From 9e8b0d620e1743122d782b262ba0ad4c393ed3f3 Mon Sep 17 00:00:00 2001 From: Pat Thoyts Date: Wed, 29 Sep 2010 15:42:16 +0100 Subject: [PATCH] Install vim73 Signed-off-by: Pat Thoyts --- bin/vi | 2 +- bin/vim | 2 +- share/vim/vim72/autoload/ccomplete.vim | 605 - share/vim/vim72/autoload/getscript.vim | 623 - share/vim/vim72/autoload/netrw.vim | 7764 -- share/vim/vim72/autoload/netrwFileHandlers.vim | 355 - share/vim/vim72/autoload/netrwSettings.vim | 200 - share/vim/vim72/autoload/pythoncomplete.vim | 599 - share/vim/vim72/autoload/rubycomplete.vim | 802 - share/vim/vim72/autoload/spellfile.vim | 179 - share/vim/vim72/autoload/sqlcomplete.vim | 693 - share/vim/vim72/autoload/syntaxcomplete.vim | 378 - share/vim/vim72/autoload/tar.vim | 500 - share/vim/vim72/autoload/vimball.vim | 762 - share/vim/vim72/autoload/zip.vim | 387 - share/vim/vim72/compiler/eruby.vim | 41 - share/vim/vim72/compiler/gcc.vim | 32 - share/vim/vim72/compiler/jikes.vim | 18 - share/vim/vim72/compiler/perl.vim | 47 - share/vim/vim72/compiler/rspec.vim | 41 - share/vim/vim72/compiler/ruby.vim | 68 - share/vim/vim72/compiler/rubyunit.vim | 35 - share/vim/vim72/doc/Makefile | 484 - share/vim/vim72/doc/arabic.txt | 322 - share/vim/vim72/doc/autocmd.txt | 1287 - share/vim/vim72/doc/change.txt | 1625 - share/vim/vim72/doc/cmdline.txt | 1080 - share/vim/vim72/doc/debug.txt | 151 - share/vim/vim72/doc/debugger.txt | 140 - share/vim/vim72/doc/develop.txt | 490 - share/vim/vim72/doc/diff.txt | 407 - share/vim/vim72/doc/digraph.txt | 350 - share/vim/vim72/doc/editing.txt | 1578 - share/vim/vim72/doc/eval.txt | 7986 -- share/vim/vim72/doc/evim-it.1 | 54 - share/vim/vim72/doc/evim-it.UTF-8.1 | 54 - share/vim/vim72/doc/evim-pl.1 | 53 - share/vim/vim72/doc/evim-pl.UTF-8.1 | 53 - share/vim/vim72/doc/farsi.txt | 269 - share/vim/vim72/doc/filetype.txt | 620 - share/vim/vim72/doc/fold.txt | 583 - share/vim/vim72/doc/ft_ada.txt | 515 - share/vim/vim72/doc/ft_sql.txt | 763 - share/vim/vim72/doc/gui.txt | 999 - share/vim/vim72/doc/gui_w16.txt | 186 - share/vim/vim72/doc/gui_w32.txt | 487 - share/vim/vim72/doc/gui_x11.txt | 585 - share/vim/vim72/doc/hangulin.txt | 101 - share/vim/vim72/doc/hebrew.txt | 142 - share/vim/vim72/doc/help.txt | 216 - share/vim/vim72/doc/howto.txt | 96 - share/vim/vim72/doc/if_cscop.txt | 483 - share/vim/vim72/doc/if_mzsch.txt | 272 - share/vim/vim72/doc/if_ole.txt | 205 - share/vim/vim72/doc/if_perl.txt | 283 - share/vim/vim72/doc/if_pyth.txt | 331 - share/vim/vim72/doc/if_ruby.txt | 205 - share/vim/vim72/doc/if_sniff.txt | 95 - share/vim/vim72/doc/if_tcl.txt | 531 - share/vim/vim72/doc/indent.txt | 774 - share/vim/vim72/doc/index.txt | 1578 - share/vim/vim72/doc/insert.txt | 1880 - share/vim/vim72/doc/intro.txt | 876 - share/vim/vim72/doc/map.txt | 1409 - share/vim/vim72/doc/mbyte.txt | 1410 - share/vim/vim72/doc/message.txt | 832 - share/vim/vim72/doc/mlang.txt | 208 - share/vim/vim72/doc/motion.txt | 1308 - share/vim/vim72/doc/netbeans.txt | 937 - share/vim/vim72/doc/options.txt | 7778 -- share/vim/vim72/doc/os_390.txt | 340 - share/vim/vim72/doc/os_amiga.txt | 145 - share/vim/vim72/doc/os_beos.txt | 348 - share/vim/vim72/doc/os_dos.txt | 296 - share/vim/vim72/doc/os_mac.txt | 118 - share/vim/vim72/doc/os_mint.txt | 39 - share/vim/vim72/doc/os_msdos.txt | 276 - share/vim/vim72/doc/os_os2.txt | 220 - share/vim/vim72/doc/os_qnx.txt | 138 - share/vim/vim72/doc/os_risc.txt | 323 - share/vim/vim72/doc/os_unix.txt | 60 - share/vim/vim72/doc/os_vms.txt | 937 - share/vim/vim72/doc/os_win32.txt | 336 - share/vim/vim72/doc/pattern.txt | 1279 - share/vim/vim72/doc/pi_getscript.txt | 417 - share/vim/vim72/doc/pi_gzip.txt | 39 - share/vim/vim72/doc/pi_netrw.txt | 3141 - share/vim/vim72/doc/pi_paren.txt | 57 - share/vim/vim72/doc/pi_spec.txt | 111 - share/vim/vim72/doc/pi_tar.txt | 90 - share/vim/vim72/doc/pi_vimball.txt | 201 - share/vim/vim72/doc/pi_zip.txt | 105 - share/vim/vim72/doc/print.txt | 755 - share/vim/vim72/doc/quickfix.txt | 1437 - share/vim/vim72/doc/quickref.txt | 1388 - share/vim/vim72/doc/quotes.txt | 274 - share/vim/vim72/doc/recover.txt | 191 - share/vim/vim72/doc/remote.txt | 204 - share/vim/vim72/doc/repeat.txt | 670 - share/vim/vim72/doc/rileft.txt | 125 - share/vim/vim72/doc/russian.txt | 74 - share/vim/vim72/doc/scroll.txt | 315 - share/vim/vim72/doc/sign.txt | 191 - share/vim/vim72/doc/spell.txt | 1580 - share/vim/vim72/doc/sponsor.txt | 216 - share/vim/vim72/doc/starting.txt | 1501 - share/vim/vim72/doc/syntax.txt | 4567 - share/vim/vim72/doc/tabpage.txt | 378 - share/vim/vim72/doc/tags | 8265 -- share/vim/vim72/doc/tagsrch.txt | 833 - share/vim/vim72/doc/term.txt | 861 - share/vim/vim72/doc/tips.txt | 508 - share/vim/vim72/doc/todo.txt | 4292 - share/vim/vim72/doc/uganda.txt | 287 - share/vim/vim72/doc/undo.txt | 242 - share/vim/vim72/doc/usr_01.txt | 185 - share/vim/vim72/doc/usr_02.txt | 564 - share/vim/vim72/doc/usr_03.txt | 654 - share/vim/vim72/doc/usr_04.txt | 514 - share/vim/vim72/doc/usr_05.txt | 625 - share/vim/vim72/doc/usr_06.txt | 276 - share/vim/vim72/doc/usr_07.txt | 479 - share/vim/vim72/doc/usr_08.txt | 601 - share/vim/vim72/doc/usr_09.txt | 289 - share/vim/vim72/doc/usr_10.txt | 824 - share/vim/vim72/doc/usr_11.txt | 287 - share/vim/vim72/doc/usr_12.txt | 358 - share/vim/vim72/doc/usr_20.txt | 384 - share/vim/vim72/doc/usr_21.txt | 499 - share/vim/vim72/doc/usr_22.txt | 400 - share/vim/vim72/doc/usr_23.txt | 343 - share/vim/vim72/doc/usr_24.txt | 606 - share/vim/vim72/doc/usr_25.txt | 578 - share/vim/vim72/doc/usr_26.txt | 221 - share/vim/vim72/doc/usr_27.txt | 563 - share/vim/vim72/doc/usr_28.txt | 426 - share/vim/vim72/doc/usr_29.txt | 613 - share/vim/vim72/doc/usr_30.txt | 643 - share/vim/vim72/doc/usr_31.txt | 272 - share/vim/vim72/doc/usr_32.txt | 151 - share/vim/vim72/doc/usr_40.txt | 657 - share/vim/vim72/doc/usr_41.txt | 2415 - share/vim/vim72/doc/usr_42.txt | 365 - share/vim/vim72/doc/usr_43.txt | 172 - share/vim/vim72/doc/usr_44.txt | 719 - share/vim/vim72/doc/usr_45.txt | 419 - share/vim/vim72/doc/usr_90.txt | 498 - share/vim/vim72/doc/usr_toc.txt | 353 - share/vim/vim72/doc/various.txt | 868 - share/vim/vim72/doc/version4.txt | 355 - share/vim/vim72/doc/version5.txt | 7813 -- share/vim/vim72/doc/version6.txt | 14530 ---- share/vim/vim72/doc/version7.txt | 7146 -- share/vim/vim72/doc/vi_diff.txt | 1009 - share/vim/vim72/doc/vim-fr.1 | 586 - share/vim/vim72/doc/vim-fr.UTF-8.1 | 586 - share/vim/vim72/doc/vim-it.1 | 566 - share/vim/vim72/doc/vim-it.UTF-8.1 | 566 - share/vim/vim72/doc/vim-pl.1 | 555 - share/vim/vim72/doc/vim-pl.UTF-8.1 | 555 - share/vim/vim72/doc/vim-ru.1 | 489 - share/vim/vim72/doc/vim-ru.UTF-8.1 | 489 - share/vim/vim72/doc/vimdiff-fr.1 | 53 - share/vim/vim72/doc/vimdiff-fr.UTF-8.1 | 53 - share/vim/vim72/doc/vimdiff-it.1 | 48 - share/vim/vim72/doc/vimdiff-it.UTF-8.1 | 48 - share/vim/vim72/doc/vimdiff-pl.1 | 46 - share/vim/vim72/doc/vimdiff-pl.UTF-8.1 | 46 - share/vim/vim72/doc/vimdiff-ru.1 | 50 - share/vim/vim72/doc/vimdiff-ru.UTF-8.1 | 50 - share/vim/vim72/doc/vimtutor-fr.1 | 55 - share/vim/vim72/doc/vimtutor-fr.UTF-8.1 | 55 - share/vim/vim72/doc/vimtutor-it.1 | 54 - share/vim/vim72/doc/vimtutor-it.UTF-8.1 | 54 - share/vim/vim72/doc/vimtutor-pl.1 | 48 - share/vim/vim72/doc/vimtutor-pl.UTF-8.1 | 48 - share/vim/vim72/doc/vimtutor.1 | 57 - share/vim/vim72/doc/vimtutor.man | 50 - share/vim/vim72/doc/visual.txt | 499 - share/vim/vim72/doc/windows.txt | 1188 - share/vim/vim72/doc/workshop.txt | 98 - share/vim/vim72/doc/xxd-fr.1 | 395 - share/vim/vim72/doc/xxd-fr.UTF-8.1 | 395 - share/vim/vim72/doc/xxd-it.1 | 402 - share/vim/vim72/doc/xxd-it.UTF-8.1 | 402 - share/vim/vim72/doc/xxd-pl.1 | 389 - share/vim/vim72/doc/xxd-pl.UTF-8.1 | 389 - share/vim/vim72/evim.vim | 66 - share/vim/vim72/filetype.vim | 2442 - share/vim/vim72/ftplugin/AppendMatchGroup.vim | 125 - share/vim/vim72/ftplugin/abaqus.vim | 79 - share/vim/vim72/ftplugin/ant.vim | 43 - share/vim/vim72/ftplugin/aspvbs.vim | 59 - share/vim/vim72/ftplugin/changelog.vim | 259 - share/vim/vim72/ftplugin/config.vim | 41 - share/vim/vim72/ftplugin/csc.vim | 26 - share/vim/vim72/ftplugin/csh.vim | 47 - share/vim/vim72/ftplugin/debchangelog.vim | 374 - share/vim/vim72/ftplugin/debcontrol.vim | 70 - share/vim/vim72/ftplugin/dosbatch.vim | 21 - share/vim/vim72/ftplugin/dtd.vim | 39 - share/vim/vim72/ftplugin/eruby.vim | 101 - share/vim/vim72/ftplugin/fortran.vim | 117 - share/vim/vim72/ftplugin/git.vim | 34 - share/vim/vim72/ftplugin/gitcommit.vim | 68 - share/vim/vim72/ftplugin/gitconfig.vim | 15 - share/vim/vim72/ftplugin/gitrebase.vim | 41 - share/vim/vim72/ftplugin/gitsendemail.vim | 6 - share/vim/vim72/ftplugin/haml.vim | 66 - share/vim/vim72/ftplugin/help.vim | 19 - share/vim/vim72/ftplugin/html.vim | 90 - share/vim/vim72/ftplugin/java.vim | 50 - share/vim/vim72/ftplugin/jsp.vim | 66 - share/vim/vim72/ftplugin/mail.vim | 35 - share/vim/vim72/ftplugin/man.vim | 181 - share/vim/vim72/ftplugin/mupad.vim | 30 - share/vim/vim72/ftplugin/ocaml.vim | 591 - share/vim/vim72/ftplugin/pascal.vim | 15 - share/vim/vim72/ftplugin/perl.vim | 71 - share/vim/vim72/ftplugin/php.vim | 82 - share/vim/vim72/ftplugin/ruby.vim | 230 - share/vim/vim72/ftplugin/sass.vim | 18 - share/vim/vim72/ftplugin/sgml.vim | 39 - share/vim/vim72/ftplugin/sh.vim | 38 - share/vim/vim72/ftplugin/sql.vim | 425 - share/vim/vim72/ftplugin/svg.vim | 39 - share/vim/vim72/ftplugin/tcsh.vim | 39 - share/vim/vim72/ftplugin/verilog.vim | 51 - share/vim/vim72/ftplugin/vim.vim | 70 - share/vim/vim72/ftplugin/xhtml.vim | 66 - share/vim/vim72/ftplugin/xml.vim | 63 - share/vim/vim72/ftplugin/xs.vim | 12 - share/vim/vim72/ftplugin/xsd.vim | 38 - share/vim/vim72/ftplugin/xslt.vim | 16 - share/vim/vim72/indent/GenericIndent.vim | 322 - share/vim/vim72/indent/cmake.vim | 92 - share/vim/vim72/indent/cpp.vim | 13 - share/vim/vim72/indent/eruby.vim | 78 - share/vim/vim72/indent/fortran.vim | 167 - share/vim/vim72/indent/gitconfig.vim | 35 - share/vim/vim72/indent/haml.vim | 73 - share/vim/vim72/indent/javascript.vim | 15 - share/vim/vim72/indent/mupad.vim | 35 - share/vim/vim72/indent/perl.vim | 180 - share/vim/vim72/indent/php.vim | 738 - share/vim/vim72/indent/ruby.vim | 378 - share/vim/vim72/indent/sass.vim | 39 - share/vim/vim72/indent/sh.vim | 52 - share/vim/vim72/indent/tf.vim | 72 - share/vim/vim72/indent/vb.vim | 75 - share/vim/vim72/indent/vhdl.vim | 406 - share/vim/vim72/indent/xml.vim | 88 - share/vim/vim72/keymap/bulgarian-bds.vim | 159 - share/vim/vim72/keymap/bulgarian-phonetic.vim | 141 - share/vim/vim72/keymap/czech_utf-8.vim | 78 - share/vim/vim72/lang/menu_de_de.latin1.vim | 303 - share/vim/vim72/lang/menu_es_es.latin1.vim | 297 - share/vim/vim72/lang/menu_it_it.latin1.vim | 349 - share/vim/vim72/lang/menu_ja_jp.euc-jp.vim | 338 - share/vim/vim72/lang/menu_ja_jp.utf-8.vim | 338 - share/vim/vim72/lang/menu_japanese_japan.932.vim | 338 - share/vim/vim72/lang/menu_ko_kr.euckr.vim | 243 - share/vim/vim72/lang/menu_ko_kr.utf-8.vim | 243 - share/vim/vim72/lang/menu_ko_kr.vim | 5 - share/vim/vim72/lang/menu_pl_pl.iso_8859-2.vim | 286 - share/vim/vim72/lang/menu_pl_pl.utf-8.vim | 286 - share/vim/vim72/lang/menu_polish_poland.1250.vim | 286 - share/vim/vim72/lang/menu_sr.utf-8.vim | 3 - share/vim/vim72/lang/menu_sr_yu.utf-8.vim | 261 - share/vim/vim72/macros/matchit.vim | 812 - share/vim/vim72/makemenu.vim | 583 - share/vim/vim72/menu.vim | 1105 - share/vim/vim72/optwin.vim | 1312 - share/vim/vim72/plugin/getscriptPlugin.vim | 38 - share/vim/vim72/plugin/gzip.vim | 36 - share/vim/vim72/plugin/matchparen.vim | 150 - share/vim/vim72/plugin/netrwPlugin.vim | 180 - share/vim/vim72/plugin/rrhelper.vim | 52 - share/vim/vim72/plugin/tarPlugin.vim | 49 - share/vim/vim72/plugin/tohtml.vim | 27 - share/vim/vim72/plugin/vimballPlugin.vim | 36 - share/vim/vim72/plugin/zipPlugin.vim | 50 - share/vim/vim72/scripts.vim | 355 - share/vim/vim72/spell/README.txt | 90 - share/vim/vim72/spell/README_en.txt | 914 - share/vim/vim72/spell/bg/main.aap | 80 - share/vim/vim72/spell/ca/main.aap | 81 - share/vim/vim72/spell/cy/main.aap | 82 - share/vim/vim72/spell/de/main.aap | 236 - share/vim/vim72/spell/eo/main.aap | 80 - share/vim/vim72/spell/es/es_MX.diff | 6975 -- share/vim/vim72/spell/es/main.aap | 92 - share/vim/vim72/spell/fr/main.aap | 126 - share/vim/vim72/spell/gd/main.aap | 77 - share/vim/vim72/spell/ku/main.aap | 82 - share/vim/vim72/spell/la/main.aap | 78 - share/vim/vim72/spell/lv/main.aap | 83 - share/vim/vim72/spell/main.aap | 26 - share/vim/vim72/spell/ms/main.aap | 81 - share/vim/vim72/spell/nb/main.aap | 78 - share/vim/vim72/spell/nl/main.aap | 78 - share/vim/vim72/spell/nl/nl_NL.diff | 85009 ------------------- share/vim/vim72/spell/nn/main.aap | 78 - share/vim/vim72/spell/pt/main.aap | 140 - share/vim/vim72/spell/pt/pt_BR.diff | 34 - share/vim/vim72/spell/pt/pt_PT.diff | 58 - share/vim/vim72/spell/sv/main.aap | 81 - share/vim/vim72/spell/sv/sv_SE.diff | 220 - share/vim/vim72/synmenu.vim | 572 - share/vim/vim72/syntax/2html.vim | 546 - share/vim/vim72/syntax/asm.vim | 103 - share/vim/vim72/syntax/bzr.vim | 51 - share/vim/vim72/syntax/c.vim | 368 - share/vim/vim72/syntax/cf.vim | 321 - share/vim/vim72/syntax/cmake.vim | 85 - share/vim/vim72/syntax/config.vim | 57 - share/vim/vim72/syntax/cs.vim | 154 - share/vim/vim72/syntax/css.vim | 282 - share/vim/vim72/syntax/d.vim | 230 - share/vim/vim72/syntax/debchangelog.vim | 59 - share/vim/vim72/syntax/debcontrol.vim | 108 - share/vim/vim72/syntax/debsources.vim | 37 - share/vim/vim72/syntax/diff.vim | 63 - share/vim/vim72/syntax/django.vim | 93 - share/vim/vim72/syntax/dosbatch.vim | 158 - share/vim/vim72/syntax/doxygen.vim | 594 - share/vim/vim72/syntax/erlang.vim | 229 - share/vim/vim72/syntax/eruby.vim | 74 - share/vim/vim72/syntax/form.vim | 101 - share/vim/vim72/syntax/forth.vim | 329 - share/vim/vim72/syntax/fortran.vim | 489 - share/vim/vim72/syntax/fstab.vim | 262 - share/vim/vim72/syntax/gdb.vim | 111 - share/vim/vim72/syntax/git.vim | 67 - share/vim/vim72/syntax/gitcommit.vim | 65 - share/vim/vim72/syntax/gitconfig.vim | 38 - share/vim/vim72/syntax/gitrebase.vim | 31 - share/vim/vim72/syntax/gitsendemail.vim | 19 - share/vim/vim72/syntax/groovy.vim | 450 - share/vim/vim72/syntax/haml.vim | 89 - share/vim/vim72/syntax/haskell.vim | 193 - share/vim/vim72/syntax/help.vim | 178 - share/vim/vim72/syntax/indent.vim | 151 - share/vim/vim72/syntax/java.vim | 348 - share/vim/vim72/syntax/javascript.vim | 137 - share/vim/vim72/syntax/jsp.vim | 84 - share/vim/vim72/syntax/kconfig.vim | 736 - share/vim/vim72/syntax/lex.vim | 100 - share/vim/vim72/syntax/lhaskell.vim | 141 - share/vim/vim72/syntax/lifelines.vim | 160 - share/vim/vim72/syntax/lilo.vim | 194 - share/vim/vim72/syntax/lisp.vim | 624 - share/vim/vim72/syntax/logtalk.vim | 398 - share/vim/vim72/syntax/mail.vim | 98 - share/vim/vim72/syntax/man.vim | 67 - share/vim/vim72/syntax/maple.vim | 631 - share/vim/vim72/syntax/matlab.vim | 109 - share/vim/vim72/syntax/maxima.vim | 274 - share/vim/vim72/syntax/mib.vim | 77 - share/vim/vim72/syntax/muttrc.vim | 707 - share/vim/vim72/syntax/mysql.vim | 297 - share/vim/vim72/syntax/netrc.vim | 51 - share/vim/vim72/syntax/netrw.vim | 103 - share/vim/vim72/syntax/papp.vim | 92 - share/vim/vim72/syntax/perl.vim | 562 - share/vim/vim72/syntax/po.vim | 135 - share/vim/vim72/syntax/pod.vim | 88 - share/vim/vim72/syntax/prolog.vim | 119 - share/vim/vim72/syntax/pyrex.vim | 67 - share/vim/vim72/syntax/python.vim | 181 - share/vim/vim72/syntax/readline.vim | 175 - share/vim/vim72/syntax/remind.vim | 69 - share/vim/vim72/syntax/rhelp.vim | 156 - share/vim/vim72/syntax/rnoweb.vim | 56 - share/vim/vim72/syntax/rst.vim | 178 - share/vim/vim72/syntax/ruby.vim | 360 - share/vim/vim72/syntax/samba.vim | 129 - share/vim/vim72/syntax/sass.vim | 56 - share/vim/vim72/syntax/scheme.vim | 309 - share/vim/vim72/syntax/screen.vim | 81 - share/vim/vim72/syntax/sed.vim | 122 - share/vim/vim72/syntax/sgmllnx.vim | 68 - share/vim/vim72/syntax/sh.vim | 594 - share/vim/vim72/syntax/sisu.vim | 192 - share/vim/vim72/syntax/spec.vim | 236 - share/vim/vim72/syntax/spyce.vim | 110 - share/vim/vim72/syntax/sqlanywhere.vim | 711 - share/vim/vim72/syntax/sshconfig.vim | 105 - share/vim/vim72/syntax/sshdconfig.vim | 104 - share/vim/vim72/syntax/synload.vim | 76 - share/vim/vim72/syntax/tcl.vim | 243 - share/vim/vim72/syntax/tcsh.vim | 244 - share/vim/vim72/syntax/tex.vim | 554 - share/vim/vim72/syntax/uil.vim | 85 - share/vim/vim72/syntax/updatedb.vim | 37 - share/vim/vim72/syntax/vim.vim | 805 - share/vim/vim72/syntax/xml.vim | 344 - share/vim/vim72/syntax/xs.vim | 54 - share/vim/vim72/syntax/yacc.vim | 120 - share/vim/vim72/syntax/yaml.vim | 83 - share/vim/vim72/syntax/zsh.vim | 213 - share/vim/vim72/tools/README.txt | 35 - share/vim/vim72/tutor/Makefile | 79 - share/vim/vim72/tutor/tutor | 970 - share/vim/vim72/tutor/tutor.eo.utf-8 | 967 - share/vim/vim72/tutor/tutor.es | 769 - share/vim/vim72/tutor/tutor.es.utf-8 | 769 - share/vim/vim72/tutor/tutor.fr | 809 - share/vim/vim72/tutor/tutor.fr.utf-8 | 809 - share/vim/vim72/tutor/tutor.hu | 823 - share/vim/vim72/tutor/tutor.hu.cp1250 | 823 - share/vim/vim72/tutor/tutor.hu.utf-8 | 823 - share/vim/vim72/tutor/tutor.it | 967 - share/vim/vim72/tutor/tutor.it.utf-8 | 967 - share/vim/vim72/tutor/tutor.ja.euc | 975 - share/vim/vim72/tutor/tutor.ja.sjis | 975 - share/vim/vim72/tutor/tutor.ja.utf-8 | 975 - share/vim/vim72/tutor/tutor.pl | 994 - share/vim/vim72/tutor/tutor.pl.cp1250 | 994 - share/vim/vim72/tutor/tutor.pl.utf-8 | 994 - share/vim/vim72/tutor/tutor.utf-8 | 970 - share/vim/vim72/vim.exe | Bin 1746944 -> 0 bytes share/vim/vim72/vimrc_example.vim | 96 - share/vim/{vim72 => vim73}/autoload/README.txt | 0 share/vim/{vim72 => vim73}/autoload/ada.vim | 0 .../vim/{vim72 => vim73}/autoload/adacomplete.vim | 0 share/vim/vim73/autoload/ccomplete.vim | 605 + .../vim/{vim72 => vim73}/autoload/csscomplete.vim | 0 share/vim/{vim72 => vim73}/autoload/decada.vim | 0 share/vim/vim73/autoload/getscript.vim | 644 + share/vim/{vim72 => vim73}/autoload/gnat.vim | 0 share/vim/{vim72 => vim73}/autoload/gzip.vim | 0 .../vim/{vim72 => vim73}/autoload/htmlcomplete.vim | 0 .../autoload/javascriptcomplete.vim | 0 share/vim/vim73/autoload/netrw.vim | 8449 ++ share/vim/vim73/autoload/netrwFileHandlers.vim | 361 + share/vim/vim73/autoload/netrwSettings.vim | 208 + share/vim/{vim72 => vim73}/autoload/paste.vim | 0 .../vim/{vim72 => vim73}/autoload/phpcomplete.vim | 0 share/vim/vim73/autoload/python3complete.vim | 606 + share/vim/vim73/autoload/pythoncomplete.vim | 625 + share/vim/vim73/autoload/rubycomplete.vim | 802 + share/vim/vim73/autoload/spellfile.vim | 208 + share/vim/vim73/autoload/sqlcomplete.vim | 795 + share/vim/vim73/autoload/syntaxcomplete.vim | 450 + share/vim/vim73/autoload/tar.vim | 599 + share/vim/vim73/autoload/tohtml.vim | 378 + share/vim/vim73/autoload/vimball.vim | 737 + share/vim/{vim72 => vim73}/autoload/xml/html32.vim | 0 .../vim/{vim72 => vim73}/autoload/xml/html401f.vim | 0 .../vim/{vim72 => vim73}/autoload/xml/html401s.vim | 0 .../vim/{vim72 => vim73}/autoload/xml/html401t.vim | 0 .../vim/{vim72 => vim73}/autoload/xml/html40f.vim | 0 .../vim/{vim72 => vim73}/autoload/xml/html40s.vim | 0 .../vim/{vim72 => vim73}/autoload/xml/html40t.vim | 0 .../vim/{vim72 => vim73}/autoload/xml/xhtml10f.vim | 0 .../vim/{vim72 => vim73}/autoload/xml/xhtml10s.vim | 0 .../vim/{vim72 => vim73}/autoload/xml/xhtml10t.vim | 0 .../vim/{vim72 => vim73}/autoload/xml/xhtml11.vim | 0 share/vim/{vim72 => vim73}/autoload/xml/xsd.vim | 0 share/vim/{vim72 => vim73}/autoload/xml/xsl.vim | 0 .../vim/{vim72 => vim73}/autoload/xmlcomplete.vim | 0 share/vim/vim73/autoload/zip.vim | 393 + share/vim/{vim72 => vim73}/bugreport.vim | 0 share/vim/{vim72 => vim73}/colors/README.txt | 0 share/vim/{vim72 => vim73}/colors/blue.vim | 0 share/vim/{vim72 => vim73}/colors/darkblue.vim | 0 share/vim/{vim72 => vim73}/colors/default.vim | 0 share/vim/{vim72 => vim73}/colors/delek.vim | 0 share/vim/{vim72 => vim73}/colors/desert.vim | 0 share/vim/{vim72 => vim73}/colors/elflord.vim | 0 share/vim/{vim72 => vim73}/colors/evening.vim | 0 share/vim/{vim72 => vim73}/colors/koehler.vim | 0 share/vim/{vim72 => vim73}/colors/morning.vim | 0 share/vim/{vim72 => vim73}/colors/murphy.vim | 0 share/vim/{vim72 => vim73}/colors/pablo.vim | 0 share/vim/{vim72 => vim73}/colors/peachpuff.vim | 0 share/vim/{vim72 => vim73}/colors/ron.vim | 0 share/vim/{vim72 => vim73}/colors/shine.vim | 0 share/vim/{vim72 => vim73}/colors/slate.vim | 0 share/vim/{vim72 => vim73}/colors/torte.vim | 0 share/vim/{vim72 => vim73}/colors/zellner.vim | 0 share/vim/{vim72 => vim73}/compiler/README.txt | 0 share/vim/{vim72 => vim73}/compiler/ant.vim | 0 share/vim/{vim72 => vim73}/compiler/bcc.vim | 0 share/vim/{vim72 => vim73}/compiler/bdf.vim | 0 share/vim/{vim72 => vim73}/compiler/checkstyle.vim | 0 share/vim/{vim72 => vim73}/compiler/cs.vim | 0 share/vim/vim73/compiler/cucumber.vim | 29 + share/vim/{vim72 => vim73}/compiler/decada.vim | 0 share/vim/{vim72 => vim73}/compiler/dot.vim | 0 share/vim/vim73/compiler/eruby.vim | 41 + share/vim/{vim72 => vim73}/compiler/fortran_F.vim | 0 share/vim/{vim72 => vim73}/compiler/fortran_cv.vim | 0 .../{vim72 => vim73}/compiler/fortran_elf90.vim | 0 .../vim/{vim72 => vim73}/compiler/fortran_g77.vim | 0 .../vim/{vim72 => vim73}/compiler/fortran_lf95.vim | 0 share/vim/{vim72 => vim73}/compiler/fpc.vim | 0 share/vim/vim73/compiler/gcc.vim | 39 + share/vim/{vim72 => vim73}/compiler/gnat.vim | 0 share/vim/{vim72 => vim73}/compiler/hp_acc.vim | 0 share/vim/{vim72 => vim73}/compiler/icc.vim | 0 share/vim/{vim72 => vim73}/compiler/intel.vim | 0 share/vim/{vim72 => vim73}/compiler/irix5_c.vim | 0 share/vim/{vim72 => vim73}/compiler/irix5_cpp.vim | 0 share/vim/{vim72 => vim73}/compiler/javac.vim | 0 share/vim/vim73/compiler/jikes.vim | 18 + share/vim/{vim72 => vim73}/compiler/mcs.vim | 0 share/vim/{vim72 => vim73}/compiler/mips_c.vim | 0 .../vim/{vim72 => vim73}/compiler/mipspro_c89.vim | 0 .../vim/{vim72 => vim73}/compiler/mipspro_cpp.vim | 0 .../{vim72 => vim73}/compiler/modelsim_vcom.vim | 0 share/vim/{vim72 => vim73}/compiler/msvc.vim | 0 share/vim/{vim72 => vim73}/compiler/neato.vim | 0 share/vim/{vim72 => vim73}/compiler/onsgmls.vim | 0 share/vim/{vim72 => vim73}/compiler/pbx.vim | 0 share/vim/vim73/compiler/perl.vim | 47 + share/vim/{vim72 => vim73}/compiler/php.vim | 0 share/vim/{vim72 => vim73}/compiler/pyunit.vim | 0 share/vim/vim73/compiler/rspec.vim | 41 + share/vim/{vim72 => vim73}/compiler/rst.vim | 0 share/vim/vim73/compiler/ruby.vim | 68 + share/vim/vim73/compiler/rubyunit.vim | 35 + share/vim/{vim72 => vim73}/compiler/se.vim | 0 share/vim/{vim72 => vim73}/compiler/splint.vim | 0 share/vim/{vim72 => vim73}/compiler/tcl.vim | 0 share/vim/{vim72 => vim73}/compiler/tex.vim | 0 share/vim/{vim72 => vim73}/compiler/tidy.vim | 0 share/vim/{vim72 => vim73}/compiler/xmllint.vim | 0 share/vim/{vim72 => vim73}/compiler/xmlwf.vim | 0 share/vim/{vim72 => vim73}/delmenu.vim | 0 share/vim/{vim72 => vim73}/doc.info | Bin share/vim/vim73/doc/Makefile | 490 + share/vim/vim73/doc/arabic.txt | 322 + share/vim/vim73/doc/autocmd.txt | 1303 + share/vim/vim73/doc/change.txt | 1659 + share/vim/vim73/doc/cmdline.txt | 1091 + share/vim/vim73/doc/debug.txt | 174 + share/vim/vim73/doc/debugger.txt | 140 + share/vim/vim73/doc/develop.txt | 490 + share/vim/vim73/doc/diff.txt | 414 + share/vim/vim73/doc/digraph.txt | 350 + share/vim/{vim72 => vim73}/doc/doctags.c | 0 share/vim/vim73/doc/editing.txt | 1634 + share/vim/vim73/doc/eval.txt | 8324 ++ share/vim/{vim72 => vim73}/doc/evim-fr.1 | 0 share/vim/{vim72 => vim73}/doc/evim-fr.UTF-8.1 | 0 share/vim/vim73/doc/evim-it.1 | 54 + share/vim/vim73/doc/evim-it.UTF-8.1 | 54 + share/vim/vim73/doc/evim-pl.1 | 53 + share/vim/vim73/doc/evim-pl.UTF-8.1 | 53 + share/vim/{vim72 => vim73}/doc/evim-ru.1 | 0 share/vim/{vim72 => vim73}/doc/evim-ru.UTF-8.1 | 0 share/vim/{vim72 => vim73}/doc/evim.1 | 0 share/vim/vim73/doc/farsi.txt | 269 + share/vim/vim73/doc/filetype.txt | 620 + share/vim/vim73/doc/fold.txt | 590 + share/vim/vim73/doc/ft_ada.txt | 515 + share/vim/vim73/doc/ft_sql.txt | 776 + share/vim/vim73/doc/gui.txt | 1001 + share/vim/vim73/doc/gui_w16.txt | 186 + share/vim/vim73/doc/gui_w32.txt | 487 + share/vim/vim73/doc/gui_x11.txt | 583 + share/vim/vim73/doc/hangulin.txt | 105 + share/vim/vim73/doc/hebrew.txt | 142 + share/vim/vim73/doc/help.txt | 221 + share/vim/{vim72 => vim73}/doc/help.txt.info | Bin share/vim/vim73/doc/helphelp.txt | 349 + share/vim/vim73/doc/howto.txt | 96 + share/vim/vim73/doc/if_cscop.txt | 490 + share/vim/vim73/doc/if_lua.txt | 244 + share/vim/vim73/doc/if_mzsch.txt | 259 + share/vim/vim73/doc/if_ole.txt | 205 + share/vim/vim73/doc/if_perl.txt | 291 + share/vim/vim73/doc/if_pyth.txt | 382 + share/vim/vim73/doc/if_ruby.txt | 213 + share/vim/vim73/doc/if_sniff.txt | 95 + share/vim/vim73/doc/if_tcl.txt | 531 + share/vim/vim73/doc/indent.txt | 811 + share/vim/vim73/doc/index.txt | 1599 + share/vim/vim73/doc/insert.txt | 1916 + share/vim/vim73/doc/intro.txt | 881 + share/vim/{vim72 => vim73}/doc/makehtml.awk | 0 share/vim/{vim72 => vim73}/doc/maketags.awk | 0 share/vim/vim73/doc/map.txt | 1424 + share/vim/vim73/doc/mbyte.txt | 1426 + share/vim/vim73/doc/message.txt | 842 + share/vim/vim73/doc/mlang.txt | 210 + share/vim/vim73/doc/motion.txt | 1312 + share/vim/vim73/doc/netbeans.txt | 989 + share/vim/vim73/doc/options.txt | 8046 ++ share/vim/vim73/doc/os_390.txt | 135 + share/vim/vim73/doc/os_amiga.txt | 147 + share/vim/vim73/doc/os_beos.txt | 319 + share/vim/vim73/doc/os_dos.txt | 296 + share/vim/vim73/doc/os_mac.txt | 118 + share/vim/vim73/doc/os_mint.txt | 39 + share/vim/vim73/doc/os_msdos.txt | 276 + share/vim/vim73/doc/os_os2.txt | 221 + share/vim/vim73/doc/os_qnx.txt | 138 + share/vim/vim73/doc/os_risc.txt | 322 + share/vim/vim73/doc/os_unix.txt | 60 + share/vim/vim73/doc/os_vms.txt | 941 + share/vim/vim73/doc/os_win32.txt | 339 + share/vim/vim73/doc/pattern.txt | 1289 + share/vim/vim73/doc/pi_getscript.txt | 435 + share/vim/vim73/doc/pi_gzip.txt | 39 + share/vim/vim73/doc/pi_netrw.txt | 3561 + share/vim/vim73/doc/pi_paren.txt | 57 + share/vim/vim73/doc/pi_spec.txt | 111 + share/vim/vim73/doc/pi_tar.txt | 124 + share/vim/vim73/doc/pi_vimball.txt | 247 + share/vim/vim73/doc/pi_zip.txt | 115 + share/vim/vim73/doc/print.txt | 755 + share/vim/vim73/doc/quickfix.txt | 1447 + share/vim/vim73/doc/quickref.txt | 1401 + share/vim/vim73/doc/quotes.txt | 274 + share/vim/vim73/doc/recover.txt | 230 + share/vim/vim73/doc/remote.txt | 204 + share/vim/vim73/doc/repeat.txt | 676 + share/vim/vim73/doc/rileft.txt | 124 + share/vim/vim73/doc/russian.txt | 74 + share/vim/vim73/doc/scroll.txt | 332 + share/vim/vim73/doc/sign.txt | 191 + share/vim/vim73/doc/spell.txt | 1613 + share/vim/vim73/doc/sponsor.txt | 216 + share/vim/vim73/doc/starting.txt | 1513 + share/vim/vim73/doc/syntax.txt | 4757 ++ share/vim/vim73/doc/tabpage.txt | 382 + share/vim/vim73/doc/tags | 8529 ++ share/vim/vim73/doc/tagsrch.txt | 837 + share/vim/vim73/doc/term.txt | 876 + share/vim/vim73/doc/tips.txt | 534 + share/vim/vim73/doc/todo.txt | 4748 ++ share/vim/vim73/doc/uganda.txt | 288 + share/vim/vim73/doc/undo.txt | 386 + share/vim/vim73/doc/usr_01.txt | 185 + share/vim/vim73/doc/usr_02.txt | 564 + share/vim/vim73/doc/usr_03.txt | 654 + share/vim/vim73/doc/usr_04.txt | 514 + share/vim/vim73/doc/usr_05.txt | 625 + share/vim/vim73/doc/usr_06.txt | 280 + share/vim/vim73/doc/usr_07.txt | 479 + share/vim/vim73/doc/usr_08.txt | 601 + share/vim/vim73/doc/usr_09.txt | 289 + share/vim/vim73/doc/usr_10.txt | 824 + share/vim/vim73/doc/usr_11.txt | 307 + share/vim/vim73/doc/usr_12.txt | 358 + share/vim/vim73/doc/usr_20.txt | 384 + share/vim/vim73/doc/usr_21.txt | 499 + share/vim/vim73/doc/usr_22.txt | 400 + share/vim/vim73/doc/usr_23.txt | 343 + share/vim/vim73/doc/usr_24.txt | 606 + share/vim/vim73/doc/usr_25.txt | 578 + share/vim/vim73/doc/usr_26.txt | 221 + share/vim/vim73/doc/usr_27.txt | 563 + share/vim/vim73/doc/usr_28.txt | 426 + share/vim/vim73/doc/usr_29.txt | 613 + share/vim/vim73/doc/usr_30.txt | 643 + share/vim/vim73/doc/usr_31.txt | 272 + share/vim/vim73/doc/usr_32.txt | 180 + share/vim/vim73/doc/usr_40.txt | 657 + share/vim/vim73/doc/usr_41.txt | 2429 + share/vim/vim73/doc/usr_42.txt | 365 + share/vim/vim73/doc/usr_43.txt | 173 + share/vim/vim73/doc/usr_44.txt | 719 + share/vim/vim73/doc/usr_45.txt | 419 + share/vim/vim73/doc/usr_90.txt | 498 + share/vim/vim73/doc/usr_toc.txt | 354 + share/vim/vim73/doc/various.txt | 629 + share/vim/vim73/doc/version4.txt | 355 + share/vim/vim73/doc/version5.txt | 7813 ++ share/vim/vim73/doc/version6.txt | 14530 ++++ share/vim/vim73/doc/version7.txt | 10154 +++ share/vim/vim73/doc/vi_diff.txt | 1009 + share/vim/vim73/doc/vim-fr.1 | 588 + share/vim/vim73/doc/vim-fr.UTF-8.1 | 588 + share/vim/vim73/doc/vim-it.1 | 566 + share/vim/vim73/doc/vim-it.UTF-8.1 | 566 + share/vim/vim73/doc/vim-pl.1 | 558 + share/vim/vim73/doc/vim-pl.UTF-8.1 | 558 + share/vim/vim73/doc/vim-ru.1 | 489 + share/vim/vim73/doc/vim-ru.UTF-8.1 | 489 + share/vim/{vim72 => vim73}/doc/vim.1 | 0 share/vim/{vim72 => vim73}/doc/vim.man | 0 share/vim/{vim72 => vim73}/doc/vim.man.info | Bin share/vim/{vim72 => vim73}/doc/vim2html.pl | 0 share/vim/vim73/doc/vimdiff-fr.1 | 53 + share/vim/vim73/doc/vimdiff-fr.UTF-8.1 | 53 + share/vim/vim73/doc/vimdiff-it.1 | 48 + share/vim/vim73/doc/vimdiff-it.UTF-8.1 | 48 + share/vim/vim73/doc/vimdiff-pl.1 | 46 + share/vim/vim73/doc/vimdiff-pl.UTF-8.1 | 46 + share/vim/vim73/doc/vimdiff-ru.1 | 50 + share/vim/vim73/doc/vimdiff-ru.UTF-8.1 | 50 + share/vim/{vim72 => vim73}/doc/vimdiff.1 | 0 share/vim/{vim72 => vim73}/doc/vimdiff.man | 0 share/vim/vim73/doc/vimtutor-fr.1 | 59 + share/vim/vim73/doc/vimtutor-fr.UTF-8.1 | 59 + share/vim/vim73/doc/vimtutor-it.1 | 58 + share/vim/vim73/doc/vimtutor-it.UTF-8.1 | 58 + share/vim/vim73/doc/vimtutor-pl.1 | 51 + share/vim/vim73/doc/vimtutor-pl.UTF-8.1 | 51 + share/vim/{vim72 => vim73}/doc/vimtutor-ru.1 | 0 share/vim/{vim72 => vim73}/doc/vimtutor-ru.UTF-8.1 | 0 share/vim/vim73/doc/vimtutor.1 | 57 + share/vim/vim73/doc/vimtutor.man | 50 + share/vim/vim73/doc/visual.txt | 509 + share/vim/vim73/doc/windows.txt | 1194 + share/vim/vim73/doc/workshop.txt | 98 + share/vim/vim73/doc/xxd-fr.1 | 395 + share/vim/vim73/doc/xxd-fr.UTF-8.1 | 395 + share/vim/vim73/doc/xxd-it.1 | 402 + share/vim/vim73/doc/xxd-it.UTF-8.1 | 402 + share/vim/vim73/doc/xxd-pl.1 | 389 + share/vim/vim73/doc/xxd-pl.UTF-8.1 | 389 + share/vim/{vim72 => vim73}/doc/xxd-ru.1 | 0 share/vim/{vim72 => vim73}/doc/xxd-ru.UTF-8.1 | 0 share/vim/{vim72 => vim73}/doc/xxd.1 | 0 share/vim/{vim72 => vim73}/doc/xxd.man | 0 share/vim/vim73/evim.vim | 66 + share/vim/vim73/filetype.vim | 2514 + share/vim/{vim72 => vim73}/ftoff.vim | 0 share/vim/{vim72 => vim73}/ftplugin.vim | 0 share/vim/{vim72 => vim73}/ftplugin/README.txt | 0 share/vim/{vim72 => vim73}/ftplugin/a2ps.vim | 0 share/vim/{vim72 => vim73}/ftplugin/aap.vim | 0 share/vim/vim73/ftplugin/abaqus.vim | 89 + share/vim/{vim72 => vim73}/ftplugin/ada.vim | 0 share/vim/{vim72 => vim73}/ftplugin/alsaconf.vim | 0 share/vim/vim73/ftplugin/ant.vim | 43 + share/vim/{vim72 => vim73}/ftplugin/arch.vim | 0 share/vim/{vim72 => vim73}/ftplugin/art.vim | 0 share/vim/vim73/ftplugin/aspvbs.vim | 59 + share/vim/{vim72 => vim73}/ftplugin/automake.vim | 0 share/vim/{vim72 => vim73}/ftplugin/bdf.vim | 0 share/vim/{vim72 => vim73}/ftplugin/bst.vim | 0 share/vim/{vim72 => vim73}/ftplugin/btm.vim | 0 share/vim/{vim72 => vim73}/ftplugin/c.vim | 0 share/vim/{vim72 => vim73}/ftplugin/calendar.vim | 0 share/vim/{vim72 => vim73}/ftplugin/cdrdaoconf.vim | 0 share/vim/{vim72 => vim73}/ftplugin/ch.vim | 0 share/vim/vim73/ftplugin/changelog.vim | 301 + share/vim/{vim72 => vim73}/ftplugin/cobol.vim | 0 share/vim/{vim72 => vim73}/ftplugin/conf.vim | 0 share/vim/vim73/ftplugin/config.vim | 41 + share/vim/{vim72 => vim73}/ftplugin/context.vim | 0 share/vim/{vim72 => vim73}/ftplugin/cpp.vim | 0 share/vim/{vim72 => vim73}/ftplugin/crm.vim | 0 share/vim/{vim72 => vim73}/ftplugin/cs.vim | 0 share/vim/vim73/ftplugin/csc.vim | 26 + share/vim/vim73/ftplugin/csh.vim | 47 + share/vim/{vim72 => vim73}/ftplugin/css.vim | 0 share/vim/vim73/ftplugin/cucumber.vim | 132 + share/vim/{vim72 => vim73}/ftplugin/cvsrc.vim | 0 share/vim/vim73/ftplugin/debchangelog.vim | 383 + share/vim/vim73/ftplugin/debcontrol.vim | 70 + share/vim/{vim72 => vim73}/ftplugin/denyhosts.vim | 0 share/vim/{vim72 => vim73}/ftplugin/dictconf.vim | 0 share/vim/{vim72 => vim73}/ftplugin/dictdconf.vim | 0 share/vim/{vim72 => vim73}/ftplugin/diff.vim | 0 share/vim/{vim72 => vim73}/ftplugin/dircolors.vim | 0 share/vim/vim73/ftplugin/dosbatch.vim | 21 + share/vim/{vim72 => vim73}/ftplugin/dosini.vim | 0 share/vim/vim73/ftplugin/dtd.vim | 39 + share/vim/{vim72 => vim73}/ftplugin/dtrace.vim | 0 share/vim/{vim72 => vim73}/ftplugin/elinks.vim | 0 share/vim/vim73/ftplugin/eruby.vim | 104 + share/vim/{vim72 => vim73}/ftplugin/eterm.vim | 0 share/vim/{vim72 => vim73}/ftplugin/fetchmail.vim | 0 share/vim/{vim72 => vim73}/ftplugin/flexwiki.vim | 0 share/vim/vim73/ftplugin/fortran.vim | 118 + .../vim/{vim72 => vim73}/ftplugin/framescript.vim | 0 share/vim/{vim72 => vim73}/ftplugin/fvwm.vim | 0 share/vim/vim73/ftplugin/git.vim | 37 + share/vim/vim73/ftplugin/gitcommit.vim | 68 + share/vim/vim73/ftplugin/gitconfig.vim | 15 + share/vim/vim73/ftplugin/gitrebase.vim | 43 + share/vim/vim73/ftplugin/gitsendemail.vim | 6 + share/vim/{vim72 => vim73}/ftplugin/gpg.vim | 0 share/vim/{vim72 => vim73}/ftplugin/group.vim | 0 share/vim/{vim72 => vim73}/ftplugin/grub.vim | 0 share/vim/vim73/ftplugin/haml.vim | 67 + share/vim/{vim72 => vim73}/ftplugin/hamster.vim | 0 share/vim/{vim72 => vim73}/ftplugin/haskell.vim | 0 share/vim/vim73/ftplugin/help.vim | 19 + share/vim/{vim72 => vim73}/ftplugin/hostconf.vim | 0 .../vim/{vim72 => vim73}/ftplugin/hostsaccess.vim | 0 share/vim/vim73/ftplugin/html.vim | 90 + share/vim/{vim72 => vim73}/ftplugin/htmldjango.vim | 0 share/vim/{vim72 => vim73}/ftplugin/indent.vim | 0 share/vim/{vim72 => vim73}/ftplugin/initex.vim | 0 share/vim/{vim72 => vim73}/ftplugin/ishd.vim | 0 share/vim/vim73/ftplugin/java.vim | 50 + share/vim/{vim72 => vim73}/ftplugin/javascript.vim | 0 share/vim/vim73/ftplugin/jsp.vim | 66 + share/vim/{vim72 => vim73}/ftplugin/kconfig.vim | 0 share/vim/{vim72 => vim73}/ftplugin/kwt.vim | 0 share/vim/{vim72 => vim73}/ftplugin/ld.vim | 0 share/vim/{vim72 => vim73}/ftplugin/lftp.vim | 0 share/vim/{vim72 => vim73}/ftplugin/libao.vim | 0 share/vim/{vim72 => vim73}/ftplugin/limits.vim | 0 share/vim/vim73/ftplugin/liquid.vim | 61 + share/vim/{vim72 => vim73}/ftplugin/lisp.vim | 0 share/vim/vim73/ftplugin/logcheck.vim | 17 + .../vim/{vim72 => vim73}/ftplugin/loginaccess.vim | 0 share/vim/{vim72 => vim73}/ftplugin/logindefs.vim | 0 share/vim/{vim72 => vim73}/ftplugin/logtalk.dict | 0 share/vim/{vim72 => vim73}/ftplugin/logtalk.vim | 0 share/vim/{vim72 => vim73}/ftplugin/lprolog.vim | 0 share/vim/{vim72 => vim73}/ftplugin/lua.vim | 0 share/vim/{vim72 => vim73}/ftplugin/m4.vim | 0 share/vim/vim73/ftplugin/mail.vim | 35 + .../vim/{vim72 => vim73}/ftplugin/mailaliases.vim | 0 share/vim/{vim72 => vim73}/ftplugin/mailcap.vim | 0 share/vim/{vim72 => vim73}/ftplugin/make.vim | 0 share/vim/vim73/ftplugin/man.vim | 181 + share/vim/{vim72 => vim73}/ftplugin/manconf.vim | 0 share/vim/vim73/ftplugin/markdown.vim | 19 + share/vim/{vim72 => vim73}/ftplugin/matlab.vim | 0 share/vim/{vim72 => vim73}/ftplugin/mf.vim | 0 share/vim/{vim72 => vim73}/ftplugin/modconf.vim | 0 share/vim/{vim72 => vim73}/ftplugin/mp.vim | 0 .../vim/{vim72 => vim73}/ftplugin/mplayerconf.vim | 0 share/vim/{vim72 => vim73}/ftplugin/mrxvtrc.vim | 0 share/vim/{vim72 => vim73}/ftplugin/msmessages.vim | 0 share/vim/{vim72 => vim73}/ftplugin/muttrc.vim | 0 share/vim/{vim72 => vim73}/ftplugin/nanorc.vim | 0 share/vim/{vim72 => vim73}/ftplugin/netrc.vim | 0 share/vim/{vim72 => vim73}/ftplugin/nsis.vim | 0 share/vim/{vim72 => vim73}/ftplugin/objc.vim | 0 share/vim/vim73/ftplugin/ocaml.vim | 584 + share/vim/{vim72 => vim73}/ftplugin/occam.vim | 0 share/vim/{vim72 => vim73}/ftplugin/pamconf.vim | 0 share/vim/vim73/ftplugin/pascal.vim | 15 + share/vim/{vim72 => vim73}/ftplugin/passwd.vim | 0 share/vim/{vim72 => vim73}/ftplugin/pdf.vim | 0 share/vim/vim73/ftplugin/perl.vim | 71 + share/vim/vim73/ftplugin/perl6.vim | 48 + share/vim/vim73/ftplugin/php.vim | 82 + share/vim/{vim72 => vim73}/ftplugin/pinfo.vim | 0 share/vim/{vim72 => vim73}/ftplugin/plaintex.vim | 0 share/vim/{vim72 => vim73}/ftplugin/postscr.vim | 0 share/vim/{vim72 => vim73}/ftplugin/procmail.vim | 0 share/vim/{vim72 => vim73}/ftplugin/prolog.vim | 0 share/vim/{vim72 => vim73}/ftplugin/protocols.vim | 0 share/vim/{vim72 => vim73}/ftplugin/pyrex.vim | 0 share/vim/{vim72 => vim73}/ftplugin/python.vim | 0 share/vim/vim73/ftplugin/qf.vim | 16 + share/vim/{vim72 => vim73}/ftplugin/quake.vim | 0 share/vim/{vim72 => vim73}/ftplugin/racc.vim | 0 share/vim/{vim72 => vim73}/ftplugin/readline.vim | 0 share/vim/{vim72 => vim73}/ftplugin/reva.vim | 0 share/vim/{vim72 => vim73}/ftplugin/rnc.vim | 0 share/vim/{vim72 => vim73}/ftplugin/rpl.vim | 0 share/vim/{vim72 => vim73}/ftplugin/rst.vim | 0 share/vim/vim73/ftplugin/ruby.vim | 274 + share/vim/vim73/ftplugin/sass.vim | 22 + share/vim/{vim72 => vim73}/ftplugin/scheme.vim | 0 share/vim/{vim72 => vim73}/ftplugin/screen.vim | 0 share/vim/vim73/ftplugin/scss.vim | 12 + share/vim/{vim72 => vim73}/ftplugin/sensors.vim | 0 share/vim/{vim72 => vim73}/ftplugin/services.vim | 0 share/vim/{vim72 => vim73}/ftplugin/setserial.vim | 0 share/vim/vim73/ftplugin/sgml.vim | 39 + share/vim/vim73/ftplugin/sh.vim | 38 + share/vim/{vim72 => vim73}/ftplugin/sieve.vim | 0 share/vim/{vim72 => vim73}/ftplugin/slpconf.vim | 0 share/vim/{vim72 => vim73}/ftplugin/slpreg.vim | 0 share/vim/{vim72 => vim73}/ftplugin/slpspi.vim | 0 share/vim/{vim72 => vim73}/ftplugin/spec.vim | 0 share/vim/vim73/ftplugin/sql.vim | 493 + share/vim/{vim72 => vim73}/ftplugin/sshconfig.vim | 0 share/vim/{vim72 => vim73}/ftplugin/sudoers.vim | 0 share/vim/vim73/ftplugin/svg.vim | 39 + share/vim/{vim72 => vim73}/ftplugin/sysctl.vim | 0 share/vim/vim73/ftplugin/tcl.vim | 36 + share/vim/vim73/ftplugin/tcsh.vim | 39 + share/vim/{vim72 => vim73}/ftplugin/terminfo.vim | 0 share/vim/{vim72 => vim73}/ftplugin/tex.vim | 0 share/vim/{vim72 => vim73}/ftplugin/udevconf.vim | 0 share/vim/{vim72 => vim73}/ftplugin/udevperm.vim | 0 share/vim/{vim72 => vim73}/ftplugin/udevrules.vim | 0 share/vim/{vim72 => vim73}/ftplugin/updatedb.vim | 0 share/vim/{vim72 => vim73}/ftplugin/vb.vim | 0 share/vim/vim73/ftplugin/verilog.vim | 57 + share/vim/{vim72 => vim73}/ftplugin/vhdl.vim | 0 share/vim/vim73/ftplugin/vim.vim | 74 + share/vim/{vim72 => vim73}/ftplugin/xdefaults.vim | 0 share/vim/{vim72 => vim73}/ftplugin/xf86conf.vim | 0 share/vim/vim73/ftplugin/xhtml.vim | 66 + share/vim/{vim72 => vim73}/ftplugin/xinetd.vim | 0 share/vim/vim73/ftplugin/xml.vim | 63 + share/vim/{vim72 => vim73}/ftplugin/xmodmap.vim | 0 share/vim/vim73/ftplugin/xs.vim | 13 + share/vim/vim73/ftplugin/xsd.vim | 38 + share/vim/vim73/ftplugin/xslt.vim | 16 + share/vim/{vim72 => vim73}/ftplugin/yaml.vim | 0 share/vim/{vim72 => vim73}/ftplugin/zsh.vim | 0 share/vim/{vim72 => vim73}/ftplugof.vim | 0 share/vim/{vim72 => vim73}/gvimrc_example.vim | 0 share/vim/{vim72 => vim73}/hi16-action-make.png | Bin share/vim/{vim72 => vim73}/hi22-action-make.png | Bin share/vim/{vim72 => vim73}/icons.info | Bin share/vim/{vim72 => vim73}/icons/README.txt | 0 share/vim/{vim72 => vim73}/icons/README.txt.info | Bin share/vim/{vim72 => vim73}/icons/Vim_32Colors.info | Bin .../{vim72 => vim73}/icons/Vim_4ColorsLace.info | Bin share/vim/{vim72 => vim73}/icons/Vim_8Colors.info | Bin .../{vim72 => vim73}/icons/Vim_8ColorsLace.info | Bin share/vim/{vim72 => vim73}/indent.vim | 0 share/vim/{vim72 => vim73}/indent/README.txt | 0 share/vim/{vim72 => vim73}/indent/aap.vim | 0 share/vim/{vim72 => vim73}/indent/ada.vim | 0 share/vim/{vim72 => vim73}/indent/ant.vim | 0 share/vim/{vim72 => vim73}/indent/automake.vim | 0 share/vim/{vim72 => vim73}/indent/awk.vim | 0 share/vim/{vim72 => vim73}/indent/bib.vim | 0 share/vim/{vim72 => vim73}/indent/bst.vim | 0 share/vim/{vim72 => vim73}/indent/c.vim | 0 share/vim/{vim72 => vim73}/indent/cdl.vim | 0 share/vim/{vim72 => vim73}/indent/ch.vim | 0 share/vim/vim73/indent/chaiscript.vim | 50 + share/vim/{vim72 => vim73}/indent/changelog.vim | 0 share/vim/vim73/indent/cmake.vim | 85 + share/vim/{vim72 => vim73}/indent/cobol.vim | 0 share/vim/{vim72 => vim73}/indent/config.vim | 0 share/vim/vim73/indent/cpp.vim | 15 + share/vim/{vim72 => vim73}/indent/cs.vim | 0 share/vim/{vim72 => vim73}/indent/css.vim | 0 share/vim/vim73/indent/cucumber.vim | 60 + share/vim/vim73/indent/cuda.vim | 15 + share/vim/{vim72 => vim73}/indent/d.vim | 0 share/vim/{vim72 => vim73}/indent/dictconf.vim | 0 share/vim/{vim72 => vim73}/indent/dictdconf.vim | 0 share/vim/{vim72 => vim73}/indent/docbk.vim | 0 share/vim/{vim72 => vim73}/indent/dtd.vim | 0 share/vim/{vim72 => vim73}/indent/dtrace.vim | 0 share/vim/{vim72 => vim73}/indent/dylan.vim | 0 share/vim/{vim72 => vim73}/indent/eiffel.vim | 0 share/vim/{vim72 => vim73}/indent/erlang.vim | 0 share/vim/vim73/indent/eruby.vim | 81 + share/vim/{vim72 => vim73}/indent/eterm.vim | 0 share/vim/vim73/indent/fortran.vim | 166 + share/vim/{vim72 => vim73}/indent/framescript.vim | 0 share/vim/vim73/indent/gitconfig.vim | 35 + share/vim/vim73/indent/haml.vim | 73 + share/vim/{vim72 => vim73}/indent/hamster.vim | 0 share/vim/{vim72 => vim73}/indent/html.vim | 0 share/vim/{vim72 => vim73}/indent/htmldjango.vim | 0 share/vim/{vim72 => vim73}/indent/idlang.vim | 0 share/vim/{vim72 => vim73}/indent/ishd.vim | 0 share/vim/{vim72 => vim73}/indent/java.vim | 0 share/vim/vim73/indent/javascript.vim | 16 + share/vim/{vim72 => vim73}/indent/jsp.vim | 0 share/vim/{vim72 => vim73}/indent/ld.vim | 0 share/vim/vim73/indent/lifelines.vim | 24 + share/vim/vim73/indent/liquid.vim | 63 + share/vim/{vim72 => vim73}/indent/lisp.vim | 0 share/vim/{vim72 => vim73}/indent/logtalk.vim | 0 share/vim/{vim72 => vim73}/indent/lua.vim | 0 share/vim/vim73/indent/mail.vim | 13 + share/vim/{vim72 => vim73}/indent/make.vim | 0 share/vim/{vim72 => vim73}/indent/matlab.vim | 0 share/vim/{vim72 => vim73}/indent/mma.vim | 0 share/vim/{vim72 => vim73}/indent/mp.vim | 0 share/vim/{vim72 => vim73}/indent/objc.vim | 0 share/vim/{vim72 => vim73}/indent/ocaml.vim | 0 share/vim/{vim72 => vim73}/indent/occam.vim | 0 share/vim/{vim72 => vim73}/indent/pascal.vim | 0 share/vim/vim73/indent/perl.vim | 180 + share/vim/vim73/indent/perl6.vim | 136 + share/vim/vim73/indent/php.vim | 733 + share/vim/{vim72 => vim73}/indent/postscr.vim | 0 share/vim/{vim72 => vim73}/indent/pov.vim | 0 share/vim/{vim72 => vim73}/indent/prolog.vim | 0 share/vim/{vim72 => vim73}/indent/pyrex.vim | 0 share/vim/{vim72 => vim73}/indent/python.vim | 0 share/vim/{vim72 => vim73}/indent/readline.vim | 0 share/vim/{vim72 => vim73}/indent/rpl.vim | 0 share/vim/{vim72 => vim73}/indent/rst.vim | 0 share/vim/vim73/indent/ruby.vim | 378 + share/vim/vim73/indent/sass.vim | 39 + share/vim/{vim72 => vim73}/indent/scheme.vim | 0 share/vim/vim73/indent/scss.vim | 12 + share/vim/{vim72 => vim73}/indent/sdl.vim | 0 share/vim/vim73/indent/sh.vim | 158 + share/vim/{vim72 => vim73}/indent/sml.vim | 0 share/vim/{vim72 => vim73}/indent/sql.vim | 0 share/vim/{vim72 => vim73}/indent/sqlanywhere.vim | 0 share/vim/{vim72 => vim73}/indent/tcl.vim | 0 share/vim/{vim72 => vim73}/indent/tcsh.vim | 0 share/vim/vim73/indent/tf.vim | 72 + share/vim/{vim72 => vim73}/indent/tilde.vim | 0 share/vim/vim73/indent/vb.vim | 78 + share/vim/{vim72 => vim73}/indent/verilog.vim | 0 share/vim/vim73/indent/vhdl.vim | 406 + share/vim/{vim72 => vim73}/indent/vim.vim | 0 share/vim/{vim72 => vim73}/indent/xf86conf.vim | 0 share/vim/{vim72 => vim73}/indent/xhtml.vim | 0 share/vim/{vim72 => vim73}/indent/xinetd.vim | 0 share/vim/vim73/indent/xml.vim | 96 + share/vim/{vim72 => vim73}/indent/xsd.vim | 0 share/vim/{vim72 => vim73}/indent/xslt.vim | 0 share/vim/{vim72 => vim73}/indent/yacc.vim | 0 share/vim/{vim72 => vim73}/indent/zsh.vim | 0 share/vim/{vim72 => vim73}/indoff.vim | 0 share/vim/{vim72 => vim73}/keymap/README.txt | 0 share/vim/{vim72 => vim73}/keymap/accents.vim | 0 share/vim/{vim72 => vim73}/keymap/arabic.vim | 0 share/vim/{vim72 => vim73}/keymap/arabic_utf-8.vim | 0 share/vim/vim73/keymap/bulgarian-bds.vim | 155 + share/vim/vim73/keymap/bulgarian-phonetic.vim | 135 + share/vim/{vim72 => vim73}/keymap/canfr-win.vim | 0 share/vim/{vim72 => vim73}/keymap/croatian.vim | 0 .../{vim72 => vim73}/keymap/croatian_cp1250.vim | 0 .../keymap/croatian_iso-8859-2.vim | 0 .../vim/{vim72 => vim73}/keymap/croatian_utf-8.vim | 0 share/vim/{vim72 => vim73}/keymap/czech.vim | 0 share/vim/vim73/keymap/czech_utf-8.vim | 86 + share/vim/vim73/keymap/dvorak.vim | 82 + share/vim/{vim72 => vim73}/keymap/esperanto.vim | 0 .../{vim72 => vim73}/keymap/esperanto_utf-8.vim | 0 share/vim/{vim72 => vim73}/keymap/greek.vim | 0 share/vim/{vim72 => vim73}/keymap/greek_cp1253.vim | 0 share/vim/{vim72 => vim73}/keymap/greek_cp737.vim | 0 .../{vim72 => vim73}/keymap/greek_iso-8859-7.vim | 0 share/vim/{vim72 => vim73}/keymap/greek_utf-8.vim | 0 share/vim/{vim72 => vim73}/keymap/hebrew.vim | 0 .../vim/{vim72 => vim73}/keymap/hebrew_cp1255.vim | 0 .../{vim72 => vim73}/keymap/hebrew_iso-8859-8.vim | 0 share/vim/{vim72 => vim73}/keymap/hebrew_utf-8.vim | 0 share/vim/{vim72 => vim73}/keymap/hebrewp.vim | 0 .../vim/{vim72 => vim73}/keymap/hebrewp_cp1255.vim | 0 .../{vim72 => vim73}/keymap/hebrewp_iso-8859-8.vim | 0 .../vim/{vim72 => vim73}/keymap/hebrewp_utf-8.vim | 0 share/vim/{vim72 => vim73}/keymap/kana.vim | 0 .../{vim72 => vim73}/keymap/lithuanian-baltic.vim | 0 share/vim/{vim72 => vim73}/keymap/magyar_utf-8.vim | 0 .../{vim72 => vim73}/keymap/mongolian_utf-8.vim | 0 .../keymap/persian-iranian_utf-8.vim | 0 share/vim/{vim72 => vim73}/keymap/persian.vim | 0 share/vim/{vim72 => vim73}/keymap/pinyin.vim | 0 share/vim/{vim72 => vim73}/keymap/polish-slash.vim | 0 .../keymap/polish-slash_cp1250.vim | 0 .../{vim72 => vim73}/keymap/polish-slash_cp852.vim | 0 .../keymap/polish-slash_iso-8859-2.vim | 0 .../{vim72 => vim73}/keymap/polish-slash_utf-8.vim | 0 .../vim/{vim72 => vim73}/keymap/russian-dvorak.vim | 0 .../vim/{vim72 => vim73}/keymap/russian-jcuken.vim | 0 .../{vim72 => vim73}/keymap/russian-jcukenwin.vim | 0 .../{vim72 => vim73}/keymap/russian-yawerty.vim | 0 .../vim/{vim72 => vim73}/keymap/serbian-latin.vim | 0 .../keymap/serbian-latin_utf-8.vim | 0 share/vim/{vim72 => vim73}/keymap/serbian.vim | 0 .../vim/{vim72 => vim73}/keymap/serbian_cp1250.vim | 0 .../vim/{vim72 => vim73}/keymap/serbian_cp1251.vim | 0 .../{vim72 => vim73}/keymap/serbian_iso-8859-2.vim | 0 .../{vim72 => vim73}/keymap/serbian_iso-8859-5.vim | 0 .../vim/{vim72 => vim73}/keymap/serbian_utf-8.vim | 0 .../keymap/sinhala-phonetic_utf-8.vim | 0 share/vim/{vim72 => vim73}/keymap/sinhala.vim | 0 share/vim/{vim72 => vim73}/keymap/slovak.vim | 0 .../vim/{vim72 => vim73}/keymap/slovak_cp1250.vim | 0 .../{vim72 => vim73}/keymap/slovak_iso-8859-2.vim | 0 share/vim/{vim72 => vim73}/keymap/slovak_utf-8.vim | 0 share/vim/{vim72 => vim73}/keymap/tamil_tscii.vim | 0 .../keymap/thaana-phonetic_utf-8.vim | 0 share/vim/{vim72 => vim73}/keymap/thaana.vim | 0 .../{vim72 => vim73}/keymap/ukrainian-dvorak.vim | 0 .../{vim72 => vim73}/keymap/ukrainian-jcuken.vim | 0 .../keymap/vietnamese-viqr_utf-8.vim | 0 share/vim/{vim72 => vim73}/lang/README.txt | 0 share/vim/{vim72 => vim73}/lang/menu_af.latin1.vim | 0 share/vim/{vim72 => vim73}/lang/menu_af.utf-8.vim | 0 .../{vim72 => vim73}/lang/menu_af_af.latin1.vim | 0 .../vim/{vim72 => vim73}/lang/menu_af_af.utf-8.vim | 0 share/vim/{vim72 => vim73}/lang/menu_ca.latin1.vim | 0 share/vim/{vim72 => vim73}/lang/menu_ca.utf-8.vim | 0 .../{vim72 => vim73}/lang/menu_ca_es.latin1.vim | 0 .../vim/{vim72 => vim73}/lang/menu_ca_es.utf-8.vim | 0 .../lang/menu_chinese(gb)_gb.936.vim | 0 .../lang/menu_chinese(taiwan)_taiwan.950.vim | 0 .../{vim72 => vim73}/lang/menu_chinese_gb.936.vim | 0 .../lang/menu_chinese_taiwan.950.vim | 0 share/vim/{vim72 => vim73}/lang/menu_cs.cp1250.vim | 0 share/vim/{vim72 => vim73}/lang/menu_cs.latin1.vim | 0 .../{vim72 => vim73}/lang/menu_cs_cz.cp1250.vim | 0 .../lang/menu_cs_cz.iso_8859-2.vim | 0 .../{vim72 => vim73}/lang/menu_cs_cz.latin1.vim | 0 .../lang/menu_czech_czech_republic.1250.vim | 0 .../lang/menu_czech_czech_republic.1252.vim | 0 .../lang/menu_czech_czech_republic.ascii.vim | 0 share/vim/{vim72 => vim73}/lang/menu_de.latin1.vim | 0 share/vim/{vim72 => vim73}/lang/menu_de.utf-8.vim | 0 share/vim/vim73/lang/menu_de_de.latin1.vim | 304 + .../vim/{vim72 => vim73}/lang/menu_de_de.utf-8.vim | 0 .../{vim72 => vim73}/lang/menu_en_gb.latin1.vim | 0 .../vim/{vim72 => vim73}/lang/menu_en_gb.utf-8.vim | 0 .../lang/menu_english_united_kingdom.1252.vim | 0 .../lang/menu_english_united_kingdom.ascii.vim | 0 share/vim/{vim72 => vim73}/lang/menu_eo.utf-8.vim | 0 .../vim/{vim72 => vim73}/lang/menu_eo_eo.utf-8.vim | 0 .../vim/{vim72 => vim73}/lang/menu_eo_xx.utf-8.vim | 0 share/vim/{vim72 => vim73}/lang/menu_es.latin1.vim | 0 share/vim/{vim72 => vim73}/lang/menu_es.utf-8.vim | 0 share/vim/vim73/lang/menu_es_es.latin1.vim | 318 + .../vim/{vim72 => vim73}/lang/menu_es_es.utf-8.vim | 0 share/vim/{vim72 => vim73}/lang/menu_fi.latin1.vim | 0 share/vim/{vim72 => vim73}/lang/menu_fi.utf-8.vim | 0 .../{vim72 => vim73}/lang/menu_fi_fi.latin1.vim | 0 .../vim/{vim72 => vim73}/lang/menu_fi_fi.utf-8.vim | 0 .../lang/menu_finnish_finland.1252.vim | 0 share/vim/{vim72 => vim73}/lang/menu_fr.latin1.vim | 0 share/vim/{vim72 => vim73}/lang/menu_fr.utf-8.vim | 0 .../{vim72 => vim73}/lang/menu_fr_fr.latin1.vim | 0 .../vim/{vim72 => vim73}/lang/menu_fr_fr.utf-8.vim | 0 .../lang/menu_french_france.1252.vim | 0 .../lang/menu_german_germany.1252.vim | 0 .../{vim72 => vim73}/lang/menu_hu.iso_8859-2.vim | 0 share/vim/{vim72 => vim73}/lang/menu_hu.utf-8.vim | 0 .../lang/menu_hu_hu.iso_8859-2.vim | 0 .../vim/{vim72 => vim73}/lang/menu_hu_hu.utf-8.vim | 0 share/vim/{vim72 => vim73}/lang/menu_it.latin1.vim | 0 share/vim/{vim72 => vim73}/lang/menu_it.utf-8.vim | 0 share/vim/vim73/lang/menu_it_it.latin1.vim | 351 + .../vim/{vim72 => vim73}/lang/menu_it_it.utf-8.vim | 0 .../lang/menu_italian_italy.1252.vim | 0 share/vim/{vim72 => vim73}/lang/menu_ja.cp932.vim | 0 share/vim/{vim72 => vim73}/lang/menu_ja.euc-jp.vim | 0 share/vim/{vim72 => vim73}/lang/menu_ja.eucjp.vim | 0 share/vim/{vim72 => vim73}/lang/menu_ja.ujis.vim | 0 share/vim/{vim72 => vim73}/lang/menu_ja.utf-8.vim | 0 .../vim/{vim72 => vim73}/lang/menu_ja_jp.cp932.vim | 0 share/vim/vim73/lang/menu_ja_jp.euc-jp.vim | 338 + .../vim/{vim72 => vim73}/lang/menu_ja_jp.eucjp.vim | 0 .../vim/{vim72 => vim73}/lang/menu_ja_jp.ujis.vim | 0 share/vim/vim73/lang/menu_ja_jp.utf-8.vim | 338 + share/vim/vim73/lang/menu_japanese_japan.932.vim | 338 + share/vim/{vim72 => vim73}/lang/menu_ko.utf-8.vim | 0 share/vim/vim73/lang/menu_ko_kr.euckr.vim | 261 + share/vim/vim73/lang/menu_ko_kr.utf-8.vim | 261 + share/vim/vim73/lang/menu_ko_kr.vim | 5 + share/vim/{vim72 => vim73}/lang/menu_nl.latin1.vim | 0 share/vim/{vim72 => vim73}/lang/menu_nl.utf-8.vim | 0 .../{vim72 => vim73}/lang/menu_nl_nl.latin1.vim | 0 .../vim/{vim72 => vim73}/lang/menu_nl_nl.utf-8.vim | 0 share/vim/{vim72 => vim73}/lang/menu_no.latin1.vim | 0 share/vim/{vim72 => vim73}/lang/menu_no.utf-8.vim | 0 .../{vim72 => vim73}/lang/menu_no_no.latin1.vim | 0 .../vim/{vim72 => vim73}/lang/menu_no_no.utf-8.vim | 0 share/vim/{vim72 => vim73}/lang/menu_pl.cp1250.vim | 0 .../{vim72 => vim73}/lang/menu_pl_pl.cp1250.vim | 0 share/vim/vim73/lang/menu_pl_pl.iso_8859-2.vim | 287 + share/vim/vim73/lang/menu_pl_pl.utf-8.vim | 287 + share/vim/vim73/lang/menu_polish_poland.1250.vim | 287 + .../{vim72 => vim73}/lang/menu_pt_br.latin1.vim | 0 .../vim/{vim72 => vim73}/lang/menu_pt_br.utf-8.vim | 0 share/vim/{vim72 => vim73}/lang/menu_pt_br.vim | 0 .../{vim72 => vim73}/lang/menu_pt_pt.latin1.vim | 0 .../vim/{vim72 => vim73}/lang/menu_pt_pt.utf-8.vim | 0 share/vim/{vim72 => vim73}/lang/menu_pt_pt.vim | 0 share/vim/{vim72 => vim73}/lang/menu_ru.utf-8.vim | 0 .../{vim72 => vim73}/lang/menu_ru_ru.koi8-r.vim | 0 .../vim/{vim72 => vim73}/lang/menu_ru_ru.utf-8.vim | 0 share/vim/{vim72 => vim73}/lang/menu_ru_ru.vim | 0 share/vim/{vim72 => vim73}/lang/menu_sk.cp1250.vim | 0 .../vim/{vim72 => vim73}/lang/menu_sk_sk.1250.vim | 0 .../{vim72 => vim73}/lang/menu_sk_sk.cp1250.vim | 0 .../lang/menu_sk_sk.iso_8859-2.vim | 0 share/vim/{vim72 => vim73}/lang/menu_sk_sk.vim | 0 .../{vim72 => vim73}/lang/menu_sl_si.cp1250.vim | 0 .../{vim72 => vim73}/lang/menu_sl_si.latin2.vim | 0 .../vim/{vim72 => vim73}/lang/menu_sl_si.utf-8.vim | 0 .../lang/menu_slovak_slovak_republic.1250.vim | 0 .../lang/menu_spanish_spain.850.vim | 0 share/vim/vim73/lang/menu_sr.utf-8.vim | 3 + .../lang/menu_sr_rs.ascii.vim} | 0 .../lang/menu_sr_rs.iso_8859-2.vim} | 0 .../lang/menu_sr_rs.iso_8859-5.vim} | 0 share/vim/vim73/lang/menu_sr_rs.utf-8.vim | 261 + share/vim/vim73/lang/menu_sr_yu.ascii.vim | 3 + share/vim/vim73/lang/menu_sr_yu.iso_8859-2.vim | 3 + share/vim/vim73/lang/menu_sr_yu.iso_8859-5.vim | 3 + share/vim/vim73/lang/menu_sr_yu.utf-8.vim | 3 + share/vim/{vim72 => vim73}/lang/menu_sv.latin1.vim | 0 share/vim/{vim72 => vim73}/lang/menu_sv.utf-8.vim | 0 .../{vim72 => vim73}/lang/menu_sv_se.latin1.vim | 0 .../vim/{vim72 => vim73}/lang/menu_sv_se.utf-8.vim | 0 .../{vim72 => vim73}/lang/menu_uk_ua.cp1251.vim | 0 .../{vim72 => vim73}/lang/menu_uk_ua.koi8-u.vim | 0 share/vim/{vim72 => vim73}/lang/menu_vi_vn.vim | 0 share/vim/{vim72 => vim73}/lang/menu_zh.big5.vim | 0 share/vim/{vim72 => vim73}/lang/menu_zh.cp936.vim | 0 share/vim/{vim72 => vim73}/lang/menu_zh.cp950.vim | 0 share/vim/{vim72 => vim73}/lang/menu_zh.gb2312.vim | 0 .../vim/{vim72 => vim73}/lang/menu_zh_cn.18030.vim | 0 .../vim/{vim72 => vim73}/lang/menu_zh_cn.cp936.vim | 0 .../{vim72 => vim73}/lang/menu_zh_cn.gb2312.vim | 0 share/vim/{vim72 => vim73}/lang/menu_zh_cn.gbk.vim | 0 .../vim/{vim72 => vim73}/lang/menu_zh_cn.utf-8.vim | 0 .../vim/{vim72 => vim73}/lang/menu_zh_tw.big5.vim | 0 .../vim/{vim72 => vim73}/lang/menu_zh_tw.cp950.vim | 0 .../vim/{vim72 => vim73}/lang/menu_zh_tw.utf-8.vim | 0 share/vim/{vim72 => vim73}/macmap.vim | 0 share/vim/{vim72 => vim73}/macros.info | Bin share/vim/{vim72 => vim73}/macros/README.txt | 0 share/vim/{vim72 => vim73}/macros/README.txt.info | Bin share/vim/{vim72 => vim73}/macros/dvorak | 0 share/vim/{vim72 => vim73}/macros/editexisting.vim | 0 share/vim/{vim72 => vim73}/macros/hanoi.info | Bin share/vim/{vim72 => vim73}/macros/hanoi/click.me | 0 .../{vim72 => vim73}/macros/hanoi/click.me.info | Bin share/vim/{vim72 => vim73}/macros/hanoi/hanoi.vim | 0 share/vim/{vim72 => vim73}/macros/hanoi/poster | 0 .../vim/{vim72 => vim73}/macros/hanoi/poster.info | Bin share/vim/{vim72 => vim73}/macros/justify.vim | 0 share/vim/{vim72 => vim73}/macros/less.sh | 0 share/vim/{vim72 => vim73}/macros/less.vim | 0 share/vim/{vim72 => vim73}/macros/life/click.me | 0 .../vim/{vim72 => vim73}/macros/life/click.me.info | Bin share/vim/{vim72 => vim73}/macros/life/life.vim | 0 share/vim/{vim72 => vim73}/macros/matchit.txt | 0 share/vim/vim73/macros/matchit.vim | 812 + share/vim/{vim72 => vim73}/macros/maze.info | Bin share/vim/{vim72 => vim73}/macros/maze/Makefile | 0 share/vim/{vim72 => vim73}/macros/maze/README.txt | 0 .../{vim72 => vim73}/macros/maze/README.txt.info | Bin share/vim/{vim72 => vim73}/macros/maze/main.aap | 0 share/vim/{vim72 => vim73}/macros/maze/maze.c | 0 share/vim/{vim72 => vim73}/macros/maze/maze_5.78 | 0 .../{vim72 => vim73}/macros/maze/maze_5.78.info | Bin share/vim/{vim72 => vim73}/macros/maze/maze_mac | 0 share/vim/{vim72 => vim73}/macros/maze/mazeansi.c | 0 share/vim/{vim72 => vim73}/macros/maze/mazeclean.c | 0 share/vim/{vim72 => vim73}/macros/maze/poster | 0 share/vim/{vim72 => vim73}/macros/maze/poster.info | Bin share/vim/{vim72 => vim73}/macros/shellmenu.vim | 0 share/vim/{vim72 => vim73}/macros/swapmous.vim | 0 share/vim/{vim72 => vim73}/macros/urm.info | Bin share/vim/{vim72 => vim73}/macros/urm/README.txt | 0 .../{vim72 => vim73}/macros/urm/README.txt.info | Bin share/vim/{vim72 => vim73}/macros/urm/examples | 0 share/vim/{vim72 => vim73}/macros/urm/urm | 0 share/vim/{vim72 => vim73}/macros/urm/urm.vim | 0 share/vim/vim73/makemenu.vim | 600 + share/vim/vim73/menu.vim | 1106 + share/vim/{vim72 => vim73}/mswin.vim | 0 share/vim/vim73/optwin.vim | 1342 + share/vim/{vim72 => vim73}/plugin/README.txt | 0 share/vim/vim73/plugin/getscriptPlugin.vim | 38 + share/vim/vim73/plugin/gzip.vim | 44 + share/vim/vim73/plugin/matchparen.vim | 151 + share/vim/vim73/plugin/netrwPlugin.vim | 168 + share/vim/vim73/plugin/rrhelper.vim | 48 + share/vim/{vim72 => vim73}/plugin/spellfile.vim | 0 share/vim/vim73/plugin/tarPlugin.vim | 53 + share/vim/vim73/plugin/tohtml.vim | 31 + share/vim/vim73/plugin/vimballPlugin.vim | 36 + share/vim/vim73/plugin/zipPlugin.vim | 50 + share/vim/{vim72 => vim73}/print/ascii.ps | 0 share/vim/{vim72 => vim73}/print/cidfont.ps | 0 share/vim/{vim72 => vim73}/print/cns_roman.ps | 0 share/vim/{vim72 => vim73}/print/cp1250.ps | 0 share/vim/{vim72 => vim73}/print/cp1251.ps | 0 share/vim/{vim72 => vim73}/print/cp1252.ps | 0 share/vim/{vim72 => vim73}/print/cp1253.ps | 0 share/vim/{vim72 => vim73}/print/cp1254.ps | 0 share/vim/{vim72 => vim73}/print/cp1255.ps | 0 share/vim/{vim72 => vim73}/print/cp1257.ps | 0 share/vim/{vim72 => vim73}/print/dec-mcs.ps | 0 share/vim/{vim72 => vim73}/print/ebcdic-uk.ps | 0 share/vim/{vim72 => vim73}/print/gb_roman.ps | 0 share/vim/{vim72 => vim73}/print/hp-roman8.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-10.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-11.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-13.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-14.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-15.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-2.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-3.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-4.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-5.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-7.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-8.ps | 0 share/vim/{vim72 => vim73}/print/iso-8859-9.ps | 0 share/vim/{vim72 => vim73}/print/jis_roman.ps | 0 share/vim/{vim72 => vim73}/print/koi8-r.ps | 0 share/vim/{vim72 => vim73}/print/koi8-u.ps | 0 share/vim/{vim72 => vim73}/print/ks_roman.ps | 0 share/vim/{vim72 => vim73}/print/latin1.ps | 0 share/vim/{vim72 => vim73}/print/mac-roman.ps | 0 share/vim/{vim72 => vim73}/print/prolog.ps | 0 share/vim/{vim72 => vim73}/rgb.txt | 0 share/vim/vim73/scripts.vim | 360 + share/vim/vim73/spell/README.txt | 112 + share/vim/vim73/spell/README_en.txt | 913 + share/vim/{vim72 => vim73}/spell/af/af_ZA.diff | 0 share/vim/{vim72 => vim73}/spell/af/main.aap | 0 share/vim/{vim72 => vim73}/spell/am/am_ET.diff | 0 share/vim/{vim72 => vim73}/spell/am/main.aap | 0 share/vim/{vim72 => vim73}/spell/bg/bg_BG.diff | 0 share/vim/vim73/spell/bg/main.aap | 80 + share/vim/vim73/spell/br/br_FR.diff | 13 + share/vim/vim73/spell/br/main.aap | 86 + share/vim/{vim72 => vim73}/spell/ca/ca_ES.diff | 0 share/vim/vim73/spell/ca/main.aap | 81 + share/vim/vim73/spell/check/check_aa.aff | 50 + share/vim/vim73/spell/check/check_aa.dic | 12 + share/vim/vim73/spell/check/check_bb.aff | 50 + share/vim/vim73/spell/check/check_bb.dic | 12 + share/vim/vim73/spell/check/main.aap | 15 + share/vim/vim73/spell/check_locales.vim | 21 + share/vim/{vim72 => vim73}/spell/cleanadd.vim | 0 share/vim/{vim72 => vim73}/spell/cs/cs_CZ.diff | 0 share/vim/{vim72 => vim73}/spell/cs/main.aap | 0 share/vim/{vim72 => vim73}/spell/cy/cy_GB.diff | 0 share/vim/vim73/spell/cy/main.aap | 82 + share/vim/{vim72 => vim73}/spell/da/da_DK.diff | 0 share/vim/{vim72 => vim73}/spell/da/main.aap | 0 share/vim/{vim72 => vim73}/spell/de/de_19.diff | 0 share/vim/{vim72 => vim73}/spell/de/de_20.diff | 0 share/vim/{vim72 => vim73}/spell/de/de_AT.diff | 0 share/vim/{vim72 => vim73}/spell/de/de_CH.diff | 0 share/vim/{vim72 => vim73}/spell/de/de_DE.diff | 0 share/vim/vim73/spell/de/main.aap | 236 + share/vim/{vim72 => vim73}/spell/el/el_GR.diff | 0 share/vim/{vim72 => vim73}/spell/el/main.aap | 0 share/vim/{vim72 => vim73}/spell/en.ascii.spl | Bin share/vim/{vim72 => vim73}/spell/en.ascii.sug | Bin share/vim/{vim72 => vim73}/spell/en.latin1.spl | Bin share/vim/{vim72 => vim73}/spell/en.latin1.sug | Bin share/vim/{vim72 => vim73}/spell/en.utf-8.spl | Bin share/vim/{vim72 => vim73}/spell/en.utf-8.sug | Bin share/vim/{vim72 => vim73}/spell/en/en_AU.diff | 0 share/vim/{vim72 => vim73}/spell/en/en_CA.diff | 0 share/vim/{vim72 => vim73}/spell/en/en_GB.diff | 0 share/vim/{vim72 => vim73}/spell/en/en_NZ.diff | 0 share/vim/{vim72 => vim73}/spell/en/en_US.diff | 0 share/vim/{vim72 => vim73}/spell/en/main.aap | 0 share/vim/{vim72 => vim73}/spell/eo/eo_l3.diff | 0 share/vim/vim73/spell/eo/main.aap | 80 + share/vim/{vim72 => vim73}/spell/es/es_ES.diff | 0 share/vim/vim73/spell/es/es_MX.diff | 6975 ++ share/vim/vim73/spell/es/main.aap | 92 + .../{vim72/spell/fixdup => vim73/spell/fixdup.vim} | 0 share/vim/{vim72 => vim73}/spell/fo/fo_FO.diff | 0 share/vim/{vim72 => vim73}/spell/fo/main.aap | 0 share/vim/{vim72 => vim73}/spell/fr/fr_FR.diff | 0 share/vim/vim73/spell/fr/main.aap | 126 + share/vim/{vim72 => vim73}/spell/ga/ga_IE.diff | 0 share/vim/{vim72 => vim73}/spell/ga/main.aap | 0 share/vim/{vim72 => vim73}/spell/gd/gd_GB.diff | 0 share/vim/vim73/spell/gd/main.aap | 77 + share/vim/{vim72 => vim73}/spell/gl/gl_ES.diff | 0 share/vim/{vim72 => vim73}/spell/gl/main.aap | 0 share/vim/{vim72 => vim73}/spell/he.vim | 0 share/vim/{vim72 => vim73}/spell/he/he_IL.diff | 0 share/vim/{vim72 => vim73}/spell/he/main.aap | 0 share/vim/{vim72 => vim73}/spell/hr/hr_HR.diff | 0 share/vim/{vim72 => vim73}/spell/hr/main.aap | 0 share/vim/{vim72 => vim73}/spell/hu/hu_HU.diff | 0 share/vim/{vim72 => vim73}/spell/hu/main.aap | 0 share/vim/{vim72 => vim73}/spell/id/id_ID.diff | 0 share/vim/{vim72 => vim73}/spell/id/main.aap | 0 share/vim/{vim72 => vim73}/spell/it/it_IT.diff | 0 share/vim/{vim72 => vim73}/spell/it/main.aap | 0 share/vim/{vim72 => vim73}/spell/ku/ku_TR.diff | 0 share/vim/vim73/spell/ku/main.aap | 82 + share/vim/{vim72 => vim73}/spell/la/la.diff | 0 share/vim/vim73/spell/la/main.aap | 81 + share/vim/{vim72 => vim73}/spell/lt/lt_LT.diff | 0 share/vim/{vim72 => vim73}/spell/lt/main.aap | 0 share/vim/{vim72 => vim73}/spell/lv/lv_LV.diff | 0 share/vim/vim73/spell/lv/main.aap | 83 + share/vim/vim73/spell/main.aap | 26 + share/vim/{vim72 => vim73}/spell/mg/main.aap | 0 share/vim/{vim72 => vim73}/spell/mg/mg_MG.diff | 0 share/vim/{vim72 => vim73}/spell/mi/main.aap | 0 share/vim/{vim72 => vim73}/spell/mi/mi_NZ.diff | 0 share/vim/vim73/spell/ms/main.aap | 81 + share/vim/{vim72 => vim73}/spell/ms/ms_MY.diff | 0 share/vim/vim73/spell/nb/main.aap | 78 + share/vim/{vim72 => vim73}/spell/nb/nb_NO.diff | 0 share/vim/vim73/spell/nl/main.aap | 96 + share/vim/vim73/spell/nl/nl_NL.diff | 228 + share/vim/vim73/spell/nn/main.aap | 78 + share/vim/{vim72 => vim73}/spell/nn/nn_NO.diff | 0 share/vim/{vim72 => vim73}/spell/ny/main.aap | 0 share/vim/{vim72 => vim73}/spell/ny/ny_MW.diff | 0 share/vim/{vim72 => vim73}/spell/pl/main.aap | 0 share/vim/{vim72 => vim73}/spell/pl/pl_PL.diff | 0 share/vim/vim73/spell/pt/main.aap | 168 + share/vim/vim73/spell/pt/pt_BR.diff | 88 + share/vim/vim73/spell/pt/pt_PT.diff | 45 + share/vim/{vim72 => vim73}/spell/ro/main.aap | 0 share/vim/{vim72 => vim73}/spell/ro/ro_RO.diff | 0 share/vim/{vim72 => vim73}/spell/ru/main.aap | 0 share/vim/{vim72 => vim73}/spell/ru/ru_RU.diff | 0 share/vim/{vim72 => vim73}/spell/ru/ru_YO.diff | 0 share/vim/{vim72 => vim73}/spell/rw/main.aap | 0 share/vim/{vim72 => vim73}/spell/rw/rw_RW.diff | 0 share/vim/{vim72 => vim73}/spell/sk/main.aap | 0 share/vim/{vim72 => vim73}/spell/sk/sk_SK.diff | 0 share/vim/{vim72 => vim73}/spell/sl/main.aap | 0 share/vim/{vim72 => vim73}/spell/sl/sl_SI.diff | 0 share/vim/vim73/spell/sv/main.aap | 93 + share/vim/vim73/spell/sv/sv_SE.diff | 205 + share/vim/{vim72 => vim73}/spell/sw/main.aap | 0 share/vim/{vim72 => vim73}/spell/sw/sw_KE.diff | 0 share/vim/vim73/spell/tet/main.aap | 79 + share/vim/vim73/spell/tet/tet_ID.diff | 26 + share/vim/{vim72 => vim73}/spell/th/main.aap | 0 share/vim/{vim72 => vim73}/spell/th/th.diff | 0 share/vim/{vim72 => vim73}/spell/tl/main.aap | 0 share/vim/{vim72 => vim73}/spell/tl/tl_PH.diff | 0 share/vim/{vim72 => vim73}/spell/tn/main.aap | 0 share/vim/{vim72 => vim73}/spell/tn/tn_ZA.diff | 0 share/vim/{vim72 => vim73}/spell/uk/main.aap | 0 share/vim/{vim72 => vim73}/spell/uk/uk_UA.diff | 0 share/vim/{vim72 => vim73}/spell/yi.vim | 0 share/vim/{vim72 => vim73}/spell/yi/README.txt | 0 share/vim/{vim72 => vim73}/spell/yi/main.aap | 0 share/vim/{vim72 => vim73}/spell/yi/yi.diff | 0 share/vim/{vim72 => vim73}/spell/yi/yi_tr.diff | 0 share/vim/{vim72 => vim73}/spell/zu/main.aap | 0 share/vim/{vim72 => vim73}/spell/zu/zu_ZA.diff | 0 share/vim/vim73/synmenu.vim | 586 + share/vim/vim73/syntax/2html.vim | 1120 + share/vim/{vim72 => vim73}/syntax/README.txt | 0 share/vim/{vim72 => vim73}/syntax/a2ps.vim | 0 share/vim/{vim72 => vim73}/syntax/a65.vim | 0 share/vim/{vim72 => vim73}/syntax/aap.vim | 0 share/vim/{vim72 => vim73}/syntax/abap.vim | 0 share/vim/{vim72 => vim73}/syntax/abaqus.vim | 0 share/vim/{vim72 => vim73}/syntax/abc.vim | 0 share/vim/{vim72 => vim73}/syntax/abel.vim | 0 share/vim/{vim72 => vim73}/syntax/acedb.vim | 0 share/vim/{vim72 => vim73}/syntax/ada.vim | 0 share/vim/{vim72 => vim73}/syntax/aflex.vim | 0 share/vim/{vim72 => vim73}/syntax/ahdl.vim | 0 share/vim/{vim72 => vim73}/syntax/alsaconf.vim | 0 share/vim/{vim72 => vim73}/syntax/amiga.vim | 0 share/vim/{vim72 => vim73}/syntax/aml.vim | 0 share/vim/{vim72 => vim73}/syntax/ampl.vim | 0 share/vim/{vim72 => vim73}/syntax/ant.vim | 0 share/vim/{vim72 => vim73}/syntax/antlr.vim | 0 share/vim/{vim72 => vim73}/syntax/apache.vim | 0 share/vim/{vim72 => vim73}/syntax/apachestyle.vim | 0 share/vim/{vim72 => vim73}/syntax/arch.vim | 0 share/vim/{vim72 => vim73}/syntax/art.vim | 0 share/vim/vim73/syntax/asm.vim | 108 + share/vim/{vim72 => vim73}/syntax/asm68k.vim | 0 share/vim/{vim72 => vim73}/syntax/asmh8300.vim | 0 share/vim/{vim72 => vim73}/syntax/asn.vim | 0 share/vim/{vim72 => vim73}/syntax/aspperl.vim | 0 share/vim/{vim72 => vim73}/syntax/aspvbs.vim | 0 share/vim/{vim72 => vim73}/syntax/asterisk.vim | 0 share/vim/{vim72 => vim73}/syntax/asteriskvm.vim | 0 share/vim/{vim72 => vim73}/syntax/atlas.vim | 0 share/vim/{vim72 => vim73}/syntax/autohotkey.vim | 0 share/vim/{vim72 => vim73}/syntax/autoit.vim | 0 share/vim/{vim72 => vim73}/syntax/automake.vim | 0 share/vim/{vim72 => vim73}/syntax/ave.vim | 0 share/vim/{vim72 => vim73}/syntax/awk.vim | 0 share/vim/{vim72 => vim73}/syntax/ayacc.vim | 0 share/vim/{vim72 => vim73}/syntax/b.vim | 0 share/vim/{vim72 => vim73}/syntax/baan.vim | 0 share/vim/{vim72 => vim73}/syntax/basic.vim | 0 share/vim/{vim72 => vim73}/syntax/bc.vim | 0 share/vim/{vim72 => vim73}/syntax/bdf.vim | 0 share/vim/{vim72 => vim73}/syntax/bib.vim | 0 share/vim/{vim72 => vim73}/syntax/bindzone.vim | 0 share/vim/{vim72 => vim73}/syntax/blank.vim | 0 share/vim/{vim72 => vim73}/syntax/bst.vim | 0 share/vim/{vim72 => vim73}/syntax/btm.vim | 0 share/vim/vim73/syntax/bzr.vim | 63 + share/vim/vim73/syntax/c.vim | 374 + share/vim/vim73/syntax/cabal.vim | 132 + share/vim/{vim72 => vim73}/syntax/calendar.vim | 0 share/vim/{vim72 => vim73}/syntax/catalog.vim | 0 share/vim/{vim72 => vim73}/syntax/cdl.vim | Bin share/vim/{vim72 => vim73}/syntax/cdrdaoconf.vim | 0 share/vim/{vim72 => vim73}/syntax/cdrtoc.vim | 0 share/vim/vim73/syntax/cf.vim | 440 + share/vim/{vim72 => vim73}/syntax/cfg.vim | 0 share/vim/{vim72 => vim73}/syntax/ch.vim | 0 share/vim/vim73/syntax/chaiscript.vim | 94 + share/vim/{vim72 => vim73}/syntax/change.vim | 0 share/vim/{vim72 => vim73}/syntax/changelog.vim | 0 share/vim/{vim72 => vim73}/syntax/chaskell.vim | 0 share/vim/{vim72 => vim73}/syntax/cheetah.vim | 0 share/vim/{vim72 => vim73}/syntax/chill.vim | 0 share/vim/{vim72 => vim73}/syntax/chordpro.vim | 0 share/vim/{vim72 => vim73}/syntax/cl.vim | 0 share/vim/{vim72 => vim73}/syntax/clean.vim | 0 share/vim/{vim72 => vim73}/syntax/clipper.vim | 0 share/vim/vim73/syntax/cmake.vim | 81 + share/vim/{vim72 => vim73}/syntax/cmusrc.vim | 0 share/vim/{vim72 => vim73}/syntax/cobol.vim | 0 share/vim/{vim72 => vim73}/syntax/coco.vim | 0 share/vim/{vim72 => vim73}/syntax/colortest.vim | 0 share/vim/{vim72 => vim73}/syntax/conaryrecipe.vim | 0 share/vim/{vim72 => vim73}/syntax/conf.vim | 0 share/vim/vim73/syntax/config.vim | 57 + share/vim/{vim72 => vim73}/syntax/context.vim | 0 share/vim/{vim72 => vim73}/syntax/cpp.vim | 0 share/vim/{vim72 => vim73}/syntax/crm.vim | 0 share/vim/{vim72 => vim73}/syntax/crontab.vim | 0 share/vim/vim73/syntax/cs.vim | 154 + share/vim/{vim72 => vim73}/syntax/csc.vim | 0 share/vim/{vim72 => vim73}/syntax/csh.vim | 0 share/vim/{vim72 => vim73}/syntax/csp.vim | 0 share/vim/vim73/syntax/css.vim | 282 + share/vim/{vim72 => vim73}/syntax/cterm.vim | 0 share/vim/{vim72 => vim73}/syntax/ctrlh.vim | 0 share/vim/vim73/syntax/cucumber.vim | 126 + share/vim/{vim72 => vim73}/syntax/cuda.vim | 0 share/vim/{vim72 => vim73}/syntax/cupl.vim | 0 share/vim/{vim72 => vim73}/syntax/cuplsim.vim | 0 share/vim/{vim72 => vim73}/syntax/cvs.vim | 0 share/vim/{vim72 => vim73}/syntax/cvsrc.vim | 0 share/vim/{vim72 => vim73}/syntax/cweb.vim | 0 share/vim/{vim72 => vim73}/syntax/cynlib.vim | 0 share/vim/{vim72 => vim73}/syntax/cynpp.vim | 0 share/vim/vim73/syntax/d.vim | 301 + share/vim/vim73/syntax/datascript.vim | 90 + share/vim/{vim72 => vim73}/syntax/dcd.vim | 0 share/vim/{vim72 => vim73}/syntax/dcl.vim | 0 share/vim/vim73/syntax/debchangelog.vim | 59 + share/vim/vim73/syntax/debcontrol.vim | 104 + share/vim/vim73/syntax/debsources.vim | 35 + share/vim/{vim72 => vim73}/syntax/def.vim | 0 share/vim/{vim72 => vim73}/syntax/denyhosts.vim | 0 share/vim/{vim72 => vim73}/syntax/desc.vim | 0 share/vim/{vim72 => vim73}/syntax/desktop.vim | 0 share/vim/{vim72 => vim73}/syntax/dictconf.vim | 0 share/vim/{vim72 => vim73}/syntax/dictdconf.vim | 0 share/vim/vim73/syntax/diff.vim | 334 + share/vim/{vim72 => vim73}/syntax/dircolors.vim | 0 share/vim/{vim72 => vim73}/syntax/diva.vim | 0 share/vim/vim73/syntax/django.vim | 96 + share/vim/{vim72 => vim73}/syntax/dns.vim | 0 share/vim/{vim72 => vim73}/syntax/docbk.vim | 0 share/vim/{vim72 => vim73}/syntax/docbksgml.vim | 0 share/vim/{vim72 => vim73}/syntax/docbkxml.vim | 0 share/vim/vim73/syntax/dosbatch.vim | 160 + share/vim/{vim72 => vim73}/syntax/dosini.vim | 0 share/vim/{vim72 => vim73}/syntax/dot.vim | 0 share/vim/vim73/syntax/doxygen.vim | 594 + share/vim/{vim72 => vim73}/syntax/dracula.vim | 0 share/vim/{vim72 => vim73}/syntax/dsl.vim | 0 share/vim/{vim72 => vim73}/syntax/dtd.vim | 0 share/vim/{vim72 => vim73}/syntax/dtml.vim | 0 share/vim/{vim72 => vim73}/syntax/dtrace.vim | 0 share/vim/{vim72 => vim73}/syntax/dylan.vim | 0 share/vim/{vim72 => vim73}/syntax/dylanintr.vim | 0 share/vim/{vim72 => vim73}/syntax/dylanlid.vim | 0 share/vim/{vim72 => vim73}/syntax/ecd.vim | 0 share/vim/{vim72 => vim73}/syntax/edif.vim | 0 share/vim/{vim72 => vim73}/syntax/eiffel.vim | 0 share/vim/{vim72 => vim73}/syntax/elf.vim | 0 share/vim/{vim72 => vim73}/syntax/elinks.vim | 0 share/vim/{vim72 => vim73}/syntax/elmfilt.vim | 0 share/vim/vim73/syntax/erlang.vim | 229 + share/vim/vim73/syntax/eruby.vim | 77 + share/vim/{vim72 => vim73}/syntax/esmtprc.vim | 0 share/vim/{vim72 => vim73}/syntax/esqlc.vim | 0 share/vim/{vim72 => vim73}/syntax/esterel.vim | 0 share/vim/{vim72 => vim73}/syntax/eterm.vim | 0 share/vim/{vim72 => vim73}/syntax/eviews.vim | 0 share/vim/{vim72 => vim73}/syntax/exim.vim | 0 share/vim/{vim72 => vim73}/syntax/expect.vim | 0 share/vim/{vim72 => vim73}/syntax/exports.vim | 0 share/vim/vim73/syntax/fan.vim | 132 + share/vim/{vim72 => vim73}/syntax/fasm.vim | 0 share/vim/{vim72 => vim73}/syntax/fdcc.vim | 0 share/vim/{vim72 => vim73}/syntax/fetchmail.vim | 0 share/vim/{vim72 => vim73}/syntax/fgl.vim | 0 share/vim/{vim72 => vim73}/syntax/flexwiki.vim | 0 share/vim/{vim72 => vim73}/syntax/focexec.vim | 0 share/vim/vim73/syntax/form.vim | 158 + share/vim/vim73/syntax/forth.vim | 334 + share/vim/vim73/syntax/fortran.vim | 540 + share/vim/{vim72 => vim73}/syntax/foxpro.vim | 0 share/vim/{vim72 => vim73}/syntax/framescript.vim | 0 share/vim/{vim72 => vim73}/syntax/freebasic.vim | 0 share/vim/vim73/syntax/fstab.vim | 280 + share/vim/{vim72 => vim73}/syntax/fvwm.vim | 0 share/vim/{vim72 => vim73}/syntax/fvwm2m4.vim | 0 share/vim/vim73/syntax/gdb.vim | 111 + share/vim/{vim72 => vim73}/syntax/gdmo.vim | 0 share/vim/{vim72 => vim73}/syntax/gedcom.vim | 0 share/vim/vim73/syntax/git.vim | 78 + share/vim/vim73/syntax/gitcommit.vim | 83 + share/vim/vim73/syntax/gitconfig.vim | 38 + share/vim/vim73/syntax/gitrebase.vim | 35 + share/vim/vim73/syntax/gitsendemail.vim | 19 + share/vim/{vim72 => vim73}/syntax/gkrellmrc.vim | 0 share/vim/{vim72 => vim73}/syntax/gnuplot.vim | 0 share/vim/{vim72 => vim73}/syntax/gp.vim | 0 share/vim/{vim72 => vim73}/syntax/gpg.vim | 0 share/vim/{vim72 => vim73}/syntax/grads.vim | 0 share/vim/{vim72 => vim73}/syntax/gretl.vim | 0 share/vim/{vim72 => vim73}/syntax/groff.vim | 0 share/vim/vim73/syntax/groovy.vim | 451 + share/vim/{vim72 => vim73}/syntax/group.vim | 0 share/vim/{vim72 => vim73}/syntax/grub.vim | 0 share/vim/{vim72 => vim73}/syntax/gsp.vim | 0 share/vim/{vim72 => vim73}/syntax/gtkrc.vim | 0 share/vim/vim73/syntax/haml.vim | 109 + share/vim/{vim72 => vim73}/syntax/hamster.vim | 0 share/vim/vim73/syntax/haskell.vim | 194 + share/vim/{vim72 => vim73}/syntax/haste.vim | 0 share/vim/{vim72 => vim73}/syntax/hastepreproc.vim | 0 share/vim/{vim72 => vim73}/syntax/hb.vim | 0 share/vim/vim73/syntax/help.vim | 188 + share/vim/{vim72 => vim73}/syntax/hercules.vim | 0 share/vim/{vim72 => vim73}/syntax/hex.vim | 0 share/vim/{vim72 => vim73}/syntax/hitest.vim | 0 share/vim/{vim72 => vim73}/syntax/hog.vim | 0 share/vim/{vim72 => vim73}/syntax/hostconf.vim | 0 share/vim/{vim72 => vim73}/syntax/html.vim | 0 share/vim/{vim72 => vim73}/syntax/htmlcheetah.vim | 0 share/vim/{vim72 => vim73}/syntax/htmldjango.vim | 0 share/vim/{vim72 => vim73}/syntax/htmlm4.vim | 0 share/vim/{vim72 => vim73}/syntax/htmlos.vim | 0 share/vim/{vim72 => vim73}/syntax/ia64.vim | 0 share/vim/{vim72 => vim73}/syntax/ibasic.vim | 0 share/vim/{vim72 => vim73}/syntax/icemenu.vim | 0 share/vim/{vim72 => vim73}/syntax/icon.vim | 0 share/vim/{vim72 => vim73}/syntax/idl.vim | 0 share/vim/{vim72 => vim73}/syntax/idlang.vim | 0 share/vim/vim73/syntax/indent.vim | 152 + share/vim/{vim72 => vim73}/syntax/inform.vim | 0 share/vim/{vim72 => vim73}/syntax/initex.vim | 0 share/vim/{vim72 => vim73}/syntax/initng.vim | 0 share/vim/{vim72 => vim73}/syntax/inittab.vim | 0 share/vim/{vim72 => vim73}/syntax/ipfilter.vim | 0 share/vim/{vim72 => vim73}/syntax/ishd.vim | 0 share/vim/{vim72 => vim73}/syntax/iss.vim | 0 share/vim/{vim72 => vim73}/syntax/ist.vim | 0 share/vim/{vim72 => vim73}/syntax/jal.vim | 0 share/vim/{vim72 => vim73}/syntax/jam.vim | 0 share/vim/{vim72 => vim73}/syntax/jargon.vim | 0 share/vim/vim73/syntax/java.vim | 348 + share/vim/{vim72 => vim73}/syntax/javacc.vim | 0 share/vim/vim73/syntax/javascript.vim | 135 + share/vim/{vim72 => vim73}/syntax/jess.vim | 0 share/vim/{vim72 => vim73}/syntax/jgraph.vim | 0 share/vim/{vim72 => vim73}/syntax/jproperties.vim | 0 share/vim/vim73/syntax/jsp.vim | 85 + share/vim/vim73/syntax/kconfig.vim | 736 + share/vim/{vim72 => vim73}/syntax/kix.vim | 0 share/vim/{vim72 => vim73}/syntax/kscript.vim | 0 share/vim/{vim72 => vim73}/syntax/kwt.vim | 0 share/vim/{vim72 => vim73}/syntax/lace.vim | 0 share/vim/{vim72 => vim73}/syntax/latte.vim | 0 share/vim/{vim72 => vim73}/syntax/ld.vim | 0 share/vim/{vim72 => vim73}/syntax/ldapconf.vim | 0 share/vim/{vim72 => vim73}/syntax/ldif.vim | 0 share/vim/vim73/syntax/lex.vim | 129 + share/vim/{vim72 => vim73}/syntax/lftp.vim | 0 share/vim/vim73/syntax/lhaskell.vim | 145 + share/vim/{vim72 => vim73}/syntax/libao.vim | 0 share/vim/vim73/syntax/lifelines.vim | 167 + share/vim/vim73/syntax/lilo.vim | 192 + share/vim/{vim72 => vim73}/syntax/limits.vim | 0 share/vim/vim73/syntax/liquid.vim | 137 + share/vim/vim73/syntax/lisp.vim | 625 + share/vim/{vim72 => vim73}/syntax/lite.vim | 0 share/vim/{vim72 => vim73}/syntax/litestep.vim | 0 share/vim/{vim72 => vim73}/syntax/loginaccess.vim | 0 share/vim/{vim72 => vim73}/syntax/logindefs.vim | 0 share/vim/vim73/syntax/logtalk.vim | 398 + share/vim/{vim72 => vim73}/syntax/lotos.vim | 0 share/vim/{vim72 => vim73}/syntax/lout.vim | 0 share/vim/{vim72 => vim73}/syntax/lpc.vim | 0 share/vim/{vim72 => vim73}/syntax/lprolog.vim | 0 share/vim/{vim72 => vim73}/syntax/lscript.vim | 0 share/vim/{vim72 => vim73}/syntax/lsl.vim | 0 share/vim/{vim72 => vim73}/syntax/lss.vim | 0 share/vim/{vim72 => vim73}/syntax/lua.vim | 0 share/vim/{vim72 => vim73}/syntax/lynx.vim | 0 share/vim/{vim72 => vim73}/syntax/m4.vim | 0 share/vim/vim73/syntax/mail.vim | 106 + share/vim/{vim72 => vim73}/syntax/mailaliases.vim | 0 share/vim/{vim72 => vim73}/syntax/mailcap.vim | 0 share/vim/{vim72 => vim73}/syntax/make.vim | 0 share/vim/vim73/syntax/man.vim | 67 + share/vim/{vim72 => vim73}/syntax/manconf.vim | 0 share/vim/{vim72 => vim73}/syntax/manual.vim | 0 share/vim/vim73/syntax/maple.vim | 633 + share/vim/vim73/syntax/markdown.vim | 105 + share/vim/{vim72 => vim73}/syntax/masm.vim | 0 share/vim/{vim72 => vim73}/syntax/mason.vim | 0 share/vim/{vim72 => vim73}/syntax/master.vim | 0 share/vim/vim73/syntax/matlab.vim | 123 + share/vim/vim73/syntax/maxima.vim | 274 + share/vim/{vim72 => vim73}/syntax/mel.vim | 0 share/vim/{vim72 => vim73}/syntax/messages.vim | 0 share/vim/{vim72 => vim73}/syntax/mf.vim | 0 share/vim/{vim72 => vim73}/syntax/mgl.vim | 0 share/vim/{vim72 => vim73}/syntax/mgp.vim | 0 share/vim/vim73/syntax/mib.vim | 57 + share/vim/{vim72 => vim73}/syntax/mma.vim | 0 share/vim/{vim72 => vim73}/syntax/mmix.vim | 0 share/vim/{vim72 => vim73}/syntax/mmp.vim | 0 share/vim/{vim72 => vim73}/syntax/modconf.vim | 0 share/vim/{vim72 => vim73}/syntax/model.vim | 0 share/vim/{vim72 => vim73}/syntax/modsim3.vim | 0 share/vim/{vim72 => vim73}/syntax/modula2.vim | 0 share/vim/{vim72 => vim73}/syntax/modula3.vim | 0 share/vim/{vim72 => vim73}/syntax/monk.vim | 0 share/vim/{vim72 => vim73}/syntax/moo.vim | 0 share/vim/{vim72 => vim73}/syntax/mp.vim | 0 share/vim/{vim72 => vim73}/syntax/mplayerconf.vim | 0 share/vim/{vim72 => vim73}/syntax/mrxvtrc.vim | 0 share/vim/{vim72 => vim73}/syntax/msidl.vim | 0 share/vim/{vim72 => vim73}/syntax/msmessages.vim | 0 share/vim/{vim72 => vim73}/syntax/msql.vim | 0 share/vim/{vim72 => vim73}/syntax/mupad.vim | 0 share/vim/{vim72 => vim73}/syntax/mush.vim | 0 share/vim/vim73/syntax/muttrc.vim | 768 + share/vim/vim73/syntax/mysql.vim | 297 + share/vim/{vim72 => vim73}/syntax/named.vim | 0 share/vim/{vim72 => vim73}/syntax/nanorc.vim | 0 share/vim/{vim72 => vim73}/syntax/nasm.vim | 0 share/vim/{vim72 => vim73}/syntax/nastran.vim | 0 share/vim/{vim72 => vim73}/syntax/natural.vim | 0 share/vim/{vim72 => vim73}/syntax/ncf.vim | 0 share/vim/vim73/syntax/netrc.vim | 52 + share/vim/vim73/syntax/netrw.vim | 109 + share/vim/{vim72 => vim73}/syntax/nosyntax.vim | 0 share/vim/{vim72 => vim73}/syntax/nqc.vim | 0 share/vim/{vim72 => vim73}/syntax/nroff.vim | 0 share/vim/{vim72 => vim73}/syntax/nsis.vim | 0 share/vim/vim73/syntax/obj.vim | 96 + share/vim/{vim72 => vim73}/syntax/objc.vim | 0 share/vim/{vim72 => vim73}/syntax/objcpp.vim | 0 share/vim/{vim72 => vim73}/syntax/ocaml.vim | 0 share/vim/{vim72 => vim73}/syntax/occam.vim | 0 share/vim/{vim72 => vim73}/syntax/omnimark.vim | 0 share/vim/{vim72 => vim73}/syntax/openroad.vim | 0 share/vim/{vim72 => vim73}/syntax/opl.vim | 0 share/vim/{vim72 => vim73}/syntax/ora.vim | 0 share/vim/{vim72 => vim73}/syntax/pamconf.vim | 0 share/vim/vim73/syntax/papp.vim | 93 + share/vim/{vim72 => vim73}/syntax/pascal.vim | 0 share/vim/{vim72 => vim73}/syntax/passwd.vim | 0 share/vim/{vim72 => vim73}/syntax/pcap.vim | 0 share/vim/{vim72 => vim73}/syntax/pccts.vim | 0 share/vim/{vim72 => vim73}/syntax/pdf.vim | 0 share/vim/vim73/syntax/perl.vim | 543 + share/vim/vim73/syntax/perl6.vim | 2249 + share/vim/{vim72 => vim73}/syntax/pf.vim | 0 share/vim/{vim72 => vim73}/syntax/pfmain.vim | 0 share/vim/{vim72 => vim73}/syntax/php.vim | 0 share/vim/{vim72 => vim73}/syntax/phtml.vim | 0 share/vim/{vim72 => vim73}/syntax/pic.vim | 0 share/vim/{vim72 => vim73}/syntax/pike.vim | 0 share/vim/{vim72 => vim73}/syntax/pilrc.vim | 0 share/vim/{vim72 => vim73}/syntax/pine.vim | 0 share/vim/{vim72 => vim73}/syntax/pinfo.vim | 0 share/vim/{vim72 => vim73}/syntax/plaintex.vim | 0 share/vim/{vim72 => vim73}/syntax/plm.vim | 0 share/vim/{vim72 => vim73}/syntax/plp.vim | 0 share/vim/{vim72 => vim73}/syntax/plsql.vim | 0 share/vim/vim73/syntax/po.vim | 135 + share/vim/vim73/syntax/pod.vim | 90 + share/vim/{vim72 => vim73}/syntax/postscr.vim | 0 share/vim/{vim72 => vim73}/syntax/pov.vim | 0 share/vim/{vim72 => vim73}/syntax/povini.vim | 0 share/vim/{vim72 => vim73}/syntax/ppd.vim | 0 share/vim/{vim72 => vim73}/syntax/ppwiz.vim | 0 share/vim/{vim72 => vim73}/syntax/prescribe.vim | 0 share/vim/{vim72 => vim73}/syntax/privoxy.vim | 0 share/vim/{vim72 => vim73}/syntax/procmail.vim | 0 share/vim/{vim72 => vim73}/syntax/progress.vim | 0 share/vim/vim73/syntax/prolog.vim | 119 + share/vim/{vim72 => vim73}/syntax/promela.vim | 0 share/vim/{vim72 => vim73}/syntax/protocols.vim | 0 share/vim/{vim72 => vim73}/syntax/psf.vim | 0 share/vim/{vim72 => vim73}/syntax/ptcap.vim | 0 share/vim/{vim72 => vim73}/syntax/purifylog.vim | 0 share/vim/vim73/syntax/pyrex.vim | 67 + share/vim/vim73/syntax/python.vim | 295 + share/vim/{vim72 => vim73}/syntax/qf.vim | 0 share/vim/{vim72 => vim73}/syntax/quake.vim | 0 share/vim/{vim72 => vim73}/syntax/r.vim | 0 share/vim/{vim72 => vim73}/syntax/racc.vim | 0 share/vim/{vim72 => vim73}/syntax/radiance.vim | 0 share/vim/{vim72 => vim73}/syntax/ratpoison.vim | 0 share/vim/{vim72 => vim73}/syntax/rc.vim | 0 share/vim/{vim72 => vim73}/syntax/rcs.vim | 0 share/vim/{vim72 => vim73}/syntax/rcslog.vim | 0 share/vim/vim73/syntax/readline.vim | 176 + share/vim/{vim72 => vim73}/syntax/rebol.vim | 0 share/vim/{vim72 => vim73}/syntax/registry.vim | 0 share/vim/vim73/syntax/remind.vim | 79 + share/vim/{vim72 => vim73}/syntax/resolv.vim | 0 share/vim/{vim72 => vim73}/syntax/reva.vim | 0 share/vim/{vim72 => vim73}/syntax/rexx.vim | 0 share/vim/vim73/syntax/rhelp.vim | 212 + share/vim/{vim72 => vim73}/syntax/rib.vim | 0 share/vim/{vim72 => vim73}/syntax/rnc.vim | 0 share/vim/vim73/syntax/rnoweb.vim | 57 + share/vim/{vim72 => vim73}/syntax/robots.vim | 0 share/vim/{vim72 => vim73}/syntax/rpcgen.vim | 0 share/vim/{vim72 => vim73}/syntax/rpl.vim | 0 share/vim/vim73/syntax/rst.vim | 175 + share/vim/{vim72 => vim73}/syntax/rtf.vim | 0 share/vim/vim73/syntax/ruby.vim | 370 + share/vim/vim73/syntax/samba.vim | 131 + share/vim/{vim72 => vim73}/syntax/sas.vim | 0 share/vim/vim73/syntax/sass.vim | 90 + share/vim/{vim72 => vim73}/syntax/sather.vim | 0 share/vim/vim73/syntax/scheme.vim | 324 + share/vim/{vim72 => vim73}/syntax/scilab.vim | 0 share/vim/vim73/syntax/screen.vim | 246 + share/vim/vim73/syntax/scss.vim | 20 + share/vim/{vim72 => vim73}/syntax/sd.vim | 0 share/vim/vim73/syntax/sdc.vim | 41 + share/vim/{vim72 => vim73}/syntax/sdl.vim | 0 share/vim/vim73/syntax/sed.vim | 122 + share/vim/{vim72 => vim73}/syntax/sendpr.vim | 0 share/vim/{vim72 => vim73}/syntax/sensors.vim | 0 share/vim/{vim72 => vim73}/syntax/services.vim | 0 share/vim/{vim72 => vim73}/syntax/setserial.vim | 0 share/vim/{vim72 => vim73}/syntax/sgml.vim | 0 share/vim/{vim72 => vim73}/syntax/sgmldecl.vim | 0 share/vim/vim73/syntax/sgmllnx.vim | 68 + share/vim/vim73/syntax/sh.vim | 605 + share/vim/{vim72 => vim73}/syntax/sicad.vim | 0 share/vim/{vim72 => vim73}/syntax/sieve.vim | 0 share/vim/{vim72 => vim73}/syntax/simula.vim | 0 share/vim/{vim72 => vim73}/syntax/sinda.vim | 0 share/vim/{vim72 => vim73}/syntax/sindacmp.vim | 0 share/vim/{vim72 => vim73}/syntax/sindaout.vim | 0 share/vim/vim73/syntax/sisu.vim | 204 + share/vim/{vim72 => vim73}/syntax/skill.vim | 0 share/vim/{vim72 => vim73}/syntax/sl.vim | 0 share/vim/{vim72 => vim73}/syntax/slang.vim | 0 share/vim/{vim72 => vim73}/syntax/slice.vim | 0 share/vim/{vim72 => vim73}/syntax/slpconf.vim | 0 share/vim/{vim72 => vim73}/syntax/slpreg.vim | 0 share/vim/{vim72 => vim73}/syntax/slpspi.vim | 0 share/vim/{vim72 => vim73}/syntax/slrnrc.vim | 0 share/vim/{vim72 => vim73}/syntax/slrnsc.vim | 0 share/vim/{vim72 => vim73}/syntax/sm.vim | 0 share/vim/{vim72 => vim73}/syntax/smarty.vim | 0 share/vim/{vim72 => vim73}/syntax/smcl.vim | 0 share/vim/{vim72 => vim73}/syntax/smil.vim | 0 share/vim/{vim72 => vim73}/syntax/smith.vim | 0 share/vim/{vim72 => vim73}/syntax/sml.vim | 0 share/vim/{vim72 => vim73}/syntax/snnsnet.vim | 0 share/vim/{vim72 => vim73}/syntax/snnspat.vim | 0 share/vim/{vim72 => vim73}/syntax/snnsres.vim | 0 share/vim/{vim72 => vim73}/syntax/snobol4.vim | 0 share/vim/vim73/syntax/spec.vim | 235 + share/vim/{vim72 => vim73}/syntax/specman.vim | 0 share/vim/{vim72 => vim73}/syntax/spice.vim | 0 share/vim/{vim72 => vim73}/syntax/splint.vim | 0 share/vim/{vim72 => vim73}/syntax/spup.vim | 0 share/vim/vim73/syntax/spyce.vim | 111 + share/vim/{vim72 => vim73}/syntax/sql.vim | 0 share/vim/vim73/syntax/sqlanywhere.vim | 686 + share/vim/{vim72 => vim73}/syntax/sqlforms.vim | 0 share/vim/{vim72 => vim73}/syntax/sqlinformix.vim | 0 share/vim/{vim72 => vim73}/syntax/sqlj.vim | 0 share/vim/{vim72 => vim73}/syntax/sqloracle.vim | 0 share/vim/{vim72 => vim73}/syntax/sqr.vim | 0 share/vim/{vim72 => vim73}/syntax/squid.vim | 0 share/vim/vim73/syntax/sshconfig.vim | 116 + share/vim/vim73/syntax/sshdconfig.vim | 111 + share/vim/{vim72 => vim73}/syntax/st.vim | 0 share/vim/{vim72 => vim73}/syntax/stata.vim | 0 share/vim/{vim72 => vim73}/syntax/stp.vim | 0 share/vim/{vim72 => vim73}/syntax/strace.vim | 0 share/vim/{vim72 => vim73}/syntax/sudoers.vim | 0 share/vim/vim73/syntax/svg.vim | 15 + share/vim/{vim72 => vim73}/syntax/svn.vim | 0 share/vim/{vim72 => vim73}/syntax/syncolor.vim | 0 share/vim/vim73/syntax/synload.vim | 76 + share/vim/{vim72 => vim73}/syntax/syntax.vim | 0 share/vim/{vim72 => vim73}/syntax/sysctl.vim | 0 share/vim/{vim72 => vim73}/syntax/tads.vim | 0 share/vim/{vim72 => vim73}/syntax/tags.vim | 0 share/vim/{vim72 => vim73}/syntax/tak.vim | 0 share/vim/{vim72 => vim73}/syntax/takcmp.vim | 0 share/vim/{vim72 => vim73}/syntax/takout.vim | 0 share/vim/{vim72 => vim73}/syntax/tar.vim | 0 share/vim/vim73/syntax/taskdata.vim | 43 + share/vim/vim73/syntax/taskedit.vim | 35 + share/vim/{vim72 => vim73}/syntax/tasm.vim | 0 share/vim/vim73/syntax/tcl.vim | 282 + share/vim/vim73/syntax/tcsh.vim | 248 + share/vim/{vim72 => vim73}/syntax/terminfo.vim | 0 share/vim/vim73/syntax/tex.vim | 1094 + share/vim/{vim72 => vim73}/syntax/texinfo.vim | 0 share/vim/{vim72 => vim73}/syntax/texmf.vim | 0 share/vim/{vim72 => vim73}/syntax/tf.vim | 0 share/vim/{vim72 => vim73}/syntax/tidy.vim | 0 share/vim/{vim72 => vim73}/syntax/tilde.vim | 0 share/vim/{vim72 => vim73}/syntax/tli.vim | 0 share/vim/{vim72 => vim73}/syntax/tpp.vim | 0 share/vim/{vim72 => vim73}/syntax/trasys.vim | 0 share/vim/{vim72 => vim73}/syntax/trustees.vim | 0 share/vim/{vim72 => vim73}/syntax/tsalt.vim | 0 share/vim/{vim72 => vim73}/syntax/tsscl.vim | 0 share/vim/{vim72 => vim73}/syntax/tssgm.vim | 0 share/vim/{vim72 => vim73}/syntax/tssop.vim | 0 share/vim/{vim72 => vim73}/syntax/uc.vim | 0 share/vim/{vim72 => vim73}/syntax/udevconf.vim | 0 share/vim/{vim72 => vim73}/syntax/udevperm.vim | 0 share/vim/{vim72 => vim73}/syntax/udevrules.vim | 0 share/vim/vim73/syntax/uil.vim | 86 + share/vim/vim73/syntax/updatedb.vim | 41 + share/vim/{vim72 => vim73}/syntax/valgrind.vim | 0 share/vim/{vim72 => vim73}/syntax/vb.vim | 0 share/vim/{vim72 => vim73}/syntax/vera.vim | 0 share/vim/{vim72 => vim73}/syntax/verilog.vim | 0 share/vim/{vim72 => vim73}/syntax/verilogams.vim | 0 share/vim/{vim72 => vim73}/syntax/vgrindefs.vim | 0 share/vim/{vim72 => vim73}/syntax/vhdl.vim | 0 share/vim/vim73/syntax/vim.vim | 870 + share/vim/{vim72 => vim73}/syntax/viminfo.vim | 0 share/vim/{vim72 => vim73}/syntax/virata.vim | 0 share/vim/{vim72 => vim73}/syntax/vmasm.vim | 0 share/vim/{vim72 => vim73}/syntax/voscm.vim | 0 share/vim/{vim72 => vim73}/syntax/vrml.vim | 0 share/vim/{vim72 => vim73}/syntax/vsejcl.vim | 0 share/vim/{vim72 => vim73}/syntax/wdiff.vim | 0 share/vim/{vim72 => vim73}/syntax/web.vim | 0 share/vim/{vim72 => vim73}/syntax/webmacro.vim | 0 share/vim/{vim72 => vim73}/syntax/wget.vim | 0 share/vim/{vim72 => vim73}/syntax/whitespace.vim | 0 share/vim/{vim72 => vim73}/syntax/winbatch.vim | 0 share/vim/{vim72 => vim73}/syntax/wml.vim | 0 share/vim/{vim72 => vim73}/syntax/wsh.vim | 0 share/vim/{vim72 => vim73}/syntax/wsml.vim | 0 share/vim/{vim72 => vim73}/syntax/wvdial.vim | 0 share/vim/{vim72 => vim73}/syntax/xbl.vim | 0 share/vim/{vim72 => vim73}/syntax/xdefaults.vim | 0 share/vim/{vim72 => vim73}/syntax/xf86conf.vim | 0 share/vim/{vim72 => vim73}/syntax/xhtml.vim | 0 share/vim/{vim72 => vim73}/syntax/xinetd.vim | 0 share/vim/{vim72 => vim73}/syntax/xkb.vim | 0 share/vim/{vim72 => vim73}/syntax/xmath.vim | 0 share/vim/vim73/syntax/xml.vim | 346 + share/vim/{vim72 => vim73}/syntax/xmodmap.vim | 0 share/vim/{vim72 => vim73}/syntax/xpm.vim | 0 share/vim/{vim72 => vim73}/syntax/xpm2.vim | 0 share/vim/{vim72 => vim73}/syntax/xquery.vim | 0 share/vim/vim73/syntax/xs.vim | 39 + share/vim/{vim72 => vim73}/syntax/xsd.vim | 0 share/vim/{vim72 => vim73}/syntax/xslt.vim | 0 share/vim/{vim72 => vim73}/syntax/xxd.vim | 0 share/vim/vim73/syntax/yacc.vim | 122 + share/vim/vim73/syntax/yaml.vim | 86 + share/vim/{vim72 => vim73}/syntax/z8a.vim | 0 share/vim/vim73/syntax/zsh.vim | 213 + share/vim/{vim72 => vim73}/termcap | 0 share/vim/{vim72 => vim73}/tools.info | Bin share/vim/vim73/tools/README.txt | 37 + share/vim/{vim72 => vim73}/tools/blink.c | 0 share/vim/{vim72 => vim73}/tools/ccfilter.1 | 0 share/vim/{vim72 => vim73}/tools/ccfilter.c | 0 .../vim/{vim72 => vim73}/tools/ccfilter_README.txt | 0 share/vim/{vim72 => vim73}/tools/efm_filter.pl | 0 share/vim/{vim72 => vim73}/tools/efm_filter.txt | 0 share/vim/{vim72 => vim73}/tools/efm_perl.pl | 0 share/vim/{vim72 => vim73}/tools/mve.awk | 0 share/vim/{vim72 => vim73}/tools/mve.txt | 0 share/vim/{vim72 => vim73}/tools/pltags.pl | 0 share/vim/{vim72 => vim73}/tools/ref | 0 share/vim/{vim72 => vim73}/tools/shtags.1 | 0 share/vim/{vim72 => vim73}/tools/shtags.pl | 0 share/vim/vim73/tools/unicode.vim | 290 + share/vim/{vim72 => vim73}/tools/vim132 | 0 share/vim/{vim72 => vim73}/tools/vim_vs_net.cmd | 0 share/vim/{vim72 => vim73}/tools/vimm | 0 share/vim/{vim72 => vim73}/tools/vimspell.sh | 0 share/vim/{vim72 => vim73}/tools/vimspell.txt | 0 share/vim/{vim72 => vim73}/tools/xcmdsrv_client.c | 0 share/vim/{vim72 => vim73}/tutor.info | Bin share/vim/vim73/tutor/Makefile | 96 + .../vim/{vim72 => vim73}/tutor/README.el.cp737.txt | 0 share/vim/{vim72 => vim73}/tutor/README.el.txt | 0 share/vim/{vim72 => vim73}/tutor/README.txt | 0 share/vim/{vim72 => vim73}/tutor/README.txt.info | Bin share/vim/vim73/tutor/tutor | 970 + share/vim/vim73/tutor/tutor.bj | 987 + share/vim/vim73/tutor/tutor.bj.utf-8 | 987 + share/vim/{vim72 => vim73}/tutor/tutor.ca | 0 share/vim/{vim72 => vim73}/tutor/tutor.ca.utf-8 | 0 share/vim/{vim72 => vim73}/tutor/tutor.cs | 0 share/vim/{vim72 => vim73}/tutor/tutor.cs.cp1250 | 0 share/vim/{vim72 => vim73}/tutor/tutor.cs.utf-8 | 0 share/vim/{vim72 => vim73}/tutor/tutor.de | 0 share/vim/{vim72 => vim73}/tutor/tutor.de.utf-8 | 0 share/vim/{vim72 => vim73}/tutor/tutor.el | 0 share/vim/{vim72 => vim73}/tutor/tutor.el.cp737 | 0 share/vim/{vim72 => vim73}/tutor/tutor.el.utf-8 | 0 share/vim/vim73/tutor/tutor.eo | 991 + share/vim/vim73/tutor/tutor.eo.utf-8 | 991 + share/vim/vim73/tutor/tutor.es | 769 + share/vim/vim73/tutor/tutor.es.utf-8 | 769 + share/vim/vim73/tutor/tutor.fr | 1038 + share/vim/vim73/tutor/tutor.fr.utf-8 | 1038 + share/vim/{vim72 => vim73}/tutor/tutor.hr | 0 share/vim/{vim72 => vim73}/tutor/tutor.hr.cp1250 | 0 share/vim/{vim72 => vim73}/tutor/tutor.hr.utf-8 | 0 share/vim/vim73/tutor/tutor.hu | 830 + share/vim/vim73/tutor/tutor.hu.cp1250 | 830 + share/vim/vim73/tutor/tutor.hu.utf-8 | 830 + share/vim/{vim72 => vim73}/tutor/tutor.info | Bin share/vim/vim73/tutor/tutor.it | 967 + share/vim/vim73/tutor/tutor.it.utf-8 | 967 + share/vim/vim73/tutor/tutor.ja.euc | 975 + share/vim/vim73/tutor/tutor.ja.sjis | 975 + share/vim/vim73/tutor/tutor.ja.utf-8 | 975 + share/vim/{vim72 => vim73}/tutor/tutor.ko.euc | 0 share/vim/{vim72 => vim73}/tutor/tutor.ko.utf-8 | 0 .../{vim72/tutor/tutor.no => vim73/tutor/tutor.nb} | 0 .../tutor.no.utf-8 => vim73/tutor/tutor.nb.utf-8} | 0 share/vim/{vim72 => vim73}/tutor/tutor.no | 0 share/vim/{vim72 => vim73}/tutor/tutor.no.utf-8 | 0 share/vim/vim73/tutor/tutor.pl | 995 + share/vim/vim73/tutor/tutor.pl.cp1250 | 995 + share/vim/vim73/tutor/tutor.pl.utf-8 | 995 + share/vim/vim73/tutor/tutor.pt | 984 + share/vim/vim73/tutor/tutor.pt.utf-8 | 984 + share/vim/{vim72 => vim73}/tutor/tutor.ru | 0 share/vim/{vim72 => vim73}/tutor/tutor.ru.cp1251 | 0 share/vim/{vim72 => vim73}/tutor/tutor.ru.utf-8 | 0 share/vim/{vim72 => vim73}/tutor/tutor.sk | 0 share/vim/{vim72 => vim73}/tutor/tutor.sk.cp1250 | 0 share/vim/{vim72 => vim73}/tutor/tutor.sk.utf-8 | 0 share/vim/{vim72 => vim73}/tutor/tutor.sv | 0 share/vim/{vim72 => vim73}/tutor/tutor.sv.utf-8 | 0 share/vim/{vim72 => vim73}/tutor/tutor.tr.iso9 | 0 share/vim/{vim72 => vim73}/tutor/tutor.tr.utf-8 | 0 share/vim/vim73/tutor/tutor.utf-8 | 970 + share/vim/{vim72 => vim73}/tutor/tutor.vi.utf-8 | 0 share/vim/{vim72 => vim73}/tutor/tutor.vim | 0 share/vim/{vim72 => vim73}/tutor/tutor.zh.big5 | 0 share/vim/{vim72 => vim73}/tutor/tutor.zh.euc | 0 share/vim/{vim72 => vim73}/tutor/tutor.zh.utf-8 | 0 share/vim/vim73/vim.exe | Bin 0 -> 1855488 bytes share/vim/{vim72 => vim73}/vim16x16.gif | Bin share/vim/{vim72 => vim73}/vim16x16.png | Bin share/vim/{vim72 => vim73}/vim16x16.xpm | 0 share/vim/{vim72 => vim73}/vim32x32.gif | Bin share/vim/{vim72 => vim73}/vim32x32.png | Bin share/vim/{vim72 => vim73}/vim32x32.xpm | 0 share/vim/{vim72 => vim73}/vim48x48.gif | Bin share/vim/{vim72 => vim73}/vim48x48.png | Bin share/vim/{vim72 => vim73}/vim48x48.xpm | 0 share/vim/{vim72 => vim73}/vimlogo.cdr | Bin share/vim/{vim72 => vim73}/vimlogo.eps | 0 share/vim/{vim72 => vim73}/vimlogo.gif | Bin share/vim/{vim72 => vim73}/vimlogo.pdf | Bin share/vim/{vim72 => vim73}/vimlogo.xpm | 0 share/vim/vim73/vimrc_example.vim | 96 + 2065 files changed, 239154 insertions(+), 303068 deletions(-) delete mode 100644 share/vim/vim72/autoload/ccomplete.vim delete mode 100644 share/vim/vim72/autoload/getscript.vim delete mode 100644 share/vim/vim72/autoload/netrw.vim delete mode 100644 share/vim/vim72/autoload/netrwFileHandlers.vim delete mode 100644 share/vim/vim72/autoload/netrwSettings.vim delete mode 100644 share/vim/vim72/autoload/pythoncomplete.vim delete mode 100644 share/vim/vim72/autoload/rubycomplete.vim delete mode 100644 share/vim/vim72/autoload/spellfile.vim delete mode 100644 share/vim/vim72/autoload/sqlcomplete.vim delete mode 100644 share/vim/vim72/autoload/syntaxcomplete.vim delete mode 100644 share/vim/vim72/autoload/tar.vim delete mode 100644 share/vim/vim72/autoload/vimball.vim delete mode 100644 share/vim/vim72/autoload/zip.vim delete mode 100644 share/vim/vim72/compiler/eruby.vim delete mode 100644 share/vim/vim72/compiler/gcc.vim delete mode 100644 share/vim/vim72/compiler/jikes.vim delete mode 100644 share/vim/vim72/compiler/perl.vim delete mode 100644 share/vim/vim72/compiler/rspec.vim delete mode 100644 share/vim/vim72/compiler/ruby.vim delete mode 100644 share/vim/vim72/compiler/rubyunit.vim delete mode 100644 share/vim/vim72/doc/Makefile delete mode 100644 share/vim/vim72/doc/arabic.txt delete mode 100644 share/vim/vim72/doc/autocmd.txt delete mode 100644 share/vim/vim72/doc/change.txt delete mode 100644 share/vim/vim72/doc/cmdline.txt delete mode 100644 share/vim/vim72/doc/debug.txt delete mode 100644 share/vim/vim72/doc/debugger.txt delete mode 100644 share/vim/vim72/doc/develop.txt delete mode 100644 share/vim/vim72/doc/diff.txt delete mode 100644 share/vim/vim72/doc/digraph.txt delete mode 100644 share/vim/vim72/doc/editing.txt delete mode 100644 share/vim/vim72/doc/eval.txt delete mode 100644 share/vim/vim72/doc/evim-it.1 delete mode 100644 share/vim/vim72/doc/evim-it.UTF-8.1 delete mode 100644 share/vim/vim72/doc/evim-pl.1 delete mode 100644 share/vim/vim72/doc/evim-pl.UTF-8.1 delete mode 100644 share/vim/vim72/doc/farsi.txt delete mode 100644 share/vim/vim72/doc/filetype.txt delete mode 100644 share/vim/vim72/doc/fold.txt delete mode 100644 share/vim/vim72/doc/ft_ada.txt delete mode 100644 share/vim/vim72/doc/ft_sql.txt delete mode 100644 share/vim/vim72/doc/gui.txt delete mode 100644 share/vim/vim72/doc/gui_w16.txt delete mode 100644 share/vim/vim72/doc/gui_w32.txt delete mode 100644 share/vim/vim72/doc/gui_x11.txt delete mode 100644 share/vim/vim72/doc/hangulin.txt delete mode 100644 share/vim/vim72/doc/hebrew.txt delete mode 100644 share/vim/vim72/doc/help.txt delete mode 100644 share/vim/vim72/doc/howto.txt delete mode 100644 share/vim/vim72/doc/if_cscop.txt delete mode 100644 share/vim/vim72/doc/if_mzsch.txt delete mode 100644 share/vim/vim72/doc/if_ole.txt delete mode 100644 share/vim/vim72/doc/if_perl.txt delete mode 100644 share/vim/vim72/doc/if_pyth.txt delete mode 100644 share/vim/vim72/doc/if_ruby.txt delete mode 100644 share/vim/vim72/doc/if_sniff.txt delete mode 100644 share/vim/vim72/doc/if_tcl.txt delete mode 100644 share/vim/vim72/doc/indent.txt delete mode 100644 share/vim/vim72/doc/index.txt delete mode 100644 share/vim/vim72/doc/insert.txt delete mode 100644 share/vim/vim72/doc/intro.txt delete mode 100644 share/vim/vim72/doc/map.txt delete mode 100644 share/vim/vim72/doc/mbyte.txt delete mode 100644 share/vim/vim72/doc/message.txt delete mode 100644 share/vim/vim72/doc/mlang.txt delete mode 100644 share/vim/vim72/doc/motion.txt delete mode 100644 share/vim/vim72/doc/netbeans.txt delete mode 100644 share/vim/vim72/doc/options.txt delete mode 100644 share/vim/vim72/doc/os_390.txt delete mode 100644 share/vim/vim72/doc/os_amiga.txt delete mode 100644 share/vim/vim72/doc/os_beos.txt delete mode 100644 share/vim/vim72/doc/os_dos.txt delete mode 100644 share/vim/vim72/doc/os_mac.txt delete mode 100644 share/vim/vim72/doc/os_mint.txt delete mode 100644 share/vim/vim72/doc/os_msdos.txt delete mode 100644 share/vim/vim72/doc/os_os2.txt delete mode 100644 share/vim/vim72/doc/os_qnx.txt delete mode 100644 share/vim/vim72/doc/os_risc.txt delete mode 100644 share/vim/vim72/doc/os_unix.txt delete mode 100644 share/vim/vim72/doc/os_vms.txt delete mode 100644 share/vim/vim72/doc/os_win32.txt delete mode 100644 share/vim/vim72/doc/pattern.txt delete mode 100644 share/vim/vim72/doc/pi_getscript.txt delete mode 100644 share/vim/vim72/doc/pi_gzip.txt delete mode 100644 share/vim/vim72/doc/pi_netrw.txt delete mode 100644 share/vim/vim72/doc/pi_paren.txt delete mode 100644 share/vim/vim72/doc/pi_spec.txt delete mode 100644 share/vim/vim72/doc/pi_tar.txt delete mode 100644 share/vim/vim72/doc/pi_vimball.txt delete mode 100644 share/vim/vim72/doc/pi_zip.txt delete mode 100644 share/vim/vim72/doc/print.txt delete mode 100644 share/vim/vim72/doc/quickfix.txt delete mode 100644 share/vim/vim72/doc/quickref.txt delete mode 100644 share/vim/vim72/doc/quotes.txt delete mode 100644 share/vim/vim72/doc/recover.txt delete mode 100644 share/vim/vim72/doc/remote.txt delete mode 100644 share/vim/vim72/doc/repeat.txt delete mode 100644 share/vim/vim72/doc/rileft.txt delete mode 100644 share/vim/vim72/doc/russian.txt delete mode 100644 share/vim/vim72/doc/scroll.txt delete mode 100644 share/vim/vim72/doc/sign.txt delete mode 100644 share/vim/vim72/doc/spell.txt delete mode 100644 share/vim/vim72/doc/sponsor.txt delete mode 100644 share/vim/vim72/doc/starting.txt delete mode 100644 share/vim/vim72/doc/syntax.txt delete mode 100644 share/vim/vim72/doc/tabpage.txt delete mode 100644 share/vim/vim72/doc/tags delete mode 100644 share/vim/vim72/doc/tagsrch.txt delete mode 100644 share/vim/vim72/doc/term.txt delete mode 100644 share/vim/vim72/doc/tips.txt delete mode 100644 share/vim/vim72/doc/todo.txt delete mode 100644 share/vim/vim72/doc/uganda.txt delete mode 100644 share/vim/vim72/doc/undo.txt delete mode 100644 share/vim/vim72/doc/usr_01.txt delete mode 100644 share/vim/vim72/doc/usr_02.txt delete mode 100644 share/vim/vim72/doc/usr_03.txt delete mode 100644 share/vim/vim72/doc/usr_04.txt delete mode 100644 share/vim/vim72/doc/usr_05.txt delete mode 100644 share/vim/vim72/doc/usr_06.txt delete mode 100644 share/vim/vim72/doc/usr_07.txt delete mode 100644 share/vim/vim72/doc/usr_08.txt delete mode 100644 share/vim/vim72/doc/usr_09.txt delete mode 100644 share/vim/vim72/doc/usr_10.txt delete mode 100644 share/vim/vim72/doc/usr_11.txt delete mode 100644 share/vim/vim72/doc/usr_12.txt delete mode 100644 share/vim/vim72/doc/usr_20.txt delete mode 100644 share/vim/vim72/doc/usr_21.txt delete mode 100644 share/vim/vim72/doc/usr_22.txt delete mode 100644 share/vim/vim72/doc/usr_23.txt delete mode 100644 share/vim/vim72/doc/usr_24.txt delete mode 100644 share/vim/vim72/doc/usr_25.txt delete mode 100644 share/vim/vim72/doc/usr_26.txt delete mode 100644 share/vim/vim72/doc/usr_27.txt delete mode 100644 share/vim/vim72/doc/usr_28.txt delete mode 100644 share/vim/vim72/doc/usr_29.txt delete mode 100644 share/vim/vim72/doc/usr_30.txt delete mode 100644 share/vim/vim72/doc/usr_31.txt delete mode 100644 share/vim/vim72/doc/usr_32.txt delete mode 100644 share/vim/vim72/doc/usr_40.txt delete mode 100644 share/vim/vim72/doc/usr_41.txt delete mode 100644 share/vim/vim72/doc/usr_42.txt delete mode 100644 share/vim/vim72/doc/usr_43.txt delete mode 100644 share/vim/vim72/doc/usr_44.txt delete mode 100644 share/vim/vim72/doc/usr_45.txt delete mode 100644 share/vim/vim72/doc/usr_90.txt delete mode 100644 share/vim/vim72/doc/usr_toc.txt delete mode 100644 share/vim/vim72/doc/various.txt delete mode 100644 share/vim/vim72/doc/version4.txt delete mode 100644 share/vim/vim72/doc/version5.txt delete mode 100644 share/vim/vim72/doc/version6.txt delete mode 100644 share/vim/vim72/doc/version7.txt delete mode 100644 share/vim/vim72/doc/vi_diff.txt delete mode 100644 share/vim/vim72/doc/vim-fr.1 delete mode 100644 share/vim/vim72/doc/vim-fr.UTF-8.1 delete mode 100644 share/vim/vim72/doc/vim-it.1 delete mode 100644 share/vim/vim72/doc/vim-it.UTF-8.1 delete mode 100644 share/vim/vim72/doc/vim-pl.1 delete mode 100644 share/vim/vim72/doc/vim-pl.UTF-8.1 delete mode 100644 share/vim/vim72/doc/vim-ru.1 delete mode 100644 share/vim/vim72/doc/vim-ru.UTF-8.1 delete mode 100644 share/vim/vim72/doc/vimdiff-fr.1 delete mode 100644 share/vim/vim72/doc/vimdiff-fr.UTF-8.1 delete mode 100644 share/vim/vim72/doc/vimdiff-it.1 delete mode 100644 share/vim/vim72/doc/vimdiff-it.UTF-8.1 delete mode 100644 share/vim/vim72/doc/vimdiff-pl.1 delete mode 100644 share/vim/vim72/doc/vimdiff-pl.UTF-8.1 delete mode 100644 share/vim/vim72/doc/vimdiff-ru.1 delete mode 100644 share/vim/vim72/doc/vimdiff-ru.UTF-8.1 delete mode 100644 share/vim/vim72/doc/vimtutor-fr.1 delete mode 100644 share/vim/vim72/doc/vimtutor-fr.UTF-8.1 delete mode 100644 share/vim/vim72/doc/vimtutor-it.1 delete mode 100644 share/vim/vim72/doc/vimtutor-it.UTF-8.1 delete mode 100644 share/vim/vim72/doc/vimtutor-pl.1 delete mode 100644 share/vim/vim72/doc/vimtutor-pl.UTF-8.1 delete mode 100644 share/vim/vim72/doc/vimtutor.1 delete mode 100644 share/vim/vim72/doc/vimtutor.man delete mode 100644 share/vim/vim72/doc/visual.txt delete mode 100644 share/vim/vim72/doc/windows.txt delete mode 100644 share/vim/vim72/doc/workshop.txt delete mode 100644 share/vim/vim72/doc/xxd-fr.1 delete mode 100644 share/vim/vim72/doc/xxd-fr.UTF-8.1 delete mode 100644 share/vim/vim72/doc/xxd-it.1 delete mode 100644 share/vim/vim72/doc/xxd-it.UTF-8.1 delete mode 100644 share/vim/vim72/doc/xxd-pl.1 delete mode 100644 share/vim/vim72/doc/xxd-pl.UTF-8.1 delete mode 100644 share/vim/vim72/evim.vim delete mode 100644 share/vim/vim72/filetype.vim delete mode 100644 share/vim/vim72/ftplugin/AppendMatchGroup.vim delete mode 100644 share/vim/vim72/ftplugin/abaqus.vim delete mode 100644 share/vim/vim72/ftplugin/ant.vim delete mode 100644 share/vim/vim72/ftplugin/aspvbs.vim delete mode 100644 share/vim/vim72/ftplugin/changelog.vim delete mode 100644 share/vim/vim72/ftplugin/config.vim delete mode 100644 share/vim/vim72/ftplugin/csc.vim delete mode 100644 share/vim/vim72/ftplugin/csh.vim delete mode 100644 share/vim/vim72/ftplugin/debchangelog.vim delete mode 100644 share/vim/vim72/ftplugin/debcontrol.vim delete mode 100644 share/vim/vim72/ftplugin/dosbatch.vim delete mode 100644 share/vim/vim72/ftplugin/dtd.vim delete mode 100644 share/vim/vim72/ftplugin/eruby.vim delete mode 100644 share/vim/vim72/ftplugin/fortran.vim delete mode 100644 share/vim/vim72/ftplugin/git.vim delete mode 100644 share/vim/vim72/ftplugin/gitcommit.vim delete mode 100644 share/vim/vim72/ftplugin/gitconfig.vim delete mode 100644 share/vim/vim72/ftplugin/gitrebase.vim delete mode 100644 share/vim/vim72/ftplugin/gitsendemail.vim delete mode 100644 share/vim/vim72/ftplugin/haml.vim delete mode 100644 share/vim/vim72/ftplugin/help.vim delete mode 100644 share/vim/vim72/ftplugin/html.vim delete mode 100644 share/vim/vim72/ftplugin/java.vim delete mode 100644 share/vim/vim72/ftplugin/jsp.vim delete mode 100644 share/vim/vim72/ftplugin/mail.vim delete mode 100644 share/vim/vim72/ftplugin/man.vim delete mode 100644 share/vim/vim72/ftplugin/mupad.vim delete mode 100644 share/vim/vim72/ftplugin/ocaml.vim delete mode 100644 share/vim/vim72/ftplugin/pascal.vim delete mode 100644 share/vim/vim72/ftplugin/perl.vim delete mode 100644 share/vim/vim72/ftplugin/php.vim delete mode 100644 share/vim/vim72/ftplugin/ruby.vim delete mode 100644 share/vim/vim72/ftplugin/sass.vim delete mode 100644 share/vim/vim72/ftplugin/sgml.vim delete mode 100644 share/vim/vim72/ftplugin/sh.vim delete mode 100644 share/vim/vim72/ftplugin/sql.vim delete mode 100644 share/vim/vim72/ftplugin/svg.vim delete mode 100644 share/vim/vim72/ftplugin/tcsh.vim delete mode 100644 share/vim/vim72/ftplugin/verilog.vim delete mode 100644 share/vim/vim72/ftplugin/vim.vim delete mode 100644 share/vim/vim72/ftplugin/xhtml.vim delete mode 100644 share/vim/vim72/ftplugin/xml.vim delete mode 100644 share/vim/vim72/ftplugin/xs.vim delete mode 100644 share/vim/vim72/ftplugin/xsd.vim delete mode 100644 share/vim/vim72/ftplugin/xslt.vim delete mode 100644 share/vim/vim72/indent/GenericIndent.vim delete mode 100644 share/vim/vim72/indent/cmake.vim delete mode 100644 share/vim/vim72/indent/cpp.vim delete mode 100644 share/vim/vim72/indent/eruby.vim delete mode 100644 share/vim/vim72/indent/fortran.vim delete mode 100644 share/vim/vim72/indent/gitconfig.vim delete mode 100644 share/vim/vim72/indent/haml.vim delete mode 100644 share/vim/vim72/indent/javascript.vim delete mode 100644 share/vim/vim72/indent/mupad.vim delete mode 100644 share/vim/vim72/indent/perl.vim delete mode 100644 share/vim/vim72/indent/php.vim delete mode 100644 share/vim/vim72/indent/ruby.vim delete mode 100644 share/vim/vim72/indent/sass.vim delete mode 100644 share/vim/vim72/indent/sh.vim delete mode 100644 share/vim/vim72/indent/tf.vim delete mode 100644 share/vim/vim72/indent/vb.vim delete mode 100644 share/vim/vim72/indent/vhdl.vim delete mode 100644 share/vim/vim72/indent/xml.vim delete mode 100644 share/vim/vim72/keymap/bulgarian-bds.vim delete mode 100644 share/vim/vim72/keymap/bulgarian-phonetic.vim delete mode 100644 share/vim/vim72/keymap/czech_utf-8.vim delete mode 100644 share/vim/vim72/lang/menu_de_de.latin1.vim delete mode 100644 share/vim/vim72/lang/menu_es_es.latin1.vim delete mode 100644 share/vim/vim72/lang/menu_it_it.latin1.vim delete mode 100644 share/vim/vim72/lang/menu_ja_jp.euc-jp.vim delete mode 100644 share/vim/vim72/lang/menu_ja_jp.utf-8.vim delete mode 100644 share/vim/vim72/lang/menu_japanese_japan.932.vim delete mode 100644 share/vim/vim72/lang/menu_ko_kr.euckr.vim delete mode 100644 share/vim/vim72/lang/menu_ko_kr.utf-8.vim delete mode 100644 share/vim/vim72/lang/menu_ko_kr.vim delete mode 100644 share/vim/vim72/lang/menu_pl_pl.iso_8859-2.vim delete mode 100644 share/vim/vim72/lang/menu_pl_pl.utf-8.vim delete mode 100644 share/vim/vim72/lang/menu_polish_poland.1250.vim delete mode 100644 share/vim/vim72/lang/menu_sr.utf-8.vim delete mode 100644 share/vim/vim72/lang/menu_sr_yu.utf-8.vim delete mode 100644 share/vim/vim72/macros/matchit.vim delete mode 100644 share/vim/vim72/makemenu.vim delete mode 100644 share/vim/vim72/menu.vim delete mode 100644 share/vim/vim72/optwin.vim delete mode 100644 share/vim/vim72/plugin/getscriptPlugin.vim delete mode 100644 share/vim/vim72/plugin/gzip.vim delete mode 100644 share/vim/vim72/plugin/matchparen.vim delete mode 100644 share/vim/vim72/plugin/netrwPlugin.vim delete mode 100644 share/vim/vim72/plugin/rrhelper.vim delete mode 100644 share/vim/vim72/plugin/tarPlugin.vim delete mode 100644 share/vim/vim72/plugin/tohtml.vim delete mode 100644 share/vim/vim72/plugin/vimballPlugin.vim delete mode 100644 share/vim/vim72/plugin/zipPlugin.vim delete mode 100644 share/vim/vim72/scripts.vim delete mode 100644 share/vim/vim72/spell/README.txt delete mode 100644 share/vim/vim72/spell/README_en.txt delete mode 100644 share/vim/vim72/spell/bg/main.aap delete mode 100644 share/vim/vim72/spell/ca/main.aap delete mode 100644 share/vim/vim72/spell/cy/main.aap delete mode 100644 share/vim/vim72/spell/de/main.aap delete mode 100644 share/vim/vim72/spell/eo/main.aap delete mode 100644 share/vim/vim72/spell/es/es_MX.diff delete mode 100644 share/vim/vim72/spell/es/main.aap delete mode 100644 share/vim/vim72/spell/fr/main.aap delete mode 100644 share/vim/vim72/spell/gd/main.aap delete mode 100644 share/vim/vim72/spell/ku/main.aap delete mode 100644 share/vim/vim72/spell/la/main.aap delete mode 100644 share/vim/vim72/spell/lv/main.aap delete mode 100644 share/vim/vim72/spell/main.aap delete mode 100644 share/vim/vim72/spell/ms/main.aap delete mode 100644 share/vim/vim72/spell/nb/main.aap delete mode 100644 share/vim/vim72/spell/nl/main.aap delete mode 100644 share/vim/vim72/spell/nl/nl_NL.diff delete mode 100644 share/vim/vim72/spell/nn/main.aap delete mode 100644 share/vim/vim72/spell/pt/main.aap delete mode 100644 share/vim/vim72/spell/pt/pt_BR.diff delete mode 100644 share/vim/vim72/spell/pt/pt_PT.diff delete mode 100644 share/vim/vim72/spell/sv/main.aap delete mode 100644 share/vim/vim72/spell/sv/sv_SE.diff delete mode 100644 share/vim/vim72/synmenu.vim delete mode 100644 share/vim/vim72/syntax/2html.vim delete mode 100644 share/vim/vim72/syntax/asm.vim delete mode 100644 share/vim/vim72/syntax/bzr.vim delete mode 100644 share/vim/vim72/syntax/c.vim delete mode 100644 share/vim/vim72/syntax/cf.vim delete mode 100644 share/vim/vim72/syntax/cmake.vim delete mode 100644 share/vim/vim72/syntax/config.vim delete mode 100644 share/vim/vim72/syntax/cs.vim delete mode 100644 share/vim/vim72/syntax/css.vim delete mode 100644 share/vim/vim72/syntax/d.vim delete mode 100644 share/vim/vim72/syntax/debchangelog.vim delete mode 100644 share/vim/vim72/syntax/debcontrol.vim delete mode 100644 share/vim/vim72/syntax/debsources.vim delete mode 100644 share/vim/vim72/syntax/diff.vim delete mode 100644 share/vim/vim72/syntax/django.vim delete mode 100644 share/vim/vim72/syntax/dosbatch.vim delete mode 100644 share/vim/vim72/syntax/doxygen.vim delete mode 100644 share/vim/vim72/syntax/erlang.vim delete mode 100644 share/vim/vim72/syntax/eruby.vim delete mode 100644 share/vim/vim72/syntax/form.vim delete mode 100644 share/vim/vim72/syntax/forth.vim delete mode 100644 share/vim/vim72/syntax/fortran.vim delete mode 100644 share/vim/vim72/syntax/fstab.vim delete mode 100644 share/vim/vim72/syntax/gdb.vim delete mode 100644 share/vim/vim72/syntax/git.vim delete mode 100644 share/vim/vim72/syntax/gitcommit.vim delete mode 100644 share/vim/vim72/syntax/gitconfig.vim delete mode 100644 share/vim/vim72/syntax/gitrebase.vim delete mode 100644 share/vim/vim72/syntax/gitsendemail.vim delete mode 100644 share/vim/vim72/syntax/groovy.vim delete mode 100644 share/vim/vim72/syntax/haml.vim delete mode 100644 share/vim/vim72/syntax/haskell.vim delete mode 100644 share/vim/vim72/syntax/help.vim delete mode 100644 share/vim/vim72/syntax/indent.vim delete mode 100644 share/vim/vim72/syntax/java.vim delete mode 100644 share/vim/vim72/syntax/javascript.vim delete mode 100644 share/vim/vim72/syntax/jsp.vim delete mode 100644 share/vim/vim72/syntax/kconfig.vim delete mode 100644 share/vim/vim72/syntax/lex.vim delete mode 100644 share/vim/vim72/syntax/lhaskell.vim delete mode 100644 share/vim/vim72/syntax/lifelines.vim delete mode 100644 share/vim/vim72/syntax/lilo.vim delete mode 100644 share/vim/vim72/syntax/lisp.vim delete mode 100644 share/vim/vim72/syntax/logtalk.vim delete mode 100644 share/vim/vim72/syntax/mail.vim delete mode 100644 share/vim/vim72/syntax/man.vim delete mode 100644 share/vim/vim72/syntax/maple.vim delete mode 100644 share/vim/vim72/syntax/matlab.vim delete mode 100644 share/vim/vim72/syntax/maxima.vim delete mode 100644 share/vim/vim72/syntax/mib.vim delete mode 100644 share/vim/vim72/syntax/muttrc.vim delete mode 100644 share/vim/vim72/syntax/mysql.vim delete mode 100644 share/vim/vim72/syntax/netrc.vim delete mode 100644 share/vim/vim72/syntax/netrw.vim delete mode 100644 share/vim/vim72/syntax/papp.vim delete mode 100644 share/vim/vim72/syntax/perl.vim delete mode 100644 share/vim/vim72/syntax/po.vim delete mode 100644 share/vim/vim72/syntax/pod.vim delete mode 100644 share/vim/vim72/syntax/prolog.vim delete mode 100644 share/vim/vim72/syntax/pyrex.vim delete mode 100644 share/vim/vim72/syntax/python.vim delete mode 100644 share/vim/vim72/syntax/readline.vim delete mode 100644 share/vim/vim72/syntax/remind.vim delete mode 100644 share/vim/vim72/syntax/rhelp.vim delete mode 100644 share/vim/vim72/syntax/rnoweb.vim delete mode 100644 share/vim/vim72/syntax/rst.vim delete mode 100644 share/vim/vim72/syntax/ruby.vim delete mode 100644 share/vim/vim72/syntax/samba.vim delete mode 100644 share/vim/vim72/syntax/sass.vim delete mode 100644 share/vim/vim72/syntax/scheme.vim delete mode 100644 share/vim/vim72/syntax/screen.vim delete mode 100644 share/vim/vim72/syntax/sed.vim delete mode 100644 share/vim/vim72/syntax/sgmllnx.vim delete mode 100644 share/vim/vim72/syntax/sh.vim delete mode 100644 share/vim/vim72/syntax/sisu.vim delete mode 100644 share/vim/vim72/syntax/spec.vim delete mode 100644 share/vim/vim72/syntax/spyce.vim delete mode 100644 share/vim/vim72/syntax/sqlanywhere.vim delete mode 100644 share/vim/vim72/syntax/sshconfig.vim delete mode 100644 share/vim/vim72/syntax/sshdconfig.vim delete mode 100644 share/vim/vim72/syntax/synload.vim delete mode 100644 share/vim/vim72/syntax/tcl.vim delete mode 100644 share/vim/vim72/syntax/tcsh.vim delete mode 100644 share/vim/vim72/syntax/tex.vim delete mode 100644 share/vim/vim72/syntax/uil.vim delete mode 100644 share/vim/vim72/syntax/updatedb.vim delete mode 100644 share/vim/vim72/syntax/vim.vim delete mode 100644 share/vim/vim72/syntax/xml.vim delete mode 100644 share/vim/vim72/syntax/xs.vim delete mode 100644 share/vim/vim72/syntax/yacc.vim delete mode 100644 share/vim/vim72/syntax/yaml.vim delete mode 100644 share/vim/vim72/syntax/zsh.vim delete mode 100644 share/vim/vim72/tools/README.txt delete mode 100644 share/vim/vim72/tutor/Makefile delete mode 100644 share/vim/vim72/tutor/tutor delete mode 100644 share/vim/vim72/tutor/tutor.eo.utf-8 delete mode 100644 share/vim/vim72/tutor/tutor.es delete mode 100644 share/vim/vim72/tutor/tutor.es.utf-8 delete mode 100644 share/vim/vim72/tutor/tutor.fr delete mode 100644 share/vim/vim72/tutor/tutor.fr.utf-8 delete mode 100644 share/vim/vim72/tutor/tutor.hu delete mode 100644 share/vim/vim72/tutor/tutor.hu.cp1250 delete mode 100644 share/vim/vim72/tutor/tutor.hu.utf-8 delete mode 100644 share/vim/vim72/tutor/tutor.it delete mode 100644 share/vim/vim72/tutor/tutor.it.utf-8 delete mode 100644 share/vim/vim72/tutor/tutor.ja.euc delete mode 100644 share/vim/vim72/tutor/tutor.ja.sjis delete mode 100644 share/vim/vim72/tutor/tutor.ja.utf-8 delete mode 100644 share/vim/vim72/tutor/tutor.pl delete mode 100644 share/vim/vim72/tutor/tutor.pl.cp1250 delete mode 100644 share/vim/vim72/tutor/tutor.pl.utf-8 delete mode 100644 share/vim/vim72/tutor/tutor.utf-8 delete mode 100644 share/vim/vim72/vim.exe delete mode 100644 share/vim/vim72/vimrc_example.vim rename share/vim/{vim72 => vim73}/autoload/README.txt (100%) rename share/vim/{vim72 => vim73}/autoload/ada.vim (100%) rename share/vim/{vim72 => vim73}/autoload/adacomplete.vim (100%) create mode 100644 share/vim/vim73/autoload/ccomplete.vim rename share/vim/{vim72 => vim73}/autoload/csscomplete.vim (100%) rename share/vim/{vim72 => vim73}/autoload/decada.vim (100%) create mode 100644 share/vim/vim73/autoload/getscript.vim rename share/vim/{vim72 => vim73}/autoload/gnat.vim (100%) rename share/vim/{vim72 => vim73}/autoload/gzip.vim (100%) rename share/vim/{vim72 => vim73}/autoload/htmlcomplete.vim (100%) rename share/vim/{vim72 => vim73}/autoload/javascriptcomplete.vim (100%) create mode 100644 share/vim/vim73/autoload/netrw.vim create mode 100644 share/vim/vim73/autoload/netrwFileHandlers.vim create mode 100644 share/vim/vim73/autoload/netrwSettings.vim rename share/vim/{vim72 => vim73}/autoload/paste.vim (100%) rename share/vim/{vim72 => vim73}/autoload/phpcomplete.vim (100%) create mode 100644 share/vim/vim73/autoload/python3complete.vim create mode 100644 share/vim/vim73/autoload/pythoncomplete.vim create mode 100644 share/vim/vim73/autoload/rubycomplete.vim create mode 100644 share/vim/vim73/autoload/spellfile.vim create mode 100644 share/vim/vim73/autoload/sqlcomplete.vim create mode 100644 share/vim/vim73/autoload/syntaxcomplete.vim create mode 100644 share/vim/vim73/autoload/tar.vim create mode 100644 share/vim/vim73/autoload/tohtml.vim create mode 100644 share/vim/vim73/autoload/vimball.vim rename share/vim/{vim72 => vim73}/autoload/xml/html32.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/html401f.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/html401s.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/html401t.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/html40f.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/html40s.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/html40t.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/xhtml10f.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/xhtml10s.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/xhtml10t.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/xhtml11.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/xsd.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xml/xsl.vim (100%) rename share/vim/{vim72 => vim73}/autoload/xmlcomplete.vim (100%) create mode 100644 share/vim/vim73/autoload/zip.vim rename share/vim/{vim72 => vim73}/bugreport.vim (100%) rename share/vim/{vim72 => vim73}/colors/README.txt (100%) rename share/vim/{vim72 => vim73}/colors/blue.vim (100%) rename share/vim/{vim72 => vim73}/colors/darkblue.vim (100%) rename share/vim/{vim72 => vim73}/colors/default.vim (100%) rename share/vim/{vim72 => vim73}/colors/delek.vim (100%) rename share/vim/{vim72 => vim73}/colors/desert.vim (100%) rename share/vim/{vim72 => vim73}/colors/elflord.vim (100%) rename share/vim/{vim72 => vim73}/colors/evening.vim (100%) rename share/vim/{vim72 => vim73}/colors/koehler.vim (100%) rename share/vim/{vim72 => vim73}/colors/morning.vim (100%) rename share/vim/{vim72 => vim73}/colors/murphy.vim (100%) rename share/vim/{vim72 => vim73}/colors/pablo.vim (100%) rename share/vim/{vim72 => vim73}/colors/peachpuff.vim (100%) rename share/vim/{vim72 => vim73}/colors/ron.vim (100%) rename share/vim/{vim72 => vim73}/colors/shine.vim (100%) rename share/vim/{vim72 => vim73}/colors/slate.vim (100%) rename share/vim/{vim72 => vim73}/colors/torte.vim (100%) rename share/vim/{vim72 => vim73}/colors/zellner.vim (100%) rename share/vim/{vim72 => vim73}/compiler/README.txt (100%) rename share/vim/{vim72 => vim73}/compiler/ant.vim (100%) rename share/vim/{vim72 => vim73}/compiler/bcc.vim (100%) rename share/vim/{vim72 => vim73}/compiler/bdf.vim (100%) rename share/vim/{vim72 => vim73}/compiler/checkstyle.vim (100%) rename share/vim/{vim72 => vim73}/compiler/cs.vim (100%) create mode 100644 share/vim/vim73/compiler/cucumber.vim rename share/vim/{vim72 => vim73}/compiler/decada.vim (100%) rename share/vim/{vim72 => vim73}/compiler/dot.vim (100%) create mode 100644 share/vim/vim73/compiler/eruby.vim rename share/vim/{vim72 => vim73}/compiler/fortran_F.vim (100%) rename share/vim/{vim72 => vim73}/compiler/fortran_cv.vim (100%) rename share/vim/{vim72 => vim73}/compiler/fortran_elf90.vim (100%) rename share/vim/{vim72 => vim73}/compiler/fortran_g77.vim (100%) rename share/vim/{vim72 => vim73}/compiler/fortran_lf95.vim (100%) rename share/vim/{vim72 => vim73}/compiler/fpc.vim (100%) create mode 100644 share/vim/vim73/compiler/gcc.vim rename share/vim/{vim72 => vim73}/compiler/gnat.vim (100%) rename share/vim/{vim72 => vim73}/compiler/hp_acc.vim (100%) rename share/vim/{vim72 => vim73}/compiler/icc.vim (100%) rename share/vim/{vim72 => vim73}/compiler/intel.vim (100%) rename share/vim/{vim72 => vim73}/compiler/irix5_c.vim (100%) rename share/vim/{vim72 => vim73}/compiler/irix5_cpp.vim (100%) rename share/vim/{vim72 => vim73}/compiler/javac.vim (100%) create mode 100644 share/vim/vim73/compiler/jikes.vim rename share/vim/{vim72 => vim73}/compiler/mcs.vim (100%) rename share/vim/{vim72 => vim73}/compiler/mips_c.vim (100%) rename share/vim/{vim72 => vim73}/compiler/mipspro_c89.vim (100%) rename share/vim/{vim72 => vim73}/compiler/mipspro_cpp.vim (100%) rename share/vim/{vim72 => vim73}/compiler/modelsim_vcom.vim (100%) rename share/vim/{vim72 => vim73}/compiler/msvc.vim (100%) rename share/vim/{vim72 => vim73}/compiler/neato.vim (100%) rename share/vim/{vim72 => vim73}/compiler/onsgmls.vim (100%) rename share/vim/{vim72 => vim73}/compiler/pbx.vim (100%) create mode 100644 share/vim/vim73/compiler/perl.vim rename share/vim/{vim72 => vim73}/compiler/php.vim (100%) rename share/vim/{vim72 => vim73}/compiler/pyunit.vim (100%) create mode 100644 share/vim/vim73/compiler/rspec.vim rename share/vim/{vim72 => vim73}/compiler/rst.vim (100%) create mode 100644 share/vim/vim73/compiler/ruby.vim create mode 100644 share/vim/vim73/compiler/rubyunit.vim rename share/vim/{vim72 => vim73}/compiler/se.vim (100%) rename share/vim/{vim72 => vim73}/compiler/splint.vim (100%) rename share/vim/{vim72 => vim73}/compiler/tcl.vim (100%) rename share/vim/{vim72 => vim73}/compiler/tex.vim (100%) rename share/vim/{vim72 => vim73}/compiler/tidy.vim (100%) rename share/vim/{vim72 => vim73}/compiler/xmllint.vim (100%) rename share/vim/{vim72 => vim73}/compiler/xmlwf.vim (100%) rename share/vim/{vim72 => vim73}/delmenu.vim (100%) rename share/vim/{vim72 => vim73}/doc.info (100%) create mode 100644 share/vim/vim73/doc/Makefile create mode 100644 share/vim/vim73/doc/arabic.txt create mode 100644 share/vim/vim73/doc/autocmd.txt create mode 100644 share/vim/vim73/doc/change.txt create mode 100644 share/vim/vim73/doc/cmdline.txt create mode 100644 share/vim/vim73/doc/debug.txt create mode 100644 share/vim/vim73/doc/debugger.txt create mode 100644 share/vim/vim73/doc/develop.txt create mode 100644 share/vim/vim73/doc/diff.txt create mode 100644 share/vim/vim73/doc/digraph.txt rename share/vim/{vim72 => vim73}/doc/doctags.c (100%) create mode 100644 share/vim/vim73/doc/editing.txt create mode 100644 share/vim/vim73/doc/eval.txt rename share/vim/{vim72 => vim73}/doc/evim-fr.1 (100%) rename share/vim/{vim72 => vim73}/doc/evim-fr.UTF-8.1 (100%) create mode 100644 share/vim/vim73/doc/evim-it.1 create mode 100644 share/vim/vim73/doc/evim-it.UTF-8.1 create mode 100644 share/vim/vim73/doc/evim-pl.1 create mode 100644 share/vim/vim73/doc/evim-pl.UTF-8.1 rename share/vim/{vim72 => vim73}/doc/evim-ru.1 (100%) rename share/vim/{vim72 => vim73}/doc/evim-ru.UTF-8.1 (100%) rename share/vim/{vim72 => vim73}/doc/evim.1 (100%) create mode 100644 share/vim/vim73/doc/farsi.txt create mode 100644 share/vim/vim73/doc/filetype.txt create mode 100644 share/vim/vim73/doc/fold.txt create mode 100644 share/vim/vim73/doc/ft_ada.txt create mode 100644 share/vim/vim73/doc/ft_sql.txt create mode 100644 share/vim/vim73/doc/gui.txt create mode 100644 share/vim/vim73/doc/gui_w16.txt create mode 100644 share/vim/vim73/doc/gui_w32.txt create mode 100644 share/vim/vim73/doc/gui_x11.txt create mode 100644 share/vim/vim73/doc/hangulin.txt create mode 100644 share/vim/vim73/doc/hebrew.txt create mode 100644 share/vim/vim73/doc/help.txt rename share/vim/{vim72 => vim73}/doc/help.txt.info (100%) create mode 100644 share/vim/vim73/doc/helphelp.txt create mode 100644 share/vim/vim73/doc/howto.txt create mode 100644 share/vim/vim73/doc/if_cscop.txt create mode 100644 share/vim/vim73/doc/if_lua.txt create mode 100644 share/vim/vim73/doc/if_mzsch.txt create mode 100644 share/vim/vim73/doc/if_ole.txt create mode 100644 share/vim/vim73/doc/if_perl.txt create mode 100644 share/vim/vim73/doc/if_pyth.txt create mode 100644 share/vim/vim73/doc/if_ruby.txt create mode 100644 share/vim/vim73/doc/if_sniff.txt create mode 100644 share/vim/vim73/doc/if_tcl.txt create mode 100644 share/vim/vim73/doc/indent.txt create mode 100644 share/vim/vim73/doc/index.txt create mode 100644 share/vim/vim73/doc/insert.txt create mode 100644 share/vim/vim73/doc/intro.txt rename share/vim/{vim72 => vim73}/doc/makehtml.awk (100%) rename share/vim/{vim72 => vim73}/doc/maketags.awk (100%) create mode 100644 share/vim/vim73/doc/map.txt create mode 100644 share/vim/vim73/doc/mbyte.txt create mode 100644 share/vim/vim73/doc/message.txt create mode 100644 share/vim/vim73/doc/mlang.txt create mode 100644 share/vim/vim73/doc/motion.txt create mode 100644 share/vim/vim73/doc/netbeans.txt create mode 100644 share/vim/vim73/doc/options.txt create mode 100644 share/vim/vim73/doc/os_390.txt create mode 100644 share/vim/vim73/doc/os_amiga.txt create mode 100644 share/vim/vim73/doc/os_beos.txt create mode 100644 share/vim/vim73/doc/os_dos.txt create mode 100644 share/vim/vim73/doc/os_mac.txt create mode 100644 share/vim/vim73/doc/os_mint.txt create mode 100644 share/vim/vim73/doc/os_msdos.txt create mode 100644 share/vim/vim73/doc/os_os2.txt create mode 100644 share/vim/vim73/doc/os_qnx.txt create mode 100644 share/vim/vim73/doc/os_risc.txt create mode 100644 share/vim/vim73/doc/os_unix.txt create mode 100644 share/vim/vim73/doc/os_vms.txt create mode 100644 share/vim/vim73/doc/os_win32.txt create mode 100644 share/vim/vim73/doc/pattern.txt create mode 100644 share/vim/vim73/doc/pi_getscript.txt create mode 100644 share/vim/vim73/doc/pi_gzip.txt create mode 100644 share/vim/vim73/doc/pi_netrw.txt create mode 100644 share/vim/vim73/doc/pi_paren.txt create mode 100644 share/vim/vim73/doc/pi_spec.txt create mode 100644 share/vim/vim73/doc/pi_tar.txt create mode 100644 share/vim/vim73/doc/pi_vimball.txt create mode 100644 share/vim/vim73/doc/pi_zip.txt create mode 100644 share/vim/vim73/doc/print.txt create mode 100644 share/vim/vim73/doc/quickfix.txt create mode 100644 share/vim/vim73/doc/quickref.txt create mode 100644 share/vim/vim73/doc/quotes.txt create mode 100644 share/vim/vim73/doc/recover.txt create mode 100644 share/vim/vim73/doc/remote.txt create mode 100644 share/vim/vim73/doc/repeat.txt create mode 100644 share/vim/vim73/doc/rileft.txt create mode 100644 share/vim/vim73/doc/russian.txt create mode 100644 share/vim/vim73/doc/scroll.txt create mode 100644 share/vim/vim73/doc/sign.txt create mode 100644 share/vim/vim73/doc/spell.txt create mode 100644 share/vim/vim73/doc/sponsor.txt create mode 100644 share/vim/vim73/doc/starting.txt create mode 100644 share/vim/vim73/doc/syntax.txt create mode 100644 share/vim/vim73/doc/tabpage.txt create mode 100644 share/vim/vim73/doc/tags create mode 100644 share/vim/vim73/doc/tagsrch.txt create mode 100644 share/vim/vim73/doc/term.txt create mode 100644 share/vim/vim73/doc/tips.txt create mode 100644 share/vim/vim73/doc/todo.txt create mode 100644 share/vim/vim73/doc/uganda.txt create mode 100644 share/vim/vim73/doc/undo.txt create mode 100644 share/vim/vim73/doc/usr_01.txt create mode 100644 share/vim/vim73/doc/usr_02.txt create mode 100644 share/vim/vim73/doc/usr_03.txt create mode 100644 share/vim/vim73/doc/usr_04.txt create mode 100644 share/vim/vim73/doc/usr_05.txt create mode 100644 share/vim/vim73/doc/usr_06.txt create mode 100644 share/vim/vim73/doc/usr_07.txt create mode 100644 share/vim/vim73/doc/usr_08.txt create mode 100644 share/vim/vim73/doc/usr_09.txt create mode 100644 share/vim/vim73/doc/usr_10.txt create mode 100644 share/vim/vim73/doc/usr_11.txt create mode 100644 share/vim/vim73/doc/usr_12.txt create mode 100644 share/vim/vim73/doc/usr_20.txt create mode 100644 share/vim/vim73/doc/usr_21.txt create mode 100644 share/vim/vim73/doc/usr_22.txt create mode 100644 share/vim/vim73/doc/usr_23.txt create mode 100644 share/vim/vim73/doc/usr_24.txt create mode 100644 share/vim/vim73/doc/usr_25.txt create mode 100644 share/vim/vim73/doc/usr_26.txt create mode 100644 share/vim/vim73/doc/usr_27.txt create mode 100644 share/vim/vim73/doc/usr_28.txt create mode 100644 share/vim/vim73/doc/usr_29.txt create mode 100644 share/vim/vim73/doc/usr_30.txt create mode 100644 share/vim/vim73/doc/usr_31.txt create mode 100644 share/vim/vim73/doc/usr_32.txt create mode 100644 share/vim/vim73/doc/usr_40.txt create mode 100644 share/vim/vim73/doc/usr_41.txt create mode 100644 share/vim/vim73/doc/usr_42.txt create mode 100644 share/vim/vim73/doc/usr_43.txt create mode 100644 share/vim/vim73/doc/usr_44.txt create mode 100644 share/vim/vim73/doc/usr_45.txt create mode 100644 share/vim/vim73/doc/usr_90.txt create mode 100644 share/vim/vim73/doc/usr_toc.txt create mode 100644 share/vim/vim73/doc/various.txt create mode 100644 share/vim/vim73/doc/version4.txt create mode 100644 share/vim/vim73/doc/version5.txt create mode 100644 share/vim/vim73/doc/version6.txt create mode 100644 share/vim/vim73/doc/version7.txt create mode 100644 share/vim/vim73/doc/vi_diff.txt create mode 100644 share/vim/vim73/doc/vim-fr.1 create mode 100644 share/vim/vim73/doc/vim-fr.UTF-8.1 create mode 100644 share/vim/vim73/doc/vim-it.1 create mode 100644 share/vim/vim73/doc/vim-it.UTF-8.1 create mode 100644 share/vim/vim73/doc/vim-pl.1 create mode 100644 share/vim/vim73/doc/vim-pl.UTF-8.1 create mode 100644 share/vim/vim73/doc/vim-ru.1 create mode 100644 share/vim/vim73/doc/vim-ru.UTF-8.1 rename share/vim/{vim72 => vim73}/doc/vim.1 (100%) rename share/vim/{vim72 => vim73}/doc/vim.man (100%) rename share/vim/{vim72 => vim73}/doc/vim.man.info (100%) rename share/vim/{vim72 => vim73}/doc/vim2html.pl (100%) create mode 100644 share/vim/vim73/doc/vimdiff-fr.1 create mode 100644 share/vim/vim73/doc/vimdiff-fr.UTF-8.1 create mode 100644 share/vim/vim73/doc/vimdiff-it.1 create mode 100644 share/vim/vim73/doc/vimdiff-it.UTF-8.1 create mode 100644 share/vim/vim73/doc/vimdiff-pl.1 create mode 100644 share/vim/vim73/doc/vimdiff-pl.UTF-8.1 create mode 100644 share/vim/vim73/doc/vimdiff-ru.1 create mode 100644 share/vim/vim73/doc/vimdiff-ru.UTF-8.1 rename share/vim/{vim72 => vim73}/doc/vimdiff.1 (100%) rename share/vim/{vim72 => vim73}/doc/vimdiff.man (100%) create mode 100644 share/vim/vim73/doc/vimtutor-fr.1 create mode 100644 share/vim/vim73/doc/vimtutor-fr.UTF-8.1 create mode 100644 share/vim/vim73/doc/vimtutor-it.1 create mode 100644 share/vim/vim73/doc/vimtutor-it.UTF-8.1 create mode 100644 share/vim/vim73/doc/vimtutor-pl.1 create mode 100644 share/vim/vim73/doc/vimtutor-pl.UTF-8.1 rename share/vim/{vim72 => vim73}/doc/vimtutor-ru.1 (100%) rename share/vim/{vim72 => vim73}/doc/vimtutor-ru.UTF-8.1 (100%) create mode 100644 share/vim/vim73/doc/vimtutor.1 create mode 100644 share/vim/vim73/doc/vimtutor.man create mode 100644 share/vim/vim73/doc/visual.txt create mode 100644 share/vim/vim73/doc/windows.txt create mode 100644 share/vim/vim73/doc/workshop.txt create mode 100644 share/vim/vim73/doc/xxd-fr.1 create mode 100644 share/vim/vim73/doc/xxd-fr.UTF-8.1 create mode 100644 share/vim/vim73/doc/xxd-it.1 create mode 100644 share/vim/vim73/doc/xxd-it.UTF-8.1 create mode 100644 share/vim/vim73/doc/xxd-pl.1 create mode 100644 share/vim/vim73/doc/xxd-pl.UTF-8.1 rename share/vim/{vim72 => vim73}/doc/xxd-ru.1 (100%) rename share/vim/{vim72 => vim73}/doc/xxd-ru.UTF-8.1 (100%) rename share/vim/{vim72 => vim73}/doc/xxd.1 (100%) rename share/vim/{vim72 => vim73}/doc/xxd.man (100%) create mode 100644 share/vim/vim73/evim.vim create mode 100644 share/vim/vim73/filetype.vim rename share/vim/{vim72 => vim73}/ftoff.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/README.txt (100%) rename share/vim/{vim72 => vim73}/ftplugin/a2ps.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/aap.vim (100%) create mode 100644 share/vim/vim73/ftplugin/abaqus.vim rename share/vim/{vim72 => vim73}/ftplugin/ada.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/alsaconf.vim (100%) create mode 100644 share/vim/vim73/ftplugin/ant.vim rename share/vim/{vim72 => vim73}/ftplugin/arch.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/art.vim (100%) create mode 100644 share/vim/vim73/ftplugin/aspvbs.vim rename share/vim/{vim72 => vim73}/ftplugin/automake.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/bdf.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/bst.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/btm.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/c.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/calendar.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/cdrdaoconf.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/ch.vim (100%) create mode 100644 share/vim/vim73/ftplugin/changelog.vim rename share/vim/{vim72 => vim73}/ftplugin/cobol.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/conf.vim (100%) create mode 100644 share/vim/vim73/ftplugin/config.vim rename share/vim/{vim72 => vim73}/ftplugin/context.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/cpp.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/crm.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/cs.vim (100%) create mode 100644 share/vim/vim73/ftplugin/csc.vim create mode 100644 share/vim/vim73/ftplugin/csh.vim rename share/vim/{vim72 => vim73}/ftplugin/css.vim (100%) create mode 100644 share/vim/vim73/ftplugin/cucumber.vim rename share/vim/{vim72 => vim73}/ftplugin/cvsrc.vim (100%) create mode 100644 share/vim/vim73/ftplugin/debchangelog.vim create mode 100644 share/vim/vim73/ftplugin/debcontrol.vim rename share/vim/{vim72 => vim73}/ftplugin/denyhosts.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/dictconf.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/dictdconf.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/diff.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/dircolors.vim (100%) create mode 100644 share/vim/vim73/ftplugin/dosbatch.vim rename share/vim/{vim72 => vim73}/ftplugin/dosini.vim (100%) create mode 100644 share/vim/vim73/ftplugin/dtd.vim rename share/vim/{vim72 => vim73}/ftplugin/dtrace.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/elinks.vim (100%) create mode 100644 share/vim/vim73/ftplugin/eruby.vim rename share/vim/{vim72 => vim73}/ftplugin/eterm.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/fetchmail.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/flexwiki.vim (100%) create mode 100644 share/vim/vim73/ftplugin/fortran.vim rename share/vim/{vim72 => vim73}/ftplugin/framescript.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/fvwm.vim (100%) create mode 100644 share/vim/vim73/ftplugin/git.vim create mode 100644 share/vim/vim73/ftplugin/gitcommit.vim create mode 100644 share/vim/vim73/ftplugin/gitconfig.vim create mode 100644 share/vim/vim73/ftplugin/gitrebase.vim create mode 100644 share/vim/vim73/ftplugin/gitsendemail.vim rename share/vim/{vim72 => vim73}/ftplugin/gpg.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/group.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/grub.vim (100%) create mode 100644 share/vim/vim73/ftplugin/haml.vim rename share/vim/{vim72 => vim73}/ftplugin/hamster.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/haskell.vim (100%) create mode 100644 share/vim/vim73/ftplugin/help.vim rename share/vim/{vim72 => vim73}/ftplugin/hostconf.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/hostsaccess.vim (100%) create mode 100644 share/vim/vim73/ftplugin/html.vim rename share/vim/{vim72 => vim73}/ftplugin/htmldjango.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/indent.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/initex.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/ishd.vim (100%) create mode 100644 share/vim/vim73/ftplugin/java.vim rename share/vim/{vim72 => vim73}/ftplugin/javascript.vim (100%) create mode 100644 share/vim/vim73/ftplugin/jsp.vim rename share/vim/{vim72 => vim73}/ftplugin/kconfig.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/kwt.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/ld.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/lftp.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/libao.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/limits.vim (100%) create mode 100644 share/vim/vim73/ftplugin/liquid.vim rename share/vim/{vim72 => vim73}/ftplugin/lisp.vim (100%) create mode 100644 share/vim/vim73/ftplugin/logcheck.vim rename share/vim/{vim72 => vim73}/ftplugin/loginaccess.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/logindefs.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/logtalk.dict (100%) rename share/vim/{vim72 => vim73}/ftplugin/logtalk.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/lprolog.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/lua.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/m4.vim (100%) create mode 100644 share/vim/vim73/ftplugin/mail.vim rename share/vim/{vim72 => vim73}/ftplugin/mailaliases.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/mailcap.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/make.vim (100%) create mode 100644 share/vim/vim73/ftplugin/man.vim rename share/vim/{vim72 => vim73}/ftplugin/manconf.vim (100%) create mode 100644 share/vim/vim73/ftplugin/markdown.vim rename share/vim/{vim72 => vim73}/ftplugin/matlab.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/mf.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/modconf.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/mp.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/mplayerconf.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/mrxvtrc.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/msmessages.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/muttrc.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/nanorc.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/netrc.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/nsis.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/objc.vim (100%) create mode 100644 share/vim/vim73/ftplugin/ocaml.vim rename share/vim/{vim72 => vim73}/ftplugin/occam.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/pamconf.vim (100%) create mode 100644 share/vim/vim73/ftplugin/pascal.vim rename share/vim/{vim72 => vim73}/ftplugin/passwd.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/pdf.vim (100%) create mode 100644 share/vim/vim73/ftplugin/perl.vim create mode 100644 share/vim/vim73/ftplugin/perl6.vim create mode 100644 share/vim/vim73/ftplugin/php.vim rename share/vim/{vim72 => vim73}/ftplugin/pinfo.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/plaintex.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/postscr.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/procmail.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/prolog.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/protocols.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/pyrex.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/python.vim (100%) create mode 100644 share/vim/vim73/ftplugin/qf.vim rename share/vim/{vim72 => vim73}/ftplugin/quake.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/racc.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/readline.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/reva.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/rnc.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/rpl.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/rst.vim (100%) create mode 100644 share/vim/vim73/ftplugin/ruby.vim create mode 100644 share/vim/vim73/ftplugin/sass.vim rename share/vim/{vim72 => vim73}/ftplugin/scheme.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/screen.vim (100%) create mode 100644 share/vim/vim73/ftplugin/scss.vim rename share/vim/{vim72 => vim73}/ftplugin/sensors.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/services.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/setserial.vim (100%) create mode 100644 share/vim/vim73/ftplugin/sgml.vim create mode 100644 share/vim/vim73/ftplugin/sh.vim rename share/vim/{vim72 => vim73}/ftplugin/sieve.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/slpconf.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/slpreg.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/slpspi.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/spec.vim (100%) create mode 100644 share/vim/vim73/ftplugin/sql.vim rename share/vim/{vim72 => vim73}/ftplugin/sshconfig.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/sudoers.vim (100%) create mode 100644 share/vim/vim73/ftplugin/svg.vim rename share/vim/{vim72 => vim73}/ftplugin/sysctl.vim (100%) create mode 100644 share/vim/vim73/ftplugin/tcl.vim create mode 100644 share/vim/vim73/ftplugin/tcsh.vim rename share/vim/{vim72 => vim73}/ftplugin/terminfo.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/tex.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/udevconf.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/udevperm.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/udevrules.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/updatedb.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/vb.vim (100%) create mode 100644 share/vim/vim73/ftplugin/verilog.vim rename share/vim/{vim72 => vim73}/ftplugin/vhdl.vim (100%) create mode 100644 share/vim/vim73/ftplugin/vim.vim rename share/vim/{vim72 => vim73}/ftplugin/xdefaults.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/xf86conf.vim (100%) create mode 100644 share/vim/vim73/ftplugin/xhtml.vim rename share/vim/{vim72 => vim73}/ftplugin/xinetd.vim (100%) create mode 100644 share/vim/vim73/ftplugin/xml.vim rename share/vim/{vim72 => vim73}/ftplugin/xmodmap.vim (100%) create mode 100644 share/vim/vim73/ftplugin/xs.vim create mode 100644 share/vim/vim73/ftplugin/xsd.vim create mode 100644 share/vim/vim73/ftplugin/xslt.vim rename share/vim/{vim72 => vim73}/ftplugin/yaml.vim (100%) rename share/vim/{vim72 => vim73}/ftplugin/zsh.vim (100%) rename share/vim/{vim72 => vim73}/ftplugof.vim (100%) rename share/vim/{vim72 => vim73}/gvimrc_example.vim (100%) rename share/vim/{vim72 => vim73}/hi16-action-make.png (100%) rename share/vim/{vim72 => vim73}/hi22-action-make.png (100%) rename share/vim/{vim72 => vim73}/icons.info (100%) rename share/vim/{vim72 => vim73}/icons/README.txt (100%) rename share/vim/{vim72 => vim73}/icons/README.txt.info (100%) rename share/vim/{vim72 => vim73}/icons/Vim_32Colors.info (100%) rename share/vim/{vim72 => vim73}/icons/Vim_4ColorsLace.info (100%) rename share/vim/{vim72 => vim73}/icons/Vim_8Colors.info (100%) rename share/vim/{vim72 => vim73}/icons/Vim_8ColorsLace.info (100%) rename share/vim/{vim72 => vim73}/indent.vim (100%) rename share/vim/{vim72 => vim73}/indent/README.txt (100%) rename share/vim/{vim72 => vim73}/indent/aap.vim (100%) rename share/vim/{vim72 => vim73}/indent/ada.vim (100%) rename share/vim/{vim72 => vim73}/indent/ant.vim (100%) rename share/vim/{vim72 => vim73}/indent/automake.vim (100%) rename share/vim/{vim72 => vim73}/indent/awk.vim (100%) rename share/vim/{vim72 => vim73}/indent/bib.vim (100%) rename share/vim/{vim72 => vim73}/indent/bst.vim (100%) rename share/vim/{vim72 => vim73}/indent/c.vim (100%) rename share/vim/{vim72 => vim73}/indent/cdl.vim (100%) rename share/vim/{vim72 => vim73}/indent/ch.vim (100%) create mode 100644 share/vim/vim73/indent/chaiscript.vim rename share/vim/{vim72 => vim73}/indent/changelog.vim (100%) create mode 100644 share/vim/vim73/indent/cmake.vim rename share/vim/{vim72 => vim73}/indent/cobol.vim (100%) rename share/vim/{vim72 => vim73}/indent/config.vim (100%) create mode 100644 share/vim/vim73/indent/cpp.vim rename share/vim/{vim72 => vim73}/indent/cs.vim (100%) rename share/vim/{vim72 => vim73}/indent/css.vim (100%) create mode 100644 share/vim/vim73/indent/cucumber.vim create mode 100644 share/vim/vim73/indent/cuda.vim rename share/vim/{vim72 => vim73}/indent/d.vim (100%) rename share/vim/{vim72 => vim73}/indent/dictconf.vim (100%) rename share/vim/{vim72 => vim73}/indent/dictdconf.vim (100%) rename share/vim/{vim72 => vim73}/indent/docbk.vim (100%) rename share/vim/{vim72 => vim73}/indent/dtd.vim (100%) rename share/vim/{vim72 => vim73}/indent/dtrace.vim (100%) rename share/vim/{vim72 => vim73}/indent/dylan.vim (100%) rename share/vim/{vim72 => vim73}/indent/eiffel.vim (100%) rename share/vim/{vim72 => vim73}/indent/erlang.vim (100%) create mode 100644 share/vim/vim73/indent/eruby.vim rename share/vim/{vim72 => vim73}/indent/eterm.vim (100%) create mode 100644 share/vim/vim73/indent/fortran.vim rename share/vim/{vim72 => vim73}/indent/framescript.vim (100%) create mode 100644 share/vim/vim73/indent/gitconfig.vim create mode 100644 share/vim/vim73/indent/haml.vim rename share/vim/{vim72 => vim73}/indent/hamster.vim (100%) rename share/vim/{vim72 => vim73}/indent/html.vim (100%) rename share/vim/{vim72 => vim73}/indent/htmldjango.vim (100%) rename share/vim/{vim72 => vim73}/indent/idlang.vim (100%) rename share/vim/{vim72 => vim73}/indent/ishd.vim (100%) rename share/vim/{vim72 => vim73}/indent/java.vim (100%) create mode 100644 share/vim/vim73/indent/javascript.vim rename share/vim/{vim72 => vim73}/indent/jsp.vim (100%) rename share/vim/{vim72 => vim73}/indent/ld.vim (100%) create mode 100644 share/vim/vim73/indent/lifelines.vim create mode 100644 share/vim/vim73/indent/liquid.vim rename share/vim/{vim72 => vim73}/indent/lisp.vim (100%) rename share/vim/{vim72 => vim73}/indent/logtalk.vim (100%) rename share/vim/{vim72 => vim73}/indent/lua.vim (100%) create mode 100644 share/vim/vim73/indent/mail.vim rename share/vim/{vim72 => vim73}/indent/make.vim (100%) rename share/vim/{vim72 => vim73}/indent/matlab.vim (100%) rename share/vim/{vim72 => vim73}/indent/mma.vim (100%) rename share/vim/{vim72 => vim73}/indent/mp.vim (100%) rename share/vim/{vim72 => vim73}/indent/objc.vim (100%) rename share/vim/{vim72 => vim73}/indent/ocaml.vim (100%) rename share/vim/{vim72 => vim73}/indent/occam.vim (100%) rename share/vim/{vim72 => vim73}/indent/pascal.vim (100%) create mode 100644 share/vim/vim73/indent/perl.vim create mode 100644 share/vim/vim73/indent/perl6.vim create mode 100644 share/vim/vim73/indent/php.vim rename share/vim/{vim72 => vim73}/indent/postscr.vim (100%) rename share/vim/{vim72 => vim73}/indent/pov.vim (100%) rename share/vim/{vim72 => vim73}/indent/prolog.vim (100%) rename share/vim/{vim72 => vim73}/indent/pyrex.vim (100%) rename share/vim/{vim72 => vim73}/indent/python.vim (100%) rename share/vim/{vim72 => vim73}/indent/readline.vim (100%) rename share/vim/{vim72 => vim73}/indent/rpl.vim (100%) rename share/vim/{vim72 => vim73}/indent/rst.vim (100%) create mode 100644 share/vim/vim73/indent/ruby.vim create mode 100644 share/vim/vim73/indent/sass.vim rename share/vim/{vim72 => vim73}/indent/scheme.vim (100%) create mode 100644 share/vim/vim73/indent/scss.vim rename share/vim/{vim72 => vim73}/indent/sdl.vim (100%) create mode 100644 share/vim/vim73/indent/sh.vim rename share/vim/{vim72 => vim73}/indent/sml.vim (100%) rename share/vim/{vim72 => vim73}/indent/sql.vim (100%) rename share/vim/{vim72 => vim73}/indent/sqlanywhere.vim (100%) rename share/vim/{vim72 => vim73}/indent/tcl.vim (100%) rename share/vim/{vim72 => vim73}/indent/tcsh.vim (100%) create mode 100644 share/vim/vim73/indent/tf.vim rename share/vim/{vim72 => vim73}/indent/tilde.vim (100%) create mode 100644 share/vim/vim73/indent/vb.vim rename share/vim/{vim72 => vim73}/indent/verilog.vim (100%) create mode 100644 share/vim/vim73/indent/vhdl.vim rename share/vim/{vim72 => vim73}/indent/vim.vim (100%) rename share/vim/{vim72 => vim73}/indent/xf86conf.vim (100%) rename share/vim/{vim72 => vim73}/indent/xhtml.vim (100%) rename share/vim/{vim72 => vim73}/indent/xinetd.vim (100%) create mode 100644 share/vim/vim73/indent/xml.vim rename share/vim/{vim72 => vim73}/indent/xsd.vim (100%) rename share/vim/{vim72 => vim73}/indent/xslt.vim (100%) rename share/vim/{vim72 => vim73}/indent/yacc.vim (100%) rename share/vim/{vim72 => vim73}/indent/zsh.vim (100%) rename share/vim/{vim72 => vim73}/indoff.vim (100%) rename share/vim/{vim72 => vim73}/keymap/README.txt (100%) rename share/vim/{vim72 => vim73}/keymap/accents.vim (100%) rename share/vim/{vim72 => vim73}/keymap/arabic.vim (100%) rename share/vim/{vim72 => vim73}/keymap/arabic_utf-8.vim (100%) create mode 100644 share/vim/vim73/keymap/bulgarian-bds.vim create mode 100644 share/vim/vim73/keymap/bulgarian-phonetic.vim rename share/vim/{vim72 => vim73}/keymap/canfr-win.vim (100%) rename share/vim/{vim72 => vim73}/keymap/croatian.vim (100%) rename share/vim/{vim72 => vim73}/keymap/croatian_cp1250.vim (100%) rename share/vim/{vim72 => vim73}/keymap/croatian_iso-8859-2.vim (100%) rename share/vim/{vim72 => vim73}/keymap/croatian_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/czech.vim (100%) create mode 100644 share/vim/vim73/keymap/czech_utf-8.vim create mode 100644 share/vim/vim73/keymap/dvorak.vim rename share/vim/{vim72 => vim73}/keymap/esperanto.vim (100%) rename share/vim/{vim72 => vim73}/keymap/esperanto_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/greek.vim (100%) rename share/vim/{vim72 => vim73}/keymap/greek_cp1253.vim (100%) rename share/vim/{vim72 => vim73}/keymap/greek_cp737.vim (100%) rename share/vim/{vim72 => vim73}/keymap/greek_iso-8859-7.vim (100%) rename share/vim/{vim72 => vim73}/keymap/greek_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/hebrew.vim (100%) rename share/vim/{vim72 => vim73}/keymap/hebrew_cp1255.vim (100%) rename share/vim/{vim72 => vim73}/keymap/hebrew_iso-8859-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/hebrew_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/hebrewp.vim (100%) rename share/vim/{vim72 => vim73}/keymap/hebrewp_cp1255.vim (100%) rename share/vim/{vim72 => vim73}/keymap/hebrewp_iso-8859-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/hebrewp_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/kana.vim (100%) rename share/vim/{vim72 => vim73}/keymap/lithuanian-baltic.vim (100%) rename share/vim/{vim72 => vim73}/keymap/magyar_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/mongolian_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/persian-iranian_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/persian.vim (100%) rename share/vim/{vim72 => vim73}/keymap/pinyin.vim (100%) rename share/vim/{vim72 => vim73}/keymap/polish-slash.vim (100%) rename share/vim/{vim72 => vim73}/keymap/polish-slash_cp1250.vim (100%) rename share/vim/{vim72 => vim73}/keymap/polish-slash_cp852.vim (100%) rename share/vim/{vim72 => vim73}/keymap/polish-slash_iso-8859-2.vim (100%) rename share/vim/{vim72 => vim73}/keymap/polish-slash_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/russian-dvorak.vim (100%) rename share/vim/{vim72 => vim73}/keymap/russian-jcuken.vim (100%) rename share/vim/{vim72 => vim73}/keymap/russian-jcukenwin.vim (100%) rename share/vim/{vim72 => vim73}/keymap/russian-yawerty.vim (100%) rename share/vim/{vim72 => vim73}/keymap/serbian-latin.vim (100%) rename share/vim/{vim72 => vim73}/keymap/serbian-latin_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/serbian.vim (100%) rename share/vim/{vim72 => vim73}/keymap/serbian_cp1250.vim (100%) rename share/vim/{vim72 => vim73}/keymap/serbian_cp1251.vim (100%) rename share/vim/{vim72 => vim73}/keymap/serbian_iso-8859-2.vim (100%) rename share/vim/{vim72 => vim73}/keymap/serbian_iso-8859-5.vim (100%) rename share/vim/{vim72 => vim73}/keymap/serbian_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/sinhala-phonetic_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/sinhala.vim (100%) rename share/vim/{vim72 => vim73}/keymap/slovak.vim (100%) rename share/vim/{vim72 => vim73}/keymap/slovak_cp1250.vim (100%) rename share/vim/{vim72 => vim73}/keymap/slovak_iso-8859-2.vim (100%) rename share/vim/{vim72 => vim73}/keymap/slovak_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/tamil_tscii.vim (100%) rename share/vim/{vim72 => vim73}/keymap/thaana-phonetic_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/keymap/thaana.vim (100%) rename share/vim/{vim72 => vim73}/keymap/ukrainian-dvorak.vim (100%) rename share/vim/{vim72 => vim73}/keymap/ukrainian-jcuken.vim (100%) rename share/vim/{vim72 => vim73}/keymap/vietnamese-viqr_utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/README.txt (100%) rename share/vim/{vim72 => vim73}/lang/menu_af.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_af.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_af_af.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_af_af.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ca.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ca.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ca_es.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ca_es.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_chinese(gb)_gb.936.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_chinese(taiwan)_taiwan.950.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_chinese_gb.936.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_chinese_taiwan.950.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_cs.cp1250.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_cs.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_cs_cz.cp1250.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_cs_cz.iso_8859-2.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_cs_cz.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_czech_czech_republic.1250.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_czech_czech_republic.1252.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_czech_czech_republic.ascii.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_de.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_de.utf-8.vim (100%) create mode 100644 share/vim/vim73/lang/menu_de_de.latin1.vim rename share/vim/{vim72 => vim73}/lang/menu_de_de.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_en_gb.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_en_gb.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_english_united_kingdom.1252.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_english_united_kingdom.ascii.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_eo.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_eo_eo.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_eo_xx.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_es.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_es.utf-8.vim (100%) create mode 100644 share/vim/vim73/lang/menu_es_es.latin1.vim rename share/vim/{vim72 => vim73}/lang/menu_es_es.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_fi.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_fi.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_fi_fi.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_fi_fi.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_finnish_finland.1252.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_fr.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_fr.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_fr_fr.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_fr_fr.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_french_france.1252.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_german_germany.1252.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_hu.iso_8859-2.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_hu.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_hu_hu.iso_8859-2.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_hu_hu.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_it.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_it.utf-8.vim (100%) create mode 100644 share/vim/vim73/lang/menu_it_it.latin1.vim rename share/vim/{vim72 => vim73}/lang/menu_it_it.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_italian_italy.1252.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ja.cp932.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ja.euc-jp.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ja.eucjp.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ja.ujis.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ja.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ja_jp.cp932.vim (100%) create mode 100644 share/vim/vim73/lang/menu_ja_jp.euc-jp.vim rename share/vim/{vim72 => vim73}/lang/menu_ja_jp.eucjp.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ja_jp.ujis.vim (100%) create mode 100644 share/vim/vim73/lang/menu_ja_jp.utf-8.vim create mode 100644 share/vim/vim73/lang/menu_japanese_japan.932.vim rename share/vim/{vim72 => vim73}/lang/menu_ko.utf-8.vim (100%) create mode 100644 share/vim/vim73/lang/menu_ko_kr.euckr.vim create mode 100644 share/vim/vim73/lang/menu_ko_kr.utf-8.vim create mode 100644 share/vim/vim73/lang/menu_ko_kr.vim rename share/vim/{vim72 => vim73}/lang/menu_nl.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_nl.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_nl_nl.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_nl_nl.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_no.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_no.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_no_no.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_no_no.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_pl.cp1250.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_pl_pl.cp1250.vim (100%) create mode 100644 share/vim/vim73/lang/menu_pl_pl.iso_8859-2.vim create mode 100644 share/vim/vim73/lang/menu_pl_pl.utf-8.vim create mode 100644 share/vim/vim73/lang/menu_polish_poland.1250.vim rename share/vim/{vim72 => vim73}/lang/menu_pt_br.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_pt_br.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_pt_br.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_pt_pt.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_pt_pt.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_pt_pt.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ru.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ru_ru.koi8-r.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ru_ru.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_ru_ru.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_sk.cp1250.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_sk_sk.1250.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_sk_sk.cp1250.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_sk_sk.iso_8859-2.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_sk_sk.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_sl_si.cp1250.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_sl_si.latin2.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_sl_si.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_slovak_slovak_republic.1250.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_spanish_spain.850.vim (100%) create mode 100644 share/vim/vim73/lang/menu_sr.utf-8.vim rename share/vim/{vim72/lang/menu_sr_yu.ascii.vim => vim73/lang/menu_sr_rs.ascii.vim} (100%) rename share/vim/{vim72/lang/menu_sr_yu.iso_8859-2.vim => vim73/lang/menu_sr_rs.iso_8859-2.vim} (100%) rename share/vim/{vim72/lang/menu_sr_yu.iso_8859-5.vim => vim73/lang/menu_sr_rs.iso_8859-5.vim} (100%) create mode 100644 share/vim/vim73/lang/menu_sr_rs.utf-8.vim create mode 100644 share/vim/vim73/lang/menu_sr_yu.ascii.vim create mode 100644 share/vim/vim73/lang/menu_sr_yu.iso_8859-2.vim create mode 100644 share/vim/vim73/lang/menu_sr_yu.iso_8859-5.vim create mode 100644 share/vim/vim73/lang/menu_sr_yu.utf-8.vim rename share/vim/{vim72 => vim73}/lang/menu_sv.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_sv.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_sv_se.latin1.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_sv_se.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_uk_ua.cp1251.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_uk_ua.koi8-u.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_vi_vn.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh.big5.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh.cp936.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh.cp950.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh.gb2312.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh_cn.18030.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh_cn.cp936.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh_cn.gb2312.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh_cn.gbk.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh_cn.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh_tw.big5.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh_tw.cp950.vim (100%) rename share/vim/{vim72 => vim73}/lang/menu_zh_tw.utf-8.vim (100%) rename share/vim/{vim72 => vim73}/macmap.vim (100%) rename share/vim/{vim72 => vim73}/macros.info (100%) rename share/vim/{vim72 => vim73}/macros/README.txt (100%) rename share/vim/{vim72 => vim73}/macros/README.txt.info (100%) rename share/vim/{vim72 => vim73}/macros/dvorak (100%) rename share/vim/{vim72 => vim73}/macros/editexisting.vim (100%) rename share/vim/{vim72 => vim73}/macros/hanoi.info (100%) rename share/vim/{vim72 => vim73}/macros/hanoi/click.me (100%) rename share/vim/{vim72 => vim73}/macros/hanoi/click.me.info (100%) rename share/vim/{vim72 => vim73}/macros/hanoi/hanoi.vim (100%) rename share/vim/{vim72 => vim73}/macros/hanoi/poster (100%) rename share/vim/{vim72 => vim73}/macros/hanoi/poster.info (100%) rename share/vim/{vim72 => vim73}/macros/justify.vim (100%) rename share/vim/{vim72 => vim73}/macros/less.sh (100%) rename share/vim/{vim72 => vim73}/macros/less.vim (100%) rename share/vim/{vim72 => vim73}/macros/life/click.me (100%) rename share/vim/{vim72 => vim73}/macros/life/click.me.info (100%) rename share/vim/{vim72 => vim73}/macros/life/life.vim (100%) rename share/vim/{vim72 => vim73}/macros/matchit.txt (100%) create mode 100644 share/vim/vim73/macros/matchit.vim rename share/vim/{vim72 => vim73}/macros/maze.info (100%) rename share/vim/{vim72 => vim73}/macros/maze/Makefile (100%) rename share/vim/{vim72 => vim73}/macros/maze/README.txt (100%) rename share/vim/{vim72 => vim73}/macros/maze/README.txt.info (100%) rename share/vim/{vim72 => vim73}/macros/maze/main.aap (100%) rename share/vim/{vim72 => vim73}/macros/maze/maze.c (100%) rename share/vim/{vim72 => vim73}/macros/maze/maze_5.78 (100%) rename share/vim/{vim72 => vim73}/macros/maze/maze_5.78.info (100%) rename share/vim/{vim72 => vim73}/macros/maze/maze_mac (100%) rename share/vim/{vim72 => vim73}/macros/maze/mazeansi.c (100%) rename share/vim/{vim72 => vim73}/macros/maze/mazeclean.c (100%) rename share/vim/{vim72 => vim73}/macros/maze/poster (100%) rename share/vim/{vim72 => vim73}/macros/maze/poster.info (100%) rename share/vim/{vim72 => vim73}/macros/shellmenu.vim (100%) rename share/vim/{vim72 => vim73}/macros/swapmous.vim (100%) rename share/vim/{vim72 => vim73}/macros/urm.info (100%) rename share/vim/{vim72 => vim73}/macros/urm/README.txt (100%) rename share/vim/{vim72 => vim73}/macros/urm/README.txt.info (100%) rename share/vim/{vim72 => vim73}/macros/urm/examples (100%) rename share/vim/{vim72 => vim73}/macros/urm/urm (100%) rename share/vim/{vim72 => vim73}/macros/urm/urm.vim (100%) create mode 100644 share/vim/vim73/makemenu.vim create mode 100644 share/vim/vim73/menu.vim rename share/vim/{vim72 => vim73}/mswin.vim (100%) create mode 100644 share/vim/vim73/optwin.vim rename share/vim/{vim72 => vim73}/plugin/README.txt (100%) create mode 100644 share/vim/vim73/plugin/getscriptPlugin.vim create mode 100644 share/vim/vim73/plugin/gzip.vim create mode 100644 share/vim/vim73/plugin/matchparen.vim create mode 100644 share/vim/vim73/plugin/netrwPlugin.vim create mode 100644 share/vim/vim73/plugin/rrhelper.vim rename share/vim/{vim72 => vim73}/plugin/spellfile.vim (100%) create mode 100644 share/vim/vim73/plugin/tarPlugin.vim create mode 100644 share/vim/vim73/plugin/tohtml.vim create mode 100644 share/vim/vim73/plugin/vimballPlugin.vim create mode 100644 share/vim/vim73/plugin/zipPlugin.vim rename share/vim/{vim72 => vim73}/print/ascii.ps (100%) rename share/vim/{vim72 => vim73}/print/cidfont.ps (100%) rename share/vim/{vim72 => vim73}/print/cns_roman.ps (100%) rename share/vim/{vim72 => vim73}/print/cp1250.ps (100%) rename share/vim/{vim72 => vim73}/print/cp1251.ps (100%) rename share/vim/{vim72 => vim73}/print/cp1252.ps (100%) rename share/vim/{vim72 => vim73}/print/cp1253.ps (100%) rename share/vim/{vim72 => vim73}/print/cp1254.ps (100%) rename share/vim/{vim72 => vim73}/print/cp1255.ps (100%) rename share/vim/{vim72 => vim73}/print/cp1257.ps (100%) rename share/vim/{vim72 => vim73}/print/dec-mcs.ps (100%) rename share/vim/{vim72 => vim73}/print/ebcdic-uk.ps (100%) rename share/vim/{vim72 => vim73}/print/gb_roman.ps (100%) rename share/vim/{vim72 => vim73}/print/hp-roman8.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-10.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-11.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-13.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-14.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-15.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-2.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-3.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-4.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-5.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-7.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-8.ps (100%) rename share/vim/{vim72 => vim73}/print/iso-8859-9.ps (100%) rename share/vim/{vim72 => vim73}/print/jis_roman.ps (100%) rename share/vim/{vim72 => vim73}/print/koi8-r.ps (100%) rename share/vim/{vim72 => vim73}/print/koi8-u.ps (100%) rename share/vim/{vim72 => vim73}/print/ks_roman.ps (100%) rename share/vim/{vim72 => vim73}/print/latin1.ps (100%) rename share/vim/{vim72 => vim73}/print/mac-roman.ps (100%) rename share/vim/{vim72 => vim73}/print/prolog.ps (100%) rename share/vim/{vim72 => vim73}/rgb.txt (100%) create mode 100644 share/vim/vim73/scripts.vim create mode 100644 share/vim/vim73/spell/README.txt create mode 100644 share/vim/vim73/spell/README_en.txt rename share/vim/{vim72 => vim73}/spell/af/af_ZA.diff (100%) rename share/vim/{vim72 => vim73}/spell/af/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/am/am_ET.diff (100%) rename share/vim/{vim72 => vim73}/spell/am/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/bg/bg_BG.diff (100%) create mode 100644 share/vim/vim73/spell/bg/main.aap create mode 100644 share/vim/vim73/spell/br/br_FR.diff create mode 100644 share/vim/vim73/spell/br/main.aap rename share/vim/{vim72 => vim73}/spell/ca/ca_ES.diff (100%) create mode 100644 share/vim/vim73/spell/ca/main.aap create mode 100644 share/vim/vim73/spell/check/check_aa.aff create mode 100644 share/vim/vim73/spell/check/check_aa.dic create mode 100644 share/vim/vim73/spell/check/check_bb.aff create mode 100644 share/vim/vim73/spell/check/check_bb.dic create mode 100644 share/vim/vim73/spell/check/main.aap create mode 100644 share/vim/vim73/spell/check_locales.vim rename share/vim/{vim72 => vim73}/spell/cleanadd.vim (100%) rename share/vim/{vim72 => vim73}/spell/cs/cs_CZ.diff (100%) rename share/vim/{vim72 => vim73}/spell/cs/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/cy/cy_GB.diff (100%) create mode 100644 share/vim/vim73/spell/cy/main.aap rename share/vim/{vim72 => vim73}/spell/da/da_DK.diff (100%) rename share/vim/{vim72 => vim73}/spell/da/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/de/de_19.diff (100%) rename share/vim/{vim72 => vim73}/spell/de/de_20.diff (100%) rename share/vim/{vim72 => vim73}/spell/de/de_AT.diff (100%) rename share/vim/{vim72 => vim73}/spell/de/de_CH.diff (100%) rename share/vim/{vim72 => vim73}/spell/de/de_DE.diff (100%) create mode 100644 share/vim/vim73/spell/de/main.aap rename share/vim/{vim72 => vim73}/spell/el/el_GR.diff (100%) rename share/vim/{vim72 => vim73}/spell/el/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/en.ascii.spl (100%) rename share/vim/{vim72 => vim73}/spell/en.ascii.sug (100%) rename share/vim/{vim72 => vim73}/spell/en.latin1.spl (100%) rename share/vim/{vim72 => vim73}/spell/en.latin1.sug (100%) rename share/vim/{vim72 => vim73}/spell/en.utf-8.spl (100%) rename share/vim/{vim72 => vim73}/spell/en.utf-8.sug (100%) rename share/vim/{vim72 => vim73}/spell/en/en_AU.diff (100%) rename share/vim/{vim72 => vim73}/spell/en/en_CA.diff (100%) rename share/vim/{vim72 => vim73}/spell/en/en_GB.diff (100%) rename share/vim/{vim72 => vim73}/spell/en/en_NZ.diff (100%) rename share/vim/{vim72 => vim73}/spell/en/en_US.diff (100%) rename share/vim/{vim72 => vim73}/spell/en/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/eo/eo_l3.diff (100%) create mode 100644 share/vim/vim73/spell/eo/main.aap rename share/vim/{vim72 => vim73}/spell/es/es_ES.diff (100%) create mode 100644 share/vim/vim73/spell/es/es_MX.diff create mode 100644 share/vim/vim73/spell/es/main.aap rename share/vim/{vim72/spell/fixdup => vim73/spell/fixdup.vim} (100%) rename share/vim/{vim72 => vim73}/spell/fo/fo_FO.diff (100%) rename share/vim/{vim72 => vim73}/spell/fo/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/fr/fr_FR.diff (100%) create mode 100644 share/vim/vim73/spell/fr/main.aap rename share/vim/{vim72 => vim73}/spell/ga/ga_IE.diff (100%) rename share/vim/{vim72 => vim73}/spell/ga/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/gd/gd_GB.diff (100%) create mode 100644 share/vim/vim73/spell/gd/main.aap rename share/vim/{vim72 => vim73}/spell/gl/gl_ES.diff (100%) rename share/vim/{vim72 => vim73}/spell/gl/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/he.vim (100%) rename share/vim/{vim72 => vim73}/spell/he/he_IL.diff (100%) rename share/vim/{vim72 => vim73}/spell/he/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/hr/hr_HR.diff (100%) rename share/vim/{vim72 => vim73}/spell/hr/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/hu/hu_HU.diff (100%) rename share/vim/{vim72 => vim73}/spell/hu/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/id/id_ID.diff (100%) rename share/vim/{vim72 => vim73}/spell/id/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/it/it_IT.diff (100%) rename share/vim/{vim72 => vim73}/spell/it/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/ku/ku_TR.diff (100%) create mode 100644 share/vim/vim73/spell/ku/main.aap rename share/vim/{vim72 => vim73}/spell/la/la.diff (100%) create mode 100644 share/vim/vim73/spell/la/main.aap rename share/vim/{vim72 => vim73}/spell/lt/lt_LT.diff (100%) rename share/vim/{vim72 => vim73}/spell/lt/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/lv/lv_LV.diff (100%) create mode 100644 share/vim/vim73/spell/lv/main.aap create mode 100644 share/vim/vim73/spell/main.aap rename share/vim/{vim72 => vim73}/spell/mg/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/mg/mg_MG.diff (100%) rename share/vim/{vim72 => vim73}/spell/mi/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/mi/mi_NZ.diff (100%) create mode 100644 share/vim/vim73/spell/ms/main.aap rename share/vim/{vim72 => vim73}/spell/ms/ms_MY.diff (100%) create mode 100644 share/vim/vim73/spell/nb/main.aap rename share/vim/{vim72 => vim73}/spell/nb/nb_NO.diff (100%) create mode 100644 share/vim/vim73/spell/nl/main.aap create mode 100644 share/vim/vim73/spell/nl/nl_NL.diff create mode 100644 share/vim/vim73/spell/nn/main.aap rename share/vim/{vim72 => vim73}/spell/nn/nn_NO.diff (100%) rename share/vim/{vim72 => vim73}/spell/ny/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/ny/ny_MW.diff (100%) rename share/vim/{vim72 => vim73}/spell/pl/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/pl/pl_PL.diff (100%) create mode 100644 share/vim/vim73/spell/pt/main.aap create mode 100644 share/vim/vim73/spell/pt/pt_BR.diff create mode 100644 share/vim/vim73/spell/pt/pt_PT.diff rename share/vim/{vim72 => vim73}/spell/ro/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/ro/ro_RO.diff (100%) rename share/vim/{vim72 => vim73}/spell/ru/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/ru/ru_RU.diff (100%) rename share/vim/{vim72 => vim73}/spell/ru/ru_YO.diff (100%) rename share/vim/{vim72 => vim73}/spell/rw/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/rw/rw_RW.diff (100%) rename share/vim/{vim72 => vim73}/spell/sk/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/sk/sk_SK.diff (100%) rename share/vim/{vim72 => vim73}/spell/sl/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/sl/sl_SI.diff (100%) create mode 100644 share/vim/vim73/spell/sv/main.aap create mode 100644 share/vim/vim73/spell/sv/sv_SE.diff rename share/vim/{vim72 => vim73}/spell/sw/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/sw/sw_KE.diff (100%) create mode 100644 share/vim/vim73/spell/tet/main.aap create mode 100644 share/vim/vim73/spell/tet/tet_ID.diff rename share/vim/{vim72 => vim73}/spell/th/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/th/th.diff (100%) rename share/vim/{vim72 => vim73}/spell/tl/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/tl/tl_PH.diff (100%) rename share/vim/{vim72 => vim73}/spell/tn/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/tn/tn_ZA.diff (100%) rename share/vim/{vim72 => vim73}/spell/uk/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/uk/uk_UA.diff (100%) rename share/vim/{vim72 => vim73}/spell/yi.vim (100%) rename share/vim/{vim72 => vim73}/spell/yi/README.txt (100%) rename share/vim/{vim72 => vim73}/spell/yi/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/yi/yi.diff (100%) rename share/vim/{vim72 => vim73}/spell/yi/yi_tr.diff (100%) rename share/vim/{vim72 => vim73}/spell/zu/main.aap (100%) rename share/vim/{vim72 => vim73}/spell/zu/zu_ZA.diff (100%) create mode 100644 share/vim/vim73/synmenu.vim create mode 100644 share/vim/vim73/syntax/2html.vim rename share/vim/{vim72 => vim73}/syntax/README.txt (100%) rename share/vim/{vim72 => vim73}/syntax/a2ps.vim (100%) rename share/vim/{vim72 => vim73}/syntax/a65.vim (100%) rename share/vim/{vim72 => vim73}/syntax/aap.vim (100%) rename share/vim/{vim72 => vim73}/syntax/abap.vim (100%) rename share/vim/{vim72 => vim73}/syntax/abaqus.vim (100%) rename share/vim/{vim72 => vim73}/syntax/abc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/abel.vim (100%) rename share/vim/{vim72 => vim73}/syntax/acedb.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ada.vim (100%) rename share/vim/{vim72 => vim73}/syntax/aflex.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ahdl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/alsaconf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/amiga.vim (100%) rename share/vim/{vim72 => vim73}/syntax/aml.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ampl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ant.vim (100%) rename share/vim/{vim72 => vim73}/syntax/antlr.vim (100%) rename share/vim/{vim72 => vim73}/syntax/apache.vim (100%) rename share/vim/{vim72 => vim73}/syntax/apachestyle.vim (100%) rename share/vim/{vim72 => vim73}/syntax/arch.vim (100%) rename share/vim/{vim72 => vim73}/syntax/art.vim (100%) create mode 100644 share/vim/vim73/syntax/asm.vim rename share/vim/{vim72 => vim73}/syntax/asm68k.vim (100%) rename share/vim/{vim72 => vim73}/syntax/asmh8300.vim (100%) rename share/vim/{vim72 => vim73}/syntax/asn.vim (100%) rename share/vim/{vim72 => vim73}/syntax/aspperl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/aspvbs.vim (100%) rename share/vim/{vim72 => vim73}/syntax/asterisk.vim (100%) rename share/vim/{vim72 => vim73}/syntax/asteriskvm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/atlas.vim (100%) rename share/vim/{vim72 => vim73}/syntax/autohotkey.vim (100%) rename share/vim/{vim72 => vim73}/syntax/autoit.vim (100%) rename share/vim/{vim72 => vim73}/syntax/automake.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ave.vim (100%) rename share/vim/{vim72 => vim73}/syntax/awk.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ayacc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/b.vim (100%) rename share/vim/{vim72 => vim73}/syntax/baan.vim (100%) rename share/vim/{vim72 => vim73}/syntax/basic.vim (100%) rename share/vim/{vim72 => vim73}/syntax/bc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/bdf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/bib.vim (100%) rename share/vim/{vim72 => vim73}/syntax/bindzone.vim (100%) rename share/vim/{vim72 => vim73}/syntax/blank.vim (100%) rename share/vim/{vim72 => vim73}/syntax/bst.vim (100%) rename share/vim/{vim72 => vim73}/syntax/btm.vim (100%) create mode 100644 share/vim/vim73/syntax/bzr.vim create mode 100644 share/vim/vim73/syntax/c.vim create mode 100644 share/vim/vim73/syntax/cabal.vim rename share/vim/{vim72 => vim73}/syntax/calendar.vim (100%) rename share/vim/{vim72 => vim73}/syntax/catalog.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cdl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cdrdaoconf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cdrtoc.vim (100%) create mode 100644 share/vim/vim73/syntax/cf.vim rename share/vim/{vim72 => vim73}/syntax/cfg.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ch.vim (100%) create mode 100644 share/vim/vim73/syntax/chaiscript.vim rename share/vim/{vim72 => vim73}/syntax/change.vim (100%) rename share/vim/{vim72 => vim73}/syntax/changelog.vim (100%) rename share/vim/{vim72 => vim73}/syntax/chaskell.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cheetah.vim (100%) rename share/vim/{vim72 => vim73}/syntax/chill.vim (100%) rename share/vim/{vim72 => vim73}/syntax/chordpro.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/clean.vim (100%) rename share/vim/{vim72 => vim73}/syntax/clipper.vim (100%) create mode 100644 share/vim/vim73/syntax/cmake.vim rename share/vim/{vim72 => vim73}/syntax/cmusrc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cobol.vim (100%) rename share/vim/{vim72 => vim73}/syntax/coco.vim (100%) rename share/vim/{vim72 => vim73}/syntax/colortest.vim (100%) rename share/vim/{vim72 => vim73}/syntax/conaryrecipe.vim (100%) rename share/vim/{vim72 => vim73}/syntax/conf.vim (100%) create mode 100644 share/vim/vim73/syntax/config.vim rename share/vim/{vim72 => vim73}/syntax/context.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cpp.vim (100%) rename share/vim/{vim72 => vim73}/syntax/crm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/crontab.vim (100%) create mode 100644 share/vim/vim73/syntax/cs.vim rename share/vim/{vim72 => vim73}/syntax/csc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/csh.vim (100%) rename share/vim/{vim72 => vim73}/syntax/csp.vim (100%) create mode 100644 share/vim/vim73/syntax/css.vim rename share/vim/{vim72 => vim73}/syntax/cterm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ctrlh.vim (100%) create mode 100644 share/vim/vim73/syntax/cucumber.vim rename share/vim/{vim72 => vim73}/syntax/cuda.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cupl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cuplsim.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cvs.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cvsrc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cweb.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cynlib.vim (100%) rename share/vim/{vim72 => vim73}/syntax/cynpp.vim (100%) create mode 100644 share/vim/vim73/syntax/d.vim create mode 100644 share/vim/vim73/syntax/datascript.vim rename share/vim/{vim72 => vim73}/syntax/dcd.vim (100%) rename share/vim/{vim72 => vim73}/syntax/dcl.vim (100%) create mode 100644 share/vim/vim73/syntax/debchangelog.vim create mode 100644 share/vim/vim73/syntax/debcontrol.vim create mode 100644 share/vim/vim73/syntax/debsources.vim rename share/vim/{vim72 => vim73}/syntax/def.vim (100%) rename share/vim/{vim72 => vim73}/syntax/denyhosts.vim (100%) rename share/vim/{vim72 => vim73}/syntax/desc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/desktop.vim (100%) rename share/vim/{vim72 => vim73}/syntax/dictconf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/dictdconf.vim (100%) create mode 100644 share/vim/vim73/syntax/diff.vim rename share/vim/{vim72 => vim73}/syntax/dircolors.vim (100%) rename share/vim/{vim72 => vim73}/syntax/diva.vim (100%) create mode 100644 share/vim/vim73/syntax/django.vim rename share/vim/{vim72 => vim73}/syntax/dns.vim (100%) rename share/vim/{vim72 => vim73}/syntax/docbk.vim (100%) rename share/vim/{vim72 => vim73}/syntax/docbksgml.vim (100%) rename share/vim/{vim72 => vim73}/syntax/docbkxml.vim (100%) create mode 100644 share/vim/vim73/syntax/dosbatch.vim rename share/vim/{vim72 => vim73}/syntax/dosini.vim (100%) rename share/vim/{vim72 => vim73}/syntax/dot.vim (100%) create mode 100644 share/vim/vim73/syntax/doxygen.vim rename share/vim/{vim72 => vim73}/syntax/dracula.vim (100%) rename share/vim/{vim72 => vim73}/syntax/dsl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/dtd.vim (100%) rename share/vim/{vim72 => vim73}/syntax/dtml.vim (100%) rename share/vim/{vim72 => vim73}/syntax/dtrace.vim (100%) rename share/vim/{vim72 => vim73}/syntax/dylan.vim (100%) rename share/vim/{vim72 => vim73}/syntax/dylanintr.vim (100%) rename share/vim/{vim72 => vim73}/syntax/dylanlid.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ecd.vim (100%) rename share/vim/{vim72 => vim73}/syntax/edif.vim (100%) rename share/vim/{vim72 => vim73}/syntax/eiffel.vim (100%) rename share/vim/{vim72 => vim73}/syntax/elf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/elinks.vim (100%) rename share/vim/{vim72 => vim73}/syntax/elmfilt.vim (100%) create mode 100644 share/vim/vim73/syntax/erlang.vim create mode 100644 share/vim/vim73/syntax/eruby.vim rename share/vim/{vim72 => vim73}/syntax/esmtprc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/esqlc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/esterel.vim (100%) rename share/vim/{vim72 => vim73}/syntax/eterm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/eviews.vim (100%) rename share/vim/{vim72 => vim73}/syntax/exim.vim (100%) rename share/vim/{vim72 => vim73}/syntax/expect.vim (100%) rename share/vim/{vim72 => vim73}/syntax/exports.vim (100%) create mode 100644 share/vim/vim73/syntax/fan.vim rename share/vim/{vim72 => vim73}/syntax/fasm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/fdcc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/fetchmail.vim (100%) rename share/vim/{vim72 => vim73}/syntax/fgl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/flexwiki.vim (100%) rename share/vim/{vim72 => vim73}/syntax/focexec.vim (100%) create mode 100644 share/vim/vim73/syntax/form.vim create mode 100644 share/vim/vim73/syntax/forth.vim create mode 100644 share/vim/vim73/syntax/fortran.vim rename share/vim/{vim72 => vim73}/syntax/foxpro.vim (100%) rename share/vim/{vim72 => vim73}/syntax/framescript.vim (100%) rename share/vim/{vim72 => vim73}/syntax/freebasic.vim (100%) create mode 100644 share/vim/vim73/syntax/fstab.vim rename share/vim/{vim72 => vim73}/syntax/fvwm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/fvwm2m4.vim (100%) create mode 100644 share/vim/vim73/syntax/gdb.vim rename share/vim/{vim72 => vim73}/syntax/gdmo.vim (100%) rename share/vim/{vim72 => vim73}/syntax/gedcom.vim (100%) create mode 100644 share/vim/vim73/syntax/git.vim create mode 100644 share/vim/vim73/syntax/gitcommit.vim create mode 100644 share/vim/vim73/syntax/gitconfig.vim create mode 100644 share/vim/vim73/syntax/gitrebase.vim create mode 100644 share/vim/vim73/syntax/gitsendemail.vim rename share/vim/{vim72 => vim73}/syntax/gkrellmrc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/gnuplot.vim (100%) rename share/vim/{vim72 => vim73}/syntax/gp.vim (100%) rename share/vim/{vim72 => vim73}/syntax/gpg.vim (100%) rename share/vim/{vim72 => vim73}/syntax/grads.vim (100%) rename share/vim/{vim72 => vim73}/syntax/gretl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/groff.vim (100%) create mode 100644 share/vim/vim73/syntax/groovy.vim rename share/vim/{vim72 => vim73}/syntax/group.vim (100%) rename share/vim/{vim72 => vim73}/syntax/grub.vim (100%) rename share/vim/{vim72 => vim73}/syntax/gsp.vim (100%) rename share/vim/{vim72 => vim73}/syntax/gtkrc.vim (100%) create mode 100644 share/vim/vim73/syntax/haml.vim rename share/vim/{vim72 => vim73}/syntax/hamster.vim (100%) create mode 100644 share/vim/vim73/syntax/haskell.vim rename share/vim/{vim72 => vim73}/syntax/haste.vim (100%) rename share/vim/{vim72 => vim73}/syntax/hastepreproc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/hb.vim (100%) create mode 100644 share/vim/vim73/syntax/help.vim rename share/vim/{vim72 => vim73}/syntax/hercules.vim (100%) rename share/vim/{vim72 => vim73}/syntax/hex.vim (100%) rename share/vim/{vim72 => vim73}/syntax/hitest.vim (100%) rename share/vim/{vim72 => vim73}/syntax/hog.vim (100%) rename share/vim/{vim72 => vim73}/syntax/hostconf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/html.vim (100%) rename share/vim/{vim72 => vim73}/syntax/htmlcheetah.vim (100%) rename share/vim/{vim72 => vim73}/syntax/htmldjango.vim (100%) rename share/vim/{vim72 => vim73}/syntax/htmlm4.vim (100%) rename share/vim/{vim72 => vim73}/syntax/htmlos.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ia64.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ibasic.vim (100%) rename share/vim/{vim72 => vim73}/syntax/icemenu.vim (100%) rename share/vim/{vim72 => vim73}/syntax/icon.vim (100%) rename share/vim/{vim72 => vim73}/syntax/idl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/idlang.vim (100%) create mode 100644 share/vim/vim73/syntax/indent.vim rename share/vim/{vim72 => vim73}/syntax/inform.vim (100%) rename share/vim/{vim72 => vim73}/syntax/initex.vim (100%) rename share/vim/{vim72 => vim73}/syntax/initng.vim (100%) rename share/vim/{vim72 => vim73}/syntax/inittab.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ipfilter.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ishd.vim (100%) rename share/vim/{vim72 => vim73}/syntax/iss.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ist.vim (100%) rename share/vim/{vim72 => vim73}/syntax/jal.vim (100%) rename share/vim/{vim72 => vim73}/syntax/jam.vim (100%) rename share/vim/{vim72 => vim73}/syntax/jargon.vim (100%) create mode 100644 share/vim/vim73/syntax/java.vim rename share/vim/{vim72 => vim73}/syntax/javacc.vim (100%) create mode 100644 share/vim/vim73/syntax/javascript.vim rename share/vim/{vim72 => vim73}/syntax/jess.vim (100%) rename share/vim/{vim72 => vim73}/syntax/jgraph.vim (100%) rename share/vim/{vim72 => vim73}/syntax/jproperties.vim (100%) create mode 100644 share/vim/vim73/syntax/jsp.vim create mode 100644 share/vim/vim73/syntax/kconfig.vim rename share/vim/{vim72 => vim73}/syntax/kix.vim (100%) rename share/vim/{vim72 => vim73}/syntax/kscript.vim (100%) rename share/vim/{vim72 => vim73}/syntax/kwt.vim (100%) rename share/vim/{vim72 => vim73}/syntax/lace.vim (100%) rename share/vim/{vim72 => vim73}/syntax/latte.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ld.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ldapconf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ldif.vim (100%) create mode 100644 share/vim/vim73/syntax/lex.vim rename share/vim/{vim72 => vim73}/syntax/lftp.vim (100%) create mode 100644 share/vim/vim73/syntax/lhaskell.vim rename share/vim/{vim72 => vim73}/syntax/libao.vim (100%) create mode 100644 share/vim/vim73/syntax/lifelines.vim create mode 100644 share/vim/vim73/syntax/lilo.vim rename share/vim/{vim72 => vim73}/syntax/limits.vim (100%) create mode 100644 share/vim/vim73/syntax/liquid.vim create mode 100644 share/vim/vim73/syntax/lisp.vim rename share/vim/{vim72 => vim73}/syntax/lite.vim (100%) rename share/vim/{vim72 => vim73}/syntax/litestep.vim (100%) rename share/vim/{vim72 => vim73}/syntax/loginaccess.vim (100%) rename share/vim/{vim72 => vim73}/syntax/logindefs.vim (100%) create mode 100644 share/vim/vim73/syntax/logtalk.vim rename share/vim/{vim72 => vim73}/syntax/lotos.vim (100%) rename share/vim/{vim72 => vim73}/syntax/lout.vim (100%) rename share/vim/{vim72 => vim73}/syntax/lpc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/lprolog.vim (100%) rename share/vim/{vim72 => vim73}/syntax/lscript.vim (100%) rename share/vim/{vim72 => vim73}/syntax/lsl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/lss.vim (100%) rename share/vim/{vim72 => vim73}/syntax/lua.vim (100%) rename share/vim/{vim72 => vim73}/syntax/lynx.vim (100%) rename share/vim/{vim72 => vim73}/syntax/m4.vim (100%) create mode 100644 share/vim/vim73/syntax/mail.vim rename share/vim/{vim72 => vim73}/syntax/mailaliases.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mailcap.vim (100%) rename share/vim/{vim72 => vim73}/syntax/make.vim (100%) create mode 100644 share/vim/vim73/syntax/man.vim rename share/vim/{vim72 => vim73}/syntax/manconf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/manual.vim (100%) create mode 100644 share/vim/vim73/syntax/maple.vim create mode 100644 share/vim/vim73/syntax/markdown.vim rename share/vim/{vim72 => vim73}/syntax/masm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mason.vim (100%) rename share/vim/{vim72 => vim73}/syntax/master.vim (100%) create mode 100644 share/vim/vim73/syntax/matlab.vim create mode 100644 share/vim/vim73/syntax/maxima.vim rename share/vim/{vim72 => vim73}/syntax/mel.vim (100%) rename share/vim/{vim72 => vim73}/syntax/messages.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mgl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mgp.vim (100%) create mode 100644 share/vim/vim73/syntax/mib.vim rename share/vim/{vim72 => vim73}/syntax/mma.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mmix.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mmp.vim (100%) rename share/vim/{vim72 => vim73}/syntax/modconf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/model.vim (100%) rename share/vim/{vim72 => vim73}/syntax/modsim3.vim (100%) rename share/vim/{vim72 => vim73}/syntax/modula2.vim (100%) rename share/vim/{vim72 => vim73}/syntax/modula3.vim (100%) rename share/vim/{vim72 => vim73}/syntax/monk.vim (100%) rename share/vim/{vim72 => vim73}/syntax/moo.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mp.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mplayerconf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mrxvtrc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/msidl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/msmessages.vim (100%) rename share/vim/{vim72 => vim73}/syntax/msql.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mupad.vim (100%) rename share/vim/{vim72 => vim73}/syntax/mush.vim (100%) create mode 100644 share/vim/vim73/syntax/muttrc.vim create mode 100644 share/vim/vim73/syntax/mysql.vim rename share/vim/{vim72 => vim73}/syntax/named.vim (100%) rename share/vim/{vim72 => vim73}/syntax/nanorc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/nasm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/nastran.vim (100%) rename share/vim/{vim72 => vim73}/syntax/natural.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ncf.vim (100%) create mode 100644 share/vim/vim73/syntax/netrc.vim create mode 100644 share/vim/vim73/syntax/netrw.vim rename share/vim/{vim72 => vim73}/syntax/nosyntax.vim (100%) rename share/vim/{vim72 => vim73}/syntax/nqc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/nroff.vim (100%) rename share/vim/{vim72 => vim73}/syntax/nsis.vim (100%) create mode 100644 share/vim/vim73/syntax/obj.vim rename share/vim/{vim72 => vim73}/syntax/objc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/objcpp.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ocaml.vim (100%) rename share/vim/{vim72 => vim73}/syntax/occam.vim (100%) rename share/vim/{vim72 => vim73}/syntax/omnimark.vim (100%) rename share/vim/{vim72 => vim73}/syntax/openroad.vim (100%) rename share/vim/{vim72 => vim73}/syntax/opl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ora.vim (100%) rename share/vim/{vim72 => vim73}/syntax/pamconf.vim (100%) create mode 100644 share/vim/vim73/syntax/papp.vim rename share/vim/{vim72 => vim73}/syntax/pascal.vim (100%) rename share/vim/{vim72 => vim73}/syntax/passwd.vim (100%) rename share/vim/{vim72 => vim73}/syntax/pcap.vim (100%) rename share/vim/{vim72 => vim73}/syntax/pccts.vim (100%) rename share/vim/{vim72 => vim73}/syntax/pdf.vim (100%) create mode 100644 share/vim/vim73/syntax/perl.vim create mode 100644 share/vim/vim73/syntax/perl6.vim rename share/vim/{vim72 => vim73}/syntax/pf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/pfmain.vim (100%) rename share/vim/{vim72 => vim73}/syntax/php.vim (100%) rename share/vim/{vim72 => vim73}/syntax/phtml.vim (100%) rename share/vim/{vim72 => vim73}/syntax/pic.vim (100%) rename share/vim/{vim72 => vim73}/syntax/pike.vim (100%) rename share/vim/{vim72 => vim73}/syntax/pilrc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/pine.vim (100%) rename share/vim/{vim72 => vim73}/syntax/pinfo.vim (100%) rename share/vim/{vim72 => vim73}/syntax/plaintex.vim (100%) rename share/vim/{vim72 => vim73}/syntax/plm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/plp.vim (100%) rename share/vim/{vim72 => vim73}/syntax/plsql.vim (100%) create mode 100644 share/vim/vim73/syntax/po.vim create mode 100644 share/vim/vim73/syntax/pod.vim rename share/vim/{vim72 => vim73}/syntax/postscr.vim (100%) rename share/vim/{vim72 => vim73}/syntax/pov.vim (100%) rename share/vim/{vim72 => vim73}/syntax/povini.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ppd.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ppwiz.vim (100%) rename share/vim/{vim72 => vim73}/syntax/prescribe.vim (100%) rename share/vim/{vim72 => vim73}/syntax/privoxy.vim (100%) rename share/vim/{vim72 => vim73}/syntax/procmail.vim (100%) rename share/vim/{vim72 => vim73}/syntax/progress.vim (100%) create mode 100644 share/vim/vim73/syntax/prolog.vim rename share/vim/{vim72 => vim73}/syntax/promela.vim (100%) rename share/vim/{vim72 => vim73}/syntax/protocols.vim (100%) rename share/vim/{vim72 => vim73}/syntax/psf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ptcap.vim (100%) rename share/vim/{vim72 => vim73}/syntax/purifylog.vim (100%) create mode 100644 share/vim/vim73/syntax/pyrex.vim create mode 100644 share/vim/vim73/syntax/python.vim rename share/vim/{vim72 => vim73}/syntax/qf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/quake.vim (100%) rename share/vim/{vim72 => vim73}/syntax/r.vim (100%) rename share/vim/{vim72 => vim73}/syntax/racc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/radiance.vim (100%) rename share/vim/{vim72 => vim73}/syntax/ratpoison.vim (100%) rename share/vim/{vim72 => vim73}/syntax/rc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/rcs.vim (100%) rename share/vim/{vim72 => vim73}/syntax/rcslog.vim (100%) create mode 100644 share/vim/vim73/syntax/readline.vim rename share/vim/{vim72 => vim73}/syntax/rebol.vim (100%) rename share/vim/{vim72 => vim73}/syntax/registry.vim (100%) create mode 100644 share/vim/vim73/syntax/remind.vim rename share/vim/{vim72 => vim73}/syntax/resolv.vim (100%) rename share/vim/{vim72 => vim73}/syntax/reva.vim (100%) rename share/vim/{vim72 => vim73}/syntax/rexx.vim (100%) create mode 100644 share/vim/vim73/syntax/rhelp.vim rename share/vim/{vim72 => vim73}/syntax/rib.vim (100%) rename share/vim/{vim72 => vim73}/syntax/rnc.vim (100%) create mode 100644 share/vim/vim73/syntax/rnoweb.vim rename share/vim/{vim72 => vim73}/syntax/robots.vim (100%) rename share/vim/{vim72 => vim73}/syntax/rpcgen.vim (100%) rename share/vim/{vim72 => vim73}/syntax/rpl.vim (100%) create mode 100644 share/vim/vim73/syntax/rst.vim rename share/vim/{vim72 => vim73}/syntax/rtf.vim (100%) create mode 100644 share/vim/vim73/syntax/ruby.vim create mode 100644 share/vim/vim73/syntax/samba.vim rename share/vim/{vim72 => vim73}/syntax/sas.vim (100%) create mode 100644 share/vim/vim73/syntax/sass.vim rename share/vim/{vim72 => vim73}/syntax/sather.vim (100%) create mode 100644 share/vim/vim73/syntax/scheme.vim rename share/vim/{vim72 => vim73}/syntax/scilab.vim (100%) create mode 100644 share/vim/vim73/syntax/screen.vim create mode 100644 share/vim/vim73/syntax/scss.vim rename share/vim/{vim72 => vim73}/syntax/sd.vim (100%) create mode 100644 share/vim/vim73/syntax/sdc.vim rename share/vim/{vim72 => vim73}/syntax/sdl.vim (100%) create mode 100644 share/vim/vim73/syntax/sed.vim rename share/vim/{vim72 => vim73}/syntax/sendpr.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sensors.vim (100%) rename share/vim/{vim72 => vim73}/syntax/services.vim (100%) rename share/vim/{vim72 => vim73}/syntax/setserial.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sgml.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sgmldecl.vim (100%) create mode 100644 share/vim/vim73/syntax/sgmllnx.vim create mode 100644 share/vim/vim73/syntax/sh.vim rename share/vim/{vim72 => vim73}/syntax/sicad.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sieve.vim (100%) rename share/vim/{vim72 => vim73}/syntax/simula.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sinda.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sindacmp.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sindaout.vim (100%) create mode 100644 share/vim/vim73/syntax/sisu.vim rename share/vim/{vim72 => vim73}/syntax/skill.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/slang.vim (100%) rename share/vim/{vim72 => vim73}/syntax/slice.vim (100%) rename share/vim/{vim72 => vim73}/syntax/slpconf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/slpreg.vim (100%) rename share/vim/{vim72 => vim73}/syntax/slpspi.vim (100%) rename share/vim/{vim72 => vim73}/syntax/slrnrc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/slrnsc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/smarty.vim (100%) rename share/vim/{vim72 => vim73}/syntax/smcl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/smil.vim (100%) rename share/vim/{vim72 => vim73}/syntax/smith.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sml.vim (100%) rename share/vim/{vim72 => vim73}/syntax/snnsnet.vim (100%) rename share/vim/{vim72 => vim73}/syntax/snnspat.vim (100%) rename share/vim/{vim72 => vim73}/syntax/snnsres.vim (100%) rename share/vim/{vim72 => vim73}/syntax/snobol4.vim (100%) create mode 100644 share/vim/vim73/syntax/spec.vim rename share/vim/{vim72 => vim73}/syntax/specman.vim (100%) rename share/vim/{vim72 => vim73}/syntax/spice.vim (100%) rename share/vim/{vim72 => vim73}/syntax/splint.vim (100%) rename share/vim/{vim72 => vim73}/syntax/spup.vim (100%) create mode 100644 share/vim/vim73/syntax/spyce.vim rename share/vim/{vim72 => vim73}/syntax/sql.vim (100%) create mode 100644 share/vim/vim73/syntax/sqlanywhere.vim rename share/vim/{vim72 => vim73}/syntax/sqlforms.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sqlinformix.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sqlj.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sqloracle.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sqr.vim (100%) rename share/vim/{vim72 => vim73}/syntax/squid.vim (100%) create mode 100644 share/vim/vim73/syntax/sshconfig.vim create mode 100644 share/vim/vim73/syntax/sshdconfig.vim rename share/vim/{vim72 => vim73}/syntax/st.vim (100%) rename share/vim/{vim72 => vim73}/syntax/stata.vim (100%) rename share/vim/{vim72 => vim73}/syntax/stp.vim (100%) rename share/vim/{vim72 => vim73}/syntax/strace.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sudoers.vim (100%) create mode 100644 share/vim/vim73/syntax/svg.vim rename share/vim/{vim72 => vim73}/syntax/svn.vim (100%) rename share/vim/{vim72 => vim73}/syntax/syncolor.vim (100%) create mode 100644 share/vim/vim73/syntax/synload.vim rename share/vim/{vim72 => vim73}/syntax/syntax.vim (100%) rename share/vim/{vim72 => vim73}/syntax/sysctl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tads.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tags.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tak.vim (100%) rename share/vim/{vim72 => vim73}/syntax/takcmp.vim (100%) rename share/vim/{vim72 => vim73}/syntax/takout.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tar.vim (100%) create mode 100644 share/vim/vim73/syntax/taskdata.vim create mode 100644 share/vim/vim73/syntax/taskedit.vim rename share/vim/{vim72 => vim73}/syntax/tasm.vim (100%) create mode 100644 share/vim/vim73/syntax/tcl.vim create mode 100644 share/vim/vim73/syntax/tcsh.vim rename share/vim/{vim72 => vim73}/syntax/terminfo.vim (100%) create mode 100644 share/vim/vim73/syntax/tex.vim rename share/vim/{vim72 => vim73}/syntax/texinfo.vim (100%) rename share/vim/{vim72 => vim73}/syntax/texmf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tidy.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tilde.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tli.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tpp.vim (100%) rename share/vim/{vim72 => vim73}/syntax/trasys.vim (100%) rename share/vim/{vim72 => vim73}/syntax/trustees.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tsalt.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tsscl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tssgm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/tssop.vim (100%) rename share/vim/{vim72 => vim73}/syntax/uc.vim (100%) rename share/vim/{vim72 => vim73}/syntax/udevconf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/udevperm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/udevrules.vim (100%) create mode 100644 share/vim/vim73/syntax/uil.vim create mode 100644 share/vim/vim73/syntax/updatedb.vim rename share/vim/{vim72 => vim73}/syntax/valgrind.vim (100%) rename share/vim/{vim72 => vim73}/syntax/vb.vim (100%) rename share/vim/{vim72 => vim73}/syntax/vera.vim (100%) rename share/vim/{vim72 => vim73}/syntax/verilog.vim (100%) rename share/vim/{vim72 => vim73}/syntax/verilogams.vim (100%) rename share/vim/{vim72 => vim73}/syntax/vgrindefs.vim (100%) rename share/vim/{vim72 => vim73}/syntax/vhdl.vim (100%) create mode 100644 share/vim/vim73/syntax/vim.vim rename share/vim/{vim72 => vim73}/syntax/viminfo.vim (100%) rename share/vim/{vim72 => vim73}/syntax/virata.vim (100%) rename share/vim/{vim72 => vim73}/syntax/vmasm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/voscm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/vrml.vim (100%) rename share/vim/{vim72 => vim73}/syntax/vsejcl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/wdiff.vim (100%) rename share/vim/{vim72 => vim73}/syntax/web.vim (100%) rename share/vim/{vim72 => vim73}/syntax/webmacro.vim (100%) rename share/vim/{vim72 => vim73}/syntax/wget.vim (100%) rename share/vim/{vim72 => vim73}/syntax/whitespace.vim (100%) rename share/vim/{vim72 => vim73}/syntax/winbatch.vim (100%) rename share/vim/{vim72 => vim73}/syntax/wml.vim (100%) rename share/vim/{vim72 => vim73}/syntax/wsh.vim (100%) rename share/vim/{vim72 => vim73}/syntax/wsml.vim (100%) rename share/vim/{vim72 => vim73}/syntax/wvdial.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xbl.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xdefaults.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xf86conf.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xhtml.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xinetd.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xkb.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xmath.vim (100%) create mode 100644 share/vim/vim73/syntax/xml.vim rename share/vim/{vim72 => vim73}/syntax/xmodmap.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xpm.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xpm2.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xquery.vim (100%) create mode 100644 share/vim/vim73/syntax/xs.vim rename share/vim/{vim72 => vim73}/syntax/xsd.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xslt.vim (100%) rename share/vim/{vim72 => vim73}/syntax/xxd.vim (100%) create mode 100644 share/vim/vim73/syntax/yacc.vim create mode 100644 share/vim/vim73/syntax/yaml.vim rename share/vim/{vim72 => vim73}/syntax/z8a.vim (100%) create mode 100644 share/vim/vim73/syntax/zsh.vim rename share/vim/{vim72 => vim73}/termcap (100%) rename share/vim/{vim72 => vim73}/tools.info (100%) create mode 100644 share/vim/vim73/tools/README.txt rename share/vim/{vim72 => vim73}/tools/blink.c (100%) rename share/vim/{vim72 => vim73}/tools/ccfilter.1 (100%) rename share/vim/{vim72 => vim73}/tools/ccfilter.c (100%) rename share/vim/{vim72 => vim73}/tools/ccfilter_README.txt (100%) rename share/vim/{vim72 => vim73}/tools/efm_filter.pl (100%) rename share/vim/{vim72 => vim73}/tools/efm_filter.txt (100%) rename share/vim/{vim72 => vim73}/tools/efm_perl.pl (100%) rename share/vim/{vim72 => vim73}/tools/mve.awk (100%) rename share/vim/{vim72 => vim73}/tools/mve.txt (100%) rename share/vim/{vim72 => vim73}/tools/pltags.pl (100%) rename share/vim/{vim72 => vim73}/tools/ref (100%) rename share/vim/{vim72 => vim73}/tools/shtags.1 (100%) rename share/vim/{vim72 => vim73}/tools/shtags.pl (100%) create mode 100644 share/vim/vim73/tools/unicode.vim rename share/vim/{vim72 => vim73}/tools/vim132 (100%) rename share/vim/{vim72 => vim73}/tools/vim_vs_net.cmd (100%) rename share/vim/{vim72 => vim73}/tools/vimm (100%) rename share/vim/{vim72 => vim73}/tools/vimspell.sh (100%) rename share/vim/{vim72 => vim73}/tools/vimspell.txt (100%) rename share/vim/{vim72 => vim73}/tools/xcmdsrv_client.c (100%) rename share/vim/{vim72 => vim73}/tutor.info (100%) create mode 100644 share/vim/vim73/tutor/Makefile rename share/vim/{vim72 => vim73}/tutor/README.el.cp737.txt (100%) rename share/vim/{vim72 => vim73}/tutor/README.el.txt (100%) rename share/vim/{vim72 => vim73}/tutor/README.txt (100%) rename share/vim/{vim72 => vim73}/tutor/README.txt.info (100%) create mode 100644 share/vim/vim73/tutor/tutor create mode 100644 share/vim/vim73/tutor/tutor.bj create mode 100644 share/vim/vim73/tutor/tutor.bj.utf-8 rename share/vim/{vim72 => vim73}/tutor/tutor.ca (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.ca.utf-8 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.cs (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.cs.cp1250 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.cs.utf-8 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.de (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.de.utf-8 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.el (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.el.cp737 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.el.utf-8 (100%) create mode 100644 share/vim/vim73/tutor/tutor.eo create mode 100644 share/vim/vim73/tutor/tutor.eo.utf-8 create mode 100644 share/vim/vim73/tutor/tutor.es create mode 100644 share/vim/vim73/tutor/tutor.es.utf-8 create mode 100644 share/vim/vim73/tutor/tutor.fr create mode 100644 share/vim/vim73/tutor/tutor.fr.utf-8 rename share/vim/{vim72 => vim73}/tutor/tutor.hr (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.hr.cp1250 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.hr.utf-8 (100%) create mode 100644 share/vim/vim73/tutor/tutor.hu create mode 100644 share/vim/vim73/tutor/tutor.hu.cp1250 create mode 100644 share/vim/vim73/tutor/tutor.hu.utf-8 rename share/vim/{vim72 => vim73}/tutor/tutor.info (100%) create mode 100644 share/vim/vim73/tutor/tutor.it create mode 100644 share/vim/vim73/tutor/tutor.it.utf-8 create mode 100644 share/vim/vim73/tutor/tutor.ja.euc create mode 100644 share/vim/vim73/tutor/tutor.ja.sjis create mode 100644 share/vim/vim73/tutor/tutor.ja.utf-8 rename share/vim/{vim72 => vim73}/tutor/tutor.ko.euc (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.ko.utf-8 (100%) copy share/vim/{vim72/tutor/tutor.no => vim73/tutor/tutor.nb} (100%) copy share/vim/{vim72/tutor/tutor.no.utf-8 => vim73/tutor/tutor.nb.utf-8} (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.no (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.no.utf-8 (100%) create mode 100644 share/vim/vim73/tutor/tutor.pl create mode 100644 share/vim/vim73/tutor/tutor.pl.cp1250 create mode 100644 share/vim/vim73/tutor/tutor.pl.utf-8 create mode 100644 share/vim/vim73/tutor/tutor.pt create mode 100644 share/vim/vim73/tutor/tutor.pt.utf-8 rename share/vim/{vim72 => vim73}/tutor/tutor.ru (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.ru.cp1251 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.ru.utf-8 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.sk (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.sk.cp1250 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.sk.utf-8 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.sv (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.sv.utf-8 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.tr.iso9 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.tr.utf-8 (100%) create mode 100644 share/vim/vim73/tutor/tutor.utf-8 rename share/vim/{vim72 => vim73}/tutor/tutor.vi.utf-8 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.vim (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.zh.big5 (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.zh.euc (100%) rename share/vim/{vim72 => vim73}/tutor/tutor.zh.utf-8 (100%) create mode 100644 share/vim/vim73/vim.exe rename share/vim/{vim72 => vim73}/vim16x16.gif (100%) rename share/vim/{vim72 => vim73}/vim16x16.png (100%) rename share/vim/{vim72 => vim73}/vim16x16.xpm (100%) rename share/vim/{vim72 => vim73}/vim32x32.gif (100%) rename share/vim/{vim72 => vim73}/vim32x32.png (100%) rename share/vim/{vim72 => vim73}/vim32x32.xpm (100%) rename share/vim/{vim72 => vim73}/vim48x48.gif (100%) rename share/vim/{vim72 => vim73}/vim48x48.png (100%) rename share/vim/{vim72 => vim73}/vim48x48.xpm (100%) rename share/vim/{vim72 => vim73}/vimlogo.cdr (100%) rename share/vim/{vim72 => vim73}/vimlogo.eps (100%) rename share/vim/{vim72 => vim73}/vimlogo.gif (100%) rename share/vim/{vim72 => vim73}/vimlogo.pdf (100%) rename share/vim/{vim72 => vim73}/vimlogo.xpm (100%) create mode 100644 share/vim/vim73/vimrc_example.vim diff --git a/bin/vi b/bin/vi index cd37cba458..90da3ce27c 100644 --- a/bin/vi +++ b/bin/vi @@ -1,3 +1,3 @@ #!/bin/sh -exec /share/vim/vim72/vim "$@" +exec /share/vim/vim73/vim "$@" diff --git a/bin/vim b/bin/vim index cd37cba458..90da3ce27c 100644 --- a/bin/vim +++ b/bin/vim @@ -1,3 +1,3 @@ #!/bin/sh -exec /share/vim/vim72/vim "$@" +exec /share/vim/vim73/vim "$@" diff --git a/share/vim/vim72/autoload/ccomplete.vim b/share/vim/vim72/autoload/ccomplete.vim deleted file mode 100644 index 6850e19a0b..0000000000 --- a/share/vim/vim72/autoload/ccomplete.vim +++ /dev/null @@ -1,605 +0,0 @@ -" Vim completion script -" Language: C -" Maintainer: Bram Moolenaar -" Last Change: 2007 Aug 30 - - -" This function is used for the 'omnifunc' option. -function! ccomplete#Complete(findstart, base) - if a:findstart - " Locate the start of the item, including ".", "->" and "[...]". - let line = getline('.') - let start = col('.') - 1 - let lastword = -1 - while start > 0 - if line[start - 1] =~ '\w' - let start -= 1 - elseif line[start - 1] =~ '\.' - if lastword == -1 - let lastword = start - endif - let start -= 1 - elseif start > 1 && line[start - 2] == '-' && line[start - 1] == '>' - if lastword == -1 - let lastword = start - endif - let start -= 2 - elseif line[start - 1] == ']' - " Skip over [...]. - let n = 0 - let start -= 1 - while start > 0 - let start -= 1 - if line[start] == '[' - if n == 0 - break - endif - let n -= 1 - elseif line[start] == ']' " nested [] - let n += 1 - endif - endwhile - else - break - endif - endwhile - - " Return the column of the last word, which is going to be changed. - " Remember the text that comes before it in s:prepended. - if lastword == -1 - let s:prepended = '' - return start - endif - let s:prepended = strpart(line, start, lastword - start) - return lastword - endif - - " Return list of matches. - - let base = s:prepended . a:base - - " Don't do anything for an empty base, would result in all the tags in the - " tags file. - if base == '' - return [] - endif - - " init cache for vimgrep to empty - let s:grepCache = {} - - " Split item in words, keep empty word after "." or "->". - " "aa" -> ['aa'], "aa." -> ['aa', ''], "aa.bb" -> ['aa', 'bb'], etc. - " We can't use split, because we need to skip nested [...]. - let items = [] - let s = 0 - while 1 - let e = match(base, '\.\|->\|\[', s) - if e < 0 - if s == 0 || base[s - 1] != ']' - call add(items, strpart(base, s)) - endif - break - endif - if s == 0 || base[s - 1] != ']' - call add(items, strpart(base, s, e - s)) - endif - if base[e] == '.' - let s = e + 1 " skip over '.' - elseif base[e] == '-' - let s = e + 2 " skip over '->' - else - " Skip over [...]. - let n = 0 - let s = e - let e += 1 - while e < len(base) - if base[e] == ']' - if n == 0 - break - endif - let n -= 1 - elseif base[e] == '[' " nested [...] - let n += 1 - endif - let e += 1 - endwhile - let e += 1 - call add(items, strpart(base, s, e - s)) - let s = e - endif - endwhile - - " Find the variable items[0]. - " 1. in current function (like with "gd") - " 2. in tags file(s) (like with ":tag") - " 3. in current file (like with "gD") - let res = [] - if searchdecl(items[0], 0, 1) == 0 - " Found, now figure out the type. - " TODO: join previous line if it makes sense - let line = getline('.') - let col = col('.') - if stridx(strpart(line, 0, col), ';') != -1 - " Handle multiple declarations on the same line. - let col2 = col - 1 - while line[col2] != ';' - let col2 -= 1 - endwhile - let line = strpart(line, col2 + 1) - let col -= col2 - endif - if stridx(strpart(line, 0, col), ',') != -1 - " Handle multiple declarations on the same line in a function - " declaration. - let col2 = col - 1 - while line[col2] != ',' - let col2 -= 1 - endwhile - if strpart(line, col2 + 1, col - col2 - 1) =~ ' *[^ ][^ ]* *[^ ]' - let line = strpart(line, col2 + 1) - let col -= col2 - endif - endif - if len(items) == 1 - " Completing one word and it's a local variable: May add '[', '.' or - " '->'. - let match = items[0] - let kind = 'v' - if match(line, '\<' . match . '\s*\[') > 0 - let match .= '[' - else - let res = s:Nextitem(strpart(line, 0, col), [''], 0, 1) - if len(res) > 0 - " There are members, thus add "." or "->". - if match(line, '\*[ \t(]*' . match . '\>') > 0 - let match .= '->' - else - let match .= '.' - endif - endif - endif - let res = [{'match': match, 'tagline' : '', 'kind' : kind, 'info' : line}] - else - " Completing "var.", "var.something", etc. - let res = s:Nextitem(strpart(line, 0, col), items[-1], 0, 1) - endif - endif - - if len(items) == 1 - " Only one part, no "." or "->": complete from tags file. - let tags = taglist('^' . base) - - " Remove members, these can't appear without something in front. - call filter(tags, 'has_key(v:val, "kind") ? v:val["kind"] != "m" : 1') - - " Remove static matches in other files. - call filter(tags, '!has_key(v:val, "static") || !v:val["static"] || bufnr("%") == bufnr(v:val["filename"])') - - call extend(res, map(tags, 's:Tag2item(v:val)')) - endif - - if len(res) == 0 - " Find the variable in the tags file(s) - let diclist = taglist('^' . items[0] . '$') - - " Remove members, these can't appear without something in front. - call filter(diclist, 'has_key(v:val, "kind") ? v:val["kind"] != "m" : 1') - - let res = [] - for i in range(len(diclist)) - " New ctags has the "typeref" field. Patched version has "typename". - if has_key(diclist[i], 'typename') - call extend(res, s:StructMembers(diclist[i]['typename'], items[1:], 1)) - elseif has_key(diclist[i], 'typeref') - call extend(res, s:StructMembers(diclist[i]['typeref'], items[1:], 1)) - endif - - " For a variable use the command, which must be a search pattern that - " shows the declaration of the variable. - if diclist[i]['kind'] == 'v' - let line = diclist[i]['cmd'] - if line[0] == '/' && line[1] == '^' - let col = match(line, '\<' . items[0] . '\>') - call extend(res, s:Nextitem(strpart(line, 2, col - 2), items[1:], 0, 1)) - endif - endif - endfor - endif - - if len(res) == 0 && searchdecl(items[0], 1) == 0 - " Found, now figure out the type. - " TODO: join previous line if it makes sense - let line = getline('.') - let col = col('.') - let res = s:Nextitem(strpart(line, 0, col), items[1:], 0, 1) - endif - - " If the last item(s) are [...] they need to be added to the matches. - let last = len(items) - 1 - let brackets = '' - while last >= 0 - if items[last][0] != '[' - break - endif - let brackets = items[last] . brackets - let last -= 1 - endwhile - - return map(res, 's:Tagline2item(v:val, brackets)') -endfunc - -function! s:GetAddition(line, match, memarg, bracket) - " Guess if the item is an array. - if a:bracket && match(a:line, a:match . '\s*\[') > 0 - return '[' - endif - - " Check if the item has members. - if len(s:SearchMembers(a:memarg, [''], 0)) > 0 - " If there is a '*' before the name use "->". - if match(a:line, '\*[ \t(]*' . a:match . '\>') > 0 - return '->' - else - return '.' - endif - endif - return '' -endfunction - -" Turn the tag info "val" into an item for completion. -" "val" is is an item in the list returned by taglist(). -" If it is a variable we may add "." or "->". Don't do it for other types, -" such as a typedef, by not including the info that s:GetAddition() uses. -function! s:Tag2item(val) - let res = {'match': a:val['name']} - - let res['extra'] = s:Tagcmd2extra(a:val['cmd'], a:val['name'], a:val['filename']) - - let s = s:Dict2info(a:val) - if s != '' - let res['info'] = s - endif - - let res['tagline'] = '' - if has_key(a:val, "kind") - let kind = a:val['kind'] - let res['kind'] = kind - if kind == 'v' - let res['tagline'] = "\t" . a:val['cmd'] - let res['dict'] = a:val - elseif kind == 'f' - let res['match'] = a:val['name'] . '(' - endif - endif - - return res -endfunction - -" Use all the items in dictionary for the "info" entry. -function! s:Dict2info(dict) - let info = '' - for k in sort(keys(a:dict)) - let info .= k . repeat(' ', 10 - len(k)) - if k == 'cmd' - let info .= substitute(matchstr(a:dict['cmd'], '/^\s*\zs.*\ze$/'), '\\\(.\)', '\1', 'g') - else - let info .= a:dict[k] - endif - let info .= "\n" - endfor - return info -endfunc - -" Parse a tag line and return a dictionary with items like taglist() -function! s:ParseTagline(line) - let l = split(a:line, "\t") - let d = {} - if len(l) >= 3 - let d['name'] = l[0] - let d['filename'] = l[1] - let d['cmd'] = l[2] - let n = 2 - if l[2] =~ '^/' - " Find end of cmd, it may contain Tabs. - while n < len(l) && l[n] !~ '/;"$' - let n += 1 - let d['cmd'] .= " " . l[n] - endwhile - endif - for i in range(n + 1, len(l) - 1) - if l[i] == 'file:' - let d['static'] = 1 - elseif l[i] !~ ':' - let d['kind'] = l[i] - else - let d[matchstr(l[i], '[^:]*')] = matchstr(l[i], ':\zs.*') - endif - endfor - endif - - return d -endfunction - -" Turn a match item "val" into an item for completion. -" "val['match']" is the matching item. -" "val['tagline']" is the tagline in which the last part was found. -function! s:Tagline2item(val, brackets) - let line = a:val['tagline'] - let add = s:GetAddition(line, a:val['match'], [a:val], a:brackets == '') - let res = {'word': a:val['match'] . a:brackets . add } - - if has_key(a:val, 'info') - " Use info from Tag2item(). - let res['info'] = a:val['info'] - else - " Parse the tag line and add each part to the "info" entry. - let s = s:Dict2info(s:ParseTagline(line)) - if s != '' - let res['info'] = s - endif - endif - - if has_key(a:val, 'kind') - let res['kind'] = a:val['kind'] - elseif add == '(' - let res['kind'] = 'f' - else - let s = matchstr(line, '\t\(kind:\)\=\zs\S\ze\(\t\|$\)') - if s != '' - let res['kind'] = s - endif - endif - - if has_key(a:val, 'extra') - let res['menu'] = a:val['extra'] - return res - endif - - " Isolate the command after the tag and filename. - let s = matchstr(line, '[^\t]*\t[^\t]*\t\zs\(/^.*$/\|[^\t]*\)\ze\(;"\t\|\t\|$\)') - if s != '' - let res['menu'] = s:Tagcmd2extra(s, a:val['match'], matchstr(line, '[^\t]*\t\zs[^\t]*\ze\t')) - endif - return res -endfunction - -" Turn a command from a tag line to something that is useful in the menu -function! s:Tagcmd2extra(cmd, name, fname) - if a:cmd =~ '^/^' - " The command is a search command, useful to see what it is. - let x = matchstr(a:cmd, '^/^\s*\zs.*\ze$/') - let x = substitute(x, '\<' . a:name . '\>', '@@', '') - let x = substitute(x, '\\\(.\)', '\1', 'g') - let x = x . ' - ' . a:fname - elseif a:cmd =~ '^\d*$' - " The command is a line number, the file name is more useful. - let x = a:fname . ' - ' . a:cmd - else - " Not recognized, use command and file name. - let x = a:cmd . ' - ' . a:fname - endif - return x -endfunction - -" Find composing type in "lead" and match items[0] with it. -" Repeat this recursively for items[1], if it's there. -" When resolving typedefs "depth" is used to avoid infinite recursion. -" Return the list of matches. -function! s:Nextitem(lead, items, depth, all) - - " Use the text up to the variable name and split it in tokens. - let tokens = split(a:lead, '\s\+\|\<') - - " Try to recognize the type of the variable. This is rough guessing... - let res = [] - for tidx in range(len(tokens)) - - " Skip tokens starting with a non-ID character. - if tokens[tidx] !~ '^\h' - continue - endif - - " Recognize "struct foobar" and "union foobar". - " Also do "class foobar" when it's C++ after all (doesn't work very well - " though). - if (tokens[tidx] == 'struct' || tokens[tidx] == 'union' || tokens[tidx] == 'class') && tidx + 1 < len(tokens) - let res = s:StructMembers(tokens[tidx] . ':' . tokens[tidx + 1], a:items, a:all) - break - endif - - " TODO: add more reserved words - if index(['int', 'short', 'char', 'float', 'double', 'static', 'unsigned', 'extern'], tokens[tidx]) >= 0 - continue - endif - - " Use the tags file to find out if this is a typedef. - let diclist = taglist('^' . tokens[tidx] . '$') - for tagidx in range(len(diclist)) - let item = diclist[tagidx] - - " New ctags has the "typeref" field. Patched version has "typename". - if has_key(item, 'typeref') - call extend(res, s:StructMembers(item['typeref'], a:items, a:all)) - continue - endif - if has_key(item, 'typename') - call extend(res, s:StructMembers(item['typename'], a:items, a:all)) - continue - endif - - " Only handle typedefs here. - if item['kind'] != 't' - continue - endif - - " Skip matches local to another file. - if has_key(item, 'static') && item['static'] && bufnr('%') != bufnr(item['filename']) - continue - endif - - " For old ctags we recognize "typedef struct aaa" and - " "typedef union bbb" in the tags file command. - let cmd = item['cmd'] - let ei = matchend(cmd, 'typedef\s\+') - if ei > 1 - let cmdtokens = split(strpart(cmd, ei), '\s\+\|\<') - if len(cmdtokens) > 1 - if cmdtokens[0] == 'struct' || cmdtokens[0] == 'union' || cmdtokens[0] == 'class' - let name = '' - " Use the first identifier after the "struct" or "union" - for ti in range(len(cmdtokens) - 1) - if cmdtokens[ti] =~ '^\w' - let name = cmdtokens[ti] - break - endif - endfor - if name != '' - call extend(res, s:StructMembers(cmdtokens[0] . ':' . name, a:items, a:all)) - endif - elseif a:depth < 10 - " Could be "typedef other_T some_T". - call extend(res, s:Nextitem(cmdtokens[0], a:items, a:depth + 1, a:all)) - endif - endif - endif - endfor - if len(res) > 0 - break - endif - endfor - - return res -endfunction - - -" Search for members of structure "typename" in tags files. -" Return a list with resulting matches. -" Each match is a dictionary with "match" and "tagline" entries. -" When "all" is non-zero find all, otherwise just return 1 if there is any -" member. -function! s:StructMembers(typename, items, all) - " Todo: What about local structures? - let fnames = join(map(tagfiles(), 'escape(v:val, " \\#%")')) - if fnames == '' - return [] - endif - - let typename = a:typename - let qflist = [] - let cached = 0 - if a:all == 0 - let n = '1' " stop at first found match - if has_key(s:grepCache, a:typename) - let qflist = s:grepCache[a:typename] - let cached = 1 - endif - else - let n = '' - endif - if !cached - while 1 - exe 'silent! ' . n . 'vimgrep /\t' . typename . '\(\t\|$\)/j ' . fnames - - let qflist = getqflist() - if len(qflist) > 0 || match(typename, "::") < 0 - break - endif - " No match for "struct:context::name", remove "context::" and try again. - let typename = substitute(typename, ':[^:]*::', ':', '') - endwhile - - if a:all == 0 - " Store the result to be able to use it again later. - let s:grepCache[a:typename] = qflist - endif - endif - - " Put matching members in matches[]. - let matches = [] - for l in qflist - let memb = matchstr(l['text'], '[^\t]*') - if memb =~ '^' . a:items[0] - " Skip matches local to another file. - if match(l['text'], "\tfile:") < 0 || bufnr('%') == bufnr(matchstr(l['text'], '\t\zs[^\t]*')) - let item = {'match': memb, 'tagline': l['text']} - - " Add the kind of item. - let s = matchstr(l['text'], '\t\(kind:\)\=\zs\S\ze\(\t\|$\)') - if s != '' - let item['kind'] = s - if s == 'f' - let item['match'] = memb . '(' - endif - endif - - call add(matches, item) - endif - endif - endfor - - if len(matches) > 0 - " Skip over [...] items - let idx = 1 - while 1 - if idx >= len(a:items) - return matches " No further items, return the result. - endif - if a:items[idx][0] != '[' - break - endif - let idx += 1 - endwhile - - " More items following. For each of the possible members find the - " matching following members. - return s:SearchMembers(matches, a:items[idx :], a:all) - endif - - " Failed to find anything. - return [] -endfunction - -" For matching members, find matches for following items. -" When "all" is non-zero find all, otherwise just return 1 if there is any -" member. -function! s:SearchMembers(matches, items, all) - let res = [] - for i in range(len(a:matches)) - let typename = '' - if has_key(a:matches[i], 'dict') - if has_key(a:matches[i].dict, 'typename') - let typename = a:matches[i].dict['typename'] - elseif has_key(a:matches[i].dict, 'typeref') - let typename = a:matches[i].dict['typeref'] - endif - let line = "\t" . a:matches[i].dict['cmd'] - else - let line = a:matches[i]['tagline'] - let e = matchend(line, '\ttypename:') - if e < 0 - let e = matchend(line, '\ttyperef:') - endif - if e > 0 - " Use typename field - let typename = matchstr(line, '[^\t]*', e) - endif - endif - - if typename != '' - call extend(res, s:StructMembers(typename, a:items, a:all)) - else - " Use the search command (the declaration itself). - let s = match(line, '\t\zs/^') - if s > 0 - let e = match(line, '\<' . a:matches[i]['match'] . '\>', s) - if e > 0 - call extend(res, s:Nextitem(strpart(line, s, e - s), a:items, 0, a:all)) - endif - endif - endif - if a:all == 0 && len(res) > 0 - break - endif - endfor - return res -endfunc diff --git a/share/vim/vim72/autoload/getscript.vim b/share/vim/vim72/autoload/getscript.vim deleted file mode 100644 index 5a466cb88b..0000000000 --- a/share/vim/vim72/autoload/getscript.vim +++ /dev/null @@ -1,623 +0,0 @@ -" --------------------------------------------------------------------- -" getscript.vim -" Author: Charles E. Campbell, Jr. -" Date: Jul 10, 2008 -" Version: 31 -" Installing: :help glvs-install -" Usage: :help glvs -" -" GetLatestVimScripts: 642 1 :AutoInstall: getscript.vim -"redraw!|call inputsave()|call input("Press to continue")|call inputrestore() -" --------------------------------------------------------------------- -" Initialization: {{{1 -" if you're sourcing this file, surely you can't be -" expecting vim to be in its vi-compatible mode! -if &cp - echoerr "GetLatestVimScripts is not vi-compatible; not loaded (you need to set nocp)" - finish -endif -let s:keepcpo = &cpo -set cpo&vim -"DechoTabOn - -if exists("g:loaded_getscript") - finish -endif -let g:loaded_getscript= "v31" - -" --------------------------- -" Global Variables: {{{1 -" --------------------------- -" Cygwin Detection ------- {{{2 -if !exists("g:getscript_cygwin") - if has("win32") || has("win95") || has("win64") || has("win16") - if &shell =~ '\%(\\|\\)\%(\.exe\)\=$' - let g:getscript_cygwin= 1 - else - let g:getscript_cygwin= 0 - endif - else - let g:getscript_cygwin= 0 - endif -endif -" shell quoting character {{{2 -if exists("g:netrw_shq") && !exists("g:getscript_shq") - let g:getscript_shq= g:netrw_shq -elseif !exists("g:getscript_shq") - if exists("&shq") && &shq != "" - let g:getscript_shq= &shq - elseif exists("&sxq") && &sxq != "" - let g:getscript_shq= &sxq - elseif has("win32") || has("win95") || has("win64") || has("win16") - if g:getscript_cygwin - let g:getscript_shq= "'" - else - let g:getscript_shq= '"' - endif - else - let g:getscript_shq= "'" - endif -" call Decho("g:getscript_shq<".g:getscript_shq.">") -endif - -" wget vs curl {{{2 -if !exists("g:GetLatestVimScripts_wget") - if executable("wget") - let g:GetLatestVimScripts_wget= "wget" - elseif executable("curl") - let g:GetLatestVimScripts_wget= "curl" - else - let g:GetLatestVimScripts_wget = 'echo "GetLatestVimScripts needs wget or curl"' - let g:GetLatestVimScripts_options = "" - endif -endif - -" options that wget and curl require: -if !exists("g:GetLatestVimScripts_options") - if g:GetLatestVimScripts_wget == "wget" - let g:GetLatestVimScripts_options= "-q -O" - elseif g:GetLatestVimScripts_wget == "curl" - let g:GetLatestVimScripts_options= "-s -O" - else - let g:GetLatestVimScripts_options= "" - endif -endif - -" by default, allow autoinstall lines to work -if !exists("g:GetLatestVimScripts_allowautoinstall") - let g:GetLatestVimScripts_allowautoinstall= 1 -endif - -"" For debugging: -"let g:GetLatestVimScripts_wget = "echo" -"let g:GetLatestVimScripts_options = "options" - -" --------------------------------------------------------------------- -" Check If AutoInstall Capable: {{{1 -let s:autoinstall= "" -if g:GetLatestVimScripts_allowautoinstall - - if (has("win32") || has("gui_win32") || has("gui_win32s") || has("win16") || has("win64") || has("win32unix") || has("win95")) && &shell != "bash" - " windows (but not cygwin/bash) - let s:dotvim= "vimfiles" - if !exists("g:GetLatestVimScripts_mv") - let g:GetLatestVimScripts_mv= "ren" - endif - - else - " unix - let s:dotvim= ".vim" - if !exists("g:GetLatestVimScripts_mv") - let g:GetLatestVimScripts_mv= "mv" - endif - endif - - if exists('$HOME') && isdirectory(expand("$HOME")."/".s:dotvim) - let s:autoinstall= $HOME."/".s:dotvim - endif -" call Decho("s:autoinstall<".s:autoinstall.">") -"else "Decho -" call Decho("g:GetLatestVimScripts_allowautoinstall=".g:GetLatestVimScripts_allowautoinstall.": :AutoInstall: disabled") -endif - -" --------------------------------------------------------------------- -" Public Interface: {{{1 -com! -nargs=0 GetLatestVimScripts call getscript#GetLatestVimScripts() -com! -nargs=0 GetScript call getscript#GetLatestVimScripts() -silent! com -nargs=0 GLVS call getscript#GetLatestVimScripts() - -" --------------------------------------------------------------------- -" GetLatestVimScripts: this function gets the latest versions of {{{1 -" scripts based on the list in -" (first dir in runtimepath)/GetLatest/GetLatestVimScripts.dat -fun! getscript#GetLatestVimScripts() -" call Dfunc("GetLatestVimScripts() autoinstall<".s:autoinstall.">") - -" insure that wget is executable - if executable(g:GetLatestVimScripts_wget) != 1 - echoerr "GetLatestVimScripts needs ".g:GetLatestVimScripts_wget." which apparently is not available on your system" -" call Dret("GetLatestVimScripts : wget not executable/availble") - return - endif - - " insure that fnameescape() is available - if !exists("*fnameescape") - echoerr "GetLatestVimScripts needs fnameescape() (provided by 7.1.299 or later)" - return - endif - - " Find the .../GetLatest subdirectory under the runtimepath - for datadir in split(&rtp,',') + [''] - if isdirectory(datadir."/GetLatest") -" call Decho("found directory<".datadir.">") - let datadir= datadir . "/GetLatest" - break - endif - if filereadable(datadir."GetLatestVimScripts.dat") -" call Decho("found ".datadir."/GetLatestVimScripts.dat") - break - endif - endfor - - " Sanity checks: readability and writability - if datadir == "" - echoerr 'Missing "GetLatest/" on your runtimepath - see :help glvs-dist-install' -" call Dret("GetLatestVimScripts : unable to find a GetLatest subdirectory") - return - endif - - if filewritable(datadir) != 2 - echoerr "(getLatestVimScripts) Your ".datadir." isn't writable" -" call Dret("GetLatestVimScripts : non-writable directory<".datadir.">") - return - endif - let datafile= datadir."/GetLatestVimScripts.dat" - if !filereadable(datafile) - echoerr "Your data file<".datafile."> isn't readable" -" call Dret("GetLatestVimScripts : non-readable datafile<".datafile.">") - return - endif - if !filewritable(datafile) - echoerr "Your data file<".datafile."> isn't writable" -" call Dret("GetLatestVimScripts : non-writable datafile<".datafile.">") - return - endif -" call Decho("datadir <".datadir.">") -" call Decho("datafile <".datafile.">") - - " don't let any events interfere (like winmanager's, taglist's, etc) - let eikeep= &ei - let hlskeep= &hls - set ei=all hls&vim - - " record current directory, change to datadir, open split window with - " datafile - let origdir= getcwd() -" call Decho("exe cd ".fnameescape(substitute(datadir,'\','/','ge'))) - exe "cd ".fnameescape(substitute(datadir,'\','/','ge')) - split -" call Decho("exe e ".fnameescape(substitute(datafile,'\','/','ge'))) - exe "e ".fnameescape(substitute(datafile,'\','/','ge')) - res 1000 - let s:downloads = 0 - let s:downerrors= 0 - - " Check on dependencies mentioned in plugins -" call Decho(" ") -" call Decho("searching plugins for GetLatestVimScripts dependencies") - let lastline = line("$") -" call Decho("lastline#".lastline) - let plugins = split(globpath(&rtp,"plugin/*.vim"),'\n') - let foundscript = 0 - let firstdir= "" - - for plugin in plugins -" call Decho("plugin<".plugin.">") - - " don't process plugins in system directories - if firstdir == "" - let firstdir= substitute(plugin,'[/\\][^/\\]\+$','','') -" call Decho("setting firstdir<".firstdir.">") - else - let curdir= substitute(plugin,'[/\\][^/\\]\+$','','') -" call Decho("curdir<".curdir.">") - if curdir != firstdir -" call Decho("skipping subsequent plugins: curdir<".curdir."> != firstdir<".firstdir.">") - break - endif - endif - - " read plugin in - " evidently a :r creates a new buffer (the "#" buffer) that is subsequently unused -- bwiping it - $ -" call Decho(" ") -" call Decho(".dependency checking<".plugin."> line$=".line("$")) -" call Decho("exe silent r ".fnameescape(plugin)) - exe "silent r ".fnameescape(plugin) - exe "silent bwipe ".bufnr("#") - - while search('^"\s\+GetLatestVimScripts:\s\+\d\+\s\+\d\+','W') != 0 - let newscript= substitute(getline("."),'^"\s\+GetLatestVimScripts:\s\+\d\+\s\+\d\+\s\+\(.*\)$','\1','e') - let llp1 = lastline+1 -" call Decho("..newscript<".newscript.">") - - " don't process ""GetLatestVimScripts lines -- those that have been doubly-commented out - if newscript !~ '^"' - " found a "GetLatestVimScripts: # #" line in the script; check if its already in the datafile - let curline = line(".") - let noai_script = substitute(newscript,'\s*:AutoInstall:\s*','','e') - exe llp1 - let srchline = search('\<'.noai_script.'\>','bW') -" call Decho("..noai_script<".noai_script."> srch=".srchline."curline#".line(".")." lastline#".lastline) - - if srchline == 0 - " found a new script to permanently include in the datafile - let keep_rega = @a - let @a = substitute(getline(curline),'^"\s\+GetLatestVimScripts:\s\+','','') - exe lastline."put a" - echomsg "Appending <".@a."> to ".datafile." for ".newscript -" call Decho("..APPEND (".noai_script.")<".@a."> to GetLatestVimScripts.dat") - let @a = keep_rega - let lastline = llp1 - let curline = curline + 1 - let foundscript = foundscript + 1 -" else " Decho -" call Decho("..found <".noai_script."> (already in datafile at line#".srchline.")") - endif - - let curline = curline + 1 - exe curline - endif - endwhile - - let llp1= lastline + 1 -" call Decho(".deleting lines: ".llp1.",$d") - exe "silent! ".llp1.",$d" - endfor -" call Decho("--- end dependency checking loop --- foundscript=".foundscript) -" call Decho(" ") -" call Dredir("BUFFER TEST (GetLatestVimScripts 1)","ls!") - - if foundscript == 0 - setlocal nomod - endif - - " Check on out-of-date scripts using GetLatest/GetLatestVimScripts.dat -" call Decho("begin: checking out-of-date scripts using datafile<".datafile.">") - setlocal lz - 1 -" /^-----/,$g/^\s*\d/call Decho(getline(".")) - 1 - /^-----/,$g/^\s*\d/call s:GetOneScript() -" call Decho("--- end out-of-date checking --- ") - - " Final report (an echomsg) - try - silent! ?^-------? - catch /^Vim\%((\a\+)\)\=:E114/ -" call Dret("GetLatestVimScripts : nothing done!") - return - endtry - exe "norm! kz\" - redraw! - let s:msg = "" - if s:downloads == 1 - let s:msg = "Downloaded one updated script to <".datadir.">" - elseif s:downloads == 2 - let s:msg= "Downloaded two updated scripts to <".datadir.">" - elseif s:downloads > 1 - let s:msg= "Downloaded ".s:downloads." updated scripts to <".datadir.">" - else - let s:msg= "Everything was already current" - endif - if s:downerrors > 0 - let s:msg= s:msg." (".s:downerrors." downloading errors)" - endif - echomsg s:msg - " save the file - if &mod - silent! w! - endif - q - - " restore events and current directory - exe "cd ".fnameescape(substitute(origdir,'\','/','ge')) - let &ei= eikeep - let &hls= hlskeep - setlocal nolz -" call Dredir("BUFFER TEST (GetLatestVimScripts 2)","ls!") -" call Dret("GetLatestVimScripts : did ".s:downloads." downloads") -endfun - -" --------------------------------------------------------------------- -" GetOneScript: (Get Latest Vim Script) this function operates {{{1 -" on the current line, interpreting two numbers and text as -" ScriptID, SourceID, and Filename. -" It downloads any scripts that have newer versions from vim.sf.net. -fun! s:GetOneScript(...) -" call Dfunc("GetOneScript()") - - " set options to allow progress to be shown on screen - let rega= @a - let t_ti= &t_ti - let t_te= &t_te - let rs = &rs - set t_ti= t_te= nors - - " put current line on top-of-screen and interpret it into - " a script identifer : used to obtain webpage - " source identifier : used to identify current version - " and an associated comment: used to report on what's being considered - if a:0 >= 3 - let scriptid = a:1 - let srcid = a:2 - let fname = a:3 - let cmmnt = "" -" call Decho("scriptid<".scriptid.">") -" call Decho("srcid <".srcid.">") -" call Decho("fname <".fname.">") - else - let curline = getline(".") - if curline =~ '^\s*#' - let @a= rega -" call Dret("GetOneScript : skipping a pure comment line") - return - endif - let parsepat = '^\s*\(\d\+\)\s\+\(\d\+\)\s\+\(.\{-}\)\(\s*#.*\)\=$' - try - let scriptid = substitute(curline,parsepat,'\1','e') - catch /^Vim\%((\a\+)\)\=:E486/ - let scriptid= 0 - endtry - try - let srcid = substitute(curline,parsepat,'\2','e') - catch /^Vim\%((\a\+)\)\=:E486/ - let srcid= 0 - endtry - try - let fname= substitute(curline,parsepat,'\3','e') - catch /^Vim\%((\a\+)\)\=:E486/ - let fname= "" - endtry - try - let cmmnt= substitute(curline,parsepat,'\4','e') - catch /^Vim\%((\a\+)\)\=:E486/ - let cmmnt= "" - endtry -" call Decho("curline <".curline.">") -" call Decho("parsepat<".parsepat.">") -" call Decho("scriptid<".scriptid.">") -" call Decho("srcid <".srcid.">") -" call Decho("fname <".fname.">") - endif - - if scriptid == 0 || srcid == 0 - " When looking for :AutoInstall: lines, skip scripts that have 0 0 scriptname - let @a= rega -" call Dret("GetOneScript : skipping a scriptid==srcid==0 line") - return - endif - - let doautoinstall= 0 - if fname =~ ":AutoInstall:" -" call Decho("case AutoInstall: fname<".fname.">") - let aicmmnt= substitute(fname,'\s\+:AutoInstall:\s\+',' ','') -" call Decho("aicmmnt<".aicmmnt."> s:autoinstall=".s:autoinstall) - if s:autoinstall != "" - let doautoinstall = g:GetLatestVimScripts_allowautoinstall - endif - else - let aicmmnt= fname - endif -" call Decho("aicmmnt<".aicmmnt.">: doautoinstall=".doautoinstall) - - exe "norm z\" - redraw! -" call Decho('considering <'.aicmmnt.'> scriptid='.scriptid.' srcid='.srcid) - echo 'considering <'.aicmmnt.'> scriptid='.scriptid.' srcid='.srcid - - " grab a copy of the plugin's vim.sf.net webpage - let scriptaddr = 'http://vim.sf.net/script.php?script_id='.scriptid - let tmpfile = tempname() - let v:errmsg = "" - - " make up to three tries at downloading the description - let itry= 1 - while itry <= 3 -" call Decho("try#".itry." to download description of <".aicmmnt."> with addr=".scriptaddr) - if has("win32") || has("win16") || has("win95") -" call Decho("new|exe silent r!".g:GetLatestVimScripts_wget." ".g:GetLatestVimScripts_options." ".s:Escape(tmpfile).' '.s:Escape(scriptaddr)."|bw!") - new|exe "silent r!".g:GetLatestVimScripts_wget." ".g:GetLatestVimScripts_options." ".s:Escape(tmpfile).' '.s:Escape(scriptaddr)|bw! - else -" call Decho("exe silent !".g:GetLatestVimScripts_wget." ".g:GetLatestVimScripts_options." ".s:Escape(tmpfile)." ".s:Escape(scriptaddr)) - exe "silent !".g:GetLatestVimScripts_wget." ".g:GetLatestVimScripts_options." ".s:Escape(tmpfile)." ".s:Escape(scriptaddr) - endif - if itry == 1 - exe "silent vsplit ".fnameescape(tmpfile) - else - silent! e % - endif - setlocal bh=wipe - - " find the latest source-id in the plugin's webpage - silent! 1 - let findpkg= search('Click on the package to download','W') - if findpkg > 0 - break - endif - let itry= itry + 1 - endwhile -" call Decho(" --- end downloading tries while loop --- itry=".itry) - - " testing: did finding "Click on the package..." fail? - if findpkg == 0 || itry >= 4 - silent q! - call delete(tmpfile) - " restore options - let &t_ti = t_ti - let &t_te = t_te - let &rs = rs - let s:downerrors = s:downerrors + 1 -" call Decho("***warning*** couldn'".'t find "Click on the package..." in description page for <'.aicmmnt.">") - echomsg "***warning*** couldn'".'t find "Click on the package..." in description page for <'.aicmmnt.">" -" call Dret("GetOneScript : srch for /Click on the package/ failed") - let @a= rega - return - endif -" call Decho('found "Click on the package to download"') - - let findsrcid= search('src_id=','W') - if findsrcid == 0 - silent q! - call delete(tmpfile) - " restore options - let &t_ti = t_ti - let &t_te = t_te - let &rs = rs - let s:downerrors = s:downerrors + 1 -" call Decho("***warning*** couldn'".'t find "src_id=" in description page for <'.aicmmnt.">") - echomsg "***warning*** couldn'".'t find "src_id=" in description page for <'.aicmmnt.">" - let @a= rega -" call Dret("GetOneScript : srch for /src_id/ failed") - return - endif -" call Decho('found "src_id=" in description page') - - let srcidpat = '^\s*\([^<]\+\)<.*$' - let latestsrcid= substitute(getline("."),srcidpat,'\1','') - let sname = substitute(getline("."),srcidpat,'\2','') " script name actually downloaded -" call Decho("srcidpat<".srcidpat."> latestsrcid<".latestsrcid."> sname<".sname.">") - silent q! - call delete(tmpfile) - - " convert the strings-of-numbers into numbers - let srcid = srcid + 0 - let latestsrcid = latestsrcid + 0 -" call Decho("srcid=".srcid." latestsrcid=".latestsrcid." sname<".sname.">") - - " has the plugin's most-recent srcid increased, which indicates - " that it has been updated - if latestsrcid > srcid -" call Decho("[latestsrcid=".latestsrcid."] <= [srcid=".srcid."]: need to update <".sname.">") - - let s:downloads= s:downloads + 1 - if sname == bufname("%") - " GetLatestVimScript has to be careful about downloading itself - let sname= "NEW_".sname - endif - - " the plugin has been updated since we last obtained it, so download a new copy -" call Decho("...downloading new <".sname.">") - echomsg "...downloading new <".sname.">" - if has("win32") || has("win16") || has("win95") -" call Decho("new|exe silent r!".g:GetLatestVimScripts_wget." ".g:GetLatestVimScripts_options." ".s:Escape(sname)." ".s:Escape('http://vim.sf.net/scripts/download_script.php?src_id='.latestsrcid)."|q") - new|exe "silent r!".g:GetLatestVimScripts_wget." ".g:GetLatestVimScripts_options." ".s:Escape(sname)." ".s:Escape('http://vim.sf.net/scripts/download_script.php?src_id='.latestsrcid)|q - else -" call Decho("exe silent !".g:GetLatestVimScripts_wget." ".g:GetLatestVimScripts_options." ".s:Escape(sname)." ".s:Escape('http://vim.sf.net/scripts/download_script.php?src_id=')) - exe "silent !".g:GetLatestVimScripts_wget." ".g:GetLatestVimScripts_options." ".s:Escape(sname)." ".s:Escape('http://vim.sf.net/scripts/download_script.php?src_id=').latestsrcid - endif - - " AutoInstall: only if doautoinstall has been requested by the plugin itself - if doautoinstall -" call Decho("attempting to do autoinstall: getcwd<".getcwd()."> filereadable(".sname.")=".filereadable(sname)) - if filereadable(sname) -" call Decho("exe silent !".g:GetLatestVimScripts_mv." ".s:Escape(sname)." ".s:Escape(s:autoinstall)) - exe "silent !".g:GetLatestVimScripts_mv." ".s:Escape(sname)." ".s:Escape(s:autoinstall) - let curdir = escape(substitute(getcwd(),'\','/','ge'),"|[]*'\" #") - let installdir= curdir."/Installed" - if !isdirectory(installdir) - call mkdir(installdir) - endif -" call Decho("exe cd ".fnameescape(s:autoinstall)) - exe "cd ".fnameescape(s:autoinstall) - - " decompress - if sname =~ '\.bz2$' -" call Decho("decompress: attempt to bunzip2 ".sname) - exe "silent !bunzip2 ".s:Escape(sname) - let sname= substitute(sname,'\.bz2$','','') -" call Decho("decompress: new sname<".sname."> after bunzip2") - elseif sname =~ '\.gz$' -" call Decho("decompress: attempt to gunzip ".sname) - exe "silent !gunzip ".s:Escape(sname) - let sname= substitute(sname,'\.gz$','','') -" call Decho("decompress: new sname<".sname."> after gunzip") - endif - - " distribute archive(.zip, .tar, .vba) contents - if sname =~ '\.zip$' -" call Decho("dearchive: attempt to unzip ".sname) - exe "silent !unzip -o ".s:Escape(sname) - elseif sname =~ '\.tar$' -" call Decho("dearchive: attempt to untar ".sname) - exe "silent !tar -xvf ".s:Escape(sname) - elseif sname =~ '\.vba$' -" call Decho("dearchive: attempt to handle a vimball: ".sname) - silent 1split - exe "silent e ".fnameescape(sname) - silent so % - silent q - endif - - if sname =~ '.vim$' -" call Decho("dearchive: attempt to simply move ".sname." to plugin") - exe "silent !".g:GetLatestVimScripts_mv." ".s:Escape(sname)." plugin" - else -" call Decho("dearchive: move <".sname."> to installdir<".installdir.">") - exe "silent !".g:GetLatestVimScripts_mv." ".s:Escape(sname)." ".installdir - endif - - " helptags step - let docdir= substitute(&rtp,',.*','','e')."/doc" -" call Decho("helptags: docdir<".docdir.">") - exe "helptags ".fnameescape(docdir) - exe "cd ".fnameescape(curdir) - endif - if fname !~ ':AutoInstall:' - let modline=scriptid." ".latestsrcid." :AutoInstall: ".fname.cmmnt - else - let modline=scriptid." ".latestsrcid." ".fname.cmmnt - endif - else - let modline=scriptid." ".latestsrcid." ".fname.cmmnt - endif - - " update the data in the file - call setline(line("."),modline) -" call Decho("update data in ".expand("%")."#".line(".").": modline<".modline.">") -" else " Decho -" call Decho("[latestsrcid=".latestsrcid."] <= [srcid=".srcid."], no need to update") - endif - - " restore options - let &t_ti = t_ti - let &t_te = t_te - let &rs = rs - let @a = rega -" call Dredir("BUFFER TEST (GetOneScript)","ls!") - -" call Dret("GetOneScript") -endfun - -" --------------------------------------------------------------------- -" s:Escape: makes a string safe&suitable for the shell {{{2 -fun! s:Escape(name) -" call Dfunc("s:Escape(name<".a:name.">)") - if exists("*shellescape") - " shellescape() was added by patch 7.0.111 - let name= shellescape(a:name) - else - let name= g:getscript_shq . a:name . g:getscript_shq - endif -" call Dret("s:Escape ".name) - return name -endfun - -" --------------------------------------------------------------------- -" Restore Options: {{{1 -let &cpo= s:keepcpo -unlet s:keepcpo - -" --------------------------------------------------------------------- -" Modelines: {{{1 -" vim: ts=8 sts=2 fdm=marker nowrap diff --git a/share/vim/vim72/autoload/netrw.vim b/share/vim/vim72/autoload/netrw.vim deleted file mode 100644 index 1e181d05d1..0000000000 --- a/share/vim/vim72/autoload/netrw.vim +++ /dev/null @@ -1,7764 +0,0 @@ -" netrw.vim: Handles file transfer and remote directory listing across -" AUTOLOAD SECTION -" Date: Aug 08, 2008 -" Version: 132 -" Maintainer: Charles E Campbell, Jr -" GetLatestVimScripts: 1075 1 :AutoInstall: netrw.vim -" Copyright: Copyright (C) 1999-2008 Charles E. Campbell, Jr. {{{1 -" Permission is hereby granted to use and distribute this code, -" with or without modifications, provided that this copyright -" notice is copied with it. Like anything else that's free, -" netrw.vim, netrwPlugin.vim, and netrwSettings.vim are provided -" *as is* and come with no warranty of any kind, either -" expressed or implied. By using this plugin, you agree that -" in no event will the copyright holder be liable for any damages -" resulting from the use of this software. -"redraw!|call DechoSep()|call inputsave()|call input("Press to continue")|call inputrestore() -" -" But be doers of the Word, and not only hearers, deluding your own selves {{{1 -" (James 1:22 RSV) -" =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=- -" Load Once: {{{1 -if &cp || exists("g:loaded_netrw") - finish -endif -if !exists("s:NOTE") - let s:NOTE = 0 - let s:WARNING = 1 - let s:ERROR = 2 -endif -let g:loaded_netrw = "v132" - -" sanity checks -if v:version < 700 - call netrw#ErrorMsg(s:WARNING,"you need vim version 7.0 or later for version ".g:loaded_netrw." of netrw",1) - finish -endif - -let s:keepcpo= &cpo -setlocal cpo&vim -"DechoTabOn -"call Decho("doing autoload/netrw.vim version ".g:loaded_netrw) - -" ====================== -" Netrw Variables: {{{1 -" ====================== - -" --------------------------------------------------------------------- -" Netrw Constants: {{{2 -if !exists("g:NETRW_BOOKMARKMAX") - let g:NETRW_BOOKMARKMAX= 0 -endif -if !exists("g:NETRW_DIRHIST_CNT") - let g:NETRW_DIRHIST_CNT= 0 -endif -if !exists("s:LONGLIST") - let s:THINLIST = 0 - let s:LONGLIST = 1 - let s:WIDELIST = 2 - let s:TREELIST = 3 - let s:MAXLIST = 4 -endif - -" --------------------------------------------------------------------- -" Default values for netrw's global protocol variables {{{2 -if !exists("g:netrw_dav_cmd") - let g:netrw_dav_cmd = "cadaver" -endif -if !exists("g:netrw_fetch_cmd") - if executable("fetch") - let g:netrw_fetch_cmd = "fetch -o" - else - let g:netrw_fetch_cmd = "" - endif -endif -if !exists("g:netrw_ftp_cmd") - let g:netrw_ftp_cmd = "ftp" -endif -if !exists("g:netrw_http_cmd") - if executable("elinks") - let g:netrw_http_cmd = "elinks" - let g:netrw_http_xcmd= "-dump >" - elseif executable("links") - let g:netrw_http_cmd = "links" - let g:netrw_http_xcmd= "-dump >" - elseif executable("curl") - let g:netrw_http_cmd = "curl -o" - elseif executable("wget") - let g:netrw_http_cmd = "wget -q -O" - elseif executable("fetch") - let g:netrw_http_cmd = "fetch -o" - else - let g:netrw_http_cmd = "" - endif -endif -if !exists("g:netrw_rcp_cmd") - let g:netrw_rcp_cmd = "rcp" -endif -if !exists("g:netrw_rsync_cmd") - let g:netrw_rsync_cmd = "rsync" -endif -if !exists("g:netrw_scp_cmd") - let g:netrw_scp_cmd = "scp -q" -endif -if !exists("g:netrw_sftp_cmd") - let g:netrw_sftp_cmd = "sftp" -endif -if !exists("g:netrw_ssh_cmd") - let g:netrw_ssh_cmd= "ssh" -endif - -if (has("win32") || has("win95") || has("win64") || has("win16")) - \ && exists("g:netrw_use_nt_rcp") - \ && g:netrw_use_nt_rcp - \ && executable( $SystemRoot .'/system32/rcp.exe') - let s:netrw_has_nt_rcp = 1 - let s:netrw_rcpmode = '-b' -else - let s:netrw_has_nt_rcp = 0 - let s:netrw_rcpmode = '' -endif - -" --------------------------------------------------------------------- -" Default values for netrw's global variables {{{2 -" Cygwin Detection ------- {{{3 -if !exists("g:netrw_cygwin") - if has("win32") || has("win95") || has("win64") || has("win16") - if &shell =~ '\%(\\|\\)\%(\.exe\)\=$' - let g:netrw_cygwin= 1 - else - let g:netrw_cygwin= 0 - endif - else - let g:netrw_cygwin= 0 - endif -endif -" Default values - a-c ---------- {{{3 -if !exists("g:netrw_alto") - let g:netrw_alto= &sb -endif -if !exists("g:netrw_altv") - let g:netrw_altv= &spr -endif -if !exists("g:netrw_browse_split") - let g:netrw_browse_split= 0 -endif -if !exists("g:netrw_chgwin") - let g:netrw_chgwin = -1 -endif -if !exists("g:netrw_compress") - let g:netrw_compress= "gzip" -endif -if !exists("g:netrw_ctags") - let g:netrw_ctags= "ctags" -endif -" Default values - d-g ---------- {{{3 -if !exists("g:NETRW_DIRHIST_CNT") - let g:NETRW_DIRHIST_CNT= 0 -endif -if !exists("g:netrw_decompress") - let g:netrw_decompress= { ".gz" : "gunzip" , ".bz2" : "bunzip2" , ".zip" : "unzip" , ".tar" : "tar -xf"} -endif -if !exists("g:netrw_dirhistmax") - let g:netrw_dirhistmax= 10 -endif -if !exists("g:netrw_fastbrowse") - let g:netrw_fastbrowse= 1 -endif -if !exists("g:netrw_ftp_browse_reject") - let g:netrw_ftp_browse_reject='^total\s\+\d\+$\|^Trying\s\+\d\+.*$\|^KERBEROS_V\d rejected\|^Security extensions not\|No such file\|: connect to address [0-9a-fA-F:]*: No route to host$' -endif -if !exists("g:netrw_ftp_list_cmd") - if has("unix") || (exists("g:netrw_cygwin") && g:netrw_cygwin) - let g:netrw_ftp_list_cmd = "ls -lF" - let g:netrw_ftp_timelist_cmd = "ls -tlF" - let g:netrw_ftp_sizelist_cmd = "ls -slF" - else - let g:netrw_ftp_list_cmd = "dir" - let g:netrw_ftp_timelist_cmd = "dir" - let g:netrw_ftp_sizelist_cmd = "dir" - endif -endif -if !exists("g:netrw_ftpmode") - let g:netrw_ftpmode= "binary" -endif -" Default values - h-lh ---------- {{{3 -if !exists("g:netrw_hide") - let g:netrw_hide= 1 -endif -if !exists("g:netrw_ignorenetrc") - if &shell =~ '\c\<\%(cmd\|4nt\)\.exe$' - let g:netrw_ignorenetrc= 1 - else - let g:netrw_ignorenetrc= 0 - endif -endif -if !exists("g:netrw_keepdir") - let g:netrw_keepdir= 1 -endif -if !exists("g:netrw_list_cmd") - if g:netrw_scp_cmd =~ '^pscp' && executable("pscp") - " provide a 'pscp' listing command - if (has("win32") || has("win95") || has("win64") || has("win16")) && filereadable("c:\\private.ppk") - let g:netrw_scp_cmd ="pscp -i C:\\private.ppk" - endif - let g:netrw_list_cmd= g:netrw_scp_cmd." -ls USEPORT HOSTNAME:" - elseif executable(g:netrw_ssh_cmd) - " provide a default listing command - let g:netrw_list_cmd= g:netrw_ssh_cmd." USEPORT HOSTNAME ls -FLa" - else -" call Decho(g:netrw_ssh_cmd." is not executable") - let g:netrw_list_cmd= "" - endif -endif -if !exists("g:netrw_list_hide") - let g:netrw_list_hide= "" -endif -" Default values - lh-lz ---------- {{{3 -if !exists("g:netrw_localcopycmd") - if has("win32") || has("win95") || has("win64") || has("win16") - if g:netrw_cygwin - let g:netrw_localcopycmd= "cp" - else - let g:netrw_localcopycmd= "copy" - endif - elseif has("unix") || has("macunix") - let g:netrw_localcopycmd= "cp" - else - let g:netrw_localcopycmd= "" - endif -endif -if !exists("g:netrw_local_mkdir") - let g:netrw_local_mkdir= "mkdir" -endif -if !exists("g:netrw_localmovecmd") - if has("win32") || has("win95") || has("win64") || has("win16") - if g:netrw_cygwin - let g:netrw_localmovecmd= "mv" - else - let g:netrw_localmovecmd= "move" - endif - elseif has("unix") || has("macunix") - let g:netrw_localmovecmd= "mv" - else - let g:netrw_localmovecmd= "" - endif -endif -if !exists("g:netrw_local_rmdir") - let g:netrw_local_rmdir= "rmdir" -endif -if !exists("g:netrw_liststyle") - let g:netrw_liststyle= s:THINLIST -endif -if g:netrw_liststyle < 0 || g:netrw_liststyle >= s:MAXLIST - " sanity check - let g:netrw_liststyle= s:THINLIST -endif -if g:netrw_liststyle == s:LONGLIST && g:netrw_scp_cmd !~ '^pscp' - let g:netrw_list_cmd= g:netrw_list_cmd." -l" -endif -" Default values - m-r ---------- {{{3 -if !exists("g:netrw_markfileesc") - let g:netrw_markfileesc= '*./[\~' -endif -if !exists("g:netrw_maxfilenamelen") - let g:netrw_maxfilenamelen= 32 -endif -if !exists("g:netrw_menu") - let g:netrw_menu= 1 -endif -if !exists("g:netrw_mkdir_cmd") - let g:netrw_mkdir_cmd= g:netrw_ssh_cmd." USEPORT HOSTNAME mkdir" -endif -if !exists("g:netrw_mousemaps") - if exists("&mouse") && &mouse =~ '[anh]' - let g:netrw_mousemaps= 1 - else - let g:netrw_mousemaps= 0 - endif -endif -if !exists("g:netrw_retmap") - let g:netrw_retmap= 0 -endif -if !exists("g:netrw_preview") - let g:netrw_preview= 0 -endif -if !exists("g:netrw_scpport") - let g:netrw_scpport= "-P" -endif -if !exists("g:netrw_sshport") - let g:netrw_sshport= "-p" -endif -if !exists("g:netrw_rename_cmd") - let g:netrw_rename_cmd= g:netrw_ssh_cmd." USEPORT HOSTNAME mv" -endif -if !exists("g:netrw_rm_cmd") - let g:netrw_rm_cmd = g:netrw_ssh_cmd." USEPORT HOSTNAME rm" -endif -if !exists("g:netrw_rmdir_cmd") - let g:netrw_rmdir_cmd = g:netrw_ssh_cmd." USEPORT HOSTNAME rmdir" -endif -if !exists("g:netrw_rmf_cmd") - let g:netrw_rmf_cmd = g:netrw_ssh_cmd." USEPORT HOSTNAME rm -f" -endif -" Default values - s ---------- {{{3 - " set up shell quoting character -if exists("g:netrw_silent") && g:netrw_silent != 0 - let s:netrw_silentxfer= "silent " -else - let s:netrw_silentxfer= "" -endif -if !exists("g:netrw_sort_by") - " alternatives: date size - let g:netrw_sort_by= "name" -endif -if !exists("g:netrw_sort_options") - let g:netrw_sort_options= "" -endif -if !exists("g:netrw_sort_direction") - " alternative: reverse (z y x ...) - let g:netrw_sort_direction= "normal" -endif -if !exists("g:netrw_sort_sequence") - let g:netrw_sort_sequence= '[\/]$,\.h$,\.c$,\.cpp$,*,\.o$,\.obj$,\.info$,\.swp$,\.bak$,\~$' -endif -if !exists("g:netrw_special_syntax") - let g:netrw_special_syntax= 0 -endif -if !exists("g:netrw_ssh_browse_reject") - let g:netrw_ssh_browse_reject='^total\s\+\d\+$' -endif -if !has("patch192") - if !exists("g:netrw_use_noswf") - let g:netrw_use_noswf= 1 - endif -else - let g:netrw_use_noswf= 0 -endif -" Default values - t-w ---------- {{{3 -if !exists("g:netrw_timefmt") - let g:netrw_timefmt= "%c" -endif -if !exists("g:netrw_xstrlen") - let g:netrw_xstrlen= 1 -endif -if !exists("g:NetrwTopLvlMenu") - let g:NetrwTopLvlMenu= "Netrw." -endif -if !exists("g:netrw_use_errorwindow") - let g:netrw_use_errorwindow= 1 -endif -if !exists("g:netrw_win95ftp") - let g:netrw_win95ftp= 1 -endif -if !exists("g:netrw_winsize") - let g:netrw_winsize= "" -endif -" --------------------------------------------------------------------- -" Default values for netrw's script variables: {{{2 -if !exists("g:netrw_fname_escape") - let g:netrw_fname_escape= ' ?&;%' -endif -if !exists("g:netrw_glob_escape") - let g:netrw_glob_escape= '[]*?`{~$' -endif -if !exists("g:netrw_tmpfile_escape") - let g:netrw_tmpfile_escape= ' &;' -endif -let s:netrw_map_escape = "<|\n\r\\\\"" - -" BufEnter event ignored by decho when following variable is true -" Has a side effect that doau BufReadPost doesn't work, so -" files read by network transfer aren't appropriately highlighted. -"let g:decho_bufenter = 1 "Decho - -" ============================== -" Netrw Utility Functions: {{{1 -" ============================== - -" ------------------------------------------------------------------------ -" s:NetrwOptionSave: save options and set to "standard" form {{{2 -" 06/08/07 : removed call to NetrwSafeOptions(), either placed -" immediately after NetrwOptionSave() calls in NetRead -" and NetWrite, or after the s:NetrwEnew() call in -" NetrwBrowse. -" vt: normally its "w:" or "s:" (a variable type) -fun! s:NetrwOptionSave(vt) -" call Dfunc("s:NetrwOptionSave(vt<".a:vt.">) win#".winnr()." buf#".bufnr("%")."<".bufname(bufnr("%")).">") - -" call Decho(a:vt."netrw_optionsave".(exists("{a:vt}netrw_optionsave")? ("=".{a:vt}netrw_optionsave) : " doesn't exist")) - if !exists("{a:vt}netrw_optionsave") - let {a:vt}netrw_optionsave= 1 - else -" call Dret("s:NetrwOptionSave : options already saved") - return - endif -" call Decho("fo=".&fo.(exists("&acd")? " acd=".&acd : " acd doesn't exist")) - - " Save current settings and current directory - let s:yykeep = @@ - if exists("&l:acd") - let {a:vt}netrw_acdkeep = &l:acd - endif - let {a:vt}netrw_aikeep = &l:ai - let {a:vt}netrw_awkeep = &l:aw - let {a:vt}netrw_cikeep = &l:ci - let {a:vt}netrw_cinkeep = &l:cin - let {a:vt}netrw_cinokeep = &l:cino - let {a:vt}netrw_comkeep = &l:com - let {a:vt}netrw_cpokeep = &l:cpo - if g:netrw_keepdir - let {a:vt}netrw_dirkeep = getcwd() - endif - let {a:vt}netrw_fokeep = &l:fo " formatoptions - let {a:vt}netrw_gdkeep = &l:gd " gdefault - let {a:vt}netrw_hidkeep = &l:hidden - let {a:vt}netrw_magickeep = &l:magic - let {a:vt}netrw_repkeep = &l:report - let {a:vt}netrw_spellkeep = &l:spell - let {a:vt}netrw_twkeep = &l:tw " textwidth - let {a:vt}netrw_wigkeep = &l:wig " wildignore - if has("win32") && !has("win95") - let {a:vt}netrw_swfkeep = &l:swf " swapfile - endif - if &go =~ 'a' | silent! let {a:vt}netrw_regstar = @* | endif - silent! let {a:vt}netrw_regslash= @/ - -" call Dret("s:NetrwOptionSave : win#".winnr()." buf#".bufnr("%")) -endfun - -" ------------------------------------------------------------------------ -" s:NetrwOptionRestore: restore options {{{2 -fun! s:NetrwOptionRestore(vt) -" call Dfunc("s:NetrwOptionRestore(vt<".a:vt.">) win#".winnr()." buf#".bufnr("%")) - if !exists("{a:vt}netrw_optionsave") -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Dret("s:NetrwOptionRestore : ".a:vt."netrw_optionsave doesn't exist") - return - endif - unlet {a:vt}netrw_optionsave - - if exists("&acd") - if exists("{a:vt}netrw_acdkeep") -" call Decho("g:netrw_keepdir=".g:netrw_keepdir.": getcwd<".getcwd()."> acd=".&acd) - let curdir = getcwd() - let &l:acd = {a:vt}netrw_acdkeep - unlet {a:vt}netrw_acdkeep - if &l:acd -" call Decho("exe keepjumps lcd ".fnameescape(curdir)) " NOTE: was g:netrw_fname_escape for some reason - try - if !exists("&l:acd") && !&l:acd - exe 'keepjumps lcd '.fnameescape(curdir) - endif - catch /^Vim\%((\a\+)\)\=:E472/ - call netrw#ErrorMsg(s:ERROR,"unable to change directory to <".curdir."> (permissions?)",61) - endtry - endif - endif - endif - if exists("{a:vt}netrw_aikeep") |let &l:ai = {a:vt}netrw_aikeep |unlet {a:vt}netrw_aikeep |endif - if exists("{a:vt}netrw_awkeep") |let &l:aw = {a:vt}netrw_awkeep |unlet {a:vt}netrw_awkeep |endif - if exists("{a:vt}netrw_cikeep") |let &l:ci = {a:vt}netrw_cikeep |unlet {a:vt}netrw_cikeep |endif - if exists("{a:vt}netrw_cinkeep") |let &l:cin = {a:vt}netrw_cinkeep |unlet {a:vt}netrw_cinkeep |endif - if exists("{a:vt}netrw_cinokeep") |let &l:cino = {a:vt}netrw_cinokeep |unlet {a:vt}netrw_cinokeep |endif - if exists("{a:vt}netrw_comkeep") |let &l:com = {a:vt}netrw_comkeep |unlet {a:vt}netrw_comkeep |endif - if exists("{a:vt}netrw_cpokeep") |let &l:cpo = {a:vt}netrw_cpokeep |unlet {a:vt}netrw_cpokeep |endif - if exists("{a:vt}netrw_dirkeep") && isdirectory({a:vt}netrw_dirkeep) && g:netrw_keepdir - let dirkeep = substitute({a:vt}netrw_dirkeep,'\\','/','g') - if exists("{a:vt}netrw_dirkeep") |exe "keepjumps lcd ".fnameescape(dirkeep)|unlet {a:vt}netrw_dirkeep |endif - endif - if exists("{a:vt}netrw_fokeep") |let &l:fo = {a:vt}netrw_fokeep |unlet {a:vt}netrw_fokeep |endif - if exists("{a:vt}netrw_gdkeep") |let &l:gd = {a:vt}netrw_gdkeep |unlet {a:vt}netrw_gdkeep |endif - if exists("{a:vt}netrw_hidkeep") |let &l:hidden = {a:vt}netrw_hidkeep |unlet {a:vt}netrw_hidkeep |endif - if exists("{a:vt}netrw_magic") |let &l:magic = {a:vt}netrw_magic |unlet {a:vt}netrw_magic |endif - if exists("{a:vt}netrw_repkeep") |let &l:report = {a:vt}netrw_repkeep |unlet {a:vt}netrw_repkeep |endif - if exists("{a:vt}netrw_spellkeep")|let &l:spell = {a:vt}netrw_spellkeep |unlet {a:vt}netrw_spellkeep|endif - if exists("{a:vt}netrw_twkeep") |let &l:tw = {a:vt}netrw_twkeep |unlet {a:vt}netrw_twkeep |endif - if exists("{a:vt}netrw_wigkeep") |let &l:wig = {a:vt}netrw_wigkeep |unlet {a:vt}netrw_wigkeep |endif - if exists("s:yykeep") |let @@ = s:yykeep |unlet s:yykeep |endif - if exists("{a:vt}netrw_swfkeep") - if &directory == "" - " user hasn't specified a swapfile directory; - " netrw will temporarily set the swapfile directory - " to the current directory as returned by getcwd(). - let &l:directory = getcwd() - silent! let &l:swf = {a:vt}netrw_swfkeep - setlocal directory= - unlet {a:vt}netrw_swfkeep - elseif &l:swf != {a:vt}netrw_swfkeep - " following line causes a Press ENTER in windows -- can't seem to work around it!!! - silent! let &l:swf= {a:vt}netrw_swfkeep - unlet {a:vt}netrw_swfkeep - endif - endif - if exists("{a:vt}netrw_regstar") |silent! let @*= {a:vt}netrw_regstar |unlet {a:vt}netrw_regstar |endif - if exists("{a:vt}netrw_regslash")|silent! let @/= {a:vt}netrw_regslash|unlet {a:vt}netrw_regslash|endif - -" call Decho("g:netrw_keepdir=".g:netrw_keepdir.": getcwd<".getcwd()."> acd=".&acd) -" call Decho("fo=".&fo.(exists("&acd")? " acd=".&acd : " acd doesn't exist")) -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Dret("s:NetrwOptionRestore : win#".winnr()." buf#".bufnr("%")) -endfun - -" --------------------------------------------------------------------- -" s:NetrwSafeOptions: sets options to help netrw do its job {{{2 -fun! s:NetrwSafeOptions() -" call Dfunc("s:NetrwSafeOptions() win#".winnr()." buf#".bufnr("%")."<".bufname(bufnr("%")).">") -" call Decho("window's ft=".&ft) - setlocal cino= - setlocal com= - setlocal cpo-=aA - if exists("&acd") | setlocal noacd | endif - setlocal nocin noai noci magic nospell nohid wig= noaw - setlocal fo=nroql2 - setlocal tw=0 - setlocal report=10000 - if g:netrw_use_noswf && has("win32") && !has("win95") - setlocal noswf - endif -" call Decho("fo=".&fo.(exists("&acd")? " acd=".&acd : " acd doesn't exist")) -" call Dret("s:NetrwSafeOptions") -endfun - -" --------------------------------------------------------------------- -" netrw#NetrwClean: remove netrw {{{2 -" supports :NetrwClean -- remove netrw from first directory on runtimepath -" :NetrwClean! -- remove netrw from all directories on runtimepath -fun! netrw#NetrwClean(sys) -" call Dfunc("netrw#NetrwClean(sys=".a:sys.")") - - if a:sys - let choice= confirm("Remove personal and system copies of netrw?","&Yes\n&No") - else - let choice= confirm("Remove personal copy of netrw?","&Yes\n&No") - endif -" call Decho("choice=".choice) - let diddel= 0 - let diddir= "" - - if choice == 1 - for dir in split(&rtp,',') - if filereadable(dir."/plugin/netrwPlugin.vim") -" call Decho("removing netrw-related files from ".dir) - if s:NetrwDelete(dir."/plugin/netrwPlugin.vim") |call netrw#ErrorMsg(1,"unable to remove ".dir."/plugin/netrwPlugin.vim",55) |endif - if s:NetrwDelete(dir."/autoload/netrwFileHandlers.vim")|call netrw#ErrorMsg(1,"unable to remove ".dir."/autoload/netrwFileHandlers.vim",55)|endif - if s:NetrwDelete(dir."/autoload/netrwSettings.vim") |call netrw#ErrorMsg(1,"unable to remove ".dir."/autoload/netrwSettings.vim",55) |endif - if s:NetrwDelete(dir."/autoload/netrw.vim") |call netrw#ErrorMsg(1,"unable to remove ".dir."/autoload/netrw.vim",55) |endif - if s:NetrwDelete(dir."/syntax/netrw.vim") |call netrw#ErrorMsg(1,"unable to remove ".dir."/syntax/netrw.vim",55) |endif - if s:NetrwDelete(dir."/syntax/netrwlist.vim") |call netrw#ErrorMsg(1,"unable to remove ".dir."/syntax/netrwlist.vim",55) |endif - let diddir= dir - let diddel= diddel + 1 - if !a:sys|break|endif - endif - endfor - endif - - echohl WarningMsg - if diddel == 0 - echomsg "netrw is either not installed or not removable" - elseif diddel == 1 - echomsg "removed one copy of netrw from <".diddir.">" - else - echomsg "removed ".diddel." copies of netrw" - endif - echohl None - -" call Dret("netrw#NetrwClean") -endfun - -" ------------------------------------------------------------------------ -" Netrw Transfer Functions: {{{1 -" =============================== - -" ------------------------------------------------------------------------ -" netrw#NetRead: responsible for reading a file over the net {{{2 -" mode: =0 read remote file and insert before current line -" =1 read remote file and insert after current line -" =2 replace with remote file -" =3 obtain file, but leave in temporary format -fun! netrw#NetRead(mode,...) -" call Dfunc("netrw#NetRead(mode=".a:mode.",...) a:0=".a:0." ".g:loaded_netrw) - - " save options {{{3 - call s:NetrwOptionSave("w:") - call s:NetrwSafeOptions() - - " interpret mode into a readcmd {{{3 - if a:mode == 0 " read remote file before current line - let readcmd = "0r" - elseif a:mode == 1 " read file after current line - let readcmd = "r" - elseif a:mode == 2 " replace with remote file - let readcmd = "%r" - elseif a:mode == 3 " skip read of file (leave as temporary) - let readcmd = "t" - else - exe a:mode - let readcmd = "r" - endif - let ichoice = (a:0 == 0)? 0 : 1 -" call Decho("readcmd<".readcmd."> ichoice=".ichoice) - - " Get Temporary Filename {{{3 - let tmpfile= s:GetTempfile("") - if tmpfile == "" -" call Dret("netrw#NetRead : unable to get a tempfile!") - return - endif - - while ichoice <= a:0 - - " attempt to repeat with previous host-file-etc - if exists("b:netrw_lastfile") && a:0 == 0 -" call Decho("using b:netrw_lastfile<" . b:netrw_lastfile . ">") - let choice = b:netrw_lastfile - let ichoice= ichoice + 1 - - else - exe "let choice= a:" . ichoice -" call Decho("no lastfile: choice<" . choice . ">") - - if match(choice,"?") == 0 - " give help - echomsg 'NetRead Usage:' - echomsg ':Nread machine:path uses rcp' - echomsg ':Nread "machine path" uses ftp with <.netrc>' - echomsg ':Nread "machine id password path" uses ftp' - echomsg ':Nread dav://machine[:port]/path uses cadaver' - echomsg ':Nread fetch://machine/path uses fetch' - echomsg ':Nread ftp://[user@]machine[:port]/path uses ftp autodetects <.netrc>' - echomsg ':Nread http://[user@]machine/path uses http wget' - echomsg ':Nread rcp://[user@]machine/path uses rcp' - echomsg ':Nread rsync://machine[:port]/path uses rsync' - echomsg ':Nread scp://[user@]machine[[:#]port]/path uses scp' - echomsg ':Nread sftp://[user@]machine[[:#]port]/path uses sftp' - sleep 4 - break - - elseif match(choice,'^"') != -1 - " Reconstruct Choice if choice starts with '"' -" call Decho("reconstructing choice") - if match(choice,'"$') != -1 - " case "..." - let choice=strpart(choice,1,strlen(choice)-2) - else - " case "... ... ..." - let choice = strpart(choice,1,strlen(choice)-1) - let wholechoice = "" - - while match(choice,'"$') == -1 - let wholechoice = wholechoice . " " . choice - let ichoice = ichoice + 1 - if ichoice > a:0 - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"Unbalanced string in filename '". wholechoice ."'",3) - endif -" call Dret("netrw#NetRead :2 getcwd<".getcwd().">") - return - endif - let choice= a:{ichoice} - endwhile - let choice= strpart(wholechoice,1,strlen(wholechoice)-1) . " " . strpart(choice,0,strlen(choice)-1) - endif - endif - endif - -" call Decho("choice<" . choice . ">") - let ichoice= ichoice + 1 - - " Determine method of read (ftp, rcp, etc) {{{3 - call s:NetrwMethod(choice) - let tmpfile= s:GetTempfile(b:netrw_fname) " apply correct suffix - - " Check if NetrwBrowse() should be handling this request -" call Decho("checking if NetrwBrowse() should handle choice<".choice."> with netrw_list_cmd<".g:netrw_list_cmd.">") - if choice =~ "^.*[\/]$" && b:netrw_method != 5 && choice !~ '^http://' -" call Decho("yes, choice matches '^.*[\/]$'") - keepjumps call s:NetrwBrowse(0,choice) -" call Dret("netrw#NetRead :3 getcwd<".getcwd().">") - return - endif - - " ============ - " Perform Protocol-Based Read {{{3 - " =========================== - if exists("g:netrw_silent") && g:netrw_silent == 0 && &ch >= 1 - echo "(netrw) Processing your read request..." - endif - - "......................................... - " rcp: NetRead Method #1 {{{3 - if b:netrw_method == 1 " read with rcp -" call Decho("read via rcp (method #1)") - " ER: nothing done with g:netrw_uid yet? - " ER: on Win2K" rcp machine[.user]:file tmpfile - " ER: if machine contains '.' adding .user is required (use $USERNAME) - " ER: the tmpfile is full path: rcp sees C:\... as host C - if s:netrw_has_nt_rcp == 1 - if exists("g:netrw_uid") && ( g:netrw_uid != "" ) - let uid_machine = g:netrw_machine .'.'. g:netrw_uid - else - " Any way needed it machine contains a '.' - let uid_machine = g:netrw_machine .'.'. $USERNAME - endif - else - if exists("g:netrw_uid") && ( g:netrw_uid != "" ) - let uid_machine = g:netrw_uid .'@'. g:netrw_machine - else - let uid_machine = g:netrw_machine - endif - endif -" call Decho("executing: !".g:netrw_rcp_cmd." ".s:netrw_rcpmode." ".shellescape(uid_machine.":".b:netrw_fname,1)." ".shellescape(tmpfile,1)) - exe s:netrw_silentxfer."!".g:netrw_rcp_cmd." ".s:netrw_rcpmode." ".shellescape(uid_machine.":".b:netrw_fname,1)." ".shellescape(tmpfile,1)) - let result = s:NetrwGetFile(readcmd, tmpfile, b:netrw_method) - let b:netrw_lastfile = choice - - "......................................... - " ftp + <.netrc>: NetRead Method #2 {{{3 - elseif b:netrw_method == 2 " read with ftp + <.netrc> -" call Decho("read via ftp+.netrc (method #2)") - let netrw_fname= b:netrw_fname - call s:SaveBufVars()|new|call s:RestoreBufVars() - let filtbuf= bufnr("%") - setlocal ff=unix - put =g:netrw_ftpmode -" call Decho("filter input: ".getline(line("$"))) - if exists("g:netrw_ftpextracmd") - put =g:netrw_ftpextracmd -" call Decho("filter input: ".getline(line("$"))) - endif - call setline(line("$")+1,'get "'.netrw_fname.'" '.tmpfile) -" call Decho("filter input: ".getline(line("$"))) - if exists("g:netrw_port") && g:netrw_port != "" -" call Decho("executing: %!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine." ".g:netrw_port,1)) - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine." ".g:netrw_port,1) - else -" call Decho("executing: %!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)) - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1) - endif - " If the result of the ftp operation isn't blank, show an error message (tnx to Doug Claar) - if getline(1) !~ "^$" && !exists("g:netrw_quiet") && getline(1) !~ '^Trying ' - let debugkeep = &debug - setlocal debug=msg - call netrw#ErrorMsg(s:ERROR,getline(1),4) - let &debug = debugkeep - endif - call s:SaveBufVars() - bd! - if bufname("%") == "" && line("$") == 1 && getline("$") == "" - q! - endif - call s:RestoreBufVars() - let result = s:NetrwGetFile(readcmd, tmpfile, b:netrw_method) - let b:netrw_lastfile = choice - - "......................................... - " ftp + machine,id,passwd,filename: NetRead Method #3 {{{3 - elseif b:netrw_method == 3 " read with ftp + machine, id, passwd, and fname - " Construct execution string (four lines) which will be passed through filter -" call Decho("read via ftp+mipf (method #3)") - let netrw_fname= escape(b:netrw_fname,g:netrw_fname_escape) - call s:SaveBufVars()|new|call s:RestoreBufVars() - let filtbuf= bufnr("%") - setlocal ff=unix - if exists("g:netrw_port") && g:netrw_port != "" - put ='open '.g:netrw_machine.' '.g:netrw_port -" call Decho("filter input: ".getline('.')) - else - put ='open '.g:netrw_machine -" call Decho("filter input: ".getline('.')) - endif - - if exists("g:netrw_ftp") && g:netrw_ftp == 1 - put =g:netrw_uid -" call Decho("filter input: ".getline('.')) - put ='\"'.s:netrw_passwd.'\"' -" call Decho("filter input: ".getline('.')) - else - put ='user \"'.g:netrw_uid.'\" \"'.s:netrw_passwd.'\"' -" call Decho("filter input: ".getline('.')) - endif - - if exists("g:netrw_ftpmode") && g:netrw_ftpmode != "" - put =g:netrw_ftpmode -" call Decho("filter input: ".getline('.')) - endif - if exists("g:netrw_ftpextracmd") - put =g:netrw_ftpextracmd -" call Decho("filter input: ".getline('.')) - endif - put ='get \"'.netrw_fname.'\" '.tmpfile -" call Decho("filter input: ".getline('.')) - - " perform ftp: - " -i : turns off interactive prompting from ftp - " -n unix : DON'T use <.netrc>, even though it exists - " -n win32: quit being obnoxious about password - norm! 1Gdd -" call Decho("executing: %!".g:netrw_ftp_cmd." -i -n") - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i -n" - " If the result of the ftp operation isn't blank, show an error message (tnx to Doug Claar) - if getline(1) !~ "^$" -" call Decho("error<".getline(1).">") - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,getline(1),5) - endif - endif - call s:SaveBufVars()|bd!|call s:RestoreBufVars() - let result = s:NetrwGetFile(readcmd, tmpfile, b:netrw_method) - let b:netrw_lastfile = choice - - "......................................... - " scp: NetRead Method #4 {{{3 - elseif b:netrw_method == 4 " read with scp -" call Decho("read via scp (method #4)") - if exists("g:netrw_port") && g:netrw_port != "" - let useport= " ".g:netrw_scpport." ".g:netrw_port - else - let useport= "" - endif -" call Decho("exe s:netrw_silentxfer.!".g:netrw_scp_cmd.useport." ".shellescape(g:netrw_machine.":".b:netrw_fname,1)." ".shellescape(tmpfile,1)) - exe s:netrw_silentxfer."!".g:netrw_scp_cmd.useport." ".shellescape(g:netrw_machine.":".b:netrw_fname,1)." ".shellescape(tmpfile,1) - let result = s:NetrwGetFile(readcmd, tmpfile, b:netrw_method) - let b:netrw_lastfile = choice - - "......................................... - " http: NetRead Method #5 (wget) {{{3 - elseif b:netrw_method == 5 -" call Decho("read via http (method #5)") - if g:netrw_http_cmd == "" - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"neither the wget nor the fetch command is available",6) - endif -" call Dret("netrw#NetRead :4 getcwd<".getcwd().">") - return - endif - - if match(b:netrw_fname,"#") == -1 || exists("g:netrw_http_xcmd") - " using g:netrw_http_cmd (usually elinks, links, curl, wget, or fetch) -" call Decho('using '.g:netrw_http_cmd.' (# not in b:netrw_fname<'.b:netrw_fname.">)") - if exists("g:netrw_http_xcmd") -" call Decho("exe ".s:netrw_silentxfer."!".g:netrw_http_cmd." ".shellescape("http://".g:netrw_machine.b:netrw_fname,1)." ".g:netrw_http_xcmd." ".shellescape(tmpfile,1)) - exe s:netrw_silentxfer."!".g:netrw_http_cmd." ".shellescape("http://".g:netrw_machine.b:netrw_fname,1)." ".g:netrw_http_xcmd." ".shellescape(tmpfile,1) - else -" call Decho("exe ".s:netrw_silentxfer."!".g:netrw_http_cmd." ".shellescape(tmpfile,1)." ".shellescape("http://".g:netrw_machine.b:netrw_fname,1)) - exe s:netrw_silentxfer."!".g:netrw_http_cmd." ".shellescape(tmpfile,1)." ".shellescape("http://".g:netrw_machine.b:netrw_fname,1) - endif - let result = s:NetrwGetFile(readcmd, tmpfile, b:netrw_method) - - else - " wget/curl/fetch plus a jump to an in-page marker (ie. http://abc/def.html#aMarker) -" call Decho(("wget/curl plus jump (# in b:netrw_fname<".b:netrw_fname.">)") - let netrw_html= substitute(b:netrw_fname,"#.*$","","") - let netrw_tag = substitute(b:netrw_fname,"^.*#","","") -" call Decho("netrw_html<".netrw_html.">") -" call Decho("netrw_tag <".netrw_tag.">") -" call Decho("exe ".s:netrw_silentxfer."!".g:netrw_http_cmd." ".shellescape(tmpfile,1)." ".shellescape("http://".g:netrw_machine.netrw_html,1)) - exe s:netrw_silentxfer."!".g:netrw_http_cmd." ".shellescape(tmpfile,1)." ".shellescape("http://".g:netrw_machine.netrw_html,1) - let result = s:NetrwGetFile(readcmd, tmpfile, b:netrw_method) -" call Decho('<\s*a\s*name=\s*"'.netrw_tag.'"/') - exe 'norm! 1G/<\s*a\s*name=\s*"'.netrw_tag.'"/'."\" - endif - let b:netrw_lastfile = choice - setlocal ro - - "......................................... - " cadaver: NetRead Method #6 {{{3 - elseif b:netrw_method == 6 -" call Decho("read via cadaver (method #6)") - - " Construct execution string (four lines) which will be passed through filter - let netrw_fname= escape(b:netrw_fname,g:netrw_fname_escape) - new - setlocal ff=unix - if exists("g:netrw_port") && g:netrw_port != "" - put ='open '.g:netrw_machine.' '.g:netrw_port - else - put ='open '.g:netrw_machine - endif - put ='user '.g:netrw_uid.' '.s:netrw_passwd - put ='get '.netrw_fname.' '.tmpfile - put ='quit' - - " perform cadaver operation: - norm! 1Gdd -" call Decho("executing: %!".g:netrw_dav_cmd) - exe s:netrw_silentxfer."%!".g:netrw_dav_cmd - bd! - let result = s:NetrwGetFile(readcmd, tmpfile, b:netrw_method) - let b:netrw_lastfile = choice - - "......................................... - " rsync: NetRead Method #7 {{{3 - elseif b:netrw_method == 7 -" call Decho("read via rsync (method #7)") -" call Decho("exe ".s:netrw_silentxfer."!".g:netrw_rsync_cmd." ".shellescape(g:netrw_machine.":".b:netrw_fname,1)." ".shellescape(tmpfile,1)) - exe s:netrw_silentxfer."!".g:netrw_rsync_cmd." ".shellescape(g:netrw_machine.":".b:netrw_fname,1)." ".shellescape(tmpfile,1) - let result = s:NetrwGetFile(readcmd,tmpfile, b:netrw_method) - let b:netrw_lastfile = choice - - "......................................... - " fetch: NetRead Method #8 {{{3 - " fetch://[user@]host[:http]/path - elseif b:netrw_method == 8 -" call Decho("read via fetch (method #8)") - if g:netrw_fetch_cmd == "" - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"fetch command not available",7) - endif -" call Dret("NetRead") - endif - if exists("g:netrw_option") && g:netrw_option == ":http" - let netrw_option= "http" - else - let netrw_option= "ftp" - endif -" call Decho("read via fetch for ".netrw_option) - - if exists("g:netrw_uid") && g:netrw_uid != "" && exists("s:netrw_passwd") && s:netrw_passwd != "" -" call Decho("exe ".s:netrw_silentxfer."!".g:netrw_fetch_cmd." ".shellescape(tmpfile,1)." ".shellescape(netrw_option."://".g:netrw_uid.':'.s:netrw_passwd.'@'.g:netrw_machine."/".b:netrw_fname,1)) - exe s:netrw_silentxfer."!".g:netrw_fetch_cmd." ".shellescape(tmpfile,1)." ".shellescape(netrw_option."://".g:netrw_uid.':'.s:netrw_passwd.'@'.g:netrw_machine."/".b:netrw_fname,1) - else -" call Decho("exe ".s:netrw_silentxfer."!".g:netrw_fetch_cmd." ".shellescape(tmpfile,1)." ".shellescape(netrw_option."://".g:netrw_machine."/".b:netrw_fname,1)) - exe s:netrw_silentxfer."!".g:netrw_fetch_cmd." ".shellescape(tmpfile,1)." ".shellescape(netrw_option."://".g:netrw_machine."/".b:netrw_fname,1) - endif - - let result = s:NetrwGetFile(readcmd,tmpfile, b:netrw_method) - let b:netrw_lastfile = choice - setlocal ro - - "......................................... - " sftp: NetRead Method #9 {{{3 - elseif b:netrw_method == 9 -" call Decho("read via sftp (method #9)") -" call Decho("exe ".s:netrw_silentxfer."!".g:netrw_sftp_cmd." ".shellescape(g:netrw_machine.":".b:netrw_fname,1)." ".tmpfile) - exe s:netrw_silentxfer."!".g:netrw_sftp_cmd." ".shellescape(g:netrw_machine.":".b:netrw_fname,1)." ".tmpfile - let result = s:NetrwGetFile(readcmd, tmpfile, b:netrw_method) - let b:netrw_lastfile = choice - - "......................................... - " Complain {{{3 - else - call netrw#ErrorMsg(s:WARNING,"unable to comply with your request<" . choice . ">",8) - endif - endwhile - - " cleanup {{{3 - if exists("b:netrw_method") -" call Decho("cleanup b:netrw_method and b:netrw_fname") - unlet b:netrw_method - unlet b:netrw_fname - endif - if s:FileReadable(tmpfile) && tmpfile !~ '.tar.bz2$' && tmpfile !~ '.tar.gz$' && tmpfile !~ '.zip' && tmpfile !~ '.tar' && readcmd != 't' -" call Decho("cleanup by deleting tmpfile<".tmpfile.">") - call s:NetrwDelete(fnameescape(tmpfile)) - endif - call s:NetrwOptionRestore("w:") - -" call Dret("netrw#NetRead :5 getcwd<".getcwd().">") -endfun - -" ------------------------------------------------------------------------ -" netrw#NetWrite: responsible for writing a file over the net {{{2 -fun! netrw#NetWrite(...) range -" call Dfunc("netrw#NetWrite(a:0=".a:0.") ".g:loaded_netrw) - - " option handling - let mod= 0 - call s:NetrwOptionSave("w:") - call s:NetrwSafeOptions() - - " Get Temporary Filename {{{3 - let tmpfile= s:GetTempfile("") - if tmpfile == "" -" call Dret("netrw#NetWrite : unable to get a tempfile!") - return - endif - - if a:0 == 0 - let ichoice = 0 - else - let ichoice = 1 - endif - - let curbufname= expand("%") -" call Decho("curbufname<".curbufname.">") - if &binary - " For binary writes, always write entire file. - " (line numbers don't really make sense for that). - " Also supports the writing of tar and zip files. -" call Decho("(write entire file) silent exe w! ".fnameescape(v:cmdarg)." ".fnameescape(tmpfile)) - silent exe "w! ".fnameescape(v:cmdarg)." ".fnameescape(tmpfile) - elseif g:netrw_cygwin - " write (selected portion of) file to temporary - let cygtmpfile= substitute(tmpfile,'/cygdrive/\(.\)','\1:','') -" call Decho("(write selected portion) silent exe ".a:firstline."," . a:lastline . "w! ".fnameescape(v:cmdarg)." ".fnameescape(cygtmpfile)) - silent exe a:firstline."," . a:lastline . "w! ".fnameescape(v:cmdarg)." ".fnameescape(cygtmpfile) - else - " write (selected portion of) file to temporary -" call Decho("(write selected portion) silent exe ".a:firstline."," . a:lastline . "w! ".fnameescape(v:cmdarg)." ".fnameescape(tmpfile)) - silent exe a:firstline."," . a:lastline . "w! ".fnameescape(v:cmdarg)." ".fnameescape(tmpfile) - endif - - if curbufname == "" - " if the file is [No Name], and one attempts to Nwrite it, the buffer takes - " on the temporary file's name. Deletion of the temporary file during - " cleanup then causes an error message. - 0file! - endif - - " While choice loop: {{{3 - while ichoice <= a:0 - - " Process arguments: {{{4 - " attempt to repeat with previous host-file-etc - if exists("b:netrw_lastfile") && a:0 == 0 -" call Decho("using b:netrw_lastfile<" . b:netrw_lastfile . ">") - let choice = b:netrw_lastfile - let ichoice= ichoice + 1 - else - exe "let choice= a:" . ichoice - - " Reconstruct Choice if choice starts with '"' - if match(choice,"?") == 0 - echomsg 'NetWrite Usage:"' - echomsg ':Nwrite machine:path uses rcp' - echomsg ':Nwrite "machine path" uses ftp with <.netrc>' - echomsg ':Nwrite "machine id password path" uses ftp' - echomsg ':Nwrite dav://[user@]machine/path uses cadaver' - echomsg ':Nwrite fetch://[user@]machine/path uses fetch' - echomsg ':Nwrite ftp://machine[#port]/path uses ftp (autodetects <.netrc>)' - echomsg ':Nwrite rcp://machine/path uses rcp' - echomsg ':Nwrite rsync://[user@]machine/path uses rsync' - echomsg ':Nwrite scp://[user@]machine[[:#]port]/path uses scp' - echomsg ':Nwrite sftp://[user@]machine/path uses sftp' - sleep 4 - break - - elseif match(choice,"^\"") != -1 - if match(choice,"\"$") != -1 - " case "..." - let choice=strpart(choice,1,strlen(choice)-2) - else - " case "... ... ..." - let choice = strpart(choice,1,strlen(choice)-1) - let wholechoice = "" - - while match(choice,"\"$") == -1 - let wholechoice= wholechoice . " " . choice - let ichoice = ichoice + 1 - if choice > a:0 - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"Unbalanced string in filename '". wholechoice ."'",13) - endif -" call Dret("netrw#NetWrite") - return - endif - let choice= a:{ichoice} - endwhile - let choice= strpart(wholechoice,1,strlen(wholechoice)-1) . " " . strpart(choice,0,strlen(choice)-1) - endif - endif - endif - let ichoice= ichoice + 1 -" call Decho("choice<" . choice . "> ichoice=".ichoice) - - " Determine method of write (ftp, rcp, etc) {{{4 - call s:NetrwMethod(choice) - - " ============= - " Perform Protocol-Based Write {{{4 - " ============================ - if exists("g:netrw_silent") && g:netrw_silent == 0 && &ch >= 1 - echo "(netrw) Processing your write request..." -" call Decho("(netrw) Processing your write request...") - endif - - "......................................... - " rcp: NetWrite Method #1 {{{4 - if b:netrw_method == 1 -" call Decho("write via rcp (method #1)") - if s:netrw_has_nt_rcp == 1 - if exists("g:netrw_uid") && ( g:netrw_uid != "" ) - let uid_machine = g:netrw_machine .'.'. g:netrw_uid - else - let uid_machine = g:netrw_machine .'.'. $USERNAME - endif - else - if exists("g:netrw_uid") && ( g:netrw_uid != "" ) - let uid_machine = g:netrw_uid .'@'. g:netrw_machine - else - let uid_machine = g:netrw_machine - endif - endif -" call Decho("executing: !".g:netrw_rcp_cmd." ".s:netrw_rcpmode." ".shellescape(tmpfile,1)." ".shellescape(uid_machine.":".b:netrw_fname,1)) - exe s:netrw_silentxfer."!".g:netrw_rcp_cmd." ".s:netrw_rcpmode." ".shellescape(tmpfile,1)." ".shellescape(uid_machine.":".b:netrw_fname,1) - let b:netrw_lastfile = choice - - "......................................... - " ftp + <.netrc>: NetWrite Method #2 {{{4 - elseif b:netrw_method == 2 -" call Decho("write via ftp+.netrc (method #2)") - let netrw_fname= b:netrw_fname - new -" call Decho("filter input window#".winnr()) - setlocal ff=unix - put =g:netrw_ftpmode -" call Decho("filter input: ".getline('$')) - if exists("g:netrw_ftpextracmd") - put =g:netrw_ftpextracmd -" call Decho("filter input: ".getline("$")) - endif - call setline(line("$")+1,'put "'.tmpfile.'" "'.netrw_fname.'"') -" call Decho("filter input: ".getline("$")) - if exists("g:netrw_port") && g:netrw_port != "" -" call Decho("executing: %!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)." ".shellescape(g:netrw_port,1)) - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)." ".shellescape(g:netrw_port,1) - else -" call Decho("filter input window#".winnr()) -" call Decho("executing: %!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)) - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1) - endif - " If the result of the ftp operation isn't blank, show an error message (tnx to Doug Claar) - if getline(1) !~ "^$" - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,getline(1),14) - endif - let mod=1 - endif - bd! - let b:netrw_lastfile = choice - - "......................................... - " ftp + machine, id, passwd, filename: NetWrite Method #3 {{{4 - elseif b:netrw_method == 3 - " Construct execution string (four lines) which will be passed through filter -" call Decho("read via ftp+mipf (method #3)") - let netrw_fname= b:netrw_fname - new - setlocal ff=unix - if exists("g:netrw_port") && g:netrw_port != "" - put ='open '.g:netrw_machine.' '.g:netrw_port -" call Decho("filter input: ".getline('.')) - else - put ='open '.g:netrw_machine -" call Decho("filter input: ".getline('.')) - endif - if exists("g:netrw_ftp") && g:netrw_ftp == 1 - put =g:netrw_uid -" call Decho("filter input: ".getline('.')) - put ='\"'.s:netrw_passwd.'\"' -" call Decho("filter input: ".getline('.')) - else - put ='user \"'.g:netrw_uid.'\" \"'.s:netrw_passwd.'\"' -" call Decho("filter input: ".getline('.')) - endif - put ='put \"'.tmpfile.'\" \"'.netrw_fname.'\"' -" call Decho("filter input: ".getline('.')) - " save choice/id/password for future use - let b:netrw_lastfile = choice - - " perform ftp: - " -i : turns off interactive prompting from ftp - " -n unix : DON'T use <.netrc>, even though it exists - " -n win32: quit being obnoxious about password - norm! 1Gdd -" call Decho("executing: %!".g:netrw_ftp_cmd." -i -n") - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i -n" - " If the result of the ftp operation isn't blank, show an error message (tnx to Doug Claar) - if getline(1) !~ "^$" - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,getline(1),15) - endif - let mod=1 - endif - bd! - - "......................................... - " scp: NetWrite Method #4 {{{4 - elseif b:netrw_method == 4 -" call Decho("write via scp (method #4)") - if exists("g:netrw_port") && g:netrw_port != "" - let useport= " ".g:netrw_scpport." ".fnameescape(g:netrw_port) - else - let useport= "" - endif -" call Decho("exe ".s:netrw_silentxfer."!".g:netrw_scp_cmd.useport." ".shellescape(tmpfile,1)." ".shellescape(g:netrw_machine.":".b:netrw_fname,1)) - exe s:netrw_silentxfer."!".g:netrw_scp_cmd.useport." ".shellescape(tmpfile,1)." ".shellescape(g:netrw_machine.":".b:netrw_fname,1) - let b:netrw_lastfile = choice - - "......................................... - " http: NetWrite Method #5 {{{4 - elseif b:netrw_method == 5 -" call Decho("write via http (method #5)") - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"currently does not support writing using http:",16) - endif - - "......................................... - " dav: NetWrite Method #6 (cadaver) {{{4 - elseif b:netrw_method == 6 -" call Decho("write via cadaver (method #6)") - - " Construct execution string (four lines) which will be passed through filter - let netrw_fname= escape(b:netrw_fname,g:netrw_fname_escape) - new - setlocal ff=unix - if exists("g:netrw_port") && g:netrw_port != "" - put ='open '.g:netrw_machine.' '.g:netrw_port - else - put ='open '.g:netrw_machine - endif - if exists("g:netrw_uid") && exists("s:netrw_passwd") - put ='user '.g:netrw_uid.' '.s:netrw_passwd - endif - put ='put '.tmpfile.' '.netrw_fname - - " perform cadaver operation: - norm! 1Gdd -" call Decho("executing: %!".g:netrw_dav_cmd) - exe s:netrw_silentxfer."%!".g:netrw_dav_cmd - bd! - let b:netrw_lastfile = choice - - "......................................... - " rsync: NetWrite Method #7 {{{4 - elseif b:netrw_method == 7 -" call Decho("write via rsync (method #7)") -" call Decho("executing: !".g:netrw_rsync_cmd." ".shellescape(tmpfile,1)." ".shellescape(g:netrw_machine.":".b:netrw_fname,1)) - exe s:netrw_silentxfer."!".g:netrw_rsync_cmd." ".shellescape(tmpfile,1)." ".shellescape(g:netrw_machine.":".b:netrw_fname,1) - let b:netrw_lastfile = choice - - "......................................... - " sftp: NetWrite Method #9 {{{4 - elseif b:netrw_method == 9 -" call Decho("read via sftp (method #9)") - let netrw_fname= escape(b:netrw_fname,g:netrw_fname_escape) - if exists("g:netrw_uid") && ( g:netrw_uid != "" ) - let uid_machine = g:netrw_uid .'@'. g:netrw_machine - else - let uid_machine = g:netrw_machine - endif - new - setlocal ff=unix - put ='put \"'.escape(tmpfile,'\').'\" '.netrw_fname -" call Decho("filter input: ".getline('.')) - norm! 1Gdd -" call Decho("executing: %!".g:netrw_sftp_cmd.' '.shellescape(uid_machine,1)) - exe s:netrw_silentxfer."%!".g:netrw_sftp_cmd.' '.shellescape(uid_machine,1) - bd! - let b:netrw_lastfile= choice - - "......................................... - " Complain {{{4 - else - call netrw#ErrorMsg(s:WARNING,"unable to comply with your request<" . choice . ">",17) - endif - endwhile - - " Cleanup: {{{3 -" call Decho("cleanup") - if s:FileReadable(tmpfile) -" call Decho("tmpfile<".tmpfile."> readable, will now delete it") - call s:NetrwDelete(tmpfile) - endif - call s:NetrwOptionRestore("w:") - - if a:firstline == 1 && a:lastline == line("$") - " restore modifiability; usually equivalent to set nomod - let &mod= mod - endif - -" call Dret("netrw#NetWrite") -endfun - -" --------------------------------------------------------------------- -" netrw#NetSource: source a remotely hosted vim script {{{2 -" uses NetRead to get a copy of the file into a temporarily file, -" then sources that file, -" then removes that file. -fun! netrw#NetSource(...) -" call Dfunc("netrw#NetSource() a:0=".a:0) - if a:0 > 0 && a:1 == '?' - " give help - echomsg 'NetSource Usage:' - echomsg ':Nsource dav://machine[:port]/path uses cadaver' - echomsg ':Nsource fetch://machine/path uses fetch' - echomsg ':Nsource ftp://[user@]machine[:port]/path uses ftp autodetects <.netrc>' - echomsg ':Nsource http://[user@]machine/path uses http wget' - echomsg ':Nsource rcp://[user@]machine/path uses rcp' - echomsg ':Nsource rsync://machine[:port]/path uses rsync' - echomsg ':Nsource scp://[user@]machine[[:#]port]/path uses scp' - echomsg ':Nsource sftp://[user@]machine[[:#]port]/path uses sftp' - sleep 4 - else - let i= 1 - while i <= a:0 - call netrw#NetRead(3,a:{i}) -" call Decho("(netrw#NetSource) s:netread_tmpfile<".s:netrw_tmpfile.">") - if s:FileReadable(s:netrw_tmpfile) -" call Decho("(netrw#NetSource) exe so ".fnameescape(s:netrw_tmpfile)) - exe "so ".fnameescape(s:netrw_tmpfile) -" call Decho("(netrw#NetSource) delete(".s:netrw_tmpfile.")") - call delete(s:netrw_tmpfile) - unlet s:netrw_tmpfile - else - call netrw#ErrorMsg(s:ERROR,"unable to source <".a:{i}.">!",48) - endif - let i= i + 1 - endwhile - endif -" call Dret("netrw#NetSource") -endfun - -" =========================================== -" s:NetrwGetFile: Function to read temporary file "tfile" with command "readcmd". {{{2 -" readcmd == %r : replace buffer with newly read file -" == 0r : read file at top of buffer -" == r : read file after current line -" == t : leave file in temporary form (ie. don't read into buffer) -fun! s:NetrwGetFile(readcmd, tfile, method) -" call Dfunc("NetrwGetFile(readcmd<".a:readcmd.">,tfile<".a:tfile."> method<".a:method.">)") - - " readcmd=='t': simply do nothing - if a:readcmd == 't' -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Dret("NetrwGetFile : skip read of <".a:tfile.">") - return - endif - - " get name of remote filename (ie. url and all) - let rfile= bufname("%") -" call Decho("rfile<".rfile.">") - - if exists("*NetReadFixup") - " for the use of NetReadFixup (not otherwise used internally) - let line2= line("$") - endif - - if a:readcmd[0] == '%' - " get file into buffer -" call Decho("get file into buffer") - - " rename the current buffer to the temp file (ie. tfile) - if g:netrw_cygwin - let tfile= substitute(a:tfile,'/cygdrive/\(.\)','\1:','') - else - let tfile= a:tfile - endif -" call Decho("exe silent! keepalt file ".fnameescape(tfile)) - exe "silent! keepalt file ".fnameescape(tfile) - - " edit temporary file (ie. read the temporary file in) - if rfile =~ '\.zip$' -" call Decho("handling remote zip file with zip#Browse(tfile<".tfile.">)") - call zip#Browse(tfile) - elseif rfile =~ '\.tar$' -" call Decho("handling remote tar file with tar#Browse(tfile<".tfile.">)") - call tar#Browse(tfile) - elseif rfile =~ '\.tar\.gz' -" call Decho("handling remote gzip-compressed tar file") - call tar#Browse(tfile) - elseif rfile =~ '\.tar\.bz2' -" call Decho("handling remote bz2-compressed tar file") - call tar#Browse(tfile) - else -" call Decho("edit temporary file") - e! - endif - - " rename buffer back to remote filename -" call Decho("exe silent! keepalt file ".fnameescape(rfile)) - exe "silent! keepalt file ".fnameescape(rfile) - if a:method == 5 - set ft=html - else - filetype detect - endif -" call Dredir("renamed buffer back to remote filename<".rfile."> : expand(%)<".expand("%").">","ls!") - let line1 = 1 - let line2 = line("$") - - elseif s:FileReadable(a:tfile) - " read file after current line -" call Decho("read file<".a:tfile."> after current line") - let curline = line(".") - let lastline= line("$") -" call Decho("exe<".a:readcmd." ".fnameescape(v:cmdarg)." ".fnameescape(a:tfile)."> line#".curline) - exe a:readcmd." ".fnameescape(v:cmdarg)." ".fnameescape(a:tfile) - let line1= curline + 1 - let line2= line("$") - lastline + 1 - - else - " not readable -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Decho("tfile<".a:tfile."> not readable") - call netrw#ErrorMsg(s:WARNING,"file <".a:tfile."> not readable",9) -" call Dret("NetrwGetFile : tfile<".a:tfile."> not readable") - return - endif - - " User-provided (ie. optional) fix-it-up command - if exists("*NetReadFixup") -" call Decho("calling NetReadFixup(method<".a:method."> line1=".line1." line2=".line2.")") - call NetReadFixup(a:method, line1, line2) -" else " Decho -" call Decho("NetReadFixup() not called, doesn't exist (line1=".line1." line2=".line2.")") - endif - - if has("gui") && has("menu") && has("gui_running") && &go =~ 'm' - " update the Buffers menu - call s:UpdateBuffersMenu() - endif - -" call Decho("readcmd<".a:readcmd."> cmdarg<".v:cmdarg."> tfile<".a:tfile."> readable=".s:FileReadable(a:tfile)) - - " make sure file is being displayed -" redraw! - -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Dret("NetrwGetFile") -endfun - -" ------------------------------------------------------------------------ -" s:NetrwMethod: determine method of transfer {{{2 -" method == 1: rcp -" 2: ftp + <.netrc> -" 3: ftp + machine, id, password, and [path]filename -" 4: scp -" 5: http (wget) -" 6: cadaver -" 7: rsync -" 8: fetch -" 9: sftp -fun! s:NetrwMethod(choice) " globals: method machine id passwd fname -" call Dfunc("NetrwMethod(a:choice<".a:choice.">)") - - " initialization - let b:netrw_method = 0 - let g:netrw_machine = "" - let b:netrw_fname = "" - let g:netrw_port = "" - let g:netrw_choice = a:choice - - " Patterns: - " mipf : a:machine a:id password filename Use ftp - " mf : a:machine filename Use ftp + <.netrc> or g:netrw_uid s:netrw_passwd - " ftpurm : ftp://[user@]host[[#:]port]/filename Use ftp + <.netrc> or g:netrw_uid s:netrw_passwd - " rcpurm : rcp://[user@]host/filename Use rcp - " rcphf : [user@]host:filename Use rcp - " scpurm : scp://[user@]host[[#:]port]/filename Use scp - " httpurm : http://[user@]host/filename Use wget - " davurm : dav[s]://host[:port]/path Use cadaver - " rsyncurm : rsync://host[:port]/path Use rsync - " fetchurm : fetch://[user@]host[:http]/filename Use fetch (defaults to ftp, override for http) - " sftpurm : sftp://[user@]host/filename Use scp - let mipf = '^\(\S\+\)\s\+\(\S\+\)\s\+\(\S\+\)\s\+\(\S\+\)$' - let mf = '^\(\S\+\)\s\+\(\S\+\)$' - let ftpurm = '^ftp://\(\([^/@]\{-}\)@\)\=\([^/#:]\{-}\)\([#:]\d\+\)\=/\(.*\)$' - let rcpurm = '^rcp://\%(\([^/@]\{-}\)@\)\=\([^/]\{-}\)/\(.*\)$' - let rcphf = '^\(\(\h\w*\)@\)\=\(\h\w*\):\([^@]\+\)$' - let scpurm = '^scp://\([^/#:]\+\)\%([#:]\(\d\+\)\)\=/\(.*\)$' - let httpurm = '^http://\([^/]\{-}\)\(/.*\)\=$' - let davurm = '^davs\=://\([^/]\+\)/\(.*/\)\([-_.~[:alnum:]]\+\)$' - let rsyncurm = '^rsync://\([^/]\{-}\)/\(.*\)\=$' - let fetchurm = '^fetch://\(\([^/@]\{-}\)@\)\=\([^/#:]\{-}\)\(:http\)\=/\(.*\)$' - let sftpurm = '^sftp://\([^/]\{-}\)/\(.*\)\=$' - -" call Decho("determine method:") - " Determine Method - " rcp://user@hostname/...path-to-file - if match(a:choice,rcpurm) == 0 -" call Decho("rcp://...") - let b:netrw_method = 1 - let userid = substitute(a:choice,rcpurm,'\1',"") - let g:netrw_machine = substitute(a:choice,rcpurm,'\2',"") - let b:netrw_fname = substitute(a:choice,rcpurm,'\3',"") - if userid != "" - let g:netrw_uid= userid - endif - - " scp://user@hostname/...path-to-file - elseif match(a:choice,scpurm) == 0 -" call Decho("scp://...") - let b:netrw_method = 4 - let g:netrw_machine = substitute(a:choice,scpurm,'\1',"") - let g:netrw_port = substitute(a:choice,scpurm,'\2',"") - let b:netrw_fname = substitute(a:choice,scpurm,'\3',"") - - " http://user@hostname/...path-to-file - elseif match(a:choice,httpurm) == 0 -" call Decho("http://...") - let b:netrw_method = 5 - let g:netrw_machine= substitute(a:choice,httpurm,'\1',"") - let b:netrw_fname = substitute(a:choice,httpurm,'\2',"") - - " dav://hostname[:port]/..path-to-file.. - elseif match(a:choice,davurm) == 0 -" call Decho("dav://...") - let b:netrw_method= 6 - if a:choice =~ '^s' - let g:netrw_machine= 'https://'.substitute(a:choice,davurm,'\1/\2',"") - else - let g:netrw_machine= 'http://'.substitute(a:choice,davurm,'\1/\2',"") - endif - let b:netrw_fname = substitute(a:choice,davurm,'\3',"") - - " rsync://user@hostname/...path-to-file - elseif match(a:choice,rsyncurm) == 0 -" call Decho("rsync://...") - let b:netrw_method = 7 - let g:netrw_machine= substitute(a:choice,rsyncurm,'\1',"") - let b:netrw_fname = substitute(a:choice,rsyncurm,'\2',"") - - " ftp://[user@]hostname[[:#]port]/...path-to-file - elseif match(a:choice,ftpurm) == 0 -" call Decho("ftp://...") - let userid = substitute(a:choice,ftpurm,'\2',"") - let g:netrw_machine= substitute(a:choice,ftpurm,'\3',"") - let g:netrw_port = substitute(a:choice,ftpurm,'\4',"") - let b:netrw_fname = substitute(a:choice,ftpurm,'\5',"") - if userid != "" - let g:netrw_uid= userid - endif - if exists("g:netrw_uid") && exists("s:netrw_passwd") - let b:netrw_method = 3 - else - if s:FileReadable(expand("$HOME/.netrc")) && !g:netrw_ignorenetrc - let b:netrw_method= 2 - else - if !exists("g:netrw_uid") || g:netrw_uid == "" - call NetUserPass() - elseif !exists("s:netrw_passwd") || s:netrw_passwd == "" - call NetUserPass(g:netrw_uid) - " else just use current g:netrw_uid and s:netrw_passwd - endif - let b:netrw_method= 3 - endif - endif - - elseif match(a:choice,fetchurm) == 0 -" call Decho("fetch://...") - let b:netrw_method = 8 - let g:netrw_userid = substitute(a:choice,fetchurm,'\2',"") - let g:netrw_machine= substitute(a:choice,fetchurm,'\3',"") - let b:netrw_option = substitute(a:choice,fetchurm,'\4',"") - let b:netrw_fname = substitute(a:choice,fetchurm,'\5',"") - - " Issue an ftp : "machine id password [path/]filename" - elseif match(a:choice,mipf) == 0 -" call Decho("(ftp) host id pass file") - let b:netrw_method = 3 - let g:netrw_machine = substitute(a:choice,mipf,'\1',"") - let g:netrw_uid = substitute(a:choice,mipf,'\2',"") - let s:netrw_passwd = substitute(a:choice,mipf,'\3',"") - let b:netrw_fname = substitute(a:choice,mipf,'\4',"") - - " Issue an ftp: "hostname [path/]filename" - elseif match(a:choice,mf) == 0 -" call Decho("(ftp) host file") - if exists("g:netrw_uid") && exists("s:netrw_passwd") - let b:netrw_method = 3 - let g:netrw_machine = substitute(a:choice,mf,'\1',"") - let b:netrw_fname = substitute(a:choice,mf,'\2',"") - - elseif s:FileReadable(expand("$HOME/.netrc")) - let b:netrw_method = 2 - let g:netrw_machine = substitute(a:choice,mf,'\1',"") - let b:netrw_fname = substitute(a:choice,mf,'\2',"") - endif - - " sftp://user@hostname/...path-to-file - elseif match(a:choice,sftpurm) == 0 -" call Decho("sftp://...") - let b:netrw_method = 9 - let g:netrw_machine= substitute(a:choice,sftpurm,'\1',"") - let b:netrw_fname = substitute(a:choice,sftpurm,'\2',"") - - " Issue an rcp: hostname:filename" (this one should be last) - elseif match(a:choice,rcphf) == 0 -" call Decho("(rcp) [user@]host:file) rcphf<".rcphf.">") - let b:netrw_method = 1 - let userid = substitute(a:choice,rcphf,'\2',"") - let g:netrw_machine = substitute(a:choice,rcphf,'\3',"") - let b:netrw_fname = substitute(a:choice,rcphf,'\4',"") -" call Decho('\1<'.substitute(a:choice,rcphf,'\1',"").">") -" call Decho('\2<'.substitute(a:choice,rcphf,'\2',"").">") -" call Decho('\3<'.substitute(a:choice,rcphf,'\3',"").">") -" call Decho('\4<'.substitute(a:choice,rcphf,'\4',"").">") - if userid != "" - let g:netrw_uid= userid - endif - - else - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:WARNING,"cannot determine method",45) - endif - let b:netrw_method = -1 - endif - - " remove any leading [:#] from port number - if g:netrw_port != "" - let g:netrw_port = substitute(g:netrw_port,'[#:]\+','','') - endif - -" call Decho("a:choice <".a:choice.">") -" call Decho("b:netrw_method <".b:netrw_method.">") -" call Decho("g:netrw_machine<".g:netrw_machine.">") -" call Decho("g:netrw_port <".g:netrw_port.">") -" if exists("g:netrw_uid") "Decho -" call Decho("g:netrw_uid <".g:netrw_uid.">") -" endif "Decho -" if exists("s:netrw_passwd") "Decho -" call Decho("s:netrw_passwd <".s:netrw_passwd.">") -" endif "Decho -" call Decho("b:netrw_fname <".b:netrw_fname.">") -" call Dret("NetrwMethod : b:netrw_method=".b:netrw_method) -endfun - -" ------------------------------------------------------------------------ -" NetReadFixup: this sort of function is typically written by the user {{{2 -" to handle extra junk that their system's ftp dumps -" into the transfer. This function is provided as an -" example and as a fix for a Windows 95 problem: in my -" experience, win95's ftp always dumped four blank lines -" at the end of the transfer. -if has("win95") && exists("g:netrw_win95ftp") && g:netrw_win95ftp - fun! NetReadFixup(method, line1, line2) -" call Dfunc("NetReadFixup(method<".a:method."> line1=".a:line1." line2=".a:line2.")") - if method == 3 " ftp (no <.netrc>) - let fourblanklines= line2 - 3 - silent fourblanklines.",".line2."g/^\s*/d" - endif -" call Dret("NetReadFixup") - endfun -endif - -" --------------------------------------------------------------------- -" NetUserPass: set username and password for subsequent ftp transfer {{{2 -" Usage: :call NetUserPass() -- will prompt for userid and password -" :call NetUserPass("uid") -- will prompt for password -" :call NetUserPass("uid","password") -- sets global userid and password -fun! NetUserPass(...) - - " get/set userid - if a:0 == 0 -" call Dfunc("NetUserPass(a:0<".a:0.">)") - if !exists("g:netrw_uid") || g:netrw_uid == "" - " via prompt - let g:netrw_uid= input('Enter username: ') - endif - else " from command line -" call Dfunc("NetUserPass(a:1<".a:1.">) {") - let g:netrw_uid= a:1 - endif - - " get password - if a:0 <= 1 " via prompt -" call Decho("a:0=".a:0." case <=1:") - let s:netrw_passwd= inputsecret("Enter Password: ") - else " from command line -" call Decho("a:0=".a:0." case >1: a:2<".a:2.">") - let s:netrw_passwd=a:2 - endif - -" call Dret("NetUserPass") -endfun - -" =========================================== -" Shared Browsing Support: {{{1 -" =========================================== - -" --------------------------------------------------------------------- -" s:BrowserMaps: {{{2 -fun! s:BrowserMaps(islocal) -" call Dfunc("s:BrowserMaps(islocal=".a:islocal.") b:netrw_curdir<".b:netrw_curdir.">") - if a:islocal -" call Decho("make local maps") - nnoremap :call netrw#LocalBrowseCheck(NetrwBrowseChgDir(1,NetrwGetWord())) - nnoremap - :exe "norm! 0"call netrw#LocalBrowseCheck(NetrwBrowseChgDir(1,'../')) - nnoremap a :call NetrwHide(1) - nnoremap mb :call NetrwBookmarkDir(0,b:netrw_curdir) - nnoremap mc :call NetrwMarkFileCopy(1) - nnoremap md :call NetrwMarkFileDiff(1) - nnoremap me :call NetrwMarkFileEdit(1) - nnoremap mf :call NetrwMarkFile(1,NetrwGetWord()) - nnoremap mg :call NetrwMarkFileGrep(1) - nnoremap mh :call NetrwMarkHideSfx(1) - nnoremap mm :call NetrwMarkFileMove(1) - nnoremap mp :call NetrwMarkFilePrint(1) - nnoremap mr :call NetrwMarkFileRegexp(1) - nnoremap ms :call NetrwMarkFileSource(1) - nnoremap mT :call NetrwMarkFileTag(1) - nnoremap mt :call NetrwMarkFileTgt(1) - nnoremap mu :call NetrwUnMarkFile(1) - nnoremap mx :call NetrwMarkFileExe(1) - nnoremap mz :call NetrwMarkFileCompress(1) - nnoremap gb :call NetrwBookmarkDir(1,b:netrw_curdir) - nnoremap gh :call NetrwHidden(1) - nnoremap c :exe "keepjumps lcd ".fnameescape(b:netrw_curdir) - nnoremap C :let g:netrw_chgwin= winnr() - nnoremap d :call NetrwMakeDir("") - nnoremap i :call NetrwListStyle(1) - nnoremap o :call NetrwSplit(3) - nnoremap O :call NetrwObtain(1) - nnoremap p :call NetrwPreview(NetrwBrowseChgDir(1,NetrwGetWord(),1)) - nnoremap P :call NetrwPrevWinOpen(1) - nnoremap qb :call NetrwBookmarkDir(2,b:netrw_curdir) - nnoremap mB :call NetrwBookmarkDir(6,b:netrw_curdir) - nnoremap qf :call NetrwFileInfo(1,NetrwGetWord()) - nnoremap r :let g:netrw_sort_direction= (g:netrw_sort_direction =~ 'n')? 'r' : 'n'exe "norm! 0"call NetrwRefresh(1,NetrwBrowseChgDir(1,'./')) - nnoremap s :call NetrwSortStyle(1) - nnoremap S :call NetSortSequence(1) - nnoremap t :call NetrwSplit(4) - nnoremap u :call NetrwBookmarkDir(4,expand("%")) - nnoremap U :call NetrwBookmarkDir(5,expand("%")) - nnoremap v :call NetrwSplit(5) - nnoremap x :call netrw#NetrwBrowseX(NetrwBrowseChgDir(1,NetrwGetWord(),0),0)" - nnoremap % :call NetrwOpenFile(1) - if !hasmapto('NetrwHideEdit') - nmap NetrwHideEdit - endif - nnoremap NetrwHideEdit :call NetrwHideEdit(1) - if !hasmapto('NetrwRefresh') - nmap NetrwRefresh - endif - nnoremap NetrwRefresh :call NetrwRefresh(1,NetrwBrowseChgDir(1,'./')) - if s:didstarstar || !mapcheck("","n") - nnoremap :Nexplore - endif - if s:didstarstar || !mapcheck("","n") - nnoremap :Pexplore - endif - let mapsafecurdir = escape(b:netrw_curdir, s:netrw_map_escape) - if g:netrw_mousemaps == 1 - nnoremap :call NetrwLeftmouse(1) - nnoremap :call NetrwPrevWinOpen(1) - nnoremap :call NetrwMarkFile(1,NetrwGetWord()) - exe 'nnoremap :call NetrwLocalRm("'.mapsafecurdir.'")' - exe 'vnoremap :call NetrwLocalRm("'.mapsafecurdir.'")' - endif - exe 'nnoremap :call NetrwLocalRm("'.mapsafecurdir.'")' - exe 'vnoremap :call NetrwLocalRm("'.mapsafecurdir.'")' - exe 'nnoremap D :call NetrwLocalRm("'.mapsafecurdir.'")' - exe 'vnoremap D :call NetrwLocalRm("'.mapsafecurdir.'")' - exe 'nnoremap R :call NetrwLocalRename("'.mapsafecurdir.'")' - exe 'vnoremap R :call NetrwLocalRename("'.mapsafecurdir.'")' - exe 'nnoremap m :call NetrwMakeDir("")' - nnoremap :he netrw-quickhelp - - else " remote -" call Decho("make remote maps") - call s:RemotePathAnalysis(b:netrw_curdir) - nnoremap :call NetrwBrowse(0,NetrwBrowseChgDir(0,NetrwGetWord())) - nnoremap :call NetrwRefresh(0,NetrwBrowseChgDir(0,'./')) - nnoremap - :exe "norm! 0"call NetrwBrowse(0,NetrwBrowseChgDir(0,'../')) - nnoremap a :call NetrwHide(0) - nnoremap mb :call NetrwBookmarkDir(0,b:netrw_curdir) - nnoremap mc :call NetrwMarkFileCopy(0) - nnoremap md :call NetrwMarkFileDiff(0) - nnoremap me :call NetrwMarkFileEdit(0) - nnoremap mf :call NetrwMarkFile(0,NetrwGetWord()) - nnoremap mg :call NetrwMarkFileGrep(0) - nnoremap mh :call NetrwMarkHideSfx(0) - nnoremap mm :call NetrwMarkFileMove(0) - nnoremap mp :call NetrwMarkFilePrint(0) - nnoremap mr :call NetrwMarkFileRegexp(0) - nnoremap ms :call NetrwMarkFileSource(0) - nnoremap mT :call NetrwMarkFileTag(0) - nnoremap mt :call NetrwMarkFileTgt(0) - nnoremap mu :call NetrwUnMarkFile(0) - nnoremap mx :call NetrwMarkFileExe(0) - nnoremap mz :call NetrwMarkFileCompress(0) - nnoremap gb :call NetrwBookmarkDir(1,b:netrw_cur) - nnoremap gh :call NetrwHidden(0) - nnoremap C :let g:netrw_chgwin= winnr() - nnoremap i :call NetrwListStyle(0) - nnoremap o :call NetrwSplit(0) - nnoremap O :call NetrwObtain(0) - nnoremap p :call NetrwPreview(NetrwBrowseChgDir(1,NetrwGetWord(),1)) - nnoremap P :call NetrwPrevWinOpen(0) - nnoremap qb :call NetrwBookmarkDir(2,b:netrw_curdir) - nnoremap mB :call NetrwBookmarkDir(6,b:netrw_curdir) - nnoremap qf :call NetrwFileInfo(0,NetrwGetWord()) - nnoremap r :let g:netrw_sort_direction= (g:netrw_sort_direction =~ 'n')? 'r' : 'n'exe "norm! 0"call NetrwBrowse(0,NetrwBrowseChgDir(0,'./')) - nnoremap s :call NetrwSortStyle(0) - nnoremap S :call NetSortSequence(0) - nnoremap t :call NetrwSplit(1) - nnoremap u :call NetrwBookmarkDir(4,b:netrw_curdir) - nnoremap U :call NetrwBookmarkDir(5,b:netrw_curdir) - nnoremap v :call NetrwSplit(2) - nnoremap x :call netrw#NetrwBrowseX(NetrwBrowseChgDir(0,NetrwGetWord()),1) - nnoremap % :call NetrwOpenFile(0) - if !hasmapto('NetrwHideEdit') - nmap NetrwHideEdit - endif - nnoremap NetrwHideEdit :call NetrwHideEdit(0) - if !hasmapto('NetrwRefresh') - nmap NetrwRefresh - endif - - let mapsafepath = escape(s:path, s:netrw_map_escape) - let mapsafeusermach = escape(s:user.s:machine, s:netrw_map_escape) - - nnoremap NetrwRefresh :call NetrwRefresh(0,NetrwBrowseChgDir(0,'./')) - if g:netrw_mousemaps == 1 - nnoremap :call NetrwLeftmouse(0) - nnoremap :call NetrwPrevWinOpen(0) - nnoremap :call NetrwMarkFile(0,NetrwGetWord()) - exe 'nnoremap :call NetrwRemoteRm("'.mapsafeusermach.'","'.mapsafepath.'")' - exe 'vnoremap :call NetrwRemoteRm("'.mapsafeusermach.'","'.mapsafepath.'")' - endif - exe 'nnoremap :call NetrwRemoteRm("'.mapsafeusermach.'","'.mapsafepath.'")' - exe 'vnoremap :call NetrwRemoteRm("'.mapsafeusermach.'","'.mapsafepath.'")' - exe 'nnoremap d :call NetrwMakeDir("'.mapsafeusermach.'")' - exe 'nnoremap D :call NetrwRemoteRm("'.mapsafeusermach.'","'.mapsafepath.'")' - exe 'vnoremap D :call NetrwRemoteRm("'.mapsafeusermach.'","'.mapsafepath.'")' - exe 'nnoremap R :call NetrwRemoteRename("'.mapsafeusermach.'","'.mapsafepath.'")' - exe 'vnoremap R :call NetrwRemoteRename("'.mapsafeusermach.'","'.mapsafepath.'")' - nnoremap :he netrw-quickhelp - endif - call s:SetRexDir(a:islocal,b:netrw_curdir) -" call Dret("s:BrowserMaps") -endfun - -" --------------------------------------------------------------------- -" s:ExplorePatHls: converts an Explore pattern into a regular expression search pattern {{{2 -fun! s:ExplorePatHls(pattern) -" call Dfunc("s:ExplorePatHls(pattern<".a:pattern.">)") - let repat= substitute(a:pattern,'^**/\{1,2}','','') -" call Decho("repat<".repat.">") - let repat= escape(repat,'][.\') -" call Decho("repat<".repat.">") - let repat= '\<'.substitute(repat,'\*','\\(\\S\\+ \\)*\\S\\+','g').'\>' -" call Dret("s:ExplorePatHls repat<".repat.">") - return repat -endfun - -" --------------------------------------------------------------------- -" s:NetrwBookmarkDir: {{{2 -" 0: (user: ) bookmark current directory -" 1: (user: ) change to the bookmarked directory -" 2: (user: ) list bookmarks -" 3: (browsing) record current directory history -" 4: (user: ) go up (previous) bookmark -" 5: (user: ) go down (next) bookmark -" 6: (user: ) delete bookmark -fun! s:NetrwBookmarkDir(chg,curdir) -" call Dfunc("NetrwBookmarkDir(chg=".a:chg." curdir<".a:curdir.">) cnt=".v:count." bookmarkcnt=".g:NETRW_BOOKMARKMAX." histcnt=".g:NETRW_DIRHIST_CNT." bookmax=".g:NETRW_BOOKMARKMAX." histmax=".g:netrw_dirhistmax) - - if a:chg == 0 - " bookmark the current directory -" call Decho("(user: ) bookmark the current directory") - if v:count > 0 - " handle bookmark# specified via the count - let g:NETRW_BOOKMARKDIR_{v:count}= a:curdir - if !exists("g:NETRW_BOOKMARKMAX") - let g:NETRW_BOOKMARKMAX= v:count - elseif v:count > g:NETRW_BOOKMARKMAX - let g:NETRW_BOOKMARKMAX= v:count - endif - else - " handle no count specified - let g:NETRW_BOOKMARKMAX = g:NETRW_BOOKMARKMAX + 1 - let g:NETRW_BOOKMARKDIR_{g:NETRW_BOOKMARKMAX} = a:curdir - endif - echo "bookmarked the current directory" - - elseif a:chg == 1 - " change to the bookmarked directory -" call Decho("(user: ) change to the bookmarked directory") - if exists("g:NETRW_BOOKMARKDIR_{v:count}") - exe "e ".fnameescape(g:NETRW_BOOKMARKDIR_{v:count}) - else - echomsg "Sorry, bookmark#".v:count." doesn't exist!" - endif - - elseif a:chg == 2 -" redraw! - let didwork= 0 - " list user's bookmarks -" call Decho("(user: ) list user's bookmarks") - if exists("g:NETRW_BOOKMARKMAX") -" call Decho("list bookmarks [0,".g:NETRW_BOOKMARKMAX."]") - let cnt= 0 - while cnt <= g:NETRW_BOOKMARKMAX - if exists("g:NETRW_BOOKMARKDIR_{cnt}") -" call Decho("Netrw Bookmark#".cnt.": ".g:NETRW_BOOKMARKDIR_{cnt}) - echo "Netrw Bookmark#".cnt.": ".g:NETRW_BOOKMARKDIR_{cnt} - let didwork= 1 - endif - let cnt= cnt + 1 - endwhile - endif - - " list directory history - let cnt = g:NETRW_DIRHIST_CNT - let first = 1 - let histcnt = 0 - while ( first || cnt != g:NETRW_DIRHIST_CNT ) -" call Decho("first=".first." cnt=".cnt." dirhist_cnt=".g:NETRW_DIRHIST_CNT) - let histcnt= histcnt + 1 - if exists("g:NETRW_DIRHIST_{cnt}") -" call Decho("Netrw History#".histcnt.": ".g:NETRW_DIRHIST_{cnt}) - echo "Netrw History#".histcnt.": ".g:NETRW_DIRHIST_{cnt} - let didwork= 1 - endif - let first = 0 - let cnt = ( cnt - 1 ) % g:netrw_dirhistmax - if cnt < 0 - let cnt= cnt + g:netrw_dirhistmax - endif - endwhile - if didwork - call inputsave()|call input("Press to continue")|call inputrestore() - endif - - elseif a:chg == 3 - " saves most recently visited directories (when they differ) -" call Decho("(browsing) record curdir history") - if !exists("g:NETRW_DIRHIST_0") || g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT} != a:curdir - let g:NETRW_DIRHIST_CNT= ( g:NETRW_DIRHIST_CNT + 1 ) % g:netrw_dirhistmax -" let g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT}= substitute(a:curdir,'[/\\]$','','e') - let g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT}= a:curdir -" call Decho("save dirhist#".g:NETRW_DIRHIST_CNT."<".g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT}.">") - endif - - elseif a:chg == 4 - " u: change to the previous directory stored on the history list -" call Decho("(user: ) chg to prev dir from history") - let g:NETRW_DIRHIST_CNT= ( g:NETRW_DIRHIST_CNT - 1 ) % g:netrw_dirhistmax - if g:NETRW_DIRHIST_CNT < 0 - let g:NETRW_DIRHIST_CNT= g:NETRW_DIRHIST_CNT + g:netrw_dirhistmax - endif - if exists("g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT}") -" call Decho("changedir u#".g:NETRW_DIRHIST_CNT."<".g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT}.">") - if exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST && exists("b:netrw_curdir") - setlocal ma noro -" call Decho("setlocal ma noro") - %d - setlocal nomod -" call Decho("setlocal nomod") - endif -" " call Decho("exe e! ".fnameescape(g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT})) - exe "e! ".fnameescape(g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT}) - else - let g:NETRW_DIRHIST_CNT= ( g:NETRW_DIRHIST_CNT + 1 ) % g:netrw_dirhistmax - echo "Sorry, no predecessor directory exists yet" - endif - - elseif a:chg == 5 - " U: change to the subsequent directory stored on the history list -" call Decho("(user: ) chg to next dir from history") - let g:NETRW_DIRHIST_CNT= ( g:NETRW_DIRHIST_CNT + 1 ) % g:netrw_dirhistmax - if exists("g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT}") -" call Decho("changedir U#".g:NETRW_DIRHIST_CNT."<".g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT}.">") - if exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST && exists("b:netrw_curdir") - setlocal ma noro -" call Decho("setlocal ma noro") - %d -" call Decho("removed all lines from buffer (%d)") - setlocal nomod -" call Decho("setlocal nomod") - endif -" call Decho("exe e! ".fnameescape(g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT})) - exe "e! ".fnameescape(g:NETRW_DIRHIST_{g:NETRW_DIRHIST_CNT}) - else - let g:NETRW_DIRHIST_CNT= ( g:NETRW_DIRHIST_CNT - 1 ) % g:netrw_dirhistmax - if g:NETRW_DIRHIST_CNT < 0 - let g:NETRW_DIRHIST_CNT= g:NETRW_DIRHIST_CNT + g:netrw_dirhistmax - endif - echo "Sorry, no successor directory exists yet" - endif - - elseif a:chg == 6 - if v:count > 0 && v:count == g:NETRW_BOOKMARKMAX - " delete the v:count'th bookmark -" call Decho("delete bookmark#".v:count."<".g:NETRW_BOOKMARKDIR_{g:NETRW_BOOKMARKMAX}.">") - unlet g:NETRW_BOOKMARKDIR_{g:NETRW_BOOKMARKMAX} - let g:NETRW_BOOKMARKMAX= g:NETRW_BOOKMARKMAX - 1 - - elseif v:count > 0 -" call Decho("delete by shifting bookmark#".v:count."<".g:NETRW_BOOKMARKDIR_{v:count}.">") - let cnt= v:count - while cnt < g:NETRW_BOOKMARKMAX - let g:NETRW_BOOKMARKDIR_{cnt} = g:NETRW_BOOKMARKDIR_{(cnt+1)} - let cnt = cnt + 1 - endwhile - unlet g:NETRW_BOOKMARKDIR_{g:NETRW_BOOKMARKMAX} - let g:NETRW_BOOKMARKMAX= g:NETRW_BOOKMARKMAX - 1 - - elseif exists("b:netrw_curdir") - " look for current directory amongst the bookmarks and remove that bookmark -" call Decho("search for bookmark<".b:netrw_curdir.">") - let cnt= 1 - while cnt <= g:NETRW_BOOKMARKMAX -" call Decho("checking: g:NETRW_BOOKMARKDIR_".cnt."<".g:NETRW_BOOKMARKDIR_{cnt}.">") - if g:NETRW_BOOKMARKDIR_{cnt} == b:netrw_curdir - if cnt < g:NETRW_BOOKMARKMAX -" call Decho("delete bookmark#".cnt."<".b:netrw_curdir.">") - while cnt < g:NETRW_BOOKMARMAX - let g:NETRW_BOOKMARKDIR_{cnt} = g:NETRW_BOOKMARKDIR_{(cnt+1)} - let cnt = cnt + 1 - endwhile - endif - unlet g:NETRW_BOOKMARKDIR_{g:NETRW_BOOKMARKMAX} - let g:NETRW_BOOKMARKMAX= g:NETRW_BOOKMARKMAX - 1 - endif - let cnt= cnt + 1 - endwhile - endif - - endif - call s:NetrwBookmarkMenu() -" call Dret("NetrwBookmarkDir") -endfun - -" --------------------------------------------------------------------- -" s:NetrwBrowse: This function uses the command in g:netrw_list_cmd to provide a {{{2 -" list of the contents of a local or remote directory. It is assumed that the -" g:netrw_list_cmd has a string, USEPORT HOSTNAME, that needs to be substituted -" with the requested remote hostname first. -fun! s:NetrwBrowse(islocal,dirname) - if !exists("w:netrw_liststyle")|let w:netrw_liststyle= g:netrw_liststyle|endif -" call Dfunc("s:NetrwBrowse(islocal=".a:islocal." dirname<".a:dirname.">) liststyle=".w:netrw_liststyle." ".g:loaded_netrw." buf#".bufnr("%")."<".bufname("%").">") -" call Decho("tab#".tabpagenr()." win#".winnr()) -" call Dredir("ls!") - - if exists("s:netrw_skipbrowse") - unlet s:netrw_skipbrowse -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Dret("s:NetrwBrowse : s:netrw_skipbrowse=".s:netrw_skipbrowse) - return - endif - if !exists("*shellescape") - call netrw#ErrorMsg(s:ERROR,"netrw can't run -- your vim is missing shellescape()",69) -" call Dret("s:NetrwBrowse : missing shellescape()") - return - endif - if !exists("*fnameescape") - call netrw#ErrorMsg(s:ERROR,"netrw can't run -- your vim is missing fnameescape()",70) -" call Dret("s:NetrwBrowse : missing fnameescape()") - return - endif - - call s:NetrwOptionSave("w:") - call s:NetrwSafeOptions() - - " re-instate any marked files - if exists("s:netrwmarkfilelist_{bufnr('%')}") -" call Decho("clearing marked files") - exe "2match netrwMarkFile /".s:netrwmarkfilemtch_{bufnr("%")}."/" - endif - - if a:islocal && exists("w:netrw_acdkeep") && w:netrw_acdkeep -" call Decho("handle w:netrw_acdkeep:") -" call Decho("keepjumps lcd ".fnameescape(a:dirname)." (due to w:netrw_acdkeep=".w:netrw_acdkeep." - acd=".&acd.")") - exe 'keepjumps lcd '.fnameescape(a:dirname) -" call Decho("getcwd<".getcwd().">") - - elseif !a:islocal && a:dirname !~ '[\/]$' && a:dirname !~ '^"' - " looks like a regular file, attempt transfer -" call Decho("attempt transfer as regular file<".a:dirname.">") - - " remove any filetype indicator from end of dirname, except for the {{{3 - " "this is a directory" indicator (/). - " There shouldn't be one of those here, anyway. - let path= substitute(a:dirname,'[*=@|]\r\=$','','e') -" call Decho("new path<".path.">") - call s:RemotePathAnalysis(a:dirname) - - " remote-read the requested file into current buffer {{{3 - mark ' - call s:NetrwEnew(a:dirname) - setlocal ma noro -" call Decho("setlocal ma noro") - let b:netrw_curdir= a:dirname -" call Decho("exe silent! keepalt file ".fnameescape(s:method."://".s:user.s:machine."/".s:path)." (bt=".&bt.")") - exe "silent! keepalt file ".fnameescape(s:method."://".s:user.s:machine."/".s:path) - exe "silent keepalt doau BufReadPre ".fnameescape(s:fname) - silent call netrw#NetRead(2,s:method."://".s:user.s:machine."/".s:path) - if s:path !~ '.tar.bz2$' && s:path !~ '.tar.gz' - " netrw.vim and tar.vim have already handled decompression of the tarball; avoiding gzip.vim error - exe "silent keepalt doau BufReadPost ".fnameescape(s:fname) - endif - - " save certain window-oriented variables into buffer-oriented variables {{{3 - call s:SetBufWinVars() - call s:NetrwOptionRestore("w:") - setlocal ma nomod - -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Dret("s:NetrwBrowse : file<".s:fname.">") - return - endif - - " use buffer-oriented WinVars if buffer ones exist but window ones don't {{{3 - call s:UseBufWinVars() - - " set up some variables {{{3 - let b:netrw_browser_active = 1 - let dirname = a:dirname - let s:last_sort_by = g:netrw_sort_by - - " set up menu {{{3 - call s:NetrwMenu(1) - - " set up buffer {{{3 - let reusing= s:NetrwGetBuffer(a:islocal,dirname) - " maintain markfile highlighting - if exists("s:netrwmarkfilemtch_{bufnr('%')}") && s:netrwmarkfilemtch_{bufnr("%")} != "" -" call Decho("bufnr(%)=".bufnr('%')) -" call Decho("exe 2match netrwMarkFile /".s:netrwmarkfilemtch_{bufnr("%")}."/") - exe "2match netrwMarkFile /".s:netrwmarkfilemtch_{bufnr("%")}."/" - else -" call Decho("2match none") - 2match none - endif - if reusing - call s:NetrwOptionRestore("w:") - setlocal noma nomod nowrap -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Dret("s:NetrwBrowse : re-using buffer") - return - endif - - " set b:netrw_curdir to the new directory name {{{3 -" call Decho("set b:netrw_curdir to the new directory name:") - let b:netrw_curdir= dirname - if b:netrw_curdir =~ '[/\\]$' - let b:netrw_curdir= substitute(b:netrw_curdir,'[/\\]$','','e') - endif - if b:netrw_curdir == '' - if has("amiga") - " On the Amiga, the empty string connotes the current directory - let b:netrw_curdir= getcwd() - else - " under unix, when the root directory is encountered, the result - " from the preceding substitute is an empty string. - let b:netrw_curdir= '/' - endif - endif - if !a:islocal && b:netrw_curdir !~ '/$' - let b:netrw_curdir= b:netrw_curdir.'/' - endif -" call Decho("b:netrw_curdir<".b:netrw_curdir.">") - - " ------------ - " (local only) {{{3 - " ------------ - if a:islocal -" call Decho("local only:") - - " Set up ShellCmdPost handling. Append current buffer to browselist - call s:LocalFastBrowser() - - " handle g:netrw_keepdir: set vim's current directory to netrw's notion of the current directory {{{3 - if !g:netrw_keepdir -" call Decho("handle g:netrw_keepdir=".g:netrw_keepdir.": getcwd<".getcwd()."> acd=".&acd) -" call Decho("l:acd".(exists("&l:acd")? "=".&l:acd : " doesn't exist")) - if !exists("&l:acd") || !&l:acd -" call Decho('exe keepjumps lcd '.fnameescape(b:netrw_curdir)) - try - exe 'keepjumps lcd '.fnameescape(b:netrw_curdir) - catch /^Vim\%((\a\+)\)\=:E472/ - call netrw#ErrorMsg(s:ERROR,"unable to change directory to <".b:netrw_curdir."> (permissions?)",61) - if exists("w:netrw_prvdir") - let b:netrw_curdir= w:netrw_prvdir - else - call s:NetrwOptionRestore("w:") - setlocal noma nomod nowrap - let b:netrw_curdir= dirname -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Dret("s:NetrwBrowse : reusing buffer#".(exists("bufnum")? bufnum : 'N/A')."<".dirname."> getcwd<".getcwd().">") - return - endif - endtry - endif - endif - - " -------------------------------- - " remote handling: {{{3 - " -------------------------------- - else -" call Decho("remote only:") - - " analyze a:dirname and g:netrw_list_cmd {{{4 -" call Decho("b:netrw_curdir<".(exists("b:netrw_curdir")? b:netrw_curdir : "doesn't exist")."> a:dirname<".a:dirname.">") - if a:dirname =~ "^NetrwTreeListing\>" - let dirname= b:netrw_curdir -" call Decho("(dirname was ".a:dirname.") dirname<".dirname.">") - elseif exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST && exists("b:netrw_curdir") - let dirname= substitute(b:netrw_curdir,'\\','/','g') - if dirname !~ '/$' - let dirname= dirname.'/' - endif - let b:netrw_curdir = dirname -" call Decho("(liststyle is TREELIST) dirname<".dirname.">") - else - let dirname = substitute(a:dirname,'\\','/','g') -" call Decho("(normal) dirname<".dirname.">") - endif - - let dirpat = '^\(\w\{-}\)://\(\w\+@\)\=\([^/]\+\)/\(.*\)$' - if dirname !~ dirpat - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"netrw doesn't understand your dirname<".dirname.">",20) - endif - call s:NetrwOptionRestore("w:") - setlocal noma nomod nowrap -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Dret("s:NetrwBrowse : badly formatted dirname<".dirname.">") - return - endif - let b:netrw_curdir= dirname -" call Decho("b:netrw_curdir<".b:netrw_curdir."> (remote)") - endif " (additional remote handling) - - " ----------------------- - " Directory Listing: {{{3 - " ----------------------- - call s:BrowserMaps(a:islocal) - call s:PerformListing(a:islocal) - -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Dret("s:NetrwBrowse : did PerformListing") - return -endfun - -" --------------------------------------------------------------------- -" s:NetrwFileInfo: supports qf (query for file information) {{{2 -fun! s:NetrwFileInfo(islocal,fname) -" call Dfunc("s:NetrwFileInfo(islocal=".a:islocal." fname<".a:fname.">)") - if a:islocal - if (has("unix") || has("macunix")) && executable("/bin/ls") - if exists("b:netrw_curdir") -" call Decho('using ls with b:netrw_curdir<'.b:netrw_curdir.'>') - if b:netrw_curdir =~ '/$' - echo system("/bin/ls -lsad ".shellescape(b:netrw_curdir.a:fname)) - else - echo system("/bin/ls -lsad ".shellescape(b:netrw_curdir."/".a:fname)) - endif - else -" call Decho('using ls '.a:fname." using cwd<".getcwd().">") - echo system("/bin/ls -lsad ".shellescape(a:fname)) - endif - else - " use vim functions to return information about file below cursor -" call Decho("using vim functions to query for file info") - if !isdirectory(a:fname) && !filereadable(a:fname) && a:fname =~ '[*@/]' - let fname= substitute(a:fname,".$","","") - else - let fname= a:fname - endif - let t = getftime(fname) - let sz = getfsize(fname) - echo a:fname.": ".sz." ".strftime(g:netrw_timefmt,getftime(fname)) -" call Decho(fname.": ".sz." ".strftime(g:netrw_timefmt,getftime(fname))) - endif - else - echo "sorry, \"qf\" not supported yet for remote files" - endif -" call Dret("s:NetrwFileInfo") -endfun - -" --------------------------------------------------------------------- -" s:NetrwGetBuffer: {{{2 -" returns 0=cleared buffer -" 1=re-used buffer -fun! s:NetrwGetBuffer(islocal,dirname) -" call Dfunc("s:NetrwGetBuffer(islocal=".a:islocal." dirname<".a:dirname.">) liststyle=".g:netrw_liststyle) - let dirname= a:dirname - - " re-use buffer if possible {{{3 -" call Decho("--re-use a buffer if possible--") - if exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST - " find NetrwTreeList buffer if there is one - if exists("w:netrw_treebufnr") && w:netrw_treebufnr > 0 -" call Decho(" re-use w:netrw_treebufnr=".w:netrw_treebufnr) - let eikeep= &ei - set ei=all - exe "b ".w:netrw_treebufnr - let &ei= eikeep -" call Dret("s:NetrwGetBuffer : bufnum#".bufnum."") - return - endif - let bufnum= -1 -" call Decho(" liststyle=TREE but w:netrw_treebufnr doesn't exist") - - else - " find buffer number of buffer named precisely the same as dirname {{{3 -" call Decho("--find buffer numnber of buffer named precisely the same as dirname--") -" call Dredir("ls!") - - " get dirname and associated buffer number - let bufnum = bufnr(escape(dirname,'\')) -" call Decho(" find buffer<".dirname.">'s number ") -" call Decho(" bufnr(dirname<".escape(dirname,'\').">)=".bufnum) - - if bufnum < 0 && dirname !~ '/$' - " trying appending a trailing / -" call Decho(" try appending a trailing / to dirname<".dirname.">") - let bufnum= bufnr(escape(dirname.'/','\')) - if bufnum > 0 - let dirname= dirname.'/' - endif - endif - - if bufnum < 0 && dirname =~ '/$' - " trying removing a trailing / -" call Decho(" try removing a trailing / from dirname<".dirname.">") - let bufnum= bufnr(escape(substitute(dirname,'/$','',''),'\')) - if bufnum > 0 - let dirname= substitute(dirname,'/$','','') - endif - endif - -" call Decho(" findbuf1: bufnum=bufnr('".dirname."')=".bufnum." bufname(".bufnum.")<".bufname(bufnum)."> (initial)") - " note: !~ was used just below, but that means using ../ to go back would match (ie. abc/def/ and abc/ matches) - if bufnum > 0 && bufname(bufnum) != dirname && bufname(bufnum) != '.' - " handle approximate matches -" call Decho(" handling approx match: bufnum#%d<".bufname(bufnum)."> approx=dirname<".dirname.">") - let ibuf = 1 - let buflast = bufnr("$") -" call Decho(" findbuf2: buflast=".buflast) - while ibuf <= buflast - let bname= substitute(bufname(ibuf),'\\','/','g') - let bname= substitute(bname,'.\zs/$','','') -" call Decho(" findbuf3: dirname<".dirname."> bufname(".ibuf.")<".bname.">") - if bname != '' && dirname =~ '/'.bname.'/\=$' | break | endif - if bname =~ '^'.dirname.'/\=$' | break | endif - if dirname =~ '^'.bname.'/$' | break | endif - let ibuf= ibuf + 1 - endwhile - if ibuf > buflast - let bufnum= -1 - else - let bufnum= ibuf - endif -" call Decho(" findbuf4: bufnum=".bufnum." (ibuf=".ibuf." buflast=".buflast.")") - endif - endif - - " get enew buffer and name it -or- re-use buffer {{{3 -" call Decho("--get enew buffer and name it OR re-use buffer-- (bufnum=".bufnum.")") - mark ' - if bufnum < 0 || !bufexists(bufnum) - call s:NetrwEnew(dirname) -" call Decho(" got enew buffer#".bufnr("%")." (altbuf<".expand("#").">)") - " name the buffer - if exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST - " Got enew buffer; transform into a NetrwTreeListing -" call Decho("--transform enew buffer#".bufnr("%")." into a NetrwTreeListing --") - if !exists("s:netrw_treelistnum") - let s:netrw_treelistnum= 1 - else - let s:netrw_treelistnum= s:netrw_treelistnum + 1 - endif - let w:netrw_treebufnr= bufnr("%") -" call Decho(" exe silent! keepalt file NetrwTreeListing ".fnameescape(s:netrw_treelistnum)) - exe 'silent! keepalt file NetrwTreeListing\ '.fnameescape(s:netrw_treelistnum) - nnoremap [ :silent call TreeListMove('[') - nnoremap ] :silent call TreeListMove(']') - nnoremap [[ :silent call TreeListMove('[') - nnoremap ]] :silent call TreeListMove(']') -" call Decho(" tree listing#".s:netrw_treelistnum." bufnr=".w:netrw_treebufnr) - else -" let v:errmsg= "" " Decho - let escdirname= fnameescape(dirname) -" call Decho(" errmsg<".v:errmsg."> bufnr(".escdirname.")=".bufnr(escdirname)."<".bufname(bufnr(escdirname)).">") -" call Decho(' exe silent! keepalt file '.escdirname) - exe 'silent! keepalt file '.escdirname -" call Decho(" errmsg<".v:errmsg."> bufnr(".escdirname.")=".bufnr(escdirname)."<".bufname(bufnr(escdirname)).">") - endif -" call Decho(" named enew buffer#".bufnr("%")."<".bufname("%").">") - - else " Re-use the buffer -" call Decho("--re-use buffer#".bufnum.": --") - let eikeep= &ei - set ei=all - if getline(2) =~ '^" Netrw Directory Listing' -" call Decho(" re-use buffer#".bufnum."<".((bufnum > 0)? bufname(bufnum) : "")."> using: keepalt b ".bufnum) - exe "keepalt b ".bufnum - else -" call Decho(" reusing buffer#".bufnum."<".((bufnum > 0)? bufname(bufnum) : "")."> using: b ".bufnum) - exe "b ".bufnum - endif - if bufname("%") == '.' -" call Decho("exe silent! keepalt file ".fnameescape(getcwd())) - exe "silent! keepalt file ".fnameescape(getcwd()) - endif - let &ei= eikeep - if line("$") <= 1 - call s:NetrwListSettings(a:islocal) -" call Dret("s:NetrwGetBuffer 0 : re-using buffer#".bufnr("%").", but its empty, so refresh it") - return 0 - elseif exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST -" call Decho("--re-use tree listing--") -" call Decho(" clear buffer<".expand("%")."> with :%d") - silent %d - call s:NetrwListSettings(a:islocal) -" call Dret("s:NetrwGetBuffer 0 : re-using buffer#".bufnr("%").", but treelist mode always needs a refresh") - return 0 - else -" call Dret("s:NetrwGetBuffer 1 : buf#".bufnr("%")) - return 1 - endif - endif - - " do netrw settings: make this buffer not-a-file, modifiable, not line-numbered, etc {{{3 - " fastbrowse Local Remote Hiding a buffer implies it may be re-used (fast) - " slow 0 D D Deleting a buffer implies it will not be re-used (slow) - " med 1 D H - " fast 2 H H -" call Decho("--do netrw settings: make this buffer not-a-file, modifiable, not line-numbered, etc--") - let fname= expand("%") - call s:NetrwListSettings(a:islocal) -" call Decho("exe keepalt file ".fnameescape(fname)) - exe "keepalt file ".fnameescape(fname) - - " delete all lines from buffer {{{3 -" call Decho("--delete all lines from buffer--") -" call Decho(" clear buffer<".expand("%")."> with :%d") - keepalt silent! %d - -" call Dret("s:NetrwGetBuffer 0 : buf#".bufnr("%")) - return 0 -endfun - -" --------------------------------------------------------------------- -" s:NetrwGetcwd: get the current directory. {{{2 -" Change backslashes to forward slashes, if any. -" If doesc is true, escape certain troublesome characters -fun! s:NetrwGetcwd(doesc) -" call Dfunc("NetrwGetcwd(doesc=".a:doesc.")") - let curdir= substitute(getcwd(),'\\','/','ge') - if curdir !~ '[\/]$' - let curdir= curdir.'/' - endif - if a:doesc - let curdir= fnameescape(curdir) - endif -" call Dret("NetrwGetcwd <".curdir.">") - return curdir -endfun - -" --------------------------------------------------------------------- -" s:NetrwGetWord: it gets the directory/file named under the cursor {{{2 -fun! s:NetrwGetWord() -" call Dfunc("s:NetrwGetWord() line#".line(".")." liststyle=".g:netrw_liststyle." virtcol=".virtcol(".")) - call s:UseBufWinVars() - - " insure that w:netrw_liststyle is set up - if !exists("w:netrw_liststyle") - if exists("g:netrw_liststyle") - let w:netrw_liststyle= g:netrw_liststyle - else - let w:netrw_liststyle= s:THINLIST - endif -" call Decho("w:netrw_liststyle=".w:netrw_liststyle) - endif - - if exists("w:netrw_bannercnt") && line(".") < w:netrw_bannercnt - " Active Banner support -" call Decho("active banner handling") - norm! 0 - let dirname= "./" - let curline= getline('.') - - if curline =~ '"\s*Sorted by\s' - norm s - let s:netrw_skipbrowse= 1 - echo 'Pressing "s" also works' - - elseif curline =~ '"\s*Sort sequence:' - let s:netrw_skipbrowse= 1 - echo 'Press "S" to edit sorting sequence' - - elseif curline =~ '"\s*Quick Help:' - norm ? - let s:netrw_skipbrowse= 1 - echo 'Pressing "?" also works' - - elseif curline =~ '"\s*\%(Hiding\|Showing\):' - norm a - let s:netrw_skipbrowse= 1 - echo 'Pressing "a" also works' - - elseif line("$") > w:netrw_bannercnt - exe 'silent keepjumps '.w:netrw_bannercnt - endif - - elseif w:netrw_liststyle == s:THINLIST -" call Decho("thin column handling") - norm! 0 - let dirname= getline('.') - - elseif w:netrw_liststyle == s:LONGLIST -" call Decho("long column handling") - norm! 0 - let dirname= substitute(getline('.'),'^\(\%(\S\+ \)*\S\+\).\{-}$','\1','e') - - elseif w:netrw_liststyle == s:TREELIST -" call Decho("treelist handling") - let dirname= substitute(getline('.'),'^\(| \)*','','e') - - else -" call Decho("obtain word from wide listing") - let dirname= getline('.') - - if !exists("b:netrw_cpf") - let b:netrw_cpf= 0 - exe 'silent keepjumps '.w:netrw_bannercnt.',$g/^./if virtcol("$") > b:netrw_cpf|let b:netrw_cpf= virtcol("$")|endif' -" call Decho("computed cpf=".b:netrw_cpf) - endif - -" call Decho("buf#".bufnr("%")."<".bufname("%").">") - let filestart = (virtcol(".")/b:netrw_cpf)*b:netrw_cpf -" call Decho("filestart= ([virtcol=".virtcol(".")."]/[b:netrw_cpf=".b:netrw_cpf."])*b:netrw_cpf=".filestart." bannercnt=".w:netrw_bannercnt) -" call Decho("1: dirname<".dirname.">") - if filestart == 0 - norm! 0ma - else - call cursor(line("."),filestart+1) - norm! ma - endif - let rega= @a - let eofname= filestart + b:netrw_cpf + 1 - if eofname <= col("$") - call cursor(line("."),filestart+b:netrw_cpf+1) - norm! "ay`a - else - norm! "ay$ - endif - let dirname = @a - let @a = rega -" call Decho("2: dirname<".dirname.">") - let dirname= substitute(dirname,'\s\+$','','e') -" call Decho("3: dirname<".dirname.">") - endif - - " symlinks are indicated by a trailing "@". Remove it before further processing. - let dirname= substitute(dirname,"@$","","") - - " executables are indicated by a trailing "*". Remove it before further processing. - let dirname= substitute(dirname,"\*$","","") - -" call Dret("s:NetrwGetWord <".dirname.">") - return dirname -endfun - -" --------------------------------------------------------------------- -" s:NetrwListSettings: {{{2 -fun! s:NetrwListSettings(islocal) -" call Dfunc("s:NetrwListSettings(islocal=".a:islocal.")") - let fname= bufname("%") -" call Decho("setlocal bt=nofile nobl ma nonu nowrap noro") - setlocal bt=nofile nobl ma nonu nowrap noro -" call Decho("exe keepalt file ".fnameescape(fname)) - exe "keepalt file ".fnameescape(fname) - if g:netrw_use_noswf - setlocal noswf - endif -" call Dredir("ls!") -" call Decho("exe setlocal ts=".g:netrw_maxfilenamelen) - exe "setlocal ts=".g:netrw_maxfilenamelen - setlocal isk+=.,~,- - if g:netrw_fastbrowse > a:islocal - setlocal bh=hide - else - setlocal bh=delete - endif -" call Dret("s:NetrwListSettings") -endfun - -" --------------------------------------------------------------------- -" s:NetrwListStyle: {{{2 -" islocal=0: remote browsing -" =1: local browsing -fun! s:NetrwListStyle(islocal) -" call Dfunc("NetrwListStyle(islocal=".a:islocal.") w:netrw_liststyle=".w:netrw_liststyle) - let fname = s:NetrwGetWord() - if !exists("w:netrw_liststyle")|let w:netrw_liststyle= g:netrw_liststyle|endif - let w:netrw_liststyle = (w:netrw_liststyle + 1) % s:MAXLIST -" call Decho("fname<".fname.">") -" call Decho("chgd w:netrw_liststyle to ".w:netrw_liststyle) -" call Decho("b:netrw_curdir<".(exists("b:netrw_curdir")? b:netrw_curdir : "doesn't exist").">") - - if w:netrw_liststyle == s:THINLIST - " use one column listing -" call Decho("use one column list") - let g:netrw_list_cmd = substitute(g:netrw_list_cmd,' -l','','ge') - - elseif w:netrw_liststyle == s:LONGLIST - " use long list -" call Decho("use long list") - let g:netrw_list_cmd = g:netrw_list_cmd." -l" - - elseif w:netrw_liststyle == s:WIDELIST - " give wide list -" call Decho("use wide list") - let g:netrw_list_cmd = substitute(g:netrw_list_cmd,' -l','','ge') - - elseif w:netrw_liststyle == s:TREELIST -" call Decho("use tree list") - let g:netrw_list_cmd = substitute(g:netrw_list_cmd,' -l','','ge') - - else - call netrw#ErrorMsg(s:WARNING,"bad value for g:netrw_liststyle (=".w:netrw_liststyle.")",46) - let g:netrw_liststyle = s:THINLIST - let w:netrw_liststyle = g:netrw_liststyle - let g:netrw_list_cmd = substitute(g:netrw_list_cmd,' -l','','ge') - endif - setlocal ma noro -" call Decho("setlocal ma noro") - - " clear buffer - this will cause NetrwBrowse/LocalBrowseCheck to do a refresh -" call Decho("clear buffer<".expand("%")."> with :%d") - %d - - " refresh the listing - let svpos= netrw#NetrwSavePosn() - call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - call netrw#NetrwRestorePosn(svpos) - - " keep cursor on the filename - silent keepjumps $ - let result= search('\%(^\%(|\+\s\)\=\|\s\{2,}\)\zs'.escape(fname,'.\[]*$^').'\%(\s\{2,}\|$\)','bc') -" call Decho("search result=".result." w:netrw_bannercnt=".(exists("w:netrw_bannercnt")? w:netrw_bannercnt : 'N/A')) - if result <= 0 && exists("w:netrw_bannercnt") - exe "keepjumps ".w:netrw_bannercnt - endif - -" call Dret("NetrwListStyle".(exists("w:netrw_liststyle")? ' : w:netrw_liststyle='.w:netrw_liststyle : "")) -endfun - -" --------------------------------------------------------------------- -" s:NetrwBookmarkMenu: Uses menu priorities {{{2 -" .2.[cnt] for bookmarks, and -" .3.[cnt] for history -" (see s:NetrwMenu()) -fun! s:NetrwBookmarkMenu() - if !exists("s:netrw_menucnt") - return - endif -" call Dfunc("NetrwBookmarkMenu() bookmarkcnt=".g:NETRW_BOOKMARKMAX." histcnt=".g:NETRW_DIRHIST_CNT." menucnt=".s:netrw_menucnt) - - " the following test assures that gvim is running, has menus available, and has menus enabled. - if has("gui") && has("menu") && has("gui_running") && &go =~ 'm' && g:netrw_menu - if exists("g:NetrwTopLvlMenu") -" call Decho("removing ".g:NetrwTopLvlMenu."Bookmarks menu item(s)") - exe 'silent! unmenu '.g:NetrwTopLvlMenu.'Bookmarks' - endif - - " show bookmarked places - let cnt = 1 - while cnt <= g:NETRW_BOOKMARKMAX - if exists("g:NETRW_BOOKMARKDIR_{cnt}") - let bmdir= escape(g:NETRW_BOOKMARKDIR_{cnt},'. ') -" call Decho('silent! menu '.g:NetrwMenuPriority.".2.".cnt." ".g:NetrwTopLvlMenu.'Bookmark.'.bmdir.' :e '.bmdir) - exe 'silent! menu '.g:NetrwMenuPriority.".2.".cnt." ".g:NetrwTopLvlMenu.'Bookmarks.'.bmdir.' :e '.bmdir."\" - endif - let cnt= cnt + 1 - endwhile - - " show directory browsing history - let cnt = g:NETRW_DIRHIST_CNT - let first = 1 - let histcnt = 0 - while ( first || cnt != g:NETRW_DIRHIST_CNT ) - let histcnt = histcnt + 1 - let priority = g:NETRW_DIRHIST_CNT + histcnt - if exists("g:NETRW_DIRHIST_{cnt}") - let bmdir= escape(g:NETRW_DIRHIST_{cnt},'/&? ') -" call Decho('silent! menu '.g:NetrwMenuPriority.".3.".priority." ".g:NetrwTopLvlMenu.'History.'.bmdir.' :e '.bmdir) - exe 'silent! menu '.g:NetrwMenuPriority.".3.".priority." ".g:NetrwTopLvlMenu.'History.'.bmdir.' :e '.bmdir."\" - endif - let first = 0 - let cnt = ( cnt - 1 ) % g:netrw_dirhistmax - if cnt < 0 - let cnt= cnt + g:netrw_dirhistmax - endif - endwhile - endif -" call Dret("NetrwBookmarkMenu") -endfun - -" --------------------------------------------------------------------- -" s:NetrwBrowseChgDir: constructs a new directory based on the current {{{2 -" directory and a new directory name. Also, if the -" "new directory name" is actually a file, -" NetrwBrowseChgDir() edits the file. -fun! s:NetrwBrowseChgDir(islocal,newdir,...) -" call Dfunc("s:NetrwBrowseChgDir(islocal=".a:islocal."> newdir<".a:newdir.">) a:0=".a:0." curpos<".string(getpos("."))."> b:netrw_curdir<".(exists("b:netrw_curdir")? b:netrw_curdir : "").">") - - if !exists("b:netrw_curdir") - " Don't try to change-directory: this can happen, for example, when netrw#ErrorMsg has been called - " and the current window is the NetrwMessage window. -" call Decho("(NetrwBrowseChgDir) b:netrw_curdir doesn't exist!") -" call Decho("getcwd<".getcwd().">") -" call Dredir("ls!") -" call Dret("s:NetrwBrowseChgDir") - return - endif - - call s:NetrwOptionSave("s:") - call s:NetrwSafeOptions() - let nbcd_curpos = netrw#NetrwSavePosn() - let s:nbcd_curpos_{bufnr('%')} = nbcd_curpos - let dirname = substitute(b:netrw_curdir,'\\','/','ge') - let newdir = a:newdir - let dolockout = 0 - - " set up o/s-dependent directory recognition pattern - if has("amiga") - let dirpat= '[\/:]$' - else - let dirpat= '[\/]$' - endif -" call Decho("dirname<".dirname."> dirpat<".dirpat.">") - - if dirname !~ dirpat - " apparently vim is "recognizing" that it is in a directory and - " is removing the trailing "/". Bad idea, so I put it back. - let dirname= dirname.'/' -" call Decho("adjusting dirname<".dirname.">") - endif - - if newdir !~ dirpat - " ------------ - " edit a file: - " ------------ -" call Decho('case "handling a file": newdir<'.newdir.'> !~ dirpat<'.dirpat.">") - if exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST && exists("w:netrw_treedict") && newdir !~ '^\(/\|\a:\)' - let dirname= s:NetrwTreeDir() - if dirname =~ '/$' - let dirname= dirname.newdir - else - let dirname= s:NetrwTreeDir()."/".newdir - endif -" call Decho("tree listing") - elseif newdir =~ '^\(/\|\a:\)' - let dirname= newdir - else - let dirname= s:ComposePath(dirname,newdir) - endif -" call Decho("handling a file: dirname<".dirname."> (a:0=".a:0.")") - " this lets NetrwBrowseX avoid the edit - if a:0 < 1 -" call Decho("set up windows for editing<".fnameescape(dirname)."> didsplit=".(exists("s:didsplit")? s:didsplit : "doesn't exist")) - call s:NetrwOptionRestore("s:") - if !exists("s:didsplit") - if g:netrw_browse_split == 1 - new - wincmd _ - elseif g:netrw_browse_split == 2 - rightb vert new - wincmd | - elseif g:netrw_browse_split == 3 - tabnew - elseif g:netrw_browse_split == 4 - if s:NetrwPrevWinOpen(2) == 3 -" call Dret("s:NetrwBrowseChgDir") - return - endif - else - " handling a file, didn't split, so remove menu -" call Decho("handling a file+didn't split, so remove menu") - call s:NetrwMenu(0) - " optional change to window - if g:netrw_chgwin >= 1 - exe "keepjumps ".g:netrw_chgwin."wincmd w" - endif - endif - endif - " the point where netrw actually edits the (local) file - " if its local only: LocalBrowseCheck() doesn't edit a file, but NetrwBrowse() will - if a:islocal -" call Decho("edit local file: exe e! ".fnameescape(dirname)) - exe "e! ".fnameescape(dirname) - else -" call Decho("remote file: NetrwBrowse will edit it") - endif - let dolockout= 1 - endif - - elseif newdir =~ '^/' - " --------------------------------- - " just go to the new directory spec - " --------------------------------- -" call Decho('case "just go to new directory spec": newdir<'.newdir.'>') - let dirname= newdir - call s:SetRexDir(a:islocal,dirname) - call s:NetrwOptionRestore("s:") - - elseif newdir == './' - " -------------------------- - " refresh the directory list - " -------------------------- -" call Decho('case "refresh directory listing": newdir == "./"') - call s:SetRexDir(a:islocal,dirname) - - elseif newdir == '../' - " ------------------- - " go up one directory - " ------------------- -" call Decho('case "go up one directory": newdir == "../"') - - if w:netrw_liststyle == s:TREELIST && exists("w:netrw_treedict") - " force a refresh -" call Decho("clear buffer<".expand("%")."> with :%d") - setlocal noro ma -" call Decho("setlocal noro ma") - keepjumps %d - endif - - if has("amiga") - " amiga -" call Decho('case "go up one directory": newdir == "../" and amiga') - if a:islocal - let dirname= substitute(dirname,'^\(.*[/:]\)\([^/]\+$\)','\1','') - let dirname= substitute(dirname,'/$','','') - else - let dirname= substitute(dirname,'^\(.*[/:]\)\([^/]\+/$\)','\1','') - endif -" call Decho("amiga: dirname<".dirname."> (go up one dir)") - - else - " unix or cygwin -" call Decho('case "go up one directory": newdir == "../" and unix or cygwin') - if a:islocal - let dirname= substitute(dirname,'^\(.*\)/\([^/]\+\)/$','\1','') - if dirname == "" - let dirname= '/' - endif - else - let dirname= substitute(dirname,'^\(\a\+://.\{-}/\{1,2}\)\(.\{-}\)\([^/]\+\)/$','\1\2','') - endif -" call Decho("unix: dirname<".dirname."> (go up one dir)") - endif - call s:SetRexDir(a:islocal,dirname) - - elseif exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST && exists("w:netrw_treedict") -" call Decho('case liststyle is TREELIST and w:netrw_treedict exists') - " force a refresh (for TREELIST, wait for NetrwTreeDir() to force the refresh) - setlocal noro ma -" call Decho("setlocal noro ma") - if !(exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST && exists("b:netrw_curdir")) -" call Decho("clear buffer<".expand("%")."> with :%d") - keepjumps %d - endif - let treedir = s:NetrwTreeDir() - let s:treecurpos = nbcd_curpos - let haskey= 0 -" call Decho("w:netrw_treedict<".string(w:netrw_treedict).">") - - " search treedict for tree dir as-is - if has_key(w:netrw_treedict,treedir) -" call Decho('....searched for treedir<'.treedir.'> : found it!') - let haskey= 1 - else -" call Decho('....searched for treedir<'.treedir.'> : not found') - endif - - " search treedict for treedir with a / appended - if !haskey && treedir !~ '/$' - if has_key(w:netrw_treedict,treedir."/") - let treedir= treedir."/" -" call Decho('....searched.for treedir<'.treedir.'> found it!') - let haskey = 1 - else -" call Decho('....searched for treedir<'.treedir.'/> : not found') - endif - endif - - " search treedict for treedir with any trailing / elided - if !haskey && treedir =~ '/$' - let treedir= substitute(treedir,'/$','','') - if has_key(w:netrw_treedict,treedir) -" call Decho('....searched.for treedir<'.treedir.'> found it!') - let haskey = 1 - else -" call Decho('....searched for treedir<'.treedir.'> : not found') - endif - endif - - if haskey - " close tree listing for selected subdirectory -" call Decho("closing selected subdirectory<".dirname.">") - call remove(w:netrw_treedict,treedir) -" call Decho("removed entry<".dirname."> from treedict") -" call Decho("yielding treedict<".string(w:netrw_treedict).">") - let dirname= w:netrw_treetop - else - " go down one directory - let dirname= substitute(treedir,'/*$','/','') -" call Decho("go down one dir: treedir<".treedir.">") - endif - call s:SetRexDir(a:islocal,dirname) - - else - " go down one directory - let dirname= s:ComposePath(dirname,newdir) -" call Decho("go down one dir: dirname<".dirname."> newdir<".newdir.">") - call s:SetRexDir(a:islocal,dirname) - endif - - call s:NetrwOptionRestore("s:") - if dolockout -" call Decho("doing modification lockout settings: ma nomod noro") - setlocal ma nomod noro -" call Decho("setlocal ma nomod noro") - endif - -" call Dret("s:NetrwBrowseChgDir <".dirname."> : curpos<".string(getpos(".")).">") - return dirname -endfun - -" --------------------------------------------------------------------- -" s:NetrwBrowseX: allows users to write custom functions to operate on {{{2 -" files given their extension. Passes 0=local, 1=remote -fun! netrw#NetrwBrowseX(fname,remote) -" call Dfunc("NetrwBrowseX(fname<".a:fname."> remote=".a:remote.")") - - " set up the filename - " (lower case the extension, make a local copy of a remote file) - let exten= substitute(a:fname,'.*\.\(.\{-}\)','\1','e') - if has("win32") || has("win95") || has("win64") || has("win16") - let exten= substitute(exten,'^.*$','\L&\E','') - endif - - " seems kde systems often have gnome-open due to dependencies, even though - " gnome-open's subsidiary display tools are largely absent. Kde systems - " usually have "kdeinit" running, though... (tnx Mikolaj Machowski) - if !exists("s:haskdeinit") - if has("unix") - let s:haskdeinit= system("ps -e") =~ 'kdeinit' - if v:shell_error - let s:haskdeinit = 0 - endif - else - let s:haskdeinit= 0 - endif -" call Decho("setting s:haskdeinit=".s:haskdeinit) - endif - - if a:remote == 1 - " create a local copy - let fname= fnamemodify(tempname(),":r").".".exten -" call Decho("a:remote=".a:remote.": create a local copy of <".fname."> as <".fname.">") - exe "silent keepjumps bot 1new ".fnameescape(fname) - setlocal bh=delete -" call Decho("read <".fnameescape(fname).">, now writing: exe w! ".fnameescape(fname)) - exe "silent! w! ".fnameescape(fname) - q - else - let fname= a:fname - endif -" call Decho("exten<".exten."> "."netrwFileHandlers#NFH_".exten."():exists=".exists("*netrwFileHandlers#NFH_".exten)) - - " set up redirection - if &srr =~ "%s" - if (has("win32") || has("win95") || has("win64") || has("win16")) - let redir= substitute(&srr,"%s","nul","") - else - let redir= substitute(&srr,"%s","/dev/null","") - endif - elseif (has("win32") || has("win95") || has("win64") || has("win16")) - let redir= &srr . "nul" - else - let redir= &srr . "/dev/null" - endif -" call Decho("redir{".redir."} srr{".&srr."}") - - " extract any viewing options. Assumes that they're set apart by quotes. - if exists("g:netrw_browsex_viewer") - if g:netrw_browsex_viewer =~ '\s' - let viewer = substitute(g:netrw_browsex_viewer,'\s.*$','','') - let viewopt = substitute(g:netrw_browsex_viewer,'^\S\+\s*','','')." " - let oviewer = '' - let cnt = 1 - while !executable(viewer) && viewer != oviewer - let viewer = substitute(g:netrw_browsex_viewer,'^\(\(^\S\+\s\+\)\{'.cnt.'}\S\+\)\(.*\)$','\1','') - let viewopt = substitute(g:netrw_browsex_viewer,'^\(\(^\S\+\s\+\)\{'.cnt.'}\S\+\)\(.*\)$','\3','')." " - let cnt = cnt + 1 - let oviewer = viewer -" call Decho("!exe: viewer<".viewer."> viewopt<".viewopt.">") - endwhile - else - let viewer = g:netrw_browsex_viewer - let viewopt = "" - endif -" call Decho("viewer<".viewer."> viewopt<".viewopt.">") - endif - - " execute the file handler - if exists("g:netrw_browsex_viewer") && g:netrw_browsex_viewer == '-' -" call Decho("g:netrw_browsex_viewer<".g:netrw_browsex_viewer.">") - let ret= netrwFileHandlers#Invoke(exten,fname) - - elseif exists("g:netrw_browsex_viewer") && executable(viewer) -" call Decho("g:netrw_browsex_viewer<".g:netrw_browsex_viewer.">") -" call Decho("exe silent !".viewer." ".viewopt.shellescape(fname,1).redir) - exe "silent !".viewer." ".viewopt.shellescape(fname,1).redir - let ret= v:shell_error - - elseif has("win32") || has("win64") -" call Decho('exe silent !start rundll32 url.dll,FileProtocolHandler '.shellescape(fname,1)) - exe 'silent !start rundll32 url.dll,FileProtocolHandler '.shellescape(fname,1) - call inputsave()|call input("Press to continue")|call inputrestore() - let ret= v:shell_error - - elseif has("unix") && executable("gnome-open") && !s:haskdeinit -" call Decho("exe silent !gnome-open ".shellescape(fname,1)." ".redir) - exe "silent !gnome-open ".shellescape(fname,1).redir - let ret= v:shell_error - - elseif has("unix") && executable("kfmclient") && s:haskdeinit -" call Decho("exe silent !kfmclient exec ".shellescape(fname,1)." ".redir) - exe "silent !kfmclient exec ".shellescape(fname,1)." ".redir - let ret= v:shell_error - - elseif has("macunix") && executable("open") -" call Decho("exe silent !open ".shellescape(fname,1)." ".redir) - exe "silent !open ".shellescape(fname,1)." ".redir - let ret= v:shell_error - - else - " netrwFileHandlers#Invoke() always returns 0 - let ret= netrwFileHandlers#Invoke(exten,fname) - endif - - " if unsuccessful, attempt netrwFileHandlers#Invoke() - if ret - let ret= netrwFileHandlers#Invoke(exten,fname) - endif - - " restoring redraw! after external file handlers - redraw! - - " cleanup: remove temporary file, - " delete current buffer if success with handler, - " return to prior buffer (directory listing) - " Feb 12, 2008: had to de-activiate removal of - " temporary file because it wasn't getting seen. -" if a:remote == 1 && fname != a:fname -" call Decho("deleting temporary file<".fname.">") -" call s:NetrwDelete(fname) -" endif - - if a:remote == 1 - setlocal bh=delete bt=nofile - if g:netrw_use_noswf - setlocal noswf - endif - exe "norm! \" -" redraw! - endif - -" call Dret("NetrwBrowseX") -endfun - -" --------------------------------------------------------------------- -" netrw#Explore: launch the local browser in the directory of the current file {{{2 -" dosplit==0: the window will be split iff the current file has -" been modified -" dosplit==1: the window will be split before running the local -" browser -fun! netrw#Explore(indx,dosplit,style,...) -" call Dfunc("netrw#Explore(indx=".a:indx." dosplit=".a:dosplit." style=".a:style.",a:1<".a:1.">) &modified=".&modified." a:0=".a:0) - if !exists("b:netrw_curdir") - let b:netrw_curdir= getcwd() -" call Decho("set b:netrw_curdir<".b:netrw_curdir."> (used getcwd)") - endif - let curfile= b:netrw_curdir -" call Decho("curfile<".curfile.">") - - " save registers - silent! let keepregstar = @* - silent! let keepregplus = @+ - silent! let keepregslash= @/ - - " if dosplit or file has been modified - if a:dosplit || &modified || a:style == 6 -" call Decho("case: dosplit=".a:dosplit." modified=".&modified." a:style=".a:style) - call s:SaveWinVars() - - if a:style == 0 " Explore, Sexplore -" call Decho("style=0: Explore or Sexplore") - exe g:netrw_winsize."wincmd s" - - elseif a:style == 1 "Explore!, Sexplore! -" call Decho("style=1: Explore! or Sexplore!") - exe g:netrw_winsize."wincmd v" - - elseif a:style == 2 " Hexplore -" call Decho("style=2: Hexplore") - exe "bel ".g:netrw_winsize."wincmd s" - - elseif a:style == 3 " Hexplore! -" call Decho("style=3: Hexplore!") - exe "abo ".g:netrw_winsize."wincmd s" - - elseif a:style == 4 " Vexplore -" call Decho("style=4: Vexplore") - exe "lefta ".g:netrw_winsize."wincmd v" - - elseif a:style == 5 " Vexplore! -" call Decho("style=5: Vexplore!") - exe "rightb ".g:netrw_winsize."wincmd v" - - elseif a:style == 6 " Texplore - call s:SaveBufVars() -" call Decho("style = 6: Texplore") - tabnew - call s:RestoreBufVars() - endif - call s:RestoreWinVars() - endif - norm! 0 - - if a:0 > 0 -" call Decho("case [a:0=".a:0."]>0: a:1<".a:1.">") - if a:1 =~ '^\~' && (has("unix") || (exists("g:netrw_cygwin") && g:netrw_cygwin)) - let dirname= substitute(a:1,'\~',expand("$HOME"),'') -" call Decho("using dirname<".dirname."> (case: ~ && unix||cygwin)") - elseif a:1 == '.' - let dirname= exists("b:netrw_curdir")? b:netrw_curdir : getcwd() - if dirname !~ '/$' - let dirname= dirname."/" - endif -" call Decho("using dirname<".dirname."> (case: ".(exists("b:netrw_curdir")? "b:netrw_curdir" : "getcwd()").")") - elseif a:1 =~ '\$' - let dirname= expand(a:1) - else - let dirname= a:1 -" call Decho("using dirname<".dirname.">") - endif - else - " clear explore -" call Decho("clearing explore variables") - 2match none - if exists("s:explore_match") |unlet s:explore_match |endif - if exists("s:explore_indx") |unlet s:explore_indx |endif - if exists("s:dirstarstar") |unlet s:dirstarstar |endif - if exists("s:dirstarstar") |unlet s:dirstarstar |endif - if exists("w:netrw_explore_indx") |unlet w:netrw_explore_indx |endif - if exists("w:netrw_explore_listlen")|unlet w:netrw_explore_listlen|endif - if exists("w:netrw_explore_list") |unlet w:netrw_explore_list |endif - if exists("w:netrw_explore_bufnr") |unlet w:netrw_explore_bufnr |endif -" redraw! - echo " " - echo " " -" call Dret("netrw#Explore : cleared list") - return - endif - - if dirname =~ '/\*\*/' - " handle .../**/.../filepat -" call Decho("case Explore .../**/.../filepat") - let prefixdir= substitute(dirname,'^\(.\{-}\)\*\*.*$','\1','') - if prefixdir =~ '^/' || (prefixdir =~ '^\a:/' && (has("win32") || has("win95") || has("win64") || has("win16"))) - let b:netrw_curdir = prefixdir - else - let b:netrw_curdir= getcwd().'/'.prefixdir - endif - let dirname= substitute(dirname,'^.\{-}\(\*\*/.*\)$','\1','') - let starpat= 4; -" call Decho("pwd<".getcwd()."> dirname<".dirname.">") -" call Decho("case Explore ../**/../filepat (starpat=".starpat.")") - - elseif dirname =~ '^\*//' - " starpat=1: Explore *//pattern (current directory only search for files containing pattern) -" call Decho("case Explore *//pattern") - let pattern= substitute(dirname,'^\*//\(.*\)$','\1','') - let starpat= 1 -" call Decho("Explore *//pat: (starpat=".starpat.") dirname<".dirname."> -> pattern<".pattern.">") - if &hls | let keepregslash= s:ExplorePatHls(pattern) | endif - - elseif dirname =~ '^\*\*//' - " starpat=2: Explore **//pattern (recursive descent search for files containing pattern) -" call Decho("case Explore **//pattern") - let pattern= substitute(dirname,'^\*\*//','','') - let starpat= 2 -" call Decho("Explore **//pat: (starpat=".starpat.") dirname<".dirname."> -> pattern<".pattern.">") - - elseif dirname =~ '^\*/' - " starpat=3: Explore */filepat (search in current directory for filenames matching filepat) - let starpat= 3 -" call Decho("case Explore */filepat (starpat=".starpat.")") - - elseif dirname=~ '^\*\*/' - " starpat=4: Explore **/filepat (recursive descent search for filenames matching filepat) - let starpat= 4 -" call Decho("case Explore **/filepat (starpat=".starpat.")") - else - let starpat= 0 - endif - - if starpat == 0 && a:indx >= 0 - " [Explore Hexplore Vexplore Sexplore] [dirname] -" call Decho("case dirname<".dirname."> a:indx=".a:indx.": Explore Hexplore Vexplore Sexplore") - if dirname == "" - let dirname= substitute(expand("%:p"),'^\(.*[/\\]\)[^/\\]*$','\1','e') - endif - if dirname =~ '^scp:' || dirname =~ '^ftp:' -" call Decho("calling NetrwBrowse(0,dirname<".dirname.">)") - call s:NetrwBrowse(0,dirname) - else - if dirname == ""|let dirname= getcwd()|endif -" call Decho("calling LocalBrowseCheck(dirname<".dirname.">)") - call netrw#LocalBrowseCheck(dirname) - endif - -" call Decho("curfile<".curfile.">") - if has("win32") || has("win95") || has("win64") || has("win16") - call search('\<'.substitute(curfile,'^.*[/\\]','','e').'\>','cW') - else - call search('\<'.substitute(curfile,'^.*/','','e').'\>','cW') - endif - - " starpat=1: Explore *//pattern (current directory only search for files containing pattern) - " starpat=2: Explore **//pattern (recursive descent search for files containing pattern) - " starpat=3: Explore */filepat (search in current directory for filenames matching filepat) - " starpat=4: Explore **/filepat (recursive descent search for filenames matching filepat) - elseif a:indx <= 0 - " Nexplore, Pexplore, Explore: handle starpat -" call Decho("case Nexplore, Pexplore, , : starpat=".starpat." a:indx=".a:indx) - if !mapcheck("","n") && !mapcheck("","n") && exists("b:netrw_curdir") -" call Decho("set up and maps") - let s:didstarstar= 1 - nnoremap :Pexplore - nnoremap :Nexplore - endif - - if has("path_extra") -" call Decho("starpat=".starpat.": has +path_extra") - if !exists("w:netrw_explore_indx") - let w:netrw_explore_indx= 0 - endif - let indx = a:indx -" call Decho("starpat=".starpat.": set indx= [a:indx=".indx."]") -" - if indx == -1 - " Nexplore -" call Decho("case Nexplore with starpat=".starpat.": (indx=".indx.")") - if !exists("w:netrw_explore_list") " sanity check - call netrw#ErrorMsg(s:WARNING,"using Nexplore or improperly; see help for netrw-starstar",40) - silent! let @* = keepregstar - silent! let @+ = keepregstar - silent! let @/ = keepregslash -" call Dret("netrw#Explore") - return - endif - let indx= w:netrw_explore_indx - if indx < 0 | let indx= 0 | endif - if indx >= w:netrw_explore_listlen | let indx= w:netrw_explore_listlen - 1 | endif - let curfile= w:netrw_explore_list[indx] -" call Decho("indx=".indx." curfile<".curfile.">") - while indx < w:netrw_explore_listlen && curfile == w:netrw_explore_list[indx] - let indx= indx + 1 -" call Decho("indx=".indx." (Nexplore while loop)") - endwhile - if indx >= w:netrw_explore_listlen | let indx= w:netrw_explore_listlen - 1 | endif -" call Decho("Nexplore: indx= [w:netrw_explore_indx=".w:netrw_explore_indx."]=".indx) - - elseif indx == -2 - " Pexplore -" call Decho("case Pexplore with starpat=".starpat.": (indx=".indx.")") - if !exists("w:netrw_explore_list") " sanity check - call netrw#ErrorMsg(s:WARNING,"using Pexplore or improperly; see help for netrw-starstar",41) - silent! let @* = keepregstar - silent! let @+ = keepregstar - silent! let @/ = keepregslash -" call Dret("netrw#Explore") - return - endif - let indx= w:netrw_explore_indx - if indx < 0 | let indx= 0 | endif - if indx >= w:netrw_explore_listlen | let indx= w:netrw_explore_listlen - 1 | endif - let curfile= w:netrw_explore_list[indx] -" call Decho("indx=".indx." curfile<".curfile.">") - while indx >= 0 && curfile == w:netrw_explore_list[indx] - let indx= indx - 1 -" call Decho("indx=".indx." (Pexplore while loop)") - endwhile - if indx < 0 | let indx= 0 | endif -" call Decho("Pexplore: indx= [w:netrw_explore_indx=".w:netrw_explore_indx."]=".indx) - - else - " Explore -- initialize - " build list of files to Explore with Nexplore/Pexplore -" call Decho("starpat=".starpat.": case Explore: initialize (indx=".indx.")") - let w:netrw_explore_indx= 0 - if !exists("b:netrw_curdir") - let b:netrw_curdir= getcwd() - endif -" call Decho("starpat=".starpat.": b:netrw_curdir<".b:netrw_curdir.">") - - " switch on starpat to build the w:netrw_explore_list of files - if starpat == 1 - " starpat=1: Explore *//pattern (current directory only search for files containing pattern) -" call Decho("starpat=".starpat.": build *//pattern list") - exe "vimgrep /".pattern."/gj ".fnameescape(b:netrw_curdir)."/*" - let w:netrw_explore_list = map(getqflist(),'bufname(v:val.bufnr)') - if &hls | let keepregslash= s:ExplorePatHls(pattern) | endif - - elseif starpat == 2 - " starpat=2: Explore **//pattern (recursive descent search for files containing pattern) -" call Decho("starpat=".starpat.": build **//pattern list") - try - exe "silent vimgrep /".pattern."/gj "."**/*" - catch /^Vim\%((\a\+)\)\=:E480/ - call netrw#ErrorMsg(s:WARNING,'no files matched pattern<'.pattern.'>',45) - if &hls | let keepregslash= s:ExplorePatHls(pattern) | endif - silent! let @* = keepregstar - silent! let @+ = keepregstar - silent! let @/ = keepregslash -" call Dret("netrw#Explore : no files matched pattern") - return - endtry - let s:netrw_curdir = b:netrw_curdir - let w:netrw_explore_list = getqflist() - let w:netrw_explore_list = map(w:netrw_explore_list,'s:netrw_curdir."/".bufname(v:val.bufnr)') - - elseif starpat == 3 - " starpat=3: Explore */filepat (search in current directory for filenames matching filepat) -" call Decho("starpat=".starpat.": build */filepat list") - let dirname = substitute(dirname,'^\*/','','') - let w:netrw_explore_list= split(expand(b:netrw_curdir."/".dirname),'\n') - if &hls | let keepregslash= s:ExplorePatHls(dirname) | endif - - elseif starpat == 4 - " starpat=4: Explore **/filepat (recursive descent search for filenames matching filepat) -" call Decho("starpat=".starpat.": build **/filepat list") - let w:netrw_explore_list= split(expand(b:netrw_curdir."/".dirname),'\n') - if &hls | let keepregslash= s:ExplorePatHls(dirname) | endif - endif " switch on starpat to build w:netrw_explore_list - - let w:netrw_explore_listlen = len(w:netrw_explore_list) -" call Decho("w:netrw_explore_list<".string(w:netrw_explore_list).">") -" call Decho("w:netrw_explore_listlen=".w:netrw_explore_listlen) - - if w:netrw_explore_listlen == 0 || (w:netrw_explore_listlen == 1 && w:netrw_explore_list[0] =~ '\*\*\/') - call netrw#ErrorMsg(s:WARNING,"no files matched",42) - silent! let @* = keepregstar - silent! let @+ = keepregstar - silent! let @/ = keepregslash -" call Dret("netrw#Explore : no files matched") - return - endif - endif " if indx ... endif - - " NetrwStatusLine support - for exploring support - let w:netrw_explore_indx= indx -" call Decho("explorelist<".join(w:netrw_explore_list,',')."> len=".w:netrw_explore_listlen) - - " wrap the indx around, but issue a note - if indx >= w:netrw_explore_listlen || indx < 0 -" call Decho("wrap indx (indx=".indx." listlen=".w:netrw_explore_listlen.")") - let indx = (indx < 0)? ( w:netrw_explore_listlen - 1 ) : 0 - let w:netrw_explore_indx= indx - call netrw#ErrorMsg(s:NOTE,"no more files match Explore pattern",43) - sleep 1 - endif - - exe "let dirfile= w:netrw_explore_list[".indx."]" -" call Decho("dirfile=w:netrw_explore_list[indx=".indx."]= <".dirfile.">") - let newdir= substitute(dirfile,'/[^/]*$','','e') -" call Decho("newdir<".newdir.">") - -" call Decho("calling LocalBrowseCheck(newdir<".newdir.">)") - call netrw#LocalBrowseCheck(newdir) - if !exists("w:netrw_liststyle") - let w:netrw_liststyle= g:netrw_liststyle - endif - if w:netrw_liststyle == s:THINLIST || w:netrw_liststyle == s:LONGLIST - call search('^'.substitute(dirfile,"^.*/","","").'\>',"W") - else - call search('\<'.substitute(dirfile,"^.*/","","").'\>',"w") - endif - let w:netrw_explore_mtchcnt = indx + 1 - let w:netrw_explore_bufnr = bufnr("%") - let w:netrw_explore_line = line(".") - call s:SetupNetrwStatusLine('%f %h%m%r%=%9*%{NetrwStatusLine()}') -" call Decho("explore: mtchcnt=".w:netrw_explore_mtchcnt." bufnr=".w:netrw_explore_bufnr." line#".w:netrw_explore_line) - - else -" call Decho("your vim does not have +path_extra") - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:WARNING,"your vim needs the +path_extra feature for Exploring with **!",44) - endif - silent! let @* = keepregstar - silent! let @+ = keepregstar - silent! let @/ = keepregslash -" call Dret("netrw#Explore : missing +path_extra") - return - endif - - else -" call Decho("case Explore newdir<".dirname.">") - if exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST && dirname =~ '/' - silent! unlet w:netrw_treedict - silent! unlet w:netrw_treetop - endif - let newdir= dirname - if !exists("b:netrw_curdir") - call netrw#LocalBrowseCheck(getcwd()) - else - call netrw#LocalBrowseCheck(s:NetrwBrowseChgDir(1,newdir)) - endif - endif - - " visual display of **/ **// */ Exploration files - if exists("w:netrw_explore_indx") && exists("b:netrw_curdir") - if !exists("s:explore_prvdir") || s:explore_prvdir != b:netrw_curdir - " only update match list if current directory isn't the same as before - let s:explore_prvdir = b:netrw_curdir - let s:explore_match = "" - let dirlen = strlen(b:netrw_curdir) - if b:netrw_curdir !~ '/$' - let dirlen= dirlen + 1 - endif - let prvfname= "" - for fname in w:netrw_explore_list -" call Decho("fname<".fname.">") - if fname =~ '^'.b:netrw_curdir - if s:explore_match == "" - let s:explore_match= '\<'.escape(strpart(fname,dirlen),g:netrw_markfileesc."'".g:netrw_markfileesc."'").'\>' - else - let s:explore_match= s:explore_match.'\|\<'.escape(strpart(fname,dirlen),g:netrw_markfileesc."'".g:netrw_markfileesc."'").'\>' - endif - elseif fname !~ '^/' && fname != prvfname - if s:explore_match == "" - let s:explore_match= '\<'.escape(fname,g:netrw_markfileesc."'".g:netrw_markfileesc."'").'\>' - else - let s:explore_match= s:explore_match.'\|\<'.escape(fname,g:netrw_markfileesc."'".g:netrw_markfileesc."'").'\>' - endif - endif - let prvfname= fname - endfor -" call Decho("explore_match<".s:explore_match.">") - exe "2match netrwMarkFile /".s:explore_match."/" - endif - echo "==Pexplore ==Nexplore" - else - 2match none - if exists("s:explore_match") | unlet s:explore_match | endif - if exists("s:explore_prvdir") | unlet s:explore_prvdir | endif - echo " " -" call Decho("cleared explore match list") - endif - - silent! let @* = keepregstar - silent! let @+ = keepregstar - silent! let @/ = keepregslash -" call Dret("netrw#Explore : @/<".@/.">") -endfun - -" --------------------------------------------------------------------- -" s:NetrwHide: this function is invoked by the "a" map for browsing {{{2 -" and switches the hiding mode. The actual hiding is done by -" s:NetrwListHide(). -" g:netrw_hide= 0: show all -" 1: show not-hidden files -" 2: show hidden files only -fun! s:NetrwHide(islocal) -" call Dfunc("NetrwHide(islocal=".a:islocal.") g:netrw_hide=".g:netrw_hide) - let svpos= netrw#NetrwSavePosn() - - if exists("s:netrwmarkfilelist_{bufnr('%')}") -" call Decho(((g:netrw_hide == 1)? "unhide" : "hide")." files in markfilelist<".string(s:netrwmarkfilelist_{bufnr("%")}).">") -" call Decho("g:netrw_list_hide<".g:netrw_list_hide.">") - - " hide the files in the markfile list - for fname in s:netrwmarkfilelist_{bufnr("%")} -" call Decho("match(g:netrw_list_hide<".g:netrw_list_hide.'> fname<\<'.fname.'\>>)='.match(g:netrw_list_hide,'\<'.fname.'\>')." isk=".&isk) - if match(g:netrw_list_hide,'\<'.fname.'\>') != -1 - " remove fname from hiding list - let g:netrw_list_hide= substitute(g:netrw_list_hide,'..\<'.escape(fname,g:netrw_fname_escape).'\>..','','') - let g:netrw_list_hide= substitute(g:netrw_list_hide,',,',',','g') - let g:netrw_list_hide= substitute(g:netrw_list_hide,'^,\|,$','','') -" call Decho("unhide: g:netrw_list_hide<".g:netrw_list_hide.">") - else - " append fname to hiding list - if exists("g:netrw_list_hide") && g:netrw_list_hide != "" - let g:netrw_list_hide= g:netrw_list_hide.',\<'.escape(fname,g:netrw_fname_escape).'\>' - else - let g:netrw_list_hide= '\<'.escape(fname,g:netrw_fname_escape).'\>' - endif -" call Decho("hide: g:netrw_list_hide<".g:netrw_list_hide.">") - endif - endfor - unlet s:netrwmarkfilelist_{bufnr("%")} - unlet s:netrwmarkfilemtch_{bufnr("%")} - 2match none - let g:netrw_hide= 1 - - else - - " switch between show-all/show-not-hidden/show-hidden - let g:netrw_hide=(g:netrw_hide+1)%3 - exe "norm! 0" - if g:netrw_hide && g:netrw_list_hide == "" - call netrw#ErrorMsg(s:WARNING,"your hiding list is empty!",49) -" call Dret("NetrwHide") - return - endif - endif - - call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - call netrw#NetrwRestorePosn(svpos) -" call Dret("NetrwHide") -endfun - -" --------------------------------------------------------------------- -" s:NetrwHidden: invoked by "gh" {{{2 -fun! s:NetrwHidden(islocal) -" call Dfunc("s:NetrwHidden()") - " save current position - let svpos= netrw#NetrwSavePosn() - - if g:netrw_list_hide =~ '\(^\|,\)\\(^\\|\\s\\s\\)\\zs\\.\\S\\+' - " remove pattern from hiding list - let g:netrw_list_hide= substitute(g:netrw_list_hide,'\(^\|,\)\\(^\\|\\s\\s\\)\\zs\\.\\S\\+','','') - elseif strlen(g:netrw_list_hide) >= 1 - let g:netrw_list_hide= g:netrw_list_hide . ',\(^\|\s\s\)\zs\.\S\+' - else - let g:netrw_list_hide= '\(^\|\s\s\)\zs\.\S\+' - endif - - " refresh screen and return to saved position - call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - call netrw#NetrwRestorePosn(svpos) -" call Dret("s:NetrwHidden") -endfun - -" --------------------------------------------------------------------- -" s:NetrwLeftmouse: handles the when in a netrw browsing window {{{2 -fun! s:NetrwLeftmouse(islocal) -" call Dfunc("s:NetrwLeftmouse(islocal=".a:islocal.")") - if a:islocal - if exists("b:netrw_curdir") - call netrw#LocalBrowseCheck(s:NetrwBrowseChgDir(1,s:NetrwGetWord())) - endif - else - if exists("b:netrw_curdir") - call s:NetrwBrowse(0,s:NetrwBrowseChgDir(0,s:NetrwGetWord())) - endif - endif -" call Dret("s:NetrwLeftmouse") -endfun - -" --------------------------------------------------------------------- -" s:NetrwListHide: uses [range]g~...~d to delete files that match comma {{{2 -" separated patterns given in g:netrw_list_hide -fun! s:NetrwListHide() -" call Dfunc("NetrwListHide() hide=".g:netrw_hide." listhide<".g:netrw_list_hide.">") - - " find a character not in the "hide" string to use as a separator for :g and :v commands - " How-it-works: take the hiding command, convert it into a range. Duplicate - " characters don't matter. Remove all such characters from the '/~...90' - " string. Use the first character left as a separator character. - let listhide= g:netrw_list_hide - let sep = strpart(substitute('/~@#$%^&*{};:,<.>?|1234567890','['.escape(listhide,'-]^\').']','','ge'),1,1) -" call Decho("sep=".sep) - - while listhide != "" - if listhide =~ ',' - let hide = substitute(listhide,',.*$','','e') - let listhide = substitute(listhide,'^.\{-},\(.*\)$','\1','e') - else - let hide = listhide - let listhide = "" - endif - - " Prune the list by hiding any files which match - if g:netrw_hide == 1 -" call Decho("hiding<".hide."> listhide<".listhide.">") - exe 'silent keepjumps '.w:netrw_bannercnt.',$g'.sep.hide.sep.'d' - elseif g:netrw_hide == 2 -" call Decho("showing<".hide."> listhide<".listhide.">") - exe 'silent keepjumps '.w:netrw_bannercnt.',$g'.sep.hide.sep.'s@^@ /-KEEP-/ @' - endif - endwhile - if g:netrw_hide == 2 - exe 'silent keepjumps '.w:netrw_bannercnt.',$v@^ /-KEEP-/ @d' - exe 'silent keepjumps '.w:netrw_bannercnt.',$s@^\%( /-KEEP-/ \)\+@@e' - endif - -" call Dret("NetrwListHide") -endfun - -" --------------------------------------------------------------------- -" NetrwHideEdit: allows user to edit the file/directory hiding list -fun! s:NetrwHideEdit(islocal) -" call Dfunc("NetrwHideEdit(islocal=".a:islocal.")") - - " save current cursor position - let svpos= netrw#NetrwSavePosn() - - " get new hiding list from user - call inputsave() - let newhide= input("Edit Hiding List: ",g:netrw_list_hide) - call inputrestore() - let g:netrw_list_hide= newhide -" call Decho("new g:netrw_list_hide<".g:netrw_list_hide.">") - - " refresh the listing - silent call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,"./")) - - " restore cursor position - call netrw#NetrwRestorePosn(svpos) - -" call Dret("NetrwHideEdit") -endfun - -" --------------------------------------------------------------------- -" NetSortSequence: allows user to edit the sorting sequence -fun! s:NetSortSequence(islocal) -" call Dfunc("NetSortSequence(islocal=".a:islocal.")") - - let svpos= netrw#NetrwSavePosn() - call inputsave() - let newsortseq= input("Edit Sorting Sequence: ",g:netrw_sort_sequence) - call inputrestore() - - " refresh the listing - let g:netrw_sort_sequence= newsortseq - call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - call netrw#NetrwRestorePosn(svpos) - -" call Dret("NetSortSequence") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMakeDir: this function makes a directory (both local and remote) {{{2 -fun! s:NetrwMakeDir(usrhost) -" call Dfunc("NetrwMakeDir(usrhost<".a:usrhost.">)") - - " get name of new directory from user. A bare will skip. - " if its currently a directory, also request will be skipped, but with - " a message. - call inputsave() - let newdirname= input("Please give directory name: ") - call inputrestore() -" call Decho("newdirname<".newdirname.">") - - if newdirname == "" -" call Dret("NetrwMakeDir : user aborted with bare ") - return - endif - - if a:usrhost == "" -" call Decho("local mkdir") - - " Local mkdir: - " sanity checks - let fullnewdir= b:netrw_curdir.'/'.newdirname -" call Decho("fullnewdir<".fullnewdir.">") - if isdirectory(fullnewdir) - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:WARNING,"<".newdirname."> is already a directory!",24) - endif -" call Dret("NetrwMakeDir : directory<".newdirname."> exists previously") - return - endif - if s:FileReadable(fullnewdir) - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:WARNING,"<".newdirname."> is already a file!",25) - endif -" call Dret("NetrwMakeDir : file<".newdirname."> exists previously") - return - endif - - " requested new local directory is neither a pre-existing file or - " directory, so make it! - if exists("*mkdir") - call mkdir(fullnewdir,"p") - else - let netrw_origdir= s:NetrwGetcwd(1) - exe 'keepjumps lcd '.fnameescape(b:netrw_curdir) -" call Decho("netrw_origdir<".netrw_origdir.">: lcd b:netrw_curdir<".fnameescape(b:netrw_curdir).">") -" call Decho("exe silent! !".g:netrw_local_mkdir.' '.shellescape(newdirname,1)) - exe "silent! !".g:netrw_local_mkdir.' '.shellescape(newdirname,1) - if !g:netrw_keepdir - exe 'keepjumps lcd '.fnameescape(netrw_origdir) -" call Decho("netrw_keepdir=".g:netrw_keepdir.": keepjumps lcd ".fnameescape(netrw_origdir)." getcwd<".getcwd().">") - endif - endif - - if v:shell_error == 0 - " refresh listing -" call Decho("refresh listing") - let svpos= netrw#NetrwSavePosn() - call s:NetrwRefresh(1,s:NetrwBrowseChgDir(1,'./')) - call netrw#NetrwRestorePosn(svpos) - elseif !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"unable to make directory<".newdirname.">",26) - endif -" redraw! - - elseif !exists("b:netrw_method") || b:netrw_method == 4 - " Remote mkdir: -" call Decho("remote mkdir") - let mkdircmd = s:MakeSshCmd(g:netrw_mkdir_cmd) - let newdirname= substitute(b:netrw_curdir,'^\%(.\{-}/\)\{3}\(.*\)$','\1','').newdirname -" call Decho("exe silent! !".mkdircmd." ".shellescape(newdirname,1)) - exe "silent! !".mkdircmd." ".shellescape(newdirname,1) - if v:shell_error == 0 - " refresh listing - let svpos= netrw#NetrwSavePosn() - call s:NetrwRefresh(0,s:NetrwBrowseChgDir(0,'./')) - call netrw#NetrwRestorePosn(svpos) - elseif !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"unable to make directory<".newdirname.">",27) - endif -" redraw! - - elseif b:netrw_method == 2 - " COMBAK -- future work - call netrw#ErrorMsg(s:ERROR,"making directories via ftp not currently supported",68) - elseif b:netrw_method == 3 - " COMBAK -- future work - call netrw#ErrorMsg(s:ERROR,"making directories via ftp not currently supported",68) - endif - -" call Dret("NetrwMakeDir") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFile: (invoked by mf) This function is used to both {{{2 -" mark and unmark files. If a markfile list exists, -" then the rename and delete functions will use it instead -" of whatever may happen to be under the cursor at that -" moment. When the mouse and gui are available, -" shift-leftmouse may also be used to mark files. -" -" Creates two lists -" s:netrwmarkfilelist -- holds complete paths to all marked files -" s:netrwmarkfilelist_# -- holds list of marked files in current-buffer's directory (#==bufnr()) -" -" Creates a marked file match string -" s:netrwmarfilemtch_# -- used with 2match to display marked files -" -" Creates a buffer version of islocal -" b:netrw_islocal -" -fun! s:NetrwMarkFile(islocal,fname) -" call Dfunc("s:NetrwMarkFile(islocal=".a:islocal." fname<".a:fname.">)") - let curbufnr= bufnr("%") - let curdir = b:netrw_curdir - if exists("s:netrwmarkfilelist_{curbufnr}") - " markfile list exists -" call Decho("starting s:netrwmarkfilelist_{curbufnr}<".string(s:netrwmarkfilelist_{curbufnr}).">") -" call Decho("starting s:netrwmarkfilemtch_{curbufnr}<".s:netrwmarkfilemtch_{curbufnr}.">") - let b:netrw_islocal= a:islocal - - if index(s:netrwmarkfilelist_{curbufnr},a:fname) == -1 - " append filename to buffer's markfilelist -" call Decho("append filename<".a:fname."> to local markfilelist_".curbufnr."<".string(s:netrwmarkfilelist_{curbufnr}).">") - call add(s:netrwmarkfilelist_{curbufnr},a:fname) - let s:netrwmarkfilemtch_{curbufnr}= s:netrwmarkfilemtch_{curbufnr}.'\|\<'.escape(a:fname,g:netrw_markfileesc."'".g:netrw_markfileesc."'").'\>' - - else - " remove filename from buffer's markfilelist -" call Decho("remove filename<".a:fname."> from local markfilelist_".curbufnr."<".string(s:netrwmarkfilelist_{curbufnr}).">") - call filter(s:netrwmarkfilelist_{curbufnr},'v:val != a:fname') - if s:netrwmarkfilelist_{curbufnr} == [] - " local markfilelist is empty; remove it entirely -" call Decho("markfile list now empty, unlet s:netrwmarkfilelist_".curbufnr." and ...mtch_".curbufnr) - call s:NetrwUnmarkList(curbufnr,curdir) - else - " rebuild match list to display markings correctly -" call Decho("rebuild s:netrwmarkfilemtch_".curbufnr) - let s:netrwmarkfilemtch_{curbufnr}= "" - let first = 1 - for fname in s:netrwmarkfilelist_{curbufnr} - if first - let s:netrwmarkfilemtch_{curbufnr}= s:netrwmarkfilemtch_{curbufnr}.'\<'.escape(fname,g:netrw_markfileesc."'".g:netrw_markfileesc."'").'\>' - else - let s:netrwmarkfilemtch_{curbufnr}= s:netrwmarkfilemtch_{curbufnr}.'\|\<'.escape(fname,g:netrw_markfileesc."'".g:netrw_markfileesc."'").'\>' - endif - let first= 0 - endfor -" call Decho("ending s:netrwmarkfilelist_"curbufnr."<".string(s:netrwmarkfilelist_{curbufnr}).">") -" call Decho("ending s:netrwmarkfilemtch_"curbufnr."<".s:netrwmarkfilemtch_{curbufnr}.">") - endif - endif - - else - " initialize new markfilelist - -" call Decho("add fname<".a:fname."> to new markfilelist_".curbufnr) - let s:netrwmarkfilelist_{curbufnr}= [] - call add(s:netrwmarkfilelist_{curbufnr},a:fname) -" call Decho("ending s:netrwmarkfilelist_{curbufnr}<".string(s:netrwmarkfilelist_{curbufnr}).">") - - " build initial markfile matching pattern - if a:fname =~ '/$' - let s:netrwmarkfilemtch_{curbufnr}= '\<'.escape(a:fname,g:netrw_markfileesc) - else - let s:netrwmarkfilemtch_{curbufnr}= '\<'.escape(a:fname,g:netrw_markfileesc).'\>' - endif -" call Decho("ending s:netrwmarkfilemtch_".curbufnr."<".s:netrwmarkfilemtch_{curbufnr}.">") - endif - - " handle global markfilelist - if exists("s:netrwmarkfilelist") - let dname= s:ComposePath(b:netrw_curdir,a:fname) - if index(s:netrwmarkfilelist,dname) == -1 - " append new filename to global markfilelist - call add(s:netrwmarkfilelist,s:ComposePath(b:netrw_curdir,a:fname)) -" call Decho("append filename<".a:fname."> to global markfilelist<".string(s:netrwmarkfilelist).">") - else - " remove new filename from global markfilelist -" call Decho("filter(".string(s:netrwmarkfilelist).",'v:val != '.".dname.")") - call filter(s:netrwmarkfilelist,'v:val != "'.dname.'"') -" call Decho("ending s:netrwmarkfilelist <".string(s:netrwmarkfilelist).">") - if s:netrwmarkfilelist == [] - unlet s:netrwmarkfilelist - endif - endif - else - " initialize new global-directory markfilelist - let s:netrwmarkfilelist= [] - call add(s:netrwmarkfilelist,s:ComposePath(b:netrw_curdir,a:fname)) -" call Decho("init s:netrwmarkfilelist<".string(s:netrwmarkfilelist).">") - endif - - " set up 2match'ing to netrwmarkfilemtch list - if exists("s:netrwmarkfilemtch_{curbufnr}") && s:netrwmarkfilemtch_{curbufnr} != "" -" call Decho("exe 2match netrwMarkFile /".s:netrwmarkfilemtch_{curbufnr}."/") - exe "2match netrwMarkFile /".s:netrwmarkfilemtch_{curbufnr}."/" - else -" call Decho("2match none") - 2match none - endif -" call Dret("s:NetrwMarkFile : netrwmarkfilelist_".curbufnr."<".(exists("s:netrwmarkfilelist_{curbufnr}")? string(s:netrwmarkfilelist_{curbufnr}) : " doesn't exist").">") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFileCompress: (invoked by mz) This function is used to {{{2 -" compress/decompress files using the programs -" in g:netrw_compress and g:netrw_uncompress, -" using g:netrw_compress_suffix to know which to -" do. By default: -" g:netrw_compress = "gzip" -" g:netrw_decompress = { ".gz" : "gunzip" , ".bz2" : "bunzip2" , ".zip" : "unzip" , ".tar" : "tar -xf"} -fun! s:NetrwMarkFileCompress(islocal) -" call Dfunc("s:NetrwMarkFileCompress(islocal=".a:islocal.")") - let svpos = netrw#NetrwSavePosn() - let curdir = b:netrw_curdir - let curbufnr = bufnr("%") - - if exists("s:netrwmarkfilelist_{curbufnr}") && exists("g:netrw_compress") && exists("g:netrw_decompress") - for fname in s:netrwmarkfilelist_{curbufnr} - " for every filename in the marked list - for sfx in sort(keys(g:netrw_decompress)) - if fname =~ '\'.sfx.'$' - " fname has a suffix indicating that its compressed; apply associated decompression routine - let exe= s:WinPath(g:netrw_decompress[sfx]) -" call Decho("fname<".fname."> is compressed so decompress with <".exe.">") - if a:islocal - if g:netrw_keepdir - let fname= shellescape(s:ComposePath(curdir,fname)) - endif - else - let fname= shellescape(b:netrw_curdir.fname,1) - endif - if executable(exe) - if a:islocal - call system(exe." ".fname) - else - call s:RemoteSystem(exe." ".fname) - endif - else - call netrw#ErrorMsg(s:WARNING,"unable to apply<".exe."> to file<".fname.">",50) - endif - break - endif - endfor - if exists("exe") - unlet exe - elseif a:islocal - " fname not a compressed file, so compress it - call system(s:WinPath(g:netrw_compress)." ".shellescape(s:ComposePath(b:netrw_curdir,fname))) - else - " fname not a compressed file, so compress it - call s:RemoteSystem(s:WinPath(g:netrw_compress)." ".shellescape(fname)) - endif - endfor - call s:NetrwUnmarkList(curbufnr,curdir) - call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - call netrw#NetrwRestorePosn(svpos) - endif -" call Dret("s:NetrwMarkFileCompress") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFileCopy: (invoked by mc) copy marked files to target {{{2 -" If no marked files, then set up directory as the -" target. Currently does not support copying entire -" directories. Uses the local-buffer marked file list. -" Returns 1=success (used by NetrwMarkFileMove()) -" 0=failure -fun! s:NetrwMarkFileCopy(islocal) -" call Dfunc("s:NetrwMarkFileCopy(islocal=".a:islocal.") target<".(exists("s:netrwmftgt")? s:netrwmftgt : '---').">") - - " sanity checks - if !exists("s:netrwmarkfilelist_{bufnr('%')}") || empty(s:netrwmarkfilelist_{bufnr('%')}) - call netrw#ErrorMsg(2,"there are no marked files in this window (:help netrw-mf)",66) -" call Dret("s:NetrwMarkFileCopy 0") - return 0 - endif -" call Decho("sanity chk passed: s:netrwmarkfilelist_".bufnr('%')."<".string(s:netrwmarkfilelist_{bufnr('%')})) - if !exists("s:netrwmftgt") - call netrw#ErrorMsg(2,"your marked file target is empty! (:help netrw-mt)",67) -" call Dret("s:NetrwMarkFileCopy 0") - return 0 - endif -" call Decho("sanity chk passed: s:netrwmftgt<".s:netrwmftgt.">") - let curdir = b:netrw_curdir - let curbufnr = bufnr("%") - - if a:islocal && s:netrwmftgt_islocal - " Copy marked files, local directory to local directory -" call Decho("copy from local to local") - let args= join(map(deepcopy(s:netrwmarkfilelist_{bufnr('%')}),"shellescape(b:netrw_curdir.\"/\".v:val)")) -" call Decho("system(".g:netrw_localcopycmd." ".args." ".shellescape(s:netrwmftgt).")") - call system(s:WinPath(g:netrw_localcopycmd)." ".args." ".shellescape(s:netrwmftgt)) - - elseif a:islocal && !s:netrwmftgt_islocal - " Copy marked files, local directory to remote directory -" call Decho("copy from local to remote") - call s:NetrwUpload(s:netrwmarkfilelist_{bufnr('%')},s:netrwmftgt) - - elseif !a:islocal && s:netrwmftgt_islocal -" call Decho("copy from remote to local") - call netrw#NetrwObtain(a:islocal,s:netrwmarkfilelist_{bufnr('%')},s:netrwmftgt) - - elseif !a:islocal && !s:netrwmftgt_islocal -" call Decho("copy from remote to remote") - let curdir = getcwd() - let tmpdir = s:GetTempfile("") - if tmpdir !~ '/' - let tmpdir= curdir."/".tmpdir - endif - if exists("*mkdir") - call mkdir(tmpdir) - else - exe "silent! !".g:netrw_local_mkdir.' '.shellescape(tmpdir,1) - endif - if isdirectory(tmpdir) - exe "keepjumps lcd ".fnameescape(tmpdir) - call netrw#NetrwObtain(a:islocal,s:netrwmarkfilelist_{bufnr('%')},tmpdir) - let localfiles= map(deepcopy(s:netrwmarkfilelist_{bufnr('%')}),'substitute(v:val,"^.*/","","")') - call s:NetrwUpload(localfiles,s:netrwmftgt) - if getcwd() == tmpdir - for fname in s:netrwmarkfilelist_{bufnr('%')} - call s:NetrwDelete(fname) - endfor - exe "keepjumps lcd ".fnameescape(curdir) - exe "silent !".g:netrw_local_rmdir." ".shellescape(tmpdir,1) - else - exe "keepjumps lcd ".fnameescape(curdir) - endif - endif - endif - - " ------- - " cleanup - " ------- -" call Decho("cleanup") - - " remove markings from local buffer - call s:NetrwUnmarkList(curbufnr,curdir) - - " refresh buffers - if !s:netrwmftgt_islocal - call s:NetrwRefreshDir(s:netrwmftgt_islocal,s:netrwmftgt) - endif - if a:islocal - call s:NetrwRefreshDir(a:islocal,b:netrw_curdir) - endif - call s:LocalBrowseShellCmdRefresh() - -" call Dret("s:NetrwMarkFileCopy 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFileDiff: (invoked by md) This function is used to {{{2 -" invoke vim's diff mode on the marked files. -" Either two or three files can be so handled. -" Uses the global marked file list. -fun! s:NetrwMarkFileDiff(islocal) -" call Dfunc("s:NetrwMarkFileDiff(islocal=".a:islocal.") b:netrw_curdir<".b:netrw_curdir.">") - let curbufnr= bufnr("%") - - if exists("s:netrwmarkfilelist_{curbufnr}") - let cnt = 0 - let curdir = b:netrw_curdir - for fname in s:netrwmarkfilelist - let cnt= cnt + 1 - if cnt == 1 -" call Decho("diffthis: fname<".fname.">") - exe "e ".fnameescape(fname) - diffthis - elseif cnt == 2 || cnt == 3 - vsplit - wincmd l -" call Decho("diffthis: ".fname) - exe "e ".fnameescape(fname) - diffthis - else - break - endif - endfor - call s:NetrwUnmarkList(curbufnr,curdir) - endif - -" call Dret("s:NetrwMarkFileDiff") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFileEdit: (invoked by me) put marked files on arg list and start editing them {{{2 -" Uses global markfilelist -fun! s:NetrwMarkFileEdit(islocal) -" call Dfunc("s:NetrwMarkFileEdit(islocal=".a:islocal.")") - - let curdir = b:netrw_curdir - let curbufnr = bufnr("%") - if exists("s:netrwmarkfilelist_{curbufnr}") - call s:SetRexDir(a:islocal,curdir) - let flist= join(map(deepcopy(s:netrwmarkfilelist), "fnameescape(v:val)")) - " unmark markedfile list -" call s:NetrwUnmarkList(curbufnr,curdir) - call s:NetrwUnmarkAll() -" call Decho("exe silent args ".flist) - exe "silent args ".flist - endif - -" call Dret("s:NetrwMarkFileEdit") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFileExe: (invoked by mx) execute arbitrary command on marked files, one at a time {{{2 -" Uses the local marked-file list. -fun! s:NetrwMarkFileExe(islocal) -" call Dfunc("s:NetrwMarkFileExe(islocal=".a:islocal.")") - let svpos = netrw#NetrwSavePosn() - let curdir = b:netrw_curdir - let curbufnr = bufnr("%") - - if exists("s:netrwmarkfilelist_{curbufnr}") - " get the command - call inputsave() - let cmd= input("Enter command: ","","file") - call inputrestore() -" call Decho("cmd<".cmd.">") - - " apply command to marked files. Substitute: filename -> % - " If no %, then append a space and the filename to the command - for fname in s:netrwmarkfilelist_{curbufnr} - if a:islocal - if g:netrw_keepdir - let fname= shellescape(s:WinPath(s:ComposePath(curdir,fname))) - endif - else - let fname= shellescape(s:WinPath(b:netrw_curdir.fname)) - endif - if cmd =~ '%' - let xcmd= substitute(cmd,'%',fname,'g') - else - let xcmd= cmd.' '.fname - endif - if a:islocal -" call Decho("local: xcmd<".xcmd.">") - let ret= system(xcmd) - else -" call Decho("remote: xcmd<".xcmd.">") - let ret= s:RemoteSystem(xcmd) - endif - if v:shell_error < 0 - call netrw#ErrorMsg(s:ERROR,"command<".xcmd."> failed, aborting",54) - break - else - echo ret - endif - endfor - - " unmark marked file list - call s:NetrwUnmarkList(curbufnr,curdir) - - " refresh the listing - call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - call netrw#NetrwRestorePosn(svpos) - else - call netrw#ErrorMsg(s:ERROR,"no files marked!",59) - endif - -" call Dret("s:NetrwMarkFileExe") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkHideSfx: (invoked by mh) (un)hide files having same suffix -" as the marked file(s) (toggles suffix presence) -" Uses the local marked file list. -fun! s:NetrwMarkHideSfx(islocal) -" call Dfunc("s:NetrwMarkHideSfx(islocal=".a:islocal.")") - let svpos = netrw#NetrwSavePosn() - let curbufnr = bufnr("%") - - " s:netrwmarkfilelist_{curbufnr}: the List of marked files - if exists("s:netrwmarkfilelist_{curbufnr}") - - for fname in s:netrwmarkfilelist_{curbufnr} -" call Decho("s:NetrwMarkFileCopy: fname<".fname.">") - " construct suffix pattern - if fname =~ '\.' - let sfxpat= "^.*".substitute(fname,'^.*\(\.[^. ]\+\)$','\1','') - else - let sfxpat= '^\%(\%(\.\)\@!.\)*$' - endif - " determine if its in the hiding list or not - let inhidelist= 0 - if g:netrw_list_hide != "" - let itemnum = 0 - let hidelist= split(g:netrw_list_hide,',') - for hidepat in hidelist - if sfxpat == hidepat - let inhidelist= 1 - break - endif - let itemnum= itemnum + 1 - endfor - endif -" call Decho("fname<".fname."> inhidelist=".inhidelist." sfxpat<".sfxpat.">") - if inhidelist - " remove sfxpat from list - call remove(hidelist,itemnum) - let g:netrw_list_hide= join(hidelist,",") - elseif g:netrw_list_hide != "" - " append sfxpat to non-empty list - let g:netrw_list_hide= g:netrw_list_hide.",".sfxpat - else - " set hiding list to sfxpat - let g:netrw_list_hide= sfxpat - endif - endfor - - " refresh the listing - call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - call netrw#NetrwRestorePosn(svpos) - else - call netrw#ErrorMsg(s:ERROR,"no files marked!",59) - endif - -" call Dret("s:NetrwMarkHideSfx") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFileGrep: (invoked by mg) This function applies vimgrep to marked files {{{2 -" Uses the global markfilelist -fun! s:NetrwMarkFileGrep(islocal) -" call Dfunc("s:NetrwMarkFileGrep(islocal=".a:islocal.")") - let svpos = netrw#NetrwSavePosn() - let curbufnr = bufnr("%") - - if exists("s:netrwmarkfilelist") -" call Decho("s:netrwmarkfilelist".string(s:netrwmarkfilelist).">") - let netrwmarkfilelist= join(map(deepcopy(s:netrwmarkfilelist), "fnameescape(v:val)")) - call s:NetrwUnmarkAll() - - " ask user for pattern - call inputsave() - let pat= input("Enter pattern: ","") - call inputrestore() - if pat !~ '^\s' - if pat !~ '^/' - let pat= '/'.pat.'/' - endif - let pat= " ".pat - endif - - " use vimgrep for both local and remote -" call Decho("exe vimgrep".pat." ".netrwmarkfilelist) - exe "vimgrep".pat." ".netrwmarkfilelist - - 2match none - call netrw#NetrwRestorePosn(svpos) - endif - -" call Dret("s:NetrwMarkFileGrep") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFileMove: (invoked by mm) execute arbitrary command on marked files, one at a time {{{2 -" uses the global marked file list -" s:netrwmfloc= 0: target directory is remote -" = 1: target directory is local -fun! s:NetrwMarkFileMove(islocal) -" call Dfunc("s:NetrwMarkFileMove(islocal=".a:islocal.")") - let curdir = b:netrw_curdir - let curbufnr = bufnr("%") - - " sanity check - if !exists("s:netrwmarkfilelist_{bufnr('%')}") || empty(s:netrwmarkfilelist_{bufnr('%')}) - call netrw#ErrorMsg(2,"there are no marked files in this window (:help netrw-mf)",66) -" call Dret("s:NetrwMarkFileMove") - return - endif -" call Decho("sanity chk passed: s:netrwmarkfilelist_".bufnr('%')."<".string(s:netrwmarkfilelist_{bufnr('%')})) - if !exists("s:netrwmftgt") - call netrw#ErrorMsg(2,"your marked file target is empty! (:help netrw-mt)",67) -" call Dret("s:NetrwMarkFileCopy 0") - return 0 - endif -" call Decho("sanity chk passed: s:netrwmftgt<".s:netrwmftgt.">") - - if a:islocal && s:netrwmftgt_islocal - " move: local -> local -" call Decho("move from local to local") -" call Decho("(s:NetrwMarkFileMove) local to local move") - if executable(g:netrw_localmovecmd) - for fname in s:netrwmarkfilelist_{bufnr("%")} -" call Decho("system(".g:netrw_localmovecmd." ".shellescape(fname)." ".shellescape(s:netrwmftgt).")") - let ret= system(g:netrw_localmovecmd." ".shellescape(fname)." ".shellescape(s:netrwmftgt)) - if v:shell_error < 0 - call netrw#ErrorMsg(s:ERROR,"command<".g:netrw_localmovecmd."> failed, aborting",54) - break - endif - endfor - else - call netrw#ErrorMsg(s:ERROR,"command<".g:netrw_localmovecmd."> is not executable!",57) - endif - - elseif a:islocal && !s:netrwmftgt_islocal - " move: local -> remote -" call Decho("move from local to remote") -" call Decho("copy") - let mflist= s:netrwmarkfilelist_{bufnr("%")} - call s:NetrwMarkFileCopy(a:islocal) -" call Decho("remove") - for fname in mflist - let barefname = substitute(fname,'^\(.*/\)\(.\{-}\)$','\2','') - let ok = s:NetrwLocalRmFile(b:netrw_curdir,barefname,1) - endfor - unlet mflist - - elseif !a:islocal && s:netrwmftgt_islocal - " move: remote -> local -" call Decho("move from remote to local") -" call Decho("copy") - let mflist= s:netrwmarkfilelist_{bufnr("%")} - call s:NetrwMarkFileCopy(a:islocal) -" call Decho("remove") - for fname in mflist - let barefname = substitute(fname,'^\(.*/\)\(.\{-}\)$','\2','') - let ok = s:NetrwRemoteRmFile(b:netrw_curdir,barefname,1) - endfor - unlet mflist - - elseif !a:islocal && !s:netrwmftgt_islocal - " move: remote -> remote -" call Decho("move from remote to remote") -" call Decho("copy") - let mflist= s:netrwmarkfilelist_{bufnr("%")} - call s:NetrwMarkFileCopy(a:islocal) -" call Decho("remove") - for fname in mflist - let barefname = substitute(fname,'^\(.*/\)\(.\{-}\)$','\2','') - let ok = s:NetrwRemoteRmFile(b:netrw_curdir,barefname,1) - endfor - unlet mflist - endif - - " ------- - " cleanup - " ------- -" call Decho("cleanup") - - " remove markings from local buffer - call s:NetrwUnmarkList(curbufnr,curdir) " remove markings from local buffer - - " refresh buffers - if !s:netrwmftgt_islocal - call s:NetrwRefreshDir(s:netrwmftgt_islocal,s:netrwmftgt) - endif - if a:islocal - call s:NetrwRefreshDir(a:islocal,b:netrw_curdir) - endif - call s:LocalBrowseShellCmdRefresh() - -" call Dret("s:NetrwMarkFileMove") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFilePrint: (invoked by mp) This function prints marked files {{{2 -" using the hardcopy command. Local marked-file list only. -fun! s:NetrwMarkFilePrint(islocal) -" call Dfunc("s:NetrwMarkFilePrint(islocal=".a:islocal.")") - let curbufnr= bufnr("%") - if exists("s:netrwmarkfilelist_{curbufnr}") - let netrwmarkfilelist = s:netrwmarkfilelist_{curbufnr} - let curdir = b:netrw_curdir - call s:NetrwUnmarkList(curbufnr,curdir) - for fname in netrwmarkfilelist - if a:islocal - if g:netrw_keepdir - let fname= s:ComposePath(curdir,fname) - endif - else - let fname= curdir.fname - endif - 1split - " the autocmds will handle both local and remote files -" call Decho("exe silent e ".escape(fname,' ')) - exe "silent e ".fnameescape(fname) -" call Decho("hardcopy") - hardcopy - q - endfor - 2match none - endif -" call Dret("s:NetrwMarkFilePrint") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFileRegexp: (invoked by mr) This function is used to mark {{{2 -" files when given a regexp (for which a prompt is -" issued). -fun! s:NetrwMarkFileRegexp(islocal) -" call Dfunc("s:NetrwMarkFileRegexp(islocal=".a:islocal.")") - - " get the regular expression - call inputsave() - let regexp= input("Enter regexp: ","","file") - call inputrestore() - - if a:islocal - " get the matching list of files using local glob() -" call Decho("handle local regexp") - let dirname = escape(b:netrw_curdir,g:netrw_glob_escape) - let filelist = glob(s:ComposePath(dirname,regexp)) - if filelist != "" - let filelist= filelist."\n" - endif - - " mark the list of files - while filelist != "" - if filelist =~ '\n' - let filename = substitute(filelist,'\n.*$','','e') - let filelist = substitute(filelist,'^.\{-}\n\(.*\)$','\1','e') - else - let filename = filelist - let filelist = "" - endif -" call Decho("filelist<".filelist.">") -" call Decho("filename<".filename.">") - call s:NetrwMarkFile(a:islocal,substitute(filename,'^.*/','','')) - endwhile - - else -" call Decho("handle remote regexp") - - " convert displayed listing into a filelist - let eikeep = &ei - let areg = @a - silent %y a - set ei=all ma -" call Decho("set ei=all ma") - 1split - enew - silent norm! "ap - 2 - let bannercnt= search('^" =====','W') - exe "silent 1,".bannercnt."d" - set bt=nofile - if g:netrw_liststyle == s:LONGLIST - silent %s/\s\{2,}\S.*$//e - elseif g:netrw_liststyle == s:WIDELIST - silent %s/\s\{2,}/\r/ge - elseif g:netrw_liststyle == s:TREELIST - silent %s/^| //e - silent! g/^ .*$/d - endif - " convert regexp into the more usual glob-style format - let regexp= substitute(regexp,'\*','.*','g') -" call Decho("regexp<".regexp.">") - exe "silent! v/".escape(regexp,'/')."/d" - let filelist= getline(1,line("$")) - q! - for filename in filelist - call s:NetrwMarkFile(a:islocal,substitute(filename,'^.*/','','')) - endfor - unlet filelist - let @a = areg - let &ei = eikeep - endif - -" call Dret("s:NetrwMarkFileRegexp") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFileSource: (invoked by ms) This function sources marked files {{{2 -" Uses the local marked file list. -fun! s:NetrwMarkFileSource(islocal) -" call Dfunc("s:NetrwMarkFileSource(islocal=".a:islocal.")") - let curbufnr= bufnr("%") - if exists("s:netrwmarkfilelist_{curbufnr}") - let netrwmarkfilelist = s:netrwmarkfilelist_{bufnr("%")} - let curdir = b:netrw_curdir - call s:NetrwUnmarkList(curbufnr,curdir) - for fname in netrwmarkfilelist - if a:islocal - if g:netrw_keepdir - let fname= s:ComposePath(curdir,fname) - endif - else - let fname= curdir.fname - endif - " the autocmds will handle sourcing both local and remote files -" call Decho("exe so ".fnameescape(fname)) - exe "so ".fnameescape(fname) - endfor - 2match none - endif -" call Dret("s:NetrwMarkFileSource") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFileTag: (invoked by mT) This function applies g:netrw_ctags to marked files {{{2 -" Uses the global markfilelist -fun! s:NetrwMarkFileTag(islocal) -" call Dfunc("s:NetrwMarkFileTag(islocal=".a:islocal.")") - let svpos = netrw#NetrwSavePosn() - let curdir = b:netrw_curdir - let curbufnr = bufnr("%") - - if exists("s:netrwmarkfilelist") -" call Decho("s:netrwmarkfilelist".string(s:netrwmarkfilelist).">") - let netrwmarkfilelist= join(map(deepcopy(s:netrwmarkfilelist), "shellescape(v:val,".!a:islocal.")")) - call s:NetrwUnmarkAll() - - if a:islocal - if executable(g:netrw_ctags) -" call Decho("call system(".g:netrw_ctags." ".netrwmarkfilelist.")") - call system(g:netrw_ctags." ".netrwmarkfilelist) - else - call netrw#ErrorMsg(s:ERROR,"g:netrw_ctags<".g:netrw_ctags."> is not executable!",51) - endif - else - let cmd = s:RemoteSystem(g:netrw_ctags." ".netrwmarkfilelist) - call netrw#NetrwObtain(a:islocal,"tags") - let curdir= b:netrw_curdir - 1split - e tags - let path= substitute(curdir,'^\(.*\)/[^/]*$','\1/','') -" call Decho("curdir<".curdir."> path<".path.">") - exe '%s/\t\(\S\+\)\t/\t'.escape(path,"/\n\r\\").'\1\t/e' - wq! - endif - 2match none - call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - call netrw#NetrwRestorePosn(svpos) - endif - -" call Dret("s:NetrwMarkFileTag") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMarkFileTgt: (invoked by mt) This function sets up a marked file target {{{2 -" Sets up two variables, -" s:netrwmftgt : holds the target directory -" s:netrwmftgt_islocal : 0=target directory is remote -" 1=target directory is local -fun! s:NetrwMarkFileTgt(islocal) -" call Dfunc("s:NetrwMarkFileTgt(islocal=".a:islocal.")") - let svpos = netrw#NetrwSavePosn() - let curdir = b:netrw_curdir - let hadtgt = exists("s:netrwmftgt") - if !exists("w:netrw_bannercnt") - let w:netrw_bannercnt= b:netrw_bannercnt - endif - - " set up target - if line(".") < w:netrw_bannercnt - " if cursor in banner region, use b:netrw_curdir for the target - let s:netrwmftgt= b:netrw_curdir -" call Decho("inbanner: s:netrwmftgt<".s:netrwmftgt.">") - - else - " get word under cursor. - " * If directory, use it for the target. - " * If file, use b:netrw_curdir for the target - let curword= s:NetrwGetWord() - let tgtdir = s:ComposePath(curdir,curword) - if a:islocal && isdirectory(tgtdir) - let s:netrwmftgt = tgtdir -" call Decho("local isdir: s:netrwmftgt<".s:netrwmftgt.">") - elseif !a:islocal && tgtdir =~ '/$' - let s:netrwmftgt = tgtdir -" call Decho("remote isdir: s:netrwmftgt<".s:netrwmftgt.">") - else - let s:netrwmftgt = curdir -" call Decho("isfile: s:netrwmftgt<".s:netrwmftgt.">") - endif - endif - if a:islocal - " simplify the target (eg. /abc/def/../ghi -> /abc/ghi) - let s:netrwmftgt= simplify(s:netrwmftgt) -" call Decho("simplify: s:netrwmftgt<".s:netrwmftgt.">") - endif - if g:netrw_cygwin - let s:netrwmftgt= substitute(system("cygpath ".shellescape(s:netrwmftgt)),'\n$','','') - let s:netrwmftgt= substitute(s:netrwmftgt,'\n$','','') - endif - let s:netrwmftgt_islocal= a:islocal - - if g:netrw_fastbrowse > 0 - call s:LocalBrowseShellCmdRefresh() - endif - call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - call netrw#NetrwRestorePosn(svpos) - if !hadtgt - norm! j - endif - -" call Dret("s:NetrwMarkFileTgt : netrwmftgt<".(exists("s:netrwmftgt")? s:netrwmftgt : "").">") -endfun - -" --------------------------------------------------------------------- -" s:NetrwOpenFile: query user for a filename and open it {{{2 -fun! s:NetrwOpenFile(islocal) -" call Dfunc("s:NetrwOpenFile(islocal=".a:islocal.")") - call inputsave() - let fname= input("Enter filename: ") - call inputrestore() - if fname !~ '[/\\]' - if exists("b:netrw_curdir") - if exists("g:netrw_quiet") - let netrw_quiet_keep = g:netrw_quiet - endif - let g:netrw_quiet = 1 - if b:netrw_curdir =~ '/$' - exe "e ".fnameescape(b:netrw_curdir.fname) - else - exe "e ".fnameescape(b:netrw_curdir."/".fname) - endif - if exists("netrw_quiet_keep") - let g:netrw_quiet= netrw_quiet_keep - else - unlet g:netrw_quiet - endif - endif - else - exe "e ".fnameescape(fname) - endif -" call Dret("s:NetrwOpenFile") -endfun - -" --------------------------------------------------------------------- -" s:NetrwUnmarkList: delete local marked file lists and remove their contents from the global marked-file list {{{2 -fun! s:NetrwUnmarkList(curbufnr,curdir) -" call Dfunc("s:NetrwUnmarkList(curbufnr=".a:curbufnr." curdir<".a:curdir.">)") - - " remove all files in local marked-file list from global list - if exists("s:netrwmarkfilelist_{a:curbufnr}") - for mfile in s:netrwmarkfilelist_{a:curbufnr} - let dfile = s:ComposePath(a:curdir,mfile) " prepend directory to mfile - let idx = index(s:netrwmarkfilelist,dfile) " get index in list of dfile - call remove(s:netrwmarkfilelist,idx) " remove from global list - endfor - if s:netrwmarkfilelist == [] - unlet s:netrwmarkfilelist - endif - - " getting rid of the local marked-file lists is easy - unlet s:netrwmarkfilelist_{a:curbufnr} - endif - if exists("s:netrwmarkfilemtch_{a:curbufnr}") - unlet s:netrwmarkfilemtch_{a:curbufnr} - endif - 2match none -" call Dret("s:NetrwUnmarkList") -endfun - -" --------------------------------------------------------------------- -" s:NetrwUnmarkAll: remove the global marked file list and all local ones {{{2 -fun! s:NetrwUnmarkAll() -" call Dfunc("s:NetrwUnmarkAll()") - if exists("s:netrwmarkfilelist") - unlet s:netrwmarkfilelist - endif - silent call s:NetrwUnmarkAll2() - 2match none -" call Dret("s:NetrwUnmarkAll") -endfun - -" --------------------------------------------------------------------- -" s:NetrwUnmarkAll2: {{{2 -fun! s:NetrwUnmarkAll2() -" call Dfunc("s:NetrwUnmarkAll2()") - redir => netrwmarkfilelist_let - let - redir END - let netrwmarkfilelist_list= split(netrwmarkfilelist_let,'\n') " convert let string into a let list - call filter(netrwmarkfilelist_list,"v:val =~ '^s:netrwmarkfilelist_'") " retain only those vars that start as s:netrwmarkfilelist_ - call map(netrwmarkfilelist_list,"substitute(v:val,'\\s.*$','','')") " remove what the entries are equal to - for flist in netrwmarkfilelist_list - let curbufnr= substitute(flist,'s:netrwmarkfilelist_','','') - unlet s:netrwmarkfilelist_{curbufnr} - unlet s:netrwmarkfilemtch_{curbufnr} - endfor -" call Dret("s:NetrwUnmarkAll2") -endfun - -" --------------------------------------------------------------------- -" s:NetrwUnMarkFile: {{{2 -fun! s:NetrwUnMarkFile(islocal) -" call Dfunc("s:NetrwUnMarkFile(islocal=".a:islocal.")") - let svpos = netrw#NetrwSavePosn() - let curbufnr = bufnr("%") - - " unmark marked file list (although I expect s:NetrwUpload() - " to do it, I'm just making sure) - if exists("s:netrwmarkfilelist_{bufnr('%')}") -" call Decho("unlet'ing: s:netrwmarkfile[list|mtch]_".bufnr("%")) - unlet s:netrwmarkfilelist - unlet s:netrwmarkfilelist_{curbufnr} - unlet s:netrwmarkfilemtch_{curbufnr} - 2match none - endif - -" call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - call netrw#NetrwRestorePosn(svpos) -" call Dret("s:NetrwUnMarkFile") -endfun - -" --------------------------------------------------------------------- -" s:NetrwMenu: generates the menu for gvim and netrw {{{2 -fun! s:NetrwMenu(domenu) - - if !exists("g:NetrwMenuPriority") - let g:NetrwMenuPriority= 80 - endif - - if has("menu") && has("gui_running") && &go =~ 'm' && g:netrw_menu -" call Dfunc("NetrwMenu(domenu=".a:domenu.")") - - if !exists("s:netrw_menu_enabled") && a:domenu -" call Decho("initialize menu") - let s:netrw_menu_enabled= 1 - exe 'silent! menu '.g:NetrwMenuPriority.'.1 '.g:NetrwTopLvlMenu.'Help ' - call s:NetrwBookmarkMenu() " provide some history! uses priorities 2,3, reserves 4 - exe 'silent! menu '.g:NetrwMenuPriority.'.5 '.g:NetrwTopLvlMenu.'-Sep1- :' - exe 'silent! menu '.g:NetrwMenuPriority.'.6 '.g:NetrwTopLvlMenu.'Go\ Up\ Directory- -' - exe 'silent! menu '.g:NetrwMenuPriority.'.7 '.g:NetrwTopLvlMenu.'Apply\ Special\ Viewerx x' - exe 'silent! menu '.g:NetrwMenuPriority.'.8.1 '.g:NetrwTopLvlMenu.'Bookmarks\ and\ History.Bookmark\ Current\ Directorymb mb' - exe 'silent! menu '.g:NetrwMenuPriority.'.8.2 '.g:NetrwTopLvlMenu.'Bookmarks\ and\ History.Bookmark\ DeletemB mB' - exe 'silent! menu '.g:NetrwMenuPriority.'.8.3 '.g:NetrwTopLvlMenu.'Bookmarks\ and\ History.Goto\ Bookmarkgb gb' - exe 'silent! menu '.g:NetrwMenuPriority.'.8.4 '.g:NetrwTopLvlMenu.'Bookmarks\ and\ History.Goto\ Prev\ Dir\ (History)u u' - exe 'silent! menu '.g:NetrwMenuPriority.'.8.5 '.g:NetrwTopLvlMenu.'Bookmarks\ and\ History.Goto\ Next\ Dir\ (History)U U' - exe 'silent! menu '.g:NetrwMenuPriority.'.8.6 '.g:NetrwTopLvlMenu.'Bookmarks\ and\ History.Listqb qb' - exe 'silent! menu '.g:NetrwMenuPriority.'.9.1 '.g:NetrwTopLvlMenu.'Browsing\ Control.Edit\ File\ Hiding\ List'." \NetrwHideEdit" - exe 'silent! menu '.g:NetrwMenuPriority.'.9.2 '.g:NetrwTopLvlMenu.'Browsing\ Control.Edit\ Sorting\ SequenceS S' - exe 'silent! menu '.g:NetrwMenuPriority.'.9.3 '.g:NetrwTopLvlMenu.'Browsing\ Control.Quick\ Hide/Unhide\ Dot\ Files'."gh gh" - exe 'silent! menu '.g:NetrwMenuPriority.'.9.4 '.g:NetrwTopLvlMenu.'Browsing\ Control.Refresh\ Listing'." \NetrwRefresh" - exe 'silent! menu '.g:NetrwMenuPriority.'.9.5 '.g:NetrwTopLvlMenu.'Browsing\ Control.Settings/Options:NetrwSettings '.":NetrwSettings\" - exe 'silent! menu '.g:NetrwMenuPriority.'.10 '.g:NetrwTopLvlMenu.'Delete\ File/DirectoryD D' - exe 'silent! menu '.g:NetrwMenuPriority.'.11.1 '.g:NetrwTopLvlMenu.'Edit\ File/Dir.In\ Current\ Window '."\" - exe 'silent! menu '.g:NetrwMenuPriority.'.11.2 '.g:NetrwTopLvlMenu.'Edit\ File/Dir.Preview\ File/Directoryp p' - exe 'silent! menu '.g:NetrwMenuPriority.'.11.3 '.g:NetrwTopLvlMenu.'Edit\ File/Dir.In\ Previous\ WindowP P' - exe 'silent! menu '.g:NetrwMenuPriority.'.11.4 '.g:NetrwTopLvlMenu.'Edit\ File/Dir.In\ New\ Windowo o' - exe 'silent! menu '.g:NetrwMenuPriority.'.11.5 '.g:NetrwTopLvlMenu.'Edit\ File/Dir.In\ New\ Vertical\ Windowv v' - exe 'silent! menu '.g:NetrwMenuPriority.'.12.1 '.g:NetrwTopLvlMenu.'Explore.Directory\ Name :Explore ' - exe 'silent! menu '.g:NetrwMenuPriority.'.12.2 '.g:NetrwTopLvlMenu.'Explore.Filenames\ Matching\ Pattern\ (curdir\ only):Explore\ */ :Explore */' - exe 'silent! menu '.g:NetrwMenuPriority.'.12.2 '.g:NetrwTopLvlMenu.'Explore.Filenames\ Matching\ Pattern\ (+subdirs):Explore\ **/ :Explore **/' - exe 'silent! menu '.g:NetrwMenuPriority.'.12.3 '.g:NetrwTopLvlMenu.'Explore.Files\ Containing\ Pattern\ (curdir\ only):Explore\ *// :Explore *//' - exe 'silent! menu '.g:NetrwMenuPriority.'.12.4 '.g:NetrwTopLvlMenu.'Explore.Files\ Containing\ Pattern\ (+subdirs):Explore\ **// :Explore **//' - exe 'silent! menu '.g:NetrwMenuPriority.'.12.4 '.g:NetrwTopLvlMenu.'Explore.Next\ Match:Nexplore :Nexplore' - exe 'silent! menu '.g:NetrwMenuPriority.'.12.4 '.g:NetrwTopLvlMenu.'Explore.Prev\ Match:Pexplore :Pexplore' - exe 'silent! menu '.g:NetrwMenuPriority.'.13 '.g:NetrwTopLvlMenu.'Make\ Subdirectoryd d' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.1 '.g:NetrwTopLvlMenu.'Marked\ Files.Mark\ Filemf mf' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.2 '.g:NetrwTopLvlMenu.'Marked\ Files.Mark\ Files\ by\ Regexpmr mr' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.3 '.g:NetrwTopLvlMenu.'Marked\ Files.Hide-Show-List\ Controla a' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.4 '.g:NetrwTopLvlMenu.'Marked\ Files.Copy\ To\ Targetmc mc' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.5 '.g:NetrwTopLvlMenu.'Marked\ Files.DeleteD D' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.6 '.g:NetrwTopLvlMenu.'Marked\ Files.Diffmd md' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.7 '.g:NetrwTopLvlMenu.'Marked\ Files.Editme me' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.8 '.g:NetrwTopLvlMenu.'Marked\ Files.Exe\ Cmdmx mx' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.9 '.g:NetrwTopLvlMenu.'Marked\ Files.Move\ To\ Targetmm mm' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.10 '.g:NetrwTopLvlMenu.'Marked\ Files.ObtainO O' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.11 '.g:NetrwTopLvlMenu.'Marked\ Files.Printmp mp' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.12 '.g:NetrwTopLvlMenu.'Marked\ Files.ReplaceR R' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.13 '.g:NetrwTopLvlMenu.'Marked\ Files.Set\ Targetmt mt' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.14 '.g:NetrwTopLvlMenu.'Marked\ Files.TagmT mT' - exe 'silent! menu '.g:NetrwMenuPriority.'.14.15 '.g:NetrwTopLvlMenu.'Marked\ Files.Zip/Unzip/Compress/Uncompressmz mz' - exe 'silent! menu '.g:NetrwMenuPriority.'.15 '.g:NetrwTopLvlMenu.'Obtain\ FileO O' - exe 'silent! menu '.g:NetrwMenuPriority.'.16.1 '.g:NetrwTopLvlMenu.'Style.Listing\ Style\ (thin-long-wide-tree)i i' - exe 'silent! menu '.g:NetrwMenuPriority.'.16.2 '.g:NetrwTopLvlMenu.'Style.Normal-Hide-Showa a' - exe 'silent! menu '.g:NetrwMenuPriority.'.16.3 '.g:NetrwTopLvlMenu.'Style.Reverse\ Sorting\ Order'."r r" - exe 'silent! menu '.g:NetrwMenuPriority.'.16.4 '.g:NetrwTopLvlMenu.'Style.Sorting\ Method\ (name-time-size)s s' - exe 'silent! menu '.g:NetrwMenuPriority.'.17 '.g:NetrwTopLvlMenu.'Rename\ File/DirectoryR R' - exe 'silent! menu '.g:NetrwMenuPriority.'.18 '.g:NetrwTopLvlMenu.'Set\ Current\ Directoryc c' - let s:netrw_menucnt= 28 - - elseif !a:domenu - let s:netrwcnt = 0 - let curwin = winnr() - windo if getline(2) =~ "Netrw" | let s:netrwcnt= s:netrwcnt + 1 | endif - exe curwin."wincmd w" - - if s:netrwcnt <= 1 -" call Decho("clear menus") - exe 'silent! unmenu '.g:NetrwTopLvlMenu -" call Decho('exe silent! unmenu '.g:NetrwTopLvlMenu.'*') - silent! unlet s:netrw_menu_enabled - endif - endif -" call Dret("NetrwMenu") - endif - -endfun - -" --------------------------------------------------------------------- -" s:NetrwObtain: obtain file under cursor or from markfile list {{{2 -" Used by the O maps (as NetrwObtain()) -fun! s:NetrwObtain(islocal) -" call Dfunc("NetrwObtain(islocal=".a:islocal.")") - - if exists("s:netrwmarkfilelist_{bufnr('%')}") - let islocal= s:netrwmarkfilelist_{bufnr("%")}[1] !~ '^\a\+://' - call netrw#NetrwObtain(islocal,s:netrwmarkfilelist_{bufnr("%")}) - call s:NetrwUnmarkList(bufnr('%'),b:netrw_curdir) - else - call netrw#NetrwObtain(a:islocal,expand("")) - endif - -" call Dret("NetrwObtain") -endfun - -" --------------------------------------------------------------------- -" netrw#NetrwObtain: {{{2 -" netrw#NetrwObtain(islocal,fname[,tgtdirectory]) -" islocal=0 obtain from remote source -" =1 obtain from local source -" fname : a filename or a list of filenames -" tgtdir : optional place where files are to go (not present, uses getcwd()) -fun! netrw#NetrwObtain(islocal,fname,...) -" call Dfunc("netrw#NetrwObtain(islocal=".a:islocal." fname<".((type(a:fname) == 1)? a:fname : string(a:fname)).">) a:0=".a:0) - " NetrwStatusLine support - for obtaining support - - if type(a:fname) == 1 - let fnamelist= [ a:fname ] - elseif type(a:fname) == 3 - let fnamelist= a:fname - else - call netrw#ErrorMsg(s:ERROR,"attempting to use NetrwObtain on something not a filename or a list",62) -" call Dret("netrw#NetrwObtain") - return - endif -" call Decho("fnamelist<".string(fnamelist).">") - if a:0 > 0 - let tgtdir= a:1 - else - let tgtdir= getcwd() - endif -" call Decho("tgtdir<".tgtdir.">") - - if b:netrw_islocal - " obtain a file from local b:netrw_curdir to (local) tgtdir -" call Decho("obtain a file from local ".b:netrw_curdir." to ".tgtdir) - if exists("b:netrw_curdir") && getcwd() != b:netrw_curdir - let topath= s:ComposePath(tgtdir,"") - if (has("win32") || has("win95") || has("win64") || has("win16")) - " transfer files one at time -" call Decho("transfer files one at a time") - for fname in fnamelist -" call Decho("system(".g:netrw_localcopycmd." ".shellescape(fname)." ".shellescape(topath).")") - call system(g:netrw_localcopycmd." ".shellescape(fname)." ".shellescape(topath)) - endfor - else - " transfer files with one command -" call Decho("transfer files with one command") - let filelist= join(map(deepcopy(fnamelist),"shellescape(v:val)")) -" call Decho("system(".g:netrw_localcopycmd." ".filelist." ".shellescape(topath).")") - call system(g:netrw_localcopycmd." ".filelist." ".shellescape(topath)) - endif - elseif !exists("b:netrw_curdir") - call netrw#ErrorMsg(s:ERROR,"local browsing directory doesn't exist!",36) - else - call netrw#ErrorMsg(s:WARNING,"local browsing directory and current directory are identical",37) - endif - - else - " obtain files from remote b:netrw_curdir to local tgtdir -" call Decho("obtain a file from remote ".b:netrw_curdir." to ".tgtdir) - if type(a:fname) == 1 - call s:SetupNetrwStatusLine('%f %h%m%r%=%9*Obtaining '.a:fname) - endif - call s:NetrwMethod(b:netrw_curdir) - - if b:netrw_method == 4 - " obtain file using scp -" call Decho("obtain via scp (method#4)") - if exists("g:netrw_port") && g:netrw_port != "" - let useport= " ".g:netrw_scpport." ".g:netrw_port - else - let useport= "" - endif - if b:netrw_fname =~ '/' - let path= substitute(b:netrw_fname,'^\(.*/\).\{-}$','\1','') - else - let path= "" - endif - let filelist= join(map(deepcopy(fnamelist),'shellescape(g:netrw_machine.":".path.v:val,1)')) -" call Decho("exe ".s:netrw_silentxfer."!".g:netrw_scp_cmd.shellescape(useport,1)." ".filelist." ".shellescape(tgtdir,1)) - exe s:netrw_silentxfer."!".g:netrw_scp_cmd.shellescape(useport,1)." ".filelist." ".shellescape(tgtdir,1) - - elseif b:netrw_method == 2 - " obtain file using ftp + .netrc -" call Decho("obtain via ftp+.netrc (method #2)") - call s:SaveBufVars()|silent keepjumps new|call s:RestoreBufVars() - let tmpbufnr= bufnr("%") - setlocal ff=unix - if exists("g:netrw_ftpmode") && g:netrw_ftpmode != "" - put =g:netrw_ftpmode -" call Decho("filter input: ".getline('$')) - endif - - if exists("b:netrw_fname") && b:netrw_fname != "" - call setline(line("$")+1,'cd "'.b:netrw_fname.'"') -" call Decho("filter input: ".getline('$')) - endif - - if exists("g:netrw_ftpextracmd") - put =g:netrw_ftpextracmd -" call Decho("filter input: ".getline('$')) - endif - for fname in fnamelist - call setline(line("$")+1,'get "'.fname.'"') -" call Decho("filter input: ".getline('$')) - endfor - if exists("g:netrw_port") && g:netrw_port != "" -" call Decho("executing: %!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)." ".shellescape(g:netrw_port,1)) - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)." ".shellescape(g:netrw_port,1) - else -" call Decho("executing: %!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)) - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1) - endif - " If the result of the ftp operation isn't blank, show an error message (tnx to Doug Claar) - if getline(1) !~ "^$" && !exists("g:netrw_quiet") && getline(1) !~ '^Trying ' - let debugkeep= &debug - setlocal debug=msg - call netrw#ErrorMsg(s:ERROR,getline(1),4) - let &debug= debugkeep - endif - - elseif b:netrw_method == 3 - " obtain with ftp + machine, id, passwd, and fname (ie. no .netrc) -" call Decho("obtain via ftp+mipf (method #3)") - call s:SaveBufVars()|silent keepjumps new|call s:RestoreBufVars() - let tmpbufnr= bufnr("%") - setlocal ff=unix - - if exists("g:netrw_port") && g:netrw_port != "" - put ='open '.g:netrw_machine.' '.g:netrw_port -" call Decho("filter input: ".getline('$')) - else - put ='open '.g:netrw_machine -" call Decho("filter input: ".getline('$')) - endif - - if exists("g:netrw_ftp") && g:netrw_ftp == 1 - put =g:netrw_uid -" call Decho("filter input: ".getline('$')) - put ='\"'.s:netrw_passwd.'\"' -" call Decho("filter input: ".getline('$')) - else - put ='user \"'.g:netrw_uid.'\" \"'.s:netrw_passwd.'\"' -" call Decho("filter input: ".getline('$')) - endif - - if exists("g:netrw_ftpmode") && g:netrw_ftpmode != "" - put =g:netrw_ftpmode -" call Decho("filter input: ".getline('$')) - endif - - if exists("b:netrw_fname") && b:netrw_fname != "" - call setline(line("$")+1,'cd "'.b:netrw_fname.'"') -" call Decho("filter input: ".getline('$')) - endif - - if exists("g:netrw_ftpextracmd") - put =g:netrw_ftpextracmd -" call Decho("filter input: ".getline('$')) - endif - - if exists("g:netrw_ftpextracmd") - put =g:netrw_ftpextracmd -" call Decho("filter input: ".getline('$')) - endif - for fname in fnamelist - call setline(line("$")+1,'get "'.fname.'"') - endfor -" call Decho("filter input: ".getline('$')) - - " perform ftp: - " -i : turns off interactive prompting from ftp - " -n unix : DON'T use <.netrc>, even though it exists - " -n win32: quit being obnoxious about password - norm! 1Gdd -" call Decho("executing: %!".g:netrw_ftp_cmd." -i -n") - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i -n" - " If the result of the ftp operation isn't blank, show an error message (tnx to Doug Claar) - if getline(1) !~ "^$" -" call Decho("error<".getline(1).">") - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,getline(1),5) - endif - endif - endif - - endif - - " cleanup - if exists("tmpbufnr") - if bufnr("%") != tmpbufnr - exe tmpbufnr."bw!" - else - q! - endif - endif - -" call Dret("netrw#NetrwObtain") -endfun - -" --------------------------------------------------------------------- -" s:NetrwPrevWinOpen: open file/directory in previous window. {{{2 -" If there's only one window, then the window will first be split. -" Returns: -" choice = 0 : didn't have to choose -" choice = 1 : saved modified file in window first -" choice = 2 : didn't save modified file, opened window -" choice = 3 : cancel open -fun! s:NetrwPrevWinOpen(islocal) -" call Dfunc("NetrwPrevWinOpen(islocal=".a:islocal.")") - - " grab a copy of the b:netrw_curdir to pass it along to newly split windows - let curdir = b:netrw_curdir - - " get last window number and the word currently under the cursor - let lastwinnr = winnr("$") - let curword = s:NetrwGetWord() - let choice = 0 -" call Decho("lastwinnr=".lastwinnr." curword<".curword.">") - - let didsplit = 0 - if lastwinnr == 1 - " if only one window, open a new one first -" call Decho("only one window, so open a new one (g:netrw_alto=".g:netrw_alto.")") - if g:netrw_preview -" call Decho("exe ".(g:netrw_alto? "top " : "bot ")."vert ".g:netrw_winsize."wincmd s") - exe (g:netrw_alto? "top " : "bot ")."vert ".g:netrw_winsize."wincmd s" - else -" call Decho("exe ".(g:netrw_alto? "bel " : "abo ").g:netrw_winsize."wincmd s") - exe (g:netrw_alto? "bel " : "abo ").g:netrw_winsize."wincmd s" - endif - let didsplit = 1 - - else - call s:SaveBufVars() -" call Decho("wincmd p") - wincmd p - call s:RestoreBufVars() - " if the previous window's buffer has been changed (is modified), - " and it doesn't appear in any other extant window, then ask the - " user if s/he wants to abandon modifications therein. - let bnr = winbufnr(0) - let bnrcnt = 0 - if &mod -" call Decho("detected: prev window's buffer has been modified: bnr=".bnr." winnr#".winnr()) - let eikeep= &ei - set ei=all - windo if winbufnr(0) == bnr | let bnrcnt=bnrcnt+1 | endif - exe bnr."wincmd p" - let &ei= eikeep -" call Decho("bnr=".bnr." bnrcnt=".bnrcnt." buftype=".&bt." winnr#".winnr()) - if bnrcnt == 1 - let bufname= bufname(winbufnr(winnr())) - let choice= confirm("Save modified file<".bufname.">?","&Yes\n&No\n&Cancel") -" call Decho("bufname<".bufname."> choice=".choice." winnr#".winnr()) - - if choice == 1 - " Yes -- write file & then browse - let v:errmsg= "" - silent w - if v:errmsg != "" - call netrw#ErrorMsg(s:ERROR,"unable to write <".bufname.">!",30) - if didsplit - q - else - wincmd p - endif -" call Dret("NetrwPrevWinOpen ".choice." : unable to write <".bufname.">") - return choice - endif - - elseif choice == 2 - " No -- don't worry about changed file, just browse anyway - setlocal nomod - call netrw#ErrorMsg(s:WARNING,bufname." changes to ".bufname." abandoned",31) - wincmd p - - else - " Cancel -- don't do this - if didsplit - q - else - wincmd p - endif -" call Dret("NetrwPrevWinOpen ".choice." : cancelled") - return choice - endif - endif - endif - endif - - " restore b:netrw_curdir (window split/enew may have lost it) - let b:netrw_curdir= curdir - if a:islocal < 2 - if a:islocal - call netrw#LocalBrowseCheck(s:NetrwBrowseChgDir(a:islocal,curword)) - else - call s:NetrwBrowse(a:islocal,s:NetrwBrowseChgDir(a:islocal,curword)) - endif - endif -" call Dret("NetrwPrevWinOpen ".choice) - return choice -endfun - -" --------------------------------------------------------------------- -" s:NetrwUpload: load fname to tgt (used by NetrwMarkFileCopy()) {{{2 -" Always assumed to be local -> remote -" call s:NetrwUpload(filename, target) -" call s:NetrwUpload(filename, target, fromdirectory) -fun! s:NetrwUpload(fname,tgt,...) -" call Dfunc("s:NetrwUpload(fname<".((type(a:fname) == 1)? a:fname : string(a:fname))."> tgt<".a:tgt.">) a:0=".a:0) - - if a:tgt =~ '^\a\+://' - let tgtdir= substitute(a:tgt,'^\a\+://[^/]\+/\(.\{-}\)$','\1','') - else - let tgtdir= substitute(a:tgt,'^\(.*\)/[^/]*$','\1','') - endif -" call Decho("tgtdir<".tgtdir.">") - - if a:0 > 0 - let fromdir= a:1 - else - let fromdir= getcwd() - endif -" call Decho("fromdir<".fromdir.">") - - if type(a:fname) == 1 - " handle uploading a single file using NetWrite -" call Decho("handle uploading a single file via NetWrite") - 1split -" call Decho("exe e ".fnameescape(a:fname)) - exe "e ".fnameescape(a:fname) -" call Decho("now locally editing<".expand("%").">, has ".line("$")." lines") - if a:tgt =~ '/$' - let wfname= substitute(a:fname,'^.*/','','') -" call Decho("exe w! ".fnameescape(wfname)) - exe "w! ".fnameescape(a:tgt.wfname) - else -" call Decho("writing local->remote: exe w ".fnameescape(a:tgt)) - exe "w ".fnameescape(a:tgt) -" call Decho("done writing local->remote") - endif - q! - - elseif type(a:fname) == 3 - " handle uploading a list of files via scp -" call Decho("handle uploading a list of files via scp") - let curdir= getcwd() - if a:tgt =~ '^scp:' - exe "keepjumps silent lcd ".fnameescape(fromdir) - let filelist= deepcopy(s:netrwmarkfilelist_{bufnr('%')}) - let args = join(map(filelist,"shellescape(v:val, 1)")) - if exists("g:netrw_port") && g:netrw_port != "" - let useport= " ".g:netrw_scpport." ".g:netrw_port - else - let useport= "" - endif - let machine = substitute(a:tgt,'^scp://\([^/:]\+\).*$','\1','') - let tgt = substitute(a:tgt,'^scp://[^/]\+/\(.*\)$','\1','') -" call Decho("exe ".s:netrw_silentxfer."!".g:netrw_scp_cmd.shellescape(useport,1)." ".args." ".shellescape(machine.":".tgt,1)) - exe s:netrw_silentxfer."!".g:netrw_scp_cmd.shellescape(useport,1)." ".args." ".shellescape(machine.":".tgt,1) - exe "keepjumps silent lcd ".fnameescape(curdir) - - elseif a:tgt =~ '^ftp:' - call s:NetrwMethod(a:tgt) - - if b:netrw_method == 2 - " handle uploading a list of files via ftp+.netrc - let netrw_fname = b:netrw_fname - silent keepjumps new -" call Decho("filter input window#".winnr()) - - put =g:netrw_ftpmode -" call Decho("filter input: ".getline('$')) - - if exists("g:netrw_ftpextracmd") - put =g:netrw_ftpextracmd -" call Decho("filter input: ".getline('$')) - endif - - call setline(line("$")+1,'lcd "'.fromdir.'"') -" call Decho("filter input: ".getline('$')) - - call setline(line("$")+1,'cd "'.tgtdir.'"') -" call Decho("filter input: ".getline('$')) - - for fname in a:fname - call setline(line("$")+1,'put "'.fname.'"') -" call Decho("filter input: ".getline('$')) - endfor - - if exists("g:netrw_port") && g:netrw_port != "" -" call Decho("executing: ".s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)." ".shellescape(g:netrw_port,1)) - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)." ".shellescape(g:netrw_port,1) - else -" call Decho("filter input window#".winnr()) -" call Decho("executing: ".s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)) - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1) - endif - " If the result of the ftp operation isn't blank, show an error message (tnx to Doug Claar) - silent g/Local directory now/d - if getline(1) !~ "^$" && !exists("g:netrw_quiet") && getline(1) !~ '^Trying ' - call netrw#ErrorMsg(s:ERROR,getline(1),14) - else - bw!|q - endif - - elseif b:netrw_method == 3 - " upload with ftp + machine, id, passwd, and fname (ie. no .netrc) - let netrw_fname= b:netrw_fname - call s:SaveBufVars()|silent keepjumps new|call s:RestoreBufVars() - let tmpbufnr= bufnr("%") - setlocal ff=unix - - if exists("g:netrw_port") && g:netrw_port != "" - put ='open '.g:netrw_machine.' '.g:netrw_port -" call Decho("filter input: ".getline('$')) - else - put ='open '.g:netrw_machine -" call Decho("filter input: ".getline('$')) - endif - - if exists("g:netrw_ftp") && g:netrw_ftp == 1 - put =g:netrw_uid -" call Decho("filter input: ".getline('$')) - call setline(line("$")+1,'"'.s:netrw_passwd.'"') -" call Decho("filter input: ".getline('$')) - else - put ='user \"'.g:netrw_uid.'\" \"'.s:netrw_passwd.'\"' -" call Decho("filter input: ".getline('$')) - endif - - call setline(line("$")+1,'lcd "'.fromdir.'"') -" call Decho("filter input: ".getline('$')) - - if exists("b:netrw_fname") && b:netrw_fname != "" - call setline(line("$")+1,'cd "'.b:netrw_fname.'"') -" call Decho("filter input: ".getline('$')) - endif - - if exists("g:netrw_ftpextracmd") - put =g:netrw_ftpextracmd -" call Decho("filter input: ".getline('$')) - endif - - for fname in a:fname - call setline(line("$")+1,'put "'.fname.'"') -" call Decho("filter input: ".getline('$')) - endfor - - " perform ftp: - " -i : turns off interactive prompting from ftp - " -n unix : DON'T use <.netrc>, even though it exists - " -n win32: quit being obnoxious about password - norm! 1Gdd -" call Decho("executing: ".s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i -n") - exe s:netrw_silentxfer."%!".g:netrw_ftp_cmd." -i -n" - " If the result of the ftp operation isn't blank, show an error message (tnx to Doug Claar) - silent g/Local directory now/d - if getline(1) !~ "^$" && !exists("g:netrw_quiet") && getline(1) !~ '^Trying ' - let debugkeep= &debug - setlocal debug=msg - call netrw#ErrorMsg(s:ERROR,getline(1),15) - let &debug = debugkeep - let mod = 1 - else - bw!|q - endif - endif - else - call netrw#ErrorMsg(s:ERROR,"can't obtain files with protocol from<".a:tgt.">",63) - endif - endif - -" call Dret("s:NetrwUpload") -endfun - -" --------------------------------------------------------------------- -" s:NetrwPreview: {{{2 -fun! s:NetrwPreview(path) range -" call Dfunc("NetrwPreview(path<".a:path.">)") - call s:NetrwOptionSave("s:") - call s:NetrwSafeOptions() - if has("quickfix") - if !isdirectory(a:path) - exe (g:netrw_preview? "vert " : "")."pedit ".fnameescape(a:path) - elseif !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:WARNING,"sorry, cannot preview a directory such as <".a:path.">",38) - endif - elseif !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:WARNING,"sorry, to preview your vim needs the quickfix feature compiled in",39) - endif - call s:NetrwOptionRestore("s:") -" call Dret("NetrwPreview") -endfun - -" --------------------------------------------------------------------- -" s:NetrwRefresh: {{{2 -fun! s:NetrwRefresh(islocal,dirname) -" call Dfunc("NetrwRefresh(islocal<".a:islocal.">,dirname=".a:dirname.") hide=".g:netrw_hide." sortdir=".g:netrw_sort_direction) - " at the current time (Mar 19, 2007) all calls to NetrwRefresh() call NetrwBrowseChgDir() first. - " NetrwBrowseChgDir() may clear the display; hence a NetrwSavePosn() may not work if its placed here. - " Also, NetrwBrowseChgDir() now does a NetrwSavePosn() itself. - setlocal ma noro -" call Decho("setlocal ma noro") -" call Decho("clear buffer<".expand("%")."> with :%d") - %d - if a:islocal - call netrw#LocalBrowseCheck(a:dirname) - else - call s:NetrwBrowse(a:islocal,a:dirname) - endif - call netrw#NetrwRestorePosn() - - " restore file marks - if exists("s:netrwmarkfilemtch_{bufnr('%')}") && s:netrwmarkfilemtch_{bufnr("%")} != "" -" call Decho("exe 2match netrwMarkFile /".s:netrwmarkfilemtch_{bufnr("%")}."/") - exe "2match netrwMarkFile /".s:netrwmarkfilemtch_{bufnr("%")}."/" - else -" call Decho("2match none") - 2match none - endif - -" redraw! -" call Dret("NetrwRefresh") -endfun - -" --------------------------------------------------------------------- -" s:NetrwRefreshDir: refreshes a directory by name {{{2 -" Called by NetrwMarkFileCopy() -" Interfaces to s:NetrwRefresh() and s:LocalBrowseShellCmdRefresh() -fun! s:NetrwRefreshDir(islocal,dirname) -" call Dfunc("s:NetrwRefreshDir(islocal=".a:islocal." dirname<".a:dirname.">) fastbrowse=".g:netrw_fastbrowse) - if g:netrw_fastbrowse == 0 - " slowest mode (keep buffers refreshed, local or remote) -" call Decho("slowest mode: keep buffers refreshed, local or remote") - let tgtwin= bufwinnr(a:dirname) -" call Decho("tgtwin= bufwinnr(".a:dirname.")=".tgtwin) - - if tgtwin > 0 - " tgtwin is being displayed, so refresh it - let curwin= winnr() -" call Decho("refresh tgtwin#".tgtwin." (curwin#".curwin.")") - exe tgtwin."wincmd w" - call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - exe curwin."wincmd w" - - elseif bufnr(a:dirname) > 0 - let bn= bufnr(a:dirname) -" call Decho("bd bufnr(".a:dirname.")=".bn) - exe "silent bd ".bn - endif - - elseif g:netrw_fastbrowse <= 1 -" call Decho("medium-speed mode: refresh local buffers only") - call s:LocalBrowseShellCmdRefresh() - endif -" call Dret("s:NetrwRefreshDir") -endfun - -" --------------------------------------------------------------------- -" s:NetrwSetSort: sets up the sort based on the g:netrw_sort_sequence {{{2 -" What this function does is to compute a priority for the patterns -" in the g:netrw_sort_sequence. It applies a substitute to any -" "files" that satisfy each pattern, putting the priority / in -" front. An "*" pattern handles the default priority. -fun! s:NetrwSetSort() -" call Dfunc("SetSort() bannercnt=".w:netrw_bannercnt) - if w:netrw_liststyle == s:LONGLIST - let seqlist = substitute(g:netrw_sort_sequence,'\$','\\%(\t\\|\$\\)','ge') - else - let seqlist = g:netrw_sort_sequence - endif - " sanity check -- insure that * appears somewhere - if seqlist == "" - let seqlist= '*' - elseif seqlist !~ '\*' - let seqlist= seqlist.',*' - endif - let priority = 1 - while seqlist != "" - if seqlist =~ ',' - let seq = substitute(seqlist,',.*$','','e') - let seqlist = substitute(seqlist,'^.\{-},\(.*\)$','\1','e') - else - let seq = seqlist - let seqlist = "" - endif - let sepchr= "\" - if priority < 10 - let spriority= "00".priority.sepchr - elseif priority < 100 - let spriority= "0".priority.sepchr - else - let spriority= priority.sepchr - endif -" call Decho("priority=".priority." spriority<".spriority."> seq<".seq."> seqlist<".seqlist.">") - - " sanity check - if w:netrw_bannercnt > line("$") - " apparently no files were left after a Hiding pattern was used -" call Dret("SetSort : no files left after hiding") - return - endif - if seq == '*' - let starpriority= spriority - else - exe 'silent keepjumps '.w:netrw_bannercnt.',$g/'.seq.'/s/^/'.spriority.'/' - " sometimes multiple sorting patterns will match the same file or directory. - " The following substitute is intended to remove the excess matches. - exe 'silent keepjumps '.w:netrw_bannercnt.',$g/^\d\{3}'.sepchr.'\d\{3}\//s/^\d\{3}'.sepchr.'\(\d\{3}\/\).\@=/\1/e' - endif - let priority = priority + 1 - endwhile - if exists("starpriority") - exe 'silent keepjumps '.w:netrw_bannercnt.',$v/^\d\{3}'.sepchr.'/s/^/'.starpriority.'/' - endif - - " Following line associated with priority -- items that satisfy a priority - " pattern get prefixed by ###/ which permits easy sorting by priority. - " Sometimes files can satisfy multiple priority patterns -- only the latest - " priority pattern needs to be retained. So, at this point, these excess - " priority prefixes need to be removed, but not directories that happen to - " be just digits themselves. - exe 'silent keepjumps '.w:netrw_bannercnt.',$s/^\(\d\{3}'.sepchr.'\)\%(\d\{3}'.sepchr.'\)\+\ze./\1/e' - -" call Dret("SetSort") -endfun - -" ===================================================================== -" s:NetrwSortStyle: change sorting style (name - time - size) and refresh display {{{2 -fun! s:NetrwSortStyle(islocal) -" call Dfunc("s:NetrwSortStyle(islocal=".a:islocal.") netrw_sort_by<".g:netrw_sort_by.">") - call s:NetrwSaveWordPosn() - let svpos= netrw#NetrwSavePosn() - - let g:netrw_sort_by= (g:netrw_sort_by =~ 'n')? 'time' : (g:netrw_sort_by =~ 't')? 'size' : 'name' - norm! 0 - call s:NetrwRefresh(a:islocal,s:NetrwBrowseChgDir(a:islocal,'./')) - call netrw#NetrwRestorePosn(svpos) - -" call Dret("s:NetrwSortStyle : netrw_sort_by<".g:netrw_sort_by.">") -endfun - -" --------------------------------------------------------------------- -" s:NetrwSplit: mode {{{2 -" =0 : net and o -" =1 : net and t -" =2 : net and v -" =3 : local and o -" =4 : local and t -" =5 : local and v -fun! s:NetrwSplit(mode) -" call Dfunc("s:NetrwSplit(mode=".a:mode.") alto=".g:netrw_alto." altv=".g:netrw_altv) - - call s:SaveWinVars() - - if a:mode == 0 - " remote and o -" call Decho("exe ".(g:netrw_alto? "bel " : "abo ").g:netrw_winsize."wincmd s") - exe (g:netrw_alto? "bel " : "abo ").g:netrw_winsize."wincmd s" - let s:didsplit= 1 - call s:RestoreWinVars() - call s:NetrwBrowse(0,s:NetrwBrowseChgDir(0,s:NetrwGetWord())) - unlet s:didsplit - - elseif a:mode == 1 - " remote and t - let cursorword = s:NetrwGetWord() -" call Decho("tabnew") - tabnew - let s:didsplit= 1 - call s:RestoreWinVars() - call s:NetrwBrowse(0,s:NetrwBrowseChgDir(0,cursorword)) - unlet s:didsplit - - elseif a:mode == 2 - " remote and v -" call Decho("exe ".(g:netrw_altv? "rightb " : "lefta ").g:netrw_winsize."wincmd v") - exe (g:netrw_altv? "rightb " : "lefta ").g:netrw_winsize."wincmd v" - let s:didsplit= 1 - call s:RestoreWinVars() - call s:NetrwBrowse(0,s:NetrwBrowseChgDir(0,s:NetrwGetWord())) - unlet s:didsplit - - elseif a:mode == 3 - " local and o -" call Decho("exe ".(g:netrw_alto? "bel " : "abo ").g:netrw_winsize."wincmd s") - exe (g:netrw_alto? "bel " : "abo ").g:netrw_winsize."wincmd s" - let s:didsplit= 1 - call s:RestoreWinVars() - call netrw#LocalBrowseCheck(s:NetrwBrowseChgDir(1,s:NetrwGetWord())) - unlet s:didsplit - - elseif a:mode == 4 - " local and t - let netrw_curdir= b:netrw_curdir - let cursorword = s:NetrwGetWord() -" call Decho("tabnew") - tabnew - let b:netrw_curdir= netrw_curdir - let s:didsplit= 1 - call s:RestoreWinVars() - call netrw#LocalBrowseCheck(s:NetrwBrowseChgDir(1,cursorword)) - unlet s:didsplit - - elseif a:mode == 5 - " local and v -" call Decho("exe ".(g:netrw_altv? "rightb " : "lefta ").g:netrw_winsize."wincmd v") - exe (g:netrw_altv? "rightb " : "lefta ").g:netrw_winsize."wincmd v" - let s:didsplit= 1 - call s:RestoreWinVars() - call netrw#LocalBrowseCheck(s:NetrwBrowseChgDir(1,s:NetrwGetWord())) - unlet s:didsplit - - else - call netrw#ErrorMsg(s:ERROR,"(NetrwSplit) unsupported mode=".a:mode,45) - endif - -" call Dret("s:NetrwSplit") -endfun - -" --------------------------------------------------------------------- -" NetrwStatusLine: {{{2 -fun! NetrwStatusLine() - -" vvv NetrwStatusLine() debugging vvv -" let g:stlmsg="" -" if !exists("w:netrw_explore_bufnr") -" let g:stlmsg="!X" -" elseif w:netrw_explore_bufnr != bufnr("%") -" let g:stlmsg="explore_bufnr!=".bufnr("%") -" endif -" if !exists("w:netrw_explore_line") -" let g:stlmsg=" !X" -" elseif w:netrw_explore_line != line(".") -" let g:stlmsg=" explore_line!={line(.)<".line(".").">" -" endif -" if !exists("w:netrw_explore_list") -" let g:stlmsg=" !X" -" endif -" ^^^ NetrwStatusLine() debugging ^^^ - - if !exists("w:netrw_explore_bufnr") || w:netrw_explore_bufnr != bufnr("%") || !exists("w:netrw_explore_line") || w:netrw_explore_line != line(".") || !exists("w:netrw_explore_list") - " restore user's status line - let &stl = s:netrw_users_stl - let &laststatus = s:netrw_users_ls - if exists("w:netrw_explore_bufnr")|unlet w:netrw_explore_bufnr|endif - if exists("w:netrw_explore_line") |unlet w:netrw_explore_line |endif - return "" - else - return "Match ".w:netrw_explore_mtchcnt." of ".w:netrw_explore_listlen - endif -endfun - -" --------------------------------------------------------------------- -" s:NetrwTreeDir: determine tree directory given current cursor position {{{2 -" (full path directory with trailing slash returned) -fun! s:NetrwTreeDir() -" call Dfunc("NetrwTreeDir() curline#".line(".")."<".getline('.')."> b:netrw_curdir<".b:netrw_curdir."> tab#".tabpagenr()." win#".winnr()." buf#".bufnr("%")."<".bufname("%").">") - - let treedir= b:netrw_curdir -" call Decho("set initial treedir<".treedir.">") - let s:treecurpos= netrw#NetrwSavePosn() - - if w:netrw_liststyle == s:TREELIST -" call Decho("w:netrrw_liststyle is TREELIST:") -" call Decho("line#".line(".")." getline(.)<".getline('.')."> treecurpos<".string(s:treecurpos).">") - if getline('.') =~ '/$' - let treedir= substitute(getline('.'),'^\%(| \)*\([^|].\{-}\)$','\1','e') - else - let treedir= "" - endif - -" call Decho("treedir<".treedir.">") - - " detect user attempting to close treeroot - if getline('.') !~ '|' && getline('.') != '..' -" call Decho("user attempted to close treeroot") - " now force a refresh -" call Decho("clear buffer<".expand("%")."> with :%d") - keepjumps %d -" call Dret("NetrwTreeDir <".treedir."> : (side effect) s:treecurpos<".string(s:treecurpos).">") - return b:netrw_curdir - endif - - " elide all non-depth information - let depth = substitute(getline('.'),'^\(\%(| \)*\)[^|].\{-}$','\1','e') -" call Decho("depth<".depth."> 1st subst") - - " elide first depth - let depth = substitute(depth,'^| ','','') -" call Decho("depth<".depth."> 2nd subst") - - " construct treedir by searching backwards at correct depth -" call Decho("constructing treedir<".treedir."> depth<".depth.">") - while depth != "" && search('^'.depth.'[^|].\{-}/$','bW') - let dirname= substitute(getline('.'),'^\(| \)*','','e') - let treedir= dirname.treedir - let depth = substitute(depth,'^| ','','') -" call Decho("constructing treedir<".treedir.">: dirname<".dirname."> while depth<".depth.">") - endwhile - if w:netrw_treetop =~ '/$' - let treedir= w:netrw_treetop.treedir - else - let treedir= w:netrw_treetop.'/'.treedir - endif -" call Decho("bufnr(.)=".bufnr("%")." line($)=".line("$")." line(.)=".line(".")) - endif - let treedir= substitute(treedir,'//$','/','') - -" " now force a refresh -"" call DECHO("clear buffer<".expand("%")."> with :%d") -" setlocal ma noro -" keepjumps %d - -" call Dret("NetrwTreeDir <".treedir."> : (side effect) s:treecurpos<".string(s:treecurpos).">") - return treedir -endfun - -" --------------------------------------------------------------------- -" s:NetrwTreeDisplay: recursive tree display {{{2 -fun! s:NetrwTreeDisplay(dir,depth) -" call Dfunc("NetrwTreeDisplay(dir<".a:dir."> depth<".a:depth.">)") - - " insure that there are no folds - setlocal nofen - - " install ../ and shortdir - if a:depth == "" - call setline(line("$")+1,'../') -" call Decho("setline#".line("$")." ../ (depth is zero)") - endif - if a:dir =~ '^\a\+://' - if a:dir == w:netrw_treetop - let shortdir= a:dir - else - let shortdir= substitute(a:dir,'^.*/\([^/]\+\)/$','\1/','e') - endif - call setline(line("$")+1,a:depth.shortdir) - else - let shortdir= substitute(a:dir,'^.*/','','e') - call setline(line("$")+1,a:depth.shortdir.'/') - endif -" call Decho("setline#".line("$")." shortdir<".a:depth.shortdir.">") - - " append a / to dir if its missing one - let dir= a:dir - if dir !~ '/$' - let dir= dir.'/' - endif - - " display subtrees (if any) - let depth= "| ".a:depth - -" call Decho("display subtrees with depth<".depth."> and current leaves") - for entry in w:netrw_treedict[a:dir] - let direntry= substitute(dir.entry,'/$','','e') -" call Decho("dir<".dir."> entry<".entry."> direntry<".direntry.">") - if entry =~ '/$' && has_key(w:netrw_treedict,direntry) -" call Decho("<".direntry."> is a key in treedict - display subtree for it") - call s:NetrwTreeDisplay(direntry,depth) - elseif entry =~ '/$' && has_key(w:netrw_treedict,direntry.'/') -" call Decho("<".direntry."/> is a key in treedict - display subtree for it") - call s:NetrwTreeDisplay(direntry.'/',depth) - else -" call Decho("<".entry."> is not a key in treedict (no subtree)") - call setline(line("$")+1,depth.entry) - endif - endfor -" call Dret("NetrwTreeDisplay") -endfun - -" --------------------------------------------------------------------- -" s:NetrwTreeListing: displays tree listing from treetop on down, using NetrwTreeDisplay() {{{2 -fun! s:NetrwTreeListing(dirname) - if w:netrw_liststyle == s:TREELIST -" call Dfunc("NetrwTreeListing() bufname<".expand("%").">") -" call Decho("curdir<".a:dirname.">") -" call Decho("win#".winnr().": w:netrw_treetop ".(exists("w:netrw_treetop")? "exists" : "doesn't exit")." w:netrw_treedict ".(exists("w:netrw_treedict")? "exists" : "doesn't exit")) - - " update the treetop -" call Decho("update the treetop") - if !exists("w:netrw_treetop") - let w:netrw_treetop= a:dirname -" call Decho("w:netrw_treetop<".w:netrw_treetop."> (reusing)") - elseif (w:netrw_treetop =~ ('^'.a:dirname) && s:Strlen(a:dirname) < s:Strlen(w:netrw_treetop)) || a:dirname !~ ('^'.w:netrw_treetop) - let w:netrw_treetop= a:dirname -" call Decho("w:netrw_treetop<".w:netrw_treetop."> (went up)") - endif - - " insure that we have at least an empty treedict - if !exists("w:netrw_treedict") - let w:netrw_treedict= {} - endif - - " update the directory listing for the current directory -" call Decho("updating dictionary with ".a:dirname.":[..directory listing..]") -" call Decho("bannercnt=".w:netrw_bannercnt." line($)=".line("$")) - exe "silent! keepjumps ".w:netrw_bannercnt.',$g@^\.\.\=/$@d' - let w:netrw_treedict[a:dirname]= getline(w:netrw_bannercnt,line("$")) -" call Decho("w:treedict[".a:dirname."]= ".w:netrw_treedict[a:dirname]) - exe "silent! keepjumps ".w:netrw_bannercnt.",$d" - - " if past banner, record word - if exists("w:netrw_bannercnt") && line(".") > w:netrw_bannercnt - let fname= expand("") - else - let fname= "" - endif -" call Decho("fname<".fname.">") - - " display from treetop on down - call s:NetrwTreeDisplay(w:netrw_treetop,"") - -" call Dret("NetrwTreeListing : bufname<".expand("%").">") - endif -endfun - -" --------------------------------------------------------------------- -" s:NetrwWideListing: {{{2 -fun! s:NetrwWideListing() - - if w:netrw_liststyle == s:WIDELIST -" call Dfunc("NetrwWideListing() w:netrw_liststyle=".w:netrw_liststyle.' fo='.&fo.' l:fo='.&l:fo) - " look for longest filename (cpf=characters per filename) - " cpf: characters per file - " fpl: files per line - " fpc: files per column - setlocal ma noro -" call Decho("setlocal ma noro") - let b:netrw_cpf= 0 - if line("$") >= w:netrw_bannercnt - exe 'silent keepjumps '.w:netrw_bannercnt.',$g/^./if virtcol("$") > b:netrw_cpf|let b:netrw_cpf= virtcol("$")|endif' - else -" call Dret("NetrwWideListing") - return - endif -" call Decho("max file strlen+1=".b:netrw_cpf) - let b:netrw_cpf= b:netrw_cpf + 1 - - " determine qty files per line (fpl) - let w:netrw_fpl= winwidth(0)/b:netrw_cpf - if w:netrw_fpl <= 0 - let w:netrw_fpl= 1 - endif -" call Decho("fpl= ".winwidth(0)."/[b:netrw_cpf=".b:netrw_cpf.']='.w:netrw_fpl) - - " make wide display - exe 'silent keepjumps '.w:netrw_bannercnt.',$s/^.*$/\=escape(printf("%-'.b:netrw_cpf.'s",submatch(0)),"\\")/' - let fpc = (line("$") - w:netrw_bannercnt + w:netrw_fpl)/w:netrw_fpl - let newcolstart = w:netrw_bannercnt + fpc - let newcolend = newcolstart + fpc - 1 -" call Decho("bannercnt=".w:netrw_bannercnt." fpl=".w:netrw_fpl." fpc=".fpc." newcol[".newcolstart.",".newcolend."]") - silent! let keepregstar = @* - while line("$") >= newcolstart - if newcolend > line("$") | let newcolend= line("$") | endif - let newcolqty= newcolend - newcolstart - exe newcolstart - if newcolqty == 0 - exe "silent keepjumps norm! 0\$hx".w:netrw_bannercnt."G$p" - else - exe "silent keepjumps norm! 0\".newcolqty.'j$hx'.w:netrw_bannercnt.'G$p' - endif - exe "silent keepjumps ".newcolstart.','.newcolend.'d' - exe 'silent keepjumps '.w:netrw_bannercnt - endwhile - silent! let @*= keepregstar - exe "silent keepjumps ".w:netrw_bannercnt.',$s/\s\+$//e' - setlocal noma nomod ro -" call Dret("NetrwWideListing") - endif - -endfun - -" --------------------------------------------------------------------- -" s:PerformListing: {{{2 -fun! s:PerformListing(islocal) -" call Dfunc("s:PerformListing(islocal=".a:islocal.") buf(%)=".bufnr("%")."<".bufname("%").">") - - call s:NetrwSafeOptions() - setlocal noro ma -" call Decho("setlocal noro ma") - -" if exists("g:netrw_silent") && g:netrw_silent == 0 && &ch >= 1 " Decho -" call Decho("(netrw) Processing your browsing request...") -" endif " Decho - -" call Decho('w:netrw_liststyle='.(exists("w:netrw_liststyle")? w:netrw_liststyle : 'n/a')) - if exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST && exists("w:netrw_treedict") - " force a refresh for tree listings -" call Decho("force refresh for treelisting: clear buffer<".expand("%")."> with :%d") - keepjumps %d - endif - - " save current directory on directory history list - call s:NetrwBookmarkDir(3,b:netrw_curdir) - - " Set up the banner {{{3 -" call Decho("set up banner") - keepjumps put ='\" ============================================================================' - keepjumps put ='\" Netrw Directory Listing (netrw '.g:loaded_netrw.')' - keepjumps put ='\" '.b:netrw_curdir - keepjumps 1d - let w:netrw_bannercnt= 3 - exe "keepjumps ".w:netrw_bannercnt - - let sortby= g:netrw_sort_by - if g:netrw_sort_direction =~ "^r" - let sortby= sortby." reversed" - endif - - " Sorted by... {{{3 -" call Decho("handle specified sorting: g:netrw_sort_by<".g:netrw_sort_by.">") - if g:netrw_sort_by =~ "^n" -" call Decho("directories will be sorted by name") - " sorted by name - keepjumps put ='\" Sorted by '.sortby - keepjumps put ='\" Sort sequence: '.g:netrw_sort_sequence - let w:netrw_bannercnt= w:netrw_bannercnt + 2 - else -" call Decho("directories will be sorted by size or time") - " sorted by size or date - keepjumps put ='\" Sorted by '.sortby - let w:netrw_bannercnt= w:netrw_bannercnt + 1 - endif - exe "keepjumps ".w:netrw_bannercnt - - " show copy/move target, if any - if exists("s:netrwmftgt") && exists("s:netrwmftgt_islocal") -" call Decho("show copy/move target<".s:netrwmftgt.">") - keepjumps put ='' - if s:netrwmftgt_islocal - call setline(line("."),'" Copy/Move Tgt: '.s:netrwmftgt.' (local)') - else - call setline(line("."),'" Copy/Move Tgt: '.s:netrwmftgt.' (remote)') - endif - let w:netrw_bannercnt= w:netrw_bannercnt + 1 - else -" call Decho("s:netrwmftgt does not exist, don't make Copy/Move Tgt") - endif - exe "keepjumps ".w:netrw_bannercnt - - " Hiding... -or- Showing... {{{3 -" call Decho("handle hiding/showing (g:netrw_hide=".g:netrw_list_hide." g:netrw_list_hide<".g:netrw_list_hide.">)") - if g:netrw_list_hide != "" && g:netrw_hide - if g:netrw_hide == 1 - keepjumps put ='\" Hiding: '.g:netrw_list_hide - else - keepjumps put ='\" Showing: '.g:netrw_list_hide - endif - let w:netrw_bannercnt= w:netrw_bannercnt + 1 - endif - exe "keepjumps ".w:netrw_bannercnt - keepjumps put ='\" Quick Help: :help -:go up dir D:delete R:rename s:sort-by x:exec' - keepjumps put ='\" ============================================================================' - let w:netrw_bannercnt= w:netrw_bannercnt + 2 - - " bannercnt should index the line just after the banner - let w:netrw_bannercnt= w:netrw_bannercnt + 1 - exe "keepjumps ".w:netrw_bannercnt -" call Decho("bannercnt=".w:netrw_bannercnt." (should index line just after banner) line($)=".line("$")) - - " set up syntax highlighting {{{3 -" call Decho("set up syntax highlighting") - if has("syntax") - setlocal ft=netrw - if !exists("g:syntax_on") || !g:syntax_on - setlocal ft= - endif - endif - - " get list of files -" call Decho("Get list of files - islocal=".a:islocal) - if a:islocal - call s:LocalListing() - else " remote - call s:NetrwRemoteListing() - endif -" call Decho("w:netrw_bannercnt=".w:netrw_bannercnt." (banner complete)") - - " manipulate the directory listing (hide, sort) {{{3 - if line("$") >= w:netrw_bannercnt -" call Decho("manipulate directory listing (hide)") -" call Decho("g:netrw_hide=".g:netrw_hide." g:netrw_list_hide<".g:netrw_list_hide.">") - if g:netrw_hide && g:netrw_list_hide != "" - call s:NetrwListHide() - endif - if line("$") >= w:netrw_bannercnt -" call Decho("manipulate directory listing (sort) : g:netrw_sort_by<".g:netrw_sort_by.">") - - if g:netrw_sort_by =~ "^n" - " sort by name - call s:NetrwSetSort() - - if w:netrw_bannercnt < line("$") -" call Decho("g:netrw_sort_direction=".g:netrw_sort_direction." (bannercnt=".w:netrw_bannercnt.")") - if g:netrw_sort_direction =~ 'n' - " normal direction sorting - exe 'silent keepjumps '.w:netrw_bannercnt.',$sort'.' '.g:netrw_sort_options - else - " reverse direction sorting - exe 'silent keepjumps '.w:netrw_bannercnt.',$sort!'.' '.g:netrw_sort_options - endif - endif - " remove priority pattern prefix -" call Decho("remove priority pattern prefix") - let sepchr= "\" - exe 'silent keepjumps '.w:netrw_bannercnt.',$s/^\d\{3}'.sepchr.'//e' - - elseif a:islocal - if w:netrw_bannercnt < line("$") -" call Decho("g:netrw_sort_direction=".g:netrw_sort_direction) - if g:netrw_sort_direction =~ 'n' -" call Decho('exe silent keepjumps '.w:netrw_bannercnt.',$sort') - exe 'silent keepjumps '.w:netrw_bannercnt.',$sort'.' '.g:netrw_sort_options - else -" call Decho('exe silent keepjumps '.w:netrw_bannercnt.',$sort!') - exe 'silent keepjumps '.w:netrw_bannercnt.',$sort!'.' '.g:netrw_sort_options - endif - endif - exe 'silent keepjumps '.w:netrw_bannercnt.',$s/^\d\{-}\///e' - endif - - elseif g:netrw_sort_direction =~ 'r' -" call Decho('reverse the sorted listing') - exe 'silent keepjumps '.w:netrw_bannercnt.'g/^/m '.w:netrw_bannercnt - endif - endif - - " convert to wide/tree listing {{{3 -" call Decho("modify display if wide/tree listing style") - call s:NetrwWideListing() - call s:NetrwTreeListing(b:netrw_curdir) - - if exists("w:netrw_bannercnt") && line("$") > w:netrw_bannercnt - " place cursor on the top-left corner of the file listing -" call Decho("place cursor on top-left corner of file listing") - exe 'silent keepjumps '.w:netrw_bannercnt - norm! 0 - endif - - " record previous current directory - let w:netrw_prvdir= b:netrw_curdir -" call Decho("record netrw_prvdir<".w:netrw_prvdir.">") - - " save certain window-oriented variables into buffer-oriented variables {{{3 - call s:SetBufWinVars() - call s:NetrwOptionRestore("w:") - - " set display to netrw display settings -" call Decho("set display to netrw display settings (noma nomod etc)") - setlocal noma nomod nonu nobl nowrap ro - if exists("s:treecurpos") - - call netrw#NetrwRestorePosn(s:treecurpos) - unlet s:treecurpos - endif - -" call Dret("s:PerformListing : curpos<".string(getpos(".")).">") -endfun - -" --------------------------------------------------------------------- -" s:SetupNetrwStatusLine: {{{2 -fun! s:SetupNetrwStatusLine(statline) -" call Dfunc("SetupNetrwStatusLine(statline<".a:statline.">)") - - if !exists("s:netrw_setup_statline") - let s:netrw_setup_statline= 1 -" call Decho("do first-time status line setup") - - if !exists("s:netrw_users_stl") - let s:netrw_users_stl= &stl - endif - if !exists("s:netrw_users_ls") - let s:netrw_users_ls= &laststatus - endif - - " set up User9 highlighting as needed - let keepa= @a - redir @a - try - hi User9 - catch /^Vim\%((\a\+)\)\=:E411/ - if &bg == "dark" - hi User9 ctermfg=yellow ctermbg=blue guifg=yellow guibg=blue - else - hi User9 ctermbg=yellow ctermfg=blue guibg=yellow guifg=blue - endif - endtry - redir END - let @a= keepa - endif - - " set up status line (may use User9 highlighting) - " insure that windows have a statusline - " make sure statusline is displayed - let &stl=a:statline - setlocal laststatus=2 -" call Decho("stl=".&stl) - redraw - -" call Dret("SetupNetrwStatusLine : stl=".&stl) -endfun - -" --------------------------------------------------------------------- -" Remote Directory Browsing Support: {{{1 -" =========================================== - -" --------------------------------------------------------------------- -" s:NetrwRemoteListing: {{{2 -fun! s:NetrwRemoteListing() -" call Dfunc("s:NetrwRemoteListing() b:netrw_curdir<".b:netrw_curdir.">)") - - call s:RemotePathAnalysis(b:netrw_curdir) - - " sanity check: - if exists("b:netrw_method") && b:netrw_method =~ '[235]' -" call Decho("b:netrw_method=".b:netrw_method) - if !executable("ftp") - if !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"this system doesn't support remote directory listing via ftp",18) - endif - call s:NetrwOptionRestore("w:") -" call Dret("s:NetrwRemoteListing") - return - endif - - elseif !exists("g:netrw_list_cmd") || g:netrw_list_cmd == '' - if !exists("g:netrw_quiet") - if g:netrw_list_cmd == "" - call netrw#ErrorMsg(s:ERROR,g:netrw_ssh_cmd." is not executable on your system",47) - else - call netrw#ErrorMsg(s:ERROR,"this system doesn't support remote directory listing via ".g:netrw_list_cmd,19) - endif - endif - - call s:NetrwOptionRestore("w:") -" call Dret("s:NetrwRemoteListing") - return - endif " (remote handling sanity check) - - if exists("b:netrw_method") -" call Decho("setting w:netrw_method<".b:netrw_method.">") - let w:netrw_method= b:netrw_method - endif - - if s:method == "ftp" - " use ftp to get remote file listing -" call Decho("use ftp to get remote file listing") - let s:method = "ftp" - let listcmd = g:netrw_ftp_list_cmd - if g:netrw_sort_by =~ '^t' - let listcmd= g:netrw_ftp_timelist_cmd - elseif g:netrw_sort_by =~ '^s' - let listcmd= g:netrw_ftp_sizelist_cmd - endif -" call Decho("listcmd<".listcmd."> (using g:netrw_ftp_list_cmd)") - call s:NetrwRemoteFtpCmd(s:path,listcmd) -" exe "keepjumps ".w:netrw_bannercnt.',$g/^./call Decho("raw listing: ".getline("."))' - - if w:netrw_liststyle == s:THINLIST || w:netrw_liststyle == s:WIDELIST || w:netrw_liststyle == s:TREELIST - " shorten the listing -" call Decho("generate short listing") - exe "keepjumps ".w:netrw_bannercnt - - " cleanup - if g:netrw_ftp_browse_reject != "" - exe "silent! g/".g:netrw_ftp_browse_reject."/keepjumps d" - endif - silent! keepjumps %s/\r$//e - - " if there's no ../ listed, then put ./ and ../ in - let line1= line(".") - exe "keepjumps ".w:netrw_bannercnt - let line2= search('^\.\.\/\%(\s\|$\)','cnW') - if line2 == 0 -" call Decho("netrw is putting ./ and ../ into listing") - keepjumps put='../' - keepjumps put='./' - endif - exe "keepjumps ".line1 - keepjumps norm! 0 - -" call Decho("line1=".line1." line2=".line2." line(.)=".line(".")) - if search('^\d\{2}-\d\{2}-\d\{2}\s','n') " M$ ftp site cleanup -" call Decho("M$ ftp cleanup") - exe 'silent! keepjumps '.w:netrw_bannercnt.',$s/^\d\{2}-\d\{2}-\d\{2}\s\+\d\+:\d\+[AaPp][Mm]\s\+\%(\|\d\+\)\s\+//' - else " normal ftp cleanup -" call Decho("normal ftp cleanup") - exe 'silent! keepjumps '.w:netrw_bannercnt.',$s/^\(\%(\S\+\s\+\)\{7}\S\+\)\s\+\(\S.*\)$/\2/e' - exe "silent! keepjumps ".w:netrw_bannercnt.',$g/ -> /s# -> .*/$#/#e' - exe "silent! keepjumps ".w:netrw_bannercnt.',$g/ -> /s# -> .*$#/#e' - endif - endif - - else - " use ssh to get remote file listing {{{3 -" call Decho("use ssh to get remote file listing: s:path<".s:path.">") - let listcmd= s:MakeSshCmd(g:netrw_list_cmd) -" call Decho("listcmd<".listcmd."> (using g:netrw_list_cmd)") - if g:netrw_scp_cmd =~ '^pscp' -" call Decho("1: exe silent r! ".shellescape(listcmd.s:path, 1)) - exe "silent r! ".listcmd.shellescape(s:path, 1) - " remove rubbish and adjust listing format of 'pscp' to 'ssh ls -FLa' like - g/^Listing directory/d - g/^d[-rwx][-rwx][-rwx]/s+$+/+e - silent g/^l[-rwx][-rwx][-rwx]/s+$+@+e - if g:netrw_liststyle != s:LONGLIST - g/^[dlsp-][-rwx][-rwx][-rwx]/s/^.*\s\(\S\+\)$/\1/e - endif - else - if s:path == "" -" call Decho("2: exe silent r! ".listcmd) - exe "silent r! ".listcmd - else -" call Decho("3: exe silent r! ".listcmd.' '.shellescape(s:path,1)) - exe "silent r! ".listcmd.' '.shellescape(s:path,1) -" call Decho("listcmd<".listcmd."> path<".s:path.">") - endif - endif - - " cleanup - if g:netrw_ftp_browse_reject != "" -" call Decho("(cleanup) exe silent! g/".g:netrw_ssh_browse_reject."/keepjumps d") - exe "silent! g/".g:netrw_ssh_browse_reject."/keepjumps d" - endif - endif - - if w:netrw_liststyle == s:LONGLIST - " do a long listing; these substitutions need to be done prior to sorting {{{3 -" call Decho("fix long listing:") - - if s:method == "ftp" - " cleanup - exe "keepjumps ".w:netrw_bannercnt - while getline('.') =~ g:netrw_ftp_browse_reject - keepjumps d - endwhile - " if there's no ../ listed, then put ./ and ../ in - let line1= line(".") - keepjumps 1 - silent keepjumps call search('^\.\.\/\%(\s\|$\)','W') - let line2= line(".") - if line2 == 0 - exe 'keepjumps '.w:netrw_bannercnt."put='./'" - if b:netrw_curdir != '/' - exe 'keepjumps '.w:netrw_bannercnt."put='../'" - endif - endif - exe "keepjumps ".line1 - keepjumps norm! 0 - endif - - if search('^\d\{2}-\d\{2}-\d\{2}\s','n') " M$ ftp site cleanup -" call Decho("M$ ftp site listing cleanup") - exe 'silent! keepjumps '.w:netrw_bannercnt.',$s/^\(\d\{2}-\d\{2}-\d\{2}\s\+\d\+:\d\+[AaPp][Mm]\s\+\%(\|\d\+\)\s\+\)\(\w.*\)$/\2\t\1/' - elseif exists("w:netrw_bannercnt") && w:netrw_bannercnt <= line("$") -" call Decho("normal ftp site listing cleanup: bannercnt=".w:netrw_bannercnt." line($)=".line("$")) - exe 'silent keepjumps '.w:netrw_bannercnt.',$s/ -> .*$//e' - exe 'silent keepjumps '.w:netrw_bannercnt.',$s/^\(\%(\S\+\s\+\)\{7}\S\+\)\s\+\(\S.*\)$/\2\t\1/e' - exe 'silent keepjumps '.w:netrw_bannercnt - endif - endif - -" if exists("w:netrw_bannercnt") && w:netrw_bannercnt <= line("$") " Decho -" exe "keepjumps ".w:netrw_bannercnt.',$g/^./call Decho("listing: ".getline("."))' -" endif " Decho -" call Dret("s:NetrwRemoteListing") -endfun - -" --------------------------------------------------------------------- -" s:NetrwRemoteRm: remove/delete a remote file or directory {{{2 -fun! s:NetrwRemoteRm(usrhost,path) range -" call Dfunc("s:NetrwRemoteRm(usrhost<".a:usrhost."> path<".a:path.">) virtcol=".virtcol(".")) -" call Decho("firstline=".a:firstline." lastline=".a:lastline) - let svpos= netrw#NetrwSavePosn() - - let all= 0 - if exists("s:netrwmarkfilelist_{bufnr('%')}") - " remove all marked files - for fname in s:netrwmarkfilelist_{bufnr("%")} - let ok= s:NetrwRemoteRmFile(a:path,fname,all) - if ok =~ 'q\%[uit]' - break - elseif ok =~ 'a\%[ll]' - let all= 1 - endif - endfor - unlet s:netrwmarkfilelist_{bufnr("%")} - unlet s:netrwmarkfilemtch_{bufnr("%")} - 2match none - - else - " remove files specified by range - - " preparation for removing multiple files/directories - let ctr= a:firstline - - " remove multiple files and directories - while ctr <= a:lastline - exe ctr - let ok= s:NetrwRemoteRmFile(a:path,s:NetrwGetWord(),all) - if ok =~ 'q\%[uit]' - break - elseif ok =~ 'a\%[ll]' - let all= 1 - endif - let ctr= ctr + 1 - endwhile - endif - - " refresh the (remote) directory listing -" call Decho("refresh remote directory listing") - call s:NetrwRefresh(0,s:NetrwBrowseChgDir(0,'./')) - call netrw#NetrwRestorePosn(svpos) - -" call Dret("s:NetrwRemoteRm") -endfun - -" --------------------------------------------------------------------- -" s:NetrwRemoteRmFile: {{{2 -fun! s:NetrwRemoteRmFile(path,rmfile,all) -" call Dfunc("s:NetrwRemoteRmFile(path<".a:path."> rmfile<".a:rmfile.">) all=".a:all) - - let all= a:all - let ok = "" - - if a:rmfile !~ '^"' && (a:rmfile =~ '@$' || a:rmfile !~ '[\/]$') - " attempt to remove file -" call Decho("attempt to remove file (all=".all.")") - if !all - echohl Statement -" call Decho("case all=0:") - call inputsave() - let ok= input("Confirm deletion of file<".a:rmfile."> ","[{y(es)},n(o),a(ll),q(uit)] ") - call inputrestore() - echohl NONE - if ok == "" - let ok="no" - endif - let ok= substitute(ok,'\[{y(es)},n(o),a(ll),q(uit)]\s*','','e') - if ok =~ 'a\%[ll]' - let all= 1 - endif - endif - - if all || ok =~ 'y\%[es]' || ok == "" -" call Decho("case all=".all." or ok<".ok.">".(exists("w:netrw_method")? ': netrw_method='.w:netrw_method : "")) - if exists("w:netrw_method") && (w:netrw_method == 2 || w:netrw_method == 3) -" call Decho("case ftp:") - let path= a:path - if path =~ '^\a\+://' - let path= substitute(path,'^\a\+://[^/]\+/','','') - endif - silent! keepjumps .,$d - call s:NetrwRemoteFtpCmd(path,"delete ".'"'.a:rmfile.'"') - else -" call Decho("case ssh: g:netrw_rm_cmd<".g:netrw_rm_cmd.">") - let netrw_rm_cmd= s:MakeSshCmd(g:netrw_rm_cmd) -" call Decho("netrw_rm_cmd<".netrw_rm_cmd.">") - if !exists("b:netrw_curdir") - call netrw#ErrorMsg(s:ERROR,"for some reason b:netrw_curdir doesn't exist!",53) - let ok="q" - else - let remotedir= substitute(b:netrw_curdir,'^.*//[^/]\+/\(.*\)$','\1','') -" call Decho("netrw_rm_cmd<".netrw_rm_cmd.">") -" call Decho("remotedir<".remotedir.">") -" call Decho("rmfile<".a:rmfile.">") - if remotedir != "" - let netrw_rm_cmd= netrw_rm_cmd." ".shellescape(fnameescape(remotedir.a:rmfile)) - else - let netrw_rm_cmd= netrw_rm_cmd." ".shellescape(fnameescape(a:rmfile)) - endif -" call Decho("call system(".netrw_rm_cmd.")") - let ret= system(netrw_rm_cmd) - if ret != 0 - call netrw#ErrorMsg(s:WARNING,"cmd<".netrw_rm_cmd."> failed",60) - endif -" call Decho("returned=".ret." errcode=".v:shell_error) - endif - endif - elseif ok =~ 'q\%[uit]' -" call Decho("ok==".ok) - break - endif - - else - " attempt to remove directory -" call Decho("attempt to remove directory") - if !all - call inputsave() - let ok= input("Confirm deletion of directory<".a:rmfile."> ","[{y(es)},n(o),a(ll),q(uit)] ") - call inputrestore() - if ok == "" - let ok="no" - endif - let ok= substitute(ok,'\[{y(es)},n(o),a(ll),q(uit)]\s*','','e') - if ok =~ 'a\%[ll]' - let all= 1 - endif - endif - - if all || ok =~ 'y\%[es]' || ok == "" - if exists("w:netrw_method") && (w:netrw_method == 2 || w:netrw_method == 3) - call s:NetrwRemoteFtpCmd(a:path,"rmdir ".a:rmfile) - else - let rmfile = substitute(a:path.a:rmfile,'/$','','') - let netrw_rmdir_cmd = s:MakeSshCmd(s:WinPath(g:netrw_rmdir_cmd)).' '.shellescape(s:WinPath(rmfile)) -" call Decho("attempt to remove dir: system(".netrw_rmdir_cmd.")") - let ret= system(netrw_rmdir_cmd) -" call Decho("returned=".ret." errcode=".v:shell_error) - - if v:shell_error != 0 -" call Decho("v:shell_error not 0") - let netrw_rmf_cmd= s:MakeSshCmd(s:WinPath(g:netrw_rmf_cmd)).' '.shellescape(s:WinPath(substitute(rmfile,'[\/]$','','e'))) -" call Decho("2nd attempt to remove dir: system(".netrw_rmf_cmd.")") - let ret= system(netrw_rmf_cmd) -" call Decho("returned=".ret." errcode=".v:shell_error) - - if v:shell_error != 0 && !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"unable to remove directory<".rmfile."> -- is it empty?",22) - endif - endif - endif - - elseif ok =~ 'q\%[uit]' - break - endif - endif - -" call Dret("s:NetrwRemoteRmFile ".ok) - return ok -endfun - -" --------------------------------------------------------------------- -" s:NetrwRemoteFtpCmd: unfortunately, not all ftp servers honor options for ls {{{2 -" This function assumes that a long listing will be received. Size, time, -" and reverse sorts will be requested of the server but not otherwise -" enforced here. -fun! s:NetrwRemoteFtpCmd(path,listcmd) -" call Dfunc("NetrwRemoteFtpCmd(path<".a:path."> listcmd<".a:listcmd.">) netrw_method=".w:netrw_method) -" call Decho("line($)=".line("$")." bannercnt=".w:netrw_bannercnt) - - " because WinXX ftp uses unix style input - let ffkeep= &ff - setlocal ma ff=unix noro -" call Decho("setlocal ma ff=unix noro") - - " clear off any older non-banner lines - " note that w:netrw_bannercnt indexes the line after the banner -" call Decho('exe silent! keepjumps '.w:netrw_bannercnt.",$d (clear off old non-banner lines)") - exe "silent! keepjumps ".w:netrw_bannercnt.",$d" - - "......................................... - if w:netrw_method == 2 || w:netrw_method == 5 - " ftp + <.netrc>: Method #2 - if a:path != "" - put ='cd \"'.a:path.'\"' - endif - if exists("g:netrw_ftpextracmd") - put =g:netrw_ftpextracmd -" call Decho("filter input: ".getline('.')) - endif - call setline(line("$")+1,a:listcmd) -" exe "keepjumps ".w:netrw_bannercnt.',$g/^./call Decho("ftp#".line(".").": ".getline("."))' - if exists("g:netrw_port") && g:netrw_port != "" -" call Decho("exe ".s:netrw_silentxfer.w:netrw_bannercnt.",$!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)." ".shellescape(g:netrw_port,1)) - exe s:netrw_silentxfer." keepjumps ".w:netrw_bannercnt.",$!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)." ".shellescape(g:netrw_port,1) - else -" call Decho("exe ".s:netrw_silentxfer.w:netrw_bannercnt.",$!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1)) - exe s:netrw_silentxfer." keepjumps ".w:netrw_bannercnt.",$!".g:netrw_ftp_cmd." -i ".shellescape(g:netrw_machine,1) - endif - - "......................................... - elseif w:netrw_method == 3 - " ftp + machine,id,passwd,filename: Method #3 - setlocal ff=unix - if exists("g:netrw_port") && g:netrw_port != "" - put ='open '.g:netrw_machine.' '.g:netrw_port - else - put ='open '.g:netrw_machine - endif - - if exists("g:netrw_ftp") && g:netrw_ftp == 1 - put =g:netrw_uid - put ='\"'.s:netrw_passwd.'\"' - else - put ='user \"'.g:netrw_uid.'\" \"'.s:netrw_passwd.'\"' - endif - - if a:path != "" - put ='cd \"'.a:path.'\"' - endif - if exists("g:netrw_ftpextracmd") - put =g:netrw_ftpextracmd -" call Decho("filter input: ".getline('.')) - endif - call setline(line("$")+1,a:listcmd) - - " perform ftp: - " -i : turns off interactive prompting from ftp - " -n unix : DON'T use <.netrc>, even though it exists - " -n win32: quit being obnoxious about password -" exe w:netrw_bannercnt.',$g/^./call Decho("ftp#".line(".").": ".getline("."))' -" call Decho("exe ".s:netrw_silentxfer.w:netrw_bannercnt.",$!".g:netrw_ftp_cmd." -i -n") - exe s:netrw_silentxfer.w:netrw_bannercnt.",$!".g:netrw_ftp_cmd." -i -n" - - "......................................... - else - call netrw#ErrorMsg(s:WARNING,"unable to comply with your request<" . choice . ">",23) - endif - - " cleanup for Windows - if has("win32") || has("win95") || has("win64") || has("win16") - silent! keepjumps %s/\r$//e - endif - if a:listcmd == "dir" - " infer directory/link based on the file permission string - silent! keepjumps g/d\%([-r][-w][-x]\)\{3}/s@$@/@ - silent! keepjumps g/l\%([-r][-w][-x]\)\{3}/s/$/@/ - if w:netrw_liststyle == s:THINLIST || w:netrw_liststyle == s:WIDELIST || w:netrw_liststyle == s:TREELIST - exe "silent! keepjumps ".w:netrw_bannercnt.',$s/^\%(\S\+\s\+\)\{8}//e' - endif - endif - - " ftp's listing doesn't seem to include ./ or ../ - if !search('^\.\/$\|\s\.\/$','wn') - exe 'keepjumps '.w:netrw_bannercnt - put ='./' - endif - if !search('^\.\.\/$\|\s\.\.\/$','wn') - exe 'keepjumps '.w:netrw_bannercnt - put ='../' - endif - - " restore settings - let &ff= ffkeep -" call Dret("NetrwRemoteFtpCmd") -endfun - -" --------------------------------------------------------------------- -" s:NetrwRemoteRename: rename a remote file or directory {{{2 -fun! s:NetrwRemoteRename(usrhost,path) range -" call Dfunc("NetrwRemoteRename(usrhost<".a:usrhost."> path<".a:path.">)") - - " preparation for removing multiple files/directories - let svpos = netrw#NetrwSavePosn() - let ctr = a:firstline - let rename_cmd = s:MakeSshCmd(g:netrw_rename_cmd) - - " rename files given by the markfilelist - if exists("s:netrwmarkfilelist_{bufnr('%')}") - for oldname in s:netrwmarkfilelist_{bufnr("%")} -" call Decho("oldname<".oldname.">") - if exists("subfrom") - let newname= substitute(oldname,subfrom,subto,'') -" call Decho("subfrom<".subfrom."> subto<".subto."> newname<".newname.">") - else - call inputsave() - let newname= input("Moving ".oldname." to : ",oldname) - call inputrestore() - if newname =~ '^s/' - let subfrom = substitute(newname,'^s/\([^/]*\)/.*/$','\1','') - let subto = substitute(newname,'^s/[^/]*/\(.*\)/$','\1','') - let newname = substitute(oldname,subfrom,subto,'') -" call Decho("subfrom<".subfrom."> subto<".subto."> newname<".newname.">") - endif - endif - - if exists("w:netrw_method") && (w:netrw_method == 2 || w:netrw_method == 3) - call s:NetrwRemoteFtpCmd(a:path,"rename ".oldname." ".newname) - else - let oldname= shellescape(a:path.oldname) - let newname= shellescape(a:path.newname) -" call Decho("system(s:WinPath(".rename_cmd.") ".oldname.' '.newname.")") - let ret = system(s:WinPath(rename_cmd).' '.oldname.' '.newname) - endif - - endfor - call s:NetrwUnMarkFile(1) - - else - - " attempt to rename files/directories - while ctr <= a:lastline - exe "keepjumps ".ctr - - let oldname= s:NetrwGetWord() -" call Decho("oldname<".oldname.">") - - call inputsave() - let newname= input("Moving ".oldname." to : ",oldname) - call inputrestore() - - if exists("w:netrw_method") && (w:netrw_method == 2 || w:netrw_method == 3) - call s:NetrwRemoteFtpCmd(a:path,"rename ".oldname." ".newname) - else - let oldname= shellescape(a:path.oldname) - let newname= shellescape(a:path.newname) -" call Decho("system(s:WinPath(".rename_cmd.") ".oldname.' '.newname.")") - let ret = system(s:WinPath(rename_cmd).' '.oldname.' '.newname) - endif - - let ctr= ctr + 1 - endwhile - endif - - " refresh the directory - call s:NetrwRefresh(0,s:NetrwBrowseChgDir(0,'./')) - call netrw#NetrwRestorePosn(svpos) - -" call Dret("NetrwRemoteRename") -endfun - -" --------------------------------------------------------------------- -" Local Directory Browsing Support: {{{1 -" ========================================== - -" --------------------------------------------------------------------- -" netrw#LocalBrowseCheck: {{{2 -fun! netrw#LocalBrowseCheck(dirname) - " unfortunate interaction -- split window debugging can't be - " used here, must use D-echoRemOn or D-echoTabOn -- the BufEnter - " event triggers another call to LocalBrowseCheck() when attempts - " to write to the DBG buffer are made. - " The &ft == "netrw" test was installed because the BufEnter event - " would hit when re-entering netrw windows, creating unexpected - " refreshes (and would do so in the middle of NetrwSaveOptions(), too) -" call Decho("netrw#LocalBrowseCheck: isdir<".a:dirname.">=".isdirectory(a:dirname)) - if isdirectory(a:dirname) -" call Decho(" ft<".&ft."> b:netrw_curdir<".(exists("b:netrw_curdir")? b:netrw_curdir : " doesn't exist")."> dirname<".a:dirname.">"." line($)=".line("$")) - if &ft != "netrw" || (exists("b:netrw_curdir") && b:netrw_curdir != a:dirname) - silent! call s:NetrwBrowse(1,a:dirname) - elseif &ft == "netrw" && line("$") == 1 - silent! call s:NetrwBrowse(1,a:dirname) - endif - endif - " not a directory, ignore it -endfun - -" --------------------------------------------------------------------- -" s:LocalListing: does the job of "ls" for local directories {{{2 -fun! s:LocalListing() -" call Dfunc("s:LocalListing()") -" call Decho("&ma=".&ma) -" call Decho("&mod=".&mod) -" call Decho("&ro=".&ro) -" call Decho("bufname(%)<".bufname("%").">") - -" if exists("b:netrw_curdir") |call Decho('b:netrw_curdir<'.b:netrw_curdir.">") |else|call Decho("b:netrw_curdir doesn't exist") |endif -" if exists("g:netrw_sort_by")|call Decho('g:netrw_sort_by<'.g:netrw_sort_by.">")|else|call Decho("g:netrw_sort_by doesn't exist")|endif - - " get the list of files contained in the current directory - let dirname = escape(b:netrw_curdir,g:netrw_glob_escape) - let dirnamelen = strlen(b:netrw_curdir) - let filelist = glob(s:ComposePath(dirname,"*")) -" call Decho("glob(dirname<".dirname."/*>)=".filelist) - if filelist != "" - let filelist= filelist."\n" - endif - let filelist= filelist.glob(s:ComposePath(dirname,".*")) -" call Decho("glob(dirname<".dirname."/.*>)=".filelist) - - " Coding choice: either elide ./ if present - " or include ./ if not present - if filelist =~ '[\\/]\.[\\/]\=\(\n\|$\)' - " elide /path/. from glob() entries if present -" call Decho("elide /path/. from glob entries if present") - let filelist = substitute(filelist,'\n','\t','g') - let filelist = substitute(filelist,'^[^\t]\+[/\\]\.\t','','') - let filelist = substitute(filelist,'[^\t]\+[/\\]\.$','','') - let filelist = substitute(filelist,'\t\zs[^\t]\+[/\\]\.\t','','') - let filelist = substitute(filelist,'\t','\n','g') - endif -" call Decho("filelist<".filelist.">") - if filelist !~ '[\\/]\.\.[\\/]\=\(\n\|$\)' - " include ../ in the glob() entry if its missing -" call Decho("forcibly tacking on ..") - let filelist= filelist."\n".s:ComposePath(b:netrw_curdir,"../") -" call Decho("filelist<".filelist.">") - endif - if b:netrw_curdir == '/' - " remove .. from filelist when current directory is root directory -" call Decho("remove .. from filelist") - let filelist= substitute(filelist,'/\.\.\n','','') - endif - " remove multiple contiguous newlines - let filelist= substitute(filelist,'\n\{2,}','\n','ge') - if !g:netrw_cygwin && (has("win32") || has("win95") || has("win64") || has("win16")) - " change all \s to /s -" call Decho('change all \s to /s') - let filelist= substitute(filelist,'\','/','g') - else - " escape all \s to \\ -" call Decho('escape all \s to \\') - let filelist= substitute(filelist,'\','\\','g') - endif - -" call Decho("(before while) dirname<".dirname.">") -" call Decho("(before while) dirnamelen<".dirnamelen.">") -" call Decho("(before while) filelist<".filelist.">") - - while filelist != "" - if filelist =~ '\n' - let filename = substitute(filelist,'\n.*$','','e') - let filelist = substitute(filelist,'^.\{-}\n\(.*\)$','\1','e') - else - let filename = filelist - let filelist = "" - endif -" call Decho(" ") -" call Decho("(while) filelist<".filelist.">") -" call Decho("(while) filename<".filename.">") - - if getftype(filename) == "link" - " indicate a symbolic link -" call Decho("indicate <".filename."> is a symbolic link with trailing @") - let pfile= filename."@" - - elseif getftype(filename) == "socket" - " indicate a socket -" call Decho("indicate <".filename."> is a socket with trailing =") - let pfile= filename."=" - - elseif getftype(filename) == "fifo" - " indicate a fifo -" call Decho("indicate <".filename."> is a fifo with trailing |") - let pfile= filename."|" - - elseif isdirectory(filename) - " indicate a directory -" call Decho("indicate <".filename."> is a directory with trailing /") - let pfile= filename."/" - - elseif exists("b:netrw_curdir") && b:netrw_curdir !~ '^.*://' && !isdirectory(filename) - if (has("win32") || has("win95") || has("win64") || has("win16")) - if filename =~ '\.[eE][xX][eE]$' || filename =~ '\.[cC][oO][mM]$' || filename =~ '\.[bB][aA][tT]$' - " indicate an executable -" call Decho("indicate <".filename."> is executable with trailing *") - let pfile= filename."*" - else - " normal file - let pfile= filename - endif - elseif executable(filename) - " indicate an executable -" call Decho("indicate <".filename."> is executable with trailing *") - let pfile= filename."*" - else - " normal file - let pfile= filename - endif - - else - " normal file - let pfile= filename - endif -" call Decho("pfile<".pfile."> (after *@/ appending)") - - if pfile =~ '//$' - let pfile= substitute(pfile,'//$','/','e') -" call Decho("change // to /: pfile<".pfile.">") - endif - let pfile= strpart(pfile,dirnamelen) - let pfile= substitute(pfile,'^[/\\]','','e') -" call Decho("filename<".filename.">") -" call Decho("pfile <".pfile.">") - - if w:netrw_liststyle == s:LONGLIST - let sz = getfsize(filename) - let fsz = strpart(" ",1,15-s:Strlen(sz)).sz - let pfile= pfile."\t".fsz." ".strftime(g:netrw_timefmt,getftime(filename)) -" call Decho("sz=".sz." fsz=".fsz) - endif - - if g:netrw_sort_by =~ "^t" - " sort by time (handles time up to 1 quintillion seconds, US) -" call Decho("getftime(".filename.")=".getftime(filename)) - let t = getftime(filename) - let ft = strpart("000000000000000000",1,18-s:Strlen(t)).t -" call Decho("exe keepjumps put ='".ft.'/'.filename."'") - let ftpfile= ft.'/'.pfile - keepjumps silent! put=ftpfile - - elseif g:netrw_sort_by =~ "^s" - " sort by size (handles file sizes up to 1 quintillion bytes, US) -" call Decho("getfsize(".filename.")=".getfsize(filename)) - let sz = getfsize(filename) - let fsz = strpart("000000000000000000",1,18-s:Strlen(sz)).sz -" call Decho("exe keepjumps put ='".fsz.'/'.filename."'") - let fszpfile= fsz.'/'.pfile - keepjumps silent! put =fszpfile - - else - " sort by name -" call Decho("exe keepjumps put ='".pfile."'") - keepjumps silent! put=pfile - endif - endwhile - - " cleanup any windows mess at end-of-line - silent! keepjumps %s/\r$//e - exe "setlocal ts=".g:netrw_maxfilenamelen -" call Decho("setlocal ts=".g:netrw_maxfilenamelen) - -" call Dret("s:LocalListing") -endfun - -" --------------------------------------------------------------------- -" s:LocalBrowseShellCmdRefresh: this function is called after a user has {{{2 -" performed any shell command. The idea is to cause all local-browsing -" buffers to be refreshed after a user has executed some shell command, -" on the chance that s/he removed/created a file/directory with it. -fun! s:LocalBrowseShellCmdRefresh() -" call Dfunc("LocalBrowseShellCmdRefresh() browselist=".(exists("s:netrw_browselist")? string(s:netrw_browselist) : "empty")." ".tabpagenr("$")." tabs") - " determine which buffers currently reside in a tab - if !exists("s:netrw_browselist") -" call Dret("LocalBrowseShellCmdRefresh : browselist is empty") - return - endif - if !exists("w:netrw_bannercnt") -" call Dret("LocalBrowseShellCmdRefresh : don't refresh when focus not on netrw windwo") - return - endif - let itab = 1 - let buftablist = [] - while itab <= tabpagenr("$") - let buftablist = buftablist + tabpagebuflist() - let itab = itab + 1 - tabn - endwhile -" call Decho("buftablist".string(buftablist)) -" call Decho("s:netrw_browselist<".(exists("s:netrw_browselist")? string(s:netrw_browselist) : "").">") - " GO through all buffers on netrw_browselist (ie. just local-netrw buffers): - " | refresh any netrw window - " | wipe out any non-displaying netrw buffer - let curwin = winnr() - let ibl = 0 - for ibuf in s:netrw_browselist -" call Decho("bufwinnr(".ibuf.") index(buftablist,".ibuf.")=".index(buftablist,ibuf)) - if bufwinnr(ibuf) == -1 && index(buftablist,ibuf) == -1 - " wipe out any non-displaying netrw buffer -" call Decho("wiping buf#".ibuf,"<".bufname(ibuf).">") - exe "silent! bd ".fnameescape(ibuf) - call remove(s:netrw_browselist,ibl) -" call Decho("browselist=".string(s:netrw_browselist)) - continue - elseif index(tabpagebuflist(),ibuf) != -1 - " refresh any netrw buffer -" call Decho("refresh buf#".ibuf.'-> win#'.bufwinnr(ibuf)) - exe bufwinnr(ibuf)."wincmd w" - call s:NetrwRefresh(1,s:NetrwBrowseChgDir(1,'./')) - endif - let ibl= ibl + 1 - endfor - exe curwin."wincmd w" - -" call Dret("LocalBrowseShellCmdRefresh") -endfun - -" --------------------------------------------------------------------- -" s:NetrwLocalRm: {{{2 -fun! s:NetrwLocalRm(path) range -" call Dfunc("s:NetrwLocalRm(path<".a:path.">)") -" call Decho("firstline=".a:firstline." lastline=".a:lastline) - - " preparation for removing multiple files/directories - let ret = 0 - let all = 0 - let svpos = netrw#NetrwSavePosn() - - if exists("s:netrwmarkfilelist_{bufnr('%')}") - " remove all marked files -" call Decho("remove all marked files") - for fname in s:netrwmarkfilelist_{bufnr("%")} - let ok= s:NetrwLocalRmFile(a:path,fname,all) - if ok =~ 'q\%[uit]' || ok == "no" - break - elseif ok =~ 'a\%[ll]' - let all= 1 - endif - endfor - call s:NetrwUnMarkFile(1) - - else - " remove (multiple) files and directories -" call Decho("remove files in range [".a:firstline.",".a:lastline."]") - - let ctr = a:firstline - while ctr <= a:lastline - exe "keepjumps ".ctr - - " sanity checks - if line(".") < w:netrw_bannercnt - let ctr= ctr + 1 - continue - endif - let curword= s:NetrwGetWord() - if curword == "./" || curword == "../" - let ctr= ctr + 1 - continue - endif - let ok= s:NetrwLocalRmFile(a:path,curword,all) - if ok =~ 'q\%[uit]' || ok == "no" - break - elseif ok =~ 'a\%[ll]' - let all= 1 - endif - let ctr= ctr + 1 - endwhile - endif - - " refresh the directory -" call Decho("bufname<".bufname("%").">") - if bufname("%") != "NetrwMessage" - call s:NetrwRefresh(1,s:NetrwBrowseChgDir(1,'./')) - call netrw#NetrwRestorePosn(svpos) - endif - -" call Dret("s:NetrwLocalRm") -endfun - -" --------------------------------------------------------------------- -" s:NetrwLocalRmFile: remove file fname given the path {{{2 -" Give confirmation prompt unless all==1 -fun! s:NetrwLocalRmFile(path,fname,all) -" call Dfunc("s:NetrwLocalRmFile(path<".a:path."> fname<".a:fname."> all=".a:all) - - let all= a:all - let ok = "" - norm! 0 - let rmfile= s:ComposePath(a:path,a:fname) -" call Decho("rmfile<".rmfile.">") - - if rmfile !~ '^"' && (rmfile =~ '@$' || rmfile !~ '[\/]$') - " attempt to remove file -" call Decho("attempt to remove file<".rmfile.">") - if !all - echohl Statement - call inputsave() - let ok= input("Confirm deletion of file<".rmfile."> ","[{y(es)},n(o),a(ll),q(uit)] ") - call inputrestore() - echohl NONE - if ok == "" - let ok="no" - endif -" call Decho("response: ok<".ok.">") - let ok= substitute(ok,'\[{y(es)},n(o),a(ll),q(uit)]\s*','','e') -" call Decho("response: ok<".ok."> (after sub)") - if ok =~ 'a\%[ll]' - let all= 1 - endif - endif - - if all || ok =~ 'y\%[es]' || ok == "" - let ret= s:NetrwDelete(rmfile) -" call Decho("errcode=".v:shell_error." ret=".ret) - endif - - else - " attempt to remove directory - if !all - echohl Statement - call inputsave() - let ok= input("Confirm deletion of directory<".rmfile."> ","[{y(es)},n(o),a(ll),q(uit)] ") - call inputrestore() - let ok= substitute(ok,'\[{y(es)},n(o),a(ll),q(uit)]\s*','','e') - if ok == "" - let ok="no" - endif - if ok =~ 'a\%[ll]' - let all= 1 - endif - endif - let rmfile= substitute(rmfile,'[\/]$','','e') - - if all || ok =~ 'y\%[es]' || ok == "" -" call Decho("1st attempt: system(s:WinPath(".g:netrw_local_rmdir.') '.shellescape(rmfile).')') - call system(s:WinPath(g:netrw_local_rmdir).' '.shellescape(rmfile)) -" call Decho("v:shell_error=".v:shell_error) - - if v:shell_error != 0 -" call Decho("2nd attempt to remove directory<".rmfile.">") - let errcode= s:NetrwDelete(rmfile) -" call Decho("errcode=".errcode) - - if errcode != 0 - if has("unix") -" call Decho("3rd attempt to remove directory<".rmfile.">") - call system("rm ".shellescape(rmfile)) - if v:shell_error != 0 && !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"unable to remove directory<".rmfile."> -- is it empty?",34) - let ok="no" - endif - elseif !exists("g:netrw_quiet") - call netrw#ErrorMsg(s:ERROR,"unable to remove directory<".rmfile."> -- is it empty?",35) - let ok="no" - endif - endif - endif - endif - endif - -" call Dret("s:NetrwLocalRmFile ".ok) - return ok -endfun - -" --------------------------------------------------------------------- -" s:NetrwLocalRename: rename a remote file or directory {{{2 -fun! s:NetrwLocalRename(path) range -" call Dfunc("NetrwLocalRename(path<".a:path.">)") - - " preparation for removing multiple files/directories - let ctr = a:firstline - let svpos= netrw#NetrwSavePosn() - - " rename files given by the markfilelist - if exists("s:netrwmarkfilelist_{bufnr('%')}") - for oldname in s:netrwmarkfilelist_{bufnr("%")} -" call Decho("oldname<".oldname.">") - if exists("subfrom") - let newname= substitute(oldname,subfrom,subto,'') -" call Decho("subfrom<".subfrom."> subto<".subto."> newname<".newname.">") - else - call inputsave() - let newname= input("Moving ".oldname." to : ",oldname) - call inputrestore() - if newname =~ '^s/' - let subfrom = substitute(newname,'^s/\([^/]*\)/.*/$','\1','') - let subto = substitute(newname,'^s/[^/]*/\(.*\)/$','\1','') -" call Decho("subfrom<".subfrom."> subto<".subto."> newname<".newname.">") - let newname = substitute(oldname,subfrom,subto,'') - endif - endif - call rename(oldname,newname) - endfor - 2match none - unlet s:netrwmarkfilelist_{bufnr("%")} - unlet s:netrwmarkfilemtch_{bufnr("%")} - - else - - " attempt to rename files/directories - while ctr <= a:lastline - exe "keepjumps ".ctr - - " sanity checks - if line(".") < w:netrw_bannercnt - let ctr= ctr + 1 - continue - endif - let curword= s:NetrwGetWord() - if curword == "./" || curword == "../" - let ctr= ctr + 1 - continue - endif - - norm! 0 - let oldname= s:ComposePath(a:path,curword) -" call Decho("oldname<".oldname.">") - - call inputsave() - let newname= input("Moving ".oldname." to : ",substitute(oldname,'/*$','','e')) - call inputrestore() - - call rename(oldname,newname) -" call Decho("renaming <".oldname."> to <".newname.">") - - let ctr= ctr + 1 - endwhile - endif - - " refresh the directory -" call Decho("refresh the directory listing") - call s:NetrwRefresh(1,s:NetrwBrowseChgDir(1,'./')) - call netrw#NetrwRestorePosn(svpos) - -" call Dret("NetrwLocalRename") -endfun - -" --------------------------------------------------------------------- -" s:LocalFastBrowser: handles setting up/taking down fast browsing for the local browser {{{2 -" -" g:netrw_ Directory Is -" fastbrowse Local Remote -" slow 0 D D D=Deleting a buffer implies it will not be re-used (slow) -" med 1 D H H=Hiding a buffer implies it may be re-used (fast) -" fast 2 H H -" -" Deleting a buffer means that it will be re-loaded when examined, hence "slow". -" Hiding a buffer means that it will be re-used when examined, hence "fast". -" (re-using a buffer may not be as accurate) -fun! s:LocalFastBrowser() -" call Dfunc("LocalFastBrowser() g:netrw_fastbrowse=".g:netrw_fastbrowse) - - " initialize browselist, a list of buffer numbers that the local browser has used - if !exists("s:netrw_browselist") -" call Decho("initialize s:netrw_browselist") - let s:netrw_browselist= [] - endif - - " append current buffer to fastbrowse list - if empty(s:netrw_browselist) || bufnr("%") > s:netrw_browselist[-1] -" call Decho("appendng current buffer to browselist") - call add(s:netrw_browselist,bufnr("%")) -" call Decho("browselist=".string(s:netrw_browselist)) - endif - - " enable autocmd events to handle refreshing/removing local browser buffers - " If local browse buffer is currently showing: refresh it - " If local browse buffer is currently hidden : wipe it - if !exists("s:netrw_browser_shellcmd") && g:netrw_fastbrowse <= 1 -" call Decho("setting up local-browser shell command refresh") - let s:netrw_browser_shellcmd= 1 - augroup AuNetrwShellCmd - au! - if (has("win32") || has("win95") || has("win64") || has("win16")) - au ShellCmdPost * call s:LocalBrowseShellCmdRefresh() - else - au ShellCmdPost,FocusGained * call s:LocalBrowseShellCmdRefresh() - endif - augroup END - endif - - " user must have changed fastbrowse to its fast setting, so remove - " the associated autocmd events - if g:netrw_fastbrowse > 1 && exists("s:netrw_browser_shellcmd") -" call Decho("remove AuNetrwShellCmd autcmd group") - unlet s:netrw_browser_shellcmd - augroup AuNetrwShellCmd - au! - augroup END - augroup! AuNetrwShellCmd - endif - -" call Dret("LocalFastBrowser : browselist<".string(s:netrw_browselist).">") -endfun - -" --------------------------------------------------------------------- -" Support Functions: {{{1 - -" --------------------------------------------------------------------- -" netrw#ErrorMsg: {{{2 -" 0=note = s:NOTE -" 1=warning = s:WARNING -" 2=error = s:ERROR -" Jul 08, 2008 : max errnum currently is 71 -fun! netrw#ErrorMsg(level,msg,errnum) -" call Dfunc("netrw#ErrorMsg(level=".a:level." msg<".a:msg."> errnum=".a:errnum.") g:netrw_use_errorwindow=".g:netrw_use_errorwindow) - - if a:level == 1 - let level= "**warning** (netrw) " - elseif a:level == 2 - let level= "**error** (netrw) " - else - let level= "**note** (netrw) " - endif -" call Decho("level=".level) - - if g:netrw_use_errorwindow - " (default) netrw creates a one-line window to show error/warning - " messages (reliably displayed) - - " record current window number for NetrwRestorePosn()'s benefit - let s:winBeforeErr= winnr() -" call Decho("s:winBeforeErr=".s:winBeforeErr) - - " getting messages out reliably is just plain difficult! - " This attempt splits the current window, creating a one line window. - if bufexists("NetrwMessage") && bufwinnr("NetrwMessage") > 0 -" call Decho("write to NetrwMessage buffer") - exe bufwinnr("NetrwMessage")."wincmd w" -" call Decho("setlocal ma noro") - setlocal ma noro - call setline(line("$")+1,level.a:msg) - $ - else -" call Decho("create a NetrwMessage buffer window") - bo 1split - enew - setlocal bt=nofile - file NetrwMessage -" call Decho("setlocal ma noro") - setlocal ma noro - call setline(line("$"),level.a:msg) - endif -" call Decho("wrote msg<".level.a:msg."> to NetrwMessage win#".winnr()) - if &fo !~ '[ta]' - syn clear - syn match netrwMesgNote "^\*\*note\*\*" - syn match netrwMesgWarning "^\*\*warning\*\*" - syn match netrwMesgError "^\*\*error\*\*" - hi link netrwMesgWarning WarningMsg - hi link netrwMesgError Error - endif - setlocal noma ro bh=wipe - - else - " (optional) netrw will show messages using echomsg. Even if the - " message doesn't appear, at least it'll be recallable via :messages -" redraw! - if a:level == s:WARNING - echohl WarningMsg - elseif a:level == s:ERROR - echohl Error - endif - echomsg level.a:msg -" call Decho("echomsg ***netrw*** ".a:msg) - echohl None - endif - -" call Dret("netrw#ErrorMsg") -endfun - -" --------------------------------------------------------------------- -" netrw#NetrwRestorePosn: restores the cursor and file position as saved by NetrwSavePosn() {{{2 -fun! netrw#NetrwRestorePosn(...) -" call Dfunc("netrw#NetrwRestorePosn() a:0=".a:0." winnr=".(exists("w:netrw_winnr")? w:netrw_winnr : -1)." line=".(exists("w:netrw_line")? w:netrw_line : -1)." col=".(exists("w:netrw_col")? w:netrw_col : -1)." hline=".(exists("w:netrw_hline")? w:netrw_hline : -1)) - let eikeep= &ei - set ei=all - if expand("%") == "NetrwMessage" - exe s:winBeforeErr."wincmd w" - endif - - if a:0 > 0 - exe a:1 - endif - - " restore window - if exists("w:netrw_winnr") -" call Decho("restore window: exe silent! ".w:netrw_winnr."wincmd w") - exe "silent! ".w:netrw_winnr."wincmd w" - endif - if v:shell_error == 0 - " as suggested by Bram M: redraw on no error - " allows protocol error messages to remain visible -" redraw! - endif - - " restore top-of-screen line - if exists("w:netrw_hline") -" call Decho("restore topofscreen: exe norm! ".w:netrw_hline."G0z") - exe "norm! ".w:netrw_hline."G0z\" - endif - - " restore position - if exists("w:netrw_line") && exists("w:netrw_col") -" call Decho("restore posn: exe norm! ".w:netrw_line."G0".w:netrw_col."|") - exe "norm! ".w:netrw_line."G0".w:netrw_col."\" - endif - - let &ei= eikeep -" call Dret("netrw#NetrwRestorePosn") -endfun - -" --------------------------------------------------------------------- -" netrw#NetrwSavePosn: saves position of cursor on screen {{{2 -fun! netrw#NetrwSavePosn() -" call Dfunc("netrw#NetrwSavePosn()") - " Save current line and column - let w:netrw_winnr= winnr() - let w:netrw_line = line(".") - let w:netrw_col = virtcol(".") - - " Save top-of-screen line - norm! H0 - let w:netrw_hline= line(".") - - " set up string holding position parameters - let ret = "let w:netrw_winnr=".w:netrw_winnr."|let w:netrw_line=".w:netrw_line."|let w:netrw_col=".w:netrw_col."|let w:netrw_hline=".w:netrw_hline - - call netrw#NetrwRestorePosn() -" call Dret("netrw#NetrwSavePosn : winnr=".w:netrw_winnr." line=".w:netrw_line." col=".w:netrw_col." hline=".w:netrw_hline) - return ret -endfun - -" ------------------------------------------------------------------------ -" netrw#RFC2396: converts %xx into characters {{{2 -fun! netrw#RFC2396(fname) -" call Dfunc("netrw#RFC2396(fname<".a:fname.">)") - let fname = escape(substitute(a:fname,'%\(\x\x\)','\=nr2char("0x".submatch(1))','ge')," \t") -" call Dret("netrw#RFC2396 ".fname) - return fname -endfun - -" --------------------------------------------------------------------- -" s:ComposePath: Appends a new part to a path taking different systems into consideration {{{2 -fun! s:ComposePath(base,subdir) -" call Dfunc("s:ComposePath(base<".a:base."> subdir<".a:subdir.">)") - - if(has("amiga")) -" call Decho("amiga") - let ec = a:base[strlen(a:base)-1] - if ec != '/' && ec != ':' - let ret = a:base . "/" . a:subdir - else - let ret = a:base . a:subdir - endif - - elseif a:subdir =~ '^\a:[/\\][^/\\]' && (has("win32") || has("win95") || has("win64") || has("win16")) -" call Decho("windows") - let ret= a:subdir - - elseif a:base =~ '^\a\+://' -" call Decho("remote linux/macos") - let urlbase = substitute(a:base,'^\(\a\+://.\{-}/\)\(.*\)$','\1','') - let curpath = substitute(a:base,'^\(\a\+://.\{-}/\)\(.*\)$','\2','') - if a:subdir == '../' - if curpath =~ '[^/]/[^/]\+/$' - let curpath= substitute(curpath,'[^/]\+/$','','') - else - let curpath="" - endif - let ret= urlbase.curpath - else - let ret= urlbase.curpath.a:subdir - endif -" call Decho("urlbase<".urlbase.">") -" call Decho("curpath<".curpath.">") -" call Decho("ret<".ret.">") - - else -" call Decho("local linux/macos") - let ret = substitute(a:base."/".a:subdir,"//","/","g") - if a:base =~ '^//' - " keeping initial '//' for the benefit of network share listing support - let ret= '/'.ret - endif - let ret= simplify(ret) - endif - -" call Dret("s:ComposePath ".ret) - return ret -endfun - -" --------------------------------------------------------------------- -" s:FileReadable: o/s independent filereadable {{{2 -fun! s:FileReadable(fname) -" call Dfunc("s:FileReadable(fname<".a:fname.">)") - - if g:netrw_cygwin - let ret= filereadable(substitute(a:fname,'/cygdrive/\(.\)','\1:/','')) - else - let ret= filereadable(a:fname) - endif - -" call Dret("s:FileReadable ".ret) - return ret -endfun - -" --------------------------------------------------------------------- -" s:GetTempfile: gets a tempname that'll work for various o/s's {{{2 -" Places correct suffix on end of temporary filename, -" using the suffix provided with fname -fun! s:GetTempfile(fname) -" call Dfunc("s:GetTempfile(fname<".a:fname.">)") - - if !exists("b:netrw_tmpfile") - " get a brand new temporary filename - let tmpfile= tempname() -" call Decho("tmpfile<".tmpfile."> : from tempname()") - - let tmpfile= substitute(tmpfile,'\','/','ge') -" call Decho("tmpfile<".tmpfile."> : chgd any \\ -> /") - - " sanity check -- does the temporary file's directory exist? - if !isdirectory(substitute(tmpfile,'[^/]\+$','','e')) -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) - call netrw#ErrorMsg(s:ERROR,"your <".substitute(tmpfile,'[^/]\+$','','e')."> directory is missing!",2) -" call Dret("s:GetTempfile getcwd<".getcwd().">") - return "" - endif - - " let netrw#NetSource() know about the tmpfile - let s:netrw_tmpfile= tmpfile " used by netrw#NetSource() -" call Decho("tmpfile<".tmpfile."> s:netrw_tmpfile<".s:netrw_tmpfile.">") - - " o/s dependencies - if g:netrw_cygwin != 0 - let tmpfile = substitute(tmpfile,'^\(\a\):','/cygdrive/\1','e') - elseif has("win32") || has("win95") || has("win64") || has("win16") - if !exists("+shellslash") || !&ssl - let tmpfile = substitute(tmpfile,'/','\','g') - endif - else - let tmpfile = tmpfile - endif - let b:netrw_tmpfile= tmpfile -" call Decho("o/s dependent fixed tempname<".tmpfile.">") - else - " re-use temporary filename - let tmpfile= b:netrw_tmpfile -" call Decho("tmpfile<".tmpfile."> re-using") - endif - - " use fname's suffix for the temporary file - if a:fname != "" - if a:fname =~ '\.[^./]\+$' -" call Decho("using fname<".a:fname.">'s suffix") - if a:fname =~ '.tar.gz' || a:fname =~ '.tar.bz2' - let suffix = ".tar".substitute(a:fname,'^.*\(\.[^./]\+\)$','\1','e') - else - let suffix = substitute(a:fname,'^.*\(\.[^./]\+\)$','\1','e') - endif -" call Decho("suffix<".suffix.">") - let tmpfile= substitute(tmpfile,'\.tmp$','','e') -" call Decho("chgd tmpfile<".tmpfile."> (removed any .tmp suffix)") - let tmpfile .= suffix -" call Decho("chgd tmpfile<".tmpfile."> (added ".suffix." suffix) netrw_fname<".b:netrw_fname.">") - let s:netrw_tmpfile= tmpfile " supports netrw#NetSource() - endif - endif - -" call Decho("ro=".&l:ro." ma=".&l:ma." mod=".&l:mod." wrap=".&l:wrap) -" call Dret("s:GetTempfile <".tmpfile.">") - return tmpfile -endfun - -" --------------------------------------------------------------------- -" s:MakeSshCmd: transforms input command using USEPORT HOSTNAME into {{{2 -" a correct command for use with a system() call -fun! s:MakeSshCmd(sshcmd) -" call Dfunc("s:MakeSshCmd(sshcmd<".a:sshcmd.">) user<".s:user."> machine<".s:machine.">") - let sshcmd = substitute(a:sshcmd,'\',s:user.s:machine,'') - if exists("g:netrw_port") && g:netrw_port != "" - let sshcmd= substitute(sshcmd,"USEPORT",g:netrw_sshport.' '.g:netrw_port,'') - elseif exists("s:port") && s:port != "" - let sshcmd= substitute(sshcmd,"USEPORT",g:netrw_sshport.' '.s:port,'') - else - let sshcmd= substitute(sshcmd,"USEPORT ",'','') - endif -" call Dret("s:MakeSshCmd <".sshcmd.">") - return sshcmd -endfun - -" --------------------------------------------------------------------- -" s:NetrwBMShow: {{{2 -fun! s:NetrwBMShow() -" call Dfunc("s:NetrwBMShow()") - redir => bmshowraw - menu - redir END - let bmshowlist = split(bmshowraw,'\n') - if bmshowlist != [] - let bmshowfuncs= filter(bmshowlist,'v:val =~ "\\d\\+_BMShow()"') - if bmshowfuncs != [] - let bmshowfunc = substitute(bmshowfuncs[0],'^.*:\(call.*BMShow()\).*$','\1','') - if bmshowfunc =~ '^call.*BMShow()' - exe "silent! ".bmshowfunc - endif - endif - endif -" call Dret("s:NetrwBMShow : bmshowfunc<".(exists("bmshowfunc")? bmshowfunc : 'n/a').">") -endfun - -" --------------------------------------------------------------------- -" s:NetrwDelete: Deletes a file. {{{2 -" Uses Steve Hall's idea to insure that Windows paths stay -" acceptable. No effect on Unix paths. -" Examples of use: let result= s:NetrwDelete(path) -fun! s:NetrwDelete(path) -" call Dfunc("s:NetrwDelete(path<".a:path.">)") - - let path = s:WinPath(a:path) - if !g:netrw_cygwin && (has("win32") || has("win95") || has("win64") || has("win16")) - if exists("+shellslash") - let sskeep= &shellslash - setlocal noshellslash - let result = delete(path) - let &shellslash = sskeep - else -" call Decho("exe let result= ".a:cmd."('".path."')") - let result= delete(path) - endif - else -" call Decho("let result= delete(".path.")") - let result= delete(path) - endif - if result < 0 - call Netrw#ErrorMsg(s:WARNING,"delete(".path.") failed!",71) - endif - -" call Dret("s:NetrwDelete ".result) - return result -endfun - -" --------------------------------------------------------------------- -" s:NetrwEnew: opens a new buffer, passes netrw buffer variables through {{{2 -fun! s:NetrwEnew(curdir) -" call Dfunc("s:NetrwEnew(curdir<".a:curdir.">) buf#".bufnr("%")."<".bufname("%").">") - - " grab a function-local-variable copy of buffer variables - if exists("b:netrw_bannercnt") |let netrw_bannercnt = b:netrw_bannercnt |endif - if exists("b:netrw_browser_active") |let netrw_browser_active = b:netrw_browser_active |endif - if exists("b:netrw_cpf") |let netrw_cpf = b:netrw_cpf |endif - if exists("b:netrw_curdir") |let netrw_curdir = b:netrw_curdir |endif - if exists("b:netrw_explore_bufnr") |let netrw_explore_bufnr = b:netrw_explore_bufnr |endif - if exists("b:netrw_explore_indx") |let netrw_explore_indx = b:netrw_explore_indx |endif - if exists("b:netrw_explore_line") |let netrw_explore_line = b:netrw_explore_line |endif - if exists("b:netrw_explore_list") |let netrw_explore_list = b:netrw_explore_list |endif - if exists("b:netrw_explore_listlen")|let netrw_explore_listlen = b:netrw_explore_listlen|endif - if exists("b:netrw_explore_mtchcnt")|let netrw_explore_mtchcnt = b:netrw_explore_mtchcnt|endif - if exists("b:netrw_fname") |let netrw_fname = b:netrw_fname |endif - if exists("b:netrw_lastfile") |let netrw_lastfile = b:netrw_lastfile |endif - if exists("b:netrw_liststyle") |let netrw_liststyle = b:netrw_liststyle |endif - if exists("b:netrw_method") |let netrw_method = b:netrw_method |endif - if exists("b:netrw_option") |let netrw_option = b:netrw_option |endif - if exists("b:netrw_prvdir") |let netrw_prvdir = b:netrw_prvdir |endif - - call s:NetrwOptionRestore("w:") -" call Decho("generate a buffer with keepjumps keepalt enew!") - keepjumps keepalt enew! - call s:NetrwOptionSave("w:") - - " copy function-local-variables to buffer variable equivalents - if exists("netrw_bannercnt") |let b:netrw_bannercnt = netrw_bannercnt |endif - if exists("netrw_browser_active") |let b:netrw_browser_active = netrw_browser_active |endif - if exists("netrw_cpf") |let b:netrw_cpf = netrw_cpf |endif - if exists("netrw_curdir") |let b:netrw_curdir = netrw_curdir |endif - if exists("netrw_explore_bufnr") |let b:netrw_explore_bufnr = netrw_explore_bufnr |endif - if exists("netrw_explore_indx") |let b:netrw_explore_indx = netrw_explore_indx |endif - if exists("netrw_explore_line") |let b:netrw_explore_line = netrw_explore_line |endif - if exists("netrw_explore_list") |let b:netrw_explore_list = netrw_explore_list |endif - if exists("netrw_explore_listlen")|let b:netrw_explore_listlen = netrw_explore_listlen|endif - if exists("netrw_explore_mtchcnt")|let b:netrw_explore_mtchcnt = netrw_explore_mtchcnt|endif - if exists("netrw_fname") |let b:netrw_fname = netrw_fname |endif - if exists("netrw_lastfile") |let b:netrw_lastfile = netrw_lastfile |endif - if exists("netrw_liststyle") |let b:netrw_liststyle = netrw_liststyle |endif - if exists("netrw_method") |let b:netrw_method = netrw_method |endif - if exists("netrw_option") |let b:netrw_option = netrw_option |endif - if exists("netrw_prvdir") |let b:netrw_prvdir = netrw_prvdir |endif - - let b:netrw_curdir= a:curdir - if b:netrw_curdir =~ '/$' - if exists("w:netrw_liststyle") && w:netrw_liststyle == s:TREELIST - file NetrwTreeListing - nno [ :silent call TreeListMove('[') - nno ] :silent call TreeListMove(']') - else - exe "silent! keepalt file ".fnameescape(b:netrw_curdir) - endif - endif - -" call Dret("s:NetrwEnew : buf#".bufnr("%")."<".bufname("%")."> expand(%)<".expand("%")."> expand(#)<".expand("#").">") -endfun - -" ------------------------------------------------------------------------ -" s:NetrwSaveWordPosn: used to keep cursor on same word after refresh, {{{2 -" changed sorting, etc. Also see s:NetrwRestoreWordPosn(). -fun! s:NetrwSaveWordPosn() -" call Dfunc("NetrwSaveWordPosn()") - let s:netrw_saveword= '^'.fnameescape(getline('.')).'$' -" call Dret("NetrwSaveWordPosn : saveword<".s:netrw_saveword.">") -endfun - -" --------------------------------------------------------------------- -" s:NetrwRestoreWordPosn: used to keep cursor on same word after refresh, {{{2 -" changed sorting, etc. Also see s:NetrwSaveWordPosn(). -fun! s:NetrwRestoreWordPosn() -" call Dfunc("NetrwRestoreWordPosn()") - silent! call search(s:netrw_saveword,'w') -" call Dret("NetrwRestoreWordPosn") -endfun - -" --------------------------------------------------------------------- -" s:RestoreBufVars: {{{2 -fun! s:RestoreBufVars() -" call Dfunc("s:RestoreBufVars()") - - if exists("s:netrw_curdir") |let b:netrw_curdir = s:netrw_curdir |endif - if exists("s:netrw_lastfile") |let b:netrw_lastfile = s:netrw_lastfile |endif - if exists("s:netrw_method") |let b:netrw_method = s:netrw_method |endif - if exists("s:netrw_fname") |let b:netrw_fname = s:netrw_fname |endif - if exists("s:netrw_machine") |let b:netrw_machine = s:netrw_machine |endif - if exists("s:netrw_browser_active")|let b:netrw_browser_active = s:netrw_browser_active|endif - -" call Dret("s:RestoreBufVars") -endfun - -" --------------------------------------------------------------------- -" s:RemotePathAnalysis: {{{2 -fun! s:RemotePathAnalysis(dirname) -" call Dfunc("s:RemotePathAnalysis()") - - let dirpat = '^\(\w\{-}\)://\(\w\+@\)\=\([^/:#]\+\)\%([:#]\(\d\+\)\)\=/\(.*\)$' - let s:method = substitute(a:dirname,dirpat,'\1','') - let s:user = substitute(a:dirname,dirpat,'\2','') - let s:machine = substitute(a:dirname,dirpat,'\3','') - let s:port = substitute(a:dirname,dirpat,'\4','') - let s:path = substitute(a:dirname,dirpat,'\5','') - let s:fname = substitute(a:dirname,'^.*/\ze.','','') - -" call Decho("set up s:method <".s:method .">") -" call Decho("set up s:user <".s:user .">") -" call Decho("set up s:machine<".s:machine.">") -" call Decho("set up s:port <".s:port.">") -" call Decho("set up s:path <".s:path .">") -" call Decho("set up s:fname <".s:fname .">") - -" call Dret("s:RemotePathAnalysis") -endfun - -" --------------------------------------------------------------------- -" s:RemoteSystem: runs a command on a remote host using ssh {{{2 -" Returns status -" Runs system() on -" [cd REMOTEDIRPATH;] a:cmd -" Note that it doesn't do shellescape(a:cmd)! -fun! s:RemoteSystem(cmd) -" call Dfunc("s:RemoteSystem(cmd<".a:cmd.">)") - if !executable(g:netrw_ssh_cmd) - call netrw#ErrorMsg(s:ERROR,"g:netrw_ssh_cmd<".g:netrw_ssh_cmd."> is not executable!",52) - elseif !exists("b:netrw_curdir") - call netrw#ErrorMsg(s:ERROR,"for some reason b:netrw_curdir doesn't exist!",53) - else - let cmd = s:MakeSshCmd(g:netrw_ssh_cmd." USEPORT HOSTNAME") - let remotedir= substitute(b:netrw_curdir,'^.*//[^/]\+/\(.*\)$','\1','') - if remotedir != "" - let cmd= cmd.' cd '.shellescape(remotedir).";" - else - let cmd= cmd.' ' - endif - let cmd= cmd.a:cmd -" call Decho("call system(".cmd.")") - let ret= system(cmd) - endif -" call Dret("s:RemoteSystem ".ret) - return ret -endfun - -" --------------------------------------------------------------------- -" s:RestoreWinVars: (used by Explore() and NetrwSplit()) {{{2 -fun! s:RestoreWinVars() -" call Dfunc("s:RestoreWinVars()") - if exists("s:bannercnt") |let w:netrw_bannercnt = s:bannercnt |unlet s:bannercnt |endif - if exists("s:col") |let w:netrw_col = s:col |unlet s:col |endif - if exists("s:curdir") |let w:netrw_curdir = s:curdir |unlet s:curdir |endif - if exists("s:explore_bufnr") |let w:netrw_explore_bufnr = s:explore_bufnr |unlet s:explore_bufnr |endif - if exists("s:explore_indx") |let w:netrw_explore_indx = s:explore_indx |unlet s:explore_indx |endif - if exists("s:explore_line") |let w:netrw_explore_line = s:explore_line |unlet s:explore_line |endif - if exists("s:explore_listlen")|let w:netrw_explore_listlen = s:explore_listlen|unlet s:explore_listlen|endif - if exists("s:explore_list") |let w:netrw_explore_list = s:explore_list |unlet s:explore_list |endif - if exists("s:explore_mtchcnt")|let w:netrw_explore_mtchcnt = s:explore_mtchcnt|unlet s:explore_mtchcnt|endif - if exists("s:fpl") |let w:netrw_fpl = s:fpl |unlet s:fpl |endif - if exists("s:hline") |let w:netrw_hline = s:hline |unlet s:hline |endif - if exists("s:line") |let w:netrw_line = s:line |unlet s:line |endif - if exists("s:liststyle") |let w:netrw_liststyle = s:liststyle |unlet s:liststyle |endif - if exists("s:method") |let w:netrw_method = s:method |unlet s:method |endif - if exists("s:prvdir") |let w:netrw_prvdir = s:prvdir |unlet s:prvdir |endif - if exists("s:treedict") |let w:netrw_treedict = s:treedict |unlet s:treedict |endif - if exists("s:treetop") |let w:netrw_treetop = s:treetop |unlet s:treetop |endif - if exists("s:winnr") |let w:netrw_winnr = s:winnr |unlet s:winnr |endif -" call Dret("s:RestoreWinVars") -endfun - -" --------------------------------------------------------------------- -" s:Rexplore: implements returning from a buffer to a netrw directory {{{2 -" -" s:SetRexDir() sets up <2-leftmouse> maps (if g:netrw_retmap -" is true) and a command, :Rexplore, which call this function. -" -" s:nbcd_curpos_{bufnr('%')} is set up by s:NetrwBrowseChgDir() -fun! s:NetrwRexplore(islocal,dirname) -" call Dfunc("s:NetrwRexplore(islocal=".a:islocal." dirname<".a:dirname.">)") - if a:islocal - call netrw#LocalBrowseCheck(a:dirname) - else - call s:NetrwBrowse(0,a:dirname) - endif - if exists("s:nbcd_curpos_{bufnr('%')}") - call netrw#NetrwRestorePosn(s:nbcd_curpos_{bufnr('%')}) - unlet s:nbcd_curpos_{bufnr('%')} - endif -" call Dret("s:NetrwRexplore") -endfun - -" --------------------------------------------------------------------- -" s:SaveBufVars: {{{2 -fun! s:SaveBufVars() -" call Dfunc("s:SaveBufVars()") - - if exists("b:netrw_curdir") |let s:netrw_curdir = b:netrw_curdir |endif - if exists("b:netrw_lastfile") |let s:netrw_lastfile = b:netrw_lastfile |endif - if exists("b:netrw_method") |let s:netrw_method = b:netrw_method |endif - if exists("b:netrw_fname") |let s:netrw_fname = b:netrw_fname |endif - if exists("b:netrw_machine") |let s:netrw_machine = b:netrw_machine |endif - if exists("b:netrw_browser_active")|let s:netrw_browser_active = b:netrw_browser_active|endif - -" call Dret("s:SaveBufVars") -endfun - -" --------------------------------------------------------------------- -" s:SaveWinVars: (used by Explore() and NetrwSplit()) {{{2 -fun! s:SaveWinVars() -" call Dfunc("s:SaveWinVars()") - if exists("w:netrw_bannercnt") |let s:bannercnt = w:netrw_bannercnt |endif - if exists("w:netrw_col") |let s:col = w:netrw_col |endif - if exists("w:netrw_curdir") |let s:curdir = w:netrw_curdir |endif - if exists("w:netrw_explore_bufnr") |let s:explore_bufnr = w:netrw_explore_bufnr |endif - if exists("w:netrw_explore_indx") |let s:explore_indx = w:netrw_explore_indx |endif - if exists("w:netrw_explore_line") |let s:explore_line = w:netrw_explore_line |endif - if exists("w:netrw_explore_listlen")|let s:explore_listlen = w:netrw_explore_listlen|endif - if exists("w:netrw_explore_list") |let s:explore_list = w:netrw_explore_list |endif - if exists("w:netrw_explore_mtchcnt")|let s:explore_mtchcnt = w:netrw_explore_mtchcnt|endif - if exists("w:netrw_fpl") |let s:fpl = w:netrw_fpl |endif - if exists("w:netrw_hline") |let s:hline = w:netrw_hline |endif - if exists("w:netrw_line") |let s:line = w:netrw_line |endif - if exists("w:netrw_liststyle") |let s:liststyle = w:netrw_liststyle |endif - if exists("w:netrw_method") |let s:method = w:netrw_method |endif - if exists("w:netrw_prvdir") |let s:prvdir = w:netrw_prvdir |endif - if exists("w:netrw_treedict") |let s:treedict = w:netrw_treedict |endif - if exists("w:netrw_treetop") |let s:treetop = w:netrw_treetop |endif - if exists("w:netrw_winnr") |let s:winnr = w:netrw_winnr |endif -" call Dret("s:SaveWinVars") -endfun - -" --------------------------------------------------------------------- -" s:SetBufWinVars: (used by NetrwBrowse() and LocalBrowseCheck()) {{{2 -" To allow separate windows to have their own activities, such as -" Explore **/pattern, several variables have been made window-oriented. -" However, when the user splits a browser window (ex: ctrl-w s), these -" variables are not inherited by the new window. SetBufWinVars() and -" UseBufWinVars() get around that. -fun! s:SetBufWinVars() -" call Dfunc("s:SetBufWinVars()") - if exists("w:netrw_liststyle") |let b:netrw_liststyle = w:netrw_liststyle |endif - if exists("w:netrw_bannercnt") |let b:netrw_bannercnt = w:netrw_bannercnt |endif - if exists("w:netrw_method") |let b:netrw_method = w:netrw_method |endif - if exists("w:netrw_prvdir") |let b:netrw_prvdir = w:netrw_prvdir |endif - if exists("w:netrw_explore_indx") |let b:netrw_explore_indx = w:netrw_explore_indx |endif - if exists("w:netrw_explore_listlen")|let b:netrw_explore_listlen= w:netrw_explore_listlen|endif - if exists("w:netrw_explore_mtchcnt")|let b:netrw_explore_mtchcnt= w:netrw_explore_mtchcnt|endif - if exists("w:netrw_explore_bufnr") |let b:netrw_explore_bufnr = w:netrw_explore_bufnr |endif - if exists("w:netrw_explore_line") |let b:netrw_explore_line = w:netrw_explore_line |endif - if exists("w:netrw_explore_list") |let b:netrw_explore_list = w:netrw_explore_list |endif -" call Dret("s:SetBufWinVars") -endfun - -" --------------------------------------------------------------------- -" s:SetRexDir: set directory for :Rexplore {{{2 -fun! s:SetRexDir(islocal,dirname) -" call Dfunc("s:SetRexDir(islocal=".a:islocal." dirname<".a:dirname.">)") - " set up Rex and leftmouse-double-click - if a:islocal - exe 'com! Rexplore call s:NetrwRexplore(1,"'.escape(a:dirname,'"\').'")' - if g:netrw_retmap - silent! unmap <2-leftmouse> - if !hasmapto("NetrwReturn") - nmap <2-leftmouse> NetrwReturn - endif - let dir = escape(a:dirname, s:netrw_map_escape) - exe 'nnoremap NetrwReturn :call NetrwRexplore(1,"'.dir.'")' - endif - else - exe 'com! Rexplore call s:NetrwRexplore(0,"'.escape(a:dirname,'"\').'")' - if g:netrw_retmap - silent! unmap <2-leftmouse> - if !hasmapto("NetrwReturn") - nmap <2-leftmouse> NetrwReturn - endif - let dir = escape(a:dirname, s:netrw_map_escape) - exe 'nnoremap NetrwReturn :call NetrwRexplore(0,"'.dir.'")' - endif - endif -" call Dret("s:SetRexDir") -endfun - -" --------------------------------------------------------------------- -" s:Strlen: this function returns the length of a string, even if its {{{2 -" using two-byte etc characters. -" Currently, its only used if g:Align_xstrlen is set to a -" nonzero value. Solution from Nicolai Weibull, vim docs -" (:help strlen()), Tony Mechelynck, and my own invention. -fun! s:Strlen(x) -" call Dfunc("s:Strlen(x<".a:x.">") - if g:netrw_xstrlen == 1 - " number of codepoints (Latin a + combining circumflex is two codepoints) - " (comment from TM, solution from NW) - let ret= strlen(substitute(a:x,'.','c','g')) - - elseif g:netrw_xstrlen == 2 - " number of spacing codepoints (Latin a + combining circumflex is one spacing - " codepoint; a hard tab is one; wide and narrow CJK are one each; etc.) - " (comment from TM, solution from TM) - let ret=strlen(substitute(a:x, '.\Z', 'x', 'g')) - - elseif g:netrw_xstrlen == 3 - " virtual length (counting, for instance, tabs as anything between 1 and - " 'tabstop', wide CJK as 2 rather than 1, Arabic alif as zero when immediately - " preceded by lam, one otherwise, etc.) - " (comment from TM, solution from me) - let modkeep= &mod - exe "norm! o\" - call setline(line("."),a:x) - let ret= virtcol("$") - 1 - d - let &mod= modkeep - - else - " at least give a decent default - ret= strlen(a:x) - endif -" call Dret("s:Strlen ".ret) - return ret -endfun - -" --------------------------------------------------------------------- -" s:TreeListMove: {{{2 -fun! s:TreeListMove(dir) -" call Dfunc("s:TreeListMove(dir<".a:dir.">)") - let curline = getline('.') - let prvline = (line(".") > 1)? getline(line(".")-1) : '' - let nxtline = (line(".") < line("$"))? getline(line(".")+1) : '' - let curindent= substitute(curline,'^\([| ]*\).\{-}$','\1','') - let indentm1 = substitute(curindent,'^| ','','') -" call Decho("prvline <".prvline."> #".line(".")-1) -" call Decho("curline <".curline."> #".line(".")) -" call Decho("nxtline <".nxtline."> #".line(".")+1) -" call Decho("curindent<".curindent.">") -" call Decho("indentm1 <".indentm1.">") - - if curline !~ '/$' -" call Decho('regfile') - if a:dir == '[' && prvline != '' - norm! 0 - let nl = search('^'.indentm1.'[^|]','bWe') " search backwards from regular file -" call Decho("regfile srch back: ".nl) - elseif a:dir == ']' && nxtline != '' - norm! $ - let nl = search('^'.indentm1.'[^|]','We') " search forwards from regular file -" call Decho("regfile srch fwd: ".nl) - endif - - elseif a:dir == '[' && prvline != '' - norm! 0 - let curline= line(".") - let nl = search('^'.curindent.'[^|]','bWe') " search backwards From directory, same indentation -" call Decho("dir srch back ind: ".nl) - if nl != 0 - if line(".") == curline-1 - let nl= search('^'.indentm1.'[^|]','bWe') " search backwards from directory, indentation - 1 -" call Decho("dir srch back ind-1: ".nl) - endif - endif - - elseif a:dir == ']' && nxtline != '' - norm! $ - let curline = line(".") - let nl = search('^'.curindent.'[^|]','We') " search forwards from directory, same indentation -" call Decho("dir srch fwd ind: ".nl) - if nl != 0 - if line(".") == curline+1 - let nl= search('^'.indentm1.'[^|]','We') " search forwards from directory, indentation - 1 -" call Decho("dir srch fwd ind-1: ".nl) - endif - endif - - endif - -" call Dret("s:TreeListMove") -endfun - -" --------------------------------------------------------------------- -" s:UpdateBuffersMenu: does emenu Buffers.Refresh (but due to locale, the menu item may not be called that) {{{2 -" The Buffers.Refresh menu calls s:BMShow(); unfortunately, that means that that function -" can't be called except via emenu. But due to locale, that menu line may not be called -" Buffers.Refresh; hence, s:NetrwBMShow() utilizes a "cheat" to call that function anyway. -fun! s:UpdateBuffersMenu() -" call Dfunc("s:UpdateBuffersMenu()") - if has("gui") && has("menu") && has("gui_running") && &go =~ 'm' - try - silent emenu Buffers.Refresh\ menu - catch /^Vim\%((\a\+)\)\=:E/ - let v:errmsg= "" - silent call s:NetrwBMShow() - endtry - endif -" call Dret("s:UpdateBuffersMenu") -endfun - -" --------------------------------------------------------------------- -" s:UseBufWinVars: (used by NetrwBrowse() and LocalBrowseCheck() {{{2 -" Matching function to BufferWinVars() -fun! s:UseBufWinVars() -" call Dfunc("s:UseBufWinVars()") - if exists("b:netrw_liststyle") && !exists("w:netrw_liststyle") |let w:netrw_liststyle = b:netrw_liststyle |endif - if exists("b:netrw_bannercnt") && !exists("w:netrw_bannercnt") |let w:netrw_bannercnt = b:netrw_bannercnt |endif - if exists("b:netrw_method") && !exists("w:netrw_method") |let w:netrw_method = b:netrw_method |endif - if exists("b:netrw_prvdir") && !exists("w:netrw_prvdir") |let w:netrw_prvdir = b:netrw_prvdir |endif - if exists("b:netrw_explore_indx") && !exists("w:netrw_explore_indx") |let w:netrw_explore_indx = b:netrw_explore_indx |endif - if exists("b:netrw_explore_listlen") && !exists("w:netrw_explore_listlen")|let w:netrw_explore_listlen = b:netrw_explore_listlen|endif - if exists("b:netrw_explore_mtchcnt") && !exists("w:netrw_explore_mtchcnt")|let w:netrw_explore_mtchcnt = b:netrw_explore_mtchcnt|endif - if exists("b:netrw_explore_bufnr") && !exists("w:netrw_explore_bufnr") |let w:netrw_explore_bufnr = b:netrw_explore_bufnr |endif - if exists("b:netrw_explore_line") && !exists("w:netrw_explore_line") |let w:netrw_explore_line = b:netrw_explore_line |endif - if exists("b:netrw_explore_list") && !exists("w:netrw_explore_list") |let w:netrw_explore_list = b:netrw_explore_list |endif -" call Dret("s:UseBufWinVars") -endfun - -" --------------------------------------------------------------------- -" s:WinPath: {{{2 -fun! s:WinPath(path) -" call Dfunc("s:WinPath(path<".a:path.">)") - if !g:netrw_cygwin && (has("win32") || has("win95") || has("win64") || has("win16")) - " remove trailing slash (Win95) - let path = substitute(a:path, '\(\\\|/\)$', '', 'g') - " remove escaped spaces - let path = substitute(path, '\ ', ' ', 'g') - " convert slashes to backslashes - let path = substitute(path, '/', '\', 'g') - else - let path= a:path - endif -" call Dret("s:WinPath <".path.">") - return path -endfun - -" --------------------------------------------------------------------- -" Settings Restoration: {{{2 -let &cpo= s:keepcpo -unlet s:keepcpo - -" ------------------------------------------------------------------------ -" Modelines: {{{1 -" vim:ts=8 fdm=marker diff --git a/share/vim/vim72/autoload/netrwFileHandlers.vim b/share/vim/vim72/autoload/netrwFileHandlers.vim deleted file mode 100644 index 5fb05bad3e..0000000000 --- a/share/vim/vim72/autoload/netrwFileHandlers.vim +++ /dev/null @@ -1,355 +0,0 @@ -" netrwFileHandlers: contains various extension-based file handlers for -" netrw's browsers' x command ("eXecute launcher") -" Author: Charles E. Campbell, Jr. -" Date: May 30, 2006 -" Version: 9 -" Copyright: Copyright (C) 1999-2005 Charles E. Campbell, Jr. {{{1 -" Permission is hereby granted to use and distribute this code, -" with or without modifications, provided that this copyright -" notice is copied with it. Like anything else that's free, -" netrwFileHandlers.vim is provided *as is* and comes with no -" warranty of any kind, either expressed or implied. In no -" event will the copyright holder be liable for any damages -" resulting from the use of this software. -" -" Rom 6:23 (WEB) For the wages of sin is death, but the free gift of God {{{1 -" is eternal life in Christ Jesus our Lord. - -" --------------------------------------------------------------------- -" Load Once: {{{1 -if exists("g:loaded_netrwFileHandlers") || &cp - finish -endif -let s:keepcpo= &cpo -set cpo&vim -let g:loaded_netrwFileHandlers= "v9" - -" --------------------------------------------------------------------- -" netrwFileHandlers#Invoke: {{{1 -fun! netrwFileHandlers#Invoke(exten,fname) -" call Dfunc("netrwFileHandlers#Invoke(exten<".a:exten."> fname<".a:fname.">)") - let fname= a:fname - " list of supported special characters. Consider rcs,v --- that can be - " supported with a NFH_rcsCOMMAv() handler - if a:fname =~ '[@:,$!=\-+%?;~]' - let specials= { -\ '@' : 'AT', -\ ':' : 'COLON', -\ ',' : 'COMMA', -\ '$' : 'DOLLAR', -\ '!' : 'EXCLAMATION', -\ '=' : 'EQUAL', -\ '-' : 'MINUS', -\ '+' : 'PLUS', -\ '%' : 'PERCENT', -\ '?' : 'QUESTION', -\ ';' : 'SEMICOLON', -\ '~' : 'TILDE'} - let fname= substitute(a:fname,'[@:,$!=\-+%?;~]','\=specials[submatch(0)]','ge') -" call Decho('fname<'.fname.'> done with dictionary') - endif - - if a:exten != "" && exists("*NFH_".a:exten) - " support user NFH_*() functions -" call Decho("let ret= netrwFileHandlers#NFH_".a:exten.'("'.fname.'")') - exe "let ret= NFH_".a:exten.'("'.fname.'")' - elseif a:exten != "" && exists("*s:NFH_".a:exten) - " use builtin-NFH_*() functions -" call Decho("let ret= netrwFileHandlers#NFH_".a:exten.'("'.fname.'")') - exe "let ret= s:NFH_".a:exten.'("'.fname.'")' - endif - -" call Dret("netrwFileHandlers#Invoke 0 : ret=".ret) - return 0 -endfun - -" --------------------------------------------------------------------- -" s:NFH_html: handles html when the user hits "x" when the {{{1 -" cursor is atop a *.html file -fun! s:NFH_html(pagefile) -" call Dfunc("s:NFH_html(".a:pagefile.")") - - let page= substitute(a:pagefile,'^','file://','') - - if executable("mozilla") -" call Decho("executing !mozilla ".page) - exe "!mozilla ".g:netrw_shq.page.g:netrw_shq - elseif executable("netscape") -" call Decho("executing !netscape ".page) - exe "!netscape ".g:netrw_shq..page.g:netrw_shq - else -" call Dret("s:NFH_html 0") - return 0 - endif - -" call Dret("s:NFH_html 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_htm: handles html when the user hits "x" when the {{{1 -" cursor is atop a *.htm file -fun! s:NFH_htm(pagefile) -" call Dfunc("s:NFH_htm(".a:pagefile.")") - - let page= substitute(a:pagefile,'^','file://','') - - if executable("mozilla") -" call Decho("executing !mozilla ".page) - exe "!mozilla ".g:netrw_shq.page.g:netrw_shq - elseif executable("netscape") -" call Decho("executing !netscape ".page) - exe "!netscape ".g:netrw_shq.page.g:netrw_shq - else -" call Dret("s:NFH_htm 0") - return 0 - endif - -" call Dret("s:NFH_htm 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_jpg: {{{1 -fun! s:NFH_jpg(jpgfile) -" call Dfunc("s:NFH_jpg(jpgfile<".a:jpgfile.">)") - - if executable("gimp") - exe "silent! !gimp -s ".g:netrw_shq.a:jpgfile.g:netrw_shq - elseif executable(expand("$SystemRoot")."/SYSTEM32/MSPAINT.EXE") -" call Decho("silent! !".expand("$SystemRoot")."/SYSTEM32/MSPAINT ".escape(a:jpgfile," []|'")) - exe "!".expand("$SystemRoot")."/SYSTEM32/MSPAINT ".g:netrw_shq.a:jpgfile.g:netrw_shq - else -" call Dret("s:NFH_jpg 0") - return 0 - endif - -" call Dret("s:NFH_jpg 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_gif: {{{1 -fun! s:NFH_gif(giffile) -" call Dfunc("s:NFH_gif(giffile<".a:giffile.">)") - - if executable("gimp") - exe "silent! !gimp -s ".g:netrw_shq.a:giffile.g:netrw_shq - elseif executable(expand("$SystemRoot")."/SYSTEM32/MSPAINT.EXE") - exe "silent! !".expand("$SystemRoot")."/SYSTEM32/MSPAINT ".g:netrw_shq.a:giffile.g:netrw_shq - else -" call Dret("s:NFH_gif 0") - return 0 - endif - -" call Dret("s:NFH_gif 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_png: {{{1 -fun! s:NFH_png(pngfile) -" call Dfunc("s:NFH_png(pngfile<".a:pngfile.">)") - - if executable("gimp") - exe "silent! !gimp -s ".g:netrw_shq.a:pngfile.g:netrw_shq - elseif executable(expand("$SystemRoot")."/SYSTEM32/MSPAINT.EXE") - exe "silent! !".expand("$SystemRoot")."/SYSTEM32/MSPAINT ".g:netrw_shq.a:pngfile.g:netrw_shq - else -" call Dret("s:NFH_png 0") - return 0 - endif - -" call Dret("s:NFH_png 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_pnm: {{{1 -fun! s:NFH_pnm(pnmfile) -" call Dfunc("s:NFH_pnm(pnmfile<".a:pnmfile.">)") - - if executable("gimp") - exe "silent! !gimp -s ".g:netrw_shq.a:pnmfile.g:netrw_shq - elseif executable(expand("$SystemRoot")."/SYSTEM32/MSPAINT.EXE") - exe "silent! !".expand("$SystemRoot")."/SYSTEM32/MSPAINT ".g:netrw_shq.a:pnmfile.g:netrw_shq - else -" call Dret("s:NFH_pnm 0") - return 0 - endif - -" call Dret("s:NFH_pnm 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_bmp: visualize bmp files {{{1 -fun! s:NFH_bmp(bmpfile) -" call Dfunc("s:NFH_bmp(bmpfile<".a:bmpfile.">)") - - if executable("gimp") - exe "silent! !gimp -s ".a:bmpfile - elseif executable(expand("$SystemRoot")."/SYSTEM32/MSPAINT.EXE") - exe "silent! !".expand("$SystemRoot")."/SYSTEM32/MSPAINT ".g:netrw_shq.a:bmpfile.g:netrw_shq - else -" call Dret("s:NFH_bmp 0") - return 0 - endif - -" call Dret("s:NFH_bmp 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_pdf: visualize pdf files {{{1 -fun! s:NFH_pdf(pdf) -" call Dfunc("s:NFH_pdf(pdf<".a:pdf.">)") - if executable("gs") - exe 'silent! !gs '.g:netrw_shq.a:pdf.g:netrw_shq - elseif executable("pdftotext") - exe 'silent! pdftotext -nopgbrk '.g:netrw_shq.a:pdf.g:netrw_shq - else -" call Dret("s:NFH_pdf 0") - return 0 - endif - -" call Dret("s:NFH_pdf 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_doc: visualize doc files {{{1 -fun! s:NFH_doc(doc) -" call Dfunc("s:NFH_doc(doc<".a:doc.">)") - - if executable("oowriter") - exe 'silent! !oowriter '.g:netrw_shq.a:doc.g:netrw_shq - redraw! - else -" call Dret("s:NFH_doc 0") - return 0 - endif - -" call Dret("s:NFH_doc 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_sxw: visualize sxw files {{{1 -fun! s:NFH_sxw(sxw) -" call Dfunc("s:NFH_sxw(sxw<".a:sxw.">)") - - if executable("oowriter") - exe 'silent! !oowriter '.g:netrw_shq.a:sxw.g:netrw_shq - redraw! - else -" call Dret("s:NFH_sxw 0") - return 0 - endif - -" call Dret("s:NFH_sxw 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_xls: visualize xls files {{{1 -fun! s:NFH_xls(xls) -" call Dfunc("s:NFH_xls(xls<".a:xls.">)") - - if executable("oocalc") - exe 'silent! !oocalc '.g:netrw_shq.a:xls.g:netrw_shq - redraw! - else -" call Dret("s:NFH_xls 0") - return 0 - endif - -" call Dret("s:NFH_xls 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_ps: handles PostScript files {{{1 -fun! s:NFH_ps(ps) -" call Dfunc("s:NFH_ps(ps<".a:ps.">)") - if executable("gs") -" call Decho("exe silent! !gs ".a:ps) - exe "silent! !gs ".g:netrw_shq.a:ps.g:netrw_shq - redraw! - elseif executable("ghostscript") -" call Decho("exe silent! !ghostscript ".a:ps) - exe "silent! !ghostscript ".g:netrw_shq.a:ps.g:netrw_shq - redraw! - elseif executable("gswin32") -" call Decho("exe silent! !gswin32 ".g:netrw_shq.a:ps.g:netrw_shq) - exe "silent! !gswin32 ".g:netrw_shq.a:ps.g:netrw_shq - redraw! - else -" call Dret("s:NFH_ps 0") - return 0 - endif - -" call Dret("s:NFH_ps 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_eps: handles encapsulated PostScript files {{{1 -fun! s:NFH_eps(eps) -" call Dfunc("s:NFH_eps()") - if executable("gs") - exe "silent! !gs ".g:netrw_shq.a:eps.g:netrw_shq - redraw! - elseif executable("ghostscript") - exe "silent! !ghostscript ".g:netrw_shq.a:eps.g:netrw_shq - redraw! - elseif executable("ghostscript") - exe "silent! !ghostscript ".g:netrw_shq.a:eps.g:netrw_shq - redraw! - elseif executable("gswin32") - exe "silent! !gswin32 ".g:netrw_shq.a:eps.g:netrw_shq - redraw! - else -" call Dret("s:NFH_eps 0") - return 0 - endif -" call Dret("s:NFH_eps 0") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_fig: handles xfig files {{{1 -fun! s:NFH_fig(fig) -" call Dfunc("s:NFH_fig()") - if executable("xfig") - exe "silent! !xfig ".a:fig - redraw! - else -" call Dret("s:NFH_fig 0") - return 0 - endif - -" call Dret("s:NFH_fig 1") - return 1 -endfun - -" --------------------------------------------------------------------- -" s:NFH_obj: handles tgif's obj files {{{1 -fun! s:NFH_obj(obj) -" call Dfunc("s:NFH_obj()") - if has("unix") && executable("tgif") - exe "silent! !tgif ".a:obj - redraw! - else -" call Dret("s:NFH_obj 0") - return 0 - endif - -" call Dret("s:NFH_obj 1") - return 1 -endfun - -let &cpo= s:keepcpo -" --------------------------------------------------------------------- -" Modelines: {{{1 -" vim: fdm=marker diff --git a/share/vim/vim72/autoload/netrwSettings.vim b/share/vim/vim72/autoload/netrwSettings.vim deleted file mode 100644 index c0704d4ef4..0000000000 --- a/share/vim/vim72/autoload/netrwSettings.vim +++ /dev/null @@ -1,200 +0,0 @@ -" netrwSettings.vim: makes netrw settings simpler -" Date: Jul 02, 2008 -" Maintainer: Charles E Campbell, Jr -" Version: 12 -" Copyright: Copyright (C) 1999-2007 Charles E. Campbell, Jr. {{{1 -" Permission is hereby granted to use and distribute this code, -" with or without modifications, provided that this copyright -" notice is copied with it. Like anything else that's free, -" netrwSettings.vim is provided *as is* and comes with no -" warranty of any kind, either expressed or implied. By using -" this plugin, you agree that in no event will the copyright -" holder be liable for any damages resulting from the use -" of this software. -" -" Mat 4:23 (WEB) Jesus went about in all Galilee, teaching in their {{{1 -" synagogues, preaching the gospel of the kingdom, and healing -" every disease and every sickness among the people. -" Load Once: {{{1 -if exists("g:loaded_netrwSettings") || &cp - finish -endif -let g:loaded_netrwSettings = "v12" - -" --------------------------------------------------------------------- -" NetrwSettings: {{{1 -fun! netrwSettings#NetrwSettings() - " this call is here largely just to insure that netrw has been loaded - call netrw#NetrwSavePosn() - if !exists("g:loaded_netrw") - echohl WarningMsg | echomsg "***sorry*** netrw needs to be loaded prior to using NetrwSettings" | echohl None - return - endif - - above wincmd s - enew - setlocal noswapfile bh=wipe - set ft=vim - file Netrw\ Settings - - " these variables have the following default effects when they don't - " exist (ie. have not been set by the user in his/her .vimrc) - if !exists("g:netrw_liststyle") - let g:netrw_liststyle= 0 - let g:netrw_list_cmd= "ssh HOSTNAME ls -FLa" - endif - if !exists("g:netrw_silent") - let g:netrw_silent= 0 - endif - if !exists("g:netrw_use_nt_rcp") - let g:netrw_use_nt_rcp= 0 - endif - if !exists("g:netrw_ftp") - let g:netrw_ftp= 0 - endif - if !exists("g:netrw_ignorenetrc") - let g:netrw_ignorenetrc= 0 - endif - - put ='+ ---------------------------------------------' - put ='+ NetrwSettings: by Charles E. Campbell, Jr.' - put ='+ Press with cursor atop any line for help' - put ='+ ---------------------------------------------' - let s:netrw_settings_stop= line(".") - - put ='' - put ='+ Netrw Protocol Commands' - put = 'let g:netrw_dav_cmd = '.g:netrw_dav_cmd - put = 'let g:netrw_fetch_cmd = '.g:netrw_fetch_cmd - put = 'let g:netrw_ftp_cmd = '.g:netrw_ftp_cmd - put = 'let g:netrw_http_cmd = '.g:netrw_http_cmd - put = 'let g:netrw_rcp_cmd = '.g:netrw_rcp_cmd - put = 'let g:netrw_rsync_cmd = '.g:netrw_rsync_cmd - put = 'let g:netrw_scp_cmd = '.g:netrw_scp_cmd - put = 'let g:netrw_sftp_cmd = '.g:netrw_sftp_cmd - put = 'let g:netrw_ssh_cmd = '.g:netrw_ssh_cmd - let s:netrw_protocol_stop= line(".") - put = '' - - put ='+Netrw Transfer Control' - put = 'let g:netrw_cygwin = '.g:netrw_cygwin - put = 'let g:netrw_ftp = '.g:netrw_ftp - put = 'let g:netrw_ftpmode = '.g:netrw_ftpmode - put = 'let g:netrw_ignorenetrc = '.g:netrw_ignorenetrc - put = 'let g:netrw_sshport = '.g:netrw_sshport - put = 'let g:netrw_use_nt_rcp = '.g:netrw_use_nt_rcp - put = 'let g:netrw_win95ftp = '.g:netrw_win95ftp - let s:netrw_xfer_stop= line(".") - put ='' - put ='+ Netrw Messages' - put ='let g:netrw_use_errorwindow = '.g:netrw_use_errorwindow - - put = '' - put ='+ Netrw Browser Control' - put = 'let g:netrw_alto = '.g:netrw_alto - put = 'let g:netrw_altv = '.g:netrw_altv - put = 'let g:netrw_browse_split = '.g:netrw_browse_split - if exists("g:netrw_browsex_viewer") - put = 'let g:netrw_browsex_viewer = '.g:netrw_browsex_viewer - else - put = 'let g:netrw_browsex_viewer = (not defined)' - endif - put = 'let g:netrw_compress = '.g:netrw_compress - let decompressline= line("$") - put ='let g:netrw_decompress...' - put = 'let g:netrw_dirhistmax = '.g:netrw_dirhistmax - put = 'let g:netrw_fastbrowse = '.g:netrw_fastbrowse - let fnameescline= line("$") - put = 'let g:netrw_fname_escape...' - put = 'let g:netrw_ftp_browse_reject = '.g:netrw_ftp_browse_reject - put = 'let g:netrw_ftp_list_cmd = '.g:netrw_ftp_list_cmd - put = 'let g:netrw_ftp_sizelist_cmd = '.g:netrw_ftp_sizelist_cmd - put = 'let g:netrw_ftp_timelist_cmd = '.g:netrw_ftp_timelist_cmd - let globescline= line("$") - put ='let g:netrw_glob_escape...' - put = 'let g:netrw_hide = '.g:netrw_hide - put = 'let g:netrw_keepdir = '.g:netrw_keepdir - put = 'let g:netrw_list_cmd = '.g:netrw_list_cmd - put = 'let g:netrw_list_hide = '.g:netrw_list_hide - put = 'let g:netrw_liststyle = '.g:netrw_liststyle - put = 'let g:netrw_localcopycmd = '.g:netrw_localcopycmd - put = 'let g:netrw_local_mkdir = '.g:netrw_local_mkdir - put = 'let g:netrw_localmovecmd = '.g:netrw_localmovecmd - put = 'let g:netrw_local_rmdir = '.g:netrw_local_rmdir - put = 'let g:netrw_maxfilenamelen = '.g:netrw_maxfilenamelen - put = 'let g:netrw_menu = '.g:netrw_menu - put = 'let g:netrw_mkdir_cmd = '.g:netrw_mkdir_cmd - put = 'let g:netrw_preview = '.g:netrw_preview - put = 'let g:netrw_rename_cmd = '.g:netrw_rename_cmd - put = 'let g:netrw_retmap = '.g:netrw_retmap - put = 'let g:netrw_rm_cmd = '.g:netrw_rm_cmd - put = 'let g:netrw_rmdir_cmd = '.g:netrw_rmdir_cmd - put = 'let g:netrw_rmf_cmd = '.g:netrw_rmf_cmd - put = 'let g:netrw_silent = '.g:netrw_silent - put = 'let g:netrw_sort_by = '.g:netrw_sort_by - put = 'let g:netrw_sort_direction = '.g:netrw_sort_direction - put = 'let g:netrw_sort_options = '.g:netrw_sort_options - put = 'let g:netrw_sort_sequence = '.g:netrw_sort_sequence - put = 'let g:netrw_special_syntax = '.g:netrw_special_syntax - put = 'let g:netrw_ssh_browse_reject = '.g:netrw_ssh_browse_reject - put = 'let g:netrw_scpport = '.g:netrw_scpport - put = 'let g:netrw_sshport = '.g:netrw_sshport - put = 'let g:netrw_timefmt = '.g:netrw_timefmt - let tmpfileescline= line("$") - put ='let g:netrw_tmpfile_escape...' - put = 'let g:netrw_use_noswf = '.g:netrw_use_noswf - put = 'let g:netrw_xstrlen = '.g:netrw_xstrlen - put = 'let g:netrw_winsize = '.g:netrw_winsize - - put ='' - put ='+ For help, place cursor on line and press ' - - 1d - silent %s/^+/"/e - res 99 - silent %s/= \([^0-9].*\)$/= '\1'/e - silent %s/= $/= ''/e - 1 - - call setline(decompressline,"let g:netrw_decompress = ".substitute(string(g:netrw_decompress),"^'\\(.*\\)'$",'\1','')) - call setline(fnameescline, "let g:netrw_fname_escape = '".escape(g:netrw_fname_escape,"'")."'") - call setline(globescline, "let g:netrw_glob_escape = '".escape(g:netrw_glob_escape,"'")."'") - call setline(tmpfileescline,"let g:netrw_tmpfile_escape = '".escape(g:netrw_tmpfile_escape,"'")."'") - - set nomod - - nmap :call NetrwSettingHelp() - nnoremap :call NetrwSettingHelp() - let tmpfile= tempname() - exe 'au BufWriteCmd Netrw\ Settings silent w! '.tmpfile.'|so '.tmpfile.'|call delete("'.tmpfile.'")|set nomod' -endfun - -" --------------------------------------------------------------------- -" NetrwSettingHelp: {{{2 -fun! NetrwSettingHelp() -" call Dfunc("NetrwSettingHelp()") - let curline = getline(".") - if curline =~ '=' - let varhelp = substitute(curline,'^\s*let ','','e') - let varhelp = substitute(varhelp,'\s*=.*$','','e') -" call Decho("trying help ".varhelp) - try - exe "he ".varhelp - catch /^Vim\%((\a\+)\)\=:E149/ - echo "***sorry*** no help available for <".varhelp.">" - endtry - elseif line(".") < s:netrw_settings_stop - he netrw-settings - elseif line(".") < s:netrw_protocol_stop - he netrw-externapp - elseif line(".") < s:netrw_xfer_stop - he netrw-variables - else - he netrw-browse-var - endif -" call Dret("NetrwSettingHelp") -endfun - -" --------------------------------------------------------------------- -" Modelines: {{{1 -" vim:ts=8 fdm=marker diff --git a/share/vim/vim72/autoload/pythoncomplete.vim b/share/vim/vim72/autoload/pythoncomplete.vim deleted file mode 100644 index 2f52f97e2e..0000000000 --- a/share/vim/vim72/autoload/pythoncomplete.vim +++ /dev/null @@ -1,599 +0,0 @@ -"pythoncomplete.vim - Omni Completion for python -" Maintainer: Aaron Griffin -" Version: 0.7 -" Last Updated: 19 Oct 2006 -" -" Changes -" TODO: -" User defined docstrings aren't handled right... -" 'info' item output can use some formatting work -" Add an "unsafe eval" mode, to allow for return type evaluation -" Complete basic syntax along with import statements -" i.e. "import url" -" Continue parsing on invalid line?? -" -" v 0.7 -" * Fixed function list sorting (_ and __ at the bottom) -" * Removed newline removal from docs. It appears vim handles these better in -" recent patches -" -" v 0.6: -" * Fixed argument completion -" * Removed the 'kind' completions, as they are better indicated -" with real syntax -" * Added tuple assignment parsing (whoops, that was forgotten) -" * Fixed import handling when flattening scope -" -" v 0.5: -" Yeah, I skipped a version number - 0.4 was never public. -" It was a bugfix version on top of 0.3. This is a complete -" rewrite. -" - -if !has('python') - echo "Error: Required vim compiled with +python" - finish -endif - -function! pythoncomplete#Complete(findstart, base) - "findstart = 1 when we need to get the text length - if a:findstart == 1 - let line = getline('.') - let idx = col('.') - while idx > 0 - let idx -= 1 - let c = line[idx] - if c =~ '\w' - continue - elseif ! c =~ '\.' - let idx = -1 - break - else - break - endif - endwhile - - return idx - "findstart = 0 when we need to return the list of completions - else - "vim no longer moves the cursor upon completion... fix that - let line = getline('.') - let idx = col('.') - let cword = '' - while idx > 0 - let idx -= 1 - let c = line[idx] - if c =~ '\w' || c =~ '\.' || c == '(' - let cword = c . cword - continue - elseif strlen(cword) > 0 || idx == 0 - break - endif - endwhile - execute "python vimcomplete('" . cword . "', '" . a:base . "')" - return g:pythoncomplete_completions - endif -endfunction - -function! s:DefPython() -python << PYTHONEOF -import sys, tokenize, cStringIO, types -from token import NAME, DEDENT, NEWLINE, STRING - -debugstmts=[] -def dbg(s): debugstmts.append(s) -def showdbg(): - for d in debugstmts: print "DBG: %s " % d - -def vimcomplete(context,match): - global debugstmts - debugstmts = [] - try: - import vim - def complsort(x,y): - try: - xa = x['abbr'] - ya = y['abbr'] - if xa[0] == '_': - if xa[1] == '_' and ya[0:2] == '__': - return xa > ya - elif ya[0:2] == '__': - return -1 - elif y[0] == '_': - return xa > ya - else: - return 1 - elif ya[0] == '_': - return -1 - else: - return xa > ya - except: - return 0 - cmpl = Completer() - cmpl.evalsource('\n'.join(vim.current.buffer),vim.eval("line('.')")) - all = cmpl.get_completions(context,match) - all.sort(complsort) - dictstr = '[' - # have to do this for double quoting - for cmpl in all: - dictstr += '{' - for x in cmpl: dictstr += '"%s":"%s",' % (x,cmpl[x]) - dictstr += '"icase":0},' - if dictstr[-1] == ',': dictstr = dictstr[:-1] - dictstr += ']' - #dbg("dict: %s" % dictstr) - vim.command("silent let g:pythoncomplete_completions = %s" % dictstr) - #dbg("Completion dict:\n%s" % all) - except vim.error: - dbg("VIM Error: %s" % vim.error) - -class Completer(object): - def __init__(self): - self.compldict = {} - self.parser = PyParser() - - def evalsource(self,text,line=0): - sc = self.parser.parse(text,line) - src = sc.get_code() - dbg("source: %s" % src) - try: exec(src) in self.compldict - except: dbg("parser: %s, %s" % (sys.exc_info()[0],sys.exc_info()[1])) - for l in sc.locals: - try: exec(l) in self.compldict - except: dbg("locals: %s, %s [%s]" % (sys.exc_info()[0],sys.exc_info()[1],l)) - - def _cleanstr(self,doc): - return doc.replace('"',' ').replace("'",' ') - - def get_arguments(self,func_obj): - def _ctor(obj): - try: return class_ob.__init__.im_func - except AttributeError: - for base in class_ob.__bases__: - rc = _find_constructor(base) - if rc is not None: return rc - return None - - arg_offset = 1 - if type(func_obj) == types.ClassType: func_obj = _ctor(func_obj) - elif type(func_obj) == types.MethodType: func_obj = func_obj.im_func - else: arg_offset = 0 - - arg_text='' - if type(func_obj) in [types.FunctionType, types.LambdaType]: - try: - cd = func_obj.func_code - real_args = cd.co_varnames[arg_offset:cd.co_argcount] - defaults = func_obj.func_defaults or '' - defaults = map(lambda name: "=%s" % name, defaults) - defaults = [""] * (len(real_args)-len(defaults)) + defaults - items = map(lambda a,d: a+d, real_args, defaults) - if func_obj.func_code.co_flags & 0x4: - items.append("...") - if func_obj.func_code.co_flags & 0x8: - items.append("***") - arg_text = (','.join(items)) + ')' - - except: - dbg("arg completion: %s: %s" % (sys.exc_info()[0],sys.exc_info()[1])) - pass - if len(arg_text) == 0: - # The doc string sometimes contains the function signature - # this works for alot of C modules that are part of the - # standard library - doc = func_obj.__doc__ - if doc: - doc = doc.lstrip() - pos = doc.find('\n') - if pos > 0: - sigline = doc[:pos] - lidx = sigline.find('(') - ridx = sigline.find(')') - if lidx > 0 and ridx > 0: - arg_text = sigline[lidx+1:ridx] + ')' - if len(arg_text) == 0: arg_text = ')' - return arg_text - - def get_completions(self,context,match): - dbg("get_completions('%s','%s')" % (context,match)) - stmt = '' - if context: stmt += str(context) - if match: stmt += str(match) - try: - result = None - all = {} - ridx = stmt.rfind('.') - if len(stmt) > 0 and stmt[-1] == '(': - result = eval(_sanitize(stmt[:-1]), self.compldict) - doc = result.__doc__ - if doc == None: doc = '' - args = self.get_arguments(result) - return [{'word':self._cleanstr(args),'info':self._cleanstr(doc)}] - elif ridx == -1: - match = stmt - all = self.compldict - else: - match = stmt[ridx+1:] - stmt = _sanitize(stmt[:ridx]) - result = eval(stmt, self.compldict) - all = dir(result) - - dbg("completing: stmt:%s" % stmt) - completions = [] - - try: maindoc = result.__doc__ - except: maindoc = ' ' - if maindoc == None: maindoc = ' ' - for m in all: - if m == "_PyCmplNoType": continue #this is internal - try: - dbg('possible completion: %s' % m) - if m.find(match) == 0: - if result == None: inst = all[m] - else: inst = getattr(result,m) - try: doc = inst.__doc__ - except: doc = maindoc - typestr = str(inst) - if doc == None or doc == '': doc = maindoc - - wrd = m[len(match):] - c = {'word':wrd, 'abbr':m, 'info':self._cleanstr(doc)} - if "function" in typestr: - c['word'] += '(' - c['abbr'] += '(' + self._cleanstr(self.get_arguments(inst)) - elif "method" in typestr: - c['word'] += '(' - c['abbr'] += '(' + self._cleanstr(self.get_arguments(inst)) - elif "module" in typestr: - c['word'] += '.' - elif "class" in typestr: - c['word'] += '(' - c['abbr'] += '(' - completions.append(c) - except: - i = sys.exc_info() - dbg("inner completion: %s,%s [stmt='%s']" % (i[0],i[1],stmt)) - return completions - except: - i = sys.exc_info() - dbg("completion: %s,%s [stmt='%s']" % (i[0],i[1],stmt)) - return [] - -class Scope(object): - def __init__(self,name,indent): - self.subscopes = [] - self.docstr = '' - self.locals = [] - self.parent = None - self.name = name - self.indent = indent - - def add(self,sub): - #print 'push scope: [%s@%s]' % (sub.name,sub.indent) - sub.parent = self - self.subscopes.append(sub) - return sub - - def doc(self,str): - """ Clean up a docstring """ - d = str.replace('\n',' ') - d = d.replace('\t',' ') - while d.find(' ') > -1: d = d.replace(' ',' ') - while d[0] in '"\'\t ': d = d[1:] - while d[-1] in '"\'\t ': d = d[:-1] - self.docstr = d - - def local(self,loc): - if not self._hasvaralready(loc): - self.locals.append(loc) - - def copy_decl(self,indent=0): - """ Copy a scope's declaration only, at the specified indent level - not local variables """ - return Scope(self.name,indent) - - def _hasvaralready(self,test): - "Convienance function... keep out duplicates" - if test.find('=') > -1: - var = test.split('=')[0].strip() - for l in self.locals: - if l.find('=') > -1 and var == l.split('=')[0].strip(): - return True - return False - - def get_code(self): - # we need to start with this, to fix up broken completions - # hopefully this name is unique enough... - str = '"""'+self.docstr+'"""\n' - for l in self.locals: - if l.startswith('import'): str += l+'\n' - str += 'class _PyCmplNoType:\n def __getattr__(self,name):\n return None\n' - for sub in self.subscopes: - str += sub.get_code() - for l in self.locals: - if not l.startswith('import'): str += l+'\n' - - return str - - def pop(self,indent): - #print 'pop scope: [%s] to [%s]' % (self.indent,indent) - outer = self - while outer.parent != None and outer.indent >= indent: - outer = outer.parent - return outer - - def currentindent(self): - #print 'parse current indent: %s' % self.indent - return ' '*self.indent - - def childindent(self): - #print 'parse child indent: [%s]' % (self.indent+1) - return ' '*(self.indent+1) - -class Class(Scope): - def __init__(self, name, supers, indent): - Scope.__init__(self,name,indent) - self.supers = supers - def copy_decl(self,indent=0): - c = Class(self.name,self.supers,indent) - for s in self.subscopes: - c.add(s.copy_decl(indent+1)) - return c - def get_code(self): - str = '%sclass %s' % (self.currentindent(),self.name) - if len(self.supers) > 0: str += '(%s)' % ','.join(self.supers) - str += ':\n' - if len(self.docstr) > 0: str += self.childindent()+'"""'+self.docstr+'"""\n' - if len(self.subscopes) > 0: - for s in self.subscopes: str += s.get_code() - else: - str += '%spass\n' % self.childindent() - return str - - -class Function(Scope): - def __init__(self, name, params, indent): - Scope.__init__(self,name,indent) - self.params = params - def copy_decl(self,indent=0): - return Function(self.name,self.params,indent) - def get_code(self): - str = "%sdef %s(%s):\n" % \ - (self.currentindent(),self.name,','.join(self.params)) - if len(self.docstr) > 0: str += self.childindent()+'"""'+self.docstr+'"""\n' - str += "%spass\n" % self.childindent() - return str - -class PyParser: - def __init__(self): - self.top = Scope('global',0) - self.scope = self.top - - def _parsedotname(self,pre=None): - #returns (dottedname, nexttoken) - name = [] - if pre == None: - tokentype, token, indent = self.next() - if tokentype != NAME and token != '*': - return ('', token) - else: token = pre - name.append(token) - while True: - tokentype, token, indent = self.next() - if token != '.': break - tokentype, token, indent = self.next() - if tokentype != NAME: break - name.append(token) - return (".".join(name), token) - - def _parseimportlist(self): - imports = [] - while True: - name, token = self._parsedotname() - if not name: break - name2 = '' - if token == 'as': name2, token = self._parsedotname() - imports.append((name, name2)) - while token != "," and "\n" not in token: - tokentype, token, indent = self.next() - if token != ",": break - return imports - - def _parenparse(self): - name = '' - names = [] - level = 1 - while True: - tokentype, token, indent = self.next() - if token in (')', ',') and level == 1: - names.append(name) - name = '' - if token == '(': - level += 1 - elif token == ')': - level -= 1 - if level == 0: break - elif token == ',' and level == 1: - pass - else: - name += str(token) - return names - - def _parsefunction(self,indent): - self.scope=self.scope.pop(indent) - tokentype, fname, ind = self.next() - if tokentype != NAME: return None - - tokentype, open, ind = self.next() - if open != '(': return None - params=self._parenparse() - - tokentype, colon, ind = self.next() - if colon != ':': return None - - return Function(fname,params,indent) - - def _parseclass(self,indent): - self.scope=self.scope.pop(indent) - tokentype, cname, ind = self.next() - if tokentype != NAME: return None - - super = [] - tokentype, next, ind = self.next() - if next == '(': - super=self._parenparse() - elif next != ':': return None - - return Class(cname,super,indent) - - def _parseassignment(self): - assign='' - tokentype, token, indent = self.next() - if tokentype == tokenize.STRING or token == 'str': - return '""' - elif token == '(' or token == 'tuple': - return '()' - elif token == '[' or token == 'list': - return '[]' - elif token == '{' or token == 'dict': - return '{}' - elif tokentype == tokenize.NUMBER: - return '0' - elif token == 'open' or token == 'file': - return 'file' - elif token == 'None': - return '_PyCmplNoType()' - elif token == 'type': - return 'type(_PyCmplNoType)' #only for method resolution - else: - assign += token - level = 0 - while True: - tokentype, token, indent = self.next() - if token in ('(','{','['): - level += 1 - elif token in (']','}',')'): - level -= 1 - if level == 0: break - elif level == 0: - if token in (';','\n'): break - assign += token - return "%s" % assign - - def next(self): - type, token, (lineno, indent), end, self.parserline = self.gen.next() - if lineno == self.curline: - #print 'line found [%s] scope=%s' % (line.replace('\n',''),self.scope.name) - self.currentscope = self.scope - return (type, token, indent) - - def _adjustvisibility(self): - newscope = Scope('result',0) - scp = self.currentscope - while scp != None: - if type(scp) == Function: - slice = 0 - #Handle 'self' params - if scp.parent != None and type(scp.parent) == Class: - slice = 1 - p = scp.params[0] - i = p.find('=') - if i != -1: p = p[:i] - newscope.local('%s = %s' % (scp.params[0],scp.parent.name)) - for p in scp.params[slice:]: - i = p.find('=') - if i == -1: - newscope.local('%s = _PyCmplNoType()' % p) - else: - newscope.local('%s = %s' % (p[:i],_sanitize(p[i+1]))) - - for s in scp.subscopes: - ns = s.copy_decl(0) - newscope.add(ns) - for l in scp.locals: newscope.local(l) - scp = scp.parent - - self.currentscope = newscope - return self.currentscope - - #p.parse(vim.current.buffer[:],vim.eval("line('.')")) - def parse(self,text,curline=0): - self.curline = int(curline) - buf = cStringIO.StringIO(''.join(text) + '\n') - self.gen = tokenize.generate_tokens(buf.readline) - self.currentscope = self.scope - - try: - freshscope=True - while True: - tokentype, token, indent = self.next() - #dbg( 'main: token=[%s] indent=[%s]' % (token,indent)) - - if tokentype == DEDENT or token == "pass": - self.scope = self.scope.pop(indent) - elif token == 'def': - func = self._parsefunction(indent) - if func == None: - print "function: syntax error..." - continue - freshscope = True - self.scope = self.scope.add(func) - elif token == 'class': - cls = self._parseclass(indent) - if cls == None: - print "class: syntax error..." - continue - freshscope = True - self.scope = self.scope.add(cls) - - elif token == 'import': - imports = self._parseimportlist() - for mod, alias in imports: - loc = "import %s" % mod - if len(alias) > 0: loc += " as %s" % alias - self.scope.local(loc) - freshscope = False - elif token == 'from': - mod, token = self._parsedotname() - if not mod or token != "import": - print "from: syntax error..." - continue - names = self._parseimportlist() - for name, alias in names: - loc = "from %s import %s" % (mod,name) - if len(alias) > 0: loc += " as %s" % alias - self.scope.local(loc) - freshscope = False - elif tokentype == STRING: - if freshscope: self.scope.doc(token) - elif tokentype == NAME: - name,token = self._parsedotname(token) - if token == '=': - stmt = self._parseassignment() - if stmt != None: - self.scope.local("%s = %s" % (name,stmt)) - freshscope = False - except StopIteration: #thrown on EOF - pass - except: - dbg("parse error: %s, %s @ %s" % - (sys.exc_info()[0], sys.exc_info()[1], self.parserline)) - return self._adjustvisibility() - -def _sanitize(str): - val = '' - level = 0 - for c in str: - if c in ('(','{','['): - level += 1 - elif c in (']','}',')'): - level -= 1 - elif level == 0: - val += c - return val - -sys.path.extend(['.','..']) -PYTHONEOF -endfunction - -call s:DefPython() -" vim: set et ts=4: diff --git a/share/vim/vim72/autoload/rubycomplete.vim b/share/vim/vim72/autoload/rubycomplete.vim deleted file mode 100644 index 86baa0d272..0000000000 --- a/share/vim/vim72/autoload/rubycomplete.vim +++ /dev/null @@ -1,802 +0,0 @@ -" Vim completion script -" Language: Ruby -" Maintainer: Mark Guzman -" Info: $Id: rubycomplete.vim,v 1.41 2008/06/30 06:50:45 segy Exp $ -" URL: http://vim-ruby.rubyforge.org -" Anon CVS: See above site -" Release Coordinator: Doug Kearns -" Maintainer Version: 0.8 -" ---------------------------------------------------------------------------- -" -" Ruby IRB/Complete author: Keiju ISHITSUKA(keiju@ishitsuka.com) -" ---------------------------------------------------------------------------- - -" {{{ requirement checks -if !has('ruby') - s:ErrMsg( "Error: Rubycomplete requires vim compiled with +ruby" ) - s:ErrMsg( "Error: falling back to syntax completion" ) - " lets fall back to syntax completion - setlocal omnifunc=syntaxcomplete#Complete - finish -endif - -if version < 700 - s:ErrMsg( "Error: Required vim >= 7.0" ) - finish -endif -" }}} requirement checks - -" {{{ configuration failsafe initialization -if !exists("g:rubycomplete_rails") - let g:rubycomplete_rails = 0 -endif - -if !exists("g:rubycomplete_classes_in_global") - let g:rubycomplete_classes_in_global = 0 -endif - -if !exists("g:rubycomplete_buffer_loading") - let g:rubycomplete_buffer_loading = 0 -endif - -if !exists("g:rubycomplete_include_object") - let g:rubycomplete_include_object = 0 -endif - -if !exists("g:rubycomplete_include_objectspace") - let g:rubycomplete_include_objectspace = 0 -endif -" }}} configuration failsafe initialization - -" {{{ vim-side support functions -let s:rubycomplete_debug = 0 - -function! s:ErrMsg(msg) - echohl ErrorMsg - echo a:msg - echohl None -endfunction - -function! s:dprint(msg) - if s:rubycomplete_debug == 1 - echom a:msg - endif -endfunction - -function! s:GetBufferRubyModule(name, ...) - if a:0 == 1 - let [snum,enum] = s:GetBufferRubyEntity(a:name, "module", a:1) - else - let [snum,enum] = s:GetBufferRubyEntity(a:name, "module") - endif - return snum . '..' . enum -endfunction - -function! s:GetBufferRubyClass(name, ...) - if a:0 >= 1 - let [snum,enum] = s:GetBufferRubyEntity(a:name, "class", a:1) - else - let [snum,enum] = s:GetBufferRubyEntity(a:name, "class") - endif - return snum . '..' . enum -endfunction - -function! s:GetBufferRubySingletonMethods(name) -endfunction - -function! s:GetBufferRubyEntity( name, type, ... ) - let lastpos = getpos(".") - let lastline = lastpos - if (a:0 >= 1) - let lastline = [ 0, a:1, 0, 0 ] - call cursor( a:1, 0 ) - endif - - let stopline = 1 - - let crex = '^\s*\<' . a:type . '\>\s*\<' . a:name . '\>\s*\(<\s*.*\s*\)\?' - let [lnum,lcol] = searchpos( crex, 'w' ) - "let [lnum,lcol] = searchpairpos( crex . '\zs', '', '\(end\|}\)', 'w' ) - - if lnum == 0 && lcol == 0 - call cursor(lastpos[1], lastpos[2]) - return [0,0] - endif - - let curpos = getpos(".") - let [enum,ecol] = searchpairpos( crex, '', '\(end\|}\)', 'wr' ) - call cursor(lastpos[1], lastpos[2]) - - if lnum > enum - return [0,0] - endif - " we found a the class def - return [lnum,enum] -endfunction - -function! s:IsInClassDef() - return s:IsPosInClassDef( line('.') ) -endfunction - -function! s:IsPosInClassDef(pos) - let [snum,enum] = s:GetBufferRubyEntity( '.*', "class" ) - let ret = 'nil' - - if snum < a:pos && a:pos < enum - let ret = snum . '..' . enum - endif - - return ret -endfunction - -function! s:GetRubyVarType(v) - let stopline = 1 - let vtp = '' - let pos = getpos('.') - let sstr = '^\s*#\s*@var\s*'.a:v.'\>\s\+[^ \t]\+\s*$' - let [lnum,lcol] = searchpos(sstr,'nb',stopline) - if lnum != 0 && lcol != 0 - call setpos('.',pos) - let str = getline(lnum) - let vtp = substitute(str,sstr,'\1','') - return vtp - endif - call setpos('.',pos) - let ctors = '\(now\|new\|open\|get_instance' - if exists('g:rubycomplete_rails') && g:rubycomplete_rails == 1 && s:rubycomplete_rails_loaded == 1 - let ctors = ctors.'\|find\|create' - else - endif - let ctors = ctors.'\)' - - let fstr = '=\s*\([^ \t]\+.' . ctors .'\>\|[\[{"''/]\|%[xwQqr][(\[{@]\|[A-Za-z0-9@:\-()\.]\+...\?\|lambda\|&\)' - let sstr = ''.a:v.'\>\s*[+\-*/]*'.fstr - let [lnum,lcol] = searchpos(sstr,'nb',stopline) - if lnum != 0 && lcol != 0 - let str = matchstr(getline(lnum),fstr,lcol) - let str = substitute(str,'^=\s*','','') - - call setpos('.',pos) - if str == '"' || str == '''' || stridx(tolower(str), '%q[') != -1 - return 'String' - elseif str == '[' || stridx(str, '%w[') != -1 - return 'Array' - elseif str == '{' - return 'Hash' - elseif str == '/' || str == '%r{' - return 'Regexp' - elseif strlen(str) >= 4 && stridx(str,'..') != -1 - return 'Range' - elseif stridx(str, 'lambda') != -1 || str == '&' - return 'Proc' - elseif strlen(str) > 4 - let l = stridx(str,'.') - return str[0:l-1] - end - return '' - endif - call setpos('.',pos) - return '' -endfunction - -"}}} vim-side support functions - -"{{{ vim-side completion function -function! rubycomplete#Init() - execute "ruby VimRubyCompletion.preload_rails" -endfunction - -function! rubycomplete#Complete(findstart, base) - "findstart = 1 when we need to get the text length - if a:findstart - let line = getline('.') - let idx = col('.') - while idx > 0 - let idx -= 1 - let c = line[idx-1] - if c =~ '\w' - continue - elseif ! c =~ '\.' - idx = -1 - break - else - break - endif - endwhile - - return idx - "findstart = 0 when we need to return the list of completions - else - let g:rubycomplete_completions = [] - execute "ruby VimRubyCompletion.get_completions('" . a:base . "')" - return g:rubycomplete_completions - endif -endfunction -"}}} vim-side completion function - -"{{{ ruby-side code -function! s:DefRuby() -ruby << RUBYEOF -# {{{ ruby completion - -begin - require 'rubygems' # let's assume this is safe...? -rescue Exception - #ignore? -end -class VimRubyCompletion -# {{{ constants - @@debug = false - @@ReservedWords = [ - "BEGIN", "END", - "alias", "and", - "begin", "break", - "case", "class", - "def", "defined", "do", - "else", "elsif", "end", "ensure", - "false", "for", - "if", "in", - "module", - "next", "nil", "not", - "or", - "redo", "rescue", "retry", "return", - "self", "super", - "then", "true", - "undef", "unless", "until", - "when", "while", - "yield", - ] - - @@Operators = [ "%", "&", "*", "**", "+", "-", "/", - "<", "<<", "<=", "<=>", "==", "===", "=~", ">", ">=", ">>", - "[]", "[]=", "^", ] -# }}} constants - -# {{{ buffer analysis magic - def load_requires - buf = VIM::Buffer.current - enum = buf.line_number - nums = Range.new( 1, enum ) - nums.each do |x| - ln = buf[x] - begin - eval( "require %s" % $1 ) if /.*require\s*(.*)$/.match( ln ) - rescue Exception - #ignore? - end - end - end - - def load_buffer_class(name) - dprint "load_buffer_class(%s) START" % name - classdef = get_buffer_entity(name, 's:GetBufferRubyClass("%s")') - return if classdef == nil - - pare = /^\s*class\s*(.*)\s*<\s*(.*)\s*\n/.match( classdef ) - load_buffer_class( $2 ) if pare != nil && $2 != name # load parent class if needed - - mixre = /.*\n\s*include\s*(.*)\s*\n/.match( classdef ) - load_buffer_module( $2 ) if mixre != nil && $2 != name # load mixins if needed - - begin - eval classdef - rescue Exception - VIM::evaluate( "s:ErrMsg( 'Problem loading class \"%s\", was it already completed?' )" % name ) - end - dprint "load_buffer_class(%s) END" % name - end - - def load_buffer_module(name) - dprint "load_buffer_module(%s) START" % name - classdef = get_buffer_entity(name, 's:GetBufferRubyModule("%s")') - return if classdef == nil - - begin - eval classdef - rescue Exception - VIM::evaluate( "s:ErrMsg( 'Problem loading module \"%s\", was it already completed?' )" % name ) - end - dprint "load_buffer_module(%s) END" % name - end - - def get_buffer_entity(name, vimfun) - loading_allowed = VIM::evaluate("exists('g:rubycomplete_buffer_loading') && g:rubycomplete_buffer_loading") - return nil if loading_allowed.to_i.zero? - return nil if /(\"|\')+/.match( name ) - buf = VIM::Buffer.current - nums = eval( VIM::evaluate( vimfun % name ) ) - return nil if nums == nil - return nil if nums.min == nums.max && nums.min == 0 - - dprint "get_buffer_entity START" - visited = [] - clscnt = 0 - bufname = VIM::Buffer.current.name - classdef = "" - cur_line = VIM::Buffer.current.line_number - while (nums != nil && !(nums.min == 0 && nums.max == 0) ) - dprint "visited: %s" % visited.to_s - break if visited.index( nums ) - visited << nums - - nums.each do |x| - if x != cur_line - next if x == 0 - ln = buf[x] - if /^\s*(module|class|def|include)\s+/.match(ln) - clscnt += 1 if $1 == "class" - #dprint "\$1: %s" % $1 - classdef += "%s\n" % ln - classdef += "end\n" if /def\s+/.match(ln) - dprint ln - end - end - end - - nm = "%s(::.*)*\", %s, \"" % [ name, nums.last ] - nums = eval( VIM::evaluate( vimfun % nm ) ) - dprint "nm: \"%s\"" % nm - dprint "vimfun: %s" % (vimfun % nm) - dprint "got nums: %s" % nums.to_s - end - if classdef.length > 1 - classdef += "end\n"*clscnt - # classdef = "class %s\n%s\nend\n" % [ bufname.gsub( /\/|\\/, "_" ), classdef ] - end - - dprint "get_buffer_entity END" - dprint "classdef====start" - lns = classdef.split( "\n" ) - lns.each { |x| dprint x } - dprint "classdef====end" - return classdef - end - - def get_var_type( receiver ) - if /(\"|\')+/.match( receiver ) - "String" - else - VIM::evaluate("s:GetRubyVarType('%s')" % receiver) - end - end - - def dprint( txt ) - print txt if @@debug - end - - def get_buffer_entity_list( type ) - # this will be a little expensive. - loading_allowed = VIM::evaluate("exists('g:rubycomplete_buffer_loading') && g:rubycomplete_buffer_loading") - allow_aggressive_load = VIM::evaluate("exists('g:rubycomplete_classes_in_global') && g:rubycomplete_classes_in_global") - return [] if allow_aggressive_load.to_i.zero? || loading_allowed.to_i.zero? - - buf = VIM::Buffer.current - eob = buf.length - ret = [] - rg = 1..eob - re = eval( "/^\s*%s\s*([A-Za-z0-9_:-]*)(\s*<\s*([A-Za-z0-9_:-]*))?\s*/" % type ) - - rg.each do |x| - if re.match( buf[x] ) - next if type == "def" && eval( VIM::evaluate("s:IsPosInClassDef(%s)" % x) ) != nil - ret.push $1 - end - end - - return ret - end - - def get_buffer_modules - return get_buffer_entity_list( "modules" ) - end - - def get_buffer_methods - return get_buffer_entity_list( "def" ) - end - - def get_buffer_classes - return get_buffer_entity_list( "class" ) - end - - - def load_rails - allow_rails = VIM::evaluate("exists('g:rubycomplete_rails') && g:rubycomplete_rails") - return if allow_rails.to_i.zero? - - buf_path = VIM::evaluate('expand("%:p")') - file_name = VIM::evaluate('expand("%:t")') - vim_dir = VIM::evaluate('getcwd()') - file_dir = buf_path.gsub( file_name, '' ) - file_dir.gsub!( /\\/, "/" ) - vim_dir.gsub!( /\\/, "/" ) - vim_dir << "/" - dirs = [ vim_dir, file_dir ] - sdirs = [ "", "./", "../", "../../", "../../../", "../../../../" ] - rails_base = nil - - dirs.each do |dir| - sdirs.each do |sub| - trail = "%s%s" % [ dir, sub ] - tcfg = "%sconfig" % trail - - if File.exists?( tcfg ) - rails_base = trail - break - end - end - break if rails_base - end - - return if rails_base == nil - $:.push rails_base unless $:.index( rails_base ) - - rails_config = rails_base + "config/" - rails_lib = rails_base + "lib/" - $:.push rails_config unless $:.index( rails_config ) - $:.push rails_lib unless $:.index( rails_lib ) - - bootfile = rails_config + "boot.rb" - envfile = rails_config + "environment.rb" - if File.exists?( bootfile ) && File.exists?( envfile ) - begin - require bootfile - require envfile - begin - require 'console_app' - require 'console_with_helpers' - rescue Exception - dprint "Rails 1.1+ Error %s" % $! - # assume 1.0 - end - #eval( "Rails::Initializer.run" ) #not necessary? - VIM::command('let s:rubycomplete_rails_loaded = 1') - dprint "rails loaded" - rescue Exception - dprint "Rails Error %s" % $! - VIM::evaluate( "s:ErrMsg('Error loading rails environment')" ) - end - end - end - - def get_rails_helpers - allow_rails = VIM::evaluate("exists('g:rubycomplete_rails') && g:rubycomplete_rails") - rails_loaded = VIM::evaluate('s:rubycomplete_rails_loaded') - return [] if allow_rails.to_i.zero? || rails_loaded.to_i.zero? - - buf_path = VIM::evaluate('expand("%:p")') - buf_path.gsub!( /\\/, "/" ) - path_elm = buf_path.split( "/" ) - dprint "buf_path: %s" % buf_path - types = [ "app", "db", "lib", "test", "components", "script" ] - - i = nil - ret = [] - type = nil - types.each do |t| - i = path_elm.index( t ) - break if i - end - type = path_elm[i] - type.downcase! - - dprint "type: %s" % type - case type - when "app" - i += 1 - subtype = path_elm[i] - subtype.downcase! - - dprint "subtype: %s" % subtype - case subtype - when "views" - ret += ActionView::Base.instance_methods - ret += ActionView::Base.methods - when "controllers" - ret += ActionController::Base.instance_methods - ret += ActionController::Base.methods - when "models" - ret += ActiveRecord::Base.instance_methods - ret += ActiveRecord::Base.methods - end - - when "db" - ret += ActiveRecord::ConnectionAdapters::SchemaStatements.instance_methods - ret += ActiveRecord::ConnectionAdapters::SchemaStatements.methods - end - - - return ret - end - - def add_rails_columns( cls ) - allow_rails = VIM::evaluate("exists('g:rubycomplete_rails') && g:rubycomplete_rails") - rails_loaded = VIM::evaluate('s:rubycomplete_rails_loaded') - return [] if allow_rails.to_i.zero? || rails_loaded.to_i.zero? - - begin - eval( "#{cls}.establish_connection" ) - return [] unless eval( "#{cls}.ancestors.include?(ActiveRecord::Base).to_s" ) - col = eval( "#{cls}.column_names" ) - return col if col - rescue - dprint "add_rails_columns err: (cls: %s) %s" % [ cls, $! ] - return [] - end - return [] - end - - def clean_sel(sel, msg) - sel.delete_if { |x| x == nil } - sel.uniq! - sel.grep(/^#{Regexp.quote(msg)}/) if msg != nil - end - - def get_rails_view_methods - allow_rails = VIM::evaluate("exists('g:rubycomplete_rails') && g:rubycomplete_rails") - rails_loaded = VIM::evaluate('s:rubycomplete_rails_loaded') - return [] if allow_rails.to_i.zero? || rails_loaded.to_i.zero? - - buf_path = VIM::evaluate('expand("%:p")') - buf_path.gsub!( /\\/, "/" ) - pelm = buf_path.split( "/" ) - idx = pelm.index( "views" ) - - return [] unless idx - idx += 1 - - clspl = pelm[idx].camelize.pluralize - cls = clspl.singularize - - ret = [] - begin - ret += eval( "#{cls}.instance_methods" ) - ret += eval( "#{clspl}Helper.instance_methods" ) - rescue Exception - dprint "Error: Unable to load rails view helpers for %s: %s" % [ cls, $! ] - end - - return ret - end -# }}} buffer analysis magic - -# {{{ main completion code - def self.preload_rails - a = VimRubyCompletion.new - require 'Thread' - Thread.new(a) do |b| - begin - b.load_rails - rescue - end - end - a.load_rails - rescue - end - - def self.get_completions(base) - b = VimRubyCompletion.new - b.get_completions base - end - - def get_completions(base) - loading_allowed = VIM::evaluate("exists('g:rubycomplete_buffer_loading') && g:rubycomplete_buffer_loading") - if loading_allowed.to_i == 1 - load_requires - load_rails - end - - input = VIM::Buffer.current.line - cpos = VIM::Window.current.cursor[1] - 1 - input = input[0..cpos] - input += base - input.sub!(/.*[ \t\n\"\\'`><=;|&{(]/, '') # Readline.basic_word_break_characters - input.sub!(/self\./, '') - input.sub!(/.*((\.\.[\[(]?)|([\[(]))/, '') - - dprint 'input %s' % input - message = nil - receiver = nil - methods = [] - variables = [] - classes = [] - constants = [] - - case input - when /^(\/[^\/]*\/)\.([^.]*)$/ # Regexp - receiver = $1 - message = Regexp.quote($2) - methods = Regexp.instance_methods(true) - - when /^([^\]]*\])\.([^.]*)$/ # Array - receiver = $1 - message = Regexp.quote($2) - methods = Array.instance_methods(true) - - when /^([^\}]*\})\.([^.]*)$/ # Proc or Hash - receiver = $1 - message = Regexp.quote($2) - methods = Proc.instance_methods(true) | Hash.instance_methods(true) - - when /^(:[^:.]*)$/ # Symbol - dprint "symbol" - if Symbol.respond_to?(:all_symbols) - receiver = $1 - message = $1.sub( /:/, '' ) - methods = Symbol.all_symbols.collect{|s| s.id2name} - methods.delete_if { |c| c.match( /'/ ) } - end - - when /^::([A-Z][^:\.\(]*)$/ # Absolute Constant or class methods - dprint "const or cls" - receiver = $1 - methods = Object.constants - methods.grep(/^#{receiver}/).collect{|e| "::" + e} - - when /^(((::)?[A-Z][^:.\(]*)+)::?([^:.]*)$/ # Constant or class methods - receiver = $1 - message = Regexp.quote($4) - dprint "const or cls 2 [recv: \'%s\', msg: \'%s\']" % [ receiver, message ] - load_buffer_class( receiver ) - begin - classes = eval("#{receiver}.constants") - #methods = eval("#{receiver}.methods") - rescue Exception - dprint "exception: %s" % $! - methods = [] - end - methods.grep(/^#{message}/).collect{|e| receiver + "::" + e} - - when /^(:[^:.]+)\.([^.]*)$/ # Symbol - dprint "symbol" - receiver = $1 - message = Regexp.quote($2) - methods = Symbol.instance_methods(true) - - when /^([0-9_]+(\.[0-9_]+)?(e[0-9]+)?)\.([^.]*)$/ # Numeric - dprint "numeric" - receiver = $1 - message = Regexp.quote($4) - begin - methods = eval(receiver).methods - rescue Exception - methods = [] - end - - when /^(\$[^.]*)$/ #global - dprint "global" - methods = global_variables.grep(Regexp.new(Regexp.quote($1))) - - when /^((\.?[^.]+)+)\.([^.]*)$/ # variable - dprint "variable" - receiver = $1 - message = Regexp.quote($3) - load_buffer_class( receiver ) - - cv = eval("self.class.constants") - vartype = get_var_type( receiver ) - dprint "vartype: %s" % vartype - if vartype != '' - load_buffer_class( vartype ) - - begin - methods = eval("#{vartype}.instance_methods") - variables = eval("#{vartype}.instance_variables") - rescue Exception - dprint "load_buffer_class err: %s" % $! - end - elsif (cv).include?(receiver) - # foo.func and foo is local var. - methods = eval("#{receiver}.methods") - vartype = receiver - elsif /^[A-Z]/ =~ receiver and /\./ !~ receiver - vartype = receiver - # Foo::Bar.func - begin - methods = eval("#{receiver}.methods") - rescue Exception - end - else - # func1.func2 - ObjectSpace.each_object(Module){|m| - next if m.name != "IRB::Context" and - /^(IRB|SLex|RubyLex|RubyToken)/ =~ m.name - methods.concat m.instance_methods(false) - } - end - variables += add_rails_columns( "#{vartype}" ) if vartype && vartype.length > 0 - - when /^\(?\s*[A-Za-z0-9:^@.%\/+*\(\)]+\.\.\.?[A-Za-z0-9:^@.%\/+*\(\)]+\s*\)?\.([^.]*)/ - message = $1 - methods = Range.instance_methods(true) - - when /^\.([^.]*)$/ # unknown(maybe String) - message = Regexp.quote($1) - methods = String.instance_methods(true) - - else - dprint "default/other" - inclass = eval( VIM::evaluate("s:IsInClassDef()") ) - - if inclass != nil - dprint "inclass" - classdef = "%s\n" % VIM::Buffer.current[ inclass.min ] - found = /^\s*class\s*([A-Za-z0-9_-]*)(\s*<\s*([A-Za-z0-9_:-]*))?\s*\n$/.match( classdef ) - - if found != nil - receiver = $1 - message = input - load_buffer_class( receiver ) - begin - methods = eval( "#{receiver}.instance_methods" ) - variables += add_rails_columns( "#{receiver}" ) - rescue Exception - found = nil - end - end - end - - if inclass == nil || found == nil - dprint "inclass == nil" - methods = get_buffer_methods - methods += get_rails_view_methods - - cls_const = Class.constants - constants = cls_const.select { |c| /^[A-Z_-]+$/.match( c ) } - classes = eval("self.class.constants") - constants - classes += get_buffer_classes - classes += get_buffer_modules - - include_objectspace = VIM::evaluate("exists('g:rubycomplete_include_objectspace') && g:rubycomplete_include_objectspace") - ObjectSpace.each_object(Class) { |cls| classes << cls.to_s } if include_objectspace == "1" - message = receiver = input - end - - methods += get_rails_helpers - methods += Kernel.public_methods - end - - - include_object = VIM::evaluate("exists('g:rubycomplete_include_object') && g:rubycomplete_include_object") - methods = clean_sel( methods, message ) - methods = (methods-Object.instance_methods) if include_object == "0" - rbcmeth = (VimRubyCompletion.instance_methods-Object.instance_methods) # lets remove those rubycomplete methods - methods = (methods-rbcmeth) - - variables = clean_sel( variables, message ) - classes = clean_sel( classes, message ) - ["VimRubyCompletion"] - constants = clean_sel( constants, message ) - - valid = [] - valid += methods.collect { |m| { :name => m, :type => 'm' } } - valid += variables.collect { |v| { :name => v, :type => 'v' } } - valid += classes.collect { |c| { :name => c, :type => 't' } } - valid += constants.collect { |d| { :name => d, :type => 'd' } } - valid.sort! { |x,y| x[:name] <=> y[:name] } - - outp = "" - - rg = 0..valid.length - rg.step(150) do |x| - stpos = 0+x - enpos = 150+x - valid[stpos..enpos].each { |c| outp += "{'word':'%s','item':'%s','kind':'%s'}," % [ c[:name], c[:name], c[:type] ] } - outp.sub!(/,$/, '') - - VIM::command("call extend(g:rubycomplete_completions, [%s])" % outp) - outp = "" - end - end -# }}} main completion code - -end # VimRubyCompletion -# }}} ruby completion -RUBYEOF -endfunction - -let s:rubycomplete_rails_loaded = 0 - -call s:DefRuby() -"}}} ruby-side code - - -" vim:tw=78:sw=4:ts=8:et:fdm=marker:ft=vim:norl: diff --git a/share/vim/vim72/autoload/spellfile.vim b/share/vim/vim72/autoload/spellfile.vim deleted file mode 100644 index 9979f1bd09..0000000000 --- a/share/vim/vim72/autoload/spellfile.vim +++ /dev/null @@ -1,179 +0,0 @@ -" Vim script to download a missing spell file -" Maintainer: Bram Moolenaar -" Last Change: 2008 Jun 27 - -if !exists('g:spellfile_URL') - " Prefer using http:// when netrw should be able to use it, since - " more firewalls let this through. - if executable("curl") || executable("wget") || executable("fetch") - let g:spellfile_URL = 'http://ftp.vim.org/pub/vim/runtime/spell' - else - let g:spellfile_URL = 'ftp://ftp.vim.org/pub/vim/runtime/spell' - endif -endif -let s:spellfile_URL = '' " Start with nothing so that s:donedict is reset. - -" This function is used for the spellfile plugin. -function! spellfile#LoadFile(lang) - " If the netrw plugin isn't loaded we silently skip everything. - if !exists(":Nread") - if &verbose - echomsg 'spellfile#LoadFile(): Nread command is not available.' - endif - return - endif - - " If the URL changes we try all files again. - if s:spellfile_URL != g:spellfile_URL - let s:donedict = {} - let s:spellfile_URL = g:spellfile_URL - endif - - " I will say this only once! - if has_key(s:donedict, a:lang . &enc) - if &verbose - echomsg 'spellfile#LoadFile(): Tried this language/encoding before.' - endif - return - endif - let s:donedict[a:lang . &enc] = 1 - - " Find spell directories we can write in. - let dirlist = [] - let dirchoices = '&Cancel' - for dir in split(globpath(&rtp, 'spell'), "\n") - if filewritable(dir) == 2 - call add(dirlist, dir) - let dirchoices .= "\n&" . len(dirlist) - endif - endfor - if len(dirlist) == 0 - if &verbose - echomsg 'spellfile#LoadFile(): There is no writable spell directory.' - endif - return - endif - - let msg = 'Cannot find spell file for "' . a:lang . '" in ' . &enc - let msg .= "\nDo you want me to try downloading it?" - if confirm(msg, "&Yes\n&No", 2) == 1 - let enc = &encoding - if enc == 'iso-8859-15' - let enc = 'latin1' - endif - let fname = a:lang . '.' . enc . '.spl' - - " Split the window, read the file into a new buffer. - " Remember the buffer number, we check it below. - new - let newbufnr = winbufnr(0) - setlocal bin - echo 'Downloading ' . fname . '...' - call spellfile#Nread(fname) - if getline(2) !~ 'VIMspell' - " Didn't work, perhaps there is an ASCII one. - " Careful: Nread() may have opened a new window for the error message, - " we need to go back to our own buffer and window. - if newbufnr != winbufnr(0) - let winnr = bufwinnr(newbufnr) - if winnr == -1 - " Our buffer has vanished!? Open a new window. - echomsg "download buffer disappeared, opening a new one" - new - setlocal bin - else - exe winnr . "wincmd w" - endif - endif - if newbufnr == winbufnr(0) - " We are back the old buffer, remove any (half-finished) download. - g/^/d - else - let newbufnr = winbufnr(0) - endif - - let fname = a:lang . '.ascii.spl' - echo 'Could not find it, trying ' . fname . '...' - call spellfile#Nread(fname) - if getline(2) !~ 'VIMspell' - echo 'Sorry, downloading failed' - exe newbufnr . "bwipe!" - return - endif - endif - - " Delete the empty first line and mark the file unmodified. - 1d - set nomod - - let msg = "In which directory do you want to write the file:" - for i in range(len(dirlist)) - let msg .= "\n" . (i + 1) . '. ' . dirlist[i] - endfor - let dirchoice = confirm(msg, dirchoices) - 2 - if dirchoice >= 0 - if exists('*fnameescape') - let dirname = fnameescape(dirlist[dirchoice]) - else - let dirname = escape(dirlist[dirchoice], ' ') - endif - exe "write " . dirname . '/' . fname - - " Also download the .sug file, if the user wants to. - let msg = "Do you want me to try getting the .sug file?\n" - let msg .= "This will improve making suggestions for spelling mistakes,\n" - let msg .= "but it uses quite a bit of memory." - if confirm(msg, "&No\n&Yes") == 2 - g/^/d - let fname = substitute(fname, '\.spl$', '.sug', '') - echo 'Downloading ' . fname . '...' - call spellfile#Nread(fname) - if getline(2) =~ 'VIMsug' - 1d - exe "write " . dirname . '/' . fname - set nomod - else - echo 'Sorry, downloading failed' - " Go back to our own buffer/window, Nread() may have taken us to - " another window. - if newbufnr != winbufnr(0) - let winnr = bufwinnr(newbufnr) - if winnr != -1 - exe winnr . "wincmd w" - endif - endif - if newbufnr == winbufnr(0) - set nomod - endif - endif - endif - endif - - " Wipe out the buffer we used. - exe newbufnr . "bwipe" - endif -endfunc - -" Read "fname" from the server. -function! spellfile#Nread(fname) - " We do our own error handling, don't want a window for it. - if exists("g:netrw_use_errorwindow") - let save_ew = g:netrw_use_errorwindow - endif - let g:netrw_use_errorwindow=0 - - if g:spellfile_URL =~ '^ftp://' - " for an ftp server use a default login and password to avoid a prompt - let machine = substitute(g:spellfile_URL, 'ftp://\([^/]*\).*', '\1', '') - let dir = substitute(g:spellfile_URL, 'ftp://[^/]*/\(.*\)', '\1', '') - exe 'Nread "' . machine . ' anonymous vim7user ' . dir . '/' . a:fname . '"' - else - exe 'Nread ' g:spellfile_URL . '/' . a:fname - endif - - if exists("save_ew") - let g:netrw_use_errorwindow = save_ew - else - unlet g:netrw_use_errorwindow - endif -endfunc diff --git a/share/vim/vim72/autoload/sqlcomplete.vim b/share/vim/vim72/autoload/sqlcomplete.vim deleted file mode 100644 index eecb3260fe..0000000000 --- a/share/vim/vim72/autoload/sqlcomplete.vim +++ /dev/null @@ -1,693 +0,0 @@ -" Vim OMNI completion script for SQL -" Language: SQL -" Maintainer: David Fishburn -" Version: 6.0 -" Last Change: Thu 03 Apr 2008 10:37:54 PM Eastern Daylight Time -" Usage: For detailed help -" ":help sql.txt" -" or ":help ft-sql-omni" -" or read $VIMRUNTIME/doc/sql.txt - -" Set completion with CTRL-X CTRL-O to autoloaded function. -" This check is in place in case this script is -" sourced directly instead of using the autoload feature. -if exists('&omnifunc') - " Do not set the option if already set since this - " results in an E117 warning. - if &omnifunc == "" - setlocal omnifunc=sqlcomplete#Complete - endif -endif - -if exists('g:loaded_sql_completion') - finish -endif -let g:loaded_sql_completion = 50 - -" Maintains filename of dictionary -let s:sql_file_table = "" -let s:sql_file_procedure = "" -let s:sql_file_view = "" - -" Define various arrays to be used for caching -let s:tbl_name = [] -let s:tbl_alias = [] -let s:tbl_cols = [] -let s:syn_list = [] -let s:syn_value = [] - -" Used in conjunction with the syntaxcomplete plugin -let s:save_inc = "" -let s:save_exc = "" -if exists('g:omni_syntax_group_include_sql') - let s:save_inc = g:omni_syntax_group_include_sql -endif -if exists('g:omni_syntax_group_exclude_sql') - let s:save_exc = g:omni_syntax_group_exclude_sql -endif - -" Used with the column list -let s:save_prev_table = "" - -" Default the option to verify table alias -if !exists('g:omni_sql_use_tbl_alias') - let g:omni_sql_use_tbl_alias = 'a' -endif -" Default syntax items to precache -if !exists('g:omni_sql_precache_syntax_groups') - let g:omni_sql_precache_syntax_groups = [ - \ 'syntax', - \ 'sqlKeyword', - \ 'sqlFunction', - \ 'sqlOption', - \ 'sqlType', - \ 'sqlStatement' - \ ] -endif -" Set ignorecase to the ftplugin standard -if !exists('g:omni_sql_ignorecase') - let g:omni_sql_ignorecase = &ignorecase -endif -" During table completion, should the table list also -" include the owner name -if !exists('g:omni_sql_include_owner') - let g:omni_sql_include_owner = 0 - if exists('g:loaded_dbext') - if g:loaded_dbext >= 300 - " New to dbext 3.00, by default the table lists include the owner - " name of the table. This is used when determining how much of - " whatever has been typed should be replaced as part of the - " code replacement. - let g:omni_sql_include_owner = 1 - endif - endif -endif - -" This function is used for the 'omnifunc' option. -function! sqlcomplete#Complete(findstart, base) - - " Default to table name completion - let compl_type = 'table' - " Allow maps to specify what type of object completion they want - if exists('b:sql_compl_type') - let compl_type = b:sql_compl_type - endif - - " First pass through this function determines how much of the line should - " be replaced by whatever is chosen from the completion list - if a:findstart - " Locate the start of the item, including "." - let line = getline('.') - let start = col('.') - 1 - let lastword = -1 - let begindot = 0 - " Check if the first character is a ".", for column completion - if line[start - 1] == '.' - let begindot = 1 - endif - while start > 0 - if line[start - 1] =~ '\(\w\|\s\+\)' - let start -= 1 - elseif line[start - 1] =~ '\.' && - \ compl_type =~ 'column\|table\|view\|procedure' - " If lastword has already been set for column completion - " break from the loop, since we do not also want to pickup - " a table name if it was also supplied. - if lastword != -1 && compl_type == 'column' - break - endif - " If column completion was specified stop at the "." if - " a . was specified, otherwise, replace all the way up - " to the owner name (if included). - if lastword == -1 && compl_type == 'column' && begindot == 1 - let lastword = start - endif - " If omni_sql_include_owner = 0, do not include the table - " name as part of the substitution, so break here - if lastword == -1 && - \ compl_type =~ 'table\|view\|procedure\column_csv' && - \ g:omni_sql_include_owner == 0 - let lastword = start - break - endif - let start -= 1 - else - break - endif - endwhile - - " Return the column of the last word, which is going to be changed. - " Remember the text that comes before it in s:prepended. - if lastword == -1 - let s:prepended = '' - return start - endif - let s:prepended = strpart(line, start, lastword - start) - return lastword - endif - - " Second pass through this function will determine what data to put inside - " of the completion list - " s:prepended is set by the first pass - let base = s:prepended . a:base - - " Default the completion list to an empty list - let compl_list = [] - - " Default to table name completion - let compl_type = 'table' - " Allow maps to specify what type of object completion they want - if exists('b:sql_compl_type') - let compl_type = b:sql_compl_type - unlet b:sql_compl_type - endif - - if compl_type == 'tableReset' - let compl_type = 'table' - let base = '' - endif - - if compl_type == 'table' || - \ compl_type == 'procedure' || - \ compl_type == 'view' - - " This type of completion relies upon the dbext.vim plugin - if s:SQLCCheck4dbext() == -1 - return [] - endif - - " Allow the user to override the dbext plugin to specify whether - " the owner/creator should be included in the list - if g:loaded_dbext >= 300 - let saveSetting = DB_listOption('dict_show_owner') - exec 'DBSetOption dict_show_owner='.(g:omni_sql_include_owner==1?'1':'0') - endif - - let compl_type_uc = substitute(compl_type, '\w\+', '\u&', '') - if s:sql_file_{compl_type} == "" - let s:sql_file_{compl_type} = DB_getDictionaryName(compl_type_uc) - endif - let s:sql_file_{compl_type} = DB_getDictionaryName(compl_type_uc) - if s:sql_file_{compl_type} != "" - if filereadable(s:sql_file_{compl_type}) - let compl_list = readfile(s:sql_file_{compl_type}) - endif - endif - - if g:loaded_dbext > 300 - exec 'DBSetOption dict_show_owner='.saveSetting - endif - elseif compl_type =~? 'column' - - " This type of completion relies upon the dbext.vim plugin - if s:SQLCCheck4dbext() == -1 - return [] - endif - - if base == "" - " The last time we displayed a column list we stored - " the table name. If the user selects a column list - " without a table name of alias present, assume they want - " the previous column list displayed. - let base = s:save_prev_table - endif - - let owner = '' - let column = '' - - if base =~ '\.' - " Check if the owner/creator has been specified - let owner = matchstr( base, '^\zs.*\ze\..*\..*' ) - let table = matchstr( base, '^\(.*\.\)\?\zs.*\ze\..*' ) - let column = matchstr( base, '.*\.\zs.*' ) - - " It is pretty well impossible to determine if the user - " has entered: - " owner.table - " table.column_prefix - " So there are a couple of things we can do to mitigate - " this issue. - " 1. Check if the dbext plugin has the option turned - " on to even allow owners - " 2. Based on 1, if the user is showing a table list - " and the DrillIntoTable (using ) then - " this will be owner.table. In this case, we can - " check to see the table.column exists in the - " cached table list. If it does, then we have - " determined the user has actually chosen - " owner.table, not table.column_prefix. - let found = -1 - if g:omni_sql_include_owner == 1 && owner == '' - if filereadable(s:sql_file_table) - let tbl_list = readfile(s:sql_file_table) - let found = index( tbl_list, ((table != '')?(table.'.'):'').column) - endif - endif - " If the table.column was found in the table list, we can safely assume - " the owner was not provided and shift the items appropriately. - " OR - " If the user has indicated not to use table owners at all and - " the base ends in a '.' we know they are not providing a column - " name, so we can shift the items appropriately. - if found != -1 || (g:omni_sql_include_owner == 0 && base !~ '\.$') - let owner = table - let table = column - let column = '' - endif - else - let table = base - endif - - " Get anything after the . and consider this the table name - " If an owner has been specified, then we must consider the - " base to be a partial column name - " let base = matchstr( base, '^\(.*\.\)\?\zs.*' ) - - if table != "" - let s:save_prev_table = base - let list_type = '' - - if compl_type == 'column_csv' - " Return one array element, with a comma separated - " list of values instead of multiple array entries - " for each column in the table. - let list_type = 'csv' - endif - - let compl_list = s:SQLCGetColumns(table, list_type) - if column != '' - " If no column prefix has been provided and the table - " name was provided, append it to each of the items - " returned. - let compl_list = map(compl_list, "table.'.'.v:val") - if owner != '' - " If an owner has been provided append it to each of the - " items returned. - let compl_list = map(compl_list, "owner.'.'.v:val") - endif - else - let base = '' - endif - - if compl_type == 'column_csv' - " Join the column array into 1 single element array - " but make the columns column separated - let compl_list = [join(compl_list, ', ')] - endif - endif - elseif compl_type == 'resetCache' - " Reset all cached items - let s:tbl_name = [] - let s:tbl_alias = [] - let s:tbl_cols = [] - let s:syn_list = [] - let s:syn_value = [] - - let msg = "All SQL cached items have been removed." - call s:SQLCWarningMsg(msg) - " Leave time for the user to read the error message - :sleep 2 - else - let compl_list = s:SQLCGetSyntaxList(compl_type) - endif - - if base != '' - " Filter the list based on the first few characters the user - " entered - let expr = 'v:val '.(g:omni_sql_ignorecase==1?'=~?':'=~#').' "\\(^'.base.'\\|\\([^.]*\\)\\?'.base.'\\)"' - let compl_list = filter(deepcopy(compl_list), expr) - endif - - if exists('b:sql_compl_savefunc') && b:sql_compl_savefunc != "" - let &omnifunc = b:sql_compl_savefunc - endif - - return compl_list -endfunc - -function! sqlcomplete#PreCacheSyntax(...) - let syn_group_arr = [] - if a:0 > 0 - let syn_group_arr = a:1 - else - let syn_group_arr = g:omni_sql_precache_syntax_groups - endif - " For each group specified in the list, precache all - " the sytnax items. - if !empty(syn_group_arr) - for group_name in syn_group_arr - call s:SQLCGetSyntaxList(group_name) - endfor - endif -endfunction - -function! sqlcomplete#Map(type) - " Tell the SQL plugin what you want to complete - let b:sql_compl_type=a:type - " Record previous omnifunc, if the SQL completion - " is being used in conjunction with other filetype - " completion plugins - if &omnifunc != "" && &omnifunc != 'sqlcomplete#Complete' - " Record the previous omnifunc, the plugin - " will automatically set this back so that it - " does not interfere with other ftplugins settings - let b:sql_compl_savefunc=&omnifunc - endif - " Set the OMNI func for the SQL completion plugin - let &omnifunc='sqlcomplete#Complete' -endfunction - -function! sqlcomplete#DrillIntoTable() - " If the omni popup window is visible - if pumvisible() - call sqlcomplete#Map('column') - " C-Y, makes the currently highlighted entry active - " and trigger the omni popup to be redisplayed - call feedkeys("\\\") - else - if has('win32') - " If the popup is not visible, simple perform the normal - " behaviour - exec "normal! \" - endif - endif - return "" -endfunction - -function! sqlcomplete#DrillOutOfColumns() - " If the omni popup window is visible - if pumvisible() - call sqlcomplete#Map('tableReset') - " Trigger the omni popup to be redisplayed - call feedkeys("\\") - else - if has('win32') - " If the popup is not visible, simple perform the normal - " behaviour - exec "normal! \" - endif - endif - return "" -endfunction - -function! s:SQLCWarningMsg(msg) - echohl WarningMsg - echomsg a:msg - echohl None -endfunction - -function! s:SQLCErrorMsg(msg) - echohl ErrorMsg - echomsg a:msg - echohl None -endfunction - -function! s:SQLCGetSyntaxList(syn_group) - let syn_group = a:syn_group - let compl_list = [] - - " Check if we have already cached the syntax list - let list_idx = index(s:syn_list, syn_group, 0, &ignorecase) - if list_idx > -1 - " Return previously cached value - let compl_list = s:syn_value[list_idx] - else - " Request the syntax list items from the - " syntax completion plugin - if syn_group == 'syntax' - " Handle this special case. This allows the user - " to indicate they want all the syntax items available, - " so do not specify a specific include list. - let g:omni_syntax_group_include_sql = '' - else - " The user has specified a specific syntax group - let g:omni_syntax_group_include_sql = syn_group - endif - let g:omni_syntax_group_exclude_sql = '' - let syn_value = OmniSyntaxList() - let g:omni_syntax_group_include_sql = s:save_inc - let g:omni_syntax_group_exclude_sql = s:save_exc - " Cache these values for later use - let s:syn_list = add( s:syn_list, syn_group ) - let s:syn_value = add( s:syn_value, syn_value ) - let compl_list = syn_value - endif - - return compl_list -endfunction - -function! s:SQLCCheck4dbext() - if !exists('g:loaded_dbext') - let msg = "The dbext plugin must be loaded for dynamic SQL completion" - call s:SQLCErrorMsg(msg) - " Leave time for the user to read the error message - :sleep 2 - return -1 - elseif g:loaded_dbext < 600 - let msg = "The dbext plugin must be at least version 5.30 " . - \ " for dynamic SQL completion" - call s:SQLCErrorMsg(msg) - " Leave time for the user to read the error message - :sleep 2 - return -1 - endif - return 1 -endfunction - -function! s:SQLCAddAlias(table_name, table_alias, cols) - " Strip off the owner if included - let table_name = matchstr(a:table_name, '\%(.\{-}\.\)\?\zs\(.*\)' ) - let table_alias = a:table_alias - let cols = a:cols - - if g:omni_sql_use_tbl_alias != 'n' - if table_alias == '' - if 'da' =~? g:omni_sql_use_tbl_alias - if table_name =~ '_' - " Treat _ as separators since people often use these - " for word separators - let save_keyword = &iskeyword - setlocal iskeyword-=_ - - " Get the first letter of each word - " [[:alpha:]] is used instead of \w - " to catch extended accented characters - " - let table_alias = substitute( - \ table_name, - \ '\<[[:alpha:]]\+\>_\?', - \ '\=strpart(submatch(0), 0, 1)', - \ 'g' - \ ) - " Restore original value - let &iskeyword = save_keyword - elseif table_name =~ '\u\U' - let table_alias = substitute( - \ table_name, '\(\u\)\U*', '\1', 'g') - else - let table_alias = strpart(table_name, 0, 1) - endif - endif - endif - if table_alias != '' - " Following a word character, make sure there is a . and no spaces - let table_alias = substitute(table_alias, '\w\zs\.\?\s*$', '.', '') - if 'a' =~? g:omni_sql_use_tbl_alias && a:table_alias == '' - let table_alias = inputdialog("Enter table alias:", table_alias) - endif - endif - if table_alias != '' - let cols = substitute(cols, '\<\w', table_alias.'&', 'g') - endif - endif - - return cols -endfunction - -function! s:SQLCGetObjectOwner(object) - " The owner regex matches a word at the start of the string which is - " followed by a dot, but doesn't include the dot in the result. - " ^ - from beginning of line - " \("\|\[\)\? - ignore any quotes - " \zs - start the match now - " .\{-} - get owner name - " \ze - end the match - " \("\|\[\)\? - ignore any quotes - " \. - must by followed by a . - " let owner = matchstr( a:object, '^\s*\zs.*\ze\.' ) - let owner = matchstr( a:object, '^\("\|\[\)\?\zs\.\{-}\ze\("\|\]\)\?\.' ) - return owner -endfunction - -function! s:SQLCGetColumns(table_name, list_type) - " Check if the table name was provided as part of the column name - let table_name = matchstr(a:table_name, '^["\[\]a-zA-Z0-9_ ]\+\ze\.\?') - let table_cols = [] - let table_alias = '' - let move_to_top = 1 - - let table_name = substitute(table_name, '\s*\(.\{-}\)\s*$', '\1', 'g') - - " If the table name was given as: - " where c. - let table_name = substitute(table_name, '^\c\(WHERE\|AND\|OR\)\s\+', '', '') - if g:loaded_dbext >= 300 - let saveSettingAlias = DB_listOption('use_tbl_alias') - exec 'DBSetOption use_tbl_alias=n' - endif - - let table_name_stripped = substitute(table_name, '["\[\]]*', '', 'g') - - " Check if we have already cached the column list for this table - " by its name - let list_idx = index(s:tbl_name, table_name_stripped, 0, &ignorecase) - if list_idx > -1 - let table_cols = split(s:tbl_cols[list_idx], '\n') - else - " Check if we have already cached the column list for this table - " by its alias, assuming the table_name provided was actually - " the alias for the table instead - " select * - " from area a - " where a. - let list_idx = index(s:tbl_alias, table_name_stripped, 0, &ignorecase) - if list_idx > -1 - let table_alias = table_name_stripped - let table_name = s:tbl_name[list_idx] - let table_cols = split(s:tbl_cols[list_idx], '\n') - endif - endif - - " If we have not found a cached copy of the table - " And the table ends in a "." or we are looking for a column list - " if list_idx == -1 && (a:table_name =~ '\.' || b:sql_compl_type =~ 'column') - " if list_idx == -1 && (a:table_name =~ '\.' || a:list_type =~ 'csv') - if list_idx == -1 - let saveY = @y - let saveSearch = @/ - let saveWScan = &wrapscan - let curline = line(".") - let curcol = col(".") - - " Do not let searchs wrap - setlocal nowrapscan - " If . was entered, look at the word just before the . - " We are looking for something like this: - " select * - " from customer c - " where c. - " So when . is pressed, we need to find 'c' - " - - " Search backwards to the beginning of the statement - " and do NOT wrap - " exec 'silent! normal! v?\<\(select\|update\|delete\|;\)\>'."\n".'"yy' - exec 'silent! normal! ?\<\(select\|update\|delete\|;\)\>'."\n" - - " Start characterwise visual mode - " Advance right one character - " Search foward until one of the following: - " 1. Another select/update/delete statement - " 2. A ; at the end of a line (the delimiter) - " 3. The end of the file (incase no delimiter) - " Yank the visually selected text into the "y register. - exec 'silent! normal! vl/\(\\|\\|\\|;\s*$\|\%$\)'."\n".'"yy' - - let query = @y - let query = substitute(query, "\n", ' ', 'g') - let found = 0 - - " if query =~? '^\(select\|update\|delete\)' - if query =~? '^\(select\)' - let found = 1 - " \(\(\<\w\+\>\)\.\)\? - - " 'from.\{-}' - Starting at the from clause - " '\zs\(\(\<\w\+\>\)\.\)\?' - Get the owner name (optional) - " '\<\w\+\>\ze' - Get the table name - " '\s\+\<'.table_name.'\>' - Followed by the alias - " '\s*\.\@!.*' - Cannot be followed by a . - " '\(\\|$\)' - Must be followed by a WHERE clause - " '.*' - Exclude the rest of the line in the match - let table_name_new = matchstr(@y, - \ 'from.\{-}'. - \ '\zs\(\("\|\[\)\?.\{-}\("\|\]\)\.\)\?'. - \ '\("\|\[\)\?.\{-}\("\|\]\)\ze'. - \ '\s\+\%(as\s\+\)\?\<'. - \ matchstr(table_name, '.\{-}\ze\.\?$'). - \ '\>'. - \ '\s*\.\@!.*'. - \ '\(\\|$\)'. - \ '.*' - \ ) - - if table_name_new != '' - let table_alias = table_name - let table_name = table_name_new - - let list_idx = index(s:tbl_name, table_name, 0, &ignorecase) - if list_idx > -1 - let table_cols = split(s:tbl_cols[list_idx]) - let s:tbl_name[list_idx] = table_name - let s:tbl_alias[list_idx] = table_alias - else - let list_idx = index(s:tbl_alias, table_name, 0, &ignorecase) - if list_idx > -1 - let table_cols = split(s:tbl_cols[list_idx]) - let s:tbl_name[list_idx] = table_name - let s:tbl_alias[list_idx] = table_alias - endif - endif - - endif - else - " Simply assume it is a table name provided with a . on the end - let found = 1 - endif - - let @y = saveY - let @/ = saveSearch - let &wrapscan = saveWScan - - " Return to previous location - call cursor(curline, curcol) - - if found == 0 - if g:loaded_dbext > 300 - exec 'DBSetOption use_tbl_alias='.saveSettingAlias - endif - - " Not a SQL statement, do not display a list - return [] - endif - endif - - if empty(table_cols) - " Specify silent mode, no messages to the user (tbl, 1) - " Specify do not comma separate (tbl, 1, 1) - let table_cols_str = DB_getListColumn(table_name, 1, 1) - - if table_cols_str != "" - let s:tbl_name = add( s:tbl_name, table_name ) - let s:tbl_alias = add( s:tbl_alias, table_alias ) - let s:tbl_cols = add( s:tbl_cols, table_cols_str ) - let table_cols = split(table_cols_str, '\n') - endif - - endif - - if g:loaded_dbext > 300 - exec 'DBSetOption use_tbl_alias='.saveSettingAlias - endif - - " If the user has asked for a comma separate list of column - " values, ask the user if they want to prepend each column - " with a tablename alias. - if a:list_type == 'csv' && !empty(table_cols) - let cols = join(table_cols, ', ') - let cols = s:SQLCAddAlias(table_name, table_alias, cols) - let table_cols = [cols] - endif - - return table_cols -endfunction - diff --git a/share/vim/vim72/autoload/syntaxcomplete.vim b/share/vim/vim72/autoload/syntaxcomplete.vim deleted file mode 100644 index 91f5fab885..0000000000 --- a/share/vim/vim72/autoload/syntaxcomplete.vim +++ /dev/null @@ -1,378 +0,0 @@ -" Vim completion script -" Language: All languages, uses existing syntax highlighting rules -" Maintainer: David Fishburn -" Version: 4.0 -" Last Change: Fri 26 Oct 2007 05:27:03 PM Eastern Daylight Time -" Usage: For detailed help, ":help ft-syntax-omni" - -" Set completion with CTRL-X CTRL-O to autoloaded function. -" This check is in place in case this script is -" sourced directly instead of using the autoload feature. -if exists('+omnifunc') - " Do not set the option if already set since this - " results in an E117 warning. - if &omnifunc == "" - setlocal omnifunc=syntaxcomplete#Complete - endif -endif - -if exists('g:loaded_syntax_completion') - finish -endif -let g:loaded_syntax_completion = 40 - -" Set ignorecase to the ftplugin standard -" This is the default setting, but if you define a buffer local -" variable you can override this on a per filetype. -if !exists('g:omni_syntax_ignorecase') - let g:omni_syntax_ignorecase = &ignorecase -endif - -" Indicates whether we should use the iskeyword option to determine -" how to split words. -" This is the default setting, but if you define a buffer local -" variable you can override this on a per filetype. -if !exists('g:omni_syntax_use_iskeyword') - let g:omni_syntax_use_iskeyword = 1 -endif - -" Only display items in the completion window that are at least -" this many characters in length. -" This is the default setting, but if you define a buffer local -" variable you can override this on a per filetype. -if !exists('g:omni_syntax_minimum_length') - let g:omni_syntax_minimum_length = 0 -endif - -" This script will build a completion list based on the syntax -" elements defined by the files in $VIMRUNTIME/syntax. -let s:syn_remove_words = 'match,matchgroup=,contains,'. - \ 'links to,start=,end=,nextgroup=' - -let s:cache_name = [] -let s:cache_list = [] -let s:prepended = '' - -" This function is used for the 'omnifunc' option. -function! syntaxcomplete#Complete(findstart, base) - - " Only display items in the completion window that are at least - " this many characters in length - if !exists('b:omni_syntax_ignorecase') - if exists('g:omni_syntax_ignorecase') - let b:omni_syntax_ignorecase = g:omni_syntax_ignorecase - else - let b:omni_syntax_ignorecase = &ignorecase - endif - endif - - if a:findstart - " Locate the start of the item, including "." - let line = getline('.') - let start = col('.') - 1 - let lastword = -1 - while start > 0 - " if line[start - 1] =~ '\S' - " let start -= 1 - " elseif line[start - 1] =~ '\.' - if line[start - 1] =~ '\k' - let start -= 1 - let lastword = a:findstart - else - break - endif - endwhile - - " Return the column of the last word, which is going to be changed. - " Remember the text that comes before it in s:prepended. - if lastword == -1 - let s:prepended = '' - return start - endif - let s:prepended = strpart(line, start, (col('.') - 1) - start) - return start - endif - - " let base = s:prepended . a:base - let base = s:prepended - - let filetype = substitute(&filetype, '\.', '_', 'g') - let list_idx = index(s:cache_name, filetype, 0, &ignorecase) - if list_idx > -1 - let compl_list = s:cache_list[list_idx] - else - let compl_list = OmniSyntaxList() - let s:cache_name = add( s:cache_name, filetype ) - let s:cache_list = add( s:cache_list, compl_list ) - endif - - " Return list of matches. - - if base != '' - " let compstr = join(compl_list, ' ') - " let expr = (b:omni_syntax_ignorecase==0?'\C':'').'\<\%('.base.'\)\@!\w\+\s*' - " let compstr = substitute(compstr, expr, '', 'g') - " let compl_list = split(compstr, '\s\+') - - " Filter the list based on the first few characters the user - " entered - let expr = 'v:val '.(g:omni_syntax_ignorecase==1?'=~?':'=~#')." '^".escape(base, '\\/.*$^~[]').".*'" - let compl_list = filter(deepcopy(compl_list), expr) - endif - - return compl_list -endfunc - -function! OmniSyntaxList() - " Default to returning a dictionary, if use_dictionary is set to 0 - " a list will be returned. - " let use_dictionary = 1 - " if a:0 > 0 && a:1 != '' - " let use_dictionary = a:1 - " endif - - " Only display items in the completion window that are at least - " this many characters in length - if !exists('b:omni_syntax_use_iskeyword') - if exists('g:omni_syntax_use_iskeyword') - let b:omni_syntax_use_iskeyword = g:omni_syntax_use_iskeyword - else - let b:omni_syntax_use_iskeyword = 1 - endif - endif - - " Only display items in the completion window that are at least - " this many characters in length - if !exists('b:omni_syntax_minimum_length') - if exists('g:omni_syntax_minimum_length') - let b:omni_syntax_minimum_length = g:omni_syntax_minimum_length - else - let b:omni_syntax_minimum_length = 0 - endif - endif - - let saveL = @l - - " Loop through all the syntax groupnames, and build a - " syntax file which contains these names. This can - " work generically for any filetype that does not already - " have a plugin defined. - " This ASSUMES the syntax groupname BEGINS with the name - " of the filetype. From my casual viewing of the vim7\syntax - " directory. - redir @l - silent! exec 'syntax list ' - redir END - - let syntax_full = "\n".@l - let @l = saveL - - if syntax_full =~ 'E28' - \ || syntax_full =~ 'E411' - \ || syntax_full =~ 'E415' - \ || syntax_full =~ 'No Syntax items' - return [] - endif - - let filetype = substitute(&filetype, '\.', '_', 'g') - - " Default the include group to include the requested syntax group - let syntax_group_include_{filetype} = '' - " Check if there are any overrides specified for this filetype - if exists('g:omni_syntax_group_include_'.filetype) - let syntax_group_include_{filetype} = - \ substitute( g:omni_syntax_group_include_{filetype},'\s\+','','g') - if syntax_group_include_{filetype} =~ '\w' - let syntax_group_include_{filetype} = - \ substitute( syntax_group_include_{filetype}, - \ '\s*,\s*', '\\|', 'g' - \ ) - endif - endif - - " Default the exclude group to nothing - let syntax_group_exclude_{filetype} = '' - " Check if there are any overrides specified for this filetype - if exists('g:omni_syntax_group_exclude_'.filetype) - let syntax_group_exclude_{filetype} = - \ substitute( g:omni_syntax_group_exclude_{filetype},'\s\+','','g') - if syntax_group_exclude_{filetype} =~ '\w' - let syntax_group_exclude_{filetype} = - \ substitute( syntax_group_exclude_{filetype}, - \ '\s*,\s*', '\\|', 'g' - \ ) - endif - endif - - " Sometimes filetypes can be composite names, like c.doxygen - " Loop through each individual part looking for the syntax - " items specific to each individual filetype. - let syn_list = '' - let ftindex = 0 - let ftindex = match(&filetype, '\w\+', ftindex) - - while ftindex > -1 - let ft_part_name = matchstr( &filetype, '\w\+', ftindex ) - - " Syntax rules can contain items for more than just the current - " filetype. They can contain additional items added by the user - " via autocmds or their vimrc. - " Some syntax files can be combined (html, php, jsp). - " We want only items that begin with the filetype we are interested in. - let next_group_regex = '\n' . - \ '\zs'.ft_part_name.'\w\+\ze'. - \ '\s\+xxx\s\+' - let index = 0 - let index = match(syntax_full, next_group_regex, index) - - while index > -1 - let group_name = matchstr( syntax_full, '\w\+', index ) - - let get_syn_list = 1 - " if syntax_group_include_{&filetype} == '' - " if syntax_group_exclude_{&filetype} != '' - " if '\<'.syntax_group_exclude_{&filetype}.'\>' =~ '\<'.group_name.'\>' - " let get_syn_list = 0 - " endif - " endif - " else - " if '\<'.syntax_group_include_{&filetype}.'\>' !~ '\<'.group_name.'\>' - " let get_syn_list = 0 - " endif - " endif - if syntax_group_exclude_{filetype} != '' - if '\<'.syntax_group_exclude_{filetype}.'\>' =~ '\<'.group_name.'\>' - let get_syn_list = 0 - endif - endif - - if get_syn_list == 1 - if syntax_group_include_{filetype} != '' - if '\<'.syntax_group_include_{filetype}.'\>' !~ '\<'.group_name.'\>' - let get_syn_list = 0 - endif - endif - endif - - if get_syn_list == 1 - " Pass in the full syntax listing, plus the group name we - " are interested in. - let extra_syn_list = s:SyntaxCSyntaxGroupItems(group_name, syntax_full) - - " if !empty(extra_syn_list) - " for elem in extra_syn_list - " let item = {'word':elem, 'kind':'t', 'info':group_name} - " let compl_list += [item] - " endfor - " endif - - let syn_list = syn_list . extra_syn_list . "\n" - endif - - let index = index + strlen(group_name) - let index = match(syntax_full, next_group_regex, index) - endwhile - - let ftindex = ftindex + len(ft_part_name) - let ftindex = match( &filetype, '\w\+', ftindex ) - endwhile - - " Convert the string to a List and sort it. - let compl_list = sort(split(syn_list)) - - if &filetype == 'vim' - let short_compl_list = [] - for i in range(len(compl_list)) - if i == len(compl_list)-1 - let next = i - else - let next = i + 1 - endif - if compl_list[next] !~ '^'.compl_list[i].'.$' - let short_compl_list += [compl_list[i]] - endif - endfor - - return short_compl_list - else - return compl_list - endif -endfunction - -function! s:SyntaxCSyntaxGroupItems( group_name, syntax_full ) - - let syn_list = "" - - " From the full syntax listing, strip out the portion for the - " request group. - " Query: - " \n - must begin with a newline - " a:group_name - the group name we are interested in - " \s\+xxx\s\+ - group names are always followed by xxx - " \zs - start the match - " .\{-} - everything ... - " \ze - end the match - " \n\w - at the first newline starting with a character - let syntax_group = matchstr(a:syntax_full, - \ "\n".a:group_name.'\s\+xxx\s\+\zs.\{-}\ze'."\n".'\w' - \ ) - - if syntax_group != "" - " let syn_list = substitute( @l, '^.*xxx\s*\%(contained\s*\)\?', "", '' ) - " let syn_list = substitute( @l, '^.*xxx\s*', "", '' ) - - " We only want the words for the lines begining with - " containedin, but there could be other items. - - " Tried to remove all lines that do not begin with contained - " but this does not work in all cases since you can have - " contained nextgroup=... - " So this will strip off the ending of lines with known - " keywords. - let syn_list = substitute( - \ syntax_group, '\<\('. - \ substitute( - \ escape(s:syn_remove_words, '\\/.*$^~[]') - \ , ',', '\\|', 'g' - \ ). - \ '\).\{-}\%($\|'."\n".'\)' - \ , "\n", 'g' - \ ) - - " Now strip off the newline + blank space + contained - let syn_list = substitute( - \ syn_list, '\%(^\|\n\)\@<=\s*\<\(contained\)' - \ , "", 'g' - \ ) - - if b:omni_syntax_use_iskeyword == 0 - " There are a number of items which have non-word characters in - " them, *'T_F1'*. vim.vim is one such file. - " This will replace non-word characters with spaces. - let syn_list = substitute( syn_list, '[^0-9A-Za-z_ ]', ' ', 'g' ) - else - let accept_chars = ','.&iskeyword.',' - " Remove all character ranges - " let accept_chars = substitute(accept_chars, ',[^,]\+-[^,]\+,', ',', 'g') - let accept_chars = substitute(accept_chars, ',\@<=[^,]\+-[^,]\+,', '', 'g') - " Remove all numeric specifications - " let accept_chars = substitute(accept_chars, ',\d\{-},', ',', 'g') - let accept_chars = substitute(accept_chars, ',\@<=\d\{-},', '', 'g') - " Remove all commas - let accept_chars = substitute(accept_chars, ',', '', 'g') - " Escape special regex characters - let accept_chars = escape(accept_chars, '\\/.*$^~[]' ) - " Remove all characters that are not acceptable - let syn_list = substitute( syn_list, '[^0-9A-Za-z_ '.accept_chars.']', ' ', 'g' ) - endif - - if b:omni_syntax_minimum_length > 0 - " If the user specified a minimum length, enforce it - let syn_list = substitute(' '.syn_list.' ', ' \S\{,'.b:omni_syntax_minimum_length.'}\ze ', ' ', 'g') - endif - else - let syn_list = '' - endif - - return syn_list -endfunction diff --git a/share/vim/vim72/autoload/tar.vim b/share/vim/vim72/autoload/tar.vim deleted file mode 100644 index af6fbca2e1..0000000000 --- a/share/vim/vim72/autoload/tar.vim +++ /dev/null @@ -1,500 +0,0 @@ -" tar.vim: Handles browsing tarfiles -" AUTOLOAD PORTION -" Date: Aug 08, 2008 -" Version: 23 + modifications by Bram -" Maintainer: Charles E Campbell, Jr -" License: Vim License (see vim's :help license) -" -" Contains many ideas from Michael Toren's -" -" Copyright: Copyright (C) 2005-2008 Charles E. Campbell, Jr. {{{1 -" Permission is hereby granted to use and distribute this code, -" with or without modifications, provided that this copyright -" notice is copied with it. Like anything else that's free, -" tar.vim and tarPlugin.vim are provided *as is* and comes -" with no warranty of any kind, either expressed or implied. -" By using this plugin, you agree that in no event will the -" copyright holder be liable for any damages resulting from -" the use of this software. - -" --------------------------------------------------------------------- -" Load Once: {{{1 -let s:keepcpo= &cpo -set cpo&vim -if &cp || exists("g:loaded_tar") || v:version < 700 - finish -endif -let g:loaded_tar= "v23b" -"call Decho("loading autoload/tar.vim") -if v:version < 701 || (v:version == 701 && !has("patch299")) - echoerr "(autoload/tar.vim) need vim v7.1 with patchlevel 299" -endif - -" --------------------------------------------------------------------- -" Default Settings: {{{1 -if !exists("g:tar_browseoptions") - let g:tar_browseoptions= "Ptf" -endif -if !exists("g:tar_readoptions") - let g:tar_readoptions= "OPxf" -endif -if !exists("g:tar_cmd") - let g:tar_cmd= "tar" -endif -if !exists("g:tar_writeoptions") - let g:tar_writeoptions= "uf" -endif - -if !exists("g:netrw_cygwin") - if has("win32") || has("win95") || has("win64") || has("win16") - if &shell =~ '\%(\\|\\)\%(\.exe\)\=$' - let g:netrw_cygwin= 1 - else - let g:netrw_cygwin= 0 - endif - else - let g:netrw_cygwin= 0 - endif -endif - -" set up shell quoting character -if !exists("g:tar_shq") - if exists("&shq") && &shq != "" - let g:tar_shq= &shq - elseif has("win32") || has("win95") || has("win64") || has("win16") - if exists("g:netrw_cygwin") && g:netrw_cygwin - let g:tar_shq= "'" - else - let g:tar_shq= '"' - endif - else - let g:tar_shq= "'" - endif -" call Decho("g:tar_shq<".g:tar_shq.">") -endif - -" ---------------- -" Functions: {{{1 -" ---------------- - -" --------------------------------------------------------------------- -" tar#Browse: {{{2 -fun! tar#Browse(tarfile) -" call Dfunc("tar#Browse(tarfile<".a:tarfile.">)") - let repkeep= &report - set report=10 - - " sanity checks - if !executable(g:tar_cmd) - redraw! - echohl Error | echo '***error*** (tar#Browse) "'.g:tar_cmd.'" not available on your system' -" call inputsave()|call input("Press to continue")|call inputrestore() - let &report= repkeep -" call Dret("tar#Browse") - return - endif - if !filereadable(a:tarfile) -" call Decho('a:tarfile<'.a:tarfile.'> not filereadable') - if a:tarfile !~# '^\a\+://' - " if its an url, don't complain, let url-handlers such as vim do its thing - redraw! - echohl Error | echo "***error*** (tar#Browse) File not readable<".a:tarfile.">" | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - endif - let &report= repkeep -" call Dret("tar#Browse : file<".a:tarfile."> not readable") - return - endif - if &ma != 1 - set ma - endif - let w:tarfile= a:tarfile - - setlocal noswapfile - setlocal buftype=nofile - setlocal bufhidden=hide - setlocal nobuflisted - setlocal nowrap - set ft=tar - - " give header -" call Decho("printing header") - let lastline= line("$") - call setline(lastline+1,'" tar.vim version '.g:loaded_tar) - call setline(lastline+2,'" Browsing tarfile '.a:tarfile) - call setline(lastline+3,'" Select a file with cursor and press ENTER') - $put ='' - 0d - $ - - let tarfile= a:tarfile - if has("win32") && executable("cygpath") - " assuming cygwin - let tarfile=substitute(system("cygpath -u ".s:Escape(tarfile,0)),'\n$','','e') - endif - let curlast= line("$") - if tarfile =~# '\.\(gz\|tgz\)$' -" call Decho("1: exe silent r! gzip -d -c -- ".s:Escape(tarfile,1)." | ".g:tar_cmd." -".g:tar_browseoptions." - ") - exe "silent r! gzip -d -c -- ".s:Escape(tarfile,1)." | ".g:tar_cmd." -".g:tar_browseoptions." - " - elseif tarfile =~# '\.lrp' -" call Decho("2: exe silent r! cat -- ".s:Escape(tarfile,1)."|gzip -d -c -|".g:tar_cmd." -".g:tar_browseoptions." - ") - exe "silent r! cat -- ".s:Escape(tarfile,1)."|gzip -d -c -|".g:tar_cmd." -".g:tar_browseoptions." - " - elseif tarfile =~# '\.bz2$' -" call Decho("3: exe silent r! bzip2 -d -c -- ".s:Escape(tarfile,1)." | ".g:tar_cmd." -".g:tar_browseoptions." - ") - exe "silent r! bzip2 -d -c -- ".s:Escape(tarfile,1)." | ".g:tar_cmd." -".g:tar_browseoptions." - " - else - if tarfile =~ '^\s*-' - " A file name starting with a dash may be taken as an option. Prepend ./ to avoid that. - let tarfile = substitute(tarfile, '-', './-', '') - endif -" call Decho("4: exe silent r! ".g:tar_cmd." -".g:tar_browseoptions." ".s:Escape(tarfile,1)) - exe "silent r! ".g:tar_cmd." -".g:tar_browseoptions." ".s:Escape(tarfile,1) - endif - if v:shell_error != 0 - redraw! - echohl WarningMsg | echo "***warning*** (tar#Browse) please check your g:tar_browseoptions<".g:tar_browseoptions.">" -" call inputsave()|call input("Press to continue")|call inputrestore() -" call Dret("tar#Browse : a:tarfile<".a:tarfile.">") - return - endif - if line("$") == curlast || ( line("$") == (curlast + 1) && getline("$") =~ '\c\%(warning\|error\|inappropriate\|unrecognized\)') - redraw! - echohl WarningMsg | echo "***warning*** (tar#Browse) ".a:tarfile." doesn't appear to be a tar file" | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - silent %d - let eikeep= &ei - set ei=BufReadCmd,FileReadCmd - exe "r ".fnameescape(a:tarfile) - let &ei= eikeep - 1d -" call Dret("tar#Browse : a:tarfile<".a:tarfile.">") - return - endif - - setlocal noma nomod ro - noremap :call TarBrowseSelect() - - let &report= repkeep -" call Dret("tar#Browse : w:tarfile<".w:tarfile.">") -endfun - -" --------------------------------------------------------------------- -" TarBrowseSelect: {{{2 -fun! s:TarBrowseSelect() -" call Dfunc("TarBrowseSelect() w:tarfile<".w:tarfile."> curfile<".expand("%").">") - let repkeep= &report - set report=10 - let fname= getline(".") -" call Decho("fname<".fname.">") - - if !exists("g:tar_secure") && fname =~ '^\s*-\|\s\+-' - redraw! - echohl WarningMsg | echo '***error*** (tar#BrowseSelect) rejecting tarfile member<'.fname.'> because of embedded "-"; See :help tar-options' -" call Dret('tar#BrowseSelect : rejecting tarfile member<'.fname.'> because of embedded "-"') - return - endif - - " sanity check - if fname =~ '^"' - let &report= repkeep -" call Dret("TarBrowseSelect") - return - endif - - " about to make a new window, need to use w:tarfile - let tarfile= w:tarfile - let curfile= expand("%") - if has("win32") && executable("cygpath") - " assuming cygwin - let tarfile=substitute(system("cygpath -u ".s:Escape(tarfile,0)),'\n$','','e') - endif - - new - if !exists("g:tar_nomax") || g:tar_nomax == 0 - wincmd _ - endif - let s:tblfile_{winnr()}= curfile - call tar#Read("tarfile:".tarfile.'::'.fname,1) - filetype detect - - let &report= repkeep -" call Dret("TarBrowseSelect : s:tblfile_".winnr()."<".s:tblfile_{winnr()}.">") -endfun - -" --------------------------------------------------------------------- -" tar#Read: {{{2 -fun! tar#Read(fname,mode) -" call Dfunc("tar#Read(fname<".a:fname.">,mode=".a:mode.")") - let repkeep= &report - set report=10 - let tarfile = substitute(a:fname,'tarfile:\(.\{-}\)::.*$','\1','') - let fname = substitute(a:fname,'tarfile:.\{-}::\(.*\)$','\1','') - if has("win32") && executable("cygpath") - " assuming cygwin - let tarfile=substitute(system("cygpath -u ".s:Escape(tarfile,0)),'\n$','','e') - endif -" call Decho("tarfile<".tarfile.">") -" call Decho("fname<".fname.">") - - if fname =~ '\.gz$' && executable("zcat") - let decmp= "|zcat" - let doro = 1 - elseif fname =~ '\.bz2$' && executable("bzcat") - let decmp= "|bzcat" - let doro = 1 - else - let decmp="" - let doro = 0 - if fname =~ '\.gz$\|\.bz2$\|\.Z$\|\.zip$' - setlocal bin - endif - endif - - if exists("g:tar_secure") - let tar_secure= " -- " - else - let tar_secure= " " - endif - if tarfile =~# '\.\(gz\|tgz\)$' -" call Decho("5: exe silent r! gzip -d -c -- ".s:Escape(tarfile,1)."| ".g:tar_cmd.' -'.g:tar_readoptions.' - '.tar_secure.s:Escape(fname,1)) - exe "silent r! gzip -d -c -- ".s:Escape(tarfile,1)."| ".g:tar_cmd." -".g:tar_readoptions." - ".tar_secure.s:Escape(fname,1).decmp - elseif tarfile =~# '\.lrp$' -" call Decho("6: exe silent r! cat ".s:Escape(tarfile,1)." | gzip -d -c - | ".g:tar_cmd." -".g:tar_readoptions." - ".tar_secure.s:Escape(fname,1).decmp) - exe "silent r! cat -- ".s:Escape(tarfile,1)." | gzip -d -c - | ".g:tar_cmd." -".g:tar_readoptions." - ".tar_secure.s:Escape(fname,1).decmp - elseif tarfile =~# '\.bz2$' -" call Decho("7: exe silent r! bzip2 -d -c ".s:Escape(tarfile,1)."| ".g:tar_cmd." -".g:tar_readoptions." - ".tar_secure.s:Escape(fname,1).decmp) - exe "silent r! bzip2 -d -c -- ".s:Escape(tarfile,1)."| ".g:tar_cmd." -".g:tar_readoptions." - ".tar_secure.s:Escape(fname,1).decmp - else - if tarfile =~ '^\s*-' - " A file name starting with a dash may be taken as an option. Prepend ./ to avoid that. - let tarfile = substitute(tarfile, '-', './-', '') - endif -" call Decho("8: exe silent r! ".g:tar_cmd." -".g:tar_readoptions." "s:Escape(tarfile,1).tar_secure..s:Escape(fname,1).decmp) - exe "silent r! ".g:tar_cmd." -".g:tar_readoptions." ".s:Escape(tarfile,1).tar_secure.s:Escape(fname,1).decmp - endif - - if doro - " because the reverse process of compressing changed files back into the tarball is not currently supported - setlocal ro - endif - - let w:tarfile= a:fname - exe "file tarfile::".fnameescape(fname) - - " cleanup - 0d - set nomod - - let &report= repkeep -" call Dret("tar#Read : w:tarfile<".w:tarfile.">") -endfun - -" --------------------------------------------------------------------- -" tar#Write: {{{2 -fun! tar#Write(fname) -" call Dfunc("tar#Write(fname<".a:fname.">) w:tarfile<".w:tarfile."> tblfile_".winnr()."<".s:tblfile_{winnr()}.">") - let repkeep= &report - set report=10 - - if !exists("g:tar_secure") && a:fname =~ '^\s*-\|\s\+-' - redraw! - echohl WarningMsg | echo '***error*** (tar#Write) rejecting tarfile member<'.a:fname.'> because of embedded "-"; See :help tar-options' -" call Dret('tar#Write : rejecting tarfile member<'.fname.'> because of embedded "-"') - return - endif - - " sanity checks - if !executable(g:tar_cmd) - redraw! - echohl Error | echo '***error*** (tar#Browse) "'.g:tar_cmd.'" not available on your system' -" call inputsave()|call input("Press to continue")|call inputrestore() - let &report= repkeep -" call Dret("tar#Write") - return - endif - if !exists("*mkdir") - redraw! - echohl Error | echo "***error*** (tar#Write) sorry, mkdir() doesn't work on your system" | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - let &report= repkeep -" call Dret("tar#Write") - return - endif - - let curdir= getcwd() - let tmpdir= tempname() -" call Decho("orig tempname<".tmpdir.">") - if tmpdir =~ '\.' - let tmpdir= substitute(tmpdir,'\.[^.]*$','','e') - endif -" call Decho("tmpdir<".tmpdir.">") - call mkdir(tmpdir,"p") - - " attempt to change to the indicated directory - try - exe "cd ".fnameescape(tmpdir) - catch /^Vim\%((\a\+)\)\=:E344/ - redraw! - echohl Error | echo "***error*** (tar#Write) cannot cd to temporary directory" | Echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - let &report= repkeep -" call Dret("tar#Write") - return - endtry -" call Decho("current directory now: ".getcwd()) - - " place temporary files under .../_ZIPVIM_/ - if isdirectory("_ZIPVIM_") - call s:Rmdir("_ZIPVIM_") - endif - call mkdir("_ZIPVIM_") - cd _ZIPVIM_ -" call Decho("current directory now: ".getcwd()) - - let tarfile = substitute(w:tarfile,'tarfile:\(.\{-}\)::.*$','\1','') - let fname = substitute(w:tarfile,'tarfile:.\{-}::\(.*\)$','\1','') - - " handle compressed archives - if tarfile =~# '\.gz' - call system("gzip -d -- ".s:Escape(tarfile,0)) - let tarfile = substitute(tarfile,'\.gz','','e') - let compress= "gzip -- ".s:Escape(tarfile,0) -" call Decho("compress<".compress.">") - elseif tarfile =~# '\.tgz' - call system("gzip -d -- ".s:Escape(tarfile,0)) - let tarfile = substitute(tarfile,'\.tgz','.tar','e') - let compress= "gzip -- ".s:Escape(tarfile,0) - let tgz = 1 -" call Decho("compress<".compress.">") - elseif tarfile =~# '\.bz2' - call system("bzip2 -d -- ".s:Escape(tarfile,0)) - let tarfile = substitute(tarfile,'\.bz2','','e') - let compress= "bzip2 -- ".s:Escape(tarfile,0) -" call Decho("compress<".compress.">") - endif -" call Decho("tarfile<".tarfile.">") - - if v:shell_error != 0 - redraw! - echohl Error | echo "***error*** (tar#Write) sorry, unable to update ".tarfile." with ".fname | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - else - -" call Decho("tarfile<".tarfile."> fname<".fname.">") - - if fname =~ '/' - let dirpath = substitute(fname,'/[^/]\+$','','e') - if executable("cygpath") - let dirpath = substitute(system("cygpath ".s:Escape(dirpath, 0)),'\n','','e') - endif - call mkdir(dirpath,"p") - endif - if tarfile !~ '/' - let tarfile= curdir.'/'.tarfile - endif - if tarfile =~ '^\s*-' - " A file name starting with a dash may be taken as an option. Prepend ./ to avoid that. - let tarfile = substitute(tarfile, '-', './-', '') - endif -" call Decho("tarfile<".tarfile."> fname<".fname.">") - - if exists("g:tar_secure") - let tar_secure= " -- " - else - let tar_secure= " " - endif - exe "w! ".fnameescape(fname) - if executable("cygpath") - let tarfile = substitute(system("cygpath ".s:Escape(tarfile,0)),'\n','','e') - endif - - " delete old file from tarfile -" call Decho("system(".g:tar_cmd." --delete -f ".s:Escape(tarfile,0)." -- ".s:Escape(fname,0).")") - call system(g:tar_cmd." --delete -f ".s:Escape(tarfile,0).tar_secure.s:Escape(fname,0)) - if v:shell_error != 0 - redraw! - echohl Error | echo "***error*** (tar#Write) sorry, unable to update ".fnameescape(tarfile)." with ".fnameescape(fname) | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - else - - " update tarfile with new file -" call Decho(g:tar_cmd." -".g:tar_writeoptions." ".s:Escape(tarfile,0).tar_secure.s:Escape(fname,0)) - call system(g:tar_cmd." -".g:tar_writeoptions." ".s:Escape(tarfile,0).tar_secure.s:Escape(fname,0)) - if v:shell_error != 0 - redraw! - echohl Error | echo "***error*** (tar#Write) sorry, unable to update ".fnameescape(tarfile)." with ".fnameescape(fname) | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - elseif exists("compress") -" call Decho("call system(".compress.")") - call system(compress) - if exists("tgz") -" call Decho("rename(".tarfile.".gz,".substitute(tarfile,'\.tar$','.tgz','e').")") - call rename(tarfile.".gz",substitute(tarfile,'\.tar$','.tgz','e')) - endif - endif - endif - - " support writing tarfiles across a network - if s:tblfile_{winnr()} =~ '^\a\+://' -" call Decho("handle writing <".tarfile."> across network to <".s:tblfile_{winnr()}.">") - let tblfile= s:tblfile_{winnr()} - 1split|enew - let binkeep= &binary - let eikeep = &ei - set binary ei=all - exe "e! ".fnameescape(tarfile) - call netrw#NetWrite(tblfile) - let &ei = eikeep - let &binary = binkeep - q! - unlet s:tblfile_{winnr()} - endif - endif - - " cleanup and restore current directory - cd .. - call s:Rmdir("_ZIPVIM_") - exe "cd ".fnameescape(curdir) - setlocal nomod - - let &report= repkeep -" call Dret("tar#Write") -endfun - -" --------------------------------------------------------------------- -" Rmdir: {{{2 -fun! s:Rmdir(fname) -" call Dfunc("Rmdir(fname<".a:fname.">)") - if has("unix") - call system("/bin/rm -rf -- ".s:Escape(a:fname,0)) - elseif has("win32") || has("win95") || has("win64") || has("win16") - if &shell =~? "sh$" - call system("/bin/rm -rf -- ".s:Escape(a:fname,0)) - else - call system("del /S ".s:Escape(a:fname,0)) - endif - endif -" call Dret("Rmdir") -endfun - -" --------------------------------------------------------------------- -" s:Escape: {{{2 -fun s:Escape(name,isfilt) - " shellescape() was added by patch 7.0.111 - if exists("*shellescape") - if a:isfilt - let qnameq= shellescape(a:name,1) - else - let qnameq= shellescape(a:name) - endif - else - let qnameq= g:tar_shq . a:name . g:tar_shq - endif - return qnameq -endfun - -" --------------------------------------------------------------------- -" Modelines And Restoration: {{{1 -let &cpo= s:keepcpo -unlet s:keepcpo -" vim:ts=8 fdm=marker diff --git a/share/vim/vim72/autoload/vimball.vim b/share/vim/vim72/autoload/vimball.vim deleted file mode 100644 index 4f6292b9c0..0000000000 --- a/share/vim/vim72/autoload/vimball.vim +++ /dev/null @@ -1,762 +0,0 @@ -" vimball.vim : construct a file containing both paths and files -" Author: Charles E. Campbell, Jr. -" Date: Jul 30, 2008 -" Version: 29 -" GetLatestVimScripts: 1502 1 :AutoInstall: vimball.vim -" Copyright: (c) 2004-2008 by Charles E. Campbell, Jr. -" The VIM LICENSE applies to Vimball.vim, and Vimball.txt -" (see |copyright|) except use "Vimball" instead of "Vim". -" No warranty, express or implied. -" *** *** Use At-Your-Own-Risk! *** *** - -" --------------------------------------------------------------------- -" Load Once: {{{1 -if &cp || exists("g:loaded_vimball") || v:version < 700 - finish -endif -let s:keepcpo = &cpo -let g:loaded_vimball = "v29" -set cpo&vim -"DechoTabOn - -" ===================================================================== -" Constants: {{{1 -if !exists("s:USAGE") - let s:USAGE = 0 - let s:WARNING = 1 - let s:ERROR = 2 - - " determine if cygwin is in use or not - if !exists("g:netrw_cygwin") - if has("win32") || has("win95") || has("win64") || has("win16") - if &shell =~ '\%(\\|\\)\%(\.exe\)\=$' - let g:netrw_cygwin= 1 - else - let g:netrw_cygwin= 0 - endif - else - let g:netrw_cygwin= 0 - endif - endif - - " set up g:vimball_mkdir if the mkdir() call isn't defined - if !exists("*mkdir") - if exists("g:netrw_local_mkdir") - let g:vimball_mkdir= g:netrw_local_mkdir - elseif executable("mkdir") - let g:vimball_mkdir= "mkdir" - elseif executable("makedir") - let g:vimball_mkdir= "makedir" - endif - if !exists(g:vimball_mkdir) - call vimball#ShowMesg(s:WARNING,"(vimball) g:vimball_mkdir undefined") - endif - endif - - " set up shell quoting character - if exists("g:vimball_shq") && !exists("g:netrw_shq") - let g:netrw_shq= g:vimball_shq - endif - if !exists("g:netrw_shq") - if exists("&shq") && &shq != "" - let g:netrw_shq= &shq - elseif has("win32") || has("win95") || has("win64") || has("win16") - if g:netrw_cygwin - let g:netrw_shq= "'" - else - let g:netrw_shq= '"' - endif - else - let g:netrw_shq= "'" - endif -" call Decho("g:netrw_shq<".g:netrw_shq.">") - endif - - " set up escape string (used to protect paths) - if !exists("g:vimball_path_escape") - let g:vimball_path_escape= ' ;#%' - endif -endif - -" ===================================================================== -" Functions: {{{1 - -" --------------------------------------------------------------------- -" vimball#MkVimball: creates a vimball given a list of paths to files {{{2 -" Input: -" line1,line2: a range of lines containing paths to files to be included in the vimball -" writelevel : if true, force a write to filename.vba, even if it exists -" (usually accomplished with :MkVimball! ... -" filename : base name of file to be created (ie. filename.vba) -" Output: a filename.vba using vimball format: -" path -" filesize -" [file] -" path -" filesize -" [file] -fun! vimball#MkVimball(line1,line2,writelevel,...) range -" call Dfunc("MkVimball(line1=".a:line1." line2=".a:line2." writelevel=".a:writelevel." vimballname<".a:1.">) a:0=".a:0) - if a:1 =~ '\.vim$' || a:1 =~ '\.txt$' - let vbname= substitute(a:1,'\.\a\{3}$','.vba','') - else - let vbname= a:1 - endif - if vbname !~ '\.vba$' - let vbname= vbname.'.vba' - endif -" call Decho("vbname<".vbname.">") - if a:1 =~ '[\/]' - call vimball#ShowMesg(s:ERROR,"(MkVimball) vimball name<".a:1."> should not include slashes") -" call Dret("MkVimball : vimball name<".a:1."> should not include slashes") - return - endif - if !a:writelevel && filereadable(vbname) - call vimball#ShowMesg(s:ERROR,"(MkVimball) file<".vbname."> exists; use ! to insist") -" call Dret("MkVimball : file<".vbname."> already exists; use ! to insist") - return - endif - - " user option bypass - call vimball#SaveSettings() - - if a:0 >= 2 - " allow user to specify where to get the files - let home= expand(a:2) - else - " use first existing directory from rtp - let home= s:VimballHome() - endif - - " save current directory - let curdir = getcwd() - call s:ChgDir(home) - - " record current tab, initialize while loop index - let curtabnr = tabpagenr() - let linenr = a:line1 -" call Decho("curtabnr=".curtabnr) - - while linenr <= a:line2 - let svfile = getline(linenr) -" call Decho("svfile<".svfile.">") - - if !filereadable(svfile) - call vimball#ShowMesg(s:ERROR,"unable to read file<".svfile.">") - call s:ChgDir(curdir) - call vimball#RestoreSettings() -" call Dret("MkVimball") - return - endif - - " create/switch to mkvimball tab - if !exists("vbtabnr") - tabnew - silent! file Vimball - let vbtabnr= tabpagenr() - else - exe "tabn ".vbtabnr - endif - - let lastline= line("$") + 1 - if lastline == 2 && getline("$") == "" - call setline(1,'" Vimball Archiver by Charles E. Campbell, Jr., Ph.D.') - call setline(2,'UseVimball') - call setline(3,'finish') - let lastline= line("$") + 1 - endif - call setline(lastline ,substitute(svfile,'$',' [[[1','')) - call setline(lastline+1,0) - - " write the file from the tab -" call Decho("exe $r ".fnameescape(svfile)) - exe "$r ".fnameescape(svfile) - - call setline(lastline+1,line("$") - lastline - 1) -" call Decho("lastline=".lastline." line$=".line("$")) - - " restore to normal tab - exe "tabn ".curtabnr - let linenr= linenr + 1 - endwhile - - " write the vimball - exe "tabn ".vbtabnr - call s:ChgDir(curdir) - setlocal ff=unix - if a:writelevel -" call Decho("exe w! ".fnameescape(vbname)) - exe "w! ".fnameescape(vbname) - else -" call Decho("exe w ".fnameescape(vbname)) - exe "w ".fnameescape(vbname) - endif -" call Decho("Vimball<".vbname."> created") - echo "Vimball<".vbname."> created" - - " remove the evidence - setlocal nomod bh=wipe - exe "tabn ".curtabnr - exe "tabc ".vbtabnr - - " restore options - call vimball#RestoreSettings() - -" call Dret("MkVimball") -endfun - -" --------------------------------------------------------------------- -" vimball#Vimball: extract and distribute contents from a vimball {{{2 -" (invoked the the UseVimball command embedded in -" vimballs' prologue) -fun! vimball#Vimball(really,...) -" call Dfunc("vimball#Vimball(really=".a:really.") a:0=".a:0) - - if v:version < 701 || (v:version == 701 && !exists('*fnameescape')) - echoerr "your vim is missing the fnameescape() function" -" call Dret("vimball#Vimball : needs 7.1 with patch 299") - return - endif - - if getline(1) !~ '^" Vimball Archiver by Charles E. Campbell, Jr., Ph.D.$' - echoerr "(Vimball) The current file does not appear to be a Vimball!" -" call Dret("vimball#Vimball") - return - endif - - " set up standard settings - call vimball#SaveSettings() - let curtabnr = tabpagenr() - let vimballfile = expand("%:tr") - - " set up vimball tab -" call Decho("setting up vimball tab") - tabnew - silent! file Vimball - let vbtabnr= tabpagenr() - let didhelp= "" - - " go to vim plugin home - if a:0 > 0 - let home= expand(a:1) - else - let home= s:VimballHome() - endif -" call Decho("home<".home.">") - - " save current directory and remove older same-named vimball, if any - let curdir = getcwd() -" call Decho("home<".home.">") -" call Decho("curdir<".curdir.">") - - call s:ChgDir(home) - let s:ok_unablefind= 1 - call vimball#RmVimball(vimballfile) - unlet s:ok_unablefind - - let linenr = 4 - let filecnt = 0 - - " give title to listing of (extracted) files from Vimball Archive - if a:really - echohl Title | echomsg "Vimball Archive" | echohl None - else - echohl Title | echomsg "Vimball Archive Listing" | echohl None - echohl Statement | echomsg "files would be placed under: ".home | echohl None - endif - - " apportion vimball contents to various files -" call Decho("exe tabn ".curtabnr) - exe "tabn ".curtabnr -" call Decho("linenr=".linenr." line$=".line("$")) - while 1 < linenr && linenr < line("$") - let fname = substitute(getline(linenr),'\t\[\[\[1$','','') - let fname = substitute(fname,'\\','/','g') - let fsize = getline(linenr+1)+0 - let filecnt = filecnt + 1 -" call Decho("fname<".fname."> fsize=".fsize." filecnt=".filecnt) - - if a:really - echomsg "extracted <".fname.">: ".fsize." lines" - else - echomsg "would extract <".fname.">: ".fsize." lines" - endif -" call Decho("using L#".linenr.": will extract file<".fname.">") -" call Decho("using L#".(linenr+1).": fsize=".fsize) - - " Allow AsNeeded/ directory to take place of plugin/ directory - " when AsNeeded/filename is filereadable or was present in VimballRecord - if fname =~ '\ instead of <".fname.">") - let fname= anfname - endif - endif - - " make directories if they don't exist yet - if a:really -" call Decho("making directories if they don't exist yet (fname<".fname.">)") - let fnamebuf= substitute(fname,'\\','/','g') - let dirpath = substitute(home,'\\','/','g') - while fnamebuf =~ '/' - let dirname = dirpath."/".substitute(fnamebuf,'/.*$','','') - let dirpath = dirname - let fnamebuf = substitute(fnamebuf,'^.\{-}/\(.*\)$','\1','') -" call Decho("dirname<".dirname.">") - if !isdirectory(dirname) -" call Decho("making <".dirname.">") - if exists("g:vimball_mkdir") - call system(g:vimball_mkdir." ".s:Escape(dirname)) - else - call mkdir(dirname) - endif - call s:RecordInVar(home,"rmdir('".dirname."')") - endif - endwhile - endif - call s:ChgDir(home) - - " grab specified qty of lines and place into "a" buffer - " (skip over path/filename and qty-lines) - let linenr = linenr + 2 - let lastline = linenr + fsize - 1 -" call Decho("exe ".linenr.",".lastline."yank a") - exe "silent ".linenr.",".lastline."yank a" - - " copy "a" buffer into tab -" call Decho('copy "a buffer into tab#'.vbtabnr) - exe "tabn ".vbtabnr - setlocal ma - silent! %d - silent put a - 1 - silent d - - " write tab to file - if a:really - let fnamepath= home."/".fname -" call Decho("exe w! ".fnameescape(fnamepath)) - exe "silent w! ".fnameescape(fnamepath) - echo "wrote ".fnamepath - call s:RecordInVar(home,"call delete('".fnameescape(fnamepath)."')") - endif - - " return to tab with vimball -" call Decho("exe tabn ".curtabnr) - exe "tabn ".curtabnr - - " set up help if its a doc/*.txt file -" call Decho("didhelp<".didhelp."> fname<".fname.">") - if a:really && didhelp == "" && fname =~ 'doc/[^/]\+\.\(txt\|..x\)$' - let didhelp= substitute(fname,'^\(.*\") - endif - - " update for next file -" call Decho("update linenr= [linenr=".linenr."] + [fsize=".fsize."] = ".(linenr+fsize)) - let linenr= linenr + fsize - endwhile - - " set up help -" call Decho("about to set up help: didhelp<".didhelp.">") - if didhelp != "" - let htpath= home."/".didhelp -" call Decho("exe helptags ".htpath) - exe "helptags ".fnameescape(htpath) - echo "did helptags" - endif - - " make sure a "Press ENTER..." prompt appears to keep the messages showing! - while filecnt <= &ch - echomsg " " - let filecnt= filecnt + 1 - endwhile - - " record actions in <.VimballRecord> - call s:RecordInFile(home) - - " restore events, delete tab and buffer - exe "tabn ".vbtabnr - setlocal nomod bh=wipe - exe "tabn ".curtabnr - exe "tabc ".vbtabnr - call vimball#RestoreSettings() - call s:ChgDir(curdir) - -" call Dret("vimball#Vimball") -endfun - -" --------------------------------------------------------------------- -" vimball#RmVimball: remove any files, remove any directories made by any {{{2 -" previous vimball extraction based on a file of the current -" name. -" Usage: RmVimball (assume current file is a vimball; remove) -" RmVimball vimballname -fun! vimball#RmVimball(...) -" call Dfunc("vimball#RmVimball() a:0=".a:0) - if exists("g:vimball_norecord") -" call Dret("vimball#RmVimball : (g:vimball_norecord)") - return - endif - - if a:0 == 0 - let curfile= expand("%:tr") -" call Decho("case a:0=0: curfile<".curfile."> (used expand(%:tr))") - else - if a:1 =~ '[\/]' - call vimball#ShowMesg(s:USAGE,"RmVimball vimballname [path]") -" call Dret("vimball#RmVimball : suspect a:1<".a:1.">") - return - endif - let curfile= a:1 -" call Decho("case a:0=".a:0.": curfile<".curfile.">") - endif - if curfile =~ '\.vba$' - let curfile= substitute(curfile,'\.vba','','') - endif - if a:0 >= 2 - let home= expand(a:2) - else - let home= s:VimballHome() - endif - let curdir = getcwd() -" call Decho("home <".home.">") -" call Decho("curfile<".curfile.">") -" call Decho("curdir <".curdir.">") - - call s:ChgDir(home) - if filereadable(".VimballRecord") -" call Decho(".VimballRecord is readable") -" call Decho("curfile<".curfile.">") - keepalt keepjumps 1split - silent! keepalt keepjumps e .VimballRecord - let keepsrch= @/ -" call Decho("search for ^".curfile.".vba:") -" call Decho("search for ^".curfile."[-0-9.]*.vba:") - if search('^'.curfile.": ".'cw') - let foundit= 1 - elseif search('^'.curfile.".vba: ",'cw') - let foundit= 1 - elseif search('^'.curfile.'[-0-9.]*.vba: ','cw') - let foundit= 1 - else - let foundit = 0 - endif - if foundit - let exestring = substitute(getline("."),'^'.curfile.'\S\{-}\.vba: ','','') - let s:VBRstring= substitute(exestring,'call delete(','','g') - let s:VBRstring= substitute(s:VBRstring,"[')]",'','g') -" call Decho("exe ".exestring) - silent! keepalt keepjumps exe exestring - silent! keepalt keepjumps d - let exestring= strlen(substitute(exestring,'call delete(.\{-})|\=',"D","g")) -" call Decho("exestring<".exestring.">") - echomsg "removed ".exestring." files" - else - let s:VBRstring= '' - let curfile = substitute(curfile,'\.vba','','') -" call Decho("unable to find <".curfile."> in .VimballRecord") - if !exists("s:ok_unablefind") - call vimball#ShowMesg(s:WARNING,"(RmVimball) unable to find <".curfile."> in .VimballRecord") - endif - endif - silent! keepalt keepjumps g/^\s*$/d - silent! keepalt keepjumps wq! - let @/= keepsrch - endif - call s:ChgDir(curdir) - -" call Dret("vimball#RmVimball") -endfun - -" --------------------------------------------------------------------- -" vimball#Decompress: attempts to automatically decompress vimballs {{{2 -fun! vimball#Decompress(fname) -" call Dfunc("Decompress(fname<".a:fname.">)") - - " decompression: - if expand("%") =~ '.*\.gz' && executable("gunzip") - " handle *.gz with gunzip - silent exe "!gunzip ".s:Escape(a:fname) - if v:shell_error != 0 - call vimball#ShowMesg(s:WARNING,"(vimball#Decompress) gunzip may have failed with <".a:fname.">") - endif - let fname= substitute(a:fname,'\.gz$','','') - exe "e ".escape(fname,' \') - call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") - - elseif expand("%") =~ '.*\.gz' && executable("gzip") - " handle *.gz with gzip -d - silent exe "!gzip -d ".s:Escape(a:fname) - if v:shell_error != 0 - call vimball#ShowMesg(s:WARNING,'(vimball#Decompress) "gzip -d" may have failed with <'.a:fname.">") - endif - let fname= substitute(a:fname,'\.gz$','','') - exe "e ".escape(fname,' \') - call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") - - elseif expand("%") =~ '.*\.bz2' && executable("bunzip2") - " handle *.bz2 with bunzip2 - silent exe "!bunzip2 ".s:Escape(a:fname) - if v:shell_error != 0 - call vimball#ShowMesg(s:WARNING,"(vimball#Decompress) bunzip2 may have failed with <".a:fname.">") - endif - let fname= substitute(a:fname,'\.bz2$','','') - exe "e ".escape(fname,' \') - call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") - - elseif expand("%") =~ '.*\.bz2' && executable("bzip2") - " handle *.bz2 with bzip2 -d - silent exe "!bzip2 -d ".s:Escape(a:fname) - if v:shell_error != 0 - call vimball#ShowMesg(s:WARNING,'(vimball#Decompress) "bzip2 -d" may have failed with <'.a:fname.">") - endif - let fname= substitute(a:fname,'\.bz2$','','') - exe "e ".escape(fname,' \') - call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") - - elseif expand("%") =~ '.*\.zip' && executable("unzip") - " handle *.zip with unzip - silent exe "!unzip ".s:Escape(a:fname) - if v:shell_error != 0 - call vimball#ShowMesg(s:WARNING,"(vimball#Decompress) unzip may have failed with <".a:fname.">") - endif - let fname= substitute(a:fname,'\.zip$','','') - exe "e ".escape(fname,' \') - call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") - endif - - set noma bt=nofile fmr=[[[,]]] fdm=marker - -" call Dret("Decompress") -endfun - -" --------------------------------------------------------------------- -" vimball#ShowMesg: {{{2 -fun! vimball#ShowMesg(level,msg) -" call Dfunc("vimball#ShowMesg(level=".a:level." msg<".a:msg.">)") - let rulerkeep = &ruler - let showcmdkeep = &showcmd - set noruler noshowcmd - redraw! - - if &fo =~ '[ta]' - echomsg "***vimball*** " a:msg - else - if a:level == s:WARNING || a:level == s:USAGE - echohl WarningMsg - elseif a:level == s:ERROR - echohl Error - endif - echomsg "***vimball*** " a:msg - echohl None - endif - - if a:level != s:USAGE - call inputsave()|let ok= input("Press to continue")|call inputrestore() - endif - - let &ruler = rulerkeep - let &showcmd = showcmdkeep - -" call Dret("vimball#ShowMesg") -endfun -" ===================================================================== -" s:ChgDir: change directory (in spite of Windoze) {{{2 -fun! s:ChgDir(newdir) -" call Dfunc("ChgDir(newdir<".a:newdir.">)") - if (has("win32") || has("win95") || has("win64") || has("win16")) - exe 'silent cd '.fnameescape(substitute(a:newdir,'/','\\','g')) - else - exe 'silent cd '.fnameescape(a:newdir) - endif -" call Dret("ChgDir : curdir<".getcwd().">") -endfun - -" --------------------------------------------------------------------- -" s:RecordInVar: record a un-vimball command in the .VimballRecord file {{{2 -fun! s:RecordInVar(home,cmd) -" call Dfunc("RecordInVar(home<".a:home."> cmd<".a:cmd.">)") - if a:cmd =~ '^rmdir' -" if !exists("s:recorddir") -" let s:recorddir= substitute(a:cmd,'^rmdir',"call s:Rmdir",'') -" else -" let s:recorddir= s:recorddir."|".substitute(a:cmd,'^rmdir',"call s:Rmdir",'') -" endif - elseif !exists("s:recordfile") - let s:recordfile= a:cmd - else - let s:recordfile= s:recordfile."|".a:cmd - endif -" call Dret("RecordInVar : s:recordfile<".(exists("s:recordfile")? s:recordfile : "")."> s:recorddir<".(exists("s:recorddir")? s:recorddir : "").">") -endfun - -" --------------------------------------------------------------------- -" s:RecordInFile: {{{2 -fun! s:RecordInFile(home) -" call Dfunc("s:RecordInFile()") - if exists("g:vimball_norecord") -" call Dret("s:RecordInFile : g:vimball_norecord") - return - endif - - if exists("s:recordfile") || exists("s:recorddir") - let curdir= getcwd() - call s:ChgDir(a:home) - keepalt keepjumps 1split - - let cmd= expand("%:tr").": " -" call Decho("cmd<".cmd.">") - - silent! keepalt keepjumps e .VimballRecord - setlocal ma - $ - if exists("s:recordfile") && exists("s:recorddir") - let cmd= cmd.s:recordfile."|".s:recorddir - elseif exists("s:recorddir") - let cmd= cmd.s:recorddir - elseif exists("s:recordfile") - let cmd= cmd.s:recordfile - else -" call Dret("s:RecordInFile : neither recordfile nor recorddir exist") - return - endif -" call Decho("cmd<".cmd.">") - - " put command into buffer, write .VimballRecord `file - keepalt keepjumps put=cmd - silent! keepalt keepjumps g/^\s*$/d - silent! keepalt keepjumps wq! - call s:ChgDir(curdir) - - if exists("s:recorddir") -" call Decho("unlet s:recorddir<".s:recorddir.">") - unlet s:recorddir - endif - if exists("s:recordfile") -" call Decho("unlet s:recordfile<".s:recordfile.">") - unlet s:recordfile - endif - else -" call Decho("s:record[file|dir] doesn't exist") - endif - -" call Dret("s:RecordInFile") -endfun - -" --------------------------------------------------------------------- -" s:VimballHome: determine/get home directory path (usually from rtp) {{{2 -fun! s:VimballHome() -" call Dfunc("VimballHome()") - if exists("g:vimball_home") - let home= g:vimball_home - else - " go to vim plugin home - for home in split(&rtp,',') + [''] - if isdirectory(home) && filewritable(home) | break | endif - let basehome= substitute(home,'[/\\]\.vim$','','') - if isdirectory(basehome) && filewritable(basehome) - let home= basehome."/.vim" - break - endif - endfor - if home == "" - " just pick the first directory - let home= substitute(&rtp,',.*$','','') - endif - if (has("win32") || has("win95") || has("win64") || has("win16")) - let home= substitute(home,'/','\\','g') - endif - endif - " insure that the home directory exists -" call Decho("picked home<".home.">") - if !isdirectory(home) - if exists("g:vimball_mkdir") -" call Decho("home<".home."> isn't a directory -- making it now with g:vimball_mkdir<".g:vimball_mkdir.">") -" call Decho("system(".g:vimball_mkdir." ".s:Escape(home).")") - call system(g:vimball_mkdir." ".s:Escape(home)) - else -" call Decho("home<".home."> isn't a directory -- making it now with mkdir()") - call mkdir(home) - endif - endif -" call Dret("VimballHome <".home.">") - return home -endfun - -" --------------------------------------------------------------------- -" vimball#SaveSettings: {{{2 -fun! vimball#SaveSettings() -" call Dfunc("SaveSettings()") - let s:makeep = getpos("'a") - let s:regakeep= @a - if exists("&acd") - let s:acdkeep = &acd - endif - let s:eikeep = &ei - let s:fenkeep = &l:fen - let s:hidkeep = &hidden - let s:ickeep = &ic - let s:lzkeep = &lz - let s:pmkeep = &pm - let s:repkeep = &report - let s:vekeep = &ve - let s:ffkeep = &l:ff - if exists("&acd") - setlocal ei=all ve=all noacd nofen noic report=999 nohid bt= ma lz pm= ff=unix - else - setlocal ei=all ve=all nofen noic report=999 nohid bt= ma lz pm= ff=unix - endif - " vimballs should be in unix format - setlocal ff=unix -" call Dret("SaveSettings") -endfun - -" --------------------------------------------------------------------- -" vimball#RestoreSettings: {{{2 -fun! vimball#RestoreSettings() -" call Dfunc("RestoreSettings()") - let @a = s:regakeep - if exists("&acd") - let &acd = s:acdkeep - endif - let &l:fen = s:fenkeep - let &hidden = s:hidkeep - let &ic = s:ickeep - let &lz = s:lzkeep - let &pm = s:pmkeep - let &report = s:repkeep - let &ve = s:vekeep - let &ei = s:eikeep - let &l:ff = s:ffkeep - if s:makeep[0] != 0 - " restore mark a -" call Decho("restore mark-a: makeep=".string(makeep)) - call setpos("'a",s:makeep) - endif - if exists("&acd") - unlet s:acdkeep - endif - unlet s:regakeep s:eikeep s:fenkeep s:hidkeep s:ickeep s:repkeep s:vekeep s:makeep s:lzkeep s:pmkeep s:ffkeep -" call Dret("RestoreSettings") -endfun - -" --------------------------------------------------------------------- -" s:Escape: {{{2 -fun s:Escape(name) - " shellescape() was added by patch 7.0.111 - if exists("*shellescape") - return shellescape(a:name) - endif - return g:netrw_shq . a:name . g:netrw_shq -endfun - -" --------------------------------------------------------------------- -" Restore: -let &cpo= s:keepcpo -unlet s:keepcpo - -" --------------------------------------------------------------------- -" Modelines: {{{1 -" vim: fdm=marker diff --git a/share/vim/vim72/autoload/zip.vim b/share/vim/vim72/autoload/zip.vim deleted file mode 100644 index af56944ce3..0000000000 --- a/share/vim/vim72/autoload/zip.vim +++ /dev/null @@ -1,387 +0,0 @@ -" zip.vim: Handles browsing zipfiles -" AUTOLOAD PORTION -" Date: Jul 30, 2008 -" Version: 22 -" Maintainer: Charles E Campbell, Jr -" License: Vim License (see vim's :help license) -" Copyright: Copyright (C) 2005-2008 Charles E. Campbell, Jr. {{{1 -" Permission is hereby granted to use and distribute this code, -" with or without modifications, provided that this copyright -" notice is copied with it. Like anything else that's free, -" zip.vim and zipPlugin.vim are provided *as is* and comes with -" no warranty of any kind, either expressed or implied. By using -" this plugin, you agree that in no event will the copyright -" holder be liable for any damages resulting from the use -" of this software. - -" --------------------------------------------------------------------- -" Load Once: {{{1 -let s:keepcpo= &cpo -set cpo&vim -if &cp || exists("g:loaded_zip") || v:version < 700 - finish -endif - -let g:loaded_zip = "v22" -let s:zipfile_escape = ' ?&;\' -let s:ERROR = 2 -let s:WARNING = 1 -let s:NOTE = 0 - -" --------------------------------------------------------------------- -" Global Values: {{{1 -if !exists("g:zip_shq") - if &shq != "" - let g:zip_shq= &shq - elseif has("unix") - let g:zip_shq= "'" - else - let g:zip_shq= '"' - endif -endif -if !exists("g:zip_zipcmd") - let g:zip_zipcmd= "zip" -endif -if !exists("g:zip_unzipcmd") - let g:zip_unzipcmd= "unzip" -endif - -" ---------------- -" Functions: {{{1 -" ---------------- - -" --------------------------------------------------------------------- -" zip#Browse: {{{2 -fun! zip#Browse(zipfile) -" call Dfunc("zip#Browse(zipfile<".a:zipfile.">)") - let repkeep= &report - set report=10 - - " sanity checks - if !exists("*fnameescape") - if &verbose > 1 - echoerr "the zip plugin is not available (your vim doens't support fnameescape())" - endif - return - endif - if !executable(g:zip_unzipcmd) - redraw! - echohl Error | echo "***error*** (zip#Browse) unzip not available on your system" -" call inputsave()|call input("Press to continue")|call inputrestore() - let &report= repkeep -" call Dret("zip#Browse") - return - endif - if !filereadable(a:zipfile) - if a:zipfile !~# '^\a\+://' - " if its an url, don't complain, let url-handlers such as vim do its thing - redraw! - echohl Error | echo "***error*** (zip#Browse) File not readable<".a:zipfile.">" | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - endif - let &report= repkeep -" call Dret("zip#Browse : file<".a:zipfile."> not readable") - return - endif -" call Decho("passed sanity checks") - if &ma != 1 - set ma - endif - let b:zipfile= a:zipfile - - setlocal noswapfile - setlocal buftype=nofile - setlocal bufhidden=hide - setlocal nobuflisted - setlocal nowrap - set ft=tar - - " give header - let lastline= line("$") - call setline(lastline+1,'" zip.vim version '.g:loaded_zip) - call setline(lastline+2,'" Browsing zipfile '.a:zipfile) - call setline(lastline+3,'" Select a file with cursor and press ENTER') - $put ='' - 0d - $ - -" call Decho("exe silent r! ".g:zip_unzipcmd." -l -- ".s:Escape(a:zipfile,1)) - exe "silent r! ".g:zip_unzipcmd." -l -- ".s:Escape(a:zipfile,1) - if v:shell_error != 0 - redraw! - echohl WarningMsg | echo "***warning*** (zip#Browse) ".fnameescape(a:zipfile)." is not a zip file" | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - silent %d - let eikeep= &ei - set ei=BufReadCmd,FileReadCmd - exe "r ".fnameescape(a:zipfile) - let &ei= eikeep - 1d -" call Dret("zip#Browse") - return - endif -" call Decho("line 6: ".getline(6)) - let namecol= stridx(getline(6),'Name') + 1 -" call Decho("namecol=".namecol) - 4,$g/^\s*----/d - 4,$g/^\s*\a/d - $d - if namecol > 0 - exe 'silent 4,$s/^.*\%'.namecol.'c//' - endif - - setlocal noma nomod ro - noremap :call ZipBrowseSelect() - - let &report= repkeep -" call Dret("zip#Browse") -endfun - -" --------------------------------------------------------------------- -" ZipBrowseSelect: {{{2 -fun! s:ZipBrowseSelect() -" call Dfunc("ZipBrowseSelect() zipfile<".b:zipfile."> curfile<".expand("%").">") - let repkeep= &report - set report=10 - let fname= getline(".") - - " sanity check - if fname =~ '^"' - let &report= repkeep -" call Dret("ZipBrowseSelect") - return - endif - if fname =~ '/$' - redraw! - echohl Error | echo "***error*** (zip#Browse) Please specify a file, not a directory" | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - let &report= repkeep -" call Dret("ZipBrowseSelect") - return - endif - -" call Decho("fname<".fname.">") - - " get zipfile to the new-window - let zipfile = b:zipfile - let curfile= expand("%") -" call Decho("zipfile<".zipfile.">") -" call Decho("curfile<".curfile.">") - - new - if !exists("g:zip_nomax") || g:zip_nomax == 0 - wincmd _ - endif - let s:zipfile_{winnr()}= curfile -" call Decho("exe e ".fnameescape("zipfile:".zipfile.'::'.fname)) - exe "e ".fnameescape("zipfile:".zipfile.'::'.fname) - filetype detect - - let &report= repkeep -" call Dret("ZipBrowseSelect : s:zipfile_".winnr()."<".s:zipfile_{winnr()}.">") -endfun - -" --------------------------------------------------------------------- -" zip#Read: {{{2 -fun! zip#Read(fname,mode) -" call Dfunc("zip#Read(fname<".a:fname.">,mode=".a:mode.")") - let repkeep= &report - set report=10 - - if has("unix") - let zipfile = substitute(a:fname,'zipfile:\(.\{-}\)::[^\\].*$','\1','') - let fname = substitute(a:fname,'zipfile:.\{-}::\([^\\].*\)$','\1','') - else - let zipfile = substitute(a:fname,'^.\{-}zipfile:\(.\{-}\)::[^\\].*$','\1','') - let fname = substitute(a:fname,'^.\{-}zipfile:.\{-}::\([^\\].*\)$','\1','') - let fname = substitute(fname, '[', '[[]', 'g') - endif -" call Decho("zipfile<".zipfile.">") -" call Decho("fname <".fname.">") - -" call Decho("exe r! ".g:zip_unzipcmd." -p -- ".s:Escape(zipfile,1)." ".s:Escape(fname,1)) - exe "silent r! ".g:zip_unzipcmd." -p -- ".s:Escape(zipfile,1)." ".s:Escape(fname,1) - - " cleanup - 0d - set nomod - - let &report= repkeep -" call Dret("zip#Read") -endfun - -" --------------------------------------------------------------------- -" zip#Write: {{{2 -fun! zip#Write(fname) -" call Dfunc("zip#Write(fname<".a:fname.">) zipfile_".winnr()."<".s:zipfile_{winnr()}.">") - let repkeep= &report - set report=10 - - " sanity checks - if !executable(g:zip_zipcmd) - redraw! - echohl Error | echo "***error*** (zip#Write) sorry, your system doesn't appear to have the zip pgm" | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - let &report= repkeep -" call Dret("zip#Write") - return - endif - if !exists("*mkdir") - redraw! - echohl Error | echo "***error*** (zip#Write) sorry, mkdir() doesn't work on your system" | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - let &report= repkeep -" call Dret("zip#Write") - return - endif - - let curdir= getcwd() - let tmpdir= tempname() -" call Decho("orig tempname<".tmpdir.">") - if tmpdir =~ '\.' - let tmpdir= substitute(tmpdir,'\.[^.]*$','','e') - endif -" call Decho("tmpdir<".tmpdir.">") - call mkdir(tmpdir,"p") - - " attempt to change to the indicated directory - if s:ChgDir(tmpdir,s:ERROR,"(zip#Write) cannot cd to temporary directory") - let &report= repkeep -" call Dret("zip#Write") - return - endif -" call Decho("current directory now: ".getcwd()) - - " place temporary files under .../_ZIPVIM_/ - if isdirectory("_ZIPVIM_") - call s:Rmdir("_ZIPVIM_") - endif - call mkdir("_ZIPVIM_") - cd _ZIPVIM_ -" call Decho("current directory now: ".getcwd()) - - if has("unix") - let zipfile = substitute(a:fname,'zipfile:\(.\{-}\)::[^\\].*$','\1','') - let fname = substitute(a:fname,'zipfile:.\{-}::\([^\\].*\)$','\1','') - else - let zipfile = substitute(a:fname,'^.\{-}zipfile:\(.\{-}\)::[^\\].*$','\1','') - let fname = substitute(a:fname,'^.\{-}zipfile:.\{-}::\([^\\].*\)$','\1','') - endif -" call Decho("zipfile<".zipfile.">") -" call Decho("fname <".fname.">") - - if fname =~ '/' - let dirpath = substitute(fname,'/[^/]\+$','','e') - if executable("cygpath") - let dirpath = substitute(system("cygpath ".s:Escape(dirpath,0)),'\n','','e') - endif -" call Decho("mkdir(dirpath<".dirpath.">,p)") - call mkdir(dirpath,"p") - endif - if zipfile !~ '/' - let zipfile= curdir.'/'.zipfile - endif -" call Decho("zipfile<".zipfile."> fname<".fname.">") - - exe "w! ".fnameescape(fname) - if executable("cygpath") - let zipfile = substitute(system("cygpath ".s:Escape(zipfile,0)),'\n','','e') - endif - - if (has("win32") || has("win95") || has("win64") || has("win16")) && &shell !~? 'sh$' - let fname = substitute(fname, '[', '[[]', 'g') - endif - -" call Decho(g:zip_zipcmd." -u ".s:Escape(fnamemodify(zipfile,":p"),0)." ".s:Escape(fname,0)) - call system(g:zip_zipcmd." -u ".s:Escape(fnamemodify(zipfile,":p"),0)." ".s:Escape(fname,0)) - if v:shell_error != 0 - redraw! - echohl Error | echo "***error*** (zip#Write) sorry, unable to update ".zipfile." with ".fname | echohl None -" call inputsave()|call input("Press to continue")|call inputrestore() - - elseif s:zipfile_{winnr()} =~ '^\a\+://' - " support writing zipfiles across a network - let netzipfile= s:zipfile_{winnr()} -" call Decho("handle writing <".zipfile."> across network as <".netzipfile.">") - 1split|enew - let binkeep= &binary - let eikeep = &ei - set binary ei=all - exe "e! ".fnameescape(zipfile) - call netrw#NetWrite(netzipfile) - let &ei = eikeep - let &binary = binkeep - q! - unlet s:zipfile_{winnr()} - endif - - " cleanup and restore current directory - cd .. - call s:Rmdir("_ZIPVIM_") - call s:ChgDir(curdir,s:WARNING,"(zip#Write) unable to return to ".curdir."!") - call s:Rmdir(tmpdir) - setlocal nomod - - let &report= repkeep -" call Dret("zip#Write") -endfun - -" --------------------------------------------------------------------- -" s:Escape: {{{2 -fun! s:Escape(fname,isfilt) -" call Dfunc("QuoteFileDir(fname<".a:fname."> isfilt=".a:isfilt.")") - if exists("*shellescape") - if a:isfilt - let qnameq= shellescape(a:fname,1) - else - let qnameq= shellescape(a:fname) - endif - else - let qnameq= g:zip_shq.escape(a:fname,g:zip_shq).g:zip_shq - endif -" call Dret("QuoteFileDir <".qnameq.">") - return qnameq -endfun - -" --------------------------------------------------------------------- -" ChgDir: {{{2 -fun! s:ChgDir(newdir,errlvl,errmsg) -" call Dfunc("ChgDir(newdir<".a:newdir."> errlvl=".a:errlvl." errmsg<".a:errmsg.">)") - - try - exe "cd ".fnameescape(a:newdir) - catch /^Vim\%((\a\+)\)\=:E344/ - redraw! - if a:errlvl == s:NOTE - echo "***note*** ".a:errmsg - elseif a:errlvl == s:WARNING - echohl WarningMsg | echo "***warning*** ".a:errmsg | echohl NONE - elseif a:errlvl == s:ERROR - echohl Error | echo "***error*** ".a:errmsg | echohl NONE - endif -" call inputsave()|call input("Press to continue")|call inputrestore() -" call Dret("ChgDir 1") - return 1 - endtry - -" call Dret("ChgDir 0") - return 0 -endfun - -" --------------------------------------------------------------------- -" s:Rmdir: {{{2 -fun! s:Rmdir(fname) -" call Dfunc("Rmdir(fname<".a:fname.">)") - if (has("win32") || has("win95") || has("win64") || has("win16")) && &shell !~? 'sh$' - call system("rmdir /S/Q ".s:Escape(a:fname,0)) - else - call system("/bin/rm -rf ".s:Escape(a:fname,0)) - endif -" call Dret("Rmdir") -endfun - -" ------------------------------------------------------------------------ -" Modelines And Restoration: {{{1 -let &cpo= s:keepcpo -unlet s:keepcpo -" vim:ts=8 fdm=marker diff --git a/share/vim/vim72/compiler/eruby.vim b/share/vim/vim72/compiler/eruby.vim deleted file mode 100644 index 1a6813624c..0000000000 --- a/share/vim/vim72/compiler/eruby.vim +++ /dev/null @@ -1,41 +0,0 @@ -" Vim compiler file -" Language: eRuby -" Maintainer: Doug Kearns -" Info: $Id: eruby.vim,v 1.7 2008/06/29 04:18:42 tpope Exp $ -" URL: http://vim-ruby.rubyforge.org -" Anon CVS: See above site -" Release Coordinator: Doug Kearns - -if exists("current_compiler") - finish -endif -let current_compiler = "eruby" - -if exists(":CompilerSet") != 2 " older Vim always used :setlocal - command -nargs=* CompilerSet setlocal -endif - -let s:cpo_save = &cpo -set cpo-=C - -if exists("eruby_compiler") && eruby_compiler == "eruby" - CompilerSet makeprg=eruby -else - CompilerSet makeprg=erb -endif - -CompilerSet errorformat= - \eruby:\ %f:%l:%m, - \%+E%f:%l:\ parse\ error, - \%W%f:%l:\ warning:\ %m, - \%E%f:%l:in\ %*[^:]:\ %m, - \%E%f:%l:\ %m, - \%-C%\tfrom\ %f:%l:in\ %.%#, - \%-Z%\tfrom\ %f:%l, - \%-Z%p^, - \%-G%.%# - -let &cpo = s:cpo_save -unlet s:cpo_save - -" vim: nowrap sw=2 sts=2 ts=8: diff --git a/share/vim/vim72/compiler/gcc.vim b/share/vim/vim72/compiler/gcc.vim deleted file mode 100644 index a62415f6b2..0000000000 --- a/share/vim/vim72/compiler/gcc.vim +++ /dev/null @@ -1,32 +0,0 @@ -" Vim compiler file -" Compiler: GNU C Compiler -" Maintainer: Nikolai Weibull -" Latest Revision: 2006-12-20 - -if exists("current_compiler") - finish -endif -let current_compiler = "gcc" - -let s:cpo_save = &cpo -set cpo-=C - -CompilerSet errorformat= - \%*[^\"]\"%f\"%*\\D%l:\ %m, - \\"%f\"%*\\D%l:\ %m, - \%-G%f:%l:\ %trror:\ (Each\ undeclared\ identifier\ is\ reported\ only\ once, - \%-G%f:%l:\ %trror:\ for\ each\ function\ it\ appears\ in.), - \%f:%l:\ %m, - \\"%f\"\\,\ line\ %l%*\\D%c%*[^\ ]\ %m, - \%D%*\\a[%*\\d]:\ Entering\ directory\ `%f', - \%X%*\\a[%*\\d]:\ Leaving\ directory\ `%f', - \%D%*\\a:\ Entering\ directory\ `%f', - \%X%*\\a:\ Leaving\ directory\ `%f', - \%DMaking\ %*\\a\ in\ %f - -if exists('g:compiler_gcc_ignore_unmatched_lines') - CompilerSet errorformat+=%-G%.%# -endif - -let &cpo = s:cpo_save -unlet s:cpo_save diff --git a/share/vim/vim72/compiler/jikes.vim b/share/vim/vim72/compiler/jikes.vim deleted file mode 100644 index 8566969ac0..0000000000 --- a/share/vim/vim72/compiler/jikes.vim +++ /dev/null @@ -1,18 +0,0 @@ -" Vim Compiler File -" Compiler: Jikes -" Maintainer: Dan Sharp -" Last Change: 2004 Mar 27 -" URL: http://mywebpage.netscape.com/sharppeople/vim/compiler - -if exists("current_compiler") - finish -endif -let current_compiler = "jikes" - -if exists(":CompilerSet") != 2 " older Vim always used :setlocal - command -nargs=* CompilerSet setlocal -endif - -" Jikes defaults to printing output on stderr -CompilerSet makeprg=jikes\ -Xstdout\ +E\ \"%\" -CompilerSet errorformat=%f:%l:%v:%*\\d:%*\\d:%*\\s%m diff --git a/share/vim/vim72/compiler/perl.vim b/share/vim/vim72/compiler/perl.vim deleted file mode 100644 index 2b7c94a89a..0000000000 --- a/share/vim/vim72/compiler/perl.vim +++ /dev/null @@ -1,47 +0,0 @@ -" Vim Compiler File -" Compiler: Perl syntax checks (perl -Wc) -" Maintainer: Christian J. Robinson -" Last Change: 2006 Aug 13 - -if exists("current_compiler") - finish -endif -let current_compiler = "perl" - -if exists(":CompilerSet") != 2 " older Vim always used :setlocal - command -nargs=* CompilerSet setlocal -endif - -let s:savecpo = &cpo -set cpo&vim - -if exists('g:perl_compiler_force_warnings') && g:perl_compiler_force_warnings == 0 - let s:warnopt = 'w' -else - let s:warnopt = 'W' -endif - -if getline(1) =~# '-[^ ]*T' - let s:taintopt = 'T' -else - let s:taintopt = '' -endif - -exe 'CompilerSet makeprg=perl\ -' . s:warnopt . s:taintopt . 'c\ %' - -CompilerSet errorformat= - \%-G%.%#had\ compilation\ errors., - \%-G%.%#syntax\ OK, - \%m\ at\ %f\ line\ %l., - \%+A%.%#\ at\ %f\ line\ %l\\,%.%#, - \%+C%.%# - -" Explanation: -" %-G%.%#had\ compilation\ errors., - Ignore the obvious. -" %-G%.%#syntax\ OK, - Don't include the 'a-okay' message. -" %m\ at\ %f\ line\ %l., - Most errors... -" %+A%.%#\ at\ %f\ line\ %l\\,%.%#, - As above, including ', near ...' -" %+C%.%# - ... Which can be multi-line. - -let &cpo = s:savecpo -unlet s:savecpo diff --git a/share/vim/vim72/compiler/rspec.vim b/share/vim/vim72/compiler/rspec.vim deleted file mode 100644 index c185bc79d3..0000000000 --- a/share/vim/vim72/compiler/rspec.vim +++ /dev/null @@ -1,41 +0,0 @@ -" Vim compiler file -" Language: RSpec -" Maintainer: Tim Pope -" Info: $Id: rspec.vim,v 1.2 2008/06/29 04:18:42 tpope Exp $ -" URL: http://vim-ruby.rubyforge.org -" Anon CVS: See above site -" Release Coordinator: Doug Kearns - -if exists("current_compiler") - finish -endif -let current_compiler = "rspec" - -if exists(":CompilerSet") != 2 " older Vim always used :setlocal - command -nargs=* CompilerSet setlocal -endif - -let s:cpo_save = &cpo -set cpo-=C - -CompilerSet makeprg=spec - -CompilerSet errorformat= - \%+W'%.%#'\ FAILED, - \%+I'%.%#'\ FIXED, - \%-Cexpected:%.%#, - \%-C\ \ \ \ \ got:%.%#, - \%E%.%#:in\ `load':\ %f:%l:%m, - \%C%f:%l:, - \%W%f:%l:\ warning:\ %m, - \%E%f:%l:in\ %*[^:]:\ %m, - \%E%f:%l:\ %m, - \%-Z%\tfrom\ %f:%l, - \%-Z%p^%.%#, - \%-C%.%#, - \%-G%.%# - -let &cpo = s:cpo_save -unlet s:cpo_save - -" vim: nowrap sw=2 sts=2 ts=8: diff --git a/share/vim/vim72/compiler/ruby.vim b/share/vim/vim72/compiler/ruby.vim deleted file mode 100644 index ff3b3c702c..0000000000 --- a/share/vim/vim72/compiler/ruby.vim +++ /dev/null @@ -1,68 +0,0 @@ -" Vim compiler file -" Language: Ruby -" Function: Syntax check and/or error reporting -" Maintainer: Tim Hammerquist -" Info: $Id: ruby.vim,v 1.13 2008/06/29 04:18:43 tpope Exp $ -" URL: http://vim-ruby.rubyforge.org -" Anon CVS: See above site -" Release Coordinator: Doug Kearns -" ---------------------------------------------------------------------------- -" -" Changelog: -" 0.2: script saves and restores 'cpoptions' value to prevent problems with -" line continuations -" 0.1: initial release -" -" Contributors: -" Hugh Sasse -" Doug Kearns -" -" Todo: -" match error type %m -" -" Comments: -" I know this file isn't perfect. If you have any questions, suggestions, -" patches, etc., please don't hesitate to let me know. -" -" This is my first experience with 'errorformat' and compiler plugins and -" I welcome any input from more experienced (or clearer-thinking) -" individuals. -" ---------------------------------------------------------------------------- - -if exists("current_compiler") - finish -endif -let current_compiler = "ruby" - -if exists(":CompilerSet") != 2 " older Vim always used :setlocal - command -nargs=* CompilerSet setlocal -endif - -let s:cpo_save = &cpo -set cpo-=C - -" default settings runs script normally -" add '-c' switch to run syntax check only: -" -" CompilerSet makeprg=ruby\ -wc\ $* -" -" or add '-c' at :make command line: -" -" :make -c % -" -CompilerSet makeprg=ruby\ -w\ $* - -CompilerSet errorformat= - \%+E%f:%l:\ parse\ error, - \%W%f:%l:\ warning:\ %m, - \%E%f:%l:in\ %*[^:]:\ %m, - \%E%f:%l:\ %m, - \%-C%\tfrom\ %f:%l:in\ %.%#, - \%-Z%\tfrom\ %f:%l, - \%-Z%p^, - \%-G%.%# - -let &cpo = s:cpo_save -unlet s:cpo_save - -" vim: nowrap sw=2 sts=2 ts=8: diff --git a/share/vim/vim72/compiler/rubyunit.vim b/share/vim/vim72/compiler/rubyunit.vim deleted file mode 100644 index dd5d4cb81a..0000000000 --- a/share/vim/vim72/compiler/rubyunit.vim +++ /dev/null @@ -1,35 +0,0 @@ -" Vim compiler file -" Language: Test::Unit - Ruby Unit Testing Framework -" Maintainer: Doug Kearns -" Info: $Id: rubyunit.vim,v 1.12 2008/06/29 04:18:43 tpope Exp $ -" URL: http://vim-ruby.rubyforge.org -" Anon CVS: See above site -" Release Coordinator: Doug Kearns - -if exists("current_compiler") - finish -endif -let current_compiler = "rubyunit" - -if exists(":CompilerSet") != 2 " older Vim always used :setlocal - command -nargs=* CompilerSet setlocal -endif - -let s:cpo_save = &cpo -set cpo-=C - -CompilerSet makeprg=testrb - -CompilerSet errorformat=\%W\ %\\+%\\d%\\+)\ Failure:, - \%C%m\ [%f:%l]:, - \%E\ %\\+%\\d%\\+)\ Error:, - \%C%m:, - \%C\ \ \ \ %f:%l:%.%#, - \%C%m, - \%Z\ %#, - \%-G%.%# - -let &cpo = s:cpo_save -unlet s:cpo_save - -" vim: nowrap sw=2 sts=2 ts=8: diff --git a/share/vim/vim72/doc/Makefile b/share/vim/vim72/doc/Makefile deleted file mode 100644 index 2f697508b0..0000000000 --- a/share/vim/vim72/doc/Makefile +++ /dev/null @@ -1,484 +0,0 @@ -# -# Makefile for the Vim documentation on Unix -# -# If you get "don't know how to make scratch", first run make in the source -# directory. Or remove the include below. - -AWK = awk - -# Set to $(VIMTARGET) when executed from src/Makefile. -VIMEXE = vim - -# include the config.mk from the source directory. It's only needed to set -# AWK, used for "make html". Comment this out if the include gives problems. -include ../../src/auto/config.mk - -DOCS = \ - arabic.txt \ - autocmd.txt \ - change.txt \ - cmdline.txt \ - debug.txt \ - debugger.txt \ - develop.txt \ - diff.txt \ - digraph.txt \ - editing.txt \ - eval.txt \ - farsi.txt \ - filetype.txt \ - fold.txt \ - ft_ada.txt \ - ft_sql.txt \ - gui.txt \ - gui_w16.txt \ - gui_w32.txt \ - gui_x11.txt \ - hangulin.txt \ - hebrew.txt \ - help.txt \ - howto.txt \ - if_cscop.txt \ - if_mzsch.txt \ - if_ole.txt \ - if_perl.txt \ - if_pyth.txt \ - if_ruby.txt \ - if_sniff.txt \ - if_tcl.txt \ - indent.txt \ - index.txt \ - insert.txt \ - intro.txt \ - map.txt \ - mbyte.txt \ - message.txt \ - mlang.txt \ - motion.txt \ - netbeans.txt \ - options.txt \ - os_390.txt \ - os_amiga.txt \ - os_beos.txt \ - os_dos.txt \ - os_mac.txt \ - os_mint.txt \ - os_msdos.txt \ - os_os2.txt \ - os_qnx.txt \ - os_risc.txt \ - os_unix.txt \ - os_vms.txt \ - os_win32.txt \ - pattern.txt \ - pi_getscript.txt \ - pi_gzip.txt \ - pi_netrw.txt \ - pi_paren.txt \ - pi_spec.txt \ - pi_tar.txt \ - pi_vimball.txt \ - pi_zip.txt \ - print.txt \ - quickfix.txt \ - quickref.txt \ - quotes.txt \ - recover.txt \ - remote.txt \ - repeat.txt \ - rileft.txt \ - russian.txt \ - scroll.txt \ - sign.txt \ - spell.txt \ - sponsor.txt \ - starting.txt \ - syntax.txt \ - tabpage.txt \ - tagsrch.txt \ - term.txt \ - tips.txt \ - todo.txt \ - uganda.txt \ - undo.txt \ - usr_01.txt \ - usr_02.txt \ - usr_03.txt \ - usr_04.txt \ - usr_05.txt \ - usr_06.txt \ - usr_07.txt \ - usr_08.txt \ - usr_09.txt \ - usr_10.txt \ - usr_11.txt \ - usr_12.txt \ - usr_20.txt \ - usr_21.txt \ - usr_22.txt \ - usr_23.txt \ - usr_24.txt \ - usr_25.txt \ - usr_26.txt \ - usr_27.txt \ - usr_28.txt \ - usr_29.txt \ - usr_30.txt \ - usr_31.txt \ - usr_32.txt \ - usr_40.txt \ - usr_41.txt \ - usr_42.txt \ - usr_43.txt \ - usr_44.txt \ - usr_45.txt \ - usr_90.txt \ - usr_toc.txt \ - various.txt \ - version4.txt \ - version5.txt \ - version6.txt \ - version7.txt \ - vi_diff.txt \ - visual.txt \ - windows.txt \ - workshop.txt - -HTMLS = \ - arabic.html \ - autocmd.html \ - change.html \ - cmdline.html \ - debug.html \ - debugger.html \ - develop.html \ - diff.html \ - digraph.html \ - editing.html \ - eval.html \ - farsi.html \ - filetype.html \ - fold.html \ - ft_ada.html \ - ft_sql.html \ - gui.html \ - gui_w16.html \ - gui_w32.html \ - gui_x11.html \ - hangulin.html \ - hebrew.html \ - howto.html \ - if_cscop.html \ - if_mzsch.html \ - if_ole.html \ - if_perl.html \ - if_pyth.html \ - if_ruby.html \ - if_sniff.html \ - if_tcl.html \ - indent.html \ - index.html \ - insert.html \ - intro.html \ - map.html \ - mbyte.html \ - message.html \ - mlang.html \ - motion.html \ - netbeans.html \ - options.html \ - os_390.html \ - os_amiga.html \ - os_beos.html \ - os_dos.html \ - os_mac.html \ - os_mint.html \ - os_msdos.html \ - os_os2.html \ - os_qnx.html \ - os_risc.html \ - os_unix.html \ - os_vms.html \ - os_win32.html \ - pattern.html \ - pi_getscript.html \ - pi_gzip.html \ - pi_netrw.html \ - pi_paren.html \ - pi_spec.html \ - pi_tar.html \ - pi_vimball.html \ - pi_zip.html \ - print.html \ - quickfix.html \ - quickref.html \ - quotes.html \ - recover.html \ - remote.html \ - repeat.html \ - rileft.html \ - russian.html \ - scroll.html \ - sign.html \ - spell.html \ - sponsor.html \ - starting.html \ - syntax.html \ - tabpage.html \ - tags.html \ - tagsrch.html \ - term.html \ - tips.html \ - todo.html \ - uganda.html \ - undo.html \ - usr_01.html \ - usr_02.html \ - usr_03.html \ - usr_04.html \ - usr_05.html \ - usr_06.html \ - usr_07.html \ - usr_08.html \ - usr_09.html \ - usr_10.html \ - usr_11.html \ - usr_12.html \ - usr_20.html \ - usr_21.html \ - usr_22.html \ - usr_23.html \ - usr_24.html \ - usr_25.html \ - usr_26.html \ - usr_27.html \ - usr_28.html \ - usr_29.html \ - usr_30.html \ - usr_31.html \ - usr_32.html \ - usr_40.html \ - usr_41.html \ - usr_42.html \ - usr_43.html \ - usr_44.html \ - usr_45.html \ - usr_90.html \ - usr_toc.html \ - various.html \ - version4.html \ - version5.html \ - version6.html \ - version7.html \ - vi_diff.html \ - vimindex.html \ - visual.html \ - windows.html \ - workshop.html - -CONVERTED = \ - vim-fr.UTF-8.1 \ - evim-fr.UTF-8.1 \ - vimdiff-fr.UTF-8.1 \ - vimtutor-fr.UTF-8.1 \ - xxd-fr.UTF-8.1 \ - vim-it.UTF-8.1 \ - evim-it.UTF-8.1 \ - vimdiff-it.UTF-8.1 \ - vimtutor-it.UTF-8.1 \ - xxd-it.UTF-8.1 \ - vim-pl.UTF-8.1 \ - evim-pl.UTF-8.1 \ - vimdiff-pl.UTF-8.1 \ - vimtutor-pl.UTF-8.1 \ - xxd-pl.UTF-8.1 \ - vim-ru.UTF-8.1 \ - evim-ru.UTF-8.1 \ - vimdiff-ru.UTF-8.1 \ - vimtutor-ru.UTF-8.1 \ - xxd-ru.UTF-8.1 - -.SUFFIXES: -.SUFFIXES: .c .o .txt .html - -all: tags vim.man evim.man vimdiff.man vimtutor.man xxd.man $(CONVERTED) - -# Use Vim to generate the tags file. Can only be used when Vim has been -# compiled and installed. Supports multiple languages. -vimtags: $(DOCS) - $(VIMEXE) -u NONE -esX -c "helptags ++t ." -c quit - -# Use "doctags" to generate the tags file. Only works for English! -tags: doctags $(DOCS) - ./doctags $(DOCS) | LANG=C LC_ALL=C sort >tags - uniq -d -2 tags - -doctags: doctags.c - $(CC) doctags.c -o doctags - -vim.man: vim.1 - nroff -man vim.1 | sed -e s/.//g > vim.man - -evim.man: evim.1 - nroff -man evim.1 | sed -e s/.//g > evim.man - -vimdiff.man: vimdiff.1 - nroff -man vimdiff.1 | sed -e s/.//g > vimdiff.man - -vimtutor.man: vimtutor.1 - nroff -man vimtutor.1 | sed -e s/.//g > vimtutor.man - -xxd.man: xxd.1 - nroff -man xxd.1 | sed -e s/.//g > xxd.man - -uganda.nsis.txt: uganda.txt - sed -e 's/[ ]*\*[-a-zA-Z0-9.]*\*//g' -e 's/vim:tw=78://' \ - uganda.txt | uniq >uganda.nsis.txt - -# Awk version of .txt to .html conversion. -html: noerrors tags tags.ref $(HTMLS) - @if test -f errors.log; then more errors.log; fi - -noerrors: - -rm -f errors.log - -.txt.html: - $(AWK) -f makehtml.awk $< >$@ - -# index.html is the starting point for HTML, but for the help files it is -# help.txt. Therefore use vimindex.html for index.txt. -index.html: help.txt - $(AWK) -f makehtml.awk help.txt >index.html - -vimindex.html: index.txt - $(AWK) -f makehtml.awk index.txt >vimindex.html - -tags.ref tags.html: tags - $(AWK) -f maketags.awk tags >tags.html - -# Perl version of .txt to .html conversion. -# There can't be two rules to produce a .html from a .txt file. -# Just run over all .txt files each time one changes. It's fast anyway. -perlhtml: tags $(DOCS) - ./vim2html.pl tags $(DOCS) - -clean: - -rm doctags *.html tags.ref - -# These files are in the extra archive, skip if not present - -arabic.txt: - touch arabic.txt - -farsi.txt: - touch farsi.txt - -hebrew.txt: - touch hebrew.txt - -russian.txt: - touch russian.txt - -gui_w16.txt: - touch gui_w16.txt - -gui_w32.txt: - touch gui_w32.txt - -if_ole.txt: - touch if_ole.txt - -os_390.txt: - touch os_390.txt - -os_amiga.txt: - touch os_amiga.txt - -os_beos.txt: - touch os_beos.txt - -os_dos.txt: - touch os_dos.txt - -os_mac.txt: - touch os_mac.txt - -os_mint.txt: - touch os_mint.txt - -os_msdos.txt: - touch os_msdos.txt - -os_os2.txt: - touch os_os2.txt - -os_qnx.txt: - touch os_qnx.txt - -os_risc.txt: - touch os_risc.txt - -os_win32.txt: - touch os_win32.txt - -# Note that $< works with GNU make while $> works for BSD make. -# Is there a solution that works for both?? -vim-fr.UTF-8.1: vim-fr.1 - iconv -f latin1 -t utf-8 $< >$@ - -evim-fr.UTF-8.1: evim-fr.1 - iconv -f latin1 -t utf-8 $< >$@ - -vimdiff-fr.UTF-8.1: vimdiff-fr.1 - iconv -f latin1 -t utf-8 $< >$@ - -vimtutor-fr.UTF-8.1: vimtutor-fr.1 - iconv -f latin1 -t utf-8 $< >$@ - -xxd-fr.UTF-8.1: xxd-fr.1 - iconv -f latin1 -t utf-8 $< >$@ - -vim-it.UTF-8.1: vim-it.1 - iconv -f latin1 -t utf-8 $< >$@ - -evim-it.UTF-8.1: evim-it.1 - iconv -f latin1 -t utf-8 $< >$@ - -vimdiff-it.UTF-8.1: vimdiff-it.1 - iconv -f latin1 -t utf-8 $< >$@ - -vimtutor-it.UTF-8.1: vimtutor-it.1 - iconv -f latin1 -t utf-8 $< >$@ - -xxd-it.UTF-8.1: xxd-it.1 - iconv -f latin1 -t utf-8 $< >$@ - -vim-pl.UTF-8.1: vim-pl.1 - iconv -f latin2 -t utf-8 $< >$@ - -evim-pl.UTF-8.1: evim-pl.1 - iconv -f latin2 -t utf-8 $< >$@ - -vimdiff-pl.UTF-8.1: vimdiff-pl.1 - iconv -f latin2 -t utf-8 $< >$@ - -vimtutor-pl.UTF-8.1: vimtutor-pl.1 - iconv -f latin2 -t utf-8 $< >$@ - -xxd-pl.UTF-8.1: xxd-pl.1 - iconv -f latin2 -t utf-8 $< >$@ - -vim-ru.UTF-8.1: vim-ru.1 - iconv -f KOI8-R -t utf-8 $< >$@ - -evim-ru.UTF-8.1: evim-ru.1 - iconv -f KOI8-R -t utf-8 $< >$@ - -vimdiff-ru.UTF-8.1: vimdiff-ru.1 - iconv -f KOI8-R -t utf-8 $< >$@ - -vimtutor-ru.UTF-8.1: vimtutor-ru.1 - iconv -f KOI8-R -t utf-8 $< >$@ - -xxd-ru.UTF-8.1: xxd-ru.1 - iconv -f KOI8-R -t utf-8 $< >$@ diff --git a/share/vim/vim72/doc/arabic.txt b/share/vim/vim72/doc/arabic.txt deleted file mode 100644 index ec92d97ee3..0000000000 --- a/share/vim/vim72/doc/arabic.txt +++ /dev/null @@ -1,322 +0,0 @@ -*arabic.txt* For Vim version 7.2. Last change: 2005 Mar 29 - - - VIM REFERENCE MANUAL by Nadim Shaikli - - -Arabic Language support (options & mappings) for Vim *Arabic* - -{Vi does not have any of these commands} - - *E800* -In order to use right-to-left and Arabic mapping support, it is -necessary to compile VIM with the |+arabic| feature. - -These functions have been created by Nadim Shaikli - -It is best to view this file with these settings within VIM's GUI: > - - :set encoding=utf-8 - :set arabicshape - - -Introduction ------------- -Arabic is a rather demanding language in which a number of special -features are required. Characters are right-to-left oriented and -ought to appear as such on the screen (i.e. from right to left). -Arabic also requires shaping of its characters, meaning the same -character has a different visual form based on its relative location -within a word (initial, medial, final or stand-alone). Arabic also -requires two different forms of combining and the ability, in -certain instances, to either superimpose up to two characters on top -of another (composing) or the actual substitution of two characters -into one (combining). Lastly, to display Arabic properly one will -require not only ISO-8859-6 (U+0600-U+06FF) fonts, but will also -require Presentation Form-B (U+FE70-U+FEFF) fonts both of which are -subsets within a so-called ISO-10646-1 font. - -The commands, prompts and help files are not in Arabic, therefore -the user interface remains the standard Vi interface. - - -Highlights ----------- -o Editing left-to-right files as in the original VIM hasn't changed. - -o Viewing and editing files in right-to-left windows. File - orientation is per window, so it is possible to view the same - file in right-to-left and left-to-right modes, simultaneously. - -o No special terminal with right-to-left capabilities is required. - The right-to-left changes are completely hardware independent. - Only Arabic fonts are necessary. - -o Compatible with the original VIM. Almost all features work in - right-to-left mode (there are liable to be bugs). - -o Changing keyboard mapping and reverse insert modes using a single - command. - -o Toggling complete Arabic support via a single command. - -o While in Arabic mode, numbers are entered from left to right. Upon - entering a none number character, that character will be inserted - just into the left of the last number. - -o Arabic keymapping on the command line in reverse insert mode. - -o Proper Bidirectional functionality is possible given VIM is - started within a Bidi capable terminal emulator. - - -Arabic Fonts *arabicfonts* ------------- - -VIM requires monospaced fonts of which there are many out there. -Arabic requires ISO-8859-6 as well as Presentation Form-B fonts -(without Form-B, Arabic will _NOT_ be usable). It is highly -recommended that users search for so-called 'ISO-10646-1' fonts. -Do an Internet search or check www.arabeyes.org for further -info on where to attain the necessary Arabic fonts. - - -Font Installation ------------------ - -o Installation of fonts for X Window systems (Unix/Linux) - - Depending on your system, copy your_ARABIC_FONT file into a - directory of your choice. Change to the directory containing - the Arabic fonts and execute the following commands: - - % mkfontdir - % xset +fp path_name_of_arabic_fonts_directory - - -Usage ------ -Prior to the actual usage of Arabic within VIM, a number of settings -need to be accounted for and invoked. - -o Setting the Arabic fonts - - + For VIM GUI set the 'guifont' to your_ARABIC_FONT. This is done - by entering the following command in the VIM window. -> - :set guifont=your_ARABIC_FONT -< - NOTE: the string 'your_ARABIC_FONT' is used to denote a complete - font name akin to that used in Linux/Unix systems. - (e.g. -misc-fixed-medium-r-normal--20-200-75-75-c-100-iso10646-1) - - You can append the 'guifont' set command to your .vimrc file - in order to get the same above noted results. In other words, - you can include ':set guifont=your_ARABIC_FONT' to your .vimrc - file. - - + Under the X Window environment, you can also start VIM with - '-fn your_ARABIC_FONT' option. - -o Setting the appropriate character Encoding - To enable the correct Arabic encoding the following command needs - to be appended, -> - :set encoding=utf-8 -< - to your .vimrc file (entering the command manually into you VIM - window is highly discouraged). In short, include ':set - encoding=utf-8' to your .vimrc file. - - Attempts to use Arabic without UTF-8 will result the following - warning message, - - *W17* > - Arabic requires UTF-8, do ':set encoding=utf-8' - -o Enable Arabic settings [short-cut] - - In order to simplify and streamline things, you can either invoke - VIM with the command-line option, - - % vim -A my_utf8_arabic_file ... - - or enable 'arabic' via the following command within VIM -> - :set arabic -< - The two above noted possible invocations are the preferred manner - in which users are instructed to proceed. Baring an enabled 'termbidi' - setting, both command options: - - 1. set the appropriate keymap - 2. enable the deletion of a single combined pair character - 3. enable rightleft mode - 4. enable rightleftcmd mode (affecting the command-line) - 5. enable arabicshape mode (do visual character alterations) - - You may also append the command to your .vimrc file and simply - include ':set arabic' to it. - - You are also capable of disabling Arabic support via -> - :set noarabic -< - which resets everything that the command had enabled without touching - the global settings as they could affect other possible open buffers. - In short the 'noarabic' command, - - 1. resets to the alternate keymap - 2. disables the deletion of a single combined pair character - 3. disables rightleft mode - - NOTE: the 'arabic' command takes into consideration 'termbidi' for - possible external bi-directional (bidi) support from the - terminal ("mlterm" for instance offers such support). - 'termbidi', if available, is superior to rightleft support - and its support is preferred due to its level of offerings. - 'arabic' when 'termbidi' is enabled only sets the keymap. - - If, on the other hand, you'd like to be verbose and explicit and - are opting not to use the 'arabic' short-cut command, here's what - is needed (i.e. if you use ':set arabic' you can skip this section) - - - + Arabic Keymapping Activation - - To activate the Arabic keymap (i.e. to remap your English/Latin - keyboard to look-n-feel like a standard Arabic one), set the - 'keymap' command to "arabic". This is done by entering -> - :set keymap=arabic -< - in your VIM window. You can also append the 'keymap' set command to - your .vimrc file. In other words, you can include ':set keymap=arabic' - to your .vimrc file. - - To turn toggle (or switch) your keymapping between Arabic and the - default mapping (English), it is advised that users use the 'CTRL-^' - key press while in insert (or add/replace) mode. The command-line - will display your current mapping by displaying an "Arabic" string - next to your insertion mode (e.g. -- INSERT Arabic --) indicating - your current keymap. - - + Arabic deletion of a combined pair character - - By default VIM has the 'delcombine' option disabled. This option - allows the deletion of ALEF in a LAM_ALEF (LAA) combined character - and still retain the LAM (i.e. it reverts to treating the combined - character as its natural two characters form -- this also pertains - to harakat and their combined forms). You can enable this option - by entering -> - :set delcombine -< - in our VIM window. You can also append the 'delcombine' set command - to your .vimrc file. In other words, you can include ':set delcombine' - to your .vimrc file. - - + Arabic right-to-left Mode - - By default VIM starts in Left-to-right mode. 'rightleft' is the - command that allows one to alter a window's orientation - that can - be accomplished via, - - - Toggling between left-to-right and right-to-left modes is - accomplished through ':set rightleft' and ':set norightleft'. - - - While in Left-to-right mode, enter ':set rl' in the command line - ('rl' is the abbreviation for rightleft). - - - Put the ':set rl' line in your '.vimrc' file to start Vim in - right-to-left mode permanently. - - + Arabic right-to-left command-line Mode - - For certain commands the editing can be done in right-to-left mode. - Currently this is only applicable to search commands. - - This is controlled with the 'rightleftcmd' option. The default is - "search", which means that windows in which 'rightleft' is set will - edit search commands in right-left mode. To disable this behavior, -> - :set rightleftcmd= -< - To enable right-left editing of search commands again, -> - :set rightleftcmd& -< - + Arabic Shaping Mode - - To activate the required visual characters alterations (shaping, - composing, combining) which the Arabic language requires, enable - the 'arabicshape' command. This is done by entering -> - :set arabicshape -< - in our VIM window. You can also append the 'arabicshape' set - command to your .vimrc file. In other words, you can include - ':set arabicshape' to your .vimrc file. - - -Keymap/Keyboard *arabickeymap* ---------------- - -The character/letter encoding used in VIM is the standard UTF-8. -It is widely discouraged that any other encoding be used or even -attempted. - -Note: UTF-8 is an all encompassing encoding and as such is - the only supported (and encouraged) encoding with - regard to Arabic (all other proprietary encodings - should be discouraged and frowned upon). - -o Keyboard - - + CTRL-^ in insert/replace mode toggles between Arabic/Latin mode - - + Keyboard mapping is based on the Microsoft's Arabic keymap (the - defacto standard in the Arab world): - - +---------------------------------------------------------------------+ - |! |@ |# |$ |% |^ |& |* |( |) |_ |+ || |~ ّ | - |1 ١ |2 ٢ |3 ٣ |4 ٤ |5 ٥ |6 ٦ |7 ٧ |8 ٨ |9 ٩ |0 ٠ |- |= |\ |` ذ | - +---------------------------------------------------------------------+ - |Q َ |W ً |E ُ |R ٌ |T لإ |Y إ |U ` |I ÷ |O x |P ؛ |{ < |} > | - |q ض |w ص |e ث |r ق |t ف |y غ |u ع |i ه |o خ |p ح |[ ج |] د | - +-----------------------------------------------------------+ - |A ِ |S ٍ |D [ |F ] |G لأ |H أ |J ـ |K ، |L / |: |" | - |a ش |s س |d ي |f ب |g ل |h ا |j ت |k ن |l م |; ك |' ط | - +------------------------------------------------------+ - |Z ~ |X ْ |C { |V } |B لآ |N آ |M ' |< , |> . |? ؟ | - |z ئ |x ء |c ؤ |v ر |b لا |n ى |m ة |, و |. ز |/ ظ | - +-------------------------------------------------+ - -Restrictions ------------- - -o VIM in its GUI form does not currently support Bi-directionality - (i.e. the ability to see both Arabic and Latin intermixed within - the same line). - - -Known Bugs ----------- - -There is one known minor bug, - - 1. If you insert a haraka (e.g. Fatha (U+064E)) after a LAM (U+0644) - and then insert an ALEF (U+0627), the appropriate combining will - not happen due to the sandwiched haraka resulting in something - that will NOT be displayed correctly. - - WORK-AROUND: Don't include harakats between LAM and ALEF combos. - In general, don't anticipate to see correct visual - representation with regard to harakats and LAM+ALEF - combined characters (even those entered after both - characters). The problem noted is strictly a visual - one, meaning saving such a file will contain all the - appropriate info/encodings - nothing is lost. - -No other bugs are known to exist. - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/autocmd.txt b/share/vim/vim72/doc/autocmd.txt deleted file mode 100644 index 836f7d2128..0000000000 --- a/share/vim/vim72/doc/autocmd.txt +++ /dev/null @@ -1,1287 +0,0 @@ -*autocmd.txt* For Vim version 7.2. Last change: 2008 Jun 27 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Automatic commands *autocommand* - -For a basic explanation, see section |40.3| in the user manual. - -1. Introduction |autocmd-intro| -2. Defining autocommands |autocmd-define| -3. Removing autocommands |autocmd-remove| -4. Listing autocommands |autocmd-list| -5. Events |autocmd-events| -6. Patterns |autocmd-patterns| -7. Buffer-local autocommands |autocmd-buflocal| -8. Groups |autocmd-groups| -9. Executing autocommands |autocmd-execute| -10. Using autocommands |autocmd-use| -11. Disabling autocommands |autocmd-disable| - -{Vi does not have any of these commands} -{only when the |+autocmd| feature has not been disabled at compile time} - -============================================================================== -1. Introduction *autocmd-intro* - -You can specify commands to be executed automatically when reading or writing -a file, when entering or leaving a buffer or window, and when exiting Vim. -For example, you can create an autocommand to set the 'cindent' option for -files matching *.c. You can also use autocommands to implement advanced -features, such as editing compressed files (see |gzip-example|). The usual -place to put autocommands is in your .vimrc or .exrc file. - - *E203* *E204* *E143* -WARNING: Using autocommands is very powerful, and may lead to unexpected side -effects. Be careful not to destroy your text. -- It's a good idea to do some testing on an expendable copy of a file first. - For example: If you use autocommands to decompress a file when starting to - edit it, make sure that the autocommands for compressing when writing work - correctly. -- Be prepared for an error halfway through (e.g., disk full). Vim will mostly - be able to undo the changes to the buffer, but you may have to clean up the - changes to other files by hand (e.g., compress a file that has been - decompressed). -- If the BufRead* events allow you to edit a compressed file, the FileRead* - events should do the same (this makes recovery possible in some rare cases). - It's a good idea to use the same autocommands for the File* and Buf* events - when possible. - -============================================================================== -2. Defining autocommands *autocmd-define* - -Note: The ":autocmd" command cannot be followed by another command, since any -'|' is considered part of the command. - - *:au* *:autocmd* -:au[tocmd] [group] {event} {pat} [nested] {cmd} - Add {cmd} to the list of commands that Vim will - execute automatically on {event} for a file matching - {pat}. Vim always adds the {cmd} after existing - autocommands, so that the autocommands execute in the - order in which they were given. See |autocmd-nested| - for [nested]. - -The special pattern or defines a buffer-local autocommand. -See |autocmd-buflocal|. - -Note that special characters (e.g., "%", "") in the ":autocmd" -arguments are not expanded when the autocommand is defined. These will be -expanded when the Event is recognized, and the {cmd} is executed. The only -exception is that "" is expanded when the autocmd is defined. Example: -> - :au BufNewFile,BufRead *.html so :h/html.vim - -Here Vim expands to the name of the file containing this line. - -When your .vimrc file is sourced twice, the autocommands will appear twice. -To avoid this, put this command in your .vimrc file, before defining -autocommands: > - - :autocmd! " Remove ALL autocommands for the current group. - -If you don't want to remove all autocommands, you can instead use a variable -to ensure that Vim includes the autocommands only once: > - - :if !exists("autocommands_loaded") - : let autocommands_loaded = 1 - : au ... - :endif - -When the [group] argument is not given, Vim uses the current group (as defined -with ":augroup"); otherwise, Vim uses the group defined with [group]. Note -that [group] must have been defined before. You cannot define a new group -with ":au group ..."; use ":augroup" for that. - -While testing autocommands, you might find the 'verbose' option to be useful: > - :set verbose=9 -This setting makes Vim echo the autocommands as it executes them. - -When defining an autocommand in a script, it will be able to call functions -local to the script and use mappings local to the script. When the event is -triggered and the command executed, it will run in the context of the script -it was defined in. This matters if || is used in a command. - -When executing the commands, the message from one command overwrites a -previous message. This is different from when executing the commands -manually. Mostly the screen will not scroll up, thus there is no hit-enter -prompt. When one command outputs two messages this can happen anyway. - -============================================================================== -3. Removing autocommands *autocmd-remove* - -:au[tocmd]! [group] {event} {pat} [nested] {cmd} - Remove all autocommands associated with {event} and - {pat}, and add the command {cmd}. See - |autocmd-nested| for [nested]. - -:au[tocmd]! [group] {event} {pat} - Remove all autocommands associated with {event} and - {pat}. - -:au[tocmd]! [group] * {pat} - Remove all autocommands associated with {pat} for all - events. - -:au[tocmd]! [group] {event} - Remove ALL autocommands for {event}. - -:au[tocmd]! [group] Remove ALL autocommands. - -When the [group] argument is not given, Vim uses the current group (as defined -with ":augroup"); otherwise, Vim uses the group defined with [group]. - -============================================================================== -4. Listing autocommands *autocmd-list* - -:au[tocmd] [group] {event} {pat} - Show the autocommands associated with {event} and - {pat}. - -:au[tocmd] [group] * {pat} - Show the autocommands associated with {pat} for all - events. - -:au[tocmd] [group] {event} - Show all autocommands for {event}. - -:au[tocmd] [group] Show all autocommands. - -If you provide the [group] argument, Vim lists only the autocommands for -[group]; otherwise, Vim lists the autocommands for ALL groups. Note that this -argument behavior differs from that for defining and removing autocommands. - -In order to list buffer-local autocommands, use a pattern in the form -or . See |autocmd-buflocal|. - - *:autocmd-verbose* -When 'verbose' is non-zero, listing an autocommand will also display where it -was last defined. Example: > - - :verbose autocmd BufEnter - FileExplorer BufEnter - * call s:LocalBrowse(expand("")) - Last set from /usr/share/vim/vim-7.0/plugin/NetrwPlugin.vim -< -See |:verbose-cmd| for more information. - -============================================================================== -5. Events *autocmd-events* *E215* *E216* - -You can specify a comma-separated list of event names. No white space can be -used in this list. The command applies to all the events in the list. - -For READING FILES there are four kinds of events possible: - BufNewFile starting to edit a non-existent file - BufReadPre BufReadPost starting to edit an existing file - FilterReadPre FilterReadPost read the temp file with filter output - FileReadPre FileReadPost any other file read -Vim uses only one of these four kinds when reading a file. The "Pre" and -"Post" events are both triggered, before and after reading the file. - -Note that the autocommands for the *ReadPre events and all the Filter events -are not allowed to change the current buffer (you will get an error message if -this happens). This is to prevent the file to be read into the wrong buffer. - -Note that the 'modified' flag is reset AFTER executing the BufReadPost -and BufNewFile autocommands. But when the 'modified' option was set by the -autocommands, this doesn't happen. - -You can use the 'eventignore' option to ignore a number of events or all -events. - *autocommand-events* *{event}* -Vim recognizes the following events. Vim ignores the case of event names -(e.g., you can use "BUFread" or "bufread" instead of "BufRead"). - -First an overview by function with a short explanation. Then the list -alphabetically with full explanations |autocmd-events-abc|. - -Name triggered by ~ - - Reading -|BufNewFile| starting to edit a file that doesn't exist -|BufReadPre| starting to edit a new buffer, before reading the file -|BufRead| starting to edit a new buffer, after reading the file -|BufReadPost| starting to edit a new buffer, after reading the file -|BufReadCmd| before starting to edit a new buffer |Cmd-event| - -|FileReadPre| before reading a file with a ":read" command -|FileReadPost| after reading a file with a ":read" command -|FileReadCmd| before reading a file with a ":read" command |Cmd-event| - -|FilterReadPre| before reading a file from a filter command -|FilterReadPost| after reading a file from a filter command - -|StdinReadPre| before reading from stdin into the buffer -|StdinReadPost| After reading from the stdin into the buffer - - Writing -|BufWrite| starting to write the whole buffer to a file -|BufWritePre| starting to write the whole buffer to a file -|BufWritePost| after writing the whole buffer to a file -|BufWriteCmd| before writing the whole buffer to a file |Cmd-event| - -|FileWritePre| starting to write part of a buffer to a file -|FileWritePost| after writing part of a buffer to a file -|FileWriteCmd| before writing part of a buffer to a file |Cmd-event| - -|FileAppendPre| starting to append to a file -|FileAppendPost| after appending to a file -|FileAppendCmd| before appending to a file |Cmd-event| - -|FilterWritePre| starting to write a file for a filter command or diff -|FilterWritePost| after writing a file for a filter command or diff - - Buffers -|BufAdd| just after adding a buffer to the buffer list -|BufCreate| just after adding a buffer to the buffer list -|BufDelete| before deleting a buffer from the buffer list -|BufWipeout| before completely deleting a buffer - -|BufFilePre| before changing the name of the current buffer -|BufFilePost| after changing the name of the current buffer - -|BufEnter| after entering a buffer -|BufLeave| before leaving to another buffer -|BufWinEnter| after a buffer is displayed in a window -|BufWinLeave| before a buffer is removed from a window - -|BufUnload| before unloading a buffer -|BufHidden| just after a buffer has become hidden -|BufNew| just after creating a new buffer - -|SwapExists| detected an existing swap file - - Options -|FileType| when the 'filetype' option has been set -|Syntax| when the 'syntax' option has been set -|EncodingChanged| after the 'encoding' option has been changed -|TermChanged| after the value of 'term' has changed - - Startup and exit -|VimEnter| after doing all the startup stuff -|GUIEnter| after starting the GUI successfully -|TermResponse| after the terminal response to |t_RV| is received - -|VimLeavePre| before exiting Vim, before writing the viminfo file -|VimLeave| before exiting Vim, after writing the viminfo file - - Various -|FileChangedShell| Vim notices that a file changed since editing started -|FileChangedShellPost| After handling a file changed since editing started -|FileChangedRO| before making the first change to a read-only file - -|ShellCmdPost| after executing a shell command -|ShellFilterPost| after filtering with a shell command - -|FuncUndefined| a user function is used but it isn't defined -|SpellFileMissing| a spell file is used but it can't be found -|SourcePre| before sourcing a Vim script -|SourceCmd| before sourcing a Vim script |Cmd-event| - -|VimResized| after the Vim window size changed -|FocusGained| Vim got input focus -|FocusLost| Vim lost input focus -|CursorHold| the user doesn't press a key for a while -|CursorHoldI| the user doesn't press a key for a while in Insert mode -|CursorMoved| the cursor was moved in Normal mode -|CursorMovedI| the cursor was moved in Insert mode - -|WinEnter| after entering another window -|WinLeave| before leaving a window -|TabEnter| after entering another tab page -|TabLeave| before leaving a tab page -|CmdwinEnter| after entering the command-line window -|CmdwinLeave| before leaving the command-line window - -|InsertEnter| starting Insert mode -|InsertChange| when typing while in Insert or Replace mode -|InsertLeave| when leaving Insert mode - -|ColorScheme| after loading a color scheme - -|RemoteReply| a reply from a server Vim was received - -|QuickFixCmdPre| before a quickfix command is run -|QuickFixCmdPost| after a quickfix command is run - -|SessionLoadPost| after loading a session file - -|MenuPopup| just before showing the popup menu - -|User| to be used in combination with ":doautocmd" - - -The alphabetical list of autocommand events: *autocmd-events-abc* - - *BufCreate* *BufAdd* -BufAdd or BufCreate Just after creating a new buffer which is - added to the buffer list, or adding a buffer - to the buffer list. - Also used just after a buffer in the buffer - list has been renamed. - The BufCreate event is for historic reasons. - NOTE: When this autocommand is executed, the - current buffer "%" may be different from the - buffer being created "". - *BufDelete* -BufDelete Before deleting a buffer from the buffer list. - The BufUnload may be called first (if the - buffer was loaded). - Also used just before a buffer in the buffer - list is renamed. - NOTE: When this autocommand is executed, the - current buffer "%" may be different from the - buffer being deleted "" and "". - *BufEnter* -BufEnter After entering a buffer. Useful for setting - options for a file type. Also executed when - starting to edit a buffer, after the - BufReadPost autocommands. - *BufFilePost* -BufFilePost After changing the name of the current buffer - with the ":file" or ":saveas" command. - *BufFilePre* -BufFilePre Before changing the name of the current buffer - with the ":file" or ":saveas" command. - *BufHidden* -BufHidden Just after a buffer has become hidden. That - is, when there are no longer windows that show - the buffer, but the buffer is not unloaded or - deleted. Not used for ":qa" or ":q" when - exiting Vim. - NOTE: When this autocommand is executed, the - current buffer "%" may be different from the - buffer being unloaded "". - *BufLeave* -BufLeave Before leaving to another buffer. Also when - leaving or closing the current window and the - new current window is not for the same buffer. - Not used for ":qa" or ":q" when exiting Vim. - *BufNew* -BufNew Just after creating a new buffer. Also used - just after a buffer has been renamed. When - the buffer is added to the buffer list BufAdd - will be triggered too. - NOTE: When this autocommand is executed, the - current buffer "%" may be different from the - buffer being created "". - *BufNewFile* -BufNewFile When starting to edit a file that doesn't - exist. Can be used to read in a skeleton - file. - *BufRead* *BufReadPost* -BufRead or BufReadPost When starting to edit a new buffer, after - reading the file into the buffer, before - executing the modelines. See |BufWinEnter| - for when you need to do something after - processing the modelines. - This does NOT work for ":r file". Not used - when the file doesn't exist. Also used after - successfully recovering a file. - *BufReadCmd* -BufReadCmd Before starting to edit a new buffer. Should - read the file into the buffer. |Cmd-event| - *BufReadPre* *E200* *E201* -BufReadPre When starting to edit a new buffer, before - reading the file into the buffer. Not used - if the file doesn't exist. - *BufUnload* -BufUnload Before unloading a buffer. This is when the - text in the buffer is going to be freed. This - may be after a BufWritePost and before a - BufDelete. Also used for all buffers that are - loaded when Vim is going to exit. - NOTE: When this autocommand is executed, the - current buffer "%" may be different from the - buffer being unloaded "". - *BufWinEnter* -BufWinEnter After a buffer is displayed in a window. This - can be when the buffer is loaded (after - processing the modelines) or when a hidden - buffer is displayed in a window (and is no - longer hidden). - Does not happen for |:split| without - arguments, since you keep editing the same - buffer, or ":split" with a file that's already - open in a window, because it re-uses an - existing buffer. But it does happen for a - ":split" with the name of the current buffer, - since it reloads that buffer. - *BufWinLeave* -BufWinLeave Before a buffer is removed from a window. - Not when it's still visible in another window. - Also triggered when exiting. It's triggered - before BufUnload or BufHidden. - NOTE: When this autocommand is executed, the - current buffer "%" may be different from the - buffer being unloaded "". - *BufWipeout* -BufWipeout Before completely deleting a buffer. The - BufUnload and BufDelete events may be called - first (if the buffer was loaded and was in the - buffer list). Also used just before a buffer - is renamed (also when it's not in the buffer - list). - NOTE: When this autocommand is executed, the - current buffer "%" may be different from the - buffer being deleted "". - *BufWrite* *BufWritePre* -BufWrite or BufWritePre Before writing the whole buffer to a file. - *BufWriteCmd* -BufWriteCmd Before writing the whole buffer to a file. - Should do the writing of the file and reset - 'modified' if successful, unless '+' is in - 'cpo' and writing to another file |cpo-+|. - The buffer contents should not be changed. - |Cmd-event| - *BufWritePost* -BufWritePost After writing the whole buffer to a file - (should undo the commands for BufWritePre). - *CmdwinEnter* -CmdwinEnter After entering the command-line window. - Useful for setting options specifically for - this special type of window. This is - triggered _instead_ of BufEnter and WinEnter. - is set to a single character, - indicating the type of command-line. - |cmdwin-char| - *CmdwinLeave* -CmdwinLeave Before leaving the command-line window. - Useful to clean up any global setting done - with CmdwinEnter. This is triggered _instead_ - of BufLeave and WinLeave. - is set to a single character, - indicating the type of command-line. - |cmdwin-char| - *ColorScheme* -ColorScheme After loading a color scheme. |:colorscheme| - - *CursorHold* -CursorHold When the user doesn't press a key for the time - specified with 'updatetime'. Not re-triggered - until the user has pressed a key (i.e. doesn't - fire every 'updatetime' ms if you leave Vim to - make some coffee. :) See |CursorHold-example| - for previewing tags. - This event is only triggered in Normal mode. - It is not triggered when waiting for a command - argument to be typed, or a movement after an - operator. - While recording the CursorHold event is not - triggered. |q| - Note: Interactive commands cannot be used for - this event. There is no hit-enter prompt, - the screen is updated directly (when needed). - Note: In the future there will probably be - another option to set the time. - Hint: to force an update of the status lines - use: > - :let &ro = &ro -< {only on Amiga, Unix, Win32, MSDOS and all GUI - versions} - *CursorHoldI* -CursorHoldI Just like CursorHold, but in Insert mode. - - *CursorMoved* -CursorMoved After the cursor was moved in Normal mode. - Also when the text of the cursor line has been - changed, e.g., with "x", "rx" or "p". - Not triggered when there is typeahead or when - an operator is pending. - For an example see |match-parens|. - Careful: Don't do anything that the user does - not expect or that is slow. - *CursorMovedI* -CursorMovedI After the cursor was moved in Insert mode. - Otherwise the same as CursorMoved. - *EncodingChanged* -EncodingChanged Fires off after the 'encoding' option has been - changed. Useful to set up fonts, for example. - *FileAppendCmd* -FileAppendCmd Before appending to a file. Should do the - appending to the file. Use the '[ and '] - marks for the range of lines.|Cmd-event| - *FileAppendPost* -FileAppendPost After appending to a file. - *FileAppendPre* -FileAppendPre Before appending to a file. Use the '[ and '] - marks for the range of lines. - *FileChangedRO* -FileChangedRO Before making the first change to a read-only - file. Can be used to check-out the file from - a source control system. Not triggered when - the change was caused by an autocommand. - This event is triggered when making the first - change in a buffer or the first change after - 'readonly' was set, just before the change is - applied to the text. - WARNING: If the autocommand moves the cursor - the effect of the change is undefined. - *E788* - It is not allowed to change to another buffer - here. You can reload the buffer but not edit - another one. - *FileChangedShell* -FileChangedShell When Vim notices that the modification time of - a file has changed since editing started. - Also when the file attributes of the file - change. |timestamp| - Mostly triggered after executing a shell - command, but also with a |:checktime| command - or when Gvim regains input focus. - This autocommand is triggered for each changed - file. It is not used when 'autoread' is set - and the buffer was not changed. If a - FileChangedShell autocommand is present the - warning message and prompt is not given. - The |v:fcs_reason| variable is set to indicate - what happened and |v:fcs_choice| can be used - to tell Vim what to do next. - NOTE: When this autocommand is executed, the - current buffer "%" may be different from the - buffer that was changed "". - NOTE: The commands must not change the current - buffer, jump to another buffer or delete a - buffer. *E246* - NOTE: This event never nests, to avoid an - endless loop. This means that while executing - commands for the FileChangedShell event no - other FileChangedShell event will be - triggered. - *FileChangedShellPost* -FileChangedShellPost After handling a file that was changed outside - of Vim. Can be used to update the statusline. - *FileEncoding* -FileEncoding Obsolete. It still works and is equivalent - to |EncodingChanged|. - *FileReadCmd* -FileReadCmd Before reading a file with a ":read" command. - Should do the reading of the file. |Cmd-event| - *FileReadPost* -FileReadPost After reading a file with a ":read" command. - Note that Vim sets the '[ and '] marks to the - first and last line of the read. This can be - used to operate on the lines just read. - *FileReadPre* -FileReadPre Before reading a file with a ":read" command. - *FileType* -FileType When the 'filetype' option has been set. The - pattern is matched against the filetype. - can be used for the name of the file - where this option was set, and for - the new value of 'filetype'. - See |filetypes|. - *FileWriteCmd* -FileWriteCmd Before writing to a file, when not writing the - whole buffer. Should do the writing to the - file. Should not change the buffer. Use the - '[ and '] marks for the range of lines. - |Cmd-event| - *FileWritePost* -FileWritePost After writing to a file, when not writing the - whole buffer. - *FileWritePre* -FileWritePre Before writing to a file, when not writing the - whole buffer. Use the '[ and '] marks for the - range of lines. - *FilterReadPost* -FilterReadPost After reading a file from a filter command. - Vim checks the pattern against the name of - the current buffer as with FilterReadPre. - Not triggered when 'shelltemp' is off. - *FilterReadPre* *E135* -FilterReadPre Before reading a file from a filter command. - Vim checks the pattern against the name of - the current buffer, not the name of the - temporary file that is the output of the - filter command. - Not triggered when 'shelltemp' is off. - *FilterWritePost* -FilterWritePost After writing a file for a filter command or - making a diff. - Vim checks the pattern against the name of - the current buffer as with FilterWritePre. - Not triggered when 'shelltemp' is off. - *FilterWritePre* -FilterWritePre Before writing a file for a filter command or - making a diff. - Vim checks the pattern against the name of - the current buffer, not the name of the - temporary file that is the output of the - filter command. - Not triggered when 'shelltemp' is off. - *FocusGained* -FocusGained When Vim got input focus. Only for the GUI - version and a few console versions where this - can be detected. - *FocusLost* -FocusLost When Vim lost input focus. Only for the GUI - version and a few console versions where this - can be detected. May also happen when a - dialog pops up. - *FuncUndefined* -FuncUndefined When a user function is used but it isn't - defined. Useful for defining a function only - when it's used. The pattern is matched - against the function name. Both and - are set to the name of the function. - See |autoload-functions|. - *GUIEnter* -GUIEnter After starting the GUI successfully, and after - opening the window. It is triggered before - VimEnter when using gvim. Can be used to - position the window from a .gvimrc file: > - :autocmd GUIEnter * winpos 100 50 -< *GUIFailed* -GUIFailed After starting the GUI failed. Vim may - continue to run in the terminal, if possible - (only on Unix and alikes, when connecting the - X server fails). You may want to quit Vim: > - :autocmd GUIFailed * qall -< *InsertChange* -InsertChange When typing while in Insert or - Replace mode. The |v:insertmode| variable - indicates the new mode. - Be careful not to move the cursor or do - anything else that the user does not expect. - *InsertEnter* -InsertEnter Just before starting Insert mode. Also for - Replace mode and Virtual Replace mode. The - |v:insertmode| variable indicates the mode. - Be careful not to move the cursor or do - anything else that the user does not expect. - *InsertLeave* -InsertLeave When leaving Insert mode. Also when using - CTRL-O |i_CTRL-O|. But not for |i_CTRL-C|. - *MenuPopup* -MenuPopup Just before showing the popup menu (under the - right mouse button). Useful for adjusting the - menu for what is under the cursor or mouse - pointer. - The pattern is matched against a single - character representing the mode: - n Normal - v Visual - o Operator-pending - i Insert - c Command line - *QuickFixCmdPre* -QuickFixCmdPre Before a quickfix command is run (|:make|, - |:lmake|, |:grep|, |:lgrep|, |:grepadd|, - |:lgrepadd|, |:vimgrep|, |:lvimgrep|, - |:vimgrepadd|, |:lvimgrepadd|). The pattern is - matched against the command being run. When - |:grep| is used but 'grepprg' is set to - "internal" it still matches "grep". - This command cannot be used to set the - 'makeprg' and 'grepprg' variables. - If this command causes an error, the quickfix - command is not executed. - *QuickFixCmdPost* -QuickFixCmdPost Like QuickFixCmdPre, but after a quickfix - command is run, before jumping to the first - location. See |QuickFixCmdPost-example|. - *RemoteReply* -RemoteReply When a reply from a Vim that functions as - server was received |server2client()|. The - pattern is matched against the {serverid}. - is equal to the {serverid} from which - the reply was sent, and is the actual - reply string. - Note that even if an autocommand is defined, - the reply should be read with |remote_read()| - to consume it. - *SessionLoadPost* -SessionLoadPost After loading the session file created using - the |:mksession| command. - *ShellCmdPost* -ShellCmdPost After executing a shell command with |:!cmd|, - |:shell|, |:make| and |:grep|. Can be used to - check for any changed files. - *ShellFilterPost* -ShellFilterPost After executing a shell command with - ":{range}!cmd", ":w !cmd" or ":r !cmd". - Can be used to check for any changed files. - *SourcePre* -SourcePre Before sourcing a Vim script. |:source| - is the name of the file being sourced. - *SourceCmd* -SourceCmd When sourcing a Vim script. |:source| - is the name of the file being sourced. - The autocommand must source this file. - |Cmd-event| - *SpellFileMissing* -SpellFileMissing When trying to load a spell checking file and - it can't be found. The pattern is matched - against the language. is the - language, 'encoding' also matters. See - |spell-SpellFileMissing|. - *StdinReadPost* -StdinReadPost After reading from the stdin into the buffer, - before executing the modelines. Only used - when the "-" argument was used when Vim was - started |--|. - *StdinReadPre* -StdinReadPre Before reading from stdin into the buffer. - Only used when the "-" argument was used when - Vim was started |--|. - *SwapExists* -SwapExists Detected an existing swap file when starting - to edit a file. Only when it is possible to - select a way to handle the situation, when Vim - would ask the user what to do. - The |v:swapname| variable holds the name of - the swap file found, the file being - edited. |v:swapcommand| may contain a command - to be executed in the opened file. - The commands should set the |v:swapchoice| - variable to a string with one character to - tell Vim what should be done next: - 'o' open read-only - 'e' edit the file anyway - 'r' recover - 'd' delete the swap file - 'q' quit, don't edit the file - 'a' abort, like hitting CTRL-C - When set to an empty string the user will be - asked, as if there was no SwapExists autocmd. - Note: Do not try to change the buffer, the - results are unpredictable. - *Syntax* -Syntax When the 'syntax' option has been set. The - pattern is matched against the syntax name. - can be used for the name of the file - where this option was set, and for - the new value of 'syntax'. - See |:syn-on|. - *TabEnter* -TabEnter Just after entering a tab page. |tab-page| - After triggering the WinEnter and before - triggering the BufEnter event. - *TabLeave* -TabLeave Just before leaving a tab page. |tab-page| - A WinLeave event will have been triggered - first. - *TermChanged* -TermChanged After the value of 'term' has changed. Useful - for re-loading the syntax file to update the - colors, fonts and other terminal-dependent - settings. Executed for all loaded buffers. - *TermResponse* -TermResponse After the response to |t_RV| is received from - the terminal. The value of |v:termresponse| - can be used to do things depending on the - terminal version. - *User* -User Never executed automatically. To be used for - autocommands that are only executed with - ":doautocmd". - *UserGettingBored* -UserGettingBored When the user hits CTRL-C. Just kidding! :-) - *VimEnter* -VimEnter After doing all the startup stuff, including - loading .vimrc files, executing the "-c cmd" - arguments, creating all windows and loading - the buffers in them. - *VimLeave* -VimLeave Before exiting Vim, just after writing the - .viminfo file. Executed only once, like - VimLeavePre. - To detect an abnormal exit use |v:dying|. - *VimLeavePre* -VimLeavePre Before exiting Vim, just before writing the - .viminfo file. This is executed only once, - if there is a match with the name of what - happens to be the current buffer when exiting. - Mostly useful with a "*" pattern. > - :autocmd VimLeavePre * call CleanupStuff() -< To detect an abnormal exit use |v:dying|. - *VimResized* -VimResized After the Vim window was resized, thus 'lines' - and/or 'columns' changed. Not when starting - up though. - *WinEnter* -WinEnter After entering another window. Not done for - the first window, when Vim has just started. - Useful for setting the window height. - If the window is for another buffer, Vim - executes the BufEnter autocommands after the - WinEnter autocommands. - Note: When using ":split fname" the WinEnter - event is triggered after the split but before - the file "fname" is loaded. - *WinLeave* -WinLeave Before leaving a window. If the window to be - entered next is for a different buffer, Vim - executes the BufLeave autocommands before the - WinLeave autocommands (but not for ":new"). - Not used for ":qa" or ":q" when exiting Vim. - -============================================================================== -6. Patterns *autocmd-patterns* *{pat}* - -The file pattern {pat} is tested for a match against the file name in one of -two ways: -1. When there is no '/' in the pattern, Vim checks for a match against only - the tail part of the file name (without its leading directory path). -2. When there is a '/' in the pattern, Vim checks for a match against the - both short file name (as you typed it) and the full file name (after - expanding it to a full path and resolving symbolic links). - -The special pattern or is used for buffer-local -autocommands |autocmd-buflocal|. This pattern is not matched against the name -of a buffer. - -Examples: > - :autocmd BufRead *.txt set et -Set the 'et' option for all text files. > - - :autocmd BufRead /vim/src/*.c set cindent -Set the 'cindent' option for C files in the /vim/src directory. > - - :autocmd BufRead /tmp/*.c set ts=5 -If you have a link from "/tmp/test.c" to "/home/nobody/vim/src/test.c", and -you start editing "/tmp/test.c", this autocommand will match. - -Note: To match part of a path, but not from the root directory, use a '*' as -the first character. Example: > - :autocmd BufRead */doc/*.txt set tw=78 -This autocommand will for example be executed for "/tmp/doc/xx.txt" and -"/usr/home/piet/doc/yy.txt". The number of directories does not matter here. - - -The file name that the pattern is matched against is after expanding -wildcards. Thus if you issue this command: > - :e $ROOTDIR/main.$EXT -The argument is first expanded to: > - /usr/root/main.py -Before it's matched with the pattern of the autocommand. Careful with this -when using events like FileReadCmd, the value of may not be what you -expect. - - -Environment variables can be used in a pattern: > - :autocmd BufRead $VIMRUNTIME/doc/*.txt set expandtab -And ~ can be used for the home directory (if $HOME is defined): > - :autocmd BufWritePost ~/.vimrc so ~/.vimrc - :autocmd BufRead ~archive/* set readonly -The environment variable is expanded when the autocommand is defined, not when -the autocommand is executed. This is different from the command! - - *file-pattern* -The pattern is interpreted like mostly used in file names: - * matches any sequence of characters - ? matches any single character - \? matches a '?' - . matches a '.' - ~ matches a '~' - , separates patterns - \, matches a ',' - { } like \( \) in a |pattern| - , inside { }: like \| in a |pattern| - \ special meaning like in a |pattern| - [ch] matches 'c' or 'h' - [^ch] match any character but 'c' and 'h' - -Note that for all systems the '/' character is used for path separator (even -MS-DOS and OS/2). This was done because the backslash is difficult to use -in a pattern and to make the autocommands portable across different systems. - - *autocmd-changes* -Matching with the pattern is done when an event is triggered. Changing the -buffer name in one of the autocommands, or even deleting the buffer, does not -change which autocommands will be executed. Example: > - - au BufEnter *.foo bdel - au BufEnter *.foo set modified - -This will delete the current buffer and then set 'modified' in what has become -the current buffer instead. Vim doesn't take into account that "*.foo" -doesn't match with that buffer name. It matches "*.foo" with the name of the -buffer at the moment the event was triggered. - -However, buffer-local autocommands will not be executed for a buffer that has -been wiped out with |:bwipe|. After deleting the buffer with |:bdel| the -buffer actually still exists (it becomes unlisted), thus the autocommands are -still executed. - -============================================================================== -7. Buffer-local autocommands *autocmd-buflocal* *autocmd-buffer-local* - ** ** *E680* - -Buffer-local autocommands are attached to a specific buffer. They are useful -if the buffer does not have a name and when the name does not match a specific -pattern. But it also means they must be explicitly added to each buffer. - -Instead of a pattern buffer-local autocommands use one of these forms: - current buffer - buffer number 99 - using (only when executing autocommands) - || - -Examples: > - :au CursorHold echo 'hold' - :au CursorHold echo 'hold' - :au CursorHold echo 'hold' - -All the commands for autocommands also work with buffer-local autocommands, -simply use the special string instead of the pattern. Examples: > - :au! * " remove buffer-local autocommands for - " current buffer - :au! * " remove buffer-local autocommands for - " buffer #33 - :bufdo :au! CursorHold " remove autocmd for given event for all - " buffers - :au * " list buffer-local autocommands for - " current buffer - -Note that when an autocommand is defined for the current buffer, it is stored -with the buffer number. Thus it uses the form "", where 12 is the -number of the current buffer. You will see this when listing autocommands, -for example. - -To test for presence of buffer-local autocommands use the |exists()| function -as follows: > - :if exists("#CursorHold#") | ... | endif - :if exists("#CursorHold#") | ... | endif " for current buffer - -When a buffer is wiped out its buffer-local autocommands are also gone, of -course. Note that when deleting a buffer, e.g., with ":bdel", it is only -unlisted, the autocommands are still present. In order to see the removal of -buffer-local autocommands: > - :set verbose=6 - -It is not possible to define buffer-local autocommands for a non-existent -buffer. - -============================================================================== -8. Groups *autocmd-groups* - -Autocommands can be put together in a group. This is useful for removing or -executing a group of autocommands. For example, all the autocommands for -syntax highlighting are put in the "highlight" group, to be able to execute -":doautoall highlight BufRead" when the GUI starts. - -When no specific group is selected, Vim uses the default group. The default -group does not have a name. You cannot execute the autocommands from the -default group separately; you can execute them only by executing autocommands -for all groups. - -Normally, when executing autocommands automatically, Vim uses the autocommands -for all groups. The group only matters when executing autocommands with -":doautocmd" or ":doautoall", or when defining or deleting autocommands. - -The group name can contain any characters except white space. The group name -"end" is reserved (also in uppercase). - -The group name is case sensitive. Note that this is different from the event -name! - - *:aug* *:augroup* -:aug[roup] {name} Define the autocmd group name for the - following ":autocmd" commands. The name "end" - or "END" selects the default group. - - *:augroup-delete* *E367* -:aug[roup]! {name} Delete the autocmd group {name}. Don't use - this if there is still an autocommand using - this group! This is not checked. - -To enter autocommands for a specific group, use this method: -1. Select the group with ":augroup {name}". -2. Delete any old autocommands with ":au!". -3. Define the autocommands. -4. Go back to the default group with "augroup END". - -Example: > - :augroup uncompress - : au! - : au BufEnter *.gz %!gunzip - :augroup END - -This prevents having the autocommands defined twice (e.g., after sourcing the -.vimrc file again). - -============================================================================== -9. Executing autocommands *autocmd-execute* - -Vim can also execute Autocommands non-automatically. This is useful if you -have changed autocommands, or when Vim has executed the wrong autocommands -(e.g., the file pattern match was wrong). - -Note that the 'eventignore' option applies here too. Events listed in this -option will not cause any commands to be executed. - - *:do* *:doau* *:doautocmd* *E217* -:do[autocmd] [group] {event} [fname] - Apply the autocommands matching [fname] (default: - current file name) for {event} to the current buffer. - You can use this when the current file name does not - match the right pattern, after changing settings, or - to execute autocommands for a certain event. - It's possible to use this inside an autocommand too, - so you can base the autocommands for one extension on - another extension. Example: > - :au Bufenter *.cpp so ~/.vimrc_cpp - :au Bufenter *.cpp doau BufEnter x.c -< Be careful to avoid endless loops. See - |autocmd-nested|. - - When the [group] argument is not given, Vim executes - the autocommands for all groups. When the [group] - argument is included, Vim executes only the matching - autocommands for that group. Note: if you use an - undefined group name, Vim gives you an error message. - - After applying the autocommands the modelines are - processed, so that their settings overrule the - settings from autocommands, like what happens when - editing a file. - - *:doautoa* *:doautoall* -:doautoa[ll] [group] {event} [fname] - Like ":doautocmd", but apply the autocommands to each - loaded buffer. Note that {fname} is used to select - the autocommands, not the buffers to which they are - applied. - Careful: Don't use this for autocommands that delete a - buffer, change to another buffer or change the - contents of a buffer; the result is unpredictable. - This command is intended for autocommands that set - options, change highlighting, and things like that. - -============================================================================== -10. Using autocommands *autocmd-use* - -For WRITING FILES there are four possible sets of events. Vim uses only one -of these sets for a write command: - -BufWriteCmd BufWritePre BufWritePost writing the whole buffer - FilterWritePre FilterWritePost writing to filter temp file -FileAppendCmd FileAppendPre FileAppendPost appending to a file -FileWriteCmd FileWritePre FileWritePost any other file write - -When there is a matching "*Cmd" autocommand, it is assumed it will do the -writing. No further writing is done and the other events are not triggered. -|Cmd-event| - -Note that the *WritePost commands should undo any changes to the buffer that -were caused by the *WritePre commands; otherwise, writing the file will have -the side effect of changing the buffer. - -Before executing the autocommands, the buffer from which the lines are to be -written temporarily becomes the current buffer. Unless the autocommands -change the current buffer or delete the previously current buffer, the -previously current buffer is made the current buffer again. - -The *WritePre and *AppendPre autocommands must not delete the buffer from -which the lines are to be written. - -The '[ and '] marks have a special position: -- Before the *ReadPre event the '[ mark is set to the line just above where - the new lines will be inserted. -- Before the *ReadPost event the '[ mark is set to the first line that was - just read, the '] mark to the last line. -- Before executing the *WriteCmd, *WritePre and *AppendPre autocommands the '[ - mark is set to the first line that will be written, the '] mark to the last - line. -Careful: '[ and '] change when using commands that change the buffer. - -In commands which expect a file name, you can use "" for the file name -that is being read |:| (you can also use "%" for the current file -name). "" can be used for the buffer number of the currently effective -buffer. This also works for buffers that doesn't have a name. But it doesn't -work for files without a buffer (e.g., with ":r file"). - - *gzip-example* -Examples for reading and writing compressed files: > - :augroup gzip - : autocmd! - : autocmd BufReadPre,FileReadPre *.gz set bin - : autocmd BufReadPost,FileReadPost *.gz '[,']!gunzip - : autocmd BufReadPost,FileReadPost *.gz set nobin - : autocmd BufReadPost,FileReadPost *.gz execute ":doautocmd BufReadPost " . expand("%:r") - : autocmd BufWritePost,FileWritePost *.gz !mv :r - : autocmd BufWritePost,FileWritePost *.gz !gzip :r - - : autocmd FileAppendPre *.gz !gunzip - : autocmd FileAppendPre *.gz !mv :r - : autocmd FileAppendPost *.gz !mv :r - : autocmd FileAppendPost *.gz !gzip :r - :augroup END - -The "gzip" group is used to be able to delete any existing autocommands with -":autocmd!", for when the file is sourced twice. - -(":r" is the file name without the extension, see |:_%:|) - -The commands executed for the BufNewFile, BufRead/BufReadPost, BufWritePost, -FileAppendPost and VimLeave events do not set or reset the changed flag of the -buffer. When you decompress the buffer with the BufReadPost autocommands, you -can still exit with ":q". When you use ":undo" in BufWritePost to undo the -changes made by BufWritePre commands, you can still do ":q" (this also makes -"ZZ" work). If you do want the buffer to be marked as modified, set the -'modified' option. - -To execute Normal mode commands from an autocommand, use the ":normal" -command. Use with care! If the Normal mode command is not finished, the user -needs to type characters (e.g., after ":normal m" you need to type a mark -name). - -If you want the buffer to be unmodified after changing it, reset the -'modified' option. This makes it possible to exit the buffer with ":q" -instead of ":q!". - - *autocmd-nested* *E218* -By default, autocommands do not nest. If you use ":e" or ":w" in an -autocommand, Vim does not execute the BufRead and BufWrite autocommands for -those commands. If you do want this, use the "nested" flag for those commands -in which you want nesting. For example: > - :autocmd FileChangedShell *.c nested e! -The nesting is limited to 10 levels to get out of recursive loops. - -It's possible to use the ":au" command in an autocommand. This can be a -self-modifying command! This can be useful for an autocommand that should -execute only once. - -If you want to skip autocommands for one command, use the |:noautocmd| command -modifier or the 'eventignore' option. - -Note: When reading a file (with ":read file" or with a filter command) and the -last line in the file does not have an , Vim remembers this. At the next -write (with ":write file" or with a filter command), if the same line is -written again as the last line in a file AND 'binary' is set, Vim does not -supply an . This makes a filter command on the just read lines write the -same file as was read, and makes a write command on just filtered lines write -the same file as was read from the filter. For example, another way to write -a compressed file: > - - :autocmd FileWritePre *.gz set bin|'[,']!gzip - :autocmd FileWritePost *.gz undo|set nobin -< - *autocommand-pattern* -You can specify multiple patterns, separated by commas. Here are some -examples: > - - :autocmd BufRead * set tw=79 nocin ic infercase fo=2croq - :autocmd BufRead .letter set tw=72 fo=2tcrq - :autocmd BufEnter .letter set dict=/usr/lib/dict/words - :autocmd BufLeave .letter set dict= - :autocmd BufRead,BufNewFile *.c,*.h set tw=0 cin noic - :autocmd BufEnter *.c,*.h abbr FOR for (i = 0; i < 3; ++i){}O - :autocmd BufLeave *.c,*.h unabbr FOR - -For makefiles (makefile, Makefile, imakefile, makefile.unix, etc.): > - - :autocmd BufEnter ?akefile* set include=^s\=include - :autocmd BufLeave ?akefile* set include& - -To always start editing C files at the first function: > - - :autocmd BufRead *.c,*.h 1;/^{ - -Without the "1;" above, the search would start from wherever the file was -entered, rather than from the start of the file. - - *skeleton* *template* -To read a skeleton (template) file when opening a new file: > - - :autocmd BufNewFile *.c 0r ~/vim/skeleton.c - :autocmd BufNewFile *.h 0r ~/vim/skeleton.h - :autocmd BufNewFile *.java 0r ~/vim/skeleton.java - -To insert the current date and time in a *.html file when writing it: > - - :autocmd BufWritePre,FileWritePre *.html ks|call LastMod()|'s - :fun LastMod() - : if line("$") > 20 - : let l = 20 - : else - : let l = line("$") - : endif - : exe "1," . l . "g/Last modified: /s/Last modified: .*/Last modified: " . - : \ strftime("%Y %b %d") - :endfun - -You need to have a line "Last modified: " in the first 20 lines -of the file for this to work. Vim replaces (and anything in the -same line after it) with the current date and time. Explanation: - ks mark current position with mark 's' - call LastMod() call the LastMod() function to do the work - 's return the cursor to the old position -The LastMod() function checks if the file is shorter than 20 lines, and then -uses the ":g" command to find lines that contain "Last modified: ". For those -lines the ":s" command is executed to replace the existing date with the -current one. The ":execute" command is used to be able to use an expression -for the ":g" and ":s" commands. The date is obtained with the strftime() -function. You can change its argument to get another date string. - -When entering :autocmd on the command-line, completion of events and command -names may be done (with , CTRL-D, etc.) where appropriate. - -Vim executes all matching autocommands in the order that you specify them. -It is recommended that your first autocommand be used for all files by using -"*" as the file pattern. This means that you can define defaults you like -here for any settings, and if there is another matching autocommand it will -override these. But if there is no other matching autocommand, then at least -your default settings are recovered (if entering this file from another for -which autocommands did match). Note that "*" will also match files starting -with ".", unlike Unix shells. - - *autocmd-searchpat* -Autocommands do not change the current search patterns. Vim saves the current -search patterns before executing autocommands then restores them after the -autocommands finish. This means that autocommands do not affect the strings -highlighted with the 'hlsearch' option. Within autocommands, you can still -use search patterns normally, e.g., with the "n" command. -If you want an autocommand to set the search pattern, such that it is used -after the autocommand finishes, use the ":let @/ =" command. -The search-highlighting cannot be switched off with ":nohlsearch" in an -autocommand. Use the 'h' flag in the 'viminfo' option to disable search- -highlighting when starting Vim. - - *Cmd-event* -When using one of the "*Cmd" events, the matching autocommands are expected to -do the file reading, writing or sourcing. This can be used when working with -a special kind of file, for example on a remote system. -CAREFUL: If you use these events in a wrong way, it may have the effect of -making it impossible to read or write the matching files! Make sure you test -your autocommands properly. Best is to use a pattern that will never match a -normal file name, for example "ftp://*". - -When defining a BufReadCmd it will be difficult for Vim to recover a crashed -editing session. When recovering from the original file, Vim reads only those -parts of a file that are not found in the swap file. Since that is not -possible with a BufReadCmd, use the |:preserve| command to make sure the -original file isn't needed for recovery. You might want to do this only when -you expect the file to be modified. - -For file read and write commands the |v:cmdarg| variable holds the "++enc=" -and "++ff=" argument that are effective. These should be used for the command -that reads/writes the file. The |v:cmdbang| variable is one when "!" was -used, zero otherwise. - -See the $VIMRUNTIME/plugin/netrw.vim for examples. - -============================================================================== -11. Disabling autocommands *autocmd-disable* - -To disable autocommands for some time use the 'eventignore' option. Note that -this may cause unexpected behavior, make sure you restore 'eventignore' -afterwards, using a |:try| block with |:finally|. - - *:noautocmd* *:noa* -To disable autocommands for just one command use the ":noautocmd" command -modifier. This will set 'eventignore' to "all" for the duration of the -following command. Example: > - - :noautocmd w fname.gz - -This will write the file without triggering the autocommands defined by the -gzip plugin. - - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/change.txt b/share/vim/vim72/doc/change.txt deleted file mode 100644 index 440e6b5456..0000000000 --- a/share/vim/vim72/doc/change.txt +++ /dev/null @@ -1,1625 +0,0 @@ -*change.txt* For Vim version 7.2. Last change: 2008 Jul 24 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -This file describes commands that delete or change text. In this context, -changing text means deleting the text and replacing it with other text using -one command. You can undo all of these commands. You can repeat the non-Ex -commands with the "." command. - -1. Deleting text |deleting| -2. Delete and insert |delete-insert| -3. Simple changes |simple-change| *changing* -4. Complex changes |complex-change| - 4.1 Filter commands |filter| - 4.2 Substitute |:substitute| - 4.3 Search and replace |search-replace| - 4.4 Changing tabs |change-tabs| -5. Copying and moving text |copy-move| -6. Formatting text |formatting| -7. Sorting text |sorting| - -For inserting text see |insert.txt|. - -============================================================================== -1. Deleting text *deleting* *E470* - -["x] or ** *x* *dl* -["x]x Delete [count] characters under and after the cursor - [into register x] (not |linewise|). Does the same as - "dl". - The key does not take a [count]. Instead, it - deletes the last character of the count. - See |:fixdel| if the key does not do what you - want. See |'whichwrap'| for deleting a line break - (join lines). {Vi does not support } - - *X* *dh* -["x]X Delete [count] characters before the cursor [into - register x] (not |linewise|). Does the same as "dh". - Also see |'whichwrap'|. - - *d* -["x]d{motion} Delete text that {motion} moves over [into register - x]. See below for exceptions. - - *dd* -["x]dd Delete [count] lines [into register x] |linewise|. - - *D* -["x]D Delete the characters under the cursor until the end - of the line and [count]-1 more lines [into register - x]; synonym for "d$". - (not |linewise|) - When the '#' flag is in 'cpoptions' the count is - ignored. - -{Visual}["x]x or *v_x* *v_d* *v_* -{Visual}["x]d or -{Visual}["x] Delete the highlighted text [into register x] (for - {Visual} see |Visual-mode|). {not in Vi} - -{Visual}["x]CTRL-H or *v_CTRL-H* *v_* -{Visual}["x] When in Select mode: Delete the highlighted text [into - register x]. - -{Visual}["x]X or *v_X* *v_D* *v_b_D* -{Visual}["x]D Delete the highlighted lines [into register x] (for - {Visual} see |Visual-mode|). In Visual block mode, - "D" deletes the highlighted text plus all text until - the end of the line. {not in Vi} - - *:d* *:de* *:del* *:delete* -:[range]d[elete] [x] Delete [range] lines (default: current line) [into - register x]. - -:[range]d[elete] [x] {count} - Delete {count} lines, starting with [range] - (default: current line |cmdline-ranges|) [into - register x]. - -These commands delete text. You can repeat them with the "." command -(except ":d") and undo them. Use Visual mode to delete blocks of text. See -|registers| for an explanation of registers. - -An exception for the d{motion} command: If the motion is not linewise, the -start and end of the motion are not in the same line, and there are only -blanks before the start and after the end of the motion, the delete becomes -linewise. This means that the delete also removes the line of blanks that you -might expect to remain. - -Trying to delete an empty region of text (e.g., "d0" in the first column) -is an error when 'cpoptions' includes the 'E' flag. - - *J* -J Join [count] lines, with a minimum of two lines. - Remove the indent and insert up to two spaces (see - below). - - *v_J* -{Visual}J Join the highlighted lines, with a minimum of two - lines. Remove the indent and insert up to two spaces - (see below). {not in Vi} - - *gJ* -gJ Join [count] lines, with a minimum of two lines. - Don't insert or remove any spaces. {not in Vi} - - *v_gJ* -{Visual}gJ Join the highlighted lines, with a minimum of two - lines. Don't insert or remove any spaces. {not in - Vi} - - *:j* *:join* -:[range]j[oin][!] [flags] - Join [range] lines. Same as "J", except with [!] - the join does not insert or delete any spaces. - If a [range] has equal start and end values, this - command does nothing. The default behavior is to - join the current line with the line below it. - {not in Vi: !} - See |ex-flags| for [flags]. - -:[range]j[oin][!] {count} [flags] - Join {count} lines, starting with [range] (default: - current line |cmdline-ranges|). Same as "J", except - with [!] the join does not insert or delete any - spaces. - {not in Vi: !} - See |ex-flags| for [flags]. - -These commands delete the between lines. This has the effect of joining -multiple lines into one line. You can repeat these commands (except ":j") and -undo them. - -These commands, except "gJ", insert one space in place of the unless -there is trailing white space or the next line starts with a ')'. These -commands, except "gJ", delete any leading white space on the next line. If -the 'joinspaces' option is on, these commands insert two spaces after a '.', -'!' or '?' (but if 'cpoptions' includes the 'j' flag, they insert two spaces -only after a '.'). -The 'B' and 'M' flags in 'formatoptions' change the behavior for inserting -spaces before and after a multi-byte character |fo-table|. - - -============================================================================== -2. Delete and insert *delete-insert* *replacing* - - *R* -R Enter Replace mode: Each character you type replaces - an existing character, starting with the character - under the cursor. Repeat the entered text [count]-1 - times. See |Replace-mode| for more details. - - *gR* -gR Enter Virtual Replace mode: Each character you type - replaces existing characters in screen space. So a - may replace several characters at once. - Repeat the entered text [count]-1 times. See - |Virtual-Replace-mode| for more details. - {not available when compiled without the +vreplace - feature} - - *c* -["x]c{motion} Delete {motion} text [into register x] and start - insert. When 'cpoptions' includes the 'E' flag and - there is no text to delete (e.g., with "cTx" when the - cursor is just after an 'x'), an error occurs and - insert mode does not start (this is Vi compatible). - When 'cpoptions' does not include the 'E' flag, the - "c" command always starts insert mode, even if there - is no text to delete. - - *cc* -["x]cc Delete [count] lines [into register x] and start - insert |linewise|. If 'autoindent' is on, preserve - the indent of the first line. - - *C* -["x]C Delete from the cursor position to the end of the - line and [count]-1 more lines [into register x], and - start insert. Synonym for c$ (not |linewise|). - - *s* -["x]s Delete [count] characters [into register x] and start - insert (s stands for Substitute). Synonym for "cl" - (not |linewise|). - - *S* -["x]S Delete [count] lines [into register x] and start - insert. Synonym for "cc" |linewise|. - -{Visual}["x]c or *v_c* *v_s* -{Visual}["x]s Delete the highlighted text [into register x] and - start insert (for {Visual} see |Visual-mode|). {not - in Vi} - - *v_r* -{Visual}["x]r{char} Replace all selected characters by {char}. - - *v_C* -{Visual}["x]C Delete the highlighted lines [into register x] and - start insert. In Visual block mode it works - differently |v_b_C|. {not in Vi} - *v_S* -{Visual}["x]S Delete the highlighted lines [into register x] and - start insert (for {Visual} see |Visual-mode|). {not - in Vi} - *v_R* -{Visual}["x]R Currently just like {Visual}["x]S. In a next version - it might work differently. {not in Vi} - -Notes: -- You can end Insert and Replace mode with . -- See the section "Insert and Replace mode" |mode-ins-repl| for the other - special characters in these modes. -- The effect of [count] takes place after Vim exits Insert or Replace mode. -- When the 'cpoptions' option contains '$' and the change is within one line, - Vim continues to show the text to be deleted and puts a '$' at the last - deleted character. - -See |registers| for an explanation of registers. - -Replace mode is just like Insert mode, except that every character you enter -deletes one character. If you reach the end of a line, Vim appends any -further characters (just like Insert mode). In Replace mode, the backspace -key restores the original text (if there was any). (See section "Insert and -Replace mode" |mode-ins-repl|). - - *cw* *cW* -Special case: When the cursor is in a word, "cw" and "cW" do not include the -white space after a word, they only change up to the end of the word. This is -because Vim interprets "cw" as change-word, and a word does not include the -following white space. -{Vi: "cw" when on a blank followed by other blanks changes only the first -blank; this is probably a bug, because "dw" deletes all the blanks; use the -'w' flag in 'cpoptions' to make it work like Vi anyway} - -If you prefer "cw" to include the space after a word, use this mapping: > - :map cw dwi -Or use "caw" (see |aw|). - - *:c* *:ch* *:change* -:{range}c[hange][!] Replace lines of text with some different text. - Type a line containing only "." to stop replacing. - Without {range}, this command changes only the current - line. - Adding [!] toggles 'autoindent' for the time this - command is executed. - -============================================================================== -3. Simple changes *simple-change* - - *r* -r{char} Replace the character under the cursor with {char}. - If {char} is a or , a line break replaces the - character. To replace with a real , use CTRL-V - . CTRL-V replaces with a . - {Vi: CTRL-V still replaces with a line break, - cannot replace something with a } - If you give a [count], Vim replaces [count] characters - with [count] {char}s. When {char} is a or , - however, Vim inserts only one : "5r" replaces - five characters with a single line break. - When {char} is a or , Vim performs - autoindenting. This works just like deleting the - characters that are replaced and then doing - "i". - {char} can be entered as a digraph |digraph-arg|. - |:lmap| mappings apply to {char}. The CTRL-^ command - in Insert mode can be used to switch this on/off - |i_CTRL-^|. See |utf-8-char-arg| about using - composing characters when 'encoding' is Unicode. - - *gr* -gr{char} Replace the virtual characters under the cursor with - {char}. This replaces in screen space, not file - space. See |gR| and |Virtual-Replace-mode| for more - details. As with |r| a count may be given. - {char} can be entered like with |r|. - {not available when compiled without the +vreplace - feature} - - *digraph-arg* -The argument for Normal mode commands like |r| and |t| is a single character. -When 'cpo' doesn't contain the 'D' flag, this character can also be entered -like |digraphs|. First type CTRL-K and then the two digraph characters. -{not available when compiled without the |+digraphs| feature} - - *case* -The following commands change the case of letters. The currently active -|locale| is used. See |:language|. The LC_CTYPE value matters here. - - *~* -~ 'notildeop' option: Switch case of the character - under the cursor and move the cursor to the right. - If a [count] is given, do that many characters. {Vi: - no count} - -~{motion} 'tildeop' option: switch case of {motion} text. {Vi: - tilde cannot be used as an operator} - - *g~* -g~{motion} Switch case of {motion} text. {not in Vi} - -g~g~ *g~g~* *g~~* -g~~ Switch case of current line. {not in Vi}. - - *v_~* -{Visual}~ Switch case of highlighted text (for {Visual} see - |Visual-mode|). {not in Vi} - - *v_U* -{Visual}U Make highlighted text uppercase (for {Visual} see - |Visual-mode|). {not in Vi} - - *gU* *uppercase* -gU{motion} Make {motion} text uppercase. {not in Vi} - Example: > - :map! gUiw`]a -< This works in Insert mode: press CTRL-F to make the - word before the cursor uppercase. Handy to type - words in lowercase and then make them uppercase. - - -gUgU *gUgU* *gUU* -gUU Make current line uppercase. {not in Vi}. - - *v_u* -{Visual}u Make highlighted text lowercase (for {Visual} see - |Visual-mode|). {not in Vi} - - *gu* *lowercase* -gu{motion} Make {motion} text lowercase. {not in Vi} - -gugu *gugu* *guu* -guu Make current line lowercase. {not in Vi}. - - *g?* *rot13* -g?{motion} Rot13 encode {motion} text. {not in Vi} - - *v_g?* -{Visual}g? Rot13 encode the highlighted text (for {Visual} see - |Visual-mode|). {not in Vi} - -g?g? *g?g?* *g??* -g?? Rot13 encode current line. {not in Vi}. - -To turn one line into title caps, make every first letter of a word -uppercase: > - :s/\v<(.)(\w*)/\u\1\L\2/g - - -Adding and subtracting ~ - *CTRL-A* -CTRL-A Add [count] to the number or alphabetic character at - or after the cursor. {not in Vi} - - *CTRL-X* -CTRL-X Subtract [count] from the number or alphabetic - character at or after the cursor. {not in Vi} - -The CTRL-A and CTRL-X commands work for (signed) decimal numbers, unsigned -octal and hexadecimal numbers and alphabetic characters. This depends on the -'nrformats' option. -- When 'nrformats' includes "octal", Vim considers numbers starting with a '0' - to be octal, unless the number includes a '8' or '9'. Other numbers are - decimal and may have a preceding minus sign. - If the cursor is on a number, the commands apply to that number; otherwise - Vim uses the number to the right of the cursor. -- When 'nrformats' includes "hex", Vim assumes numbers starting with '0x' or - '0X' are hexadecimal. The case of the rightmost letter in the number - determines the case of the resulting hexadecimal number. If there is no - letter in the current number, Vim uses the previously detected case. -- When 'nrformats' includes "alpha", Vim will change the alphabetic character - under or after the cursor. This is useful to make lists with an alphabetic - index. - -For numbers with leading zeros (including all octal and hexadecimal numbers), -Vim preserves the number of characters in the number when possible. CTRL-A on -"0077" results in "0100", CTRL-X on "0x100" results in "0x0ff". -There is one exception: When a number that starts with a zero is found not to -be octal (it contains a '8' or '9'), but 'nrformats' does include "octal", -leading zeros are removed to avoid that the result may be recognized as an -octal number. - -Note that when 'nrformats' includes "octal", decimal numbers with leading -zeros cause mistakes, because they can be confused with octal numbers. - -The CTRL-A command is very useful in a macro. Example: Use the following -steps to make a numbered list. - -1. Create the first list entry, make sure it starts with a number. -2. qa - start recording into register 'a' -3. Y - yank the entry -4. p - put a copy of the entry below the first one -5. CTRL-A - increment the number -6. q - stop recording -7. @a - repeat the yank, put and increment times - - -SHIFTING LINES LEFT OR RIGHT *shift-left-right* - - *<* -<{motion} Shift {motion} lines one 'shiftwidth' leftwards. - - *<<* -<< Shift [count] lines one 'shiftwidth' leftwards. - - *v_<* -{Visual}[count]< Shift the highlighted lines [count] 'shiftwidth' - leftwards (for {Visual} see |Visual-mode|). {not in - Vi} - - *>* - >{motion} Shift {motion} lines one 'shiftwidth' rightwards. - - *>>* - >> Shift [count] lines one 'shiftwidth' rightwards. - - *v_>* -{Visual}[count]> Shift the highlighted lines [count] 'shiftwidth' - rightwards (for {Visual} see |Visual-mode|). {not in - Vi} - - *:<* -:[range]< Shift [range] lines one 'shiftwidth' left. Repeat '<' - for shifting multiple 'shiftwidth's. - -:[range]< {count} Shift {count} lines one 'shiftwidth' left, starting - with [range] (default current line |cmdline-ranges|). - Repeat '<' for shifting multiple 'shiftwidth's. - -:[range]le[ft] [indent] left align lines in [range]. Sets the indent in the - lines to [indent] (default 0). {not in Vi} - - *:>* -:[range]> [flags] Shift {count} [range] lines one 'shiftwidth' right. - Repeat '>' for shifting multiple 'shiftwidth's. - See |ex-flags| for [flags]. - -:[range]> {count} [flags] - Shift {count} lines one 'shiftwidth' right, starting - with [range] (default current line |cmdline-ranges|). - Repeat '>' for shifting multiple 'shiftwidth's. - See |ex-flags| for [flags]. - -The ">" and "<" commands are handy for changing the indentation within -programs. Use the 'shiftwidth' option to set the size of the white space -which these commands insert or delete. Normally the 'shiftwidth' option is 8, -but you can set it to, say, 3 to make smaller indents. The shift leftwards -stops when there is no indent. The shift right does not affect empty lines. - -If the 'shiftround' option is on, the indent is rounded to a multiple of -'shiftwidth'. - -If the 'smartindent' option is on, or 'cindent' is on and 'cinkeys' contains -'#', shift right does not affect lines starting with '#' (these are supposed -to be C preprocessor lines that must stay in column 1). - -When the 'expandtab' option is off (this is the default) Vim uses s as -much as possible to make the indent. You can use ">><<" to replace an indent -made out of spaces with the same indent made out of s (and a few spaces -if necessary). If the 'expandtab' option is on, Vim uses only spaces. Then -you can use ">><<" to replace s in the indent by spaces (or use -":retab!"). - -To move a line several 'shiftwidth's, use Visual mode or the ":" commands. -For example: > - Vjj4> move three lines 4 indents to the right - :<<< move current line 3 indents to the left - :>> 5 move 5 lines 2 indents to the right - :5>> move line 5 2 indents to the right - -============================================================================== -4. Complex changes *complex-change* - -4.1 Filter commands *filter* - -A filter is a program that accepts text at standard input, changes it in some -way, and sends it to standard output. You can use the commands below to send -some text through a filter, so that it is replaced by the filter output. -Examples of filters are "sort", which sorts lines alphabetically, and -"indent", which formats C program files (you need a version of indent that -works like a filter; not all versions do). The 'shell' option specifies the -shell Vim uses to execute the filter command (See also the 'shelltype' -option). You can repeat filter commands with ".". Vim does not recognize a -comment (starting with '"') after the ":!" command. - - *!* -!{motion}{filter} Filter {motion} text lines through the external - program {filter}. - - *!!* -!!{filter} Filter [count] lines through the external program - {filter}. - - *v_!* -{Visual}!{filter} Filter the highlighted lines through the external - program {filter} (for {Visual} see |Visual-mode|). - {not in Vi} - -:{range}![!]{filter} [!][arg] *:range!* - Filter {range} lines through the external program - {filter}. Vim replaces the optional bangs with the - latest given command and appends the optional [arg]. - Vim saves the output of the filter command in a - temporary file and then reads the file into the - buffer. Vim uses the 'shellredir' option to redirect - the filter output to the temporary file. - However, if the 'shelltemp' option is off then pipes - are used when possible (on Unix). - When the 'R' flag is included in 'cpoptions' marks in - the filtered lines are deleted, unless the - |:keepmarks| command is used. Example: > - :keepmarks '<,'>!sort -< When the number of lines after filtering is less than - before, marks in the missing lines are deleted anyway. - - *=* -={motion} Filter {motion} lines through the external program - given with the 'equalprg' option. When the 'equalprg' - option is empty (this is the default), use the - internal formatting function |C-indenting|. But when - 'indentexpr' is not empty, it will be used instead - |indent-expression|. - - *==* -== Filter [count] lines like with ={motion}. - - *v_=* -{Visual}= Filter the highlighted lines like with ={motion}. - {not in Vi} - - -4.2 Substitute *:substitute* - *:s* *:su* -:[range]s[ubstitute]/{pattern}/{string}/[flags] [count] - For each line in [range] replace a match of {pattern} - with {string}. - For the {pattern} see |pattern|. - {string} can be a literal string, or something - special; see |sub-replace-special|. - When [range] and [count] are omitted, replace in the - current line only. - When [count] is given, replace in [count] lines, - starting with the last line in [range]. When [range] - is omitted start in the current line. - Also see |cmdline-ranges|. - See |:s_flags| for [flags]. - -:[range]s[ubstitute] [flags] [count] -:[range]&[&][flags] [count] *:&* - Repeat last :substitute with same search pattern and - substitute string, but without the same flags. You - may add [flags], see |:s_flags|. - Note that after ":substitute" the '&' flag can't be - used, it's recognized as a pattern separator. - The space between ":substitute" and the 'c', 'g' and - 'r' flags isn't required, but in scripts it's a good - idea to keep it to avoid confusion. - -:[range]~[&][flags] [count] *:~* - Repeat last substitute with same substitute string - but with last used search pattern. This is like - ":&r". See |:s_flags| for [flags]. - - *&* -& Synonym for ":s//~/" (repeat last substitute). Note - that the flags are not remembered, thus it might - actually work differently. You can use ":&&" to keep - the flags. - - *g&* -g& Synonym for ":%s//~/&" (repeat last substitute on all - lines with the same flags). - Mnemonic: global substitute. {not in Vi} - - *:snomagic* *:sno* -:[range]sno[magic] ... Same as ":substitute", but always use 'nomagic'. - {not in Vi} - - *:smagic* *:sm* -:[range]sm[agic] ... Same as ":substitute", but always use 'magic'. - {not in Vi} - - *:s_flags* -The flags that you can use for the substitute commands: - -[&] Must be the first one: Keep the flags from the previous substitute - command. Examples: > - :&& - :s/this/that/& -< Note that ":s" and ":&" don't keep the flags. - {not in Vi} - -[c] Confirm each substitution. Vim highlights the matching string (with - |hl-IncSearch|). You can type: *:s_c* - 'y' to substitute this match - 'l' to substitute this match and then quit ("last") - 'n' to skip this match - to quit substituting - 'a' to substitute this and all remaining matches {not in Vi} - 'q' to quit substituting {not in Vi} - CTRL-E to scroll the screen up {not in Vi, not available when - compiled without the +insert_expand feature} - CTRL-Y to scroll the screen down {not in Vi, not available when - compiled without the +insert_expand feature} - If the 'edcompatible' option is on, Vim remembers the [c] flag and - toggles it each time you use it, but resets it when you give a new - search pattern. - {not in Vi: highlighting of the match, other responses than 'y' or 'n'} - -[e] When the search pattern fails, do not issue an error message and, in - particular, continue in maps as if no error occurred. This is most - useful to prevent the "No match" error from breaking a mapping. Vim - does not suppress the following error messages, however: - Regular expressions can't be delimited by letters - \ should be followed by /, ? or & - No previous substitute regular expression - Trailing characters - Interrupted - {not in Vi} - -[g] Replace all occurrences in the line. Without this argument, - replacement occurs only for the first occurrence in each line. If - the 'edcompatible' option is on, Vim remembers this flag and toggles - it each time you use it, but resets it when you give a new search - pattern. If the 'gdefault' option is on, this flag is on by default - and the [g] argument switches it off. - -[i] Ignore case for the pattern. The 'ignorecase' and 'smartcase' options - are not used. - {not in Vi} - -[I] Don't ignore case for the pattern. The 'ignorecase' and 'smartcase' - options are not used. - {not in Vi} - -[n] Report the number of matches, do not actually substitute. The [c] - flag is ignored. The matches are reported as if 'report' is zero. - Useful to |count-items|. - -[p] Print the line containing the last substitute. - -[#] Like [p] and prepend the line number. - -[l] Like [p] but print the text like |:list|. - -[r] Only useful in combination with ":&" or ":s" without arguments. ":&r" - works the same way as ":~": When the search pattern is empty, use the - previously used search pattern instead of the search pattern from the - last substitute or ":global". If the last command that did a search - was a substitute or ":global", there is no effect. If the last - command was a search command such as "/", use the pattern from that - command. - For ":s" with an argument this already happens: > - :s/blue/red/ - /green - :s//red/ or :~ or :&r -< The last commands will replace "green" with "red". > - :s/blue/red/ - /green - :& -< The last command will replace "blue" with "red". - {not in Vi} - -Note that there is no flag to change the "magicness" of the pattern. A -different command is used instead, or you can use |/\v| and friends. The -reason is that the flags can only be found by skipping the pattern, and in -order to skip the pattern the "magicness" must be known. Catch 22! - -If the {pattern} for the substitute command is empty, the command uses the -pattern from the last substitute or ":global" command. With the [r] flag, the -command uses the pattern from the last substitute, ":global", or search -command. - -If the {string} is omitted the substitute is done as if it's empty. Thus the -matched pattern is deleted. The separator after {pattern} can also be left -out then. Example: > - :%s/TESTING -This deletes "TESTING" from all lines, but only one per line. - -For compatibility with Vi these two exceptions are allowed: -"\/{string}/" and "\?{string}?" do the same as "//{string}/r". -"\&{string}&" does the same as "//{string}/". - *E146* -Instead of the '/' which surrounds the pattern and replacement string, you -can use any other single-byte character, but not an alphanumeric character, -'\', '"' or '|'. This is useful if you want to include a '/' in the search -pattern or replacement string. Example: > - :s+/+//+ - -For the definition of a pattern, see |pattern|. In Visual block mode, use -|/\%V| in the pattern to have the substitute work in the block only. -Otherwise it works on whole lines anyway. - - *sub-replace-special* *:s\=* -When the {string} starts with "\=" it is evaluated as an expression, see -|sub-replace-expression|. You can use that for any special characters. -Otherwise these characters in {string} have a special meaning: - *:s%* -When {string} is equal to "%" and '/' is included with the 'cpoptions' option, -then the {string} of the previous substitute command is used. |cpo-/| - -magic nomagic action ~ - & \& replaced with the whole matched pattern *s/\&* - \& & replaced with & - \0 replaced with the whole matched pattern *\0* *s/\0* - \1 replaced with the matched pattern in the first - pair of () *s/\1* - \2 replaced with the matched pattern in the second - pair of () *s/\2* - .. .. *s/\3* - \9 replaced with the matched pattern in the ninth - pair of () *s/\9* - ~ \~ replaced with the {string} of the previous - substitute *s~* - \~ ~ replaced with ~ *s/\~* - \u next character made uppercase *s/\u* - \U following characters made uppercase, until \E *s/\U* - \l next character made lowercase *s/\l* - \L following characters made lowercase, until \E *s/\L* - \e end of \u, \U, \l and \L (NOTE: not !) *s/\e* - \E end of \u, \U, \l and \L *s/\E* - split line in two at this point - (Type the as CTRL-V ) *s* - \r idem *s/\r* - \ insert a carriage-return (CTRL-M) - (Type the as CTRL-V ) *s/\* - \n insert a ( in the file) - (does NOT break the line) *s/\n* - \b insert a *s/\b* - \t insert a *s/\t* - \\ insert a single backslash *s/\\* - \x where x is any character not mentioned above: - Reserved for future expansion - -Examples: > - :s/a\|b/xxx\0xxx/g modifies "a b" to "xxxaxxx xxxbxxx" - :s/\([abc]\)\([efg]\)/\2\1/g modifies "af fa bg" to "fa fa gb" - :s/abcde/abc^Mde/ modifies "abcde" to "abc", "de" (two lines) - :s/$/\^M/ modifies "abcde" to "abcde^M" - :s/\w\+/\u\0/g modifies "bla bla" to "Bla Bla" - -Note: In previous versions CTRL-V was handled in a special way. Since this is -not Vi compatible, this was removed. Use a backslash instead. - -command text result ~ -:s/aa/a^Ma/ aa aa -:s/aa/a\^Ma/ aa a^Ma -:s/aa/a\\^Ma/ aa a\a - -(you need to type CTRL-V to get a ^M here) - -The numbering of "\1", "\2" etc. is done based on which "\(" comes first in -the pattern (going left to right). When a parentheses group matches several -times, the last one will be used for "\1", "\2", etc. Example: > - :s/\(\(a[a-d] \)*\)/\2/ modifies "aa ab x" to "ab x" - -When using parentheses in combination with '|', like in \([ab]\)\|\([cd]\), -either the first or second pattern in parentheses did not match, so either -\1 or \2 is empty. Example: > - :s/\([ab]\)\|\([cd]\)/\1x/g modifies "a b c d" to "ax bx x x" -< - -Substitute with an expression *sub-replace-expression* - *sub-replace-\=* -When the substitute string starts with "\=" the remainder is interpreted as an -expression. This does not work recursively: a substitute() function inside -the expression cannot use "\=" for the substitute string. - -The special meaning for characters as mentioned at |sub-replace-special| does -not apply except for "", "\" and "\\". Thus in the result of the -expression you need to use two backslashes to get one, put a backslash before a - you want to insert, and use a without a backslash where you want to -break the line. - -For convenience a character is also used as a line break. Prepend a -backslash to get a real character (which will be a NUL in the file). - -When the result is a |List| then the items are joined with separating line -breaks. Thus each item becomes a line, except that they can contain line -breaks themselves. - -The whole matched text can be accessed with "submatch(0)". The text matched -with the first pair of () with "submatch(1)". Likewise for further -sub-matches in (). - -Be careful: The separation character must not appear in the expression! -Consider using a character like "@" or ":". There is no problem if the result -of the expression contains the separation character. - -Examples: > - :s@\n@\="\r" . expand("$HOME") . "\r"@ -This replaces an end-of-line with a new line containing the value of $HOME. > - - s/E/\="\"/g -This replaces each 'E' character with a euro sign. Read more in ||. - - -4.3 Search and replace *search-replace* - - *:pro* *:promptfind* -:promptf[ind] [string] - Put up a Search dialog. When [string] is given, it is - used as the initial search string. - {only for Win32, Motif and GTK GUI} - - *:promptr* *:promptrepl* -:promptr[epl] [string] - Put up a Search/Replace dialog. When [string] is - given, it is used as the initial search string. - {only for Win32, Motif and GTK GUI} - - -4.4 Changing tabs *change-tabs* - *:ret* *:retab* -:[range]ret[ab][!] [new_tabstop] - Replace all sequences of white-space containing a - with new strings of white-space using the new - tabstop value given. If you do not specify a new - tabstop size or it is zero, Vim uses the current value - of 'tabstop'. - The current value of 'tabstop' is always used to - compute the width of existing tabs. - With !, Vim also replaces strings of only normal - spaces with tabs where appropriate. - With 'expandtab' on, Vim replaces all tabs with the - appropriate number of spaces. - This command sets 'tabstop' to the new value given, - and if performed on the whole file, which is default, - should not make any visible change. - Careful: This command modifies any characters - inside of strings in a C program. Use "\t" to avoid - this (that's a good habit anyway). - ":retab!" may also change a sequence of spaces by - characters, which can mess up a printf(). - {not in Vi} - Not available when |+ex_extra| feature was disabled at - compile time. - - *retab-example* -Example for using autocommands and ":retab" to edit a file which is stored -with tabstops at 8 but edited with tabstops set at 4. Warning: white space -inside of strings can change! Also see 'softtabstop' option. > - - :auto BufReadPost *.xx retab! 4 - :auto BufWritePre *.xx retab! 8 - :auto BufWritePost *.xx retab! 4 - :auto BufNewFile *.xx set ts=4 - -============================================================================== -5. Copying and moving text *copy-move* - - *quote* -"{a-zA-Z0-9.%#:-"} Use register {a-zA-Z0-9.%#:-"} for next delete, yank - or put (use uppercase character to append with - delete and yank) ({.%#:} only work with put). - - *:reg* *:registers* -:reg[isters] Display the contents of all numbered and named - registers. {not in Vi} - -:reg[isters] {arg} Display the contents of the numbered and named - registers that are mentioned in {arg}. For example: > - :dis 1a -< to display registers '1' and 'a'. Spaces are allowed - in {arg}. {not in Vi} - - *:di* *:display* -:di[splay] [arg] Same as :registers. {not in Vi} - - *y* *yank* -["x]y{motion} Yank {motion} text [into register x]. When no - characters are to be yanked (e.g., "y0" in column 1), - this is an error when 'cpoptions' includes the 'E' - flag. - - *yy* -["x]yy Yank [count] lines [into register x] |linewise|. - - *Y* -["x]Y yank [count] lines [into register x] (synonym for - yy, |linewise|). If you like "Y" to work from the - cursor to the end of line (which is more logical, - but not Vi-compatible) use ":map Y y$". - - *v_y* -{Visual}["x]y Yank the highlighted text [into register x] (for - {Visual} see |Visual-mode|). {not in Vi} - - *v_Y* -{Visual}["x]Y Yank the highlighted lines [into register x] (for - {Visual} see |Visual-mode|). {not in Vi} - - *:y* *:yank* -:[range]y[ank] [x] Yank [range] lines [into register x]. - -:[range]y[ank] [x] {count} - Yank {count} lines, starting with last line number - in [range] (default: current line |cmdline-ranges|), - [into register x]. - - *p* *put* *E353* -["x]p Put the text [from register x] after the cursor - [count] times. {Vi: no count} - - *P* -["x]P Put the text [from register x] before the cursor - [count] times. {Vi: no count} - - ** -["x] Put the text from a register before the cursor [count] - times. Uses the "* register, unless another is - specified. - Leaves the cursor at the end of the new text. - Using the mouse only works when 'mouse' contains 'n' - or 'a'. - {not in Vi} - If you have a scrollwheel and often accidentally paste - text, you can use these mappings to disable the - pasting with the middle mouse button: > - :map - :imap -< You might want to disable the multi-click versions - too, see |double-click|. - - *gp* -["x]gp Just like "p", but leave the cursor just after the new - text. {not in Vi} - - *gP* -["x]gP Just like "P", but leave the cursor just after the new - text. {not in Vi} - - *:pu* *:put* -:[line]pu[t] [x] Put the text [from register x] after [line] (default - current line). This always works |linewise|, thus - this command can be used to put a yanked block as new - lines. - The cursor is left on the first non-blank in the last - new line. - The register can also be '=' followed by an optional - expression. The expression continues until the end of - the command. You need to escape the '|' and '"' - characters to prevent them from terminating the - command. Example: > - :put ='path' . \",/test\" -< If there is no expression after '=', Vim uses the - previous expression. You can see it with ":dis =". - -:[line]pu[t]! [x] Put the text [from register x] before [line] (default - current line). - -["x]]p or *]p* *]* -["x]] Like "p", but adjust the indent to the current line. - Using the mouse only works when 'mouse' contains 'n' - or 'a'. {not in Vi} - -["x][P or *[P* -["x]]P or *]P* -["x][p or *[p* *[* -["x][ Like "P", but adjust the indent to the current line. - Using the mouse only works when 'mouse' contains 'n' - or 'a'. {not in Vi} - -You can use these commands to copy text from one place to another. Do this -by first getting the text into a register with a yank, delete or change -command, then inserting the register contents with a put command. You can -also use these commands to move text from one file to another, because Vim -preserves all registers when changing buffers (the CTRL-^ command is a quick -way to toggle between two files). - - *linewise-register* *characterwise-register* -You can repeat the put commands with "." (except for :put) and undo them. If -the command that was used to get the text into the register was |linewise|, -Vim inserts the text below ("p") or above ("P") the line where the cursor is. -Otherwise Vim inserts the text after ("p") or before ("P") the cursor. With -the ":put" command, Vim always inserts the text in the next line. You can -exchange two characters with the command sequence "xp". You can exchange two -lines with the command sequence "ddp". You can exchange two words with the -command sequence "deep" (start with the cursor in the blank space before the -first word). You can use the "']" or "`]" command after the put command to -move the cursor to the end of the inserted text, or use "'[" or "`[" to move -the cursor to the start. - - *put-Visual-mode* *v_p* *v_P* -When using a put command like |p| or |P| in Visual mode, Vim will try to -replace the selected text with the contents of the register. Whether this -works well depends on the type of selection and the type of the text in the -register. With blockwise selection it also depends on the size of the block -and whether the corners are on an existing character. (Implementation detail: -it actually works by first putting the register after the selection and then -deleting the selection.) - - *blockwise-register* -If you use a blockwise Visual mode command to get the text into the register, -the block of text will be inserted before ("P") or after ("p") the cursor -column in the current and next lines. Vim makes the whole block of text start -in the same column. Thus the inserted text looks the same as when it was -yanked or deleted. Vim may replace some characters with spaces to make -this happen. However, if the width of the block is not a multiple of a -width and the text after the inserted block contains s, that text may be -misaligned. - -Note that after a characterwise yank command, Vim leaves the cursor on the -first yanked character that is closest to the start of the buffer. This means -that "yl" doesn't move the cursor, but "yh" moves the cursor one character -left. -Rationale: In Vi the "y" command followed by a backwards motion would - sometimes not move the cursor to the first yanked character, - because redisplaying was skipped. In Vim it always moves to - the first character, as specified by Posix. -With a linewise yank command the cursor is put in the first line, but the -column is unmodified, thus it may not be on the first yanked character. - -There are nine types of registers: *registers* *E354* -1. The unnamed register "" -2. 10 numbered registers "0 to "9 -3. The small delete register "- -4. 26 named registers "a to "z or "A to "Z -5. four read-only registers ":, "., "% and "# -6. the expression register "= -7. The selection and drop registers "*, "+ and "~ -8. The black hole register "_ -9. Last search pattern register "/ - -1. Unnamed register "" *quote_quote* *quotequote* -Vim fills this register with text deleted with the "d", "c", "s", "x" commands -or copied with the yank "y" command, regardless of whether or not a specific -register was used (e.g. "xdd). This is like the unnamed register is pointing -to the last used register. An exception is the '_' register: "_dd does not -store the deleted text in any register. -Vim uses the contents of the unnamed register for any put command (p or P) -which does not specify a register. Additionally you can access it with the -name '"'. This means you have to type two double quotes. Writing to the "" -register writes to register "0. -{Vi: register contents are lost when changing files, no '"'} - -2. Numbered registers "0 to "9 *quote_number* *quote0* *quote1* - *quote2* *quote3* *quote4* *quote9* -Vim fills these registers with text from yank and delete commands. - Numbered register 0 contains the text from the most recent yank command, -unless the command specified another register with ["x]. - Numbered register 1 contains the text deleted by the most recent delete or -change command, unless the command specified another register or the text is -less than one line (the small delete register is used then). An exception is -made for the delete operator with these movement commands: |%|, |(|, |)|, |`|, -|/|, |?|, |n|, |N|, |{| and |}|. Register "1 is always used then (this is Vi -compatible). The "- register is used as well if the delete is within a line. - With each successive deletion or change, Vim shifts the previous contents -of register 1 into register 2, 2 into 3, and so forth, losing the previous -contents of register 9. -{Vi: numbered register contents are lost when changing files; register 0 does -not exist} - -3. Small delete register "- *quote_-* *quote-* -This register contains text from commands that delete less than one line, -except when the command specifies a register with ["x]. -{not in Vi} - -4. Named registers "a to "z or "A to "Z *quote_alpha* *quotea* -Vim fills these registers only when you say so. Specify them as lowercase -letters to replace their previous contents or as uppercase letters to append -to their previous contents. When the '>' flag is present in 'cpoptions' then -a line break is inserted before the appended text. - -5. Read-only registers ":, "., "% and "# -These are '%', '#', ':' and '.'. You can use them only with the "p", "P", -and ":put" commands and with CTRL-R. {not in Vi} - *quote_.* *quote.* *E29* - ". Contains the last inserted text (the same as what is inserted - with the insert mode commands CTRL-A and CTRL-@). Note: this - doesn't work with CTRL-R on the command-line. It works a bit - differently, like inserting the text instead of putting it - ('textwidth' and other options affect what is inserted). - *quote_%* *quote%* - "% Contains the name of the current file. - *quote_#* *quote#* - "# Contains the name of the alternate file. - *quote_:* *quote:* *E30* - ": Contains the most recent executed command-line. Example: Use - "@:" to repeat the previous command-line command. - The command-line is only stored in this register when at least - one character of it was typed. Thus it remains unchanged if - the command was completely from a mapping. - {not available when compiled without the |+cmdline_hist| - feature} - -6. Expression register "= *quote_=* *quote=* *@=* -This is not really a register that stores text, but is a way to use an -expression in commands which use a register. The expression register is -read-only; you cannot put text into it. After the '=', the cursor moves to -the command-line, where you can enter any expression (see |expression|). All -normal command-line editing commands are available, including a special -history for expressions. When you end the command-line by typing , Vim -computes the result of the expression. If you end it with , Vim abandons -the expression. If you do not enter an expression, Vim uses the previous -expression (like with the "/" command). The expression must evaluate to a -string. If the result is a number it's turned into a string. A List, -Dictionary or FuncRef results in an error message (use string() to convert). -If the "= register is used for the "p" command, the string is split up at -characters. If the string ends in a , it is regarded as a linewise -register. {not in Vi} - -7. Selection and drop registers "*, "+ and "~ -Use these register for storing and retrieving the selected text for the GUI. -See |quotestar| and |quoteplus|. When the clipboard is not available or not -working, the unnamed register is used instead. For Unix systems the clipboard -is only available when the |+xterm_clipboard| feature is present. {not in Vi} - -Note that there is only a distinction between "* and "+ for X11 systems. For -an explanation of the difference, see |x11-selection|. Under MS-Windows, use -of "* and "+ is actually synonymous and refers to the |gui-clipboard|. - - *quote_~* *quote~* ** -The read-only "~ register stores the dropped text from the last drag'n'drop -operation. When something has been dropped onto Vim, the "~ register is -filled in and the pseudo key is sent for notification. You can remap -this key if you want; the default action (for all modes) is to insert the -contents of the "~ register at the cursor position. {not in Vi} -{only available when compiled with the |+dnd| feature, currently only with the -GTK GUI} - -Note: The "~ register is only used when dropping plain text onto Vim. -Drag'n'drop of URI lists is handled internally. - -8. Black hole register "_ *quote_* -When writing to this register, nothing happens. This can be used to delete -text without affecting the normal registers. When reading from this register, -nothing is returned. {not in Vi} - -9. Last search pattern register "/ *quote_/* *quote/* -Contains the most recent search-pattern. This is used for "n" and 'hlsearch'. -It is writable with ":let", you can change it to have 'hlsearch' highlight -other matches without actually searching. You can't yank or delete into this -register. The search direction is available in |v:searchforward|. -Note that the valued is restored when returning from a function -|function-search-undo|. -{not in Vi} - - *@/* -You can write to a register with a ":let" command |:let-@|. Example: > - :let @/ = "the" - -If you use a put command without specifying a register, Vim uses the register -that was last filled (this is also the contents of the unnamed register). If -you are confused, use the ":dis" command to find out what Vim will put (this -command displays all named and numbered registers; the unnamed register is -labelled '"'). - -The next three commands always work on whole lines. - -:[range]co[py] {address} *:co* *:copy* - Copy the lines given by [range] to below the line - given by {address}. - - *:t* -:t Synonym for copy. - -:[range]m[ove] {address} *:m* *:mo* *:move* *E134* - Move the lines given by [range] to below the line - given by {address}. - -============================================================================== -6. Formatting text *formatting* - -:[range]ce[nter] [width] *:ce* *:center* - Center lines in [range] between [width] columns - (default 'textwidth' or 80 when 'textwidth' is 0). - {not in Vi} - Not available when |+ex_extra| feature was disabled at - compile time. - -:[range]ri[ght] [width] *:ri* *:right* - Right-align lines in [range] at [width] columns - (default 'textwidth' or 80 when 'textwidth' is 0). - {not in Vi} - Not available when |+ex_extra| feature was disabled at - compile time. - - *:le* *:left* -:[range]le[ft] [indent] - Left-align lines in [range]. Sets the indent in the - lines to [indent] (default 0). {not in Vi} - Not available when |+ex_extra| feature was disabled at - compile time. - - *gq* -gq{motion} Format the lines that {motion} moves over. - Formatting is done with one of three methods: - 1. If 'formatexpr' is not empty the expression is - evaluated. This can differ for each buffer. - 2. If 'formatprg' is not empty an external program - is used. - 3. Otherwise formatting is done internally. - - In the third case the 'textwidth' option controls the - length of each formatted line (see below). - If the 'textwidth' option is 0, the formatted line - length is the screen width (with a maximum width of - 79). - The 'formatoptions' option controls the type of - formatting |fo-table|. - The cursor is left on the first non-blank of the last - formatted line. - NOTE: The "Q" command formerly performed this - function. If you still want to use "Q" for - formatting, use this mapping: > - :nnoremap Q gq - -gqgq *gqgq* *gqq* -gqq Format the current line. {not in Vi} - - *v_gq* -{Visual}gq Format the highlighted text. (for {Visual} see - |Visual-mode|). {not in Vi} - - *gw* -gw{motion} Format the lines that {motion} moves over. Similar to - |gq| but puts the cursor back at the same position in - the text. However, 'formatprg' and 'formatexpr' are - not used. {not in Vi} - -gwgw *gwgw* *gww* -gww Format the current line as with "gw". {not in Vi} - - *v_gw* -{Visual}gw Format the highlighted text as with "gw". (for - {Visual} see |Visual-mode|). {not in Vi} - -Example: To format the current paragraph use: *gqap* > - gqap - -The "gq" command leaves the cursor in the line where the motion command takes -the cursor. This allows you to repeat formatting repeated with ".". This -works well with "gqj" (format current and next line) and "gq}" (format until -end of paragraph). Note: When 'formatprg' is set, "gq" leaves the cursor on -the first formatted line (as with using a filter command). - -If you want to format the current paragraph and continue where you were, use: > - gwap -If you always want to keep paragraphs formatted you may want to add the 'a' -flag to 'formatoptions'. See |auto-format|. - -If the 'autoindent' option is on, Vim uses the indent of the first line for -the following lines. - -Formatting does not change empty lines (but it does change lines with only -white space!). - -The 'joinspaces' option is used when lines are joined together. - -You can set the 'formatexpr' option to an expression or the 'formatprg' option -to the name of an external program for Vim to use for text formatting. The -'textwidth' and other options have no effect on formatting by an external -program. - - *right-justify* -There is no command in Vim to right justify text. You can do it with -an external command, like "par" (e.g.: "!}par" to format until the end of the -paragraph) or set 'formatprg' to "par". - - *format-comments* -An overview of comment formatting is in section |30.6| of the user manual. - -Vim can automatically insert and format comments in a special way. Vim -recognizes a comment by a specific string at the start of the line (ignoring -white space). Three types of comments can be used: - -- A comment string that repeats at the start of each line. An example is the - type of comment used in shell scripts, starting with "#". -- A comment string that occurs only in the first line, not in the following - lines. An example is this list with dashes. -- Three-piece comments that have a start string, an end string, and optional - lines in between. The strings for the start, middle and end are different. - An example is the C style comment: - /* - * this is a C comment - */ - -The 'comments' option is a comma-separated list of parts. Each part defines a -type of comment string. A part consists of: - {flags}:{string} - -{string} is the literal text that must appear. - -{flags}: - n Nested comment. Nesting with mixed parts is allowed. If 'comments' - is "n:),n:>" a line starting with "> ) >" is a comment. - - b Blank (, or ) required after {string}. - - f Only the first line has the comment string. Do not repeat comment on - the next line, but preserve indentation (e.g., a bullet-list). - - s Start of three-piece comment - - m Middle of a three-piece comment - - e End of a three-piece comment - - l Left align. Used together with 's' or 'e', the leftmost character of - start or end will line up with the leftmost character from the middle. - This is the default and can be omitted. See below for more details. - - r Right align. Same as above but rightmost instead of leftmost. See - below for more details. - - O Don't consider this comment for the "O" command. - - x Allows three-piece comments to be ended by just typing the last - character of the end-comment string as the first action on a new - line when the middle-comment string has been inserted automatically. - See below for more details. - - {digits} - When together with 's' or 'e': add {digit} amount of offset to an - automatically inserted middle or end comment leader. The offset begins - from a left alignment. See below for more details. - - -{digits} - Like {digits} but reduce the indent. This only works when there is - some indent for the start or end part that can be removed. - -When a string has none of the 'f', 's', 'm' or 'e' flags, Vim assumes the -comment string repeats at the start of each line. The flags field may be -empty. - -Any blank space in the text before and after the {string} is part of the -{string}, so do not include leading or trailing blanks unless the blanks are a -required part of the comment string. - -When one comment leader is part of another, specify the part after the whole. -For example, to include both "-" and "->", use > - :set comments=f:->,f:- - -A three-piece comment must always be given as start,middle,end, with no other -parts in between. An example of a three-piece comment is > - sr:/*,mb:*,ex:*/ -for C-comments. To avoid recognizing "*ptr" as a comment, the middle string -includes the 'b' flag. For three-piece comments, Vim checks the text after -the start and middle strings for the end string. If Vim finds the end string, -the comment does not continue on the next line. Three-piece comments must -have a middle string because otherwise Vim can't recognize the middle lines. - -Notice the use of the "x" flag in the above three-piece comment definition. -When you hit Return in a C-comment, Vim will insert the middle comment leader -for the new line: " * ". To close this comment you just have to type "/" -before typing anything else on the new line. This will replace the -middle-comment leader with the end-comment leader and apply any specified -alignment, leaving just " */". There is no need to hit BackSpace first. - - -Here is an example of alignment flags at work to make a comment stand out -(kind of looks like a 1 too). Consider comment string > - sr:/***,m:**,ex2:******/ - - /*** - **<--right aligned from "r" flag - ** -offset 2 spaces from the "2" flag--->** - ******/ -In this case, the first comment was typed, then return was pressed 4 times, -then "/" was pressed to end the comment. - -Here are some finer points of three part comments. There are three times when -alignment and offset flags are taken into consideration: opening a new line -after a start-comment, opening a new line before an end-comment, and -automatically ending a three-piece comment. The end alignment flag has a -backwards perspective; the result is that the same alignment flag used with -"s" and "e" will result in the same indent for the starting and ending pieces. -Only one alignment per comment part is meant to be used, but an offset number -will override the "r" and "l" flag. - -Enabling 'cindent' will override the alignment flags in many cases. -Reindenting using a different method like |gq| or |=| will not consult -alignment flags either. The same behaviour can be defined in those other -formatting options. One consideration is that 'cindent' has additional options -for context based indenting of comments but cannot replicate many three piece -indent alignments. However, 'indentexpr' is has the ability to work better -with three piece comments. - -Other examples: > - "b:*" Includes lines starting with "*", but not if the "*" is - followed by a non-blank. This avoids a pointer dereference - like "*str" to be recognized as a comment. - "n:>" Includes a line starting with ">", ">>", ">>>", etc. - "fb:-" Format a list that starts with "- ". - -By default, "b:#" is included. This means that a line that starts with -"#include" is not recognized as a comment line. But a line that starts with -"# define" is recognized. This is a compromise. - -{not available when compiled without the |+comments| feature} - - *fo-table* -You can use the 'formatoptions' option to influence how Vim formats text. -'formatoptions' is a string that can contain any of the letters below. The -default setting is "tcq". You can separate the option letters with commas for -readability. - -letter meaning when present in 'formatoptions' ~ - -t Auto-wrap text using textwidth -c Auto-wrap comments using textwidth, inserting the current comment - leader automatically. -r Automatically insert the current comment leader after hitting - in Insert mode. -o Automatically insert the current comment leader after hitting 'o' or - 'O' in Normal mode. -q Allow formatting of comments with "gq". - Note that formatting will not change blank lines or lines containing - only the comment leader. A new paragraph starts after such a line, - or when the comment leader changes. -w Trailing white space indicates a paragraph continues in the next line. - A line that ends in a non-white character ends a paragraph. -a Automatic formatting of paragraphs. Every time text is inserted or - deleted the paragraph will be reformatted. See |auto-format|. - When the 'c' flag is present this only happens for recognized - comments. -n When formatting text, recognize numbered lists. This actually uses - the 'formatlistpat' option, thus any kind of list can be used. The - indent of the text after the number is used for the next line. The - default is to find a number, optionally followed by '.', ':', ')', - ']' or '}'. Note that 'autoindent' must be set too. Doesn't work - well together with "2". - Example: > - 1. the first item - wraps - 2. the second item -2 When formatting text, use the indent of the second line of a paragraph - for the rest of the paragraph, instead of the indent of the first - line. This supports paragraphs in which the first line has a - different indent than the rest. Note that 'autoindent' must be set - too. Example: > - first line of a paragraph - second line of the same paragraph - third line. -v Vi-compatible auto-wrapping in insert mode: Only break a line at a - blank that you have entered during the current insert command. (Note: - this is not 100% Vi compatible. Vi has some "unexpected features" or - bugs in this area. It uses the screen column instead of the line - column.) -b Like 'v', but only auto-wrap if you enter a blank at or before - the wrap margin. If the line was longer than 'textwidth' when you - started the insert, or you do not enter a blank in the insert before - reaching 'textwidth', Vim does not perform auto-wrapping. -l Long lines are not broken in insert mode: When a line was longer than - 'textwidth' when the insert command started, Vim does not - automatically format it. -m Also break at a multi-byte character above 255. This is useful for - Asian text where every character is a word on its own. -M When joining lines, don't insert a space before or after a multi-byte - character. Overrules the 'B' flag. -B When joining lines, don't insert a space between two multi-byte - characters. Overruled by the 'M' flag. -1 Don't break a line after a one-letter word. It's broken before it - instead (if possible). - - -With 't' and 'c' you can specify when Vim performs auto-wrapping: -value action ~ -"" no automatic formatting (you can use "gq" for manual formatting) -"t" automatic formatting of text, but not comments -"c" automatic formatting for comments, but not text (good for C code) -"tc" automatic formatting for text and comments - -Note that when 'textwidth' is 0, Vim does no automatic formatting anyway (but -does insert comment leaders according to the 'comments' option). An exception -is when the 'a' flag is present. |auto-format| - -Note that when 'paste' is on, Vim does no formatting at all. - -Note that 'textwidth' can be non-zero even if Vim never performs auto-wrapping; -'textwidth' is still useful for formatting with "gq". - -If the 'comments' option includes "/*", "*" and/or "*/", then Vim has some -built in stuff to treat these types of comments a bit more cleverly. -Opening a new line before or after "/*" or "*/" (with 'r' or 'o' present in -'formatoptions') gives the correct start of the line automatically. The same -happens with formatting and auto-wrapping. Opening a line after a line -starting with "/*" or "*" and containing "*/", will cause no comment leader to -be inserted, and the indent of the new line is taken from the line containing -the start of the comment. -E.g.: - /* ~ - * Your typical comment. ~ - */ ~ - The indent on this line is the same as the start of the above - comment. - -All of this should be really cool, especially in conjunction with the new -:autocmd command to prepare different settings for different types of file. - -Some examples: - for C code (only format comments): > - :set fo=croq -< for Mail/news (format all, don't start comment with "o" command): > - :set fo=tcrq -< - -Automatic formatting *auto-format* - -When the 'a' flag is present in 'formatoptions' text is formatted -automatically when inserting text or deleting text. This works nice for -editing text paragraphs. A few hints on how to use this: - -- You need to properly define paragraphs. The simplest is paragraphs that are - separated by a blank line. When there is no separating blank line, consider - using the 'w' flag and adding a space at the end of each line in the - paragraphs except the last one. - -- You can set the 'formatoptions' based on the type of file |filetype| or - specifically for one file with a |modeline|. - -- Set 'formatoptions' to "aw2tq" to make text with indents like this: - - bla bla foobar bla - bla foobar bla foobar bla - bla bla foobar bla - bla foobar bla bla foobar - -- Add the 'c' flag to only auto-format comments. Useful in source code. - -- Set 'textwidth' to the desired width. If it is zero then 79 is used, or the - width of the screen if this is smaller. - -And a few warnings: - -- When part of the text is not properly separated in paragraphs, making - changes in this text will cause it to be formatted anyway. Consider doing > - - :set fo-=a - -- When using the 'w' flag (trailing space means paragraph continues) and - deleting the last line of a paragraph with |dd|, the paragraph will be - joined with the next one. - -- Changed text is saved for undo. Formatting is also a change. Thus each - format action saves text for undo. This may consume quite a lot of memory. - -- Formatting a long paragraph and/or with complicated indenting may be slow. - -============================================================================== -7. Sorting text *sorting* - -Vim has a sorting function and a sorting command. The sorting function can be -found here: |sort()|. - - *:sor* *:sort* -:[range]sor[t][!] [i][u][r][n][x][o] [/{pattern}/] - Sort lines in [range]. When no range is given all - lines are sorted. - - With [!] the order is reversed. - - With [i] case is ignored. - - With [n] sorting is done on the first decimal number - in the line (after or inside a {pattern} match). - One leading '-' is included in the number. - - With [x] sorting is done on the first hexadecimal - number in the line (after or inside a {pattern} - match). A leading "0x" or "0X" is ignored. - One leading '-' is included in the number. - - With [o] sorting is done on the first octal number in - the line (after or inside a {pattern} match). - - With [u] only keep the first of a sequence of - identical lines (ignoring case when [i] is used). - Without this flag, a sequence of identical lines - will be kept in their original order. - Note that leading and trailing white space may cause - lines to be different. - - When /{pattern}/ is specified and there is no [r] flag - the text matched with {pattern} is skipped, so that - you sort on what comes after the match. - Instead of the slash any non-letter can be used. - For example, to sort on the second comma-separated - field: > - :sort /[^,]*,/ -< To sort on the text at virtual column 10 (thus - ignoring the difference between tabs and spaces): > - :sort /.*\%10v/ -< To sort on the first number in the line, no matter - what is in front of it: > - :sort /.\{-}\ze\d/ -< (Explanation: ".\{-}" matches any text, "\ze" sets the - end of the match and \d matches a digit.) - With [r] sorting is done on the matching {pattern} - instead of skipping past it as described above. - For example, to sort on only the first three letters - of each line: > - :sort /\a\a\a/ r - -< If a {pattern} is used, any lines which don't have a - match for {pattern} are kept in their current order, - but separate from the lines which do match {pattern}. - If you sorted in reverse, they will be in reverse - order after the sorted lines, otherwise they will be - in their original order, right before the sorted - lines. - - If {pattern} is empty (e.g. // is specified), the - last search pattern is used. This allows trying out - a pattern first. - -Note that using ":sort" with ":global" doesn't sort the matching lines, it's -quite useless. - -The details about sorting depend on the library function used. There is no -guarantee that sorting is "stable" or obeys the current locale. You will have -to try it out. - -The sorting can be interrupted, but if you interrupt it too late in the -process you may end up with duplicated lines. This also depends on the system -library function used. - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/cmdline.txt b/share/vim/vim72/doc/cmdline.txt deleted file mode 100644 index 839536b21f..0000000000 --- a/share/vim/vim72/doc/cmdline.txt +++ /dev/null @@ -1,1080 +0,0 @@ -*cmdline.txt* For Vim version 7.2. Last change: 2008 Sep 18 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - - *Cmdline-mode* *Command-line-mode* -Command-line mode *Cmdline* *Command-line* *mode-cmdline* *:* - -Command-line mode is used to enter Ex commands (":"), search patterns -("/" and "?"), and filter commands ("!"). - -Basic command line editing is explained in chapter 20 of the user manual -|usr_20.txt|. - -1. Command-line editing |cmdline-editing| -2. Command-line completion |cmdline-completion| -3. Ex command-lines |cmdline-lines| -4. Ex command-line ranges |cmdline-ranges| -5. Ex command-line flags |ex-flags| -6. Ex special characters |cmdline-special| -7. Command-line window |cmdline-window| - -============================================================================== -1. Command-line editing *cmdline-editing* - -Normally characters are inserted in front of the cursor position. You can -move around in the command-line with the left and right cursor keys. With the - key, you can toggle between inserting and overstriking characters. -{Vi: can only alter the last character in the line} - -Note that if your keyboard does not have working cursor keys or any of the -other special keys, you can use ":cnoremap" to define another key for them. -For example, to define tcsh style editing keys: *tcsh-style* > - :cnoremap - :cnoremap - :cnoremap - :cnoremap b - :cnoremap f -(<> notation |<>|; type all this literally) - - *cmdline-too-long* -When the command line is getting longer than what fits on the screen, only the -part that fits will be shown. The cursor can only move in this visible part, -thus you cannot edit beyond that. - - *cmdline-history* *history* -The command-lines that you enter are remembered in a history table. You can -recall them with the up and down cursor keys. There are actually five -history tables: -- one for ':' commands -- one for search strings -- one for expressions -- one for input lines, typed for the |input()| function. -- one for debug mode commands -These are completely separate. Each history can only be accessed when -entering the same type of line. -Use the 'history' option to set the number of lines that are remembered -(default: 20). -Notes: -- When you enter a command-line that is exactly the same as an older one, the - old one is removed (to avoid repeated commands moving older commands out of - the history). -- Only commands that are typed are remembered. Ones that completely come from - mappings are not put in the history. -- All searches are put in the search history, including the ones that come - from commands like "*" and "#". But for a mapping, only the last search is - remembered (to avoid that long mappings trash the history). -{Vi: no history} -{not available when compiled without the |+cmdline_hist| feature} - -There is an automatic completion of names on the command-line; see -|cmdline-completion|. - - *c_CTRL-V* -CTRL-V Insert next non-digit literally. Up to three digits form the - decimal value of a single byte. The non-digit and the three - digits are not considered for mapping. This works the same - way as in Insert mode (see above, |i_CTRL-V|). - Note: Under Windows CTRL-V is often mapped to paste text. - Use CTRL-Q instead then. - *c_CTRL-Q* -CTRL-Q Same as CTRL-V. But with some terminals it is used for - control flow, it doesn't work then. - - *c_* - cursor left - *c_* - cursor right - *c_* - or *c_* - cursor one WORD left - *c_* - or *c_* - cursor one WORD right -CTRL-B or *c_CTRL-B* *c_* - cursor to beginning of command-line -CTRL-E or *c_CTRL-E* *c_* - cursor to end of command-line - - *c_* - Move the cursor to the position of the mouse click. - -CTRL-H *c_* *c_CTRL-H* - Delete the character in front of the cursor (see |:fixdel| if - your key does not do what you want). - *c_* - Delete the character under the cursor (at end of line: - character before the cursor) (see |:fixdel| if your - key does not do what you want). - *c_CTRL-W* -CTRL-W Delete the |word| before the cursor. This depends on the - 'iskeyword' option. - *c_CTRL-U* -CTRL-U Remove all characters between the cursor position and - the beginning of the line. Previous versions of vim - deleted all characters on the line. If that is the - preferred behavior, add the following to your .vimrc: > - :cnoremap -< - Note: if the command-line becomes empty with one of the - delete commands, Command-line mode is quit. - *c_* - Toggle between insert and overstrike. {not in Vi} - -{char1} {char2} or *c_digraph* -CTRL-K {char1} {char2} *c_CTRL-K* - enter digraph (see |digraphs|). When {char1} is a special - key, the code for that key is inserted in <> form. {not in Vi} - -CTRL-R {0-9a-z"%#:-=.} *c_CTRL-R* *c_* - Insert the contents of a numbered or named register. Between - typing CTRL-R and the second character '"' will be displayed - to indicate that you are expected to enter the name of a - register. - The text is inserted as if you typed it, but mappings and - abbreviations are not used. Command-line completion through - 'wildchar' is not triggered though. And characters that end - the command line are inserted literally (, , , - ). A or CTRL-W could still end the command line - though, and remaining characters will then be interpreted in - another mode, which might not be what you intended. - Special registers: - '"' the unnamed register, containing the text of - the last delete or yank - '%' the current file name - '#' the alternate file name - '*' the clipboard contents (X11: primary selection) - '+' the clipboard contents - '/' the last search pattern - ':' the last command-line - '-' the last small (less than a line) delete - '.' the last inserted text - *c_CTRL-R_=* - '=' the expression register: you are prompted to - enter an expression (see |expression|) - (doesn't work at the expression prompt; some - things such as changing the buffer or current - window are not allowed to avoid side effects) - When the result is a |List| the items are used - as lines. They can have line breaks inside - too. - When the result is a Float it's automatically - converted to a String. - See |registers| about registers. {not in Vi} - Implementation detail: When using the |expression| register - and invoking setcmdpos(), this sets the position before - inserting the resulting string. Use CTRL-R CTRL-R to set the - position afterwards. - -CTRL-R CTRL-F *c_CTRL-R_CTRL-F* *c__* -CTRL-R CTRL-P *c_CTRL-R_CTRL-P* *c__* -CTRL-R CTRL-W *c_CTRL-R_CTRL-W* *c__* -CTRL-R CTRL-A *c_CTRL-R_CTRL-A* *c__* - Insert the object under the cursor: - CTRL-F the Filename under the cursor - CTRL-P the Filename under the cursor, expanded with - 'path' as in |gf| - CTRL-W the Word under the cursor - CTRL-A the WORD under the cursor; see |WORD| - - When 'incsearch' is set the cursor position at the end of the - currently displayed match is used. With CTRL-W the part of - the word that was already typed is not inserted again. - - {not in Vi} - CTRL-F and CTRL-P: {only when +file_in_path feature is - included} - - *c_CTRL-R_CTRL-R* *c__* - *c_CTRL-R_CTRL-O* *c__* -CTRL-R CTRL-R {0-9a-z"%#:-=. CTRL-F CTRL-P CTRL-W CTRL-A} -CTRL-R CTRL-O {0-9a-z"%#:-=. CTRL-F CTRL-P CTRL-W CTRL-A} - Insert register or object under the cursor. Works like - |c_CTRL-R| but inserts the text literally. For example, if - register a contains "xy^Hz" (where ^H is a backspace), - "CTRL-R a" will insert "xz" while "CTRL-R CTRL-R a" will - insert "xy^Hz". - -CTRL-\ e {expr} *c_CTRL-\_e* - Evaluate {expr} and replace the whole command line with the - result. You will be prompted for the expression, type - to finish it. It's most useful in mappings though. See - |expression|. - See |c_CTRL-R_=| for inserting the result of an expression. - Useful functions are |getcmdtype()|, |getcmdline()| and - |getcmdpos()|. - The cursor position is unchanged, except when the cursor was - at the end of the line, then it stays at the end. - |setcmdpos()| can be used to set the cursor position. - The |sandbox| is used for evaluating the expression to avoid - nasty side effects. - Example: > - :cmap eAppendSome() - :func AppendSome() - :let cmd = getcmdline() . " Some()" - :" place the cursor on the ) - :call setcmdpos(strlen(cmd)) - :return cmd - :endfunc -< This doesn't work recursively, thus not when already editing - an expression. - - *c_CTRL-Y* -CTRL-Y When there is a modeless selection, copy the selection into - the clipboard. |modeless-selection| - If there is no selection CTRL-Y is inserted as a character. - -CTRL-J *c_CTRL-J* *c_* *c_* - or start entered command - *c_* - When typed and 'x' not present in 'cpoptions', quit - Command-line mode without executing. In macros or when 'x' - present in 'cpoptions', start entered command. - Note: If your key is hard to hit on your keyboard, train - yourself to use CTRL-[. - *c_CTRL-C* -CTRL-C quit command-line without executing - - *c_* - recall older command-line from history, whose beginning - matches the current command-line (see below). - {not available when compiled without the |+cmdline_hist| - feature} - *c_* - recall more recent command-line from history, whose beginning - matches the current command-line (see below). - {not available when compiled without the |+cmdline_hist| - feature} - - *c_* *c_* - or - recall older command-line from history - {not available when compiled without the |+cmdline_hist| - feature} - *c_* *c_* - or - recall more recent command-line from history - {not available when compiled without the |+cmdline_hist| - feature} - -CTRL-D command-line completion (see |cmdline-completion|) -'wildchar' option - command-line completion (see |cmdline-completion|) -CTRL-N command-line completion (see |cmdline-completion|) -CTRL-P command-line completion (see |cmdline-completion|) -CTRL-A command-line completion (see |cmdline-completion|) -CTRL-L command-line completion (see |cmdline-completion|) - - *c_CTRL-_* -CTRL-_ a - switch between Hebrew and English keyboard mode, which is - private to the command-line and not related to hkmap. - This is useful when Hebrew text entry is required in the - command-line, searches, abbreviations, etc. Applies only if - Vim is compiled with the |+rightleft| feature and the - 'allowrevins' option is set. - See |rileft.txt|. - - b - switch between Farsi and English keyboard mode, which is - private to the command-line and not related to fkmap. In - Farsi keyboard mode the characters are inserted in reverse - insert manner. This is useful when Farsi text entry is - required in the command-line, searches, abbreviations, etc. - Applies only if Vim is compiled with the |+farsi| feature. - See |farsi.txt|. - - *c_CTRL-^* -CTRL-^ Toggle the use of language |:lmap| mappings and/or Input - Method. - When typing a pattern for a search command and 'imsearch' is - not -1, VAL is the value of 'imsearch', otherwise VAL is the - value of 'iminsert'. - When language mappings are defined: - - If VAL is 1 (langmap mappings used) it becomes 0 (no langmap - mappings used). - - If VAL was not 1 it becomes 1, thus langmap mappings are - enabled. - When no language mappings are defined: - - If VAL is 2 (Input Method is used) it becomes 0 (no input - method used) - - If VAL has another value it becomes 2, thus the Input Method - is enabled. - These language mappings are normally used to type characters - that are different from what the keyboard produces. The - 'keymap' option can be used to install a whole number of them. - When entering a command line, langmap mappings are switched - off, since you are expected to type a command. After - switching it on with CTRL-^, the new state is not used again - for the next command or Search pattern. - {not in Vi} - - *c_CTRL-]* -CTRL-] Trigger abbreviation, without inserting a character. {not in - Vi} - -For Emacs-style editing on the command-line see |emacs-keys|. - -The and keys take the current command-line as a search string. -The beginning of the next/previous command-lines are compared with this -string. The first line that matches is the new command-line. When typing -these two keys repeatedly, the same string is used again. For example, this -can be used to find the previous substitute command: Type ":s" and then . -The same could be done by typing a number of times until the desired -command-line is shown. (Note: the shifted arrow keys do not work on all -terminals) - - *:his* *:history* -:his[tory] Print the history of last entered commands. - {not in Vi} - {not available when compiled without the |+cmdline_hist| - feature} - -:his[tory] [{name}] [{first}][, [{last}]] - List the contents of history {name} which can be: - c[md] or : command-line history - s[earch] or / search string history - e[xpr] or = expression register history - i[nput] or @ input line history - d[ebug] or > debug command history - a[ll] all of the above - {not in Vi} - - If the numbers {first} and/or {last} are given, the respective - range of entries from a history is listed. These numbers can - be specified in the following form: - *:history-indexing* - A positive number represents the absolute index of an entry - as it is given in the first column of a :history listing. - This number remains fixed even if other entries are deleted. - - A negative number means the relative position of an entry, - counted from the newest entry (which has index -1) backwards. - - Examples: - List entries 6 to 12 from the search history: > - :history / 6,12 -< - List the recent five entries from all histories: > - :history all -5, - -============================================================================== -2. Command-line completion *cmdline-completion* - -When editing the command-line, a few commands can be used to complete the -word before the cursor. This is available for: - -- Command names: At the start of the command-line. -- Tags: Only after the ":tag" command. -- File names: Only after a command that accepts a file name or a setting for - an option that can be set to a file name. This is called file name - completion. -- Shell command names: After ":!cmd", ":r !cmd" and ":w !cmd". $PATH is used. -- Options: Only after the ":set" command. -- Mappings: Only after a ":map" or similar command. -- Variable and function names: Only after a ":if", ":call" or similar command. - -When Vim was compiled with the |+cmdline_compl| feature disabled, only file -names, directories and help items can be completed. The number of help item -matches is limited (currently to 300) to avoid a long delay when there are -very many matches. - -These are the commands that can be used: - - *c_CTRL-D* -CTRL-D List names that match the pattern in front of the cursor. - When showing file names, directories are highlighted (see - 'highlight' option). Names where 'suffixes' matches are moved - to the end. - The 'wildoptions' option can be set to "tagfile" to list the - file of matching tags. - *c_CTRL-I* *c_wildchar* *c_* -'wildchar' option - A match is done on the pattern in front of the cursor. The - match (if there are several, the first match) is inserted - in place of the pattern. (Note: does not work inside a - macro, because or are mostly used as 'wildchar', - and these have a special meaning in some macros.) When typed - again and there were multiple matches, the next - match is inserted. After the last match, the first is used - again (wrap around). - The behavior can be changed with the 'wildmode' option. - *c_CTRL-N* -CTRL-N After using 'wildchar' which got multiple matches, go to next - match. Otherwise recall more recent command-line from history. - *c_CTRL-P* *c_* -CTRL-P After using 'wildchar' which got multiple matches, go to - previous match. Otherwise recall older command-line from - history. only works with the GUI, on the Amiga and - with MS-DOS. - *c_CTRL-A* -CTRL-A All names that match the pattern in front of the cursor are - inserted. - *c_CTRL-L* -CTRL-L A match is done on the pattern in front of the cursor. If - there is one match, it is inserted in place of the pattern. - If there are multiple matches the longest common part is - inserted in place of the pattern. If the result is shorter - than the pattern, no completion is done. - When 'incsearch' is set, entering a search pattern for "/" or - "?" and the current match is displayed then CTRL-L will add - one character from the end of the current match. - -The 'wildchar' option defaults to (CTRL-E when in Vi compatible mode; in -a previous version was used). In the pattern standard wildcards '*' and -'?' are accepted. '*' matches any string, '?' matches exactly one character. - -If you like tcsh's autolist completion, you can use this mapping: - :cnoremap X -(Where X is the command key to use, is CTRL-L and is CTRL-D) -This will find the longest match and then list all matching files. - -If you like tcsh's autolist completion, you can use the 'wildmode' option to -emulate it. For example, this mimics autolist=ambiguous: - :set wildmode=longest,list -This will find the longest match with the first 'wildchar', then list all -matching files with the next. - - *suffixes* -For file name completion you can use the 'suffixes' option to set a priority -between files with almost the same name. If there are multiple matches, -those files with an extension that is in the 'suffixes' option are ignored. -The default is ".bak,~,.o,.h,.info,.swp,.obj", which means that files ending -in ".bak", "~", ".o", ".h", ".info", ".swp" and ".obj" are sometimes ignored. -It is impossible to ignore suffixes with two dots. Examples: - - pattern: files: match: ~ - test* test.c test.h test.o test.c - test* test.h test.o test.h and test.o - test* test.i test.h test.c test.i and test.c - -If there is more than one matching file (after ignoring the ones matching -the 'suffixes' option) the first file name is inserted. You can see that -there is only one match when you type 'wildchar' twice and the completed -match stays the same. You can get to the other matches by entering -'wildchar', CTRL-N or CTRL-P. All files are included, also the ones with -extensions matching the 'suffixes' option. - -To completely ignore files with some extension use 'wildignore'. - -To match only files that end at the end of the typed text append a "$". For -example, to match only files that end in ".c": > - :e *.c$ -This will not match a file ending in ".cpp". Without the "$" it does match. - -The old value of an option can be obtained by hitting 'wildchar' just after -the '='. For example, typing 'wildchar' after ":set dir=" will insert the -current value of 'dir'. This overrules file name completion for the options -that take a file name. - -If you would like using for CTRL-P in an xterm, put this command in -your .cshrc: > - xmodmap -e "keysym Tab = Tab Find" -And this in your .vimrc: > - :cmap [1~ - -============================================================================== -3. Ex command-lines *cmdline-lines* - -The Ex commands have a few specialties: - - *:quote* -'"' at the start of a line causes the whole line to be ignored. '"' -after a command causes the rest of the line to be ignored. This can be used -to add comments. Example: > - :set ai "set 'autoindent' option -It is not possible to add a comment to a shell command ":!cmd" or to the -":map" command and friends, because they see the '"' as part of their -argument. - - *:bar* *:\bar* -'|' can be used to separate commands, so you can give multiple commands in one -line. If you want to use '|' in an argument, precede it with '\'. - -These commands see the '|' as their argument, and can therefore not be -followed by another Vim command: - :argdo - :autocmd - :bufdo - :command - :cscope - :debug - :folddoopen - :folddoclosed - :function - :global - :help - :helpfind - :lcscope - :make - :normal - :perl - :perldo - :promptfind - :promptrepl - :pyfile - :python - :registers - :read ! - :scscope - :tcl - :tcldo - :tclfile - :vglobal - :windo - :write ! - :[range]! - a user defined command without the "-bar" argument |:command| - -Note that this is confusing (inherited from Vi): With ":g" the '|' is included -in the command, with ":s" it is not. - -To be able to use another command anyway, use the ":execute" command. -Example (append the output of "ls" and jump to the first line): > - :execute 'r !ls' | '[ - -There is one exception: When the 'b' flag is present in 'cpoptions', with the -":map" and ":abbr" commands and friends CTRL-V needs to be used instead of -'\'. You can also use "" instead. See also |map_bar|. - -Examples: > - :!ls | wc view the output of two commands - :r !ls | wc insert the same output in the text - :%g/foo/p|> moves all matching lines one shiftwidth - :%s/foo/bar/|> moves one line one shiftwidth - :map q 10^V| map "q" to "10|" - :map q 10\| map \ l map "q" to "10\" and map "\" to "l" - (when 'b' is present in 'cpoptions') - -You can also use to separate commands in the same way as with '|'. To -insert a use CTRL-V CTRL-J. "^@" will be shown. Using '|' is the -preferred method. But for external commands a must be used, because a -'|' is included in the external command. To avoid the special meaning of -it must be preceded with a backslash. Example: > - :r !date-join -This reads the current date into the file and joins it with the previous line. - -Note that when the command before the '|' generates an error, the following -commands will not be executed. - - -Because of Vi compatibility the following strange commands are supported: > - :| print current line (like ":p") - :3| print line 3 (like ":3p") - :3 goto line 3 - -A colon is allowed between the range and the command name. It is ignored -(this is Vi compatible). For example: > - :1,$:s/pat/string - -When the character '%' or '#' is used where a file name is expected, they are -expanded to the current and alternate file name (see the chapter "editing -files" |:_%| |:_#|). - -Embedded spaces in file names are allowed on the Amiga if one file name is -expected as argument. Trailing spaces will be ignored, unless escaped with a -backslash or CTRL-V. Note that the ":next" command uses spaces to separate -file names. Escape the spaces to include them in a file name. Example: > - :next foo\ bar goes\ to school\ -starts editing the three files "foo bar", "goes to" and "school ". - -When you want to use the special characters '"' or '|' in a command, or want -to use '%' or '#' in a file name, precede them with a backslash. The -backslash is not required in a range and in the ":substitute" command. - - *:_!* -The '!' (bang) character after an Ex command makes the command behave in a -different way. The '!' should be placed immediately after the command, without -any blanks in between. If you insert blanks the '!' will be seen as an -argument for the command, which has a different meaning. For example: - :w! name write the current buffer to file "name", overwriting - any existing file - :w !name send the current buffer as standard input to command - "name" - -============================================================================== -4. Ex command-line ranges *cmdline-ranges* *[range]* *E16* - -Some Ex commands accept a line range in front of them. This is noted as -[range]. It consists of one or more line specifiers, separated with ',' or -';'. - -The basics are explained in section |10.3| of the user manual. - - *:,* *:;* -When separated with ';' the cursor position will be set to that line -before interpreting the next line specifier. This doesn't happen for ','. -Examples: > - 4,/this line/ -< from line 4 till match with "this line" after the cursor line. > - 5;/that line/ -< from line 5 till match with "that line" after line 5. - -The default line specifier for most commands is the cursor position, but the -commands ":write" and ":global" have the whole file (1,$) as default. - -If more line specifiers are given than required for the command, the first -one(s) will be ignored. - -Line numbers may be specified with: *:range* *E14* *{address}* - {number} an absolute line number - . the current line *:.* - $ the last line in the file *:$* - % equal to 1,$ (the entire file) *:%* - 't position of mark t (lowercase) *:'* - 'T position of mark T (uppercase); when the mark is in - another file it cannot be used in a range - /{pattern}[/] the next line where {pattern} matches *:/* - ?{pattern}[?] the previous line where {pattern} matches *:?* - \/ the next line where the previously used search - pattern matches - \? the previous line where the previously used search - pattern matches - \& the next line where the previously used substitute - pattern matches - -Each may be followed (several times) by '+' or '-' and an optional number. -This number is added or subtracted from the preceding line number. If the -number is omitted, 1 is used. - -The "/" and "?" after {pattern} are required to separate the pattern from -anything that follows. - -The "/" and "?" may be preceded with another address. The search starts from -there. The difference from using ';' is that the cursor isn't moved. -Examples: > - /pat1//pat2/ Find line containing "pat2" after line containing - "pat1", without moving the cursor. - 7;/pat2/ Find line containing "pat2", after line 7, leaving - the cursor in line 7. - -The {number} must be between 0 and the number of lines in the file. When -using a 0 (zero) this is interpreted as a 1 by most commands. Commands that -use it as a count do use it as a zero (|:tag|, |:pop|, etc). Some commands -interpret the zero as "before the first line" (|:read|, search pattern, etc). - -Examples: > - .+3 three lines below the cursor - /that/+1 the line below the next line containing "that" - .,$ from current line until end of file - 0;/that the first line containing "that", also matches in the - first line. - 1;/that the first line after line 1 containing "that" - -Some commands allow for a count after the command. This count is used as the -number of lines to be used, starting with the line given in the last line -specifier (the default is the cursor line). The commands that accept a count -are the ones that use a range but do not have a file name argument (because -a file name can also be a number). - -Examples: > - :s/x/X/g 5 substitute 'x' by 'X' in the current line and four - following lines - :23d 4 delete lines 23, 24, 25 and 26 - - -Folds and Range - -When folds are active the line numbers are rounded off to include the whole -closed fold. See |fold-behavior|. - - -Reverse Range *E493* - -A range should have the lower line number first. If this is not the case, Vim -will ask you if it should swap the line numbers. - Backwards range given, OK to swap ~ -This is not done within the global command ":g". - -You can use ":silent" before a command to avoid the question, the range will -always be swapped then. - - -Count and Range *N:* - -When giving a count before entering ":", this is translated into: - :.,.+(count - 1) -In words: The 'count' lines at and after the cursor. Example: To delete -three lines: > - 3:d is translated into: .,.+2d -< - -Visual Mode and Range *v_:* - -{Visual}: Starts a command-line with the Visual selected lines as a - range. The code ":'<,'>" is used for this range, which makes - it possible to select a similar line from the command-line - history for repeating a command on different Visually selected - lines. - -============================================================================== -5. Ex command-line flags *ex-flags* - -These flags are supported by a selection of Ex commands. They print the line -that the cursor ends up after executing the command: - - l output like for |:list| - # add line number - p output like for |:print| - -The flags can be combined, thus "l#" uses both a line number and |:list| style -output. - -============================================================================== -6. Ex special characters *cmdline-special* - -Note: These are special characters in the executed command line. If you want -to insert special things while typing you can use the CTRL-R command. For -example, "%" stands for the current file name, while CTRL-R % inserts the -current file name right away. See |c_CTRL-R|. - -Note: If you want to avoid the special characters in a Vim script you may want -to use |fnameescape()|. - - -In Ex commands, at places where a file name can be used, the following -characters have a special meaning. These can also be used in the expression -function expand() |expand()|. - % Is replaced with the current file name. *:_%* *c_%* - # Is replaced with the alternate file name. *:_#* *c_#* - #n (where n is a number) is replaced with the file name of - buffer n. "#0" is the same as "#". - ## Is replaced with all names in the argument list *:_##* *c_##* - concatenated, separated by spaces. Each space in a name - is preceded with a backslash. - # 0) is replaced with old *:_#<* *c_#<* - file name n. See |:oldfiles| or |v:oldfiles| to get the - number. *E809* - {only when compiled with the +eval and +viminfo features} - -Note that these, except "# - :!ls "%" - :r !spell "%" - -To avoid the special meaning of '%' and '#' insert a backslash before it. -Detail: The special meaning is always escaped when there is a backslash before -it, no matter how many backslashes. - you type: result ~ - # alternate.file - \# # - \\# \# - - *:* *:* *:* ** - *:* ** *:* ** - *:* ** *:* ** - *E495* *E496* *E497* *E498* *E499* *E500* -Note: these are typed literally, they are not special keys! - is replaced with the word under the cursor (like |star|) - is replaced with the WORD under the cursor (see |WORD|) - is replaced with the path name under the cursor (like what - |gf| uses) - when executing autocommands, is replaced with the file name - for a file read or write - when executing autocommands, is replaced with the currently - effective buffer number (for ":r file" and ":so file" it is - the current buffer, the file being read/sourced is not in a - buffer). - when executing autocommands, is replaced with the match for - which this autocommand was executed. It differs from - only when the file name isn't used to match with - (for FileType, Syntax and SpellFileMissing events). - when executing a ":source" command, is replaced with the - file name of the sourced file; - when executing a function, is replaced with - "function {function-name}"; function call nesting is - indicated like this: - "function {function-name1}..{function-name2}". Note that - filename-modifiers are useless when is used inside - a function. - - *filename-modifiers* - *:_%:* *::8* *::p* *::.* *::~* *::h* *::t* *::r* *::e* *::s* *::gs* -The file name modifiers can be used after "%", "#", "#n", "", "", -"" or "". They are also used with the |fnamemodify()| function. -These are not available when Vim has been compiled without the |+modify_fname| -feature. -These modifiers can be given, in this order: - :p Make file name a full path. Must be the first modifier. Also - changes "~/" (and "~user/" for Unix and VMS) to the path for - the home directory. If the name is a directory a path - separator is added at the end. For a file name that does not - exist and does not have an absolute path the result is - unpredictable. - :8 Converts the path to 8.3 short format (currently only on - win32). Will act on as much of a path that is an existing - path. - :~ Reduce file name to be relative to the home directory, if - possible. File name is unmodified if it is not below the home - directory. - :. Reduce file name to be relative to current directory, if - possible. File name is unmodified if it is not below the - current directory. - For maximum shortness, use ":~:.". - :h Head of the file name (the last component and any separators - removed). Cannot be used with :e, :r or :t. - Can be repeated to remove several components at the end. - When the file name ends in a path separator, only the path - separator is removed. Thus ":p:h" on a directory name results - on the directory name itself (without trailing slash). - When the file name is an absolute path (starts with "/" for - Unix; "x:\" for MS-DOS, WIN32, OS/2; "drive:" for Amiga), that - part is not removed. When there is no head (path is relative - to current directory) the result is empty. - :t Tail of the file name (last component of the name). Must - precede any :r or :e. - :r Root of the file name (the last extension removed). When - there is only an extension (file name that starts with '.', - e.g., ".vimrc"), it is not removed. Can be repeated to remove - several extensions (last one first). - :e Extension of the file name. Only makes sense when used alone. - When there is no extension the result is empty. - When there is only an extension (file name that starts with - '.'), the result is empty. Can be repeated to include more - extensions. If there are not enough extensions (but at least - one) as much as possible are included. - :s?pat?sub? - Substitute the first occurrence of "pat" with "sub". This - works like the |:s| command. "pat" is a regular expression. - Any character can be used for '?', but it must not occur in - "pat" or "sub". - After this, the previous modifiers can be used again. For - example ":p", to make a full path after the substitution. - :gs?pat?sub? - Substitute all occurrences of "path" with "sub". Otherwise - this works like ":s". - -Examples, when the file name is "src/version.c", current dir -"/home/mool/vim": > - :p /home/mool/vim/src/version.c - :p:. src/version.c - :p:~ ~/vim/src/version.c - :h src - :p:h /home/mool/vim/src - :p:h:h /home/mool/vim - :t version.c - :p:t version.c - :r src/version - :p:r /home/mool/vim/src/version - :t:r version - :e c - :s?version?main? src/main.c - :s?version?main?:p /home/mool/vim/src/main.c - :p:gs?/?\\? \home\mool\vim\src\version.c - -Examples, when the file name is "src/version.c.gz": > - :p /home/mool/vim/src/version.c.gz - :e gz - :e:e c.gz - :e:e:e c.gz - :e:e:r c - :r src/version.c - :r:e c - :r:r src/version - :r:r:r src/version -< - *extension-removal* *:_%<* -If a "<" is appended to "%", "#", "#n" or "CTRL-V p" the extension of the file -name is removed (everything after and including the last '.' in the file -name). This is included for backwards compatibility with version 3.0, the -":r" form is preferred. Examples: > - - % current file name - %< current file name without extension - # alternate file name for current window - #< idem, without extension - #31 alternate file number 31 - #31< idem, without extension - word under the cursor - WORD under the cursor (see |WORD|) - path name under the cursor - < idem, without extension - -Note: Where a file name is expected wildcards expansion is done. On Unix the -shell is used for this, unless it can be done internally (for speed). -Backticks also work, like in > - :n `echo *.c` -(backtick expansion is not possible in |restricted-mode|) -But expansion is only done if there are any wildcards before expanding the -'%', '#', etc.. This avoids expanding wildcards inside a file name. If you -want to expand the result of , add a wildcard character to it. -Examples: (alternate file name is "?readme?") - command expands to ~ - :e # :e ?readme? - :e `ls #` :e {files matching "?readme?"} - :e #.* :e {files matching "?readme?.*"} - :cd :cd {file name under cursor} - :cd * :cd {file name under cursor plus "*" and then expanded} - -When the expanded argument contains a "!" and it is used for a shell command -(":!cmd", ":r !cmd" or ":w !cmd"), the "!" is escaped with a backslash to -avoid it being expanded into a previously used command. When the 'shell' -option contains "sh", this is done twice, to avoid the shell trying to expand -the "!". - - *filename-backslash* -For filesystems that use a backslash as directory separator (MS-DOS, Windows, -OS/2), it's a bit difficult to recognize a backslash that is used to escape -the special meaning of the next character. The general rule is: If the -backslash is followed by a normal file name character, it does not have a -special meaning. Therefore "\file\foo" is a valid file name, you don't have -to type the backslash twice. - -An exception is the '$' sign. It is a valid character in a file name. But -to avoid a file name like "$home" to be interpreted as an environment variable, -it needs to be preceded by a backslash. Therefore you need to use "/\$home" -for the file "$home" in the root directory. A few examples: - - FILE NAME INTERPRETED AS ~ - $home expanded to value of environment var $home - \$home file "$home" in current directory - /\$home file "$home" in root directory - \\$home file "\\", followed by expanded $home - -============================================================================== -6. Command-line window *cmdline-window* *cmdwin* - -In the command-line window the command line can be edited just like editing -text in any window. It is a special kind of window, because you cannot leave -it in a normal way. -{not available when compiled without the |+cmdline_hist| or |+vertsplit| -feature} - - -OPEN - -There are two ways to open the command-line window: -1. From Command-line mode, use the key specified with the 'cedit' option. - The default is CTRL-F when 'compatible' is not set. -2. From Normal mode, use the "q:", "q/" or "q?" command. *q:* *q/* *q?* - This starts editing an Ex command-line ("q:") or search string ("q/" or - "q?"). Note that this is not possible while recording is in progress (the - "q" stops recording then). - -When the window opens it is filled with the command-line history. The last -line contains the command as typed so far. The left column will show a -character that indicates the type of command-line being edited, see -|cmdwin-char|. - -Vim will be in Normal mode when the editor is opened, except when 'insertmode' -is set. - -The height of the window is specified with 'cmdwinheight' (or smaller if there -is no room). The window is always full width and is positioned just above the -command-line. - - -EDIT - -You can now use commands to move around and edit the text in the window. Both -in Normal mode and Insert mode. - -It is possible to use ":", "/" and other commands that use the command-line, -but it's not possible to open another command-line window then. There is no -nesting. - *E11* -The command-line window is not a normal window. It is not possible to move to -another window or edit another buffer. All commands that would do this are -disabled in the command-line window. Of course it _is_ possible to execute -any command that you entered in the command-line window. - - -CLOSE *E199* - -There are several ways to leave the command-line window: - - Execute the command-line under the cursor. Works both in - Insert and in Normal mode. -CTRL-C Continue in Command-line mode. The command-line under the - cursor is used as the command-line. Works both in Insert and - in Normal mode. ":close" also works. There is no redraw, - thus the window will remain visible. -:quit Discard the command line and go back to Normal mode. - ":exit", ":xit" and CTRL-\ CTRL-N also work. -:qall Quit Vim, unless there are changes in some buffer. -:qall! Quit Vim, discarding changes to any buffer. - -Once the command-line window is closed the old window sizes are restored. The -executed command applies to the window and buffer where the command-line was -started from. This works as if the command-line window was not there, except -that there will be an extra screen redraw. -The buffer used for the command-line window is deleted. Any changes to lines -other than the one that is executed with are lost. - -If you would like to execute the command under the cursor and then have the -command-line window open again, you may find this mapping useful: > - - :autocmd CmdwinEnter * map q: - - -VARIOUS - -The command-line window cannot be used: -- when there already is a command-line window (no nesting) -- for entering a encryption key or when using inputsecret() -- when Vim was not compiled with the +vertsplit feature - -Some options are set when the command-line window is opened: -'filetype' "vim", when editing an Ex command-line; this starts Vim syntax - highlighting if it was enabled -'rightleft' off -'modifiable' on -'buftype' "nofile" -'swapfile' off - -It is allowed to write the buffer contents to a file. This is an easy way to -save the command-line history and read it back later. - -If the 'wildchar' option is set to , and the command-line window is used -for an Ex command, then two mappings will be added to use for completion -in the command-line window, like this: > - :imap - :nmap a -Note that hitting in Normal mode will do completion on the next -character. That way it works at the end of the line. -If you don't want these mappings, disable them with: > - au CmdwinEnter [:>] iunmap - au CmdwinEnter [:>] nunmap -You could put these lines in your vimrc file. - -While in the command-line window you cannot use the mouse to put the cursor in -another window, or drag statuslines of other windows. You can drag the -statusline of the command-line window itself and the statusline above it. -Thus you can resize the command-line window, but not others. - - -AUTOCOMMANDS - -Two autocommand events are used: |CmdwinEnter| and |CmdwinLeave|. Since this -window is of a special type, the WinEnter, WinLeave, BufEnter and BufLeave -events are not triggered. You can use the Cmdwin events to do settings -specifically for the command-line window. Be careful not to cause side -effects! -Example: > - :au CmdwinEnter : let b:cpt_save = &cpt | set cpt=. - :au CmdwinLeave : let &cpt = b:cpt_save -This sets 'complete' to use completion in the current window for |i_CTRL-N|. -Another example: > - :au CmdwinEnter [/?] startinsert -This will make Vim start in Insert mode in the command-line window. - - *cmdwin-char* -The character used for the pattern indicates the type of command-line: - : normal Ex command - > debug mode command |debug-mode| - / forward search string - ? backward search string - = expression for "= |expr-register| - @ string for |input()| - - text for |:insert| or |:append| - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/debug.txt b/share/vim/vim72/doc/debug.txt deleted file mode 100644 index 44c9f9f1a7..0000000000 --- a/share/vim/vim72/doc/debug.txt +++ /dev/null @@ -1,151 +0,0 @@ -*debug.txt* For Vim version 7.2. Last change: 2006 May 01 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Debugging Vim *debug-vim* - -This is for debugging Vim itself, when it doesn't work properly. -For debugging Vim scripts, functions, etc. see |debug-scripts| - -1. Location of a crash, using gcc and gdb |debug-gcc| -2. Windows Bug Reporting |debug-win32| - -============================================================================== - -1. Location of a crash, using gcc and gdb *debug-gcc* - -When Vim crashes in one of the test files, and you are using gcc for -compilation, here is what you can do to find out exactly where Vim crashes. -This also applies when using the MingW tools. - -1. Compile Vim with the "-g" option (there is a line in the Makefile for this, - which you can uncomment). - -2. Execute these commands (replace "11" with the test that fails): > - cd testdir - gdb ../vim - run -u unix.vim -U NONE -s dotest.in test11.in - -3. Check where Vim crashes, gdb should give a message for this. - -4. Get a stack trace from gdb with this command: > - where -< You can check out different places in the stack trace with: > - frame 3 -< Replace "3" with one of the numbers in the stack trace. - -============================================================================== - -2. Windows Bug Reporting *debug-win32* - -If the Windows version of Vim crashes in a reproducible manner, you can take -some steps to provide a useful bug report. - - -GENERIC ~ - -You must obtain the debugger symbols (PDB) file for your executable: gvim.pdb -for gvim.exe, or vim.pdb for vim.exe. The PDB should be available from the -same place that you obtained the executable. Be sure to use the PDB that -matches the EXE (same date). - -If you built the executable yourself with the Microsoft Visual C++ compiler, -then the PDB was built with the EXE. - -Alternatively, if you have the source files, you can import Make_ivc.mak into -Visual Studio as a workspace. Then select a debug configuration, build and -you can do all kinds of debugging (set breakpoints, watch variables, etc.). - -If you have Visual Studio, use that instead of the VC Toolkit and WinDbg. - -For other compilers, you should always use the corresponding debugger: TD for -a Vim executable compiled with the Borland compiler; gdb (see above -|debug-gcc|) for the Cygwin and MinGW compilers. - - - *debug-vs2005* -2.2 Debugging Vim crashes with Visual Studio 2005/Visual C++ 2005 Express ~ - -First launch vim.exe or gvim.exe and then launch Visual Studio. (If you don't -have Visual Studio, follow the instructions at |get-ms-debuggers| to obtain a -free copy of Visual C++ 2005 Express Edition.) - -On the Tools menu, click Attach to Process. Choose the Vim process. - -In Vim, reproduce the crash. A dialog will appear in Visual Studio, telling -you about the unhandled exception in the Vim process. Click Break to break -into the process. - -Visual Studio will pop up another dialog, telling you that no symbols are -loaded and that the source code cannot be displayed. Click OK. - -Several windows will open. Right-click in the Call Stack window. Choose Load -Symbols. The Find Symbols dialog will open, looking for (g)vim.pdb. Navigate -to the directory where you have the PDB file and click Open. - -At this point, you should have a full call stack with vim function names and -line numbers. Double-click one of the lines and the Find Source dialog will -appear. Navigate to the directory where the Vim source is (if you have it.) - -If you don't know how to debug this any further, follow the instructions -at ":help bug-reports". Paste the call stack into the bug report. - -If you have a non-free version of Visual Studio, you can save a minidump via -the Debug menu and send it with the bug report. A minidump is a small file -(<100KB), which contains information about the state of your process. -Visual C++ 2005 Express Edition cannot save minidumps and it cannot be -installed as a just-in-time debugger. Use WinDbg, |debug-windbg|, if you -need to save minidumps or you want a just-in-time (postmortem) debugger. - - *debug-windbg* -2.3 Debugging Vim crashes with WinDbg ~ - -See |get-ms-debuggers| to obtain a copy of WinDbg. - -As with the Visual Studio IDE, you can attach WinDbg to a running Vim process. -You can also have your system automatically invoke WinDbg as a postmortem -debugger. To set WinDbg as your postmortem debugger, run "windbg -I". - -To attach WinDbg to a running Vim process, launch WinDbg. On the File menu, -choose Attach to a Process. Select the Vim process and click OK. - -At this point, choose Symbol File Path on the File menu, and add the folder -containing your Vim PDB to the sympath. If you have Vim source available, -use Source File Path on the File menu. You can now open source files in WinDbg -and set breakpoints, if you like. Reproduce your crash. WinDbg should open the -source file at the point of the crash. Using the View menu, you can examine -the call stack, local variables, watch windows, and so on. - -If WinDbg is your postmortem debugger, you do not need to attach WinDbg to -your Vim process. Simply reproduce the crash and WinDbg will launch -automatically. As above, set the Symbol File Path and the Source File Path. - -To save a minidump, type the following at the WinDbg command line: > - .dump vim.dmp -< - *debug-minidump* -2.4 Opening a Minidump ~ - -If you have a minidump file, you can open it in Visual Studio or in WinDbg. - -In Visual Studio 2005: on the File menu, choose Open, then Project/Solution. -Navigate to the .dmp file and open it. Now press F5 to invoke the debugger. -Follow the instructions in |debug-vs2005| to set the Symbol File Path. - -In WinDbg: choose Open Crash Dump on the File menu. Follow the instructions in -|debug-windbg| to set the Symbol File Path. - - *get-ms-debuggers* -2.5 Obtaining Microsoft Debugging Tools ~ - -The Debugging Tools for Windows (including WinDbg) can be downloaded from - http://www.microsoft.com/whdc/devtools/debugging/default.mspx -This includes the WinDbg debugger. - -Visual C++ 2005 Express Edition can be downloaded for free from: - http://msdn.microsoft.com/vstudio/express/visualC/default.aspx - -========================================================================= - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/debugger.txt b/share/vim/vim72/doc/debugger.txt deleted file mode 100644 index 3b599ade17..0000000000 --- a/share/vim/vim72/doc/debugger.txt +++ /dev/null @@ -1,140 +0,0 @@ -*debugger.txt* For Vim version 7.2. Last change: 2005 Mar 29 - - - VIM REFERENCE MANUAL by Gordon Prieur - - -Debugger Support Features *debugger-support* - -1. Debugger Features |debugger-features| -2. Vim Compile Options |debugger-compilation| -3. Integrated Debuggers |debugger-integration| - -{Vi does not have any of these features} - -============================================================================== -1. Debugger Features *debugger-features* - -The following features are available for an integration with a debugger or -an Integrated Programming Environment (IPE) or Integrated Development -Environment (IDE): - - Alternate Command Input |alt-input| - Debug Signs |debug-signs| - Debug Source Highlight |debug-highlight| - Message Footer |gui-footer| - Balloon Evaluation |balloon-eval| - -These features were added specifically for use in the Motif version of gvim. -However, the |alt-input| and |debug-highlight| were written to be usable in -both vim and gvim. Some of the other features could be used in the non-GUI -vim with slight modifications. However, I did not do this nor did I test the -reliability of building for vim or non Motif GUI versions. - - -1.1 Alternate Command Input *alt-input* - -For Vim to work with a debugger there must be at least an input connection -with a debugger or external tool. In many cases there will also be an output -connection but this isn't absolutely necessary. - -The purpose of the input connection is to let the external debugger send -commands to Vim. The commands sent by the debugger should give the debugger -enough control to display the current debug environment and state. - -The current implementation is based on the X Toolkit dispatch loop and the -XtAddInput() function call. - - -1.2 Debug Signs *debug-signs* - -Many debuggers mark specific lines by placing a small sign or color highlight -on the line. The |:sign| command lets the debugger set this graphic mark. Some -examples where this feature would be used would be a debugger showing an arrow -representing the Program Counter (PC) of the program being debugged. Another -example would be a small stop sign for a line with a breakpoint. These visible -highlights let the user keep track of certain parts of the state of the -debugger. - -This feature can be used with more than debuggers, too. An IPE can use a sign -to highlight build errors, searched text, or other things. The sign feature -can also work together with the |debug-highlight| to ensure the mark is -highly visible. - -Debug signs are defined and placed using the |:sign| command. - - -1.3 Debug Source Highlight *debug-highlight* - -This feature allows a line to have a predominant highlight. The highlight is -intended to make a specific line stand out. The highlight could be made to -work for both vim and gvim, whereas the debug sign is, in most cases, limited -to gvim. The one exception to this is Sun Microsystem's dtterm. The dtterm -from Sun has a "sign gutter" for showing signs. - - -1.4 Message Footer *gui-footer* - -The message footer can be used to display messages from a debugger or IPE. It -can also be used to display menu and toolbar tips. The footer area is at the -bottom of the GUI window, below the line used to display colon commands. - -The display of the footer is controlled by the 'guioptions' letter 'F'. - - -1.5 Balloon Evaluation *balloon-eval* - -This feature allows a debugger, or other external tool, to display dynamic -information based on where the mouse is pointing. The purpose of this feature -was to allow Sun's Visual WorkShop debugger to display expression evaluations. -However, the feature was implemented in as general a manner as possible and -could be used for displaying other information as well. - -The Balloon Evaluation has some settable parameters too. For Motif the font -list and colors can be set via X resources (XmNballoonEvalFontList, -XmNballoonEvalBackground, and XmNballoonEvalForeground). -The 'balloondelay' option sets the delay before an attempt is made to show a -balloon. -The 'ballooneval' option needs to be set to switch it on. - -Balloon evaluation is only available when compiled with the |+balloon_eval| -feature. - -The Balloon evaluation functions are also used to show a tooltip for the -toolbar. The 'ballooneval' option does not need to be set for this. But the -other settings apply. - -Another way to use the balloon is with the 'balloonexpr' option. This is -completely user definable. - -============================================================================== -2. Vim Compile Options *debugger-compilation* - -The debugger features were added explicitly for use with Sun's Visual -WorkShop Integrated Programming Environment (ipe). However, they were done -in as generic a manner as possible so that integration with other debuggers -could also use some or all of the tools used with Sun's ipe. - -The following compile time preprocessor variables control the features: - - Alternate Command Input ALT_X_INPUT - Debug Glyphs FEAT_SIGNS - Debug Highlights FEAT_SIGNS - Message Footer FEAT_FOOTER - Balloon Evaluation FEAT_BEVAL - -The first integration with a full IPE/IDE was with Sun Visual WorkShop. To -compile a gvim which interfaces with VWS set the following flag, which sets -all the above flags: - - Sun Visual WorkShop FEAT_SUN_WORKSHOP - -============================================================================== -3. Integrated Debuggers *debugger-integration* - -One fully integrated debugger/IPE/IDE is Sun's Visual WorkShop Integrated -Programming Environment. - -For Sun NetBeans support see |netbeans|. - - vim:tw=78:sw=4:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/develop.txt b/share/vim/vim72/doc/develop.txt deleted file mode 100644 index 89cb455e0c..0000000000 --- a/share/vim/vim72/doc/develop.txt +++ /dev/null @@ -1,490 +0,0 @@ -*develop.txt* For Vim version 7.2. Last change: 2007 May 11 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Development of Vim. *development* - -This text is important for those who want to be involved in further developing -Vim. - -1. Design goals |design-goals| -2. Coding style |coding-style| -3. Design decisions |design-decisions| -4. Assumptions |design-assumptions| - -See the file README.txt in the "src" directory for an overview of the source -code. - -Vim is open source software. Everybody is encouraged to contribute to help -improving Vim. For sending patches a context diff "diff -c" is preferred. -Also see http://www.vim.org/tips/tip.php?tip_id=618. - -============================================================================== -1. Design goals *design-goals* - -Most important things come first (roughly). - -Note that quite a few items are contradicting. This is intentional. A -balance must be found between them. - - -VIM IS... VI COMPATIBLE *design-compatible* - -First of all, it should be possible to use Vim as a drop-in replacement for -Vi. When the user wants to, he can use Vim in compatible mode and hardly -notice any difference with the original Vi. - -Exceptions: -- We don't reproduce obvious Vi bugs in Vim. -- There are different versions of Vi. I am using Version 3.7 (6/7/85) as a - reference. But support for other versions is also included when possible. - The Vi part of POSIX is not considered a definitive source. -- Vim adds new commands, you cannot rely on some command to fail because it - didn't exist in Vi. -- Vim will have a lot of features that Vi doesn't have. Going back from Vim - to Vi will be a problem, this cannot be avoided. -- Some things are hardly ever used (open mode, sending an e-mail when - crashing, etc.). Those will only be included when someone has a good reason - why it should be included and it's not too much work. -- For some items it is debatable whether Vi compatibility should be - maintained. There will be an option flag for these. - - -VIM IS... IMPROVED *design-improved* - -The IMproved bits of Vim should make it a better Vi, without becoming a -completely different editor. Extensions are done with a "Vi spirit". -- Use the keyboard as much as feasible. The mouse requires a third hand, - which we don't have. Many terminals don't have a mouse. -- When the mouse is used anyway, avoid the need to switch back to the - keyboard. Avoid mixing mouse and keyboard handling. -- Add commands and options in a consistent way. Otherwise people will have a - hard time finding and remembering them. Keep in mind that more commands and - options will be added later. -- A feature that people do not know about is a useless feature. Don't add - obscure features, or at least add hints in documentation that they exists. -- Minimize using CTRL and other modifiers, they are more difficult to type. -- There are many first-time and inexperienced Vim users. Make it easy for - them to start using Vim and learn more over time. -- There is no limit to the features that can be added. Selecting new features - is one based on (1) what users ask for, (2) how much effort it takes to - implement and (3) someone actually implementing it. - - -VIM IS... MULTI PLATFORM *design-multi-platform* - -Vim tries to help as many users on as many platforms as possible. -- Support many kinds of terminals. The minimal demands are cursor positioning - and clear-screen. Commands should only use key strokes that most keyboards - have. Support all the keys on the keyboard for mapping. -- Support many platforms. A condition is that there is someone willing to do - Vim development on that platform, and it doesn't mean messing up the code. -- Support many compilers and libraries. Not everybody is able or allowed to - install another compiler or GUI library. -- People switch from one platform to another, and from GUI to terminal - version. Features should be present in all versions, or at least in as many - as possible with a reasonable effort. Try to avoid that users must switch - between platforms to accomplish their work efficiently. -- That a feature is not possible on some platforms, or only possible on one - platform, does not mean it cannot be implemented. [This intentionally - contradicts the previous item, these two must be balanced.] - - -VIM IS... WELL DOCUMENTED *design-documented* - -- A feature that isn't documented is a useless feature. A patch for a new - feature must include the documentation. -- Documentation should be comprehensive and understandable. Using examples is - recommended. -- Don't make the text unnecessarily long. Less documentation means that an - item is easier to find. - - -VIM IS... HIGH SPEED AND SMALL IN SIZE *design-speed-size* - -Using Vim must not be a big attack on system resources. Keep it small and -fast. -- Computers are becoming faster and bigger each year. Vim can grow too, but - no faster than computers are growing. Keep Vim usable on older systems. -- Many users start Vim from a shell very often. Startup time must be short. -- Commands must work efficiently. The time they consume must be as small as - possible. Useful commands may take longer. -- Don't forget that some people use Vim over a slow connection. Minimize the - communication overhead. -- Items that add considerably to the size and are not used by many people - should be a feature that can be disabled. -- Vim is a component among other components. Don't turn it into a massive - application, but have it work well together with other programs. - - -VIM IS... MAINTAINABLE *design-maintain* - -- The source code should not become a mess. It should be reliable code. -- Use the same layout in all files to make it easy to read |coding-style|. -- Use comments in a useful way! Quoting the function name and argument names - is NOT useful. Do explain what they are for. -- Porting to another platform should be made easy, without having to change - too much platform-independent code. -- Use the object-oriented spirit: Put data and code together. Minimize the - knowledge spread to other parts of the code. - - -VIM IS... FLEXIBLE *design-flexible* - -Vim should make it easy for users to work in their preferred styles rather -than coercing its users into particular patterns of work. This can be for -items with a large impact (e.g., the 'compatible' option) or for details. The -defaults are carefully chosen such that most users will enjoy using Vim as it -is. Commands and options can be used to adjust Vim to the desire of the user -and its environment. - - -VIM IS... NOT *design-not* - -- Vim is not a shell or an Operating System. You will not be able to run a - shell inside Vim or use it to control a debugger. This should work the - other way around: Use Vim as a component from a shell or in an IDE. - A satirical way to say this: "Unlike Emacs, Vim does not attempt to include - everything but the kitchen sink, but some people say that you can clean one - with it. ;-)" - To use Vim with gdb see: http://www.agide.org and http://clewn.sf.net. -- Vim is not a fancy GUI editor that tries to look nice at the cost of - being less consistent over all platforms. But functional GUI features are - welcomed. - -============================================================================== -2. Coding style *coding-style* - -These are the rules to use when making changes to the Vim source code. Please -stick to these rules, to keep the sources readable and maintainable. - -This list is not complete. Look in the source code for more examples. - - -MAKING CHANGES *style-changes* - -The basic steps to make changes to the code: -1. Adjust the documentation. Doing this first gives you an impression of how - your changes affect the user. -2. Make the source code changes. -3. Check ../doc/todo.txt if the change affects any listed item. -4. Make a patch with "diff -c" against the unmodified code and docs. -5. Make a note about what changed and include it with the patch. - - -USE OF COMMON FUNCTIONS *style-functions* - -Some functions that are common to use, have a special Vim version. Always -consider using the Vim version, because they were introduced with a reason. - -NORMAL NAME VIM NAME DIFFERENCE OF VIM VERSION -free() vim_free() Checks for freeing NULL -malloc() alloc() Checks for out of memory situation -malloc() lalloc() Like alloc(), but has long argument -strcpy() STRCPY() Includes cast to (char *), for char_u * args -strchr() vim_strchr() Accepts special characters -strrchr() vim_strrchr() Accepts special characters -isspace() vim_isspace() Can handle characters > 128 -iswhite() vim_iswhite() Only TRUE for tab and space -memcpy() mch_memmove() Handles overlapped copies -bcopy() mch_memmove() Handles overlapped copies -memset() vim_memset() Uniform for all systems - - -NAMES *style-names* - -Function names can not be more than 31 characters long (because of VMS). - -Don't use "delete" as a variable name, C++ doesn't like it. - -Because of the requirement that Vim runs on as many systems as possible, we -need to avoid using names that are already defined by the system. This is a -list of names that are known to cause trouble. The name is given as a regexp -pattern. - -is.*() POSIX, ctype.h -to.*() POSIX, ctype.h - -d_.* POSIX, dirent.h -l_.* POSIX, fcntl.h -gr_.* POSIX, grp.h -pw_.* POSIX, pwd.h -sa_.* POSIX, signal.h -mem.* POSIX, string.h -str.* POSIX, string.h -wcs.* POSIX, string.h -st_.* POSIX, stat.h -tms_.* POSIX, times.h -tm_.* POSIX, time.h -c_.* POSIX, termios.h -MAX.* POSIX, limits.h -__.* POSIX, system -_[A-Z].* POSIX, system -E[A-Z0-9]* POSIX, errno.h - -.*_t POSIX, for typedefs. Use .*_T instead. - -wait don't use as argument to a function, conflicts with types.h -index shadows global declaration -time shadows global declaration -new C++ reserved keyword -try Borland C++ doesn't like it to be used as a variable. - -basename() GNU string function -dirname() GNU string function -get_env_value() Linux system function - - -VARIOUS *style-various* - -Typedef'ed names should end in "_T": > - typedef int some_T; -Define'ed names should be uppercase: > - #define SOME_THING -Features always start with "FEAT_": > - #define FEAT_FOO - -Don't use '\"', some compilers can't handle it. '"' works fine. - -Don't use: - #if HAVE_SOME -Some compilers can't handle that and complain that "HAVE_SOME" is not defined. -Use - #ifdef HAVE_SOME -or - #if defined(HAVE_SOME) - - -STYLE *style-examples* - -General rule: One statement per line. - -Wrong: if (cond) a = 1; - -OK: if (cond) - a = 1; - -Wrong: while (cond); - -OK: while (cond) - ; - -Wrong: do a = 1; while (cond); - -OK: do - a = 1; - while (cond); - - -Functions start with: - -Wrong: int function_name(int arg1, int arg2) - -OK: /* - * Explanation of what this function is used for. - * - * Return value explanation. - */ - int - function_name(arg1, arg2) - int arg1; /* short comment about arg1 */ - int arg2; /* short comment about arg2 */ - { - int local; /* comment about local */ - - local = arg1 * arg2; - -NOTE: Don't use ANSI style function declarations. A few people still have to -use a compiler that doesn't support it. - - -SPACES AND PUNCTUATION *style-spaces* - -No space between a function name and the bracket: - -Wrong: func (arg); -OK: func(arg); - -Do use a space after if, while, switch, etc. - -Wrong: if(arg) for(;;) -OK: if (arg) for (;;) - -Use a space after a comma and semicolon: - -Wrong: func(arg1,arg2); for (i = 0;i < 2;++i) -OK: func(arg1, arg2); for (i = 0; i < 2; ++i) - -Use a space before and after '=', '+', '/', etc. - -Wrong: var=a*5; -OK: var = a * 5; - -In general: Use empty lines to group lines of code together. Put a comment -just above the group of lines. This makes it more easy to quickly see what is -being done. - -OK: /* Prepare for building the table. */ - get_first_item(); - table_idx = 0; - - /* Build the table */ - while (has_item()) - table[table_idx++] = next_item(); - - /* Finish up. */ - cleanup_items(); - generate_hash(table); - -============================================================================== -3. Design decisions *design-decisions* - -Folding - -Several forms of folding should be possible for the same buffer. For example, -have one window that shows the text with function bodies folded, another -window that shows a function body. - -Folding is a way to display the text. It should not change the text itself. -Therefore the folding has been implemented as a filter between the text stored -in a buffer (buffer lines) and the text displayed in a window (logical lines). - - -Naming the window - -The word "window" is commonly used for several things: A window on the screen, -the xterm window, a window inside Vim to view a buffer. -To avoid confusion, other items that are sometimes called window have been -given another name. Here is an overview of the related items: - -screen The whole display. For the GUI it's something like 1024x768 - pixels. The Vim shell can use the whole screen or part of it. -shell The Vim application. This can cover the whole screen (e.g., - when running in a console) or part of it (xterm or GUI). -window View on a buffer. There can be several windows in Vim, - together with the command line, menubar, toolbar, etc. they - fit in the shell. - - -Spell checking *develop-spell* - -When spell checking was going to be added to Vim a survey was done over the -available spell checking libraries and programs. Unfortunately, the result -was that none of them provided sufficient capabilities to be used as the spell -checking engine in Vim, for various reasons: - -- Missing support for multi-byte encodings. At least UTF-8 must be supported, - so that more than one language can be used in the same file. - Doing on-the-fly conversion is not always possible (would require iconv - support). -- For the programs and libraries: Using them as-is would require installing - them separately from Vim. That's mostly not impossible, but a drawback. -- Performance: A few tests showed that it's possible to check spelling on the - fly (while redrawing), just like syntax highlighting. But the mechanisms - used by other code are much slower. Myspell uses a hashtable, for example. - The affix compression that most spell checkers use makes it slower too. -- For using an external program like aspell a communication mechanism would - have to be setup. That's complicated to do in a portable way (Unix-only - would be relatively simple, but that's not good enough). And performance - will become a problem (lots of process switching involved). -- Missing support for words with non-word characters, such as "Etten-Leur" and - "et al.", would require marking the pieces of them OK, lowering the - reliability. -- Missing support for regions or dialects. Makes it difficult to accept - all English words and highlight non-Canadian words differently. -- Missing support for rare words. Many words are correct but hardly ever used - and could be a misspelled often-used word. -- For making suggestions the speed is less important and requiring to install - another program or library would be acceptable. But the word lists probably - differ, the suggestions may be wrong words. - - -Spelling suggestions *develop-spell-suggestions* - -For making suggestions there are two basic mechanisms: -1. Try changing the bad word a little bit and check for a match with a good - word. Or go through the list of good words, change them a little bit and - check for a match with the bad word. The changes are deleting a character, - inserting a character, swapping two characters, etc. -2. Perform soundfolding on both the bad word and the good words and then find - matches, possibly with a few changes like with the first mechanism. - -The first is good for finding typing mistakes. After experimenting with -hashtables and looking at solutions from other spell checkers the conclusion -was that a trie (a kind of tree structure) is ideal for this. Both for -reducing memory use and being able to try sensible changes. For example, when -inserting a character only characters that lead to good words need to be -tried. Other mechanisms (with hashtables) need to try all possible letters at -every position in the word. Also, a hashtable has the requirement that word -boundaries are identified separately, while a trie does not require this. -That makes the mechanism a lot simpler. - -Soundfolding is useful when someone knows how the words sounds but doesn't -know how it is spelled. For example, the word "dictionary" might be written -as "daktonerie". The number of changes that the first method would need to -try is very big, it's hard to find the good word that way. After soundfolding -the words become "tktnr" and "tkxnry", these differ by only two letters. - -To find words by their soundfolded equivalent (soundalike word) we need a list -of all soundfolded words. A few experiments have been done to find out what -the best method is. Alternatives: -1. Do the sound folding on the fly when looking for suggestions. This means - walking through the trie of good words, soundfolding each word and - checking how different it is from the bad word. This is very efficient for - memory use, but takes a long time. On a fast PC it takes a couple of - seconds for English, which can be acceptable for interactive use. But for - some languages it takes more than ten seconds (e.g., German, Catalan), - which is unacceptable slow. For batch processing (automatic corrections) - it's too slow for all languages. -2. Use a trie for the soundfolded words, so that searching can be done just - like how it works without soundfolding. This requires remembering a list - of good words for each soundfolded word. This makes finding matches very - fast but requires quite a lot of memory, in the order of 1 to 10 Mbyte. - For some languages more than the original word list. -3. Like the second alternative, but reduce the amount of memory by using affix - compression and store only the soundfolded basic word. This is what Aspell - does. Disadvantage is that affixes need to be stripped from the bad word - before soundfolding it, which means that mistakes at the start and/or end - of the word will cause the mechanism to fail. Also, this becomes slow when - the bad word is quite different from the good word. - -The choice made is to use the second mechanism and use a separate file. This -way a user with sufficient memory can get very good suggestions while a user -who is short of memory or just wants the spell checking and no suggestions -doesn't use so much memory. - - -Word frequency - -For sorting suggestions it helps to know which words are common. In theory we -could store a word frequency with the word in the dictionary. However, this -requires storing a count per word. That degrades word tree compression a lot. -And maintaining the word frequency for all languages will be a heavy task. -Also, it would be nice to prefer words that are already in the text. This way -the words that appear in the specific text are preferred for suggestions. - -What has been implemented is to count words that have been seen during -displaying. A hashtable is used to quickly find the word count. The count is -initialized from words listed in COMMON items in the affix file, so that it -also works when starting a new file. - -This isn't ideal, because the longer Vim is running the higher the counts -become. But in practice it is a noticeable improvement over not using the word -count. - -============================================================================== -4. Assumptions *design-assumptions* - -Size of variables: -char 8 bit signed -char_u 8 bit unsigned -int 32 or 64 bit signed (16 might be possible with limited features) -unsigned 32 or 64 bit unsigned (16 as with ints) -long 32 or 64 bit signed, can hold a pointer - -Note that some compilers cannot handle long lines or strings. The C89 -standard specifies a limit of 509 characters. - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/diff.txt b/share/vim/vim72/doc/diff.txt deleted file mode 100644 index 3f55c30b69..0000000000 --- a/share/vim/vim72/doc/diff.txt +++ /dev/null @@ -1,407 +0,0 @@ -*diff.txt* For Vim version 7.2. Last change: 2008 Jul 21 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - - *diff* *vimdiff* *gvimdiff* *diff-mode* -This file describes the +diff feature: Showing differences between two, -three or four versions of the same file. - -The basics are explained in section |08.7| of the user manual. - -1. Starting diff mode |vimdiff| -2. Viewing diffs |view-diffs| -3. Jumping to diffs |jumpto-diffs| -4. Copying diffs |copy-diffs| -5. Diff options |diff-options| - -{not in Vi} - -============================================================================== -1. Starting diff mode - -The easiest way to start editing in diff mode is with the "vimdiff" command. -This starts Vim as usual, and additionally sets up for viewing the differences -between the arguments. > - - vimdiff file1 file2 [file3 [file4]] - -This is equivalent to: > - - vim -d file1 file2 [file3 [file4]] - -You may also use "gvimdiff" or "vim -d -g". The GUI is started then. -You may also use "viewdiff" or "gviewdiff". Vim starts in readonly mode then. -"r" may be prepended for restricted mode (see |-Z|). - -The second and following arguments may also be a directory name. Vim will -then append the file name of the first argument to the directory name to find -the file. - -This only works when a standard "diff" command is available. See 'diffexpr'. - -Diffs are local to the current tab page |tab-page|. You can't see diffs with -a window in another tab page. This does make it possible to have several -diffs at the same time, each in their own tab page. - -What happens is that Vim opens a window for each of the files. This is like -using the |-O| argument. This uses vertical splits. If you prefer horizontal -splits add the |-o| argument: > - - vimdiff -o file1 file2 [file3 [file4]] - -If you always prefer horizontal splits include "horizontal" in 'diffopt'. - -In each of the edited files these options are set: - - 'diff' on - 'scrollbind' on - 'scrollopt' includes "hor" - 'wrap' off - 'foldmethod' "diff" - 'foldcolumn' value from 'diffopt', default is 2 - -These options are set local to the window. When editing another file they are -reset to the global value. - -The differences shown are actually the differences in the buffer. Thus if you -make changes after loading a file, these will be included in the displayed -diffs. You might have to do ":diffupdate" now and then, not all changes are -immediately taken into account. - -In your .vimrc file you could do something special when Vim was started in -diff mode. You could use a construct like this: > - - if &diff - setup for diff mode - else - setup for non-diff mode - endif - -While already in Vim you can start diff mode in three ways. - - *E98* -:diffsplit {filename} *:diffs* *:diffsplit* - Open a new window on the file {filename}. The options are set - as for "vimdiff" for the current and the newly opened window. - Also see 'diffexpr'. - - *:difft* *:diffthis* -:diffthis Make the current window part of the diff windows. This sets - the options like for "vimdiff". - -:diffpatch {patchfile} *:diffp* *:diffpatch* - Use the current buffer, patch it with the diff found in - {patchfile} and open a buffer on the result. The options are - set as for "vimdiff". - {patchfile} can be in any format that the "patch" program - understands or 'patchexpr' can handle. - Note that {patchfile} should only contain a diff for one file, - the current file. If {patchfile} contains diffs for other - files as well, the results are unpredictable. Vim changes - directory to /tmp to avoid files in the current directory - accidentally being patched. But it may still result in - various ".rej" files to be created. And when absolute path - names are present these files may get patched anyway. - -To make these commands use a vertical split, prepend |:vertical|. Examples: > - - :vert diffsplit main.c~ - :vert diffpatch /tmp/diff - -If you always prefer a vertical split include "vertical" in 'diffopt'. - - *E96* -There can be up to four buffers with 'diff' set. - -Since the option values are remembered with the buffer, you can edit another -file for a moment and come back to the same file and be in diff mode again. - - *:diffo* *:diffoff* -:diffoff Switch off diff mode for the current window. - -:diffoff! Switch off diff mode for all windows in the current tab page. - -The ":diffoff" command resets the relevant options to their default value. -This may be different from what the values were before diff mode was started, -the old values are not remembered. - - 'diff' off - 'scrollbind' off - 'scrollopt' without "hor" - 'wrap' on - 'foldmethod' "manual" - 'foldcolumn' 0 - -============================================================================== -2. Viewing diffs *view-diffs* - -The effect is that the diff windows show the same text, with the differences -highlighted. When scrolling the text, the 'scrollbind' option will make the -text in other windows to be scrolled as well. With vertical splits the text -should be aligned properly. - -The alignment of text will go wrong when: -- 'wrap' is on, some lines will be wrapped and occupy two or more screen - lines -- folds are open in one window but not another -- 'scrollbind' is off -- changes have been made to the text -- "filler" is not present in 'diffopt', deleted/inserted lines makes the - alignment go wrong - -All the buffers edited in a window where the 'diff' option is set will join in -the diff. This is also possible for hidden buffers. They must have been -edited in a window first for this to be possible. - - *:DiffOrig* *diff-original-file* -Since 'diff' is a window-local option, it's possible to view the same buffer -in diff mode in one window and "normal" in another window. It is also -possible to view the changes you have made to a buffer since the file was -loaded. Since Vim doesn't allow having two buffers for the same file, you -need another buffer. This command is useful: > - command DiffOrig vert new | set bt=nofile | r # | 0d_ | diffthis - \ | wincmd p | diffthis -(this is in |vimrc_example.vim|). Use ":DiffOrig" to see the differences -between the current buffer and the file it was loaded from. - -A buffer that is unloaded cannot be used for the diff. But it does work for -hidden buffers. You can use ":hide" to close a window without unloading the -buffer. If you don't want a buffer to remain used for the diff do ":set -nodiff" before hiding it. - - *:diffu* *:diffupdate* -:diffu[pdate] Update the diff highlighting and folds. - -Vim attempts to keep the differences updated when you make changes to the -text. This mostly takes care of inserted and deleted lines. Changes within a -line and more complicated changes do not cause the differences to be updated. -To force the differences to be updated use: > - - :diffupdate - - -Vim will show filler lines for lines that are missing in one window but are -present in another. These lines were inserted in another file or deleted in -this file. Removing "filler" from the 'diffopt' option will make Vim not -display these filler lines. - - -Folds are used to hide the text that wasn't changed. See |folding| for all -the commands that can be used with folds. - -The context of lines above a difference that are not included in the fold can -be set with the 'diffopt' option. For example, to set the context to three -lines: > - - :set diffopt=filler,context:3 - - -The diffs are highlighted with these groups: - -|hl-DiffAdd| DiffAdd Added (inserted) lines. These lines exist in - this buffer but not in another. -|hl-DiffChange| DiffChange Changed lines. -|hl-DiffText| DiffText Changed text inside a Changed line. Vim - finds the first character that is different, - and the last character that is different - (searching from the end of the line). The - text in between is highlighted. This means - that parts in the middle that are still the - same are highlighted anyway. Only "iwhite" of - 'diffopt' is used here. -|hl-DiffDelete| DiffDelete Deleted lines. Also called filler lines, - because they don't really exist in this - buffer. - -============================================================================== -3. Jumping to diffs *jumpto-diffs* - -Two commands can be used to jump to diffs: - *[c* - [c Jump backwards to the previous start of a change. - When a count is used, do it that many times. - *]c* - ]c Jump forwards to the next start of a change. - When a count is used, do it that many times. - -It is an error if there is no change for the cursor to move to. - -============================================================================== -4. Diff copying *copy-diffs* *E99* *E100* *E101* *E102* *E103* - *merge* -There are two commands to copy text from one buffer to another. The result is -that the buffers will be equal within the specified range. - - *:diffg* *:diffget* -:[range]diffg[et] [bufspec] - Modify the current buffer to undo difference with another - buffer. If [bufspec] is given, that buffer is used. - Otherwise this only works if there is one other buffer in diff - mode. - See below for [range]. - - *:diffpu* *:diffput* *E793* -:[range]diffpu[t] [bufspec] - Modify another buffer to undo difference with the current - buffer. Just like ":diffget" but the other buffer is modified - instead of the current one. - When [bufspec] is omitted and there is more than one other - buffer in diff mode where 'modifiable' is set this fails. - See below for [range]. - - *do* -do Same as ":diffget" without argument or range. The "o" stands - for "obtain" ("dg" can't be used, it could be the start of - "dgg"!). - - *dp* -dp Same as ":diffput" without argument or range. - -When no [range] is given, the diff at the cursor position or just above it is -affected. When [range] is used, Vim tries to only put or get the specified -lines. When there are deleted lines, this may not always be possible. - -There can be deleted lines below the last line of the buffer. When the cursor -is on the last line in the buffer and there is no diff above this line, the -":diffget" and "do" commands will obtain lines from the other buffer. - -To be able to get those lines from another buffer in a [range] it's allowed to -use the last line number plus one. This command gets all diffs from the other -buffer: > - - :1,$+1diffget - -Note that deleted lines are displayed, but not counted as text lines. You -can't move the cursor into them. To fill the deleted lines with the lines -from another buffer use ":diffget" on the line below them. - *E787* -When the buffer that is about to be modified is read-only and the autocommand -that is triggered by |FileChangedRO| changes buffers the command will fail. -The autocommand must not change buffers. - -The [bufspec] argument above can be a buffer number, a pattern for a buffer -name or a part of a buffer name. Examples: - - :diffget Use the other buffer which is in diff mode - :diffget 3 Use buffer 3 - :diffget v2 Use the buffer which matches "v2" and is in - diff mode (e.g., "file.c.v2") - -============================================================================== -5. Diff options *diff-options* - -Also see |'diffopt'| and the "diff" item of |'fillchars'|. - - -FINDING THE DIFFERENCES *diff-diffexpr* - -The 'diffexpr' option can be set to use something else than the standard -"diff" program to compare two files and find the differences. - -When 'diffexpr' is empty, Vim uses this command to find the differences -between file1 and file2: > - - diff file1 file2 > outfile - -The ">" is replaced with the value of 'shellredir'. - -The output of "diff" must be a normal "ed" style diff. Do NOT use a context -diff. This example explains the format that Vim expects: > - - 1a2 - > bbb - 4d4 - < 111 - 7c7 - < GGG - --- - > ggg - -The "1a2" item appends the line "bbb". -The "4d4" item deletes the line "111". -The '7c7" item replaces the line "GGG" with "ggg". - -When 'diffexpr' is not empty, Vim evaluates to obtain a diff file in the -format mentioned. These variables are set to the file names used: - - v:fname_in original file - v:fname_new new version of the same file - v:fname_out resulting diff file - -Additionally, 'diffexpr' should take care of "icase" and "iwhite" in the -'diffopt' option. 'diffexpr' cannot change the value of 'lines' and -'columns'. - -Example (this does almost the same as 'diffexpr' being empty): > - - set diffexpr=MyDiff() - function MyDiff() - let opt = "" - if &diffopt =~ "icase" - let opt = opt . "-i " - endif - if &diffopt =~ "iwhite" - let opt = opt . "-b " - endif - silent execute "!diff -a --binary " . opt . v:fname_in . " " . v:fname_new . - \ " > " . v:fname_out - endfunction - -The "-a" argument is used to force comparing the files as text, comparing as -binaries isn't useful. The "--binary" argument makes the files read in binary -mode, so that a CTRL-Z doesn't end the text on DOS. - - *E97* -Vim will do a test if the diff output looks alright. If it doesn't, you will -get an error message. Possible causes: -- The "diff" program cannot be executed. -- The "diff" program doesn't produce normal "ed" style diffs (see above). -- The 'shell' and associated options are not set correctly. Try if filtering - works with a command like ":!sort". -- You are using 'diffexpr' and it doesn't work. -If it's not clear what the problem is set the 'verbose' option to one or more -to see more messages. - -The self-installing Vim includes a diff program. If you don't have it you -might want to download a diff.exe. For example from -http://jlb.twu.net/code/unixkit.php. - - -USING PATCHES *diff-patchexpr* - -The 'patchexpr' option can be set to use something else than the standard -"patch" program. - -When 'patchexpr' is empty, Vim will call the "patch" program like this: > - - patch -o outfile origfile < patchfile - -This should work fine with most versions of the "patch" program. Note that a -CR in the middle of a line may cause problems, it is seen as a line break. - -If the default doesn't work for you, set the 'patchexpr' to an expression that -will have the same effect. These variables are set to the file names used: - - v:fname_in original file - v:fname_diff patch file - v:fname_out resulting patched file - -Example (this does the same as 'patchexpr' being empty): > - - set patchexpr=MyPatch() - function MyPatch() - :call system("patch -o " . v:fname_out . " " . v:fname_in . - \ " < " . v:fname_diff) - endfunction - -Make sure that using the "patch" program doesn't have unwanted side effects. -For example, watch out for additionally generated files, which should be -deleted. It should just patch the file and nothing else. - Vim will change directory to "/tmp" or another temp directory before -evaluating 'patchexpr'. This hopefully avoids that files in the current -directory are accidentally patched. Vim will also delete files starting with -v:fname_in and ending in ".rej" and ".orig". - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/digraph.txt b/share/vim/vim72/doc/digraph.txt deleted file mode 100644 index 65261b72e0..0000000000 --- a/share/vim/vim72/doc/digraph.txt +++ /dev/null @@ -1,350 +0,0 @@ -*digraph.txt* For Vim version 7.2. Last change: 2008 Aug 06 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Digraphs *digraph* *digraphs* *Digraphs* - -Digraphs are used to enter characters that normally cannot be entered by -an ordinary keyboard. These are mostly printable non-ASCII characters. The -digraphs are easier to remember than the decimal number that can be entered -with CTRL-V (see |i_CTRL-V|). - -There is a brief introduction on digraphs in the user manual: |24.9| -An alternative is using the 'keymap' option. - -1. Defining digraphs |digraphs-define| -2. Using digraphs |digraphs-use| -3. Default digraphs |digraphs-default| - -{Vi does not have any of these commands} - -============================================================================== -1. Defining digraphs *digraphs-define* - - *:dig* *:digraphs* -:dig[raphs] show currently defined digraphs. - *E104* *E39* -:dig[raphs] {char1}{char2} {number} ... - Add digraph {char1}{char2} to the list. {number} is - the decimal representation of the character. Normally - it is the Unicode character, see |digraph-encoding|. - Example: > - :digr e: 235 a: 228 -< Avoid defining a digraph with '_' (underscore) as the - first character, it has a special meaning in the - future. - -Vim is normally compiled with the |+digraphs| feature. If the feature is -disabled, the ":digraph" command will display an error message. - -Example of the output of ":digraphs": > - TH Þ 222 ss ß 223 a! à 224 a' á 225 a> â 226 a? ã 227 a: ä 228 - -The first two characters in each column are the characters you have to type to -enter the digraph. - -In the middle of each column is the resulting character. This may be mangled -if you look at it on a system that does not support digraphs or if you print -this file. - - *digraph-encoding* -The decimal number normally is the Unicode number of the character. Note that -the meaning doesn't change when 'encoding' changes. The character will be -converted from Unicode to 'encoding' when needed. This does require the -conversion to be available, it might fail. For the NUL character you will see -"10". That's because NUL characters are internally represented with a NL -character. When you write the file it will become a NUL character. - -When Vim was compiled without the +multi_byte feature, you need to specify the -character in the encoding given with 'encoding'. You might want to use -something like this: > - - if has("multi_byte") - digraph oe 339 - elseif &encoding == "iso-8859-15" - digraph oe 189 - endif - -This defines the "oe" digraph for a character that is number 339 in Unicode -and 189 in latin9 (iso-8859-15). - -============================================================================== -2. Using digraphs *digraphs-use* - -There are two methods to enter digraphs: *i_digraph* - CTRL-K {char1} {char2} or - {char1} {char2} -The first is always available; the second only when the 'digraph' option is -set. - -If a digraph with {char1}{char2} does not exist, Vim searches for a digraph -{char2}{char1}. This helps when you don't remember which character comes -first. - -Note that when you enter CTRL-K {char1}, where {char1} is a special key, Vim -enters the code for that special key. This is not a digraph. - -Once you have entered the digraph, Vim treats the character like a normal -character that occupies only one character in the file and on the screen. -Example: > - 'B' 'B' will enter the broken '|' character (166) - 'a' '>' will enter an 'a' with a circumflex (226) - CTRL-K '-' '-' will enter a soft hyphen (173) - -The current digraphs are listed with the ":digraphs" command. Some of the -default ones are listed below |digraph-table|. - -For CTRL-K, there is one general digraph: CTRL-K {char} will enter -{char} with the highest bit set. You can use this to enter meta-characters. - -The character cannot be part of a digraph. When hitting , Vim -stops digraph entry and ends Insert mode or Command-line mode, just like -hitting an out of digraph context. Use CTRL-V 155 to enter meta-ESC -(CSI). - -If you accidentally typed an 'a' that should be an 'e', you will type 'a' -'e'. But that is a digraph, so you will not get what you want. To correct -this, you will have to type e again. To avoid this don't set the -'digraph' option and use CTRL-K to enter digraphs. - -You may have problems using Vim with characters which have a value above 128. -For example: You insert ue (u-umlaut) and the editor echoes \334 in Insert -mode. After leaving the Insert mode everything is fine. Note that fmt -removes all characters with a value above 128 from the text being formatted. -On some Unix systems this means you have to define the environment-variable -LC_CTYPE. If you are using csh, then put the following line in your .cshrc: > - setenv LC_CTYPE iso_8859_1 - -============================================================================== -3. Default digraphs *digraphs-default* - -Vim comes with a set of default digraphs. Check the output of ":digraphs" to -see them. - -On most systems Vim uses the same digraphs. They work for the Unicode and -ISO-8859-1 character sets. These default digraphs are taken from the RFC1345 -mnemonics. To make it easy to remember the mnemonic, the second character has -a standard meaning: - - char name char meaning ~ - Exclamation mark ! Grave - Apostrophe ' Acute accent - Greater-Than sign > Circumflex accent - Question mark ? Tilde - Hyphen-Minus - Macron - Left parenthesis ( Breve - Full stop . Dot above - Colon : Diaeresis - Comma , Cedilla - Underline _ Underline - Solidus / Stroke - Quotation mark " Double acute accent - Semicolon ; Ogonek - Less-Than sign < Caron - Zero 0 Ring above - Two 2 Hook - Nine 9 Horn - - Equals = Cyrillic - Asterisk * Greek - Percent sign % Greek/Cyrillic special - Plus + smalls: Arabic, capitals: Hebrew - Three 3 some Latin/Greek/Cyrillic letters - Four 4 Bopomofo - Five 5 Hiragana - Six 6 Katakana - -Example: a: is ä and o: is ö - -These are the RFC1345 digraphs for the one-byte characters. See the output of -":digraphs" for the others. The characters above 255 are only available when -Vim was compiled with the |+multi_byte| feature. - -EURO - -Exception: RFC1345 doesn't specify the euro sign. In Vim the digraph =e was -added for this. Note the difference between latin1, where the digraph Cu is -used for the currency sign, and latin9 (iso-8859-15), where the digraph =e is -used for the euro sign, while both of them are the character 164, 0xa4. For -compatibility with zsh Eu can also be used for the euro sign. - - *digraph-table* -char digraph hex dec official name ~ -^@ NU 0x00 0 NULL (NUL) -^A SH 0x01 1 START OF HEADING (SOH) -^B SX 0x02 2 START OF TEXT (STX) -^C EX 0x03 3 END OF TEXT (ETX) -^D ET 0x04 4 END OF TRANSMISSION (EOT) -^E EQ 0x05 5 ENQUIRY (ENQ) -^F AK 0x06 6 ACKNOWLEDGE (ACK) -^G BL 0x07 7 BELL (BEL) -^H BS 0x08 8 BACKSPACE (BS) -^I HT 0x09 9 CHARACTER TABULATION (HT) -^@ LF 0x0a 10 LINE FEED (LF) -^K VT 0x0b 11 LINE TABULATION (VT) -^L FF 0x0c 12 FORM FEED (FF) -^M CR 0x0d 13 CARRIAGE RETURN (CR) -^N SO 0x0e 14 SHIFT OUT (SO) -^O SI 0x0f 15 SHIFT IN (SI) -^P DL 0x10 16 DATALINK ESCAPE (DLE) -^Q D1 0x11 17 DEVICE CONTROL ONE (DC1) -^R D2 0x12 18 DEVICE CONTROL TWO (DC2) -^S D3 0x13 19 DEVICE CONTROL THREE (DC3) -^T D4 0x14 20 DEVICE CONTROL FOUR (DC4) -^U NK 0x15 21 NEGATIVE ACKNOWLEDGE (NAK) -^V SY 0x16 22 SYNCHRONOUS IDLE (SYN) -^W EB 0x17 23 END OF TRANSMISSION BLOCK (ETB) -^X CN 0x18 24 CANCEL (CAN) -^Y EM 0x19 25 END OF MEDIUM (EM) -^Z SB 0x1a 26 SUBSTITUTE (SUB) -^[ EC 0x1b 27 ESCAPE (ESC) -^\ FS 0x1c 28 FILE SEPARATOR (IS4) -^] GS 0x1d 29 GROUP SEPARATOR (IS3) -^^ RS 0x1e 30 RECORD SEPARATOR (IS2) -^_ US 0x1f 31 UNIT SEPARATOR (IS1) - SP 0x20 32 SPACE -# Nb 0x23 35 NUMBER SIGN -$ DO 0x24 36 DOLLAR SIGN -@ At 0x40 64 COMMERCIAL AT -[ <( 0x5b 91 LEFT SQUARE BRACKET -\ // 0x5c 92 REVERSE SOLIDUS -] )> 0x5d 93 RIGHT SQUARE BRACKET -^ '> 0x5e 94 CIRCUMFLEX ACCENT -` '! 0x60 96 GRAVE ACCENT -{ (! 0x7b 123 LEFT CURLY BRACKET -| !! 0x7c 124 VERTICAL LINE -} !) 0x7d 125 RIGHT CURLY BRACKET -~ '? 0x7e 126 TILDE -^? DT 0x7f 127 DELETE (DEL) -~@ PA 0x80 128 PADDING CHARACTER (PAD) -~A HO 0x81 129 HIGH OCTET PRESET (HOP) -~B BH 0x82 130 BREAK PERMITTED HERE (BPH) -~C NH 0x83 131 NO BREAK HERE (NBH) -~D IN 0x84 132 INDEX (IND) -~E NL 0x85 133 NEXT LINE (NEL) -~F SA 0x86 134 START OF SELECTED AREA (SSA) -~G ES 0x87 135 END OF SELECTED AREA (ESA) -~H HS 0x88 136 CHARACTER TABULATION SET (HTS) -~I HJ 0x89 137 CHARACTER TABULATION WITH JUSTIFICATION (HTJ) -~J VS 0x8a 138 LINE TABULATION SET (VTS) -~K PD 0x8b 139 PARTIAL LINE FORWARD (PLD) -~L PU 0x8c 140 PARTIAL LINE BACKWARD (PLU) -~M RI 0x8d 141 REVERSE LINE FEED (RI) -~N S2 0x8e 142 SINGLE-SHIFT TWO (SS2) -~O S3 0x8f 143 SINGLE-SHIFT THREE (SS3) -~P DC 0x90 144 DEVICE CONTROL STRING (DCS) -~Q P1 0x91 145 PRIVATE USE ONE (PU1) -~R P2 0x92 146 PRIVATE USE TWO (PU2) -~S TS 0x93 147 SET TRANSMIT STATE (STS) -~T CC 0x94 148 CANCEL CHARACTER (CCH) -~U MW 0x95 149 MESSAGE WAITING (MW) -~V SG 0x96 150 START OF GUARDED AREA (SPA) -~W EG 0x97 151 END OF GUARDED AREA (EPA) -~X SS 0x98 152 START OF STRING (SOS) -~Y GC 0x99 153 SINGLE GRAPHIC CHARACTER INTRODUCER (SGCI) -~Z SC 0x9a 154 SINGLE CHARACTER INTRODUCER (SCI) -~[ CI 0x9b 155 CONTROL SEQUENCE INTRODUCER (CSI) -~\ ST 0x9c 156 STRING TERMINATOR (ST) -~] OC 0x9d 157 OPERATING SYSTEM COMMAND (OSC) -~^ PM 0x9e 158 PRIVACY MESSAGE (PM) -~_ AC 0x9f 159 APPLICATION PROGRAM COMMAND (APC) -| NS 0xa0 160 NO-BREAK SPACE -¡ !I 0xa1 161 INVERTED EXCLAMATION MARK -¢ Ct 0xa2 162 CENT SIGN -£ Pd 0xa3 163 POUND SIGN -¤ Cu 0xa4 164 CURRENCY SIGN -¥ Ye 0xa5 165 YEN SIGN -¦ BB 0xa6 166 BROKEN BAR -§ SE 0xa7 167 SECTION SIGN -¨ ': 0xa8 168 DIAERESIS -© Co 0xa9 169 COPYRIGHT SIGN -ª -a 0xaa 170 FEMININE ORDINAL INDICATOR -« << 0xab 171 LEFT-POINTING DOUBLE ANGLE QUOTATION MARK -¬ NO 0xac 172 NOT SIGN -­ -- 0xad 173 SOFT HYPHEN -® Rg 0xae 174 REGISTERED SIGN -¯ 'm 0xaf 175 MACRON -° DG 0xb0 176 DEGREE SIGN -± +- 0xb1 177 PLUS-MINUS SIGN -² 2S 0xb2 178 SUPERSCRIPT TWO -³ 3S 0xb3 179 SUPERSCRIPT THREE -´ '' 0xb4 180 ACUTE ACCENT -µ My 0xb5 181 MICRO SIGN -¶ PI 0xb6 182 PILCROW SIGN -· .M 0xb7 183 MIDDLE DOT -¸ ', 0xb8 184 CEDILLA -¹ 1S 0xb9 185 SUPERSCRIPT ONE -º -o 0xba 186 MASCULINE ORDINAL INDICATOR -» >> 0xbb 187 RIGHT-POINTING DOUBLE ANGLE QUOTATION MARK -¼ 14 0xbc 188 VULGAR FRACTION ONE QUARTER -½ 12 0xbd 189 VULGAR FRACTION ONE HALF -¾ 34 0xbe 190 VULGAR FRACTION THREE QUARTERS -¿ ?I 0xbf 191 INVERTED QUESTION MARK -À A! 0xc0 192 LATIN CAPITAL LETTER A WITH GRAVE -Á A' 0xc1 193 LATIN CAPITAL LETTER A WITH ACUTE -Â A> 0xc2 194 LATIN CAPITAL LETTER A WITH CIRCUMFLEX -Ã A? 0xc3 195 LATIN CAPITAL LETTER A WITH TILDE -Ä A: 0xc4 196 LATIN CAPITAL LETTER A WITH DIAERESIS -Å AA 0xc5 197 LATIN CAPITAL LETTER A WITH RING ABOVE -Æ AE 0xc6 198 LATIN CAPITAL LETTER AE -Ç C, 0xc7 199 LATIN CAPITAL LETTER C WITH CEDILLA -È E! 0xc8 200 LATIN CAPITAL LETTER E WITH GRAVE -É E' 0xc9 201 LATIN CAPITAL LETTER E WITH ACUTE -Ê E> 0xca 202 LATIN CAPITAL LETTER E WITH CIRCUMFLEX -Ë E: 0xcb 203 LATIN CAPITAL LETTER E WITH DIAERESIS -Ì I! 0xcc 204 LATIN CAPITAL LETTER I WITH GRAVE -Í I' 0xcd 205 LATIN CAPITAL LETTER I WITH ACUTE -Î I> 0xce 206 LATIN CAPITAL LETTER I WITH CIRCUMFLEX -Ï I: 0xcf 207 LATIN CAPITAL LETTER I WITH DIAERESIS -Ð D- 0xd0 208 LATIN CAPITAL LETTER ETH (Icelandic) -Ñ N? 0xd1 209 LATIN CAPITAL LETTER N WITH TILDE -Ò O! 0xd2 210 LATIN CAPITAL LETTER O WITH GRAVE -Ó O' 0xd3 211 LATIN CAPITAL LETTER O WITH ACUTE -Ô O> 0xd4 212 LATIN CAPITAL LETTER O WITH CIRCUMFLEX -Õ O? 0xd5 213 LATIN CAPITAL LETTER O WITH TILDE -Ö O: 0xd6 214 LATIN CAPITAL LETTER O WITH DIAERESIS -× *X 0xd7 215 MULTIPLICATION SIGN -Ø O/ 0xd8 216 LATIN CAPITAL LETTER O WITH STROKE -Ù U! 0xd9 217 LATIN CAPITAL LETTER U WITH GRAVE -Ú U' 0xda 218 LATIN CAPITAL LETTER U WITH ACUTE -Û U> 0xdb 219 LATIN CAPITAL LETTER U WITH CIRCUMFLEX -Ü U: 0xdc 220 LATIN CAPITAL LETTER U WITH DIAERESIS -Ý Y' 0xdd 221 LATIN CAPITAL LETTER Y WITH ACUTE -Þ TH 0xde 222 LATIN CAPITAL LETTER THORN (Icelandic) -ß ss 0xdf 223 LATIN SMALL LETTER SHARP S (German) -à a! 0xe0 224 LATIN SMALL LETTER A WITH GRAVE -á a' 0xe1 225 LATIN SMALL LETTER A WITH ACUTE -â a> 0xe2 226 LATIN SMALL LETTER A WITH CIRCUMFLEX -ã a? 0xe3 227 LATIN SMALL LETTER A WITH TILDE -ä a: 0xe4 228 LATIN SMALL LETTER A WITH DIAERESIS -å aa 0xe5 229 LATIN SMALL LETTER A WITH RING ABOVE -æ ae 0xe6 230 LATIN SMALL LETTER AE -ç c, 0xe7 231 LATIN SMALL LETTER C WITH CEDILLA -è e! 0xe8 232 LATIN SMALL LETTER E WITH GRAVE -é e' 0xe9 233 LATIN SMALL LETTER E WITH ACUTE -ê e> 0xea 234 LATIN SMALL LETTER E WITH CIRCUMFLEX -ë e: 0xeb 235 LATIN SMALL LETTER E WITH DIAERESIS -ì i! 0xec 236 LATIN SMALL LETTER I WITH GRAVE -í i' 0xed 237 LATIN SMALL LETTER I WITH ACUTE -î i> 0xee 238 LATIN SMALL LETTER I WITH CIRCUMFLEX -ï i: 0xef 239 LATIN SMALL LETTER I WITH DIAERESIS -ð d- 0xf0 240 LATIN SMALL LETTER ETH (Icelandic) -ñ n? 0xf1 241 LATIN SMALL LETTER N WITH TILDE -ò o! 0xf2 242 LATIN SMALL LETTER O WITH GRAVE -ó o' 0xf3 243 LATIN SMALL LETTER O WITH ACUTE -ô o> 0xf4 244 LATIN SMALL LETTER O WITH CIRCUMFLEX -õ o? 0xf5 245 LATIN SMALL LETTER O WITH TILDE -ö o: 0xf6 246 LATIN SMALL LETTER O WITH DIAERESIS -÷ -: 0xf7 247 DIVISION SIGN -ø o/ 0xf8 248 LATIN SMALL LETTER O WITH STROKE -ù u! 0xf9 249 LATIN SMALL LETTER U WITH GRAVE -ú u' 0xfa 250 LATIN SMALL LETTER U WITH ACUTE -û u> 0xfb 251 LATIN SMALL LETTER U WITH CIRCUMFLEX -ü u: 0xfc 252 LATIN SMALL LETTER U WITH DIAERESIS -ý y' 0xfd 253 LATIN SMALL LETTER Y WITH ACUTE -þ th 0xfe 254 LATIN SMALL LETTER THORN (Icelandic) -ÿ y: 0xff 255 LATIN SMALL LETTER Y WITH DIAERESIS - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/editing.txt b/share/vim/vim72/doc/editing.txt deleted file mode 100644 index c745f902ec..0000000000 --- a/share/vim/vim72/doc/editing.txt +++ /dev/null @@ -1,1578 +0,0 @@ -*editing.txt* For Vim version 7.2. Last change: 2008 Aug 09 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Editing files *edit-files* - -1. Introduction |edit-intro| -2. Editing a file |edit-a-file| -3. The argument list |argument-list| -4. Writing |writing| -5. Writing and quitting |write-quit| -6. Dialogs |edit-dialogs| -7. The current directory |current-directory| -8. Editing binary files |edit-binary| -9. Encryption |encryption| -10. Timestamps |timestamps| -11. File Searching |file-searching| - -============================================================================== -1. Introduction *edit-intro* - -Editing a file with Vim means: - -1. reading the file into a buffer -2. changing the buffer with editor commands -3. writing the buffer into a file - - *current-file* -As long as you don't write the buffer, the original file remains unchanged. -If you start editing a file (read a file into the buffer), the file name is -remembered as the "current file name". This is also known as the name of the -current buffer. It can be used with "%" on the command line |:_%|. - - *alternate-file* -If there already was a current file name, then that one becomes the alternate -file name. It can be used with "#" on the command line |:_#| and you can use -the |CTRL-^| command to toggle between the current and the alternate file. -However, the alternate file name is not changed when |:keepalt| is used. - - *:keepalt* *:keepa* -:keepalt {cmd} Execute {cmd} while keeping the current alternate file - name. Note that commands invoked indirectly (e.g., - with a function) may still set the alternate file - name. {not in Vi} - -All file names are remembered in the buffer list. When you enter a file name, -for editing (e.g., with ":e filename") or writing (e.g., with ":w filename"), -the file name is added to the list. You can use the buffer list to remember -which files you edited and to quickly switch from one file to another (e.g., -to copy text) with the |CTRL-^| command. First type the number of the file -and then hit CTRL-^. {Vi: only one alternate file name is remembered} - - -CTRL-G or *CTRL-G* *:f* *:fi* *:file* -:f[ile] Prints the current file name (as typed, unless ":cd" - was used), the cursor position (unless the 'ruler' - option is set), and the file status (readonly, - modified, read errors, new file). See the 'shortmess' - option about how to make this message shorter. - {Vi does not include column number} - -:f[ile]! like |:file|, but don't truncate the name even when - 'shortmess' indicates this. - -{count}CTRL-G Like CTRL-G, but prints the current file name with - full path. If the count is higher than 1 the current - buffer number is also given. {not in Vi} - - *g_CTRL-G* *word-count* *byte-count* -g CTRL-G Prints the current position of the cursor in five - ways: Column, Line, Word, Character and Byte. If the - number of Characters and Bytes is the same then the - Character position is omitted. - If there are characters in the line that take more - than one position on the screen ( or special - character), both the "real" column and the screen - column are shown, separated with a dash. - See also 'ruler' option. {not in Vi} - - *v_g_CTRL-G* -{Visual}g CTRL-G Similar to "g CTRL-G", but Word, Character, Line, and - Byte counts for the visually selected region are - displayed. - In Blockwise mode, Column count is also shown. (For - {Visual} see |Visual-mode|.) - {not in VI} - - *:file_f* -:f[ile][!] {name} Sets the current file name to {name}. The optional ! - avoids truncating the message, as with |:file|. - If the buffer did have a name, that name becomes the - |alternate-file| name. An unlisted buffer is created - to hold the old name. - *:0file* -:0f[ile][!] Remove the name of the current buffer. The optional ! - avoids truncating the message, as with |:file|. {not - in Vi} - -:buffers -:files -:ls List all the currently known file names. See - 'windows.txt' |:files| |:buffers| |:ls|. {not in - Vi} - -Vim will remember the full path name of a file name that you enter. In most -cases when the file name is displayed only the name you typed is shown, but -the full path name is being used if you used the ":cd" command |:cd|. - - *home-replace* -If the environment variable $HOME is set, and the file name starts with that -string, it is often displayed with HOME replaced with "~". This was done to -keep file names short. When reading or writing files the full name is still -used, the "~" is only used when displaying file names. When replacing the -file name would result in just "~", "~/" is used instead (to avoid confusion -between options set to $HOME with 'backupext' set to "~"). - -When writing the buffer, the default is to use the current file name. Thus -when you give the "ZZ" or ":wq" command, the original file will be -overwritten. If you do not want this, the buffer can be written into another -file by giving a file name argument to the ":write" command. For example: > - - vim testfile - [change the buffer with editor commands] - :w newfile - :q - -This will create a file "newfile", that is a modified copy of "testfile". -The file "testfile" will remain unchanged. Anyway, if the 'backup' option is -set, Vim renames or copies the original file before it will be overwritten. -You can use this file if you discover that you need the original file. See -also the 'patchmode' option. The name of the backup file is normally the same -as the original file with 'backupext' appended. The default "~" is a bit -strange to avoid accidentally overwriting existing files. If you prefer ".bak" -change the 'backupext' option. Extra dots are replaced with '_' on MS-DOS -machines, when Vim has detected that an MS-DOS-like filesystem is being used -(e.g., messydos or crossdos) or when the 'shortname' option is on. The -backup file can be placed in another directory by setting 'backupdir'. - - *auto-shortname* -Technical: On the Amiga you can use 30 characters for a file name. But on an - MS-DOS-compatible filesystem only 8 plus 3 characters are - available. Vim tries to detect the type of filesystem when it is - creating the .swp file. If an MS-DOS-like filesystem is suspected, - a flag is set that has the same effect as setting the 'shortname' - option. This flag will be reset as soon as you start editing a - new file. The flag will be used when making the file name for the - ".swp" and ".~" files for the current file. But when you are - editing a file in a normal filesystem and write to an MS-DOS-like - filesystem the flag will not have been set. In that case the - creation of the ".~" file may fail and you will get an error - message. Use the 'shortname' option in this case. - -When you started editing without giving a file name, "No File" is displayed in -messages. If the ":write" command is used with a file name argument, the file -name for the current file is set to that file name. This only happens when -the 'F' flag is included in 'cpoptions' (by default it is included) |cpo-F|. -This is useful when entering text in an empty buffer and then writing it to a -file. If 'cpoptions' contains the 'f' flag (by default it is NOT included) -|cpo-f| the file name is set for the ":read file" command. This is useful -when starting Vim without an argument and then doing ":read file" to start -editing a file. -When the file name was set and 'filetype' is empty the filetype detection -autocommands will be triggered. - *not-edited* -Because the file name was set without really starting to edit that file, you -are protected from overwriting that file. This is done by setting the -"notedited" flag. You can see if this flag is set with the CTRL-G or ":file" -command. It will include "[Not edited]" when the "notedited" flag is set. -When writing the buffer to the current file name (with ":w!"), the "notedited" -flag is reset. - - *abandon* -Vim remembers whether you have changed the buffer. You are protected from -losing the changes you made. If you try to quit without writing, or want to -start editing another file, Vim will refuse this. In order to overrule this -protection, add a '!' to the command. The changes will then be lost. For -example: ":q" will not work if the buffer was changed, but ":q!" will. To see -whether the buffer was changed use the "CTRL-G" command. The message includes -the string "[Modified]" if the buffer has been changed. - -If you want to automatically save the changes without asking, switch on the -'autowriteall' option. 'autowrite' is the associated Vi-compatible option -that does not work for all commands. - -If you want to keep the changed buffer without saving it, switch on the -'hidden' option. See |hidden-buffer|. - -============================================================================== -2. Editing a file *edit-a-file* - - *:e* *:edit* -:e[dit] [++opt] [+cmd] Edit the current file. This is useful to re-edit the - current file, when it has been changed outside of Vim. - This fails when changes have been made to the current - buffer and 'autowriteall' isn't set or the file can't - be written. - Also see |++opt| and |+cmd|. - {Vi: no ++opt} - - *:edit!* -:e[dit]! [++opt] [+cmd] - Edit the current file always. Discard any changes to - the current buffer. This is useful if you want to - start all over again. - Also see |++opt| and |+cmd|. - {Vi: no ++opt} - - *:edit_f* -:e[dit] [++opt] [+cmd] {file} - Edit {file}. - This fails when changes have been made to the current - buffer, unless 'hidden' is set or 'autowriteall' is - set and the file can be written. - Also see |++opt| and |+cmd|. - {Vi: no ++opt} - - *:edit!_f* -:e[dit]! [++opt] [+cmd] {file} - Edit {file} always. Discard any changes to the - current buffer. - Also see |++opt| and |+cmd|. - {Vi: no ++opt} - -:e[dit] [++opt] [+cmd] #[count] - Edit the [count]th buffer (as shown by |:files|). - This command does the same as [count] CTRL-^. But ":e - #" doesn't work if the alternate buffer doesn't have a - file name, while CTRL-^ still works then. - Also see |++opt| and |+cmd|. - {Vi: no ++opt} - - *:ene* *:enew* -:ene[w] Edit a new, unnamed buffer. This fails when changes - have been made to the current buffer, unless 'hidden' - is set or 'autowriteall' is set and the file can be - written. - If 'fileformats' is not empty, the first format given - will be used for the new buffer. If 'fileformats' is - empty, the 'fileformat' of the current buffer is used. - {not in Vi} - - *:ene!* *:enew!* -:ene[w]! Edit a new, unnamed buffer. Discard any changes to - the current buffer. - Set 'fileformat' like |:enew|. - {not in Vi} - - *:fin* *:find* -:fin[d][!] [++opt] [+cmd] {file} - Find {file} in 'path' and then |:edit| it. - {not in Vi} {not available when the |+file_in_path| - feature was disabled at compile time} - -:{count}fin[d][!] [++opt] [+cmd] {file} - Just like ":find", but use the {count} match in - 'path'. Thus ":2find file" will find the second - "file" found in 'path'. When there are fewer matches - for the file in 'path' than asked for, you get an - error message. - - *:ex* -:ex [++opt] [+cmd] [file] - Same as |:edit|. - - *:vi* *:visual* -:vi[sual][!] [++opt] [+cmd] [file] - When used in Ex mode: Leave |Ex-mode|, go back to - Normal mode. Otherwise same as |:edit|. - - *:vie* *:view* -:vie[w] [++opt] [+cmd] file - When used in Ex mode: Leave |Ex mode|, go back to - Normal mode. Otherwise same as |:edit|, but set - 'readonly' option for this buffer. {not in Vi} - - *CTRL-^* *CTRL-6* -CTRL-^ Edit the alternate file (equivalent to ":e #"). - Mostly the alternate file is the previously edited - file. This is a quick way to toggle between two - files. - If the 'autowrite' or 'autowriteall' option is on and - the buffer was changed, write it. - Mostly the ^ character is positioned on the 6 key, - pressing CTRL and 6 then gets you what we call CTRL-^. - But on some non-US keyboards CTRL-^ is produced in - another way. - -{count}CTRL-^ Edit [count]th file in the buffer list (equivalent to - ":e #[count]"). This is a quick way to switch between - files. - See |CTRL-^| above for further details. - {not in Vi} - -[count]]f *]f* *[f* -[count][f Same as "gf". Deprecated. - - *gf* *E446* *E447* -[count]gf Edit the file whose name is under or after the cursor. - Mnemonic: "goto file". - Uses the 'isfname' option to find out which characters - are supposed to be in a file name. Trailing - punctuation characters ".,:;!" are ignored. - Uses the 'path' option as a list of directory names to - look for the file. See the 'path' option for details - about relative directories and wildcards. - Uses the 'suffixesadd' option to check for file names - with a suffix added. - If the file can't be found, 'includeexpr' is used to - modify the name and another attempt is done. - If a [count] is given, the count'th file that is found - in the 'path' is edited. - This command fails if Vim refuses to |abandon| the - current file. - If you want to edit the file in a new window use - |CTRL-W_CTRL-F|. - If you do want to edit a new file, use: > - :e -< To make gf always work like that: > - :map gf :e -< If the name is a hypertext link, that looks like - "type://machine/path", you need the |netrw| plugin. - For Unix the '~' character is expanded, like in - "~user/file". Environment variables are expanded too - |expand-env|. - {not in Vi} - {not available when the |+file_in_path| feature was - disabled at compile time} - - *v_gf* -{Visual}[count]gf Same as "gf", but the highlighted text is used as the - name of the file to edit. 'isfname' is ignored. - Leading blanks are skipped, otherwise all blanks and - special characters are included in the file name. - (For {Visual} see |Visual-mode|.) - {not in VI} - - *gF* -[count]gF Same as "gf", except if a number follows the file - name, then the cursor is positioned on that line in - the file. The file name and the number must be - separated by a non-filename (see 'isfname') and - non-numeric character. White space between the - filename, the separator and the number are ignored. - Examples: - eval.c:10 ~ - eval.c @ 20 ~ - eval.c (30) ~ - eval.c 40 ~ - - *v_gF* -{Visual}[count]gF Same as "v_gf". - -These commands are used to start editing a single file. This means that the -file is read into the buffer and the current file name is set. The file that -is opened depends on the current directory, see |:cd|. - -See |read-messages| for an explanation of the message that is given after the -file has been read. - -You can use the ":e!" command if you messed up the buffer and want to start -all over again. The ":e" command is only useful if you have changed the -current file name. - - *:filename* *{file}* -Besides the things mentioned here, more special items for where a filename is -expected are mentioned at |cmdline-special|. - -Note for systems other than Unix: When using a command that accepts a single -file name (like ":edit file") spaces in the file name are allowed, but -trailing spaces are ignored. This is useful on systems that regularly embed -spaces in file names (like MS-Windows and the Amiga). Example: The command -":e Long File Name " will edit the file "Long File Name". When using a -command that accepts more than one file name (like ":next file1 file2") -embedded spaces must be escaped with a backslash. - - *wildcard* *wildcards* -Wildcards in {file} are expanded. Which wildcards are supported depends on -the system. These are the common ones: - ? matches one character - * matches anything, including nothing - ** matches anything, including nothing, recurses into directories - [abc] match 'a', 'b' or 'c' - -To avoid the special meaning of the wildcards prepend a backslash. However, -on MS-Windows the backslash is a path separator and "path\[abc]" is still seen -as a wildcard when "[" is in the 'isfname' option. A simple way to avoid this -is to use "path\[[]abc]". Then the file "path[abc]" literally. - - *starstar-wildcard* -Expanding "**" is possible on Unix, Win32, Mac OS/X and a few other systems. -This allows searching a directory tree. This goes up to 100 directories deep. -Note there are some commands where this works slightly different, see -|file-searching|. -Example: > - :n **/*.txt -Finds files: - ttt.txt - subdir/ttt.txt - a/b/c/d/ttt.txt -When non-wildcard characters are used these are only matched in the first -directory. Example: > - :n /usr/inc**/*.h -Finds files: - /usr/include/types.h - /usr/include/sys/types.h - /usr/inc_old/types.h - *backtick-expansion* *`-expansion* -On Unix and a few other systems you can also use backticks in the file name, -for example: > - :e `find . -name ver\\*.c -print` -The backslashes before the star are required to prevent "ver*.c" to be -expanded by the shell before executing the find program. -This also works for most other systems, with the restriction that the -backticks must be around the whole item. It is not possible to have text -directly before the first or just after the last backtick. - - *`=* -You can have the backticks expanded as a Vim expression, instead of an -external command, by using the syntax `={expr}` e.g.: > - :e `=tempname()` -The expression can contain just about anything, thus this can also be used to -avoid the special meaning of '"', '|', '%' and '#'. Names are to be separated -with line breaks. When the result is a |List| then each item is used as a -name. Line breaks also separate names. - - *++opt* *[++opt]* -The [++opt] argument can be used to force the value of 'fileformat', -'fileencoding' or 'binary' to a value for one command, and to specify the -behavior for bad characters. The form is: > - ++{optname} -Or: > - ++{optname}={value} - -Where {optname} is one of: *++ff* *++enc* *++bin* *++nobin* *++edit* - ff or fileformat overrides 'fileformat' - enc or encoding overrides 'fileencoding' - bin or binary sets 'binary' - nobin or nobinary resets 'binary' - bad specifies behavior for bad characters - edit for |:read| only: keep option values as if editing - a file - -{value} cannot contain white space. It can be any valid value for these -options. Examples: > - :e ++ff=unix -This edits the same file again with 'fileformat' set to "unix". > - - :w ++enc=latin1 newfile -This writes the current buffer to "newfile" in latin1 format. - -There may be several ++opt arguments, separated by white space. They must all -appear before any |+cmd| argument. - - *++bad* -The argument of "++bad=" specifies what happens with characters that can't be -converted and illegal bytes. It can be one of three things: - ++bad=X A single-byte character that replaces each bad character. - ++bad=keep Keep bad characters without conversion. Note that this may - result in illegal bytes in your text! - ++bad=drop Remove the bad characters. - -The default is like "++bad=?": Replace each bad character with a question -mark. - -Note that when reading, the 'fileformat' and 'fileencoding' options will be -set to the used format. When writing this doesn't happen, thus a next write -will use the old value of the option. Same for the 'binary' option. - - - *+cmd* *[+cmd]* -The [+cmd] argument can be used to position the cursor in the newly opened -file, or execute any other command: - + Start at the last line. - +{num} Start at line {num}. - +/{pat} Start at first line containing {pat}. - +{command} Execute {command} after opening the new file. - {command} is any Ex command. -To include a white space in the {pat} or {command}, precede it with a -backslash. Double the number of backslashes. > - :edit +/The\ book file - :edit +/dir\ dirname\\ file - :edit +set\ dir=c:\\\\temp file -Note that in the last example the number of backslashes is halved twice: Once -for the "+cmd" argument and once for the ":set" command. - - *file-formats* -The 'fileformat' option sets the style for a file: -'fileformat' characters name ~ - "dos" or DOS format *DOS-format* - "unix" Unix format *Unix-format* - "mac" Mac format *Mac-format* -Previously 'textmode' was used. It is obsolete now. - -When reading a file, the mentioned characters are interpreted as the . -In DOS format (default for MS-DOS, OS/2 and Win32), and are both -interpreted as the . Note that when writing the file in DOS format, - characters will be added for each single . Also see |file-read|. - -When writing a file, the mentioned characters are used for . For DOS -format is used. Also see |DOS-format-write|. - -You can read a file in DOS format and write it in Unix format. This will -replace all pairs by (assuming 'fileformats' includes "dos"): > - :e file - :set fileformat=unix - :w -If you read a file in Unix format and write with DOS format, all -characters will be replaced with (assuming 'fileformats' includes -"unix"): > - :e file - :set fileformat=dos - :w - -If you start editing a new file and the 'fileformats' option is not empty -(which is the default), Vim will try to detect whether the lines in the file -are separated by the specified formats. When set to "unix,dos", Vim will -check for lines with a single (as used on Unix and Amiga) or by a - pair (MS-DOS). Only when ALL lines end in , 'fileformat' is set -to "dos", otherwise it is set to "unix". When 'fileformats' includes "mac", -and no characters are found in the file, 'fileformat' is set to "mac". - -If the 'fileformat' option is set to "dos" on non-MS-DOS systems the message -"[dos format]" is shown to remind you that something unusual is happening. On -MS-DOS systems you get the message "[unix format]" if 'fileformat' is set to -"unix". On all systems but the Macintosh you get the message "[mac format]" -if 'fileformat' is set to "mac". - -If the 'fileformats' option is empty and DOS format is used, but while reading -a file some lines did not end in , "[CR missing]" will be included in -the file message. -If the 'fileformats' option is empty and Mac format is used, but while reading -a file a was found, "[NL missing]" will be included in the file message. - -If the new file does not exist, the 'fileformat' of the current buffer is used -when 'fileformats' is empty. Otherwise the first format from 'fileformats' is -used for the new file. - -Before editing binary, executable or Vim script files you should set the -'binary' option. A simple way to do this is by starting Vim with the "-b" -option. This will avoid the use of 'fileformat'. Without this you risk that -single characters are unexpectedly replaced with . - -You can encrypt files that are written by setting the 'key' option. This -provides some security against others reading your files. |encryption| - - -============================================================================== -3. The argument list *argument-list* *arglist* - -If you give more than one file name when starting Vim, this list is remembered -as the argument list. You can jump to each file in this list. - -Do not confuse this with the buffer list, which you can see with the -|:buffers| command. The argument list was already present in Vi, the buffer -list is new in Vim. Every file name in the argument list will also be present -in the buffer list (unless it was deleted with |:bdel| or |:bwipe|). But it's -common that names in the buffer list are not in the argument list. - -This subject is introduced in section |07.2| of the user manual. - -There is one global argument list, which is used for all windows by default. -It is possible to create a new argument list local to a window, see -|:arglocal|. - -You can use the argument list with the following commands, and with the -expression functions |argc()| and |argv()|. These all work on the argument -list of the current window. - - *:ar* *:args* -:ar[gs] Print the argument list, with the current file in - square brackets. - -:ar[gs] [++opt] [+cmd] {arglist} *:args_f* - Define {arglist} as the new argument list and edit - the first one. This fails when changes have been made - and Vim does not want to |abandon| the current buffer. - Also see |++opt| and |+cmd|. - {Vi: no ++opt} - -:ar[gs]! [++opt] [+cmd] {arglist} *:args_f!* - Define {arglist} as the new argument list and edit - the first one. Discard any changes to the current - buffer. - Also see |++opt| and |+cmd|. - {Vi: no ++opt} - -:[count]arge[dit][!] [++opt] [+cmd] {name} *:arge* *:argedit* - Add {name} to the argument list and edit it. - When {name} already exists in the argument list, this - entry is edited. - This is like using |:argadd| and then |:edit|. - Note that only one file name is allowed, and spaces - inside the file name are allowed, like with |:edit|. - [count] is used like with |:argadd|. - [!] is required if the current file cannot be - |abandon|ed. - Also see |++opt| and |+cmd|. - {not in Vi} - -:[count]arga[dd] {name} .. *:arga* *:argadd* *E479* - Add the {name}s to the argument list. - If [count] is omitted, the {name}s are added just - after the current entry in the argument list. - Otherwise they are added after the [count]'th file. - If the argument list is "a b c", and "b" is the - current argument, then these commands result in: - command new argument list ~ - :argadd x a b x c - :0argadd x x a b c - :1argadd x a x b c - :99argadd x a b c x - There is no check for duplicates, it is possible to - add a file to the argument list twice. - The currently edited file is not changed. - {not in Vi} {not available when compiled without the - |+listcmds| feature} - Note: you can also use this method: > - :args ## x -< This will add the "x" item and sort the new list. - -:argd[elete] {pattern} .. *:argd* *:argdelete* *E480* - Delete files from the argument list that match the - {pattern}s. {pattern} is used like a file pattern, - see |file-pattern|. "%" can be used to delete the - current entry. - This command keeps the currently edited file, also - when it's deleted from the argument list. - Example: > - :argdel *.obj -< {not in Vi} {not available when compiled without the - |+listcmds| feature} - -:{range}argd[elete] Delete the {range} files from the argument list. - When the last number in the range is too high, up to - the last argument is deleted. Example: > - :10,1000argdel -< Deletes arguments 10 and further, keeping 1-9. - {not in Vi} {not available when compiled without the - |+listcmds| feature} - - *:argu* *:argument* -:[count]argu[ment] [count] [++opt] [+cmd] - Edit file [count] in the argument list. When [count] - is omitted the current entry is used. This fails - when changes have been made and Vim does not want to - |abandon| the current buffer. - Also see |++opt| and |+cmd|. - {not in Vi} {not available when compiled without the - |+listcmds| feature} - -:[count]argu[ment]! [count] [++opt] [+cmd] - Edit file [count] in the argument list, discard any - changes to the current buffer. When [count] is - omitted the current entry is used. - Also see |++opt| and |+cmd|. - {not in Vi} {not available when compiled without the - |+listcmds| feature} - -:[count]n[ext] [++opt] [+cmd] *:n* *:ne* *:next* *E165* *E163* - Edit [count] next file. This fails when changes have - been made and Vim does not want to |abandon| the - current buffer. Also see |++opt| and |+cmd|. {Vi: no - count or ++opt}. - -:[count]n[ext]! [++opt] [+cmd] - Edit [count] next file, discard any changes to the - buffer. Also see |++opt| and |+cmd|. {Vi: no count - or ++opt}. - -:n[ext] [++opt] [+cmd] {arglist} *:next_f* - Same as |:args_f|. - -:n[ext]! [++opt] [+cmd] {arglist} - Same as |:args_f!|. - -:[count]N[ext] [count] [++opt] [+cmd] *:Next* *:N* *E164* - Edit [count] previous file in argument list. This - fails when changes have been made and Vim does not - want to |abandon| the current buffer. - Also see |++opt| and |+cmd|. {Vi: no count or ++opt}. - -:[count]N[ext]! [count] [++opt] [+cmd] - Edit [count] previous file in argument list. Discard - any changes to the buffer. Also see |++opt| and - |+cmd|. {Vi: no count or ++opt}. - -:[count]prev[ious] [count] [++opt] [+cmd] *:prev* *:previous* - Same as :Next. Also see |++opt| and |+cmd|. {Vi: - only in some versions} - - *:rew* *:rewind* -:rew[ind] [++opt] [+cmd] - Start editing the first file in the argument list. - This fails when changes have been made and Vim does - not want to |abandon| the current buffer. - Also see |++opt| and |+cmd|. {Vi: no ++opt} - -:rew[ind]! [++opt] [+cmd] - Start editing the first file in the argument list. - Discard any changes to the buffer. Also see |++opt| - and |+cmd|. {Vi: no ++opt} - - *:fir* *:first* -:fir[st][!] [++opt] [+cmd] - Other name for ":rewind". {not in Vi} - - *:la* *:last* -:la[st] [++opt] [+cmd] - Start editing the last file in the argument list. - This fails when changes have been made and Vim does - not want to |abandon| the current buffer. - Also see |++opt| and |+cmd|. {not in Vi} - -:la[st]! [++opt] [+cmd] - Start editing the last file in the argument list. - Discard any changes to the buffer. Also see |++opt| - and |+cmd|. {not in Vi} - - *:wn* *:wnext* -:[count]wn[ext] [++opt] - Write current file and start editing the [count] - next file. Also see |++opt| and |+cmd|. {not in Vi} - -:[count]wn[ext] [++opt] {file} - Write current file to {file} and start editing the - [count] next file, unless {file} already exists and - the 'writeany' option is off. Also see |++opt| and - |+cmd|. {not in Vi} - -:[count]wn[ext]! [++opt] {file} - Write current file to {file} and start editing the - [count] next file. Also see |++opt| and |+cmd|. {not - in Vi} - -:[count]wN[ext][!] [++opt] [file] *:wN* *:wNext* -:[count]wp[revious][!] [++opt] [file] *:wp* *:wprevious* - Same as :wnext, but go to previous file instead of - next. {not in Vi} - -The [count] in the commands above defaults to one. For some commands it is -possible to use two counts. The last one (rightmost one) is used. - -If no [+cmd] argument is present, the cursor is positioned at the last known -cursor position for the file. If 'startofline' is set, the cursor will be -positioned at the first non-blank in the line, otherwise the last know column -is used. If there is no last known cursor position the cursor will be in the -first line (the last line in Ex mode). - - *{arglist}* -The wildcards in the argument list are expanded and the file names are sorted. -Thus you can use the command "vim *.c" to edit all the C files. From within -Vim the command ":n *.c" does the same. - -White space is used to separate file names. Put a backslash before a space or -tab to include it in a file name. E.g., to edit the single file "foo bar": > - :next foo\ bar - -On Unix and a few other systems you can also use backticks, for example: > - :next `find . -name \\*.c -print` -The backslashes before the star are required to prevent "*.c" to be expanded -by the shell before executing the find program. - - *arglist-position* -When there is an argument list you can see which file you are editing in the -title of the window (if there is one and 'title' is on) and with the file -message you get with the "CTRL-G" command. You will see something like - (file 4 of 11) -If 'shortmess' contains 'f' it will be - (4 of 11) -If you are not really editing the file at the current position in the argument -list it will be - (file (4) of 11) -This means that you are position 4 in the argument list, but not editing the -fourth file in the argument list. This happens when you do ":e file". - - -LOCAL ARGUMENT LIST - -{not in Vi} -{not available when compiled without the |+windows| or |+listcmds| feature} - - *:arglocal* -:argl[ocal] Make a local copy of the global argument list. - Doesn't start editing another file. - -:argl[ocal][!] [++opt] [+cmd] {arglist} - Define a new argument list, which is local to the - current window. Works like |:args_f| otherwise. - - *:argglobal* -:argg[lobal] Use the global argument list for the current window. - Doesn't start editing another file. - -:argg[lobal][!] [++opt] [+cmd] {arglist} - Use the global argument list for the current window. - Define a new global argument list like |:args_f|. - All windows using the global argument list will see - this new list. - -There can be several argument lists. They can be shared between windows. -When they are shared, changing the argument list in one window will also -change it in the other window. - -When a window is split the new window inherits the argument list from the -current window. The two windows then share this list, until one of them uses -|:arglocal| or |:argglobal| to use another argument list. - - -USING THE ARGUMENT LIST - - *:argdo* -:argdo[!] {cmd} Execute {cmd} for each file in the argument list. - It works like doing this: > - :rewind - :{cmd} - :next - :{cmd} - etc. -< When the current file can't be |abandon|ed and the [!] - is not present, the command fails. - When an error is detected on one file, further files - in the argument list will not be visited. - The last file in the argument list (or where an error - occurred) becomes the current file. - {cmd} can contain '|' to concatenate several commands. - {cmd} must not change the argument list. - Note: While this command is executing, the Syntax - autocommand event is disabled by adding it to - 'eventignore'. This considerably speeds up editing - each file. - {not in Vi} {not available when compiled without the - |+listcmds| feature} - Also see |:windo|, |:tabdo| and |:bufdo|. - -Example: > - :args *.c - :argdo set ff=unix | update -This sets the 'fileformat' option to "unix" and writes the file if is now -changed. This is done for all *.c files. - -Example: > - :args *.[ch] - :argdo %s/\/My_Foo/ge | update -This changes the word "my_foo" to "My_Foo" in all *.c and *.h files. The "e" -flag is used for the ":substitute" command to avoid an error for files where -"my_foo" isn't used. ":update" writes the file only if changes were made. - -============================================================================== -4. Writing *writing* *save-file* - -Note: When the 'write' option is off, you are not able to write any file. - - *:w* *:write* - *E502* *E503* *E504* *E505* - *E512* *E514* *E667* *E796* -:w[rite] [++opt] Write the whole buffer to the current file. This is - the normal way to save changes to a file. It fails - when the 'readonly' option is set or when there is - another reason why the file can't be written. - For ++opt see |++opt|, but only ++bin, ++nobin, ++ff - and ++enc are effective. - -:w[rite]! [++opt] Like ":write", but forcefully write when 'readonly' is - set or there is another reason why writing was - refused. - Note: This may change the permission and ownership of - the file and break (symbolic) links. Add the 'W' flag - to 'cpoptions' to avoid this. - -:[range]w[rite][!] [++opt] - Write the specified lines to the current file. This - is unusual, because the file will not contain all - lines in the buffer. - - *:w_f* *:write_f* -:[range]w[rite] [++opt] {file} - Write the specified lines to {file}, unless it - already exists and the 'writeany' option is off. - - *:w!* -:[range]w[rite]! [++opt] {file} - Write the specified lines to {file}. Overwrite an - existing file. - - *:w_a* *:write_a* *E494* -:[range]w[rite][!] [++opt] >> - Append the specified lines to the current file. - -:[range]w[rite][!] [++opt] >> {file} - Append the specified lines to {file}. '!' forces the - write even if file does not exist. - - *:w_c* *:write_c* -:[range]w[rite] [++opt] !{cmd} - Execute {cmd} with [range] lines as standard input - (note the space in front of the '!'). {cmd} is - executed like with ":!{cmd}", any '!' is replaced with - the previous command |:!|. - -The default [range] for the ":w" command is the whole buffer (1,$). If you -write the whole buffer, it is no longer considered changed. When you -write it to a different file with ":w somefile" it depends on the "+" flag in -'cpoptions'. When included, the write command will reset the 'modified' flag, -even though the buffer itself may still be different from its file. - -If a file name is given with ":w" it becomes the alternate file. This can be -used, for example, when the write fails and you want to try again later with -":w #". This can be switched off by removing the 'A' flag from the -'cpoptions' option. - - *:sav* *:saveas* -:sav[eas][!] [++opt] {file} - Save the current buffer under the name {file} and set - the filename of the current buffer to {file}. The - previous name is used for the alternate file name. - The [!] is needed to overwrite an existing file. - When 'filetype' is empty filetype detection is done - with the new name, before the file is written. - When the write was successful 'readonly' is reset. - {not in Vi} - - *:up* *:update* -:[range]up[date][!] [++opt] [>>] [file] - Like ":write", but only write when the buffer has been - modified. {not in Vi} - - -WRITING WITH MULTIPLE BUFFERS *buffer-write* - - *:wa* *:wall* -:wa[ll] Write all changed buffers. Buffers without a file - name or which are readonly are not written. {not in - Vi} - -:wa[ll]! Write all changed buffers, even the ones that are - readonly. Buffers without a file name are not - written. {not in Vi} - - -Vim will warn you if you try to overwrite a file that has been changed -elsewhere. See |timestamp|. - - *backup* *E207* *E506* *E507* *E508* *E509* *E510* -If you write to an existing file (but do not append) while the 'backup', -'writebackup' or 'patchmode' option is on, a backup of the original file is -made. The file is either copied or renamed (see 'backupcopy'). After the -file has been successfully written and when the 'writebackup' option is on and -the 'backup' option is off, the backup file is deleted. When the 'patchmode' -option is on the backup file may be renamed. - - *backup-table* -'backup' 'writebackup' action ~ - off off no backup made - off on backup current file, deleted afterwards (default) - on off delete old backup, backup current file - on on delete old backup, backup current file - -When the 'backupskip' pattern matches with the name of the file which is -written, no backup file is made. The values of 'backup' and 'writebackup' are -ignored then. - -When the 'backup' option is on, an old backup file (with the same name as the -new backup file) will be deleted. If 'backup' is not set, but 'writebackup' -is set, an existing backup file will not be deleted. The backup file that is -made while the file is being written will have a different name. - -On some filesystems it's possible that in a crash you lose both the backup and -the newly written file (it might be there but contain bogus data). In that -case try recovery, because the swap file is synced to disk and might still be -there. |:recover| - -The directories given with the 'backupdir' option is used to put the backup -file in. (default: same directory as the written file). - -Whether the backup is a new file, which is a copy of the original file, or the -original file renamed depends on the 'backupcopy' option. See there for an -explanation of when the copy is made and when the file is renamed. - -If the creation of a backup file fails, the write is not done. If you want -to write anyway add a '!' to the command. - - *write-readonly* -When the 'cpoptions' option contains 'W', Vim will refuse to overwrite a -readonly file. When 'W' is not present, ":w!" will overwrite a readonly file, -if the system allows it (the directory must be writable). - - *write-fail* -If the writing of the new file fails, you have to be careful not to lose -your changes AND the original file. If there is no backup file and writing -the new file failed, you have already lost the original file! DON'T EXIT VIM -UNTIL YOU WRITE OUT THE FILE! If a backup was made, it is put back in place -of the original file (if possible). If you exit Vim, and lose the changes -you made, the original file will mostly still be there. If putting back the -original file fails, there will be an error message telling you that you -lost the original file. - - *DOS-format-write* -If the 'fileformat' is "dos", is used for . This is default -for MS-DOS, Win32 and OS/2. On other systems the message "[dos format]" is -shown to remind you that an unusual was used. - *Unix-format-write* -If the 'fileformat' is "unix", is used for . On MS-DOS, Win32 and -OS/2 the message "[unix format]" is shown. - *Mac-format-write* -If the 'fileformat' is "mac", is used for . On non-Mac systems the -message "[mac format]" is shown. - -See also |file-formats| and the 'fileformat' and 'fileformats' options. - - *ACL* -ACL stands for Access Control List. It is an advanced way to control access -rights for a file. It is used on new MS-Windows and Unix systems, but only -when the filesystem supports it. - Vim attempts to preserve the ACL info when writing a file. The backup file -will get the ACL info of the original file. - The ACL info is also used to check if a file is read-only (when opening the -file). - - *read-only-share* -When MS-Windows shares a drive on the network it can be marked as read-only. -This means that even if the file read-only attribute is absent, and the ACL -settings on NT network shared drives allow writing to the file, you can still -not write to the file. Vim on Win32 platforms will detect read-only network -drives and will mark the file as read-only. You will not be able to override -it with |:write|. - - *write-device* -When the file name is actually a device name, Vim will not make a backup (that -would be impossible). You need to use "!", since the device already exists. -Example for Unix: > - :w! /dev/lpt0 -and for MS-DOS or MS-Windows: > - :w! lpt0 -For Unix a device is detected when the name doesn't refer to a normal file or -a directory. A fifo or named pipe also looks like a device to Vim. -For MS-DOS and MS-Windows the device is detected by its name: - AUX - CON - CLOCK$ - NUL - PRN - COMn n=1,2,3... etc - LPTn n=1,2,3... etc -The names can be in upper- or lowercase. - -============================================================================== -5. Writing and quitting *write-quit* - - *:q* *:quit* -:q[uit] Quit the current window. Quit Vim if this is the last - window. This fails when changes have been made and - Vim refuses to |abandon| the current buffer, and when - the last file in the argument list has not been - edited. - If there are other tab pages and quitting the last - window in the current tab page the current tab page is - closed |tab-page|. - -:conf[irm] q[uit] Quit, but give prompt when changes have been made, or - the last file in the argument list has not been - edited. See |:confirm| and 'confirm'. {not in Vi} - -:q[uit]! Quit without writing, also when visible buffers have - changes. Does not exit when there are changed hidden - buffers. Use ":qall!" to exit always. - -:cq[uit] Quit always, without writing, and return an error - code. See |:cq|. Used for Manx's QuickFix mode (see - |quickfix|). {not in Vi} - - *:wq* -:wq [++opt] Write the current file and quit. Writing fails when - the file is read-only or the buffer does not have a - name. Quitting fails when the last file in the - argument list has not been edited. - -:wq! [++opt] Write the current file and quit. Writing fails when - the current buffer does not have a name. - -:wq [++opt] {file} Write to {file} and quit. Quitting fails when the - last file in the argument list has not been edited. - -:wq! [++opt] {file} Write to {file} and quit. - -:[range]wq[!] [++opt] [file] - Same as above, but only write the lines in [range]. - - *:x* *:xit* -:[range]x[it][!] [++opt] [file] - Like ":wq", but write only when changes have been - made. - When 'hidden' is set and there are more windows, the - current buffer becomes hidden, after writing the file. - - *:exi* *:exit* -:[range]exi[t][!] [++opt] [file] - Same as :xit. - - *ZZ* -ZZ Write current file, if modified, and quit (same as - ":x"). (Note: If there are several windows for the - current file, the file is written if it was modified - and the window is closed). - - *ZQ* -ZQ Quit without checking for changes (same as ":q!"). - {not in Vi} - -MULTIPLE WINDOWS AND BUFFERS *window-exit* - - *:qa* *:qall* -:qa[ll] Exit Vim, unless there are some buffers which have been - changed. (Use ":bmod" to go to the next modified buffer). - When 'autowriteall' is set all changed buffers will be - written, like |:wqall|. {not in Vi} - -:conf[irm] qa[ll] - Exit Vim. Bring up a prompt when some buffers have been - changed. See |:confirm|. {not in Vi} - -:qa[ll]! Exit Vim. Any changes to buffers are lost. {not in Vi} - Also see |:cquit|, it does the same but exits with a non-zero - value. - - *:quita* *:quitall* -:quita[ll][!] Same as ":qall". {not in Vi} - -:wqa[ll] [++opt] *:wqa* *:wqall* *:xa* *:xall* -:xa[ll] Write all changed buffers and exit Vim. If there are buffers - without a file name, which are readonly or which cannot be - written for another reason, Vim will not quit. {not in Vi} - -:conf[irm] wqa[ll] [++opt] -:conf[irm] xa[ll] - Write all changed buffers and exit Vim. Bring up a prompt - when some buffers are readonly or cannot be written for - another reason. See |:confirm|. {not in Vi} - -:wqa[ll]! [++opt] -:xa[ll]! Write all changed buffers, even the ones that are readonly, - and exit Vim. If there are buffers without a file name or - which cannot be written for another reason, Vim will not quit. - {not in Vi} - -============================================================================== -6. Dialogs *edit-dialogs* - - *:confirm* *:conf* -:conf[irm] {command} Execute {command}, and use a dialog when an - operation has to be confirmed. Can be used on the - ":q", ":qa" and ":w" commands (the latter to over-ride - a read-only setting). - -Examples: > - :confirm w foo -< Will ask for confirmation when "foo" already exists. > - :confirm q -< Will ask for confirmation when there are changes. > - :confirm qa -< If any modified, unsaved buffers exist, you will be prompted to save - or abandon each one. There are also choices to "save all" or "abandon - all". - -If you want to always use ":confirm", set the 'confirm' option. - - *:browse* *:bro* *E338* *E614* *E615* *E616* *E578* -:bro[wse] {command} Open a file selection dialog for an argument to - {command}. At present this works for |:e|, |:w|, - |:r|, |:saveas|, |:sp|, |:mkexrc|, |:mkvimrc|, - |:mksession|, |:split|, |:vsplit|, and |:tabe|. - {only in Win32, Athena, Motif, GTK and Mac GUI} - When ":browse" is not possible you get an error - message. If the |+browse| feature is missing or the - {command} doesn't support browsing, the {command} is - executed without a dialog. - ":browse set" works like |:options|. - -The syntax is best shown via some examples: > - :browse e $vim/foo -< Open the browser in the $vim/foo directory, and edit the - file chosen. > - :browse e -< Open the browser in the directory specified with 'browsedir', - and edit the file chosen. > - :browse w -< Open the browser in the directory of the current buffer, - with the current buffer filename as default, and save the - buffer under the filename chosen. > - :browse w C:/bar -< Open the browser in the C:/bar directory, with the current - buffer filename as default, and save the buffer under the - filename chosen. -Also see the |'browsedir'| option. -For versions of Vim where browsing is not supported, the command is executed -unmodified. - - *browsefilter* -For MS Windows, you can modify the filters that are used in the browse dialog. -By setting the g:browsefilter or b:browsefilter variables, you can change the -filters globally or locally to the buffer. The variable is set to a string in -the format "{filter label}\t{pattern};{pattern}\n" where {filter label} is the -text that appears in the "Files of Type" comboBox, and {pattern} is the -pattern which filters the filenames. Several patterns can be given, separated -by ';'. - -For Motif the same format is used, but only the very first pattern is actually -used (Motif only offers one pattern, but you can edit it). - -For example, to have only Vim files in the dialog, you could use the following -command: > - - let g:browsefilter="Vim Scripts\t*.vim\nVim Startup Files\t*vimrc\n" - -You can override the filter setting on a per-buffer basis by setting the -b:browsefilter variable. You would most likely set b:browsefilter in a -filetype plugin, so that the browse dialog would contain entries related to -the type of file you are currently editing. Disadvantage: This makes it -difficult to start editing a file of a different type. To overcome this, you -may want to add "All Files\t*.*\n" as the final filter, so that the user can -still access any desired file. - -============================================================================== -7. The current directory *current-directory* - -You may use the |:cd| and |:lcd| commands to change to another directory, so -you will not have to type that directory name in front of the file names. It -also makes a difference for executing external commands, e.g. ":!ls". - -Changing directory fails when the current buffer is modified, the '.' flag is -present in 'cpoptions' and "!" is not used in the command. - - *:cd* *E747* *E472* -:cd[!] On non-Unix systems: Print the current directory - name. On Unix systems: Change the current directory - to the home directory. Use |:pwd| to print the - current directory on all systems. - -:cd[!] {path} Change the current directory to {path}. - If {path} is relative, it is searched for in the - directories listed in |'cdpath'|. - Does not change the meaning of an already opened file, - because its full path name is remembered. Files from - the |arglist| may change though! - On MS-DOS this also changes the active drive. - To change to the directory of the current file: > - :cd %:h -< - *:cd-* *E186* -:cd[!] - Change to the previous current directory (before the - previous ":cd {path}" command). {not in Vi} - - *:chd* *:chdir* -:chd[ir][!] [path] Same as |:cd|. - - *:lc* *:lcd* -:lc[d][!] {path} Like |:cd|, but only set the current directory for the - current window. The current directory for other - windows is not changed. {not in Vi} - - *:lch* *:lchdir* -:lch[dir][!] Same as |:lcd|. {not in Vi} - - *:pw* *:pwd* *E187* -:pw[d] Print the current directory name. {Vi: no pwd} - Also see |getcwd()|. - -So long as no |:lcd| command has been used, all windows share the same current -directory. Using a command to jump to another window doesn't change anything -for the current directory. -When a |:lcd| command has been used for a window, the specified directory -becomes the current directory for that window. Windows where the |:lcd| -command has not been used stick to the global current directory. When jumping -to another window the current directory will become the last specified local -current directory. If none was specified, the global current directory is -used. -When a |:cd| command is used, the current window will lose his local current -directory and will use the global current directory from now on. - -After using |:cd| the full path name will be used for reading and writing -files. On some networked file systems this may cause problems. The result of -using the full path name is that the file names currently in use will remain -referring to the same file. Example: If you have a file a:test and a -directory a:vim the commands ":e test" ":cd vim" ":w" will overwrite the file -a:test and not write a:vim/test. But if you do ":w test" the file a:vim/test -will be written, because you gave a new file name and did not refer to a -filename before the ":cd". - -============================================================================== -8. Editing binary files *edit-binary* - -Although Vim was made to edit text files, it is possible to edit binary -files. The |-b| Vim argument (b for binary) makes Vim do file I/O in binary -mode, and sets some options for editing binary files ('binary' on, 'textwidth' -to 0, 'modeline' off, 'expandtab' off). Setting the 'binary' option has the -same effect. Don't forget to do this before reading the file. - -There are a few things to remember when editing binary files: -- When editing executable files the number of characters must not change. - Use only the "R" or "r" command to change text. Do not delete characters - with "x" or by backspacing. -- Set the 'textwidth' option to 0. Otherwise lines will unexpectedly be - split in two. -- When there are not many s, the lines will become very long. If you - want to edit a line that does not fit on the screen reset the 'wrap' option. - Horizontal scrolling is used then. If a line becomes too long (more than - about 32767 characters on the Amiga, much more on 32-bit systems, see - |limits|) you cannot edit that line. The line will be split when reading - the file. It is also possible that you get an "out of memory" error when - reading the file. -- Make sure the 'binary' option is set BEFORE loading the - file. Otherwise both and are considered to end a line - and when the file is written the will be replaced with . -- characters are shown on the screen as ^@. You can enter them with - "CTRL-V CTRL-@" or "CTRL-V 000" {Vi cannot handle characters in the - file} -- To insert a character in the file split up a line. When writing the - buffer to a file a will be written for the . -- Vim normally appends an at the end of the file if there is none. - Setting the 'binary' option prevents this. If you want to add the final - , set the 'endofline' option. You can also read the value of this - option to see if there was an for the last line (you cannot see this - in the text). - -============================================================================== -9. Encryption *encryption* - -Vim is able to write files encrypted, and read them back. The encrypted text -cannot be read without the right key. - -Note: The swapfile and text in memory is not encrypted. A system -administrator will be able to see your text while you are editing it. -When filtering text with ":!filter" or using ":w !command" the text is not -encrypted, this may reveal it to others. - -WARNING: If you make a typo when entering the key and then write the file and -exit, the text will be lost! - -The normal way to work with encryption, is to use the ":X" command, which will -ask you to enter a key. A following write command will use that key to -encrypt the file. If you later edit the same file, Vim will ask you to enter -a key. If you type the same key as that was used for writing, the text will -be readable again. If you use a wrong key, it will be a mess. - - *:X* -:X Prompt for an encryption key. The typing is done without showing the - actual text, so that someone looking at the display won't see it. - The typed key is stored in the 'key' option, which is used to encrypt - the file when it is written. The file will remain unchanged until you - write it. See also |-x|. - -The value of the 'key' options is used when text is written. When the option -is not empty, the written file will be encrypted, using the value as the -encryption key. A magic number is prepended, so that Vim can recognize that -the file is encrypted. - -To disable the encryption, reset the 'key' option to an empty value: > - :set key= - -When reading a file that has been encrypted and this option is not empty, it -will be used for decryption. If the value is empty, you will be prompted to -enter the key. If you don't enter a key, the file is edited without being -decrypted. - -If want to start reading a file that uses a different key, set the 'key' -option to an empty string, so that Vim will prompt for a new one. Don't use -the ":set" command to enter the value, other people can read the command over -your shoulder. - -Since the value of the 'key' option is supposed to be a secret, its value can -never be viewed. You should not set this option in a vimrc file. - -An encrypted file can be recognized by the "file" command, if you add this -line to "/etc/magic", "/usr/share/misc/magic" or wherever your system has the -"magic" file: > - 0 string VimCrypt~ Vim encrypted file - -Notes: -- Encryption is not possible when doing conversion with 'charconvert'. -- Text you copy or delete goes to the numbered registers. The registers can - be saved in the .viminfo file, where they could be read. Change your - 'viminfo' option to be safe. -- Someone can type commands in Vim when you walk away for a moment, he should - not be able to get the key. -- If you make a typing mistake when entering the key, you might not be able to - get your text back! -- If you type the key with a ":set key=value" command, it can be kept in the - history, showing the 'key' value in a viminfo file. -- There is never 100% safety. The encryption in Vim has not been tested for - robustness. -- The algorithm used is breakable. A 4 character key in about one hour, a 6 - character key in one day (on a Pentium 133 PC). This requires that you know - some text that must appear in the file. An expert can break it for any key. - When the text has been decrypted, this also means that the key can be - revealed, and other files encrypted with the same key can be decrypted. -- Pkzip uses the same encryption, and US Govt has no objection to its export. - Pkzip's public file APPNOTE.TXT describes this algorithm in detail. -- Vim originates from the Netherlands. That is where the sources come from. - Thus the encryption code is not exported from the USA. - -============================================================================== -10. Timestamps *timestamp* *timestamps* - -Vim remembers the modification timestamp of a file when you begin editing it. -This is used to avoid that you have two different versions of the same file -(without you knowing this). - -After a shell command is run (|:!cmd| |suspend| |:read!| |K|) timestamps are -compared for all buffers in a window. Vim will run any associated -|FileChangedShell| autocommands or display a warning for any files that have -changed. In the GUI this happens when Vim regains input focus. - - *E321* *E462* -If you want to automatically reload a file when it has been changed outside of -Vim, set the 'autoread' option. This doesn't work at the moment you write the -file though, only when the file wasn't changed inside of Vim. - -Note that if a FileChangedShell autocommand is defined you will not get a -warning message or prompt. The autocommand is expected to handle this. - -There is no warning for a directory (e.g., with |netrw-browse|). But you do -get warned if you started editing a new file and it was created as a directory -later. - -When Vim notices the timestamp of a file has changed, and the file is being -edited in a buffer but has not changed, Vim checks if the contents of the file -is equal. This is done by reading the file again (into a hidden buffer, which -is immediately deleted again) and comparing the text. If the text is equal, -you will get no warning. - -If you don't get warned often enough you can use the following command. - - *:checkt* *:checktime* -:checkt[ime] Check if any buffers were changed outside of Vim. - This checks and warns you if you would end up with two - versions of a file. - If this is called from an autocommand, a ":global" - command or is not typed the actual check is postponed - until a moment the side effects (reloading the file) - would be harmless. - Each loaded buffer is checked for its associated file - being changed. If the file was changed Vim will take - action. If there are no changes in the buffer and - 'autoread' is set, the buffer is reloaded. Otherwise, - you are offered the choice of reloading the file. If - the file was deleted you get an error message. - If the file previously didn't exist you get a warning - if it exists now. - Once a file has been checked the timestamp is reset, - you will not be warned again. - -:[N]checkt[ime] {filename} -:[N]checkt[ime] [N] - Check the timestamp of a specific buffer. The buffer - may be specified by name, number or with a pattern. - - -Before writing a file the timestamp is checked. If it has changed, Vim will -ask if you really want to overwrite the file: - - WARNING: The file has been changed since reading it!!! - Do you really want to write to it (y/n)? - -If you hit 'y' Vim will continue writing the file. If you hit 'n' the write is -aborted. If you used ":wq" or "ZZ" Vim will not exit, you will get another -chance to write the file. - -The message would normally mean that somebody has written to the file after -the edit session started. This could be another person, in which case you -probably want to check if your changes to the file and the changes from the -other person should be merged. Write the file under another name and check for -differences (the "diff" program can be used for this). - -It is also possible that you modified the file yourself, from another edit -session or with another command (e.g., a filter command). Then you will know -which version of the file you want to keep. - -There is one situation where you get the message while there is nothing wrong: -On a Win32 system on the day daylight saving time starts. There is something -in the Win32 libraries that confuses Vim about the hour time difference. The -problem goes away the next day. - -============================================================================== -11. File Searching *file-searching* - -{not available when compiled without the |+path_extra| feature} - -The file searching is currently used for the 'path', 'cdpath' and 'tags' -options, for |finddir()| and |findfile()|. Other commands use |wildcards| -which is slightly different. - -There are three different types of searching: - -1) Downward search: *starstar* - Downward search uses the wildcards '*', '**' and possibly others - supported by your operating system. '*' and '**' are handled inside Vim, - so they work on all operating systems. Note that "**" only acts as a - special wildcard when it is at the start of a name. - - The usage of '*' is quite simple: It matches 0 or more characters. In a - search pattern this would be ".*". Note that the "." is not used for file - searching. - - '**' is more sophisticated: - - It ONLY matches directories. - - It matches up to 30 directories deep by default, so you can use it to - search an entire directory tree - - The maximum number of levels matched can be given by appending a number - to '**'. - Thus '/usr/**2' can match: > - /usr - /usr/include - /usr/include/sys - /usr/include/g++ - /usr/lib - /usr/lib/X11 - .... -< It does NOT match '/usr/include/g++/std' as this would be three - levels. - The allowed number range is 0 ('**0' is removed) to 100 - If the given number is smaller than 0 it defaults to 30, if it's - bigger than 100 then 100 is used. The system also has a limit on the - path length, usually 256 or 1024 bytes. - - '**' can only be at the end of the path or be followed by a path - separator or by a number and a path separator. - - You can combine '*' and '**' in any order: > - /usr/**/sys/* - /usr/*tory/sys/** - /usr/**2/sys/* - -2) Upward search: - Here you can give a directory and then search the directory tree upward for - a file. You could give stop-directories to limit the upward search. The - stop-directories are appended to the path (for the 'path' option) or to - the filename (for the 'tags' option) with a ';'. If you want several - stop-directories separate them with ';'. If you want no stop-directory - ("search upward till the root directory) just use ';'. > - /usr/include/sys;/usr -< will search in: > - /usr/include/sys - /usr/include - /usr -< - If you use a relative path the upward search is started in Vim's current - directory or in the directory of the current file (if the relative path - starts with './' and 'd' is not included in 'cpoptions'). - - If Vim's current path is /u/user_x/work/release and you do > - :set path=include;/u/user_x -< and then search for a file with |gf| the file is searched in: > - /u/user_x/work/release/include - /u/user_x/work/include - /u/user_x/include - -3) Combined up/downward search: - If Vim's current path is /u/user_x/work/release and you do > - set path=**;/u/user_x -< and then search for a file with |gf| the file is searched in: > - /u/user_x/work/release/** - /u/user_x/work/** - /u/user_x/** -< - BE CAREFUL! This might consume a lot of time, as the search of - '/u/user_x/**' includes '/u/user_x/work/**' and - '/u/user_x/work/release/**'. So '/u/user_x/work/release/**' is searched - three times and '/u/user_x/work/**' is searched twice. - - In the above example you might want to set path to: > - :set path=**,/u/user_x/** -< This searches: > - /u/user_x/work/release/** - /u/user_x/** -< This searches the same directories, but in a different order. - - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/eval.txt b/share/vim/vim72/doc/eval.txt deleted file mode 100644 index 81afadcaa8..0000000000 --- a/share/vim/vim72/doc/eval.txt +++ /dev/null @@ -1,7986 +0,0 @@ -*eval.txt* For Vim version 7.2. Last change: 2008 Nov 02 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Expression evaluation *expression* *expr* *E15* *eval* - -Using expressions is introduced in chapter 41 of the user manual |usr_41.txt|. - -Note: Expression evaluation can be disabled at compile time. If this has been -done, the features in this document are not available. See |+eval| and -|no-eval-feature|. - -1. Variables |variables| - 1.1 Variable types - 1.2 Function references |Funcref| - 1.3 Lists |Lists| - 1.4 Dictionaries |Dictionaries| - 1.5 More about variables |more-variables| -2. Expression syntax |expression-syntax| -3. Internal variable |internal-variables| -4. Builtin Functions |functions| -5. Defining functions |user-functions| -6. Curly braces names |curly-braces-names| -7. Commands |expression-commands| -8. Exception handling |exception-handling| -9. Examples |eval-examples| -10. No +eval feature |no-eval-feature| -11. The sandbox |eval-sandbox| -12. Textlock |textlock| - -{Vi does not have any of these commands} - -============================================================================== -1. Variables *variables* - -1.1 Variable types ~ - *E712* -There are six types of variables: - -Number A 32 bit signed number. |expr-number| *Number* - Examples: -123 0x10 0177 - -Float A floating point number. |floating-point-format| *Float* - {only when compiled with the |+float| feature} - Examples: 123.456 1.15e-6 -1.1e3 - -String A NUL terminated string of 8-bit unsigned characters (bytes). - |expr-string| Examples: "ab\txx\"--" 'x-z''a,c' - -Funcref A reference to a function |Funcref|. - Example: function("strlen") - -List An ordered sequence of items |List|. - Example: [1, 2, ['a', 'b']] - -Dictionary An associative, unordered array: Each entry has a key and a - value. |Dictionary| - Example: {'blue': "#0000ff", 'red': "#ff0000"} - -The Number and String types are converted automatically, depending on how they -are used. - -Conversion from a Number to a String is by making the ASCII representation of -the Number. Examples: > - Number 123 --> String "123" - Number 0 --> String "0" - Number -1 --> String "-1" - -Conversion from a String to a Number is done by converting the first digits -to a number. Hexadecimal "0xf9" and Octal "017" numbers are recognized. If -the String doesn't start with digits, the result is zero. Examples: > - String "456" --> Number 456 - String "6bar" --> Number 6 - String "foo" --> Number 0 - String "0xf1" --> Number 241 - String "0100" --> Number 64 - String "-8" --> Number -8 - String "+8" --> Number 0 - -To force conversion from String to Number, add zero to it: > - :echo "0100" + 0 -< 64 ~ - -To avoid a leading zero to cause octal conversion, or for using a different -base, use |str2nr()|. - -For boolean operators Numbers are used. Zero is FALSE, non-zero is TRUE. - -Note that in the command > - :if "foo" -"foo" is converted to 0, which means FALSE. To test for a non-empty string, -use strlen(): > - :if strlen("foo") -< *E745* *E728* *E703* *E729* *E730* *E731* -List, Dictionary and Funcref types are not automatically converted. - - *E805* *E806* *E808* -When mixing Number and Float the Number is converted to Float. Otherwise -there is no automatic conversion of Float. You can use str2float() for String -to Float, printf() for Float to String and float2nr() for Float to Number. - - *E706* *sticky-type-checking* -You will get an error if you try to change the type of a variable. You need -to |:unlet| it first to avoid this error. String and Number are considered -equivalent though, as well are Float and Number. Consider this sequence of -commands: > - :let l = "string" - :let l = 44 " changes type from String to Number - :let l = [1, 2, 3] " error! l is still a Number - :let l = 4.4 " changes type from Number to Float - :let l = "string" " error! - - -1.2 Function references ~ - *Funcref* *E695* *E718* -A Funcref variable is obtained with the |function()| function. It can be used -in an expression in the place of a function name, before the parenthesis -around the arguments, to invoke the function it refers to. Example: > - - :let Fn = function("MyFunc") - :echo Fn() -< *E704* *E705* *E707* -A Funcref variable must start with a capital, "s:", "w:", "t:" or "b:". You -cannot have both a Funcref variable and a function with the same name. - -A special case is defining a function and directly assigning its Funcref to a -Dictionary entry. Example: > - :function dict.init() dict - : let self.val = 0 - :endfunction - -The key of the Dictionary can start with a lower case letter. The actual -function name is not used here. Also see |numbered-function|. - -A Funcref can also be used with the |:call| command: > - :call Fn() - :call dict.init() - -The name of the referenced function can be obtained with |string()|. > - :let func = string(Fn) - -You can use |call()| to invoke a Funcref and use a list variable for the -arguments: > - :let r = call(Fn, mylist) - - -1.3 Lists ~ - *List* *Lists* *E686* -A List is an ordered sequence of items. An item can be of any type. Items -can be accessed by their index number. Items can be added and removed at any -position in the sequence. - - -List creation ~ - *E696* *E697* -A List is created with a comma separated list of items in square brackets. -Examples: > - :let mylist = [1, two, 3, "four"] - :let emptylist = [] - -An item can be any expression. Using a List for an item creates a -List of Lists: > - :let nestlist = [[11, 12], [21, 22], [31, 32]] - -An extra comma after the last item is ignored. - - -List index ~ - *list-index* *E684* -An item in the List can be accessed by putting the index in square brackets -after the List. Indexes are zero-based, thus the first item has index zero. > - :let item = mylist[0] " get the first item: 1 - :let item = mylist[2] " get the third item: 3 - -When the resulting item is a list this can be repeated: > - :let item = nestlist[0][1] " get the first list, second item: 12 -< -A negative index is counted from the end. Index -1 refers to the last item in -the List, -2 to the last but one item, etc. > - :let last = mylist[-1] " get the last item: "four" - -To avoid an error for an invalid index use the |get()| function. When an item -is not available it returns zero or the default value you specify: > - :echo get(mylist, idx) - :echo get(mylist, idx, "NONE") - - -List concatenation ~ - -Two lists can be concatenated with the "+" operator: > - :let longlist = mylist + [5, 6] - :let mylist += [7, 8] - -To prepend or append an item turn the item into a list by putting [] around -it. To change a list in-place see |list-modification| below. - - -Sublist ~ - -A part of the List can be obtained by specifying the first and last index, -separated by a colon in square brackets: > - :let shortlist = mylist[2:-1] " get List [3, "four"] - -Omitting the first index is similar to zero. Omitting the last index is -similar to -1. > - :let endlist = mylist[2:] " from item 2 to the end: [3, "four"] - :let shortlist = mylist[2:2] " List with one item: [3] - :let otherlist = mylist[:] " make a copy of the List - -If the first index is beyond the last item of the List or the second item is -before the first item, the result is an empty list. There is no error -message. - -If the second index is equal to or greater than the length of the list the -length minus one is used: > - :let mylist = [0, 1, 2, 3] - :echo mylist[2:8] " result: [2, 3] - -NOTE: mylist[s:e] means using the variable "s:e" as index. Watch out for -using a single letter variable before the ":". Insert a space when needed: -mylist[s : e]. - - -List identity ~ - *list-identity* -When variable "aa" is a list and you assign it to another variable "bb", both -variables refer to the same list. Thus changing the list "aa" will also -change "bb": > - :let aa = [1, 2, 3] - :let bb = aa - :call add(aa, 4) - :echo bb -< [1, 2, 3, 4] - -Making a copy of a list is done with the |copy()| function. Using [:] also -works, as explained above. This creates a shallow copy of the list: Changing -a list item in the list will also change the item in the copied list: > - :let aa = [[1, 'a'], 2, 3] - :let bb = copy(aa) - :call add(aa, 4) - :let aa[0][1] = 'aaa' - :echo aa -< [[1, aaa], 2, 3, 4] > - :echo bb -< [[1, aaa], 2, 3] - -To make a completely independent list use |deepcopy()|. This also makes a -copy of the values in the list, recursively. Up to a hundred levels deep. - -The operator "is" can be used to check if two variables refer to the same -List. "isnot" does the opposite. In contrast "==" compares if two lists have -the same value. > - :let alist = [1, 2, 3] - :let blist = [1, 2, 3] - :echo alist is blist -< 0 > - :echo alist == blist -< 1 - -Note about comparing lists: Two lists are considered equal if they have the -same length and all items compare equal, as with using "==". There is one -exception: When comparing a number with a string they are considered -different. There is no automatic type conversion, as with using "==" on -variables. Example: > - echo 4 == "4" -< 1 > - echo [4] == ["4"] -< 0 - -Thus comparing Lists is more strict than comparing numbers and strings. You -can compare simple values this way too by putting them in a list: > - - :let a = 5 - :let b = "5" - :echo a == b -< 1 > - :echo [a] == [b] -< 0 - - -List unpack ~ - -To unpack the items in a list to individual variables, put the variables in -square brackets, like list items: > - :let [var1, var2] = mylist - -When the number of variables does not match the number of items in the list -this produces an error. To handle any extra items from the list append ";" -and a variable name: > - :let [var1, var2; rest] = mylist - -This works like: > - :let var1 = mylist[0] - :let var2 = mylist[1] - :let rest = mylist[2:] - -Except that there is no error if there are only two items. "rest" will be an -empty list then. - - -List modification ~ - *list-modification* -To change a specific item of a list use |:let| this way: > - :let list[4] = "four" - :let listlist[0][3] = item - -To change part of a list you can specify the first and last item to be -modified. The value must at least have the number of items in the range: > - :let list[3:5] = [3, 4, 5] - -Adding and removing items from a list is done with functions. Here are a few -examples: > - :call insert(list, 'a') " prepend item 'a' - :call insert(list, 'a', 3) " insert item 'a' before list[3] - :call add(list, "new") " append String item - :call add(list, [1, 2]) " append a List as one new item - :call extend(list, [1, 2]) " extend the list with two more items - :let i = remove(list, 3) " remove item 3 - :unlet list[3] " idem - :let l = remove(list, 3, -1) " remove items 3 to last item - :unlet list[3 : ] " idem - :call filter(list, 'v:val !~ "x"') " remove items with an 'x' - -Changing the order of items in a list: > - :call sort(list) " sort a list alphabetically - :call reverse(list) " reverse the order of items - - -For loop ~ - -The |:for| loop executes commands for each item in a list. A variable is set -to each item in the list in sequence. Example: > - :for item in mylist - : call Doit(item) - :endfor - -This works like: > - :let index = 0 - :while index < len(mylist) - : let item = mylist[index] - : :call Doit(item) - : let index = index + 1 - :endwhile - -Note that all items in the list should be of the same type, otherwise this -results in error |E706|. To avoid this |:unlet| the variable at the end of -the loop. - -If all you want to do is modify each item in the list then the |map()| -function will be a simpler method than a for loop. - -Just like the |:let| command, |:for| also accepts a list of variables. This -requires the argument to be a list of lists. > - :for [lnum, col] in [[1, 3], [2, 8], [3, 0]] - : call Doit(lnum, col) - :endfor - -This works like a |:let| command is done for each list item. Again, the types -must remain the same to avoid an error. - -It is also possible to put remaining items in a List variable: > - :for [i, j; rest] in listlist - : call Doit(i, j) - : if !empty(rest) - : echo "remainder: " . string(rest) - : endif - :endfor - - -List functions ~ - *E714* -Functions that are useful with a List: > - :let r = call(funcname, list) " call a function with an argument list - :if empty(list) " check if list is empty - :let l = len(list) " number of items in list - :let big = max(list) " maximum value in list - :let small = min(list) " minimum value in list - :let xs = count(list, 'x') " count nr of times 'x' appears in list - :let i = index(list, 'x') " index of first 'x' in list - :let lines = getline(1, 10) " get ten text lines from buffer - :call append('$', lines) " append text lines in buffer - :let list = split("a b c") " create list from items in a string - :let string = join(list, ', ') " create string from list items - :let s = string(list) " String representation of list - :call map(list, '">> " . v:val') " prepend ">> " to each item - -Don't forget that a combination of features can make things simple. For -example, to add up all the numbers in a list: > - :exe 'let sum = ' . join(nrlist, '+') - - -1.4 Dictionaries ~ - *Dictionaries* *Dictionary* -A Dictionary is an associative array: Each entry has a key and a value. The -entry can be located with the key. The entries are stored without a specific -ordering. - - -Dictionary creation ~ - *E720* *E721* *E722* *E723* -A Dictionary is created with a comma separated list of entries in curly -braces. Each entry has a key and a value, separated by a colon. Each key can -only appear once. Examples: > - :let mydict = {1: 'one', 2: 'two', 3: 'three'} - :let emptydict = {} -< *E713* *E716* *E717* -A key is always a String. You can use a Number, it will be converted to a -String automatically. Thus the String '4' and the number 4 will find the same -entry. Note that the String '04' and the Number 04 are different, since the -Number will be converted to the String '4'. - -A value can be any expression. Using a Dictionary for a value creates a -nested Dictionary: > - :let nestdict = {1: {11: 'a', 12: 'b'}, 2: {21: 'c'}} - -An extra comma after the last entry is ignored. - - -Accessing entries ~ - -The normal way to access an entry is by putting the key in square brackets: > - :let val = mydict["one"] - :let mydict["four"] = 4 - -You can add new entries to an existing Dictionary this way, unlike Lists. - -For keys that consist entirely of letters, digits and underscore the following -form can be used |expr-entry|: > - :let val = mydict.one - :let mydict.four = 4 - -Since an entry can be any type, also a List and a Dictionary, the indexing and -key lookup can be repeated: > - :echo dict.key[idx].key - - -Dictionary to List conversion ~ - -You may want to loop over the entries in a dictionary. For this you need to -turn the Dictionary into a List and pass it to |:for|. - -Most often you want to loop over the keys, using the |keys()| function: > - :for key in keys(mydict) - : echo key . ': ' . mydict[key] - :endfor - -The List of keys is unsorted. You may want to sort them first: > - :for key in sort(keys(mydict)) - -To loop over the values use the |values()| function: > - :for v in values(mydict) - : echo "value: " . v - :endfor - -If you want both the key and the value use the |items()| function. It returns -a List in which each item is a List with two items, the key and the value: > - :for [key, value] in items(mydict) - : echo key . ': ' . value - :endfor - - -Dictionary identity ~ - *dict-identity* -Just like Lists you need to use |copy()| and |deepcopy()| to make a copy of a -Dictionary. Otherwise, assignment results in referring to the same -Dictionary: > - :let onedict = {'a': 1, 'b': 2} - :let adict = onedict - :let adict['a'] = 11 - :echo onedict['a'] - 11 - -Two Dictionaries compare equal if all the key-value pairs compare equal. For -more info see |list-identity|. - - -Dictionary modification ~ - *dict-modification* -To change an already existing entry of a Dictionary, or to add a new entry, -use |:let| this way: > - :let dict[4] = "four" - :let dict['one'] = item - -Removing an entry from a Dictionary is done with |remove()| or |:unlet|. -Three ways to remove the entry with key "aaa" from dict: > - :let i = remove(dict, 'aaa') - :unlet dict.aaa - :unlet dict['aaa'] - -Merging a Dictionary with another is done with |extend()|: > - :call extend(adict, bdict) -This extends adict with all entries from bdict. Duplicate keys cause entries -in adict to be overwritten. An optional third argument can change this. -Note that the order of entries in a Dictionary is irrelevant, thus don't -expect ":echo adict" to show the items from bdict after the older entries in -adict. - -Weeding out entries from a Dictionary can be done with |filter()|: > - :call filter(dict, 'v:val =~ "x"') -This removes all entries from "dict" with a value not matching 'x'. - - -Dictionary function ~ - *Dictionary-function* *self* *E725* -When a function is defined with the "dict" attribute it can be used in a -special way with a dictionary. Example: > - :function Mylen() dict - : return len(self.data) - :endfunction - :let mydict = {'data': [0, 1, 2, 3], 'len': function("Mylen")} - :echo mydict.len() - -This is like a method in object oriented programming. The entry in the -Dictionary is a |Funcref|. The local variable "self" refers to the dictionary -the function was invoked from. - -It is also possible to add a function without the "dict" attribute as a -Funcref to a Dictionary, but the "self" variable is not available then. - - *numbered-function* *anonymous-function* -To avoid the extra name for the function it can be defined and directly -assigned to a Dictionary in this way: > - :let mydict = {'data': [0, 1, 2, 3]} - :function mydict.len() dict - : return len(self.data) - :endfunction - :echo mydict.len() - -The function will then get a number and the value of dict.len is a |Funcref| -that references this function. The function can only be used through a -|Funcref|. It will automatically be deleted when there is no |Funcref| -remaining that refers to it. - -It is not necessary to use the "dict" attribute for a numbered function. - - -Functions for Dictionaries ~ - *E715* -Functions that can be used with a Dictionary: > - :if has_key(dict, 'foo') " TRUE if dict has entry with key "foo" - :if empty(dict) " TRUE if dict is empty - :let l = len(dict) " number of items in dict - :let big = max(dict) " maximum value in dict - :let small = min(dict) " minimum value in dict - :let xs = count(dict, 'x') " count nr of times 'x' appears in dict - :let s = string(dict) " String representation of dict - :call map(dict, '">> " . v:val') " prepend ">> " to each item - - -1.5 More about variables ~ - *more-variables* -If you need to know the type of a variable or expression, use the |type()| -function. - -When the '!' flag is included in the 'viminfo' option, global variables that -start with an uppercase letter, and don't contain a lowercase letter, are -stored in the viminfo file |viminfo-file|. - -When the 'sessionoptions' option contains "global", global variables that -start with an uppercase letter and contain at least one lowercase letter are -stored in the session file |session-file|. - -variable name can be stored where ~ -my_var_6 not -My_Var_6 session file -MY_VAR_6 viminfo file - - -It's possible to form a variable name with curly braces, see -|curly-braces-names|. - -============================================================================== -2. Expression syntax *expression-syntax* - -Expression syntax summary, from least to most significant: - -|expr1| expr2 ? expr1 : expr1 if-then-else - -|expr2| expr3 || expr3 .. logical OR - -|expr3| expr4 && expr4 .. logical AND - -|expr4| expr5 == expr5 equal - expr5 != expr5 not equal - expr5 > expr5 greater than - expr5 >= expr5 greater than or equal - expr5 < expr5 smaller than - expr5 <= expr5 smaller than or equal - expr5 =~ expr5 regexp matches - expr5 !~ expr5 regexp doesn't match - - expr5 ==? expr5 equal, ignoring case - expr5 ==# expr5 equal, match case - etc. As above, append ? for ignoring case, # for - matching case - - expr5 is expr5 same |List| instance - expr5 isnot expr5 different |List| instance - -|expr5| expr6 + expr6 .. number addition or list concatenation - expr6 - expr6 .. number subtraction - expr6 . expr6 .. string concatenation - -|expr6| expr7 * expr7 .. number multiplication - expr7 / expr7 .. number division - expr7 % expr7 .. number modulo - -|expr7| ! expr7 logical NOT - - expr7 unary minus - + expr7 unary plus - - -|expr8| expr8[expr1] byte of a String or item of a |List| - expr8[expr1 : expr1] substring of a String or sublist of a |List| - expr8.name entry in a |Dictionary| - expr8(expr1, ...) function call with |Funcref| variable - -|expr9| number number constant - "string" string constant, backslash is special - 'string' string constant, ' is doubled - [expr1, ...] |List| - {expr1: expr1, ...} |Dictionary| - &option option value - (expr1) nested expression - variable internal variable - va{ria}ble internal variable with curly braces - $VAR environment variable - @r contents of register 'r' - function(expr1, ...) function call - func{ti}on(expr1, ...) function call with curly braces - - -".." indicates that the operations in this level can be concatenated. -Example: > - &nu || &list && &shell == "csh" - -All expressions within one level are parsed from left to right. - - -expr1 *expr1* *E109* ------ - -expr2 ? expr1 : expr1 - -The expression before the '?' is evaluated to a number. If it evaluates to -non-zero, the result is the value of the expression between the '?' and ':', -otherwise the result is the value of the expression after the ':'. -Example: > - :echo lnum == 1 ? "top" : lnum - -Since the first expression is an "expr2", it cannot contain another ?:. The -other two expressions can, thus allow for recursive use of ?:. -Example: > - :echo lnum == 1 ? "top" : lnum == 1000 ? "last" : lnum - -To keep this readable, using |line-continuation| is suggested: > - :echo lnum == 1 - :\ ? "top" - :\ : lnum == 1000 - :\ ? "last" - :\ : lnum - -You should always put a space before the ':', otherwise it can be mistaken for -use in a variable such as "a:1". - - -expr2 and expr3 *expr2* *expr3* ---------------- - - *expr-barbar* *expr-&&* -The "||" and "&&" operators take one argument on each side. The arguments -are (converted to) Numbers. The result is: - - input output ~ -n1 n2 n1 || n2 n1 && n2 ~ -zero zero zero zero -zero non-zero non-zero zero -non-zero zero non-zero zero -non-zero non-zero non-zero non-zero - -The operators can be concatenated, for example: > - - &nu || &list && &shell == "csh" - -Note that "&&" takes precedence over "||", so this has the meaning of: > - - &nu || (&list && &shell == "csh") - -Once the result is known, the expression "short-circuits", that is, further -arguments are not evaluated. This is like what happens in C. For example: > - - let a = 1 - echo a || b - -This is valid even if there is no variable called "b" because "a" is non-zero, -so the result must be non-zero. Similarly below: > - - echo exists("b") && b == "yes" - -This is valid whether "b" has been defined or not. The second clause will -only be evaluated if "b" has been defined. - - -expr4 *expr4* ------ - -expr5 {cmp} expr5 - -Compare two expr5 expressions, resulting in a 0 if it evaluates to false, or 1 -if it evaluates to true. - - *expr-==* *expr-!=* *expr->* *expr->=* - *expr-<* *expr-<=* *expr-=~* *expr-!~* - *expr-==#* *expr-!=#* *expr->#* *expr->=#* - *expr-<#* *expr-<=#* *expr-=~#* *expr-!~#* - *expr-==?* *expr-!=?* *expr->?* *expr->=?* - *expr- ># >? -greater than or equal >= >=# >=? -smaller than < <# - 1 . 90 + 90.0 -As: > - (1 . 90) + 90.0 -That works, since the String "190" is automatically converted to the Number -190, which can be added to the Float 90.0. However: > - 1 . 90 * 90.0 -Should be read as: > - 1 . (90 * 90.0) -Since '.' has lower precedence than '*'. This does NOT work, since this -attempts to concatenate a Float and a String. - -When dividing a Number by zero the result depends on the value: - 0 / 0 = -0x80000000 (like NaN for Float) - >0 / 0 = 0x7fffffff (like positive infinity) - <0 / 0 = -0x7fffffff (like negative infinity) - (before Vim 7.2 it was always 0x7fffffff) - -When the righthand side of '%' is zero, the result is 0. - -None of these work for |Funcref|s. - -. and % do not work for Float. *E804* - - -expr7 *expr7* ------ -! expr7 logical NOT *expr-!* -- expr7 unary minus *expr-unary--* -+ expr7 unary plus *expr-unary-+* - -For '!' non-zero becomes zero, zero becomes one. -For '-' the sign of the number is changed. -For '+' the number is unchanged. - -A String will be converted to a Number first. - -These three can be repeated and mixed. Examples: - !-1 == 0 - !!8 == 1 - --9 == 9 - - -expr8 *expr8* ------ -expr8[expr1] item of String or |List| *expr-[]* *E111* - -If expr8 is a Number or String this results in a String that contains the -expr1'th single byte from expr8. expr8 is used as a String, expr1 as a -Number. Note that this doesn't recognize multi-byte encodings. - -Index zero gives the first character. This is like it works in C. Careful: -text column numbers start with one! Example, to get the character under the -cursor: > - :let c = getline(".")[col(".") - 1] - -If the length of the String is less than the index, the result is an empty -String. A negative index always results in an empty string (reason: backwards -compatibility). Use [-1:] to get the last byte. - -If expr8 is a |List| then it results the item at index expr1. See |list-index| -for possible index values. If the index is out of range this results in an -error. Example: > - :let item = mylist[-1] " get last item - -Generally, if a |List| index is equal to or higher than the length of the -|List|, or more negative than the length of the |List|, this results in an -error. - - -expr8[expr1a : expr1b] substring or sublist *expr-[:]* - -If expr8 is a Number or String this results in the substring with the bytes -from expr1a to and including expr1b. expr8 is used as a String, expr1a and -expr1b are used as a Number. Note that this doesn't recognize multi-byte -encodings. - -If expr1a is omitted zero is used. If expr1b is omitted the length of the -string minus one is used. - -A negative number can be used to measure from the end of the string. -1 is -the last character, -2 the last but one, etc. - -If an index goes out of range for the string characters are omitted. If -expr1b is smaller than expr1a the result is an empty string. - -Examples: > - :let c = name[-1:] " last byte of a string - :let c = name[-2:-2] " last but one byte of a string - :let s = line(".")[4:] " from the fifth byte to the end - :let s = s[:-3] " remove last two bytes - -If expr8 is a |List| this results in a new |List| with the items indicated by -the indexes expr1a and expr1b. This works like with a String, as explained -just above, except that indexes out of range cause an error. Examples: > - :let l = mylist[:3] " first four items - :let l = mylist[4:4] " List with one item - :let l = mylist[:] " shallow copy of a List - -Using expr8[expr1] or expr8[expr1a : expr1b] on a |Funcref| results in an -error. - - -expr8.name entry in a |Dictionary| *expr-entry* - -If expr8 is a |Dictionary| and it is followed by a dot, then the following -name will be used as a key in the |Dictionary|. This is just like: -expr8[name]. - -The name must consist of alphanumeric characters, just like a variable name, -but it may start with a number. Curly braces cannot be used. - -There must not be white space before or after the dot. - -Examples: > - :let dict = {"one": 1, 2: "two"} - :echo dict.one - :echo dict .2 - -Note that the dot is also used for String concatenation. To avoid confusion -always put spaces around the dot for String concatenation. - - -expr8(expr1, ...) |Funcref| function call - -When expr8 is a |Funcref| type variable, invoke the function it refers to. - - - - *expr9* -number ------- -number number constant *expr-number* - -Decimal, Hexadecimal (starting with 0x or 0X), or Octal (starting with 0). - - *floating-point-format* -Floating point numbers can be written in two forms: - - [-+]{N}.{M} - [-+]{N}.{M}e[-+]{exp} - -{N} and {M} are numbers. Both {N} and {M} must be present and can only -contain digits. -[-+] means there is an optional plus or minus sign. -{exp} is the exponent, power of 10. -Only a decimal point is accepted, not a comma. No matter what the current -locale is. -{only when compiled with the |+float| feature} - -Examples: - 123.456 - +0.0001 - 55.0 - -0.123 - 1.234e03 - 1.0E-6 - -3.1416e+88 - -These are INVALID: - 3. empty {M} - 1e40 missing .{M} - - *float-pi* *float-e* -A few useful values to copy&paste: > - :let pi = 3.14159265359 - :let e = 2.71828182846 - -Rationale: -Before floating point was introduced, the text "123.456" was interpreted as -the two numbers "123" and "456", both converted to a string and concatenated, -resulting in the string "123456". Since this was considered pointless, and we -could not find it intentionally being used in Vim scripts, this backwards -incompatibility was accepted in favor of being able to use the normal notation -for floating point numbers. - - *floating-point-precision* -The precision and range of floating points numbers depends on what "double" -means in the library Vim was compiled with. There is no way to change this at -runtime. - -The default for displaying a |Float| is to use 6 decimal places, like using -printf("%g", f). You can select something else when using the |printf()| -function. Example: > - :echo printf('%.15e', atan(1)) -< 7.853981633974483e-01 - - - -string *expr-string* *E114* ------- -"string" string constant *expr-quote* - -Note that double quotes are used. - -A string constant accepts these special characters: -\... three-digit octal number (e.g., "\316") -\.. two-digit octal number (must be followed by non-digit) -\. one-digit octal number (must be followed by non-digit) -\x.. byte specified with two hex numbers (e.g., "\x1f") -\x. byte specified with one hex number (must be followed by non-hex char) -\X.. same as \x.. -\X. same as \x. -\u.... character specified with up to 4 hex numbers, stored according to the - current value of 'encoding' (e.g., "\u02a4") -\U.... same as \u.... -\b backspace -\e escape -\f formfeed -\n newline -\r return -\t tab -\\ backslash -\" double quote -\ Special key named "xxx". e.g. "\" for CTRL-W. - -Note that "\xff" is stored as the byte 255, which may be invalid in some -encodings. Use "\u00ff" to store character 255 according to the current value -of 'encoding'. - -Note that "\000" and "\x00" force the end of the string. - - -literal-string *literal-string* *E115* ---------------- -'string' string constant *expr-'* - -Note that single quotes are used. - -This string is taken as it is. No backslashes are removed or have a special -meaning. The only exception is that two quotes stand for one quote. - -Single quoted strings are useful for patterns, so that backslashes do not need -to be doubled. These two commands are equivalent: > - if a =~ "\\s*" - if a =~ '\s*' - - -option *expr-option* *E112* *E113* ------- -&option option value, local value if possible -&g:option global option value -&l:option local option value - -Examples: > - echo "tabstop is " . &tabstop - if &insertmode - -Any option name can be used here. See |options|. When using the local value -and there is no buffer-local or window-local value, the global value is used -anyway. - - -register *expr-register* *@r* --------- -@r contents of register 'r' - -The result is the contents of the named register, as a single string. -Newlines are inserted where required. To get the contents of the unnamed -register use @" or @@. See |registers| for an explanation of the available -registers. - -When using the '=' register you get the expression itself, not what it -evaluates to. Use |eval()| to evaluate it. - - -nesting *expr-nesting* *E110* -------- -(expr1) nested expression - - -environment variable *expr-env* --------------------- -$VAR environment variable - -The String value of any environment variable. When it is not defined, the -result is an empty string. - *expr-env-expand* -Note that there is a difference between using $VAR directly and using -expand("$VAR"). Using it directly will only expand environment variables that -are known inside the current Vim session. Using expand() will first try using -the environment variables known inside the current Vim session. If that -fails, a shell will be used to expand the variable. This can be slow, but it -does expand all variables that the shell knows about. Example: > - :echo $version - :echo expand("$version") -The first one probably doesn't echo anything, the second echoes the $version -variable (if your shell supports it). - - -internal variable *expr-variable* ------------------ -variable internal variable -See below |internal-variables|. - - -function call *expr-function* *E116* *E118* *E119* *E120* -------------- -function(expr1, ...) function call -See below |functions|. - - -============================================================================== -3. Internal variable *internal-variables* *E121* - *E461* -An internal variable name can be made up of letters, digits and '_'. But it -cannot start with a digit. It's also possible to use curly braces, see -|curly-braces-names|. - -An internal variable is created with the ":let" command |:let|. -An internal variable is explicitly destroyed with the ":unlet" command -|:unlet|. -Using a name that is not an internal variable or refers to a variable that has -been destroyed results in an error. - -There are several name spaces for variables. Which one is to be used is -specified by what is prepended: - - (nothing) In a function: local to a function; otherwise: global -|buffer-variable| b: Local to the current buffer. -|window-variable| w: Local to the current window. -|tabpage-variable| t: Local to the current tab page. -|global-variable| g: Global. -|local-variable| l: Local to a function. -|script-variable| s: Local to a |:source|'ed Vim script. -|function-argument| a: Function argument (only inside a function). -|vim-variable| v: Global, predefined by Vim. - -The scope name by itself can be used as a |Dictionary|. For example, to -delete all script-local variables: > - :for k in keys(s:) - : unlet s:[k] - :endfor -< - *buffer-variable* *b:var* -A variable name that is preceded with "b:" is local to the current buffer. -Thus you can have several "b:foo" variables, one for each buffer. -This kind of variable is deleted when the buffer is wiped out or deleted with -|:bdelete|. - -One local buffer variable is predefined: - *b:changedtick-variable* *changetick* -b:changedtick The total number of changes to the current buffer. It is - incremented for each change. An undo command is also a change - in this case. This can be used to perform an action only when - the buffer has changed. Example: > - :if my_changedtick != b:changedtick - : let my_changedtick = b:changedtick - : call My_Update() - :endif -< - *window-variable* *w:var* -A variable name that is preceded with "w:" is local to the current window. It -is deleted when the window is closed. - - *tabpage-variable* *t:var* -A variable name that is preceded with "t:" is local to the current tab page, -It is deleted when the tab page is closed. {not available when compiled -without the +windows feature} - - *global-variable* *g:var* -Inside functions global variables are accessed with "g:". Omitting this will -access a variable local to a function. But "g:" can also be used in any other -place if you like. - - *local-variable* *l:var* -Inside functions local variables are accessed without prepending anything. -But you can also prepend "l:" if you like. However, without prepending "l:" -you may run into reserved variable names. For example "count". By itself it -refers to "v:count". Using "l:count" you can have a local variable with the -same name. - - *script-variable* *s:var* -In a Vim script variables starting with "s:" can be used. They cannot be -accessed from outside of the scripts, thus are local to the script. - -They can be used in: -- commands executed while the script is sourced -- functions defined in the script -- autocommands defined in the script -- functions and autocommands defined in functions and autocommands which were - defined in the script (recursively) -- user defined commands defined in the script -Thus not in: -- other scripts sourced from this one -- mappings -- etc. - -Script variables can be used to avoid conflicts with global variable names. -Take this example: > - - let s:counter = 0 - function MyCounter() - let s:counter = s:counter + 1 - echo s:counter - endfunction - command Tick call MyCounter() - -You can now invoke "Tick" from any script, and the "s:counter" variable in -that script will not be changed, only the "s:counter" in the script where -"Tick" was defined is used. - -Another example that does the same: > - - let s:counter = 0 - command Tick let s:counter = s:counter + 1 | echo s:counter - -When calling a function and invoking a user-defined command, the context for -script variables is set to the script where the function or command was -defined. - -The script variables are also available when a function is defined inside a -function that is defined in a script. Example: > - - let s:counter = 0 - function StartCounting(incr) - if a:incr - function MyCounter() - let s:counter = s:counter + 1 - endfunction - else - function MyCounter() - let s:counter = s:counter - 1 - endfunction - endif - endfunction - -This defines the MyCounter() function either for counting up or counting down -when calling StartCounting(). It doesn't matter from where StartCounting() is -called, the s:counter variable will be accessible in MyCounter(). - -When the same script is sourced again it will use the same script variables. -They will remain valid as long as Vim is running. This can be used to -maintain a counter: > - - if !exists("s:counter") - let s:counter = 1 - echo "script executed for the first time" - else - let s:counter = s:counter + 1 - echo "script executed " . s:counter . " times now" - endif - -Note that this means that filetype plugins don't get a different set of script -variables for each buffer. Use local buffer variables instead |b:var|. - - -Predefined Vim variables: *vim-variable* *v:var* - - *v:beval_col* *beval_col-variable* -v:beval_col The number of the column, over which the mouse pointer is. - This is the byte index in the |v:beval_lnum| line. - Only valid while evaluating the 'balloonexpr' option. - - *v:beval_bufnr* *beval_bufnr-variable* -v:beval_bufnr The number of the buffer, over which the mouse pointer is. Only - valid while evaluating the 'balloonexpr' option. - - *v:beval_lnum* *beval_lnum-variable* -v:beval_lnum The number of the line, over which the mouse pointer is. Only - valid while evaluating the 'balloonexpr' option. - - *v:beval_text* *beval_text-variable* -v:beval_text The text under or after the mouse pointer. Usually a word as - it is useful for debugging a C program. 'iskeyword' applies, - but a dot and "->" before the position is included. When on a - ']' the text before it is used, including the matching '[' and - word before it. When on a Visual area within one line the - highlighted text is used. - Only valid while evaluating the 'balloonexpr' option. - - *v:beval_winnr* *beval_winnr-variable* -v:beval_winnr The number of the window, over which the mouse pointer is. Only - valid while evaluating the 'balloonexpr' option. - - *v:char* *char-variable* -v:char Argument for evaluating 'formatexpr'. - - *v:charconvert_from* *charconvert_from-variable* -v:charconvert_from - The name of the character encoding of a file to be converted. - Only valid while evaluating the 'charconvert' option. - - *v:charconvert_to* *charconvert_to-variable* -v:charconvert_to - The name of the character encoding of a file after conversion. - Only valid while evaluating the 'charconvert' option. - - *v:cmdarg* *cmdarg-variable* -v:cmdarg This variable is used for two purposes: - 1. The extra arguments given to a file read/write command. - Currently these are "++enc=" and "++ff=". This variable is - set before an autocommand event for a file read/write - command is triggered. There is a leading space to make it - possible to append this variable directly after the - read/write command. Note: The "+cmd" argument isn't - included here, because it will be executed anyway. - 2. When printing a PostScript file with ":hardcopy" this is - the argument for the ":hardcopy" command. This can be used - in 'printexpr'. - - *v:cmdbang* *cmdbang-variable* -v:cmdbang Set like v:cmdarg for a file read/write command. When a "!" - was used the value is 1, otherwise it is 0. Note that this - can only be used in autocommands. For user commands || - can be used. - - *v:count* *count-variable* -v:count The count given for the last Normal mode command. Can be used - to get the count before a mapping. Read-only. Example: > - :map _x :echo "the count is " . v:count -< Note: The is required to remove the line range that you - get when typing ':' after a count. - Also used for evaluating the 'formatexpr' option. - "count" also works, for backwards compatibility. - - *v:count1* *count1-variable* -v:count1 Just like "v:count", but defaults to one when no count is - used. - - *v:ctype* *ctype-variable* -v:ctype The current locale setting for characters of the runtime - environment. This allows Vim scripts to be aware of the - current locale encoding. Technical: it's the value of - LC_CTYPE. When not using a locale the value is "C". - This variable can not be set directly, use the |:language| - command. - See |multi-lang|. - - *v:dying* *dying-variable* -v:dying Normally zero. When a deadly signal is caught it's set to - one. When multiple signals are caught the number increases. - Can be used in an autocommand to check if Vim didn't - terminate normally. {only works on Unix} - Example: > - :au VimLeave * if v:dying | echo "\nAAAAaaaarrrggghhhh!!!\n" | endif -< - *v:errmsg* *errmsg-variable* -v:errmsg Last given error message. It's allowed to set this variable. - Example: > - :let v:errmsg = "" - :silent! next - :if v:errmsg != "" - : ... handle error -< "errmsg" also works, for backwards compatibility. - - *v:exception* *exception-variable* -v:exception The value of the exception most recently caught and not - finished. See also |v:throwpoint| and |throw-variables|. - Example: > - :try - : throw "oops" - :catch /.*/ - : echo "caught" v:exception - :endtry -< Output: "caught oops". - - *v:fcs_reason* *fcs_reason-variable* -v:fcs_reason The reason why the |FileChangedShell| event was triggered. - Can be used in an autocommand to decide what to do and/or what - to set v:fcs_choice to. Possible values: - deleted file no longer exists - conflict file contents, mode or timestamp was - changed and buffer is modified - changed file contents has changed - mode mode of file changed - time only file timestamp changed - - *v:fcs_choice* *fcs_choice-variable* -v:fcs_choice What should happen after a |FileChangedShell| event was - triggered. Can be used in an autocommand to tell Vim what to - do with the affected buffer: - reload Reload the buffer (does not work if - the file was deleted). - ask Ask the user what to do, as if there - was no autocommand. Except that when - only the timestamp changed nothing - will happen. - Nothing, the autocommand should do - everything that needs to be done. - The default is empty. If another (invalid) value is used then - Vim behaves like it is empty, there is no warning message. - - *v:fname_in* *fname_in-variable* -v:fname_in The name of the input file. Valid while evaluating: - option used for ~ - 'charconvert' file to be converted - 'diffexpr' original file - 'patchexpr' original file - 'printexpr' file to be printed - And set to the swap file name for |SwapExists|. - - *v:fname_out* *fname_out-variable* -v:fname_out The name of the output file. Only valid while - evaluating: - option used for ~ - 'charconvert' resulting converted file (*) - 'diffexpr' output of diff - 'patchexpr' resulting patched file - (*) When doing conversion for a write command (e.g., ":w - file") it will be equal to v:fname_in. When doing conversion - for a read command (e.g., ":e file") it will be a temporary - file and different from v:fname_in. - - *v:fname_new* *fname_new-variable* -v:fname_new The name of the new version of the file. Only valid while - evaluating 'diffexpr'. - - *v:fname_diff* *fname_diff-variable* -v:fname_diff The name of the diff (patch) file. Only valid while - evaluating 'patchexpr'. - - *v:folddashes* *folddashes-variable* -v:folddashes Used for 'foldtext': dashes representing foldlevel of a closed - fold. - Read-only in the |sandbox|. |fold-foldtext| - - *v:foldlevel* *foldlevel-variable* -v:foldlevel Used for 'foldtext': foldlevel of closed fold. - Read-only in the |sandbox|. |fold-foldtext| - - *v:foldend* *foldend-variable* -v:foldend Used for 'foldtext': last line of closed fold. - Read-only in the |sandbox|. |fold-foldtext| - - *v:foldstart* *foldstart-variable* -v:foldstart Used for 'foldtext': first line of closed fold. - Read-only in the |sandbox|. |fold-foldtext| - - *v:insertmode* *insertmode-variable* -v:insertmode Used for the |InsertEnter| and |InsertChange| autocommand - events. Values: - i Insert mode - r Replace mode - v Virtual Replace mode - - *v:key* *key-variable* -v:key Key of the current item of a |Dictionary|. Only valid while - evaluating the expression used with |map()| and |filter()|. - Read-only. - - *v:lang* *lang-variable* -v:lang The current locale setting for messages of the runtime - environment. This allows Vim scripts to be aware of the - current language. Technical: it's the value of LC_MESSAGES. - The value is system dependent. - This variable can not be set directly, use the |:language| - command. - It can be different from |v:ctype| when messages are desired - in a different language than what is used for character - encoding. See |multi-lang|. - - *v:lc_time* *lc_time-variable* -v:lc_time The current locale setting for time messages of the runtime - environment. This allows Vim scripts to be aware of the - current language. Technical: it's the value of LC_TIME. - This variable can not be set directly, use the |:language| - command. See |multi-lang|. - - *v:lnum* *lnum-variable* -v:lnum Line number for the 'foldexpr' |fold-expr| and 'indentexpr' - expressions, tab page number for 'guitablabel' and - 'guitabtooltip'. Only valid while one of these expressions is - being evaluated. Read-only when in the |sandbox|. - - *v:mouse_win* *mouse_win-variable* -v:mouse_win Window number for a mouse click obtained with |getchar()|. - First window has number 1, like with |winnr()|. The value is - zero when there was no mouse button click. - - *v:mouse_lnum* *mouse_lnum-variable* -v:mouse_lnum Line number for a mouse click obtained with |getchar()|. - This is the text line number, not the screen line number. The - value is zero when there was no mouse button click. - - *v:mouse_col* *mouse_col-variable* -v:mouse_col Column number for a mouse click obtained with |getchar()|. - This is the screen column number, like with |virtcol()|. The - value is zero when there was no mouse button click. - - *v:oldfiles* *oldfiles-variable* -v:oldfiles List of file names that is loaded from the |viminfo| file on - startup. These are the files that Vim remembers marks for. - The length of the List is limited by the ' argument of the - 'viminfo' option (default is 100). - Also see |:oldfiles| and |c_#<|. - The List can be modified, but this has no effect on what is - stored in the |viminfo| file later. If you use values other - than String this will cause trouble. - {only when compiled with the +viminfo feature} - - *v:operator* *operator-variable* -v:operator The last operator given in Normal mode. This is a single - character except for commands starting with or , - in which case it is two characters. Best used alongside - |v:prevcount| and |v:register|. Useful if you want to cancel - Operator-pending mode and then use the operator, e.g.: > - :omap O :call MyMotion(v:operator) -< The value remains set until another operator is entered, thus - don't expect it to be empty. - v:operator is not set for |:delete|, |:yank| or other Ex - commands. - Read-only. - - *v:prevcount* *prevcount-variable* -v:prevcount The count given for the last but one Normal mode command. - This is the v:count value of the previous command. Useful if - you want to cancel Visual or Operator-pending mode and then - use the count, e.g.: > - :vmap % :call MyFilter(v:prevcount) -< Read-only. - - *v:profiling* *profiling-variable* -v:profiling Normally zero. Set to one after using ":profile start". - See |profiling|. - - *v:progname* *progname-variable* -v:progname Contains the name (with path removed) with which Vim was - invoked. Allows you to do special initialisations for "view", - "evim" etc., or any other name you might symlink to Vim. - Read-only. - - *v:register* *register-variable* -v:register The name of the register supplied to the last normal mode - command. Empty if none were supplied. |getreg()| |setreg()| - - *v:scrollstart* *scrollstart-variable* -v:scrollstart String describing the script or function that caused the - screen to scroll up. It's only set when it is empty, thus the - first reason is remembered. It is set to "Unknown" for a - typed command. - This can be used to find out why your script causes the - hit-enter prompt. - - *v:servername* *servername-variable* -v:servername The resulting registered |x11-clientserver| name if any. - Read-only. - - -v:searchforward *v:searchforward* *searchforward-variable* - Search direction: 1 after a forward search, 0 after a - backward search. It is reset to forward when directly setting - the last search pattern, see |quote/|. - Note that the value is restored when returning from a - function. |function-search-undo|. - Read-write. - - *v:shell_error* *shell_error-variable* -v:shell_error Result of the last shell command. When non-zero, the last - shell command had an error. When zero, there was no problem. - This only works when the shell returns the error code to Vim. - The value -1 is often used when the command could not be - executed. Read-only. - Example: > - :!mv foo bar - :if v:shell_error - : echo 'could not rename "foo" to "bar"!' - :endif -< "shell_error" also works, for backwards compatibility. - - *v:statusmsg* *statusmsg-variable* -v:statusmsg Last given status message. It's allowed to set this variable. - - *v:swapname* *swapname-variable* -v:swapname Only valid when executing |SwapExists| autocommands: Name of - the swap file found. Read-only. - - *v:swapchoice* *swapchoice-variable* -v:swapchoice |SwapExists| autocommands can set this to the selected choice - for handling an existing swap file: - 'o' Open read-only - 'e' Edit anyway - 'r' Recover - 'd' Delete swapfile - 'q' Quit - 'a' Abort - The value should be a single-character string. An empty value - results in the user being asked, as would happen when there is - no SwapExists autocommand. The default is empty. - - *v:swapcommand* *swapcommand-variable* -v:swapcommand Normal mode command to be executed after a file has been - opened. Can be used for a |SwapExists| autocommand to have - another Vim open the file and jump to the right place. For - example, when jumping to a tag the value is ":tag tagname\r". - For ":edit +cmd file" the value is ":cmd\r". - - *v:termresponse* *termresponse-variable* -v:termresponse The escape sequence returned by the terminal for the |t_RV| - termcap entry. It is set when Vim receives an escape sequence - that starts with ESC [ or CSI and ends in a 'c', with only - digits, ';' and '.' in between. - When this option is set, the TermResponse autocommand event is - fired, so that you can react to the response from the - terminal. - The response from a new xterm is: "[ Pp ; Pv ; Pc c". Pp - is the terminal type: 0 for vt100 and 1 for vt220. Pv is the - patch level (since this was introduced in patch 95, it's - always 95 or bigger). Pc is always zero. - {only when compiled with |+termresponse| feature} - - *v:this_session* *this_session-variable* -v:this_session Full filename of the last loaded or saved session file. See - |:mksession|. It is allowed to set this variable. When no - session file has been saved, this variable is empty. - "this_session" also works, for backwards compatibility. - - *v:throwpoint* *throwpoint-variable* -v:throwpoint The point where the exception most recently caught and not - finished was thrown. Not set when commands are typed. See - also |v:exception| and |throw-variables|. - Example: > - :try - : throw "oops" - :catch /.*/ - : echo "Exception from" v:throwpoint - :endtry -< Output: "Exception from test.vim, line 2" - - *v:val* *val-variable* -v:val Value of the current item of a |List| or |Dictionary|. Only - valid while evaluating the expression used with |map()| and - |filter()|. Read-only. - - *v:version* *version-variable* -v:version Version number of Vim: Major version number times 100 plus - minor version number. Version 5.0 is 500. Version 5.1 (5.01) - is 501. Read-only. "version" also works, for backwards - compatibility. - Use |has()| to check if a certain patch was included, e.g.: > - if has("patch123") -< Note that patch numbers are specific to the version, thus both - version 5.0 and 5.1 may have a patch 123, but these are - completely different. - - *v:warningmsg* *warningmsg-variable* -v:warningmsg Last given warning message. It's allowed to set this variable. - -============================================================================== -4. Builtin Functions *functions* - -See |function-list| for a list grouped by what the function is used for. - -(Use CTRL-] on the function name to jump to the full explanation.) - -USAGE RESULT DESCRIPTION ~ - -abs( {expr}) Float or Number absolute value of {expr} -add( {list}, {item}) List append {item} to |List| {list} -append( {lnum}, {string}) Number append {string} below line {lnum} -append( {lnum}, {list}) Number append lines {list} below line {lnum} -argc() Number number of files in the argument list -argidx() Number current index in the argument list -argv( {nr}) String {nr} entry of the argument list -argv( ) List the argument list -atan( {expr}) Float arc tangent of {expr} -browse( {save}, {title}, {initdir}, {default}) - String put up a file requester -browsedir( {title}, {initdir}) String put up a directory requester -bufexists( {expr}) Number TRUE if buffer {expr} exists -buflisted( {expr}) Number TRUE if buffer {expr} is listed -bufloaded( {expr}) Number TRUE if buffer {expr} is loaded -bufname( {expr}) String Name of the buffer {expr} -bufnr( {expr}) Number Number of the buffer {expr} -bufwinnr( {expr}) Number window number of buffer {expr} -byte2line( {byte}) Number line number at byte count {byte} -byteidx( {expr}, {nr}) Number byte index of {nr}'th char in {expr} -call( {func}, {arglist} [, {dict}]) - any call {func} with arguments {arglist} -ceil( {expr}) Float round {expr} up -changenr() Number current change number -char2nr( {expr}) Number ASCII value of first char in {expr} -cindent( {lnum}) Number C indent for line {lnum} -clearmatches() None clear all matches -col( {expr}) Number column nr of cursor or mark -complete({startcol}, {matches}) String set Insert mode completion -complete_add( {expr}) Number add completion match -complete_check() Number check for key typed during completion -confirm( {msg} [, {choices} [, {default} [, {type}]]]) - Number number of choice picked by user -copy( {expr}) any make a shallow copy of {expr} -cos( {expr}) Float cosine of {expr} -count( {list}, {expr} [, {start} [, {ic}]]) - Number count how many {expr} are in {list} -cscope_connection( [{num} , {dbpath} [, {prepend}]]) - Number checks existence of cscope connection -cursor( {lnum}, {col} [, {coladd}]) - Number move cursor to {lnum}, {col}, {coladd} -cursor( {list}) Number move cursor to position in {list} -deepcopy( {expr}) any make a full copy of {expr} -delete( {fname}) Number delete file {fname} -did_filetype() Number TRUE if FileType autocommand event used -diff_filler( {lnum}) Number diff filler lines about {lnum} -diff_hlID( {lnum}, {col}) Number diff highlighting at {lnum}/{col} -empty( {expr}) Number TRUE if {expr} is empty -escape( {string}, {chars}) String escape {chars} in {string} with '\' -eval( {string}) any evaluate {string} into its value -eventhandler( ) Number TRUE if inside an event handler -executable( {expr}) Number 1 if executable {expr} exists -exists( {expr}) Number TRUE if {expr} exists -extend({expr1}, {expr2} [, {expr3}]) - List/Dict insert items of {expr2} into {expr1} -expand( {expr}) String expand special keywords in {expr} -feedkeys( {string} [, {mode}]) Number add key sequence to typeahead buffer -filereadable( {file}) Number TRUE if {file} is a readable file -filewritable( {file}) Number TRUE if {file} is a writable file -filter( {expr}, {string}) List/Dict remove items from {expr} where - {string} is 0 -finddir( {name}[, {path}[, {count}]]) - String find directory {name} in {path} -findfile( {name}[, {path}[, {count}]]) - String find file {name} in {path} -float2nr( {expr}) Number convert Float {expr} to a Number -floor( {expr}) Float round {expr} down -fnameescape( {fname}) String escape special characters in {fname} -fnamemodify( {fname}, {mods}) String modify file name -foldclosed( {lnum}) Number first line of fold at {lnum} if closed -foldclosedend( {lnum}) Number last line of fold at {lnum} if closed -foldlevel( {lnum}) Number fold level at {lnum} -foldtext( ) String line displayed for closed fold -foldtextresult( {lnum}) String text for closed fold at {lnum} -foreground( ) Number bring the Vim window to the foreground -function( {name}) Funcref reference to function {name} -garbagecollect( [at_exit]) none free memory, breaking cyclic references -get( {list}, {idx} [, {def}]) any get item {idx} from {list} or {def} -get( {dict}, {key} [, {def}]) any get item {key} from {dict} or {def} -getbufline( {expr}, {lnum} [, {end}]) - List lines {lnum} to {end} of buffer {expr} -getbufvar( {expr}, {varname}) any variable {varname} in buffer {expr} -getchar( [expr]) Number get one character from the user -getcharmod( ) Number modifiers for the last typed character -getcmdline() String return the current command-line -getcmdpos() Number return cursor position in command-line -getcmdtype() String return the current command-line type -getcwd() String the current working directory -getfperm( {fname}) String file permissions of file {fname} -getfsize( {fname}) Number size in bytes of file {fname} -getfontname( [{name}]) String name of font being used -getftime( {fname}) Number last modification time of file -getftype( {fname}) String description of type of file {fname} -getline( {lnum}) String line {lnum} of current buffer -getline( {lnum}, {end}) List lines {lnum} to {end} of current buffer -getloclist({nr}) List list of location list items -getmatches() List list of current matches -getpid() Number process ID of Vim -getpos( {expr}) List position of cursor, mark, etc. -getqflist() List list of quickfix items -getreg( [{regname} [, 1]]) String contents of register -getregtype( [{regname}]) String type of register -gettabwinvar( {tabnr}, {winnr}, {name}) - any {name} in {winnr} in tab page {tabnr} -getwinposx() Number X coord in pixels of GUI Vim window -getwinposy() Number Y coord in pixels of GUI Vim window -getwinvar( {nr}, {varname}) any variable {varname} in window {nr} -glob( {expr}) String expand file wildcards in {expr} -globpath( {path}, {expr}) String do glob({expr}) for all dirs in {path} -has( {feature}) Number TRUE if feature {feature} supported -has_key( {dict}, {key}) Number TRUE if {dict} has entry {key} -haslocaldir() Number TRUE if current window executed |:lcd| -hasmapto( {what} [, {mode} [, {abbr}]]) - Number TRUE if mapping to {what} exists -histadd( {history},{item}) String add an item to a history -histdel( {history} [, {item}]) String remove an item from a history -histget( {history} [, {index}]) String get the item {index} from a history -histnr( {history}) Number highest index of a history -hlexists( {name}) Number TRUE if highlight group {name} exists -hlID( {name}) Number syntax ID of highlight group {name} -hostname() String name of the machine Vim is running on -iconv( {expr}, {from}, {to}) String convert encoding of {expr} -indent( {lnum}) Number indent of line {lnum} -index( {list}, {expr} [, {start} [, {ic}]]) - Number index in {list} where {expr} appears -input( {prompt} [, {text} [, {completion}]]) - String get input from the user -inputdialog( {p} [, {t} [, {c}]]) String like input() but in a GUI dialog -inputlist( {textlist}) Number let the user pick from a choice list -inputrestore() Number restore typeahead -inputsave() Number save and clear typeahead -inputsecret( {prompt} [, {text}]) String like input() but hiding the text -insert( {list}, {item} [, {idx}]) List insert {item} in {list} [before {idx}] -isdirectory( {directory}) Number TRUE if {directory} is a directory -islocked( {expr}) Number TRUE if {expr} is locked -items( {dict}) List key-value pairs in {dict} -join( {list} [, {sep}]) String join {list} items into one String -keys( {dict}) List keys in {dict} -len( {expr}) Number the length of {expr} -libcall( {lib}, {func}, {arg}) String call {func} in library {lib} with {arg} -libcallnr( {lib}, {func}, {arg}) Number idem, but return a Number -line( {expr}) Number line nr of cursor, last line or mark -line2byte( {lnum}) Number byte count of line {lnum} -lispindent( {lnum}) Number Lisp indent for line {lnum} -localtime() Number current time -log10( {expr}) Float logarithm of Float {expr} to base 10 -map( {expr}, {string}) List/Dict change each item in {expr} to {expr} -maparg( {name}[, {mode} [, {abbr}]]) - String rhs of mapping {name} in mode {mode} -mapcheck( {name}[, {mode} [, {abbr}]]) - String check for mappings matching {name} -match( {expr}, {pat}[, {start}[, {count}]]) - Number position where {pat} matches in {expr} -matchadd( {group}, {pattern}[, {priority}[, {id}]]) - Number highlight {pattern} with {group} -matcharg( {nr}) List arguments of |:match| -matchdelete( {id}) Number delete match identified by {id} -matchend( {expr}, {pat}[, {start}[, {count}]]) - Number position where {pat} ends in {expr} -matchlist( {expr}, {pat}[, {start}[, {count}]]) - List match and submatches of {pat} in {expr} -matchstr( {expr}, {pat}[, {start}[, {count}]]) - String {count}'th match of {pat} in {expr} -max({list}) Number maximum value of items in {list} -min({list}) Number minimum value of items in {list} -mkdir({name} [, {path} [, {prot}]]) - Number create directory {name} -mode( [expr]) String current editing mode -nextnonblank( {lnum}) Number line nr of non-blank line >= {lnum} -nr2char( {expr}) String single char with ASCII value {expr} -pathshorten( {expr}) String shorten directory names in a path -pow( {x}, {y}) Float {x} to the power of {y} -prevnonblank( {lnum}) Number line nr of non-blank line <= {lnum} -printf( {fmt}, {expr1}...) String format text -pumvisible() Number whether popup menu is visible -range( {expr} [, {max} [, {stride}]]) - List items from {expr} to {max} -readfile({fname} [, {binary} [, {max}]]) - List get list of lines from file {fname} -reltime( [{start} [, {end}]]) List get time value -reltimestr( {time}) String turn time value into a String -remote_expr( {server}, {string} [, {idvar}]) - String send expression -remote_foreground( {server}) Number bring Vim server to the foreground -remote_peek( {serverid} [, {retvar}]) - Number check for reply string -remote_read( {serverid}) String read reply string -remote_send( {server}, {string} [, {idvar}]) - String send key sequence -remove( {list}, {idx} [, {end}]) any remove items {idx}-{end} from {list} -remove( {dict}, {key}) any remove entry {key} from {dict} -rename( {from}, {to}) Number rename (move) file from {from} to {to} -repeat( {expr}, {count}) String repeat {expr} {count} times -resolve( {filename}) String get filename a shortcut points to -reverse( {list}) List reverse {list} in-place -round( {expr}) Float round off {expr} -search( {pattern} [, {flags} [, {stopline} [, {timeout}]]]) - Number search for {pattern} -searchdecl({name} [, {global} [, {thisblock}]]) - Number search for variable declaration -searchpair( {start}, {middle}, {end} [, {flags} [, {skip} [...]]]) - Number search for other end of start/end pair -searchpairpos( {start}, {middle}, {end} [, {flags} [, {skip} [...]]]) - List search for other end of start/end pair -searchpos( {pattern} [, {flags} [, {stopline} [, {timeout}]]]) - List search for {pattern} -server2client( {clientid}, {string}) - Number send reply string -serverlist() String get a list of available servers -setbufvar( {expr}, {varname}, {val}) set {varname} in buffer {expr} to {val} -setcmdpos( {pos}) Number set cursor position in command-line -setline( {lnum}, {line}) Number set line {lnum} to {line} -setloclist( {nr}, {list}[, {action}]) - Number modify location list using {list} -setmatches( {list}) Number restore a list of matches -setpos( {expr}, {list}) none set the {expr} position to {list} -setqflist( {list}[, {action}]) Number modify quickfix list using {list} -setreg( {n}, {v}[, {opt}]) Number set register to value and type -settabwinvar( {tabnr}, {winnr}, {varname}, {val}) set {varname} in window - {winnr} in tab page {tabnr} to {val} -setwinvar( {nr}, {varname}, {val}) set {varname} in window {nr} to {val} -shellescape( {string} [, {special}]) - String escape {string} for use as shell - command argument -simplify( {filename}) String simplify filename as much as possible -sin( {expr}) Float sine of {expr} -sort( {list} [, {func}]) List sort {list}, using {func} to compare -soundfold( {word}) String sound-fold {word} -spellbadword() String badly spelled word at cursor -spellsuggest( {word} [, {max} [, {capital}]]) - List spelling suggestions -split( {expr} [, {pat} [, {keepempty}]]) - List make |List| from {pat} separated {expr} -sqrt( {expr} Float squar root of {expr} -str2float( {expr}) Float convert String to Float -str2nr( {expr} [, {base}]) Number convert String to Number -strftime( {format}[, {time}]) String time in specified format -stridx( {haystack}, {needle}[, {start}]) - Number index of {needle} in {haystack} -string( {expr}) String String representation of {expr} value -strlen( {expr}) Number length of the String {expr} -strpart( {src}, {start}[, {len}]) - String {len} characters of {src} at {start} -strridx( {haystack}, {needle} [, {start}]) - Number last index of {needle} in {haystack} -strtrans( {expr}) String translate string to make it printable -submatch( {nr}) String specific match in ":substitute" -substitute( {expr}, {pat}, {sub}, {flags}) - String all {pat} in {expr} replaced with {sub} -synID( {lnum}, {col}, {trans}) Number syntax ID at {lnum} and {col} -synIDattr( {synID}, {what} [, {mode}]) - String attribute {what} of syntax ID {synID} -synIDtrans( {synID}) Number translated syntax ID of {synID} -synstack({lnum}, {col}) List stack of syntax IDs at {lnum} and {col} -system( {expr} [, {input}]) String output of shell command/filter {expr} -tabpagebuflist( [{arg}]) List list of buffer numbers in tab page -tabpagenr( [{arg}]) Number number of current or last tab page -tabpagewinnr( {tabarg}[, {arg}]) - Number number of current window in tab page -taglist( {expr}) List list of tags matching {expr} -tagfiles() List tags files used -tempname() String name for a temporary file -tolower( {expr}) String the String {expr} switched to lowercase -toupper( {expr}) String the String {expr} switched to uppercase -tr( {src}, {fromstr}, {tostr}) String translate chars of {src} in {fromstr} - to chars in {tostr} -trunc( {expr} Float truncate Float {expr} -type( {name}) Number type of variable {name} -values( {dict}) List values in {dict} -virtcol( {expr}) Number screen column of cursor or mark -visualmode( [expr]) String last visual mode used -winbufnr( {nr}) Number buffer number of window {nr} -wincol() Number window column of the cursor -winheight( {nr}) Number height of window {nr} -winline() Number window line of the cursor -winnr( [{expr}]) Number number of current window -winrestcmd() String returns command to restore window sizes -winrestview({dict}) None restore view of current window -winsaveview() Dict save view of current window -winwidth( {nr}) Number width of window {nr} -writefile({list}, {fname} [, {binary}]) - Number write list of lines to file {fname} - -abs({expr}) *abs()* - Return the absolute value of {expr}. When {expr} evaluates to - a |Float| abs() returns a |Float|. When {expr} can be - converted to a |Number| abs() returns a |Number|. Otherwise - abs() gives an error message and returns -1. - Examples: > - echo abs(1.456) -< 1.456 > - echo abs(-5.456) -< 5.456 > - echo abs(-4) -< 4 - {only available when compiled with the |+float| feature} - -add({list}, {expr}) *add()* - Append the item {expr} to |List| {list}. Returns the - resulting |List|. Examples: > - :let alist = add([1, 2, 3], item) - :call add(mylist, "woodstock") -< Note that when {expr} is a |List| it is appended as a single - item. Use |extend()| to concatenate |Lists|. - Use |insert()| to add an item at another position. - - -append({lnum}, {expr}) *append()* - When {expr} is a |List|: Append each item of the |List| as a - text line below line {lnum} in the current buffer. - Otherwise append {expr} as one text line below line {lnum} in - the current buffer. - {lnum} can be zero to insert a line before the first one. - Returns 1 for failure ({lnum} out of range or out of memory), - 0 for success. Example: > - :let failed = append(line('$'), "# THE END") - :let failed = append(0, ["Chapter 1", "the beginning"]) -< - *argc()* -argc() The result is the number of files in the argument list of the - current window. See |arglist|. - - *argidx()* -argidx() The result is the current index in the argument list. 0 is - the first file. argc() - 1 is the last one. See |arglist|. - - *argv()* -argv([{nr}]) The result is the {nr}th file in the argument list of the - current window. See |arglist|. "argv(0)" is the first one. - Example: > - :let i = 0 - :while i < argc() - : let f = escape(fnameescape(argv(i)), '.') - : exe 'amenu Arg.' . f . ' :e ' . f . '' - : let i = i + 1 - :endwhile -< Without the {nr} argument a |List| with the whole |arglist| is - returned. - -atan({expr}) *atan()* - Return the principal value of the arc tangent of {expr}, in - the range [-pi/2, +pi/2] radians, as a |Float|. - {expr} must evaluate to a |Float| or a |Number|. - Examples: > - :echo atan(100) -< 1.560797 > - :echo atan(-4.01) -< -1.326405 - {only available when compiled with the |+float| feature} - - *browse()* -browse({save}, {title}, {initdir}, {default}) - Put up a file requester. This only works when "has("browse")" - returns non-zero (only in some GUI versions). - The input fields are: - {save} when non-zero, select file to write - {title} title for the requester - {initdir} directory to start browsing in - {default} default file name - When the "Cancel" button is hit, something went wrong, or - browsing is not possible, an empty string is returned. - - *browsedir()* -browsedir({title}, {initdir}) - Put up a directory requester. This only works when - "has("browse")" returns non-zero (only in some GUI versions). - On systems where a directory browser is not supported a file - browser is used. In that case: select a file in the directory - to be used. - The input fields are: - {title} title for the requester - {initdir} directory to start browsing in - When the "Cancel" button is hit, something went wrong, or - browsing is not possible, an empty string is returned. - -bufexists({expr}) *bufexists()* - The result is a Number, which is non-zero if a buffer called - {expr} exists. - If the {expr} argument is a number, buffer numbers are used. - If the {expr} argument is a string it must match a buffer name - exactly. The name can be: - - Relative to the current directory. - - A full path. - - The name of a buffer with 'buftype' set to "nofile". - - A URL name. - Unlisted buffers will be found. - Note that help files are listed by their short name in the - output of |:buffers|, but bufexists() requires using their - long name to be able to find them. - bufexists() may report a buffer exists, but to use the name - with a |:buffer| command you may need to use |expand()|. Esp - for MS-Windows 8.3 names in the form "c:\DOCUME~1" - Use "bufexists(0)" to test for the existence of an alternate - file name. - *buffer_exists()* - Obsolete name: buffer_exists(). - -buflisted({expr}) *buflisted()* - The result is a Number, which is non-zero if a buffer called - {expr} exists and is listed (has the 'buflisted' option set). - The {expr} argument is used like with |bufexists()|. - -bufloaded({expr}) *bufloaded()* - The result is a Number, which is non-zero if a buffer called - {expr} exists and is loaded (shown in a window or hidden). - The {expr} argument is used like with |bufexists()|. - -bufname({expr}) *bufname()* - The result is the name of a buffer, as it is displayed by the - ":ls" command. - If {expr} is a Number, that buffer number's name is given. - Number zero is the alternate buffer for the current window. - If {expr} is a String, it is used as a |file-pattern| to match - with the buffer names. This is always done like 'magic' is - set and 'cpoptions' is empty. When there is more than one - match an empty string is returned. - "" or "%" can be used for the current buffer, "#" for the - alternate buffer. - A full match is preferred, otherwise a match at the start, end - or middle of the buffer name is accepted. If you only want a - full match then put "^" at the start and "$" at the end of the - pattern. - Listed buffers are found first. If there is a single match - with a listed buffer, that one is returned. Next unlisted - buffers are searched for. - If the {expr} is a String, but you want to use it as a buffer - number, force it to be a Number by adding zero to it: > - :echo bufname("3" + 0) -< If the buffer doesn't exist, or doesn't have a name, an empty - string is returned. > - bufname("#") alternate buffer name - bufname(3) name of buffer 3 - bufname("%") name of current buffer - bufname("file2") name of buffer where "file2" matches. -< *buffer_name()* - Obsolete name: buffer_name(). - - *bufnr()* -bufnr({expr} [, {create}]) - The result is the number of a buffer, as it is displayed by - the ":ls" command. For the use of {expr}, see |bufname()| - above. - If the buffer doesn't exist, -1 is returned. Or, if the - {create} argument is present and not zero, a new, unlisted, - buffer is created and its number is returned. - bufnr("$") is the last buffer: > - :let last_buffer = bufnr("$") -< The result is a Number, which is the highest buffer number - of existing buffers. Note that not all buffers with a smaller - number necessarily exist, because ":bwipeout" may have removed - them. Use bufexists() to test for the existence of a buffer. - *buffer_number()* - Obsolete name: buffer_number(). - *last_buffer_nr()* - Obsolete name for bufnr("$"): last_buffer_nr(). - -bufwinnr({expr}) *bufwinnr()* - The result is a Number, which is the number of the first - window associated with buffer {expr}. For the use of {expr}, - see |bufname()| above. If buffer {expr} doesn't exist or - there is no such window, -1 is returned. Example: > - - echo "A window containing buffer 1 is " . (bufwinnr(1)) - -< The number can be used with |CTRL-W_w| and ":wincmd w" - |:wincmd|. - Only deals with the current tab page. - - -byte2line({byte}) *byte2line()* - Return the line number that contains the character at byte - count {byte} in the current buffer. This includes the - end-of-line character, depending on the 'fileformat' option - for the current buffer. The first character has byte count - one. - Also see |line2byte()|, |go| and |:goto|. - {not available when compiled without the |+byte_offset| - feature} - -byteidx({expr}, {nr}) *byteidx()* - Return byte index of the {nr}'th character in the string - {expr}. Use zero for the first character, it returns zero. - This function is only useful when there are multibyte - characters, otherwise the returned value is equal to {nr}. - Composing characters are counted as a separate character. - Example : > - echo matchstr(str, ".", byteidx(str, 3)) -< will display the fourth character. Another way to do the - same: > - let s = strpart(str, byteidx(str, 3)) - echo strpart(s, 0, byteidx(s, 1)) -< If there are less than {nr} characters -1 is returned. - If there are exactly {nr} characters the length of the string - is returned. - -call({func}, {arglist} [, {dict}]) *call()* *E699* - Call function {func} with the items in |List| {arglist} as - arguments. - {func} can either be a |Funcref| or the name of a function. - a:firstline and a:lastline are set to the cursor line. - Returns the return value of the called function. - {dict} is for functions with the "dict" attribute. It will be - used to set the local variable "self". |Dictionary-function| - -ceil({expr}) *ceil()* - Return the smallest integral value greater than or equal to - {expr} as a |Float| (round up). - {expr} must evaluate to a |Float| or a |Number|. - Examples: > - echo ceil(1.456) -< 2.0 > - echo ceil(-5.456) -< -5.0 > - echo ceil(4.0) -< 4.0 - {only available when compiled with the |+float| feature} - -changenr() *changenr()* - Return the number of the most recent change. This is the same - number as what is displayed with |:undolist| and can be used - with the |:undo| command. - When a change was made it is the number of that change. After - redo it is the number of the redone change. After undo it is - one less than the number of the undone change. - -char2nr({expr}) *char2nr()* - Return number value of the first char in {expr}. Examples: > - char2nr(" ") returns 32 - char2nr("ABC") returns 65 -< The current 'encoding' is used. Example for "utf-8": > - char2nr("á") returns 225 - char2nr("á"[0]) returns 195 -< |nr2char()| does the opposite. - -cindent({lnum}) *cindent()* - Get the amount of indent for line {lnum} according the C - indenting rules, as with 'cindent'. - The indent is counted in spaces, the value of 'tabstop' is - relevant. {lnum} is used just like in |getline()|. - When {lnum} is invalid or Vim was not compiled the |+cindent| - feature, -1 is returned. - See |C-indenting|. - -clearmatches() *clearmatches()* - Clears all matches previously defined by |matchadd()| and the - |:match| commands. - - *col()* -col({expr}) The result is a Number, which is the byte index of the column - position given with {expr}. The accepted positions are: - . the cursor position - $ the end of the cursor line (the result is the - number of characters in the cursor line plus one) - 'x position of mark x (if the mark is not set, 0 is - returned) - Additionally {expr} can be [lnum, col]: a |List| with the line - and column number. Most useful when the column is "$", to get - the last column of a specific line. When "lnum" or "col" is - out of range then col() returns zero. - To get the line number use |line()|. To get both use - |getpos()|. - For the screen column position use |virtcol()|. - Note that only marks in the current file can be used. - Examples: > - col(".") column of cursor - col("$") length of cursor line plus one - col("'t") column of mark t - col("'" . markname) column of mark markname -< The first column is 1. 0 is returned for an error. - For an uppercase mark the column may actually be in another - buffer. - For the cursor position, when 'virtualedit' is active, the - column is one higher if the cursor is after the end of the - line. This can be used to obtain the column in Insert mode: > - :imap :let save_ve = &ve - \:set ve=all - \:echo col(".") . "\n" - \let &ve = save_ve -< - -complete({startcol}, {matches}) *complete()* *E785* - Set the matches for Insert mode completion. - Can only be used in Insert mode. You need to use a mapping - with CTRL-R = |i_CTRL-R|. It does not work after CTRL-O or - with an expression mapping. - {startcol} is the byte offset in the line where the completed - text start. The text up to the cursor is the original text - that will be replaced by the matches. Use col('.') for an - empty string. "col('.') - 1" will replace one character by a - match. - {matches} must be a |List|. Each |List| item is one match. - See |complete-items| for the kind of items that are possible. - Note that the after calling this function you need to avoid - inserting anything that would completion to stop. - The match can be selected with CTRL-N and CTRL-P as usual with - Insert mode completion. The popup menu will appear if - specified, see |ins-completion-menu|. - Example: > - inoremap =ListMonths() - - func! ListMonths() - call complete(col('.'), ['January', 'February', 'March', - \ 'April', 'May', 'June', 'July', 'August', 'September', - \ 'October', 'November', 'December']) - return '' - endfunc -< This isn't very useful, but it shows how it works. Note that - an empty string is returned to avoid a zero being inserted. - -complete_add({expr}) *complete_add()* - Add {expr} to the list of matches. Only to be used by the - function specified with the 'completefunc' option. - Returns 0 for failure (empty string or out of memory), - 1 when the match was added, 2 when the match was already in - the list. - See |complete-functions| for an explanation of {expr}. It is - the same as one item in the list that 'omnifunc' would return. - -complete_check() *complete_check()* - Check for a key typed while looking for completion matches. - This is to be used when looking for matches takes some time. - Returns non-zero when searching for matches is to be aborted, - zero otherwise. - Only to be used by the function specified with the - 'completefunc' option. - - *confirm()* -confirm({msg} [, {choices} [, {default} [, {type}]]]) - Confirm() offers the user a dialog, from which a choice can be - made. It returns the number of the choice. For the first - choice this is 1. - Note: confirm() is only supported when compiled with dialog - support, see |+dialog_con| and |+dialog_gui|. - {msg} is displayed in a |dialog| with {choices} as the - alternatives. When {choices} is missing or empty, "&OK" is - used (and translated). - {msg} is a String, use '\n' to include a newline. Only on - some systems the string is wrapped when it doesn't fit. - {choices} is a String, with the individual choices separated - by '\n', e.g. > - confirm("Save changes?", "&Yes\n&No\n&Cancel") -< The letter after the '&' is the shortcut key for that choice. - Thus you can type 'c' to select "Cancel". The shortcut does - not need to be the first letter: > - confirm("file has been modified", "&Save\nSave &All") -< For the console, the first letter of each choice is used as - the default shortcut key. - The optional {default} argument is the number of the choice - that is made if the user hits . Use 1 to make the first - choice the default one. Use 0 to not set a default. If - {default} is omitted, 1 is used. - The optional {type} argument gives the type of dialog. This - is only used for the icon of the Win32 GUI. It can be one of - these values: "Error", "Question", "Info", "Warning" or - "Generic". Only the first character is relevant. When {type} - is omitted, "Generic" is used. - If the user aborts the dialog by pressing , CTRL-C, - or another valid interrupt key, confirm() returns 0. - - An example: > - :let choice = confirm("What do you want?", "&Apples\n&Oranges\n&Bananas", 2) - :if choice == 0 - : echo "make up your mind!" - :elseif choice == 3 - : echo "tasteful" - :else - : echo "I prefer bananas myself." - :endif -< In a GUI dialog, buttons are used. The layout of the buttons - depends on the 'v' flag in 'guioptions'. If it is included, - the buttons are always put vertically. Otherwise, confirm() - tries to put the buttons in one horizontal line. If they - don't fit, a vertical layout is used anyway. For some systems - the horizontal layout is always used. - - *copy()* -copy({expr}) Make a copy of {expr}. For Numbers and Strings this isn't - different from using {expr} directly. - When {expr} is a |List| a shallow copy is created. This means - that the original |List| can be changed without changing the - copy, and vice versa. But the items are identical, thus - changing an item changes the contents of both |Lists|. Also - see |deepcopy()|. - -cos({expr}) *cos()* - Return the cosine of {expr}, measured in radians, as a |Float|. - {expr} must evaluate to a |Float| or a |Number|. - Examples: > - :echo cos(100) -< 0.862319 > - :echo cos(-4.01) -< -0.646043 - {only available when compiled with the |+float| feature} - - -count({comp}, {expr} [, {ic} [, {start}]]) *count()* - Return the number of times an item with value {expr} appears - in |List| or |Dictionary| {comp}. - If {start} is given then start with the item with this index. - {start} can only be used with a |List|. - When {ic} is given and it's non-zero then case is ignored. - - - *cscope_connection()* -cscope_connection([{num} , {dbpath} [, {prepend}]]) - Checks for the existence of a |cscope| connection. If no - parameters are specified, then the function returns: - 0, if cscope was not available (not compiled in), or - if there are no cscope connections; - 1, if there is at least one cscope connection. - - If parameters are specified, then the value of {num} - determines how existence of a cscope connection is checked: - - {num} Description of existence check - ----- ------------------------------ - 0 Same as no parameters (e.g., "cscope_connection()"). - 1 Ignore {prepend}, and use partial string matches for - {dbpath}. - 2 Ignore {prepend}, and use exact string matches for - {dbpath}. - 3 Use {prepend}, use partial string matches for both - {dbpath} and {prepend}. - 4 Use {prepend}, use exact string matches for both - {dbpath} and {prepend}. - - Note: All string comparisons are case sensitive! - - Examples. Suppose we had the following (from ":cs show"): > - - # pid database name prepend path - 0 27664 cscope.out /usr/local -< - Invocation Return Val ~ - ---------- ---------- > - cscope_connection() 1 - cscope_connection(1, "out") 1 - cscope_connection(2, "out") 0 - cscope_connection(3, "out") 0 - cscope_connection(3, "out", "local") 1 - cscope_connection(4, "out") 0 - cscope_connection(4, "out", "local") 0 - cscope_connection(4, "cscope.out", "/usr/local") 1 -< -cursor({lnum}, {col} [, {off}]) *cursor()* -cursor({list}) - Positions the cursor at the column (byte count) {col} in the - line {lnum}. The first column is one. - When there is one argument {list} this is used as a |List| - with two or three items {lnum}, {col} and {off}. This is like - the return value of |getpos()|, but without the first item. - Does not change the jumplist. - If {lnum} is greater than the number of lines in the buffer, - the cursor will be positioned at the last line in the buffer. - If {lnum} is zero, the cursor will stay in the current line. - If {col} is greater than the number of bytes in the line, - the cursor will be positioned at the last character in the - line. - If {col} is zero, the cursor will stay in the current column. - When 'virtualedit' is used {off} specifies the offset in - screen columns from the start of the character. E.g., a - position within a or after the last character. - - -deepcopy({expr}[, {noref}]) *deepcopy()* *E698* - Make a copy of {expr}. For Numbers and Strings this isn't - different from using {expr} directly. - When {expr} is a |List| a full copy is created. This means - that the original |List| can be changed without changing the - copy, and vice versa. When an item is a |List|, a copy for it - is made, recursively. Thus changing an item in the copy does - not change the contents of the original |List|. - When {noref} is omitted or zero a contained |List| or - |Dictionary| is only copied once. All references point to - this single copy. With {noref} set to 1 every occurrence of a - |List| or |Dictionary| results in a new copy. This also means - that a cyclic reference causes deepcopy() to fail. - *E724* - Nesting is possible up to 100 levels. When there is an item - that refers back to a higher level making a deep copy with - {noref} set to 1 will fail. - Also see |copy()|. - -delete({fname}) *delete()* - Deletes the file by the name {fname}. The result is a Number, - which is 0 if the file was deleted successfully, and non-zero - when the deletion failed. - Use |remove()| to delete an item from a |List|. - - *did_filetype()* -did_filetype() Returns non-zero when autocommands are being executed and the - FileType event has been triggered at least once. Can be used - to avoid triggering the FileType event again in the scripts - that detect the file type. |FileType| - When editing another file, the counter is reset, thus this - really checks if the FileType event has been triggered for the - current buffer. This allows an autocommand that starts - editing another buffer to set 'filetype' and load a syntax - file. - -diff_filler({lnum}) *diff_filler()* - Returns the number of filler lines above line {lnum}. - These are the lines that were inserted at this point in - another diff'ed window. These filler lines are shown in the - display but don't exist in the buffer. - {lnum} is used like with |getline()|. Thus "." is the current - line, "'m" mark m, etc. - Returns 0 if the current window is not in diff mode. - -diff_hlID({lnum}, {col}) *diff_hlID()* - Returns the highlight ID for diff mode at line {lnum} column - {col} (byte index). When the current line does not have a - diff change zero is returned. - {lnum} is used like with |getline()|. Thus "." is the current - line, "'m" mark m, etc. - {col} is 1 for the leftmost column, {lnum} is 1 for the first - line. - The highlight ID can be used with |synIDattr()| to obtain - syntax information about the highlighting. - -empty({expr}) *empty()* - Return the Number 1 if {expr} is empty, zero otherwise. - A |List| or |Dictionary| is empty when it does not have any - items. A Number is empty when its value is zero. - For a long |List| this is much faster then comparing the - length with zero. - -escape({string}, {chars}) *escape()* - Escape the characters in {chars} that occur in {string} with a - backslash. Example: > - :echo escape('c:\program files\vim', ' \') -< results in: > - c:\\program\ files\\vim -< Also see |shellescape()|. - - *eval()* -eval({string}) Evaluate {string} and return the result. Especially useful to - turn the result of |string()| back into the original value. - This works for Numbers, Floats, Strings and composites of - them. Also works for |Funcref|s that refer to existing - functions. - -eventhandler() *eventhandler()* - Returns 1 when inside an event handler. That is that Vim got - interrupted while waiting for the user to type a character, - e.g., when dropping a file on Vim. This means interactive - commands cannot be used. Otherwise zero is returned. - -executable({expr}) *executable()* - This function checks if an executable with the name {expr} - exists. {expr} must be the name of the program without any - arguments. - executable() uses the value of $PATH and/or the normal - searchpath for programs. *PATHEXT* - On MS-DOS and MS-Windows the ".exe", ".bat", etc. can - optionally be included. Then the extensions in $PATHEXT are - tried. Thus if "foo.exe" does not exist, "foo.exe.bat" can be - found. If $PATHEXT is not set then ".exe;.com;.bat;.cmd" is - used. A dot by itself can be used in $PATHEXT to try using - the name without an extension. When 'shell' looks like a - Unix shell, then the name is also tried without adding an - extension. - On MS-DOS and MS-Windows it only checks if the file exists and - is not a directory, not if it's really executable. - On MS-Windows an executable in the same directory as Vim is - always found. Since this directory is added to $PATH it - should also work to execute it |win32-PATH|. - The result is a Number: - 1 exists - 0 does not exist - -1 not implemented on this system - - *exists()* -exists({expr}) The result is a Number, which is non-zero if {expr} is - defined, zero otherwise. The {expr} argument is a string, - which contains one of these: - &option-name Vim option (only checks if it exists, - not if it really works) - +option-name Vim option that works. - $ENVNAME environment variable (could also be - done by comparing with an empty - string) - *funcname built-in function (see |functions|) - or user defined function (see - |user-functions|). - varname internal variable (see - |internal-variables|). Also works - for |curly-braces-names|, |Dictionary| - entries, |List| items, etc. Beware - that evaluating an index may cause an - error message for an invalid - expression. E.g.: > - :let l = [1, 2, 3] - :echo exists("l[5]") -< 0 > - :echo exists("l[xx]") -< E121: Undefined variable: xx - 0 - :cmdname Ex command: built-in command, user - command or command modifier |:command|. - Returns: - 1 for match with start of a command - 2 full match with a command - 3 matches several user commands - To check for a supported command - always check the return value to be 2. - :2match The |:2match| command. - :3match The |:3match| command. - #event autocommand defined for this event - #event#pattern autocommand defined for this event and - pattern (the pattern is taken - literally and compared to the - autocommand patterns character by - character) - #group autocommand group exists - #group#event autocommand defined for this group and - event. - #group#event#pattern - autocommand defined for this group, - event and pattern. - ##event autocommand for this event is - supported. - For checking for a supported feature use |has()|. - - Examples: > - exists("&shortname") - exists("$HOSTNAME") - exists("*strftime") - exists("*s:MyFunc") - exists("bufcount") - exists(":Make") - exists("#CursorHold") - exists("#BufReadPre#*.gz") - exists("#filetypeindent") - exists("#filetypeindent#FileType") - exists("#filetypeindent#FileType#*") - exists("##ColorScheme") -< There must be no space between the symbol (&/$/*/#) and the - name. - There must be no extra characters after the name, although in - a few cases this is ignored. That may become more strict in - the future, thus don't count on it! - Working example: > - exists(":make") -< NOT working example: > - exists(":make install") - -< Note that the argument must be a string, not the name of the - variable itself. For example: > - exists(bufcount) -< This doesn't check for existence of the "bufcount" variable, - but gets the value of "bufcount", and checks if that exists. - -expand({expr} [, {flag}]) *expand()* - Expand wildcards and the following special keywords in {expr}. - The result is a String. - - When there are several matches, they are separated by - characters. [Note: in version 5.0 a space was used, which - caused problems when a file name contains a space] - - If the expansion fails, the result is an empty string. A name - for a non-existing file is not included. - - When {expr} starts with '%', '#' or '<', the expansion is done - like for the |cmdline-special| variables with their associated - modifiers. Here is a short overview: - - % current file name - # alternate file name - #n alternate file name n - file name under the cursor - autocmd file name - autocmd buffer number (as a String!) - autocmd matched name - sourced script file name - word under the cursor - WORD under the cursor - the {clientid} of the last received - message |server2client()| - Modifiers: - :p expand to full path - :h head (last path component removed) - :t tail (last path component only) - :r root (one extension removed) - :e extension only - - Example: > - :let &tags = expand("%:p:h") . "/tags" -< Note that when expanding a string that starts with '%', '#' or - '<', any following text is ignored. This does NOT work: > - :let doesntwork = expand("%:h.bak") -< Use this: > - :let doeswork = expand("%:h") . ".bak" -< Also note that expanding "" and others only returns the - referenced file name without further expansion. If "" - is "~/.cshrc", you need to do another expand() to have the - "~/" expanded into the path of the home directory: > - :echo expand(expand("")) -< - There cannot be white space between the variables and the - following modifier. The |fnamemodify()| function can be used - to modify normal file names. - - When using '%' or '#', and the current or alternate file name - is not defined, an empty string is used. Using "%:p" in a - buffer with no name, results in the current directory, with a - '/' added. - - When {expr} does not start with '%', '#' or '<', it is - expanded like a file name is expanded on the command line. - 'suffixes' and 'wildignore' are used, unless the optional - {flag} argument is given and it is non-zero. Names for - non-existing files are included. The "**" item can be used to - search in a directory tree. For example, to find all "README" - files in the current directory and below: > - :echo expand("**/README") -< - Expand() can also be used to expand variables and environment - variables that are only known in a shell. But this can be - slow, because a shell must be started. See |expr-env-expand|. - The expanded variable is still handled like a list of file - names. When an environment variable cannot be expanded, it is - left unchanged. Thus ":echo expand('$FOOBAR')" results in - "$FOOBAR". - - See |glob()| for finding existing files. See |system()| for - getting the raw output of an external command. - -extend({expr1}, {expr2} [, {expr3}]) *extend()* - {expr1} and {expr2} must be both |Lists| or both - |Dictionaries|. - - If they are |Lists|: Append {expr2} to {expr1}. - If {expr3} is given insert the items of {expr2} before item - {expr3} in {expr1}. When {expr3} is zero insert before the - first item. When {expr3} is equal to len({expr1}) then - {expr2} is appended. - Examples: > - :echo sort(extend(mylist, [7, 5])) - :call extend(mylist, [2, 3], 1) -< When {expr1} is the same List as {expr2} then the number of - items copied is equal to the original length of the List. - E.g., when {expr3} is 1 you get N new copies of the first item - (where N is the original length of the List). - Use |add()| to concatenate one item to a list. To concatenate - two lists into a new list use the + operator: > - :let newlist = [1, 2, 3] + [4, 5] -< - If they are |Dictionaries|: - Add all entries from {expr2} to {expr1}. - If a key exists in both {expr1} and {expr2} then {expr3} is - used to decide what to do: - {expr3} = "keep": keep the value of {expr1} - {expr3} = "force": use the value of {expr2} - {expr3} = "error": give an error message *E737* - When {expr3} is omitted then "force" is assumed. - - {expr1} is changed when {expr2} is not empty. If necessary - make a copy of {expr1} first. - {expr2} remains unchanged. - Returns {expr1}. - - -feedkeys({string} [, {mode}]) *feedkeys()* - Characters in {string} are queued for processing as if they - come from a mapping or were typed by the user. They are added - to the end of the typeahead buffer, thus if a mapping is still - being executed these characters come after them. - The function does not wait for processing of keys contained in - {string}. - To include special keys into {string}, use double-quotes - and "\..." notation |expr-quote|. For example, - feedkeys("\") simulates pressing of the key. But - feedkeys('\') pushes 5 characters. - If {mode} is absent, keys are remapped. - {mode} is a String, which can contain these character flags: - 'm' Remap keys. This is default. - 'n' Do not remap keys. - 't' Handle keys as if typed; otherwise they are handled as - if coming from a mapping. This matters for undo, - opening folds, etc. - Return value is always 0. - -filereadable({file}) *filereadable()* - The result is a Number, which is TRUE when a file with the - name {file} exists, and can be read. If {file} doesn't exist, - or is a directory, the result is FALSE. {file} is any - expression, which is used as a String. - If you don't care about the file being readable you can use - |glob()|. - *file_readable()* - Obsolete name: file_readable(). - - -filewritable({file}) *filewritable()* - The result is a Number, which is 1 when a file with the - name {file} exists, and can be written. If {file} doesn't - exist, or is not writable, the result is 0. If {file} is a - directory, and we can write to it, the result is 2. - - -filter({expr}, {string}) *filter()* - {expr} must be a |List| or a |Dictionary|. - For each item in {expr} evaluate {string} and when the result - is zero remove the item from the |List| or |Dictionary|. - Inside {string} |v:val| has the value of the current item. - For a |Dictionary| |v:key| has the key of the current item. - Examples: > - :call filter(mylist, 'v:val !~ "OLD"') -< Removes the items where "OLD" appears. > - :call filter(mydict, 'v:key >= 8') -< Removes the items with a key below 8. > - :call filter(var, 0) -< Removes all the items, thus clears the |List| or |Dictionary|. - - Note that {string} is the result of expression and is then - used as an expression again. Often it is good to use a - |literal-string| to avoid having to double backslashes. - - The operation is done in-place. If you want a |List| or - |Dictionary| to remain unmodified make a copy first: > - :let l = filter(copy(mylist), 'v:val =~ "KEEP"') - -< Returns {expr}, the |List| or |Dictionary| that was filtered. - When an error is encountered while evaluating {string} no - further items in {expr} are processed. - - -finddir({name}[, {path}[, {count}]]) *finddir()* - Find directory {name} in {path}. Supports both downwards and - upwards recursive directory searches. See |file-searching| - for the syntax of {path}. - Returns the path of the first found match. When the found - directory is below the current directory a relative path is - returned. Otherwise a full path is returned. - If {path} is omitted or empty then 'path' is used. - If the optional {count} is given, find {count}'s occurrence of - {name} in {path} instead of the first one. - When {count} is negative return all the matches in a |List|. - This is quite similar to the ex-command |:find|. - {only available when compiled with the +file_in_path feature} - -findfile({name}[, {path}[, {count}]]) *findfile()* - Just like |finddir()|, but find a file instead of a directory. - Uses 'suffixesadd'. - Example: > - :echo findfile("tags.vim", ".;") -< Searches from the directory of the current file upwards until - it finds the file "tags.vim". - -float2nr({expr}) *float2nr()* - Convert {expr} to a Number by omitting the part after the - decimal point. - {expr} must evaluate to a |Float| or a Number. - When the value of {expr} is out of range for a |Number| the - result is truncated to 0x7fffffff or -0x7fffffff. NaN results - in -0x80000000. - Examples: > - echo float2nr(3.95) -< 3 > - echo float2nr(-23.45) -< -23 > - echo float2nr(1.0e100) -< 2147483647 > - echo float2nr(-1.0e150) -< -2147483647 > - echo float2nr(1.0e-100) -< 0 - {only available when compiled with the |+float| feature} - - -floor({expr}) *floor()* - Return the largest integral value less than or equal to - {expr} as a |Float| (round down). - {expr} must evaluate to a |Float| or a |Number|. - Examples: > - echo floor(1.856) -< 1.0 > - echo floor(-5.456) -< -6.0 > - echo floor(4.0) -< 4.0 - {only available when compiled with the |+float| feature} - -fnameescape({string}) *fnameescape()* - Escape {string} for use as file name command argument. All - characters that have a special meaning, such as '%' and '|' - are escaped with a backslash. - For most systems the characters escaped are - " \t\n*?[{`$\\%#'\"|!<". For systems where a backslash - appears in a filename, it depends on the value of 'isfname'. - A leading '+' and '>' is also escaped (special after |:edit| - and |:write|). And a "-" by itself (special after |:cd|). - Example: > - :let fname = '+some str%nge|name' - :exe "edit " . fnameescape(fname) -< results in executing: > - edit \+some\ str\%nge\|name - -fnamemodify({fname}, {mods}) *fnamemodify()* - Modify file name {fname} according to {mods}. {mods} is a - string of characters like it is used for file names on the - command line. See |filename-modifiers|. - Example: > - :echo fnamemodify("main.c", ":p:h") -< results in: > - /home/mool/vim/vim/src -< Note: Environment variables don't work in {fname}, use - |expand()| first then. - -foldclosed({lnum}) *foldclosed()* - The result is a Number. If the line {lnum} is in a closed - fold, the result is the number of the first line in that fold. - If the line {lnum} is not in a closed fold, -1 is returned. - -foldclosedend({lnum}) *foldclosedend()* - The result is a Number. If the line {lnum} is in a closed - fold, the result is the number of the last line in that fold. - If the line {lnum} is not in a closed fold, -1 is returned. - -foldlevel({lnum}) *foldlevel()* - The result is a Number, which is the foldlevel of line {lnum} - in the current buffer. For nested folds the deepest level is - returned. If there is no fold at line {lnum}, zero is - returned. It doesn't matter if the folds are open or closed. - When used while updating folds (from 'foldexpr') -1 is - returned for lines where folds are still to be updated and the - foldlevel is unknown. As a special case the level of the - previous line is usually available. - - *foldtext()* -foldtext() Returns a String, to be displayed for a closed fold. This is - the default function used for the 'foldtext' option and should - only be called from evaluating 'foldtext'. It uses the - |v:foldstart|, |v:foldend| and |v:folddashes| variables. - The returned string looks like this: > - +-- 45 lines: abcdef -< The number of dashes depends on the foldlevel. The "45" is - the number of lines in the fold. "abcdef" is the text in the - first non-blank line of the fold. Leading white space, "//" - or "/*" and the text from the 'foldmarker' and 'commentstring' - options is removed. - {not available when compiled without the |+folding| feature} - -foldtextresult({lnum}) *foldtextresult()* - Returns the text that is displayed for the closed fold at line - {lnum}. Evaluates 'foldtext' in the appropriate context. - When there is no closed fold at {lnum} an empty string is - returned. - {lnum} is used like with |getline()|. Thus "." is the current - line, "'m" mark m, etc. - Useful when exporting folded text, e.g., to HTML. - {not available when compiled without the |+folding| feature} - - *foreground()* -foreground() Move the Vim window to the foreground. Useful when sent from - a client to a Vim server. |remote_send()| - On Win32 systems this might not work, the OS does not always - allow a window to bring itself to the foreground. Use - |remote_foreground()| instead. - {only in the Win32, Athena, Motif and GTK GUI versions and the - Win32 console version} - - -function({name}) *function()* *E700* - Return a |Funcref| variable that refers to function {name}. - {name} can be a user defined function or an internal function. - - -garbagecollect([at_exit]) *garbagecollect()* - Cleanup unused |Lists| and |Dictionaries| that have circular - references. There is hardly ever a need to invoke this - function, as it is automatically done when Vim runs out of - memory or is waiting for the user to press a key after - 'updatetime'. Items without circular references are always - freed when they become unused. - This is useful if you have deleted a very big |List| and/or - |Dictionary| with circular references in a script that runs - for a long time. - When the optional "at_exit" argument is one, garbage - collection will also be done when exiting Vim, if it wasn't - done before. This is useful when checking for memory leaks. - -get({list}, {idx} [, {default}]) *get()* - Get item {idx} from |List| {list}. When this item is not - available return {default}. Return zero when {default} is - omitted. -get({dict}, {key} [, {default}]) - Get item with key {key} from |Dictionary| {dict}. When this - item is not available return {default}. Return zero when - {default} is omitted. - - *getbufline()* -getbufline({expr}, {lnum} [, {end}]) - Return a |List| with the lines starting from {lnum} to {end} - (inclusive) in the buffer {expr}. If {end} is omitted, a - |List| with only the line {lnum} is returned. - - For the use of {expr}, see |bufname()| above. - - For {lnum} and {end} "$" can be used for the last line of the - buffer. Otherwise a number must be used. - - When {lnum} is smaller than 1 or bigger than the number of - lines in the buffer, an empty |List| is returned. - - When {end} is greater than the number of lines in the buffer, - it is treated as {end} is set to the number of lines in the - buffer. When {end} is before {lnum} an empty |List| is - returned. - - This function works only for loaded buffers. For unloaded and - non-existing buffers, an empty |List| is returned. - - Example: > - :let lines = getbufline(bufnr("myfile"), 1, "$") - -getbufvar({expr}, {varname}) *getbufvar()* - The result is the value of option or local buffer variable - {varname} in buffer {expr}. Note that the name without "b:" - must be used. - When {varname} is empty returns a dictionary with all the - buffer-local variables. - This also works for a global or buffer-local option, but it - doesn't work for a global variable, window-local variable or - window-local option. - For the use of {expr}, see |bufname()| above. - When the buffer or variable doesn't exist an empty string is - returned, there is no error message. - Examples: > - :let bufmodified = getbufvar(1, "&mod") - :echo "todo myvar = " . getbufvar("todo", "myvar") -< -getchar([expr]) *getchar()* - Get a single character from the user or input stream. - If [expr] is omitted, wait until a character is available. - If [expr] is 0, only get a character when one is available. - Return zero otherwise. - If [expr] is 1, only check if a character is available, it is - not consumed. Return zero if no character available. - - Without {expr} and when {expr} is 0 a whole character or - special key is returned. If it is an 8-bit character, the - result is a number. Use nr2char() to convert it to a String. - Otherwise a String is returned with the encoded character. - For a special key it's a sequence of bytes starting with 0x80 - (decimal: 128). This is the same value as the string - "\", e.g., "\". The returned value is also a - String when a modifier (shift, control, alt) was used that is - not included in the character. - - When {expr} is 1 only the first byte is returned. For a - one-byte character it is the character itself as a number. - Use nr2char() to convert it to a String. - - When the user clicks a mouse button, the mouse event will be - returned. The position can then be found in |v:mouse_col|, - |v:mouse_lnum| and |v:mouse_win|. This example positions the - mouse as it would normally happen: > - let c = getchar() - if c == "\" && v:mouse_win > 0 - exe v:mouse_win . "wincmd w" - exe v:mouse_lnum - exe "normal " . v:mouse_col . "|" - endif -< - There is no prompt, you will somehow have to make clear to the - user that a character has to be typed. - There is no mapping for the character. - Key codes are replaced, thus when the user presses the - key you get the code for the key, not the raw character - sequence. Examples: > - getchar() == "\" - getchar() == "\" -< This example redefines "f" to ignore case: > - :nmap f :call FindChar() - :function FindChar() - : let c = nr2char(getchar()) - : while col('.') < col('$') - 1 - : normal l - : if getline('.')[col('.') - 1] ==? c - : break - : endif - : endwhile - :endfunction - -getcharmod() *getcharmod()* - The result is a Number which is the state of the modifiers for - the last obtained character with getchar() or in another way. - These values are added together: - 2 shift - 4 control - 8 alt (meta) - 16 mouse double click - 32 mouse triple click - 64 mouse quadruple click - 128 Macintosh only: command - Only the modifiers that have not been included in the - character itself are obtained. Thus Shift-a results in "A" - with no modifier. - -getcmdline() *getcmdline()* - Return the current command-line. Only works when the command - line is being edited, thus requires use of |c_CTRL-\_e| or - |c_CTRL-R_=|. - Example: > - :cmap eescape(getcmdline(), ' \') -< Also see |getcmdtype()|, |getcmdpos()| and |setcmdpos()|. - -getcmdpos() *getcmdpos()* - Return the position of the cursor in the command line as a - byte count. The first column is 1. - Only works when editing the command line, thus requires use of - |c_CTRL-\_e| or |c_CTRL-R_=|. Returns 0 otherwise. - Also see |getcmdtype()|, |setcmdpos()| and |getcmdline()|. - -getcmdtype() *getcmdtype()* - Return the current command-line type. Possible return values - are: - : normal Ex command - > debug mode command |debug-mode| - / forward search command - ? backward search command - @ |input()| command - - |:insert| or |:append| command - Only works when editing the command line, thus requires use of - |c_CTRL-\_e| or |c_CTRL-R_=|. Returns an empty string - otherwise. - Also see |getcmdpos()|, |setcmdpos()| and |getcmdline()|. - - *getcwd()* -getcwd() The result is a String, which is the name of the current - working directory. - -getfsize({fname}) *getfsize()* - The result is a Number, which is the size in bytes of the - given file {fname}. - If {fname} is a directory, 0 is returned. - If the file {fname} can't be found, -1 is returned. - If the size of {fname} is too big to fit in a Number then -2 - is returned. - -getfontname([{name}]) *getfontname()* - Without an argument returns the name of the normal font being - used. Like what is used for the Normal highlight group - |hl-Normal|. - With an argument a check is done whether {name} is a valid - font name. If not then an empty string is returned. - Otherwise the actual font name is returned, or {name} if the - GUI does not support obtaining the real name. - Only works when the GUI is running, thus not in your vimrc or - gvimrc file. Use the |GUIEnter| autocommand to use this - function just after the GUI has started. - Note that the GTK 2 GUI accepts any font name, thus checking - for a valid name does not work. - -getfperm({fname}) *getfperm()* - The result is a String, which is the read, write, and execute - permissions of the given file {fname}. - If {fname} does not exist or its directory cannot be read, an - empty string is returned. - The result is of the form "rwxrwxrwx", where each group of - "rwx" flags represent, in turn, the permissions of the owner - of the file, the group the file belongs to, and other users. - If a user does not have a given permission the flag for this - is replaced with the string "-". Example: > - :echo getfperm("/etc/passwd") -< This will hopefully (from a security point of view) display - the string "rw-r--r--" or even "rw-------". - -getftime({fname}) *getftime()* - The result is a Number, which is the last modification time of - the given file {fname}. The value is measured as seconds - since 1st Jan 1970, and may be passed to strftime(). See also - |localtime()| and |strftime()|. - If the file {fname} can't be found -1 is returned. - -getftype({fname}) *getftype()* - The result is a String, which is a description of the kind of - file of the given file {fname}. - If {fname} does not exist an empty string is returned. - Here is a table over different kinds of files and their - results: - Normal file "file" - Directory "dir" - Symbolic link "link" - Block device "bdev" - Character device "cdev" - Socket "socket" - FIFO "fifo" - All other "other" - Example: > - getftype("/home") -< Note that a type such as "link" will only be returned on - systems that support it. On some systems only "dir" and - "file" are returned. - - *getline()* -getline({lnum} [, {end}]) - Without {end} the result is a String, which is line {lnum} - from the current buffer. Example: > - getline(1) -< When {lnum} is a String that doesn't start with a - digit, line() is called to translate the String into a Number. - To get the line under the cursor: > - getline(".") -< When {lnum} is smaller than 1 or bigger than the number of - lines in the buffer, an empty string is returned. - - When {end} is given the result is a |List| where each item is - a line from the current buffer in the range {lnum} to {end}, - including line {end}. - {end} is used in the same way as {lnum}. - Non-existing lines are silently omitted. - When {end} is before {lnum} an empty |List| is returned. - Example: > - :let start = line('.') - :let end = search("^$") - 1 - :let lines = getline(start, end) - -< To get lines from another buffer see |getbufline()| - -getloclist({nr}) *getloclist()* - Returns a list with all the entries in the location list for - window {nr}. When {nr} is zero the current window is used. - For a location list window, the displayed location list is - returned. For an invalid window number {nr}, an empty list is - returned. Otherwise, same as getqflist(). - -getmatches() *getmatches()* - Returns a |List| with all matches previously defined by - |matchadd()| and the |:match| commands. |getmatches()| is - useful in combination with |setmatches()|, as |setmatches()| - can restore a list of matches saved by |getmatches()|. - Example: > - :echo getmatches() -< [{'group': 'MyGroup1', 'pattern': 'TODO', - 'priority': 10, 'id': 1}, {'group': 'MyGroup2', - 'pattern': 'FIXME', 'priority': 10, 'id': 2}] > - :let m = getmatches() - :call clearmatches() - :echo getmatches() -< [] > - :call setmatches(m) - :echo getmatches() -< [{'group': 'MyGroup1', 'pattern': 'TODO', - 'priority': 10, 'id': 1}, {'group': 'MyGroup2', - 'pattern': 'FIXME', 'priority': 10, 'id': 2}] > - :unlet m -< - -getqflist() *getqflist()* - Returns a list with all the current quickfix errors. Each - list item is a dictionary with these entries: - bufnr number of buffer that has the file name, use - bufname() to get the name - lnum line number in the buffer (first line is 1) - col column number (first column is 1) - vcol non-zero: "col" is visual column - zero: "col" is byte index - nr error number - pattern search pattern used to locate the error - text description of the error - type type of the error, 'E', '1', etc. - valid non-zero: recognized error message - - When there is no error list or it's empty an empty list is - returned. Quickfix list entries with non-existing buffer - number are returned with "bufnr" set to zero. - - Useful application: Find pattern matches in multiple files and - do something with them: > - :vimgrep /theword/jg *.c - :for d in getqflist() - : echo bufname(d.bufnr) ':' d.lnum '=' d.text - :endfor - - -getreg([{regname} [, 1]]) *getreg()* - The result is a String, which is the contents of register - {regname}. Example: > - :let cliptext = getreg('*') -< getreg('=') returns the last evaluated value of the expression - register. (For use in maps.) - getreg('=', 1) returns the expression itself, so that it can - be restored with |setreg()|. For other registers the extra - argument is ignored, thus you can always give it. - If {regname} is not specified, |v:register| is used. - - -getregtype([{regname}]) *getregtype()* - The result is a String, which is type of register {regname}. - The value will be one of: - "v" for |characterwise| text - "V" for |linewise| text - "{width}" for |blockwise-visual| text - 0 for an empty or unknown register - is one character with value 0x16. - If {regname} is not specified, |v:register| is used. - -gettabwinvar({tabnr}, {winnr}, {varname}) *gettabwinvar()* - Get the value of window-local variable {varname} in window - {winnr} in tab page {tabnr}. - When {varname} starts with "&" get the value of a window-local - option. - Tabs are numbered starting with one. For the current tabpage - use |getwinvar()|. - When {winnr} is zero the current window is used. - This also works for a global option, buffer-local option and - window-local option, but it doesn't work for a global variable - or buffer-local variable. - When {varname} is empty a dictionary with all window-local - variables is returned. - Note that {varname} must be the name without "w:". - Examples: > - :let list_is_on = gettabwinvar(1, 2, '&list') - :echo "myvar = " . gettabwinvar(3, 1, 'myvar') -< - *getwinposx()* -getwinposx() The result is a Number, which is the X coordinate in pixels of - the left hand side of the GUI Vim window. The result will be - -1 if the information is not available. - - *getwinposy()* -getwinposy() The result is a Number, which is the Y coordinate in pixels of - the top of the GUI Vim window. The result will be -1 if the - information is not available. - -getwinvar({winnr}, {varname}) *getwinvar()* - Like |gettabwinvar()| for the current tabpage. - Examples: > - :let list_is_on = getwinvar(2, '&list') - :echo "myvar = " . getwinvar(1, 'myvar') -< - *glob()* -glob({expr}) Expand the file wildcards in {expr}. See |wildcards| for the - use of special characters. - The result is a String. - When there are several matches, they are separated by - characters. - The 'wildignore' option applies: Names matching one of the - patterns in 'wildignore' will be skipped. - If the expansion fails, the result is an empty string. - A name for a non-existing file is not included. - - For most systems backticks can be used to get files names from - any external command. Example: > - :let tagfiles = glob("`find . -name tags -print`") - :let &tags = substitute(tagfiles, "\n", ",", "g") -< The result of the program inside the backticks should be one - item per line. Spaces inside an item are allowed. - - See |expand()| for expanding special Vim variables. See - |system()| for getting the raw output of an external command. - -globpath({path}, {expr}) *globpath()* - Perform glob() on all directories in {path} and concatenate - the results. Example: > - :echo globpath(&rtp, "syntax/c.vim") -< {path} is a comma-separated list of directory names. Each - directory name is prepended to {expr} and expanded like with - glob(). A path separator is inserted when needed. - To add a comma inside a directory name escape it with a - backslash. Note that on MS-Windows a directory may have a - trailing backslash, remove it if you put a comma after it. - If the expansion fails for one of the directories, there is no - error message. - The 'wildignore' option applies: Names matching one of the - patterns in 'wildignore' will be skipped. - - The "**" item can be used to search in a directory tree. - For example, to find all "README.txt" files in the directories - in 'runtimepath' and below: > - :echo globpath(&rtp, "**/README.txt") -< Upwards search and limiting the depth of "**" is not - supported, thus using 'path' will not always work properly. - - *has()* -has({feature}) The result is a Number, which is 1 if the feature {feature} is - supported, zero otherwise. The {feature} argument is a - string. See |feature-list| below. - Also see |exists()|. - - -has_key({dict}, {key}) *has_key()* - The result is a Number, which is 1 if |Dictionary| {dict} has - an entry with key {key}. Zero otherwise. - -haslocaldir() *haslocaldir()* - The result is a Number, which is 1 when the current - window has set a local path via |:lcd|, and 0 otherwise. - -hasmapto({what} [, {mode} [, {abbr}]]) *hasmapto()* - The result is a Number, which is 1 if there is a mapping that - contains {what} in somewhere in the rhs (what it is mapped to) - and this mapping exists in one of the modes indicated by - {mode}. - When {abbr} is there and it is non-zero use abbreviations - instead of mappings. Don't forget to specify Insert and/or - Command-line mode. - Both the global mappings and the mappings local to the current - buffer are checked for a match. - If no matching mapping is found 0 is returned. - The following characters are recognized in {mode}: - n Normal mode - v Visual mode - o Operator-pending mode - i Insert mode - l Language-Argument ("r", "f", "t", etc.) - c Command-line mode - When {mode} is omitted, "nvo" is used. - - This function is useful to check if a mapping already exists - to a function in a Vim script. Example: > - :if !hasmapto('\ABCdoit') - : map d \ABCdoit - :endif -< This installs the mapping to "\ABCdoit" only if there isn't - already a mapping to "\ABCdoit". - -histadd({history}, {item}) *histadd()* - Add the String {item} to the history {history} which can be - one of: *hist-names* - "cmd" or ":" command line history - "search" or "/" search pattern history - "expr" or "=" typed expression history - "input" or "@" input line history - If {item} does already exist in the history, it will be - shifted to become the newest entry. - The result is a Number: 1 if the operation was successful, - otherwise 0 is returned. - - Example: > - :call histadd("input", strftime("%Y %b %d")) - :let date=input("Enter date: ") -< This function is not available in the |sandbox|. - -histdel({history} [, {item}]) *histdel()* - Clear {history}, i.e. delete all its entries. See |hist-names| - for the possible values of {history}. - - If the parameter {item} evaluates to a String, it is used as a - regular expression. All entries matching that expression will - be removed from the history (if there are any). - Upper/lowercase must match, unless "\c" is used |/\c|. - If {item} evaluates to a Number, it will be interpreted as - an index, see |:history-indexing|. The respective entry will - be removed if it exists. - - The result is a Number: 1 for a successful operation, - otherwise 0 is returned. - - Examples: - Clear expression register history: > - :call histdel("expr") -< - Remove all entries starting with "*" from the search history: > - :call histdel("/", '^\*') -< - The following three are equivalent: > - :call histdel("search", histnr("search")) - :call histdel("search", -1) - :call histdel("search", '^'.histget("search", -1).'$') -< - To delete the last search pattern and use the last-but-one for - the "n" command and 'hlsearch': > - :call histdel("search", -1) - :let @/ = histget("search", -1) - -histget({history} [, {index}]) *histget()* - The result is a String, the entry with Number {index} from - {history}. See |hist-names| for the possible values of - {history}, and |:history-indexing| for {index}. If there is - no such entry, an empty String is returned. When {index} is - omitted, the most recent item from the history is used. - - Examples: - Redo the second last search from history. > - :execute '/' . histget("search", -2) - -< Define an Ex command ":H {num}" that supports re-execution of - the {num}th entry from the output of |:history|. > - :command -nargs=1 H execute histget("cmd", 0+) -< -histnr({history}) *histnr()* - The result is the Number of the current entry in {history}. - See |hist-names| for the possible values of {history}. - If an error occurred, -1 is returned. - - Example: > - :let inp_index = histnr("expr") -< -hlexists({name}) *hlexists()* - The result is a Number, which is non-zero if a highlight group - called {name} exists. This is when the group has been - defined in some way. Not necessarily when highlighting has - been defined for it, it may also have been used for a syntax - item. - *highlight_exists()* - Obsolete name: highlight_exists(). - - *hlID()* -hlID({name}) The result is a Number, which is the ID of the highlight group - with name {name}. When the highlight group doesn't exist, - zero is returned. - This can be used to retrieve information about the highlight - group. For example, to get the background color of the - "Comment" group: > - :echo synIDattr(synIDtrans(hlID("Comment")), "bg") -< *highlightID()* - Obsolete name: highlightID(). - -hostname() *hostname()* - The result is a String, which is the name of the machine on - which Vim is currently running. Machine names greater than - 256 characters long are truncated. - -iconv({expr}, {from}, {to}) *iconv()* - The result is a String, which is the text {expr} converted - from encoding {from} to encoding {to}. - When the conversion fails an empty string is returned. - The encoding names are whatever the iconv() library function - can accept, see ":!man 3 iconv". - Most conversions require Vim to be compiled with the |+iconv| - feature. Otherwise only UTF-8 to latin1 conversion and back - can be done. - This can be used to display messages with special characters, - no matter what 'encoding' is set to. Write the message in - UTF-8 and use: > - echo iconv(utf8_str, "utf-8", &enc) -< Note that Vim uses UTF-8 for all Unicode encodings, conversion - from/to UCS-2 is automatically changed to use UTF-8. You - cannot use UCS-2 in a string anyway, because of the NUL bytes. - {only available when compiled with the +multi_byte feature} - - *indent()* -indent({lnum}) The result is a Number, which is indent of line {lnum} in the - current buffer. The indent is counted in spaces, the value - of 'tabstop' is relevant. {lnum} is used just like in - |getline()|. - When {lnum} is invalid -1 is returned. - - -index({list}, {expr} [, {start} [, {ic}]]) *index()* - Return the lowest index in |List| {list} where the item has a - value equal to {expr}. - If {start} is given then start looking at the item with index - {start} (may be negative for an item relative to the end). - When {ic} is given and it is non-zero, ignore case. Otherwise - case must match. - -1 is returned when {expr} is not found in {list}. - Example: > - :let idx = index(words, "the") - :if index(numbers, 123) >= 0 - - -input({prompt} [, {text} [, {completion}]]) *input()* - The result is a String, which is whatever the user typed on - the command-line. The parameter is either a prompt string, or - a blank string (for no prompt). A '\n' can be used in the - prompt to start a new line. - The highlighting set with |:echohl| is used for the prompt. - The input is entered just like a command-line, with the same - editing commands and mappings. There is a separate history - for lines typed for input(). - Example: > - :if input("Coffee or beer? ") == "beer" - : echo "Cheers!" - :endif -< - If the optional {text} is present and not empty, this is used - for the default reply, as if the user typed this. Example: > - :let color = input("Color? ", "white") - -< The optional {completion} argument specifies the type of - completion supported for the input. Without it completion is - not performed. The supported completion types are the same as - that can be supplied to a user-defined command using the - "-complete=" argument. Refer to |:command-completion| for - more information. Example: > - let fname = input("File: ", "", "file") -< - NOTE: This function must not be used in a startup file, for - the versions that only run in GUI mode (e.g., the Win32 GUI). - Note: When input() is called from within a mapping it will - consume remaining characters from that mapping, because a - mapping is handled like the characters were typed. - Use |inputsave()| before input() and |inputrestore()| - after input() to avoid that. Another solution is to avoid - that further characters follow in the mapping, e.g., by using - |:execute| or |:normal|. - - Example with a mapping: > - :nmap \x :call GetFoo():exe "/" . Foo - :function GetFoo() - : call inputsave() - : let g:Foo = input("enter search pattern: ") - : call inputrestore() - :endfunction - -inputdialog({prompt} [, {text} [, {cancelreturn}]]) *inputdialog()* - Like input(), but when the GUI is running and text dialogs are - supported, a dialog window pops up to input the text. - Example: > - :let n = inputdialog("value for shiftwidth", &sw) - :if n != "" - : let &sw = n - :endif -< When the dialog is cancelled {cancelreturn} is returned. When - omitted an empty string is returned. - Hitting works like pressing the OK button. Hitting - works like pressing the Cancel button. - NOTE: Command-line completion is not supported. - -inputlist({textlist}) *inputlist()* - {textlist} must be a |List| of strings. This |List| is - displayed, one string per line. The user will be prompted to - enter a number, which is returned. - The user can also select an item by clicking on it with the - mouse. For the first string 0 is returned. When clicking - above the first item a negative number is returned. When - clicking on the prompt one more than the length of {textlist} - is returned. - Make sure {textlist} has less then 'lines' entries, otherwise - it won't work. It's a good idea to put the entry number at - the start of the string. And put a prompt in the first item. - Example: > - let color = inputlist(['Select color:', '1. red', - \ '2. green', '3. blue']) - -inputrestore() *inputrestore()* - Restore typeahead that was saved with a previous inputsave(). - Should be called the same number of times inputsave() is - called. Calling it more often is harmless though. - Returns 1 when there is nothing to restore, 0 otherwise. - -inputsave() *inputsave()* - Preserve typeahead (also from mappings) and clear it, so that - a following prompt gets input from the user. Should be - followed by a matching inputrestore() after the prompt. Can - be used several times, in which case there must be just as - many inputrestore() calls. - Returns 1 when out of memory, 0 otherwise. - -inputsecret({prompt} [, {text}]) *inputsecret()* - This function acts much like the |input()| function with but - two exceptions: - a) the user's response will be displayed as a sequence of - asterisks ("*") thereby keeping the entry secret, and - b) the user's response will not be recorded on the input - |history| stack. - The result is a String, which is whatever the user actually - typed on the command-line in response to the issued prompt. - NOTE: Command-line completion is not supported. - -insert({list}, {item} [, {idx}]) *insert()* - Insert {item} at the start of |List| {list}. - If {idx} is specified insert {item} before the item with index - {idx}. If {idx} is zero it goes before the first item, just - like omitting {idx}. A negative {idx} is also possible, see - |list-index|. -1 inserts just before the last item. - Returns the resulting |List|. Examples: > - :let mylist = insert([2, 3, 5], 1) - :call insert(mylist, 4, -1) - :call insert(mylist, 6, len(mylist)) -< The last example can be done simpler with |add()|. - Note that when {item} is a |List| it is inserted as a single - item. Use |extend()| to concatenate |Lists|. - -isdirectory({directory}) *isdirectory()* - The result is a Number, which is non-zero when a directory - with the name {directory} exists. If {directory} doesn't - exist, or isn't a directory, the result is FALSE. {directory} - is any expression, which is used as a String. - -islocked({expr}) *islocked()* *E786* - The result is a Number, which is non-zero when {expr} is the - name of a locked variable. - {expr} must be the name of a variable, |List| item or - |Dictionary| entry, not the variable itself! Example: > - :let alist = [0, ['a', 'b'], 2, 3] - :lockvar 1 alist - :echo islocked('alist') " 1 - :echo islocked('alist[1]') " 0 - -< When {expr} is a variable that does not exist you get an error - message. Use |exists()| to check for existence. - -items({dict}) *items()* - Return a |List| with all the key-value pairs of {dict}. Each - |List| item is a list with two items: the key of a {dict} - entry and the value of this entry. The |List| is in arbitrary - order. - - -join({list} [, {sep}]) *join()* - Join the items in {list} together into one String. - When {sep} is specified it is put in between the items. If - {sep} is omitted a single space is used. - Note that {sep} is not added at the end. You might want to - add it there too: > - let lines = join(mylist, "\n") . "\n" -< String items are used as-is. |Lists| and |Dictionaries| are - converted into a string like with |string()|. - The opposite function is |split()|. - -keys({dict}) *keys()* - Return a |List| with all the keys of {dict}. The |List| is in - arbitrary order. - - *len()* *E701* -len({expr}) The result is a Number, which is the length of the argument. - When {expr} is a String or a Number the length in bytes is - used, as with |strlen()|. - When {expr} is a |List| the number of items in the |List| is - returned. - When {expr} is a |Dictionary| the number of entries in the - |Dictionary| is returned. - Otherwise an error is given. - - *libcall()* *E364* *E368* -libcall({libname}, {funcname}, {argument}) - Call function {funcname} in the run-time library {libname} - with single argument {argument}. - This is useful to call functions in a library that you - especially made to be used with Vim. Since only one argument - is possible, calling standard library functions is rather - limited. - The result is the String returned by the function. If the - function returns NULL, this will appear as an empty string "" - to Vim. - If the function returns a number, use libcallnr()! - If {argument} is a number, it is passed to the function as an - int; if {argument} is a string, it is passed as a - null-terminated string. - This function will fail in |restricted-mode|. - - libcall() allows you to write your own 'plug-in' extensions to - Vim without having to recompile the program. It is NOT a - means to call system functions! If you try to do so Vim will - very probably crash. - - For Win32, the functions you write must be placed in a DLL - and use the normal C calling convention (NOT Pascal which is - used in Windows System DLLs). The function must take exactly - one parameter, either a character pointer or a long integer, - and must return a character pointer or NULL. The character - pointer returned must point to memory that will remain valid - after the function has returned (e.g. in static data in the - DLL). If it points to allocated memory, that memory will - leak away. Using a static buffer in the function should work, - it's then freed when the DLL is unloaded. - - WARNING: If the function returns a non-valid pointer, Vim may - crash! This also happens if the function returns a number, - because Vim thinks it's a pointer. - For Win32 systems, {libname} should be the filename of the DLL - without the ".DLL" suffix. A full path is only required if - the DLL is not in the usual places. - For Unix: When compiling your own plugins, remember that the - object code must be compiled as position-independent ('PIC'). - {only in Win32 on some Unix versions, when the |+libcall| - feature is present} - Examples: > - :echo libcall("libc.so", "getenv", "HOME") -< - *libcallnr()* -libcallnr({libname}, {funcname}, {argument}) - Just like libcall(), but used for a function that returns an - int instead of a string. - {only in Win32 on some Unix versions, when the |+libcall| - feature is present} - Examples: > - :echo libcallnr("/usr/lib/libc.so", "getpid", "") - :call libcallnr("libc.so", "printf", "Hello World!\n") - :call libcallnr("libc.so", "sleep", 10) -< - *line()* -line({expr}) The result is a Number, which is the line number of the file - position given with {expr}. The accepted positions are: - . the cursor position - $ the last line in the current buffer - 'x position of mark x (if the mark is not set, 0 is - returned) - w0 first line visible in current window - w$ last line visible in current window - v In Visual mode: the start of the Visual area (the - cursor is the end). When not in Visual mode - returns the cursor position. Differs from |'<| in - that it's updated right away. - Note that a mark in another file can be used. The line number - then applies to another buffer. - To get the column number use |col()|. To get both use - |getpos()|. - Examples: > - line(".") line number of the cursor - line("'t") line number of mark t - line("'" . marker) line number of mark marker -< *last-position-jump* - This autocommand jumps to the last known position in a file - just after opening it, if the '" mark is set: > - :au BufReadPost * if line("'\"") > 1 && line("'\"") <= line("$") | exe "normal! g'\"" | endif - -line2byte({lnum}) *line2byte()* - Return the byte count from the start of the buffer for line - {lnum}. This includes the end-of-line character, depending on - the 'fileformat' option for the current buffer. The first - line returns 1. - This can also be used to get the byte count for the line just - below the last line: > - line2byte(line("$") + 1) -< This is the file size plus one. - When {lnum} is invalid, or the |+byte_offset| feature has been - disabled at compile time, -1 is returned. - Also see |byte2line()|, |go| and |:goto|. - -lispindent({lnum}) *lispindent()* - Get the amount of indent for line {lnum} according the lisp - indenting rules, as with 'lisp'. - The indent is counted in spaces, the value of 'tabstop' is - relevant. {lnum} is used just like in |getline()|. - When {lnum} is invalid or Vim was not compiled the - |+lispindent| feature, -1 is returned. - -localtime() *localtime()* - Return the current time, measured as seconds since 1st Jan - 1970. See also |strftime()| and |getftime()|. - - -log10({expr}) *log10()* - Return the logarithm of Float {expr} to base 10 as a |Float|. - {expr} must evaluate to a |Float| or a |Number|. - Examples: > - :echo log10(1000) -< 3.0 > - :echo log10(0.01) -< -2.0 - {only available when compiled with the |+float| feature} - -map({expr}, {string}) *map()* - {expr} must be a |List| or a |Dictionary|. - Replace each item in {expr} with the result of evaluating - {string}. - Inside {string} |v:val| has the value of the current item. - For a |Dictionary| |v:key| has the key of the current item. - Example: > - :call map(mylist, '"> " . v:val . " <"') -< This puts "> " before and " <" after each item in "mylist". - - Note that {string} is the result of an expression and is then - used as an expression again. Often it is good to use a - |literal-string| to avoid having to double backslashes. You - still have to double ' quotes - - The operation is done in-place. If you want a |List| or - |Dictionary| to remain unmodified make a copy first: > - :let tlist = map(copy(mylist), ' & . "\t"') - -< Returns {expr}, the |List| or |Dictionary| that was filtered. - When an error is encountered while evaluating {string} no - further items in {expr} are processed. - - -maparg({name}[, {mode} [, {abbr}]]) *maparg()* - Return the rhs of mapping {name} in mode {mode}. When there - is no mapping for {name}, an empty String is returned. - {mode} can be one of these strings: - "n" Normal - "v" Visual - "o" Operator-pending - "i" Insert - "c" Cmd-line - "l" langmap |language-mapping| - "" Normal, Visual and Operator-pending - When {mode} is omitted, the modes for "" are used. - When {abbr} is there and it is non-zero use abbreviations - instead of mappings. - The {name} can have special key names, like in the ":map" - command. The returned String has special characters - translated like in the output of the ":map" command listing. - The mappings local to the current buffer are checked first, - then the global mappings. - This function can be used to map a key even when it's already - mapped, and have it do the original mapping too. Sketch: > - exe 'nnoremap ==' . maparg('', 'n') - - -mapcheck({name}[, {mode} [, {abbr}]]) *mapcheck()* - Check if there is a mapping that matches with {name} in mode - {mode}. See |maparg()| for {mode} and special names in - {name}. - When {abbr} is there and it is non-zero use abbreviations - instead of mappings. - A match happens with a mapping that starts with {name} and - with a mapping which is equal to the start of {name}. - - matches mapping "a" "ab" "abc" ~ - mapcheck("a") yes yes yes - mapcheck("abc") yes yes yes - mapcheck("ax") yes no no - mapcheck("b") no no no - - The difference with maparg() is that mapcheck() finds a - mapping that matches with {name}, while maparg() only finds a - mapping for {name} exactly. - When there is no mapping that starts with {name}, an empty - String is returned. If there is one, the rhs of that mapping - is returned. If there are several mappings that start with - {name}, the rhs of one of them is returned. - The mappings local to the current buffer are checked first, - then the global mappings. - This function can be used to check if a mapping can be added - without being ambiguous. Example: > - :if mapcheck("_vv") == "" - : map _vv :set guifont=7x13 - :endif -< This avoids adding the "_vv" mapping when there already is a - mapping for "_v" or for "_vvv". - -match({expr}, {pat}[, {start}[, {count}]]) *match()* - When {expr} is a |List| then this returns the index of the - first item where {pat} matches. Each item is used as a - String, |Lists| and |Dictionaries| are used as echoed. - Otherwise, {expr} is used as a String. The result is a - Number, which gives the index (byte offset) in {expr} where - {pat} matches. - A match at the first character or |List| item returns zero. - If there is no match -1 is returned. - Example: > - :echo match("testing", "ing") " results in 4 - :echo match([1, 'x'], '\a') " results in 1 -< See |string-match| for how {pat} is used. - *strpbrk()* - Vim doesn't have a strpbrk() function. But you can do: > - :let sepidx = match(line, '[.,;: \t]') -< *strcasestr()* - Vim doesn't have a strcasestr() function. But you can add - "\c" to the pattern to ignore case: > - :let idx = match(haystack, '\cneedle') -< - If {start} is given, the search starts from byte index - {start} in a String or item {start} in a |List|. - The result, however, is still the index counted from the - first character/item. Example: > - :echo match("testing", "ing", 2) -< result is again "4". > - :echo match("testing", "ing", 4) -< result is again "4". > - :echo match("testing", "t", 2) -< result is "3". - For a String, if {start} > 0 then it is like the string starts - {start} bytes later, thus "^" will match at {start}. Except - when {count} is given, then it's like matches before the - {start} byte are ignored (this is a bit complicated to keep it - backwards compatible). - For a String, if {start} < 0, it will be set to 0. For a list - the index is counted from the end. - If {start} is out of range ({start} > strlen({expr}) for a - String or {start} > len({expr}) for a |List|) -1 is returned. - - When {count} is given use the {count}'th match. When a match - is found in a String the search for the next one starts one - character further. Thus this example results in 1: > - echo match("testing", "..", 0, 2) -< In a |List| the search continues in the next item. - Note that when {count} is added the way {start} works changes, - see above. - - See |pattern| for the patterns that are accepted. - The 'ignorecase' option is used to set the ignore-caseness of - the pattern. 'smartcase' is NOT used. The matching is always - done like 'magic' is set and 'cpoptions' is empty. - - *matchadd()* *E798* *E799* *E801* -matchadd({group}, {pattern}[, {priority}[, {id}]]) - Defines a pattern to be highlighted in the current window (a - "match"). It will be highlighted with {group}. Returns an - identification number (ID), which can be used to delete the - match using |matchdelete()|. - - The optional {priority} argument assigns a priority to the - match. A match with a high priority will have its - highlighting overrule that of a match with a lower priority. - A priority is specified as an integer (negative numbers are no - exception). If the {priority} argument is not specified, the - default priority is 10. The priority of 'hlsearch' is zero, - hence all matches with a priority greater than zero will - overrule it. Syntax highlighting (see 'syntax') is a separate - mechanism, and regardless of the chosen priority a match will - always overrule syntax highlighting. - - The optional {id} argument allows the request for a specific - match ID. If a specified ID is already taken, an error - message will appear and the match will not be added. An ID - is specified as a positive integer (zero excluded). IDs 1, 2 - and 3 are reserved for |:match|, |:2match| and |:3match|, - respectively. If the {id} argument is not specified, - |matchadd()| automatically chooses a free ID. - - The number of matches is not limited, as it is the case with - the |:match| commands. - - Example: > - :highlight MyGroup ctermbg=green guibg=green - :let m = matchadd("MyGroup", "TODO") -< Deletion of the pattern: > - :call matchdelete(m) - -< A list of matches defined by |matchadd()| and |:match| are - available from |getmatches()|. All matches can be deleted in - one operation by |clearmatches()|. - -matcharg({nr}) *matcharg()* - Selects the {nr} match item, as set with a |:match|, - |:2match| or |:3match| command. - Return a |List| with two elements: - The name of the highlight group used - The pattern used. - When {nr} is not 1, 2 or 3 returns an empty |List|. - When there is no match item set returns ['', '']. - This is useful to save and restore a |:match|. - Highlighting matches using the |:match| commands are limited - to three matches. |matchadd()| does not have this limitation. - -matchdelete({id}) *matchdelete()* *E802* *E803* - Deletes a match with ID {id} previously defined by |matchadd()| - or one of the |:match| commands. Returns 0 if successful, - otherwise -1. See example for |matchadd()|. All matches can - be deleted in one operation by |clearmatches()|. - -matchend({expr}, {pat}[, {start}[, {count}]]) *matchend()* - Same as match(), but return the index of first character after - the match. Example: > - :echo matchend("testing", "ing") -< results in "7". - *strspn()* *strcspn()* - Vim doesn't have a strspn() or strcspn() function, but you can - do it with matchend(): > - :let span = matchend(line, '[a-zA-Z]') - :let span = matchend(line, '[^a-zA-Z]') -< Except that -1 is returned when there are no matches. - - The {start}, if given, has the same meaning as for match(). > - :echo matchend("testing", "ing", 2) -< results in "7". > - :echo matchend("testing", "ing", 5) -< result is "-1". - When {expr} is a |List| the result is equal to match(). - -matchlist({expr}, {pat}[, {start}[, {count}]]) *matchlist()* - Same as match(), but return a |List|. The first item in the - list is the matched string, same as what matchstr() would - return. Following items are submatches, like "\1", "\2", etc. - in |:substitute|. When an optional submatch didn't match an - empty string is used. Example: > - echo matchlist('acd', '\(a\)\?\(b\)\?\(c\)\?\(.*\)') -< Results in: ['acd', 'a', '', 'c', 'd', '', '', '', '', ''] - When there is no match an empty list is returned. - -matchstr({expr}, {pat}[, {start}[, {count}]]) *matchstr()* - Same as |match()|, but return the matched string. Example: > - :echo matchstr("testing", "ing") -< results in "ing". - When there is no match "" is returned. - The {start}, if given, has the same meaning as for match(). > - :echo matchstr("testing", "ing", 2) -< results in "ing". > - :echo matchstr("testing", "ing", 5) -< result is "". - When {expr} is a |List| then the matching item is returned. - The type isn't changed, it's not necessarily a String. - - *max()* -max({list}) Return the maximum value of all items in {list}. - If {list} is not a list or one of the items in {list} cannot - be used as a Number this results in an error. - An empty |List| results in zero. - - *min()* -min({list}) Return the minimum value of all items in {list}. - If {list} is not a list or one of the items in {list} cannot - be used as a Number this results in an error. - An empty |List| results in zero. - - *mkdir()* *E739* -mkdir({name} [, {path} [, {prot}]]) - Create directory {name}. - If {path} is "p" then intermediate directories are created as - necessary. Otherwise it must be "". - If {prot} is given it is used to set the protection bits of - the new directory. The default is 0755 (rwxr-xr-x: r/w for - the user readable for others). Use 0700 to make it unreadable - for others. This is only used for the last part of {name}. - Thus if you create /tmp/foo/bar then /tmp/foo will be created - with 0755. - Example: > - :call mkdir($HOME . "/tmp/foo/bar", "p", 0700) -< This function is not available in the |sandbox|. - Not available on all systems. To check use: > - :if exists("*mkdir") -< - *mode()* -mode([expr]) Return a string that indicates the current mode. - If [expr] is supplied and it evaluates to a non-zero Number or - a non-empty String (|non-zero-arg|), then the full mode is - returned, otherwise only the first letter is returned. Note - that " " and "0" are also non-empty strings. - - n Normal - no Operator-pending - v Visual by character - V Visual by line - CTRL-V Visual blockwise - s Select by character - S Select by line - CTRL-S Select blockwise - i Insert - R Replace |R| - Rv Virtual Replace |gR| - c Command-line - cv Vim Ex mode |gQ| - ce Normal Ex mode |Q| - r Hit-enter prompt - rm The -- more -- prompt - r? A |:confirm| query of some sort - ! Shell or external command is executing - This is useful in the 'statusline' option or when used - with |remote_expr()| In most other places it always returns - "c" or "n". - Also see |visualmode()|. - -nextnonblank({lnum}) *nextnonblank()* - Return the line number of the first line at or below {lnum} - that is not blank. Example: > - if getline(nextnonblank(1)) =~ "Java" -< When {lnum} is invalid or there is no non-blank line at or - below it, zero is returned. - See also |prevnonblank()|. - -nr2char({expr}) *nr2char()* - Return a string with a single character, which has the number - value {expr}. Examples: > - nr2char(64) returns "@" - nr2char(32) returns " " -< The current 'encoding' is used. Example for "utf-8": > - nr2char(300) returns I with bow character -< Note that a NUL character in the file is specified with - nr2char(10), because NULs are represented with newline - characters. nr2char(0) is a real NUL and terminates the - string, thus results in an empty string. - - *getpid()* -getpid() Return a Number which is the process ID of the Vim process. - On Unix and MS-Windows this is a unique number, until Vim - exits. On MS-DOS it's always zero. - - *getpos()* -getpos({expr}) Get the position for {expr}. For possible values of {expr} - see |line()|. - The result is a |List| with four numbers: - [bufnum, lnum, col, off] - "bufnum" is zero, unless a mark like '0 or 'A is used, then it - is the buffer number of the mark. - "lnum" and "col" are the position in the buffer. The first - column is 1. - The "off" number is zero, unless 'virtualedit' is used. Then - it is the offset in screen columns from the start of the - character. E.g., a position within a or after the last - character. - This can be used to save and restore the cursor position: > - let save_cursor = getpos(".") - MoveTheCursorAround - call setpos('.', save_cursor) -< Also see |setpos()|. - -pathshorten({expr}) *pathshorten()* - Shorten directory names in the path {expr} and return the - result. The tail, the file name, is kept as-is. The other - components in the path are reduced to single letters. Leading - '~' and '.' characters are kept. Example: > - :echo pathshorten('~/.vim/autoload/myfile.vim') -< ~/.v/a/myfile.vim ~ - It doesn't matter if the path exists or not. - -pow({x}, {y}) *pow()* - Return the power of {x} to the exponent {y} as a |Float|. - {x} and {y} must evaluate to a |Float| or a |Number|. - Examples: > - :echo pow(3, 3) -< 27.0 > - :echo pow(2, 16) -< 65536.0 > - :echo pow(32, 0.20) -< 2.0 - {only available when compiled with the |+float| feature} - -prevnonblank({lnum}) *prevnonblank()* - Return the line number of the first line at or above {lnum} - that is not blank. Example: > - let ind = indent(prevnonblank(v:lnum - 1)) -< When {lnum} is invalid or there is no non-blank line at or - above it, zero is returned. - Also see |nextnonblank()|. - - -printf({fmt}, {expr1} ...) *printf()* - Return a String with {fmt}, where "%" items are replaced by - the formatted form of their respective arguments. Example: > - printf("%4d: E%d %.30s", lnum, errno, msg) -< May result in: - " 99: E42 asdfasdfasdfasdfasdfasdfasdfas" ~ - - Often used items are: - %s string - %6s string right-aligned in 6 bytes - %.9s string truncated to 9 bytes - %c single byte - %d decimal number - %5d decimal number padded with spaces to 5 characters - %x hex number - %04x hex number padded with zeros to at least 4 characters - %X hex number using upper case letters - %o octal number - %f floating point number in the form 123.456 - %e floating point number in the form 1.234e3 - %E floating point number in the form 1.234E3 - %g floating point number, as %f or %e depending on value - %G floating point number, as %f or %E depending on value - %% the % character itself - - Conversion specifications start with '%' and end with the - conversion type. All other characters are copied unchanged to - the result. - - The "%" starts a conversion specification. The following - arguments appear in sequence: - - % [flags] [field-width] [.precision] type - - flags - Zero or more of the following flags: - - # The value should be converted to an "alternate - form". For c, d, and s conversions, this option - has no effect. For o conversions, the precision - of the number is increased to force the first - character of the output string to a zero (except - if a zero value is printed with an explicit - precision of zero). - For x and X conversions, a non-zero result has - the string "0x" (or "0X" for X conversions) - prepended to it. - - 0 (zero) Zero padding. For all conversions the converted - value is padded on the left with zeros rather - than blanks. If a precision is given with a - numeric conversion (d, o, x, and X), the 0 flag - is ignored. - - - A negative field width flag; the converted value - is to be left adjusted on the field boundary. - The converted value is padded on the right with - blanks, rather than on the left with blanks or - zeros. A - overrides a 0 if both are given. - - ' ' (space) A blank should be left before a positive - number produced by a signed conversion (d). - - + A sign must always be placed before a number - produced by a signed conversion. A + overrides - a space if both are used. - - field-width - An optional decimal digit string specifying a minimum - field width. If the converted value has fewer bytes - than the field width, it will be padded with spaces on - the left (or right, if the left-adjustment flag has - been given) to fill out the field width. - - .precision - An optional precision, in the form of a period '.' - followed by an optional digit string. If the digit - string is omitted, the precision is taken as zero. - This gives the minimum number of digits to appear for - d, o, x, and X conversions, or the maximum number of - bytes to be printed from a string for s conversions. - For floating point it is the number of digits after - the decimal point. - - type - A character that specifies the type of conversion to - be applied, see below. - - A field width or precision, or both, may be indicated by an - asterisk '*' instead of a digit string. In this case, a - Number argument supplies the field width or precision. A - negative field width is treated as a left adjustment flag - followed by a positive field width; a negative precision is - treated as though it were missing. Example: > - :echo printf("%d: %.*s", nr, width, line) -< This limits the length of the text used from "line" to - "width" bytes. - - The conversion specifiers and their meanings are: - - *printf-d* *printf-o* *printf-x* *printf-X* - doxX The Number argument is converted to signed decimal - (d), unsigned octal (o), or unsigned hexadecimal (x - and X) notation. The letters "abcdef" are used for - x conversions; the letters "ABCDEF" are used for X - conversions. - The precision, if any, gives the minimum number of - digits that must appear; if the converted value - requires fewer digits, it is padded on the left with - zeros. - In no case does a non-existent or small field width - cause truncation of a numeric field; if the result of - a conversion is wider than the field width, the field - is expanded to contain the conversion result. - - *printf-c* - c The Number argument is converted to a byte, and the - resulting character is written. - - *printf-s* - s The text of the String argument is used. If a - precision is specified, no more bytes than the number - specified are used. - - *printf-f* *E807* - f The Float argument is converted into a string of the - form 123.456. The precision specifies the number of - digits after the decimal point. When the precision is - zero the decimal point is omitted. When the precision - is not specified 6 is used. A really big number - (out of range or dividing by zero) results in "inf". - "0.0 / 0.0" results in "nan". - Example: > - echo printf("%.2f", 12.115) -< 12.12 - Note that roundoff depends on the system libraries. - Use |round()| when in doubt. - - *printf-e* *printf-E* - e E The Float argument is converted into a string of the - form 1.234e+03 or 1.234E+03 when using 'E'. The - precision specifies the number of digits after the - decimal point, like with 'f'. - - *printf-g* *printf-G* - g G The Float argument is converted like with 'f' if the - value is between 0.001 (inclusive) and 10000000.0 - (exclusive). Otherwise 'e' is used for 'g' and 'E' - for 'G'. When no precision is specified superfluous - zeroes and '+' signs are removed, except for the zero - immediately after the decimal point. Thus 10000000.0 - results in 1.0e7. - - *printf-%* - % A '%' is written. No argument is converted. The - complete conversion specification is "%%". - - When a Number argument is expected a String argument is also - accepted and automatically converted. - When a Float or String argument is expected a Number argument - is also accepted and automatically converted. - Any other argument type results in an error message. - - *E766* *E767* - The number of {exprN} arguments must exactly match the number - of "%" items. If there are not sufficient or too many - arguments an error is given. Up to 18 arguments can be used. - - -pumvisible() *pumvisible()* - Returns non-zero when the popup menu is visible, zero - otherwise. See |ins-completion-menu|. - This can be used to avoid some things that would remove the - popup menu. - - *E726* *E727* -range({expr} [, {max} [, {stride}]]) *range()* - Returns a |List| with Numbers: - - If only {expr} is specified: [0, 1, ..., {expr} - 1] - - If {max} is specified: [{expr}, {expr} + 1, ..., {max}] - - If {stride} is specified: [{expr}, {expr} + {stride}, ..., - {max}] (increasing {expr} with {stride} each time, not - producing a value past {max}). - When the maximum is one before the start the result is an - empty list. When the maximum is more than one before the - start this is an error. - Examples: > - range(4) " [0, 1, 2, 3] - range(2, 4) " [2, 3, 4] - range(2, 9, 3) " [2, 5, 8] - range(2, -2, -1) " [2, 1, 0, -1, -2] - range(0) " [] - range(2, 0) " error! -< - *readfile()* -readfile({fname} [, {binary} [, {max}]]) - Read file {fname} and return a |List|, each line of the file - as an item. Lines broken at NL characters. Macintosh files - separated with CR will result in a single long line (unless a - NL appears somewhere). - When {binary} is equal to "b" binary mode is used: - - When the last line ends in a NL an extra empty list item is - added. - - No CR characters are removed. - Otherwise: - - CR characters that appear before a NL are removed. - - Whether the last line ends in a NL or not does not matter. - All NUL characters are replaced with a NL character. - When {max} is given this specifies the maximum number of lines - to be read. Useful if you only want to check the first ten - lines of a file: > - :for line in readfile(fname, '', 10) - : if line =~ 'Date' | echo line | endif - :endfor -< When {max} is negative -{max} lines from the end of the file - are returned, or as many as there are. - When {max} is zero the result is an empty list. - Note that without {max} the whole file is read into memory. - Also note that there is no recognition of encoding. Read a - file into a buffer if you need to. - When the file can't be opened an error message is given and - the result is an empty list. - Also see |writefile()|. - -reltime([{start} [, {end}]]) *reltime()* - Return an item that represents a time value. The format of - the item depends on the system. It can be passed to - |reltimestr()| to convert it to a string. - Without an argument it returns the current time. - With one argument is returns the time passed since the time - specified in the argument. - With two arguments it returns the time passed between {start} - and {end}. - The {start} and {end} arguments must be values returned by - reltime(). - {only available when compiled with the +reltime feature} - -reltimestr({time}) *reltimestr()* - Return a String that represents the time value of {time}. - This is the number of seconds, a dot and the number of - microseconds. Example: > - let start = reltime() - call MyFunction() - echo reltimestr(reltime(start)) -< Note that overhead for the commands will be added to the time. - The accuracy depends on the system. - Leading spaces are used to make the string align nicely. You - can use split() to remove it. > - echo split(reltimestr(reltime(start)))[0] -< Also see |profiling|. - {only available when compiled with the +reltime feature} - - *remote_expr()* *E449* -remote_expr({server}, {string} [, {idvar}]) - Send the {string} to {server}. The string is sent as an - expression and the result is returned after evaluation. - The result must be a String or a |List|. A |List| is turned - into a String by joining the items with a line break in - between (not at the end), like with join(expr, "\n"). - If {idvar} is present, it is taken as the name of a - variable and a {serverid} for later use with - remote_read() is stored there. - See also |clientserver| |RemoteReply|. - This function is not available in the |sandbox|. - {only available when compiled with the |+clientserver| feature} - Note: Any errors will cause a local error message to be issued - and the result will be the empty string. - Examples: > - :echo remote_expr("gvim", "2+2") - :echo remote_expr("gvim1", "b:current_syntax") -< - -remote_foreground({server}) *remote_foreground()* - Move the Vim server with the name {server} to the foreground. - This works like: > - remote_expr({server}, "foreground()") -< Except that on Win32 systems the client does the work, to work - around the problem that the OS doesn't always allow the server - to bring itself to the foreground. - Note: This does not restore the window if it was minimized, - like foreground() does. - This function is not available in the |sandbox|. - {only in the Win32, Athena, Motif and GTK GUI versions and the - Win32 console version} - - -remote_peek({serverid} [, {retvar}]) *remote_peek()* - Returns a positive number if there are available strings - from {serverid}. Copies any reply string into the variable - {retvar} if specified. {retvar} must be a string with the - name of a variable. - Returns zero if none are available. - Returns -1 if something is wrong. - See also |clientserver|. - This function is not available in the |sandbox|. - {only available when compiled with the |+clientserver| feature} - Examples: > - :let repl = "" - :echo "PEEK: ".remote_peek(id, "repl").": ".repl - -remote_read({serverid}) *remote_read()* - Return the oldest available reply from {serverid} and consume - it. It blocks until a reply is available. - See also |clientserver|. - This function is not available in the |sandbox|. - {only available when compiled with the |+clientserver| feature} - Example: > - :echo remote_read(id) -< - *remote_send()* *E241* -remote_send({server}, {string} [, {idvar}]) - Send the {string} to {server}. The string is sent as input - keys and the function returns immediately. At the Vim server - the keys are not mapped |:map|. - If {idvar} is present, it is taken as the name of a variable - and a {serverid} for later use with remote_read() is stored - there. - See also |clientserver| |RemoteReply|. - This function is not available in the |sandbox|. - {only available when compiled with the |+clientserver| feature} - Note: Any errors will be reported in the server and may mess - up the display. - Examples: > - :echo remote_send("gvim", ":DropAndReply ".file, "serverid"). - \ remote_read(serverid) - - :autocmd NONE RemoteReply * - \ echo remote_read(expand("")) - :echo remote_send("gvim", ":sleep 10 | echo ". - \ 'server2client(expand(""), "HELLO")') -< -remove({list}, {idx} [, {end}]) *remove()* - Without {end}: Remove the item at {idx} from |List| {list} and - return it. - With {end}: Remove items from {idx} to {end} (inclusive) and - return a list with these items. When {idx} points to the same - item as {end} a list with one item is returned. When {end} - points to an item before {idx} this is an error. - See |list-index| for possible values of {idx} and {end}. - Example: > - :echo "last item: " . remove(mylist, -1) - :call remove(mylist, 0, 9) -remove({dict}, {key}) - Remove the entry from {dict} with key {key}. Example: > - :echo "removed " . remove(dict, "one") -< If there is no {key} in {dict} this is an error. - - Use |delete()| to remove a file. - -rename({from}, {to}) *rename()* - Rename the file by the name {from} to the name {to}. This - should also work to move files across file systems. The - result is a Number, which is 0 if the file was renamed - successfully, and non-zero when the renaming failed. - This function is not available in the |sandbox|. - -repeat({expr}, {count}) *repeat()* - Repeat {expr} {count} times and return the concatenated - result. Example: > - :let separator = repeat('-', 80) -< When {count} is zero or negative the result is empty. - When {expr} is a |List| the result is {expr} concatenated - {count} times. Example: > - :let longlist = repeat(['a', 'b'], 3) -< Results in ['a', 'b', 'a', 'b', 'a', 'b']. - - -resolve({filename}) *resolve()* *E655* - On MS-Windows, when {filename} is a shortcut (a .lnk file), - returns the path the shortcut points to in a simplified form. - On Unix, repeat resolving symbolic links in all path - components of {filename} and return the simplified result. - To cope with link cycles, resolving of symbolic links is - stopped after 100 iterations. - On other systems, return the simplified {filename}. - The simplification step is done as by |simplify()|. - resolve() keeps a leading path component specifying the - current directory (provided the result is still a relative - path name) and also keeps a trailing path separator. - - *reverse()* -reverse({list}) Reverse the order of items in {list} in-place. Returns - {list}. - If you want a list to remain unmodified make a copy first: > - :let revlist = reverse(copy(mylist)) - -round({expr}) *round()* - Round off {expr} to the nearest integral value and return it - as a |Float|. If {expr} lies halfway between two integral - values, then use the larger one (away from zero). - {expr} must evaluate to a |Float| or a |Number|. - Examples: > - echo round(0.456) -< 0.0 > - echo round(4.5) -< 5.0 > - echo round(-4.5) -< -5.0 - {only available when compiled with the |+float| feature} - - -search({pattern} [, {flags} [, {stopline} [, {timeout}]]]) *search()* - Search for regexp pattern {pattern}. The search starts at the - cursor position (you can use |cursor()| to set it). - - {flags} is a String, which can contain these character flags: - 'b' search backward instead of forward - 'c' accept a match at the cursor position - 'e' move to the End of the match - 'n' do Not move the cursor - 'p' return number of matching sub-pattern (see below) - 's' set the ' mark at the previous location of the cursor - 'w' wrap around the end of the file - 'W' don't wrap around the end of the file - If neither 'w' or 'W' is given, the 'wrapscan' option applies. - - If the 's' flag is supplied, the ' mark is set, only if the - cursor is moved. The 's' flag cannot be combined with the 'n' - flag. - - 'ignorecase', 'smartcase' and 'magic' are used. - - When the {stopline} argument is given then the search stops - after searching this line. This is useful to restrict the - search to a range of lines. Examples: > - let match = search('(', 'b', line("w0")) - let end = search('END', '', line("w$")) -< When {stopline} is used and it is not zero this also implies - that the search does not wrap around the end of the file. - A zero value is equal to not giving the argument. - - When the {timeout} argument is given the search stops when - more than this many milli seconds have passed. Thus when - {timeout} is 500 the search stops after half a second. - The value must not be negative. A zero value is like not - giving the argument. - {only available when compiled with the +reltime feature} - - If there is no match a 0 is returned and the cursor doesn't - move. No error message is given. - When a match has been found its line number is returned. - *search()-sub-match* - With the 'p' flag the returned value is one more than the - first sub-match in \(\). One if none of them matched but the - whole pattern did match. - To get the column number too use |searchpos()|. - - The cursor will be positioned at the match, unless the 'n' - flag is used. - - Example (goes over all files in the argument list): > - :let n = 1 - :while n <= argc() " loop over all files in arglist - : exe "argument " . n - : " start at the last char in the file and wrap for the - : " first search to find match at start of file - : normal G$ - : let flags = "w" - : while search("foo", flags) > 0 - : s/foo/bar/g - : let flags = "W" - : endwhile - : update " write the file if modified - : let n = n + 1 - :endwhile -< - Example for using some flags: > - :echo search('\ - if searchdecl('myvar') == 0 - echo getline('.') - endif -< - *searchpair()* -searchpair({start}, {middle}, {end} [, {flags} [, {skip} - [, {stopline} [, {timeout}]]]]) - Search for the match of a nested start-end pair. This can be - used to find the "endif" that matches an "if", while other - if/endif pairs in between are ignored. - The search starts at the cursor. The default is to search - forward, include 'b' in {flags} to search backward. - If a match is found, the cursor is positioned at it and the - line number is returned. If no match is found 0 or -1 is - returned and the cursor doesn't move. No error message is - given. - - {start}, {middle} and {end} are patterns, see |pattern|. They - must not contain \( \) pairs. Use of \%( \) is allowed. When - {middle} is not empty, it is found when searching from either - direction, but only when not in a nested start-end pair. A - typical use is: > - searchpair('\', '\', '\') -< By leaving {middle} empty the "else" is skipped. - - {flags} 'b', 'c', 'n', 's', 'w' and 'W' are used like with - |search()|. Additionally: - 'r' Repeat until no more matches found; will find the - outer pair. Implies the 'W' flag. - 'm' Return number of matches instead of line number with - the match; will be > 1 when 'r' is used. - Note: it's nearly always a good idea to use the 'W' flag, to - avoid wrapping around the end of the file. - - When a match for {start}, {middle} or {end} is found, the - {skip} expression is evaluated with the cursor positioned on - the start of the match. It should return non-zero if this - match is to be skipped. E.g., because it is inside a comment - or a string. - When {skip} is omitted or empty, every match is accepted. - When evaluating {skip} causes an error the search is aborted - and -1 returned. - - For {stopline} and {timeout} see |search()|. - - The value of 'ignorecase' is used. 'magic' is ignored, the - patterns are used like it's on. - - The search starts exactly at the cursor. A match with - {start}, {middle} or {end} at the next character, in the - direction of searching, is the first one found. Example: > - if 1 - if 2 - endif 2 - endif 1 -< When starting at the "if 2", with the cursor on the "i", and - searching forwards, the "endif 2" is found. When starting on - the character just before the "if 2", the "endif 1" will be - found. That's because the "if 2" will be found first, and - then this is considered to be a nested if/endif from "if 2" to - "endif 2". - When searching backwards and {end} is more than one character, - it may be useful to put "\zs" at the end of the pattern, so - that when the cursor is inside a match with the end it finds - the matching start. - - Example, to find the "endif" command in a Vim script: > - - :echo searchpair('\', '\', '\', 'W', - \ 'getline(".") =~ "^\\s*\""') - -< The cursor must be at or after the "if" for which a match is - to be found. Note that single-quote strings are used to avoid - having to double the backslashes. The skip expression only - catches comments at the start of a line, not after a command. - Also, a word "en" or "if" halfway a line is considered a - match. - Another example, to search for the matching "{" of a "}": > - - :echo searchpair('{', '', '}', 'bW') - -< This works when the cursor is at or before the "}" for which a - match is to be found. To reject matches that syntax - highlighting recognized as strings: > - - :echo searchpair('{', '', '}', 'bW', - \ 'synIDattr(synID(line("."), col("."), 0), "name") =~? "string"') -< - *searchpairpos()* -searchpairpos({start}, {middle}, {end} [, {flags} [, {skip} - [, {stopline} [, {timeout}]]]]) - Same as searchpair(), but returns a |List| with the line and - column position of the match. The first element of the |List| - is the line number and the second element is the byte index of - the column position of the match. If no match is found, - returns [0, 0]. -> - :let [lnum,col] = searchpairpos('{', '', '}', 'n') -< - See |match-parens| for a bigger and more useful example. - -searchpos({pattern} [, {flags} [, {stopline} [, {timeout}]]]) *searchpos()* - Same as |search()|, but returns a |List| with the line and - column position of the match. The first element of the |List| - is the line number and the second element is the byte index of - the column position of the match. If no match is found, - returns [0, 0]. - Example: > - :let [lnum, col] = searchpos('mypattern', 'n') - -< When the 'p' flag is given then there is an extra item with - the sub-pattern match number |search()-sub-match|. Example: > - :let [lnum, col, submatch] = searchpos('\(\l\)\|\(\u\)', 'np') -< In this example "submatch" is 2 when a lowercase letter is - found |/\l|, 3 when an uppercase letter is found |/\u|. - -server2client( {clientid}, {string}) *server2client()* - Send a reply string to {clientid}. The most recent {clientid} - that sent a string can be retrieved with expand(""). - {only available when compiled with the |+clientserver| feature} - Note: - This id has to be stored before the next command can be - received. I.e. before returning from the received command and - before calling any commands that waits for input. - See also |clientserver|. - Example: > - :echo server2client(expand(""), "HELLO") -< -serverlist() *serverlist()* - Return a list of available server names, one per line. - When there are no servers or the information is not available - an empty string is returned. See also |clientserver|. - {only available when compiled with the |+clientserver| feature} - Example: > - :echo serverlist() -< -setbufvar({expr}, {varname}, {val}) *setbufvar()* - Set option or local variable {varname} in buffer {expr} to - {val}. - This also works for a global or local window option, but it - doesn't work for a global or local window variable. - For a local window option the global value is unchanged. - For the use of {expr}, see |bufname()| above. - Note that the variable name without "b:" must be used. - Examples: > - :call setbufvar(1, "&mod", 1) - :call setbufvar("todo", "myvar", "foobar") -< This function is not available in the |sandbox|. - -setcmdpos({pos}) *setcmdpos()* - Set the cursor position in the command line to byte position - {pos}. The first position is 1. - Use |getcmdpos()| to obtain the current position. - Only works while editing the command line, thus you must use - |c_CTRL-\_e|, |c_CTRL-R_=| or |c_CTRL-R_CTRL-R| with '='. For - |c_CTRL-\_e| and |c_CTRL-R_CTRL-R| with '=' the position is - set after the command line is set to the expression. For - |c_CTRL-R_=| it is set after evaluating the expression but - before inserting the resulting text. - When the number is too big the cursor is put at the end of the - line. A number smaller than one has undefined results. - Returns 0 when successful, 1 when not editing the command - line. - -setline({lnum}, {text}) *setline()* - Set line {lnum} of the current buffer to {text}. - {lnum} is used like with |getline()|. - When {lnum} is just below the last line the {text} will be - added as a new line. - If this succeeds, 0 is returned. If this fails (most likely - because {lnum} is invalid) 1 is returned. Example: > - :call setline(5, strftime("%c")) -< When {text} is a |List| then line {lnum} and following lines - will be set to the items in the list. Example: > - :call setline(5, ['aaa', 'bbb', 'ccc']) -< This is equivalent to: > - :for [n, l] in [[5, 6, 7], ['aaa', 'bbb', 'ccc']] - : call setline(n, l) - :endfor -< Note: The '[ and '] marks are not set. - -setloclist({nr}, {list} [, {action}]) *setloclist()* - Create or replace or add to the location list for window {nr}. - When {nr} is zero the current window is used. For a location - list window, the displayed location list is modified. For an - invalid window number {nr}, -1 is returned. - Otherwise, same as |setqflist()|. - Also see |location-list|. - -setmatches({list}) *setmatches()* - Restores a list of matches saved by |getmatches()|. Returns 0 - if successful, otherwise -1. All current matches are cleared - before the list is restored. See example for |getmatches()|. - - *setpos()* -setpos({expr}, {list}) - Set the position for {expr}. Possible values: - . the cursor - 'x mark x - - {list} must be a |List| with four numbers: - [bufnum, lnum, col, off] - - "bufnum" is the buffer number. Zero can be used for the - current buffer. Setting the cursor is only possible for - the current buffer. To set a mark in another buffer you can - use the |bufnr()| function to turn a file name into a buffer - number. - Does not change the jumplist. - - "lnum" and "col" are the position in the buffer. The first - column is 1. Use a zero "lnum" to delete a mark. - - The "off" number is only used when 'virtualedit' is set. Then - it is the offset in screen columns from the start of the - character. E.g., a position within a or after the last - character. - - Returns 0 when the position could be set, -1 otherwise. - An error message is given if {expr} is invalid. - - Also see |getpos()| - - This does not restore the preferred column for moving - vertically. See |winrestview()| for that. - - -setqflist({list} [, {action}]) *setqflist()* - Create or replace or add to the quickfix list using the items - in {list}. Each item in {list} is a dictionary. - Non-dictionary items in {list} are ignored. Each dictionary - item can contain the following entries: - - bufnr buffer number; must be the number of a valid - buffer - filename name of a file; only used when "bufnr" is not - present or it is invalid. - lnum line number in the file - pattern search pattern used to locate the error - col column number - vcol when non-zero: "col" is visual column - when zero: "col" is byte index - nr error number - text description of the error - type single-character error type, 'E', 'W', etc. - - The "col", "vcol", "nr", "type" and "text" entries are - optional. Either "lnum" or "pattern" entry can be used to - locate a matching error line. - If the "filename" and "bufnr" entries are not present or - neither the "lnum" or "pattern" entries are present, then the - item will not be handled as an error line. - If both "pattern" and "lnum" are present then "pattern" will - be used. - Note that the list is not exactly the same as what - |getqflist()| returns. - - If {action} is set to 'a', then the items from {list} are - added to the existing quickfix list. If there is no existing - list, then a new list is created. If {action} is set to 'r', - then the items from the current quickfix list are replaced - with the items from {list}. If {action} is not present or is - set to ' ', then a new list is created. - - Returns zero for success, -1 for failure. - - This function can be used to create a quickfix list - independent of the 'errorformat' setting. Use a command like - ":cc 1" to jump to the first position. - - - *setreg()* -setreg({regname}, {value} [,{options}]) - Set the register {regname} to {value}. - If {options} contains "a" or {regname} is upper case, - then the value is appended. - {options} can also contains a register type specification: - "c" or "v" |characterwise| mode - "l" or "V" |linewise| mode - "b" or "" |blockwise-visual| mode - If a number immediately follows "b" or "" then this is - used as the width of the selection - if it is not specified - then the width of the block is set to the number of characters - in the longest line (counting a as 1 character). - - If {options} contains no register settings, then the default - is to use character mode unless {value} ends in a . - Setting the '=' register is not possible. - Returns zero for success, non-zero for failure. - - Examples: > - :call setreg(v:register, @*) - :call setreg('*', @%, 'ac') - :call setreg('a', "1\n2\n3", 'b5') - -< This example shows using the functions to save and restore a - register. > - :let var_a = getreg('a', 1) - :let var_amode = getregtype('a') - .... - :call setreg('a', var_a, var_amode) - -< You can also change the type of a register by appending - nothing: > - :call setreg('a', '', 'al') - -settabwinvar({tabnr}, {winnr}, {varname}, {val}) *settabwinvar()* - Set option or local variable {varname} in window {winnr} to - {val}. - Tabs are numbered starting with one. For the current tabpage - use |setwinvar()|. - When {winnr} is zero the current window is used. - This also works for a global or local buffer option, but it - doesn't work for a global or local buffer variable. - For a local buffer option the global value is unchanged. - Note that the variable name without "w:" must be used. - Vim briefly goes to the tab page {tabnr}, this may trigger - TabLeave and TabEnter autocommands. - Examples: > - :call settabwinvar(1, 1, "&list", 0) - :call settabwinvar(3, 2, "myvar", "foobar") -< This function is not available in the |sandbox|. - -setwinvar({nr}, {varname}, {val}) *setwinvar()* - Like |settabwinvar()| for the current tab page. - Examples: > - :call setwinvar(1, "&list", 0) - :call setwinvar(2, "myvar", "foobar") - -shellescape({string} [, {special}]) *shellescape()* - Escape {string} for use as shell command argument. - On MS-Windows and MS-DOS, when 'shellslash' is not set, it - will enclose {string} in double quotes and double all double - quotes within {string}. - For other systems, it will enclose {string} in single quotes - and replace all "'" with "'\''". - When the {special} argument is present and it's a non-zero - Number or a non-empty String (|non-zero-arg|), then special - items such as "!", "%", "#" and "" will be preceded by - a backslash. This backslash will be removed again by the |:!| - command. - The "!" character will be escaped (again with a |non-zero-arg| - {special}) when 'shell' contains "csh" in the tail. That is - because for csh and tcsh "!" is used for history replacement - even when inside single quotes. - The character is also escaped. With a |non-zero-arg| - {special} and 'shell' containing "csh" in the tail it's - escaped a second time. - Example of use with a |:!| command: > - :exe '!dir ' . shellescape(expand(''), 1) -< This results in a directory listing for the file under the - cursor. Example of use with |system()|: > - :call system("chmod +w -- " . shellescape(expand("%"))) - - -simplify({filename}) *simplify()* - Simplify the file name as much as possible without changing - the meaning. Shortcuts (on MS-Windows) or symbolic links (on - Unix) are not resolved. If the first path component in - {filename} designates the current directory, this will be - valid for the result as well. A trailing path separator is - not removed either. - Example: > - simplify("./dir/.././/file/") == "./file/" -< Note: The combination "dir/.." is only removed if "dir" is - a searchable directory or does not exist. On Unix, it is also - removed when "dir" is a symbolic link within the same - directory. In order to resolve all the involved symbolic - links before simplifying the path name, use |resolve()|. - - -sin({expr}) *sin()* - Return the sine of {expr}, measured in radians, as a |Float|. - {expr} must evaluate to a |Float| or a |Number|. - Examples: > - :echo sin(100) -< -0.506366 > - :echo sin(-4.01) -< 0.763301 - {only available when compiled with the |+float| feature} - - -sort({list} [, {func}]) *sort()* *E702* - Sort the items in {list} in-place. Returns {list}. If you - want a list to remain unmodified make a copy first: > - :let sortedlist = sort(copy(mylist)) -< Uses the string representation of each item to sort on. - Numbers sort after Strings, |Lists| after Numbers. - For sorting text in the current buffer use |:sort|. - When {func} is given and it is one then case is ignored. - When {func} is a |Funcref| or a function name, this function - is called to compare items. The function is invoked with two - items as argument and must return zero if they are equal, 1 if - the first one sorts after the second one, -1 if the first one - sorts before the second one. Example: > - func MyCompare(i1, i2) - return a:i1 == a:i2 ? 0 : a:i1 > a:i2 ? 1 : -1 - endfunc - let sortedlist = sort(mylist, "MyCompare") -< - - *soundfold()* -soundfold({word}) - Return the sound-folded equivalent of {word}. Uses the first - language in 'spelllang' for the current window that supports - soundfolding. 'spell' must be set. When no sound folding is - possible the {word} is returned unmodified. - This can be used for making spelling suggestions. Note that - the method can be quite slow. - - *spellbadword()* -spellbadword([{sentence}]) - Without argument: The result is the badly spelled word under - or after the cursor. The cursor is moved to the start of the - bad word. When no bad word is found in the cursor line the - result is an empty string and the cursor doesn't move. - - With argument: The result is the first word in {sentence} that - is badly spelled. If there are no spelling mistakes the - result is an empty string. - - The return value is a list with two items: - - The badly spelled word or an empty string. - - The type of the spelling error: - "bad" spelling mistake - "rare" rare word - "local" word only valid in another region - "caps" word should start with Capital - Example: > - echo spellbadword("the quik brown fox") -< ['quik', 'bad'] ~ - - The spelling information for the current window is used. The - 'spell' option must be set and the value of 'spelllang' is - used. - - *spellsuggest()* -spellsuggest({word} [, {max} [, {capital}]]) - Return a |List| with spelling suggestions to replace {word}. - When {max} is given up to this number of suggestions are - returned. Otherwise up to 25 suggestions are returned. - - When the {capital} argument is given and it's non-zero only - suggestions with a leading capital will be given. Use this - after a match with 'spellcapcheck'. - - {word} can be a badly spelled word followed by other text. - This allows for joining two words that were split. The - suggestions also include the following text, thus you can - replace a line. - - {word} may also be a good word. Similar words will then be - returned. {word} itself is not included in the suggestions, - although it may appear capitalized. - - The spelling information for the current window is used. The - 'spell' option must be set and the values of 'spelllang' and - 'spellsuggest' are used. - - -split({expr} [, {pattern} [, {keepempty}]]) *split()* - Make a |List| out of {expr}. When {pattern} is omitted or - empty each white-separated sequence of characters becomes an - item. - Otherwise the string is split where {pattern} matches, - removing the matched characters. - When the first or last item is empty it is omitted, unless the - {keepempty} argument is given and it's non-zero. - Other empty items are kept when {pattern} matches at least one - character or when {keepempty} is non-zero. - Example: > - :let words = split(getline('.'), '\W\+') -< To split a string in individual characters: > - :for c in split(mystring, '\zs') -< If you want to keep the separator you can also use '\zs': > - :echo split('abc:def:ghi', ':\zs') -< ['abc:', 'def:', 'ghi'] ~ - Splitting a table where the first element can be empty: > - :let items = split(line, ':', 1) -< The opposite function is |join()|. - - -sqrt({expr}) *sqrt()* - Return the non-negative square root of Float {expr} as a - |Float|. - {expr} must evaluate to a |Float| or a |Number|. When {expr} - is negative the result is NaN (Not a Number). - Examples: > - :echo sqrt(100) -< 10.0 > - :echo sqrt(-4.01) -< nan - "nan" may be different, it depends on system libraries. - {only available when compiled with the |+float| feature} - - -str2float( {expr}) *str2float()* - Convert String {expr} to a Float. This mostly works the same - as when using a floating point number in an expression, see - |floating-point-format|. But it's a bit more permissive. - E.g., "1e40" is accepted, while in an expression you need to - write "1.0e40". - Text after the number is silently ignored. - The decimal point is always '.', no matter what the locale is - set to. A comma ends the number: "12,345.67" is converted to - 12.0. You can strip out thousands separators with - |substitute()|: > - let f = str2float(substitute(text, ',', '', 'g')) -< {only available when compiled with the |+float| feature} - - -str2nr( {expr} [, {base}]) *str2nr()* - Convert string {expr} to a number. - {base} is the conversion base, it can be 8, 10 or 16. - When {base} is omitted base 10 is used. This also means that - a leading zero doesn't cause octal conversion to be used, as - with the default String to Number conversion. - When {base} is 16 a leading "0x" or "0X" is ignored. With a - different base the result will be zero. - Text after the number is silently ignored. - - -strftime({format} [, {time}]) *strftime()* - The result is a String, which is a formatted date and time, as - specified by the {format} string. The given {time} is used, - or the current time if no time is given. The accepted - {format} depends on your system, thus this is not portable! - See the manual page of the C function strftime() for the - format. The maximum length of the result is 80 characters. - See also |localtime()| and |getftime()|. - The language can be changed with the |:language| command. - Examples: > - :echo strftime("%c") Sun Apr 27 11:49:23 1997 - :echo strftime("%Y %b %d %X") 1997 Apr 27 11:53:25 - :echo strftime("%y%m%d %T") 970427 11:53:55 - :echo strftime("%H:%M") 11:55 - :echo strftime("%c", getftime("file.c")) - Show mod time of file.c. -< Not available on all systems. To check use: > - :if exists("*strftime") - -stridx({haystack}, {needle} [, {start}]) *stridx()* - The result is a Number, which gives the byte index in - {haystack} of the first occurrence of the String {needle}. - If {start} is specified, the search starts at index {start}. - This can be used to find a second match: > - :let comma1 = stridx(line, ",") - :let comma2 = stridx(line, ",", comma1 + 1) -< The search is done case-sensitive. - For pattern searches use |match()|. - -1 is returned if the {needle} does not occur in {haystack}. - See also |strridx()|. - Examples: > - :echo stridx("An Example", "Example") 3 - :echo stridx("Starting point", "Start") 0 - :echo stridx("Starting point", "start") -1 -< *strstr()* *strchr()* - stridx() works similar to the C function strstr(). When used - with a single character it works similar to strchr(). - - *string()* -string({expr}) Return {expr} converted to a String. If {expr} is a Number, - Float, String or a composition of them, then the result can be - parsed back with |eval()|. - {expr} type result ~ - String 'string' - Number 123 - Float 123.123456 or 1.123456e8 - Funcref function('name') - List [item, item] - Dictionary {key: value, key: value} - Note that in String values the ' character is doubled. - Also see |strtrans()|. - - *strlen()* -strlen({expr}) The result is a Number, which is the length of the String - {expr} in bytes. - If you want to count the number of multi-byte characters (not - counting composing characters) use something like this: > - - :let len = strlen(substitute(str, ".", "x", "g")) -< - If the argument is a Number it is first converted to a String. - For other types an error is given. - Also see |len()|. - -strpart({src}, {start}[, {len}]) *strpart()* - The result is a String, which is part of {src}, starting from - byte {start}, with the byte length {len}. - When non-existing bytes are included, this doesn't result in - an error, the bytes are simply omitted. - If {len} is missing, the copy continues from {start} till the - end of the {src}. > - strpart("abcdefg", 3, 2) == "de" - strpart("abcdefg", -2, 4) == "ab" - strpart("abcdefg", 5, 4) == "fg" - strpart("abcdefg", 3) == "defg" -< Note: To get the first character, {start} must be 0. For - example, to get three bytes under and after the cursor: > - strpart(getline("."), col(".") - 1, 3) -< -strridx({haystack}, {needle} [, {start}]) *strridx()* - The result is a Number, which gives the byte index in - {haystack} of the last occurrence of the String {needle}. - When {start} is specified, matches beyond this index are - ignored. This can be used to find a match before a previous - match: > - :let lastcomma = strridx(line, ",") - :let comma2 = strridx(line, ",", lastcomma - 1) -< The search is done case-sensitive. - For pattern searches use |match()|. - -1 is returned if the {needle} does not occur in {haystack}. - If the {needle} is empty the length of {haystack} is returned. - See also |stridx()|. Examples: > - :echo strridx("an angry armadillo", "an") 3 -< *strrchr()* - When used with a single character it works similar to the C - function strrchr(). - -strtrans({expr}) *strtrans()* - The result is a String, which is {expr} with all unprintable - characters translated into printable characters |'isprint'|. - Like they are shown in a window. Example: > - echo strtrans(@a) -< This displays a newline in register a as "^@" instead of - starting a new line. - -submatch({nr}) *submatch()* - Only for an expression in a |:substitute| command. Returns - the {nr}'th submatch of the matched text. When {nr} is 0 - the whole matched text is returned. - Example: > - :s/\d\+/\=submatch(0) + 1/ -< This finds the first number in the line and adds one to it. - A line break is included as a newline character. - -substitute({expr}, {pat}, {sub}, {flags}) *substitute()* - The result is a String, which is a copy of {expr}, in which - the first match of {pat} is replaced with {sub}. This works - like the ":substitute" command (without any flags). But the - matching with {pat} is always done like the 'magic' option is - set and 'cpoptions' is empty (to make scripts portable). - 'ignorecase' is still relevant. 'smartcase' is not used. - See |string-match| for how {pat} is used. - And a "~" in {sub} is not replaced with the previous {sub}. - Note that some codes in {sub} have a special meaning - |sub-replace-special|. For example, to replace something with - "\n" (two characters), use "\\\\n" or '\\n'. - When {pat} does not match in {expr}, {expr} is returned - unmodified. - When {flags} is "g", all matches of {pat} in {expr} are - replaced. Otherwise {flags} should be "". - Example: > - :let &path = substitute(&path, ",\\=[^,]*$", "", "") -< This removes the last component of the 'path' option. > - :echo substitute("testing", ".*", "\\U\\0", "") -< results in "TESTING". - -synID({lnum}, {col}, {trans}) *synID()* - The result is a Number, which is the syntax ID at the position - {lnum} and {col} in the current window. - The syntax ID can be used with |synIDattr()| and - |synIDtrans()| to obtain syntax information about text. - - {col} is 1 for the leftmost column, {lnum} is 1 for the first - line. 'synmaxcol' applies, in a longer line zero is returned. - - When {trans} is non-zero, transparent items are reduced to the - item that they reveal. This is useful when wanting to know - the effective color. When {trans} is zero, the transparent - item is returned. This is useful when wanting to know which - syntax item is effective (e.g. inside parens). - Warning: This function can be very slow. Best speed is - obtained by going through the file in forward direction. - - Example (echoes the name of the syntax item under the cursor): > - :echo synIDattr(synID(line("."), col("."), 1), "name") -< -synIDattr({synID}, {what} [, {mode}]) *synIDattr()* - The result is a String, which is the {what} attribute of - syntax ID {synID}. This can be used to obtain information - about a syntax item. - {mode} can be "gui", "cterm" or "term", to get the attributes - for that mode. When {mode} is omitted, or an invalid value is - used, the attributes for the currently active highlighting are - used (GUI, cterm or term). - Use synIDtrans() to follow linked highlight groups. - {what} result - "name" the name of the syntax item - "fg" foreground color (GUI: color name used to set - the color, cterm: color number as a string, - term: empty string) - "bg" background color (like "fg") - "fg#" like "fg", but for the GUI and the GUI is - running the name in "#RRGGBB" form - "bg#" like "fg#" for "bg" - "bold" "1" if bold - "italic" "1" if italic - "reverse" "1" if reverse - "inverse" "1" if inverse (= reverse) - "underline" "1" if underlined - "undercurl" "1" if undercurled - - Example (echoes the color of the syntax item under the - cursor): > - :echo synIDattr(synIDtrans(synID(line("."), col("."), 1)), "fg") -< -synIDtrans({synID}) *synIDtrans()* - The result is a Number, which is the translated syntax ID of - {synID}. This is the syntax group ID of what is being used to - highlight the character. Highlight links given with - ":highlight link" are followed. - -synstack({lnum}, {col}) *synstack()* - Return a |List|, which is the stack of syntax items at the - position {lnum} and {col} in the current window. Each item in - the List is an ID like what |synID()| returns. - The first item in the List is the outer region, following are - items contained in that one. The last one is what |synID()| - returns, unless not the whole item is highlighted or it is a - transparent item. - This function is useful for debugging a syntax file. - Example that shows the syntax stack under the cursor: > - for id in synstack(line("."), col(".")) - echo synIDattr(id, "name") - endfor - -system({expr} [, {input}]) *system()* *E677* - Get the output of the shell command {expr}. - When {input} is given, this string is written to a file and - passed as stdin to the command. The string is written as-is, - you need to take care of using the correct line separators - yourself. Pipes are not used. - Note: Use |shellescape()| to escape special characters in a - command argument. Newlines in {expr} may cause the command to - fail. The characters in 'shellquote' and 'shellxquote' may - also cause trouble. - This is not to be used for interactive commands. - - The result is a String. Example: > - :let files = system("ls " . shellescape(expand('%:h'))) - -< To make the result more system-independent, the shell output - is filtered to replace with for Macintosh, and - with for DOS-like systems. - The command executed is constructed using several options: - 'shell' 'shellcmdflag' 'shellxquote' {expr} 'shellredir' {tmp} 'shellxquote' - ({tmp} is an automatically generated file name). - For Unix and OS/2 braces are put around {expr} to allow for - concatenated commands. - - The command will be executed in "cooked" mode, so that a - CTRL-C will interrupt the command (on Unix at least). - - The resulting error code can be found in |v:shell_error|. - This function will fail in |restricted-mode|. - - Note that any wrong value in the options mentioned above may - make the function fail. It has also been reported to fail - when using a security agent application. - Unlike ":!cmd" there is no automatic check for changed files. - Use |:checktime| to force a check. - - -tabpagebuflist([{arg}]) *tabpagebuflist()* - The result is a |List|, where each item is the number of the - buffer associated with each window in the current tab page. - {arg} specifies the number of tab page to be used. When - omitted the current tab page is used. - When {arg} is invalid the number zero is returned. - To get a list of all buffers in all tabs use this: > - tablist = [] - for i in range(tabpagenr('$')) - call extend(tablist, tabpagebuflist(i + 1)) - endfor -< Note that a buffer may appear in more than one window. - - -tabpagenr([{arg}]) *tabpagenr()* - The result is a Number, which is the number of the current - tab page. The first tab page has number 1. - When the optional argument is "$", the number of the last tab - page is returned (the tab page count). - The number can be used with the |:tab| command. - - -tabpagewinnr({tabarg}, [{arg}]) *tabpagewinnr()* - Like |winnr()| but for tab page {arg}. - {tabarg} specifies the number of tab page to be used. - {arg} is used like with |winnr()|: - - When omitted the current window number is returned. This is - the window which will be used when going to this tab page. - - When "$" the number of windows is returned. - - When "#" the previous window nr is returned. - Useful examples: > - tabpagewinnr(1) " current window of tab page 1 - tabpagewinnr(4, '$') " number of windows in tab page 4 -< When {tabarg} is invalid zero is returned. - - *tagfiles()* -tagfiles() Returns a |List| with the file names used to search for tags - for the current buffer. This is the 'tags' option expanded. - - -taglist({expr}) *taglist()* - Returns a list of tags matching the regular expression {expr}. - Each list item is a dictionary with at least the following - entries: - name Name of the tag. - filename Name of the file where the tag is - defined. It is either relative to the - current directory or a full path. - cmd Ex command used to locate the tag in - the file. - kind Type of the tag. The value for this - entry depends on the language specific - kind values. Only available when - using a tags file generated by - Exuberant ctags or hdrtag. - static A file specific tag. Refer to - |static-tag| for more information. - More entries may be present, depending on the content of the - tags file: access, implementation, inherits and signature. - Refer to the ctags documentation for information about these - fields. For C code the fields "struct", "class" and "enum" - may appear, they give the name of the entity the tag is - contained in. - - The ex-command 'cmd' can be either an ex search pattern, a - line number or a line number followed by a byte number. - - If there are no matching tags, then an empty list is returned. - - To get an exact tag match, the anchors '^' and '$' should be - used in {expr}. Refer to |tag-regexp| for more information - about the tag search regular expression pattern. - - Refer to |'tags'| for information about how the tags file is - located by Vim. Refer to |tags-file-format| for the format of - the tags file generated by the different ctags tools. - -tempname() *tempname()* *temp-file-name* - The result is a String, which is the name of a file that - doesn't exist. It can be used for a temporary file. The name - is different for at least 26 consecutive calls. Example: > - :let tmpfile = tempname() - :exe "redir > " . tmpfile -< For Unix, the file will be in a private directory (only - accessible by the current user) to avoid security problems - (e.g., a symlink attack or other people reading your file). - When Vim exits the directory and all files in it are deleted. - For MS-Windows forward slashes are used when the 'shellslash' - option is set or when 'shellcmdflag' starts with '-'. - -tolower({expr}) *tolower()* - The result is a copy of the String given, with all uppercase - characters turned into lowercase (just like applying |gu| to - the string). - -toupper({expr}) *toupper()* - The result is a copy of the String given, with all lowercase - characters turned into uppercase (just like applying |gU| to - the string). - -tr({src}, {fromstr}, {tostr}) *tr()* - The result is a copy of the {src} string with all characters - which appear in {fromstr} replaced by the character in that - position in the {tostr} string. Thus the first character in - {fromstr} is translated into the first character in {tostr} - and so on. Exactly like the unix "tr" command. - This code also deals with multibyte characters properly. - - Examples: > - echo tr("hello there", "ht", "HT") -< returns "Hello THere" > - echo tr("", "<>", "{}") -< returns "{blob}" - -trunc({expr}) *trunc()* - Return the largest integral value with magnitude less than or - equal to {expr} as a |Float| (truncate towards zero). - {expr} must evaluate to a |Float| or a |Number|. - Examples: > - echo trunc(1.456) -< 1.0 > - echo trunc(-5.456) -< -5.0 > - echo trunc(4.0) -< 4.0 - {only available when compiled with the |+float| feature} - - *type()* -type({expr}) The result is a Number, depending on the type of {expr}: - Number: 0 - String: 1 - Funcref: 2 - List: 3 - Dictionary: 4 - Float: 5 - To avoid the magic numbers it should be used this way: > - :if type(myvar) == type(0) - :if type(myvar) == type("") - :if type(myvar) == type(function("tr")) - :if type(myvar) == type([]) - :if type(myvar) == type({}) - :if type(myvar) == type(0.0) - -values({dict}) *values()* - Return a |List| with all the values of {dict}. The |List| is - in arbitrary order. - - -virtcol({expr}) *virtcol()* - The result is a Number, which is the screen column of the file - position given with {expr}. That is, the last screen position - occupied by the character at that position, when the screen - would be of unlimited width. When there is a at the - position, the returned Number will be the column at the end of - the . For example, for a in column 1, with 'ts' - set to 8, it returns 8. - For the byte position use |col()|. - For the use of {expr} see |col()|. - When 'virtualedit' is used {expr} can be [lnum, col, off], where - "off" is the offset in screen columns from the start of the - character. E.g., a position within a or after the last - character. - When Virtual editing is active in the current mode, a position - beyond the end of the line can be returned. |'virtualedit'| - The accepted positions are: - . the cursor position - $ the end of the cursor line (the result is the - number of displayed characters in the cursor line - plus one) - 'x position of mark x (if the mark is not set, 0 is - returned) - Note that only marks in the current file can be used. - Examples: > - virtcol(".") with text "foo^Lbar", with cursor on the "^L", returns 5 - virtcol("$") with text "foo^Lbar", returns 9 - virtcol("'t") with text " there", with 't at 'h', returns 6 -< The first column is 1. 0 is returned for an error. - A more advanced example that echoes the maximum length of - all lines: > - echo max(map(range(1, line('$')), "virtcol([v:val, '$'])")) - - -visualmode([expr]) *visualmode()* - The result is a String, which describes the last Visual mode - used in the current buffer. Initially it returns an empty - string, but once Visual mode has been used, it returns "v", - "V", or "" (a single CTRL-V character) for - character-wise, line-wise, or block-wise Visual mode - respectively. - Example: > - :exe "normal " . visualmode() -< This enters the same Visual mode as before. It is also useful - in scripts if you wish to act differently depending on the - Visual mode that was used. - If Visual mode is active, use |mode()| to get the Visual mode - (e.g., in a |:vmap|). - *non-zero-arg* - If [expr] is supplied and it evaluates to a non-zero Number or - a non-empty String, then the Visual mode will be cleared and - the old value is returned. Note that " " and "0" are also - non-empty strings, thus cause the mode to be cleared. A List, - Dictionary or Float is not a Number or String, thus does not - cause the mode to be cleared. - - *winbufnr()* -winbufnr({nr}) The result is a Number, which is the number of the buffer - associated with window {nr}. When {nr} is zero, the number of - the buffer in the current window is returned. When window - {nr} doesn't exist, -1 is returned. - Example: > - :echo "The file in the current window is " . bufname(winbufnr(0)) -< - *wincol()* -wincol() The result is a Number, which is the virtual column of the - cursor in the window. This is counting screen cells from the - left side of the window. The leftmost column is one. - -winheight({nr}) *winheight()* - The result is a Number, which is the height of window {nr}. - When {nr} is zero, the height of the current window is - returned. When window {nr} doesn't exist, -1 is returned. - An existing window always has a height of zero or more. - Examples: > - :echo "The current window has " . winheight(0) . " lines." -< - *winline()* -winline() The result is a Number, which is the screen line of the cursor - in the window. This is counting screen lines from the top of - the window. The first line is one. - If the cursor was moved the view on the file will be updated - first, this may cause a scroll. - - *winnr()* -winnr([{arg}]) The result is a Number, which is the number of the current - window. The top window has number 1. - When the optional argument is "$", the number of the - last window is returned (the window count). - When the optional argument is "#", the number of the last - accessed window is returned (where |CTRL-W_p| goes to). - If there is no previous window or it is in another tab page 0 - is returned. - The number can be used with |CTRL-W_w| and ":wincmd w" - |:wincmd|. - Also see |tabpagewinnr()|. - - *winrestcmd()* -winrestcmd() Returns a sequence of |:resize| commands that should restore - the current window sizes. Only works properly when no windows - are opened or closed and the current window and tab page is - unchanged. - Example: > - :let cmd = winrestcmd() - :call MessWithWindowSizes() - :exe cmd -< - *winrestview()* -winrestview({dict}) - Uses the |Dictionary| returned by |winsaveview()| to restore - the view of the current window. - If you have changed the values the result is unpredictable. - If the window size changed the result won't be the same. - - *winsaveview()* -winsaveview() Returns a |Dictionary| that contains information to restore - the view of the current window. Use |winrestview()| to - restore the view. - This is useful if you have a mapping that jumps around in the - buffer and you want to go back to the original view. - This does not save fold information. Use the 'foldenable' - option to temporarily switch off folding, so that folds are - not opened when moving around. - The return value includes: - lnum cursor line number - col cursor column - coladd cursor column offset for 'virtualedit' - curswant column for vertical movement - topline first line in the window - topfill filler lines, only in diff mode - leftcol first column displayed - skipcol columns skipped - Note that no option values are saved. - - -winwidth({nr}) *winwidth()* - The result is a Number, which is the width of window {nr}. - When {nr} is zero, the width of the current window is - returned. When window {nr} doesn't exist, -1 is returned. - An existing window always has a width of zero or more. - Examples: > - :echo "The current window has " . winwidth(0) . " columns." - :if winwidth(0) <= 50 - : exe "normal 50\|" - :endif -< - *writefile()* -writefile({list}, {fname} [, {binary}]) - Write |List| {list} to file {fname}. Each list item is - separated with a NL. Each list item must be a String or - Number. - When {binary} is equal to "b" binary mode is used: There will - not be a NL after the last list item. An empty item at the - end does cause the last line in the file to end in a NL. - All NL characters are replaced with a NUL character. - Inserting CR characters needs to be done before passing {list} - to writefile(). - An existing file is overwritten, if possible. - When the write fails -1 is returned, otherwise 0. There is an - error message if the file can't be created or when writing - fails. - Also see |readfile()|. - To copy a file byte for byte: > - :let fl = readfile("foo", "b") - :call writefile(fl, "foocopy", "b") -< - - *feature-list* -There are three types of features: -1. Features that are only supported when they have been enabled when Vim - was compiled |+feature-list|. Example: > - :if has("cindent") -2. Features that are only supported when certain conditions have been met. - Example: > - :if has("gui_running") -< *has-patch* -3. Included patches. First check |v:version| for the version of Vim. - Then the "patch123" feature means that patch 123 has been included for - this version. Example (checking version 6.2.148 or later): > - :if v:version > 602 || v:version == 602 && has("patch148") -< Note that it's possible for patch 147 to be omitted even though 148 is - included. - -all_builtin_terms Compiled with all builtin terminals enabled. -amiga Amiga version of Vim. -arabic Compiled with Arabic support |Arabic|. -arp Compiled with ARP support (Amiga). -autocmd Compiled with autocommand support. |autocommand| -balloon_eval Compiled with |balloon-eval| support. -balloon_multiline GUI supports multiline balloons. -beos BeOS version of Vim. -browse Compiled with |:browse| support, and browse() will - work. -builtin_terms Compiled with some builtin terminals. -byte_offset Compiled with support for 'o' in 'statusline' -cindent Compiled with 'cindent' support. -clientserver Compiled with remote invocation support |clientserver|. -clipboard Compiled with 'clipboard' support. -cmdline_compl Compiled with |cmdline-completion| support. -cmdline_hist Compiled with |cmdline-history| support. -cmdline_info Compiled with 'showcmd' and 'ruler' support. -comments Compiled with |'comments'| support. -cryptv Compiled with encryption support |encryption|. -cscope Compiled with |cscope| support. -compatible Compiled to be very Vi compatible. -debug Compiled with "DEBUG" defined. -dialog_con Compiled with console dialog support. -dialog_gui Compiled with GUI dialog support. -diff Compiled with |vimdiff| and 'diff' support. -digraphs Compiled with support for digraphs. -dnd Compiled with support for the "~ register |quote_~|. -dos32 32 bits DOS (DJGPP) version of Vim. -dos16 16 bits DOS version of Vim. -ebcdic Compiled on a machine with ebcdic character set. -emacs_tags Compiled with support for Emacs tags. -eval Compiled with expression evaluation support. Always - true, of course! -ex_extra Compiled with extra Ex commands |+ex_extra|. -extra_search Compiled with support for |'incsearch'| and - |'hlsearch'| -farsi Compiled with Farsi support |farsi|. -file_in_path Compiled with support for |gf| and || -filterpipe When 'shelltemp' is off pipes are used for shell - read/write/filter commands -find_in_path Compiled with support for include file searches - |+find_in_path|. -float Compiled with support for |Float|. -fname_case Case in file names matters (for Amiga, MS-DOS, and - Windows this is not present). -folding Compiled with |folding| support. -footer Compiled with GUI footer support. |gui-footer| -fork Compiled to use fork()/exec() instead of system(). -gettext Compiled with message translation |multi-lang| -gui Compiled with GUI enabled. -gui_athena Compiled with Athena GUI. -gui_gtk Compiled with GTK+ GUI (any version). -gui_gtk2 Compiled with GTK+ 2 GUI (gui_gtk is also defined). -gui_gnome Compiled with Gnome support (gui_gtk is also defined). -gui_mac Compiled with Macintosh GUI. -gui_motif Compiled with Motif GUI. -gui_photon Compiled with Photon GUI. -gui_win32 Compiled with MS Windows Win32 GUI. -gui_win32s idem, and Win32s system being used (Windows 3.1) -gui_running Vim is running in the GUI, or it will start soon. -hangul_input Compiled with Hangul input support. |hangul| -iconv Can use iconv() for conversion. -insert_expand Compiled with support for CTRL-X expansion commands in - Insert mode. -jumplist Compiled with |jumplist| support. -keymap Compiled with 'keymap' support. -langmap Compiled with 'langmap' support. -libcall Compiled with |libcall()| support. -linebreak Compiled with 'linebreak', 'breakat' and 'showbreak' - support. -lispindent Compiled with support for lisp indenting. -listcmds Compiled with commands for the buffer list |:files| - and the argument list |arglist|. -localmap Compiled with local mappings and abbr. |:map-local| -mac Macintosh version of Vim. -macunix Macintosh version of Vim, using Unix files (OS-X). -menu Compiled with support for |:menu|. -mksession Compiled with support for |:mksession|. -modify_fname Compiled with file name modifiers. |filename-modifiers| -mouse Compiled with support mouse. -mouseshape Compiled with support for 'mouseshape'. -mouse_dec Compiled with support for Dec terminal mouse. -mouse_gpm Compiled with support for gpm (Linux console mouse) -mouse_netterm Compiled with support for netterm mouse. -mouse_pterm Compiled with support for qnx pterm mouse. -mouse_sysmouse Compiled with support for sysmouse (*BSD console mouse) -mouse_xterm Compiled with support for xterm mouse. -multi_byte Compiled with support for editing Korean et al. -multi_byte_ime Compiled with support for IME input method. -multi_lang Compiled with support for multiple languages. -mzscheme Compiled with MzScheme interface |mzscheme|. -netbeans_intg Compiled with support for |netbeans|. -netbeans_enabled Compiled with support for |netbeans| and it's used. -ole Compiled with OLE automation support for Win32. -os2 OS/2 version of Vim. -osfiletype Compiled with support for osfiletypes |+osfiletype| -path_extra Compiled with up/downwards search in 'path' and 'tags' -perl Compiled with Perl interface. -postscript Compiled with PostScript file printing. -printer Compiled with |:hardcopy| support. -profile Compiled with |:profile| support. -python Compiled with Python interface. -qnx QNX version of Vim. -quickfix Compiled with |quickfix| support. -reltime Compiled with |reltime()| support. -rightleft Compiled with 'rightleft' support. -ruby Compiled with Ruby interface |ruby|. -scrollbind Compiled with 'scrollbind' support. -showcmd Compiled with 'showcmd' support. -signs Compiled with |:sign| support. -smartindent Compiled with 'smartindent' support. -sniff Compiled with SNiFF interface support. -statusline Compiled with support for 'statusline', 'rulerformat' - and special formats of 'titlestring' and 'iconstring'. -sun_workshop Compiled with support for Sun |workshop|. -spell Compiled with spell checking support |spell|. -syntax Compiled with syntax highlighting support |syntax|. -syntax_items There are active syntax highlighting items for the - current buffer. -system Compiled to use system() instead of fork()/exec(). -tag_binary Compiled with binary searching in tags files - |tag-binary-search|. -tag_old_static Compiled with support for old static tags - |tag-old-static|. -tag_any_white Compiled with support for any white characters in tags - files |tag-any-white|. -tcl Compiled with Tcl interface. -terminfo Compiled with terminfo instead of termcap. -termresponse Compiled with support for |t_RV| and |v:termresponse|. -textobjects Compiled with support for |text-objects|. -tgetent Compiled with tgetent support, able to use a termcap - or terminfo file. -title Compiled with window title support |'title'|. -toolbar Compiled with support for |gui-toolbar|. -unix Unix version of Vim. -user_commands User-defined commands. -viminfo Compiled with viminfo support. -vim_starting True while initial source'ing takes place. -vertsplit Compiled with vertically split windows |:vsplit|. -virtualedit Compiled with 'virtualedit' option. -visual Compiled with Visual mode. -visualextra Compiled with extra Visual mode commands. - |blockwise-operators|. -vms VMS version of Vim. -vreplace Compiled with |gR| and |gr| commands. -wildignore Compiled with 'wildignore' option. -wildmenu Compiled with 'wildmenu' option. -windows Compiled with support for more than one window. -winaltkeys Compiled with 'winaltkeys' option. -win16 Win16 version of Vim (MS-Windows 3.1). -win32 Win32 version of Vim (MS-Windows 95/98/ME/NT/2000/XP). -win64 Win64 version of Vim (MS-Windows 64 bit). -win32unix Win32 version of Vim, using Unix files (Cygwin) -win95 Win32 version for MS-Windows 95/98/ME. -writebackup Compiled with 'writebackup' default on. -xfontset Compiled with X fontset support |xfontset|. -xim Compiled with X input method support |xim|. -xsmp Compiled with X session management support. -xsmp_interact Compiled with interactive X session management support. -xterm_clipboard Compiled with support for xterm clipboard. -xterm_save Compiled with support for saving and restoring the - xterm screen. -x11 Compiled with X11 support. - - *string-match* -Matching a pattern in a String - -A regexp pattern as explained at |pattern| is normally used to find a match in -the buffer lines. When a pattern is used to find a match in a String, almost -everything works in the same way. The difference is that a String is handled -like it is one line. When it contains a "\n" character, this is not seen as a -line break for the pattern. It can be matched with a "\n" in the pattern, or -with ".". Example: > - :let a = "aaaa\nxxxx" - :echo matchstr(a, "..\n..") - aa - xx - :echo matchstr(a, "a.x") - a - x - -Don't forget that "^" will only match at the first character of the String and -"$" at the last character of the string. They don't match after or before a -"\n". - -============================================================================== -5. Defining functions *user-functions* - -New functions can be defined. These can be called just like builtin -functions. The function executes a sequence of Ex commands. Normal mode -commands can be executed with the |:normal| command. - -The function name must start with an uppercase letter, to avoid confusion with -builtin functions. To prevent from using the same name in different scripts -avoid obvious, short names. A good habit is to start the function name with -the name of the script, e.g., "HTMLcolor()". - -It's also possible to use curly braces, see |curly-braces-names|. And the -|autoload| facility is useful to define a function only when it's called. - - *local-function* -A function local to a script must start with "s:". A local script function -can only be called from within the script and from functions, user commands -and autocommands defined in the script. It is also possible to call the -function from a mapping defined in the script, but then || must be used -instead of "s:" when the mapping is expanded outside of the script. - - *:fu* *:function* *E128* *E129* *E123* -:fu[nction] List all functions and their arguments. - -:fu[nction] {name} List function {name}. - {name} can also be a |Dictionary| entry that is a - |Funcref|: > - :function dict.init - -:fu[nction] /{pattern} List functions with a name matching {pattern}. - Example that lists all functions ending with "File": > - :function /File$ -< - *:function-verbose* -When 'verbose' is non-zero, listing a function will also display where it was -last defined. Example: > - - :verbose function SetFileTypeSH - function SetFileTypeSH(name) - Last set from /usr/share/vim/vim-7.0/filetype.vim -< -See |:verbose-cmd| for more information. - - *E124* *E125* -:fu[nction][!] {name}([arguments]) [range] [abort] [dict] - Define a new function by the name {name}. The name - must be made of alphanumeric characters and '_', and - must start with a capital or "s:" (see above). - - {name} can also be a |Dictionary| entry that is a - |Funcref|: > - :function dict.init(arg) -< "dict" must be an existing dictionary. The entry - "init" is added if it didn't exist yet. Otherwise [!] - is required to overwrite an existing function. The - result is a |Funcref| to a numbered function. The - function can only be used with a |Funcref| and will be - deleted if there are no more references to it. - *E127* *E122* - When a function by this name already exists and [!] is - not used an error message is given. When [!] is used, - an existing function is silently replaced. Unless it - is currently being executed, that is an error. - - For the {arguments} see |function-argument|. - - *a:firstline* *a:lastline* - When the [range] argument is added, the function is - expected to take care of a range itself. The range is - passed as "a:firstline" and "a:lastline". If [range] - is excluded, ":{range}call" will call the function for - each line in the range, with the cursor on the start - of each line. See |function-range-example|. - - When the [abort] argument is added, the function will - abort as soon as an error is detected. - - When the [dict] argument is added, the function must - be invoked through an entry in a |Dictionary|. The - local variable "self" will then be set to the - dictionary. See |Dictionary-function|. - - *function-search-undo* - The last used search pattern and the redo command "." - will not be changed by the function. This also - implies that the effect of |:nohlsearch| is undone - when the function returns. - - *:endf* *:endfunction* *E126* *E193* -:endf[unction] The end of a function definition. Must be on a line - by its own, without other commands. - - *:delf* *:delfunction* *E130* *E131* -:delf[unction] {name} Delete function {name}. - {name} can also be a |Dictionary| entry that is a - |Funcref|: > - :delfunc dict.init -< This will remove the "init" entry from "dict". The - function is deleted if there are no more references to - it. - *:retu* *:return* *E133* -:retu[rn] [expr] Return from a function. When "[expr]" is given, it is - evaluated and returned as the result of the function. - If "[expr]" is not given, the number 0 is returned. - When a function ends without an explicit ":return", - the number 0 is returned. - Note that there is no check for unreachable lines, - thus there is no warning if commands follow ":return". - - If the ":return" is used after a |:try| but before the - matching |:finally| (if present), the commands - following the ":finally" up to the matching |:endtry| - are executed first. This process applies to all - nested ":try"s inside the function. The function - returns at the outermost ":endtry". - - *function-argument* *a:var* -An argument can be defined by giving its name. In the function this can then -be used as "a:name" ("a:" for argument). - *a:0* *a:1* *a:000* *E740* *...* -Up to 20 arguments can be given, separated by commas. After the named -arguments an argument "..." can be specified, which means that more arguments -may optionally be following. In the function the extra arguments can be used -as "a:1", "a:2", etc. "a:0" is set to the number of extra arguments (which -can be 0). "a:000" is set to a |List| that contains these arguments. Note -that "a:1" is the same as "a:000[0]". - *E742* -The a: scope and the variables in it cannot be changed, they are fixed. -However, if a |List| or |Dictionary| is used, you can change their contents. -Thus you can pass a |List| to a function and have the function add an item to -it. If you want to make sure the function cannot change a |List| or -|Dictionary| use |:lockvar|. - -When not using "...", the number of arguments in a function call must be equal -to the number of named arguments. When using "...", the number of arguments -may be larger. - -It is also possible to define a function without any arguments. You must -still supply the () then. The body of the function follows in the next lines, -until the matching |:endfunction|. It is allowed to define another function -inside a function body. - - *local-variables* -Inside a function variables can be used. These are local variables, which -will disappear when the function returns. Global variables need to be -accessed with "g:". - -Example: > - :function Table(title, ...) - : echohl Title - : echo a:title - : echohl None - : echo a:0 . " items:" - : for s in a:000 - : echon ' ' . s - : endfor - :endfunction - -This function can then be called with: > - call Table("Table", "line1", "line2") - call Table("Empty Table") - -To return more than one value, return a |List|: > - :function Compute(n1, n2) - : if a:n2 == 0 - : return ["fail", 0] - : endif - : return ["ok", a:n1 / a:n2] - :endfunction - -This function can then be called with: > - :let [success, div] = Compute(102, 6) - :if success == "ok" - : echo div - :endif -< - *:cal* *:call* *E107* *E117* -:[range]cal[l] {name}([arguments]) - Call a function. The name of the function and its arguments - are as specified with |:function|. Up to 20 arguments can be - used. The returned value is discarded. - Without a range and for functions that accept a range, the - function is called once. When a range is given the cursor is - positioned at the start of the first line before executing the - function. - When a range is given and the function doesn't handle it - itself, the function is executed for each line in the range, - with the cursor in the first column of that line. The cursor - is left at the last line (possibly moved by the last function - call). The arguments are re-evaluated for each line. Thus - this works: - *function-range-example* > - :function Mynumber(arg) - : echo line(".") . " " . a:arg - :endfunction - :1,5call Mynumber(getline(".")) -< - The "a:firstline" and "a:lastline" are defined anyway, they - can be used to do something different at the start or end of - the range. - - Example of a function that handles the range itself: > - - :function Cont() range - : execute (a:firstline + 1) . "," . a:lastline . 's/^/\t\\ ' - :endfunction - :4,8call Cont() -< - This function inserts the continuation character "\" in front - of all the lines in the range, except the first one. - - When the function returns a composite value it can be further - dereferenced, but the range will not be used then. Example: > - :4,8call GetDict().method() -< Here GetDict() gets the range but method() does not. - - *E132* -The recursiveness of user functions is restricted with the |'maxfuncdepth'| -option. - - -AUTOMATICALLY LOADING FUNCTIONS ~ - *autoload-functions* -When using many or large functions, it's possible to automatically define them -only when they are used. There are two methods: with an autocommand and with -the "autoload" directory in 'runtimepath'. - - -Using an autocommand ~ - -This is introduced in the user manual, section |41.14|. - -The autocommand is useful if you have a plugin that is a long Vim script file. -You can define the autocommand and quickly quit the script with |:finish|. -That makes Vim startup faster. The autocommand should then load the same file -again, setting a variable to skip the |:finish| command. - -Use the FuncUndefined autocommand event with a pattern that matches the -function(s) to be defined. Example: > - - :au FuncUndefined BufNet* source ~/vim/bufnetfuncs.vim - -The file "~/vim/bufnetfuncs.vim" should then define functions that start with -"BufNet". Also see |FuncUndefined|. - - -Using an autoload script ~ - *autoload* *E746* -This is introduced in the user manual, section |41.15|. - -Using a script in the "autoload" directory is simpler, but requires using -exactly the right file name. A function that can be autoloaded has a name -like this: > - - :call filename#funcname() - -When such a function is called, and it is not defined yet, Vim will search the -"autoload" directories in 'runtimepath' for a script file called -"filename.vim". For example "~/.vim/autoload/filename.vim". That file should -then define the function like this: > - - function filename#funcname() - echo "Done!" - endfunction - -The file name and the name used before the # in the function must match -exactly, and the defined function must have the name exactly as it will be -called. - -It is possible to use subdirectories. Every # in the function name works like -a path separator. Thus when calling a function: > - - :call foo#bar#func() - -Vim will look for the file "autoload/foo/bar.vim" in 'runtimepath'. - -This also works when reading a variable that has not been set yet: > - - :let l = foo#bar#lvar - -However, when the autoload script was already loaded it won't be loaded again -for an unknown variable. - -When assigning a value to such a variable nothing special happens. This can -be used to pass settings to the autoload script before it's loaded: > - - :let foo#bar#toggle = 1 - :call foo#bar#func() - -Note that when you make a mistake and call a function that is supposed to be -defined in an autoload script, but the script doesn't actually define the -function, the script will be sourced every time you try to call the function. -And you will get an error message every time. - -Also note that if you have two script files, and one calls a function in the -other and vice versa, before the used function is defined, it won't work. -Avoid using the autoload functionality at the toplevel. - -Hint: If you distribute a bunch of scripts you can pack them together with the -|vimball| utility. Also read the user manual |distribute-script|. - -============================================================================== -6. Curly braces names *curly-braces-names* - -Wherever you can use a variable, you can use a "curly braces name" variable. -This is a regular variable name with one or more expressions wrapped in braces -{} like this: > - my_{adjective}_variable - -When Vim encounters this, it evaluates the expression inside the braces, puts -that in place of the expression, and re-interprets the whole as a variable -name. So in the above example, if the variable "adjective" was set to -"noisy", then the reference would be to "my_noisy_variable", whereas if -"adjective" was set to "quiet", then it would be to "my_quiet_variable". - -One application for this is to create a set of variables governed by an option -value. For example, the statement > - echo my_{&background}_message - -would output the contents of "my_dark_message" or "my_light_message" depending -on the current value of 'background'. - -You can use multiple brace pairs: > - echo my_{adverb}_{adjective}_message -..or even nest them: > - echo my_{ad{end_of_word}}_message -where "end_of_word" is either "verb" or "jective". - -However, the expression inside the braces must evaluate to a valid single -variable name, e.g. this is invalid: > - :let foo='a + b' - :echo c{foo}d -.. since the result of expansion is "ca + bd", which is not a variable name. - - *curly-braces-function-names* -You can call and define functions by an evaluated name in a similar way. -Example: > - :let func_end='whizz' - :call my_func_{func_end}(parameter) - -This would call the function "my_func_whizz(parameter)". - -============================================================================== -7. Commands *expression-commands* - -:let {var-name} = {expr1} *:let* *E18* - Set internal variable {var-name} to the result of the - expression {expr1}. The variable will get the type - from the {expr}. If {var-name} didn't exist yet, it - is created. - -:let {var-name}[{idx}] = {expr1} *E689* - Set a list item to the result of the expression - {expr1}. {var-name} must refer to a list and {idx} - must be a valid index in that list. For nested list - the index can be repeated. - This cannot be used to add an item to a |List|. - This cannot be used to set a byte in a String. You - can do that like this: > - :let var = var[0:2] . 'X' . var[4:] -< - *E711* *E719* -:let {var-name}[{idx1}:{idx2}] = {expr1} *E708* *E709* *E710* - Set a sequence of items in a |List| to the result of - the expression {expr1}, which must be a list with the - correct number of items. - {idx1} can be omitted, zero is used instead. - {idx2} can be omitted, meaning the end of the list. - When the selected range of items is partly past the - end of the list, items will be added. - - *:let+=* *:let-=* *:let.=* *E734* -:let {var} += {expr1} Like ":let {var} = {var} + {expr1}". -:let {var} -= {expr1} Like ":let {var} = {var} - {expr1}". -:let {var} .= {expr1} Like ":let {var} = {var} . {expr1}". - These fail if {var} was not set yet and when the type - of {var} and {expr1} don't fit the operator. - - -:let ${env-name} = {expr1} *:let-environment* *:let-$* - Set environment variable {env-name} to the result of - the expression {expr1}. The type is always String. -:let ${env-name} .= {expr1} - Append {expr1} to the environment variable {env-name}. - If the environment variable didn't exist yet this - works like "=". - -:let @{reg-name} = {expr1} *:let-register* *:let-@* - Write the result of the expression {expr1} in register - {reg-name}. {reg-name} must be a single letter, and - must be the name of a writable register (see - |registers|). "@@" can be used for the unnamed - register, "@/" for the search pattern. - If the result of {expr1} ends in a or , the - register will be linewise, otherwise it will be set to - characterwise. - This can be used to clear the last search pattern: > - :let @/ = "" -< This is different from searching for an empty string, - that would match everywhere. - -:let @{reg-name} .= {expr1} - Append {expr1} to register {reg-name}. If the - register was empty it's like setting it to {expr1}. - -:let &{option-name} = {expr1} *:let-option* *:let-&* - Set option {option-name} to the result of the - expression {expr1}. A String or Number value is - always converted to the type of the option. - For an option local to a window or buffer the effect - is just like using the |:set| command: both the local - value and the global value are changed. - Example: > - :let &path = &path . ',/usr/local/include' - -:let &{option-name} .= {expr1} - For a string option: Append {expr1} to the value. - Does not insert a comma like |:set+=|. - -:let &{option-name} += {expr1} -:let &{option-name} -= {expr1} - For a number or boolean option: Add or subtract - {expr1}. - -:let &l:{option-name} = {expr1} -:let &l:{option-name} .= {expr1} -:let &l:{option-name} += {expr1} -:let &l:{option-name} -= {expr1} - Like above, but only set the local value of an option - (if there is one). Works like |:setlocal|. - -:let &g:{option-name} = {expr1} -:let &g:{option-name} .= {expr1} -:let &g:{option-name} += {expr1} -:let &g:{option-name} -= {expr1} - Like above, but only set the global value of an option - (if there is one). Works like |:setglobal|. - -:let [{name1}, {name2}, ...] = {expr1} *:let-unpack* *E687* *E688* - {expr1} must evaluate to a |List|. The first item in - the list is assigned to {name1}, the second item to - {name2}, etc. - The number of names must match the number of items in - the |List|. - Each name can be one of the items of the ":let" - command as mentioned above. - Example: > - :let [s, item] = GetItem(s) -< Detail: {expr1} is evaluated first, then the - assignments are done in sequence. This matters if - {name2} depends on {name1}. Example: > - :let x = [0, 1] - :let i = 0 - :let [i, x[i]] = [1, 2] - :echo x -< The result is [0, 2]. - -:let [{name1}, {name2}, ...] .= {expr1} -:let [{name1}, {name2}, ...] += {expr1} -:let [{name1}, {name2}, ...] -= {expr1} - Like above, but append/add/subtract the value for each - |List| item. - -:let [{name}, ..., ; {lastname}] = {expr1} - Like |:let-unpack| above, but the |List| may have more - items than there are names. A list of the remaining - items is assigned to {lastname}. If there are no - remaining items {lastname} is set to an empty list. - Example: > - :let [a, b; rest] = ["aval", "bval", 3, 4] -< -:let [{name}, ..., ; {lastname}] .= {expr1} -:let [{name}, ..., ; {lastname}] += {expr1} -:let [{name}, ..., ; {lastname}] -= {expr1} - Like above, but append/add/subtract the value for each - |List| item. - *E106* -:let {var-name} .. List the value of variable {var-name}. Multiple - variable names may be given. Special names recognized - here: *E738* - g: global variables - b: local buffer variables - w: local window variables - t: local tab page variables - s: script-local variables - l: local function variables - v: Vim variables. - -:let List the values of all variables. The type of the - variable is indicated before the value: - String - # Number - * Funcref - - -:unl[et][!] {name} ... *:unlet* *:unl* *E108* *E795* - Remove the internal variable {name}. Several variable - names can be given, they are all removed. The name - may also be a |List| or |Dictionary| item. - With [!] no error message is given for non-existing - variables. - One or more items from a |List| can be removed: > - :unlet list[3] " remove fourth item - :unlet list[3:] " remove fourth item to last -< One item from a |Dictionary| can be removed at a time: > - :unlet dict['two'] - :unlet dict.two -< This is especially useful to clean up used global - variables and script-local variables (these are not - deleted when the script ends). Function-local - variables are automatically deleted when the function - ends. - -:lockv[ar][!] [depth] {name} ... *:lockvar* *:lockv* - Lock the internal variable {name}. Locking means that - it can no longer be changed (until it is unlocked). - A locked variable can be deleted: > - :lockvar v - :let v = 'asdf' " fails! - :unlet v -< *E741* - If you try to change a locked variable you get an - error message: "E741: Value of {name} is locked" - - [depth] is relevant when locking a |List| or - |Dictionary|. It specifies how deep the locking goes: - 1 Lock the |List| or |Dictionary| itself, - cannot add or remove items, but can - still change their values. - 2 Also lock the values, cannot change - the items. If an item is a |List| or - |Dictionary|, cannot add or remove - items, but can still change the - values. - 3 Like 2 but for the |List| / - |Dictionary| in the |List| / - |Dictionary|, one level deeper. - The default [depth] is 2, thus when {name} is a |List| - or |Dictionary| the values cannot be changed. - *E743* - For unlimited depth use [!] and omit [depth]. - However, there is a maximum depth of 100 to catch - loops. - - Note that when two variables refer to the same |List| - and you lock one of them, the |List| will also be - locked when used through the other variable. - Example: > - :let l = [0, 1, 2, 3] - :let cl = l - :lockvar l - :let cl[1] = 99 " won't work! -< You may want to make a copy of a list to avoid this. - See |deepcopy()|. - - -:unlo[ckvar][!] [depth] {name} ... *:unlockvar* *:unlo* - Unlock the internal variable {name}. Does the - opposite of |:lockvar|. - - -:if {expr1} *:if* *:endif* *:en* *E171* *E579* *E580* -:en[dif] Execute the commands until the next matching ":else" - or ":endif" if {expr1} evaluates to non-zero. - - From Vim version 4.5 until 5.0, every Ex command in - between the ":if" and ":endif" is ignored. These two - commands were just to allow for future expansions in a - backwards compatible way. Nesting was allowed. Note - that any ":else" or ":elseif" was ignored, the "else" - part was not executed either. - - You can use this to remain compatible with older - versions: > - :if version >= 500 - : version-5-specific-commands - :endif -< The commands still need to be parsed to find the - "endif". Sometimes an older Vim has a problem with a - new command. For example, ":silent" is recognized as - a ":substitute" command. In that case ":execute" can - avoid problems: > - :if version >= 600 - : execute "silent 1,$delete" - :endif -< - NOTE: The ":append" and ":insert" commands don't work - properly in between ":if" and ":endif". - - *:else* *:el* *E581* *E583* -:el[se] Execute the commands until the next matching ":else" - or ":endif" if they previously were not being - executed. - - *:elseif* *:elsei* *E582* *E584* -:elsei[f] {expr1} Short for ":else" ":if", with the addition that there - is no extra ":endif". - -:wh[ile] {expr1} *:while* *:endwhile* *:wh* *:endw* - *E170* *E585* *E588* *E733* -:endw[hile] Repeat the commands between ":while" and ":endwhile", - as long as {expr1} evaluates to non-zero. - When an error is detected from a command inside the - loop, execution continues after the "endwhile". - Example: > - :let lnum = 1 - :while lnum <= line("$") - :call FixLine(lnum) - :let lnum = lnum + 1 - :endwhile -< - NOTE: The ":append" and ":insert" commands don't work - properly inside a ":while" and ":for" loop. - -:for {var} in {list} *:for* *E690* *E732* -:endfo[r] *:endfo* *:endfor* - Repeat the commands between ":for" and ":endfor" for - each item in {list}. Variable {var} is set to the - value of each item. - When an error is detected for a command inside the - loop, execution continues after the "endfor". - Changing {list} inside the loop affects what items are - used. Make a copy if this is unwanted: > - :for item in copy(mylist) -< When not making a copy, Vim stores a reference to the - next item in the list, before executing the commands - with the current item. Thus the current item can be - removed without effect. Removing any later item means - it will not be found. Thus the following example - works (an inefficient way to make a list empty): > - :for item in mylist - :call remove(mylist, 0) - :endfor -< Note that reordering the list (e.g., with sort() or - reverse()) may have unexpected effects. - Note that the type of each list item should be - identical to avoid errors for the type of {var} - changing. Unlet the variable at the end of the loop - to allow multiple item types. - -:for [{var1}, {var2}, ...] in {listlist} -:endfo[r] - Like ":for" above, but each item in {listlist} must be - a list, of which each item is assigned to {var1}, - {var2}, etc. Example: > - :for [lnum, col] in [[1, 3], [2, 5], [3, 8]] - :echo getline(lnum)[col] - :endfor -< - *:continue* *:con* *E586* -:con[tinue] When used inside a ":while" or ":for" loop, jumps back - to the start of the loop. - If it is used after a |:try| inside the loop but - before the matching |:finally| (if present), the - commands following the ":finally" up to the matching - |:endtry| are executed first. This process applies to - all nested ":try"s inside the loop. The outermost - ":endtry" then jumps back to the start of the loop. - - *:break* *:brea* *E587* -:brea[k] When used inside a ":while" or ":for" loop, skips to - the command after the matching ":endwhile" or - ":endfor". - If it is used after a |:try| inside the loop but - before the matching |:finally| (if present), the - commands following the ":finally" up to the matching - |:endtry| are executed first. This process applies to - all nested ":try"s inside the loop. The outermost - ":endtry" then jumps to the command after the loop. - -:try *:try* *:endt* *:endtry* *E600* *E601* *E602* -:endt[ry] Change the error handling for the commands between - ":try" and ":endtry" including everything being - executed across ":source" commands, function calls, - or autocommand invocations. - - When an error or interrupt is detected and there is - a |:finally| command following, execution continues - after the ":finally". Otherwise, or when the - ":endtry" is reached thereafter, the next - (dynamically) surrounding ":try" is checked for - a corresponding ":finally" etc. Then the script - processing is terminated. (Whether a function - definition has an "abort" argument does not matter.) - Example: > - :try | edit too much | finally | echo "cleanup" | endtry - :echo "impossible" " not reached, script terminated above -< - Moreover, an error or interrupt (dynamically) inside - ":try" and ":endtry" is converted to an exception. It - can be caught as if it were thrown by a |:throw| - command (see |:catch|). In this case, the script - processing is not terminated. - - The value "Vim:Interrupt" is used for an interrupt - exception. An error in a Vim command is converted - to a value of the form "Vim({command}):{errmsg}", - other errors are converted to a value of the form - "Vim:{errmsg}". {command} is the full command name, - and {errmsg} is the message that is displayed if the - error exception is not caught, always beginning with - the error number. - Examples: > - :try | sleep 100 | catch /^Vim:Interrupt$/ | endtry - :try | edit | catch /^Vim(edit):E\d\+/ | echo "error" | endtry -< - *:cat* *:catch* *E603* *E604* *E605* -:cat[ch] /{pattern}/ The following commands until the next ":catch", - |:finally|, or |:endtry| that belongs to the same - |:try| as the ":catch" are executed when an exception - matching {pattern} is being thrown and has not yet - been caught by a previous ":catch". Otherwise, these - commands are skipped. - When {pattern} is omitted all errors are caught. - Examples: > - :catch /^Vim:Interrupt$/ " catch interrupts (CTRL-C) - :catch /^Vim\%((\a\+)\)\=:E/ " catch all Vim errors - :catch /^Vim\%((\a\+)\)\=:/ " catch errors and interrupts - :catch /^Vim(write):/ " catch all errors in :write - :catch /^Vim\%((\a\+)\)\=:E123/ " catch error E123 - :catch /my-exception/ " catch user exception - :catch /.*/ " catch everything - :catch " same as /.*/ -< - Another character can be used instead of / around the - {pattern}, so long as it does not have a special - meaning (e.g., '|' or '"') and doesn't occur inside - {pattern}. - NOTE: It is not reliable to ":catch" the TEXT of - an error message because it may vary in different - locales. - - *:fina* *:finally* *E606* *E607* -:fina[lly] The following commands until the matching |:endtry| - are executed whenever the part between the matching - |:try| and the ":finally" is left: either by falling - through to the ":finally" or by a |:continue|, - |:break|, |:finish|, or |:return|, or by an error or - interrupt or exception (see |:throw|). - - *:th* *:throw* *E608* -:th[row] {expr1} The {expr1} is evaluated and thrown as an exception. - If the ":throw" is used after a |:try| but before the - first corresponding |:catch|, commands are skipped - until the first ":catch" matching {expr1} is reached. - If there is no such ":catch" or if the ":throw" is - used after a ":catch" but before the |:finally|, the - commands following the ":finally" (if present) up to - the matching |:endtry| are executed. If the ":throw" - is after the ":finally", commands up to the ":endtry" - are skipped. At the ":endtry", this process applies - again for the next dynamically surrounding ":try" - (which may be found in a calling function or sourcing - script), until a matching ":catch" has been found. - If the exception is not caught, the command processing - is terminated. - Example: > - :try | throw "oops" | catch /^oo/ | echo "caught" | endtry -< - - *:ec* *:echo* -:ec[ho] {expr1} .. Echoes each {expr1}, with a space in between. The - first {expr1} starts on a new line. - Also see |:comment|. - Use "\n" to start a new line. Use "\r" to move the - cursor to the first column. - Uses the highlighting set by the |:echohl| command. - Cannot be followed by a comment. - Example: > - :echo "the value of 'shell' is" &shell -< *:echo-redraw* - A later redraw may make the message disappear again. - And since Vim mostly postpones redrawing until it's - finished with a sequence of commands this happens - quite often. To avoid that a command from before the - ":echo" causes a redraw afterwards (redraws are often - postponed until you type something), force a redraw - with the |:redraw| command. Example: > - :new | redraw | echo "there is a new window" -< - *:echon* -:echon {expr1} .. Echoes each {expr1}, without anything added. Also see - |:comment|. - Uses the highlighting set by the |:echohl| command. - Cannot be followed by a comment. - Example: > - :echon "the value of 'shell' is " &shell -< - Note the difference between using ":echo", which is a - Vim command, and ":!echo", which is an external shell - command: > - :!echo % --> filename -< The arguments of ":!" are expanded, see |:_%|. > - :!echo "%" --> filename or "filename" -< Like the previous example. Whether you see the double - quotes or not depends on your 'shell'. > - :echo % --> nothing -< The '%' is an illegal character in an expression. > - :echo "%" --> % -< This just echoes the '%' character. > - :echo expand("%") --> filename -< This calls the expand() function to expand the '%'. - - *:echoh* *:echohl* -:echoh[l] {name} Use the highlight group {name} for the following - |:echo|, |:echon| and |:echomsg| commands. Also used - for the |input()| prompt. Example: > - :echohl WarningMsg | echo "Don't panic!" | echohl None -< Don't forget to set the group back to "None", - otherwise all following echo's will be highlighted. - - *:echom* *:echomsg* -:echom[sg] {expr1} .. Echo the expression(s) as a true message, saving the - message in the |message-history|. - Spaces are placed between the arguments as with the - |:echo| command. But unprintable characters are - displayed, not interpreted. - The parsing works slightly different from |:echo|, - more like |:execute|. All the expressions are first - evaluated and concatenated before echoing anything. - The expressions must evaluate to a Number or String, a - Dictionary or List causes an error. - Uses the highlighting set by the |:echohl| command. - Example: > - :echomsg "It's a Zizzer Zazzer Zuzz, as you can plainly see." -< See |:echo-redraw| to avoid the message disappearing - when the screen is redrawn. - *:echoe* *:echoerr* -:echoe[rr] {expr1} .. Echo the expression(s) as an error message, saving the - message in the |message-history|. When used in a - script or function the line number will be added. - Spaces are placed between the arguments as with the - :echo command. When used inside a try conditional, - the message is raised as an error exception instead - (see |try-echoerr|). - Example: > - :echoerr "This script just failed!" -< If you just want a highlighted message use |:echohl|. - And to get a beep: > - :exe "normal \" -< - *:exe* *:execute* -:exe[cute] {expr1} .. Executes the string that results from the evaluation - of {expr1} as an Ex command. Multiple arguments are - concatenated, with a space in between. {expr1} is - used as the processed command, command line editing - keys are not recognized. - Cannot be followed by a comment. - Examples: > - :execute "buffer " nextbuf - :execute "normal " count . "w" -< - ":execute" can be used to append a command to commands - that don't accept a '|'. Example: > - :execute '!ls' | echo "theend" - -< ":execute" is also a nice way to avoid having to type - control characters in a Vim script for a ":normal" - command: > - :execute "normal ixxx\" -< This has an character, see |expr-string|. - - Be careful to correctly escape special characters in - file names. The |fnameescape()| function can be used - for Vim commands, |shellescape()| for |:!| commands. - Examples: > - :execute "e " . fnameescape(filename) - :execute "!ls " . shellescape(expand('%:h'), 1) -< - Note: The executed string may be any command-line, but - you cannot start or end a "while", "for" or "if" - command. Thus this is illegal: > - :execute 'while i > 5' - :execute 'echo "test" | break' -< - It is allowed to have a "while" or "if" command - completely in the executed string: > - :execute 'while i < 5 | echo i | let i = i + 1 | endwhile' -< - - *:comment* - ":execute", ":echo" and ":echon" cannot be followed by - a comment directly, because they see the '"' as the - start of a string. But, you can use '|' followed by a - comment. Example: > - :echo "foo" | "this is a comment - -============================================================================== -8. Exception handling *exception-handling* - -The Vim script language comprises an exception handling feature. This section -explains how it can be used in a Vim script. - -Exceptions may be raised by Vim on an error or on interrupt, see -|catch-errors| and |catch-interrupt|. You can also explicitly throw an -exception by using the ":throw" command, see |throw-catch|. - - -TRY CONDITIONALS *try-conditionals* - -Exceptions can be caught or can cause cleanup code to be executed. You can -use a try conditional to specify catch clauses (that catch exceptions) and/or -a finally clause (to be executed for cleanup). - A try conditional begins with a |:try| command and ends at the matching -|:endtry| command. In between, you can use a |:catch| command to start -a catch clause, or a |:finally| command to start a finally clause. There may -be none or multiple catch clauses, but there is at most one finally clause, -which must not be followed by any catch clauses. The lines before the catch -clauses and the finally clause is called a try block. > - - :try - : ... - : ... TRY BLOCK - : ... - :catch /{pattern}/ - : ... - : ... CATCH CLAUSE - : ... - :catch /{pattern}/ - : ... - : ... CATCH CLAUSE - : ... - :finally - : ... - : ... FINALLY CLAUSE - : ... - :endtry - -The try conditional allows to watch code for exceptions and to take the -appropriate actions. Exceptions from the try block may be caught. Exceptions -from the try block and also the catch clauses may cause cleanup actions. - When no exception is thrown during execution of the try block, the control -is transferred to the finally clause, if present. After its execution, the -script continues with the line following the ":endtry". - When an exception occurs during execution of the try block, the remaining -lines in the try block are skipped. The exception is matched against the -patterns specified as arguments to the ":catch" commands. The catch clause -after the first matching ":catch" is taken, other catch clauses are not -executed. The catch clause ends when the next ":catch", ":finally", or -":endtry" command is reached - whatever is first. Then, the finally clause -(if present) is executed. When the ":endtry" is reached, the script execution -continues in the following line as usual. - When an exception that does not match any of the patterns specified by the -":catch" commands is thrown in the try block, the exception is not caught by -that try conditional and none of the catch clauses is executed. Only the -finally clause, if present, is taken. The exception pends during execution of -the finally clause. It is resumed at the ":endtry", so that commands after -the ":endtry" are not executed and the exception might be caught elsewhere, -see |try-nesting|. - When during execution of a catch clause another exception is thrown, the -remaining lines in that catch clause are not executed. The new exception is -not matched against the patterns in any of the ":catch" commands of the same -try conditional and none of its catch clauses is taken. If there is, however, -a finally clause, it is executed, and the exception pends during its -execution. The commands following the ":endtry" are not executed. The new -exception might, however, be caught elsewhere, see |try-nesting|. - When during execution of the finally clause (if present) an exception is -thrown, the remaining lines in the finally clause are skipped. If the finally -clause has been taken because of an exception from the try block or one of the -catch clauses, the original (pending) exception is discarded. The commands -following the ":endtry" are not executed, and the exception from the finally -clause is propagated and can be caught elsewhere, see |try-nesting|. - -The finally clause is also executed, when a ":break" or ":continue" for -a ":while" loop enclosing the complete try conditional is executed from the -try block or a catch clause. Or when a ":return" or ":finish" is executed -from the try block or a catch clause of a try conditional in a function or -sourced script, respectively. The ":break", ":continue", ":return", or -":finish" pends during execution of the finally clause and is resumed when the -":endtry" is reached. It is, however, discarded when an exception is thrown -from the finally clause. - When a ":break" or ":continue" for a ":while" loop enclosing the complete -try conditional or when a ":return" or ":finish" is encountered in the finally -clause, the rest of the finally clause is skipped, and the ":break", -":continue", ":return" or ":finish" is executed as usual. If the finally -clause has been taken because of an exception or an earlier ":break", -":continue", ":return", or ":finish" from the try block or a catch clause, -this pending exception or command is discarded. - -For examples see |throw-catch| and |try-finally|. - - -NESTING OF TRY CONDITIONALS *try-nesting* - -Try conditionals can be nested arbitrarily. That is, a complete try -conditional can be put into the try block, a catch clause, or the finally -clause of another try conditional. If the inner try conditional does not -catch an exception thrown in its try block or throws a new exception from one -of its catch clauses or its finally clause, the outer try conditional is -checked according to the rules above. If the inner try conditional is in the -try block of the outer try conditional, its catch clauses are checked, but -otherwise only the finally clause is executed. It does not matter for -nesting, whether the inner try conditional is directly contained in the outer -one, or whether the outer one sources a script or calls a function containing -the inner try conditional. - -When none of the active try conditionals catches an exception, just their -finally clauses are executed. Thereafter, the script processing terminates. -An error message is displayed in case of an uncaught exception explicitly -thrown by a ":throw" command. For uncaught error and interrupt exceptions -implicitly raised by Vim, the error message(s) or interrupt message are shown -as usual. - -For examples see |throw-catch|. - - -EXAMINING EXCEPTION HANDLING CODE *except-examine* - -Exception handling code can get tricky. If you are in doubt what happens, set -'verbose' to 13 or use the ":13verbose" command modifier when sourcing your -script file. Then you see when an exception is thrown, discarded, caught, or -finished. When using a verbosity level of at least 14, things pending in -a finally clause are also shown. This information is also given in debug mode -(see |debug-scripts|). - - -THROWING AND CATCHING EXCEPTIONS *throw-catch* - -You can throw any number or string as an exception. Use the |:throw| command -and pass the value to be thrown as argument: > - :throw 4711 - :throw "string" -< *throw-expression* -You can also specify an expression argument. The expression is then evaluated -first, and the result is thrown: > - :throw 4705 + strlen("string") - :throw strpart("strings", 0, 6) - -An exception might be thrown during evaluation of the argument of the ":throw" -command. Unless it is caught there, the expression evaluation is abandoned. -The ":throw" command then does not throw a new exception. - Example: > - - :function! Foo(arg) - : try - : throw a:arg - : catch /foo/ - : endtry - : return 1 - :endfunction - : - :function! Bar() - : echo "in Bar" - : return 4710 - :endfunction - : - :throw Foo("arrgh") + Bar() - -This throws "arrgh", and "in Bar" is not displayed since Bar() is not -executed. > - :throw Foo("foo") + Bar() -however displays "in Bar" and throws 4711. - -Any other command that takes an expression as argument might also be -abandoned by an (uncaught) exception during the expression evaluation. The -exception is then propagated to the caller of the command. - Example: > - - :if Foo("arrgh") - : echo "then" - :else - : echo "else" - :endif - -Here neither of "then" or "else" is displayed. - - *catch-order* -Exceptions can be caught by a try conditional with one or more |:catch| -commands, see |try-conditionals|. The values to be caught by each ":catch" -command can be specified as a pattern argument. The subsequent catch clause -gets executed when a matching exception is caught. - Example: > - - :function! Foo(value) - : try - : throw a:value - : catch /^\d\+$/ - : echo "Number thrown" - : catch /.*/ - : echo "String thrown" - : endtry - :endfunction - : - :call Foo(0x1267) - :call Foo('string') - -The first call to Foo() displays "Number thrown", the second "String thrown". -An exception is matched against the ":catch" commands in the order they are -specified. Only the first match counts. So you should place the more -specific ":catch" first. The following order does not make sense: > - - : catch /.*/ - : echo "String thrown" - : catch /^\d\+$/ - : echo "Number thrown" - -The first ":catch" here matches always, so that the second catch clause is -never taken. - - *throw-variables* -If you catch an exception by a general pattern, you may access the exact value -in the variable |v:exception|: > - - : catch /^\d\+$/ - : echo "Number thrown. Value is" v:exception - -You may also be interested where an exception was thrown. This is stored in -|v:throwpoint|. Note that "v:exception" and "v:throwpoint" are valid for the -exception most recently caught as long it is not finished. - Example: > - - :function! Caught() - : if v:exception != "" - : echo 'Caught "' . v:exception . '" in ' . v:throwpoint - : else - : echo 'Nothing caught' - : endif - :endfunction - : - :function! Foo() - : try - : try - : try - : throw 4711 - : finally - : call Caught() - : endtry - : catch /.*/ - : call Caught() - : throw "oops" - : endtry - : catch /.*/ - : call Caught() - : finally - : call Caught() - : endtry - :endfunction - : - :call Foo() - -This displays > - - Nothing caught - Caught "4711" in function Foo, line 4 - Caught "oops" in function Foo, line 10 - Nothing caught - -A practical example: The following command ":LineNumber" displays the line -number in the script or function where it has been used: > - - :function! LineNumber() - : return substitute(v:throwpoint, '.*\D\(\d\+\).*', '\1', "") - :endfunction - :command! LineNumber try | throw "" | catch | echo LineNumber() | endtry -< - *try-nested* -An exception that is not caught by a try conditional can be caught by -a surrounding try conditional: > - - :try - : try - : throw "foo" - : catch /foobar/ - : echo "foobar" - : finally - : echo "inner finally" - : endtry - :catch /foo/ - : echo "foo" - :endtry - -The inner try conditional does not catch the exception, just its finally -clause is executed. The exception is then caught by the outer try -conditional. The example displays "inner finally" and then "foo". - - *throw-from-catch* -You can catch an exception and throw a new one to be caught elsewhere from the -catch clause: > - - :function! Foo() - : throw "foo" - :endfunction - : - :function! Bar() - : try - : call Foo() - : catch /foo/ - : echo "Caught foo, throw bar" - : throw "bar" - : endtry - :endfunction - : - :try - : call Bar() - :catch /.*/ - : echo "Caught" v:exception - :endtry - -This displays "Caught foo, throw bar" and then "Caught bar". - - *rethrow* -There is no real rethrow in the Vim script language, but you may throw -"v:exception" instead: > - - :function! Bar() - : try - : call Foo() - : catch /.*/ - : echo "Rethrow" v:exception - : throw v:exception - : endtry - :endfunction -< *try-echoerr* -Note that this method cannot be used to "rethrow" Vim error or interrupt -exceptions, because it is not possible to fake Vim internal exceptions. -Trying so causes an error exception. You should throw your own exception -denoting the situation. If you want to cause a Vim error exception containing -the original error exception value, you can use the |:echoerr| command: > - - :try - : try - : asdf - : catch /.*/ - : echoerr v:exception - : endtry - :catch /.*/ - : echo v:exception - :endtry - -This code displays - - Vim(echoerr):Vim:E492: Not an editor command: asdf ~ - - -CLEANUP CODE *try-finally* - -Scripts often change global settings and restore them at their end. If the -user however interrupts the script by pressing CTRL-C, the settings remain in -an inconsistent state. The same may happen to you in the development phase of -a script when an error occurs or you explicitly throw an exception without -catching it. You can solve these problems by using a try conditional with -a finally clause for restoring the settings. Its execution is guaranteed on -normal control flow, on error, on an explicit ":throw", and on interrupt. -(Note that errors and interrupts from inside the try conditional are converted -to exceptions. When not caught, they terminate the script after the finally -clause has been executed.) -Example: > - - :try - : let s:saved_ts = &ts - : set ts=17 - : - : " Do the hard work here. - : - :finally - : let &ts = s:saved_ts - : unlet s:saved_ts - :endtry - -This method should be used locally whenever a function or part of a script -changes global settings which need to be restored on failure or normal exit of -that function or script part. - - *break-finally* -Cleanup code works also when the try block or a catch clause is left by -a ":continue", ":break", ":return", or ":finish". - Example: > - - :let first = 1 - :while 1 - : try - : if first - : echo "first" - : let first = 0 - : continue - : else - : throw "second" - : endif - : catch /.*/ - : echo v:exception - : break - : finally - : echo "cleanup" - : endtry - : echo "still in while" - :endwhile - :echo "end" - -This displays "first", "cleanup", "second", "cleanup", and "end". > - - :function! Foo() - : try - : return 4711 - : finally - : echo "cleanup\n" - : endtry - : echo "Foo still active" - :endfunction - : - :echo Foo() "returned by Foo" - -This displays "cleanup" and "4711 returned by Foo". You don't need to add an -extra ":return" in the finally clause. (Above all, this would override the -return value.) - - *except-from-finally* -Using either of ":continue", ":break", ":return", ":finish", or ":throw" in -a finally clause is possible, but not recommended since it abandons the -cleanup actions for the try conditional. But, of course, interrupt and error -exceptions might get raised from a finally clause. - Example where an error in the finally clause stops an interrupt from -working correctly: > - - :try - : try - : echo "Press CTRL-C for interrupt" - : while 1 - : endwhile - : finally - : unlet novar - : endtry - :catch /novar/ - :endtry - :echo "Script still running" - :sleep 1 - -If you need to put commands that could fail into a finally clause, you should -think about catching or ignoring the errors in these commands, see -|catch-errors| and |ignore-errors|. - - -CATCHING ERRORS *catch-errors* - -If you want to catch specific errors, you just have to put the code to be -watched in a try block and add a catch clause for the error message. The -presence of the try conditional causes all errors to be converted to an -exception. No message is displayed and |v:errmsg| is not set then. To find -the right pattern for the ":catch" command, you have to know how the format of -the error exception is. - Error exceptions have the following format: > - - Vim({cmdname}):{errmsg} -or > - Vim:{errmsg} - -{cmdname} is the name of the command that failed; the second form is used when -the command name is not known. {errmsg} is the error message usually produced -when the error occurs outside try conditionals. It always begins with -a capital "E", followed by a two or three-digit error number, a colon, and -a space. - -Examples: - -The command > - :unlet novar -normally produces the error message > - E108: No such variable: "novar" -which is converted inside try conditionals to an exception > - Vim(unlet):E108: No such variable: "novar" - -The command > - :dwim -normally produces the error message > - E492: Not an editor command: dwim -which is converted inside try conditionals to an exception > - Vim:E492: Not an editor command: dwim - -You can catch all ":unlet" errors by a > - :catch /^Vim(unlet):/ -or all errors for misspelled command names by a > - :catch /^Vim:E492:/ - -Some error messages may be produced by different commands: > - :function nofunc -and > - :delfunction nofunc -both produce the error message > - E128: Function name must start with a capital: nofunc -which is converted inside try conditionals to an exception > - Vim(function):E128: Function name must start with a capital: nofunc -or > - Vim(delfunction):E128: Function name must start with a capital: nofunc -respectively. You can catch the error by its number independently on the -command that caused it if you use the following pattern: > - :catch /^Vim(\a\+):E128:/ - -Some commands like > - :let x = novar -produce multiple error messages, here: > - E121: Undefined variable: novar - E15: Invalid expression: novar -Only the first is used for the exception value, since it is the most specific -one (see |except-several-errors|). So you can catch it by > - :catch /^Vim(\a\+):E121:/ - -You can catch all errors related to the name "nofunc" by > - :catch /\/ - -You can catch all Vim errors in the ":write" and ":read" commands by > - :catch /^Vim(\(write\|read\)):E\d\+:/ - -You can catch all Vim errors by the pattern > - :catch /^Vim\((\a\+)\)\=:E\d\+:/ -< - *catch-text* -NOTE: You should never catch the error message text itself: > - :catch /No such variable/ -only works in the english locale, but not when the user has selected -a different language by the |:language| command. It is however helpful to -cite the message text in a comment: > - :catch /^Vim(\a\+):E108:/ " No such variable - - -IGNORING ERRORS *ignore-errors* - -You can ignore errors in a specific Vim command by catching them locally: > - - :try - : write - :catch - :endtry - -But you are strongly recommended NOT to use this simple form, since it could -catch more than you want. With the ":write" command, some autocommands could -be executed and cause errors not related to writing, for instance: > - - :au BufWritePre * unlet novar - -There could even be such errors you are not responsible for as a script -writer: a user of your script might have defined such autocommands. You would -then hide the error from the user. - It is much better to use > - - :try - : write - :catch /^Vim(write):/ - :endtry - -which only catches real write errors. So catch only what you'd like to ignore -intentionally. - -For a single command that does not cause execution of autocommands, you could -even suppress the conversion of errors to exceptions by the ":silent!" -command: > - :silent! nunmap k -This works also when a try conditional is active. - - -CATCHING INTERRUPTS *catch-interrupt* - -When there are active try conditionals, an interrupt (CTRL-C) is converted to -the exception "Vim:Interrupt". You can catch it like every exception. The -script is not terminated, then. - Example: > - - :function! TASK1() - : sleep 10 - :endfunction - - :function! TASK2() - : sleep 20 - :endfunction - - :while 1 - : let command = input("Type a command: ") - : try - : if command == "" - : continue - : elseif command == "END" - : break - : elseif command == "TASK1" - : call TASK1() - : elseif command == "TASK2" - : call TASK2() - : else - : echo "\nIllegal command:" command - : continue - : endif - : catch /^Vim:Interrupt$/ - : echo "\nCommand interrupted" - : " Caught the interrupt. Continue with next prompt. - : endtry - :endwhile - -You can interrupt a task here by pressing CTRL-C; the script then asks for -a new command. If you press CTRL-C at the prompt, the script is terminated. - -For testing what happens when CTRL-C would be pressed on a specific line in -your script, use the debug mode and execute the |>quit| or |>interrupt| -command on that line. See |debug-scripts|. - - -CATCHING ALL *catch-all* - -The commands > - - :catch /.*/ - :catch // - :catch - -catch everything, error exceptions, interrupt exceptions and exceptions -explicitly thrown by the |:throw| command. This is useful at the top level of -a script in order to catch unexpected things. - Example: > - - :try - : - : " do the hard work here - : - :catch /MyException/ - : - : " handle known problem - : - :catch /^Vim:Interrupt$/ - : echo "Script interrupted" - :catch /.*/ - : echo "Internal error (" . v:exception . ")" - : echo " - occurred at " . v:throwpoint - :endtry - :" end of script - -Note: Catching all might catch more things than you want. Thus, you are -strongly encouraged to catch only for problems that you can really handle by -specifying a pattern argument to the ":catch". - Example: Catching all could make it nearly impossible to interrupt a script -by pressing CTRL-C: > - - :while 1 - : try - : sleep 1 - : catch - : endtry - :endwhile - - -EXCEPTIONS AND AUTOCOMMANDS *except-autocmd* - -Exceptions may be used during execution of autocommands. Example: > - - :autocmd User x try - :autocmd User x throw "Oops!" - :autocmd User x catch - :autocmd User x echo v:exception - :autocmd User x endtry - :autocmd User x throw "Arrgh!" - :autocmd User x echo "Should not be displayed" - : - :try - : doautocmd User x - :catch - : echo v:exception - :endtry - -This displays "Oops!" and "Arrgh!". - - *except-autocmd-Pre* -For some commands, autocommands get executed before the main action of the -command takes place. If an exception is thrown and not caught in the sequence -of autocommands, the sequence and the command that caused its execution are -abandoned and the exception is propagated to the caller of the command. - Example: > - - :autocmd BufWritePre * throw "FAIL" - :autocmd BufWritePre * echo "Should not be displayed" - : - :try - : write - :catch - : echo "Caught:" v:exception "from" v:throwpoint - :endtry - -Here, the ":write" command does not write the file currently being edited (as -you can see by checking 'modified'), since the exception from the BufWritePre -autocommand abandons the ":write". The exception is then caught and the -script displays: > - - Caught: FAIL from BufWrite Auto commands for "*" -< - *except-autocmd-Post* -For some commands, autocommands get executed after the main action of the -command has taken place. If this main action fails and the command is inside -an active try conditional, the autocommands are skipped and an error exception -is thrown that can be caught by the caller of the command. - Example: > - - :autocmd BufWritePost * echo "File successfully written!" - : - :try - : write /i/m/p/o/s/s/i/b/l/e - :catch - : echo v:exception - :endtry - -This just displays: > - - Vim(write):E212: Can't open file for writing (/i/m/p/o/s/s/i/b/l/e) - -If you really need to execute the autocommands even when the main action -fails, trigger the event from the catch clause. - Example: > - - :autocmd BufWritePre * set noreadonly - :autocmd BufWritePost * set readonly - : - :try - : write /i/m/p/o/s/s/i/b/l/e - :catch - : doautocmd BufWritePost /i/m/p/o/s/s/i/b/l/e - :endtry -< -You can also use ":silent!": > - - :let x = "ok" - :let v:errmsg = "" - :autocmd BufWritePost * if v:errmsg != "" - :autocmd BufWritePost * let x = "after fail" - :autocmd BufWritePost * endif - :try - : silent! write /i/m/p/o/s/s/i/b/l/e - :catch - :endtry - :echo x - -This displays "after fail". - -If the main action of the command does not fail, exceptions from the -autocommands will be catchable by the caller of the command: > - - :autocmd BufWritePost * throw ":-(" - :autocmd BufWritePost * echo "Should not be displayed" - : - :try - : write - :catch - : echo v:exception - :endtry -< - *except-autocmd-Cmd* -For some commands, the normal action can be replaced by a sequence of -autocommands. Exceptions from that sequence will be catchable by the caller -of the command. - Example: For the ":write" command, the caller cannot know whether the file -had actually been written when the exception occurred. You need to tell it in -some way. > - - :if !exists("cnt") - : let cnt = 0 - : - : autocmd BufWriteCmd * if &modified - : autocmd BufWriteCmd * let cnt = cnt + 1 - : autocmd BufWriteCmd * if cnt % 3 == 2 - : autocmd BufWriteCmd * throw "BufWriteCmdError" - : autocmd BufWriteCmd * endif - : autocmd BufWriteCmd * write | set nomodified - : autocmd BufWriteCmd * if cnt % 3 == 0 - : autocmd BufWriteCmd * throw "BufWriteCmdError" - : autocmd BufWriteCmd * endif - : autocmd BufWriteCmd * echo "File successfully written!" - : autocmd BufWriteCmd * endif - :endif - : - :try - : write - :catch /^BufWriteCmdError$/ - : if &modified - : echo "Error on writing (file contents not changed)" - : else - : echo "Error after writing" - : endif - :catch /^Vim(write):/ - : echo "Error on writing" - :endtry - -When this script is sourced several times after making changes, it displays -first > - File successfully written! -then > - Error on writing (file contents not changed) -then > - Error after writing -etc. - - *except-autocmd-ill* -You cannot spread a try conditional over autocommands for different events. -The following code is ill-formed: > - - :autocmd BufWritePre * try - : - :autocmd BufWritePost * catch - :autocmd BufWritePost * echo v:exception - :autocmd BufWritePost * endtry - : - :write - - -EXCEPTION HIERARCHIES AND PARAMETERIZED EXCEPTIONS *except-hier-param* - -Some programming languages allow to use hierarchies of exception classes or to -pass additional information with the object of an exception class. You can do -similar things in Vim. - In order to throw an exception from a hierarchy, just throw the complete -class name with the components separated by a colon, for instance throw the -string "EXCEPT:MATHERR:OVERFLOW" for an overflow in a mathematical library. - When you want to pass additional information with your exception class, add -it in parentheses, for instance throw the string "EXCEPT:IO:WRITEERR(myfile)" -for an error when writing "myfile". - With the appropriate patterns in the ":catch" command, you can catch for -base classes or derived classes of your hierarchy. Additional information in -parentheses can be cut out from |v:exception| with the ":substitute" command. - Example: > - - :function! CheckRange(a, func) - : if a:a < 0 - : throw "EXCEPT:MATHERR:RANGE(" . a:func . ")" - : endif - :endfunction - : - :function! Add(a, b) - : call CheckRange(a:a, "Add") - : call CheckRange(a:b, "Add") - : let c = a:a + a:b - : if c < 0 - : throw "EXCEPT:MATHERR:OVERFLOW" - : endif - : return c - :endfunction - : - :function! Div(a, b) - : call CheckRange(a:a, "Div") - : call CheckRange(a:b, "Div") - : if (a:b == 0) - : throw "EXCEPT:MATHERR:ZERODIV" - : endif - : return a:a / a:b - :endfunction - : - :function! Write(file) - : try - : execute "write" fnameescape(a:file) - : catch /^Vim(write):/ - : throw "EXCEPT:IO(" . getcwd() . ", " . a:file . "):WRITEERR" - : endtry - :endfunction - : - :try - : - : " something with arithmetics and I/O - : - :catch /^EXCEPT:MATHERR:RANGE/ - : let function = substitute(v:exception, '.*(\(\a\+\)).*', '\1', "") - : echo "Range error in" function - : - :catch /^EXCEPT:MATHERR/ " catches OVERFLOW and ZERODIV - : echo "Math error" - : - :catch /^EXCEPT:IO/ - : let dir = substitute(v:exception, '.*(\(.\+\),\s*.\+).*', '\1', "") - : let file = substitute(v:exception, '.*(.\+,\s*\(.\+\)).*', '\1', "") - : if file !~ '^/' - : let file = dir . "/" . file - : endif - : echo 'I/O error for "' . file . '"' - : - :catch /^EXCEPT/ - : echo "Unspecified error" - : - :endtry - -The exceptions raised by Vim itself (on error or when pressing CTRL-C) use -a flat hierarchy: they are all in the "Vim" class. You cannot throw yourself -exceptions with the "Vim" prefix; they are reserved for Vim. - Vim error exceptions are parameterized with the name of the command that -failed, if known. See |catch-errors|. - - -PECULIARITIES - *except-compat* -The exception handling concept requires that the command sequence causing the -exception is aborted immediately and control is transferred to finally clauses -and/or a catch clause. - -In the Vim script language there are cases where scripts and functions -continue after an error: in functions without the "abort" flag or in a command -after ":silent!", control flow goes to the following line, and outside -functions, control flow goes to the line following the outermost ":endwhile" -or ":endif". On the other hand, errors should be catchable as exceptions -(thus, requiring the immediate abortion). - -This problem has been solved by converting errors to exceptions and using -immediate abortion (if not suppressed by ":silent!") only when a try -conditional is active. This is no restriction since an (error) exception can -be caught only from an active try conditional. If you want an immediate -termination without catching the error, just use a try conditional without -catch clause. (You can cause cleanup code being executed before termination -by specifying a finally clause.) - -When no try conditional is active, the usual abortion and continuation -behavior is used instead of immediate abortion. This ensures compatibility of -scripts written for Vim 6.1 and earlier. - -However, when sourcing an existing script that does not use exception handling -commands (or when calling one of its functions) from inside an active try -conditional of a new script, you might change the control flow of the existing -script on error. You get the immediate abortion on error and can catch the -error in the new script. If however the sourced script suppresses error -messages by using the ":silent!" command (checking for errors by testing -|v:errmsg| if appropriate), its execution path is not changed. The error is -not converted to an exception. (See |:silent|.) So the only remaining cause -where this happens is for scripts that don't care about errors and produce -error messages. You probably won't want to use such code from your new -scripts. - - *except-syntax-err* -Syntax errors in the exception handling commands are never caught by any of -the ":catch" commands of the try conditional they belong to. Its finally -clauses, however, is executed. - Example: > - - :try - : try - : throw 4711 - : catch /\(/ - : echo "in catch with syntax error" - : catch - : echo "inner catch-all" - : finally - : echo "inner finally" - : endtry - :catch - : echo 'outer catch-all caught "' . v:exception . '"' - : finally - : echo "outer finally" - :endtry - -This displays: > - inner finally - outer catch-all caught "Vim(catch):E54: Unmatched \(" - outer finally -The original exception is discarded and an error exception is raised, instead. - - *except-single-line* -The ":try", ":catch", ":finally", and ":endtry" commands can be put on -a single line, but then syntax errors may make it difficult to recognize the -"catch" line, thus you better avoid this. - Example: > - :try | unlet! foo # | catch | endtry -raises an error exception for the trailing characters after the ":unlet!" -argument, but does not see the ":catch" and ":endtry" commands, so that the -error exception is discarded and the "E488: Trailing characters" message gets -displayed. - - *except-several-errors* -When several errors appear in a single command, the first error message is -usually the most specific one and therefor converted to the error exception. - Example: > - echo novar -causes > - E121: Undefined variable: novar - E15: Invalid expression: novar -The value of the error exception inside try conditionals is: > - Vim(echo):E121: Undefined variable: novar -< *except-syntax-error* -But when a syntax error is detected after a normal error in the same command, -the syntax error is used for the exception being thrown. - Example: > - unlet novar # -causes > - E108: No such variable: "novar" - E488: Trailing characters -The value of the error exception inside try conditionals is: > - Vim(unlet):E488: Trailing characters -This is done because the syntax error might change the execution path in a way -not intended by the user. Example: > - try - try | unlet novar # | catch | echo v:exception | endtry - catch /.*/ - echo "outer catch:" v:exception - endtry -This displays "outer catch: Vim(unlet):E488: Trailing characters", and then -a "E600: Missing :endtry" error message is given, see |except-single-line|. - -============================================================================== -9. Examples *eval-examples* - -Printing in Binary ~ -> - :" The function Nr2Bin() returns the Hex string of a number. - :func Nr2Bin(nr) - : let n = a:nr - : let r = "" - : while n - : let r = '01'[n % 2] . r - : let n = n / 2 - : endwhile - : return r - :endfunc - - :" The function String2Bin() converts each character in a string to a - :" binary string, separated with dashes. - :func String2Bin(str) - : let out = '' - : for ix in range(strlen(a:str)) - : let out = out . '-' . Nr2Bin(char2nr(a:str[ix])) - : endfor - : return out[1:] - :endfunc - -Example of its use: > - :echo Nr2Bin(32) -result: "100000" > - :echo String2Bin("32") -result: "110011-110010" - - -Sorting lines ~ - -This example sorts lines with a specific compare function. > - - :func SortBuffer() - : let lines = getline(1, '$') - : call sort(lines, function("Strcmp")) - : call setline(1, lines) - :endfunction - -As a one-liner: > - :call setline(1, sort(getline(1, '$'), function("Strcmp"))) - - -scanf() replacement ~ - *sscanf* -There is no sscanf() function in Vim. If you need to extract parts from a -line, you can use matchstr() and substitute() to do it. This example shows -how to get the file name, line number and column number out of a line like -"foobar.txt, 123, 45". > - :" Set up the match bit - :let mx='\(\f\+\),\s*\(\d\+\),\s*\(\d\+\)' - :"get the part matching the whole expression - :let l = matchstr(line, mx) - :"get each item out of the match - :let file = substitute(l, mx, '\1', '') - :let lnum = substitute(l, mx, '\2', '') - :let col = substitute(l, mx, '\3', '') - -The input is in the variable "line", the results in the variables "file", -"lnum" and "col". (idea from Michael Geddes) - - -getting the scriptnames in a Dictionary ~ - *scriptnames-dictionary* -The |:scriptnames| command can be used to get a list of all script files that -have been sourced. There is no equivalent function or variable for this -(because it's rarely needed). In case you need to manipulate the list this -code can be used: > - " Get the output of ":scriptnames" in the scriptnames_output variable. - let scriptnames_output = '' - redir => scriptnames_output - silent scriptnames - redir END - - " Split the output into lines and parse each line. Add an entry to the - " "scripts" dictionary. - let scripts = {} - for line in split(scriptnames_output, "\n") - " Only do non-blank lines. - if line =~ '\S' - " Get the first number in the line. - let nr = matchstr(line, '\d\+') - " Get the file name, remove the script number " 123: ". - let name = substitute(line, '.\+:\s*', '', '') - " Add an item to the Dictionary - let scripts[nr] = name - endif - endfor - unlet scriptnames_output - -============================================================================== -10. No +eval feature *no-eval-feature* - -When the |+eval| feature was disabled at compile time, none of the expression -evaluation commands are available. To prevent this from causing Vim scripts -to generate all kinds of errors, the ":if" and ":endif" commands are still -recognized, though the argument of the ":if" and everything between the ":if" -and the matching ":endif" is ignored. Nesting of ":if" blocks is allowed, but -only if the commands are at the start of the line. The ":else" command is not -recognized. - -Example of how to avoid executing commands when the |+eval| feature is -missing: > - - :if 1 - : echo "Expression evaluation is compiled in" - :else - : echo "You will _never_ see this message" - :endif - -============================================================================== -11. The sandbox *eval-sandbox* *sandbox* *E48* - -The 'foldexpr', 'includeexpr', 'indentexpr', 'statusline' and 'foldtext' -options are evaluated in a sandbox. This means that you are protected from -these expressions having nasty side effects. This gives some safety for when -these options are set from a modeline. It is also used when the command from -a tags file is executed and for CTRL-R = in the command line. -The sandbox is also used for the |:sandbox| command. - -These items are not allowed in the sandbox: - - changing the buffer text - - defining or changing mapping, autocommands, functions, user commands - - setting certain options (see |option-summary|) - - setting certain v: variables (see |v:var|) *E794* - - executing a shell command - - reading or writing a file - - jumping to another buffer or editing a file - - executing Python, Perl, etc. commands -This is not guaranteed 100% secure, but it should block most attacks. - - *:san* *:sandbox* -:san[dbox] {cmd} Execute {cmd} in the sandbox. Useful to evaluate an - option that may have been set from a modeline, e.g. - 'foldexpr'. - - *sandbox-option* -A few options contain an expression. When this expression is evaluated it may -have to be done in the sandbox to avoid a security risk. But the sandbox is -restrictive, thus this only happens when the option was set from an insecure -location. Insecure in this context are: -- sourcing a .vimrc or .exrc in the current directory -- while executing in the sandbox -- value coming from a modeline - -Note that when in the sandbox and saving an option value and restoring it, the -option will still be marked as it was set in the sandbox. - -============================================================================== -12. Textlock *textlock* - -In a few situations it is not allowed to change the text in the buffer, jump -to another window and some other things that might confuse or break what Vim -is currently doing. This mostly applies to things that happen when Vim is -actually doing something else. For example, evaluating the 'balloonexpr' may -happen any moment the mouse cursor is resting at some position. - -This is not allowed when the textlock is active: - - changing the buffer text - - jumping to another buffer or window - - editing another file - - closing a window or quitting Vim - - etc. - - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/evim-it.1 b/share/vim/vim72/doc/evim-it.1 deleted file mode 100644 index 48e9a83ce2..0000000000 --- a/share/vim/vim72/doc/evim-it.1 +++ /dev/null @@ -1,54 +0,0 @@ -.TH EVIM 1 "16 febbraio 2002 " -.SH NOME -evim \- Vim "facile", Vim impostato in modo da poter essere usato -facilmente per modificare file, anche da chi non abbia familiarità -con i comandi. -.SH SINTASSI -.br -.B evim -[opzioni] [file ..] -.br -.B eview -.SH DESCRIZIONE -.B evim -Inizia -.B Vim -e imposta le opzioni per farlo comportare come un editore "modeless". -State sempre usando Vim, ma come un editore "posizionati-e-clicca". -Simile all'uso di Notepad in MS-Windows. -.B evim -richiede la presenza della GUI, per avere a disposizione menu e barra -strumenti. -.PP -Da usarsi solo da parte di chi non è in grado di lavorare con Vim nella -maniera usuale. -La modifica file sarà molto meno efficiente. -.PP -.B eview -come sopra, ma parte in modalità "Sola Lettura". Funziona come evim \-R. -.PP -Vedere vim(1) per dettagli riguardo a Vim, opzioni, etc. -.PP -L'opzione 'insertmode' è impostata per poter immettere del testo direttamente. -.br -Sono definite delle mappature che consentono di usare COPIA e INCOLLA con i -familiari tasti usati sotto MS-Windows. -CTRL-X taglia testo, CTRL-C copia testo e CTRL-V incolla testo. -Usate CTRL-Q per ottenere quello chs si ottierrebbe con CTRL-V in Vim nativo. -.SH OPZIONI -Vedere vim(1). -.SH FILE -.TP 15 -/usr/local/lib/vim/evim.vim -Lo script caricato per inizializzare eVim. -.SH NAC [NOTO ANCHE COME] -Noto Anche Come "Vim per semplici". -Quando usate evim si suppone che prendiate un fazzoletto, -facciate un nodo ad ogni angolo e ve lo mettiate in testa. -.SH VEDERE ANCHE -vim(1) -.SH AUTORE -Buona parte di -.B Vim -è stato scritto da Bram Moolenaar, con molto aiuto da altri. -Vedere il Menu "Aiuto/Crediti". diff --git a/share/vim/vim72/doc/evim-it.UTF-8.1 b/share/vim/vim72/doc/evim-it.UTF-8.1 deleted file mode 100644 index c6656bfd55..0000000000 --- a/share/vim/vim72/doc/evim-it.UTF-8.1 +++ /dev/null @@ -1,54 +0,0 @@ -.TH EVIM 1 "16 febbraio 2002 " -.SH NOME -evim \- Vim "facile", Vim impostato in modo da poter essere usato -facilmente per modificare file, anche da chi non abbia familiarità -con i comandi. -.SH SINTASSI -.br -.B evim -[opzioni] [file ..] -.br -.B eview -.SH DESCRIZIONE -.B evim -Inizia -.B Vim -e imposta le opzioni per farlo comportare come un editore "modeless". -State sempre usando Vim, ma come un editore "posizionati-e-clicca". -Simile all'uso di Notepad in MS-Windows. -.B evim -richiede la presenza della GUI, per avere a disposizione menu e barra -strumenti. -.PP -Da usarsi solo da parte di chi non è in grado di lavorare con Vim nella -maniera usuale. -La modifica file sarà molto meno efficiente. -.PP -.B eview -come sopra, ma parte in modalità "Sola Lettura". Funziona come evim \-R. -.PP -Vedere vim(1) per dettagli riguardo a Vim, opzioni, etc. -.PP -L'opzione 'insertmode' è impostata per poter immettere del testo direttamente. -.br -Sono definite delle mappature che consentono di usare COPIA e INCOLLA con i -familiari tasti usati sotto MS-Windows. -CTRL-X taglia testo, CTRL-C copia testo e CTRL-V incolla testo. -Usate CTRL-Q per ottenere quello chs si ottierrebbe con CTRL-V in Vim nativo. -.SH OPZIONI -Vedere vim(1). -.SH FILE -.TP 15 -/usr/local/lib/vim/evim.vim -Lo script caricato per inizializzare eVim. -.SH NAC [NOTO ANCHE COME] -Noto Anche Come "Vim per semplici". -Quando usate evim si suppone che prendiate un fazzoletto, -facciate un nodo ad ogni angolo e ve lo mettiate in testa. -.SH VEDERE ANCHE -vim(1) -.SH AUTORE -Buona parte di -.B Vim -è stato scritto da Bram Moolenaar, con molto aiuto da altri. -Vedere il Menu "Aiuto/Crediti". diff --git a/share/vim/vim72/doc/evim-pl.1 b/share/vim/vim72/doc/evim-pl.1 deleted file mode 100644 index 284b5bcb9b..0000000000 --- a/share/vim/vim72/doc/evim-pl.1 +++ /dev/null @@ -1,53 +0,0 @@ -.TH EVIM 1 "2002 Lut 16" -.SH NAZWA -evim \- ³atwy Vim, edytuj plik w Vimie z ustawieniami dla edycji bez -trybów -.SH SYNOPSIS -.br -.B evim -[opcje] [plik ...] -.br -.B eview -.SH OPIS -.B eVim -uruchamia -.B Vima -i ustawia opcje tak by zachowywa³ siê jak edytor bez trybów. -To jest ca³y czas Vim ale u¿ywany jako edytor wska¿-i-kliknij. -Zachowanie w stlu Notepada dla MS-Windows. -.B eVim -bêdzie zawsze uruchomiony w GUI by w³±czyæ menu i pasek narzêdzi. -.PP -Przeznaczony tylko dla ludzi, którzy naprawdê nie potrafi± pracowaæ -z Vimem w normalny sposób. Edycja bêdzie o wiele mniej efektywna. -.PP -.B eview -dzia³a tak samo, ale zaczyna w trybie tylko do odczytu. Dzia³a tak -samo jak evim \-R. -.PP -Zobacz vim(1) by poznaæ wiêcej szczegó³ów o Vimie, opcjach, itd. -.PP -Opcja 'insertmode' jest ustawiona by mo¿na by³o od razu wpisywaæ -tekst. -.br -Mapowania s± ustawione tak by Kopiowanie i Wklejanie dzia³a³o -z klawiszami MS-Windows. CTRL-X wycina tekst, CTRL-C kopiuje -a CTRL-V wkleja. U¿yj CTRL-Q by uzyskaæ oryginalne znaczenie -CTRL-V. -.SH OPCJE -Zobacz vim(1). -.SH PLIKI -.TP 15 -/usr/local/lib/vim/evim.vim -Skrypt uruchamiania dla eVima. -.SH ZNANY JAKO -Znany jako "Vim dla frajerów". -Je¶li u¿ywasz evima oczekuje siê, ¿e wyjmiesz chusteczkê do nosa, -zrobisz wêzê³ w ka¿dym rogu i bêdziesz to nosi³ na g³owie. -.SH ZOBACZ TAK¯E -vim(1) -.SH AUTOR -Wiêkszo¶æ -.B Vima -zosta³a napisana przez Brama Moolenaara z du¿± pomoc± innych osób. -Zobacz menu Help/Credits. diff --git a/share/vim/vim72/doc/evim-pl.UTF-8.1 b/share/vim/vim72/doc/evim-pl.UTF-8.1 deleted file mode 100644 index da940c0a73..0000000000 --- a/share/vim/vim72/doc/evim-pl.UTF-8.1 +++ /dev/null @@ -1,53 +0,0 @@ -.TH EVIM 1 "2002 Lut 16" -.SH NAZWA -evim \- łatwy Vim, edytuj plik w Vimie z ustawieniami dla edycji bez -trybów -.SH SYNOPSIS -.br -.B evim -[opcje] [plik ...] -.br -.B eview -.SH OPIS -.B eVim -uruchamia -.B Vima -i ustawia opcje tak by zachowywał się jak edytor bez trybów. -To jest cały czas Vim ale używany jako edytor wskaż-i-kliknij. -Zachowanie w stlu Notepada dla MS-Windows. -.B eVim -będzie zawsze uruchomiony w GUI by włączyć menu i pasek narzędzi. -.PP -Przeznaczony tylko dla ludzi, którzy naprawdę nie potrafią pracować -z Vimem w normalny sposób. Edycja będzie o wiele mniej efektywna. -.PP -.B eview -działa tak samo, ale zaczyna w trybie tylko do odczytu. Działa tak -samo jak evim \-R. -.PP -Zobacz vim(1) by poznać więcej szczegółów o Vimie, opcjach, itd. -.PP -Opcja 'insertmode' jest ustawiona by można było od razu wpisywać -tekst. -.br -Mapowania są ustawione tak by Kopiowanie i Wklejanie działało -z klawiszami MS-Windows. CTRL-X wycina tekst, CTRL-C kopiuje -a CTRL-V wkleja. Użyj CTRL-Q by uzyskać oryginalne znaczenie -CTRL-V. -.SH OPCJE -Zobacz vim(1). -.SH PLIKI -.TP 15 -/usr/local/lib/vim/evim.vim -Skrypt uruchamiania dla eVima. -.SH ZNANY JAKO -Znany jako "Vim dla frajerów". -Jeśli używasz evima oczekuje się, że wyjmiesz chusteczkę do nosa, -zrobisz węzęł w każdym rogu i będziesz to nosił na głowie. -.SH ZOBACZ TAKŻE -vim(1) -.SH AUTOR -Większość -.B Vima -została napisana przez Brama Moolenaara z dużą pomocą innych osób. -Zobacz menu Help/Credits. diff --git a/share/vim/vim72/doc/farsi.txt b/share/vim/vim72/doc/farsi.txt deleted file mode 100644 index 2172a48e17..0000000000 --- a/share/vim/vim72/doc/farsi.txt +++ /dev/null @@ -1,269 +0,0 @@ -*farsi.txt* For Vim version 7.2. Last change: 2005 Mar 29 - - - VIM REFERENCE MANUAL by Mortaza Ghassab Shiran - - -Right to Left and Farsi Mapping for Vim *farsi* *Farsi* - -{Vi does not have any of these commands} - - *E27* -In order to use right-to-left and Farsi mapping support, it is necessary to -compile Vim with the |+farsi| feature. - -These functions have been made by Mortaza G. Shiran - - -Introduction ------------- -In right-to-left oriented files the characters appear on the screen from right -to left. This kind of file is most useful when writing Farsi documents, -composing faxes or writing Farsi memos. - -The commands, prompts and help files are not in Farsi, therefore the user -interface remains the standard Vi interface. - - -Highlights ----------- -o Editing left-to-right files as in the original Vim, no change. - -o Viewing and editing files in right-to-left windows. File orientation is - per window, so it is possible to view the same file in right-to-left and - left-to-right modes, simultaneously. - -o Compatibility to the original Vim. Almost all features work in - right-to-left mode (see bugs below). - -o Changing keyboard mapping and reverse insert modes using a single - command. - -o Backing from reverse insert mode to the correct place in the file - (if possible). - -o While in Farsi mode, numbers are entered from left to right. Upon entering - a none number character, that character will be inserted just into the - left of the last number. - -o No special terminal with right-to-left capabilities is required. The - right-to-left changes are completely hardware independent. Only - Farsi font is necessary. - -o Farsi keymapping on the command line in reverse insert mode. - -o Toggling between left-to-right and right-to-left via F8 function key. - -o Toggling between Farsi ISIR-3342 standard encoding and Vim Farsi via F9 - function key. Since this makes sense only for the text written in - right-to-left mode, this function is also supported only in right-to-left - mode. - -Farsi Fonts *farsi fonts* ------------ - -If the "extra" archive has been unpacked, the following files are found in the -subdirectories of the '$VIM/farsi' directory: - - + far-a01.pcf X Windows fonts for Unix including Linux systems - + far-a01.bf X Windows fonts for SunOS - + far-a01.f16 a screen fonts for Unix including Linux systems - + far-a01.fon a monospaced fonts for Windows NT/95/98 - + far-a01.com a screen fonts for DOS - - -Font Installation ------------------ - -o Installation of fonts for MS Window systems (NT/95/98) - - From 'Control Panel' folder, start the 'Fonts' program. Then from 'file' - menu item select 'Install New Fonts ...'. Browse and select the - 'far-a01.fon', then follow the installation guide. - NOTE: several people have reported that this does not work. The solution - is unknown. - -o Installation of fonts for X Window systems (Unix/Linux) - - Depending on your system, copy far-a01.pcf.Z or far-a01.pcf.gz into a - directory of your choice. Change to the directory containing the Farsi - fonts and execute the following commands: - - > mkfontdir - > xset +fp path_name_of_farsi_fonts_directory - -o Installation of fonts for X Window systems (SunOS) - - Copy far-a01.bf font into a directory of your choice. - Change to the directory containing the far-a01.fb fonts and - execute the following commands: - - > fldfamily - > xset +fp path_name_of_fonts_directory - -o Installation of ASCII screen fonts (Unix/Linux) - - For Linux system, copy the far-a01.f16 fonts into /usr/lib/kbd/consolefonts - directory and execute the setfont program as "setfont far-a01.f16". For - other systems (e.g. SCO Unix), please refer to the fonts installation - section of your system administration manuals. - -o Installation of ASCII screen fonts (DOS) - - After system power on, prior to the first use of Vim, upload the Farsi - fonts by executing the far-a01.com font uploading program. - - -Usage ------ -Prior to starting Vim, the environment in which Vim can run in Farsi mode, -must be set. In addition to installation of Farsi fonts, following points -refer to some of the system environments, which you may need to set: -Key code mapping, loading graphic card in ASCII screen mode, setting the IO -driver in 8 bit clean mode ... . - -o Setting the Farsi fonts - - + For Vim GUI set the 'guifont' to far-a01. This is done by entering - ':set guifont=far-a01' in the Vim window. - - You can have 'guifont' set to far-a01 by Vim during the Vim startup - by appending the ':set guifont=far-a01' into your .vimrc file - (in case of NT/95/98 platforms _vimrc). - - Under the X Window environment, you can also start Vim with the - '-fn far-a01' option. - - + For Vim within a xterm, start a xterm with the Farsi fonts (e.g. - kterm -fn far-a01). Then start Vim inside the kterm. - - + For Vim under DOS, prior to the first usage of Vim, upload the Farsi - fonts by executing the far-a01.com fonts uploading program. - -o Farsi Keymapping Activation - - To activate the Farsi keymapping, set either 'altkeymap' or 'fkmap'. - This is done by entering ':set akm' or ':set fk' in the Vim window. - You can have 'altkeymap' or 'fkmap' set as default by appending ':set akm' - or ':set fk' in your .vimrc file or _vimrc in case of NT/95/98 platforms. - - To turn off the Farsi keymapping as a default second language keymapping, - reset the 'altkeymap' by entering ':set noakm'. - -o right-to-left Farsi Mode - - By default Vim starts in Left-to-right mode. Following are ways to change - the window orientation: - - + Start Vim with the -F option (e.g. vim -F ...). - - + Use the F8 function key to toggle between left-to-right and right-to-left. - - + While in Left-to-right mode, enter 'set rl' in the command line ('rl' is - the abbreviation for rightleft). - - + Put the 'set rl' line in your '.vimrc' file to start Vim in - right-to-left mode permanently. - -Encoding --------- - -The letter encoding used is the Vim extended ISIR-3342 standard with a built -in function to convert between Vim extended ISIR-3342 and ISIR-3342 standard. - -For document portability reasons, the letter encoding is kept the same across -different platforms (i.e. UNIX's, NT/95/98, MS DOS, ...). - - -o Keyboard - - + CTRL-_ in insert/replace modes toggles between Farsi(akm)/Latin - mode as follows: - - + CTRL-_ moves the cursor to the end of the typed text in edit mode. - - + CTRL-_ in command mode only toggles keyboard mapping between Farsi(akm)/ - Latin. The Farsi text is then entered in reverse insert mode. - - + F8 - Toggles between left-to-right and right-to-left. - - + F9 - Toggles the encoding between ISIR-3342 standard and Vim extended - ISIR-3342 (supported only in right-to-left mode). - - + Keyboard mapping is based on the Iranian ISIRI-2901 standard. - Following table shows the keyboard mapping while Farsi(akm) mode set: - - ------------------------------------- - ` 1 2 3 4 5 6 7 8 9 0 - = - ¢ ± ² ³ ´ µ ¶ · ¸ ¹ ° ­ ½ - ------------------------------------- - ~ ! @ # $ % ^ & * ( ) _ + - ~ £ § ® ¤ ¥ ª ¬ è ¨ © é « - ------------------------------------- - q w e r t z u i o p [ ] - Ó Ò Æ Ù Ø Õ Ö à Ê É Ç ˆ - ------------------------------------- - Q W E R T Z U I O P { } - ÷ õ ô ó ò ý ð ö [ ] { } - ------------------------------------- - a s d f g h j k l ; ' \ - Ñ Ð á Ã Ü Á Å Þ Ý Ú Û ë - ------------------------------------- - A S D F G H J K L : " | - ù û  þ ú ø À ü æ ç º » ê - ------------------------------------- - < y x c v b n m , . / - ¾ × Ô Î Í Ì Ë Ä ß ¦ ¯ - ------------------------------------- - > Y X C V B N M < > ? - ¼ ñ Ô Ï Í ¡ Ë Â ¾ ¼ ¿ - ------------------------------------- - -Note: - ¡ stands for Farsi PSP (break without space) - - ¢ stands for Farsi PCN (for HAMZE attribute ) - -Restrictions ------------- - -o In insert/replace mode and fkmap (Farsi mode) set, CTRL-B is not - supported. - -o If you change the character mapping between Latin/Farsi, the redo buffer - will be reset (emptied). That is, redo is valid and will function (using - '.') only within the mode you are in. - -o While numbers are entered in Farsi mode, the redo buffer will be reset - (emptied). That is, you cannot redo the last changes (using '.') after - entering numbers. - -o While in left-to-right mode and Farsi mode set, CTRL-R is not supported. - -o While in right-to-left mode, the search on 'Latin' pattern does not work, - except if you enter the Latin search pattern in reverse. - -o In command mode there is no support for entering numbers from left - to right and also for the sake of flexibility the keymapping logic is - restricted. - -o Under the X Window environment, if you want to run Vim within a xterm - terminal emulator and Farsi mode set, you need to have an ANSI compatible - xterm terminal emulator. This is because the letter codes above 128 decimal - have certain meanings in the standard xterm terminal emulator. - - Note: Under X Window environment, Vim GUI works fine in Farsi mode. - This eliminates the need of any xterm terminal emulator. - - -Bugs ----- -While in insert/replace and Farsi mode set, if you repeatedly change the -cursor position (via cursor movement) and enter new text and then try to undo -the last change, the undo will lag one change behind. But as you continue to -undo, you will reach the original line of text. You can also use U to undo all -changes made in the current line. - -For more information about the bugs refer to rileft.txt. - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/filetype.txt b/share/vim/vim72/doc/filetype.txt deleted file mode 100644 index 7f2e7096cf..0000000000 --- a/share/vim/vim72/doc/filetype.txt +++ /dev/null @@ -1,620 +0,0 @@ -*filetype.txt* For Vim version 7.2. Last change: 2008 Jul 15 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Filetypes *filetype* *file-type* - -1. Filetypes |filetypes| -2. Filetype plugin |filetype-plugins| -3. Docs for the default filetype plugins. |ftplugin-docs| - -Also see |autocmd.txt|. - -{Vi does not have any of these commands} - -============================================================================== -1. Filetypes *filetypes* *file-types* - -Vim can detect the type of file that is edited. This is done by checking the -file name and sometimes by inspecting the contents of the file for specific -text. - - *:filetype* *:filet* -To enable file type detection, use this command in your vimrc: > - :filetype on -Each time a new or existing file is edited, Vim will try to recognize the type -of the file and set the 'filetype' option. This will trigger the FileType -event, which can be used to set the syntax highlighting, set options, etc. - -NOTE: Filetypes and 'compatible' don't work together well, since being Vi -compatible means options are global. Resetting 'compatible' is recommended, -if you didn't do that already. - -Detail: The ":filetype on" command will load one of these files: - Amiga $VIMRUNTIME/filetype.vim - Mac $VIMRUNTIME:filetype.vim - MS-DOS $VIMRUNTIME\filetype.vim - RiscOS Vim:Filetype - Unix $VIMRUNTIME/filetype.vim - VMS $VIMRUNTIME/filetype.vim - This file is a Vim script that defines autocommands for the - BufNewFile and BufRead events. If the file type is not found by the - name, the file $VIMRUNTIME/scripts.vim is used to detect it from the - contents of the file. - When the GUI is running or will start soon, the menu.vim script is - also sourced. See |'go-M'| about avoiding that. - -To add your own file types, see |new-filetype| below. To search for help on a -filetype prepend "ft-" and optionally append "-syntax", "-indent" or -"-plugin". For example: > - :help ft-vim-indent - :help ft-vim-syntax - :help ft-man-plugin - -If the file type is not detected automatically, or it finds the wrong type, -you can either set the 'filetype' option manually, or add a modeline to your -file. Example, for an IDL file use the command: > - :set filetype=idl - -or add this |modeline| to the file: - /* vim: set filetype=idl : */ ~ - - *:filetype-plugin-on* -You can enable loading the plugin files for specific file types with: > - :filetype plugin on -If filetype detection was not switched on yet, it will be as well. -This actually loads the file "ftplugin.vim" in 'runtimepath'. -The result is that when a file is edited its plugin file is loaded (if there -is one for the detected filetype). |filetype-plugin| - - *:filetype-plugin-off* -You can disable it again with: > - :filetype plugin off -The filetype detection is not switched off then. But if you do switch off -filetype detection, the plugins will not be loaded either. -This actually loads the file "ftplugof.vim" in 'runtimepath'. - - *:filetype-indent-on* -You can enable loading the indent file for specific file types with: > - :filetype indent on -If filetype detection was not switched on yet, it will be as well. -This actually loads the file "indent.vim" in 'runtimepath'. -The result is that when a file is edited its indent file is loaded (if there -is one for the detected filetype). |indent-expression| - - *:filetype-indent-off* -You can disable it again with: > - :filetype indent off -The filetype detection is not switched off then. But if you do switch off -filetype detection, the indent files will not be loaded either. -This actually loads the file "indoff.vim" in 'runtimepath'. -This disables auto-indenting for files you will open. It will keep working in -already opened files. Reset 'autoindent', 'cindent', 'smartindent' and/or -'indentexpr' to disable indenting in an opened file. - - *:filetype-off* -To disable file type detection, use this command: > - :filetype off -This will keep the flags for "plugin" and "indent", but since no file types -are being detected, they won't work until the next ":filetype on". - - -Overview: *:filetype-overview* - -command detection plugin indent ~ -:filetype on on unchanged unchanged -:filetype off off unchanged unchanged -:filetype plugin on on on unchanged -:filetype plugin off unchanged off unchanged -:filetype indent on on unchanged on -:filetype indent off unchanged unchanged off -:filetype plugin indent on on on on -:filetype plugin indent off unchanged off off - -To see the current status, type: > - :filetype -The output looks something like this: > - filetype detection:ON plugin:ON indent:OFF - -The file types are also used for syntax highlighting. If the ":syntax on" -command is used, the file type detection is installed too. There is no need -to do ":filetype on" after ":syntax on". - -To disable one of the file types, add a line in your filetype file, see -|remove-filetype|. - - *filetype-detect* -To detect the file type again: > - :filetype detect -Use this if you started with an empty file and typed text that makes it -possible to detect the file type. For example, when you entered this in a -shell script: "#!/bin/csh". - When filetype detection was off, it will be enabled first, like the "on" -argument was used. - - *filetype-overrule* -When the same extension is used for two filetypes, Vim tries to guess what -kind of file it is. This doesn't always work. A number of global variables -can be used to overrule the filetype used for certain extensions: - - file name variable ~ - *.asa g:filetype_asa |ft-aspvbs-syntax| |ft-aspperl-syntax| - *.asp g:filetype_asp |ft-aspvbs-syntax| |ft-aspperl-syntax| - *.asm g:asmsyntax |ft-asm-syntax| - *.prg g:filetype_prg - *.pl g:filetype_pl - *.inc g:filetype_inc - *.w g:filetype_w |ft-cweb-syntax| - *.i g:filetype_i |ft-progress-syntax| - *.p g:filetype_p |ft-pascal-syntax| - *.sh g:bash_is_sh |ft-sh-syntax| - *.tex g:tex_flavor |ft-tex-plugin| - - *filetype-ignore* -To avoid that certain files are being inspected, the g:ft_ignore_pat variable -is used. The default value is set like this: > - :let g:ft_ignore_pat = '\.\(Z\|gz\|bz2\|zip\|tgz\)$' -This means that the contents of compressed files are not inspected. - - *new-filetype* -If a file type that you want to use is not detected yet, there are four ways -to add it. In any way, it's better not to modify the $VIMRUNTIME/filetype.vim -file. It will be overwritten when installing a new version of Vim. - -A. If you want to overrule all default file type checks. - This works by writing one file for each filetype. The disadvantage is that - means there can be many files. The advantage is that you can simply drop - this file in the right directory to make it work. - *ftdetect* - 1. Create your user runtime directory. You would normally use the first - item of the 'runtimepath' option. Then create the directory "ftdetect" - inside it. Example for Unix: > - :!mkdir ~/.vim - :!mkdir ~/.vim/ftdetect -< - 2. Create a file that contains an autocommand to detect the file type. - Example: > - au BufRead,BufNewFile *.mine set filetype=mine -< Note that there is no "augroup" command, this has already been done - when sourcing your file. You could also use the pattern "*" and then - check the contents of the file to recognize it. - Write this file as "mine.vim" in the "ftdetect" directory in your user - runtime directory. For example, for Unix: > - :w ~/.vim/ftdetect/mine.vim - -< 3. To use the new filetype detection you must restart Vim. - - The files in the "ftdetect" directory are used after all the default - checks, thus they can overrule a previously detected file type. But you - can also use |:setfiletype| to keep a previously detected filetype. - -B. If you want to detect your file after the default file type checks. - - This works like A above, but instead of setting 'filetype' unconditionally - use ":setfiletype". This will only set 'filetype' if no file type was - detected yet. Example: > - au BufRead,BufNewFile *.txt setfiletype text -< - You can also use the already detected file type in your command. For - example, to use the file type "mypascal" when "pascal" has been detected: > - au BufRead,BufNewFile * if &ft == 'pascal' | set ft=mypascal - | endif - -C. If your file type can be detected by the file name. - 1. Create your user runtime directory. You would normally use the first - item of the 'runtimepath' option. Example for Unix: > - :!mkdir ~/.vim -< - 2. Create a file that contains autocommands to detect the file type. - Example: > - " my filetype file - if exists("did_load_filetypes") - finish - endif - augroup filetypedetect - au! BufRead,BufNewFile *.mine setfiletype mine - au! BufRead,BufNewFile *.xyz setfiletype drawing - augroup END -< Write this file as "filetype.vim" in your user runtime directory. For - example, for Unix: > - :w ~/.vim/filetype.vim - -< 3. To use the new filetype detection you must restart Vim. - - Your filetype.vim will be sourced before the default FileType autocommands - have been installed. Your autocommands will match first, and the - ":setfiletype" command will make sure that no other autocommands will set - 'filetype' after this. - *new-filetype-scripts* -D. If your filetype can only be detected by inspecting the contents of the - file. - - 1. Create your user runtime directory. You would normally use the first - item of the 'runtimepath' option. Example for Unix: > - :!mkdir ~/.vim -< - 2. Create a vim script file for doing this. Example: > - if did_filetype() " filetype already set.. - finish " ..don't do these checks - endif - if getline(1) =~ '^#!.*\' - setfiletype mine - elseif getline(1) =~? '\' - setfiletype drawing - endif -< See $VIMRUNTIME/scripts.vim for more examples. - Write this file as "scripts.vim" in your user runtime directory. For - example, for Unix: > - :w ~/.vim/scripts.vim -< - 3. The detection will work right away, no need to restart Vim. - - Your scripts.vim is loaded before the default checks for file types, which - means that your rules override the default rules in - $VIMRUNTIME/scripts.vim. - - *remove-filetype* -If a file type is detected that is wrong for you, install a filetype.vim or -scripts.vim to catch it (see above). You can set 'filetype' to a non-existing -name to avoid that it will be set later anyway: > - :set filetype=ignored - -If you are setting up a system with many users, and you don't want each user -to add/remove the same filetypes, consider writing the filetype.vim and -scripts.vim files in a runtime directory that is used for everybody. Check -the 'runtimepath' for a directory to use. If there isn't one, set -'runtimepath' in the |system-vimrc|. Be careful to keep the default -directories! - - - *autocmd-osfiletypes* -On operating systems which support storing a file type with the file, you can -specify that an autocommand should only be executed if the file is of a -certain type. - -The actual type checking depends on which platform you are running Vim -on; see your system's documentation for details. - -To use osfiletype checking in an autocommand you should put a list of types to -match in angle brackets in place of a pattern, like this: > - - :au BufRead *.html,<&faf;HTML> runtime! syntax/html.vim - -This will match: - -- Any file whose name ends in ".html" -- Any file whose type is "&faf" or "HTML", where the meaning of these types - depends on which version of Vim you are using. - Unknown types are considered NOT to match. - -You can also specify a type and a pattern at the same time (in which case they -must both match): > - - :au BufRead <&fff>diff* - -This will match files of type "&fff" whose names start with "diff". - -Note that osfiletype checking is skipped if Vim is compiled without the -|+osfiletype| feature. - - *plugin-details* -The "plugin" directory can be in any of the directories in the 'runtimepath' -option. All of these directories will be searched for plugins and they are -all loaded. For example, if this command: > - - set runtimepath - -produces this output: - - runtimepath=/etc/vim,~/.vim,/usr/local/share/vim/vim60 ~ - -then Vim will load all plugins in these directories and below: - - /etc/vim/plugin/ ~ - ~/.vim/plugin/ ~ - /usr/local/share/vim/vim60/plugin/ ~ - -Note that the last one is the value of $VIMRUNTIME which has been expanded. - -What if it looks like your plugin is not being loaded? You can find out what -happens when Vim starts up by using the |-V| argument: > - - vim -V2 - -You will see a lot of messages, in between them is a remark about loading the -plugins. It starts with: - - Searching for "plugin/**/*.vim" in ~ - -There you can see where Vim looks for your plugin scripts. - -============================================================================== -2. Filetype plugin *filetype-plugins* - -When loading filetype plugins has been enabled |:filetype-plugin-on|, options -will be set and mappings defined. These are all local to the buffer, they -will not be used for other files. - -Defining mappings for a filetype may get in the way of the mappings you -define yourself. There are a few ways to avoid this: -1. Set the "maplocalleader" variable to the key sequence you want the mappings - to start with. Example: > - :let maplocalleader = "," -< All mappings will then start with a comma instead of the default, which - is a backslash. Also see ||. - -2. Define your own mapping. Example: > - :map ,p MailQuote -< You need to check the description of the plugin file below for the - functionality it offers and the string to map to. - You need to define your own mapping before the plugin is loaded (before - editing a file of that type). The plugin will then skip installing the - default mapping. - -3. Disable defining mappings for a specific filetype by setting a variable, - which contains the name of the filetype. For the "mail" filetype this - would be: > - :let no_mail_maps = 1 - -4. Disable defining mappings for all filetypes by setting a variable: > - :let no_plugin_maps = 1 -< - - *ftplugin-overrule* -If a global filetype plugin does not do exactly what you want, there are three -ways to change this: - -1. Add a few settings. - You must create a new filetype plugin in a directory early in - 'runtimepath'. For Unix, for example you could use this file: > - vim ~/.vim/ftplugin/fortran.vim -< You can set those settings and mappings that you would like to add. Note - that the global plugin will be loaded after this, it may overrule the - settings that you do here. If this is the case, you need to use one of the - following two methods. - -2. Make a copy of the plugin and change it. - You must put the copy in a directory early in 'runtimepath'. For Unix, for - example, you could do this: > - cp $VIMRUNTIME/ftplugin/fortran.vim ~/.vim/ftplugin/fortran.vim -< Then you can edit the copied file to your liking. Since the b:did_ftplugin - variable will be set, the global plugin will not be loaded. - A disadvantage of this method is that when the distributed plugin gets - improved, you will have to copy and modify it again. - -3. Overrule the settings after loading the global plugin. - You must create a new filetype plugin in a directory from the end of - 'runtimepath'. For Unix, for example, you could use this file: > - vim ~/.vim/after/ftplugin/fortran.vim -< In this file you can change just those settings that you want to change. - -============================================================================== -3. Docs for the default filetype plugins. *ftplugin-docs* - - -CHANGELOG *ft-changelog-plugin* - -Allows for easy entrance of Changelog entries in Changelog files. There are -some commands, mappings, and variables worth exploring: - -Options: -'comments' is made empty to not mess up formatting. -'textwidth' is set to 78, which is standard. -'formatoptions' the 't' flag is added to wrap when inserting text. - -Commands: -NewChangelogEntry Adds a new Changelog entry in an intelligent fashion - (see below). - -Local mappings: -o Starts a new Changelog entry in an equally intelligent - fashion (see below). - -Global mappings: - NOTE: The global mappings are accessed by sourcing the - ftplugin/changelog.vim file first, e.g. with > - runtime ftplugin/changelog.vim -< in your |.vimrc|. -o Switches to the ChangeLog buffer opened for the - current directory, or opens it in a new buffer if it - exists in the current directory. Then it does the - same as the local o described above. - -Variables: -g:changelog_timeformat Deprecated; use g:changelog_dateformat instead. -g:changelog_dateformat The date (and time) format used in ChangeLog entries. - The format accepted is the same as for the - |strftime()| function. - The default is "%Y-%m-%d" which is the standard format - for many ChangeLog layouts. -g:changelog_username The name and email address of the user. - The default is deduced from environment variables and - system files. It searches /etc/passwd for the comment - part of the current user, which informally contains - the real name of the user up to the first separating - comma. then it checks the $NAME environment variable - and finally runs `whoami` and `hostname` to build an - email address. The final form is > - Full Name -< -g:changelog_new_date_format - The format to use when creating a new date-entry. - The following table describes special tokens in the - string: - %% insert a single '%' character - %d insert the date from above - %u insert the user from above - %c where to position cursor when done - The default is "%d %u\n\n\t* %c\n\n", which produces - something like (| is where cursor will be, unless at - the start of the line where it denotes the beginning - of the line) > - |2003-01-14 Full Name - | - | * | -< -g:changelog_new_entry_format - The format used when creating a new entry. - The following table describes special tokens in the - string: - %c where to position cursor when done - The default is "\t*%c", which produces something - similar to > - | * | -< -g:changelog_date_entry_search - The search pattern to use when searching for a - date-entry. - The same tokens that can be used for - g:changelog_new_date_format can be used here as well. - The default is '^\s*%d\_s*%u' which finds lines - matching the form > - |2003-01-14 Full Name -< and some similar formats. - -g:changelog_date_end_entry_search - The search pattern to use when searching for the end - of a date-entry. - The same tokens that can be used for - g:changelog_new_date_format can be used here as well. - The default is '^\s*$' which finds lines that contain - only whitespace or are completely empty. - -b:changelog_name *b:changelog_name* - Name of the ChangeLog file to look for. - The default is 'ChangeLog'. - -b:changelog_path - Path of the ChangeLog to use for the current buffer. - The default is empty, thus looking for a file named - |b:changelog_name| in the same directory as the - current buffer. If not found, the parent directory of - the current buffer is searched. This continues - recursively until a file is found or there are no more - parent directories to search. - -b:changelog_entry_prefix - Name of a function to call to generate a prefix to a - new entry. This function takes no arguments and - should return a string containing the prefix. - Returning an empty prefix is fine. - The default generates the shortest path between the - ChangeLog's pathname and the current buffers pathname. - In the future, it will also be possible to use other - variable contexts for this variable, for example, g:. - -The Changelog entries are inserted where they add the least amount of text. -After figuring out the current date and user, the file is searched for an -entry beginning with the current date and user and if found adds another item -under it. If not found, a new entry and item is prepended to the beginning of -the Changelog. - - -FORTRAN *ft-fortran-plugin* - -Options: -'expandtab' is switched on to avoid tabs as required by the Fortran - standards unless the user has set fortran_have_tabs in .vimrc. -'textwidth' is set to 72 for fixed source format as required by the - Fortran standards and to 80 for free source format. -'formatoptions' is set to break code and comment lines and to preserve long - lines. You can format comments with |gq|. -For further discussion of fortran_have_tabs and the method used for the -detection of source format see |ft-fortran-syntax|. - - -GIT COMMIT *ft-gitcommit-plugin* - -One command, :DiffGitCached, is provided to show a diff of the current commit -in the preview window. It is equivalent to calling "git diff --cached" plus -any arguments given to the command. - - -MAIL *ft-mail-plugin* - -Options: -'modeline' is switched off to avoid the danger of trojan horses, and to - avoid that a Subject line with "Vim:" in it will cause an - error message. -'textwidth' is set to 72. This is often recommended for e-mail. -'formatoptions' is set to break text lines and to repeat the comment leader - in new lines, so that a leading ">" for quotes is repeated. - You can also format quoted text with |gq|. - -Local mappings: -q or \\MailQuote - Quotes the text selected in Visual mode, or from the cursor position - to the end of the file in Normal mode. This means "> " is inserted in - each line. - -MAN *ft-man-plugin* *:Man* - -Displays a manual page in a nice way. Also see the user manual -|find-manpage|. - -To start using the ":Man" command before any manual page was loaded, source -this script from your startup vimrc file: > - - runtime ftplugin/man.vim - -Options: -'iskeyword' the '.' character is added to be able to use CTRL-] on the - manual page name. - -Commands: -Man {name} Display the manual page for {name} in a window. -Man {number} {name} - Display the manual page for {name} in a section {number}. - -Global mapping: -K Displays the manual page for the word under the cursor. - -Local mappings: -CTRL-] Jump to the manual page for the word under the cursor. -CTRL-T Jump back to the previous manual page. - - -PDF *ft-pdf-plugin* - -Two maps, and , are provided to simulate a tag stack for navigating -the PDF. The following are treated as tags: - -- The byte offset after "startxref" to the xref table -- The byte offset after the /Prev key in the trailer to an earlier xref table -- A line of the form "0123456789 00000 n" in the xref table -- An object reference like "1 0 R" anywhere in the PDF - -These maps can be disabled with > - :let g:no_pdf_maps = 1 -< - -RPM SPEC *ft-spec-plugin* - -Since the text for this plugin is rather long it has been put in a separate -file: |pi_spec.txt|. - - -SQL *ft-sql* - -Since the text for this plugin is rather long it has been put in a separate -file: |ft_sql.txt|. - - -TEX *ft-tex-plugin* - -If the first line of a *.tex file has the form > - %& -then this determined the file type: plaintex (for plain TeX), context (for -ConTeXt), or tex (for LaTeX). Otherwise, the file is searched for keywords to -choose context or tex. If no keywords are found, it defaults to plaintex. -You can change the default by defining the variable g:tex_flavor to the format -(not the file type) you use most. Use one of these: > - let g:tex_flavor = "plain" - let g:tex_flavor = "context" - let g:tex_flavor = "latex" -Currently no other formats are recognized. - - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/fold.txt b/share/vim/vim72/doc/fold.txt deleted file mode 100644 index 7c117a8fdc..0000000000 --- a/share/vim/vim72/doc/fold.txt +++ /dev/null @@ -1,583 +0,0 @@ -*fold.txt* For Vim version 7.2. Last change: 2007 May 11 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Folding *Folding* *folding* - -You can find an introduction on folding in chapter 28 of the user manual. -|usr_28.txt| - -1. Fold methods |fold-methods| -2. Fold commands |fold-commands| -3. Fold options |fold-options| -4. Behavior of folds |fold-behavior| - -{Vi has no Folding} -{not available when compiled without the +folding feature} - -============================================================================== -1. Fold methods *fold-methods* - -The folding method can be set with the 'foldmethod' option. - -When setting 'foldmethod' to a value other than "manual", all folds are -deleted and new ones created. Switching to the "manual" method doesn't remove -the existing folds. This can be used to first define the folds automatically -and then change them manually. - -There are six methods to select folds: - manual manually define folds - indent more indent means a higher fold level - expr specify an expression to define folds - syntax folds defined by syntax highlighting - diff folds for unchanged text - marker folds defined by markers in the text - - -MANUAL *fold-manual* - -Use commands to manually define the fold regions. This can also be used by a -script that parses text to find folds. - -The level of a fold is only defined by its nesting. To increase the fold -level of a fold for a range of lines, define a fold inside it that has the -same lines. - -The manual folds are lost when you abandon the file. To save the folds use -the |:mkview| command. The view can be restored later with |:loadview|. - - -INDENT *fold-indent* - -The folds are automatically defined by the indent of the lines. - -The foldlevel is computed from the indent of the line, divided by the -'shiftwidth' (rounded down). A sequence of lines with the same or higher fold -level form a fold, with the lines with a higher level forming a nested fold. - -The nesting of folds is limited with 'foldnestmax'. - -Some lines are ignored and get the fold level of the line above or below it, -whatever is the lowest. These are empty or white lines and lines starting -with a character in 'foldignore'. White space is skipped before checking for -characters in 'foldignore'. For C use "#" to ignore preprocessor lines. - -When you want to ignore lines in another way, use the 'expr' method. The -|indent()| function can be used in 'foldexpr' to get the indent of a line. - - -EXPR *fold-expr* - -The folds are automatically defined by their foldlevel, like with the "indent" -method. The value of the 'foldexpr' option is evaluated to get the foldlevel -of a line. Examples: -This will create a fold for all consecutive lines that start with a tab: > - :set foldexpr=getline(v:lnum)[0]==\"\\t\" -This will call a function to compute the fold level: > - :set foldexpr=MyFoldLevel(v:lnum) -This will make a fold out of paragraphs separated by blank lines: > - :set foldexpr=getline(v:lnum)=~'^\\s*$'&&getline(v:lnum+1)=~'\\S'?'<1':1 -this does the same: > - :set foldexpr=getline(v:lnum-1)=~'^\\s*$'&&getline(v:lnum)=~'\\S'?'>1':1 - -Note that backslashes must be used to escape characters that ":set" handles -differently (space, backslash, double quote, etc., see |option-backslash|). - -These are the conditions with which the expression is evaluated: -- The current buffer and window are set for the line. -- The variable "v:lnum" is set to the line number. -- The result is used for the fold level in this way: - value meaning ~ - 0 the line is not in a fold - 1, 2, .. the line is in a fold with this level - -1 the fold level is undefined, use the fold level of a - line before or after this line, whichever is the - lowest. - "=" use fold level from the previous line - "a1", "a2", .. add one, two, .. to the fold level of the previous - line - "s1", "s2", .. subtract one, two, .. from the fold level of the - previous line - "<1", "<2", .. a fold with this level ends at this line - ">1", ">2", .. a fold with this level starts at this line - -It is not required to mark the start (end) of a fold with ">1" ("<1"), a fold -will also start (end) when the fold level is higher (lower) than the fold -level of the previous line. - -There must be no side effects from the expression. The text in the buffer, -cursor position, the search patterns, options etc. must not be changed. -You can change and restore them if you are careful. - -If there is some error in the expression, or the resulting value isn't -recognized, there is no error message and the fold level will be zero. -For debugging the 'debug' option can be set to "msg", the error messages will -be visible then. - -Note: Since the expression has to be evaluated for every line, this fold -method can be very slow! - -Try to avoid the "=", "a" and "s" return values, since Vim often has to search -backwards for a line for which the fold level is defined. This can be slow. - -|foldlevel()| can be useful to compute a fold level relative to a previous -fold level. But note that foldlevel() may return -1 if the level is not known -yet. And it returns the level at the start of the line, while a fold might -end in that line. - - -SYNTAX *fold-syntax* - -A fold is defined by syntax items that have the "fold" argument. |:syn-fold| - -The fold level is defined by nesting folds. The nesting of folds is limited -with 'foldnestmax'. - -Be careful to specify proper syntax syncing. If this is not done right, folds -may differ from the displayed highlighting. This is especially relevant when -using patterns that match more than one line. In case of doubt, try using -brute-force syncing: > - :syn sync fromstart - - -DIFF *fold-diff* - -The folds are automatically defined for text that is not part of a change or -close to a change. - -This method only works properly when the 'diff' option is set for the current -window and changes are being displayed. Otherwise the whole buffer will be -one big fold. - -The 'diffopt' option can be used to specify the context. That is, the number -of lines between the fold and a change that are not included in the fold. For -example, to use a context of 8 lines: > - :set diffopt=filler,context:8 -The default context is six lines. - -When 'scrollbind' is also set, Vim will attempt to keep the same folds open in -other diff windows, so that the same text is visible. - - -MARKER *fold-marker* - -Markers in the text tell where folds start and end. This allows you to -precisely specify the folds. This will allow deleting and putting a fold, -without the risk of including the wrong lines. The 'foldtext' option is -normally set such that the text before the marker shows up in the folded line. -This makes it possible to give a name to the fold. - -Markers can have a level included, or can use matching pairs. Including a -level is easier, you don't have to add end markers and avoid problems with -non-matching marker pairs. Example: > - /* global variables {{{1 */ - int varA, varB; - - /* functions {{{1 */ - /* funcA() {{{2 */ - void funcA() {} - - /* funcB() {{{2 */ - void funcB() {} - -A fold starts at a "{{{" marker. The following number specifies the fold -level. What happens depends on the difference between the current fold level -and the level given by the marker: -1. If a marker with the same fold level is encountered, the previous fold - ends and another fold with the same level starts. -2. If a marker with a higher fold level is found, a nested fold is started. -3. if a marker with a lower fold level is found, all folds up to and including - this level end and a fold with the specified level starts. - -The number indicates the fold level. A zero cannot be used (a marker with -level zero is ignored). You can use "}}}" with a digit to indicate the level -of the fold that ends. The fold level of the following line will be one less -than the indicated level. Note that Vim doesn't look back to the level of the -matching marker (that would take too much time). Example: > - - {{{1 - fold level here is 1 - {{{3 - fold level here is 3 - }}}3 - fold level here is 2 - -You can also use matching pairs of "{{{" and "}}}" markers to define folds. -Each "{{{" increases the fold level by one, each "}}}" decreases the fold -level by one. Be careful to keep the markers matching! Example: > - - {{{ - fold level here is 1 - {{{ - fold level here is 2 - }}} - fold level here is 1 - -You can mix using markers with a number and without a number. A useful way of -doing this is to use numbered markers for large folds, and unnumbered markers -locally in a function. For example use level one folds for the sections of -your file like "structure definitions", "local variables" and "functions". -Use level 2 markers for each definition and function, Use unnumbered markers -inside functions. When you make changes in a function to split up folds, you -don't have to renumber the markers. - -The markers can be set with the 'foldmarker' option. It is recommended to -keep this at the default value of "{{{,}}}", so that files can be exchanged -between Vim users. Only change it when it is required for the file (e.g., it -contains markers from another folding editor, or the default markers cause -trouble for the language of the file). - - *fold-create-marker* -"zf" can be used to create a fold defined by markers. Vim will insert the -markers for you. Vim will append the start and end marker, as specified with -'foldmarker'. The markers are appended to the end of the line. -'commentstring' is used if it isn't empty. -This does not work properly when: -- The line already contains a marker with a level number. Vim then doesn't - know what to do. -- Folds nearby use a level number in their marker which gets in the way. -- The line is inside a comment, 'commentstring' isn't empty and nested - comments don't work. For example with C: adding /* {{{ */ inside a comment - will truncate the existing comment. Either put the marker before or after - the comment, or add the marker manually. -Generally it's not a good idea to let Vim create markers when you already have -markers with a level number. - - *fold-delete-marker* -"zd" can be used to delete a fold defined by markers. Vim will delete the -markers for you. Vim will search for the start and end markers, as specified -with 'foldmarker', at the start and end of the fold. When the text around the -marker matches with 'commentstring', that text is deleted as well. -This does not work properly when: -- A line contains more than one marker and one of them specifies a level. - Only the first one is removed, without checking if this will have the - desired effect of deleting the fold. -- The marker contains a level number and is used to start or end several folds - at the same time. - -============================================================================== -2. Fold commands *fold-commands* *E490* - -All folding commands start with "z". Hint: the "z" looks like a folded piece -of paper, if you look at it from the side. - - -CREATING AND DELETING FOLDS ~ - *zf* *E350* -zf{motion} or -{Visual}zf Operator to create a fold. - This only works when 'foldmethod' is "manual" or "marker". - The new fold will be closed for the "manual" method. - 'foldenable' will be set. - Also see |fold-create-marker|. - - *zF* -zF Create a fold for N lines. Works like "zf". - -:{range}fo[ld] *:fold* *:fo* - Create a fold for the lines in {range}. Works like "zf". - - *zd* *E351* -zd Delete one fold at the cursor. When the cursor is on a folded - line, that fold is deleted. Nested folds are moved one level - up. In Visual mode all folds (partially) in the selected area - are deleted. Careful: This easily deletes more folds than you - expect and there is no undo. - This only works when 'foldmethod' is "manual" or "marker". - Also see |fold-delete-marker|. - - *zD* -zD Delete folds recursively at the cursor. In Visual mode all - folds (partially) in the selected area and all nested folds in - them are deleted. - This only works when 'foldmethod' is "manual" or "marker". - Also see |fold-delete-marker|. - - *zE* *E352* -zE Eliminate all folds in the window. - This only works when 'foldmethod' is "manual" or "marker". - Also see |fold-delete-marker|. - - -OPENING AND CLOSING FOLDS ~ - -A fold smaller than 'foldminlines' will always be displayed like it was open. -Therefore the commands below may work differently on small folds. - - *zo* -zo Open one fold under the cursor. When a count is given, that - many folds deep will be opened. In Visual mode one level of - folds is opened for all lines in the selected area. - - *zO* -zO Open all folds under the cursor recursively. Folds that don't - contain the cursor line are unchanged. - In Visual mode it opens all folds that are in the selected - area, also those that are only partly selected. - - *zc* -zc Close one fold under the cursor. When a count is given, that - many folds deep are closed. In Visual mode one level of folds - is closed for all lines in the selected area. - 'foldenable' will be set. - - *zC* -zC Close all folds under the cursor recursively. Folds that - don't contain the cursor line are unchanged. - In Visual mode it closes all folds that are in the selected - area, also those that are only partly selected. - 'foldenable' will be set. - - *za* -za When on a closed fold: open it. When folds are nested, you - may have to use "za" several times. When a count is given, - that many closed folds are opened. - When on an open fold: close it and set 'foldenable'. This - will only close one level, since using "za" again will open - the fold. When a count is given that many folds will be - closed (that's not the same as repeating "za" that many - times). - - *zA* -zA When on a closed fold: open it recursively. - When on an open fold: close it recursively and set - 'foldenable'. - - *zv* -zv View cursor line: Open just enough folds to make the line in - which the cursor is located not folded. - - *zx* -zx Update folds: Undo manually opened and closed folds: re-apply - 'foldlevel', then do "zv": View cursor line. - - *zX* -zX Undo manually opened and closed folds: re-apply 'foldlevel'. - - *zm* -zm Fold more: Subtract one from 'foldlevel'. If 'foldlevel' was - already zero nothing happens. - 'foldenable' will be set. - - *zM* -zM Close all folds: set 'foldlevel' to 0. - 'foldenable' will be set. - - *zr* -zr Reduce folding: Add one to 'foldlevel'. - - *zR* -zR Open all folds. This sets 'foldlevel' to highest fold level. - - *:foldo* *:foldopen* -:{range}foldo[pen][!] - Open folds in {range}. When [!] is added all folds are - opened. Useful to see all the text in {range}. Without [!] - one level of folds is opened. - - *:foldc* *:foldclose* -:{range}foldc[lose][!] - Close folds in {range}. When [!] is added all folds are - closed. Useful to hide all the text in {range}. Without [!] - one level of folds is closed. - - *zn* -zn Fold none: reset 'foldenable'. All folds will be open. - - *zN* -zN Fold normal: set 'foldenable'. All folds will be as they - were before. - - *zi* -zi Invert 'foldenable'. - - -MOVING OVER FOLDS ~ - *[z* -[z Move to the start of the current open fold. If already at the - start, move to the start of the fold that contains it. If - there is no containing fold, the command fails. - When a count is used, repeats the command N times. - - *]z* -]z Move to the end of the current open fold. If already at the - end, move to the end of the fold that contains it. If there - is no containing fold, the command fails. - When a count is used, repeats the command N times. - - *zj* -zj Move downwards to the start of the next fold. A closed fold - is counted as one fold. - When a count is used, repeats the command N times. - This command can be used after an |operator|. - - *zk* -zk Move upwards to the end of the previous fold. A closed fold - is counted as one fold. - When a count is used, repeats the command N times. - This command can be used after an |operator|. - - -EXECUTING COMMANDS ON FOLDS ~ - -:[range]foldd[oopen] {cmd} *:foldd* *:folddoopen* - Execute {cmd} on all lines that are not in a closed fold. - When [range] is given, only these lines are used. - Each time {cmd} is executed the cursor is positioned on the - line it is executed for. - This works like the ":global" command: First all lines that - are not in a closed fold are marked. Then the {cmd} is - executed for all marked lines. Thus when {cmd} changes the - folds, this has no influence on where it is executed (except - when lines are deleted, of course). - Example: > - :folddoopen s/end/loop_end/ge -< Note the use of the "e" flag to avoid getting an error message - where "end" doesn't match. - -:[range]folddoc[losed] {cmd} *:folddoc* *:folddoclosed* - Execute {cmd} on all lines that are in a closed fold. - Otherwise like ":folddoopen". - -============================================================================== -3. Fold options *fold-options* - -COLORS *fold-colors* - -The colors of a closed fold are set with the Folded group |hl-Folded|. The -colors of the fold column are set with the FoldColumn group |hl-FoldColumn|. -Example to set the colors: > - - :highlight Folded guibg=grey guifg=blue - :highlight FoldColumn guibg=darkgrey guifg=white - - -FOLDLEVEL *fold-foldlevel* - -'foldlevel' is a number option: The higher the more folded regions are open. -When 'foldlevel' is 0, all folds are closed. -When 'foldlevel' is positive, some folds are closed. -When 'foldlevel' is very high, all folds are open. -'foldlevel' is applied when it is changed. After that manually folds can be -opened and closed. -When increased, folds above the new level are opened. No manually opened -folds will be closed. -When decreased, folds above the new level are closed. No manually closed -folds will be opened. - - -FOLDTEXT *fold-foldtext* - -'foldtext' is a string option that specifies an expression. This expression -is evaluated to obtain the text displayed for a closed fold. Example: > - - :set foldtext=v:folddashes.substitute(getline(v:foldstart),'/\\*\\\|\\*/\\\|{{{\\d\\=','','g') - -This shows the first line of the fold, with "/*", "*/" and "{{{" removed. -Note the use of backslashes to avoid some characters to be interpreted by the -":set" command. It's simpler to define a function and call that: > - - :set foldtext=MyFoldText() - :function MyFoldText() - : let line = getline(v:foldstart) - : let sub = substitute(line, '/\*\|\*/\|{{{\d\=', '', 'g') - : return v:folddashes . sub - :endfunction - -Evaluating 'foldtext' is done in the |sandbox|. The current window is set to -the window that displays the line. Errors are ignored. - -The default value is |foldtext()|. This returns a reasonable text for most -types of folding. If you don't like it, you can specify your own 'foldtext' -expression. It can use these special Vim variables: - v:foldstart line number of first line in the fold - v:foldend line number of last line in the fold - v:folddashes a string that contains dashes to represent the - foldlevel. - v:foldlevel the foldlevel of the fold - -In the result a TAB is replaced with a space and unprintable characters are -made into printable characters. - -The resulting line is truncated to fit in the window, it never wraps. -When there is room after the text, it is filled with the character specified -by 'fillchars'. - -Note that backslashes need to be used for characters that the ":set" command -handles differently: Space, backslash and double-quote. |option-backslash| - - -FOLDCOLUMN *fold-foldcolumn* - -'foldcolumn' is a number, which sets the width for a column on the side of the -window to indicate folds. When it is zero, there is no foldcolumn. A normal -value is 4 or 5. The minimal useful value is 2, although 1 still provides -some information. The maximum is 12. - -An open fold is indicated with a column that has a '-' at the top and '|' -characters below it. This column stops where the open fold stops. When folds -nest, the nested fold is one character right of the fold it's contained in. - -A closed fold is indicated with a '+'. - -Where the fold column is too narrow to display all nested folds, digits are -shown to indicate the nesting level. - -The mouse can also be used to open and close folds by clicking in the -fold column: -- Click on a '+' to open the closed fold at this row. -- Click on any other non-blank character to close the open fold at this row. - - -OTHER OPTIONS - -'foldenable' 'fen': Open all folds while not set. -'foldexpr' 'fde': Expression used for "expr" folding. -'foldignore' 'fdi': Characters used for "indent" folding. -'foldmarker' 'fmr': Defined markers used for "marker" folding. -'foldmethod' 'fdm': Name of the current folding method. -'foldminlines' 'fml': Minimum number of screen lines for a fold to be - displayed closed. -'foldnestmax' 'fdn': Maximum nesting for "indent" and "syntax" folding. -'foldopen' 'fdo': Which kinds of commands open closed folds. -'foldclose' 'fcl': When the folds not under the cursor are closed. - -============================================================================== -4. Behavior of folds *fold-behavior* - -When moving the cursor upwards or downwards and when scrolling, the cursor -will move to the first line of a sequence of folded lines. When the cursor is -already on a folded line, it moves to the next unfolded line or the next -closed fold. - -While the cursor is on folded lines, the cursor is always displayed in the -first column. The ruler does show the actual cursor position, but since the -line is folded, it cannot be displayed there. - -Many movement commands handle a sequence of folded lines like an empty line. -For example, the "w" command stops once in the first column. - -When in Insert mode, the cursor line is never folded. That allows you to see -what you type! - -When using an operator, a closed fold is included as a whole. Thus "dl" -deletes the whole closed fold under the cursor. - -For Ex commands the range is adjusted to always start at the first line of a -closed fold and end at the last line of a closed fold. Thus this command: > - :s/foo/bar/g -when used with the cursor on a closed fold, will replace "foo" with "bar" in -all lines of the fold. -This does not happen for |:folddoopen| and |:folddoclosed|. - -When editing a buffer that has been edited before, the last used folding -settings are used again. For manual folding the defined folds are restored. -For all folding methods the manually opened and closed folds are restored. -If this buffer has been edited in this window, the values from back then are -used. Otherwise the values from the window where the buffer was edited last -are used. - -============================================================================== - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/ft_ada.txt b/share/vim/vim72/doc/ft_ada.txt deleted file mode 100644 index 6f328e625f..0000000000 --- a/share/vim/vim72/doc/ft_ada.txt +++ /dev/null @@ -1,515 +0,0 @@ -*ft_ada.txt* For Vim version 7.2. Last change: 2008 Jun 21 - - - ADA FILE TYPE PLUG-INS REFERENCE MANUAL~ - -ADA *ada.vim* - -1. Syntax Highlighting |ft-ada-syntax| -2. Plug-in |ft-ada-plugin| -3. Omni Completion |ft-ada-omni| - 3.1 Omni Completion with "gnat xref" |gnat-xref| - 3.2 Omni Completion with "ctags" |ada-ctags| -4. Compiler Support |ada-compiler| - 4.1 GNAT |compiler-gnat| - 4.1 Dec Ada |compiler-decada| -5. References |ada-reference| - 5.1 Options |ft-ada-options| - 5.2 Functions |ft-ada-functions| - 5.3 Commands |ft-ada-commands| - 5.4 Variables |ft-ada-variables| - 5.5 Constants |ft-ada-constants| -8. Extra Plug-ins |ada-extra-plugins| - -============================================================================== -1. Syntax Highlighting ~ - *ft-ada-syntax* - -This mode is designed for the 2005 edition of Ada ("Ada 2005"), which includes -support for objected-programming, protected types, and so on. It handles code -written for the original Ada language ("Ada83", "Ada87", "Ada95") as well, -though code which uses Ada 2005-only keywords will be wrongly colored (such -code should be fixed anyway). For more information about Ada, see -http://www.adapower.com. - -The Ada mode handles a number of situations cleanly. - -For example, it knows that the "-" in "-5" is a number, but the same character -in "A-5" is an operator. Normally, a "with" or "use" clause referencing -another compilation unit is coloured the same way as C's "#include" is coloured. -If you have "Conditional" or "Repeat" groups coloured differently, then "end -if" and "end loop" will be coloured as part of those respective groups. - -You can set these to different colours using vim's "highlight" command (e.g., -to change how loops are displayed, enter the command ":hi Repeat" followed by -the colour specification; on simple terminals the colour specification -ctermfg=White often shows well). - -There are several options you can select in this Ada mode. See|ft-ada-options| -for a complete list. - -To enable them, assign a value to the option. For example, to turn one on: - > - > let g:ada_standard_types = 1 -> -To disable them use ":unlet". Example: -> - > unlet g:ada_standard_types - -You can just use ":" and type these into the command line to set these -temporarily before loading an Ada file. You can make these option settings -permanent by adding the "let" command(s), without a colon, to your "~/.vimrc" -file. - -Even on a slow (90Mhz) PC this mode works quickly, but if you find the -performance unacceptable, turn on |g:ada_withuse_ordinary|. - -Syntax folding instructions (|fold-syntax|) are added when |g:ada_folding| is -set. - -============================================================================== -2. File type Plug-in ~ - *ft-ada-indent* *ft-ada-plugin* - -The Ada plug-in provides support for: - - - auto indenting (|indent.txt|) - - insert completion (|i_CTRL-N|) - - user completion (|i_CTRL-X_CTRL-U|) - - tag searches (|tagsrch.txt|) - - Quick Fix (|quickfix.txt|) - - backspace handling (|'backspace'|) - - comment handling (|'comments'|, |'commentstring'|) - -The plug-in only activates the features of the Ada mode whenever an Ada -files is opened and add adds Ada related entries to the main and pop-up menu. - -============================================================================== -3. Omni Completion ~ - *ft-ada-omni* - -The Ada omni-completions (|i_CTRL-X_CTRL-O|) uses tags database created either -by "gnat xref -v" or the "exuberant Ctags (http://ctags.sourceforge.net). The -complete function will automatically detect which tool was used to create the -tags file. - ------------------------------------------------------------------------------- -3.1 Omni Completion with "gnat xref" ~ - *gnat-xref* - -GNAT XREF uses the compiler internal information (ali-files) to produce the -tags file. This has the advantage to be 100% correct and the option of deep -nested analysis. However the code must compile, the generator is quite -slow and the created tags file contains only the basic Ctags information for -each entry - not enough for some of the more advanced Vim code browser -plug-ins. - -NOTE: "gnat xref -v" is very tricky to use as it has almost no diagnostic - output - If nothing is printed then usually the parameters are wrong. - Here some important tips: - -1) You need to compile your code first and use the "-aO" option to point to - your .ali files. -2) "gnat xref -v ../Include/adacl.ads" won't work - use the "gnat xref -v - -aI../Include adacl.ads" instead. -3) "gnat xref -v -aI../Include *.ad?" won't work - use "cd ../Include" and - then "gnat xref -v *.ad?" -4) Project manager support is completely broken - don't even try "gnat xref - -Padacl.gpr". -5) VIM is faster when the tags file is sorted - use "sort --unique - --ignore-case --output=tags tags" . -6) Remember to insert "!_TAG_FILE_SORTED 2 %sort ui" as first line to mark - the file assorted. - ------------------------------------------------------------------------------- -3.2 Omni Completion with "ctags"~ - *ada-ctags* - -Exuberant Ctags uses its own multi-language code parser. The parser is quite -fast, produces a lot of extra information (hence the name "Exuberant Ctags") -and can run on files which currently do not compile. - -There are also lots of other Vim-tools which use exuberant Ctags. - -You will need to install a version of the Exuberant Ctags which has Ada -support patched in. Such a version is available from the GNU Ada Project -(http://gnuada.sourceforge.net). - -The Ada parser for Exuberant Ctags is fairly new - don't expect complete -support yet. - -============================================================================== -4. Compiler Support ~ - *ada-compiler* - -The Ada mode supports more then one Ada compiler and will automatically load the -compiler set in|g:ada_default_compiler|whenever an Ada source is opened. The -provided compiler plug-ins are split into the actual compiler plug-in and a -collection of support functions and variables. This allows the easy -development of specialized compiler plug-ins fine tuned to your development -environment. - ------------------------------------------------------------------------------- -4.1 GNAT ~ - *compiler-gnat* - -GNAT is the only free (beer and speech) Ada compiler available. There are -several version available which differentiate in the licence terms used. - -The GNAT compiler plug-in will perform a compile on pressing and then -immediately shows the result. You can set the project file to be used by -setting: - > - > call g:gnat.Set_Project_File ('my_project.gpr') - -Setting a project file will also create a Vim session (|views-sessions|) so - -like with the GPS - opened files, window positions etc. will remembered -separately for all projects. - - *gnat_members* -GNAT OBJECT ~ - - *g:gnat.Make()* -g:gnat.Make() - Calls|g:gnat.Make_Command|and displays the result inside a - |quickfix| window. - - *g:gnat.Pretty()* -g:gnat.Pretty() - Calls|g:gnat.Pretty_Command| - - *g:gnat.Find()* -g:gnat.Find() - Calls|g:gnat.Find_Command| - - *g:gnat.Tags()* -g:gnat.Tags() - Calls|g:gnat.Tags_Command| - - *g:gnat.Set_Project_File()* -g:gnat.Set_Project_File([{file}]) - Set gnat project file and load associated session. An open - project will be closed and the session written. If called - without file name the file selector opens for selection of a - project file. If called with an empty string then the project - and associated session are closed. - - *g:gnat.Project_File* -g:gnat.Project_File string - Current project file. - - *g:gnat.Make_Command* -g:gnat.Make_Command string - External command used for|g:gnat.Make()| (|'makeprg'|). - - *g:gnat.Pretty_Program* -g:gnat.Pretty_Program string - External command used for|g:gnat.Pretty()| - - *g:gnat.Find_Program* -g:gnat.Find_Program string - External command used for|g:gnat.Find()| - - *g:gnat.Tags_Command* -g:gnat.Tags_Command string - External command used for|g:gnat.Tags()| - - *g:gnat.Error_Format* -g:gnat.Error_Format string - Error format (|'errorformat'|) - ------------------------------------------------------------------------------- -4.2 Dec Ada ~ - *compiler-hpada* *compiler-decada* - *compiler-vaxada* *compiler-compaqada* - -Dec Ada (also known by - in chronological order - VAX Ada, Dec Ada, Compaq Ada -and HP Ada) is a fairly dated Ada 83 compiler. Support is basic: will -compile the current unit. - -The Dec Ada compiler expects the package name and not the file name to be -passed a parameter. The compiler plug-in supports the usual file name -convention to convert the file into a unit name. For separates both '-' and -'__' are allowed. - - *decada_members* -DEC ADA OBJECT ~ - - *g:decada.Make()* -g:decada.Make() function - Calls|g:decada.Make_Command|and displays the result inside a - |quickfix| window. - - *g:decada.Unit_Name()* -g:decada.Unit_Name() function - Get the Unit name for the current file. - - *g:decada.Make_Command* -g:decada.Make_Command string - External command used for|g:decadat.Make()| (|'makeprg'|). - - *g:decada.Error_Format* -g:decada.Error_Format| string - Error format (|'errorformat'|). - -============================================================================== -5. References ~ - *ada-reference* - ------------------------------------------------------------------------------- -5.1 Options ~ - *ft-ada-options* - - *g:ada_standard_types* -g:ada_standard_types bool (true when exists) - Highlight types in package Standard (e.g., "Float") - - *g:ada_space_errors* - *g:ada_no_trail_space_error* - *g:ada_no_tab_space_error* - *g:ada_all_tab_usage* -g:ada_space_errors bool (true when exists) - Highlight extraneous errors in spaces ... - g:ada_no_trail_space_error - - but ignore trailing spaces at the end of a line - g:ada_no_tab_space_error - - but ignore tabs after spaces - g:ada_all_tab_usage - - highlight all tab use - - *g:ada_line_errors* -g:ada_line_errors bool (true when exists) - Highlight lines which are to long. Note: This highlighting - option is quite CPU intensive. - - *g:ada_rainbow_color* -g:ada_rainbow_color bool (true when exists) - Use rainbow colours for '(' and ')'. You need the - rainbow_parenthesis for this to work - - *g:ada_folding* -g:ada_folding set ('sigpft') - Use folding for Ada sources. - 's': activate syntax folding on load - 'p': fold packages - 'f': fold functions and procedures - 't': fold types - 'c': fold conditionals - 'g': activate gnat pretty print folding on load - 'i': lone 'is' folded with line above - 'b': lone 'begin' folded with line above - 'p': lone 'private' folded with line above - 'x': lone 'exception' folded with line above - 'i': activate indent folding on load - - Note: Syntax folding is in an early (unusable) stage and - indent or gnat pretty folding is suggested. - - For gnat pretty folding to work the following settings are - suggested: -cl3 -M79 -c2 -c3 -c4 -A1 -A2 -A3 -A4 -A5 - - For indent folding to work the following settings are - suggested: shiftwidth=3 softtabstop=3 - - *g:ada_abbrev* -g:ada_abbrev bool (true when exists) - Add some abbreviations. This feature more or less superseded - by the various completion methods. - - *g:ada_withuse_ordinary* -g:ada_withuse_ordinary bool (true when exists) - Show "with" and "use" as ordinary keywords (when used to - reference other compilation units they're normally highlighted - specially). - - *g:ada_begin_preproc* -g:ada_begin_preproc bool (true when exists) - Show all begin-like keywords using the colouring of C - preprocessor commands. - - *g:ada_omni_with_keywords* -g:ada_omni_with_keywords - Add Keywords, Pragmas, Attributes to omni-completions - (|compl-omni|). Note: You can always complete then with user - completion (|i_CTRL-X_CTRL-U|). - - *g:ada_extended_tagging* -g:ada_extended_tagging enum ('jump', 'list') - use extended tagging, two options are available - 'jump': use tjump to jump. - 'list': add tags quick fix list. - Normal tagging does not support function or operator - overloading as these features are not available in C and - tagging was originally developed for C. - - *g:ada_extended_completion* -g:ada_extended_completion - Uses extended completion for and completions - (|i_CTRL-N|). In this mode the '.' is used as part of the - identifier so that 'Object.Method' or 'Package.Procedure' are - completed together. - - *g:ada_gnat_extensions* -g:ada_gnat_extensions bool (true when exists) - Support GNAT extensions. - - *g:ada_with_gnat_project_files* -g:ada_with_gnat_project_files bool (true when exists) - Add gnat project file keywords and Attributes. - - *g:ada_default_compiler* -g:ada_default_compiler string - set default compiler. Currently supported is 'gnat' and - 'decada'. - -An "exists" type is a boolean is considered true when the variable is defined -and false when the variable is undefined. The value which the variable is -set makes no difference. - ------------------------------------------------------------------------------- -5.3 Commands ~ - *ft-ada-commands* - -:AdaRainbow *:AdaRainbow* - Toggles rainbow colour (|g:ada_rainbow_color|) mode for - '(' and ')' - -:AdaLines *:AdaLines* - Toggles line error (|g:ada_line_errors|) display - -:AdaSpaces *:AdaSpaces* - Toggles space error (|g:ada_space_errors|) display. - -:AdaTagDir *:AdaTagDir* - Creates tags file for the directory of the current file. - -:AdaTagFile *:AdaTagFile* - Creates tags file for the current file. - -:AdaTypes *:AdaTypes* - Toggles standard types (|g:ada_standard_types|) colour. - -:GnatFind *:GnatFind* - Calls |g:gnat.Find()| - -:GnatPretty *:GnatPretty* - Calls |g:gnat.Pretty()| - -:GnatTags *:GnatTags* - Calls |g:gnat.Tags()| - ------------------------------------------------------------------------------- -5.3 Variables ~ - *ft-ada-variables* - - *g:gnat* -g:gnat object - Control object which manages GNAT compiles. The object - is created when the first Ada source code is loaded provided - that |g:ada_default_compiler|is set to 'gnat'. See|gnat_members| - for details. - - *g:decada* -g:decada object - Control object which manages Dec Ada compiles. The object - is created when the first Ada source code is loaded provided - that |g:ada_default_compiler|is set to 'decada'. See - |decada_members|for details. - ------------------------------------------------------------------------------- -5.4 Constants ~ - *ft-ada-constants* - -All constants are locked. See |:lockvar| for details. - - *g:ada#WordRegex* -g:ada#WordRegex string - Regular expression to search for Ada words - - *g:ada#DotWordRegex* -g:ada#DotWordRegex string - Regular expression to search for Ada words separated by dots. - - *g:ada#Comment* -g:ada#Comment string - Regular expression to search for Ada comments - - *g:ada#Keywords* -g:ada#Keywords list of dictionaries - List of keywords, attributes etc. pp. in the format used by - omni completion. See |complete-items| for details. - - *g:ada#Ctags_Kinds* -g:ada#Ctags_Kinds dictionary of lists - Dictionary of the various kinds of items which the Ada support - for Ctags generates. - ------------------------------------------------------------------------------- -5.2 Functions ~ - *ft-ada-functions* - -ada#Word([{line}, {col}]) *ada#Word()* - Return full name of Ada entity under the cursor (or at given - line/column), stripping white space/newlines as necessary. - -ada#List_Tag([{line}, {col}]) *ada#Listtags()* - List all occurrences of the Ada entity under the cursor (or at - given line/column) inside the quick-fix window - -ada#Jump_Tag ({ident}, {mode}) *ada#Jump_Tag()* - List all occurrences of the Ada entity under the cursor (or at - given line/column) in the tag jump list. Mode can either be - 'tjump' or 'stjump'. - -ada#Create_Tags ({option}) *ada#Create_Tags()* - Creates tag file using Ctags. The option can either be 'file' - for the current file, 'dir' for the directory of the current - file or a file name. - -gnat#Insert_Tags_Header() *gnat#Insert_Tags_Header()* - Adds the tag file header (!_TAG_) information to the current - file which are missing from the GNAT XREF output. - -ada#Switch_Syntax_Option ({option}) *ada#Switch_Syntax_Option()* - Toggles highlighting options on or off. Used for the Ada menu. - - *gnat#New()* -gnat#New () - Create a new gnat object. See |g:gnat| for details. - - -============================================================================== -8. Extra Plugins ~ - *ada-extra-plugins* - -You can optionally install the following extra plug-in. They work well with Ada -and enhance the ability of the Ada mode.: - -backup.vim - http://www.vim.org/scripts/script.php?script_id=1537 - Keeps as many backups as you like so you don't have to. - -rainbow_parenthsis.vim - http://www.vim.org/scripts/script.php?script_id=1561 - Very helpful since Ada uses only '(' and ')'. - -nerd_comments.vim - http://www.vim.org/scripts/script.php?script_id=1218 - Excellent commenting and uncommenting support for almost any - programming language. - -matchit.vim - http://www.vim.org/scripts/script.php?script_id=39 - '%' jumping for any language. The normal '%' jump only works for '{}' - style languages. The Ada mode will set the needed search patters. - -taglist.vim - http://www.vim.org/scripts/script.php?script_id=273 - Source code explorer sidebar. There is a patch for Ada available. - -The GNU Ada Project distribution (http://gnuada.sourceforge.net) of Vim -contains all of the above. - -============================================================================== -vim: textwidth=78 nowrap tabstop=8 shiftwidth=4 softtabstop=4 noexpandtab -vim: filetype=help diff --git a/share/vim/vim72/doc/ft_sql.txt b/share/vim/vim72/doc/ft_sql.txt deleted file mode 100644 index 893a9c35e8..0000000000 --- a/share/vim/vim72/doc/ft_sql.txt +++ /dev/null @@ -1,763 +0,0 @@ -*ft_sql.txt* For Vim version 7.2. Last change: Wed Apr 26 2006 3:05:33 PM - -by David Fishburn - -This is a filetype plugin to work with SQL files. - -The Structured Query Language (SQL) is a standard which specifies statements -that allow a user to interact with a relational database. Vim includes -features for navigation, indentation and syntax highlighting. - -1. Navigation |sql-navigation| - 1.1 Matchit |sql-matchit| - 1.2 Text Object Motions |sql-object-motions| - 1.3 Predefined Object Motions |sql-predefined-objects| - 1.4 Macros |sql-macros| -2. SQL Dialects |sql-dialects| - 2.1 SQLSetType |SQLSetType| - 2.2 SQL Dialect Default |sql-type-default| -3. Adding new SQL Dialects |sql-adding-dialects| -4. OMNI SQL Completion |sql-completion| - 4.1 Static mode |sql-completion-static| - 4.2 Dynamic mode |sql-completion-dynamic| - 4.3 Tutorial |sql-completion-tutorial| - 4.3.1 Complete Tables |sql-completion-tables| - 4.3.2 Complete Columns |sql-completion-columns| - 4.3.3 Complete Procedures |sql-completion-procedures| - 4.3.4 Complete Views |sql-completion-views| - 4.4 Completion Customization |sql-completion-customization| - 4.5 SQL Maps |sql-completion-maps| - 4.6 Using with other filetypes |sql-completion-filetypes| - -============================================================================== -1. Navigation *sql-navigation* - -The SQL ftplugin provides a number of options to assist with file -navigation. - - -1.1 Matchit *sql-matchit* ------------ -The matchit plugin (http://www.vim.org/scripts/script.php?script_id=39) -provides many additional features and can be customized for different -languages. The matchit plugin is configured by defining a local -buffer variable, b:match_words. Pressing the % key while on various -keywords will move the cursor to its match. For example, if the cursor -is on an "if", pressing % will cycle between the "else", "elseif" and -"end if" keywords. - -The following keywords are supported: > - if - elseif | elsif - else [if] - end if - - [while condition] loop - leave - break - continue - exit - end loop - - for - leave - break - continue - exit - end loop - - do - statements - doend - - case - when - when - default - end case - - merge - when not matched - when matched - - create[ or replace] procedure|function|event - returns - - -1.2 Text Object Motions *sql-object-motions* ------------------------ -Vim has a number of predefined keys for working with text |object-motions|. -This filetype plugin attempts to translate these keys to maps which make sense -for the SQL language. - -The following |Normal| mode and |Visual| mode maps exist (when you edit a SQL -file): > - ]] move forward to the next 'begin' - [[ move backwards to the previous 'begin' - ][ move forward to the next 'end' - [] move backwards to the previous 'end' - - -1.3 Predefined Object Motions *sql-predefined-objects* ------------------------------ -Most relational databases support various standard features, tables, indices, -triggers and stored procedures. Each vendor also has a variety of proprietary -objects. The next set of maps have been created to help move between these -objects. Depends on which database vendor you are using, the list of objects -must be configurable. The filetype plugin attempts to define many of the -standard objects, plus many additional ones. In order to make this as -flexible as possible, you can override the list of objects from within your -|vimrc| with the following: > - let g:ftplugin_sql_objects = 'function,procedure,event,table,trigger' . - \ ',schema,service,publication,database,datatype,domain' . - \ ',index,subscription,synchronization,view,variable' - -The following |Normal| mode and |Visual| mode maps have been created which use -the above list: > - ]} move forward to the next 'create ' - [{ move backward to the previous 'create ' - -Repeatedly pressing ]} will cycle through each of these create statements: > - create table t1 ( - ... - ); - - create procedure p1 - begin - ... - end; - - create index i1 on t1 (c1); - -The default setting for g:ftplugin_sql_objects is: > - let g:ftplugin_sql_objects = 'function,procedure,event,' . - \ '\\(existing\\\\|global\\s\\+temporary\\s\\+\\)\\\{,1}' . - \ 'table,trigger' . - \ ',schema,service,publication,database,datatype,domain' . - \ ',index,subscription,synchronization,view,variable' - -The above will also handle these cases: > - create table t1 ( - ... - ); - create existing table t2 ( - ... - ); - create global temporary table t3 ( - ... - ); - -By default, the ftplugin only searches for CREATE statements. You can also -override this via your |vimrc| with the following: > - let g:ftplugin_sql_statements = 'create,alter' - -The filetype plugin defines three types of comments: > - 1. -- - 2. // - 3. /* - * - */ - -The following |Normal| mode and |Visual| mode maps have been created to work -with comments: > - ]" move forward to the beginning of a comment - [" move forward to the end of a comment - - - -1.4 Macros *sql-macros* ----------- -Vim's feature to find macro definitions, |'define'|, is supported using this -regular expression: > - \c\<\(VARIABLE\|DECLARE\|IN\|OUT\|INOUT\)\> - -This addresses the following code: > - CREATE VARIABLE myVar1 INTEGER; - - CREATE PROCEDURE sp_test( - IN myVar2 INTEGER, - OUT myVar3 CHAR(30), - INOUT myVar4 NUMERIC(20,0) - ) - BEGIN - DECLARE myVar5 INTEGER; - - SELECT c1, c2, c3 - INTO myVar2, myVar3, myVar4 - FROM T1 - WHERE c4 = myVar1; - END; - -Place your cursor on "myVar1" on this line: > - WHERE c4 = myVar1; - ^ - -Press any of the following keys: > - [d - [D - [CTRL-D - - -============================================================================== -2. SQL Dialects *sql-dialects* *sql-types* - *sybase* *TSQL* *Transact-SQL* - *sqlanywhere* - *oracle* *plsql* *sqlj* - *sqlserver* - *mysql* *postgres* *psql* - *informix* - -All relational databases support SQL. There is a portion of SQL that is -portable across vendors (ex. CREATE TABLE, CREATE INDEX), but there is a -great deal of vendor specific extensions to SQL. Oracle supports the -"CREATE OR REPLACE" syntax, column defaults specified in the CREATE TABLE -statement and the procedural language (for stored procedures and triggers). - -The default Vim distribution ships with syntax highlighting based on Oracle's -PL/SQL. The default SQL indent script works for Oracle and SQL Anywhere. -The default filetype plugin works for all vendors and should remain vendor -neutral, but extendable. - -Vim currently has support for a variety of different vendors, currently this -is via syntax scripts. Unfortunately, to flip between different syntax rules -you must either create: - 1. New filetypes - 2. Custom autocmds - 3. Manual steps / commands - -The majority of people work with only one vendor's database product, it would -be nice to specify a default in your |vimrc|. - - -2.1 SQLSetType *sqlsettype* *SQLSetType* --------------- -For the people that work with many different databases, it would be nice to be -able to flip between the various vendors rules (indent, syntax) on a per -buffer basis, at any time. The ftplugin/sql.vim file defines this function: > - SQLSetType - -Executing this function without any parameters will set the indent and syntax -scripts back to their defaults, see |sql-type-default|. If you have turned -off Vi's compatibility mode, |'compatible'|, you can use the key to -complete the optional parameter. - -After typing the function name and a space, you can use the completion to -supply a parameter. The function takes the name of the Vim script you want to -source. Using the |cmdline-completion| feature, the SQLSetType function will -search the |'runtimepath'| for all Vim scripts with a name containing 'sql'. -This takes the guess work out of the spelling of the names. The following are -examples: > - :SQLSetType - :SQLSetType sqloracle - :SQLSetType sqlanywhere - :SQLSetType sqlinformix - :SQLSetType mysql - -The easiest approach is to the use character which will first complete -the command name (SQLSetType), after a space and another , display a list -of available Vim script names: > - :SQL - - -2.2 SQL Dialect Default *sql-type-default* ------------------------ -As mentioned earlier, the default syntax rules for Vim is based on Oracle -(PL/SQL). You can override this default by placing one of the following in -your |vimrc|: > - let g:sql_type_default = 'sqlanywhere' - let g:sql_type_default = 'sqlinformix' - let g:sql_type_default = 'mysql' - -If you added the following to your |vimrc|: > - let g:sql_type_default = 'sqlinformix' - -The next time edit a SQL file the following scripts will be automatically -loaded by Vim: > - ftplugin/sql.vim - syntax/sqlinformix.vim - indent/sql.vim -> -Notice indent/sqlinformix.sql was not loaded. There is no indent file -for Informix, Vim loads the default files if the specified files does not -exist. - - -============================================================================== -3. Adding new SQL Dialects *sql-adding-dialects* - -If you begin working with a SQL dialect which does not have any customizations -available with the default Vim distribution you can check http://www.vim.org -to see if any customization currently exist. If not, you can begin by cloning -an existing script. Read |filetype-plugins| for more details. - -To help identify these scripts, try to create the files with a "sql" prefix. -If you decide you wish to create customizations for the SQLite database, you -can create any of the following: > - Unix - ~/.vim/syntax/sqlite.vim - ~/.vim/indent/sqlite.vim - Windows - $VIM/vimfiles/syntax/sqlite.vim - $VIM/vimfiles/indent/sqlite.vim - -No changes are necessary to the SQLSetType function. It will automatically -pickup the new SQL files and load them when you issue the SQLSetType command. - - -============================================================================== -4. OMNI SQL Completion *sql-completion* - *omni-sql-completion* - -Vim 7 includes a code completion interface and functions which allows plugin -developers to build in code completion for any language. Vim 7 includes -code completion for the SQL language. - -There are two modes to the SQL completion plugin, static and dynamic. The -static mode populates the popups with the data generated from current syntax -highlight rules. The dynamic mode populates the popups with data retrieved -directly from a database. This includes, table lists, column lists, -procedures names and more. - -4.1 Static Mode *sql-completion-static* ---------------- -The static popups created contain items defined by the active syntax rules -while editing a file with a filetype of SQL. The plugin defines (by default) -various maps to help the user refine the list of items to be displayed. -The defaults static maps are: > - imap a :call sqlcomplete#Map('syntax') - imap k :call sqlcomplete#Map('sqlKeyword') - imap f :call sqlcomplete#Map('sqlFunction') - imap o :call sqlcomplete#Map('sqlOption') - imap T :call sqlcomplete#Map('sqlType') - imap s :call sqlcomplete#Map('sqlStatement') - -The static maps (which are based on the syntax highlight groups) follow this -format: > - imap k :call sqlcomplete#Map('sqlKeyword') - -This command breaks down as: > - imap - Create an insert map - - Only for this buffer - k - Your choice of key map - - Execute one command, return to Insert mode - :call sqlcomplete#Map( - Allows the SQL completion plugin to perform some - housekeeping functions to allow it to be used in - conjunction with other completion plugins. - Indicate which item you want the SQL completion - plugin to complete. - In this case we are asking the plugin to display - items from the syntax highlight group - 'sqlKeyword'. - You can view a list of highlight group names to - choose from by executing the - :syntax list - command while editing a SQL file. - 'sqlKeyword' - Display the items for the sqlKeyword highlight - group - ) - Execute the :let command - - Trigger the standard omni completion key stroke. - Passing in 'sqlKeyword' instructs the SQL - completion plugin to populate the popup with - items from the sqlKeyword highlight group. The - plugin will also cache this result until Vim is - restarted. The syntax list is retrieved using - the syntaxcomplete plugin. - -Using the 'syntax' keyword is a special case. This instructs the -syntaxcomplete plugin to retrieve all syntax items. So this will effectively -work for any of Vim's SQL syntax files. At the time of writing this includes -10 different syntax files for the different dialects of SQL (see section 3 -above, |sql-dialects|). - -Here are some examples of the entries which are pulled from the syntax files: > - All - - Contains the contents of all syntax highlight groups - Statements - - Select, Insert, Update, Delete, Create, Alter, ... - Functions - - Min, Max, Trim, Round, Date, ... - Keywords - - Index, Database, Having, Group, With - Options - - Isolation_level, On_error, Qualify_owners, Fire_triggers, ... - Types - - Integer, Char, Varchar, Date, DateTime, Timestamp, ... - - -4.2 Dynamic Mode *sql-completion-dynamic* ----------------- -Dynamic mode populates the popups with data directly from a database. In -order for the dynamic feature to be enabled you must have the dbext.vim -plugin installed, (http://vim.sourceforge.net/script.php?script_id=356). - -Dynamic mode is used by several features of the SQL completion plugin. -After installing the dbext plugin see the dbext-tutorial for additional -configuration and usage. The dbext plugin allows the SQL completion plugin -to display a list of tables, procedures, views and columns. > - Table List - - All tables for all schema owners - Procedure List - - All stored procedures for all schema owners - View List - - All stored procedures for all schema owners - Column List - - For the selected table, the columns that are part of the table - -To enable the popup, while in INSERT mode, use the following key combinations -for each group (where means hold the CTRL key down while pressing -the space bar): - Table List - t - - (the default map assumes tables) - Stored Procedure List - p - View List - v - Column List - c - - Windows platform only - When viewing a popup window displaying the list - of tables, you can press , this will - replace the table currently highlighted with - the column list for that table. - - When viewing a popup window displaying the list - of columns, you can press , this will - replace the column list with the list of tables. - - This allows you to quickly drill down into a - table to view it's columns and back again. - -The SQL completion plugin caches various lists that are displayed in -the popup window. This makes the re-displaying of these lists very -fast. If new tables or columns are added to the database it may become -necessary to clear the plugins cache. The default map for this is: > - imap R :call sqlcomplete#Map('ResetCache') - - -4.3 SQL Tutorial *sql-completion-tutorial* ----------------- - -This tutorial is designed to take you through the common features of the SQL -completion plugin so that: > - a) You gain familiarity with the plugin - b) You are introduced to some of the more common features - c) Show how to customize it to your preferences - d) Demonstrate "Best of Use" of the plugin (easiest way to configure). - -First, create a new buffer: > - :e tutorial.sql - - -Static features ---------------- -To take you through the various lists, simply enter insert mode, hit: - s (show SQL statements) -At this point, you can page down through the list until you find "select". -If you are familiar with the item you are looking for, for example you know -the statement begins with the letter "s". You can type ahead (without the -quotes) "se" then press: - t -Assuming "select" is highlighted in the popup list press to choose -the entry. Now type: - * fra (show all syntax items) -choose "from" from the popup list. - -When writing stored procedures using the "type" list is useful. It contains -a list of all the database supported types. This may or may not be true -depending on the syntax file you are using. The SQL Anywhere syntax file -(sqlanywhere.vim) has support for this: > - BEGIN - DECLARE customer_id T <-- Choose a type from the list - - -Dynamic features ----------------- -To take advantage of the dynamic features you must first install the -dbext.vim plugin (http://vim.sourceforge.net/script.php?script_id=356). It -also comes with a tutorial. From the SQL completion plugin's perspective, -the main feature dbext provides is a connection to a database. dbext -connection profiles are the most efficient mechanism to define connection -information. Once connections have been setup, the SQL completion plugin -uses the features of dbext in the background to populate the popups. - -What follows assumes dbext.vim has been correctly configured, a simple test -is to run the command, :DBListTable. If a list of tables is shown, you know -dbext.vim is working as expected. If not, please consult the dbext.txt -documentation. - -Assuming you have followed the dbext-tutorial you can press t to -display a list of tables. There is a delay while dbext is creating the table -list. After the list is displayed press . This will remove both the -popup window and the table name already chosen when the list became active. > - - 4.3.1 Table Completion: *sql-completion-tables* - -Press t to display a list of tables from within the database you -have connected via the dbext plugin. -NOTE: All of the SQL completion popups support typing a prefix before pressing -the key map. This will limit the contents of the popup window to just items -beginning with those characters. > - - 4.3.2 Column Completion: *sql-completion-columns* - -The SQL completion plugin can also display a list of columns for particular -tables. The column completion is trigger via c. - -NOTE: The following example uses to trigger a column list while -the popup window is active. This map is only available on the Windows -platforms since *nix does not recognize CTRL and the right arrow held down -together. If you wish to enable this functionality on a *nix platform choose -a key and create one of these mappings (see |sql-completion-maps| for further -details on where to create this imap): > - imap =sqlcomplete#DrillIntoTable() - imap :call sqlcomplete#Map('column') - -Example of using column completion: - - Press t again to display the list of tables. - - When the list is displayed in the completion window, press , - this will replace the list of tables, with a list of columns for the - table highlighted (after the same short delay). - - If you press , this will again replace the column list with the - list of tables. This allows you to drill into tables and column lists - very quickly. - - Press again while the same table is highlighted. You will - notice there is no delay since the column list has been cached. If you - change the schema of a cached table you can press R, which - clears the SQL completion cache. - - NOTE: and have been designed to work while the - completion window is active. If the completion popup window is - not active, a normal or will be executed. - -Lets look how we can build a SQL statement dynamically. A select statement -requires a list of columns. There are two ways to build a column list using -the SQL completion plugin. > - One column at a time: -< 1. After typing SELECT press t to display a list of tables. - 2. Choose a table from the list. - 3. Press to display a list of columns. - 4. Choose the column from the list and press enter. - 5. Enter a "," and press c. Generating a column list - generally requires having the cursor on a table name. The plugin - uses this name to determine what table to retrieve the column list. - In this step, since we are pressing c without the cursor - on a table name the column list displayed will be for the previous - table. Choose a different column and move on. - 6. Repeat step 5 as often as necessary. > - All columns for a table: -< 1. After typing SELECT press t to display a list of tables. - 2. Highlight the table you need the column list for. - 3. Press to choose the table from the list. - 4. Press l to request a comma separated list of all columns - for this table. - 5. Based on the table name chosen in step 3, the plugin attempts to - decide on a reasonable table alias. You are then prompted to - either accept of change the alias. Press OK. - 6. The table name is replaced with the column list of the table is - replaced with the comma separate list of columns with the alias - prepended to each of the columns. - 7. Step 3 and 4 can be replaced by pressing L, which has - a embedded in the map to choose the currently highlighted - table in the list. - -There is a special provision when writing select statements. Consider the -following statement: > - select * - from customer c, - contact cn, - department as dp, - employee e, - site_options so - where c. - -In INSERT mode after typing the final "c." which is an alias for the -"customer" table, you can press either c or . This will -popup a list of columns for the customer table. It does this by looking back -to the beginning of the select statement and finding a list of the tables -specified in the FROM clause. In this case it notes that in the string -"customer c", "c" is an alias for the customer table. The optional "AS" -keyword is also supported, "customer AS c". > - - - 4.3.3 Procedure Completion: *sql-completion-procedures* - -Similar to the table list, p, will display a list of stored -procedures stored within the database. > - - 4.3.4 View Completion: *sql-completion-views* - -Similar to the table list, v, will display a list of views in the -database. - - -4.4 Completion Customization *sql-completion-customization* ----------------------------- - -The SQL completion plugin can be customized through various options set in -your |vimrc|: > - omni_sql_no_default_maps -< - Default: This variable is not defined - - If this variable is defined, no maps are created for OMNI - completion. See |sql-completion-maps| for further discussion. -> - omni_sql_use_tbl_alias -< - Default: a - - This setting is only used when generating a comma separated - column list. By default the map is l. When generating - a column list, an alias can be prepended to the beginning of each - column, for example: e.emp_id, e.emp_name. This option has three - settings: > - n - do not use an alias - d - use the default (calculated) alias - a - ask to confirm the alias name -< - An alias is determined following a few rules: - 1. If the table name has an '_', then use it as a separator: > - MY_TABLE_NAME --> MTN - my_table_name --> mtn - My_table_NAME --> MtN -< 2. If the table name does NOT contain an '_', but DOES use - mixed case then the case is used as a separator: > - MyTableName --> MTN -< 3. If the table name does NOT contain an '_', and does NOT - use mixed case then the first letter of the table is used: > - mytablename --> m - MYTABLENAME --> M - - omni_sql_ignorecase -< - Default: Current setting for|ignorecase| - - Valid settings are 0 or 1. - - When entering a few letters before initiating completion, the list - will be filtered to display only the entries which begin with the - list of characters. When this option is set to 0, the list will be - filtered using case sensitivity. > - - omni_sql_include_owner -< - Default: 0, unless dbext.vim 3.00 has been installed - - Valid settings are 0 or 1. - - When completing tables, procedure or views and using dbext.vim 3.00 - or higher the list of objects will also include the owner name. - When completing these objects and omni_sql_include_owner is enabled - the owner name will be replaced. > - - omni_sql_precache_syntax_groups -< - Default: - ['syntax','sqlKeyword','sqlFunction','sqlOption','sqlType','sqlStatement'] - - sqlcomplete can be used in conjunction with other completion - plugins. This is outlined at |sql-completion-filetypes|. When the - filetype is changed temporarily to SQL, the sqlcompletion plugin - will cache the syntax groups listed in the List specified in this - option. -> - -4.5 SQL Maps *sql-completion-maps* ------------- - -The default SQL maps have been described in other sections of this document in -greater detail. Here is a list of the maps with a brief description of each. - -Static Maps ------------ -These are maps which use populate the completion list using Vim's syntax -highlighting rules. > - a -< - Displays all SQL syntax items. > - k -< - Displays all SQL syntax items defined as 'sqlKeyword'. > - f -< - Displays all SQL syntax items defined as 'sqlFunction. > - o -< - Displays all SQL syntax items defined as 'sqlOption'. > - T -< - Displays all SQL syntax items defined as 'sqlType'. > - s -< - Displays all SQL syntax items defined as 'sqlStatement'. > - -Dynamic Maps ------------- -These are maps which use populate the completion list using the dbext.vim -plugin. > - t -< - Displays a list of tables. > - p -< - Displays a list of procedures. > - v -< - Displays a list of views. > - c -< - Displays a list of columns for a specific table. > - l -< - Displays a comma separated list of columns for a specific table. > - L -< - Displays a comma separated list of columns for a specific table. - This should only be used when the completion window is active. > - -< - Displays a list of columns for the table currently highlighted in - the completion window. is not recognized on most Unix - systems, so this maps is only created on the Windows platform. - If you would like the same feature on Unix, choose a different key - and make the same map in your vimrc. > - -< - Displays the list of tables. - is not recognized on most Unix systems, so this maps is - only created on the Windows platform. If you would like the same - feature on Unix, choose a different key and make the same map in - your vimrc. > - R -< - This maps removes all cached items and forces the SQL completion - to regenerate the list of items. - -Customizing Maps ----------------- -You can create as many additional key maps as you like. Generally, the maps -will be specifying different syntax highlight groups. - -If you do not wish the default maps created or the key choices do not work on -your platform (often a case on *nix) you define the following variable in -your |vimrc|: > - let g:omni_sql_no_default_maps = 1 - -Do no edit ftplugin/sql.vim directly! If you change this file your changes -will be over written on future updates. Vim has a special directory structure -which allows you to make customizations without changing the files that are -included with the Vim distribution. If you wish to customize the maps -create an after/ftplugin/sql.vim (see |after-directory|) and place the same -maps from the ftplugin/sql.vim in it using your own key strokes. was -chosen since it will work on both Windows and *nix platforms. On the windows -platform you can also use or ALT keys. - - -4.6 Using with other filetypes *sql-completion-filetypes* ------------------------------- - -Many times SQL can be used with different filetypes. For example Perl, Java, -PHP, Javascript can all interact with a database. Often you need both the SQL -completion as well as the completion capabilities for the current language you -are editing. - -This can be enabled easily with the following steps (assuming a Perl file): > - 1. :e test.pl - 2. :set filetype=sql - 3. :set ft=perl - -Step 1 ------- -Begins by editing a Perl file. Vim automatically sets the filetype to -"perl". By default, Vim runs the appropriate filetype file -ftplugin/perl.vim. If you are using the syntax completion plugin by following -the directions at |ft-syntax-omni| then the |'omnifunc'| option has been set to -"syntax#Complete". Pressing will display the omni popup containing -the syntax items for Perl. - -Step 2 ------- -Manually setting the filetype to 'sql' will also fire the appropriate filetype -files ftplugin/sql.vim. This file will define a number of buffer specific -maps for SQL completion, see |sql-completion-maps|. Now these maps have -been created and the SQL completion plugin has been initialized. All SQL -syntax items have been cached in preparation. The SQL filetype script detects -we are attempting to use two different completion plugins. Since the SQL maps -begin with , the maps will toggle the |'omnifunc'| when in use. So you -can use to continue using the completion for Perl (using the syntax -completion plugin) and to use the SQL completion features. - -Step 3 ------- -Setting the filetype back to Perl sets all the usual "perl" related items back -as they were. - - -vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/gui.txt b/share/vim/vim72/doc/gui.txt deleted file mode 100644 index daf1a9a852..0000000000 --- a/share/vim/vim72/doc/gui.txt +++ /dev/null @@ -1,999 +0,0 @@ -*gui.txt* For Vim version 7.2. Last change: 2008 Jun 14 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Vim's Graphical User Interface *gui* *GUI* - -1. Starting the GUI |gui-start| -2. Scrollbars |gui-scrollbars| -3. Mouse Control |gui-mouse| -4. Making GUI Selections |gui-selections| -5. Menus |menus| -6. Extras |gui-extras| -7. Shell Commands |gui-shell| - -Other GUI documentation: -|gui_x11.txt| For specific items of the X11 GUI. -|gui_w32.txt| For specific items of the Win32 GUI. - -{Vi does not have any of these commands} - -============================================================================== -1. Starting the GUI *gui-start* *E229* *E233* - -First you must make sure you actually have a version of Vim with the GUI code -included. You can check this with the ":version" command, it says "with xxx -GUI", where "xxx" is X11-Motif, X11-Athena, Photon, GTK, GTK2, etc., or -"MS-Windows 32 bit GUI version". - -How to start the GUI depends on the system used. Mostly you can run the -GUI version of Vim with: - gvim [options] [files...] - -The X11 version of Vim can run both in GUI and in non-GUI mode. See -|gui-x11-start|. - - *gui-init* *gvimrc* *.gvimrc* *_gvimrc* -The gvimrc file is where GUI-specific startup commands should be placed. It -is always sourced after the |vimrc| file. If you have one then the $MYGVIMRC -environment variable has its name. - -When the GUI starts up initializations are carried out, in this order: -- The 'term' option is set to "builgin_gui" and terminal options are reset to - their default value for the GUI |terminal-options|. -- If the system menu file exists, it is sourced. The name of this file is - normally "$VIMRUNTIME/menu.vim". You can check this with ":version". Also - see |$VIMRUNTIME|. To skip loading the system menu include 'M' in - 'guioptions'. *buffers-menu* *no_buffers_menu* - The system menu file includes a "Buffers" menu. If you don't want this, set - the "no_buffers_menu" variable in your .vimrc (not .gvimrc!): > - :let no_buffers_menu = 1 -< NOTE: Switching on syntax highlighting also loads the menu file, thus - disabling the Buffers menu must be done before ":syntax on". - The path names are truncated to 35 characters. You can truncate them at a - different length, for example 50, like this: > - :let bmenu_max_pathlen = 50 -- If the "-U {gvimrc}" command-line option has been used when starting Vim, - the {gvimrc} file will be read for initializations. The following - initializations are skipped. When {gvimrc} is "NONE" no file will be read - for initializations. -- For Unix and MS-Windows, if the system gvimrc exists, it is sourced. The - name of this file is normally "$VIM/gvimrc". You can check this with - ":version". Also see |$VIM|. -- The following are tried, and only the first one that exists is used: - - If the GVIMINIT environment variable exists and is not empty, it is - executed as an Ex command. - - If the user gvimrc file exists, it is sourced. The name of this file is - normally "$HOME/.gvimrc". You can check this with ":version". - - For Win32, when $HOME is not set, "$VIM\_gvimrc" is used. - - When a "_gvimrc" file is not found, ".gvimrc" is tried too. And vice - versa. - The name of the first file found is stored in $MYGVIMRC, unless it was - already set. -- If the 'exrc' option is set (which is NOT the default) the file ./.gvimrc - is sourced, if it exists and isn't the same file as the system or user - gvimrc file. If this file is not owned by you, some security restrictions - apply. When ".gvimrc" is not found, "_gvimrc" is tried too. For Macintosh - and DOS/Win32 "_gvimrc" is tried first. - -NOTE: All but the first one are not carried out if Vim was started with -"-u NONE" and no "-U" argument was given, or when started with "-U NONE". - -All this happens AFTER the normal Vim initializations, like reading your -.vimrc file. See |initialization|. -But the GUI window is only opened after all the initializations have been -carried out. If you want some commands to be executed just after opening the -GUI window, use the |GUIEnter| autocommand event. Example: > - :autocmd GUIEnter * winpos 100 50 - -You can use the gvimrc files to set up your own customized menus (see |:menu|) -and initialize other things that you may want to set up differently from the -terminal version. - -Recommended place for your personal GUI initializations: - Unix $HOME/.gvimrc - OS/2 $HOME/.gvimrc or $VIM/.gvimrc - MS-DOS and Win32 $HOME/_gvimrc or $VIM/_gvimrc - Amiga s:.gvimrc or $VIM/.gvimrc - -There are a number of options which only have meaning in the GUI version of -Vim. These are 'guicursor', 'guifont', 'guipty' and 'guioptions'. They are -documented in |options.txt| with all the other options. - -If using the Motif or Athena version of the GUI (but not for the GTK+ or -Win32 version), a number of X resources are available. See |gui-resources|. - -Another way to set the colors for different occasions is with highlight -groups. The "Normal" group is used to set the background and foreground -colors. Example (which looks nice): > - - :highlight Normal guibg=grey90 - -The "guibg" and "guifg" settings override the normal background and -foreground settings. The other settings for the Normal highlight group are -not used. Use the 'guifont' option to set the font. - -Also check out the 'guicursor' option, to set the colors for the cursor in -various modes. - -Vim tries to make the window fit on the screen when it starts up. This avoids -that you can't see part of it. On the X Window System this requires a bit of -guesswork. You can change the height that is used for the window title and a -task bar with the 'guiheadroom' option. - - *:winp* *:winpos* *E188* -:winp[os] - Display current position of the top left corner of the GUI vim - window in pixels. Does not work in all versions. - -:winp[os] {X} {Y} *E466* - Put the GUI vim window at the given {X} and {Y} coordinates. - The coordinates should specify the position in pixels of the - top left corner of the window. Does not work in all versions. - Does work in an (new) xterm |xterm-color|. - When the GUI window has not been opened yet, the values are - remembered until the window is opened. The position is - adjusted to make the window fit on the screen (if possible). - - *:win* *:winsize* *E465* -:win[size] {width} {height} - Set the window height to {width} by {height} characters. - Obsolete, use ":set lines=11 columns=22". - If you get less lines than expected, check the 'guiheadroom' - option. - -If you are running the X Window System, you can get information about the -window Vim is running in with this command: > - :!xwininfo -id $WINDOWID - -============================================================================== -2. Scrollbars *gui-scrollbars* - -There are vertical scrollbars and a horizontal scrollbar. You may -configure which ones appear with the 'guioptions' option. - -The interface looks like this (with ":set guioptions=mlrb"): - - +------------------------------+ - | File Edit Help | <- Menu bar (m) - +-+--------------------------+-+ - |^| |^| - |#| Text area. |#| - | | | | - |v|__________________________|v| - Normal status line -> |-+ File.c 5,2 +-| - between Vim windows |^|""""""""""""""""""""""""""|^| - | | | | - | | Another file buffer. | | - | | | | - |#| |#| - Left scrollbar (l) -> |#| |#| <- Right - |#| |#| scrollbar (r) - | | | | - |v| |v| - +-+--------------------------+-+ - | |< #### >| | <- Bottom - +-+--------------------------+-+ scrollbar (b) - -Any of the scrollbar or menu components may be turned off by not putting the -appropriate letter in the 'guioptions' string. The bottom scrollbar is -only useful when 'nowrap' is set. - - -VERTICAL SCROLLBARS *gui-vert-scroll* - -Each Vim window has a scrollbar next to it which may be scrolled up and down -to move through the text in that buffer. The size of the scrollbar-thumb -indicates the fraction of the buffer which can be seen in the window. -When the scrollbar is dragged all the way down, the last line of the file -will appear in the top of the window. - -If a window is shrunk to zero height (by the growth of another window) its -scrollbar disappears. It reappears when the window is restored. - -If a window is vertically split, it will get a scrollbar when it is the -current window and when, taking the middle of the current window and drawing a -vertical line, this line goes through the window. -When there are scrollbars on both sides, and the middle of the current window -is on the left half, the right scrollbar column will contain scrollbars for -the rightmost windows. The same happens on the other side. - - -HORIZONTAL SCROLLBARS *gui-horiz-scroll* - -The horizontal scrollbar (at the bottom of the Vim GUI) may be used to -scroll text sideways when the 'wrap' option is turned off. The -scrollbar-thumb size is such that the text of the longest visible line may be -scrolled as far as possible left and right. The cursor is moved when -necessary, it must remain on a visible character (unless 'virtualedit' is -set). - -Computing the length of the longest visible line takes quite a bit of -computation, and it has to be done every time something changes. If this -takes too much time or you don't like the cursor jumping to another line, -include the 'h' flag in 'guioptions'. Then the scrolling is limited by the -text of the current cursor line. - - *athena-intellimouse* -If you have an Intellimouse and an X server that supports using the wheel, -then you can use the wheel to scroll the text up and down in gvim. This works -with XFree86 4.0 and later, and with some older versions when you add patches. -See |scroll-mouse-wheel|. - -For older versions of XFree86 you must patch your X server. The following -page has a bit of information about using the Intellimouse on Linux as well as -links to the patches and X server binaries (may not have the one you need -though): - http://www.inria.fr/koala/colas/mouse-wheel-scroll/ - -============================================================================== -3. Mouse Control *gui-mouse* - -The mouse only works if the appropriate flag in the 'mouse' option is set. -When the GUI is switched on, and 'mouse' wasn't set yet, the 'mouse' option is -automatically set to "a", enabling it for all modes except for the -|hit-enter| prompt. If you don't want this, a good place to change the -'mouse' option is the "gvimrc" file. - -Other options that are relevant: -'mousefocus' window focus follows mouse pointer |gui-mouse-focus| -'mousemodel' what mouse button does which action -'mousehide' hide mouse pointer while typing text -'selectmode' whether to start Select mode or Visual mode - -A quick way to set these is with the ":behave" command. - *:behave* *:be* -:be[have] {model} Set behavior for mouse and selection. Valid - arguments are: - mswin MS-Windows behavior - xterm Xterm behavior - - Using ":behave" changes these options: - option mswin xterm ~ - 'selectmode' "mouse,key" "" - 'mousemodel' "popup" "extend" - 'keymodel' "startsel,stopsel" "" - 'selection' "exclusive" "inclusive" - -In the $VIMRUNTIME directory, there is a script called |mswin.vim|, which will -also map a few keys to the MS-Windows cut/copy/paste commands. This is NOT -compatible, since it uses the CTRL-V, CTRL-X and CTRL-C keys. If you don't -mind, use this command: > - :so $VIMRUNTIME/mswin.vim - -For scrolling with a wheel on a mouse, see |scroll-mouse-wheel|. - - -3.1 Moving Cursor with Mouse *gui-mouse-move* - -Click the left mouse button somewhere in a text buffer where you want the -cursor to go, and it does! -This works in when 'mouse' contains ~ -Normal mode 'n' or 'a' -Visual mode 'v' or 'a' -Insert mode 'i' or 'a' - -Select mode is handled like Visual mode. - -You may use this with an operator such as 'd' to delete text from the current -cursor position to the position you point to with the mouse. That is, you hit -'d' and then click the mouse somewhere. - - *gui-mouse-focus* -The 'mousefocus' option can be set to make the keyboard focus follow the -mouse pointer. This means that the window where the mouse pointer is, is the -active window. Warning: this doesn't work very well when using a menu, -because the menu command will always be applied to the top window. - -If you are on the ':' line (or '/' or '?'), then clicking the left or right -mouse button will position the cursor on the ':' line (if 'mouse' contains -'c', 'a' or 'A'). - -In any situation the middle mouse button may be clicked to paste the current -selection. - - -3.2 Selection with Mouse *gui-mouse-select* - -The mouse can be used to start a selection. How depends on the 'mousemodel' -option: -'mousemodel' is "extend": use the right mouse button -'mousemodel' is "popup": use the left mouse button, while keeping the Shift -key pressed. - -If there was no selection yet, this starts a selection from the old cursor -position to the position pointed to with the mouse. If there already is a -selection then the closest end will be extended. - -If 'selectmode' contains "mouse", then the selection will be in Select mode. -This means that typing normal text will replace the selection. See -|Select-mode|. Otherwise, the selection will be in Visual mode. - -Double clicking may be done to make the selection word-wise, triple clicking -makes it line-wise, and quadruple clicking makes it rectangular block-wise. - -See |gui-selections| on how the selection is used. - - -3.3 Other Text Selection with Mouse *gui-mouse-modeless* - *modeless-selection* -A different kind of selection is used when: -- in Command-line mode -- in the Command-line window and pointing in another window -- at the |hit-enter| prompt -- whenever the current mode is not in the 'mouse' option -- when holding the CTRL and SHIFT keys in the GUI - -Since Vim continues like the selection isn't there, and there is no mode -associated with the selection, this is called modeless selection. Any text in -the Vim window can be selected. Select the text by pressing the left mouse -button at the start, drag to the end and release. To extend the selection, -use the right mouse button when 'mousemodel' is "extend", or the left mouse -button with the shift key pressed when 'mousemodel' is "popup". -The selection is removed when the selected text is scrolled or changed. - -On the command line CTRL-Y can be used to copy the selection into the -clipboard. To do this from Insert mode, use CTRL-O : CTRL-Y . When -'guioptions' contains a or A (default on X11), the selection is automatically -copied to the "* register. - -The middle mouse button can then paste the text. On non-X11 systems, you can -use CTRL-R +. - - -3.4 Using Mouse on Status Lines *gui-mouse-status* - -Clicking the left or right mouse button on the status line below a Vim -window makes that window the current window. This actually happens on button -release (to be able to distinguish a click from a drag action). - -With the left mouse button a status line can be dragged up and down, thus -resizing the windows above and below it. This does not change window focus. - -The same can be used on the vertical separator: click to give the window left -of it focus, drag left and right to make windows wider and narrower. - - -3.5 Various Mouse Clicks *gui-mouse-various* - - Search forward for the word under the mouse click. - When 'mousemodel' is "popup" this starts or extends a - selection. - Search backward for the word under the mouse click. - Jump to the tag name under the mouse click. - Jump back to position before the previous tag jump - (same as "CTRL-T") - - -3.6 Mouse Mappings *gui-mouse-mapping* - -The mouse events, complete with modifiers, may be mapped. Eg: > - :map - :map - :map - :map <2-S-LeftMouse> <2-RightMouse> - :map <2-S-LeftDrag> <2-RightDrag> - :map <2-S-LeftRelease> <2-RightRelease> - :map <3-S-LeftMouse> <3-RightMouse> - :map <3-S-LeftDrag> <3-RightDrag> - :map <3-S-LeftRelease> <3-RightRelease> - :map <4-S-LeftMouse> <4-RightMouse> - :map <4-S-LeftDrag> <4-RightDrag> - :map <4-S-LeftRelease> <4-RightRelease> -These mappings make selection work the way it probably should in a Motif -application, with shift-left mouse allowing for extending the visual area -rather than the right mouse button. - -Mouse mapping with modifiers does not work for modeless selection. - - -3.7 Drag and drop *drag-n-drop* - -You can drag and drop one or more files into the Vim window, where they will -be opened as if a |:drop| command was used. - -If you hold down Shift while doing this, Vim changes to the first dropped -file's directory. If you hold Ctrl Vim will always split a new window for the -file. Otherwise it's only done if the current buffer has been changed. - -You can also drop a directory on Vim. This starts the explorer plugin for -that directory (assuming it was enabled, otherwise you'll get an error -message). Keep Shift pressed to change to the directory instead. - -If Vim happens to be editing a command line, the names of the dropped files -and directories will be inserted at the cursor. This allows you to use these -names with any Ex command. Special characters (space, tab, double quote and -'|'; backslash on non-MS-Windows systems) will be escaped. - -============================================================================== -4. Making GUI Selections *gui-selections* - - *quotestar* -You may make selections with the mouse (see |gui-mouse-select|), or by using -Vim's Visual mode (see |v|). If 'a' is present in 'guioptions', then -whenever a selection is started (Visual or Select mode), or when the selection -is changed, Vim becomes the owner of the windowing system's primary selection -(on MS-Windows the |gui-clipboard| is used; under X11, the |x11-selection| is -used - you should read whichever of these is appropriate now). - - *clipboard* -There is a special register for storing this selection, it is the "* -register. Nothing is put in here unless the information about what text is -selected is about to change (e.g. with a left mouse click somewhere), or when -another application wants to paste the selected text. Then the text is put -in the "* register. For example, to cut a line and make it the current -selection/put it on the clipboard: > - - "*dd - -Similarly, when you want to paste a selection from another application, e.g., -by clicking the middle mouse button, the selection is put in the "* register -first, and then 'put' like any other register. For example, to put the -selection (contents of the clipboard): > - - "*p - -When using this register under X11, also see |x11-selection|. This also -explains the related "+ register. - -Note that when pasting text from one Vim into another separate Vim, the type -of selection (character, line, or block) will also be copied. For other -applications the type is always character. However, if the text gets -transferred via the |x11-cut-buffer|, the selection type is ALWAYS lost. - -When the "unnamed" string is included in the 'clipboard' option, the unnamed -register is the same as the "* register. Thus you can yank to and paste the -selection without prepending "* to commands. - -============================================================================== -5. Menus *menus* - -For an introduction see |usr_42.txt| in the user manual. - - -5.1 Using Menus *using-menus* - -Basically, menus can be used just like mappings. You can define your own -menus, as many as you like. -Long-time Vim users won't use menus much. But the power is in adding your own -menus and menu items. They are most useful for things that you can't remember -what the key sequence was. - -For creating menus in a different language, see |:menutrans|. - - *menu.vim* -The default menus are read from the file "$VIMRUNTIME/menu.vim". See -|$VIMRUNTIME| for where the path comes from. You can set up your own menus. -Starting off with the default set is a good idea. You can add more items, or, -if you don't like the defaults at all, start with removing all menus -|:unmenu-all|. You can also avoid the default menus being loaded by adding -this line to your .vimrc file (NOT your .gvimrc file!): > - :let did_install_default_menus = 1 -If you also want to avoid the Syntax menu: > - :let did_install_syntax_menu = 1 -If you do want the Syntax menu but not all the entries for each available -syntax file (which take quite a bit of time to load): > - :let skip_syntax_sel_menu = 1 -< - *console-menus* -Although this documentation is in the GUI section, you can actually use menus -in console mode too. You will have to load |menu.vim| explicitly then, it is -not done by default. You can use the |:emenu| command and command-line -completion with 'wildmenu' to access the menu entries almost like a real menu -system. To do this, put these commands in your .vimrc file: > - :source $VIMRUNTIME/menu.vim - :set wildmenu - :set cpo-=< - :set wcm= - :map :emenu -Pressing will start the menu. You can now use the cursor keys to select -a menu entry. Hit to execute it. Hit if you want to cancel. -This does require the |+menu| feature enabled at compile time. - - *tear-off-menus* -GTK+ and Motif support Tear-off menus. These are sort of sticky menus or -pop-up menus that are present all the time. If the resizing does not work -correctly, this may be caused by using something like "Vim*geometry" in the -defaults. Use "Vim.geometry" instead. - -The Win32 GUI version emulates Motif's tear-off menus. Actually, a Motif user -will spot the differences easily, but hopefully they're just as useful. You -can also use the |:tearoff| command together with |hidden-menus| to create -floating menus that do not appear on the main menu bar. - - -5.2 Creating New Menus *creating-menus* - - *:me* *:menu* *:noreme* *:noremenu* - *:am* *:amenu* *:an* *:anoremenu* - *:nme* *:nmenu* *:nnoreme* *:nnoremenu* - *:ome* *:omenu* *:onoreme* *:onoremenu* - *:vme* *:vmenu* *:vnoreme* *:vnoremenu* - *:xme* *:xmenu* *:xnoreme* *:xnoremenu* - *:sme* *:smenu* *:snoreme* *:snoremenu* - *:ime* *:imenu* *:inoreme* *:inoremenu* - *:cme* *:cmenu* *:cnoreme* *:cnoremenu* - *E330* *E327* *E331* *E336* *E333* - *E328* *E329* *E337* *E792* -To create a new menu item, use the ":menu" commands. They are mostly like -the ":map" set of commands but the first argument is a menu item name, given -as a path of menus and submenus with a '.' between them, e.g.: > - - :menu File.Save :w - :inoremenu File.Save :w - :menu Edit.Big\ Changes.Delete\ All\ Spaces :%s/[ ^I]//g - -This last one will create a new item in the menu bar called "Edit", holding -the mouse button down on this will pop up a menu containing the item -"Big Changes", which is a sub-menu containing the item "Delete All Spaces", -which when selected, performs the operation. - -Special characters in a menu name: - - & The next character is the shortcut key. Make sure each - shortcut key is only used once in a (sub)menu. If you want to - insert a literal "&" in the menu name use "&&". - Separates the menu name from right-aligned text. This can be - used to show the equivalent typed command. The text "" - can be used here for convenience. If you are using a real - tab, don't forget to put a backslash before it! -Example: > - - :amenu &File.&Open:e :browse e - -[typed literally] -With the shortcut "F" (while keeping the key pressed), and then "O", -this menu can be used. The second part is shown as "Open :e". The ":e" -is right aligned, and the "O" is underlined, to indicate it is the shortcut. - -The ":amenu" command can be used to define menu entries for all modes at once. -To make the command work correctly, a character is automatically inserted for -some modes: - mode inserted appended ~ - Normal nothing nothing - Visual - Insert - Cmdline - Op-pending - -Appending CTRL-\ CTRL-G is for going back to insert mode when 'insertmode' is -set. |CTRL-\_CTRL-G| - -Example: > - - :amenu File.Next :next^M - -is equal to: > - - :nmenu File.Next :next^M - :vmenu File.Next ^C:next^M^\^G - :imenu File.Next ^O:next^M - :cmenu File.Next ^C:next^M^\^G - :omenu File.Next ^C:next^M^\^G - -Careful: In Insert mode this only works for a SINGLE Normal mode command, -because of the CTRL-O. If you have two or more commands, you will need to use -the ":imenu" command. For inserting text in any mode, you can use the -expression register: > - - :amenu Insert.foobar "='foobar'P - -Note that the '<' and 'k' flags in 'cpoptions' also apply here (when -included they make the <> form and raw key codes not being recognized). - -Note that in Cmdline mode executes the command, like in a mapping. This -is Vi compatible. Use CTRL-C to quit Cmdline mode. - - *:menu-* *:menu-silent* -To define a menu which will not be echoed on the command line, add -"" as the first argument. Example: > - :menu Settings.Ignore\ case :set ic -The ":set ic" will not be echoed when using this menu. Messages from the -executed command are still given though. To shut them up too, add a ":silent" -in the executed command: > - :menu Search.Header :exe ":silent normal /Header\r" -"" may also appear just after "" or " - -See |mysyntaxfile-add| for installing script languages permanently. - - -APACHE *apache.vim* *ft-apache-syntax* - -The apache syntax file provides syntax highlighting depending on Apache HTTP -server version, by default for 1.3.x. Set "apache_version" to Apache version -(as a string) to get highlighting for another version. Example: > - - :let apache_version = "2.0" -< - - *asm.vim* *asmh8300.vim* *nasm.vim* *masm.vim* *asm68k* -ASSEMBLY *ft-asm-syntax* *ft-asmh8300-syntax* *ft-nasm-syntax* - *ft-masm-syntax* *ft-asm68k-syntax* *fasm.vim* - -Files matching "*.i" could be Progress or Assembly. If the automatic detection -doesn't work for you, or you don't edit Progress at all, use this in your -startup vimrc: > - :let filetype_i = "asm" -Replace "asm" with the type of assembly you use. - -There are many types of assembly languages that all use the same file name -extensions. Therefore you will have to select the type yourself, or add a -line in the assembly file that Vim will recognize. Currently these syntax -files are included: - asm GNU assembly (the default) - asm68k Motorola 680x0 assembly - asmh8300 Hitachi H-8300 version of GNU assembly - ia64 Intel Itanium 64 - fasm Flat assembly (http://flatassembler.net) - masm Microsoft assembly (probably works for any 80x86) - nasm Netwide assembly - tasm Turbo Assembly (with opcodes 80x86 up to Pentium, and - MMX) - pic PIC assembly (currently for PIC16F84) - -The most flexible is to add a line in your assembly file containing: > - :asmsyntax=nasm -Replace "nasm" with the name of the real assembly syntax. This line must be -one of the first five lines in the file. - -The syntax type can always be overruled for a specific buffer by setting the -b:asmsyntax variable: > - :let b:asmsyntax = "nasm" - -If b:asmsyntax is not set, either automatically or by hand, then the value of -the global variable asmsyntax is used. This can be seen as a default assembly -language: > - :let asmsyntax = "nasm" - -As a last resort, if nothing is defined, the "asm" syntax is used. - - -Netwide assembler (nasm.vim) optional highlighting ~ - -To enable a feature: > - :let {variable}=1|set syntax=nasm -To disable a feature: > - :unlet {variable} |set syntax=nasm - -Variable Highlight ~ -nasm_loose_syntax unofficial parser allowed syntax not as Error - (parser dependent; not recommended) -nasm_ctx_outside_macro contexts outside macro not as Error -nasm_no_warn potentially risky syntax not as ToDo - - -ASPPERL and ASPVBS *ft-aspperl-syntax* *ft-aspvbs-syntax* - -*.asp and *.asa files could be either Perl or Visual Basic script. Since it's -hard to detect this you can set two global variables to tell Vim what you are -using. For Perl script use: > - :let g:filetype_asa = "aspperl" - :let g:filetype_asp = "aspperl" -For Visual Basic use: > - :let g:filetype_asa = "aspvbs" - :let g:filetype_asp = "aspvbs" - - -BAAN *baan.vim* *baan-syntax* - -The baan.vim gives syntax support for BaanC of release BaanIV upto SSA ERP LN -for both 3 GL and 4 GL programming. Large number of standard defines/constants -are supported. - -Some special violation of coding standards will be signalled when one specify -in ones |.vimrc|: > - let baan_code_stds=1 - -*baan-folding* - -Syntax folding can be enabled at various levels through the variables -mentioned below (Set those in your |.vimrc|). The more complex folding on -source blocks and SQL can be CPU intensive. - -To allow any folding and enable folding at function level use: > - let baan_fold=1 -Folding can be enabled at source block level as if, while, for ,... The -indentation preceding the begin/end keywords has to match (spaces are not -considered equal to a tab). > - let baan_fold_block=1 -Folding can be enabled for embedded SQL blocks as SELECT, SELECTDO, -SELECTEMPTY, ... The indentation preceding the begin/end keywords has to -match (spaces are not considered equal to a tab). > - let baan_fold_sql=1 -Note: Block folding can result in many small folds. It is suggested to |:set| -the options 'foldminlines' and 'foldnestmax' in |.vimrc| or use |:setlocal| in -.../after/syntax/baan.vim (see |after-directory|). Eg: > - set foldminlines=5 - set foldnestmax=6 - - -BASIC *basic.vim* *vb.vim* *ft-basic-syntax* *ft-vb-syntax* - -Both Visual Basic and "normal" basic use the extension ".bas". To detect -which one should be used, Vim checks for the string "VB_Name" in the first -five lines of the file. If it is not found, filetype will be "basic", -otherwise "vb". Files with the ".frm" extension will always be seen as Visual -Basic. - - -C *c.vim* *ft-c-syntax* - -A few things in C highlighting are optional. To enable them assign any value -to the respective variable. Example: > - :let c_comment_strings = 1 -To disable them use ":unlet". Example: > - :unlet c_comment_strings - -Variable Highlight ~ -c_gnu GNU gcc specific items -c_comment_strings strings and numbers inside a comment -c_space_errors trailing white space and spaces before a -c_no_trail_space_error ... but no trailing spaces -c_no_tab_space_error ... but no spaces before a -c_no_bracket_error don't highlight {}; inside [] as errors -c_no_curly_error don't highlight {}; inside [] and () as errors; - except { and } in first column -c_curly_error highlight a missing }; this forces syncing from the - start of the file, can be slow -c_no_ansi don't do standard ANSI types and constants -c_ansi_typedefs ... but do standard ANSI types -c_ansi_constants ... but do standard ANSI constants -c_no_utf don't highlight \u and \U in strings -c_syntax_for_h use C syntax for *.h files, instead of C++ -c_no_if0 don't highlight "#if 0" blocks as comments -c_no_cformat don't highlight %-formats in strings -c_no_c99 don't highlight C99 standard items - -When 'foldmethod' is set to "syntax" then /* */ comments and { } blocks will -become a fold. If you don't want comments to become a fold use: > - :let c_no_comment_fold = 1 -"#if 0" blocks are also folded, unless: > - :let c_no_if0_fold = 1 - -If you notice highlighting errors while scrolling backwards, which are fixed -when redrawing with CTRL-L, try setting the "c_minlines" internal variable -to a larger number: > - :let c_minlines = 100 -This will make the syntax synchronization start 100 lines before the first -displayed line. The default value is 50 (15 when c_no_if0 is set). The -disadvantage of using a larger number is that redrawing can become slow. - -When using the "#if 0" / "#endif" comment highlighting, notice that this only -works when the "#if 0" is within "c_minlines" from the top of the window. If -you have a long "#if 0" construct it will not be highlighted correctly. - -To match extra items in comments, use the cCommentGroup cluster. -Example: > - :au Syntax c call MyCadd() - :function MyCadd() - : syn keyword cMyItem contained Ni - : syn cluster cCommentGroup add=cMyItem - : hi link cMyItem Title - :endfun - -ANSI constants will be highlighted with the "cConstant" group. This includes -"NULL", "SIG_IGN" and others. But not "TRUE", for example, because this is -not in the ANSI standard. If you find this confusing, remove the cConstant -highlighting: > - :hi link cConstant NONE - -If you see '{' and '}' highlighted as an error where they are OK, reset the -highlighting for cErrInParen and cErrInBracket. - -If you want to use folding in your C files, you can add these lines in a file -an the "after" directory in 'runtimepath'. For Unix this would be -~/.vim/after/syntax/c.vim. > - syn sync fromstart - set foldmethod=syntax - -CH *ch.vim* *ft-ch-syntax* - -C/C++ interpreter. Ch has similar syntax highlighting to C and builds upon -the C syntax file. See |c.vim| for all the settings that are available for C. - -By setting a variable you can tell Vim to use Ch syntax for *.h files, instead -of C or C++: > - :let ch_syntax_for_h = 1 - - -CHILL *chill.vim* *ft-chill-syntax* - -Chill syntax highlighting is similar to C. See |c.vim| for all the settings -that are available. Additionally there is: - -chill_space_errors like c_space_errors -chill_comment_string like c_comment_strings -chill_minlines like c_minlines - - -CHANGELOG *changelog.vim* *ft-changelog-syntax* - -ChangeLog supports highlighting spaces at the start of a line. -If you do not like this, add following line to your .vimrc: > - let g:changelog_spacing_errors = 0 -This works the next time you edit a changelog file. You can also use -"b:changelog_spacing_errors" to set this per buffer (before loading the syntax -file). - -You can change the highlighting used, e.g., to flag the spaces as an error: > - :hi link ChangelogError Error -Or to avoid the highlighting: > - :hi link ChangelogError NONE -This works immediately. - - -COBOL *cobol.vim* *ft-cobol-syntax* - -COBOL highlighting has different needs for legacy code than it does for fresh -development. This is due to differences in what is being done (maintenance -versus development) and other factors. To enable legacy code highlighting, -add this line to your .vimrc: > - :let cobol_legacy_code = 1 -To disable it again, use this: > - :unlet cobol_legacy_code - - -COLD FUSION *coldfusion.vim* *ft-coldfusion-syntax* - -The ColdFusion has its own version of HTML comments. To turn on ColdFusion -comment highlighting, add the following line to your startup file: > - - :let html_wrong_comments = 1 - -The ColdFusion syntax file is based on the HTML syntax file. - - -CSH *csh.vim* *ft-csh-syntax* - -This covers the shell named "csh". Note that on some systems tcsh is actually -used. - -Detecting whether a file is csh or tcsh is notoriously hard. Some systems -symlink /bin/csh to /bin/tcsh, making it almost impossible to distinguish -between csh and tcsh. In case VIM guesses wrong you can set the -"filetype_csh" variable. For using csh: > - - :let filetype_csh = "csh" - -For using tcsh: > - - :let filetype_csh = "tcsh" - -Any script with a tcsh extension or a standard tcsh filename (.tcshrc, -tcsh.tcshrc, tcsh.login) will have filetype tcsh. All other tcsh/csh scripts -will be classified as tcsh, UNLESS the "filetype_csh" variable exists. If the -"filetype_csh" variable exists, the filetype will be set to the value of the -variable. - - -CYNLIB *cynlib.vim* *ft-cynlib-syntax* - -Cynlib files are C++ files that use the Cynlib class library to enable -hardware modelling and simulation using C++. Typically Cynlib files have a .cc -or a .cpp extension, which makes it very difficult to distinguish them from a -normal C++ file. Thus, to enable Cynlib highlighting for .cc files, add this -line to your .vimrc file: > - - :let cynlib_cyntax_for_cc=1 - -Similarly for cpp files (this extension is only usually used in Windows) > - - :let cynlib_cyntax_for_cpp=1 - -To disable these again, use this: > - - :unlet cynlib_cyntax_for_cc - :unlet cynlib_cyntax_for_cpp -< - -CWEB *cweb.vim* *ft-cweb-syntax* - -Files matching "*.w" could be Progress or cweb. If the automatic detection -doesn't work for you, or you don't edit Progress at all, use this in your -startup vimrc: > - :let filetype_w = "cweb" - - -DESKTOP *desktop.vim* *ft-desktop-syntax* - -Primary goal of this syntax file is to highlight .desktop and .directory files -according to freedesktop.org standard: http://pdx.freedesktop.org/Standards/ -But actually almost none implements this standard fully. Thus it will -highlight all Unix ini files. But you can force strict highlighting according -to standard by placing this in your vimrc file: > - :let enforce_freedesktop_standard = 1 - - -DIRCOLORS *dircolors.vim* *ft-dircolors-syntax* - -The dircolors utility highlighting definition has one option. It exists to -provide compatibility with the Slackware GNU/Linux distributions version of -the command. It adds a few keywords that are generally ignored by most -versions. On Slackware systems, however, the utility accepts the keywords and -uses them for processing. To enable the Slackware keywords add the following -line to your startup file: > - let dircolors_is_slackware = 1 - - -DOCBOOK *docbk.vim* *ft-docbk-syntax* *docbook* -DOCBOOK XML *docbkxml.vim* *ft-docbkxml-syntax* -DOCBOOK SGML *docbksgml.vim* *ft-docbksgml-syntax* - -There are two types of DocBook files: SGML and XML. To specify what type you -are using the "b:docbk_type" variable should be set. Vim does this for you -automatically if it can recognize the type. When Vim can't guess it the type -defaults to XML. -You can set the type manually: > - :let docbk_type = "sgml" -or: > - :let docbk_type = "xml" -You need to do this before loading the syntax file, which is complicated. -Simpler is setting the filetype to "docbkxml" or "docbksgml": > - :set filetype=docbksgml -or: > - :set filetype=docbkxml - - -DOSBATCH *dosbatch.vim* *ft-dosbatch-syntax* - -There is one option with highlighting DOS batch files. This covers new -extensions to the Command Interpreter introduced with Windows 2000 and -is controlled by the variable dosbatch_cmdextversion. For Windows NT -this should have the value 1, and for Windows 2000 it should be 2. -Select the version you want with the following line: > - - :let dosbatch_cmdextversion = 1 - -If this variable is not defined it defaults to a value of 2 to support -Windows 2000. - -A second option covers whether *.btm files should be detected as type -"dosbatch" (MS-DOS batch files) or type "btm" (4DOS batch files). The latter -is used by default. You may select the former with the following line: > - - :let g:dosbatch_syntax_for_btm = 1 - -If this variable is undefined or zero, btm syntax is selected. - - -DOXYGEN *doxygen.vim* *doxygen-syntax* - -Doxygen generates code documentation using a special documentation format -(similar to Javadoc). This syntax script adds doxygen highlighting to c, cpp, -idl and php files, and should also work with java. - -There are a few of ways to turn on doxygen formatting. It can be done -explicitly or in a modeline by appending '.doxygen' to the syntax of the file. -Example: > - :set syntax=c.doxygen -or > - // vim:syntax=c.doxygen - -It can also be done automatically for c, cpp and idl files by setting the -global or buffer-local variable load_doxygen_syntax. This is done by adding -the following to your .vimrc. > - :let g:load_doxygen_syntax=1 - -There are a couple of variables that have an affect on syntax highlighting, and -are to do with non-standard highlighting options. - -Variable Default Effect ~ -g:doxygen_enhanced_color -g:doxygen_enhanced_colour 0 Use non-standard highlighting for - doxygen comments. - -doxygen_my_rendering 0 Disable rendering of HTML bold, italic - and html_my_rendering underline. - -doxygen_javadoc_autobrief 1 Set to 0 to disable javadoc autobrief - colour highlighting. - -doxygen_end_punctuation '[.]' Set to regexp match for the ending - punctuation of brief - -There are also some hilight groups worth mentioning as they can be useful in -configuration. - -Highlight Effect ~ -doxygenErrorComment The colour of an end-comment when missing - punctuation in a code, verbatim or dot section -doxygenLinkError The colour of an end-comment when missing the - \endlink from a \link section. - - -DTD *dtd.vim* *ft-dtd-syntax* - -The DTD syntax highlighting is case sensitive by default. To disable -case-sensitive highlighting, add the following line to your startup file: > - - :let dtd_ignore_case=1 - -The DTD syntax file will highlight unknown tags as errors. If -this is annoying, it can be turned off by setting: > - - :let dtd_no_tag_errors=1 - -before sourcing the dtd.vim syntax file. -Parameter entity names are highlighted in the definition using the -'Type' highlighting group and 'Comment' for punctuation and '%'. -Parameter entity instances are highlighted using the 'Constant' -highlighting group and the 'Type' highlighting group for the -delimiters % and ;. This can be turned off by setting: > - - :let dtd_no_param_entities=1 - -The DTD syntax file is also included by xml.vim to highlight included dtd's. - - -EIFFEL *eiffel.vim* *ft-eiffel-syntax* - -While Eiffel is not case-sensitive, its style guidelines are, and the -syntax highlighting file encourages their use. This also allows to -highlight class names differently. If you want to disable case-sensitive -highlighting, add the following line to your startup file: > - - :let eiffel_ignore_case=1 - -Case still matters for class names and TODO marks in comments. - -Conversely, for even stricter checks, add one of the following lines: > - - :let eiffel_strict=1 - :let eiffel_pedantic=1 - -Setting eiffel_strict will only catch improper capitalization for the -five predefined words "Current", "Void", "Result", "Precursor", and -"NONE", to warn against their accidental use as feature or class names. - -Setting eiffel_pedantic will enforce adherence to the Eiffel style -guidelines fairly rigorously (like arbitrary mixes of upper- and -lowercase letters as well as outdated ways to capitalize keywords). - -If you want to use the lower-case version of "Current", "Void", -"Result", and "Precursor", you can use > - - :let eiffel_lower_case_predef=1 - -instead of completely turning case-sensitive highlighting off. - -Support for ISE's proposed new creation syntax that is already -experimentally handled by some compilers can be enabled by: > - - :let eiffel_ise=1 - -Finally, some vendors support hexadecimal constants. To handle them, add > - - :let eiffel_hex_constants=1 - -to your startup file. - - -ERLANG *erlang.vim* *ft-erlang-syntax* - -The erlang highlighting supports Erlang (ERicsson LANGuage). -Erlang is case sensitive and default extension is ".erl". - -If you want to disable keywords highlighting, put in your .vimrc: > - :let erlang_keywords = 1 -If you want to disable built-in-functions highlighting, put in your -.vimrc file: > - :let erlang_functions = 1 -If you want to disable special characters highlighting, put in -your .vimrc: > - :let erlang_characters = 1 - - -FLEXWIKI *flexwiki.vim* *ft-flexwiki-syntax* - -FlexWiki is an ASP.NET-based wiki package available at http://www.flexwiki.com - -Syntax highlighting is available for the most common elements of FlexWiki -syntax. The associated ftplugin script sets some buffer-local options to make -editing FlexWiki pages more convenient. FlexWiki considers a newline as the -start of a new paragraph, so the ftplugin sets 'tw'=0 (unlimited line length), -'wrap' (wrap long lines instead of using horizontal scrolling), 'linebreak' -(to wrap at a character in 'breakat' instead of at the last char on screen), -and so on. It also includes some keymaps that are disabled by default. - -If you want to enable the keymaps that make "j" and "k" and the cursor keys -move up and down by display lines, add this to your .vimrc: > - :let flexwiki_maps = 1 - - -FORM *form.vim* *ft-form-syntax* - -The coloring scheme for syntax elements in the FORM file uses the default -modes Conditional, Number, Statement, Comment, PreProc, Type, and String, -following the language specifications in 'Symbolic Manipulation with FORM' by -J.A.M. Vermaseren, CAN, Netherlands, 1991. - -If you want include your own changes to the default colors, you have to -redefine the following syntax groups: - - - formConditional - - formNumber - - formStatement - - formHeaderStatement - - formComment - - formPreProc - - formDirective - - formType - - formString - -Note that the form.vim syntax file implements FORM preprocessor commands and -directives per default in the same syntax group. - -A predefined enhanced color mode for FORM is available to distinguish between -header statements and statements in the body of a FORM program. To activate -this mode define the following variable in your vimrc file > - - :let form_enhanced_color=1 - -The enhanced mode also takes advantage of additional color features for a dark -gvim display. Here, statements are colored LightYellow instead of Yellow, and -conditionals are LightBlue for better distinction. - - -FORTRAN *fortran.vim* *ft-fortran-syntax* - -Default highlighting and dialect ~ -Highlighting appropriate for f95 (Fortran 95) is used by default. This choice -should be appropriate for most users most of the time because Fortran 95 is a -superset of Fortran 90 and almost a superset of Fortran 77. - -Fortran source code form ~ -Fortran 9x code can be in either fixed or free source form. Note that the -syntax highlighting will not be correct if the form is incorrectly set. - -When you create a new fortran file, the syntax script assumes fixed source -form. If you always use free source form, then > - :let fortran_free_source=1 -in your .vimrc prior to the :syntax on command. If you always use fixed source -form, then > - :let fortran_fixed_source=1 -in your .vimrc prior to the :syntax on command. - -If the form of the source code depends upon the file extension, then it is -most convenient to set fortran_free_source in a ftplugin file. For more -information on ftplugin files, see |ftplugin|. For example, if all your -fortran files with an .f90 extension are written in free source form and the -rest in fixed source form, add the following code to your ftplugin file > - let s:extfname = expand("%:e") - if s:extfname ==? "f90" - let fortran_free_source=1 - unlet! fortran_fixed_source - else - let fortran_fixed_source=1 - unlet! fortran_free_source - endif -Note that this will work only if the "filetype plugin indent on" command -precedes the "syntax on" command in your .vimrc file. - -When you edit an existing fortran file, the syntax script will assume free -source form if the fortran_free_source variable has been set, and assumes -fixed source form if the fortran_fixed_source variable has been set. If -neither of these variables have been set, the syntax script attempts to -determine which source form has been used by examining the first five columns -of the first 250 lines of your file. If no signs of free source form are -detected, then the file is assumed to be in fixed source form. The algorithm -should work in the vast majority of cases. In some cases, such as a file that -begins with 250 or more full-line comments, the script may incorrectly decide -that the fortran code is in fixed form. If that happens, just add a -non-comment statement beginning anywhere in the first five columns of the -first twenty five lines, save (:w) and then reload (:e!) the file. - -Tabs in fortran files ~ -Tabs are not recognized by the Fortran standards. Tabs are not a good idea in -fixed format fortran source code which requires fixed column boundaries. -Therefore, tabs are marked as errors. Nevertheless, some programmers like -using tabs. If your fortran files contain tabs, then you should set the -variable fortran_have_tabs in your .vimrc with a command such as > - :let fortran_have_tabs=1 -placed prior to the :syntax on command. Unfortunately, the use of tabs will -mean that the syntax file will not be able to detect incorrect margins. - -Syntax folding of fortran files ~ -If you wish to use foldmethod=syntax, then you must first set the variable -fortran_fold with a command such as > - :let fortran_fold=1 -to instruct the syntax script to define fold regions for program units, that -is main programs starting with a program statement, subroutines, function -subprograms, block data subprograms, interface blocks, and modules. If you -also set the variable fortran_fold_conditionals with a command such as > - :let fortran_fold_conditionals=1 -then fold regions will also be defined for do loops, if blocks, and select -case constructs. If you also set the variable -fortran_fold_multilinecomments with a command such as > - :let fortran_fold_multilinecomments=1 -then fold regions will also be defined for three or more consecutive comment -lines. Note that defining fold regions can be slow for large files. - -If fortran_fold, and possibly fortran_fold_conditionals and/or -fortran_fold_multilinecomments, have been set, then vim will fold your file if -you set foldmethod=syntax. Comments or blank lines placed between two program -units are not folded because they are seen as not belonging to any program -unit. - -More precise fortran syntax ~ -If you set the variable fortran_more_precise with a command such as > - :let fortran_more_precise=1 -then the syntax coloring will be more precise but slower. In particular, -statement labels used in do, goto and arithmetic if statements will be -recognized, as will construct names at the end of a do, if, select or forall -construct. - -Non-default fortran dialects ~ -The syntax script supports five Fortran dialects: f95, f90, f77, the Lahey -subset elf90, and the Imagine1 subset F. - -If you use f77 with extensions, even common ones like do/enddo loops, do/while -loops and free source form that are supported by most f77 compilers including -g77 (GNU Fortran), then you will probably find the default highlighting -satisfactory. However, if you use strict f77 with no extensions, not even free -source form or the MIL STD 1753 extensions, then the advantages of setting the -dialect to f77 are that names such as SUM are recognized as user variable -names and not highlighted as f9x intrinsic functions, that obsolete constructs -such as ASSIGN statements are not highlighted as todo items, and that fixed -source form will be assumed. - -If you use elf90 or F, the advantage of setting the dialect appropriately is -that f90 features excluded from these dialects will be highlighted as todo -items and that free source form will be assumed as required for these -dialects. - -The dialect can be selected by setting the variable fortran_dialect. The -permissible values of fortran_dialect are case-sensitive and must be "f95", -"f90", "f77", "elf" or "F". Invalid values of fortran_dialect are ignored. - -If all your fortran files use the same dialect, set fortran_dialect in your -.vimrc prior to your syntax on statement. If the dialect depends upon the file -extension, then it is most convenient to set it in a ftplugin file. For more -information on ftplugin files, see |ftplugin|. For example, if all your -fortran files with an .f90 extension are written in the elf subset, your -ftplugin file should contain the code > - let s:extfname = expand("%:e") - if s:extfname ==? "f90" - let fortran_dialect="elf" - else - unlet! fortran_dialect - endif -Note that this will work only if the "filetype plugin indent on" command -precedes the "syntax on" command in your .vimrc file. - -Finer control is necessary if the file extension does not uniquely identify -the dialect. You can override the default dialect, on a file-by-file basis, by -including a comment with the directive "fortran_dialect=xx" (where xx=f77 or -elf or F or f90 or f95) in one of the first three lines in your file. For -example, your older .f files may be written in extended f77 but your newer -ones may be F codes, and you would identify the latter by including in the -first three lines of those files a Fortran comment of the form > - ! fortran_dialect=F -F overrides elf if both directives are present. - -Limitations ~ -Parenthesis checking does not catch too few closing parentheses. Hollerith -strings are not recognized. Some keywords may be highlighted incorrectly -because Fortran90 has no reserved words. - -For further information related to fortran, see |ft-fortran-indent| and -|ft-fortran-plugin|. - - -FVWM CONFIGURATION FILES *fvwm.vim* *ft-fvwm-syntax* - -In order for Vim to recognize Fvwm configuration files that do not match -the patterns *fvwmrc* or *fvwm2rc* , you must put additional patterns -appropriate to your system in your myfiletypes.vim file. For these -patterns, you must set the variable "b:fvwm_version" to the major version -number of Fvwm, and the 'filetype' option to fvwm. - -For example, to make Vim identify all files in /etc/X11/fvwm2/ -as Fvwm2 configuration files, add the following: > - - :au! BufNewFile,BufRead /etc/X11/fvwm2/* let b:fvwm_version = 2 | - \ set filetype=fvwm - -If you'd like Vim to highlight all valid color names, tell it where to -find the color database (rgb.txt) on your system. Do this by setting -"rgb_file" to its location. Assuming your color database is located -in /usr/X11/lib/X11/, you should add the line > - - :let rgb_file = "/usr/X11/lib/X11/rgb.txt" - -to your .vimrc file. - - -GSP *gsp.vim* *ft-gsp-syntax* - -The default coloring style for GSP pages is defined by |html.vim|, and -the coloring for java code (within java tags or inline between backticks) -is defined by |java.vim|. The following HTML groups defined in |html.vim| -are redefined to incorporate and highlight inline java code: - - htmlString - htmlValue - htmlEndTag - htmlTag - htmlTagN - -Highlighting should look fine most of the places where you'd see inline -java code, but in some special cases it may not. To add another HTML -group where you will have inline java code where it does not highlight -correctly, just copy the line you want from |html.vim| and add gspJava -to the contains clause. - -The backticks for inline java are highlighted according to the htmlError -group to make them easier to see. - - -GROFF *groff.vim* *ft-groff-syntax* - -The groff syntax file is a wrapper for |nroff.vim|, see the notes -under that heading for examples of use and configuration. The purpose -of this wrapper is to set up groff syntax extensions by setting the -filetype from a |modeline| or in a personal filetype definitions file -(see |filetype.txt|). - - -HASKELL *haskell.vim* *lhaskell.vim* *ft-haskell-syntax* - -The Haskell syntax files support plain Haskell code as well as literate -Haskell code, the latter in both Bird style and TeX style. The Haskell -syntax highlighting will also highlight C preprocessor directives. - -If you want to highlight delimiter characters (useful if you have a -light-coloured background), add to your .vimrc: > - :let hs_highlight_delimiters = 1 -To treat True and False as keywords as opposed to ordinary identifiers, -add: > - :let hs_highlight_boolean = 1 -To also treat the names of primitive types as keywords: > - :let hs_highlight_types = 1 -And to treat the names of even more relatively common types as keywords: > - :let hs_highlight_more_types = 1 -If you want to highlight the names of debugging functions, put in -your .vimrc: > - :let hs_highlight_debug = 1 - -The Haskell syntax highlighting also highlights C preprocessor -directives, and flags lines that start with # but are not valid -directives as erroneous. This interferes with Haskell's syntax for -operators, as they may start with #. If you want to highlight those -as operators as opposed to errors, put in your .vimrc: > - :let hs_allow_hash_operator = 1 - -The syntax highlighting for literate Haskell code will try to -automatically guess whether your literate Haskell code contains -TeX markup or not, and correspondingly highlight TeX constructs -or nothing at all. You can override this globally by putting -in your .vimrc > - :let lhs_markup = none -for no highlighting at all, or > - :let lhs_markup = tex -to force the highlighting to always try to highlight TeX markup. -For more flexibility, you may also use buffer local versions of -this variable, so e.g. > - :let b:lhs_markup = tex -will force TeX highlighting for a particular buffer. It has to be -set before turning syntax highlighting on for the buffer or -loading a file. - - -HTML *html.vim* *ft-html-syntax* - -The coloring scheme for tags in the HTML file works as follows. - -The <> of opening tags are colored differently than the of a closing tag. -This is on purpose! For opening tags the 'Function' color is used, while for -closing tags the 'Type' color is used (See syntax.vim to check how those are -defined for you) - -Known tag names are colored the same way as statements in C. Unknown tag -names are colored with the same color as the <> or respectively which -makes it easy to spot errors - -Note that the same is true for argument (or attribute) names. Known attribute -names are colored differently than unknown ones. - -Some HTML tags are used to change the rendering of text. The following tags -are recognized by the html.vim syntax coloring file and change the way normal -text is shown: ( is used as an alias for , -while as an alias for ),

-

, , and <A>, but -only if used as a link (that is, it must include a href as in -<A href="somefile.html">). - -If you want to change how such text is rendered, you must redefine the -following syntax groups: - - - htmlBold - - htmlBoldUnderline - - htmlBoldUnderlineItalic - - htmlUnderline - - htmlUnderlineItalic - - htmlItalic - - htmlTitle for titles - - htmlH1 - htmlH6 for headings - -To make this redefinition work you must redefine them all with the exception -of the last two (htmlTitle and htmlH[1-6], which are optional) and define the -following variable in your vimrc (this is due to the order in which the files -are read during initialization) > - :let html_my_rendering=1 - -If you'd like to see an example download mysyntax.vim at -http://www.fleiner.com/vim/download.html - -You can also disable this rendering by adding the following line to your -vimrc file: > - :let html_no_rendering=1 - -HTML comments are rather special (see an HTML reference document for the -details), and the syntax coloring scheme will highlight all errors. -However, if you prefer to use the wrong style (starts with <!-- and -ends with --!>) you can define > - :let html_wrong_comments=1 - -JavaScript and Visual Basic embedded inside HTML documents are highlighted as -'Special' with statements, comments, strings and so on colored as in standard -programming languages. Note that only JavaScript and Visual Basic are currently -supported, no other scripting language has been added yet. - -Embedded and inlined cascading style sheets (CSS) are highlighted too. - -There are several html preprocessor languages out there. html.vim has been -written such that it should be trivial to include it. To do so add the -following two lines to the syntax coloring file for that language -(the example comes from the asp.vim file): - - runtime! syntax/html.vim - syn cluster htmlPreproc add=asp - -Now you just need to make sure that you add all regions that contain -the preprocessor language to the cluster htmlPreproc. - - -HTML/OS (by Aestiva) *htmlos.vim* *ft-htmlos-syntax* - -The coloring scheme for HTML/OS works as follows: - -Functions and variable names are the same color by default, because VIM -doesn't specify different colors for Functions and Identifiers. To change -this (which is recommended if you want function names to be recognizable in a -different color) you need to add the following line to either your ~/.vimrc: > - :hi Function term=underline cterm=bold ctermfg=LightGray - -Of course, the ctermfg can be a different color if you choose. - -Another issues that HTML/OS runs into is that there is no special filetype to -signify that it is a file with HTML/OS coding. You can change this by opening -a file and turning on HTML/OS syntax by doing the following: > - :set syntax=htmlos - -Lastly, it should be noted that the opening and closing characters to begin a -block of HTML/OS code can either be << or [[ and >> or ]], respectively. - - -IA64 *ia64.vim* *intel-itanium* *ft-ia64-syntax* - -Highlighting for the Intel Itanium 64 assembly language. See |asm.vim| for -how to recognize this filetype. - -To have *.inc files be recognized as IA64, add this to your .vimrc file: > - :let g:filetype_inc = "ia64" - - -INFORM *inform.vim* *ft-inform-syntax* - -Inform highlighting includes symbols provided by the Inform Library, as -most programs make extensive use of it. If do not wish Library symbols -to be highlighted add this to your vim startup: > - :let inform_highlight_simple=1 - -By default it is assumed that Inform programs are Z-machine targeted, -and highlights Z-machine assembly language symbols appropriately. If -you intend your program to be targeted to a Glulx/Glk environment you -need to add this to your startup sequence: > - :let inform_highlight_glulx=1 - -This will highlight Glulx opcodes instead, and also adds glk() to the -set of highlighted system functions. - -The Inform compiler will flag certain obsolete keywords as errors when -it encounters them. These keywords are normally highlighted as errors -by Vim. To prevent such error highlighting, you must add this to your -startup sequence: > - :let inform_suppress_obsolete=1 - -By default, the language features highlighted conform to Compiler -version 6.30 and Library version 6.11. If you are using an older -Inform development environment, you may with to add this to your -startup sequence: > - :let inform_highlight_old=1 - -IDL *idl.vim* *idl-syntax* - -IDL (Interface Definition Language) files are used to define RPC calls. In -Microsoft land, this is also used for defining COM interfaces and calls. - -IDL's structure is simple enough to permit a full grammar based approach to -rather than using a few heuristics. The result is large and somewhat -repetitive but seems to work. - -There are some Microsoft extensions to idl files that are here. Some of them -are disabled by defining idl_no_ms_extensions. - -The more complex of the extensions are disabled by defining idl_no_extensions. - -Variable Effect ~ - -idl_no_ms_extensions Disable some of the Microsoft specific - extensions -idl_no_extensions Disable complex extensions -idlsyntax_showerror Show IDL errors (can be rather intrusive, but - quite helpful) -idlsyntax_showerror_soft Use softer colours by default for errors - - -JAVA *java.vim* *ft-java-syntax* - -The java.vim syntax highlighting file offers several options: - -In Java 1.0.2 it was never possible to have braces inside parens, so this was -flagged as an error. Since Java 1.1 this is possible (with anonymous -classes), and therefore is no longer marked as an error. If you prefer the old -way, put the following line into your vim startup file: > - :let java_mark_braces_in_parens_as_errors=1 - -All identifiers in java.lang.* are always visible in all classes. To -highlight them use: > - :let java_highlight_java_lang_ids=1 - -You can also highlight identifiers of most standard Java packages if you -download the javaid.vim script at http://www.fleiner.com/vim/download.html. -If you prefer to only highlight identifiers of a certain package, say java.io -use the following: > - :let java_highlight_java_io=1 -Check the javaid.vim file for a list of all the packages that are supported. - -Function names are not highlighted, as the way to find functions depends on -how you write Java code. The syntax file knows two possible ways to highlight -functions: - -If you write function declarations that are always indented by either -a tab, 8 spaces or 2 spaces you may want to set > - :let java_highlight_functions="indent" -However, if you follow the Java guidelines about how functions and classes are -supposed to be named (with respect to upper and lowercase), use > - :let java_highlight_functions="style" -If both options do not work for you, but you would still want function -declarations to be highlighted create your own definitions by changing the -definitions in java.vim or by creating your own java.vim which includes the -original one and then adds the code to highlight functions. - -In Java 1.1 the functions System.out.println() and System.err.println() should -only be used for debugging. Therefore it is possible to highlight debugging -statements differently. To do this you must add the following definition in -your startup file: > - :let java_highlight_debug=1 -The result will be that those statements are highlighted as 'Special' -characters. If you prefer to have them highlighted differently you must define -new highlightings for the following groups.: - Debug, DebugSpecial, DebugString, DebugBoolean, DebugType -which are used for the statement itself, special characters used in debug -strings, strings, boolean constants and types (this, super) respectively. I -have opted to chose another background for those statements. - -In order to help you write code that can be easily ported between Java and -C++, all C++ keywords can be marked as an error in a Java program. To -have this add this line in your .vimrc file: > - :let java_allow_cpp_keywords = 0 - -Javadoc is a program that takes special comments out of Java program files and -creates HTML pages. The standard configuration will highlight this HTML code -similarly to HTML files (see |html.vim|). You can even add Javascript -and CSS inside this code (see below). There are four differences however: - 1. The title (all characters up to the first '.' which is followed by - some white space or up to the first '@') is colored differently (to change - the color change the group CommentTitle). - 2. The text is colored as 'Comment'. - 3. HTML comments are colored as 'Special' - 4. The special Javadoc tags (@see, @param, ...) are highlighted as specials - and the argument (for @see, @param, @exception) as Function. -To turn this feature off add the following line to your startup file: > - :let java_ignore_javadoc=1 - -If you use the special Javadoc comment highlighting described above you -can also turn on special highlighting for Javascript, visual basic -scripts and embedded CSS (stylesheets). This makes only sense if you -actually have Javadoc comments that include either Javascript or embedded -CSS. The options to use are > - :let java_javascript=1 - :let java_css=1 - :let java_vb=1 - -In order to highlight nested parens with different colors define colors -for javaParen, javaParen1 and javaParen2, for example with > - :hi link javaParen Comment -or > - :hi javaParen ctermfg=blue guifg=#0000ff - -If you notice highlighting errors while scrolling backwards, which are fixed -when redrawing with CTRL-L, try setting the "java_minlines" internal variable -to a larger number: > - :let java_minlines = 50 -This will make the syntax synchronization start 50 lines before the first -displayed line. The default value is 10. The disadvantage of using a larger -number is that redrawing can become slow. - - -LACE *lace.vim* *ft-lace-syntax* - -Lace (Language for Assembly of Classes in Eiffel) is case insensitive, but the -style guide lines are not. If you prefer case insensitive highlighting, just -define the vim variable 'lace_case_insensitive' in your startup file: > - :let lace_case_insensitive=1 - - -LEX *lex.vim* *ft-lex-syntax* - -Lex uses brute-force synchronizing as the "^%%$" section delimiter -gives no clue as to what section follows. Consequently, the value for > - :syn sync minlines=300 -may be changed by the user if s/he is experiencing synchronization -difficulties (such as may happen with large lex files). - - -LISP *lisp.vim* *ft-lisp-syntax* - -The lisp syntax highlighting provides two options: > - - g:lisp_instring : if it exists, then "(...)" strings are highlighted - as if the contents of the string were lisp. - Useful for AutoLisp. - g:lisp_rainbow : if it exists and is nonzero, then differing levels - of parenthesization will receive different - highlighting. -< -The g:lisp_rainbow option provides 10 levels of individual colorization for -the parentheses and backquoted parentheses. Because of the quantity of -colorization levels, unlike non-rainbow highlighting, the rainbow mode -specifies its highlighting using ctermfg and guifg, thereby bypassing the -usual colorscheme control using standard highlighting groups. The actual -highlighting used depends on the dark/bright setting (see |'bg'|). - - -LITE *lite.vim* *ft-lite-syntax* - -There are two options for the lite syntax highlighting. - -If you like SQL syntax highlighting inside Strings, use this: > - - :let lite_sql_query = 1 - -For syncing, minlines defaults to 100. If you prefer another value, you can -set "lite_minlines" to the value you desire. Example: > - - :let lite_minlines = 200 - - -LPC *lpc.vim* *ft-lpc-syntax* - -LPC stands for a simple, memory-efficient language: Lars Pensj| C. The -file name of LPC is usually *.c. Recognizing these files as LPC would bother -users writing only C programs. If you want to use LPC syntax in Vim, you -should set a variable in your .vimrc file: > - - :let lpc_syntax_for_c = 1 - -If it doesn't work properly for some particular C or LPC files, use a -modeline. For a LPC file: - - // vim:set ft=lpc: - -For a C file that is recognized as LPC: - - // vim:set ft=c: - -If you don't want to set the variable, use the modeline in EVERY LPC file. - -There are several implementations for LPC, we intend to support most widely -used ones. Here the default LPC syntax is for MudOS series, for MudOS v22 -and before, you should turn off the sensible modifiers, and this will also -asserts the new efuns after v22 to be invalid, don't set this variable when -you are using the latest version of MudOS: > - - :let lpc_pre_v22 = 1 - -For LpMud 3.2 series of LPC: > - - :let lpc_compat_32 = 1 - -For LPC4 series of LPC: > - - :let lpc_use_lpc4_syntax = 1 - -For uLPC series of LPC: -uLPC has been developed to Pike, so you should use Pike syntax -instead, and the name of your source file should be *.pike - - -LUA *lua.vim* *ft-lua-syntax* - -This syntax file may be used for Lua 4.0, Lua 5.0 or Lua 5.1 (the latter is -the default). You can select one of these versions using the global variables -lua_version and lua_subversion. For example, to activate Lua -4.0 syntax highlighting, use this command: > - - :let lua_version = 4 - -If you are using Lua 5.0, use these commands: > - - :let lua_version = 5 - :let lua_subversion = 0 - -To restore highlighting for Lua 5.1: > - - :let lua_version = 5 - :let lua_subversion = 1 - - -MAIL *mail.vim* *ft-mail.vim* - -Vim highlights all the standard elements of an email (headers, signatures, -quoted text and URLs / email addresses). In keeping with standard conventions, -signatures begin in a line containing only "--" followed optionally by -whitespaces and end with a newline. - -Vim treats lines beginning with ']', '}', '|', '>' or a word followed by '>' -as quoted text. However Vim highlights headers and signatures in quoted text -only if the text is quoted with '>' (optionally followed by one space). - -By default mail.vim synchronises syntax to 100 lines before the first -displayed line. If you have a slow machine, and generally deal with emails -with short headers, you can change this to a smaller value: > - - :let mail_minlines = 30 - - -MAKE *make.vim* *ft-make-syntax* - -In makefiles, commands are usually highlighted to make it easy for you to spot -errors. However, this may be too much coloring for you. You can turn this -feature off by using: > - - :let make_no_commands = 1 - - -MAPLE *maple.vim* *ft-maple-syntax* - -Maple V, by Waterloo Maple Inc, supports symbolic algebra. The language -supports many packages of functions which are selectively loaded by the user. -The standard set of packages' functions as supplied in Maple V release 4 may be -highlighted at the user's discretion. Users may place in their .vimrc file: > - - :let mvpkg_all= 1 - -to get all package functions highlighted, or users may select any subset by -choosing a variable/package from the table below and setting that variable to -1, also in their .vimrc file (prior to sourcing -$VIMRUNTIME/syntax/syntax.vim). - - Table of Maple V Package Function Selectors > - mv_DEtools mv_genfunc mv_networks mv_process - mv_Galois mv_geometry mv_numapprox mv_simplex - mv_GaussInt mv_grobner mv_numtheory mv_stats - mv_LREtools mv_group mv_orthopoly mv_student - mv_combinat mv_inttrans mv_padic mv_sumtools - mv_combstruct mv_liesymm mv_plots mv_tensor - mv_difforms mv_linalg mv_plottools mv_totorder - mv_finance mv_logic mv_powseries - - -MATHEMATICA *mma.vim* *ft-mma-syntax* *ft-mathematica-syntax* - -Empty *.m files will automatically be presumed to be Matlab files unless you -have the following in your .vimrc: > - - let filetype_m = "mma" - - -MOO *moo.vim* *ft-moo-syntax* - -If you use C-style comments inside expressions and find it mangles your -highlighting, you may want to use extended (slow!) matches for C-style -comments: > - - :let moo_extended_cstyle_comments = 1 - -To disable highlighting of pronoun substitution patterns inside strings: > - - :let moo_no_pronoun_sub = 1 - -To disable highlighting of the regular expression operator '%|', and matching -'%(' and '%)' inside strings: > - - :let moo_no_regexp = 1 - -Unmatched double quotes can be recognized and highlighted as errors: > - - :let moo_unmatched_quotes = 1 - -To highlight builtin properties (.name, .location, .programmer etc.): > - - :let moo_builtin_properties = 1 - -Unknown builtin functions can be recognized and highlighted as errors. If you -use this option, add your own extensions to the mooKnownBuiltinFunction group. -To enable this option: > - - :let moo_unknown_builtin_functions = 1 - -An example of adding sprintf() to the list of known builtin functions: > - - :syn keyword mooKnownBuiltinFunction sprintf contained - - -MSQL *msql.vim* *ft-msql-syntax* - -There are two options for the msql syntax highlighting. - -If you like SQL syntax highlighting inside Strings, use this: > - - :let msql_sql_query = 1 - -For syncing, minlines defaults to 100. If you prefer another value, you can -set "msql_minlines" to the value you desire. Example: > - - :let msql_minlines = 200 - - -NCF *ncf.vim* *ft-ncf-syntax* - -There is one option for NCF syntax highlighting. - -If you want to have unrecognized (by ncf.vim) statements highlighted as -errors, use this: > - - :let ncf_highlight_unknowns = 1 - -If you don't want to highlight these errors, leave it unset. - - -NROFF *nroff.vim* *ft-nroff-syntax* - -The nroff syntax file works with AT&T n/troff out of the box. You need to -activate the GNU groff extra features included in the syntax file before you -can use them. - -For example, Linux and BSD distributions use groff as their default text -processing package. In order to activate the extra syntax highlighting -features for groff, add the following option to your start-up files: > - - :let b:nroff_is_groff = 1 - -Groff is different from the old AT&T n/troff that you may still find in -Solaris. Groff macro and request names can be longer than 2 characters and -there are extensions to the language primitives. For example, in AT&T troff -you access the year as a 2-digit number with the request \(yr. In groff you -can use the same request, recognized for compatibility, or you can use groff's -native syntax, \[yr]. Furthermore, you can use a 4-digit year directly: -\[year]. Macro requests can be longer than 2 characters, for example, GNU mm -accepts the requests ".VERBON" and ".VERBOFF" for creating verbatim -environments. - -In order to obtain the best formatted output g/troff can give you, you should -follow a few simple rules about spacing and punctuation. - -1. Do not leave empty spaces at the end of lines. - -2. Leave one space and one space only after an end-of-sentence period, - exclamation mark, etc. - -3. For reasons stated below, it is best to follow all period marks with a - carriage return. - -The reason behind these unusual tips is that g/n/troff have a line breaking -algorithm that can be easily upset if you don't follow the rules given above. - -Unlike TeX, troff fills text line-by-line, not paragraph-by-paragraph and, -furthermore, it does not have a concept of glue or stretch, all horizontal and -vertical space input will be output as is. - -Therefore, you should be careful about not using more space between sentences -than you intend to have in your final document. For this reason, the common -practice is to insert a carriage return immediately after all punctuation -marks. If you want to have "even" text in your final processed output, you -need to maintaining regular spacing in the input text. To mark both trailing -spaces and two or more spaces after a punctuation as an error, use: > - - :let nroff_space_errors = 1 - -Another technique to detect extra spacing and other errors that will interfere -with the correct typesetting of your file, is to define an eye-catching -highlighting definition for the syntax groups "nroffDefinition" and -"nroffDefSpecial" in your configuration files. For example: > - - hi def nroffDefinition term=italic cterm=italic gui=reverse - hi def nroffDefSpecial term=italic,bold cterm=italic,bold - \ gui=reverse,bold - -If you want to navigate preprocessor entries in your source file as easily as -with section markers, you can activate the following option in your .vimrc -file: > - - let b:preprocs_as_sections = 1 - -As well, the syntax file adds an extra paragraph marker for the extended -paragraph macro (.XP) in the ms package. - -Finally, there is a |groff.vim| syntax file that can be used for enabling -groff syntax highlighting either on a file basis or globally by default. - - -OCAML *ocaml.vim* *ft-ocaml-syntax* - -The OCaml syntax file handles files having the following prefixes: .ml, -.mli, .mll and .mly. By setting the following variable > - - :let ocaml_revised = 1 - -you can switch from standard OCaml-syntax to revised syntax as supported -by the camlp4 preprocessor. Setting the variable > - - :let ocaml_noend_error = 1 - -prevents highlighting of "end" as error, which is useful when sources -contain very long structures that Vim does not synchronize anymore. - - -PAPP *papp.vim* *ft-papp-syntax* - -The PApp syntax file handles .papp files and, to a lesser extend, .pxml -and .pxsl files which are all a mixture of perl/xml/html/other using xml -as the top-level file format. By default everything inside phtml or pxml -sections is treated as a string with embedded preprocessor commands. If -you set the variable: > - - :let papp_include_html=1 - -in your startup file it will try to syntax-hilight html code inside phtml -sections, but this is relatively slow and much too colourful to be able to -edit sensibly. ;) - -The newest version of the papp.vim syntax file can usually be found at -http://papp.plan9.de. - - -PASCAL *pascal.vim* *ft-pascal-syntax* - -Files matching "*.p" could be Progress or Pascal. If the automatic detection -doesn't work for you, or you don't edit Progress at all, use this in your -startup vimrc: > - - :let filetype_p = "pascal" - -The Pascal syntax file has been extended to take into account some extensions -provided by Turbo Pascal, Free Pascal Compiler and GNU Pascal Compiler. -Delphi keywords are also supported. By default, Turbo Pascal 7.0 features are -enabled. If you prefer to stick with the standard Pascal keywords, add the -following line to your startup file: > - - :let pascal_traditional=1 - -To switch on Delphi specific constructions (such as one-line comments, -keywords, etc): > - - :let pascal_delphi=1 - - -The option pascal_symbol_operator controls whether symbol operators such as +, -*, .., etc. are displayed using the Operator color or not. To colorize symbol -operators, add the following line to your startup file: > - - :let pascal_symbol_operator=1 - -Some functions are highlighted by default. To switch it off: > - - :let pascal_no_functions=1 - -Furthermore, there are specific variable for some compiler. Besides -pascal_delphi, there are pascal_gpc and pascal_fpc. Default extensions try to -match Turbo Pascal. > - - :let pascal_gpc=1 - -or > - - :let pascal_fpc=1 - -To ensure that strings are defined on a single line, you can define the -pascal_one_line_string variable. > - - :let pascal_one_line_string=1 - -If you dislike <Tab> chars, you can set the pascal_no_tabs variable. Tabs -will be highlighted as Error. > - - :let pascal_no_tabs=1 - - - -PERL *perl.vim* *ft-perl-syntax* - -There are a number of possible options to the perl syntax highlighting. - -If you use POD files or POD segments, you might: > - - :let perl_include_pod = 1 - -The reduce the complexity of parsing (and increase performance) you can switch -off two elements in the parsing of variable names and contents. > - -To handle package references in variable and function names not differently -from the rest of the name (like 'PkgName::' in '$PkgName::VarName'): > - - :let perl_no_scope_in_variables = 1 - -(In Vim 6.x it was the other way around: "perl_want_scope_in_variables" -enabled it.) - -If you do not want complex things like '@{${"foo"}}' to be parsed: > - - :let perl_no_extended_vars = 1 - -(In Vim 6.x it was the other way around: "perl_extended_vars" enabled it.) - -The coloring strings can be changed. By default strings and qq friends will be -highlighted like the first line. If you set the variable -perl_string_as_statement, it will be highlighted as in the second line. - - "hello world!"; qq|hello world|; - ^^^^^^^^^^^^^^NN^^^^^^^^^^^^^^^N (unlet perl_string_as_statement) - S^^^^^^^^^^^^SNNSSS^^^^^^^^^^^SN (let perl_string_as_statement) - -(^ = perlString, S = perlStatement, N = None at all) - -The syncing has 3 options. The first two switch off some triggering of -synchronization and should only be needed in case it fails to work properly. -If while scrolling all of a sudden the whole screen changes color completely -then you should try and switch off one of those. Let me know if you can figure -out the line that causes the mistake. - -One triggers on "^\s*sub\s*" and the other on "^[$@%]" more or less. > - - :let perl_no_sync_on_sub - :let perl_no_sync_on_global_var - -Below you can set the maximum distance VIM should look for starting points for -its attempts in syntax highlighting. > - - :let perl_sync_dist = 100 - -If you want to use folding with perl, set perl_fold: > - - :let perl_fold = 1 - -If you want to fold blocks in if statements, etc. as well set the following: > - - :let perl_fold_blocks = 1 - -To avoid folding packages or subs when perl_fold is let, let the appropriate -variable(s): > - - :unlet perl_nofold_packages - :unlet perl_nofold_subs - - - -PHP3 and PHP4 *php.vim* *php3.vim* *ft-php-syntax* *ft-php3-syntax* - -[note: previously this was called "php3", but since it now also supports php4 -it has been renamed to "php"] - -There are the following options for the php syntax highlighting. - -If you like SQL syntax highlighting inside Strings: > - - let php_sql_query = 1 - -For highlighting the Baselib methods: > - - let php_baselib = 1 - -Enable HTML syntax highlighting inside strings: > - - let php_htmlInStrings = 1 - -Using the old colorstyle: > - - let php_oldStyle = 1 - -Enable highlighting ASP-style short tags: > - - let php_asp_tags = 1 - -Disable short tags: > - - let php_noShortTags = 1 - -For highlighting parent error ] or ): > - - let php_parent_error_close = 1 - -For skipping an php end tag, if there exists an open ( or [ without a closing -one: > - - let php_parent_error_open = 1 - -Enable folding for classes and functions: > - - let php_folding = 1 - -Selecting syncing method: > - - let php_sync_method = x - -x = -1 to sync by search (default), -x > 0 to sync at least x lines backwards, -x = 0 to sync from start. - - -PLAINTEX *plaintex.vim* *ft-plaintex-syntax* - -TeX is a typesetting language, and plaintex is the file type for the "plain" -variant of TeX. If you never want your *.tex files recognized as plain TeX, -see |ft-tex-plugin|. - -This syntax file has the option > - - let g:plaintex_delimiters = 1 - -if you want to highlight brackets "[]" and braces "{}". - - -PPWIZARD *ppwiz.vim* *ft-ppwiz-syntax* - -PPWizard is a preprocessor for HTML and OS/2 INF files - -This syntax file has the options: - -- ppwiz_highlight_defs : determines highlighting mode for PPWizard's - definitions. Possible values are - - ppwiz_highlight_defs = 1 : PPWizard #define statements retain the - colors of their contents (e.g. PPWizard macros and variables) - - ppwiz_highlight_defs = 2 : preprocessor #define and #evaluate - statements are shown in a single color with the exception of line - continuation symbols - - The default setting for ppwiz_highlight_defs is 1. - -- ppwiz_with_html : If the value is 1 (the default), highlight literal - HTML code; if 0, treat HTML code like ordinary text. - - -PHTML *phtml.vim* *ft-phtml-syntax* - -There are two options for the phtml syntax highlighting. - -If you like SQL syntax highlighting inside Strings, use this: > - - :let phtml_sql_query = 1 - -For syncing, minlines defaults to 100. If you prefer another value, you can -set "phtml_minlines" to the value you desire. Example: > - - :let phtml_minlines = 200 - - -POSTSCRIPT *postscr.vim* *ft-postscr-syntax* - -There are several options when it comes to highlighting PostScript. - -First which version of the PostScript language to highlight. There are -currently three defined language versions, or levels. Level 1 is the original -and base version, and includes all extensions prior to the release of level 2. -Level 2 is the most common version around, and includes its own set of -extensions prior to the release of level 3. Level 3 is currently the highest -level supported. You select which level of the PostScript language you want -highlighted by defining the postscr_level variable as follows: > - - :let postscr_level=2 - -If this variable is not defined it defaults to 2 (level 2) since this is -the most prevalent version currently. - -Note, not all PS interpreters will support all language features for a -particular language level. In particular the %!PS-Adobe-3.0 at the start of -PS files does NOT mean the PostScript present is level 3 PostScript! - -If you are working with Display PostScript, you can include highlighting of -Display PS language features by defining the postscr_display variable as -follows: > - - :let postscr_display=1 - -If you are working with Ghostscript, you can include highlighting of -Ghostscript specific language features by defining the variable -postscr_ghostscript as follows: > - - :let postscr_ghostscript=1 - -PostScript is a large language, with many predefined elements. While it -useful to have all these elements highlighted, on slower machines this can -cause Vim to slow down. In an attempt to be machine friendly font names and -character encodings are not highlighted by default. Unless you are working -explicitly with either of these this should be ok. If you want them to be -highlighted you should set one or both of the following variables: > - - :let postscr_fonts=1 - :let postscr_encodings=1 - -There is a stylistic option to the highlighting of and, or, and not. In -PostScript the function of these operators depends on the types of their -operands - if the operands are booleans then they are the logical operators, -if they are integers then they are binary operators. As binary and logical -operators can be highlighted differently they have to be highlighted one way -or the other. By default they are treated as logical operators. They can be -highlighted as binary operators by defining the variable -postscr_andornot_binary as follows: > - - :let postscr_andornot_binary=1 -< - - *ptcap.vim* *ft-printcap-syntax* -PRINTCAP + TERMCAP *ft-ptcap-syntax* *ft-termcap-syntax* - -This syntax file applies to the printcap and termcap databases. - -In order for Vim to recognize printcap/termcap files that do not match -the patterns *printcap*, or *termcap*, you must put additional patterns -appropriate to your system in your |myfiletypefile| file. For these -patterns, you must set the variable "b:ptcap_type" to either "print" or -"term", and then the 'filetype' option to ptcap. - -For example, to make Vim identify all files in /etc/termcaps/ as termcap -files, add the following: > - - :au BufNewFile,BufRead /etc/termcaps/* let b:ptcap_type = "term" | - \ set filetype=ptcap - -If you notice highlighting errors while scrolling backwards, which -are fixed when redrawing with CTRL-L, try setting the "ptcap_minlines" -internal variable to a larger number: > - - :let ptcap_minlines = 50 - -(The default is 20 lines.) - - -PROGRESS *progress.vim* *ft-progress-syntax* - -Files matching "*.w" could be Progress or cweb. If the automatic detection -doesn't work for you, or you don't edit cweb at all, use this in your -startup vimrc: > - :let filetype_w = "progress" -The same happens for "*.i", which could be assembly, and "*.p", which could be -Pascal. Use this if you don't use assembly and Pascal: > - :let filetype_i = "progress" - :let filetype_p = "progress" - - -PYTHON *python.vim* *ft-python-syntax* - -There are four options to control Python syntax highlighting. - -For highlighted numbers: > - :let python_highlight_numbers = 1 - -For highlighted builtin functions: > - :let python_highlight_builtins = 1 - -For highlighted standard exceptions: > - :let python_highlight_exceptions = 1 - -For highlighted trailing whitespace and mix of spaces and tabs: - :let python_highlight_space_errors = 1 - -If you want all possible Python highlighting (the same as setting the -preceding three options): > - :let python_highlight_all = 1 - - -QUAKE *quake.vim* *ft-quake-syntax* - -The Quake syntax definition should work for most any FPS (First Person -Shooter) based on one of the Quake engines. However, the command names vary -a bit between the three games (Quake, Quake 2, and Quake 3 Arena) so the -syntax definition checks for the existence of three global variables to allow -users to specify what commands are legal in their files. The three variables -can be set for the following effects: - -set to highlight commands only available in Quake: > - :let quake_is_quake1 = 1 - -set to highlight commands only available in Quake 2: > - :let quake_is_quake2 = 1 - -set to highlight commands only available in Quake 3 Arena: > - :let quake_is_quake3 = 1 - -Any combination of these three variables is legal, but might highlight more -commands than are actually available to you by the game. - - -READLINE *readline.vim* *ft-readline-syntax* - -The readline library is primarily used by the BASH shell, which adds quite a -few commands and options to the ones already available. To highlight these -items as well you can add the following to your |vimrc| or just type it in the -command line before loading a file with the readline syntax: > - let readline_has_bash = 1 - -This will add highlighting for the commands that BASH (version 2.05a and -later, and part earlier) adds. - - -REXX *rexx.vim* *ft-rexx-syntax* - -If you notice highlighting errors while scrolling backwards, which are fixed -when redrawing with CTRL-L, try setting the "rexx_minlines" internal variable -to a larger number: > - :let rexx_minlines = 50 -This will make the syntax synchronization start 50 lines before the first -displayed line. The default value is 10. The disadvantage of using a larger -number is that redrawing can become slow. - - -RUBY *ruby.vim* *ft-ruby-syntax* - -There are a number of options to the Ruby syntax highlighting. - -By default, the "end" keyword is colorized according to the opening statement -of the block it closes. While useful, this feature can be expensive; if you -experience slow redrawing (or you are on a terminal with poor color support) -you may want to turn it off by defining the "ruby_no_expensive" variable: > - - :let ruby_no_expensive = 1 -< -In this case the same color will be used for all control keywords. - -If you do want this feature enabled, but notice highlighting errors while -scrolling backwards, which are fixed when redrawing with CTRL-L, try setting -the "ruby_minlines" variable to a value larger than 50: > - - :let ruby_minlines = 100 -< -Ideally, this value should be a number of lines large enough to embrace your -largest class or module. - -Highlighting of special identifiers can be disabled by removing the -rubyIdentifier highlighting: > - - :hi link rubyIdentifier NONE -< -This will prevent highlighting of special identifiers like "ConstantName", -"$global_var", "@@class_var", "@instance_var", "| block_param |", and -":symbol". - -Significant methods of Kernel, Module and Object are highlighted by default. -This can be disabled by defining "ruby_no_special_methods": > - - :let ruby_no_special_methods = 1 -< -This will prevent highlighting of important methods such as "require", "attr", -"private", "raise" and "proc". - -Ruby operators can be highlighted. This is enabled by defining -"ruby_operators": > - - :let ruby_operators = 1 -< -Whitespace errors can be highlighted by defining "ruby_space_errors": > - - :let ruby_space_errors = 1 -< -This will highlight trailing whitespace and tabs preceded by a space character -as errors. This can be refined by defining "ruby_no_trail_space_error" and -"ruby_no_tab_space_error" which will ignore trailing whitespace and tabs after -spaces respectively. - -Folding can be enabled by defining "ruby_fold": > - - :let ruby_fold = 1 -< -This will set the 'foldmethod' option to "syntax" and allow folding of -classes, modules, methods, code blocks, heredocs and comments. - -Folding of multiline comments can be disabled by defining -"ruby_no_comment_fold": > - - :let ruby_no_comment_fold = 1 -< - -SCHEME *scheme.vim* *ft-scheme-syntax* - -By default only R5RS keywords are highlighted and properly indented. - -MzScheme-specific stuff will be used if b:is_mzscheme or g:is_mzscheme -variables are defined. - -Also scheme.vim supports keywords of the Chicken Scheme->C compiler. Define -b:is_chicken or g:is_chicken, if you need them. - - -SDL *sdl.vim* *ft-sdl-syntax* - -The SDL highlighting probably misses a few keywords, but SDL has so many -of them it's almost impossibly to cope. - -The new standard, SDL-2000, specifies that all identifiers are -case-sensitive (which was not so before), and that all keywords can be -used either completely lowercase or completely uppercase. To have the -highlighting reflect this, you can set the following variable: > - :let sdl_2000=1 - -This also sets many new keywords. If you want to disable the old -keywords, which is probably a good idea, use: > - :let SDL_no_96=1 - - -The indentation is probably also incomplete, but right now I am very -satisfied with it for my own projects. - - -SED *sed.vim* *ft-sed-syntax* - -To make tabs stand out from regular blanks (accomplished by using Todo -highlighting on the tabs), define "highlight_sedtabs" by putting > - - :let highlight_sedtabs = 1 - -in the vimrc file. (This special highlighting only applies for tabs -inside search patterns, replacement texts, addresses or text included -by an Append/Change/Insert command.) If you enable this option, it is -also a good idea to set the tab width to one character; by doing that, -you can easily count the number of tabs in a string. - -Bugs: - - The transform command (y) is treated exactly like the substitute - command. This means that, as far as this syntax file is concerned, - transform accepts the same flags as substitute, which is wrong. - (Transform accepts no flags.) I tolerate this bug because the - involved commands need very complex treatment (95 patterns, one for - each plausible pattern delimiter). - - -SGML *sgml.vim* *ft-sgml-syntax* - -The coloring scheme for tags in the SGML file works as follows. - -The <> of opening tags are colored differently than the </> of a closing tag. -This is on purpose! For opening tags the 'Function' color is used, while for -closing tags the 'Type' color is used (See syntax.vim to check how those are -defined for you) - -Known tag names are colored the same way as statements in C. Unknown tag -names are not colored which makes it easy to spot errors. - -Note that the same is true for argument (or attribute) names. Known attribute -names are colored differently than unknown ones. - -Some SGML tags are used to change the rendering of text. The following tags -are recognized by the sgml.vim syntax coloring file and change the way normal -text is shown: <varname> <emphasis> <command> <function> <literal> -<replaceable> <ulink> and <link>. - -If you want to change how such text is rendered, you must redefine the -following syntax groups: - - - sgmlBold - - sgmlBoldItalic - - sgmlUnderline - - sgmlItalic - - sgmlLink for links - -To make this redefinition work you must redefine them all and define the -following variable in your vimrc (this is due to the order in which the files -are read during initialization) > - let sgml_my_rendering=1 - -You can also disable this rendering by adding the following line to your -vimrc file: > - let sgml_no_rendering=1 - -(Adapted from the html.vim help text by Claudio Fleiner <claudio@fleiner.com>) - - -SH *sh.vim* *ft-sh-syntax* *ft-bash-syntax* *ft-ksh-syntax* - -This covers the "normal" Unix (Bourne) sh, bash and the Korn shell. - -Vim attempts to determine which shell type is in use by specifying that -various filenames are of specific types: > - - ksh : .kshrc* *.ksh - bash: .bashrc* bashrc bash.bashrc .bash_profile* *.bash -< -If none of these cases pertain, then the first line of the file is examined -(ex. /bin/sh /bin/ksh /bin/bash). If the first line specifies a shelltype, -then that shelltype is used. However some files (ex. .profile) are known to -be shell files but the type is not apparent. Furthermore, on many systems -sh is symbolically linked to "bash" (Linux, Windows+cygwin) or "ksh" (Posix). - -One may specify a global default by instantiating one of the following three -variables in your <.vimrc>: - - ksh: > - let g:is_kornshell = 1 -< posix: (using this is the same as setting is_kornshell to 1) > - let g:is_posix = 1 -< bash: > - let g:is_bash = 1 -< sh: (default) Bourne shell > - let g:is_sh = 1 - -If there's no "#! ..." line, and the user hasn't availed himself/herself of a -default sh.vim syntax setting as just shown, then syntax/sh.vim will assume -the Bourne shell syntax. No need to quote RFCs or market penetration -statistics in error reports, please -- just select the default version of the -sh your system uses in your <.vimrc>. - -The syntax/sh.vim file provides several levels of syntax-based folding: > - - let g:sh_fold_enabled= 0 (default, no syntax folding) - let g:sh_fold_enabled= 1 (enable function folding) - let g:sh_fold_enabled= 2 (enable heredoc folding) - let g:sh_fold_enabled= 4 (enable if/do/for folding) -> -then various syntax items (HereDocuments and function bodies) become -syntax-foldable (see |:syn-fold|). You also may add these together -to get multiple types of folding: > - - let g:sh_fold_enabled= 3 (enables function and heredoc folding) - -If you notice highlighting errors while scrolling backwards which are fixed -when one redraws with CTRL-L, try setting the "sh_minlines" internal variable -to a larger number. Example: > - - let sh_minlines = 500 - -This will make syntax synchronization start 500 lines before the first -displayed line. The default value is 200. The disadvantage of using a larger -number is that redrawing can become slow. - -If you don't have much to synchronize on, displaying can be very slow. To -reduce this, the "sh_maxlines" internal variable can be set. Example: > - - let sh_maxlines = 100 -< -The default is to use the twice sh_minlines. Set it to a smaller number to -speed up displaying. The disadvantage is that highlight errors may appear. - - -SPEEDUP (AspenTech plant simulator) *spup.vim* *ft-spup-syntax* - -The Speedup syntax file has some options: - -- strict_subsections : If this variable is defined, only keywords for - sections and subsections will be highlighted as statements but not - other keywords (like WITHIN in the OPERATION section). - -- highlight_types : Definition of this variable causes stream types - like temperature or pressure to be highlighted as Type, not as a - plain Identifier. Included are the types that are usually found in - the DECLARE section; if you defined own types, you have to include - them in the syntax file. - -- oneline_comments : this value ranges from 1 to 3 and determines the - highlighting of # style comments. - - oneline_comments = 1 : allow normal Speedup code after an even - number of #s. - - oneline_comments = 2 : show code starting with the second # as - error. This is the default setting. - - oneline_comments = 3 : show the whole line as error if it contains - more than one #. - -Since especially OPERATION sections tend to become very large due to -PRESETting variables, syncing may be critical. If your computer is -fast enough, you can increase minlines and/or maxlines near the end of -the syntax file. - - -SQL *sql.vim* *ft-sql-syntax* - *sqlinformix.vim* *ft-sqlinformix-syntax* - *sqlanywhere.vim* *ft-sqlanywhere-syntax* - -While there is an ANSI standard for SQL, most database engines add their own -custom extensions. Vim currently supports the Oracle and Informix dialects of -SQL. Vim assumes "*.sql" files are Oracle SQL by default. - -Vim currently has SQL support for a variety of different vendors via syntax -scripts. You can change Vim's default from Oracle to any of the current SQL -supported types. You can also easily alter the SQL dialect being used on a -buffer by buffer basis. - -For more detailed instructions see |ft_sql.txt|. - - -TCSH *tcsh.vim* *ft-tcsh-syntax* - -This covers the shell named "tcsh". It is a superset of csh. See |csh.vim| -for how the filetype is detected. - -Tcsh does not allow \" in strings unless the "backslash_quote" shell variable -is set. If you want VIM to assume that no backslash quote constructs exist add -this line to your .vimrc: > - - :let tcsh_backslash_quote = 0 - -If you notice highlighting errors while scrolling backwards, which are fixed -when redrawing with CTRL-L, try setting the "tcsh_minlines" internal variable -to a larger number: > - - :let tcsh_minlines = 100 - -This will make the syntax synchronization start 100 lines before the first -displayed line. The default value is 15. The disadvantage of using a larger -number is that redrawing can become slow. - - -TEX *tex.vim* *ft-tex-syntax* - - *tex-folding* -Want Syntax Folding? ~ - -As of version 28 of <syntax/tex.vim>, syntax-based folding of parts, chapters, -sections, subsections, etc are supported. Put > - let g:tex_fold_enabled=1 -in your <.vimrc>, and :set fdm=syntax. I suggest doing the latter via a -modeline at the end of your LaTeX file: > - % vim: fdm=syntax -< - *tex-nospell* -Don't Want Spell Checking In Comments? ~ - -Some folks like to include things like source code in comments and so would -prefer that spell checking be disabled in comments in LaTeX files. To do -this, put the following in your <.vimrc>: > - let g:tex_comment_nospell= 1 -< - *tex-runon* -Run-on Comments/Math? ~ - -The <syntax/tex.vim> highlighting supports TeX, LaTeX, and some AmsTeX. The -highlighting supports three primary zones/regions: normal, texZone, and -texMathZone. Although considerable effort has been made to have these zones -terminate properly, zones delineated by $..$ and $$..$$ cannot be synchronized -as there's no difference between start and end patterns. Consequently, a -special "TeX comment" has been provided > - %stopzone -which will forcibly terminate the highlighting of either a texZone or a -texMathZone. - - *tex-slow* -Slow Syntax Highlighting? ~ - -If you have a slow computer, you may wish to reduce the values for > - :syn sync maxlines=200 - :syn sync minlines=50 -(especially the latter). If your computer is fast, you may wish to -increase them. This primarily affects synchronizing (i.e. just what group, -if any, is the text at the top of the screen supposed to be in?). - - *tex-morecommands* *tex-package* -Want To Highlight More Commands? ~ - -LaTeX is a programmable language, and so there are thousands of packages full -of specialized LaTeX commands, syntax, and fonts. If you're using such a -package you'll often wish that the distributed syntax/tex.vim would support -it. However, clearly this is impractical. So please consider using the -techniques in |mysyntaxfile-add| to extend or modify the highlighting provided -by syntax/tex.vim. - - *tex-error* -Excessive Error Highlighting? ~ - -The <tex.vim> supports lexical error checking of various sorts. Thus, -although the error checking is ofttimes very useful, it can indicate -errors where none actually are. If this proves to be a problem for you, -you may put in your <.vimrc> the following statement: > - let tex_no_error=1 -and all error checking by <syntax/tex.vim> will be suppressed. - - *tex-math* -Need a new Math Group? ~ - -If you want to include a new math group in your LaTeX, the following -code shows you an example as to how you might do so: > - call TexNewMathZone(sfx,mathzone,starform) -You'll want to provide the new math group with a unique suffix -(currently, A-L and V-Z are taken by <syntax/tex.vim> itself). -As an example, consider how eqnarray is set up by <syntax/tex.vim>: > - call TexNewMathZone("D","eqnarray",1) -You'll need to change "mathzone" to the name of your new math group, -and then to the call to it in .vim/after/syntax/tex.vim. -The "starform" variable, if true, implies that your new math group -has a starred form (ie. eqnarray*). - - *tex-style* -Starting a New Style? ~ - -One may use "\makeatletter" in *.tex files, thereby making the use of "@" in -commands available. However, since the *.tex file doesn't have one of the -following suffices: sty cls clo dtx ltx, the syntax highlighting will flag -such use of @ as an error. To solve this: > - - :let b:tex_stylish = 1 - :set ft=tex - -Putting "let g:tex_stylish=1" into your <.vimrc> will make <syntax/tex.vim> -always accept such use of @. - - -TF *tf.vim* *ft-tf-syntax* - -There is one option for the tf syntax highlighting. - -For syncing, minlines defaults to 100. If you prefer another value, you can -set "tf_minlines" to the value you desire. Example: > - - :let tf_minlines = your choice - - -VIM *vim.vim* *ft-vim-syntax* - *g:vimsyn_minlines* *g:vimsyn_maxlines* -There is a tradeoff between more accurate syntax highlighting versus screen -updating speed. To improve accuracy, you may wish to increase the -g:vimsyn_minlines variable. The g:vimsyn_maxlines variable may be used to -improve screen updating rates (see |:syn-sync| for more on this). > - - g:vimsyn_minlines : used to set synchronization minlines - g:vimsyn_maxlines : used to set synchronization maxlines -< - (g:vim_minlines and g:vim_maxlines are deprecated variants of - these two options) - - *g:vimsyn_embed* -The g:vimsyn_embed option allows users to select what, if any, types of -embedded script highlighting they wish to have. > - - g:vimsyn_embed == 0 : don't embed any scripts - g:vimsyn_embed =~ 'm' : embed mzscheme (but only if vim supports it) - g:vimsyn_embed =~ 'p' : embed perl (but only if vim supports it) - g:vimsyn_embed =~ 'P' : embed python (but only if vim supports it) - g:vimsyn_embed =~ 'r' : embed ruby (but only if vim supports it) - g:vimsyn_embed =~ 't' : embed tcl (but only if vim supports it) -< -By default, g:vimsyn_embed is "mpPr"; ie. syntax/vim.vim will support -highlighting mzscheme, perl, python, and ruby by default. Vim's has("tcl") -test appears to hang vim when tcl is not truly available. Thus, by default, -tcl is not supported for embedding (but those of you who like tcl embedded in -their vim syntax highlighting can simply include it in the g:vimembedscript -option). - *g:vimsyn_folding* - -Some folding is now supported with syntax/vim.vim: > - - g:vimsyn_folding == 0 or doesn't exist: no syntax-based folding - g:vimsyn_folding =~ 'a' : augroups - g:vimsyn_folding =~ 'f' : fold functions - g:vimsyn_folding =~ 'm' : fold mzscheme script - g:vimsyn_folding =~ 'p' : fold perl script - g:vimsyn_folding =~ 'P' : fold python script - g:vimsyn_folding =~ 'r' : fold ruby script - g:vimsyn_folding =~ 't' : fold tcl script - - *g:vimsyn_noerror* -Not all error highlighting that syntax/vim.vim does may be correct; VimL is a -difficult language to highlight correctly. A way to suppress error -highlighting is to put the following line in your |vimrc|: > - - let g:vimsyn_noerror = 1 -< - - -XF86CONFIG *xf86conf.vim* *ft-xf86conf-syntax* - -The syntax of XF86Config file differs in XFree86 v3.x and v4.x. Both -variants are supported. Automatic detection is used, but is far from perfect. -You may need to specify the version manually. Set the variable -xf86conf_xfree86_version to 3 or 4 according to your XFree86 version in -your .vimrc. Example: > - :let xf86conf_xfree86_version=3 -When using a mix of versions, set the b:xf86conf_xfree86_version variable. - -Note that spaces and underscores in option names are not supported. Use -"SyncOnGreen" instead of "__s yn con gr_e_e_n" if you want the option name -highlighted. - - -XML *xml.vim* *ft-xml-syntax* - -Xml namespaces are highlighted by default. This can be inhibited by -setting a global variable: > - - :let g:xml_namespace_transparent=1 -< - *xml-folding* -The xml syntax file provides syntax |folding| (see |:syn-fold|) between -start and end tags. This can be turned on by > - - :let g:xml_syntax_folding = 1 - :set foldmethod=syntax - -Note: syntax folding might slow down syntax highlighting significantly, -especially for large files. - - -X Pixmaps (XPM) *xpm.vim* *ft-xpm-syntax* - -xpm.vim creates its syntax items dynamically based upon the contents of the -XPM file. Thus if you make changes e.g. in the color specification strings, -you have to source it again e.g. with ":set syn=xpm". - -To copy a pixel with one of the colors, yank a "pixel" with "yl" and insert it -somewhere else with "P". - -Do you want to draw with the mouse? Try the following: > - :function! GetPixel() - : let c = getline(".")[col(".") - 1] - : echo c - : exe "noremap <LeftMouse> <LeftMouse>r".c - : exe "noremap <LeftDrag> <LeftMouse>r".c - :endfunction - :noremap <RightMouse> <LeftMouse>:call GetPixel()<CR> - :set guicursor=n:hor20 " to see the color beneath the cursor -This turns the right button into a pipette and the left button into a pen. -It will work with XPM files that have one character per pixel only and you -must not click outside of the pixel strings, but feel free to improve it. - -It will look much better with a font in a quadratic cell size, e.g. for X: > - :set guifont=-*-clean-medium-r-*-*-8-*-*-*-*-80-* - -============================================================================== -5. Defining a syntax *:syn-define* *E410* - -Vim understands three types of syntax items: - -1. Keyword - It can only contain keyword characters, according to the 'iskeyword' - option. It cannot contain other syntax items. It will only match with a - complete word (there are no keyword characters before or after the match). - The keyword "if" would match in "if(a=b)", but not in "ifdef x", because - "(" is not a keyword character and "d" is. - -2. Match - This is a match with a single regexp pattern. - -3. Region - This starts at a match of the "start" regexp pattern and ends with a match - with the "end" regexp pattern. Any other text can appear in between. A - "skip" regexp pattern can be used to avoid matching the "end" pattern. - -Several syntax ITEMs can be put into one syntax GROUP. For a syntax group -you can give highlighting attributes. For example, you could have an item -to define a "/* .. */" comment and another one that defines a "// .." comment, -and put them both in the "Comment" group. You can then specify that a -"Comment" will be in bold font and have a blue color. You are free to make -one highlight group for one syntax item, or put all items into one group. -This depends on how you want to specify your highlighting attributes. Putting -each item in its own group results in having to specify the highlighting -for a lot of groups. - -Note that a syntax group and a highlight group are similar. For a highlight -group you will have given highlight attributes. These attributes will be used -for the syntax group with the same name. - -In case more than one item matches at the same position, the one that was -defined LAST wins. Thus you can override previously defined syntax items by -using an item that matches the same text. But a keyword always goes before a -match or region. And a keyword with matching case always goes before a -keyword with ignoring case. - - -PRIORITY *:syn-priority* - -When several syntax items may match, these rules are used: - -1. When multiple Match or Region items start in the same position, the item - defined last has priority. -2. A Keyword has priority over Match and Region items. -3. An item that starts in an earlier position has priority over items that - start in later positions. - - -DEFINING CASE *:syn-case* *E390* - -:sy[ntax] case [match | ignore] - This defines if the following ":syntax" commands will work with - matching case, when using "match", or with ignoring case, when using - "ignore". Note that any items before this are not affected, and all - items until the next ":syntax case" command are affected. - - -SPELL CHECKING *:syn-spell* - -:sy[ntax] spell [toplevel | notoplevel | default] - This defines where spell checking is to be done for text that is not - in a syntax item: - - toplevel: Text is spell checked. - notoplevel: Text is not spell checked. - default: When there is a @Spell cluster no spell checking. - - For text in syntax items use the @Spell and @NoSpell clusters - |spell-syntax|. When there is no @Spell and no @NoSpell cluster then - spell checking is done for "default" and "toplevel". - - To activate spell checking the 'spell' option must be set. - - -DEFINING KEYWORDS *:syn-keyword* - -:sy[ntax] keyword {group-name} [{options}] {keyword} .. [{options}] - - This defines a number of keywords. - - {group-name} Is a syntax group name such as "Comment". - [{options}] See |:syn-arguments| below. - {keyword} .. Is a list of keywords which are part of this group. - - Example: > - :syntax keyword Type int long char -< - The {options} can be given anywhere in the line. They will apply to - all keywords given, also for options that come after a keyword. - These examples do exactly the same: > - :syntax keyword Type contained int long char - :syntax keyword Type int long contained char - :syntax keyword Type int long char contained -< *E789* - When you have a keyword with an optional tail, like Ex commands in - Vim, you can put the optional characters inside [], to define all the - variations at once: > - :syntax keyword vimCommand ab[breviate] n[ext] -< - Don't forget that a keyword can only be recognized if all the - characters are included in the 'iskeyword' option. If one character - isn't, the keyword will never be recognized. - Multi-byte characters can also be used. These do not have to be in - 'iskeyword'. - - A keyword always has higher priority than a match or region, the - keyword is used if more than one item matches. Keywords do not nest - and a keyword can't contain anything else. - - Note that when you have a keyword that is the same as an option (even - one that isn't allowed here), you can not use it. Use a match - instead. - - The maximum length of a keyword is 80 characters. - - The same keyword can be defined multiple times, when its containment - differs. For example, you can define the keyword once not contained - and use one highlight group, and once contained, and use a different - highlight group. Example: > - :syn keyword vimCommand tag - :syn keyword vimSetting contained tag -< When finding "tag" outside of any syntax item, the "vimCommand" - highlight group is used. When finding "tag" in a syntax item that - contains "vimSetting", the "vimSetting" group is used. - - -DEFINING MATCHES *:syn-match* - -:sy[ntax] match {group-name} [{options}] [excludenl] {pattern} [{options}] - - This defines one match. - - {group-name} A syntax group name such as "Comment". - [{options}] See |:syn-arguments| below. - [excludenl] Don't make a pattern with the end-of-line "$" - extend a containing match or region. Must be - given before the pattern. |:syn-excludenl| - {pattern} The search pattern that defines the match. - See |:syn-pattern| below. - Note that the pattern may match more than one - line, which makes the match depend on where - Vim starts searching for the pattern. You - need to make sure syncing takes care of this. - - Example (match a character constant): > - :syntax match Character /'.'/hs=s+1,he=e-1 -< - -DEFINING REGIONS *:syn-region* *:syn-start* *:syn-skip* *:syn-end* - *E398* *E399* -:sy[ntax] region {group-name} [{options}] - [matchgroup={group-name}] - [keepend] - [extend] - [excludenl] - start={start_pattern} .. - [skip={skip_pattern}] - end={end_pattern} .. - [{options}] - - This defines one region. It may span several lines. - - {group-name} A syntax group name such as "Comment". - [{options}] See |:syn-arguments| below. - [matchgroup={group-name}] The syntax group to use for the following - start or end pattern matches only. Not used - for the text in between the matched start and - end patterns. Use NONE to reset to not using - a different group for the start or end match. - See |:syn-matchgroup|. - keepend Don't allow contained matches to go past a - match with the end pattern. See - |:syn-keepend|. - extend Override a "keepend" for an item this region - is contained in. See |:syn-extend|. - excludenl Don't make a pattern with the end-of-line "$" - extend a containing match or item. Only - useful for end patterns. Must be given before - the patterns it applies to. |:syn-excludenl| - start={start_pattern} The search pattern that defines the start of - the region. See |:syn-pattern| below. - skip={skip_pattern} The search pattern that defines text inside - the region where not to look for the end - pattern. See |:syn-pattern| below. - end={end_pattern} The search pattern that defines the end of - the region. See |:syn-pattern| below. - - Example: > - :syntax region String start=+"+ skip=+\\"+ end=+"+ -< - The start/skip/end patterns and the options can be given in any order. - There can be zero or one skip pattern. There must be one or more - start and end patterns. This means that you can omit the skip - pattern, but you must give at least one start and one end pattern. It - is allowed to have white space before and after the equal sign - (although it mostly looks better without white space). - - When more than one start pattern is given, a match with one of these - is sufficient. This means there is an OR relation between the start - patterns. The last one that matches is used. The same is true for - the end patterns. - - The search for the end pattern starts right after the start pattern. - Offsets are not used for this. This implies that the match for the - end pattern will never overlap with the start pattern. - - The skip and end pattern can match across line breaks, but since the - search for the pattern can start in any line it often does not do what - you want. The skip pattern doesn't avoid a match of an end pattern in - the next line. Use single-line patterns to avoid trouble. - - Note: The decision to start a region is only based on a matching start - pattern. There is no check for a matching end pattern. This does NOT - work: > - :syn region First start="(" end=":" - :syn region Second start="(" end=";" -< The Second always matches before the First (last defined pattern has - higher priority). The Second region then continues until the next - ';', no matter if there is a ':' before it. Using a match does work: > - :syn match First "(\_.\{-}:" - :syn match Second "(\_.\{-};" -< This pattern matches any character or line break with "\_." and - repeats that with "\{-}" (repeat as few as possible). - - *:syn-keepend* - By default, a contained match can obscure a match for the end pattern. - This is useful for nesting. For example, a region that starts with - "{" and ends with "}", can contain another region. An encountered "}" - will then end the contained region, but not the outer region: - { starts outer "{}" region - { starts contained "{}" region - } ends contained "{}" region - } ends outer "{} region - If you don't want this, the "keepend" argument will make the matching - of an end pattern of the outer region also end any contained item. - This makes it impossible to nest the same region, but allows for - contained items to highlight parts of the end pattern, without causing - that to skip the match with the end pattern. Example: > - :syn match vimComment +"[^"]\+$+ - :syn region vimCommand start="set" end="$" contains=vimComment keepend -< The "keepend" makes the vimCommand always end at the end of the line, - even though the contained vimComment includes a match with the <EOL>. - - When "keepend" is not used, a match with an end pattern is retried - after each contained match. When "keepend" is included, the first - encountered match with an end pattern is used, truncating any - contained matches. - *:syn-extend* - The "keepend" behavior can be changed by using the "extend" argument. - When an item with "extend" is contained in an item that uses - "keepend", the "keepend" is ignored and the containing region will be - extended. - This can be used to have some contained items extend a region while - others don't. Example: > - - :syn region htmlRef start=+<a>+ end=+</a>+ keepend contains=htmlItem,htmlScript - :syn match htmlItem +<[^>]*>+ contained - :syn region htmlScript start=+<script+ end=+</script[^>]*>+ contained extend - -< Here the htmlItem item does not make the htmlRef item continue - further, it is only used to highlight the <> items. The htmlScript - item does extend the htmlRef item. - - Another example: > - :syn region xmlFold start="<a>" end="</a>" fold transparent keepend extend -< This defines a region with "keepend", so that its end cannot be - changed by contained items, like when the "</a>" is matched to - highlight it differently. But when the xmlFold region is nested (it - includes itself), the "extend" applies, so that the "</a>" of a nested - region only ends that region, and not the one it is contained in. - - *:syn-excludenl* - When a pattern for a match or end pattern of a region includes a '$' - to match the end-of-line, it will make a region item that it is - contained in continue on the next line. For example, a match with - "\\$" (backslash at the end of the line) can make a region continue - that would normally stop at the end of the line. This is the default - behavior. If this is not wanted, there are two ways to avoid it: - 1. Use "keepend" for the containing item. This will keep all - contained matches from extending the match or region. It can be - used when all contained items must not extend the containing item. - 2. Use "excludenl" in the contained item. This will keep that match - from extending the containing match or region. It can be used if - only some contained items must not extend the containing item. - "excludenl" must be given before the pattern it applies to. - - *:syn-matchgroup* - "matchgroup" can be used to highlight the start and/or end pattern - differently than the body of the region. Example: > - :syntax region String matchgroup=Quote start=+"+ skip=+\\"+ end=+"+ -< This will highlight the quotes with the "Quote" group, and the text in - between with the "String" group. - The "matchgroup" is used for all start and end patterns that follow, - until the next "matchgroup". Use "matchgroup=NONE" to go back to not - using a matchgroup. - - In a start or end pattern that is highlighted with "matchgroup" the - contained items of the region are not used. This can be used to avoid - that a contained item matches in the start or end pattern match. When - using "transparent", this does not apply to a start or end pattern - match that is highlighted with "matchgroup". - - Here is an example, which highlights three levels of parentheses in - different colors: > - :sy region par1 matchgroup=par1 start=/(/ end=/)/ contains=par2 - :sy region par2 matchgroup=par2 start=/(/ end=/)/ contains=par3 contained - :sy region par3 matchgroup=par3 start=/(/ end=/)/ contains=par1 contained - :hi par1 ctermfg=red guifg=red - :hi par2 ctermfg=blue guifg=blue - :hi par3 ctermfg=darkgreen guifg=darkgreen - -============================================================================== -6. :syntax arguments *:syn-arguments* - -The :syntax commands that define syntax items take a number of arguments. -The common ones are explained here. The arguments may be given in any order -and may be mixed with patterns. - -Not all commands accept all arguments. This table shows which arguments -can not be used for all commands: - *E395* *E396* - contains oneline fold display extend ~ -:syntax keyword - - - - - -:syntax match yes - yes yes yes -:syntax region yes yes yes yes yes - -These arguments can be used for all three commands: - contained - containedin - nextgroup - transparent - skipwhite - skipnl - skipempty - - -contained *:syn-contained* - -When the "contained" argument is given, this item will not be recognized at -the top level, but only when it is mentioned in the "contains" field of -another match. Example: > - :syntax keyword Todo TODO contained - :syntax match Comment "//.*" contains=Todo - - -display *:syn-display* - -If the "display" argument is given, this item will be skipped when the -detected highlighting will not be displayed. This will speed up highlighting, -by skipping this item when only finding the syntax state for the text that is -to be displayed. - -Generally, you can use "display" for match and region items that meet these -conditions: -- The item does not continue past the end of a line. Example for C: A region - for a "/*" comment can't contain "display", because it continues on the next - line. -- The item does not contain items that continue past the end of the line or - make it continue on the next line. -- The item does not change the size of any item it is contained in. Example - for C: A match with "\\$" in a preprocessor match can't have "display", - because it may make that preprocessor match shorter. -- The item does not allow other items to match that didn't match otherwise, - and that item may extend the match too far. Example for C: A match for a - "//" comment can't use "display", because a "/*" inside that comment would - match then and start a comment which extends past the end of the line. - -Examples, for the C language, where "display" can be used: -- match with a number -- match with a label - - -transparent *:syn-transparent* - -If the "transparent" argument is given, this item will not be highlighted -itself, but will take the highlighting of the item it is contained in. This -is useful for syntax items that don't need any highlighting but are used -only to skip over a part of the text. - -The "contains=" argument is also inherited from the item it is contained in, -unless a "contains" argument is given for the transparent item itself. To -avoid that unwanted items are contained, use "contains=NONE". Example, which -highlights words in strings, but makes an exception for "vim": > - :syn match myString /'[^']*'/ contains=myWord,myVim - :syn match myWord /\<[a-z]*\>/ contained - :syn match myVim /\<vim\>/ transparent contained contains=NONE - :hi link myString String - :hi link myWord Comment -Since the "myVim" match comes after "myWord" it is the preferred match (last -match in the same position overrules an earlier one). The "transparent" -argument makes the "myVim" match use the same highlighting as "myString". But -it does not contain anything. If the "contains=NONE" argument would be left -out, then "myVim" would use the contains argument from myString and allow -"myWord" to be contained, which will be highlighted as a Constant. This -happens because a contained match doesn't match inside itself in the same -position, thus the "myVim" match doesn't overrule the "myWord" match here. - -When you look at the colored text, it is like looking at layers of contained -items. The contained item is on top of the item it is contained in, thus you -see the contained item. When a contained item is transparent, you can look -through, thus you see the item it is contained in. In a picture: - - look from here - - | | | | | | - V V V V V V - - xxxx yyy more contained items - .................... contained item (transparent) - ============================= first item - -The 'x', 'y' and '=' represent a highlighted syntax item. The '.' represent a -transparent group. - -What you see is: - - =======xxxx=======yyy======== - -Thus you look through the transparent "....". - - -oneline *:syn-oneline* - -The "oneline" argument indicates that the region does not cross a line -boundary. It must match completely in the current line. However, when the -region has a contained item that does cross a line boundary, it continues on -the next line anyway. A contained item can be used to recognize a line -continuation pattern. But the "end" pattern must still match in the first -line, otherwise the region doesn't even start. - -When the start pattern includes a "\n" to match an end-of-line, the end -pattern must be found in the same line as where the start pattern ends. The -end pattern may also include an end-of-line. Thus the "oneline" argument -means that the end of the start pattern and the start of the end pattern must -be within one line. This can't be changed by a skip pattern that matches a -line break. - - -fold *:syn-fold* - -The "fold" argument makes the fold level increase by one for this item. -Example: > - :syn region myFold start="{" end="}" transparent fold - :syn sync fromstart - :set foldmethod=syntax -This will make each {} block form one fold. - -The fold will start on the line where the item starts, and end where the item -ends. If the start and end are within the same line, there is no fold. -The 'foldnestmax' option limits the nesting of syntax folds. -{not available when Vim was compiled without |+folding| feature} - - - *:syn-contains* *E405* *E406* *E407* *E408* *E409* -contains={groupname},.. - -The "contains" argument is followed by a list of syntax group names. These -groups will be allowed to begin inside the item (they may extend past the -containing group's end). This allows for recursive nesting of matches and -regions. If there is no "contains" argument, no groups will be contained in -this item. The group names do not need to be defined before they can be used -here. - -contains=ALL - If the only item in the contains list is "ALL", then all - groups will be accepted inside the item. - -contains=ALLBUT,{group-name},.. - If the first item in the contains list is "ALLBUT", then all - groups will be accepted inside the item, except the ones that - are listed. Example: > - :syntax region Block start="{" end="}" ... contains=ALLBUT,Function - -contains=TOP - If the first item in the contains list is "TOP", then all - groups will be accepted that don't have the "contained" - argument. -contains=TOP,{group-name},.. - Like "TOP", but excluding the groups that are listed. - -contains=CONTAINED - If the first item in the contains list is "CONTAINED", then - all groups will be accepted that have the "contained" - argument. -contains=CONTAINED,{group-name},.. - Like "CONTAINED", but excluding the groups that are - listed. - - -The {group-name} in the "contains" list can be a pattern. All group names -that match the pattern will be included (or excluded, if "ALLBUT" is used). -The pattern cannot contain white space or a ','. Example: > - ... contains=Comment.*,Keyw[0-3] -The matching will be done at moment the syntax command is executed. Groups -that are defined later will not be matched. Also, if the current syntax -command defines a new group, it is not matched. Be careful: When putting -syntax commands in a file you can't rely on groups NOT being defined, because -the file may have been sourced before, and ":syn clear" doesn't remove the -group names. - -The contained groups will also match in the start and end patterns of a -region. If this is not wanted, the "matchgroup" argument can be used -|:syn-matchgroup|. The "ms=" and "me=" offsets can be used to change the -region where contained items do match. Note that this may also limit the -area that is highlighted - - -containedin={groupname}... *:syn-containedin* - -The "containedin" argument is followed by a list of syntax group names. The -item will be allowed to begin inside these groups. This works as if the -containing item has a "contains=" argument that includes this item. - -The {groupname}... can be used just like for "contains", as explained above. - -This is useful when adding a syntax item afterwards. An item can be told to -be included inside an already existing item, without changing the definition -of that item. For example, to highlight a word in a C comment after loading -the C syntax: > - :syn keyword myword HELP containedin=cComment contained -Note that "contained" is also used, to avoid that the item matches at the top -level. - -Matches for "containedin" are added to the other places where the item can -appear. A "contains" argument may also be added as usual. Don't forget that -keywords never contain another item, thus adding them to "containedin" won't -work. - - -nextgroup={groupname},.. *:syn-nextgroup* - -The "nextgroup" argument is followed by a list of syntax group names, -separated by commas (just like with "contains", so you can also use patterns). - -If the "nextgroup" argument is given, the mentioned syntax groups will be -tried for a match, after the match or region ends. If none of the groups have -a match, highlighting continues normally. If there is a match, this group -will be used, even when it is not mentioned in the "contains" field of the -current group. This is like giving the mentioned group priority over all -other groups. Example: > - :syntax match ccFoobar "Foo.\{-}Bar" contains=ccFoo - :syntax match ccFoo "Foo" contained nextgroup=ccFiller - :syntax region ccFiller start="." matchgroup=ccBar end="Bar" contained - -This will highlight "Foo" and "Bar" differently, and only when there is a -"Bar" after "Foo". In the text line below, "f" shows where ccFoo is used for -highlighting, and "bbb" where ccBar is used. > - - Foo asdfasd Bar asdf Foo asdf Bar asdf - fff bbb fff bbb - -Note the use of ".\{-}" to skip as little as possible until the next Bar. -when ".*" would be used, the "asdf" in between "Bar" and "Foo" would be -highlighted according to the "ccFoobar" group, because the ccFooBar match -would include the first "Foo" and the last "Bar" in the line (see |pattern|). - - -skipwhite *:syn-skipwhite* -skipnl *:syn-skipnl* -skipempty *:syn-skipempty* - -These arguments are only used in combination with "nextgroup". They can be -used to allow the next group to match after skipping some text: - skipwhite skip over space and tab characters - skipnl skip over the end of a line - skipempty skip over empty lines (implies a "skipnl") - -When "skipwhite" is present, the white space is only skipped if there is no -next group that matches the white space. - -When "skipnl" is present, the match with nextgroup may be found in the next -line. This only happens when the current item ends at the end of the current -line! When "skipnl" is not present, the nextgroup will only be found after -the current item in the same line. - -When skipping text while looking for a next group, the matches for other -groups are ignored. Only when no next group matches, other items are tried -for a match again. This means that matching a next group and skipping white -space and <EOL>s has a higher priority than other items. - -Example: > - :syn match ifstart "\<if.*" nextgroup=ifline skipwhite skipempty - :syn match ifline "[^ \t].*" nextgroup=ifline skipwhite skipempty contained - :syn match ifline "endif" contained -Note that the "[^ \t].*" match matches all non-white text. Thus it would also -match "endif". Therefore the "endif" match is put last, so that it takes -precedence. -Note that this example doesn't work for nested "if"s. You need to add -"contains" arguments to make that work (omitted for simplicity of the -example). - -============================================================================== -7. Syntax patterns *:syn-pattern* *E401* *E402* - -In the syntax commands, a pattern must be surrounded by two identical -characters. This is like it works for the ":s" command. The most common to -use is the double quote. But if the pattern contains a double quote, you can -use another character that is not used in the pattern. Examples: > - :syntax region Comment start="/\*" end="\*/" - :syntax region String start=+"+ end=+"+ skip=+\\"+ - -See |pattern| for the explanation of what a pattern is. Syntax patterns are -always interpreted like the 'magic' option is set, no matter what the actual -value of 'magic' is. And the patterns are interpreted like the 'l' flag is -not included in 'cpoptions'. This was done to make syntax files portable and -independent of 'compatible' and 'magic' settings. - -Try to avoid patterns that can match an empty string, such as "[a-z]*". -This slows down the highlighting a lot, because it matches everywhere. - - *:syn-pattern-offset* -The pattern can be followed by a character offset. This can be used to -change the highlighted part, and to change the text area included in the -match or region (which only matters when trying to match other items). Both -are relative to the matched pattern. The character offset for a skip -pattern can be used to tell where to continue looking for an end pattern. - -The offset takes the form of "{what}={offset}" -The {what} can be one of seven strings: - -ms Match Start offset for the start of the matched text -me Match End offset for the end of the matched text -hs Highlight Start offset for where the highlighting starts -he Highlight End offset for where the highlighting ends -rs Region Start offset for where the body of a region starts -re Region End offset for where the body of a region ends -lc Leading Context offset past "leading context" of pattern - -The {offset} can be: - -s start of the matched pattern -s+{nr} start of the matched pattern plus {nr} chars to the right -s-{nr} start of the matched pattern plus {nr} chars to the left -e end of the matched pattern -e+{nr} end of the matched pattern plus {nr} chars to the right -e-{nr} end of the matched pattern plus {nr} chars to the left -{nr} (for "lc" only): start matching {nr} chars to the left - -Examples: "ms=s+1", "hs=e-2", "lc=3". - -Although all offsets are accepted after any pattern, they are not always -meaningful. This table shows which offsets are actually used: - - ms me hs he rs re lc ~ -match item yes yes yes yes - - yes -region item start yes - yes - yes - yes -region item skip - yes - - - - yes -region item end - yes - yes - yes yes - -Offsets can be concatenated, with a ',' in between. Example: > - :syn match String /"[^"]*"/hs=s+1,he=e-1 -< - some "string" text - ^^^^^^ highlighted - -Notes: -- There must be no white space between the pattern and the character - offset(s). -- The highlighted area will never be outside of the matched text. -- A negative offset for an end pattern may not always work, because the end - pattern may be detected when the highlighting should already have stopped. -- Until Vim 7.2 the offsets were counted in bytes instead of characters. This - didn't work well for multi-byte characters. -- The start of a match cannot be in a line other than where the pattern - matched. This doesn't work: "a\nb"ms=e. You can make the highlighting - start in another line, this does work: "a\nb"hs=e. - -Example (match a comment but don't highlight the /* and */): > - :syntax region Comment start="/\*"hs=e+1 end="\*/"he=s-1 -< - /* this is a comment */ - ^^^^^^^^^^^^^^^^^^^ highlighted - -A more complicated Example: > - :syn region Exa matchgroup=Foo start="foo"hs=s+2,rs=e+2 matchgroup=Bar end="bar"me=e-1,he=e-1,re=s-1 -< - abcfoostringbarabc - mmmmmmmmmmm match - sssrrreee highlight start/region/end ("Foo", "Exa" and "Bar") - -Leading context *:syn-lc* *:syn-leading* *:syn-context* - -Note: This is an obsolete feature, only included for backwards compatibility -with previous Vim versions. It's now recommended to use the |/\@<=| construct -in the pattern. - -The "lc" offset specifies leading context -- a part of the pattern that must -be present, but is not considered part of the match. An offset of "lc=n" will -cause Vim to step back n columns before attempting the pattern match, allowing -characters which have already been matched in previous patterns to also be -used as leading context for this match. This can be used, for instance, to -specify that an "escaping" character must not precede the match: > - - :syn match ZNoBackslash "[^\\]z"ms=s+1 - :syn match WNoBackslash "[^\\]w"lc=1 - :syn match Underline "_\+" -< - ___zzzz ___wwww - ^^^ ^^^ matches Underline - ^ ^ matches ZNoBackslash - ^^^^ matches WNoBackslash - -The "ms" offset is automatically set to the same value as the "lc" offset, -unless you set "ms" explicitly. - - -Multi-line patterns *:syn-multi-line* - -The patterns can include "\n" to match an end-of-line. Mostly this works as -expected, but there are a few exceptions. - -When using a start pattern with an offset, the start of the match is not -allowed to start in a following line. The highlighting can start in a -following line though. - -The skip pattern can include the "\n", but the search for an end pattern will -continue in the first character of the next line, also when that character is -matched by the skip pattern. This is because redrawing may start in any line -halfway a region and there is no check if the skip pattern started in a -previous line. For example, if the skip pattern is "a\nb" and an end pattern -is "b", the end pattern does match in the second line of this: > - x x a - b x x -Generally this means that the skip pattern should not match any characters -after the "\n". - - -External matches *:syn-ext-match* - -These extra regular expression items are available in region patterns: - - */\z(* */\z(\)* *E50* *E52* - \z(\) Marks the sub-expression as "external", meaning that it is can - be accessed from another pattern match. Currently only usable - in defining a syntax region start pattern. - - */\z1* */\z2* */\z3* */\z4* */\z5* - \z1 ... \z9 */\z6* */\z7* */\z8* */\z9* *E66* *E67* - Matches the same string that was matched by the corresponding - sub-expression in a previous start pattern match. - -Sometimes the start and end patterns of a region need to share a common -sub-expression. A common example is the "here" document in Perl and many Unix -shells. This effect can be achieved with the "\z" special regular expression -items, which marks a sub-expression as "external", in the sense that it can be -referenced from outside the pattern in which it is defined. The here-document -example, for instance, can be done like this: > - :syn region hereDoc start="<<\z(\I\i*\)" end="^\z1$" - -As can be seen here, the \z actually does double duty. In the start pattern, -it marks the "\(\I\i*\)" sub-expression as external; in the end pattern, it -changes the \1 back-reference into an external reference referring to the -first external sub-expression in the start pattern. External references can -also be used in skip patterns: > - :syn region foo start="start \(\I\i*\)" skip="not end \z1" end="end \z1" - -Note that normal and external sub-expressions are completely orthogonal and -indexed separately; for instance, if the pattern "\z(..\)\(..\)" is applied -to the string "aabb", then \1 will refer to "bb" and \z1 will refer to "aa". -Note also that external sub-expressions cannot be accessed as back-references -within the same pattern like normal sub-expressions. If you want to use one -sub-expression as both a normal and an external sub-expression, you can nest -the two, as in "\(\z(...\)\)". - -Note that only matches within a single line can be used. Multi-line matches -cannot be referred to. - -============================================================================== -8. Syntax clusters *:syn-cluster* *E400* - -:sy[ntax] cluster {cluster-name} [contains={group-name}..] - [add={group-name}..] - [remove={group-name}..] - -This command allows you to cluster a list of syntax groups together under a -single name. - - contains={group-name}.. - The cluster is set to the specified list of groups. - add={group-name}.. - The specified groups are added to the cluster. - remove={group-name}.. - The specified groups are removed from the cluster. - -A cluster so defined may be referred to in a contains=.., containedin=.., -nextgroup=.., add=.. or remove=.. list with a "@" prefix. You can also use -this notation to implicitly declare a cluster before specifying its contents. - -Example: > - :syntax match Thing "# [^#]\+ #" contains=@ThingMembers - :syntax cluster ThingMembers contains=ThingMember1,ThingMember2 - -As the previous example suggests, modifications to a cluster are effectively -retroactive; the membership of the cluster is checked at the last minute, so -to speak: > - :syntax keyword A aaa - :syntax keyword B bbb - :syntax cluster AandB contains=A - :syntax match Stuff "( aaa bbb )" contains=@AandB - :syntax cluster AandB add=B " now both keywords are matched in Stuff - -This also has implications for nested clusters: > - :syntax keyword A aaa - :syntax keyword B bbb - :syntax cluster SmallGroup contains=B - :syntax cluster BigGroup contains=A,@SmallGroup - :syntax match Stuff "( aaa bbb )" contains=@BigGroup - :syntax cluster BigGroup remove=B " no effect, since B isn't in BigGroup - :syntax cluster SmallGroup remove=B " now bbb isn't matched within Stuff - -============================================================================== -9. Including syntax files *:syn-include* *E397* - -It is often useful for one language's syntax file to include a syntax file for -a related language. Depending on the exact relationship, this can be done in -two different ways: - - - If top-level syntax items in the included syntax file are to be - allowed at the top level in the including syntax, you can simply use - the |:runtime| command: > - - " In cpp.vim: - :runtime! syntax/c.vim - :unlet b:current_syntax - -< - If top-level syntax items in the included syntax file are to be - contained within a region in the including syntax, you can use the - ":syntax include" command: - -:sy[ntax] include [@{grouplist-name}] {file-name} - - All syntax items declared in the included file will have the - "contained" flag added. In addition, if a group list is specified, - all top-level syntax items in the included file will be added to - that list. > - - " In perl.vim: - :syntax include @Pod <sfile>:p:h/pod.vim - :syntax region perlPOD start="^=head" end="^=cut" contains=@Pod -< - When {file-name} is an absolute path (starts with "/", "c:", "$VAR" - or "<sfile>") that file is sourced. When it is a relative path - (e.g., "syntax/pod.vim") the file is searched for in 'runtimepath'. - All matching files are loaded. Using a relative path is - recommended, because it allows a user to replace the included file - with his own version, without replacing the file that does the ":syn - include". - -============================================================================== -10. Synchronizing *:syn-sync* *E403* *E404* - -Vim wants to be able to start redrawing in any position in the document. To -make this possible it needs to know the syntax state at the position where -redrawing starts. - -:sy[ntax] sync [ccomment [group-name] | minlines={N} | ...] - -There are four ways to synchronize: -1. Always parse from the start of the file. - |:syn-sync-first| -2. Based on C-style comments. Vim understands how C-comments work and can - figure out if the current line starts inside or outside a comment. - |:syn-sync-second| -3. Jumping back a certain number of lines and start parsing there. - |:syn-sync-third| -4. Searching backwards in the text for a pattern to sync on. - |:syn-sync-fourth| - - *:syn-sync-maxlines* *:syn-sync-minlines* -For the last three methods, the line range where the parsing can start is -limited by "minlines" and "maxlines". - -If the "minlines={N}" argument is given, the parsing always starts at least -that many lines backwards. This can be used if the parsing may take a few -lines before it's correct, or when it's not possible to use syncing. - -If the "maxlines={N}" argument is given, the number of lines that are searched -for a comment or syncing pattern is restricted to N lines backwards (after -adding "minlines"). This is useful if you have few things to sync on and a -slow machine. Example: > - :syntax sync ccomment maxlines=500 -< - *:syn-sync-linebreaks* -When using a pattern that matches multiple lines, a change in one line may -cause a pattern to no longer match in a previous line. This means has to -start above where the change was made. How many lines can be specified with -the "linebreaks" argument. For example, when a pattern may include one line -break use this: > - :syntax sync linebreaks=1 -The result is that redrawing always starts at least one line before where a -change was made. The default value for "linebreaks" is zero. Usually the -value for "minlines" is bigger than "linebreaks". - - -First syncing method: *:syn-sync-first* -> - :syntax sync fromstart - -The file will be parsed from the start. This makes syntax highlighting -accurate, but can be slow for long files. Vim caches previously parsed text, -so that it's only slow when parsing the text for the first time. However, -when making changes some part of the next needs to be parsed again (worst -case: to the end of the file). - -Using "fromstart" is equivalent to using "minlines" with a very large number. - - -Second syncing method: *:syn-sync-second* *:syn-sync-ccomment* - -For the second method, only the "ccomment" argument needs to be given. -Example: > - :syntax sync ccomment - -When Vim finds that the line where displaying starts is inside a C-style -comment, the last region syntax item with the group-name "Comment" will be -used. This requires that there is a region with the group-name "Comment"! -An alternate group name can be specified, for example: > - :syntax sync ccomment javaComment -This means that the last item specified with "syn region javaComment" will be -used for the detected C comment region. This only works properly if that -region does have a start pattern "\/*" and an end pattern "*\/". - -The "maxlines" argument can be used to restrict the search to a number of -lines. The "minlines" argument can be used to at least start a number of -lines back (e.g., for when there is some construct that only takes a few -lines, but it hard to sync on). - -Note: Syncing on a C comment doesn't work properly when strings are used -that cross a line and contain a "*/". Since letting strings cross a line -is a bad programming habit (many compilers give a warning message), and the -chance of a "*/" appearing inside a comment is very small, this restriction -is hardly ever noticed. - - -Third syncing method: *:syn-sync-third* - -For the third method, only the "minlines={N}" argument needs to be given. -Vim will subtract {N} from the line number and start parsing there. This -means {N} extra lines need to be parsed, which makes this method a bit slower. -Example: > - :syntax sync minlines=50 - -"lines" is equivalent to "minlines" (used by older versions). - - -Fourth syncing method: *:syn-sync-fourth* - -The idea is to synchronize on the end of a few specific regions, called a -sync pattern. Only regions can cross lines, so when we find the end of some -region, we might be able to know in which syntax item we are. The search -starts in the line just above the one where redrawing starts. From there -the search continues backwards in the file. - -This works just like the non-syncing syntax items. You can use contained -matches, nextgroup, etc. But there are a few differences: -- Keywords cannot be used. -- The syntax items with the "sync" keyword form a completely separated group - of syntax items. You can't mix syncing groups and non-syncing groups. -- The matching works backwards in the buffer (line by line), instead of - forwards. -- A line continuation pattern can be given. It is used to decide which group - of lines need to be searched like they were one line. This means that the - search for a match with the specified items starts in the first of the - consecutive that contain the continuation pattern. -- When using "nextgroup" or "contains", this only works within one line (or - group of continued lines). -- When using a region, it must start and end in the same line (or group of - continued lines). Otherwise the end is assumed to be at the end of the - line (or group of continued lines). -- When a match with a sync pattern is found, the rest of the line (or group of - continued lines) is searched for another match. The last match is used. - This is used when a line can contain both the start end the end of a region - (e.g., in a C-comment like /* this */, the last "*/" is used). - -There are two ways how a match with a sync pattern can be used: -1. Parsing for highlighting starts where redrawing starts (and where the - search for the sync pattern started). The syntax group that is expected - to be valid there must be specified. This works well when the regions - that cross lines cannot contain other regions. -2. Parsing for highlighting continues just after the match. The syntax group - that is expected to be present just after the match must be specified. - This can be used when the previous method doesn't work well. It's much - slower, because more text needs to be parsed. -Both types of sync patterns can be used at the same time. - -Besides the sync patterns, other matches and regions can be specified, to -avoid finding unwanted matches. - -[The reason that the sync patterns are given separately, is that mostly the -search for the sync point can be much simpler than figuring out the -highlighting. The reduced number of patterns means it will go (much) -faster.] - - *syn-sync-grouphere* *E393* *E394* - :syntax sync match {sync-group-name} grouphere {group-name} "pattern" .. - - Define a match that is used for syncing. {group-name} is the - name of a syntax group that follows just after the match. Parsing - of the text for highlighting starts just after the match. A region - must exist for this {group-name}. The first one defined will be used. - "NONE" can be used for when there is no syntax group after the match. - - *syn-sync-groupthere* - :syntax sync match {sync-group-name} groupthere {group-name} "pattern" .. - - Like "grouphere", but {group-name} is the name of a syntax group that - is to be used at the start of the line where searching for the sync - point started. The text between the match and the start of the sync - pattern searching is assumed not to change the syntax highlighting. - For example, in C you could search backwards for "/*" and "*/". If - "/*" is found first, you know that you are inside a comment, so the - "groupthere" is "cComment". If "*/" is found first, you know that you - are not in a comment, so the "groupthere" is "NONE". (in practice - it's a bit more complicated, because the "/*" and "*/" could appear - inside a string. That's left as an exercise to the reader...). - - :syntax sync match .. - :syntax sync region .. - - Without a "groupthere" argument. Define a region or match that is - skipped while searching for a sync point. - - *syn-sync-linecont* - :syntax sync linecont {pattern} - - When {pattern} matches in a line, it is considered to continue in - the next line. This means that the search for a sync point will - consider the lines to be concatenated. - -If the "maxlines={N}" argument is given too, the number of lines that are -searched for a match is restricted to N. This is useful if you have very -few things to sync on and a slow machine. Example: > - :syntax sync maxlines=100 - -You can clear all sync settings with: > - :syntax sync clear - -You can clear specific sync patterns with: > - :syntax sync clear {sync-group-name} .. - -============================================================================== -11. Listing syntax items *:syntax* *:sy* *:syn* *:syn-list* - -This command lists all the syntax items: > - - :sy[ntax] [list] - -To show the syntax items for one syntax group: > - - :sy[ntax] list {group-name} - -To list the syntax groups in one cluster: *E392* > - - :sy[ntax] list @{cluster-name} - -See above for other arguments for the ":syntax" command. - -Note that the ":syntax" command can be abbreviated to ":sy", although ":syn" -is mostly used, because it looks better. - -============================================================================== -12. Highlight command *:highlight* *:hi* *E28* *E411* *E415* - -There are three types of highlight groups: -- The ones used for specific languages. For these the name starts with the - name of the language. Many of these don't have any attributes, but are - linked to a group of the second type. -- The ones used for all syntax languages. -- The ones used for the 'highlight' option. - *hitest.vim* -You can see all the groups currently active with this command: > - :so $VIMRUNTIME/syntax/hitest.vim -This will open a new window containing all highlight group names, displayed -in their own color. - - *:colo* *:colorscheme* *E185* -:colo[rscheme] {name} Load color scheme {name}. This searches 'runtimepath' - for the file "colors/{name}.vim. The first one that - is found is loaded. - To see the name of the currently active color scheme - (if there is one): > - :echo g:colors_name -< Doesn't work recursively, thus you can't use - ":colorscheme" in a color scheme script. - After the color scheme has been loaded the - |ColorScheme| autocommand event is triggered. - For info about writing a colorscheme file: > - :edit $VIMRUNTIME/colors/README.txt - -:hi[ghlight] List all the current highlight groups that have - attributes set. - -:hi[ghlight] {group-name} - List one highlight group. - -:hi[ghlight] clear Reset all highlighting to the defaults. Removes all - highlighting for groups added by the user! - Uses the current value of 'background' to decide which - default colors to use. - -:hi[ghlight] clear {group-name} -:hi[ghlight] {group-name} NONE - Disable the highlighting for one highlight group. It - is _not_ set back to the default colors. - -:hi[ghlight] [default] {group-name} {key}={arg} .. - Add a highlight group, or change the highlighting for - an existing group. - See |highlight-args| for the {key}={arg} arguments. - See |:highlight-default| for the optional [default] - argument. - -Normally a highlight group is added once when starting up. This sets the -default values for the highlighting. After that, you can use additional -highlight commands to change the arguments that you want to set to non-default -values. The value "NONE" can be used to switch the value off or go back to -the default value. - -A simple way to change colors is with the |:colorscheme| command. This loads -a file with ":highlight" commands such as this: > - - :hi Comment gui=bold - -Note that all settings that are not included remain the same, only the -specified field is used, and settings are merged with previous ones. So, the -result is like this single command has been used: > - :hi Comment term=bold ctermfg=Cyan guifg=#80a0ff gui=bold -< - *:highlight-verbose* -When listing a highlight group and 'verbose' is non-zero, the listing will -also tell where it was last set. Example: > - :verbose hi Comment -< Comment xxx term=bold ctermfg=4 guifg=Blue ~ - Last set from /home/mool/vim/vim7/runtime/syntax/syncolor.vim ~ - -When ":hi clear" is used then the script where this command is used will be -mentioned for the default values. See |:verbose-cmd| for more information. - - *highlight-args* *E416* *E417* *E423* -There are three types of terminals for highlighting: -term a normal terminal (vt100, xterm) -cterm a color terminal (MS-DOS console, color-xterm, these have the "Co" - termcap entry) -gui the GUI - -For each type the highlighting can be given. This makes it possible to use -the same syntax file on all terminals, and use the optimal highlighting. - -1. highlight arguments for normal terminals - - *bold* *underline* *undercurl* - *inverse* *italic* *standout* -term={attr-list} *attr-list* *highlight-term* *E418* - attr-list is a comma separated list (without spaces) of the - following items (in any order): - bold - underline - undercurl not always available - reverse - inverse same as reverse - italic - standout - NONE no attributes used (used to reset it) - - Note that "bold" can be used here and by using a bold font. They - have the same effect. - "undercurl" is a curly underline. When "undercurl" is not possible - then "underline" is used. In general "undercurl" is only available in - the GUI. The color is set with |highlight-guisp|. - -start={term-list} *highlight-start* *E422* -stop={term-list} *term-list* *highlight-stop* - These lists of terminal codes can be used to get - non-standard attributes on a terminal. - - The escape sequence specified with the "start" argument - is written before the characters in the highlighted - area. It can be anything that you want to send to the - terminal to highlight this area. The escape sequence - specified with the "stop" argument is written after the - highlighted area. This should undo the "start" argument. - Otherwise the screen will look messed up. - - The {term-list} can have two forms: - - 1. A string with escape sequences. - This is any string of characters, except that it can't start with - "t_" and blanks are not allowed. The <> notation is recognized - here, so you can use things like "<Esc>" and "<Space>". Example: - start=<Esc>[27h;<Esc>[<Space>r; - - 2. A list of terminal codes. - Each terminal code has the form "t_xx", where "xx" is the name of - the termcap entry. The codes have to be separated with commas. - White space is not allowed. Example: - start=t_C1,t_BL - The terminal codes must exist for this to work. - - -2. highlight arguments for color terminals - -cterm={attr-list} *highlight-cterm* - See above for the description of {attr-list} |attr-list|. - The "cterm" argument is likely to be different from "term", when - colors are used. For example, in a normal terminal comments could - be underlined, in a color terminal they can be made Blue. - Note: Many terminals (e.g., DOS console) can't mix these attributes - with coloring. Use only one of "cterm=" OR "ctermfg=" OR "ctermbg=". - -ctermfg={color-nr} *highlight-ctermfg* *E421* -ctermbg={color-nr} *highlight-ctermbg* - The {color-nr} argument is a color number. Its range is zero to - (not including) the number given by the termcap entry "Co". - The actual color with this number depends on the type of terminal - and its settings. Sometimes the color also depends on the settings of - "cterm". For example, on some systems "cterm=bold ctermfg=3" gives - another color, on others you just get color 3. - - For an xterm this depends on your resources, and is a bit - unpredictable. See your xterm documentation for the defaults. The - colors for a color-xterm can be changed from the .Xdefaults file. - Unfortunately this means that it's not possible to get the same colors - for each user. See |xterm-color| for info about color xterms. - - The MSDOS standard colors are fixed (in a console window), so these - have been used for the names. But the meaning of color names in X11 - are fixed, so these color settings have been used, to make the - highlighting settings portable (complicated, isn't it?). The - following names are recognized, with the color number used: - - *cterm-colors* - NR-16 NR-8 COLOR NAME ~ - 0 0 Black - 1 4 DarkBlue - 2 2 DarkGreen - 3 6 DarkCyan - 4 1 DarkRed - 5 5 DarkMagenta - 6 3 Brown, DarkYellow - 7 7 LightGray, LightGrey, Gray, Grey - 8 0* DarkGray, DarkGrey - 9 4* Blue, LightBlue - 10 2* Green, LightGreen - 11 6* Cyan, LightCyan - 12 1* Red, LightRed - 13 5* Magenta, LightMagenta - 14 3* Yellow, LightYellow - 15 7* White - - The number under "NR-16" is used for 16-color terminals ('t_Co' - greater than or equal to 16). The number under "NR-8" is used for - 8-color terminals ('t_Co' less than 16). The '*' indicates that the - bold attribute is set for ctermfg. In many 8-color terminals (e.g., - "linux"), this causes the bright colors to appear. This doesn't work - for background colors! Without the '*' the bold attribute is removed. - If you want to set the bold attribute in a different way, put a - "cterm=" argument AFTER the "ctermfg=" or "ctermbg=" argument. Or use - a number instead of a color name. - - The case of the color names is ignored. - Note that for 16 color ansi style terminals (including xterms), the - numbers in the NR-8 column is used. Here '*' means 'add 8' so that Blue - is 12, DarkGray is 8 etc. - - Note that for some color terminals these names may result in the wrong - colors! - - *:hi-normal-cterm* - When setting the "ctermfg" or "ctermbg" colors for the Normal group, - these will become the colors used for the non-highlighted text. - Example: > - :highlight Normal ctermfg=grey ctermbg=darkblue -< When setting the "ctermbg" color for the Normal group, the - 'background' option will be adjusted automatically. This causes the - highlight groups that depend on 'background' to change! This means - you should set the colors for Normal first, before setting other - colors. - When a colorscheme is being used, changing 'background' causes it to - be reloaded, which may reset all colors (including Normal). First - delete the "colors_name" variable when you don't want this. - - When you have set "ctermfg" or "ctermbg" for the Normal group, Vim - needs to reset the color when exiting. This is done with the "op" - termcap entry |t_op|. If this doesn't work correctly, try setting the - 't_op' option in your .vimrc. - *E419* *E420* - When Vim knows the normal foreground and background colors, "fg" and - "bg" can be used as color names. This only works after setting the - colors for the Normal group and for the MS-DOS console. Example, for - reverse video: > - :highlight Visual ctermfg=bg ctermbg=fg -< Note that the colors are used that are valid at the moment this - command are given. If the Normal group colors are changed later, the - "fg" and "bg" colors will not be adjusted. - - -3. highlight arguments for the GUI - -gui={attr-list} *highlight-gui* - These give the attributes to use in the GUI mode. - See |attr-list| for a description. - Note that "bold" can be used here and by using a bold font. They - have the same effect. - Note that the attributes are ignored for the "Normal" group. - -font={font-name} *highlight-font* - font-name is the name of a font, as it is used on the system Vim - runs on. For X11 this is a complicated name, for example: > - font=-misc-fixed-bold-r-normal--14-130-75-75-c-70-iso8859-1 -< - The font-name "NONE" can be used to revert to the default font. - When setting the font for the "Normal" group, this becomes the default - font (until the 'guifont' option is changed; the last one set is - used). - The following only works with Motif and Athena, not with other GUIs: - When setting the font for the "Menu" group, the menus will be changed. - When setting the font for the "Tooltip" group, the tooltips will be - changed. - All fonts used, except for Menu and Tooltip, should be of the same - character size as the default font! Otherwise redrawing problems will - occur. - -guifg={color-name} *highlight-guifg* -guibg={color-name} *highlight-guibg* -guisp={color-name} *highlight-guisp* - These give the foreground (guifg), background (guibg) and special - (guisp) color to use in the GUI. "guisp" is used for undercurl. - There are a few special names: - NONE no color (transparent) - bg use normal background color - background use normal background color - fg use normal foreground color - foreground use normal foreground color - To use a color name with an embedded space or other special character, - put it in single quotes. The single quote cannot be used then. - Example: > - :hi comment guifg='salmon pink' -< - *gui-colors* - Suggested color names (these are available on most systems): - Red LightRed DarkRed - Green LightGreen DarkGreen SeaGreen - Blue LightBlue DarkBlue SlateBlue - Cyan LightCyan DarkCyan - Magenta LightMagenta DarkMagenta - Yellow LightYellow Brown DarkYellow - Gray LightGray DarkGray - Black White - Orange Purple Violet - - In the Win32 GUI version, additional system colors are available. See - |win32-colors|. - - You can also specify a color by its Red, Green and Blue values. - The format is "#rrggbb", where - "rr" is the Red value - "gg" is the Green value - "bb" is the Blue value - All values are hexadecimal, range from "00" to "ff". Examples: > - :highlight Comment guifg=#11f0c3 guibg=#ff00ff -< - *highlight-groups* *highlight-default* -These are the default highlighting groups. These groups are used by the -'highlight' option default. Note that the highlighting depends on the value -of 'background'. You can see the current settings with the ":highlight" -command. - *hl-Cursor* -Cursor the character under the cursor - *hl-CursorIM* -CursorIM like Cursor, but used when in IME mode |CursorIM| - *hl-CursorColumn* -CursorColumn the screen column that the cursor is in when 'cursorcolumn' is - set - *hl-CursorLine* -CursorLine the screen line that the cursor is in when 'cursorline' is - set - *hl-Directory* -Directory directory names (and other special names in listings) - *hl-DiffAdd* -DiffAdd diff mode: Added line |diff.txt| - *hl-DiffChange* -DiffChange diff mode: Changed line |diff.txt| - *hl-DiffDelete* -DiffDelete diff mode: Deleted line |diff.txt| - *hl-DiffText* -DiffText diff mode: Changed text within a changed line |diff.txt| - *hl-ErrorMsg* -ErrorMsg error messages on the command line - *hl-VertSplit* -VertSplit the column separating vertically split windows - *hl-Folded* -Folded line used for closed folds - *hl-FoldColumn* -FoldColumn 'foldcolumn' - *hl-SignColumn* -SignColumn column where |signs| are displayed - *hl-IncSearch* -IncSearch 'incsearch' highlighting; also used for the text replaced with - ":s///c" - *hl-LineNr* -LineNr Line number for ":number" and ":#" commands, and when 'number' - option is set. - *hl-MatchParen* -MatchParen The character under the cursor or just before it, if it - is a paired bracket, and its match. |pi_paren.txt| - - *hl-ModeMsg* -ModeMsg 'showmode' message (e.g., "-- INSERT --") - *hl-MoreMsg* -MoreMsg |more-prompt| - *hl-NonText* -NonText '~' and '@' at the end of the window, characters from - 'showbreak' and other characters that do not really exist in - the text (e.g., ">" displayed when a double-wide character - doesn't fit at the end of the line). - *hl-Normal* -Normal normal text - *hl-Pmenu* -Pmenu Popup menu: normal item. - *hl-PmenuSel* -PmenuSel Popup menu: selected item. - *hl-PmenuSbar* -PmenuSbar Popup menu: scrollbar. - *hl-PmenuThumb* -PmenuThumb Popup menu: Thumb of the scrollbar. - *hl-Question* -Question |hit-enter| prompt and yes/no questions - *hl-Search* -Search Last search pattern highlighting (see 'hlsearch'). - Also used for highlighting the current line in the quickfix - window and similar items that need to stand out. - *hl-SpecialKey* -SpecialKey Meta and special keys listed with ":map", also for text used - to show unprintable characters in the text, 'listchars'. - Generally: text that is displayed differently from what it - really is. - *hl-SpellBad* -SpellBad Word that is not recognized by the spellchecker. |spell| - This will be combined with the highlighting used otherwise. - *hl-SpellCap* -SpellCap Word that should start with a capital. |spell| - This will be combined with the highlighting used otherwise. - *hl-SpellLocal* -SpellLocal Word that is recognized by the spellchecker as one that is - used in another region. |spell| - This will be combined with the highlighting used otherwise. - *hl-SpellRare* -SpellRare Word that is recognized by the spellchecker as one that is - hardly ever used. |spell| - This will be combined with the highlighting used otherwise. - *hl-StatusLine* -StatusLine status line of current window - *hl-StatusLineNC* -StatusLineNC status lines of not-current windows - Note: if this is equal to "StatusLine" Vim will use "^^^" in - the status line of the current window. - *hl-TabLine* -TabLine tab pages line, not active tab page label - *hl-TabLineFill* -TabLineFill tab pages line, where there are no labels - *hl-TabLineSel* -TabLineSel tab pages line, active tab page label - *hl-Title* -Title titles for output from ":set all", ":autocmd" etc. - *hl-Visual* -Visual Visual mode selection - *hl-VisualNOS* -VisualNOS Visual mode selection when vim is "Not Owning the Selection". - Only X11 Gui's |gui-x11| and |xterm-clipboard| supports this. - *hl-WarningMsg* -WarningMsg warning messages - *hl-WildMenu* -WildMenu current match in 'wildmenu' completion - - *hl-User1* *hl-User1..9* *hl-User9* -The 'statusline' syntax allows the use of 9 different highlights in the -statusline and ruler (via 'rulerformat'). The names are User1 to User9. - -For the GUI you can use the following groups to set the colors for the menu, -scrollbars and tooltips. They don't have defaults. This doesn't work for the -Win32 GUI. Only three highlight arguments have any effect here: font, guibg, -and guifg. - - *hl-Menu* -Menu Current font, background and foreground colors of the menus. - Also used for the toolbar. - Applicable highlight arguments: font, guibg, guifg. - - NOTE: For Motif and Athena the font argument actually - specifies a fontset at all times, no matter if 'guifontset' is - empty, and as such it is tied to the current |:language| when - set. - - *hl-Scrollbar* -Scrollbar Current background and foreground of the main window's - scrollbars. - Applicable highlight arguments: guibg, guifg. - - *hl-Tooltip* -Tooltip Current font, background and foreground of the tooltips. - Applicable highlight arguments: font, guibg, guifg. - - NOTE: For Motif and Athena the font argument actually - specifies a fontset at all times, no matter if 'guifontset' is - empty, and as such it is tied to the current |:language| when - set. - -============================================================================== -13. Linking groups *:hi-link* *:highlight-link* *E412* *E413* - -When you want to use the same highlighting for several syntax groups, you -can do this more easily by linking the groups into one common highlight -group, and give the color attributes only for that group. - -To set a link: - - :hi[ghlight][!] [default] link {from-group} {to-group} - -To remove a link: - - :hi[ghlight][!] [default] link {from-group} NONE - -Notes: *E414* -- If the {from-group} and/or {to-group} doesn't exist, it is created. You - don't get an error message for a non-existing group. -- As soon as you use a ":highlight" command for a linked group, the link is - removed. -- If there are already highlight settings for the {from-group}, the link is - not made, unless the '!' is given. For a ":highlight link" command in a - sourced file, you don't get an error message. This can be used to skip - links for groups that already have settings. - - *:hi-default* *:highlight-default* -The [default] argument is used for setting the default highlighting for a -group. If highlighting has already been specified for the group the command -will be ignored. Also when there is an existing link. - -Using [default] is especially useful to overrule the highlighting of a -specific syntax file. For example, the C syntax file contains: > - :highlight default link cComment Comment -If you like Question highlighting for C comments, put this in your vimrc file: > - :highlight link cComment Question -Without the "default" in the C syntax file, the highlighting would be -overruled when the syntax file is loaded. - -============================================================================== -14. Cleaning up *:syn-clear* *E391* - -If you want to clear the syntax stuff for the current buffer, you can use this -command: > - :syntax clear - -This command should be used when you want to switch off syntax highlighting, -or when you want to switch to using another syntax. It's normally not needed -in a syntax file itself, because syntax is cleared by the autocommands that -load the syntax file. -The command also deletes the "b:current_syntax" variable, since no syntax is -loaded after this command. - -If you want to disable syntax highlighting for all buffers, you need to remove -the autocommands that load the syntax files: > - :syntax off - -What this command actually does, is executing the command > - :source $VIMRUNTIME/syntax/nosyntax.vim -See the "nosyntax.vim" file for details. Note that for this to work -$VIMRUNTIME must be valid. See |$VIMRUNTIME|. - -To clean up specific syntax groups for the current buffer: > - :syntax clear {group-name} .. -This removes all patterns and keywords for {group-name}. - -To clean up specific syntax group lists for the current buffer: > - :syntax clear @{grouplist-name} .. -This sets {grouplist-name}'s contents to an empty list. - - *:syntax-reset* *:syn-reset* -If you have changed the colors and messed them up, use this command to get the -defaults back: > - - :syntax reset - -This doesn't change the colors for the 'highlight' option. - -Note that the syntax colors that you set in your vimrc file will also be reset -back to their Vim default. -Note that if you are using a color scheme, the colors defined by the color -scheme for syntax highlighting will be lost. - -What this actually does is: > - - let g:syntax_cmd = "reset" - runtime! syntax/syncolor.vim - -Note that this uses the 'runtimepath' option. - - *syncolor* -If you want to use different colors for syntax highlighting, you can add a Vim -script file to set these colors. Put this file in a directory in -'runtimepath' which comes after $VIMRUNTIME, so that your settings overrule -the default colors. This way these colors will be used after the ":syntax -reset" command. - -For Unix you can use the file ~/.vim/after/syntax/syncolor.vim. Example: > - - if &background == "light" - highlight comment ctermfg=darkgreen guifg=darkgreen - else - highlight comment ctermfg=green guifg=green - endif - - *E679* -Do make sure this syncolor.vim script does not use a "syntax on", set the -'background' option or uses a "colorscheme" command, because it results in an -endless loop. - -Note that when a color scheme is used, there might be some confusion whether -your defined colors are to be used or the colors from the scheme. This -depends on the color scheme file. See |:colorscheme|. - - *syntax_cmd* -The "syntax_cmd" variable is set to one of these values when the -syntax/syncolor.vim files are loaded: - "on" ":syntax on" command. Highlight colors are overruled but - links are kept - "enable" ":syntax enable" command. Only define colors for groups that - don't have highlighting yet. Use ":syntax default". - "reset" ":syntax reset" command or loading a color scheme. Define all - the colors. - "skip" Don't define colors. Used to skip the default settings when a - syncolor.vim file earlier in 'runtimepath' has already set - them. - -============================================================================== -15. Highlighting tags *tag-highlight* - -If you want to highlight all the tags in your file, you can use the following -mappings. - - <F11> -- Generate tags.vim file, and highlight tags. - <F12> -- Just highlight tags based on existing tags.vim file. -> - :map <F11> :sp tags<CR>:%s/^\([^ :]*:\)\=\([^ ]*\).*/syntax keyword Tag \2/<CR>:wq! tags.vim<CR>/^<CR><F12> - :map <F12> :so tags.vim<CR> - -WARNING: The longer the tags file, the slower this will be, and the more -memory Vim will consume. - -Only highlighting typedefs, unions and structs can be done too. For this you -must use Exuberant ctags (found at http://ctags.sf.net). - -Put these lines in your Makefile: - -# Make a highlight file for types. Requires Exuberant ctags and awk -types: types.vim -types.vim: *.[ch] - ctags --c-kinds=gstu -o- *.[ch] |\ - awk 'BEGIN{printf("syntax keyword Type\t")}\ - {printf("%s ", $$1)}END{print ""}' > $@ - -And put these lines in your .vimrc: > - - " load the types.vim highlighting file, if it exists - autocmd BufRead,BufNewFile *.[ch] let fname = expand('<afile>:p:h') . '/types.vim' - autocmd BufRead,BufNewFile *.[ch] if filereadable(fname) - autocmd BufRead,BufNewFile *.[ch] exe 'so ' . fname - autocmd BufRead,BufNewFile *.[ch] endif - -============================================================================== -16. Color xterms *xterm-color* *color-xterm* - -Most color xterms have only eight colors. If you don't get colors with the -default setup, it should work with these lines in your .vimrc: > - :if &term =~ "xterm" - : if has("terminfo") - : set t_Co=8 - : set t_Sf=<Esc>[3%p1%dm - : set t_Sb=<Esc>[4%p1%dm - : else - : set t_Co=8 - : set t_Sf=<Esc>[3%dm - : set t_Sb=<Esc>[4%dm - : endif - :endif -< [<Esc> is a real escape, type CTRL-V <Esc>] - -You might want to change the first "if" to match the name of your terminal, -e.g. "dtterm" instead of "xterm". - -Note: Do these settings BEFORE doing ":syntax on". Otherwise the colors may -be wrong. - *xiterm* *rxvt* -The above settings have been mentioned to work for xiterm and rxvt too. -But for using 16 colors in an rxvt these should work with terminfo: > - :set t_AB=<Esc>[%?%p1%{8}%<%t25;%p1%{40}%+%e5;%p1%{32}%+%;%dm - :set t_AF=<Esc>[%?%p1%{8}%<%t22;%p1%{30}%+%e1;%p1%{22}%+%;%dm -< - *colortest.vim* -To test your color setup, a file has been included in the Vim distribution. -To use it, execute this command: > - :runtime syntax/colortest.vim - -Some versions of xterm (and other terminals, like the Linux console) can -output lighter foreground colors, even though the number of colors is defined -at 8. Therefore Vim sets the "cterm=bold" attribute for light foreground -colors, when 't_Co' is 8. - - *xfree-xterm* -To get 16 colors or more, get the newest xterm version (which should be -included with XFree86 3.3 and later). You can also find the latest version -at: > - http://invisible-island.net/xterm/xterm.html -Here is a good way to configure it. This uses 88 colors and enables the -termcap-query feature, which allows Vim to ask the xterm how many colors it -supports. > - ./configure --disable-bold-color --enable-88-color --enable-tcap-query -If you only get 8 colors, check the xterm compilation settings. -(Also see |UTF8-xterm| for using this xterm with UTF-8 character encoding). - -This xterm should work with these lines in your .vimrc (for 16 colors): > - :if has("terminfo") - : set t_Co=16 - : set t_AB=<Esc>[%?%p1%{8}%<%t%p1%{40}%+%e%p1%{92}%+%;%dm - : set t_AF=<Esc>[%?%p1%{8}%<%t%p1%{30}%+%e%p1%{82}%+%;%dm - :else - : set t_Co=16 - : set t_Sf=<Esc>[3%dm - : set t_Sb=<Esc>[4%dm - :endif -< [<Esc> is a real escape, type CTRL-V <Esc>] - -Without |+terminfo|, Vim will recognize these settings, and automatically -translate cterm colors of 8 and above to "<Esc>[9%dm" and "<Esc>[10%dm". -Colors above 16 are also translated automatically. - -For 256 colors this has been reported to work: > - - :set t_AB=<Esc>[48;5;%dm - :set t_AF=<Esc>[38;5;%dm - -Or just set the TERM environment variable to "xterm-color" or "xterm-16color" -and try if that works. - -You probably want to use these X resources (in your ~/.Xdefaults file): - XTerm*color0: #000000 - XTerm*color1: #c00000 - XTerm*color2: #008000 - XTerm*color3: #808000 - XTerm*color4: #0000c0 - XTerm*color5: #c000c0 - XTerm*color6: #008080 - XTerm*color7: #c0c0c0 - XTerm*color8: #808080 - XTerm*color9: #ff6060 - XTerm*color10: #00ff00 - XTerm*color11: #ffff00 - XTerm*color12: #8080ff - XTerm*color13: #ff40ff - XTerm*color14: #00ffff - XTerm*color15: #ffffff - Xterm*cursorColor: Black - -[Note: The cursorColor is required to work around a bug, which changes the -cursor color to the color of the last drawn text. This has been fixed by a -newer version of xterm, but not everybody is using it yet.] - -To get these right away, reload the .Xdefaults file to the X Option database -Manager (you only need to do this when you just changed the .Xdefaults file): > - xrdb -merge ~/.Xdefaults -< - *xterm-blink* *xterm-blinking-cursor* -To make the cursor blink in an xterm, see tools/blink.c. Or use Thomas -Dickey's xterm above patchlevel 107 (see above for where to get it), with -these resources: - XTerm*cursorBlink: on - XTerm*cursorOnTime: 400 - XTerm*cursorOffTime: 250 - XTerm*cursorColor: White - - *hpterm-color* -These settings work (more or less) for an hpterm, which only supports 8 -foreground colors: > - :if has("terminfo") - : set t_Co=8 - : set t_Sf=<Esc>[&v%p1%dS - : set t_Sb=<Esc>[&v7S - :else - : set t_Co=8 - : set t_Sf=<Esc>[&v%dS - : set t_Sb=<Esc>[&v7S - :endif -< [<Esc> is a real escape, type CTRL-V <Esc>] - - *Eterm* *enlightened-terminal* -These settings have been reported to work for the Enlightened terminal -emulator, or Eterm. They might work for all xterm-like terminals that use the -bold attribute to get bright colors. Add an ":if" like above when needed. > - :set t_Co=16 - :set t_AF=^[[%?%p1%{8}%<%t3%p1%d%e%p1%{22}%+%d;1%;m - :set t_AB=^[[%?%p1%{8}%<%t4%p1%d%e%p1%{32}%+%d;1%;m -< - *TTpro-telnet* -These settings should work for TTpro telnet. Tera Term Pro is a freeware / -open-source program for MS-Windows. > - set t_Co=16 - set t_AB=^[[%?%p1%{8}%<%t%p1%{40}%+%e%p1%{32}%+5;%;%dm - set t_AF=^[[%?%p1%{8}%<%t%p1%{30}%+%e%p1%{22}%+1;%;%dm -Also make sure TTpro's Setup / Window / Full Color is enabled, and make sure -that Setup / Font / Enable Bold is NOT enabled. -(info provided by John Love-Jensen <eljay@Adobe.COM>) - - vim:tw=78:sw=4:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/tabpage.txt b/share/vim/vim72/doc/tabpage.txt deleted file mode 100644 index 0b64003a05..0000000000 --- a/share/vim/vim72/doc/tabpage.txt +++ /dev/null @@ -1,378 +0,0 @@ -*tabpage.txt* For Vim version 7.2. Last change: 2007 Mar 11 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Editing with windows in multiple tab pages. *tab-page* *tabpage* - -The commands which have been added to use multiple tab pages are explained -here. Additionally, there are explanations for commands that work differently -when used in combination with more than one tab page. - -1. Introduction |tab-page-intro| -2. Commands |tab-page-commands| -3. Other items |tab-page-other| -4. Setting 'tabline' |setting-tabline| -5. Setting 'guitablabel' |setting-guitablabel| - -{Vi does not have any of these commands} -{not able to use multiple tab pages when the |+windows| feature was disabled -at compile time} - -============================================================================== -1. Introduction *tab-page-intro* - -A tab page holds one or more windows. You can easily switch between tab -pages, so that you have several collections of windows to work on different -things. - -Usually you will see a list of labels at the top of the Vim window, one for -each tab page. With the mouse you can click on the label to jump to that tab -page. There are other ways to move between tab pages, see below. - -Most commands work only in the current tab page. That includes the |CTRL-W| -commands, |:windo|, |:all| and |:ball| (when not using the |:tab| modifier). -The commands that are aware of other tab pages than the current one are -mentioned below. - -Tabs are also a nice way to edit a buffer temporarily without changing the -current window layout. Open a new tab page, do whatever you want to do and -close the tab page. - -============================================================================== -2. Commands *tab-page-commands* - -OPENING A NEW TAB PAGE: - -When starting Vim "vim -p filename ..." opens each file argument in a separate -tab page (up to 'tabpagemax'). |-p| - -A double click with the mouse in the non-GUI tab pages line opens a new, empty -tab page. It is placed left of the position of the click. The first click -may select another tab page first, causing an extra screen update. - -This also works in a few GUI versions, esp. Win32 and Motif. But only when -clicking right of the labels. - -In the GUI tab pages line you can use the right mouse button to open menu. -|tabline-menu|. - -:tabe[dit] *:tabe* *:tabedit* *:tabnew* -:tabnew Open a new tab page with an empty window, after the current - tab page. - -:tabe[dit] [++opt] [+cmd] {file} -:tabnew [++opt] [+cmd] {file} - Open a new tab page and edit {file}, like with |:edit|. - -:tabf[ind] [++opt] [+cmd] {file} *:tabf* *:tabfind* - Open a new tab page and edit {file} in 'path', like with - |:find|. - {not available when the |+file_in_path| feature was disabled - at compile time} - -:[count]tab {cmd} *:tab* - Execute {cmd} and when it opens a new window open a new tab - page instead. Doesn't work for |:diffsplit|, |:diffpatch|, - |:execute| and |:normal|. - When [count] is omitted the tab page appears after the current - one. When [count] is specified the new tab page comes after - tab page [count]. Use ":0tab cmd" to get the new tab page as - the first one. Examples: > - :tab split " opens current buffer in new tab page - :tab help gt " opens tab page with help for "gt" - -CTRL-W gf Open a new tab page and edit the file name under the cursor. - See |CTRL-W_gf|. - -CTRL-W gF Open a new tab page and edit the file name under the cursor - and jump to the line number following the file name. - See |CTRL-W_gF|. - -CLOSING A TAB PAGE: - -Closing the last window of a tab page closes the tab page too, unless there is -only one tab page. - -Using the mouse: If the tab page line is displayed you can click in the "X" at -the top right to close the current tab page. A custom |'tabline'| may show -something else. - - *:tabc* *:tabclose* -:tabc[lose][!] Close current tab page. - This command fails when: - - There is only one tab page on the screen. *E784* - - When 'hidden' is not set, [!] is not used, a buffer has - changes, and there is no other window on this buffer. - Changes to the buffer are not written and won't get lost, so - this is a "safe" command. - -:tabc[lose][!] {count} - Close tab page {count}. Fails in the same way as ':tabclose" - above. - - *:tabo* *:tabonly* -:tabo[nly][!] Close all other tab pages. - When the 'hidden' option is set, all buffers in closed windows - become hidden. - When 'hidden' is not set, and the 'autowrite' option is set, - modified buffers are written. Otherwise, windows that have - buffers that are modified are not removed, unless the [!] is - given, then they become hidden. But modified buffers are - never abandoned, so changes cannot get lost. - - -SWITCHING TO ANOTHER TAB PAGE: - -Using the mouse: If the tab page line is displayed you can click in a tab page -label to switch to that tab page. Click where there is no label to go to the -next tab page. |'tabline'| - -:tabn[ext] *:tabn* *:tabnext* *gt* -<C-PageDown> *CTRL-<PageDown>* *<C-PageDown>* -gt *i_CTRL-<PageDown>* *i_<C-PageDown>* - Go to the next tab page. Wraps around from the last to the - first one. - -:tabn[ext] {count} -{count}<C-PageDown> -{count}gt Go to tab page {count}. The first tab page has number one. - - -:tabp[revious] *:tabp* *:tabprevious* *gT* *:tabN* -:tabN[ext] *:tabNext* *CTRL-<PageUp>* -<C-PageUp> *<C-PageUp>* *i_CTRL-<PageUp>* *i_<C-PageUp>* -gT Go to the previous tab page. Wraps around from the first one - to the last one. - -:tabp[revious] {count} -:tabN[ext] {count} -{count}<C-PageUp> -{count}gT Go {count} tab pages back. Wraps around from the first one - to the last one. - -:tabr[ewind] *:tabfir* *:tabfirst* *:tabr* *:tabrewind* -:tabfir[st] Go to the first tab page. - - *:tabl* *:tablast* -:tabl[ast] Go to the last tab page. - - -Other commands: - *:tabs* -:tabs List the tab pages and the windows they contain. - Shows a ">" for the current window. - Shows a "+" for modified buffers. - - -REORDERING TAB PAGES: - -:tabm[ove] [N] *:tabm* *:tabmove* - Move the current tab page to after tab page N. Use zero to - make the current tab page the first one. Without N the tab - page is made the last one. - - -LOOPING OVER TAB PAGES: - - *:tabd* *:tabdo* -:tabd[o] {cmd} Execute {cmd} in each tab page. - It works like doing this: > - :tabfirst - :{cmd} - :tabnext - :{cmd} - etc. -< This only operates in the current window of each tab page. - When an error is detected on one tab page, further tab pages - will not be visited. - The last tab page (or where an error occurred) becomes the - current tab page. - {cmd} can contain '|' to concatenate several commands. - {cmd} must not open or close tab pages or reorder them. - {not in Vi} {not available when compiled without the - |+listcmds| feature} - Also see |:windo|, |:argdo| and |:bufdo|. - -============================================================================== -3. Other items *tab-page-other* - - *tabline-menu* -The GUI tab pages line has a popup menu. It is accessed with a right click. -The entries are: - Close Close the tab page under the mouse pointer. The - current one if there is no label under the mouse - pointer. - New Tab Open a tab page, editing an empty buffer. It appears - to the left of the mouse pointer. - Open Tab... Like "New Tab" and additionally use a file selector to - select a file to edit. - -Diff mode works per tab page. You can see the diffs between several files -within one tab page. Other tab pages can show differences between other -files. - -Variables local to a tab page start with "t:". |tabpage-variable| - -Currently there is only one option local to a tab page: 'cmdheight'. - -The TabLeave and TabEnter autocommand events can be used to do something when -switching from one tab page to another. The exact order depends on what you -are doing. When creating a new tab page this works as if you create a new -window on the same buffer and then edit another buffer. Thus ":tabnew" -triggers: - WinLeave leave current window - TabLeave leave current tab page - TabEnter enter new tab page - WinEnter enter window in new tab page - BufLeave leave current buffer - BufEnter enter new empty buffer - -When switching to another tab page the order is: - BufLeave - WinLeave - TabLeave - TabEnter - WinEnter - BufEnter - -============================================================================== -4. Setting 'tabline' *setting-tabline* - -The 'tabline' option specifies what the line with tab pages labels looks like. -It is only used when there is no GUI tab line. - -You can use the 'showtabline' option to specify when you want the line with -tab page labels to appear: never, when there is more than one tab page or -always. - -The highlighting of the tab pages line is set with the groups TabLine -TabLineSel and TabLineFill. |hl-TabLine| |hl-TabLineSel| |hl-TabLineFill| - -A "+" will be shown for a tab page that has a modified window. The number of -windows in a tabpage is also shown. Thus "3+" means three windows and one of -them has a modified buffer. - -The 'tabline' option allows you to define your preferred way to tab pages -labels. This isn't easy, thus an example will be given here. - -For basics see the 'statusline' option. The same items can be used in the -'tabline' option. Additionally, the |tabpagebuflist()|, |tabpagenr()| and -|tabpagewinnr()| functions are useful. - -Since the number of tab labels will vary, you need to use an expression for -the whole option. Something like: > - :set tabline=%!MyTabLine() - -Then define the MyTabLine() function to list all the tab pages labels. A -convenient method is to split it in two parts: First go over all the tab -pages and define labels for them. Then get the label for each tab page. > - - function MyTabLine() - let s = '' - for i in range(tabpagenr('$')) - " select the highlighting - if i + 1 == tabpagenr() - let s .= '%#TabLineSel#' - else - let s .= '%#TabLine#' - endif - - " set the tab page number (for mouse clicks) - let s .= '%' . (i + 1) . 'T' - - " the label is made by MyTabLabel() - let s .= ' %{MyTabLabel(' . (i + 1) . ')} ' - endfor - - " after the last tab fill with TabLineFill and reset tab page nr - let s .= '%#TabLineFill#%T' - - " right-align the label to close the current tab page - if tabpagenr('$') > 1 - let s .= '%=%#TabLine#%999Xclose' - endif - - return s - endfunction - -Now the MyTabLabel() function is called for each tab page to get its label. > - - function MyTabLabel(n) - let buflist = tabpagebuflist(a:n) - let winnr = tabpagewinnr(a:n) - return bufname(buflist[winnr - 1]) - endfunction - -This is just a simplistic example that results in a tab pages line that -resembles the default, but without adding a + for a modified buffer or -truncating the names. You will want to reduce the width of labels in a -clever way when there is not enough room. Check the 'columns' option for the -space available. - -============================================================================== -5. Setting 'guitablabel' *setting-guitablabel* - -When the GUI tab pages line is displayed, 'guitablabel' can be used to -specify the label to display for each tab page. Unlike 'tabline', which -specifies the whole tab pages line at once, 'guitablabel' is used for each -label separately. - -'guitabtooltip' is very similar and is used for the tooltip of the same label. -This only appears when the mouse pointer hovers over the label, thus it -usually is longer. Only supported on some systems though. - -See the 'statusline' option for the format of the value. - -The "%N" item can be used for the current tab page number. The |v:lnum| -variable is also set to this number when the option is evaluated. -The items that use a file name refer to the current window of the tab page. - -Note that syntax highlighting is not used for the option. The %T and %X -items are also ignored. - -A simple example that puts the tab page number and the buffer name in the -label: > - :set guitablabel=%N\ %f - -An example that resembles the default 'guitablabel': Show the number of -windows in the tab page and a '+' if there is a modified buffer: > - - function GuiTabLabel() - let label = '' - let bufnrlist = tabpagebuflist(v:lnum) - - " Add '+' if one of the buffers in the tab page is modified - for bufnr in bufnrlist - if getbufvar(bufnr, "&modified") - let label = '+' - break - endif - endfor - - " Append the number of windows in the tab page if more than one - let wincount = tabpagewinnr(v:lnum, '$') - if wincount > 1 - let label .= wincount - endif - if label != '' - let label .= ' ' - endif - - " Append the buffer name - return label . bufname(bufnrlist[tabpagewinnr(v:lnum) - 1]) - endfunction - - set guitablabel=%{GuiTabLabel()} - -Note that the function must be defined before setting the option, otherwise -you get an error message for the function not being known. - -If you want to fall back to the default label, return an empty string. - -If you want to show something specific for a tab page, you might want to use a -tab page local variable. |t:var| - - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/tags b/share/vim/vim72/doc/tags deleted file mode 100644 index cf872e7a03..0000000000 --- a/share/vim/vim72/doc/tags +++ /dev/null @@ -1,8265 +0,0 @@ -! change.txt /*!* -!! change.txt /*!!* -# pattern.txt /*#* -$ motion.txt /*$* -$HOME options.txt /*$HOME* -$HOME-use version5.txt /*$HOME-use* -$VIM starting.txt /*$VIM* -$VIM-use version5.txt /*$VIM-use* -$VIMRUNTIME starting.txt /*$VIMRUNTIME* -% motion.txt /*%* -& change.txt /*&* -' motion.txt /*'* -'' motion.txt /*''* -'( motion.txt /*'(* -') motion.txt /*')* -'. motion.txt /*'.* -'0 motion.txt /*'0* -'< motion.txt /*'<* -'> motion.txt /*'>* -'A motion.txt /*'A* -'[ motion.txt /*'[* -'] motion.txt /*']* -'^ motion.txt /*'^* -'a motion.txt /*'a* -'acd' options.txt /*'acd'* -'ai' options.txt /*'ai'* -'akm' options.txt /*'akm'* -'al' options.txt /*'al'* -'aleph' options.txt /*'aleph'* -'allowrevins' options.txt /*'allowrevins'* -'altkeymap' options.txt /*'altkeymap'* -'ambiwidth' options.txt /*'ambiwidth'* -'ambw' options.txt /*'ambw'* -'anti' options.txt /*'anti'* -'antialias' options.txt /*'antialias'* -'ap' vi_diff.txt /*'ap'* -'ar' options.txt /*'ar'* -'arab' options.txt /*'arab'* -'arabic' options.txt /*'arabic'* -'arabicshape' options.txt /*'arabicshape'* -'ari' options.txt /*'ari'* -'arshape' options.txt /*'arshape'* -'as' todo.txt /*'as'* -'autochdir' options.txt /*'autochdir'* -'autoindent' options.txt /*'autoindent'* -'autoprint' vi_diff.txt /*'autoprint'* -'autoread' options.txt /*'autoread'* -'autosave' todo.txt /*'autosave'* -'autowrite' options.txt /*'autowrite'* -'autowriteall' options.txt /*'autowriteall'* -'aw' options.txt /*'aw'* -'awa' options.txt /*'awa'* -'background' options.txt /*'background'* -'backspace' options.txt /*'backspace'* -'backup' options.txt /*'backup'* -'backupcopy' options.txt /*'backupcopy'* -'backupdir' options.txt /*'backupdir'* -'backupext' options.txt /*'backupext'* -'backupskip' options.txt /*'backupskip'* -'balloondelay' options.txt /*'balloondelay'* -'ballooneval' options.txt /*'ballooneval'* -'balloonexpr' options.txt /*'balloonexpr'* -'bdir' options.txt /*'bdir'* -'bdlay' options.txt /*'bdlay'* -'beautify' vi_diff.txt /*'beautify'* -'beval' options.txt /*'beval'* -'bex' options.txt /*'bex'* -'bexpr' options.txt /*'bexpr'* -'bf' vi_diff.txt /*'bf'* -'bg' options.txt /*'bg'* -'bh' options.txt /*'bh'* -'bin' options.txt /*'bin'* -'binary' options.txt /*'binary'* -'biosk' options.txt /*'biosk'* -'bioskey' options.txt /*'bioskey'* -'bk' options.txt /*'bk'* -'bkc' options.txt /*'bkc'* -'bl' options.txt /*'bl'* -'bomb' options.txt /*'bomb'* -'breakat' options.txt /*'breakat'* -'brk' options.txt /*'brk'* -'browsedir' options.txt /*'browsedir'* -'bs' options.txt /*'bs'* -'bsdir' options.txt /*'bsdir'* -'bsk' options.txt /*'bsk'* -'bt' options.txt /*'bt'* -'bufhidden' options.txt /*'bufhidden'* -'buflisted' options.txt /*'buflisted'* -'buftype' options.txt /*'buftype'* -'casemap' options.txt /*'casemap'* -'cb' options.txt /*'cb'* -'ccv' options.txt /*'ccv'* -'cd' options.txt /*'cd'* -'cdpath' options.txt /*'cdpath'* -'cedit' options.txt /*'cedit'* -'cf' options.txt /*'cf'* -'cfu' options.txt /*'cfu'* -'ch' options.txt /*'ch'* -'character' intro.txt /*'character'* -'charconvert' options.txt /*'charconvert'* -'ci' options.txt /*'ci'* -'cin' options.txt /*'cin'* -'cindent' options.txt /*'cindent'* -'cink' options.txt /*'cink'* -'cinkeys' options.txt /*'cinkeys'* -'cino' options.txt /*'cino'* -'cinoptions' options.txt /*'cinoptions'* -'cinw' options.txt /*'cinw'* -'cinwords' options.txt /*'cinwords'* -'clipboard' options.txt /*'clipboard'* -'cmdheight' options.txt /*'cmdheight'* -'cmdwinheight' options.txt /*'cmdwinheight'* -'cmp' options.txt /*'cmp'* -'cms' options.txt /*'cms'* -'co' options.txt /*'co'* -'columns' options.txt /*'columns'* -'com' options.txt /*'com'* -'comments' options.txt /*'comments'* -'commentstring' options.txt /*'commentstring'* -'compatible' options.txt /*'compatible'* -'complete' options.txt /*'complete'* -'completefunc' options.txt /*'completefunc'* -'completeopt' options.txt /*'completeopt'* -'confirm' options.txt /*'confirm'* -'consk' options.txt /*'consk'* -'conskey' options.txt /*'conskey'* -'copyindent' options.txt /*'copyindent'* -'cot' options.txt /*'cot'* -'cp' options.txt /*'cp'* -'cpo' options.txt /*'cpo'* -'cpoptions' options.txt /*'cpoptions'* -'cpt' options.txt /*'cpt'* -'cscopepathcomp' options.txt /*'cscopepathcomp'* -'cscopeprg' options.txt /*'cscopeprg'* -'cscopequickfix' options.txt /*'cscopequickfix'* -'cscopetag' options.txt /*'cscopetag'* -'cscopetagorder' options.txt /*'cscopetagorder'* -'cscopeverbose' options.txt /*'cscopeverbose'* -'cspc' options.txt /*'cspc'* -'csprg' options.txt /*'csprg'* -'csqf' options.txt /*'csqf'* -'cst' options.txt /*'cst'* -'csto' options.txt /*'csto'* -'csverb' options.txt /*'csverb'* -'cuc' options.txt /*'cuc'* -'cul' options.txt /*'cul'* -'cursorcolumn' options.txt /*'cursorcolumn'* -'cursorline' options.txt /*'cursorline'* -'cwh' options.txt /*'cwh'* -'debug' options.txt /*'debug'* -'deco' options.txt /*'deco'* -'def' options.txt /*'def'* -'define' options.txt /*'define'* -'delcombine' options.txt /*'delcombine'* -'dex' options.txt /*'dex'* -'dg' options.txt /*'dg'* -'dict' options.txt /*'dict'* -'dictionary' options.txt /*'dictionary'* -'diff' options.txt /*'diff'* -'diffexpr' options.txt /*'diffexpr'* -'diffopt' options.txt /*'diffopt'* -'digraph' options.txt /*'digraph'* -'dip' options.txt /*'dip'* -'dir' options.txt /*'dir'* -'directory' options.txt /*'directory'* -'display' options.txt /*'display'* -'dy' options.txt /*'dy'* -'ea' options.txt /*'ea'* -'ead' options.txt /*'ead'* -'eadirection' options.txt /*'eadirection'* -'eb' options.txt /*'eb'* -'ed' options.txt /*'ed'* -'edcompatible' options.txt /*'edcompatible'* -'ef' options.txt /*'ef'* -'efm' options.txt /*'efm'* -'ei' options.txt /*'ei'* -'ek' options.txt /*'ek'* -'enc' options.txt /*'enc'* -'encoding' options.txt /*'encoding'* -'endofline' options.txt /*'endofline'* -'eol' options.txt /*'eol'* -'ep' options.txt /*'ep'* -'equalalways' options.txt /*'equalalways'* -'equalprg' options.txt /*'equalprg'* -'errorbells' options.txt /*'errorbells'* -'errorfile' options.txt /*'errorfile'* -'errorformat' options.txt /*'errorformat'* -'esckeys' options.txt /*'esckeys'* -'et' options.txt /*'et'* -'eventignore' options.txt /*'eventignore'* -'ex' options.txt /*'ex'* -'expandtab' options.txt /*'expandtab'* -'exrc' options.txt /*'exrc'* -'fcl' options.txt /*'fcl'* -'fcs' options.txt /*'fcs'* -'fdc' options.txt /*'fdc'* -'fde' options.txt /*'fde'* -'fdi' options.txt /*'fdi'* -'fdl' options.txt /*'fdl'* -'fdls' options.txt /*'fdls'* -'fdm' options.txt /*'fdm'* -'fdn' options.txt /*'fdn'* -'fdo' options.txt /*'fdo'* -'fdt' options.txt /*'fdt'* -'fe' options.txt /*'fe'* -'fen' options.txt /*'fen'* -'fenc' options.txt /*'fenc'* -'fencs' options.txt /*'fencs'* -'fex' options.txt /*'fex'* -'ff' options.txt /*'ff'* -'ffs' options.txt /*'ffs'* -'fileencoding' options.txt /*'fileencoding'* -'fileencodings' options.txt /*'fileencodings'* -'fileformat' options.txt /*'fileformat'* -'fileformats' options.txt /*'fileformats'* -'filetype' options.txt /*'filetype'* -'fillchars' options.txt /*'fillchars'* -'fk' options.txt /*'fk'* -'fkmap' options.txt /*'fkmap'* -'fl' vi_diff.txt /*'fl'* -'flash' vi_diff.txt /*'flash'* -'flp' options.txt /*'flp'* -'fml' options.txt /*'fml'* -'fmr' options.txt /*'fmr'* -'fo' options.txt /*'fo'* -'foldclose' options.txt /*'foldclose'* -'foldcolumn' options.txt /*'foldcolumn'* -'foldenable' options.txt /*'foldenable'* -'foldexpr' options.txt /*'foldexpr'* -'foldignore' options.txt /*'foldignore'* -'foldlevel' options.txt /*'foldlevel'* -'foldlevelstart' options.txt /*'foldlevelstart'* -'foldmarker' options.txt /*'foldmarker'* -'foldmethod' options.txt /*'foldmethod'* -'foldminlines' options.txt /*'foldminlines'* -'foldnestmax' options.txt /*'foldnestmax'* -'foldopen' options.txt /*'foldopen'* -'foldtext' options.txt /*'foldtext'* -'formatexpr' options.txt /*'formatexpr'* -'formatlistpat' options.txt /*'formatlistpat'* -'formatoptions' options.txt /*'formatoptions'* -'formatprg' options.txt /*'formatprg'* -'fp' options.txt /*'fp'* -'fs' options.txt /*'fs'* -'fsync' options.txt /*'fsync'* -'ft' options.txt /*'ft'* -'gcr' options.txt /*'gcr'* -'gd' options.txt /*'gd'* -'gdefault' options.txt /*'gdefault'* -'gfm' options.txt /*'gfm'* -'gfn' options.txt /*'gfn'* -'gfs' options.txt /*'gfs'* -'gfw' options.txt /*'gfw'* -'ghr' options.txt /*'ghr'* -'go' options.txt /*'go'* -'go-A' options.txt /*'go-A'* -'go-F' options.txt /*'go-F'* -'go-L' options.txt /*'go-L'* -'go-M' options.txt /*'go-M'* -'go-R' options.txt /*'go-R'* -'go-T' options.txt /*'go-T'* -'go-a' options.txt /*'go-a'* -'go-b' options.txt /*'go-b'* -'go-c' options.txt /*'go-c'* -'go-e' options.txt /*'go-e'* -'go-f' options.txt /*'go-f'* -'go-g' options.txt /*'go-g'* -'go-h' options.txt /*'go-h'* -'go-i' options.txt /*'go-i'* -'go-l' options.txt /*'go-l'* -'go-m' options.txt /*'go-m'* -'go-p' options.txt /*'go-p'* -'go-r' options.txt /*'go-r'* -'go-t' options.txt /*'go-t'* -'go-v' options.txt /*'go-v'* -'gp' options.txt /*'gp'* -'gr' vi_diff.txt /*'gr'* -'graphic' vi_diff.txt /*'graphic'* -'grepformat' options.txt /*'grepformat'* -'grepprg' options.txt /*'grepprg'* -'gtl' options.txt /*'gtl'* -'gtt' options.txt /*'gtt'* -'guicursor' options.txt /*'guicursor'* -'guifont' options.txt /*'guifont'* -'guifontset' options.txt /*'guifontset'* -'guifontwide' options.txt /*'guifontwide'* -'guiheadroom' options.txt /*'guiheadroom'* -'guioptions' options.txt /*'guioptions'* -'guipty' options.txt /*'guipty'* -'guitablabel' options.txt /*'guitablabel'* -'guitabtooltip' options.txt /*'guitabtooltip'* -'hardtabs' vi_diff.txt /*'hardtabs'* -'helpfile' options.txt /*'helpfile'* -'helpheight' options.txt /*'helpheight'* -'helplang' options.txt /*'helplang'* -'hf' options.txt /*'hf'* -'hh' options.txt /*'hh'* -'hi' options.txt /*'hi'* -'hid' options.txt /*'hid'* -'hidden' options.txt /*'hidden'* -'highlight' options.txt /*'highlight'* -'history' options.txt /*'history'* -'hk' options.txt /*'hk'* -'hkmap' options.txt /*'hkmap'* -'hkmapp' options.txt /*'hkmapp'* -'hkp' options.txt /*'hkp'* -'hl' options.txt /*'hl'* -'hlg' options.txt /*'hlg'* -'hls' options.txt /*'hls'* -'hlsearch' options.txt /*'hlsearch'* -'ht' vi_diff.txt /*'ht'* -'ic' options.txt /*'ic'* -'icon' options.txt /*'icon'* -'iconstring' options.txt /*'iconstring'* -'ignorecase' options.txt /*'ignorecase'* -'im' options.txt /*'im'* -'imactivatekey' options.txt /*'imactivatekey'* -'imak' options.txt /*'imak'* -'imc' options.txt /*'imc'* -'imcmdline' options.txt /*'imcmdline'* -'imd' options.txt /*'imd'* -'imdisable' options.txt /*'imdisable'* -'imi' options.txt /*'imi'* -'iminsert' options.txt /*'iminsert'* -'ims' options.txt /*'ims'* -'imsearch' options.txt /*'imsearch'* -'inc' options.txt /*'inc'* -'include' options.txt /*'include'* -'includeexpr' options.txt /*'includeexpr'* -'incsearch' options.txt /*'incsearch'* -'inde' options.txt /*'inde'* -'indentexpr' options.txt /*'indentexpr'* -'indentkeys' options.txt /*'indentkeys'* -'indk' options.txt /*'indk'* -'inex' options.txt /*'inex'* -'inf' options.txt /*'inf'* -'infercase' options.txt /*'infercase'* -'insertmode' options.txt /*'insertmode'* -'is' options.txt /*'is'* -'isf' options.txt /*'isf'* -'isfname' options.txt /*'isfname'* -'isi' options.txt /*'isi'* -'isident' options.txt /*'isident'* -'isk' options.txt /*'isk'* -'iskeyword' options.txt /*'iskeyword'* -'isp' options.txt /*'isp'* -'isprint' options.txt /*'isprint'* -'joinspaces' options.txt /*'joinspaces'* -'js' options.txt /*'js'* -'key' options.txt /*'key'* -'keymap' options.txt /*'keymap'* -'keymodel' options.txt /*'keymodel'* -'keywordprg' options.txt /*'keywordprg'* -'km' options.txt /*'km'* -'kmp' options.txt /*'kmp'* -'kp' options.txt /*'kp'* -'langmap' options.txt /*'langmap'* -'langmenu' options.txt /*'langmenu'* -'laststatus' options.txt /*'laststatus'* -'lazyredraw' options.txt /*'lazyredraw'* -'lbr' options.txt /*'lbr'* -'lcs' options.txt /*'lcs'* -'linebreak' options.txt /*'linebreak'* -'lines' options.txt /*'lines'* -'linespace' options.txt /*'linespace'* -'lisp' options.txt /*'lisp'* -'lispwords' options.txt /*'lispwords'* -'list' options.txt /*'list'* -'listchars' options.txt /*'listchars'* -'lm' options.txt /*'lm'* -'lmap' options.txt /*'lmap'* -'loadplugins' options.txt /*'loadplugins'* -'lpl' options.txt /*'lpl'* -'ls' options.txt /*'ls'* -'lsp' options.txt /*'lsp'* -'lw' options.txt /*'lw'* -'lz' options.txt /*'lz'* -'ma' options.txt /*'ma'* -'macatsui' options.txt /*'macatsui'* -'magic' options.txt /*'magic'* -'makeef' options.txt /*'makeef'* -'makeprg' options.txt /*'makeprg'* -'mat' options.txt /*'mat'* -'matchpairs' options.txt /*'matchpairs'* -'matchtime' options.txt /*'matchtime'* -'maxcombine' options.txt /*'maxcombine'* -'maxfuncdepth' options.txt /*'maxfuncdepth'* -'maxmapdepth' options.txt /*'maxmapdepth'* -'maxmem' options.txt /*'maxmem'* -'maxmempattern' options.txt /*'maxmempattern'* -'maxmemtot' options.txt /*'maxmemtot'* -'mco' options.txt /*'mco'* -'mef' options.txt /*'mef'* -'menuitems' options.txt /*'menuitems'* -'mesg' vi_diff.txt /*'mesg'* -'mfd' options.txt /*'mfd'* -'mh' options.txt /*'mh'* -'mis' options.txt /*'mis'* -'mkspellmem' options.txt /*'mkspellmem'* -'ml' options.txt /*'ml'* -'mls' options.txt /*'mls'* -'mm' options.txt /*'mm'* -'mmd' options.txt /*'mmd'* -'mmp' options.txt /*'mmp'* -'mmt' options.txt /*'mmt'* -'mod' options.txt /*'mod'* -'modeline' options.txt /*'modeline'* -'modelines' options.txt /*'modelines'* -'modifiable' options.txt /*'modifiable'* -'modified' options.txt /*'modified'* -'more' options.txt /*'more'* -'mouse' options.txt /*'mouse'* -'mousef' options.txt /*'mousef'* -'mousefocus' options.txt /*'mousefocus'* -'mousehide' options.txt /*'mousehide'* -'mousem' options.txt /*'mousem'* -'mousemodel' options.txt /*'mousemodel'* -'mouses' options.txt /*'mouses'* -'mouseshape' options.txt /*'mouseshape'* -'mouset' options.txt /*'mouset'* -'mousetime' options.txt /*'mousetime'* -'mp' options.txt /*'mp'* -'mps' options.txt /*'mps'* -'msm' options.txt /*'msm'* -'mzq' options.txt /*'mzq'* -'mzquantum' options.txt /*'mzquantum'* -'nf' options.txt /*'nf'* -'noacd' options.txt /*'noacd'* -'noai' options.txt /*'noai'* -'noakm' options.txt /*'noakm'* -'noallowrevins' options.txt /*'noallowrevins'* -'noaltkeymap' options.txt /*'noaltkeymap'* -'noanti' options.txt /*'noanti'* -'noantialias' options.txt /*'noantialias'* -'noar' options.txt /*'noar'* -'noarab' options.txt /*'noarab'* -'noarabic' options.txt /*'noarabic'* -'noarabicshape' options.txt /*'noarabicshape'* -'noari' options.txt /*'noari'* -'noarshape' options.txt /*'noarshape'* -'noas' todo.txt /*'noas'* -'noautochdir' options.txt /*'noautochdir'* -'noautoindent' options.txt /*'noautoindent'* -'noautoread' options.txt /*'noautoread'* -'noautosave' todo.txt /*'noautosave'* -'noautowrite' options.txt /*'noautowrite'* -'noautowriteall' options.txt /*'noautowriteall'* -'noaw' options.txt /*'noaw'* -'noawa' options.txt /*'noawa'* -'nobackup' options.txt /*'nobackup'* -'noballooneval' options.txt /*'noballooneval'* -'nobeval' options.txt /*'nobeval'* -'nobin' options.txt /*'nobin'* -'nobinary' options.txt /*'nobinary'* -'nobiosk' options.txt /*'nobiosk'* -'nobioskey' options.txt /*'nobioskey'* -'nobk' options.txt /*'nobk'* -'nobl' options.txt /*'nobl'* -'nobomb' options.txt /*'nobomb'* -'nobuflisted' options.txt /*'nobuflisted'* -'nocf' options.txt /*'nocf'* -'noci' options.txt /*'noci'* -'nocin' options.txt /*'nocin'* -'nocindent' options.txt /*'nocindent'* -'nocompatible' options.txt /*'nocompatible'* -'noconfirm' options.txt /*'noconfirm'* -'noconsk' options.txt /*'noconsk'* -'noconskey' options.txt /*'noconskey'* -'nocopyindent' options.txt /*'nocopyindent'* -'nocp' options.txt /*'nocp'* -'nocscopetag' options.txt /*'nocscopetag'* -'nocscopeverbose' options.txt /*'nocscopeverbose'* -'nocst' options.txt /*'nocst'* -'nocsverb' options.txt /*'nocsverb'* -'nocuc' options.txt /*'nocuc'* -'nocul' options.txt /*'nocul'* -'nocursorcolumn' options.txt /*'nocursorcolumn'* -'nocursorline' options.txt /*'nocursorline'* -'nodeco' options.txt /*'nodeco'* -'nodelcombine' options.txt /*'nodelcombine'* -'nodg' options.txt /*'nodg'* -'nodiff' options.txt /*'nodiff'* -'nodigraph' options.txt /*'nodigraph'* -'nodisable' options.txt /*'nodisable'* -'noea' options.txt /*'noea'* -'noeb' options.txt /*'noeb'* -'noed' options.txt /*'noed'* -'noedcompatible' options.txt /*'noedcompatible'* -'noek' options.txt /*'noek'* -'noendofline' options.txt /*'noendofline'* -'noeol' options.txt /*'noeol'* -'noequalalways' options.txt /*'noequalalways'* -'noerrorbells' options.txt /*'noerrorbells'* -'noesckeys' options.txt /*'noesckeys'* -'noet' options.txt /*'noet'* -'noex' options.txt /*'noex'* -'noexpandtab' options.txt /*'noexpandtab'* -'noexrc' options.txt /*'noexrc'* -'nofen' options.txt /*'nofen'* -'nofk' options.txt /*'nofk'* -'nofkmap' options.txt /*'nofkmap'* -'nofoldenable' options.txt /*'nofoldenable'* -'nogd' options.txt /*'nogd'* -'nogdefault' options.txt /*'nogdefault'* -'noguipty' options.txt /*'noguipty'* -'nohid' options.txt /*'nohid'* -'nohidden' options.txt /*'nohidden'* -'nohk' options.txt /*'nohk'* -'nohkmap' options.txt /*'nohkmap'* -'nohkmapp' options.txt /*'nohkmapp'* -'nohkp' options.txt /*'nohkp'* -'nohls' options.txt /*'nohls'* -'nohlsearch' options.txt /*'nohlsearch'* -'noic' options.txt /*'noic'* -'noicon' options.txt /*'noicon'* -'noignorecase' options.txt /*'noignorecase'* -'noim' options.txt /*'noim'* -'noimc' options.txt /*'noimc'* -'noimcmdline' options.txt /*'noimcmdline'* -'noimd' options.txt /*'noimd'* -'noincsearch' options.txt /*'noincsearch'* -'noinf' options.txt /*'noinf'* -'noinfercase' options.txt /*'noinfercase'* -'noinsertmode' options.txt /*'noinsertmode'* -'nois' options.txt /*'nois'* -'nojoinspaces' options.txt /*'nojoinspaces'* -'nojs' options.txt /*'nojs'* -'nolazyredraw' options.txt /*'nolazyredraw'* -'nolbr' options.txt /*'nolbr'* -'nolinebreak' options.txt /*'nolinebreak'* -'nolisp' options.txt /*'nolisp'* -'nolist' options.txt /*'nolist'* -'noloadplugins' options.txt /*'noloadplugins'* -'nolpl' options.txt /*'nolpl'* -'nolz' options.txt /*'nolz'* -'noma' options.txt /*'noma'* -'nomacatsui' options.txt /*'nomacatsui'* -'nomagic' options.txt /*'nomagic'* -'nomh' options.txt /*'nomh'* -'noml' options.txt /*'noml'* -'nomod' options.txt /*'nomod'* -'nomodeline' options.txt /*'nomodeline'* -'nomodifiable' options.txt /*'nomodifiable'* -'nomodified' options.txt /*'nomodified'* -'nomore' options.txt /*'nomore'* -'nomousef' options.txt /*'nomousef'* -'nomousefocus' options.txt /*'nomousefocus'* -'nomousehide' options.txt /*'nomousehide'* -'nonu' options.txt /*'nonu'* -'nonumber' options.txt /*'nonumber'* -'noodev' options.txt /*'noodev'* -'noopendevice' options.txt /*'noopendevice'* -'nopaste' options.txt /*'nopaste'* -'nopi' options.txt /*'nopi'* -'nopreserveindent' options.txt /*'nopreserveindent'* -'nopreviewwindow' options.txt /*'nopreviewwindow'* -'noprompt' options.txt /*'noprompt'* -'nopvw' options.txt /*'nopvw'* -'noreadonly' options.txt /*'noreadonly'* -'noremap' options.txt /*'noremap'* -'norestorescreen' options.txt /*'norestorescreen'* -'norevins' options.txt /*'norevins'* -'nori' options.txt /*'nori'* -'norightleft' options.txt /*'norightleft'* -'norightleftcmd' options.txt /*'norightleftcmd'* -'norl' options.txt /*'norl'* -'norlc' options.txt /*'norlc'* -'noro' options.txt /*'noro'* -'nors' options.txt /*'nors'* -'noru' options.txt /*'noru'* -'noruler' options.txt /*'noruler'* -'nosb' options.txt /*'nosb'* -'nosc' options.txt /*'nosc'* -'noscb' options.txt /*'noscb'* -'noscrollbind' options.txt /*'noscrollbind'* -'noscs' options.txt /*'noscs'* -'nosecure' options.txt /*'nosecure'* -'nosft' options.txt /*'nosft'* -'noshellslash' options.txt /*'noshellslash'* -'noshelltemp' options.txt /*'noshelltemp'* -'noshiftround' options.txt /*'noshiftround'* -'noshortname' options.txt /*'noshortname'* -'noshowcmd' options.txt /*'noshowcmd'* -'noshowfulltag' options.txt /*'noshowfulltag'* -'noshowmatch' options.txt /*'noshowmatch'* -'noshowmode' options.txt /*'noshowmode'* -'nosi' options.txt /*'nosi'* -'nosm' options.txt /*'nosm'* -'nosmartcase' options.txt /*'nosmartcase'* -'nosmartindent' options.txt /*'nosmartindent'* -'nosmarttab' options.txt /*'nosmarttab'* -'nosmd' options.txt /*'nosmd'* -'nosn' options.txt /*'nosn'* -'nosol' options.txt /*'nosol'* -'nospell' options.txt /*'nospell'* -'nosplitbelow' options.txt /*'nosplitbelow'* -'nosplitright' options.txt /*'nosplitright'* -'nospr' options.txt /*'nospr'* -'nosr' options.txt /*'nosr'* -'nossl' options.txt /*'nossl'* -'nosta' options.txt /*'nosta'* -'nostartofline' options.txt /*'nostartofline'* -'nostmp' options.txt /*'nostmp'* -'noswapfile' options.txt /*'noswapfile'* -'noswf' options.txt /*'noswf'* -'nota' options.txt /*'nota'* -'notagbsearch' options.txt /*'notagbsearch'* -'notagrelative' options.txt /*'notagrelative'* -'notagstack' options.txt /*'notagstack'* -'notbi' options.txt /*'notbi'* -'notbidi' options.txt /*'notbidi'* -'notbs' options.txt /*'notbs'* -'notermbidi' options.txt /*'notermbidi'* -'noterse' options.txt /*'noterse'* -'notextauto' options.txt /*'notextauto'* -'notextmode' options.txt /*'notextmode'* -'notf' options.txt /*'notf'* -'notgst' options.txt /*'notgst'* -'notildeop' options.txt /*'notildeop'* -'notimeout' options.txt /*'notimeout'* -'notitle' options.txt /*'notitle'* -'noto' options.txt /*'noto'* -'notop' options.txt /*'notop'* -'notr' options.txt /*'notr'* -'nottimeout' options.txt /*'nottimeout'* -'nottybuiltin' options.txt /*'nottybuiltin'* -'nottyfast' options.txt /*'nottyfast'* -'notx' options.txt /*'notx'* -'novb' options.txt /*'novb'* -'novice' vi_diff.txt /*'novice'* -'novisualbell' options.txt /*'novisualbell'* -'nowa' options.txt /*'nowa'* -'nowarn' options.txt /*'nowarn'* -'nowb' options.txt /*'nowb'* -'noweirdinvert' options.txt /*'noweirdinvert'* -'nowfh' options.txt /*'nowfh'* -'nowfw' options.txt /*'nowfw'* -'nowildmenu' options.txt /*'nowildmenu'* -'nowinfixheight' options.txt /*'nowinfixheight'* -'nowinfixwidth' options.txt /*'nowinfixwidth'* -'nowiv' options.txt /*'nowiv'* -'nowmnu' options.txt /*'nowmnu'* -'nowrap' options.txt /*'nowrap'* -'nowrapscan' options.txt /*'nowrapscan'* -'nowrite' options.txt /*'nowrite'* -'nowriteany' options.txt /*'nowriteany'* -'nowritebackup' options.txt /*'nowritebackup'* -'nows' options.txt /*'nows'* -'nrformats' options.txt /*'nrformats'* -'nu' options.txt /*'nu'* -'number' options.txt /*'number'* -'numberwidth' options.txt /*'numberwidth'* -'nuw' options.txt /*'nuw'* -'odev' options.txt /*'odev'* -'oft' options.txt /*'oft'* -'ofu' options.txt /*'ofu'* -'omnifunc' options.txt /*'omnifunc'* -'op' vi_diff.txt /*'op'* -'open' vi_diff.txt /*'open'* -'opendevice' options.txt /*'opendevice'* -'operatorfunc' options.txt /*'operatorfunc'* -'opfunc' options.txt /*'opfunc'* -'optimize' vi_diff.txt /*'optimize'* -'option' intro.txt /*'option'* -'osfiletype' options.txt /*'osfiletype'* -'pa' options.txt /*'pa'* -'para' options.txt /*'para'* -'paragraphs' options.txt /*'paragraphs'* -'paste' options.txt /*'paste'* -'pastetoggle' options.txt /*'pastetoggle'* -'patchexpr' options.txt /*'patchexpr'* -'patchmode' options.txt /*'patchmode'* -'path' options.txt /*'path'* -'pdev' options.txt /*'pdev'* -'penc' options.txt /*'penc'* -'pex' options.txt /*'pex'* -'pexpr' options.txt /*'pexpr'* -'pfn' options.txt /*'pfn'* -'ph' options.txt /*'ph'* -'pheader' options.txt /*'pheader'* -'pi' options.txt /*'pi'* -'pm' options.txt /*'pm'* -'pmbcs' options.txt /*'pmbcs'* -'pmbfn' options.txt /*'pmbfn'* -'popt' options.txt /*'popt'* -'preserveindent' options.txt /*'preserveindent'* -'previewheight' options.txt /*'previewheight'* -'previewwindow' options.txt /*'previewwindow'* -'printdevice' options.txt /*'printdevice'* -'printencoding' options.txt /*'printencoding'* -'printexpr' options.txt /*'printexpr'* -'printfont' options.txt /*'printfont'* -'printheader' options.txt /*'printheader'* -'printmbcharset' options.txt /*'printmbcharset'* -'printmbfont' options.txt /*'printmbfont'* -'printoptions' options.txt /*'printoptions'* -'prompt' options.txt /*'prompt'* -'pt' options.txt /*'pt'* -'pumheight' options.txt /*'pumheight'* -'pvh' options.txt /*'pvh'* -'pvw' options.txt /*'pvw'* -'qe' options.txt /*'qe'* -'quote motion.txt /*'quote* -'quoteescape' options.txt /*'quoteescape'* -'rdt' options.txt /*'rdt'* -'readonly' options.txt /*'readonly'* -'redraw' vi_diff.txt /*'redraw'* -'redrawtime' options.txt /*'redrawtime'* -'remap' options.txt /*'remap'* -'report' options.txt /*'report'* -'restorescreen' options.txt /*'restorescreen'* -'revins' options.txt /*'revins'* -'ri' options.txt /*'ri'* -'rightleft' options.txt /*'rightleft'* -'rightleftcmd' options.txt /*'rightleftcmd'* -'rl' options.txt /*'rl'* -'rlc' options.txt /*'rlc'* -'ro' options.txt /*'ro'* -'rs' options.txt /*'rs'* -'rtp' options.txt /*'rtp'* -'ru' options.txt /*'ru'* -'ruf' options.txt /*'ruf'* -'ruler' options.txt /*'ruler'* -'rulerformat' options.txt /*'rulerformat'* -'runtimepath' options.txt /*'runtimepath'* -'sb' options.txt /*'sb'* -'sbo' options.txt /*'sbo'* -'sbr' options.txt /*'sbr'* -'sc' options.txt /*'sc'* -'scb' options.txt /*'scb'* -'scr' options.txt /*'scr'* -'scroll' options.txt /*'scroll'* -'scrollbind' options.txt /*'scrollbind'* -'scrolljump' options.txt /*'scrolljump'* -'scrolloff' options.txt /*'scrolloff'* -'scrollopt' options.txt /*'scrollopt'* -'scs' options.txt /*'scs'* -'sect' options.txt /*'sect'* -'sections' options.txt /*'sections'* -'secure' options.txt /*'secure'* -'sel' options.txt /*'sel'* -'selection' options.txt /*'selection'* -'selectmode' options.txt /*'selectmode'* -'sessionoptions' options.txt /*'sessionoptions'* -'sft' options.txt /*'sft'* -'sh' options.txt /*'sh'* -'shcf' options.txt /*'shcf'* -'shell' options.txt /*'shell'* -'shellcmdflag' options.txt /*'shellcmdflag'* -'shellpipe' options.txt /*'shellpipe'* -'shellquote' options.txt /*'shellquote'* -'shellredir' options.txt /*'shellredir'* -'shellslash' options.txt /*'shellslash'* -'shelltemp' options.txt /*'shelltemp'* -'shelltype' options.txt /*'shelltype'* -'shellxquote' options.txt /*'shellxquote'* -'shiftround' options.txt /*'shiftround'* -'shiftwidth' options.txt /*'shiftwidth'* -'shm' options.txt /*'shm'* -'shortmess' options.txt /*'shortmess'* -'shortname' options.txt /*'shortname'* -'showbreak' options.txt /*'showbreak'* -'showcmd' options.txt /*'showcmd'* -'showfulltag' options.txt /*'showfulltag'* -'showmatch' options.txt /*'showmatch'* -'showmode' options.txt /*'showmode'* -'showtabline' options.txt /*'showtabline'* -'shq' options.txt /*'shq'* -'si' options.txt /*'si'* -'sidescroll' options.txt /*'sidescroll'* -'sidescrolloff' options.txt /*'sidescrolloff'* -'siso' options.txt /*'siso'* -'sj' options.txt /*'sj'* -'slm' options.txt /*'slm'* -'slow' vi_diff.txt /*'slow'* -'slowopen' vi_diff.txt /*'slowopen'* -'sm' options.txt /*'sm'* -'smartcase' options.txt /*'smartcase'* -'smartindent' options.txt /*'smartindent'* -'smarttab' options.txt /*'smarttab'* -'smc' options.txt /*'smc'* -'smd' options.txt /*'smd'* -'sn' options.txt /*'sn'* -'so' options.txt /*'so'* -'softtabstop' options.txt /*'softtabstop'* -'sol' options.txt /*'sol'* -'sourceany' vi_diff.txt /*'sourceany'* -'sp' options.txt /*'sp'* -'spc' options.txt /*'spc'* -'spell' options.txt /*'spell'* -'spellcapcheck' options.txt /*'spellcapcheck'* -'spellfile' options.txt /*'spellfile'* -'spelllang' options.txt /*'spelllang'* -'spellsuggest' options.txt /*'spellsuggest'* -'spf' options.txt /*'spf'* -'spl' options.txt /*'spl'* -'splitbelow' options.txt /*'splitbelow'* -'splitright' options.txt /*'splitright'* -'spr' options.txt /*'spr'* -'sps' options.txt /*'sps'* -'sr' options.txt /*'sr'* -'srr' options.txt /*'srr'* -'ss' options.txt /*'ss'* -'ssl' options.txt /*'ssl'* -'ssop' options.txt /*'ssop'* -'st' options.txt /*'st'* -'sta' options.txt /*'sta'* -'stal' options.txt /*'stal'* -'startofline' options.txt /*'startofline'* -'statusline' options.txt /*'statusline'* -'stl' options.txt /*'stl'* -'stmp' options.txt /*'stmp'* -'sts' options.txt /*'sts'* -'su' options.txt /*'su'* -'sua' options.txt /*'sua'* -'suffixes' options.txt /*'suffixes'* -'suffixesadd' options.txt /*'suffixesadd'* -'sw' options.txt /*'sw'* -'swapfile' options.txt /*'swapfile'* -'swapsync' options.txt /*'swapsync'* -'swb' options.txt /*'swb'* -'swf' options.txt /*'swf'* -'switchbuf' options.txt /*'switchbuf'* -'sws' options.txt /*'sws'* -'sxq' options.txt /*'sxq'* -'syn' options.txt /*'syn'* -'synmaxcol' options.txt /*'synmaxcol'* -'syntax' options.txt /*'syntax'* -'t_#2' term.txt /*'t_#2'* -'t_#4' term.txt /*'t_#4'* -'t_%1' term.txt /*'t_%1'* -'t_%i' term.txt /*'t_%i'* -'t_&8' term.txt /*'t_&8'* -'t_@7' term.txt /*'t_@7'* -'t_AB' term.txt /*'t_AB'* -'t_AF' term.txt /*'t_AF'* -'t_AL' term.txt /*'t_AL'* -'t_CS' term.txt /*'t_CS'* -'t_CV' term.txt /*'t_CV'* -'t_Ce' term.txt /*'t_Ce'* -'t_Co' term.txt /*'t_Co'* -'t_Cs' term.txt /*'t_Cs'* -'t_DL' term.txt /*'t_DL'* -'t_EI' term.txt /*'t_EI'* -'t_F1' term.txt /*'t_F1'* -'t_F2' term.txt /*'t_F2'* -'t_F3' term.txt /*'t_F3'* -'t_F4' term.txt /*'t_F4'* -'t_F5' term.txt /*'t_F5'* -'t_F6' term.txt /*'t_F6'* -'t_F7' term.txt /*'t_F7'* -'t_F8' term.txt /*'t_F8'* -'t_F9' term.txt /*'t_F9'* -'t_IE' term.txt /*'t_IE'* -'t_IS' term.txt /*'t_IS'* -'t_K1' term.txt /*'t_K1'* -'t_K3' term.txt /*'t_K3'* -'t_K4' term.txt /*'t_K4'* -'t_K5' term.txt /*'t_K5'* -'t_K6' term.txt /*'t_K6'* -'t_K7' term.txt /*'t_K7'* -'t_K8' term.txt /*'t_K8'* -'t_K9' term.txt /*'t_K9'* -'t_KA' term.txt /*'t_KA'* -'t_KB' term.txt /*'t_KB'* -'t_KC' term.txt /*'t_KC'* -'t_KD' term.txt /*'t_KD'* -'t_KE' term.txt /*'t_KE'* -'t_KF' term.txt /*'t_KF'* -'t_KG' term.txt /*'t_KG'* -'t_KH' term.txt /*'t_KH'* -'t_KI' term.txt /*'t_KI'* -'t_KJ' term.txt /*'t_KJ'* -'t_KK' term.txt /*'t_KK'* -'t_KL' term.txt /*'t_KL'* -'t_RI' term.txt /*'t_RI'* -'t_RV' term.txt /*'t_RV'* -'t_SI' term.txt /*'t_SI'* -'t_Sb' term.txt /*'t_Sb'* -'t_Sf' term.txt /*'t_Sf'* -'t_WP' term.txt /*'t_WP'* -'t_WS' term.txt /*'t_WS'* -'t_ZH' term.txt /*'t_ZH'* -'t_ZR' term.txt /*'t_ZR'* -'t_al' term.txt /*'t_al'* -'t_bc' term.txt /*'t_bc'* -'t_cd' term.txt /*'t_cd'* -'t_ce' term.txt /*'t_ce'* -'t_cl' term.txt /*'t_cl'* -'t_cm' term.txt /*'t_cm'* -'t_cs' term.txt /*'t_cs'* -'t_da' term.txt /*'t_da'* -'t_db' term.txt /*'t_db'* -'t_dl' term.txt /*'t_dl'* -'t_fs' term.txt /*'t_fs'* -'t_k1' term.txt /*'t_k1'* -'t_k2' term.txt /*'t_k2'* -'t_k3' term.txt /*'t_k3'* -'t_k4' term.txt /*'t_k4'* -'t_k5' term.txt /*'t_k5'* -'t_k6' term.txt /*'t_k6'* -'t_k7' term.txt /*'t_k7'* -'t_k8' term.txt /*'t_k8'* -'t_k9' term.txt /*'t_k9'* -'t_k;' term.txt /*'t_k;'* -'t_kB' term.txt /*'t_kB'* -'t_kD' term.txt /*'t_kD'* -'t_kI' term.txt /*'t_kI'* -'t_kN' term.txt /*'t_kN'* -'t_kP' term.txt /*'t_kP'* -'t_kb' term.txt /*'t_kb'* -'t_kd' term.txt /*'t_kd'* -'t_ke' term.txt /*'t_ke'* -'t_kh' term.txt /*'t_kh'* -'t_kl' term.txt /*'t_kl'* -'t_kr' term.txt /*'t_kr'* -'t_ks' term.txt /*'t_ks'* -'t_ku' term.txt /*'t_ku'* -'t_le' term.txt /*'t_le'* -'t_mb' term.txt /*'t_mb'* -'t_md' term.txt /*'t_md'* -'t_me' term.txt /*'t_me'* -'t_mr' term.txt /*'t_mr'* -'t_ms' term.txt /*'t_ms'* -'t_nd' term.txt /*'t_nd'* -'t_op' term.txt /*'t_op'* -'t_se' term.txt /*'t_se'* -'t_so' term.txt /*'t_so'* -'t_sr' term.txt /*'t_sr'* -'t_star7' term.txt /*'t_star7'* -'t_te' term.txt /*'t_te'* -'t_ti' term.txt /*'t_ti'* -'t_ts' term.txt /*'t_ts'* -'t_ue' term.txt /*'t_ue'* -'t_us' term.txt /*'t_us'* -'t_ut' term.txt /*'t_ut'* -'t_vb' term.txt /*'t_vb'* -'t_ve' term.txt /*'t_ve'* -'t_vi' term.txt /*'t_vi'* -'t_vs' term.txt /*'t_vs'* -'t_xs' term.txt /*'t_xs'* -'ta' options.txt /*'ta'* -'tabline' options.txt /*'tabline'* -'tabpagemax' options.txt /*'tabpagemax'* -'tabstop' options.txt /*'tabstop'* -'tag' options.txt /*'tag'* -'tagbsearch' options.txt /*'tagbsearch'* -'taglength' options.txt /*'taglength'* -'tagrelative' options.txt /*'tagrelative'* -'tags' options.txt /*'tags'* -'tagstack' options.txt /*'tagstack'* -'tal' options.txt /*'tal'* -'tb' options.txt /*'tb'* -'tbi' options.txt /*'tbi'* -'tbidi' options.txt /*'tbidi'* -'tbis' options.txt /*'tbis'* -'tbs' options.txt /*'tbs'* -'tenc' options.txt /*'tenc'* -'term' options.txt /*'term'* -'termbidi' options.txt /*'termbidi'* -'termencoding' options.txt /*'termencoding'* -'terse' options.txt /*'terse'* -'textauto' options.txt /*'textauto'* -'textmode' options.txt /*'textmode'* -'textwidth' options.txt /*'textwidth'* -'tf' options.txt /*'tf'* -'tgst' options.txt /*'tgst'* -'thesaurus' options.txt /*'thesaurus'* -'tildeop' options.txt /*'tildeop'* -'timeout' options.txt /*'timeout'* -'timeoutlen' options.txt /*'timeoutlen'* -'title' options.txt /*'title'* -'titlelen' options.txt /*'titlelen'* -'titleold' options.txt /*'titleold'* -'titlestring' options.txt /*'titlestring'* -'tl' options.txt /*'tl'* -'tm' options.txt /*'tm'* -'to' options.txt /*'to'* -'toolbar' options.txt /*'toolbar'* -'toolbariconsize' options.txt /*'toolbariconsize'* -'top' options.txt /*'top'* -'tpm' options.txt /*'tpm'* -'tr' options.txt /*'tr'* -'ts' options.txt /*'ts'* -'tsl' options.txt /*'tsl'* -'tsr' options.txt /*'tsr'* -'ttimeout' options.txt /*'ttimeout'* -'ttimeoutlen' options.txt /*'ttimeoutlen'* -'ttm' options.txt /*'ttm'* -'tty' options.txt /*'tty'* -'ttybuiltin' options.txt /*'ttybuiltin'* -'ttyfast' options.txt /*'ttyfast'* -'ttym' options.txt /*'ttym'* -'ttymouse' options.txt /*'ttymouse'* -'ttyscroll' options.txt /*'ttyscroll'* -'ttytype' options.txt /*'ttytype'* -'tw' options.txt /*'tw'* -'tx' options.txt /*'tx'* -'uc' options.txt /*'uc'* -'ul' options.txt /*'ul'* -'undolevels' options.txt /*'undolevels'* -'updatecount' options.txt /*'updatecount'* -'updatetime' options.txt /*'updatetime'* -'ut' options.txt /*'ut'* -'vb' options.txt /*'vb'* -'vbs' options.txt /*'vbs'* -'vdir' options.txt /*'vdir'* -'ve' options.txt /*'ve'* -'verbose' options.txt /*'verbose'* -'verbosefile' options.txt /*'verbosefile'* -'vfile' options.txt /*'vfile'* -'vi' options.txt /*'vi'* -'viewdir' options.txt /*'viewdir'* -'viewoptions' options.txt /*'viewoptions'* -'viminfo' options.txt /*'viminfo'* -'virtualedit' options.txt /*'virtualedit'* -'visualbell' options.txt /*'visualbell'* -'vop' options.txt /*'vop'* -'w1200' vi_diff.txt /*'w1200'* -'w300' vi_diff.txt /*'w300'* -'w9600' vi_diff.txt /*'w9600'* -'wa' options.txt /*'wa'* -'wak' options.txt /*'wak'* -'warn' options.txt /*'warn'* -'wb' options.txt /*'wb'* -'wc' options.txt /*'wc'* -'wcm' options.txt /*'wcm'* -'wd' options.txt /*'wd'* -'weirdinvert' options.txt /*'weirdinvert'* -'wfh' options.txt /*'wfh'* -'wfw' options.txt /*'wfw'* -'wh' options.txt /*'wh'* -'whichwrap' options.txt /*'whichwrap'* -'wi' options.txt /*'wi'* -'wig' options.txt /*'wig'* -'wildchar' options.txt /*'wildchar'* -'wildcharm' options.txt /*'wildcharm'* -'wildignore' options.txt /*'wildignore'* -'wildmenu' options.txt /*'wildmenu'* -'wildmode' options.txt /*'wildmode'* -'wildoptions' options.txt /*'wildoptions'* -'wim' options.txt /*'wim'* -'winaltkeys' options.txt /*'winaltkeys'* -'window' options.txt /*'window'* -'winfixheight' options.txt /*'winfixheight'* -'winfixwidth' options.txt /*'winfixwidth'* -'winheight' options.txt /*'winheight'* -'winminheight' options.txt /*'winminheight'* -'winminwidth' options.txt /*'winminwidth'* -'winwidth' options.txt /*'winwidth'* -'wiv' options.txt /*'wiv'* -'wiw' options.txt /*'wiw'* -'wm' options.txt /*'wm'* -'wmh' options.txt /*'wmh'* -'wmnu' options.txt /*'wmnu'* -'wmw' options.txt /*'wmw'* -'wop' options.txt /*'wop'* -'wrap' options.txt /*'wrap'* -'wrapmargin' options.txt /*'wrapmargin'* -'wrapscan' options.txt /*'wrapscan'* -'write' options.txt /*'write'* -'writeany' options.txt /*'writeany'* -'writebackup' options.txt /*'writebackup'* -'writedelay' options.txt /*'writedelay'* -'ws' options.txt /*'ws'* -'ww' options.txt /*'ww'* -'{ motion.txt /*'{* -'} motion.txt /*'}* -( motion.txt /*(* -) motion.txt /*)* -+ motion.txt /*+* -++bad editing.txt /*++bad* -++bin editing.txt /*++bin* -++builtin_terms various.txt /*++builtin_terms* -++edit editing.txt /*++edit* -++enc editing.txt /*++enc* -++ff editing.txt /*++ff* -++nobin editing.txt /*++nobin* -++opt editing.txt /*++opt* -+ARP various.txt /*+ARP* -+GUI_Athena various.txt /*+GUI_Athena* -+GUI_GTK various.txt /*+GUI_GTK* -+GUI_Motif various.txt /*+GUI_Motif* -+GUI_Photon various.txt /*+GUI_Photon* -+GUI_neXtaw various.txt /*+GUI_neXtaw* -+X11 various.txt /*+X11* -+arabic various.txt /*+arabic* -+autocmd various.txt /*+autocmd* -+balloon_eval various.txt /*+balloon_eval* -+browse various.txt /*+browse* -+builtin_terms various.txt /*+builtin_terms* -+byte_offset various.txt /*+byte_offset* -+cindent various.txt /*+cindent* -+clientserver various.txt /*+clientserver* -+clipboard various.txt /*+clipboard* -+cmd editing.txt /*+cmd* -+cmdline_compl various.txt /*+cmdline_compl* -+cmdline_hist various.txt /*+cmdline_hist* -+cmdline_info various.txt /*+cmdline_info* -+comments various.txt /*+comments* -+cryptv various.txt /*+cryptv* -+cscope various.txt /*+cscope* -+cursorshape various.txt /*+cursorshape* -+debug various.txt /*+debug* -+dialog_con various.txt /*+dialog_con* -+dialog_con_gui various.txt /*+dialog_con_gui* -+dialog_gui various.txt /*+dialog_gui* -+diff various.txt /*+diff* -+digraphs various.txt /*+digraphs* -+dnd various.txt /*+dnd* -+emacs_tags various.txt /*+emacs_tags* -+eval various.txt /*+eval* -+ex_extra various.txt /*+ex_extra* -+extra_search various.txt /*+extra_search* -+farsi various.txt /*+farsi* -+feature-list various.txt /*+feature-list* -+file_in_path various.txt /*+file_in_path* -+find_in_path various.txt /*+find_in_path* -+float various.txt /*+float* -+folding various.txt /*+folding* -+footer various.txt /*+footer* -+fork various.txt /*+fork* -+gettext various.txt /*+gettext* -+hangul_input various.txt /*+hangul_input* -+iconv various.txt /*+iconv* -+iconv/dyn various.txt /*+iconv\/dyn* -+insert_expand various.txt /*+insert_expand* -+jumplist various.txt /*+jumplist* -+keymap various.txt /*+keymap* -+langmap various.txt /*+langmap* -+libcall various.txt /*+libcall* -+linebreak various.txt /*+linebreak* -+lispindent various.txt /*+lispindent* -+listcmds various.txt /*+listcmds* -+localmap various.txt /*+localmap* -+menu various.txt /*+menu* -+mksession various.txt /*+mksession* -+modify_fname various.txt /*+modify_fname* -+mouse various.txt /*+mouse* -+mouse_dec various.txt /*+mouse_dec* -+mouse_gpm various.txt /*+mouse_gpm* -+mouse_netterm various.txt /*+mouse_netterm* -+mouse_pterm various.txt /*+mouse_pterm* -+mouse_sysmouse various.txt /*+mouse_sysmouse* -+mouse_xterm various.txt /*+mouse_xterm* -+mouseshape various.txt /*+mouseshape* -+multi_byte various.txt /*+multi_byte* -+multi_byte_ime various.txt /*+multi_byte_ime* -+multi_lang various.txt /*+multi_lang* -+mzscheme various.txt /*+mzscheme* -+mzscheme/dyn various.txt /*+mzscheme\/dyn* -+netbeans_intg various.txt /*+netbeans_intg* -+ole various.txt /*+ole* -+osfiletype various.txt /*+osfiletype* -+path_extra various.txt /*+path_extra* -+perl various.txt /*+perl* -+perl/dyn various.txt /*+perl\/dyn* -+postscript various.txt /*+postscript* -+printer various.txt /*+printer* -+profile various.txt /*+profile* -+python various.txt /*+python* -+python/dyn various.txt /*+python\/dyn* -+quickfix various.txt /*+quickfix* -+reltime various.txt /*+reltime* -+rightleft various.txt /*+rightleft* -+ruby various.txt /*+ruby* -+ruby/dyn various.txt /*+ruby\/dyn* -+scrollbind various.txt /*+scrollbind* -+signs various.txt /*+signs* -+smartindent various.txt /*+smartindent* -+sniff various.txt /*+sniff* -+statusline various.txt /*+statusline* -+sun_workshop various.txt /*+sun_workshop* -+syntax various.txt /*+syntax* -+system() various.txt /*+system()* -+tag_any_white various.txt /*+tag_any_white* -+tag_binary various.txt /*+tag_binary* -+tag_old_static various.txt /*+tag_old_static* -+tcl various.txt /*+tcl* -+tcl/dyn various.txt /*+tcl\/dyn* -+terminfo various.txt /*+terminfo* -+termresponse various.txt /*+termresponse* -+textobjects various.txt /*+textobjects* -+tgetent various.txt /*+tgetent* -+title various.txt /*+title* -+toolbar various.txt /*+toolbar* -+user_commands various.txt /*+user_commands* -+vertsplit various.txt /*+vertsplit* -+viminfo various.txt /*+viminfo* -+virtualedit various.txt /*+virtualedit* -+visual various.txt /*+visual* -+visualextra various.txt /*+visualextra* -+vreplace various.txt /*+vreplace* -+wildignore various.txt /*+wildignore* -+wildmenu various.txt /*+wildmenu* -+windows various.txt /*+windows* -+writebackup various.txt /*+writebackup* -+xfontset various.txt /*+xfontset* -+xim various.txt /*+xim* -+xsmp various.txt /*+xsmp* -+xsmp_interact various.txt /*+xsmp_interact* -+xterm_clipboard various.txt /*+xterm_clipboard* -+xterm_save various.txt /*+xterm_save* -, motion.txt /*,* -- motion.txt /*-* --+ starting.txt /*-+* --+/ starting.txt /*-+\/* --+c starting.txt /*-+c* --+reverse gui_x11.txt /*-+reverse* --+rv gui_x11.txt /*-+rv* --- starting.txt /*--* ---- starting.txt /*---* ---cmd starting.txt /*--cmd* ---echo-wid starting.txt /*--echo-wid* ---help starting.txt /*--help* ---literal starting.txt /*--literal* ---nofork starting.txt /*--nofork* ---noplugin starting.txt /*--noplugin* ---remote remote.txt /*--remote* ---remote-expr remote.txt /*--remote-expr* ---remote-send remote.txt /*--remote-send* ---remote-silent remote.txt /*--remote-silent* ---remote-tab remote.txt /*--remote-tab* ---remote-tab-silent remote.txt /*--remote-tab-silent* ---remote-tab-wait remote.txt /*--remote-tab-wait* ---remote-tab-wait-silent remote.txt /*--remote-tab-wait-silent* ---remote-wait remote.txt /*--remote-wait* ---remote-wait-silent remote.txt /*--remote-wait-silent* ---role starting.txt /*--role* ---serverlist remote.txt /*--serverlist* ---servername remote.txt /*--servername* ---socketid starting.txt /*--socketid* ---version starting.txt /*--version* ---windowid starting.txt /*--windowid* --A starting.txt /*-A* --C starting.txt /*-C* --D starting.txt /*-D* --E starting.txt /*-E* --F starting.txt /*-F* --H starting.txt /*-H* --L starting.txt /*-L* --M starting.txt /*-M* --N starting.txt /*-N* --O starting.txt /*-O* --P starting.txt /*-P* --R starting.txt /*-R* --S starting.txt /*-S* --T starting.txt /*-T* --U starting.txt /*-U* --V starting.txt /*-V* --W starting.txt /*-W* --X starting.txt /*-X* --Z starting.txt /*-Z* --b starting.txt /*-b* --background gui_x11.txt /*-background* --bg gui_x11.txt /*-bg* --boldfont gui_x11.txt /*-boldfont* --borderwidth gui_x11.txt /*-borderwidth* --bw gui_x11.txt /*-bw* --c starting.txt /*-c* --d starting.txt /*-d* --dev starting.txt /*-dev* --display gui_x11.txt /*-display* --e starting.txt /*-e* --f starting.txt /*-f* --fg gui_x11.txt /*-fg* --file starting.txt /*-file* --fn gui_x11.txt /*-fn* --font gui_x11.txt /*-font* --foreground gui_x11.txt /*-foreground* --g starting.txt /*-g* --geom gui_x11.txt /*-geom* --geometry gui_x11.txt /*-geometry* --geometry-example gui_x11.txt /*-geometry-example* --gui gui_x11.txt /*-gui* --h starting.txt /*-h* --i starting.txt /*-i* --iconic gui_x11.txt /*-iconic* --italicfont gui_x11.txt /*-italicfont* --l starting.txt /*-l* --m starting.txt /*-m* --menufont gui_x11.txt /*-menufont* --menufontset gui_x11.txt /*-menufontset* --menuheight gui_x11.txt /*-menuheight* --mf gui_x11.txt /*-mf* --mh gui_x11.txt /*-mh* --n starting.txt /*-n* --nb starting.txt /*-nb* --o starting.txt /*-o* --p starting.txt /*-p* --q starting.txt /*-q* --qf starting.txt /*-qf* --r starting.txt /*-r* --register if_ole.txt /*-register* --reverse gui_x11.txt /*-reverse* --rv gui_x11.txt /*-rv* --s starting.txt /*-s* --s-ex starting.txt /*-s-ex* --scrollbarwidth gui_x11.txt /*-scrollbarwidth* --silent if_ole.txt /*-silent* --sw gui_x11.txt /*-sw* --t starting.txt /*-t* --tag starting.txt /*-tag* --u starting.txt /*-u* --ul gui_x11.txt /*-ul* --unregister if_ole.txt /*-unregister* --v starting.txt /*-v* --vim starting.txt /*-vim* --w starting.txt /*-w* --w_nr starting.txt /*-w_nr* --x starting.txt /*-x* --xrm gui_x11.txt /*-xrm* --y starting.txt /*-y* -. repeat.txt /*.* -... eval.txt /*...* -.Xdefaults gui_x11.txt /*.Xdefaults* -.aff spell.txt /*.aff* -.dic spell.txt /*.dic* -.exrc starting.txt /*.exrc* -.gvimrc gui.txt /*.gvimrc* -.vimrc starting.txt /*.vimrc* -/ pattern.txt /*\/* -/$ pattern.txt /*\/$* -/. pattern.txt /*\/.* -// version7.txt /*\/\/* -//; pattern.txt /*\/\/;* -/<CR> pattern.txt /*\/<CR>* -/[[. pattern.txt /*\/[[.* -/[[= pattern.txt /*\/[[=* -/[\n] pattern.txt /*\/[\\n]* -/[] pattern.txt /*\/[]* -/\ pattern.txt /*\/\\* -/\$ pattern.txt /*\/\\$* -/\%# pattern.txt /*\/\\%#* -/\%$ pattern.txt /*\/\\%$* -/\%'m pattern.txt /*\/\\%'m* -/\%( pattern.txt /*\/\\%(* -/\%(\) pattern.txt /*\/\\%(\\)* -/\%<'m pattern.txt /*\/\\%<'m* -/\%<c pattern.txt /*\/\\%<c* -/\%<l pattern.txt /*\/\\%<l* -/\%<v pattern.txt /*\/\\%<v* -/\%>'m pattern.txt /*\/\\%>'m* -/\%>c pattern.txt /*\/\\%>c* -/\%>l pattern.txt /*\/\\%>l* -/\%>v pattern.txt /*\/\\%>v* -/\%U pattern.txt /*\/\\%U* -/\%V pattern.txt /*\/\\%V* -/\%[] pattern.txt /*\/\\%[]* -/\%^ pattern.txt /*\/\\%^* -/\%c pattern.txt /*\/\\%c* -/\%d pattern.txt /*\/\\%d* -/\%l pattern.txt /*\/\\%l* -/\%o pattern.txt /*\/\\%o* -/\%u pattern.txt /*\/\\%u* -/\%v pattern.txt /*\/\\%v* -/\%x pattern.txt /*\/\\%x* -/\& pattern.txt /*\/\\&* -/\( pattern.txt /*\/\\(* -/\(\) pattern.txt /*\/\\(\\)* -/\) pattern.txt /*\/\\)* -/\+ pattern.txt /*\/\\+* -/\. pattern.txt /*\/\\.* -/\1 pattern.txt /*\/\\1* -/\2 pattern.txt /*\/\\2* -/\3 pattern.txt /*\/\\3* -/\9 pattern.txt /*\/\\9* -/\< pattern.txt /*\/\\<* -/\= pattern.txt /*\/\\=* -/\> pattern.txt /*\/\\>* -/\? pattern.txt /*\/\\?* -/\@! pattern.txt /*\/\\@!* -/\@<! pattern.txt /*\/\\@<!* -/\@<= pattern.txt /*\/\\@<=* -/\@= pattern.txt /*\/\\@=* -/\@> pattern.txt /*\/\\@>* -/\A pattern.txt /*\/\\A* -/\C pattern.txt /*\/\\C* -/\D pattern.txt /*\/\\D* -/\F pattern.txt /*\/\\F* -/\H pattern.txt /*\/\\H* -/\I pattern.txt /*\/\\I* -/\K pattern.txt /*\/\\K* -/\L pattern.txt /*\/\\L* -/\M pattern.txt /*\/\\M* -/\O pattern.txt /*\/\\O* -/\P pattern.txt /*\/\\P* -/\S pattern.txt /*\/\\S* -/\U pattern.txt /*\/\\U* -/\V pattern.txt /*\/\\V* -/\W pattern.txt /*\/\\W* -/\X pattern.txt /*\/\\X* -/\Z pattern.txt /*\/\\Z* -/\[] pattern.txt /*\/\\[]* -/\\ pattern.txt /*\/\\\\* -/\] pattern.txt /*\/\\]* -/\^ pattern.txt /*\/\\^* -/\_ pattern.txt /*\/\\_* -/\_$ pattern.txt /*\/\\_$* -/\_. pattern.txt /*\/\\_.* -/\_A pattern.txt /*\/\\_A* -/\_D pattern.txt /*\/\\_D* -/\_F pattern.txt /*\/\\_F* -/\_H pattern.txt /*\/\\_H* -/\_I pattern.txt /*\/\\_I* -/\_K pattern.txt /*\/\\_K* -/\_L pattern.txt /*\/\\_L* -/\_O pattern.txt /*\/\\_O* -/\_P pattern.txt /*\/\\_P* -/\_S pattern.txt /*\/\\_S* -/\_U pattern.txt /*\/\\_U* -/\_W pattern.txt /*\/\\_W* -/\_X pattern.txt /*\/\\_X* -/\_[] pattern.txt /*\/\\_[]* -/\_^ pattern.txt /*\/\\_^* -/\_a pattern.txt /*\/\\_a* -/\_d pattern.txt /*\/\\_d* -/\_f pattern.txt /*\/\\_f* -/\_h pattern.txt /*\/\\_h* -/\_i pattern.txt /*\/\\_i* -/\_k pattern.txt /*\/\\_k* -/\_l pattern.txt /*\/\\_l* -/\_o pattern.txt /*\/\\_o* -/\_p pattern.txt /*\/\\_p* -/\_s pattern.txt /*\/\\_s* -/\_u pattern.txt /*\/\\_u* -/\_w pattern.txt /*\/\\_w* -/\_x pattern.txt /*\/\\_x* -/\a pattern.txt /*\/\\a* -/\b pattern.txt /*\/\\b* -/\bar pattern.txt /*\/\\bar* -/\c pattern.txt /*\/\\c* -/\d pattern.txt /*\/\\d* -/\e pattern.txt /*\/\\e* -/\f pattern.txt /*\/\\f* -/\h pattern.txt /*\/\\h* -/\i pattern.txt /*\/\\i* -/\k pattern.txt /*\/\\k* -/\l pattern.txt /*\/\\l* -/\m pattern.txt /*\/\\m* -/\n pattern.txt /*\/\\n* -/\o pattern.txt /*\/\\o* -/\p pattern.txt /*\/\\p* -/\r pattern.txt /*\/\\r* -/\s pattern.txt /*\/\\s* -/\star pattern.txt /*\/\\star* -/\t pattern.txt /*\/\\t* -/\u pattern.txt /*\/\\u* -/\v pattern.txt /*\/\\v* -/\w pattern.txt /*\/\\w* -/\x pattern.txt /*\/\\x* -/\z( syntax.txt /*\/\\z(* -/\z(\) syntax.txt /*\/\\z(\\)* -/\z1 syntax.txt /*\/\\z1* -/\z2 syntax.txt /*\/\\z2* -/\z3 syntax.txt /*\/\\z3* -/\z4 syntax.txt /*\/\\z4* -/\z5 syntax.txt /*\/\\z5* -/\z6 syntax.txt /*\/\\z6* -/\z7 syntax.txt /*\/\\z7* -/\z8 syntax.txt /*\/\\z8* -/\z9 syntax.txt /*\/\\z9* -/\ze pattern.txt /*\/\\ze* -/\zs pattern.txt /*\/\\zs* -/\{ pattern.txt /*\/\\{* -/\{- pattern.txt /*\/\\{-* -/\~ pattern.txt /*\/\\~* -/^ pattern.txt /*\/^* -/atom pattern.txt /*\/atom* -/bar pattern.txt /*\/bar* -/branch pattern.txt /*\/branch* -/character-classes pattern.txt /*\/character-classes* -/collection pattern.txt /*\/collection* -/concat pattern.txt /*\/concat* -/dyn various.txt /*\/dyn* -/ignorecase pattern.txt /*\/ignorecase* -/magic pattern.txt /*\/magic* -/multi pattern.txt /*\/multi* -/ordinary-atom pattern.txt /*\/ordinary-atom* -/pattern pattern.txt /*\/pattern* -/piece pattern.txt /*\/piece* -/star pattern.txt /*\/star* -/zero-width pattern.txt /*\/zero-width* -/~ pattern.txt /*\/~* -0 motion.txt /*0* -01.1 usr_01.txt /*01.1* -01.2 usr_01.txt /*01.2* -01.3 usr_01.txt /*01.3* -01.4 usr_01.txt /*01.4* -02.1 usr_02.txt /*02.1* -02.2 usr_02.txt /*02.2* -02.3 usr_02.txt /*02.3* -02.4 usr_02.txt /*02.4* -02.5 usr_02.txt /*02.5* -02.6 usr_02.txt /*02.6* -02.7 usr_02.txt /*02.7* -02.8 usr_02.txt /*02.8* -03.1 usr_03.txt /*03.1* -03.10 usr_03.txt /*03.10* -03.2 usr_03.txt /*03.2* -03.3 usr_03.txt /*03.3* -03.4 usr_03.txt /*03.4* -03.5 usr_03.txt /*03.5* -03.6 usr_03.txt /*03.6* -03.7 usr_03.txt /*03.7* -03.8 usr_03.txt /*03.8* -03.9 usr_03.txt /*03.9* -04.1 usr_04.txt /*04.1* -04.10 usr_04.txt /*04.10* -04.2 usr_04.txt /*04.2* -04.3 usr_04.txt /*04.3* -04.4 usr_04.txt /*04.4* -04.5 usr_04.txt /*04.5* -04.6 usr_04.txt /*04.6* -04.7 usr_04.txt /*04.7* -04.8 usr_04.txt /*04.8* -04.9 usr_04.txt /*04.9* -05.1 usr_05.txt /*05.1* -05.2 usr_05.txt /*05.2* -05.3 usr_05.txt /*05.3* -05.4 usr_05.txt /*05.4* -05.5 usr_05.txt /*05.5* -05.6 usr_05.txt /*05.6* -05.7 usr_05.txt /*05.7* -06.1 usr_06.txt /*06.1* -06.2 usr_06.txt /*06.2* -06.3 usr_06.txt /*06.3* -06.4 usr_06.txt /*06.4* -06.5 usr_06.txt /*06.5* -06.6 usr_06.txt /*06.6* -07.1 usr_07.txt /*07.1* -07.2 usr_07.txt /*07.2* -07.3 usr_07.txt /*07.3* -07.4 usr_07.txt /*07.4* -07.5 usr_07.txt /*07.5* -07.6 usr_07.txt /*07.6* -07.7 usr_07.txt /*07.7* -08.1 usr_08.txt /*08.1* -08.2 usr_08.txt /*08.2* -08.3 usr_08.txt /*08.3* -08.4 usr_08.txt /*08.4* -08.5 usr_08.txt /*08.5* -08.6 usr_08.txt /*08.6* -08.7 usr_08.txt /*08.7* -08.8 usr_08.txt /*08.8* -08.9 usr_08.txt /*08.9* -09.1 usr_09.txt /*09.1* -09.2 usr_09.txt /*09.2* -09.3 usr_09.txt /*09.3* -09.4 usr_09.txt /*09.4* -10.1 usr_10.txt /*10.1* -10.2 usr_10.txt /*10.2* -10.3 usr_10.txt /*10.3* -10.4 usr_10.txt /*10.4* -10.5 usr_10.txt /*10.5* -10.6 usr_10.txt /*10.6* -10.7 usr_10.txt /*10.7* -10.8 usr_10.txt /*10.8* -10.9 usr_10.txt /*10.9* -11.1 usr_11.txt /*11.1* -11.2 usr_11.txt /*11.2* -11.3 usr_11.txt /*11.3* -11.4 usr_11.txt /*11.4* -12.1 usr_12.txt /*12.1* -12.2 usr_12.txt /*12.2* -12.3 usr_12.txt /*12.3* -12.4 usr_12.txt /*12.4* -12.5 usr_12.txt /*12.5* -12.6 usr_12.txt /*12.6* -12.7 usr_12.txt /*12.7* -12.8 usr_12.txt /*12.8* -1gD pattern.txt /*1gD* -1gd pattern.txt /*1gd* -20.1 usr_20.txt /*20.1* -20.2 usr_20.txt /*20.2* -20.3 usr_20.txt /*20.3* -20.4 usr_20.txt /*20.4* -20.5 usr_20.txt /*20.5* -21.1 usr_21.txt /*21.1* -21.2 usr_21.txt /*21.2* -21.3 usr_21.txt /*21.3* -21.4 usr_21.txt /*21.4* -21.5 usr_21.txt /*21.5* -21.6 usr_21.txt /*21.6* -22.1 usr_22.txt /*22.1* -22.2 usr_22.txt /*22.2* -22.3 usr_22.txt /*22.3* -22.4 usr_22.txt /*22.4* -23.1 usr_23.txt /*23.1* -23.2 usr_23.txt /*23.2* -23.3 usr_23.txt /*23.3* -23.4 usr_23.txt /*23.4* -23.5 usr_23.txt /*23.5* -24.1 usr_24.txt /*24.1* -24.10 usr_24.txt /*24.10* -24.2 usr_24.txt /*24.2* -24.3 usr_24.txt /*24.3* -24.4 usr_24.txt /*24.4* -24.5 usr_24.txt /*24.5* -24.6 usr_24.txt /*24.6* -24.7 usr_24.txt /*24.7* -24.8 usr_24.txt /*24.8* -24.9 usr_24.txt /*24.9* -25.1 usr_25.txt /*25.1* -25.2 usr_25.txt /*25.2* -25.3 usr_25.txt /*25.3* -25.4 usr_25.txt /*25.4* -25.5 usr_25.txt /*25.5* -26.1 usr_26.txt /*26.1* -26.2 usr_26.txt /*26.2* -26.3 usr_26.txt /*26.3* -26.4 usr_26.txt /*26.4* -27.1 usr_27.txt /*27.1* -27.2 usr_27.txt /*27.2* -27.3 usr_27.txt /*27.3* -27.4 usr_27.txt /*27.4* -27.5 usr_27.txt /*27.5* -27.6 usr_27.txt /*27.6* -27.7 usr_27.txt /*27.7* -27.8 usr_27.txt /*27.8* -27.9 usr_27.txt /*27.9* -28.1 usr_28.txt /*28.1* -28.10 usr_28.txt /*28.10* -28.2 usr_28.txt /*28.2* -28.3 usr_28.txt /*28.3* -28.4 usr_28.txt /*28.4* -28.5 usr_28.txt /*28.5* -28.6 usr_28.txt /*28.6* -28.7 usr_28.txt /*28.7* -28.8 usr_28.txt /*28.8* -28.9 usr_28.txt /*28.9* -29.1 usr_29.txt /*29.1* -29.2 usr_29.txt /*29.2* -29.3 usr_29.txt /*29.3* -29.4 usr_29.txt /*29.4* -29.5 usr_29.txt /*29.5* -2html.vim syntax.txt /*2html.vim* -30.1 usr_30.txt /*30.1* -30.2 usr_30.txt /*30.2* -30.3 usr_30.txt /*30.3* -30.4 usr_30.txt /*30.4* -30.5 usr_30.txt /*30.5* -30.6 usr_30.txt /*30.6* -31.1 usr_31.txt /*31.1* -31.2 usr_31.txt /*31.2* -31.3 usr_31.txt /*31.3* -31.4 usr_31.txt /*31.4* -31.5 usr_31.txt /*31.5* -32.1 usr_32.txt /*32.1* -32.2 usr_32.txt /*32.2* -32.3 usr_32.txt /*32.3* -40.1 usr_40.txt /*40.1* -40.2 usr_40.txt /*40.2* -40.3 usr_40.txt /*40.3* -41.1 usr_41.txt /*41.1* -41.10 usr_41.txt /*41.10* -41.11 usr_41.txt /*41.11* -41.12 usr_41.txt /*41.12* -41.13 usr_41.txt /*41.13* -41.14 usr_41.txt /*41.14* -41.15 usr_41.txt /*41.15* -41.16 usr_41.txt /*41.16* -41.2 usr_41.txt /*41.2* -41.3 usr_41.txt /*41.3* -41.4 usr_41.txt /*41.4* -41.5 usr_41.txt /*41.5* -41.6 usr_41.txt /*41.6* -41.7 usr_41.txt /*41.7* -41.8 usr_41.txt /*41.8* -41.9 usr_41.txt /*41.9* -42 usr_42.txt /*42* -42.1 usr_42.txt /*42.1* -42.2 usr_42.txt /*42.2* -42.3 usr_42.txt /*42.3* -42.4 usr_42.txt /*42.4* -43.1 usr_43.txt /*43.1* -43.2 usr_43.txt /*43.2* -44.1 usr_44.txt /*44.1* -44.10 usr_44.txt /*44.10* -44.11 usr_44.txt /*44.11* -44.12 usr_44.txt /*44.12* -44.2 usr_44.txt /*44.2* -44.3 usr_44.txt /*44.3* -44.4 usr_44.txt /*44.4* -44.5 usr_44.txt /*44.5* -44.6 usr_44.txt /*44.6* -44.7 usr_44.txt /*44.7* -44.8 usr_44.txt /*44.8* -44.9 usr_44.txt /*44.9* -45.1 usr_45.txt /*45.1* -45.2 usr_45.txt /*45.2* -45.3 usr_45.txt /*45.3* -45.4 usr_45.txt /*45.4* -45.5 usr_45.txt /*45.5* -8g8 various.txt /*8g8* -90.1 usr_90.txt /*90.1* -90.2 usr_90.txt /*90.2* -90.3 usr_90.txt /*90.3* -90.4 usr_90.txt /*90.4* -90.5 usr_90.txt /*90.5* -: cmdline.txt /*:* -:! various.txt /*:!* -:!! various.txt /*:!!* -:!cmd various.txt /*:!cmd* -:!start os_win32.txt /*:!start* -:# various.txt /*:#* -:#! various.txt /*:#!* -:$ cmdline.txt /*:$* -:% cmdline.txt /*:%* -:& change.txt /*:&* -:' cmdline.txt /*:'* -:, cmdline.txt /*:,* -:. cmdline.txt /*:.* -:/ cmdline.txt /*:\/* -:0file editing.txt /*:0file* -:2match pattern.txt /*:2match* -:3match pattern.txt /*:3match* -::. cmdline.txt /*::.* -::8 cmdline.txt /*::8* -::e cmdline.txt /*::e* -::gs cmdline.txt /*::gs* -::h cmdline.txt /*::h* -::p cmdline.txt /*::p* -::r cmdline.txt /*::r* -::s cmdline.txt /*::s* -::t cmdline.txt /*::t* -::~ cmdline.txt /*::~* -:; cmdline.txt /*:;* -:< change.txt /*:<* -:<abuf> cmdline.txt /*:<abuf>* -:<afile> cmdline.txt /*:<afile>* -:<amatch> cmdline.txt /*:<amatch>* -:<cWORD> cmdline.txt /*:<cWORD>* -:<cfile> cmdline.txt /*:<cfile>* -:<cword> cmdline.txt /*:<cword>* -:<sfile> cmdline.txt /*:<sfile>* -:= various.txt /*:=* -:> change.txt /*:>* -:? cmdline.txt /*:?* -:@ repeat.txt /*:@* -:@: repeat.txt /*:@:* -:@@ repeat.txt /*:@@* -:AdaLines ft_ada.txt /*:AdaLines* -:AdaRainbow ft_ada.txt /*:AdaRainbow* -:AdaSpaces ft_ada.txt /*:AdaSpaces* -:AdaTagDir ft_ada.txt /*:AdaTagDir* -:AdaTagFile ft_ada.txt /*:AdaTagFile* -:AdaTypes ft_ada.txt /*:AdaTypes* -:CompilerSet usr_41.txt /*:CompilerSet* -:DiffOrig diff.txt /*:DiffOrig* -:DoMatchParen pi_paren.txt /*:DoMatchParen* -:Explore pi_netrw.txt /*:Explore* -:GLVS pi_getscript.txt /*:GLVS* -:GetLatestVimScripts_dat pi_getscript.txt /*:GetLatestVimScripts_dat* -:GnatFind ft_ada.txt /*:GnatFind* -:GnatPretty ft_ada.txt /*:GnatPretty* -:GnatTags ft_ada.txt /*:GnatTags* -:Hexplore pi_netrw.txt /*:Hexplore* -:Man filetype.txt /*:Man* -:MkVimball pi_vimball.txt /*:MkVimball* -:N editing.txt /*:N* -:NetrwClean pi_netrw.txt /*:NetrwClean* -:Nexplore pi_netrw.txt /*:Nexplore* -:Next editing.txt /*:Next* -:NoMatchParen pi_paren.txt /*:NoMatchParen* -:P various.txt /*:P* -:Pexplore pi_netrw.txt /*:Pexplore* -:Print various.txt /*:Print* -:Rexplore pi_netrw.txt /*:Rexplore* -:RmVimball pi_vimball.txt /*:RmVimball* -:Sexplore pi_netrw.txt /*:Sexplore* -:TOhtml syntax.txt /*:TOhtml* -:Texplore pi_netrw.txt /*:Texplore* -:UseVimball pi_vimball.txt /*:UseVimball* -:Vexplore pi_netrw.txt /*:Vexplore* -:VimballList pi_vimball.txt /*:VimballList* -:X editing.txt /*:X* -:XMLent insert.txt /*:XMLent* -:XMLns insert.txt /*:XMLns* -:\bar cmdline.txt /*:\\bar* -:_! cmdline.txt /*:_!* -:_# cmdline.txt /*:_#* -:_## cmdline.txt /*:_##* -:_% cmdline.txt /*:_%* -:_%: cmdline.txt /*:_%:* -:_%< cmdline.txt /*:_%<* -:a insert.txt /*:a* -:ab map.txt /*:ab* -:abbreviate map.txt /*:abbreviate* -:abbreviate-<buffer> map.txt /*:abbreviate-<buffer>* -:abbreviate-local map.txt /*:abbreviate-local* -:abbreviate-verbose map.txt /*:abbreviate-verbose* -:abc map.txt /*:abc* -:abclear map.txt /*:abclear* -:abo windows.txt /*:abo* -:aboveleft windows.txt /*:aboveleft* -:al windows.txt /*:al* -:all windows.txt /*:all* -:am gui.txt /*:am* -:amenu gui.txt /*:amenu* -:an gui.txt /*:an* -:anoremenu gui.txt /*:anoremenu* -:append insert.txt /*:append* -:ar editing.txt /*:ar* -:arga editing.txt /*:arga* -:argadd editing.txt /*:argadd* -:argd editing.txt /*:argd* -:argdelete editing.txt /*:argdelete* -:argdo editing.txt /*:argdo* -:arge editing.txt /*:arge* -:argedit editing.txt /*:argedit* -:argglobal editing.txt /*:argglobal* -:arglocal editing.txt /*:arglocal* -:args editing.txt /*:args* -:args_f editing.txt /*:args_f* -:args_f! editing.txt /*:args_f!* -:argu editing.txt /*:argu* -:argument editing.txt /*:argument* -:as various.txt /*:as* -:ascii various.txt /*:ascii* -:au autocmd.txt /*:au* -:aug autocmd.txt /*:aug* -:augroup autocmd.txt /*:augroup* -:augroup-delete autocmd.txt /*:augroup-delete* -:aun gui.txt /*:aun* -:aunmenu gui.txt /*:aunmenu* -:autocmd autocmd.txt /*:autocmd* -:autocmd-verbose autocmd.txt /*:autocmd-verbose* -:b windows.txt /*:b* -:bN windows.txt /*:bN* -:bNext windows.txt /*:bNext* -:ba windows.txt /*:ba* -:bad windows.txt /*:bad* -:badd windows.txt /*:badd* -:ball windows.txt /*:ball* -:bar cmdline.txt /*:bar* -:bd windows.txt /*:bd* -:bdel windows.txt /*:bdel* -:bdelete windows.txt /*:bdelete* -:be gui.txt /*:be* -:behave gui.txt /*:behave* -:bel windows.txt /*:bel* -:belowright windows.txt /*:belowright* -:bf windows.txt /*:bf* -:bfirst windows.txt /*:bfirst* -:bl windows.txt /*:bl* -:blast windows.txt /*:blast* -:bm windows.txt /*:bm* -:bmodified windows.txt /*:bmodified* -:bn windows.txt /*:bn* -:bnext windows.txt /*:bnext* -:botright windows.txt /*:botright* -:bp windows.txt /*:bp* -:bprevious windows.txt /*:bprevious* -:br windows.txt /*:br* -:brea eval.txt /*:brea* -:break eval.txt /*:break* -:breaka repeat.txt /*:breaka* -:breakadd repeat.txt /*:breakadd* -:breakd repeat.txt /*:breakd* -:breakdel repeat.txt /*:breakdel* -:breakl repeat.txt /*:breakl* -:breaklist repeat.txt /*:breaklist* -:brewind windows.txt /*:brewind* -:bro editing.txt /*:bro* -:browse editing.txt /*:browse* -:browse-set options.txt /*:browse-set* -:bu windows.txt /*:bu* -:buf windows.txt /*:buf* -:bufdo windows.txt /*:bufdo* -:buffer windows.txt /*:buffer* -:buffer-! windows.txt /*:buffer-!* -:buffers windows.txt /*:buffers* -:bun windows.txt /*:bun* -:bunload windows.txt /*:bunload* -:bw windows.txt /*:bw* -:bwipe windows.txt /*:bwipe* -:bwipeout windows.txt /*:bwipeout* -:c change.txt /*:c* -:cN quickfix.txt /*:cN* -:cNext quickfix.txt /*:cNext* -:cNf quickfix.txt /*:cNf* -:cNfile quickfix.txt /*:cNfile* -:ca map.txt /*:ca* -:cabbrev map.txt /*:cabbrev* -:cabc map.txt /*:cabc* -:cabclear map.txt /*:cabclear* -:cad quickfix.txt /*:cad* -:caddb quickfix.txt /*:caddb* -:caddbuffer quickfix.txt /*:caddbuffer* -:caddexpr quickfix.txt /*:caddexpr* -:caddf quickfix.txt /*:caddf* -:caddfile quickfix.txt /*:caddfile* -:cal eval.txt /*:cal* -:call eval.txt /*:call* -:cat eval.txt /*:cat* -:catch eval.txt /*:catch* -:cb quickfix.txt /*:cb* -:cbuffer quickfix.txt /*:cbuffer* -:cc quickfix.txt /*:cc* -:ccl quickfix.txt /*:ccl* -:cclose quickfix.txt /*:cclose* -:cd editing.txt /*:cd* -:cd- editing.txt /*:cd-* -:ce change.txt /*:ce* -:center change.txt /*:center* -:cex quickfix.txt /*:cex* -:cexpr quickfix.txt /*:cexpr* -:cf quickfix.txt /*:cf* -:cfile quickfix.txt /*:cfile* -:cfir quickfix.txt /*:cfir* -:cfirst quickfix.txt /*:cfirst* -:cg quickfix.txt /*:cg* -:cgetb quickfix.txt /*:cgetb* -:cgetbuffer quickfix.txt /*:cgetbuffer* -:cgete quickfix.txt /*:cgete* -:cgetexpr quickfix.txt /*:cgetexpr* -:cgetfile quickfix.txt /*:cgetfile* -:ch change.txt /*:ch* -:change change.txt /*:change* -:changes motion.txt /*:changes* -:chd editing.txt /*:chd* -:chdir editing.txt /*:chdir* -:che tagsrch.txt /*:che* -:checkpath tagsrch.txt /*:checkpath* -:checkt editing.txt /*:checkt* -:checktime editing.txt /*:checktime* -:cl quickfix.txt /*:cl* -:cla quickfix.txt /*:cla* -:clast quickfix.txt /*:clast* -:clist quickfix.txt /*:clist* -:clo windows.txt /*:clo* -:close windows.txt /*:close* -:cm map.txt /*:cm* -:cmap map.txt /*:cmap* -:cmap_l map.txt /*:cmap_l* -:cmapc map.txt /*:cmapc* -:cmapclear map.txt /*:cmapclear* -:cme gui.txt /*:cme* -:cmenu gui.txt /*:cmenu* -:cn quickfix.txt /*:cn* -:cnew quickfix.txt /*:cnew* -:cnewer quickfix.txt /*:cnewer* -:cnext quickfix.txt /*:cnext* -:cnf quickfix.txt /*:cnf* -:cnfile quickfix.txt /*:cnfile* -:cno map.txt /*:cno* -:cnorea map.txt /*:cnorea* -:cnoreabbrev map.txt /*:cnoreabbrev* -:cnoremap map.txt /*:cnoremap* -:cnoreme gui.txt /*:cnoreme* -:cnoremenu gui.txt /*:cnoremenu* -:co change.txt /*:co* -:col quickfix.txt /*:col* -:colder quickfix.txt /*:colder* -:colo syntax.txt /*:colo* -:colorscheme syntax.txt /*:colorscheme* -:com map.txt /*:com* -:comc map.txt /*:comc* -:comclear map.txt /*:comclear* -:command map.txt /*:command* -:command-bang map.txt /*:command-bang* -:command-bar map.txt /*:command-bar* -:command-buffer map.txt /*:command-buffer* -:command-complete map.txt /*:command-complete* -:command-completion map.txt /*:command-completion* -:command-completion-custom map.txt /*:command-completion-custom* -:command-completion-customlist map.txt /*:command-completion-customlist* -:command-count map.txt /*:command-count* -:command-nargs map.txt /*:command-nargs* -:command-range map.txt /*:command-range* -:command-register map.txt /*:command-register* -:command-verbose map.txt /*:command-verbose* -:comment eval.txt /*:comment* -:comp quickfix.txt /*:comp* -:compiler quickfix.txt /*:compiler* -:con eval.txt /*:con* -:conf editing.txt /*:conf* -:confirm editing.txt /*:confirm* -:continue eval.txt /*:continue* -:cope quickfix.txt /*:cope* -:copen quickfix.txt /*:copen* -:copy change.txt /*:copy* -:cp quickfix.txt /*:cp* -:cpf quickfix.txt /*:cpf* -:cpfile quickfix.txt /*:cpfile* -:cprevious quickfix.txt /*:cprevious* -:cq quickfix.txt /*:cq* -:cquit quickfix.txt /*:cquit* -:cr quickfix.txt /*:cr* -:crewind quickfix.txt /*:crewind* -:cs if_cscop.txt /*:cs* -:cscope if_cscop.txt /*:cscope* -:cstag if_cscop.txt /*:cstag* -:cu map.txt /*:cu* -:cuna map.txt /*:cuna* -:cunabbrev map.txt /*:cunabbrev* -:cunmap map.txt /*:cunmap* -:cunme gui.txt /*:cunme* -:cunmenu gui.txt /*:cunmenu* -:cw quickfix.txt /*:cw* -:cwindow quickfix.txt /*:cwindow* -:d change.txt /*:d* -:de change.txt /*:de* -:debug repeat.txt /*:debug* -:debug-name repeat.txt /*:debug-name* -:debugg repeat.txt /*:debugg* -:debuggreedy repeat.txt /*:debuggreedy* -:del change.txt /*:del* -:delc map.txt /*:delc* -:delcommand map.txt /*:delcommand* -:delcr todo.txt /*:delcr* -:delete change.txt /*:delete* -:delf eval.txt /*:delf* -:delfunction eval.txt /*:delfunction* -:delm motion.txt /*:delm* -:delmarks motion.txt /*:delmarks* -:di change.txt /*:di* -:diffg diff.txt /*:diffg* -:diffget diff.txt /*:diffget* -:diffo diff.txt /*:diffo* -:diffoff diff.txt /*:diffoff* -:diffp diff.txt /*:diffp* -:diffpatch diff.txt /*:diffpatch* -:diffpu diff.txt /*:diffpu* -:diffput diff.txt /*:diffput* -:diffs diff.txt /*:diffs* -:diffsplit diff.txt /*:diffsplit* -:difft diff.txt /*:difft* -:diffthis diff.txt /*:diffthis* -:diffu diff.txt /*:diffu* -:diffupdate diff.txt /*:diffupdate* -:dig digraph.txt /*:dig* -:digraphs digraph.txt /*:digraphs* -:display change.txt /*:display* -:dj tagsrch.txt /*:dj* -:djump tagsrch.txt /*:djump* -:dli tagsrch.txt /*:dli* -:dlist tagsrch.txt /*:dlist* -:do autocmd.txt /*:do* -:doau autocmd.txt /*:doau* -:doautoa autocmd.txt /*:doautoa* -:doautoall autocmd.txt /*:doautoall* -:doautocmd autocmd.txt /*:doautocmd* -:dr windows.txt /*:dr* -:drop windows.txt /*:drop* -:ds tagsrch.txt /*:ds* -:dsearch tagsrch.txt /*:dsearch* -:dsp tagsrch.txt /*:dsp* -:dsplit tagsrch.txt /*:dsplit* -:e editing.txt /*:e* -:ea undo.txt /*:ea* -:earlier undo.txt /*:earlier* -:ec eval.txt /*:ec* -:echo eval.txt /*:echo* -:echo-redraw eval.txt /*:echo-redraw* -:echoe eval.txt /*:echoe* -:echoerr eval.txt /*:echoerr* -:echoh eval.txt /*:echoh* -:echohl eval.txt /*:echohl* -:echom eval.txt /*:echom* -:echomsg eval.txt /*:echomsg* -:echon eval.txt /*:echon* -:edit editing.txt /*:edit* -:edit! editing.txt /*:edit!* -:edit!_f editing.txt /*:edit!_f* -:edit_f editing.txt /*:edit_f* -:el eval.txt /*:el* -:else eval.txt /*:else* -:elsei eval.txt /*:elsei* -:elseif eval.txt /*:elseif* -:em gui.txt /*:em* -:emenu gui.txt /*:emenu* -:en eval.txt /*:en* -:endf eval.txt /*:endf* -:endfo eval.txt /*:endfo* -:endfor eval.txt /*:endfor* -:endfunction eval.txt /*:endfunction* -:endif eval.txt /*:endif* -:endt eval.txt /*:endt* -:endtry eval.txt /*:endtry* -:endw eval.txt /*:endw* -:endwhile eval.txt /*:endwhile* -:ene editing.txt /*:ene* -:ene! editing.txt /*:ene!* -:enew editing.txt /*:enew* -:enew! editing.txt /*:enew!* -:ex editing.txt /*:ex* -:exe eval.txt /*:exe* -:execute eval.txt /*:execute* -:exi editing.txt /*:exi* -:exit editing.txt /*:exit* -:exu various.txt /*:exu* -:exusage various.txt /*:exusage* -:f editing.txt /*:f* -:fi editing.txt /*:fi* -:file editing.txt /*:file* -:file_f editing.txt /*:file_f* -:filename editing.txt /*:filename* -:files windows.txt /*:files* -:filet filetype.txt /*:filet* -:filetype filetype.txt /*:filetype* -:filetype-indent-off filetype.txt /*:filetype-indent-off* -:filetype-indent-on filetype.txt /*:filetype-indent-on* -:filetype-off filetype.txt /*:filetype-off* -:filetype-overview filetype.txt /*:filetype-overview* -:filetype-plugin-off filetype.txt /*:filetype-plugin-off* -:filetype-plugin-on filetype.txt /*:filetype-plugin-on* -:fin editing.txt /*:fin* -:fina eval.txt /*:fina* -:finally eval.txt /*:finally* -:find editing.txt /*:find* -:fini repeat.txt /*:fini* -:finish repeat.txt /*:finish* -:fir editing.txt /*:fir* -:first editing.txt /*:first* -:fix options.txt /*:fix* -:fixdel options.txt /*:fixdel* -:fo fold.txt /*:fo* -:fold fold.txt /*:fold* -:foldc fold.txt /*:foldc* -:foldclose fold.txt /*:foldclose* -:foldd fold.txt /*:foldd* -:folddoc fold.txt /*:folddoc* -:folddoclosed fold.txt /*:folddoclosed* -:folddoopen fold.txt /*:folddoopen* -:foldo fold.txt /*:foldo* -:foldopen fold.txt /*:foldopen* -:for eval.txt /*:for* -:fu eval.txt /*:fu* -:function eval.txt /*:function* -:function-verbose eval.txt /*:function-verbose* -:g repeat.txt /*:g* -:global repeat.txt /*:global* -:go motion.txt /*:go* -:goto motion.txt /*:goto* -:gr quickfix.txt /*:gr* -:grep quickfix.txt /*:grep* -:grepa quickfix.txt /*:grepa* -:grepadd quickfix.txt /*:grepadd* -:gu gui_x11.txt /*:gu* -:gui gui_x11.txt /*:gui* -:gv gui_x11.txt /*:gv* -:gvim gui_x11.txt /*:gvim* -:h various.txt /*:h* -:ha print.txt /*:ha* -:hardcopy print.txt /*:hardcopy* -:help various.txt /*:help* -:helpf various.txt /*:helpf* -:helpfind various.txt /*:helpfind* -:helpg various.txt /*:helpg* -:helpgrep various.txt /*:helpgrep* -:helpt various.txt /*:helpt* -:helptags various.txt /*:helptags* -:hi syntax.txt /*:hi* -:hi-default syntax.txt /*:hi-default* -:hi-link syntax.txt /*:hi-link* -:hi-normal syntax.txt /*:hi-normal* -:hi-normal-cterm syntax.txt /*:hi-normal-cterm* -:hide windows.txt /*:hide* -:highlight syntax.txt /*:highlight* -:highlight-default syntax.txt /*:highlight-default* -:highlight-link syntax.txt /*:highlight-link* -:highlight-normal syntax.txt /*:highlight-normal* -:highlight-verbose syntax.txt /*:highlight-verbose* -:his cmdline.txt /*:his* -:history cmdline.txt /*:history* -:history-indexing cmdline.txt /*:history-indexing* -:i insert.txt /*:i* -:ia map.txt /*:ia* -:iabbrev map.txt /*:iabbrev* -:iabc map.txt /*:iabc* -:iabclear map.txt /*:iabclear* -:if eval.txt /*:if* -:ij tagsrch.txt /*:ij* -:ijump tagsrch.txt /*:ijump* -:il tagsrch.txt /*:il* -:ilist tagsrch.txt /*:ilist* -:im map.txt /*:im* -:imap map.txt /*:imap* -:imap_l map.txt /*:imap_l* -:imapc map.txt /*:imapc* -:imapclear map.txt /*:imapclear* -:ime gui.txt /*:ime* -:imenu gui.txt /*:imenu* -:in insert.txt /*:in* -:index index.txt /*:index* -:ino map.txt /*:ino* -:inorea map.txt /*:inorea* -:inoreabbrev map.txt /*:inoreabbrev* -:inoremap map.txt /*:inoremap* -:inoreme gui.txt /*:inoreme* -:inoremenu gui.txt /*:inoremenu* -:insert insert.txt /*:insert* -:intro starting.txt /*:intro* -:is tagsrch.txt /*:is* -:isearch tagsrch.txt /*:isearch* -:isp tagsrch.txt /*:isp* -:isplit tagsrch.txt /*:isplit* -:iu map.txt /*:iu* -:iuna map.txt /*:iuna* -:iunabbrev map.txt /*:iunabbrev* -:iunmap map.txt /*:iunmap* -:iunme gui.txt /*:iunme* -:iunmenu gui.txt /*:iunmenu* -:j change.txt /*:j* -:join change.txt /*:join* -:ju motion.txt /*:ju* -:jumps motion.txt /*:jumps* -:k motion.txt /*:k* -:kee motion.txt /*:kee* -:keepa editing.txt /*:keepa* -:keepalt editing.txt /*:keepalt* -:keepj motion.txt /*:keepj* -:keepjumps motion.txt /*:keepjumps* -:keepmarks motion.txt /*:keepmarks* -:l various.txt /*:l* -:lN quickfix.txt /*:lN* -:lNext quickfix.txt /*:lNext* -:lNf quickfix.txt /*:lNf* -:lNfile quickfix.txt /*:lNfile* -:la editing.txt /*:la* -:lad quickfix.txt /*:lad* -:laddb quickfix.txt /*:laddb* -:laddbuffer quickfix.txt /*:laddbuffer* -:laddexpr quickfix.txt /*:laddexpr* -:laddf quickfix.txt /*:laddf* -:laddfile quickfix.txt /*:laddfile* -:lan mlang.txt /*:lan* -:lang mlang.txt /*:lang* -:language mlang.txt /*:language* -:last editing.txt /*:last* -:lat undo.txt /*:lat* -:later undo.txt /*:later* -:lb quickfix.txt /*:lb* -:lbuffer quickfix.txt /*:lbuffer* -:lc editing.txt /*:lc* -:lcd editing.txt /*:lcd* -:lch editing.txt /*:lch* -:lchdir editing.txt /*:lchdir* -:lcl quickfix.txt /*:lcl* -:lclose quickfix.txt /*:lclose* -:lcs if_cscop.txt /*:lcs* -:lcscope if_cscop.txt /*:lcscope* -:le change.txt /*:le* -:left change.txt /*:left* -:lefta windows.txt /*:lefta* -:leftabove windows.txt /*:leftabove* -:let eval.txt /*:let* -:let+= eval.txt /*:let+=* -:let-$ eval.txt /*:let-$* -:let-& eval.txt /*:let-&* -:let-= eval.txt /*:let-=* -:let-@ eval.txt /*:let-@* -:let-environment eval.txt /*:let-environment* -:let-option eval.txt /*:let-option* -:let-register eval.txt /*:let-register* -:let-unpack eval.txt /*:let-unpack* -:let.= eval.txt /*:let.=* -:lex quickfix.txt /*:lex* -:lexpr quickfix.txt /*:lexpr* -:lf quickfix.txt /*:lf* -:lfile quickfix.txt /*:lfile* -:lfir quickfix.txt /*:lfir* -:lfirst quickfix.txt /*:lfirst* -:lg quickfix.txt /*:lg* -:lgetb quickfix.txt /*:lgetb* -:lgetbuffer quickfix.txt /*:lgetbuffer* -:lgete quickfix.txt /*:lgete* -:lgetexpr quickfix.txt /*:lgetexpr* -:lgetfile quickfix.txt /*:lgetfile* -:lgr quickfix.txt /*:lgr* -:lgrep quickfix.txt /*:lgrep* -:lgrepa quickfix.txt /*:lgrepa* -:lgrepadd quickfix.txt /*:lgrepadd* -:lh various.txt /*:lh* -:lhelpgrep various.txt /*:lhelpgrep* -:list various.txt /*:list* -:ll quickfix.txt /*:ll* -:lla quickfix.txt /*:lla* -:llast quickfix.txt /*:llast* -:lli quickfix.txt /*:lli* -:llist quickfix.txt /*:llist* -:lm map.txt /*:lm* -:lmak quickfix.txt /*:lmak* -:lmake quickfix.txt /*:lmake* -:lmap map.txt /*:lmap* -:lmap_l map.txt /*:lmap_l* -:lmapc map.txt /*:lmapc* -:lmapclear map.txt /*:lmapclear* -:ln map.txt /*:ln* -:lne quickfix.txt /*:lne* -:lnew quickfix.txt /*:lnew* -:lnewer quickfix.txt /*:lnewer* -:lnext quickfix.txt /*:lnext* -:lnf quickfix.txt /*:lnf* -:lnfile quickfix.txt /*:lnfile* -:lnoremap map.txt /*:lnoremap* -:lo starting.txt /*:lo* -:loadk mbyte.txt /*:loadk* -:loadkeymap mbyte.txt /*:loadkeymap* -:loadview starting.txt /*:loadview* -:loc motion.txt /*:loc* -:lockmarks motion.txt /*:lockmarks* -:lockv eval.txt /*:lockv* -:lockvar eval.txt /*:lockvar* -:lol quickfix.txt /*:lol* -:lolder quickfix.txt /*:lolder* -:lop quickfix.txt /*:lop* -:lopen quickfix.txt /*:lopen* -:lp quickfix.txt /*:lp* -:lpf quickfix.txt /*:lpf* -:lpfile quickfix.txt /*:lpfile* -:lprevious quickfix.txt /*:lprevious* -:lr quickfix.txt /*:lr* -:lrewind quickfix.txt /*:lrewind* -:ls windows.txt /*:ls* -:lt tagsrch.txt /*:lt* -:ltag tagsrch.txt /*:ltag* -:lu map.txt /*:lu* -:lunmap map.txt /*:lunmap* -:lv quickfix.txt /*:lv* -:lvimgrep quickfix.txt /*:lvimgrep* -:lvimgrepa quickfix.txt /*:lvimgrepa* -:lvimgrepadd quickfix.txt /*:lvimgrepadd* -:lw quickfix.txt /*:lw* -:lwindow quickfix.txt /*:lwindow* -:m change.txt /*:m* -:ma motion.txt /*:ma* -:mak quickfix.txt /*:mak* -:make quickfix.txt /*:make* -:make_makeprg quickfix.txt /*:make_makeprg* -:map map.txt /*:map* -:map! map.txt /*:map!* -:map-<buffer> map.txt /*:map-<buffer>* -:map-<expr> map.txt /*:map-<expr>* -:map-<script> map.txt /*:map-<script>* -:map-<silent> map.txt /*:map-<silent>* -:map-<special> map.txt /*:map-<special>* -:map-<unique> map.txt /*:map-<unique>* -:map-alt-keys map.txt /*:map-alt-keys* -:map-arguments map.txt /*:map-arguments* -:map-commands map.txt /*:map-commands* -:map-expression map.txt /*:map-expression* -:map-local map.txt /*:map-local* -:map-modes map.txt /*:map-modes* -:map-operator map.txt /*:map-operator* -:map-script map.txt /*:map-script* -:map-silent map.txt /*:map-silent* -:map-special map.txt /*:map-special* -:map-special-chars map.txt /*:map-special-chars* -:map-special-keys map.txt /*:map-special-keys* -:map-undo map.txt /*:map-undo* -:map-verbose map.txt /*:map-verbose* -:map_l map.txt /*:map_l* -:map_l! map.txt /*:map_l!* -:mapc map.txt /*:mapc* -:mapc! map.txt /*:mapc!* -:mapclear map.txt /*:mapclear* -:mapclear! map.txt /*:mapclear!* -:mark motion.txt /*:mark* -:marks motion.txt /*:marks* -:mat pattern.txt /*:mat* -:match pattern.txt /*:match* -:me gui.txt /*:me* -:menu gui.txt /*:menu* -:menu-<script> gui.txt /*:menu-<script>* -:menu-<silent> gui.txt /*:menu-<silent>* -:menu-<special> gui.txt /*:menu-<special>* -:menu-disable gui.txt /*:menu-disable* -:menu-enable gui.txt /*:menu-enable* -:menu-script gui.txt /*:menu-script* -:menu-silent gui.txt /*:menu-silent* -:menu-special gui.txt /*:menu-special* -:menut mlang.txt /*:menut* -:menutrans mlang.txt /*:menutrans* -:menutranslate mlang.txt /*:menutranslate* -:mes message.txt /*:mes* -:messages message.txt /*:messages* -:mk starting.txt /*:mk* -:mkexrc starting.txt /*:mkexrc* -:mks starting.txt /*:mks* -:mksession starting.txt /*:mksession* -:mksp spell.txt /*:mksp* -:mkspell spell.txt /*:mkspell* -:mkv starting.txt /*:mkv* -:mkvie starting.txt /*:mkvie* -:mkview starting.txt /*:mkview* -:mkvimrc starting.txt /*:mkvimrc* -:mo change.txt /*:mo* -:mod term.txt /*:mod* -:mode term.txt /*:mode* -:move change.txt /*:move* -:mz if_mzsch.txt /*:mz* -:mzf if_mzsch.txt /*:mzf* -:mzfile if_mzsch.txt /*:mzfile* -:mzscheme if_mzsch.txt /*:mzscheme* -:n editing.txt /*:n* -:nbkey netbeans.txt /*:nbkey* -:ne editing.txt /*:ne* -:new windows.txt /*:new* -:next editing.txt /*:next* -:next_f editing.txt /*:next_f* -:nm map.txt /*:nm* -:nmap map.txt /*:nmap* -:nmap_l map.txt /*:nmap_l* -:nmapc map.txt /*:nmapc* -:nmapclear map.txt /*:nmapclear* -:nme gui.txt /*:nme* -:nmenu gui.txt /*:nmenu* -:nn map.txt /*:nn* -:nnoremap map.txt /*:nnoremap* -:nnoreme gui.txt /*:nnoreme* -:nnoremenu gui.txt /*:nnoremenu* -:no map.txt /*:no* -:no! map.txt /*:no!* -:noa autocmd.txt /*:noa* -:noautocmd autocmd.txt /*:noautocmd* -:noh pattern.txt /*:noh* -:nohlsearch pattern.txt /*:nohlsearch* -:norea map.txt /*:norea* -:noreabbrev map.txt /*:noreabbrev* -:noremap map.txt /*:noremap* -:noremap! map.txt /*:noremap!* -:noreme gui.txt /*:noreme* -:noremenu gui.txt /*:noremenu* -:norm various.txt /*:norm* -:normal various.txt /*:normal* -:normal-range various.txt /*:normal-range* -:nu various.txt /*:nu* -:number various.txt /*:number* -:nun map.txt /*:nun* -:nunmap map.txt /*:nunmap* -:nunme gui.txt /*:nunme* -:nunmenu gui.txt /*:nunmenu* -:o vi_diff.txt /*:o* -:om map.txt /*:om* -:omap map.txt /*:omap* -:omap_l map.txt /*:omap_l* -:omapc map.txt /*:omapc* -:omapclear map.txt /*:omapclear* -:ome gui.txt /*:ome* -:omenu gui.txt /*:omenu* -:on windows.txt /*:on* -:only windows.txt /*:only* -:ono map.txt /*:ono* -:onoremap map.txt /*:onoremap* -:onoreme gui.txt /*:onoreme* -:onoremenu gui.txt /*:onoremenu* -:op vi_diff.txt /*:op* -:open vi_diff.txt /*:open* -:opt options.txt /*:opt* -:options options.txt /*:options* -:ou map.txt /*:ou* -:ounmap map.txt /*:ounmap* -:ounme gui.txt /*:ounme* -:ounmenu gui.txt /*:ounmenu* -:p various.txt /*:p* -:pc windows.txt /*:pc* -:pclose windows.txt /*:pclose* -:pe if_perl.txt /*:pe* -:ped windows.txt /*:ped* -:pedit windows.txt /*:pedit* -:perl if_perl.txt /*:perl* -:perld if_perl.txt /*:perld* -:perldo if_perl.txt /*:perldo* -:po tagsrch.txt /*:po* -:pop tagsrch.txt /*:pop* -:popu gui.txt /*:popu* -:popup gui.txt /*:popup* -:pp windows.txt /*:pp* -:ppop windows.txt /*:ppop* -:pr various.txt /*:pr* -:pre recover.txt /*:pre* -:preserve recover.txt /*:preserve* -:prev editing.txt /*:prev* -:previous editing.txt /*:previous* -:print various.txt /*:print* -:pro change.txt /*:pro* -:prof repeat.txt /*:prof* -:profd repeat.txt /*:profd* -:profdel repeat.txt /*:profdel* -:profile repeat.txt /*:profile* -:promptfind change.txt /*:promptfind* -:promptr change.txt /*:promptr* -:promptrepl change.txt /*:promptrepl* -:ps windows.txt /*:ps* -:psearch windows.txt /*:psearch* -:ptN tagsrch.txt /*:ptN* -:ptNext tagsrch.txt /*:ptNext* -:pta windows.txt /*:pta* -:ptag windows.txt /*:ptag* -:ptf tagsrch.txt /*:ptf* -:ptfirst tagsrch.txt /*:ptfirst* -:ptj tagsrch.txt /*:ptj* -:ptjump tagsrch.txt /*:ptjump* -:ptl tagsrch.txt /*:ptl* -:ptlast tagsrch.txt /*:ptlast* -:ptn tagsrch.txt /*:ptn* -:ptnext tagsrch.txt /*:ptnext* -:ptp tagsrch.txt /*:ptp* -:ptprevious tagsrch.txt /*:ptprevious* -:ptr tagsrch.txt /*:ptr* -:ptrewind tagsrch.txt /*:ptrewind* -:pts tagsrch.txt /*:pts* -:ptselect tagsrch.txt /*:ptselect* -:pu change.txt /*:pu* -:put change.txt /*:put* -:pw editing.txt /*:pw* -:pwd editing.txt /*:pwd* -:py if_pyth.txt /*:py* -:pyf if_pyth.txt /*:pyf* -:pyfile if_pyth.txt /*:pyfile* -:python if_pyth.txt /*:python* -:q editing.txt /*:q* -:qa editing.txt /*:qa* -:qall editing.txt /*:qall* -:quit editing.txt /*:quit* -:quita editing.txt /*:quita* -:quitall editing.txt /*:quitall* -:quote cmdline.txt /*:quote* -:r insert.txt /*:r* -:r! insert.txt /*:r!* -:range cmdline.txt /*:range* -:range! change.txt /*:range!* -:re insert.txt /*:re* -:read insert.txt /*:read* -:read! insert.txt /*:read!* -:rec recover.txt /*:rec* -:recover recover.txt /*:recover* -:red undo.txt /*:red* -:redi various.txt /*:redi* -:redir various.txt /*:redir* -:redo undo.txt /*:redo* -:redr various.txt /*:redr* -:redraw various.txt /*:redraw* -:redraws various.txt /*:redraws* -:redrawstatus various.txt /*:redrawstatus* -:reg change.txt /*:reg* -:registers change.txt /*:registers* -:res windows.txt /*:res* -:resize windows.txt /*:resize* -:ret change.txt /*:ret* -:retab change.txt /*:retab* -:retu eval.txt /*:retu* -:return eval.txt /*:return* -:rew editing.txt /*:rew* -:rewind editing.txt /*:rewind* -:ri change.txt /*:ri* -:right change.txt /*:right* -:rightb windows.txt /*:rightb* -:rightbelow windows.txt /*:rightbelow* -:ru repeat.txt /*:ru* -:rub if_ruby.txt /*:rub* -:ruby if_ruby.txt /*:ruby* -:rubyd if_ruby.txt /*:rubyd* -:rubydo if_ruby.txt /*:rubydo* -:rubyf if_ruby.txt /*:rubyf* -:rubyfile if_ruby.txt /*:rubyfile* -:runtime repeat.txt /*:runtime* -:rv starting.txt /*:rv* -:rviminfo starting.txt /*:rviminfo* -:s change.txt /*:s* -:s% change.txt /*:s%* -:sN windows.txt /*:sN* -:sNext windows.txt /*:sNext* -:s\= change.txt /*:s\\=* -:s_c change.txt /*:s_c* -:s_flags change.txt /*:s_flags* -:sa windows.txt /*:sa* -:sal windows.txt /*:sal* -:sall windows.txt /*:sall* -:san eval.txt /*:san* -:sandbox eval.txt /*:sandbox* -:sargument windows.txt /*:sargument* -:sav editing.txt /*:sav* -:saveas editing.txt /*:saveas* -:sb windows.txt /*:sb* -:sbN windows.txt /*:sbN* -:sbNext windows.txt /*:sbNext* -:sba windows.txt /*:sba* -:sball windows.txt /*:sball* -:sbf windows.txt /*:sbf* -:sbfirst windows.txt /*:sbfirst* -:sbl windows.txt /*:sbl* -:sblast windows.txt /*:sblast* -:sbm windows.txt /*:sbm* -:sbmodified windows.txt /*:sbmodified* -:sbn windows.txt /*:sbn* -:sbnext windows.txt /*:sbnext* -:sbp windows.txt /*:sbp* -:sbprevious windows.txt /*:sbprevious* -:sbr windows.txt /*:sbr* -:sbrewind windows.txt /*:sbrewind* -:sbuffer windows.txt /*:sbuffer* -:scrip repeat.txt /*:scrip* -:scripte repeat.txt /*:scripte* -:scriptencoding repeat.txt /*:scriptencoding* -:scriptnames repeat.txt /*:scriptnames* -:scs if_cscop.txt /*:scs* -:scscope if_cscop.txt /*:scscope* -:se options.txt /*:se* -:search-args tagsrch.txt /*:search-args* -:set options.txt /*:set* -:set+= options.txt /*:set+=* -:set-& options.txt /*:set-&* -:set-&vi options.txt /*:set-&vi* -:set-&vim options.txt /*:set-&vim* -:set-= options.txt /*:set-=* -:set-args options.txt /*:set-args* -:set-browse options.txt /*:set-browse* -:set-default options.txt /*:set-default* -:set-termcap options.txt /*:set-termcap* -:set-verbose options.txt /*:set-verbose* -:set^= options.txt /*:set^=* -:set_env options.txt /*:set_env* -:setf options.txt /*:setf* -:setfiletype options.txt /*:setfiletype* -:setg options.txt /*:setg* -:setglobal options.txt /*:setglobal* -:setl options.txt /*:setl* -:setlocal options.txt /*:setlocal* -:sf windows.txt /*:sf* -:sfind windows.txt /*:sfind* -:sfir windows.txt /*:sfir* -:sfirst windows.txt /*:sfirst* -:sh various.txt /*:sh* -:shell various.txt /*:shell* -:si gui_w32.txt /*:si* -:sig sign.txt /*:sig* -:sign sign.txt /*:sign* -:sign-define sign.txt /*:sign-define* -:sign-fname sign.txt /*:sign-fname* -:sign-jump sign.txt /*:sign-jump* -:sign-list sign.txt /*:sign-list* -:sign-place sign.txt /*:sign-place* -:sign-undefine sign.txt /*:sign-undefine* -:sign-unplace sign.txt /*:sign-unplace* -:sil various.txt /*:sil* -:silent various.txt /*:silent* -:simalt gui_w32.txt /*:simalt* -:sl various.txt /*:sl* -:sla windows.txt /*:sla* -:slast windows.txt /*:slast* -:sleep various.txt /*:sleep* -:sm change.txt /*:sm* -:smagic change.txt /*:smagic* -:smap map.txt /*:smap* -:smap_l map.txt /*:smap_l* -:smapc map.txt /*:smapc* -:smapclear map.txt /*:smapclear* -:sme gui.txt /*:sme* -:smenu gui.txt /*:smenu* -:sn windows.txt /*:sn* -:snext windows.txt /*:snext* -:sni if_sniff.txt /*:sni* -:sniff if_sniff.txt /*:sniff* -:sno change.txt /*:sno* -:snomagic change.txt /*:snomagic* -:snor map.txt /*:snor* -:snoremap map.txt /*:snoremap* -:snoreme gui.txt /*:snoreme* -:snoremenu gui.txt /*:snoremenu* -:so repeat.txt /*:so* -:sor change.txt /*:sor* -:sort change.txt /*:sort* -:source repeat.txt /*:source* -:source_crnl repeat.txt /*:source_crnl* -:sp windows.txt /*:sp* -:spe spell.txt /*:spe* -:spelld spell.txt /*:spelld* -:spelldump spell.txt /*:spelldump* -:spellgood spell.txt /*:spellgood* -:spelli spell.txt /*:spelli* -:spellinfo spell.txt /*:spellinfo* -:spellr spell.txt /*:spellr* -:spellrepall spell.txt /*:spellrepall* -:spellu spell.txt /*:spellu* -:spellundo spell.txt /*:spellundo* -:spellw spell.txt /*:spellw* -:spellwrong spell.txt /*:spellwrong* -:split windows.txt /*:split* -:split_f windows.txt /*:split_f* -:spr windows.txt /*:spr* -:sprevious windows.txt /*:sprevious* -:sre windows.txt /*:sre* -:srewind windows.txt /*:srewind* -:st starting.txt /*:st* -:sta windows.txt /*:sta* -:stag windows.txt /*:stag* -:star repeat.txt /*:star* -:start insert.txt /*:start* -:startgreplace insert.txt /*:startgreplace* -:startinsert insert.txt /*:startinsert* -:startreplace insert.txt /*:startreplace* -:stj tagsrch.txt /*:stj* -:stjump tagsrch.txt /*:stjump* -:stop starting.txt /*:stop* -:stopi insert.txt /*:stopi* -:stopinsert insert.txt /*:stopinsert* -:sts tagsrch.txt /*:sts* -:stselect tagsrch.txt /*:stselect* -:su change.txt /*:su* -:substitute change.txt /*:substitute* -:sun windows.txt /*:sun* -:sunhide windows.txt /*:sunhide* -:sunm map.txt /*:sunm* -:sunmap map.txt /*:sunmap* -:sunme gui.txt /*:sunme* -:sunmenu gui.txt /*:sunmenu* -:sus starting.txt /*:sus* -:suspend starting.txt /*:suspend* -:sv windows.txt /*:sv* -:sview windows.txt /*:sview* -:sw recover.txt /*:sw* -:swapname recover.txt /*:swapname* -:sy syntax.txt /*:sy* -:syn syntax.txt /*:syn* -:syn-arguments syntax.txt /*:syn-arguments* -:syn-case syntax.txt /*:syn-case* -:syn-clear syntax.txt /*:syn-clear* -:syn-cluster syntax.txt /*:syn-cluster* -:syn-contained syntax.txt /*:syn-contained* -:syn-containedin syntax.txt /*:syn-containedin* -:syn-contains syntax.txt /*:syn-contains* -:syn-context syntax.txt /*:syn-context* -:syn-default-override usr_06.txt /*:syn-default-override* -:syn-define syntax.txt /*:syn-define* -:syn-display syntax.txt /*:syn-display* -:syn-enable syntax.txt /*:syn-enable* -:syn-end syntax.txt /*:syn-end* -:syn-excludenl syntax.txt /*:syn-excludenl* -:syn-ext-match syntax.txt /*:syn-ext-match* -:syn-extend syntax.txt /*:syn-extend* -:syn-file-remarks syntax.txt /*:syn-file-remarks* -:syn-files syntax.txt /*:syn-files* -:syn-fold syntax.txt /*:syn-fold* -:syn-include syntax.txt /*:syn-include* -:syn-keepend syntax.txt /*:syn-keepend* -:syn-keyword syntax.txt /*:syn-keyword* -:syn-lc syntax.txt /*:syn-lc* -:syn-leading syntax.txt /*:syn-leading* -:syn-list syntax.txt /*:syn-list* -:syn-manual usr_06.txt /*:syn-manual* -:syn-match syntax.txt /*:syn-match* -:syn-matchgroup syntax.txt /*:syn-matchgroup* -:syn-multi-line syntax.txt /*:syn-multi-line* -:syn-nextgroup syntax.txt /*:syn-nextgroup* -:syn-off usr_06.txt /*:syn-off* -:syn-on syntax.txt /*:syn-on* -:syn-oneline syntax.txt /*:syn-oneline* -:syn-pattern syntax.txt /*:syn-pattern* -:syn-pattern-offset syntax.txt /*:syn-pattern-offset* -:syn-priority syntax.txt /*:syn-priority* -:syn-qstart syntax.txt /*:syn-qstart* -:syn-region syntax.txt /*:syn-region* -:syn-reset syntax.txt /*:syn-reset* -:syn-skip syntax.txt /*:syn-skip* -:syn-skipempty syntax.txt /*:syn-skipempty* -:syn-skipnl syntax.txt /*:syn-skipnl* -:syn-skipwhite syntax.txt /*:syn-skipwhite* -:syn-spell syntax.txt /*:syn-spell* -:syn-start syntax.txt /*:syn-start* -:syn-sync syntax.txt /*:syn-sync* -:syn-sync-ccomment syntax.txt /*:syn-sync-ccomment* -:syn-sync-first syntax.txt /*:syn-sync-first* -:syn-sync-fourth syntax.txt /*:syn-sync-fourth* -:syn-sync-linebreaks syntax.txt /*:syn-sync-linebreaks* -:syn-sync-maxlines syntax.txt /*:syn-sync-maxlines* -:syn-sync-minlines syntax.txt /*:syn-sync-minlines* -:syn-sync-second syntax.txt /*:syn-sync-second* -:syn-sync-third syntax.txt /*:syn-sync-third* -:syn-transparent syntax.txt /*:syn-transparent* -:sync scroll.txt /*:sync* -:syncbind scroll.txt /*:syncbind* -:syntax syntax.txt /*:syntax* -:syntax-enable syntax.txt /*:syntax-enable* -:syntax-on syntax.txt /*:syntax-on* -:syntax-reset syntax.txt /*:syntax-reset* -:t change.txt /*:t* -:tN tagsrch.txt /*:tN* -:tNext tagsrch.txt /*:tNext* -:ta tagsrch.txt /*:ta* -:tab tabpage.txt /*:tab* -:tabN tabpage.txt /*:tabN* -:tabNext tabpage.txt /*:tabNext* -:tabc tabpage.txt /*:tabc* -:tabclose tabpage.txt /*:tabclose* -:tabd tabpage.txt /*:tabd* -:tabdo tabpage.txt /*:tabdo* -:tabe tabpage.txt /*:tabe* -:tabedit tabpage.txt /*:tabedit* -:tabf tabpage.txt /*:tabf* -:tabfind tabpage.txt /*:tabfind* -:tabfir tabpage.txt /*:tabfir* -:tabfirst tabpage.txt /*:tabfirst* -:tabl tabpage.txt /*:tabl* -:tablast tabpage.txt /*:tablast* -:tabm tabpage.txt /*:tabm* -:tabmove tabpage.txt /*:tabmove* -:tabn tabpage.txt /*:tabn* -:tabnew tabpage.txt /*:tabnew* -:tabnext tabpage.txt /*:tabnext* -:tabo tabpage.txt /*:tabo* -:tabonly tabpage.txt /*:tabonly* -:tabp tabpage.txt /*:tabp* -:tabprevious tabpage.txt /*:tabprevious* -:tabr tabpage.txt /*:tabr* -:tabrewind tabpage.txt /*:tabrewind* -:tabs tabpage.txt /*:tabs* -:tag tagsrch.txt /*:tag* -:tags tagsrch.txt /*:tags* -:tc if_tcl.txt /*:tc* -:tcl if_tcl.txt /*:tcl* -:tcld if_tcl.txt /*:tcld* -:tcldo if_tcl.txt /*:tcldo* -:tclf if_tcl.txt /*:tclf* -:tclfile if_tcl.txt /*:tclfile* -:te gui_w32.txt /*:te* -:tearoff gui_w32.txt /*:tearoff* -:tf tagsrch.txt /*:tf* -:tfirst tagsrch.txt /*:tfirst* -:th eval.txt /*:th* -:throw eval.txt /*:throw* -:tj tagsrch.txt /*:tj* -:tjump tagsrch.txt /*:tjump* -:tl tagsrch.txt /*:tl* -:tlast tagsrch.txt /*:tlast* -:tm gui.txt /*:tm* -:tmenu gui.txt /*:tmenu* -:tn tagsrch.txt /*:tn* -:tnext tagsrch.txt /*:tnext* -:topleft windows.txt /*:topleft* -:tp tagsrch.txt /*:tp* -:tprevious tagsrch.txt /*:tprevious* -:tr tagsrch.txt /*:tr* -:trewind tagsrch.txt /*:trewind* -:try eval.txt /*:try* -:ts tagsrch.txt /*:ts* -:tselect tagsrch.txt /*:tselect* -:tu gui.txt /*:tu* -:tunmenu gui.txt /*:tunmenu* -:u undo.txt /*:u* -:un undo.txt /*:un* -:una map.txt /*:una* -:unabbreviate map.txt /*:unabbreviate* -:undo undo.txt /*:undo* -:undoj undo.txt /*:undoj* -:undojoin undo.txt /*:undojoin* -:undol undo.txt /*:undol* -:undolist undo.txt /*:undolist* -:unh windows.txt /*:unh* -:unhide windows.txt /*:unhide* -:unl eval.txt /*:unl* -:unlet eval.txt /*:unlet* -:unlo eval.txt /*:unlo* -:unlockvar eval.txt /*:unlockvar* -:unm map.txt /*:unm* -:unm! map.txt /*:unm!* -:unmap map.txt /*:unmap* -:unmap! map.txt /*:unmap!* -:unme gui.txt /*:unme* -:unmenu gui.txt /*:unmenu* -:unmenu-all gui.txt /*:unmenu-all* -:up editing.txt /*:up* -:update editing.txt /*:update* -:v repeat.txt /*:v* -:ve various.txt /*:ve* -:verb various.txt /*:verb* -:verbose various.txt /*:verbose* -:verbose-cmd various.txt /*:verbose-cmd* -:version various.txt /*:version* -:vert windows.txt /*:vert* -:vertical windows.txt /*:vertical* -:vertical-resize windows.txt /*:vertical-resize* -:vglobal repeat.txt /*:vglobal* -:vi editing.txt /*:vi* -:vie editing.txt /*:vie* -:view editing.txt /*:view* -:vim quickfix.txt /*:vim* -:vimgrep quickfix.txt /*:vimgrep* -:vimgrepa quickfix.txt /*:vimgrepa* -:vimgrepadd quickfix.txt /*:vimgrepadd* -:visual editing.txt /*:visual* -:visual_example visual.txt /*:visual_example* -:viu various.txt /*:viu* -:viusage various.txt /*:viusage* -:vm map.txt /*:vm* -:vmap map.txt /*:vmap* -:vmap_l map.txt /*:vmap_l* -:vmapc map.txt /*:vmapc* -:vmapclear map.txt /*:vmapclear* -:vme gui.txt /*:vme* -:vmenu gui.txt /*:vmenu* -:vn map.txt /*:vn* -:vne windows.txt /*:vne* -:vnew windows.txt /*:vnew* -:vnoremap map.txt /*:vnoremap* -:vnoreme gui.txt /*:vnoreme* -:vnoremenu gui.txt /*:vnoremenu* -:vs windows.txt /*:vs* -:vsplit windows.txt /*:vsplit* -:vu map.txt /*:vu* -:vunmap map.txt /*:vunmap* -:vunme gui.txt /*:vunme* -:vunmenu gui.txt /*:vunmenu* -:w editing.txt /*:w* -:w! editing.txt /*:w!* -:wN editing.txt /*:wN* -:wNext editing.txt /*:wNext* -:w_a editing.txt /*:w_a* -:w_c editing.txt /*:w_c* -:w_f editing.txt /*:w_f* -:wa editing.txt /*:wa* -:wall editing.txt /*:wall* -:wh eval.txt /*:wh* -:while eval.txt /*:while* -:win gui.txt /*:win* -:winc windows.txt /*:winc* -:wincmd windows.txt /*:wincmd* -:windo windows.txt /*:windo* -:winp gui.txt /*:winp* -:winpos gui.txt /*:winpos* -:winsize gui.txt /*:winsize* -:wn editing.txt /*:wn* -:wnext editing.txt /*:wnext* -:wp editing.txt /*:wp* -:wprevious editing.txt /*:wprevious* -:wq editing.txt /*:wq* -:wqa editing.txt /*:wqa* -:wqall editing.txt /*:wqall* -:write editing.txt /*:write* -:write_a editing.txt /*:write_a* -:write_c editing.txt /*:write_c* -:write_f editing.txt /*:write_f* -:ws workshop.txt /*:ws* -:wsverb workshop.txt /*:wsverb* -:wv starting.txt /*:wv* -:wviminfo starting.txt /*:wviminfo* -:x editing.txt /*:x* -:xa editing.txt /*:xa* -:xall editing.txt /*:xall* -:xit editing.txt /*:xit* -:xm map.txt /*:xm* -:xmap map.txt /*:xmap* -:xmap_l map.txt /*:xmap_l* -:xmapc map.txt /*:xmapc* -:xmapclear map.txt /*:xmapclear* -:xme gui.txt /*:xme* -:xmenu gui.txt /*:xmenu* -:xn map.txt /*:xn* -:xnoremap map.txt /*:xnoremap* -:xnoreme gui.txt /*:xnoreme* -:xnoremenu gui.txt /*:xnoremenu* -:xu map.txt /*:xu* -:xunmap map.txt /*:xunmap* -:xunme gui.txt /*:xunme* -:xunmenu gui.txt /*:xunmenu* -:y change.txt /*:y* -:yank change.txt /*:yank* -:z various.txt /*:z* -:z# various.txt /*:z#* -:~ change.txt /*:~* -; motion.txt /*;* -< change.txt /*<* -<2-LeftMouse> term.txt /*<2-LeftMouse>* -<3-LeftMouse> term.txt /*<3-LeftMouse>* -<4-LeftMouse> term.txt /*<4-LeftMouse>* -<< change.txt /*<<* -<> intro.txt /*<>* -<A- intro.txt /*<A-* -<A-LeftMouse> term.txt /*<A-LeftMouse>* -<A-RightMouse> term.txt /*<A-RightMouse>* -<BS> motion.txt /*<BS>* -<Bar> intro.txt /*<Bar>* -<Bslash> intro.txt /*<Bslash>* -<C- intro.txt /*<C-* -<C-Del> os_dos.txt /*<C-Del>* -<C-End> motion.txt /*<C-End>* -<C-Home> motion.txt /*<C-Home>* -<C-Insert> os_dos.txt /*<C-Insert>* -<C-Left> motion.txt /*<C-Left>* -<C-LeftMouse> tagsrch.txt /*<C-LeftMouse>* -<C-MouseDown> scroll.txt /*<C-MouseDown>* -<C-MouseUp> scroll.txt /*<C-MouseUp>* -<C-PageDown> tabpage.txt /*<C-PageDown>* -<C-PageUp> tabpage.txt /*<C-PageUp>* -<C-Right> motion.txt /*<C-Right>* -<C-RightMouse> tagsrch.txt /*<C-RightMouse>* -<CR> motion.txt /*<CR>* -<CSI> intro.txt /*<CSI>* -<Char-> map.txt /*<Char->* -<Char> map.txt /*<Char>* -<D- intro.txt /*<D-* -<Del> change.txt /*<Del>* -<Down> motion.txt /*<Down>* -<Drop> change.txt /*<Drop>* -<EOL> intro.txt /*<EOL>* -<End> motion.txt /*<End>* -<Enter> intro.txt /*<Enter>* -<Esc> intro.txt /*<Esc>* -<F10> term.txt /*<F10>* -<F11> term.txt /*<F11>* -<F12> term.txt /*<F12>* -<F13> term.txt /*<F13>* -<F14> term.txt /*<F14>* -<F15> term.txt /*<F15>* -<F16> term.txt /*<F16>* -<F17> term.txt /*<F17>* -<F18> term.txt /*<F18>* -<F19> term.txt /*<F19>* -<F1> various.txt /*<F1>* -<F2> term.txt /*<F2>* -<F3> term.txt /*<F3>* -<F4> term.txt /*<F4>* -<F5> term.txt /*<F5>* -<F6> term.txt /*<F6>* -<F7> term.txt /*<F7>* -<F8> term.txt /*<F8>* -<F9> term.txt /*<F9>* -<Help> various.txt /*<Help>* -<Home> motion.txt /*<Home>* -<Insert> insert.txt /*<Insert>* -<Leader> map.txt /*<Leader>* -<Left> motion.txt /*<Left>* -<LeftDrag> term.txt /*<LeftDrag>* -<LeftMouse> visual.txt /*<LeftMouse>* -<LeftRelease> visual.txt /*<LeftRelease>* -<LocalLeader> map.txt /*<LocalLeader>* -<M- intro.txt /*<M-* -<MiddleDrag> term.txt /*<MiddleDrag>* -<MiddleMouse> change.txt /*<MiddleMouse>* -<MiddleRelease> term.txt /*<MiddleRelease>* -<Mouse> term.txt /*<Mouse>* -<MouseDown> scroll.txt /*<MouseDown>* -<MouseUp> scroll.txt /*<MouseUp>* -<NL> motion.txt /*<NL>* -<Nop> map.txt /*<Nop>* -<Nul> intro.txt /*<Nul>* -<PageDown> scroll.txt /*<PageDown>* -<PageUp> scroll.txt /*<PageUp>* -<Plug> map.txt /*<Plug>* -<Return> intro.txt /*<Return>* -<Right> motion.txt /*<Right>* -<RightDrag> term.txt /*<RightDrag>* -<RightMouse> visual.txt /*<RightMouse>* -<RightRelease> term.txt /*<RightRelease>* -<S- intro.txt /*<S-* -<S-Del> os_dos.txt /*<S-Del>* -<S-Down> scroll.txt /*<S-Down>* -<S-End> term.txt /*<S-End>* -<S-F10> term.txt /*<S-F10>* -<S-F11> term.txt /*<S-F11>* -<S-F12> term.txt /*<S-F12>* -<S-F1> intro.txt /*<S-F1>* -<S-F2> term.txt /*<S-F2>* -<S-F3> term.txt /*<S-F3>* -<S-F4> term.txt /*<S-F4>* -<S-F5> term.txt /*<S-F5>* -<S-F6> term.txt /*<S-F6>* -<S-F7> term.txt /*<S-F7>* -<S-F8> term.txt /*<S-F8>* -<S-F9> term.txt /*<S-F9>* -<S-Home> term.txt /*<S-Home>* -<S-Insert> os_dos.txt /*<S-Insert>* -<S-Left> motion.txt /*<S-Left>* -<S-LeftMouse> term.txt /*<S-LeftMouse>* -<S-MouseDown> scroll.txt /*<S-MouseDown>* -<S-MouseUp> scroll.txt /*<S-MouseUp>* -<S-Right> motion.txt /*<S-Right>* -<S-RightMouse> term.txt /*<S-RightMouse>* -<S-Tab> term.txt /*<S-Tab>* -<S-Up> scroll.txt /*<S-Up>* -<S-xF1> term.txt /*<S-xF1>* -<S-xF2> term.txt /*<S-xF2>* -<S-xF3> term.txt /*<S-xF3>* -<S-xF4> term.txt /*<S-xF4>* -<SID> map.txt /*<SID>* -<SNR> map.txt /*<SNR>* -<Space> motion.txt /*<Space>* -<Tab> motion.txt /*<Tab>* -<Undo> undo.txt /*<Undo>* -<Up> motion.txt /*<Up>* -<abuf> cmdline.txt /*<abuf>* -<afile> cmdline.txt /*<afile>* -<amatch> cmdline.txt /*<amatch>* -<args> map.txt /*<args>* -<bang> map.txt /*<bang>* -<buffer=N> autocmd.txt /*<buffer=N>* -<buffer=abuf> autocmd.txt /*<buffer=abuf>* -<cfile> cmdline.txt /*<cfile>* -<character> intro.txt /*<character>* -<count> map.txt /*<count>* -<f-args> map.txt /*<f-args>* -<k0> term.txt /*<k0>* -<k1> term.txt /*<k1>* -<k2> term.txt /*<k2>* -<k3> term.txt /*<k3>* -<k4> term.txt /*<k4>* -<k5> term.txt /*<k5>* -<k6> term.txt /*<k6>* -<k7> term.txt /*<k7>* -<k8> term.txt /*<k8>* -<k9> term.txt /*<k9>* -<kDivide> term.txt /*<kDivide>* -<kEnd> motion.txt /*<kEnd>* -<kEnter> term.txt /*<kEnter>* -<kHome> motion.txt /*<kHome>* -<kMinus> term.txt /*<kMinus>* -<kMultiply> term.txt /*<kMultiply>* -<kPageDown> scroll.txt /*<kPageDown>* -<kPageUp> scroll.txt /*<kPageUp>* -<kPlus> term.txt /*<kPlus>* -<kPoint> term.txt /*<kPoint>* -<line1> map.txt /*<line1>* -<line2> map.txt /*<line2>* -<lt> intro.txt /*<lt>* -<q-args> map.txt /*<q-args>* -<reg> map.txt /*<reg>* -<register> map.txt /*<register>* -<sfile> cmdline.txt /*<sfile>* -<xCSI> intro.txt /*<xCSI>* -<xDown> term.txt /*<xDown>* -<xEnd> term.txt /*<xEnd>* -<xEnd>-xterm term.txt /*<xEnd>-xterm* -<xF1> term.txt /*<xF1>* -<xF1>-xterm term.txt /*<xF1>-xterm* -<xF2> term.txt /*<xF2>* -<xF2>-xterm term.txt /*<xF2>-xterm* -<xF3> term.txt /*<xF3>* -<xF3>-xterm term.txt /*<xF3>-xterm* -<xF4> term.txt /*<xF4>* -<xF4>-xterm term.txt /*<xF4>-xterm* -<xHome> term.txt /*<xHome>* -<xHome>-xterm term.txt /*<xHome>-xterm* -<xLeft> term.txt /*<xLeft>* -<xRight> term.txt /*<xRight>* -<xUp> term.txt /*<xUp>* -= change.txt /*=* -== change.txt /*==* -> change.txt /*>* ->> change.txt /*>>* ->cont repeat.txt /*>cont* ->finish repeat.txt /*>finish* ->interrupt repeat.txt /*>interrupt* ->next repeat.txt /*>next* ->quit repeat.txt /*>quit* ->step repeat.txt /*>step* -? pattern.txt /*?* -?<CR> pattern.txt /*?<CR>* -@ repeat.txt /*@* -@/ change.txt /*@\/* -@: repeat.txt /*@:* -@= change.txt /*@=* -@@ repeat.txt /*@@* -@r eval.txt /*@r* -A insert.txt /*A* -ACL editing.txt /*ACL* -ATTENTION usr_11.txt /*ATTENTION* -Abbreviations map.txt /*Abbreviations* -Aleph options.txt /*Aleph* -Amiga os_amiga.txt /*Amiga* -Arabic arabic.txt /*Arabic* -Atari os_mint.txt /*Atari* -Athena gui_x11.txt /*Athena* -B motion.txt /*B* -BeBox os_beos.txt /*BeBox* -BeOS os_beos.txt /*BeOS* -Bram intro.txt /*Bram* -BufAdd autocmd.txt /*BufAdd* -BufCreate autocmd.txt /*BufCreate* -BufDelete autocmd.txt /*BufDelete* -BufEnter autocmd.txt /*BufEnter* -BufFilePost autocmd.txt /*BufFilePost* -BufFilePre autocmd.txt /*BufFilePre* -BufHidden autocmd.txt /*BufHidden* -BufLeave autocmd.txt /*BufLeave* -BufNew autocmd.txt /*BufNew* -BufNewFile autocmd.txt /*BufNewFile* -BufRead autocmd.txt /*BufRead* -BufReadCmd autocmd.txt /*BufReadCmd* -BufReadPost autocmd.txt /*BufReadPost* -BufReadPre autocmd.txt /*BufReadPre* -BufUnload autocmd.txt /*BufUnload* -BufWinEnter autocmd.txt /*BufWinEnter* -BufWinLeave autocmd.txt /*BufWinLeave* -BufWipeout autocmd.txt /*BufWipeout* -BufWrite autocmd.txt /*BufWrite* -BufWriteCmd autocmd.txt /*BufWriteCmd* -BufWritePost autocmd.txt /*BufWritePost* -BufWritePre autocmd.txt /*BufWritePre* -C change.txt /*C* -C-editing tips.txt /*C-editing* -C-indenting indent.txt /*C-indenting* -COMSPEC starting.txt /*COMSPEC* -CR-used-for-NL pattern.txt /*CR-used-for-NL* -CTRL-6 editing.txt /*CTRL-6* -CTRL-<PageDown> tabpage.txt /*CTRL-<PageDown>* -CTRL-<PageUp> tabpage.txt /*CTRL-<PageUp>* -CTRL-A change.txt /*CTRL-A* -CTRL-B scroll.txt /*CTRL-B* -CTRL-C pattern.txt /*CTRL-C* -CTRL-D scroll.txt /*CTRL-D* -CTRL-E scroll.txt /*CTRL-E* -CTRL-F scroll.txt /*CTRL-F* -CTRL-G editing.txt /*CTRL-G* -CTRL-H motion.txt /*CTRL-H* -CTRL-I motion.txt /*CTRL-I* -CTRL-J motion.txt /*CTRL-J* -CTRL-L various.txt /*CTRL-L* -CTRL-M motion.txt /*CTRL-M* -CTRL-N motion.txt /*CTRL-N* -CTRL-O motion.txt /*CTRL-O* -CTRL-P motion.txt /*CTRL-P* -CTRL-Q gui_w32.txt /*CTRL-Q* -CTRL-R undo.txt /*CTRL-R* -CTRL-T tagsrch.txt /*CTRL-T* -CTRL-U scroll.txt /*CTRL-U* -CTRL-U-changed version6.txt /*CTRL-U-changed* -CTRL-V visual.txt /*CTRL-V* -CTRL-V-alternative gui_w32.txt /*CTRL-V-alternative* -CTRL-W index.txt /*CTRL-W* -CTRL-W_+ windows.txt /*CTRL-W_+* -CTRL-W_- windows.txt /*CTRL-W_-* -CTRL-W_< windows.txt /*CTRL-W_<* -CTRL-W_<BS> windows.txt /*CTRL-W_<BS>* -CTRL-W_<CR> quickfix.txt /*CTRL-W_<CR>* -CTRL-W_<Down> windows.txt /*CTRL-W_<Down>* -CTRL-W_<Enter> quickfix.txt /*CTRL-W_<Enter>* -CTRL-W_<Left> windows.txt /*CTRL-W_<Left>* -CTRL-W_<Right> windows.txt /*CTRL-W_<Right>* -CTRL-W_<Up> windows.txt /*CTRL-W_<Up>* -CTRL-W_= windows.txt /*CTRL-W_=* -CTRL-W_> windows.txt /*CTRL-W_>* -CTRL-W_CTRL-B windows.txt /*CTRL-W_CTRL-B* -CTRL-W_CTRL-C windows.txt /*CTRL-W_CTRL-C* -CTRL-W_CTRL-D tagsrch.txt /*CTRL-W_CTRL-D* -CTRL-W_CTRL-F windows.txt /*CTRL-W_CTRL-F* -CTRL-W_CTRL-H windows.txt /*CTRL-W_CTRL-H* -CTRL-W_CTRL-I tagsrch.txt /*CTRL-W_CTRL-I* -CTRL-W_CTRL-J windows.txt /*CTRL-W_CTRL-J* -CTRL-W_CTRL-K windows.txt /*CTRL-W_CTRL-K* -CTRL-W_CTRL-L windows.txt /*CTRL-W_CTRL-L* -CTRL-W_CTRL-N windows.txt /*CTRL-W_CTRL-N* -CTRL-W_CTRL-O windows.txt /*CTRL-W_CTRL-O* -CTRL-W_CTRL-P windows.txt /*CTRL-W_CTRL-P* -CTRL-W_CTRL-Q windows.txt /*CTRL-W_CTRL-Q* -CTRL-W_CTRL-R windows.txt /*CTRL-W_CTRL-R* -CTRL-W_CTRL-S windows.txt /*CTRL-W_CTRL-S* -CTRL-W_CTRL-T windows.txt /*CTRL-W_CTRL-T* -CTRL-W_CTRL-V windows.txt /*CTRL-W_CTRL-V* -CTRL-W_CTRL-W windows.txt /*CTRL-W_CTRL-W* -CTRL-W_CTRL-X windows.txt /*CTRL-W_CTRL-X* -CTRL-W_CTRL-Z windows.txt /*CTRL-W_CTRL-Z* -CTRL-W_CTRL-] windows.txt /*CTRL-W_CTRL-]* -CTRL-W_CTRL-^ windows.txt /*CTRL-W_CTRL-^* -CTRL-W_CTRL-_ windows.txt /*CTRL-W_CTRL-_* -CTRL-W_F windows.txt /*CTRL-W_F* -CTRL-W_H windows.txt /*CTRL-W_H* -CTRL-W_J windows.txt /*CTRL-W_J* -CTRL-W_K windows.txt /*CTRL-W_K* -CTRL-W_L windows.txt /*CTRL-W_L* -CTRL-W_P windows.txt /*CTRL-W_P* -CTRL-W_R windows.txt /*CTRL-W_R* -CTRL-W_S windows.txt /*CTRL-W_S* -CTRL-W_T windows.txt /*CTRL-W_T* -CTRL-W_W windows.txt /*CTRL-W_W* -CTRL-W_] windows.txt /*CTRL-W_]* -CTRL-W_^ windows.txt /*CTRL-W_^* -CTRL-W__ windows.txt /*CTRL-W__* -CTRL-W_b windows.txt /*CTRL-W_b* -CTRL-W_bar windows.txt /*CTRL-W_bar* -CTRL-W_c windows.txt /*CTRL-W_c* -CTRL-W_d tagsrch.txt /*CTRL-W_d* -CTRL-W_f windows.txt /*CTRL-W_f* -CTRL-W_gF windows.txt /*CTRL-W_gF* -CTRL-W_g] windows.txt /*CTRL-W_g]* -CTRL-W_g_CTRL-] windows.txt /*CTRL-W_g_CTRL-]* -CTRL-W_gf windows.txt /*CTRL-W_gf* -CTRL-W_g} windows.txt /*CTRL-W_g}* -CTRL-W_h windows.txt /*CTRL-W_h* -CTRL-W_i tagsrch.txt /*CTRL-W_i* -CTRL-W_j windows.txt /*CTRL-W_j* -CTRL-W_k windows.txt /*CTRL-W_k* -CTRL-W_l windows.txt /*CTRL-W_l* -CTRL-W_n windows.txt /*CTRL-W_n* -CTRL-W_o windows.txt /*CTRL-W_o* -CTRL-W_p windows.txt /*CTRL-W_p* -CTRL-W_q windows.txt /*CTRL-W_q* -CTRL-W_r windows.txt /*CTRL-W_r* -CTRL-W_s windows.txt /*CTRL-W_s* -CTRL-W_t windows.txt /*CTRL-W_t* -CTRL-W_v windows.txt /*CTRL-W_v* -CTRL-W_w windows.txt /*CTRL-W_w* -CTRL-W_x windows.txt /*CTRL-W_x* -CTRL-W_z windows.txt /*CTRL-W_z* -CTRL-W_} windows.txt /*CTRL-W_}* -CTRL-X change.txt /*CTRL-X* -CTRL-Y scroll.txt /*CTRL-Y* -CTRL-Z starting.txt /*CTRL-Z* -CTRL-\_CTRL-G intro.txt /*CTRL-\\_CTRL-G* -CTRL-\_CTRL-N intro.txt /*CTRL-\\_CTRL-N* -CTRL-] tagsrch.txt /*CTRL-]* -CTRL-^ editing.txt /*CTRL-^* -CTRL-{char} intro.txt /*CTRL-{char}* -Chinese mbyte.txt /*Chinese* -Cmd-event autocmd.txt /*Cmd-event* -Cmdline cmdline.txt /*Cmdline* -Cmdline-mode cmdline.txt /*Cmdline-mode* -CmdwinEnter autocmd.txt /*CmdwinEnter* -CmdwinLeave autocmd.txt /*CmdwinLeave* -ColorScheme autocmd.txt /*ColorScheme* -Command-line cmdline.txt /*Command-line* -Command-line-mode cmdline.txt /*Command-line-mode* -Contents quickref.txt /*Contents* -Cscope if_cscop.txt /*Cscope* -CursorHold autocmd.txt /*CursorHold* -CursorHold-example windows.txt /*CursorHold-example* -CursorHoldI autocmd.txt /*CursorHoldI* -CursorIM mbyte.txt /*CursorIM* -CursorMoved autocmd.txt /*CursorMoved* -CursorMovedI autocmd.txt /*CursorMovedI* -D change.txt /*D* -DOS os_dos.txt /*DOS* -DOS-format editing.txt /*DOS-format* -DOS-format-write editing.txt /*DOS-format-write* -DPMI os_msdos.txt /*DPMI* -Dictionaries eval.txt /*Dictionaries* -Dictionary eval.txt /*Dictionary* -Dictionary-function eval.txt /*Dictionary-function* -Digraphs digraph.txt /*Digraphs* -E motion.txt /*E* -E10 message.txt /*E10* -E100 diff.txt /*E100* -E101 diff.txt /*E101* -E102 diff.txt /*E102* -E103 diff.txt /*E103* -E104 digraph.txt /*E104* -E105 mbyte.txt /*E105* -E106 eval.txt /*E106* -E107 eval.txt /*E107* -E108 eval.txt /*E108* -E109 eval.txt /*E109* -E11 cmdline.txt /*E11* -E110 eval.txt /*E110* -E111 eval.txt /*E111* -E112 eval.txt /*E112* -E113 eval.txt /*E113* -E114 eval.txt /*E114* -E115 eval.txt /*E115* -E116 eval.txt /*E116* -E117 eval.txt /*E117* -E118 eval.txt /*E118* -E119 eval.txt /*E119* -E12 message.txt /*E12* -E120 eval.txt /*E120* -E121 eval.txt /*E121* -E122 eval.txt /*E122* -E123 eval.txt /*E123* -E124 eval.txt /*E124* -E125 eval.txt /*E125* -E126 eval.txt /*E126* -E127 eval.txt /*E127* -E128 eval.txt /*E128* -E129 eval.txt /*E129* -E13 message.txt /*E13* -E130 eval.txt /*E130* -E131 eval.txt /*E131* -E132 eval.txt /*E132* -E133 eval.txt /*E133* -E134 change.txt /*E134* -E135 autocmd.txt /*E135* -E136 starting.txt /*E136* -E137 starting.txt /*E137* -E138 starting.txt /*E138* -E139 message.txt /*E139* -E14 cmdline.txt /*E14* -E140 message.txt /*E140* -E141 message.txt /*E141* -E142 message.txt /*E142* -E143 autocmd.txt /*E143* -E144 various.txt /*E144* -E145 starting.txt /*E145* -E146 change.txt /*E146* -E147 repeat.txt /*E147* -E148 repeat.txt /*E148* -E149 various.txt /*E149* -E15 eval.txt /*E15* -E150 various.txt /*E150* -E151 various.txt /*E151* -E152 various.txt /*E152* -E153 various.txt /*E153* -E154 various.txt /*E154* -E155 sign.txt /*E155* -E156 sign.txt /*E156* -E157 sign.txt /*E157* -E158 sign.txt /*E158* -E159 sign.txt /*E159* -E16 cmdline.txt /*E16* -E160 sign.txt /*E160* -E161 repeat.txt /*E161* -E162 message.txt /*E162* -E163 editing.txt /*E163* -E164 editing.txt /*E164* -E165 editing.txt /*E165* -E166 message.txt /*E166* -E167 repeat.txt /*E167* -E168 repeat.txt /*E168* -E169 message.txt /*E169* -E17 message.txt /*E17* -E170 eval.txt /*E170* -E171 eval.txt /*E171* -E172 message.txt /*E172* -E173 message.txt /*E173* -E174 map.txt /*E174* -E175 map.txt /*E175* -E176 map.txt /*E176* -E177 map.txt /*E177* -E178 map.txt /*E178* -E179 map.txt /*E179* -E18 eval.txt /*E18* -E180 map.txt /*E180* -E181 map.txt /*E181* -E182 map.txt /*E182* -E183 map.txt /*E183* -E184 map.txt /*E184* -E185 syntax.txt /*E185* -E186 editing.txt /*E186* -E187 editing.txt /*E187* -E188 gui.txt /*E188* -E189 message.txt /*E189* -E19 message.txt /*E19* -E190 message.txt /*E190* -E191 motion.txt /*E191* -E192 message.txt /*E192* -E193 eval.txt /*E193* -E194 message.txt /*E194* -E195 starting.txt /*E195* -E196 various.txt /*E196* -E197 mlang.txt /*E197* -E198 options.txt /*E198* -E199 cmdline.txt /*E199* -E20 motion.txt /*E20* -E200 autocmd.txt /*E200* -E201 autocmd.txt /*E201* -E202 options.txt /*E202* -E203 autocmd.txt /*E203* -E204 autocmd.txt /*E204* -E205 if_pyth.txt /*E205* -E206 options.txt /*E206* -E207 editing.txt /*E207* -E208 message.txt /*E208* -E209 message.txt /*E209* -E21 options.txt /*E21* -E210 message.txt /*E210* -E211 message.txt /*E211* -E212 message.txt /*E212* -E213 options.txt /*E213* -E214 options.txt /*E214* -E215 autocmd.txt /*E215* -E216 autocmd.txt /*E216* -E217 autocmd.txt /*E217* -E218 autocmd.txt /*E218* -E219 message.txt /*E219* -E22 message.txt /*E22* -E220 message.txt /*E220* -E222 message.txt /*E222* -E223 options.txt /*E223* -E224 map.txt /*E224* -E225 map.txt /*E225* -E226 map.txt /*E226* -E227 map.txt /*E227* -E228 message.txt /*E228* -E229 gui.txt /*E229* -E23 message.txt /*E23* -E230 starting.txt /*E230* -E231 options.txt /*E231* -E232 message.txt /*E232* -E233 gui.txt /*E233* -E234 options.txt /*E234* -E235 options.txt /*E235* -E236 options.txt /*E236* -E237 print.txt /*E237* -E238 print.txt /*E238* -E239 sign.txt /*E239* -E24 message.txt /*E24* -E240 remote.txt /*E240* -E241 eval.txt /*E241* -E243 if_ole.txt /*E243* -E244 options.txt /*E244* -E245 options.txt /*E245* -E246 autocmd.txt /*E246* -E247 remote.txt /*E247* -E248 remote.txt /*E248* -E25 message.txt /*E25* -E250 options.txt /*E250* -E251 remote.txt /*E251* -E252 options.txt /*E252* -E253 mbyte.txt /*E253* -E254 message.txt /*E254* -E255 sign.txt /*E255* -E256 message.txt /*E256* -E257 if_cscop.txt /*E257* -E258 remote.txt /*E258* -E259 if_cscop.txt /*E259* -E26 rileft.txt /*E26* -E260 if_cscop.txt /*E260* -E261 if_cscop.txt /*E261* -E262 if_cscop.txt /*E262* -E263 if_pyth.txt /*E263* -E264 if_pyth.txt /*E264* -E265 if_ruby.txt /*E265* -E266 if_ruby.txt /*E266* -E267 if_ruby.txt /*E267* -E268 if_ruby.txt /*E268* -E269 if_ruby.txt /*E269* -E27 farsi.txt /*E27* -E270 if_ruby.txt /*E270* -E271 if_ruby.txt /*E271* -E272 if_ruby.txt /*E272* -E273 if_ruby.txt /*E273* -E274 if_sniff.txt /*E274* -E275 if_sniff.txt /*E275* -E276 if_sniff.txt /*E276* -E277 remote.txt /*E277* -E278 if_sniff.txt /*E278* -E279 if_sniff.txt /*E279* -E28 syntax.txt /*E28* -E280 if_tcl.txt /*E280* -E281 if_tcl.txt /*E281* -E282 starting.txt /*E282* -E283 motion.txt /*E283* -E284 mbyte.txt /*E284* -E285 mbyte.txt /*E285* -E286 mbyte.txt /*E286* -E287 mbyte.txt /*E287* -E288 mbyte.txt /*E288* -E289 mbyte.txt /*E289* -E29 change.txt /*E29* -E290 mbyte.txt /*E290* -E291 mbyte.txt /*E291* -E292 mbyte.txt /*E292* -E293 message.txt /*E293* -E294 message.txt /*E294* -E295 message.txt /*E295* -E296 message.txt /*E296* -E297 message.txt /*E297* -E298 message.txt /*E298* -E299 if_perl.txt /*E299* -E30 change.txt /*E30* -E300 message.txt /*E300* -E301 message.txt /*E301* -E302 message.txt /*E302* -E303 message.txt /*E303* -E304 message.txt /*E304* -E305 recover.txt /*E305* -E306 recover.txt /*E306* -E307 recover.txt /*E307* -E308 recover.txt /*E308* -E309 recover.txt /*E309* -E31 message.txt /*E31* -E310 recover.txt /*E310* -E311 recover.txt /*E311* -E312 recover.txt /*E312* -E313 recover.txt /*E313* -E314 recover.txt /*E314* -E315 message.txt /*E315* -E316 message.txt /*E316* -E317 message.txt /*E317* -E318 message.txt /*E318* -E319 message.txt /*E319* -E32 message.txt /*E32* -E320 message.txt /*E320* -E321 editing.txt /*E321* -E322 message.txt /*E322* -E323 message.txt /*E323* -E324 print.txt /*E324* -E325 usr_11.txt /*E325* -E326 recover.txt /*E326* -E327 gui.txt /*E327* -E328 gui.txt /*E328* -E329 gui.txt /*E329* -E33 message.txt /*E33* -E330 gui.txt /*E330* -E331 gui.txt /*E331* -E332 gui.txt /*E332* -E333 gui.txt /*E333* -E334 gui.txt /*E334* -E335 gui.txt /*E335* -E336 gui.txt /*E336* -E337 gui.txt /*E337* -E338 editing.txt /*E338* -E339 message.txt /*E339* -E34 various.txt /*E34* -E340 vi_diff.txt /*E340* -E341 message.txt /*E341* -E342 message.txt /*E342* -E343 options.txt /*E343* -E344 options.txt /*E344* -E345 options.txt /*E345* -E346 options.txt /*E346* -E347 options.txt /*E347* -E348 pattern.txt /*E348* -E349 pattern.txt /*E349* -E35 message.txt /*E35* -E350 fold.txt /*E350* -E351 fold.txt /*E351* -E352 fold.txt /*E352* -E353 change.txt /*E353* -E354 change.txt /*E354* -E355 options.txt /*E355* -E356 message.txt /*E356* -E357 options.txt /*E357* -E358 options.txt /*E358* -E359 term.txt /*E359* -E36 windows.txt /*E36* -E360 various.txt /*E360* -E362 term.txt /*E362* -E363 options.txt /*E363* -E364 eval.txt /*E364* -E365 print.txt /*E365* -E366 options.txt /*E366* -E367 autocmd.txt /*E367* -E368 eval.txt /*E368* -E369 pattern.txt /*E369* -E37 message.txt /*E37* -E370 various.txt /*E370* -E371 various.txt /*E371* -E372 quickfix.txt /*E372* -E373 quickfix.txt /*E373* -E374 quickfix.txt /*E374* -E375 quickfix.txt /*E375* -E376 quickfix.txt /*E376* -E377 quickfix.txt /*E377* -E378 quickfix.txt /*E378* -E379 quickfix.txt /*E379* -E38 message.txt /*E38* -E380 quickfix.txt /*E380* -E381 quickfix.txt /*E381* -E382 options.txt /*E382* -E383 pattern.txt /*E383* -E384 options.txt /*E384* -E385 options.txt /*E385* -E386 pattern.txt /*E386* -E387 tagsrch.txt /*E387* -E388 tagsrch.txt /*E388* -E389 tagsrch.txt /*E389* -E39 digraph.txt /*E39* -E390 syntax.txt /*E390* -E391 syntax.txt /*E391* -E392 syntax.txt /*E392* -E393 syntax.txt /*E393* -E394 syntax.txt /*E394* -E395 syntax.txt /*E395* -E396 syntax.txt /*E396* -E397 syntax.txt /*E397* -E398 syntax.txt /*E398* -E399 syntax.txt /*E399* -E40 message.txt /*E40* -E400 syntax.txt /*E400* -E401 syntax.txt /*E401* -E402 syntax.txt /*E402* -E403 syntax.txt /*E403* -E404 syntax.txt /*E404* -E405 syntax.txt /*E405* -E406 syntax.txt /*E406* -E407 syntax.txt /*E407* -E408 syntax.txt /*E408* -E409 syntax.txt /*E409* -E41 message.txt /*E41* -E410 syntax.txt /*E410* -E411 syntax.txt /*E411* -E412 syntax.txt /*E412* -E413 syntax.txt /*E413* -E414 syntax.txt /*E414* -E415 syntax.txt /*E415* -E416 syntax.txt /*E416* -E417 syntax.txt /*E417* -E418 syntax.txt /*E418* -E419 syntax.txt /*E419* -E42 quickfix.txt /*E42* -E420 syntax.txt /*E420* -E421 syntax.txt /*E421* -E422 syntax.txt /*E422* -E423 syntax.txt /*E423* -E424 message.txt /*E424* -E425 tagsrch.txt /*E425* -E426 tagsrch.txt /*E426* -E427 tagsrch.txt /*E427* -E428 tagsrch.txt /*E428* -E429 tagsrch.txt /*E429* -E43 message.txt /*E43* -E430 tagsrch.txt /*E430* -E431 tagsrch.txt /*E431* -E432 message.txt /*E432* -E433 options.txt /*E433* -E434 tagsrch.txt /*E434* -E435 tagsrch.txt /*E435* -E436 term.txt /*E436* -E437 term.txt /*E437* -E438 message.txt /*E438* -E439 message.txt /*E439* -E44 message.txt /*E44* -E440 message.txt /*E440* -E441 windows.txt /*E441* -E442 windows.txt /*E442* -E443 windows.txt /*E443* -E444 windows.txt /*E444* -E445 windows.txt /*E445* -E446 editing.txt /*E446* -E447 editing.txt /*E447* -E448 various.txt /*E448* -E449 eval.txt /*E449* -E45 message.txt /*E45* -E450 os_msdos.txt /*E450* -E451 os_msdos.txt /*E451* -E452 os_msdos.txt /*E452* -E453 os_msdos.txt /*E453* -E454 os_msdos.txt /*E454* -E455 print.txt /*E455* -E456 print.txt /*E456* -E457 print.txt /*E457* -E458 message.txt /*E458* -E459 message.txt /*E459* -E46 message.txt /*E46* -E460 message.txt /*E460* -E461 eval.txt /*E461* -E462 editing.txt /*E462* -E463 netbeans.txt /*E463* -E464 message.txt /*E464* -E465 gui.txt /*E465* -E466 gui.txt /*E466* -E467 map.txt /*E467* -E468 map.txt /*E468* -E469 if_cscop.txt /*E469* -E47 message.txt /*E47* -E470 change.txt /*E470* -E471 message.txt /*E471* -E472 editing.txt /*E472* -E473 message.txt /*E473* -E474 message.txt /*E474* -E475 message.txt /*E475* -E476 pattern.txt /*E476* -E477 message.txt /*E477* -E478 message.txt /*E478* -E479 editing.txt /*E479* -E48 eval.txt /*E48* -E480 editing.txt /*E480* -E481 message.txt /*E481* -E482 message.txt /*E482* -E483 message.txt /*E483* -E484 message.txt /*E484* -E485 message.txt /*E485* -E486 pattern.txt /*E486* -E487 options.txt /*E487* -E488 message.txt /*E488* -E489 intro.txt /*E489* -E49 message.txt /*E49* -E490 fold.txt /*E490* -E492 message.txt /*E492* -E493 cmdline.txt /*E493* -E494 editing.txt /*E494* -E495 cmdline.txt /*E495* -E496 cmdline.txt /*E496* -E497 cmdline.txt /*E497* -E498 cmdline.txt /*E498* -E499 cmdline.txt /*E499* -E50 syntax.txt /*E50* -E500 cmdline.txt /*E500* -E501 intro.txt /*E501* -E502 editing.txt /*E502* -E503 editing.txt /*E503* -E504 editing.txt /*E504* -E505 editing.txt /*E505* -E506 editing.txt /*E506* -E507 editing.txt /*E507* -E508 editing.txt /*E508* -E509 editing.txt /*E509* -E51 pattern.txt /*E51* -E510 editing.txt /*E510* -E512 editing.txt /*E512* -E513 options.txt /*E513* -E514 editing.txt /*E514* -E515 windows.txt /*E515* -E516 windows.txt /*E516* -E517 windows.txt /*E517* -E518 options.txt /*E518* -E519 options.txt /*E519* -E52 syntax.txt /*E52* -E520 options.txt /*E520* -E521 options.txt /*E521* -E522 options.txt /*E522* -E523 options.txt /*E523* -E524 options.txt /*E524* -E525 options.txt /*E525* -E526 options.txt /*E526* -E527 options.txt /*E527* -E528 options.txt /*E528* -E529 options.txt /*E529* -E53 pattern.txt /*E53* -E530 options.txt /*E530* -E531 options.txt /*E531* -E533 options.txt /*E533* -E534 options.txt /*E534* -E535 options.txt /*E535* -E536 options.txt /*E536* -E537 options.txt /*E537* -E538 options.txt /*E538* -E539 options.txt /*E539* -E54 pattern.txt /*E54* -E540 options.txt /*E540* -E541 options.txt /*E541* -E542 options.txt /*E542* -E543 options.txt /*E543* -E544 options.txt /*E544* -E545 options.txt /*E545* -E546 options.txt /*E546* -E547 options.txt /*E547* -E548 options.txt /*E548* -E549 options.txt /*E549* -E55 pattern.txt /*E55* -E550 options.txt /*E550* -E551 options.txt /*E551* -E552 options.txt /*E552* -E553 quickfix.txt /*E553* -E554 pattern.txt /*E554* -E555 tagsrch.txt /*E555* -E556 tagsrch.txt /*E556* -E557 term.txt /*E557* -E558 term.txt /*E558* -E559 term.txt /*E559* -E56 pattern.txt /*E56* -E560 if_cscop.txt /*E560* -E561 if_cscop.txt /*E561* -E562 if_cscop.txt /*E562* -E563 if_cscop.txt /*E563* -E564 if_cscop.txt /*E564* -E565 if_cscop.txt /*E565* -E566 if_cscop.txt /*E566* -E567 if_cscop.txt /*E567* -E568 if_cscop.txt /*E568* -E569 if_cscop.txt /*E569* -E57 pattern.txt /*E57* -E570 message.txt /*E570* -E571 if_tcl.txt /*E571* -E572 if_tcl.txt /*E572* -E573 remote.txt /*E573* -E574 starting.txt /*E574* -E575 starting.txt /*E575* -E576 starting.txt /*E576* -E577 starting.txt /*E577* -E578 editing.txt /*E578* -E579 eval.txt /*E579* -E58 pattern.txt /*E58* -E580 eval.txt /*E580* -E581 eval.txt /*E581* -E582 eval.txt /*E582* -E583 eval.txt /*E583* -E584 eval.txt /*E584* -E585 eval.txt /*E585* -E586 eval.txt /*E586* -E587 eval.txt /*E587* -E588 eval.txt /*E588* -E589 options.txt /*E589* -E59 pattern.txt /*E59* -E590 options.txt /*E590* -E591 options.txt /*E591* -E592 options.txt /*E592* -E593 options.txt /*E593* -E594 options.txt /*E594* -E595 options.txt /*E595* -E596 options.txt /*E596* -E597 options.txt /*E597* -E598 options.txt /*E598* -E60 pattern.txt /*E60* -E600 eval.txt /*E600* -E601 eval.txt /*E601* -E602 eval.txt /*E602* -E603 eval.txt /*E603* -E604 eval.txt /*E604* -E605 eval.txt /*E605* -E606 eval.txt /*E606* -E607 eval.txt /*E607* -E608 eval.txt /*E608* -E609 if_cscop.txt /*E609* -E61 pattern.txt /*E61* -E610 options.txt /*E610* -E611 options.txt /*E611* -E612 sign.txt /*E612* -E613 print.txt /*E613* -E614 editing.txt /*E614* -E615 editing.txt /*E615* -E616 editing.txt /*E616* -E617 options.txt /*E617* -E618 print.txt /*E618* -E619 print.txt /*E619* -E62 pattern.txt /*E62* -E620 print.txt /*E620* -E621 print.txt /*E621* -E622 if_cscop.txt /*E622* -E623 if_cscop.txt /*E623* -E624 print.txt /*E624* -E625 if_cscop.txt /*E625* -E626 if_cscop.txt /*E626* -E627 netbeans.txt /*E627* -E628 netbeans.txt /*E628* -E629 netbeans.txt /*E629* -E63 pattern.txt /*E63* -E630 netbeans.txt /*E630* -E631 netbeans.txt /*E631* -E632 netbeans.txt /*E632* -E633 netbeans.txt /*E633* -E634 netbeans.txt /*E634* -E635 netbeans.txt /*E635* -E636 netbeans.txt /*E636* -E637 netbeans.txt /*E637* -E638 netbeans.txt /*E638* -E639 netbeans.txt /*E639* -E64 pattern.txt /*E64* -E640 netbeans.txt /*E640* -E641 netbeans.txt /*E641* -E642 netbeans.txt /*E642* -E643 netbeans.txt /*E643* -E644 netbeans.txt /*E644* -E645 netbeans.txt /*E645* -E646 netbeans.txt /*E646* -E647 netbeans.txt /*E647* -E648 netbeans.txt /*E648* -E649 netbeans.txt /*E649* -E65 pattern.txt /*E65* -E650 netbeans.txt /*E650* -E651 netbeans.txt /*E651* -E652 netbeans.txt /*E652* -E653 netbeans.txt /*E653* -E654 netbeans.txt /*E654* -E655 eval.txt /*E655* -E656 netbeans.txt /*E656* -E657 netbeans.txt /*E657* -E658 netbeans.txt /*E658* -E659 if_pyth.txt /*E659* -E66 syntax.txt /*E66* -E660 netbeans.txt /*E660* -E661 various.txt /*E661* -E662 motion.txt /*E662* -E663 motion.txt /*E663* -E664 motion.txt /*E664* -E665 gui_x11.txt /*E665* -E666 quickfix.txt /*E666* -E667 editing.txt /*E667* -E668 netbeans.txt /*E668* -E669 syntax.txt /*E669* -E67 syntax.txt /*E67* -E670 various.txt /*E670* -E671 starting.txt /*E671* -E672 starting.txt /*E672* -E673 print.txt /*E673* -E674 print.txt /*E674* -E675 print.txt /*E675* -E676 options.txt /*E676* -E677 eval.txt /*E677* -E678 pattern.txt /*E678* -E679 syntax.txt /*E679* -E68 pattern.txt /*E68* -E680 autocmd.txt /*E680* -E681 quickfix.txt /*E681* -E682 quickfix.txt /*E682* -E683 quickfix.txt /*E683* -E684 eval.txt /*E684* -E685 message.txt /*E685* -E686 eval.txt /*E686* -E687 eval.txt /*E687* -E688 eval.txt /*E688* -E689 eval.txt /*E689* -E69 pattern.txt /*E69* -E690 eval.txt /*E690* -E691 eval.txt /*E691* -E692 eval.txt /*E692* -E693 eval.txt /*E693* -E694 eval.txt /*E694* -E695 eval.txt /*E695* -E696 eval.txt /*E696* -E697 eval.txt /*E697* -E698 eval.txt /*E698* -E699 eval.txt /*E699* -E70 pattern.txt /*E70* -E700 eval.txt /*E700* -E701 eval.txt /*E701* -E702 eval.txt /*E702* -E703 eval.txt /*E703* -E704 eval.txt /*E704* -E705 eval.txt /*E705* -E706 eval.txt /*E706* -E707 eval.txt /*E707* -E708 eval.txt /*E708* -E709 eval.txt /*E709* -E71 pattern.txt /*E71* -E710 eval.txt /*E710* -E711 eval.txt /*E711* -E712 eval.txt /*E712* -E713 eval.txt /*E713* -E714 eval.txt /*E714* -E715 eval.txt /*E715* -E716 eval.txt /*E716* -E717 eval.txt /*E717* -E718 eval.txt /*E718* -E719 eval.txt /*E719* -E72 message.txt /*E72* -E720 eval.txt /*E720* -E721 eval.txt /*E721* -E722 eval.txt /*E722* -E723 eval.txt /*E723* -E724 eval.txt /*E724* -E725 eval.txt /*E725* -E726 eval.txt /*E726* -E727 eval.txt /*E727* -E728 eval.txt /*E728* -E729 eval.txt /*E729* -E73 tagsrch.txt /*E73* -E730 eval.txt /*E730* -E731 eval.txt /*E731* -E732 eval.txt /*E732* -E733 eval.txt /*E733* -E734 eval.txt /*E734* -E735 eval.txt /*E735* -E736 eval.txt /*E736* -E737 eval.txt /*E737* -E738 eval.txt /*E738* -E739 eval.txt /*E739* -E74 message.txt /*E74* -E740 eval.txt /*E740* -E741 eval.txt /*E741* -E742 eval.txt /*E742* -E743 eval.txt /*E743* -E744 netbeans.txt /*E744* -E745 eval.txt /*E745* -E746 eval.txt /*E746* -E747 editing.txt /*E747* -E748 repeat.txt /*E748* -E749 various.txt /*E749* -E75 vi_diff.txt /*E75* -E750 repeat.txt /*E750* -E751 spell.txt /*E751* -E752 spell.txt /*E752* -E753 spell.txt /*E753* -E754 spell.txt /*E754* -E755 spell.txt /*E755* -E756 spell.txt /*E756* -E757 options.txt /*E757* -E758 spell.txt /*E758* -E759 spell.txt /*E759* -E76 pattern.txt /*E76* -E760 spell.txt /*E760* -E761 spell.txt /*E761* -E762 spell.txt /*E762* -E763 spell.txt /*E763* -E764 options.txt /*E764* -E765 options.txt /*E765* -E766 eval.txt /*E766* -E767 eval.txt /*E767* -E768 message.txt /*E768* -E769 pattern.txt /*E769* -E77 message.txt /*E77* -E770 spell.txt /*E770* -E771 spell.txt /*E771* -E772 spell.txt /*E772* -E773 recover.txt /*E773* -E774 map.txt /*E774* -E775 map.txt /*E775* -E776 quickfix.txt /*E776* -E777 quickfix.txt /*E777* -E778 spell.txt /*E778* -E779 spell.txt /*E779* -E78 motion.txt /*E78* -E780 spell.txt /*E780* -E781 spell.txt /*E781* -E782 spell.txt /*E782* -E783 spell.txt /*E783* -E784 tabpage.txt /*E784* -E785 eval.txt /*E785* -E786 eval.txt /*E786* -E787 diff.txt /*E787* -E788 autocmd.txt /*E788* -E789 syntax.txt /*E789* -E79 message.txt /*E79* -E790 undo.txt /*E790* -E791 mbyte.txt /*E791* -E792 gui.txt /*E792* -E793 diff.txt /*E793* -E794 eval.txt /*E794* -E795 eval.txt /*E795* -E796 editing.txt /*E796* -E797 spell.txt /*E797* -E798 eval.txt /*E798* -E799 eval.txt /*E799* -E80 message.txt /*E80* -E800 arabic.txt /*E800* -E801 eval.txt /*E801* -E802 eval.txt /*E802* -E803 eval.txt /*E803* -E804 eval.txt /*E804* -E805 eval.txt /*E805* -E806 eval.txt /*E806* -E807 eval.txt /*E807* -E808 eval.txt /*E808* -E81 map.txt /*E81* -E82 message.txt /*E82* -E83 message.txt /*E83* -E84 windows.txt /*E84* -E85 options.txt /*E85* -E86 windows.txt /*E86* -E87 windows.txt /*E87* -E88 windows.txt /*E88* -E89 message.txt /*E89* -E90 message.txt /*E90* -E91 options.txt /*E91* -E92 message.txt /*E92* -E93 windows.txt /*E93* -E94 windows.txt /*E94* -E95 message.txt /*E95* -E96 diff.txt /*E96* -E97 diff.txt /*E97* -E98 diff.txt /*E98* -E99 diff.txt /*E99* -EX intro.txt /*EX* -EXINIT starting.txt /*EXINIT* -Elvis intro.txt /*Elvis* -EncodingChanged autocmd.txt /*EncodingChanged* -Eterm syntax.txt /*Eterm* -Ex intro.txt /*Ex* -Ex-mode intro.txt /*Ex-mode* -Exuberant_ctags tagsrch.txt /*Exuberant_ctags* -F motion.txt /*F* -FAQ intro.txt /*FAQ* -Farsi farsi.txt /*Farsi* -FileAppendCmd autocmd.txt /*FileAppendCmd* -FileAppendPost autocmd.txt /*FileAppendPost* -FileAppendPre autocmd.txt /*FileAppendPre* -FileChangedRO autocmd.txt /*FileChangedRO* -FileChangedShell autocmd.txt /*FileChangedShell* -FileChangedShellPost autocmd.txt /*FileChangedShellPost* -FileEncoding autocmd.txt /*FileEncoding* -FileReadCmd autocmd.txt /*FileReadCmd* -FileReadPost autocmd.txt /*FileReadPost* -FileReadPre autocmd.txt /*FileReadPre* -FileType autocmd.txt /*FileType* -FileWriteCmd autocmd.txt /*FileWriteCmd* -FileWritePost autocmd.txt /*FileWritePost* -FileWritePre autocmd.txt /*FileWritePre* -FilterReadPost autocmd.txt /*FilterReadPost* -FilterReadPre autocmd.txt /*FilterReadPre* -FilterWritePost autocmd.txt /*FilterWritePost* -FilterWritePre autocmd.txt /*FilterWritePre* -Float eval.txt /*Float* -FocusGained autocmd.txt /*FocusGained* -FocusLost autocmd.txt /*FocusLost* -Folding fold.txt /*Folding* -FuncUndefined autocmd.txt /*FuncUndefined* -Funcref eval.txt /*Funcref* -G motion.txt /*G* -GNOME gui_x11.txt /*GNOME* -GTK gui_x11.txt /*GTK* -GTK+ gui_x11.txt /*GTK+* -GUI gui.txt /*GUI* -GUI-X11 gui_x11.txt /*GUI-X11* -GUIEnter autocmd.txt /*GUIEnter* -GUIFailed autocmd.txt /*GUIFailed* -GetLatestVimScripts pi_getscript.txt /*GetLatestVimScripts* -GetLatestVimScripts-copyright pi_getscript.txt /*GetLatestVimScripts-copyright* -GetLatestVimScripts_dat pi_getscript.txt /*GetLatestVimScripts_dat* -Gnome gui_x11.txt /*Gnome* -H motion.txt /*H* -I insert.txt /*I* -ICCF uganda.txt /*ICCF* -IM-server mbyte.txt /*IM-server* -IME mbyte.txt /*IME* -Insert insert.txt /*Insert* -Insert-mode insert.txt /*Insert-mode* -InsertChange autocmd.txt /*InsertChange* -InsertEnter autocmd.txt /*InsertEnter* -InsertLeave autocmd.txt /*InsertLeave* -J change.txt /*J* -Japanese mbyte.txt /*Japanese* -K various.txt /*K* -KDE gui_x11.txt /*KDE* -KVim gui_x11.txt /*KVim* -Kibaale uganda.txt /*Kibaale* -Korean mbyte.txt /*Korean* -L motion.txt /*L* -Linux-backspace options.txt /*Linux-backspace* -List eval.txt /*List* -Lists eval.txt /*Lists* -M motion.txt /*M* -MDI starting.txt /*MDI* -MS-DOS os_msdos.txt /*MS-DOS* -MS-Windows os_win32.txt /*MS-Windows* -MSDOS os_msdos.txt /*MSDOS* -MSVisualStudio if_ole.txt /*MSVisualStudio* -MVS os_390.txt /*MVS* -Mac os_mac.txt /*Mac* -Mac-format editing.txt /*Mac-format* -Mac-format-write editing.txt /*Mac-format-write* -Macintosh os_mac.txt /*Macintosh* -Mark motion.txt /*Mark* -MenuPopup autocmd.txt /*MenuPopup* -MiNT os_mint.txt /*MiNT* -Moolenaar intro.txt /*Moolenaar* -MorphOS os_amiga.txt /*MorphOS* -Motif gui_x11.txt /*Motif* -Myspell spell.txt /*Myspell* -MzScheme if_mzsch.txt /*MzScheme* -N pattern.txt /*N* -N% motion.txt /*N%* -N: cmdline.txt /*N:* -N<Del> various.txt /*N<Del>* -NL-used-for-Nul pattern.txt /*NL-used-for-Nul* -NetBSD-backspace options.txt /*NetBSD-backspace* -Normal intro.txt /*Normal* -Normal-mode intro.txt /*Normal-mode* -Nread pi_netrw.txt /*Nread* -Nsource pi_netrw.txt /*Nsource* -Number eval.txt /*Number* -Nvi intro.txt /*Nvi* -Nwrite pi_netrw.txt /*Nwrite* -O insert.txt /*O* -OS/2 os_os2.txt /*OS\/2* -OS2 os_os2.txt /*OS2* -OS390 os_390.txt /*OS390* -OS390-Motif os_390.txt /*OS390-Motif* -OS390-bugs os_390.txt /*OS390-bugs* -OS390-building os_390.txt /*OS390-building* -OS390-changes os_390.txt /*OS390-changes* -OS390-feedback os_390.txt /*OS390-feedback* -OS390-has-ebcdic os_390.txt /*OS390-has-ebcdic* -OS390-open-source os_390.txt /*OS390-open-source* -OS390-weaknesses os_390.txt /*OS390-weaknesses* -OS390-xterm os_390.txt /*OS390-xterm* -OffTheSpot mbyte.txt /*OffTheSpot* -OnTheSpot mbyte.txt /*OnTheSpot* -Operator-pending intro.txt /*Operator-pending* -Operator-pending-mode intro.txt /*Operator-pending-mode* -OverTheSpot mbyte.txt /*OverTheSpot* -P change.txt /*P* -PATHEXT eval.txt /*PATHEXT* -Pattern pattern.txt /*Pattern* -Perl if_perl.txt /*Perl* -Posix intro.txt /*Posix* -Python if_pyth.txt /*Python* -Q intro.txt /*Q* -Q-command-changed version5.txt /*Q-command-changed* -QNX os_qnx.txt /*QNX* -Q_ab quickref.txt /*Q_ab* -Q_ac quickref.txt /*Q_ac* -Q_ai quickref.txt /*Q_ai* -Q_bu quickref.txt /*Q_bu* -Q_ce quickref.txt /*Q_ce* -Q_ch quickref.txt /*Q_ch* -Q_cm quickref.txt /*Q_cm* -Q_co quickref.txt /*Q_co* -Q_ct help.txt /*Q_ct* -Q_de quickref.txt /*Q_de* -Q_di quickref.txt /*Q_di* -Q_ed quickref.txt /*Q_ed* -Q_et quickref.txt /*Q_et* -Q_ex quickref.txt /*Q_ex* -Q_fl quickref.txt /*Q_fl* -Q_fo quickref.txt /*Q_fo* -Q_gu quickref.txt /*Q_gu* -Q_in quickref.txt /*Q_in* -Q_km quickref.txt /*Q_km* -Q_lr quickref.txt /*Q_lr* -Q_ma quickref.txt /*Q_ma* -Q_op quickref.txt /*Q_op* -Q_pa quickref.txt /*Q_pa* -Q_qf quickref.txt /*Q_qf* -Q_ra quickref.txt /*Q_ra* -Q_re quickref.txt /*Q_re* -Q_sc quickref.txt /*Q_sc* -Q_si quickref.txt /*Q_si* -Q_ss quickref.txt /*Q_ss* -Q_st quickref.txt /*Q_st* -Q_sy quickref.txt /*Q_sy* -Q_ta quickref.txt /*Q_ta* -Q_tm quickref.txt /*Q_tm* -Q_to quickref.txt /*Q_to* -Q_ud quickref.txt /*Q_ud* -Q_ur quickref.txt /*Q_ur* -Q_vc quickref.txt /*Q_vc* -Q_vi quickref.txt /*Q_vi* -Q_vm quickref.txt /*Q_vm* -Q_wi quickref.txt /*Q_wi* -Q_wq quickref.txt /*Q_wq* -QuickFixCmdPost autocmd.txt /*QuickFixCmdPost* -QuickFixCmdPost-example quickfix.txt /*QuickFixCmdPost-example* -QuickFixCmdPre autocmd.txt /*QuickFixCmdPre* -Quickfix quickfix.txt /*Quickfix* -R change.txt /*R* -RISC-OS os_risc.txt /*RISC-OS* -RISCOS os_risc.txt /*RISCOS* -RemoteReply autocmd.txt /*RemoteReply* -Replace insert.txt /*Replace* -Replace-mode insert.txt /*Replace-mode* -Root mbyte.txt /*Root* -Ruby if_ruby.txt /*Ruby* -Russian russian.txt /*Russian* -S change.txt /*S* -SHELL starting.txt /*SHELL* -SQLSetType ft_sql.txt /*SQLSetType* -Select visual.txt /*Select* -Select-mode visual.txt /*Select-mode* -Select-mode-mapping visual.txt /*Select-mode-mapping* -Session starting.txt /*Session* -SessionLoad-variable starting.txt /*SessionLoad-variable* -SessionLoadPost autocmd.txt /*SessionLoadPost* -ShellCmdPost autocmd.txt /*ShellCmdPost* -ShellFilterPost autocmd.txt /*ShellFilterPost* -SourceCmd autocmd.txt /*SourceCmd* -SourcePre autocmd.txt /*SourcePre* -SpellFileMissing autocmd.txt /*SpellFileMissing* -StdinReadPost autocmd.txt /*StdinReadPost* -StdinReadPre autocmd.txt /*StdinReadPre* -SwapExists autocmd.txt /*SwapExists* -Syntax autocmd.txt /*Syntax* -T motion.txt /*T* -TCL if_tcl.txt /*TCL* -TERM starting.txt /*TERM* -TSQL ft_sql.txt /*TSQL* -TTpro-telnet syntax.txt /*TTpro-telnet* -Tab intro.txt /*Tab* -TabEnter autocmd.txt /*TabEnter* -TabLeave autocmd.txt /*TabLeave* -Tcl if_tcl.txt /*Tcl* -TermChanged autocmd.txt /*TermChanged* -TermResponse autocmd.txt /*TermResponse* -Transact-SQL ft_sql.txt /*Transact-SQL* -U undo.txt /*U* -UTF-8 mbyte.txt /*UTF-8* -UTF8-xterm mbyte.txt /*UTF8-xterm* -Uganda uganda.txt /*Uganda* -Unicode mbyte.txt /*Unicode* -Unix os_unix.txt /*Unix* -Unix-format editing.txt /*Unix-format* -Unix-format-write editing.txt /*Unix-format-write* -User autocmd.txt /*User* -UserGettingBored autocmd.txt /*UserGettingBored* -V visual.txt /*V* -VIMINIT starting.txt /*VIMINIT* -VMS os_vms.txt /*VMS* -Vi intro.txt /*Vi* -View starting.txt /*View* -VimEnter autocmd.txt /*VimEnter* -VimLeave autocmd.txt /*VimLeave* -VimLeavePre autocmd.txt /*VimLeavePre* -VimResized autocmd.txt /*VimResized* -Vimball-copyright pi_vimball.txt /*Vimball-copyright* -Virtual-Replace-mode insert.txt /*Virtual-Replace-mode* -VisVim if_ole.txt /*VisVim* -Visual visual.txt /*Visual* -Visual-mode visual.txt /*Visual-mode* -W motion.txt /*W* -W10 message.txt /*W10* -W11 message.txt /*W11* -W12 message.txt /*W12* -W13 message.txt /*W13* -W14 message.txt /*W14* -W15 repeat.txt /*W15* -W16 message.txt /*W16* -W17 arabic.txt /*W17* -W18 syntax.txt /*W18* -WORD motion.txt /*WORD* -WWW intro.txt /*WWW* -Win32 os_win32.txt /*Win32* -WinEnter autocmd.txt /*WinEnter* -WinLeave autocmd.txt /*WinLeave* -X change.txt /*X* -X11 options.txt /*X11* -X11-icon gui_x11.txt /*X11-icon* -X11_mouse_shapes gui_x11.txt /*X11_mouse_shapes* -X1Drag term.txt /*X1Drag* -X1Mouse term.txt /*X1Mouse* -X1Release term.txt /*X1Release* -X2Drag term.txt /*X2Drag* -X2Mouse term.txt /*X2Mouse* -X2Release term.txt /*X2Release* -XIM mbyte.txt /*XIM* -XLFD mbyte.txt /*XLFD* -Y change.txt /*Y* -Y2K intro.txt /*Y2K* -ZQ editing.txt /*ZQ* -ZZ editing.txt /*ZZ* -[ index.txt /*[* -[# motion.txt /*[#* -[' motion.txt /*['* -[( motion.txt /*[(* -[++opt] editing.txt /*[++opt]* -[+cmd] editing.txt /*[+cmd]* -[..] pattern.txt /*[..]* -[/ motion.txt /*[\/* -[:alnum:] pattern.txt /*[:alnum:]* -[:alpha:] pattern.txt /*[:alpha:]* -[:backspace:] pattern.txt /*[:backspace:]* -[:blank:] pattern.txt /*[:blank:]* -[:cntrl:] pattern.txt /*[:cntrl:]* -[:digit:] pattern.txt /*[:digit:]* -[:escape:] pattern.txt /*[:escape:]* -[:graph:] pattern.txt /*[:graph:]* -[:lower:] pattern.txt /*[:lower:]* -[:print:] pattern.txt /*[:print:]* -[:punct:] pattern.txt /*[:punct:]* -[:return:] pattern.txt /*[:return:]* -[:space:] pattern.txt /*[:space:]* -[:tab:] pattern.txt /*[:tab:]* -[:upper:] pattern.txt /*[:upper:]* -[:xdigit:] pattern.txt /*[:xdigit:]* -[<MiddleMouse> change.txt /*[<MiddleMouse>* -[==] pattern.txt /*[==]* -[D tagsrch.txt /*[D* -[I tagsrch.txt /*[I* -[M motion.txt /*[M* -[P change.txt /*[P* -[S spell.txt /*[S* -[[ motion.txt /*[[* -[] motion.txt /*[]* -[_CTRL-D tagsrch.txt /*[_CTRL-D* -[_CTRL-I tagsrch.txt /*[_CTRL-I* -[` motion.txt /*[`* -[c diff.txt /*[c* -[count] intro.txt /*[count]* -[d tagsrch.txt /*[d* -[f editing.txt /*[f* -[i tagsrch.txt /*[i* -[m motion.txt /*[m* -[p change.txt /*[p* -[pattern] pattern.txt /*[pattern]* -[quotex] intro.txt /*[quotex]* -[range] cmdline.txt /*[range]* -[s spell.txt /*[s* -[star motion.txt /*[star* -[z fold.txt /*[z* -[{ motion.txt /*[{* -\0 change.txt /*\\0* -] index.txt /*]* -]# motion.txt /*]#* -]' motion.txt /*]'* -]) motion.txt /*])* -]/ motion.txt /*]\/* -]<MiddleMouse> change.txt /*]<MiddleMouse>* -]D tagsrch.txt /*]D* -]I tagsrch.txt /*]I* -]M motion.txt /*]M* -]P change.txt /*]P* -]S spell.txt /*]S* -][ motion.txt /*][* -]] motion.txt /*]]* -]_CTRL-D tagsrch.txt /*]_CTRL-D* -]_CTRL-I tagsrch.txt /*]_CTRL-I* -]` motion.txt /*]`* -]c diff.txt /*]c* -]d tagsrch.txt /*]d* -]f editing.txt /*]f* -]i tagsrch.txt /*]i* -]m motion.txt /*]m* -]p change.txt /*]p* -]s spell.txt /*]s* -]star motion.txt /*]star* -]z fold.txt /*]z* -]} motion.txt /*]}* -^ motion.txt /*^* -_ motion.txt /*_* -_exrc starting.txt /*_exrc* -_gvimrc gui.txt /*_gvimrc* -_vimrc starting.txt /*_vimrc* -` motion.txt /*`* -`( motion.txt /*`(* -`) motion.txt /*`)* -`-expansion editing.txt /*`-expansion* -`. motion.txt /*`.* -`0 motion.txt /*`0* -`< motion.txt /*`<* -`= editing.txt /*`=* -`> motion.txt /*`>* -`A motion.txt /*`A* -`[ motion.txt /*`[* -`] motion.txt /*`]* -`^ motion.txt /*`^* -`` motion.txt /*``* -`a motion.txt /*`a* -`quote motion.txt /*`quote* -`{ motion.txt /*`{* -`} motion.txt /*`}* -a insert.txt /*a* -a' motion.txt /*a'* -a( motion.txt /*a(* -a) motion.txt /*a)* -a4 print.txt /*a4* -a:0 eval.txt /*a:0* -a:000 eval.txt /*a:000* -a:1 eval.txt /*a:1* -a:firstline eval.txt /*a:firstline* -a:lastline eval.txt /*a:lastline* -a:var eval.txt /*a:var* -a< motion.txt /*a<* -a> motion.txt /*a>* -aB motion.txt /*aB* -aW motion.txt /*aW* -a[ motion.txt /*a[* -a] motion.txt /*a]* -a` motion.txt /*a`* -ab motion.txt /*ab* -abandon editing.txt /*abandon* -abbreviations map.txt /*abbreviations* -abel.vim syntax.txt /*abel.vim* -abs() eval.txt /*abs()* -active-buffer windows.txt /*active-buffer* -ada#Create_Tags() ft_ada.txt /*ada#Create_Tags()* -ada#Jump_Tag() ft_ada.txt /*ada#Jump_Tag()* -ada#Listtags() ft_ada.txt /*ada#Listtags()* -ada#Switch_Syntax_Option() ft_ada.txt /*ada#Switch_Syntax_Option()* -ada#Word() ft_ada.txt /*ada#Word()* -ada-compiler ft_ada.txt /*ada-compiler* -ada-ctags ft_ada.txt /*ada-ctags* -ada-extra-plugins ft_ada.txt /*ada-extra-plugins* -ada-reference ft_ada.txt /*ada-reference* -ada.vim ft_ada.txt /*ada.vim* -add() eval.txt /*add()* -add-filetype-plugin usr_05.txt /*add-filetype-plugin* -add-global-plugin usr_05.txt /*add-global-plugin* -add-local-help usr_05.txt /*add-local-help* -add-option-flags options.txt /*add-option-flags* -add-plugin usr_05.txt /*add-plugin* -added-5.1 version5.txt /*added-5.1* -added-5.2 version5.txt /*added-5.2* -added-5.3 version5.txt /*added-5.3* -added-5.4 version5.txt /*added-5.4* -added-5.5 version5.txt /*added-5.5* -added-5.6 version5.txt /*added-5.6* -added-5.7 version5.txt /*added-5.7* -added-5.8 version5.txt /*added-5.8* -added-6.1 version6.txt /*added-6.1* -added-6.2 version6.txt /*added-6.2* -added-6.3 version6.txt /*added-6.3* -added-6.4 version6.txt /*added-6.4* -added-7.1 version7.txt /*added-7.1* -added-7.2 version7.txt /*added-7.2* -added-BeOS version5.txt /*added-BeOS* -added-Mac version5.txt /*added-Mac* -added-VMS version5.txt /*added-VMS* -added-cmdline-args version5.txt /*added-cmdline-args* -added-options version5.txt /*added-options* -added-regexp version5.txt /*added-regexp* -added-various version5.txt /*added-various* -added-win32-GUI version5.txt /*added-win32-GUI* -aff-dic-format spell.txt /*aff-dic-format* -after-directory options.txt /*after-directory* -aleph options.txt /*aleph* -alt intro.txt /*alt* -alt-input debugger.txt /*alt-input* -alternate-file editing.txt /*alternate-file* -amiga-window starting.txt /*amiga-window* -anonymous-function eval.txt /*anonymous-function* -ant.vim syntax.txt /*ant.vim* -ap motion.txt /*ap* -apache.vim syntax.txt /*apache.vim* -append() eval.txt /*append()* -aquote motion.txt /*aquote* -arabic.txt arabic.txt /*arabic.txt* -arabicfonts arabic.txt /*arabicfonts* -arabickeymap arabic.txt /*arabickeymap* -argc() eval.txt /*argc()* -argidx() eval.txt /*argidx()* -arglist editing.txt /*arglist* -arglist-position editing.txt /*arglist-position* -arglist-quit usr_07.txt /*arglist-quit* -argument-list editing.txt /*argument-list* -argv() eval.txt /*argv()* -as motion.txt /*as* -asm.vim syntax.txt /*asm.vim* -asm68k syntax.txt /*asm68k* -asmh8300.vim syntax.txt /*asmh8300.vim* -at motion.txt /*at* -atan() eval.txt /*atan()* -athena-intellimouse gui.txt /*athena-intellimouse* -attr-list syntax.txt /*attr-list* -author intro.txt /*author* -auto-format change.txt /*auto-format* -auto-setting options.txt /*auto-setting* -auto-shortname editing.txt /*auto-shortname* -autocmd-<> tips.txt /*autocmd-<>* -autocmd-buffer-local autocmd.txt /*autocmd-buffer-local* -autocmd-buflocal autocmd.txt /*autocmd-buflocal* -autocmd-changes autocmd.txt /*autocmd-changes* -autocmd-define autocmd.txt /*autocmd-define* -autocmd-disable autocmd.txt /*autocmd-disable* -autocmd-events autocmd.txt /*autocmd-events* -autocmd-events-abc autocmd.txt /*autocmd-events-abc* -autocmd-execute autocmd.txt /*autocmd-execute* -autocmd-groups autocmd.txt /*autocmd-groups* -autocmd-intro autocmd.txt /*autocmd-intro* -autocmd-list autocmd.txt /*autocmd-list* -autocmd-nested autocmd.txt /*autocmd-nested* -autocmd-osfiletypes filetype.txt /*autocmd-osfiletypes* -autocmd-patterns autocmd.txt /*autocmd-patterns* -autocmd-remove autocmd.txt /*autocmd-remove* -autocmd-searchpat autocmd.txt /*autocmd-searchpat* -autocmd-use autocmd.txt /*autocmd-use* -autocmd.txt autocmd.txt /*autocmd.txt* -autocmds-kept version5.txt /*autocmds-kept* -autocommand autocmd.txt /*autocommand* -autocommand-events autocmd.txt /*autocommand-events* -autocommand-pattern autocmd.txt /*autocommand-pattern* -autoload eval.txt /*autoload* -autoload-functions eval.txt /*autoload-functions* -avoid-hit-enter version5.txt /*avoid-hit-enter* -aw motion.txt /*aw* -a{ motion.txt /*a{* -a} motion.txt /*a}* -b motion.txt /*b* -b:changedtick-variable eval.txt /*b:changedtick-variable* -b:changelog_name filetype.txt /*b:changelog_name* -b:current_syntax-variable syntax.txt /*b:current_syntax-variable* -b:netrw_lastfile pi_netrw.txt /*b:netrw_lastfile* -b:var eval.txt /*b:var* -baan-folding syntax.txt /*baan-folding* -baan-syntax syntax.txt /*baan-syntax* -baan.vim syntax.txt /*baan.vim* -backslash intro.txt /*backslash* -backspace intro.txt /*backspace* -backspace-delete version4.txt /*backspace-delete* -backtick-expansion editing.txt /*backtick-expansion* -backup editing.txt /*backup* -backup-changed version4.txt /*backup-changed* -backup-extension version4.txt /*backup-extension* -backup-table editing.txt /*backup-table* -balloon-eval debugger.txt /*balloon-eval* -bar motion.txt /*bar* -bars help.txt /*bars* -base_font_name_list mbyte.txt /*base_font_name_list* -basic.vim syntax.txt /*basic.vim* -beep options.txt /*beep* -beos-colors os_beos.txt /*beos-colors* -beos-compiling os_beos.txt /*beos-compiling* -beos-dragndrop os_beos.txt /*beos-dragndrop* -beos-fonts os_beos.txt /*beos-fonts* -beos-general os_beos.txt /*beos-general* -beos-gui os_beos.txt /*beos-gui* -beos-launch os_beos.txt /*beos-launch* -beos-meta os_beos.txt /*beos-meta* -beos-mouse os_beos.txt /*beos-mouse* -beos-perl os_beos.txt /*beos-perl* -beos-timeout os_beos.txt /*beos-timeout* -beos-unicode os_beos.txt /*beos-unicode* -beos-utf8 os_beos.txt /*beos-utf8* -beos-vimdir os_beos.txt /*beos-vimdir* -beval_bufnr-variable eval.txt /*beval_bufnr-variable* -beval_col-variable eval.txt /*beval_col-variable* -beval_lnum-variable eval.txt /*beval_lnum-variable* -beval_text-variable eval.txt /*beval_text-variable* -beval_winnr-variable eval.txt /*beval_winnr-variable* -blockwise-examples visual.txt /*blockwise-examples* -blockwise-operators visual.txt /*blockwise-operators* -blockwise-register change.txt /*blockwise-register* -blockwise-visual visual.txt /*blockwise-visual* -bold syntax.txt /*bold* -book intro.txt /*book* -bookmark usr_03.txt /*bookmark* -boolean options.txt /*boolean* -break-finally eval.txt /*break-finally* -browse() eval.txt /*browse()* -browsedir() eval.txt /*browsedir()* -browsefilter editing.txt /*browsefilter* -bufexists() eval.txt /*bufexists()* -buffer-hidden windows.txt /*buffer-hidden* -buffer-list windows.txt /*buffer-list* -buffer-variable eval.txt /*buffer-variable* -buffer-write editing.txt /*buffer-write* -buffer_exists() eval.txt /*buffer_exists()* -buffer_name() eval.txt /*buffer_name()* -buffer_number() eval.txt /*buffer_number()* -buffers windows.txt /*buffers* -buffers-menu gui.txt /*buffers-menu* -buflisted() eval.txt /*buflisted()* -bufloaded() eval.txt /*bufloaded()* -bufname() eval.txt /*bufname()* -bufnr() eval.txt /*bufnr()* -bufwinnr() eval.txt /*bufwinnr()* -bug-fixes-5 version5.txt /*bug-fixes-5* -bug-fixes-6 version6.txt /*bug-fixes-6* -bug-fixes-7 version7.txt /*bug-fixes-7* -bug-reports intro.txt /*bug-reports* -bugreport.vim intro.txt /*bugreport.vim* -bugs intro.txt /*bugs* -builtin-terms term.txt /*builtin-terms* -builtin-tools gui.txt /*builtin-tools* -builtin_terms term.txt /*builtin_terms* -byte-count editing.txt /*byte-count* -byte2line() eval.txt /*byte2line()* -byteidx() eval.txt /*byteidx()* -bzip2 pi_gzip.txt /*bzip2* -c change.txt /*c* -c.vim syntax.txt /*c.vim* -cW change.txt /*cW* -c_<BS> cmdline.txt /*c_<BS>* -c_<C-Left> cmdline.txt /*c_<C-Left>* -c_<C-R> cmdline.txt /*c_<C-R>* -c_<C-R>_<C-A> cmdline.txt /*c_<C-R>_<C-A>* -c_<C-R>_<C-F> cmdline.txt /*c_<C-R>_<C-F>* -c_<C-R>_<C-O> cmdline.txt /*c_<C-R>_<C-O>* -c_<C-R>_<C-P> cmdline.txt /*c_<C-R>_<C-P>* -c_<C-R>_<C-R> cmdline.txt /*c_<C-R>_<C-R>* -c_<C-R>_<C-W> cmdline.txt /*c_<C-R>_<C-W>* -c_<C-Right> cmdline.txt /*c_<C-Right>* -c_<CR> cmdline.txt /*c_<CR>* -c_<Del> cmdline.txt /*c_<Del>* -c_<Down> cmdline.txt /*c_<Down>* -c_<End> cmdline.txt /*c_<End>* -c_<Esc> cmdline.txt /*c_<Esc>* -c_<Home> cmdline.txt /*c_<Home>* -c_<Insert> cmdline.txt /*c_<Insert>* -c_<Left> cmdline.txt /*c_<Left>* -c_<LeftMouse> cmdline.txt /*c_<LeftMouse>* -c_<NL> cmdline.txt /*c_<NL>* -c_<PageDown> cmdline.txt /*c_<PageDown>* -c_<PageUp> cmdline.txt /*c_<PageUp>* -c_<Right> cmdline.txt /*c_<Right>* -c_<S-Down> cmdline.txt /*c_<S-Down>* -c_<S-Left> cmdline.txt /*c_<S-Left>* -c_<S-Right> cmdline.txt /*c_<S-Right>* -c_<S-Tab> cmdline.txt /*c_<S-Tab>* -c_<S-Up> cmdline.txt /*c_<S-Up>* -c_<Tab> cmdline.txt /*c_<Tab>* -c_<Up> cmdline.txt /*c_<Up>* -c_CTRL-A cmdline.txt /*c_CTRL-A* -c_CTRL-B cmdline.txt /*c_CTRL-B* -c_CTRL-C cmdline.txt /*c_CTRL-C* -c_CTRL-D cmdline.txt /*c_CTRL-D* -c_CTRL-E cmdline.txt /*c_CTRL-E* -c_CTRL-H cmdline.txt /*c_CTRL-H* -c_CTRL-I cmdline.txt /*c_CTRL-I* -c_CTRL-J cmdline.txt /*c_CTRL-J* -c_CTRL-K cmdline.txt /*c_CTRL-K* -c_CTRL-L cmdline.txt /*c_CTRL-L* -c_CTRL-N cmdline.txt /*c_CTRL-N* -c_CTRL-P cmdline.txt /*c_CTRL-P* -c_CTRL-Q cmdline.txt /*c_CTRL-Q* -c_CTRL-R cmdline.txt /*c_CTRL-R* -c_CTRL-R_= cmdline.txt /*c_CTRL-R_=* -c_CTRL-R_CTRL-A cmdline.txt /*c_CTRL-R_CTRL-A* -c_CTRL-R_CTRL-F cmdline.txt /*c_CTRL-R_CTRL-F* -c_CTRL-R_CTRL-O cmdline.txt /*c_CTRL-R_CTRL-O* -c_CTRL-R_CTRL-P cmdline.txt /*c_CTRL-R_CTRL-P* -c_CTRL-R_CTRL-R cmdline.txt /*c_CTRL-R_CTRL-R* -c_CTRL-R_CTRL-W cmdline.txt /*c_CTRL-R_CTRL-W* -c_CTRL-U cmdline.txt /*c_CTRL-U* -c_CTRL-V cmdline.txt /*c_CTRL-V* -c_CTRL-W cmdline.txt /*c_CTRL-W* -c_CTRL-Y cmdline.txt /*c_CTRL-Y* -c_CTRL-\_CTRL-G intro.txt /*c_CTRL-\\_CTRL-G* -c_CTRL-\_CTRL-N intro.txt /*c_CTRL-\\_CTRL-N* -c_CTRL-\_e cmdline.txt /*c_CTRL-\\_e* -c_CTRL-] cmdline.txt /*c_CTRL-]* -c_CTRL-^ cmdline.txt /*c_CTRL-^* -c_CTRL-_ cmdline.txt /*c_CTRL-_* -c_digraph cmdline.txt /*c_digraph* -c_wildchar cmdline.txt /*c_wildchar* -call() eval.txt /*call()* -carriage-return intro.txt /*carriage-return* -case change.txt /*case* -catch-all eval.txt /*catch-all* -catch-errors eval.txt /*catch-errors* -catch-interrupt eval.txt /*catch-interrupt* -catch-order eval.txt /*catch-order* -catch-text eval.txt /*catch-text* -cc change.txt /*cc* -ceil() eval.txt /*ceil()* -ch.vim syntax.txt /*ch.vim* -change-list-jumps motion.txt /*change-list-jumps* -change-tabs change.txt /*change-tabs* -change.txt change.txt /*change.txt* -changed-5.1 version5.txt /*changed-5.1* -changed-5.2 version5.txt /*changed-5.2* -changed-5.3 version5.txt /*changed-5.3* -changed-5.4 version5.txt /*changed-5.4* -changed-5.5 version5.txt /*changed-5.5* -changed-5.6 version5.txt /*changed-5.6* -changed-5.7 version5.txt /*changed-5.7* -changed-5.8 version5.txt /*changed-5.8* -changed-6.1 version6.txt /*changed-6.1* -changed-6.2 version6.txt /*changed-6.2* -changed-6.3 version6.txt /*changed-6.3* -changed-6.4 version6.txt /*changed-6.4* -changed-7.1 version7.txt /*changed-7.1* -changed-7.2 version7.txt /*changed-7.2* -changelist motion.txt /*changelist* -changelog.vim syntax.txt /*changelog.vim* -changenr() eval.txt /*changenr()* -changetick eval.txt /*changetick* -changing change.txt /*changing* -char-variable eval.txt /*char-variable* -char2nr() eval.txt /*char2nr()* -characterwise motion.txt /*characterwise* -characterwise-register change.txt /*characterwise-register* -characterwise-visual visual.txt /*characterwise-visual* -charconvert_from-variable eval.txt /*charconvert_from-variable* -charconvert_to-variable eval.txt /*charconvert_to-variable* -charity uganda.txt /*charity* -charset mbyte.txt /*charset* -charset-conversion mbyte.txt /*charset-conversion* -chill.vim syntax.txt /*chill.vim* -cindent() eval.txt /*cindent()* -cinkeys-format indent.txt /*cinkeys-format* -cinoptions-values indent.txt /*cinoptions-values* -clearmatches() eval.txt /*clearmatches()* -client-server remote.txt /*client-server* -clientserver remote.txt /*clientserver* -clipboard gui.txt /*clipboard* -cmdarg-variable eval.txt /*cmdarg-variable* -cmdbang-variable eval.txt /*cmdbang-variable* -cmdline-arguments vi_diff.txt /*cmdline-arguments* -cmdline-changed version5.txt /*cmdline-changed* -cmdline-completion cmdline.txt /*cmdline-completion* -cmdline-editing cmdline.txt /*cmdline-editing* -cmdline-history cmdline.txt /*cmdline-history* -cmdline-lines cmdline.txt /*cmdline-lines* -cmdline-ranges cmdline.txt /*cmdline-ranges* -cmdline-special cmdline.txt /*cmdline-special* -cmdline-too-long cmdline.txt /*cmdline-too-long* -cmdline-window cmdline.txt /*cmdline-window* -cmdline.txt cmdline.txt /*cmdline.txt* -cmdwin cmdline.txt /*cmdwin* -cmdwin-char cmdline.txt /*cmdwin-char* -cobol.vim syntax.txt /*cobol.vim* -codeset mbyte.txt /*codeset* -coding-style develop.txt /*coding-style* -col() eval.txt /*col()* -coldfusion.vim syntax.txt /*coldfusion.vim* -collapse tips.txt /*collapse* -color-xterm syntax.txt /*color-xterm* -coloring syntax.txt /*coloring* -colortest.vim syntax.txt /*colortest.vim* -command-mode intro.txt /*command-mode* -compatible-default starting.txt /*compatible-default* -compile-changes-5 version5.txt /*compile-changes-5* -compile-changes-6 version6.txt /*compile-changes-6* -compile-changes-7 version7.txt /*compile-changes-7* -compiler-compaqada ft_ada.txt /*compiler-compaqada* -compiler-decada ft_ada.txt /*compiler-decada* -compiler-gcc quickfix.txt /*compiler-gcc* -compiler-gnat ft_ada.txt /*compiler-gnat* -compiler-hpada ft_ada.txt /*compiler-hpada* -compiler-manx quickfix.txt /*compiler-manx* -compiler-perl quickfix.txt /*compiler-perl* -compiler-pyunit quickfix.txt /*compiler-pyunit* -compiler-select quickfix.txt /*compiler-select* -compiler-tex quickfix.txt /*compiler-tex* -compiler-vaxada ft_ada.txt /*compiler-vaxada* -compl-current insert.txt /*compl-current* -compl-define insert.txt /*compl-define* -compl-dictionary insert.txt /*compl-dictionary* -compl-filename insert.txt /*compl-filename* -compl-function insert.txt /*compl-function* -compl-generic insert.txt /*compl-generic* -compl-keyword insert.txt /*compl-keyword* -compl-omni insert.txt /*compl-omni* -compl-omni-filetypes insert.txt /*compl-omni-filetypes* -compl-spelling insert.txt /*compl-spelling* -compl-tag insert.txt /*compl-tag* -compl-vim insert.txt /*compl-vim* -compl-whole-line insert.txt /*compl-whole-line* -complete() eval.txt /*complete()* -complete-functions insert.txt /*complete-functions* -complete-items insert.txt /*complete-items* -complete_CTRL-E insert.txt /*complete_CTRL-E* -complete_CTRL-Y insert.txt /*complete_CTRL-Y* -complete_add() eval.txt /*complete_add()* -complete_check() eval.txt /*complete_check()* -complex-change change.txt /*complex-change* -complex-repeat repeat.txt /*complex-repeat* -compress pi_gzip.txt /*compress* -confirm() eval.txt /*confirm()* -connection-refused message.txt /*connection-refused* -console-menus gui.txt /*console-menus* -control intro.txt /*control* -conversion-server mbyte.txt /*conversion-server* -convert-to-HTML syntax.txt /*convert-to-HTML* -convert-to-XHTML syntax.txt /*convert-to-XHTML* -convert-to-XML syntax.txt /*convert-to-XML* -copy() eval.txt /*copy()* -copy-diffs diff.txt /*copy-diffs* -copy-move change.txt /*copy-move* -copying uganda.txt /*copying* -copyright uganda.txt /*copyright* -cos() eval.txt /*cos()* -count intro.txt /*count* -count() eval.txt /*count()* -count-bytes tips.txt /*count-bytes* -count-items tips.txt /*count-items* -count-variable eval.txt /*count-variable* -count1-variable eval.txt /*count1-variable* -cp-default version5.txt /*cp-default* -cpo-! options.txt /*cpo-!* -cpo-# options.txt /*cpo-#* -cpo-$ options.txt /*cpo-$* -cpo-% options.txt /*cpo-%* -cpo-& options.txt /*cpo-&* -cpo-+ options.txt /*cpo-+* -cpo-- options.txt /*cpo--* -cpo-. options.txt /*cpo-.* -cpo-/ options.txt /*cpo-\/* -cpo-< options.txt /*cpo-<* -cpo-> options.txt /*cpo->* -cpo-A options.txt /*cpo-A* -cpo-B options.txt /*cpo-B* -cpo-C options.txt /*cpo-C* -cpo-D options.txt /*cpo-D* -cpo-E options.txt /*cpo-E* -cpo-F options.txt /*cpo-F* -cpo-H options.txt /*cpo-H* -cpo-I options.txt /*cpo-I* -cpo-J options.txt /*cpo-J* -cpo-K options.txt /*cpo-K* -cpo-L options.txt /*cpo-L* -cpo-M options.txt /*cpo-M* -cpo-O options.txt /*cpo-O* -cpo-P options.txt /*cpo-P* -cpo-R options.txt /*cpo-R* -cpo-S options.txt /*cpo-S* -cpo-W options.txt /*cpo-W* -cpo-X options.txt /*cpo-X* -cpo-Z options.txt /*cpo-Z* -cpo-\ options.txt /*cpo-\\* -cpo-a options.txt /*cpo-a* -cpo-b options.txt /*cpo-b* -cpo-bar options.txt /*cpo-bar* -cpo-c options.txt /*cpo-c* -cpo-d options.txt /*cpo-d* -cpo-e options.txt /*cpo-e* -cpo-f options.txt /*cpo-f* -cpo-g options.txt /*cpo-g* -cpo-i options.txt /*cpo-i* -cpo-j options.txt /*cpo-j* -cpo-k options.txt /*cpo-k* -cpo-l options.txt /*cpo-l* -cpo-m options.txt /*cpo-m* -cpo-n options.txt /*cpo-n* -cpo-o options.txt /*cpo-o* -cpo-p options.txt /*cpo-p* -cpo-q options.txt /*cpo-q* -cpo-r options.txt /*cpo-r* -cpo-s options.txt /*cpo-s* -cpo-star options.txt /*cpo-star* -cpo-t options.txt /*cpo-t* -cpo-u options.txt /*cpo-u* -cpo-v options.txt /*cpo-v* -cpo-w options.txt /*cpo-w* -cpo-x options.txt /*cpo-x* -cpo-y options.txt /*cpo-y* -cpo-{ options.txt /*cpo-{* -crash-recovery recover.txt /*crash-recovery* -creating-menus gui.txt /*creating-menus* -credits intro.txt /*credits* -crontab options.txt /*crontab* -cs-find if_cscop.txt /*cs-find* -cs7-problem term.txt /*cs7-problem* -cscope if_cscop.txt /*cscope* -cscope-commands if_cscop.txt /*cscope-commands* -cscope-find if_cscop.txt /*cscope-find* -cscope-howtouse if_cscop.txt /*cscope-howtouse* -cscope-info if_cscop.txt /*cscope-info* -cscope-intro if_cscop.txt /*cscope-intro* -cscope-limitations if_cscop.txt /*cscope-limitations* -cscope-options if_cscop.txt /*cscope-options* -cscope-suggestions if_cscop.txt /*cscope-suggestions* -cscope-win32 if_cscop.txt /*cscope-win32* -cscope_connection() eval.txt /*cscope_connection()* -cscopepathcomp if_cscop.txt /*cscopepathcomp* -cscopeprg if_cscop.txt /*cscopeprg* -cscopequickfix if_cscop.txt /*cscopequickfix* -cscopetag if_cscop.txt /*cscopetag* -cscopetagorder if_cscop.txt /*cscopetagorder* -cscopeverbose if_cscop.txt /*cscopeverbose* -csh.vim syntax.txt /*csh.vim* -cspc if_cscop.txt /*cspc* -csprg if_cscop.txt /*csprg* -csqf if_cscop.txt /*csqf* -cst if_cscop.txt /*cst* -csto if_cscop.txt /*csto* -csverb if_cscop.txt /*csverb* -ctags tagsrch.txt /*ctags* -ctags-gone version6.txt /*ctags-gone* -cterm-colors syntax.txt /*cterm-colors* -ctrl intro.txt /*ctrl* -ctype-variable eval.txt /*ctype-variable* -curly-braces-function-names eval.txt /*curly-braces-function-names* -curly-braces-names eval.txt /*curly-braces-names* -curpos-visual version6.txt /*curpos-visual* -current-directory editing.txt /*current-directory* -current-file editing.txt /*current-file* -current_compiler quickfix.txt /*current_compiler* -cursor() eval.txt /*cursor()* -cursor-blinking options.txt /*cursor-blinking* -cursor-down intro.txt /*cursor-down* -cursor-left intro.txt /*cursor-left* -cursor-motions motion.txt /*cursor-motions* -cursor-position pattern.txt /*cursor-position* -cursor-right intro.txt /*cursor-right* -cursor-up intro.txt /*cursor-up* -cursor_down intro.txt /*cursor_down* -cursor_left intro.txt /*cursor_left* -cursor_right intro.txt /*cursor_right* -cursor_up intro.txt /*cursor_up* -cw change.txt /*cw* -cweb.vim syntax.txt /*cweb.vim* -cynlib.vim syntax.txt /*cynlib.vim* -d change.txt /*d* -daB motion.txt /*daB* -daW motion.txt /*daW* -dab motion.txt /*dab* -dap motion.txt /*dap* -das motion.txt /*das* -dav pi_netrw.txt /*dav* -davs pi_netrw.txt /*davs* -daw motion.txt /*daw* -dd change.txt /*dd* -debug-gcc debug.txt /*debug-gcc* -debug-highlight debugger.txt /*debug-highlight* -debug-minidump debug.txt /*debug-minidump* -debug-mode repeat.txt /*debug-mode* -debug-scripts repeat.txt /*debug-scripts* -debug-signs debugger.txt /*debug-signs* -debug-vim debug.txt /*debug-vim* -debug-vs2005 debug.txt /*debug-vs2005* -debug-win32 debug.txt /*debug-win32* -debug-windbg debug.txt /*debug-windbg* -debug.txt debug.txt /*debug.txt* -debugger-compilation debugger.txt /*debugger-compilation* -debugger-features debugger.txt /*debugger-features* -debugger-integration debugger.txt /*debugger-integration* -debugger-support debugger.txt /*debugger-support* -debugger.txt debugger.txt /*debugger.txt* -dec-mouse options.txt /*dec-mouse* -decada_members ft_ada.txt /*decada_members* -deepcopy() eval.txt /*deepcopy()* -definition-search tagsrch.txt /*definition-search* -definitions intro.txt /*definitions* -delete() eval.txt /*delete()* -delete-insert change.txt /*delete-insert* -delete-menus gui.txt /*delete-menus* -deleting change.txt /*deleting* -design-assumptions develop.txt /*design-assumptions* -design-compatible develop.txt /*design-compatible* -design-decisions develop.txt /*design-decisions* -design-documented develop.txt /*design-documented* -design-flexible develop.txt /*design-flexible* -design-goals develop.txt /*design-goals* -design-improved develop.txt /*design-improved* -design-maintain develop.txt /*design-maintain* -design-multi-platform develop.txt /*design-multi-platform* -design-not develop.txt /*design-not* -design-speed-size develop.txt /*design-speed-size* -desktop.vim syntax.txt /*desktop.vim* -develop-spell develop.txt /*develop-spell* -develop-spell-suggestions develop.txt /*develop-spell-suggestions* -develop.txt develop.txt /*develop.txt* -development develop.txt /*development* -dh change.txt /*dh* -diB motion.txt /*diB* -diW motion.txt /*diW* -dialog gui_w32.txt /*dialog* -dialogs-added version5.txt /*dialogs-added* -dib motion.txt /*dib* -dict-identity eval.txt /*dict-identity* -dict-modification eval.txt /*dict-modification* -did_filetype() eval.txt /*did_filetype()* -diff diff.txt /*diff* -diff-diffexpr diff.txt /*diff-diffexpr* -diff-mode diff.txt /*diff-mode* -diff-options diff.txt /*diff-options* -diff-original-file diff.txt /*diff-original-file* -diff-patchexpr diff.txt /*diff-patchexpr* -diff.txt diff.txt /*diff.txt* -diff_filler() eval.txt /*diff_filler()* -diff_hlID() eval.txt /*diff_hlID()* -digraph digraph.txt /*digraph* -digraph-arg change.txt /*digraph-arg* -digraph-encoding digraph.txt /*digraph-encoding* -digraph-table digraph.txt /*digraph-table* -digraph.txt digraph.txt /*digraph.txt* -digraphs digraph.txt /*digraphs* -digraphs-changed version6.txt /*digraphs-changed* -digraphs-default digraph.txt /*digraphs-default* -digraphs-define digraph.txt /*digraphs-define* -digraphs-use digraph.txt /*digraphs-use* -dip motion.txt /*dip* -dircolors.vim syntax.txt /*dircolors.vim* -dis motion.txt /*dis* -disable-menus gui.txt /*disable-menus* -distribute-script usr_41.txt /*distribute-script* -distribution intro.txt /*distribution* -diw motion.txt /*diw* -dl change.txt /*dl* -do diff.txt /*do* -doc-file-list help.txt /*doc-file-list* -docbk.vim syntax.txt /*docbk.vim* -docbksgml.vim syntax.txt /*docbksgml.vim* -docbkxml.vim syntax.txt /*docbkxml.vim* -docbook syntax.txt /*docbook* -documentation-6 version6.txt /*documentation-6* -donate uganda.txt /*donate* -dos os_dos.txt /*dos* -dos-:cd os_dos.txt /*dos-:cd* -dos-CTRL-Break os_dos.txt /*dos-CTRL-Break* -dos-backslash os_dos.txt /*dos-backslash* -dos-colors os_dos.txt /*dos-colors* -dos-file-formats os_dos.txt /*dos-file-formats* -dos-locations os_dos.txt /*dos-locations* -dos-shell os_dos.txt /*dos-shell* -dos-standard-mappings os_dos.txt /*dos-standard-mappings* -dos-temp-files os_dos.txt /*dos-temp-files* -dos16 os_msdos.txt /*dos16* -dos32 os_msdos.txt /*dos32* -dosbatch.vim syntax.txt /*dosbatch.vim* -double-click term.txt /*double-click* -download intro.txt /*download* -doxygen-syntax syntax.txt /*doxygen-syntax* -doxygen.vim syntax.txt /*doxygen.vim* -dp diff.txt /*dp* -drag-n-drop gui.txt /*drag-n-drop* -drag-n-drop-win32 gui_w32.txt /*drag-n-drop-win32* -drag-status-line term.txt /*drag-status-line* -dtd.vim syntax.txt /*dtd.vim* -dtd2vim insert.txt /*dtd2vim* -dying-variable eval.txt /*dying-variable* -e motion.txt /*e* -easy starting.txt /*easy* -edit-a-file editing.txt /*edit-a-file* -edit-binary editing.txt /*edit-binary* -edit-dialogs editing.txt /*edit-dialogs* -edit-files editing.txt /*edit-files* -edit-intro editing.txt /*edit-intro* -edit-no-break usr_25.txt /*edit-no-break* -editing.txt editing.txt /*editing.txt* -efm-%> quickfix.txt /*efm-%>* -efm-entries quickfix.txt /*efm-entries* -efm-ignore quickfix.txt /*efm-ignore* -eiffel.vim syntax.txt /*eiffel.vim* -emacs-keys tips.txt /*emacs-keys* -emacs-tags tagsrch.txt /*emacs-tags* -emacs_tags tagsrch.txt /*emacs_tags* -empty() eval.txt /*empty()* -encoding-names mbyte.txt /*encoding-names* -encoding-table mbyte.txt /*encoding-table* -encoding-values mbyte.txt /*encoding-values* -encryption editing.txt /*encryption* -end intro.txt /*end* -end-of-file pattern.txt /*end-of-file* -enlightened-terminal syntax.txt /*enlightened-terminal* -erlang.vim syntax.txt /*erlang.vim* -errmsg-variable eval.txt /*errmsg-variable* -error-file-format quickfix.txt /*error-file-format* -error-messages message.txt /*error-messages* -errorformat quickfix.txt /*errorformat* -errorformat-Jikes quickfix.txt /*errorformat-Jikes* -errorformat-LaTeX quickfix.txt /*errorformat-LaTeX* -errorformat-Perl quickfix.txt /*errorformat-Perl* -errorformat-ant quickfix.txt /*errorformat-ant* -errorformat-changed version4.txt /*errorformat-changed* -errorformat-jade quickfix.txt /*errorformat-jade* -errorformat-javac quickfix.txt /*errorformat-javac* -errorformat-multi-line quickfix.txt /*errorformat-multi-line* -errorformat-separate-filename quickfix.txt /*errorformat-separate-filename* -errorformats quickfix.txt /*errorformats* -errors message.txt /*errors* -escape intro.txt /*escape* -escape() eval.txt /*escape()* -escape-bar version4.txt /*escape-bar* -eval eval.txt /*eval* -eval() eval.txt /*eval()* -eval-examples eval.txt /*eval-examples* -eval-sandbox eval.txt /*eval-sandbox* -eval.txt eval.txt /*eval.txt* -eventhandler() eval.txt /*eventhandler()* -eview starting.txt /*eview* -evim starting.txt /*evim* -evim-keys starting.txt /*evim-keys* -evim.vim starting.txt /*evim.vim* -ex starting.txt /*ex* -ex-cmd-index index.txt /*ex-cmd-index* -ex-edit-index index.txt /*ex-edit-index* -ex-flags cmdline.txt /*ex-flags* -ex: options.txt /*ex:* -except-autocmd eval.txt /*except-autocmd* -except-autocmd-Cmd eval.txt /*except-autocmd-Cmd* -except-autocmd-Post eval.txt /*except-autocmd-Post* -except-autocmd-Pre eval.txt /*except-autocmd-Pre* -except-autocmd-ill eval.txt /*except-autocmd-ill* -except-compat eval.txt /*except-compat* -except-examine eval.txt /*except-examine* -except-from-finally eval.txt /*except-from-finally* -except-hier-param eval.txt /*except-hier-param* -except-several-errors eval.txt /*except-several-errors* -except-single-line eval.txt /*except-single-line* -except-syntax-err eval.txt /*except-syntax-err* -except-syntax-error eval.txt /*except-syntax-error* -exception-handling eval.txt /*exception-handling* -exception-variable eval.txt /*exception-variable* -exclusive motion.txt /*exclusive* -exclusive-linewise motion.txt /*exclusive-linewise* -executable() eval.txt /*executable()* -execute-menus gui.txt /*execute-menus* -exim starting.txt /*exim* -exists() eval.txt /*exists()* -expand() eval.txt /*expand()* -expand-env options.txt /*expand-env* -expand-environment-var options.txt /*expand-environment-var* -expr eval.txt /*expr* -expr-! eval.txt /*expr-!* -expr-!= eval.txt /*expr-!=* -expr-!=# eval.txt /*expr-!=#* -expr-!=? eval.txt /*expr-!=?* -expr-!~ eval.txt /*expr-!~* -expr-!~# eval.txt /*expr-!~#* -expr-!~? eval.txt /*expr-!~?* -expr-% eval.txt /*expr-%* -expr-&& eval.txt /*expr-&&* -expr-' eval.txt /*expr-'* -expr-+ eval.txt /*expr-+* -expr-- eval.txt /*expr--* -expr-. eval.txt /*expr-.* -expr-/ eval.txt /*expr-\/* -expr-< eval.txt /*expr-<* -expr-<# eval.txt /*expr-<#* -expr-<= eval.txt /*expr-<=* -expr-<=# eval.txt /*expr-<=#* -expr-<=? eval.txt /*expr-<=?* -expr-<? eval.txt /*expr-<?* -expr-== eval.txt /*expr-==* -expr-==# eval.txt /*expr-==#* -expr-==? eval.txt /*expr-==?* -expr-=~ eval.txt /*expr-=~* -expr-=~# eval.txt /*expr-=~#* -expr-=~? eval.txt /*expr-=~?* -expr-> eval.txt /*expr->* -expr-># eval.txt /*expr->#* -expr->= eval.txt /*expr->=* -expr->=# eval.txt /*expr->=#* -expr->=? eval.txt /*expr->=?* -expr->? eval.txt /*expr->?* -expr-[:] eval.txt /*expr-[:]* -expr-[] eval.txt /*expr-[]* -expr-barbar eval.txt /*expr-barbar* -expr-entry eval.txt /*expr-entry* -expr-env eval.txt /*expr-env* -expr-env-expand eval.txt /*expr-env-expand* -expr-function eval.txt /*expr-function* -expr-is eval.txt /*expr-is* -expr-nesting eval.txt /*expr-nesting* -expr-number eval.txt /*expr-number* -expr-option eval.txt /*expr-option* -expr-quote eval.txt /*expr-quote* -expr-register eval.txt /*expr-register* -expr-star eval.txt /*expr-star* -expr-string eval.txt /*expr-string* -expr-unary-+ eval.txt /*expr-unary-+* -expr-unary-- eval.txt /*expr-unary--* -expr-variable eval.txt /*expr-variable* -expr1 eval.txt /*expr1* -expr2 eval.txt /*expr2* -expr3 eval.txt /*expr3* -expr4 eval.txt /*expr4* -expr5 eval.txt /*expr5* -expr6 eval.txt /*expr6* -expr7 eval.txt /*expr7* -expr8 eval.txt /*expr8* -expr9 eval.txt /*expr9* -expression eval.txt /*expression* -expression-commands eval.txt /*expression-commands* -expression-syntax eval.txt /*expression-syntax* -exrc starting.txt /*exrc* -extend() eval.txt /*extend()* -extension-removal cmdline.txt /*extension-removal* -extensions-improvements todo.txt /*extensions-improvements* -f motion.txt /*f* -faq intro.txt /*faq* -farsi farsi.txt /*farsi* -farsi.txt farsi.txt /*farsi.txt* -fasm.vim syntax.txt /*fasm.vim* -fcs_choice-variable eval.txt /*fcs_choice-variable* -fcs_reason-variable eval.txt /*fcs_reason-variable* -feature-list eval.txt /*feature-list* -feedkeys() eval.txt /*feedkeys()* -fetch pi_netrw.txt /*fetch* -file-browser-5.2 version5.txt /*file-browser-5.2* -file-formats editing.txt /*file-formats* -file-pattern autocmd.txt /*file-pattern* -file-read insert.txt /*file-read* -file-searching editing.txt /*file-searching* -file-type filetype.txt /*file-type* -file-types filetype.txt /*file-types* -file_readable() eval.txt /*file_readable()* -fileencoding-changed version6.txt /*fileencoding-changed* -filename-backslash cmdline.txt /*filename-backslash* -filename-modifiers cmdline.txt /*filename-modifiers* -filereadable() eval.txt /*filereadable()* -filetype filetype.txt /*filetype* -filetype-detect filetype.txt /*filetype-detect* -filetype-ignore filetype.txt /*filetype-ignore* -filetype-overrule filetype.txt /*filetype-overrule* -filetype-plugin usr_43.txt /*filetype-plugin* -filetype-plugins filetype.txt /*filetype-plugins* -filetype.txt filetype.txt /*filetype.txt* -filetypedetect-changed version6.txt /*filetypedetect-changed* -filetypes filetype.txt /*filetypes* -filewritable() eval.txt /*filewritable()* -filter change.txt /*filter* -filter() eval.txt /*filter()* -find-manpage usr_12.txt /*find-manpage* -find-replace usr_10.txt /*find-replace* -finddir() eval.txt /*finddir()* -findfile() eval.txt /*findfile()* -fixed-5.1 version5.txt /*fixed-5.1* -fixed-5.2 version5.txt /*fixed-5.2* -fixed-5.3 version5.txt /*fixed-5.3* -fixed-5.4 version5.txt /*fixed-5.4* -fixed-5.5 version5.txt /*fixed-5.5* -fixed-5.6 version5.txt /*fixed-5.6* -fixed-5.7 version5.txt /*fixed-5.7* -fixed-5.8 version5.txt /*fixed-5.8* -fixed-6.1 version6.txt /*fixed-6.1* -fixed-6.2 version6.txt /*fixed-6.2* -fixed-6.3 version6.txt /*fixed-6.3* -fixed-6.4 version6.txt /*fixed-6.4* -fixed-7.1 version7.txt /*fixed-7.1* -fixed-7.2 version7.txt /*fixed-7.2* -flexwiki.vim syntax.txt /*flexwiki.vim* -float-e eval.txt /*float-e* -float-pi eval.txt /*float-pi* -float2nr() eval.txt /*float2nr()* -floating-point-format eval.txt /*floating-point-format* -floating-point-precision eval.txt /*floating-point-precision* -floor() eval.txt /*floor()* -fname_diff-variable eval.txt /*fname_diff-variable* -fname_in-variable eval.txt /*fname_in-variable* -fname_new-variable eval.txt /*fname_new-variable* -fname_out-variable eval.txt /*fname_out-variable* -fnameescape() eval.txt /*fnameescape()* -fnamemodify() eval.txt /*fnamemodify()* -fo-table change.txt /*fo-table* -fold-behavior fold.txt /*fold-behavior* -fold-colors fold.txt /*fold-colors* -fold-commands fold.txt /*fold-commands* -fold-create-marker fold.txt /*fold-create-marker* -fold-delete-marker fold.txt /*fold-delete-marker* -fold-diff fold.txt /*fold-diff* -fold-expr fold.txt /*fold-expr* -fold-foldcolumn fold.txt /*fold-foldcolumn* -fold-foldlevel fold.txt /*fold-foldlevel* -fold-foldtext fold.txt /*fold-foldtext* -fold-indent fold.txt /*fold-indent* -fold-manual fold.txt /*fold-manual* -fold-marker fold.txt /*fold-marker* -fold-methods fold.txt /*fold-methods* -fold-options fold.txt /*fold-options* -fold-syntax fold.txt /*fold-syntax* -fold.txt fold.txt /*fold.txt* -foldclosed() eval.txt /*foldclosed()* -foldclosedend() eval.txt /*foldclosedend()* -folddashes-variable eval.txt /*folddashes-variable* -foldend-variable eval.txt /*foldend-variable* -folding fold.txt /*folding* -foldlevel() eval.txt /*foldlevel()* -foldlevel-variable eval.txt /*foldlevel-variable* -foldstart-variable eval.txt /*foldstart-variable* -foldtext() eval.txt /*foldtext()* -foldtextresult() eval.txt /*foldtextresult()* -font-sizes gui_x11.txt /*font-sizes* -fontset mbyte.txt /*fontset* -foreground() eval.txt /*foreground()* -fork os_unix.txt /*fork* -form.vim syntax.txt /*form.vim* -format-bullet-list tips.txt /*format-bullet-list* -format-comments change.txt /*format-comments* -formatting change.txt /*formatting* -formfeed intro.txt /*formfeed* -fortran.vim syntax.txt /*fortran.vim* -frombook usr_01.txt /*frombook* -ft-abel-syntax syntax.txt /*ft-abel-syntax* -ft-ada-commands ft_ada.txt /*ft-ada-commands* -ft-ada-constants ft_ada.txt /*ft-ada-constants* -ft-ada-functions ft_ada.txt /*ft-ada-functions* -ft-ada-indent ft_ada.txt /*ft-ada-indent* -ft-ada-omni ft_ada.txt /*ft-ada-omni* -ft-ada-options ft_ada.txt /*ft-ada-options* -ft-ada-plugin ft_ada.txt /*ft-ada-plugin* -ft-ada-syntax ft_ada.txt /*ft-ada-syntax* -ft-ada-variables ft_ada.txt /*ft-ada-variables* -ft-ant-syntax syntax.txt /*ft-ant-syntax* -ft-apache-syntax syntax.txt /*ft-apache-syntax* -ft-asm-syntax syntax.txt /*ft-asm-syntax* -ft-asm68k-syntax syntax.txt /*ft-asm68k-syntax* -ft-asmh8300-syntax syntax.txt /*ft-asmh8300-syntax* -ft-aspperl-syntax syntax.txt /*ft-aspperl-syntax* -ft-aspvbs-syntax syntax.txt /*ft-aspvbs-syntax* -ft-bash-syntax syntax.txt /*ft-bash-syntax* -ft-basic-syntax syntax.txt /*ft-basic-syntax* -ft-c-omni insert.txt /*ft-c-omni* -ft-c-syntax syntax.txt /*ft-c-syntax* -ft-ch-syntax syntax.txt /*ft-ch-syntax* -ft-changelog-plugin filetype.txt /*ft-changelog-plugin* -ft-changelog-syntax syntax.txt /*ft-changelog-syntax* -ft-chill-syntax syntax.txt /*ft-chill-syntax* -ft-cobol-syntax syntax.txt /*ft-cobol-syntax* -ft-coldfusion-syntax syntax.txt /*ft-coldfusion-syntax* -ft-csh-syntax syntax.txt /*ft-csh-syntax* -ft-css-omni insert.txt /*ft-css-omni* -ft-cweb-syntax syntax.txt /*ft-cweb-syntax* -ft-cynlib-syntax syntax.txt /*ft-cynlib-syntax* -ft-desktop-syntax syntax.txt /*ft-desktop-syntax* -ft-dircolors-syntax syntax.txt /*ft-dircolors-syntax* -ft-docbk-syntax syntax.txt /*ft-docbk-syntax* -ft-docbksgml-syntax syntax.txt /*ft-docbksgml-syntax* -ft-docbkxml-syntax syntax.txt /*ft-docbkxml-syntax* -ft-dosbatch-syntax syntax.txt /*ft-dosbatch-syntax* -ft-dtd-syntax syntax.txt /*ft-dtd-syntax* -ft-eiffel-syntax syntax.txt /*ft-eiffel-syntax* -ft-erlang-syntax syntax.txt /*ft-erlang-syntax* -ft-flexwiki-syntax syntax.txt /*ft-flexwiki-syntax* -ft-form-syntax syntax.txt /*ft-form-syntax* -ft-fortran-indent indent.txt /*ft-fortran-indent* -ft-fortran-plugin filetype.txt /*ft-fortran-plugin* -ft-fortran-syntax syntax.txt /*ft-fortran-syntax* -ft-fvwm-syntax syntax.txt /*ft-fvwm-syntax* -ft-gitcommit-plugin filetype.txt /*ft-gitcommit-plugin* -ft-groff-syntax syntax.txt /*ft-groff-syntax* -ft-gsp-syntax syntax.txt /*ft-gsp-syntax* -ft-haskell-syntax syntax.txt /*ft-haskell-syntax* -ft-html-omni insert.txt /*ft-html-omni* -ft-html-syntax syntax.txt /*ft-html-syntax* -ft-htmlos-syntax syntax.txt /*ft-htmlos-syntax* -ft-ia64-syntax syntax.txt /*ft-ia64-syntax* -ft-inform-syntax syntax.txt /*ft-inform-syntax* -ft-java-syntax syntax.txt /*ft-java-syntax* -ft-javascript-omni insert.txt /*ft-javascript-omni* -ft-ksh-syntax syntax.txt /*ft-ksh-syntax* -ft-lace-syntax syntax.txt /*ft-lace-syntax* -ft-lex-syntax syntax.txt /*ft-lex-syntax* -ft-lisp-syntax syntax.txt /*ft-lisp-syntax* -ft-lite-syntax syntax.txt /*ft-lite-syntax* -ft-lpc-syntax syntax.txt /*ft-lpc-syntax* -ft-lua-syntax syntax.txt /*ft-lua-syntax* -ft-mail-plugin filetype.txt /*ft-mail-plugin* -ft-mail.vim syntax.txt /*ft-mail.vim* -ft-make-syntax syntax.txt /*ft-make-syntax* -ft-man-plugin filetype.txt /*ft-man-plugin* -ft-maple-syntax syntax.txt /*ft-maple-syntax* -ft-masm-syntax syntax.txt /*ft-masm-syntax* -ft-mathematica-syntax syntax.txt /*ft-mathematica-syntax* -ft-mma-syntax syntax.txt /*ft-mma-syntax* -ft-moo-syntax syntax.txt /*ft-moo-syntax* -ft-msql-syntax syntax.txt /*ft-msql-syntax* -ft-nasm-syntax syntax.txt /*ft-nasm-syntax* -ft-ncf-syntax syntax.txt /*ft-ncf-syntax* -ft-nroff-syntax syntax.txt /*ft-nroff-syntax* -ft-ocaml-syntax syntax.txt /*ft-ocaml-syntax* -ft-papp-syntax syntax.txt /*ft-papp-syntax* -ft-pascal-syntax syntax.txt /*ft-pascal-syntax* -ft-pdf-plugin filetype.txt /*ft-pdf-plugin* -ft-perl-syntax syntax.txt /*ft-perl-syntax* -ft-php-indent indent.txt /*ft-php-indent* -ft-php-omni insert.txt /*ft-php-omni* -ft-php-syntax syntax.txt /*ft-php-syntax* -ft-php3-syntax syntax.txt /*ft-php3-syntax* -ft-phtml-syntax syntax.txt /*ft-phtml-syntax* -ft-plaintex-syntax syntax.txt /*ft-plaintex-syntax* -ft-postscr-syntax syntax.txt /*ft-postscr-syntax* -ft-ppwiz-syntax syntax.txt /*ft-ppwiz-syntax* -ft-printcap-syntax syntax.txt /*ft-printcap-syntax* -ft-progress-syntax syntax.txt /*ft-progress-syntax* -ft-ptcap-syntax syntax.txt /*ft-ptcap-syntax* -ft-python-indent indent.txt /*ft-python-indent* -ft-python-syntax syntax.txt /*ft-python-syntax* -ft-quake-syntax syntax.txt /*ft-quake-syntax* -ft-readline-syntax syntax.txt /*ft-readline-syntax* -ft-rexx-syntax syntax.txt /*ft-rexx-syntax* -ft-ruby-omni insert.txt /*ft-ruby-omni* -ft-ruby-syntax syntax.txt /*ft-ruby-syntax* -ft-scheme-syntax syntax.txt /*ft-scheme-syntax* -ft-sdl-syntax syntax.txt /*ft-sdl-syntax* -ft-sed-syntax syntax.txt /*ft-sed-syntax* -ft-sgml-syntax syntax.txt /*ft-sgml-syntax* -ft-sh-indent indent.txt /*ft-sh-indent* -ft-sh-syntax syntax.txt /*ft-sh-syntax* -ft-spec-plugin filetype.txt /*ft-spec-plugin* -ft-spup-syntax syntax.txt /*ft-spup-syntax* -ft-sql filetype.txt /*ft-sql* -ft-sql-omni insert.txt /*ft-sql-omni* -ft-sql-syntax syntax.txt /*ft-sql-syntax* -ft-sqlanywhere-syntax syntax.txt /*ft-sqlanywhere-syntax* -ft-sqlinformix-syntax syntax.txt /*ft-sqlinformix-syntax* -ft-syntax-omni insert.txt /*ft-syntax-omni* -ft-tcsh-syntax syntax.txt /*ft-tcsh-syntax* -ft-termcap-syntax syntax.txt /*ft-termcap-syntax* -ft-tex-plugin filetype.txt /*ft-tex-plugin* -ft-tex-syntax syntax.txt /*ft-tex-syntax* -ft-tf-syntax syntax.txt /*ft-tf-syntax* -ft-vb-syntax syntax.txt /*ft-vb-syntax* -ft-verilog-indent indent.txt /*ft-verilog-indent* -ft-vhdl-indent indent.txt /*ft-vhdl-indent* -ft-vim-indent indent.txt /*ft-vim-indent* -ft-vim-syntax syntax.txt /*ft-vim-syntax* -ft-xf86conf-syntax syntax.txt /*ft-xf86conf-syntax* -ft-xhtml-omni insert.txt /*ft-xhtml-omni* -ft-xml-omni insert.txt /*ft-xml-omni* -ft-xml-syntax syntax.txt /*ft-xml-syntax* -ft-xpm-syntax syntax.txt /*ft-xpm-syntax* -ft_ada.txt ft_ada.txt /*ft_ada.txt* -ft_sql.txt ft_sql.txt /*ft_sql.txt* -ftdetect filetype.txt /*ftdetect* -ftp pi_netrw.txt /*ftp* -ftplugin usr_41.txt /*ftplugin* -ftplugin-docs filetype.txt /*ftplugin-docs* -ftplugin-name usr_05.txt /*ftplugin-name* -ftplugin-overrule filetype.txt /*ftplugin-overrule* -ftplugin-special usr_41.txt /*ftplugin-special* -ftplugins usr_05.txt /*ftplugins* -function() eval.txt /*function()* -function-argument eval.txt /*function-argument* -function-key intro.txt /*function-key* -function-list usr_41.txt /*function-list* -function-range-example eval.txt /*function-range-example* -function-search-undo eval.txt /*function-search-undo* -function_key intro.txt /*function_key* -functions eval.txt /*functions* -fvwm.vim syntax.txt /*fvwm.vim* -fvwm2rc syntax.txt /*fvwm2rc* -fvwmrc syntax.txt /*fvwmrc* -g index.txt /*g* -g# pattern.txt /*g#* -g$ motion.txt /*g$* -g& change.txt /*g&* -g' motion.txt /*g'* -g'a motion.txt /*g'a* -g+ undo.txt /*g+* -g, motion.txt /*g,* -g- undo.txt /*g-* -g0 motion.txt /*g0* -g8 various.txt /*g8* -g:NetrwTopLvlMenu pi_netrw.txt /*g:NetrwTopLvlMenu* -g:ada#Comment ft_ada.txt /*g:ada#Comment* -g:ada#Ctags_Kinds ft_ada.txt /*g:ada#Ctags_Kinds* -g:ada#DotWordRegex ft_ada.txt /*g:ada#DotWordRegex* -g:ada#Keywords ft_ada.txt /*g:ada#Keywords* -g:ada#WordRegex ft_ada.txt /*g:ada#WordRegex* -g:ada_abbrev ft_ada.txt /*g:ada_abbrev* -g:ada_all_tab_usage ft_ada.txt /*g:ada_all_tab_usage* -g:ada_begin_preproc ft_ada.txt /*g:ada_begin_preproc* -g:ada_default_compiler ft_ada.txt /*g:ada_default_compiler* -g:ada_extended_completion ft_ada.txt /*g:ada_extended_completion* -g:ada_extended_tagging ft_ada.txt /*g:ada_extended_tagging* -g:ada_folding ft_ada.txt /*g:ada_folding* -g:ada_gnat_extensions ft_ada.txt /*g:ada_gnat_extensions* -g:ada_line_errors ft_ada.txt /*g:ada_line_errors* -g:ada_no_tab_space_error ft_ada.txt /*g:ada_no_tab_space_error* -g:ada_no_trail_space_error ft_ada.txt /*g:ada_no_trail_space_error* -g:ada_omni_with_keywords ft_ada.txt /*g:ada_omni_with_keywords* -g:ada_rainbow_color ft_ada.txt /*g:ada_rainbow_color* -g:ada_space_errors ft_ada.txt /*g:ada_space_errors* -g:ada_standard_types ft_ada.txt /*g:ada_standard_types* -g:ada_with_gnat_project_files ft_ada.txt /*g:ada_with_gnat_project_files* -g:ada_withuse_ordinary ft_ada.txt /*g:ada_withuse_ordinary* -g:colors_name options.txt /*g:colors_name* -g:decada ft_ada.txt /*g:decada* -g:decada.Error_Format ft_ada.txt /*g:decada.Error_Format* -g:decada.Make() ft_ada.txt /*g:decada.Make()* -g:decada.Make_Command ft_ada.txt /*g:decada.Make_Command* -g:decada.Unit_Name() ft_ada.txt /*g:decada.Unit_Name()* -g:gnat ft_ada.txt /*g:gnat* -g:gnat.Error_Format ft_ada.txt /*g:gnat.Error_Format* -g:gnat.Find() ft_ada.txt /*g:gnat.Find()* -g:gnat.Find_Program ft_ada.txt /*g:gnat.Find_Program* -g:gnat.Make() ft_ada.txt /*g:gnat.Make()* -g:gnat.Make_Command ft_ada.txt /*g:gnat.Make_Command* -g:gnat.Pretty() ft_ada.txt /*g:gnat.Pretty()* -g:gnat.Pretty_Program ft_ada.txt /*g:gnat.Pretty_Program* -g:gnat.Project_File ft_ada.txt /*g:gnat.Project_File* -g:gnat.Set_Project_File() ft_ada.txt /*g:gnat.Set_Project_File()* -g:gnat.Tags() ft_ada.txt /*g:gnat.Tags()* -g:gnat.Tags_Command ft_ada.txt /*g:gnat.Tags_Command* -g:netrw_alto pi_netrw.txt /*g:netrw_alto* -g:netrw_altv pi_netrw.txt /*g:netrw_altv* -g:netrw_browse_split pi_netrw.txt /*g:netrw_browse_split* -g:netrw_browsex_viewer pi_netrw.txt /*g:netrw_browsex_viewer* -g:netrw_compress pi_netrw.txt /*g:netrw_compress* -g:netrw_ctags pi_netrw.txt /*g:netrw_ctags* -g:netrw_cygwin pi_netrw.txt /*g:netrw_cygwin* -g:netrw_dav_cmd pi_netrw.txt /*g:netrw_dav_cmd* -g:netrw_decompress pi_netrw.txt /*g:netrw_decompress* -g:netrw_extracmd pi_netrw.txt /*g:netrw_extracmd* -g:netrw_fastbrowse pi_netrw.txt /*g:netrw_fastbrowse* -g:netrw_fetch_cmd pi_netrw.txt /*g:netrw_fetch_cmd* -g:netrw_fname_escape pi_netrw.txt /*g:netrw_fname_escape* -g:netrw_ftp pi_netrw.txt /*g:netrw_ftp* -g:netrw_ftp_browse_reject pi_netrw.txt /*g:netrw_ftp_browse_reject* -g:netrw_ftp_cmd pi_netrw.txt /*g:netrw_ftp_cmd* -g:netrw_ftp_list_cmd pi_netrw.txt /*g:netrw_ftp_list_cmd* -g:netrw_ftp_sizelist_cmd pi_netrw.txt /*g:netrw_ftp_sizelist_cmd* -g:netrw_ftp_timelist_cmd pi_netrw.txt /*g:netrw_ftp_timelist_cmd* -g:netrw_ftpmode pi_netrw.txt /*g:netrw_ftpmode* -g:netrw_glob_escape pi_netrw.txt /*g:netrw_glob_escape* -g:netrw_hide pi_netrw.txt /*g:netrw_hide* -g:netrw_http_cmd pi_netrw.txt /*g:netrw_http_cmd* -g:netrw_ignorenetrc pi_netrw.txt /*g:netrw_ignorenetrc* -g:netrw_keepdir pi_netrw.txt /*g:netrw_keepdir* -g:netrw_list_cmd pi_netrw.txt /*g:netrw_list_cmd* -g:netrw_list_hide pi_netrw.txt /*g:netrw_list_hide* -g:netrw_liststyle pi_netrw.txt /*g:netrw_liststyle* -g:netrw_local_mkdir pi_netrw.txt /*g:netrw_local_mkdir* -g:netrw_local_rmdir pi_netrw.txt /*g:netrw_local_rmdir* -g:netrw_localcopycmd pi_netrw.txt /*g:netrw_localcopycmd* -g:netrw_localmovecmd pi_netrw.txt /*g:netrw_localmovecmd* -g:netrw_maxfilenamelen pi_netrw.txt /*g:netrw_maxfilenamelen* -g:netrw_menu pi_netrw.txt /*g:netrw_menu* -g:netrw_mkdir_cmd pi_netrw.txt /*g:netrw_mkdir_cmd* -g:netrw_nogx pi_netrw.txt /*g:netrw_nogx* -g:netrw_preview pi_netrw.txt /*g:netrw_preview* -g:netrw_rcp_cmd pi_netrw.txt /*g:netrw_rcp_cmd* -g:netrw_retmap pi_netrw.txt /*g:netrw_retmap* -g:netrw_rm_cmd pi_netrw.txt /*g:netrw_rm_cmd* -g:netrw_rmdir_cmd pi_netrw.txt /*g:netrw_rmdir_cmd* -g:netrw_rmf_cmd pi_netrw.txt /*g:netrw_rmf_cmd* -g:netrw_rsync_cmd pi_netrw.txt /*g:netrw_rsync_cmd* -g:netrw_scp_cmd pi_netrw.txt /*g:netrw_scp_cmd* -g:netrw_scpport pi_netrw.txt /*g:netrw_scpport* -g:netrw_sftp_cmd pi_netrw.txt /*g:netrw_sftp_cmd* -g:netrw_silent pi_netrw.txt /*g:netrw_silent* -g:netrw_sort_by pi_netrw.txt /*g:netrw_sort_by* -g:netrw_sort_direction pi_netrw.txt /*g:netrw_sort_direction* -g:netrw_sort_options pi_netrw.txt /*g:netrw_sort_options* -g:netrw_sort_sequence pi_netrw.txt /*g:netrw_sort_sequence* -g:netrw_special_syntax pi_netrw.txt /*g:netrw_special_syntax* -g:netrw_ssh_browse_reject pi_netrw.txt /*g:netrw_ssh_browse_reject* -g:netrw_ssh_cmd pi_netrw.txt /*g:netrw_ssh_cmd* -g:netrw_sshport pi_netrw.txt /*g:netrw_sshport* -g:netrw_timefmt pi_netrw.txt /*g:netrw_timefmt* -g:netrw_tmpfile_escape pi_netrw.txt /*g:netrw_tmpfile_escape* -g:netrw_uid pi_netrw.txt /*g:netrw_uid* -g:netrw_use_errorwindow pi_netrw.txt /*g:netrw_use_errorwindow* -g:netrw_use_noswf pi_netrw.txt /*g:netrw_use_noswf* -g:netrw_use_nt_rcp pi_netrw.txt /*g:netrw_use_nt_rcp* -g:netrw_win95ftp pi_netrw.txt /*g:netrw_win95ftp* -g:netrw_winsize pi_netrw.txt /*g:netrw_winsize* -g:netrw_xstrlen pi_netrw.txt /*g:netrw_xstrlen* -g:tar_browseoptions pi_tar.txt /*g:tar_browseoptions* -g:tar_cmd pi_tar.txt /*g:tar_cmd* -g:tar_nomax pi_tar.txt /*g:tar_nomax* -g:tar_readoptions pi_tar.txt /*g:tar_readoptions* -g:tar_secure pi_tar.txt /*g:tar_secure* -g:tar_writeoptions pi_tar.txt /*g:tar_writeoptions* -g:var eval.txt /*g:var* -g:vimball_home pi_vimball.txt /*g:vimball_home* -g:vimball_mkdir pi_vimball.txt /*g:vimball_mkdir* -g:vimball_path_escape pi_vimball.txt /*g:vimball_path_escape* -g:vimsyn_embed syntax.txt /*g:vimsyn_embed* -g:vimsyn_folding syntax.txt /*g:vimsyn_folding* -g:vimsyn_maxlines syntax.txt /*g:vimsyn_maxlines* -g:vimsyn_minlines syntax.txt /*g:vimsyn_minlines* -g:vimsyn_noerror syntax.txt /*g:vimsyn_noerror* -g:zip_nomax pi_zip.txt /*g:zip_nomax* -g:zip_shq pi_zip.txt /*g:zip_shq* -g:zip_unzipcmd pi_zip.txt /*g:zip_unzipcmd* -g:zip_zipcmd pi_zip.txt /*g:zip_zipcmd* -g; motion.txt /*g;* -g< message.txt /*g<* -g<Down> motion.txt /*g<Down>* -g<End> motion.txt /*g<End>* -g<Home> motion.txt /*g<Home>* -g<LeftMouse> tagsrch.txt /*g<LeftMouse>* -g<RightMouse> tagsrch.txt /*g<RightMouse>* -g<Up> motion.txt /*g<Up>* -g? change.txt /*g?* -g?? change.txt /*g??* -g?g? change.txt /*g?g?* -g@ map.txt /*g@* -gD pattern.txt /*gD* -gE motion.txt /*gE* -gF editing.txt /*gF* -gH visual.txt /*gH* -gI insert.txt /*gI* -gJ change.txt /*gJ* -gP change.txt /*gP* -gQ intro.txt /*gQ* -gR change.txt /*gR* -gT tabpage.txt /*gT* -gU change.txt /*gU* -gUU change.txt /*gUU* -gUgU change.txt /*gUgU* -gV visual.txt /*gV* -g] tagsrch.txt /*g]* -g^ motion.txt /*g^* -g_ motion.txt /*g_* -g_CTRL-A various.txt /*g_CTRL-A* -g_CTRL-G editing.txt /*g_CTRL-G* -g_CTRL-H visual.txt /*g_CTRL-H* -g_CTRL-] tagsrch.txt /*g_CTRL-]* -g` motion.txt /*g`* -g`a motion.txt /*g`a* -ga various.txt /*ga* -garbagecollect() eval.txt /*garbagecollect()* -gd pattern.txt /*gd* -ge motion.txt /*ge* -get() eval.txt /*get()* -get-ms-debuggers debug.txt /*get-ms-debuggers* -getbufline() eval.txt /*getbufline()* -getbufvar() eval.txt /*getbufvar()* -getchar() eval.txt /*getchar()* -getcharmod() eval.txt /*getcharmod()* -getcmdline() eval.txt /*getcmdline()* -getcmdpos() eval.txt /*getcmdpos()* -getcmdtype() eval.txt /*getcmdtype()* -getcwd() eval.txt /*getcwd()* -getfontname() eval.txt /*getfontname()* -getfperm() eval.txt /*getfperm()* -getfsize() eval.txt /*getfsize()* -getftime() eval.txt /*getftime()* -getftype() eval.txt /*getftype()* -getlatestvimscripts-install pi_getscript.txt /*getlatestvimscripts-install* -getline() eval.txt /*getline()* -getloclist() eval.txt /*getloclist()* -getmatches() eval.txt /*getmatches()* -getpid() eval.txt /*getpid()* -getpos() eval.txt /*getpos()* -getqflist() eval.txt /*getqflist()* -getreg() eval.txt /*getreg()* -getregtype() eval.txt /*getregtype()* -getscript pi_getscript.txt /*getscript* -getscript-autoinstall pi_getscript.txt /*getscript-autoinstall* -getscript-data pi_getscript.txt /*getscript-data* -getscript-history pi_getscript.txt /*getscript-history* -getscript-plugins pi_getscript.txt /*getscript-plugins* -getscript-start pi_getscript.txt /*getscript-start* -gettabwinvar() eval.txt /*gettabwinvar()* -getwinposx() eval.txt /*getwinposx()* -getwinposy() eval.txt /*getwinposy()* -getwinvar() eval.txt /*getwinvar()* -gex starting.txt /*gex* -gf editing.txt /*gf* -gg motion.txt /*gg* -gh visual.txt /*gh* -gi insert.txt /*gi* -gj motion.txt /*gj* -gk motion.txt /*gk* -glob() eval.txt /*glob()* -global-ime mbyte.txt /*global-ime* -global-local options.txt /*global-local* -global-variable eval.txt /*global-variable* -global_markfilelist pi_netrw.txt /*global_markfilelist* -globpath() eval.txt /*globpath()* -glvs pi_getscript.txt /*glvs* -glvs-alg pi_getscript.txt /*glvs-alg* -glvs-algorithm pi_getscript.txt /*glvs-algorithm* -glvs-autoinstall pi_getscript.txt /*glvs-autoinstall* -glvs-contents pi_getscript.txt /*glvs-contents* -glvs-copyright pi_getscript.txt /*glvs-copyright* -glvs-data pi_getscript.txt /*glvs-data* -glvs-dist-install pi_getscript.txt /*glvs-dist-install* -glvs-hist pi_getscript.txt /*glvs-hist* -glvs-install pi_getscript.txt /*glvs-install* -glvs-options pi_getscript.txt /*glvs-options* -glvs-plugins pi_getscript.txt /*glvs-plugins* -glvs-usage pi_getscript.txt /*glvs-usage* -gm motion.txt /*gm* -gnat#Insert_Tags_Header() ft_ada.txt /*gnat#Insert_Tags_Header()* -gnat#New() ft_ada.txt /*gnat#New()* -gnat-xref ft_ada.txt /*gnat-xref* -gnat_members ft_ada.txt /*gnat_members* -gnome-session gui_x11.txt /*gnome-session* -go motion.txt /*go* -gp change.txt /*gp* -gpm-mouse term.txt /*gpm-mouse* -gq change.txt /*gq* -gqap change.txt /*gqap* -gqgq change.txt /*gqgq* -gqq change.txt /*gqq* -gr change.txt /*gr* -graphic-option-gone version4.txt /*graphic-option-gone* -greek options.txt /*greek* -grep quickfix.txt /*grep* -groff.vim syntax.txt /*groff.vim* -group-name syntax.txt /*group-name* -gs various.txt /*gs* -gsp.vim syntax.txt /*gsp.vim* -gstar pattern.txt /*gstar* -gt tabpage.txt /*gt* -gtk-tooltip-colors gui_x11.txt /*gtk-tooltip-colors* -gu change.txt /*gu* -gugu change.txt /*gugu* -gui gui.txt /*gui* -gui-clipboard gui_w32.txt /*gui-clipboard* -gui-colors syntax.txt /*gui-colors* -gui-extras gui.txt /*gui-extras* -gui-footer debugger.txt /*gui-footer* -gui-fork gui_x11.txt /*gui-fork* -gui-gnome gui_x11.txt /*gui-gnome* -gui-gnome-session gui_x11.txt /*gui-gnome-session* -gui-gtk gui_x11.txt /*gui-gtk* -gui-gtk-socketid gui_x11.txt /*gui-gtk-socketid* -gui-horiz-scroll gui.txt /*gui-horiz-scroll* -gui-init gui.txt /*gui-init* -gui-kde gui_x11.txt /*gui-kde* -gui-mouse gui.txt /*gui-mouse* -gui-mouse-focus gui.txt /*gui-mouse-focus* -gui-mouse-mapping gui.txt /*gui-mouse-mapping* -gui-mouse-modeless gui.txt /*gui-mouse-modeless* -gui-mouse-move gui.txt /*gui-mouse-move* -gui-mouse-select gui.txt /*gui-mouse-select* -gui-mouse-status gui.txt /*gui-mouse-status* -gui-mouse-various gui.txt /*gui-mouse-various* -gui-pty gui_x11.txt /*gui-pty* -gui-pty-erase gui_x11.txt /*gui-pty-erase* -gui-resources gui_x11.txt /*gui-resources* -gui-scrollbars gui.txt /*gui-scrollbars* -gui-selections gui.txt /*gui-selections* -gui-shell gui.txt /*gui-shell* -gui-shell-win32 gui_w32.txt /*gui-shell-win32* -gui-start gui.txt /*gui-start* -gui-toolbar gui.txt /*gui-toolbar* -gui-vert-scroll gui.txt /*gui-vert-scroll* -gui-w16 gui_w16.txt /*gui-w16* -gui-w32 gui_w32.txt /*gui-w32* -gui-w32-cmdargs gui_w32.txt /*gui-w32-cmdargs* -gui-w32-dialogs gui_w32.txt /*gui-w32-dialogs* -gui-w32-printing gui_w32.txt /*gui-w32-printing* -gui-w32-start gui_w32.txt /*gui-w32-start* -gui-w32-various gui_w32.txt /*gui-w32-various* -gui-w32-windowid gui_w32.txt /*gui-w32-windowid* -gui-w32s gui_w32.txt /*gui-w32s* -gui-win32-maximized gui_w32.txt /*gui-win32-maximized* -gui-x11 gui_x11.txt /*gui-x11* -gui-x11-athena gui_x11.txt /*gui-x11-athena* -gui-x11-compiling gui_x11.txt /*gui-x11-compiling* -gui-x11-gtk gui_x11.txt /*gui-x11-gtk* -gui-x11-kde gui_x11.txt /*gui-x11-kde* -gui-x11-misc gui_x11.txt /*gui-x11-misc* -gui-x11-motif gui_x11.txt /*gui-x11-motif* -gui-x11-neXtaw gui_x11.txt /*gui-x11-neXtaw* -gui-x11-printing gui_x11.txt /*gui-x11-printing* -gui-x11-start gui_x11.txt /*gui-x11-start* -gui-x11-various gui_x11.txt /*gui-x11-various* -gui.txt gui.txt /*gui.txt* -gui_w16.txt gui_w16.txt /*gui_w16.txt* -gui_w32.txt gui_w32.txt /*gui_w32.txt* -gui_x11.txt gui_x11.txt /*gui_x11.txt* -guifontwide_gtk2 options.txt /*guifontwide_gtk2* -guioptions_a options.txt /*guioptions_a* -guu change.txt /*guu* -gv visual.txt /*gv* -gview starting.txt /*gview* -gvim starting.txt /*gvim* -gvimdiff diff.txt /*gvimdiff* -gvimrc gui.txt /*gvimrc* -gw change.txt /*gw* -gwgw change.txt /*gwgw* -gww change.txt /*gww* -gzip pi_gzip.txt /*gzip* -gzip-autocmd pi_gzip.txt /*gzip-autocmd* -gzip-example autocmd.txt /*gzip-example* -gzip-helpfile tips.txt /*gzip-helpfile* -g~ change.txt /*g~* -g~g~ change.txt /*g~g~* -g~~ change.txt /*g~~* -h motion.txt /*h* -hangul hangulin.txt /*hangul* -hangulin.txt hangulin.txt /*hangulin.txt* -has() eval.txt /*has()* -has-patch eval.txt /*has-patch* -has_key() eval.txt /*has_key()* -haskell.vim syntax.txt /*haskell.vim* -haslocaldir() eval.txt /*haslocaldir()* -hasmapto() eval.txt /*hasmapto()* -hebrew hebrew.txt /*hebrew* -hebrew.txt hebrew.txt /*hebrew.txt* -help various.txt /*help* -help-context help.txt /*help-context* -help-summary usr_02.txt /*help-summary* -help-tags tags 1 -help-translated various.txt /*help-translated* -help-xterm-window various.txt /*help-xterm-window* -help.txt help.txt /*help.txt* -hex-editing tips.txt /*hex-editing* -hidden-buffer windows.txt /*hidden-buffer* -hidden-changed version5.txt /*hidden-changed* -hidden-menus gui.txt /*hidden-menus* -hidden-options options.txt /*hidden-options* -hidden-quit windows.txt /*hidden-quit* -highlight-args syntax.txt /*highlight-args* -highlight-changed version4.txt /*highlight-changed* -highlight-cterm syntax.txt /*highlight-cterm* -highlight-ctermbg syntax.txt /*highlight-ctermbg* -highlight-ctermfg syntax.txt /*highlight-ctermfg* -highlight-default syntax.txt /*highlight-default* -highlight-font syntax.txt /*highlight-font* -highlight-groups syntax.txt /*highlight-groups* -highlight-gui syntax.txt /*highlight-gui* -highlight-guibg syntax.txt /*highlight-guibg* -highlight-guifg syntax.txt /*highlight-guifg* -highlight-guisp syntax.txt /*highlight-guisp* -highlight-start syntax.txt /*highlight-start* -highlight-stop syntax.txt /*highlight-stop* -highlight-term syntax.txt /*highlight-term* -highlightID() eval.txt /*highlightID()* -highlight_exists() eval.txt /*highlight_exists()* -hist-names eval.txt /*hist-names* -histadd() eval.txt /*histadd()* -histdel() eval.txt /*histdel()* -histget() eval.txt /*histget()* -histnr() eval.txt /*histnr()* -history cmdline.txt /*history* -hit-enter message.txt /*hit-enter* -hit-enter-prompt message.txt /*hit-enter-prompt* -hit-return message.txt /*hit-return* -hitest.vim syntax.txt /*hitest.vim* -hjkl usr_02.txt /*hjkl* -hl-Cursor syntax.txt /*hl-Cursor* -hl-CursorColumn syntax.txt /*hl-CursorColumn* -hl-CursorIM syntax.txt /*hl-CursorIM* -hl-CursorLine syntax.txt /*hl-CursorLine* -hl-DiffAdd syntax.txt /*hl-DiffAdd* -hl-DiffChange syntax.txt /*hl-DiffChange* -hl-DiffDelete syntax.txt /*hl-DiffDelete* -hl-DiffText syntax.txt /*hl-DiffText* -hl-Directory syntax.txt /*hl-Directory* -hl-ErrorMsg syntax.txt /*hl-ErrorMsg* -hl-FoldColumn syntax.txt /*hl-FoldColumn* -hl-Folded syntax.txt /*hl-Folded* -hl-IncSearch syntax.txt /*hl-IncSearch* -hl-LineNr syntax.txt /*hl-LineNr* -hl-MatchParen syntax.txt /*hl-MatchParen* -hl-Menu syntax.txt /*hl-Menu* -hl-ModeMsg syntax.txt /*hl-ModeMsg* -hl-MoreMsg syntax.txt /*hl-MoreMsg* -hl-NonText syntax.txt /*hl-NonText* -hl-Normal syntax.txt /*hl-Normal* -hl-Pmenu syntax.txt /*hl-Pmenu* -hl-PmenuSbar syntax.txt /*hl-PmenuSbar* -hl-PmenuSel syntax.txt /*hl-PmenuSel* -hl-PmenuThumb syntax.txt /*hl-PmenuThumb* -hl-Question syntax.txt /*hl-Question* -hl-Scrollbar syntax.txt /*hl-Scrollbar* -hl-Search syntax.txt /*hl-Search* -hl-SignColumn syntax.txt /*hl-SignColumn* -hl-SpecialKey syntax.txt /*hl-SpecialKey* -hl-SpellBad syntax.txt /*hl-SpellBad* -hl-SpellCap syntax.txt /*hl-SpellCap* -hl-SpellLocal syntax.txt /*hl-SpellLocal* -hl-SpellRare syntax.txt /*hl-SpellRare* -hl-StatusLine syntax.txt /*hl-StatusLine* -hl-StatusLineNC syntax.txt /*hl-StatusLineNC* -hl-TabLine syntax.txt /*hl-TabLine* -hl-TabLineFill syntax.txt /*hl-TabLineFill* -hl-TabLineSel syntax.txt /*hl-TabLineSel* -hl-Title syntax.txt /*hl-Title* -hl-Tooltip syntax.txt /*hl-Tooltip* -hl-User1 syntax.txt /*hl-User1* -hl-User1..9 syntax.txt /*hl-User1..9* -hl-User9 syntax.txt /*hl-User9* -hl-VertSplit syntax.txt /*hl-VertSplit* -hl-Visual syntax.txt /*hl-Visual* -hl-VisualNOS syntax.txt /*hl-VisualNOS* -hl-WarningMsg syntax.txt /*hl-WarningMsg* -hl-WildMenu syntax.txt /*hl-WildMenu* -hlID() eval.txt /*hlID()* -hlexists() eval.txt /*hlexists()* -holy-grail index.txt /*holy-grail* -home intro.txt /*home* -home-replace editing.txt /*home-replace* -hostname() eval.txt /*hostname()* -how-do-i howto.txt /*how-do-i* -how-to howto.txt /*how-to* -howdoi howto.txt /*howdoi* -howto howto.txt /*howto* -howto.txt howto.txt /*howto.txt* -hpterm term.txt /*hpterm* -hpterm-color syntax.txt /*hpterm-color* -html-flavor insert.txt /*html-flavor* -html.vim syntax.txt /*html.vim* -htmlos.vim syntax.txt /*htmlos.vim* -http pi_netrw.txt /*http* -i insert.txt /*i* -i' motion.txt /*i'* -i( motion.txt /*i(* -i) motion.txt /*i)* -i< motion.txt /*i<* -i> motion.txt /*i>* -iB motion.txt /*iB* -iW motion.txt /*iW* -i[ motion.txt /*i[* -i] motion.txt /*i]* -i_0_CTRL-D insert.txt /*i_0_CTRL-D* -i_<BS> insert.txt /*i_<BS>* -i_<C-End> insert.txt /*i_<C-End>* -i_<C-Home> insert.txt /*i_<C-Home>* -i_<C-Left> insert.txt /*i_<C-Left>* -i_<C-PageDown> tabpage.txt /*i_<C-PageDown>* -i_<C-PageUp> tabpage.txt /*i_<C-PageUp>* -i_<C-Right> insert.txt /*i_<C-Right>* -i_<CR> insert.txt /*i_<CR>* -i_<Del> insert.txt /*i_<Del>* -i_<Down> insert.txt /*i_<Down>* -i_<End> insert.txt /*i_<End>* -i_<Esc> insert.txt /*i_<Esc>* -i_<F1> various.txt /*i_<F1>* -i_<Help> various.txt /*i_<Help>* -i_<Home> insert.txt /*i_<Home>* -i_<Insert> insert.txt /*i_<Insert>* -i_<Left> insert.txt /*i_<Left>* -i_<LeftMouse> insert.txt /*i_<LeftMouse>* -i_<MouseDown> insert.txt /*i_<MouseDown>* -i_<MouseUp> insert.txt /*i_<MouseUp>* -i_<NL> insert.txt /*i_<NL>* -i_<PageDown> insert.txt /*i_<PageDown>* -i_<PageUp> insert.txt /*i_<PageUp>* -i_<Right> insert.txt /*i_<Right>* -i_<S-Down> insert.txt /*i_<S-Down>* -i_<S-Left> insert.txt /*i_<S-Left>* -i_<S-MouseDown> insert.txt /*i_<S-MouseDown>* -i_<S-MouseUp> insert.txt /*i_<S-MouseUp>* -i_<S-Right> insert.txt /*i_<S-Right>* -i_<S-Up> insert.txt /*i_<S-Up>* -i_<Tab> insert.txt /*i_<Tab>* -i_<Up> insert.txt /*i_<Up>* -i_BS insert.txt /*i_BS* -i_CTRL-<PageDown> tabpage.txt /*i_CTRL-<PageDown>* -i_CTRL-<PageUp> tabpage.txt /*i_CTRL-<PageUp>* -i_CTRL-@ insert.txt /*i_CTRL-@* -i_CTRL-A insert.txt /*i_CTRL-A* -i_CTRL-B-gone version5.txt /*i_CTRL-B-gone* -i_CTRL-C insert.txt /*i_CTRL-C* -i_CTRL-D insert.txt /*i_CTRL-D* -i_CTRL-E insert.txt /*i_CTRL-E* -i_CTRL-F indent.txt /*i_CTRL-F* -i_CTRL-G_<Down> insert.txt /*i_CTRL-G_<Down>* -i_CTRL-G_<Up> insert.txt /*i_CTRL-G_<Up>* -i_CTRL-G_CTRL-J insert.txt /*i_CTRL-G_CTRL-J* -i_CTRL-G_CTRL-K insert.txt /*i_CTRL-G_CTRL-K* -i_CTRL-G_j insert.txt /*i_CTRL-G_j* -i_CTRL-G_k insert.txt /*i_CTRL-G_k* -i_CTRL-G_u insert.txt /*i_CTRL-G_u* -i_CTRL-H insert.txt /*i_CTRL-H* -i_CTRL-I insert.txt /*i_CTRL-I* -i_CTRL-J insert.txt /*i_CTRL-J* -i_CTRL-K insert.txt /*i_CTRL-K* -i_CTRL-L insert.txt /*i_CTRL-L* -i_CTRL-M insert.txt /*i_CTRL-M* -i_CTRL-N insert.txt /*i_CTRL-N* -i_CTRL-O insert.txt /*i_CTRL-O* -i_CTRL-P insert.txt /*i_CTRL-P* -i_CTRL-Q insert.txt /*i_CTRL-Q* -i_CTRL-R insert.txt /*i_CTRL-R* -i_CTRL-R_CTRL-O insert.txt /*i_CTRL-R_CTRL-O* -i_CTRL-R_CTRL-P insert.txt /*i_CTRL-R_CTRL-P* -i_CTRL-R_CTRL-R insert.txt /*i_CTRL-R_CTRL-R* -i_CTRL-T insert.txt /*i_CTRL-T* -i_CTRL-U insert.txt /*i_CTRL-U* -i_CTRL-V insert.txt /*i_CTRL-V* -i_CTRL-V_digit insert.txt /*i_CTRL-V_digit* -i_CTRL-W insert.txt /*i_CTRL-W* -i_CTRL-X insert.txt /*i_CTRL-X* -i_CTRL-X_CTRL-D insert.txt /*i_CTRL-X_CTRL-D* -i_CTRL-X_CTRL-E insert.txt /*i_CTRL-X_CTRL-E* -i_CTRL-X_CTRL-F insert.txt /*i_CTRL-X_CTRL-F* -i_CTRL-X_CTRL-I insert.txt /*i_CTRL-X_CTRL-I* -i_CTRL-X_CTRL-K insert.txt /*i_CTRL-X_CTRL-K* -i_CTRL-X_CTRL-L insert.txt /*i_CTRL-X_CTRL-L* -i_CTRL-X_CTRL-N insert.txt /*i_CTRL-X_CTRL-N* -i_CTRL-X_CTRL-O insert.txt /*i_CTRL-X_CTRL-O* -i_CTRL-X_CTRL-P insert.txt /*i_CTRL-X_CTRL-P* -i_CTRL-X_CTRL-S insert.txt /*i_CTRL-X_CTRL-S* -i_CTRL-X_CTRL-T insert.txt /*i_CTRL-X_CTRL-T* -i_CTRL-X_CTRL-U insert.txt /*i_CTRL-X_CTRL-U* -i_CTRL-X_CTRL-V insert.txt /*i_CTRL-X_CTRL-V* -i_CTRL-X_CTRL-Y insert.txt /*i_CTRL-X_CTRL-Y* -i_CTRL-X_CTRL-] insert.txt /*i_CTRL-X_CTRL-]* -i_CTRL-X_index index.txt /*i_CTRL-X_index* -i_CTRL-X_s insert.txt /*i_CTRL-X_s* -i_CTRL-Y insert.txt /*i_CTRL-Y* -i_CTRL-Z options.txt /*i_CTRL-Z* -i_CTRL-[ insert.txt /*i_CTRL-[* -i_CTRL-\_CTRL-G intro.txt /*i_CTRL-\\_CTRL-G* -i_CTRL-\_CTRL-N intro.txt /*i_CTRL-\\_CTRL-N* -i_CTRL-\_CTRL-O insert.txt /*i_CTRL-\\_CTRL-O* -i_CTRL-] insert.txt /*i_CTRL-]* -i_CTRL-^ insert.txt /*i_CTRL-^* -i_CTRL-_ insert.txt /*i_CTRL-_* -i_DEL insert.txt /*i_DEL* -i_Tab insert.txt /*i_Tab* -i_^_CTRL-D insert.txt /*i_^_CTRL-D* -i_backspacing insert.txt /*i_backspacing* -i_digraph digraph.txt /*i_digraph* -i_esc intro.txt /*i_esc* -i` motion.txt /*i`* -ia64.vim syntax.txt /*ia64.vim* -ib motion.txt /*ib* -iccf uganda.txt /*iccf* -iccf-donations uganda.txt /*iccf-donations* -icon-changed version4.txt /*icon-changed* -iconise starting.txt /*iconise* -iconize starting.txt /*iconize* -iconv() eval.txt /*iconv()* -iconv-dynamic mbyte.txt /*iconv-dynamic* -ident-search tips.txt /*ident-search* -idl-syntax syntax.txt /*idl-syntax* -idl.vim syntax.txt /*idl.vim* -if_cscop.txt if_cscop.txt /*if_cscop.txt* -if_mzsch.txt if_mzsch.txt /*if_mzsch.txt* -if_ole.txt if_ole.txt /*if_ole.txt* -if_perl.txt if_perl.txt /*if_perl.txt* -if_pyth.txt if_pyth.txt /*if_pyth.txt* -if_ruby.txt if_ruby.txt /*if_ruby.txt* -if_sniff.txt if_sniff.txt /*if_sniff.txt* -if_tcl.txt if_tcl.txt /*if_tcl.txt* -ignore-errors eval.txt /*ignore-errors* -improved-autocmds-5.4 version5.txt /*improved-autocmds-5.4* -improved-quickfix version5.txt /*improved-quickfix* -improved-sessions version5.txt /*improved-sessions* -improved-viminfo version5.txt /*improved-viminfo* -improvements-5 version5.txt /*improvements-5* -improvements-6 version6.txt /*improvements-6* -improvements-7 version7.txt /*improvements-7* -inactive-buffer windows.txt /*inactive-buffer* -include-search tagsrch.txt /*include-search* -inclusive motion.txt /*inclusive* -incomp-small-6 version6.txt /*incomp-small-6* -incompatible-5 version5.txt /*incompatible-5* -incompatible-6 version6.txt /*incompatible-6* -incompatible-7 version7.txt /*incompatible-7* -indent() eval.txt /*indent()* -indent-expression indent.txt /*indent-expression* -indent.txt indent.txt /*indent.txt* -indentkeys-format indent.txt /*indentkeys-format* -index index.txt /*index* -index() eval.txt /*index()* -index.txt index.txt /*index.txt* -info-message starting.txt /*info-message* -inform.vim syntax.txt /*inform.vim* -informix ft_sql.txt /*informix* -initialization starting.txt /*initialization* -input() eval.txt /*input()* -inputdialog() eval.txt /*inputdialog()* -inputlist() eval.txt /*inputlist()* -inputrestore() eval.txt /*inputrestore()* -inputsave() eval.txt /*inputsave()* -inputsecret() eval.txt /*inputsecret()* -ins-completion insert.txt /*ins-completion* -ins-completion-menu insert.txt /*ins-completion-menu* -ins-expandtab insert.txt /*ins-expandtab* -ins-reverse rileft.txt /*ins-reverse* -ins-smarttab insert.txt /*ins-smarttab* -ins-softtabstop insert.txt /*ins-softtabstop* -ins-special-keys insert.txt /*ins-special-keys* -ins-special-special insert.txt /*ins-special-special* -ins-textwidth insert.txt /*ins-textwidth* -insert insert.txt /*insert* -insert() eval.txt /*insert()* -insert-index index.txt /*insert-index* -insert.txt insert.txt /*insert.txt* -insert_expand insert.txt /*insert_expand* -inserting insert.txt /*inserting* -inserting-ex insert.txt /*inserting-ex* -inserting-file insert.txt /*inserting-file* -insertmode-variable eval.txt /*insertmode-variable* -install usr_90.txt /*install* -install-home usr_90.txt /*install-home* -install-registry gui_w32.txt /*install-registry* -intel-itanium syntax.txt /*intel-itanium* -intellimouse-wheel-problems gui_w32.txt /*intellimouse-wheel-problems* -interfaces-5.2 version5.txt /*interfaces-5.2* -internal-variables eval.txt /*internal-variables* -internal-wordlist spell.txt /*internal-wordlist* -internet intro.txt /*internet* -intro intro.txt /*intro* -intro.txt intro.txt /*intro.txt* -inverse syntax.txt /*inverse* -ip motion.txt /*ip* -iquote motion.txt /*iquote* -is motion.txt /*is* -isdirectory() eval.txt /*isdirectory()* -islocked() eval.txt /*islocked()* -it motion.txt /*it* -italic syntax.txt /*italic* -items() eval.txt /*items()* -iw motion.txt /*iw* -i{ motion.txt /*i{* -i} motion.txt /*i}* -j motion.txt /*j* -java-cinoptions indent.txt /*java-cinoptions* -java-indenting indent.txt /*java-indenting* -java.vim syntax.txt /*java.vim* -join() eval.txt /*join()* -jsbterm-mouse options.txt /*jsbterm-mouse* -jtags tagsrch.txt /*jtags* -jump-motions motion.txt /*jump-motions* -jumplist motion.txt /*jumplist* -jumpto-diffs diff.txt /*jumpto-diffs* -k motion.txt /*k* -kcc uganda.txt /*kcc* -kde gui_x11.txt /*kde* -key-codes intro.txt /*key-codes* -key-codes-changed version4.txt /*key-codes-changed* -key-mapping map.txt /*key-mapping* -key-notation intro.txt /*key-notation* -key-variable eval.txt /*key-variable* -keycodes intro.txt /*keycodes* -keymap-accents mbyte.txt /*keymap-accents* -keymap-file-format mbyte.txt /*keymap-file-format* -keymap-hebrew mbyte.txt /*keymap-hebrew* -keypad-0 intro.txt /*keypad-0* -keypad-9 intro.txt /*keypad-9* -keypad-comma term.txt /*keypad-comma* -keypad-divide intro.txt /*keypad-divide* -keypad-end intro.txt /*keypad-end* -keypad-enter intro.txt /*keypad-enter* -keypad-home intro.txt /*keypad-home* -keypad-minus intro.txt /*keypad-minus* -keypad-multiply intro.txt /*keypad-multiply* -keypad-page-down intro.txt /*keypad-page-down* -keypad-page-up intro.txt /*keypad-page-up* -keypad-plus intro.txt /*keypad-plus* -keypad-point intro.txt /*keypad-point* -keys() eval.txt /*keys()* -known-bugs todo.txt /*known-bugs* -l motion.txt /*l* -l:var eval.txt /*l:var* -lace.vim syntax.txt /*lace.vim* -lang-variable eval.txt /*lang-variable* -language-mapping map.txt /*language-mapping* -last-pattern pattern.txt /*last-pattern* -last-position-jump eval.txt /*last-position-jump* -last_buffer_nr() eval.txt /*last_buffer_nr()* -lc_time-variable eval.txt /*lc_time-variable* -left-right-motions motion.txt /*left-right-motions* -len() eval.txt /*len()* -less various.txt /*less* -letter print.txt /*letter* -lex.vim syntax.txt /*lex.vim* -lhaskell.vim syntax.txt /*lhaskell.vim* -libcall() eval.txt /*libcall()* -libcallnr() eval.txt /*libcallnr()* -license uganda.txt /*license* -lid quickfix.txt /*lid* -limits vi_diff.txt /*limits* -line() eval.txt /*line()* -line-continuation repeat.txt /*line-continuation* -line2byte() eval.txt /*line2byte()* -linefeed intro.txt /*linefeed* -linewise motion.txt /*linewise* -linewise-register change.txt /*linewise-register* -linewise-visual visual.txt /*linewise-visual* -lisp.vim syntax.txt /*lisp.vim* -lispindent() eval.txt /*lispindent()* -list-identity eval.txt /*list-identity* -list-index eval.txt /*list-index* -list-modification eval.txt /*list-modification* -list-repeat windows.txt /*list-repeat* -lite.vim syntax.txt /*lite.vim* -literal-string eval.txt /*literal-string* -lnum-variable eval.txt /*lnum-variable* -load-plugins starting.txt /*load-plugins* -load-vim-script repeat.txt /*load-vim-script* -local-additions help.txt /*local-additions* -local-function eval.txt /*local-function* -local-options options.txt /*local-options* -local-variable eval.txt /*local-variable* -local-variables eval.txt /*local-variables* -local_markfilelist pi_netrw.txt /*local_markfilelist* -locale mbyte.txt /*locale* -locale-name mbyte.txt /*locale-name* -localtime() eval.txt /*localtime()* -location-list quickfix.txt /*location-list* -location-list-window quickfix.txt /*location-list-window* -log10() eval.txt /*log10()* -long-lines version5.txt /*long-lines* -lowercase change.txt /*lowercase* -lpc.vim syntax.txt /*lpc.vim* -lua.vim syntax.txt /*lua.vim* -m motion.txt /*m* -m' motion.txt /*m'* -m[ motion.txt /*m[* -m] motion.txt /*m]* -m` motion.txt /*m`* -mac os_mac.txt /*mac* -mac-bug os_mac.txt /*mac-bug* -mac-compile os_mac.txt /*mac-compile* -mac-faq os_mac.txt /*mac-faq* -mac-filename os_mac.txt /*mac-filename* -mac-lack os_mac.txt /*mac-lack* -mac-vimfile os_mac.txt /*mac-vimfile* -macintosh os_mac.txt /*macintosh* -macro map.txt /*macro* -mail-list intro.txt /*mail-list* -mail.vim syntax.txt /*mail.vim* -maillist intro.txt /*maillist* -maillist-archive intro.txt /*maillist-archive* -make.vim syntax.txt /*make.vim* -manual-copyright usr_01.txt /*manual-copyright* -map() eval.txt /*map()* -map-<SID> map.txt /*map-<SID>* -map-ambiguous map.txt /*map-ambiguous* -map-backtick tips.txt /*map-backtick* -map-comments map.txt /*map-comments* -map-examples map.txt /*map-examples* -map-keys-fails map.txt /*map-keys-fails* -map-listing map.txt /*map-listing* -map-modes map.txt /*map-modes* -map-multibyte map.txt /*map-multibyte* -map-overview map.txt /*map-overview* -map-self-destroy tips.txt /*map-self-destroy* -map-typing map.txt /*map-typing* -map-which-keys map.txt /*map-which-keys* -map.txt map.txt /*map.txt* -map_CTRL-C map.txt /*map_CTRL-C* -map_backslash map.txt /*map_backslash* -map_bar map.txt /*map_bar* -map_empty_rhs map.txt /*map_empty_rhs* -map_return map.txt /*map_return* -map_space_in_lhs map.txt /*map_space_in_lhs* -map_space_in_rhs map.txt /*map_space_in_rhs* -maparg() eval.txt /*maparg()* -mapcheck() eval.txt /*mapcheck()* -maple.vim syntax.txt /*maple.vim* -mapleader map.txt /*mapleader* -maplocalleader map.txt /*maplocalleader* -mapmode-c map.txt /*mapmode-c* -mapmode-i map.txt /*mapmode-i* -mapmode-ic map.txt /*mapmode-ic* -mapmode-l map.txt /*mapmode-l* -mapmode-n map.txt /*mapmode-n* -mapmode-nvo map.txt /*mapmode-nvo* -mapmode-o map.txt /*mapmode-o* -mapmode-s map.txt /*mapmode-s* -mapmode-v map.txt /*mapmode-v* -mapmode-x map.txt /*mapmode-x* -mapping map.txt /*mapping* -mark motion.txt /*mark* -mark-motions motion.txt /*mark-motions* -markfilelist pi_netrw.txt /*markfilelist* -masm.vim syntax.txt /*masm.vim* -match() eval.txt /*match()* -match-highlight pattern.txt /*match-highlight* -match-parens tips.txt /*match-parens* -matchadd() eval.txt /*matchadd()* -matcharg() eval.txt /*matcharg()* -matchdelete() eval.txt /*matchdelete()* -matchend() eval.txt /*matchend()* -matchit-install usr_05.txt /*matchit-install* -matchlist() eval.txt /*matchlist()* -matchparen pi_paren.txt /*matchparen* -matchstr() eval.txt /*matchstr()* -max() eval.txt /*max()* -mbyte-IME mbyte.txt /*mbyte-IME* -mbyte-XIM mbyte.txt /*mbyte-XIM* -mbyte-combining mbyte.txt /*mbyte-combining* -mbyte-composing mbyte.txt /*mbyte-composing* -mbyte-conversion mbyte.txt /*mbyte-conversion* -mbyte-encoding mbyte.txt /*mbyte-encoding* -mbyte-first mbyte.txt /*mbyte-first* -mbyte-fonts-MSwin mbyte.txt /*mbyte-fonts-MSwin* -mbyte-fonts-X11 mbyte.txt /*mbyte-fonts-X11* -mbyte-keymap mbyte.txt /*mbyte-keymap* -mbyte-locale mbyte.txt /*mbyte-locale* -mbyte-options mbyte.txt /*mbyte-options* -mbyte-terminal mbyte.txt /*mbyte-terminal* -mbyte-utf8 mbyte.txt /*mbyte-utf8* -mbyte.txt mbyte.txt /*mbyte.txt* -menu-changes-5.4 version5.txt /*menu-changes-5.4* -menu-examples gui.txt /*menu-examples* -menu-priority gui.txt /*menu-priority* -menu-separator gui.txt /*menu-separator* -menu.vim gui.txt /*menu.vim* -menus gui.txt /*menus* -merge diff.txt /*merge* -message-history message.txt /*message-history* -message.txt message.txt /*message.txt* -messages message.txt /*messages* -meta intro.txt /*meta* -min() eval.txt /*min()* -minimal-features os_msdos.txt /*minimal-features* -missing-options vi_diff.txt /*missing-options* -mkdir() eval.txt /*mkdir()* -mlang.txt mlang.txt /*mlang.txt* -mma.vim syntax.txt /*mma.vim* -mode() eval.txt /*mode()* -mode-Ex intro.txt /*mode-Ex* -mode-cmdline cmdline.txt /*mode-cmdline* -mode-ins-repl insert.txt /*mode-ins-repl* -mode-replace insert.txt /*mode-replace* -mode-switching intro.txt /*mode-switching* -modeless-and-clipboard version6.txt /*modeless-and-clipboard* -modeless-selection gui.txt /*modeless-selection* -modeline options.txt /*modeline* -modeline-local options.txt /*modeline-local* -modeline-version options.txt /*modeline-version* -moo.vim syntax.txt /*moo.vim* -more-compatible version5.txt /*more-compatible* -more-prompt message.txt /*more-prompt* -more-variables eval.txt /*more-variables* -motion.txt motion.txt /*motion.txt* -mouse-mode-table term.txt /*mouse-mode-table* -mouse-overview term.txt /*mouse-overview* -mouse-swap-buttons term.txt /*mouse-swap-buttons* -mouse-using term.txt /*mouse-using* -mouse_col-variable eval.txt /*mouse_col-variable* -mouse_lnum-variable eval.txt /*mouse_lnum-variable* -mouse_win-variable eval.txt /*mouse_win-variable* -movement intro.txt /*movement* -ms-dos os_msdos.txt /*ms-dos* -msdos os_msdos.txt /*msdos* -msdos-arrows os_msdos.txt /*msdos-arrows* -msdos-clipboard-limits os_msdos.txt /*msdos-clipboard-limits* -msdos-compiling os_msdos.txt /*msdos-compiling* -msdos-copy-paste os_msdos.txt /*msdos-copy-paste* -msdos-fname-extensions os_msdos.txt /*msdos-fname-extensions* -msdos-limitations os_msdos.txt /*msdos-limitations* -msdos-linked-files os_msdos.txt /*msdos-linked-files* -msdos-longfname os_msdos.txt /*msdos-longfname* -msdos-mode gui_w32.txt /*msdos-mode* -msdos-problems os_msdos.txt /*msdos-problems* -msdos-termcap os_msdos.txt /*msdos-termcap* -msdos-versions os_msdos.txt /*msdos-versions* -msql.vim syntax.txt /*msql.vim* -mswin.vim gui_w32.txt /*mswin.vim* -multi-byte mbyte.txt /*multi-byte* -multi-lang mlang.txt /*multi-lang* -multi-repeat repeat.txt /*multi-repeat* -multibyte mbyte.txt /*multibyte* -multibyte-ime mbyte.txt /*multibyte-ime* -multibyte-input mbyte.txt /*multibyte-input* -multilang mlang.txt /*multilang* -multilang-menus mlang.txt /*multilang-menus* -multilang-messages mlang.txt /*multilang-messages* -multilang-scripts mlang.txt /*multilang-scripts* -myfiletypefile syntax.txt /*myfiletypefile* -myscriptsfile syntax.txt /*myscriptsfile* -mysql ft_sql.txt /*mysql* -mysyntaxfile syntax.txt /*mysyntaxfile* -mysyntaxfile-add syntax.txt /*mysyntaxfile-add* -mysyntaxfile-replace syntax.txt /*mysyntaxfile-replace* -mzscheme if_mzsch.txt /*mzscheme* -mzscheme-buffer if_mzsch.txt /*mzscheme-buffer* -mzscheme-commands if_mzsch.txt /*mzscheme-commands* -mzscheme-dynamic if_mzsch.txt /*mzscheme-dynamic* -mzscheme-examples if_mzsch.txt /*mzscheme-examples* -mzscheme-sandbox if_mzsch.txt /*mzscheme-sandbox* -mzscheme-threads if_mzsch.txt /*mzscheme-threads* -mzscheme-vim if_mzsch.txt /*mzscheme-vim* -mzscheme-vimext if_mzsch.txt /*mzscheme-vimext* -mzscheme-window if_mzsch.txt /*mzscheme-window* -n pattern.txt /*n* -nasm.vim syntax.txt /*nasm.vim* -navigation motion.txt /*navigation* -nb-commands netbeans.txt /*nb-commands* -nb-events netbeans.txt /*nb-events* -nb-functions netbeans.txt /*nb-functions* -nb-messages netbeans.txt /*nb-messages* -nb-protocol_errors netbeans.txt /*nb-protocol_errors* -nb-special netbeans.txt /*nb-special* -nb-terms netbeans.txt /*nb-terms* -ncf.vim syntax.txt /*ncf.vim* -netbeans netbeans.txt /*netbeans* -netbeans-configure netbeans.txt /*netbeans-configure* -netbeans-debugging netbeans.txt /*netbeans-debugging* -netbeans-download netbeans.txt /*netbeans-download* -netbeans-integration netbeans.txt /*netbeans-integration* -netbeans-intro netbeans.txt /*netbeans-intro* -netbeans-key netbeans.txt /*netbeans-key* -netbeans-keybindings netbeans.txt /*netbeans-keybindings* -netbeans-messages netbeans.txt /*netbeans-messages* -netbeans-preparation netbeans.txt /*netbeans-preparation* -netbeans-problems netbeans.txt /*netbeans-problems* -netbeans-protocol netbeans.txt /*netbeans-protocol* -netbeans-run netbeans.txt /*netbeans-run* -netbeans-setup netbeans.txt /*netbeans-setup* -netbeans-support netbeans.txt /*netbeans-support* -netbeans.txt netbeans.txt /*netbeans.txt* -netreadfixup pi_netrw.txt /*netreadfixup* -netrw pi_netrw.txt /*netrw* -netrw-% pi_netrw.txt /*netrw-%* -netrw-- pi_netrw.txt /*netrw--* -netrw-D pi_netrw.txt /*netrw-D* -netrw-O pi_netrw.txt /*netrw-O* -netrw-P pi_netrw.txt /*netrw-P* -netrw-R pi_netrw.txt /*netrw-R* -netrw-S pi_netrw.txt /*netrw-S* -netrw-U pi_netrw.txt /*netrw-U* -netrw-a pi_netrw.txt /*netrw-a* -netrw-activate pi_netrw.txt /*netrw-activate* -netrw-bookmark pi_netrw.txt /*netrw-bookmark* -netrw-bookmarks pi_netrw.txt /*netrw-bookmarks* -netrw-browse pi_netrw.txt /*netrw-browse* -netrw-browse-cmds pi_netrw.txt /*netrw-browse-cmds* -netrw-browse-maps pi_netrw.txt /*netrw-browse-maps* -netrw-browser pi_netrw.txt /*netrw-browser* -netrw-browser-options pi_netrw.txt /*netrw-browser-options* -netrw-browser-var pi_netrw.txt /*netrw-browser-var* -netrw-browsing pi_netrw.txt /*netrw-browsing* -netrw-c pi_netrw.txt /*netrw-c* -netrw-cadaver pi_netrw.txt /*netrw-cadaver* -netrw-chgup pi_netrw.txt /*netrw-chgup* -netrw-clean pi_netrw.txt /*netrw-clean* -netrw-contents pi_netrw.txt /*netrw-contents* -netrw-cr pi_netrw.txt /*netrw-cr* -netrw-credits pi_netrw.txt /*netrw-credits* -netrw-ctrl-h pi_netrw.txt /*netrw-ctrl-h* -netrw-ctrl-l pi_netrw.txt /*netrw-ctrl-l* -netrw-ctrl_l pi_netrw.txt /*netrw-ctrl_l* -netrw-curdir pi_netrw.txt /*netrw-curdir* -netrw-d pi_netrw.txt /*netrw-d* -netrw-debug pi_netrw.txt /*netrw-debug* -netrw-del pi_netrw.txt /*netrw-del* -netrw-delete pi_netrw.txt /*netrw-delete* -netrw-dir pi_netrw.txt /*netrw-dir* -netrw-dirlist pi_netrw.txt /*netrw-dirlist* -netrw-downdir pi_netrw.txt /*netrw-downdir* -netrw-edithide pi_netrw.txt /*netrw-edithide* -netrw-ex pi_netrw.txt /*netrw-ex* -netrw-explore pi_netrw.txt /*netrw-explore* -netrw-explore-cmds pi_netrw.txt /*netrw-explore-cmds* -netrw-externapp pi_netrw.txt /*netrw-externapp* -netrw-file pi_netrw.txt /*netrw-file* -netrw-fixup pi_netrw.txt /*netrw-fixup* -netrw-ftp pi_netrw.txt /*netrw-ftp* -netrw-gb pi_netrw.txt /*netrw-gb* -netrw-gh pi_netrw.txt /*netrw-gh* -netrw-gx pi_netrw.txt /*netrw-gx* -netrw-handler pi_netrw.txt /*netrw-handler* -netrw-help pi_netrw.txt /*netrw-help* -netrw-hexplore pi_netrw.txt /*netrw-hexplore* -netrw-hide pi_netrw.txt /*netrw-hide* -netrw-hiding pi_netrw.txt /*netrw-hiding* -netrw-history pi_netrw.txt /*netrw-history* -netrw-horiz pi_netrw.txt /*netrw-horiz* -netrw-i pi_netrw.txt /*netrw-i* -netrw-incompatible pi_netrw.txt /*netrw-incompatible* -netrw-intro-browse pi_netrw.txt /*netrw-intro-browse* -netrw-list pi_netrw.txt /*netrw-list* -netrw-listbookmark pi_netrw.txt /*netrw-listbookmark* -netrw-listhack pi_netrw.txt /*netrw-listhack* -netrw-login pi_netrw.txt /*netrw-login* -netrw-mT pi_netrw.txt /*netrw-mT* -netrw-mb pi_netrw.txt /*netrw-mb* -netrw-mc pi_netrw.txt /*netrw-mc* -netrw-md pi_netrw.txt /*netrw-md* -netrw-me pi_netrw.txt /*netrw-me* -netrw-mf pi_netrw.txt /*netrw-mf* -netrw-mg pi_netrw.txt /*netrw-mg* -netrw-mh pi_netrw.txt /*netrw-mh* -netrw-ml_get pi_netrw.txt /*netrw-ml_get* -netrw-mm pi_netrw.txt /*netrw-mm* -netrw-move pi_netrw.txt /*netrw-move* -netrw-mp pi_netrw.txt /*netrw-mp* -netrw-mr pi_netrw.txt /*netrw-mr* -netrw-ms pi_netrw.txt /*netrw-ms* -netrw-mt pi_netrw.txt /*netrw-mt* -netrw-mu pi_netrw.txt /*netrw-mu* -netrw-mx pi_netrw.txt /*netrw-mx* -netrw-mz pi_netrw.txt /*netrw-mz* -netrw-netrc pi_netrw.txt /*netrw-netrc* -netrw-nexplore pi_netrw.txt /*netrw-nexplore* -netrw-nread pi_netrw.txt /*netrw-nread* -netrw-nwrite pi_netrw.txt /*netrw-nwrite* -netrw-o pi_netrw.txt /*netrw-o* -netrw-options pi_netrw.txt /*netrw-options* -netrw-p pi_netrw.txt /*netrw-p* -netrw-p1 pi_netrw.txt /*netrw-p1* -netrw-p10 pi_netrw.txt /*netrw-p10* -netrw-p11 pi_netrw.txt /*netrw-p11* -netrw-p2 pi_netrw.txt /*netrw-p2* -netrw-p3 pi_netrw.txt /*netrw-p3* -netrw-p4 pi_netrw.txt /*netrw-p4* -netrw-p5 pi_netrw.txt /*netrw-p5* -netrw-p6 pi_netrw.txt /*netrw-p6* -netrw-p7 pi_netrw.txt /*netrw-p7* -netrw-p8 pi_netrw.txt /*netrw-p8* -netrw-p9 pi_netrw.txt /*netrw-p9* -netrw-passwd pi_netrw.txt /*netrw-passwd* -netrw-password pi_netrw.txt /*netrw-password* -netrw-path pi_netrw.txt /*netrw-path* -netrw-pexplore pi_netrw.txt /*netrw-pexplore* -netrw-preview pi_netrw.txt /*netrw-preview* -netrw-problems pi_netrw.txt /*netrw-problems* -netrw-protocol pi_netrw.txt /*netrw-protocol* -netrw-prvwin pi_netrw.txt /*netrw-prvwin* -netrw-pscp pi_netrw.txt /*netrw-pscp* -netrw-psftp pi_netrw.txt /*netrw-psftp* -netrw-putty pi_netrw.txt /*netrw-putty* -netrw-qb pi_netrw.txt /*netrw-qb* -netrw-qf pi_netrw.txt /*netrw-qf* -netrw-quickcom pi_netrw.txt /*netrw-quickcom* -netrw-quickcoms pi_netrw.txt /*netrw-quickcoms* -netrw-quickhelp pi_netrw.txt /*netrw-quickhelp* -netrw-quickmap pi_netrw.txt /*netrw-quickmap* -netrw-quickmaps pi_netrw.txt /*netrw-quickmaps* -netrw-r pi_netrw.txt /*netrw-r* -netrw-read pi_netrw.txt /*netrw-read* -netrw-ref pi_netrw.txt /*netrw-ref* -netrw-rename pi_netrw.txt /*netrw-rename* -netrw-reverse pi_netrw.txt /*netrw-reverse* -netrw-rexplore pi_netrw.txt /*netrw-rexplore* -netrw-s pi_netrw.txt /*netrw-s* -netrw-settings pi_netrw.txt /*netrw-settings* -netrw-sexplore pi_netrw.txt /*netrw-sexplore* -netrw-sort pi_netrw.txt /*netrw-sort* -netrw-sortsequence pi_netrw.txt /*netrw-sortsequence* -netrw-source pi_netrw.txt /*netrw-source* -netrw-ssh-hack pi_netrw.txt /*netrw-ssh-hack* -netrw-star pi_netrw.txt /*netrw-star* -netrw-starpat pi_netrw.txt /*netrw-starpat* -netrw-starstar pi_netrw.txt /*netrw-starstar* -netrw-starstarpat pi_netrw.txt /*netrw-starstarpat* -netrw-start pi_netrw.txt /*netrw-start* -netrw-t pi_netrw.txt /*netrw-t* -netrw-texplore pi_netrw.txt /*netrw-texplore* -netrw-transparent pi_netrw.txt /*netrw-transparent* -netrw-u pi_netrw.txt /*netrw-u* -netrw-uidpass pi_netrw.txt /*netrw-uidpass* -netrw-updir pi_netrw.txt /*netrw-updir* -netrw-urls pi_netrw.txt /*netrw-urls* -netrw-userpass pi_netrw.txt /*netrw-userpass* -netrw-v pi_netrw.txt /*netrw-v* -netrw-var pi_netrw.txt /*netrw-var* -netrw-variables pi_netrw.txt /*netrw-variables* -netrw-vexplore pi_netrw.txt /*netrw-vexplore* -netrw-write pi_netrw.txt /*netrw-write* -netrw-x pi_netrw.txt /*netrw-x* -netrw-xfer pi_netrw.txt /*netrw-xfer* -netrw.vim pi_netrw.txt /*netrw.vim* -netrw_filehandler pi_netrw.txt /*netrw_filehandler* -netterm-mouse options.txt /*netterm-mouse* -network pi_netrw.txt /*network* -new-5 version5.txt /*new-5* -new-6 version6.txt /*new-6* -new-7 version7.txt /*new-7* -new-GTK-GUI version5.txt /*new-GTK-GUI* -new-MzScheme version7.txt /*new-MzScheme* -new-Select-mode version5.txt /*new-Select-mode* -new-View version6.txt /*new-View* -new-argument-list version6.txt /*new-argument-list* -new-buftype version6.txt /*new-buftype* -new-cmdwin version6.txt /*new-cmdwin* -new-color-schemes version6.txt /*new-color-schemes* -new-commands version5.txt /*new-commands* -new-commands-5.4 version5.txt /*new-commands-5.4* -new-debug-itf version6.txt /*new-debug-itf* -new-debug-mode version6.txt /*new-debug-mode* -new-debug-support version7.txt /*new-debug-support* -new-define-operator version7.txt /*new-define-operator* -new-diff-mode version6.txt /*new-diff-mode* -new-encryption version5.txt /*new-encryption* -new-evim version6.txt /*new-evim* -new-ex-commands-5.2 version5.txt /*new-ex-commands-5.2* -new-file-browser version6.txt /*new-file-browser* -new-file-writing version6.txt /*new-file-writing* -new-filetype filetype.txt /*new-filetype* -new-filetype-5.4 version5.txt /*new-filetype-5.4* -new-filetype-plugins version6.txt /*new-filetype-plugins* -new-filetype-scripts filetype.txt /*new-filetype-scripts* -new-folding version6.txt /*new-folding* -new-functions-5.2 version5.txt /*new-functions-5.2* -new-global-values version6.txt /*new-global-values* -new-highlighting version5.txt /*new-highlighting* -new-indent-flex version6.txt /*new-indent-flex* -new-items-6 version6.txt /*new-items-6* -new-items-7 version7.txt /*new-items-7* -new-line-continuation version5.txt /*new-line-continuation* -new-location-list version7.txt /*new-location-list* -new-manpage-trans version7.txt /*new-manpage-trans* -new-map-expression version7.txt /*new-map-expression* -new-map-select version7.txt /*new-map-select* -new-more-highlighting version7.txt /*new-more-highlighting* -new-more-unicode version7.txt /*new-more-unicode* -new-multi-byte version5.txt /*new-multi-byte* -new-multi-lang version6.txt /*new-multi-lang* -new-netrw-explore version7.txt /*new-netrw-explore* -new-network-files version6.txt /*new-network-files* -new-omni-completion version7.txt /*new-omni-completion* -new-onemore version7.txt /*new-onemore* -new-operator-mod version6.txt /*new-operator-mod* -new-options-5.2 version5.txt /*new-options-5.2* -new-options-5.4 version5.txt /*new-options-5.4* -new-perl-python version5.txt /*new-perl-python* -new-plugins version6.txt /*new-plugins* -new-posix version7.txt /*new-posix* -new-print-multi-byte version7.txt /*new-print-multi-byte* -new-printing version6.txt /*new-printing* -new-runtime-dir version5.txt /*new-runtime-dir* -new-script version5.txt /*new-script* -new-script-5.4 version5.txt /*new-script-5.4* -new-scroll-back version7.txt /*new-scroll-back* -new-search-path version6.txt /*new-search-path* -new-searchpat version6.txt /*new-searchpat* -new-session-files version5.txt /*new-session-files* -new-spell version7.txt /*new-spell* -new-tab-pages version7.txt /*new-tab-pages* -new-undo-branches version7.txt /*new-undo-branches* -new-unlisted-buffers version6.txt /*new-unlisted-buffers* -new-user-defined version5.txt /*new-user-defined* -new-user-manual version6.txt /*new-user-manual* -new-utf-8 version6.txt /*new-utf-8* -new-vertsplit version6.txt /*new-vertsplit* -new-vim-script version7.txt /*new-vim-script* -new-vim-server version6.txt /*new-vim-server* -new-vimgrep version7.txt /*new-vimgrep* -new-virtedit version6.txt /*new-virtedit* -news intro.txt /*news* -nextnonblank() eval.txt /*nextnonblank()* -nice todo.txt /*nice* -no-eval-feature eval.txt /*no-eval-feature* -no_buffers_menu gui.txt /*no_buffers_menu* -non-greedy pattern.txt /*non-greedy* -non-zero-arg eval.txt /*non-zero-arg* -normal-index index.txt /*normal-index* -not-compatible usr_01.txt /*not-compatible* -not-edited editing.txt /*not-edited* -notation intro.txt /*notation* -notepad gui_w32.txt /*notepad* -nr2char() eval.txt /*nr2char()* -nroff.vim syntax.txt /*nroff.vim* -numbered-function eval.txt /*numbered-function* -o insert.txt /*o* -o_CTRL-V motion.txt /*o_CTRL-V* -o_V motion.txt /*o_V* -o_v motion.txt /*o_v* -object-motions motion.txt /*object-motions* -object-select motion.txt /*object-select* -objects index.txt /*objects* -obtaining-exted netbeans.txt /*obtaining-exted* -ocaml.vim syntax.txt /*ocaml.vim* -ole-activation if_ole.txt /*ole-activation* -ole-eval if_ole.txt /*ole-eval* -ole-gethwnd if_ole.txt /*ole-gethwnd* -ole-interface if_ole.txt /*ole-interface* -ole-methods if_ole.txt /*ole-methods* -ole-normal if_ole.txt /*ole-normal* -ole-registration if_ole.txt /*ole-registration* -ole-sendkeys if_ole.txt /*ole-sendkeys* -ole-setforeground if_ole.txt /*ole-setforeground* -omap-info map.txt /*omap-info* -omni-sql-completion ft_sql.txt /*omni-sql-completion* -online-help various.txt /*online-help* -opening-window windows.txt /*opening-window* -operator motion.txt /*operator* -operator-variable eval.txt /*operator-variable* -option-backslash options.txt /*option-backslash* -option-list quickref.txt /*option-list* -option-summary options.txt /*option-summary* -options options.txt /*options* -options-changed version5.txt /*options-changed* -options.txt options.txt /*options.txt* -oracle ft_sql.txt /*oracle* -os2 os_os2.txt /*os2* -os2ansi os_os2.txt /*os2ansi* -os390 os_390.txt /*os390* -os_390.txt os_390.txt /*os_390.txt* -os_amiga.txt os_amiga.txt /*os_amiga.txt* -os_beos.txt os_beos.txt /*os_beos.txt* -os_dos.txt os_dos.txt /*os_dos.txt* -os_mac.txt os_mac.txt /*os_mac.txt* -os_mint.txt os_mint.txt /*os_mint.txt* -os_msdos.txt os_msdos.txt /*os_msdos.txt* -os_os2.txt os_os2.txt /*os_os2.txt* -os_qnx.txt os_qnx.txt /*os_qnx.txt* -os_risc.txt os_risc.txt /*os_risc.txt* -os_unix.txt os_unix.txt /*os_unix.txt* -os_vms.txt os_vms.txt /*os_vms.txt* -os_win32.txt os_win32.txt /*os_win32.txt* -other-features vi_diff.txt /*other-features* -p change.txt /*p* -page-down intro.txt /*page-down* -page-up intro.txt /*page-up* -page_down intro.txt /*page_down* -page_up intro.txt /*page_up* -pager message.txt /*pager* -papp.vim syntax.txt /*papp.vim* -paragraph motion.txt /*paragraph* -pascal.vim syntax.txt /*pascal.vim* -pathshorten() eval.txt /*pathshorten()* -pattern pattern.txt /*pattern* -pattern-atoms pattern.txt /*pattern-atoms* -pattern-multi-byte pattern.txt /*pattern-multi-byte* -pattern-multi-items pattern.txt /*pattern-multi-items* -pattern-overview pattern.txt /*pattern-overview* -pattern-searches pattern.txt /*pattern-searches* -pattern.txt pattern.txt /*pattern.txt* -patterns-composing pattern.txt /*patterns-composing* -pdev-option print.txt /*pdev-option* -penc-option print.txt /*penc-option* -perl if_perl.txt /*perl* -perl-Append if_perl.txt /*perl-Append* -perl-Buffer if_perl.txt /*perl-Buffer* -perl-Buffers if_perl.txt /*perl-Buffers* -perl-Count if_perl.txt /*perl-Count* -perl-Delete if_perl.txt /*perl-Delete* -perl-DoCommand if_perl.txt /*perl-DoCommand* -perl-Eval if_perl.txt /*perl-Eval* -perl-Get if_perl.txt /*perl-Get* -perl-GetCursor if_perl.txt /*perl-GetCursor* -perl-Msg if_perl.txt /*perl-Msg* -perl-Name if_perl.txt /*perl-Name* -perl-Number if_perl.txt /*perl-Number* -perl-Set if_perl.txt /*perl-Set* -perl-SetHeight if_perl.txt /*perl-SetHeight* -perl-SetOption if_perl.txt /*perl-SetOption* -perl-Windows if_perl.txt /*perl-Windows* -perl-compiling if_perl.txt /*perl-compiling* -perl-dynamic if_perl.txt /*perl-dynamic* -perl-editing if_perl.txt /*perl-editing* -perl-overview if_perl.txt /*perl-overview* -perl-patterns pattern.txt /*perl-patterns* -perl-using if_perl.txt /*perl-using* -perl.vim syntax.txt /*perl.vim* -pexpr-option print.txt /*pexpr-option* -pfn-option print.txt /*pfn-option* -pheader-option print.txt /*pheader-option* -photon-fonts os_qnx.txt /*photon-fonts* -photon-gui os_qnx.txt /*photon-gui* -php-comment indent.txt /*php-comment* -php-indent indent.txt /*php-indent* -php-indenting indent.txt /*php-indenting* -php.vim syntax.txt /*php.vim* -php3.vim syntax.txt /*php3.vim* -phtml.vim syntax.txt /*phtml.vim* -pi_getscript.txt pi_getscript.txt /*pi_getscript.txt* -pi_gzip.txt pi_gzip.txt /*pi_gzip.txt* -pi_netrw.txt pi_netrw.txt /*pi_netrw.txt* -pi_paren.txt pi_paren.txt /*pi_paren.txt* -pi_spec.txt pi_spec.txt /*pi_spec.txt* -pi_tar.txt pi_tar.txt /*pi_tar.txt* -pi_vimball.txt pi_vimball.txt /*pi_vimball.txt* -pi_zip.txt pi_zip.txt /*pi_zip.txt* -plaintex.vim syntax.txt /*plaintex.vim* -plsql ft_sql.txt /*plsql* -plugin usr_05.txt /*plugin* -plugin-details filetype.txt /*plugin-details* -plugin-filetype usr_41.txt /*plugin-filetype* -plugin-special usr_41.txt /*plugin-special* -pmbcs-option print.txt /*pmbcs-option* -pmbfn-option print.txt /*pmbfn-option* -popt-option print.txt /*popt-option* -popup-menu gui.txt /*popup-menu* -popup-menu-added version5.txt /*popup-menu-added* -popupmenu-completion insert.txt /*popupmenu-completion* -popupmenu-keys insert.txt /*popupmenu-keys* -ports-5.2 version5.txt /*ports-5.2* -ports-6 version6.txt /*ports-6* -posix vi_diff.txt /*posix* -posix-compliance vi_diff.txt /*posix-compliance* -posix-screen-size vi_diff.txt /*posix-screen-size* -postgres ft_sql.txt /*postgres* -postscr.vim syntax.txt /*postscr.vim* -postscript-cjk-printing print.txt /*postscript-cjk-printing* -postscript-print-encoding print.txt /*postscript-print-encoding* -postscript-print-trouble print.txt /*postscript-print-trouble* -postscript-print-util print.txt /*postscript-print-util* -postscript-printing print.txt /*postscript-printing* -pow() eval.txt /*pow()* -ppwiz.vim syntax.txt /*ppwiz.vim* -press-enter message.txt /*press-enter* -press-return message.txt /*press-return* -prevcount-variable eval.txt /*prevcount-variable* -preview-window windows.txt /*preview-window* -prevnonblank() eval.txt /*prevnonblank()* -print-intro print.txt /*print-intro* -print-options print.txt /*print-options* -print.txt print.txt /*print.txt* -printf() eval.txt /*printf()* -printf-% eval.txt /*printf-%* -printf-E eval.txt /*printf-E* -printf-G eval.txt /*printf-G* -printf-X eval.txt /*printf-X* -printf-c eval.txt /*printf-c* -printf-d eval.txt /*printf-d* -printf-e eval.txt /*printf-e* -printf-f eval.txt /*printf-f* -printf-g eval.txt /*printf-g* -printf-o eval.txt /*printf-o* -printf-s eval.txt /*printf-s* -printf-x eval.txt /*printf-x* -printing print.txt /*printing* -printing-formfeed print.txt /*printing-formfeed* -profile repeat.txt /*profile* -profiling repeat.txt /*profiling* -profiling-variable eval.txt /*profiling-variable* -progname-variable eval.txt /*progname-variable* -progress.vim syntax.txt /*progress.vim* -psql ft_sql.txt /*psql* -ptcap.vim syntax.txt /*ptcap.vim* -pterm-mouse options.txt /*pterm-mouse* -pumvisible() eval.txt /*pumvisible()* -put change.txt /*put* -put-Visual-mode change.txt /*put-Visual-mode* -python if_pyth.txt /*python* -python-buffer if_pyth.txt /*python-buffer* -python-buffers if_pyth.txt /*python-buffers* -python-command if_pyth.txt /*python-command* -python-commands if_pyth.txt /*python-commands* -python-current if_pyth.txt /*python-current* -python-dynamic if_pyth.txt /*python-dynamic* -python-error if_pyth.txt /*python-error* -python-eval if_pyth.txt /*python-eval* -python-examples if_pyth.txt /*python-examples* -python-input if_pyth.txt /*python-input* -python-output if_pyth.txt /*python-output* -python-range if_pyth.txt /*python-range* -python-vim if_pyth.txt /*python-vim* -python-window if_pyth.txt /*python-window* -python-windows if_pyth.txt /*python-windows* -python.vim syntax.txt /*python.vim* -q repeat.txt /*q* -q/ cmdline.txt /*q\/* -q: cmdline.txt /*q:* -q? cmdline.txt /*q?* -qnx os_qnx.txt /*qnx* -qnx-compiling os_qnx.txt /*qnx-compiling* -qnx-general os_qnx.txt /*qnx-general* -qnx-terminal os_qnx.txt /*qnx-terminal* -quake.vim syntax.txt /*quake.vim* -quickfix quickfix.txt /*quickfix* -quickfix-6 version6.txt /*quickfix-6* -quickfix-directory-stack quickfix.txt /*quickfix-directory-stack* -quickfix-error-lists quickfix.txt /*quickfix-error-lists* -quickfix-gcc quickfix.txt /*quickfix-gcc* -quickfix-manx quickfix.txt /*quickfix-manx* -quickfix-perl quickfix.txt /*quickfix-perl* -quickfix-valid quickfix.txt /*quickfix-valid* -quickfix-window quickfix.txt /*quickfix-window* -quickfix.txt quickfix.txt /*quickfix.txt* -quickref quickref.txt /*quickref* -quickref.txt quickref.txt /*quickref.txt* -quote change.txt /*quote* -quote# change.txt /*quote#* -quote% change.txt /*quote%* -quote+ gui_x11.txt /*quote+* -quote- change.txt /*quote-* -quote. change.txt /*quote.* -quote/ change.txt /*quote\/* -quote0 change.txt /*quote0* -quote1 change.txt /*quote1* -quote2 change.txt /*quote2* -quote3 change.txt /*quote3* -quote4 change.txt /*quote4* -quote9 change.txt /*quote9* -quote: change.txt /*quote:* -quote= change.txt /*quote=* -quote_ change.txt /*quote_* -quote_# change.txt /*quote_#* -quote_% change.txt /*quote_%* -quote_- change.txt /*quote_-* -quote_. change.txt /*quote_.* -quote_/ change.txt /*quote_\/* -quote_: change.txt /*quote_:* -quote_= change.txt /*quote_=* -quote_alpha change.txt /*quote_alpha* -quote_number change.txt /*quote_number* -quote_quote change.txt /*quote_quote* -quote_~ change.txt /*quote_~* -quotea change.txt /*quotea* -quotecommandquote intro.txt /*quotecommandquote* -quoteplus gui_x11.txt /*quoteplus* -quotequote change.txt /*quotequote* -quotes quotes.txt /*quotes* -quotes.txt quotes.txt /*quotes.txt* -quotestar gui.txt /*quotestar* -quote~ change.txt /*quote~* -r change.txt /*r* -range() eval.txt /*range()* -raw-terminal-mode term.txt /*raw-terminal-mode* -rcp pi_netrw.txt /*rcp* -read-messages insert.txt /*read-messages* -read-only-share editing.txt /*read-only-share* -read-stdin version5.txt /*read-stdin* -readfile() eval.txt /*readfile()* -readline.vim syntax.txt /*readline.vim* -recording repeat.txt /*recording* -recover.txt recover.txt /*recover.txt* -recovery recover.txt /*recovery* -recursive_mapping map.txt /*recursive_mapping* -redo undo.txt /*redo* -redo-register undo.txt /*redo-register* -ref intro.txt /*ref* -reference intro.txt /*reference* -reference_toc help.txt /*reference_toc* -regexp pattern.txt /*regexp* -regexp-changes-5.4 version5.txt /*regexp-changes-5.4* -register sponsor.txt /*register* -register-faq sponsor.txt /*register-faq* -register-variable eval.txt /*register-variable* -registers change.txt /*registers* -regular-expression pattern.txt /*regular-expression* -reltime() eval.txt /*reltime()* -reltimestr() eval.txt /*reltimestr()* -remote.txt remote.txt /*remote.txt* -remote_expr() eval.txt /*remote_expr()* -remote_foreground() eval.txt /*remote_foreground()* -remote_peek() eval.txt /*remote_peek()* -remote_read() eval.txt /*remote_read()* -remote_send() eval.txt /*remote_send()* -remove() eval.txt /*remove()* -remove-filetype filetype.txt /*remove-filetype* -remove-option-flags options.txt /*remove-option-flags* -rename() eval.txt /*rename()* -rename-files tips.txt /*rename-files* -repeat() eval.txt /*repeat()* -repeat.txt repeat.txt /*repeat.txt* -repeating repeat.txt /*repeating* -replacing change.txt /*replacing* -replacing-ex insert.txt /*replacing-ex* -reselect-Visual visual.txt /*reselect-Visual* -resolve() eval.txt /*resolve()* -restore-cursor usr_05.txt /*restore-cursor* -restore-position tips.txt /*restore-position* -restricted-mode starting.txt /*restricted-mode* -retab-example change.txt /*retab-example* -rethrow eval.txt /*rethrow* -reverse() eval.txt /*reverse()* -rexx.vim syntax.txt /*rexx.vim* -rgb.txt gui_w32.txt /*rgb.txt* -rgview starting.txt /*rgview* -rgvim starting.txt /*rgvim* -right-justify change.txt /*right-justify* -rileft rileft.txt /*rileft* -rileft.txt rileft.txt /*rileft.txt* -riscos os_risc.txt /*riscos* -riscos-commandline os_risc.txt /*riscos-commandline* -riscos-filetypes os_risc.txt /*riscos-filetypes* -riscos-gui os_risc.txt /*riscos-gui* -riscos-interrupt os_risc.txt /*riscos-interrupt* -riscos-locations os_risc.txt /*riscos-locations* -riscos-memory os_risc.txt /*riscos-memory* -riscos-munging os_risc.txt /*riscos-munging* -riscos-porting os_risc.txt /*riscos-porting* -riscos-remote os_risc.txt /*riscos-remote* -riscos-shell os_risc.txt /*riscos-shell* -riscos-temp-files os_risc.txt /*riscos-temp-files* -rot13 change.txt /*rot13* -round() eval.txt /*round()* -rsync pi_netrw.txt /*rsync* -ruby if_ruby.txt /*ruby* -ruby-buffer if_ruby.txt /*ruby-buffer* -ruby-command if_ruby.txt /*ruby-command* -ruby-commands if_ruby.txt /*ruby-commands* -ruby-dynamic if_ruby.txt /*ruby-dynamic* -ruby-evaluate if_ruby.txt /*ruby-evaluate* -ruby-globals if_ruby.txt /*ruby-globals* -ruby-message if_ruby.txt /*ruby-message* -ruby-set_option if_ruby.txt /*ruby-set_option* -ruby-vim if_ruby.txt /*ruby-vim* -ruby-window if_ruby.txt /*ruby-window* -ruby.vim syntax.txt /*ruby.vim* -russian russian.txt /*russian* -russian-intro russian.txt /*russian-intro* -russian-issues russian.txt /*russian-issues* -russian-keymap russian.txt /*russian-keymap* -russian-l18n russian.txt /*russian-l18n* -russian.txt russian.txt /*russian.txt* -rview starting.txt /*rview* -rvim starting.txt /*rvim* -rxvt syntax.txt /*rxvt* -s change.txt /*s* -s/\& change.txt /*s\/\\&* -s/\0 change.txt /*s\/\\0* -s/\1 change.txt /*s\/\\1* -s/\2 change.txt /*s\/\\2* -s/\3 change.txt /*s\/\\3* -s/\9 change.txt /*s\/\\9* -s/\<CR> change.txt /*s\/\\<CR>* -s/\E change.txt /*s\/\\E* -s/\L change.txt /*s\/\\L* -s/\U change.txt /*s\/\\U* -s/\\ change.txt /*s\/\\\\* -s/\b change.txt /*s\/\\b* -s/\e change.txt /*s\/\\e* -s/\l change.txt /*s\/\\l* -s/\n change.txt /*s\/\\n* -s/\r change.txt /*s\/\\r* -s/\t change.txt /*s\/\\t* -s/\u change.txt /*s\/\\u* -s/\~ change.txt /*s\/\\~* -s:netrw_passwd pi_netrw.txt /*s:netrw_passwd* -s:var eval.txt /*s:var* -s<CR> change.txt /*s<CR>* -sandbox eval.txt /*sandbox* -sandbox-option eval.txt /*sandbox-option* -save-file editing.txt /*save-file* -save-settings starting.txt /*save-settings* -scheme.vim syntax.txt /*scheme.vim* -scp pi_netrw.txt /*scp* -script usr_41.txt /*script* -script-here if_perl.txt /*script-here* -script-local map.txt /*script-local* -script-variable eval.txt /*script-variable* -scriptnames-dictionary eval.txt /*scriptnames-dictionary* -scriptout-changed version4.txt /*scriptout-changed* -scroll-binding scroll.txt /*scroll-binding* -scroll-cursor scroll.txt /*scroll-cursor* -scroll-down scroll.txt /*scroll-down* -scroll-horizontal scroll.txt /*scroll-horizontal* -scroll-insert tips.txt /*scroll-insert* -scroll-mouse-wheel scroll.txt /*scroll-mouse-wheel* -scroll-region term.txt /*scroll-region* -scroll-smooth tips.txt /*scroll-smooth* -scroll-up scroll.txt /*scroll-up* -scroll.txt scroll.txt /*scroll.txt* -scrollbind-quickadj scroll.txt /*scrollbind-quickadj* -scrollbind-relative scroll.txt /*scrollbind-relative* -scrolling scroll.txt /*scrolling* -scrollstart-variable eval.txt /*scrollstart-variable* -sdl.vim syntax.txt /*sdl.vim* -search() eval.txt /*search()* -search()-sub-match eval.txt /*search()-sub-match* -search-commands pattern.txt /*search-commands* -search-offset pattern.txt /*search-offset* -search-pattern pattern.txt /*search-pattern* -search-range pattern.txt /*search-range* -search-replace change.txt /*search-replace* -searchdecl() eval.txt /*searchdecl()* -searchforward-variable eval.txt /*searchforward-variable* -searchpair() eval.txt /*searchpair()* -searchpairpos() eval.txt /*searchpairpos()* -searchpos() eval.txt /*searchpos()* -section motion.txt /*section* -sed.vim syntax.txt /*sed.vim* -self eval.txt /*self* -send-money sponsor.txt /*send-money* -send-to-menu gui_w32.txt /*send-to-menu* -sendto gui_w32.txt /*sendto* -sentence motion.txt /*sentence* -server2client() eval.txt /*server2client()* -serverlist() eval.txt /*serverlist()* -servername-variable eval.txt /*servername-variable* -session-file starting.txt /*session-file* -set-option options.txt /*set-option* -set-spc-auto spell.txt /*set-spc-auto* -setbufvar() eval.txt /*setbufvar()* -setcmdpos() eval.txt /*setcmdpos()* -setline() eval.txt /*setline()* -setloclist() eval.txt /*setloclist()* -setmatches() eval.txt /*setmatches()* -setpos() eval.txt /*setpos()* -setqflist() eval.txt /*setqflist()* -setreg() eval.txt /*setreg()* -settabwinvar() eval.txt /*settabwinvar()* -setting-guifont gui.txt /*setting-guifont* -setting-guitablabel tabpage.txt /*setting-guitablabel* -setting-tabline tabpage.txt /*setting-tabline* -setwinvar() eval.txt /*setwinvar()* -sftp pi_netrw.txt /*sftp* -sgml.vim syntax.txt /*sgml.vim* -sh.vim syntax.txt /*sh.vim* -shell-window tips.txt /*shell-window* -shell_error-variable eval.txt /*shell_error-variable* -shellescape() eval.txt /*shellescape()* -shift intro.txt /*shift* -shift-left-right change.txt /*shift-left-right* -short-name-changed version4.txt /*short-name-changed* -showing-menus gui.txt /*showing-menus* -sign-commands sign.txt /*sign-commands* -sign-intro sign.txt /*sign-intro* -sign-support sign.txt /*sign-support* -sign.txt sign.txt /*sign.txt* -signs sign.txt /*signs* -simple-change change.txt /*simple-change* -simplify() eval.txt /*simplify()* -simulated-command vi_diff.txt /*simulated-command* -sin() eval.txt /*sin()* -single-repeat repeat.txt /*single-repeat* -skeleton autocmd.txt /*skeleton* -slow-fast-terminal term.txt /*slow-fast-terminal* -slow-start starting.txt /*slow-start* -slow-terminal term.txt /*slow-terminal* -sniff if_sniff.txt /*sniff* -sniff-commands if_sniff.txt /*sniff-commands* -sniff-compiling if_sniff.txt /*sniff-compiling* -sniff-intro if_sniff.txt /*sniff-intro* -socket-interface netbeans.txt /*socket-interface* -sort() eval.txt /*sort()* -sorting change.txt /*sorting* -soundfold() eval.txt /*soundfold()* -space intro.txt /*space* -spec-customizing pi_spec.txt /*spec-customizing* -spec-how-to-use-it pi_spec.txt /*spec-how-to-use-it* -spec-setting-a-map pi_spec.txt /*spec-setting-a-map* -spec_chglog_format pi_spec.txt /*spec_chglog_format* -spec_chglog_prepend pi_spec.txt /*spec_chglog_prepend* -spec_chglog_release_info pi_spec.txt /*spec_chglog_release_info* -special-buffers windows.txt /*special-buffers* -speed-up tips.txt /*speed-up* -spell spell.txt /*spell* -spell-ACCENT spell.txt /*spell-ACCENT* -spell-AUTHOR spell.txt /*spell-AUTHOR* -spell-BAD spell.txt /*spell-BAD* -spell-CHECKCOMPOUNDCASE spell.txt /*spell-CHECKCOMPOUNDCASE* -spell-CHECKCOMPOUNDDUP spell.txt /*spell-CHECKCOMPOUNDDUP* -spell-CHECKCOMPOUNDPATTERN spell.txt /*spell-CHECKCOMPOUNDPATTERN* -spell-CHECKCOMPOUNDREP spell.txt /*spell-CHECKCOMPOUNDREP* -spell-CHECKCOMPOUNDTRIPLE spell.txt /*spell-CHECKCOMPOUNDTRIPLE* -spell-CIRCUMFIX spell.txt /*spell-CIRCUMFIX* -spell-COMMON spell.txt /*spell-COMMON* -spell-COMPLEXPREFIXES spell.txt /*spell-COMPLEXPREFIXES* -spell-COMPOUND spell.txt /*spell-COMPOUND* -spell-COMPOUNDBEGIN spell.txt /*spell-COMPOUNDBEGIN* -spell-COMPOUNDEND spell.txt /*spell-COMPOUNDEND* -spell-COMPOUNDFIRST spell.txt /*spell-COMPOUNDFIRST* -spell-COMPOUNDFLAG spell.txt /*spell-COMPOUNDFLAG* -spell-COMPOUNDFORBIDFLAG spell.txt /*spell-COMPOUNDFORBIDFLAG* -spell-COMPOUNDMIDDLE spell.txt /*spell-COMPOUNDMIDDLE* -spell-COMPOUNDMIN spell.txt /*spell-COMPOUNDMIN* -spell-COMPOUNDPERMITFLAG spell.txt /*spell-COMPOUNDPERMITFLAG* -spell-COMPOUNDROOT spell.txt /*spell-COMPOUNDROOT* -spell-COMPOUNDRULE spell.txt /*spell-COMPOUNDRULE* -spell-COMPOUNDSYLLABLE spell.txt /*spell-COMPOUNDSYLLABLE* -spell-COMPOUNDSYLMAX spell.txt /*spell-COMPOUNDSYLMAX* -spell-COMPOUNDWORDMAX spell.txt /*spell-COMPOUNDWORDMAX* -spell-COPYRIGHT spell.txt /*spell-COPYRIGHT* -spell-EMAIL spell.txt /*spell-EMAIL* -spell-FLAG spell.txt /*spell-FLAG* -spell-FOL spell.txt /*spell-FOL* -spell-FORBIDDENWORD spell.txt /*spell-FORBIDDENWORD* -spell-HOME spell.txt /*spell-HOME* -spell-KEEPCASE spell.txt /*spell-KEEPCASE* -spell-LANG spell.txt /*spell-LANG* -spell-LEMMA_PRESENT spell.txt /*spell-LEMMA_PRESENT* -spell-LOW spell.txt /*spell-LOW* -spell-MAP spell.txt /*spell-MAP* -spell-MAXNGRAMSUGS spell.txt /*spell-MAXNGRAMSUGS* -spell-NAME spell.txt /*spell-NAME* -spell-NEEDAFFIX spell.txt /*spell-NEEDAFFIX* -spell-NEEDCOMPOUND spell.txt /*spell-NEEDCOMPOUND* -spell-NOBREAK spell.txt /*spell-NOBREAK* -spell-NOSPLITSUGS spell.txt /*spell-NOSPLITSUGS* -spell-NOSUGFILE spell.txt /*spell-NOSUGFILE* -spell-NOSUGGEST spell.txt /*spell-NOSUGGEST* -spell-ONLYINCOMPOUND spell.txt /*spell-ONLYINCOMPOUND* -spell-PFX spell.txt /*spell-PFX* -spell-PFXPOSTPONE spell.txt /*spell-PFXPOSTPONE* -spell-PSEUDOROOT spell.txt /*spell-PSEUDOROOT* -spell-RARE spell.txt /*spell-RARE* -spell-REP spell.txt /*spell-REP* -spell-SAL spell.txt /*spell-SAL* -spell-SET spell.txt /*spell-SET* -spell-SFX spell.txt /*spell-SFX* -spell-SLASH spell.txt /*spell-SLASH* -spell-SOFOFROM spell.txt /*spell-SOFOFROM* -spell-SOFOTO spell.txt /*spell-SOFOTO* -spell-SUGSWITHDOTS spell.txt /*spell-SUGSWITHDOTS* -spell-SYLLABLE spell.txt /*spell-SYLLABLE* -spell-SYLLABLENUM spell.txt /*spell-SYLLABLENUM* -spell-SpellFileMissing spell.txt /*spell-SpellFileMissing* -spell-TRY spell.txt /*spell-TRY* -spell-UPP spell.txt /*spell-UPP* -spell-VERSION spell.txt /*spell-VERSION* -spell-WORDCHARS spell.txt /*spell-WORDCHARS* -spell-aff-format spell.txt /*spell-aff-format* -spell-affix-chars spell.txt /*spell-affix-chars* -spell-affix-comment spell.txt /*spell-affix-comment* -spell-affix-flags spell.txt /*spell-affix-flags* -spell-affix-mbyte spell.txt /*spell-affix-mbyte* -spell-affix-not-supported spell.txt /*spell-affix-not-supported* -spell-affix-vim spell.txt /*spell-affix-vim* -spell-compound spell.txt /*spell-compound* -spell-dic-format spell.txt /*spell-dic-format* -spell-double-scoring spell.txt /*spell-double-scoring* -spell-file-format spell.txt /*spell-file-format* -spell-german spell.txt /*spell-german* -spell-load spell.txt /*spell-load* -spell-midword spell.txt /*spell-midword* -spell-mkspell spell.txt /*spell-mkspell* -spell-quickstart spell.txt /*spell-quickstart* -spell-remarks spell.txt /*spell-remarks* -spell-russian spell.txt /*spell-russian* -spell-sug-file spell.txt /*spell-sug-file* -spell-syntax spell.txt /*spell-syntax* -spell-wordlist-format spell.txt /*spell-wordlist-format* -spell-yiddish spell.txt /*spell-yiddish* -spell.txt spell.txt /*spell.txt* -spellbadword() eval.txt /*spellbadword()* -spellfile-cleanup spell.txt /*spellfile-cleanup* -spellfile.vim spell.txt /*spellfile.vim* -spellsuggest() eval.txt /*spellsuggest()* -split() eval.txt /*split()* -splitfind windows.txt /*splitfind* -splitview windows.txt /*splitview* -sponsor sponsor.txt /*sponsor* -sponsor-faq sponsor.txt /*sponsor-faq* -sponsor.txt sponsor.txt /*sponsor.txt* -spoon os_unix.txt /*spoon* -spup.vim syntax.txt /*spup.vim* -sql-adding-dialects ft_sql.txt /*sql-adding-dialects* -sql-completion ft_sql.txt /*sql-completion* -sql-completion-columns ft_sql.txt /*sql-completion-columns* -sql-completion-customization ft_sql.txt /*sql-completion-customization* -sql-completion-dynamic ft_sql.txt /*sql-completion-dynamic* -sql-completion-filetypes ft_sql.txt /*sql-completion-filetypes* -sql-completion-maps ft_sql.txt /*sql-completion-maps* -sql-completion-procedures ft_sql.txt /*sql-completion-procedures* -sql-completion-static ft_sql.txt /*sql-completion-static* -sql-completion-tables ft_sql.txt /*sql-completion-tables* -sql-completion-tutorial ft_sql.txt /*sql-completion-tutorial* -sql-completion-views ft_sql.txt /*sql-completion-views* -sql-dialects ft_sql.txt /*sql-dialects* -sql-macros ft_sql.txt /*sql-macros* -sql-matchit ft_sql.txt /*sql-matchit* -sql-navigation ft_sql.txt /*sql-navigation* -sql-object-motions ft_sql.txt /*sql-object-motions* -sql-predefined-objects ft_sql.txt /*sql-predefined-objects* -sql-type-default ft_sql.txt /*sql-type-default* -sql-types ft_sql.txt /*sql-types* -sql.vim syntax.txt /*sql.vim* -sqlanywhere ft_sql.txt /*sqlanywhere* -sqlanywhere.vim syntax.txt /*sqlanywhere.vim* -sqlinformix.vim syntax.txt /*sqlinformix.vim* -sqlj ft_sql.txt /*sqlj* -sqlserver ft_sql.txt /*sqlserver* -sqlsettype ft_sql.txt /*sqlsettype* -sqrt() eval.txt /*sqrt()* -sscanf eval.txt /*sscanf* -standard-plugin usr_05.txt /*standard-plugin* -standard-plugin-list help.txt /*standard-plugin-list* -standout syntax.txt /*standout* -star pattern.txt /*star* -starstar editing.txt /*starstar* -starstar-wildcard editing.txt /*starstar-wildcard* -start-of-file pattern.txt /*start-of-file* -starting starting.txt /*starting* -starting-amiga starting.txt /*starting-amiga* -starting.txt starting.txt /*starting.txt* -startup starting.txt /*startup* -startup-options starting.txt /*startup-options* -startup-terminal term.txt /*startup-terminal* -static-tag tagsrch.txt /*static-tag* -status-line windows.txt /*status-line* -statusmsg-variable eval.txt /*statusmsg-variable* -sticky-type-checking eval.txt /*sticky-type-checking* -str2float() eval.txt /*str2float()* -str2nr() eval.txt /*str2nr()* -strcasestr() eval.txt /*strcasestr()* -strchr() eval.txt /*strchr()* -strcspn() eval.txt /*strcspn()* -strftime() eval.txt /*strftime()* -stridx() eval.txt /*stridx()* -string() eval.txt /*string()* -string-match eval.txt /*string-match* -strlen() eval.txt /*strlen()* -strpart() eval.txt /*strpart()* -strpbrk() eval.txt /*strpbrk()* -strrchr() eval.txt /*strrchr()* -strridx() eval.txt /*strridx()* -strspn() eval.txt /*strspn()* -strstr() eval.txt /*strstr()* -strtrans() eval.txt /*strtrans()* -style-changes develop.txt /*style-changes* -style-examples develop.txt /*style-examples* -style-functions develop.txt /*style-functions* -style-names develop.txt /*style-names* -style-spaces develop.txt /*style-spaces* -style-various develop.txt /*style-various* -sub-menu-priority gui.txt /*sub-menu-priority* -sub-replace-\= change.txt /*sub-replace-\\=* -sub-replace-expression change.txt /*sub-replace-expression* -sub-replace-special change.txt /*sub-replace-special* -submatch() eval.txt /*submatch()* -subscribe-maillist intro.txt /*subscribe-maillist* -substitute() eval.txt /*substitute()* -substitute-CR version6.txt /*substitute-CR* -suffixes cmdline.txt /*suffixes* -suspend starting.txt /*suspend* -swap-file recover.txt /*swap-file* -swapchoice-variable eval.txt /*swapchoice-variable* -swapcommand-variable eval.txt /*swapcommand-variable* -swapfile-changed version4.txt /*swapfile-changed* -swapname-variable eval.txt /*swapname-variable* -sybase ft_sql.txt /*sybase* -syn-sync-grouphere syntax.txt /*syn-sync-grouphere* -syn-sync-groupthere syntax.txt /*syn-sync-groupthere* -syn-sync-linecont syntax.txt /*syn-sync-linecont* -synID() eval.txt /*synID()* -synIDattr() eval.txt /*synIDattr()* -synIDtrans() eval.txt /*synIDtrans()* -syncbind scroll.txt /*syncbind* -syncolor syntax.txt /*syncolor* -synload-1 syntax.txt /*synload-1* -synload-2 syntax.txt /*synload-2* -synload-3 syntax.txt /*synload-3* -synload-4 syntax.txt /*synload-4* -synload-5 syntax.txt /*synload-5* -synload-6 syntax.txt /*synload-6* -synstack() eval.txt /*synstack()* -syntax syntax.txt /*syntax* -syntax-highlighting syntax.txt /*syntax-highlighting* -syntax-loading syntax.txt /*syntax-loading* -syntax-printing usr_06.txt /*syntax-printing* -syntax.txt syntax.txt /*syntax.txt* -syntax_cmd syntax.txt /*syntax_cmd* -sys-file-list help.txt /*sys-file-list* -sysmouse term.txt /*sysmouse* -system() eval.txt /*system()* -system-vimrc starting.txt /*system-vimrc* -s~ change.txt /*s~* -t motion.txt /*t* -t:var eval.txt /*t:var* -t_#2 term.txt /*t_#2* -t_#4 term.txt /*t_#4* -t_%1 term.txt /*t_%1* -t_%i term.txt /*t_%i* -t_&8 term.txt /*t_&8* -t_@7 term.txt /*t_@7* -t_AB term.txt /*t_AB* -t_AF term.txt /*t_AF* -t_AL term.txt /*t_AL* -t_CS term.txt /*t_CS* -t_CV term.txt /*t_CV* -t_Ce term.txt /*t_Ce* -t_Co term.txt /*t_Co* -t_Cs term.txt /*t_Cs* -t_DL term.txt /*t_DL* -t_EI term.txt /*t_EI* -t_F1 term.txt /*t_F1* -t_F2 term.txt /*t_F2* -t_F3 term.txt /*t_F3* -t_F4 term.txt /*t_F4* -t_F5 term.txt /*t_F5* -t_F6 term.txt /*t_F6* -t_F7 term.txt /*t_F7* -t_F8 term.txt /*t_F8* -t_F9 term.txt /*t_F9* -t_IE term.txt /*t_IE* -t_IS term.txt /*t_IS* -t_K1 term.txt /*t_K1* -t_K3 term.txt /*t_K3* -t_K4 term.txt /*t_K4* -t_K5 term.txt /*t_K5* -t_K6 term.txt /*t_K6* -t_K7 term.txt /*t_K7* -t_K8 term.txt /*t_K8* -t_K9 term.txt /*t_K9* -t_KA term.txt /*t_KA* -t_KB term.txt /*t_KB* -t_KC term.txt /*t_KC* -t_KD term.txt /*t_KD* -t_KE term.txt /*t_KE* -t_KF term.txt /*t_KF* -t_KG term.txt /*t_KG* -t_KH term.txt /*t_KH* -t_KI term.txt /*t_KI* -t_KJ term.txt /*t_KJ* -t_KK term.txt /*t_KK* -t_KL term.txt /*t_KL* -t_RI term.txt /*t_RI* -t_RV term.txt /*t_RV* -t_SI term.txt /*t_SI* -t_Sb term.txt /*t_Sb* -t_Sf term.txt /*t_Sf* -t_WP term.txt /*t_WP* -t_WS term.txt /*t_WS* -t_ZH term.txt /*t_ZH* -t_ZR term.txt /*t_ZR* -t_al term.txt /*t_al* -t_bc term.txt /*t_bc* -t_cd term.txt /*t_cd* -t_cdl version4.txt /*t_cdl* -t_ce term.txt /*t_ce* -t_ci version4.txt /*t_ci* -t_cil version4.txt /*t_cil* -t_cl term.txt /*t_cl* -t_cm term.txt /*t_cm* -t_cri version4.txt /*t_cri* -t_cs term.txt /*t_cs* -t_csc version4.txt /*t_csc* -t_cv version4.txt /*t_cv* -t_cvv version4.txt /*t_cvv* -t_da term.txt /*t_da* -t_db term.txt /*t_db* -t_dl term.txt /*t_dl* -t_ed version4.txt /*t_ed* -t_el version4.txt /*t_el* -t_f1 version4.txt /*t_f1* -t_f10 version4.txt /*t_f10* -t_f2 version4.txt /*t_f2* -t_f3 version4.txt /*t_f3* -t_f4 version4.txt /*t_f4* -t_f5 version4.txt /*t_f5* -t_f6 version4.txt /*t_f6* -t_f7 version4.txt /*t_f7* -t_f8 version4.txt /*t_f8* -t_f9 version4.txt /*t_f9* -t_fs term.txt /*t_fs* -t_help version4.txt /*t_help* -t_il version4.txt /*t_il* -t_k1 term.txt /*t_k1* -t_k2 term.txt /*t_k2* -t_k3 term.txt /*t_k3* -t_k4 term.txt /*t_k4* -t_k5 term.txt /*t_k5* -t_k6 term.txt /*t_k6* -t_k7 term.txt /*t_k7* -t_k8 term.txt /*t_k8* -t_k9 term.txt /*t_k9* -t_k; term.txt /*t_k;* -t_kB term.txt /*t_kB* -t_kD term.txt /*t_kD* -t_kI term.txt /*t_kI* -t_kN term.txt /*t_kN* -t_kP term.txt /*t_kP* -t_kb term.txt /*t_kb* -t_kd term.txt /*t_kd* -t_ke term.txt /*t_ke* -t_kh term.txt /*t_kh* -t_kl term.txt /*t_kl* -t_kr term.txt /*t_kr* -t_ks term.txt /*t_ks* -t_ku term.txt /*t_ku* -t_le term.txt /*t_le* -t_mb term.txt /*t_mb* -t_md term.txt /*t_md* -t_me term.txt /*t_me* -t_mr term.txt /*t_mr* -t_ms term.txt /*t_ms* -t_nd term.txt /*t_nd* -t_op term.txt /*t_op* -t_se term.txt /*t_se* -t_sf1 version4.txt /*t_sf1* -t_sf10 version4.txt /*t_sf10* -t_sf2 version4.txt /*t_sf2* -t_sf3 version4.txt /*t_sf3* -t_sf4 version4.txt /*t_sf4* -t_sf5 version4.txt /*t_sf5* -t_sf6 version4.txt /*t_sf6* -t_sf7 version4.txt /*t_sf7* -t_sf8 version4.txt /*t_sf8* -t_sf9 version4.txt /*t_sf9* -t_skd version4.txt /*t_skd* -t_skl version4.txt /*t_skl* -t_skr version4.txt /*t_skr* -t_sku version4.txt /*t_sku* -t_so term.txt /*t_so* -t_sr term.txt /*t_sr* -t_star7 term.txt /*t_star7* -t_tb version4.txt /*t_tb* -t_te term.txt /*t_te* -t_ti term.txt /*t_ti* -t_tp version4.txt /*t_tp* -t_ts term.txt /*t_ts* -t_ts_old version4.txt /*t_ts_old* -t_ue term.txt /*t_ue* -t_undo version4.txt /*t_undo* -t_us term.txt /*t_us* -t_ut term.txt /*t_ut* -t_vb term.txt /*t_vb* -t_ve term.txt /*t_ve* -t_vi term.txt /*t_vi* -t_vs term.txt /*t_vs* -t_xs term.txt /*t_xs* -tab intro.txt /*tab* -tab-page tabpage.txt /*tab-page* -tab-page-commands tabpage.txt /*tab-page-commands* -tab-page-intro tabpage.txt /*tab-page-intro* -tab-page-other tabpage.txt /*tab-page-other* -tabline-menu tabpage.txt /*tabline-menu* -tabpage tabpage.txt /*tabpage* -tabpage-variable eval.txt /*tabpage-variable* -tabpage.txt tabpage.txt /*tabpage.txt* -tabpagebuflist() eval.txt /*tabpagebuflist()* -tabpagenr() eval.txt /*tabpagenr()* -tabpagewinnr() eval.txt /*tabpagewinnr()* -tag tagsrch.txt /*tag* -tag-! tagsrch.txt /*tag-!* -tag-any-white tagsrch.txt /*tag-any-white* -tag-binary-search tagsrch.txt /*tag-binary-search* -tag-blocks motion.txt /*tag-blocks* -tag-commands tagsrch.txt /*tag-commands* -tag-details tagsrch.txt /*tag-details* -tag-highlight syntax.txt /*tag-highlight* -tag-matchlist tagsrch.txt /*tag-matchlist* -tag-old-static tagsrch.txt /*tag-old-static* -tag-overloaded version5.txt /*tag-overloaded* -tag-preview tagsrch.txt /*tag-preview* -tag-priority tagsrch.txt /*tag-priority* -tag-regexp tagsrch.txt /*tag-regexp* -tag-search tagsrch.txt /*tag-search* -tag-security tagsrch.txt /*tag-security* -tag-skip-file tagsrch.txt /*tag-skip-file* -tag-stack tagsrch.txt /*tag-stack* -tagfiles() eval.txt /*tagfiles()* -taglist() eval.txt /*taglist()* -tags tagsrch.txt /*tags* -tags-and-searches tagsrch.txt /*tags-and-searches* -tags-file-changed version5.txt /*tags-file-changed* -tags-file-format tagsrch.txt /*tags-file-format* -tags-option tagsrch.txt /*tags-option* -tagsrch.txt tagsrch.txt /*tagsrch.txt* -tagstack tagsrch.txt /*tagstack* -tar pi_tar.txt /*tar* -tar-contents pi_tar.txt /*tar-contents* -tar-copyright pi_tar.txt /*tar-copyright* -tar-history pi_tar.txt /*tar-history* -tar-manual pi_tar.txt /*tar-manual* -tar-options pi_tar.txt /*tar-options* -tar-usage pi_tar.txt /*tar-usage* -tcl if_tcl.txt /*tcl* -tcl-beep if_tcl.txt /*tcl-beep* -tcl-buffer if_tcl.txt /*tcl-buffer* -tcl-buffer-append if_tcl.txt /*tcl-buffer-append* -tcl-buffer-cmds if_tcl.txt /*tcl-buffer-cmds* -tcl-buffer-command if_tcl.txt /*tcl-buffer-command* -tcl-buffer-count if_tcl.txt /*tcl-buffer-count* -tcl-buffer-delcmd if_tcl.txt /*tcl-buffer-delcmd* -tcl-buffer-delete if_tcl.txt /*tcl-buffer-delete* -tcl-buffer-expr if_tcl.txt /*tcl-buffer-expr* -tcl-buffer-get if_tcl.txt /*tcl-buffer-get* -tcl-buffer-insert if_tcl.txt /*tcl-buffer-insert* -tcl-buffer-last if_tcl.txt /*tcl-buffer-last* -tcl-buffer-mark if_tcl.txt /*tcl-buffer-mark* -tcl-buffer-option if_tcl.txt /*tcl-buffer-option* -tcl-buffer-set if_tcl.txt /*tcl-buffer-set* -tcl-buffer-windows if_tcl.txt /*tcl-buffer-windows* -tcl-bugs if_tcl.txt /*tcl-bugs* -tcl-command if_tcl.txt /*tcl-command* -tcl-commands if_tcl.txt /*tcl-commands* -tcl-dynamic if_tcl.txt /*tcl-dynamic* -tcl-ex-commands if_tcl.txt /*tcl-ex-commands* -tcl-examples if_tcl.txt /*tcl-examples* -tcl-expr if_tcl.txt /*tcl-expr* -tcl-linenumbers if_tcl.txt /*tcl-linenumbers* -tcl-misc if_tcl.txt /*tcl-misc* -tcl-option if_tcl.txt /*tcl-option* -tcl-output if_tcl.txt /*tcl-output* -tcl-var-current if_tcl.txt /*tcl-var-current* -tcl-var-lbase if_tcl.txt /*tcl-var-lbase* -tcl-var-line if_tcl.txt /*tcl-var-line* -tcl-var-lnum if_tcl.txt /*tcl-var-lnum* -tcl-var-range if_tcl.txt /*tcl-var-range* -tcl-variables if_tcl.txt /*tcl-variables* -tcl-window if_tcl.txt /*tcl-window* -tcl-window-buffer if_tcl.txt /*tcl-window-buffer* -tcl-window-cmds if_tcl.txt /*tcl-window-cmds* -tcl-window-command if_tcl.txt /*tcl-window-command* -tcl-window-cursor if_tcl.txt /*tcl-window-cursor* -tcl-window-delcmd if_tcl.txt /*tcl-window-delcmd* -tcl-window-expr if_tcl.txt /*tcl-window-expr* -tcl-window-height if_tcl.txt /*tcl-window-height* -tcl-window-option if_tcl.txt /*tcl-window-option* -tcsh-style cmdline.txt /*tcsh-style* -tcsh.vim syntax.txt /*tcsh.vim* -tear-off-menus gui.txt /*tear-off-menus* -telnet-CTRL-] tagsrch.txt /*telnet-CTRL-]* -temp-file-name eval.txt /*temp-file-name* -template autocmd.txt /*template* -tempname() eval.txt /*tempname()* -term-dependent-settings term.txt /*term-dependent-settings* -term-list syntax.txt /*term-list* -term.txt term.txt /*term.txt* -termcap term.txt /*termcap* -termcap-changed version4.txt /*termcap-changed* -termcap-colors term.txt /*termcap-colors* -termcap-cursor-color term.txt /*termcap-cursor-color* -termcap-cursor-shape term.txt /*termcap-cursor-shape* -termcap-options term.txt /*termcap-options* -termcap-title term.txt /*termcap-title* -terminal-colors os_unix.txt /*terminal-colors* -terminal-info term.txt /*terminal-info* -terminal-options term.txt /*terminal-options* -terminfo term.txt /*terminfo* -termresponse-variable eval.txt /*termresponse-variable* -tex-error syntax.txt /*tex-error* -tex-folding syntax.txt /*tex-folding* -tex-math syntax.txt /*tex-math* -tex-morecommands syntax.txt /*tex-morecommands* -tex-nospell syntax.txt /*tex-nospell* -tex-package syntax.txt /*tex-package* -tex-runon syntax.txt /*tex-runon* -tex-slow syntax.txt /*tex-slow* -tex-style syntax.txt /*tex-style* -tex.vim syntax.txt /*tex.vim* -text-objects motion.txt /*text-objects* -text-objects-changed version5.txt /*text-objects-changed* -textlock eval.txt /*textlock* -tf.vim syntax.txt /*tf.vim* -this_session-variable eval.txt /*this_session-variable* -throw-catch eval.txt /*throw-catch* -throw-expression eval.txt /*throw-expression* -throw-from-catch eval.txt /*throw-from-catch* -throw-variables eval.txt /*throw-variables* -throwpoint-variable eval.txt /*throwpoint-variable* -timestamp editing.txt /*timestamp* -timestamps editing.txt /*timestamps* -tips tips.txt /*tips* -tips.txt tips.txt /*tips.txt* -todo todo.txt /*todo* -todo.txt todo.txt /*todo.txt* -toggle options.txt /*toggle* -toggle-revins version4.txt /*toggle-revins* -tolower() eval.txt /*tolower()* -toolbar-icon gui.txt /*toolbar-icon* -toupper() eval.txt /*toupper()* -tr() eval.txt /*tr()* -trojan-horse starting.txt /*trojan-horse* -trunc() eval.txt /*trunc()* -try-conditionals eval.txt /*try-conditionals* -try-echoerr eval.txt /*try-echoerr* -try-finally eval.txt /*try-finally* -try-nested eval.txt /*try-nested* -try-nesting eval.txt /*try-nesting* -tutor usr_01.txt /*tutor* -twice if_cscop.txt /*twice* -type() eval.txt /*type()* -type-mistakes tips.txt /*type-mistakes* -typecorr-settings usr_41.txt /*typecorr-settings* -typecorr.txt usr_41.txt /*typecorr.txt* -u undo.txt /*u* -uganda uganda.txt /*uganda* -uganda.txt uganda.txt /*uganda.txt* -undercurl syntax.txt /*undercurl* -underline syntax.txt /*underline* -undo undo.txt /*undo* -undo-blocks undo.txt /*undo-blocks* -undo-branches undo.txt /*undo-branches* -undo-commands undo.txt /*undo-commands* -undo-redo undo.txt /*undo-redo* -undo-remarks undo.txt /*undo-remarks* -undo-tree undo.txt /*undo-tree* -undo-two-ways undo.txt /*undo-two-ways* -undo.txt undo.txt /*undo.txt* -undo_ftplugin usr_41.txt /*undo_ftplugin* -unicode mbyte.txt /*unicode* -unix os_unix.txt /*unix* -unlisted-buffer windows.txt /*unlisted-buffer* -up-down-motions motion.txt /*up-down-motions* -uppercase change.txt /*uppercase* -use-cpo-save usr_41.txt /*use-cpo-save* -use-visual-cmds version4.txt /*use-visual-cmds* -useful-mappings tips.txt /*useful-mappings* -usenet intro.txt /*usenet* -user-cmd-ambiguous map.txt /*user-cmd-ambiguous* -user-commands map.txt /*user-commands* -user-functions eval.txt /*user-functions* -user-manual usr_toc.txt /*user-manual* -using-<Plug> usr_41.txt /*using-<Plug>* -using-menus gui.txt /*using-menus* -using-scripts repeat.txt /*using-scripts* -using-xxd tips.txt /*using-xxd* -using_CTRL-V map.txt /*using_CTRL-V* -usr_01.txt usr_01.txt /*usr_01.txt* -usr_02.txt usr_02.txt /*usr_02.txt* -usr_03.txt usr_03.txt /*usr_03.txt* -usr_04.txt usr_04.txt /*usr_04.txt* -usr_05.txt usr_05.txt /*usr_05.txt* -usr_06.txt usr_06.txt /*usr_06.txt* -usr_07.txt usr_07.txt /*usr_07.txt* -usr_08.txt usr_08.txt /*usr_08.txt* -usr_09.txt usr_09.txt /*usr_09.txt* -usr_10.txt usr_10.txt /*usr_10.txt* -usr_11.txt usr_11.txt /*usr_11.txt* -usr_12.txt usr_12.txt /*usr_12.txt* -usr_20.txt usr_20.txt /*usr_20.txt* -usr_21.txt usr_21.txt /*usr_21.txt* -usr_22.txt usr_22.txt /*usr_22.txt* -usr_23.txt usr_23.txt /*usr_23.txt* -usr_24.txt usr_24.txt /*usr_24.txt* -usr_25.txt usr_25.txt /*usr_25.txt* -usr_26.txt usr_26.txt /*usr_26.txt* -usr_27.txt usr_27.txt /*usr_27.txt* -usr_28.txt usr_28.txt /*usr_28.txt* -usr_29.txt usr_29.txt /*usr_29.txt* -usr_30.txt usr_30.txt /*usr_30.txt* -usr_31.txt usr_31.txt /*usr_31.txt* -usr_32.txt usr_32.txt /*usr_32.txt* -usr_40.txt usr_40.txt /*usr_40.txt* -usr_41.txt usr_41.txt /*usr_41.txt* -usr_42.txt usr_42.txt /*usr_42.txt* -usr_43.txt usr_43.txt /*usr_43.txt* -usr_44.txt usr_44.txt /*usr_44.txt* -usr_45.txt usr_45.txt /*usr_45.txt* -usr_90.txt usr_90.txt /*usr_90.txt* -usr_toc.txt usr_toc.txt /*usr_toc.txt* -utf-8 mbyte.txt /*utf-8* -utf-8-char-arg mbyte.txt /*utf-8-char-arg* -utf-8-in-xwindows mbyte.txt /*utf-8-in-xwindows* -utf-8-typing mbyte.txt /*utf-8-typing* -utf8 mbyte.txt /*utf8* -v visual.txt /*v* -v:beval_bufnr eval.txt /*v:beval_bufnr* -v:beval_col eval.txt /*v:beval_col* -v:beval_lnum eval.txt /*v:beval_lnum* -v:beval_text eval.txt /*v:beval_text* -v:beval_winnr eval.txt /*v:beval_winnr* -v:char eval.txt /*v:char* -v:charconvert_from eval.txt /*v:charconvert_from* -v:charconvert_to eval.txt /*v:charconvert_to* -v:cmdarg eval.txt /*v:cmdarg* -v:cmdbang eval.txt /*v:cmdbang* -v:count eval.txt /*v:count* -v:count1 eval.txt /*v:count1* -v:ctype eval.txt /*v:ctype* -v:dying eval.txt /*v:dying* -v:errmsg eval.txt /*v:errmsg* -v:exception eval.txt /*v:exception* -v:fcs_choice eval.txt /*v:fcs_choice* -v:fcs_reason eval.txt /*v:fcs_reason* -v:fname_diff eval.txt /*v:fname_diff* -v:fname_in eval.txt /*v:fname_in* -v:fname_new eval.txt /*v:fname_new* -v:fname_out eval.txt /*v:fname_out* -v:folddashes eval.txt /*v:folddashes* -v:foldend eval.txt /*v:foldend* -v:foldlevel eval.txt /*v:foldlevel* -v:foldstart eval.txt /*v:foldstart* -v:insertmode eval.txt /*v:insertmode* -v:key eval.txt /*v:key* -v:lang eval.txt /*v:lang* -v:lc_time eval.txt /*v:lc_time* -v:lnum eval.txt /*v:lnum* -v:mouse_col eval.txt /*v:mouse_col* -v:mouse_lnum eval.txt /*v:mouse_lnum* -v:mouse_win eval.txt /*v:mouse_win* -v:operator eval.txt /*v:operator* -v:prevcount eval.txt /*v:prevcount* -v:profiling eval.txt /*v:profiling* -v:progname eval.txt /*v:progname* -v:register eval.txt /*v:register* -v:scrollstart eval.txt /*v:scrollstart* -v:searchforward eval.txt /*v:searchforward* -v:servername eval.txt /*v:servername* -v:shell_error eval.txt /*v:shell_error* -v:statusmsg eval.txt /*v:statusmsg* -v:swapchoice eval.txt /*v:swapchoice* -v:swapcommand eval.txt /*v:swapcommand* -v:swapname eval.txt /*v:swapname* -v:termresponse eval.txt /*v:termresponse* -v:this_session eval.txt /*v:this_session* -v:throwpoint eval.txt /*v:throwpoint* -v:val eval.txt /*v:val* -v:var eval.txt /*v:var* -v:version eval.txt /*v:version* -v:warningmsg eval.txt /*v:warningmsg* -v_! change.txt /*v_!* -v_$ visual.txt /*v_$* -v_: cmdline.txt /*v_:* -v_< change.txt /*v_<* -v_<BS> change.txt /*v_<BS>* -v_<Del> change.txt /*v_<Del>* -v_<Esc> visual.txt /*v_<Esc>* -v_= change.txt /*v_=* -v_> change.txt /*v_>* -v_C change.txt /*v_C* -v_CTRL-C visual.txt /*v_CTRL-C* -v_CTRL-G visual.txt /*v_CTRL-G* -v_CTRL-H change.txt /*v_CTRL-H* -v_CTRL-O visual.txt /*v_CTRL-O* -v_CTRL-V visual.txt /*v_CTRL-V* -v_CTRL-Z starting.txt /*v_CTRL-Z* -v_CTRL-\_CTRL-G intro.txt /*v_CTRL-\\_CTRL-G* -v_CTRL-\_CTRL-N intro.txt /*v_CTRL-\\_CTRL-N* -v_CTRL-] tagsrch.txt /*v_CTRL-]* -v_D change.txt /*v_D* -v_J change.txt /*v_J* -v_K various.txt /*v_K* -v_O visual.txt /*v_O* -v_P change.txt /*v_P* -v_R change.txt /*v_R* -v_S change.txt /*v_S* -v_U change.txt /*v_U* -v_V visual.txt /*v_V* -v_X change.txt /*v_X* -v_Y change.txt /*v_Y* -v_a motion.txt /*v_a* -v_a' motion.txt /*v_a'* -v_a( motion.txt /*v_a(* -v_a) motion.txt /*v_a)* -v_a< motion.txt /*v_a<* -v_a> motion.txt /*v_a>* -v_aB motion.txt /*v_aB* -v_aW motion.txt /*v_aW* -v_a[ motion.txt /*v_a[* -v_a] motion.txt /*v_a]* -v_a` motion.txt /*v_a`* -v_ab motion.txt /*v_ab* -v_ap motion.txt /*v_ap* -v_aquote motion.txt /*v_aquote* -v_as motion.txt /*v_as* -v_at motion.txt /*v_at* -v_aw motion.txt /*v_aw* -v_a{ motion.txt /*v_a{* -v_a} motion.txt /*v_a}* -v_b_< visual.txt /*v_b_<* -v_b_<_example visual.txt /*v_b_<_example* -v_b_> visual.txt /*v_b_>* -v_b_>_example visual.txt /*v_b_>_example* -v_b_A visual.txt /*v_b_A* -v_b_A_example visual.txt /*v_b_A_example* -v_b_C visual.txt /*v_b_C* -v_b_D change.txt /*v_b_D* -v_b_I visual.txt /*v_b_I* -v_b_I_example visual.txt /*v_b_I_example* -v_b_c visual.txt /*v_b_c* -v_b_r visual.txt /*v_b_r* -v_b_r_example visual.txt /*v_b_r_example* -v_c change.txt /*v_c* -v_d change.txt /*v_d* -v_g? change.txt /*v_g?* -v_gF editing.txt /*v_gF* -v_gJ change.txt /*v_gJ* -v_gV visual.txt /*v_gV* -v_g] tagsrch.txt /*v_g]* -v_g_CTRL-G editing.txt /*v_g_CTRL-G* -v_g_CTRL-] tagsrch.txt /*v_g_CTRL-]* -v_gf editing.txt /*v_gf* -v_gq change.txt /*v_gq* -v_gv visual.txt /*v_gv* -v_gw change.txt /*v_gw* -v_i motion.txt /*v_i* -v_i' motion.txt /*v_i'* -v_i( motion.txt /*v_i(* -v_i) motion.txt /*v_i)* -v_i< motion.txt /*v_i<* -v_i> motion.txt /*v_i>* -v_iB motion.txt /*v_iB* -v_iW motion.txt /*v_iW* -v_i[ motion.txt /*v_i[* -v_i] motion.txt /*v_i]* -v_i` motion.txt /*v_i`* -v_ib motion.txt /*v_ib* -v_ip motion.txt /*v_ip* -v_iquote motion.txt /*v_iquote* -v_is motion.txt /*v_is* -v_it motion.txt /*v_it* -v_iw motion.txt /*v_iw* -v_i{ motion.txt /*v_i{* -v_i} motion.txt /*v_i}* -v_o visual.txt /*v_o* -v_p change.txt /*v_p* -v_r change.txt /*v_r* -v_s change.txt /*v_s* -v_u change.txt /*v_u* -v_v visual.txt /*v_v* -v_x change.txt /*v_x* -v_y change.txt /*v_y* -v_~ change.txt /*v_~* -val-variable eval.txt /*val-variable* -values() eval.txt /*values()* -variables eval.txt /*variables* -various various.txt /*various* -various-cmds various.txt /*various-cmds* -various-motions motion.txt /*various-motions* -various.txt various.txt /*various.txt* -vb.vim syntax.txt /*vb.vim* -vba pi_vimball.txt /*vba* -verbose starting.txt /*verbose* -version-5.1 version5.txt /*version-5.1* -version-5.2 version5.txt /*version-5.2* -version-5.3 version5.txt /*version-5.3* -version-5.4 version5.txt /*version-5.4* -version-5.5 version5.txt /*version-5.5* -version-5.6 version5.txt /*version-5.6* -version-5.7 version5.txt /*version-5.7* -version-5.8 version5.txt /*version-5.8* -version-6.1 version6.txt /*version-6.1* -version-6.2 version6.txt /*version-6.2* -version-6.3 version6.txt /*version-6.3* -version-6.4 version6.txt /*version-6.4* -version-7.1 version7.txt /*version-7.1* -version-7.2 version7.txt /*version-7.2* -version-variable eval.txt /*version-variable* -version4.txt version4.txt /*version4.txt* -version5.txt version5.txt /*version5.txt* -version6.txt version6.txt /*version6.txt* -version7.txt version7.txt /*version7.txt* -vi intro.txt /*vi* -vi-differences vi_diff.txt /*vi-differences* -vi: options.txt /*vi:* -vi_diff.txt vi_diff.txt /*vi_diff.txt* -view starting.txt /*view* -view-diffs diff.txt /*view-diffs* -view-file starting.txt /*view-file* -views-sessions starting.txt /*views-sessions* -vim-additions vi_diff.txt /*vim-additions* -vim-announce intro.txt /*vim-announce* -vim-arguments starting.txt /*vim-arguments* -vim-default-editor gui_w32.txt /*vim-default-editor* -vim-dev intro.txt /*vim-dev* -vim-mac intro.txt /*vim-mac* -vim-modes intro.txt /*vim-modes* -vim-modes-intro intro.txt /*vim-modes-intro* -vim-multibyte intro.txt /*vim-multibyte* -vim-script-intro usr_41.txt /*vim-script-intro* -vim-variable eval.txt /*vim-variable* -vim.vim syntax.txt /*vim.vim* -vim7 version7.txt /*vim7* -vim: options.txt /*vim:* -vimball pi_vimball.txt /*vimball* -vimball-contents pi_vimball.txt /*vimball-contents* -vimball-extract pi_vimball.txt /*vimball-extract* -vimball-history pi_vimball.txt /*vimball-history* -vimball-intro pi_vimball.txt /*vimball-intro* -vimball-manual pi_vimball.txt /*vimball-manual* -vimdev intro.txt /*vimdev* -vimdiff diff.txt /*vimdiff* -vimfiles options.txt /*vimfiles* -viminfo starting.txt /*viminfo* -viminfo-encoding starting.txt /*viminfo-encoding* -viminfo-errors starting.txt /*viminfo-errors* -viminfo-file starting.txt /*viminfo-file* -viminfo-file-marks starting.txt /*viminfo-file-marks* -viminfo-file-name starting.txt /*viminfo-file-name* -viminfo-read starting.txt /*viminfo-read* -viminfo-write starting.txt /*viminfo-write* -vimrc starting.txt /*vimrc* -vimrc-filetype usr_05.txt /*vimrc-filetype* -vimrc-intro usr_05.txt /*vimrc-intro* -vimrc-option-example starting.txt /*vimrc-option-example* -vimrc_example.vim usr_05.txt /*vimrc_example.vim* -vimtutor usr_01.txt /*vimtutor* -virtcol() eval.txt /*virtcol()* -visual-block visual.txt /*visual-block* -visual-change visual.txt /*visual-change* -visual-examples visual.txt /*visual-examples* -visual-index index.txt /*visual-index* -visual-mode visual.txt /*visual-mode* -visual-operators visual.txt /*visual-operators* -visual-repeat visual.txt /*visual-repeat* -visual-search visual.txt /*visual-search* -visual-start visual.txt /*visual-start* -visual-use visual.txt /*visual-use* -visual.txt visual.txt /*visual.txt* -visualmode() eval.txt /*visualmode()* -vms os_vms.txt /*vms* -vms-authors os_vms.txt /*vms-authors* -vms-changes os_vms.txt /*vms-changes* -vms-compiling os_vms.txt /*vms-compiling* -vms-deploy os_vms.txt /*vms-deploy* -vms-download os_vms.txt /*vms-download* -vms-gui os_vms.txt /*vms-gui* -vms-notes os_vms.txt /*vms-notes* -vms-problems os_vms.txt /*vms-problems* -vms-started os_vms.txt /*vms-started* -vms-usage os_vms.txt /*vms-usage* -vote-for-features sponsor.txt /*vote-for-features* -votes-counted sponsor.txt /*votes-counted* -votes-for-changes todo.txt /*votes-for-changes* -vreplace-mode insert.txt /*vreplace-mode* -vt100-cursor-keys term.txt /*vt100-cursor-keys* -vt100-function-keys term.txt /*vt100-function-keys* -w motion.txt /*w* -w32-clientserver remote.txt /*w32-clientserver* -w:var eval.txt /*w:var* -warningmsg-variable eval.txt /*warningmsg-variable* -white-space pattern.txt /*white-space* -whitespace pattern.txt /*whitespace* -wildcard editing.txt /*wildcard* -wildcards editing.txt /*wildcards* -win16-!start gui_w16.txt /*win16-!start* -win16-clipboard gui_w16.txt /*win16-clipboard* -win16-colors gui_w16.txt /*win16-colors* -win16-default-editor gui_w16.txt /*win16-default-editor* -win16-dialogs gui_w16.txt /*win16-dialogs* -win16-drag-n-drop gui_w16.txt /*win16-drag-n-drop* -win16-gui gui_w16.txt /*win16-gui* -win16-maximized gui_w16.txt /*win16-maximized* -win16-printing gui_w16.txt /*win16-printing* -win16-shell gui_w16.txt /*win16-shell* -win16-start gui_w16.txt /*win16-start* -win16-truetype gui_w16.txt /*win16-truetype* -win16-various gui_w16.txt /*win16-various* -win32 os_win32.txt /*win32* -win32-!start gui_w32.txt /*win32-!start* -win32-PATH os_win32.txt /*win32-PATH* -win32-colors gui_w32.txt /*win32-colors* -win32-compiling os_win32.txt /*win32-compiling* -win32-curdir os_win32.txt /*win32-curdir* -win32-faq os_win32.txt /*win32-faq* -win32-gettext mlang.txt /*win32-gettext* -win32-gui gui_w32.txt /*win32-gui* -win32-hidden-menus gui.txt /*win32-hidden-menus* -win32-mouse os_win32.txt /*win32-mouse* -win32-open-with-menu gui_w32.txt /*win32-open-with-menu* -win32-popup-menu gui_w32.txt /*win32-popup-menu* -win32-problems os_win32.txt /*win32-problems* -win32-restore os_win32.txt /*win32-restore* -win32-startup os_win32.txt /*win32-startup* -win32-term os_win32.txt /*win32-term* -win32-vimrun gui_w32.txt /*win32-vimrun* -win32-win3.1 os_win32.txt /*win32-win3.1* -win32s os_win32.txt /*win32s* -winbufnr() eval.txt /*winbufnr()* -wincol() eval.txt /*wincol()* -window windows.txt /*window* -window-contents intro.txt /*window-contents* -window-exit editing.txt /*window-exit* -window-move-cursor windows.txt /*window-move-cursor* -window-moving windows.txt /*window-moving* -window-resize windows.txt /*window-resize* -window-size term.txt /*window-size* -window-tag windows.txt /*window-tag* -window-variable eval.txt /*window-variable* -windows windows.txt /*windows* -windows-3.1 os_win32.txt /*windows-3.1* -windows-intro windows.txt /*windows-intro* -windows-starting windows.txt /*windows-starting* -windows.txt windows.txt /*windows.txt* -windows95 os_win32.txt /*windows95* -winheight() eval.txt /*winheight()* -winline() eval.txt /*winline()* -winnr() eval.txt /*winnr()* -winrestcmd() eval.txt /*winrestcmd()* -winrestview() eval.txt /*winrestview()* -winsaveview() eval.txt /*winsaveview()* -winwidth() eval.txt /*winwidth()* -word motion.txt /*word* -word-count editing.txt /*word-count* -word-motions motion.txt /*word-motions* -workbench starting.txt /*workbench* -workshop workshop.txt /*workshop* -workshop-commands workshop.txt /*workshop-commands* -workshop-compiling workshop.txt /*workshop-compiling* -workshop-configure workshop.txt /*workshop-configure* -workshop-intro workshop.txt /*workshop-intro* -workshop-support workshop.txt /*workshop-support* -workshop-xpm workshop.txt /*workshop-xpm* -workshop.txt workshop.txt /*workshop.txt* -wrap-off intro.txt /*wrap-off* -write-compiler-plugin usr_41.txt /*write-compiler-plugin* -write-device editing.txt /*write-device* -write-fail editing.txt /*write-fail* -write-filetype-plugin usr_41.txt /*write-filetype-plugin* -write-library-script usr_41.txt /*write-library-script* -write-local-help usr_41.txt /*write-local-help* -write-plugin usr_41.txt /*write-plugin* -write-plugin-quickload usr_41.txt /*write-plugin-quickload* -write-quit editing.txt /*write-quit* -write-readonly editing.txt /*write-readonly* -writefile() eval.txt /*writefile()* -writing editing.txt /*writing* -www intro.txt /*www* -x change.txt /*x* -x-input-method mbyte.txt /*x-input-method* -x-resources version5.txt /*x-resources* -x11-clientserver remote.txt /*x11-clientserver* -x11-cut-buffer gui_x11.txt /*x11-cut-buffer* -x11-selection gui_x11.txt /*x11-selection* -xf86conf.vim syntax.txt /*xf86conf.vim* -xfontset mbyte.txt /*xfontset* -xfree-xterm syntax.txt /*xfree-xterm* -xim mbyte.txt /*xim* -xim-input-style mbyte.txt /*xim-input-style* -xiterm syntax.txt /*xiterm* -xml-folding syntax.txt /*xml-folding* -xml-omni-datafile insert.txt /*xml-omni-datafile* -xml.vim syntax.txt /*xml.vim* -xpm.vim syntax.txt /*xpm.vim* -xterm-8-bit term.txt /*xterm-8-bit* -xterm-8bit term.txt /*xterm-8bit* -xterm-blink syntax.txt /*xterm-blink* -xterm-blinking-cursor syntax.txt /*xterm-blinking-cursor* -xterm-clipboard term.txt /*xterm-clipboard* -xterm-codes term.txt /*xterm-codes* -xterm-color syntax.txt /*xterm-color* -xterm-command-server term.txt /*xterm-command-server* -xterm-copy-paste term.txt /*xterm-copy-paste* -xterm-cursor-keys term.txt /*xterm-cursor-keys* -xterm-end-home-keys term.txt /*xterm-end-home-keys* -xterm-function-keys term.txt /*xterm-function-keys* -xterm-modifier-keys term.txt /*xterm-modifier-keys* -xterm-mouse options.txt /*xterm-mouse* -xterm-mouse-wheel scroll.txt /*xterm-mouse-wheel* -xterm-save-screen tips.txt /*xterm-save-screen* -xterm-screens tips.txt /*xterm-screens* -xterm-scroll-region term.txt /*xterm-scroll-region* -xterm-shifted-keys term.txt /*xterm-shifted-keys* -y change.txt /*y* -yank change.txt /*yank* -ye-option-gone version4.txt /*ye-option-gone* -year-2000 intro.txt /*year-2000* -your-runtime-dir usr_43.txt /*your-runtime-dir* -yy change.txt /*yy* -z index.txt /*z* -z+ scroll.txt /*z+* -z- scroll.txt /*z-* -z. scroll.txt /*z.* -z/OS os_390.txt /*z\/OS* -z<CR> scroll.txt /*z<CR>* -z<Left> scroll.txt /*z<Left>* -z<Right> scroll.txt /*z<Right>* -z= spell.txt /*z=* -zA fold.txt /*zA* -zC fold.txt /*zC* -zD fold.txt /*zD* -zE fold.txt /*zE* -zF fold.txt /*zF* -zG spell.txt /*zG* -zH scroll.txt /*zH* -zL scroll.txt /*zL* -zM fold.txt /*zM* -zN fold.txt /*zN* -zN<CR> scroll.txt /*zN<CR>* -zO fold.txt /*zO* -zOS os_390.txt /*zOS* -zOS-Bugs os_390.txt /*zOS-Bugs* -zOS-Motif os_390.txt /*zOS-Motif* -zOS-building os_390.txt /*zOS-building* -zOS-changes os_390.txt /*zOS-changes* -zOS-feedback os_390.txt /*zOS-feedback* -zOS-has-ebcdic os_390.txt /*zOS-has-ebcdic* -zOS-open-source os_390.txt /*zOS-open-source* -zOS-weaknesses os_390.txt /*zOS-weaknesses* -zOS-xterm os_390.txt /*zOS-xterm* -zR fold.txt /*zR* -zW spell.txt /*zW* -zX fold.txt /*zX* -z^ scroll.txt /*z^* -za fold.txt /*za* -zb scroll.txt /*zb* -zc fold.txt /*zc* -zd fold.txt /*zd* -ze scroll.txt /*ze* -zf fold.txt /*zf* -zg spell.txt /*zg* -zh scroll.txt /*zh* -zi fold.txt /*zi* -zip pi_zip.txt /*zip* -zip-contents pi_zip.txt /*zip-contents* -zip-copyright pi_zip.txt /*zip-copyright* -zip-extension pi_zip.txt /*zip-extension* -zip-history pi_zip.txt /*zip-history* -zip-manual pi_zip.txt /*zip-manual* -zip-usage pi_zip.txt /*zip-usage* -zj fold.txt /*zj* -zk fold.txt /*zk* -zl scroll.txt /*zl* -zm fold.txt /*zm* -zn fold.txt /*zn* -zo fold.txt /*zo* -zr fold.txt /*zr* -zs scroll.txt /*zs* -zt scroll.txt /*zt* -zuG spell.txt /*zuG* -zuW spell.txt /*zuW* -zug spell.txt /*zug* -zuw spell.txt /*zuw* -zv fold.txt /*zv* -zw spell.txt /*zw* -zx fold.txt /*zx* -zz scroll.txt /*zz* -{ motion.txt /*{* -{Visual} intro.txt /*{Visual}* -{address} cmdline.txt /*{address}* -{arglist} editing.txt /*{arglist}* -{char1-char2} intro.txt /*{char1-char2}* -{event} autocmd.txt /*{event}* -{file} editing.txt /*{file}* -{group-name} syntax.txt /*{group-name}* -{lhs} map.txt /*{lhs}* -{motion} intro.txt /*{motion}* -{move-around} visual.txt /*{move-around}* -{offset} pattern.txt /*{offset}* -{pat} autocmd.txt /*{pat}* -{rhs} map.txt /*{rhs}* -{subject} various.txt /*{subject}* -{} intro.txt /*{}* -} motion.txt /*}* -~ change.txt /*~* diff --git a/share/vim/vim72/doc/tagsrch.txt b/share/vim/vim72/doc/tagsrch.txt deleted file mode 100644 index 1267fb1536..0000000000 --- a/share/vim/vim72/doc/tagsrch.txt +++ /dev/null @@ -1,833 +0,0 @@ -*tagsrch.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Tags and special searches *tags-and-searches* - -See section |29.1| of the user manual for an introduction. - -1. Jump to a tag |tag-commands| -2. Tag stack |tag-stack| -3. Tag match list |tag-matchlist| -4. Tags details |tag-details| -5. Tags file format |tags-file-format| -6. Include file searches |include-search| - -============================================================================== -1. Jump to a tag *tag-commands* - - *tag* *tags* -A tag is an identifier that appears in a "tags" file. It is a sort of label -that can be jumped to. For example: In C programs each function name can be -used as a tag. The "tags" file has to be generated by a program like ctags, -before the tag commands can be used. - -With the ":tag" command the cursor will be positioned on the tag. With the -CTRL-] command, the keyword on which the cursor is standing is used as the -tag. If the cursor is not on a keyword, the first keyword to the right of the -cursor is used. - -The ":tag" command works very well for C programs. If you see a call to a -function and wonder what that function does, position the cursor inside of the -function name and hit CTRL-]. This will bring you to the function definition. -An easy way back is with the CTRL-T command. Also read about the tag stack -below. - - *:ta* *:tag* *E426* *E429* -:[count]ta[g][!] {ident} - Jump to the definition of {ident}, using the - information in the tags file(s). Put {ident} in the - tag stack. See |tag-!| for [!]. - {ident} can be a regexp pattern, see |tag-regexp|. - When there are several matching tags for {ident}, jump - to the [count] one. When [count] is omitted the - first one is jumped to. See |tag-matchlist| for - jumping to other matching tags. - -g<LeftMouse> *g<LeftMouse>* -<C-LeftMouse> *<C-LeftMouse>* *CTRL-]* -CTRL-] Jump to the definition of the keyword under the - cursor. Same as ":tag {ident}", where {ident} is the - keyword under or after cursor. - When there are several matching tags for {ident}, jump - to the [count] one. When no [count] is given the - first one is jumped to. See |tag-matchlist| for - jumping to other matching tags. - {Vi: identifier after the cursor} - - *v_CTRL-]* -{Visual}CTRL-] Same as ":tag {ident}", where {ident} is the text that - is highlighted. {not in Vi} - - *telnet-CTRL-]* -CTRL-] is the default telnet escape key. When you type CTRL-] to jump to a -tag, you will get the telnet prompt instead. Most versions of telnet allow -changing or disabling the default escape key. See the telnet man page. You -can 'telnet -E {Hostname}' to disable the escape character, or 'telnet -e -{EscapeCharacter} {Hostname}' to specify another escape character. If -possible, try to use "ssh" instead of "telnet" to avoid this problem. - - *tag-priority* -When there are multiple matches for a tag, this priority is used: -1. "FSC" A full matching static tag for the current file. -2. "F C" A full matching global tag for the current file. -3. "F " A full matching global tag for another file. -4. "FS " A full matching static tag for another file. -5. " SC" An ignore-case matching static tag for the current file. -6. " C" An ignore-case matching global tag for the current file. -7. " " An ignore-case matching global tag for another file. -8. " S " An ignore-case matching static tag for another file. - -Note that when the current file changes, the priority list is mostly not -changed, to avoid confusion when using ":tnext". It is changed when using -":tag {ident}". - -The ignore-case matches are not found for a ":tag" command when the -'ignorecase' option is off. They are found when a pattern is used (starting -with a "/") and for ":tselect", also when 'ignorecase' is off. Note that -using ignore-case tag searching disables binary searching in the tags file, -which causes a slowdown. This can be avoided by fold-case sorting the tag -file. See the 'tagbsearch' option for an explanation. - -============================================================================== -2. Tag stack *tag-stack* *tagstack* *E425* - -On the tag stack is remembered which tags you jumped to, and from where. -Tags are only pushed onto the stack when the 'tagstack' option is set. - -g<RightMouse> *g<RightMouse>* -<C-RightMouse> *<C-RightMouse>* *CTRL-T* -CTRL-T Jump to [count] older entry in the tag stack - (default 1). {not in Vi} - - *:po* *:pop* *E555* *E556* -:[count]po[p][!] Jump to [count] older entry in tag stack (default 1). - See |tag-!| for [!]. {not in Vi} - -:[count]ta[g][!] Jump to [count] newer entry in tag stack (default 1). - See |tag-!| for [!]. {not in Vi} - - *:tags* -:tags Show the contents of the tag stack. The active - entry is marked with a '>'. {not in Vi} - -The output of ":tags" looks like this: - - # TO tag FROM line in file/line - 1 1 main 1 harddisk2:text/vim/test - > 2 2 FuncA 58 i = FuncA(10); - 3 1 FuncC 357 harddisk2:text/vim/src/amiga.c - -This list shows the tags that you jumped to and the cursor position before -that jump. The older tags are at the top, the newer at the bottom. - -The '>' points to the active entry. This is the tag that will be used by the -next ":tag" command. The CTRL-T and ":pop" command will use the position -above the active entry. - -Below the "TO" is the number of the current match in the match list. Note -that this doesn't change when using ":pop" or ":tag". - -The line number and file name are remembered to be able to get back to where -you were before the tag command. The line number will be correct, also when -deleting/inserting lines, unless this was done by another program (e.g. -another instance of Vim). - -For the current file, the "file/line" column shows the text at the position. -An indent is removed and a long line is truncated to fit in the window. - -You can jump to previously used tags with several commands. Some examples: - - ":pop" or CTRL-T to position before previous tag - {count}CTRL-T to position before {count} older tag - ":tag" to newer tag - ":0tag" to last used tag - -The most obvious way to use this is while browsing through the call graph of -a program. Consider the following call graph: - - main ---> FuncA ---> FuncC - ---> FuncB - -(Explanation: main calls FuncA and FuncB; FuncA calls FuncC). -You can get from main to FuncA by using CTRL-] on the call to FuncA. Then -you can CTRL-] to get to FuncC. If you now want to go back to main you can -use CTRL-T twice. Then you can CTRL-] to FuncB. - -If you issue a ":ta {ident}" or CTRL-] command, this tag is inserted at the -current position in the stack. If the stack was full (it can hold up to 20 -entries), the oldest entry is deleted and the older entries shift one -position up (their index number is decremented by one). If the last used -entry was not at the bottom, the entries below the last used one are -deleted. This means that an old branch in the call graph is lost. After the -commands explained above the tag stack will look like this: - - # TO tag FROM line in file - 1 main 1 harddisk2:text/vim/test - 2 FuncB 59 harddisk2:text/vim/src/main.c - - *E73* -When you try to use the tag stack while it doesn't contain anything you will -get an error message. - -============================================================================== -3. Tag match list *tag-matchlist* *E427* *E428* - -When there are several matching tags, these commands can be used to jump -between them. Note that these command don't change the tag stack, they keep -the same entry. - - *:ts* *:tselect* -:ts[elect][!] [ident] List the tags that match [ident], using the - information in the tags file(s). - When [ident] is not given, the last tag name from the - tag stack is used. - With a '>' in the first column is indicated which is - the current position in the list (if there is one). - [ident] can be a regexp pattern, see |tag-regexp|. - See |tag-priority| for the priorities used in the - listing. {not in Vi} - Example output: - -> - nr pri kind tag file - 1 F f mch_delay os_amiga.c - mch_delay(msec, ignoreinput) - > 2 F f mch_delay os_msdos.c - mch_delay(msec, ignoreinput) - 3 F f mch_delay os_unix.c - mch_delay(msec, ignoreinput) - Enter nr of choice (<CR> to abort): -< - See |tag-priority| for the "pri" column. Note that - this depends on the current file, thus using - ":tselect xxx" can produce different results. - The "kind" column gives the kind of tag, if this was - included in the tags file. - The "info" column shows information that could be - found in the tags file. It depends on the program - that produced the tags file. - When the list is long, you may get the |more-prompt|. - If you already see the tag you want to use, you can - type 'q' and enter the number. - - *:sts* *:stselect* -:sts[elect][!] [ident] Does ":tselect[!] [ident]" and splits the window for - the selected tag. {not in Vi} - - *g]* -g] Like CTRL-], but use ":tselect" instead of ":tag". - {not in Vi} - - *v_g]* -{Visual}g] Same as "g]", but use the highlighted text as the - identifier. {not in Vi} - - *:tj* *:tjump* -:tj[ump][!] [ident] Like ":tselect", but jump to the tag directly when - there is only one match. {not in Vi} - - *:stj* *:stjump* -:stj[ump][!] [ident] Does ":tjump[!] [ident]" and splits the window for the - selected tag. {not in Vi} - - *g_CTRL-]* -g CTRL-] Like CTRL-], but use ":tjump" instead of ":tag". - {not in Vi} - - *v_g_CTRL-]* -{Visual}g CTRL-] Same as "g CTRL-]", but use the highlighted text as - the identifier. {not in Vi} - - *:tn* *:tnext* -:[count]tn[ext][!] Jump to [count] next matching tag (default 1). See - |tag-!| for [!]. {not in Vi} - - *:tp* *:tprevious* -:[count]tp[revious][!] Jump to [count] previous matching tag (default 1). - See |tag-!| for [!]. {not in Vi} - - *:tN* *:tNext* -:[count]tN[ext][!] Same as ":tprevious". {not in Vi} - - *:tr* *:trewind* -:[count]tr[ewind][!] Jump to first matching tag. If [count] is given, jump - to [count]th matching tag. See |tag-!| for [!]. {not - in Vi} - - *:tf* *:tfirst* -:[count]tf[irst][!] Same as ":trewind". {not in Vi} - - *:tl* *:tlast* -:tl[ast][!] Jump to last matching tag. See |tag-!| for [!]. {not - in Vi} - - *:lt* *:ltag* -:lt[ag][!] [ident] Jump to tag [ident] and add the matching tags to a new - location list for the current window. [ident] can be - a regexp pattern, see |tag-regexp|. When [ident] is - not given, the last tag name from the tag stack is - used. The search pattern to locate the tag line is - prefixed with "\V" to escape all the special - characters (very nomagic). The location list showing - the matching tags is independent of the tag stack. - See |tag-!| for [!]. - {not in Vi} - -When there is no other message, Vim shows which matching tag has been jumped -to, and the number of matching tags: > - tag 1 of 3 or more -The " or more" is used to indicate that Vim didn't try all the tags files yet. -When using ":tnext" a few times, or with ":tlast", more matches may be found. - -When you didn't see this message because of some other message, or you just -want to know where you are, this command will show it again (and jump to the -same tag as last time): > - :0tn -< - *tag-skip-file* -When a matching tag is found for which the file doesn't exist, this match is -skipped and the next matching tag is used. Vim reports this, to notify you of -missing files. When the end of the list of matches has been reached, an error -message is given. - - *tag-preview* -The tag match list can also be used in the preview window. The commands are -the same as above, with a "p" prepended. -{not available when compiled without the |+quickfix| feature} - - *:pts* *:ptselect* -:pts[elect][!] [ident] Does ":tselect[!] [ident]" and shows the new tag in a - "Preview" window. See |:ptag| for more info. - {not in Vi} - - *:ptj* *:ptjump* -:ptj[ump][!] [ident] Does ":tjump[!] [ident]" and shows the new tag in a - "Preview" window. See |:ptag| for more info. - {not in Vi} - - *:ptn* *:ptnext* -:[count]ptn[ext][!] ":tnext" in the preview window. See |:ptag|. - {not in Vi} - - *:ptp* *:ptprevious* -:[count]ptp[revious][!] ":tprevious" in the preview window. See |:ptag|. - {not in Vi} - - *:ptN* *:ptNext* -:[count]ptN[ext][!] Same as ":ptprevious". {not in Vi} - - *:ptr* *:ptrewind* -:[count]ptr[ewind][!] ":trewind" in the preview window. See |:ptag|. - {not in Vi} - - *:ptf* *:ptfirst* -:[count]ptf[irst][!] Same as ":ptrewind". {not in Vi} - - *:ptl* *:ptlast* -:ptl[ast][!] ":tlast" in the preview window. See |:ptag|. - {not in Vi} - -============================================================================== -4. Tags details *tag-details* - - *static-tag* -A static tag is a tag that is defined for a specific file. In a C program -this could be a static function. - -In Vi jumping to a tag sets the current search pattern. This means that -the "n" command after jumping to a tag does not search for the same pattern -that it did before jumping to the tag. Vim does not do this as we consider it -to be a bug. You can still find the tag search pattern in the search history. -If you really want the old Vi behavior, set the 't' flag in 'cpoptions'. - - *tag-binary-search* -Vim uses binary searching in the tags file to find the desired tag quickly -(when enabled at compile time |+tag_binary|). But this only works if the -tags file was sorted on ASCII byte value. Therefore, if no match was found, -another try is done with a linear search. If you only want the linear search, -reset the 'tagbsearch' option. Or better: Sort the tags file! - -Note that the binary searching is disabled when not looking for a tag with a -specific name. This happens when ignoring case and when a regular expression -is used that doesn't start with a fixed string. Tag searching can be a lot -slower then. The former can be avoided by case-fold sorting the tags file. -See 'tagbsearch' for details. - - *tag-regexp* -The ":tag" and "tselect" commands accept a regular expression argument. See -|pattern| for the special characters that can be used. -When the argument starts with '/', it is used as a pattern. If the argument -does not start with '/', it is taken literally, as a full tag name. -Examples: > - :tag main -< jumps to the tag "main" that has the highest priority. > - :tag /^get -< jumps to the tag that starts with "get" and has the highest priority. > - :tag /norm -< lists all the tags that contain "norm", including "id_norm". -When the argument both exists literally, and match when used as a regexp, a -literal match has a higher priority. For example, ":tag /open" matches "open" -before "open_file" and "file_open". -When using a pattern case is ignored. If you want to match case use "\C" in -the pattern. - - *tag-!* -If the tag is in the current file this will always work. Otherwise the -performed actions depend on whether the current file was changed, whether a ! -is added to the command and on the 'autowrite' option: - - tag in file autowrite ~ -current file changed ! option action ~ ------------------------------------------------------------------------------ - yes x x x goto tag - no no x x read other file, goto tag - no yes yes x abandon current file, read other file, goto - tag - no yes no on write current file, read other file, goto - tag - no yes no off fail ------------------------------------------------------------------------------ - -- If the tag is in the current file, the command will always work. -- If the tag is in another file and the current file was not changed, the - other file will be made the current file and read into the buffer. -- If the tag is in another file, the current file was changed and a ! is - added to the command, the changes to the current file are lost, the other - file will be made the current file and read into the buffer. -- If the tag is in another file, the current file was changed and the - 'autowrite' option is on, the current file will be written, the other - file will be made the current file and read into the buffer. -- If the tag is in another file, the current file was changed and the - 'autowrite' option is off, the command will fail. If you want to save - the changes, use the ":w" command and then use ":tag" without an argument. - This works because the tag is put on the stack anyway. If you want to lose - the changes you can use the ":tag!" command. - - *tag-security* -Note that Vim forbids some commands, for security reasons. This works like -using the 'secure' option for exrc/vimrc files in the current directory. See -|trojan-horse| and |sandbox|. -When the {tagaddress} changes a buffer, you will get a warning message: - "WARNING: tag command changed a buffer!!!" -In a future version changing the buffer will be impossible. All this for -security reasons: Somebody might hide a nasty command in the tags file, which -would otherwise go unnoticed. Example: > - :$d|/tag-function-name/ -{this security prevention is not present in Vi} - -In Vi the ":tag" command sets the last search pattern when the tag is searched -for. In Vim this is not done, the previous search pattern is still remembered, -unless the 't' flag is present in 'cpoptions'. The search pattern is always -put in the search history, so you can modify it if searching fails. - - *emacs-tags* *emacs_tags* *E430* -Emacs style tag files are only supported if Vim was compiled with the -|+emacs_tags| feature enabled. Sorry, there is no explanation about Emacs tag -files here, it is only supported for backwards compatibility :-). - - *tags-option* -The 'tags' option is a list of file names. Each of these files is searched -for the tag. This can be used to use a different tags file than the default -file "tags". It can also be used to access a common tags file. - -The next file in the list is not used when: -- A matching static tag for the current buffer has been found. -- A matching global tag has been found. -This also depends on the 'ignorecase' option. If it is off, and the tags file -only has a match without matching case, the next tags file is searched for a -match with matching case. If no tag with matching case is found, the first -match without matching case is used. If 'ignorecase' is on, and a matching -global tag with or without matching case is found, this one is used, no -further tags files are searched. - -When a tag file name starts with "./", the '.' is replaced with the path of -the current file. This makes it possible to use a tags file in the directory -where the current file is (no matter what the current directory is). The idea -of using "./" is that you can define which tag file is searched first: In the -current directory ("tags,./tags") or in the directory of the current file -("./tags,tags"). - -For example: > - :set tags=./tags,tags,/home/user/commontags - -In this example the tag will first be searched for in the file "tags" in the -directory where the current file is. Next the "tags" file in the current -directory. If it is not found there, then the file "/home/user/commontags" -will be searched for the tag. - -This can be switched off by including the 'd' flag in 'cpoptions', to make -it Vi compatible. "./tags" will then be the tags file in the current -directory, instead of the tags file in the directory where the current file -is. - -Instead of the comma a space may be used. Then a backslash is required for -the space to be included in the string option: > - :set tags=tags\ /home/user/commontags - -To include a space in a file name use three backslashes. To include a comma -in a file name use two backslashes. For example, use: > - :set tags=tag\\\ file,/home/user/common\\,tags - -for the files "tag file" and "/home/user/common,tags". The 'tags' option will -have the value "tag\ file,/home/user/common\,tags". - -If the 'tagrelative' option is on (which is the default) and using a tag file -in another directory, file names in that tag file are relative to the -directory where the tag file is. - -============================================================================== -5. Tags file format *tags-file-format* *E431* - - *ctags* *jtags* -A tags file can be created with an external command, for example "ctags". It -will contain a tag for each function. Some versions of "ctags" will also make -a tag for each "#defined" macro, typedefs, enums, etc. - -Some programs that generate tags files: -ctags As found on most Unix systems. Only supports C. Only - does the basic work. - *Exuberant_ctags* -exuberant ctags This a very good one. It works for C, C++, Java, - Fortran, Eiffel and others. It can generate tags for - many items. See http://ctags.sourceforge.net. -etags Connected to Emacs. Supports many languages. -JTags For Java, in Java. It can be found at - http://www.fleiner.com/jtags/. -ptags.py For Python, in Python. Found in your Python source - directory at Tools/scripts/ptags.py. -ptags For Perl, in Perl. It can be found at - http://www.eleves.ens.fr:8080/home/nthiery/Tags/. -gnatxref For Ada. See http://www.gnuada.org/. gnatxref is - part of the gnat package. - - -The lines in the tags file must have one of these three formats: - -1. {tagname} {TAB} {tagfile} {TAB} {tagaddress} -2. {tagfile}:{tagname} {TAB} {tagfile} {TAB} {tagaddress} -3. {tagname} {TAB} {tagfile} {TAB} {tagaddress} {term} {field} .. - -The first is a normal tag, which is completely compatible with Vi. It is the -only format produced by traditional ctags implementations. This is often used -for functions that are global, also referenced in other files. - -The lines in the tags file can end in <LF> or <CR><LF>. On the Macintosh <CR> -also works. The <CR> and <NL> characters can never appear inside a line. - - *tag-old-static* -The second format is for a static tag only. It is obsolete now, replaced by -the third format. It is only supported by Elvis 1.x and Vim and a few -versions of ctags. A static tag is often used for functions that are local, -only referenced in the file {tagfile}. Note that for the static tag, the two -occurrences of {tagfile} must be exactly the same. Also see |tags-option| -below, for how static tags are used. - -The third format is new. It includes additional information in optional -fields at the end of each line. It is backwards compatible with Vi. It is -only supported by new versions of ctags (such as Exuberant ctags). - -{tagname} The identifier. Normally the name of a function, but it can - be any identifier. It cannot contain a <Tab>. -{TAB} One <Tab> character. Note: previous versions allowed any - white space here. This has been abandoned to allow spaces in - {tagfile}. It can be re-enabled by including the - |+tag_any_white| feature at compile time. *tag-any-white* -{tagfile} The file that contains the definition of {tagname}. It can - have an absolute or relative path. It may contain environment - variables and wildcards (although the use of wildcards is - doubtful). It cannot contain a <Tab>. -{tagaddress} The Ex command that positions the cursor on the tag. It can - be any Ex command, although restrictions apply (see - |tag-security|). Posix only allows line numbers and search - commands, which are mostly used. -{term} ;" The two characters semicolon and double quote. This is - interpreted by Vi as the start of a comment, which makes the - following be ignored. This is for backwards compatibility - with Vi, it ignores the following fields. -{field} .. A list of optional fields. Each field has the form: - - <Tab>{fieldname}:{value} - - The {fieldname} identifies the field, and can only contain - alphabetical characters [a-zA-Z]. - The {value} is any string, but cannot contain a <Tab>. - These characters are special: - "\t" stands for a <Tab> - "\r" stands for a <CR> - "\n" stands for a <NL> - "\\" stands for a single '\' character - - There is one field that doesn't have a ':'. This is the kind - of the tag. It is handled like it was preceded with "kind:". - See the documentation of ctags for the kinds it produces. - - The only other field currently recognized by Vim is "file:" - (with an empty value). It is used for a static tag. - -The first lines in the tags file can contain lines that start with - !_TAG_ -These are sorted to the first lines, only rare tags that start with "!" can -sort to before them. Vim recognizes two items. The first one is the line -that indicates if the file was sorted. When this line is found, Vim uses -binary searching for the tags file: - !_TAG_FILE_SORTED<Tab>1<Tab>{anything} ~ - -A tag file may be case-fold sorted to avoid a linear search when 'ignorecase' -is on. See 'tagbsearch' for details. The value '2' should be used then: - !_TAG_FILE_SORTED<Tab>2<Tab>{anything} ~ - -The other tag that Vim recognizes, but only when compiled with the -|+multi_byte| feature, is the encoding of the tags file: - !_TAG_FILE_ENCODING<Tab>utf-8<Tab>{anything} ~ -Here "utf-8" is the encoding used for the tags. Vim will then convert the tag -being searched for from 'encoding' to the encoding of the tags file. And when -listing tags the reverse happens. When the conversion fails the unconverted -tag is used. - - *tag-search* -The command can be any Ex command, but often it is a search command. -Examples: - tag1 file1 /^main(argc, argv)/ ~ - tag2 file2 108 ~ - -The command is always executed with 'magic' not set. The only special -characters in a search pattern are "^" (begin-of-line) and "$" (<EOL>). -See |pattern|. Note that you must put a backslash before each backslash in -the search text. This is for backwards compatibility with Vi. - - *E434* *E435* -If the command is a normal search command (it starts and ends with "/" or -"?"), some special handling is done: -- Searching starts on line 1 of the file. - The direction of the search is forward for "/", backward for "?". - Note that 'wrapscan' does not matter, the whole file is always searched. (Vi - does use 'wrapscan', which caused tags sometimes not be found.) {Vi starts - searching in line 2 of another file. It does not find a tag in line 1 of - another file when 'wrapscan' is not set} -- If the search fails, another try is done ignoring case. If that fails too, - a search is done for: - "^tagname[ \t]*(" - (the tag with '^' prepended and "[ \t]*(" appended). When using function - names, this will find the function name when it is in column 0. This will - help when the arguments to the function have changed since the tags file was - made. If this search also fails another search is done with: - "^[#a-zA-Z_].*\<tagname[ \t]*(" - This means: A line starting with '#' or an identifier and containing the tag - followed by white space and a '('. This will find macro names and function - names with a type prepended. {the extra searches are not in Vi} - -============================================================================== -6. Include file searches *include-search* *definition-search* - *E387* *E388* *E389* - -These commands look for a string in the current file and in all encountered -included files (recursively). This can be used to find the definition of a -variable, function or macro. If you only want to search in the current -buffer, use the commands listed at |pattern-searches|. - -These commands are not available when the |+find_in_path| feature was disabled -at compile time. - -When a line is encountered that includes another file, that file is searched -before continuing in the current buffer. Files included by included files are -also searched. When an include file could not be found it is silently -ignored. Use the |:checkpath| command to discover which files could not be -found, possibly your 'path' option is not set up correctly. Note: the -included file is searched, not a buffer that may be editing that file. Only -for the current file the lines in the buffer are used. - -The string can be any keyword or a defined macro. For the keyword any match -will be found. For defined macros only lines that match with the 'define' -option will be found. The default is "^#\s*define", which is for C programs. -For other languages you probably want to change this. See 'define' for an -example for C++. The string cannot contain an end-of-line, only matches -within a line are found. - -When a match is found for a defined macro, the displaying of lines continues -with the next line when a line ends in a backslash. - -The commands that start with "[" start searching from the start of the current -file. The commands that start with "]" start at the current cursor position. - -The 'include' option is used to define a line that includes another file. The -default is "\^#\s*include", which is for C programs. Note: Vim does not -recognize C syntax, if the 'include' option matches a line inside -"#ifdef/#endif" or inside a comment, it is searched anyway. The 'isfname' -option is used to recognize the file name that comes after the matched -pattern. - -The 'path' option is used to find the directory for the include files that -do not have an absolute path. - -The 'comments' option is used for the commands that display a single line or -jump to a line. It defines patterns that may start a comment. Those lines -are ignored for the search, unless [!] is used. One exception: When the line -matches the pattern "^# *define" it is not considered to be a comment. - -If you want to list matches, and then select one to jump to, you could use a -mapping to do that for you. Here is an example: > - - :map <F4> [I:let nr = input("Which one: ")<Bar>exe "normal " . nr ."[\t"<CR> -< - *[i* -[i Display the first line that contains the keyword - under the cursor. The search starts at the beginning - of the file. Lines that look like a comment are - ignored (see 'comments' option). If a count is given, - the count'th matching line is displayed, and comment - lines are not ignored. {not in Vi} - - *]i* -]i like "[i", but start at the current cursor position. - {not in Vi} - - *:is* *:isearch* -:[range]is[earch][!] [count] [/]pattern[/] - Like "[i" and "]i", but search in [range] lines - (default: whole file). - See |:search-args| for [/] and [!]. {not in Vi} - - *[I* -[I Display all lines that contain the keyword under the - cursor. Filenames and line numbers are displayed - for the found lines. The search starts at the - beginning of the file. {not in Vi} - - *]I* -]I like "[I", but start at the current cursor position. - {not in Vi} - - *:il* *:ilist* -:[range]il[ist][!] [/]pattern[/] - Like "[I" and "]I", but search in [range] lines - (default: whole file). - See |:search-args| for [/] and [!]. {not in Vi} - - *[_CTRL-I* -[ CTRL-I Jump to the first line that contains the keyword - under the cursor. The search starts at the beginning - of the file. Lines that look like a comment are - ignored (see 'comments' option). If a count is given, - the count'th matching line is jumped to, and comment - lines are not ignored. {not in Vi} - - *]_CTRL-I* -] CTRL-I like "[ CTRL-I", but start at the current cursor - position. {not in Vi} - - *:ij* *:ijump* -:[range]ij[ump][!] [count] [/]pattern[/] - Like "[ CTRL-I" and "] CTRL-I", but search in - [range] lines (default: whole file). - See |:search-args| for [/] and [!]. {not in Vi} - -CTRL-W CTRL-I *CTRL-W_CTRL-I* *CTRL-W_i* -CTRL-W i Open a new window, with the cursor on the first line - that contains the keyword under the cursor. The - search starts at the beginning of the file. Lines - that look like a comment line are ignored (see - 'comments' option). If a count is given, the count'th - matching line is jumped to, and comment lines are not - ignored. {not in Vi} - - *:isp* *:isplit* -:[range]isp[lit][!] [count] [/]pattern[/] - Like "CTRL-W i" and "CTRL-W i", but search in - [range] lines (default: whole file). - See |:search-args| for [/] and [!]. {not in Vi} - - *[d* -[d Display the first macro definition that contains the - macro under the cursor. The search starts from the - beginning of the file. If a count is given, the - count'th matching line is displayed. {not in Vi} - - *]d* -]d like "[d", but start at the current cursor position. - {not in Vi} - - *:ds* *:dsearch* -:[range]ds[earch][!] [count] [/]string[/] - Like "[d" and "]d", but search in [range] lines - (default: whole file). - See |:search-args| for [/] and [!]. {not in Vi} - - *[D* -[D Display all macro definitions that contain the macro - under the cursor. Filenames and line numbers are - displayed for the found lines. The search starts - from the beginning of the file. {not in Vi} - - *]D* -]D like "[D", but start at the current cursor position. - {not in Vi} - - *:dli* *:dlist* -:[range]dl[ist][!] [/]string[/] - Like "[D" and "]D", but search in [range] lines - (default: whole file). - See |:search-args| for [/] and [!]. {not in Vi} - Note that ":dl" works like ":delete" with the "l" - flag. - - *[_CTRL-D* -[ CTRL-D Jump to the first macro definition that contains the - keyword under the cursor. The search starts from - the beginning of the file. If a count is given, the - count'th matching line is jumped to. {not in Vi} - - *]_CTRL-D* -] CTRL-D like "[ CTRL-D", but start at the current cursor - position. {not in Vi} - - *:dj* *:djump* -:[range]dj[ump][!] [count] [/]string[/] - Like "[ CTRL-D" and "] CTRL-D", but search in - [range] lines (default: whole file). - See |:search-args| for [/] and [!]. {not in Vi} - -CTRL-W CTRL-D *CTRL-W_CTRL-D* *CTRL-W_d* -CTRL-W d Open a new window, with the cursor on the first - macro definition line that contains the keyword - under the cursor. The search starts from the - beginning of the file. If a count is given, the - count'th matching line is jumped to. {not in Vi} - - *:dsp* *:dsplit* -:[range]dsp[lit][!] [count] [/]string[/] - Like "CTRL-W d", but search in [range] lines - (default: whole file). - See |:search-args| for [/] and [!]. {not in Vi} - - *:che* *:checkpath* -:che[ckpath] List all the included files that could not be found. - {not in Vi} - -:che[ckpath]! List all the included files. {not in Vi} - - *:search-args* -Common arguments for the commands above: -[!] When included, find matches in lines that are recognized as comments. - When excluded, a match is ignored when the line is recognized as a - comment (according to 'comments'), or the match is in a C comment (after - "//" or inside /* */). Note that a match may be missed if a line is - recognized as a comment, but the comment ends halfway the line. - And if the line is a comment, but it is not recognized (according to - 'comments') a match may be found in it anyway. Example: > - /* comment - foobar */ -< A match for "foobar" is found, because this line is not recognized as a - comment (even though syntax highlighting does recognize it). - Note: Since a macro definition mostly doesn't look like a comment, the - [!] makes no difference for ":dlist", ":dsearch" and ":djump". -[/] A pattern can be surrounded by '/'. Without '/' only whole words are - matched, using the pattern "\<pattern\>". Only after the second '/' a - next command can be appended with '|'. Example: > - :isearch /string/ | echo "the last one" -< For a ":djump", ":dsplit", ":dlist" and ":dsearch" command the pattern - is used as a literal string, not as a search pattern. - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/term.txt b/share/vim/vim72/doc/term.txt deleted file mode 100644 index 3df065653e..0000000000 --- a/share/vim/vim72/doc/term.txt +++ /dev/null @@ -1,861 +0,0 @@ -*term.txt* For Vim version 7.2. Last change: 2008 Jun 21 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Terminal information *terminal-info* - -Vim uses information about the terminal you are using to fill the screen and -recognize what keys you hit. If this information is not correct, the screen -may be messed up or keys may not be recognized. The actions which have to be -performed on the screen are accomplished by outputting a string of -characters. Special keys produce a string of characters. These strings are -stored in the terminal options, see |terminal-options|. - -NOTE: Most of this is not used when running the |GUI|. - -1. Startup |startup-terminal| -2. Terminal options |terminal-options| -3. Window size |window-size| -4. Slow and fast terminals |slow-fast-terminal| -5. Using the mouse |mouse-using| - -============================================================================== -1. Startup *startup-terminal* - -When Vim is started a default terminal type is assumed. For the Amiga this is -a standard CLI window, for MS-DOS the pc terminal, for Unix an ansi terminal. -A few other terminal types are always available, see below |builtin-terms|. - -You can give the terminal name with the '-T' Vim argument. If it is not given -Vim will try to get the name from the TERM environment variable. - - *termcap* *terminfo* *E557* *E558* *E559* -On Unix the terminfo database or termcap file is used. This is referred to as -"termcap" in all the documentation. At compile time, when running configure, -the choice whether to use terminfo or termcap is done automatically. When -running Vim the output of ":version" will show |+terminfo| if terminfo is -used. Also see |xterm-screens|. - -On non-Unix systems a termcap is only available if Vim was compiled with -TERMCAP defined. - - *builtin-terms* *builtin_terms* -Which builtin terminals are available depends on a few defines in feature.h, -which need to be set at compile time: - define output of ":version" terminals builtin ~ -NO_BUILTIN_TCAPS -builtin_terms none -SOME_BUILTIN_TCAPS +builtin_terms most common ones (default) -ALL_BUILTIN_TCAPS ++builtin_terms all available - -You can see a list of available builtin terminals with ":set term=xxx" (when -not running the GUI). Also see |+builtin_terms|. - -If the termcap code is included Vim will try to get the strings for the -terminal you are using from the termcap file and the builtin termcaps. Both -are always used, if an entry for the terminal you are using is present. Which -one is used first depends on the 'ttybuiltin' option: - -'ttybuiltin' on 1: builtin termcap 2: external termcap -'ttybuiltin' off 1: external termcap 2: builtin termcap - -If an option is missing in one of them, it will be obtained from the other -one. If an option is present in both, the one first encountered is used. - -Which external termcap file is used varies from system to system and may -depend on the environment variables "TERMCAP" and "TERMPATH". See "man -tgetent". - -Settings depending on terminal *term-dependent-settings* - -If you want to set options or mappings, depending on the terminal name, you -can do this best in your .vimrc. Example: > - - if &term == "xterm" - ... xterm maps and settings ... - elseif &term =~ "vt10." - ... vt100, vt102 maps and settings ... - endif -< - *raw-terminal-mode* -For normal editing the terminal will be put into "raw" mode. The strings -defined with 't_ti' and 't_ks' will be sent to the terminal. Normally this -puts the terminal in a state where the termcap codes are valid and activates -the cursor and function keys. When Vim exits the terminal will be put back -into the mode it was before Vim started. The strings defined with 't_te' and -'t_ke' will be sent to the terminal. On the Amiga, with commands that execute -an external command (e.g., "!!"), the terminal will be put into Normal mode -for a moment. This means that you can stop the output to the screen by -hitting a printing key. Output resumes when you hit <BS>. - - *cs7-problem* -Note: If the terminal settings are changed after running Vim, you might have -an illegal combination of settings. This has been reported on Solaris 2.5 -with "stty cs8 parenb", which is restored as "stty cs7 parenb". Use -"stty cs8 -parenb -istrip" instead, this is restored correctly. - -Some termcap entries are wrong in the sense that after sending 't_ks' the -cursor keys send codes different from the codes defined in the termcap. To -avoid this you can set 't_ks' (and 't_ke') to empty strings. This must be -done during initialization (see |initialization|), otherwise it's too late. - -Some termcap entries assume that the highest bit is always reset. For -example: The cursor-up entry for the Amiga could be ":ku=\E[A:". But the -Amiga really sends "\233A". This works fine if the highest bit is reset, -e.g., when using an Amiga over a serial line. If the cursor keys don't work, -try the entry ":ku=\233A:". - -Some termcap entries have the entry ":ku=\E[A:". But the Amiga really sends -"\233A". On output "\E[" and "\233" are often equivalent, on input they -aren't. You will have to change the termcap entry, or change the key code with -the :set command to fix this. - -Many cursor key codes start with an <Esc>. Vim must find out if this is a -single hit of the <Esc> key or the start of a cursor key sequence. It waits -for a next character to arrive. If it does not arrive within one second a -single <Esc> is assumed. On very slow systems this may fail, causing cursor -keys not to work sometimes. If you discover this problem reset the 'timeout' -option. Vim will wait for the next character to arrive after an <Esc>. If -you want to enter a single <Esc> you must type it twice. Resetting the -'esckeys' option avoids this problem in Insert mode, but you lose the -possibility to use cursor and function keys in Insert mode. - -On the Amiga the recognition of window resizing is activated only when the -terminal name is "amiga" or "builtin_amiga". - -Some terminals have confusing codes for the cursor keys. The televideo 925 is -such a terminal. It sends a CTRL-H for cursor-left. This would make it -impossible to distinguish a backspace and cursor-left. To avoid this problem -CTRL-H is never recognized as cursor-left. - - *vt100-cursor-keys* *xterm-cursor-keys* -Other terminals (e.g., vt100 and xterm) have cursor keys that send <Esc>OA, -<Esc>OB, etc. Unfortunately these are valid commands in insert mode: Stop -insert, Open a new line above the new one, start inserting 'A', 'B', etc. -Instead of performing these commands Vim will erroneously recognize this typed -key sequence as a cursor key movement. To avoid this and make Vim do what you -want in either case you could use these settings: > - :set notimeout " don't timeout on mappings - :set ttimeout " do timeout on terminal key codes - :set timeoutlen=100 " timeout after 100 msec -This requires the key-codes to be sent within 100 msec in order to recognize -them as a cursor key. When you type you normally are not that fast, so they -are recognized as individual typed commands, even though Vim receives the same -sequence of bytes. - - *vt100-function-keys* *xterm-function-keys* -An xterm can send function keys F1 to F4 in two modes: vt100 compatible or -not. Because Vim may not know what the xterm is sending, both types of keys -are recognized. The same happens for the <Home> and <End> keys. - normal vt100 ~ - <F1> t_k1 <Esc>[11~ <xF1> <Esc>OP *<xF1>-xterm* - <F2> t_k2 <Esc>[12~ <xF2> <Esc>OQ *<xF2>-xterm* - <F3> t_k3 <Esc>[13~ <xF3> <Esc>OR *<xF3>-xterm* - <F4> t_k4 <Esc>[14~ <xF4> <Esc>OS *<xF4>-xterm* - <Home> t_kh <Esc>[7~ <xHome> <Esc>OH *<xHome>-xterm* - <End> t_@7 <Esc>[4~ <xEnd> <Esc>OF *<xEnd>-xterm* - -When Vim starts, <xF1> is mapped to <F1>, <xF2> to <F2> etc. This means that -by default both codes do the same thing. If you make a mapping for <xF2>, -because your terminal does have two keys, the default mapping is overwritten, -thus you can use the <F2> and <xF2> keys for something different. - - *xterm-shifted-keys* -Newer versions of xterm support shifted function keys and special keys. Vim -recognizes most of them. Use ":set termcap" to check which are supported and -what the codes are. Mostly these are not in a termcap, they are only -supported by the builtin_xterm termcap. - - *xterm-modifier-keys* -Newer versions of xterm support Alt and Ctrl for most function keys. To avoid -having to add all combinations of Alt, Ctrl and Shift for every key a special -sequence is recognized at the end of a termcap entry: ";*X". The "X" can be -any character, often '~' is used. The ";*" stands for an optional modifier -argument. ";2" is Shift, ";3" is Alt, ";5" is Ctrl and ";9" is Meta (when -it's different from Alt). They can be combined. Examples: > - :set <F8>=^[[19;*~ - :set <Home>=^[[1;*H -Another speciality about these codes is that they are not overwritten by -another code. That is to avoid that the codes obtained from xterm directly -|t_RV| overwrite them. - *xterm-scroll-region* -The default termcap entry for xterm on Sun and other platforms does not -contain the entry for scroll regions. Add ":cs=\E[%i%d;%dr:" to the xterm -entry in /etc/termcap and everything should work. - - *xterm-end-home-keys* -On some systems (at least on FreeBSD with XFree86 3.1.2) the codes that the -<End> and <Home> keys send contain a <Nul> character. To make these keys send -the proper key code, add these lines to your ~/.Xdefaults file: - -*VT100.Translations: #override \n\ - <Key>Home: string("0x1b") string("[7~") \n\ - <Key>End: string("0x1b") string("[8~") - - *xterm-8bit* *xterm-8-bit* -Xterm can be run in a mode where it uses 8-bit escape sequences. The CSI code -is used instead of <Esc>[. The advantage is that an <Esc> can quickly be -recognized in Insert mode, because it can't be confused with the start of a -special key. -For the builtin termcap entries, Vim checks if the 'term' option contains -"8bit" anywhere. It then uses 8-bit characters for the termcap entries, the -mouse and a few other things. You would normally set $TERM in your shell to -"xterm-8bit" and Vim picks this up and adjusts to the 8-bit setting -automatically. -When Vim receives a response to the |t_RV| (request version) sequence and it -starts with CSI, it assumes that the terminal is in 8-bit mode and will -convert all key sequences to their 8-bit variants. - -============================================================================== -2. Terminal options *terminal-options* *termcap-options* *E436* - -The terminal options can be set just like normal options. But they are not -shown with the ":set all" command. Instead use ":set termcap". - -It is always possible to change individual strings by setting the -appropriate option. For example: > - :set t_ce=^V^[[K (CTRL-V, <Esc>, [, K) - -{Vi: no terminal options. You have to exit Vi, edit the termcap entry and -try again} - -The options are listed below. The associated termcap code is always equal to -the last two characters of the option name. Only one termcap code is -required: Cursor motion, 't_cm'. - -The options 't_da', 't_db', 't_ms', 't_xs' represent flags in the termcap. -When the termcap flag is present, the option will be set to "y". But any -non-empty string means that the flag is set. An empty string means that the -flag is not set. 't_CS' works like this too, but it isn't a termcap flag. - -OUTPUT CODES - option meaning ~ - - t_AB set background color (ANSI) *t_AB* *'t_AB'* - t_AF set foreground color (ANSI) *t_AF* *'t_AF'* - t_AL add number of blank lines *t_AL* *'t_AL'* - t_al add new blank line *t_al* *'t_al'* - t_bc backspace character *t_bc* *'t_bc'* - t_cd clear to end of screen *t_cd* *'t_cd'* - t_ce clear to end of line *t_ce* *'t_ce'* - t_cl clear screen *t_cl* *'t_cl'* - t_cm cursor motion (required!) *E437* *t_cm* *'t_cm'* - t_Co number of colors *t_Co* *'t_Co'* - t_CS if non-empty, cursor relative to scroll region *t_CS* *'t_CS'* - t_cs define scrolling region *t_cs* *'t_cs'* - t_CV define vertical scrolling region *t_CV* *'t_CV'* - t_da if non-empty, lines from above scroll down *t_da* *'t_da'* - t_db if non-empty, lines from below scroll up *t_db* *'t_db'* - t_DL delete number of lines *t_DL* *'t_DL'* - t_dl delete line *t_dl* *'t_dl'* - t_fs set window title end (from status line) *t_fs* *'t_fs'* - t_ke exit "keypad transmit" mode *t_ke* *'t_ke'* - t_ks start "keypad transmit" mode *t_ks* *'t_ks'* - t_le move cursor one char left *t_le* *'t_le'* - t_mb blinking mode *t_mb* *'t_mb'* - t_md bold mode *t_md* *'t_md'* - t_me Normal mode (undoes t_mr, t_mb, t_md and color) *t_me* *'t_me'* - t_mr reverse (invert) mode *t_mr* *'t_mr'* - *t_ms* *'t_ms'* - t_ms if non-empty, cursor can be moved in standout/inverse mode - t_nd non destructive space character *t_nd* *'t_nd'* - t_op reset to original color pair *t_op* *'t_op'* - t_RI cursor number of chars right *t_RI* *'t_RI'* - t_Sb set background color *t_Sb* *'t_Sb'* - t_Sf set foreground color *t_Sf* *'t_Sf'* - t_se standout end *t_se* *'t_se'* - t_so standout mode *t_so* *'t_so'* - t_sr scroll reverse (backward) *t_sr* *'t_sr'* - t_te out of "termcap" mode *t_te* *'t_te'* - t_ti put terminal in "termcap" mode *t_ti* *'t_ti'* - t_ts set window title start (to status line) *t_ts* *'t_ts'* - t_ue underline end *t_ue* *'t_ue'* - t_us underline mode *t_us* *'t_us'* - t_Ce undercurl end *t_Ce* *'t_Ce'* - t_Cs undercurl mode *t_Cs* *'t_Cs'* - t_ut clearing uses the current background color *t_ut* *'t_ut'* - t_vb visual bell *t_vb* *'t_vb'* - t_ve cursor visible *t_ve* *'t_ve'* - t_vi cursor invisible *t_vi* *'t_vi'* - t_vs cursor very visible *t_vs* *'t_vs'* - *t_xs* *'t_xs'* - t_xs if non-empty, standout not erased by overwriting (hpterm) - t_ZH italics mode *t_ZH* *'t_ZH'* - t_ZR italics end *t_ZR* *'t_ZR'* - -Added by Vim (there are no standard codes for these): - t_IS set icon text start *t_IS* *'t_IS'* - t_IE set icon text end *t_IE* *'t_IE'* - t_WP set window position (Y, X) in pixels *t_WP* *'t_WP'* - t_WS set window size (height, width) in characters *t_WS* *'t_WS'* - t_SI start insert mode (bar cursor shape) *t_SI* *'t_SI'* - t_EI end insert mode (block cursor shape) *t_EI* *'t_EI'* - |termcap-cursor-shape| - t_RV request terminal version string (for xterm) *t_RV* *'t_RV'* - |xterm-8bit| |v:termresponse| |'ttymouse'| |xterm-codes| - -KEY CODES -Note: Use the <> form if possible - - option name meaning ~ - - t_ku <Up> arrow up *t_ku* *'t_ku'* - t_kd <Down> arrow down *t_kd* *'t_kd'* - t_kr <Right> arrow right *t_kr* *'t_kr'* - t_kl <Left> arrow left *t_kl* *'t_kl'* - <xUp> alternate arrow up *<xUp>* - <xDown> alternate arrow down *<xDown>* - <xRight> alternate arrow right *<xRight>* - <xLeft> alternate arrow left *<xLeft>* - <S-Up> shift arrow up - <S-Down> shift arrow down - t_%i <S-Right> shift arrow right *t_%i* *'t_%i'* - t_#4 <S-Left> shift arrow left *t_#4* *'t_#4'* - t_k1 <F1> function key 1 *t_k1* *'t_k1'* - <xF1> alternate F1 *<xF1>* - t_k2 <F2> function key 2 *<F2>* *t_k2* *'t_k2'* - <xF2> alternate F2 *<xF2>* - t_k3 <F3> function key 3 *<F3>* *t_k3* *'t_k3'* - <xF3> alternate F3 *<xF3>* - t_k4 <F4> function key 4 *<F4>* *t_k4* *'t_k4'* - <xF4> alternate F4 *<xF4>* - t_k5 <F5> function key 5 *<F5>* *t_k5* *'t_k5'* - t_k6 <F6> function key 6 *<F6>* *t_k6* *'t_k6'* - t_k7 <F7> function key 7 *<F7>* *t_k7* *'t_k7'* - t_k8 <F8> function key 8 *<F8>* *t_k8* *'t_k8'* - t_k9 <F9> function key 9 *<F9>* *t_k9* *'t_k9'* - t_k; <F10> function key 10 *<F10>* *t_k;* *'t_k;'* - t_F1 <F11> function key 11 *<F11>* *t_F1* *'t_F1'* - t_F2 <F12> function key 12 *<F12>* *t_F2* *'t_F2'* - t_F3 <F13> function key 13 *<F13>* *t_F3* *'t_F3'* - t_F4 <F14> function key 14 *<F14>* *t_F4* *'t_F4'* - t_F5 <F15> function key 15 *<F15>* *t_F5* *'t_F5'* - t_F6 <F16> function key 16 *<F16>* *t_F6* *'t_F6'* - t_F7 <F17> function key 17 *<F17>* *t_F7* *'t_F7'* - t_F8 <F18> function key 18 *<F18>* *t_F8* *'t_F8'* - t_F9 <F19> function key 19 *<F19>* *t_F9* *'t_F9'* - <S-F1> shifted function key 1 - <S-xF1> alternate <S-F1> *<S-xF1>* - <S-F2> shifted function key 2 *<S-F2>* - <S-xF2> alternate <S-F2> *<S-xF2>* - <S-F3> shifted function key 3 *<S-F3>* - <S-xF3> alternate <S-F3> *<S-xF3>* - <S-F4> shifted function key 4 *<S-F4>* - <S-xF4> alternate <S-F4> *<S-xF4>* - <S-F5> shifted function key 5 *<S-F5>* - <S-F6> shifted function key 6 *<S-F6>* - <S-F7> shifted function key 7 *<S-F7>* - <S-F8> shifted function key 8 *<S-F8>* - <S-F9> shifted function key 9 *<S-F9>* - <S-F10> shifted function key 10 *<S-F10>* - <S-F11> shifted function key 11 *<S-F11>* - <S-F12> shifted function key 12 *<S-F12>* - t_%1 <Help> help key *t_%1* *'t_%1'* - t_&8 <Undo> undo key *t_&8* *'t_&8'* - t_kI <Insert> insert key *t_kI* *'t_kI'* - t_kD <Del> delete key *t_kD* *'t_kD'* - t_kb <BS> backspace key *t_kb* *'t_kb'* - t_kB <S-Tab> back-tab (shift-tab) *<S-Tab>* *t_kB* *'t_kB'* - t_kh <Home> home key *t_kh* *'t_kh'* - t_#2 <S-Home> shifted home key *<S-Home>* *t_#2* *'t_#2'* - <xHome> alternate home key *<xHome>* - t_@7 <End> end key *t_@7* *'t_@7'* - t_*7 <S-End> shifted end key *<S-End>* *t_star7* *'t_star7'* - <xEnd> alternate end key *<xEnd>* - t_kP <PageUp> page-up key *t_kP* *'t_kP'* - t_kN <PageDown> page-down key *t_kN* *'t_kN'* - t_K1 <kHome> keypad home key *t_K1* *'t_K1'* - t_K4 <kEnd> keypad end key *t_K4* *'t_K4'* - t_K3 <kPageUp> keypad page-up key *t_K3* *'t_K3'* - t_K5 <kPageDown> keypad page-down key *t_K5* *'t_K5'* - t_K6 <kPlus> keypad plus key *<kPlus>* *t_K6* *'t_K6'* - t_K7 <kMinus> keypad minus key *<kMinus>* *t_K7* *'t_K7'* - t_K8 <kDivide> keypad divide *<kDivide>* *t_K8* *'t_K8'* - t_K9 <kMultiply> keypad multiply *<kMultiply>* *t_K9* *'t_K9'* - t_KA <kEnter> keypad enter key *<kEnter>* *t_KA* *'t_KA'* - t_KB <kPoint> keypad decimal point *<kPoint>* *t_KB* *'t_KB'* - t_KC <k0> keypad 0 *<k0>* *t_KC* *'t_KC'* - t_KD <k1> keypad 1 *<k1>* *t_KD* *'t_KD'* - t_KE <k2> keypad 2 *<k2>* *t_KE* *'t_KE'* - t_KF <k3> keypad 3 *<k3>* *t_KF* *'t_KF'* - t_KG <k4> keypad 4 *<k4>* *t_KG* *'t_KG'* - t_KH <k5> keypad 5 *<k5>* *t_KH* *'t_KH'* - t_KI <k6> keypad 6 *<k6>* *t_KI* *'t_KI'* - t_KJ <k7> keypad 7 *<k7>* *t_KJ* *'t_KJ'* - t_KK <k8> keypad 8 *<k8>* *t_KK* *'t_KK'* - t_KL <k9> keypad 9 *<k9>* *t_KL* *'t_KL'* - <Mouse> leader of mouse code *<Mouse>* - -Note about t_so and t_mr: When the termcap entry "so" is not present the -entry for "mr" is used. And vice versa. The same is done for "se" and "me". -If your terminal supports both inversion and standout mode, you can see two -different modes. If your terminal supports only one of the modes, both will -look the same. - - *keypad-comma* -The keypad keys, when they are not mapped, behave like the equivalent normal -key. There is one exception: if you have a comma on the keypad instead of a -decimal point, Vim will use a dot anyway. Use these mappings to fix that: > - :noremap <kPoint> , - :noremap! <kPoint> , -< *xterm-codes* -There is a special trick to obtain the key codes which currently only works -for xterm. When |t_RV| is defined and a response is received which indicates -an xterm with patchlevel 141 or higher, Vim uses special escape sequences to -request the key codes directly from the xterm. The responses are used to -adjust the various t_ codes. This avoids the problem that the xterm can -produce different codes, depending on the mode it is in (8-bit, VT102, -VT220, etc.). The result is that codes like <xF1> are no longer needed. -Note: This is only done on startup. If the xterm options are changed after -Vim has started, the escape sequences may not be recognized any more. - - *termcap-colors* -Note about colors: The 't_Co' option tells Vim the number of colors available. -When it is non-zero, the 't_AB' and 't_AF' options are used to set the color. -If one of these is not available, 't_Sb' and 't_Sf' are used. 't_me' is used -to reset to the default colors. - - *termcap-cursor-shape* *termcap-cursor-color* -When Vim enters Insert mode the 't_SI' escape sequence is sent. When leaving -Insert mode 't_EI' is used. But only if both are defined. This can be used -to change the shape or color of the cursor in Insert mode. These are not -standard termcap/terminfo entries, you need to set them yourself. -Example for an xterm, this changes the color of the cursor: > - if &term =~ "xterm" - let &t_SI = "\<Esc>]12;purple\x7" - let &t_EI = "\<Esc>]12;blue\x7" - endif -NOTE: When Vim exits the shape for Normal mode will remain. The shape from -before Vim started will not be restored. -{not available when compiled without the +cursorshape feature} - - *termcap-title* -The 't_ts' and 't_fs' options are used to set the window title if the terminal -allows title setting via sending strings. They are sent before and after the -title string, respectively. Similar 't_IS' and 't_IE' are used to set the -icon text. These are Vim-internal extensions of the Unix termcap, so they -cannot be obtained from an external termcap. However, the builtin termcap -contains suitable entries for xterm and iris-ansi, so you don't need to set -them here. - *hpterm* -If inversion or other highlighting does not work correctly, try setting the -'t_xs' option to a non-empty string. This makes the 't_ce' code be used to -remove highlighting from a line. This is required for "hpterm". Setting the -'weirdinvert' option has the same effect as making 't_xs' non-empty, and vice -versa. - - *scroll-region* -Some termcaps do not include an entry for 'cs' (scroll region), although the -terminal does support it. For example: xterm on a Sun. You can use the -builtin_xterm or define t_cs yourself. For example: > - :set t_cs=^V^[[%i%d;%dr -Where ^V is CTRL-V and ^[ is <Esc>. - -The vertical scroll region t_CV is not a standard termcap code. Vim uses it -internally in the GUI. But it can also be defined for a terminal, if you can -find one that supports it. The two arguments are the left and right column of -the region which to restrict the scrolling to. Just like t_cs defines the top -and bottom lines. Defining t_CV will make scrolling in vertically split -windows a lot faster. Don't set t_CV when t_da or t_db is set (text isn't -cleared when scrolling). - -Unfortunately it is not possible to deduce from the termcap how cursor -positioning should be done when using a scrolling region: Relative to the -beginning of the screen or relative to the beginning of the scrolling region. -Most terminals use the first method. A known exception is the MS-DOS console -(pcterm). The 't_CS' option should be set to any string when cursor -positioning is relative to the start of the scrolling region. It should be -set to an empty string otherwise. It defaults to "yes" when 'term' is -"pcterm". - -Note for xterm users: The shifted cursor keys normally don't work. You can - make them work with the xmodmap command and some mappings in Vim. - - Give these commands in the xterm: - xmodmap -e "keysym Up = Up F13" - xmodmap -e "keysym Down = Down F16" - xmodmap -e "keysym Left = Left F18" - xmodmap -e "keysym Right = Right F19" - - And use these mappings in Vim: - :map <t_F3> <S-Up> - :map! <t_F3> <S-Up> - :map <t_F6> <S-Down> - :map! <t_F6> <S-Down> - :map <t_F8> <S-Left> - :map! <t_F8> <S-Left> - :map <t_F9> <S-Right> - :map! <t_F9> <S-Right> - -Instead of, say, <S-Up> you can use any other command that you want to use the -shift-cursor-up key for. (Note: To help people that have a Sun keyboard with -left side keys F14 is not used because it is confused with the undo key; F15 -is not used, because it does a window-to-front; F17 is not used, because it -closes the window. On other systems you can probably use them.) - -============================================================================== -3. Window size *window-size* - -[This is about the size of the whole window Vim is using, not a window that is -created with the ":split" command.] - -If you are running Vim on an Amiga and the terminal name is "amiga" or -"builtin_amiga", the amiga-specific window resizing will be enabled. On Unix -systems three methods are tried to get the window size: - -- an ioctl call (TIOCGSIZE or TIOCGWINSZ, depends on your system) -- the environment variables "LINES" and "COLUMNS" -- from the termcap entries "li" and "co" - -If everything fails a default size of 24 lines and 80 columns is assumed. If -a window-resize signal is received the size will be set again. If the window -size is wrong you can use the 'lines' and 'columns' options to set the -correct values. - -One command can be used to set the screen size: - - *:mod* *:mode* *E359* *E362* -:mod[e] [mode] - -Without argument this only detects the screen size and redraws the screen. -With MS-DOS it is possible to switch screen mode. [mode] can be one of these -values: - "bw40" 40 columns black&white - "c40" 40 columns color - "bw80" 80 columns black&white - "c80" 80 columns color (most people use this) - "mono" 80 columns monochrome - "c4350" 43 or 50 lines EGA/VGA mode - number mode number to use, depends on your video card - -============================================================================== -4. Slow and fast terminals *slow-fast-terminal* - *slow-terminal* - -If you have a fast terminal you may like to set the 'ruler' option. The -cursor position is shown in the status line. If you are using horizontal -scrolling ('wrap' option off) consider setting 'sidescroll' to a small -number. - -If you have a slow terminal you may want to reset the 'showcmd' option. -The command characters will not be shown in the status line. If the terminal -scrolls very slowly, set the 'scrolljump' to 5 or so. If the cursor is moved -off the screen (e.g., with "j") Vim will scroll 5 lines at a time. Another -possibility is to reduce the number of lines that Vim uses with the command -"z{height}<CR>". - -If the characters from the terminal are arriving with more than 1 second -between them you might want to set the 'timeout' and/or 'ttimeout' option. -See the "Options" chapter |options|. - -If your terminal does not support a scrolling region, but it does support -insert/delete line commands, scrolling with multiple windows may make the -lines jump up and down. If you don't want this set the 'ttyfast' option. -This will redraw the window instead of scroll it. - -If your terminal scrolls very slowly, but redrawing is not slow, set the -'ttyscroll' option to a small number, e.g., 3. This will make Vim redraw the -screen instead of scrolling, when there are more than 3 lines to be scrolled. - -If you are using a color terminal that is slow, use this command: > - hi NonText cterm=NONE ctermfg=NONE -This avoids that spaces are sent when they have different attributes. On most -terminals you can't see this anyway. - -If you are using Vim over a slow serial line, you might want to try running -Vim inside the "screen" program. Screen will optimize the terminal I/O quite -a bit. - -If you are testing termcap options, but you cannot see what is happening, -you might want to set the 'writedelay' option. When non-zero, one character -is sent to the terminal at a time (does not work for MS-DOS). This makes the -screen updating a lot slower, making it possible to see what is happening. - -============================================================================== -5. Using the mouse *mouse-using* - -This section is about using the mouse on a terminal or a terminal window. How -to use the mouse in a GUI window is explained in |gui-mouse|. For scrolling -with a mouse wheel see |scroll-mouse-wheel|. - -Don't forget to enable the mouse with this commands: > - :set mouse=a -Otherwise Vim won't recognize the mouse in all modes (See 'mouse'). - -Currently the mouse is supported for Unix in an xterm window, in a *BSD -console with |sysmouse|, in a Linux console (with GPM |gpm-mouse|), for -MS-DOS and in a Windows console. -Mouse clicks can be used to position the cursor, select an area and paste. - -These characters in the 'mouse' option tell in which situations the mouse will -be used by Vim: - n Normal mode - v Visual mode - i Insert mode - c Command-line mode - h all previous modes when in a help file - a all previous modes - r for |hit-enter| prompt - -The default for 'mouse' is empty, the mouse is not used. Normally you would -do: > - :set mouse=a -to start using the mouse (this is equivalent to setting 'mouse' to "nvich"). -If you only want to use the mouse in a few modes or also want to use it for -the two questions you will have to concatenate the letters for those modes. -For example: > - :set mouse=nv -Will make the mouse work in Normal mode and Visual mode. > - :set mouse=h -Will make the mouse work in help files only (so you can use "g<LeftMouse>" to -jump to tags). - -Whether the selection that is started with the mouse is in Visual mode or -Select mode depends on whether "mouse" is included in the 'selectmode' -option. - -In an xterm, with the currently active mode included in the 'mouse' option, -normal mouse clicks are used by Vim, mouse clicks with the shift or ctrl key -pressed go to the xterm. With the currently active mode not included in -'mouse' all mouse clicks go to the xterm. - - *xterm-clipboard* -In the Athena and Motif GUI versions, when running in a terminal and there is -access to the X-server (DISPLAY is set), the copy and paste will behave like -in the GUI. If not, the middle mouse button will insert the unnamed register. -In that case, here is how you copy and paste a piece of text: - -Copy/paste with the mouse and Visual mode ('mouse' option must be set, see -above): -1. Press left mouse button on first letter of text, move mouse pointer to last - letter of the text and release the button. This will start Visual mode and - highlight the selected area. -2. Press "y" to yank the Visual text in the unnamed register. -3. Click the left mouse button at the insert position. -4. Click the middle mouse button. - -Shortcut: If the insert position is on the screen at the same time as the -Visual text, you can do 2, 3 and 4 all in one: Click the middle mouse button -at the insert position. - -Note: When the |-X| command line argument is used, Vim will not connect to the -X server and copy/paste to the X clipboard (selection) will not work. Use the -shift key with the mouse buttons to let the xterm do the selection. - - *xterm-command-server* -When the X-server clipboard is available, the command server described in -|x11-clientserver| can be enabled with the --servername command line argument. - - *xterm-copy-paste* -NOTE: In some (older) xterms, it's not possible to move the cursor past column -95. This is an xterm problem, not Vim's. Get a newer xterm |color-xterm|. - -Copy/paste in xterm with (current mode NOT included in 'mouse'): -1. Press left mouse button on first letter of text, move mouse pointer to last - letter of the text and release the button. -2. Use normal Vim commands to put the cursor at the insert position. -3. Press "a" to start Insert mode. -4. Click the middle mouse button. -5. Press ESC to end Insert mode. -(The same can be done with anything in 'mouse' if you keep the shift key -pressed while using the mouse.) - -Note: if you lose the 8th bit when pasting (special characters are translated -into other characters), you may have to do "stty cs8 -istrip -parenb" in your -shell before starting Vim. - -Thus in an xterm the shift and ctrl keys cannot be used with the mouse. Mouse -commands requiring the CTRL modifier can be simulated by typing the "g" key -before using the mouse: - "g<LeftMouse>" is "<C-LeftMouse> (jump to tag under mouse click) - "g<RightMouse>" is "<C-RightMouse> ("CTRL-T") - - *mouse-mode-table* *mouse-overview* -A short overview of what the mouse buttons do, when 'mousemodel' is "extend": - -Normal Mode: -event position selection change action ~ - cursor window ~ -<LeftMouse> yes end yes -<C-LeftMouse> yes end yes "CTRL-]" (2) -<S-LeftMouse> yes no change yes "*" (2) *<S-LeftMouse>* -<LeftDrag> yes start or extend (1) no *<LeftDrag>* -<LeftRelease> yes start or extend (1) no -<MiddleMouse> yes if not active no put -<MiddleMouse> yes if active no yank and put -<RightMouse> yes start or extend yes -<A-RightMouse> yes start or extend blockw. yes *<A-RightMouse>* -<S-RightMouse> yes no change yes "#" (2) *<S-RightMouse>* -<C-RightMouse> no no change no "CTRL-T" -<RightDrag> yes extend no *<RightDrag>* -<RightRelease> yes extend no *<RightRelease>* - -Insert or Replace Mode: -event position selection change action ~ - cursor window ~ -<LeftMouse> yes (cannot be active) yes -<C-LeftMouse> yes (cannot be active) yes "CTRL-O^]" (2) -<S-LeftMouse> yes (cannot be active) yes "CTRL-O*" (2) -<LeftDrag> yes start or extend (1) no like CTRL-O (1) -<LeftRelease> yes start or extend (1) no like CTRL-O (1) -<MiddleMouse> no (cannot be active) no put register -<RightMouse> yes start or extend yes like CTRL-O -<A-RightMouse> yes start or extend blockw. yes -<S-RightMouse> yes (cannot be active) yes "CTRL-O#" (2) -<C-RightMouse> no (cannot be active) no "CTRL-O CTRL-T" - -In a help window: -event position selection change action ~ - cursor window ~ -<2-LeftMouse> yes (cannot be active) no "^]" (jump to help tag) - -When 'mousemodel' is "popup", these are different: - -Normal Mode: -event position selection change action ~ - cursor window ~ -<S-LeftMouse> yes start or extend (1) no -<A-LeftMouse> yes start or extend blockw. no *<A-LeftMouse>* -<RightMouse> no popup menu no - -Insert or Replace Mode: -event position selection change action ~ - cursor window ~ -<S-LeftMouse> yes start or extend (1) no like CTRL-O (1) -<A-LeftMouse> yes start or extend blockw. no -<RightMouse> no popup menu no - -(1) only if mouse pointer moved since press -(2) only if click is in same buffer - -Clicking the left mouse button causes the cursor to be positioned. If the -click is in another window that window is made the active window. When -editing the command-line the cursor can only be positioned on the -command-line. When in Insert mode Vim remains in Insert mode. If 'scrolloff' -is set, and the cursor is positioned within 'scrolloff' lines from the window -border, the text is scrolled. - -A selection can be started by pressing the left mouse button on the first -character, moving the mouse to the last character, then releasing the mouse -button. You will not always see the selection until you release the button, -only in some versions (GUI, MS-DOS, WIN32) will the dragging be shown -immediately. Note that you can make the text scroll by moving the mouse at -least one character in the first/last line in the window when 'scrolloff' is -non-zero. - -In Normal, Visual and Select mode clicking the right mouse button causes the -Visual area to be extended. When 'mousemodel' is "popup", the left button has -to be used while keeping the shift key pressed. When clicking in a window -which is editing another buffer, the Visual or Select mode is stopped. - -In Normal, Visual and Select mode clicking the right mouse button with the alt -key pressed causes the Visual area to become blockwise. When 'mousemodel' is -"popup" the left button has to be used with the alt key. Note that this won't -work on systems where the window manager consumes the mouse events when the -alt key is pressed (it may move the window). - - *double-click* -Double, triple and quadruple clicks are supported when the GUI is active, -for MS-DOS and Win32, and for an xterm (if the gettimeofday() function is -available). For selecting text, extra clicks extend the selection: - click select ~ - double word or % match *<2-LeftMouse>* - triple line *<3-LeftMouse>* - quadruple rectangular block *<4-LeftMouse>* -Exception: In a Help window a double click jumps to help for the word that is -clicked on. -A double click on a word selects that word. 'iskeyword' is used to specify -which characters are included in a word. A double click on a character -that has a match selects until that match (like using "v%"). If the match is -an #if/#else/#endif block, the selection becomes linewise. -For MS-DOS and xterm the time for double clicking can be set with the -'mousetime' option. For the other systems this time is defined outside of -Vim. -An example, for using a double click to jump to the tag under the cursor: > - :map <2-LeftMouse> :exe "tag ". expand("<cword>")<CR> - -Dragging the mouse with a double click (button-down, button-up, button-down -and then drag) will result in whole words to be selected. This continues -until the button is released, at which point the selection is per character -again. - - *gpm-mouse* -The GPM mouse is only supported when the |+mouse_gpm| feature was enabled at -compile time. The GPM mouse driver (Linux console) does not support quadruple -clicks. - -In Insert mode, when a selection is started, Vim goes into Normal mode -temporarily. When Visual or Select mode ends, it returns to Insert mode. -This is like using CTRL-O in Insert mode. Select mode is used when the -'selectmode' option contains "mouse". - *sysmouse* -The sysmouse is only supported when the |+mouse_sysmouse| feature was enabled -at compile time. The sysmouse driver (*BSD console) does not support keyboard -modifiers. - - *drag-status-line* -When working with several windows, the size of the windows can be changed by -dragging the status line with the mouse. Point the mouse at a status line, -press the left button, move the mouse to the new position of the status line, -release the button. Just clicking the mouse in a status line makes that window -the current window, without moving the cursor. If by selecting a window it -will change position or size, the dragging of the status line will look -confusing, but it will work (just try it). - - *<MiddleRelease>* *<MiddleDrag>* -Mouse clicks can be mapped. The codes for mouse clicks are: - code mouse button normal action ~ - <LeftMouse> left pressed set cursor position - <LeftDrag> left moved while pressed extend selection - <LeftRelease> left released set selection end - <MiddleMouse> middle pressed paste text at cursor position - <MiddleDrag> middle moved while pressed - - <MiddleRelease> middle released - - <RightMouse> right pressed extend selection - <RightDrag> right moved while pressed extend selection - <RightRelease> right released set selection end - <X1Mouse> X1 button pressed - *X1Mouse* - <X1Drag> X1 moved while pressed - *X1Drag* - <X1Release> X1 button release - *X1Release* - <X2Mouse> X2 button pressed - *X2Mouse* - <X2Drag> X2 moved while pressed - *X2Drag* - <X2Release> X2 button release - *X2Release* - -The X1 and X2 buttons refer to the extra buttons found on some mice. The -'Microsoft Explorer' mouse has these buttons available to the right thumb. -Currently X1 and X2 only work on Win32 environments. - -Examples: > - :noremap <MiddleMouse> <LeftMouse><MiddleMouse> -Paste at the position of the middle mouse button click (otherwise the paste -would be done at the cursor position). > - - :noremap <LeftRelease> <LeftRelease>y -Immediately yank the selection, when using Visual mode. - -Note the use of ":noremap" instead of "map" to avoid a recursive mapping. -> - :map <X1Mouse> <C-O> - :map <X2Mouse> <C-I> -Map the X1 and X2 buttons to go forwards and backwards in the jump list, see -|CTRL-O| and |CTRL-I|. - - *mouse-swap-buttons* -To swap the meaning of the left and right mouse buttons: > - :noremap <LeftMouse> <RightMouse> - :noremap <LeftDrag> <RightDrag> - :noremap <LeftRelease> <RightRelease> - :noremap <RightMouse> <LeftMouse> - :noremap <RightDrag> <LeftDrag> - :noremap <RightRelease> <LeftRelease> - :noremap g<LeftMouse> <C-RightMouse> - :noremap g<RightMouse> <C-LeftMouse> - :noremap! <LeftMouse> <RightMouse> - :noremap! <LeftDrag> <RightDrag> - :noremap! <LeftRelease> <RightRelease> - :noremap! <RightMouse> <LeftMouse> - :noremap! <RightDrag> <LeftDrag> - :noremap! <RightRelease> <LeftRelease> -< - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/tips.txt b/share/vim/vim72/doc/tips.txt deleted file mode 100644 index 5f83ec50ac..0000000000 --- a/share/vim/vim72/doc/tips.txt +++ /dev/null @@ -1,508 +0,0 @@ -*tips.txt* For Vim version 7.2. Last change: 2006 Jul 24 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Tips and ideas for using Vim *tips* - -Don't forget to browse the user manual, it also contains lots of useful tips -|usr_toc.txt|. - -Editing C programs |C-editing| -Finding where identifiers are used |ident-search| -Switching screens in an xterm |xterm-screens| -Scrolling in Insert mode |scroll-insert| -Smooth scrolling |scroll-smooth| -Correcting common typing mistakes |type-mistakes| -Counting words, lines, etc. |count-items| -Restoring the cursor position |restore-position| -Renaming files |rename-files| -Speeding up external commands |speed-up| -Useful mappings |useful-mappings| -Compressing the help files |gzip-helpfile| -Hex editing |hex-editing| -Executing shell commands in a window |shell-window| -Using <> notation in autocommands |autocmd-<>| -Highlighting matching parens |match-parens| - -============================================================================== -Editing C programs *C-editing* - -There are quite a few features in Vim to help you edit C program files. Here -is an overview with tags to jump to: - -|usr_29.txt| Moving through programs chapter in the user manual. -|usr_30.txt| Editing programs chapter in the user manual. -|C-indenting| Automatically set the indent of a line while typing - text. -|=| Re-indent a few lines. -|format-comments| Format comments. - -|:checkpath| Show all recursively included files. -|[i| Search for identifier under cursor in current and - included files. -|[_CTRL-I| Jump to match for "[i" -|[I| List all lines in current and included files where - identifier under the cursor matches. -|[d| Search for define under cursor in current and included - files. - -|CTRL-]| Jump to tag under cursor (e.g., definition of a - function). -|CTRL-T| Jump back to before a CTRL-] command. -|:tselect| Select one tag out of a list of matching tags. - -|gd| Go to Declaration of local variable under cursor. -|gD| Go to Declaration of global variable under cursor. - -|gf| Go to file name under the cursor. - -|%| Go to matching (), {}, [], /* */, #if, #else, #endif. -|[/| Go to previous start of comment. -|]/| Go to next end of comment. -|[#| Go back to unclosed #if, #ifdef, or #else. -|]#| Go forward to unclosed #else or #endif. -|[(| Go back to unclosed '(' -|])| Go forward to unclosed ')' -|[{| Go back to unclosed '{' -|]}| Go forward to unclosed '}' - -|v_ab| Select "a block" from "[(" to "])", including braces -|v_ib| Select "inner block" from "[(" to "])" -|v_aB| Select "a block" from "[{" to "]}", including brackets -|v_iB| Select "inner block" from "[{" to "]}" - -============================================================================== -Finding where identifiers are used *ident-search* - -You probably already know that |tags| can be used to jump to the place where a -function or variable is defined. But sometimes you wish you could jump to all -the places where a function or variable is being used. This is possible in -two ways: -1. Using the |:grep| command. This should work on most Unix systems, - but can be slow (it reads all files) and only searches in one directory. -2. Using ID utils. This is fast and works in multiple directories. It uses a - database to store locations. You will need some additional programs for - this to work. And you need to keep the database up to date. - -Using the GNU id-tools: - -What you need: -- The GNU id-tools installed (mkid is needed to create ID and lid is needed to - use the macros). -- An identifier database file called "ID" in the current directory. You can - create it with the shell command "mkid file1 file2 ..". - -Put this in your .vimrc: > - map _u :call ID_search()<Bar>execute "/\\<" . g:word . "\\>"<CR> - map _n :n<Bar>execute "/\\<" . g:word . "\\>"<CR> - - function! ID_search() - let g:word = expand("<cword>") - let x = system("lid --key=none ". g:word) - let x = substitute(x, "\n", " ", "g") - execute "next " . x - endfun - -To use it, place the cursor on a word, type "_u" and vim will load the file -that contains the word. Search for the next occurrence of the word in the -same file with "n". Go to the next file with "_n". - -This has been tested with id-utils-3.2 (which is the name of the id-tools -archive file on your closest gnu-ftp-mirror). - -[the idea for this comes from Andreas Kutschera] - -============================================================================== -Switching screens in an xterm *xterm-screens* *xterm-save-screen* - -(From comp.editors, by Juergen Weigert, in reply to a question) - -:> Another question is that after exiting vim, the screen is left as it -:> was, i.e. the contents of the file I was viewing (editing) was left on -:> the screen. The output from my previous like "ls" were lost, -:> ie. no longer in the scrolling buffer. I know that there is a way to -:> restore the screen after exiting vim or other vi like editors, -:> I just don't know how. Helps are appreciated. Thanks. -: -:I imagine someone else can answer this. I assume though that vim and vi do -:the same thing as each other for a given xterm setup. - -They not necessarily do the same thing, as this may be a termcap vs. -terminfo problem. You should be aware that there are two databases for -describing attributes of a particular type of terminal: termcap and -terminfo. This can cause differences when the entries differ AND when of -the programs in question one uses terminfo and the other uses termcap -(also see |+terminfo|). - -In your particular problem, you are looking for the control sequences -^[[?47h and ^[[?47l. These switch between xterms alternate and main screen -buffer. As a quick workaround a command sequence like > - echo -n "^[[?47h"; vim ... ; echo -n "^[[?47l" -may do what you want. (My notation ^[ means the ESC character, further down -you'll see that the databases use \E instead). - -On startup, vim echoes the value of the termcap variable ti (terminfo: -smcup) to the terminal. When exiting, it echoes te (terminfo: rmcup). Thus -these two variables are the correct place where the above mentioned control -sequences should go. - -Compare your xterm termcap entry (found in /etc/termcap) with your xterm -terminfo entry (retrieved with "infocmp -C xterm"). Both should contain -entries similar to: > - :te=\E[2J\E[?47l\E8:ti=\E7\E[?47h: - -PS: If you find any difference, someone (your sysadmin?) should better check - the complete termcap and terminfo database for consistency. - -NOTE 1: If you recompile Vim with FEAT_XTERM_SAVE defined in feature.h, the -builtin xterm will include the mentioned "te" and "ti" entries. - -NOTE 2: If you want to disable the screen switching, and you don't want to -change your termcap, you can add these lines to your .vimrc: > - :set t_ti= t_te= - -============================================================================== -Scrolling in Insert mode *scroll-insert* - -If you are in insert mode and you want to see something that is just off the -screen, you can use CTRL-X CTRL-E and CTRL-X CTRL-Y to scroll the screen. - |i_CTRL-X_CTRL-E| - -To make this easier, you could use these mappings: > - :inoremap <C-E> <C-X><C-E> - :inoremap <C-Y> <C-X><C-Y> -(Type this literally, make sure the '<' flag is not in 'cpoptions'). -You then lose the ability to copy text from the line above/below the cursor -|i_CTRL-E|. - -Also consider setting 'scrolloff' to a larger value, so that you can always see -some context around the cursor. If 'scrolloff' is bigger than half the window -height, the cursor will always be in the middle and the text is scrolled when -the cursor is moved up/down. - -============================================================================== -Smooth scrolling *scroll-smooth* - -If you like the scrolling to go a bit smoother, you can use these mappings: > - :map <C-U> <C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y> - :map <C-D> <C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E> - -(Type this literally, make sure the '<' flag is not in 'cpoptions'). - -============================================================================== -Correcting common typing mistakes *type-mistakes* - -When there are a few words that you keep on typing in the wrong way, make -abbreviations that correct them. For example: > - :ab teh the - :ab fro for - -============================================================================== -Counting words, lines, etc. *count-items* - -To count how often any pattern occurs in the current buffer use the substitute -command and add the 'n' flag to avoid the substitution. The reported number -of substitutions is the number of items. Examples: > - - :%s/./&/gn characters - :%s/\i\+/&/gn words - :%s/^//n lines - :%s/the/&/gn "the" anywhere - :%s/\<the\>/&/gn "the" as a word - -You might want to reset 'hlsearch' or do ":nohlsearch". -Add the 'e' flag if you don't want an error when there are no matches. - -An alternative is using |v_g_CTRL-G| in Visual mode. - -If you want to find matches in multiple files use |:vimgrep|. - - *count-bytes* -If you want to count bytes, you can use this: - - Visually select the characters (block is also possible) - Use "y" to yank the characters - Use the strlen() function: > - :echo strlen(@") -A line break is counted for one byte. - -============================================================================== -Restoring the cursor position *restore-position* - -Sometimes you want to write a mapping that makes a change somewhere in the -file and restores the cursor position, without scrolling the text. For -example, to change the date mark in a file: > - :map <F2> msHmtgg/Last [cC]hange:\s*/e+1<CR>"_D"=strftime("%Y %b %d")<CR>p'tzt`s - -Breaking up saving the position: - ms store cursor position in the 's' mark - H go to the first line in the window - mt store this position in the 't' mark - -Breaking up restoring the position: - 't go to the line previously at the top of the window - zt scroll to move this line to the top of the window - `s jump to the original position of the cursor - -============================================================================== -Renaming files *rename-files* - -Say I have a directory with the following files in them (directory picked at -random :-): - -buffer.c -charset.c -digraph.c -... - -and I want to rename *.c *.bla. I'd do it like this: > - - $ vim - :r !ls *.c - :%s/\(.*\).c/mv & \1.bla - :w !sh - :q! - -============================================================================== -Speeding up external commands *speed-up* - -In some situations, execution of an external command can be very slow. This -can also slow down wildcard expansion on Unix. Here are a few suggestions to -increase the speed. - -If your .cshrc (or other file, depending on the shell used) is very long, you -should separate it into a section for interactive use and a section for -non-interactive use (often called secondary shells). When you execute a -command from Vim like ":!ls", you do not need the interactive things (for -example, setting the prompt). Put the stuff that is not needed after these -lines: > - - if ($?prompt == 0) then - exit 0 - endif - -Another way is to include the "-f" flag in the 'shell' option, e.g.: > - - :set shell=csh\ -f - -(the backslash is needed to include the space in the option). -This will make csh completely skip the use of the .cshrc file. This may cause -some things to stop working though. - -============================================================================== -Useful mappings *useful-mappings* - -Here are a few mappings that some people like to use. - - *map-backtick* > - :map ' ` -Make the single quote work like a backtick. Puts the cursor on the column of -a mark, instead of going to the first non-blank character in the line. - - *emacs-keys* -For Emacs-style editing on the command-line: > - " start of line - :cnoremap <C-A> <Home> - " back one character - :cnoremap <C-B> <Left> - " delete character under cursor - :cnoremap <C-D> <Del> - " end of line - :cnoremap <C-E> <End> - " forward one character - :cnoremap <C-F> <Right> - " recall newer command-line - :cnoremap <C-N> <Down> - " recall previous (older) command-line - :cnoremap <C-P> <Up> - " back one word - :cnoremap <Esc><C-B> <S-Left> - " forward one word - :cnoremap <Esc><C-F> <S-Right> - -NOTE: This requires that the '<' flag is excluded from 'cpoptions'. |<>| - - *format-bullet-list* -This mapping will format any bullet list. It requires that there is an empty -line above and below each list entry. The expression commands are used to -be able to give comments to the parts of the mapping. > - - :let m = ":map _f :set ai<CR>" " need 'autoindent' set - :let m = m . "{O<Esc>" " add empty line above item - :let m = m . "}{)^W" " move to text after bullet - :let m = m . "i <CR> <Esc>" " add space for indent - :let m = m . "gq}" " format text after the bullet - :let m = m . "{dd" " remove the empty line - :let m = m . "5lDJ" " put text after bullet - :execute m |" define the mapping - -(<> notation |<>|. Note that this is all typed literally. ^W is "^" "W", not -CTRL-W. You can copy/paste this into Vim if '<' is not included in -'cpoptions'.) - -Note that the last comment starts with |", because the ":execute" command -doesn't accept a comment directly. - -You also need to set 'textwidth' to a non-zero value, e.g., > - :set tw=70 - -A mapping that does about the same, but takes the indent for the list from the -first line (Note: this mapping is a single long line with a lot of spaces): > - :map _f :set ai<CR>}{a <Esc>WWmmkD`mi<CR><Esc>kkddpJgq}'mJO<Esc>j -< - *collapse* -These two mappings reduce a sequence of empty (;b) or blank (;n) lines into a -single line > - :map ;b GoZ<Esc>:g/^$/.,/./-j<CR>Gdd - :map ;n GoZ<Esc>:g/^[ <Tab>]*$/.,/[^ <Tab>]/-j<CR>Gdd - -============================================================================== -Compressing the help files *gzip-helpfile* - -For those of you who are really short on disk space, you can compress the help -files and still be able to view them with Vim. This makes accessing the help -files a bit slower and requires the "gzip" program. - -(1) Compress all the help files: "gzip doc/*.txt". - -(2) Edit "doc/tags" and change the ".txt" to ".txt.gz": > - :%s=\(\t.*\.txt\)\t=\1.gz\t= - -(3) Add this line to your vimrc: > - set helpfile={dirname}/help.txt.gz - -Where {dirname} is the directory where the help files are. The |gzip| plugin -will take care of decompressing the files. -You must make sure that $VIMRUNTIME is set to where the other Vim files are, -when they are not in the same location as the compressed "doc" directory. See -|$VIMRUNTIME|. - -============================================================================== -Executing shell commands in a window *shell-window* - -There have been questions for the possibility to execute a shell in a window -inside Vim. The answer: you can't! Including this would add a lot of code to -Vim, which is a good reason not to do this. After all, Vim is an editor, it -is not supposed to do non-editing tasks. However, to get something like this, -you might try splitting your terminal screen or display window with the -"splitvt" program. You can probably find it on some ftp server. The person -that knows more about this is Sam Lantinga <slouken@cs.ucdavis.edu>. -An alternative is the "window" command, found on BSD Unix systems, which -supports multiple overlapped windows. Or the "screen" program, found at -www.uni-erlangen.de, which supports a stack of windows. - -============================================================================== -Hex editing *hex-editing* *using-xxd* - -See section |23.4| of the user manual. - -If one has a particular extension that one uses for binary files (such as exe, -bin, etc), you may find it helpful to automate the process with the following -bit of autocmds for your <.vimrc>. Change that "*.bin" to whatever -comma-separated list of extension(s) you find yourself wanting to edit: > - - " vim -b : edit binary using xxd-format! - augroup Binary - au! - au BufReadPre *.bin let &bin=1 - au BufReadPost *.bin if &bin | %!xxd - au BufReadPost *.bin set ft=xxd | endif - au BufWritePre *.bin if &bin | %!xxd -r - au BufWritePre *.bin endif - au BufWritePost *.bin if &bin | %!xxd - au BufWritePost *.bin set nomod | endif - augroup END - -============================================================================== -Using <> notation in autocommands *autocmd-<>* - -The <> notation is not recognized in the argument of an :autocmd. To avoid -having to use special characters, you could use a self-destroying mapping to -get the <> notation and then call the mapping from the autocmd. Example: - - *map-self-destroy* > - " This is for automatically adding the name of the file to the menu list. - " It uses a self-destroying mapping! - " 1. use a line in the buffer to convert the 'dots' in the file name to \. - " 2. store that in register '"' - " 3. add that name to the Buffers menu list - " WARNING: this does have some side effects, like overwriting the - " current register contents and removing any mapping for the "i" command. - " - autocmd BufNewFile,BufReadPre * nmap i :nunmap i<CR>O<C-R>%<Esc>:.g/\./s/\./\\./g<CR>0"9y$u:menu Buffers.<C-R>9 :buffer <C-R>%<C-V><CR><CR> - autocmd BufNewFile,BufReadPre * normal i - -Another method, perhaps better, is to use the ":execute" command. In the -string you can use the <> notation by preceding it with a backslash. Don't -forget to double the number of existing backslashes and put a backslash before -'"'. -> - autocmd BufNewFile,BufReadPre * exe "normal O\<C-R>%\<Esc>:.g/\\./s/\\./\\\\./g\<CR>0\"9y$u:menu Buffers.\<C-R>9 :buffer \<C-R>%\<C-V>\<CR>\<CR>" - -For a real buffer menu, user functions should be used (see |:function|), but -then the <> notation isn't used, which defeats using it as an example here. - -============================================================================== -Highlighting matching parens *match-parens* - -This example shows the use of a few advanced tricks: -- using the |CursorMoved| autocommand event -- using |searchpairpos()| to find a matching paren -- using |synID()| to detect whether the cursor is in a string or comment -- using |:match| to highlight something -- using a |pattern| to match a specific position in the file. - -This should be put in a Vim script file, since it uses script-local variables. -It skips matches in strings or comments, unless the cursor started in string -or comment. This requires syntax highlighting. - -A slightly more advanced version is used in the |matchparen| plugin. -> - let s:paren_hl_on = 0 - function s:Highlight_Matching_Paren() - if s:paren_hl_on - match none - let s:paren_hl_on = 0 - endif - - let c_lnum = line('.') - let c_col = col('.') - - let c = getline(c_lnum)[c_col - 1] - let plist = split(&matchpairs, ':\|,') - let i = index(plist, c) - if i < 0 - return - endif - if i % 2 == 0 - let s_flags = 'nW' - let c2 = plist[i + 1] - else - let s_flags = 'nbW' - let c2 = c - let c = plist[i - 1] - endif - if c == '[' - let c = '\[' - let c2 = '\]' - endif - let s_skip ='synIDattr(synID(line("."), col("."), 0), "name") ' . - \ '=~? "string\\|comment"' - execute 'if' s_skip '| let s_skip = 0 | endif' - - let [m_lnum, m_col] = searchpairpos(c, '', c2, s_flags, s_skip) - - if m_lnum > 0 && m_lnum >= line('w0') && m_lnum <= line('w$') - exe 'match Search /\(\%' . c_lnum . 'l\%' . c_col . - \ 'c\)\|\(\%' . m_lnum . 'l\%' . m_col . 'c\)/' - let s:paren_hl_on = 1 - endif - endfunction - - autocmd CursorMoved,CursorMovedI * call s:Highlight_Matching_Paren() - autocmd InsertEnter * match none -< - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/todo.txt b/share/vim/vim72/doc/todo.txt deleted file mode 100644 index 81492c0f1a..0000000000 --- a/share/vim/vim72/doc/todo.txt +++ /dev/null @@ -1,4292 +0,0 @@ -*todo.txt* For Vim version 7.2. Last change: 2008 Aug 09 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - - TODO list for Vim *todo* - -This is a veeeery long list of known bugs, current work and desired -improvements. To make it a little bit accessible, the items are grouped by -subject. In the first column of the line a classification is used to be able -to look for "the next thing to do": - -Priority classification: -9 next point release -8 next release -7 as soon as possible -6 soon -5 should be included -4 nice to have -3 consider including -2 maybe not -1 probably not -- unclassified - - *votes-for-changes* -See |develop.txt| for development plans. You can vote for which items should -be worked on, but only if you sponsor Vim development. See |sponsor|. - - *known-bugs* --------------------- Known bugs and current work ----------------------- - -":pedit %" with a BufReadPre autocommand causes the cursor to move to the -first line. (Ingo Karkat, 2008 Jul 1) Ian Kelling is working on this. - -Have a look at patch for utf-8 line breaking. (Yongwei Wu, 2008 Mar 1, Mar 23) - -netrw: dragging status line causes selection of entry. Should check row -number to be below last visible line. - -Runtime files for Clojure. (Toralf Wittner, 2008 Jun 25) - -Patch to add extra argument to glob() and globpath() to ignore 'wildignore'. -(Ingo Karkat, 2008 Jun 25) - -Crash with dragn-n-drop of file combined with netrw (Marius Gedminas, 2008 Jun -11) I can't reproduce it. It's probably caused by a handle_drop() call -in combination with autocommands that invoke a ":redraw" command. -Another valgrind output Jun 30. - -When reallocating cmdline xp_pattern becomes invalid. Move expand_T xpc into -ccline? (Dominique Pelle) - -Wildmenu not deleted: "gvim -u NONE", ":set nocp wildmenu cmdheight=3 -laststatus=2", CTRL-D CTRL-H CTRL-H CTRL-H. (A.Politz, 2008 April 1) -Works OK with Vim in an xterm. - -When using ":e ++enc=foo file" and the file is already loaded with -'fileencoding' set to "bar", then do_ecmd() uses that buffer, even though the -fileencoding differs. Reload the buffer in this situation? Need to check for -the buffer to be unmodified. -Unfinished patch by Ian Kelling, 2008 Jul 11. Followup Jul 14, need to have -another look at it. - -Fix for matchparen HL doesn't work. beep. - -Win32: associating a type with Vim doesn't take care of space after a -backslash? (Robert Vibrant, 2008 Jun 5) - -After using <Tab> for command line completion after ":ta blah" and getting E33 -(no tags file), further editing the command to e.g., ":echo 'blah'", the -command is not executed. Fix by Ian Kelling? - -":help s/~" jumps to *s/\~*, while ":help s/\~" doesn't find anything. (Tim -Chase) Fix by Ian Kelling, 2008 Jul 14. - -Despite adding save_subexpr() this still doesn't work properly: -Regexp: matchlist('12a4aaa', '^\(.\{-}\)\(\%5c\@<=a\+\)\(.\+\)\?') -Returns ['12a4', 'aaa', '4aaa'], should be ['12a4', 'aaa', ''] -Backreference not cleared when retrying after \@<= fails? -(Brett Stahlman, 2008 March 8) - -Patch for 2html.vim to avoid "&nbsp;". (Markus Heidelberg, 2008 Jul 19) - -Win32: remote editing fails when the current directory name contains "[". -(Ivan Tishchenko, Liu Yubao) Suggested patch by Chris Lubinski: Avoid -escaping characters where the backslash is not removed later. Asked Chris for -an alternate solution, also for src/ex_getln.c. -This also fails when the file or directory name contains "%". (Thoml, 2008 -July 7) - -The str2special() function doesn't handle multi-byte characters properly. -Patch from Vladimir Vichniakov, 2007 Apr 24. -Should clean up the whole function. Also allow modifiers like <S-Char-32>? -find_special_key() also has this problem. - -Problem with 'langmap' parsing. (James Vega, 2008 Jan 27) -Problem with 'langmap' being used on the rhs of a mapping. (Nikolai Weibull, -2008 May 14) - -Problem with CTRL-F. (Charles Campbell, 2008 March 21) -Only happens with "gvim -geometry "160x26+4+27" -u NONE -U NONE prop.c". -'lines' is 54. (2008 March 27) - -Unexpectedly inserting a double quote. (Anton Woellert, 2008 Mar 23) -Works OK when 'cmdheight' is 2. - -The utf class table is missing some entries: - 0x2212, minus sign - 0x2217, star - 0x2500, bar - 0x26ab, circle - -Visual line mode doesn't highlight properly when 'showbreak' is used and the -line doesn't fit. (Dasn, 2008 May 1) - -GUI: In Normal mode can't yank the modeless selection. Make "gy" do this? -Works like CTRL-Y in Command line mode. - -Mac: After a ":vsplit" the left scrollbar doesn't appear until 'columns' is -changed or the window is resized. - -Mac: Patch for configure: remove arch from ruby link args. (Knezevic, 2008 -Mar 5) Alternative: Kazuki Sakamoto, Mar 7. - -Mac: trouble compiling with Motif, requires --disable-darwin. (Raf, 2008 Aug -1) Reply by Ben Schmidt. - -":emenu" works with the translated menu name. Should also work with the -untranslated name. Would need to store both the English and the translated -name. Patch by Bjorn Winckler, 2008 Mar 30. - -C't: On utf-8 system, editing file with umlaut through Gnome results in URL -with %nn%nn, which is taken as two characters instead of one. -Try to reproduce at work. - -Patch for redo register. (Ben Schmidt, 2007 Oct 19) -Await response to question to make the register writable. - -Problem with 'ts' set to 9 and 'showbreak' to ">>>". (Matthew Winn, 2007 Oct -1) - -Including NFA regexp code: -Use "\%#= to set the engine: 0 = automatic, 1 = backtracking, 2 = new. -Useful in tests. -Performance tests: -- ~/vim/test/veryslow.js (file from Daniel Fetchinson) -- ~/vim/test/slowsearch -- ~/vim/test/rgb.vim -- search for a.*e*exn in the vim executable. Go to last line to use - 'hlsearch'. - -Using Aap to build Vim: add remarks about how to set personal preferences. -Example on http://www.calmar.ws/tmp/aap.html - -Syntax highlighting wrong for transparent region. (Doug Kearns, 2007 Feb 26) -Bug in using a transparent syntax region. (Hanlen in vim-dev maillist, 2007 -Jul 31) - -C syntax: {} inside () causes following {} to be highlighted as error. -(Michalis Giannakidis, 2006 Jun 1) - -When 'diffopt' has "context:0" a single deleted line causes two folds to merge -and mess up syncing. (Austin Jennings, 2008 Jan 31) - -Gnome improvements: Edward Catmur, 2007 Jan 7 - Also use Save/Discard for other GUIs - -New PHP syntax file, use it? (Peter Hodge) - -'foldcolumn' in modeline applied to wrong window when using a session. (Teemu -Likonen, March 19) - -The documentation mentions the priority for ":2match" and ":3match", but it -appears the last one wins. (John Beckett, 2008 Jul 22) Caused by adding -matchadd()? Suggested patch by John, 2008 Jul 24. - -Replace ccomplete.vim by cppcomplete.vim from www.vim.org? script 1520 -by Vissale Neang. (Martin Stubenschrott) -Asked Vissale to make the scripts more friendly for the Vim distribution. -New version received 2008 Jan 6. - -Cheng Fang made javacomplete. (2007 Aug 11) -Asked about latest version: 0.77.1 is on www.vim.org. - -More AmigaOS4 patches. (Peter Bengtsson, Nov 9) - -Insert mode completion: When editing the text and pressing CTRL-N again goes -back to originally completed text, edited text is gone. (Peng Yu, 2008 Jul 24) -Suggestion by Ben Schmidt, 2008 Aug 6. - -Problem with compound words? (Bert, 2008 May 6) -No warning for when flags are defined after they are used in an affix. - -With Visual selection, "r" and then CTRL-C Visual mode is stopped but the -highlighting is not removed. - -Screen redrawing when continuously updating the buffer and resizing the -terminal. (Yakov Lerner, 2006 Sept 7) - -Add option settings to help ftplugin. (David Eggum, 2006 Dec 18) - -Autoconf problem: when checking for iconv library we may add -L/usr/local/lib, -but when compiling further tests -liconv is added without the -L argument, -that may fail (e.g., sizeof(int)). (Blaine, 2007 Aug 21) - -When opening quickfix window, disable spell checking? - -Popup menu redraw: Instead of first redrawing the text and then drawing the -popup menu over it, first draw the new popup menu, remember its position and -size and then redraw the text, skipping the characters under the popup menu. -This should avoid flicker. Other solution by A.Politz, 2007 Aug 22. - -When the popup menu is close to the edge of the window it is truncated. Patch -to anchor the popup menu in a different way. (James Vega, 2008 Jul 30) - -Spell checking: Add a way to specify punctuation characters. Add the -superscript numbers by default: 0x2070, 0xb9, 0xb2, 0xb3, 0x2074 - 0x2079. - -Windows 98: pasting from the clipboard with text from another application has -a trailing NUL. (Joachim Hofmann) Perhaps the length specified for CF_TEXT -isn't right? - -Command line completion: Scanning for tags doesn't check for typed key now and -then? Hangs for about 5 seconds. Appears to be caused by finding include -files with "foo/**" in 'path'. (Kalisiak, 2006 July 15) -Additional info: When using the |wildcards| ** globing, vim hangs -indefinitely on lots of directories. The |file-searching| globing, like in -":set path=/**" does not hang as often as with globing with |wildcards|, like -in ":1find /**/file". This is for a files that unix "find" can find very -quick. Merging the 2 kinds of globing might make this an easier fix. (Ian -Kelling, 2008 July 4) - -When the file name has parenthesis, e.g., "foo (bar).txt", ":!ls '%'" has the -parenthesis escaped but not the space. That's inconsistent. Either escape -neither or both. No escaping might be best, because it doesn't depend on -particularities of the shell. (Zvi Har'El, 2007 Nov 10) (Teemu Likonen, 2008 -Jun 3) -However, for backwards compatibility escaping might be necessary. Check if -the user put quotes around the expanded item? - -Color for cUserLabel should differ from case label, so that a mistake in a -switch list is noticed: - switch (i) - { - case 1: - foobar: - } - -Look at http://www.gtk-server.org/ . It has a Vim script implementation. - -Netbeans problem. Use "nc -l 127.0.0.1 55555" for the server, then run gvim -with "gvim -nb:localhost:55555:foo". From nc do: '1:editFile!0 "foo"'. Then -go to Insert mode and add a few lines. Then backspacing every other time -moves the cursor instead of deleting. (Chris Kaiser, 2007 Sep 25) - -Redraw problem when appending digraph causes line to wrap. (James Vega, 2007 -Sep 18) Patch by Ian Kelling, 2008 Aug 8. - -Changes for Win32 makefile. (Mike Williams, 2007 Jan 22, Alexei Alexandrov, -2007 Feb 8) - -Patch for Win32 clipboard under Cygwin. (Frodak Baksik, Feb 15) - Sutcliffe says it works well. - Update 2007 May 22 for Vim 7.1 - -Win32: Patch for convert_filterW(). (Taro Muraoka, 2007 Mar 2) - -Win32: Patch for cscope external command. (Mike Williams, 2007 Aug 7) - -":cscope find f filename" doesn't work because of the extra space. (Ethan -Mallove) - -Win32: XPM support only works with path without spaces. Patch by Mathias -Michaelis, 2006 Jun 9. Another patch for more path names, 2006 May 31. -New version: http://members.tcnet.ch/michaelis/vim/patches.zip (also for other -patches by Mathias, see mail Feb 22) - -Win32: compiling with normal features and OLE fails. Patch by Mathias -Michaelis, 2006 Jun 4. - -Win32: echo doesn't work for gvim.exe.mnf. Use inline file. Patch by Mathias -Michaelis. http://groups.yahoo.com/group/vimdev/message/43765 -Patch that includes this and does more by George Reilly, 2007 Feb 12 - -Win16: include patches to make Win16 version work. (Vince Negri, 2006 May 22) - -Win32: after "[I" showing matches, scroll wheel messes up screen. (Tsakiridis, -2007 Feb 18) -Patch by Alex Dobrynin, 2007 Jun 3. Also fixes other scroll wheel problems. - -Win32: using CTRL-S in Insert mode doesn't remove the "+" from the tab pages -label. (Tsakiridis, 2007 Feb 18) Patch from Ian Kelling, 2008 Aug 6. - -When 'bomb' is changed the window title is updated to show/hide a "+", but the -tab page label isn't. (Patrick Texier, 2008 Jun 24) - -Win32: using "gvim --remote-tab-silent fname" sometimes gives an empty screen -with the more prompt. Caused by setting the guitablabel? (Thomas Michael -Engelke, 2007 Dec 20 - 2008 Jan 17) - -Win64: diff.exe crashes on Win64. (Julianne Bailey, 2006 Dec 12) -Build another diff.exe somehow? - -Win64: Seek error in swap file for a very big file (3 Gbyte). Check storing -pointer in long and seek offset in 64 bit var. - -Win32: patch for fullscreen mode. (Liushaolin, 2008 April 17) - -When file b is a link to file a and editing b twice you get the correct -warning for existing swap file, but when trying to recover it doesn't find the -swapfile. (Matt Wozniski, 2008 Aug 5) - -Pressing the 'pastetoggle' key doesn't update the statusline. (Jan Christoph -Ebersbach, 2008 Feb 1) - -Menu item that does "xxd -r" doesn't work when 'fileencoding' is utf-16. -Check for this and use iconv? (Edward L. Fox, 2007 Sep 12) -Does the conversion in the other direction work when 'filenecodings' is set -properly? - -Cursor displayed in the wrong position when using 'numberwidth'. (James Vega, -2007 Jun 21) - -When $VAR contains a backslash expand('$VAR') removes it. (Teemu Likonen, 2008 -Jun 18) - -If the variable "g:x#y#z" exists completion after ":echo g:x#" doesn't work. - -F1 - F4 in an xterm produce a different escape sequence when used with a -modifier key. Need to catch three different sequences. Use K_ZF1, like -K_ZHOME? (Dickey, 2007 Dec 2) - -Problem finding swap file for recovery. (Gautam Iyer, 2006 May 16) - -UTF-8: mapping a multi-byte key where the second byte is 0x80 doesn't appear -to work. (Tony Mechelynck, 2007 March 2) - -In debug mode, using CTRL-R = to evaluate a function causes stepping through -the function. (Hari Krishna Dara, 2006 Jun 28) - -C++ indenting wrong with "=". (James Kanze, 2007 Jan 26) - -":lockvar" should use copyID to avoid endless loop. - -When using --remote-silent and the file name matches 'wildignore' get an E479 -error. without --remote-silent it works fine. (Ben Fritz, 2008 Jun 20) - -Gvim: dialog for closing Vim should check if Vim is busy writing a file. Then -use a different dialog: "busy saving, really quit? yes / no". - -Check other interfaces for changing curbuf in a wrong way. Patch like for -if_ruby.c. - -Problem with cursorcolumn highlighting and folds. (John Mullin, 2008 Jul 18) - -Spell checking in popup menu: If the only problem is the case of the first -character, don't offer "ignore" and "add to word list". - -":helpgrep" should use the directory from 'helpfile'. - -The need_fileinfo flag is messy. Instead make the message right away and put -it in keep_msg? - -Editing a file remotely that matches 'wildignore' results in a "no match" -error. Should only happen when there are wildards, not when giving the file -name literally, and esp. if there is only one name. - -Test 61 fails sometimes. This is a timing problem: "sleep 2" sometimes takes -longer than 2 seconds. - -Changing 'guifont' in the console causes an unnecessary redraw. - -"vim -C" often has 'nocompatible', because it's set in some startup script. -Set 'compatible' after startup is done? Patch by James Vega, 2008 Feb 7. - -VMS: while editing a file found in complex, Vim will save file into the first -directory of the path and not to the original location of the file. -(Zoltan Arpadffy) - -VMS: VFC files are in some cases truncated during reading (Zoltan Arpadffy) - -input() completion should not insert a backslash to escape a space in a file -name? - -getpos()/setpos() don't include curswant. getpos() could return a fifth -element. setpos() could accept an optional fifth element. - -Ruby completion is insecure. Can this be fixed? - -When 'backupskip' is set from $TEMP special characters need to be escaped. -(patch by Grembowietz, 2007 Feb 26, not quite right) -Another problem is that file_pat_to_reg_pat() doesn't recognize "\\", so "\\(" -will be seen as a path separator plus "\(". - -":python os.chdir('/tmp')" makes short buffer names invalid. (Xavier de Gaye) -Check directory and call shorten_fnames()? - -aucmd_prepbuf() should also use a window in another tab page. - -Substituting an area with a line break with almost the same area does change -the Visual area. Can this be fixed? (James Vega, 2006 Sept 15) - -Windows installer could add a "open in new tab of existing Vim" menu entry. -Gvimext: patch to add "Edit with single Vim &tabbed" menu entry. -Just have two choices, always using one Vim and selecting between using an -argument list or opening each file in a separate tab. -(Erik Falor, 2008 May 21, 2008 Jun 26) - -GUI: When combining fg en bg make sure they are not equal. - -Use different pt_br dictionary for spell checking. (Jackson A. Aquino, 2006 -Jun 5) - -Mac: Using gvim: netrw window disappears. (Nick Lo, 2006 Jun 21) - -When 'ff' is "mac" then "ga" on a ^J shows 0x0d instead of 0x0a. Compare with -using "ga" on a NUL when 'ff' is "unix". (Andy Wokula, 2008 Jul 16) - -Add an option to specify the character to use when a double-width character is -moved to the next line. Default '>', set to a space to blank it out. Check -that char is single width when it's set (compare with 'listchars'). - -The generated vim.bat can avoid the loop for NT. (Carl Zmola, 2006 Sep 3) - -In a C file with spell checking, in "% integer" "nteger" is seen as an error, -but "]s" doesn't find it. "nteger" by itself is found. (Ralf Wildenhues, 2008 -Jul 22) - -Session file creation: 'autochdir' causes trouble. Keep it off until after -loading all files. - -When showing a diff between a non-existant file and an existing one, with the -cursor in the empty buffer, the other buffer only shows the last line. Change -the "insert" into a change from one line to many? (Yakov Lerner, 2008 May 27) - -Add autocommand for when a tabpage is being closed. Also for when a tab page -has been created. - -Using ":make" blocks Vim. Allow running one make in the background (if the -shell supports it), catch errors in a file and update the error list on the -fly. A bit like "!make > file&" and repeating ":cf file". ":bgmake", -background make. ":bgcancel" interrupts it. -A.Politz may work on this. - -The spellfile plugin checks for a writable "spell" directory. A user may have -a writable runtime directory without a "spell" directory, it could be created -then. - -These two abbreviations don't give the same result: - let asdfasdf = "xyz\<Left>" - cabbr XXX <C-R>=asdfasdf<CR> - cabbr YYY xyz<Left> - -Michael Dietrich: maximized gvim sometimes displays output of external command -partly. (2006 Dec 7) - -In FileChangedShell command it's no longer allowed to switch to another -buffer. But the changed buffer may differ from the current buffer, how to -reload it then? - -New syntax files for fstab and resolv from Radu Dineiu, David Necas did -previous version. - -For Aap: include a config.arg.example file with hints how to use config.arg. - -Command line completion when 'cmdheight' is maximum and 'wildmenu' is set, -only one buffer line displayed, causes display errors. - -Completing with 'wildmenu' and using <Up> and <Down> to move through directory -tree stops unexpectedly when using ":cd " and entering a directory that -doesn't contain other directories. - -Linux distributions: -- Suggest compiling xterm with --enable-tcap-query, so that nr of colors is - known to Vim. 88 colors instead of 16 works better. See ":help - xfree-xterm". -- Suggest including bare "vi" and "vim" with X11, syntax, etc. - -Completion menu: For a wrapping line, completing a long file name, only the -start of the path is shown in the menu. Should move the menu to the right to -show more text of the completions. Shorten the items that don't fit in the -middle? - -When running inside screen it's possible to kill the X server and restart it -(using pty's the program can keep on running). Vim dies because it loses the -connection to the X server. Can Vim simply quit using the X server instead of -dying? Also relevant when running in a console. - -Accessing file#var in a function should not need the g: prepended. - -When ":cn" moves to an error in the same line the message isn't shortened. -Only skip shortening for ":cc"? - -Write "making vim work better" for the docs (mostly pointers): *nice* - - sourcing $VIMRUNTIME/vimrc_example.vim - - setting 'mouse' to "a" - - getting colors in xterm - - compiling Vim with X11, GUI, etc. - -Problem with ":call" and dictionary function. Hari Krishna Dara, Charles -Campbell 2006 Jul 06. - -Syntax HL error caused by "containedin". (Peter Hodge, 2006 Oct 6) - -A custom completion function in a ":command" cannot be a Funcref. (Andy -Wokula, 2007 Aug 25) - -Problem with using :redir in user command completion function? (Hari Krishna -Dara, 2006 June 21) - -GTK: When maximizing Vim the result is slightly smaller, the filler border is -not there, and the "maximize" button is still there. Clicking it again does -give a maximized window. (Darren Hiebert) -Problem is that gui_mch_set_text_area_pos() is invoked to change the text area -size, which causes the toplevel window to resize. When doing this while the -size is already right the filler remains there. -Detect using the maximize button (GdkWindowState bit -GDK_WINDOW_STATE_MAXIMIZED) and set it again? - -Another resizing problem when setting 'columns' and 'lines' to a very large -number. (Tony Mechelynck, 2007 Feb 6) - -GTK: when using the -geom argument with an offset from the right edge and the -size is smaller than the default, the Vim window is not positioned properly. - -After starting Vim, using '0 to jump somewhere in a file, ":sp" doesn't center -the cursor line. It works OK after some other commands. - -Win32: Is it possible to have both postscript and Win32 printing? -Does multi-byte printing with ":hardcopy" work? Add remark in documentation -about this. - -There should be something about spell checking in the user manual. - -Check: Running Vim in a console and still having connect to the X server for -copy/paste: is stopping the X server handled gracefully? Should catch the X -error and stop using the connection to the server. - -Problem with 'cdpath' on MS-Windows when a directory is equal to $HOME. (2006 -Jul 26, Gary Johnson) - -In the Netbeans interface add a "vimeval" function, so that the other side can -check the result of has("patch13"). - -Add command modifier that skips wildcard expansion, so that you don't need to -put backslashes before special chars, only for white space. - -Win32: When the GUI tab pages line is displayed Vim jumps from the secondary -to the primary monitor. (Afton Lewis, 2007 Mar 9) Old resizing problem? - -GTK: when the Tab pages bar appears or disappears while the window is -maximized the window is no longer maximized. Patch that has some idea but -doesn't work from Geoffrey Antos, 2008 May 5. - -The magic clipboard format "VimClipboard2" appears in several places. Should -be only one. - -"vim -C" often has 'nocompatible', because it's set somewhere in a startup -script. Do "set compatible" after startup? - -It's difficult to debug numbered functions (function in a Dictionary). Print -the function name before resolving it to a number? - let d = {} - fun! d.foo() - echo "here" - endfun - call d.foo(9) - -Add a mark for the other end of the Visual area (VIsual pos). '< and '> are -only set after Visual moded is ended. -Also add a variable for the Visual mode. So that this mode and '< '> can be -used to set what "gv" selects. (Ben Schmidt) - -Win32: When running ":make" and 'encoding' differs from the system locale, the -output should be converted. Esp. when 'encoding' is "utf-8". (Yongwei Wu) -Should we use 'termencoding' for this? - -Win32, NTFS: When editing an specific infostream directly and 'backupcopy' is -"auto" should detect this situation and work like 'backupcopy' is "yes". File -name is something like "c:\path\foo.txt:bar", includes a colon. (Alex -Jakushev, 2008 Feb 1) - -Small problem displaying diff filler line when opening windows with a script. -(David Luyer, 2007 Mar 1 ~/Mail/oldmail/mool/in.15872 ) - -Is it allowed that 'backupext' is empty? Problems when backup is in same dir -as original file? If it's OK don't compare with 'patchmode'. (Thierry Closen) - -Patch for supporting count before CR in quickfix window. (AOYAMA Shotaro, 2007 -Jan 1) - -Patch for adding ":lscscope". (Navdeep Parhar, 2007 Apr 26; update 2008 Apr -23) - -":mkview" isn't called with the right buffer argument. Happens when using -tabs and the autocommand "autocmd BufWinLeave * mkview". (James Vega, 2007 -Jun 18) - -xterm should be able to pass focus changes to Vim, so that Vim can check for -buffers that changed. Perhaps in misc.c, function selectwindow(). -Xterm 224 supports it! - -When completing from another file that uses a different encoding completion -text has the wrong encoding. E.g., when 'encoding' is utf-8 and file is -latin1. Example from Gombault Damien, 2007 Mar 24. - -Is it possible to use "foo#var" instead of "g:foo#var" inside a function? - -Syntax HL: When using "nextgroup" and the group has an empty match, there is -no search at that position for another match. (Lukas Mai, 2008 April 11) - -Spell menu: When using the Popup menu to select a replacement word, -":spellrepeat" doesn't work. SpellReplace() uses setline(). Can it use "z=" -somehow? Or use a new function. - -In gvim the backspace key produces a backspace character, but on Linux the -VERASE key is Delete. Set VERASE to Backspace? (patch by Stephane Chazelas, -2007 Oct 16) - -When entering a C /* comment, after typing <Enter> for 70 times the indent -disappears. (Vincent Beffara, 2008 Jul 3) - -TermResponse autocommand isn't always triggered when using vimdiff. (Aron -Griffis, 2007 Sep 19) - -Patch for supporting #rrggbb in color terminals. (Matt Wozniski) - -Create a gvimtutor.1 file and change Makefiles to install it. - - -Vim 7.3: -- Add patch for 'relativenumber' option? Markus Heidelberg, 2008 Jun 27. -- Add blowfish encryption. Openssl has an implementation. Also by Paul - Kocher (LGPL), close to original. Mohsin also has some ideas. - Take four bytes and turn them into unsigned to avoid byte-order problems. - Need to buffer up to 7 bytes to align on 8 byte boundaries. -- ":{range}source": source the lines from the file. - You can already yank lines and use :@" to execute them. - Most of do_source() would not be used, need a new function. - It's easy when not doing breakpoints or profiling. - - -More patches: -- Add 'cscopeignorecase' option. (Liang Wenzhi, 2006 Sept 3) -- Argument for feedkeys() to prepend to typeahead (Yakov Lerner, 2006 Oct - 21) -- Load intl.dll too, not only libintl.dll. (Mike Williams, 2006 May 9, docs - patch May 10) -- Extra argument to strtrans() to translate special keys to their name (Eric - Arnold, 2006 May 22) -- 'threglookexp' option: only match with first word in thesaurus file. - (Jakson A. Aquino, 2006 Jun 14) -- Mac: indicate whether a buffer was modified. (Nicolas Weber, 2006 Jun 30) -- Allow negative 'nrwidth' for left aligning. (Nathan Laredo, 2006 Aug 16) -- ml_append_string(): efficiently append to an existing line. (Brad - Beveridge, 2006 Aug 26) Use in some situations, e.g., when pasting a - character at a time? -- gettabvar() and settabvar() functions. (Yegappan Lakshmanan, 2007 Sep 13, - 2008 Jun 12) -- recognize hex numbers better. (Mark Manning, 2006 Sep 13) -- Add <AbbrExpand> key, to expand an abbreviation in a mapping. (Kana - Natsuno, 2008 Jul 17) -- Add 'wspara' option, also accept blank lines like empty lines for "{" and - "}". (Mark Lundquist, 2008 Jul 18) -- Patch to add CTRL-T to delete part of a path on cmdline. (Adek, 2008 Jul - 21) -- Instead of creating a copy of the tutor in all the shell scripts, do it in - vimtutor.vim. (Jan Minar, 2008 Jul 20) -- When fsync() fails there is no hint about what went wrong. Patch by Ben - Schmidt, 2008 Jul 22. - - -Awaiting updated patches: -9 Mac unicode patch (Da Woon Jung, Eckehard Berns): - 8 Add patch from Muraoka Taro (Mar 16) to support input method on Mac? - New patch 2004 Jun 16 - - selecting proportional font breaks display - - UTF-8 text causes display problems. Font replacement causes this. - - Command-key mappings do not work. (Alan Schmitt) - - With 'nopaste' pasting is wrong, with 'paste' Command-V doesn't work. - (Alan Schmitt) - - remove 'macatsui' option when this has been fixed. - - when 'macatsui' is off should we always convert to "macroman" and ignore - 'termencoding'? -9 HTML indenting can be slow. Caused by using searchpair(). Can search() - be used instead? A.Politz is looking into a solution. -8 Win32: Add minidump generation. (George Reilly, 2006 Apr 24) -8 Add ":n" to fnamemodify(): normalize path, remove "../" when possible. - Aric Blumer has a patch for this. He will update the patch for 6.3. -7 Completion of network shares, patch by Yasuhiro Matsumoto. - Update 2004 Sep 6. - How does this work? Missing comments. -- Patch for 'breakindent' option: repeat indent for wrapped line. (Vaclav - Smilauer, 2004 Sep 13, fix Oct 31, update 2007 May 30) -8 Add a few more command names to the menus. Patch from Jiri Brezina - (28 feb 2002). Will mess the translations... -7 ATTENTION dialog choices are more logical when "Delete it' appears - before "Quit". Patch by Robert Webb, 2004 May 3. -- Include flipcase patch: ~/vim/patches/wall.flipcase2 ? Make it work - for multi-byte characters. -- Win32: add options to print dialog. Patch from Vipin Aravind. -- Patch to add highlighting for whitespace. (Tom Schumm, 2003 Jul 5) - use the patch that keeps using HLF_8 if HLF_WS has not - been given values. - Add section in help files for these highlight groups? -8 "fg" and "bg" don't work in an xterm. Get default colors from xterm - with an ESC sequence. - xterm can send colors for many things. E.g. for the cursor: - <Esc>]12;?<Bel> - Can use this to get the background color and restore the colors on exit. -7 Add "DefaultFG" and "DefaultBG" for the colors of the menu. (Marcin - Dalecki has a patch for Motif and Carbon) -- Add possibility to highlight specific columns (for Fortran). Or put a - line in between columns (e.g., for 'textwidth'). - Patch to add 'hlcolumn' from Vit Stradal, 2004 May 20. -8 Add functions: - gettext() Translate a message. (Patch from Yasuhiro Matsumoto) - Update 2004 Sep 10 - Another patch from Edward L. Fox (2005 Nov 24) - Search in 'runtimepath'? - More docs needed about how to use this. - How to get the messages into the .po files? - charlen() Like strlen() but counting characters instead of - bytes. - confirm() add "flags" argument, with 'v' for vertical - layout and 'c' for console dialog. (Haegg) - Flemming Madsen has a patch for the 'c' flag - (2003 May 13) - raisewin() raise gvim window (see HierAssist patch for - Tcl implementation ~/vim/HierAssist/ ) - taglist() add argument to specify maximum number of matches. - useful for interactive things or completion. - col('^') column of first non-white character. - Can use "len(substitute(getline('.'), '\S.*', '', '')) - + 1", but that's ugly. -7 Add patch from Benoit Cerrina to integrate Vim and Perl functions - better. Now also works for Ruby (2001 Nov 10) -- Patch from Herculano de Lima Einloft Neto for better formatting of the - quickfix window (2004 dec 2) -7 When 'rightleft' is set, the search pattern should be displayed right - to left as well? See patch of Dec 26. (Nadim Shaikli) -8 Option to lock all used memory so that it doesn't get swapped to disk - (uncrypted). Patch by Jason Holt, 2003 May 23. Uses mlock. -7 Support a stronger encryption. Jason Holt implemented AES (May 6 2003). -7 Add ! register, for shell commands. (patch from Grenie) -8 In the gzip plugin, also recognize *.gz.orig, *.gz.bak, etc. Like it's - done for filetype detection. Patch from Walter Briscoe, 2003 Jul 1. -7 Add a "-@ filelist" argument: read file names from a file. (David - Kotchan has a patch for it) -8 Include a connection to an external program through a pipe? See - patches from Felbinger for a mathematica interface. - Or use emacs server kind of thing? -7 Add ":justify" command. Patch from Vit Stradal 2002 Nov 25. -- findmatch() should be adjusted for Lisp. See remark at - get_lisp_indent(). Esp. \( and \) should be skipped. (Dorai Sitaram, - incomplete patch Mar 18) -- For GUI Find/Replace dialog support using a regexp. Patch for Motif - and GTK by degreneir (nov 10 and nov 18). -- Patch for "paranoid mode" by Kevin Collins, March 7. Needs much more work. - - -Vi incompatibility: -- Try new POSIX tests, made after my comments. (Geoff Clare, 2005 April 7) - Version 1.5 is in ~/src/posix/1.5. (Lynne Canal) -8 With undo/redo only marks in the changed lines should be changed. Other - marks should be kept. Vi keeps each mark at the same text, even when it - is deleted or restored. (Webb) - Also: A mark is lost after: make change, undo, redo and undo. - Example: "{d''" then "u" then "d''": deletes an extra line, because the '' - position is one line down. (Veselinovic) -8 When stdin is not a tty, and Vim reads commands from it, an error should - make Vim exit. -7 Unix Vim (not gvim): Typing CTRL-C in Ex mode should finish the line - (currently you can continue typing, but it's truncated later anyway). - Requires a way to make CTRL-C interrupt select() when in cooked input. -8 When loading a file in the .exrc, Vi loads the argument anyway. Vim skips - loading the argument if there is a file already. When no file argument - given, Vi starts with an empty buffer, Vim keeps the loaded file. (Bearded) -6 In Insert mode, when using <BS> or <Del>, don't wipe out the text, but - only move back the cursor. Behaves like '$' in 'cpoptions'. Use a flag - in 'cpoptions' to switch this on/off. -8 When editing a file which is a symbolic link, and then opening another - symbolic link on the same file, Vim uses the name of the first one. - Adjust the file name in the buffer to the last one used? Use several file - names in one buffer??? - Also: When first editing file "test", which is symlink to "test2", and - then editing "test2", you end up editing buffer "test" again. It's not - logical that the name that was first used sticks with the buffer. -7 The ":undo" command works differently in Ex mode. Edit a file, make some - changes, "Q", "undo" and _all_ changes are undone, like the ":visual" - command was one command. - On the other hand, an ":undo" command in an Ex script only undoes the last - change (e.g., use two :append commands, then :undo). -7 The ":map" command output overwrites the command. Perhaps it should keep - the ":map" when it's used without arguments? -7 CTRL-L is not the end of a section? It is for Posix! Make it an option. -7 Implement 'prompt' option. Init to off when stdin is not a tty. -7 CTRL-T in Insert mode inserts 'shiftwidth' of spaces at the cursor. Add a - flag in 'cpoptions' for this. -7 Add a way to send an email for a crashed edit session. Create a file when - making changes (containing name of the swap file), delete it when writing - the file. Supply a program that can check for crashed sessions (either - all, for a system startup, or for one user, for in a .login file). -7 Vi doesn't do autoindenting when input is not from a tty (in Ex mode). -7 "z3<CR>" should still use the whole window, but only redisplay 3 lines. -7 ":tag xx" should move the cursor to the first non-blank. Or should it go - to the match with the tag? Option? -7 Implement 'autoprint'/'ap' option. -7 Add flag in 'cpoptions' that makes <BS> after a count work like <Del> - (Sayre). -7 Add flag in 'cpoptions' that makes operator (yank, filter) not move the - cursor, at least when cancelled. (default Vi compatible). -7 This Vi-trick doesn't work: "Q" to go to Ex mode, then "g/pattern/visual". - In Vi you can edit in visual mode, and when doing "Q" you jump to the next - match. Nvi can do it too. -7 Support '\' for line continuation in Ex mode for these commands: (Luebking) - g/./a\ g/pattern1/ s/pattern2/rep1\\ - line 1\ line 2\\ - line 2\ line 3\\ - . line4/ -6 ":e /tmp/$tty" doesn't work. ":e $uid" does. Is $tty not set because of - the way the shell is started? -6 Vi compatibility (optional): make "ia<CR><ESC>10." do the same strange - thing. (only repeat insert for the first line). - - -GTK+ 1 (OK in GTK 2): -8 When using "gvim -geom 40x30" or setting 'columns' in .gvimrc or with a - GUIEnter autocommand, the width is still set to fit the toolbar. Also - happens when changing the font. How to avoid that the toolbar specifies - the minimal window width? -8 When using a theme with different scrollbars (gtkstep), the scrollbars can - be too narrow. (Drazen Kacar) -8 Font "7x14" has a bold version "7x14bold". Try to find the bold font by - appending "bold" when there are not 14 dashes. - -GTK+ GUI known bugs: -9 Crash with X command server over ssh. (Ciaran McCreesh, 2006 Feb 6) -8 GTK 2: Combining UTF-8 characters not displayed properly in menus (Mikolaj - Machowski) They are displayed as separate characters. Problem in - creating a label? -8 GTK 2: Combining UTF-8 characters are sometimes not drawn properly. - Depends on the font size, "monospace 13" has the problem. Vim seems to do - everything right, must be a GTK bug. Is there a way to work around it? -9 Can't paste a Visual selection from GTK-gvim to vim in xterm or Motif gvim - when it is longer than 4000 characters. Works OK from gvim to gvim and - vim to vim. Pasting through xterm (using the shift key) also works. - It starts working after GTK gvim loses the selection and gains it again. -- Gnome2: When moving the toolbar out of the dock, so that it becomes - floating, it can no longer be moved. Therefore making it float has been - blocked for now. - - -Win32 GUI known bugs: -- Win32: tearoff menu window should have a scrollbar when it's taller than - the screen. -8 non-ASCII font names don't work. Need to convert from 'encoding' and use - the wide functions. -8 On Windows 98 the unicows library is needed to support functions with UCS2 - file names. Can we load unicows.dll dynamically? -8 When the primary monitor is below or right of the secondary monitor and - Vim is on the secondary monitor it will often move to the primary monitor. - Window position coordinates can be negative. (James Harvey) -8 The -P argument doesn't work very well with many MDI applications. - The last argument of CreateWindowEx() should be used, see MSDN docs. - Tutorial: http://win32assembly.online.fr/tut32.html -8 In eval.c, io.h is included when MSWIN32 is defined. Shouldn't this be - WIN32? Or can including io.h be moved to vim.h? (Dan Sharp) -7 Windows XP: When using "ClearType" for text smoothing, a column of yellow - pixels remains when typing spaces in front of a "D" ('guifont' set to - "lucida_console:h8"). -6 Win32 GUI: With "-u NONE -U NONE" and doing "CTRL-W v" "CTRL-W o", the ":" - of ":only" is highlighted like the cursor. (Lipelis) -8 When 'encoding' is "utf-8", should use 'guifont' for both normal and wide - characters to make Asian languages work. Win32 fonts contain both - type of characters. -7 When font smoothing is enabled, redrawing can become very slow. The reason - appears to be drawing with a transparent background. Would it be possible - to use an opaque background in most places? -8 Use another default for 'termencoding': the active codepage. Means that - when 'encoding' is changed typing characters still works properly. - Alternative: use the Unicode functions to obtain typed characters. -8 Win32: Multi-byte characters are not displayed, even though the same font - in Notepad can display them. (Srinath Avadhanula) Try with the - UTF-8-demo.txt page with Andale Mono. -7 The cursor color indicating IME mode doesn't work properly. (Shizhu Pan, - 2004 May 9) -8 Win32: When clicking on the gvim title bar, which gives it focus, produces - a file-changed dialog, after clicking on a button in that dialog the gvim - window follows the mouse. The button-up event is lost. Only with - MS-Windows 98? - Try this: ":set sw ts", get enter-prompt, then change the file in a - console, go back to Vim and click "reload" in the dialog for the changed - file: Window moves with the cursor! - Put focus event in input buffer and let generic Vim code handle it? -8 Win32: When mouse is hidden and in the toolbar, moving it won't make it - appear. (Sami Salonen) -8 Win32 GUI: With maximized window, ":set go-=r" doesn't use the space that - comes available. (Poucet) It works OK on Win 98 but doesn't work on Win - NT 4.0. Leaves a grey area where the scrollbar was. ":set go+=r" also - doesn't work properly. -8 When Vim is minimized and when maximizing it a file-changed dialog pops - up, Vim isn't maximized. It should be done before the dialog, so that it - appears in the right position. (Webb) -9 When selecting at the more-prompt or hit-enter-prompt, the right mouse - button doesn't give popup menu. - At the hit-enter prompt CTRL-Y doesn't work to copy the modeless - selection. - On the command line, don't get a popup menu for the right mouse button. - Let the middle button paste selected text (not the clipboard but the - non-Visual selection)? Otherwise CTRL-Y has to be used to copy the text. -8 When 'grepprg' doesn't execute, the error only flashes by, the - user can hardly see what is wrong. (Moore) - Could use vimrun with an "-nowait" argument to only wait when an error - occurs, but "command.com" doesn't return an error code. -8 When the 'shell' cannot be executed, should give an appropriate error msg. - Esp. for a filter command, currently it only complains the file could not - be read. -7 Add an option to add one pixel column to the character width? Lucida - Console italic is wider than the normal font ("d" overlaps with next char). - Opposite of 'linespace': 'columnspace'. -7 At the hit-enter prompt scrolling now no longer works. Need to use the - keyboard to get around this. Pretend <CR> was hit when the user tries to - scroll? -7 Scrollbar width doesn't change when selecting other windows appearance. - Also background color of Toolbar and rectangle below vert. scrollbar. -7 "!start /min cmd" should run in a minimized window, instead of using - "/min" as the command name. (Rogall) -6 Drawing text transparently doesn't seem to work (when drawing part cursor). -8 CTRL key doesn't always work in combination with ALT key. It does work - for function keys, not for alphabetic characters. Perhaps this is because - CTRL-ALT is used by Windows as AltGr? -8 CTRL-- doesn't work for AZERTY, because it's CTRL-[ for QWERTY. How do we - know which keyboard is being used? -7 When scrolling, and a background color is dithered, the dither pattern - doesn't always join correctly between the scrolled area and the new drawn - area (Koloseike). -8 When gui_init_font() is called with "*", p_guifont is freed while it might - still be used somewhere. This is too tricky, do the font selection first, - then set the new font by name (requires putting all logfont parameters in - the font name). - - -Athena and Motif: -6 New Motif toolbar button from Marcin Dalecki: - - When the mouse pointer is over an Agide button the red becomes black. - Something with the way colors are specified in the .xpm file. - - The pixmap is two pixels smaller than it should be. The gap is filled - with grey instead of the current toolbar background color. -9 Can configure be changed to disable netbeans if the Xpm library is - required and it's missing? -8 When using the resource "Vim*borderwidth 2" the widgets are positioned - wrong. -9 XIM is disabled by default for SGI/IRIX. Fix XIM so that 'imdisable' can - be off by default. -9 XIM doesn't work properly for Athena/Motif. (Yasuhiro Matsumoto) For now, - keep XIM active at all times when the input method has the preediting - flag. -8 X11: A menu that contains an umlaut is truncated at that character. - Happens when the locale is "C", which uses ASCII instead of IS0-8859-1. - Is there a way to use latin1 by default? Gnome_init() seems to do this. -8 Perhaps use fontsets for everything? -6 When starting in English and switching the language to Japanese, setting - the locale with ":lang", 'guifontset' and "hi menu font=", deleting all - menus and setting them again, the menus don't use the new font. Most of - the tooltips work though... -7 Motif: when using a file selection dialog, the specified file name is not - always used (when specifying a filter or another directory). -8 When 'encoding' is different from the current locale (e.g., utf-8) the - menu strings don't work. Requires conversion from 'encoding' to the - current locale. Workaround: set 'langmenu'. - - -Athena GUI: -9 When dragging the scrollbar thumb very fast, focus is only obtained in - the scrollbar itself. And the thumb is no longer updated when moving - through files. -7 The file selector is not resizable. With a big font it is difficult to - read long file names. (Schroeder) -4 Re-write the widget attachments and code so that we will not have to go - through and calculate the absolute position of every widget every time the - window is refreshed/changes size. This will help the "flashing-widgets" - problem during a refresh. -5 When starting gvim with all the default colors and then typing - ":hi Menu guibg=cyan", the menus change color but the background of the - pullright pixmap doesn't change colors. - If you type ":hi Menu guibg=cyan font=anyfont", then the pixmap changes - colors as it should. - Allocating a new pixmap and setting the resource doesn't change the - pullright pixmap's colors. Why? Possible Athena bug? - - -Motif GUI: -- gui_mch_browsedir() is missing. -7 Use XmStringCreateLocalized() instead of XmStringCreateSimple()? - David Harrison says it's OK (it exists in Motif 1.2). -8 Lesstif: When deleting a menu that's torn off, the torn off menu becomes - very small instead of disappearing. When closing it, Vim crashes. - (Phillipps) - - -GUI: -9 On Solaris, creating the popup menu causes the right mouse button no - longer to work for extending the selection. (Halevy) -9 When running an external program, it can't always be killed with CTRL-C. - e.g., on Solaris 5.5, when using "K" (Keech). Other 'guipty' problems on - Solaris 2.6. (Marley) -9 On Solaris: Using a "-geometry" argument, bigger than the window where Vim - is started from, causes empty lines below the cmdline. (raf) -8 X11 GUI: When menu is disabled by excluding 'm' from 'guioptions', ALT key - should not be used to trigger a menu (like the Win32 version). -8 When setting 'langmenu', it should be effective immediately. Store both - the English and the translated text in the menu structure. Re-generate - the translation when 'langmenu' has changed. -8 Basic flaw in the GUI code: NextScreen is updated before calling - gui_write(), but the GUI code relies on NextScreen to represent the state - of where it is processing the output. - Need better separation of Vim core and GUI code. -8 When fontset support is enabled, setting 'guifont' to a single font - doesn't work. -8 Menu priority for sub-menus for: Amiga, BeOS. -8 When translating menus ignore the part after the Tab, the shortcut. So - that the same menu item with a different shortcut (e.g., for the Mac) are - still translated. -8 Add menu separators for Amiga, RISCOS. -8 Add way to specify the file filter for the browse dialog. At least for - browse(). -8 Add dialog for search/replace to other GUIs? Tk has something for this, - use that code? Or use console dialog. -8 When selecting a font with the font dialog and the font is invalid, the - error message disappears too quick. -7 More features in the find/replace dialog: - - regexp on/off - - search in selection/buffer/all buffers/directory - when all buffers/directory is used: - - filter for file name - when directory is used: - - subdirectory on/off - - top directory browser -8 gui_check_colors() is not called at the right moment. Do it much later, - to avoid problems. -8 gui_update_cursor() is called for a cursor shape change, even when there - are mappings to be processed. Only do something when going to wait for - input. Or maybe every 100 ms? -8 X11: When the window size is reduced to fit on screen, there are blank - lines below the text and bottom scrollbar. "gvim -geometry 80x78+0+0". - When the "+0+0" is omitted it works. -8 When starting an external command, and 'guipty' set, BS and DEL are mixed - up. Set erase character somehow? -8 A dead circumflex followed by a space should give the '^' character - (Rommel). Look how xterm does this. - Also: Bednar has some code for dead key handling. - Also: Nedit 5.0.2 with USE_XMIM does it right. (Gaya) -8 The compose key doesn't work properly (Cepas). Both for Win32 and X11. -7 The cursor in an inactive window should be hollow. Currently it's not - visible. -7 GUI on Solaris 2.5.1, using /usr/dt/..: When gvim starts, cursor is - hollow, after window lowered/raised it's OK. (Godfrey) -7 When starting GUI with ":gui", and window is made smaller because it - doesn't fit on the screen, there is an extra redraw. -8 When setting font with .Xdefaults, there is an extra empty line at the - bottom, which disappears when using ":set guifont=<Tab>". (Chadzelek) -8 When font shape changes, but not the size, doing ":set font=" does not - redraw the screen with the new font. Also for Win32. - When the size changes, on Solaris 2.5 there isn't a redraw for the - remaining part of the window (Phillipps). -- Flashes really badly in certain cases when running remotely from a Sun. -4 Re-write the code so that the highlighting isn't changed multiple times - when doing a ":hi clear". The color changes happen three or more times - currently. This is very obvious on a 66Mhz 486. - - -MSDOS/DJGPP: -9 Pressing CTRL-C often crashes the console Vim runs in. (Ken Liao) - When 'bioskey' isn't set it doesn't happen. Could be a problem with the - BIOS emulation of the console. Version 5.6 already had this problem. -8 DJGPP: "cd c:" can take us to a directory that no longer exists. - change_drive() doesn't check this. How to check for this error? -9 The 16 bit version runs out of memory very quickly. Should find unused - code and reduce static data. Resetting 'writebackup' helps to be able to - write a file. -9 Crash when running on Windows 98 in a console window and pressing CTRL-C. - Happens now and then. When debugging Vim in gdb this also happens. Since - the console crashes, might be a bug in the DOS console. Resetting - 'bioskey' avoids it, but then CTRL-C doesn't work. -9 DOS: Make CTRL-Fx and ALT-Fx work. - CTRL-F1 = CE-5E, CTRL-F2 = CE-5F, .., CTRL-F10 = CE-67 - ALT-F1 = CE-68, ALT-F2 = CE-69, .., ALT-F10 = CE-71 - Shifted cursor keys produce same codes as unshifted keys. Use bioskey(2) - to get modifier mask for <S-C-M-Fx>. - Use K_SPECIAL/KS_MODIFIER codes to insert modifier mask in input stream? - Make this work like in Win32 console. - Mapping things like <M-A> doesn't work, because it generates an extended - key code. Use a translation table? -9 Can't read an opened swap file when the "share" command has not been used. - At least ignore the swap files that Vim has opened itself. -8 Use DJGPP 2.03. -8 The Dos32 version (DJGPP) can't use long file names on Windows NT. - Check if new package can be used (v2misc/ntlfn08[bs].zip). -8 setlocale() is bogus. -8 Vim busy waits for new characters or mouse clicks. Should put in some - sort of sleep, to avoid eating 50% of the CPU time. Test on an unpatched - Windows 95 system! -8 DJGPP: when shell is bash, make fails. (Donahoe) -7 Hitting CTRL-P twice quickly (e.g., in keyword completion) on a 8088 - machine, starts printer echo! (John Mullin). -7 MSDOS 16 bit version can't work with COMSPEC that has an argument, e.g.: - COMSPEC=C:\WINDOWS\COMMAND.COM /E:4096 (Bradley) - Caused by BCC system() function (Borland "make" has the same problem). -8 Mouse: handle left&right button pressed as middle button pressed. Add - modifier keys shift, ctrl and alt. -7 When too many files are open (depends on FILES), strange things happen. - The Dos16 version runs out of memory, in the Dos32 version "!ls" causes a - crash. Another symptom: .swp files are not deleted, existing files are - "[New file]". -7 DJGPP version doesn't work with graphics display mode. Switch to a mode - that is supported? -8 DJGPP: ":mode" doesn't work for many modes. Disable them. -8 DJGPP: When starting in Ex mode, shouldn't clear the screen. (Walter - Briscoe) - - -MSDOS, OS/2 and Win32: -8 OS/2: Add backtick expansion. Undefine NO_EXPANDPATH and use - gen_expand_wildcards(). -8 OS/2: Add clipboard support? See example clipbrd.exe from Alexander - Wagner. -8 OS/2: Add Extended Attributes support and define HAVE_ACL. -8 OS/2: When editing a file name "foo.txt" that is actually called FOO.txt, - writing uses "foo.txt". Should obtain the real file name. -8 Should $USERPROFILE be preferred above $HOMEDRIVE/$HOMEPATH? No, but it's - a good fallback, thus use: - $HOME - $HOMEDRIVE$HOMEPATH - SHGetSpecialFolderPath(NULL, lpzsPath, CSIDL_APPDATA, FALSE); - $USERPROFILE - SHGetSpecialFolderPath(NULL, lpzsPath, CSIDL_COMMON_APPDATA, FALSE); - $ALLUSERSPROFILE - $SYSTEMDRIVE\ - C:\ -8 Win32 console: <M-Up> and <M-Down> don't work. (Geddes) We don't have - special keys for these. Should use modifier + key. -8 Win32 console: caps-lock makes non-alpha keys work like with shift. - Should work like in the GUI version. -8 Environment variables in DOS are not case sensitive. Make a define for - STRCMP_ENV(), and use it when comparing environment var names. -8 Setting 'shellslash' has no immediate effect. Change all file names when - it is set/reset? Or only use it when actually executing a shell command? -8 When editing a file on a Samba server, case might matter. ":e file" - followed by ":e FILE" will edit "file" again, even though "FILE" might be - another one. Set last used name in buflist_new()? Fix do_ecmd(), etc. -8 When a buffer is editing a file like "ftp://mach/file", which is not going - to be used like a normal file name, don't change the slashes to - backslashes. (Ronald Hoellwarth) - - -Windows 95: -8 Editing a file by it's short file name and writing it, makes the long file - name disappear. Setting 'backupcopy' helps. - Use FindFirstFile()->cAlternateFileName in fname_case() (George Reilly). -8 Doing wildcard expansion, will match the short filename, but result in the - long filename (both DJGPP and Win32). - - -Win32 console: -9 When editing a file by its short file name, it should be expanded into its - long file name, to avoid problems like these: (Mccollister) - 1) Create a file called ".bashrc" using some other editor. - 2) Drag that file onto a shortcut or the actual executable. - 3) Note that the file name is something like BASHRC~1 - 4) Go to File->Save As menu item and type ".bashrc" as the file name. - 5) Press "Yes" to indicate that I want to overwrite the file. - 6) Note that the message "File exists (add ! to override)" is displayed - and the file is not saved. - Use FindFirstFile() to expand a file name and directory in the path to its - long name. -8 Also implement 'conskey' option for the Win32 console version? Look at - how Xvi does console I/O under Windows NT. -7 Re-install the use of $TERM and support the use of different terminals, - besides the console. -8 Use of <altgr> modifier doesn't work? 5.3 was OK. (Garcia-Suarez/Guckes) -9 Mapping <C-S-Tab> doesn't work correctly. How to see the difference with - <C-S-i>? -9 tmpnam() uses file in root of file system: "\asdf". That doesn't work on - a Netware network drive. Use same function as for Win32 GUI? -8 In os_win32.h, HAVE_STRICMP and HAVE_STRNICMP are defined only if __GNUC__ - is not defined. Shouldn't that be the other way around? -7 Use SetConsoleCP() and SetConsoleOutputCP() to implement 'termencoding'? - Avoids that input and output work differently. Need to be restored when - exiting. - - -Amiga: -8 In mch_inchar() should use convert_input_safe() to handle incomplete byte - sequences. -9 In mch_expandpath() a "*" is to be expanded, but "\*" isn't. Remove - backslashes in result. -8 Executing a shell, only one option for 'shell' is separated. Should do - all options, using white space separation. - - -Macintosh: -- GUI: gui_mch_browsedir() is missing. -7 Patch to add 'transparency' option. Disadvantage: it's slow. (Eckehard - Berns, 2004 May 9) http://ecki.to/vim/TransBack-2004-05-09.diff - Needs more work. Add when someone really wants it. -7 Loading the Perl library only works on OS/X 10.2 or 10.3, never on both. - Load the Perl library dynamically see Python sources file dynload_mac - (Jack) - dynamic linking: http://developer.apple.com/technotes/tn2002/tn2064.html -8 Inputting Unicode characters does not work in the terminal. They appear - to arrive as upper and lower bytes. (David Brown, 2004 April 17) -8 Typing Unicode characters doesn't work at all in the GUI. -8 inputdialog() doesn't resize when giving more text lines. (David Fishburn, - 2006 Sept 28) -9 Problems in Carbon version for OS X: (Benji Fisher) - - keyboard shortcuts in the menus get lost. -8 The Vim/About menu doesn't work. -8 ":gui" doesn't fork. Enabling the code in gui.c to fork causes a SEGV. -8 Define vim_mkdir() for Macintosh. -8 Define mch_writable() for Macintosh. -8 Some file systems are case-sensitive, some are not. Turn - CASE_INSENSITIVE_FILENAME into an option, at least for completion. -9 When DiskLock is running, using a swap file causes a crash. Appears to be - a problem with writing a file that starts with a dot. (Giacalone) -9 On G3 Mac, OS version 8, control strip causes characters messed up when - scrolling (CTRL-L cleans it up). (Benji Fisher) -9 On G3 Mac, OS version 8, variable-speed scrolling doesn't work, after two - seconds of scrolling the screen freezes. (Benji Fisher) -9 In mac_expandpath() check that handling of backslashes is done properly. -8 Standard Mac shortcuts are missing. (Amerige) -8 Handling of non-fixed width fonts is wrong. (Amerige) - - -"Small" problems: -- Can't disable terminal flow control, to enable the use of CTRL-S and - CTRL-Q. Add an option for it? -- When using e_secure in do_one_cmd() mention the command being executed, - otherwise it's not clear where it comes from. -9 For Turkish vim_tolower() and vim_toupper() also need to use utf_ - functions for characters below 0x80. (Sertacyildiz) -9 When the last edited file is a help file, using '0 in a new Vim doesn't - edit the file as a help file. 'filetype' is OK, but 'iskeyword' isn't, - file isn't readonly, etc. -8 When an ":edit" is inside a try command and the ATTENTION prompt is used, - the :catch commands are always executed, also when the file is edited - normally. Should reset did_emsg and undo side effects. Also make sure - the ATTENTION message shows up. Servatius Brandt works on this. -8 ":g//" gives "Pattern not found error" with E486. Should not use the - error number, it's not a regular error message. -7 Vimtutor leaves escape sequence in terminal. This is the xterm response to - requesting the version number. (Yasuhiro Matsumoto) -8 When redirecting and using ":silent" the current column for displaying and - redirection can be different. Use a separate variable to hold the column - for redirection. -7 The messages for "vim --help" and "vim --version" don't use - 'termencoding'. -- Could the hit-enter prompt be avoided when a message only overlaps the - 'showcmd' area? Clear that area when the next cmd is typed. -8 When 'scrollbind' is set, a window won't scroll horizontally if the cursor - line is too short. Add a word in 'scrollopt' to allow moving the cursor - to longer line that is visible. A similar thing is done for the GUI when - using the horizontal scrollbar. -7 VisVim can only open one file. Hard to solve: each opened file is passed - with a separate invocation, would need to use timestamps to know the - invocations belong together. -8 When giving a ":bwipeout" command a file-changed dialog may popup for this - buffer, which is pointless. (Mike Williams) -8 On MS-Windows ":make" doesn't show output while it is working. Use the - tee.exe from http://unxutils.sourceforge.net/ ? About 16 Kbyte in the - UnxUtils.zip archive. - Alternate one: http://www.pramodx.20m.com/tee_for_win32.htm, but Walter - Briscoe says it's not as good. -8 "stl" and "stlnc" in 'fillchars' don't work for multi-byte characters. -8 When doing Insert mode completion a mapping cannot recursively call - edit(), because the completion information is global. Put everything in - an allocated structure? -6 Python: ":py raw_input('prompt')" doesn't work. (Manu Hack) -8 Command line completion: buffers "foo.txt" and "../b/foo.txt", completing - ":buf foo<Tab>" doesn't find the second one. (George V. Reilly) -7 Output for ":scriptnames" and ":breaklist" should shorten the file names: - use "~/" when possible. -7 mb_off2cells() doesn't work correctly on the tail byte of a double-byte - character. (Yasuhiro Matsumoto) It should return 1 when used on a tail - byte, like for utf-8. Store second byte of double-byte in ScreenLines2[] - (like for DBCS_JPNU) and put a zero in the second byte (like for UTF-8). -8 'backupdir' and 'directory' should use $TMPDIR, $TMP and/or $TEMP when - defined. -7 Inside a function with "perl <<EOF" a line with "$i++" is recognized as an - ":insert" command, causing the following "endfunction" not to be found. - Add skipping this perl construction inside function definitions. -7 When 'ttimeoutlen' is 10 and 'timeoutlen' is 1000, there is a keycode - "<Esc>a" and a mapping <Esc>x", when typing "<Esc>a" with half a second - delay should not be interpreted as a keycode. (Hans Ginzel) -7 ":botright 1 new" twice causes all window heights to be changed. Make the - bottom window only bigger as much as needed. -7 The Cygwin and MingW makefiles define "PC", but it's not used anywhere. - Remove? (Dan Sharp) -9 User commands use the context of the script they were defined in. This - causes a "s:var" argument to unexpectedly use a variable in the defining - script, not the calling script. Add an argument to ":command": - "-keepcontext". Do replace <SID>, so that a function in the defining - script can be called. -8 The Japanese message translations for MS-Windows are called ja.sjis.po, - but they use encoding cp932. Rename the file and check that it still - works. -8 A very long message in confirm() can't be quit. Make this possible with - CTRL-C. -7 clip_x11_own_selection() uses CurrentTime, that is not allowed. VNC X - server has a problem with this. (Mark Waggoner) Remembering the timestamp - of events isn't always possible. We don't get them in an xterm. GTK - doesn't obtain the selection again when the timestamp differs, thus it - won't work for GTK anyway. -8 When the clipboard isn't supported: ":yank*" gives a confusing error - message. Specifically mention that the register name is invalid. -8 "gf" always excludes trailing punctuation characters. file_name_in_line() - is currently fixed to use ".,:;!". Add an option to make this - configurable? -8 'hkmap' should probably be global-local. -9 When "$" is in 'cpoptions' and folding is active, a "C" command changes - the folds and resets w_lines_valid. The display updating doesn't work - then. (Pritesh Mistry) -8 Using ":s" in a function changes the previous replacement string. Save - "old_sub" in save_search_patterns()? -8 Should allow multi-byte characters for the delimiter: ":s+a+b+" where "+" - is a multi-byte character. -8 When appending to a file and 'patchmode' isn't empty, a backup file is - always written, even when the original file already exists. -7 When using "daw" on the last word in a file and this is a single letter, - nothing is deleted. Should delete the letter and preceding white space. -9 When getting focus while writing a large file, could warn for this file - being changed outside of Vim. Avoid checking this while the file is being - written. -7 The message in bt_dontwrite_msg() could be clearer. -8 The script ID that is stored with an option and displayed with ":verbose - set" isn't reset when the option is set internally. For example when - 'foldlevel' is set from 'foldlevelstart'. -8 Also store the line number with the script ID and use it for ":verbose", - so that "set nocompatible" is found when it changes other option values. - When an option is set indirectly mention the command? E.g. when - ":diffsplit" sets 'foldmethod'. -8 In the fileformat dialog, "Cancel" isn't translated. Add a global - variable for this. (Eduardo Fernandez) -9 When editing a file with 'readonly' set, there is no check for an existing - swap file. Then using ":write" (without making any changes) doesn't give - a warning either. Should check for an existing swap file without creating - one. Unfinished patch by Ian Kelling, 2008 July 14. -7 When 'showbreak' is set, the amount of space a Tab occupies changes. - Should work like 'showbreak' is inserted without changing the Tabs. -7 When 'mousefocus' is set and switching to another window with a typed - command, the mouse pointer may be moved to a part of the window that's - covered by another window and we lose focus. Only move in the y - direction, not horizontally? -8 ":hardcopy": - - Using the cterm_color[] table is wrong when t_colors is > 16. - - Need to handle unprintable characters. - - Win32: On a B&W printer syntax highlighting isn't visible. Perform - dithering to make grey text? - - Add a flag in 'printoptions' to add an empty page to make the total - number even. "addempty"? (Mike Williams) - - Respect 'linebreak'. Perhaps also 'showbreak'? - - Should interpreted CTRL-L as a page break. - - Grey line numbers are not always readable. Add field in 'printoptions'. - Default to black when no syntax highlighting. - - Be able to print a window in diff mode. - - Be able to specify a colorscheme to use for printing. And a separate - one for B&W printing (if that can be detected). -8 In Visual block mode with 'lbr' set, a change command doesn't insert the - text in following lines where the linebreak changes. -9 dosinst.c: The DJGPP version can't uninstall the Uninstall registry key on - Windows NT. How to install a .inf file on Windows NT and how to detect - that Windows NT is being used? -8 When 'virtualedit' is "block,insert" and encoding is "utf-8", selecting a - block of one double-wide character, then "d" deletes only half of it. -8 When 'virtualedit' is set, should "I" in blockwise visual mode also insert - in lines that don't extend into the block? -8 With 'virtualedit' set, in Insert mode just after the end of line, CTRL-O - yh does not yank the last character of the line. (Pavel Papushev) - Doing "hl" first appears to make it work. -8 With 'virtualedit' set it's possible to move into the blank area from - 'linebreak'. -8 With 'virtualedit' set and 'selection' "exclusive", a Visual selection - that ends in or after a tab, "d" doesn't delete (part of) the tab. - (Helmut Stiegler) -8 With 'virtualedit' set, a blockwise Visual selection that starts and ends - in a tab, "<" shifts too much. (Helmut Stiegler) -9 When jumping to a tag, the search pattern is put in the history. When - 'magic' is on, the pattern may not work. Translate the pattern depending - on p_magic when putting it in the history? Alternative: Store value of - 'magic' in history. (Margo) -9 optwin.vim: Restoring a mapping for <Space> or <CR> is not correct for - ":noremap". Add "mapcmd({string}, {mode})? Use code from ":mkexrc". -9 incsearch is incorrect for "/that/<Return>/this/;//" (last search pattern - isn't updated). -9 term_console is used before it is set (msdos, Amiga). -9 Get out-of-memory for ":g/^/,$s//@/" on 1000 lines, this is not handled - correctly. Get many error messages while redrawing the screen, which - cause another redraw, etc. -8 [<C-I> doesn't work when '*' is in 'iskeyword'. find_pattern_in_path() - must escape special characters in the pattern. -8 Vim can overwrite a read-only file with ":w!". ":w" can't overwrite an - existing file, "w!" can, but perhaps not a read-only file? Then use - ":w!!" for that. - Or ask for permission to overwrite it (if file can be made writable) and - restore file to readonly afterwards. - Overwriting a file for which a swap file exists is similar issue. -7 When compiled with "xterm_clipboard", startup can be slower and might get - error message for invalid $DISPLAY. Try connecting to the X server in the - background (forked), so that Vim starts up quicker? Connect as soon as - the clipboard is to be used (Visual select mode starts, paste from - clipboard) -7 X11: Some people prefer to use CLIPBOARD instead of PRIMARY for the normal - selection. Add an "xclipboard" argument to the 'clipboard' option? (Mark - Waggoner) -8 For xterm need to open a connection to the X server to get the window - title, which can be slow. Can also get the title with "<Esc>[21t", no - need to use X11 calls. This returns "<Esc>]l{title}<Esc>\". -6 When the xterm reports the number of colors, a redraw occurs. This is - annoying on a slow connection. Wait for the xterm to report the number of - colors before drawing the screen. With a timeout. -8 When the builtin xterm termcap contains codes that are not wanted, need a - way to avoid using the builtin termcap. -8 Xterm sends ^[[H for <Home> and ^[[F for <End> in some mode. Also - recognize these keys? Mostly useful for xterm simulators, like gnometerm. - See http://dickey.his.com/xterm/xterm.faq.html#xterm_pc_style. -8 For xterm also recognize keypad up/down/left/right and insert. -8 '[ and '] should be set to start/end of line when using a linewise operator - (e.g., ":w"). -8 CTRL-A can't handle big "long" numbers, they become negative. Check for - "-" character, if not present, use unsigned long. -8 Make it possible to disable the special meaning of "#" in the first column - for ">>". -8 Add suspending with CTRL-Z at the "more" prompt, and when executing a long - script in do_cmdline(). -8 When using 'hidden', many swap files will be open. When Vim runs into the - maximum number of open files, error messages will appear. Detect that - this problem is present, and close any hidden files that don't have - changes. -8 With 'viminfo' set such that the ".viminfo" file is written on a FAT - filesystem, an illegal file name may be created: ".vim". -8 For each buffer that is opened, the viminfo file is opened and read to - check for file marks. This can be slow. -7 In xterm, recognize both vt100 and vt220 cursor keys. Change - add_termcode() to not remove an existing entry for a name, when it's - needed. - Need a generic solution to recognize different codes for the same key. -8 Core dump within signal function: gdb doesn't show stack backtrace! Option - to skip catch_signals()? -9 Repeating a "cw" with "." doesn't work if the text was pasted from the - clipboard. (Thomas Jones) It's because the menu/toolbar item exits Insert - mode and uses "gP". How to fix this without breaking inserting a block of - text? -8 In Replace mode pasting from the clipboard (using menu or toolbar) inserts - all the text. Add ":rmenu"? -8 Pasting with the mouse in Replace mode inserts the text, instead of - overwriting, when it is more than one line. Same for using <C-R>. -9 CTRL-E and CTRL-Y don't work in small window when 'so' is 4 and lines are - wrapping (Acevedo/in.226). E.g., when using CTRL-E, window height 7, - window might actually scroll down when last line of buffer is displayed. - --> Remember if the previous command was "cursor follows screen" or - "screen follow cursor" and use this in cursupdate(). -7 tilde_replace() can only handle "~/", should also do "~user/". - Get the list of home directories (from /etc/passwd? Use getpwent()) and - use some clever algorithm to match a path with that. Find common strings - in the list? -8 When dragging status line with mouse, sometimes a jump when first clicking - on the status line (caused by 'winheight'). Select window on button up, - instead of on button down. -8 Dragging the status line doesn't scroll but redraw. -9 Evaluating 'statusline' in build_stl_str_hl() does not properly check for - reaching the end of the available buffer. - Patch to dynamically allocate the buffer for % items. (Eric Arnold, 2006 - May 14) -8 When performing incremental search, should abort searching as soon as a - character is typed. -8 When the value of $MAKE contains a path, configure can't handle this. - It's an autoconf bug. Remove the path from $MAKE to work around it. -8 How to set VIMRC_FILE to \"something\" for configure? Why does this not - work: CFLAGS='-DVIMRC_FILE=\"/mydir/myfile\"' ./configure -8 The temporary file is sometimes not writable. Check for this, and use an - alternate name when it isn't. Or add the 'temptemplate' option: template - for the temp file name ":set temptemplate=/usr/tmp/?????.tmp". - Also: Win32 version uses Windows temp directory, which might not work for - cygwin bash. -7 Get error "*, \+ or \( operand could be empty" for pattern "\(.\)\1\{3}". - Remember flags for backreferences. -7 When switching to Daylight Saving Time, Vim complains that a file has been - changed since last read. Can we use a function that uses GMT? -7 When completing an environment variable after a '$', check for file names - that contain a '$' after all have been found. -8 When "cm" termcap entry is missing, starting gvim shouldn't complain about - it. (Lohner) Try out with "vt100" entry, cm replaced with cX. -7 When an include file starts with "../", the check for already visiting - this file doesn't work. Need to simplify the file name. -7 The names and comments for the arguments of do_browse() are confusing. - "dflt" isn't the default file name when "initdir" is not NULL and - "initdir" is the default path to be used. -7 When 'scrolloff' is exactly half the window height, "j" causes a scroll of - two lines at a time. "k" doesn't do this. (Cory T. Echols) -8 When write_viminfo() is used while there are many orphaned viminfo - tempfiles writing the viminfo file fails. Give a clear error message so - that the user knows he has to delete the files. -7 It's possible to redefine a script-local function with ":func - <SNR>123_Test()". (Krishna) Disallow this. - - -I can't reproduce these (if you can, let me know how!): -9 NT 4.0 on NTFS file system: Editing ".bashrc" (drag and drop), file - disappears. Editing ".xyz" is OK. Also, drag&drop only works for three - files. (McCollister) - - -Problems that will (probably) not be solved: -- GTK: when using the popup menu with spelling suggestions and releasing the - right mouse button before the menu appears selecting an item with the - right mouse button has no effect. GTK does not produce an event for this. -- GTK 2: Cannot use the file selector. When using it many things become - slow. This is caused by some code in GTK that writes - ~/.recently-used.xbel every time an event is handled. It assumes the main - loop is never quit, which is a wrong assumption. Also, it overwrites the - file with different file permissions, which is a privacy issue. This - needs to be fixed in GTK. A solution in Vim would be really complicated. - (2008 Jul 31) -- xterm title: The following scenario may occur (esp. when running the Vim - test script): Vim 1 sets the title to "file1", then restores the title to - "xterm" with an ESC sequence when exiting. Vim 2 obtains the old title - with an X library call, this may result in "file1", because the window - manager hasn't processed the "xterm" title yet. Can apparently only be - worked around with a delay. -- In a terminal with 'mouse' set such that the mouse is active when entering - a command line, after executing a shell command that scrolls up the - display and then pressing ":": Selecting text with the mouse works like - the display wasn't scrolled. Vim doesn't know how much the external - command scrolled up the display. Use Shift to select text. -- X windows: When $DISPLAY points to a X server where there is no access - permission, trying to connect to the X server causes an error message. - XtOpenDisplay() prints this directly, there is no way to avoid it. -- X windows: Setting 'guifontset' to an illegal value sometimes crashes Vim. - This is caused by a fault in a X library function, can't be solved in Vim. -- Win32 tcl: has("tcl") hangs when the tcl84.dll is from cygwin. -- Motif: When adding a menu item "Find this &Symbol", the "s" in "this" will - be underlined, instead of in "Symbol". Motif doesn't let us specify which - character gets the highlighting. -- Moving the cursor removes color in color-xterm. This is a color-xterm - problem! color-xterm ver. 6.1 beta 3 and later work properly. -- In zsh, "gvim&" changes the terminal settings. This is a zsh problem. - (Jennings) -- Problem with HPterm under X: old contents of window is lost (Cosentino). -- Amiga: When using quickfix with the Manx compiler we only get the first 25 - errors. How do we get the rest? -- Amiga: The ":cq" command does not always abort the Manx compiler. Why? -- Linux: A file with protection r--rw-rw- is seen readonly for others. The - access() function in GNU libc is probably wrong. -- MSDOS: When using smartdrive with write-back buffering, writing to a - readonly floppy will cause problems. How to test for a writable floppy - first? -- MSDOS: Both 16 and 32 bit versions: File name expansion doesn't work for - names that start with a dot. These used to be illegal file names. -- When doing a CTRL-Z and typing a command for the shell, while Vim is busy - (e.g. writing a file), the command for the shell is sometimes eaten by Vim, - because the terminal mode is changed from RAW to CBREAK. -- An old version of GNU tgoto can't handle the terminfo code for "AF". The - "%p1" is interpreted as "%p" and "1", causing color not to be working. - Fix: Change the "%p1" in the "AF" and "AB" terminfo entries to "%p". - (Benzinger). -- When running an external command from the GUI, typeahead is going to that - program, not to Vim. It looks like the shell eats the characters, Vim - can't get back what the external command didn't use. -- Win32 GUI: Error code from external command not returned in shell_error. - It appears that cmd.exe and command.com don't return an error code. -- Win32 GUI: The Toolbar is a bit too high when the flat style is being - used. We don't have control over the height of the Toolbar. -- Win32: All files created on the day of switching from winter to summer - time cause "changed since editing started" messages. It goes away when - the file is written again the next day, or the timezone is adjusted. - DJGPP version is OK. (Zaimi) Looks like a problem with the Win32 library. - Rebooting doesn't help. Time stamps look OK in directory. (Penn) - Is this on FAT (stores wall clock time) or NTFS (stores UTS)? -- Win32, MS-Windows XP: $HOME uses the wrong drive when the user profiles - are not on the boot disk. This is caused by a wrong value of $HOMEDRIVE. - This is a bug in XP, see MSKB article 818134. -- SunOS 5.5.1 with Motif: The file open dialog does not have a horizontal - scroll bar for the "files" selection. This is a problem in the Motif - libraries, get a patch from Sun. -- Solaris 2.6 with GTK and Perl: gvim crashes when started. Problem with X - input method called from GDK code. Without Perl it doesn't crash. -- VMS: Vimdiff doesn't work with the VMS diff, because the output looks - different. This makes test 47 fail. Install a Unix-compatible diff. -- VMS v7.1 and older: Tests 21 and 32 fail. From VMS v7.1-2 and newer Vim - does not have this behavior. (Zoltan Arpadffy) -- Win32 GUI: mouse wheel always scrolls rightmost window. The events arrive - in Vim as if the rightmost scrollbar was used. -- GTK with Gnome: Produces an error message when starting up: - Gdk-WARNING **: locale not supported by C library - This is caused by the gnome library gnome_init() setting $LC_CTYPE to - "en_US". Not all systems support this locale name, thus causing the - error. Hopefully a newer version of GTK/Gnome fixes this problem. -- GTK 2: With this mapping the hit-enter prompt is _sometimes_ below the - screen, at other times there is a grey area below the command line: - :nmap <F11> :if &guioptions=~'m' \| set guioptions-=m \| else \| set guioptions+=m \| endif<cr> -- GTK: When pasting a selection from Vim to xclipboard gvim crashes with a - ABRT signal. Probably an error in the file gdkselection.c, the assert - always fails when XmbTextListToTextProperty() fails. (Tom Allard) -- GTK 2: gives an assertion error for every non-builtin icon in the toolbar. - This is a GTK 2.4.x bug, fixed in GTK 2.4.2. (Thomas de Grenier de Latour) -- When using an xterm that supports the termresponse feature, and the 't_Co' - termcap option was wrong when Vim started, it will be corrected when the - termresponse is received. Since the number of colors changes, the - highlighting needs to be initialized again. This may cause colors defined - in the vimrc file to be lost. -- On Windows NT 4.0 the number of files passed to Vim with drag&drop and - "Edit with Vim" is limited. The maximum command line length is 255 chars. - ---------------------- extensions and improvements ---------------------- - *extensions-improvements* - -Didn't make it into Vim 7.0: -- Add COLUMN NUMBERS to ":" commands ":line1,line2[col1,col2]cmd". Block - can be selected with CTRL-V. Allow '$' (end of line) for col2. -- Add DEBUGGER INTERFACE. Implementation for gdb by Xavier de Gaye. - Should work like an IDE. Try to keep it generic. Now found here: - http://clewn.sf.net. - And the idevim plugin/script. - To be able to start the debugger from inside Vim: For GUI run a program - with a netbeans connection; for console: start a program that splits the - terminal, runs the debugger in one window and reconnect Vim I/O to the - other window. - Wishes for NetBeans commands: - - make it possible to have 'defineAnnoType' also handle terminal colors. - - send 'balloonText' events for the cursor position (using CursorHold ?) - in terminal mode. -- ECLIPSE plugin. Problem is: the interface is very complicated. Need to - implement part in Java and then connect to Vim. Some hints from Alexandru - Roman, 2004 Dec 15. Should then also work with Oracle Jdeveloper, see JSR - 198 standard http://www.jcp.org/en/jsr/detail?id=198. - Eclim does it: http://eclim.sourceforge.net/ (Eric Van Dewoestine) - Plugin that uses a terminal emulator: http://vimplugin.sf.net - And another one: http://www.satokar.com/viplugin/index.php -- STICKY CURSOR: Add a way of scrolling that leaves the cursor where it is. - Especially when using the scrollbar. Typing a cursor-movement command - scrolls back to where the cursor is. -- Running a shell command from the GUI still has limitations. Look into how - the terminal emulator of the Vim shell project can help: - http://vimshell.wana.at -- Add Lua interface? (Wolfgang Oertl) -8 Add a command to jump to a certain kind of tag. Allow the user to specify - values for the optional fields. E.g., ":tag size type=m". - Also allow specifying the file and command, so that the result of - taglist() can be used. -- X11: Make it possible to run Vim inside a window of another program. - This can be done with XReparentWindow(). But how exactly? - - -Documentation: -8 List of Vim runtime directories. dotvim.txt from Charles Campbell, 2007 - Feb 20. -8 The GUI help should explain the Find and Find/Replace dialogs. Add a link - to it from ":promptrepl" and ":promptfind". -8 List of options should mention whether environment variables are expanded - or not. -8 Extend usr_27.txt a bit. (Adam Seyfarth) -7 Add a section on debugging scripts in the user manual. -9 Make the Reference Manual more precise. For each command mention: - - change to cursor position and curswant - - if it can be undone (u/CTRL-R) and redone (.) - - how it works for folded lines - - how it works with multi-byte characters -9 In change.txt, remark about Javadoc isn't right. Right alignment would - work too. -8 Spread the windows commands over the other files. For example, ":stag" - should be with ":tag". Cross-link with tags to avoid too much double - text. -8 Add tags for all features, e.g. "gui_running". -7 MS-Windows: When a wrong command is typed with an ALT key, give a hint to - look at the help for 'winaltkeys'. -7 Add a help.vim plugin that maps <Tab> to jump to the next tag in || and - <C-Tab> (and <S-Tab>) to the previous tag. - Patch by Balazs Kezes, 2007 Dec 30. Remark from A. Politz. -- Check text editor compendium for vi and Vim remarks. - - -Help: -- First try using the ":help" argument literally, before using it as a - pattern. And then match it as part of a tag. -- When a help item has multiple matches make it possible to use ":tn" to go - to the other matches. -- Support a way to view (and edit) .info files. -- Default mapping for help files: <Tab> to position cursor on next |:tag|. -- Implement a "sticky" help window, some help text lines that are always - displayed in a window with fixed height. (Guckes) Use "~/.vimhelp" file, - user can edit it to insert his favorite commands, new account can contain a - default contents. -- Make 'winminheight' a local option, so that the user can set a minimal - height for the help window (and other windows). -- ":help :s^I" should expand to ":help :substitute". -- Make the help key (<F1>) context sensitive? -- Learn mode: show short help while typing commands. - - -User Friendlier: -8 Windows install with NSIS: make it possible to do a silent install, see - http://nsis.sourceforge.net/Docs/Chapter4.html#4.12 -8 Windows install with install.exe: Use .exe instead of .bat files for - links, so that command line arguments are passed on unmodified? (Walter - Briscoe) -8 Windows install: Be able to associate Vim with a selection of file types? -8 Windows uninstall: Have uninstal.c delete the vimfiles directories that - dosinst.c creates. List the contents of the directory (recursively) if - the user asks for it. Requires an implementation of "rm -rf". -8 Remember the name of the vimrc file that was used (~/.vimrc, $VIM/_vimrc, - $HOME/_vimrc, etc.) and add "edit vimrc" to the File menu. -- Add a way to save local settings and mappings into a new plugin file. - ":mkplugin <file>"? -8 Add ":plugininstall" command. Can be used to install a plugin file that - includes documentation. Let the user select a directory from - 'runtimepath'. - " Vim plugin - <main plugin code> - " >>> plugin help start <<< - <plugin docs> -- Add mappings local to a window: ":map <window> ..."? -9 Add buffer-local menu. Should offer a choice between removing the menu or - disabling it. Be careful that tear-offs don't disappear (keep one empty - item?). - Alternative: use BufEnter and BufLeave autocommands. -8 make a vimtutor script for Amiga and other systems. -7 Add the arguments for configure to the ":version" output? -7 When Vim detects a file is being edited elsewhere and it's a gvim session - of the same user it should offer a "Raise" button, so that the other gvim - window can be displayed. (Eduard) -8 Support saving and restoring session for X windows? It should work to do - ":mksession" and use "-S fname" for the restart command. The - gui_x11_wm_protocol_handler() already takes care of the rest. - global_event_filter() for GTK. - - -Tab pages: -9 GUI implementation for the tab pages line for other systems. -7 GUI: Control over the appearance of the text in the labels (bold, color, - font, etc.) -9 Make it possible to drag a tab page label to another position with the - mouse. -8 Make GUI menu in tab pages line configurable. Like the popup menu. -8 balloons for the tab page labels that are shortened to show the full path. -8 :tabmove +N move tab page N pages forward -8 :tabmove -N move tab page N pages backward -7 :tabdup duplicate the tab with all its windows. -7 Option to put tab line at the left or right? Need an option to specify - its width. It's like a separate window with ":tabs" output. -7 Add local variables for each tab page? -8 Add local options for each tab page? E.g., 'diffopt' could differ between - tab pages. -7 Add local highlighting for each tab page? -7 Add local directory for tab pages? How would this interfere with - window-local directories? - - -Spell checking: -- have some way not to give spelling errors for a range of characters. - E.g. for Chinese and other languages with specific characters for which we - don't have a spell file. Useful when there is also text in other - languages in the file. -- Support more regions? Caolan McNamara argues it's needed for es_XX. - https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=219777 -- Unicode defines another quote character: 0x2019. Use it as an equivalent - of a single quote, thus use it as a word character like a quote and match - with words, replacing the curly quote with a single quote. -- Could filter é things for HTML before doing spell checking. - Similarly for TeX. -- The Hungarian spell file uses four extra characters in the FOL/UPP/LOW - items than other spell files with the ISO-8859-2 encoding, that causes - problem when changing 'spelllang'. There is no obvious way to fix this. -- Considering Hunspell 1.1.4: - What does MAXNGRAMSUGS do? - Is COMPLEXPREFIXES necessary when we have flags for affixes? -- Support spelling words in CamelCase as if they were two separate words. - Requires some option to enable it. (Timothy Knox) -- There is no Finnish spell checking file. For openoffic Voikko is now - used, which is based on Malaga: http://home.arcor.de/bjoern-beutel/malaga/ - (Teemu Likonen) -8 ":mkspell" still takes much too long in Hungarian dictionary from - hunspell. Only solution appears to be to postpone secondary suffixes. -8 Handle postponed prefix with COMPOUNDPERMITFLAG or COMPOUNDFORBIDFLAG. - WFP_COMPPERMIT and WFP_COMPFORBID -8 implement use of <compoptions> in .spl file: - implement CHECKCOMPOUNDREP: when a compound word seems to be OK apply REP - items and check if the result is a valid word. - implement CHECKCOMPOUNDDUP - implement CHECKCOMPOUNDTRIPLE - Add CHECKCOMPOUNDCASE: when compounding make leading capital lower case. - How is it supposed to work? -8 implement using CHECKCOMPOUNDPATTERN: match words with sl_comppat[]. -- Add a command the repeats ]s and z=, showing the misspelled word in its - context. Thus to spell-check a whole file. -- suggestion for "KG" to "kg" when it's keepcase. -- For flags on affixes: Use a "AFFCOMPSET" flag; means the compound flags of - the word are not used. -- Support breakpoint character ? 0xb7 and ignore it? Makes it possible to - use same wordlist for hyphenation. -- Compound word is accepted if nr of words is <= COMPOUNDWORDMAX OR nr of - syllables <= COMPOUNDSYLMAX. Specify using AND in the affix file? -- NEEDCOMPOUND also used for affix? Or is this called ONLYINCOMPOUND now? - Or is ONLYINCOMPOUND only for inside a compound, not at start or end? -- Do we need a flag for the rule that when compounding is done the following - word doesn't have a capital after a word character, even for Onecap words? -- New hunspell home page: http://hunspell.sourceforge.net/ - - Version 1.1.0 is out now, look into that. - - Lots of code depends on LANG, that isn't right. Enable each mechanism - in the affix file separately. - - Example with compounding dash is bad, gets in the way of setting - COMPOUNDMIN and COMPOUNDWORDMAX to a reasonable value. - - PSEUDOROOT == NEEDAFFIX - - COMPOUNDROOT -> COMPOUNDED? For a word that already is a compound word - Or use COMPOUNDED2, COMPOUNDED3, etc. -8 Alternate Dutch word list at www.nederlandsewoorden.nl (use script to - obtain). But new Myspell wordlist will come (Hagen) -- CIRCUMFIX: when a word uses a prefix marked with the CIRCUMFIX flag, then - the word must also have a suffix marked with the CIRCUMFIX flag. It's a - bit primitive, since only one flag is used, which doesn't allow matching - specific prefixes with suffixes. - Alternative: - PSFX {flag} {pchop} {padd} {pcond} {schop} {sadd}[/flags] {scond} - We might not need this at all, you can use the NEEDAFFIX flag and the - affix which is required. -- When a suffix has more than one syllable, it may count as a word for - COMPOUNDWORDMAX. -- Add flags to count extra syllables in a word. SYLLABLEADD1 SYLLABLEADD2, - etc.? Or make it possible to specify the syllable count of a word - directly, e.g., after another slash: /abc/3 -- MORPHO item in affix file: ignore TAB and morphological field after - word/flags and affix. -- Implement multiple flags for compound words and CMP item? - Await comments from other spell checking authors. -- Also see tklspell: http://tkltrans.sourceforge.net/ -8 Charles Campbell asks for method to add "contained" groups to existing - syntax items (to add @Spell). - Add ":syntax contains {pattern} add=@Spell" command? A bit like ":syn - cluster" but change the contains list directly for matching syntax items. -- References: MySpell library (in OpenOffice.org). - http://spellchecker.mozdev.org/source.html - http://whiteboard.openoffice.org/source/browse/whiteboard/lingucomponent/source/spellcheck/myspell/ - author: Kevin Hendricks <kevin.hendricks@sympatico.ca> -8 It is currently not possible to mark "can not" as rare, because "can" and - "not" are good words. Find a way to let "rare" overrule "good"? -8 Make "en-rare" spell file? Ask Charles Campbell. -8 The English dictionaries for different regions are not consistent in their - use of words with a dash. -7 Insert mode completion mechanism that uses the spell word lists. -8 Add hl groups to 'spelllang'? - :set spelllang=en_us,en-rare/SpellRare,en-math/SpellMath - More complicated: Regions with different languages? E.g., comments - in English, strings in German (po file). - - -Diff mode: -9 Instead invoking an external diff program, use builtin code. One can be - found here: http://www.ioplex.com/~miallen/libmba/dl/src/diff.c -8 Use diff mode to show the changes made in a buffer (compared to the file). - Use an unnamed buffer, like doing: - new | set bt=nofile | r # | 0d_ | diffthis | wincmd p | diffthis - Also show difference with the file when editing started? Should show what - can be undone. (Tom Popovich) -7 Add cursor-binding: when moving the cursor in one diff'ed buffer, also - move it in other diff'ed buffers, so that CTRL-W commands go to the same - location. - - -Folding: - (commands still available: zI zJ zK zp zP zq zQ zV zy zY; - secondary: zB zS zT zZ, z=) -8 Vertical folds: looks like vertically split windows, but the cursor moves - through the vertical separator, separator moves when scrolling. -8 Add "z/" and "z?" for searching in not folded text only. -9 Add search pattern item to only match in closed or open fold and/or fold - with certain level. Allows doing ":g/pat/cmd" to work on closed folds. -8 Add different highlighting for a fold line depending on the fold level. - (Noel Henson) -7 Use "++--", "+++--" for different levels instead of "+---" "+----". -8 When a closed fold is displayed open because of 'foldminlines', the - behavior of commands is still like the fold is closed. How to make the - user aware of this? -8 Add an option 'foldskip' with values like 'foldopen' that specifies which - commands skip over a closed fold. -8 "H" and "L" count buffer lines instead of window lines. (Servatius Brandt) -8 Add a way to add fold-plugins. Johannes Zellner has one for VB. -7 When using manual folding, the undo command should also restore folds. -- Allow completely hiding a closed fold. E.g., by setting 'foldtext' to an - empty string. Require showing a character in 'foldcolumn' to avoid the - missing line goes unnoticed. - How to implement this? -- When pressing the down arrow of a scrollbar, a closed fold doesn't scroll - until after a long time. How to make scrolling with closed folds - smoother? -- When creating a session, also store folds for buffers in the buffer list, - using the wininfo in wi_folds. -- When currently editing the first file in the argument list the session - file can contain: - args version.c main.c - edit version.c - Can editing version.c twice be avoided? -- 'foldmethod' "textobject": fold on sections and paragraph text objects. -- Add 'hidecomment' option: don't display comments in /* */ and after //. - Or is the conceal patch from Vince Negri a more generic solution? -- "zuf": undo change in manual fold. "zUf" redo change in manual fold. How - to implement this? -- "zJ" command: add the line or fold below the fold in the fold under the - cursor. -- 'foldmethod' "syntax": "fold=3" argument: set fold level for a region or - match. -- Apply a new foldlevel to a range of lines. (Steve Litt) -8 Have some way to restrict commands to not folded text. Also commands like - searches. - - -Multi-byte characters: -- When editing a file with both utf-8 and latin1 text Vim always falls back - to latin1. Add a command to convert the latin1 characters to utf-8? - :unmix utf-8,latin1 filename - Would only work when 'encoding' is utf-8. -9 When the tail byte of a double-byte character is illegal (e.g., a CR), the - display is messed up (Yasuhiro Matsumoto). Should check for illegal - double-byte characters and display them differently (display each single - byte). -8 Add an item in 'fileencodings' to check the first lines of a file for - the encoding. See Python PEP: http://www.python.org/peps/pep-0263.html. - To avoid getting a wrong encoding only accept something Emacs-like: - "-*- coding: enc-na_me.foo -*-" and "-*- coding= enc-na_me.foo -*-" - Match with "-\*-\s*coding[:=]\s*\([::word::-_.]\+\)\s*-\*-" and use first - item. -8 Add an item in 'fileencodings' to check the first line of an XML file for - the encoding. <?xml version="1.0" encoding="UTF-8"?> Or "charset=UTF-8"? - For HTML look for "charset=utf-8". -8 The quickfix file is read without conversion, thus in 'encoding'. Add an - option to specify the encoding of the errorfile and convert it. Also for - ":grep" and ":helpgrep". - More generic solution: support a filter (e.g., by calling a function). -8 When a file was converted from 'fileencoding' to 'encoding', a tag search - should also do this on the search pattern. (Andrzej M. Ostruszka) -8 When filtering changes the encoding 'fileencoding' may not work. E.g., - when using xxd and 'fileencoding' is "utf-16". Add an option to set a - different fileencoding for filter output? -7 When converting a file fails, mention which byte could not be converted, - so that the user can fix the problem. -8 Add configure option to be able to disable using the iconv library. (Udo - Schweigert) -9 'aleph' should be set to 1488 for Unicode. (Zvi Har'El) -8 Should add test for using various commands with multi-byte characters. -8 'infercase' doesn't work with multi-byte characters. -8 toupper() function doesn't handle byte count changes. -7 Searching and composing characters: - When searching, should order of composing characters be ignored? - Add special item to match with a composing character, zero-width, so that - one can replace a base character and keep the composing characters. - Add a special item to match with a composing character, so that composing - characters can be manipulated. - Add a modifier to ignore composing characters, only compare base - characters. Useful for Hebrew (Ron Aaron) -8 Should implement 'delcombine' for command line editing. -8 Detect overlong UTF-8 sequences and handle them like illegal bytes. -8 ":s/x/\u\1/" doesn't work, making uppercase isn't done for multi-byte - characters. -8 UTF-8: "r" in Visual mode doesn't take composing characters. -8 UTF-8: When there is a precomposed character in the font, use it instead - of a character and a composing character. See xterm for an example. -7 When a character can't be displayed, display its digraph instead. - 'display' option to specify this. -7 Use ideas for nl_langinfo() from Markus Kuhn in enc_default(): - (www.cl.cam.ac.uk/~mgk25/ucs/langinfo.c) -- GTK and Win32: Allow selecting fonts for 'guifontset' with the - fontselector somehow. -- GTK and Win32: make it possible to set the font for the menu to make it - possible to have 'encoding' different from the current locale. -- dbcs_class() only works for Japanese and Korean. Implement this for - other encodings. The "euc-jp" and "euc-kr" choices might be wrong. -- Find some way to automatically select the right GUI font or fontset, - depending on the default value of 'encoding'. - Irrelevant in the GTK+ 2 GUI so long as UTF-8 is used. - For Windows, the charset_pairs[] table could be used. But how do we know - if a font exists? -- Do keyboard conversion from 'termencoding' to 'encoding' with - convert_input() for Mac GUI and RiscOS GUI. -- Add mnemonics from RFC1345 longer than two characters. - Support CTRL-K _{mnemonic}_ -7 In "-- INSERT (lang) --" show the name of the keymap used instead of - "lang". (Ilya Dogolazky) -- Make 'langmap' accept multi-byte characters. - Patch from Konstantin Korikov, 2006 Oct 15. -- Make 'breakat' accept multi-byte characters. Problem: can't use a lookup - table anymore (breakat_flags[]). - Simplistic solution: when 'formatoptions' contains "m" also break a line - at a multi-byte character >= 0x100. -- Do we need the reverse of 'keymap', like 'langmap' but with files and - multi-byte characters? E.g., when using a Russian keyboard. -- Add the possibility to enter mappings which are used whenever normal text - could be entered. E.g., for "f" command. But not in Normal mode. Sort - of opposite of 'langmap'. Use ":tmap" command? -- When breaking a line, take properties of multi-byte characters into - account. The "linebreak" program from Bruno Haible can do it: - ftp://ftp.ilog.fr/pub/Users/haible/gnu/linebreak-0.1.tar.gz - But it's very complicated... - - -Printing: -7 Implement "undercurl" for printing. -- Add "page width" to wrap long lines. -- Win32: use a font dialog for setting 'printfont'. Can reuse the code for - the 'guifont' dialog, put the common code in a separate function. -- Add the file timestamp to the page header (with an option). (George - Reilly) -- Win32: when 'printfont' is empty use 'guifont'. -- Unix: Use some dialog box to do the obvious settings (paper size, printer - name, portrait/landscape, etc). -- PostScript: Only works for text that can be converted to an 8-bit - character set. How to support Unicode fully? -- Allow specifying the paper size, instead of using a standard size. Same - units as for the margins. -- Support right-to-left text? -8 Make the foreground color darkening function preserve the hue of the - color. - - -Syntax highlighting: -8 Make ":syn off" use 'runtimepath' instead of $VIMRUNTIME. (Gary Johnson) - Should do the same for ":syn on" and ":syn manual". -8 Support "containedin" argument for ":syn include", so that the defined - cluster can be added to existing syntax items. -8 C syntax: Don't highlight {} as errors inside () when used like this: - "({ something })", often used in GCC code. -7 Add a "startgroup" to a region. Used like "nextgroup" inside the region, - preferred item at the start of the region. (Charles Campbell) -8 When editing a new file without a name and giving it a name (by writing - it) and 'filetype' is not set, detect the filetype. Avoid doing it for - ":wq file". -7 For "nextgroup" we have skipwhite, skipnl and skipempty. It would be - really nice to be able to skip with a pattern. Or skip with a syntax - group. (Nikolai Weibull, 2007 Feb 27) -8 Make conversion to HTML faster (Write it in C or pre-compile the script). -9 There is still a redraw bug somewhere. Probably because a cached state is - used in a wrong way. I can't reproduce it... -7 Be able to change only the background highlighting. Useful for Diff* and - Search highlighting. -7 When 'number' is set highlight the number of the current line. - Must be enabled with an option, because it slows down display updating. -8 Allow the user to add items to the Syntax menu sorted, without having to - change this for each release. -8 Add a "matchcontains" for regions: items contained in the start or end - pattern, but not in the body. -8 Add a "keepend-contained" argument: Don't change the end of an item this - one is contained in. Like "keepend" but specified on the contained item, - instead of the containing item. -8 cpp.vim: In C++ it's allowed to use {} inside (). -8 Some syntax files set 'iskeyword'. When switching to another filetype - this isn't reset. Add a special keyword definition for the syntax rules? - When this is done, use vim.vim syntax highlighting for help file examples, - but without ":" in 'iskeyword' for syntax. -8 Add specific syntax item to match with parens/braces that don't have a - "%" match. :syntax nomatch cMatchError (,{,[,),},] [contained] -8 Highlight the text between two matching parens (e.g., with a grey - background) when on one of the parens or in between them. - Option for the matchparen plugin? -8 Add a command to jump to the next character highlighted with "Error". -8 When using a cterm, and no ctermfg or ctermbg are defined, use start/stop - sequences. Add remark in docs that :if 'term' == "term-name" should be - used. -8 Add @spell cluster to String and Comment groups for many languages. Will - allow spell checking. (Fleiner) -8 When listing syntax items, try to sort the keywords alphabetically. And - re-insert the [] if possible. -8 Make it possible to use color of text for Visual highlight group (like for - the Cursor). -8 It would be useful to make the highlight group name an expression. Then - when there is a match, the expression would be evaluated to find out what - highlight group to use. Could be used to check if the shell used in a - password file appears in /etc/shells. (Nikolai Weibull) - syn match =s:checkShell(v:match) contained 'pattern' -8 Make it possible to only highlight a sub-expression of a match. Like - using "\1" in a ":s" command. -8 Support for deleting syntax items: - :syn keyword cTodo remove this - :syn match cTodo remove "pattern" - :syn region cString remove start="this" end="that" -8 Add possibility to sync on something else, when the syncing in one way - doesn't find match. For HTML: When no {script} is found, try looking for - a '<'. (Fleiner) -7 Replace the synchronizing method with a state machine specification? - Should be able to start at any line in the file, search forwards or - backwards, and use the result of matching a pattern. -7 Use parsing like awk, so that e.g., a ( without a matching ) can be - detected. -8 Make it possible to use "inverted" highlighting, invert the original - character. For Visual mode. (xterm-selection already does this). -8 Highlight non-printable characters with "SpecialChar", linked to - "Special". Display them with the digraph characters, if possible. -8 Highlight the clipboard-selection with a highlight group. -8 Be able to reset highlighting to its original (default) values. -7 Be able to write current highlighting to a file as commands, similar to - ":mkvimrc". -8 Improve c.vim: - - Add check for unterminated strings, with a variable to switch it on: - "c_strict_ansi". - - Detect unbalanced "#endif". Requires looking back a long way... -8 Add an option to restrict the updating of syntax highlighting to the - current line while in Insert mode. -8 When guessing value of 'background', the syntax file has already been - loaded (from the .gvimrc). After changing 'background', load it again? -8 Add ":syn resync" command, to re-parse the whole file until the current - display position. -8 Should support "me" offset for a region start pattern. To be used to - allow searching for the end pattern inside the match of the end pattern. - Example: syn region pikeXX start="([^{]" end=")" should work on "()". -8 When using a regexp for "contains=", should delay matching with it until - redrawing happens. Set a flag when a group is added, check this flag when - highlighting starts. -8 Some terminals can display colors like the GUI. Add some setting to use - GUI colors for the terminal? With something to define the escape - sequence. -7 It's possible for an item to be transparent, so that the colors of an item - lower on the stack is used. Also do this with highlighting, so that the - user can set transparent highlighting? E.g. a number in a C comment would - get the color of a comment, a number in an assignment Normal. (Nikolai - Weibull) -7 Add "semitrans": Add highlighting. E.g., make the text bold, but keep the - colors. And add colors, so that Green+Red becomes Yellow. - E.g. for this html: - <B> bold text <I> italic+bold text </B> italic text </I> -7 Wild idea: Not only set highlighting, but also change what is displayed - (e.g., remove characters, so that "<B>bold</B>" can be shown as "bold"): - :syn region boldstuff start="<B>" display="" end="</B>" display="" -7 CTRL-] checks the highlight group for finding out what the tag is. -7 Add an explanation how a list of words can be used to highlight misspelled - words. -8 Add more command line completion for :syntax. -8 Add more command line completion for :highlight. -8 Add more command line completion for :sign. -7 Should find a better way to parse the :syntax and :highlight commands. - Use tables or lists that can be shared by parsing for execution and - completion? -8 Add ColorSchemePost autocommand event, so that scripts can set up their - highlighting. (Salman Halim) -7 Add a few sets of colors (e.g. Borland Turbo C one). With a menu to - select one of the sets. -8 Add offsets to sub-matches: "\(a*\) *"he=e1-1 - 'e' is end of match 'e1' is end of sub-match 1, 's2' is start of submatch - 2, etc. -8 In Insert mode, when there are typeahead characters, postpone the - highlighting (for "." command). -8 Syncing on comments isn't 100% correct when / / lines mix with / * and * /. - For example: What about a line that starts with / / and contains * /? -8 Ignore / * and * / inside strings, when syncing. -7 Build a few more syntax files from the file "/usr/share/misc/vgrindefs": - ISP, LDL, Icon, ratfor. And check "nedit/source/highlight.c". -6 Add possibility to have background color continue until the right edge of - the window. Useful for comment blocks and function headings. (Rogall) -- Make it possible to add "contains" items for all items in a group. Useful - when extending an already existing syntax file. -- Add line-continuation pattern for non-syncing items too? -- Add possibility to highlight the whole line, including the right margin - (for comment blocks). -- Add 'hlmatch' option: List of flags: - 'c': highlight match for character under the cursor. - 'b': highlight the previous (, and its match. - 'a': highlight all text from the previous ( until its match. - Also for {}, <>, etc.? - 'e': highlight all braces without a match (slow?) - OR: add an argument "cursor" to the syntax command, which means that the - region/match/keyword is only highlighted when the cursor is on it. - (Campbell) - Or do it like Elvis: define text objects and how to highlight them around - the cursor. (Iain Truskett) -7 Make it possible to use all words in the tags files as Keyword. - Can also be done with a script (but it's slow). -7 Make it possible to call a ":" command when a match is found. Should - allow for adding keywords from the text (e.g. variables that are set). - And allows for sections with different highlighting. -7 Add highlight group for commandline: "Commandline". Make sure it - highlights the command line while typing a command, and any output from - messages. And external commands? -8 Make a version that works like less, but with highlighting: read stdin for - text, exit at end of file, don't allow editing, etc. moreim? lessim? -7 SpecialKey highlighting overrules syntax highlighting. Can't give an - unprintable char another color. Would be useful for ^M at end of line. - - -Built-in script language: -8 Make the filename and line number available to script functions, so that - they can give useful debugging info. The whole call stack would be ideal. -7 Execute a function with standard option values. No need to save and - restore option values. Especially useful for new options. Problem: how - to avoid a performance penalty (esp. for string options)? -8 Add referring to key options with "&t_xx". Both for "echo &t_xx" and - ":let &t_xx =". Useful for making portable mappings. -- Add ":let var ?= value", conditional assignment. Patch by Dave Eggum, - 2006 Dec 11. -- range for ":exec", pass it on to the executed command. (Webb) -7 ":include" command: just like ":source" but doesn't start a new scriptID? - Will be tricky for the list of script names. -8 Have a look at VSEL. Would it be useful to include? (Bigham) -8 Add ":fungroup" command, to group function definitions together. When - encountered, all functions in the group are removed. Suggest using an - obscure name to avoid name clashes. Require a ":fungroup END" in the same - sourced file? Assume the group ends at the end of the file. Handle - nested packages? - Alternative: Support packages. {package-name}:{function-name}(). - Packages are loaded automatically when first used, from - $VIMRUNTIME/packages (or use a search path). -7 Pre-parse or compile Vim scripts into a bytecode. - 1. Put the bytecode with the original script, with an ":if - has('bytecode')" around it, so that it's only used with a Vim that - supports it. Update the code with a command, can be used in an - autocommand. - 2. Use a ".vic" file (like Python use .pyc). Create it when writing a - .vim file. Problem: distribution. - 3. Use a cache directory for each user. How to recognize which cached - file belongs to a sourced script? -7 Add argument to winwidth() to subtract the space taken by 'foldcolumn', - signs and/or 'number'. -6 Add ++ and -- operators? They only work on variables (lvals), how to - implement this? -8 Add functions: - has(":command") Check if ":command" works. compare function - with "ex_ni". E.g. for ":simalt". - system() With a List argument. Bypasses the shell, use - exec() directly. (Bob Hiestand) - escape() Add argument to specify what to escape with. - modestack() Instead of just the current mode return the - stack of Insert / CTRL-O / :normal things. - realname() Get user name (first, last, full) - user_fullname() patch by Nikolai Weibull, Nov - 3 2002 - Only add this when also implemented for - non-Unix systems, otherwise a shell cmd could - be used. - get_user_name() gets login name. - menuprop({name}, {idx}, {what}) - Get menu property of menu {name} item {idx}. - menuprop("", 1, "name") returns "File". - menuprop("File", 1, "n") returns "nmenu - File.Open..." argument. - Patch by Ilya Sher, 2004 Apr 22 - Return a list of menus and/or a dictionary - with properties instead. - mapname({idx}, mode) return the name of the idx'th mapping. - Patch by Ilya Sher, 2004 Mar 4. - Return a list instead. - char2hex() convert char string to hex string. - attributes() return file protection flags "drwxrwxrwx" - filecopy(from, to) Copy a file - shorten(fname) shorten a file name, like home_replace() - perl(cmd) call Perl and return string - inputrl() like input() but right-to-left - typed() return the characters typed and consumed (to - find out what happened) - virtualmode() add argument to obtain whether "$" was used in - Visual block mode. - getacp() Win32: get codepage (Glenn Maynard) - deletebufline() delete line in any buffer - appendbufline() append line in any buffer - libcall() Allow more than one argument. - libcallext() Like libcall(), but using a callback function - to allow the library to execute a command or - evaluate an expression. -7 Make bufname("'0") return the buffer name from mark '0. How to get the - column and line number? col("'0") currently returns zero. -8 argc() returns 0 when using "vim -t tag". How to detect that no file was - specified in any way? To be able to jump to the last edited file. -8 Pass the command line arguments to Vim scripts in some way. As v:args - List? Or extra parameter to argv()? -8 Add command arguments with three dashes, passed on to Vim scripts. -7 Add optional arguments to user functions: - :func myFunc(arg1, arg2, arg3 = "blah", arg4 = 17) -6 User functions: Functions local to buffer "b:func()"? -8 For Strings add ":let var[{expr}] = {expr}". When past the end of "var" - just ignore. -8 The "= register should be writable, if followed by the name of a variable, - option or environment variable. -8 ":let &option" should list the value of the option. -8 ":let Func().foo = value" should work, also when "foo" doesn't exist. -7 Add synIDlist(), making the whole list of syntax items on the syntax stack - available as a List. -8 Add autocommand-event for when a variable is changed: - :au VarChanged {varname} {commands} -8 Add "has("gui_capable")", to check if the GUI can be started. -8 Add possibility to use variables like registers: characterwise (default), - linewise (when ending in '\n'), blockwise (when ending in '\001'). reg0, - rega, reg%, etc. Add functions linewise({expr}), blockwise({expr}) and - charwise({expr}). -7 Make it possible to do any command on a string variable (make a buffer - with one line, containing the string). Maybe add an (invisible) scratch - buffer for this? - result = scratch(string, command) - result = apply(string, command) - result = execute(string, command) - "command" would use <> notation. - Does scratch buffer have a number? Or re-use same number? -7 Add function to generate unique number (date in milliseconds). -7 Automatically load a function from a file when it is called. Need an - option for the search path. (Sekera) - - -Robustness: -6 Add file locking. Lock a file when starting to edit it with flock() or - fcntl(). This patch has advisory file locking while reading/writing - the file for Vim 5.4: ~/vim/patches/kahn_file_locking . - The patch is incomplete (needs support for more systems, autoconf). - Andy doesn't have time to work on it. - Disadvantage: Need to find ways to gracefully handle failure to obtain a - lock. When to release a lock: When buffer is unloaded? - - -Performance: -7 For string variables up to 3 bytes don't allocate memory, use v_list - itself as a character array. Use VAR_SSTRING (short string). -8 move_lines() copies every line into allocated memory, making reloading a - buffer a lot slower than re-editing the file. Can the memline be locked - so that we don't need to make a copy? Or avoid invoking ml_updatechunk(), - that is taking a lot of time. (Ralf Wildenhues, 2008 Jul 7) -8 Instead of loading rgb.txt every time a color wasn't recognized load it - once and keep it in memory. Move the code to a common place to avoid - repeating it in various system files. -8 Turn b_syn_ic and b_syn_containedin into b_syn_flags. -9 Loading menu.vim still takes quite a bit of time. How to make it faster? -8 in_id_list() takes much time for syntax highlighting. Cache the result? -7 setpcmark() shifts the jumplist, this takes quite a bit of time when - jumping around. Instead use an index for the start? -8 When displaying a space with only foreground highlighting, it's the same - as a space without attributes. Avoid displaying spaces for the "~" lines - when starting up in a color terminal. -8 Avoid alloc() for scratch buffer use, esp. in syntax.c. It's very slow on - Win16. -9 Setting GUI options in the console (e.g., 'guifont') should not cause a - redraw. -8 Profiling shows that in_id_list() is used very often for C code. Can this - function be improved? -8 For an existing file, the page size of the swap file is always the - default, instead of using the block size of the device, because the swap - file is created only after setting the block size in mf_open(). How can - this be improved? -8 Set default for 'ttyscroll' to half a screen height? Should speed up - MS-DOS version. (Negri) -7 C syntax highlighting gets a lot slower after ":set foldmethod=syntax". - (Charles Campbell) Inserting a "{" is very slow. (dman) -7 HTML syntax highlighting is slow for long lines. Try displaying - http://www.theregister.co.uk/content/4/22908.html. (Andre Pang) -7 Check how performance of loading the wordlist can be improved (adding a - lot of abbreviations). -7 DOS console: Add t_DL support, to make scrolling faster. -7 Compile Ex commands to byte codes. Store byte codes in a vim script file - at the end, after "compiled:. Make it look like a single comment line - for old Vim versions. Insert first line "Vim script compiled <timestamp>. - Only used compiled code when timestamp matches the file stat. - Add command to compile a vim script and add it to the file in-place. - Split Ex command executing into a parsing and executing phase. - Use compiled code for functions, while loops, etc. -8 When editing a file with extremely long lines (e.g., an executable), the - "linerest" in readfile() is allocated twice to be able to copy what was - read so far. Use realloc() instead? Or split the line when allocating - memory fails and "linerest" is big (> 100000)? -8 When defining autocommands (e.g., from $VIMRUNTIME/filetype.vim), need to - compare each pattern with all existing patterns. Use a hash code to avoid - using strcmp() too often? -7 Include turbo_loader patches, speeding up reading a file? - Speed up reading a file by reading it into a fixed-size buffer, creating - the list of indexes in another buffer, and then copying the result into a - memfile block with two copies. Then read the next block into another - fixed-size buffer, create the second list of indexes and copy text from - the two blocks to the memfile block. -7 do_cmdline(): Avoid that the command line is copied to allocated memory - and freed again later all the time. For while loops, and for when called - with an argument that can be messed with. - Generic solution: Make a struct that contains a pointer and a flag that - indicates if the pointer should be freed when replaced. -7 Check that the file size is not more than "sizeof(long)". -- Further improve finding mappings in maphash[] in vgetorpeek() -8 Syntax highlighting is slow when deleting lines. Try in - $VIMRUNTIME/filetype.vim. -- "out of memory" after deleting (1,$d) and changing (:%s/^/> /) a lot of - lines (27000) a few times. Memory fragmentation? -- Have a look at how pdksh does memory allocation (alloc.c). (Dalecki) -- Do profiling on: - - :g/pat/normal cmd - - 1000ii<Esc> - - deleting 10Mbyte worth of lines (netscape binary) - - "[i" and "[d" (Yegappan Lakshmanan) - - ":g/^/m0" on a 450Kbyte file. And the "u". - - highlighting "~/vim/test/longline.tex", "~/vim/test/scwoop.tcl" and - "~/vim/test/lockup.pl". - - loading a syntax file to highlight all words not from a dictionary. - - editing a Vim script with syntax highlighting on (loading vim.vim). -7 Screen updating can be further improved by only redrawing lines that were - changed (and lines after them, when syntax highlighting was used, and it - changed). - - On each change, remember start and end of the change. - - When inserting/deleting lines, remember begin, end, and line count. -- Use macros/duarte/capicua for profiling. Nvi 1.71 is the fastest! -- When using a file with one long line (1Mbyte), then do "$hhhh", is still - very slow. Avoid calling getvcol() for each "h"? -- Executing a register, e.g. "10000@@" is slow, because ins_typebuf has to - move the previous commands forward each time. Pass count from - normal_cmd() down to do_execreg(). -- Repeating insert "1000i-<Esc>" displays --INSERT-- all the time, because of - the <Esc> at the end. Make this work faster (disable redrawing). -- Avoid calls to plines() for cursor line, use w_cline_height. -- After ":set nowrap" remove superfluous redraw with wrong hor. offset if - cursor is right of the screen. -8 Make CTRL-C on Unix generate a signal, avoid using select() to check for a - CTRL-C (it's slow). - - -Code size: -8 GUI: When NO_CONSOLE is defined, more code can be excluded. -- Put getline() and cookie in a struct, so only one argument has to be - passed to do_cmdline() and other functions. -8 Make a GUI-only version for Unix? -8 In buf_write _() isn't needed when setting errmsg, do it once when using - it. -7 When compiling with a GUI-only version, the code for cterm colors can be - left out. -8 When compiled with a GUI-only version, the termcap entries for terminals - can be removed. -8 Can the check for libelf in configure.in be removed? - - -Messages: -8 When using ":q" in a changed file, the error says to "add !". Add the - command so that beginners understand it: "use :q!". -8 For 'verbose' level 12 prints commands from source'ed files. How to skip - lines that aren't executed? Perhaps move the echoing to do_cmdline()? -8 Use 'report' for ":bdel"? (Krishna) To avoid these messages when using a - script. -- Delete message after new command has been entered and have waited for key. - Perhaps after ten seconds? -- Make message history available in "msg" variables: msg1, msg2, .. msg9. -8 When reading from stdin allow suppressing the "reading from stdin" - message. -9 Check handling of overwriting of messages and delays: - Very wrong: errors while redrawing cause endless loop. - When switching to another file and screen scrolls because of the long - message and return must be typed, don't scroll the screen back before - redrawing. -8 When address range is wrong you only get "Invalid range". Be a bit more - specific: Negative, beyond last line, reverse range? Include the text. -8 Make it possible to ignore errors for a moment ('errorignore'?). Another - option to switch off giving error messages ('errorquiet'?). Also an option - not to give any messages ('quiet')? Or ":quiet on", ":quiet off". - Careful: For a severe error (out of memory), and when the user starts - typing, error messages must be switched back on. - Also a flag to ignore error messages for shell commands (for mappings). -- Option to set time for emsg() sleep. Interrupt sleep when key is typed? - Sleep before second message? -8 In Ex silent mode or when reading commands from a file, what exactly is - not printed and what is? Check ":print", ":set all", ":args", ":vers", - etc. At least there should be no prompt. (Smulders) And don't clear the - screen when reading commands from stdin. (Kendall) - --> Make a difference between informative messages, prompts, etc. and - error messages, printing text, etc. -8 Window should be redrawn when resizing at the hit-enter prompt. - Also at the ":tselect" prompt. Find a generic solution for redrawing when - a prompt is present (with a callback function?). - - -Screen updating: -7 Add a string to the 'display' option to make CTRL-E and CTRL-Y scroll one - screen line, also if this means the first line doesn't start with the - first character (like what happens with a single line that doesn't fit). -- screen_line(): - - insert/delete character stuff. - - improve delete rest of line (spaces at end of line). -- When moving or resizing window, try to avoid a complete redraw (esp. when - dragging the status line with the mouse). -- When 'lazyredraw' set, don't echo :ex commands? Need a flag to redraw when - waiting for a character. -8 Add a ":refresh [winnr]" command, to force updating a window. Useful from - an event handler where ":normal" can't be used. Also useful when - 'lazyredraw' is set in a mapping. -7 Make 'list' and 'linebreak' work together. - - -Scrolling: -8 Add "zm" command: scroll horizontally to put the cursor in the middle. -6 Add option to set the overlap for CTRL-F and CTRL-B. (Garhi) -- extend 'scrollbind' option: 'scrollopt' words "search", "relative", etc.. - Also 'e'xecute some commands (search, vertical movements) in all bound - windows. -7 Add 'scrollbind' feature to make the offset of one window with the next - one equal to the window height. When editing one file in both windows it - looks like each window displays a page of the buffer. -- Allow scrolling by dragging with the mouse (grab a character and move it - up/down). Like the "hand" in Acrobat reader. Use Alt-LeftMouse for this? - (Goldfarb) -- Add command to execute some commands (search, vertical movements) in all - bound windows. -- Add 'search' option to 'scrollopt' to allow 'scrollbind' windows to - be bound by regexp searches -- Add "z>" and "z<": scroll sideways one screenful. (Campbell) -- Add option to set the number of lines when not to scroll, instead of the - fixed number used now (for terminals that scroll slow with a large number - of lines but not with a single line). - - -Autoconf: -8 Should use acconfig.h to define prototypes that are used by autoheader. -8 Some compilers don't give an error for "-OPT:Olimit" but a warning. (Webb) - Add a check for the warning, so that "Olimit" can be added automatically? -- Autoconf: Use @datadir@ for the system independent files. Make sure the - system dependent and system independent files are separated. (Leitner). -- Add autoconf check for waitpid()/wait4(). -- Remove fcntl() from autoconf, all systems have it? -- Set default for 'dictionary', add search for dictionary to autoconf. - - -Perl interface: -8 Rename typemap file to something else? -7 Make buffers accessed as Perl arrays. (Clark) -7 Make it possible to compile with non-ANSI C? -6 Tcl/Tk has the "load" command: load a shared library (.so or .dll). - - -Shared libraries: -6 Add support for loading shared libraries, and calling functions in it. - :libload internal-name libname - :libunload internal-name - :liblist - :libcall internal-name function(arg1, arg2, ...) - :libcall function(arg1, arg2, ...) - libcall() can have only one integer or String argument at the moment. -6 Have a look on how Perl handles loading dynamic libraries. - - -Tags: -9 With ":set tags=./tags,../tags" and a tag appears in both tags files it is - added twice. Requires figuring out the actual file name for each found - match. Remove tag_fname from the match and combine it with the fname in - the match (without expanding or other things that take time). When - 'tagrelative' is off tag_fname isn't needed at all. -8 For 'tags' wildcard in the file name is not supported, only in the path. - This is due to it using |file-searching|. Suboptimal solution would be to - make the filename or the whole option use |wildcards| globing, better - would be to merge the 2 kinds of globing. originall (Erik Falor, 2008 - April 18), updated (Ian Kelling, 2008 July 4) -8 Use a mechanism similar to omni completion to figure out the kind of tab - for CTRL-] and jump to the appropriate matching tag (if there are - several). -7 Can CTRL-] (jump to tag) include a following "." and "->" to restrict the - number of possible matches? Check tags file for an item that has members. - (Flemming Madsen) -8 Scope arguments for ":tag", e.g.: ":tag class:cPage open", like Elvis. -8 When output of ":tselect" is long, getting the more-prompt, should be able - to type the tag number directly. -7 Add the possibility to use the "-t {tag}" argument multiple times. Open a - window for each tag. -7 Make output of ":tselect" a bit nicer. Use highlighting? -7 Highlight the "tag 1 of >2" message. New highlight group, or same as "hit - bottom" search message. -7 When using ":tag" at the top of the tag stack, should add another entry, - so CTRL-T can bring you back to where you are now AND to where you were - before the previous ":tag" command. (Webb) -- When doing "[^I" or "[^D" add position to tag stack. -- Add command to put current position to tag stack: ":tpush". -- Add functions to save and restore the tag stack? Or a command to switch - to another tag stack? So that you can do something else and come back to - what you were working on. -7 When using CTRL-] on someClass::someMethod, separate class from method and - use ":ta class:someClass someMethod". - Include C++ tags changes (Bertin). Change "class::func" tag into "func" - with "class=class"? Docs in oldmail/bertin/in.xxx. -7 Add ":tagargs", to set values for fields: - :tagargs class:someclass file:version.c - :tagargs clear - These are then the default values (changes the order of priority in tag - matching). -7 Support for "gtags" and "global"? With ":rtag" command? - There is an example for how to do this in Nvi. - Or do it like Elvis: 'tagprg' and 'tagprgonce' options. (Yamaguchi) - The Elvis method is far more flexible, do it that way. -7 Support "col:99" extra field, to position the cursor in that column. With - a flag in 'cpoptions' to switch it off again. -7 Better support for jumping to where a function or variable is used. Use - the id-utils, with a connection to "gid" (Emacs can do it too). Add - ":idselect", which uses an "ID" database (made by "mkid") like "tselect". - - -Win32 GUI: -8 Make debug mode work while starting up (vim -D). Open console window for - the message and input? -7 The Python interface only works with one version of Python, selected at - compile time. Can this be made to work with version 2.1 and 2.2 - dynamically? -7 GvimExt: when there are several existing Vims, move the list to a submenu. - (Mike McCollister) -8 When using "Edit with Vim" for one file it changes directory, when several - files are selected and using "Edit with single Vim" the directory isn't - changed. At least change directory when the path is the same for all - files. Perhaps just use the path of the first file or use the longest - common part of the path. -8 Add font argument to set the lfCharSet. (Bobcik) -8 Somehow automatically detect the system language and set $LANG, so that - gettext and menus work. -8 Could keep console open to run multiple commands, to avoid the need to hit - return in every console. - Also: Look at how Emacs does runs external commands: - http://www.cs.washington.edu/homes/voelker/ntemacs.html. -8 Need a separate PopUp menu for modeless selection. Need two new commands: - Copy selection to clipboard, Paste selection (as typed text). -8 Support copy/paste for other file formats. At least HTML, perhaps RTF. - Add "copy special" and "paste special" commands? -7 Use different default colors, to match the current Windows color scheme. - Sys_WindowText, Sys_Window, etc. (Lionel Schaffhauser) -7 Use <C-Tab> to cycle through open windows (e.g., the find dialog). -7 <Esc> should close a dialog. -7 Keep the console for external commands open. Don't wait for a key to be - hit. Re-open it when the user has closed it anyway. Or use a prepended - command: ":nowait {cmd}", or ":quiet", which executes {cmd} without any - prompts. -7 Should be able to set an option so that when you double click a file that - is associated with Vim, you can either get a new instance of Vim, or have - the file added into an already running Vim. -7 The "-P" argument only works for the current codepage. Use wide - functions to find the window title. - - -GUI: -8 Make inputdialog() work for Photon, Amiga, RiscOS. -- <C--> cannot be mapped. Should be possible to recognize this as a - normal "-" with the Ctrl modifier. -7 Implement ":popup" for other systems than Windows. -8 Implement ":tearoff" for other systems than Win32 GUI. -6 Implement ":untearoff": hide a torn-off menu. -8 When using the scrollbar to scroll, don't move the cursor position. When - moving the cursor: scroll to the cursor position. -9 Make <S-Insert> paste from the clipboard by default. (Kunze) -7 Menu local to a buffer, like mappings. Or local to a filetype? -8 In Buffers menu, add a choice whether selecting a buffer opens it in the - current window, splits the window or uses ":hide". -8 Dragging the mouse pointer outside of a Vim Window should make the text - scroll. Return a value from gui_send_mouse_event() to the machine - specific code to indicate the time in which the event should be repeated. -8 Make it possible to ignore a mouse click when it's used to give Vim (gvim) - window focus. Also when a mouse click is used to bring a window to front. -8 Make the split into system independent code and system specific code more - explicit. There are too many #ifdefs in gui.c. - If possible, separate the Vim code completely from the GUI code, to allow - running them in separate processes. -7 X11: Support cursorColor resource and "-cr" argument. -8 X11 (and others): CTRL-; is not different from ';'. Set the modifier mask - to include CTRL for keys where CTRL produces the same ASCII code. -7 Add some code to handle proportional fonts on more systems? Need to draw - each character separately (like xterm). Also for when a double-width font - is not exactly double-width. (Maeda) -8 Should take font from xterm where gvim was started (if no other default). -8 Selecting font names in X11 is difficult, make a script or something to - select one. -8 Visual highlighting should keep the same font (bold, italic, etc.). -8 Add flag to 'guioptions' to not put anything in the clipboard at all? -8 Should support a way to use keys that we don't recognize yet. Add a - command that adds entries to special_keys somehow. How do we make this - portable (X11, Win32, ..)? -7 Add a flag to 'guioptions' that tells not to remove inactive menu items. - For systems where greying-out or removing menu items is very slow. The - menu items would remain visibly normally, but not do anything. -7 Add ":minimize" and ":maximize", which iconize the window and back. - Useful when using gvim to run a script (e.g. 2html.vim). -7 X11: Is it possible to free allocated colors, so that other programs can - use them again? Otherwise, allow disabling allocating the default colors. - Or allocate an own colormap (check UAE). With an option to use it. For - the commandline, "-install" is mostly used for X11 programs. -7 Add command line argument for "gvim" not to start the GUI. Sort of the - inverse of "vim -g". (Vikas) -7 Should support multi-column menus. -- Should add option for where to put the "Help" menu: like Motif at the far - right, or with the other menus (but still at the right). -- Add menu item to "Keep Insert mode". -8 ":mkgvimrc" command, that includes menus. -6 Big change: Move GUI to separate program "vimgui", to make startup of vim a - lot faster, but still be able to do "vim -g" or ":gui". -7 More explicit mouse button binding instead of 'mousemodel'? -7 Add option to set the position of the window on the screen. 'windowpos', - which has a value of "123,456": <x>,<y>. - Or add a command, like ":winsize"? -7 Add toolbar for more GUIs. -8 Make it possible to use "amenu icon=BuiltIn##", so that the toolbar item - name can be chosen free. -7 Make it possible to put the toolbar on top, left, right and/or bottom of - the window? Allows for softkey-like use. -6 Separate the part of Vim that does the editing from the part that runs the - GUI. Communicate through a pseudo-tty. Vim starts up, creates a - pty that is connected to the terminal. When the GUI starts, the pty is - reconnected to the GUI process. When the GUI stops, it is connected to - the terminal again. Also use the pty for external processes, it looks - like a vt100 terminal to them. Vim uses extra commands to communicate GUI - things. -7 Motif: For a confirm() dialog <Enter> should be ignored when no default - button selected, <Esc> should close the dialog. -7 When using a pseudo-tty Vim should behave like some terminal (vt52 looks - simple enough). Terminal codes to/from shell should be translated. -- Would it be useful to be able to quit the GUI and go back to the terminal - where it was started from? -7 Support "-visual <type>" command line argument. - - -Autocommands: -- Put autocommand event names in a hashtable for faster lookup? -7 For autocommand events that trigger multiple times per buffer (e.g., - CursorHold), go through the list once and cache the result for a specific - buffer. Invalidate the cache when adding/deleting autocommands or - changing the buffer name. -8 Add ScriptReadCmd event: used to load remote Vim scripts, e.g. - "vim -u http://mach/path/vimrc". -7 Add TagJump event: do something after jumping to a tag. -8 Add "TagJumpFile" autocommand: When jumping to another file for a tag. - Can be used to open "main.c.gz" when "main.c" isn't found. -8 Use another option than 'updatetime' for the CursorHold event. The two - things are unrelated for the user (but the implementation is more - difficult). -8 Add an event like CursorHold that is triggered repeatedly, not just once - after typing something. -7 Add autocommand event for when a buffer cannot be abandoned. So that the - user can define the action taking (autowrite, dialog, fail) based on the - kind of file. (Yakov Lerner) Or is BufLeave sufficient? -8 Autocommand for when modified files have been found, when getting input - focus again (e.g., FileChangedFocus). - Check when: getting focus, jumping to another buffer, ... -7 Autocommand for when an option is changed. Match buffer name or option - name? -8 Autocommands should not change registers. And marks? And the jumplist? - And anything else? Add a command to save and restore these things. -8 Add autocommands, user functions and user commands to ":mkvimrc". -6 Add KeymapChanged event, so that the effects of a different keymap can be - handled (e.g., other font) (Ron Aaron) -7 When trying to open a directory, trigger an OpenDirectory event. -7 Add file type in front of file pattern: <d> for directory, <l> for link, - <x> for executable, etc. <&xxx> for Risc OS. With commas to separate - alternatives. The autocommand is only executed when both the file type - AND the file pattern match. (Leonard) -5 Add option that specifies extensions which are to be discarded from the - file name. E.g. 'ausuffix', with ".gz,.orig". Such that file.c.gz will - trigger the "*.c" autocommands. (Belabas) -7 Add something to break the autocommands for the current event, and for - what follows. Useful for a "BufWritePre" that wants to avoid writing the - file. -8 When editing "tt.gz", which is in DOS format, 'fileformat' stays at - "unix", thus writing the file changes it. Somehow detect that the read - command used dos fileformat. Same for 'fileencoding'. -- Add events to autocommands: - Error - When an error happens - NormalEnter - Entering Normal mode - ReplaceEnter - Entering Replace mode - CmdEnter - Entering Cmdline mode (with type of cmdline to allow - different mapping) - VisualEnter - Entering Visual mode - *Leave - Leaving a mode (in pair with the above *Enter) - VimLeaveCheck - Before Vim decides to exit, so that it can be cancelled - when exiting isn't a good idea. - CursorHoldC - CursorHold while command-line editing - WinMoved - when windows have been moved around, e.g, ":wincmd J" - CmdUndefined - Like FuncUndefined but for user commands. - SearchPost - After doing a search command (e.g. to do "M") - PreDirChanged/PostDirChanged - - Before/after ":cd" has been used (for changing the - window title) - BufReadAction - replaces reading a file - BufWriteAction - replaces writing a file - ShutDown - when the system is about to shut down - InsertCharPre - user typed character Insert mode, before inserting the - char. Pattern is matched with text before the cursor. - Set v:char to the character, can be changed. - (not triggered when 'paste' is set). - InsertCharPost - user typed a character in Insert mode, after inserting - the char. - BufModified - When a buffer becomes modified, or unmodified (for - putting a [+] in the window title or checking out the - file from CVS). - BufFirstChange - When making a change, when 'modified' is set. Can be - used to do a :preserve for remote files. - BufChange - after a change was made. Set some variables to indicate - the position and number of inserted/deleted lines, so - that marks can be updated. HierAssist has patch to add - BufChangePre, BufChangePost and RevertBuf. (Shah) - ViewChanged - triggered when the text scrolls and when the window size - changes. - WinResized - After a window has been resized - WinClose - Just before closing a window -- Write the file now and then ('autosave'): - *'autosave'* *'as'* *'noautosave'* *'noas'* - 'autosave' 'aw' number (default 0) - Automatically write the current buffer to file N seconds after the - last change has been made and when |'modified'| is still set. - Default: 0 = do not autosave the buffer. - Alternative: have 'autosave' use 'updatetime' and 'updatecount' but make - them save the file itself besides the swapfile. - - -Omni completion: -- Add a flag to 'complete' to be able to do omni completion with CTRL-N (and - mix it with other kinds of completion). -- Ideas from the Vim 7 BOF at SANE: - - For interpreted languages, use the interpreter to obtain information. - Should work for Java (Eclipse does this), Python, Tcl, etc. - Richard Emberson mentioned working on an interface to Java. - - Check Readline for its completion interface. -- Ideas from others: - http://www.wholetomato.com/ - http://www.vim.org/scripts/script.php?script_id=747 - http://sourceforge.net/projects/insenvim - or http://insenvim.sourceforge.net - Java, XML, HTML, C++, JSP, SQL, C# - MS-Windows only, lots of dependencies (e.g. Perl, Internet - explorer), uses .dll shared libraries. - For C++ uses $INCLUDE environment var. - Uses Perl for C++. - Uses ctags to find the info: - ctags -f $allTagsFile --fields=+aiKmnsSz --language-force=C++ --C++-kinds=+cefgmnpsut-dlux -u $files - www.vim.org script 1213 (Java Development Environment) (Fuchuan Wang) - IComplete: http://www.vim.org/scripts/script.php?script_id=1265 - and http://stud4.tuwien.ac.at/~e0125672/icomplete/ - http://cedet.sourceforge.net/intellisense.shtml (for Emacs) - Ivan Villanueva has something for Java. - Emads: http://www.xref-tech.com/xrefactory/more_c_completion.html - Completion in .NET framework SharpDevelop: http://www.icsharpcode.net -- Pre-expand abbreviations, show which abbrevs would match? - - -Insert mode completion/expansion: -- GUI implementation of the popup menu. -7 When searching in other files the name flash by, too fast to read. Only - display a name every second or so, like with ":vimgrep". -7 When expanding file names with an environment variable, add the match with - the unexpanded var. So $HOME/tm expands to "/home/guy/tmp" and - "$HOME/tmp" -8 When there is no word before the cursor but something like "sys." complete - with "sys.". Works well for C and similar languages. -9 ^X^L completion doesn't repeat correctly. It uses the first match with - the last added line, instead of continuing where the last match ended. - (Webb) -8 Add option to set different behavior for Insert mode completion: - - ignore/match case - - different characters than 'iskeyword' -8 Add option 'isexpand', containing characters when doing expansion (so that - "." and "\" can be included, without changing 'iskeyword'). (Goldfarb) - Also: 'istagword': characters used for CTRL-]. - When 'isexpand' or 'istagword' are empty, use 'iskeyword'. - Alternative: Use a pattern so that start and end of a keyword can be - defined, only allow dash in the middle, etc. -8 Add a command to undo the completion, go back to the original text. -7 Completion of an abbreviation: Can leave letters out, like what Instant - text does: www.textware.com -8 Use the class information in the tags file to do context-sensitive - completion. After "foo." complete all member functions/variables of - "foo". Need to search backwards for the class definition of foo. - Should work for C++ and Java. - Even more context would be nice: "import java.^N" -> "io", "lang", etc. -7 When expanding $HOME/dir with ^X^F keep the $HOME (with an option?). -7 Add CTRL-X command in Insert mode like CTRL-X CTRL-N, that completes WORDS - instead of words. -8 Add CTRL-X CTRL-R: complete words from register contents. -8 Add completion of previously inserted texts (like what CTRL-A does). - Requires remembering a number of insertions. -8 Add 'f' flag to 'complete': Expand file names. - Also apply 'complete' to whole line completion. -- Add a flag to 'complete' to only scan local header files, not system - header files. (Andri Moell) -- Make it possible to search include files in several places. Use the - 'path' option? Can this be done with the dictionary completion (use - wildcards in the file name)? -- Make CTRL-X CTRL-K do a binary search in the dictionary (if it's sorted). -- Speed up CTRL-X CTRL-K dictionary searching (don't use a regexp?). -- Set a mark at the position where the match was found (file mark, could - be in another file). -- Add CTRL-A command in CTRL-X mode: show all matches. -- Make CTRL-X CTRL-L use the 'complete' option? -- Add command in CTRL-X mode to add following words to the completed string - (e.g. to complete "Pointer->element" with CTRL-X CTRL-P CTRL-W CTRL-W) -- CTRL-X CTRL-F: Use 'path' to find completions. -- CTRL-X CTRL-F: Option to use forward slashes on MS-Windows? -- CTRL-X CTRL-F: Don't replace "$VIM" with the actual value. (Kelly) -- Allow listing all matches in some way (and picking one from the list). - - -Command line editing: -7 Add commands (keys) to delete from the cursor to the end of the command - line. -8 Custom completion of user commands can't use the standard completion - functions. Add a hook to invoke a user function that returns the type of - completion to be done: "file", "tag", "custom", etc. -- Add flags to 'whichwrap' for command line editing (cursor right at end of - lines wraps to start of line). -- Make editing the command line work like Insert mode in a single-line view - on a buffer that contains the command line history. But this has many - disadvantages, only implement it when these can be solved. Elvis has run - into these, see remarks from Steve (~/Mail/oldmail/kirkendall/in.00012). - - Going back in history and editing a line there would change the history. - Would still need to keep a copy of the history elsewhere. Like the - cmdwin does now already. - - Use CTRL-O to execute one Normal mode command. How to switch to normal - mode for more commands? <Esc> should cancel the command line. CTRL-T? - - To allow "/" and "= need to recursively call getcmdline(), overwrite the - cmdline. But then we are editing a command-line again. How to avoid - that the user gets confused by the stack of command lines? - - Use edit() for normal cmdline editing? Would have to integrate - getcmdline() into edit(). Need to solve conflicts between Insert mode - and Command-line mode commands. Make it work like Korn shell and tcsh. - Problems: - - Insert: completion with 'wildchar' - - Insert: use cmdline abbreviations - - Insert: CTRL-D deletes indent instead of listing matches - - Normal: no CTRL-W commands - - Normal: no ":" commands? - - Normal: allow Visual mode only within one line. - - where to show insert/normal mode message? Change highlighting of - character in first column? - - Implementation ideas: - - Set "curwin" and "curbuf" to the command line window and buffer. - - curwin->w_topline is always equal to curwin->w_cursor.lnum. - - never set 'number', no folding, etc. No status line. - - sync undo after entering a command line? - - use NV_NOCL flag for commands that are not allowed in Command-line - Mode. - - -Command line completion: -8 Completing ":r ~br" should find matching user names. -8 Change expand_interactively into a flag that is passed as an argument. -8 With command line completion after '%' and '#', expand current/alternate - file name, so it can be edited. Also with modifiers, such as "%:h". -8 When completing command names, either sort them on the long name, or list - them with the optional part inside []. -8 Add an option to ignore case when doing interactive completion. So that - ":e file<Tab>" also lists "Filelist" (sorted after matching case matches). -7 Completion of ":map x ": fill in the current mapping, so that it can be - edited. (Sven Guckes) -- For 'wildmenu': Simplify "../bar" when possible. -- When using <Up> in wildmenu mode for a submenu, should go back to the - current menu, not the first one. E.g., ":emenu File.Save<Up>". -8 For ":find" and ":sfind" expand files found in 'path'. -8 When using backtick expansion, the external command may write a greeting - message. Add an option or commands to remove lines that match a regexp? -7 When listing matches of files, display the common path separately from the - file names, if this makes the listing shorter. (Webb) -- Add command line completion for ":ilist" and friends, show matching - identifiers (Webb). -8 Add command line completion for "old value" of a command. ":args <key>" - would result in the current list of arguments, which you can then edit. -7 Add command line completion with CTRL-X, just like Insert mode completion. - Useful for ":s/word/xx/". -- Add command to go back to the text as it was before completion started. - Also to be used for <Up> in the command line. -- Add 'wildlongest' option: Key to use to find longest common match for - command line completion (default CTRL-L), like 'wildchar'. (Cregut) - Also: when there are several matches, show them line a CTRL-D. - - -Command line history: -9 Remember which command lines were actually typed and were not loaded from - viminfo. When writing viminfo append only these lines, so that lines from - other Vim's are not overwritten. -- Add "KeyWasTyped" flag: It's reset before each command and set when a - character from the keyboard is consumed. Value is used to decide to put a - command line in history or not. Put line in history if it didn't - completely resulted from one mapping. -- When using ":browse", also put the resulting edit command in the history, - so that it can be repeated. (Demirel) - - -Insert mode: -9 When 'autoindent' is set, hitting <CR> twice, while there is text after - the cursor, doesn't delete the autoindent in the resulting blank line. - (Rich Wales) This is Vi compatible, but it looks like a bug. -8 When using CTRL-O in Insert mode, then executing an insert command - "a" or "i", should we return to Insert mode after <Esc>? (Eggink) - Perhaps it can be allowed a single time, to be able to do - "<C-O>10axyz<Esc>". Nesting this further is confusing. - ":map <F2> 5aabc<Esc>" works only once from Insert mode. -8 When using CTRL-G CTRL-O do like CTRL-\ CTRL-O, but when returning with - the cursor in the same position and the text didn't change continue the - same change, so that "." repeats the whole insert. -7 Use CTRL-G <count> to repeat what follows. Useful for inserting a - character multiple times or repeating CTRL-Y. -- Make 'revins' work in Replace mode. -7 Use 'matchpairs' for 'showmatch': When inserting a character check if it - appears in the rhs of 'matchpairs'. -- In Insert mode (and command line editing?): Allow undo of the last typed - character. This is useful for CTRL-U, CTRL-W, delete and backspace, and - also for characters that wrap to the next line. - Also: be able to undo CTRL-R (insert register). - Possibly use 'backspace'="whole" for a mode where at least a <CR> that - inserts autoindent is undone by a single <BS>. -- Use CTRL-G in Insert mode for an extra range of commands, like "g" in - Normal mode. -- Make 'paste' work without resetting other options, but override their - value. Avoids problems when changing files and modelines or autocommands - are used. -- When typing CTRL-V and a digit higher than 2, only expect two digits. -- Insert binary numbers with CTRL-V b. -- Make it possible to undo <BS>, <C-W> and <C-U>. Bash uses CTRL-Y. - - -'cindent', 'smartindent': -9 ") :" confuses continuation line: (Colin Bennett, 2007 Dec 14) - cout << "a" - << ") :" - << "y"; -8 Lisp indenting: "\\" confuses the indenter. (Dorai Sitaram, 2006 May 17) -8 Why are continuation lines outside of a {} block not indented? E.g.: - long_type foo = - value; -8 Java: Inside an anonymous class, after an "else" or "try" the indent is - too small. (Vincent Bergbauer) - Problem of using {} inside (), 'cindent' doesn't work then. -8 In C++ it's possible to have {} inside (): (Kirshna) - func( - new String[] { - "asdf", - "asdf" - } - ); -6 Add 'cino' flag for this function argument layout: (Spencer Collyer) - func( arg1 - , arg2 - , arg3 - ); -7 Add separate "(0" option into inside/outside a function (Zellner): - func( - int x) // indent like "(4" - { - if (a - && b) // indent like "(0" -9 Using "{" in a comment: (Helmut Stiegler) - if (a) - { - if (b) - { - // { - } - } <-- this is indented incorrect - Problem is that find_start_brace() checks for the matching brace to be in - a comment, but not braces in between. Requires adding a comment check to - findmatchlimit(). -- Make smartindenting configurable. Add 'sioptions', e.g. '#' setting the - indent to 0 should be switched on/off. -7 Support ANSI style function header, with each argument on its own line. -- "[p" and "]p" should use 'cindent' code if it's on (only for the first - line). -- Add option to 'cindent' to set indent for comments outside of {}? -- Make a command to line up a comment after a code line with a previous - comment after a code line. Can 'cindent' do this automatically? -7 Add 'j' flag to 'formatoptions': Remove comment leader when joining lines. -- When 'cindent'ing a '}', showmatch is done before fixing the indent. It - looks better when the indent is fixed before the showmatch. (Webb) -- Add option to make indenting work in comments too (for commented-out - code), unless the line starts with "*". -- Don't use 'cindent' when doing formatting with "gq"? -- When formatting a comment after some text, insert the '*' for the new line - (indent is correct if 'cindent' is set, but '*' doesn't get inserted). -8 When 'comments' has both "s1:/*,mb:*,ex:*/" and "s1:(*,mb:*,ex:*)", the - 'x' flag always uses the first match. Need to continue looking for more - matches of "*" and remember all characters that could end the comment. -- For smartindent: When typing 'else' line it up with matching 'if'. -- 'smartindent': allow patterns in 'cinwords', for e.g. TeX files, where - lines start with "\item". -- Support this style of comments (with an option): (Brown) - /* here is a comment that - is just autoindented, and - nothing else */ -- Add words to 'cinwords' to reduce the indent, e.g., "end" or "fi". -7 Use Tabs for the indent of starting lines, pad with spaces for - continuation lines. Allows changing 'tabstop' without messing up the - indents. - 'keeptabs': when set don't change the tabs and spaces used for indent, - when the indent remains the same or increases. - - -Java: -8 Can have {} constructs inside parens. Include changes from Steve - Odendahl? -8 Recognize "import java.util.Vector" and use $CLASSPATH to find files for - "[i" commands and friends. -- For files found with 'include': handle "*" in included name, for Java. - (Jason) -- How to make a "package java.util" cause all classes in the package to be - searched? Also for "import java.util.*". (Mark Brophy) - - -'comments': -8 When formatting C comments that are after code, the "*" isn't repeated - like it's done when there is no code. And there is no automatic wrapping. - Recognize comments that come after code. Should insert the comment leader - when it's "#" or "//". - Other way around: when a C command starts with "* 4" the "*" is repeated - while it should not. Use syntax HL comment recognition? -7 When using "comments=fg:--", Vim inserts three spaces for a new line. - When hitting a TAB, these spaces could be removed. -7 The 'n'esting flag doesn't do the indenting of the last (rightmost) item. -6 Make strings in 'comments' option a RE, to be able to match more - complicated things. (Phillipps) Use a special flag to indicate that a - regexp is used. -8 Make the 'comments' option with "/* * */" lines only repeat the "*" line - when there is a "/*" before it? Or include this in 'cindent'? - - -Virtual edit: -8 Make the horizontal scrollbar work to move the text further left. -7 Add a mode where the cursor is only allowed to go one character after the - end of the line? -7 Allow specifying it separately for Tabs and beyond end-of-line? - - -Text objects: -8 Add text object for fold, so that it can be yanked when it's open. -8 Add test script for text object commands "aw", "iW", etc. -8 Add text object for part of a CamelHumpedWord and under_scored_word. - (Scott Graham) "ac" and "au"? -8 Add a text object for any kind of quoting, also with multi-byte - characters. Option to specify what quotes are recognized (default: all) - use "aq" and "iq". Use 'quotepairs' to define pairs of quotes, like - 'matchpairs'? -8 Add text object for any kind of parens, also multi-byte ones. -7 Add text object for current search pattern: "a/" and "i/". Makes it - possible to turn text highlighted for 'hlsearch' into a Visual area. -8 Add a way to make an ":omap" for a user-defined text object. Requires - changing the starting position in oap->start. -8 Add "gp" and "gP" commands: insert text and make sure there is a single - space before it, unless at the start of the line, and after it, unless at - the end of the line or before a ".". -7 Add objects with backwards extension? Use "I" and "A". Thus "2dAs" - deletes the current and previous sentence. (Jens Paulus) -7 Add "g{" and "g}" to move to the first/last character of a paragraph - (instead of the line just before/after a paragraph as with "{" and "}"). -6 Ignore comment leaders for objects. Make "das" work in reply-email. -5 Make it possible to use syntax group matches as a text object. For - example, define a "ccItem" group, then do "da<ccItem>" to delete one. - Or, maybe just define "dai", delete-an-item, to delete the syntax item the - cursor is on. - - -Select mode: -8 In blockwise mode, typed characters are inserted in front of the block, - backspace deletes a column before the block. (Steve Hall) -7 Alt-leftmouse starts block mode selection in MS Word. - See http://www.vim.org/tips/tip.php?tip_id=743 -7 Add Cmdline-select mode. Like Select mode, but used on the command line. - - Change gui_send_mouse_event() to pass on mouse events when 'mouse' - contains 'C' or 'A'. - - Catch mouse events in ex_getln.c. Also shift-cursor, etc., like in - normal_cmd(). - - remember start and end of selection in cmdline_info. - - Typing text replaces the selection. - - -Visual mode: -- When dragging the Visual selection with the mouse and 'scrolloff' is zero, - behave like 'scrolloff' is one, so that the text scrolls when the pointer - is in the top line. -- Displaying size of Visual area: use 24-33 column display. - When selecting multiple lines, up to about a screenful, also count the - characters. -8 When using "I" or "A" in Visual block mode, short lines do not get the new - text. Make it possible to add the text to short lines too, with padding - where needed. -7 With a Visual block selected, "2x" deletes a block of double the width, - "3y" yanks a block of triple width, etc. -7 When selecting linewise, using "itext" should insert "text" at the start - of each selected line. -8 What is "R" supposed to do in Visual mode? -8 Make Visual mode local to the buffer. Allow changing to another buffer. - When starting a new Visual selection, remove the Visual selection in any - other buffer. (Ron Aaron) -8 Support dragging the Visual area to drop it somewhere else. (Ron Aaron, - Ben Godfrey) -7 Support dragging the Visual area to drop it in another program, and - receive dropped text from another program. (Ben Godfrey) -7 With blockwise Visual mode and "c", "C", "I", "A", etc., allow the use of - a <CR>. The entered lines are repeated over the Visual area. -7 CTRL-V :s should substitute only in the block, not to whole lines. (David - Young is working on this) -7 Filtering a block should only apply to the block, not to the whole lines. - When the number of lines is increased, add lines. When decreased, pad with - spaces or delete? Use ":`<,`>" on the command line. -8 After filtering the Visual area, make "gv" select the filtered text? - Currently "gv" only selects a single line, not useful. -7 Don't move the cursor when scrolling? Needed when the selection should - stay the same. Scroll to the cursor at any movement command. With an - option! -7 In Visual block mode, need to be able to define a corner on a position - that doesn't have text? Also: when using the mouse, be able to select - part of a TAB. Even more: Add a mode where the cursor can be on a screen - position where there is no text. When typing, add spaces to fill the gap. - Other solution: Always use curswant, so that you can move the cursor to - the right column, and then use up/down movements to select the line, - without changing the column. -6 ":left" and ":right" should work in Visual block mode. -7 CTRL-I and CTRL-O should work in Visual mode, but only jump to marks in the - current buffer. -7 CTRL-A and CTRL-X should increase/decrease all numbers in the Visual area. -6 In non-Block mode, "I" should insert the same text in front of each line, - before the first non-blank, "gI" in column 1. -6 In non-Block mode, "A" should append the same text after each line. -6 When in blockwise visual selection (CTRL-V), allow cursor to be placed - right of the line. Could also allow cursor to be placed anywhere on a TAB - or other special character. -6 Add commands to move selected text, without deselecting. - - -More advanced repeating commands: -- Add "." command for visual mode: redo last visual command (e.g. ":fmt"). -7 Repeating "d:{cmd}" with "." doesn't work. (Benji Fisher) Somehow remember - the command line so that it can be repeated? -- Add "gn": repeat last movement command. Including count. -- Add "." command after operator: repeat last command of same operator. E.g. - "c." will repeat last change, also when "x" used since then (Webb). - "y." will repeat last yank. - "c2." will repeat the last but one change? - Also: keep history of Normal mode commands, add command to list the history - and/or pick an older command. -- History stack for . command? Use "g." command. - - -Mappings and Abbreviations: -8 When "0" is mapped (it is a movement command) this mapping should not be - used after typing another number, e.g. "20l". (Charles Campbell) - Is this possible without disabling the mapping of the following command? -8 Should mapping <C-A> and <C-S-A> both work? -7 ":abbr b byte", append "b " to an existing word still expands to "byte". - This is Vi compatible, but can we avoid it anyway? -8 To make a mapping work with a prepended "x to select a register, store the - last _typed_ register name and access it with "&. -8 Add ":amap", like ":amenu". -7 Add a mapping that works always, for remapping the keyboard. -8 Add ":cab!", abbreviations that only apply to Command-line mode and not to - entering search strings. -8 Add a flag to ":abbrev" to eat the character that triggers the - abbreviation. Thus "abb ab xxx" and typing "ab<Space>" inserts "xxx" and - not the <Space>. -8 Allow mapping of CTRL-@ (anywhere in the LHS). -8 Give a warning when using CTRL-C in the lhs of a mapping. It will never - (?) work. -8 Add a way to save a current mapping and restore it later. Use a function - that returns the mapping command to restore it: mapcmd()? mapcheck() is - not fool proof. How to handle ambiguous mappings? -7 Add <0x8f> (hex), <033> (octal) and <123> (decimal) to <> notation? -7 Allow mapping "Q" and "Q}" at the same time. Need to put a flag with "Q", - that it needs an extra character before it can match. See Vile 'maplonger' - option. -7 When someone tries to unmap with a trailing space, and it fails, try - unmapping without the trailing space. Helps for ":unmap xx | unmap yy". -7 Make it possible to map 'wildchar', but only when it's a special character - (like CTRL-E). Currently it's only recognized when typed. Useful for - mapping a key to do something and then completion. -6 Context-sensitive abbreviations: Specify syntax group(s) in which the - abbreviations are to be used. -- Add mappings that take arguments. Could work like the ":s" command. For - example, for a mouse escape sequence: - :mapexp <Esc>{\([0-9]*\),\([0-9]*\); H\1j\2l -- Add optional <Number> argument for mappings: - :map <Number>q ^W^W<Number>G - :map <Number>q<Number>t ^W^W<Number1-1>G<Number2>l - :map q<Char> :s/<Char>/\u\0/g - Or implicit: - :map q <Register>d<Number>$ -- Make it possible to include a <Nul> in the lhs and rhs of a mapping. -- Add command to repeat a whole mapping ("." only repeats the last change in - a mapping). Also: Repeat a whole insert command, including any mappings - that it included. Sort-of automatic recording? -- Add an option to ":map" that makes it display the special keys in - <> notation (e.g. <CR> instead of ^M). Or just always do this? -- Include an option (or flag to 'cpoptions') that makes errors in mappings - not flush the rest of the mapping (like nvi does). -- Use context sensitiveness of completion to switch abbreviations and - mappings off for :unab and :unmap. -6 When using mappings in Insert mode, insert characters for incomplete - mappings first, then remove them again when a mapping matches. Avoids - that characters that are the start of some mapping are not shown until you - hit another character. -- Add mappings for replace mode: ":rmap". How do we then enter mappings for - non-replace Insert mode? -- Add separate mappings for Visual-character/block/line mode? -- Add 'mapstop' command, to stop recursive mappings. -- List mappings that have a raw escape sequence both with the name of the key - for that escape sequence (if there is one) and the sequence itself. -- List mappings: Once with special keys listed as <>, once with meta chars as - <M-a>, once with the byte values (octal?). Sort of "spell mapping" command? -- When entering mappings: Add the possibility to enter meta keys like they - are displayed, within <>: <M-a>, <~@> or <|a>. -- Allow multiple arguments to :unmap. -- Command to show keys that are not used and available for mapping - ":freekeys". -- Allow any character except white space in abbreviations lhs (Riehm). - - -Incsearch: -- Add a limit to the number of lines that are searched for 'incsearch'? -- When no match is found and the user types more, the screen is redrawn - anyway. Could skip that. Esp. if the line wraps and the text is scrolled - up every time. -- Temporarily open folds to show where the search ends up. Restore the - folds when going to another line. -- When incsearch used and hitting return, no need to search again in many - cases, saves a lot of time in big files. (Slootman wants to work on this?) - When not using special characters, can continue search from the last match - (or not at all, when there was no match). See oldmail/webb/in.872. -- With incsearch, use CTRL-N/CTRL-P to go to next/previous match, some other - key to copy matched word to search pattern (Alexander Schmid). - - -Searching: -8 Add "g/" and "gb" to search for a pattern in the Visually selected text? - "g?" is already used for rot13. - The vis.vim script has a ":S" command that does something like this. - Can use "g/" in Normal mode, uses the '< to '> area. - Use "&/" for searching the text in the Visual area? -8 Add a mechanism for recursiveness: "\@(([^()]*\@g[^()]*)\)". \@g stands - for "go recursive here" and \@( \) marks the recursive part. - Perl does it this way: - $paren = qr/ \(( [^()] | (??{ $paren }) )* \) /x; - Here $paren is evaluated when it's encountered. This is like a regexp - inside a regexp. In the above terms it would be: - \@((\([^()]\|\@g\)*)\) -8 Show the progress every second. Could use the code that checks for CTRL-C - to find out how much time has passed. Or use SIGALRM. Where to show the - number? -7 Support for approximate-regexps to find similar words (agrep - http://www.tgries.de/agrep/ tre: http://laurikari.net/tre/index.html). -8 Add an item for a big character range, so that one can search for a - chinese character: \z[234-1234] or \z[XX-YY] or \z[0x23-0x234]. -7 Add an item stack to allow matching (). One side is "push X on - the stack if previous atom matched". Other side is "match with top of - stack, pop it when it matches". Use "\@pX" and "\@m"? - Example: \((\@p).\{-}\@m\)* -7 Add an option to accept a match at the cursor position. Also for - search(). (Brett) -7 Add a flag to "/pat/" to discard an error. Useful to continue a mapping - when a search fails. Could be "/pat/E" (e is already used for an offset). -7 Add pattern item to use properties of Unicode characters. In Perl it's - "\p{L}" for a letter. See Regular Expression Pocket Reference. -8 Would it be possible to allow ":23,45/pat/flags" to search for "pat" in - lines 23 to 45? Or does this conflict with Ex range syntax? -8 Allow identical pairs in 'matchpairs'. Restrict the search to the current - line. -7 Allow longer pairs in 'matchpairs'. Use ~/vim/macros/matchit.vim as an - example. -8 Make it possible to define the character that "%" checks for in - #if/#endif. For nmake it's !if/!endif. -- For "%" command: set hierarchy for which things include other things that - should be ignored (like "*/" or "#endif" inside /* */). - Also: use "%" to jump from start to end of syntax region and back. - Alternative: use matchit.vim -8 "/:/e+1" gets stuck on a match at the end of the line. Do we care? -8 A pattern like "\([^a]\+\)\+" takes an awful long time. Recognize that - the recursive "\+" is meaningless and optimize for it. - This one is also very slow on "/* some comment */": "^\/\*\(.*[^/]\)*$". -7 Recognize "[a-z]", "[0-9]", etc. and replace them with the faster "\l" and - "\d". -7 Add a way to specify characters in <C-M> or <Key> form. Could be - \%<C-M>. -8 Add an argument after ":s/pat/str/" for a range of matches. For example, - ":s/pat/str/#3-4" to replace only the third and fourth "pat" in a line. -8 When 'iskeyword' is changed the matches from 'hlsearch' may change. (Benji - Fisher) redraw if some options are set while 'hlsearch' is set? -8 Add an option not to use 'hlsearch' highlighting for ":s" and ":g" - commands. (Kahn) It would work like ":noh" is used after that command. - Also: An extra flag to do this once, and a flag to keep the existing - search pattern. -- Make 'hlsearch' a local/global option, so that it can be disabled in some - of the windows. -- Add \%h{group-name}; to search for a specific highlight group. - Add \%s{syntax-group}; to search for a specific syntax group. -- Support Perl regexp. Use PCRE (Perl Compatible RE) package. (Shade) - Or translate the pattern to a Vim one. - Don't switch on with an option for typed commands/mappings/functions, it's - too confusing. Use "\@@" in the pattern, to avoid incompatibilities. -8 Add a way to access the last substitute text, what is used for ":s//~/". - Can't use the ~ register, it's already used for drag & drop. -- Remember flags for backreferenced items, so that "*" can be used after it. - Check with "\(\S\)\1\{3}". (Hemmerling) -8 Flags that apply to the whole pattern. - This works for all places where a regexp is used. - Add "\q" to not store this pattern as the last search pattern? -- Add flags to search command (also for ":s"?): - i ignore case - I use case - p use Perl regexp syntax (or POSIX?) - v use Vi regexp syntax - f forget pattern, don't keep it for "n" command - F remember pattern, keep it for "n" command - Perl uses these too: - e evaluate the right side as an expression (Perl only) - m multiple line expression (we don't need it) - o compile only once (Perl only) - s single line expression (we don't need it) - x extended regexp (we don't need it) - When used after ":g" command, backslash needed to avoid confusion with the - following command. - Add 'searchflags' for default flags (replaces 'gdefault'). -- Add command to display the last used substitute pattern and last used - pattern. (Margo) Maybe make it accessible through a register (like "/ - for search string)? -7 Use T-search algorithm, to speed up searching for strings without special - characters. See C't article, August 1997. -- Add 'fuzzycase' option, so that case doesn't matter, and '-' and '_' are - equivalent (for Unix filenames). -- Add 'v' flag to search command: enter Visual mode, with the matching text - as Visual area. (variation on idea from Bertin) -- Searching: "/this//that/" should find "that" after "this". -- Add global search commands: Instead of wrapping at the end of the buffer, - they continue in another buffer. Use flag after search pattern: - a for the next file in the argument list - f for file in the buffer list - w for file edited in a window. - e.g. "/pat/f". Then "n" and "N" work through files too. "f" flag also for - ":s/pat/foo/f"??? Then when 'autowrite' and 'hidden' are both not set, ask - before saving files: "Save modified buffer "/path/file"? (Yes/Hide/No - Save-all/hide-All/Quit) ". -- ":s/pat/foo/3": find 3rd match of "pat", like sed. (Thomas Koehler) -7 When searching with 'n' give message when getting back where the search - first started. Remember start of search in '/ mark. -7 Add option that scrolls screen to put cursor in middle of screen after - search always/when off-screen/never. And after a ":tag" command. Maybe - specify how many lines below the screen causes a redraw with the cursor in - the middle (default would be half a screen, zero means always). -6 Support multiple search buffers, so macros can be made without side - effects. -7 From xvim: Allow a newline in search patterns (also for :s, can delete - newline). Add BOW, EOW, NEWL, NLORANY, NLBUTANY, magic 'n' and 'r', etc. - [not in xvim:] Add option to switch on matches crossing ONE line boundary. -7 Add ":iselect", a combination of ":ilist" and ":tselect". (Aaron) (Zellner) - Also ":dselect". - - -Undo: -9 After undo/redo, in the message show whether the buffer is modified or - not. -8 Undo tree: visually show the tree somehow (Damian Conway) - Show only the leaves, indicating how many changed from the branch and the - timestamp? - Put branch with most recent change on the left, older changes get more - indent? -8 See ":e" as a change operation, find the changes and add them to the - undo info. Also be able to undo the "Reload file" choice for when a file - was changed outside of Vim. - Would require doing a diff between the buffer text and the file and - storing the differences. -8 Search for pattern in undo tree, showing when it happened and the text - state, so that you can jump to it. -- Persistent undo: store undo in a file. - Use timestamps, so that a version a certain time ago can be found and info - before some time/date can be flushed. 'undopersist' gives maximum time to - keep undo: "3h", "1d", "2w", "1y", etc. For the file use dot and - extension: ".filename.un~" (like swapfile but "un~" instead of "swp"). -- Make it possible to undo all the commands from a mapping, including a - trailing unfinished command, e.g. for ":map K iX^[r". -- When accidentally hitting "R" instead of Ctrl-R, further Ctrl-R is not - possible, even when typing <Esc> immediately. (Grahn) Also for "i", "a", - etc. Postpone saving for undo until something is really inserted? -8 When Inserting a lot of text, it can only be undone as a whole. Make undo - sync points at every line or word. Could recognize the start of a new - word (white space and then non-white space) and backspacing. - Can already use CTRL-G u, but that requires remapping a lot of things. -8 Make undo more memory-efficient: Compare text before and after change, - only remember the lines that really changed. -7 Add undo for a range of lines. Can change these back to a previous - version without changing the rest of the file. Stop doing this when a - change includes only some of these lines and changes the line count. Need - to store these undo actions as a separate change that can be undone. -- For u_save() include the column number. This can be used to set '[ and ']. - And in the future the undo can be made more efficient (Webb). -- In out-of-memory situations: Free allocated space in undo, and reduce the - number of undo levels (with confirmation). -- Instead of [+], give the number of changes since the last write: [+123]. - When undoing to before the last write, change this to a negative number: - [-99]. -- With undo with simple line delete/insert: optimize screen updating. -- When executing macro's: Save each line for undo only once. -- When doing a global substitute, causing almost all lines to be changed, - undo info becomes very big. Put undo info in swap file?? - - -Buffer list: -7 Command to execute a command in another buffer: ":inbuf {bufname} {cmd}". - Also for other windows: ":inwin {winnr} {cmd}". How to make sure that - this works properly for all commands, and still be able to return to the - current buffer/window? E.g.: ":inbuf xxx only". -8 Add File.{recent_files} menu entries: Recently edited files. - Ron Aaron has a plugin for this: mru.vim. -8 Unix: Check all uses of fnamecmp() and fnamencmp() if they should check - inode too. -7 Add another number for a buffer, which is visible for the user. When - creating a new buffer, use the lowest number not in use (or the highest - number in use plus one?). -7 Offer some buffer selection from the command line? Like using ":ls" and - asking for a buffer number. (Zachmann) -- When starting to edit a file that is already in the buffer list, use the - file name argument for the new short file name. (Webb) -- Add an option to make ":bnext" and ":bprev" wrap around the end of the - buffer list. Also for ":next" and ":prev"? -7 Add argument to ":ls" which is a pattern for buffers to list. - E.g. ":ls *.c". (Thompson) -7 Add expansion of buffer names, so that "*.c" is expanded to all buffer - names. Needed for ":bdel *.c", ":bunload *.c", etc. -8 Support for <afile> where a buffer name is expected. -8 Some commands don't use line numbers, but buffer numbers. '$' - should then mean the number of the last buffer. E.g.: "4,$bdel". -7 Add an option to mostly use slashes in file names. Separately for - internal use and for when executing an external program? - - -Swap (.swp) files: -8 If writing to the swap file fails, should try to open one in another - directory from 'dir'. Useful in case the file system is full and when - there are short file name problems. -8 Also use the code to try using a short file name for the backup and swap - file for the Win32 and Dos 32 bit versions. -8 When a file is edited by root, add $LOGNAME to know who did su. -8 When the edited file is a symlink, try to put the swap file in the same - dir as the actual file. Adjust FullName(). Avoids editing the same file - twice (e.g. when using quickfix). Also try to make the name of the backup - file the same as the actual file? - Use the code for resolve()? -7 When using 64 bit inode numbers, also store the top 32 bits. Add another - field for this, using part of bo_fname[], to keep it compatible. -7 When editing a file on removable media, should put swap file somewhere - else. Use something like 'r' flag in 'viminfo'. 'diravoid'? - Also: Be able to specify minimum disk space, skip directory when not - enough room. -7 Add a configure check for which directory should be used: /tmp, /var/tmp - or /var/preserve. -- Add an option to create a swap file only when making the first change to - the buffer. (Liang) Or only when the buffer is not read-only. -- Add option to set "umask" for backup files and swap files (Antwerpen). - 'backupumask' and 'swapumask'? Or 'umaskback' and 'umaskswap'? -- When editing a readonly file, don't use a swap file but read parts from the - original file. Also do this when the file is huge (>'maxmem'). We do - need to load the file once to count the number of lines? Perhaps keep a - cached list of which line is where. - - -Viminfo: -7 Can probably remove the code that checks for a writable viminfo file, - because we now do the chown() for root, and others can't overwrite someone - else's viminfo file. -8 When there is no .viminfo file and someone does "su", runs Vim, a - root-owned .viminfo file is created. Is there a good way to avoid this? - Perhaps check the owner of the directory. Only when root? -8 Add argument to keep the list of buffers when Vim is started with a file - name. (Schild) -8 Keep the last used directory of the file browser (File/Open menu). -8 Remember the last used register for "@@". -8 Remember the redo buffer, so that "." works after restarting. -8 Remember a list of last accessed files. To be used in the - "File.Open Recent" menu. Default is to remember 10 files or so. - Also remember which files have been read and written. How to display - this? -7 Also store the ". register (last inserted text). -7 Make it possible to store buffer names in viminfo file relative to some - directory, to make them portable over a network. (Aaron) -6 Store a snapshot of the currently opened windows. So that when quitting - Vim, and then starting again (without a file name argument), you see the - same files in the windows. Use ":mksession" code? -- Make marks present in .viminfo usable as file marks: Display a list of - "last visited files" and select one to jump to. - - -Modelines: -8 Before trying to execute a modeline, check that it looks like one (valid - option names). If it's very wrong, silently ignore it. - Ignore a line that starts with "Subject: ". -- Add an option to whitelist options that are allowed in a modeline. This - would allow careful users to use modelines, e.g., only allowing - 'shiftwidth'. -- Add an option to let modelines only set local options, not global ones - such as 'encoding'. -- When an option value is coming from a modeline, do not carry it over to - another edited file? Would need to remember the value from before the - modeline setting. -- Allow setting a variable from a modeline? Only allow using fixed strings, - no function calls, to avoid a security problem. -- Allow ":doauto BufRead x.cpp" in modelines, to execute autocommands for - .cpp files. -- Support the "abbreviate" command in modelines (Kearns). Careful for - characters after <Esc>, that is a security leak. -- Add option setting to ask user if he wants to have the modelines executed - or not. Same for .exrc in local dir. - - -Sessions: -8 DOS/Windows: ":mksession" generates a "cd" command where "aa\#bb" means - directory "#bb" in "aa", but it's used as "aa#bb". (Ronald Hoellwarth) -7 When there is a "help.txt" window in a session file, restoring that - session will not get the "LOCAL ADDITIONS" back. -8 With ":mksession" always store the 'sessionoptions' option, even when - "options" isn't in it. (St-Amant) -8 When using ":mksession", also store a command to reset all options to - their default value, before setting the options that are not at their - default value. -7 With ":mksession" also store the tag stack and jump history. (Michal - Malecki) -7 Persistent variables: "p:var"; stored in viminfo file and sessions files. - - -Options: -7 ":with option=value | command": temporarily set an option value and - restore it after the command has executed. -7 Setting an option always sets "w_set_curswant", while this is only - required for a few options. Only do it for those options to avoid the - side effect. -8 Make "old" number options that really give a number of effects into string - options that are a comma separated list. The old number values should - also be supported. -8 Add commands to save and restore an option, which also preserves the flag - that marks if the option was set. Useful to keep the effect of setting - 'compatible' after ":syntax on" has been used. -7 There is 'titleold', why is there no 'iconold'? (Chazelas) -7 Make 'scrolloff' a global-local option, so that it can be different in the - quickfix window, for example. (Gary Holloway) - - -External commands: -8 When filtering text, redirect stderr so that it can't mess up the screen - and Vim doesn't need to redraw it. Also for ":r !cmd". -4 Set separate shell for ":sh", piping "range!filter", reading text "r !ls" - and writing text "w !wc". (Deutsche) Allow arguments for fast start (e.g. - -f). -4 Allow direct execution, without using a shell. -4 Run an external command in the background. But how about I/O in the GUI? - Careful: don't turn Vim into a shell! -4 Add feature to disable using a shell or external commands. - - -Multiple Windows: -7 "vim -oO file ..." use both horizontal and vertical splits. -8 Add CTRL-W T: go to the top window in the column of the current window. - And CTRL-W B: go to bottom window. -7 Use CTRL-W <Tab>, like alt-tab, to switch between buffers. Repeat <Tab> - to select another buffer (only loaded ones?), <BS> to go back, <Enter> to - select buffer, <Esc> to go back to original buffer. -7 Make it possible to edit a new buffer in the preview window. A script can - then fill it with something. ":popen"? -7 Add a 'tool' window: behaves like a preview window but there can be - several. Don't count it in only_one_window(). (Alexei Alexandrov) -6 Add an option to resize the shell when splitting and/or closing a window. - ":vsp" would make the shell wider by as many columns as needed for the new - window. Specify a maximum size (or use the screen size). ":close" would - shrink the shell by as many columns as come available. (Demirel) -7 When starting Vim several times, instantiate a Vim server, that allows - communication between the different Vims. Feels like one Vim running with - multiple top-level windows. Esp. useful when Vim is started from an IDE - too. Requires some form of inter process communication. -- Support a connection to an external viewer. Could call the viewer - automatically after some seconds of non-activity, or with a command. - Allow some way of reporting scrolling and cursor positioning in the viewer - to Vim, so that the link between the viewed and edited text can be made. - - -Marks: -8 Add ten marks for last changed files: ':0, ':1, etc. One mark per file. -8 When cursor is first moved because of scrolling, set a mark at this - position. (Rimon Barr) Use '-. -8 Add a command to jump to a mark and make the motion inclusive. g'm and g`m? -8 The '" mark is set to the first line, even when doing ":next" a few times. - Only set the '" mark when the cursor was really moved in a file. -8 Make `` and '', which would position the new cursor position in the middle - of the window, restore the old topline (or relative position) from when - the mark was set. -7 Make a list of file marks in a separate window. For listing all buffers, - matching tags, errors, etc. Normal commands to move around. Add commands - to jump to the mark (in current window or new window). Start it with - ":browse marks"? -6 Add a menu that lists the Marks like ":marks". (Amerige) -7 For ":jumps", ":tags" and ":marks", for not loaded buffers, remember the - text at the mark. Highlight the column with the mark. -7 Highlight each mark in some way (With "Mark" highlight group). - Or display marks in a separate column, like 'number' does. -7 Use d"m to delete rectangular area from cursor to mark m (like Vile's \m - command). -7 Try to keep marks in the same position when: - - replacing with a line break, like in ":s/pat/^M/", move marks after the - line break column to the next line. (Acevedo) - - inserting/deleting characters in a line. -5 Include marks for start/end of the current word and section. Useful in - mappings. -6 Add "unnamed mark" feature: Like marks for the ":g" command, but place and - unplace them with commands before doing something with the lines. - Highlight the marked lines somehow. - - -Digraphs: -7 Make "ga" show the digraph for a character, if it exists. - Also the keymap? -- Make it possible to enter "r<C-E>" and "r<C-Y>" (get character from line - below/above). -- Use digraph table to tell Vim about the collating sequence of special - characters? -8 Add command to remove one or more (all) digraphs. (Brown) -7 Support different sets of digraphs (depending on the character set?). At - least Latin1/Unicode, Latin-2, MS-DOS (esp. for Win32). - - -Writing files: -- In vim_rename(), should lock "from" file when deleting "to" file for - systems other than Amiga. Avoids problems with unexpected longname to - shortname conversion. -8 write mch_isdevice() for Amiga, Mac, VMS, etc. -8 When appending to a file, Vim should also make a backup and a 'patchmode' - file. -8 'backupskip' doesn't write a backup file at all, a bit dangerous for some - applications. Add 'backupelsewhere' to write a backup file in another - directory? Or add a flag to 'backupdir'? -7 The 'directory' option supports changing path separators to "%" to make - file names unique, also support this for 'backupdir'. (Mikolaj Machowski) -6 Add an option to write a new, numbered, backup file each time. Like - 'patchmode', e.g., 'backupmode'. -6 Make it possible to write 'patchmode' files to a different directory. - E.g., ":set patchmode=~/backups/*.orig". (Thomas) -6 Add an option to prepend something to the backup file name. E.g., "#". - Or maybe allow a function to modify the backup file name? -8 Only make a backup when overwriting a file for the first time. Avoids - losing the original when writing twice. (Slootman) -7 On non-Unix machines, also overwrite the original file in some situations - (file system full, it's a link on an NFS partition). -7 When editing a file, check that it has been change outside of Vim more - often, not only when writing over it. E.g., at the time the swap file is - flushed. Or every ten seconds or so (use the time of day, check it before - waiting for a character to be typed). -8 When a file was changed since editing started, show this in the status - line of the window, like "[time]". - Make it easier to reload all outdated files that don't have changes. - Automatic and/or with a command. - - -Substitute: -8 Substitute with hex/unicode number "\%xff" and "\%uabcd". Just like - "\%uabcd" in search pattern. -8 Make it easier to replace in all files in the argument list. E.g.: - ":argsub/oldword/newword/". Works like ":argdo %s/oldword/newword/g|w". -- :s///p prints the line after a substitution. -- With :s///c replace \&, ~, etc. when showing the replacement pattern. -8 With :s///c allow scrolling horizontally when 'nowrap' is effective. - Also allow a count before the scrolling keys. -- Add number option to ":s//2": replace second occurrence of string? Or: - :s///N substitutes N times. -- Add answers to ":substitute" with 'c' flag, used in a ":global", e.g.: - ":g/pat1/s/pat2/pat3/cg": 'A' do all remaining replacements, 'Q' don't do - any replacements, 'u' undo last substitution. -7 Substitute in a block of text. Use {line}.{column} notation in an Ex - range, e.g.: ":1.3,$.5s" means to substitute from line 1 column 3 to the - last line column 5. -5 Add commands to bookmark lines, display bookmarks, remove bookmarks, - operate on lines with bookmarks, etc. Like ":global" but with the - possibility to keep the bookmarks and use them with several commands. - (Stanislav Sitar) - - -Mouse support: -8 Add 'o' flag to 'mouse'? -7 Be able to set a 'mouseshape' for the popup menu. -8 Add 'mouse' flag, which sets a behavior like Visual mode, but automatic - yanking at the button-up event. Or like Select mode, but typing gets you - out of Select mode, instead of replacing the text. (Bhaskar) -- Implement mouse support for the Amiga console. -- Using right mouse button to extend a blockwise selection should attach to - the nearest corner of the rectangle (four possible corners). -- Precede mouse click by a number to simulate double clicks?!? -- When mouse click after 'r' command, get character that was pointed to. - - -Crypt and security: -8 Also crypt the swapfile, each block separately. Change mf_write() and - mf_read(). How to get b_p_key to these functions? - - -Argument list: -6 Add command to put all filenames from the tag files in the argument list. - When given an argument, only use the files where that argument matches - (like `grep -l ident`) and jump to the first match. -6 Add command to form an args list from all the buffers? - - -Registers: -8 Don't display empty registers with ":display". (Etienne) -8 Make the # register writable, so that it can be restored after jumping - around in windows. -8 Add put command that overwrites existing text. Should also work for - blocks. Useful to move text around in a table. Works like using "R ^R r" - for every line. -6 When yanking into the unnamed registers several times, somehow make the - previous contents also available (like it's done for deleting). What - register names to use? g"1, g"2, etc.? -- When appending to a register, also report the total resulting number of - lines. Or just say "99 more lines yanked", add the "more". -- When inserting a register in Insert mode with CTRL-R, don't insert comment - leader when line wraps? -- The ":@r" commands should take a range and execute the register for each - line in the range. -- Add "P" command to insert contents of unnamed register, move selected text - to position of previous deleted (to swap foo and bar in " + foo") -8 Should be able to yank and delete into the "/ register. - How to take care of the flags (offset, magic)? - - -Debug mode: -7 Add something to enable debugging when a remote message is received. -8 Add breakpoints for setting an option -8 Add breakpoints for assigning to a variable. -7 Add a watchpoint in the debug mode: An expression that breaks execution - when evaluating to non-zero. Add the "watchadd expr" command, stop when - the value of the expression changes. ":watchdel" deletes an item, - ":watchlist" lists the items. (Charles Campbell) -7 Store the history from debug mode in viminfo. -7 Make the debug mode history available with histget() et al. - - -Various improvements: -8 ":sign unplace * file={filename}" should work. Also: ":sign unplace * - buffer={bufnr}". So one can remove all signs for one file/buffer. -7 Add plugins for formatting? Should be able to make a choice depending on - the language of a file (English/Korean/Japanese/etc.). - Setting the 'langformat' option to "chinese" would load the - "format/chinese.vim" plugin. - The plugin would set 'formatexpr' and define the function being called. - Edward L. Fox explains how it should be done for most Asian languages. - (2005 Nov 24) - Alternative: patch for utf-8 line breaking. (Yongwei Wu, 2008 Feb 23) -7 [t to move to previous xml/html tag (like "vatov"), ]t to move to next - ("vatv"). -7 [< to move to previous xml/html tag, e.g., previous <li>. ]< to move to - next <li>, ]< to next </li>, [< to previous </li>. -8 Add ":rename" command: rename the file of the current buffer and rename - the buffer. Buffer may be modified. -7 Instead of filtering errors with a shell script it should be possible to - do this with Vim script. A function that filters the raw text that comes - from the 'makeprg'? -- Add %b to 'errorformat': buffer number. (Yegappan Lakshmanan / Suresh - Govindachar) -7 Add a command that goes back to the position from before jumping to the - first quickfix location. ":cbefore"? -6 In the quickfix window statusline add the command used to get the list of - errors, e.g. ":make foo", ":grep something *.c". -6 Python interface: add vim.message() function. (Michal Vitecek, 2002 Nov 5) -7 Support using ":vert" with User commands. Add expandable items <vert>. - Do the same for ":browse" and ":confirm"? - For ":silent" and ":debug" apply to the whole user command. - More general: need a way to access command modifiers in a user command. - Assign them to a v: variable? -7 Allow a window not to have a statusline. Makes it possible to use a - window as a buffer-tab selection. -7 Add an invisible buffer which can be edited. For use in scripts that want - to manipulate text without changing the window layout. -8 Add a command to revert to the saved version of file; undo or redo until - all changes are gone. -6 "vim -q -" should read the list of errors from stdin. (Gautam Mudunuri) -8 Add "--remote-fail": When contacting the server fails, exit Vim. - Add "--remote-self": When contacting the server fails, do it in this Vim. - Overrules the default of "--remote-send" to fail and "--remote" to do it - in this Vim. -8 When Vim was started without a server, make it possible to start one, as - if the "--servername" argument was given. ":startserver <name>"? -8 No address range can be used before the command modifiers. This makes - them difficult to use in a menu for Visual mode. Accept the range and - have it apply to the following command. -8 Add the possibility to set 'fileformats' to force a format and strip other - CR characters. For example, for "dos" files remove CR characters at the - end of the line, so that a file with mixed line endings is cleaned up. - To just not display the CR characters: Add a flag to 'display'? -7 Some compilers give error messages in which the file name does not have a - path. Be able to specify that 'path' is used for these files. -7 Xterm sends <Esc>O3F for <M-End>. Similarly for other <M-Home>, <M-Left>, - etc. Combinations of Alt, Ctrl and Shift are also possible. Recognize - these to avoid inserting the raw byte sequence, handle like the key - without modifier (unless mapped). -7 Support ":browse edit" in console, using explorer.vim? -6 Add "gG": like what "gj" is to "j": go to the N'th window line. -8 Add command like ":normal" that accepts <Key> notation like ":map". -9 Support ACLs on more systems. -7 Add ModeMsgVisual, ModeMsgInsert, etc. so that each mode message can be - highlighted differently. -7 Add a message area for the user. Set some option to reserve space (above - the command line?). Use an ":echouser" command to display the message - (truncated to fit in the space). -7 Add %s to 'keywordprg': replace with word under the cursor. (Zellner) -8 Support printing on Unix. Can use "lpansi.c" as an example. (Bookout) -8 Add put command that replaces the text under it. Esp. for blockwise - Visual mode. -7 Enhance termresponse stuff: Add t_CV(?): pattern of term response, use - regexp: "\e\[[>?][0-9;]*c", but only check just after sending t_RV. -7 Add "g|" command: move to N'th column from the left margin (after wrapping - and applying 'leftcol'). Works as "|" like what "g0" is to "0". -7 Support setting 'equalprg' to a user function name. -7 Highlight the characters after the end-of-line differently. -7 When 'whichwrap' contains "l", "$dl" should join lines? -8 Add an argument to configure to use $CFLAGS and not modify it? (Mooney) -8 Enabling features is a mix of configure arguments and defines in - feature.h. How to make this consistent? Feature.h is required for - non-unix systems. Perhaps let configure define CONF_XXX, and use #ifdef - CONF_XXX in feature.h? Then what should min-features and max-features do? -8 Add "g^E" and "g^Y", to scroll a screen-full line up and down. -6 Add ":timer" command, to set a command to be executed at a certain - interval, or once after some time has elapsed. (Aaron) - Perhaps an autocommand event like CursorHold is better? -8 Add ":confirm" handling in open_exfile(), for when file already exists. -8 When quitting with changed files, make the dialog list the changed file - and allow "write all", "discard all", "write some". The last one would - then ask "write" or "discard" for each changed file. Patch in HierAssist - does something like this. (Shah) -7 Use growarray for replace stack. -7 Have a look at viH (Hellenic or Greek version of Vim). But a solution - outside of Vim might be satisfactory (Haritsis). -3 Make "2d%" work like "d%d%" instead of "d2%"? -7 "g CTRL-O" jumps back to last used buffer. Skip CTRL-O jumps in the same - buffer. Make jumplist remember the last ten accessed buffers? -- Keep a list of most recently used files for each window, use "[o" to go - back (older file) and "]n" to go forward (newer file) (like ^O and ^I for - jumps). (Webb) Use ":files" and ":ls" to list the files in history order. -7 Add a history of recently accessed buffer. Maybe make "2 CTRL-^" jump to - the 2nd previously visited buffer, "3 CTRL-^" to the third, etc. Or use - "3 g CTRL-^" for this? -- Add code to disable the CAPS key when going from Insert to Normal mode. -- Set date/protection/etc. of the patchfile the same as the original file. -- Use growarray for termcodes[] in term.c -- Add <window-99>, like <cword> but use filename of 99'th window. -7 Add a way to change an operator to always work characterwise-inclusive - (like "v" makes the operator characterwise-exclusive). "x" could be used. -- Make a set of operations on list of names: expand wildcards, replace home - dir, append a string, delete a string, etc. -- Remove mktemp() and use tmpname() only? Ctags does this. -- When replacing environment variables, and there is one that is not set, - turn it into an empty string? Only when expanding options? (Hiebert) -- Option to set command to be executed instead of producing a beep (e.g. to - call "play newbeep.au"). -- Add option to show the current function name in the status line. More or - less what you find with "[[k", like how 'cindent' recognizes a function. - (Bhatt). -- "[r" and "]r": like "p" and "P", but replace instead of insert (esp. for - blockwise registers). -- Add 'timecheck' option, on by default. Makes it possible to switch off the - timestamp warning and question. (Dodt). -- Add an option to set the time after which Vim should check the timestamps - of the files. Only check when an event occurs (e.g., character typed, - mouse moved). Useful for non-GUI versions where keyboard focus isn't - noticeable. -- Make 'smartcase' work even though 'ic' isn't set (Webb). -7 When formatting text, allow to break the line at a number of characters. - Use an option for this: 'breakchars'? Useful for formatting Fortran code. -- Add flag to 'formatoptions' to be able to format book-style paragraphs - (first line of paragraph has larger indent, no empty lines between - paragraphs). Complements the '2' flag. Use '>' flag when larger indent - starts a new paragraph, use '<' flag when smaller indent starts a new - paragraph. Both start a new paragraph on any indent change. -8 The 'a' flag in 'formatoptions' is too dangerous. In some way only do - auto-formatting in specific regions, e.g. defined by syntax highlighting. -8 Allow using a trailing space to signal a paragraph that continues on the - next line (MIME text/plain; format=flowed, RFC 2646). Can be used for - continuous formatting. Could use 'autoformat' option, which specifies a - regexp which triggers auto-formatting (for one line). - ":set autoformat=\\s$". -- Be able to redefine where a sentence stops. Use a regexp pattern? -- Support multi-byte characters for sentences. Example from Ben Peterson. -7 Add command "g)" to go to the end of a sentence, "g(" to go back to the - end of a sentence. (Servatius Brandt) -- Be able to redefine where a paragraph starts. For "[[" where the '{' is - not in column 1. -6 Add ":cdprev": go back to the previous directory. Need to remember a - stack of previous directories. We also need ":cdnext". -7 Should ":cd" for MS-DOS go to $HOME, when it's defined? -- Make "gq<CR>" work on the last line in the file. Maybe for every operator? -- Add more redirecting of Ex commands: - :redir #> bufname - :redir #>> bufname (append) -- Give error message when starting :redir: twice or using END when no - redirection was active. -- Setting of options, specifically for a buffer or window, with - ":set window.option" or ":set buffer.option=val". Or use ":buffer.set". - Also: "buffer.map <F1> quit". -6 Would it be possible to change the color of the cursor in the Win32 - console? (Klaus Hast) -- Add :delcr command: - *:delcr* - :[range]delcr[!] Check [range] lines (default: whole buffer) for lines - ending in <CR>. If all lines end in <CR>, or [!] is - used, remove the <CR> at the end of lines in [range]. - A CTRL-Z at the end of the file is removed. If - [range] is omitted, or it is the whole file, and all - lines end in <CR> 'textmode' is set. {not in Vi} -- Should integrate addstar() and file_pat_to_reg_pat(). -- When working over a serial line with 7 bit characters, remove meta - characters from 'isprint'. -- Use fchdir() in init_homedir(), like in FullName(). -- In win_update(), when the GUI is active, always use the scrolling area. - Avoid that the last status line is deleted and needs to be redrawn. -- That "cTx" fails when the cursor is just after 'x' is Vi compatible, but - may not be what you expect. Add a flag in 'cpoptions' for this? More - general: Add an option to allow "c" to work with a null motion. -- Give better error messages by using errno (strerror()). -- Give "Usage:" error message when command used with wrong arguments (like - Nvi). -- Make 'restorescreen' option also work for xterm (and others), replaces the - SAVE_XTERM_SCREEN define. -7 Support for ":winpos" In xterm: report the current window position. -- Give warning message when using ":set t_xx=asdf" for a termcap code that - Vim doesn't know about. Add flag in 'shortmess'? -6 Add ":che <file>", list all the include paths which lead to this file. -- For a commandline that has several commands (:s, :d, etc.) summarize the - changes all together instead of for each command (e.g. for the rot13 - macro). -- Add command like "[I" that also shows the tree of included files. -- ":set sm^L" results in ":set s", because short names of options are also - expanded. Is there a better way to do this? -- Add ":@!" command, to ":@" like what ":source!" is to ":source". -8 Add ":@:!": repeat last command with forceit set. -- Should be possible to write to a device, e.g. ":w! /dev/null". -- Add 't_normal': Used whenever t_me, t_se, t_ue or t_Zr is empty. -- ":cab map test ^V| je", ":cunab map" doesn't work. This is vi compatible! -- CTRL-W CTRL-E and CTRL-W CTRL-Y should move the current window up or down - if it is not the first or last window. -- Include-file-search commands should look in the loaded buffer of a file (if - there is one) instead of the file itself. -7 Change 'nrformats' to include the leader for each format. Example: - nrformats=hex:$,binary:b,octal:0 - Add setting of 'nrformats' to syntax files. -- 'path' can become very long, don't use NameBuff for expansion. -- When unhiding a hidden buffer, put the same line at top of the window as - the one before hiding it. Or: keep the same relative cursor position (so - many percent down the windows). -- Make it possible for the 'showbreak' to be displayed at the end of the - line. Use a comma to separate the part at the end and the start of the - line? Highlight the linebreak characters, add flag in 'highlight'. -- Some string options should be expanded if they have wildcards, e.g. - 'dictionary' when it is "*.h". -- Use a specific type for number and boolean options, making it possible to - change it for specific machines (e.g. when a long is 64 bit). -- Add option for <Insert> in replace mode going to normal mode. (Nugent) -- Add a next/previous possibility to "[^I" and friends. -- Add possibility to change the HOME directory. Use the directory from the - passwd file? (Antwerpen) -8 Add commands to push and pop all or individual options. ":setpush tw", - ":setpop tw", ":setpush all". Maybe pushing/popping all options is - sufficient. ":setflush" resets the option stack? - How to handle an aborted mapping? Remember position in tag stack when - mapping starts, restore it when an error aborts the mapping? -- Change ":fixdel" into option 'fixdel', t_del will be adjusted each time - t_bs is set? (Webb) -- "gc": goto character, move absolute character positions forward, also - counting newlines. "gC" goes backwards (Weigert). -- When doing CTRL-^, redraw buffer with the same topline. (Demirel) Store - cursor row and window height to redraw cursor at same percentage of window - (Webb). -- Besides remembering the last used line number of a file, also remember the - column. Use it with CTRL-^ et. al. -- Check for non-digits when setting a number option (careful when entering - hex codes like 0xff). -- Add option to make "." redo the "@r" command, instead of the last command - executed by it. Also to make "." redo the whole mapping. Basically: redo - the last TYPED command. -- Support URL links for ^X^F in Insert mode, like for "gf". -- Support %name% expansion for "gf" on Windows. -- Make "gf" work on "file://c:/path/name". "file:/c:/" and "file:///c:/" - should also work? -- Add 'urlpath', used like 'path' for when "gf" used on an URL? -8 When using "gf" on an absolute file name, while editing a remote file - (starts with scp:// or http://) should prepend the method and machine - name. -- When finding an URL or file name, and it doesn't exist, try removing a - trailing '.'. -- Add ":path" command modifier. Should work for every command that takes a - file name argument, to search for the file name in 'path'. Use - find_file_in_path(). -- Highlight control characters on the screen: Shows the difference between - CTRL-X and "^" followed by "X" (Colon). -- Integrate parsing of cmdline command and parsing for expansion. -- Create a program that can translate a .swp file from any machine into a - form usable by Vim on the current machine. -- Add ":noro" command: Reset 'ro' flag for all buffers, except ones that have - a readonly file. ":noro!" will reset all 'ro' flags. -- Add a variant of CTRL-V that stops interpretation of more than one - character. For entering mappings on the command line where a key contains - several special characters, e.g. a trailing newline. -- Add regex for 'paragraphs' and 'sections': 'parare' and 'sectre'. Combine - the two into a regex for searching. (Ned Konz) -- Make '2' option in 'formatoptions' also work inside comments. -- Add 's' flag to 'formatoptions': Do not break when inside a string. (Dodt) -- When window size changed (with the mouse) and made too small, set it back - to the minimal size. -- Add "]>" and "[<", shift comment at end of line (command; /* comment */). -- Should not call cursorcmd() for each vgetc() in getcmdline(). -- ":split file1 file2" adds two more windows (Webb). -- Don't give message "Incomplete last line" when editing binary file. -- Add ":a", ":i" for preloading of named buffers. -- Allow autowrite when doing ":e file" (with an option 'eaw'). -- Allow a "+command" argument before each file name in the Vim command line: - "vim +123 file1 +234 file2 +345 file3". ??? -- When entering text, keep other windows on same buffer updated (when a line - entered)? -- Check out how screen does output optimizing. Apparently this is possible - as an output filter. -- In dosub() regexec is called twice for the same line. Try to avoid this. -- Window updating from memline.c: insert/delete/replace line. -- Optimize ml_append() for speed, esp. for reading a file. -- V..c should keep indent when 'ai' is set, just like [count]cc. -- Updatescript() can be done faster with a string instead of a char. -- Screen updating is inefficient with CTRL-F and CTRL-B when there are long - lines. -- Uppercase characters in ex commands can be made lowercase? -8 Add option to show characters in text not as "|A" but as decimal ("^129"), - hex ("\x81") or octal ("\201") or meta (M-x). Nvi has the 'octal' option - to switch from hex to octal. Vile can show unprintable characters in hex - or in octal. -7 Tighter integration with xxd to edit binary files. Make it more - easy/obvious to use. Command line argument? -- How does vi detect whether a filter has messed up the screen? Check source. - After ":w !command" a wait_return? -- Improve screen updating code for doput() (use s_ins()). -- With 'p' command on last line: scroll screen up (also for terminals without - insert line command). -- Use insert/delete char when terminal supports it. -- Optimize screen redraw for slow terminals. -- Optimize "dw" for long row of spaces (say, 30000). -- Add "-d null" for editing from a script file without displaying. -- In Insert mode: Remember the characters that were removed with backspace - and re-insert them one at a time with <key1>, all together with <key2>. -- Amiga: Add possibility to set a keymap. The code in amiga.c does not work - yet. -- Implement 'redraw' option. -- Add special code to 'sections' option to define something else but '{' or - '}' as the start of a section (e.g. one shiftwidth to the right). -7 Allow using Vim in a pipe: "ls | vim -u xxx.vim - | yyy". Only needs - implementing ":w" to stdout in the buffer that was read from stdin. - Perhaps writing to stdout will work, since stderr is used for the terminal - I/O. -8 Allow opening an unnamed buffer with ":e !cmd" and ":sp !cmd". Vile can - do it. -- Add commands like ]] and [[ that do not include the line jumped to. -- When :unab without matching "from" part and several matching "to" parts, - delete the entry that was used last, instead of the first in the list. -- Add text justification option. -- Set boolean options on/off with ":set paste=off", ":set paste=on". -- After "inv"ing an option show the value: ":set invpaste" gives "paste is - off". -- Check handling of CTRL-V and '\' for ":" commands that do not have TRLBAR. -- When a file cannot be opened but does exist, give error message. -- Amiga: When 'r' protection bit is not set, file can still be opened but - gives read errors. Check protection before opening. -- When writing check for file exists but no permission, "Permission denied". -- If file does not exists, check if directory exists. -- MSDOS: although t_cv and t_ci are not set, do invert char under cursor. -- Settings edit mode: make file with ":set opt=xx", edit it, parse it as ex - commands. -- ":set -w all": list one option per line. -- Amiga: test for 'w' flag when reading a file. -- :table command (Webb) -- Add new operator: clear, make area white (replace with spaces): "g ". -- Add command to ":read" a file at a certain column (blockwise read?). -- Add sort of replace mode where case is taken from the old text (Goldfarb). -- Allow multiple arguments for ":read", read all the files. -- Support for tabs in specific columns: ":set tabcol=8,20,34,56" (Demirel). -- Add 'searchdir' option: Directories to search for file name being edited - (Demirel). -- Modifier for the put command: Change to linewise, charwise, blockwise, etc. -- Add commands for saving and restoring options ":set save" "set restore", - for use in macro's and the like. -- Keep output from listings in a window, so you can have a look at it while - working in another window. Put cmdline in a separate window? -- Add possibility to put output of ex commands in a buffer or file, e.g. for - ":set all". ":r :set all"? -- 'edit' option: When off changing the buffer is not possible (Really - read-only mode). -- When the 'equalalways' option is set, creating a new window should not - result in windows to become bigger. Deleting a window should not result in - a window to become smaller (Webb). -- When resizing the whole Vim window, the windows inside should be resized - proportionally (Webb). -- Include options directly in option table, no indirect pointers. Use - mkopttab to make option table? -- When doing ":w dir", where "dir" is a directory name, write the current - file into that directory, with the current file name (without the path)? -- Support for 'dictionary's that are sorted, makes access a lot faster - (Haritsis). -- Add "^Vrx" on the command line, replace with contents of register x. Used - instead of CTRL-R to make repeating possible. (Marinichev) -- Add "^Vb" on the command line, replace with word before or under the - cursor? -- Option to make a .swp file only when a change is made (Templeton). -- Support mapping for replace mode and "r" command (Vi doesn't do this)? -5 Add 'ignorefilecase' option: Ignore case when expanding file names. - ":e ma<Tab>" would also find "Makefile" on Unix. -8 Sorting of filenames for completion is wrong on systems that ignore - case of filenames. Add 'ignorefncase' option. When set, case in - filenames is ignored for sorting them. Patch by Mike Williams: - ~/vim/patches/ignorefncase. Also change what matches? Or use another - option name. -8 Should be able to compile Vim in another directory, with $(srcdir) set to - where the sources are. Add $(srcdir) in the Makefile in a lot of places. - (Netherton) -6 Make it configurable when "J" inserts a space or not. Should not add a - space after "(", for example. -5 When inserting spaces after the end-of-line for 'virtualedit', use tabs - when the user wants this (e.g., add a "tab" field to 'virtualedit'). - (Servatius Brandt) - - -From Elvis: -- Use "instman.sh" to install manpages? -- Add ":alias" command. -- fontchanges recognized "\\fB" etc. -- Search patterns: - \@ match word under cursor. - but do: - \@w match the word under the cursor? - \@W match the WORD under the cursor? -8 ":window" command: - :win + next window (up) - :win ++ idem, wrapping - :win - previous window (down) - :win -- idem, wrapping - :win nr to window number "nr" - :win name to window editing buffer "name" -7 ":cc" compiles a single file (default: current one). 'ccprg' option is - program to use with ":cc". Use ":compile" instead of ":cc"? - - -From Nvi: -- 'searchincr' option, alias for 'incsearch'? -- 'leftright' option, alias for 'nowrap'? -- Have a look at "vi/doc/vi.chart", for Nvi specialties. -8 Add 'keytime', time in 1/10 sec for mapping timeout? -- Add 'filec' option as an alternative for 'wildchar'. -6 Support Nvi command names as an alias: - :bg :hide - :fg fname :buf fname (with 'hidden' set?) - :dis b :ls - :Edit fname :split fname - :Fg fname :sbuf fname (with 'hidden' set?) - :Next :snext (can't do this, already use :Next) - :Previous :sprevious - :Tag :stag - - -From xvi: -- CTRL-_ : swap 8th bit of character. -- Add egrep-like regex type, like xvi (Ned Konz) or Perl (Emmanuel Mogenet) - - -From vile: -- When horizontal scrolling, use '>' for lines continuing right of a window. -- Support putting .swp files in /tmp: Command in rc.local to move .swp files - from /tmp to some directory before deleting files. - - -Far future and "big" extensions: -- Instead of using a Makefile and autoconf, use a simple shell script to - find the C compiler and do everything with C code. Translate something - like an Aap recipe and configure.in to C. Avoids depending on Python, - thus will work everywhere. With batch file to find the C compiler it - would also work on MS-Windows. -- Make it easy to setup Vim for groups of users: novice vi users, novice - Vim users, C programmers, xterm users, GUI users,... -- Change layout of blocks in swap file: Text at the start, with '\n' in - between lines (just load the file without changes, except for Mac). - Indexes for lines are from the end of the block backwards. It's the - current layout mirrored. -- Make it possible to edit a register, in a window, like a buffer. -- Add stuff to syntax highlighting to change the text (upper-case keywords, - set indent, define other highlighting, etc.). -- Mode to keep C-code formatted all the time (sort of on-line indent). -- Several top-level windows in one Vim session. Be able to use a different - font in each top-level window. -- Allow editing above start and below end of buffer (flag in 'virtualedit'). -- Smart cut/paste: recognize words and adjust spaces before/after them. -- Add open mode, use it when terminal has no cursor positioning. -- Special "drawing mode": a line is drawn where the cursor is moved to. - Backspace deletes along the line (from jvim). -- Implement ":Bset", set option in all buffers. Also ":Wset", set in all - windows, ":Aset, set in all arguments and ":Tset", set in all files - mentioned in the tags file. - Add buffer/arg range, like in ":2,5B%s/..." (do we really need this???) - Add search string: "B/*.c/%s/.."? Or ":F/*.c/%s/.."? -- Support for underlining (underscore-BS-char), bold (char-BS-char) and other - standout modes switched on/off with , 'overstrike' option (Reiter). -- Add vertical mode (Paul Jury, Demirel): "5vdw" deletes a word in five - lines, "3vitextESC" will insert "text" in three lines, etc.. -4 Recognize l, #, p as 'flags' to EX commands: - :g/RE/#l shall print lines with line numbers and in list format. - :g/RE/dp shall print lines that are deleted. - POSIX: Commands where flags shall apply to all lines written: list, - number, open, print, substitute, visual, &, z. For other commands, flags - shall apply to the current line after the command completes. Examples: - :7,10j #l Join the lines 7-10 and print the result in list -- Allow two or more users to edit the same file at the same time. Changes - are reflected in each Vim immediately. Could work with local files but - also over the internet. See http://www.codingmonkeys.de/subethaedit/. - -When using "do" or ":diffget" in a buffer with changes in every line an extra -empty line would appear. - -vim:tw=78:sw=4:sts=4:ts=8:ft=help:norl: -vim: set fo+=n : diff --git a/share/vim/vim72/doc/uganda.txt b/share/vim/vim72/doc/uganda.txt deleted file mode 100644 index 8f684e8354..0000000000 --- a/share/vim/vim72/doc/uganda.txt +++ /dev/null @@ -1,287 +0,0 @@ -*uganda.txt* For Vim version 7.2. Last change: 2008 Jun 21 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - - *uganda* *Uganda* *copying* *copyright* *license* -SUMMARY - *iccf* *ICCF* -Vim is Charityware. You can use and copy it as much as you like, but you are -encouraged to make a donation for needy children in Uganda. Please see |kcc| -below or visit the ICCF web site, available at these URLs: - - http://iccf-holland.org/ - http://www.vim.org/iccf/ - http://www.iccf.nl/ - -You can also sponsor the development of Vim. Vim sponsors can vote for -features. See |sponsor|. The money goes to Uganda anyway. - -The Open Publication License applies to the Vim documentation, see -|manual-copyright|. - -=== begin of license === - -VIM LICENSE - -I) There are no restrictions on distributing unmodified copies of Vim except - that they must include this license text. You can also distribute - unmodified parts of Vim, likewise unrestricted except that they must - include this license text. You are also allowed to include executables - that you made from the unmodified Vim sources, plus your own usage - examples and Vim scripts. - -II) It is allowed to distribute a modified (or extended) version of Vim, - including executables and/or source code, when the following four - conditions are met: - 1) This license text must be included unmodified. - 2) The modified Vim must be distributed in one of the following five ways: - a) If you make changes to Vim yourself, you must clearly describe in - the distribution how to contact you. When the maintainer asks you - (in any way) for a copy of the modified Vim you distributed, you - must make your changes, including source code, available to the - maintainer without fee. The maintainer reserves the right to - include your changes in the official version of Vim. What the - maintainer will do with your changes and under what license they - will be distributed is negotiable. If there has been no negotiation - then this license, or a later version, also applies to your changes. - The current maintainer is Bram Moolenaar <Bram@vim.org>. If this - changes it will be announced in appropriate places (most likely - vim.sf.net, www.vim.org and/or comp.editors). When it is completely - impossible to contact the maintainer, the obligation to send him - your changes ceases. Once the maintainer has confirmed that he has - received your changes they will not have to be sent again. - b) If you have received a modified Vim that was distributed as - mentioned under a) you are allowed to further distribute it - unmodified, as mentioned at I). If you make additional changes the - text under a) applies to those changes. - c) Provide all the changes, including source code, with every copy of - the modified Vim you distribute. This may be done in the form of a - context diff. You can choose what license to use for new code you - add. The changes and their license must not restrict others from - making their own changes to the official version of Vim. - d) When you have a modified Vim which includes changes as mentioned - under c), you can distribute it without the source code for the - changes if the following three conditions are met: - - The license that applies to the changes permits you to distribute - the changes to the Vim maintainer without fee or restriction, and - permits the Vim maintainer to include the changes in the official - version of Vim without fee or restriction. - - You keep the changes for at least three years after last - distributing the corresponding modified Vim. When the maintainer - or someone who you distributed the modified Vim to asks you (in - any way) for the changes within this period, you must make them - available to him. - - You clearly describe in the distribution how to contact you. This - contact information must remain valid for at least three years - after last distributing the corresponding modified Vim, or as long - as possible. - e) When the GNU General Public License (GPL) applies to the changes, - you can distribute the modified Vim under the GNU GPL version 2 or - any later version. - 3) A message must be added, at least in the output of the ":version" - command and in the intro screen, such that the user of the modified Vim - is able to see that it was modified. When distributing as mentioned - under 2)e) adding the message is only required for as far as this does - not conflict with the license used for the changes. - 4) The contact information as required under 2)a) and 2)d) must not be - removed or changed, except that the person himself can make - corrections. - -III) If you distribute a modified version of Vim, you are encouraged to use - the Vim license for your changes and make them available to the - maintainer, including the source code. The preferred way to do this is - by e-mail or by uploading the files to a server and e-mailing the URL. - If the number of changes is small (e.g., a modified Makefile) e-mailing a - context diff will do. The e-mail address to be used is - <maintainer@vim.org> - -IV) It is not allowed to remove this license from the distribution of the Vim - sources, parts of it or from a modified version. You may use this - license for previous Vim releases instead of the license that they came - with, at your option. - -=== end of license === - -Note: - -- If you are happy with Vim, please express that by reading the rest of this - file and consider helping needy children in Uganda. - -- If you want to support further Vim development consider becoming a - |sponsor|. The money goes to Uganda anyway. - -- According to Richard Stallman the Vim license is GNU GPL compatible. - A few minor changes have been made since he checked it, but that should not - make a difference. - -- If you link Vim with a library that goes under the GNU GPL, this limits - further distribution to the GNU GPL. Also when you didn't actually change - anything in Vim. - -- Once a change is included that goes under the GNU GPL, this forces all - further changes to also be made under the GNU GPL or a compatible license. - -- If you distribute a modified version of Vim, you can include your name and - contact information with the "--with-modified-by" configure argument or the - MODIFIED_BY define. - -============================================================================== -Kibaale Children's Centre *kcc* *Kibaale* *charity* - -Kibaale Children's Centre (KCC) is located in Kibaale, a small town in the -south of Uganda, near Tanzania, in East Africa. The area is known as Rakai -District. The population is mostly farmers. Although people are poor, there -is enough food. But this district is suffering from AIDS more than any other -part of the world. Some say that it started there. Estimations are that 10 -to 30% of the Ugandans are infected with HIV. Because parents die, there are -many orphans. In this district about 60,000 children have lost one or both -parents, out of a population of 350,000. And this is still continuing. - -The children need a lot of help. The KCC is working hard to provide the needy -with food, medical care and education. Food and medical care to keep them -healthy now, and education so that they can take care of themselves in the -future. KCC works on a Christian base, but help is given to children of any -religion. - -The key to solving the problems in this area is education. This has been -neglected in the past years with president Idi Amin and the following civil -wars. Now that the government is stable again, the children and parents have -to learn how to take care of themselves and how to avoid infections. There is -also help for people who are ill and hungry, but the primary goal is to -prevent people from getting ill and to teach them how to grow healthy food. - -Most of the orphans are living in an extended family. An uncle or older -sister is taking care of them. Because these families are big and the income -(if any) is low, a child is lucky if it gets healthy food. Clothes, medical -care and schooling is beyond its reach. To help these needy children, a -sponsorship program was put into place. A child can be financially adopted. -For a few dollars a month KCC sees to it that the child gets indispensable -items, is healthy, goes to school and KCC takes care of anything else that -needs to be done for the child and the family that supports it. - -Besides helping the child directly, the environment where the child grows up -needs to be improved. KCC helps schools to improve their teaching methods. -There is a demonstration school at the centre and teacher trainings are given. -Health workers are being trained, hygiene education is carried out and -households are stimulated to build a proper latrine. I helped setting up a -production site for cement slabs. These are used to build a good latrine. -They are sold below cost price. - -There is a small clinic at the project, which provides children and their -family with medical help. When needed, transport to a hospital is offered. -Immunization programs are carried out and help is provided when an epidemic is -breaking out (measles and cholera have been a problem). - *donate* -Summer 1994 to summer 1995 I spent a whole year at the centre, working as a -volunteer. I have helped to expand the centre and worked in the area of water -and sanitation. I learned that the help that the KCC provides really helps. -When I came back to Holland, I wanted to continue supporting KCC. To do this -I'm raising funds and organizing the sponsorship program. Please consider one -of these possibilities: - -1. Sponsor a child in primary school: 17 euro a month (or more). -2. Sponsor a child in secondary school: 25 euro a month (or more). -3. Sponsor the clinic: Any amount a month or quarter -4. A one-time donation - -Compared with other organizations that do child sponsorship the amounts are -very low. This is because the money goes directly to the centre. Less than -5% is used for administration. This is possible because this is a small -organization that works with volunteers. If you would like to sponsor a -child, you should have the intention to do this for at least one year. - -How do you know that the money will be spent right? First of all you have my -personal guarantee as the author of Vim. I trust the people that are working -at the centre, I know them personally. Further more, the centre is -co-sponsored and inspected by World Vision, Save the Children Fund and -International Child Care Fund. The centre is visited about once a year to -check the progress (at our own cost). I have visited the centre myself in -1996, 1998, 2000, 2001 and 2003. The visit reports are on the ICCF web site. - -If you have any further questions, send me e-mail: <Bram@vim.org>. - -The address of the centre is: - Kibaale Children's Centre - p.o. box 1658 - Masaka, Uganda, East Africa - -Sending money: *iccf-donations* - -Check the ICCF web site for the latest information! See |iccf| for the URL. - - -USA: The methods mentioned below can be used. - Sending a check to the Nehemiah Group Outreach Society (NGOS) - is no longer possible, unfortunately. We are looking for - another way to get you an IRS tax receipt. - For sponsoring a child contact KCF in Canada (see below). US - checks can be sent to them to lower banking costs. - -Canada: Contact Kibaale Children's Fund (KCF) in Surrey, Canada. They - take care of the Canadian sponsors for the children in - Kibaale. KCF forwards 100% of the money to the project in - Uganda. You can send them a one time donation directly. - Please send me a note so that I know what has been donated - because of Vim. Ask KCF for information about sponsorship. - Kibaale Children's Fund c/o Pacific Academy - 10238-168 Street - Surrey, B.C. V4N 1Z4 - Canada - Phone: 604-581-5353 - If you make a donation to Kibaale Children's Fund (KCF) you - will receive a tax receipt which can be submitted with your - tax return. - -Holland: Transfer to the account of "Stichting ICCF Holland" in Venlo. - This will allow for tax deduction if you live in Holland. - Postbank, nr. 4548774 - -Germany: It is possible to make donations that allow for a tax return. - Check the ICCF web site for the latest information: - http://iccf-holland.org/germany.html - -World: Use a postal money order. That should be possible from any - country, mostly from the post office. Use this name (which is - in my passport): "Abraham Moolenaar". Use Euro for the - currency if possible. - -Europe: Use a bank transfer if possible. Your bank should have a form - that you can use for this. See "Others" below for the swift - code and IBAN number. - Any other method should work. Ask for information about - sponsorship. - -Credit Card: You can use PayPal to send money with a Credit card. This is - the most widely used Internet based payment system. It's - really simple to use. Use this link to find more info: - https://www.paypal.com/en_US/mrb/pal=XAC62PML3GF8Q - The e-mail address for sending the money to is: - Bram@iccf-holland.org - For amounts above 400 Euro ($500) sending a check is - preferred. - -Others: Transfer to one of these accounts if possible: - Postbank, account 4548774 - Swift code: INGB NL 2A - IBAN: NL47 PSTB 0004 5487 74 - under the name "stichting ICCF Holland", Venlo - If that doesn't work: - Rabobank Venlo, account 3765.05.117 - Swift code: RABO NL 2U - under the name "Bram Moolenaar", Venlo - Otherwise, send a check in euro or US dollars to the address - below. Minimal amount: $70 (my bank does not accept smaller - amounts for foreign check, sorry) - -Address to send checks to: - stichting ICCF Holland - Bram Moolenaar - Finsterruetihof 1 - 8134 Adliswil - Switzerland - -This address is expected to be valid for a long time. - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/undo.txt b/share/vim/vim72/doc/undo.txt deleted file mode 100644 index c50e6390c5..0000000000 --- a/share/vim/vim72/doc/undo.txt +++ /dev/null @@ -1,242 +0,0 @@ -*undo.txt* For Vim version 7.2. Last change: 2006 Apr 30 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Undo and redo *undo-redo* - -The basics are explained in section |02.5| of the user manual. - -1. Undo and redo commands |undo-commands| -2. Two ways of undo |undo-two-ways| -3. Undo blocks |undo-blocks| -4. Undo branches |undo-branches| -5. Remarks about undo |undo-remarks| - -============================================================================== -1. Undo and redo commands *undo-commands* - -<Undo> or *undo* *<Undo>* *u* -u Undo [count] changes. {Vi: only one level} - - *:u* *:un* *:undo* -:u[ndo] Undo one change. {Vi: only one level} - -:u[ndo] {N} Jump to after change number {N}. See |undo-branches| - for the meaning of {N}. {not in Vi} - - *CTRL-R* -CTRL-R Redo [count] changes which were undone. {Vi: redraw - screen} - - *:red* *:redo* *redo* -:red[o] Redo one change which was undone. {Vi: no redo} - - *U* -U Undo all latest changes on one line. {Vi: while not - moved off of it} - -The last changes are remembered. You can use the undo and redo commands above -to revert the text to how it was before each change. You can also apply the -changes again, getting back the text before the undo. - -The "U" command is treated by undo/redo just like any other command. Thus a -"u" command undoes a "U" command and a 'CTRL-R' command redoes it again. When -mixing "U", "u" and 'CTRL-R' you will notice that the "U" command will -restore the situation of a line to before the previous "U" command. This may -be confusing. Try it out to get used to it. -The "U" command will always mark the buffer as changed. When "U" changes the -buffer back to how it was without changes, it is still considered changed. -Use "u" to undo changes until the buffer becomes unchanged. - -============================================================================== -2. Two ways of undo *undo-two-ways* - -How undo and redo commands work depends on the 'u' flag in 'cpoptions'. -There is the Vim way ('u' excluded) and the vi-compatible way ('u' included). -In the Vim way, "uu" undoes two changes. In the Vi-compatible way, "uu" does -nothing (undoes an undo). - -'u' excluded, the Vim way: -You can go back in time with the undo command. You can then go forward again -with the redo command. If you make a new change after the undo command, -the redo will not be possible anymore. - -'u' included, the Vi-compatible way: -The undo command undoes the previous change, and also the previous undo command. -The redo command repeats the previous undo command. It does NOT repeat a -change command, use "." for that. - -Examples Vim way Vi-compatible way ~ -"uu" two times undo no-op -"u CTRL-R" no-op two times undo - -Rationale: Nvi uses the "." command instead of CTRL-R. Unfortunately, this - is not Vi compatible. For example "dwdwu." in Vi deletes two - words, in Nvi it does nothing. - -============================================================================== -3. Undo blocks *undo-blocks* - -One undo command normally undoes a typed command, no matter how many changes -that command makes. This sequence of undo-able changes forms an undo block. -Thus if the typed key(s) call a function, all the commands in the function are -undone together. - -If you want to write a function or script that doesn't create a new undoable -change but joins in with the previous change use this command: - - *:undoj* *:undojoin* *E790* -:undoj[oin] Join further changes with the previous undo block. - Warning: Use with care, it may prevent the user from - properly undoing changes. Don't use this after undo - or redo. - {not in Vi} - -This is most useful when you need to prompt the user halfway a change. For -example in a function that calls |getchar()|. Do make sure that there was a -related change before this that you must join with. - -This doesn't work by itself, because the next key press will start a new -change again. But you can do something like this: > - - :undojoin | delete - -After this an "u" command will undo the delete command and the previous -change. - -============================================================================== -4. Undo branches *undo-branches* *undo-tree* - -Above we only discussed one line of undo/redo. But it is also possible to -branch off. This happens when you undo a few changes and then make a new -change. The undone changes become a branch. You can go to that branch with -the following commands. - -This is explained in the user manual: |usr_32.txt|. - - *:undol* *:undolist* -:undol[ist] List the leafs in the tree of changes. Example: - number changes time ~ - 4 10 10:34:11 - 18 4 11:01:46 - - The "number" column is the change number. This number - continuously increases and can be used to identify a - specific undo-able change, see |:undo|. - The "changes" column is the number of changes to this - leaf from the root of the tree. - The "time" column is the time this change was made. - - *g-* -g- Go to older text state. With a count repeat that many - times. {not in Vi} - *:ea* *:earlier* -:earlier {count} Go to older text state {count} times. -:earlier {N}s Go to older text state about {N} seconds before. -:earlier {N}m Go to older text state about {N} minutes before. -:earlier {N}h Go to older text state about {N} hours before. - - *g+* -g+ Go to newer text state. With a count repeat that many - times. {not in Vi} - *:lat* *:later* -:later {count} Go to newer text state {count} times. -:later {N}s Go to newer text state about {N} seconds later. -:later {N}m Go to newer text state about {N} minutes later. -:later {N}h Go to newer text state about {N} hours later. - - -Note that text states will become unreachable when undo information is cleared -for 'undolevels'. - -Don't be surprised when moving through time shows multiple changes to take -place at a time. This happens when moving through the undo tree and then -making a new change. - -EXAMPLE - -Start with this text: - one two three ~ - -Delete the first word by pressing "x" three times: - ne two three ~ - e two three ~ - two three ~ - -Now undo that by pressing "u" three times: - e two three ~ - ne two three ~ - one two three ~ - -Delete the second word by pressing "x" three times: - one wo three ~ - one o three ~ - one three ~ - -Now undo that by using "g-" three times: - one o three ~ - one wo three ~ - two three ~ - -You are now back in the first undo branch, after deleting "one". Repeating -"g-" will now bring you back to the original text: - e two three ~ - ne two three ~ - one two three ~ - -Jump to the last change with ":later 1h": - one three ~ - -And back to the start again with ":earlier 1h": - one two three ~ - - -Note that using "u" and CTRL-R will not get you to all possible text states -while repeating "g-" and "g+" does. - -============================================================================== -5. Remarks about undo *undo-remarks* - -The number of changes that are remembered is set with the 'undolevels' option. -If it is zero, the Vi-compatible way is always used. If it is negative no -undo is possible. Use this if you are running out of memory. - -Marks for the buffer ('a to 'z) are also saved and restored, together with the -text. {Vi does this a little bit different} - -When all changes have been undone, the buffer is not considered to be changed. -It is then possible to exit Vim with ":q" instead of ":q!" {not in Vi}. Note -that this is relative to the last write of the file. Typing "u" after ":w" -actually changes the buffer, compared to what was written, so the buffer is -considered changed then. - -When manual |folding| is being used, the folds are not saved and restored. -Only changes completely within a fold will keep the fold as it was, because -the first and last line of the fold don't change. - -The numbered registers can also be used for undoing deletes. Each time you -delete text, it is put into register "1. The contents of register "1 are -shifted to "2, etc. The contents of register "9 are lost. You can now get -back the most recent deleted text with the put command: '"1P'. (also, if the -deleted text was the result of the last delete or copy operation, 'P' or 'p' -also works as this puts the contents of the unnamed register). You can get -back the text of three deletes ago with '"3P'. - - *redo-register* -If you want to get back more than one part of deleted text, you can use a -special feature of the repeat command ".". It will increase the number of the -register used. So if you first do ""1P", the following "." will result in a -'"2P'. Repeating this will result in all numbered registers being inserted. - -Example: If you deleted text with 'dd....' it can be restored with - '"1P....'. - -If you don't know in which register the deleted text is, you can use the -:display command. An alternative is to try the first register with '"1P', and -if it is not what you want do 'u.'. This will remove the contents of the -first put, and repeat the put command for the second register. Repeat the -'u.' until you got what you want. - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_01.txt b/share/vim/vim72/doc/usr_01.txt deleted file mode 100644 index 17fb6b05b1..0000000000 --- a/share/vim/vim72/doc/usr_01.txt +++ /dev/null @@ -1,185 +0,0 @@ -*usr_01.txt* For Vim version 7.2. Last change: 2008 May 07 - - VIM USER MANUAL - by Bram Moolenaar - - About the manuals - - -This chapter introduces the manuals available with Vim. Read this to know the -conditions under which the commands are explained. - -|01.1| Two manuals -|01.2| Vim installed -|01.3| Using the Vim tutor -|01.4| Copyright - - Next chapter: |usr_02.txt| The first steps in Vim -Table of contents: |usr_toc.txt| - -============================================================================== -*01.1* Two manuals - -The Vim documentation consists of two parts: - -1. The User manual - Task oriented explanations, from simple to complex. Reads from start to - end like a book. - -2. The Reference manual - Precise description of how everything in Vim works. - -The notation used in these manuals is explained here: |notation| - - -JUMPING AROUND - -The text contains hyperlinks between the two parts, allowing you to quickly -jump between the description of an editing task and a precise explanation of -the commands and options used for it. Use these two commands: - - Press CTRL-] to jump to a subject under the cursor. - Press CTRL-O to jump back (repeat to go further back). - -Many links are in vertical bars, like this: |bars|. An option name, like -'number', a command in double quotes like ":write" and any other word can also -be used as a link. Try it out: Move the cursor to CTRL-] and press CTRL-] -on it. - -Other subjects can be found with the ":help" command, see |help.txt|. - -============================================================================== -*01.2* Vim installed - -Most of the manuals assume that Vim has been properly installed. If you -didn't do that yet, or if Vim doesn't run properly (e.g., files can't be found -or in the GUI the menus do not show up) first read the chapter on -installation: |usr_90.txt|. - *not-compatible* -The manuals often assume you are using Vim with Vi-compatibility switched -off. For most commands this doesn't matter, but sometimes it is important, -e.g., for multi-level undo. An easy way to make sure you are using a nice -setup is to copy the example vimrc file. By doing this inside Vim you don't -have to check out where it is located. How to do this depends on the system -you are using: - -Unix: > - :!cp -i $VIMRUNTIME/vimrc_example.vim ~/.vimrc -MS-DOS, MS-Windows, OS/2: > - :!copy $VIMRUNTIME/vimrc_example.vim $VIM/_vimrc -Amiga: > - :!copy $VIMRUNTIME/vimrc_example.vim $VIM/.vimrc - -If the file already exists you probably want to keep it. - -If you start Vim now, the 'compatible' option should be off. You can check it -with this command: > - - :set compatible? - -If it responds with "nocompatible" you are doing well. If the response is -"compatible" you are in trouble. You will have to find out why the option is -still set. Perhaps the file you wrote above is not found. Use this command -to find out: > - - :scriptnames - -If your file is not in the list, check its location and name. If it is in the -list, there must be some other place where the 'compatible' option is switched -back on. - -For more info see |vimrc| and |compatible-default|. - - Note: - This manual is about using Vim in the normal way. There is an - alternative called "evim" (easy Vim). This is still Vim, but used in - a way that resembles a click-and-type editor like Notepad. It always - stays in Insert mode, thus it feels very different. It is not - explained in the user manual, since it should be mostly self - explanatory. See |evim-keys| for details. - -============================================================================== -*01.3* Using the Vim tutor *tutor* *vimtutor* - -Instead of reading the text (boring!) you can use the vimtutor to learn your -first Vim commands. This is a 30 minute tutorial that teaches the most basic -Vim functionality hands-on. - -On Unix, if Vim has been properly installed, you can start it from the shell: -> - vimtutor - -On MS-Windows you can find it in the Program/Vim menu. Or execute -vimtutor.bat in the $VIMRUNTIME directory. - -This will make a copy of the tutor file, so that you can edit it without -the risk of damaging the original. - There are a few translated versions of the tutor. To find out if yours is -available, use the two-letter language code. For French: > - - vimtutor fr - -On Unix, if you prefer using the GUI version of Vim, use "gvimtutor" or -"vimtutor -g" instead of "vimtutor". - -For OpenVMS, if Vim has been properly installed, you can start vimtutor from a -VMS prompt with: > - - @VIM:vimtutor - -Optionally add the two-letter language code as above. - - -On other systems, you have to do a little work: - -1. Copy the tutor file. You can do this with Vim (it knows where to find it): -> - vim -u NONE -c 'e $VIMRUNTIME/tutor/tutor' -c 'w! TUTORCOPY' -c 'q' -< - This will write the file "TUTORCOPY" in the current directory. To use a -translated version of the tutor, append the two-letter language code to the -filename. For French: -> - vim -u NONE -c 'e $VIMRUNTIME/tutor/tutor.fr' -c 'w! TUTORCOPY' -c 'q' -< -2. Edit the copied file with Vim: -> - vim -u NONE -c "set nocp" TUTORCOPY -< - The extra arguments make sure Vim is started in a good mood. - -3. Delete the copied file when you are finished with it: -> - del TUTORCOPY -< -============================================================================== -*01.4* Copyright *manual-copyright* - -The Vim user manual and reference manual are Copyright (c) 1988-2003 by Bram -Moolenaar. This material may be distributed only subject to the terms and -conditions set forth in the Open Publication License, v1.0 or later. The -latest version is presently available at: - http://www.opencontent.org/openpub/ - -People who contribute to the manuals must agree with the above copyright -notice. - *frombook* -Parts of the user manual come from the book "Vi IMproved - Vim" by Steve -Oualline (published by New Riders Publishing, ISBN: 0735710015). The Open -Publication License applies to this book. Only selected parts are included -and these have been modified (e.g., by removing the pictures, updating the -text for Vim 6.0 and later, fixing mistakes). The omission of the |frombook| -tag does not mean that the text does not come from the book. - -Many thanks to Steve Oualline and New Riders for creating this book and -publishing it under the OPL! It has been a great help while writing the user -manual. Not only by providing literal text, but also by setting the tone and -style. - -If you make money through selling the manuals, you are strongly encouraged to -donate part of the profit to help AIDS victims in Uganda. See |iccf|. - -============================================================================== - -Next chapter: |usr_02.txt| The first steps in Vim - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_02.txt b/share/vim/vim72/doc/usr_02.txt deleted file mode 100644 index 9124c5cad2..0000000000 --- a/share/vim/vim72/doc/usr_02.txt +++ /dev/null @@ -1,564 +0,0 @@ -*usr_02.txt* For Vim version 7.2. Last change: 2007 Feb 28 - - VIM USER MANUAL - by Bram Moolenaar - - The first steps in Vim - - -This chapter provides just enough information to edit a file with Vim. Not -well or fast, but you can edit. Take some time to practice with these -commands, they form the base for what follows. - -|02.1| Running Vim for the First Time -|02.2| Inserting text -|02.3| Moving around -|02.4| Deleting characters -|02.5| Undo and Redo -|02.6| Other editing commands -|02.7| Getting out -|02.8| Finding help - - Next chapter: |usr_03.txt| Moving around - Previous chapter: |usr_01.txt| About the manuals -Table of contents: |usr_toc.txt| - -============================================================================== -*02.1* Running Vim for the First Time - -To start Vim, enter this command: > - - gvim file.txt - -In UNIX you can type this at any command prompt. If you are running Microsoft -Windows, open an MS-DOS prompt window and enter the command. - In either case, Vim starts editing a file called file.txt. Because this -is a new file, you get a blank window. This is what your screen will look -like: - - +---------------------------------------+ - |# | - |~ | - |~ | - |~ | - |~ | - |"file.txt" [New file] | - +---------------------------------------+ - ('#" is the cursor position.) - -The tilde (~) lines indicate lines not in the file. In other words, when Vim -runs out of file to display, it displays tilde lines. At the bottom of the -screen, a message line indicates the file is named file.txt and shows that you -are creating a new file. The message information is temporary and other -information overwrites it. - - -THE VIM COMMAND - -The gvim command causes the editor to create a new window for editing. If you -use this command: > - - vim file.txt - -the editing occurs inside your command window. In other words, if you are -running inside an xterm, the editor uses your xterm window. If you are using -an MS-DOS command prompt window under Microsoft Windows, the editing occurs -inside this window. The text in the window will look the same for both -versions, but with gvim you have extra features, like a menu bar. More about -that later. - -============================================================================== -*02.2* Inserting text - -The Vim editor is a modal editor. That means that the editor behaves -differently, depending on which mode you are in. The two basic modes are -called Normal mode and Insert mode. In Normal mode the characters you type -are commands. In Insert mode the characters are inserted as text. - Since you have just started Vim it will be in Normal mode. To start Insert -mode you type the "i" command (i for Insert). Then you can enter -the text. It will be inserted into the file. Do not worry if you make -mistakes; you can correct them later. To enter the following programmer's -limerick, this is what you type: > - - iA very intelligent turtle - Found programming UNIX a hurdle - -After typing "turtle" you press the <Enter> key to start a new line. Finally -you press the <Esc> key to stop Insert mode and go back to Normal mode. You -now have two lines of text in your Vim window: - - +---------------------------------------+ - |A very intelligent turtle | - |Found programming UNIX a hurdle | - |~ | - |~ | - | | - +---------------------------------------+ - - -WHAT IS THE MODE? - -To be able to see what mode you are in, type this command: > - - :set showmode - -You will notice that when typing the colon Vim moves the cursor to the last -line of the window. That's where you type colon commands (commands that start -with a colon). Finish this command by pressing the <Enter> key (all commands -that start with a colon are finished this way). - Now, if you type the "i" command Vim will display --INSERT-- at the bottom -of the window. This indicates you are in Insert mode. - - +---------------------------------------+ - |A very intelligent turtle | - |Found programming UNIX a hurdle | - |~ | - |~ | - |-- INSERT -- | - +---------------------------------------+ - -If you press <Esc> to go back to Normal mode the last line will be made blank. - - -GETTING OUT OF TROUBLE - -One of the problems for Vim novices is mode confusion, which is caused by -forgetting which mode you are in or by accidentally typing a command that -switches modes. To get back to Normal mode, no matter what mode you are in, -press the <Esc> key. Sometimes you have to press it twice. If Vim beeps back -at you, you already are in Normal mode. - -============================================================================== -*02.3* Moving around - -After you return to Normal mode, you can move around by using these keys: - - h left *hjkl* - j down - k up - l right - -At first, it may appear that these commands were chosen at random. After all, -who ever heard of using l for right? But actually, there is a very good -reason for these choices: Moving the cursor is the most common thing you do in -an editor, and these keys are on the home row of your right hand. In other -words, these commands are placed where you can type them the fastest -(especially when you type with ten fingers). - - Note: - You can also move the cursor by using the arrow keys. If you do, - however, you greatly slow down your editing because to press the arrow - keys, you must move your hand from the text keys to the arrow keys. - Considering that you might be doing it hundreds of times an hour, this - can take a significant amount of time. - Also, there are keyboards which do not have arrow keys, or which - locate them in unusual places; therefore, knowing the use of the hjkl - keys helps in those situations. - -One way to remember these commands is that h is on the left, l is on the -right and j points down. In a picture: > - - k - h l - j - -The best way to learn these commands is by using them. Use the "i" command to -insert some more lines of text. Then use the hjkl keys to move around and -insert a word somewhere. Don't forget to press <Esc> to go back to Normal -mode. The |vimtutor| is also a nice way to learn by doing. - -For Japanese users, Hiroshi Iwatani suggested using this: - - Komsomolsk - ^ - | - Huan Ho <--- ---> Los Angeles - (Yellow river) | - v - Java (the island, not the programming language) - -============================================================================== -*02.4* Deleting characters - -To delete a character, move the cursor over it and type "x". (This is a -throwback to the old days of the typewriter, when you deleted things by typing -xxxx over them.) Move the cursor to the beginning of the first line, for -example, and type xxxxxxx (seven x's) to delete "A very ". The result should -look like this: - - +---------------------------------------+ - |intelligent turtle | - |Found programming UNIX a hurdle | - |~ | - |~ | - | | - +---------------------------------------+ - -Now you can insert new text, for example by typing: > - - iA young <Esc> - -This begins an insert (the i), inserts the words "A young", and then exits -insert mode (the final <Esc>). The result: - - +---------------------------------------+ - |A young intelligent turtle | - |Found programming UNIX a hurdle | - |~ | - |~ | - | | - +---------------------------------------+ - - -DELETING A LINE - -To delete a whole line use the "dd" command. The following line will -then move up to fill the gap: - - +---------------------------------------+ - |Found programming UNIX a hurdle | - |~ | - |~ | - |~ | - | | - +---------------------------------------+ - - -DELETING A LINE BREAK - -In Vim you can join two lines together, which means that the line break -between them is deleted. The "J" command does this. - Take these two lines: - - A young intelligent ~ - turtle ~ - -Move the cursor to the first line and press "J": - - A young intelligent turtle ~ - -============================================================================== -*02.5* Undo and Redo - -Suppose you delete too much. Well, you can type it in again, but an easier -way exists. The "u" command undoes the last edit. Take a look at this in -action: After using "dd" to delete the first line, "u" brings it back. - Another one: Move the cursor to the A in the first line: - - A young intelligent turtle ~ - -Now type xxxxxxx to delete "A young". The result is as follows: - - intelligent turtle ~ - -Type "u" to undo the last delete. That delete removed the g, so the undo -restores the character. - - g intelligent turtle ~ - -The next u command restores the next-to-last character deleted: - - ng intelligent turtle ~ - -The next u command gives you the u, and so on: - - ung intelligent turtle ~ - oung intelligent turtle ~ - young intelligent turtle ~ - young intelligent turtle ~ - A young intelligent turtle ~ - - Note: - If you type "u" twice, and the result is that you get the same text - back, you have Vim configured to work Vi compatible. Look here to fix - this: |not-compatible|. - This text assumes you work "The Vim Way". You might prefer to use - the good old Vi way, but you will have to watch out for small - differences in the text then. - - -REDO - -If you undo too many times, you can press CTRL-R (redo) to reverse the -preceding command. In other words, it undoes the undo. To see this in -action, press CTRL-R twice. The character A and the space after it disappear: - - young intelligent turtle ~ - -There's a special version of the undo command, the "U" (undo line) command. -The undo line command undoes all the changes made on the last line that was -edited. Typing this command twice cancels the preceding "U". - - A very intelligent turtle ~ - xxxx Delete very - - A intelligent turtle ~ - xxxxxx Delete turtle - - A intelligent ~ - Restore line with "U" - A very intelligent turtle ~ - Undo "U" with "u" - A intelligent ~ - -The "U" command is a change by itself, which the "u" command undoes and CTRL-R -redoes. This might be a bit confusing. Don't worry, with "u" and CTRL-R you -can go to any of the situations you had. More about that in section |32.1|. - -============================================================================== -*02.6* Other editing commands - -Vim has a large number of commands to change the text. See |Q_in| and below. -Here are a few often used ones. - - -APPENDING - -The "i" command inserts a character before the character under the cursor. -That works fine; but what happens if you want to add stuff to the end of the -line? For that you need to insert text after the cursor. This is done with -the "a" (append) command. - For example, to change the line - - and that's not saying much for the turtle. ~ -to - and that's not saying much for the turtle!!! ~ - -move the cursor over to the dot at the end of the line. Then type "x" to -delete the period. The cursor is now positioned at the end of the line on the -e in turtle. Now type > - - a!!!<Esc> - -to append three exclamation points after the e in turtle: - - and that's not saying much for the turtle!!! ~ - - -OPENING UP A NEW LINE - -The "o" command creates a new, empty line below the cursor and puts Vim in -Insert mode. Then you can type the text for the new line. - Suppose the cursor is somewhere in the first of these two lines: - - A very intelligent turtle ~ - Found programming UNIX a hurdle ~ - -If you now use the "o" command and type new text: > - - oThat liked using Vim<Esc> - -The result is: - - A very intelligent turtle ~ - That liked using Vim ~ - Found programming UNIX a hurdle ~ - -The "O" command (uppercase) opens a line above the cursor. - - -USING A COUNT - -Suppose you want to move up nine lines. You can type "kkkkkkkkk" or you can -enter the command "9k". In fact, you can precede many commands with a number. -Earlier in this chapter, for instance, you added three exclamation points to -the end of a line by typing "a!!!<Esc>". Another way to do this is to use the -command "3a!<Esc>". The count of 3 tells the command that follows to triple -its effect. Similarly, to delete three characters, use the command "3x". The -count always comes before the command it applies to. - -============================================================================== -*02.7* Getting out - -To exit, use the "ZZ" command. This command writes the file and exits. - - Note: - Unlike many other editors, Vim does not automatically make a backup - file. If you type "ZZ", your changes are committed and there's no - turning back. You can configure the Vim editor to produce backup - files, see |07.4|. - - -DISCARDING CHANGES - -Sometimes you will make a sequence of changes and suddenly realize you were -better off before you started. Not to worry; Vim has a -quit-and-throw-things-away command. It is: > - - :q! - -Don't forget to press <Enter> to finish the command. - -For those of you interested in the details, the three parts of this command -are the colon (:), which enters Command-line mode; the q command, which tells -the editor to quit; and the override command modifier (!). - The override command modifier is needed because Vim is reluctant to throw -away changes. If you were to just type ":q", Vim would display an error -message and refuse to exit: - - E37: No write since last change (use ! to override) ~ - -By specifying the override, you are in effect telling Vim, "I know that what -I'm doing looks stupid, but I'm a big boy and really want to do this." - -If you want to continue editing with Vim: The ":e!" command reloads the -original version of the file. - -============================================================================== -*02.8* Finding help - -Everything you always wanted to know can be found in the Vim help files. -Don't be afraid to ask! - To get generic help use this command: > - - :help - -You could also use the first function key <F1>. If your keyboard has a <Help> -key it might work as well. - If you don't supply a subject, ":help" displays the general help window. -The creators of Vim did something very clever (or very lazy) with the help -system: They made the help window a normal editing window. You can use all -the normal Vim commands to move through the help information. Therefore h, j, -k, and l move left, down, up and right. - To get out of the help window, use the same command you use to get out of -the editor: "ZZ". This will only close the help window, not exit Vim. - -As you read the help text, you will notice some text enclosed in vertical bars -(for example, |help|). This indicates a hyperlink. If you position the -cursor anywhere between the bars and press CTRL-] (jump to tag), the help -system takes you to the indicated subject. (For reasons not discussed here, -the Vim terminology for a hyperlink is tag. So CTRL-] jumps to the location -of the tag given by the word under the cursor.) - After a few jumps, you might want to go back. CTRL-T (pop tag) takes you -back to the preceding position. CTRL-O (jump to older position) also works -nicely here. - At the top of the help screen, there is the notation *help.txt*. This name -between "*" characters is used by the help system to define a tag (hyperlink -destination). - See |29.1| for details about using tags. - -To get help on a given subject, use the following command: > - - :help {subject} - -To get help on the "x" command, for example, enter the following: > - - :help x - -To find out how to delete text, use this command: > - - :help deleting - -To get a complete index of all Vim commands, use the following command: > - - :help index - -When you need to get help for a control character command (for example, -CTRL-A), you need to spell it with the prefix "CTRL-". > - - :help CTRL-A - -The Vim editor has many different modes. By default, the help system displays -the normal-mode commands. For example, the following command displays help -for the normal-mode CTRL-H command: > - - :help CTRL-H - -To identify other modes, use a mode prefix. If you want the help for the -insert-mode version of a command, use "i_". For CTRL-H this gives you the -following command: > - - :help i_CTRL-H - -When you start the Vim editor, you can use several command-line arguments. -These all begin with a dash (-). To find what the -t argument does, for -example, use the command: > - - :help -t - -The Vim editor has a number of options that enable you to configure and -customize the editor. If you want help for an option, you need to enclose it -in single quotation marks. To find out what the 'number' option does, for -example, use the following command: > - - :help 'number' - -The table with all mode prefixes can be found here: |help-context|. - -Special keys are enclosed in angle brackets. To find help on the up-arrow key -in Insert mode, for instance, use this command: > - - :help i_<Up> - -If you see an error message that you don't understand, for example: - - E37: No write since last change (use ! to override) ~ - -You can use the error ID at the start to find help about it: > - - :help E37 - - -Summary: *help-summary* > - :help -< Gives you very general help. Scroll down to see a list of all - helpfiles, including those added locally (i.e. not distributed - with Vim). > - :help user-toc.txt -< Table of contents of the User Manual. > - :help :subject -< Ex-command "subject", for instance the following: > - :help :help -< Help on getting help. > - :help abc -< normal-mode command "abc". > - :help CTRL-B -< Control key <C-B> in Normal mode. > - :help i_abc - :help i_CTRL-B -< The same in Insert mode. > - :help v_abc - :help v_CTRL-B -< The same in Visual mode. > - :help c_abc - :help c_CTRL-B -< The same in Command-line mode. > - :help 'subject' -< Option 'subject'. > - :help subject() -< Function "subject". > - :help -subject -< Command-line option "-subject". > - :help +subject -< Compile-time feature "+subject'. > - :help EventName -< Autocommand event "EventName". > - :help digraphs.txt -< The top of the helpfile "digraph.txt". - Similarly for any other helpfile. > - :help pattern<Tab> -< Find a help tag starting with "pattern". Repeat <Tab> for - others. > - :help pattern<Ctrl-D> -< See all possible help tag matches "pattern" at once. > - :helpgrep pattern -< Search the whole text of all help files for pattern "pattern". - Jumps to the first match. Jump to other matches with: > - :cn -< next match > - :cprev - :cN -< previous match > - :cfirst - :clast -< first or last match > - :copen - :cclose -< open/close the quickfix window; press <Enter> to jump - to the item under the cursor - - -============================================================================== - -Next chapter: |usr_03.txt| Moving around - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_03.txt b/share/vim/vim72/doc/usr_03.txt deleted file mode 100644 index 30a6eea7aa..0000000000 --- a/share/vim/vim72/doc/usr_03.txt +++ /dev/null @@ -1,654 +0,0 @@ -*usr_03.txt* For Vim version 7.2. Last change: 2006 Jun 21 - - VIM USER MANUAL - by Bram Moolenaar - - Moving around - - -Before you can insert or delete text the cursor has to be moved to the right -place. Vim has a large number of commands to position the cursor. This -chapter shows you how to use the most important ones. You can find a list of -these commands below |Q_lr|. - -|03.1| Word movement -|03.2| Moving to the start or end of a line -|03.3| Moving to a character -|03.4| Matching a parenthesis -|03.5| Moving to a specific line -|03.6| Telling where you are -|03.7| Scrolling around -|03.8| Simple searches -|03.9| Simple search patterns -|03.10| Using marks - - Next chapter: |usr_04.txt| Making small changes - Previous chapter: |usr_02.txt| The first steps in Vim -Table of contents: |usr_toc.txt| - -============================================================================== -*03.1* Word movement - -To move the cursor forward one word, use the "w" command. Like most Vim -commands, you can use a numeric prefix to move past multiple words. For -example, "3w" moves three words. This figure shows how it works: - - This is a line with example text ~ - --->-->->-----------------> - w w w 3w - -Notice that "w" moves to the start of the next word if it already is at the -start of a word. - The "b" command moves backward to the start of the previous word: - - This is a line with example text ~ - <----<--<-<---------<--- - b b b 2b b - -There is also the "e" command that moves to the next end of a word and "ge", -which moves to the previous end of a word: - - This is a line with example text ~ - <- <--- -----> ----> - ge ge e e - -If you are at the last word of a line, the "w" command will take you to the -first word in the next line. Thus you can use this to move through a -paragraph, much faster than using "l". "b" does the same in the other -direction. - -A word ends at a non-word character, such as a ".", "-" or ")". To change -what Vim considers to be a word, see the 'iskeyword' option. - It is also possible to move by white-space separated WORDs. This is not a -word in the normal sense, that's why the uppercase is used. The commands for -moving by WORDs are also uppercase, as this figure shows: - - ge b w e - <- <- ---> ---> - This is-a line, with special/separated/words (and some more). ~ - <----- <----- --------------------> -----> - gE B W E - -With this mix of lowercase and uppercase commands, you can quickly move -forward and backward through a paragraph. - -============================================================================== -*03.2* Moving to the start or end of a line - -The "$" command moves the cursor to the end of a line. If your keyboard has -an <End> key it will do the same thing. - -The "^" command moves to the first non-blank character of the line. The "0" -command (zero) moves to the very first character of the line. The <Home> key -does the same thing. In a picture: - - ^ - <------------ - .....This is a line with example text ~ - <----------------- ---------------> - 0 $ - -(the "....." indicates blanks here) - - The "$" command takes a count, like most movement commands. But moving to -the end of the line several times doesn't make sense. Therefore it causes the -editor to move to the end of another line. For example, "1$" moves you to -the end of the first line (the one you're on), "2$" to the end of the next -line, and so on. - The "0" command doesn't take a count argument, because the "0" would be -part of the count. Unexpectedly, using a count with "^" doesn't have any -effect. - -============================================================================== -*03.3* Moving to a character - -One of the most useful movement commands is the single-character search -command. The command "fx" searches forward in the line for the single -character x. Hint: "f" stands for "Find". - For example, you are at the beginning of the following line. Suppose you -want to go to the h of human. Just execute the command "fh" and the cursor -will be positioned over the h: - - To err is human. To really foul up you need a computer. ~ - ---------->---------------> - fh fy - -This also shows that the command "fy" moves to the end of the word really. - You can specify a count; therefore, you can go to the "l" of "foul" with -"3fl": - - To err is human. To really foul up you need a computer. ~ - ---------------------> - 3fl - -The "F" command searches to the left: - - To err is human. To really foul up you need a computer. ~ - <--------------------- - Fh - -The "tx" command works like the "fx" command, except it stops one character -before the searched character. Hint: "t" stands for "To". The backward -version of this command is "Tx". - - To err is human. To really foul up you need a computer. ~ - <------------ -------------> - Th tn - -These four commands can be repeated with ";". "," repeats in the other -direction. The cursor is never moved to another line. Not even when the -sentence continues. - -Sometimes you will start a search, only to realize that you have typed the -wrong command. You type "f" to search backward, for example, only to realize -that you really meant "F". To abort a search, press <Esc>. So "f<Esc>" is an -aborted forward search and doesn't do anything. Note: <Esc> cancels most -operations, not just searches. - -============================================================================== -*03.4* Matching a parenthesis - -When writing a program you often end up with nested () constructs. Then the -"%" command is very handy: It moves to the matching paren. If the cursor is -on a "(" it will move to the matching ")". If it's on a ")" it will move to -the matching "(". - - % - <-----> - if (a == (b * c) / d) ~ - <----------------> - % - -This also works for [] and {} pairs. (This can be defined with the -'matchpairs' option.) - -When the cursor is not on a useful character, "%" will search forward to find -one. Thus if the cursor is at the start of the line of the previous example, -"%" will search forward and find the first "(". Then it moves to its match: - - if (a == (b * c) / d) ~ - ---+----------------> - % - -============================================================================== -*03.5* Moving to a specific line - -If you are a C or C++ programmer, you are familiar with error messages such as -the following: - - prog.c:33: j undeclared (first use in this function) ~ - -This tells you that you might want to fix something on line 33. So how do you -find line 33? One way is to do "9999k" to go to the top of the file and "32j" -to go down thirty two lines. It is not a good way, but it works. A much -better way of doing things is to use the "G" command. With a count, this -command positions you at the given line number. For example, "33G" puts you -on line 33. (For a better way of going through a compiler's error list, see -|usr_30.txt|, for information on the :make command.) - With no argument, "G" positions you at the end of the file. A quick way to -go to the start of a file use "gg". "1G" will do the same, but is a tiny bit -more typing. - - | first line of a file ^ - | text text text text | - | text text text text | gg - 7G | text text text text | - | text text text text - | text text text text - V text text text text | - text text text text | G - text text text text | - last line of a file V - -Another way to move to a line is using the "%" command with a count. For -example "50%" moves you to halfway the file. "90%" goes to near the end. - -The previous assumes that you want to move to a line in the file, no matter if -it's currently visible or not. What if you want to move to one of the lines -you can see? This figure shows the three commands you can use: - - +---------------------------+ - H --> | text sample text | - | sample text | - | text sample text | - | sample text | - M --> | text sample text | - | sample text | - | text sample text | - | sample text | - L --> | text sample text | - +---------------------------+ - -Hints: "H" stands for Home, "M" for Middle and "L" for Last. - -============================================================================== -*03.6* Telling where you are - -To see where you are in a file, there are three ways: - -1. Use the CTRL-G command. You get a message like this (assuming the 'ruler' - option is off): - - "usr_03.txt" line 233 of 650 --35%-- col 45-52 ~ - - This shows the name of the file you are editing, the line number where the - cursor is, the total number of lines, the percentage of the way through - the file and the column of the cursor. - Sometimes you will see a split column number. For example, "col 2-9". - This indicates that the cursor is positioned on the second character, but - because character one is a tab, occupying eight spaces worth of columns, - the screen column is 9. - -2. Set the 'number' option. This will display a line number in front of - every line: > - - :set number -< - To switch this off again: > - - :set nonumber -< - Since 'number' is a boolean option, prepending "no" to its name has the - effect of switching it off. A boolean option has only these two values, - it is either on or off. - Vim has many options. Besides the boolean ones there are options with - a numerical value and string options. You will see examples of this where - they are used. - -3. Set the 'ruler' option. This will display the cursor position in the - lower right corner of the Vim window: > - - :set ruler - -Using the 'ruler' option has the advantage that it doesn't take much room, -thus there is more space for your text. - -============================================================================== -*03.7* Scrolling around - -The CTRL-U command scrolls down half a screen of text. Think of looking -through a viewing window at the text and moving this window up by half the -height of the window. Thus the window moves up over the text, which is -backward in the file. Don't worry if you have a little trouble remembering -which end is up. Most users have the same problem. - The CTRL-D command moves the viewing window down half a screen in the file, -thus scrolls the text up half a screen. - - +----------------+ - | some text | - | some text | - | some text | - +---------------+ | some text | - | some text | CTRL-U --> | | - | | | 123456 | - | 123456 | +----------------+ - | 7890 | - | | +----------------+ - | example | CTRL-D --> | 7890 | - +---------------+ | | - | example | - | example | - | example | - | example | - +----------------+ - -To scroll one line at a time use CTRL-E (scroll up) and CTRL-Y (scroll down). -Think of CTRL-E to give you one line Extra. (If you use MS-Windows compatible -key mappings CTRL-Y will redo a change instead of scroll.) - -To scroll forward by a whole screen (except for two lines) use CTRL-F. The -other way is backward, CTRL-B is the command to use. Fortunately CTRL-F is -Forward and CTRL-B is Backward, that's easy to remember. - -A common issue is that after moving down many lines with "j" your cursor is at -the bottom of the screen. You would like to see the context of the line with -the cursor. That's done with the "zz" command. - - +------------------+ +------------------+ - | some text | | some text | - | some text | | some text | - | some text | | some text | - | some text | zz --> | line with cursor | - | some text | | some text | - | some text | | some text | - | line with cursor | | some text | - +------------------+ +------------------+ - -The "zt" command puts the cursor line at the top, "zb" at the bottom. There -are a few more scrolling commands, see |Q_sc|. To always keep a few lines of -context around the cursor, use the 'scrolloff' option. - -============================================================================== -*03.8* Simple searches - -To search for a string, use the "/string" command. To find the word include, -for example, use the command: > - - /include - -You will notice that when you type the "/" the cursor jumps to the last line -of the Vim window, like with colon commands. That is where you type the word. -You can press the backspace key (backarrow or <BS>) to make corrections. Use -the <Left> and <Right> cursor keys when necessary. - Pressing <Enter> executes the command. - - Note: - The characters .*[]^%/\?~$ have special meanings. If you want to use - them in a search you must put a \ in front of them. See below. - -To find the next occurrence of the same string use the "n" command. Use this -to find the first #include after the cursor: > - - /#include - -And then type "n" several times. You will move to each #include in the text. -You can also use a count if you know which match you want. Thus "3n" finds -the third match. Using a count with "/" doesn't work. - -The "?" command works like "/" but searches backwards: > - - ?word - -The "N" command repeats the last search the opposite direction. Thus using -"N" after a "/" command search backwards, using "N" after "?" searches -forward. - - -IGNORING CASE - -Normally you have to type exactly what you want to find. If you don't care -about upper or lowercase in a word, set the 'ignorecase' option: > - - :set ignorecase - -If you now search for "word", it will also match "Word" and "WORD". To match -case again: > - - :set noignorecase - - -HISTORY - -Suppose you do three searches: > - - /one - /two - /three - -Now let's start searching by typing a simple "/" without pressing <Enter>. If -you press <Up> (the cursor key), Vim puts "/three" on the command line. -Pressing <Enter> at this point searches for three. If you do not press -<Enter>, but press <Up> instead, Vim changes the prompt to "/two". Another -press of <Up> moves you to "/one". - You can also use the <Down> cursor key to move through the history of -search commands in the other direction. - -If you know what a previously used pattern starts with, and you want to use it -again, type that character before pressing <Up>. With the previous example, -you can type "/o<Up>" and Vim will put "/one" on the command line. - -The commands starting with ":" also have a history. That allows you to recall -a previous command and execute it again. These two histories are separate. - - -SEARCHING FOR A WORD IN THE TEXT - -Suppose you see the word "TheLongFunctionName" in the text and you want to -find the next occurrence of it. You could type "/TheLongFunctionName", but -that's a lot of typing. And when you make a mistake Vim won't find it. - There is an easier way: Position the cursor on the word and use the "*" -command. Vim will grab the word under the cursor and use it as the search -string. - The "#" command does the same in the other direction. You can prepend a -count: "3*" searches for the third occurrence of the word under the cursor. - - -SEARCHING FOR WHOLE WORDS - -If you type "/the" it will also match "there". To only find words that end -in "the" use: > - - /the\> - -The "\>" item is a special marker that only matches at the end of a word. -Similarly "\<" only matches at the begin of a word. Thus to search for the -word "the" only: > - - /\<the\> - -This does not match "there" or "soothe". Notice that the "*" and "#" commands -use these start-of-word and end-of-word markers to only find whole words (you -can use "g*" and "g#" to match partial words). - - -HIGHLIGHTING MATCHES - -While editing a program you see a variable called "nr". You want to check -where it's used. You could move the cursor to "nr" and use the "*" command -and press "n" to go along all the matches. - There is another way. Type this command: > - - :set hlsearch - -If you now search for "nr", Vim will highlight all matches. That is a very -good way to see where the variable is used, without the need to type commands. - To switch this off: > - - :set nohlsearch - -Then you need to switch it on again if you want to use it for the next search -command. If you only want to remove the highlighting, use this command: > - - :nohlsearch - -This doesn't reset the option. Instead, it disables the highlighting. As -soon as you execute a search command, the highlighting will be used again. -Also for the "n" and "N" commands. - - -TUNING SEARCHES - -There are a few options that change how searching works. These are the -essential ones: -> - :set incsearch - -This makes Vim display the match for the string while you are still typing it. -Use this to check if the right match will be found. Then press <Enter> to -really jump to that location. Or type more to change the search string. -> - :set nowrapscan - -This stops the search at the end of the file. Or, when you are searching -backwards, at the start of the file. The 'wrapscan' option is on by default, -thus searching wraps around the end of the file. - - -INTERMEZZO - -If you like one of the options mentioned before, and set it each time you use -Vim, you can put the command in your Vim startup file. - Edit the file, as mentioned at |not-compatible|. Or use this command to -find out where it is: > - - :scriptnames - -Edit the file, for example with: > - - :edit ~/.vimrc - -Then add a line with the command to set the option, just like you typed it in -Vim. Example: > - - Go:set hlsearch<Esc> - -"G" moves to the end of the file. "o" starts a new line, where you type the -":set" command. You end insert mode with <Esc>. Then write the file: > - - ZZ - -If you now start Vim again, the 'hlsearch' option will already be set. - -============================================================================== -*03.9* Simple search patterns - -The Vim editor uses regular expressions to specify what to search for. -Regular expressions are an extremely powerful and compact way to specify a -search pattern. Unfortunately, this power comes at a price, because regular -expressions are a bit tricky to specify. - In this section we mention only a few essential ones. More about search -patterns and commands in chapter 27 |usr_27.txt|. You can find the full -explanation here: |pattern|. - - -BEGINNING AND END OF A LINE - -The ^ character matches the beginning of a line. On an English-US keyboard -you find it above the 6. The pattern "include" matches the word include -anywhere on the line. But the pattern "^include" matches the word include -only if it is at the beginning of a line. - The $ character matches the end of a line. Therefore, "was$" matches the -word was only if it is at the end of a line. - -Let's mark the places where "the" matches in this example line with "x"s: - - the solder holding one of the chips melted and the ~ - xxx xxx xxx - -Using "/the$" we find this match: - - the solder holding one of the chips melted and the ~ - xxx - -And with "/^the" we find this one: - the solder holding one of the chips melted and the ~ - xxx - -You can try searching with "/^the$", it will only match a single line -consisting of "the". White space does matter here, thus if a line contains a -space after the word, like "the ", the pattern will not match. - - -MATCHING ANY SINGLE CHARACTER - -The . (dot) character matches any existing character. For example, the -pattern "c.m" matches a string whose first character is a c, whose second -character is anything, and whose the third character is m. Example: - - We use a computer that became the cummin winter. ~ - xxx xxx xxx - - -MATCHING SPECIAL CHARACTERS - -If you really want to match a dot, you must avoid its special meaning by -putting a backslash before it. - If you search for "ter.", you will find these matches: - - We use a computer that became the cummin winter. ~ - xxxx xxxx - -Searching for "ter\." only finds the second match. - -============================================================================== -*03.10* Using marks - -When you make a jump to a position with the "G" command, Vim remembers the -position from before this jump. This position is called a mark. To go back -where you came from, use this command: > - - `` - -This ` is a backtick or open single-quote character. - If you use the same command a second time you will jump back again. That's -because the ` command is a jump itself, and the position from before this jump -is remembered. - -Generally, every time you do a command that can move the cursor further than -within the same line, this is called a jump. This includes the search -commands "/" and "n" (it doesn't matter how far away the match is). But not -the character searches with "fx" and "tx" or the word movements "w" and "e". - Also, "j" and "k" are not considered to be a jump. Even when you use a -count to make them move the cursor quite a long way away. - -The `` command jumps back and forth, between two points. The CTRL-O command -jumps to older positions (Hint: O for older). CTRL-I then jumps back to newer -positions (Hint: I is just next to O on the keyboard). Consider this sequence -of commands: > - - 33G - /^The - CTRL-O - -You first jump to line 33, then search for a line that starts with "The". -Then with CTRL-O you jump back to line 33. Another CTRL-O takes you back to -where you started. If you now use CTRL-I you jump to line 33 again. And -to the match for "The" with another CTRL-I. - - - | example text ^ | - 33G | example text | CTRL-O | CTRL-I - | example text | | - V line 33 text ^ V - | example text | | - /^The | example text | CTRL-O | CTRL-I - V There you are | V - example text - - Note: - CTRL-I is the same as <Tab>. - -The ":jumps" command gives a list of positions you jumped to. The entry which -you used last is marked with a ">". - - -NAMED MARKS *bookmark* - -Vim enables you to place your own marks in the text. The command "ma" marks -the place under the cursor as mark a. You can place 26 marks (a through z) in -your text. You can't see them, it's just a position that Vim remembers. - To go to a mark, use the command `{mark}, where {mark} is the mark letter. -Thus to move to the a mark: -> - `a - -The command 'mark (single quotation mark, or apostrophe) moves you to the -beginning of the line containing the mark. This differs from the `mark -command, which moves you to marked column. - -The marks can be very useful when working on two related parts in a file. -Suppose you have some text near the start of the file you need to look at, -while working on some text near the end of the file. - Move to the text at the start and place the s (start) mark there: > - - ms - -Then move to the text you want to work on and put the e (end) mark there: > - - me - -Now you can move around, and when you want to look at the start of the file, -you use this to jump there: > - - 's - -Then you can use '' to jump back to where you were, or 'e to jump to the text -you were working on at the end. - There is nothing special about using s for start and e for end, they are -just easy to remember. - -You can use this command to get a list of marks: > - - :marks - -You will notice a few special marks. These include: - - ' The cursor position before doing a jump - " The cursor position when last editing the file - [ Start of the last change - ] End of the last change - -============================================================================== - -Next chapter: |usr_04.txt| Making small changes - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_04.txt b/share/vim/vim72/doc/usr_04.txt deleted file mode 100644 index d1af10d63e..0000000000 --- a/share/vim/vim72/doc/usr_04.txt +++ /dev/null @@ -1,514 +0,0 @@ -*usr_04.txt* For Vim version 7.2. Last change: 2006 Jun 21 - - VIM USER MANUAL - by Bram Moolenaar - - Making small changes - - -This chapter shows you several ways of making corrections and moving text -around. It teaches you the three basic ways to change text: operator-motion, -Visual mode and text objects. - -|04.1| Operators and motions -|04.2| Changing text -|04.3| Repeating a change -|04.4| Visual mode -|04.5| Moving text -|04.6| Copying text -|04.7| Using the clipboard -|04.8| Text objects -|04.9| Replace mode -|04.10| Conclusion - - Next chapter: |usr_05.txt| Set your settings - Previous chapter: |usr_03.txt| Moving around -Table of contents: |usr_toc.txt| - -============================================================================== -*04.1* Operators and motions - -In chapter 2 you learned the "x" command to delete a single character. And -using a count: "4x" deletes four characters. - The "dw" command deletes a word. You may recognize the "w" command as the -move word command. In fact, the "d" command may be followed by any motion -command, and it deletes from the current location to the place where the -cursor winds up. - The "4w" command, for example, moves the cursor over four words. The d4w -command deletes four words. - - To err is human. To really foul up you need a computer. ~ - ------------------> - d4w - - To err is human. you need a computer. ~ - -Vim only deletes up to the position where the motion takes the cursor. That's -because Vim knows that you probably don't want to delete the first character -of a word. If you use the "e" command to move to the end of a word, Vim -guesses that you do want to include that last character: - - To err is human. you need a computer. ~ - --------> - d2e - - To err is human. a computer. ~ - -Whether the character under the cursor is included depends on the command you -used to move to that character. The reference manual calls this "exclusive" -when the character isn't included and "inclusive" when it is. - -The "$" command moves to the end of a line. The "d$" command deletes from the -cursor to the end of the line. This is an inclusive motion, thus the last -character of the line is included in the delete operation: - - To err is human. a computer. ~ - ------------> - d$ - - To err is human ~ - -There is a pattern here: operator-motion. You first type an operator command. -For example, "d" is the delete operator. Then you type a motion command like -"4l" or "w". This way you can operate on any text you can move over. - -============================================================================== -*04.2* Changing text - -Another operator is "c", change. It acts just like the "d" operator, except -it leaves you in Insert mode. For example, "cw" changes a word. Or more -specifically, it deletes a word and then puts you in Insert mode. - - To err is human ~ - -------> - c2wbe<Esc> - - To be human ~ - -This "c2wbe<Esc>" contains these bits: - - c the change operator - 2w move two words (they are deleted and Insert mode started) - be insert this text - <Esc> back to Normal mode - -If you have paid attention, you will have noticed something strange: The space -before "human" isn't deleted. There is a saying that for every problem there -is an answer that is simple, clear, and wrong. That is the case with the -example used here for the "cw" command. The c operator works just like the -d operator, with one exception: "cw". It actually works like "ce", change to -end of word. Thus the space after the word isn't included. This is an -exception that dates back to the old Vi. Since many people are used to it -now, the inconsistency has remained in Vim. - - -MORE CHANGES - -Like "dd" deletes a whole line, "cc" changes a whole line. It keeps the -existing indent (leading white space) though. - -Just like "d$" deletes until the end of the line, "c$" changes until the end -of the line. It's like doing "d$" to delete the text and then "a" to start -Insert mode and append new text. - - -SHORTCUTS - -Some operator-motion commands are used so often that they have been given a -single letter command: - - x stands for dl (delete character under the cursor) - X stands for dh (delete character left of the cursor) - D stands for d$ (delete to end of the line) - C stands for c$ (change to end of the line) - s stands for cl (change one character) - S stands for cc (change a whole line) - - -WHERE TO PUT THE COUNT - -The commands "3dw" and "d3w" delete three words. If you want to get really -picky about things, the first command, "3dw", deletes one word three times; -the command "d3w" deletes three words once. This is a difference without a -distinction. You can actually put in two counts, however. For example, -"3d2w" deletes two words, repeated three times, for a total of six words. - - -REPLACING WITH ONE CHARACTER - -The "r" command is not an operator. It waits for you to type a character, and -will replace the character under the cursor with it. You could do the same -with "cl" or with the "s" command, but with "r" you don't have to press <Esc> - - there is somerhing grong here ~ - rT rt rw - - There is something wrong here ~ - -Using a count with "r" causes that many characters to be replaced with the -same character. Example: - - There is something wrong here ~ - 5rx - - There is something xxxxx here ~ - -To replace a character with a line break use "r<Enter>". This deletes one -character and inserts a line break. Using a count here only applies to the -number of characters deleted: "4r<Enter>" replaces four characters with one -line break. - -============================================================================== -*04.3* Repeating a change - -The "." command is one of the most simple yet powerful commands in Vim. It -repeats the last change. For instance, suppose you are editing an HTML file -and want to delete all the <B> tags. You position the cursor on the first < -and delete the <B> with the command "df>". You then go to the < of the next -</B> and kill it using the "." command. The "." command executes the last -change command (in this case, "df>"). To delete another tag, position the -cursor on the < and use the "." command. - - To <B>generate</B> a table of <B>contents ~ - f< find first < ---> - df> delete to > --> - f< find next < ---------> - . repeat df> ---> - f< find next < -------------> - . repeat df> --> - -The "." command works for all changes you make, except for the "u" (undo), -CTRL-R (redo) and commands that start with a colon (:). - -Another example: You want to change the word "four" to "five". It appears -several times in your text. You can do this quickly with this sequence of -commands: - - /four<Enter> find the first string "four" - cwfive<Esc> change the word to "five" - n find the next "four" - . repeat the change to "five' - n find the next "four" - . repeat the change - etc. - -============================================================================== -*04.4* Visual mode - -To delete simple items the operator-motion changes work quite well. But often -it's not so easy to decide which command will move over the text you want to -change. Then you can use Visual mode. - -You start Visual mode by pressing "v". You move the cursor over the text you -want to work on. While you do this, the text is highlighted. Finally type -the operator command. - For example, to delete from halfway one word to halfway another word: - - This is an examination sample of visual mode ~ - ----------> - velllld - - This is an example of visual mode ~ - -When doing this you don't really have to count how many times you have to -press "l" to end up in the right position. You can immediately see what text -will be deleted when you press "d". - -If at any time you decide you don't want to do anything with the highlighted -text, just press <Esc> and Visual mode will stop without doing anything. - - -SELECTING LINES - -If you want to work on whole lines, use "V" to start Visual mode. You will -see right away that the whole line is highlighted, without moving around. -When you move left or right nothing changes. When you move up or down the -selection is extended whole lines at a time. - For example, select three lines with "Vjj": - - +------------------------+ - | text more text | - >> | more text more text | | - selected lines >> | text text text | | Vjj - >> | text more | V - | more text more | - +------------------------+ - - -SELECTING BLOCKS - -If you want to work on a rectangular block of characters, use CTRL-V to start -Visual mode. This is very useful when working on tables. - - name Q1 Q2 Q3 - pierre 123 455 234 - john 0 90 39 - steve 392 63 334 - -To delete the middle "Q2" column, move the cursor to the "Q" of "Q2". Press -CTRL-V to start blockwise Visual mode. Now move the cursor three lines down -with "3j" and to the next word with "w". You can see the first character of -the last column is included. To exclude it, use "h". Now press "d" and the -middle column is gone. - - -GOING TO THE OTHER SIDE - -If you have selected some text in Visual mode, and discover that you need to -change the other end of the selection, use the "o" command (Hint: o for other -end). The cursor will go to the other end, and you can move the cursor to -change where the selection starts. Pressing "o" again brings you back to the -other end. - -When using blockwise selection, you have four corners. "o" only takes you to -one of the other corners, diagonally. Use "O" to move to the other corner in -the same line. - -Note that "o" and "O" in Visual mode work very different from Normal mode, -where they open a new line below or above the cursor. - -============================================================================== -*04.5* Moving text - -When you delete something with the "d", "x", or another command, the text is -saved. You can paste it back by using the p command. (The Vim name for -this is put). - Take a look at how this works. First you will delete an entire line, by -putting the cursor on the line you want to delete and typing "dd". Now you -move the cursor to where you want to put the line and use the "p" (put) -command. The line is inserted on the line below the cursor. - - a line a line a line - line 2 dd line 3 p line 3 - line 3 line 2 - -Because you deleted an entire line, the "p" command placed the text line below -the cursor. If you delete part of a line (a word, for instance), the "p" -command puts it just after the cursor. - - Some more boring try text to out commands. ~ - ----> - dw - - Some more boring text to out commands. ~ - -------> - welp - - Some more boring text to try out commands. ~ - - -MORE ON PUTTING - -The "P" command puts text like "p", but before the cursor. When you deleted a -whole line with "dd", "P" will put it back above the cursor. When you deleted -a word with "dw", "P" will put it back just before the cursor. - -You can repeat putting as many times as you like. The same text will be used. - -You can use a count with "p" and "P". The text will be repeated as many times -as specified with the count. Thus "dd" and then "3p" puts three copies of the -same deleted line. - - -SWAPPING TWO CHARACTERS - -Frequently when you are typing, your fingers get ahead of your brain (or the -other way around?). The result is a typo such as "teh" for "the". Vim -makes it easy to correct such problems. Just put the cursor on the e of "teh" -and execute the command "xp". This works as follows: "x" deletes the -character e and places it in a register. "p" puts the text after the cursor, -which is after the h. - - teh th the ~ - x p - -============================================================================== -*04.6* Copying text - -To copy text from one place to another, you could delete it, use "u" to undo -the deletion and then "p" to put it somewhere else. There is an easier way: -yanking. The "y" operator copies text into a register. Then a "p" command -can be used to put it. - Yanking is just a Vim name for copying. The "c" letter was already used -for the change operator, and "y" was still available. Calling this -operator "yank" made it easier to remember to use the "y" key. - -Since "y" is an operator, you use "yw" to yank a word. A count is possible as -usual. To yank two words use "y2w". Example: - - let sqr = LongVariable * ~ - --------------> - y2w - - let sqr = LongVariable * ~ - p - - let sqr = LongVariable * LongVariable ~ - -Notice that "yw" includes the white space after a word. If you don't want -this, use "ye". - -The "yy" command yanks a whole line, just like "dd" deletes a whole line. -Unexpectedly, while "D" deletes from the cursor to the end of the line, "Y" -works like "yy", it yanks the whole line. Watch out for this inconsistency! -Use "y$" to yank to the end of the line. - - a text line yy a text line a text line - line 2 line 2 p line 2 - last line last line a text line - last line - -============================================================================== -*04.7* Using the clipboard - -If you are using the GUI version of Vim (gvim), you can find the "Copy" item -in the "Edit" menu. First select some text with Visual mode, then use the -Edit/Copy menu. The selected text is now copied to the clipboard. You can -paste the text in other programs. In Vim itself too. - -If you have copied text to the clipboard in another application, you can paste -it in Vim with the Edit/Paste menu. This works in Normal mode and Insert -mode. In Visual mode the selected text is replaced with the pasted text. - -The "Cut" menu item deletes the text before it's put on the clipboard. The -"Copy", "Cut" and "Paste" items are also available in the popup menu (only -when there is a popup menu, of course). If your Vim has a toolbar, you can -also find these items there. - -If you are not using the GUI, or if you don't like using a menu, you have to -use another way. You use the normal "y" (yank) and "p" (put) commands, but -prepend "* (double-quote star) before it. To copy a line to the clipboard: > - - "*yy - -To put text from the clipboard back into the text: > - - "*p - -This only works on versions of Vim that include clipboard support. More about -the clipboard in section |09.3| and here: |clipboard|. - -============================================================================== -*04.8* Text objects - -If the cursor is in the middle of a word and you want to delete that word, you -need to move back to its start before you can do "dw". There is a simpler way -to do this: "daw". - - this is some example text. ~ - daw - - this is some text. ~ - -The "d" of "daw" is the delete operator. "aw" is a text object. Hint: "aw" -stands for "A Word". Thus "daw" is "Delete A Word". To be precise, the white -space after the word is also deleted (the white space before the word at the -end of the line). - -Using text objects is the third way to make changes in Vim. We already had -operator-motion and Visual mode. Now we add operator-text object. - It is very similar to operator-motion, but instead of operating on the text -between the cursor position before and after a movement command, the text -object is used as a whole. It doesn't matter where in the object the cursor -was. - -To change a whole sentence use "cis". Take this text: - - Hello there. This ~ - is an example. Just ~ - some text. ~ - -Move to the start of the second line, on "is an". Now use "cis": - - Hello there. Just ~ - some text. ~ - -The cursor is in between the blanks in the first line. Now you type the new -sentence "Another line.": - - Hello there. Another line. Just ~ - some text. ~ - -"cis" consists of the "c" (change) operator and the "is" text object. This -stands for "Inner Sentence". There is also the "as" (a sentence) object. The -difference is that "as" includes the white space after the sentence and "is" -doesn't. If you would delete a sentence, you want to delete the white space -at the same time, thus use "das". If you want to type new text the white -space can remain, thus you use "cis". - -You can also use text objects in Visual mode. It will include the text object -in the Visual selection. Visual mode continues, thus you can do this several -times. For example, start Visual mode with "v" and select a sentence with -"as". Now you can repeat "as" to include more sentences. Finally you use an -operator to do something with the selected sentences. - -You can find a long list of text objects here: |text-objects|. - -============================================================================== -*04.9* Replace mode - -The "R" command causes Vim to enter replace mode. In this mode, each -character you type replaces the one under the cursor. This continues until -you type <Esc>. - In this example you start Replace mode on the first "t" of "text": - - This is text. ~ - Rinteresting.<Esc> - - This is interesting. ~ - -You may have noticed that this command replaced 5 characters in the line with -twelve others. The "R" command automatically extends the line if it runs out -of characters to replace. It will not continue on the next line. - -You can switch between Insert mode and Replace mode with the <Insert> key. - -When you use <BS> (backspace) to make correction, you will notice that the -old text is put back. Thus it works like an undo command for the last typed -character. - -============================================================================== -*04.10* Conclusion - -The operators, movement commands and text objects give you the possibility to -make lots of combinations. Now that you know how it works, you can use N -operators with M movement commands to make N * M commands! - -You can find a list of operators here: |operator| - -For example, there are many other ways to delete pieces of text. Here are a -few often used ones: - -x delete character under the cursor (short for "dl") -X delete character before the cursor (short for "dh") -D delete from cursor to end of line (short for "d$") -dw delete from cursor to next start of word -db delete from cursor to previous start of word -diw delete word under the cursor (excluding white space) -daw delete word under the cursor (including white space) -dG delete until the end of the file -dgg delete until the start of the file - -If you use "c" instead of "d" they become change commands. And with "y" you -yank the text. And so forth. - - -There are a few often used commands to make changes that didn't fit somewhere -else: - - ~ change case of the character under the cursor, and move the - cursor to the next character. This is not an operator (unless - 'tildeop' is set), thus you can't use it with a motion - command. It does works in Visual mode and changes case for - all the selected text then. - - I Start Insert mode after moving the cursor to the first - non-blank in the line. - - A Start Insert mode after moving the cursor to the end of the - line. - -============================================================================== - -Next chapter: |usr_05.txt| Set your settings - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_05.txt b/share/vim/vim72/doc/usr_05.txt deleted file mode 100644 index 0bac988d7b..0000000000 --- a/share/vim/vim72/doc/usr_05.txt +++ /dev/null @@ -1,625 +0,0 @@ -*usr_05.txt* For Vim version 7.2. Last change: 2007 May 11 - - VIM USER MANUAL - by Bram Moolenaar - - Set your settings - - -Vim can be tuned to work like you want it to. This chapter shows you how to -make Vim start with options set to different values. Add plugins to extend -Vim's capabilities. Or define your own macros. - -|05.1| The vimrc file -|05.2| The example vimrc file explained -|05.3| Simple mappings -|05.4| Adding a plugin -|05.5| Adding a help file -|05.6| The option window -|05.7| Often used options - - Next chapter: |usr_06.txt| Using syntax highlighting - Previous chapter: |usr_04.txt| Making small changes -Table of contents: |usr_toc.txt| - -============================================================================== -*05.1* The vimrc file *vimrc-intro* - -You probably got tired of typing commands that you use very often. To start -Vim with all your favorite option settings and mappings, you write them in -what is called the vimrc file. Vim executes the commands in this file when it -starts up. - -If you already have a vimrc file (e.g., when your sysadmin has one setup for -you), you can edit it this way: > - - :edit $MYVIMRC - -If you don't have a vimrc file yet, see |vimrc| to find out where you can -create a vimrc file. Also, the ":version" command mentions the name of the -"user vimrc file" Vim looks for. - -For Unix and Macintosh this file is always used and is recommended: - - ~/.vimrc ~ - -For MS-DOS and MS-Windows you can use one of these: - - $HOME/_vimrc ~ - $VIM/_vimrc ~ - -The vimrc file can contain all the commands that you type after a colon. The -most simple ones are for setting options. For example, if you want Vim to -always start with the 'incsearch' option on, add this line you your vimrc -file: > - - set incsearch - -For this new line to take effect you need to exit Vim and start it again. -Later you will learn how to do this without exiting Vim. - -This chapter only explains the most basic items. For more information on how -to write a Vim script file: |usr_41.txt|. - -============================================================================== -*05.2* The example vimrc file explained *vimrc_example.vim* - -In the first chapter was explained how the example vimrc (included in the -Vim distribution) file can be used to make Vim startup in not-compatible mode -(see |not-compatible|). The file can be found here: - - $VIMRUNTIME/vimrc_example.vim ~ - -In this section we will explain the various commands used in this file. This -will give you hints about how to set up your own preferences. Not everything -will be explained though. Use the ":help" command to find out more. - -> - set nocompatible - -As mentioned in the first chapter, these manuals explain Vim working in an -improved way, thus not completely Vi compatible. Setting the 'compatible' -option off, thus 'nocompatible' takes care of this. - -> - set backspace=indent,eol,start - -This specifies where in Insert mode the <BS> is allowed to delete the -character in front of the cursor. The three items, separated by commas, tell -Vim to delete the white space at the start of the line, a line break and the -character before where Insert mode started. -> - - set autoindent - -This makes Vim use the indent of the previous line for a newly created line. -Thus there is the same amount of white space before the new line. For example -when pressing <Enter> in Insert mode, and when using the "o" command to open a -new line. -> - - if has("vms") - set nobackup - else - set backup - endif - -This tells Vim to keep a backup copy of a file when overwriting it. But not -on the VMS system, since it keeps old versions of files already. The backup -file will have the same name as the original file with "~" added. See |07.4| -> - - set history=50 - -Keep 50 commands and 50 search patterns in the history. Use another number if -you want to remember fewer or more lines. -> - - set ruler - -Always display the current cursor position in the lower right corner of the -Vim window. - -> - set showcmd - -Display an incomplete command in the lower right corner of the Vim window, -left of the ruler. For example, when you type "2f", Vim is waiting for you to -type the character to find and "2f" is displayed. When you press "w" next, -the "2fw" command is executed and the displayed "2f" is removed. - - +-------------------------------------------------+ - |text in the Vim window | - |~ | - |~ | - |-- VISUAL -- 2f 43,8 17% | - +-------------------------------------------------+ - ^^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^ - 'showmode' 'showcmd' 'ruler' - -> - set incsearch - -Display the match for a search pattern when halfway typing it. - -> - map Q gq - -This defines a key mapping. More about that in the next section. This -defines the "Q" command to do formatting with the "gq" operator. This is how -it worked before Vim 5.0. Otherwise the "Q" command starts Ex mode, but you -will not need it. - -> - vnoremap _g y:exe "grep /" . escape(@", '\\/') . "/ *.c *.h"<CR> - -This mapping yanks the visually selected text and searches for it in C files. -This is a complicated mapping. You can see that mappings can be used to do -quite complicated things. Still, it is just a sequence of commands that are -executed like you typed them. - -> - if &t_Co > 2 || has("gui_running") - syntax on - set hlsearch - endif - -This switches on syntax highlighting, but only if colors are available. And -the 'hlsearch' option tells Vim to highlight matches with the last used search -pattern. The "if" command is very useful to set options only when some -condition is met. More about that in |usr_41.txt|. - - *vimrc-filetype* > - filetype plugin indent on - -This switches on three very clever mechanisms: -1. Filetype detection. - Whenever you start editing a file, Vim will try to figure out what kind of - file this is. When you edit "main.c", Vim will see the ".c" extension and - recognize this as a "c" filetype. When you edit a file that starts with - "#!/bin/sh", Vim will recognize it as a "sh" filetype. - The filetype detection is used for syntax highlighting and the other two - items below. - See |filetypes|. - -2. Using filetype plugin files - Many different filetypes are edited with different options. For example, - when you edit a "c" file, it's very useful to set the 'cindent' option to - automatically indent the lines. These commonly useful option settings are - included with Vim in filetype plugins. You can also add your own, see - |write-filetype-plugin|. - -3. Using indent files - When editing programs, the indent of a line can often be computed - automatically. Vim comes with these indent rules for a number of - filetypes. See |:filetype-indent-on| and 'indentexpr'. - -> - autocmd FileType text setlocal textwidth=78 - -This makes Vim break text to avoid lines getting longer than 78 characters. -But only for files that have been detected to be plain text. There are -actually two parts here. "autocmd FileType text" is an autocommand. This -defines that when the file type is set to "text" the following command is -automatically executed. "setlocal textwidth=78" sets the 'textwidth' option -to 78, but only locally in one file. - - *restore-cursor* > - autocmd BufReadPost * - \ if line("'\"") > 0 && line("'\"") <= line("$") | - \ exe "normal g`\"" | - \ endif - -Another autocommand. This time it is used after reading any file. The -complicated stuff after it checks if the '" mark is defined, and jumps to it -if so. The backslash at the start of a line is used to continue the command -from the previous line. That avoids a line getting very long. -See |line-continuation|. This only works in a Vim script file, not when -typing commands at the command-line. - -============================================================================== -*05.3* Simple mappings - -A mapping enables you to bind a set of Vim commands to a single key. Suppose, -for example, that you need to surround certain words with curly braces. In -other words, you need to change a word such as "amount" into "{amount}". With -the :map command, you can tell Vim that the F5 key does this job. The command -is as follows: > - - :map <F5> i{<Esc>ea}<Esc> -< - Note: - When entering this command, you must enter <F5> by typing four - characters. Similarly, <Esc> is not entered by pressing the <Esc> - key, but by typing five characters. Watch out for this difference - when reading the manual! - -Let's break this down: - <F5> The F5 function key. This is the trigger key that causes the - command to be executed as the key is pressed. - - i{<Esc> Insert the { character. The <Esc> key ends Insert mode. - - e Move to the end of the word. - - a}<Esc> Append the } to the word. - -After you execute the ":map" command, all you have to do to put {} around a -word is to put the cursor on the first character and press F5. - -In this example, the trigger is a single key; it can be any string. But when -you use an existing Vim command, that command will no longer be available. -You better avoid that. - One key that can be used with mappings is the backslash. Since you -probably want to define more than one mapping, add another character. You -could map "\p" to add parentheses around a word, and "\c" to add curly braces, -for example: > - - :map \p i(<Esc>ea)<Esc> - :map \c i{<Esc>ea}<Esc> - -You need to type the \ and the p quickly after another, so that Vim knows they -belong together. - -The ":map" command (with no arguments) lists your current mappings. At -least the ones for Normal mode. More about mappings in section |40.1|. - -============================================================================== -*05.4* Adding a plugin *add-plugin* *plugin* - -Vim's functionality can be extended by adding plugins. A plugin is nothing -more than a Vim script file that is loaded automatically when Vim starts. You -can add a plugin very easily by dropping it in your plugin directory. -{not available when Vim was compiled without the |+eval| feature} - -There are two types of plugins: - - global plugin: Used for all kinds of files - filetype plugin: Only used for a specific type of file - -The global plugins will be discussed first, then the filetype ones -|add-filetype-plugin|. - - -GLOBAL PLUGINS *standard-plugin* - -When you start Vim, it will automatically load a number of global plugins. -You don't have to do anything for this. They add functionality that most -people will want to use, but which was implemented as a Vim script instead of -being compiled into Vim. You can find them listed in the help index -|standard-plugin-list|. Also see |load-plugins|. - - *add-global-plugin* -You can add a global plugin to add functionality that will always be present -when you use Vim. There are only two steps for adding a global plugin: -1. Get a copy of the plugin. -2. Drop it in the right directory. - - -GETTING A GLOBAL PLUGIN - -Where can you find plugins? -- Some come with Vim. You can find them in the directory $VIMRUNTIME/macros - and its sub-directories. -- Download from the net. There is a large collection on http://www.vim.org. -- They are sometimes posted in a Vim |maillist|. -- You could write one yourself, see |write-plugin|. - -Some plugins come as a vimball archive, see |vimball|. -Some plugins can be updated automatically, see |getscript|. - - -USING A GLOBAL PLUGIN - -First read the text in the plugin itself to check for any special conditions. -Then copy the file to your plugin directory: - - system plugin directory ~ - Unix ~/.vim/plugin/ - PC and OS/2 $HOME/vimfiles/plugin or $VIM/vimfiles/plugin - Amiga s:vimfiles/plugin - Macintosh $VIM:vimfiles:plugin - Mac OS X ~/.vim/plugin/ - RISC-OS Choices:vimfiles.plugin - -Example for Unix (assuming you didn't have a plugin directory yet): > - - mkdir ~/.vim - mkdir ~/.vim/plugin - cp /usr/local/share/vim/vim60/macros/justify.vim ~/.vim/plugin - -That's all! Now you can use the commands defined in this plugin to justify -text. - -Instead of putting plugins directly into the plugin/ directory, you may -better organize them by putting them into subdirectories under plugin/. -As an example, consider using "~/.vim/plugin/perl/*.vim" for all your Perl -plugins. - - -FILETYPE PLUGINS *add-filetype-plugin* *ftplugins* - -The Vim distribution comes with a set of plugins for different filetypes that -you can start using with this command: > - - :filetype plugin on - -That's all! See |vimrc-filetype|. - -If you are missing a plugin for a filetype you are using, or you found a -better one, you can add it. There are two steps for adding a filetype plugin: -1. Get a copy of the plugin. -2. Drop it in the right directory. - - -GETTING A FILETYPE PLUGIN - -You can find them in the same places as the global plugins. Watch out if the -type of file is mentioned, then you know if the plugin is a global or a -filetype one. The scripts in $VIMRUNTIME/macros are global ones, the filetype -plugins are in $VIMRUNTIME/ftplugin. - - -USING A FILETYPE PLUGIN *ftplugin-name* - -You can add a filetype plugin by dropping it in the right directory. The -name of this directory is in the same directory mentioned above for global -plugins, but the last part is "ftplugin". Suppose you have found a plugin for -the "stuff" filetype, and you are on Unix. Then you can move this file to the -ftplugin directory: > - - mv thefile ~/.vim/ftplugin/stuff.vim - -If that file already exists you already have a plugin for "stuff". You might -want to check if the existing plugin doesn't conflict with the one you are -adding. If it's OK, you can give the new one another name: > - - mv thefile ~/.vim/ftplugin/stuff_too.vim - -The underscore is used to separate the name of the filetype from the rest, -which can be anything. If you use "otherstuff.vim" it wouldn't work, it would -be loaded for the "otherstuff" filetype. - -On MS-DOS you cannot use long filenames. You would run into trouble if you -add a second plugin and the filetype has more than six characters. You can -use an extra directory to get around this: > - - mkdir $VIM/vimfiles/ftplugin/fortran - copy thefile $VIM/vimfiles/ftplugin/fortran/too.vim - -The generic names for the filetype plugins are: > - - ftplugin/<filetype>.vim - ftplugin/<filetype>_<name>.vim - ftplugin/<filetype>/<name>.vim - -Here "<name>" can be any name that you prefer. -Examples for the "stuff" filetype on Unix: > - - ~/.vim/ftplugin/stuff.vim - ~/.vim/ftplugin/stuff_def.vim - ~/.vim/ftplugin/stuff/header.vim - -The <filetype> part is the name of the filetype the plugin is to be used for. -Only files of this filetype will use the settings from the plugin. The <name> -part of the plugin file doesn't matter, you can use it to have several plugins -for the same filetype. Note that it must end in ".vim". - - -Further reading: -|filetype-plugins| Documentation for the filetype plugins and information - about how to avoid that mappings cause problems. -|load-plugins| When the global plugins are loaded during startup. -|ftplugin-overrule| Overruling the settings from a global plugin. -|write-plugin| How to write a plugin script. -|plugin-details| For more information about using plugins or when your - plugin doesn't work. -|new-filetype| How to detect a new file type. - -============================================================================== -*05.5* Adding a help file *add-local-help* *matchit-install* - -If you are lucky, the plugin you installed also comes with a help file. We -will explain how to install the help file, so that you can easily find help -for your new plugin. - Let us use the "matchit.vim" plugin as an example (it is included with -Vim). This plugin makes the "%" command jump to matching HTML tags, -if/else/endif in Vim scripts, etc. Very useful, although it's not backwards -compatible (that's why it is not enabled by default). - This plugin comes with documentation: "matchit.txt". Let's first copy the -plugin to the right directory. This time we will do it from inside Vim, so -that we can use $VIMRUNTIME. (You may skip some of the "mkdir" commands if -you already have the directory.) > - - :!mkdir ~/.vim - :!mkdir ~/.vim/plugin - :!cp $VIMRUNTIME/macros/matchit.vim ~/.vim/plugin - -The "cp" command is for Unix, on MS-DOS you can use "copy". - -Now create a "doc" directory in one of the directories in 'runtimepath'. > - - :!mkdir ~/.vim/doc - -Copy the help file to the "doc" directory. > - - :!cp $VIMRUNTIME/macros/matchit.txt ~/.vim/doc - -Now comes the trick, which allows you to jump to the subjects in the new help -file: Generate the local tags file with the |:helptags| command. > - - :helptags ~/.vim/doc - -Now you can use the > - - :help g% - -command to find help for "g%" in the help file you just added. You can see an -entry for the local help file when you do: > - - :help local-additions - -The title lines from the local help files are automagically added to this -section. There you can see which local help files have been added and jump to -them through the tag. - -For writing a local help file, see |write-local-help|. - -============================================================================== -*05.6* The option window - -If you are looking for an option that does what you want, you can search in -the help files here: |options|. Another way is by using this command: > - - :options - -This opens a new window, with a list of options with a one-line explanation. -The options are grouped by subject. Move the cursor to a subject and press -<Enter> to jump there. Press <Enter> again to jump back. Or use CTRL-O. - -You can change the value of an option. For example, move to the "displaying -text" subject. Then move the cursor down to this line: - - set wrap nowrap ~ - -When you hit <Enter>, the line will change to: - - set nowrap wrap ~ - -The option has now been switched off. - -Just above this line is a short description of the 'wrap' option. Move the -cursor one line up to place it in this line. Now hit <Enter> and you jump to -the full help on the 'wrap' option. - -For options that take a number or string argument you can edit the value. -Then press <Enter> to apply the new value. For example, move the cursor a few -lines up to this line: - - set so=0 ~ - -Position the cursor on the zero with "$". Change it into a five with "r5". -Then press <Enter> to apply the new value. When you now move the cursor -around you will notice that the text starts scrolling before you reach the -border. This is what the 'scrolloff' option does, it specifies an offset -from the window border where scrolling starts. - -============================================================================== -*05.7* Often used options - -There are an awful lot of options. Most of them you will hardly ever use. -Some of the more useful ones will be mentioned here. Don't forget you can -find more help on these options with the ":help" command, with single quotes -before and after the option name. For example: > - - :help 'wrap' - -In case you have messed up an option value, you can set it back to the -default by putting an ampersand (&) after the option name. Example: > - - :set iskeyword& - - -NOT WRAPPING LINES - -Vim normally wraps long lines, so that you can see all of the text. Sometimes -it's better to let the text continue right of the window. Then you need to -scroll the text left-right to see all of a long line. Switch wrapping off -with this command: > - - :set nowrap - -Vim will automatically scroll the text when you move to text that is not -displayed. To see a context of ten characters, do this: > - - :set sidescroll=10 - -This doesn't change the text in the file, only the way it is displayed. - - -WRAPPING MOVEMENT COMMANDS - -Most commands for moving around will stop moving at the start and end of a -line. You can change that with the 'whichwrap' option. This sets it to the -default value: > - - :set whichwrap=b,s - -This allows the <BS> key, when used in the first position of a line, to move -the cursor to the end of the previous line. And the <Space> key moves from -the end of a line to the start of the next one. - -To allow the cursor keys <Left> and <Right> to also wrap, use this command: > - - :set whichwrap=b,s,<,> - -This is still only for Normal mode. To let <Left> and <Right> do this in -Insert mode as well: > - - :set whichwrap=b,s,<,>,[,] - -There are a few other flags that can be added, see 'whichwrap'. - - -VIEWING TABS - -When there are tabs in a file, you cannot see where they are. To make them -visible: > - - :set list - -Now every tab is displayed as ^I. And a $ is displayed at the end of each -line, so that you can spot trailing spaces that would otherwise go unnoticed. - A disadvantage is that this looks ugly when there are many Tabs in a file. -If you have a color terminal, or are using the GUI, Vim can show the spaces -and tabs as highlighted characters. Use the 'listchars' option: > - - :set listchars=tab:>-,trail:- - -Now every tab will be displayed as ">---" (with more or less "-") and trailing -white space as "-". Looks a lot better, doesn't it? - - -KEYWORDS - -The 'iskeyword' option specifies which characters can appear in a word: > - - :set iskeyword -< iskeyword=@,48-57,_,192-255 ~ - -The "@" stands for all alphabetic letters. "48-57" stands for ASCII -characters 48 to 57, which are the numbers 0 to 9. "192-255" are the -printable latin characters. - Sometimes you will want to include a dash in keywords, so that commands -like "w" consider "upper-case" to be one word. You can do it like this: > - - :set iskeyword+=- - :set iskeyword -< iskeyword=@,48-57,_,192-255,- ~ - -If you look at the new value, you will see that Vim has added a comma for you. - To remove a character use "-=". For example, to remove the underscore: > - - :set iskeyword-=_ - :set iskeyword -< iskeyword=@,48-57,192-255,- ~ - -This time a comma is automatically deleted. - - -ROOM FOR MESSAGES - -When Vim starts there is one line at the bottom that is used for messages. -When a message is long, it is either truncated, thus you can only see part of -it, or the text scrolls and you have to press <Enter> to continue. - You can set the 'cmdheight' option to the number of lines used for -messages. Example: > - - :set cmdheight=3 - -This does mean there is less room to edit text, thus it's a compromise. - -============================================================================== - -Next chapter: |usr_06.txt| Using syntax highlighting - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_06.txt b/share/vim/vim72/doc/usr_06.txt deleted file mode 100644 index a339129812..0000000000 --- a/share/vim/vim72/doc/usr_06.txt +++ /dev/null @@ -1,276 +0,0 @@ -*usr_06.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - VIM USER MANUAL - by Bram Moolenaar - - Using syntax highlighting - - -Black and white text is boring. With colors your file comes to life. This -not only looks nice, it also speeds up your work. Change the colors used for -the different sorts of text. Print your text, with the colors you see on the -screen. - -|06.1| Switching it on -|06.2| No or wrong colors? -|06.3| Different colors -|06.4| With colors or without colors -|06.5| Printing with colors -|06.6| Further reading - - Next chapter: |usr_07.txt| Editing more than one file - Previous chapter: |usr_05.txt| Set your settings -Table of contents: |usr_toc.txt| - -============================================================================== -*06.1* Switching it on - -It all starts with one simple command: > - - :syntax enable - -That should work in most situations to get color in your files. Vim will -automagically detect the type of file and load the right syntax highlighting. -Suddenly comments are blue, keywords brown and strings red. This makes it -easy to overview the file. After a while you will find that black&white text -slows you down! - -If you always want to use syntax highlighting, put the ":syntax enable" -command in your |vimrc| file. - -If you want syntax highlighting only when the terminal supports colors, you -can put this in your |vimrc| file: > - - if &t_Co > 1 - syntax enable - endif - -If you want syntax highlighting only in the GUI version, put the ":syntax -enable" command in your |gvimrc| file. - -============================================================================== -*06.2* No or wrong colors? - -There can be a number of reasons why you don't see colors: - -- Your terminal does not support colors. - Vim will use bold, italic and underlined text, but this doesn't look - very nice. You probably will want to try to get a terminal with - colors. For Unix, I recommend the xterm from the XFree86 project: - |xfree-xterm|. - -- Your terminal does support colors, but Vim doesn't know this. - Make sure your $TERM setting is correct. For example, when using an - xterm that supports colors: > - - setenv TERM xterm-color -< - or (depending on your shell): > - - TERM=xterm-color; export TERM - -< The terminal name must match the terminal you are using. If it - still doesn't work, have a look at |xterm-color|, which shows a few - ways to make Vim display colors (not only for an xterm). - -- The file type is not recognized. - Vim doesn't know all file types, and sometimes it's near to impossible - to tell what language a file uses. Try this command: > - - :set filetype -< - If the result is "filetype=" then the problem is indeed that Vim - doesn't know what type of file this is. You can set the type - manually: > - - :set filetype=fortran - -< To see which types are available, look in the directory - $VIMRUNTIME/syntax. For the GUI you can use the Syntax menu. - Setting the filetype can also be done with a |modeline|, so that the - file will be highlighted each time you edit it. For example, this - line can be used in a Makefile (put it near the start or end of the - file): > - - # vim: syntax=make - -< You might know how to detect the file type yourself. Often the file - name extension (after the dot) can be used. - See |new-filetype| for how to tell Vim to detect that file type. - -- There is no highlighting for your file type. - You could try using a similar file type by manually setting it as - mentioned above. If that isn't good enough, you can write your own - syntax file, see |mysyntaxfile|. - - -Or the colors could be wrong: - -- The colored text is very hard to read. - Vim guesses the background color that you are using. If it is black - (or another dark color) it will use light colors for text. If it is - white (or another light color) it will use dark colors for text. If - Vim guessed wrong the text will be hard to read. To solve this, set - the 'background' option. For a dark background: > - - :set background=dark - -< And for a light background: > - - :set background=light - -< Make sure you put this _before_ the ":syntax enable" command, - otherwise the colors will already have been set. You could do - ":syntax reset" after setting 'background' to make Vim set the default - colors again. - -- The colors are wrong when scrolling bottom to top. - Vim doesn't read the whole file to parse the text. It starts parsing - wherever you are viewing the file. That saves a lot of time, but - sometimes the colors are wrong. A simple fix is hitting CTRL-L. Or - scroll back a bit and then forward again. - For a real fix, see |:syn-sync|. Some syntax files have a way to make - it look further back, see the help for the specific syntax file. For - example, |tex.vim| for the TeX syntax. - -============================================================================== -*06.3* Different colors *:syn-default-override* - -If you don't like the default colors, you can select another color scheme. In -the GUI use the Edit/Color Scheme menu. You can also type the command: > - - :colorscheme evening - -"evening" is the name of the color scheme. There are several others you might -want to try out. Look in the directory $VIMRUNTIME/colors. - -When you found the color scheme that you like, add the ":colorscheme" command -to your |vimrc| file. - -You could also write your own color scheme. This is how you do it: - -1. Select a color scheme that comes close. Copy this file to your own Vim - directory. For Unix, this should work: > - - !mkdir ~/.vim/colors - !cp $VIMRUNTIME/colors/morning.vim ~/.vim/colors/mine.vim -< - This is done from Vim, because it knows the value of $VIMRUNTIME. - -2. Edit the color scheme file. These entries are useful: - - term attributes in a B&W terminal - cterm attributes in a color terminal - ctermfg foreground color in a color terminal - ctermbg background color in a color terminal - gui attributes in the GUI - guifg foreground color in the GUI - guibg background color in the GUI - - For example, to make comments green: > - - :highlight Comment ctermfg=green guifg=green -< - Attributes you can use for "cterm" and "gui" are "bold" and "underline". - If you want both, use "bold,underline". For details see the |:highlight| - command. - -3. Tell Vim to always use your color scheme. Put this line in your |vimrc|: > - - colorscheme mine - -If you want to see what the most often used color combinations look like, use -this command: > - - :runtime syntax/colortest.vim - -You will see text in various color combinations. You can check which ones are -readable and look nice. - -============================================================================== -*06.4* With colors or without colors - -Displaying text in color takes a lot of effort. If you find the displaying -too slow, you might want to disable syntax highlighting for a moment: > - - :syntax clear - -When editing another file (or the same one) the colors will come back. - - *:syn-off* -If you want to stop highlighting completely use: > - - :syntax off - -This will completely disable syntax highlighting and remove it immediately for -all buffers. - - *:syn-manual* -If you want syntax highlighting only for specific files, use this: > - - :syntax manual - -This will enable the syntax highlighting, but not switch it on automatically -when starting to edit a buffer. To switch highlighting on for the current -buffer, set the 'syntax' option: > - - :set syntax=ON -< -============================================================================== -*06.5* Printing with colors *syntax-printing* - -In the MS-Windows version you can print the current file with this command: > - - :hardcopy - -You will get the usual printer dialog, where you can select the printer and a -few settings. If you have a color printer, the paper output should look the -same as what you see inside Vim. But when you use a dark background the -colors will be adjusted to look good on white paper. - -There are several options that change the way Vim prints: - 'printdevice' - 'printheader' - 'printfont' - 'printoptions' - -To print only a range of lines, use Visual mode to select the lines and then -type the command: > - - v100j:hardcopy - -"v" starts Visual mode. "100j" moves a hundred lines down, they will be -highlighted. Then ":hardcopy" will print those lines. You can use other -commands to move in Visual mode, of course. - -This also works on Unix, if you have a PostScript printer. Otherwise, you -will have to do a bit more work. You need to convert the text to HTML first, -and then print it from a web browser such as Netscape. - -Convert the current file to HTML with this command: > - - :source $VIMRUNTIME/syntax/2html.vim - -You will see it crunching away, this can take quite a while for a large file. -Some time later another window shows the HTML code. Now write this somewhere -(doesn't matter where, you throw it away later): -> - :write main.c.html - -Open this file in your favorite browser and print it from there. If all goes -well, the output should look exactly as it does in Vim. See |2html.vim| for -details. Don't forget to delete the HTML file when you are done with it. - -Instead of printing, you could also put the HTML file on a web server, and let -others look at the colored text. - -============================================================================== -*06.6* Further reading - -|usr_44.txt| Your own syntax highlighted. -|syntax| All the details. - -============================================================================== - -Next chapter: |usr_07.txt| Editing more than one file - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_07.txt b/share/vim/vim72/doc/usr_07.txt deleted file mode 100644 index 0b51400045..0000000000 --- a/share/vim/vim72/doc/usr_07.txt +++ /dev/null @@ -1,479 +0,0 @@ -*usr_07.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - VIM USER MANUAL - by Bram Moolenaar - - Editing more than one file - - -No matter how many files you have, you can edit them without leaving Vim. -Define a list of files to work on and jump from one to the other. Copy text -from one file and put it in another one. - -|07.1| Edit another file -|07.2| A list of files -|07.3| Jumping from file to file -|07.4| Backup files -|07.5| Copy text between files -|07.6| Viewing a file -|07.7| Changing the file name - - Next chapter: |usr_08.txt| Splitting windows - Previous chapter: |usr_06.txt| Using syntax highlighting -Table of contents: |usr_toc.txt| - -============================================================================== -*07.1* Edit another file - -So far you had to start Vim for every file you wanted to edit. There is a -simpler way. To start editing another file, use this command: > - - :edit foo.txt - -You can use any file name instead of "foo.txt". Vim will close the current -file and open the new one. If the current file has unsaved changes, however, -Vim displays an error message and does not open the new file: - - E37: No write since last change (use ! to override) ~ - - Note: - Vim puts an error ID at the start of each error message. If you do - not understand the message or what caused it, look in the help system - for this ID. In this case: > - - :help E37 - -At this point, you have a number of alternatives. You can write the file -using this command: > - - :write - -Or you can force Vim to discard your changes and edit the new file, using the -force (!) character: > - - :edit! foo.txt - -If you want to edit another file, but not write the changes in the current -file yet, you can make it hidden: > - - :hide edit foo.txt - -The text with changes is still there, but you can't see it. This is further -explained in section |22.4|: The buffer list. - -============================================================================== -*07.2* A list of files - -You can start Vim to edit a sequence of files. For example: > - - vim one.c two.c three.c - -This command starts Vim and tells it that you will be editing three files. -Vim displays just the first file. After you have done your thing in this -file, to edit the next file you use this command: > - - :next - -If you have unsaved changes in the current file, you will get an error -message and the ":next" will not work. This is the same problem as with -":edit" mentioned in the previous section. To abandon the changes: > - - :next! - -But mostly you want to save the changes and move on to the next file. There -is a special command for this: > - - :wnext - -This does the same as using two separate commands: > - - :write - :next - - -WHERE AM I? - -To see which file in the argument list you are editing, look in the window -title. It should show something like "(2 of 3)". This means you are editing -the second file out of three files. - If you want to see the list of files, use this command: > - - :args - -This is short for "arguments". The output might look like this: - - one.c [two.c] three.c ~ - -These are the files you started Vim with. The one you are currently editing, -"two.c", is in square brackets. - - -MOVING TO OTHER ARGUMENTS - -To go back one file: > - - :previous - -This is just like the ":next" command, except that it moves in the other -direction. Again, there is a shortcut command for when you want to write the -file first: > - - :wprevious - -To move to the very last file in the list: > - - :last - -And to move back to the first one again: > - - :first - -There is no ":wlast" or ":wfirst" command though! - -You can use a count for ":next" and ":previous". To skip two files forward: > - - :2next - - -AUTOMATIC WRITING - -When moving around the files and making changes, you have to remember to use -":write". Otherwise you will get an error message. If you are sure you -always want to write modified files, you can tell Vim to automatically write -them: > - - :set autowrite - -When you are editing a file which you may not want to write, switch it off -again: > - - :set noautowrite - - -EDITING ANOTHER LIST OF FILES - -You can redefine the list of files without the need to exit Vim and start it -again. Use this command to edit three other files: > - - :args five.c six.c seven.h - -Or use a wildcard, like it's used in the shell: > - - :args *.txt - -Vim will take you to the first file in the list. Again, if the current file -has changes, you can either write the file first, or use ":args!" (with ! -added) to abandon the changes. - - -DID YOU EDIT THE LAST FILE? - *arglist-quit* -When you use a list of files, Vim assumes you want to edit them all. To -protect you from exiting too early, you will get this error when you didn't -edit the last file in the list yet: - - E173: 46 more files to edit ~ - -If you really want to exit, just do it again. Then it will work (but not when -you did other commands in between). - -============================================================================== -*07.3* Jumping from file to file - -To quickly jump between two files, press CTRL-^ (on English-US keyboards the ^ -is above the 6 key). Example: > - - :args one.c two.c three.c - -You are now in one.c. > - - :next - -Now you are in two.c. Now use CTRL-^ to go back to one.c. Another CTRL-^ and -you are back in two.c. Another CTRL-^ and you are in one.c again. If you now -do: > - - :next - -You are in three.c. Notice that the CTRL-^ command does not change the idea -of where you are in the list of files. Only commands like ":next" and -":previous" do that. - -The file you were previously editing is called the "alternate" file. When you -just started Vim CTRL-^ will not work, since there isn't a previous file. - - -PREDEFINED MARKS - -After jumping to another file, you can use two predefined marks which are very -useful: > - - `" - -This takes you to the position where the cursor was when you left the file. -Another mark that is remembered is the position where you made the last -change: > - - `. - -Suppose you are editing the file "one.txt". Somewhere halfway the file you -use "x" to delete a character. Then you go to the last line with "G" and -write the file with ":w". You edit several other files, and then use ":edit -one.txt" to come back to "one.txt". If you now use `" Vim jumps to the last -line of the file. Using `. takes you to the position where you deleted the -character. Even when you move around in the file `" and `. will take you to -the remembered position. At least until you make another change or leave the -file. - - -FILE MARKS - -In chapter 4 was explained how you can place a mark in a file with "mx" and -jump to that position with "`x". That works within one file. If you edit -another file and place marks there, these are specific for that file. Thus -each file has its own set of marks, they are local to the file. - So far we were using marks with a lowercase letter. There are also marks -with an uppercase letter. These are global, they can be used from any file. -For example suppose that we are editing the file "foo.txt". Go to halfway the -file ("50%") and place the F mark there (F for foo): > - - 50%mF - -Now edit the file "bar.txt" and place the B mark (B for bar) at its last line: -> - GmB - -Now you can use the "'F" command to jump back to halfway foo.txt. Or edit yet -another file, type "'B" and you are at the end of bar.txt again. - -The file marks are remembered until they are placed somewhere else. Thus you -can place the mark, do hours of editing and still be able to jump back to that -mark. - It's often useful to think of a simple connection between the mark letter -and where it is placed. For example, use the H mark in a header file, M in -a Makefile and C in a C code file. - -To see where a specific mark is, give an argument to the ":marks" command: > - - :marks M - -You can also give several arguments: > - - :marks MCP - -Don't forget that you can use CTRL-O and CTRL-I to jump to older and newer -positions without placing marks there. - -============================================================================== -*07.4* Backup files - -Usually Vim does not produce a backup file. If you want to have one, all you -need to do is execute the following command: > - - :set backup - -The name of the backup file is the original file with a ~ added to the end. -If your file is named data.txt, for example, the backup file name is -data.txt~. - If you do not like the fact that the backup files end with ~, you can -change the extension: > - - :set backupext=.bak - -This will use data.txt.bak instead of data.txt~. - Another option that matters here is 'backupdir'. It specifies where the -backup file is written. The default, to write the backup in the same -directory as the original file, will mostly be the right thing. - - Note: - When the 'backup' option isn't set but the 'writebackup' is, Vim will - still create a backup file. However, it is deleted as soon as writing - the file was completed successfully. This functions as a safety - against losing your original file when writing fails in some way (disk - full is the most common cause; being hit by lightning might be - another, although less common). - - -KEEPING THE ORIGINAL FILE - -If you are editing source files, you might want to keep the file before you -make any changes. But the backup file will be overwritten each time you write -the file. Thus it only contains the previous version, not the first one. - To make Vim keep the original file, set the 'patchmode' option. This -specifies the extension used for the first backup of a changed file. Usually -you would do this: > - - :set patchmode=.orig - -When you now edit the file data.txt for the first time, make changes and write -the file, Vim will keep a copy of the unchanged file under the name -"data.txt.orig". - If you make further changes to the file, Vim will notice that -"data.txt.orig" already exists and leave it alone. Further backup files will -then be called "data.txt~" (or whatever you specified with 'backupext'). - If you leave 'patchmode' empty (that is the default), the original file -will not be kept. - -============================================================================== -*07.5* Copy text between files - -This explains how to copy text from one file to another. Let's start with a -simple example. Edit the file that contains the text you want to copy. Move -the cursor to the start of the text and press "v". This starts Visual mode. -Now move the cursor to the end of the text and press "y". This yanks (copies) -the selected text. - To copy the above paragraph, you would do: > - - :edit thisfile - /This - vjjjj$y - -Now edit the file you want to put the text in. Move the cursor to the -character where you want the text to appear after. Use "p" to put the text -there. > - :edit otherfile - /There - p - -Of course you can use many other commands to yank the text. For example, to -select whole lines start Visual mode with "V". Or use CTRL-V to select a -rectangular block. Or use "Y" to yank a single line, "yaw" to yank-a-word, -etc. - The "p" command puts the text after the cursor. Use "P" to put the text -before the cursor. Notice that Vim remembers if you yanked a whole line or a -block, and puts it back that way. - - -USING REGISTERS - -When you want to copy several pieces of text from one file to another, having -to switch between the files and writing the target file takes a lot of time. -To avoid this, copy each piece of text to its own register. - A register is a place where Vim stores text. Here we will use the -registers named a to z (later you will find out there are others). Let's copy -a sentence to the f register (f for First): > - - "fyas - -The "yas" command yanks a sentence like before. It's the "f that tells Vim -the text should be place in the f register. This must come just before the -yank command. - Now yank three whole lines to the l register (l for line): > - - "l3Y - -The count could be before the "l just as well. To yank a block of text to the -b (for block) register: > - - CTRL-Vjjww"by - -Notice that the register specification "b is just before the "y" command. -This is required. If you would have put it before the "w" command, it would -not have worked. - Now you have three pieces of text in the f, l and b registers. Edit -another file, move around and place the text where you want it: > - - "fp - -Again, the register specification "f comes before the "p" command. - You can put the registers in any order. And the text stays in the register -until you yank something else into it. Thus you can put it as many times as -you like. - -When you delete text, you can also specify a register. Use this to move -several pieces of text around. For example, to delete-a-word and write it in -the w register: > - - "wdaw - -Again, the register specification comes before the delete command "d". - - -APPENDING TO A FILE - -When collecting lines of text into one file, you can use this command: > - - :write >> logfile - -This will write the text of the current file to the end of "logfile". Thus it -is appended. This avoids that you have to copy the lines, edit the log file -and put them there. Thus you save two steps. But you can only append to the -end of a file. - To append only a few lines, select them in Visual mode before typing -":write". In chapter 10 you will learn other ways to select a range of lines. - -============================================================================== -*07.6* Viewing a file - -Sometimes you only want to see what a file contains, without the intention to -ever write it back. There is the risk that you type ":w" without thinking and -overwrite the original file anyway. To avoid this, edit the file read-only. - To start Vim in readonly mode, use this command: > - - vim -R file - -On Unix this command should do the same thing: > - - view file - -You are now editing "file" in read-only mode. When you try using ":w" you -will get an error message and the file won't be written. - When you try to make a change to the file Vim will give you a warning: - - W10: Warning: Changing a readonly file ~ - -The change will be done though. This allows for formatting the file, for -example, to be able to read it easily. - If you make changes to a file and forgot that it was read-only, you can -still write it. Add the ! to the write command to force writing. - -If you really want to forbid making changes in a file, do this: > - - vim -M file - -Now every attempt to change the text will fail. The help files are like this, -for example. If you try to make a change you get this error message: - - E21: Cannot make changes, 'modifiable' is off ~ - -You could use the -M argument to setup Vim to work in a viewer mode. This is -only voluntary though, since these commands will remove the protection: > - - :set modifiable - :set write - -============================================================================== -*07.7* Changing the file name - -A clever way to start editing a new file is by using an existing file that -contains most of what you need. For example, you start writing a new program -to move a file. You know that you already have a program that copies a file, -thus you start with: > - - :edit copy.c - -You can delete the stuff you don't need. Now you need to save the file under -a new name. The ":saveas" command can be used for this: > - - :saveas move.c - -Vim will write the file under the given name, and edit that file. Thus the -next time you do ":write", it will write "move.c". "copy.c" remains -unmodified. - When you want to change the name of the file you are editing, but don't -want to write the file, you can use this command: > - - :file move.c - -Vim will mark the file as "not edited". This means that Vim knows this is not -the file you started editing. When you try to write the file, you might get -this message: - - E13: File exists (use ! to override) ~ - -This protects you from accidentally overwriting another file. - -============================================================================== - -Next chapter: |usr_08.txt| Splitting windows - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_08.txt b/share/vim/vim72/doc/usr_08.txt deleted file mode 100644 index 5eb6478af3..0000000000 --- a/share/vim/vim72/doc/usr_08.txt +++ /dev/null @@ -1,601 +0,0 @@ -*usr_08.txt* For Vim version 7.2. Last change: 2006 Jul 18 - - VIM USER MANUAL - by Bram Moolenaar - - Splitting windows - - -Display two different files above each other. Or view two locations in the -file at the same time. See the difference between two files by putting them -side by side. All this is possible with split windows. - -|08.1| Split a window -|08.2| Split a window on another file -|08.3| Window size -|08.4| Vertical splits -|08.5| Moving windows -|08.6| Commands for all windows -|08.7| Viewing differences with vimdiff -|08.8| Various -|08.9| Tab pages - - Next chapter: |usr_09.txt| Using the GUI - Previous chapter: |usr_07.txt| Editing more than one file -Table of contents: |usr_toc.txt| - -============================================================================== -*08.1* Split a window - -The easiest way to open a new window is to use the following command: > - - :split - -This command splits the screen into two windows and leaves the cursor in the -top one: - - +----------------------------------+ - |/* file one.c */ | - |~ | - |~ | - |one.c=============================| - |/* file one.c */ | - |~ | - |one.c=============================| - | | - +----------------------------------+ - -What you see here is two windows on the same file. The line with "====" is -that status line. It displays information about the window above it. (In -practice the status line will be in reverse video.) - The two windows allow you to view two parts of the same file. For example, -you could make the top window show the variable declarations of a program, and -the bottom one the code that uses these variables. - -The CTRL-W w command can be used to jump between the windows. If you are in -the top window, CTRL-W w jumps to the window below it. If you are in the -bottom window it will jump to the first window. (CTRL-W CTRL-W does the same -thing, in case you let go of the CTRL key a bit later.) - - -CLOSE THE WINDOW - -To close a window, use the command: > - - :close - -Actually, any command that quits editing a file works, like ":quit" and "ZZ". -But ":close" prevents you from accidentally exiting Vim when you close the -last window. - - -CLOSING ALL OTHER WINDOWS - -If you have opened a whole bunch of windows, but now want to concentrate on -one of them, this command will be useful: > - - :only - -This closes all windows, except for the current one. If any of the other -windows has changes, you will get an error message and that window won't be -closed. - -============================================================================== -*08.2* Split a window on another file - -The following command opens a second window and starts editing the given file: -> - :split two.c - -If you were editing one.c, then the result looks like this: - - +----------------------------------+ - |/* file two.c */ | - |~ | - |~ | - |two.c=============================| - |/* file one.c */ | - |~ | - |one.c=============================| - | | - +----------------------------------+ - -To open a window on a new, empty file, use this: > - - :new - -You can repeat the ":split" and ":new" commands to create as many windows as -you like. - -============================================================================== -*08.3* Window size - -The ":split" command can take a number argument. If specified, this will be -the height of the new window. For example, the following opens a new window -three lines high and starts editing the file alpha.c: > - - :3split alpha.c - -For existing windows you can change the size in several ways. When you have a -working mouse, it is easy: Move the mouse pointer to the status line that -separates two windows, and drag it up or down. - -To increase the size of a window: > - - CTRL-W + - -To decrease it: > - - CTRL-W - - -Both of these commands take a count and increase or decrease the window size -by that many lines. Thus "4 CTRL-W +" make the window four lines higher. - -To set the window height to a specified number of lines: > - - {height}CTRL-W _ - -That's: a number {height}, CTRL-W and then an underscore (the - key with Shift -on English-US keyboards). - To make a window as high as it can be, use the CTRL-W _ command without a -count. - - -USING THE MOUSE - -In Vim you can do many things very quickly from the keyboard. Unfortunately, -the window resizing commands require quite a bit of typing. In this case, -using the mouse is faster. Position the mouse pointer on a status line. Now -press the left mouse button and drag. The status line will move, thus making -the window on one side higher and the other smaller. - - -OPTIONS - -The 'winheight' option can be set to a minimal desired height of a window and -'winminheight' to a hard minimum height. - Likewise, there is 'winwidth' for the minimal desired width and -'winminwidth' for the hard minimum width. - The 'equalalways' option, when set, makes Vim equalize the windows sizes -when a window is closed or opened. - -============================================================================== -*08.4* Vertical splits - -The ":split" command creates the new window above the current one. To make -the window appear at the left side, use: > - - :vsplit - -or: > - :vsplit two.c - -The result looks something like this: - - +--------------------------------------+ - |/* file two.c */ |/* file one.c */ | - |~ |~ | - |~ |~ | - |~ |~ | - |two.c===============one.c=============| - | | - +--------------------------------------+ - -Actually, the | lines in the middle will be in reverse video. This is called -the vertical separator. It separates the two windows left and right of it. - -There is also the ":vnew" command, to open a vertically split window on a new, -empty file. Another way to do this: > - - :vertical new - -The ":vertical" command can be inserted before another command that splits a -window. This will cause that command to split the window vertically instead -of horizontally. (If the command doesn't split a window, it works -unmodified.) - - -MOVING BETWEEN WINDOWS - -Since you can split windows horizontally and vertically as much as you like, -you can create almost any layout of windows. Then you can use these commands -to move between them: - - CTRL-W h move to the window on the left - CTRL-W j move to the window below - CTRL-W k move to the window above - CTRL-W l move to the window on the right - - CTRL-W t move to the TOP window - CTRL-W b move to the BOTTOM window - -You will notice the same letters as used for moving the cursor. And the -cursor keys can also be used, if you like. - More commands to move to other windows: |Q_wi|. - -============================================================================== -*08.5* Moving windows - -You have split a few windows, but now they are in the wrong place. Then you -need a command to move the window somewhere else. For example, you have three -windows like this: - - +----------------------------------+ - |/* file two.c */ | - |~ | - |~ | - |two.c=============================| - |/* file three.c */ | - |~ | - |~ | - |three.c===========================| - |/* file one.c */ | - |~ | - |one.c=============================| - | | - +----------------------------------+ - -Clearly the last one should be at the top. Go to that window (using CTRL-W w) -and the type this command: > - - CTRL-W K - -This uses the uppercase letter K. What happens is that the window is moved to -the very top. You will notice that K is again used for moving upwards. - When you have vertical splits, CTRL-W K will move the current window to the -top and make it occupy the full width of the Vim window. If this is your -layout: - - +-------------------------------------------+ - |/* two.c */ |/* three.c */ |/* one.c */ | - |~ |~ |~ | - |~ |~ |~ | - |~ |~ |~ | - |~ |~ |~ | - |~ |~ |~ | - |two.c=========three.c=========one.c========| - | | - +-------------------------------------------+ - -Then using CTRL-W K in the middle window (three.c) will result in: - - +-------------------------------------------+ - |/* three.c */ | - |~ | - |~ | - |three.c====================================| - |/* two.c */ |/* one.c */ | - |~ |~ | - |two.c==================one.c===============| - | | - +-------------------------------------------+ - -The other three similar commands (you can probably guess these now): - - CTRL-W H move window to the far left - CTRL-W J move window to the bottom - CTRL-W L move window to the far right - -============================================================================== -*08.6* Commands for all windows - -When you have several windows open and you want to quit Vim, you can close -each window separately. A quicker way is using this command: > - - :qall - -This stands for "quit all". If any of the windows contain changes, Vim will -not exit. The cursor will automatically be positioned in a window with -changes. You can then either use ":write" to save the changes, or ":quit!" to -throw them away. - -If you know there are windows with changes, and you want to save all these -changes, use this command: > - - :wall - -This stands for "write all". But actually, it only writes files with -changes. Vim knows it doesn't make sense to write files that were not -changed. - And then there is the combination of ":qall" and ":wall": the "write and -quit all" command: > - - :wqall - -This writes all modified files and quits Vim. - Finally, there is a command that quits Vim and throws away all changes: > - - :qall! - -Be careful, there is no way to undo this command! - - -OPENING A WINDOW FOR ALL ARGUMENTS - -To make Vim open a window for each file, start it with the "-o" argument: > - - vim -o one.txt two.txt three.txt - -This results in: - - +-------------------------------+ - |file one.txt | - |~ | - |one.txt========================| - |file two.txt | - |~ | - |two.txt========================| - |file three.txt | - |~ | - |three.txt======================| - | | - +-------------------------------+ - -The "-O" argument is used to get vertically split windows. - When Vim is already running, the ":all" command opens a window for each -file in the argument list. ":vertical all" does it with vertical splits. - -============================================================================== -*08.7* Viewing differences with vimdiff - -There is a special way to start Vim, which shows the differences between two -files. Let's take a file "main.c" and insert a few characters in one line. -Write this file with the 'backup' option set, so that the backup file -"main.c~" will contain the previous version of the file. - Type this command in a shell (not in Vim): > - - vimdiff main.c~ main.c - -Vim will start, with two windows side by side. You will only see the line -in which you added characters, and a few lines above and below it. - - VV VV - +-----------------------------------------+ - |+ +--123 lines: /* a|+ +--123 lines: /* a| <- fold - | text | text | - | text | text | - | text | text | - | text | changed text | <- changed line - | text | text | - | text | ------------------| <- deleted line - | text | text | - | text | text | - | text | text | - |+ +--432 lines: text|+ +--432 lines: text| <- fold - | ~ | ~ | - | ~ | ~ | - |main.c~==============main.c==============| - | | - +-----------------------------------------+ - -(This picture doesn't show the highlighting, use the vimdiff command for a -better look.) - -The lines that were not modified have been collapsed into one line. This is -called a closed fold. They are indicated in the picture with "<- fold". Thus -the single fold line at the top stands for 123 text lines. These lines are -equal in both files. - The line marked with "<- changed line" is highlighted, and the inserted -text is displayed with another color. This clearly shows what the difference -is between the two files. - The line that was deleted is displayed with "---" in the main.c window. -See the "<- deleted line" marker in the picture. These characters are not -really there. They just fill up main.c, so that it displays the same number -of lines as the other window. - - -THE FOLD COLUMN - -Each window has a column on the left with a slightly different background. In -the picture above these are indicated with "VV". You notice there is a plus -character there, in front of each closed fold. Move the mouse pointer to that -plus and click the left button. The fold will open, and you can see the text -that it contains. - The fold column contains a minus sign for an open fold. If you click on -this -, the fold will close. - Obviously, this only works when you have a working mouse. You can also use -"zo" to open a fold and "zc" to close it. - - -DIFFING IN VIM - -Another way to start in diff mode can be done from inside Vim. Edit the -"main.c" file, then make a split and show the differences: > - - :edit main.c - :vertical diffsplit main.c~ - -The ":vertical" command is used to make the window split vertically. If you -omit this, you will get a horizontal split. - -If you have a patch or diff file, you can use the third way to start diff -mode. First edit the file to which the patch applies. Then tell Vim the name -of the patch file: > - - :edit main.c - :vertical diffpatch main.c.diff - -WARNING: The patch file must contain only one patch, for the file you are -editing. Otherwise you will get a lot of error messages, and some files might -be patched unexpectedly. - The patching will only be done to the copy of the file in Vim. The file on -your harddisk will remain unmodified (until you decide to write the file). - - -SCROLL BINDING - -When the files have more changes, you can scroll in the usual way. Vim will -try to keep both the windows start at the same position, so you can easily see -the differences side by side. - When you don't want this for a moment, use this command: > - - :set noscrollbind - - -JUMPING TO CHANGES - -When you have disabled folding in some way, it may be difficult to find the -changes. Use this command to jump forward to the next change: > - - ]c - -To go the other way use: > - - [c - -Prepended a count to jump further away. - - -REMOVING CHANGES - -You can move text from one window to the other. This either removes -differences or adds new ones. Vim doesn't keep the highlighting updated in -all situations. To update it use this command: > - - :diffupdate - -To remove a difference, you can move the text in a highlighted block from one -window to another. Take the "main.c" and "main.c~" example above. Move the -cursor to the left window, on the line that was deleted in the other window. -Now type this command: > - - dp - -The change will be removed by putting the text of the current window in the -other window. "dp" stands for "diff put". - You can also do it the other way around. Move the cursor to the right -window, to the line where "changed" was inserted. Now type this command: > - - do - -The change will now be removed by getting the text from the other window. -Since there are no changes left now, Vim puts all text in a closed fold. -"do" stands for "diff obtain". "dg" would have been better, but that already -has a different meaning ("dgg" deletes from the cursor until the first line). - -For details about diff mode, see |vimdiff|. - -============================================================================== -*08.8* Various - -The 'laststatus' option can be used to specify when the last window has a -statusline: - - 0 never - 1 only when there are split windows (the default) - 2 always - -Many commands that edit another file have a variant that splits the window. -For Command-line commands this is done by prepending an "s". For example: -":tag" jumps to a tag, ":stag" splits the window and jumps to a -tag. - For Normal mode commands a CTRL-W is prepended. CTRL-^ jumps to the -alternate file, CTRL-W CTRL-^ splits the window and edits the alternate file. - -The 'splitbelow' option can be set to make a new window appear below the -current window. The 'splitright' option can be set to make a vertically split -window appear right of the current window. - -When splitting a window you can prepend a modifier command to tell where the -window is to appear: - - :leftabove {cmd} left or above the current window - :aboveleft {cmd} idem - :rightbelow {cmd} right or below the current window - :belowright {cmd} idem - :topleft {cmd} at the top or left of the Vim window - :botright {cmd} at the bottom or right of the Vim window - - -============================================================================== -*08.9* Tab pages - -You will have noticed that windows never overlap. That means you quickly run -out of screen space. The solution for this is called Tab pages. - -Assume you are editing "thisfile". To create a new tab page use this command: > - - :tabedit thatfile - -This will edit the file "thatfile" in a window that occupies the whole Vim -window. And you will notice a bar at the top with the two file names: - - +----------------------------------+ - | thisfile | /thatfile/ __________X| (thatfile is bold) - |/* thatfile */ | - |that | - |that | - |~ | - |~ | - |~ | - | | - +----------------------------------+ - -You now have two tab pages. The first one has a window for "thisfile" and the -second one a window for "thatfile". It's like two pages that are on top of -eachother, with a tab sticking out of each page showing the file name. - -Now use the mouse to click on "thisfile" in the top line. The result is - - +----------------------------------+ - | /thisfile/ | thatfile __________X| (thisfile is bold) - |/* thisfile */ | - |this | - |this | - |~ | - |~ | - |~ | - | | - +----------------------------------+ - -Thus you can switch between tab pages by clicking on the label in the top -line. If you don't have a mouse or don't want to use it, you can use the "gt" -command. Mnemonic: Goto Tab. - -Now let's create another tab page with the command: > - - :tab split - -This makes a new tab page with one window that is editing the same buffer as -the window we were in: - - +-------------------------------------+ - | thisfile | /thisfile/ | thatfile __X| (thisfile is bold) - |/* thisfile */ | - |this | - |this | - |~ | - |~ | - |~ | - | | - +-------------------------------------+ - -You can put ":tab" before any Ex command that opens a window. The window will -be opened in a new tab page. Another example: > - - :tab help gt - -Will show the help text for "gt" in a new tab page. - -A few more things you can do with tab pages: - -- click with the mouse in the space after the last label - The next tab page will be selected, like with "gt". - -- click with the mouse on the "X" in the top right corner - The current tab page will be closed. Unless there are unsaved - changes in the current tab page. - -- double click with the mouse in the top line - A new tab page will be created. - -- the "tabonly" command - Closes all tab pages except the current one. Unless there are unsaved - changes in other tab pages. - -For more information about tab pages see |tab-page|. - -============================================================================== - -Next chapter: |usr_09.txt| Using the GUI - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_09.txt b/share/vim/vim72/doc/usr_09.txt deleted file mode 100644 index c68f565f35..0000000000 --- a/share/vim/vim72/doc/usr_09.txt +++ /dev/null @@ -1,289 +0,0 @@ -*usr_09.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - VIM USER MANUAL - by Bram Moolenaar - - Using the GUI - - -Vim works in an ordinary terminal. GVim can do the same things and a few -more. The GUI offers menus, a toolbar, scrollbars and other items. This -chapter is about these extra things that the GUI offers. - -|09.1| Parts of the GUI -|09.2| Using the mouse -|09.3| The clipboard -|09.4| Select mode - - Next chapter: |usr_10.txt| Making big changes - Previous chapter: |usr_08.txt| Splitting windows -Table of contents: |usr_toc.txt| - -============================================================================== -*09.1* Parts of the GUI - -You might have an icon on your desktop that starts gVim. Otherwise, one of -these commands should do it: > - - gvim file.txt - vim -g file.txt - -If this doesn't work you don't have a version of Vim with GUI support. You -will have to install one first. - Vim will open a window and display "file.txt" in it. What the window looks -like depends on the version of Vim. It should resemble the following picture -(for as far as this can be shown in ASCII!). - - +----------------------------------------------------+ - | file.txt + (~/dir) - VIM X | <- window title - +----------------------------------------------------+ - | File Edit Tools Syntax Buffers Window Help | <- menubar - +----------------------------------------------------+ - | aaa bbb ccc ddd eee fff ggg hhh iii jjj | <- toolbar - | aaa bbb ccc ddd eee fff ggg hhh iii jjj | - +----------------------------------------------------+ - | file text | ^ | - | ~ | # | - | ~ | # | <- scrollbar - | ~ | # | - | ~ | # | - | ~ | # | - | | V | - +----------------------------------------------------+ - -The largest space is occupied by the file text. This shows the file in the -same way as in a terminal. With some different colors and another font -perhaps. - - -THE WINDOW TITLE - -At the very top is the window title. This is drawn by your window system. -Vim will set the title to show the name of the current file. First comes the -name of the file. Then some special characters and the directory of the file -in parens. These special character can be present: - - - The file cannot be modified (e.g., a help file) - + The file contains changes - = The file is read-only - =+ The file is read-only, contains changes anyway - -If nothing is shown you have an ordinary, unchanged file. - - -THE MENUBAR - -You know how menus work, right? Vim has the usual items, plus a few more. -Browse them to get an idea of what you can use them for. A relevant submenu -is Edit/Global Settings. You will find these entries: - - Toggle Toolbar make the toolbar appear/disappear - Toggle Bottom Scrollbar make a scrollbar appear/disappear at the bottom - Toggle Left Scrollbar make a scrollbar appear/disappear at the left - Toggle Right Scrollbar make a scrollbar appear/disappear at the right - -On most systems you can tear-off the menus. Select the top item of the menu, -the one that looks like a dashed line. You will get a separate window with -the items of the menu. It will hang around until you close the window. - - -THE TOOLBAR - -This contains icons for the most often used actions. Hopefully the icons are -self-explanatory. There are tooltips to get an extra hint (move the mouse -pointer to the icon without clicking and don't move it for a second). - -The "Edit/Global Settings/Toggle Toolbar" menu item can be used to make the -toolbar disappear. If you never want a toolbar, use this command in your -vimrc file: > - - :set guioptions-=T - -This removes the 'T' flag from the 'guioptions' option. Other parts of the -GUI can also be enabled or disabled with this option. See the help for it. - - -THE SCROLLBARS - -By default there is one scrollbar on the right. It does the obvious thing. -When you split the window, each window will get its own scrollbar. - You can make a horizontal scrollbar appear with the menu item -Edit/Global Settings/Toggle Bottom Scrollbar. This is useful in diff mode, or -when the 'wrap' option has been reset (more about that later). - -When there are vertically split windows, only the windows on the right side -will have a scrollbar. However, when you move the cursor to a window on the -left, it will be this one the that scrollbar controls. This takes a bit of -time to get used to. - When you work with vertically split windows, consider adding a scrollbar on -the left. This can be done with a menu item, or with the 'guioptions' option: -> - :set guioptions+=l - -This adds the 'l' flag to 'guioptions'. - -============================================================================== -*09.2* Using the mouse - -Standards are wonderful. In Microsoft Windows, you can use the mouse to -select text in a standard manner. The X Window system also has a standard -system for using the mouse. Unfortunately, these two standards are not the -same. - Fortunately, you can customize Vim. You can make the behavior of the mouse -work like an X Window system mouse or a Microsoft Windows mouse. The following -command makes the mouse behave like an X Window mouse: > - - :behave xterm - -The following command makes the mouse work like a Microsoft Windows mouse: > - - :behave mswin - -The default behavior of the mouse on UNIX systems is xterm. The default -behavior on a Microsoft Windows system is selected during the installation -process. For details about what the two behaviors are, see |:behave|. Here -follows a summary. - - -XTERM MOUSE BEHAVIOR - -Left mouse click position the cursor -Left mouse drag select text in Visual mode -Middle mouse click paste text from the clipboard -Right mouse click extend the selected text until the mouse - pointer - - -MSWIN MOUSE BEHAVIOR - -Left mouse click position the cursor -Left mouse drag select text in Select mode (see |09.4|) -Left mouse click, with Shift extend the selected text until the mouse - pointer -Middle mouse click paste text from the clipboard -Right mouse click display a pop-up menu - - -The mouse can be further tuned. Check out these options if you want to change -the way how the mouse works: - - 'mouse' in which mode the mouse is used by Vim - 'mousemodel' what effect a mouse click has - 'mousetime' time between clicks for a double-click - 'mousehide' hide the mouse while typing - 'selectmode' whether the mouse starts Visual or Select mode - -============================================================================== -*09.3* The clipboard - -In section |04.7| the basic use of the clipboard was explained. There is one -essential thing to explain about X-windows: There are actually two places to -exchange text between programs. MS-Windows doesn't have this. - -In X-Windows there is the "current selection". This is the text that is -currently highlighted. In Vim this is the Visual area (this assumes you are -using the default option settings). You can paste this selection in another -application without any further action. - For example, in this text select a few words with the mouse. Vim will -switch to Visual mode and highlight the text. Now start another gVim, without -a file name argument, so that it displays an empty window. Click the middle -mouse button. The selected text will be inserted. - -The "current selection" will only remain valid until some other text is -selected. After doing the paste in the other gVim, now select some characters -in that window. You will notice that the words that were previously selected -in the other gVim window are displayed differently. This means that it no -longer is the current selection. - -You don't need to select text with the mouse, using the keyboard commands for -Visual mode works just as well. - - -THE REAL CLIPBOARD - -Now for the other place with which text can be exchanged. We call this the -"real clipboard", to avoid confusion. Often both the "current selection" and -the "real clipboard" are called clipboard, you'll have to get used to that. - To put text on the real clipboard, select a few different words in one of -the gVims you have running. Then use the Edit/Copy menu entry. Now the text -has been copied to the real clipboard. You can't see this, unless you have -some application that shows the clipboard contents (e.g., KDE's klipper). - Now select the other gVim, position the cursor somewhere and use the -Edit/Paste menu. You will see the text from the real clipboard is inserted. - - -USING BOTH - -This use of both the "current selection" and the "real clipboard" might sound -a bit confusing. But it is very useful. Let's show this with an example. -Use one gVim with a text file and perform these actions: - -- Select two words in Visual mode. -- Use the Edit/Copy menu to get these words onto the clipboard. -- Select one other word in Visual mode. -- Use the Edit/Paste menu item. What will happen is that the single selected - word is replaced with the two words from the clipboard. -- Move the mouse pointer somewhere else and click the middle button. You - will see that the word you just overwrote with the clipboard is inserted - here. - -If you use the "current selection" and the "real clipboard" with care, you can -do a lot of useful editing with them. - - -USING THE KEYBOARD - -If you don't like using the mouse, you can access the current selection and -the real clipboard with two registers. The "* register is for the current -selection. - To make text become the current selection, use Visual mode. For example, -to select a whole line just press "V". - To insert the current selection before the cursor: > - - "*P - -Notice the uppercase "P". The lowercase "p" puts the text after the cursor. - -The "+ register is used for the real clipboard. For example, to copy the text -from the cursor position until the end of the line to the clipboard: > - - "+y$ - -Remember, "y" is yank, which is Vim's copy command. - To insert the contents of the real clipboard before the cursor: > - - "+P - -It's the same as for the current selection, but uses the plus (+) register -instead of the star (*) register. - -============================================================================== -*09.4* Select mode - -And now something that is used more often on MS-Windows than on X-Windows. -But both can do it. You already know about Visual mode. Select mode is like -Visual mode, because it is also used to select text. But there is an obvious -difference: When typing text, the selected text is deleted and the typed text -replaces it. - -To start working with Select mode, you must first enable it (for MS-Windows -it is probably already enabled, but you can do this anyway): > - - :set selectmode+=mouse - -Now use the mouse to select some text. It is highlighted like in Visual mode. -Now press a letter. The selected text is deleted, and the single letter -replaces it. You are in Insert mode now, thus you can continue typing. - -Since typing normal text causes the selected text to be deleted, you can not -use the normal movement commands "hjkl", "w", etc. Instead, use the shifted -function keys. <S-Left> (shifted cursor left key) moves the cursor left. The -selected text is changed like in Visual mode. The other shifted cursor keys -do what you expect. <S-End> and <S-Home> also work. - -You can tune the way Select mode works with the 'selectmode' option. - -============================================================================== - -Next chapter: |usr_10.txt| Making big changes - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_10.txt b/share/vim/vim72/doc/usr_10.txt deleted file mode 100644 index c1334a5431..0000000000 --- a/share/vim/vim72/doc/usr_10.txt +++ /dev/null @@ -1,824 +0,0 @@ -*usr_10.txt* For Vim version 7.2. Last change: 2006 Nov 05 - - VIM USER MANUAL - by Bram Moolenaar - - Making big changes - - -In chapter 4 several ways to make small changes were explained. This chapter -goes into making changes that are repeated or can affect a large amount of -text. The Visual mode allows doing various things with blocks of text. Use -an external program to do really complicated things. - -|10.1| Record and playback commands -|10.2| Substitution -|10.3| Command ranges -|10.4| The global command -|10.5| Visual block mode -|10.6| Reading and writing part of a file -|10.7| Formatting text -|10.8| Changing case -|10.9| Using an external program - - Next chapter: |usr_11.txt| Recovering from a crash - Previous chapter: |usr_09.txt| Using the GUI -Table of contents: |usr_toc.txt| - -============================================================================== -*10.1* Record and playback commands - -The "." command repeats the preceding change. But what if you want to do -something more complex than a single change? That's where command recording -comes in. There are three steps: - -1. The "q{register}" command starts recording keystrokes into the register - named {register}. The register name must be between a and z. -2. Type your commands. -3. To finish recording, press q (without any extra character). - -You can now execute the macro by typing the command "@{register}". - -Take a look at how to use these commands in practice. You have a list of -filenames that look like this: - - stdio.h ~ - fcntl.h ~ - unistd.h ~ - stdlib.h ~ - -And what you want is the following: - - #include "stdio.h" ~ - #include "fcntl.h" ~ - #include "unistd.h" ~ - #include "stdlib.h" ~ - -You start by moving to the first character of the first line. Next you -execute the following commands: - - qa Start recording a macro in register a. - ^ Move to the beginning of the line. - i#include "<Esc> Insert the string #include " at the beginning - of the line. - $ Move to the end of the line. - a"<Esc> Append the character double quotation mark (") - to the end of the line. - j Go to the next line. - q Stop recording the macro. - -Now that you have done the work once, you can repeat the change by typing the -command "@a" three times. - The "@a" command can be preceded by a count, which will cause the macro to -be executed that number of times. In this case you would type: > - - 3@a - - -MOVE AND EXECUTE - -You might have the lines you want to change in various places. Just move the -cursor to each location and use the "@a" command. If you have done that once, -you can do it again with "@@". That's a bit easier to type. If you now -execute register b with "@b", the next "@@" will use register b. - If you compare the playback method with using ".", there are several -differences. First of all, "." can only repeat one change. As seen in the -example above, "@a" can do several changes, and move around as well. -Secondly, "." can only remember the last change. Executing a register allows -you to make any changes and then still use "@a" to replay the recorded -commands. Finally, you can use 26 different registers. Thus you can remember -26 different command sequences to execute. - - -USING REGISTERS - -The registers used for recording are the same ones you used for yank and -delete commands. This allows you to mix recording with other commands to -manipulate the registers. - Suppose you have recorded a few commands in register n. When you execute -this with "@n" you notice you did something wrong. You could try recording -again, but perhaps you will make another mistake. Instead, use this trick: - - G Go to the end of the file. - o<Esc> Create an empty line. - "np Put the text from the n register. You now see - the commands you typed as text in the file. - {edits} Change the commands that were wrong. This is - just like editing text. - 0 Go to the start of the line. - "ny$ Yank the corrected commands into the n - register. - dd Delete the scratch line. - -Now you can execute the corrected commands with "@n". (If your recorded -commands include line breaks, adjust the last two items in the example to -include all the lines.) - - -APPENDING TO A REGISTER - -So far we have used a lowercase letter for the register name. To append to a -register, use an uppercase letter. - Suppose you have recorded a command to change a word to register c. It -works properly, but you would like to add a search for the next word to -change. This can be done with: > - - qC/word<Enter>q - -You start with "qC", which records to the c register and appends. Thus -writing to an uppercase register name means to append to the register with -the same letter, but lowercase. - -This works both with recording and with yank and delete commands. For -example, you want to collect a sequence of lines into the a register. Yank -the first line with: > - - "aY - -Now move to the second line, and type: > - - "AY - -Repeat this command for all lines. The a register now contains all those -lines, in the order you yanked them. - -============================================================================== -*10.2* Substitution *find-replace* - -The ":substitute" command enables you to perform string replacements on a -whole range of lines. The general form of this command is as follows: > - - :[range]substitute/from/to/[flags] - -This command changes the "from" string to the "to" string in the lines -specified with [range]. For example, you can change "Professor" to "Teacher" -in all lines with the following command: > - - :%substitute/Professor/Teacher/ -< - Note: - The ":substitute" command is almost never spelled out completely. - Most of the time, people use the abbreviated version ":s". From here - on the abbreviation will be used. - -The "%" before the command specifies the command works on all lines. Without -a range, ":s" only works on the current line. More about ranges in the next -section |10.3|. - -By default, the ":substitute" command changes only the first occurrence on -each line. For example, the preceding command changes the line: - - Professor Smith criticized Professor Johnson today. ~ - -to: - - Teacher Smith criticized Professor Johnson today. ~ - -To change every occurrence on the line, you need to add the g (global) flag. -The command: > - - :%s/Professor/Teacher/g - -results in (starting with the original line): - - Teacher Smith criticized Teacher Johnson today. ~ - -Other flags include p (print), which causes the ":substitute" command to print -out the last line it changes. The c (confirm) flag tells ":substitute" to ask -you for confirmation before it performs each substitution. Enter the -following: > - - :%s/Professor/Teacher/c - -Vim finds the first occurrence of "Professor" and displays the text it is -about to change. You get the following prompt: > - - replace with Teacher (y/n/a/q/l/^E/^Y)? - -At this point, you must enter one of the following answers: - - y Yes; make this change. - n No; skip this match. - a All; make this change and all remaining ones without - further confirmation. - q Quit; don't make any more changes. - l Last; make this change and then quit. - CTRL-E Scroll the text one line up. - CTRL-Y Scroll the text one line down. - - -The "from" part of the substitute command is actually a pattern. The same -kind as used for the search command. For example, this command only -substitutes "the" when it appears at the start of a line: > - - :s/^the/these/ - -If you are substituting with a "from" or "to" part that includes a slash, you -need to put a backslash before it. A simpler way is to use another character -instead of the slash. A plus, for example: > - - :s+one/two+one or two+ - -============================================================================== -*10.3* Command ranges - -The ":substitute" command, and many other : commands, can be applied to a -selection of lines. This is called a range. - The simple form of a range is {number},{number}. For example: > - - :1,5s/this/that/g - -Executes the substitute command on the lines 1 to 5. Line 5 is included. -The range is always placed before the command. - -A single number can be used to address one specific line: > - - :54s/President/Fool/ - -Some commands work on the whole file when you do not specify a range. To make -them work on the current line the "." address is used. The ":write" command -works like that. Without a range, it writes the whole file. To make it write -only the current line into a file: > - - :.write otherfile - -The first line always has number one. How about the last line? The "$" -character is used for this. For example, to substitute in the lines from the -cursor to the end: > - - :.,$s/yes/no/ - -The "%" range that we used before, is actually a short way to say "1,$", from -the first to the last line. - - -USING A PATTERN IN A RANGE - -Suppose you are editing a chapter in a book, and want to replace all -occurrences of "grey" with "gray". But only in this chapter, not in the next -one. You know that only chapter boundaries have the word "Chapter" in the -first column. This command will work then: > - - :?^Chapter?,/^Chapter/s=grey=gray=g - -You can see a search pattern is used twice. The first "?^Chapter?" finds the -line above the current position that matches this pattern. Thus the ?pattern? -range is used to search backwards. Similarly, "/^Chapter/" is used to search -forward for the start of the next chapter. - To avoid confusion with the slashes, the "=" character was used in the -substitute command here. A slash or another character would have worked as -well. - - -ADD AND SUBTRACT - -There is a slight error in the above command: If the title of the next chapter -had included "grey" it would be replaced as well. Maybe that's what you -wanted, but what if you didn't? Then you can specify an offset. - To search for a pattern and then use the line above it: > - - /Chapter/-1 - -You can use any number instead of the 1. To address the second line below the -match: > - - /Chapter/+2 - -The offsets can also be used with the other items in a range. Look at this -one: > - - :.+3,$-5 - -This specifies the range that starts three lines below the cursor and ends -five lines before the last line in the file. - - -USING MARKS - -Instead of figuring out the line numbers of certain positions, remembering them -and typing them in a range, you can use marks. - Place the marks as mentioned in chapter 3. For example, use "mt" to mark -the top of an area and "mb" to mark the bottom. Then you can use this range -to specify the lines between the marks (including the lines with the marks): > - - :'t,'b - - -VISUAL MODE AND RANGES - -You can select text with Visual mode. If you then press ":" to start a colon -command, you will see this: > - - :'<,'> - -Now you can type the command and it will be applied to the range of lines that -was visually selected. - - Note: - When using Visual mode to select part of a line, or using CTRL-V to - select a block of text, the colon commands will still apply to whole - lines. This might change in a future version of Vim. - -The '< and '> are actually marks, placed at the start and end of the Visual -selection. The marks remain at their position until another Visual selection -is made. Thus you can use the "'<" command to jump to position where the -Visual area started. And you can mix the marks with other items: > - - :'>,$ - -This addresses the lines from the end of the Visual area to the end of the -file. - - -A NUMBER OF LINES - -When you know how many lines you want to change, you can type the number and -then ":". For example, when you type "5:", you will get: > - - :.,.+4 - -Now you can type the command you want to use. It will use the range "." -(current line) until ".+4" (four lines down). Thus it spans five lines. - -============================================================================== -*10.4* The global command - -The ":global" command is one of the more powerful features of Vim. It allows -you to find a match for a pattern and execute a command there. The general -form is: > - - :[range]global/{pattern}/{command} - -This is similar to the ":substitute" command. But, instead of replacing the -matched text with other text, the command {command} is executed. - - Note: - The command executed for ":global" must be one that starts with a - colon. Normal mode commands can not be used directly. The |:normal| - command can do this for you. - -Suppose you want to change "foobar" to "barfoo", but only in C++ style -comments. These comments start with "//". Use this command: > - - :g+//+s/foobar/barfoo/g - -This starts with ":g". That is short for ":global", just like ":s" is short -for ":substitute". Then the pattern, enclosed in plus characters. Since the -pattern we are looking for contains a slash, this uses the plus character to -separate the pattern. Next comes the substitute command that changes "foobar" -into "barfoo". - The default range for the global command is the whole file. Thus no range -was specified in this example. This is different from ":substitute", which -works on one line without a range. - The command isn't perfect, since it also matches lines where "//" appears -halfway a line, and the substitution will also take place before the "//". - -Just like with ":substitute", any pattern can be used. When you learn more -complicated patterns later, you can use them here. - -============================================================================== -*10.5* Visual block mode - -With CTRL-V you can start selection of a rectangular area of text. There are -a few commands that do something special with the text block. - -There is something special about using the "$" command in Visual block mode. -When the last motion command used was "$", all lines in the Visual selection -will extend until the end of the line, also when the line with the cursor is -shorter. This remains effective until you use a motion command that moves the -cursor horizontally. Thus using "j" keeps it, "h" stops it. - - -INSERTING TEXT - -The command "I{string}<Esc>" inserts the text {string} in each line, just -left of the visual block. You start by pressing CTRL-V to enter visual block -mode. Now you move the cursor to define your block. Next you type I to enter -Insert mode, followed by the text to insert. As you type, the text appears on -the first line only. - After you press <Esc> to end the insert, the text will magically be -inserted in the rest of the lines contained in the visual selection. Example: - - include one ~ - include two ~ - include three ~ - include four ~ - -Move the cursor to the "o" of "one" and press CTRL-V. Move it down with "3j" -to "four". You now have a block selection that spans four lines. Now type: > - - Imain.<Esc> - -The result: - - include main.one ~ - include main.two ~ - include main.three ~ - include main.four ~ - -If the block spans short lines that do not extend into the block, the text is -not inserted in that line. For example, make a Visual block selection that -includes the word "long" in the first and last line of this text, and thus has -no text selected in the second line: - - This is a long line ~ - short ~ - Any other long line ~ - - ^^^^ selected block - -Now use the command "Ivery <Esc>". The result is: - - This is a very long line ~ - short ~ - Any other very long line ~ - -In the short line no text was inserted. - -If the string you insert contains a newline, the "I" acts just like a Normal -insert command and affects only the first line of the block. - -The "A" command works the same way, except that it appends after the right -side of the block. And it does insert text in a short line. Thus you can -make a choice whether you do or don't want to append text to a short line. - There is one special case for "A": Select a Visual block and then use "$" -to make the block extend to the end of each line. Using "A" now will append -the text to the end of each line. - Using the same example from above, and then typing "$A XXX<Esc>, you get -this result: - - This is a long line XXX ~ - short XXX ~ - Any other long line XXX ~ - -This really requires using the "$" command. Vim remembers that it was used. -Making the same selection by moving the cursor to the end of the longest line -with other movement commands will not have the same result. - - -CHANGING TEXT - -The Visual block "c" command deletes the block and then throws you into Insert -mode to enable you to type in a string. The string will be inserted in each -line in the block. - Starting with the same selection of the "long" words as above, then typing -"c_LONG_<Esc>", you get this: - - This is a _LONG_ line ~ - short ~ - Any other _LONG_ line ~ - -Just like with "I" the short line is not changed. Also, you can't enter a -newline in the new text. - -The "C" command deletes text from the left edge of the block to the end of -line. It then puts you in Insert mode so that you can type in a string, -which is added to the end of each line. - Starting with the same text again, and typing "Cnew text<Esc>" you get: - - This is a new text ~ - short ~ - Any other new text ~ - -Notice that, even though only the "long" word was selected, the text after it -is deleted as well. Thus only the location of the left edge of the visual -block really matters. - Again, short lines that do not reach into the block are excluded. - -Other commands that change the characters in the block: - - ~ swap case (a -> A and A -> a) - U make uppercase (a -> A and A -> A) - u make lowercase (a -> a and A -> a) - - -FILLING WITH A CHARACTER - -To fill the whole block with one character, use the "r" command. Again, -starting with the same example text from above, and then typing "rx": - - This is a xxxx line ~ - short ~ - Any other xxxx line ~ - - - Note: - If you want to include characters beyond the end of the line in the - block, check out the 'virtualedit' feature in chapter 25. - - -SHIFTING - -The command ">" shifts the selected text to the right one shift amount, -inserting whitespace. The starting point for this shift is the left edge of -the visual block. - With the same example again, ">" gives this result: - - This is a long line ~ - short ~ - Any other long line ~ - -The shift amount is specified with the 'shiftwidth' option. To change it to -use 4 spaces: > - - :set shiftwidth=4 - -The "<" command removes one shift amount of whitespace at the left -edge of the block. This command is limited by the amount of text that is -there; so if there is less than a shift amount of whitespace available, it -removes what it can. - - -JOINING LINES - -The "J" command joins all selected lines together into one line. Thus it -removes the line breaks. Actually, the line break, leading white space and -trailing white space is replaced by one space. Two spaces are used after a -line ending (that can be changed with the 'joinspaces' option). - Let's use the example that we got so familiar with now. The result of -using the "J" command: - - This is a long line short Any other long line ~ - -The "J" command doesn't require a blockwise selection. It works with "v" and -"V" selection in exactly the same way. - -If you don't want the white space to be changed, use the "gJ" command. - -============================================================================== -*10.6* Reading and writing part of a file - -When you are writing an e-mail message, you may want to include another file. -This can be done with the ":read {filename}" command. The text of the file is -put below the cursor line. - Starting with this text: - - Hi John, ~ - Here is the diff that fixes the bug: ~ - Bye, Pierre. ~ - -Move the cursor to the second line and type: > - - :read patch - -The file named "patch" will be inserted, with this result: - - Hi John, ~ - Here is the diff that fixes the bug: ~ - 2c2 ~ - < for (i = 0; i <= length; ++i) ~ - --- ~ - > for (i = 0; i < length; ++i) ~ - Bye, Pierre. ~ - -The ":read" command accepts a range. The file will be put below the last line -number of this range. Thus ":$r patch" appends the file "patch" at the end of -the file. - What if you want to read the file above the first line? This can be done -with the line number zero. This line doesn't really exist, you will get an -error message when using it with most commands. But this command is allowed: -> - :0read patch - -The file "patch" will be put above the first line of the file. - - -WRITING A RANGE OF LINES - -To write a range of lines to a file, the ":write" command can be used. -Without a range it writes the whole file. With a range only the specified -lines are written: > - - :.,$write tempo - -This writes the lines from the cursor until the end of the file into the file -"tempo". If this file already exists you will get an error message. Vim -protects you from accidentally overwriting an existing file. If you know what -you are doing and want to overwrite the file, append !: > - - :.,$write! tempo - -CAREFUL: The ! must follow the ":write" command immediately, without white -space. Otherwise it becomes a filter command, which is explained later in -this chapter. - - -APPENDING TO A FILE - -In the first section of this chapter was explained how to collect a number of -lines into a register. The same can be done to collect lines in a file. -Write the first line with this command: > - - :.write collection - -Now move the cursor to the second line you want to collect, and type this: > - - :.write >>collection - -The ">>" tells Vim the "collection" file is not to be written as a new file, -but the line must be appended at the end. You can repeat this as many times -as you like. - -============================================================================== -*10.7* Formatting text - -When you are typing plain text, it's nice if the length of each line is -automatically trimmed to fit in the window. To make this happen while -inserting text, set the 'textwidth' option: > - - :set textwidth=72 - -You might remember that in the example vimrc file this command was used for -every text file. Thus if you are using that vimrc file, you were already -using it. To check the current value of 'textwidth': > - - :set textwidth - -Now lines will be broken to take only up to 72 characters. But when you -insert text halfway a line, or when you delete a few words, the lines will get -too long or too short. Vim doesn't automatically reformat the text. - To tell Vim to format the current paragraph: > - - gqap - -This starts with the "gq" command, which is an operator. Following is "ap", -the text object that stands for "a paragraph". A paragraph is separated from -the next paragraph by an empty line. - - Note: - A blank line, which contains white space, does NOT separate - paragraphs. This is hard to notice! - -Instead of "ap" you could use any motion or text object. If your paragraphs -are properly separated, you can use this command to format the whole file: > - - gggqG - -"gg" takes you to the first line, "gq" is the format operator and "G" the -motion that jumps to the last line. - -In case your paragraphs aren't clearly defined, you can format just the lines -you manually select. Move the cursor to the first line you want to format. -Start with the command "gqj". This formats the current line and the one below -it. If the first line was short, words from the next line will be appended. -If it was too long, words will be moved to the next line. The cursor moves to -the second line. Now you can use "." to repeat the command. Keep doing this -until you are at the end of the text you want to format. - -============================================================================== -*10.8* Changing case - -You have text with section headers in lowercase. You want to make the word -"section" all uppercase. Do this with the "gU" operator. Start with the -cursor in the first column: > - - gUw -< section header ----> SECTION header - -The "gu" operator does exactly the opposite: > - - guw -< SECTION header ----> section header - -You can also use "g~" to swap case. All these are operators, thus they work -with any motion command, with text objects and in Visual mode. - To make an operator work on lines you double it. The delete operator is -"d", thus to delete a line you use "dd". Similarly, "gugu" makes a whole line -lowercase. This can be shortened to "guu". "gUgU" is shortened to "gUU" and -"g~g~" to "g~~". Example: > - - g~~ -< Some GIRLS have Fun ----> sOME girls HAVE fUN ~ - -============================================================================== -*10.9* Using an external program - -Vim has a very powerful set of commands, it can do anything. But there may -still be something that an external command can do better or faster. - The command "!{motion}{program}" takes a block of text and filters it -through an external program. In other words, it runs the system command -represented by {program}, giving it the block of text represented by {motion} -as input. The output of this command then replaces the selected block. - Because this summarizes badly if you are unfamiliar with UNIX filters, take -a look at an example. The sort command sorts a file. If you execute the -following command, the unsorted file input.txt will be sorted and written to -output.txt. (This works on both UNIX and Microsoft Windows.) > - - sort <input.txt >output.txt - -Now do the same thing in Vim. You want to sort lines 1 through 5 of a file. -You start by putting the cursor on line 1. Next you execute the following -command: > - - !5G - -The "!" tells Vim that you are performing a filter operation. The Vim editor -expects a motion command to follow, indicating which part of the file to -filter. The "5G" command tells Vim to go to line 5, so it now knows that it -is to filter lines 1 (the current line) through 5. - In anticipation of the filtering, the cursor drops to the bottom of the -screen and a ! prompt displays. You can now type in the name of the filter -program, in this case "sort". Therefore, your full command is as follows: > - - !5Gsort<Enter> - -The result is that the sort program is run on the first 5 lines. The output -of the program replaces these lines. - - line 55 line 11 - line 33 line 22 - line 11 --> line 33 - line 22 line 44 - line 44 line 55 - last line last line - -The "!!" command filters the current line through a filter. In Unix the "date" -command prints the current time and date. "!!date<Enter>" replaces the current -line with the output of "date". This is useful to add a timestamp to a file. - - -WHEN IT DOESN'T WORK - -Starting a shell, sending it text and capturing the output requires that Vim -knows how the shell works exactly. When you have problems with filtering, -check the values of these options: - - 'shell' specifies the program that Vim uses to execute - external programs. - 'shellcmdflag' argument to pass a command to the shell - 'shellquote' quote to be used around the command - 'shellxquote' quote to be used around the command and redirection - 'shelltype' kind of shell (only for the Amiga) - 'shellslash' use forward slashes in the command (only for - MS-Windows and alikes) - 'shellredir' string used to write the command output into a file - -On Unix this is hardly ever a problem, because there are two kinds of shells: -"sh" like and "csh" like. Vim checks the 'shell' option and sets related -options automatically, depending on whether it sees "csh" somewhere in -'shell'. - On MS-Windows, however, there are many different shells and you might have -to tune the options to make filtering work. Check the help for the options -for more information. - - -READING COMMAND OUTPUT - -To read the contents of the current directory into the file, use this: - -on Unix: > - :read !ls -on MS-Windows: > - :read !dir - -The output of the "ls" or "dir" command is captured and inserted in the text, -below the cursor. This is similar to reading a file, except that the "!" is -used to tell Vim that a command follows. - The command may have arguments. And a range can be used to tell where Vim -should put the lines: > - - :0read !date -u - -This inserts the current time and date in UTC format at the top of the file. -(Well, if you have a date command that accepts the "-u" argument.) Note the -difference with using "!!date": that replaced a line, while ":read !date" will -insert a line. - - -WRITING TEXT TO A COMMAND - -The Unix command "wc" counts words. To count the words in the current file: > - - :write !wc - -This is the same write command as before, but instead of a file name the "!" -character is used and the name of an external command. The written text will -be passed to the specified command as its standard input. The output could -look like this: - - 4 47 249 ~ - -The "wc" command isn't verbose. This means you have 4 lines, 47 words and 249 -characters. - -Watch out for this mistake: > - - :write! wc - -This will write the file "wc" in the current directory, with force. White -space is important here! - - -REDRAWING THE SCREEN - -If the external command produced an error message, the display may have been -messed up. Vim is very efficient and only redraws those parts of the screen -that it knows need redrawing. But it can't know about what another program -has written. To tell Vim to redraw the screen: > - - CTRL-L - -============================================================================== - -Next chapter: |usr_11.txt| Recovering from a crash - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_11.txt b/share/vim/vim72/doc/usr_11.txt deleted file mode 100644 index 67328846af..0000000000 --- a/share/vim/vim72/doc/usr_11.txt +++ /dev/null @@ -1,287 +0,0 @@ -*usr_11.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - VIM USER MANUAL - by Bram Moolenaar - - Recovering from a crash - - -Did your computer crash? And you just spent hours editing? Don't panic! Vim -keeps enough information on harddisk to be able to restore most of your work. -This chapter shows you how to get your work back and explains how the swap -file is used. - -|11.1| Basic recovery -|11.2| Where is the swap file? -|11.3| Crashed or not? -|11.4| Further reading - - Next chapter: |usr_12.txt| Clever tricks - Previous chapter: |usr_10.txt| Making big changes -Table of contents: |usr_toc.txt| - -============================================================================== -*11.1* Basic recovery - -In most cases recovering a file is quite simple, assuming you know which file -you were editing (and the harddisk is still working). Start Vim on the file, -with the "-r" argument added: > - - vim -r help.txt - -Vim will read the swap file (used to store text you were editing) and may read -bits and pieces of the original file. If all is well, you will see these -messages (with different file names, of course): - - Using swap file ".help.txt.swp" ~ - Original file "~/vim/runtime/doc/help.txt" ~ - Recovery completed. You should check if everything is OK. ~ - (You might want to write out this file under another name ~ - and run diff with the original file to check for changes) ~ - Delete the .swp file afterwards. ~ - -To be on the safe side, write this file under another name: > - - :write help.txt.recovered - -Compare the file with the original file to check if you ended up with what you -expected. Vimdiff is very useful for this |08.7|. Watch out for the original -file to contain a more recent version (you saved the file just before the -computer crashed). And check that no lines are missing (something went wrong -that Vim could not recover). - If Vim produces warning messages when recovering, read them carefully. -This is rare though. - -It's normal that the last few changes can not be recovered. Vim flushes the -changes to disk when you don't type for about four seconds, or after typing -about two hundred characters. This is set with the 'updatetime' and -'updatecount' options. Thus when Vim didn't get a chance to save itself when -the system went down, the changes after the last flush will be lost. - -If you were editing without a file name, give an empty string as argument: > - - vim -r "" - -You must be in the right directory, otherwise Vim can't find the swap file. - -============================================================================== -*11.2* Where is the swap file? - -Vim can store the swap file in several places. Normally it is in the same -directory as the original file. To find it, change to the directory of the -file, and use: > - - vim -r - -Vim will list the swap files that it can find. It will also look in other -directories where the swap file for files in the current directory may be -located. It will not find swap files in any other directories though, it -doesn't search the directory tree. - The output could look like this: - - Swap files found: ~ - In current directory: ~ - 1. .main.c.swp ~ - owned by: mool dated: Tue May 29 21:00:25 2001 ~ - file name: ~mool/vim/vim6/src/main.c ~ - modified: YES ~ - user name: mool host name: masaka.moolenaar.net ~ - process ID: 12525 ~ - In directory ~/tmp: ~ - -- none -- ~ - In directory /var/tmp: ~ - -- none -- ~ - In directory /tmp: ~ - -- none -- ~ - -If there are several swap files that look like they may be the one you want to -use, a list is given of these swap files and you are requested to enter the -number of the one you want to use. Carefully look at the dates to decide -which one you want to use. - In case you don't know which one to use, just try them one by one and check -the resulting files if they are what you expected. - - -USING A SPECIFIC SWAP FILE - -If you know which swap file needs to be used, you can recover by giving the -swap file name. Vim will then finds out the name of the original file from -the swap file. - -Example: > - vim -r .help.txt.swo - -This is also handy when the swap file is in another directory than expected. -If this still does not work, see what file names Vim reports and rename the -files accordingly. Check the 'directory' option to see where Vim may have -put the swap file. - - Note: - Vim tries to find the swap file by searching the directories in the - 'dir' option, looking for files that match "filename.sw?". If - wildcard expansion doesn't work (e.g., when the 'shell' option is - invalid), Vim does a desperate try to find the file "filename.swp". - If that fails too, you will have to give the name of the swapfile - itself to be able to recover the file. - -============================================================================== -*11.3* Crashed or not? *ATTENTION* *E325* - -Vim tries to protect you from doing stupid things. Suppose you innocently -start editing a file, expecting the contents of the file to show up. Instead, -Vim produces a very long message: - - E325: ATTENTION ~ - Found a swap file by the name ".main.c.swp" ~ - owned by: mool dated: Tue May 29 21:09:28 2001 ~ - file name: ~mool/vim/vim6/src/main.c ~ - modified: no ~ - user name: mool host name: masaka.moolenaar.net ~ - process ID: 12559 (still running) ~ - While opening file "main.c" ~ - dated: Tue May 29 19:46:12 2001 ~ - ~ - (1) Another program may be editing the same file. ~ - If this is the case, be careful not to end up with two ~ - different instances of the same file when making changes. ~ - Quit, or continue with caution. ~ - ~ - (2) An edit session for this file crashed. ~ - If this is the case, use ":recover" or "vim -r main.c" ~ - to recover the changes (see ":help recovery"). ~ - If you did this already, delete the swap file ".main.c.swp" ~ - to avoid this message. ~ - -You get this message, because, when starting to edit a file, Vim checks if a -swap file already exists for that file. If there is one, there must be -something wrong. It may be one of these two situations. - -1. Another edit session is active on this file. Look in the message for the - line with "process ID". It might look like this: - - process ID: 12559 (still running) ~ - - The text "(still running)" indicates that the process editing this file - runs on the same computer. When working on a non-Unix system you will not - get this extra hint. When editing a file over a network, you may not see - the hint, because the process might be running on another computer. In - those two cases you must find out what the situation is yourself. - If there is another Vim editing the same file, continuing to edit will - result in two versions of the same file. The one that is written last will - overwrite the other one, resulting in loss of changes. You better quit - this Vim. - -2. The swap file might be the result from a previous crash of Vim or the - computer. Check the dates mentioned in the message. If the date of the - swap file is newer than the file you were editing, and this line appears: - - modified: YES ~ - - Then you very likely have a crashed edit session that is worth recovering. - If the date of the file is newer than the date of the swap file, then - either it was changed after the crash (perhaps you recovered it earlier, - but didn't delete the swap file?), or else the file was saved before the - crash but after the last write of the swap file (then you're lucky: you - don't even need that old swap file). Vim will warn you for this with this - extra line: - - NEWER than swap file! ~ - - -UNREADABLE SWAP FILE - -Sometimes the line - - [cannot be read] ~ - -will appear under the name of the swap file. This can be good or bad, -depending on circumstances. - -It is good if a previous editing session crashed without having made any -changes to the file. Then a directory listing of the swap file will show -that it has zero bytes. You may delete it and proceed. - -It is slightly bad if you don't have read permission for the swap file. You -may want to view the file read-only, or quit. On multi-user systems, if you -yourself did the last changes under a different login name, a logout -followed by a login under that other name might cure the "read error". Or -else you might want to find out who last edited (or is editing) the file and -have a talk with them. - -It is very bad if it means there is a physical read error on the disk -containing the swap file. Fortunately, this almost never happens. -You may want to view the file read-only at first (if you can), to see the -extent of the changes that were "forgotten". If you are the one in charge of -that file, be prepared to redo your last changes. - - -WHAT TO DO? - -If dialogs are supported you will be asked to select one of five choices: - - Swap file ".main.c.swp" already exists! ~ - [O]pen Read-Only, (E)dit anyway, (R)ecover, (Q)uit, (A)bort, (D)elete it: ~ - -O Open the file readonly. Use this when you just want to view the file and - don't need to recover it. You might want to use this when you know someone - else is editing the file, but you just want to look in it and not make - changes. - -E Edit the file anyway. Use this with caution! If the file is being edited - in another Vim, you might end up with two versions of the file. Vim will - try to warn you when this happens, but better be safe then sorry. - -R Recover the file from the swap file. Use this if you know that the swap - file contains changes that you want to recover. - -Q Quit. This avoids starting to edit the file. Use this if there is another - Vim editing the same file. - When you just started Vim, this will exit Vim. When starting Vim with - files in several windows, Vim quits only if there is a swap file for the - first one. When using an edit command, the file will not be loaded and you - are taken back to the previously edited file. - -A Abort. Like Quit, but also abort further commands. This is useful when - loading a script that edits several files, such as a session with multiple - windows. - -D Delete the swap file. Use this when you are sure you no longer need it. - For example, when it doesn't contain changes, or when the file itself is - newer than the swap file. - On Unix this choice is only offered when the process that created the - swap file does not appear to be running. - -If you do not get the dialog (you are running a version of Vim that does not -support it), you will have to do it manually. To recover the file, use this -command: > - - :recover - - -Vim cannot always detect that a swap file already exists for a file. This is -the case when the other edit session puts the swap files in another directory -or when the path name for the file is different when editing it on different -machines. Therefore, don't rely on Vim always warning you. - -If you really don't want to see this message, you can add the 'A' flag to the -'shortmess' option. But it's very unusual that you need this. - -============================================================================== -*11.4* Further reading - -|swap-file| An explanation about where the swap file will be created and - what its name is. -|:preserve| Manually flushing the swap file to disk. -|:swapname| See the name of the swap file for the current file. -'updatecount' Number of key strokes after which the swap file is flushed to - disk. -'updatetime' Timeout after which the swap file is flushed to disk. -'swapsync' Whether the disk is synced when the swap file is flushed. -'directory' List of directory names where to store the swap file. -'maxmem' Limit for memory usage before writing text to the swap file. -'maxmemtot' Same, but for all files in total. - -============================================================================== - -Next chapter: |usr_12.txt| Clever tricks - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_12.txt b/share/vim/vim72/doc/usr_12.txt deleted file mode 100644 index 43ae89eb9b..0000000000 --- a/share/vim/vim72/doc/usr_12.txt +++ /dev/null @@ -1,358 +0,0 @@ -*usr_12.txt* For Vim version 7.2. Last change: 2007 May 11 - - VIM USER MANUAL - by Bram Moolenaar - - Clever tricks - - -By combining several commands you can make Vim do nearly everything. In this -chapter a number of useful combinations will be presented. This uses the -commands introduced in the previous chapters and a few more. - -|12.1| Replace a word -|12.2| Change "Last, First" to "First Last" -|12.3| Sort a list -|12.4| Reverse line order -|12.5| Count words -|12.6| Find a man page -|12.7| Trim blanks -|12.8| Find where a word is used - - Next chapter: |usr_20.txt| Typing command-line commands quickly - Previous chapter: |usr_11.txt| Recovering from a crash -Table of contents: |usr_toc.txt| - -============================================================================== -*12.1* Replace a word - -The substitute command can be used to replace all occurrences of a word with -another word: > - - :%s/four/4/g - -The "%" range means to replace in all lines. The "g" flag at the end causes -all words in a line to be replaced. - This will not do the right thing if your file also contains "thirtyfour". -It would be replaced with "thirty4". To avoid this, use the "\<" item to -match the start of a word: > - - :%s/\<four/4/g - -Obviously, this still goes wrong on "fourteen". Use "\>" to match the end of -a word: > - - :%s/\<four\>/4/g - -If you are programming, you might want to replace "four" in comments, but not -in the code. Since this is difficult to specify, add the "c" flag to have the -substitute command prompt you for each replacement: > - - - :%s/\<four\>/4/gc - - -REPLACING IN SEVERAL FILES - -Suppose you want to replace a word in more than one file. You could edit each -file and type the command manually. It's a lot faster to use record and -playback. - Let's assume you have a directory with C++ files, all ending in ".cpp". -There is a function called "GetResp" that you want to rename to "GetAnswer". - - vim *.cpp Start Vim, defining the argument list to - contain all the C++ files. You are now in the - first file. - qq Start recording into the q register - :%s/\<GetResp\>/GetAnswer/g - Do the replacements in the first file. - :wnext Write this file and move to the next one. - q Stop recording. - @q Execute the q register. This will replay the - substitution and ":wnext". You can verify - that this doesn't produce an error message. - 999@q Execute the q register on the remaining files. - -At the last file you will get an error message, because ":wnext" cannot move -to the next file. This stops the execution, and everything is done. - - Note: - When playing back a recorded sequence, an error stops the execution. - Therefore, make sure you don't get an error message when recording. - -There is one catch: If one of the .cpp files does not contain the word -"GetResp", you will get an error and replacing will stop. To avoid this, add -the "e" flag to the substitute command: > - - :%s/\<GetResp\>/GetAnswer/ge - -The "e" flag tells ":substitute" that not finding a match is not an error. - -============================================================================== -*12.2* Change "Last, First" to "First Last" - -You have a list of names in this form: - - Doe, John ~ - Smith, Peter ~ - -You want to change that to: - - John Doe ~ - Peter Smith ~ - -This can be done with just one command: > - - :%s/\([^,]*\), \(.*\)/\2 \1/ - -Let's break this down in parts. Obviously it starts with a substitute -command. The "%" is the line range, which stands for the whole file. Thus -the substitution is done in every line in the file. - The arguments for the substitute command are "/from/to/". The slashes -separate the "from" pattern and the "to" string. This is what the "from" -pattern contains: - \([^,]*\), \(.*\) ~ - - The first part between \( \) matches "Last" \( \) - match anything but a comma [^,] - any number of times * - matches ", " literally , - The second part between \( \) matches "First" \( \) - any character . - any number of times * - -In the "to" part we have "\2" and "\1". These are called backreferences. -They refer to the text matched by the "\( \)" parts in the pattern. "\2" -refers to the text matched by the second "\( \)", which is the "First" name. -"\1" refers to the first "\( \)", which is the "Last" name. - You can use up to nine backreferences in the "to" part of a substitute -command. "\0" stands for the whole matched pattern. There are a few more -special items in a substitute command, see |sub-replace-special|. - -============================================================================== -*12.3* Sort a list - -In a Makefile you often have a list of files. For example: - - OBJS = \ ~ - version.o \ ~ - pch.o \ ~ - getopt.o \ ~ - util.o \ ~ - getopt1.o \ ~ - inp.o \ ~ - patch.o \ ~ - backup.o ~ - -To sort this list, filter the text through the external sort command: > - - /^OBJS - j - :.,/^$/-1!sort - -This goes to the first line, where "OBJS" is the first thing in the line. -Then it goes one line down and filters the lines until the next empty line. -You could also select the lines in Visual mode and then use "!sort". That's -easier to type, but more work when there are many lines. - The result is this: - - OBJS = \ ~ - backup.o ~ - getopt.o \ ~ - getopt1.o \ ~ - inp.o \ ~ - patch.o \ ~ - pch.o \ ~ - util.o \ ~ - version.o \ ~ - - -Notice that a backslash at the end of each line is used to indicate the line -continues. After sorting, this is wrong! The "backup.o" line that was at -the end didn't have a backslash. Now that it sorts to another place, it -must have a backslash. - The simplest solution is to add the backslash with "A \<Esc>". You can -keep the backslash in the last line, if you make sure an empty line comes -after it. That way you don't have this problem again. - -============================================================================== -*12.4* Reverse line order - -The |:global| command can be combined with the |:move| command to move all the -lines before the first line, resulting in a reversed file. The command is: > - - :global/^/m 0 - -Abbreviated: > - - :g/^/m 0 - -The "^" regular expression matches the beginning of the line (even if the line -is blank). The |:move| command moves the matching line to after the mythical -zeroth line, so the current matching line becomes the first line of the file. -As the |:global| command is not confused by the changing line numbering, -|:global| proceeds to match all remaining lines of the file and puts each as -the first. - -This also works on a range of lines. First move to above the first line and -mark it with "mt". Then move the cursor to the last line in the range and -type: > - - :'t+1,.g/^/m 't - -============================================================================== -*12.5* Count words - -Sometimes you have to write a text with a maximum number of words. Vim can -count the words for you. - When the whole file is what you want to count the words in, use this -command: > - - g CTRL-G - -Do not type a space after the g, this is just used here to make the command -easy to read. - The output looks like this: - - Col 1 of 0; Line 141 of 157; Word 748 of 774; Byte 4489 of 4976 ~ - -You can see on which word you are (748), and the total number of words in the -file (774). - -When the text is only part of a file, you could move to the start of the text, -type "g CTRL-G", move to the end of the text, type "g CTRL-G" again, and then -use your brain to compute the difference in the word position. That's a good -exercise, but there is an easier way. With Visual mode, select the text you -want to count words in. Then type g CTRL-G. The result: - - Selected 5 of 293 Lines; 70 of 1884 Words; 359 of 10928 Bytes ~ - -For other ways to count words, lines and other items, see |count-items|. - -============================================================================== -*12.6* Find a man page *find-manpage* - -While editing a shell script or C program, you are using a command or function -that you want to find the man page for (this is on Unix). Let's first use a -simple way: Move the cursor to the word you want to find help on and press > - - K - -Vim will run the external "man" program on the word. If the man page is -found, it is displayed. This uses the normal pager to scroll through the text -(mostly the "more" program). When you get to the end pressing <Enter> will -get you back into Vim. - -A disadvantage is that you can't see the man page and the text you are working -on at the same time. There is a trick to make the man page appear in a Vim -window. First, load the man filetype plugin: > - - :runtime! ftplugin/man.vim - -Put this command in your vimrc file if you intend to do this often. Now you -can use the ":Man" command to open a window on a man page: > - - :Man csh - -You can scroll around and the text is highlighted. This allows you to find -the help you were looking for. Use CTRL-W w to jump to the window with the -text you were working on. - To find a man page in a specific section, put the section number first. -For example, to look in section 3 for "echo": > - - :Man 3 echo - -To jump to another man page, which is in the text with the typical form -"word(1)", press CTRL-] on it. Further ":Man" commands will use the same -window. - -To display a man page for the word under the cursor, use this: > - - \K - -(If you redefined the <Leader>, use it instead of the backslash). -For example, you want to know the return value of "strstr()" while editing -this line: - - if ( strstr (input, "aap") == ) ~ - -Move the cursor to somewhere on "strstr" and type "\K". A window will open -to display the man page for strstr(). - -============================================================================== -*12.7* Trim blanks - -Some people find spaces and tabs at the end of a line useless, wasteful, and -ugly. To remove whitespace at the end of every line, execute the following -command: > - - :%s/\s\+$// - -The line range "%" is used, thus this works on the whole file. The pattern -that the ":substitute" command matches with is "\s\+$". This finds white -space characters (\s), 1 or more of them (\+), before the end-of-line ($). -Later will be explained how you write patterns like this |usr_27.txt|. - The "to" part of the substitute command is empty: "//". Thus it replaces -with nothing, effectively deleting the matched white space. - -Another wasteful use of spaces is placing them before a tab. Often these can -be deleted without changing the amount of white space. But not always! -Therefore, you can best do this manually. Use this search command: > - - / - -You cannot see it, but there is a space before a tab in this command. Thus -it's "/<Space><Tab>". Now use "x" to delete the space and check that the -amount of white space doesn't change. You might have to insert a tab if it -does change. Type "n" to find the next match. Repeat this until no more -matches can be found. - -============================================================================== -*12.8* Find where a word is used - -If you are a UNIX user, you can use a combination of Vim and the grep command -to edit all the files that contain a given word. This is extremely useful if -you are working on a program and want to view or edit all the files that -contain a specific variable. - For example, suppose you want to edit all the C program files that contain -the word "frame_counter". To do this you use the command: > - - vim `grep -l frame_counter *.c` - -Let's look at this command in detail. The grep command searches through a set -of files for a given word. Because the -l argument is specified, the command -will only list the files containing the word and not print the matching lines. -The word it is searching for is "frame_counter". Actually, this can be any -regular expression. (Note: What grep uses for regular expressions is not -exactly the same as what Vim uses.) - The entire command is enclosed in backticks (`). This tells the UNIX shell -to run this command and pretend that the results were typed on the command -line. So what happens is that the grep command is run and produces a list of -files, these files are put on the Vim command line. This results in Vim -editing the file list that is the output of grep. You can then use commands -like ":next" and ":first" to browse through the files. - - -FINDING EACH LINE - -The above command only finds the files in which the word is found. You still -have to find the word within the files. - Vim has a built-in command that you can use to search a set of files for a -given string. If you want to find all occurrences of "error_string" in all C -program files, for example, enter the following command: > - - :grep error_string *.c - -This causes Vim to search for the string "error_string" in all the specified -files (*.c). The editor will now open the first file where a match is found -and position the cursor on the first matching line. To go to the next -matching line (no matter in what file it is), use the ":cnext" command. To go -to the previous match, use the ":cprev" command. Use ":clist" to see all the -matches and where they are. - The ":grep" command uses the external commands grep (on Unix) or findstr -(on Windows). You can change this by setting the option 'grepprg'. - -============================================================================== - -Next chapter: |usr_20.txt| Typing command-line commands quickly - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_20.txt b/share/vim/vim72/doc/usr_20.txt deleted file mode 100644 index 1841881869..0000000000 --- a/share/vim/vim72/doc/usr_20.txt +++ /dev/null @@ -1,384 +0,0 @@ -*usr_20.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - VIM USER MANUAL - by Bram Moolenaar - - Typing command-line commands quickly - - -Vim has a few generic features that makes it easier to enter commands. Colon -commands can be abbreviated, edited and repeated. Completion is available for -nearly everything. - -|20.1| Command line editing -|20.2| Command line abbreviations -|20.3| Command line completion -|20.4| Command line history -|20.5| Command line window - - Next chapter: |usr_21.txt| Go away and come back - Previous chapter: |usr_12.txt| Clever tricks -Table of contents: |usr_toc.txt| - -============================================================================== -*20.1* Command line editing - -When you use a colon (:) command or search for a string with / or ?, Vim puts -the cursor on the bottom of the screen. There you type the command or search -pattern. This is called the Command line. Also when it's used for entering a -search command. - -The most obvious way to edit the command you type is by pressing the <BS> key. -This erases the character before the cursor. To erase another character, -typed earlier, first move the cursor with the cursor keys. - For example, you have typed this: > - - :s/col/pig/ - -Before you hit <Enter>, you notice that "col" should be "cow". To correct -this, you type <Left> five times. The cursor is now just after "col". Type -<BS> and "w" to correct: > - - :s/cow/pig/ - -Now you can press <Enter> directly. You don't have to move the cursor to the -end of the line before executing the command. - -The most often used keys to move around in the command line: - - <Left> one character left - <Right> one character right - <S-Left> or <C-Left> one word left - <S-Right> or <C-Right> one word right - CTRL-B or <Home> to begin of command line - CTRL-E or <End> to end of command line - - Note: - <S-Left> (cursor left key with Shift key pressed) and <C-Left> (cursor - left key with Control pressed) will not work on all keyboards. Same - for the other Shift and Control combinations. - -You can also use the mouse to move the cursor. - - -DELETING - -As mentioned, <BS> deletes the character before the cursor. To delete a whole -word use CTRL-W. - - /the fine pig ~ - - CTRL-W - - /the fine ~ - -CTRL-U removes all text, thus allows you to start all over again. - - -OVERSTRIKE - -The <Insert> key toggles between inserting characters and replacing the -existing ones. Start with this text: - - /the fine pig ~ - -Move the cursor to the start of "fine" with <S-Left> twice (or <Left> eight -times, if <S-Left> doesn't work). Now press <Insert> to switch to overstrike -and type "great": - - /the greatpig ~ - -Oops, we lost the space. Now, don't use <BS>, because it would delete the -"t" (this is different from Replace mode). Instead, press <Insert> to switch -from overstrike to inserting, and type the space: - - /the great pig ~ - - -CANCELLING - -You thought of executing a : or / command, but changed your mind. To get rid -of what you already typed, without executing it, press CTRL-C or <Esc>. - - Note: - <Esc> is the universal "get out" key. Unfortunately, in the good old - Vi pressing <Esc> in a command line executed the command! Since that - might be considered to be a bug, Vim uses <Esc> to cancel the command. - But with the 'cpoptions' option it can be made Vi compatible. And - when using a mapping (which might be written for Vi) <Esc> also works - Vi compatible. Therefore, using CTRL-C is a method that always works. - -If you are at the start of the command line, pressing <BS> will cancel the -command. It's like deleting the ":" or "/" that the line starts with. - -============================================================================== -*20.2* Command line abbreviations - -Some of the ":" commands are really long. We already mentioned that -":substitute" can be abbreviated to ":s". This is a generic mechanism, all -":" commands can be abbreviated. - -How short can a command get? There are 26 letters, and many more commands. -For example, ":set" also starts with ":s", but ":s" doesn't start a ":set" -command. Instead ":set" can be abbreviated to ":se". - When the shorter form of a command could be used for two commands, it -stands for only one of them. There is no logic behind which one, you have to -learn them. In the help files the shortest form that works is mentioned. For -example: > - - :s[ubstitute] - -This means that the shortest form of ":substitute" is ":s". The following -characters are optional. Thus ":su" and ":sub" also work. - -In the user manual we will either use the full name of command, or a short -version that is still readable. For example, ":function" can be abbreviated -to ":fu". But since most people don't understand what that stands for, we -will use ":fun". (Vim doesn't have a ":funny" command, otherwise ":fun" would -be confusing too.) - -It is recommended that in Vim scripts you write the full command name. That -makes it easier to read back when you make later changes. Except for some -often used commands like ":w" (":write") and ":r" (":read"). - A particularly confusing one is ":end", which could stand for ":endif", -":endwhile" or ":endfunction". Therefore, always use the full name. - - -SHORT OPTION NAMES - -In the user manual the long version of the option names is used. Many options -also have a short name. Unlike ":" commands, there is only one short name -that works. For example, the short name of 'autoindent' is 'ai'. Thus these -two commands do the same thing: > - - :set autoindent - :set ai - -You can find the full list of long and short names here: |option-list|. - -============================================================================== -*20.3* Command line completion - -This is one of those Vim features that, by itself, is a reason to switch from -Vi to Vim. Once you have used this, you can't do without. - -Suppose you have a directory that contains these files: - - info.txt - intro.txt - bodyofthepaper.txt - -To edit the last one, you use the command: > - - :edit bodyofthepaper.txt - -It's easy to type this wrong. A much quicker way is: > - - :edit b<Tab> - -Which will result in the same command. What happened? The <Tab> key does -completion of the word before the cursor. In this case "b". Vim looks in the -directory and finds only one file that starts with a "b". That must be the -one you are looking for, thus Vim completes the file name for you. - -Now type: > - - :edit i<Tab> - -Vim will beep, and give you: > - - :edit info.txt - -The beep means that Vim has found more than one match. It then uses the first -match it found (alphabetically). If you press <Tab> again, you get: > - - :edit intro.txt - -Thus, if the first <Tab> doesn't give you the file you were looking for, press -it again. If there are more matches, you will see them all, one at a time. - If you press <Tab> on the last matching entry, you will go back to what you -first typed: > - - :edit i - -Then it starts all over again. Thus Vim cycles through the list of matches. -Use CTRL-P to go through the list in the other direction: - - <------------------- <Tab> -------------------------+ - | - <Tab> --> <Tab> --> - :edit i :edit info.txt :edit intro.txt - <-- CTRL-P <-- CTRL-P - | - +---------------------- CTRL-P ------------------------> - - -CONTEXT - -When you type ":set i" instead of ":edit i" and press <Tab> you get: > - - :set icon - -Hey, why didn't you get ":set info.txt"? That's because Vim has context -sensitive completion. The kind of words Vim will look for depends on the -command before it. Vim knows that you cannot use a file name just after a -":set" command, but you can use an option name. - Again, if you repeat typing the <Tab>, Vim will cycle through all matches. -There are quite a few, it's better to type more characters first: > - - :set isk<Tab> - -Gives: > - - :set iskeyword - -Now type "=" and press <Tab>: > - - :set iskeyword=@,48-57,_,192-255 - -What happens here is that Vim inserts the old value of the option. Now you -can edit it. - What is completed with <Tab> is what Vim expects in that place. Just try -it out to see how it works. In some situations you will not get what you -want. That's either because Vim doesn't know what you want, or because -completion was not implemented for that situation. In that case you will get -a <Tab> inserted (displayed as ^I). - - -LIST MATCHES - -When there are many matches, you would like to see an overview. Do this by -pressing CTRL-D. For example, pressing CTRL-D after: > - - :set is - -results in: > - - :set is - incsearch isfname isident iskeyword isprint - :set is - -Vim lists the matches and then comes back with the text you typed. You can -now check the list for the item you wanted. If it isn't there, you can use -<BS> to correct the word. If there are many matches, type a few more -characters before pressing <Tab> to complete the rest. - If you have watched carefully, you will have noticed that "incsearch" -doesn't start with "is". In this case "is" stands for the short name of -"incsearch". (Many options have a short and a long name.) Vim is clever -enough to know that you might have wanted to expand the short name of the -option into the long name. - - -THERE IS MORE - -The CTRL-L command completes the word to the longest unambiguous string. If -you type ":edit i" and there are files "info.txt" and "info_backup.txt" you -will get ":edit info". - -The 'wildmode' option can be used to change the way completion works. -The 'wildmenu' option can be used to get a menu-like list of matches. -Use the 'suffixes' option to specify files that are less important and appear -at the end of the list of files. -The 'wildignore' option specifies files that are not listed at all. - -More about all of this here: |cmdline-completion| - -============================================================================== -*20.4* Command line history - -In chapter 3 we briefly mentioned the history. The basics are that you can -use the <Up> key to recall an older command line. <Down> then takes you back -to newer commands. - -There are actually four histories. The ones we will mention here are for ":" -commands and for "/" and "?" search commands. The "/" and "?" commands share -the same history, because they are both search commands. The two other -histories are for expressions and input lines for the input() function. -|cmdline-history| - -Suppose you have done a ":set" command, typed ten more colon commands and then -want to repeat that ":set" command again. You could press ":" and then ten -times <Up>. There is a quicker way: > - - :se<Up> - -Vim will now go back to the previous command that started with "se". You have -a good chance that this is the ":set" command you were looking for. At least -you should not have to press <Up> very often (unless ":set" commands is all -you have done). - -The <Up> key will use the text typed so far and compare it with the lines in -the history. Only matching lines will be used. - If you do not find the line you were looking for, use <Down> to go back to -what you typed and correct that. Or use CTRL-U to start all over again. - -To see all the lines in the history: > - - :history - -That's the history of ":" commands. The search history is displayed with this -command: > - - :history / - -CTRL-P will work like <Up>, except that it doesn't matter what you already -typed. Similarly for CTRL-N and <Down>. CTRL-P stands for previous, CTRL-N -for next. - -============================================================================== -*20.5* Command line window - -Typing the text in the command line works different from typing text in Insert -mode. It doesn't allow many commands to change the text. For most commands -that's OK, but sometimes you have to type a complicated command. That's where -the command line window is useful. - -Open the command line window with this command: > - - q: - -Vim now opens a (small) window at the bottom. It contains the command line -history, and an empty line at the end: - - +-------------------------------------+ - |other window | - |~ | - |file.txt=============================| - |:e c | - |:e config.h.in | - |:set path=.,/usr/include,, | - |:set iskeyword=@,48-57,_,192-255 | - |:set is | - |:q | - |: | - |command-line=========================| - | | - +-------------------------------------+ - -You are now in Normal mode. You can use the "hjkl" keys to move around. For -example, move up with "5k" to the ":e config.h.in" line. Type "$h" to go to -the "i" of "in" and type "cwout". Now you have changed the line to: - - :e config.h.out ~ - -Now press <Enter> and this command will be executed. The command line window -will close. - The <Enter> command will execute the line under the cursor. It doesn't -matter whether Vim is in Insert mode or in Normal mode. - Changes in the command line window are lost. They do not result in the -history to be changed. Except that the command you execute will be added to -the end of the history, like with all executed commands. - -The command line window is very useful when you want to have overview of the -history, lookup a similar command, change it a bit and execute it. A search -command can be used to find something. - In the previous example the "?config" search command could have been used -to find the previous command that contains "config". It's a bit strange, -because you are using a command line to search in the command line window. -While typing that search command you can't open another command line window, -there can be only one. - -============================================================================== - -Next chapter: |usr_21.txt| Go away and come back - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_21.txt b/share/vim/vim72/doc/usr_21.txt deleted file mode 100644 index cdbc42e76c..0000000000 --- a/share/vim/vim72/doc/usr_21.txt +++ /dev/null @@ -1,499 +0,0 @@ -*usr_21.txt* For Vim version 7.2. Last change: 2008 Nov 09 - - VIM USER MANUAL - by Bram Moolenaar - - Go away and come back - - -This chapter goes into mixing the use of other programs with Vim. Either by -executing program from inside Vim or by leaving Vim and coming back later. -Furthermore, this is about the ways to remember the state of Vim and restore -it later. - -|21.1| Suspend and resume -|21.2| Executing shell commands -|21.3| Remembering information; viminfo -|21.4| Sessions -|21.5| Views -|21.6| Modelines - - Next chapter: |usr_22.txt| Finding the file to edit - Previous chapter: |usr_20.txt| Typing command-line commands quickly -Table of contents: |usr_toc.txt| - -============================================================================== -*21.1* Suspend and resume - -Like most Unix programs Vim can be suspended by pressing CTRL-Z. This stops -Vim and takes you back to the shell it was started in. You can then do any -other commands until you are bored with them. Then bring back Vim with the -"fg" command. > - - CTRL-Z - {any sequence of shell commands} - fg - -You are right back where you left Vim, nothing has changed. - In case pressing CTRL-Z doesn't work, you can also use ":suspend". -Don't forget to bring Vim back to the foreground, you would lose any changes -that you made! - -Only Unix has support for this. On other systems Vim will start a shell for -you. This also has the functionality of being able to execute shell commands. -But it's a new shell, not the one that you started Vim from. - When you are running the GUI you can't go back to the shell where Vim was -started. CTRL-Z will minimize the Vim window instead. - -============================================================================== -*21.2* Executing shell commands - -To execute a single shell command from Vim use ":!{command}". For example, to -see a directory listing: > - - :!ls - :!dir - -The first one is for Unix, the second one for MS-Windows. - Vim will execute the program. When it ends you will get a prompt to hit -<Enter>. This allows you to have a look at the output from the command before -returning to the text you were editing. - The "!" is also used in other places where a program is run. Let's take -a look at an overview: - - :!{program} execute {program} - :r !{program} execute {program} and read its output - :w !{program} execute {program} and send text to its input - :[range]!{program} filter text through {program} - -Notice that the presence of a range before "!{program}" makes a big -difference. Without it executes the program normally, with the range a number -of text lines is filtered through the program. - -Executing a whole row of programs this way is possible. But a shell is much -better at it. You can start a new shell this way: > - - :shell - -This is similar to using CTRL-Z to suspend Vim. The difference is that a new -shell is started. - -When using the GUI the shell will be using the Vim window for its input and -output. Since Vim is not a terminal emulator, this will not work perfectly. -If you have trouble, try toggling the 'guipty' option. If this still doesn't -work well enough, start a new terminal to run the shell in. For example with: -> - :!xterm& - -============================================================================== -*21.3* Remembering information; viminfo - -After editing for a while you will have text in registers, marks in various -files, a command line history filled with carefully crafted commands. When -you exit Vim all of this is lost. But you can get it back! - -The viminfo file is designed to store status information: - - Command-line and Search pattern history - Text in registers - Marks for various files - The buffer list - Global variables - -Each time you exit Vim it will store this information in a file, the viminfo -file. When Vim starts again, the viminfo file is read and the information -restored. - -The 'viminfo' option is set by default to restore a limited number of items. -You might want to set it to remember more information. This is done through -the following command: > - - :set viminfo=string - -The string specifies what to save. The syntax of this string is an option -character followed by an argument. The option/argument pairs are separated by -commas. - Take a look at how you can build up your own viminfo string. First, the ' -option is used to specify how many files for which you save marks (a-z). Pick -a nice even number for this option (1000, for instance). Your command now -looks like this: > - - :set viminfo='1000 - -The f option controls whether global marks (A-Z and 0-9) are stored. If this -option is 0, none are stored. If it is 1 or you do not specify an f option, -the marks are stored. You want this feature, so now you have this: > - - :set viminfo='1000,f1 - -The < option controls how many lines are saved for each of the registers. By -default, all the lines are saved. If 0, nothing is saved. To avoid adding -thousands of lines to your viminfo file (which might never get used and makes -starting Vim slower) you use a maximum of 500 lines: > - - :set viminfo='1000,f1,<500 -< -Other options you might want to use: - : number of lines to save from the command line history - @ number of lines to save from the input line history - / number of lines to save from the search history - r removable media, for which no marks will be stored (can be - used several times) - ! global variables that start with an uppercase letter and - don't contain lowercase letters - h disable 'hlsearch' highlighting when starting - % the buffer list (only restored when starting Vim without file - arguments) - c convert the text using 'encoding' - n name used for the viminfo file (must be the last option) - -See the 'viminfo' option and |viminfo-file| for more information. - -When you run Vim multiple times, the last one exiting will store its -information. This may cause information that previously exiting Vims stored -to be lost. Each item can be remembered only once. - - -GETTING BACK TO WHERE YOU STOPPED VIM - -You are halfway editing a file and it's time to leave for holidays. You exit -Vim and go enjoy yourselves, forgetting all about your work. After a couple -of weeks you start Vim, and type: -> - '0 - -And you are right back where you left Vim. So you can get on with your work. - Vim creates a mark each time you exit Vim. The last one is '0. The -position that '0 pointed to is made '1. And '1 is made to '2, and so forth. -Mark '9 is lost. - The |:marks| command is useful to find out where '0 to '9 will take you. - - -GETTING BACK TO SOME FILE - -If you want to go back to a file that you edited recently, but not when -exiting Vim, there is a slightly more complicated way. You can see a list of -files by typing the command: > - - :oldfiles -< 1: ~/.viminfo ~ - 2: ~/text/resume.txt ~ - 3: /tmp/draft ~ - -Now you would like to edit the second file, which is in the list preceded by -"2:". You type: > - - :e #<2 - -Instead of ":e" you can use any command that has a file name argument, the -"#<2" item works in the same place as "%" (current file name) and "#" -(alternate file name). So you can also split the window to edit the third -file: > - - :split #<3 - -That #<123 thing is a bit complicated when you just want to edit a file. -Fortunately there is a simpler way: > - - :browse oldfiles -< 1: ~/.viminfo ~ - 2: ~/text/resume.txt ~ - 3: /tmp/draft ~ - -- More -- - -You get the same list of files as with |:oldfiles|. If you want to edit -"resume.txt" first press "q" to stop the listing. You will get a prompt: - - Type number and <Enter> (empty cancels): ~ - -Type "2" and press <Enter> to edit the second file. - -More info at |:oldfiles|, |v:oldfiles| and |c_#<|. - - -MOVE INFO FROM ONE VIM TO ANOTHER - -You can use the ":wviminfo" and ":rviminfo" commands to save and restore the -information while still running Vim. This is useful for exchanging register -contents between two instances of Vim, for example. In the first Vim do: > - - :wviminfo! ~/tmp/viminfo - -And in the second Vim do: > - - :rviminfo! ~/tmp/viminfo - -Obviously, the "w" stands for "write" and the "r" for "read". - The ! character is used by ":wviminfo" to forcefully overwrite an existing -file. When it is omitted, and the file exists, the information is merged into -the file. - The ! character used for ":rviminfo" means that all the information is -used, this may overwrite existing information. Without the ! only information -that wasn't set is used. - These commands can also be used to store info and use it again later. You -could make a directory full of viminfo files, each containing info for a -different purpose. - -============================================================================== -*21.4* Sessions - -Suppose you are editing along, and it is the end of the day. You want to quit -work and pick up where you left off the next day. You can do this by saving -your editing session and restoring it the next day. - A Vim session contains all the information about what you are editing. -This includes things such as the file list, window layout, global variables, -options and other information. (Exactly what is remembered is controlled by -the 'sessionoptions' option, described below.) - The following command creates a session file: > - - :mksession vimbook.vim - -Later if you want to restore this session, you can use this command: > - - :source vimbook.vim - -If you want to start Vim and restore a specific session, you can use the -following command: > - - vim -S vimbook.vim - -This tells Vim to read a specific file on startup. The 'S' stands for -session (actually, you can source any Vim script with -S, thus it might as -well stand for "source"). - -The windows that were open are restored, with the same position and size as -before. Mappings and option values are like before. - What exactly is restored depends on the 'sessionoptions' option. The -default value is "blank,buffers,curdir,folds,help,options,winsize". - - blank keep empty windows - buffers all buffers, not only the ones in a window - curdir the current directory - folds folds, also manually created ones - help the help window - options all options and mappings - winsize window sizes - -Change this to your liking. To also restore the size of the Vim window, for -example, use: > - - :set sessionoptions+=resize - - -SESSION HERE, SESSION THERE - -The obvious way to use sessions is when working on different projects. -Suppose you store you session files in the directory "~/.vim". You are -currently working on the "secret" project and have to switch to the "boring" -project: > - - :wall - :mksession! ~/.vim/secret.vim - :source ~/.vim/boring.vim - -This first uses ":wall" to write all modified files. Then the current session -is saved, using ":mksession!". This overwrites the previous session. The -next time you load the secret session you can continue where you were at this -point. And finally you load the new "boring" session. - -If you open help windows, split and close various window, and generally mess -up the window layout, you can go back to the last saved session: > - - :source ~/.vim/boring.vim - -Thus you have complete control over whether you want to continue next time -where you are now, by saving the current setup in a session, or keep the -session file as a starting point. - Another way of using sessions is to create a window layout that you like to -use, and save this in a session. Then you can go back to this layout whenever -you want. - For example, this is a nice layout to use: - - +----------------------------------------+ - | VIM - main help file | - | | - |Move around: Use the cursor keys, or "h| - |help.txt================================| - |explorer | | - |dir |~ | - |dir |~ | - |file |~ | - |file |~ | - |file |~ | - |file |~ | - |~/=========|[No File]===================| - | | - +----------------------------------------+ - -This has a help window at the top, so that you can read this text. The narrow -vertical window on the left contains a file explorer. This is a Vim plugin -that lists the contents of a directory. You can select files to edit there. -More about this in the next chapter. - Create this from a just started Vim with: > - - :help - CTRL-W w - :vertical split ~/ - -You can resize the windows a bit to your liking. Then save the session with: -> - :mksession ~/.vim/mine.vim - -Now you can start Vim with this layout: > - - vim -S ~/.vim/mine.vim - -Hint: To open a file you see listed in the explorer window in the empty -window, move the cursor to the filename and press "O". Double clicking with -the mouse will also do this. - - -UNIX AND MS-WINDOWS - -Some people have to do work on MS-Windows systems one day and on Unix another -day. If you are one of them, consider adding "slash" and "unix" to -'sessionoptions'. The session files will then be written in a format that can -be used on both systems. This is the command to put in your vimrc file: > - - :set sessionoptions+=unix,slash - -Vim will use the Unix format then, because the MS-Windows Vim can read and -write Unix files, but Unix Vim can't read MS-Windows format session files. -Similarly, MS-Windows Vim understands file names with / to separate names, but -Unix Vim doesn't understand \. - - -SESSIONS AND VIMINFO - -Sessions store many things, but not the position of marks, contents of -registers and the command line history. You need to use the viminfo feature -for these things. - In most situations you will want to use sessions separately from viminfo. -This can be used to switch to another session, but keep the command line -history. And yank text into registers in one session, and paste it back in -another session. - You might prefer to keep the info with the session. You will have to do -this yourself then. Example: > - - :mksession! ~/.vim/secret.vim - :wviminfo! ~/.vim/secret.viminfo - -And to restore this again: > - - :source ~/.vim/secret.vim - :rviminfo! ~/.vim/secret.viminfo - -============================================================================== -*21.5* Views - -A session stores the looks of the whole of Vim. When you want to store the -properties for one window only, use a view. - The use of a view is for when you want to edit a file in a specific way. -For example, you have line numbers enabled with the 'number' option and -defined a few folds. Just like with sessions, you can remember this view on -the file and restore it later. Actually, when you store a session, it stores -the view of each window. - There are two basic ways to use views. The first is to let Vim pick a name -for the view file. You can restore the view when you later edit the same -file. To store the view for the current window: > - - :mkview - -Vim will decide where to store the view. When you later edit the same file -you get the view back with this command: > - - :loadview - -That's easy, isn't it? - Now you want to view the file without the 'number' option on, or with all -folds open, you can set the options to make the window look that way. Then -store this view with: > - - :mkview 1 - -Obviously, you can get this back with: > - - :loadview 1 - -Now you can switch between the two views on the file by using ":loadview" with -and without the "1" argument. - You can store up to ten views for the same file this way, one unnumbered -and nine numbered 1 to 9. - - -A VIEW WITH A NAME - -The second basic way to use views is by storing the view in a file with a name -you chose. This view can be loaded while editing another file. Vim will then -switch to editing the file specified in the view. Thus you can use this to -quickly switch to editing another file, with all its options set as you saved -them. - For example, to save the view of the current file: > - - :mkview ~/.vim/main.vim - -You can restore it with: > - - :source ~/.vim/main.vim - -============================================================================== -*21.6* Modelines - -When editing a specific file, you might set options specifically for that -file. Typing these commands each time is boring. Using a session or view for -editing a file doesn't work when sharing the file between several people. - The solution for this situation is adding a modeline to the file. This is -a line of text that tells Vim the values of options, to be used in this file -only. - A typical example is a C program where you make indents by a multiple of 4 -spaces. This requires setting the 'shiftwidth' option to 4. This modeline -will do that: - - /* vim:set shiftwidth=4: */ ~ - -Put this line as one of the first or last five lines in the file. When -editing the file, you will notice that 'shiftwidth' will have been set to -four. When editing another file, it's set back to the default value of eight. - For some files the modeline fits well in the header, thus it can be put at -the top of the file. For text files and other files where the modeline gets -in the way of the normal contents, put it at the end of the file. - -The 'modelines' option specifies how many lines at the start and end of the -file are inspected for containing a modeline. To inspect ten lines: > - - :set modelines=10 - -The 'modeline' option can be used to switch this off. Do this when you are -working as root on Unix or Administrator on MS-Windows, or when you don't -trust the files you are editing: > - - :set nomodeline - -Use this format for the modeline: - - any-text vim:set {option}={value} ... : any-text ~ - -The "any-text" indicates that you can put any text before and after the part -that Vim will use. This allows making it look like a comment, like what was -done above with /* and */. - The " vim:" part is what makes Vim recognize this line. There must be -white space before "vim", or "vim" must be at the start of the line. Thus -using something like "gvim:" will not work. - The part between the colons is a ":set" command. It works the same way as -typing the ":set" command, except that you need to insert a backslash before a -colon (otherwise it would be seen as the end of the modeline). - -Another example: - - // vim:set textwidth=72 dir=c\:\tmp: use c:\tmp here ~ - -There is an extra backslash before the first colon, so that it's included in -the ":set" command. The text after the second colon is ignored, thus a remark -can be placed there. - -For more details see |modeline|. - -============================================================================== - -Next chapter: |usr_22.txt| Finding the file to edit - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_22.txt b/share/vim/vim72/doc/usr_22.txt deleted file mode 100644 index 45bd2f4aa5..0000000000 --- a/share/vim/vim72/doc/usr_22.txt +++ /dev/null @@ -1,400 +0,0 @@ -*usr_22.txt* For Vim version 7.2. Last change: 2007 Aug 14 - - VIM USER MANUAL - by Bram Moolenaar - - Finding the file to edit - - -Files can be found everywhere. So how do you find them? Vim offers various -ways to browse the directory tree. There are commands to jump to a file that -is mentioned in another. And Vim remembers which files have been edited -before. - -|22.1| The file browser -|22.2| The current directory -|22.3| Finding a file -|22.4| The buffer list - - Next chapter: |usr_23.txt| Editing other files - Previous chapter: |usr_21.txt| Go away and come back -Table of contents: |usr_toc.txt| - -============================================================================== -*22.1* The file browser - -Vim has a plugin that makes it possible to edit a directory. Try this: > - - :edit . - -Through the magic of autocommands and Vim scripts, the window will be filled -with the contents of the directory. It looks like this: - -" ============================================================================ ~ -" Netrw Directory Listing (netrw v109) ~ -" Sorted by name ~ -" Sort sequence: [\/]$,\.h$,\.c$,\.cpp$,*,\.info$,\.swp$,\.o$\.obj$,\.bak$ ~ -" Quick Help: <F1>:help -:go up dir D:delete R:rename s:sort-by x:exec ~ -" ============================================================================ ~ -../ ~ -./ ~ -check/ ~ -Makefile ~ -autocmd.txt ~ -change.txt ~ -eval.txt~ ~ -filetype.txt~ ~ -help.txt.info ~ - -You can see these items: - -1. The name of the browsing tool and its version number -2. The name of the browsing directory -3. The method of sorting (may be by name, time, or size) -4. How names are to be sorted (directories first, then *.h files, - *.c files, etc) -5. How to get help (use the <F1> key), and an abbreviated listing - of available commands -6. A listing of files, including "../", which allows one to to list - the parent directory. - -If you have syntax highlighting enabled, the different parts are highlighted -so as to make it easier to spot them. - -You can use Normal mode Vim commands to move around in the text. For example, -move the cursor atop a file and press <Enter>; you will then be editing that -file. To go back to the browser use ":edit ." again, or use ":Explore". -CTRL-O also works. - -Try using <Enter> while the cursor is atop a directory name. The result is -that the file browser moves into that directory and displays the items found -there. Pressing <Enter> on the first directory "../" moves you one level -higher. Pressing "-" does the same thing, without the need to move to the -"../" item first. - -You can press <F1> to get help on the things you can do in the netrw file -browser. This is what you get: > - - 9. Directory Browsing netrw-browse netrw-dir netrw-list netrw-help - - MAPS netrw-maps - <F1>.............Help.......................................|netrw-help| - <cr>.............Browsing...................................|netrw-cr| - <del>............Deleting Files or Directories..............|netrw-delete| - -................Going Up...................................|netrw--| - a................Hiding Files or Directories................|netrw-a| - mb...............Bookmarking a Directory....................|netrw-mb| - gb...............Changing to a Bookmarked Directory.........|netrw-gb| - c................Make Browsing Directory The Current Dir....|netrw-c| - d................Make A New Directory.......................|netrw-d| - D................Deleting Files or Directories..............|netrw-D| - <c-h>............Edit File/Directory Hiding List............|netrw-ctrl-h| - i................Change Listing Style.......................|netrw-i| - <c-l>............Refreshing the Listing.....................|netrw-ctrl-l| - o................Browsing with a Horizontal Split...........|netrw-o| - p................Use Preview Window.........................|netrw-p| - P................Edit in Previous Window....................|netrw-p| - q................Listing Bookmarks and History..............|netrw-q| - r................Reversing Sorting Order....................|netrw-r| -< (etc) - -The <F1> key thus brings you to a netrw directory browsing contents help page. -Its a regular help page; use the usual |CTRL-]| to jump to tagged help items -and |CTRL-O| to jump back. - -To select files for display and editing: (with the cursor is atop a filename) - - <enter> Open the file in the current window. |netrw-cr| - o Horizontally split window and display file |netrw-o| - v Vertically split window and display file |netrw-v| - p Use the |preview-window| |netrw-p| - P Edit in the previous window |netrw-P| - t Open file in a new tab |netrw-t| - -The following normal-mode commands may be used to control the browser display: - - i Controls listing style (thin, long, wide, and tree). - The long listing includes size and date information. - s Repeatedly pressing s will change the way the files - are sorted; one may sort on name, modification time, - or size. - r Reverse the sorting order. - -As a sampling of extra normal-mode commands: - - c Change Vim's notion of the current directory to be - the same as the browser directory. (see - |g:netrw_keepdir| to control this, too) - R Rename the file or directory under the cursor; a - prompt will be issued for the new name. - D Delete the file or directory under the cursor; a - confirmation request will be issued. - mb gb Make bookmark/goto bookmark - - -One may also use command mode; again, just a sampling: - - :Explore [directory] Browse specified/current directory - :NetrwSettings A comprehensive list of your current netrw - settings with help linkage. - -The netrw browser is not limited to just your local machine; one may use -urls such as: (that trailing / is important) - - :Explore ftp://somehost/path/to/dir/ - :e scp://somehost/path/to/dir/ - -See |netrw-browse| for more. - -============================================================================== -*22.2* The current directory - -Just like the shell, Vim has the concept of a current directory. Suppose you -are in your home directory and want to edit several files in a directory -"VeryLongFileName". You could do: > - - :edit VeryLongFileName/file1.txt - :edit VeryLongFileName/file2.txt - :edit VeryLongFileName/file3.txt - -To avoid much of the typing, do this: > - - :cd VeryLongFileName - :edit file1.txt - :edit file2.txt - :edit file3.txt - -The ":cd" command changes the current directory. You can see what the current -directory is with the ":pwd" command: > - - :pwd - /home/Bram/VeryLongFileName - -Vim remembers the last directory that you used. Use "cd -" to go back to it. -Example: > - - :pwd - /home/Bram/VeryLongFileName - :cd /etc - :pwd - /etc - :cd - - :pwd - /home/Bram/VeryLongFileName - :cd - - :pwd - /etc - - -WINDOW LOCAL DIRECTORY - -When you split a window, both windows use the same current directory. When -you want to edit a number of files somewhere else in the new window, you can -make it use a different directory, without changing the current directory in -the other window. This is called a local directory. > - - :pwd - /home/Bram/VeryLongFileName - :split - :lcd /etc - :pwd - /etc - CTRL-W w - :pwd - /home/Bram/VeryLongFileName - -So long as no ":lcd" command has been used, all windows share the same current -directory. Doing a ":cd" command in one window will also change the current -directory of the other window. - For a window where ":lcd" has been used a different current directory is -remembered. Using ":cd" or ":lcd" in other windows will not change it. - When using a ":cd" command in a window that uses a different current -directory, it will go back to using the shared directory. - -============================================================================== -*22.3* Finding a file - -You are editing a C program that contains this line: - - #include "inits.h" ~ - -You want to see what is in that "inits.h" file. Move the cursor on the name -of the file and type: > - - gf - -Vim will find the file and edit it. - What if the file is not in the current directory? Vim will use the 'path' -option to find the file. This option is a list of directory names where to -look for your file. - Suppose you have your include files located in "c:/prog/include". This -command will add it to the 'path' option: > - - :set path+=c:/prog/include - -This directory is an absolute path. No matter where you are, it will be the -same place. What if you have located files in a subdirectory, below where the -file is? Then you can specify a relative path name. This starts with a dot: -> - :set path+=./proto - -This tells Vim to look in the directory "proto", below the directory where the -file in which you use "gf" is. Thus using "gf" on "inits.h" will make Vim -look for "proto/inits.h", starting in the directory of the file. - Without the "./", thus "proto", Vim would look in the "proto" directory -below the current directory. And the current directory might not be where the -file that you are editing is located. - -The 'path' option allows specifying the directories where to search for files -in many more ways. See the help on the 'path' option. - The 'isfname' option is used to decide which characters are included in the -file name, and which ones are not (e.g., the " character in the example -above). - -When you know the file name, but it's not to be found in the file, you can -type it: > - - :find inits.h - -Vim will then use the 'path' option to try and locate the file. This is the -same as the ":edit" command, except for the use of 'path'. - -To open the found file in a new window use CTRL-W f instead of "gf", or use -":sfind" instead of ":find". - - -A nice way to directly start Vim to edit a file somewhere in the 'path': > - - vim "+find stdio.h" - -This finds the file "stdio.h" in your value of 'path'. The quotes are -necessary to have one argument |-+c|. - -============================================================================== -*22.4* The buffer list - -The Vim editor uses the term buffer to describe a file being edited. -Actually, a buffer is a copy of the file that you edit. When you finish -changing the buffer, you write the contents of the buffer to the file. -Buffers not only contain file contents, but also all the marks, settings, and -other stuff that goes with it. - - -HIDDEN BUFFERS - -Suppose you are editing the file one.txt and need to edit the file two.txt. -You could simply use ":edit two.txt", but since you made changes to one.txt -that won't work. You also don't want to write one.txt yet. Vim has a -solution for you: > - - :hide edit two.txt - -The buffer "one.txt" disappears from the screen, but Vim still knows that you -are editing this buffer, so it keeps the modified text. This is called a -hidden buffer: The buffer contains text, but you can't see it. - The argument of ":hide" is another command. ":hide" makes that command -behave as if the 'hidden' option was set. You could also set this option -yourself. The effect is that when any buffer is abandoned, it becomes hidden. - Be careful! When you have hidden buffers with changes, don't exit Vim -without making sure you have saved all the buffers. - - -INACTIVE BUFFERS - - When a buffer has been used once, Vim remembers some information about it. -When it is not displayed in a window and it is not hidden, it is still in the -buffer list. This is called an inactive buffer. Overview: - - Active Appears in a window, text loaded. - Hidden Not in a window, text loaded. - Inactive Not in a window, no text loaded. - -The inactive buffers are remembered, because Vim keeps information about them, -like marks. And remembering the file name is useful too, so that you can see -which files you have edited. And edit them again. - - -LISTING BUFFERS - -View the buffer list with this command: > - - :buffers - -A command which does the same, is not so obvious to list buffers, but is much -shorter to type: > - - :ls - -The output could look like this: - - 1 #h "help.txt" line 62 ~ - 2 %a+ "usr_21.txt" line 1 ~ - 3 "usr_toc.txt" line 1 ~ - -The first column contains the buffer number. You can use this to edit the -buffer without having to type the name, see below. - After the buffer number come the flags. Then the name of the file -and the line number where the cursor was the last time. - The flags that can appear are these (from left to right): - - u Buffer is unlisted |unlisted-buffer|. - % Current buffer. - # Alternate buffer. - a Buffer is loaded and displayed. - h Buffer is loaded but hidden. - = Buffer is read-only. - - Buffer is not modifiable, the 'modifiable' option is off. - + Buffer has been modified. - - -EDITING A BUFFER - -You can edit a buffer by its number. That avoids having to type the file -name: > - - :buffer 2 - -But the only way to know the number is by looking in the buffer list. You can -use the name, or part of it, instead: > - - :buffer help - -Vim will find a best match for the name you type. If there is only one -buffer that matches the name, it will be used. In this case "help.txt". - To open a buffer in a new window: > - - :sbuffer 3 - -This works with a name as well. - - -USING THE BUFFER LIST - -You can move around in the buffer list with these commands: - - :bnext go to next buffer - :bprevious go to previous buffer - :bfirst go to the first buffer - :blast go to the last buffer - -To remove a buffer from the list, use this command: > - - :bdelete 3 - -Again, this also works with a name. - If you delete a buffer that was active (visible in a window), that window -will be closed. If you delete the current buffer, the current window will be -closed. If it was the last window, Vim will find another buffer to edit. You -can't be editing nothing! - - Note: - Even after removing the buffer with ":bdelete" Vim still remembers it. - It's actually made "unlisted", it no longer appears in the list from - ":buffers". The ":buffers!" command will list unlisted buffers (yes, - Vim can do the impossible). To really make Vim forget about a buffer, - use ":bwipe". Also see the 'buflisted' option. - -============================================================================== - -Next chapter: |usr_23.txt| Editing other files - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_23.txt b/share/vim/vim72/doc/usr_23.txt deleted file mode 100644 index 03367b89c2..0000000000 --- a/share/vim/vim72/doc/usr_23.txt +++ /dev/null @@ -1,343 +0,0 @@ -*usr_23.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - VIM USER MANUAL - by Bram Moolenaar - - Editing other files - - -This chapter is about editing files that are not ordinary files. With Vim you -can edit files that are compressed or encrypted. Some files need to be -accessed over the internet. With some restrictions, binary files can be -edited as well. - -|23.1| DOS, Mac and Unix files -|23.2| Files on the internet -|23.3| Encryption -|23.4| Binary files -|23.5| Compressed files - - Next chapter: |usr_24.txt| Inserting quickly - Previous chapter: |usr_22.txt| Finding the file to edit -Table of contents: |usr_toc.txt| - -============================================================================== -*23.1* DOS, Mac and Unix files - -Back in the early days, the old Teletype machines used two characters to -start a new line. One to move the carriage back to the first position -(carriage return, <CR>), another to move the paper up (line feed, <LF>). - When computers came out, storage was expensive. Some people decided that -they did not need two characters for end-of-line. The UNIX people decided -they could use <Line Feed> only for end-of-line. The Apple people -standardized on <CR>. The MS-DOS (and Microsoft Windows) folks decided to -keep the old <CR><LF>. - This means that if you try to move a file from one system to another, you -have line-break problems. The Vim editor automatically recognizes the -different file formats and handles things properly behind your back. - The option 'fileformats' contains the various formats that will be tried -when a new file is edited. The following command, for example, tells Vim to -try UNIX format first and MS-DOS format second: > - - :set fileformats=unix,dos - -You will notice the format in the message you get when editing a file. You -don't see anything if you edit a native file format. Thus editing a Unix file -on Unix won't result in a remark. But when you edit a dos file, Vim will -notify you of this: - - "/tmp/test" [dos] 3L, 71C ~ - -For a Mac file you would see "[mac]". - The detected file format is stored in the 'fileformat' option. To see -which format you have, execute the following command: > - - :set fileformat? - -The three names that Vim uses are: - - unix <LF> - dos <CR><LF> - mac <CR> - - -USING THE MAC FORMAT - -On Unix, <LF> is used to break a line. It's not unusual to have a <CR> -character halfway a line. Incidentally, this happens quite often in Vi (and -Vim) scripts. - On the Macintosh, where <CR> is the line break character, it's possible to -have a <LF> character halfway a line. - The result is that it's not possible to be 100% sure whether a file -containing both <CR> and <LF> characters is a Mac or a Unix file. Therefore, -Vim assumes that on Unix you probably won't edit a Mac file, and doesn't check -for this type of file. To check for this format anyway, add "mac" to -'fileformats': > - - :set fileformats+=mac - -Then Vim will take a guess at the file format. Watch out for situations where -Vim guesses wrong. - - -OVERRULING THE FORMAT - -If you use the good old Vi and try to edit an MS-DOS format file, you will -find that each line ends with a ^M character. (^M is <CR>). The automatic -detection avoids this. Suppose you do want to edit the file that way? Then -you need to overrule the format: > - - :edit ++ff=unix file.txt - -The "++" string is an item that tells Vim that an option name follows, which -overrules the default for this single command. "++ff" is used for -'fileformat'. You could also use "++ff=mac" or "++ff=dos". - This doesn't work for any option, only "++ff" and "++enc" are currently -implemented. The full names "++fileformat" and "++encoding" also work. - - -CONVERSION - -You can use the 'fileformat' option to convert from one file format to -another. Suppose, for example, that you have an MS-DOS file named README.TXT -that you want to convert to UNIX format. Start by editing the MS-DOS format -file: > - vim README.TXT - -Vim will recognize this as a dos format file. Now change the file format to -UNIX: > - - :set fileformat=unix - :write - -The file is written in Unix format. - -============================================================================== -*23.2* Files on the internet - -Someone sends you an e-mail message, which refers to a file by its URL. For -example: - - You can find the information here: ~ - ftp://ftp.vim.org/pub/vim/README ~ - -You could start a program to download the file, save it on your local disk and -then start Vim to edit it. - There is a much simpler way. Move the cursor to any character of the URL. -Then use this command: > - - gf - -With a bit of luck, Vim will figure out which program to use for downloading -the file, download it and edit the copy. To open the file in a new window use -CTRL-W f. - If something goes wrong you will get an error message. It's possible that -the URL is wrong, you don't have permission to read it, the network connection -is down, etc. Unfortunately, it's hard to tell the cause of the error. You -might want to try the manual way of downloading the file. - -Accessing files over the internet works with the netrw plugin. Currently URLs -with these formats are recognized: - - ftp:// uses ftp - rcp:// uses rcp - scp:// uses scp - http:// uses wget (reading only) - -Vim doesn't do the communication itself, it relies on the mentioned programs -to be available on your computer. On most Unix systems "ftp" and "rcp" will -be present. "scp" and "wget" might need to be installed. - -Vim detects these URLs for each command that starts editing a new file, also -with ":edit" and ":split", for example. Write commands also work, except for -http://. - -For more information, also about passwords, see |netrw|. - -============================================================================== -*23.3* Encryption - -Some information you prefer to keep to yourself. For example, when writing -a test on a computer that students also use. You don't want clever students -to figure out a way to read the questions before the exam starts. Vim can -encrypt the file for you, which gives you some protection. - To start editing a new file with encryption, use the "-x" argument to start -Vim. Example: > - - vim -x exam.txt - -Vim prompts you for a key used for encrypting and decrypting the file: - - Enter encryption key: ~ - -Carefully type the secret key now. You cannot see the characters you type, -they will be replaced by stars. To avoid the situation that a typing mistake -will cause trouble, Vim asks you to enter the key again: - - Enter same key again: ~ - -You can now edit this file normally and put in all your secrets. When you -finish editing the file and tell Vim to exit, the file is encrypted and -written. - When you edit the file with Vim, it will ask you to enter the same key -again. You don't need to use the "-x" argument. You can also use the normal -":edit" command. Vim adds a magic string to the file by which it recognizes -that the file was encrypted. - If you try to view this file using another program, all you get is garbage. -Also, if you edit the file with Vim and enter the wrong key, you get garbage. -Vim does not have a mechanism to check if the key is the right one (this makes -it much harder to break the key). - - -SWITCHING ENCRYPTION ON AND OFF - -To disable the encryption of a file, set the 'key' option to an empty string: -> - :set key= - -The next time you write the file this will be done without encryption. - Setting the 'key' option to enable encryption is not a good idea, because -the password appears in the clear. Anyone shoulder-surfing can read your -password. - To avoid this problem, the ":X" command was created. It asks you for an -encryption key, just like the "-x" argument did: > - - :X - Enter encryption key: ****** - Enter same key again: ****** - - -LIMITS ON ENCRYPTION - -The encryption algorithm used by Vim is weak. It is good enough to keep out -the casual prowler, but not good enough to keep out a cryptology expert with -lots of time on his hands. Also you should be aware that the swap file is not -encrypted; so while you are editing, people with superuser privileges can read -the unencrypted text from this file. - One way to avoid letting people read your swap file is to avoid using one. -If the -n argument is supplied on the command line, no swap file is used -(instead, Vim puts everything in memory). For example, to edit the encrypted -file "file.txt" without a swap file use the following command: > - - vim -x -n file.txt - -When already editing a file, the swapfile can be disabled with: > - - :setlocal noswapfile - -Since there is no swapfile, recovery will be impossible. Save the file a bit -more often to avoid the risk of losing your changes. - -While the file is in memory, it is in plain text. Anyone with privilege can -look in the editor's memory and discover the contents of the file. - If you use a viminfo file, be aware that the contents of text registers are -written out in the clear as well. - If you really want to secure the contents of a file, edit it only on a -portable computer not connected to a network, use good encryption tools, and -keep the computer locked up in a big safe when not in use. - -============================================================================== -*23.4* Binary files - -You can edit binary files with Vim. Vim wasn't really made for this, thus -there are a few restrictions. But you can read a file, change a character and -write it back, with the result that only that one character was changed and -the file is identical otherwise. - To make sure that Vim does not use its clever tricks in the wrong way, add -the "-b" argument when starting Vim: > - - vim -b datafile - -This sets the 'binary' option. The effect of this is that unexpected side -effects are turned off. For example, 'textwidth' is set to zero, to avoid -automatic formatting of lines. And files are always read in Unix file format. - -Binary mode can be used to change a message in a program. Be careful not to -insert or delete any characters, it would stop the program from working. Use -"R" to enter replace mode. - -Many characters in the file will be unprintable. To see them in Hex format: > - - :set display=uhex - -Otherwise, the "ga" command can be used to see the value of the character -under the cursor. The output, when the cursor is on an <Esc>, looks like -this: - - <^[> 27, Hex 1b, Octal 033 ~ - -There might not be many line breaks in the file. To get some overview switch -the 'wrap' option off: > - - :set nowrap - - -BYTE POSITION - -To see on which byte you are in the file use this command: > - - g CTRL-G - -The output is verbose: - - Col 9-16 of 9-16; Line 277 of 330; Word 1806 of 2058; Byte 10580 of 12206 ~ - -The last two numbers are the byte position in the file and the total number of -bytes. This takes into account how 'fileformat' changes the number of bytes -that a line break uses. - To move to a specific byte in the file, use the "go" command. For -example, to move to byte 2345: > - - 2345go - - -USING XXD - -A real binary editor shows the text in two ways: as it is and in hex format. -You can do this in Vim by first converting the file with the "xxd" program. -This comes with Vim. - First edit the file in binary mode: > - - vim -b datafile - -Now convert the file to a hex dump with xxd: > - - :%!xxd - -The text will look like this: - - 0000000: 1f8b 0808 39d7 173b 0203 7474 002b 4e49 ....9..;..tt.+NI ~ - 0000010: 4b2c 8660 eb9c ecac c462 eb94 345e 2e30 K,.`.....b..4^.0 ~ - 0000020: 373b 2731 0b22 0ca6 c1a2 d669 1035 39d9 7;'1.".....i.59. ~ - -You can now view and edit the text as you like. Vim treats the information as -ordinary text. Changing the hex does not cause the printable character to be -changed, or the other way around. - Finally convert it back with: -> - :%!xxd -r - -Only changes in the hex part are used. Changes in the printable text part on -the right are ignored. - -See the manual page of xxd for more information. - -============================================================================== -*23.5* Compressed files - -This is easy: You can edit a compressed file just like any other file. The -"gzip" plugin takes care of decompressing the file when you edit it. And -compressing it again when you write it. - These compression methods are currently supported: - - .Z compress - .gz gzip - .bz2 bzip2 - -Vim uses the mentioned programs to do the actual compression and -decompression. You might need to install the programs first. - -============================================================================== - -Next chapter: |usr_24.txt| Inserting quickly - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_24.txt b/share/vim/vim72/doc/usr_24.txt deleted file mode 100644 index 37592a098d..0000000000 --- a/share/vim/vim72/doc/usr_24.txt +++ /dev/null @@ -1,606 +0,0 @@ -*usr_24.txt* For Vim version 7.2. Last change: 2006 Jul 23 - - VIM USER MANUAL - by Bram Moolenaar - - Inserting quickly - - -When entering text, Vim offers various ways to reduce the number of keystrokes -and avoid typing mistakes. Use Insert mode completion to repeat previously -typed words. Abbreviate long words to short ones. Type characters that -aren't on your keyboard. - -|24.1| Making corrections -|24.2| Showing matches -|24.3| Completion -|24.4| Repeating an insert -|24.5| Copying from another line -|24.6| Inserting a register -|24.7| Abbreviations -|24.8| Entering special characters -|24.9| Digraphs -|24.10| Normal mode commands - - Next chapter: |usr_25.txt| Editing formatted text - Previous chapter: |usr_23.txt| Editing other files -Table of contents: |usr_toc.txt| - -============================================================================== -*24.1* Making corrections - -The <BS> key was already mentioned. It deletes the character just before the -cursor. The <Del> key does the same for the character under (after) the -cursor. - When you typed a whole word wrong, use CTRL-W: - - The horse had fallen to the sky ~ - CTRL-W - The horse had fallen to the ~ - -If you really messed up a line and want to start over, use CTRL-U to delete -it. This keeps the text after the cursor and the indent. Only the text from -the first non-blank to the cursor is deleted. With the cursor on the "f" of -"fallen" in the next line pressing CTRL-U does this: - - The horse had fallen to the ~ - CTRL-U - fallen to the ~ - -When you spot a mistake a few words back, you need to move the cursor there to -correct it. For example, you typed this: - - The horse had follen to the ground ~ - -You need to change "follen" to "fallen". With the cursor at the end, you -would type this to correct it: > - - <Esc>4blraA - -< get out of Insert mode <Esc> - four words back 4b - move on top of the "o" l - replace with "a" ra - restart Insert mode A - -Another way to do this: > - - <C-Left><C-Left><C-Left><C-Left><Right><Del>a<End> - -< four words back <C-Left><C-Left><C-Left><C-Left> - move on top of the "o" <Right> - delete the "o" <Del> - insert an "a" a - go to end of the line <End> - -This uses special keys to move around, while remaining in Insert mode. This -resembles what you would do in a modeless editor. It's easier to remember, -but takes more time (you have to move your hand from the letters to the cursor -keys, and the <End> key is hard to press without looking at the keyboard). - These special keys are most useful when writing a mapping that doesn't -leave Insert mode. The extra typing doesn't matter then. - An overview of the keys you can use in Insert mode: - - <C-Home> to start of the file - <PageUp> a whole screenful up - <Home> to start of line - <S-Left> one word left - <C-Left> one word left - <S-Right> one word right - <C-Right> one word right - <End> to end of the line - <PageDown> a whole screenful down - <C-End> to end of the file - -There are a few more, see |ins-special-special|. - -============================================================================== -*24.2* Showing matches - -When you type a ) it would be nice to see with which ( it matches. To make -Vim do that use this command: > - - :set showmatch - -When you now type a text like "(example)", as soon as you type the ) Vim will -briefly move the cursor to the matching (, keep it there for half a second, -and move back to where you were typing. - In case there is no matching (, Vim will beep. Then you know that you -might have forgotten the ( somewhere, or typed a ) too many. - The match will also be shown for [] and {} pairs. You don't have to wait -with typing the next character, as soon as Vim sees it the cursor will move -back and inserting continues as before. - You can change the time Vim waits with the 'matchtime' option. For -example, to make Vim wait one and a half second: > - - :set matchtime=15 - -The time is specified in tenths of a second. - -============================================================================== -*24.3* Completion - -Vim can automatically complete words on insertion. You type the first part of -a word, press CTRL-P, and Vim guesses the rest. - Suppose, for example, that you are creating a C program and want to type in -the following: - - total = ch_array[0] + ch_array[1] + ch_array[2]; ~ - -You start by entering the following: - - total = ch_array[0] + ch_ ~ - -At this point, you tell Vim to complete the word using the command CTRL-P. -Vim searches for a word that starts with what's in front of the cursor. In -this case, it is "ch_", which matches with the word ch_array. So typing -CTRL-P gives you the following: - - total = ch_array[0] + ch_array ~ - -After a little more typing, you get this (ending in a space): - - total = ch_array[0] + ch_array[1] + ~ - -If you now type CTRL-P Vim will search again for a word that completes the -word before the cursor. Since there is nothing in front of the cursor, it -finds the first word backwards, which is "ch_array". Typing CTRL-P again -gives you the next word that matches, in this case "total". A third CTRL-P -searches further back. If there is nothing else, it causes the editor to run -out of words, so it returns to the original text, which is nothing. A fourth -CTRL-P causes the editor to start over again with "ch_array". - -To search forward, use CTRL-N. Since the search wraps around the end of the -file, CTRL-N and CTRL-P will find the same matches, but in a different -sequence. Hint: CTRL-N is Next-match and CTRL-P is Previous-match. - -The Vim editor goes through a lot of effort to find words to complete. By -default, it searches the following places: - - 1. Current file - 2. Files in other windows - 3. Other loaded files (hidden buffers) - 4. Files which are not loaded (inactive buffers) - 5. Tag files - 6. All files #included by the current file - - -OPTIONS - -You can customize the search order with the 'complete' option. - -The 'ignorecase' option is used. When it is set, case differences are ignored -when searching for matches. - -A special option for completion is 'infercase'. This is useful to find -matches while ignoring case ('ignorecase' must be set) but still using the -case of the word typed so far. Thus if you type "For" and Vim finds a match -"fortunately", it will result in "Fortunately". - - -COMPLETING SPECIFIC ITEMS - -If you know what you are looking for, you can use these commands to complete -with a certain type of item: - - CTRL-X CTRL-F file names - CTRL-X CTRL-L whole lines - CTRL-X CTRL-D macro definitions (also in included files) - CTRL-X CTRL-I current and included files - CTRL-X CTRL-K words from a dictionary - CTRL-X CTRL-T words from a thesaurus - CTRL-X CTRL-] tags - CTRL-X CTRL-V Vim command line - -After each of them CTRL-N can be used to find the next match, CTRL-P to find -the previous match. - More information for each of these commands here: |ins-completion|. - - -COMPLETING FILE NAMES - -Let's take CTRL-X CTRL-F as an example. This will find file names. It scans -the current directory for files and displays each one that matches the word in -front of the cursor. - Suppose, for example, that you have the following files in the current -directory: - - main.c sub_count.c sub_done.c sub_exit.c - -Now enter Insert mode and start typing: - - The exit code is in the file sub ~ - -At this point, you enter the command CTRL-X CTRL-F. Vim now completes the -current word "sub" by looking at the files in the current directory. The -first match is sub_count.c. This is not the one you want, so you match the -next file by typing CTRL-N. This match is sub_done.c. Typing CTRL-N again -takes you to sub_exit.c. The results: - - The exit code is in the file sub_exit.c ~ - -If the file name starts with / (Unix) or C:\ (MS-Windows) you can find all -files in the file system. For example, type "/u" and CTRL-X CTRL-F. This -will match "/usr" (this is on Unix): - - the file is found in /usr/ ~ - -If you now press CTRL-N you go back to "/u". Instead, to accept the "/usr/" -and go one directory level deeper, use CTRL-X CTRL-F again: - - the file is found in /usr/X11R6/ ~ - -The results depend on what is found in your file system, of course. The -matches are sorted alphabetically. - - -COMPLETING IN SOURCE CODE - -Source code files are well structured. That makes it possible to do -completion in an intelligent way. In Vim this is called Omni completion. In -some other editors it's called intellisense, but that is a trademark. - -The key to Omni completion is CTRL-X CTRL-O. Obviously the O stands for Omni -here, so that you can remember it easier. Let's use an example for editing C -source: - - { ~ - struct foo *p; ~ - p-> ~ - -The cursor is after "p->". Now type CTRL-X CTRL-O. Vim will offer you a list -of alternatives, which are the items that "struct foo" contains. That is -quite different from using CTRL-P, which would complete any word, while only -members of "struct foo" are valid here. - -For Omni completion to work you may need to do some setup. At least make sure -filetype plugins are enabled. Your vimrc file should contain a line like -this: > - filetype plugin on -Or: > - filetype plugin indent on - -For C code you need to create a tags file and set the 'tags' option. That is -explained |ft-c-omni|. For other filetypes you may need to do something -similar, look below |compl-omni-filetypes|. It only works for specific -filetypes. Check the value of the 'omnifunc' option to find out if it would -work. - -============================================================================== -*24.4* Repeating an insert - -If you press CTRL-A, the editor inserts the text you typed the last time you -were in Insert mode. - Assume, for example, that you have a file that begins with the following: - - "file.h" ~ - /* Main program begins */ ~ - -You edit this file by inserting "#include " at the beginning of the first -line: - - #include "file.h" ~ - /* Main program begins */ ~ - -You go down to the beginning of the next line using the commands "j^". You -now start to insert a new "#include" line. So you type: > - - i CTRL-A - -The result is as follows: - - #include "file.h" ~ - #include /* Main program begins */ ~ - -The "#include " was inserted because CTRL-A inserts the text of the previous -insert. Now you type "main.h"<Enter> to finish the line: - - - #include "file.h" ~ - #include "main.h" ~ - /* Main program begins */ ~ - -The CTRL-@ command does a CTRL-A and then exits Insert mode. That's a quick -way of doing exactly the same insertion again. - -============================================================================== -*24.5* Copying from another line - -The CTRL-Y command inserts the character above the cursor. This is useful -when you are duplicating a previous line. For example, you have this line of -C code: - - b_array[i]->s_next = a_array[i]->s_next; ~ - -Now you need to type the same line, but with "s_prev" instead of "s_next". -Start the new line, and press CTRL-Y 14 times, until you are at the "n" of -"next": - - b_array[i]->s_next = a_array[i]->s_next; ~ - b_array[i]->s_ ~ - -Now you type "prev": - - b_array[i]->s_next = a_array[i]->s_next; ~ - b_array[i]->s_prev ~ - -Continue pressing CTRL-Y until the following "next": - - b_array[i]->s_next = a_array[i]->s_next; ~ - b_array[i]->s_prev = a_array[i]->s_ ~ - -Now type "prev;" to finish it off. - -The CTRL-E command acts like CTRL-Y except it inserts the character below the -cursor. - -============================================================================== -*24.6* Inserting a register - -The command CTRL-R {register} inserts the contents of the register. This is -useful to avoid having to type a long word. For example, you need to type -this: - - r = VeryLongFunction(a) + VeryLongFunction(b) + VeryLongFunction(c) ~ - -The function name is defined in a different file. Edit that file and move the -cursor on top of the function name there, and yank it into register v: > - - "vyiw - -"v is the register specification, "yiw" is yank-inner-word. Now edit the file -where the new line is to be inserted, and type the first letters: - - r = ~ - -Now use CTRL-R v to insert the function name: - - r = VeryLongFunction ~ - -You continue to type the characters in between the function name, and use -CTRL-R v two times more. - You could have done the same with completion. Using a register is useful -when there are many words that start with the same characters. - -If the register contains characters such as <BS> or other special characters, -they are interpreted as if they had been typed from the keyboard. If you do -not want this to happen (you really want the <BS> to be inserted in the text), -use the command CTRL-R CTRL-R {register}. - -============================================================================== -*24.7* Abbreviations - -An abbreviation is a short word that takes the place of a long one. For -example, "ad" stands for "advertisement". Vim enables you to type an -abbreviation and then will automatically expand it for you. - To tell Vim to expand "ad" into "advertisement" every time you insert it, -use the following command: > - - :iabbrev ad advertisement - -Now, when you type "ad", the whole word "advertisement" will be inserted into -the text. This is triggered by typing a character that can't be part of a -word, for example a space: - - What Is Entered What You See - I saw the a I saw the a ~ - I saw the ad I saw the ad ~ - I saw the ad<Space> I saw the advertisement<Space> ~ - -The expansion doesn't happen when typing just "ad". That allows you to type a -word like "add", which will not get expanded. Only whole words are checked -for abbreviations. - - -ABBREVIATING SEVERAL WORDS - -It is possible to define an abbreviation that results in multiple words. For -example, to define "JB" as "Jack Benny", use the following command: > - - :iabbrev JB Jack Benny - -As a programmer, I use two rather unusual abbreviations: > - - :iabbrev #b /**************************************** - :iabbrev #e <Space>****************************************/ - -These are used for creating boxed comments. The comment starts with #b, which -draws the top line. I then type the comment text and use #e to draw the -bottom line. - Notice that the #e abbreviation begins with a space. In other words, the -first two characters are space-star. Usually Vim ignores spaces between the -abbreviation and the expansion. To avoid that problem, I spell space as seven -characters: <, S, p, a, c, e, >. - - Note: - ":iabbrev" is a long word to type. ":iab" works just as well. - That's abbreviating the abbreviate command! - - -FIXING TYPING MISTAKES - -It's very common to make the same typing mistake every time. For example, -typing "teh" instead of "the". You can fix this with an abbreviation: > - - :abbreviate teh the - -You can add a whole list of these. Add one each time you discover a common -mistake. - - -LISTING ABBREVIATIONS - -The ":abbreviate" command lists the abbreviations: - - :abbreviate - i #e ****************************************/ - i #b /**************************************** - i JB Jack Benny - i ad advertisement - ! teh the - -The "i" in the first column indicates Insert mode. These abbreviations are -only active in Insert mode. Other possible characters are: - - c Command-line mode :cabbrev - ! both Insert and Command-line mode :abbreviate - -Since abbreviations are not often useful in Command-line mode, you will mostly -use the ":iabbrev" command. That avoids, for example, that "ad" gets expanded -when typing a command like: > - - :edit ad - - -DELETING ABBREVIATIONS - -To get rid of an abbreviation, use the ":unabbreviate" command. Suppose you -have the following abbreviation: > - - :abbreviate @f fresh - -You can remove it with this command: > - - :unabbreviate @f - -While you type this, you will notice that @f is expanded to "fresh". Don't -worry about this, Vim understands it anyway (except when you have an -abbreviation for "fresh", but that's very unlikely). - To remove all the abbreviations: > - - :abclear - -":unabbreviate" and ":abclear" also come in the variants for Insert mode -(":iunabbreviate and ":iabclear") and Command-line mode (":cunabbreviate" and -":cabclear"). - - -REMAPPING ABBREVIATIONS - -There is one thing to watch out for when defining an abbreviation: The -resulting string should not be mapped. For example: > - - :abbreviate @a adder - :imap dd disk-door - -When you now type @a, you will get "adisk-doorer". That's not what you want. -To avoid this, use the ":noreabbrev" command. It does the same as -":abbreviate", but avoids that the resulting string is used for mappings: > - - :noreabbrev @a adder - -Fortunately, it's unlikely that the result of an abbreviation is mapped. - -============================================================================== -*24.8* Entering special characters - -The CTRL-V command is used to insert the next character literally. In other -words, any special meaning the character has, it will be ignored. For -example: > - - CTRL-V <Esc> - -Inserts an escape character. Thus you don't leave Insert mode. (Don't type -the space after CTRL-V, it's only to make this easier to read). - - Note: - On MS-Windows CTRL-V is used to paste text. Use CTRL-Q instead of - CTRL-V. On Unix, on the other hand, CTRL-Q does not work on some - terminals, because it has a special meaning. - -You can also use the command CTRL-V {digits} to insert a character with the -decimal number {digits}. For example, the character number 127 is the <Del> -character (but not necessarily the <Del> key!). To insert <Del> type: > - - CTRL-V 127 - -You can enter characters up to 255 this way. When you type fewer than two -digits, a non-digit will terminate the command. To avoid the need of typing a -non-digit, prepend one or two zeros to make three digits. - All the next commands insert a <Tab> and then a dot: - - CTRL-V 9. - CTRL-V 09. - CTRL-V 009. - -To enter a character in hexadecimal, use an "x" after the CTRL-V: > - - CTRL-V x7f - -This also goes up to character 255 (CTRL-V xff). You can use "o" to type a -character as an octal number and two more methods allow you to type up to -a 16 bit and a 32 bit number (e.g., for a Unicode character): > - - CTRL-V o123 - CTRL-V u1234 - CTRL-V U12345678 - -============================================================================== -*24.9* Digraphs - -Some characters are not on the keyboard. For example, the copyright character -(©). To type these characters in Vim, you use digraphs, where two characters -represent one. To enter a ©, for example, you press three keys: > - - CTRL-K Co - -To find out what digraphs are available, use the following command: > - - :digraphs - -Vim will display the digraph table. Here are three lines of it: - - AC ~_ 159 NS | 160 !I ¡ 161 Ct ¢ 162 Pd £ 163 Cu ¤ 164 Ye ¥ 165 ~ - BB ¦ 166 SE § 167 ': ¨ 168 Co © 169 -a ª 170 << « 171 NO ¬ 172 ~ - -- ­ 173 Rg ® 174 'm ¯ 175 DG ° 176 +- ± 177 2S ² 178 3S ³ 179 ~ - -This shows, for example, that the digraph you get by typing CTRL-K Pd is the -character (£). This is character number 163 (decimal). - Pd is short for Pound. Most digraphs are selected to give you a hint about -the character they will produce. If you look through the list you will -understand the logic. - You can exchange the first and second character, if there is no digraph for -that combination. Thus CTRL-K dP also works. Since there is no digraph for -"dP" Vim will also search for a "Pd" digraph. - - Note: - The digraphs depend on the character set that Vim assumes you are - using. On MS-DOS they are different from MS-Windows. Always use - ":digraphs" to find out which digraphs are currently available. - -You can define your own digraphs. Example: > - - :digraph a" ä - -This defines that CTRL-K a" inserts an ä character. You can also specify the -character with a decimal number. This defines the same digraph: > - - :digraph a" 228 - -More information about digraphs here: |digraphs| - Another way to insert special characters is with a keymap. More about that -here: |45.5| - -============================================================================== -*24.10* Normal mode commands - -Insert mode offers a limited number of commands. In Normal mode you have many -more. When you want to use one, you usually leave Insert mode with <Esc>, -execute the Normal mode command, and re-enter Insert mode with "i" or "a". - There is a quicker way. With CTRL-O {command} you can execute any Normal -mode command from Insert mode. For example, to delete from the cursor to the -end of the line: > - - CTRL-O D - -You can execute only one Normal mode command this way. But you can specify a -register or a count. A more complicated example: > - - CTRL-O "g3dw - -This deletes up to the third word into register g. - -============================================================================== - -Next chapter: |usr_25.txt| Editing formatted text - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_25.txt b/share/vim/vim72/doc/usr_25.txt deleted file mode 100644 index 88505da306..0000000000 --- a/share/vim/vim72/doc/usr_25.txt +++ /dev/null @@ -1,578 +0,0 @@ -*usr_25.txt* For Vim version 7.2. Last change: 2007 May 11 - - VIM USER MANUAL - by Bram Moolenaar - - Editing formatted text - - -Text hardly ever comes in one sentence per line. This chapter is about -breaking sentences to make them fit on a page and other formatting. -Vim also has useful features for editing single-line paragraphs and tables. - -|25.1| Breaking lines -|25.2| Aligning text -|25.3| Indents and tabs -|25.4| Dealing with long lines -|25.5| Editing tables - - Next chapter: |usr_26.txt| Repeating - Previous chapter: |usr_24.txt| Inserting quickly -Table of contents: |usr_toc.txt| - -============================================================================== -*25.1* Breaking lines - -Vim has a number of functions that make dealing with text easier. By default, -the editor does not perform automatic line breaks. In other words, you have -to press <Enter> yourself. This is useful when you are writing programs where -you want to decide where the line ends. It is not so good when you are -creating documentation and want the text to be at most 70 character wide. - If you set the 'textwidth' option, Vim automatically inserts line breaks. -Suppose, for example, that you want a very narrow column of only 30 -characters. You need to execute the following command: > - - :set textwidth=30 - -Now you start typing (ruler added): - - 1 2 3 - 12345678901234567890123456789012345 - I taught programming for a whi ~ - -If you type "l" next, this makes the line longer than the 30-character limit. -When Vim sees this, it inserts a line break and you get the following: - - 1 2 3 - 12345678901234567890123456789012345 - I taught programming for a ~ - whil ~ - -Continuing on, you can type in the rest of the paragraph: - - 1 2 3 - 12345678901234567890123456789012345 - I taught programming for a ~ - while. One time, I was stopped ~ - by the Fort Worth police, ~ - because my homework was too ~ - hard. True story. ~ - -You do not have to type newlines; Vim puts them in automatically. - - Note: - The 'wrap' option makes Vim display lines with a line break, but this - doesn't insert a line break in the file. - - -REFORMATTING - -The Vim editor is not a word processor. In a word processor, if you delete -something at the beginning of the paragraph, the line breaks are reworked. In -Vim they are not; so if you delete the word "programming" from the first line, -all you get is a short line: - - 1 2 3 - 12345678901234567890123456789012345 - I taught for a ~ - while. One time, I was stopped ~ - by the Fort Worth police, ~ - because my homework was too ~ - hard. True story. ~ - -This does not look good. To get the paragraph into shape you use the "gq" -operator. - Let's first use this with a Visual selection. Starting from the first -line, type: > - - v4jgq - -"v" to start Visual mode, "4j' to move to the end of the paragraph and then -the "gq" operator. The result is: - - 1 2 3 - 12345678901234567890123456789012345 - I taught for a while. One ~ - time, I was stopped by the ~ - Fort Worth police, because my ~ - homework was too hard. True ~ - story. ~ - -Note: there is a way to do automatic formatting for specific types of text -layouts, see |auto-format|. - -Since "gq" is an operator, you can use one of the three ways to select the -text it works on: With Visual mode, with a movement and with a text object. - The example above could also be done with "gq4j". That's less typing, but -you have to know the line count. A more useful motion command is "}". This -moves to the end of a paragraph. Thus "gq}" formats from the cursor to the -end of the current paragraph. - A very useful text object to use with "gq" is the paragraph. Try this: > - - gqap - -"ap" stands for "a-paragraph". This formats the text of one paragraph -(separated by empty lines). Also the part before the cursor. - If you have your paragraphs separated by empty lines, you can format the -whole file by typing this: > - - gggqG - -"gg" to move to the first line, "gqG" to format until the last line. - Warning: If your paragraphs are not properly separated, they will be joined -together. A common mistake is to have a line with a space or tab. That's a -blank line, but not an empty line. - -Vim is able to format more than just plain text. See |fo-table| for how to -change this. See the 'joinspaces' option to change the number of spaces used -after a full stop. - It is possible to use an external program for formatting. This is useful -if your text can't be properly formatted with Vim's builtin command. See the -'formatprg' option. - -============================================================================== -*25.2* Aligning text - -To center a range of lines, use the following command: > - - :{range}center [width] - -{range} is the usual command-line range. [width] is an optional line width to -use for centering. If [width] is not specified, it defaults to the value of -'textwidth'. (If 'textwidth' is 0, the default is 80.) - For example: > - - :1,5center 40 - -results in the following: - - I taught for a while. One ~ - time, I was stopped by the ~ - Fort Worth police, because my ~ - homework was too hard. True ~ - story. ~ - - -RIGHT ALIGNMENT - -Similarly, the ":right" command right-justifies the text: > - - :1,5right 37 - -gives this result: - - I taught for a while. One ~ - time, I was stopped by the ~ - Fort Worth police, because my ~ - homework was too hard. True ~ - story. ~ - -LEFT ALIGNMENT - -Finally there is this command: > - - :{range}left [margin] - -Unlike ":center" and ":right", however, the argument to ":left" is not the -length of the line. Instead it is the left margin. If it is omitted, the -text will be put against the left side of the screen (using a zero margin -would do the same). If it is 5, the text will be indented 5 spaces. For -example, use these commands: > - - :1left 5 - :2,5left - -This results in the following: - - I taught for a while. One ~ - time, I was stopped by the ~ - Fort Worth police, because my ~ - homework was too hard. True ~ - story. ~ - - -JUSTIFYING TEXT - -Vim has no built-in way of justifying text. However, there is a neat macro -package that does the job. To use this package, execute the following -command: > - - :runtime macros/justify.vim - -This Vim script file defines a new visual command "_j". To justify a block of -text, highlight the text in Visual mode and then execute "_j". - Look in the file for more explanations. To go there, do "gf" on this name: -$VIMRUNTIME/macros/justify.vim. - -An alternative is to filter the text through an external program. Example: > - - :%!fmt - -============================================================================== -*25.3* Indents and tabs - -Indents can be used to make text stand out from the rest. The example texts -in this manual, for example, are indented by eight spaces or a tab. You would -normally enter this by typing a tab at the start of each line. Take this -text: - the first line ~ - the second line ~ - -This is entered by typing a tab, some text, <Enter>, tab and more text. - The 'autoindent' option inserts indents automatically: > - - :set autoindent - -When a new line is started it gets the same indent as the previous line. In -the above example, the tab after the <Enter> is not needed anymore. - - -INCREASING INDENT - -To increase the amount of indent in a line, use the ">" operator. Often this -is used as ">>", which adds indent to the current line. - The amount of indent added is specified with the 'shiftwidth' option. The -default value is 8. To make ">>" insert four spaces worth of indent, for -example, type this: > - - :set shiftwidth=4 - -When used on the second line of the example text, this is what you get: - - the first line ~ - the second line ~ - -"4>>" will increase the indent of four lines. - - -TABSTOP - -If you want to make indents a multiple of 4, you set 'shiftwidth' to 4. But -when pressing a <Tab> you still get 8 spaces worth of indent. To change this, -set the 'softtabstop' option: > - - :set softtabstop=4 - -This will make the <Tab> key insert 4 spaces worth of indent. If there are -already four spaces, a <Tab> character is used (saving seven characters in the -file). (If you always want spaces and no tab characters, set the 'expandtab' -option.) - - Note: - You could set the 'tabstop' option to 4. However, if you edit the - file another time, with 'tabstop' set to the default value of 8, it - will look wrong. In other programs and when printing the indent will - also be wrong. Therefore it is recommended to keep 'tabstop' at eight - all the time. That's the standard value everywhere. - - -CHANGING TABS - -You edit a file which was written with a tabstop of 3. In Vim it looks ugly, -because it uses the normal tabstop value of 8. You can fix this by setting -'tabstop' to 3. But you have to do this every time you edit this file. - Vim can change the use of tabstops in your file. First, set 'tabstop' to -make the indents look good, then use the ":retab" command: > - - :set tabstop=3 - :retab 8 - -The ":retab" command will change 'tabstop' to 8, while changing the text such -that it looks the same. It changes spans of white space into tabs and spaces -for this. You can now write the file. Next time you edit it the indents will -be right without setting an option. - Warning: When using ":retab" on a program, it may change white space inside -a string constant. Therefore it's a good habit to use "\t" instead of a -real tab. - -============================================================================== -*25.4* Dealing with long lines - -Sometimes you will be editing a file that is wider than the number of columns -in the window. When that occurs, Vim wraps the lines so that everything fits -on the screen. - If you switch the 'wrap' option off, each line in the file shows up as one -line on the screen. Then the ends of the long lines disappear off the screen -to the right. - When you move the cursor to a character that can't be seen, Vim will scroll -the text to show it. This is like moving a viewport over the text in the -horizontal direction. - By default, Vim does not display a horizontal scrollbar in the GUI. If you -want to enable one, use the following command: > - - :set guioptions+=b - -One horizontal scrollbar will appear at the bottom of the Vim window. - -If you don't have a scrollbar or don't want to use it, use these commands to -scroll the text. The cursor will stay in the same place, but it's move back -into the visible text if necessary. - - zh scroll right - 4zh scroll four characters right - zH scroll half a window width right - ze scroll right to put the cursor at the end - zl scroll left - 4zl scroll four characters left - zL scroll half a window width left - zs scroll left to put the cursor at the start - -Let's attempt to show this with one line of text. The cursor is on the "w" of -"which". The "current window" above the line indicates the text that is -currently visible. The "window"s below the text indicate the text that is -visible after the command left of it. - - |<-- current window -->| - some long text, part of which is visible in the window ~ - ze |<-- window -->| - zH |<-- window -->| - 4zh |<-- window -->| - zh |<-- window -->| - zl |<-- window -->| - 4zl |<-- window -->| - zL |<-- window -->| - zs |<-- window -->| - - -MOVING WITH WRAP OFF - -When 'wrap' is off and the text has scrolled horizontally, you can use the -following commands to move the cursor to a character you can see. Thus text -left and right of the window is ignored. These never cause the text to -scroll: - - g0 to first visible character in this line - g^ to first non-blank visible character in this line - gm to middle of this line - g$ to last visible character in this line - - |<-- window -->| - some long text, part of which is visible ~ - g0 g^ gm g$ - - -BREAKING AT WORDS *edit-no-break* - -When preparing text for use by another program, you might have to make -paragraphs without a line break. A disadvantage of using 'nowrap' is that you -can't see the whole sentence you are working on. When 'wrap' is on, words are -broken halfway, which makes them hard to read. - A good solution for editing this kind of paragraph is setting the -'linebreak' option. Vim then breaks lines at an appropriate place when -displaying the line. The text in the file remains unchanged. - Without 'linebreak' text might look like this: - - +---------------------------------+ - |letter generation program for a b| - |ank. They wanted to send out a s| - |pecial, personalized letter to th| - |eir richest 1000 customers. Unfo| - |rtunately for the programmer, he | - +---------------------------------+ -After: > - - :set linebreak - -it looks like this: - - +---------------------------------+ - |letter generation program for a | - |bank. They wanted to send out a | - |special, personalized letter to | - |their richest 1000 customers. | - |Unfortunately for the programmer,| - +---------------------------------+ - -Related options: -'breakat' specifies the characters where a break can be inserted. -'showbreak' specifies a string to show at the start of broken line. -Set 'textwidth' to zero to avoid a paragraph to be split. - - -MOVING BY VISIBLE LINES - -The "j" and "k" commands move to the next and previous lines. When used on -a long line, this means moving a lot of screen lines at once. - To move only one screen line, use the "gj" and "gk" commands. When a line -doesn't wrap they do the same as "j" and "k". When the line does wrap, they -move to a character displayed one line below or above. - You might like to use these mappings, which bind these movement commands to -the cursor keys: > - - :map <Up> gk - :map <Down> gj - - -TURNING A PARAGRAPH INTO ONE LINE - -If you want to import text into a program like MS-Word, each paragraph should -be a single line. If your paragraphs are currently separated with empty -lines, this is how you turn each paragraph into a single line: > - - :g/./,/^$/join - -That looks complicated. Let's break it up in pieces: - - :g/./ A ":global" command that finds all lines that contain - at least one character. - ,/^$/ A range, starting from the current line (the non-empty - line) until an empty line. - join The ":join" command joins the range of lines together - into one line. - -Starting with this text, containing eight lines broken at column 30: - - +----------------------------------+ - |A letter generation program | - |for a bank. They wanted to | - |send out a special, | - |personalized letter. | - | | - |To their richest 1000 | - |customers. Unfortunately for | - |the programmer, | - +----------------------------------+ - -You end up with two lines: - - +----------------------------------+ - |A letter generation program for a | - |bank. They wanted to send out a s| - |pecial, personalized letter. | - |To their richest 1000 customers. | - |Unfortunately for the programmer, | - +----------------------------------+ - -Note that this doesn't work when the separating line is blank but not empty; -when it contains spaces and/or tabs. This command does work with blank lines: -> - :g/\S/,/^\s*$/join - -This still requires a blank or empty line at the end of the file for the last -paragraph to be joined. - -============================================================================== -*25.5* Editing tables - -Suppose you are editing a table with four columns: - - nice table test 1 test 2 test 3 ~ - input A 0.534 ~ - input B 0.913 ~ - -You need to enter numbers in the third column. You could move to the second -line, use "A", enter a lot of spaces and type the text. - For this kind of editing there is a special option: > - - set virtualedit=all - -Now you can move the cursor to positions where there isn't any text. This is -called "virtual space". Editing a table is a lot easier this way. - Move the cursor by searching for the header of the last column: > - - /test 3 - -Now press "j" and you are right where you can enter the value for "input A". -Typing "0.693" results in: - - nice table test 1 test 2 test 3 ~ - input A 0.534 0.693 ~ - input B 0.913 ~ - -Vim has automatically filled the gap in front of the new text for you. Now, -to enter the next field in this column use "Bj". "B" moves back to the start -of a white space separated word. Then "j" moves to the place where the next -field can be entered. - - Note: - You can move the cursor anywhere in the display, also beyond the end - of a line. But Vim will not insert spaces there, until you insert a - character in that position. - - -COPYING A COLUMN - -You want to add a column, which should be a copy of the third column and -placed before the "test 1" column. Do this in seven steps: -1. Move the cursor to the left upper corner of this column, e.g., with - "/test 3". -2. Press CTRL-V to start blockwise Visual mode. -3. Move the cursor down two lines with "2j". You are now in "virtual space": - the "input B" line of the "test 3" column. -4. Move the cursor right, to include the whole column in the selection, plus - the space that you want between the columns. "9l" should do it. -5. Yank the selected rectangle with "y". -6. Move the cursor to "test 1", where the new column must be placed. -7. Press "P". - -The result should be: - - nice table test 3 test 1 test 2 test 3 ~ - input A 0.693 0.534 0.693 ~ - input B 0.913 ~ - -Notice that the whole "test 1" column was shifted right, also the line where -the "test 3" column didn't have text. - -Go back to non-virtual cursor movements with: > - - :set virtualedit= - - -VIRTUAL REPLACE MODE - -The disadvantage of using 'virtualedit' is that it "feels" different. You -can't recognize tabs or spaces beyond the end of line when moving the cursor -around. Another method can be used: Virtual Replace mode. - Suppose you have a line in a table that contains both tabs and other -characters. Use "rx" on the first tab: - - inp 0.693 0.534 0.693 ~ - - | - rx | - V - - inpx0.693 0.534 0.693 ~ - -The layout is messed up. To avoid that, use the "gr" command: - - inp 0.693 0.534 0.693 ~ - - | - grx | - V - - inpx 0.693 0.534 0.693 ~ - -What happens is that the "gr" command makes sure the new character takes the -right amount of screen space. Extra spaces or tabs are inserted to fill the -gap. Thus what actually happens is that a tab is replaced by "x" and then -blanks added to make the text after it keep it's place. In this case a -tab is inserted. - When you need to replace more than one character, you use the "R" command -to go to Replace mode (see |04.9|). This messes up the layout and replaces -the wrong characters: - - inp 0 0.534 0.693 ~ - - | - R0.786 | - V - - inp 0.78634 0.693 ~ - -The "gR" command uses Virtual Replace mode. This preserves the layout: - - inp 0 0.534 0.693 ~ - - | - gR0.786 | - V - - inp 0.786 0.534 0.693 ~ - -============================================================================== - -Next chapter: |usr_26.txt| Repeating - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_26.txt b/share/vim/vim72/doc/usr_26.txt deleted file mode 100644 index 551875fa60..0000000000 --- a/share/vim/vim72/doc/usr_26.txt +++ /dev/null @@ -1,221 +0,0 @@ -*usr_26.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - VIM USER MANUAL - by Bram Moolenaar - - Repeating - - -An editing task is hardly ever unstructured. A change often needs to be made -several times. In this chapter a number of useful ways to repeat a change -will be explained. - -|26.1| Repeating with Visual mode -|26.2| Add and subtract -|26.3| Making a change in many files -|26.4| Using Vim from a shell script - - Next chapter: |usr_27.txt| Search commands and patterns - Previous chapter: |usr_25.txt| Editing formatted text -Table of contents: |usr_toc.txt| - -============================================================================== -*26.1* Repeating with Visual mode - -Visual mode is very handy for making a change in any sequence of lines. You -can see the highlighted text, thus you can check if the correct lines are -changed. But making the selection takes some typing. The "gv" command -selects the same area again. This allows you to do another operation on the -same text. - Suppose you have some lines where you want to change "2001" to "2002" and -"2000" to "2001": - - The financial results for 2001 are better ~ - than for 2000. The income increased by 50%, ~ - even though 2001 had more rain than 2000. ~ - 2000 2001 ~ - income 45,403 66,234 ~ - -First change "2001" to "2002". Select the lines in Visual mode, and use: > - - :s/2001/2002/g - -Now use "gv" to reselect the same text. It doesn't matter where the cursor -is. Then use ":s/2000/2001/g" to make the second change. - Obviously, you can repeat these changes several times. - -============================================================================== -*26.2* Add and subtract - -When repeating the change of one number into another, you often have a fixed -offset. In the example above, one was added to each year. Instead of typing -a substitute command for each year that appears, the CTRL-A command can be -used. - Using the same text as above, search for a year: > - - /19[0-9][0-9]\|20[0-9][0-9] - -Now press CTRL-A. The year will be increased by one: - - The financial results for 2002 are better ~ - than for 2000. The income increased by 50%, ~ - even though 2001 had more rain than 2000. ~ - 2000 2001 ~ - income 45,403 66,234 ~ - -Use "n" to find the next year, and press "." to repeat the CTRL-A ("." is a -bit quicker to type). Repeat "n" and "." for all years that appear. - Hint: set the 'hlsearch' option to see the matches you are going to change, -then you can look ahead and do it faster. - -Adding more than one can be done by prepending the number to CTRL-A. Suppose -you have this list: - - 1. item four ~ - 2. item five ~ - 3. item six ~ - -Move the cursor to "1." and type: > - - 3 CTRL-A - -The "1." will change to "4.". Again, you can use "." to repeat this on the -other numbers. - -Another example: - - 006 foo bar ~ - 007 foo bar ~ - -Using CTRL-A on these numbers results in: - - 007 foo bar ~ - 010 foo bar ~ - -7 plus one is 10? What happened here is that Vim recognized "007" as an octal -number, because there is a leading zero. This notation is often used in C -programs. If you do not want a number with leading zeros to be handled as -octal, use this: > - - :set nrformats-=octal - -The CTRL-X command does subtraction in a similar way. - -============================================================================== -*26.3* Making a change in many files - -Suppose you have a variable called "x_cnt" and you want to change it to -"x_counter". This variable is used in several of your C files. You need to -change it in all files. This is how you do it. - Put all the relevant files in the argument list: > - - :args *.c -< -This finds all C files and edits the first one. Now you can perform a -substitution command on all these files: > - - :argdo %s/\<x_cnt\>/x_counter/ge | update - -The ":argdo" command takes an argument that is another command. That command -will be executed on all files in the argument list. - The "%s" substitute command that follows works on all lines. It finds the -word "x_cnt" with "\<x_cnt\>". The "\<" and "\>" are used to match the whole -word only, and not "px_cnt" or "x_cnt2". - The flags for the substitute command include "g" to replace all occurrences -of "x_cnt" in the same line. The "e" flag is used to avoid an error message -when "x_cnt" does not appear in the file. Otherwise ":argdo" would abort on -the first file where "x_cnt" was not found. - The "|" separates two commands. The following "update" command writes the -file only if it was changed. If no "x_cnt" was changed to "x_counter" nothing -happens. - -There is also the ":windo" command, which executes its argument in all -windows. And ":bufdo" executes its argument on all buffers. Be careful with -this, because you might have more files in the buffer list than you think. -Check this with the ":buffers" command (or ":ls"). - -============================================================================== -*26.4* Using Vim from a shell script - -Suppose you have a lot of files in which you need to change the string -"-person-" to "Jones" and then print it. How do you do that? One way is to -do a lot of typing. The other is to write a shell script to do the work. - The Vim editor does a superb job as a screen-oriented editor when using -Normal mode commands. For batch processing, however, Normal mode commands do -not result in clear, commented command files; so here you will use Ex mode -instead. This mode gives you a nice command-line interface that makes it easy -to put into a batch file. ("Ex command" is just another name for a -command-line (:) command.) - The Ex mode commands you need are as follows: > - - %s/-person-/Jones/g - write tempfile - quit - -You put these commands in the file "change.vim". Now to run the editor in -batch mode, use this shell script: > - - for file in *.txt; do - vim -e -s $file < change.vim - lpr -r tempfile - done - -The for-done loop is a shell construct to repeat the two lines in between, -while the $file variable is set to a different file name each time. - The second line runs the Vim editor in Ex mode (-e argument) on the file -$file and reads commands from the file "change.vim". The -s argument tells -Vim to operate in silent mode. In other words, do not keep outputting the -:prompt, or any other prompt for that matter. - The "lpr -r tempfile" command prints the resulting "tempfile" and deletes -it (that's what the -r argument does). - - -READING FROM STDIN - -Vim can read text on standard input. Since the normal way is to read commands -there, you must tell Vim to read text instead. This is done by passing the -"-" argument in place of a file. Example: > - - ls | vim - - -This allows you to edit the output of the "ls" command, without first saving -the text in a file. - If you use the standard input to read text from, you can use the "-S" -argument to read a script: > - - producer | vim -S change.vim - - - -NORMAL MODE SCRIPTS - -If you really want to use Normal mode commands in a script, you can use it -like this: > - - vim -s script file.txt ... -< - Note: - "-s" has a different meaning when it is used without "-e". Here it - means to source the "script" as Normal mode commands. When used with - "-e" it means to be silent, and doesn't use the next argument as a - file name. - -The commands in "script" are executed like you typed them. Don't forget that -a line break is interpreted as pressing <Enter>. In Normal mode that moves -the cursor to the next line. - To create the script you can edit the script file and type the commands. -You need to imagine what the result would be, which can be a bit difficult. -Another way is to record the commands while you perform them manually. This -is how you do that: > - - vim -w script file.txt ... - -All typed keys will be written to "script". If you make a small mistake you -can just continue and remember to edit the script later. - The "-w" argument appends to an existing script. That is good when you -want to record the script bit by bit. If you want to start from scratch and -start all over, use the "-W" argument. It overwrites any existing file. - -============================================================================== - -Next chapter: |usr_27.txt| Search commands and patterns - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_27.txt b/share/vim/vim72/doc/usr_27.txt deleted file mode 100644 index f06515d1ae..0000000000 --- a/share/vim/vim72/doc/usr_27.txt +++ /dev/null @@ -1,563 +0,0 @@ -*usr_27.txt* For Vim version 7.2. Last change: 2007 Nov 10 - - VIM USER MANUAL - by Bram Moolenaar - - Search commands and patterns - - -In chapter 3 a few simple search patterns were mentioned |03.9|. Vim can do -much more complex searches. This chapter explains the most often used ones. -A detailed specification can be found here: |pattern| - -|27.1| Ignoring case -|27.2| Wrapping around the file end -|27.3| Offsets -|27.4| Matching multiple times -|27.5| Alternatives -|27.6| Character ranges -|27.7| Character classes -|27.8| Matching a line break -|27.9| Examples - - Next chapter: |usr_28.txt| Folding - Previous chapter: |usr_26.txt| Repeating -Table of contents: |usr_toc.txt| - -============================================================================== -*27.1* Ignoring case - -By default, Vim's searches are case sensitive. Therefore, "include", -"INCLUDE", and "Include" are three different words and a search will match -only one of them. - Now switch on the 'ignorecase' option: > - - :set ignorecase - -Search for "include" again, and now it will match "Include", "INCLUDE" and -"InClUDe". (Set the 'hlsearch' option to quickly see where a pattern -matches.) - You can switch this off again with: > - - :set noignorecase - -But lets keep it set, and search for "INCLUDE". It will match exactly the -same text as "include" did. Now set the 'smartcase' option: > - - :set ignorecase smartcase - -If you have a pattern with at least one uppercase character, the search -becomes case sensitive. The idea is that you didn't have to type that -uppercase character, so you must have done it because you wanted case to -match. That's smart! - With these two options set you find the following matches: - - pattern matches ~ - word word, Word, WORD, WoRd, etc. - Word Word - WORD WORD - WoRd WoRd - - -CASE IN ONE PATTERN - -If you want to ignore case for one specific pattern, you can do this by -prepending the "\c" string. Using "\C" will make the pattern to match case. -This overrules the 'ignorecase' and 'smartcase' options, when "\c" or "\C" is -used their value doesn't matter. - - pattern matches ~ - \Cword word - \CWord Word - \cword word, Word, WORD, WoRd, etc. - \cWord word, Word, WORD, WoRd, etc. - -A big advantage of using "\c" and "\C" is that it sticks with the pattern. -Thus if you repeat a pattern from the search history, the same will happen, no -matter if 'ignorecase' or 'smartcase' was changed. - - Note: - The use of "\" items in search patterns depends on the 'magic' option. - In this chapters we will assume 'magic' is on, because that is the - standard and recommended setting. If you would change 'magic', many - search patterns would suddenly become invalid. - - Note: - If your search takes much longer than you expected, you can interrupt - it with CTRL-C on Unix and CTRL-Break on MS-DOS and MS-Windows. - -============================================================================== -*27.2* Wrapping around the file end - -By default, a forward search starts searching for the given string at the -current cursor location. It then proceeds to the end of the file. If it has -not found the string by that time, it starts from the beginning and searches -from the start of the file to the cursor location. - Keep in mind that when repeating the "n" command to search for the next -match, you eventually get back to the first match. If you don't notice this -you keep searching forever! To give you a hint, Vim displays this message: - - search hit BOTTOM, continuing at TOP ~ - -If you use the "?" command, to search in the other direction, you get this -message: - - search hit TOP, continuing at BOTTOM ~ - -Still, you don't know when you are back at the first match. One way to see -this is by switching on the 'ruler' option: > - - :set ruler - -Vim will display the cursor position in the lower righthand corner of the -window (in the status line if there is one). It looks like this: - - 101,29 84% ~ - -The first number is the line number of the cursor. Remember the line number -where you started, so that you can check if you passed this position again. - - -NOT WRAPPING - -To turn off search wrapping, use the following command: > - - :set nowrapscan - -Now when the search hits the end of the file, an error message displays: - - E385: search hit BOTTOM without match for: forever ~ - -Thus you can find all matches by going to the start of the file with "gg" and -keep searching until you see this message. - If you search in the other direction, using "?", you get: - - E384: search hit TOP without match for: forever ~ - -============================================================================== -*27.3* Offsets - -By default, the search command leaves the cursor positioned on the beginning -of the pattern. You can tell Vim to leave it some other place by specifying -an offset. For the forward search command "/", the offset is specified by -appending a slash (/) and the offset: > - - /default/2 - -This command searches for the pattern "default" and then moves to the -beginning of the second line past the pattern. Using this command on the -paragraph above, Vim finds the word "default" in the first line. Then the -cursor is moved two lines down and lands on "an offset". - -If the offset is a simple number, the cursor will be placed at the beginning -of the line that many lines from the match. The offset number can be positive -or negative. If it is positive, the cursor moves down that many lines; if -negative, it moves up. - - -CHARACTER OFFSETS - -The "e" offset indicates an offset from the end of the match. It moves the -cursor onto the last character of the match. The command: > - - /const/e - -puts the cursor on the "t" of "const". - From that position, adding a number moves forward that many characters. -This command moves to the character just after the match: > - - /const/e+1 - -A positive number moves the cursor to the right, a negative number moves it to -the left. For example: > - - /const/e-1 - -moves the cursor to the "s" of "const". - -If the offset begins with "b", the cursor moves to the beginning of the -pattern. That's not very useful, since leaving out the "b" does the same -thing. It does get useful when a number is added or subtracted. The cursor -then goes forward or backward that many characters. For example: > - - /const/b+2 - -Moves the cursor to the beginning of the match and then two characters to the -right. Thus it lands on the "n". - - -REPEATING - -To repeat searching for the previously used search pattern, but with a -different offset, leave out the pattern: > - - /that - //e - -Is equal to: > - - /that/e - -To repeat with the same offset: > - - / - -"n" does the same thing. To repeat while removing a previously used offset: > - - // - - -SEARCHING BACKWARDS - -The "?" command uses offsets in the same way, but you must use "?" to separate -the offset from the pattern, instead of "/": > - - ?const?e-2 - -The "b" and "e" keep their meaning, they don't change direction with the use -of "?". - - -START POSITION - -When starting a search, it normally starts at the cursor position. When you -specify a line offset, this can cause trouble. For example: > - - /const/-2 - -This finds the next word "const" and then moves two lines up. If you -use "n" to search again, Vim could start at the current position and find the same -"const" match. Then using the offset again, you would be back where you started. -You would be stuck! - It could be worse: Suppose there is another match with "const" in the next -line. Then repeating the forward search would find this match and move two -lines up. Thus you would actually move the cursor back! - -When you specify a character offset, Vim will compensate for this. Thus the -search starts a few characters forward or backward, so that the same match -isn't found again. - -============================================================================== -*27.4* Matching multiple times - -The "*" item specifies that the item before it can match any number of times. -Thus: > - - /a* - -matches "a", "aa", "aaa", etc. But also "" (the empty string), because zero -times is included. - The "*" only applies to the item directly before it. Thus "ab*" matches -"a", "ab", "abb", "abbb", etc. To match a whole string multiple times, it -must be grouped into one item. This is done by putting "\(" before it and -"\)" after it. Thus this command: > - - /\(ab\)* - -Matches: "ab", "abab", "ababab", etc. And also "". - -To avoid matching the empty string, use "\+". This makes the previous item -match one or more times. > - - /ab\+ - -Matches "ab", "abb", "abbb", etc. It does not match "a" when no "b" follows. - -To match an optional item, use "\=". Example: > - - /folders\= - -Matches "folder" and "folders". - - -SPECIFIC COUNTS - -To match a specific number of items use the form "\{n,m}". "n" and "m" are -numbers. The item before it will be matched "n" to "m" times |inclusive|. -Example: > - - /ab\{3,5} - -matches "abbb", "abbbb" and "abbbbb". - When "n" is omitted, it defaults to zero. When "m" is omitted it defaults -to infinity. When ",m" is omitted, it matches exactly "n" times. -Examples: - - pattern match count ~ - \{,4} 0, 1, 2, 3 or 4 - \{3,} 3, 4, 5, etc. - \{0,1} 0 or 1, same as \= - \{0,} 0 or more, same as * - \{1,} 1 or more, same as \+ - \{3} 3 - - -MATCHING AS LITTLE AS POSSIBLE - -The items so far match as many characters as they can find. To match as few -as possible, use "\{-n,m}". It works the same as "\{n,m}", except that the -minimal amount possible is used. - For example, use: > - - /ab\{-1,3} - -Will match "ab" in "abbb". Actually, it will never match more than one b, -because there is no reason to match more. It requires something else to force -it to match more than the lower limit. - The same rules apply to removing "n" and "m". It's even possible to remove -both of the numbers, resulting in "\{-}". This matches the item before it -zero or more times, as few as possible. The item by itself always matches -zero times. It is useful when combined with something else. Example: > - - /a.\{-}b - -This matches "axb" in "axbxb". If this pattern would be used: > - - /a.*b - -It would try to match as many characters as possible with ".*", thus it -matches "axbxb" as a whole. - -============================================================================== -*27.5* Alternatives - -The "or" operator in a pattern is "\|". Example: > - - /foo\|bar - -This matches "foo" or "bar". More alternatives can be concatenated: > - - /one\|two\|three - -Matches "one", "two" and "three". - To match multiple times, the whole thing must be placed in "\(" and "\)": > - - /\(foo\|bar\)\+ - -This matches "foo", "foobar", "foofoo", "barfoobar", etc. - Another example: > - - /end\(if\|while\|for\) - -This matches "endif", "endwhile" and "endfor". - -A related item is "\&". This requires that both alternatives match in the -same place. The resulting match uses the last alternative. Example: > - - /forever\&... - -This matches "for" in "forever". It will not match "fortuin", for example. - -============================================================================== -*27.6* Character ranges - -To match "a", "b" or "c" you could use "/a\|b\|c". When you want to match all -letters from "a" to "z" this gets very long. There is a shorter method: > - - /[a-z] - -The [] construct matches a single character. Inside you specify which -characters to match. You can include a list of characters, like this: > - - /[0123456789abcdef] - -This will match any of the characters included. For consecutive characters -you can specify the range. "0-3" stands for "0123". "w-z" stands for "wxyz". -Thus the same command as above can be shortened to: > - - /[0-9a-f] - -To match the "-" character itself make it the first or last one in the range. -These special characters are accepted to make it easier to use them inside a -[] range (they can actually be used anywhere in the search pattern): - - \e <Esc> - \t <Tab> - \r <CR> - \b <BS> - -There are a few more special cases for [] ranges, see |/[]| for the whole -story. - - -COMPLEMENTED RANGE - -To avoid matching a specific character, use "^" at the start of the range. -The [] item then matches everything but the characters included. Example: > - - /"[^"]*" -< - " a double quote - [^"] any character that is not a double quote - * as many as possible - " a double quote again - -This matches "foo" and "3!x", including the double quotes. - - -PREDEFINED RANGES - -A number of ranges are used very often. Vim provides a shortcut for these. -For example: > - - /\a - -Finds alphabetic characters. This is equal to using "/[a-zA-Z]". Here are a -few more of these: - - item matches equivalent ~ - \d digit [0-9] - \D non-digit [^0-9] - \x hex digit [0-9a-fA-F] - \X non-hex digit [^0-9a-fA-F] - \s white space [ ] (<Tab> and <Space>) - \S non-white characters [^ ] (not <Tab> and <Space>) - \l lowercase alpha [a-z] - \L non-lowercase alpha [^a-z] - \u uppercase alpha [A-Z] - \U non-uppercase alpha [^A-Z] - - Note: - Using these predefined ranges works a lot faster than the character - range it stands for. - These items can not be used inside []. Thus "[\d\l]" does NOT work to - match a digit or lowercase alpha. Use "\(\d\|\l\)" instead. - -See |/\s| for the whole list of these ranges. - -============================================================================== -*27.7* Character classes - -The character range matches a fixed set of characters. A character class is -similar, but with an essential difference: The set of characters can be -redefined without changing the search pattern. - For example, search for this pattern: > - - /\f\+ - -The "\f" items stands for file name characters. Thus this matches a sequence -of characters that can be a file name. - Which characters can be part of a file name depends on the system you are -using. On MS-Windows, the backslash is included, on Unix it is not. This is -specified with the 'isfname' option. The default value for Unix is: > - - :set isfname - isfname=@,48-57,/,.,-,_,+,,,#,$,%,~,= - -For other systems the default value is different. Thus you can make a search -pattern with "\f" to match a file name, and it will automatically adjust to -the system you are using it on. - - Note: - Actually, Unix allows using just about any character in a file name, - including white space. Including these characters in 'isfname' would - be theoretically correct. But it would make it impossible to find the - end of a file name in text. Thus the default value of 'isfname' is a - compromise. - -The character classes are: - - item matches option ~ - \i identifier characters 'isident' - \I like \i, excluding digits - \k keyword characters 'iskeyword' - \K like \k, excluding digits - \p printable characters 'isprint' - \P like \p, excluding digits - \f file name characters 'isfname' - \F like \f, excluding digits - -============================================================================== -*27.8* Matching a line break - -Vim can find a pattern that includes a line break. You need to specify where -the line break happens, because all items mentioned so far don't match a line -break. - To check for a line break in a specific place, use the "\n" item: > - - /the\nword - -This will match at a line that ends in "the" and the next line starts with -"word". To match "the word" as well, you need to match a space or a line -break. The item to use for it is "\_s": > - - /the\_sword - -To allow any amount of white space: > - - /the\_s\+word - -This also matches when "the " is at the end of a line and " word" at the -start of the next one. - -"\s" matches white space, "\_s" matches white space or a line break. -Similarly, "\a" matches an alphabetic character, and "\_a" matches an -alphabetic character or a line break. The other character classes and ranges -can be modified in the same way by inserting a "_". - -Many other items can be made to match a line break by prepending "\_". For -example: "\_." matches any character or a line break. - - Note: - "\_.*" matches everything until the end of the file. Be careful with - this, it can make a search command very slow. - -Another example is "\_[]", a character range that includes a line break: > - - /"\_[^"]*" - -This finds a text in double quotes that may be split up in several lines. - -============================================================================== -*27.9* Examples - -Here are a few search patterns you might find useful. This shows how the -items mentioned above can be combined. - - -FINDING A CALIFORNIA LICENSE PLATE - -A sample license plate number is "1MGU103". It has one digit, three uppercase -letters and three digits. Directly putting this into a search pattern: > - - /\d\u\u\u\d\d\d - -Another way is to specify that there are three digits and letters with a -count: > - - /\d\u\{3}\d\{3} - -Using [] ranges instead: > - - /[0-9][A-Z]\{3}[0-9]\{3} - -Which one of these you should use? Whichever one you can remember. The -simple way you can remember is much faster than the fancy way that you can't. -If you can remember them all, then avoid the last one, because it's both more -typing and slower to execute. - - -FINDING AN IDENTIFIER - -In C programs (and many other computer languages) an identifier starts with a -letter and further consists of letters and digits. Underscores can be used -too. This can be found with: > - - /\<\h\w*\> - -"\<" and "\>" are used to find only whole words. "\h" stands for "[A-Za-z_]" -and "\w" for "[0-9A-Za-z_]". - - Note: - "\<" and "\>" depend on the 'iskeyword' option. If it includes "-", - for example, then "ident-" is not matched. In this situation use: > - - /\w\@<!\h\w*\w\@! -< - This checks if "\w" does not match before or after the identifier. - See |/\@<!| and |/\@!|. - -============================================================================== - -Next chapter: |usr_28.txt| Folding - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_28.txt b/share/vim/vim72/doc/usr_28.txt deleted file mode 100644 index 912f22bca8..0000000000 --- a/share/vim/vim72/doc/usr_28.txt +++ /dev/null @@ -1,426 +0,0 @@ -*usr_28.txt* For Vim version 7.2. Last change: 2008 Jun 14 - - VIM USER MANUAL - by Bram Moolenaar - - Folding - - -Structured text can be separated in sections. And sections in sub-sections. -Folding allows you to display a section as one line, providing an overview. -This chapter explains the different ways this can be done. - -|28.1| What is folding? -|28.2| Manual folding -|28.3| Working with folds -|28.4| Saving and restoring folds -|28.5| Folding by indent -|28.6| Folding with markers -|28.7| Folding by syntax -|28.8| Folding by expression -|28.9| Folding unchanged lines -|28.10| Which fold method to use? - - Next chapter: |usr_29.txt| Moving through programs - Previous chapter: |usr_27.txt| Search commands and patterns -Table of contents: |usr_toc.txt| - -============================================================================== -*28.1* What is folding? - -Folding is used to show a range of lines in the buffer as a single line on the -screen. Like a piece of paper which is folded to make it shorter: - - +------------------------+ - | line 1 | - | line 2 | - | line 3 | - |_______________________ | - \ \ - \________________________\ - / folded lines / - /________________________/ - | line 12 | - | line 13 | - | line 14 | - +------------------------+ - -The text is still in the buffer, unchanged. Only the way lines are displayed -is affected by folding. - -The advantage of folding is that you can get a better overview of the -structure of text, by folding lines of a section and replacing it with a line -that indicates that there is a section. - -============================================================================== -*28.2* Manual folding - -Try it out: Position the cursor in a paragraph and type: > - - zfap - -You will see that the paragraph is replaced by a highlighted line. You have -created a fold. |zf| is an operator and |ap| a text object selection. You -can use the |zf| operator with any movement command to create a fold for the -text that it moved over. |zf| also works in Visual mode. - -To view the text again, open the fold by typing: > - - zo - -And you can close the fold again with: > - - zc - -All the folding commands start with "z". With some fantasy, this looks like a -folded piece of paper, seen from the side. The letter after the "z" has a -mnemonic meaning to make it easier to remember the commands: - - zf F-old creation - zo O-pen a fold - zc C-lose a fold - -Folds can be nested: A region of text that contains folds can be folded -again. For example, you can fold each paragraph in this section, and then -fold all the sections in this chapter. Try it out. You will notice that -opening the fold for the whole chapter will restore the nested folds as they -were, some may be open and some may be closed. - -Suppose you have created several folds, and now want to view all the text. -You could go to each fold and type "zo". To do this faster, use this command: > - - zr - -This will R-educe the folding. The opposite is: > - - zm - -This folds M-ore. You can repeat "zr" and "zm" to open and close nested folds -of several levels. - -If you have nested several levels deep, you can open all of them with: > - - zR - -This R-educes folds until there are none left. And you can close all folds -with: > - - zM - -This folds M-ore and M-ore. - -You can quickly disable the folding with the |zn| command. Then |zN| brings -back the folding as it was. |zi| toggles between the two. This is a useful -way of working: -- create folds to get overview on your file -- move around to where you want to do your work -- do |zi| to look at the text and edit it -- do |zi| again to go back to moving around - -More about manual folding in the reference manual: |fold-manual| - -============================================================================== -*28.3* Working with folds - -When some folds are closed, movement commands like "j" and "k" move over a -fold like it was a single, empty line. This allows you to quickly move around -over folded text. - -You can yank, delete and put folds as if it was a single line. This is very -useful if you want to reorder functions in a program. First make sure that -each fold contains a whole function (or a bit less) by selecting the right -'foldmethod'. Then delete the function with "dd", move the cursor and put it -with "p". If some lines of the function are above or below the fold, you can -use Visual selection: -- put the cursor on the first line to be moved -- hit "V" to start Visual mode -- put the cursor on the last line to be moved -- hit "d" to delete the selected lines. -- move the cursor to the new position and "p"ut the lines there. - -It is sometimes difficult to see or remember where a fold is located, thus -where a |zo| command would actually work. To see the defined folds: > - - :set foldcolumn=4 - -This will show a small column on the left of the window to indicate folds. -A "+" is shown for a closed fold. A "-" is shown at the start of each open -fold and "|" at following lines of the fold. - -You can use the mouse to open a fold by clicking on the "+" in the foldcolumn. -Clicking on the "-" or a "|" below it will close an open fold. - -To open all folds at the cursor line use |zO|. -To close all folds at the cursor line use |zC|. -To delete a fold at the cursor line use |zd|. -To delete all folds at the cursor line use |zD|. - -When in Insert mode, the fold at the cursor line is never closed. That allows -you to see what you type! - -Folds are opened automatically when jumping around or moving the cursor left -or right. For example, the "0" command opens the fold under the cursor -(if 'foldopen' contains "hor", which is the default). The 'foldopen' option -can be changed to open folds for specific commands. If you want the line -under the cursor always to be open, do this: > - - :set foldopen=all - -Warning: You won't be able to move onto a closed fold then. You might want to -use this only temporarily and then set it back to the default: > - - :set foldopen& - -You can make folds close automatically when you move out of it: > - - :set foldclose=all - -This will re-apply 'foldlevel' to all folds that don't contain the cursor. -You have to try it out if you like how this feels. Use |zm| to fold more and -|zr| to fold less (reduce folds). - -The folding is local to the window. This allows you to open two windows on -the same buffer, one with folds and one without folds. Or one with all folds -closed and one with all folds open. - -============================================================================== -*28.4* Saving and restoring folds - -When you abandon a file (starting to edit another one), the state of the folds -is lost. If you come back to the same file later, all manually opened and -closed folds are back to their default. When folds have been created -manually, all folds are gone! To save the folds use the |:mkview| command: > - - :mkview - -This will store the settings and other things that influence the view on the -file. You can change what is stored with the 'viewoptions' option. -When you come back to the same file later, you can load the view again: > - - :loadview - -You can store up to ten views on one file. For example, to save the current -setup as the third view and load the second view: > - - :mkview 3 - :loadview 2 - -Note that when you insert or delete lines the views might become invalid. -Also check out the 'viewdir' option, which specifies where the views are -stored. You might want to delete old views now and then. - -============================================================================== -*28.5* Folding by indent - -Defining folds with |zf| is a lot of work. If your text is structured by -giving lower level items a larger indent, you can use the indent folding -method. This will create folds for every sequence of lines with the same -indent. Lines with a larger indent will become nested folds. This works well -with many programming languages. - -Try this by setting the 'foldmethod' option: > - - :set foldmethod=indent - -Then you can use the |zm| and |zr| commands to fold more and reduce folding. -It's easy to see on this example text: - -This line is not indented - This line is indented once - This line is indented twice - This line is indented twice - This line is indented once -This line is not indented - This line is indented once - This line is indented once - -Note that the relation between the amount of indent and the fold depth depends -on the 'shiftwidth' option. Each 'shiftwidth' worth of indent adds one to the -depth of the fold. This is called a fold level. - -When you use the |zr| and |zm| commands you actually increase or decrease the -'foldlevel' option. You could also set it directly: > - - :set foldlevel=3 - -This means that all folds with three times a 'shiftwidth' indent or more will -be closed. The lower the foldlevel, the more folds will be closed. When -'foldlevel' is zero, all folds are closed. |zM| does set 'foldlevel' to zero. -The opposite command |zR| sets 'foldlevel' to the deepest fold level that is -present in the file. - -Thus there are two ways to open and close the folds: -(A) By setting the fold level. - This gives a very quick way of "zooming out" to view the structure of the - text, move the cursor, and "zoom in" on the text again. - -(B) By using |zo| and |zc| commands to open or close specific folds. - This allows opening only those folds that you want to be open, while other - folds remain closed. - -This can be combined: You can first close most folds by using |zm| a few times -and then open a specific fold with |zo|. Or open all folds with |zR| and -then close specific folds with |zc|. - -But you cannot manually define folds when 'foldmethod' is "indent", as that -would conflict with the relation between the indent and the fold level. - -More about folding by indent in the reference manual: |fold-indent| - -============================================================================== -*28.6* Folding with markers - -Markers in the text are used to specify the start and end of a fold region. -This gives precise control over which lines are included in a fold. The -disadvantage is that the text needs to be modified. - -Try it: > - - :set foldmethod=marker - -Example text, as it could appear in a C program: - - /* foobar () {{{ */ - int foobar() - { - /* return a value {{{ */ - return 42; - /* }}} */ - } - /* }}} */ - -Notice that the folded line will display the text before the marker. This is -very useful to tell what the fold contains. - -It's quite annoying when the markers don't pair up correctly after moving some -lines around. This can be avoided by using numbered markers. Example: - - /* global variables {{{1 */ - int varA, varB; - - /* functions {{{1 */ - /* funcA() {{{2 */ - void funcA() {} - - /* funcB() {{{2 */ - void funcB() {} - /* }}}1 */ - -At every numbered marker a fold at the specified level begins. This will make -any fold at a higher level stop here. You can just use numbered start markers -to define all folds. Only when you want to explicitly stop a fold before -another starts you need to add an end marker. - -More about folding with markers in the reference manual: |fold-marker| - -============================================================================== -*28.7* Folding by syntax - -For each language Vim uses a different syntax file. This defines the colors -for various items in the file. If you are reading this in Vim, in a terminal -that supports colors, the colors you see are made with the "help" syntax file. - In the syntax files it is possible to add syntax items that have the "fold" -argument. These define a fold region. This requires writing a syntax file -and adding these items in it. That's not so easy to do. But once it's done, -all folding happens automatically. - Here we'll assume you are using an existing syntax file. Then there is -nothing more to explain. You can open and close folds as explained above. -The folds will be created and deleted automatically when you edit the file. - -More about folding by syntax in the reference manual: |fold-syntax| - -============================================================================== -*28.8* Folding by expression - -This is similar to folding by indent, but instead of using the indent of a -line a user function is called to compute the fold level of a line. You can -use this for text where something in the text indicates which lines belong -together. An example is an e-mail message where the quoted text is indicated -by a ">" before the line. To fold these quotes use this: > - - :set foldmethod=expr - :set foldexpr=strlen(substitute(substitute(getline(v:lnum),'\\s','',\"g\"),'[^>].*','','')) - -You can try it out on this text: - -> quoted text he wrote -> quoted text he wrote -> > double quoted text I wrote -> > double quoted text I wrote - -Explanation for the 'foldexpr' used in the example (inside out): - getline(v:lnum) gets the current line - substitute(...,'\\s','','g') removes all white space from the line - substitute(...,'[^>].*','','') removes everything after leading '>'s - strlen(...) counts the length of the string, which - is the number of '>'s found - -Note that a backslash must be inserted before every space, double quote and -backslash for the ":set" command. If this confuses you, do > - - :set foldexpr - -to check the actual resulting value. To correct a complicated expression, use -the command-line completion: > - - :set foldexpr=<Tab> - -Where <Tab> is a real Tab. Vim will fill in the previous value, which you can -then edit. - -When the expression gets more complicated you should put it in a function and -set 'foldexpr' to call that function. - -More about folding by expression in the reference manual: |fold-expr| - -============================================================================== -*28.9* Folding unchanged lines - -This is useful when you set the 'diff' option in the same window. The -|vimdiff| command does this for you. Example: > - - :setlocal diff foldmethod=diff scrollbind nowrap foldlevel=1 - -Do this in every window that shows a different version of the same file. You -will clearly see the differences between the files, while the text that didn't -change is folded. - -For more details see |fold-diff|. - -============================================================================== -*28.10* Which fold method to use? - -All these possibilities make you wonder which method you should chose. -Unfortunately, there is no golden rule. Here are some hints. - -If there is a syntax file with folding for the language you are editing, that -is probably the best choice. If there isn't one, you might try to write it. -This requires a good knowledge of search patterns. It's not easy, but when -it's working you will not have to define folds manually. - -Typing commands to manually fold regions can be used for unstructured text. -Then use the |:mkview| command to save and restore your folds. - -The marker method requires you to change the file. If you are sharing the -files with other people or you have to meet company standards, you might not -be allowed to add them. - The main advantage of markers is that you can put them exactly where you -want them. That avoids that a few lines are missed when you cut and paste -folds. And you can add a comment about what is contained in the fold. - -Folding by indent is something that works in many files, but not always very -well. Use it when you can't use one of the other methods. However, it is -very useful for outlining. Then you specifically use one 'shiftwidth' for -each nesting level. - -Folding with expressions can make folds in almost any structured text. It is -quite simple to specify, especially if the start and end of a fold can easily -be recognized. - If you use the "expr" method to define folds, but they are not exactly how -you want them, you could switch to the "manual" method. This will not remove -the defined folds. Then you can delete or add folds manually. - -============================================================================== - -Next chapter: |usr_29.txt| Moving through programs - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_29.txt b/share/vim/vim72/doc/usr_29.txt deleted file mode 100644 index 82dfaf585c..0000000000 --- a/share/vim/vim72/doc/usr_29.txt +++ /dev/null @@ -1,613 +0,0 @@ -*usr_29.txt* For Vim version 7.2. Last change: 2008 Jun 28 - - VIM USER MANUAL - by Bram Moolenaar - - Moving through programs - - -The creator of Vim is a computer programmer. It's no surprise that Vim -contains many features to aid in writing programs. Jump around to find where -identifiers are defined and used. Preview declarations in a separate window. -There is more in the next chapter. - -|29.1| Using tags -|29.2| The preview window -|29.3| Moving through a program -|29.4| Finding global identifiers -|29.5| Finding local identifiers - - Next chapter: |usr_30.txt| Editing programs - Previous chapter: |usr_28.txt| Folding -Table of contents: |usr_toc.txt| - -============================================================================== -*29.1* Using tags - -What is a tag? It is a location where an identifier is defined. An example -is a function definition in a C or C++ program. A list of tags is kept in a -tags file. This can be used by Vim to directly jump from any place to the -tag, the place where an identifier is defined. - To generate the tags file for all C files in the current directory, use the -following command: > - - ctags *.c - -"ctags" is a separate program. Most Unix systems already have it installed. -If you do not have it yet, you can find Exuberant ctags here: - - http://ctags.sf.net ~ - -Now when you are in Vim and you want to go to a function definition, you can -jump to it by using the following command: > - - :tag startlist - -This command will find the function "startlist" even if it is in another file. - The CTRL-] command jumps to the tag of the word that is under the cursor. -This makes it easy to explore a tangle of C code. Suppose, for example, that -you are in the function "write_block". You can see that it calls -"write_line". But what does "write_line" do? By placing the cursor on the -call to "write_line" and pressing CTRL-], you jump to the definition of this -function. - The "write_line" function calls "write_char". You need to figure out what -it does. So you position the cursor over the call to "write_char" and press -CTRL-]. Now you are at the definition of "write_char". - - +-------------------------------------+ - |void write_block(char **s; int cnt) | - |{ | - | int i; | - | for (i = 0; i < cnt; ++i) | - | write_line(s[i]); | - |} | | - +-----------|-------------------------+ - | - CTRL-] | - | +----------------------------+ - +--> |void write_line(char *s) | - |{ | - | while (*s != 0) | - | write_char(*s++); | - |} | | - +--------|-------------------+ - | - CTRL-] | - | +------------------------------------+ - +--> |void write_char(char c) | - |{ | - | putchar((int)(unsigned char)c); | - |} | - +------------------------------------+ - -The ":tags" command shows the list of tags that you traversed through: - - :tags - # TO tag FROM line in file/text ~ - 1 1 write_line 8 write_block.c ~ - 2 1 write_char 7 write_line.c ~ - > ~ -> -Now to go back. The CTRL-T command goes to the preceding tag. In the example -above you get back to the "write_line" function, in the call to "write_char". - This command takes a count argument that indicates how many tags to jump -back. You have gone forward, and now back. Let's go forward again. The -following command goes to the tag on top of the list: > - - :tag - -You can prefix it with a count and jump forward that many tags. For example: -":3tag". CTRL-T also can be preceded with a count. - These commands thus allow you to go down a call tree with CTRL-] and back -up again with CTRL-T. Use ":tags" to find out where you are. - - -SPLIT WINDOWS - -The ":tag" command replaces the file in the current window with the one -containing the new function. But suppose you want to see not only the old -function but also the new one? You can split the window using the ":split" -command followed by the ":tag" command. Vim has a shorthand command that does -both: > - :stag tagname - -To split the current window and jump to the tag under the cursor use this -command: > - - CTRL-W ] - -If a count is specified, the new window will be that many lines high. - - -MORE TAGS FILES - -When you have files in many directories, you can create a tags file in each of -them. Vim will then only be able to jump to tags within that directory. - To find more tags files, set the 'tags' option to include all the relevant -tags files. Example: > - - :set tags=./tags,./../tags,./*/tags - -This finds a tags file in the same directory as the current file, one -directory level higher and in all subdirectories. - This is quite a number of tags files, but it may still not be enough. For -example, when editing a file in "~/proj/src", you will not find the tags file -"~/proj/sub/tags". For this situation Vim offers to search a whole directory -tree for tags files. Example: > - - :set tags=~/proj/**/tags - - -ONE TAGS FILE - -When Vim has to search many places for tags files, you can hear the disk -rattling. It may get a bit slow. In that case it's better to spend this -time while generating one big tags file. You might do this overnight. - This requires the Exuberant ctags program, mentioned above. It offers an -argument to search a whole directory tree: > - - cd ~/proj - ctags -R . - -The nice thing about this is that Exuberant ctags recognizes various file -types. Thus this doesn't work just for C and C++ programs, also for Eiffel -and even Vim scripts. See the ctags documentation to tune this. - Now you only need to tell Vim where your big tags file is: > - - :set tags=~/proj/tags - - -MULTIPLE MATCHES - -When a function is defined multiple times (or a method in several classes), -the ":tag" command will jump to the first one. If there is a match in the -current file, that one is used first. - You can now jump to other matches for the same tag with: > - - :tnext - -Repeat this to find further matches. If there are many, you can select which -one to jump to: > - - :tselect tagname - -Vim will present you with a list of choices: - - # pri kind tag file ~ - 1 F f mch_init os_amiga.c ~ - mch_init() ~ - 2 F f mch_init os_mac.c ~ - mch_init() ~ - 3 F f mch_init os_msdos.c ~ - mch_init(void) ~ - 4 F f mch_init os_riscos.c ~ - mch_init() ~ - Enter nr of choice (<CR> to abort): ~ - -You can now enter the number (in the first column) of the match that you would -like to jump to. The information in the other columns give you a good idea of -where the match is defined. - -To move between the matching tags, these commands can be used: - - :tfirst go to first match - :[count]tprevious go to [count] previous match - :[count]tnext go to [count] next match - :tlast go to last match - -If [count] is omitted then one is used. - - -GUESSING TAG NAMES - -Command line completion is a good way to avoid typing a long tag name. Just -type the first bit and press <Tab>: > - - :tag write_<Tab> - -You will get the first match. If it's not the one you want, press <Tab> until -you find the right one. - Sometimes you only know part of the name of a function. Or you have many -tags that start with the same string, but end differently. Then you can tell -Vim to use a pattern to find the tag. - Suppose you want to jump to a tag that contains "block". First type -this: > - - :tag /block - -Now use command line completion: press <Tab>. Vim will find all tags that -contain "block" and use the first match. - The "/" before a tag name tells Vim that what follows is not a literal tag -name, but a pattern. You can use all the items for search patterns here. For -example, suppose you want to select a tag that starts with "write_": > - - :tselect /^write_ - -The "^" specifies that the tag starts with "write_". Otherwise it would also -be found halfway a tag name. Similarly "$" at the end makes sure the pattern -matches until the end of a tag. - - -A TAGS BROWSER - -Since CTRL-] takes you to the definition of the identifier under the cursor, -you can use a list of identifier names as a table of contents. Here is an -example. - First create a list of identifiers (this requires Exuberant ctags): > - - ctags --c-types=f -f functions *.c - -Now start Vim without a file, and edit this file in Vim, in a vertically split -window: > - - vim - :vsplit functions - -The window contains a list of all the functions. There is some more stuff, -but you can ignore that. Do ":setlocal ts=99" to clean it up a bit. - In this window, define a mapping: > - - :nnoremap <buffer> <CR> 0ye<C-W>w:tag <C-R>"<CR> - -Move the cursor to the line that contains the function you want to go to. -Now press <Enter>. Vim will go to the other window and jump to the selected -function. - - -RELATED ITEMS - -You can set 'ignorecase' to make case in tag names be ignored. - -The 'tagbsearch' option tells if the tags file is sorted or not. The default -is to assume a sorted tags file, which makes a tags search a lot faster, but -doesn't work if the tags file isn't sorted. - -The 'taglength' option can be used to tell Vim the number of significant -characters in a tag. - -When you use the SNiFF+ program, you can use the Vim interface to it |sniff|. -SNiFF+ is a commercial program. - -Cscope is a free program. It does not only find places where an identifier is -declared, but also where it is used. See |cscope|. - -============================================================================== -*29.2* The preview window - -When you edit code that contains a function call, you need to use the correct -arguments. To know what values to pass you can look at how the function is -defined. The tags mechanism works very well for this. Preferably the -definition is displayed in another window. For this the preview window can be -used. - To open a preview window to display the function "write_char": > - - :ptag write_char - -Vim will open a window, and jumps to the tag "write_char". Then it takes you -back to the original position. Thus you can continue typing without the need -to use a CTRL-W command. - If the name of a function appears in the text, you can get its definition -in the preview window with: > - - CTRL-W } - -There is a script that automatically displays the text where the word under -the cursor was defined. See |CursorHold-example|. - -To close the preview window use this command: > - - :pclose - -To edit a specific file in the preview window, use ":pedit". This can be -useful to edit a header file, for example: > - - :pedit defs.h - -Finally, ":psearch" can be used to find a word in the current file and any -included files and display the match in the preview window. This is -especially useful when using library functions, for which you do not have a -tags file. Example: > - - :psearch popen - -This will show the "stdio.h" file in the preview window, with the function -prototype for popen(): - - FILE *popen __P((const char *, const char *)); ~ - -You can specify the height of the preview window, when it is opened, with the -'previewheight' option. - -============================================================================== -*29.3* Moving through a program - -Since a program is structured, Vim can recognize items in it. Specific -commands can be used to move around. - C programs often contain constructs like this: - - #ifdef USE_POPEN ~ - fd = popen("ls", "r") ~ - #else ~ - fd = fopen("tmp", "w") ~ - #endif ~ - -But then much longer, and possibly nested. Position the cursor on the -"#ifdef" and press %. Vim will jump to the "#else". Pressing % again takes -you to the "#endif". Another % takes you to the "#ifdef" again. - When the construct is nested, Vim will find the matching items. This is a -good way to check if you didn't forget an "#endif". - When you are somewhere inside a "#if" - "#endif", you can jump to the start -of it with: > - - [# - -If you are not after a "#if" or "#ifdef" Vim will beep. To jump forward to -the next "#else" or "#endif" use: > - - ]# - -These two commands skip any "#if" - "#endif" blocks that they encounter. -Example: - - #if defined(HAS_INC_H) ~ - a = a + inc(); ~ - # ifdef USE_THEME ~ - a += 3; ~ - # endif ~ - set_width(a); ~ - -With the cursor in the last line, "[#" moves to the first line. The "#ifdef" -- "#endif" block in the middle is skipped. - - -MOVING IN CODE BLOCKS - -In C code blocks are enclosed in {}. These can get pretty long. To move to -the start of the outer block use the "[[" command. Use "][" to find the end. -This assumes that the "{" and "}" are in the first column. - The "[{" command moves to the start of the current block. It skips over -pairs of {} at the same level. "]}" jumps to the end. - An overview: - - function(int a) - +-> { - | if (a) - | +-> { - [[ | | for (;;) --+ - | | +-> { | - | [{ | | foo(32); | --+ - | | [{ | if (bar(a)) --+ | ]} | - +-- | +-- break; | ]} | | - | } <-+ | | ][ - +-- foobar(a) | | - } <-+ | - } <-+ - -When writing C++ or Java, the outer {} block is for the class. The next level -of {} is for a method. When somewhere inside a class use "[m" to find the -previous start of a method. "]m" finds the next start of a method. - -Additionally, "[]" moves backward to the end of a function and "]]" moves -forward to the start of the next function. The end of a function is defined -by a "}" in the first column. - - int func1(void) - { - return 1; - +----------> } - | - [] | int func2(void) - | +-> { - | [[ | if (flag) - start +-- +-- return flag; - | ][ | return 2; - | +-> } - ]] | - | int func3(void) - +----------> { - return 3; - } - -Don't forget you can also use "%" to move between matching (), {} and []. -That also works when they are many lines apart. - - -MOVING IN BRACES - -The "[(" and "])" commands work similar to "[{" and "]}", except that they -work on () pairs instead of {} pairs. -> - [( -< <-------------------------------- - <------- - if (a == b && (c == d || (e > f)) && x > y) ~ - --------------> - --------------------------------> > - ]) - -MOVING IN COMMENTS - -To move back to the start of a comment use "[/". Move forward to the end of a -comment with "]/". This only works for /* - */ comments. - - +-> +-> /* - | [/ | * A comment about --+ - [/ | +-- * wonderful life. | ]/ - | */ <-+ - | - +-- foo = bar * 3; --+ - | ]/ - /* a short comment */ <-+ - -============================================================================== -*29.4* Finding global identifiers - -You are editing a C program and wonder if a variable is declared as "int" or -"unsigned". A quick way to find this is with the "[I" command. - Suppose the cursor is on the word "column". Type: > - - [I - -Vim will list the matching lines it can find. Not only in the current file, -but also in all included files (and files included in them, etc.). The result -looks like this: - - structs.h ~ - 1: 29 unsigned column; /* column number */ ~ - -The advantage over using tags or the preview window is that included files are -searched. In most cases this results in the right declaration to be found. -Also when the tags file is out of date. Also when you don't have tags for the -included files. - However, a few things must be right for "[I" to do its work. First of all, -the 'include' option must specify how a file is included. The default value -works for C and C++. For other languages you will have to change it. - - -LOCATING INCLUDED FILES - - Vim will find included files in the places specified with the 'path' -option. If a directory is missing, some include files will not be found. You -can discover this with this command: > - - :checkpath - -It will list the include files that could not be found. Also files included -by the files that could be found. An example of the output: - - --- Included files not found in path --- ~ - <io.h> ~ - vim.h --> ~ - <functions.h> ~ - <clib/exec_protos.h> ~ - -The "io.h" file is included by the current file and can't be found. "vim.h" -can be found, thus ":checkpath" goes into this file and checks what it -includes. The "functions.h" and "clib/exec_protos.h" files, included by -"vim.h" are not found. - - Note: - Vim is not a compiler. It does not recognize "#ifdef" statements. - This means every "#include" statement is used, also when it comes - after "#if NEVER". - -To fix the files that could not be found, add a directory to the 'path' -option. A good place to find out about this is the Makefile. Look out for -lines that contain "-I" items, like "-I/usr/local/X11". To add this directory -use: > - - :set path+=/usr/local/X11 - -When there are many subdirectories, you can use the "*" wildcard. Example: > - - :set path+=/usr/*/include - -This would find files in "/usr/local/include" as well as "/usr/X11/include". - -When working on a project with a whole nested tree of included files, the "**" -items is useful. This will search down in all subdirectories. Example: > - - :set path+=/projects/invent/**/include - -This will find files in the directories: - - /projects/invent/include ~ - /projects/invent/main/include ~ - /projects/invent/main/os/include ~ - etc. - -There are even more possibilities. Check out the 'path' option for info. - If you want to see which included files are actually found, use this -command: > - - :checkpath! - -You will get a (very long) list of included files, the files they include, and -so on. To shorten the list a bit, Vim shows "(Already listed)" for files that -were found before and doesn't list the included files in there again. - - -JUMPING TO A MATCH - -"[I" produces a list with only one line of text. When you want to have a -closer look at the first item, you can jump to that line with the command: > - - [<Tab> - -You can also use "[ CTRL-I", since CTRL-I is the same as pressing <Tab>. - -The list that "[I" produces has a number at the start of each line. When you -want to jump to another item than the first one, type the number first: > - - 3[<Tab> - -Will jump to the third item in the list. Remember that you can use CTRL-O to -jump back to where you started from. - - -RELATED COMMANDS - - [i only lists the first match - ]I only lists items below the cursor - ]i only lists the first item below the cursor - - -FINDING DEFINED IDENTIFIERS - -The "[I" command finds any identifier. To find only macros, defined with -"#define" use: > - - [D - -Again, this searches in included files. The 'define' option specifies what a -line looks like that defines the items for "[D". You could change it to make -it work with other languages than C or C++. - The commands related to "[D" are: - - [d only lists the first match - ]D only lists items below the cursor - ]d only lists the first item below the cursor - -============================================================================== -*29.5* Finding local identifiers - -The "[I" command searches included files. To search in the current file only, -and jump to the first place where the word under the cursor is used: > - - gD - -Hint: Goto Definition. This command is very useful to find a variable or -function that was declared locally ("static", in C terms). Example (cursor on -"counter"): - - +-> static int counter = 0; - | - | int get_counter(void) - gD | { - | ++counter; - +-- return counter; - } - -To restrict the search even further, and look only in the current function, -use this command: > - - gd - -This will go back to the start of the current function and find the first -occurrence of the word under the cursor. Actually, it searches backwards to -an empty line above a "{" in the first column. From there it searches forward -for the identifier. Example (cursor on "idx"): - - int find_entry(char *name) - { - +-> int idx; - | - gd | for (idx = 0; idx < table_len; ++idx) - | if (strcmp(table[idx].name, name) == 0) - +-- return idx; - } - -============================================================================== - -Next chapter: |usr_30.txt| Editing programs - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_30.txt b/share/vim/vim72/doc/usr_30.txt deleted file mode 100644 index 00189e9bc6..0000000000 --- a/share/vim/vim72/doc/usr_30.txt +++ /dev/null @@ -1,643 +0,0 @@ -*usr_30.txt* For Vim version 7.2. Last change: 2007 Nov 10 - - VIM USER MANUAL - by Bram Moolenaar - - Editing programs - - -Vim has various commands that aid in writing computer programs. Compile a -program and directly jump to reported errors. Automatically set the indent -for many languages and format comments. - -|30.1| Compiling -|30.2| Indenting C files -|30.3| Automatic indenting -|30.4| Other indenting -|30.5| Tabs and spaces -|30.6| Formatting comments - - Next chapter: |usr_31.txt| Exploiting the GUI - Previous chapter: |usr_29.txt| Moving through programs -Table of contents: |usr_toc.txt| - -============================================================================== -*30.1* Compiling - -Vim has a set of so called "quickfix" commands. They enable you to compile a -program from within Vim and then go through the errors generated and fix them -(hopefully). You can then recompile and fix any new errors that are found -until finally your program compiles without any error. - -The following command runs the program "make" (supplying it with any argument -you give) and captures the results: > - - :make {arguments} - -If errors were generated, they are captured and the editor positions you where -the first error occurred. - Take a look at an example ":make" session. (Typical :make sessions generate -far more errors and fewer stupid ones.) After typing ":make" the screen looks -like this: - - :!make | &tee /tmp/vim215953.err ~ - gcc -g -Wall -o prog main.c sub.c ~ - main.c: In function 'main': ~ - main.c:6: too many arguments to function 'do_sub' ~ - main.c: At top level: ~ - main.c:10: parse error before '}' ~ - make: *** [prog] Error 1 ~ - - 2 returned ~ - "main.c" 11L, 111C ~ - (3 of 6): too many arguments to function 'do_sub' ~ - Press ENTER or type command to continue ~ - -From this you can see that you have errors in the file "main.c". When you -press <Enter>, Vim displays the file "main.c", with the cursor positioned on -line 6, the first line with an error. You did not need to specify the file or -the line number, Vim knew where to go by looking in the error messages. - - +---------------------------------------------------+ - |int main() | - |{ | - | int i=3; | - cursor -> | do_sub("foo"); | - | ++i; | - | return (0); | - |} | - |} | - | ~ | - |(3 of 12): too many arguments to function 'do_sub' | - +---------------------------------------------------+ - -The following command goes to where the next error occurs: > - - :cnext - -Vim jumps to line 10, the last line in the file, where there is an extra '}'. - When there is not enough room, Vim will shorten the error message. To see -the whole message use: > - - :cc - -You can get an overview of all the error messages with the ":clist" command. -The output looks like this: > - - :clist -< 3 main.c: 6:too many arguments to function 'do_sub' ~ - 5 main.c: 10:parse error before '}' ~ - -Only the lines where Vim recognized a file name and line number are listed -here. It assumes those are the interesting lines and the rest is just boring -messages. However, sometimes unrecognized lines do contain something you want -to see. Output from the linker, for example, about an undefined function. -To see all the messages add a "!" to the command: > - - :clist! -< 1 gcc -g -Wall -o prog main.c sub.c ~ - 2 main.c: In function 'main': ~ - 3 main.c:6: too many arguments to function 'do_sub' ~ - 4 main.c: At top level: ~ - 5 main.c:10: parse error before '}' ~ - 6 make: *** [prog] Error 1 ~ - -Vim will highlight the current error. To go back to the previous error, use: -> - :cprevious - -Other commands to move around in the error list: - - :cfirst to first error - :clast to last error - :cc 3 to error nr 3 - - -USING ANOTHER COMPILER - -The name of the program to run when the ":make" command is executed is defined -by the 'makeprg' option. Usually this is set to "make", but Visual C++ users -should set this to "nmake" by executing the following command: > - - :set makeprg=nmake - -You can also include arguments in this option. Special characters need to -be escaped with a backslash. Example: > - - :set makeprg=nmake\ -f\ project.mak - -You can include special Vim keywords in the command specification. The % -character expands to the name of the current file. So if you execute the -command: > - :set makeprg=make\ % - -When you are editing main.c, then ":make" executes the following command: > - - make main.c - -This is not too useful, so you will refine the command a little and use the :r -(root) modifier: > - - :set makeprg=make\ %:r.o - -Now the command executed is as follows: > - - make main.o - -More about these modifiers here: |filename-modifiers|. - - -OLD ERROR LISTS - -Suppose you ":make" a program. There is a warning message in one file and an -error message in another. You fix the error and use ":make" again to check if -it was really fixed. Now you want to look at the warning message. It doesn't -show up in the last error list, since the file with the warning wasn't -compiled again. You can go back to the previous error list with: > - - :colder - -Then use ":clist" and ":cc {nr}" to jump to the place with the warning. - To go forward to the next error list: > - - :cnewer - -Vim remembers ten error lists. - - -SWITCHING COMPILERS - -You have to tell Vim what format the error messages are that your compiler -produces. This is done with the 'errorformat' option. The syntax of this -option is quite complicated and it can be made to fit almost any compiler. -You can find the explanation here: |errorformat|. - -You might be using various different compilers. Setting the 'makeprg' option, -and especially the 'errorformat' each time is not easy. Vim offers a simple -method for this. For example, to switch to using the Microsoft Visual C++ -compiler: > - - :compiler msvc - -This will find the Vim script for the "msvc" compiler and set the appropriate -options. - You can write your own compiler files. See |write-compiler-plugin|. - - -OUTPUT REDIRECTION - -The ":make" command redirects the output of the executed program to an error -file. How this works depends on various things, such as the 'shell'. If your -":make" command doesn't capture the output, check the 'makeef' and -'shellpipe' options. The 'shellquote' and 'shellxquote' options might also -matter. - -In case you can't get ":make" to redirect the file for you, an alternative is -to compile the program in another window and redirect the output into a file. -Then have Vim read this file with: > - - :cfile {filename} - -Jumping to errors will work like with the ":make" command. - -============================================================================== -*30.2* Indenting C style text - -A program is much easier to understand when the lines have been properly -indented. Vim offers various ways to make this less work. For C or C style -programs like Java or C++, set the 'cindent' option. Vim knows a lot about C -programs and will try very hard to automatically set the indent for you. Set -the 'shiftwidth' option to the amount of spaces you want for a deeper level. -Four spaces will work fine. One ":set" command will do it: > - - :set cindent shiftwidth=4 - -With this option enabled, when you type something such as "if (x)", the next -line will automatically be indented an additional level. - - if (flag) - Automatic indent ---> do_the_work(); - Automatic unindent <-- if (other_flag) { - Automatic indent ---> do_file(); - keep indent do_some_more(); - Automatic unindent <-- } - -When you type something in curly braces ({}), the text will be indented at the -start and unindented at the end. The unindenting will happen after typing the -'}', since Vim can't guess what you are going to type. - -One side effect of automatic indentation is that it helps you catch errors in -your code early. When you type a } to finish a function, only to find that -the automatic indentation gives it more indent than what you expected, there -is probably a } missing. Use the "%" command to find out which { matches the -} you typed. - A missing ) and ; also cause extra indent. Thus if you get more white -space than you would expect, check the preceding lines. - -When you have code that is badly formatted, or you inserted and deleted lines, -you need to re-indent the lines. The "=" operator does this. The simplest -form is: > - - == - -This indents the current line. Like with all operators, there are three ways -to use it. In Visual mode "=" indents the selected lines. A useful text -object is "a{". This selects the current {} block. Thus, to re-indent the -code block the cursor is in: > - - =a{ - -I you have really badly indented code, you can re-indent the whole file with: -> - gg=G - -However, don't do this in files that have been carefully indented manually. -The automatic indenting does a good job, but in some situations you might want -to overrule it. - - -SETTING INDENT STYLE - -Different people have different styles of indentation. By default Vim does a -pretty good job of indenting in a way that 90% of programmers do. There are -different styles, however; so if you want to, you can customize the -indentation style with the 'cinoptions' option. - By default 'cinoptions' is empty and Vim uses the default style. You can -add various items where you want something different. For example, to make -curly braces be placed like this: - - if (flag) ~ - { ~ - i = 8; ~ - j = 0; ~ - } ~ - -Use this command: > - - :set cinoptions+={2 - -There are many of these items. See |cinoptions-values|. - -============================================================================== -*30.3* Automatic indenting - -You don't want to switch on the 'cindent' option manually every time you edit -a C file. This is how you make it work automatically: > - - :filetype indent on - -Actually, this does a lot more than switching on 'cindent' for C files. First -of all, it enables detecting the type of a file. That's the same as what is -used for syntax highlighting. - When the filetype is known, Vim will search for an indent file for this -type of file. The Vim distribution includes a number of these for various -programming languages. This indent file will then prepare for automatic -indenting specifically for this file. - -If you don't like the automatic indenting, you can switch it off again: > - - :filetype indent off - -If you don't like the indenting for one specific type of file, this is how you -avoid it. Create a file with just this one line: > - - :let b:did_indent = 1 - -Now you need to write this in a file with a specific name: - - {directory}/indent/{filetype}.vim - -The {filetype} is the name of the file type, such as "cpp" or "java". You can -see the exact name that Vim detected with this command: > - - :set filetype - -In this file the output is: - - filetype=help ~ - -Thus you would use "help" for {filetype}. - For the {directory} part you need to use your runtime directory. Look at -the output of this command: > - - set runtimepath - -Now use the first item, the name before the first comma. Thus if the output -looks like this: - - runtimepath=~/.vim,/usr/local/share/vim/vim60/runtime,~/.vim/after ~ - -You use "~/.vim" for {directory}. Then the resulting file name is: - - ~/.vim/indent/help.vim ~ - -Instead of switching the indenting off, you could write your own indent file. -How to do that is explained here: |indent-expression|. - -============================================================================== -*30.4* Other indenting - -The most simple form of automatic indenting is with the 'autoindent' option. -It uses the indent from the previous line. A bit smarter is the 'smartindent' -option. This is useful for languages where no indent file is available. -'smartindent' is not as smart as 'cindent', but smarter than 'autoindent'. - With 'smartindent' set, an extra level of indentation is added for each { -and removed for each }. An extra level of indentation will also be added for -any of the words in the 'cinwords' option. Lines that begin with # are -treated specially: all indentation is removed. This is done so that -preprocessor directives will all start in column 1. The indentation is -restored for the next line. - - -CORRECTING INDENTS - -When you are using 'autoindent' or 'smartindent' to get the indent of the -previous line, there will be many times when you need to add or remove one -'shiftwidth' worth of indent. A quick way to do this is using the CTRL-D and -CTRL-T commands in Insert mode. - For example, you are typing a shell script that is supposed to look like -this: - - if test -n a; then ~ - echo a ~ - echo "-------" ~ - fi ~ - -Start off by setting these option: > - - :set autoindent shiftwidth=3 - -You start by typing the first line, <Enter> and the start of the second line: - - if test -n a; then ~ - echo ~ - -Now you see that you need an extra indent. Type CTRL-T. The result: - - if test -n a; then ~ - echo ~ - -The CTRL-T command, in Insert mode, adds one 'shiftwidth' to the indent, no -matter where in the line you are. - You continue typing the second line, <Enter> and the third line. This time -the indent is OK. Then <Enter> and the last line. Now you have this: - - if test -n a; then ~ - echo a ~ - echo "-------" ~ - fi ~ - -To remove the superfluous indent in the last line press CTRL-D. This deletes -one 'shiftwidth' worth of indent, no matter where you are in the line. - When you are in Normal mode, you can use the ">>" and "<<" commands to -shift lines. ">" and "<" are operators, thus you have the usual three ways to -specify the lines you want to indent. A useful combination is: > - - >i{ - -This adds one indent to the current block of lines, inside {}. The { and } -lines themselves are left unmodified. ">a{" includes them. In this example -the cursor is on "printf": - - original text after ">i{" after ">a{" - - if (flag) if (flag) if (flag) ~ - { { { ~ - printf("yes"); printf("yes"); printf("yes"); ~ - flag = 0; flag = 0; flag = 0; ~ - } } } ~ - -============================================================================== -*30.5* Tabs and spaces - -'tabstop' is set to eight by default. Although you can change it, you quickly -run into trouble later. Other programs won't know what tabstop value you -used. They probably use the default value of eight, and your text suddenly -looks very different. Also, most printers use a fixed tabstop value of eight. -Thus it's best to keep 'tabstop' alone. (If you edit a file which was written -with a different tabstop setting, see |25.3| for how to fix that.) - For indenting lines in a program, using a multiple of eight spaces makes -you quickly run into the right border of the window. Using a single space -doesn't provide enough visual difference. Many people prefer to use four -spaces, a good compromise. - Since a <Tab> is eight spaces and you want to use an indent of four spaces, -you can't use a <Tab> character to make your indent. There are two ways to -handle this: - -1. Use a mix of <Tab> and space characters. Since a <Tab> takes the place of - eight spaces, you have fewer characters in your file. Inserting a <Tab> - is quicker than eight spaces. Backspacing works faster as well. - -2. Use spaces only. This avoids the trouble with programs that use a - different tabstop value. - -Fortunately, Vim supports both methods quite well. - - -SPACES AND TABS - -If you are using a combination of tabs and spaces, you just edit normally. -The Vim defaults do a fine job of handling things. - You can make life a little easier by setting the 'softtabstop' option. -This option tells Vim to make the <Tab> key look and feel as if tabs were set -at the value of 'softtabstop', but actually use a combination of tabs and -spaces. - After you execute the following command, every time you press the <Tab> key -the cursor moves to the next 4-column boundary: > - - :set softtabstop=4 - -When you start in the first column and press <Tab>, you get 4 spaces inserted -in your text. The second time, Vim takes out the 4 spaces and puts in a <Tab> -(thus taking you to column 8). Thus Vim uses as many <Tab>s as possible, and -then fills up with spaces. - When backspacing it works the other way around. A <BS> will always delete -the amount specified with 'softtabstop'. Then <Tab>s are used as many as -possible and spaces to fill the gap. - The following shows what happens pressing <Tab> a few times, and then using -<BS>. A "." stands for a space and "------->" for a <Tab>. - - type result ~ - <Tab> .... - <Tab><Tab> -------> - <Tab><Tab><Tab> ------->.... - <Tab><Tab><Tab><BS> -------> - <Tab><Tab><Tab><BS><BS> .... - -An alternative is to use the 'smarttab' option. When it's set, Vim uses -'shiftwidth' for a <Tab> typed in the indent of a line, and a real <Tab> when -typed after the first non-blank character. However, <BS> doesn't work like -with 'softtabstop'. - - -JUST SPACES - -If you want absolutely no tabs in your file, you can set the 'expandtab' -option: > - - :set expandtab - -When this option is set, the <Tab> key inserts a series of spaces. Thus you -get the same amount of white space as if a <Tab> character was inserted, but -there isn't a real <Tab> character in your file. - The backspace key will delete each space by itself. Thus after typing one -<Tab> you have to press the <BS> key up to eight times to undo it. If you are -in the indent, pressing CTRL-D will be a lot quicker. - - -CHANGING TABS IN SPACES (AND BACK) - -Setting 'expandtab' does not affect any existing tabs. In other words, any -tabs in the document remain tabs. If you want to convert tabs to spaces, use -the ":retab" command. Use these commands: > - - :set expandtab - :%retab - -Now Vim will have changed all indents to use spaces instead of tabs. However, -all tabs that come after a non-blank character are kept. If you want these to -be converted as well, add a !: > - - :%retab! - -This is a little bit dangerous, because it can also change tabs inside a -string. To check if these exist, you could use this: > - - /"[^"\t]*\t[^"]*" - -It's recommended not to use hard tabs inside a string. Replace them with -"\t" to avoid trouble. - -The other way around works just as well: > - - :set noexpandtab - :%retab! - -============================================================================== -*30.6* Formatting comments - -One of the great things about Vim is that it understands comments. You can -ask Vim to format a comment and it will do the right thing. - Suppose, for example, that you have the following comment: - - /* ~ - * This is a test ~ - * of the text formatting. ~ - */ ~ - -You then ask Vim to format it by positioning the cursor at the start of the -comment and type: > - - gq]/ - -"gq" is the operator to format text. "]/" is the motion that takes you to the -end of a comment. The result is: - - /* ~ - * This is a test of the text formatting. ~ - */ ~ - -Notice that Vim properly handled the beginning of each line. - An alternative is to select the text that is to be formatted in Visual mode -and type "gq". - -To add a new line to the comment, position the cursor on the middle line and -press "o". The result looks like this: - - /* ~ - * This is a test of the text formatting. ~ - * ~ - */ ~ - -Vim has automatically inserted a star and a space for you. Now you can type -the comment text. When it gets longer than 'textwidth', Vim will break the -line. Again, the star is inserted automatically: - - /* ~ - * This is a test of the text formatting. ~ - * Typing a lot of text here will make Vim ~ - * break ~ - */ ~ - -For this to work some flags must be present in 'formatoptions': - - r insert the star when typing <Enter> in Insert mode - o insert the star when using "o" or "O" in Normal mode - c break comment text according to 'textwidth' - -See |fo-table| for more flags. - - -DEFINING A COMMENT - -The 'comments' option defines what a comment looks like. Vim distinguishes -between a single-line comment and a comment that has a different start, end -and middle part. - Many single-line comments start with a specific character. In C++ // is -used, in Makefiles #, in Vim scripts ". For example, to make Vim understand -C++ comments: > - - :set comments=:// - -The colon separates the flags of an item from the text by which the comment is -recognized. The general form of an item in 'comments' is: - - {flags}:{text} - -The {flags} part can be empty, as in this case. - Several of these items can be concatenated, separated by commas. This -allows recognizing different types of comments at the same time. For example, -let's edit an e-mail message. When replying, the text that others wrote is -preceded with ">" and "!" characters. This command would work: > - - :set comments=n:>,n:! - -There are two items, one for comments starting with ">" and one for comments -that start with "!". Both use the flag "n". This means that these comments -nest. Thus a line starting with ">" may have another comment after the ">". -This allows formatting a message like this: - - > ! Did you see that site? ~ - > ! It looks really great. ~ - > I don't like it. The ~ - > colors are terrible. ~ - What is the URL of that ~ - site? ~ - -Try setting 'textwidth' to a different value, e.g., 80, and format the text by -Visually selecting it and typing "gq". The result is: - - > ! Did you see that site? It looks really great. ~ - > I don't like it. The colors are terrible. ~ - What is the URL of that site? ~ - -You will notice that Vim did not move text from one type of comment to -another. The "I" in the second line would have fit at the end of the first -line, but since that line starts with "> !" and the second line with ">", Vim -knows that this is a different kind of comment. - - -A THREE PART COMMENT - -A C comment starts with "/*", has "*" in the middle and "*/" at the end. The -entry in 'comments' for this looks like this: > - - :set comments=s1:/*,mb:*,ex:*/ - -The start is defined with "s1:/*". The "s" indicates the start of a -three-piece comment. The colon separates the flags from the text by which the -comment is recognized: "/*". There is one flag: "1". This tells Vim that the -middle part has an offset of one space. - The middle part "mb:*" starts with "m", which indicates it is a middle -part. The "b" flag means that a blank must follow the text. Otherwise Vim -would consider text like "*pointer" also to be the middle of a comment. - The end part "ex:*/" has the "e" for identification. The "x" flag has a -special meaning. It means that after Vim automatically inserted a star, -typing / will remove the extra space. - -For more details see |format-comments|. - -============================================================================== - -Next chapter: |usr_31.txt| Exploiting the GUI - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_31.txt b/share/vim/vim72/doc/usr_31.txt deleted file mode 100644 index ff3dfbcc23..0000000000 --- a/share/vim/vim72/doc/usr_31.txt +++ /dev/null @@ -1,272 +0,0 @@ -*usr_31.txt* For Vim version 7.2. Last change: 2007 May 08 - - VIM USER MANUAL - by Bram Moolenaar - - Exploiting the GUI - - -Vim works well in a terminal, but the GUI has a few extra items. A file -browser can be used for commands that use a file. A dialog to make a choice -between alternatives. Use keyboard shortcuts to access menu items quickly. - -|31.1| The file browser -|31.2| Confirmation -|31.3| Menu shortcuts -|31.4| Vim window position and size -|31.5| Various - - Next chapter: |usr_32.txt| The undo tree - Previous chapter: |usr_30.txt| Editing programs -Table of contents: |usr_toc.txt| - -============================================================================== -*31.1* The file browser - -When using the File/Open... menu you get a file browser. This makes it easier -to find the file you want to edit. But what if you want to split a window to -edit another file? There is no menu entry for this. You could first use -Window/Split and then File/Open..., but that's more work. - Since you are typing most commands in Vim, opening the file browser with a -typed command is possible as well. To make the split command use the file -browser, prepend "browse": > - - :browse split - -Select a file and then the ":split" command will be executed with it. If you -cancel the file dialog nothing happens, the window isn't split. - You can also specify a file name argument. This is used to tell the file -browser where to start. Example: > - - :browse split /etc - -The file browser will pop up, starting in the directory "/etc". - -The ":browse" command can be prepended to just about any command that opens a -file. - If no directory is specified, Vim will decide where to start the file -browser. By default it uses the same directory as the last time. Thus when -you used ":browse split" and selected a file in "/usr/local/share", the next -time you use a ":browse" it will start in "/usr/local/share" again. - This can be changed with the 'browsedir' option. It can have one of three -values: - - last Use the last directory browsed (default) - buffer Use the same directory as the current buffer - current use the current directory - -For example, when you are in the directory "/usr", editing the file -"/usr/local/share/readme", then the command: > - - :set browsedir=buffer - :browse edit - -Will start the browser in "/usr/local/share". Alternatively: > - - :set browsedir=current - :browse edit - -Will start the browser in "/usr". - - Note: - To avoid using the mouse, most file browsers offer using key presses - to navigate. Since this is different for every system, it is not - explained here. Vim uses a standard browser when possible, your - system documentation should contain an explanation on the keyboard - shortcuts somewhere. - -When you are not using the GUI version, you could use the file explorer window -to select files like in a file browser. However, this doesn't work for the -":browse" command. See |netrw-browse|. - -============================================================================== -*31.2* Confirmation - -Vim protects you from accidentally overwriting a file and other ways to lose -changes. If you do something that might be a bad thing to do, Vim produces an -error message and suggests appending ! if you really want to do it. - To avoid retyping the command with the !, you can make Vim give you a -dialog. You can then press "OK" or "Cancel" to tell Vim what you want. - For example, you are editing a file and made changes to it. You start -editing another file with: > - - :confirm edit foo.txt - -Vim will pop up a dialog that looks something like this: - - +-----------------------------------+ - | | - | ? Save changes to "bar.txt"? | - | | - | YES NO CANCEL | - +-----------------------------------+ - -Now make your choice. If you do want to save the changes, select "YES". If -you want to lose the changes for ever: "NO". If you forgot what you were -doing and want to check what really changed use "CANCEL". You will be back in -the same file, with the changes still there. - -Just like ":browse", the ":confirm" command can be prepended to most commands -that edit another file. They can also be combined: > - - :confirm browse edit - -This will produce a dialog when the current buffer was changed. Then it will -pop up a file browser to select the file to edit. - - Note: - In the dialog you can use the keyboard to select the choice. - Typically the <Tab> key and the cursor keys change the choice. - Pressing <Enter> selects the choice. This depends on the system - though. - -When you are not using the GUI, the ":confirm" command works as well. Instead -of popping up a dialog, Vim will print the message at the bottom of the Vim -window and ask you to press a key to make a choice. > - - :confirm edit main.c -< Save changes to "Untitled"? ~ - [Y]es, (N)o, (C)ancel: ~ - -You can now press the single key for the choice. You don't have to press -<Enter>, unlike other typing on the command line. - -============================================================================== -*31.3* Menu shortcuts - -The keyboard is used for all Vim commands. The menus provide a simple way to -select commands, without knowing what they are called. But you have to move -your hand from the keyboard and grab the mouse. - Menus can often be selected with keys as well. This depends on your -system, but most often it works this way. Use the <Alt> key in combination -with the underlined letter of a menu. For example, <A-w> (<Alt> and w) pops -up the Window menu. - In the Window menu, the "split" item has the p underlined. To select it, -let go of the <Alt> key and press p. - -After the first selection of a menu with the <Alt> key, you can use the cursor -keys to move through the menus. <Right> selects a submenu and <left> closes -it. <Esc> also closes a menu. <Enter> selects a menu item. - -There is a conflict between using the <Alt> key to select menu items, and -using <Alt> key combinations for mappings. The 'winaltkeys' option tells Vim -what it should do with the <Alt> key. - The default value "menu" is the smart choice: If the key combination is a -menu shortcut it can't be mapped. All other keys are available for mapping. - The value "no" doesn't use any <Alt> keys for the menus. Thus you must use -the mouse for the menus, and all <Alt> keys can be mapped. - The value "yes" means that Vim will use any <Alt> keys for the menus. Some -<Alt> key combinations may also do other things than selecting a menu. - -============================================================================== -*31.4* Vim window position and size - -To see the current Vim window position on the screen use: > - - :winpos - -This will only work in the GUI. The output may look like this: - - Window position: X 272, Y 103 ~ - -The position is given in screen pixels. Now you can use the numbers to move -Vim somewhere else. For example, to move it to the left a hundred pixels: > - - :winpos 172 103 -< - Note: - There may be a small offset between the reported position and where - the window moves. This is because of the border around the window. - This is added by the window manager. - -You can use this command in your startup script to position the window at a -specific position. - -The size of the Vim window is computed in characters. Thus this depends on -the size of the font being used. You can see the current size with this -command: > - - :set lines columns - -To change the size set the 'lines' and/or 'columns' options to a new value: > - - :set lines=50 - :set columns=80 - -Obtaining the size works in a terminal just like in the GUI. Setting the size -is not possible in most terminals. - -You can start the X-Windows version of gvim with an argument to specify the -size and position of the window: > - - gvim -geometry {width}x{height}+{x_offset}+{y_offset} - -{width} and {height} are in characters, {x_offset} and {y_offset} are in -pixels. Example: > - - gvim -geometry 80x25+100+300 - -============================================================================== -*31.5* Various - -You can use gvim to edit an e-mail message. In your e-mail program you must -select gvim to be the editor for messages. When you try that, you will -see that it doesn't work: The mail program thinks that editing is finished, -while gvim is still running! - What happens is that gvim disconnects from the shell it was started in. -That is fine when you start gvim in a terminal, so that you can do other work -in that terminal. But when you really want to wait for gvim to finish, you -must prevent it from disconnecting. The "-f" argument does this: > - - gvim -f file.txt - -The "-f" stands for foreground. Now Vim will block the shell it was started -in until you finish editing and exit. - - -DELAYED START OF THE GUI - -On Unix it's possible to first start Vim in a terminal. That's useful if you -do various tasks in the same shell. If you are editing a file and decide you -want to use the GUI after all, you can start it with: > - - :gui - -Vim will open the GUI window and no longer use the terminal. You can continue -using the terminal for something else. The "-f" argument is used here to run -the GUI in the foreground. You can also use ":gui -f". - - -THE GVIM STARTUP FILE - -When gvim starts, it reads the gvimrc file. That's similar to the vimrc file -used when starting Vim. The gvimrc file can be used for settings and commands -that are only to be used when the GUI is going to be started. For example, -you can set the 'lines' option to set a different window size: > - - :set lines=55 - -You don't want to do this in a terminal, since it's size is fixed (except for -an xterm that supports resizing). - The gvimrc file is searched for in the same locations as the vimrc file. -Normally its name is "~/.gvimrc" for Unix and "$VIM/_gvimrc" for MS-Windows. -The $MYGVIMRC environment variable is set to it, thus you can use this command -to edit the file, if you have one: > - - :edit $MYGVIMRC -< - If for some reason you don't want to use the normal gvimrc file, you can -specify another one with the "-U" argument: > - - gvim -U thisrc ... - -That allows starting gvim for different kinds of editing. You could set -another font size, for example. - To completely skip reading a gvimrc file: > - - gvim -U NONE ... - -============================================================================== - -Next chapter: |usr_32.txt| The undo tree - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_32.txt b/share/vim/vim72/doc/usr_32.txt deleted file mode 100644 index d0319a0e92..0000000000 --- a/share/vim/vim72/doc/usr_32.txt +++ /dev/null @@ -1,151 +0,0 @@ -*usr_32.txt* For Vim version 7.2. Last change: 2006 Apr 30 - - VIM USER MANUAL - by Bram Moolenaar - - The undo tree - - -Vim provides multi-level undo. If you undo a few changes and then make a new -change you create a branch in the undo tree. This text is about moving -through the branches. - -|32.1| Numbering changes -|32.2| Jumping around the tree -|32.3| Time travelling - - Next chapter: |usr_40.txt| Make new commands - Previous chapter: |usr_31.txt| Exploiting the GUI -Table of contents: |usr_toc.txt| - -============================================================================== -*32.1* Numbering changes - -In section |02.5| we only discussed one line of undo/redo. But it is also -possible to branch off. This happens when you undo a few changes and then -make a new change. The new changes become a branch in the undo tree. - -Let's start with the text "one". The first change to make is to append -" too". And then move to the first 'o' and change it into 'w'. We then have -two changes, numbered 1 and 2, and three states of the text: - - one ~ - | - change 1 - | - one too ~ - | - change 2 - | - one two ~ - -If we now undo one change, back to "one too", and change "one" to "me" we -create a branch in the undo tree: - - one ~ - | - change 1 - | - one too ~ - / \ - change 2 change 3 - | | - one two me too ~ - -You can now use the |u| command to undo. If you do this twice you get to -"one". Use |CTRL-R| to redo, and you will go to "one too". One more |CTRL-R| -takes you to "me too". Thus undo and redo go up and down in the tree, using -the branch that was last used. - -What matters here is the order in which the changes are made. Undo and redo -are not considered changes in this context. After each change you have a new -state of the text. - -Note that only the changes are numbered, the text shown in the tree above has -no identifier. They are mostly referred to by the number of the change above -it. But sometimes by the number of one of the changes below it, especially -when moving up in the tree, so that you know which change was just undone. - -============================================================================== -*32.2* Jumping around the tree - -So how do you get to "one two" now? You can use this command: > - - :undo 2 - -The text is now "one two", you are below change 2. You can use the |:undo| -command to jump to below any change in the tree. - -Now make another change: change "one" to "not": - - one ~ - | - change 1 - | - one too ~ - / \ - change 2 change 3 - | | - one two me too ~ - | - change 4 - | - not two ~ - -Now you change your mind and want to go back to "me too". Use the |g-| -command. This moves back in time. Thus it doesn't walk the tree upwards or -downwards, but goes to the change made before. - -You can repeat |g-| and you will see the text change: - me too ~ - one two ~ - one too ~ - one ~ - -Use |g+| to move forward in time: - one ~ - one too ~ - one two ~ - me too ~ - not two ~ - -Using |:undo| is useful if you know what change you want to jump to. |g-| and -|g+| are useful if you don't know exactly what the change number is. - -You can type a count before |g-| and |g+| to repeat them. - -============================================================================== -*32.3* Time travelling - -When you have been working on text for a while the tree grows to become big. -Then you may want to go to the text of some minutes ago. - -To see what branches there are in the undo tree use this command: > - - :undolist -< number changes time ~ - 3 2 16 seconds ago - 4 3 5 seconds ago - -Here you can see the number of the leaves in each branch and when the change -was made. Assuming we are below change 4, at "not two", you can go back ten -seconds with this command: > - - :earlier 10s - -Depending on how much time you took for the changes you end up at a certain -position in the tree. The |:earlier| command argument can be "m" for minutes -and "h" for hours. To go all the way back use a big number: > - - :earlier 10h - -To travel forward in time again use the |:later| command: > - - :later 1m - -The arguments are "s", "m" and "h", just like with |:earlier|. - -============================================================================== - -Next chapter: |usr_40.txt| Make new commands - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_40.txt b/share/vim/vim72/doc/usr_40.txt deleted file mode 100644 index 737005fae6..0000000000 --- a/share/vim/vim72/doc/usr_40.txt +++ /dev/null @@ -1,657 +0,0 @@ -*usr_40.txt* For Vim version 7.2. Last change: 2006 Jun 21 - - VIM USER MANUAL - by Bram Moolenaar - - Make new commands - - -Vim is an extensible editor. You can take a sequence of commands you use -often and turn it into a new command. Or redefine an existing command. -Autocommands make it possible to execute commands automatically. - -|40.1| Key mapping -|40.2| Defining command-line commands -|40.3| Autocommands - - Next chapter: |usr_41.txt| Write a Vim script - Previous chapter: |usr_32.txt| The undo tree -Table of contents: |usr_toc.txt| - -============================================================================== -*40.1* Key mapping - -A simple mapping was explained in section |05.3|. The principle is that one -sequence of key strokes is translated into another sequence of key strokes. -This is a simple, yet powerful mechanism. - The simplest form is that one key is mapped to a sequence of keys. Since -the function keys, except <F1>, have no predefined meaning in Vim, these are a -good choice to map. Example: > - - :map <F2> GoDate: <Esc>:read !date<CR>kJ - -This shows how three modes are used. After going to the last line with "G", -the "o" command opens a new line and starts Insert mode. The text "Date: " is -inserted and <Esc> takes you out of insert mode. - Notice the use of special keys inside <>. This is called angle bracket -notation. You type these as separate characters, not by pressing the key -itself. This makes the mappings better readable and you can copy and paste -the text without problems. - The ":" character takes Vim to the command line. The ":read !date" command -reads the output from the "date" command and appends it below the current -line. The <CR> is required to execute the ":read" command. - At this point of execution the text looks like this: - - Date: ~ - Fri Jun 15 12:54:34 CEST 2001 ~ - -Now "kJ" moves the cursor up and joins the lines together. - To decide which key or keys you use for mapping, see |map-which-keys|. - - -MAPPING AND MODES - -The ":map" command defines remapping for keys in Normal mode. You can also -define mappings for other modes. For example, ":imap" applies to Insert mode. -You can use it to insert a date below the cursor: > - - :imap <F2> <CR>Date: <Esc>:read !date<CR>kJ - -It looks a lot like the mapping for <F2> in Normal mode, only the start is -different. The <F2> mapping for Normal mode is still there. Thus you can map -the same key differently for each mode. - Notice that, although this mapping starts in Insert mode, it ends in Normal -mode. If you want it to continue in Insert mode, append an "a" to the -mapping. - -Here is an overview of map commands and in which mode they work: - - :map Normal, Visual and Operator-pending - :vmap Visual - :nmap Normal - :omap Operator-pending - :map! Insert and Command-line - :imap Insert - :cmap Command-line - -Operator-pending mode is when you typed an operator character, such as "d" or -"y", and you are expected to type the motion command or a text object. Thus -when you type "dw", the "w" is entered in operator-pending mode. - -Suppose that you want to define <F7> so that the command d<F7> deletes a C -program block (text enclosed in curly braces, {}). Similarly y<F7> would yank -the program block into the unnamed register. Therefore, what you need to do -is to define <F7> to select the current program block. You can do this with -the following command: > - - :omap <F7> a{ - -This causes <F7> to perform a select block "a{" in operator-pending mode, just -like you typed it. This mapping is useful if typing a { on your keyboard is a -bit difficult. - - -LISTING MAPPINGS - -To see the currently defined mappings, use ":map" without arguments. Or one -of the variants that include the mode in which they work. The output could -look like this: - - _g :call MyGrep(1)<CR> ~ - v <F2> :s/^/> /<CR>:noh<CR>`` ~ - n <F2> :.,$s/^/> /<CR>:noh<CR>`` ~ - <xHome> <Home> - <xEnd> <End> - - -The first column of the list shows in which mode the mapping is effective. -This is "n" for Normal mode, "i" for Insert mode, etc. A blank is used for a -mapping defined with ":map", thus effective in both Normal and Visual mode. - One useful purpose of listing the mapping is to check if special keys in <> -form have been recognized (this only works when color is supported). For -example, when <Esc> is displayed in color, it stands for the escape character. -When it has the same color as the other text, it is five characters. - - -REMAPPING - -The result of a mapping is inspected for other mappings in it. For example, -the mappings for <F2> above could be shortened to: > - - :map <F2> G<F3> - :imap <F2> <Esc><F3> - :map <F3> oDate: <Esc>:read !date<CR>kJ - -For Normal mode <F2> is mapped to go to the last line, and then behave like -<F3> was pressed. In Insert mode <F2> stops Insert mode with <Esc> and then -also uses <F3>. Then <F3> is mapped to do the actual work. - -Suppose you hardly ever use Ex mode, and want to use the "Q" command to format -text (this was so in old versions of Vim). This mapping will do it: > - - :map Q gq - -But, in rare cases you need to use Ex mode anyway. Let's map "gQ" to Q, so -that you can still go to Ex mode: > - - :map gQ Q - -What happens now is that when you type "gQ" it is mapped to "Q". So far so -good. But then "Q" is mapped to "gq", thus typing "gQ" results in "gq", and -you don't get to Ex mode at all. - To avoid keys to be mapped again, use the ":noremap" command: > - - :noremap gQ Q - -Now Vim knows that the "Q" is not to be inspected for mappings that apply to -it. There is a similar command for every mode: - - :noremap Normal, Visual and Operator-pending - :vnoremap Visual - :nnoremap Normal - :onoremap Operator-pending - :noremap! Insert and Command-line - :inoremap Insert - :cnoremap Command-line - - -RECURSIVE MAPPING - -When a mapping triggers itself, it will run forever. This can be used to -repeat an action an unlimited number of times. - For example, you have a list of files that contain a version number in the -first line. You edit these files with "vim *.txt". You are now editing the -first file. Define this mapping: > - - :map ,, :s/5.1/5.2/<CR>:wnext<CR>,, - -Now you type ",,". This triggers the mapping. It replaces "5.1" with "5.2" -in the first line. Then it does a ":wnext" to write the file and edit the -next one. The mapping ends in ",,". This triggers the same mapping again, -thus doing the substitution, etc. - This continues until there is an error. In this case it could be a file -where the substitute command doesn't find a match for "5.1". You can then -make a change to insert "5.1" and continue by typing ",," again. Or the -":wnext" fails, because you are in the last file in the list. - When a mapping runs into an error halfway, the rest of the mapping is -discarded. CTRL-C interrupts the mapping (CTRL-Break on MS-Windows). - - -DELETE A MAPPING - -To remove a mapping use the ":unmap" command. Again, the mode the unmapping -applies to depends on the command used: - - :unmap Normal, Visual and Operator-pending - :vunmap Visual - :nunmap Normal - :ounmap Operator-pending - :unmap! Insert and Command-line - :iunmap Insert - :cunmap Command-line - -There is a trick to define a mapping that works in Normal and Operator-pending -mode, but not in Visual mode. First define it for all three modes, then -delete it for Visual mode: > - - :map <C-A> /---><CR> - :vunmap <C-A> - -Notice that the five characters "<C-A>" stand for the single key CTRL-A. - -To remove all mappings use the |:mapclear| command. You can guess the -variations for different modes by now. Be careful with this command, it can't -be undone. - - -SPECIAL CHARACTERS - -The ":map" command can be followed by another command. A | character -separates the two commands. This also means that a | character can't be used -inside a map command. To include one, use <Bar> (five characters). Example: -> - :map <F8> :write <Bar> !checkin %<CR> - -The same problem applies to the ":unmap" command, with the addition that you -have to watch out for trailing white space. These two commands are different: -> - :unmap a | unmap b - :unmap a| unmap b - -The first command tries to unmap "a ", with a trailing space. - -When using a space inside a mapping, use <Space> (seven characters): > - - :map <Space> W - -This makes the spacebar move a blank-separated word forward. - -It is not possible to put a comment directly after a mapping, because the " -character is considered to be part of the mapping. You can use |", this -starts a new, empty command with a comment. Example: > - - :map <Space> W| " Use spacebar to move forward a word - - -MAPPINGS AND ABBREVIATIONS - -Abbreviations are a lot like Insert mode mappings. The arguments are handled -in the same way. The main difference is the way they are triggered. An -abbreviation is triggered by typing a non-word character after the word. A -mapping is triggered when typing the last character. - Another difference is that the characters you type for an abbreviation are -inserted in the text while you type them. When the abbreviation is triggered -these characters are deleted and replaced by what the abbreviation produces. -When typing the characters for a mapping, nothing is inserted until you type -the last character that triggers it. If the 'showcmd' option is set, the -typed characters are displayed in the last line of the Vim window. - An exception is when a mapping is ambiguous. Suppose you have done two -mappings: > - - :imap aa foo - :imap aaa bar - -Now, when you type "aa", Vim doesn't know if it should apply the first or the -second mapping. It waits for another character to be typed. If it is an "a", -the second mapping is applied and results in "bar". If it is a space, for -example, the first mapping is applied, resulting in "foo", and then the space -is inserted. - - -ADDITIONALLY... - -The <script> keyword can be used to make a mapping local to a script. See -|:map-<script>|. - -The <buffer> keyword can be used to make a mapping local to a specific buffer. -See |:map-<buffer>| - -The <unique> keyword can be used to make defining a new mapping fail when it -already exists. Otherwise a new mapping simply overwrites the old one. See -|:map-<unique>|. - -To make a key do nothing, map it to <Nop> (five characters). This will make -the <F7> key do nothing at all: > - - :map <F7> <Nop>| map! <F7> <Nop> - -There must be no space after <Nop>. - -============================================================================== -*40.2* Defining command-line commands - -The Vim editor enables you to define your own commands. You execute these -commands just like any other Command-line mode command. - To define a command, use the ":command" command, as follows: > - - :command DeleteFirst 1delete - -Now when you execute the command ":DeleteFirst" Vim executes ":1delete", which -deletes the first line. - - Note: - User-defined commands must start with a capital letter. You cannot - use ":X", ":Next" and ":Print". The underscore cannot be used! You - can use digits, but this is discouraged. - -To list the user-defined commands, execute the following command: > - - :command - -Just like with the builtin commands, the user defined commands can be -abbreviated. You need to type just enough to distinguish the command from -another. Command line completion can be used to get the full name. - - -NUMBER OF ARGUMENTS - -User-defined commands can take a series of arguments. The number of arguments -must be specified by the -nargs option. For instance, the example -:DeleteFirst command takes no arguments, so you could have defined it as -follows: > - - :command -nargs=0 DeleteFirst 1delete - -However, because zero arguments is the default, you do not need to add -"-nargs=0". The other values of -nargs are as follows: - - -nargs=0 No arguments - -nargs=1 One argument - -nargs=* Any number of arguments - -nargs=? Zero or one argument - -nargs=+ One or more arguments - - -USING THE ARGUMENTS - -Inside the command definition, the arguments are represented by the -<args> keyword. For example: > - - :command -nargs=+ Say :echo "<args>" - -Now when you type > - - :Say Hello World - -Vim echoes "Hello World". However, if you add a double quote, it won't work. -For example: > - - :Say he said "hello" - -To get special characters turned into a string, properly escaped to use as an -expression, use "<q-args>": > - - :command -nargs=+ Say :echo <q-args> - -Now the above ":Say" command will result in this to be executed: > - - :echo "he said \"hello\"" - -The <f-args> keyword contains the same information as the <args> keyword, -except in a format suitable for use as function call arguments. For example: -> - :command -nargs=* DoIt :call AFunction(<f-args>) - :DoIt a b c - -Executes the following command: > - - :call AFunction("a", "b", "c") - - -LINE RANGE - -Some commands take a range as their argument. To tell Vim that you are -defining such a command, you need to specify a -range option. The values for -this option are as follows: - - -range Range is allowed; default is the current line. - -range=% Range is allowed; default is the whole file. - -range={count} Range is allowed; the last number in it is used as a - single number whose default is {count}. - -When a range is specified, the keywords <line1> and <line2> get the values of -the first and last line in the range. For example, the following command -defines the SaveIt command, which writes out the specified range to the file -"save_file": > - - :command -range=% SaveIt :<line1>,<line2>write! save_file - - -OTHER OPTIONS - -Some of the other options and keywords are as follows: - - -count={number} The command can take a count whose default is - {number}. The resulting count can be used - through the <count> keyword. - -bang You can use a !. If present, using <bang> will - result in a !. - -register You can specify a register. (The default is - the unnamed register.) - The register specification is available as - <reg> (a.k.a. <register>). - -complete={type} Type of command-line completion used. See - |:command-completion| for the list of possible - values. - -bar The command can be followed by | and another - command, or " and a comment. - -buffer The command is only available for the current - buffer. - -Finally, you have the <lt> keyword. It stands for the character <. Use this -to escape the special meaning of the <> items mentioned. - - -REDEFINING AND DELETING - -To redefine the same command use the ! argument: > - - :command -nargs=+ Say :echo "<args>" - :command! -nargs=+ Say :echo <q-args> - -To delete a user command use ":delcommand". It takes a single argument, which -is the name of the command. Example: > - - :delcommand SaveIt - -To delete all the user commands: > - - :comclear - -Careful, this can't be undone! - -More details about all this in the reference manual: |user-commands|. - -============================================================================== -*40.3* Autocommands - -An autocommand is a command that is executed automatically in response to some -event, such as a file being read or written or a buffer change. Through the -use of autocommands you can train Vim to edit compressed files, for example. -That is used in the |gzip| plugin. - Autocommands are very powerful. Use them with care and they will help you -avoid typing many commands. Use them carelessly and they will cause a lot of -trouble. - -Suppose you want to replace a datestamp on the end of a file every time it is -written. First you define a function: > - - :function DateInsert() - : $delete - : read !date - :endfunction - -You want this function to be called each time, just before a file is written. -This will make that happen: > - - :autocmd FileWritePre * call DateInsert() - -"FileWritePre" is the event for which this autocommand is triggered: Just -before (pre) writing a file. The "*" is a pattern to match with the file -name. In this case it matches all files. - With this command enabled, when you do a ":write", Vim checks for any -matching FileWritePre autocommands and executes them, and then it -performs the ":write". - The general form of the :autocmd command is as follows: > - - :autocmd [group] {events} {file_pattern} [nested] {command} - -The [group] name is optional. It is used in managing and calling the commands -(more on this later). The {events} parameter is a list of events (comma -separated) that trigger the command. - {file_pattern} is a filename, usually with wildcards. For example, using -"*.txt" makes the autocommand be used for all files whose name end in ".txt". -The optional [nested] flag allows for nesting of autocommands (see below), and -finally, {command} is the command to be executed. - - -EVENTS - -One of the most useful events is BufReadPost. It is triggered after a new -file is being edited. It is commonly used to set option values. For example, -you know that "*.gsm" files are GNU assembly language. To get the syntax file -right, define this autocommand: > - - :autocmd BufReadPost *.gsm set filetype=asm - -If Vim is able to detect the type of file, it will set the 'filetype' option -for you. This triggers the Filetype event. Use this to do something when a -certain type of file is edited. For example, to load a list of abbreviations -for text files: > - - :autocmd Filetype text source ~/.vim/abbrevs.vim - -When starting to edit a new file, you could make Vim insert a skeleton: > - - :autocmd BufNewFile *.[ch] 0read ~/skeletons/skel.c - -See |autocmd-events| for a complete list of events. - - -PATTERNS - -The {file_pattern} argument can actually be a comma-separated list of file -patterns. For example: "*.c,*.h" matches files ending in ".c" and ".h". - The usual file wildcards can be used. Here is a summary of the most often -used ones: - - * Match any character any number of times - ? Match any character once - [abc] Match the character a, b or c - . Matches a dot - a{b,c} Matches "ab" and "ac" - -When the pattern includes a slash (/) Vim will compare directory names. -Without the slash only the last part of a file name is used. For example, -"*.txt" matches "/home/biep/readme.txt". The pattern "/home/biep/*" would -also match it. But "home/foo/*.txt" wouldn't. - When including a slash, Vim matches the pattern against both the full path -of the file ("/home/biep/readme.txt") and the relative path (e.g., -"biep/readme.txt"). - - Note: - When working on a system that uses a backslash as file separator, such - as MS-Windows, you still use forward slashes in autocommands. This - makes it easier to write the pattern, since a backslash has a special - meaning. It also makes the autocommands portable. - - -DELETING - -To delete an autocommand, use the same command as what it was defined with, -but leave out the {command} at the end and use a !. Example: > - - :autocmd! FileWritePre * - -This will delete all autocommands for the "FileWritePre" event that use the -"*" pattern. - - -LISTING - -To list all the currently defined autocommands, use this: > - - :autocmd - -The list can be very long, especially when filetype detection is used. To -list only part of the commands, specify the group, event and/or pattern. For -example, to list all BufNewFile autocommands: > - - :autocmd BufNewFile - -To list all autocommands for the pattern "*.c": > - - :autocmd * *.c - -Using "*" for the event will list all the events. To list all autocommands -for the cprograms group: > - - :autocmd cprograms - - -GROUPS - -The {group} item, used when defining an autocommand, groups related autocommands -together. This can be used to delete all the autocommands in a certain group, -for example. - When defining several autocommands for a certain group, use the ":augroup" -command. For example, let's define autocommands for C programs: > - - :augroup cprograms - : autocmd BufReadPost *.c,*.h :set sw=4 sts=4 - : autocmd BufReadPost *.cpp :set sw=3 sts=3 - :augroup END - -This will do the same as: > - - :autocmd cprograms BufReadPost *.c,*.h :set sw=4 sts=4 - :autocmd cprograms BufReadPost *.cpp :set sw=3 sts=3 - -To delete all autocommands in the "cprograms" group: > - - :autocmd! cprograms - - -NESTING - -Generally, commands executed as the result of an autocommand event will not -trigger any new events. If you read a file in response to a FileChangedShell -event, it will not trigger the autocommands that would set the syntax, for -example. To make the events triggered, add the "nested" argument: > - - :autocmd FileChangedShell * nested edit - - -EXECUTING AUTOCOMMANDS - -It is possible to trigger an autocommand by pretending an event has occurred. -This is useful to have one autocommand trigger another one. Example: > - - :autocmd BufReadPost *.new execute "doautocmd BufReadPost " . expand("<afile>:r") - -This defines an autocommand that is triggered when a new file has been edited. -The file name must end in ".new". The ":execute" command uses expression -evaluation to form a new command and execute it. When editing the file -"tryout.c.new" the executed command will be: > - - :doautocmd BufReadPost tryout.c - -The expand() function takes the "<afile>" argument, which stands for the file -name the autocommand was executed for, and takes the root of the file name -with ":r". - -":doautocmd" executes on the current buffer. The ":doautoall" command works -like "doautocmd" except it executes on all the buffers. - - -USING NORMAL MODE COMMANDS - -The commands executed by an autocommand are Command-line commands. If you -want to use a Normal mode command, the ":normal" command can be used. -Example: > - - :autocmd BufReadPost *.log normal G - -This will make the cursor jump to the last line of *.log files when you start -to edit it. - Using the ":normal" command is a bit tricky. First of all, make sure its -argument is a complete command, including all the arguments. When you use "i" -to go to Insert mode, there must also be a <Esc> to leave Insert mode again. -If you use a "/" to start a search pattern, there must be a <CR> to execute -it. - The ":normal" command uses all the text after it as commands. Thus there -can be no | and another command following. To work around this, put the -":normal" command inside an ":execute" command. This also makes it possible -to pass unprintable characters in a convenient way. Example: > - - :autocmd BufReadPost *.chg execute "normal ONew entry:\<Esc>" | - \ 1read !date - -This also shows the use of a backslash to break a long command into more -lines. This can be used in Vim scripts (not at the command line). - -When you want the autocommand do something complicated, which involves jumping -around in the file and then returning to the original position, you may want -to restore the view on the file. See |restore-position| for an example. - - -IGNORING EVENTS - -At times, you will not want to trigger an autocommand. The 'eventignore' -option contains a list of events that will be totally ignored. For example, -the following causes events for entering and leaving a window to be ignored: > - - :set eventignore=WinEnter,WinLeave - -To ignore all events, use the following command: > - - :set eventignore=all - -To set it back to the normal behavior, make 'eventignore' empty: > - - :set eventignore= - -============================================================================== - -Next chapter: |usr_41.txt| Write a Vim script - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_41.txt b/share/vim/vim72/doc/usr_41.txt deleted file mode 100644 index 5305ff18bc..0000000000 --- a/share/vim/vim72/doc/usr_41.txt +++ /dev/null @@ -1,2415 +0,0 @@ -*usr_41.txt* For Vim version 7.2. Last change: 2008 Jun 21 - - VIM USER MANUAL - by Bram Moolenaar - - Write a Vim script - - -The Vim script language is used for the startup vimrc file, syntax files, and -many other things. This chapter explains the items that can be used in a Vim -script. There are a lot of them, thus this is a long chapter. - -|41.1| Introduction -|41.2| Variables -|41.3| Expressions -|41.4| Conditionals -|41.5| Executing an expression -|41.6| Using functions -|41.7| Defining a function -|41.8| Lists and Dictionaries -|41.9| Exceptions -|41.10| Various remarks -|41.11| Writing a plugin -|41.12| Writing a filetype plugin -|41.13| Writing a compiler plugin -|41.14| Writing a plugin that loads quickly -|41.15| Writing library scripts -|41.16| Distributing Vim scripts - - Next chapter: |usr_42.txt| Add new menus - Previous chapter: |usr_40.txt| Make new commands -Table of contents: |usr_toc.txt| - -============================================================================== -*41.1* Introduction *vim-script-intro* *script* - -Your first experience with Vim scripts is the vimrc file. Vim reads it when -it starts up and executes the commands. You can set options to values you -prefer. And you can use any colon command in it (commands that start with a -":"; these are sometimes referred to as Ex commands or command-line commands). - Syntax files are also Vim scripts. As are files that set options for a -specific file type. A complicated macro can be defined by a separate Vim -script file. You can think of other uses yourself. - -Let's start with a simple example: > - - :let i = 1 - :while i < 5 - : echo "count is" i - : let i += 1 - :endwhile -< - Note: - The ":" characters are not really needed here. You only need to use - them when you type a command. In a Vim script file they can be left - out. We will use them here anyway to make clear these are colon - commands and make them stand out from Normal mode commands. - Note: - You can try out the examples by yanking the lines from the text here - and executing them with :@" - -The output of the example code is: - - count is 1 ~ - count is 2 ~ - count is 3 ~ - count is 4 ~ - -In the first line the ":let" command assigns a value to a variable. The -generic form is: > - - :let {variable} = {expression} - -In this case the variable name is "i" and the expression is a simple value, -the number one. - The ":while" command starts a loop. The generic form is: > - - :while {condition} - : {statements} - :endwhile - -The statements until the matching ":endwhile" are executed for as long as the -condition is true. The condition used here is the expression "i < 5". This -is true when the variable i is smaller than five. - Note: - If you happen to write a while loop that keeps on running, you can - interrupt it by pressing CTRL-C (CTRL-Break on MS-Windows). - -The ":echo" command prints its arguments. In this case the string "count is" -and the value of the variable i. Since i is one, this will print: - - count is 1 ~ - -Then there is the ":let i += 1" command. This does the same thing as -":let i = i + 1". This adds one to the variable i and assigns the new value -to the same variable. - -The example was given to explain the commands, but would you really want to -make such a loop it can be written much more compact: > - - :for i in range(1, 4) - : echo "count is" i - :endfor - -We won't explain how |:for| and |range()| work until later. Follow the links -if you are impatient. - - -THREE KINDS OF NUMBERS - -Numbers can be decimal, hexadecimal or octal. A hexadecimal number starts -with "0x" or "0X". For example "0x1f" is decimal 31. An octal number starts -with a zero. "017" is decimal 15. Careful: don't put a zero before a decimal -number, it will be interpreted as an octal number! - The ":echo" command always prints decimal numbers. Example: > - - :echo 0x7f 036 -< 127 30 ~ - -A number is made negative with a minus sign. This also works for hexadecimal -and octal numbers. A minus sign is also used for subtraction. Compare this -with the previous example: > - - :echo 0x7f -036 -< 97 ~ - -White space in an expression is ignored. However, it's recommended to use it -for separating items, to make the expression easier to read. For example, to -avoid the confusion with a negative number above, put a space between the -minus sign and the following number: > - - :echo 0x7f - 036 - -============================================================================== -*41.2* Variables - -A variable name consists of ASCII letters, digits and the underscore. It -cannot start with a digit. Valid variable names are: - - counter - _aap3 - very_long_variable_name_with_underscores - FuncLength - LENGTH - -Invalid names are "foo+bar" and "6var". - These variables are global. To see a list of currently defined variables -use this command: > - - :let - -You can use global variables everywhere. This also means that when the -variable "count" is used in one script file, it might also be used in another -file. This leads to confusion at least, and real problems at worst. To avoid -this, you can use a variable local to a script file by prepending "s:". For -example, one script contains this code: > - - :let s:count = 1 - :while s:count < 5 - : source other.vim - : let s:count += 1 - :endwhile - -Since "s:count" is local to this script, you can be sure that sourcing the -"other.vim" script will not change this variable. If "other.vim" also uses an -"s:count" variable, it will be a different copy, local to that script. More -about script-local variables here: |script-variable|. - -There are more kinds of variables, see |internal-variables|. The most often -used ones are: - - b:name variable local to a buffer - w:name variable local to a window - g:name global variable (also in a function) - v:name variable predefined by Vim - - -DELETING VARIABLES - -Variables take up memory and show up in the output of the ":let" command. To -delete a variable use the ":unlet" command. Example: > - - :unlet s:count - -This deletes the script-local variable "s:count" to free up the memory it -uses. If you are not sure if the variable exists, and don't want an error -message when it doesn't, append !: > - - :unlet! s:count - -When a script finishes, the local variables used there will not be -automatically freed. The next time the script executes, it can still use the -old value. Example: > - - :if !exists("s:call_count") - : let s:call_count = 0 - :endif - :let s:call_count = s:call_count + 1 - :echo "called" s:call_count "times" - -The "exists()" function checks if a variable has already been defined. Its -argument is the name of the variable you want to check. Not the variable -itself! If you would do this: > - - :if !exists(s:call_count) - -Then the value of s:call_count will be used as the name of the variable that -exists() checks. That's not what you want. - The exclamation mark ! negates a value. When the value was true, it -becomes false. When it was false, it becomes true. You can read it as "not". -Thus "if !exists()" can be read as "if not exists()". - What Vim calls true is anything that is not zero. Zero is false. - Note: - Vim automatically converts a string to a number when it is looking for - a number. When using a string that doesn't start with a digit the - resulting number is zero. Thus look out for this: > - :if "true" -< The "true" will be interpreted as a zero, thus as false! - - -STRING VARIABLES AND CONSTANTS - -So far only numbers were used for the variable value. Strings can be used as -well. Numbers and strings are the basic types of variables that Vim supports. -The type is dynamic, it is set each time when assigning a value to the -variable with ":let". More about types in |41.8|. - To assign a string value to a variable, you need to use a string constant. -There are two types of these. First the string in double quotes: > - - :let name = "peter" - :echo name -< peter ~ - -If you want to include a double quote inside the string, put a backslash in -front of it: > - - :let name = "\"peter\"" - :echo name -< "peter" ~ - -To avoid the need for a backslash, you can use a string in single quotes: > - - :let name = '"peter"' - :echo name -< "peter" ~ - -Inside a single-quote string all the characters are as they are. Only the -single quote itself is special: you need to use two to get one. A backslash -is taken literally, thus you can't use it to change the meaning of the -character after it. - In double-quote strings it is possible to use special characters. Here are -a few useful ones: - - \t <Tab> - \n <NL>, line break - \r <CR>, <Enter> - \e <Esc> - \b <BS>, backspace - \" " - \\ \, backslash - \<Esc> <Esc> - \<C-W> CTRL-W - -The last two are just examples. The "\<name>" form can be used to include -the special key "name". - See |expr-quote| for the full list of special items in a string. - -============================================================================== -*41.3* Expressions - -Vim has a rich, yet simple way to handle expressions. You can read the -definition here: |expression-syntax|. Here we will show the most common -items. - The numbers, strings and variables mentioned above are expressions by -themselves. Thus everywhere an expression is expected, you can use a number, -string or variable. Other basic items in an expression are: - - $NAME environment variable - &name option - @r register - -Examples: > - - :echo "The value of 'tabstop' is" &ts - :echo "Your home directory is" $HOME - :if @a > 5 - -The &name form can be used to save an option value, set it to a new value, -do something and restore the old value. Example: > - - :let save_ic = &ic - :set noic - :/The Start/,$delete - :let &ic = save_ic - -This makes sure the "The Start" pattern is used with the 'ignorecase' option -off. Still, it keeps the value that the user had set. (Another way to do -this would be to add "\C" to the pattern, see |/\C|.) - - -MATHEMATICS - -It becomes more interesting if we combine these basic items. Let's start with -mathematics on numbers: - - a + b add - a - b subtract - a * b multiply - a / b divide - a % b modulo - -The usual precedence is used. Example: > - - :echo 10 + 5 * 2 -< 20 ~ - -Grouping is done with braces. No surprises here. Example: > - - :echo (10 + 5) * 2 -< 30 ~ - -Strings can be concatenated with ".". Example: > - - :echo "foo" . "bar" -< foobar ~ - -When the ":echo" command gets multiple arguments, it separates them with a -space. In the example the argument is a single expression, thus no space is -inserted. - -Borrowed from the C language is the conditional expression: - - a ? b : c - -If "a" evaluates to true "b" is used, otherwise "c" is used. Example: > - - :let i = 4 - :echo i > 5 ? "i is big" : "i is small" -< i is small ~ - -The three parts of the constructs are always evaluated first, thus you could -see it work as: - - (a) ? (b) : (c) - -============================================================================== -*41.4* Conditionals - -The ":if" commands executes the following statements, until the matching -":endif", only when a condition is met. The generic form is: - - :if {condition} - {statements} - :endif - -Only when the expression {condition} evaluates to true (non-zero) will the -{statements} be executed. These must still be valid commands. If they -contain garbage, Vim won't be able to find the ":endif". - You can also use ":else". The generic form for this is: - - :if {condition} - {statements} - :else - {statements} - :endif - -The second {statements} is only executed if the first one isn't. - Finally, there is ":elseif": - - :if {condition} - {statements} - :elseif {condition} - {statements} - :endif - -This works just like using ":else" and then "if", but without the need for an -extra ":endif". - A useful example for your vimrc file is checking the 'term' option and -doing something depending upon its value: > - - :if &term == "xterm" - : " Do stuff for xterm - :elseif &term == "vt100" - : " Do stuff for a vt100 terminal - :else - : " Do something for other terminals - :endif - - -LOGIC OPERATIONS - -We already used some of them in the examples. These are the most often used -ones: - - a == b equal to - a != b not equal to - a > b greater than - a >= b greater than or equal to - a < b less than - a <= b less than or equal to - -The result is one if the condition is met and zero otherwise. An example: > - - :if v:version >= 700 - : echo "congratulations" - :else - : echo "you are using an old version, upgrade!" - :endif - -Here "v:version" is a variable defined by Vim, which has the value of the Vim -version. 600 is for version 6.0. Version 6.1 has the value 601. This is -very useful to write a script that works with multiple versions of Vim. -|v:version| - -The logic operators work both for numbers and strings. When comparing two -strings, the mathematical difference is used. This compares byte values, -which may not be right for some languages. - When comparing a string with a number, the string is first converted to a -number. This is a bit tricky, because when a string doesn't look like a -number, the number zero is used. Example: > - - :if 0 == "one" - : echo "yes" - :endif - -This will echo "yes", because "one" doesn't look like a number, thus it is -converted to the number zero. - -For strings there are two more items: - - a =~ b matches with - a !~ b does not match with - -The left item "a" is used as a string. The right item "b" is used as a -pattern, like what's used for searching. Example: > - - :if str =~ " " - : echo "str contains a space" - :endif - :if str !~ '\.$' - : echo "str does not end in a full stop" - :endif - -Notice the use of a single-quote string for the pattern. This is useful, -because backslashes would need to be doubled in a double-quote string and -patterns tend to contain many backslashes. - -The 'ignorecase' option is used when comparing strings. When you don't want -that, append "#" to match case and "?" to ignore case. Thus "==?" compares -two strings to be equal while ignoring case. And "!~#" checks if a pattern -doesn't match, also checking the case of letters. For the full table see -|expr-==|. - - -MORE LOOPING - -The ":while" command was already mentioned. Two more statements can be used -in between the ":while" and the ":endwhile": - - :continue Jump back to the start of the while loop; the - loop continues. - :break Jump forward to the ":endwhile"; the loop is - discontinued. - -Example: > - - :while counter < 40 - : call do_something() - : if skip_flag - : continue - : endif - : if finished_flag - : break - : endif - : sleep 50m - :endwhile - -The ":sleep" command makes Vim take a nap. The "50m" specifies fifty -milliseconds. Another example is ":sleep 4", which sleeps for four seconds. - -Even more looping can be done with the ":for" command, see below in |41.8|. - -============================================================================== -*41.5* Executing an expression - -So far the commands in the script were executed by Vim directly. The -":execute" command allows executing the result of an expression. This is a -very powerful way to build commands and execute them. - An example is to jump to a tag, which is contained in a variable: > - - :execute "tag " . tag_name - -The "." is used to concatenate the string "tag " with the value of variable -"tag_name". Suppose "tag_name" has the value "get_cmd", then the command that -will be executed is: > - - :tag get_cmd - -The ":execute" command can only execute colon commands. The ":normal" command -executes Normal mode commands. However, its argument is not an expression but -the literal command characters. Example: > - - :normal gg=G - -This jumps to the first line and formats all lines with the "=" operator. - To make ":normal" work with an expression, combine ":execute" with it. -Example: > - - :execute "normal " . normal_commands - -The variable "normal_commands" must contain the Normal mode commands. - Make sure that the argument for ":normal" is a complete command. Otherwise -Vim will run into the end of the argument and abort the command. For example, -if you start Insert mode, you must leave Insert mode as well. This works: > - - :execute "normal Inew text \<Esc>" - -This inserts "new text " in the current line. Notice the use of the special -key "\<Esc>". This avoids having to enter a real <Esc> character in your -script. - -If you don't want to execute a string but evaluate it to get its expression -value, you can use the eval() function: > - - :let optname = "path" - :let optval = eval('&' . optname) - -A "&" character is prepended to "path", thus the argument to eval() is -"&path". The result will then be the value of the 'path' option. - The same thing can be done with: > - :exe 'let optval = &' . optname - -============================================================================== -*41.6* Using functions - -Vim defines many functions and provides a large amount of functionality that -way. A few examples will be given in this section. You can find the whole -list here: |functions|. - -A function is called with the ":call" command. The parameters are passed in -between braces, separated by commas. Example: > - - :call search("Date: ", "W") - -This calls the search() function, with arguments "Date: " and "W". The -search() function uses its first argument as a search pattern and the second -one as flags. The "W" flag means the search doesn't wrap around the end of -the file. - -A function can be called in an expression. Example: > - - :let line = getline(".") - :let repl = substitute(line, '\a', "*", "g") - :call setline(".", repl) - -The getline() function obtains a line from the current buffer. Its argument -is a specification of the line number. In this case "." is used, which means -the line where the cursor is. - The substitute() function does something similar to the ":substitute" -command. The first argument is the string on which to perform the -substitution. The second argument is the pattern, the third the replacement -string. Finally, the last arguments are the flags. - The setline() function sets the line, specified by the first argument, to a -new string, the second argument. In this example the line under the cursor is -replaced with the result of the substitute(). Thus the effect of the three -statements is equal to: > - - :substitute/\a/*/g - -Using the functions becomes more interesting when you do more work before and -after the substitute() call. - - -FUNCTIONS *function-list* - -There are many functions. We will mention them here, grouped by what they are -used for. You can find an alphabetical list here: |functions|. Use CTRL-] on -the function name to jump to detailed help on it. - -String manipulation: - nr2char() get a character by its ASCII value - char2nr() get ASCII value of a character - str2nr() convert a string to a Number - str2float() convert a string to a Float - printf() format a string according to % items - escape() escape characters in a string with a '\' - shellescape() escape a string for use with a shell command - fnameescape() escape a file name for use with a Vim command - tr() translate characters from one set to another - strtrans() translate a string to make it printable - tolower() turn a string to lowercase - toupper() turn a string to uppercase - match() position where a pattern matches in a string - matchend() position where a pattern match ends in a string - matchstr() match of a pattern in a string - matchlist() like matchstr() and also return submatches - stridx() first index of a short string in a long string - strridx() last index of a short string in a long string - strlen() length of a string - substitute() substitute a pattern match with a string - submatch() get a specific match in a ":substitute" - strpart() get part of a string - expand() expand special keywords - iconv() convert text from one encoding to another - byteidx() byte index of a character in a string - repeat() repeat a string multiple times - eval() evaluate a string expression - -List manipulation: - get() get an item without error for wrong index - len() number of items in a List - empty() check if List is empty - insert() insert an item somewhere in a List - add() append an item to a List - extend() append a List to a List - remove() remove one or more items from a List - copy() make a shallow copy of a List - deepcopy() make a full copy of a List - filter() remove selected items from a List - map() change each List item - sort() sort a List - reverse() reverse the order of a List - split() split a String into a List - join() join List items into a String - range() return a List with a sequence of numbers - string() String representation of a List - call() call a function with List as arguments - index() index of a value in a List - max() maximum value in a List - min() minimum value in a List - count() count number of times a value appears in a List - repeat() repeat a List multiple times - -Dictionary manipulation: - get() get an entry without an error for a wrong key - len() number of entries in a Dictionary - has_key() check whether a key appears in a Dictionary - empty() check if Dictionary is empty - remove() remove an entry from a Dictionary - extend() add entries from one Dictionary to another - filter() remove selected entries from a Dictionary - map() change each Dictionary entry - keys() get List of Dictionary keys - values() get List of Dictionary values - items() get List of Dictionary key-value pairs - copy() make a shallow copy of a Dictionary - deepcopy() make a full copy of a Dictionary - string() String representation of a Dictionary - max() maximum value in a Dictionary - min() minimum value in a Dictionary - count() count number of times a value appears - -Floating point computation: - float2nr() convert Float to Number - abs() absolute value (also works for Number) - round() round off - ceil() round up - floor() round down - trunc() remove value after decimal point - log10() logarithm to base 10 - pow() value of x to the exponent y - sqrt() square root - sin() sine - cos() cosine - atan() arc tangent - -Variables: - type() type of a variable - islocked() check if a variable is locked - function() get a Funcref for a function name - getbufvar() get a variable value from a specific buffer - setbufvar() set a variable in a specific buffer - getwinvar() get a variable from specific window - gettabwinvar() get a variable from specific window & tab page - setwinvar() set a variable in a specific window - settabwinvar() set a variable in a specific window & tab page - garbagecollect() possibly free memory - -Cursor and mark position: - col() column number of the cursor or a mark - virtcol() screen column of the cursor or a mark - line() line number of the cursor or mark - wincol() window column number of the cursor - winline() window line number of the cursor - cursor() position the cursor at a line/column - getpos() get position of cursor, mark, etc. - setpos() set position of cursor, mark, etc. - byte2line() get line number at a specific byte count - line2byte() byte count at a specific line - diff_filler() get the number of filler lines above a line - -Working with text in the current buffer: - getline() get a line or list of lines from the buffer - setline() replace a line in the buffer - append() append line or list of lines in the buffer - indent() indent of a specific line - cindent() indent according to C indenting - lispindent() indent according to Lisp indenting - nextnonblank() find next non-blank line - prevnonblank() find previous non-blank line - search() find a match for a pattern - searchpos() find a match for a pattern - searchpair() find the other end of a start/skip/end - searchpairpos() find the other end of a start/skip/end - searchdecl() search for the declaration of a name - -System functions and manipulation of files: - glob() expand wildcards - globpath() expand wildcards in a number of directories - findfile() find a file in a list of directories - finddir() find a directory in a list of directories - resolve() find out where a shortcut points to - fnamemodify() modify a file name - pathshorten() shorten directory names in a path - simplify() simplify a path without changing its meaning - executable() check if an executable program exists - filereadable() check if a file can be read - filewritable() check if a file can be written to - getfperm() get the permissions of a file - getftype() get the kind of a file - isdirectory() check if a directory exists - getfsize() get the size of a file - getcwd() get the current working directory - haslocaldir() check if current window used |:lcd| - tempname() get the name of a temporary file - mkdir() create a new directory - delete() delete a file - rename() rename a file - system() get the result of a shell command - hostname() name of the system - readfile() read a file into a List of lines - writefile() write a List of lines into a file - -Date and Time: - getftime() get last modification time of a file - localtime() get current time in seconds - strftime() convert time to a string - reltime() get the current or elapsed time accurately - reltimestr() convert reltime() result to a string - -Buffers, windows and the argument list: - argc() number of entries in the argument list - argidx() current position in the argument list - argv() get one entry from the argument list - bufexists() check if a buffer exists - buflisted() check if a buffer exists and is listed - bufloaded() check if a buffer exists and is loaded - bufname() get the name of a specific buffer - bufnr() get the buffer number of a specific buffer - tabpagebuflist() return List of buffers in a tab page - tabpagenr() get the number of a tab page - tabpagewinnr() like winnr() for a specified tab page - winnr() get the window number for the current window - bufwinnr() get the window number of a specific buffer - winbufnr() get the buffer number of a specific window - getbufline() get a list of lines from the specified buffer - -Command line: - getcmdline() get the current command line - getcmdpos() get position of the cursor in the command line - setcmdpos() set position of the cursor in the command line - getcmdtype() return the current command-line type - -Quickfix and location lists: - getqflist() list of quickfix errors - setqflist() modify a quickfix list - getloclist() list of location list items - setloclist() modify a location list - -Insert mode completion: - complete() set found matches - complete_add() add to found matches - complete_check() check if completion should be aborted - pumvisible() check if the popup menu is displayed - -Folding: - foldclosed() check for a closed fold at a specific line - foldclosedend() like foldclosed() but return the last line - foldlevel() check for the fold level at a specific line - foldtext() generate the line displayed for a closed fold - foldtextresult() get the text displayed for a closed fold - -Syntax and highlighting: - clearmatches() clear all matches defined by |matchadd()| and - the |:match| commands - getmatches() get all matches defined by |matchadd()| and - the |:match| commands - hlexists() check if a highlight group exists - hlID() get ID of a highlight group - synID() get syntax ID at a specific position - synIDattr() get a specific attribute of a syntax ID - synIDtrans() get translated syntax ID - diff_hlID() get highlight ID for diff mode at a position - matchadd() define a pattern to highlight (a "match") - matcharg() get info about |:match| arguments - matchdelete() delete a match defined by |matchadd()| or a - |:match| command - setmatches() restore a list of matches saved by - |getmatches()| - -Spelling: - spellbadword() locate badly spelled word at or after cursor - spellsuggest() return suggested spelling corrections - soundfold() return the sound-a-like equivalent of a word - -History: - histadd() add an item to a history - histdel() delete an item from a history - histget() get an item from a history - histnr() get highest index of a history list - -Interactive: - browse() put up a file requester - browsedir() put up a directory requester - confirm() let the user make a choice - getchar() get a character from the user - getcharmod() get modifiers for the last typed character - feedkeys() put characters in the typeahead queue - input() get a line from the user - inputlist() let the user pick an entry from a list - inputsecret() get a line from the user without showing it - inputdialog() get a line from the user in a dialog - inputsave() save and clear typeahead - inputrestore() restore typeahead - -GUI: - getfontname() get name of current font being used - getwinposx() X position of the GUI Vim window - getwinposy() Y position of the GUI Vim window - -Vim server: - serverlist() return the list of server names - remote_send() send command characters to a Vim server - remote_expr() evaluate an expression in a Vim server - server2client() send a reply to a client of a Vim server - remote_peek() check if there is a reply from a Vim server - remote_read() read a reply from a Vim server - foreground() move the Vim window to the foreground - remote_foreground() move the Vim server window to the foreground - -Window size and position: - winheight() get height of a specific window - winwidth() get width of a specific window - winrestcmd() return command to restore window sizes - winsaveview() get view of current window - winrestview() restore saved view of current window - -Various: - mode() get current editing mode - visualmode() last visual mode used - hasmapto() check if a mapping exists - mapcheck() check if a matching mapping exists - maparg() get rhs of a mapping - exists() check if a variable, function, etc. exists - has() check if a feature is supported in Vim - changenr() return number of most recent change - cscope_connection() check if a cscope connection exists - did_filetype() check if a FileType autocommand was used - eventhandler() check if invoked by an event handler - getpid() get process ID of Vim - - libcall() call a function in an external library - libcallnr() idem, returning a number - - getreg() get contents of a register - getregtype() get type of a register - setreg() set contents and type of a register - - taglist() get list of matching tags - tagfiles() get a list of tags files - -============================================================================== -*41.7* Defining a function - -Vim enables you to define your own functions. The basic function declaration -begins as follows: > - - :function {name}({var1}, {var2}, ...) - : {body} - :endfunction -< - Note: - Function names must begin with a capital letter. - -Let's define a short function to return the smaller of two numbers. It starts -with this line: > - - :function Min(num1, num2) - -This tells Vim that the function is named "Min" and it takes two arguments: -"num1" and "num2". - The first thing you need to do is to check to see which number is smaller: - > - : if a:num1 < a:num2 - -The special prefix "a:" tells Vim that the variable is a function argument. -Let's assign the variable "smaller" the value of the smallest number: > - - : if a:num1 < a:num2 - : let smaller = a:num1 - : else - : let smaller = a:num2 - : endif - -The variable "smaller" is a local variable. Variables used inside a function -are local unless prefixed by something like "g:", "a:", or "s:". - - Note: - To access a global variable from inside a function you must prepend - "g:" to it. Thus "g:today" inside a function is used for the global - variable "today", and "today" is another variable, local to the - function. - -You now use the ":return" statement to return the smallest number to the user. -Finally, you end the function: > - - : return smaller - :endfunction - -The complete function definition is as follows: > - - :function Min(num1, num2) - : if a:num1 < a:num2 - : let smaller = a:num1 - : else - : let smaller = a:num2 - : endif - : return smaller - :endfunction - -For people who like short functions, this does the same thing: > - - :function Min(num1, num2) - : if a:num1 < a:num2 - : return a:num1 - : endif - : return a:num2 - :endfunction - -A user defined function is called in exactly the same way as a built-in -function. Only the name is different. The Min function can be used like -this: > - - :echo Min(5, 8) - -Only now will the function be executed and the lines be interpreted by Vim. -If there are mistakes, like using an undefined variable or function, you will -now get an error message. When defining the function these errors are not -detected. - -When a function reaches ":endfunction" or ":return" is used without an -argument, the function returns zero. - -To redefine a function that already exists, use the ! for the ":function" -command: > - - :function! Min(num1, num2, num3) - - -USING A RANGE - -The ":call" command can be given a line range. This can have one of two -meanings. When a function has been defined with the "range" keyword, it will -take care of the line range itself. - The function will be passed the variables "a:firstline" and "a:lastline". -These will have the line numbers from the range the function was called with. -Example: > - - :function Count_words() range - : let lnum = a:firstline - : let n = 0 - : while lnum <= a:lastline - : let n = n + len(split(getline(lnum))) - : let lnum = lnum + 1 - : endwhile - : echo "found " . n . " words" - :endfunction - -You can call this function with: > - - :10,30call Count_words() - -It will be executed once and echo the number of words. - The other way to use a line range is by defining a function without the -"range" keyword. The function will be called once for every line in the -range, with the cursor in that line. Example: > - - :function Number() - : echo "line " . line(".") . " contains: " . getline(".") - :endfunction - -If you call this function with: > - - :10,15call Number() - -The function will be called six times. - - -VARIABLE NUMBER OF ARGUMENTS - -Vim enables you to define functions that have a variable number of arguments. -The following command, for instance, defines a function that must have 1 -argument (start) and can have up to 20 additional arguments: > - - :function Show(start, ...) - -The variable "a:1" contains the first optional argument, "a:2" the second, and -so on. The variable "a:0" contains the number of extra arguments. - For example: > - - :function Show(start, ...) - : echohl Title - : echo "Show is " . a:start - : echohl None - : let index = 1 - : while index <= a:0 - : echo " Arg " . index . " is " . a:{index} - : let index = index + 1 - : endwhile - : echo "" - :endfunction - -This uses the ":echohl" command to specify the highlighting used for the -following ":echo" command. ":echohl None" stops it again. The ":echon" -command works like ":echo", but doesn't output a line break. - -You can also use the a:000 variable, it is a List of all the "..." arguments. -See |a:000|. - - -LISTING FUNCTIONS - -The ":function" command lists the names and arguments of all user-defined -functions: > - - :function -< function Show(start, ...) ~ - function GetVimIndent() ~ - function SetSyn(name) ~ - -To see what a function does, use its name as an argument for ":function": > - - :function SetSyn -< 1 if &syntax == '' ~ - 2 let &syntax = a:name ~ - 3 endif ~ - endfunction ~ - - -DEBUGGING - -The line number is useful for when you get an error message or when debugging. -See |debug-scripts| about debugging mode. - You can also set the 'verbose' option to 12 or higher to see all function -calls. Set it to 15 or higher to see every executed line. - - -DELETING A FUNCTION - -To delete the Show() function: > - - :delfunction Show - -You get an error when the function doesn't exist. - - -FUNCTION REFERENCES - -Sometimes it can be useful to have a variable point to one function or -another. You can do it with the function() function. It turns the name of a -function into a reference: > - - :let result = 0 " or 1 - :function! Right() - : return 'Right!' - :endfunc - :function! Wrong() - : return 'Wrong!' - :endfunc - : - :if result == 1 - : let Afunc = function('Right') - :else - : let Afunc = function('Wrong') - :endif - :echo call(Afunc, []) -< Wrong! ~ - -Note that the name of a variable that holds a function reference must start -with a capital. Otherwise it could be confused with the name of a builtin -function. - The way to invoke a function that a variable refers to is with the call() -function. Its first argument is the function reference, the second argument -is a List with arguments. - -Function references are most useful in combination with a Dictionary, as is -explained in the next section. - -============================================================================== -*41.8* Lists and Dictionaries - -So far we have used the basic types String and Number. Vim also supports two -composite types: List and Dictionary. - -A List is an ordered sequence of things. The things can be any kind of value, -thus you can make a List of numbers, a List of Lists and even a List of mixed -items. To create a List with three strings: > - - :let alist = ['aap', 'mies', 'noot'] - -The List items are enclosed in square brackets and separated by commas. To -create an empty List: > - - :let alist = [] - -You can add items to a List with the add() function: > - - :let alist = [] - :call add(alist, 'foo') - :call add(alist, 'bar') - :echo alist -< ['foo', 'bar'] ~ - -List concatenation is done with +: > - - :echo alist + ['foo', 'bar'] -< ['foo', 'bar', 'foo', 'bar'] ~ - -Or, if you want to extend a List directly: > - - :let alist = ['one'] - :call extend(alist, ['two', 'three']) - :echo alist -< ['one', 'two', 'three'] ~ - -Notice that using add() will have a different effect: > - - :let alist = ['one'] - :call add(alist, ['two', 'three']) - :echo alist -< ['one', ['two', 'three']] ~ - -The second argument of add() is added as a single item. - - -FOR LOOP - -One of the nice things you can do with a List is iterate over it: > - - :let alist = ['one', 'two', 'three'] - :for n in alist - : echo n - :endfor -< one ~ - two ~ - three ~ - -This will loop over each element in List "alist", assigning the value to -variable "n". The generic form of a for loop is: > - - :for {varname} in {listexpression} - : {commands} - :endfor - -To loop a certain number of times you need a List of a specific length. The -range() function creates one for you: > - - :for a in range(3) - : echo a - :endfor -< 0 ~ - 1 ~ - 2 ~ - -Notice that the first item of the List that range() produces is zero, thus the -last item is one less than the length of the list. - You can also specify the maximum value, the stride and even go backwards: > - - :for a in range(8, 4, -2) - : echo a - :endfor -< 8 ~ - 6 ~ - 4 ~ - -A more useful example, looping over lines in the buffer: > - - :for line in getline(1, 20) - : if line =~ "Date: " - : echo matchstr(line, 'Date: \zs.*') - : endif - :endfor - -This looks into lines 1 to 20 (inclusive) and echoes any date found in there. - - -DICTIONARIES - -A Dictionary stores key-value pairs. You can quickly lookup a value if you -know the key. A Dictionary is created with curly braces: > - - :let uk2nl = {'one': 'een', 'two': 'twee', 'three': 'drie'} - -Now you can lookup words by putting the key in square brackets: > - - :echo uk2nl['two'] -< twee ~ - -The generic form for defining a Dictionary is: > - - {<key> : <value>, ...} - -An empty Dictionary is one without any keys: > - - {} - -The possibilities with Dictionaries are numerous. There are various functions -for them as well. For example, you can obtain a list of the keys and loop -over them: > - - :for key in keys(uk2nl) - : echo key - :endfor -< three ~ - one ~ - two ~ - -You will notice the keys are not ordered. You can sort the list to get a -specific order: > - - :for key in sort(keys(uk2nl)) - : echo key - :endfor -< one ~ - three ~ - two ~ - -But you can never get back the order in which items are defined. For that you -need to use a List, it stores items in an ordered sequence. - - -DICTIONARY FUNCTIONS - -The items in a Dictionary can normally be obtained with an index in square -brackets: > - - :echo uk2nl['one'] -< een ~ - -A method that does the same, but without so many punctuation characters: > - - :echo uk2nl.one -< een ~ - -This only works for a key that is made of ASCII letters, digits and the -underscore. You can also assign a new value this way: > - - :let uk2nl.four = 'vier' - :echo uk2nl -< {'three': 'drie', 'four': 'vier', 'one': 'een', 'two': 'twee'} ~ - -And now for something special: you can directly define a function and store a -reference to it in the dictionary: > - - :function uk2nl.translate(line) dict - : return join(map(split(a:line), 'get(self, v:val, "???")')) - :endfunction - -Let's first try it out: > - - :echo uk2nl.translate('three two five one') -< drie twee ??? een ~ - -The first special thing you notice is the "dict" at the end of the ":function" -line. This marks the function as being used from a Dictionary. The "self" -local variable will then refer to that Dictionary. - Now let's break up the complicated return command: > - - split(a:line) - -The split() function takes a string, chops it into white separated words -and returns a list with these words. Thus in the example it returns: > - - :echo split('three two five one') -< ['three', 'two', 'five', 'one'] ~ - -This list is the first argument to the map() function. This will go through -the list, evaluating its second argument with "v:val" set to the value of each -item. This is a shortcut to using a for loop. This command: > - - :let alist = map(split(a:line), 'get(self, v:val, "???")') - -Is equivalent to: > - - :let alist = split(a:line) - :for idx in range(len(alist)) - : let alist[idx] = get(self, alist[idx], "???") - :endfor - -The get() function checks if a key is present in a Dictionary. If it is, then -the value is retrieved. If it isn't, then the default value is returned, in -the example it's '???'. This is a convenient way to handle situations where a -key may not be present and you don't want an error message. - -The join() function does the opposite of split(): it joins together a list of -words, putting a space in between. - This combination of split(), map() and join() is a nice way to filter a line -of words in a very compact way. - - -OBJECT ORIENTED PROGRAMMING - -Now that you can put both values and functions in a Dictionary, you can -actually use a Dictionary like an object. - Above we used a Dictionary for translating Dutch to English. We might want -to do the same for other languages. Let's first make an object (aka -Dictionary) that has the translate function, but no words to translate: > - - :let transdict = {} - :function transdict.translate(line) dict - : return join(map(split(a:line), 'get(self.words, v:val, "???")')) - :endfunction - -It's slightly different from the function above, using 'self.words' to lookup -word translations. But we don't have a self.words. Thus you could call this -an abstract class. - -Now we can instantiate a Dutch translation object: > - - :let uk2nl = copy(transdict) - :let uk2nl.words = {'one': 'een', 'two': 'twee', 'three': 'drie'} - :echo uk2nl.translate('three one') -< drie een ~ - -And a German translator: > - - :let uk2de = copy(transdict) - :let uk2de.words = {'one': 'ein', 'two': 'zwei', 'three': 'drei'} - :echo uk2de.translate('three one') -< drei ein ~ - -You see that the copy() function is used to make a copy of the "transdict" -Dictionary and then the copy is changed to add the words. The original -remains the same, of course. - -Now you can go one step further, and use your preferred translator: > - - :if $LANG =~ "de" - : let trans = uk2de - :else - : let trans = uk2nl - :endif - :echo trans.translate('one two three') -< een twee drie ~ - -Here "trans" refers to one of the two objects (Dictionaries). No copy is -made. More about List and Dictionary identity can be found at |list-identity| -and |dict-identity|. - -Now you might use a language that isn't supported. You can overrule the -translate() function to do nothing: > - - :let uk2uk = copy(transdict) - :function! uk2uk.translate(line) - : return a:line - :endfunction - :echo uk2uk.translate('three one wladiwostok') -< three one wladiwostok ~ - -Notice that a ! was used to overwrite the existing function reference. Now -use "uk2uk" when no recognized language is found: > - - :if $LANG =~ "de" - : let trans = uk2de - :elseif $LANG =~ "nl" - : let trans = uk2nl - :else - : let trans = uk2uk - :endif - :echo trans.translate('one two three') -< one two three ~ - -For further reading see |Lists| and |Dictionaries|. - -============================================================================== -*41.9* Exceptions - -Let's start with an example: > - - :try - : read ~/templates/pascal.tmpl - :catch /E484:/ - : echo "Sorry, the Pascal template file cannot be found." - :endtry - -The ":read" command will fail if the file does not exist. Instead of -generating an error message, this code catches the error and gives the user a -nice message instead. - -For the commands in between ":try" and ":endtry" errors are turned into -exceptions. An exception is a string. In the case of an error the string -contains the error message. And every error message has a number. In this -case, the error we catch contains "E484:". This number is guaranteed to stay -the same (the text may change, e.g., it may be translated). - -When the ":read" command causes another error, the pattern "E484:" will not -match in it. Thus this exception will not be caught and result in the usual -error message. - -You might be tempted to do this: > - - :try - : read ~/templates/pascal.tmpl - :catch - : echo "Sorry, the Pascal template file cannot be found." - :endtry - -This means all errors are caught. But then you will not see errors that are -useful, such as "E21: Cannot make changes, 'modifiable' is off". - -Another useful mechanism is the ":finally" command: > - - :let tmp = tempname() - :try - : exe ".,$write " . tmp - : exe "!filter " . tmp - : .,$delete - : exe "$read " . tmp - :finally - : call delete(tmp) - :endtry - -This filters the lines from the cursor until the end of the file through the -"filter" command, which takes a file name argument. No matter if the -filtering works, something goes wrong in between ":try" and ":finally" or the -user cancels the filtering by pressing CTRL-C, the "call delete(tmp)" is -always executed. This makes sure you don't leave the temporary file behind. - -More information about exception handling can be found in the reference -manual: |exception-handling|. - -============================================================================== -*41.10* Various remarks - -Here is a summary of items that apply to Vim scripts. They are also mentioned -elsewhere, but form a nice checklist. - -The end-of-line character depends on the system. For Unix a single <NL> -character is used. For MS-DOS, Windows, OS/2 and the like, <CR><LF> is used. -This is important when using mappings that end in a <CR>. See |:source_crnl|. - - -WHITE SPACE - -Blank lines are allowed and ignored. - -Leading whitespace characters (blanks and TABs) are always ignored. The -whitespaces between parameters (e.g. between the 'set' and the 'cpoptions' in -the example below) are reduced to one blank character and plays the role of a -separator, the whitespaces after the last (visible) character may or may not -be ignored depending on the situation, see below. - -For a ":set" command involving the "=" (equal) sign, such as in: > - - :set cpoptions =aABceFst - -the whitespace immediately before the "=" sign is ignored. But there can be -no whitespace after the "=" sign! - -To include a whitespace character in the value of an option, it must be -escaped by a "\" (backslash) as in the following example: > - - :set tags=my\ nice\ file - -The same example written as > - - :set tags=my nice file - -will issue an error, because it is interpreted as: > - - :set tags=my - :set nice - :set file - - -COMMENTS - -The character " (the double quote mark) starts a comment. Everything after -and including this character until the end-of-line is considered a comment and -is ignored, except for commands that don't consider comments, as shown in -examples below. A comment can start on any character position on the line. - -There is a little "catch" with comments for some commands. Examples: > - - :abbrev dev development " shorthand - :map <F3> o#include " insert include - :execute cmd " do it - :!ls *.c " list C files - -The abbreviation 'dev' will be expanded to 'development " shorthand'. The -mapping of <F3> will actually be the whole line after the 'o# ....' including -the '" insert include'. The "execute" command will give an error. The "!" -command will send everything after it to the shell, causing an error for an -unmatched '"' character. - There can be no comment after ":map", ":abbreviate", ":execute" and "!" -commands (there are a few more commands with this restriction). For the -":map", ":abbreviate" and ":execute" commands there is a trick: > - - :abbrev dev development|" shorthand - :map <F3> o#include|" insert include - :execute cmd |" do it - -With the '|' character the command is separated from the next one. And that -next command is only a comment. For the last command you need to do two -things: |:execute| and use '|': > - :exe '!ls *.c' |" list C files - -Notice that there is no white space before the '|' in the abbreviation and -mapping. For these commands, any character until the end-of-line or '|' is -included. As a consequence of this behavior, you don't always see that -trailing whitespace is included: > - - :map <F4> o#include - -To spot these problems, you can set the 'list' option when editing vimrc -files. - -For Unix there is one special way to comment a line, that allows making a Vim -script executable: > - #!/usr/bin/env vim -S - echo "this is a Vim script" - quit - -The "#" command by itself lists a line with the line number. Adding an -exclamation mark changes it into doing nothing, so that you can add the shell -command to execute the rest of the file. |:#!| |-S| - - -PITFALLS - -Even bigger problem arises in the following example: > - - :map ,ab o#include - :unmap ,ab - -Here the unmap command will not work, because it tries to unmap ",ab ". This -does not exist as a mapped sequence. An error will be issued, which is very -hard to identify, because the ending whitespace character in ":unmap ,ab " is -not visible. - -And this is the same as what happens when one uses a comment after an 'unmap' -command: > - - :unmap ,ab " comment - -Here the comment part will be ignored. However, Vim will try to unmap -',ab ', which does not exist. Rewrite it as: > - - :unmap ,ab| " comment - - -RESTORING THE VIEW - -Sometimes you want to make a change and go back to where cursor was. -Restoring the relative position would also be nice, so that the same line -appears at the top of the window. - This example yanks the current line, puts it above the first line in the -file and then restores the view: > - - map ,p ma"aYHmbgg"aP`bzt`a - -What this does: > - ma"aYHmbgg"aP`bzt`a -< ma set mark a at cursor position - "aY yank current line into register a - Hmb go to top line in window and set mark b there - gg go to first line in file - "aP put the yanked line above it - `b go back to top line in display - zt position the text in the window as before - `a go back to saved cursor position - - -PACKAGING - -To avoid your function names to interfere with functions that you get from -others, use this scheme: -- Prepend a unique string before each function name. I often use an - abbreviation. For example, "OW_" is used for the option window functions. -- Put the definition of your functions together in a file. Set a global - variable to indicate that the functions have been loaded. When sourcing the - file again, first unload the functions. -Example: > - - " This is the XXX package - - if exists("XXX_loaded") - delfun XXX_one - delfun XXX_two - endif - - function XXX_one(a) - ... body of function ... - endfun - - function XXX_two(b) - ... body of function ... - endfun - - let XXX_loaded = 1 - -============================================================================== -*41.11* Writing a plugin *write-plugin* - -You can write a Vim script in such a way that many people can use it. This is -called a plugin. Vim users can drop your script in their plugin directory and -use its features right away |add-plugin|. - -There are actually two types of plugins: - - global plugins: For all types of files. -filetype plugins: Only for files of a specific type. - -In this section the first type is explained. Most items are also relevant for -writing filetype plugins. The specifics for filetype plugins are in the next -section |write-filetype-plugin|. - - -NAME - -First of all you must choose a name for your plugin. The features provided -by the plugin should be clear from its name. And it should be unlikely that -someone else writes a plugin with the same name but which does something -different. And please limit the name to 8 characters, to avoid problems on -old Windows systems. - -A script that corrects typing mistakes could be called "typecorr.vim". We -will use it here as an example. - -For the plugin to work for everybody, it should follow a few guidelines. This -will be explained step-by-step. The complete example plugin is at the end. - - -BODY - -Let's start with the body of the plugin, the lines that do the actual work: > - - 14 iabbrev teh the - 15 iabbrev otehr other - 16 iabbrev wnat want - 17 iabbrev synchronisation - 18 \ synchronization - 19 let s:count = 4 - -The actual list should be much longer, of course. - -The line numbers have only been added to explain a few things, don't put them -in your plugin file! - - -HEADER - -You will probably add new corrections to the plugin and soon have several -versions laying around. And when distributing this file, people will want to -know who wrote this wonderful plugin and where they can send remarks. -Therefore, put a header at the top of your plugin: > - - 1 " Vim global plugin for correcting typing mistakes - 2 " Last Change: 2000 Oct 15 - 3 " Maintainer: Bram Moolenaar <Bram@vim.org> - -About copyright and licensing: Since plugins are very useful and it's hardly -worth restricting their distribution, please consider making your plugin -either public domain or use the Vim |license|. A short note about this near -the top of the plugin should be sufficient. Example: > - - 4 " License: This file is placed in the public domain. - - -LINE CONTINUATION, AVOIDING SIDE EFFECTS *use-cpo-save* - -In line 18 above, the line-continuation mechanism is used |line-continuation|. -Users with 'compatible' set will run into trouble here, they will get an error -message. We can't just reset 'compatible', because that has a lot of side -effects. To avoid this, we will set the 'cpoptions' option to its Vim default -value and restore it later. That will allow the use of line-continuation and -make the script work for most people. It is done like this: > - - 11 let s:save_cpo = &cpo - 12 set cpo&vim - .. - 42 let &cpo = s:save_cpo - -We first store the old value of 'cpoptions' in the s:save_cpo variable. At -the end of the plugin this value is restored. - -Notice that a script-local variable is used |s:var|. A global variable could -already be in use for something else. Always use script-local variables for -things that are only used in the script. - - -NOT LOADING - -It's possible that a user doesn't always want to load this plugin. Or the -system administrator has dropped it in the system-wide plugin directory, but a -user has his own plugin he wants to use. Then the user must have a chance to -disable loading this specific plugin. This will make it possible: > - - 6 if exists("loaded_typecorr") - 7 finish - 8 endif - 9 let loaded_typecorr = 1 - -This also avoids that when the script is loaded twice it would cause error -messages for redefining functions and cause trouble for autocommands that are -added twice. - - -MAPPING - -Now let's make the plugin more interesting: We will add a mapping that adds a -correction for the word under the cursor. We could just pick a key sequence -for this mapping, but the user might already use it for something else. To -allow the user to define which keys a mapping in a plugin uses, the <Leader> -item can be used: > - - 22 map <unique> <Leader>a <Plug>TypecorrAdd - -The "<Plug>TypecorrAdd" thing will do the work, more about that further on. - -The user can set the "mapleader" variable to the key sequence that he wants -this mapping to start with. Thus if the user has done: > - - let mapleader = "_" - -the mapping will define "_a". If the user didn't do this, the default value -will be used, which is a backslash. Then a map for "\a" will be defined. - -Note that <unique> is used, this will cause an error message if the mapping -already happened to exist. |:map-<unique>| - -But what if the user wants to define his own key sequence? We can allow that -with this mechanism: > - - 21 if !hasmapto('<Plug>TypecorrAdd') - 22 map <unique> <Leader>a <Plug>TypecorrAdd - 23 endif - -This checks if a mapping to "<Plug>TypecorrAdd" already exists, and only -defines the mapping from "<Leader>a" if it doesn't. The user then has a -chance of putting this in his vimrc file: > - - map ,c <Plug>TypecorrAdd - -Then the mapped key sequence will be ",c" instead of "_a" or "\a". - - -PIECES - -If a script gets longer, you often want to break up the work in pieces. You -can use functions or mappings for this. But you don't want these functions -and mappings to interfere with the ones from other scripts. For example, you -could define a function Add(), but another script could try to define the same -function. To avoid this, we define the function local to the script by -prepending it with "s:". - -We will define a function that adds a new typing correction: > - - 30 function s:Add(from, correct) - 31 let to = input("type the correction for " . a:from . ": ") - 32 exe ":iabbrev " . a:from . " " . to - .. - 36 endfunction - -Now we can call the function s:Add() from within this script. If another -script also defines s:Add(), it will be local to that script and can only -be called from the script it was defined in. There can also be a global Add() -function (without the "s:"), which is again another function. - -<SID> can be used with mappings. It generates a script ID, which identifies -the current script. In our typing correction plugin we use it like this: > - - 24 noremap <unique> <script> <Plug>TypecorrAdd <SID>Add - .. - 28 noremap <SID>Add :call <SID>Add(expand("<cword>"), 1)<CR> - -Thus when a user types "\a", this sequence is invoked: > - - \a -> <Plug>TypecorrAdd -> <SID>Add -> :call <SID>Add() - -If another script would also map <SID>Add, it would get another script ID and -thus define another mapping. - -Note that instead of s:Add() we use <SID>Add() here. That is because the -mapping is typed by the user, thus outside of the script. The <SID> is -translated to the script ID, so that Vim knows in which script to look for -the Add() function. - -This is a bit complicated, but it's required for the plugin to work together -with other plugins. The basic rule is that you use <SID>Add() in mappings and -s:Add() in other places (the script itself, autocommands, user commands). - -We can also add a menu entry to do the same as the mapping: > - - 26 noremenu <script> Plugin.Add\ Correction <SID>Add - -The "Plugin" menu is recommended for adding menu items for plugins. In this -case only one item is used. When adding more items, creating a submenu is -recommended. For example, "Plugin.CVS" could be used for a plugin that offers -CVS operations "Plugin.CVS.checkin", "Plugin.CVS.checkout", etc. - -Note that in line 28 ":noremap" is used to avoid that any other mappings cause -trouble. Someone may have remapped ":call", for example. In line 24 we also -use ":noremap", but we do want "<SID>Add" to be remapped. This is why -"<script>" is used here. This only allows mappings which are local to the -script. |:map-<script>| The same is done in line 26 for ":noremenu". -|:menu-<script>| - - -<SID> AND <Plug> *using-<Plug>* - -Both <SID> and <Plug> are used to avoid that mappings of typed keys interfere -with mappings that are only to be used from other mappings. Note the -difference between using <SID> and <Plug>: - -<Plug> is visible outside of the script. It is used for mappings which the - user might want to map a key sequence to. <Plug> is a special code - that a typed key will never produce. - To make it very unlikely that other plugins use the same sequence of - characters, use this structure: <Plug> scriptname mapname - In our example the scriptname is "Typecorr" and the mapname is "Add". - This results in "<Plug>TypecorrAdd". Only the first character of - scriptname and mapname is uppercase, so that we can see where mapname - starts. - -<SID> is the script ID, a unique identifier for a script. - Internally Vim translates <SID> to "<SNR>123_", where "123" can be any - number. Thus a function "<SID>Add()" will have a name "<SNR>11_Add()" - in one script, and "<SNR>22_Add()" in another. You can see this if - you use the ":function" command to get a list of functions. The - translation of <SID> in mappings is exactly the same, that's how you - can call a script-local function from a mapping. - - -USER COMMAND - -Now let's add a user command to add a correction: > - - 38 if !exists(":Correct") - 39 command -nargs=1 Correct :call s:Add(<q-args>, 0) - 40 endif - -The user command is defined only if no command with the same name already -exists. Otherwise we would get an error here. Overriding the existing user -command with ":command!" is not a good idea, this would probably make the user -wonder why the command he defined himself doesn't work. |:command| - - -SCRIPT VARIABLES - -When a variable starts with "s:" it is a script variable. It can only be used -inside a script. Outside the script it's not visible. This avoids trouble -with using the same variable name in different scripts. The variables will be -kept as long as Vim is running. And the same variables are used when sourcing -the same script again. |s:var| - -The fun is that these variables can also be used in functions, autocommands -and user commands that are defined in the script. In our example we can add -a few lines to count the number of corrections: > - - 19 let s:count = 4 - .. - 30 function s:Add(from, correct) - .. - 34 let s:count = s:count + 1 - 35 echo s:count . " corrections now" - 36 endfunction - -First s:count is initialized to 4 in the script itself. When later the -s:Add() function is called, it increments s:count. It doesn't matter from -where the function was called, since it has been defined in the script, it -will use the local variables from this script. - - -THE RESULT - -Here is the resulting complete example: > - - 1 " Vim global plugin for correcting typing mistakes - 2 " Last Change: 2000 Oct 15 - 3 " Maintainer: Bram Moolenaar <Bram@vim.org> - 4 " License: This file is placed in the public domain. - 5 - 6 if exists("loaded_typecorr") - 7 finish - 8 endif - 9 let loaded_typecorr = 1 - 10 - 11 let s:save_cpo = &cpo - 12 set cpo&vim - 13 - 14 iabbrev teh the - 15 iabbrev otehr other - 16 iabbrev wnat want - 17 iabbrev synchronisation - 18 \ synchronization - 19 let s:count = 4 - 20 - 21 if !hasmapto('<Plug>TypecorrAdd') - 22 map <unique> <Leader>a <Plug>TypecorrAdd - 23 endif - 24 noremap <unique> <script> <Plug>TypecorrAdd <SID>Add - 25 - 26 noremenu <script> Plugin.Add\ Correction <SID>Add - 27 - 28 noremap <SID>Add :call <SID>Add(expand("<cword>"), 1)<CR> - 29 - 30 function s:Add(from, correct) - 31 let to = input("type the correction for " . a:from . ": ") - 32 exe ":iabbrev " . a:from . " " . to - 33 if a:correct | exe "normal viws\<C-R>\" \b\e" | endif - 34 let s:count = s:count + 1 - 35 echo s:count . " corrections now" - 36 endfunction - 37 - 38 if !exists(":Correct") - 39 command -nargs=1 Correct :call s:Add(<q-args>, 0) - 40 endif - 41 - 42 let &cpo = s:save_cpo - -Line 33 wasn't explained yet. It applies the new correction to the word under -the cursor. The |:normal| command is used to use the new abbreviation. Note -that mappings and abbreviations are expanded here, even though the function -was called from a mapping defined with ":noremap". - -Using "unix" for the 'fileformat' option is recommended. The Vim scripts will -then work everywhere. Scripts with 'fileformat' set to "dos" do not work on -Unix. Also see |:source_crnl|. To be sure it is set right, do this before -writing the file: > - - :set fileformat=unix - - -DOCUMENTATION *write-local-help* - -It's a good idea to also write some documentation for your plugin. Especially -when its behavior can be changed by the user. See |add-local-help| for how -they are installed. - -Here is a simple example for a plugin help file, called "typecorr.txt": > - - 1 *typecorr.txt* Plugin for correcting typing mistakes - 2 - 3 If you make typing mistakes, this plugin will have them corrected - 4 automatically. - 5 - 6 There are currently only a few corrections. Add your own if you like. - 7 - 8 Mappings: - 9 <Leader>a or <Plug>TypecorrAdd - 10 Add a correction for the word under the cursor. - 11 - 12 Commands: - 13 :Correct {word} - 14 Add a correction for {word}. - 15 - 16 *typecorr-settings* - 17 This plugin doesn't have any settings. - -The first line is actually the only one for which the format matters. It will -be extracted from the help file to be put in the "LOCAL ADDITIONS:" section of -help.txt |local-additions|. The first "*" must be in the first column of the -first line. After adding your help file do ":help" and check that the entries -line up nicely. - -You can add more tags inside ** in your help file. But be careful not to use -existing help tags. You would probably use the name of your plugin in most of -them, like "typecorr-settings" in the example. - -Using references to other parts of the help in || is recommended. This makes -it easy for the user to find associated help. - - -FILETYPE DETECTION *plugin-filetype* - -If your filetype is not already detected by Vim, you should create a filetype -detection snippet in a separate file. It is usually in the form of an -autocommand that sets the filetype when the file name matches a pattern. -Example: > - - au BufNewFile,BufRead *.foo set filetype=foofoo - -Write this single-line file as "ftdetect/foofoo.vim" in the first directory -that appears in 'runtimepath'. For Unix that would be -"~/.vim/ftdetect/foofoo.vim". The convention is to use the name of the -filetype for the script name. - -You can make more complicated checks if you like, for example to inspect the -contents of the file to recognize the language. Also see |new-filetype|. - - -SUMMARY *plugin-special* - -Summary of special things to use in a plugin: - -s:name Variables local to the script. - -<SID> Script-ID, used for mappings and functions local to - the script. - -hasmapto() Function to test if the user already defined a mapping - for functionality the script offers. - -<Leader> Value of "mapleader", which the user defines as the - keys that plugin mappings start with. - -:map <unique> Give a warning if a mapping already exists. - -:noremap <script> Use only mappings local to the script, not global - mappings. - -exists(":Cmd") Check if a user command already exists. - -============================================================================== -*41.12* Writing a filetype plugin *write-filetype-plugin* *ftplugin* - -A filetype plugin is like a global plugin, except that it sets options and -defines mappings for the current buffer only. See |add-filetype-plugin| for -how this type of plugin is used. - -First read the section on global plugins above |41.11|. All that is said there -also applies to filetype plugins. There are a few extras, which are explained -here. The essential thing is that a filetype plugin should only have an -effect on the current buffer. - - -DISABLING - -If you are writing a filetype plugin to be used by many people, they need a -chance to disable loading it. Put this at the top of the plugin: > - - " Only do this when not done yet for this buffer - if exists("b:did_ftplugin") - finish - endif - let b:did_ftplugin = 1 - -This also needs to be used to avoid that the same plugin is executed twice for -the same buffer (happens when using an ":edit" command without arguments). - -Now users can disable loading the default plugin completely by making a -filetype plugin with only this line: > - - let b:did_ftplugin = 1 - -This does require that the filetype plugin directory comes before $VIMRUNTIME -in 'runtimepath'! - -If you do want to use the default plugin, but overrule one of the settings, -you can write the different setting in a script: > - - setlocal textwidth=70 - -Now write this in the "after" directory, so that it gets sourced after the -distributed "vim.vim" ftplugin |after-directory|. For Unix this would be -"~/.vim/after/ftplugin/vim.vim". Note that the default plugin will have set -"b:did_ftplugin", but it is ignored here. - - -OPTIONS - -To make sure the filetype plugin only affects the current buffer use the > - - :setlocal - -command to set options. And only set options which are local to a buffer (see -the help for the option to check that). When using |:setlocal| for global -options or options local to a window, the value will change for many buffers, -and that is not what a filetype plugin should do. - -When an option has a value that is a list of flags or items, consider using -"+=" and "-=" to keep the existing value. Be aware that the user may have -changed an option value already. First resetting to the default value and -then changing it often a good idea. Example: > - - :setlocal formatoptions& formatoptions+=ro - - -MAPPINGS - -To make sure mappings will only work in the current buffer use the > - - :map <buffer> - -command. This needs to be combined with the two-step mapping explained above. -An example of how to define functionality in a filetype plugin: > - - if !hasmapto('<Plug>JavaImport') - map <buffer> <unique> <LocalLeader>i <Plug>JavaImport - endif - noremap <buffer> <unique> <Plug>JavaImport oimport ""<Left><Esc> - -|hasmapto()| is used to check if the user has already defined a map to -<Plug>JavaImport. If not, then the filetype plugin defines the default -mapping. This starts with |<LocalLeader>|, which allows the user to select -the key(s) he wants filetype plugin mappings to start with. The default is a -backslash. -"<unique>" is used to give an error message if the mapping already exists or -overlaps with an existing mapping. -|:noremap| is used to avoid that any other mappings that the user has defined -interferes. You might want to use ":noremap <script>" to allow remapping -mappings defined in this script that start with <SID>. - -The user must have a chance to disable the mappings in a filetype plugin, -without disabling everything. Here is an example of how this is done for a -plugin for the mail filetype: > - - " Add mappings, unless the user didn't want this. - if !exists("no_plugin_maps") && !exists("no_mail_maps") - " Quote text by inserting "> " - if !hasmapto('<Plug>MailQuote') - vmap <buffer> <LocalLeader>q <Plug>MailQuote - nmap <buffer> <LocalLeader>q <Plug>MailQuote - endif - vnoremap <buffer> <Plug>MailQuote :s/^/> /<CR> - nnoremap <buffer> <Plug>MailQuote :.,$s/^/> /<CR> - endif - -Two global variables are used: -no_plugin_maps disables mappings for all filetype plugins -no_mail_maps disables mappings for a specific filetype - - -USER COMMANDS - -To add a user command for a specific file type, so that it can only be used in -one buffer, use the "-buffer" argument to |:command|. Example: > - - :command -buffer Make make %:r.s - - -VARIABLES - -A filetype plugin will be sourced for each buffer of the type it's for. Local -script variables |s:var| will be shared between all invocations. Use local -buffer variables |b:var| if you want a variable specifically for one buffer. - - -FUNCTIONS - -When defining a function, this only needs to be done once. But the filetype -plugin will be sourced every time a file with this filetype will be opened. -This construct make sure the function is only defined once: > - - :if !exists("*s:Func") - : function s:Func(arg) - : ... - : endfunction - :endif -< - -UNDO *undo_ftplugin* - -When the user does ":setfiletype xyz" the effect of the previous filetype -should be undone. Set the b:undo_ftplugin variable to the commands that will -undo the settings in your filetype plugin. Example: > - - let b:undo_ftplugin = "setlocal fo< com< tw< commentstring<" - \ . "| unlet b:match_ignorecase b:match_words b:match_skip" - -Using ":setlocal" with "<" after the option name resets the option to its -global value. That is mostly the best way to reset the option value. - -This does require removing the "C" flag from 'cpoptions' to allow line -continuation, as mentioned above |use-cpo-save|. - - -FILE NAME - -The filetype must be included in the file name |ftplugin-name|. Use one of -these three forms: - - .../ftplugin/stuff.vim - .../ftplugin/stuff_foo.vim - .../ftplugin/stuff/bar.vim - -"stuff" is the filetype, "foo" and "bar" are arbitrary names. - - -SUMMARY *ftplugin-special* - -Summary of special things to use in a filetype plugin: - -<LocalLeader> Value of "maplocalleader", which the user defines as - the keys that filetype plugin mappings start with. - -:map <buffer> Define a mapping local to the buffer. - -:noremap <script> Only remap mappings defined in this script that start - with <SID>. - -:setlocal Set an option for the current buffer only. - -:command -buffer Define a user command local to the buffer. - -exists("*s:Func") Check if a function was already defined. - -Also see |plugin-special|, the special things used for all plugins. - -============================================================================== -*41.13* Writing a compiler plugin *write-compiler-plugin* - -A compiler plugin sets options for use with a specific compiler. The user can -load it with the |:compiler| command. The main use is to set the -'errorformat' and 'makeprg' options. - -Easiest is to have a look at examples. This command will edit all the default -compiler plugins: > - - :next $VIMRUNTIME/compiler/*.vim - -Use |:next| to go to the next plugin file. - -There are two special items about these files. First is a mechanism to allow -a user to overrule or add to the default file. The default files start with: > - - :if exists("current_compiler") - : finish - :endif - :let current_compiler = "mine" - -When you write a compiler file and put it in your personal runtime directory -(e.g., ~/.vim/compiler for Unix), you set the "current_compiler" variable to -make the default file skip the settings. - *:CompilerSet* -The second mechanism is to use ":set" for ":compiler!" and ":setlocal" for -":compiler". Vim defines the ":CompilerSet" user command for this. However, -older Vim versions don't, thus your plugin should define it then. This is an -example: > - - if exists(":CompilerSet") != 2 - command -nargs=* CompilerSet setlocal <args> - endif - CompilerSet errorformat& " use the default 'errorformat' - CompilerSet makeprg=nmake - -When you write a compiler plugin for the Vim distribution or for a system-wide -runtime directory, use the mechanism mentioned above. When -"current_compiler" was already set by a user plugin nothing will be done. - -When you write a compiler plugin to overrule settings from a default plugin, -don't check "current_compiler". This plugin is supposed to be loaded -last, thus it should be in a directory at the end of 'runtimepath'. For Unix -that could be ~/.vim/after/compiler. - -============================================================================== -*41.14* Writing a plugin that loads quickly *write-plugin-quickload* - -A plugin may grow and become quite long. The startup delay may become -noticeable, while you hardly ever use the plugin. Then it's time for a -quickload plugin. - -The basic idea is that the plugin is loaded twice. The first time user -commands and mappings are defined that offer the functionality. The second -time the functions that implement the functionality are defined. - -It may sound surprising that quickload means loading a script twice. What we -mean is that it loads quickly the first time, postponing the bulk of the -script to the second time, which only happens when you actually use it. When -you always use the functionality it actually gets slower! - -Note that since Vim 7 there is an alternative: use the |autoload| -functionality |41.15|. - -The following example shows how it's done: > - - " Vim global plugin for demonstrating quick loading - " Last Change: 2005 Feb 25 - " Maintainer: Bram Moolenaar <Bram@vim.org> - " License: This file is placed in the public domain. - - if !exists("s:did_load") - command -nargs=* BNRead call BufNetRead(<f-args>) - map <F19> :call BufNetWrite('something')<CR> - - let s:did_load = 1 - exe 'au FuncUndefined BufNet* source ' . expand('<sfile>') - finish - endif - - function BufNetRead(...) - echo 'BufNetRead(' . string(a:000) . ')' - " read functionality here - endfunction - - function BufNetWrite(...) - echo 'BufNetWrite(' . string(a:000) . ')' - " write functionality here - endfunction - -When the script is first loaded "s:did_load" is not set. The commands between -the "if" and "endif" will be executed. This ends in a |:finish| command, thus -the rest of the script is not executed. - -The second time the script is loaded "s:did_load" exists and the commands -after the "endif" are executed. This defines the (possible long) -BufNetRead() and BufNetWrite() functions. - -If you drop this script in your plugin directory Vim will execute it on -startup. This is the sequence of events that happens: - -1. The "BNRead" command is defined and the <F19> key is mapped when the script - is sourced at startup. A |FuncUndefined| autocommand is defined. The - ":finish" command causes the script to terminate early. - -2. The user types the BNRead command or presses the <F19> key. The - BufNetRead() or BufNetWrite() function will be called. - -3. Vim can't find the function and triggers the |FuncUndefined| autocommand - event. Since the pattern "BufNet*" matches the invoked function, the - command "source fname" will be executed. "fname" will be equal to the name - of the script, no matter where it is located, because it comes from - expanding "<sfile>" (see |expand()|). - -4. The script is sourced again, the "s:did_load" variable exists and the - functions are defined. - -Notice that the functions that are loaded afterwards match the pattern in the -|FuncUndefined| autocommand. You must make sure that no other plugin defines -functions that match this pattern. - -============================================================================== -*41.15* Writing library scripts *write-library-script* - -Some functionality will be required in several places. When this becomes more -than a few lines you will want to put it in one script and use it from many -scripts. We will call that one script a library script. - -Manually loading a library script is possible, so long as you avoid loading it -when it's already done. You can do this with the |exists()| function. -Example: > - - if !exists('*MyLibFunction') - runtime library/mylibscript.vim - endif - call MyLibFunction(arg) - -Here you need to know that MyLibFunction() is defined in a script -"library/mylibscript.vim" in one of the directories in 'runtimepath'. - -To make this a bit simpler Vim offers the autoload mechanism. Then the -example looks like this: > - - call mylib#myfunction(arg) - -That's a lot simpler, isn't it? Vim will recognize the function name and when -it's not defined search for the script "autoload/mylib.vim" in 'runtimepath'. -That script must define the "mylib#myfunction()" function. - -You can put many other functions in the mylib.vim script, you are free to -organize your functions in library scripts. But you must use function names -where the part before the '#' matches the script name. Otherwise Vim would -not know what script to load. - -If you get really enthusiastic and write lots of library scripts, you may -want to use subdirectories. Example: > - - call netlib#ftp#read('somefile') - -For Unix the library script used for this could be: - - ~/.vim/autoload/netlib/ftp.vim - -Where the function is defined like this: > - - function netlib#ftp#read(fname) - " Read the file fname through ftp - endfunction - -Notice that the name the function is defined with is exactly the same as the -name used for calling the function. And the part before the last '#' -exactly matches the subdirectory and script name. - -You can use the same mechanism for variables: > - - let weekdays = dutch#weekdays - -This will load the script "autoload/dutch.vim", which should contain something -like: > - - let dutch#weekdays = ['zondag', 'maandag', 'dinsdag', 'woensdag', - \ 'donderdag', 'vrijdag', 'zaterdag'] - -Further reading: |autoload|. - -============================================================================== -*41.16* Distributing Vim scripts *distribute-script* - -Vim users will look for scripts on the Vim website: http://www.vim.org. -If you made something that is useful for others, share it! - -Vim scripts can be used on any system. There might not be a tar or gzip -command. If you want to pack files together and/or compress them the "zip" -utility is recommended. - -For utmost portability use Vim itself to pack scripts together. This can be -done with the Vimball utility. See |vimball|. - -It's good if you add a line to allow automatic updating. See |glvs-plugins|. - -============================================================================== - -Next chapter: |usr_42.txt| Add new menus - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_42.txt b/share/vim/vim72/doc/usr_42.txt deleted file mode 100644 index 275078ceea..0000000000 --- a/share/vim/vim72/doc/usr_42.txt +++ /dev/null @@ -1,365 +0,0 @@ -*usr_42.txt* For Vim version 7.2. Last change: 2008 May 05 - - VIM USER MANUAL - by Bram Moolenaar - - Add new menus - - -By now you know that Vim is very flexible. This includes the menus used in -the GUI. You can define your own menu entries to make certain commands easily -accessible. This is for mouse-happy users only. - -|42.1| Introduction -|42.2| Menu commands -|42.3| Various -|42.4| Toolbar and popup menus - - Next chapter: |usr_43.txt| Using filetypes - Previous chapter: |usr_41.txt| Write a Vim script -Table of contents: |usr_toc.txt| - -============================================================================== -*42.1* Introduction - -The menus that Vim uses are defined in the file "$VIMRUNTIME/menu.vim". If -you want to write your own menus, you might first want to look through that -file. - To define a menu item, use the ":menu" command. The basic form of this -command is as follows: > - - :menu {menu-item} {keys} - -The {menu-item} describes where on the menu to put the item. A typical -{menu-item} is "File.Save", which represents the item "Save" under the -"File" menu. A dot is used to separate the names. Example: > - - :menu File.Save :update<CR> - -The ":update" command writes the file when it was modified. - You can add another level: "Edit.Settings.Shiftwidth" defines a submenu -"Settings" under the "Edit" menu, with an item "Shiftwidth". You could use -even deeper levels. Don't use this too much, you need to move the mouse quite -a bit to use such an item. - The ":menu" command is very similar to the ":map" command: the left side -specifies how the item is triggered and the right hand side defines the -characters that are executed. {keys} are characters, they are used just like -you would have typed them. Thus in Insert mode, when {keys} is plain text, -that text is inserted. - - -ACCELERATORS - -The ampersand character (&) is used to indicate an accelerator. For instance, -you can use Alt-F to select "File" and S to select "Save". (The 'winaltkeys' -option may disable this though!). Therefore, the {menu-item} looks like -"&File.&Save". The accelerator characters will be underlined in the menu. - You must take care that each key is used only once in each menu. Otherwise -you will not know which of the two will actually be used. Vim doesn't warn -you for this. - - -PRIORITIES - -The actual definition of the File.Save menu item is as follows: > - - :menu 10.340 &File.&Save<Tab>:w :confirm w<CR> - -The number 10.340 is called the priority number. It is used by the editor to -decide where it places the menu item. The first number (10) indicates the -position on the menu bar. Lower numbered menus are positioned to the left, -higher numbers to the right. - These are the priorities used for the standard menus: - - 10 20 40 50 60 70 9999 - - +------------------------------------------------------------+ - | File Edit Tools Syntax Buffers Window Help | - +------------------------------------------------------------+ - -Notice that the Help menu is given a very high number, to make it appear on -the far right. - The second number (340) determines the location of the item within the -pull-down menu. Lower numbers go on top, higher number on the bottom. These -are the priorities in the File menu: - - +-----------------+ - 10.310 |Open... | - 10.320 |Split-Open... | - 10.325 |New | - 10.330 |Close | - 10.335 |---------------- | - 10.340 |Save | - 10.350 |Save As... | - 10.400 |---------------- | - 10.410 |Split Diff with | - 10.420 |Split Patched By | - 10.500 |---------------- | - 10.510 |Print | - 10.600 |---------------- | - 10.610 |Save-Exit | - 10.620 |Exit | - +-----------------+ - -Notice that there is room in between the numbers. This is where you can -insert your own items, if you really want to (it's often better to leave the -standard menus alone and add a new menu for your own items). - When you create a submenu, you can add another ".number" to the priority. -Thus each name in {menu-item} has its priority number. - - -SPECIAL CHARACTERS - -The {menu-item} in this example is "&File.&Save<Tab>:w". This brings up an -important point: {menu-item} must be one word. If you want to put a dot, -space or tabs in the name, you either use the <> notation (<Space> and <Tab>, -for instance) or use the backslash (\) escape. > - - :menu 10.305 &File.&Do\ It\.\.\. :exit<CR> - -In this example, the name of the menu item "Do It..." contains a space and the -command is ":exit<CR>". - -The <Tab> character in a menu name is used to separate the part that defines -the menu name from the part that gives a hint to the user. The part after the -<Tab> is displayed right aligned in the menu. In the File.Save menu the name -used is "&File.&Save<Tab>:w". Thus the menu name is "File.Save" and the hint -is ":w". - - -SEPARATORS - -The separator lines, used to group related menu items together, can be defined -by using a name that starts and ends in a '-'. For example "-sep-". When -using several separators the names must be different. Otherwise the names -don't matter. - The command from a separator will never be executed, but you have to define -one anyway. A single colon will do. Example: > - - :amenu 20.510 Edit.-sep3- : - -============================================================================== -*42.2* Menu commands - -You can define menu items that exist for only certain modes. This works just -like the variations on the ":map" command: - - :menu Normal, Visual and Operator-pending mode - :nmenu Normal mode - :vmenu Visual mode - :omenu Operator-pending mode - :menu! Insert and Command-line mode - :imenu Insert mode - :cmenu Command-line mode - :amenu All modes - -To avoid that the commands of a menu item are being mapped, use the command -":noremenu", ":nnoremenu", ":anoremenu", etc. - - -USING :AMENU - -The ":amenu" command is a bit different. It assumes that the {keys} you -give are to be executed in Normal mode. When Vim is in Visual or Insert mode -when the menu is used, Vim first has to go back to Normal mode. ":amenu" -inserts a CTRL-C or CTRL-O for you. For example, if you use this command: -> - :amenu 90.100 Mine.Find\ Word * - -Then the resulting menu commands will be: - - Normal mode: * - Visual mode: CTRL-C * - Operator-pending mode: CTRL-C * - Insert mode: CTRL-O * - Command-line mode: CTRL-C * - -When in Command-line mode the CTRL-C will abandon the command typed so far. -In Visual and Operator-pending mode CTRL-C will stop the mode. The CTRL-O in -Insert mode will execute the command and then return to Insert mode. - CTRL-O only works for one command. If you need to use two or more -commands, put them in a function and call that function. Example: > - - :amenu Mine.Next\ File :call <SID>NextFile()<CR> - :function <SID>NextFile() - : next - : 1/^Code - :endfunction - -This menu entry goes to the next file in the argument list with ":next". Then -it searches for the line that starts with "Code". - The <SID> before the function name is the script ID. This makes the -function local to the current Vim script file. This avoids problems when a -function with the same name is defined in another script file. See |<SID>|. - - -SILENT MENUS - -The menu executes the {keys} as if you typed them. For a ":" command this -means you will see the command being echoed on the command line. If it's a -long command, the hit-Enter prompt will appear. That can be very annoying! - To avoid this, make the menu silent. This is done with the <silent> -argument. For example, take the call to NextFile() in the previous example. -When you use this menu, you will see this on the command line: - - :call <SNR>34_NextFile() ~ - -To avoid this text on the command line, insert "<silent>" as the first -argument: > - - :amenu <silent> Mine.Next\ File :call <SID>NextFile()<CR> - -Don't use "<silent>" too often. It is not needed for short commands. If you -make a menu for someone else, being able the see the executed command will -give him a hint about what he could have typed, instead of using the mouse. - - -LISTING MENUS - -When a menu command is used without a {keys} part, it lists the already -defined menus. You can specify a {menu-item}, or part of it, to list specific -menus. Example: > - - :amenu - -This lists all menus. That's a long list! Better specify the name of a menu -to get a shorter list: > - - :amenu Edit - -This lists only the "Edit" menu items for all modes. To list only one -specific menu item for Insert mode: > - - :imenu Edit.Undo - -Take care that you type exactly the right name. Case matters here. But the -'&' for accelerators can be omitted. The <Tab> and what comes after it can be -left out as well. - - -DELETING MENUS - -To delete a menu, the same command is used as for listing, but with "menu" -changed to "unmenu". Thus ":menu" becomes, ":unmenu", ":nmenu" becomes -":nunmenu", etc. To delete the "Tools.Make" item for Insert mode: > - - :iunmenu Tools.Make - -You can delete a whole menu, with all its items, by using the menu name. -Example: > - - :aunmenu Syntax - -This deletes the Syntax menu and all the items in it. - -============================================================================== -*42.3* Various - -You can change the appearance of the menus with flags in 'guioptions'. In the -default value they are all included, except "M". You can remove a flag with a -command like: > - - :set guioptions-=m -< - m When removed the menubar is not displayed. - - M When added the default menus are not loaded. - - g When removed the inactive menu items are not made grey - but are completely removed. (Does not work on all - systems.) - - t When removed the tearoff feature is not enabled. - -The dotted line at the top of a menu is not a separator line. When you select -this item, the menu is "teared-off": It is displayed in a separate window. -This is called a tearoff menu. This is useful when you use the same menu -often. - -For translating menu items, see |:menutrans|. - -Since the mouse has to be used to select a menu item, it is a good idea to use -the ":browse" command for selecting a file. And ":confirm" to get a dialog -instead of an error message, e.g., when the current buffer contains changes. -These two can be combined: > - - :amenu File.Open :browse confirm edit<CR> - -The ":browse" makes a file browser appear to select the file to edit. The -":confirm" will pop up a dialog when the current buffer has changes. You can -then select to save the changes, throw them away or cancel the command. - For more complicated items, the confirm() and inputdialog() functions can -be used. The default menus contain a few examples. - -============================================================================== -*42.4* Toolbar and popup menus - -There are two special menus: ToolBar and PopUp. Items that start with these -names do not appear in the normal menu bar. - - -TOOLBAR - -The toolbar appears only when the "T" flag is included in the 'guioptions' -option. - The toolbar uses icons rather than text to represent the command. For -example, the {menu-item} named "ToolBar.New" causes the "New" icon to appear -on the toolbar. - The Vim editor has 28 built-in icons. You can find a table here: -|builtin-tools|. Most of them are used in the default toolbar. You can -redefine what these items do (after the default menus are setup). - You can add another bitmap for a toolbar item. Or define a new toolbar -item with a bitmap. For example, define a new toolbar item with: > - - :tmenu ToolBar.Compile Compile the current file - :amenu ToolBar.Compile :!cc % -o %:r<CR> - -Now you need to create the icon. For MS-Windows it must be in bitmap format, -with the name "Compile.bmp". For Unix XPM format is used, the file name is -"Compile.xpm". The size must be 18 by 18 pixels. On MS-Windows other sizes -can be used as well, but it will look ugly. - Put the bitmap in the directory "bitmaps" in one of the directories from -'runtimepath'. E.g., for Unix "~/.vim/bitmaps/Compile.xpm". - -You can define tooltips for the items in the toolbar. A tooltip is a short -text that explains what a toolbar item will do. For example "Open file". It -appears when the mouse pointer is on the item, without moving for a moment. -This is very useful if the meaning of the picture isn't that obvious. -Example: > - - :tmenu ToolBar.Make Run make in the current directory -< - Note: - Pay attention to the case used. "Toolbar" and "toolbar" are different - from "ToolBar"! - -To remove a tooltip, use the |:tunmenu| command. - -The 'toolbar' option can be used to display text instead of a bitmap, or both -text and a bitmap. Most people use just the bitmap, since the text takes -quite a bit of space. - - -POPUP MENU - -The popup menu pops up where the mouse pointer is. On MS-Windows you activate -it by clicking the right mouse button. Then you can select an item with the -left mouse button. On Unix the popup menu is used by pressing and holding the -right mouse button. - The popup menu only appears when the 'mousemodel' has been set to "popup" -or "popup_setpos". The difference between the two is that "popup_setpos" -moves the cursor to the mouse pointer position. When clicking inside a -selection, the selection will be used unmodified. When there is a selection -but you click outside of it, the selection is removed. - There is a separate popup menu for each mode. Thus there are never grey -items like in the normal menus. - -What is the meaning of life, the universe and everything? *42* -Douglas Adams, the only person who knew what this question really was about is -now dead, unfortunately. So now you might wonder what the meaning of death -is... - -============================================================================== - -Next chapter: |usr_43.txt| Using filetypes - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_43.txt b/share/vim/vim72/doc/usr_43.txt deleted file mode 100644 index 089f3c4bad..0000000000 --- a/share/vim/vim72/doc/usr_43.txt +++ /dev/null @@ -1,172 +0,0 @@ -*usr_43.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - VIM USER MANUAL - by Bram Moolenaar - - Using filetypes - - -When you are editing a file of a certain type, for example a C program or a -shell script, you often use the same option settings and mappings. You -quickly get tired of manually setting these each time. This chapter explains -how to do it automatically. - -|43.1| Plugins for a filetype -|43.2| Adding a filetype - - Next chapter: |usr_44.txt| Your own syntax highlighted - Previous chapter: |usr_42.txt| Add new menus -Table of contents: |usr_toc.txt| - -============================================================================== -*43.1* Plugins for a filetype *filetype-plugin* - -How to start using filetype plugins has already been discussed here: -|add-filetype-plugin|. But you probably are not satisfied with the default -settings, because they have been kept minimal. Suppose that for C files you -want to set the 'softtabstop' option to 4 and define a mapping to insert a -three-line comment. You do this with only two steps: - - *your-runtime-dir* -1. Create your own runtime directory. On Unix this usually is "~/.vim". In - this directory create the "ftplugin" directory: > - - mkdir ~/.vim - mkdir ~/.vim/ftplugin -< - When you are not on Unix, check the value of the 'runtimepath' option to - see where Vim will look for the "ftplugin" directory: > - - set runtimepath - -< You would normally use the first directory name (before the first comma). - You might want to prepend a directory name to the 'runtimepath' option in - your |vimrc| file if you don't like the default value. - -2. Create the file "~/.vim/ftplugin/c.vim", with the contents: > - - setlocal softtabstop=4 - noremap <buffer> <LocalLeader>c o/**************<CR><CR>/<Esc> - -Try editing a C file. You should notice that the 'softtabstop' option is set -to 4. But when you edit another file it's reset to the default zero. That is -because the ":setlocal" command was used. This sets the 'softtabstop' option -only locally to the buffer. As soon as you edit another buffer, it will be -set to the value set for that buffer. For a new buffer it will get the -default value or the value from the last ":set" command. - -Likewise, the mapping for "\c" will disappear when editing another buffer. -The ":map <buffer>" command creates a mapping that is local to the current -buffer. This works with any mapping command: ":map!", ":vmap", etc. The -|<LocalLeader>| in the mapping is replaced with the value of "maplocalleader". - -You can find examples for filetype plugins in this directory: > - - $VIMRUNTIME/ftplugin/ - -More details about writing a filetype plugin can be found here: -|write-plugin|. - -============================================================================== -*43.2* Adding a filetype - -If you are using a type of file that is not recognized by Vim, this is how to -get it recognized. You need a runtime directory of your own. See -|your-runtime-dir| above. - -Create a file "filetype.vim" which contains an autocommand for your filetype. -(Autocommands were explained in section |40.3|.) Example: > - - augroup filetypedetect - au BufNewFile,BufRead *.xyz setf xyz - augroup END - -This will recognize all files that end in ".xyz" as the "xyz" filetype. The -":augroup" commands put this autocommand in the "filetypedetect" group. This -allows removing all autocommands for filetype detection when doing ":filetype -off". The "setf" command will set the 'filetype' option to its argument, -unless it was set already. This will make sure that 'filetype' isn't set -twice. - -You can use many different patterns to match the name of your file. Directory -names can also be included. See |autocmd-patterns|. For example, the files -under "/usr/share/scripts/" are all "ruby" files, but don't have the expected -file name extension. Adding this to the example above: > - - augroup filetypedetect - au BufNewFile,BufRead *.xyz setf xyz - au BufNewFile,BufRead /usr/share/scripts/* setf ruby - augroup END - -However, if you now edit a file /usr/share/scripts/README.txt, this is not a -ruby file. The danger of a pattern ending in "*" is that it quickly matches -too many files. To avoid trouble with this, put the filetype.vim file in -another directory, one that is at the end of 'runtimepath'. For Unix for -example, you could use "~/.vim/after/filetype.vim". - You now put the detection of text files in ~/.vim/filetype.vim: > - - augroup filetypedetect - au BufNewFile,BufRead *.txt setf text - augroup END - -That file is found in 'runtimepath' first. Then use this in -~/.vim/after/filetype.vim, which is found last: > - - augroup filetypedetect - au BufNewFile,BufRead /usr/share/scripts/* setf ruby - augroup END - -What will happen now is that Vim searches for "filetype.vim" files in each -directory in 'runtimepath'. First ~/.vim/filetype.vim is found. The -autocommand to catch *.txt files is defined there. Then Vim finds the -filetype.vim file in $VIMRUNTIME, which is halfway 'runtimepath'. Finally -~/.vim/after/filetype.vim is found and the autocommand for detecting ruby -files in /usr/share/scripts is added. - When you now edit /usr/share/scripts/README.txt, the autocommands are -checked in the order in which they were defined. The *.txt pattern matches, -thus "setf text" is executed to set the filetype to "text". The pattern for -ruby matches too, and the "setf ruby" is executed. But since 'filetype' was -already set to "text", nothing happens here. - When you edit the file /usr/share/scripts/foobar the same autocommands are -checked. Only the one for ruby matches and "setf ruby" sets 'filetype' to -ruby. - - -RECOGNIZING BY CONTENTS - -If your file cannot be recognized by its file name, you might be able to -recognize it by its contents. For example, many script files start with a -line like: - - #!/bin/xyz ~ - -To recognize this script create a file "scripts.vim" in your runtime directory -(same place where filetype.vim goes). It might look like this: > - - if did_filetype() - finish - endif - if getline(1) =~ '^#!.*[/\\]xyz\>' - setf xyz - endif - -The first check with did_filetype() is to avoid that you will check the -contents of files for which the filetype was already detected by the file -name. That avoids wasting time on checking the file when the "setf" command -won't do anything. - The scripts.vim file is sourced by an autocommand in the default -filetype.vim file. Therefore, the order of checks is: - - 1. filetype.vim files before $VIMRUNTIME in 'runtimepath' - 2. first part of $VIMRUNTIME/filetype.vim - 3. all scripts.vim files in 'runtimepath' - 4. remainder of $VIMRUNTIME/filetype.vim - 5. filetype.vim files after $VIMRUNTIME in 'runtimepath' - -If this is not sufficient for you, add an autocommand that matches all files -and sources a script or executes a function to check the contents of the file. - -============================================================================== - -Next chapter: |usr_44.txt| Your own syntax highlighted - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_44.txt b/share/vim/vim72/doc/usr_44.txt deleted file mode 100644 index f5506b4cb8..0000000000 --- a/share/vim/vim72/doc/usr_44.txt +++ /dev/null @@ -1,719 +0,0 @@ -*usr_44.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - VIM USER MANUAL - by Bram Moolenaar - - Your own syntax highlighted - - -Vim comes with highlighting for a couple of hundred different file types. If -the file you are editing isn't included, read this chapter to find out how to -get this type of file highlighted. Also see |:syn-define| in the reference -manual. - -|44.1| Basic syntax commands -|44.2| Keywords -|44.3| Matches -|44.4| Regions -|44.5| Nested items -|44.6| Following groups -|44.7| Other arguments -|44.8| Clusters -|44.9| Including another syntax file -|44.10| Synchronizing -|44.11| Installing a syntax file -|44.12| Portable syntax file layout - - Next chapter: |usr_45.txt| Select your language - Previous chapter: |usr_43.txt| Using filetypes -Table of contents: |usr_toc.txt| - -============================================================================== -*44.1* Basic syntax commands - -Using an existing syntax file to start with will save you a lot of time. Try -finding a syntax file in $VIMRUNTIME/syntax for a language that is similar. -These files will also show you the normal layout of a syntax file. To -understand it, you need to read the following. - -Let's start with the basic arguments. Before we start defining any new -syntax, we need to clear out any old definitions: > - - :syntax clear - -This isn't required in the final syntax file, but very useful when -experimenting. - -There are more simplifications in this chapter. If you are writing a syntax -file to be used by others, read all the way through the end to find out the -details. - - -LISTING DEFINED ITEMS - -To check which syntax items are currently defined, use this command: > - - :syntax - -You can use this to check which items have actually been defined. Quite -useful when you are experimenting with a new syntax file. It also shows the -colors used for each item, which helps to find out what is what. - To list the items in a specific syntax group use: > - - :syntax list {group-name} - -This also can be used to list clusters (explained in |44.8|). Just include -the @ in the name. - - -MATCHING CASE - -Some languages are not case sensitive, such as Pascal. Others, such as C, are -case sensitive. You need to tell which type you have with the following -commands: > - :syntax case match - :syntax case ignore - -The "match" argument means that Vim will match the case of syntax elements. -Therefore, "int" differs from "Int" and "INT". If the "ignore" argument is -used, the following are equivalent: "Procedure", "PROCEDURE" and "procedure". - The ":syntax case" commands can appear anywhere in a syntax file and affect -the syntax definitions that follow. In most cases, you have only one ":syntax -case" command in your syntax file; if you work with an unusual language that -contains both case-sensitive and non-case-sensitive elements, however, you can -scatter the ":syntax case" command throughout the file. - -============================================================================== -*44.2* Keywords - -The most basic syntax elements are keywords. To define a keyword, use the -following form: > - - :syntax keyword {group} {keyword} ... - -The {group} is the name of a syntax group. With the ":highlight" command you -can assign colors to a {group}. The {keyword} argument is an actual keyword. -Here are a few examples: > - - :syntax keyword xType int long char - :syntax keyword xStatement if then else endif - -This example uses the group names "xType" and "xStatement". By convention, -each group name is prefixed by the filetype for the language being defined. -This example defines syntax for the x language (eXample language without an -interesting name). In a syntax file for "csh" scripts the name "cshType" -would be used. Thus the prefix is equal to the value of 'filetype'. - These commands cause the words "int", "long" and "char" to be highlighted -one way and the words "if", "then", "else" and "endif" to be highlighted -another way. Now you need to connect the x group names to standard Vim -names. You do this with the following commands: > - - :highlight link xType Type - :highlight link xStatement Statement - -This tells Vim to highlight "xType" like "Type" and "xStatement" like -"Statement". See |group-name| for the standard names. - - -UNUSUAL KEYWORDS - -The characters used in a keyword must be in the 'iskeyword' option. If you -use another character, the word will never match. Vim doesn't give a warning -message for this. - The x language uses the '-' character in keywords. This is how it's done: -> - :setlocal iskeyword+=- - :syntax keyword xStatement when-not - -The ":setlocal" command is used to change 'iskeyword' only for the current -buffer. Still it does change the behavior of commands like "w" and "*". If -that is not wanted, don't define a keyword but use a match (explained in the -next section). - -The x language allows for abbreviations. For example, "next" can be -abbreviated to "n", "ne" or "nex". You can define them by using this command: -> - :syntax keyword xStatement n[ext] - -This doesn't match "nextone", keywords always match whole words only. - -============================================================================== -*44.3* Matches - -Consider defining something a bit more complex. You want to match ordinary -identifiers. To do this, you define a match syntax item. This one matches -any word consisting of only lowercase letters: > - - :syntax match xIdentifier /\<\l\+\>/ -< - Note: - Keywords overrule any other syntax item. Thus the keywords "if", - "then", etc., will be keywords, as defined with the ":syntax keyword" - commands above, even though they also match the pattern for - xIdentifier. - -The part at the end is a pattern, like it's used for searching. The // is -used to surround the pattern (like how it's done in a ":substitute" command). -You can use any other character, like a plus or a quote. - -Now define a match for a comment. In the x language it is anything from # to -the end of a line: > - - :syntax match xComment /#.*/ - -Since you can use any search pattern, you can highlight very complex things -with a match item. See |pattern| for help on search patterns. - -============================================================================== -*44.4* Regions - -In the example x language, strings are enclosed in double quotation marks ("). -To highlight strings you define a region. You need a region start (double -quote) and a region end (double quote). The definition is as follows: > - - :syntax region xString start=/"/ end=/"/ - -The "start" and "end" directives define the patterns used to find the start -and end of the region. But what about strings that look like this? - - "A string with a double quote (\") in it" ~ - -This creates a problem: The double quotation marks in the middle of the string -will end the region. You need to tell Vim to skip over any escaped double -quotes in the string. Do this with the skip keyword: > - - :syntax region xString start=/"/ skip=/\\"/ end=/"/ - -The double backslash matches a single backslash, since the backslash is a -special character in search patterns. - -When to use a region instead of a match? The main difference is that a match -item is a single pattern, which must match as a whole. A region starts as -soon as the "start" pattern matches. Whether the "end" pattern is found or -not doesn't matter. Thus when the item depends on the "end" pattern to match, -you cannot use a region. Otherwise, regions are often simpler to define. And -it is easier to use nested items, as is explained in the next section. - -============================================================================== -*44.5* Nested items - -Take a look at this comment: - - %Get input TODO: Skip white space ~ - -You want to highlight TODO in big yellow letters, even though it is in a -comment that is highlighted blue. To let Vim know about this, you define the -following syntax groups: > - - :syntax keyword xTodo TODO contained - :syntax match xComment /%.*/ contains=xTodo - -In the first line, the "contained" argument tells Vim that this keyword can -exist only inside another syntax item. The next line has "contains=xTodo". -This indicates that the xTodo syntax element is inside it. The result is that -the comment line as a whole is matched with "xComment" and made blue. The -word TODO inside it is matched by xTodo and highlighted yellow (highlighting -for xTodo was setup for this). - - -RECURSIVE NESTING - -The x language defines code blocks in curly braces. And a code block may -contain other code blocks. This can be defined this way: > - - :syntax region xBlock start=/{/ end=/}/ contains=xBlock - -Suppose you have this text: - - while i < b { ~ - if a { ~ - b = c; ~ - } ~ - } ~ - -First a xBlock starts at the { in the first line. In the second line another -{ is found. Since we are inside a xBlock item, and it contains itself, a -nested xBlock item will start here. Thus the "b = c" line is inside the -second level xBlock region. Then a } is found in the next line, which matches -with the end pattern of the region. This ends the nested xBlock. Because the -} is included in the nested region, it is hidden from the first xBlock region. -Then at the last } the first xBlock region ends. - - -KEEPING THE END - -Consider the following two syntax items: > - - :syntax region xComment start=/%/ end=/$/ contained - :syntax region xPreProc start=/#/ end=/$/ contains=xComment - -You define a comment as anything from % to the end of the line. A -preprocessor directive is anything from # to the end of the line. Because you -can have a comment on a preprocessor line, the preprocessor definition -includes a "contains=xComment" argument. Now look what happens with this -text: - - #define X = Y % Comment text ~ - int foo = 1; ~ - -What you see is that the second line is also highlighted as xPreProc. The -preprocessor directive should end at the end of the line. That is why -you have used "end=/$/". So what is going wrong? - The problem is the contained comment. The comment starts with % and ends -at the end of the line. After the comment ends, the preprocessor syntax -continues. This is after the end of the line has been seen, so the next -line is included as well. - To avoid this problem and to avoid a contained syntax item eating a needed -end of line, use the "keepend" argument. This takes care of -the double end-of-line matching: > - - :syntax region xComment start=/%/ end=/$/ contained - :syntax region xPreProc start=/#/ end=/$/ contains=xComment keepend - - -CONTAINING MANY ITEMS - -You can use the contains argument to specify that everything can be contained. -For example: > - - :syntax region xList start=/\[/ end=/\]/ contains=ALL - -All syntax items will be contained in this one. It also contains itself, but -not at the same position (that would cause an endless loop). - You can specify that some groups are not contained. Thus contain all -groups but the ones that are listed: -> - :syntax region xList start=/\[/ end=/\]/ contains=ALLBUT,xString - -With the "TOP" item you can include all items that don't have a "contained" -argument. "CONTAINED" is used to only include items with a "contained" -argument. See |:syn-contains| for the details. - -============================================================================== -*44.6* Following groups - -The x language has statements in this form: - - if (condition) then ~ - -You want to highlight the three items differently. But "(condition)" and -"then" might also appear in other places, where they get different -highlighting. This is how you can do this: > - - :syntax match xIf /if/ nextgroup=xIfCondition skipwhite - :syntax match xIfCondition /([^)]*)/ contained nextgroup=xThen skipwhite - :syntax match xThen /then/ contained - -The "nextgroup" argument specifies which item can come next. This is not -required. If none of the items that are specified are found, nothing happens. -For example, in this text: - - if not (condition) then ~ - -The "if" is matched by xIf. "not" doesn't match the specified nextgroup -xIfCondition, thus only the "if" is highlighted. - -The "skipwhite" argument tells Vim that white space (spaces and tabs) may -appear in between the items. Similar arguments are "skipnl", which allows a -line break in between the items, and "skipempty", which allows empty lines. -Notice that "skipnl" doesn't skip an empty line, something must match after -the line break. - -============================================================================== -*44.7* Other arguments - -MATCHGROUP - -When you define a region, the entire region is highlighted according to the -group name specified. To highlight the text enclosed in parentheses () with -the group xInside, for example, use the following command: > - - :syntax region xInside start=/(/ end=/)/ - -Suppose, that you want to highlight the parentheses differently. You can do -this with a lot of convoluted region statements, or you can use the -"matchgroup" argument. This tells Vim to highlight the start and end of a -region with a different highlight group (in this case, the xParen group): > - - :syntax region xInside matchgroup=xParen start=/(/ end=/)/ - -The "matchgroup" argument applies to the start or end match that comes after -it. In the previous example both start and end are highlighted with xParen. -To highlight the end with xParenEnd: > - - :syntax region xInside matchgroup=xParen start=/(/ - \ matchgroup=xParenEnd end=/)/ - -A side effect of using "matchgroup" is that contained items will not match in -the start or end of the region. The example for "transparent" uses this. - - -TRANSPARENT - -In a C language file you would like to highlight the () text after a "while" -differently from the () text after a "for". In both of these there can be -nested () items, which should be highlighted in the same way. You must make -sure the () highlighting stops at the matching ). This is one way to do this: -> - :syntax region cWhile matchgroup=cWhile start=/while\s*(/ end=/)/ - \ contains=cCondNest - :syntax region cFor matchgroup=cFor start=/for\s*(/ end=/)/ - \ contains=cCondNest - :syntax region cCondNest start=/(/ end=/)/ contained transparent - -Now you can give cWhile and cFor different highlighting. The cCondNest item -can appear in either of them, but take over the highlighting of the item it is -contained in. The "transparent" argument causes this. - Notice that the "matchgroup" argument has the same group as the item -itself. Why define it then? Well, the side effect of using a matchgroup is -that contained items are not found in the match with the start item then. -This avoids that the cCondNest group matches the ( just after the "while" or -"for". If this would happen, it would span the whole text until the matching -) and the region would continue after it. Now cCondNest only matches after -the match with the start pattern, thus after the first (. - - -OFFSETS - -Suppose you want to define a region for the text between ( and ) after an -"if". But you don't want to include the "if" or the ( and ). You can do this -by specifying offsets for the patterns. Example: > - - :syntax region xCond start=/if\s*(/ms=e+1 end=/)/me=s-1 - -The offset for the start pattern is "ms=e+1". "ms" stands for Match Start. -This defines an offset for the start of the match. Normally the match starts -where the pattern matches. "e+1" means that the match now starts at the end -of the pattern match, and then one character further. - The offset for the end pattern is "me=s-1". "me" stands for Match End. -"s-1" means the start of the pattern match and then one character back. The -result is that in this text: - - if (foo == bar) ~ - -Only the text "foo == bar" will be highlighted as xCond. - -More about offsets here: |:syn-pattern-offset|. - - -ONELINE - -The "oneline" argument indicates that the region does not cross a line -boundary. For example: > - - :syntax region xIfThen start=/if/ end=/then/ oneline - -This defines a region that starts at "if" and ends at "then". But if there is -no "then" after the "if", the region doesn't match. - - Note: - When using "oneline" the region doesn't start if the end pattern - doesn't match in the same line. Without "oneline" Vim does _not_ - check if there is a match for the end pattern. The region starts even - when the end pattern doesn't match in the rest of the file. - - -CONTINUATION LINES AND AVOIDING THEM - -Things now become a little more complex. Let's define a preprocessor line. -This starts with a # in the first column and continues until the end of the -line. A line that ends with \ makes the next line a continuation line. The -way you handle this is to allow the syntax item to contain a continuation -pattern: > - - :syntax region xPreProc start=/^#/ end=/$/ contains=xLineContinue - :syntax match xLineContinue "\\$" contained - -In this case, although xPreProc normally matches a single line, the group -contained in it (namely xLineContinue) lets it go on for more than one line. -For example, it would match both of these lines: - - #define SPAM spam spam spam \ ~ - bacon and spam ~ - -In this case, this is what you want. If it is not what you want, you can call -for the region to be on a single line by adding "excludenl" to the contained -pattern. For example, you want to highlight "end" in xPreProc, but only at -the end of the line. To avoid making the xPreProc continue on the next line, -like xLineContinue does, use "excludenl" like this: > - - :syntax region xPreProc start=/^#/ end=/$/ - \ contains=xLineContinue,xPreProcEnd - :syntax match xPreProcEnd excludenl /end$/ contained - :syntax match xLineContinue "\\$" contained - -"excludenl" must be placed before the pattern. Since "xLineContinue" doesn't -have "excludenl", a match with it will extend xPreProc to the next line as -before. - -============================================================================== -*44.8* Clusters - -One of the things you will notice as you start to write a syntax file is that -you wind up generating a lot of syntax groups. Vim enables you to define a -collection of syntax groups called a cluster. - Suppose you have a language that contains for loops, if statements, while -loops, and functions. Each of them contains the same syntax elements: numbers -and identifiers. You define them like this: > - - :syntax match xFor /^for.*/ contains=xNumber,xIdent - :syntax match xIf /^if.*/ contains=xNumber,xIdent - :syntax match xWhile /^while.*/ contains=xNumber,xIdent - -You have to repeat the same "contains=" every time. If you want to add -another contained item, you have to add it three times. Syntax clusters -simplify these definitions by enabling you to have one cluster stand for -several syntax groups. - To define a cluster for the two items that the three groups contain, use -the following command: > - - :syntax cluster xState contains=xNumber,xIdent - -Clusters are used inside other syntax items just like any syntax group. -Their names start with @. Thus, you can define the three groups like this: > - - :syntax match xFor /^for.*/ contains=@xState - :syntax match xIf /^if.*/ contains=@xState - :syntax match xWhile /^while.*/ contains=@xState - -You can add new group names to this cluster with the "add" argument: > - - :syntax cluster xState add=xString - -You can remove syntax groups from this list as well: > - - :syntax cluster xState remove=xNumber - -============================================================================== -*44.9* Including another syntax file - -The C++ language syntax is a superset of the C language. Because you do not -want to write two syntax files, you can have the C++ syntax file read in the -one for C by using the following command: > - - :runtime! syntax/c.vim - -The ":runtime!" command searches 'runtimepath' for all "syntax/c.vim" files. -This makes the C syntax be defined like for C files. If you have replaced the -c.vim syntax file, or added items with an extra file, these will be loaded as -well. - After loading the C syntax items the specific C++ items can be defined. -For example, add keywords that are not used in C: > - - :syntax keyword cppStatement new delete this friend using - -This works just like in any other syntax file. - -Now consider the Perl language. It consists of two distinct parts: a -documentation section in POD format, and a program written in Perl itself. -The POD section starts with "=head" and ends with "=cut". - You want to define the POD syntax in one file, and use it from the Perl -syntax file. The ":syntax include" command reads in a syntax file and stores -the elements it defined in a syntax cluster. For Perl, the statements are as -follows: > - - :syntax include @Pod <sfile>:p:h/pod.vim - :syntax region perlPOD start=/^=head/ end=/^=cut/ contains=@Pod - -When "=head" is found in a Perl file, the perlPOD region starts. In this -region the @Pod cluster is contained. All the items defined as top-level -items in the pod.vim syntax files will match here. When "=cut" is found, the -region ends and we go back to the items defined in the Perl file. - The ":syntax include" command is clever enough to ignore a ":syntax clear" -command in the included file. And an argument such as "contains=ALL" will -only contain items defined in the included file, not in the file that includes -it. - The "<sfile>:p:h/" part uses the name of the current file (<sfile>), -expands it to a full path (:p) and then takes the head (:h). This results in -the directory name of the file. This causes the pod.vim file in the same -directory to be included. - -============================================================================== -*44.10* Synchronizing - -Compilers have it easy. They start at the beginning of a file and parse it -straight through. Vim does not have it so easy. It must start in the middle, -where the editing is being done. So how does it tell where it is? - The secret is the ":syntax sync" command. This tells Vim how to figure out -where it is. For example, the following command tells Vim to scan backward -for the beginning or end of a C-style comment and begin syntax coloring from -there: > - - :syntax sync ccomment - -You can tune this processing with some arguments. The "minlines" argument -tells Vim the minimum number of lines to look backward, and "maxlines" tells -the editor the maximum number of lines to scan. - For example, the following command tells Vim to look at least 10 lines -before the top of the screen: > - - :syntax sync ccomment minlines=10 maxlines=500 - -If it cannot figure out where it is in that space, it starts looking farther -and farther back until it figures out what to do. But it looks no farther -back than 500 lines. (A large "maxlines" slows down processing. A small one -might cause synchronization to fail.) - To make synchronizing go a bit faster, tell Vim which syntax items can be -skipped. Every match and region that only needs to be used when actually -displaying text can be given the "display" argument. - By default, the comment to be found will be colored as part of the Comment -syntax group. If you want to color things another way, you can specify a -different syntax group: > - - :syntax sync ccomment xAltComment - -If your programming language does not have C-style comments in it, you can try -another method of synchronization. The simplest way is to tell Vim to space -back a number of lines and try to figure out things from there. The following -command tells Vim to go back 150 lines and start parsing from there: > - - :syntax sync minlines=150 - -A large "minlines" value can make Vim slower, especially when scrolling -backwards in the file. - Finally, you can specify a syntax group to look for by using this command: -> - :syntax sync match {sync-group-name} - \ grouphere {group-name} {pattern} - -This tells Vim that when it sees {pattern} the syntax group named {group-name} -begins just after the pattern given. The {sync-group-name} is used to give a -name to this synchronization specification. For example, the sh scripting -language begins an if statement with "if" and ends it with "fi": - - if [ --f file.txt ] ; then ~ - echo "File exists" ~ - fi ~ - -To define a "grouphere" directive for this syntax, you use the following -command: > - - :syntax sync match shIfSync grouphere shIf "\<if\>" - -The "groupthere" argument tells Vim that the pattern ends a group. For -example, the end of the if/fi group is as follows: > - - :syntax sync match shIfSync groupthere NONE "\<fi\>" - -In this example, the NONE tells Vim that you are not in any special syntax -region. In particular, you are not inside an if block. - -You also can define matches and regions that are with no "grouphere" or -"groupthere" arguments. These groups are for syntax groups skipped during -synchronization. For example, the following skips over anything inside {}, -even if it would normally match another synchronization method: > - - :syntax sync match xSpecial /{.*}/ - -More about synchronizing in the reference manual: |:syn-sync|. - -============================================================================== -*44.11* Installing a syntax file - -When your new syntax file is ready to be used, drop it in a "syntax" directory -in 'runtimepath'. For Unix that would be "~/.vim/syntax". - The name of the syntax file must be equal to the file type, with ".vim" -added. Thus for the x language, the full path of the file would be: - - ~/.vim/syntax/x.vim ~ - -You must also make the file type be recognized. See |43.2|. - -If your file works well, you might want to make it available to other Vim -users. First read the next section to make sure your file works well for -others. Then e-mail it to the Vim maintainer: <maintainer@vim.org>. Also -explain how the filetype can be detected. With a bit of luck your file will -be included in the next Vim version! - - -ADDING TO AN EXISTING SYNTAX FILE - -We were assuming you were adding a completely new syntax file. When an existing -syntax file works, but is missing some items, you can add items in a separate -file. That avoids changing the distributed syntax file, which will be lost -when installing a new version of Vim. - Write syntax commands in your file, possibly using group names from the -existing syntax. For example, to add new variable types to the C syntax file: -> - :syntax keyword cType off_t uint - -Write the file with the same name as the original syntax file. In this case -"c.vim". Place it in a directory near the end of 'runtimepath'. This makes -it loaded after the original syntax file. For Unix this would be: - - ~/.vim/after/syntax/c.vim ~ - -============================================================================== -*44.12* Portable syntax file layout - -Wouldn't it be nice if all Vim users exchange syntax files? To make this -possible, the syntax file must follow a few guidelines. - -Start with a header that explains what the syntax file is for, who maintains -it and when it was last updated. Don't include too much information about -changes history, not many people will read it. Example: > - - " Vim syntax file - " Language: C - " Maintainer: Bram Moolenaar <Bram@vim.org> - " Last Change: 2001 Jun 18 - " Remark: Included by the C++ syntax. - -Use the same layout as the other syntax files. Using an existing syntax file -as an example will save you a lot of time. - -Choose a good, descriptive name for your syntax file. Use lowercase letters -and digits. Don't make it too long, it is used in many places: The name of -the syntax file "name.vim", 'filetype', b:current_syntax the start of each -syntax group (nameType, nameStatement, nameString, etc). - -Start with a check for "b:current_syntax". If it is defined, some other -syntax file, earlier in 'runtimepath' was already loaded: > - - if exists("b:current_syntax") - finish - endif - -To be compatible with Vim 5.8 use: > - - if version < 600 - syntax clear - elseif exists("b:current_syntax") - finish - endif - -Set "b:current_syntax" to the name of the syntax at the end. Don't forget -that included files do this too, you might have to reset "b:current_syntax" if -you include two files. - -If you want your syntax file to work with Vim 5.x, add a check for v:version. -See yacc.vim for an example. - -Do not include anything that is a user preference. Don't set 'tabstop', -'expandtab', etc. These belong in a filetype plugin. - -Do not include mappings or abbreviations. Only include setting 'iskeyword' if -it is really necessary for recognizing keywords. - -To allow users select their own preferred colors, make a different group name -for every kind of highlighted item. Then link each of them to one of the -standard highlight groups. That will make it work with every color scheme. -If you select specific colors it will look bad with some color schemes. And -don't forget that some people use a different background color, or have only -eight colors available. - -For the linking use "hi def link", so that the user can select different -highlighting before your syntax file is loaded. Example: > - - hi def link nameString String - hi def link nameNumber Number - hi def link nameCommand Statement - ... etc ... - -Add the "display" argument to items that are not used when syncing, to speed -up scrolling backwards and CTRL-L. - -============================================================================== - -Next chapter: |usr_45.txt| Select your language - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_45.txt b/share/vim/vim72/doc/usr_45.txt deleted file mode 100644 index 42a11b4862..0000000000 --- a/share/vim/vim72/doc/usr_45.txt +++ /dev/null @@ -1,419 +0,0 @@ -*usr_45.txt* For Vim version 7.2. Last change: 2008 Apr 30 - - VIM USER MANUAL - by Bram Moolenaar - - Select your language - - -The messages in Vim can be given in several languages. This chapter explains -how to change which one is used. Also, the different ways to work with files -in various languages is explained. - -|45.1| Language for Messages -|45.2| Language for Menus -|45.3| Using another encoding -|45.4| Editing files with a different encoding -|45.5| Entering language text - - Next chapter: |usr_90.txt| Installing Vim - Previous chapter: |usr_44.txt| Your own syntax highlighted -Table of contents: |usr_toc.txt| - -============================================================================== -*45.1* Language for Messages - -When you start Vim, it checks the environment to find out what language you -are using. Mostly this should work fine, and you get the messages in your -language (if they are available). To see what the current language is, use -this command: > - - :language - -If it replies with "C", this means the default is being used, which is -English. - - Note: - Using different languages only works when Vim was compiled to handle - it. To find out if it works, use the ":version" command and check the - output for "+gettext" and "+multi_lang". If they are there, you are - OK. If you see "-gettext" or "-multi_lang" you will have to find - another Vim. - -What if you would like your messages in a different language? There are -several ways. Which one you should use depends on the capabilities of your -system. - The first way is to set the environment to the desired language before -starting Vim. Example for Unix: > - - env LANG=de_DE.ISO_8859-1 vim - -This only works if the language is available on your system. The advantage is -that all the GUI messages and things in libraries will use the right language -as well. A disadvantage is that you must do this before starting Vim. If you -want to change language while Vim is running, you can use the second method: > - - :language fr_FR.ISO_8859-1 - -This way you can try out several names for your language. You will get an -error message when it's not supported on your system. You don't get an error -when translated messages are not available. Vim will silently fall back to -using English. - To find out which languages are supported on your system, find the -directory where they are listed. On my system it is "/usr/share/locale". On -some systems it's in "/usr/lib/locale". The manual page for "setlocale" -should give you a hint where it is found on your system. - Be careful to type the name exactly as it should be. Upper and lowercase -matter, and the '-' and '_' characters are easily confused. - -You can also set the language separately for messages, edited text and the -time format. See |:language|. - - -DO-IT-YOURSELF MESSAGE TRANSLATION - -If translated messages are not available for your language, you could write -them yourself. To do this, get the source code for Vim and the GNU gettext -package. After unpacking the sources, instructions can be found in the -directory src/po/README.txt. - It's not too difficult to do the translation. You don't need to be a -programmer. You must know both English and the language you are translating -to, of course. - When you are satisfied with the translation, consider making it available -to others. Upload it at vim-online (http://vim.sf.net) or e-mail it to -the Vim maintainer <maintainer@vim.org>. Or both. - -============================================================================== -*45.2* Language for Menus - -The default menus are in English. To be able to use your local language, they -must be translated. Normally this is automatically done for you if the -environment is set for your language, just like with messages. You don't need -to do anything extra for this. But it only works if translations for the -language are available. - Suppose you are in Germany, with the language set to German, but prefer to -use "File" instead of "Datei". You can switch back to using the English menus -this way: > - - :set langmenu=none - -It is also possible to specify a language: > - - :set langmenu=nl_NL.ISO_8859-1 - -Like above, differences between "-" and "_" matter. However, upper/lowercase -differences are ignored here. - The 'langmenu' option must be set before the menus are loaded. Once the -menus have been defined changing 'langmenu' has no direct effect. Therefore, -put the command to set 'langmenu' in your vimrc file. - If you really want to switch menu language while running Vim, you can do it -this way: > - - :source $VIMRUNTIME/delmenu.vim - :set langmenu=de_DE.ISO_8859-1 - :source $VIMRUNTIME/menu.vim - -There is one drawback: All menus that you defined yourself will be gone. You -will need to redefine them as well. - - -DO-IT-YOURSELF MENU TRANSLATION - -To see which menu translations are available, look in this directory: - - $VIMRUNTIME/lang ~ - -The files are called menu_{language}.vim. If you don't see the language you -want to use, you can do your own translations. The simplest way to do this is -by copying one of the existing language files, and change it. - First find out the name of your language with the ":language" command. Use -this name, but with all letters made lowercase. Then copy the file to your -own runtime directory, as found early in 'runtimepath'. For example, for Unix -you would do: > - - :!cp $VIMRUNTIME/lang/menu_ko_kr.euckr.vim ~/.vim/lang/menu_nl_be.iso_8859-1.vim - -You will find hints for the translation in "$VIMRUNTIME/lang/README.txt". - -============================================================================== -*45.3* Using another encoding - -Vim guesses that the files you are going to edit are encoded for your -language. For many European languages this is "latin1". Then each byte is -one character. That means there are 256 different characters possible. For -Asian languages this is not sufficient. These mostly use a double-byte -encoding, providing for over ten thousand possible characters. This still -isn't enough when a text is to contain several different languages. This is -where Unicode comes in. It was designed to include all characters used in -commonly used languages. This is the "Super encoding that replaces all -others". But it isn't used that much yet. - Fortunately, Vim supports these three kinds of encodings. And, with some -restrictions, you can use them even when your environment uses another -language than the text. - Nevertheless, when you only edit files that are in the encoding of your -language, the default should work fine and you don't need to do anything. The -following is only relevant when you want to edit different languages. - - Note: - Using different encodings only works when Vim was compiled to handle - it. To find out if it works, use the ":version" command and check the - output for "+multi_byte". If it's there, you are OK. If you see - "-multi_byte" you will have to find another Vim. - - -USING UNICODE IN THE GUI - -The nice thing about Unicode is that other encodings can be converted to it -and back without losing information. When you make Vim use Unicode -internally, you will be able to edit files in any encoding. - Unfortunately, the number of systems supporting Unicode is still limited. -Thus it's unlikely that your language uses it. You need to tell Vim you want -to use Unicode, and how to handle interfacing with the rest of the system. - Let's start with the GUI version of Vim, which is able to display Unicode -characters. This should work: > - - :set encoding=utf-8 - :set guifont=-misc-fixed-medium-r-normal--18-120-100-100-c-90-iso10646-1 - -The 'encoding' option tells Vim the encoding of the characters that you use. -This applies to the text in buffers (files you are editing), registers, Vim -script files, etc. You can regard 'encoding' as the setting for the internals -of Vim. - This example assumes you have this font on your system. The name in the -example is for the X Window System. This font is in a package that is used to -enhance xterm with Unicode support. If you don't have this font, you might -find it here: - - http://www.cl.cam.ac.uk/~mgk25/download/ucs-fonts.tar.gz ~ - -For MS-Windows, some fonts have a limited number of Unicode characters. Try -using the "Courier New" font. You can use the Edit/Select Font... menu to -select and try out the fonts available. Only fixed-width fonts can be used -though. Example: > - - :set guifont=courier_new:h12 - -If it doesn't work well, try getting a fontpack. If Microsoft didn't move it, -you can find it here: - - http://www.microsoft.com/typography/fonts/default.aspx ~ - -Now you have told Vim to use Unicode internally and display text with a -Unicode font. Typed characters still arrive in the encoding of your original -language. This requires converting them to Unicode. Tell Vim the language -from which to convert with the 'termencoding' option. You can do it like -this: > - - :let &termencoding = &encoding - :set encoding=utf-8 - -This assigns the old value of 'encoding' to 'termencoding' before setting -'encoding' to utf-8. You will have to try out if this really works for your -setup. It should work especially well when using an input method for an Asian -language, and you want to edit Unicode text. - - -USING UNICODE IN A UNICODE TERMINAL - -There are terminals that support Unicode directly. The standard xterm that -comes with XFree86 is one of them. Let's use that as an example. - First of all, the xterm must have been compiled with Unicode support. See -|UTF8-xterm| how to check that and how to compile it when needed. - Start the xterm with the "-u8" argument. You might also need so specify a -font. Example: > - - xterm -u8 -fn -misc-fixed-medium-r-normal--18-120-100-100-c-90-iso10646-1 - -Now you can run Vim inside this terminal. Set 'encoding' to "utf-8" as -before. That's all. - - -USING UNICODE IN AN ORDINARY TERMINAL - -Suppose you want to work with Unicode files, but don't have a terminal with -Unicode support. You can do this with Vim, although characters that are not -supported by the terminal will not be displayed. The layout of the text -will be preserved. > - - :let &termencoding = &encoding - :set encoding=utf-8 - -This is the same as what was used for the GUI. But it works differently: Vim -will convert the displayed text before sending it to the terminal. That -avoids that the display is messed up with strange characters. - For this to work the conversion between 'termencoding' and 'encoding' must -be possible. Vim will convert from latin1 to Unicode, thus that always works. -For other conversions the |+iconv| feature is required. - Try editing a file with Unicode characters in it. You will notice that Vim -will put a question mark (or underscore or some other character) in places -where a character should be that the terminal can't display. Move the cursor -to a question mark and use this command: > - - ga - -Vim will display a line with the code of the character. This gives you a hint -about what character it is. You can look it up in a Unicode table. You could -actually view a file that way, if you have lots of time at hand. - - Note: - Since 'encoding' is used for all text inside Vim, changing it makes - all non-ASCII text invalid. You will notice this when using registers - and the 'viminfo' file (e.g., a remembered search pattern). It's - recommended to set 'encoding' in your vimrc file, and leave it alone. - -============================================================================== -*45.4* Editing files with a different encoding - -Suppose you have setup Vim to use Unicode, and you want to edit a file that is -in 16-bit Unicode. Sounds simple, right? Well, Vim actually uses utf-8 -encoding internally, thus the 16-bit encoding must be converted. Thus there -is a difference between the character set (Unicode) and the encoding (utf-8 or -16-bit). - Vim will try to detect what kind of file you are editing. It uses the -encoding names in the 'fileencodings' option. When using Unicode, the default -value is: "ucs-bom,utf-8,latin1". This means that Vim checks the file to see -if it's one of these encodings: - - ucs-bom File must start with a Byte Order Mark (BOM). This - allows detection of 16-bit, 32-bit and utf-8 Unicode - encodings. - utf-8 utf-8 Unicode. This is rejected when a sequence of - bytes is illegal in utf-8. - latin1 The good old 8-bit encoding. Always works. - -When you start editing that 16-bit Unicode file, and it has a BOM, Vim will -detect this and convert the file to utf-8 when reading it. The 'fileencoding' -option (without s at the end) is set to the detected value. In this case it -is "ucs-2le". That means it's Unicode, two bytes and little-endian. This -file format is common on MS-Windows (e.g., for registry files). - When writing the file, Vim will compare 'fileencoding' with 'encoding'. If -they are different, the text will be converted. - An empty value for 'fileencoding' means that no conversion is to be done. -Thus the text is assumed to be encoded with 'encoding'. - -If the default 'fileencodings' value is not good for you, set it to the -encodings you want Vim to try. Only when a value is found to be invalid will -the next one be used. Putting "latin1" first doesn't work, because it is -never illegal. An example, to fall back to Japanese when the file doesn't -have a BOM and isn't utf-8: > - - :set fileencodings=ucs-bom,utf-8,sjis - -See |encoding-values| for suggested values. Other values may work as well. -This depends on the conversion available. - - -FORCING AN ENCODING - -If the automatic detection doesn't work you must tell Vim what encoding the -file is. Example: > - - :edit ++enc=koi8-r russian.txt - -The "++enc" part specifies the name of the encoding to be used for this file -only. Vim will convert the file from the specified encoding, Russian in this -example, to 'encoding'. 'fileencoding' will also be set to the specified -encoding, so that the reverse conversion can be done when writing the file. - The same argument can be used when writing the file. This way you can -actually use Vim to convert a file. Example: > - - :write ++enc=utf-8 russian.txt -< - Note: - Conversion may result in lost characters. Conversion from an encoding - to Unicode and back is mostly free of this problem, unless there are - illegal characters. Conversion from Unicode to other encodings often - loses information when there was more than one language in the file. - -============================================================================== -*45.5* Entering language text - -Computer keyboards don't have much more than a hundred keys. Some languages -have thousands of characters, Unicode has ten thousands. So how do you type -these characters? - First of all, when you don't use too many of the special characters, you -can use digraphs. This was already explained in |24.9|. - When you use a language that uses many more characters than keys on your -keyboard, you will want to use an Input Method (IM). This requires learning -the translation from typed keys to resulting character. When you need an IM -you probably already have one on your system. It should work with Vim like -with other programs. For details see |mbyte-XIM| for the X Window system and -|mbyte-IME| for MS-Windows. - - -KEYMAPS - -For some languages the character set is different from latin, but uses a -similar number of characters. It's possible to map keys to characters. Vim -uses keymaps for this. - Suppose you want to type Hebrew. You can load the keymap like this: > - - :set keymap=hebrew - -Vim will try to find a keymap file for you. This depends on the value of -'encoding'. If no matching file was found, you will get an error message. - -Now you can type Hebrew in Insert mode. In Normal mode, and when typing a ":" -command, Vim automatically switches to English. You can use this command to -switch between Hebrew and English: > - - CTRL-^ - -This only works in Insert mode and Command-line mode. In Normal mode it does -something completely different (jumps to alternate file). - The usage of the keymap is indicated in the mode message, if you have the -'showmode' option set. In the GUI Vim will indicate the usage of keymaps with -a different cursor color. - You can also change the usage of the keymap with the 'iminsert' and -'imsearch' options. - -To see the list of mappings, use this command: > - - :lmap - -To find out which keymap files are available, in the GUI you can use the -Edit/Keymap menu. Otherwise you can use this command: > - - :echo globpath(&rtp, "keymap/*.vim") - - -DO-IT-YOURSELF KEYMAPS - -You can create your own keymap file. It's not very difficult. Start with -a keymap file that is similar to the language you want to use. Copy it to the -"keymap" directory in your runtime directory. For example, for Unix, you -would use the directory "~/.vim/keymap". - The name of the keymap file must look like this: - - keymap/{name}.vim ~ -or - keymap/{name}_{encoding}.vim ~ - -{name} is the name of the keymap. Chose a name that is obvious, but different -from existing keymaps (unless you want to replace an existing keymap file). -{name} cannot contain an underscore. Optionally, add the encoding used after -an underscore. Examples: - - keymap/hebrew.vim ~ - keymap/hebrew_utf-8.vim ~ - -The contents of the file should be self-explanatory. Look at a few of the -keymaps that are distributed with Vim. For the details, see |mbyte-keymap|. - - -LAST RESORT - -If all other methods fail, you can enter any character with CTRL-V: - - encoding type range ~ - 8-bit CTRL-V 123 decimal 0-255 - 8-bit CTRL-V x a1 hexadecimal 00-ff - 16-bit CTRL-V u 013b hexadecimal 0000-ffff - 31-bit CTRL-V U 001303a4 hexadecimal 00000000-7fffffff - -Don't type the spaces. See |i_CTRL-V_digit| for the details. - -============================================================================== - -Next chapter: |usr_90.txt| Installing Vim - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_90.txt b/share/vim/vim72/doc/usr_90.txt deleted file mode 100644 index 6701fe9428..0000000000 --- a/share/vim/vim72/doc/usr_90.txt +++ /dev/null @@ -1,498 +0,0 @@ -*usr_90.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - VIM USER MANUAL - by Bram Moolenaar - - Installing Vim - - *install* -Before you can use Vim you have to install it. Depending on your system it's -simple or easy. This chapter gives a few hints and also explains how -upgrading to a new version is done. - -|90.1| Unix -|90.2| MS-Windows -|90.3| Upgrading -|90.4| Common installation issues -|90.5| Uninstalling Vim - - Previous chapter: |usr_45.txt| Select your language -Table of contents: |usr_toc.txt| - -============================================================================== -*90.1* Unix - -First you have to decide if you are going to install Vim system-wide or for a -single user. The installation is almost the same, but the directory where Vim -is installed in differs. - For a system-wide installation the base directory "/usr/local" is often -used. But this may be different for your system. Try finding out where other -packages are installed. - When installing for a single user, you can use your home directory as the -base. The files will be placed in subdirectories like "bin" and "shared/vim". - - -FROM A PACKAGE - -You can get precompiled binaries for many different UNIX systems. There is a -long list with links on this page: - - http://www.vim.org/binaries.html ~ - -Volunteers maintain the binaries, so they are often out of date. It is a -good idea to compile your own UNIX version from the source. Also, creating -the editor from the source allows you to control which features are compiled. -This does require a compiler though. - -If you have a Linux distribution, the "vi" program is probably a minimal -version of Vim. It doesn't do syntax highlighting, for example. Try finding -another Vim package in your distribution, or search on the web site. - - -FROM SOURCES - -To compile and install Vim, you will need the following: - - - A C compiler (GCC preferred) - - The GZIP program (you can get it from www.gnu.org) - - The Vim source and runtime archives - -To get the Vim archives, look in this file for a mirror near you, this should -provide the fastest download: - - ftp://ftp.vim.org/pub/vim/MIRRORS ~ - -Or use the home site ftp.vim.org, if you think it's fast enough. Go to the -"unix" directory and you'll find a list of files there. The version number is -embedded in the file name. You will want to get the most recent version. - You can get the files for Unix in two ways: One big archive that contains -everything, or four smaller ones that each fit on a floppy disk. For version -6.1 the single big one is called: - - vim-6.1.tar.bz2 ~ - -You need the bzip2 program to uncompress it. If you don't have it, get the -four smaller files, which can be uncompressed with gzip. For Vim 6.1 they are -called: - - vim-6.1-src1.tar.gz ~ - vim-6.1-src2.tar.gz ~ - vim-6.1-rt1.tar.gz ~ - vim-6.1-rt2.tar.gz ~ - - -COMPILING - -First create a top directory to work in, for example: > - - mkdir ~/vim - cd ~/vim - -Then unpack the archives there. If you have the one big archive, you unpack -it like this: > - - bzip2 -d -c path/vim-6.1.tar.bz2 | tar xf - - -Change "path" to where you have downloaded the file. > - - gzip -d -c path/vim-6.1-src1.tar.gz | tar xf - - gzip -d -c path/vim-6.1-src2.tar.gz | tar xf - - gzip -d -c path/vim-6.1-rt1.tar.gz | tar xf - - gzip -d -c path/vim-6.1-rt2.tar.gz | tar xf - - -If you are satisfied with getting the default features, and your environment -is setup properly, you should be able to compile Vim with just this: > - - cd vim61/src - make - -The make program will run configure and compile everything. Further on we -will explain how to compile with different features. - If there are errors while compiling, carefully look at the error messages. -There should be a hint about what went wrong. Hopefully you will be able to -correct it. You might have to disable some features to make Vim compile. -Look in the Makefile for specific hints for your system. - - -TESTING - -Now you can check if compiling worked OK: > - - make test - -This will run a sequence of test scripts to verify that Vim works as expected. -Vim will be started many times and all kinds of text and messages flash by. -If it is alright you will finally see: - - test results: ~ - ALL DONE ~ - -If there are one or two messages about failed tests, Vim might still work, but -not perfectly. If you see a lot of error messages or Vim doesn't finish until -the end, there must be something wrong. Either try to find out yourself, or -find someone who can solve it. You could look in the |maillist-archive| for a -solution. If everything else fails, you could ask in the vim |maillist| if -someone can help you. - - -INSTALLING - *install-home* -If you want to install in your home directory, edit the Makefile and search -for a line: - - #prefix = $(HOME) ~ - -Remove the # at the start of the line. - When installing for the whole system, Vim has most likely already selected -a good installation directory for you. You can also specify one, see below. -You need to become root for the following. - -To install Vim do: > - - make install - -That should move all the relevant files to the right place. Now you can try -running vim to verify that it works. Use two simple tests to check if Vim can -find its runtime files: > - - :help - :syntax enable - -If this doesn't work, use this command to check where Vim is looking for the -runtime files: > - - :echo $VIMRUNTIME - -You can also start Vim with the "-V" argument to see what happens during -startup: > - - vim -V - -Don't forget that the user manual assumes you Vim in a certain way. After -installing Vim, follow the instructions at |not-compatible| to make Vim work -as assumed in this manual. - - -SELECTING FEATURES - -Vim has many ways to select features. One of the simple ways is to edit the -Makefile. There are many directions and examples. Often you can enable or -disable a feature by uncommenting a line. - An alternative is to run "configure" separately. This allows you to -specify configuration options manually. The disadvantage is that you have to -figure out what exactly to type. - Some of the most interesting configure arguments follow. These can also be -enabled from the Makefile. - - --prefix={directory} Top directory where to install Vim. - - --with-features=tiny Compile with many features disabled. - --with-features=small Compile with some features disabled. - --with-features=big Compile with more features enabled. - --with-features=huge Compile with most features enabled. - See |+feature-list| for which feature - is enabled in which case. - - --enable-perlinterp Enable the Perl interface. There are - similar arguments for ruby, python and - tcl. - - --disable-gui Do not compile the GUI interface. - --without-x Do not compile X-windows features. - When both of these are used, Vim will - not connect to the X server, which - makes startup faster. - -To see the whole list use: > - - ./configure --help - -You can find a bit of explanation for each feature, and links for more -information here: |feature-list|. - For the adventurous, edit the file "feature.h". You can also change the -source code yourself! - -============================================================================== -*90.2* MS-Windows - -There are two ways to install the Vim program for Microsoft Windows. You can -uncompress several archives, or use a self-installing big archive. Most users -with fairly recent computers will prefer the second method. For the first -one, you will need: - - - An archive with binaries for Vim. - - The Vim runtime archive. - - A program to unpack the zip files. - -To get the Vim archives, look in this file for a mirror near you, this should -provide the fastest download: - - ftp://ftp.vim.org/pub/vim/MIRRORS ~ - -Or use the home site ftp.vim.org, if you think it's fast enough. Go to the -"pc" directory and you'll find a list of files there. The version number is -embedded in the file name. You will want to get the most recent version. -We will use "61" here, which is version 6.1. - - gvim61.exe The self-installing archive. - -This is all you need for the second method. Just launch the executable, and -follow the prompts. - -For the first method you must chose one of the binary archives. These are -available: - - gvim61.zip The normal MS-Windows GUI version. - gvim61ole.zip The MS-Windows GUI version with OLE support. - Uses more memory, supports interfacing with - other OLE applications. - vim61w32.zip 32 bit MS-Windows console version. For use in - a Win NT/2000/XP console. Does not work well - on Win 95/98. - vim61d32.zip 32 bit MS-DOS version. For use in the - Win 95/98 console window. - vim61d16.zip 16 bit MS-DOS version. Only for old systems. - Does not support long filenames. - -You only need one of them. Although you could install both a GUI and a -console version. You always need to get the archive with runtime files. - - vim61rt.zip The runtime files. - -Use your un-zip program to unpack the files. For example, using the "unzip" -program: > - - cd c:\ - unzip path\gvim61.zip - unzip path\vim61rt.zip - -This will unpack the files in the directory "c:\vim\vim61". If you already -have a "vim" directory somewhere, you will want to move to the directory just -above it. - Now change to the "vim\vim61" directory and run the install program: > - - install - -Carefully look through the messages and select the options you want to use. -If you finally select "do it" the install program will carry out the actions -you selected. - The install program doesn't move the runtime files. They remain where you -unpacked them. - -In case you are not satisfied with the features included in the supplied -binaries, you could try compiling Vim yourself. Get the source archive from -the same location as where the binaries are. You need a compiler for which a -makefile exists. Microsoft Visual C works, but is expensive. The Free -Borland command-line compiler 5.5 can be used, as well as the free MingW and -Cygwin compilers. Check the file src/INSTALLpc.txt for hints. - -============================================================================== -*90.3* Upgrading - -If you are running one version of Vim and want to install another, here is -what to do. - - -UNIX - -When you type "make install" the runtime files will be copied to a directory -which is specific for this version. Thus they will not overwrite a previous -version. This makes it possible to use two or more versions next to -each other. - The executable "vim" will overwrite an older version. If you don't care -about keeping the old version, running "make install" will work fine. You can -delete the old runtime files manually. Just delete the directory with the -version number in it and all files below it. Example: > - - rm -rf /usr/local/share/vim/vim58 - -There are normally no changed files below this directory. If you did change -the "filetype.vim" file, for example, you better merge the changes into the -new version before deleting it. - -If you are careful and want to try out the new version for a while before -switching to it, install the new version under another name. You need to -specify a configure argument. For example: > - - ./configure --with-vim-name=vim6 - -Before running "make install", you could use "make -n install" to check that -no valuable existing files are overwritten. - When you finally decide to switch to the new version, all you need to do is -to rename the binary to "vim". For example: > - - mv /usr/local/bin/vim6 /usr/local/bin/vim - - -MS-WINDOWS - -Upgrading is mostly equal to installing a new version. Just unpack the files -in the same place as the previous version. A new directory will be created, -e.g., "vim61", for the files of the new version. Your runtime files, vimrc -file, viminfo, etc. will be left alone. - If you want to run the new version next to the old one, you will have to do -some handwork. Don't run the install program, it will overwrite a few files -of the old version. Execute the new binaries by specifying the full path. -The program should be able to automatically find the runtime files for the -right version. However, this won't work if you set the $VIMRUNTIME variable -somewhere. - If you are satisfied with the upgrade, you can delete the files of the -previous version. See |90.5|. - -============================================================================== -*90.4* Common installation issues - -This section describes some of the common problems that occur when installing -Vim and suggests some solutions. It also contains answers to many -installation questions. - - -Q: I Do Not Have Root Privileges. How Do I Install Vim? (Unix) - -Use the following configuration command to install Vim in a directory called -$HOME/vim: > - - ./configure --prefix=$HOME - -This gives you a personal copy of Vim. You need to put $HOME/bin in your -path to execute the editor. Also see |install-home|. - - -Q: The Colors Are Not Right on My Screen. (Unix) - -Check your terminal settings by using the following command in a shell: > - - echo $TERM - -If the terminal type listed is not correct, fix it. For more hints, see -|06.2|. Another solution is to always use the GUI version of Vim, called -gvim. This avoids the need for a correct terminal setup. - - -Q: My Backspace And Delete Keys Don't Work Right - -The definition of what key sends what code is very unclear for backspace <BS> -and Delete <Del> keys. First of all, check your $TERM setting. If there is -nothing wrong with it, try this: > - - :set t_kb=^V<BS> - :set t_kD=^V<Del> - -In the first line you need to press CTRL-V and then hit the backspace key. -In the second line you need to press CTRL-V and then hit the Delete key. -You can put these lines in your vimrc file, see |05.1|. A disadvantage is -that it won't work when you use another terminal some day. Look here for -alternate solutions: |:fixdel|. - - -Q: I Am Using RedHat Linux. Can I Use the Vim That Comes with the System? - -By default RedHat installs a minimal version of Vim. Check your RPM packages -for something named "Vim-enhanced-version.rpm" and install that. - - -Q: How Do I Turn Syntax Coloring On? How do I make plugins work? - -Use the example vimrc script. You can find an explanation on how to use it -here: |not-compatible|. - -See chapter 6 for information about syntax highlighting: |usr_06.txt|. - - -Q: What Is a Good vimrc File to Use? - -See the www.vim.org Web site for several good examples. - - -Q: Where Do I Find a Good Vim Plugin? - -See the Vim-online site: http://vim.sf.net. Many users have uploaded useful -Vim scripts and plugins there. - - -Q: Where Do I Find More Tips? - -See the Vim-online site: http://vim.sf.net. There is an archive with hints -from Vim users. You might also want to search in the |maillist-archive|. - -============================================================================== -*90.5* Uninstalling Vim - -In the unlikely event you want to uninstall Vim completely, this is how you do -it. - - -UNIX - -When you installed Vim as a package, check your package manager to find out -how to remove the package again. - If you installed Vim from sources you can use this command: > - - make uninstall - -However, if you have deleted the original files or you used an archive that -someone supplied, you can't do this. Do delete the files manually, here is an -example for when "/usr/local" was used as the root: > - - rm -rf /usr/local/share/vim/vim61 - rm /usr/local/bin/eview - rm /usr/local/bin/evim - rm /usr/local/bin/ex - rm /usr/local/bin/gview - rm /usr/local/bin/gvim - rm /usr/local/bin/gvim - rm /usr/local/bin/gvimdiff - rm /usr/local/bin/rgview - rm /usr/local/bin/rgvim - rm /usr/local/bin/rview - rm /usr/local/bin/rvim - rm /usr/local/bin/rvim - rm /usr/local/bin/view - rm /usr/local/bin/vim - rm /usr/local/bin/vimdiff - rm /usr/local/bin/vimtutor - rm /usr/local/bin/xxd - rm /usr/local/man/man1/eview.1 - rm /usr/local/man/man1/evim.1 - rm /usr/local/man/man1/ex.1 - rm /usr/local/man/man1/gview.1 - rm /usr/local/man/man1/gvim.1 - rm /usr/local/man/man1/gvimdiff.1 - rm /usr/local/man/man1/rgview.1 - rm /usr/local/man/man1/rgvim.1 - rm /usr/local/man/man1/rview.1 - rm /usr/local/man/man1/rvim.1 - rm /usr/local/man/man1/view.1 - rm /usr/local/man/man1/vim.1 - rm /usr/local/man/man1/vimdiff.1 - rm /usr/local/man/man1/vimtutor.1 - rm /usr/local/man/man1/xxd.1 - - -MS-WINDOWS - -If you installed Vim with the self-installing archive you can run -the "uninstall-gui" program located in the same directory as the other Vim -programs, e.g. "c:\vim\vim61". You can also launch it from the Start menu if -installed the Vim entries there. This will remove most of the files, menu -entries and desktop shortcuts. Some files may remain however, as they need a -Windows restart before being deleted. - You will be given the option to remove the whole "vim" directory. It -probably contains your vimrc file and other runtime files that you created, so -be careful. - -Else, if you installed Vim with the zip archives, the preferred way is to use -the "uninstal" program (note the missing l at the end). You can find it in -the same directory as the "install" program, e.g., "c:\vim\vim61". This -should also work from the usual "install/remove software" page. - However, this only removes the registry entries for Vim. You have to -delete the files yourself. Simply select the directory "vim\vim61" and delete -it recursively. There should be no files there that you changed, but you -might want to check that first. - The "vim" directory probably contains your vimrc file and other runtime -files that you created. You might want to keep that. - -============================================================================== - -Table of contents: |usr_toc.txt| - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/usr_toc.txt b/share/vim/vim72/doc/usr_toc.txt deleted file mode 100644 index 6f5ea48791..0000000000 --- a/share/vim/vim72/doc/usr_toc.txt +++ /dev/null @@ -1,353 +0,0 @@ -*usr_toc.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - VIM USER MANUAL - by Bram Moolenaar - - Table Of Contents *user-manual* - -============================================================================== -Overview ~ - -Getting Started -|usr_01.txt| About the manuals -|usr_02.txt| The first steps in Vim -|usr_03.txt| Moving around -|usr_04.txt| Making small changes -|usr_05.txt| Set your settings -|usr_06.txt| Using syntax highlighting -|usr_07.txt| Editing more than one file -|usr_08.txt| Splitting windows -|usr_09.txt| Using the GUI -|usr_10.txt| Making big changes -|usr_11.txt| Recovering from a crash -|usr_12.txt| Clever tricks - -Editing Effectively -|usr_20.txt| Typing command-line commands quickly -|usr_21.txt| Go away and come back -|usr_22.txt| Finding the file to edit -|usr_23.txt| Editing other files -|usr_24.txt| Inserting quickly -|usr_25.txt| Editing formatted text -|usr_26.txt| Repeating -|usr_27.txt| Search commands and patterns -|usr_28.txt| Folding -|usr_29.txt| Moving through programs -|usr_30.txt| Editing programs -|usr_31.txt| Exploiting the GUI -|usr_32.txt| The undo tree - -Tuning Vim -|usr_40.txt| Make new commands -|usr_41.txt| Write a Vim script -|usr_42.txt| Add new menus -|usr_43.txt| Using filetypes -|usr_44.txt| Your own syntax highlighted -|usr_45.txt| Select your language - -Making Vim Run -|usr_90.txt| Installing Vim - - -Reference manual -|reference_toc| More detailed information for all commands - -The user manual is available as a single, ready to print HTML and PDF file -here: - http://vimdoc.sf.net - -============================================================================== -Getting Started ~ - -Read this from start to end to learn the essential commands. - -|usr_01.txt| About the manuals - |01.1| Two manuals - |01.2| Vim installed - |01.3| Using the Vim tutor - |01.4| Copyright - -|usr_02.txt| The first steps in Vim - |02.1| Running Vim for the First Time - |02.2| Inserting text - |02.3| Moving around - |02.4| Deleting characters - |02.5| Undo and Redo - |02.6| Other editing commands - |02.7| Getting out - |02.8| Finding help - -|usr_03.txt| Moving around - |03.1| Word movement - |03.2| Moving to the start or end of a line - |03.3| Moving to a character - |03.4| Matching a paren - |03.5| Moving to a specific line - |03.6| Telling where you are - |03.7| Scrolling around - |03.8| Simple searches - |03.9| Simple search patterns - |03.10| Using marks - -|usr_04.txt| Making small changes - |04.1| Operators and motions - |04.2| Changing text - |04.3| Repeating a change - |04.4| Visual mode - |04.5| Moving text - |04.6| Copying text - |04.7| Using the clipboard - |04.8| Text objects - |04.9| Replace mode - |04.10| Conclusion - -|usr_05.txt| Set your settings - |05.1| The vimrc file - |05.2| The example vimrc file explained - |05.3| Simple mappings - |05.4| Adding a plugin - |05.5| Adding a help file - |05.6| The option window - |05.7| Often used options - -|usr_06.txt| Using syntax highlighting - |06.1| Switching it on - |06.2| No or wrong colors? - |06.3| Different colors - |06.4| With colors or without colors - |06.5| Printing with colors - |06.6| Further reading - -|usr_07.txt| Editing more than one file - |07.1| Edit another file - |07.2| A list of files - |07.3| Jumping from file to file - |07.4| Backup files - |07.5| Copy text between files - |07.6| Viewing a file - |07.7| Changing the file name - -|usr_08.txt| Splitting windows - |08.1| Split a window - |08.2| Split a window on another file - |08.3| Window size - |08.4| Vertical splits - |08.5| Moving windows - |08.6| Commands for all windows - |08.7| Viewing differences with vimdiff - |08.8| Various - -|usr_09.txt| Using the GUI - |09.1| Parts of the GUI - |09.2| Using the mouse - |09.3| The clipboard - |09.4| Select mode - -|usr_10.txt| Making big changes - |10.1| Record and playback commands - |10.2| Substitution - |10.3| Command ranges - |10.4| The global command - |10.5| Visual block mode - |10.6| Reading and writing part of a file - |10.7| Formatting text - |10.8| Changing case - |10.9| Using an external program - -|usr_11.txt| Recovering from a crash - |11.1| Basic recovery - |11.2| Where is the swap file? - |11.3| Crashed or not? - |11.4| Further reading - -|usr_12.txt| Clever tricks - |12.1| Replace a word - |12.2| Change "Last, First" to "First Last" - |12.3| Sort a list - |12.4| Reverse line order - |12.5| Count words - |12.6| Find a man page - |12.7| Trim blanks - |12.8| Find where a word is used - -============================================================================== -Editing Effectively ~ - -Subjects that can be read independently. - -|usr_20.txt| Typing command-line commands quickly - |20.1| Command line editing - |20.2| Command line abbreviations - |20.3| Command line completion - |20.4| Command line history - |20.5| Command line window - -|usr_21.txt| Go away and come back - |21.1| Suspend and resume - |21.2| Executing shell commands - |21.3| Remembering information; viminfo - |21.4| Sessions - |21.5| Views - |21.6| Modelines - -|usr_22.txt| Finding the file to edit - |22.1| The file explorer - |22.2| The current directory - |22.3| Finding a file - |22.4| The buffer list - -|usr_23.txt| Editing other files - |23.1| DOS, Mac and Unix files - |23.2| Files on the internet - |23.3| Encryption - |23.4| Binary files - |23.5| Compressed files - -|usr_24.txt| Inserting quickly - |24.1| Making corrections - |24.2| Showing matches - |24.3| Completion - |24.4| Repeating an insert - |24.5| Copying from another line - |24.6| Inserting a register - |24.7| Abbreviations - |24.8| Entering special characters - |24.9| Digraphs - |24.10| Normal mode commands - -|usr_25.txt| Editing formatted text - |25.1| Breaking lines - |25.2| Aligning text - |25.3| Indents and tabs - |25.4| Dealing with long lines - |25.5| Editing tables - -|usr_26.txt| Repeating - |26.1| Repeating with Visual mode - |26.2| Add and subtract - |26.3| Making a change in many files - |26.4| Using Vim from a shell script - -|usr_27.txt| Search commands and patterns - |27.1| Ignoring case - |27.2| Wrapping around the file end - |27.3| Offsets - |27.4| Matching multiple times - |27.5| Alternatives - |27.6| Character ranges - |27.7| Character classes - |27.8| Matching a line break - |27.9| Examples - -|usr_28.txt| Folding - |28.1| What is folding? - |28.2| Manual folding - |28.3| Working with folds - |28.4| Saving and restoring folds - |28.5| Folding by indent - |28.6| Folding with markers - |28.7| Folding by syntax - |28.8| Folding by expression - |28.9| Folding unchanged lines - |28.10| Which fold method to use? - -|usr_29.txt| Moving through programs - |29.1| Using tags - |29.2| The preview window - |29.3| Moving through a program - |29.4| Finding global identifiers - |29.5| Finding local identifiers - -|usr_30.txt| Editing programs - |30.1| Compiling - |30.2| Indenting C files - |30.3| Automatic indenting - |30.4| Other indenting - |30.5| Tabs and spaces - |30.6| Formatting comments - -|usr_31.txt| Exploiting the GUI - |31.1| The file browser - |31.2| Confirmation - |31.3| Menu shortcuts - |31.4| Vim window position and size - |31.5| Various - -|usr_32.txt| The undo tree - |32.1| Numbering changes - |32.2| Jumping around the tree - |32.3| Time travelling - -============================================================================== -Tuning Vim ~ - -Make Vim work as you like it. - -|usr_40.txt| Make new commands - |40.1| Key mapping - |40.2| Defining command-line commands - |40.3| Autocommands - -|usr_41.txt| Write a Vim script - |41.1| Introduction - |41.2| Variables - |41.3| Expressions - |41.4| Conditionals - |41.5| Executing an expression - |41.6| Using functions - |41.7| Defining a function - |41.8| Lists and Dictionaries - |41.9| Exceptions - |41.10| Various remarks - |41.11| Writing a plugin - |41.12| Writing a filetype plugin - |41.13| Writing a compiler plugin - |41.14| Writing a plugin that loads quickly - |41.15| Writing library scripts - |41.16| Distributing Vim scripts - -|usr_42.txt| Add new menus - |42.1| Introduction - |42.2| Menu commands - |42.3| Various - |42.4| Toolbar and popup menus - -|usr_43.txt| Using filetypes - |43.1| Plugins for a filetype - |43.2| Adding a filetype - -|usr_44.txt| Your own syntax highlighted - |44.1| Basic syntax commands - |44.2| Keywords - |44.3| Matches - |44.4| Regions - |44.5| Nested items - |44.6| Following groups - |44.7| Other arguments - |44.8| Clusters - |44.9| Including another syntax file - |44.10| Synchronizing - |44.11| Installing a syntax file - |44.12| Portable syntax file layout - -|usr_45.txt| Select your language - |45.1| Language for Messages - |45.2| Language for Menus - |45.3| Using another encoding - |45.4| Editing files with a different encoding - |45.5| Entering language text - -============================================================================== -Making Vim Run ~ - -Before you can use Vim. - -|usr_90.txt| Installing Vim - |90.1| Unix - |90.2| MS-Windows - |90.3| Upgrading - |90.4| Common installation issues - |90.5| Uninstalling Vim - -============================================================================== - -Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/various.txt b/share/vim/vim72/doc/various.txt deleted file mode 100644 index cf4b0c6bcd..0000000000 --- a/share/vim/vim72/doc/various.txt +++ /dev/null @@ -1,868 +0,0 @@ -*various.txt* For Vim version 7.2. Last change: 2008 Aug 06 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Various commands *various* - -1. Various commands |various-cmds| -2. Online help |online-help| -3. Using Vim like less or more |less| - -============================================================================== -1. Various commands *various-cmds* - - *CTRL-L* -CTRL-L Clear and redraw the screen. The redraw may happen - later, after processing typeahead. - - *:redr* *:redraw* -:redr[aw][!] Redraw the screen right now. When ! is included it is - cleared first. - Useful to update the screen halfway executing a script - or function. Also when halfway a mapping and - 'lazyredraw' is set. - - *:redraws* *:redrawstatus* -:redraws[tatus][!] Redraw the status line of the current window. When ! - is included all status lines are redrawn. - Useful to update the status line(s) when 'statusline' - includes an item that doesn't cause automatic - updating. - - *N<Del>* -<Del> When entering a number: Remove the last digit. - Note: if you like to use <BS> for this, add this - mapping to your .vimrc: > - :map CTRL-V <BS> CTRL-V <Del> -< See |:fixdel| if your <Del> key does not do what you - want. - -:as[cii] or *ga* *:as* *:ascii* -ga Print the ascii value of the character under the - cursor in decimal, hexadecimal and octal. For - example, when the cursor is on a 'R': - <R> 82, Hex 52, Octal 122 ~ - When the character is a non-standard ASCII character, - but printable according to the 'isprint' option, the - non-printable version is also given. When the - character is larger than 127, the <M-x> form is also - printed. For example: - <~A> <M-^A> 129, Hex 81, Octal 201 ~ - <p> <|~> <M-~> 254, Hex fe, Octal 376 ~ - (where <p> is a special character) - The <Nul> character in a file is stored internally as - <NL>, but it will be shown as: - <^@> 0, Hex 00, Octal 000 ~ - If the character has composing characters these are - also shown. The value of 'maxcombine' doesn't matter. - Mnemonic: Get Ascii value. {not in Vi} - - *g8* -g8 Print the hex values of the bytes used in the - character under the cursor, assuming it is in |UTF-8| - encoding. This also shows composing characters. The - value of 'maxcombine' doesn't matter. - Example of a character with two composing characters: - e0 b8 81 + e0 b8 b9 + e0 b9 89 ~ - {not in Vi} {only when compiled with the |+multi_byte| - feature} - - *8g8* -8g8 Find an illegal UTF-8 byte sequence at or after the - cursor. This works in two situations: - 1. when 'encoding' is any 8-bit encoding - 2. when 'encoding' is "utf-8" and 'fileencoding' is - any 8-bit encoding - Thus it can be used when editing a file that was - supposed to be UTF-8 but was read as if it is an 8-bit - encoding because it contains illegal bytes. - Does not wrap around the end of the file. - Note that when the cursor is on an illegal byte or the - cursor is halfway a multi-byte character the command - won't move the cursor. - {not in Vi} {only when compiled with the |+multi_byte| - feature} - - *:p* *:pr* *:print* *E749* -:[range]p[rint] [flags] - Print [range] lines (default current line). - Note: If you are looking for a way to print your text - on paper see |:hardcopy|. In the GUI you can use the - File.Print menu entry. - See |ex-flags| for [flags]. - -:[range]p[rint] {count} [flags] - Print {count} lines, starting with [range] (default - current line |cmdline-ranges|). - See |ex-flags| for [flags]. - - *:P* *:Print* -:[range]P[rint] [count] [flags] - Just as ":print". Was apparently added to Vi for - people that keep the shift key pressed too long... - See |ex-flags| for [flags]. - - *:l* *:list* -:[range]l[ist] [count] [flags] - Same as :print, but display unprintable characters - with '^' and put $ after the line. - See |ex-flags| for [flags]. - - *:nu* *:number* -:[range]nu[mber] [count] [flags] - Same as :print, but precede each line with its line - number. (See also 'highlight' and 'numberwidth' - option). - See |ex-flags| for [flags]. - - *:#* -:[range]# [count] [flags] - synonym for :number. - - *:#!* -:#!{anything} Ignored, so that you can start a Vim script with: > - #!vim -S - echo "this is a Vim script" - quit -< - *:z* *E144* -:{range}z[+-^.=]{count} Display several lines of text surrounding the line - specified with {range}, or around the current line - if there is no {range}. If there is a {count}, that's - how many lines you'll see; if there is only one window - then the 'window' option is used, otherwise the - current window size is used. - - :z can be used either alone or followed by any of - several punctuation marks. These have the following - effect: - - mark first line last line new location ~ - ---- ---------- --------- ------------ - + current line 1 scr forward 1 scr forward - - 1 scr back current line current line - ^ 2 scr back 1 scr back 1 scr back - . 1/2 scr back 1/2 scr fwd 1/2 scr fwd - = 1/2 scr back 1/2 scr fwd current line - - Specifying no mark at all is the same as "+". - If the mark is "=", a line of dashes is printed - around the current line. - -:{range}z#[+-^.=]{count} *:z#* - Like ":z", but number the lines. - {not in all versions of Vi, not with these arguments} - - *:=* -:= [flags] Print the last line number. - See |ex-flags| for [flags]. - -:{range}= [flags] Prints the last line number in {range}. For example, - this prints the current line number: > - :.= -< See |ex-flags| for [flags]. - -:norm[al][!] {commands} *:norm* *:normal* - Execute Normal mode commands {commands}. This makes - it possible to execute Normal mode commands typed on - the command-line. {commands} is executed like it is - typed. For undo all commands are undone together. - Execution stops when an error is encountered. - If the [!] is given, mappings will not be used. - {commands} should be a complete command. If - {commands} does not finish a command, the last one - will be aborted as if <Esc> or <C-C> was typed. - The display isn't updated while ":normal" is busy. - This implies that an insert command must be completed - (to start Insert mode, see |:startinsert|). A ":" - command must be completed as well. And you can't use - "Q" or "gQ" to start Ex mode. - {commands} cannot start with a space. Put a 1 (one) - before it, 1 space is one space. - The 'insertmode' option is ignored for {commands}. - This command cannot be followed by another command, - since any '|' is considered part of the command. - This command can be used recursively, but the depth is - limited by 'maxmapdepth'. - When this command is called from a non-remappable - mapping |:noremap|, the argument can be mapped anyway. - An alternative is to use |:execute|, which uses an - expression as argument. This allows the use of - printable characters. Example: > - :exe "normal \<c-w>\<c-w>" -< {not in Vi, of course} - {not available when the |+ex_extra| feature was - disabled at compile time} - -:{range}norm[al][!] {commands} *:normal-range* - Execute Normal mode commands {commands} for each line - in the {range}. Before executing the {commands}, the - cursor is positioned in the first column of the range, - for each line. Otherwise it's the same as the - ":normal" command without a range. - {not in Vi} - Not available when |+ex_extra| feature was disabled at - compile time. - - *:sh* *:shell* *E371* -:sh[ell] This command starts a shell. When the shell exits - (after the "exit" command) you return to Vim. The - name for the shell command comes from 'shell' option. - *E360* - Note: This doesn't work when Vim on the Amiga was - started in QuickFix mode from a compiler, because the - compiler will have set stdin to a non-interactive - mode. - - *:!cmd* *:!* *E34* -:!{cmd} Execute {cmd} with the shell. See also the 'shell' - and 'shelltype' option. - Any '!' in {cmd} is replaced with the previous - external command (see also 'cpoptions'). But not when - there is a backslash before the '!', then that - backslash is removed. Example: ":!ls" followed by - ":!echo ! \! \\!" executes "echo ls ! \!". - After the command has been executed, the timestamp of - the current file is checked |timestamp|. - A '|' in {cmd} is passed to the shell, you cannot use - it to append a Vim command. See |:bar|. - A newline character ends {cmd}, what follows is - interpreted as a following ":" command. However, if - there is a backslash before the newline it is removed - and {cmd} continues. It doesn't matter how many - backslashes are before the newline, only one is - removed. - On Unix the command normally runs in a non-interactive - shell. If you want an interactive shell to be used - (to use aliases) set 'shellcmdflag' to "-ic". - For Win32 also see |:!start|. - Vim redraws the screen after the command is finished, - because it may have printed any text. This requires a - hit-enter prompt, so that you can read any messages. - To avoid this use: > - :silent !{cmd} -< The screen is not redrawn then, thus you have to use - CTRL-L or ":redraw!" if the command did display - something. - Also see |shell-window|. - - *:!!* -:!! Repeat last ":!{cmd}". - - *:ve* *:version* -:ve[rsion] Print the version number of the editor. If the - compiler used understands "__DATE__" the compilation - date is mentioned. Otherwise a fixed release-date is - shown. - The following lines contain information about which - features were enabled when Vim was compiled. When - there is a preceding '+', the feature is included, - when there is a '-' it is excluded. To change this, - you have to edit feature.h and recompile Vim. - To check for this in an expression, see |has()|. - Here is an overview of the features. - The first column shows the smallest version in which - they are included: - T tiny - S small - N normal - B big - H huge - m manually enabled or depends on other features - (none) system dependent - Thus if a feature is marked with "N", it is included - in the normal, big and huge versions of Vim. - - *+feature-list* - *+ARP* Amiga only: ARP support included -B *+arabic* |Arabic| language support -N *+autocmd* |:autocmd|, automatic commands -m *+balloon_eval* |balloon-eval| support. Included when compiling with - supported GUI (Motif, GTK, GUI) and either - Netbeans/Sun Workshop integration or |+eval| feature. -N *+browse* |:browse| command -N *+builtin_terms* some terminals builtin |builtin-terms| -B *++builtin_terms* maximal terminals builtin |builtin-terms| -N *+byte_offset* support for 'o' flag in 'statusline' option, "go" - and ":goto" commands. -N *+cindent* |'cindent'|, C indenting -N *+clientserver* Unix and Win32: Remote invocation |clientserver| - *+clipboard* |clipboard| support -N *+cmdline_compl* command line completion |cmdline-completion| -N *+cmdline_hist* command line history |cmdline-history| -N *+cmdline_info* |'showcmd'| and |'ruler'| -N *+comments* |'comments'| support -N *+cryptv* encryption support |encryption| -B *+cscope* |cscope| support -m *+cursorshape* |termcap-cursor-shape| support -m *+debug* Compiled for debugging. -N *+dialog_gui* Support for |:confirm| with GUI dialog. -N *+dialog_con* Support for |:confirm| with console dialog. -N *+dialog_con_gui* Support for |:confirm| with GUI and console dialog. -N *+diff* |vimdiff| and 'diff' -N *+digraphs* |digraphs| *E196* - *+dnd* Support for DnD into the "~ register |quote_~|. -B *+emacs_tags* |emacs-tags| files -N *+eval* expression evaluation |eval.txt| -N *+ex_extra* Vim's extra Ex commands: |:center|, |:left|, - |:normal|, |:retab| and |:right| -N *+extra_search* |'hlsearch'| and |'incsearch'| options. -B *+farsi* |farsi| language -N *+file_in_path* |gf|, |CTRL-W_f| and |<cfile>| -N *+find_in_path* include file searches: |[I|, |:isearch|, - |CTRL-W_CTRL-I|, |:checkpath|, etc. -N *+folding* |folding| - *+footer* |gui-footer| - *+fork* Unix only: |fork| shell commands - *+float* Floating point support -N *+gettext* message translations |multi-lang| - *+GUI_Athena* Unix only: Athena |GUI| - *+GUI_neXtaw* Unix only: neXtaw |GUI| - *+GUI_GTK* Unix only: GTK+ |GUI| - *+GUI_Motif* Unix only: Motif |GUI| - *+GUI_Photon* QNX only: Photon |GUI| -m *+hangul_input* Hangul input support |hangul| - *+iconv* Compiled with the |iconv()| function - *+iconv/dyn* Likewise |iconv-dynamic| |/dyn| -N *+insert_expand* |insert_expand| Insert mode completion -N *+jumplist* |jumplist| -B *+keymap* |'keymap'| -B *+langmap* |'langmap'| -N *+libcall* |libcall()| -N *+linebreak* |'linebreak'|, |'breakat'| and |'showbreak'| -N *+lispindent* |'lisp'| -N *+listcmds* Vim commands for the list of buffers |buffer-hidden| - and argument list |:argdelete| -N *+localmap* Support for mappings local to a buffer |:map-local| -N *+menu* |:menu| -N *+mksession* |:mksession| -N *+modify_fname* |filename-modifiers| -N *+mouse* Mouse handling |mouse-using| -N *+mouseshape* |'mouseshape'| -B *+mouse_dec* Unix only: Dec terminal mouse handling |dec-mouse| -N *+mouse_gpm* Unix only: Linux console mouse handling |gpm-mouse| -B *+mouse_netterm* Unix only: netterm mouse handling |netterm-mouse| -N *+mouse_pterm* QNX only: pterm mouse handling |qnx-terminal| -N *+mouse_sysmouse* Unix only: *BSD console mouse handling |sysmouse| -N *+mouse_xterm* Unix only: xterm mouse handling |xterm-mouse| -B *+multi_byte* Korean and other languages |multibyte| - *+multi_byte_ime* Win32 input method for multibyte chars |multibyte-ime| -N *+multi_lang* non-English language support |multi-lang| -m *+mzscheme* Mzscheme interface |mzscheme| -m *+mzscheme/dyn* Mzscheme interface |mzscheme-dynamic| |/dyn| -m *+netbeans_intg* |netbeans| -m *+ole* Win32 GUI only: |ole-interface| - *+osfiletype* Support for the 'osfiletype' option and filetype - checking in automatic commands. |autocmd-osfiletypes| -N *+path_extra* Up/downwards search in 'path' and 'tags' -m *+perl* Perl interface |perl| -m *+perl/dyn* Perl interface |perl-dynamic| |/dyn| - *+postscript* |:hardcopy| writes a PostScript file -N *+printer* |:hardcopy| command -H *+profile* |:profile| command -m *+python* Python interface |python| -m *+python/dyn* Python interface |python-dynamic| |/dyn| -N *+quickfix* |:make| and |quickfix| commands -N *+reltime* |reltime()| function, 'hlsearch'/'incsearch' timeout, - 'redrawtime' option -B *+rightleft* Right to left typing |'rightleft'| -m *+ruby* Ruby interface |ruby| -m *+ruby/dyn* Ruby interface |ruby-dynamic| |/dyn| -N *+scrollbind* |'scrollbind'| -B *+signs* |:sign| -N *+smartindent* |'smartindent'| -m *+sniff* SniFF interface |sniff| -N *+statusline* Options 'statusline', 'rulerformat' and special - formats of 'titlestring' and 'iconstring' -m *+sun_workshop* |workshop| -N *+syntax* Syntax highlighting |syntax| - *+system()* Unix only: opposite of |+fork| -N *+tag_binary* binary searching in tags file |tag-binary-search| -N *+tag_old_static* old method for static tags |tag-old-static| -m *+tag_any_white* any white space allowed in tags file |tag-any-white| -m *+tcl* Tcl interface |tcl| -m *+tcl/dyn* Tcl interface |tcl-dynamic| |/dyn| - *+terminfo* uses |terminfo| instead of termcap -N *+termresponse* support for |t_RV| and |v:termresponse| -N *+textobjects* |text-objects| selection - *+tgetent* non-Unix only: able to use external termcap -N *+title* Setting the window 'title' and 'icon' -N *+toolbar* |gui-toolbar| -N *+user_commands* User-defined commands. |user-commands| -N *+viminfo* |'viminfo'| -N *+vertsplit* Vertically split windows |:vsplit| -N *+virtualedit* |'virtualedit'| -S *+visual* Visual mode |Visual-mode| -N *+visualextra* extra Visual mode commands |blockwise-operators| -N *+vreplace* |gR| and |gr| -N *+wildignore* |'wildignore'| -N *+wildmenu* |'wildmenu'| -S *+windows* more than one window -m *+writebackup* |'writebackup'| is default on -m *+xim* X input method |xim| - *+xfontset* X fontset support |xfontset| - *+xsmp* XSMP (X session management) support - *+xsmp_interact* interactive XSMP (X session management) support -N *+xterm_clipboard* Unix only: xterm clipboard handling -m *+xterm_save* save and restore xterm screen |xterm-screens| -N *+X11* Unix only: can restore window title |X11| - - */dyn* *E370* *E448* - To some of the features "/dyn" is added when the - feature is only available when the related library can - be dynamically loaded. - -:ve[rsion] {nr} Is now ignored. This was previously used to check the - version number of a .vimrc file. It was removed, - because you can now use the ":if" command for - version-dependent behavior. {not in Vi} - - *:redi* *:redir* -:redi[r][!] > {file} Redirect messages to file {file}. The messages which - are the output of commands are written to that file, - until redirection ends. The messages are also still - shown on the screen. When [!] is included, an - existing file is overwritten. When [!] is omitted, - and {file} exists, this command fails. - Only one ":redir" can be active at a time. Calls to - ":redir" will close any active redirection before - starting redirection to the new target. - To stop the messages and commands from being echoed to - the screen, put the commands in a function and call it - with ":silent call Function()". - An alternative is to use the 'verbosefile' option, - this can be used in combination with ":redir". - {not in Vi} - -:redi[r] >> {file} Redirect messages to file {file}. Append if {file} - already exists. {not in Vi} - -:redi[r] @{a-zA-Z} -:redi[r] @{a-zA-Z}> Redirect messages to register {a-z}. Append to the - contents of the register if its name is given - uppercase {A-Z}. The ">" after the register name is - optional. {not in Vi} -:redi[r] @{a-z}>> Append messages to register {a-z}. {not in Vi} - -:redi[r] @*> -:redi[r] @+> Redirect messages to the selection or clipboard. For - backward compatibility, the ">" after the register - name can be omitted. See |quotestar| and |quoteplus|. - {not in Vi} -:redi[r] @*>> -:redi[r] @+>> Append messages to the selection or clipboard. - {not in Vi} - -:redi[r] @"> Redirect messages to the unnamed register. For - backward compatibility, the ">" after the register - name can be omitted. {not in Vi} -:redi[r] @">> Append messages to the unnamed register. {not in Vi} - -:redi[r] => {var} Redirect messages to a variable. If the variable - doesn't exist, then it is created. If the variable - exists, then it is initialized to an empty string. - The variable will remain empty until redirection ends. - Only string variables can be used. After the - redirection starts, if the variable is removed or - locked or the variable type is changed, then further - command output messages will cause errors. {not in Vi} - -:redi[r] =>> {var} Append messages to an existing variable. Only string - variables can be used. {not in Vi} - -:redi[r] END End redirecting messages. {not in Vi} - - *:sil* *:silent* -:sil[ent][!] {command} Execute {command} silently. Normal messages will not - be given or added to the message history. - When [!] is added, error messages will also be - skipped, and commands and mappings will not be aborted - when an error is detected. |v:errmsg| is still set. - When [!] is not used, an error message will cause - further messages to be displayed normally. - Redirection, started with |:redir|, will continue as - usual, although there might be small differences. - This will allow redirecting the output of a command - without seeing it on the screen. Example: > - :redir >/tmp/foobar - :silent g/Aap/p - :redir END -< To execute a Normal mode command silently, use the - |:normal| command. For example, to search for a - string without messages: > - :silent exe "normal /path\<CR>" -< ":silent!" is useful to execute a command that may - fail, but the failure is to be ignored. Example: > - :let v:errmsg = "" - :silent! /^begin - :if v:errmsg != "" - : ... pattern was not found -< ":silent" will also avoid the hit-enter prompt. When - using this for an external command, this may cause the - screen to be messed up. Use |CTRL-L| to clean it up - then. - ":silent menu ..." defines a menu that will not echo a - Command-line command. The command will still produce - messages though. Use ":silent" in the command itself - to avoid that: ":silent menu .... :silent command". - - *:verb* *:verbose* -:[count]verb[ose] {command} - Execute {command} with 'verbose' set to [count]. If - [count] is omitted one is used. ":0verbose" can be - used to set 'verbose' to zero. - The additional use of ":silent" makes messages - generated but not displayed. - The combination of ":silent" and ":verbose" can be - used to generate messages and check them with - |v:statusmsg| and friends. For example: > - :let v:statusmsg = "" - :silent verbose runtime foobar.vim - :if v:statusmsg != "" - : " foobar.vim could not be found - :endif -< When concatenating another command, the ":verbose" - only applies to the first one: > - :4verbose set verbose | set verbose -< verbose=4 ~ - verbose=0 ~ - For logging verbose messages in a file use the - 'verbosefile' option. - - *:verbose-cmd* -When 'verbose' is non-zero, listing the value of a Vim option or a key map or -an abbreviation or a user-defined function or a command or a highlight group -or an autocommand will also display where it was last defined. If it was -defined manually then there will be no "Last set" message. When it was -defined while executing a function, user command or autocommand, the script in -which it was defined is reported. -{not available when compiled without the +eval feature} - - *K* -K Run a program to lookup the keyword under the - cursor. The name of the program is given with the - 'keywordprg' (kp) option (default is "man"). The - keyword is formed of letters, numbers and the - characters in 'iskeyword'. The keyword under or - right of the cursor is used. The same can be done - with the command > - :!{program} {keyword} -< There is an example of a program to use in the tools - directory of Vim. It is called 'ref' and does a - simple spelling check. - Special cases: - - If 'keywordprg' is empty, the ":help" command is - used. It's a good idea to include more characters - in 'iskeyword' then, to be able to find more help. - - When 'keywordprg' is equal to "man", a count before - "K" is inserted after the "man" command and before - the keyword. For example, using "2K" while the - cursor is on "mkdir", results in: > - !man 2 mkdir -< - When 'keywordprg' is equal to "man -s", a count - before "K" is inserted after the "-s". If there is - no count, the "-s" is removed. - {not in Vi} - - *v_K* -{Visual}K Like "K", but use the visually highlighted text for - the keyword. Only works when the highlighted text is - not more than one line. {not in Vi} - -[N]gs *gs* *:sl* *:sleep* -:[N]sl[eep] [N] [m] Do nothing for [N] seconds. When [m] is included, - sleep for [N] milliseconds. The count for "gs" always - uses seconds. The default is one second. > - :sleep "sleep for one second - :5sleep "sleep for five seconds - :sleep 100m "sleep for a hundred milliseconds - 10gs "sleep for ten seconds -< Can be interrupted with CTRL-C (CTRL-Break on MS-DOS). - "gs" stands for "goto sleep". - While sleeping the cursor is positioned in the text, - if at a visible position. {not in Vi} - - *g_CTRL-A* -g CTRL-A Only when Vim was compiled with MEM_PROFILING defined - (which is very rare): print memory usage statistics. - Only useful for debugging Vim. - -============================================================================== -2. Online help *online-help* - - *help* *<Help>* *:h* *:help* *<F1>* *i_<F1>* *i_<Help>* -<Help> or -:h[elp] Open a window and display the help file in read-only - mode. If there is a help window open already, use - that one. Otherwise, if the current window uses the - full width of the screen or is at least 80 characters - wide, the help window will appear just above the - current window. Otherwise the new window is put at - the very top. - The 'helplang' option is used to select a language, if - the main help file is available in several languages. - {not in Vi} - - *{subject}* *E149* *E661* -:h[elp] {subject} Like ":help", additionally jump to the tag {subject}. - {subject} can include wildcards like "*", "?" and - "[a-z]": - :help z? jump to help for any "z" command - :help z. jump to the help for "z." - If there is no full match for the pattern, or there - are several matches, the "best" match will be used. - A sophisticated algorithm is used to decide which - match is better than another one. These items are - considered in the computation: - - A match with same case is much better than a match - with different case. - - A match that starts after a non-alphanumeric - character is better than a match in the middle of a - word. - - A match at or near the beginning of the tag is - better than a match further on. - - The more alphanumeric characters match, the better. - - The shorter the length of the match, the better. - - The 'helplang' option is used to select a language, if - the {subject} is available in several languages. - To find a tag in a specific language, append "@ab", - where "ab" is the two-letter language code. See - |help-translated|. - - Note that the longer the {subject} you give, the less - matches will be found. You can get an idea how this - all works by using commandline completion (type CTRL-D - after ":help subject"). - If there are several matches, you can have them listed - by hitting CTRL-D. Example: > - :help cont<Ctrl-D> -< To use a regexp |pattern|, first do ":help" and then - use ":tag {pattern}" in the help window. The - ":tnext" command can then be used to jump to other - matches, "tselect" to list matches and choose one. > - :help index| :tse z. -< When there is no argument you will see matches for - "help", to avoid listing all possible matches (that - would be very slow). - The number of matches displayed is limited to 300. - - This command can be followed by '|' and another - command, but you don't need to escape the '|' inside a - help command. So these both work: > - :help | - :help k| only -< Note that a space before the '|' is seen as part of - the ":help" argument. - You can also use <LF> or <CR> to separate the help - command from a following command. You need to type - CTRL-V first to insert the <LF> or <CR>. Example: > - :help so<C-V><CR>only -< {not in Vi} - -:h[elp]! [subject] Like ":help", but in non-English help files prefer to - find a tag in a file with the same language as the - current file. See |help-translated|. - - *:helpg* *:helpgrep* -:helpg[rep] {pattern}[@xx] - Search all help text files and make a list of lines - in which {pattern} matches. Jumps to the first match. - The optional [@xx] specifies that only matches in the - "xx" language are to be found. - You can navigate through the matches with the - |quickfix| commands, e.g., |:cnext| to jump to the - next one. Or use |:cwindow| to get the list of - matches in the quickfix window. - {pattern} is used as a Vim regexp |pattern|. - 'ignorecase' is not used, add "\c" to ignore case. - Example for case sensitive search: > - :helpgrep Uganda -< Example for case ignoring search: > - :helpgrep uganda\c -< Example for searching in French help: > - :helpgrep backspace@fr -< The pattern does not support line breaks, it must - match within one line. You can use |:grep| instead, - but then you need to get the list of help files in a - complicated way. - Cannot be followed by another command, everything is - used as part of the pattern. But you can use - |:execute| when needed. - Compressed help files will not be searched (Fedora - compresses the help files). - {not in Vi} - - *:lh* *:lhelpgrep* -:lh[elpgrep] {pattern}[@xx] - Same as ":helpgrep", except the location list is used - instead of the quickfix list. If the help window is - already opened, then the location list for that window - is used. Otherwise, a new help window is opened and - the location list for that window is set. The - location list for the current window is not changed. - - *:exu* *:exusage* -:exu[sage] Show help on Ex commands. Added to simulate the Nvi - command. {not in Vi} - - *:viu* *:viusage* -:viu[sage] Show help on Normal mode commands. Added to simulate - the Nvi command. {not in Vi} - -When no argument is given to |:help| the file given with the 'helpfile' option -will be opened. Otherwise the specified tag is searched for in all "doc/tags" -files in the directories specified in the 'runtimepath' option. - -The initial height of the help window can be set with the 'helpheight' option -(default 20). - -Jump to specific subjects by using tags. This can be done in two ways: -- Use the "CTRL-]" command while standing on the name of a command or option. - This only works when the tag is a keyword. "<C-Leftmouse>" and - "g<LeftMouse>" work just like "CTRL-]". -- use the ":ta {subject}" command. This also works with non-keyword - characters. - -Use CTRL-T or CTRL-O to jump back. -Use ":q" to close the help window. - -If there are several matches for an item you are looking for, this is how you -can jump to each one of them: -1. Open a help window -2. Use the ":tag" command with a slash prepended to the tag. E.g.: > - :tag /min -3. Use ":tnext" to jump to the next matching tag. - -It is possible to add help files for plugins and other items. You don't need -to change the distributed help files for that. See |add-local-help|. - -To write a local help file, see |write-local-help|. - -Note that the title lines from the local help files are automagically added to -the "LOCAL ADDITIONS" section in the "help.txt" help file |local-additions|. -This is done when viewing the file in Vim, the file itself is not changed. It -is done by going through all help files and obtaining the first line of each -file. The files in $VIMRUNTIME/doc are skipped. - - *help-xterm-window* -If you want to have the help in another xterm window, you could use this -command: > - :!xterm -e vim +help & -< - - *:helpfind* *:helpf* -:helpf[ind] Like |:help|, but use a dialog to enter the argument. - Only for backwards compatibility. It now executes the - ToolBar.FindHelp menu entry instead of using a builtin - dialog. {only when compiled with |+GUI_GTK|} -< {not in Vi} - - *:helpt* *:helptags* - *E154* *E150* *E151* *E152* *E153* *E670* -:helpt[ags] [++t] {dir} - Generate the help tags file(s) for directory {dir}. - All "*.txt" and "*.??x" files in the directory are - scanned for a help tag definition in between stars. - The "*.??x" files are for translated docs, they - generate the "tags-??" file, see |help-translated|. - The generated tags files are sorted. - When there are duplicates an error message is given. - An existing tags file is silently overwritten. - The optional "++t" argument forces adding the - "help-tags" tag. This is also done when the {dir} is - equal to $VIMRUNTIME/doc. - To rebuild the help tags in the runtime directory - (requires write permission there): > - :helptags $VIMRUNTIME/doc -< {not in Vi} - - -TRANSLATED HELP *help-translated* - -It is possible to add translated help files, next to the original English help -files. Vim will search for all help in "doc" directories in 'runtimepath'. -This is only available when compiled with the |+multi_lang| feature. - -At this moment translations are available for: - Chinese - multiple authors - French - translated by David Blanchet - Italian - translated by Antonio Colombo - Polish - translated by Mikolaj Machowski - Russian - translated by Vassily Ragosin -See the Vim website to find them: http://www.vim.org/translations.php - -A set of translated help files consists of these files: - - help.abx - howto.abx - ... - tags-ab - -"ab" is the two-letter language code. Thus for Italian the names are: - - help.itx - howto.itx - ... - tags-it - -The 'helplang' option can be set to the preferred language(s). The default is -set according to the environment. Vim will first try to find a matching tag -in the preferred language(s). English is used when it cannot be found. - -To find a tag in a specific language, append "@ab" to a tag, where "ab" is the -two-letter language code. Example: > - :he user-manual@it - :he user-manual@en -The first one finds the Italian user manual, even when 'helplang' is empty. -The second one finds the English user manual, even when 'helplang' is set to -"it". - -When using command-line completion for the ":help" command, the "@en" -extension is only shown when a tag exists for multiple languages. When the -tag only exists for English "@en" is omitted. - -When using |CTRL-]| or ":help!" in a non-English help file Vim will try to -find the tag in the same language. If not found then 'helplang' will be used -to select a language. - -Help files must use latin1 or utf-8 encoding. Vim assumes the encoding is -utf-8 when finding non-ASCII characters in the first line. Thus you must -translate the header with "For Vim version". - -The same encoding must be used for the help files of one language in one -directory. You can use a different encoding for different languages and use -a different encoding for help files of the same language but in a different -directory. - -Hints for translators: -- Do not translate the tags. This makes it possible to use 'helplang' to - specify the preferred language. You may add new tags in your language. -- When you do not translate a part of a file, add tags to the English version, - using the "tag@en" notation. -- Make a package with all the files and the tags file available for download. - Users can drop it in one of the "doc" directories and start use it. - Report this to Bram, so that he can add a link on www.vim.org. -- Use the |:helptags| command to generate the tags files. It will find all - languages in the specified directory. - -============================================================================== -3. Using Vim like less or more *less* - -If you use the less or more program to view a file, you don't get syntax -highlighting. Thus you would like to use Vim instead. You can do this by -using the shell script "$VIMRUNTIME/macros/less.sh". - -This shell script uses the Vim script "$VIMRUNTIME/macros/less.vim". It sets -up mappings to simulate the commands that less supports. Otherwise, you can -still use the Vim commands. - -This isn't perfect. For example, when viewing a short file Vim will still use -the whole screen. But it works good enough for most uses, and you get syntax -highlighting. - -The "h" key will give you a short overview of the available commands. - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/version4.txt b/share/vim/vim72/doc/version4.txt deleted file mode 100644 index 82a1bbe746..0000000000 --- a/share/vim/vim72/doc/version4.txt +++ /dev/null @@ -1,355 +0,0 @@ -*version4.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -This document lists the incompatible differences between Vim 3.0 and Vim 4.0. -Although 4.0 is mentioned here, this is also for version 4.1, 4.2, etc.. - -This file is important for everybody upgrading from Vim 3.0. Read it -carefully to avoid unexpected problems. - -'backup' option default changed |backup-changed| -Extension for backup file changed |backup-extension| -Structure of swap file changed |swapfile-changed| -"-w scriptout" argument changed |scriptout-changed| -Backspace and Delete keys |backspace-delete| -Escape for | changed |escape-bar| -Key codes changed |key-codes-changed| -Terminal options changed |termcap-changed| -'errorformat' option changed |errorformat-changed| -'graphic' option gone |graphic-option-gone| -'yankendofline' option gone |ye-option-gone| -'icon' and 'title' default value changed |icon-changed| -'highlight' option changed |highlight-changed| -'tildeop' and 'weirdinvert' short names changed |short-name-changed| -Use of "v", "V" and "CTRL-V" in Visual mode |use-visual-cmds| -CTRL-B in Insert mode removed |toggle-revins| - - -'backup' option default changed *backup-changed* -------------------------------- - -The default value for 'backup' used to be on. This resulted in a backup file -being made when the original file was overwritten. - -Now the default for 'backup' is off. As soon as the writing of the file has -successfully finished, the backup file is deleted. If you want to keep the -backup file, set 'backup' on in your vimrc. The reason for this change is -that many people complained that leaving a backup file behind is not -Vi-compatible. |'backup'| - - -Extension for backup file changed *backup-extension* ---------------------------------- - -The extension for the backup file used to be ".bak". Since other programs -also use this extension and some users make copies with this extension, it was -changed to the less obvious "~". Another advantage is that this takes less -space, which is useful when working on a system with short file names. For -example, on MS-DOS the backup files for "longfile.c" and "longfile.h" would -both become "longfile.bak"; now they will be "longfile.c~" and "longfile.h~". - -If you prefer to use ".bak", you can set the 'backupext' option: > - :set bex=.bak - - -Structure of swap file changed *swapfile-changed* ------------------------------- - -The contents of the swap file were extended with several parameters. Vim -stores the user name and other information about the edited file to make -recovery more easy and to be able to know where the swap file comes from. The -first part of the swap file can now be understood on a machine with a -different byte order or sizeof(int). When you try to recover a file on such a -machine, you will get an error message that this is not possible. - -Because of this change, swap files cannot be exchanged between 3.0 and 4.0. -If you have a swap file from a crashed session with 3.0, use Vim 3.0 to -recover the file---don't use 4.0. |swap-file| - - -"-w scriptout" argument changed *scriptout-changed* -------------------------------- - -"vim -w scriptout" used to append to the scriptout file. Since this was -illogical, it now creates a new file. An existing file is not overwritten -(to avoid destroying an existing file for those who rely on the appending). -[This was removed again later] |-w| - - -Backspace and Delete keys *backspace-delete* -------------------------- - -In 3.0 both the delete key and the backspace key worked as a backspace in -insert mode; they deleted the character to the left of the cursor. In 4.0 the -delete key has a new function: it deletes the character under the cursor, just -like it does on the command-line. If the cursor is after the end of the line -and 'bs' is set, two lines are joined. |<Del>| |i_<Del>| - -In 3.0 the backspace key was always defined as CTRL-H and delete as CTRL-?. -In 4.0 the code for the backspace and delete key is obtained from termcap or -termlib, and adjusted for the "stty erase" value on Unix. This helps people -who define the erase character according to the keyboard they are working on. - |<BS>| |i_<BS>| - -If you prefer backspace and delete in Insert mode to have the old behavior, -put this line in your vimrc: - - inoremap ^? ^H - -And you may also want to add these, to fix the values for <BS> and <Del>: - - set t_kb=^H - set t_kD=^? - -(Enter ^H with CTRL-V CTRL-H and ^? with CTRL-V CTRL-? or <Del>.) - -If the value for t_kb is correct, but the t_kD value is not, use the ":fixdel" -command. It will set t_kD according to the value of t_kb. This is useful if -you are using several different terminals. |:fixdel| - -When ^H is not recognized as <BS> or <Del>, it is used like a backspace. - - -Escape for | changed *escape-bar* --------------------- - -When the 'b' flag is present in 'cpoptions', the backslash cannot be used to -escape '|' in mapping and abbreviate commands, only CTRL-V can. This is -Vi-compatible. If you work in Vi-compatible mode and had used "\|" to include -a bar in a mapping, this needs to be replaced by "^V|". See |:bar|. - - -Key codes changed *key-codes-changed* ------------------ - -The internal representation of key codes has changed dramatically. In 3.0 a -one-byte code was used to represent a key. This caused problems with -different characters sets that also used these codes. In 4.0 a three-byte -code is used that cannot be confused with a character. |key-notation| - -If you have used the single-byte key codes in your vimrc for mappings, you -will have to replace them with the 4.0 codes. Instead of using the three-byte -code directly, you should use the symbolic representation for this in <>. See -the table below. The table also lists the old name, as it was used in the 3.0 -documentation. - -The key names in <> can be used in mappings directly. This makes it possible -to copy/paste examples or type them literally. The <> notation has been -introduced for this |<>|. The 'B' and '<' flags must not be present in -'cpoptions' to enable this to work |'cpoptions'|. - -old name new name old code old MS-DOS code ~ - hex dec hex dec ~ -<ESC> <Esc> -<TAB> <Tab> -<LF> <NL> <NewLine> <LineFeed> -<SPACE> <Space> -<NUL> <Nul> -<BELL> <Bell> -<BS> <BS> <BackSpace> -<INSERT> <Insert> -<DEL> <Del> <Delete> -<HOME> <Home> -<END> <End> -<PAGE_UP> <PageUp> -<PAGE_DOWN> <PageDown> - -<C_UP> <Up> 0x80 128 0xb0 176 -<C_DOWN> <Down> 0x81 129 0xb1 177 -<C_LEFT> <Left> 0x82 130 0xb2 178 -<C_RIGHT> <Right> 0x83 131 0xb3 179 -<SC_UP> <S-Up> 0x84 132 0xb4 180 -<SC_DOWN> <S-Down> 0x85 133 0xb5 181 -<SC_LEFT> <S-Left> 0x86 134 0xb6 182 -<SC_RIGHT> <S-Right> 0x87 135 0xb7 183 - -<F1> <F1> 0x88 136 0xb8 184 -<F2> <F2> 0x89 137 0xb9 185 -<F3> <F3> 0x8a 138 0xba 186 -<F4> <F4> 0x8b 139 0xbb 187 -<F5> <F5> 0x8c 140 0xbc 188 -<F6> <F6> 0x8d 141 0xbd 189 -<F7> <F7> 0x8e 142 0xbe 190 -<F8> <F8> 0x8f 143 0xbf 191 -<F9> <F9> 0x90 144 0xc0 192 -<F10> <F10> 0x91 145 0xc1 193 - -<SF1> <S-F1> 0x92 146 0xc2 194 -<SF2> <S-F2> 0x93 147 0xc3 195 -<SF3> <S-F3> 0x94 148 0xc4 196 -<SF4> <S-F4> 0x95 149 0xc5 197 -<SF5> <S-F5> 0x96 150 0xc6 198 -<SF6> <S-F6> 0x97 151 0xc7 199 -<SF7> <S-F7> 0x98 152 0xc8 200 -<SF8> <S-F8> 0x99 153 0xc9 201 -<SF9> <S-F9> 0x9a 154 0xca 202 -<SF10> <S-F10> 0x9b 155 0xcb 203 - -<HELP> <Help> 0x9c 156 0xcc 204 -<UNDO> <Undo> 0x9d 157 0xcd 205 - - (not used) 0x9e 158 0xce 206 - (not used) 0x9f 159 0xcf 207 - - -Terminal options changed *termcap-changed* ------------------------- - -The names of the terminal options have been changed to match the termcap names -of these options. All terminal options now have the name t_xx, where xx is -the termcap name. Normally these options are not used, unless you have a -termcap entry that is wrong or incomplete, or you have set the highlight -options to a different value. |terminal-options| - -Note that for some keys there is no termcap name. Use the <> type of name -instead, which is a good idea anyway. - -Note that "t_ti" has become "t_mr" (invert/reverse output) and "t_ts" has -become "t_ti" (init terminal mode). Be careful when you use "t_ti"! - -old name new name meaning ~ -t_cdl t_DL delete number of lines *t_cdl* -t_ci t_vi cursor invisible *t_ci* -t_cil t_AL insert number of lines *t_cil* -t_cm t_cm move cursor -t_cri t_RI cursor number of chars right *t_cri* -t_cv t_ve cursor visible *t_cv* -t_cvv t_vs cursor very visible *t_cvv* -t_dl t_dl delete line -t_cs t_cs scroll region -t_ed t_cl clear display *t_ed* -t_el t_ce clear line *t_el* -t_il t_al insert line *t_il* - t_da display may be retained above the screen - t_db display may be retained below the screen -t_ke t_ke put terminal out of keypad transmit mode -t_ks t_ks put terminal in keypad transmit mode -t_ms t_ms save to move cursor in highlight mode -t_se t_se normal mode (undo t_so) -t_so t_so shift out (standout) mode -t_ti t_mr reverse highlight -t_tb t_md bold mode *t_tb* -t_tp t_me highlight end *t_tp* -t_sr t_sr scroll reverse -t_te t_te out of termcap mode -t_ts t_ti into termcap mode *t_ts_old* -t_vb t_vb visual bell -t_csc t_CS cursor is relative to scroll region *t_csc* - -t_ku t_ku <Up> arrow up -t_kd t_kd <Down> arrow down -t_kr t_kr <Right> arrow right -t_kl t_kl <Left> arrow left -t_sku <S-Up> shifted arrow up *t_sku* -t_skd <S-Down> shifted arrow down *t_skd* -t_skr t_%i <S-Right> shifted arrow right *t_skr* -t_skl t_#4 <S-Left> shifted arrow left *t_skl* -t_f1 t_k1 <F1> function key 1 *t_f1* -t_f2 t_k2 <F2> function key 2 *t_f2* -t_f3 t_k3 <F3> function key 3 *t_f3* -t_f4 t_k4 <F4> function key 4 *t_f4* -t_f5 t_k5 <F5> function key 5 *t_f5* -t_f6 t_k6 <F6> function key 6 *t_f6* -t_f7 t_k7 <F7> function key 7 *t_f7* -t_f8 t_k8 <F8> function key 8 *t_f8* -t_f9 t_k9 <F9> function key 9 *t_f9* -t_f10 t_k; <F10> function key 10 *t_f10* -t_sf1 <S-F1> shifted function key 1 *t_sf1* -t_sf2 <S-F2> shifted function key 2 *t_sf2* -t_sf3 <S-F3> shifted function key 3 *t_sf3* -t_sf4 <S-F4> shifted function key 4 *t_sf4* -t_sf5 <S-F5> shifted function key 5 *t_sf5* -t_sf6 <S-F6> shifted function key 6 *t_sf6* -t_sf7 <S-F7> shifted function key 7 *t_sf7* -t_sf8 <S-F8> shifted function key 8 *t_sf8* -t_sf9 <S-F9> shifted function key 9 *t_sf9* -t_sf10 <S-F10> shifted function key 10 *t_sf10* -t_help t_%1 <Help> help key *t_help* -t_undo t_&8 <Undo> undo key *t_undo* - - -'errorformat' option changed *errorformat-changed* ----------------------------- - -'errorformat' can now contain several formats, separated by commas. The first -format that matches is used. The default values have been adjusted to catch -the most common formats. |errorformat| - -If you have a format that contains a comma, it needs to be preceded with a -backslash. Type two backslashes, because the ":set" command will eat one. - - -'graphic' option gone *graphic-option-gone* ---------------------- - -The 'graphic' option was used to make the characters between <~> and 0xa0 -display directly on the screen. Now the 'isprint' option takes care of this -with many more possibilities. The default setting is the same; you only need -to look into this if you previously set the 'graphic' option in your vimrc. - |'isprint'| - - -'yankendofline' option gone *ye-option-gone* ---------------------------- - -The 'yankendofline' option has been removed. Instead you can just use - :map Y y$ - - -'icon' and 'title' default value changed *icon-changed* ----------------------------------------- - -The 'title' option is now only set by default if the original title can be -restored. Avoids "Thanks for flying Vim" titles. If you want them anyway, -put ":set title" in your vimrc. |'title'| - -The default for 'icon' now depends on the possibility of restoring the -original value, just like 'title'. If you don't like your icon titles to be -changed, add this line to your vimrc: |'icon'| - :set noicon - - -'highlight' option changed *highlight-changed* --------------------------- - -The 'i' flag now means italic highlighting, instead of invert. The 'r' flag -is used for reverse highlighting, which is what 'i' used to be. Normally you -won't see the difference, because italic mode is not supported on most -terminals and reverse mode is used as a fallback. |'highlight'| - -When an occasion is not present in 'highlight', use the mode from the default -value for 'highlight', instead of reverse mode. - - -'tildeop' and 'weirdinvert' short names changed *short-name-changed* ------------------------------------------------ - -Renamed 'to' (abbreviation for 'tildeop') to 'top'. |'tildeop'| -Renamed 'wi' (abbreviation for 'weirdinvert') to 'wiv'. |'weirdinvert'| - -This was done because Vi uses 'wi' as the short name for 'window' and 'to' as -the short name for 'timeout'. This means that if you try setting these -options, you won't get an error message, but the effect will be different. - - -Use of "v", "V" and "CTRL-V" in Visual mode *use-visual-cmds* -------------------------------------------- - -In Visual mode, "v", "V", and "CTRL-V" used to end Visual mode. Now this -happens only if the Visual mode was in the corresponding type. Otherwise the -type of Visual mode is changed. Now only ESC can be used in all circumstances -to end Visual mode without doing anything. |v_V| - - -CTRL-B in Insert mode removed *toggle-revins* ------------------------------ - -CTRL-B in Insert mode used to toggle the 'revins' option. If you don't know -this and accidentally hit CTRL-B, it is very difficult to find out how to undo -it. Since hardly anybody uses this feature, it is disabled by default. If -you want to use it, define RIGHTLEFT in feature.h before compiling. |'revins'| - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/version5.txt b/share/vim/vim72/doc/version5.txt deleted file mode 100644 index 16d2657b9f..0000000000 --- a/share/vim/vim72/doc/version5.txt +++ /dev/null @@ -1,7813 +0,0 @@ -*version5.txt* For Vim version 7.2. Last change: 2008 Jun 28 - - - VIM REFERENCE MANUAL by Bram Moolenaar - -Welcome to Vim Version 5.0! - -This document lists the differences between Vim 4.x and Vim 5.0. -Although 5.0 is mentioned here, this is also for version 5.1, 5.2, etc.. -See |vi_diff.txt| for an overview of differences between Vi and Vim 5.0. -See |version4.txt| for differences between Vim 3.0 and Vim 4.0. - -INCOMPATIBLE: |incompatible-5| - -Default value for 'compatible' changed |cp-default| -Text formatting command "Q" changed |Q-command-changed| -Command-line arguments changed |cmdline-changed| -Autocommands are kept |autocmds-kept| -Use of 'hidden' changed |hidden-changed| -Text object commands changed |text-objects-changed| -X-Windows Resources removed |x-resources| -Use of $VIM |$VIM-use| -Use of $HOME for MS-DOS and Win32 |$HOME-use| -Tags file format changed |tags-file-changed| -Options changed |options-changed| -CTRL-B in Insert mode gone |i_CTRL-B-gone| - -NEW FEATURES: |new-5| - -Syntax highlighting |new-highlighting| -Built-in script language |new-script| -Perl and Python support |new-perl-python| -Win32 GUI version |added-win32-GUI| -VMS version |added-VMS| -BeOS version |added-BeOS| -Macintosh GUI version |added-Mac| -More Vi compatible |more-compatible| -Read input from stdin |read-stdin| -Regular expression patterns |added-regexp| -Overloaded tags |tag-overloaded| -New commands |new-commands| -New options |added-options| -New command-line arguments |added-cmdline-args| -Various additions |added-various| - -IMPROVEMENTS |improvements-5| - -COMPILE TIME CHANGES |compile-changes-5| - -BUG FIXES |bug-fixes-5| - -VERSION 5.1 |version-5.1| -Changed |changed-5.1| -Added |added-5.1| -Fixed |fixed-5.1| - -VERSION 5.2 |version-5.2| -Long lines editable |long-lines| -File browser added |file-browser-5.2| -Dialogs added |dialogs-added| -Popup menu added |popup-menu-added| -Select mode added |new-Select-mode| -Session files added |new-session-files| -User defined functions and commands |new-user-defined| -New interfaces |interfaces-5.2| -New ports |ports-5.2| -Multi-byte support |new-multi-byte| -New functions |new-functions-5.2| -New options |new-options-5.2| -New Ex commands |new-ex-commands-5.2| -Changed |changed-5.2| -Added |added-5.2| -Fixed |fixed-5.2| - -VERSION 5.3 |version-5.3| -Changed |changed-5.3| -Added |added-5.3| -Fixed |fixed-5.3| - -VERSION 5.4 |version-5.4| -Runtime directory introduced |new-runtime-dir| -Filetype introduced |new-filetype-5.4| -Vim script line continuation |new-line-continuation| -Improved session files |improved-sessions| -Autocommands improved |improved-autocmds-5.4| -Encryption |new-encryption| -GTK GUI port |new-GTK-GUI| -Menu changes |menu-changes-5.4| -Viminfo improved |improved-viminfo| -Various new commands |new-commands-5.4| -Various new options |new-options-5.4| -Vim scripts |new-script-5.4| -Avoid hit-enter prompt |avoid-hit-enter| -Improved quickfix |improved-quickfix| -Regular expressions |regexp-changes-5.4| -Changed |changed-5.4| -Added |added-5.4| -Fixed |fixed-5.4| - -VERSION 5.5 |version-5.5| -Changed |changed-5.5| -Added |added-5.5| -Fixed |fixed-5.5| - -VERSION 5.6 |version-5.6| -Changed |changed-5.6| -Added |added-5.6| -Fixed |fixed-5.6| - -VERSION 5.7 |version-5.7| -Changed |changed-5.7| -Added |added-5.7| -Fixed |fixed-5.7| - -VERSION 5.8 |version-5.8| -Changed |changed-5.8| -Added |added-5.8| -Fixed |fixed-5.8| - -============================================================================== - INCOMPATIBLE *incompatible-5* - -Default value for 'compatible' changed *cp-default* --------------------------------------- - -Vim version 5.0 tries to be more Vi compatible. This helps people who use Vim -as a drop-in replacement for Vi, but causes some things to be incompatible -with version 4.x. - -In version 4.x the default value for the 'compatible' option was off. Now the -default is on. The first thing you will notice is that the "u" command undoes -itself. Other side effects will be that mappings may work differently or not -work at all. - -Since a lot of people switching from Vim 4.x to 5.0 will find this annoying, -the 'compatible' option is switched off if Vim finds a vimrc file. This is a -bit of magic to make sure that 90% of the Vim users will not be bitten by -this change. - -What does this mean? -- If you prefer to run in 'compatible' mode and don't have a vimrc file, you - don't have to do anything. -- If you prefer to run in 'nocompatible' mode and do have a vimrc file, you - don't have to do anything. -- If you prefer to run in 'compatible' mode and do have a vimrc file, you - should put this line first in your vimrc file: > - :set compatible -- If you prefer to run in 'nocompatible' mode and don't have a vimrc file, - you can do one of the following: - - Create an empty vimrc file (e.g.: "~/.vimrc" for Unix). - - Put this command in your .exrc file or $EXINIT: > - :set nocompatible -< - Start Vim with the "-N" argument. - -If you are new to Vi and Vim, using 'nocompatible' is strongly recommended, -because Vi has a lot of unexpected side effects, which are avoided by this -setting. See 'compatible'. - -If you like some things from 'compatible' and some not, you can tune the -compatibility with 'cpoptions'. - -When you invoke Vim as "ex" or "gex", Vim always starts in compatible mode. - - -Text formatting command "Q" changed *Q-command-changed* ------------------------------------ - -The "Q" command formerly formatted lines to the width the 'textwidth' option -specifies. The command for this is now "gq" (see |gq| for more info). The -reason for this change is that "Q" is the standard Vi command to enter "Ex" -mode, and Vim now does in fact have an "Ex" mode (see |Q| for more info). - -If you still want to use "Q" for formatting, use this mapping: > - :noremap Q gq -And if you also want to use the functionality of "Q": > - :noremap gQ Q - - -Command-line arguments changed *cmdline-changed* ------------------------------- - -Command-line file-arguments and option-arguments can now be mixed. You can -give options after the file names. Example: > - vim main.c -g - -This is not possible when editing a file that starts with a '-'. Use the "--" -argument then |---|: > - vim -g -- -main.c - -"-v" now means to start Ex in Vi mode, use "-R" for read-only mode. -old: "vim -v file" |-v| -new: "vim -R file" |-R| - -"-e" now means to start Vi in Ex mode, use "-q" for quickfix. -old: "vim -e errorfile" |-e| -new: "vim -q errorfile" |-q| - -"-s" in Ex mode now means to run in silent (batch) mode. |-s-ex| - -"-x" reserved for crypt, use "-f" to avoid starting a new CLI (Amiga). -old: "vim -x file" |-x| -new: "vim -f file" |-f| - -Vim allows up to ten "+cmd" and "-c cmd" arguments. Previously Vim executed -only the last one. - -"-n" now overrides any setting for 'updatecount' in a vimrc file, but not in -a gvimrc file. - - -Autocommands are kept *autocmds-kept* ---------------------- - -Before version 5.0, autocommands with the same event, file name pattern, and -command could appear only once. This was fine for simple autocommands (like -setting option values), but for more complicated autocommands, where the same -command might appear twice, this restriction caused problems. Therefore -Vim stores all autocommands and keeps them in the order that they are defined. - -The most obvious side effect of this change is that when you source a vimrc -file twice, the autocommands in it will be defined twice. To avoid this, do -one of these: - -- Remove any autocommands that might potentially defined twice before - defining them. Example: > - :au! * *.ext - :au BufEnter *.ext ... - -- Put the autocommands inside an ":if" command. Example: > - if !exists("did_ext_autocmds") - let did_ext_autocmds = 1 - autocmd BufEnter *.ext ... - endif - -- Put your autocommands in a different autocommand group so you can remove - them before defining them |:augroup|: > - augroup uncompress - au! - au BufReadPost *.gz ... - augroup END - - -Use of 'hidden' changed *hidden-changed* ------------------------ - -In version 4.x, only some commands used the 'hidden' option. Now all commands -uses it whenever a buffer disappears from a window. - -Previously you could do ":buf xxx" in a changed buffer and that buffer would -then become hidden. Now you must set the 'hidden' option for this to work. - -The new behavior is simpler: whether Vim hides buffers no longer depends on -the specific command that you use. -- with 'hidden' not set, you never get hidden buffers. Exceptions are the - ":hide" and ":close!" commands and, in rare cases, where you would otherwise - lose changes to the buffer. -- With 'hidden' set, you almost never unload a buffer. Exceptions are the - ":bunload" or ":bdel" commands. - -":buffer" now supports a "!": abandon changes in current buffer. So do -":bnext", ":brewind", etc. - - -Text object commands changed *text-objects-changed* ----------------------------- - -Text object commands have new names. This allows more text objects and makes -characters available for other Visual mode commands. Since no more single -characters were available, text objects names now require two characters. -The first one is always 'i' or 'a'. - OLD NEW ~ - a aw a word |v_aw| - A aW a WORD |v_aW| - s as a sentence |v_as| - p ap a paragraph |v_ap| - S ab a () block |v_ab| - P aB a {} block |v_aB| - -There is another set of text objects that starts with "i", for "inner". These -select the same objects, but exclude white space. - - -X-Windows Resources removed *x-resources* --------------------------- - -Vim no longer supports the following X resources: -- boldColor -- italicColor -- underlineColor -- cursorColor - -Vim now uses highlight groups to set colors. This avoids the confusion of -using a bold Font, which would imply a certain color. See |:highlight| and -|gui-resources|. - - -Use of $VIM *$VIM-use* ------------ - -Vim now uses the VIM environment variable to find all Vim system files. This -includes the global vimrc, gvimrc, and menu.vim files and all on-line help -and syntax files. See |$VIM|. Starting with version 5.4, |$VIMRUNTIME| can -also be used. -For Unix, Vim sets a default value for $VIM when doing "make install". -When $VIM is not set, its default value is the directory from 'helpfile', -excluding "/doc/help.txt". - - -Use of $HOME for MS-DOS and Win32 *$HOME-use* ---------------------------------- - -The MS-DOS and Win32 versions of Vim now first check $HOME when searching for -a vimrc or exrc file and for reading/storing the viminfo file. Previously Vim -used $VIM for these systems, but this causes trouble on a system with several -users. Now Vim uses $VIM only when $HOME is not set or the file is not found -in $HOME. See |_vimrc|. - - -Tags file format changed *tags-file-changed* ------------------------- - -Only tabs are allowed to separate fields in a tags file. This allows for -spaces in a file name and is still Vi compatible. In previous versions of -Vim, any white space was allowed to separate the fields. If you have a file -which doesn't use a single tab between fields, edit the tags file and execute -this command: > - :%s/\(\S*\)\s\+\(\S*\)\s\+\(.*\)/\1\t\2\t\3/ - - -Options changed *options-changed* ---------------- - -The default value of 'errorfile' has changed from "errors.vim" to "errors.err". -The reason is that only Vim scripts should have the ".vim" extensions. - -The ":make" command no longer uses the 'errorfile' option. This prevents the -output of the ":make" command from overwriting a manually saved error file. -":make" uses the 'makeef' option instead. This also allows for generating a -unique name, to prevent concurrently running ":make" commands from overwriting -each other's files. - -With 'insertmode' set, a few more things change: -- <Esc> in Normal mode goes to Insert mode. -- <Esc> in Insert mode doesn't leave Insert mode. -- When doing ":set im", go to Insert mode immediately. - -Vim considers a buffer to be changed when the 'fileformat' (formerly the -'textmode' option) is different from the buffer's initial format. - - -CTRL-B in Insert mode gone *i_CTRL-B-gone* --------------------------- - -When Vim was compiled with the |+rightleft| feature, you could use CTRL-B to -toggle the 'revins' option. Unfortunately, some people hit the 'B' key -accidentally when trying to type CTRL-V or CTRL-N and then didn't know how to -undo this. Since toggling the 'revins' option can easily be done with the -mapping below, this use of the CTRL-B key is disabled. You can still use the -CTRL-_ key for this |i_CTRL-_|. > - :imap <C-B> <C-O>:set revins!<CR> - -============================================================================== - NEW FEATURES *new-5* - -Syntax highlighting *new-highlighting* -------------------- - -Vim now has a very flexible way to highlighting just about any type of file. -See |syntax|. Summary: > - :syntax on - -Colors and attributes can be set for the syntax highlighting, and also for -other highlighted items with the ':' flag in the 'highlight' option. All -highlighted items are assigned a highlight group which specifies their -highlighting. See |:highlight|. The default colors have been improved. - -You can use the "Normal" group to set the default fore/background colors for a -color terminal. For the GUI, you can use this group to specify the font, too. - -The "2html.vim" script can be used to convert any file that has syntax -highlighting to HTML. The colors will be exactly the same as how you see them -in Vim. With a HTML viewer you can also print the file with colors. - - -Built-in script language *new-script* ------------------------- - -A few extra commands and an expression evaluator enable you to write simple -but powerful scripts. Commands include ":if" and ":while". Expressions can -manipulate numbers and strings. You can use the '=' register to insert -directly the result of an expression. See |expression|. - - -Perl and Python support *new-perl-python* ------------------------ - -Vim can call Perl commands with ":perldo", ":perl", etc. See |perl|. -Patches made by Sven Verdoolaege and Matt Gerassimoff. - -Vim can call Python commands with ":python" and ":pyfile". See |python|. - -Both of these are only available when enabled at compile time. - - -Win32 GUI version *added-win32-GUI* ------------------ - -The GUI has been ported to MS Windows 95 and NT. All the features of the X11 -GUI are available to Windows users now. |gui-w32| -This also fixes problems with running the Win32 console version under Windows -95, where console support has always been bad. -There is also a version that supports OLE automation interface. |if_ole.txt| -Vim can be integrated with Microsoft Developer Studio using the VisVim DLL. -It is possible to produce a DLL version of gvim with Borland C++ (Aaron). - - -VMS version *added-VMS* ------------ - -Vim can now also be used on VMS systems. Port done by Henk Elbers. -This has not been tested much, but it should work. -Sorry, no documentation! - - -BeOS version *added-BeOS* ------------- - -Vim can be used on BeOS systems (including the BeBox). (Olaf Seibert) -See |os_beos.txt|. - - -Macintosh GUI version *added-Mac* ---------------------- - -Vim can now be used on the Macintosh. (Dany St-Amant) -It has not been tested much yet, be careful! -See |os_mac.txt|. - - -More Vi compatible *more-compatible* ------------------- - -There is now a real Ex mode. Started with the "Q" command, or by calling the -executable "ex" or "gex". |Ex-mode| - -Always allow multi-level undo, also in Vi compatible mode. When the 'u' flag -in 'cpoptions' is included, CTRL-R is used for repeating the undo or redo -(like "." in Nvi). - - -Read input from stdin *read-stdin* ---------------------- - -When using the "-" command-line argument, Vim reads its text input from stdin. -This can be used for putting Vim at the end of a pipe: > - grep "^a.*" *.c | vim - -See |--|. - - -Regular expression patterns *added-regexp* ---------------------------- - -Added specifying a range for the number of matches of a atom: "\{a,b}". |/\{| -Added the "shortest match" regexp "\{-}" (Webb). -Added "\s", matches a white character. Can replace "[ \t]". |/\s| -Added "\S", matches a non-white character. Can replace "[^ \t]". |/\S| - - -Overloaded tags *tag-overloaded* ---------------- - -When using a language like C++, there can be several tags for the same -tagname. Commands have been added to be able to jump to any of these -overloaded tags: -|:tselect| List matching tags, and jump to one of them. -|:stselect| Idem, and split window. -|g_CTRL-]| Do ":tselect" with the word under the cursor. - - After ":ta {tagname}" with multiple matches: -|:tnext| Go to next matching tag. -|:tprevious| Go to previous matching tag. -|:trewind| Go to first matching tag. -|:tlast| Go to last matching tag. - -The ":tag" command now also accepts wildcards. When doing command-line -completion on tags, case-insensitive matching is also available (at the end). - - -New commands *new-commands* ------------- - -|:amenu| Define menus for all modes, inserting a CTRL-O for Insert - mode, ESC for Visual and CTRL-C for Cmdline mode. "amenu" is - used for the default menus and the Syntax menu. - -|:augroup| Set group to be used for following autocommands. Allows the - grouping of autocommands to enable deletion of a specific - group. - -|:crewind| Go to first error. -|:clast| Go to last error. - -|:doautoall| Execute autocommands for all loaded buffers. - -|:echo| Echo its argument, which is an expression. Can be used to - display messages which include variables. - -|:execute| Execute its argument, which is an expression. Can be used to - built up an Ex command with anything. - -|:hide| Works like ":close". - -|:if| Conditional execution, for built-in script language. - -|:intro| Show introductory message. This is always executed when Vim - is started without file arguments. - -|:let| Assign a value to an internal variable. - -|:omap| Map only in operator-pending mode. Makes it possible to map - text-object commands. - -|:redir| Redirect output of messages to a file. - -|:update| Write when buffer has changed. - -|:while| While-loop for built-in script language. - -Visual mode: -|v_O| "O" in Visual block mode, moves the cursor to the other corner - horizontally. -|v_D| "D" in Visual block mode deletes till end of line. - -Insert mode: -|i_CTRL-]| Triggers abbreviation, without inserting any character. - - -New options *added-options* ------------ - -'background' Used for selecting highlight color defaults. Also used in - "syntax.vim" for selecting the syntax colors. Often set - automatically, depending on the terminal used. - -'complete' Specifies how Insert mode completion works. - -'eventignore' Makes it possible to ignore autocommands temporarily. - -'fileformat' Current file format. Replaces 'textmode'. -'fileformats' Possible file formats. Replaces 'textauto'. - New is that this also supports Macintosh format: A single <CR> - separates lines. - The default for 'fileformats' for MS-DOS, Win32 and OS/2 is - "dos,unix", also when 'compatible' set. Unix type files - didn't work anyway when 'fileformats' was empty. - -'guicursor' Set the cursor shape and blinking in various modes. - Default is to adjust the cursor for Insert and Replace mode, - and when an operator is pending. Blinking is default on. - -'fkmap' Farsi key mapping. - -'hlsearch' Highlight all matches with the last used search pattern. - -'hkmapp' Phonetic Hebrew mapping. (Ilya Dogolazky) - -'iconstring' Define the name of the icon, when not empty. (Version 5.2: the - string is used literally, a newline can be used to make two - lines.) - -'lazyredraw' Don't redraw the screen while executing macros, registers or - other not typed commands. - -'makeef' Errorfile to be used for ":make". "##" is replaced with a - unique number. Avoids that two Vim sessions overwrite each - others errorfile. The Unix default is "/tmp/vim##.err"; for - Amiga "t:vim##.Err, for others "vim##.err". - -'matchtime' 1/10s of a second to show a matching paren, when 'showmatch' - is set. Like Nvi. - -'mousehide' Hide mouse pointer in GUI when typing text. - -'nrformats' Defines what bases Vim will consider for numbers when using - the CTRL-A and CTRL-X commands. Default: "hex,octal". - -'shellxquote' Add extra quotes around the whole shell command, including - redirection. - -'softtabstop' Make typing behave like tabstop is set at this value, without - changing the value of 'tabstop'. Makes it more easy to keep - 'ts' at 8, while still getting four spaces for a <Tab>. - -'titlestring' String for the window title, when not empty. (Version 5.2: - this string is used literally, a newline can be used to make - two lines.) - -'verbose' Level of verbosity. Makes it possible to show which .vimrc, - .exrc, .viminfo files etc. are used for initializing. Also - to show autocommands that are being executed. Can also be set - by using the "-V" command-line argument. - - -New command-line arguments *added-cmdline-args* --------------------------- - -|-U| Set the gvimrc file to be used. Like "-u" for the vimrc. - -|-V| Set the 'verbose' option. E.g. "vim -V10". - -|-N| Start in non-compatible mode. - -|-C| Start in compatible mode. - -|-Z| Start in restricted mode, disallow shell commands. Can also - be done by calling the executable "rvim". - -|-h| Show usage information and exit. - - -Various additions *added-various* ------------------ - -Added support for SNiFF+ connection (submitted by Toni Leherbauer). Vim can -be used as an editor for SNiFF. No documentation available... - -For producing a bug report, the bugreport.vim script has been included. -Can be used with ":so $VIMRUNTIME/bugreport.vim", which creates the file -"bugreport.txt" in the current directory. |bugs| - -Added range to ":normal" command. Now you can repeat the same command for -each line in the range. |:normal-range| - -Included support for the Farsi language (Shiran). Only when enabled at -compile time. See |farsi|. - -============================================================================== - IMPROVEMENTS *improvements-5* - -Performance: -- When 'showcmd' was set, mappings would execute much more slowly because the - output would be flushed very often. Helps a lot when executing the "life" - macros with 'showcmd' set. -- Included patches for binary searching in tags file (David O'Neill). - Can be disabled by resetting the 'tagbsearch' option. -- Don't update the ruler when repeating insert (slowed it down a lot). -- For Unix, file name expansion is now done internally instead of starting a - shell for it. -- Expand environment variables with expand_env(), instead of calling the - shell. Makes ":so $VIMRUNTIME/syntax/syntax.vim" a LOT faster. -- Reduced output for cursor positioning: Use CR-LF for moving to first few - columns in next few lines; Don't output CR twice when using termios. -- Optimized cursor positioning. Use CR, BS and NL when it's shorter than - absolute cursor positioning. -- Disable redrawing while repeating insert "1000ii<Esc>". -- Made "d$" or "D" for long lines a lot faster (delete all characters at once, - instead of one by one). -- Access option table by first letter, instead of searching from start. -- Made setting special highlighting attributes a lot faster by using - highlight_attr[], instead of searching in the 'highlight' string. -- Don't show the mode when redrawing is disabled. -- When setting an option, only redraw the screen when required. -- Improved performance of Ex commands by using a lookup table for the first - character. - -Options: -'cinoptions' Added 'g' flag, for C++ scope declarations. -'cpoptions' Added 'E' flag: Disallow yanking, deleting, etc. empty text - area. Default is to allow empty yanks. When 'E' is included, - "y$" in an empty line now is handled as an error (Vi - compatible). - Added 'j' flag: Only add two spaces for a join after a '.', - not after a '?' or '!'. - Added 'A' flag: don't give ATTENTION message. - Added 'L' flag: When not included, and 'list' is set, - 'textwidth' formatting works like 'list' is not set. - Added 'W' flag: Let ":w!" behave like Vi: don't overwrite - readonly files, or a file owned by someone else. -'highlight' Added '@' flag, for '@' characters after the last line on the - screen, and '$' at the end of the line when 'list' is set. - Added 'i' flag: Set highlighting for 'incsearch'. Default - uses "IncSearch" highlight group, which is linked to "Visual". - Disallow 'h' flag in 'highlight' (wasn't used anymore since - 3.0). -'guifont' Win32 GUI only: When set to "*" brings up a font requester. -'guipty' Default on, because so many people need it. -'path' Can contain wildcards, and "**" for searching a whole tree. -'shortmess' Added 'I' flag to avoid the intro message. -'viminfo' Added '%' flag: Store buffer list in viminfo file. - -- Increased defaults for 'maxmem' and 'maxmemtot' for Unix and Win32. Most - machines have much more RAM now that prices have dropped. -- Implemented ":set all&", set all options to their default value. |:set| - -Swap file: -- Don't create a swap file for a readonly file. Then create one on the first - change. Also create a swapfile when the amount of memory used is getting - too high. |swap-file| -- Make swap file "hidden", if possible. On Unix this is done by prepending a - dot to the swap file name. When long file names are used, the DJGPP and - Win32 versions also prepend a dot, in case a file on a mounted Unix file - system is edited. |:swapname| On MSDOS the hidden file attribute is NOT - set, because this causes problems with share.exe. -- 'updatecount' always defaults to non-zero, also for Vi compatible mode. - This means there is a swap file, which can be used for recovery. - -Tags: -- Included ctags 2.0 (Darren Hiebert). The syntax for static tags changed - from - {tag}:{fname} {fname} {command} - to - {tag} {fname} {command};" file: - Which is both faster to parse, shorter and Vi compatible. The old format is - also still accepted, unless disabled in src/feature.h (see OLD_STATIC_TAGS). - |tags-file-format| -- Completion of tags now also includes static tags for other files, at the - end. -- Included "shtags" from Stephen Riehm. -- When finding a matching tag, but the file doesn't exist, continue searching - for another match. Helps when using the same tags file (with links) for - different versions of source code. -- Give a tag with a global match in the current file a higher priority than a - global match in another file. - -Included xxd version V1.8 (Juergen Weigert). - -Autocommands: -- VimLeave autocommands are executed after writing the viminfo file, instead - of before. |VimLeave| -- Allow changing autocommands while executing them. This allows for - self-modifying autocommands. (idea from Goldberg) -- When using autocommands with two or more patterns, could not split - ":if/:endif" over two lines. Now all matching autocommands are executed in - one do_cmdline(). -- Autocommands no longer change the command repeated with ".". -- Search patterns are restored after executing autocommands. This avoids - that the 'hlsearch' highlighting is messed up by autocommands. -- When trying to execute an autocommand, also try matching the pattern with - the short file name. Helps when short file name is different from full - file name (expanded symbolic links). |autocmd-patterns| -- Made the output of ":autocmd" shorter and look better. -- Expand <sfile> in an ":autocmd" when it is defined. |<sfile>| -- Added "nested" flag to ":autocmd", allows nesting. |autocmd-nested| -- Added [group] argument to ":autocmd". Overrides the currently set group. - |autocmd-groups| -- new events: - |BufUnload| before a buffer is unloaded - |BufDelete| before a buffer is deleted from the buffer list - |FileChangedShell| when a file's modification time has changed after - executing a shell command - |User| user-defined autocommand -- When 'modified' was set by a BufRead* autocommand, it was reset again - afterwards. Now the ":set modified" is remembered. - -GUI: -- Improved GUI scrollbar handling when redrawing is slower than the scrollbar - events are generated. -- "vim -u NONE" now also stops loading the .gvimrc and other GUI inits. |-u| - Use "-U" to use another gvimrc file. |-U| -- Handle CTRL-C for external command, also for systems where "setsid()" is - supported. -- When starting the GUI, restrict the window size to the screen size. -- The default menus are read from $VIMRUNTIME/menu.vim. This allows for a - customized default menu. |menu.vim| -- Improved the default menus. Added File/Print, a Window menu, Syntax menu, - etc. -- Added priority to the ":menu" command. Now each menu can be put in a place - where you want it, independent of the order in which the menus are defined. - |menu-priority| - -Give a warning in the intro screen when running the Win32 console version on -Windows 95 because there are problems using this version under Windows 95. -|win32-problems| - -Added 'e' flag for ":substitute" command: Don't complain when not finding a -match (Campbell). |:s| - -When using search commands in a mapping, only the last one is kept in the -history. Avoids that the history is trashed by long mappings. - -Ignore characters after "ex", "view" and "gvim" when checking startup mode. -Allows the use of "gvim5" et. al. |gvim| "gview" starts the GUI in readonly -mode. |gview| - -When resizing windows, the cursor is kept in the same relative position, if -possible. (Webb) - -":all" and ":ball" no longer close and then open a window for the same buffer. -Avoids losing options, jumplist, and other info. - -"-f" command-line argument is now ignored if Vim was compiled without GUI. -|-f| - -In Visual block mode, the right mouse button picks up the nearest corner. - -Changed default mappings for DOS et al. Removed the DOS-specific mappings, -only use the Windows ones. Added Shift-Insert, Ctrl-Insert, Ctrl-Del and -Shift-Del. - -Changed the numbers in the output of ":jumps", so you can see where {count} -CTRL-O takes you. |:jumps| - -Using "~" for $HOME now works for all systems. |$HOME| - -Unix: Besides using CTRL-C, also use the INTR character from the tty settings. -Somebody has INTR set to DEL. - -Allow a <LF> in a ":help" command argument to end the help command, so another -command can follow. - -Doing "%" on a line that starts with " #if" didn't jump to matching "#else". -Don't recognize "#if", "#else" etc. for '%' when 'cpo' contains the '%' flag. -|%| - -Insert mode expansion with "CTRL-N", "CTRL-P" and "CTRL-X" improved -|ins-completion|: -- 'complete' option added. -- When 'nowrapscan' is set, and no match found, report the searched direction - in the error message. -- Repeating CTRL-X commands adds following words/lines after the match. -- When adding-expansions, accept single character matches. -- Made repeated CTRL-X CTRL-N not break undo, and "." repeats the whole - insertion. Also fixes not being able to backspace over a word that has been - inserted with CTRL-N. - -When copying characters in Insert mode from previous/next line, with CTRL-E or -CTRL-Y, 'textwidth' is no longer used. |i_CTRL-E| - -Commands that move in the arglist, like ":n" and ":rew", keep the old cursor -position of the file (this is mostly Vi compatible). - -Vim now remembers the '< and '> marks for each buffer. This fixes a problem -that a line-delete in one buffer invalidated the '< and '> marks in another -buffer. |'<| - -For MSDOS, Unix and OS/2: When $VIM not set, use the path from the executable. -When using the executable path for $VIM, remove "src/" when present. Should -make Vim find the docs and syntax files when it is run directly after -compiling. |$VIM| - -When quitting Visual mode with <Esc>, the cursor is put at start of the Visual -area (like after executing an operator). - -Win32 and Unix version: Removed 1100 character limit on external commands. - -Added possibility to include a space in a ":edit +command" argument, by -putting a backslash before it. |+cmd| - -After recovery, BufReadPost autocommands are applied. |:recover| - -Added color support for "os2ansi", OS/2 console. (Slootman) |os2ansi| - -Allow "%:p:h" when % is empty. |:_%| - -Included "<sfile>": file name from the ":source" command. |<sfile>| - -Added "<Bslash>" special character. Helps for avoiding multiple backslashes -in mappings and menus. - -In a help window, a double-click jumps to the tag under the cursor (like -CTRL-]). - -<C-Left> and <C-Right> now work like <S-Left> and <S-Right>, move a word -forward/backward (Windows compatible). |<C-Left>| - -Removed the requirement for a ":version" command in a .vimrc file. It wasn't -used for anything. You can use ":if" to handle differences between versions. -|:version| - -For MS-DOS, Win32 and OS/2: When comparing file names for autocommands, don't -make a difference between '/' and '\' for path separator. - -New termcap options: -"mb": blink. Can only be used by assigning it to one of the other highlight - options. |t_mb| -"bc": backspace character. |t_bc| -"nd": Used for moving the cursor right in the GUI, to avoid removing one line - of pixels from the last bold character. |t_nd| -"xs": highlighting not erased by overwriting, for hpterm. Combined with - 'weirdinvert'. Visual mode works on hpterm now. |t_xs| - -Unix: Set time of patch and backup file same as original file. (Hiebert). - -Amiga: In QuickFix mode no longer opens another window. Shell commands can be -used now. - -Added decmouse patches from David Binette. Can now use Dec and Netterm mouse. -But only when enabled at compile time. - -Added '#' register: Alternate file name |quote#|. Display '#' register with -":dis" command. |:display| - -Removed ':' from 'isfname' default for Unix. Check for "://" in a file name -anyway. Also check for ":\\", for MS-DOS. - -Added count to "K"eyword command, when 'keywordprg' is "man", is inserted in -the man command. "2K" results in "!man 2 <cword>". |K| - -When using "gf" on a relative path name, remove "../" from the file name, like -it's done for file names in the tags file. |gf| - -When finishing recording, don't make the recorded register the default put -register. - -When using "!!", don't put ":5,5!" on the command-line, but ":.!". And some -other enhancements to replace the line number with "." or "$" when possible. - -MSDOS et al.: Renamed $VIM/viminfo to $VIM/_viminfo. It's more consistent: -.vimrc/_vimrc and .viminfo/_viminfo - -For systems where case doesn't matter in file names (MSDOS, Amiga), ignore -case while sorting file names. For buffer names too. - -When reading from stdin doesn't work, read from stderr (helps for "foo | xargs -vim"). - -32 bit MS-DOS version: Replaced csdpmi3 by csdpmi4. - -Changed <C-Left> and <C-Right> to skip a WORD instead of a word. - -Warning for changed modified time when overwriting a file now also works on -other systems than Unix. - -Unix: Changed the defaults for configure to be the same as the defaults for -Makefile: include GUI, Perl, and Python. - -Some versions of Motif require "-lXpm". Added check for this in configure. - -Don't add "-L/usr/lib" to the link line, causes problems on a few systems. - -============================================================================== - COMPILE TIME CHANGES *compile-changes-5* - -When compiling, allow a choice for minimal, normal or maximal features in an -easy way, by changing a single line in src/feature.h. -The DOS16 version has been compiled with minimal features to avoid running -out of memory too quickly. |dos16| -The Win32, DJGPP, and OS/2 versions use maximal features, because they have -enough memory. -The Amiga version is available with normal and maximal features. - -Added "make test" to Unix version Makefile. Allows for a quick check if most -"normal" commands work properly. Also tests a few specific commands. - -Added setlocale() with codepage support for DJGPP version. - -autoconf: -- Added autoconf check for -lXdmcp. -- Included check for -lXmu, no longer needed to edit the Makefile for this. -- Switched to autoconf 2.12. -- Added configure check for <poll.h>. Seems to be needed when including - Perl on Linux? -- termlib is now checked before termcap. -- Added configure check for strncasecmp(), stricmp() and strnicmp(). Added - vim_stricmp() for when there's no library function for stricmp(). -- Use "datadir" in configure, instead of our own check for HELPDIR. - -Removed "make proto" from Makefile.manx. Could not make it work without a lot -of #ifdefs. - -Removed "proto/" from paths in proto.h. Needed for the Mac port. - -Drastically changed Makefile.mint. Now it includes the Unix Makefile. - -Added support for Dos16 in Makefile.b32 (renamed Makefile.b32 to Makefile.bor) - -All source files are now edited with a tabstop of 8 instead of 4, which is -better when debugging and using other tools. 'softtabstop' is set to 4, to -make editing easier. - -Unix: Added "link.sh" script, which removes a few unnecessary libraries from -the link command. - -Don't use HPUX digraphs by default, but only when HPUX_DIGRAPHS is defined. -|digraphs-default| - -============================================================================== - BUG FIXES *bug-fixes-5* - -Note: Some of these fixes may only apply to test versions which were - created after version 4.6, but before 5.0. - - -When doing ":bdel", try going to the next loaded buffer. Don't rewind to the -start of the buffer list. - -mch_isdir() for Unix returned TRUE for "" on some systems. - -Win32: 'shell' set to "mksnt/sh.exe" breaks ":!" commands. Don't use -backslashes in the temp file names. - -On linux, with a FAT file system, could get spurious "file xxx changed since -editing started" messages, because the time is rounded off to two seconds -unexpectedly. - -Crash in GUI, when selecting a word (double click) and then extend until an -empty line. - -For systems where isdigit() can't handle characters > 255, get_number() caused -a crash when moving the mouse during the prompt for recovery. - -In Insert mode, "CTRL-O P" left the cursor on the last inserted character. -Now the cursor is left after the last putted character. - -When quickfix found an error type other than 'e' or 'w', it was never printed. - -A setting for 'errorfile' in a .vimrc overruled the "-q errorfile" argument. - -Some systems create a file when generating a temp file name. Filtering would -then create a backup file for this, which was never deleted. Now no backup -file is made when filtering. - -simplify_filename() could remove a ".." after a link, resulting in the wrong -file name. Made simplify_filename also work for MSDOS. Don't use it for -Amiga, since it doesn't have "../". - -otherfile() was unreliable when using links. Could think that reading/writing -was for a different file, when it was the same. - -Pasting with mouse in Replace mode didn't replace anything. - -Window height computed wrong when resizing a window with an autocommand (could -cause a crash). - -":s!foo!bar!" wasn't possible (Vi compatible). - -do_bang() freed memory twice when called recursively, because of autocommands -(test11). Thanks to Electric Fence! - -"v$d" on an empty line didn't remove the "-- VISUAL --" mode message from the -command-line, and inverted the cursor. - -":mkexrc" didn't check for failure to open the file, causing a crash. -(Felderhoff). - -Win32 mch_write() wrote past fixed buffer, causing terminal keys no longer to -be recognized. Both console and GUI version. - -Athena GUI: Crash when removing a menu item. Now Vim doesn't crash, but the -reversing of the menu item is still wrong. - -Always reset 'list' option for the help window. - -When 'scrolloff' is non-zero, a 'showmatch' could cause the shown match to be -in the wrong line and the window to be scrolled (Acevedo). - -After ":set all&", 'lines' and 'ttytype' were still non-default, because the -defaults never got set. Now the defaults for 'lines' and 'columns' are set -after detecting the window size. 'term' and 'ttytype' defaults are set when -detecting the terminal type. - -For (most) non-Unix systems, don't add file names with illegal characters when -expanding. Fixes "cannot open swapfile" error when doing ":e *.burp", when -there is no match. - -In X11 GUI, drawing part of the cursor obscured the text. Now the text is -drawn over the cursor, like when it fills the block. (Seibert) - -when started with "-c cmd -q errfile", the cursor would be left in line 1. -Now a ":cc" is done after executing "cmd". - -":ilist" never ignored case, even when 'ignorecase' set. - -"vim -r file" for a readonly file, then making a change, got ATTENTION message -in insert mode, display mixed up until <Esc> typed. Also don't give ATTENTION -message after recovering a file. - -The abbreviation ":ab #i #include" could not be removed. - -CTRL-L completion (longest common match) on command-line didn't work properly -for case-insensitive systems (MS-DOS, Windows, etc.). (suggested by Richard -Kilgore). - -For terminals that can hide the cursor ("vi" termcap entry), resizing the -window caused the cursor to disappear. - -Using an invalid mark in an Ex address didn't abort the command. - -When 'smarttab' set, would use 'shiftround' when inserting a TAB after a -space. Now it always rounds to a tabstop. - -Set '[ and '] marks for ":copy", ":move", ":append", ":insert", ":substitute" -and ":change". (Acevedo). - -"d$" in an empty line still caused an error, even when 'E' is not in -'cpoptions'. - -Help files were stored in the viminfo buffer list without a path. - -GUI: Displaying cursor was not synchronized with other displaying. Caused -several display errors. For example, when the last two lines in the file -start with spaces, "dd" on the last line copied text to the (then) last line. - -Win32: Needed to type CTRL-SHIFT-- to get CTRL-_. - -GUI: Moving the cursor forwards over bold text would remove one column of bold -pixels. - -X11 GUI: When a bold character in the last column was scrolled up or down, one -column of pixels would not be copied. - -Using <BS> to move the cursor left can sometimes erase a character. Now use -"le" termcap entry for this. - -Keyword completion with regexp didn't work. e.g., for "b.*crat". - -Fixed: With CTRL-O that jumps to another file, cursor could end up just after -the line. - -Amiga: '$' was missing from character recognized as wildcards, causing $VIM -sometimes not to be expanded. - -":change" didn't adjust marks for deleted lines. - -":help [range]" didn't work. Also for [pattern], [count] and [quotex]. - -For 'cindent'ing, typing "class::method" doesn't align like a label when the -second ':' is typed. -When inserting a CR with 'cindent' set (and a bunch of other conditions) the -cursor went to a wrong location. -'cindent' was wrong for a line that ends in '}'. -'cindent' was wrong after "else {". - -While editing the cmdline in the GUI, could not use the mouse to select text -from the command-line itself. - -When deleting lines, marks in tag stack were only adjusted for the current -window, not for other windows on the same buffer. - -Tag guessing could find a function "some_func" instead of the "func" we were -looking for. - -Tags file name relative to the current file didn't work. - -":g/pat2/s//pat2/g", causing the number of subs to be reported, used to cause -a scroll up. Now you no longer have to hit <CR>. - -X11 GUI: Selecting text could cause a crash. - -32 bit DOS version: CTRL-C in external command killed Vim. When SHELL is set -to "sh.exe", external commands didn't work. Removed using of command.com, no -longer need to set 'shellquote'. - -Fixed crash when using ":g/pat/i". - -Fixed (potential) crash for X11 GUI, when using an X selection. Was giving a -pointer on the stack to a callback function, now it's static. - -Using "#" and "*" with an operator didn't work. E.g. "c#". - -Command-line expansion didn't work properly after ":*". (Acevedo) - -Setting 'weirdinvert' caused highlighting to be wrong in the GUI. - -":e +4 #" didn't work, because the "4" was in unallocated memory (could cause -a crash). - -Cursor position was wrong for ":e #", after ":e #" failed, because of changes -to the buffer. - -When doing ":buf N", going to a buffer that was edited with ":view", the -readonly flag was reset. Now make a difference between ":e file" and ":buf -file": Only set/reset 'ro' for the first one. - -Avoid |hit-enter| prompt when not able to write viminfo on exit. - -When giving error messages in the terminal where the GUI was started, GUI -escape codes would be written to the terminal. In an xterm this could be seen -as a '$' after the message. - -Mouse would not work directly after ":gui", because full_screen isn't set, -which causes starttermcap() not to do its work. - -'incsearch' did not scroll the window in the same way as the actual search. -When 'nowrap' set, incsearch didn't show a match when it was off the side of -the screen. Now it also shows the whole match, instead of just the cursor -position (if possible). - -":unmap", ":unab" and ":unmenu" did not accept a double quote, it was seen as -the start of a comment. Now it's Vi compatible. - -Using <Up><Left><Left><Up> in the command-line, when there is no previous -cmdline in the history, inserted a NUL on the command-line. - -"i<Esc>" when on a <Tab> in column 0 left the cursor in the wrong place. - -GUI Motif: When adding a lot of menu items, the menu bar goes into two rows. -Deleting menu items, reducing the number of rows, now also works. - -With ":g/pat/s//foo/c", a match in the first line was scrolled off of the -screen, so you could not see it. -When using ":s//c", with 'nowrap' set, a match could be off the side of the -screen, so you could not see it. - -When 'helpfile' was set to a fixed, non-absolute path in feature.h, Vim would -crash. mch_Fullname can now handle file names in read-only memory. (Lottem) - -When using CTRL-A or CTRL-@ in Insert mode, there could be strange effects -when using CTRL-D next. Also, when repeating inserted text that included "0 -CTRL-D" or "^ CTRL-D" this didn't work. (Acevedo) -Using CTRL-D after using CTRL-E or CTRL-Y in Insert mode that inserted a '0' -or '^', removed the '0' or '^' and more indent. - -The command "2".p" caused the last inserted text to be executed as commands. -(Acevedo) - -Repeating the insert of "CTRL-V 048" resulted in "^@" to be inserted. - -Repeating Insert completion could fail if there are special characters in the -text. (Acevedo) - -":normal /string<CR>" caused the window to scroll. Now all ":normal" commands -are executed without scrolling messages. - -Redo of CTRL-E or CTRL-Y in Insert mode interpreted special characters as -commands. - -Line wrapping for 'tw' was done one character off for insert expansion -inserts. - -buffer_exists() function didn't work properly for buffer names with a symbolic -link in them (e.g. when using buffer_exists(#)). - -Removed the "MOTIF_COMMENT" construction from Makefile. It now works with -FreeBSD make, and probably with NeXT make too. - -Matching the 'define' and 'include' arguments now honor the settings for -'ignorecase'. (Acevedo) - -When one file shown in two windows, Visual selection mixed up cursor position -in current window and other window. - -When doing ":e file" from a help file, the 'isk' option wasn't reset properly, -because of a modeline in the help file. - -When doing ":e!", a cursor in another window on the same buffer could become -invalid, leading to "ml_get: invalid lnum" errors. - -Matching buffer name for when expanded name has a different path from not -expanded name (Brugnara). - -Normal mappings didn't work after an operator. For example, with ":map Q gq", -"QQ" didn't work. - -When ":make" resulted in zero errors, a "No Errors" error message was given -(which breaks mappings). - -When ":sourcing" a file, line length was limited to 1024 characters. CTRL-V -before <EOL> was not handled Vi compatible. (Acevedo) - -Unexpected exit for X11 GUI, caused by SAVE_YOURSELF event. (Heimann) - -CTRL-X CTRL-I only found one match per line. (Acevedo) -When using an illegal CTRL-X key in Insert mode, the CTRL-X mode message -was stuck. - -Finally managed to ignore the "Quit" menu entry of the Window manager! Now -Vim only exists when there are no changed buffers. - -Trying to start the GUI when $DISPLAY is not set resulted in a crash. -When $DISPLAY is not set and gvim starts vim, title was restored to "Thanks -for flying Vim". -When $DISPLAY not set, starting "gvim" (dropping back to vim) and then -selecting text with the mouse caused a crash. - -"J", with 'joinspaces' set, on a line ending in ". ", caused one space too -many to be added. (Acevedo) - -In insert mode, a CTRL-R {regname} which didn't insert anything left the '"' -on the screen. - -":z10" didn't work. (Clapp) - -"Help "*" didn't work. - -Renamed a lot of functions, to avoid clashes with POSIX name space. - -When adding characters to a line, making it wrap, the following lines were -sometimes not shifted down (e.g. after a tag jump). - -CTRL-E, with 'so' set and cursor on last line, now does not move cursor as -long as the last line is on the screen. - -When there are two windows, doing "^W+^W-" in the bottom window could cause -the status line to be doubled (not redrawn correctly). - -This command would hang: ":n `cat`". Now connect stdin of the external -command to /dev/null, when expanding. - -Fixed lalloc(0,) error for ":echo %:e:r". (Acevedo) - -The "+command" argument to ":split" didn't work when there was no file name. - -When selecting text in the GUI, which is the output of a command-line command -or an external command, the inversion would sometimes remain. - -GUI: "-mh 70" argument was broken. Now, when menuheight is specified, it is -not changed anymore. - -GUI: When using the scrollbar or mouse while executing an external command, -this caused garbage characters. - -Showmatch sometimes jumped to the wrong position. Was caused by a call to -findmatch() when redrawing the display (when syntax highlighting is on). - -Search pattern "\(a *\)\{3} did not work correctly, also matched "a a". -Problem with brace_count not being decremented. - -Wildcard expansion added too many non-matching file names. - -When 'iskeyword' contains characters like '~', "*" and "#" didn't work -properly. (Acevedo) - -On Linux, on a FAT file system, modification time can change by one second. -Avoid a "file has changed" warning for a one second difference. - -When using the page-switching in an xterm, Vim would position the cursor on -the last line of the window on exit. Also removed the cursor positioning for -":!" commands. - -":g/pat/p" command (partly) overwrote the command. Now the output is on a -separate line. - -With 'ic' and 'scs' set, a search for "Keyword", ignore-case matches were -highlighted too. - -"^" on a line with only white space, put cursor beyond the end of the line. - -When deleting characters before where insertion started ('bs' == 2), could not -use abbreviations. - -CTRL-E at end of file puts cursor below the file, in Visual mode, when 'so' is -non-zero. CTRL-E didn't work when 'so' is big and the line below the window -wraps. CTRL-E, when 'so' is non-zero, at end of the file, caused jumping -up-down. - -":retab" didn't work well when 'list' is set. - -Amiga: When inserting characters at the last line on the screen, causing it -to wrap, messed up the display. It appears that a '\n' on the last line -doesn't always cause a scroll up. - -In Insert mode "0<C-D><C-D>" deleted an extra character, because Vim thought -that the "0" was still there. (Acevedo) - -"z{count}l" ignored the count. Also for "zh" et. al. (Acevedo) - -"S" when 'autoindent' is off didn't delete leading white space. - -"/<Tab>" landed on the wrong character when 'incsearch' is set. - -Asking a yes/no question could cause a |hit-enter| prompt. - -When the file consists of one long line (>4100 characters), making changes -caused various errors and a crash. - -DJGPP version could not save long lines (>64000) for undo. - -"yw" on the last char in the file didn't work. Also fixed "6x" at the end of -the line. "6X" at the start of a line fails, but does not break a mapping. In -general, a movement for an operator doesn't beep or flush a mapping, but when -there is nothing to operate on it beeps (this is Vi compatible). - -"m'" and "m`" now set the '' mark at the cursor position. - -Unix: Resetting of signals for external program didn't work, because SIG_DFL -and NULL are the same! For "!!yes|dd count=1|, the yes command kept on -running. - -Partly fixed: Unix GUI: Typeahead while executing an external command was lost. -Now it's not lost while the command is producing output. - -Typing <S-Tab> in Insert mode, when it isn't mapped, inserted "<S-Tab>". Now -it works like a normal <Tab>, just like <C-Tab> and <M-Tab>. - -Redrawing ruler didn't check for old value correctly (caused UMR warnings in -Purify). - -Negative array index in finish_viminfo_history(). - -":g/^/d|mo $" deleted all the lines. The ":move" command now removes the -:global mark from the moved lines. - -Using "vG" while the last line in the window is a "@" line, didn't update -correctly. Just the "v" showed "~" lines. - -"daw" on the last char of the file, when it's a space, moved the cursor beyond -the end of the line. - -When 'hlsearch' was set or reset, only the current buffer was redrawn, while -this affects all windows. - -CTRL-^, positioning the cursor somewhere from 1/2 to 1 1/2 screen down the -file, put the cursor at the bottom of the window, instead of halfway. - -When scrolling up for ":append" command, not all windows were updated -correctly. - -When 'hlsearch' is set, and an auto-indent is highlighted, pressing <Esc> -didn't remove the highlighting, although the indent was deleted. - -When 'ru' set and 'nosc', using "$j" showed a wrong ruler. - -Under Xfree 3.2, Shift-Tab didn't work (wrong keysym is used). - -Mapping <S-Tab> didn't work. Changed the key translations to use the shortest -key code possible. This makes the termcode translations and mappings more -consistent. Now all modifiers work in all combinations, not only with <Tab>, -but also with <Space>, <CR>, etc. - -For Unix, restore three more signals. And Vim catches SIGINT now, so CTRL-C -in Ex mode doesn't make Vim exit. - -""a5Y" yanked 25 lines instead of 5. - -"vrxxx<Esc>" in an empty line could not be undone. - -A CTRL-C that breaks ":make" caused the errorfile not to be read (annoying -when you want to handle what ":make" produced so far). - -":0;/pat" didn't find "pat" in line 1. - -Search for "/test/s+1" at first char of file gave bottom-top message, or -didn't work at all with 'nowrapscan'. - -Bug in viminfo history. Could cause a crash on exit. - -":print" didn't put cursor on first non-blank in line. - -":0r !cat </dev/null" left cursor in line zero, with very strange effects. - -With 'showcmd' set and 'timeoutlen' set to a few seconds, trick to position -the cursor leftwards didn't work. - -AIX stty settings were restored to cs5 instead of cs8 (Winn). - -File name completion didn't work for "zsh" versions that put spaces between -file names, instead of NULs. - -Changed "XawChain*" to "XtChain*", should work for more systems. - -Included quite a few fixes for rightleft mode (Lottem). - -Didn't ask to |hit-enter| when GUI is started and error messages are printed. - -When trying to edit a file in a non-existent directory, ended up with editing -"No file". - -"gqap" to format a paragraph did too much redrawing. - -When 'hlsearch' set, only the current window was updated for a new search -pattern. - -Sometimes error messages on startup didn't cause a |hit-enter| prompt, -because of autocommands containing an empty line. - -Was possible to select part of the window in the border, below the command -line. - -'< and '> marks were not at the correct position after linewise Visual -selection. - -When translating a help argument to "CTRL-x", prepend or append a '_', when -applicable. - -Blockwise visual mode wasn't correct when moving vertically over a special -character (displayed as two screen characters). - -Renamed "struct option" to "struct vimoption" to avoid name clash with GNU -getopt(). - -":abclear" didn't work (but ":iabclear" and ":cabclear" did work). - -When 'nowrap' used, screen wasn't always updated correctly. - -"vim -c split file" displayed extra lines. - -After starting the GUI, searched the termcap for a "gui" term. - -When 'hls' used, search for "^$" caused a hang. -When 'hls' was set, an error in the last regexp caused trouble. - -Unix: Only output an extra <EOL> on exit when outputted something in the -alternate screen, or when there is a message that needs to be cleared. - -"/a\{" did strange things, depending on previous search. - -"c}" only redrew one line (with -u NONE). - -For mappings, CTRL-META-A was shown as <M-^A> instead of <MC-A>, while :map -only accepts <MC-A>. Now <M-C-A> is shown. - -Unix: When using full path name in a tags file, which contains a link, and -'hidden' set and jumping to a tag in the current file, would get bogus -ATTENTION message. Solved by always expanding file names, even when starting -with '/'. - -'hlsearch' highlighting of special characters (e.g., a TAB) didn't highlight -the whole thing. - -"r<CR>" didn't work correctly on the last char of a line. - -sometimes a window resize or other signal caused an endless loop, involving -set_winsize(). - -"vim -r" didn't work, it would just hang (using tgetent() while 'term' is -empty). - -"gk" while 'nowrap' set moved two lines up. - -When windows are split, a message that causes a scroll-up messed up one of the -windows, which required a CTRL-L to be typed. - -Possible endless loop when using shell command in the GUI. - -Menus defined in the .vimrc were removed when GUI started. - -Crash when pasting with the mouse in insert mode. - -Crash with ":unmenu *" in .gvimrc for Athena. - -"5>>" shifted 5 lines 5 times, instead of 1 time. - -CTRL-C when getting a prompt in ":global" didn't interrupt. - -When 'so' is non-zero, and moving the scrollbar completely to the bottom, -there was a lot of flashing. - -GUI: Scrollbar ident must be long for DEC Alpha. - -Some functions called vim_regcomp() without setting reg_magic, which could -lead to unpredictable magicness. - -Crash when clicking around the status line, could get a selection with a -backwards range. - -When deleting more than one line characterwise, the last character wasn't -deleted. - -GUI: Status line could be overwritten when moving the scrollbar quickly (or -when 'wd' is non-zero). - -An ESC at the end of a ":normal" command caused a wait for a terminal code to -finish. Now, a terminal code is not recognized when its start comes from a -mapping or ":normal" command. - -Included patches from Robert Webb for GUI. Layout of the windows is now done -inside Vim, instead of letting the layout manager do this. Makes Vim work -with Lesstif! - -UMR warning in set_expand_context(). - -Memory leak: b_winlnum list was never freed. - -Removed TIOCLSET/TIOCLGET code from os_unix.c. Was changing some of the -terminal settings, and looked like it wasn't doing anything good. (suggested -by Juergen Weigert). - -Ruler overwrote "is a directory" message. When starting up, and 'cmdheight' -set to > 1, first message could still be in the last line. - -Removed prototype for putenv() from proto.h, it's already in osdef2.h.in. - -In replace mode, when moving the cursor and then backspacing, wrong characters -were inserted. - -Win32 GUI was checking for a CTRL-C too often, making it slow. - -Removed mappings for MS-DOS that were already covered by commands. - -When visually selecting all lines in a file, cursor at last line, then "J". -Gave ml_get errors. Was a problem with scrolling down during redrawing. - -When doing a linewise operator, and then an operator with a mouse click, it -was also linewise, instead of characterwise. - -When 'list' is set, the column of the ruler was wrong. - -Spurious error message for "/\(b\+\)*". - -When visually selected many lines, message from ":w file" disappeared when -redrawing the screen. - -":set <M-b>=^[b", then insert "^[b", waited for another character. And then -inserted "<M-b>" instead of the real <M-b> character. Was trying to insert -K_SPECIAL x NUL. - -CTRL-W ] didn't use count to set window height. - -GUI: "-font" command-line argument didn't override 'guifont' setting from -.gvimrc. (Acevedo) - -GUI: clipboard wasn't used for "*y". And some more Win32/X11 differences -fixed for the clipboard (Webb). - -Jumping from one help file to another help file, with 'compatible' set, -removed the 'help' flag from the buffer. - -File-writable bit could be reset when using ":w!" for a readonly file. - -There was a wait for CTRL-O n in Insert mode, because the search pattern was -shown. -Reduced wait, to allow reading a message, from 10 to 3 seconds. It seemed -nothing was happening. - -":recover" found same swap file twice. - -GUI: "*yy only worked the second time (when pasting to an xterm)." - -DJGPP version (dos32): The system flags were cleared. - -Dos32 version: Underscores were sometimes replaced with y-umlaut (Levin). - -Version 4.1 of ncurses can't handle tputs("", ..). Avoid calling tputs() with -an empty string. - -<S-Tab> in the command-line worked like CTRL-P when no completion started yet. -Now it does completion, last match first. - -Unix: Could get annoying "can't write viminfo" message after doing "su". Now -the viminfo file is overwritten, and the user set back to the original one. - -":set term=builtin_gui" started the GUI in a wrong way. Now it's not -allowed anymore. But "vim -T gui" does start the GUI correctly now. - -GUI: Triple click after a line only put last char in selection, when it is a -single character word. - -When the window is bigger than the screen, the scrolling up of messages was -wrong (e.g. ":vers", ":hi"). Also when the bottom part of the window was -obscured by another window. - -When using a wrong option only an error message is printed, to avoid that the -usage information makes it scroll off the screen. - -When exiting because of not being able to read from stdin, didn't preserve the -swap files properly. - -Visual selecting all chars in more than one line, then hit "x" didn't leave an -empty line. For one line it did leave an empty line. - -Message for which autocommand is executing messed up file write message (for -FileWritePost event). - -"vim -h" included "-U" even when GUI is not available, and "-l" when lisp is -not available. - -Crash for ":he <C-A>" (command-line longer than screen). - -":s/this/that/gc", type "y" two times, then undo, did reset the modified -option, even though the file is still modified. - -Empty lines in a tags file caused a ":tag" to be aborted. - -When hitting 'q' at the more prompt for ":menu", still scrolled a few lines. - -In an xterm that uses the bold trick a single row of characters could remain -after an erased bold character. Now erase one extra char after the bold char, -like for the GUI. - -":pop!" didn't work. - -When the reading a buffer was interrupted, ":w" should not be able to -overwrite the file, ":w!" is required. - -":cf%" caused a crash. - -":gui longfilename", when forking is enabled, could leave part of the -longfilename at the shell prompt. - -============================================================================== -VERSION 5.1 *version-5.1* - -Improvements made between version 5.0 and 5.1. - -This was mostly a bug-fix release, not many new features. - - -Changed *changed-5.1* -------- - -The expand() function now separates file names with <NL> instead of a space. -This avoids problems for file names with embedded spaces. To get the old -result, use substitute(expand(foo), "\n", " ", "g"). - -For Insert-expanding dictionaries allow a backslash to be used for -wildchars. Allows expanding "ze\kra", when 'isk' includes a backslash. - -New icon for the Win32 GUI. - -":tag", ":tselect" etc. only use the argument as a regexp when it starts -with '/'. Avoids that ":tag xx~" gives an error message: "No previous sub. -regexp". Also, when the :tag argument contained wildcard characters, it was -not Vi compatible. -When using '/', the argument is taken literally too, with a higher priority, -so it's found before wildcard matches. -Only when the '/' is used are matches with different case found, even though -'ignorecase' isn't set. -Changed "g^]" to only do ":tselect" when there is more than on matching tag. - -Changed some of the default colors, because they were not very readable on a -dark background. - -A character offset to a search pattern can move the cursor to the next or -previous line. Also fixes that "/pattern/e+2" got stuck on "pattern" at the -end of a line. - -Double-clicks in the status line do no longer start Visual mode. Dragging a -status line no longer stops Visual mode. - -Perl interface: Buffers() and Windows() now use more logical arguments, like -they are used in the rest of Vim (Moore). - -Init '" mark to the first character of the first line. Makes it possible to -use '" in an autocommand without getting an error message. - - -Added *added-5.1* ------ - -"shell_error" internal variable: result of last shell command. - -":echohl" command: Set highlighting for ":echo". - -'S' flag in 'highlight' and StatusLineNC highlight group: highlighting for -status line of not-current window. Default is to use bold for current -window. - -Added buffer_name() and buffer_number() functions (Aaron). -Added flags argument "g" to substitute() function (Aaron). -Added winheight() function. - -Win32: When an external command starts with "start ", no console is opened -for it (Aaron). - -Win32 console: Use termcap codes for bold/reverse based on the current -console attributes. - -Configure check for "strip". (Napier) - -CTRL-R CTRL-R x in Insert mode: Insert the contents of a register literally, -instead of as typed. - -Made a few "No match" error messages more informative by adding the pattern -that didn't match. - -"make install" now also copies the macro files. - -tools/tcltags, a shell script to generate a tags file from a TCL file. - -"--with-tlib" setting for configure. Easy way to use termlib: "./configure ---with-tlib=termlib". - -'u' flag in 'cino' for setting the indent for contained () parts. - -When Win32 OLE version can't load the registered type library, ask the user -if he wants to register Vim now. (Erhardt) -Win32 with OLE: When registered automatically, exit Vim. -Included VisVim 1.1b, with a few enhancements and the new icon (Heiko -Erhardt). - -Added patch from Vince Negri for Win32s support. Needs to be compiled with -VC 4.1! - -Perl interface: Added $curbuf. Rationalized Buffers() and Windows(). -(Moore) Added "group" argument to Msg(). - -Included Perl files in DOS source archive. Changed Makefile.bor and -Makefile.w32 to support building a Win32 version with Perl included. - -Included new Makefile.w32 from Ken Scott. Now it's able to make all Win32 -versions, including OLE, Perl and Python. - -Added CTRL-W g ] and CTRL-W g ^]: split window and do g] or g^]. - -Added "g]" to always do ":tselect" for the ident under the cursor. -Added ":tjump" and ":stjump" commands. -Improved listing of ":tselect" when tag names are a bit long. - -Included patches for the Macintosh version. Also for Python interface. -(St-Amant) - -":buf foo" now also restores cursor column, when the buffer was used before. - -Adjusted the Makefile for different final destinations for the syntax files -and scripts (for Debian Linux). - -Amiga: $VIM can be used everywhere. When $VIM is not defined, "VIM:" is -used. This fixes that "VIM:" had to be assigned for the help files, and -$VIM set for the syntax files. Now either of these work. - -Some xterms send vt100 compatible function keys F1-F4. Since it's not -possible to detect this, recognize both type of keys and translate them to -<F1> - <F4>. - -Added "VimEnter" autocommand. Executed after loading all the startup stuff. - -BeOS version now also runs on Intel CPUs (Seibert). - - -Fixed *fixed-5.1* ------ - -":ts" changed position in the tag stack when cancelled with <CR>. -":ts" changed the cursor position for CTRL-T when cancelled with <CR>. -":tn" would always jump to the second match. Was using the wrong entry in -the tag stack. -Doing "tag foo", then ":tselect", overwrote the original cursor position in -the tag stack. - -"make install" changed the vim.1 manpage in a wrong way, causing "doc/doc" -to appear for the documentation files. - -When compiled with MAX_FEAT, xterm mouse handling failed. Was caused by DEC -mouse handling interfering. - -Was leaking memory when using selection in X11. - -CTRL-D halfway a command-line left some characters behind the first line(s) -of the listing. - -When expanding directories for ":set path=", put two extra backslashes -before a space in a directory name. - -When 'lisp' set, first line of a function would be indented. Now its indent -is set to zero. And use the indent of the first previous line that is at -the same () level. Added test33. - -"so<Esc>u" in an empty file didn't work. - -DOS: "seek error in swap file write" errors, when using DOS 6.2 share.exe, -because the swap file was made hidden. It's no longer hidden. - -":global" command would sometimes not execute on a matching line. Happened -when a data block is full in ml_replace(). - -For AIX use a tgetent buffer of 2048 bytes, instead of 1024. - -Win32 gvim now only sets the console size for external commands to 25x80 -on Windows 95, not on NT. - -Win32 console: Dead key could cause a crash, because of a missing "WINAPI" -(Deshpande). - -The right mouse button started Visual mode, even when 'mouse' is empty, and -in the command-line, a left click moved the cursor when 'mouse' is empty. -In Visual mode, 'n' in 'mouse' would be used instead of 'v'. - -A blinking cursor or focus change cleared a non-Visual selection. - -CTRL-Home and CTRL-End didn't work for MS-DOS versions. - -Could include NUL in 'iskeyword', causing a crash when doing insert mode -completion. - -Use _dos_commit() to flush the swap file to disk for MSDOS 16 bit version. - -In mappings, CTRL-H was replaced by the backspace key code. This caused -problems when it was used as text, e.g. ":map _U :%s/.^H//g<CR>". - -":set t_Co=0" was not handled like a normal term. Now it's translated into -":set t_Co=", which works. - -For ":syntax keyword" the "transparent" option did work, although not -mentioned in the help. But synID() returned wrong name. - -"gqG" in a file with one-word-per-line (e.g. a dictionary) was very slow and -not interruptible. - -"gq" operator inserted screen lines in the wrong situation. Now screen -lines are inserted or deleted when this speeds up displaying. - -cindent was wrong when an "if" contained "((". - -'r' flag in 'viminfo' was not used for '%'. Could get files in the buffer -list from removable media. - -Win32 GUI with OLE: if_ole_vc.mak could not be converted into a project. -Hand-edited to fix this... - -With 'nosol' set, doing "$kdw" below an empty line positioned the cursor at -the end of the line. - -Dos32 version changed "\dir\file" into "/dir/file", to work around a DJGPP -bug. That bug appears to have been fixed, therefore this translation has -been removed. - -"/^*" didn't work (find '*' in first column). - -"<afile>" was not always set for autocommands. E.g., for ":au BufEnter * -let &tags = expand("<afile>:p:h") . "/tags". - -In an xterm, the window may be a child of the outer xterm window. Use the -parent window when getting the title and icon names. (Smith) - -When starting with "gvim -bg black -fg white", the value of 'background' is -only set after reading the .gvimrc file. This causes a ":syntax on" to use -the wrong colors. Now allow using ":gui" to open the GUI window and set the -colors. Previously ":gui" in a gvimrc crashed Vim. - -tempname() returned the same name all the time, unless the file was actually -created. Now there are at least 26 different names. - -File name used for <afile> was sometimes full path, sometimes file name -relative to current directory. - -When 'background' was set after the GUI window was opened, it could change -colors that were set by the user in the .gvimrc file. Now it only changes -colors that have not been set by the user. - -Ignore special characters after a CSI in the GUI version. These could be -interpreted as special characters in a wrong way. (St-Amant) - -Memory leak in farsi code, when using search or ":s" command. -Farsi string reversing for a mapping was only done for new mappings. Now it -also works for replacing a mapping. - -Crash in Win32 when using a file name longer than _MAX_PATH. (Aaron) - -When BufDelete autocommands were executed, some things for the buffer were -already deleted (esp. Perl stuff). - -Perl interface: Buffer specific items were deleted too soon; fixes "screen -no longer exists" messages. (Moore) - -The Perl functions didn't set the 'modified' flag. - -link.sh did not return an error on exit, which may cause Vim to start -installing, even though there is no executable to install. (Riehm) - -Vi incompatibility: In Vi "." redoes the "y" command. Added the 'y' flag to -'cpoptions'. Only for 'compatible' mode. - -":echohl" defined a new group, when the argument was not an existing group. - -"syn on" and ":syn off" could move the cursor, if there is a hidden buffer -that is shorter that the current cursor position. - -The " mark was not set when doing ":b file". - -When a "nextgroup" is used with "skipwhite" in syntax highlighting, space at -the end of the line made the nextgroup also be found in the next line. - -":he g<CTRL-D>", then ":" and backspace to the start didn't redraw. - -X11 GUI: "gvim -rv" reversed the colors twice on Sun. Now Vim checks if the -result is really reverse video (background darker than foreground). - -"cat link.sh | vim -" didn't set syntax highlighting. - -Win32: Expanding "file.sw?" matched ".file.swp". This is an error of -FindnextFile() that we need to work around. (Kilgore) - -"gqgq" gave an "Invalid lnum" error on the last line. -Formatting with "gq" didn't format the first line after a change of comment -leader. - -There was no check for out-of-memory in win_alloc(). - -"vim -h" didn't mention "-register" and "-unregister" for the OLE version. - -Could not increase 'cmdheight' when the last window is only one line. Now -other windows are also made smaller, when necessary. - -Added a few {} to avoid "suggest braces around" warnings from gcc 2.8.x. -Changed return type of main() from void to int. (Nam) - -Using '~' twice in a substitute pattern caused a crash. - -"syn on" and ":syn off" could scroll the window, if there is a hidden buffer -that is shorter that the current cursor position. - -":if 0 | if 1 | endif | endif" didn't work. Same for ":while" and "elseif". - -With two windows on modified files, with 'autowrite' set, cursor in second -window, ":qa" gave a warning for the file in the first window, but then -auto-wrote the file in the second window. (Webb) - -Win32 GUI scrollbar could only handle 32767 lines. Also makes the -intellimouse wheel use the configurable number of scrolls. (Robinson) - -When using 'patchmode', and the backup file is on another partition, the file -copying messed up the write-file message. - -GUI X11: Alt-Backspace and Alt-Delete didn't work. - -"`0" could put the cursor after the last character in the line, causing -trouble for other commands, like "i". - -When completing tags in insert mode with ^X^], some matches were skipped, -because the compare with other tags was wrong. E.g., when "mnuFileSave" was -already there, "mnuFile" would be skipped. (Negri) - -When scrolling up/down, a syntax item with "keepend" didn't work properly. -Now the flags are also stored for the syntax state at the start of each line. - -When 'ic' was changed while 'hlsearch' is on, there was no redraw to show the -effect. - -Win32 GUI: Don't display "No write since last chance" in a message box, but in -the Vim window. - -============================================================================== -VERSION 5.2 *version-5.2* - -Improvements made between version 5.1 and 5.2. - - -Long lines editable *long-lines* -------------------- - -A single long line that doesn't fit in the window doesn't show a line of @@@ -anymore. Redrawing starts at a character further on in the line, such that -the text around the cursor can be seen. This makes it possible to edit these -long lines when wrapping is on. - - -File browser added *file-browser-5.2* ------------------- - -The Win32, Athena and Motif GUI bring up a file requester if the user asks to -":browse" for the ":e", ":w", ":r", ":so", ":redirect" and -":mkexrc/vimrc/vsess" commands. ::browse e /foo/bar" opens the requester in -the /foo/bar directory, so you can have nice mapping rhs's like ":browse so -$vim/macros". If no initial dir specified for ":browse e", can be compiled to -either begin in the current directory, or that of the current buffer. (Negri -and Kahn) -Added the 'browsedir' option, with value "current", "last" or "buffer". Tells -whether a browse dialog starts in last used dir, dir of current buffer, or -current dir. ":browse w" is unaffected. -The default menus have been changed to use the ":browse" command. - - -Dialogs added *dialogs-added* -------------- - -Added the ":confirm" command. Works on ":e", ":q", ":w", ":cl". Win32, -Athena and Motif GUI uses a window-dialog. All other platforms can use -prompt in command-line. ":confirm qa" offers a choice to save all modified -files. - -confirm() function: allows user access to the confirm engine. - -Added 'v' flag to 'guioptions'. When included, a vertical button layout is -always used for the Win32 GUI dialog. Otherwise, a horizontal layout is -preferred. - -Win32 GUI: ":promptfind" and ":promptrepl" pop up a dialog to find/replace. -To be used from a menu entry. (Negri) - - -Popup menu added *popup-menu-added* ----------------- - -When the 'mousemodel' option is set to "popup", the right mouse button -displays the top level menu headed with "PopUp" as pop-up context menu. The -"PopUp" menu is not displayed in the normal menu bar. This currently only -works for Win32 and Athena GUI. - - -Select mode added *new-Select-mode* ------------------ - -A new mode has been added: "Select mode". It is like Visual mode, but typing -a printable character replaces the selection. -- CTRL-G can be used to toggle between Visual mode and Select mode. -- CTRL-O can be used to switch from Select mode to Visual mode for one command. -- Added 'selectmode' option: tells when to start Select mode instead of Visual - mode. -- Added 'mousemodel' option: Change use of mouse buttons. -- Added 'keymodel' option: tells to use shifted special keys to start a - Visual or Select mode selection. -- Added ":behave". Can be used to quickly set 'selectmode', 'mousemodel' - and 'keymodel' for MS-Windows and xterm behavior. -- The xterm-like selection is now called modeless selection. -- Visual mode mappings and menus are used in Select mode. They automatically - switch to Visual mode first. Afterwards, reselect the area, unless it was - deleted. The "gV" command can be used in a mapping to skip the reselection. -- Added the "gh", "gH" and "g^H" commands: start Select (highlight) mode. -- Backspace in Select mode deletes the selected area. - -"mswin.vim" script. Sets behavior mostly like MS-Windows. - - -Session files added *new-session-files* -------------------- - -":mks[ession]" acts like "mkvimrc", but also writes the full filenames of the -currently loaded buffers and current directory, so that :so'ing the file -re-loads those files and cd's to that directory. Also stores and restores -windows. File names are made relative to session file. -The 'sessionoptions' option sets behavior of ":mksession". (Negri) - - -User defined functions and commands *new-user-defined* ------------------------------------ - -Added user defined functions. Defined with ":function" until ":endfunction". -Called with "Func()". Allows the use of a variable number of arguments. -Included support for local variables "l:name". Return a value with ":return". -See |:function|. -Call a function with ":call". When using a range, the function is called for -each line in the range. |:call| -"macros/justify.vim" is an example of using user defined functions. -User functions do not change the last used search pattern or the command to be -redone with ".". -'maxfuncdepth' option. Restricts the depth of function calls. Avoids trouble -(crash because of out-of-memory) when a function uses endless recursion. - -User definable Ex commands: ":command", ":delcommand" and ":comclear". -(Moore) See |user-commands|. - - -New interfaces *interfaces-5.2* --------------- - -Tcl interface. (Wilken) See |tcl|. -Uses the ":tcl", ":tcldo" and "tclfile" commands. - -Cscope support. (Kahn) (Sekera) See |cscope|. -Uses the ":cscope" and ":cstag" commands. Uses the options 'cscopeprg', -'cscopetag', 'cscopetagorder' and 'cscopeverbose'. - - -New ports *ports-5.2* ---------- - -Amiga GUI port. (Nielsen) Not tested much yet! - -RISC OS version. (Thomas Leonard) See |riscos|. -This version can run either with a GUI or in text mode, depending upon where -it is invoked. -Deleted the "os_archie" files, they were not working anyway. - - -Multi-byte support *new-multi-byte* ------------------- - -MultiByte support for Win32 GUI. (Baek) -The 'fileencoding' option decides how the text in the file is encoded. -":ascii" works for multi-byte characters. Multi-byte characters work on -Windows 95, even when using the US version. (Aaron) -Needs to be enabled in feature.h. -This has not been tested much yet! - - -New functions *new-functions-5.2* -------------- - -|browse()| puts up a file requester when available. (Negri) -|escape()| escapes characters in a string with a backslash. -|fnamemodify()| modifies a file name. -|input()| asks the user to enter a line. (Aaron) There is a separate - history for lines typed for the input() function. -|argc()| -|argv()| can be used to access the argument list. -|winbufnr()| buffer number of a window. (Aaron) -|winnr()| window number. (Aaron) -|matchstr()| Return matched string. -|setline()| Set a line to a string value. - - -New options *new-options-5.2* ------------ - -'allowrevins' Enable the CTRL-_ command in Insert and Command-line mode. -'browsedir' Tells in which directory a browse dialog starts. -'confirm' when set, :q :w and :e commands always act as if ":confirm" - is used. (Negri) -'cscopeprg' -'cscopetag' -'cscopetagorder' -'cscopeverbose' Set the |cscope| behavior. -'filetype' RISC-OS specific type of file. -'grepformat' -'grepprg' For the |:grep| command. -'keymodel' Tells to use shifted special keys to start a Visual or Select - mode selection. -'listchars' Set character to show in 'list' mode for end-of-line, tabs and - trailing spaces. (partly by Smith) Also sets character to - display if a line doesn't fit when 'nowrap' is set. -'matchpairs' Allows matching '<' with '>', and other single character - pairs. -'mousefocus' Window focus follows mouse (partly by Terhaar). Changing the - focus with a keyboard command moves the pointer to that - window. Also move the pointer when changing the window layout - (split window, change window height, etc.). -'mousemodel' Change use of mouse buttons. -'selection' When set to "inclusive" or "exclusive", the cursor can go one - character past the end of the line in Visual or Select mode. - When set to "old" the old behavior is used. When - "inclusive", the character under the cursor is included in the - operation. When using "exclusive", the new "ve" entry of - 'guicursor' is used. The default is a vertical bar. -'selectmode' Tells when to start Select mode instead of Visual mode. -'sessionoptions' Sets behavior of ":mksession". (Negri) -'showfulltag' When completing a tag in Insert mode, show the tag search - pattern (tidied up) as a choice as well (if there is one). -'swapfile' Whether to use a swap file for a buffer. -'syntax' When it is set, the syntax by that name is loaded. Allows for - setting a specific syntax from a modeline. -'ttymouse' Allows using xterm mouse codes for terminals which name - doesn't start with "xterm". -'wildignore' List of patterns for files that should not be completed at - all. -'wildmode' Can be used to set the type of expansion for 'wildchar'. - Replaces the CTRL-T command for command line completion. - Don't beep when listing all matches. -'winaltkeys' Win32 and Motif GUI. When "yes", ALT keys are handled - entirely by the window system. When "no", ALT keys are never - used by the window system. When "menu" it depends on whether - a key is a menu shortcut. -'winminheight' Minimal height for each window. Default is 1. Set to 0 if - you want zero-line windows. Scrollbar is removed for - zero-height windows. (Negri) - - - -New Ex commands *new-ex-commands-5.2* ---------------- - -|:badd| Add file name to buffer list without side effects. (Negri) -|:behave| Quickly set MS-Windows or xterm behavior. -|:browse| Use file selection dialog. -|:call| Call a function, optionally with a range. -|:cnewer| -|:colder| To access a stack of quickfix error lists. -|:comclear| Clear all user-defined commands. -|:command| Define a user command. -|:continue| Go back to ":while". -|:confirm| Ask confirmation if something unexpected happens. -|:cscope| Execute cscope command. -|:cstag| Use cscope to jump to a tag. -|:delcommand| Delete a user-defined command. -|:delfunction| Delete a user-defined function. -|:endfunction| End of user-defined function. -|:function| Define a user function. -|:grep| Works similar to ":make". (Negri) -|:mksession| Create a session file. -|:nohlsearch| Stop 'hlsearch' highlighting for a moment. -|:Print| This is Vi compatible. Does the same as ":print". -|:promptfind| Search dialog (Win32 GUI). -|:promptrepl| Search/replace dialog (Win32 GUI). -|:return| Return from a user-defined function. -|:simalt| Win32 GUI: Simulate alt-key pressed. (Negri) -|:smagic| Like ":substitute", but always use 'magic'. -|:snomagic| Like ":substitute", but always use 'nomagic'. -|:tcl| Execute TCL command. -|:tcldo| Execute TCL command for a range of lines. -|:tclfile| Execute a TCL script file. -|:tearoff| Tear-off a menu (Win32 GUI). -|:tmenu| -|:tunmenu| Win32 GUI: menu tooltips. (Negri) -|:star| :* Execute a register. - - -Changed *changed-5.2* -------- - -Renamed functions: - buffer_exists() -> bufexists() - buffer_name() -> bufname() - buffer_number() -> bufnr() - file_readable() -> filereadable() - highlight_exists() -> hlexists() - highlightID() -> hlID() - last_buffer_nr() -> bufnr("$") -The old ones are still there, for backwards compatibility. - -The CTRL-_ command in Insert and Command-line mode is only available when the -new 'allowrevins' option is set. Avoids that people who want to type SHIFT-_ -accidentally enter reverse Insert mode, and don't know how to get out. - -When a file name path in ":tselect" listing is too long, remove a part in the -middle and put "..." there. - -Win32 GUI: Made font selector appear inside Vim window, not just any odd -place. (Negri) - -":bn" skips help buffers, unless currently in a help buffer. (Negri) - -When there is a status line and only one window, don't show '^' in the status -line of the current window. - -":*" used to be used for "'<,'>", the Visual area. But in Vi it's used as an -alternative for ":@". When 'cpoptions' includes '*' this is Vi compatible. - -When 'insertmode' is set, using CTRL-O to execute a mapping will work like -'insertmode' was not set. This allows "normal" mappings to be used even when -'insertmode' is set. - -When 'mouse' was set already (e.g., in the .vimrc file), don't automatically -set 'mouse' when the GUI starts. - -Removed the 'N', 'I' and 'A' flags from the 'mouse' option. - -Renamed "toggle option" to "boolean option". Some people thought that ":set -xyz" would toggle 'xyz' on/off each time. - -The internal variable "shell_error" contains the error code from the shell, -instead of just 0 or 1. - -When inserting or replacing, typing CTRL-V CTRL-<CR> used to insert "<C-CR>". -That is not very useful. Now the CTRL key is ignored and a <CR> is inserted. -Same for all other "normal" keys with modifiers. Mapping these modified key -combinations is still possible. -In Insert mode, <C-CR> and <S-Space> can be inserted by using CTRL-K and then -the special character. - -Moved "quotes" file to doc/quotes.txt, and "todo" file to doc/todo.txt. They -are now installed like other documentation files. - -winheight() function returns -1 for a non-existing window. It used to be -zero, but that is a valid height now. - -The default for 'selection' is "inclusive", which makes a difference when -using "$" or the mouse to move the cursor in Visual mode. - -":q!" does not exit when there are changed buffers which are hidden. Use -":qa!" to exit anyway. - -Disabled the Perl/Python/Tcl interfaces by default. Not many people use them -and they make the executable a lot bigger. The internal scripting language is -now powerful enough for most tasks. - -The strings from the 'titlestring' and 'iconstring' options are used -untranslated for the Window title and icon. This allows for including a <CR>. -Previously a <CR> would be shown as "^M" (two characters). - -When a mapping is started in Visual or Select mode which was started from -Insert mode (the mode shows "(insert) Visual"), don't return to Insert mode -until the mapping has ended. Makes it possible to use a mapping in Visual -mode that also works when the Visual mode was started from Select mode. - -Menus in $VIMRUNTIME/menu.vim no longer overrule existing menus. This helps -when defining menus in the .vimrc file, or when sourcing mswin.vim. - -Unix: Use /var/tmp for .swp files, if it exists. Files there survive a -reboot (at least on Linux). - - -Added *added-5.2* ------ - ---with-motif-lib configure argument. Allows for using a static Motif library. - -Support for mapping numeric keypad +,-,*,/ keys. (Negri) -When not mapped, they produce the normal character. - -Win32 GUI: When directory dropped on Gvim, cd there and edit new buffer. -(Negri) - -Win32 GUI: Made CTRL-Break work as interrupt, so that CTRL-C can be -used for mappings. - -In the output of ":map", highlight the "*" to make clear it's not part of the -rhs. (Roemer) - -When showing the Visual area, the cursor is not switched off, so that it can -be located. The Visual area is now highlighted with a grey background in the -GUI. This makes the cursor visible when it's also reversed. - -Win32: When started with single full pathname (e.g. via double-clicked file), -cd to that file's directory. (Negri) - -Win32 GUI: Tear-off menus, with ":tearoff <menu-name>" command. (Negri) -'t' option to 'guioptions': Add tearoff menu items for Win32 GUI and Motif. -It's included by default. -Win32 GUI: tearoff menu with submenus is indicated with a ">>". (Negri) - -Added ^Kaa and ^KAA digraphs. -Added "euro" symbol to digraph.c. (Corry) - -Support for Motif menu shortcut keys, using '&' like MS-Windows (Ollis). -Other GUIs ignore '&' in a menu name. - -DJGPP: Faster screen updating (John Lange). - -Clustering of syntax groups ":syntax cluster" (Bigham). -Including syntax files: ":syntax include" (Bigham). - -Keep column when switching buffers, when 'nosol' is set (Radics). - -Number function for Perl interface. - -Support for Intellimouse in Athena GUI. (Jensen) - -":sleep" also accepts an argument in milliseconds, when "m" is used. - -Added 'p' flag in 'guioptions': Install callbacks for enter/leave window -events. Makes cursor blinking work for Terhaar, breaks it for me. - -"--help" and "--version" command-line arguments. - -Non-text in ":list" output is highlighted with NonText. - -Added text objects: "i(" and "i)" as synonym for "ib". "i{" and "i}" as -synonym for "iB". New: "i<" and "i>", to select <thing>. All this also for -"a" objects. - -'O' flag in 'shortmess': message for reading a file overwrites any previous -message. (Negri) - -Win32 GUI: 'T' flag in 'guioptions': switch toolbar on/off. -Included a list with self-made toolbar bitmaps. (Negri) - -Added menu priority for sub-menus. Implemented for Win32 and Motif GUI. -Display menu priority with ":menu" command. -Default and Syntax menus now include priority for items. Allows inserting -menu items in between the default ones. - -When the 'number' option is on, highlight line numbers with the LineNr group. - -"Ignore" highlight group: Text highlighted with this is made blank. It is -used to hide special characters in the help text. - -Included Exuberant Ctags version 2.3, with C++ support, Java support and -recurse into directories. (Hiebert) - -When a tags file is not sorted, and this is detected (in a simplistic way), an -error message is given. - -":unlet" accepts a "!", to ignore non-existing variables, and accepts more -than one argument. (Roemer) -Completion of variable names for ":unlet". (Roemer) - -When there is an error in a function which is called by another function, show -the call stack in the error message. - -New file name modifiers: -":.": reduce file name to be relative to current dir. -":~": reduce file name to be relative to home dir. -":s?pat?sub?": substitute "pat" with "sub" once. -":gs?pat?sub?": substitute "pat" with "sub" globally. - -New configure arguments: --enable-min-features and --enable-max-features. -Easy way to switch to minimum or maximum features. - -New compile-time feature: modify_fname. For file name modifiers, e.g, -"%:p:h". Can be disabled to save some code (16 bit DOS). - -When using whole-line completion in Insert mode, and 'cindent' is set, indent -the line properly. - -MSDOS and Win32 console: 'guicursor' sets cursor thickness. (Negri) - -Included new set of Farsi fonts. (Shiran) - -Accelerator text now also works in Motif. All menus can be defined with & for -mnemonic and TAB for accelerator text. They are ignored on systems that don't -support them. -When removing or replacing a menu, compare the menu name only up to the <Tab> -before the mnemonic. - -'i' and 'I' flags after ":substitute": ignore case or not. - -"make install" complains if the runtime files are missing. - -Unix: When finding an existing swap file that can't be opened, mention the -owner of the file in the ATTENTION message. - -The 'i', 't' and 'k' options in 'complete' now also print the place where they -are looking for matches. (Acevedo) - -"gJ" command: Join lines without inserting a space. - -Setting 'keywordprg' to "man -s" is handled specifically. The "-s" is removed -when no count given, the count is added otherwise. Configure checks if "man --s 2 read" works, and sets the default for 'keywordprg' accordingly. - -If you do a ":bd" and there is only one window open, Vim tries to move to a -buffer of the same type (i.e. non-help to non-help, help to help), for -consistent behavior to :bnext/:bprev. (Negri) - -Allow "<Nop>" to be used as the rhs of a mapping. ":map xx <Nop>", maps "xx" -to nothing at all. - -In a ":menu" command, "<Tab>" can be used instead of a real tab, in the menu -path. This makes it more easy to type, no backslash needed. - -POSIX compatible character classes for regexp patterns: [:alnum:], [:alpha:], -[:blank:], [:cntrl:], [:digit:], [:graph:], [:lower:], [:print:], [:punct:], -[:space:], [:upper:] and [:xdigit:]. (Briscoe) - -regexp character classes (for fast syntax highlight matching): - digits: \d [0-9] \D not digit (Roemer) - hex: \x [0-9a-fA-F] \X not hex - octal: \o [0-7] \O not octal - word: \w [a-zA-Z0-9_] \W not word - head: \h [a-zA-Z_] \H not head - alphabetic: \a [a-zA-Z] \A not alphabetic - lowercase: \l [a-z] \L not lowercase - uppercase: \u [A-Z] \U not uppercase - -":set" now accepts "+=", |^=" and "-=": add or remove parts of a string -option, add or subtract a number from a number option. A comma is -automagically inserted or deleted for options that are a comma separated list. - -Filetype feature, for autocommands. Uses a file type instead of a pattern to -match a file. Currently only used for RISC OS. (Leonard) - -In a pattern for an autocommand, environment variables can be used. They are -expanded when the autocommand is defined. - -"BufFilePre" and "BufFilePost" autocommand evens: Before and after applying -the ":file" command to change the name of a buffer. -"VimLeavePre" autocommand event: before writing the .viminfo file. - -For autocommands argument: <abuf> is buffer number, like <afile>. - -Made syntax highlighting a bit faster when scrolling backwards, by keeping -more syncing context. - -Win32 GUI: Made scrolling faster by avoiding a redraw when deleting or -inserting screen lines. - -GUI: Made scrolling faster by not redrawing the scrollbar when the thumb moved -less than a pixel. - -Included ":highlight" in bugreport.vim. - -Created install.exe program, for simplistic installation on DOS and -MS-Windows. - -New register: '_', the black hole. When writing to it, nothing happens. When -reading from it, it's always empty. Can be used to avoid a delete or change -command to modify the registers, or reduce memory use for big changes. - -CTRL-V xff enters character by hex number. CTRL-V o123 enters character by -octal number. (Aaron) - -Improved performance of syntax highlighting by skipping check for "keepend" -when there isn't any. - -Moved the mode message ("-- INSERT --") to the last line of the screen. When -'cmdheight' is more than one, messages will remain readable. - -When listing matching files, they are also sorted on 'suffixes', such that -they are listed in the same order as CTRL-N retrieves them. - -synIDattr() takes a third argument (optionally), which tells for which -terminal type to get the attributes for. This makes it possible to run -2html.vim outside of gvim (using color names instead of #RRGGBB). - -Memory profiling, only for debugging. Prints at exit, and with "g^A" command. -(Kahn) - -DOS: When using a file in the current drive, remove the drive name: -"A:\dir\file" -> "\dir\file". This helps when moving a session file on a -floppy from "A:\dir" to "B:\dir". - -Increased number of remembered jumps from 30 to 50 per window. - -Command to temporarily disable 'hls' highlighting until the next search: -":nohlsearch". - -"gp" and "gP" commands: like "p" and "P", but leave the cursor just after the -inserted text. Used for the CTRL-V command in MS-Windows mode. - - -Fixed *fixed-5.2* ------ - -Win32 GUI: Could draw text twice in one place, for fake-bold text. Removed -this, Windows will handle the bold text anyway. (Negri) - -patch 5.1.1: Win32s GUI: pasting caused a crash (Negri) - -patch 5.1.2: When entering another window, where characters before the cursor -have been deleted, could have a cursor beyond the end of the line. - -patch 5.1.3: Win32s GUI: Didn't wait for external command to finish. (Negri) - -patch 5.1.4: Makefile.w32 can now also be used to generate the OLE version -(Scott). - -patch 5.1.5: Crashed when using syntax highlighting: cursor on a line that -doesn't fit in the window, and splitting that line in two. - -patch 5.1.6: Visual highlighting bug: After ":set nowrap", go to end of line -(so that the window scrolls horizontally), ":set wrap". Following Visual -selection was wrong. - -patch 5.1.7: When 'tagbsearch' off, and 'ignorecase' off, still could do -binary searching. - -patch 5.1.8: Win32 GUI: dragging the scrollbar didn't update the ruler. - -patch 5.1.9: Using ":gui" in .vimrc, caused xterm cursor to disappear. - -patch 5.1.10: A CTRL-N in Insert mode could cause a crash, when a buffer -without a name exists. - -patch 5.1.11: "make test" didn't work in the shadow directory. Also adjusted -"make shadow" for the links in the ctags directory. - -patch 5.1.12: "buf 123foo" used "123" as a count, instead as the start of a -buffer name. - -patch 5.1.13: When completing file names on the command-line, reallocating the -command-line may go wrong. - -patch 5.1.14: ":[nvci]unmenu" removed menu for all modes, when full menu patch -specified. - -Graceful handling of NULLs in drag-dropped file list. Handle passing NULL to -Fullname_save(). (Negri) - -Win32: ":!start" to invoke a program without opening a console, swapping -screens, or waiting for completion in either console or gui version, e.g. you -can type ":!start winfile". ALSO fixes "can't delete swapfile after spawning -a shell" bug. (enhancement of Aaron patch) (Negri) - -Win32 GUI: Fix CTRL-X default keymapping to be more Windows-like. (Negri) - -Shorten filenames on startup. If in /foo/bar, entering "vim ../bar/bang.c" -displays "bang.c" in status bar, not "/foo/bar/bang.c" (Negri) - -Win32 GUI: No copy to Windows clipboard when it's not desired. - -Win32s: Fix pasting from clipboard - made an assumption not valid under -Win32s. (Negri) - -Win32 GUI: Speed up calls to gui_mch_draw_string() and cursor drawing -functions. (Negri) - -Win32 GUI: Middle mouse button emulation now works in GUI! (Negri) - -Could skip messages when combining commands in one line, e.g.: -":echo "hello" | write". - -Perl interpreter was disabled before executing VimLeave autocommands. Could -not use ":perl" in them. (Aaron) - -Included patch for the Intellimouse (Aaron/Robinson). - -Could not set 'ls' to one, when last window has only one line. (Mitterand) - -Fixed a memory leak when removing menus. - -After ":only" the ruler could overwrite a message. - -Dos32: removed changing of __system_flags. It appears to work better when -it's left at the default value. - -p_aleph was an int instead of along, caused trouble on systems where -sizeof(int) != sizeof(long). (Schmidt) - -Fixed enum problems for Ultrix. (Seibert) - -Small redraw problem: "dd" on last line in file cleared wrong line. - -Didn't interpret "cmd | endif" when "cmd" starts with a range. E.g. "if 0 | -.d | endif". - -Command "+|" on the last line of the file caused ml_get errors. - -Memory underrun in eval_vars(). (Aaron) - -Don't rename files in a difficult way, except on Windows 95 (was also done on -Windows NT). - -Win32 GUI: An external command that produces an error code put the error -message in a dialog box. had to close the window and close the dialog. Now -the error code is displayed in the console. (Negri) - -"comctl32.lib" was missing from the GUI libraries in Makefile.w32. (Battle) - -In Insert mode, when entering a window in Insert mode, allow the cursor to be -one char beyond the text. - -Renamed machine dependent rename() to mch_rename(). Define mch_rename() to -rename() when it works properly. - -Rename vim_chdir() to mch_chdir(), because it's machine dependent. - -When using an arglist, and editing file 5 of 4, ":q" could cause "-1 more -files to edit" error. - -In if_python.c, VimCommand() caused an assertion when a do_cmdline() failed. -Moved the Python_Release_Vim() to before the VimErrorCheck(). (Harkins) - -Give an error message for an unknown argument after "--". E.g. for "vim ---xyz". - -The FileChangedShell autocommand didn't set <afile> to the name of the changed -file. - -When doing ":e file", causing the attention message, there sometimes was no -hit-enter prompt. Caused by empty line or "endif" at end of sourced file. - -A large number of patches for the VMS version. (Hunsaker) - -When CTRL-L completion (find longest match) results in a shorter string, no -completion is done (happens with ":help"). - -Crash in Win32 GUI version, when using an Ex "@" command, because -LinePointers[] was used while not initialized. - -Win32 GUI: allow mapping of Alt-Space. - -Output from "vim -h" was sent to stderr. Sending it to stdout is better, so -one can use "vim -h | more". - -In command-line mode, ":vi[!]" should reload the file, just like ":e[!]". -In Ex mode, ":vi" stops Ex mode, but doesn't reload the file. This is Vi -compatible. - -When using a ":set ls=1" in the .gvimrc file, would get a status line for a -single window. (Robinson) - -Didn't give an error message for ":set ai,xx". (Roemer) -Didn't give an error message for ":set ai?xx", ":set ai&xx", ":set ai!xx". - -Non-Unix systems: That a file exists but is unreadable is recognized as "new -file". Now check for existence when file can't be opened (like Unix). - -Unix: osdef.sh didn't handle declarations where the function name is at the -first column of the line. - -DJGPP: Shortening of file names didn't work properly, because get_cwd() -returned a path with backslashes. (Negri) - -When using a 'comments' part where a space is required after the middle part, -always insert a space when starting a new line. Helps for C comments, below a -line with "/****". - -Replacing path of home directory with "~/" could be wrong for file names -with embedded spaces or commas. - -A few fixes for the Sniff interface. (Leherbauer) - -When asking to hit 'y' or 'n' (e.g. for ":3,1d"), using the mouse caused -trouble. Same for ":s/x/y/c" prompt. - -With 'nowrap' and 'list', a Tab halfway on the screen was displayed as blanks, -instead of the characters specified with 'listchars'. Also for other -characters that take more than one screen character. - -When setting 'guifont' to an unknown font name, the previous font was lost and -a default font would be used. (Steed) - -DOS: Filenames in the root directory didn't get shortened properly. (Negri) - -DJGPP: making a full path name out of a file name didn't work properly when -there is no _fullpath() function. (Negri) - -Win32 console: ":sh" caused a crash. (Negri) - -Win32 console: Setting 'lines' and/or 'columns' in the _vimrc failed miserably -(could hang Windows 95). (Negri) - -Win32: The change-drive function was not correct, went to the wrong drive. -(Tsindlekht) - -GUI: When editing a command line in Ex mode, Tabs were sometimes not -backspaced properly, and unprintable characters were displayed directly. -non-GUI can still be wrong, because a system function is called for this. - -":set" didn't stop after an error. For example ":set no ai" gave an error for -"no", but still set "ai". Now ":set" stops after the first error. - -When running configure for ctags, $LDFLAGS wasn't passed to it, causing -trouble for IRIX. - -"@%" and "@#" when file name not set gave an error message. Now they just -return an empty string. (Steed) - -CTRL-X and CTRL-A didn't work correctly with negative hex and octal numbers. -(Steed) - -":echo" always started with a blank. - -Updating GUI cursor shape didn't always work (e.g., when blinking is off). - -In silent Ex mode ("ex -s" or "ex <file") ":s///p" didn't print a line. Also -a few other commands that explicitly print a text line didn't work. Made this -Vi compatible. - -Win32 version of _chdrive() didn't return correct value. (Tsindlekht) - -When using 't' in 'complete' option, no longer give an error message for a -missing tags file. - -Unix: tgoto() can return NULL, which was not handled correctly in configure. - -When doing ":help" from a buffer where 'binary' is set, also edited the help -file in binary mode. Caused extra ^Ms for DOS systems. - -Cursor position in a file was reset to 1 when closing a window. - -":!ls" in Ex mode switched off echo. - -When doing a double click in window A, while currently in window B, first -click would reset double click time, had to click three times to select a -word. - -When using <F11> in mappings, ":mkexrc" produced an exrc file that can't be -used in Vi compatible mode. Added setting of 'cpo' to avoid this. Also, add -a CTRL-V in front of a '<', to avoid a normal string to be interpreted as a -special key name. - -Gave confusing error message for ":set guifont=-*-lucida-*": first "font is -not fixed width", then "Unknown font". - -Some options were still completely left out, instead of included as hidden -options. - -While running the X11 GUI, ignore SIGHUP signals. Avoids a crash after -executing an external command (in rare cases). - -In os_unixx.h, signal() was defined to sigset(), while it already was. - -Memory leak when executing autocommands (was reported as a memory leak in -syntax highlighting). - -Didn't print source of error sometimes, because pointers were the same, -although names were different. - -Avoid a number of UMR errors from Purify (third argument to open()). - -A swap file could still be created just after setting 'updatecount' to zero, -when there is an empty buffer and doing ":e file". (Kutschera) - -Test 35 failed on 64 bit machines. (Schild) - -With "p" and "P" commands, redrawing was slow. - -Awk script for html documentation didn't work correctly with AIX awk. -Replaced "[ ,.);\] ]" with "[] ,.); ]". (Briscoe) -The makehtml.awk script had a small problem, causing extra lines to be -inserted. (Briscoe) - -"gqgq" could not be repeated. Repeating for "gugu" and "gUgU" worked in a -wrong way. Also made "gqq" work to be consistent with "guu". - -C indent was wrong after "case ':':". - -":au BufReadPre *.c put": Line from put text was deleted, because the buffer -was still assumed to be empty. - -Text pasted with the Edit/Paste menu was subject to 'textwidth' and -'autoindent'. That was inconsistent with using the mouse to paste. Now "*p -is used. - -When using CTRL-W CTRL-] on a word that's not a tag, and then CTRL-] on a tag, -window was split. - -":ts" got stuck on a tags line that has two extra fields. - -In Insert mode, with 'showmode' on, <C-O><C-G> message was directly -overwritten by mode message, if preceded with search command warning message. - -When putting the result of an expression with "=<expr>p, newlines were -inserted like ^@ (NUL in the file). Now the string is split up in lines at -the newline. - -putenv() was declared with "const char *" in pty.c, but with "char *" in -osdef2.h.in. Made the last one also "const char *". - -":help {word}", where +{word} is a feature, jumped to the feature list instead -of where the command was explained. E.g., ":help browse", ":help autocmd". - -Using the "\<xx>" form in an expression only got one byte, even when using a -special character that uses several bytes (e.g., "\<F9>"). -Changed "\<BS>" to produce CTRL-H instead of the special key code for the -backspace key. "\<Del>" produces 0x7f. - -":mkvimrc" didn't write a command to set 'compatible' or 'nocompatible'. - -The shell syntax didn't contain a "syn sync maxlines" setting. In a long file -without recognizable items, syncing took so long it looked like Vim hangs. -Added a maxlines setting, and made syncing interruptible. - -The "gs" command didn't flush output before waiting. - -Memory leaks for: - ":if 0 | let a = b . c | endif" - "let a = b[c]" - ":so {file}" where {file} contains a ":while" - -GUI: allocated fonts were never released. (Leonard) - -Makefile.bor: -- Changed $(DEFINES) into a list of "-D" options, so that it can also be used - for the resource compiler. (not tested!) -- "bcc.cfg" was used for all configurations. When building for another - configuration, the settings for the previous one would be used. Moved - "bcc.cfg" to the object directory. (Geddes) -- Included targets for vimrun, install, ctags and xxd. Changed the default to - use the Borland DLL Runtime Library, makes Vim.exe a log smaller. (Aaron) - -"2*" search for the word under the cursor with "2" prepended. (Leonard) - -When deleting into a specific register, would still overwrite the non-Win32 -GUI selection. Now ""x"*P works. - -When deleting into the "" register, would write to the last used register. -Now ""x always writes to the unnamed register. - -GUI Athena: A submenu with a '.' in it didn't work. E.g., -":amenu Syntax.XY\.Z.foo lll". - -When first doing ":tag foo" and then ":tnext" and/or ":tselect" the order of -matching tags could change, because the current file is different. Now the -existing matches are kept in the same order, newly found matches are added -after them, not matter what the current file is. - -":ta" didn't find the second entry in a tags file, if the second entry was -longer than the first one. - -When using ":set si tw=7" inserting "foo {^P}" made the "}" inserted at the -wrong position. can_si was still TRUE when the cursor is not in the indent of -the line. - -Running an external command in Win32 version had the problem that Vim exits -when the X on the console is hit (and confirmed). Now use the "vimrun" -command to start the external command indirectly. (Negri) - -Win32 GUI: When running an external filter, do it in a minimized DOS box. -(Negri) - -":let" listed variables without translation into printable characters. - -Win32 console: When resizing the window, switching back to the old size -(when exiting or executing an external command) sometimes failed. (Negri) -This appears to also fix a "non fixable" problem: -Win32 console in NT 4.0: When running Vim in a cmd window with a scrollbar, -the scrollbar disappeared and was not restored when Vim exits. This does work -under NT 3.51, it appears not to be a Vim problem. - -When executing BufDelete and BufUnload autocommands for a buffer without a -name, the name of the current buffer was used for <afile>. - -When jumping to a tag it reported "tag 1 of >2", while in fact there could be -only two matches. Changed to "tag 1 of 2 or more". - -":tjump tag" did a linear search in the tags file, which can be slow. - -Configure didn't find "LibXm.so.2.0", a Xm library with a version number. - -Win32 GUI: When using a shifted key with ALT, the shift modifier would remain -set, even when it was already used by changing the used key. E.g., "<M-S-9>" -resulted in "<M-S-(>", but it should be "<M-(>". (Negri) - -A call to ga_init() was often followed by setting growsize and itemsize. -Created ga_init2() for this, which looks better. (Aaron) - -Function filereadable() could call fopen() with an empty string, which might -be illegal. - -X Windows GUI: When executing an external command that outputs text, could -write one character beyond the end of a buffer, which caused a crash. (Kohan) - -When using "*" or "#" on a string that includes '/' or '?' (when these are -included in 'isk'), they were not escaped. (Parmelan) - -When adding a ToolBar menu in the Motif GUI, the submenu_id field was not -cleared, causing random problems. - -When adding a menu, the check if this menu (or submenu) name already exists -didn't compare with the simplified version (no mnemonic or accelerator) of the -new menu. Could get two menus with the same name, e.g., "File" and "&File". - -Breaking a line because of 'textwidth' at the last line in the window caused a -redraw of the whole window instead of a scroll. Speeds up normal typing with -'textwidth' a lot for slow terminals. - -An invalid line number produced an "invalid range" error, even when it wasn't -to be executed (inside "if 0"). - -When the unnamed, first buffer is re-used, the "BufDelete" autocommand was -not called. It would stick in a buffer list menu. - -When doing "%" on the NUL after the line, a "{" or "}" in the last character -of the line was not found. - -The Insert mode menu was not used for the "s" command, the Operator-pending -menu was used instead. - -With 'compatible' set, some syntax highlighting was not correct, because of -using "[\t]" for a search pattern. Now use the regexps for syntax -highlighting like the 'cpoptions' option is empty (as was documented already). - -When using "map <M-Space> ms" or "map <Space> sss" the output of ":map" didn't -show any lhs for the mapping (if 'isprint' includes 160). Now always use -<Space> and <M-Space>, even when they are printable. - -Adjusted the Syntax menu, so that the lowest entry fits on a small screen (for -Athena, where menus don't wrap). - -When using CTRL-E or CTRL-Y in Insert mode for characters like 'o', 'x' and -digits, repeating the insert didn't work. - -The file "tools/ccfilter.README.txt" could not be unpacked when using short -file names, because of the two dots. Renamed it to -"tools/ccfilter_README.txt". - -For a dark 'background', using Blue for Directory and SpecialKey highlight -groups is not very readable. Use Cyan instead. - -In the function uc_scan_attr() in ex_docmd.c there was a goto that jumped into -a block with a local variable. That's illegal for some compilers. - -Win32 GUI: There was a row of pixels at the bottom of the window which was not -drawn. (Aaron) - -Under DOS, editing "filename/" created a swap file of "filename/.swp". Should -be "filename/_swp". - -Win32 GUI: pointer was hidden when executing an external command. - -When 'so' is 999, "J" near the end of the file didn't redisplay correctly. - -":0a" inserted after the first line, instead of before the first line. - -Unix: Wildcard expansion didn't handle single quotes and {} patterns. Now -":file 'window.c'" removes the quotes and ":e 'main*.c'" works (literal '*'). -":file {o}{n}{e}" now results in file name "one". - -Memory leak when setting a string option back to its default value. - -============================================================================== -VERSION 5.3 *version-5.3* - -Version 5.3 was a bug-fix version of 5.2. There are not many changes. -Improvements made between version 5.2 and 5.3: - -Changed *changed-5.3* -------- - -Renamed "IDE" menu to "Tools" menu. - - -Added *added-5.3* ------ - -Win32 GUI: Give a warning when Vim is activated, and one of the files changed -since editing started. (Negri) - - -Fixed *fixed-5.3* ------ - -5.2.1: Win32 GUI: space for external command was not properly allocated, could -cause a crash. (Aaron) This was the reason to bring out 5.3 quickly after -5.2. - -5.2.2: Some commands didn't complain when used without an argument, although -they need one: ":badd", ":browse", ":call", ":confirm", ":behave", -":delfunction", ":delcommand" and ":tearoff". -":endfunction" outside of a function gave wrong error message: "Command not -implemented". Should be ":endfunction not inside a function". - -5.2.3: Win32 GUI: When gvim was installed in "Program files", or another path -with a space in it, executing external commands with vimrun didn't work. - -5.2.4: Pasting with the mouse in Insert mode left the cursor on the last -pasted character, instead of behind it. - -5.2.5: In Insert mode, cursor after the end of the line, a shift-cursor-left -didn't include the last character in the selection. - -5.2.6: When deleting text from Insert mode (with "<C-O>D" or the mouse), which -includes the last character in the line, the cursor could be left on the last -character in the line, instead of just after it. - -5.2.7: Win32 GUI: scrollbar was one pixel too big. - -5.2.8: Completion of "PopUp" menu showed the derivatives "PopUpc", "PopUPi", -etc. ":menu" also showed these. - -5.2.9: When using two input() functions on a row, the prompt would not be -drawn in column 0. - -5.2.10: A loop with input() could not be broken with CTRL-C. - -5.2.11: ":call asdf" and ":call asdf(" didn't give an error message. - -5.2.12: Recursively using ":normal" crashes Vim after a while. E.g.: -":map gq :normal gq<CR>" - -5.2.13: Syntax highlighting used 'iskeyword' from wrong buffer. When using -":help", then "/\k*" in another window with 'hlsearch' set. - -5.2.14: When using ":source" from a function, global variables would not be -available unless "g:" was used. - -5.2.15: XPM files can have the extension ".pm", which is the same as for Perl -modules. Added "syntax/pmfile.vim" to handle this. - -5.2.16: On Win32 and Amiga, "echo expand("%:p:h")" removed one dirname in an -empty buffer. mch_Fullname() didn't append a slash at the end of a directory -name. - -Should include the character under the cursor in the Visual area when using -'selection' "exclusive". This wasn't done for "%", "e", "E", "t" and "f". - -""p would always put register 0, instead of the unnamed (last used) register. -Reverse the change that ""x doesn't write in the unnamed (last used) register. -It would always write in register 0, which isn't very useful. Use "-x for the -paste mappings in Visual mode. - -When there is one long line on the screen, and 'showcmd' is off, "0$" didn't -redraw the screen. - -Win32 GUI: When using 'mousehide', the pointer would flicker when the cursor -shape is changed. (Negri) - -When cancelling Visual mode, and the cursor moves to the start, the wanted -column wasn't set, "k" or "j" moved to the wrong column. - -When using ":browse" or ":confirm", was checking for a comment and separating -bar, which can break some commands. - -Included fixes for Macintosh. (Kielhorn) - -============================================================================== -VERSION 5.4 *version-5.4* - -Version 5.4 adds new features, useful changes and a lot of bug fixes. - - -Runtime directory introduced *new-runtime-dir* ----------------------------- - -The distributed runtime files are now in $VIMRUNTIME, the user files in $VIM. -You normally don't set $VIMRUNTIME but let Vim find it, by using -$VIM/vim{version}, or use $VIM when that doesn't exist. This allows for -separating the user files from the distributed files and makes it more easy to -upgrade to another version. It also makes it possible to keep two versions of -Vim around, each with their own runtime files. - -In the Unix distribution the runtime files have been moved to the "runtime" -directory. This makes it possible to copy all the runtime files at once, -without the need to know what needs to be copied. - -The archives for DOS, Windows, Amiga and OS/2 now have an extra top-level -"vim" directory. This is to make clear that user-modified files should be put -here. The directory that contains the executables doesn't have '-' or '.' -characters. This avoids strange extensions. - -The $VIM and $VIMRUNTIME variables are set when they are first used. This -allows them to be used by Perl, for example. - -The runtime files are also found in a directory called "$VIM/runtime". This -helps when running Vim after just unpacking the runtime archive. When using -an executable in the "src" directory, Vim checks if "vim54" or "runtime" can -be added after removing it. This make the runtime files be found just after -compiling. - -A default for $VIMRUNTIME can be given in the Unix Makefile. This is useful -if $VIM doesn't point to above the runtime directory but to e.g., "/etc/". - - -Filetype introduced *new-filetype-5.4* -------------------- - -Syntax files are now loaded with the new FileType autocommand. Old -"mysyntaxfile" files will no longer work. |filetypes| - -The scripts for loading syntax highlighting have been changed to use the -new Syntax autocommand event. - -This combination of Filetype and Syntax events allows tuning the syntax -highlighting a bit more, also when selected from the Syntax menu. The -FileType autocommand can also be used to set options and mappings specifically -for that type of file. - -The "$VIMRUNTIME/filetype.vim" file is not loaded automatically. The -":filetype on" command has been added for this. ":syntax on" also loads it. - -The 'filetype' option has been added. It is used to trigger the FileType -autocommand event, like the 'syntax' option does for the Syntax event. - -":set syntax=OFF" and ":set syntax=ON" can be used (in a modeline) to switch -syntax highlighting on/off for the current file. - -The Syntax menu commands have been moved to $VIMRUNTIME/menu.vim. The Syntax -menu is included both when ":filetype on" and when ":syntax manual" is used. - -Renamed the old 'filetype' option to 'osfiletype'. It was only used for -RISCOS. 'filetype' is now used for the common file type. - -Added the ":syntax manual" command. Allows manual selection of the syntax to -be used, e.g., from a modeline. - - -Vim script line continuation *new-line-continuation* ----------------------------- - -When an Ex line starts with a backslash, it is concatenated to the previous -line. This avoids the need for long lines. |line-continuation| (Roemer) -Example: > - if has("dialog_con") || - \ has("dialog_gui") - :let result = confirm("Enter your choice", - \ "&Yes\n&No\n&Maybe", - \ 2) - endif - - -Improved session files *improved-sessions* ----------------------- - -New words for 'sessionoptions': -- "help" Restore the help window. -- "blank" Restore empty windows. -- "winpos" Restore the Vim window position. Uses the new ":winpos" - command -- "buffers" Restore hidden and unloaded buffers. Without it only the - buffers in windows are restored. -- "slash" Replace backward by forward slashes in file names. -- "globals" Store global variables. -- "unix" Use unix file format (<NL> instead of <CR><NL>) - -The ":mksession" and 'sessionoptions' are now in the +mksession feature. - -The top line of the window is also restored when using a session file. - -":mksession" and ":mkvimrc" don't store 'fileformat', it should be detected -when loading a file. - -(Most of this was done by Vince Negri and Robert Webb) - - -Autocommands improved *improved-autocmds-5.4* ---------------------- - -New events: -|FileType| When the file type has been detected. -|FocusGained| When Vim got input focus. (Negri) -|FocusLost| When Vim lost input focus. (Negri) -|BufCreate| Called just after a new buffer has been created or has been - renamed. (Madsen) -|CursorHold| Triggered when no key has been typed for 'updatetime'. Can be - used to do something with the word under the cursor. (Negri) - Implemented CursorHold autocommand event for Unix. (Zellner) - Also for Amiga and MS-DOS. -|GUIEnter| Can be used to do something with the GUI window after it has - been created (e.g., a ":winpos 100 50"). -|BufHidden| When a buffer becomes hidden. Used to delete the - option-window when it becomes hidden. - -Also trigger |BufDelete| just before a buffer is going to be renamed. (Madsen) - -The "<amatch>" pattern can be used like "<afile>" for autocommands, except -that it is the matching value for the FileType and Syntax events. - -When ":let @/ = <string>" is used in an autocommand, this last search pattern -will be used after the autocommand finishes. - -Made loading autocommands a bit faster. Avoid doing strlen() on each exiting -pattern for each new pattern by remembering the length. - - -Encryption *new-encryption* ----------- - -Files can be encrypted when writing and decrypted when reading. Added the -'key' option, "-x" command line argument and ":X" command. |encryption| (based -on patch from Mohsin Ahmed) - -When reading a file, there is an automatic detection whether it has been -crypted. Vim will then prompt for the key. - -Note that the encryption method is not compatible with Vi. The encryption is -not unbreakable. This allows it to be exported from the US. - - -GTK GUI port *new-GTK-GUI* ------------- - -New GUI port for GTK+. Includes a toolbar, menu tearoffs, etc. |gui-gtk| -Added the |:helpfind| command. (Kahn and Dalecki) - - -Menu changes *menu-changes-5.4* ------------- - -Menus can now also be used in the console. It is enabled by the new -'wildmenu' option. This shows matches for command-line completion like a -menu. This works as a minimal file browser. - -The new |:emenu| command can be used to execute a menu item. - -Uses the last status line to list items, or inserts a line just above the -command line. (Negri) - -The 'wildcharx' option can be used to trigger 'wildmenu' completion from a -mapping. - -When compiled without menus, this can be detected with has("menu"). Also show -this in the ":version" output. Allow compiling GUI versions without menu -support. Only include toolbar support when there is menu support. - -Moved the "Window" menu all the way to the right (priority 70). Looks more -familiar for people working with MS-Windows, shouldn't matter for others. - -Included "Buffers" menu. Works with existing autocommands and functions. It -can be disabled by setting the "no_buffers_menu" variable. (Aaron and Madsen) - -Win32 supports separators in a menu: "-.*-". (Geddes) -Menu separators for Motif now work too. - -Made Popup menu for Motif GUI work. (Madsen) - -'M' flag in 'guioptions': Don't source the system menu. - -All the menu code has been moved from gui.c to menu.c. - - -Viminfo improved *improved-viminfo* ----------------- - -New flags for 'viminfo': -'!' Store global variables in the viminfo file if they are in uppercase - letters. (Negri) -'h' Do ":nohlsearch" when loading a viminfo file. - -Store search patterns in the viminfo file with their offset, magic, etc. Also -store the flag whether 'hlsearch' highlighting is on or off (which is not used -if the 'h' flag is in 'viminfo'). - -Give an error message when setting 'viminfo' without commas. - - -Various new commands *new-commands-5.4* --------------------- - -Operator |g?|: rot13 encoding. (Negri) - -|zH| and |zL| commands: Horizontal scrolling by half a page. -|gm| move cursor to middle of screen line. (Ideas by Campbell) - -Operations on Visual blocks: |v_b_I|, |v_b_A|, |v_b_c|, |v_b_C|, |v_b_r|, -|v_b_<| and |v_b_>|. (Kelly) - -New command: CTRL-\ CTRL-N, which does nothing in Normal mode, and goes to -Normal mode when in Insert or Command-line mode. Can be used by VisVim or -other OLE programs to make sure Vim is in Normal mode, without causing a beep. -|CTRL-\_CTRL-N| - -":cscope kill" command to use the connection filename. |:cscope| (Kahn) - -|:startinsert| command: Start Insert mode next. - -|:history| command, to show all four types of histories. (Roemer) - -|[m|, |[M|, |]m| and |]M| commands, for jumping backward/forward to start/end -of method in a (Java) class. - -":@*" executes the * register. |:@| (Acevedo) - -|go| and |:goto| commands: Jump to byte offset in the file. - -|gR| and |gr| command: Virtual Replace mode. Replace characters without -changing the layout. (Webb) - -":cd -" changes to the directory from before the previous ":cd" command. -|:cd-| (Webb) - -Tag preview commands |:ptag|. Shows the result of a ":tag" in a dedicated -window. Can be used to see the context of the tag (e.g., function arguments). -(Negri) -|:pclose| command, and CTRL-W CTRL-Z: Close preview window. (Moore) -'previewheight' option, height for the preview window. -Also |:ppop|, |:ptnext|, |:ptprevious|, |:ptNext|, |:ptrewind|, |:ptlast|. - -|:find| and |:sfind| commands: Find a file in 'path', (split window) and edit -it. - -The |:options| command opens an option window that shows the current option -values. Or use ":browse set" to open it. Options are grouped by function. -Offers short help on each option. Hit <CR> to jump to more help. Edit the -option value and hit <CR> on a "set" line to set a new value. - - -Various new options *new-options-5.4* -------------------- - -Scroll-binding: 'scrollbind' and 'scrollopt' options. Added |:syncbind| -command. Makes windows scroll the same amount (horizontally and/or -vertically). (Ralston) - -'conskey' option for MS-DOS. Use direct console I/O. This should work with -telnet (untested!). - -'statusline' option: Configurable contents of the status line. Also allows -showing the byte offset in the file. Highlighting with %1* to %9*, using the -new highlight groups User1 to User9. (Madsen) - -'rulerformat' option: Configurable contents of the ruler, like 'statusline'. -(Madsen) - -'write' option: When off, writing files is not allowed. Avoids overwriting a -file even with ":w!". The |-m| command line option resets 'write'. - -'clipboard' option: How the clipboard is used. Value "unnamed": Use unnamed -register like "*. (Cortopassi) Value "autoselect": Like what 'a' in -'guioptions' does but works in the terminal. - -'guifontset' option: Specify fonts for the +fontset feature, for the X11 GUI -versions. Allows using normal fonts when vim is compiled with this feature. -(Nam) - -'guiheadroom' option: How much room to allow above/below the GUI window. -Used for Motif, Athena and GTK. - -Implemented 'tagstack' option: When off, pushing tags onto the stack is -disabled (Vi compatible). Useful for mappings. - -'shellslash' option. Only for systems that use a backslash as a file -separator. This option will use a forward slash in file names when expanding -it. Useful when 'shell' is sh or csh. - -'pastetoggle' option: Key sequence that toggles 'paste'. Works around the -problem that mappings don't work in Insert mode when 'paste' is set. - -'display' option: When set to "lastline", the last line fills the window, -instead of being replaced with "@" lines. Only the last three characters are -replaced with "@@@", to indicate that the line has not finished yet. - -'switchbuf' option: Allows re-using existing windows on a buffer that is being -jumped to, or split the window to open a new buffer. (Roemer) - -'titleold' option. Replaces the fixed string "Thanks for flying Vim", which -is used to set the title when exiting. (Schild) - - -Vim scripts *new-script-5.4* ------------ - -The |exists()| function can also check for existence of a function. (Roemer) -An internal function is now found with a binary search, should be a bit -faster. (Roemer) - -New functions: -- |getwinposx()| and |getwinposy()|: get Vim window position. (Webb) -- |histnr()|, |histadd()|, |histget()| and |histdel()|: Make history - available. (Roemer) -- |maparg()|: Returns rhs of a mapping. Based on a patch from Vikas. -- |mapcheck()|: Check if a map name matches with an existing one. -- |visualmode()|: Return type of last Visual mode. (Webb) -- |libcall()|: Call a function in a library. Currently only for Win32. (Negri) -- |bufwinnr()|: find window that contains the specified buffer. (Roemer) -- |bufloaded()|: Whether a buffer exists and is loaded. -- |localtime()| and |getftime()|: wall clock time and last modification time - of a file (Webb) -- |glob()|: expand file name wildcards only. -- |system()|: get the raw output of an external command. (based on a patch - from Aaron). -- |strtrans()|: Translate String into printable characters. Used for - 2html.vim script. -- |append()|: easy way to append a line of text in a buffer. - -Changed functions: -- Optional argument to |strftime()| to give the time in seconds. (Webb) -- |expand()| now also returns names for files that don't exist. - -Allow numbers in the name of a user command. (Webb) - -Use "v:" for internal Vim variables: "v:errmsg", "v:shell_error", etc. The -ones from version 5.3 can be used without "v:" too, for backwards -compatibility. - -New variables: -"v:warningmsg" and "v:statusmsg" internal variables. Contain the last given -warning and status message. |v:warningmsg| |v:statusmsg| (Madsen) -"v:count1" variable: like "v:count", but defaults to one when no count is -used. |v:count1| - -When compiling without expression evaluation, "if 1" can be used around the -not supported commands to avoid it being executed. Works like in Vim 4.x. -Some of the runtime scripts gave errors when used with a Vim that was compiled -with minimal features. Now "if 1" is used around code that is not always -supported. - -When evaluating an expression with && and ||, skip the parts that will not -influence the outcome. This makes it faster and avoids error messages. (Webb) -Also optimized the skipping of expressions inside an "if 0". - - -Avoid hit-enter prompt *avoid-hit-enter* ------------------------ - -Added 'T' flag to 'shortmess': Truncate all messages that would cause the -hit-enter prompt (unless that would happen anyway). -The 'O' flag in 'shortmess' now also applies to quickfix messages, e.g., from -the ":cn" command. - -The default for 'shortmess' is now "filnxtToO", to make most messages fit on -the command line, and not cause the hit-enter prompt. - -Previous messages can be viewed with the new |:messages| command. - -Some messages are shown fully, even when 'shortmess' tells to shorten -messages, because the user is expected to want to see them in full: CTRL-G and -some quickfix commands. - - -Improved quickfix *improved-quickfix* ------------------ - -Parse change-directory lines for gmake: "make[1]: Entering directory 'name'". -Uses "%D" and "%X" in 'errorformat'. -Also parse "Making {target} in {dir}" messages from make. Helps when not -using GNU make. (Schandl) - -Use 'isfname' for "%f" in 'errorformat'. - -Parsing of multi-line messages. |errorformat-multi-line| - -Allow a range for the |:clist| command. (Roemer) - -Support for "global" file names, for error formats that output the file name -once for several errors. (Roemer) - -|:cnfile| jumps to first error in next file. - -"$*" in 'makeprg' is replaced by arguments to ":make". (Roemer) - - -Regular expressions *regexp-changes-5.4* -------------------- - -In a regexp, a '$' before "\)" is also considered to be an end-of-line. |/$| -In patterns "^" after "\|" or "\(" is a start-of-line. |/^| (Robinson) - -In a regexp, in front of "\)" and "\|" both "$" and "\$" were considered -end-of-line. Now use "$" as end-of-line and "\$" for a literal dollar. Same -for '^' after "\(" and "\|". |/\$| |/\^| - -Some search patterns can be extremely slow, even though they are not really -illegal. For example: "\([^a-z]\+\)\+Q". Allow interrupting any regexp -search with CTRL-C. - -Register "/: last search string (read-only). (Kohan) Changed to use last used -search pattern (like what 'hlsearch' uses). Can set the search pattern with -":let @/ = {expr}". - -Added character classes to search patterns, to avoid the need for removing the -'l' flag from 'cpoptions': |[:tab:]|, |[:return:]|, |[:backspace:]| and -|[:escape:]|. - -By adding a '?' after a comparative operator in an expression, the comparison -is done by ignoring case. |expr-==?| - - -Other improvements made between version 5.3 and 5.4 ---------------------------------------------------- - -Changed *changed-5.4* -------- - -Unix: Use $TMPDIR for temporary files, if it is set and exists. - -Removed "Empty buffer" message. It isn't useful and can cause a hit-enter -prompt. (Negri) - -"ex -" now reads commands from stdin and works in silent mode. This is to be -compatible with the original "ex" command that is used for scripts. - -Default range for ":tcldo" is the whole file. - -Cancelling Visual mode with ESC moved the cursor. There appears to be no -reason for this. Now leave the cursor where it is. - -The ":grep" and ":make" commands see " as part of the arguments, instead of -the start of a comment. - -In expressions the "=~" and "!~" operators no longer are affected by -'ignorecase'. - -Renamed vimrc_example to vimrc_example.vim and gvimrc_example to -gvimrc_example.vim. Makes them being recognized as vim scripts. - -"gd" no longer starts searching at the end of the previous function, but at -the first blank line above the start of the current function. Avoids that -using "gd" in the first function finds global a variable. - -Default for 'complete' changed from ".,b" to ".,w,b,u,t,i". Many more matches -will be found, at the cost of time (the search can be interrupted). - -It is no longer possible to set 'shell*' options from a modeline. Previously -only a warning message was given. This reduces security risks. - -The ordering of the index of documentation files was changed to make it more -easy to find a subject. - -On MS-DOS and win32, when $VIM was not set, $HOME was used. This caused -trouble if $HOME was set to e.g., "C:\" for some other tool, the runtime files -would not be found. Now use $HOME only for _vimrc, _gvimrc, etc., not to find -the runtime file. - -When 'tags' is "./{fname}" and there is no file name for the current buffer, -just use it. Previously it was skipped, causing "vim -t {tag}" not to find -many tags. - -When trying to select text in the 'scrolloff' area by mouse dragging, the -resulting scrolling made this difficult. Now 'scrolloff' is temporarily set -to 0 or 1 to avoid this. But still allow scrolling in the top line to extend -to above the displayed text. - -Default for 'comments' now includes "sl:/*,mb: *,ex:*/", to make javadoc -comments work. Also helps for C comments that start with "/*******". - -CTRL-X CTRL-] Insert mode tag expansion tried to expand to all tags when used -after a non-ID character, which can take a very long time. Now limit this to -200 matches. Also used for command-line tag completion. - -The OS/2 distribution has been split in two files. It was too big to fit on a -floppy. The same runtime archive as for the PC is now used. - -In the documentation, items like <a-z> have been replaced with {a-z} for -non-optional arguments. This avoids confusion with key names: <C-Z> is a -CTRL-Z, not a character between C and Z, that is {C-Z}. - - -Added *added-5.4* ------ - -Color support for the iris-ansi builtin termcap entry. (Tubman) - -Included VisVim version 1.3a. (Erhardt) - -Win32 port for SNiFF+ interface. (Leherbauer) -Documentation file for sniff interface: if_sniff.txt. (Leherbauer) - -Included the "SendToVim" and "OpenWithVim" programs in the OleVim directory. -To be used with the OLE version of gvim under MS-Windows. (Schaller) - -Included Exuberant Ctags version 3.2.4 with Eiffel support. (Hiebert) - -When a file that is being edited is deleted, give a warning (like when the -time stamp changed). - -Included newer versions of the HTML-generating Awk and Perl scripts. (Colombo) - -Linux console mouse support through "gpm". (Tsindlekht) - -Security fix: Disallow changing 'secure' and 'exrc' from a modeline. When -'secure' is set, give a warning for changing options that contain a program -name. - -Made the Perl interface work with Perl 5.005 and threads. (Verdoolaege) - -When giving an error message for an ambiguous mapping, include the offending -mapping. (Roemer) - -Command line editing: -- Command line completion of mappings. (Roemer) -- Command line completion for ":function", ":delfunction", ":let", ":call", - ":if", etc. (Roemer) -- When using CTRL-D completion for user commands that have - "-complete=tag_listfiles" also list the file names. (Madsen) -- Complete the arguments of the ":command" command. (Webb) -- CTRL-R . in command line inserts last inserted text. CTRL-F, CTRL-P, CTRL-W - and CTRL-A after CTRL-R are used to insert an object from under the cursor. - (Madsen) - -Made the text in uganda.txt about copying Vim a bit more clear. - -Updated the Vim tutor. Added the "vimtutor" command, which copies the tutor -and starts Vim on it. "make install" now also copies the tutor. - -In the output of ":clist" the current entry is highlighted, with the 'i' -highlighting (same as used for 'incsearch'). - -For the ":clist" command, you can scroll backwards with "b" (one screenful), -"u" (half a screenful) and "k" (one line). - -Multi-byte support: -- X-input method for multi-byte characters. And various fixes for multi-byte - support. (Nam) -- Hangul input method feature: |hangul|. (Nam) -- Cleaned up configuration of multi-byte support, XIM, fontset and Hangul - input. Each is now configurable separately. -- Changed check for GTK_KEYBOARD to HANGUL_KEYBOARD_TYPE. (Nam) -- Added doc/hangulin.txt: Documentation for the Hangul input code. (Nam) -- XIM support for GTK+. (Nam) -- First attempt to include support for SJIS encoding. (Nagano) -- When a double-byte character doesn't fit at the end of the line, put a "~" - there and print it on the next line. -- Optimize output of multi-byte text. (Park) -- Win32 IME: preedit style is like over-the-spot. (Nagano) -- Win32 IME: IME mode change now done with ImmSetOpenStatus. (Nagano) -- GUI Athena: file selection dialog can display multi-byte characters. - (Nagano) -- Selection reply for XA_TEXT as XA_STRING. (Nagano) - -"runtime/macros/diffwin.vim". Mappings to make a diff window. (Campbell) - -Added ".obj" to the 'suffixes' option. - -Reduced size of syntax/synload.vim by using the ":SynAu" user command. -Automated numbering of Syntax menu entries in menu.vim. -In the Syntax menu, insert separators between syntax names that start with -a different letter. (Geddes) - -Xterm: -- Clipboard support when using the mouse in an xterm. (Madsen) -- When using the xterm mouse, track dragging of the mouse. Use xterm escape - sequences when possible. It is more precise than other methods, but - requires a fairly recent xterm version. It is enabled with "xterm2" in - 'ttymouse'. (Madsen) -- Check xterm patch level, to set the value of 'ttymouse'. Has only been - added to xterm recently (patch level > 95). Uses the new 't_RV' termcap - option. Set 'ttymouse' to "xterm2" when a correct response is recognized. - Will make xterm mouse dragging work better. -- Support for shifted function keys on xterm. Changed codes for shifted - cursor keys to what the xterm actually produces. Added codes for shifted - <End> and <Home>. -- Added 't_WP' to set the window position in pixels and 't_WS' to set the - window size in characters. Xterm can now move (used for ":winpos") and - resize (use for ":set lines=" and ":set columns="). - -X11: -- When in Visual mode but not owning the selection, display the Visual area - with the VisualNOS group to show this. (Madsen) -- Support for requesting the type of clipboard support. Used for AIX and - dtterm. (Wittig) -- Support compound_text selection (even when compiled without multi-byte). - -Swap file: -- New variation for naming swap files: Replace path separators into %, place - all swap files in one directory. Used when a name in 'dir' ends in two path - separators. (Madsen) -- When a swap file is found, show whether it contains modifications or not in - the informative message. (Madsen) -- When dialogs are supported, use a dialog to ask the user what to do when a - swapfile already exists. - -"popup_setpos" in 'mousemodel' option. Allows for moving the cursor when -using the right mouse button. - -When a buffer is deleted, the selection for which buffer to display instead -now uses the most recent entry from the jump list. (Madsen) - -When using CTRL-O/CTRL-I, skip deleted buffers. - -A percentage is shown in the ruler, when there is room. - -Used autoconf 1.13 to generate configure. - -Included get_lisp_indent() from Dirk van Deun. Does better Lisp indenting -when 'p' flag in 'cpoptions' is not included. - -Made the 2html.vim script quite a bit faster. (based on ideas from Geddes) - -Unix: -- Included the name of the user that compiled Vim and the system name it was - compiled on in the version message. -- "make install" now also installs the "tools" directory. Makes them - available for everybody. -- "make check" now does the same as "make test". "make test" checks for - Visual block mode shift, insert, replace and change. -- Speed up comparing a file name with existing buffers by storing the - device/inode number with the buffer. -- Added configure arguments "--disable-gtk", "--disable-motif" and - "--disable-athena", to be able to disable a specific GUI (when it doesn't - work). -- Renamed the configure arguments for disabling the check for specific GUIs. - Should be clearer now. (Kahn) -- On a Digital Unix system ("OSF1") check for the curses library before - termlib and termcap. (Schild) -- "make uninstall_runtime" will only delete the version-specific files. Can - be used to delete the runtime files of a previous version. - -Macintosh: (St-Amant) -- Dragging the scrollbar, like it's done for the Win32 GUI. Moved common code - from gui_w32.c to gui.c -- Added dialogs and file browsing. -- Resource fork preserved, warning when it will be lost. -- Copy original file attributes to newly written file. -- Set title/notitle bug solved. -- Filename completion improved. -- Grow box limit resize to a char by char size. -- Use of rgb.txt for more colors (but give back bad color). -- Apple menu works (beside the about...). -- Internal border now vim compliant. -- Removing a menu doesn't crash anymore. -- Weak-linking of Python 1.5.1 (only on PPC). Python is supported when the - library is available. -- If an error is encountered when sourcing the users .vimrc, the alert box now - shows right away with the OK button defaulted. There's no more "Delete"-key - sign at the start of each line -- Better management of environment variables. Now $VIM is calculated only - once, not regenerated every time it is used. -- No more CPU hog when in background. -- In a sourced Vim script the Mac file format can be recognized, just like DOS - file format is. - -When both "unix" and "mac" are present in 'fileformats', prefer "mac" format -when there are more CR than NL characters. -When using "mac" fileformat, use CR instead of a NL, because NL is used for -NUL. Will preserve all characters in a file. (Madsen) - -The DOS install.exe now contains checks for an existing installation. It -avoids setting $VIM and $PATH again. -The install program for Dos/Windows can now install Vim in the popup menu, by -adding two registry keys. - -Port to EGCS/mingw32. New Makefile.ming. (Aaron) - -DOS 16 bit: Don't include cursor shape stuff. Save some bytes. - -TCL support to Makefile.w32. (Duperval) - -OS/2: Use argv[0] to find runtime files. - -When using "gf" to go to a buffer that has already been used, jump to the -line where the cursor last was. - -Colored the output of ":tselect" a bit more. Different highlighting between -tag name and file name. Highlight field name ("struct:") separately from -argument. - -Backtick expansion for non-Unix systems. Based on a patch from Aaron. -Allows the use of things like ":n `grep -l test *.c`" and -"echo expand('`ls m*`')". - -Check for the 'complete' option when it is set. (Acevedo) -'d' flag in 'complete' searches for defined names or macros. -While searching for Insert mode completions in include files and tags files, -check for typeahead, so that you can use matches early. (Webb) -The '.' flag in 'complete' now scans the current buffer completely, ignoring -'nowrapscan'. (Webb) - -Added '~' flag to 'whichwrap'. (Acevedo) - -When ending the Visual mode (e.g., with ESC) don't grab ownership of the -selection. - -In a color terminal, "fg" and "bg" can be used as color names. They stand for -the "Normal" colors. - -A few cscope cleanups. (Kahn) - -Included changed vimspell.sh from Schemenauer. - -Concatenation of strings in an expression with "." is a bit faster. (Roemer) - -The ":redir" command can now redirect to a register: ":redir @r". (Roemer) - -Made the output of ":marks" and ":jumps" look similar. When the mark is in -the current file, show the text at the mark. Also for ":tags". - -When configure finds ftello() and fseeko(), they are used in tag.c (for when -you have extremely big tags files). - -Configure check for "-FOlimit,2000" argument for the compiler. (Borsenkow) - -GUI: -- When using ":gui" in a non-GUI Vim, give a clear error message. -- "gvim -v" doesn't start the GUI (if console support is present). -- When in Ex mode, use non-Visual selection for the whole screen. -- When starting with "gvim -f" and using ":gui" in the .gvimrc file, Vim - forked anyway. Now the "-f" flag is remembered for ":gui". Added "gui -b" - to run gvim in the background anyway. - -Motif GUI: -- Check for "-lXp" library in configure (but it doesn't work yet...). -- Let configure check for Lesstif in "/usr/local/Lesstif/Motif*". Changed the - order to let a local Motif version override a system standard version. - -Win32 GUI: -- When using "-register" or "-unregister" in the non-OLE version, give an - error message. -- Use GTK toolbar icons. Make window border look better. Use sizing handles - on the lower left&right corners of the window. (Negri) -- When starting an external command with ":!start" and the command can not be - executed, give an error message. (Webb) -- Use sizing handles for the grey rectangles below the scrollbars. Can draw - toolbar in flat mode now, looks better. (Negri) -- Preparations for MS-Windows 3.1 addition. Mostly changing WIN32 to MSWIN - and USE_GUI_WIN32 to USE_GUI_MSWIN. (Negri) - -Avoid allocating the same string four times in buflist_findpat(). (Williams) - -Set title and icon text with termcap options 't_ts', 't_fs', 't_IS' and -'t_IE'. Allows doing this on any terminal that supports setting the title -and/or icon text. (Schild) - -New 'x' flag in 'comments': Automatically insert the end part when its last -character is typed. Helps to close a /* */ comment in C. (Webb) - -When expand() has a second argument which is non-zero, don't use 'suffixes' -and 'wildignore', return all matches. - -'O' flag in 'cpoptions: When not included, Vim will not overwrite a file, if -it didn't exist when editing started but it does exist when the buffer is -written to the file. The file must have been created outside of Vim, possibly -without the user knowing it. When this is detected after a shell command, -give a warning message. - -When editing a new file, CTRL-G will show [New file]. When there were errors -while reading the file, CTRL-G will show [Read errors]. - -":wall" can now use a dialog and file-browsing when needed. - -Grouped functionality into new features, mainly to reduce the size of the -minimal version: -+linebreak: 'showbreak', 'breakat' and 'linebreak' -+visualextra: "I"nsert and "A"ppend in Visual block mode, "c"hange all lines - in a block, ">" and "<": Shifting a block, "r": Replacing a - Visual area with one character. -+comments: 'comments' -+cmdline_info: 'ruler' and 'showcmd'. Replaces +showcmd. -"+title" Don't add code to set title or icon for MSDOS, this was not - possible anyway. -+cmdline_compl Disable commandline completion at compile time, except for - files, directories and help items. - -Moved features from a list of function calls into an array. Should save a bit -of space. - -While entering the body of a function, adjust indent according to "if" and -"while" commands. - -VMS: Adjusted os_vms.mms a bit according to suggestions from Arpadffy. - -The flags in the 'comments' option can now include an offset. This makes it -possible to align "/*****", "/* xxx" and "/*" comments with the same -'comments' setting. The default value for 'comments' uses this. -Added 'O' flag: Don't use this part for the "O" command. Useful for "set -com=sO:*\ -,mO:*\ \ ,exO:*/" - -FileType autocommands recognize ".bak", ".orig" and "~" extensions and remove -them to find the relevant extension. - -The tutorial for writing a Vim script file has been extended. - -Some more highlighting in help files, for items that are not typed literally. - -Can use "CTRL-W CTRL-G" like "CTRL-W g". - -"make test" for OS/2. - -Adjusted configure to automatically use the GUI for BeOS. - - -Fixed *fixed-5.4* ------ - -5.3.1: When using an autocommand for BufWritePre that changes the name of the -buffer, freed memory would be used. (Geddes) - -Mac: Compiler didn't understand start of skip_class_name(). - -Win32 GUI: -- When cancelling the font requester, don't give an error message. -- When a tearoff-menu is open and its menu is deleted, Vim could crash. - (Negri) -- There was a problem on Windows 95 with (un)maximizing the window. - (Williams) -- when 'mousehide' is set, the mouse would stay hidden when a menu is dropped - with the keyboard. (Ralston) -- The tempname() function already created the file. Caused problems when - using ":w". Now the file is deleted. -- Cursor disappeared when ending up in the top-left character on the screen - after scrolling. (Webb) -- When adding a submenu for a torn-off menu, it was not updated. -- Menu tooltip was using the toolbar tooltip. (Negri) -- Setting 'notitle' didn't remove the title. (Steed) -- Using ":!start cmd" scrolled the screen one line up, and didn't wait for - return when the command wasn't found. - -Cscope interface: Sorting of matches was wrong. Starting the interface could -fail. (Kahn) - -Motif GUI: Could not compile with Motif 1.1, because some tear-off -functionality was not in #ifdefs. - -Configure could sometimes not compile or link the test program for sizeof(int) -properly. This caused alignment problems for the undo structure allocations. -Added a safety check that SIZEOF_INT is not zero. - -Added configure check to test if strings.h can be included after string.h. -Some systems can't handle it. -Some systems need both string.h and strings.h included. Adjusted vim.h for -that. Removed including string.h from os_unixx.h, since it's already in -vim.h. (Savage) -AIX: defining _NO_PROTO in os_unix.h causes a conflict between string.h and -strings.h, but after the configure check said it was OK. Also define -_NO_PROTO for AIX in the configure check. (Winn) - -When closing a window with CTRL-W c, the value of 'hidden' was not taken into -account, the buffer was always unloaded. (Negri) - -Unix Makefile: "make install" always tried to rename an older executable and -remove it. This caused an error message when it didn't exit. Added a check -for the existence of an old executable. -The command line for "make install" could get too long, because of the many -syntax files. Now first do a "cd" to reduce the length. - -On RISCOS and MSDOS, reading a file could fail, because the short filename was -used, which can be wrong after a ":!cd". - -In the DOS versions, the wrong install.exe was included (required Windows). -Now the install.exe version is included that is the same as the Vim version. -This also supports long file names where possible. - -When recording, and stopping while in Insert mode with CTRL-O q, the CTRL-O -would also be recorded. - -32bit DOS version: "vim \file", while in a subdirectory, resulted in "new -file" for "file" in the local directory, while "\file" did exist. When -"file" in the current directory existed, this didn't happen. - -MSDOS: Mouse could not go beyond 80 columns in 132 columns mode. (Young) - -"make test" failed in the RedHat RPM, because compatible is off by default. - -In Insert mode <C-O><C-W><C-W> changes to other window, but the status bars -were not updated until another character was typed. - -MSDOS: environment options in lowercase didn't work, although they did in the -Win32 versions. (Negri) - -After ":nohlsearch", a tag command switched highlighting back on. - -When using "append" command as the last line in an autocommand, Vim would -crash. - -RISCOS: The scroll bumpers (?) were not working properly. (Leonard) - -"zl" and "zh" could move the cursor, but this didn't set the column in which -e.g., "k" would move the cursor. - -When doing ":set all&" the value of 'scroll' was not set correctly. This -caused an error message when later setting any other number option. - -When 'hlsearch' highlighting has been disabled with ":nohlsearch", -incremental searching would switch it back on too early. - -When listing tags for ":tselect", and using a non-search command, and the last -character was equal to the first (e.g., "99"), the last char would not be -shown. - -When searching for tags with ":tag" Vim would assume that all matches had been -found when there were still more (e.g. from another tags file). - -Win32: Didn't recognize "c:\" (e.g., in tags file) as absolute path when -upper/lowercase was different. - -Some xterms (Debian) send <Esc>OH for HOME and <Esc>OF for END. Added these -to the builtin-xterm. - -In ex mode, any CR was seen as the end of the line. Only a NL should be -handled that way. broke ":s/foo/some^Mtext/". - -In menu.vim, a vmenu was used to override an amenu. That didn't work, because -the system menu file doesn't overwrite existing menus. Added explicit vunmenu -to solve this. - -Configure check for terminal library could find a library that doesn't work at -runtime (Solaris: shared library not found). Added a check that a program -with tgoto() can run correctly. - -Unix: "echo -n" in the Makefile doesn't work on all systems, causing errors -compiling pathdef.c. Replaced it with "tr". - -Perl: DO_JOIN was redefined by Perl. Undefined it in the perl files. - -Various XIM and multi-byte fixes: -- Fix user cannot see his language while he is typing his language with - off-the-spot method. (Nagano) -- Fix preedit position using text/edit area (using gui.wid). (Nagano) -- remove 'fix dead key' codes. It was needed since XNFocusWindow was - "x11_window", XNFocusWindow is now gui.wid. (Nagano) -- Remove some compile warnings and fix typos. (Namsh) -- For status area, check the gtk+ version while Vim runs. I believe it is - better than compile time check. (Namsh) -- Remove one FIXME for gtk+-xim. (Namsh) -- XIM: Dead keys didn't work for Czech. (Vyskovsky) -- Multibyte: If user input only 3byte such as mb1_mb2_eng or eng_mb1_mb2 VIM - could convert it to special character. (Nam) -- Athena/Motif with XIM: fix preedit area. (Nam) -- XIM: Composed strings were sometimes ignored. Vim crashed when compose - string was longer than 256 bytes. IM's geometry control is fixed. (Nam, - Nagano) -- Win32 multi-byte: hollowed cursor width on a double byte char was wrong. - (Nagano) -- When there is no GUI, selecting XIM caused compilation problems. - Automatically disable XIM when there is no GUI in configure. -- Motif and Athena: When compiled with XIM, but the input method was not - enabled, there would still be a status line. Now the status line is gone if - the input method doesn't work. (Nam) - -Win32: tooltip was not removed when selecting a parent menu (it was when -selecting a menu entry). (Negri) - -Unix with X: Some systems crash on exit, because of the XtCloseDisplay() call. -Removed it, it should not be necessary when exiting. - -Win32: Crash on keypress when compiled with Borland C++. (Aaron) - -When checking for Motif library files, prefer the same location as the include -files (with "include" replaced with "lib") above another entry. - -Athena GUI: Changed "XtOffset()" in gui_at_fs.c to "XtOffsetOf()", like it's -used in gui_x11.c. - -Win32: When testing for a timestamp of a file on floppy, would get a dialog -box when the floppy has been removed. Now return with an error. (Negri) - -Win32 OLE: When forced to come to the foreground, a minimized window was still -minimized, now it's restored. (Zivkov) - -There was no check for a positive 'shiftwidth'. A negative value could cause -a hangup, a zero value a crash. - -Athena GUI: horizontal scrollbar wasn't updated correctly when clicking right -or left of the thumb. - -When making a Visual-block selection in one window, and trying to scroll -another, could cause errors for accessing non-existent line numbers. - -When 'matchpairs' contains "`:'", jumping from the ` to the ' didn't work -properly. - -Changed '\"' to '"' to make it compatible with old C compilers. - -The command line expansion for mappings caused a script with a TAB between lhs -and rhs of a map command to fail. Assume the TAB is to separate lhs and rhs -when there are no mappings to expand. - -When editing a file with very long lines with 'scrolloff' set, "j" would -sometimes end up in a line which wasn't displayed. - -When editing a read-only file, it was completely read into memory, even when -it would not fit. Now create a swap file for a read-only file when running -out of memory while reading the file. - -When using ":set cino={s,e-s", a line after "} else {" was not indented -properly. Also added a check for this in test3.in. - -The Hebrew mapping for the command line was remembered for the next command -line. That isn't very useful, a command is not Hebrew. (Kol) - -When completing file names with embedded spaces, like "Program\ files", this -didn't work. Also for user commands. Moved backslash_halve() down to -mch_expandpath(). - -When using "set mouse=a" in Ex mode, mouse events were handled like typed -text. Then typing "quit" screwed up the mouse behavior of the xterm. - -When repeating an insert with "." that contains a CTRL-Y, a number 5 was -inserted as "053". - -Yanking a Visual area, with the cursor past the line, didn't move the cursor -back onto the line. Same for "~", "u", "U" and "g?" - -Win32: Default for 'grepprg' could be "findstr /n" even though there is no -findstr.exe (Windows 95). Check if it exists, and fall back to "grep -n" if -it doesn't. - -Because gui_mouse_moved() inserted a leftmouse click in the input buffer, -remapping a leftmouse click caused strange effects. Now Insert another code -in the input buffer. Also insert a leftmouse release, to avoid the problem -with ":map <LeftMouse> l" that the next release is seen as the release for the -focus click. - -With 'wrap' on, when using a line that doesn't fit on the screen, if the start -of the Visual area is before the start of the screen, there was no -highlighting. Also, 'showbreak' doesn't work properly. - -DOS, Win32: A pattern "[0-9]\+" didn't work in autocommands. - -When creating a swap file for a buffer which isn't the current buffer, could -get a mixup of short file name, resulting in a long file name when a short -file name was required. makeswapname() was calling modname() instead of -buf_modname(). - -When a function caused an error, and the error message was very long because -of recursiveness, this would cause a crash. - -'suffixes' were always compared with matching case. For MS-DOS, Win32 and -OS/2 case is now ignored. - -The use of CHARBITS in regexp.c didn't work on some Linux. Don't use it. - -When generating a script file, 'cpo' was made empty. This caused backslashes -to disappear from mappings. Set it to "B" to avoid that. - -Lots of typos in the documentation. (Campbell) - -When editing an existing (hidden) buffer, jump to the last used cursor -position. (Madsen) - -On a Sun the xterm screen was not restored properly when suspending. (Madsen) - -When $VIMINIT is processed, 'nocompatible' was only set after processing it. - -Unix: Polling for a character wasn't done for GPM, Sniff and Xterm clipboard -all together. Cleaned up the code for using select() too. - -When executing external commands from the GUI, some typeahead was lost. Added -some code to regain as much typeahead as possible. - -When the window height is 5 lines or fewer, <PageDown> didn't use a one-line -overlap, while <PageUp> does. Made sure that <PageUp> uses the same overlap -as <PageDown>, so that using them both always displays the same lines. - -Removed a few unused functions and variables (found with lint). - -Dictionary completion didn't use 'infercase'. (Raul) - -Configure tests failed when the Perl library was not in LD_LIBRARY_PATH. -Don't use the Perl library for configure tests, add it to the linker line only -when linking Vim. - -When using ncurses/terminfo, could get a 't_Sf' and 't_Sb' termcap entry that -has "%d" instead of "%p1%d". The light background colors didn't work then. - -GTK GUI with ncurses: Crashed when starting up in tputs(). Don't use tputs() -when the GUI is active. - -Could use the ":let" command to set the "count", "shell_error" and "version" -variables, but that didn't work. Give an error message when trying to set -them. - -On FreeBSD 3.0, tclsh is called tclsh8.0. Adjusted configure.in to find it. - -When Vim is linked with -lncurses, but python uses -ltermcap, this causes -trouble: "OOPS". Configure now removes the -ltermcap. - -:@" and :*" didn't work properly, because the " was recognized as the start of -a comment. - -Win32s GUI: Minimizing the console where a filter command runs in caused -trouble for detecting that the filter command has finished. (Negri) - -After executing a filter command from an xterm, the mouse would be disabled. -It would work again after changing the mode. - -Mac GUI: Crashed in newenv(). (St-Amant) - -The menus and mappings in mswin.vim didn't handle text ending in a NL -correctly. (Acevedo) - -The ":k" command didn't check if it had a valid argument or extra characters. -Now give a meaningful error message. (Webb) - -On SGI, the signal function doesn't always have three arguments. Check for -struct sigcontext to find out. Might still be wrong... - -Could crash when using 'hlsearch' and search pattern is "^". - -When search patterns were saved and restored, status of no_hlsearch was not -also saved and restored (from ":nohlsearch" command). - -When using setline() to make a line shorter, the cursor position was not -adjusted. - -MS-DOS and Win95: When trying to edit a file and accidentally adding a slash -or backslash at the end, the file was deleted. Probably when trying to create -the swap file. Explicitly check for a trailing slash or backslash before -trying to read a file. - -X11 GUI: When starting the GUI failed and received a deadly signal while -setting the title, would lock up when trying to exit, because the title is -reset again. Avoid using mch_settitle() recursively. - -X11 GUI: When starting the GUI fails, and then trying it again, would crash, -because argv[] has been freed and x11_display was reset to NULL. - -Win32: When $HOME was set, would put "~user" in the swap file, which would -never compare with a file name, and never cause the attention message. Put -the full path in the swap file instead. - -Win32 console: There were funny characters at the end of the "vim -r" swap -files message (direct output of CR CR LF). - -DOS 32 bit: "vim -r" put the text at the top of the window. - -GUI: With 'mousefocus' set, got mouse codes as text with "!sleep 100" or "Q". - -Motif and Win32 GUI: When changing 'guifont' to a font of the same size the -screen wasn't redrawn. - -Unix: When using ":make", jumping to a file b.c, which is already open as a -symbolic link a.c, opened a new buffer instead of using the existing one. - -Inserting text in the current buffer while sourcing the .vimrc file would -cause a crash or hang. The memfile for the current buffer was never -allocated. Now it's allocated as soon as something is written in the buffer. - -DOS 32 bit: "lightblue" background worked for text, but not drawn parts were -black. - -DOS: Colors of console were not restored upon exiting. - -When recording, with 'cmdheight' set to 2 and typing Esc> in Insert mode -caused the "recording" message to be doubled. - -Spurious "file changed" messages could happen on Windows. Now tolerate a one -second difference, like for Linux. - -GUI: When returning from Ex mode, scrollbars were not updated. - -Win32: Copying text to the clipboard containing a <CR>, pasting it would -replace it with a <NL> and drop the next character. - -Entering a double byte character didn't work if the second byte is in [xXoO]. -(Eric Lee) - -vim_realloc was both defined and had a prototype in proto/misc2.pro. Caused -conflicts on Solaris. - -A pattern in an autocommand was treated differently on DOS et al. than on -Unix. Now it's the same, also when using backslashes. - -When using <Tab> twice for command line completion, without a match, the <Tab> -would be inserted. (Negri) - -Bug in MS-Visual C++ 6.0 when compiling ex_docmd.c with optimization. (Negri) - -Testing the result of mktemp() for failure was wrong. Could cause a crash. -(Peters) - -GUI: When checking for a ".gvimrc" file in the current directory, didn't check -for a "_gvimrc" file too. - -Motif GUI: When using the popup menu and then adding an item to the menu bar, -the menu bar would get very high. - -Mouse clicks and special keys (e.g. cursor keys) quit the more prompt and -dialogs. Now they are ignored. - -When at the more-prompt, xterm selection didn't work. Now use the 'r' flag in -'mouse' also for the more-prompt. - -When selecting a Visual area of more than 1023 lines, with 'guioptions' set to -"a", could mess up the display because of a message in free_yank(). Removed -that message, except for the Amiga. - -Moved auto-selection from ui_write() to the screen update functions. Avoids -unexpected behavior from a low-level function. Also makes the different -feedback of owning the selection possible. - -Vi incompatibility: Using "i<CR>" in an indent, with 'ai' set, used the -original indent instead of truncating it at the cursor. (Webb) - -":echo x" didn't stop at "q" for the more prompt. - -Various fixes for Macintosh. (St-Amant) - -When using 'selectmode' set to "exclusive", selecting a word and then using -CTRL-] included the character under the cursor. - -Using ":let a:name" in a function caused a crash. (Webb) - -When using ":append", an empty line didn't scroll up. - -DOS etc.: A file name starting with '!' didn't work. Added '!' to default for -'isfname'. - -BeOS: Compilation problem with prototype of skip_class_name(). (Price) - -When deleting more than one line, e.g., with "de", could still use "U" -command, which didn't work properly then. - -Amiga: Could not compile ex_docmd.c, it was getting too big. Moved some -functions to ex_cmds.c. - -The expand() function would add a trailing slash for directories. - -Didn't give an error message when trying to assign a value to an argument of a -function. (Webb) - -Moved including sys/ptem.h to after termios.h. Needed for Sinix. - -OLE interface: Don't delete the object in CVimCF::Release() when the reference -count becomes zero. (Cordell) -VisVim could still crash on exit. (Erhardt) - -"case a: case b:" (two case statements in one line) aligned with the second -case. Now it uses one 'sw' for indent. (Webb) - -Font initialisation wasn't right for Athena/Motif GUI. Moved the call to -highlight_gui_started() gui_mch_init() to gui_mch_open(). (Nam) - -In Replace mode, backspacing over a TAB before where the replace mode started -while 'sts' is different from 'ts', would delete the TAB. - -Win32 console: When executing external commands and switching between the two -console screens, Vim would copy the text between the buffers. That caused the -screen to be messed up for backtick expansion. - -":winpos -1" then ":winpos" gave wrong error message. - -Windows commander creates files called c:\tmp\$wc\abc.txt. Don't remove the -backslash before the $. Environment variables were not expanded anyway, -because of the backslash before the dollar. - -Using "-=" with ":set" could remove half a part when it contains a "\,". -E.g., ":set path+=a\\,b" and then "set path-=b" removed ",b". - -When Visually selecting lines, with 'selection' set to "inclusive", including -the last char of the line, "<<" moved an extra line. Also for other operators -that always work on lines. - -link.sh changed "-lnsl_s" to "_s" when looking for "nsl" to be removed. -Now it only remove whole words. - -When jumped to a mark or using "fz", and there is an error, the current column -was lost. E.g. when using "$fzj". - -The "g CTRL-G" command could not be interrupted, even though it can take a -long time. - -Some terminals do have <F4> and <xF4>. <xF4> was always interpreted as <F4>. -Now map <xF4> to <F4>, so that the user can override this. - -When compiling os_win32.c with MIN_FEAT the apply_autocmds() should not be -used. (Aaron) - -This autocommand looped forever: ":au FileChangedShell * nested e <afile>" -Now FileChangeShell never nests. (Roemer) - -When evaluating an ":elseif" that was not going to matter anyway, ignore -errors. (Roemer) - -GUI Lesstif: Tearoff bar was the last item, instead of the first. - -GUI Motif: Colors of tear-off widgets was wrong when 't' flag added to -'guioptions' afterwards. When 't' flag in 'guioptions' is excluded, would -still get a tearoff item in a new menu. - -An inode number can be "long long". Use ino_t instead of long. Added -configure check for ino_t. - -Binary search for tags was using a file offset "long" instead of "off_t". - -Insert mode completion of tags was not using 'ignorecase' properly. - -In Insert mode, the <xFn> keys were not properly mapped to <Fn> for the -default mappings. Also caused errors for ":mkvimrc" and ":mksession". - -When jumping to another window while in Insert mode, would get the "warning: -changing readonly file" even when not making a change. - -A '(' or '{' inside a trailing "//" comment would disturb C-indenting. -When using two labels below each other, the second one was not indented -properly. Comments could mess up C-indenting in many places. (Roemer) - -Could delete or redefine a function while it was being used. Could cause a -crash. -In a function it's logical to prepend "g:" to a system variable, but this -didn't work. (Roemer) - -Hangul input: Buffer would overflow when user inputs invalid key sequence. -(Nam) - -When BufLoad or BufEnter autocommands change the topline of the buffer in the -window, it was overruled and the cursor put halfway the window. Now only put -the cursor halfway if the autocommands didn't change the topline. - -Calling exists("&option") always returned 1. (Roemer) - -Win32: Didn't take actually available memory into account. (Williams) - -White space after an automatically inserted comment leader was not removed -when 'ai' is not set and <CR> hit just after inserting it. (Webb) - -A few menus had duplicated accelerators. (Roemer) - -Spelling errors in documentation, quite a few "the the". (Roemer) - -Missing prototypes for Macintosh. (Kielhorn) - -Win32: When using 'shellquote' or 'shellxquote', the "!start cmd" wasn't -executed in a disconnected process. - -When resizing the window, causing a line before the cursor to wrap or unwrap, -the cursor was displayed in the wrong position. - -There was quite a bit of dead code when compiling with minimal features. - -When doing a ":%s///" command that makes lines shorter, such that lines above -the final cursor position no longer wrap, the cursor position was not updated. - -get_id_list() could allocate an array one too small, when a "contains=" item -has a wildcard that matches a group name that is added just after it. E.g.: -"contains=a.*b,axb". Give an error message for it. - -When yanking a Visual area and using the middle mouse button -> crash. When -clipboard doesn't work, now make "* always use "". - -Win32: Using ":buf a\ b\file" didn't work, it was interpreted as "ab\file". - -Using ":ts ident", then hit <CR>, with 'cmdheight' set to 2: command line was -not cleared, the tselect prompt was on the last but one line. - -mksession didn't restore the cursor column properly when it was after a tab. -Could not get all windows back when using a smaller terminal screen. Didn't -restore all windows when "winsize" was not in 'sessionoptions'. (Webb) - -Command line completion for ":buffer" depended on 'ignorecase' for Unix, but -not for DOS et al.. Now don't use 'ignorecase', but let it depend on whether -file names are case sensitive or not (like when expanding file names). - -Win32 GUI: (Negri) -- Redrawing the background caused flicker when resizing the window. Removed - _OnEraseBG(). Removed CS_HREDRAW and CS_VREDRAW flags from the - sndclass.style. -- Some parts of the window were drawn in grey, instead of using the color from - the user color scheme. -- Dropping a file on gvim didn't activate the window. -- When there is no menu ('guioptions' excludes 'm'), never use the ALT key for - it. - -GUI: When resizing the window, would make the window height a bit smaller. -Now round off to the nearest char cell size. (Negri) - -In Vi the ")" and "(" commands don't stop at a single space after a dot. -Added 'J' flag in 'cpoptions' to make this behave Vi compatible. (Roemer) - -When saving a session without any buffers loaded, there would be a ":normal" -command without arguments in it. (Webb) - -Memory leaks fixed: (Madsen) -- eval.c: forgot to release func structure when func deleted -- ex_docmd.c: forgot to release string after "<sfile>" -- misc1.c: leak when completion pattern had no matches. -- os_unix.c: forgot to release regexp after file completions - -Could crash when using a buffer without a name. (Madsen) -Could crash when doing file name completion, because of backslash_halve(). -(Madsen) - -":@a" would do mappings on register a, which is not Vi compatible. (Roemer) - -":g/foo.*()/s/foobar/_&/gc" worked fine, but then "n" searched for "foobar" -and displayed "/foo.*()". (Roemer) - -OS/2: get_cmd_output() was not included. Didn't check for $VIM/.vimrc file. - -Command line completion of options didn't work after "+=" and "-=". - -Unix configure: Test for memmove()/bcopy()/memcpy() tried redefining these -functions, which could fail if they are defined already. Use mch_memmove() to -redefine. - -Unix: ":let a = expand("`xterm`&")" started an xterm asynchronously, but -":let a = expand("`xterm&`")" generated an error message, because the -redirection was put after the '&'. - -Win32 GUI: Dialog buttons could not be selected properly with cursor keys, -when the default is not the first button. (Webb) - -The "File has changed since editing started" (when regaining focus) could not -always be seen. (Webb) - -When starting with "ex filename", the file message was overwritten with -the "entering Ex mode" message. - -Output of ":tselect" listed name of file directly from the tags file. Now it -is corrected for the position of the tags file. - -When 'backspace' is 0, could backspace over autoindent. Now it is no longer -allowed (Vi compatible). - -In Replace mode, when 'noexpandtab' and 'smarttab' were set, and inserting -Tabs, backspacing didn't work correctly for Tabs inserted at the start of the -line (unless 'sts' was set too). Also, when replacing the first non-blank -after which is a space, rounding the indent was done on the first non-blank -instead of on the character under the cursor. - -When 'sw' at 4, 'ts' at 8 and 'smarttab' set: When a tab was appended after -four spaces (they are replaced with a tab) couldn't backspace over the tab. - -In Insert mode, with 'bs' set to 0, couldn't backspace to before autoindent, -even when it was removed with CTRL-D. - -When repeating an insert command where a <BS>, <Left> or other key causes an -error, would flush buffers and remain in Insert mode. No longer flush -buffers, only beep and continue with the insert command. - -Dos and Win32 console: Setting t_me didn't work to get another color. Made -this works backwards compatible. - -For Turkish (LANG = "tr") uppercase 'i' is not an 'I'. Use ASCII uppercase -translation in vim_strup() to avoid language problems. (Komur) - -Unix: Use usleep() or nanosleep() for mch_delay() when available. Hopefully -this avoids a hangup in select(0, ..) for Solaris 2.6. - -Vim would crash when using a script file with 'let &sp = "| tee"', starting -vim with "vim -u test", then doing ":set sp=". The P_WAS_SET flag wasn't set -for a string option, could cause problems with any string option. - -When using "cmd | vim -", stdin is not a terminal. This gave problems with -GPM (Linux console mouse) and when executing external commands. Now close -stdin and re-open it as a copy of stderr. - -Syntax highlighting: A "nextgroup" item was not properly stored in the state -list. This caused missing of next groups when not redrawing from start to -end, but starting halfway. - -Didn't check for valid values of 'ttymouse'. - -When executing an external command from the GUI, waiting for the child to -terminate might not work, causing a hang. (Parmelan) - -"make uninstall" didn't delete the vimrc_example.vim and gvimrc_example.vim -files and the vimtutor. - -Win32: "expand("%:p:h")" with no buffer name removed the directory name. -"fnamemodify("", ":p")" did not add a trailing slash, fname_case() removed it. - -Fixed: When 'hlsearch' was set and the 'c' flag was not in 'cpoptions': -highlighting was not correct. Now overlapping matches are handled correctly. - -Athena, Motif and GTK GUI: When started without focus, cursor was shown as if -with focus. - -Don't include 'shellpipe' when compiled without quickfix, it's not used. -Don't include 'dictionary' option when compiled without the +insert_expand -feature. -Only include the 'shelltype' option for the Amiga. - -When making a change to a line, with 'hlsearch' on, causing it to wrap, while -executing a register, the screen would not be updated correctly. This was a -generic problem in update_screenline() being called while must_redraw is -VALID. - -Using ":bdelete" in a BufUnload autocommand could cause a crash. The window -height was added to another window twice in close_window(). - -Win32 GUI: When removing a menu item, the tearoff wasn't updated. (Negri) - -Some performance bottlenecks removed. Allocating memory was not efficient. -For Win32 checking for available memory was slow, don't check it every time -now. On NT obtaining the user name takes a long time, cache the result (for -all systems). - -fnamemodify() with an argument ":~:." or ":.:~" didn't work properly. - -When editing a new file and exiting, the marks for the buffer were not saved -in the viminfo file. - -":confirm only" didn't put up a dialog. - -These text objects didn't work when 'selection' was "exclusive": va( vi( va{ -vi{ va< vi< vi[ va[. - -The dialog for writing a readonly file didn't have a valid default. (Negri) - -The line number used for error messages when sourcing a file was reset when -modelines were inspected. It was wrong when executing a function. - -The file name and line number for an error message wasn't displayed when it -was the same as for the last error, even when this was long ago. Now reset -the name/lnum after a hit-enter prompt. - -In a session file, a "%" in a file name caused trouble, because fprintf() was -used to write it to the file. - -When skipping statements, a mark in an address wasn't skipped correctly: -"ka|if 0|'ad|else|echo|endif". (Roemer) - -":wall" could overwrite a not-edited file without asking. - -GUI: When $DISPLAY was not set or starting the GUI failed in another way, the -console mode then started with wrong colors and skipped initializations. Now -do an early check if the GUI can be started. Don't source the menu.vim or -gvimrc when it will not. Also do normal terminal initializations if the GUI -might not start. - -When using a BufEnter autocommand to position the cursor and scroll the -window, the cursor was always put at the last used line and halfway the window -anyhow. - -When 'wildmode' was set to "longest,list:full", ":e *.c<Tab><Tab>" didn't list -the matches. Also avoid that listing after a "longest" lists the wrong -matches when the first expansion changed the string in front of the cursor. - -When using ":insert", ":append" or ":change" inside a while loop, was not able -to break out of it with a CTRL-C. - -Win32: ":e ." took an awful long time before an error message when used in -"C:\". Was caused by adding another backslash and then trying to get the full -name for "C:\\". - -":winpos -10 100" was working like ":winpos -10 -10", because a pointer was -not advanced past the '-' sign. - -When obtaining the value of a hidden option, would give an error message. Now -just use a zero value. - -OS/2: Was using argv[0], even though it was not a useful name. It could be -just "vim", found in the search path. - -Xterm: ":set columns=78" didn't redraw properly (when lines wrap/unwrap) until -after a delay of 'updatetime'. Didn't check for the size-changed signal. - -'scrollbind' didn't work in Insert mode. -Horizontal scrollbinding didn't always work for "0" and "$" commands (e.g., -when 'showcmd' was off). - -When compiled with minimal features but with GUI, switching on the mouse in an -xterm caused garbage, because the mouse codes were not recognized. Don't -enable the mouse when it can't be recognized. In the GUI it also didn't work, -the arguments to the mouse code were not interpreted. - -When 'showbreak' used, in Insert mode, when the cursor is just after the last -character in the line, which is also the in the rightmost column, the cursor -position would be like the 'showbreak' string is shown, but it wasn't. - -Autocommands could move the cursor in a new file, so that CTRL-W i didn't show -the right line. Same for when using a filemark to jump to another file. - -When redefining the argument list, the title used for other windows could be -showing the wrong info about the position in the argument list. Also update -this for a ":split" command without arguments. - -When editing file 97 of 13, ":Next" didn't work. Now it goes to the last -file in the argument list. - -Insert mode completion (for dictionaries or included files) could not be -interrupted by typing an <Esc>. Could get hit-enter prompt after line -completion, or whenever the informative message would get too long. - -When using the ":edit" command to re-edit the same file, an autocommand to -jump to the last cursor position caused the cursor to move. Now set the last -used cursor position to avoid this. - -When 'comments' has a part that starts with white space, formatting the -comment didn't work. - -At the ":tselect" prompt Normal mode mappings were used. That has been -disabled. - -When 'selection' is not "old", some commands still didn't allow the cursor -past the end-of-line in Visual mode. - -Athena: When a menu was deleted, it would appear again (but not functional) -when adding another menu. Now they don't reappear anymore (although they are -not really deleted either). - -Borland C++ 4.x had an optimizer problem in fill_breakat_flags(). (Negri) - -"ze" didn't work when 'number' was on. (Davis) - -Win32 GUI: Intellimouse code didn't work properly on Windows 98. (Robinson) - -A few files were including proto.h a second time, after vim.h had already done -that, which could cause problems with the vim_realloc() macro. - -Win32 console: <M-x> or ALT-x was not recognized. Also keypad '+', '-' and -'*'. (Negri) -MS-DOS: <M-x> didn't work, produced a two-byte code. Now the alphabetic and -number keys work. (Negri) - -When finding a lot of matches for a tag completion, the check for avoiding -double matches could take a lot of time. Add a line_breakcheck() to be able -to interrupt this. (Deshpande) - -When the command line was getting longer than the screen, the more-prompt -would be given regularly, and the cursor position would be wrong. Now only -show the part of the command line that fits on the screen and force the cursor -to be positioned on the visible part. There can be text after the cursor -which isn't editable. - -At the more prompt and with the console dialog, a cursor key was interpreted -as <Esc> and OA. Now recognize special keys in get_keystroke(). Ignore mouse -and scrollbar events. - -When typing a BS after inserting a middle comment leader, typing the last char -of the end comment leader still changed it into the end comment leader. (Webb) - -When a file system is full, writing to a swap file failed. Now first try to -write one block to the file. Try next entry in 'dir' if it fails. - -When "~" is in 'whichwrap', doing "~" on last char of a line didn't update the -display. - -Unix: Expanding wildcards for ":file {\\}" didn't work, because "\}" was -translated to "}" before the shell got it. Now don't remove backslashes when -wildcards are going to be expanded. - -Unix: ":e /tmp/$uid" didn't work. When expanding environment variables in a -file name doesn't work, use the shell to expand the file name. ":e /tmp/$tty" -still doesn't work though. - -"make test" didn't always work on DOS/Windows for test30, because it depended -on the external "echo" command. - -The link.sh script used "make" instead of $MAKE from the Makefile. Caused -problems for generating pathdef.c when "make" doesn't work properly. - -On versions that can do console and GUI: In the console a typed CSI code could -cause trouble. - -The patterns in expression evaluation didn't ignore the 'l' flag in -'cpoptions'. This broke the working of <CR> in the options window. - -When 'hls' off and 'ai' on, "O<Esc>" did remove the indent, but it was still -highlighted red for trailing space. - -Win32 GUI: Dropping an encrypted file on a running gvim didn't work right. Vim -would loop while outputting "*" characters. vgetc() was called recursively, -thus it returns NUL. Added safe_vgetc(), which reads input directly from the -user in this situation. - -While reading text from stdin, only an empty screen was shown. Now show that -Vim is reading from stdin. - -The cursor shape wasn't set properly when returning to Insert mode, after -using a CTRL-O /asdf command which fails. It would be OK after a few seconds. -Now it's OK right away. - -The 'isfname' default for DOS/Windows didn't include the '@' character. File -names that contained "dir\@file" could not be edited. - -Win32 console: <C-S-Left> could cause a crash when compiled with Borland or -egcs. (Aaron) - -Unix and VMS: "#if HAVE_DIRENT_H" caused problems for some compilers. Use -"#ifdef HAVE_DIRENT_H" instead. (Jones) - -When a matching tag is in the current file but has a search pattern that -doesn't match, the cursor would jump to the first line. - -Unix: Dependencies for pty.c were not included in Makefile. Dependency of -ctags/config.h was not included (only matters for parallel make). - -Removed a few Uninitialized Memory Reads (potential crashes). In do_call() -calling clear_var() when not evaluating. In win32_expandpath() and -dos_expandpath() calling backslash_halve() past the end of a file name. - -Removed memory leaks: Set_vim_var_string() never freed the value. The -next_list for a syntax keyword was never freed. - -On non-Unix systems, using a file name with wildcards without a match would -silently fail. E.g., ":e *.sh". Now give a "No match" error message. - -The life/life.mac, urm/urm.mac and hanoi/hanoi.mac files were not recognized -as Vim scripts. Renamed them to *.vim. - -[Note: some numbered patches are not relevant when upgrading from version 5.3, -they have been removed] - -Patch 5.4m.1 -Problem: When editing a file with a long name, would get the hit-enter - prompt, even though all settings are such that the name should be - truncated to avoid that. filemess() was printing the file name - without truncating it. -Solution: Truncate the message in filemess(). Use the same code as for - msg_trunc_attr(), which is moved to the new function - msg_may_trunc(). -Files: src/message.c, src/proto/message.pro, src/fileio.c - -Patch 5.4m.3 -Problem: The Motif libraries were not found by configure for Digital Unix. -Solution: Add "/usr/shlib" to the search path. (Andy Kahn) -Files: src/configure.in, src/configure - -Patch 5.4m.5 -Problem: Win32 GUI: When using the Save-As menu entry and selecting an - existing file in the file browser, would get a dialog to confirm - overwriting twice. (Ed Krall) -Solution: Removed the dialog from the file browser. It would be nicer to - set the "forceit" flag and skip Vim's ":confirm" dialog, but it - requires quite a few changes to do that. -Files: src/gui_w32.c - -Patch 5.4m.6 -Problem: Win32 GUI: When reading text from stdin, e.g., "cat foo | gvim -", - a message box would pop up with "-stdin-" (when exiting). (Michael - Schaap) -Solution: Don't switch off termcap mode for versions that are GUI-only. - They use another terminal to read from stdin. -Files: src/main.c, src/fileio.c - -Patch 5.4m.7 -Problem: Unix: running configure with --enable-gtk-check, - --enable-motif-check, --enable-athena-check or --enable-gtktest - had the reverse effect. (Thomas Koehler) -Solution: Use $enable_gtk_check variable correctly in AC_ARG_ENABLE(). -Files: src/configure.in, src/configure - -Patch 5.4m.9 -Problem: Multi-byte: With wrapping lines, the cursor was sometimes 2 - characters to the left. Syntax highlighting was wrong when a - double-byte character was split for a wrapping line. When - 'showbreak' was on the splitting also didn't work. -Solution: Adjust getvcol() and win_line(). (Chong-Dae Park) -Files: src/charset.c, src/screen.c - -Patch 5.4m.11 -Problem: The ":call" command didn't check for illegal trailing characters. - (Stefan Roemer) -Solution: Add the check in do_call(). -Files: src/eval.c - -Patch 5.4m.13 -Problem: With the ":s" command: - 1. When performing a substitute command, the mouse would be - disabled and enabled for every substitution. - 2. The cursor position could be beyond the end of the line. - Calling line_breakcheck() could try to position the cursor, - which causes a crash in the Win32 GUI. - 3. When using ":s" in a ":g" command, the cursor was not put on - the first non-white in the line. - 4. There was a hit-enter prompt when confirming the substitution - and the replacement was a bit longer. -Solution: 1. Only disable/enable the mouse when asking for confirmation. - 2. Always put the cursor on the first character, it is going to be - moved to the first non-blank anyway. - Don't use the cursor position in gui_mch_draw_hollow_cursor(), - get the character from the screen buffer. - 3. Added global_need_beginline flag to call beginline() after ":g" - has finished all substitutions. - 4. Clear the need_wait_return flag after prompting the user. -Files: src/ex_cmds.c, src/gui_w32.c - -Patch 5.4m.14 -Problem: When doing "vim xxx", ":opt", ":only" and then ":e xxx" we end - up with two swapfiles for "xxx". That is caused by the ":bdel" - command which is executed when unloading the option-window. - Also, there was no check if closing a buffer made the new one - invalid, this could cause a crash. -Solution: When closing a buffer causes the current buffer to be deleted, - use the new buffer to replace it. Also detect that the new buffer - has become invalid as a side effect of closing the current one. - Make autocommand that calls ":bdel" in optwin.vim nested, so that - the buffer loading it triggers also executes autocommands. - Also added a test for this in test13. -Files: runtime/optwin.vim, src/buffer.c, src/ex_cmds.c, src/globals.h - src/testdir/test13.in, src/testdir/test13.ok - -Patch 5.4m.15 -Problem: When using a BufEnter autocommand to reload the syntax file, - conversion to HTML caused a crash. (Sung-Hyun Nam) -Solution: When using ":syntax clear" the current stack of syntax items was - not cleared. This will cause memory to be used that has already - been freed. Added call to invalidate_current_state() in - syntax_clear(). -Files: src/syntax.c - -Patch 5.4m.17 -Problem: When omitting a ')' in an expression it would not be seen as a - failure. - When detecting an error inside (), there would be an error message - for a missing ')' too. - When using ":echo 1+|echo 2" there was no error message. (Roemer) - When using ":exe 1+" there was no error message. - When using ":return 1+" there was no error message. -Solution: Fix do_echo(), do_execute() and do_return() to give an error - message when eval1() returns FAIL. - Fix eval6() to handle trailing ')' correctly and return FAIL when - it's missing. -Files: src/eval.c - -Patch 5.4m.18 -Problem: When using input() from inside an expression entered with - "CTRL-R =" on the command line, there could be a crash. And the - resulting command line was wrong. -Solution: Added getcmdline_prompt(), which handles recursive use of - getcmdline() correctly. It also sets the command line prompt. - Removed cmdline_prompt(). Also use getcmdline_prompt() for - getting the crypt key in get_crypt_key(). -Files: src/proto/ex_getln.pro, src/ex_getln.c, src/eval.c, src/misc2.c - -Patch 5.4m.21 -Problem: When starting up, the screen structures were first allocated at - the minimal size, then initializations were done with Rows - possibly different from screen_Rows. Caused a crash in rare - situations (GTK with XIM and fontset). -Solution: Call screenalloc() in main() only after calling ui_get_winsize(). - Also avoids a potential delay because of calling screenclear() - while "starting" is non-zero. -Files: src/main.c - -Patch 5.4m.22 -Problem: In the GUI it was possible that the screen was resized and the - screen structures re-allocated while redrawing the screen. This - could cause a crash (hard to reproduce). The call sequence goes - through update_screen() .. syntax_start() .. ui_breakcheck() .. - gui_resize_window() .. screenalloc(). -Solution: Set updating_screen while redrawing. If the window is resized - remember the new size and handle it only after redrawing is - finished. - This also fixes that resizing the screen while still redrawing - (slow syntax highlighting) would not work properly. - Also disable display_hint, it was never used. -Files: src/globals.h, src/gui.c, src/screen.c, src/proto/gui.pro - -Patch 5.4m.23 -Problem: When using expand("<cword>") when there was no word under the - cursor, would get an error message. Same for <cWORD> and <cfile>. -Solution: Don't give an error message, return an empty string. -Files: src/eval.c - -Patch 5.4m.24 -Problem: ":help \|" didn't find anything. It was translated to "/\\|". -Solution: Translate "\|" into "\\bar". First check the table for specific - translations before checking for "\x". -Files: src/ex_cmds.c - -Patch 5.4m.25 -Problem: Unix: When using command line completion on files that contain - ''', '"' or '|' the file name could not be used. - Adding this file name to the Buffers menu caused an error message. -Solution: Insert a backslash before these three characters. - Adjust Mungename() function to insert a backslash before '|'. -Files: src/ex_getln.c, runtime/menu.vim - -Patch 5.4m.26 -Problem: When using a mapping of two function keys, e.g., <F1><F1>, and - only the first char of the second key has been read, the mapping - would not be recognized. Noticed on some Unix systems with xterm. -Solution: Add 'K' flag to 'cpoptions' to wait for the whole key code, even - when halfway a mapping. -Files: src/option.h, src/term.c - -Patch 5.4m.27 -Problem: When making test33 without the lisp feature it hangs. Interrupting - the execution of the script then might cause a crash. -Solution: In inchar(), after closing a script, don't use buf[] anymore. - closescript() has freed typebuf[] and buf[] might be pointing - inside typebuf[]. - Avoid that test33 hangs when the lisp feature is missing. -Files: src/getchar.c src/testdir/test33.in - -"os2" was missing from the feature list. Useful for has("os2"). - -BeOS: -- Included patches from Richard Offer for BeOS R4.5. -- menu code didn't work right. Crashed in the Buffers menu. The window title - wasn't set. (Offer) - -Patch 5.4n.3 -Problem: C-indenting was wrong after " } else". The white space was not - skipped. Visible when 'cino' has "+10". -Solution: Skip white space before calling cin_iselse(). (Norbert Zeh) -Files: src/misc1.c - -Patch 5.4n.4 -Problem: When the 't' flag in 'cpoptions' is included, after a - ":nohlsearch" the search highlighting would not be enabled again - after a tag search. (Norbert Zeh) -Solution: When setting the new search pattern in jumpto_tag(), don't restore - no_hlsearch. -Files: src/tag.c - -Patch 5.4n.5 -Problem: When using ":normal" from a CursorHold autocommand Vim hangs. The - autocommand is executed down from vgetc(). Calling vgetc() - recursively to execute the command doesn't work then. -Solution: Forbid the use of ":normal" when vgetc_busy is set. Give an error - message when this happens. -Files: src/ex_docmd.c, runtime/doc/autocmd.txt - -Patch 5.4n.6 -Problem: "gv" could reselect a Visual that starts and/or ends past the end - of a line. (Robert Webb) -Solution: Check that the start and end of the Visual area are on a valid - character by calling adjust_cursor(). -Files: src/normal.c - -Patch 5.4n.8 -Problem: When a mark was on a non existing line (e.g., when the .viminfo - was edited), jumping to it caused ml_get errors. (Alexey - Marinichev). -Solution: Added check_cursor_lnum() in nv_gomark(). -Files: src/normal.c - -Patch 5.4n.9 -Problem: ":-2" moved the cursor to a negative line number. (Ralf Schandl) -Solution: Give an error message for a negative line number. -Files: src/ex_docmd.c - -Patch 5.4n.10 -Problem: Win32 GUI: At the hit-enter prompt, it was possible to scroll the - text. This erased the prompt and made Vim look like it is in - Normal mode, while it is actually still waiting for a <CR>. -Solution: Disallow scrolling at the hit-enter prompt for systems that use - on the fly scrolling. -Files: src/message.c - -Patch 5.4n.14 -Problem: Win32 GUI: When using ":winsize 80 46" and the height is more than - what fits on the screen, the window size was made smaller than - asked for (that's OK) and Vim crashed (that's not OK)> -Solution: Call check_winsize() from gui_set_winsize() to resize the windows. -Files: src/gui.c - -Patch 5.4n.16 -Problem: Win32 GUI: The <F10> key both selected the menu and was handled as - a key hit. -Solution: Apply 'winaltkeys' to <F10>, like it is used for Alt keys. -Files: src/gui_w32.c - -Patch 5.4n.17 -Problem: Local buffer variables were freed when the buffer is unloaded. - That's not logical, since options are not freed. (Ron Aaron) -Solution: Free local buffer variables only when deleting the buffer. -Files: src/buffer.c - -Patch 5.4n.19 -Problem: Doing ":e" (without argument) in an option-window causes trouble. - The mappings for <CR> and <Space> are not removed. When there is - another buffer loaded, the swap file for it gets mixed up. - (Steve Mueller) -Solution: Also remove the mappings at the BufUnload event, if they are still - present. - When re-editing the same file causes the current buffer to be - deleted, don't try editing it. - Also added a test for this situation. -Files: runtime/optwin.vim, src/ex_cmds.c, src/testdir/test13.in, - src/testdir/test13.ok - -Patch 5.4n.24 -Problem: BeOS: configure never enabled the GUI, because $with_x was "no". - Unix prototypes caused problems, because Display and Widget are - undefined. - Freeing fonts on exit caused a crash. -Solution: Only disable the GUI when $with_x is "no" and $BEOS is not "yes". - Add dummy defines for Display and Widget in proto.h. - Don't free the fonts in gui_exit() for BeOS. -Files: src/configure.in, src/configure, src/proto.h, src/gui.c. - - -The runtime/vim48x48.xpm icon didn't have a transparent background. (Schild) - -Some versions of the mingw32/egcs compiler didn't have WINBASEAPI defined. -(Aaron) - -VMS: -- mch_setenv() had two arguments instead of three. -- The system vimrc and gvimrc files were called ".vimrc" and ".gvimrc". - Removed the dot. -- call to RealWaitForChar() had one argument too many. (Campbell) -- WaitForChar() is static, removed the prototype from proto/os_vms.pro. -- Many file accesses failed, because Unix style file names were used. - Translate file names to VMS style by using vim_fopen(). -- Filtering didn't work, because the temporary file name was generated wrong. -- There was an extra newline every 9192 characters when writing a file. Work - around it by writing line by line. (Campbell) -- os_vms.c contained "# typedef int DESC". Should be "typedef int DESC;". - Only mattered for generating prototypes. -- Added file name translation to many places. Made easy by defining macros - mch_access(), mch_fopen(), mch_fstat(), mch_lstat() and mch_stat(). -- Set default for 'tagbsearch' to off, because binary tag searching apparently - doesn't work for VMS. -- make mch_get_host_name() work with /dec and /standard=vaxc. (Campbell) - - -Patch 5.4o.2 -Problem: Crash when using "gf" on "file.c://comment here". (Scott Graham) -Solution: Fix wrong use of pointers in get_file_name_in_path(). -Files: src/window.c - -Patch 5.4o.3 -Problem: The horizontal scrollbar was not sized correctly when 'number' is - set and 'wrap' not set. - Athena: Horizontal scrollbar wasn't updated when the cursor was - positioned with a mouse click just after dragging. -Solution: Subtract 8 from the size when 'number' set and 'wrap' not set. - Reset gui.dragged_sb when a mouse click is received. -Files: src/gui.c - -Patch 5.4o.4 -Problem: When running in an xterm and $WINDOWID is set to an illegal value, - Vim would exit with "Vim: Got X error". -Solution: When using the display which was opened for the xterm clipboard, - check if x11_window is valid by trying to obtain the window title. - Also add a check in setup_xterm_clip(), for when using X calls to - get the pointer position in an xterm. -Files: src/os_unix.c - -Patch 5.4o.5 -Problem: Motif version with Lesstif: When removing the menubar and then - using a menu shortcut key, Vim would crash. (raf) -Solution: Disable the menu mnemonics when the menu bar is removed. -Files: src/gui_motif.c - -Patch 5.4o.9 -Problem: The DOS install.exe program used the "move" program. That doesn't - work on Windows NT, where "move" is internal to cmd.exe. -Solution: Don't use an external program for moving the executables. Use C - functions to copy the file and delete the original. -Files: src/dosinst.c - -Motif and Athena obtained the status area height differently from GTK. Moved -status_area_enabled from global.h to gui_x11.c and call -xim_get_status_area_height() to get the status area height. - -Patch 5.4p.1 -Problem: When using auto-select, and the "gv" command is used, would not - always obtain ownership of the selection. Caused by the Visual - area still being the same, but ownership taken away by another - program. -Solution: Reset the clipboard Visual mode to force updating the selection. -Files: src/normal.c - -Patch 5.4p.2 -Problem: Motif and Athena with XIM: Typing 3-byte - <multibyte><multibyte><space> doesn't work correctly with Ami XIM. -Solution: Avoid using key_sym XK_VoidSymbol. (Nam) -Files: src/multbyte.c, src/gui_x11.c - -Patch 5.4p.4 -Problem: Win32 GUI: The scrollbar values were reduced for a file with more - than 32767 lines. But this info was kept global for all - scrollbars, causing a mixup between the windows. - Using the down arrow of a scrollbar in a large file didn't work. - Because of round-off errors there is no scroll at all. -Solution: Give each scrollbar its own scroll_shift field. When the down - arrow is used, scroll several lines. -Files: src/gui.h, src/gui_w32.c - -Patch 5.4p.5 -Problem: When changing buffers in a BufDelete autocommand, there could be - ml_line errors and/or a crash. (Schandl) Was caused by deleting - the current buffer. -Solution: When the buffer to be deleted unexpectedly becomes the current - buffer, don't delete it. - Also added a check for this in test13. -Files: src/buffer.c, src/testdir/test13.in, src/testdir/test13.ok - -Patch 5.4p.7 -Problem: Win32 GUI: When using 'mousemodel' set to "popup_setpos" and - clicking the right mouse button outside of the selected area, the - selected area wasn't removed until the popup menu has gone. - (Aaron) -Solution: Set the cursor and update the display before showing the popup - menu. -Files: src/normal.c - -Patch 5.4p.8 -Problem: The generated bugreport didn't contain information about - $VIMRUNTIME and whether runtime files actually exist. -Solution: Added a few checks to the bugreport script. -Files: runtime/bugreport.vim - -Patch 5.4p.9 -Problem: The windows install.exe created a wrong entry in the popup menu. - The "%1" was "". The full directory was included, even when the - executable had been moved elsewhere. (Ott) -Solution: Double the '%' to get one from printf. Only include the path to - gvim.exe when it wasn't moved and it's not in $PATH. -Files: src/dosinst.c - -Patch 5.4p.10 -Problem: Win32: On top of 5.4p.9: The "Edit with Vim" entry sometimes used - a short file name for a directory. -Solution: Change the "%1" to "%L" in the registry entry. -Files: src/dosinst.c - -Patch 5.4p.11 -Problem: Motif, Athena and GTK: When closing the GUI window when there is a - changed buffer, there was only an error message and Vim would not - exit. -Solution: Put up a dialog, like for ":confirm qa". Uses the code that was - already used for MS-Windows. -Files: src/gui.c, src/gui_w32.c - -Patch 5.4p.12 -Problem: Win32: Trying to expand a string that is longer than 256 - characters could cause a crash. (Steed) -Solution: For the buffer in win32_expandpath() don't use a fixed size array, - allocate it. -Files: src/os_win32.c - -MSDOS: Added "-Wall" to Makefile.djg compile flags. Function prototypes for -fname_case() and mch_update_cursor() were missing. "fd" was unused in -mf_sync(). "puiLocation" was unused in myputch(). "newcmd" unused in -mch_call_shell() for DJGPP version. - -============================================================================== -VERSION 5.5 *version-5.5* - -Version 5.5 is a bug-fix version of 5.4. - - -Changed *changed-5.5* -------- - -The DJGPP version is now compiled with "-O2" instead of "-O4" to reduce the -size of the executables. - -Moved the src/STYLE file to runtime/doc/develop.txt. Added the design goals -to it. - -'backspace' is now a string option. See patch 5.4.15. - - -Added *added-5.5* ------ - -Included Exuberant Ctags version 3.3. (Darren Hiebert) - -In runtime/mswin.vim, map CTRL-Q to CTRL-V, so that CTRL-Q can be used -everywhere to do what CTRL-V used to do. - -Support for decompression of bzip2 files in vimrc_example.vim. - -When a patch is included, the patch number is entered in a table in version.c. -This allows skipping a patch without breaking a next one. - -Support for mouse scroll wheel in X11. See patch 5.5a.14. - -line2byte() can be used to get the size of the buffer. See patch 5.4.35. - -The CTRL-R CTRL-O r and CTRL-R CTRL-P r commands in Insert mode are used to -insert a register literally. See patch 5.4.48. - -Uninstall program for MS-Windows. To be able to remove the registry entries -for "Edit with Vim". It is registered to be run from the "Add/Remove -programs" application. See patch 5.4.x7. - - -Fixed *fixed-5.5* ------ - -When using vimrc_example.vim: An error message when the cursor is on a line -higher than the number of lines in the compressed file. Move the autocommand -for jumping to the last known cursor position to after the decompressing -autocommands. - -":mkexrc" and ":mksession" wrote the current value of 'textmode'. That may -mark a file as modified, which causes problems. This is a buffer-specific -setting, it should not affect all files. - -"vim --version" wrote two empty lines. - -Unix: The alarm signal could kill Vim. It is generated by the Perl alarm() -function. Ignore SIGALRM. - -Win32 GUI: Toolbar still had the yellow bitmap for running a Vim script. - -BeOS: "tmo" must be bigtime_t, instead of double. (Seibert) - -Patch 5.4.1 -Problem: Test11 fails when $GZIP is set to "-v". (Matthew Jackson) -Solution: Set $GZIP to an empty string. -Files: src/testdir/test11.in - -Patch 5.4.2 -Problem: Typing <Esc> at the crypt key prompt caused a crash. (Kallingal) -Solution: Check for a NULL pointer returned from get_crypt_key(). -Files: src/fileio.c - -Patch 5.4.3 -Problem: Python: Trying to use the name of an unnamed buffer caused a - crash. (Daniel Burrows) -Solution: Check for b_fname being a NULL pointer. -Files: src/if_python.c - -Patch 5.4.4 -Problem: Win32: When compiled without toolbar, but the 'T' flag is in - 'guioptions', there would be an empty space for the toolbar. -Solution: Add two #ifdefs where checking for the 'T' flag. (Vince Negri) -Files: src/gui.c - -Patch 5.4.5 -Problem: Athena GUI: Using the Buffers.Refresh menu entry caused a crash. - Looks like any ":unmenu" command may cause trouble. -Solution: Disallow ":unmenu" in the Athena version. Disable the Buffers - menu, because the Refresh item would not work. -Files: src/menu.c, runtime/menu.vim - -Patch 5.4.6 -Problem: GTK GUI: Using ":gui" in the .gvimrc file caused an error. Only - happens when the GUI forks. -Solution: Don't fork in a recursive call of gui_start(). -Files: src/gui.c - -Patch 5.4.7 -Problem: Typing 'q' at the more prompt for the ATTENTION message causes the - file loading to be interrupted. (Will Day) -Solution: Reset got_int after showing the ATTENTION message. -Files: src/memline.c - -Patch 5.4.8 -Problem: Edit some file, ":he", ":opt": options from help window are shown, - but pressing space updates from the other window. (Phillipps) - Also: When there are changes in the option-window, ":q!" gives an - error message. -Solution: Before creating the option-window, go to a non-help window. - Use ":bdel!" to delete the buffer. -Files: runtime/optwin.vim - -Patch 5.4.9 - Just updates version.h. The real patch has been moved to 5.4.x1. - This patch is just to keep the version number correct. - -Patch 5.4.10 -Problem: GTK GUI: When $DISPLAY is invalid, "gvim -f" just exits. It - should run in the terminal. -Solution: Use gtk_init_check() instead of gtk_init(). -Files: src/gui_gtk_x11.c - -Patch 5.4.11 -Problem: When using the 'S' flag in 'cpoptions', 'tabstop' is not copied to - the next buffer for some commands, e.g., ":buffer". -Solution: When the BCO_NOHELP flag is given to buf_copy_options(), still - copy the options used by do_help() when neither the "from" or "to" - buffer is a help buffer. -Files: src/option.c - -Patch 5.4.12 -Problem: When using 'smartindent', there would be no extra indent if the - current line did not have any indent already. (Hanus Adler) -Solution: There was a wrongly placed "else", that previously matched with - the "if" that set trunc_line. Removed the "else" and added a - check for trunc_line to be false. -Files: src/misc1.c - -Patch 5.4.13 -Problem: New SGI C compilers need another option for optimisation. -Solution: Add a check in configure for "-OPT:Olimit". (Chin A Young) -Files: src/configure.in, src/configure - -Patch 5.4.14 -Problem: Motif GUI: When the popup menu is present, a tiny window appears - on the desktop for some users. -Solution: Set the menu widget ID for a popup menu to 0. (Thomas Koehler) -Files: src/gui_motif.c - -Patch 5.4.15 -Problem: Since 'backspace' set to 0 has been made Vi compatible, it is no - longer possible to only allow deleting autoindent. -Solution: Make 'backspace' a list of parts, to allow each kind of - backspacing separately. -Files: src/edit.c, src/option.c, src/option.h, src/proto/option.pro, - runtime/doc/option.txt, runtime/doc/insert.txt - -Patch 5.4.16 -Problem: Multibyte: Locale zh_TW.Big5 was not checked for in configure. -Solution: Add zh_TW.Big5 to configure check. (Chih-Tsun Huang) -Files: src/configure.in, src/configure - -Patch 5.4.17 -Problem: GUI: When started from inside gvim with ":!gvim", Vim would not - start. ":!gvim -f" works fine. -Solution: After forking, wait a moment in the parent process, to give the - child a chance to set its process group. -Files: src/gui.c - -Patch 5.4.18 -Problem: Python: The clear_history() function also exists in a library. -Solution: Rename clear_history() to clear_hist(). -Files: src/ex_getln.c, src/eval.c, src/proto/ex_getln.pro - -Patch 5.4.19 -Problem: In a terminal with 25 lines, there is a more prompt after the - ATTENTION message. When hitting 'q' here the dialog prompt - doesn't appear and file loading is interrupted. (Will Day) -Solution: Don't allow quitting the printing of a message for the dialog - prompt. Added the msg_noquit_more flag for this. -Files: src/message.c - -Patch 5.4.20 -Problem: GTK: When starting gvim, would send escape sequences to the - terminal to switch the cursor off and on. -Solution: Don't call msg_start() if the GUI is expected to start. -Files: src/main.c - -Patch 5.4.21 -Problem: Motif: Toplevel menu ordering was wrong when using tear-off items. -Solution: Don't add one to the index for a toplevel menu. -Files: src/gui_motif.c - -Patch 5.4.22 -Problem: In Insert mode, <C-Left>, <S-Left>, <C-Right> and <S-Right> didn't - update the column used for vertical movement. -Solution: Set curwin->w_set_curswant for those commands. -Files: src/edit.c - -Patch 5.4.23 -Problem: When a Visual selection is lost to another program, and then the - same text is Visually selected again, the clipboard ownership - wasn't regained. -Solution: Set clipboard.vmode to NUL to force regaining the clipboard. -Files: src/normal.c - -Patch 5.4.24 -Problem: Encryption: When using ":r file" while 'key' has already entered, - the 'key' option would be messed up. When writing the file it - would be encrypted with an unknown key and lost! (Brad Despres) -Solution: Don't free cryptkey when it is equal to the 'key' option. -Files: src/fileio.c - -Patch 5.4.25 -Problem: When 'cindent' is set, but 'autoindent' isn't, comments are not - properly indented when starting a new line. (Mitterand) -Solution: When there is a comment leader for the new line, but 'autoindent' - isn't set, do C-indenting. -Files: src/misc1.c - -Patch 5.4.26 -Problem: Multi-byte: a multi-byte character is never recognized in a file - name, causing a backslash before it to be removed on Windows. -Solution: Assume that a leading-byte character is a file name character in - vim_isfilec(). -Files: src/charset.c - -Patch 5.4.27 -Problem: Entries in the PopUp[nvic] menus were added for several modes, but - only deleted for the mode they were used for. This resulted in - the entry remaining in the PopUp menu. - When removing a PopUp[nvic] menu, the name had been truncated, - could result in greying-out the whole PopUp menu. -Solution: Remove entries for all modes from the PopUp[nvic] menus. Remove - the PopUp[nvic] menu entries first, before the name is changed. -Files: src/menu.c - -Patch 5.4.28 -Problem: When using a BufWritePre autocommand to change 'fileformat', the - new value would not be used for writing the file. -Solution: Check 'fileformat' after executing the autocommands instead of - before. -Files: src/fileio.c - -Patch 5.4.29 -Problem: Athena GUI: When removing the 'g' flag from 'guioptions', using a - menu can result in a crash. -Solution: Always grey-out menus for Athena, don't hide them. -Files: src/menu.c - -Patch 5.4.30 -Problem: BeOS: Suspending Vim with CTRL-Z didn't work (killed Vim). The - first character typed after ":sh" goes to Vim, instead of the - started shell. -Solution: Don't suspend Vim, start a new shell. Kill the async read thread - when starting a new shell. It will be restarted later. (Will Day) -Files: src/os_unix.c, src/ui.c - -Patch 5.4.31 -Problem: GUI: When 'mousefocus' is set, moving the mouse over where a - window boundary was, causes a hit-enter prompt to be finished. - (Jeff Walker) -Solution: Don't use 'mousefocus' at the hit-enter prompt. Also ignore it - for the more prompt and a few other situations. When an operator - is pending, abort it first. -Files: src/gui.c - -Patch 5.4.32 -Problem: Unix: $LDFLAGS was not passed to configure. -Solution: Pass $LDFLAGS to configure just like $CFLAGS. (Jon Miner) -Files: src/Makefile - -Patch 5.4.33 -Problem: Unix: After expanding an environment variable with the shell, the - next expansion would also use the shell, even though it is not - needed. -Solution: Reset "recursive" before returning from gen_expand_wildcards(). -Files: src/misc1.c - -Patch 5.4.34 (also see 5.4.x5) -Problem: When editing a file, and the file name is relative to a directory - above the current directory, the file name was made absolute. - (Gregory Margo) -Solution: Add an argument to shorten_fnames() which indicates if all file - names should be shortened, or only absolute names. In main() only - use shorten_fnames() to shorten absolute names. -Files: src/ex_docmd.c, src/fileio.c, src/main.c, src/proto/fileio.pro - -Patch 5.4.35 -Problem: There is no function to get the current file size. -Solution: Allow using line2byte() with the number of lines in the file plus - one. This returns the offset of the line past the end of the - file, which is the file size plus one. -Files: src/eval.c, runtime/doc/eval.txt - -Patch 5.4.36 -Problem: Comparing strings while ignoring case didn't work correctly for - some machines. (Mide Steed) -Solution: vim_stricmp() and vim_strnicmp() only returned 0 or 1. Changed - them to return -1 when the first argument is smaller. -Files: src/misc2.c - -Patch 5.4.37 (also see 5.4.40 and 5.4.43) -Problem: Long strings from the viminfo file are truncated. -Solution: When writing a long string to the viminfo file, first write a line - with the length, then the string itself in a second line. -Files: src/eval.c, src/ex_cmds.c, src/ex_getln.c, src/mark.c, src/ops.c, - src/search.c, src/proto/ex_cmds.pro, runtime/syntax/viminfo.vim - -Patch 5.4.38 -Problem: In the option-window, ":set go&" resulted in 'go' being handled - like a boolean option. - Mappings for <Space> and <CR> were overruled by the option-window. -Solution: When the value of an option isn't 0 or 1, don't handle it like a - boolean option. - Save and restore mappings for <Space> and <CR> when entering and - leaving the option-window. -Files: runtime/optwin.vim - -Patch 5.4.39 -Problem: When setting a hidden option, spaces before the equal sign were - not skipped and cause an error message. E.g., ":set csprg =cmd". -Solution: When skipping over a hidden option, check for a following "=val" - and skip it too. -Files: src/option.c - -Patch 5.4.40 (depends on 5.4.37) -Problem: Compiler error for "atol(p + 1)". (Axel Kielhorn) -Solution: Add a typecast: "atol((char *)p + 1)". -Files: src/ex_cmds.c - -Patch 5.4.41 -Problem: Some commands that were not included would give an error message, - even when after "if 0". -Solution: Don't give an error message for an unsupported command when not - executing the command. -Files: src/ex_docmd.c - -Patch 5.4.42 -Problem: ":w" would also cause a truncated message to appear in the message - history. -Solution: Don't put a kept message in the message history when it starts - with "<". -Files: src/message.c - -Patch 5.4.43 (depends on 5.4.37) -Problem: Mixing long lines with multiple lines in a register causes errors - when writing the viminfo file. (Robinson) -Solution: When reading the viminfo file to skip register contents, skip - lines that start with "<". -Files: src/ops.c - -Patch 5.4.44 -Problem: When 'whichwrap' includes '~', a "~" command that goes on to the - next line cannot be properly undone. (Zellner) -Solution: Save each line for undo in n_swapchar(). -Files: src/normal.c - -Patch 5.4.45 (also see 5.4.x8) -Problem: When expand("$ASDF") fails, there is an error message. -Solution: Remove the global expand_interactively. Pass a flag down to skip - the error message. - Also: expand("$ASDF") returns an empty string if $ASDF isn't set. - Previously it returned "$ASDF" when 'shell' is "sh". - Also: system() doesn't print an error when the command returns an - error code. -Files: many - -Patch 5.4.46 -Problem: Backspacing did not always use 'softtabstop' after hitting <CR>, - inserting a register, moving the cursor, etc. -Solution: Reset inserted_space much more often in edit(). -Files: src/edit.c - -Patch 5.4.47 -Problem: When executing BufWritePre or BufWritePost autocommands for a - hidden buffer, the cursor could be moved to a non-existing - position. (Vince Negri) -Solution: Save and restore the cursor and topline for the current window - when it is going to be used to execute autocommands for a hidden - buffer. Use an existing window for the buffer when it's not - hidden. -Files: src/fileio.c - -Patch 5.4.48 -Problem: A paste with the mouse in Insert mode was not repeated exactly the - same with ".". For example, when 'autoindent' is set and pasting - text with leading indent. (Perry) -Solution: Add the CTRL-R CTRL-O r and CTRL-R CTRL-P r commands in Insert - mode, which insert the contents of a register literally. -Files: src/edit.c, src/normal.c, runtime/doc/insert.txt - -Patch 5.4.49 -Problem: When pasting text with [ <MiddleMouse>, the cursor could end up - after the last character of the line. -Solution: Correct the cursor position for the change in indent. -Files: src/ops.c - -Patch 5.4.x1 (note: Replaces patch 5.4.9) -Problem: Win32 GUI: menu hints were never used, because WANT_MENU is not - defined until vim.h is included. -Solution: Move the #ifdef WANT_MENU from where MENUHINTS is defined to where - it is used. -Files: src/gui_w32.c - -Patch 5.4.x2 -Problem: BeOS: When pasting text, one character was moved to the end. -Solution: Re-enable the BeOS code in fill_input_buf(), and fix timing out - with acquire_sem_etc(). (Will Day) -Files: src/os_beos.c, src/ui.c - -Patch 5.4.x3 -Problem: Win32 GUI: When dropping a directory on a running gvim it crashes. -Solution: Avoid using a NULL file name. Also display a message to indicate - that the current directory was changed. -Files: src/gui_w32.c - -Patch 5.4.x4 -Problem: Win32 GUI: Removing an item from the popup menu doesn't work. -Solution: Don't remove the item from the menubar, but from the parent popup - menu. -Files: src/gui_w32.c - -Patch 5.4.x5 (addition to 5.4.34) -Files: src/gui_w32.c - -Patch 5.4.x6 -Problem: Win32: Expanding (dir)name starting with a dot doesn't work. - (McCormack) Only when there is a path before it. -Solution: Fix the check, done before expansion, if the file name pattern - starts with a dot. -Files: src/os_win32.c - -Patch 5.4.x7 -Problem: Win32 GUI: Removing "Edit with Vim" from registry is difficult. -Solution: Add uninstall program to remove the registry keys. It is installed - in the "Add/Remove programs" list for ease of use. - Also: don't set $VIM when the executable is with the runtime files. - Also: Add a text file with a step-by-step description of how to - uninstall Vim for DOS and Windows. -Files: src/uninstal.c, src/dosinst.c, src/Makefile.w32, uninstal.txt - -Patch 5.4.x8 (addition to 5.4.45) -Files: many - -Patch 5.4.x9 -Problem: Win32 GUI: After executing an external command, focus is not - always regained (when using focus-follows-mouse). -Solution: Add SetFocus() in mch_system(). (Mike Steed) -Files: src/os_win32.c - - -Patch 5.5a.1 -Problem: ":let @* = @:" did not work. The text was not put on the - I clipboard. (Fisher) -Solution: Own the clipboard and put the text on it. -Files: src/ops.c - -Patch 5.5a.2 -Problem: append() did not mark the buffer modified. Marks below the - new line were not adjusted. -Solution: Fix the f_append() function. -Files: src/eval.c - -Patch 5.5a.3 -Problem: Editing compressed ".gz" files doesn't work on non-Unix systems, - because there is no "mv" command. -Solution: Add the rename() function and use it instead of ":!mv". - Also: Disable the automatic jump to the last position, because it - changes the jumplist. -Files: src/eval.c, runtime/doc/eval.txt, runtime/vimrc_example.vim - -Patch 5.5a.4 -Problem: When using whole-line completion in insert mode while the cursor - is in the indent, get "out of memory" error. (Stekrt) -Solution: Don't allocate a negative amount of memory in ins_complete(). -Files: src/edit.c - -Patch 5.5a.5 -Problem: Win32: The 'path' option can hold only up to 256 characters, - because _MAX_PATH is 256. (Robert Webb) -Solution: Use a fixed path length of 1024. -Files: src/os_win32.h - -Patch 5.5a.6 -Problem: Compiling with gcc on Win32, using the Unix Makefile, didn't work. -Solution: Add $(SUFFIX) to all places where an executable is used. Also - pass it to ctags. (Reynolds) -Files: src/Makefile - -Patch 5.5a.7 -Problem: When using "cat | vim -" in an xterm, the xterm version reply - would end up in the file. -Solution: Read the file from stdin before switching the terminal to RAW - mode. Should also avoid problems with programs that use a - specific terminal setting. - Also: when using the GUI, print "Reading from stdin..." in the GUI - window, to give a hint why it doesn't do anything. -Files: src/main.c, src/fileio.c - -Patch 5.5a.8 -Problem: On multi-threaded Solaris, suspending doesn't work. -Solution: Call pause() when the SIGCONT signal was not received after - sending the SIGTSTP signal. (Nagano) -Files: src/os_unix.c - -Patch 5.5a.9 -Problem: 'winaltkeys' could be set to an empty argument, which is illegal. -Solution: Give an error message when doing ":set winaltkeys=". -Files: src/option.c - -Patch 5.5a.10 -Problem: Win32 console: Using ALTGR on a German keyboard to produce "}" - doesn't work, because the 8th bit is set when ALT is pressed. -Solution: Don't set the 8th bit when ALT and CTRL are used. (Leipert) -Files: src/os_win32.c - -Patch 5.5a.11 -Problem: Tcl: Configure always uses tclsh8.0. - Also: Loading a library doesn't work. -Solution: Add "--with-tclsh" configure argument to allow specifying another - name for the tcl shell. - Call Tcl_Init() in tclinit() to make loading libraries work. - (Johannes Zellner) -Files: src/configure.in, src/configure, src/if_tcl.c - -Patch 5.5a.12 -Problem: The "user_commands" feature is called "user-commands". -Solution: Replace "user-commands" with "user_commands". (Kim Sung-bom) - Keep "user-commands" for the has() function, to remain backwards - compatible with 5.4. -Files: src/eval.c, src/version.c - -Patch 5.5a.13 -Problem: OS/2: When $HOME is not defined, "C:/" is used for the viminfo - file. That is very wrong when OS/2 is on another partition. -Solution: Use $VIM for the viminfo file when it is defined, like for MSDOS. - Also: Makefile.os2 didn't depend on os_unix.h. -Files: src/os_unix.h, src/Makefile.os2 - -Patch 5.5a.14 -Problem: Athena, Motif and GTK: The Mouse scroll wheel doesn't work. -Solution: Interpret a click of the wheel as a key press of the <MouseDown> - or <MouseUp> keys. Default behavior is to scroll three lines, or - a full page when Shift is used. -Files: src/edit.c, src/ex_getln.c, src/gui.c, src/gui_gtk_x11.c, - src/gui_x11.c, src/keymap.h, src/message.c, src/misc1.c, - src/misc2.c, src/normal.c, src/proto/normal.pro, src/vim.h, - runtime/doc/scroll.txt - -Patch 5.5a.15 -Problem: Using CTRL-A in Insert mode doesn't work correctly when the insert - started with the <Insert> key. (Andreas Rohrschneider) -Solution: Replace <Insert> with "i" before setting up the redo buffer. -Files: src/normal.c - -Patch 5.5a.16 -Problem: VMS: GUI does not compile and run. -Solution: Various fixes. (Zoltan Arpadffy) - Moved functions from os_unix.c to ui.c, so that VMS can use them - too: open_app_context(), x11_setup_atoms() and clip_x11* functions. - Made xterm_dpy global, it's now used by ui.c and os_unix.c. - Use gethostname() always, sys_hostname doesn't exist. -Files: src/globals.h, src/gui_x11.c, src/os_vms.mms, src/os_unix.c, - src/os_vms.c, src/ui.c, src/proto/os_unix.pro, src/proto/ui.pro - -Renamed AdjustCursorForMultiByteCharacter() to AdjustCursorForMultiByteChar() -to avoid symbol length limit of 31 characters. (Steve P. Wall) - -Patch 5.5b.1 -Problem: SASC complains about dead assignments and implicit type casts. -Solution: Removed the dead assignments. Added explicit type casts. -Files: src/buffer.c, src/edit.c, src/eval.c, src/ex_cmds.c, - src/ex_getln.c, src/fileio.c, src/getchar.c, src/memline.c, - src/menu.c, src/misc1.c, src/normal.c, src/ops.c, src/quickfix.c, - src/screen.c - -Patch 5.5b.2 -Problem: When using "CTRL-O O" in Insert mode, hit <Esc> and then "o" in - another line truncates that line. (Devin Weaver) -Solution: When using a command that starts Insert mode from CTRL-O, reset - "restart_edit" first. This avoids that edit() is called with a - mix of starting a new edit command and restarting a previous one. -Files: src/normal.c - -============================================================================== -VERSION 5.6 *version-5.6* - -Version 5.6 is a bug-fix version of 5.5. - - -Changed *changed-5.6* -------- - -Small changes to OleVim files. (Christian Schaller) - -Inserted "/**/" between patch numbers in src/version.c. This allows for one -line of context, which some versions of patch need. - -Reordered the Syntax menu to avoid long submenus. Removed keyboard shortcuts -for alphabetical items to avoid a clash with fixed items. - - -Added *added-5.6* ------ - -Included Exuberant Ctags version 3.4. (Darren Hiebert) - -OpenWithVim in Python. (Christian Schaller) - -Win32 GUI: gvimext.dll, for the context menu "Edit with Vim" entry. Avoids -the reported problems with the MS Office taskbar. Now it's a Shell Extension. -(Tianmiao Hu) - -New syntax files: -abel Abel (John Cook) -aml Arc Macro Language (Nikki Knuit) -apachestyle Apache-style config file (Christian Hammers) -cf Cold Fusion (Jeff Lanzarotta) -ctrlh files with CTRL-H sequences (Bram Moolenaar) -cupl CUPL (John Cook) -cuplsim CUPL simulation (John Cook) -erlang Erlang (Kresimir Marzic) -gedcom Gedcom (Paul Johnson) -icon Icon (Wendell Turner) -ist MakeIndex style (Peter Meszaros) -jsp Java Server Pages (Rafael Garcia-Suarez) -rcslog Rcslog (Joe Karthauser) -remind Remind (Davide Alberani) -sqr Structured Query Report Writer (Paul Moore) -tads TADS (Amir Karger) -texinfo Texinfo (Sandor Kopanyi) -xpm2 X Pixmap v2 (Steve Wall) - -The 'C' flag in 'cpoptions' can be used to switch off concatenation for -sourced lines. See patch 5.5.013 below. |line-continuation| - -"excludenl" argument for the ":syntax" command. See patch 5.5.032 below. -|:syn-excludenl| - -Implemented |z+| and |z^| commands. See patch 5.5.050 below. - -Vim logo in Corel Draw format. Can be scaled to any resolution. - - -Fixed *fixed-5.6* ------ - -Using this mapping in Select mode, terminated completion: -":vnoremap <C-N> <Esc>a<C-N>" (Benji Fisher) -Ignore K_SELECT in ins_compl_prep(). - -VMS (Zoltan Arpadffy, David Elins): -- ioctl() in pty.c caused trouble, #ifndef VMS added. -- Cut & paste mismatch corrected. -- Popup menu line crash corrected. (Patch 5.5.047) -- Motif directories during open and save as corrected. -- Handle full file names with version numbers. (Patch 5.5.046) -- Directory handling (CD command etc.) -- Corrected file name conversion VMS to Unix and v.v. -- Recovery was not working. -- Terminal and signal handling was outdated compared to os_unix.c. -- Improved os_vms.txt. - -Configure used fprintf() instead of printf() to check for __DATE__ and -__TIME__. (John Card II) - -BeOS: Adjust computing the char_height and char_ascent. Round them up -separately, avoids redrawing artifacts. (Mike Steed) - -Fix a few multi-byte problems in menu_name_skip(), set_reg_ic(), searchc() and -findmatchlimit(). (Taro Muraoka) - -GTK GUI: -- With GTK 1.2.5 and later the scrollbars were not redrawn correctly. -- Adjusted the gtk_form_draw() function. -- SNiFF connection didn't work. -- 'mousefocus' was not working. (Dalecki) -- Some keys were not working with modifiers: Shift-Tab, Ctrl-Space and CTRL-@. - - -Patch 5.5.001 -Problem: Configure in the top directory did not pass on an argument with a - space correctly. For example "./configure --previs="/My home". - (Stephane Chazelas) -Solution: Use '"$@"' instead of '$*' to pass on the arguments. -Files: configure - -Patch 5.5.002 -Problem: Compilation error for using "fds[] & POLLIN". (Jeff Walker) -Solution: Use "fds[].revents & POLLIN". -Files: src/os_unix.c - -Patch 5.5.003 -Problem: The autoconf check for sizeof(int) is wrong on machines where - sizeof(size_t) != sizeof(int). -Solution: Use our own configure check. Also fixes the warning for - cross-compiling. -Files: src/configure.in, src/configure - -Patch 5.5.004 -Problem: On Unix it's not possible to interrupt ":sleep 100". -Solution: Switch terminal to cooked mode while asleep, to allow a SIGINT to - wake us up. But switch off echo, added TMODE_SLEEP. -Files: src/term.h, src/os_unix.c - -Patch 5.5.005 -Problem: When using <f-args> with a user command, an empty argument to the - command resulted in one empty string, while no string was - expected. -Solution: Catch an empty argument and pass no argument to the function. - (Paul Moore) -Files: src/ex_docmd.c - -Patch 5.5.006 -Problem: Python: When platform-dependent files are in another directory - than the platform-independent files it doesn't work. -Solution: Also check the executable directory, and add it to CFLAGS. (Tessa - Lau) -Files: src/configure.in, src/configure - -Patch 5.5.007 (extra) -Problem: Win32 OLE: Occasional crash when exiting while still being used - via OLE. -Solution: Move OleUninitialize() to before deleting the application object. - (Vince Negri) -Files: src/if_ole.cpp - -Patch 5.5.008 -Problem: 10000@@ takes a long time and cannot be interrupted. -Solution: Check for CTRL-C typed while in the loop to push the register. -Files: src/normal.c - -Patch 5.5.009 -Problem: Recent Sequent machines don't link with "-linet". (Kurtis Rader) -Solution: Remove configure check for Sequent. -Files: src/configure.in, src/configure - -Patch 5.5.010 -Problem: Ctags freed a memory block twice when exiting. When out of - memory, a misleading error message was given. -Solution: Update to ctags 3.3.2. Also fixes a few other problems. (Darren - Hiebert) -Files: src/ctags/* - -Patch 5.5.011 -Problem: After "CTRL-V s", the cursor jumps back to the start, while all - other operators leave the cursor on the last changed character. - (Xiangjiang Ma) -Solution: Position cursor on last changed character, if possible. -Files: src/ops.c - -Patch 5.5.012 -Problem: Using CTRL-] in Visual mode doesn't work when the text includes a - space (just where it's useful). (Stefan Bittner) -Solution: Don't escape special characters in a tag name with a backslash. -Files: src/normal.c - -Patch 5.5.013 -Problem: The ":append" and ":insert" commands allow using a leading - backslash in a line. The ":source" command concatenates those - lines. (Heinlein) -Solution: Add the 'C' flag in 'cpoptions' to switch off concatenation. -Files: src/ex_docmd.c, src/option.h, runtime/doc/options.txt, - runtime/filetype.vim, runtime/scripts.vim - -Patch 5.5.014 -Problem: When executing a register with ":@", the ":append" command would - get text lines with a ':' prepended. (Heinlein) -Solution: Remove the ':' characters. -Files: src/ex_docmd.c, src/ex_getln.c, src/globals.h - -Patch 5.5.015 -Problem: When using ":g/pat/p", it's hard to see where the output starts, - the ":g" command is overwritten. Vi keeps the ":g" command. -Solution: Keep the ":g" command, but allow overwriting it with the report - for the number of changes. -Files: src/ex_cmds.c - -Patch 5.5.016 (extra) -Problem: Win32: Using regedit to install Vim in the popup menu requires the - user to confirm this in a dialog. -Solution: Use "regedit /s" to avoid the dialog -Files: src/dosinst.c - -Patch 5.5.017 -Problem: If an error occurs when closing the current window, Vim could get - stuck in the error handling. -Solution: Don't set curwin to NULL when closing the current window. -Files: src/window.c - -Patch 5.5.018 -Problem: Absolute paths in shell scripts do not always work. -Solution: Use /usr/bin/env to find out the path. -Files: runtime/doc/vim2html.pl, runtime/tools/efm_filter.pl, - runtime/tools/shtags.pl - -Patch 5.5.019 -Problem: A function call in 'statusline' stops using ":q" twice from - exiting, when the last argument hasn't been edited. -Solution: Don't decrement quitmore when executing a function. (Madsen) -Files: src/ex_docmd.c - -Patch 5.5.020 -Problem: When the output of CTRL-D completion in the commandline goes all - the way to the last column, there is an empty line. -Solution: Don't add a newline when the cursor wrapped already. (Madsen) -Files: src/ex_getln.c - -Patch 5.5.021 -Problem: When checking if a file name in the tags file is relative, - environment variables were not expanded. -Solution: Expand the file name before checking if it is relative. (Madsen) -Files: src/tag.c - -Patch 5.5.022 -Problem: When setting or resetting 'paste' the ruler wasn't updated. -Solution: Update the status lines when 'ruler' changes because of 'paste'. -Files: src/option.c - -Patch 5.5.023 -Problem: When editing a new file and autocommands change the cursor - position, the cursor was moved back to the first non-white, unless - 'startofline' was reset. -Solution: Keep the new column, just like the line number. -Files: src/ex_cmds.c - -Patch 5.5.024 (extra) -Problem: Win32 GUI: When using confirm() to put up a dialog without a - default button, the dialog would not have keyboard focus. - (Krishna) -Solution: Always set focus to the dialog window. Only set focus to a button - when a default one is specified. -Files: src/gui_w32.c - -Patch 5.5.025 -Problem: When using "keepend" in a syntax region, a contained match that - includes the end-of-line could still force that region to - continue, if there is another contained match in between. -Solution: Check the keepend_level in check_state_ends(). -Files: src/syntax.c - -Patch 5.5.026 -Problem: When starting Vim in a white-on-black xterm, with 'bg' set to - "dark", and then starting the GUI with ":gui", setting 'bg' to - "light" in the gvimrc, the highlighting isn't set. (Tsjokwing) -Solution: Set the highlighting when 'bg' is changed in the gvimrc, even - though full_screen isn't set. -Files: src/option.c - -Patch 5.5.027 -Problem: Unix: os_unix.c doesn't compile when XTERM_CLIP is used but - WANT_TITLE isn't. (Barnum) -Solution: Move a few functions that are used by the X11 title and clipboard - and put another "#if" around it. -Files: src/os_unix.c - -Patch 5.5.028 (extra) -Problem: Win32 GUI: When a file is dropped on Win32 gvim while at the ":" - prompt, the file is edited but the command line is actually still - there, the cursor goes back to command line on the next command. - (Krishna) -Solution: When dropping a file or directory on gvim while at the ":" prompt, - insert the name of the file/directory. Allows using the - file/directory name for any Ex command. -Files: src/gui_w32.c - -Patch 5.5.029 -Problem: "das" at the end of the file didn't delete the last character of - the sentence. -Solution: When there is no character after the sentence, make the operation - inclusive in current_sent(). -Files: src/search.c - -Patch 5.5.030 -Problem: Unix: in os_unix.c, "term_str" is used, which is also defined in - vim.h as a macro. (wuxin) -Solution: Renamed "term_str" to "buf" in do_xterm_trace(). -Files: src/os_unix.c - -Patch 5.5.031 (extra) -Problem: Win32 GUI: When exiting Windows, gvim will leave swap files behind - and will be killed ungracefully. (Krishna) -Solution: Catch the WM_QUERYENDSESSION and WM_ENDSESSION messages and try to - exit gracefully. Allow the user to cancel the shutdown if there - is a changed buffer. -Files: src/gui_w32.c - -Patch 5.5.032 -Problem: Patch 5.5.025 wasn't right. And C highlighting was still not - working correctly for a #define. -Solution: Added "excludenl" argument to ":syntax", to be able not to extend - a containing item when there is a match with the end-of-line. -Files: src/syntax.c, runtime/doc/syntax.txt, runtime/syntax/c.vim - -Patch 5.5.033 -Problem: When reading from stdin, a long line in viminfo would mess up the - file message. readfile() uses IObuff for keep_msg, which could be - overwritten by anyone. -Solution: Copy the message from IObuff to msg_buf and set keep_msg to that. - Also change vim_fgets() to not use IObuff any longer. -Files: src/fileio.c - -Patch 5.5.034 -Problem: "gvim -rv" caused a crash. Using 't_Co' before it's set. -Solution: Don't try to initialize the highlighting before it has been - initialized from main(). -Files: src/syntax.c - -Patch 5.5.035 -Problem: GTK with XIM: Resizing with status area was messy, and - ":set guioptions+=b" didn't work. -Solution: Make status area a separate widget, but not a separate window. - (Chi-Deok Hwang) -Files: src/gui_gtk_f.c, src/gui_gtk_x11.c, src/multbyte.c - -Patch 5.5.036 -Problem: The GZIP_read() function in $VIMRUNTIME/vimrc_example.vim to - uncompress a file did not do detection for 'fileformat'. This is - because the filtering is done with 'binary' set. -Solution: Split the filtering into separate write, filter and read commands. -Files: runtime/vimrc_example.vim - -Patch 5.5.037 -Problem: The "U" command didn't mark the buffer as changed. (McCormack) -Solution: Set the 'modified' flag when using "U". -Files: src/undo.c - -Patch 5.5.038 -Problem: When typing a long ":" command, so that the screen scrolls up, - causes the hit-enter prompt, even though the user just typed - return to execute the command. -Solution: Reset need_wait_return if (part of) the command was typed in - getcmdline(). -Files: src/ex_getln.c - -Patch 5.5.039 -Problem: When using a custom status line, "%a" (file # of #) reports the - index of the current window for all windows. -Solution: Pass a window pointer to append_arg_number(), and pass the window - being updated from build_stl_str_hl(). (Stephen P. Wall) -Files: src/buffer.c, src/screen.c, src/proto/buffer.pro - -Patch 5.5.040 -Problem: Multi-byte: When there is some error in xim_real_init(), it can - close XIM and return. After this there can be a segv. -Solution: Test "xic" for being non-NULL, don't set "xim" to NULL. Also try - to find more matches for supported styles. (Sung-Hyun Nam) -Files: src/multbyte.c - -Patch 5.5.041 -Problem: X11 GUI: CTRL-_ requires the SHIFT key only on some machines. -Solution: Translate CTRL-- to CTRL-_. (Robert Webb) -Files: src/gui_x11.c - -Patch 5.5.042 -Problem: X11 GUI: keys with ALT were assumed to be used for the menu, even - when the menu has been disabled by removing 'm' from 'guioptions'. -Solution: Ignore keys with ALT only when gui.menu_is_active is set. (Raf) -Files: src/gui_x11.c - -Patch 5.5.043 -Problem: GTK: Handling of fontset fonts was not right when 'guifontset' - contains exactly 14 times '-'. -Solution: Avoid setting fonts when working with a fontset. (Sung-Hyun Nam) -Files: src/gui_gtk_x11.c - -Patch 5.5.044 -Problem: pltags.pl contains an absolute path "/usr/local/bin/perl". That - might not work everywhere. -Solution: Use "/usr/bin/env perl" instead. -Files: runtime/tools/pltags.pl - -Patch 5.5.045 -Problem: Using "this_session" variable does not work, requires preceding it - with "v:". Default filename for ":mksession" isn't mentioned - in the docs. (Fisher) -Solution: Support using "this_session" to be backwards compatible. -Files: src/eval.c, runtime/doc/options.txt - -Patch 5.5.046 (extra) -Problem: VMS: problems with path and filename. -Solution: Truncate file name at last ';', etc. (Zoltan Arpadffy) -Files: src/buffer.c, src/fileio.c, src/gui_motif.c, src/os_vms.c, - src/proto/os_vms.pro - -Patch 5.5.047 -Problem: VMS: Crash when using the popup menu -Solution: Turn the #define MENU_MODE_CHARS into an array. (Arpadffy) -Files: src/structs.h, src/menu.c - -Patch 5.5.048 -Problem: HP-UX 11: Compiling doesn't work, because both string.h and - strings.h are included. (Squassabia) -Solution: The configure test for including both string.h and strings.h - must include <Xm/Xm.h> first, because it causes problems. -Files: src/configure.in, src/configure, src/config.h.in - -Patch 5.5.049 -Problem: Unix: When installing Vim, the protection bits of files might be - influenced by the umask. -Solution: Add $(FILEMOD) to Makefile. (Shetye) -Files: src/Makefile - -Patch 5.5.050 -Problem: "z+" and "z^" commands are missing. -Solution: Implemented "z+" and "z^". -Files: src/normal.c, runtime/doc/scroll.txt, runtime/doc/index.txt - -Patch 5.5.051 -Problem: Several Unix systems have a problem with the optimization limits - check in configure. -Solution: Removed the configure check, let the user add it manually in - Makefile or the environment. -Files: src/configure.in, src/configure, src/Makefile - -Patch 5.5.052 -Problem: Crash when using a cursor key at the ATTENTION prompt. (Alberani) -Solution: Ignore special keys at the console dialog. Also ignore characters - > 255 for other uses of tolower() and toupper(). -Files: src/menu.c, src/message.c, src/misc2.c - -Patch 5.5.053 -Problem: Indenting is wrong after a function when 'cino' has "fs". Another - problem when 'cino' has "{s". -Solution: Put line after closing "}" of a function at the left margin. - Apply ind_open_extra in the right way after a '{'. -Files: src/misc1.c, src/testdir/test3.in, src/testdir/test3.ok - -Patch 5.5.054 -Problem: Unix: ":e #" doesn't work if the alternate file name contains a - space or backslash. (Hudacek) -Solution: When replacing "#", "%" or other items that stand for a file name, - prepend a backslash before special characters. -Files: src/ex_docmd.c - -Patch 5.5.055 -Problem: Using "<C-V>$r-" in blockwise Visual mode replaces one character - beyond the end of the line. (Zivkov) -Solution: Only replace existing characters. -Files: src/ops.c - -Patch 5.5.056 -Problem: After "z20<CR>" messages were printed at the old command line - position once. (Veselinovic) -Solution: Set msg_row and msg_col when changing cmdline_row in - win_setheight(). -Files: src/window.c - -Patch 5.5.057 -Problem: After "S<Esc>" it should be possible to restore the line with "U". - (Veselinovic) -Solution: Don't call u_clearline() in op_delete() when changing only one - line. -Files: src/ops.c - -Patch 5.5.058 -Problem: Using a long search pattern and then "n" causes the hit-enter - prompt. (Krishna) -Solution: Truncate the echoed pattern, like other messages. Moved code for - truncating from msg_attr() to msg_strtrunc(). -Files: src/message.c, src/proto/message.pro, src/search.c - -Patch 5.5.059 -Problem: GTK GUI: When $term is invalid, using "gvim" gives an error - message, even though $term isn't really used. (Robbins) -Solution: When the GUI is about to start, skip the error messages for a - wrong $term. -Files: src/term.c - -Patch 5.5.060 (extra) -Problem: Dos 32 bit: When a directory in 'backupdir' doesn't exist, ":w" - causes the file to be renamed to "axlqwqhy.ba~". (Matzdorf) -Solution: The code to work around a LFN bug in Windows 95 doesn't handle a - non-existing target name correctly. When renaming fails, make - sure the file has its original name. Also do this for the Win32 - version, although it's unlikely that it runs into this problem. -Files: src/os_msdos.c, src/os_win32.c - -Patch 5.5.061 -Problem: When using "\:" in a modeline, the backslash is included in the - option value. (Mohsin) -Solution: Remove one backslash before the ':' in a modeline. -Files: src/buffer.c, runtime/doc/options.txt - -Patch 5.5.062 (extra) -Problem: Win32 console: Temp files are created in the root of the current - drive, which may be read-only. (Peterson) -Solution: Use the same mechanism of the GUI version: Use $TMP, $TEMP or the - current directory. Cleaned up vim_tempname() a bit. -Files: src/fileio.c, src/os_win32.h, runtime/doc/os_dos.txt - -Patch 5.5.063 -Problem: When using whole-line completion in Insert mode, 'cindent' is - applied, even after changing the indent of the line. -Solution: Don't reindent the completed line after inserting/removing indent. - (Robert Webb) -Files: src/edit.c - -Patch 5.5.064 -Problem: has("sniff") doesn't work correctly. -Solution: Return 1 when Vim was compiled with the +sniff feature. (Pruemmer) -Files: src/eval.c - -Patch 5.5.065 -Problem: When dropping a file on Vim, the 'shellslash' option is not - effective. (Krishna) -Solution: Fix the slashes in the dropped file names according to - 'shellslash'. -Files: src/ex_docmd.c, runtime/doc/options.txt - -Patch 5.5.066 -Problem: For systems with backslash in file name: Setting a file name - option to a value starting with "\\machine" removed a backslash. -Solution: Keep the double backslash for "\\machine", but do change - "\\\\machine" to "\\machine" for backwards compatibility. -Files: src/option.c, runtime/doc/options.txt - -Patch 5.5.067 -Problem: With 'hlsearch' set, the pattern "\>" doesn't highlight the first - match in a line. (Benji Fisher) -Solution: Fix highlighting an empty match. Also highlight the first - character in an empty line for "$". -Files: src/screen.c - -Patch 5.5.068 -Problem: Crash when a ":while" is used with an argument that has an error. - (Sylvain Viart) -Solution: Was using an uninitialized index in the cs_line[] array. The - crash only happened when the index was far off. Made sure the - uninitialized index isn't used. -Files: src/ex_docmd.c - -Patch 5.5.069 -Problem: Shifting lines in blockwise Visual mode didn't set the 'modified' - flag. -Solution: Do set the 'modified' flag. -Files: src/ops.c - -Patch 5.5.070 -Problem: When editing a new file, creating that file outside of Vim, then - editing it again, ":w" still warns for overwriting an existing - file. (Nam) -Solution: The BF_NEW flag in the "b_flags" field wasn't cleared properly. -Files: src/buffer.c, src/fileio.c - -Patch 5.5.071 -Problem: Using a matchgroup in a ":syn region", which is the same syntax - group as the region, didn't stop a contained item from matching in - the start pattern. -Solution: Also push an item on the stack when the syntax ID of the - matchgroup is the same as the syntax ID of the region. -Files: src/syntax.c - -Patch 5.5.072 (extra) -Problem: Dos 32 bit: When setting 'columns' to a too large value, Vim may - crash, and the DOS console too. -Solution: Check that the value of 'columns' isn't larger than the number of - columns that the BIOS reports. -Files: src/os_msdos.c, src/proto/os_msdos.pro, src/option.c - -Patch 5.5.073 (extra) -Problem: Win 32 GUI: The Find and Find/Replace dialogs didn't show the - "match case" checkbox. The Find/Replace dialog didn't handle the - "match whole word" checkbox. -Solution: Support the "match case" and "match whole word" checkboxes. -Files: src/gui_w32.c - -Patch 5.6a.001 -Problem: Using <C-End> with a count doesn't work like it does with "G". - (Benji Fisher) -Solution: Accept a count for <C-End> and <C-Home>. -Files: src/normal.c - -Patch 5.6a.002 -Problem: The script for conversion to HTML was an older version. -Solution: Add support for running 2html.vim on a color terminal. -Files: runtime/syntax/2html.vim - -Patch 5.6a.003 -Problem: Defining a function inside a function didn't give an error - message. A missing ":endfunction" doesn't give an error message. -Solution: Allow defining a function inside a function. -Files: src/eval.c, runtime/doc/eval.txt - -Patch 5.6a.004 -Problem: A missing ":endwhile" or ":endif" doesn't give an error message. - (Johannes Zellner) -Solution: Check for missing ":endwhile" and ":endif" in sourced files. - Add missing ":endif" in file selection macros. -Files: src/ex_docmd.c, runtime/macros/file_select.vim - -Patch 5.6a.005 -Problem: 'hlsearch' was not listed alphabetically. The value of 'toolbar' - was changed when 'compatible' is set. -Solution: Moved entry of 'hlsearch' in options[] table down. - Don't reset 'toolbar' option to the default value when - 'compatible' is set. -Files: src/option.c - -Patch 5.6a.006 -Problem: Using a backwards range inside ":if 0" gave an error message. -Solution: Don't complain about a range when it is not going to be used. - (Stefan Roemer) -Files: src/ex_docmd.c - -Patch 5.6a.007 -Problem: ":let" didn't show internal Vim variables. (Ron Aaron) -Solution: Do show ":v" variables for ":let" and ":let v:name". -Files: src/eval.c - -Patch 5.6a.008 -Problem: Selecting a syntax from the Syntax menu gives an error message. -Solution: Replace "else if" in SetSyn() with "elseif". (Ronald Schild) -Files: runtime/menu.vim - -Patch 5.6a.009 -Problem: When compiling with +extra_search but without +syntax, there is a - compilation error in screen.c. (Axel Kielhorn) -Solution: Adjust the #ifdef for declaring and initializing "line" in - win_line(). Also solve compilation problem when +statusline is - used without +eval. Another one when +cmdline_compl is used - without +eval. -Files: src/screen.c, src/misc2.c - -Patch 5.6a.010 -Problem: In a function, ":startinsert!" does not append to the end of the - line if a ":normal" command was used to move the cursor. (Fisher) -Solution: Reset "w_set_curswant" to avoid that w_curswant is changed again. -Files: src/ex_docmd.c - -Patch 5.6a.011 (depends on 5.6a.004) -Problem: A missing ":endif" or ":endwhile" in a function doesn't give an - error message. -Solution: Give that error message. -Files: src/ex_docmd.c - -Patch 5.6a.012 (depends on 5.6a.008) -Problem: Some Syntax menu entries caused a hit-enter prompt. -Solution: Call a function to make the command shorter. Also rename a few - functions to avoid name clashes. -Files: runtime/menu.vim - -Patch 5.6a.013 -Problem: Command line completion works different when another completion - was done earlier. (Johannes Zellner) -Solution: Reset wim_index when starting a new completion. -Files: src/ex_getln.c - -Patch 5.6a.014 -Problem: Various warning messages when compiling and running lint with - different combinations of features. -Solution: Fix the warning messages. -Files: src/eval.c, src/ex_cmds.c, src/ex_docmd.c, src/gui_gtk_x11.c, - src/option.c, src/screen.c, src/search.c, src/syntax.c, - src/feature.h, src/globals.h - -Patch 5.6a.015 -Problem: The vimtutor command doesn't always know the value of $VIMRUNTIME. -Solution: Let Vim expand $VIMRUNTIME, instead of the shell. -Files: src/vimtutor - -Patch 5.6a.016 (extra) -Problem: Mac: Window size is restricted when starting. Cannot drag the - window all over the desktop. -Solution: Get real screen size instead of assuming 640x400. Do not use a - fixed number for the drag limits. (Axel Kielhorn) -Files: src/gui_mac.c - -Patch 5.6a.017 -Problem: The "Paste" entry in popup menu for Visual, Insert and Cmdline - mode is in the wrong position. (Stol) -Solution: Add priority numbers for all Paste menu entries. -Files: runtime/menu.vim - -Patch 5.6a.018 -Problem: GTK GUI: submenu priority doesn't work. - Help dialog could be destroyed too soon. - When closing a dialog window (e.g. the "ATTENTION" one), Vim would - just hang. - When GTK theme is changed, Vim doesn't adjust to the new colors. - Argument for ":promptfind" isn't used. -Solution: Fixed the mentioned problems. - Made the dialogs look&feel nicer. - Moved functions to avoid the need for a forward declaration. - Fixed reentrancy of the file browser dialog. - Added drag&drop support for GNOME. - Init the text for the Find/replace dialog from the last used - search string. Set "match whole word" toggle button correctly. - Made repeat rate for drag outside of window depend on the - distance from the window. (Marcin Dalecki) - Made the drag in Visual mode actually work. - Removed recursiveness protection from gui_mch_get_rgb(), it might - cause more trouble than it solves. -Files: src/ex_docmd.c, src/gui_gtk.c, src/gui_gtk_x11.c, src/ui.c, - src/proto/ui.pro, src/misc2.c - -Patch 5.6a.019 -Problem: When trying to recover through NFS, which uses a large block size, - Vim might think the swap file is empty, because mf_blocknr_max is - zero. (Scott McDermott) -Solution: When computing the number of blocks of the file in mf_open(), - round up instead of down. -Files: src/memfile.c - -Patch 5.6a.020 -Problem: GUI GTK: Could not set display for gvim. -Solution: Add "-display" and "--display" arguments. (Marcin Dalecki) -Files: src/gui_gtk_x11.c - -Patch 5.6a.021 -Problem: Recovering still may not work when the block size of the device - where the swap file is located is larger than 4096. -Solution: Read block 0 with the minimal block size. -Files: src/memline.c, src/memfile.c, src/vim.h - -Patch 5.6a.022 (extra) -Problem: Win32 GUI: When an error in the vimrc causes a dialog to pop up - (e.g., for an existing swap file), Vim crashes. (David Elins) -Solution: Before showing a dialog, open the main window. -Files: src/gui_w32.c - -Patch 5.6a.023 -Problem: Using expand("%:gs??/?") causes a crash. (Ron Aaron) -Solution: Check for running into the end of the string in do_string_sub(). -Files: src/eval.c - -Patch 5.6a.024 -Problem: Using an autocommand to delete a buffer when leaving it can cause - a crash when jumping to a tag. (Franz Gorkotte) -Solution: In do_tag(), store tagstacklen before jumping to another buffer. - Check tagstackidx after jumping to another buffer. - Add extra check in win_split() if tagname isn't NULL. -Files: src/tag.c, src/window.c - -Patch 5.6a.025 (extra) -Problem: Win32 GUI: The tables for toupper() and tolower() are initialized - too late. (Mike Steed) -Solution: Move the initialization to win32_init() and call it from main(). -Files: src/main.c, src/os_w32.c, src/proto/os_w32.pro - -Patch 5.6a.026 -Problem: When the SNiFF connection is open, shell commands hang. (Pruemmer) -Solution: Skip a second wait() call if waitpid() already detected that the - child has exited. -Files: src/os_unix.c - -Patch 5.6a.027 (extra) -Problem: Win32 GUI: The "Edit with Vim" popup menu entry causes problems - for the Office toolbar. -Solution: Use a shell extension dll. (Tianmiao Hu) - Added it to the install and uninstal programs, replaces the old - "Edit with Vim" menu registry entries. -Files: src/dosinst.c, src/uninstal.c, gvimext/*, runtime/doc/gui_w32.txt - -Patch 5.6a.028 (extra) -Problem: Win32 GUI: Dialogs and tear-off menus can't handle multi-byte - characters. -Solution: Adjust nCopyAnsiToWideChar() to handle multi-byte characters - correctly. -Files: src/gui_w32.c - -============================================================================== -VERSION 5.7 *version-5.7* - -Version 5.7 is a bug-fix version of 5.6. - -Changed *changed-5.7* -------- - -Renamed src/INSTALL.mac to INSTALL_mac.txt to avoid it being recognized with a -wrong file type. Also renamed src/INSTALL.amiga to INSTALL_ami.txt. - - -Added *added-5.7* ------ - -New syntax files: -stp Stored Procedures (Jeff Lanzarotta) -snnsnet, snnspat, snnsres SNNS (Davide Alberani) -mel MEL (Robert Minsk) -ruby Ruby (Mirko Nasato) -tli TealInfo (Kurt W. Andrews) -ora Oracle config file (Sandor Kopanyi) -abaqus Abaqus (Carl Osterwisch) -jproperties Java Properties (Simon Baldwin) -apache Apache config (Allan Kelly) -csp CSP (Jan Bredereke) -samba Samba config (Rafael Garcia-Suarez) -kscript KDE script (Thomas Capricelli) -hb Hyper Builder (Alejandro Forero Cuervo) -fortran Fortran (rewritten) (Ajit J. Thakkar) -sml SML (Fabrizio Zeno Cornelli) -cvs CVS commit (Matt Dunford) -aspperl ASP Perl (Aaron Hope) -bc BC calculator (Vladimir Scholtz) -latte Latte (Nick Moffitt) -wml WML (Gerfried Fuchs) - -Included Exuberant ctags 3.5.1. (Darren Hiebert) - -"display" and "fold" arguments for syntax items. For future extension, they -are ignored now. - -strftime() function for the Macintosh. - -macros/explorer.vim: A file browser script (M A Aziz Ahmed) - - -Fixed *fixed-5.7* ------ - -The 16 bit MS-DOS version is now compiled with Bcc 3.1 instead of 4.0. The -executable is smaller. - -When a "make test" failed, the output file was lost. Rename it to -test99.failed to be able to see what went wrong. - -After sourcing bugreport.vim, it's not clear that bugreport.txt has been -written in the current directory. Edit bugreport.txt to avoid that. - -Adding IME support when using Makefile.w32 didn't work. (Taro Muraoka) - -Win32 console: Mouse drags were passed on even when the mouse didn't move. - -Perl interface: In Buffers(), type of argument to SvPV() was int, should be -STRLEN. (Tony Leneis) - -Problem with prototype for index() on AIX 4.3.0. Added check for _AIX43 in -os_unix.h. (Jake Hamby) - -Mappings in mswin.vim could break when some commands are mapped. Add "nore" -to most mappings to avoid re-mapping. - -modify_fname() made a copy of a file name for ":p" when it already was a full -path name, which is a bit slow. - -Win32 with Borland C++ 5.5: Pass the path to the compiler on to xxd and ctags, -to avoid depending on $PATH. Fixed "make clean". - -Many fixes to Macintosh specific parts: (mostly by Dany StAmant) -- Only one Help menu. -- No more crash when removing a menu item. -- Support as External Editor for Codewarrior (still some little glitches). -- Popup menu support. -- Fixed crash when pasting after application switch. -- Color from rgb.txt properly displayed. -- 'isprint' default includes all chars above '~'. (Axel Kielhorn) -- mac_expandpath() was leaking memory. -- Add digraphs table. (Axel Kielhorn) -- Multi-byte support: (Kenichi Asai) - Switch keyscript when going in/out of Insert mode. - Draw multi-byte character correctly. - Don't use mblen() but highest bit of char to detect multi-byte char. - Display value of multi-byte in statusline (also for other systems). -- mouse button was not initialized properly to MOUSE_LEFT when - USE_CTRLCLICKMENU not defined. -- With Japanese SJIS characters: Make "w", "b", and "e" work - properly. (Kenichi Asai) -- Replaced old CodeWarrior file os_mac.CW9.hqx with os_mac.cw5.sit.hqx. - -Fixes for VMS: (Zoltan Arpadffy) (also see patch 5.6.045 below) -- Added Makefile_vms.mms and vimrc.vms to src/testdir to be able to run the - tests. -- Various fixes. -- Set 'undolevels' to 1000 by default. -- Made mch_settitle() equivalent to the one in os_unix.c. - -RiscOS: A few prototypes for os_riscos.c were outdated. Generate prototypes -automatically. - - -Previously released patches: - -Patch 5.6.001 -Problem: When using "set bs=0 si cin", Inserting "#<BS>" or "}<BS>" which - reduces the indent doesn't delete the "#" or "}". (Lorton) -Solution: Adjust ai_col in ins_try_si(). -Files: src/edit.c - -Patch 5.6.002 -Problem: When using the vim.vim syntax file, a comment with all uppercase - characters causes a hang. -Solution: Adjust pattern for vimCommentTitle (Charles Campbell) -Files: runtime/syntax/vim.vim - -Patch 5.6.003 -Problem: GTK GUI: Loading a user defined toolbar bitmap gives a warning - about the colormap. Probably because the window has not been - opened yet. -Solution: Use gdk_pixmap_colormap_create_from_xpm() to convert the xpm file. - (Keith Radebaugh) -Files: src/gui_gtk.c - -Patch 5.6.004 (extra) -Problem: Win32 GUI with IME: When setting 'guifont' to "*", the font - requester appears twice. -Solution: In gui_mch_init_font() don't call get_logfont() but copy - norm_logfont from fh. (Yasuhiro Matsumoto) -Files: src/gui_w32.c - -Patch 5.6.005 -Problem: When 'winminheight' is zero, CTRL-W - with a big number causes a - crash. (David Kotchan) -Solution: Check for negative window height in win_setheight(). -Files: src/window.c - -Patch 5.6.006 -Problem: GTK GUI: Bold font cannot always be used. Memory is freed too - early in gui_mch_init_font(). -Solution: Move call to g_free() to after where sdup is used. (Artem Hodyush) -Files: src/gui_gtk_x11.c - -Patch 5.6.007 (extra) -Problem: Win32 IME: Font is not changed when screen font is changed. And - IME composition window does not trace the cursor. -Solution: Initialize IME font. When cursor is moved, set IME composition - window with ImeSetCompositionWindow(). Add call to - ImmReleaseContext() in several places. (Taro Muraoka) -Files: src/gui.c, src/gui_w32.c, src/proto/gui_w32.pro - -Patch 5.6.008 (extra) -Problem: Win32: When two files exist with the same name but different case - (through NFS or Samba), fixing the file name case could cause the - wrong one to be edited. -Solution: Prefer a perfect match above a match while ignoring case in - fname_case(). (Flemming Madsen) -Files: src/os_win32.c - -Patch 5.6.009 (extra) -Problem: Win32 GUI: Garbage in Windows Explorer help line when selecting - "Edit with Vim" popup menu entry. -Solution: Only return the help line when called with the GCS_HELPTEXT flag. - (Tianmiao Hu) -Files: GvimExt/gvimext.cpp - -Patch 5.6.010 -Problem: A file name which contains a TAB was not read correctly from the - viminfo file and the ":ls" listing was not aligned properly. -Solution: Parse the buffer list lines in the viminfo file from the end - backwards. Count a Tab for two characters to align the ":ls" list. -Files: src/buffer.c - -Patch 5.6.011 -Problem: When 'columns' is huge (using a tiny font) and 'statusline' is - used, Vim can crash. -Solution: Limit maxlen to MAXPATHL in win_redr_custom(). (John Mullin) -Files: src/screen.c - -Patch 5.6.012 -Problem: When using "zsh" for /bin/sh, toolcheck may hang until "exit" is - typed. (Kuratczyk) -Solution: Add "-c exit" when checking for the shell version. -Files: src/toolcheck - -Patch 5.6.013 -Problem: Multibyte char in tooltip is broken. -Solution: Consider multibyte char in replace_termcodes(). (Taro Muraoka) -Files: src/term.c - -Patch 5.6.014 -Problem: When cursor is at the end of line and the character under cursor - is a multibyte character, "yl" doesn't yank 1 multibyte-char. - (Takuhiro Nishioka) -Solution: Recognize a multibyte-char at end-of-line correctly in oneright(). - (Taro Muraoka) - Also: make "+quickfix" in ":version" output appear alphabetically. -Files: src/edit.c - -Patch 5.6.015 -Problem: New xterm delete key sends <Esc>[3~ by default. -Solution: Added <kDel> and <kIns> to make the set of keypad keys complete. -Files: src/edit.c, src/ex_getln.c, src/keymap.h, src/misc1.c, - src/misc2.c, src/normal.c, src/os_unix.c, src/term.c - -Patch 5.6.016 -Problem: When deleting a search string from history from inside a mapping, - another entry is deleted too. (Benji Fisher) -Solution: Reset last_maptick when deleting the last entry of the search - history. Also: Increment maptick when starting a mapping from - typed characters to avoid a just added search string being - overwritten or removed from history. -Files: src/ex_getln.c, src/getchar.c - -Patch 5.6.017 -Problem: ":s/e/\^M/" should replace an "e" with a CTRL-M, not split the - line. (Calder) -Solution: Replace the backslash with a CTRL-V internally. (Stephen P. Wall) -Files: src/ex_cmds.c - -Patch 5.6.018 -Problem: ":help [:digit:]" takes a long time to jump to the wrong place. -Solution: Insert a backslash to avoid the special meaning of '[]'. -Files: src/ex_cmds.c - -Patch 5.6.019 -Problem: "snd.c", "snd.java", etc. were recognized as "mail" filetype. -Solution: Make pattern for mail filetype more strict. -Files: runtime/filetype.vim - -Patch 5.6.020 (extra) -Problem: The DJGPP version eats processor time (Walter Briscoe). -Solution: Call __dpmi_yield() in the busy-wait loop. -Files: src/os_msdos.c - -Patch 5.6.021 -Problem: When 'selection' is "exclusive", a double mouse click in Insert - mode doesn't select last char in line. (Lutz) -Solution: Allow leaving the cursor on the NUL past the line in this case. -Files: src/edit.c - -Patch 5.6.022 -Problem: ":e \~<Tab>" expands to ":e ~\$ceelen", which doesn't work. -Solution: Re-insert the backslash before the '~'. -Files: src/ex_getln.c - -Patch 5.6.023 (extra) -Problem: Various warnings for the Ming compiler. -Solution: Changes to avoid the warnings. (Bill McCarthy) -Files: src/ex_cmds.c, src/gui_w32.c, src/os_w32exe.c, src/os_win32.c, - src/syntax.c, src/vim.rc - -Patch 5.6.024 (extra) -Problem: Win32 console: Entering CTRL-_ requires the shift key. (Kotchan) -Solution: Specifically catch keycode 0xBD, like the GUI. -Files: src/os_win32.c - -Patch 5.6.025 -Problem: GTK GUI: Starting the GUI could be interrupted by a SIGWINCH. - (Nils Lohner) -Solution: Repeat the read() call to get the gui_in_use value when - interrupted by a signal. -Files: src/gui.c - -Patch 5.6.026 (extra) -Problem: Win32 GUI: Toolbar bitmaps are searched for in - $VIMRUNTIME/bitmaps, while GTK looks in $VIM/bitmaps. (Keith - Radebaugh) -Solution: Use $VIM/bitmaps for both, because these are not part of the - distribution but defined by the user. -Files: src/gui_w32.c, runtime/doc/gui.txt - -Patch 5.6.027 -Problem: TCL: Crash when using a Tcl script (reported for Win32). -Solution: Call Tcl_FindExecutable() in main(). (Brent Fulgham) -Files: src/main.c - -Patch 5.6.028 -Problem: Xterm patch level 126 sends codes for mouse scroll wheel. - Fully works with xterm patch level 131. -Solution: Recognize the codes for button 4 (0x60) and button 5 (0x61). -Files: src/term.c - -Patch 5.6.029 -Problem: GTK GUI: Shortcut keys cannot be used for a dialog. (Johannes - Zellner) -Solution: Add support for shortcut keys. (Marcin Dalecki) -Files: src/gui_gtk.c - -Patch 5.6.030 -Problem: When closing a window and 'ea' is set, Vim can crash. (Yasuhiro - Matsumoto) -Solution: Set "curbuf" to a valid value in win_close(). -Files: src/window.c - -Patch 5.6.031 -Problem: Multi-byte: When a double-byte character ends in CSI, Vim waits - for another character to be typed. -Solution: Recognize the CSI as the second byte of a character and don't wait - for another one. (Yasuhiro Matsumoto) -Files: src/getchar.c - -Patch 5.6.032 -Problem: Functions with an argument that is a line number don't all accept - ".", "$", etc. (Ralf Arens) -Solution: Add get_art_lnum() and use it for setline(), line2byte() and - synID(). -Files: src/eval.c - -Patch 5.6.033 -Problem: Multi-byte: "f " sometimes skips to the second space. (Sung-Hyun - Nam) -Solution: Change logic in searchc() to skip trailing byte of a double-byte - character. - Also: Ask for second byte when searching for double-byte - character. (Park Chong-Dae) -Files: src/search.c - -Patch 5.6.034 (extra) -Problem: Compiling with Borland C++ 5.5 fails on tolower() and toupper(). -Solution: Use TO_LOWER() and TO_UPPER() instead. Also adjust the Makefile - to make using bcc 5.5 easier. -Files: src/edit.c, src/ex_docmd.c, src/misc1.c, src/Makefile.bor - -Patch 5.6.035 -Problem: Listing the"+comments" feature in the ":version" output depended - on the wrong ID. (Stephen P. Wall) -Solution: Change "CRYPTV" to "COMMENTS". -Files: src/version.c - -Patch 5.6.036 -Problem: GTK GUI: Copy/paste text doesn't work between gvim and Eterm. -Solution: Support TEXT and COMPOUND_TEXT selection targets. (ChiDeok Hwang) -Files: src/gui_gtk_x11.c - -Patch 5.6.037 -Problem: Multi-byte: Can't use "f" command with multi-byte character in GUI. -Solution: Enable XIM in Normal mode for the GUI. (Sung-Hyun Nam) -Files: src/gui_gtk_x11.c, src/multbyte.c - -Patch 5.6.038 -Problem: Multi-clicks in GUI are interpreted as a mouse wheel click. When - 'ttymouse' is "xterm" a mouse click is interpreted as a mouse - wheel click. -Solution: Don't recognize the mouse wheel in check_termcode() in the GUI. - Use 0x43 for a mouse drag in do_xterm_trace(), not 0x63. -Files: src/term.c, src/os_unix.c - -Patch 5.6.039 -Problem: Motif GUI under KDE: When trying to logout, Vim hangs up the - system. (Hermann Rochholz) -Solution: When handling the WM_SAVE_YOURSELF event, set the WM_COMMAND - property of the window to let the session manager know we finished - saving ourselves. -Files: src/gui_x11.c - -Patch 5.6.040 -Problem: When using ":s" command, matching the regexp is done twice. -Solution: After copying the matched line, adjust the pointers instead of - finding the match again. (Loic Grenie) Added vim_regnewptr(). -Files: src/ex_cmds.c, src/regexp.c, src/proto/regexp.pro - -Patch 5.6.041 -Problem: GUI: Athena, Motif and GTK don't give more than 10 dialog buttons. -Solution: Remove the limit on the number of buttons. - Also support the 'v' flag in 'guioptions'. - For GTK: Center the buttons. -Files: src/gui_athena.c, src/gui_gtk.c, src/gui_motif.c - -Patch 5.6.042 -Problem: When doing "vim -u vimrc" and vimrc contains ":q", the cursor in - the terminal can remain off. -Solution: Call cursor_on() in mch_windexit(). -Files: src/os_unix.c - -Patch 5.6.043 (extra) -Problem: Win32 GUI: When selecting guifont with the dialog, 'guifont' - doesn't include the bold or italic attributes. -Solution: Append ":i" and/or ":b" to 'guifont' in gui_mch_init_font(). -Files: src/gui_w32.c - -Patch 5.6.044 (extra) -Problem: MS-DOS and Windows: The line that dosinst.exe appends to - autoexec.bat to set PATH is wrong when Vim is in a directory with - an embedded space. -Solution: Use double quotes for the value when there is an embedded space. -Files: src/dosinst.c - -Patch 5.6.045 (extra) (fixed version) -Problem: VMS: Various small problems. -Solution: Many small changes. (Zoltan Arpadffy) - File name modifier ":h" keeps the path separator. - File name modifier ":e" also removes version. - Compile with MAX_FEAT by default. - When checking for autocommands ignore version in file name. - Be aware of file names being case insensitive. - Added vt320 builtin termcap. - Be prepared for an empty default_vim_dir. -Files: runtime/gvimrc_example.vim, runtime/vimrc_example.vim, - runtime/doc/os_vms.txt, src/eval.c, src/feature.h, src/fileio.c, - src/gui_motif.c, src/gui_vms_conf.h, src/main.c, src/memline.c, - src/misc1.c, src/option.c, src/os_vms_conf.h, src/os_vms.c, - src/os_vms.h, src/os_vms.mms, src/tag.c, src/term.c, src/version.c - -Patch 5.6.046 -Problem: Systems with backslash in file name: With 'shellslash' set, "vim - */*.c" only uses a slash for the first file name. (Har'El) -Solution: Fix slashes in file name arguments after reading the vimrc file. -Files: src/option.c - -Patch 5.6.047 -Problem: $CPPFLAGS is not passed on to ctags configure. -Solution: Add it. (Walter Briscoe) -Files: src/config.mk.in, src/Makefile - -Patch 5.6.048 -Problem: CTRL-R in Command-line mode is documented to insert text as typed, - but inserts text literally. -Solution: Make CTRL-R insert text as typed, use CTRL-R CTRL-R to insert - literally. This is consistent with Insert mode. But characters - that end Command-line mode are inserted literally. -Files: runtime/doc/index.txt, runtime/doc/cmdline.txt, src/ex_getln.c, - src/ops.c, src/proto/ops.pro - -Patch 5.6.049 -Problem: Documentation for [!] after ":ijump" is wrong way around. (Benji - Fisher) -Solution: Fix the documentation. Also improve the code to check for a match - after a /* */ comment. -Files: runtime/doc/tagsearch.txt, src/search.c - -Patch 5.6.050 -Problem: Replacing is wrong when replacing a single-byte char with - double-byte char or the other way around. -Solution: Shift the text after the character when it is replaced. - (Yasuhiro Matsumoto) -Files: src/normal.c, src/misc1.c - -Patch 5.6.051 -Problem: ":tprev" and ":tnext" don't give an error message when trying to - go before the first or beyond the last tag. (Robert Webb) -Solution: Added error messages. Also: Delay a second when a file-read - message is going to overwrite an error message, otherwise it won't - be seen. -Files: src/fileio.c, src/tag.c - -Patch 5.6.052 -Problem: Multi-byte: When an Ex command has a '|' or '"' as a second byte, - it terminates the command. -Solution: Skip second byte of multi-byte char when checking for '|' and '"'. - (Asai Kenichi) -Files: src/ex_docmd.c - -Patch 5.6.053 -Problem: CTRL-] doesn't work on a tag that contains a '|'. (Cesar Crusius) -Solution: Escape '|', '"' and '\' in tag names when using CTRL-] and also - for command-line completion. -Files: src/ex_getln.c, src/normal.c - -Patch 5.6.054 -Problem: When using ":e" and ":e #" the cursor is put in the first column - when 'startofline' is set. (Cordell) -Solution: Use the last known column when 'startofline' is set. - Also, use ECMD_LAST more often to simplify the code. -Files: src/buffer.c, src/ex_cmds.c, src/ex_docmd.c, src/proto/buffer.pro - -Patch 5.6.055 -Problem: When 'statusline' only contains a text without "%" and doesn't fit - in the window, Vim crashes. (Ron Aaron) -Solution: Don't use the pointer for the first item if there is no item. -Files: src/screen.c - -Patch 5.6.056 (extra) -Problem: MS-DOS: F11 and F12 don't work when 'bioskey' is set. -Solution: Use enhanced keyboard functions. (Vince Negri) - Detect presence of enhanced keyboard and set bioskey_read and - bioskey_ready. -Files: src/os_msdos.c - -Patch 5.6.057 (extra) -Problem: Win32 GUI: Multi-byte characters are wrong in dialogs and tear-off - menus. -Solution: Use system font instead of a fixed font. (Matsumoto, Muraoka) -Files: src/gui_w32.c - -Patch 5.6.058 -Problem: When the 'a' flag is not in 'guioptions', non-Windows systems - copy Visually selected text to the clipboard/selection on a yank - or delete command anyway. On Windows it isn't done even when the - 'a' flag is included. -Solution: Respect the 'a' flag in 'guioptions' on all systems. -Files: src/normal.c - -Patch 5.6.059 (extra) -Problem: When moving the cursor over italic text and the characters spill - over to the cell on the right, that spill-over is deleted. - Noticed in the Win32 GUI, can happen on other systems too. -Solution: Redraw italic text starting from a blank, like this is already - done for bold text. (Vince Negri) -Files: src/gui.c, src/gui.h, src/gui_w32.c - -Patch 5.6.060 -Problem: Some bold characters spill over to the cell on the left, that - spill-over can remain sometimes. -Solution: Redraw a characters when the next character was bold and needs - redrawing. (Robert Webb) -Files: src/screen.c - -Patch 5.6.061 -Problem: When xterm sends 8-bit controls, recognizing the version response - doesn't work. - When using CSI instead of <Esc>[ for the termcap color codes, - using 16 colors doesn't work. (Neil Bird) -Solution: Also accept CSI in place of <Esc>[ for the version string. - Also check for CSI when handling colors 8-15 in term_color(). - Use CSI for builtin xterm termcap entries when 'term' contains - "8bit". -Files: runtime/doc/term.txt, src/ex_cmds.c, src/option.c, src/term.c, - src/os_unix.c, src/proto/option.pro, src/proto/term.pro - -Patch 5.6.062 -Problem: The documentation says that setting 'smartindent' doesn't have an - effect when 'cindent' is set, but it does make a difference for - lines starting with "#". (Neil Bird) -Solution: Really ignore 'smartindent' when 'cindent' is set. -Files: src/misc1.c, src/ops.c - -Patch 5.6.063 -Problem: Using "I" in Visual-block mode doesn't accept a count. (Johannes - Zellner) -Solution: Pass the count on to do_insert() and edit(). (Allan Kelly) -Files: src/normal.c, src/ops.c, src/proto/ops.pro - -Patch 5.6.064 -Problem: MS-DOS and Win32 console: Mouse doesn't work correctly after - including patch 5.6.28. (Vince Negri) -Solution: Don't check for mouse scroll wheel when the mouse code contains - the number of clicks. -Files: src/term.c - -Patch 5.6.065 -Problem: After moving the cursor around in Insert mode, typing a space can - still trigger an abbreviation. (Benji Fisher) -Solution: Don't check for an abbreviation after moving around in Insert mode. -Files: src/edit.c - -Patch 5.6.066 -Problem: Still a few bold character spill-over remains after patch 60. -Solution: Clear character just in front of blanking out rest of the line. - (Robert Webb) -Files: src/screen.c - -Patch 5.6.067 -Problem: When a file name contains a NL, the viminfo file is corrupted. -Solution: Use viminfo_writestring() to convert the NL to CTRL-V n. - Also fix the Buffers menu and listing a menu name with a newline. -Files: runtime/menu.vim, src/buffer.c, src/mark.c, src/menu.c - -Patch 5.6.068 -Problem: Compiling the Perl interface doesn't work with Perl 5.6.0. - (Bernhard Rosenkraenzer) -Solution: Also check xs_apiversion for the version number when prepending - defines for PL_*. -Files: src/Makefile - -Patch 5.6.069 -Problem: "go" doesn't always end up at the right character when - 'fileformat' is "dos". (Bruce DeVisser) -Solution: Correct computations in ml_find_line_or_offset(). -Files: src/memline. - -Patch 5.6.070 (depends on 5.6.068) -Problem: Compiling the Perl interface doesn't work with Perl 5.6.0. - (Bernhard Rosenkraenzer) -Solution: Simpler check instead of the one from patch 68. -Files: src/Makefile - -Patch 5.6.071 -Problem: "A" in Visual block mode on a Tab positions the cursor one char to - the right. (Michael Haumann) -Solution: Correct the column computation in op_insert(). -Files: src/ops.c - -Patch 5.6.072 -Problem: When starting Vim with "vim +startinsert", it enters Insert mode - only after typing the first command. (Andrew Pimlott) -Solution: Insert a dummy command in the stuff buffer. -Files: src/main.c - -Patch 5.6.073 (extra) (depends on 5.6.034) -Problem: Win32 GUI: When compiled with Bcc 5.5 menus don't work. - In dosinst.c toupper() and tolower() give an "internal compiler - error" for Bcc 5.5. -Solution: Define WINVER to 4 to avoid compiling for Windows 2000. (Dan - Sharp) Also cleaned up compilation arguments. - Use our own implementation of toupper() in dosinst.c. Use - mytoupper() instead of tolower(). -Files: src/Makefile.bor, src/dosinst.c - -Patch 5.6.074 (extra) -Problem: Entering CSI directly doesn't always work, because it's recognized - as the start of a special key. Mostly a problem with multi-byte - in the GUI. -Solution: Use K_CSI for a typed CSI character. Use <CSI> for a normal CSI, - <xCSI> for a CSI typed in the GUI. -Files: runtime/doc/intro.txt, src/getchar.c, src/gui_amiga.c, - src/gui_gtk_x11.c, src/gui_mac.c, src/gui_riscos.c, src/gui_w32.c, - src/keymap.h, src/misc2.c - -Patch 5.6.075 -Problem: When using "I" or "A" in Visual block mode while 'sts' is set may - change spaces to a Tab the inserted text is not correct. (Mike - Steed) And some other problems when using "A" to append after the - end of the line. -Solution: Check for change in spaces/tabs after inserting the text. Append - spaces to fill the gap between the end-of-line and the right edge - of the block. -Files: src/ops.c - -Patch 5.6.076 -Problem: GTK GUI: Mapping <M-Space> doesn't work. -Solution: Don't use the "Alt" modifier twice in key_press_event(). -Files: src/gui_gtk_x11.c - -Patch 5.6.077 -Problem: GUI: When interrupting an external program with CTRL-C, gvim might - crash. (Benjamin Korvemaker) -Solution: Avoid using a NULL pointer in ui_inchar_undo(). -Files: src/ui.c - -Patch 5.6.078 -Problem: Locale doesn't always work on FreeBSD. (David O'Brien) -Solution: Link with the "xpg4" library when available. -Files: src/configure.in, src/configure - -Patch 5.6.079 -Problem: Vim could crash when several Tcl interpreters are created and - destroyed. -Solution: handle the "exit" command and nested ":tcl" commands better. (Ingo - Wilken) -Files: runtime/doc/if_tcl.txt, src/if_tcl.c - -Patch 5.6.080 -Problem: When jumping to a tag, generating the tags file and jumping to the - same tag again uses the old search pattern. (Sung-Hyun Nam) -Solution: Flush cached tag matches when executing an external command. -Files: src/misc2.c, src/proto/tag.pro, src/tag.c - -Patch 5.6.081 -Problem: ":syn include" uses a level for the included file, this confuses - contained items included at the same level. -Solution: Use a unique tag for each included file. Changed sp_syn_inc_lvl - to sp_syn_inc_tag. (Scott Bigham) -Files: src/syntax.c, src/structs.h - -Patch 5.6.082 -Problem: When using cscope, Vim can crash. -Solution: Initialize tag_fname in find_tags(). (Anton Blanchard) -Files: src/tag.c - -Patch 5.6.083 (extra) -Problem: Win32: The visual beep can't be seen. (Eric Roesinger) -Solution: Flush the output before waiting with GdiFlush(). (Maurice S. Barnum) - Also: Allow specifying the delay in t_vb for the GUI. -Files: src/gui.c, src/gui_amiga.c, src/gui_gtk_x11.c, src/gui_mac.c, - src/gui_riscos.c, src/gui_w32.c, src/gui_x11.c, src/gui_beos.cc, - src/proto/gui_amiga.pro, src/proto/gui_gtk_x11.pro, - src/proto/gui_mac.pro, src/proto/gui_riscos.pro, - src/proto/gui_w32.pro, src/proto/gui_x11.pro, - src/proto/gui_beos.pro - -Patch 5.6.084 (depends on 5.6.074) -Problem: GUI: Entering CSI doesn't always work for Athena and Motif. -Solution: Handle typed CSI as <xCSI> (forgot this bit in 5.6.074). -Files: src/gui_x11.c - -Patch 5.6.085 -Problem: Multi-byte: Using "r" to replace a double-byte char with a - single-byte char moved the cursor one character. (Matsumoto) - Also, using a count when replacing a single-byte char with a - double-byte char didn't work. -Solution: Don't use del_char() to delete the second byte. - Get "ptr" again after calling ins_char(). -Files: src/normal.c - -Patch 5.6.086 (extra) -Problem: Win32: When using libcall() and the returned value is not a valid - pointer, Vim crashes. -Solution: Use IsBadStringPtr() to check if the pointer is valid. -Files: src/os_win32.c - -Patch 5.6.087 -Problem: Multi-byte: Commands and messages with multi-byte characters are - displayed wrong. -Solution: Detect double-byte characters. (Yasuhiro Matsumoto) -Files: src/ex_getln.c, src/message.c, src/misc2.c, src/screen.c - -Patch 5.6.088 -Problem: Multi-byte with Motif or Athena: The message "XIM requires - fontset" is annoying when Vim was compiled with XIM support but it - is not being used. -Solution: Remove that message. -Files: src/multbyte.c - -Patch 5.6.089 -Problem: On non-Unix systems it's possible to overwrite a read-only file - without using "!". -Solution: Check if the file permissions allow overwriting before moving the - file to become the backup file. -Files: src/fileio.c - -Patch 5.6.090 -Problem: When editing a file in "/home/dir/home/dir" this was replaced with - "~~". (Andreas Jellinghaus) -Solution: Replace the home directory only once in home_replace(). -Files: src/misc1.c - -Patch 5.6.091 -Problem: When editing many "no file" files, can't create swap file, because - .sw[a-p] have all been used. (Neil Bird) -Solution: Also use ".sv[a-z]", ".su[a-z]", etc. -Files: src/memline.c - -Patch 5.6.092 -Problem: FreeBSD: When setting $TERM to a non-valid terminal name, Vim - hangs in tputs(). -Solution: After tgetent() returns an error code, call it again with the - terminal name "dumb". This apparently creates an environment in - which tputs() doesn't fail. -Files: src/term.c - -Patch 5.6.093 (extra) -Problem: Win32 GUI: "ls | gvim -" will show a message box about reading - stdin when Vim exits. (Donohue) -Solution: Don't write a message about the file read from stdin until the GUI - has started. -Files: src/fileio.c - -Patch 5.6.094 -Problem: Problem with multi-byte string for ":echo var". -Solution: Check for length in msg_outtrans_len_attr(). (Sung-Hyun Nam) - Also make do_echo() aware of multi-byte characters. -Files: src/eval.c, src/message.c - -Patch 5.6.095 -Problem: With an Emacs TAGS file that include another a relative path - doesn't always work. -Solution: Use expand_tag_fname() on the name of the included file. - (Utz-Uwe Haus) -Files: src/tag.c - -Patch 5.6.096 -Problem: Unix: When editing many files, startup can be slow. (Paul - Ackersviller) -Solution: Halve the number of stat() calls used to add a file to the buffer - list. -Files: src/buffer.c - -Patch 5.7a.001 -Problem: GTK doesn't respond on drag&drop from ROX-Filer. -Solution: Add "text/uri-list" target. (Thomas Leonard) - Also: fix problem with checking for trash arguments. -Files: src/gui_gtk_x11.c - -Patch 5.7a.002 -Problem: Multi-byte: 'showmatch' is performed when second byte of an - inserted double-byte char is a paren or brace. -Solution: Check IsTrailByte() before calling showmatch(). (Taro Muraoka) -Files: src/misc1.c - -Patch 5.7a.003 -Problem: Multi-byte: After using CTRL-O in Insert mode with the cursor at - the end of the line on a multi-byte character the cursor moves to - the left. -Solution: Check for multi-byte character at end-of-line. (Taro Muraoka) - Also: fix cls() to detect a double-byte character. (Chong-Dae Park) -Files: src/edit.c, src/search.c - -Patch 5.7a.004 -Problem: When reporting the search pattern offset, the string could be - unterminated, which may cause a crash. -Solution: Terminate the string for the search offset. (Stephen P. Wall) -Files: src/search.c - -Patch 5.7a.005 -Problem: When ":s//~/" doesn't find a match it reports "[NULL]" for the - pattern. -Solution: Use get_search_pat() to obtain the actually used pattern. -Files: src/ex_cmds.c, src/proto/search.pro, src/search.c - -Patch 5.7a.006 (extra) -Problem: VMS: Various problems, also with the VAXC compiler. -Solution: In many places use the Unix code for VMS too. - Added time, date and compiler version to version message. - (Zoltan Arpadffy) -Files: src/ex_cmds.c, src/ex_docmd.c, src/globals.h, src/gui_vms_conf.h, - src/main.c, src/message.c, src/misc1.c, src/os_vms.c, - src/os_vms.h, src/os_vms.mms, src/os_vms_conf.h, - src/proto/os_vms.pro, src/proto/version.pro, src/term.c, - src/version.c, src/xxd/os_vms.mms, src/xxd/xxd.c - -Patch 5.7a.007 -Problem: Motif and Athena GUI: CTRL-@ is interpreted as CTRL-C. -Solution: Only use "intr_char" when it has been set. -Files: src/gui_x11.c - -Patch 5.7a.008 -Problem: GTK GUI: When using CTRL-L the screen is redrawn twice, causing - trouble for bold characters. Also happens when moving with the - scrollbar. Best seen when 'writedelay' is non-zero. - When starting the GUI with ":gui" the screen is redrawn once with - the wrong colors. -Solution: Only set the geometry hints when the window size really changed. - This avoids setting it each time the scrollbar is forcefully - redrawn. - Don't redraw in expose_event() when gui.starting is still set. -Files: src/gui_gtk_x11.c - - -============================================================================== -VERSION 5.8 *version-5.8* - -Version 5.8 is a bug-fix version of 5.7. - - -Changed *changed-5.8* -------- - -Ctags is no longer included with Vim. It has grown into a project of its own. -You can find it here: http://ctags.sf.net. It is highly recommended as a Vim -companion when you are writing programs. - - -Added *added-5.8* ------ - -New syntax files: -acedb AceDB (Stewart Morris) -aflex Aflex (Mathieu Clabaut) -antlr Antlr (Mathieu Clabaut) -asm68k 68000 Assembly (Steve Wall) -automake Automake (John Williams) -ayacc Ayacc (Mathieu Clabaut) -b B (Mathieu Clabaut) -bindzone BIND zone (glory hump) -blank Blank (Rafal Sulejman) -cfg Configure files (Igor Prischepoff) -changelog ChangeLog (Gediminas Paulauskas) -cl Clever (Phil Uren) -crontab Crontab (John Hoelzel) -csc Essbase script (Raul Segura Acevedo) -cynlib Cynlib(C++) (Phil Derrick) -cynpp Cyn++ (Phil Derrick) -debchangelog Debian Changelog (Wichert Akkerman) -debcontrol Debian Control (Wichert Akkerman) -dns DNS zone file (Jehsom) -dtml Zope's DTML (Jean Jordaan) -dylan Dylan, Dylan-intr and Dylan-lid (Brent Fulgham) -ecd Embedix Component Description (John Beppu) -fgl Informix 4GL (Rafal Sulejman) -foxpro FoxPro (Powing Tse) -gsp GNU Server Pages (Nathaniel Harward) -gtkrc GTK rc (David Necas) -hercules Hercules (Avant! Corporation) (Dana Edwards) -htmlos HTML/OS by Aestiva (Jason Rust) -inittab SysV process control (David Necas) -iss Inno Setup (Dominique Stephan) -jam Jam (Ralf Lemke) -jess Jess (Paul Baleme) -lprolog LambdaProlog (Markus Mottl) -ia64 Intel Itanium (parth malwankar) -kix Kixtart (Nigel Gibbs) -mgp MaGic Point (Gerfried Fuchs) -mason Mason (HTML with Perl) (Andrew Smith) -mma Mathematica (Wolfgang Waltenberger) -nqc Not Quite C (Stefan Scherer) -omnimark Omnimark (Paul Terray) -openroad OpenROAD (Luis Moreno Serrano) -named BIND configuration (glory hump) -papp PApp (Marc Lehmann) -pfmain Postfix main config (Peter Kelemen) -pic PIC assembly (Aleksandar Veselinovic) -ppwiz PPWizard (Stefan Schwarzer) -progress Progress (Phil Uren) -psf Product Specification File (Rex Barzee) -r R (Tom Payne) -registry MS-Windows registry (Dominique Stephan) -robots Robots.txt (Dominique Stephan) -rtf Rich Text Format (Dominique Stephan) -setl SETL (Alex Poylisher) -sgmldecl SGML Declarations (Daniel A. Molina W.) -sinda Sinda input (Adrian Nagle) -sindacmp Sinda compare (Adrian Nagle) -sindaout Sinda output (Adrian Nagle) -smith SMITH (Rafal Sulejman) -snobol4 Snobol 4 (Rafal Sulejman) -strace Strace (David Necas) -tak TAK input (Adrian Nagle) -takcmp TAK compare (Adrian Nagle) -takout TAK output (Adrian Nagle) -tasm Turbo assembly (FooLman) -texmf TeX configuration (David Necas) -trasys Trasys input (Adrian Nagle) -tssgm TSS Geometry (Adrian Nagle) -tssop TSS Optics (Adrian Nagle) -tsscl TSS Command line (Adrian Nagle) -virata Virata Configuration Script (Manuel M.H. Stol) -vsejcl VSE JCL (David Ondrejko) -wdiff Wordwise diff (Gerfried Fuchs) -wsh Windows Scripting Host (Paul Moore) -xkb X Keyboard Extension (David Necas) - -Renamed php3 to php, it now also supports php4 (Lutz Eymers) - -Patch 5.7.015 -Problem: Syntax files for Vim 6.0 can't be used with 5.x. -Solution: Add the "default" argument to the ":highlight" command: Ignore the - command if highlighting was already specified. -Files: src/syntax.c - -Generate the Syntax menu with makemenu.vim, so that it doesn't have to be done -when Vim is starting up. Reduces the startup time of the GUI. - - -Fixed *fixed-5.8* ------ - -Conversion of docs to HTML didn't convert "|tag|s" to a hyperlink. - -Fixed compiling under NeXT. (Jeroen C.M. Goudswaard) - -optwin.vim gave an error when used in Vi compatible mode ('cpo' contains 'C'). - -Tcl interpreter: "buffer" command didn't check for presence of an argument. -(Dave Bodenstab) - -dosinst.c: Added checks for too long file name. - -Amiga: a file name starting with a colon was considered absolute but it isn't. -Amiga: ":pwd" added a slash when in the root of a drive. - -Macintosh: Warnings for unused variables. (Bernhard Pruemmer) - -Unix: When catching a deadly signal, handle it in such a way that it's -unlikely that Vim will hang. Call _exit() instead of exit() in case of a -severe problem. - -Setting the window title from nothing to something didn't work after patch 29. - -Check for ownership of .exrc and .vimrc was done with stat(). Use lstat() as -well for extra security. - -Win32 GUI: Printing a file with 'fileformat' "unix" didn't work. Set -'fileformat' to "dos" before writing the temp file. - -Unix: Could start waiting for a character when checking for a CTRL-C typed -when an X event is received. - -Could not use Perl and Python at the same time on FreeBSD, because Perl used -"-lc" and Python used the threaded C library. - -Win32: The Mingw compiler gave a few warning messages. - -When using "ZZ" and an autocommand for writing uses an abbreviation it didn't -work. Don't stuff the ":x" command but execute it directly. (Mikael Berthe) - -VMS doesn't always have lstat(), added an #ifdef around it. - -Added a few corrections for the Macintosh. (Axel Kielhorn) - -Win32: Gvimext could not edit more than a few files at once, the length of the -argument was fixed. - - -Previously released patches for Vim 5.7: - -Patch 5.7.001 -Problem: When the current buffer is crypted, and another modified buffer - isn't, ":wall" will encrypt the other buffer. -Solution: In buf_write() use "buf" instead of "curbuf" to check for the - crypt key. -Files: src/fileio.c - -Patch 5.7.002 -Problem: When 'showmode' is set, using "CTRL-O :r file" waits three seconds - before displaying the read text. (Wichert Akkerman) -Solution: Set "keep_msg" to the file message so that the screen is redrawn - before the three seconds wait for displaying the mode message. -Files: src/fileio.c - -Patch 5.7.003 -Problem: Searching for "[[:cntrl:]]" doesn't work. -Solution: Exclude NUL from the matching characters, it terminates the list. -Files: src/regexp.c - -Patch 5.7.004 -Problem: GTK: When selecting a new font, Vim can crash. -Solution: In gui_mch_init_font() unreference the old font, not the new one. -Files: src/gui_gtk_x11.c - -Patch 5.7.005 -Problem: Multibyte: Inserting a wrapped line corrupts kterm screen. - Pasting TEXT/COMPOUND_TEXT into Vim does not work. - On Motif no XIM status line is displayed even though it is - available. -Solution: Don't use xterm trick for wrapping lines for multibyte mode. - Correct a missing "break", added TEXT/COMPOUND_TEXT selection - request. - Add XIMStatusArea fallback code. - (Katsuhito Nagano) -Files: src/gui_gtk_x11.c, src/multbyte.c, src/screen.c, src/ui.c - -Patch 5.7.006 -Problem: GUI: redrawing the non-Visual selection is wrong when the window - is unobscured. (Jean-Pierre Etienne) -Solution: Redraw the selection properly and don't clear it. Added "len" - argument to clip_may_redraw_selection(). -Files: src/gui.c, src/ui.c, src/proto/ui.pro - -Patch 5.7.007 -Problem: Python: Crash when using the current buffer twice. -Solution: Increase the reference count for buffer and window objects. - (Johannes Zellner) -Files: src/if_python.c - -Patch 5.7.008 -Problem: In Ex mode, backspacing over the first TAB doesn't work properly. - (Wichert Akkerman) -Solution: Switch the cursor on before printing the newline. -Files: src/ex_getln.c - -Patch 5.7.009 (extra) -Problem: Mac: Crash when using a long file. -Solution: Don't redefine malloc() and free(), because it will break using - realloc(). -Files: src/os_mac.h - -Patch 5.7.010 -Problem: When using CTRL-A on a very long number Vim can crash. (Michael - Naumann) -Solution: Truncate the length of the new number to avoid a buffer overflow. -Files: src/ops.c - -Patch 5.7.011 (extra) -Problem: Win32 GUI on NT 5 and Win98: Displaying Hebrew is reversed. -Solution: Output each character separately, to avoid that Windows reverses - the text for some fonts. (Ron Aaron) -Files: src/gui_w32.c - -Patch 5.7.012 -Problem: When using "-complete=buffer" for ":command" the user command - fails. -Solution: In a user command don't replace the buffer name with a count for - the buffer number. -Files: src/ex_docmd.c - -Patch 5.7.013 -Problem: "gD" didn't always find a match in the first line, depending on - the column the search started at. -Solution: Reset the column to zero before starting to search. -Files: src/normal.c - -Patch 5.7.014 -Problem: Rot13 encoding was done on characters with accents, which is - wrong. (Sven Gottwald) -Solution: Only do rot13 encoding on ASCII characters. -Files: src/ops.c - -Patch 5.7.016 -Problem: When hitting 'n' for a ":s///c" command, the ignore-case flag was - not restored, some matches were skipped. (Daniel Blaustein) -Solution: Restore the reg_ic variable when 'n' was hit. -Files: src/ex_cmds.c - -Patch 5.7.017 -Problem: When using a Vim script for Vim 6.0 with <SID> before a function - name, it produces an error message even when inside an "if version - >= 600". (Charles Campbell) -Solution: Ignore errors in the function name when the function is not going - to be defined. -Files: src/eval.c - -Patch 5.7.018 -Problem: When running "rvim" or "vim -Z" it was still possible to execute a - shell command with system() and backtick-expansion. (Antonios A. - Kavarnos) -Solution: Disallow executing a shell command in get_cmd_output() and - mch_expand_wildcards(). -Files: src/misc1.c, src/os_unix.c - -Patch 5.7.019 -Problem: Multibyte: In a substitute string, a multi-byte character isn't - skipped properly, can be a problem when the second byte is a - backslash. -Solution: Skip an extra byte for a double-byte character. (Muraoka Taro) -Files: src/ex_cmds.c - -Patch 5.7.020 -Problem: Compilation doesn't work on MacOS-X. -Solution: Add a couple of #ifdefs. (Jamie Curmi) -Files: src/regexp.c, src/ctags/general.h - -Patch 5.7.021 -Problem: Vim sometimes produces a beep when started in an xterm. Only - happens when compiled without mouse support. -Solution: Requesting the xterm version results in a K_IGNORE. This wasn't - handled when mouse support is disabled. Accept K_IGNORE always. -Files: src/normal.c - -Patch 5.7.022 -Problem: %v in 'statusline' is not displayed when it's equal to %c. -Solution: Check if %V or %v is used and handle them differently. -Files: src/screen.c - -Patch 5.7.023 -Problem: Crash when a WinLeave autocommand deletes the buffer in the other - window. -Solution: Check that after executing the WinLeave autocommands there still - is a window to be closed. Also update the test that was supposed - to check for this problem. -Files: src/window.c, testdir/test13.in, testdir/test13.ok - -Patch 5.7.024 -Problem: Evaluating an expression for 'statusline' can have side effects. -Solution: Evaluate the expression in a sandbox. -Files: src/edit.c, src/eval.c, src/proto/eval.pro, src/ex_cmds.c, - src/ex_cmds.h, src/ex_docmd.c, src/globals.h, src/option.c, - src/screen.c, src/undo.c - -Patch 5.7.025 (fixed) -Problem: Creating a temp file has a race condition. -Solution: Create a private directory to write the temp files in. -Files: src/fileio.c, src/misc1.c, src/proto/misc1.pro, - src/proto/fileio.pro, src/memline.c, src/os_unix.h - -Patch 5.7.026 (extra) -Problem: Creating a temp file has a race condition. -Solution: Create a private directory to write the temp files in. - This is the extra part of patch 5.7.025. -Files: src/os_msdos.h - -Patch 5.7.027 -Problem: Starting to edit a file can cause a crash. For example when in - Insert mode, using CTRL-O :help abbr<Tab> to scroll the screen and - then <CR>, which edits a help file. (Robert Bogomip) -Solution: Check if keep_msg is NULL before copying it. -Files: src/fileio.c - -Patch 5.7.028 -Problem: Creating a backup or swap file could fail in rare situations. -Solution: Use O_EXCL for open(). -Files: src/fileio.c, src/memfile.c - -Patch 5.7.029 -Problem: Editing a file with an extremely long name crashed Vim. -Solution: Check for length of the name when setting the window title. -Files: src/buffer.c - -Patch 5.7.030 -Problem: A ":make" or ":grep" command with a very long argument could cause - a crash. -Solution: Allocate the buffer for the shell command. -Files: src/ex_docmd.c - - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/version6.txt b/share/vim/vim72/doc/version6.txt deleted file mode 100644 index 611ff8df2d..0000000000 --- a/share/vim/vim72/doc/version6.txt +++ /dev/null @@ -1,14530 +0,0 @@ -*version6.txt* For Vim version 7.2. Last change: 2008 Aug 06 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Welcome to Vim Version 6.0! A large number of features has been added. This -file mentions all the new items that have been added, changes to existing -features and bug fixes compared to Vim 5.x. - -See |vi_diff.txt| for an overview of differences between Vi and Vim 6.0. -See |version4.txt| for differences between Vim 3.0 and Vim 4.0. -See |version5.txt| for differences between Vim 4.0 and Vim 5.0. - -INCOMPATIBLE CHANGES |incompatible-6| - -Cursor position in Visual mode |curpos-visual| -substitute command Vi compatible |substitute-CR| -global option values introduced |new-global-values| -'fileencoding' changed |fileencoding-changed| -Digraphs changed |digraphs-changed| -Filetype detection changed |filetypedetect-changed| -Unlisted buffers introduced |new-unlisted-buffers| -CTRL-U in Command-line mode changed |CTRL-U-changed| -Ctags gone |ctags-gone| -Documentation reorganized |documentation-6| -Modeless selection and clipboard |modeless-and-clipboard| -Small incompatibilities |incomp-small-6| - -NEW FEATURES |new-6| - -Folding |new-folding| -Vertically split windows |new-vertsplit| -Diff mode |new-diff-mode| -Easy Vim: click-and-type |new-evim| -User manual |new-user-manual| -Flexible indenting |new-indent-flex| -Extended search patterns |new-searchpat| -UTF-8 support |new-utf-8| -Multi-language support |new-multi-lang| -Plugin support |new-plugins| -Filetype plugins |new-filetype-plugins| -File browser |new-file-browser| -Editing files over a network |new-network-files| -Window for command-line editing |new-cmdwin| -Debugging mode |new-debug-mode| -Cursor in virtual position |new-virtedit| -Debugger interface |new-debug-itf| -Communication between Vims |new-vim-server| -Buffer type options |new-buftype| -Printing |new-printing| -Ports |ports-6| -Quickfix extended |quickfix-6| -Operator modifiers |new-operator-mod| -Search Path |new-search-path| -Writing files improved |new-file-writing| -Argument list |new-argument-list| -Restore a View |new-View| -Color schemes |new-color-schemes| -Various new items |new-items-6| - -IMPROVEMENTS |improvements-6| - -COMPILE TIME CHANGES |compile-changes-6| - -BUG FIXES |bug-fixes-6| - -VERSION 6.1 |version-6.1| -Changed |changed-6.1| -Added |added-6.1| -Fixed |fixed-6.1| - -VERSION 6.2 |version-6.2| -Changed |changed-6.2| -Added |added-6.2| -Fixed |fixed-6.2| - -VERSION 6.3 |version-6.3| -Changed |changed-6.3| -Added |added-6.3| -Fixed |fixed-6.3| - -VERSION 6.4 |version-6.4| -Changed |changed-6.4| -Added |added-6.4| -Fixed |fixed-6.4| - -============================================================================== -INCOMPATIBLE CHANGES *incompatible-6* - -These changes are incompatible with previous releases. Check this list if you -run into a problem when upgrading from Vim 5.x to 6.0 - - -Cursor position in Visual mode *curpos-visual* ------------------------------- - -When going from one window to another window on the same buffer while in -Visual mode, the cursor position of the other window is adjusted to keep the -same Visual area. This can be used to set the start of the Visual area in one -window and the end in another. In vim 5.x the cursor position of the other -window would be used, which could be anywhere and was not very useful. - - -Substitute command Vi compatible *substitute-CR* --------------------------------- - -The substitute string (the "to" part of the substitute command) has been made -Vi compatible. Previously a CTRL-V had a special meaning and could be used to -prevent a <CR> to insert a line break. This made it impossible to insert a -CTRL-V before a line break. Now a backslash is used to prevent a <CR> to -cause a line break. Since the number of backslashes is halved, it is still -possible to insert a line break at the end of the line. This now works just -like Vi, but it's not compatible with Vim versions before 6.0. - -When a ":s" command doesn't make any substitutions, it no longer sets the '[ -and '] marks. This is not related to Vi, since it doesn't have these marks. - - -Global option values introduced *new-global-values* -------------------------------- - -There are now global values for options which are local to a buffer or window. -Previously the local options were copied from one buffer to another. When -editing another file this could cause option values from a modeline to be used -for the wrong file. Now the global values are used when entering a buffer -that has not been used before. Also, when editing another buffer in a window, -the local window options are reset to their global values. The ":set" command -sets both the local and global values, this is still compatible. But a -modeline only sets the local value, this is not backwards compatible. - -":let &opt = val" now sets the local and global values, like ":set". New -commands have been added to set the global or local value: - :let &opt = val like ":set" - :let &g:opt = val like ":setglobal" - :let &l:opt = val like ":setlocal" - - -'fileencoding' changed *fileencoding-changed* ----------------------- - -'fileencoding' was used in Vim 5.x to set the encoding used inside all of Vim. -This was a bit strange, because it was local to a buffer and worked for all -buffers. It could never be different between buffers, because it changed the -way text in all buffers was interpreted. -It is now used for the encoding of the file related to the buffer. If you -still set 'fileencoding' it is likely to be overwritten by the detected -encoding from 'fileencodings', thus it is "mostly harmless". -The old FileEncoding autocommand now does the same as the new EncodingChanged -event. - - -Digraphs changed *digraphs-changed* ----------------- - -The default digraphs now correspond to RFC1345. This is very different from -what was used in Vim 5.x. |digraphs| - - -Filetype detection changed *filetypedetect-changed* --------------------------- - -The filetype detection previously was using the "filetype" autocommand group. -This caused confusion with the FileType event name (case is ignored). The -group is now called "filetypedetect". It still works, but if the "filetype" -group is used the autocommands will not be removed by ":filetype off". - The support for 'runtimepath' has made the "myfiletypefile" and -"mysyntaxfile" mechanism obsolete. They are still used for backwards -compatibility. - -The connection between the FileType event and setting the 'syntax' option was -previously in the "syntax" autocommand group. That caused confusion with the -Syntax event name. The group is now called "syntaxset". - -The distributed syntax files no longer contain "syntax clear". That makes it -possible to include one in the other without tricks. The syntax is now -cleared when the 'syntax' option is set (by an autocommand added from -synload.vim). This makes the syntax cleared when the value of 'syntax' does -not correspond to a syntax file. Previously the existing highlighting was -kept. - - -Unlisted buffers introduced *new-unlisted-buffers* ---------------------------- - -There is now a difference between buffers which don't appear in the buffer -list and buffers which are really not in the buffer list. Commands like -":ls", ":bnext", ":blast" and the Buffers menu will skip buffers not in the -buffer list. |unlisted-buffer| -The 'buflisted' option can be used to make a buffer appear in the buffer list -or not. - -Several commands that previously added a buffer to the buffer list now create -an unlisted buffer. This means that a ":bnext" and ":ball" will not find these -files until they have actually been edited. For example, buffers used for the -alternative file by ":write file" and ":read file". - Other commands previously completely deleted a buffer and now only remove -the buffer from the buffer list. Commands relying on a buffer not to be -present might fail. For example, a ":bdelete" command in an autocommand that -relied on something following to fail (was used in the automatic tests). -|:bwipeout| can be used for the old meaning of ":bdelete". - -The BufDelete autocommand event is now triggered when a buffer is removed from -the buffer list. The BufCreate event is only triggered when a buffer is -created that is added to the buffer list, or when an existing buffer is added -to the buffer list. BufAdd is a new name for BufCreate. -The new BufNew event is for creating any buffer and BufWipeout for really -deleting a buffer. - -When doing Insert mode completion, only buffers in the buffer list are -scanned. Added the 'U' flag to 'complete' to do completion from unlisted -buffers. - -Unlisted buffers are not stored in a viminfo file. - - -CTRL-U in Command-line mode changed *CTRL-U-changed* ------------------------------------ - -Using CTRL-U when editing the command line cleared the whole line. Most -shells only delete the characters before the cursor. Made it work like that. -(Steve Wall) - -You can get the old behavior with CTRL-E CTRL-U: > - :cnoremap <C-U> <C-E><C-U> - - -Ctags gone *ctags-gone* ----------- - -Ctags is no longer part of the Vim distribution. It's now a grown-up program -by itself, it deserves to be distributed separately. -Ctags can be found here: http://ctags.sf.net/. - - -Documentation reorganized *documentation-6* -------------------------- - -The documentation has been reorganized, an item may not be where you found it -in Vim 5.x. -- The user manual was added, some items have been moved to it from the - reference manual. -- The quick reference is now in a separate file (so that it can be printed). - -The examples in the documentation were previously marked with a ">" in the -first column. This made it difficult to copy/paste them. There is now a -single ">" before the example and it ends at a "<" or a non-blank in the first -column. This also looks better without highlighting. - -'helpfile' is no longer used to find the help tags file. This allows a user -to add its own help files (e.g., for plugins). - - -Modeless selection and clipboard *modeless-and-clipboard* --------------------------------- - -The modeless selection is used to select text when Visual mode can't be used, -for example when editing the command line or at the more prompt. -In Vim 5.x the modeless selection was always used. On MS-Windows this caused -the clipboard to be overwritten, with no way to avoid that. The modeless -selection now obeys the 'a' and 'A' flags in 'guioptions' and "autoselect" and -"autoselectml" in 'clipboard'. By default there is no automatic copy on -MS-Windows. Use the |c_CTRL-Y| command to manually copy the selection. - -To get the old behavior back, do this: > - - :set clipboard^=autoselectml guioptions+=A - - -Small incompatibilities *incomp-small-6* ------------------------ - -'backupdir', 'cdpath', 'directory', 'equalprg', 'errorfile', 'formatprg', -'grepprg', 'helpfile', 'makeef', 'makeprg', 'keywordprg', 'cscopeprg', -'viminfo' and 'runtimepath' can no longer be set from a modeline, for better -security. - -Removed '_' from the 'breakat' default: It's commonly used in keywords. - -The default for 'mousehide' is on, because this works well for most people. - -The Amiga binary is now always compiled with "big" features. The "big" binary -archive no longer exists. - -The items "[RO]", "[+]", "[help]", "[Preview]" and "[filetype]" in -'statusline' no longer have a leading space. - -Non-Unix systems: When expanding wildcards for the Vim arguments, don't use -'suffixes'. It now works as if the shell had expanded the arguments. - -The 'lisp', 'smartindent' and 'cindent' options are not switched off when -'paste' is set. The auto-indenting is disabled when 'paste' is set, but -manual indenting with "=" still works. - -When formatting with "=" uses 'cindent' or 'indentexpr' indenting, and there -is no change in indent, this is not counted as a change ('modified' isn't set -and there is nothing to undo). - -Report 'modified' as changed when 'fileencoding' or 'fileformat' was set. -Thus it reflects the possibility to abandon the buffer without losing changes. - -The "Save As" menu entry now edits the saved file. Most people expect it to -work like this. - -A buffer for a directory is no longer added to the Buffers menu. - -Renamed <Return> to <Enter>, since that's what it's called on most keyboards. -Thus it's now the hit-enter prompt instead of the hit-return prompt. -Can map <Enter> just like <CR> or <Return>. - -The default for the 'viminfo' option is now '20,"50,h when 'compatible' isn't -set. Most people will want to use it, including beginners, but it required -setting the option, which isn't that easy. - -After using ":colder" the newer error lists are overwritten. This makes it -possible to use ":grep" to browse in a tree-like way. Must use ":cnewer 99" -to get the old behavior. - -The patterns in 'errorformat' would sometimes ignore case (MS-Windows) and -sometimes not (Unix). Now case is always ignored. Add "\C" to the pattern to -match case. - -The 16 bit MS-DOS version is now compiled without the +listcmds feature -(buffer list manipulation commands). They are not often needed and this -executable needs to be smaller. - -'sessionoptions' now includes "curdir" by default. This means that restoring -a session will result in the current directory being restored, instead of -going to the directory where the session file is located. - -A session deleted all buffers, deleting all marks. Now keep the buffer list, -it shouldn't hurt for some existing buffers to remain present. -When the argument list is empty ":argdel *" caused an error message. - -No longer put the search pattern from a tag jump in the history. - -Use "SpecialKey" highlighting for unprintable characters instead of "NonText". -The idea is that unprintable text or any text that's displayed differently -from the characters in the file is using "SpecialKey", and "NonText" is used -for text that doesn't really exist in the file. - -Motif now uses the system default colors for the menu and scrollbar. Used to -be grey. It's still possible to set the colors with ":highlight" commands and -resources. - -Formatting text with "gq" breaks a paragraph at a non-empty blank line. -Previously the line would be removed, which wasn't very useful. - -":normal" does no longer hang when the argument ends in half a command. -Previously Vim would wait for more characters to be typed, without updating -the screen. Now it pretends an <Esc> was typed. - -Bitmaps for the toolbar are no longer searched for in "$VIM/bitmaps" but in -the "bitmaps" directories in 'runtimepath'. - -Now use the Cmdline-mode menus for the hit-enter prompt instead of the Normal -mode menus. This generally works better and allows using the "Copy" menu to -produce CTRL-Y to copy the modeless selection. - -Moved the font selection from the Window to the Edit menu, together with the -other settings. - -The default values for 'isfname' include more characters to make "gf" work -better. - -Changed the license for the documentation to the Open Publication License. -This seemed fair, considering the inclusion of parts of the Vim book, which is -also published under the OPL. The downside is that we can't force someone who -would sell copies of the manual to contribute to Uganda. - -After "ayy don't let ""yy or :let @" = val overwrite the "a register. -Use the unnamed register instead. - -MSDOS: A pattern "*.*" previously also matched a file name without a dot. -This was inconsistent with other versions. - -In Insert mode, CTRL-O CTRL-\ CTRL-N {cmd} remains in Normal mode. Previously -it would go back to Insert mode, thus confusing the meaning of CTRL-\ CTRL-N, -which is supposed to take us to Normal mode (especially in ":amenu"). - -Allow using ":" commands after an operator. Could be used to implement a new -movement command. Thus it no longer aborts a pending operator. - -For the Amiga the "-d {device}" argument was possible. When compiled with the -diff feature, this no longer works. Use "-dev {device}" instead. |-dev| - -Made the default mappings for <S-Insert> in Insert mode insert the text -literally, avoids that special characters like BS cause side effects. - -Using ":confirm" applied to the rest of the line. Now it applies only to the -command right after it. Thus ":confirm if x | edit | endif" no longer works, -use ":if x | confirm edit | endif". This was the original intention, that it -worked differently was a bug. - -============================================================================== -NEW FEATURES *new-6* - -Folding *new-folding* -------- - -Vim can now display a buffer with text folded. This allows overviewing the -structure of a file quickly. It is also possible to yank, delete and put -folded text, for example to move a function to another position. - -There is a whole bunch of new commands and options related to folding. -See |folding|. - - -Vertically split windows *new-vertsplit* ------------------------- - -Windows can also be split vertically. This makes it possible to have windows -side by side. One nice use for this is to compare two similar files (see -|new-diff-mode|). The 'scrollbind' option can be used to synchronize -scrolling. - -A vertical split can be created with the commands: - :vsplit or CTRL-W v or CTRL-W CTRL-V |:vsplit| - :vnew |:vnew| - :vertical {cmd} |:vertical| -The last one is a modifier, which has a meaning for any command that splits a -window. For example: > - :vertical stag main -Will vertically split the window and jump to the tag "main" in the new window. - -Moving from window to window horizontally can be done with the |CTRL-W_h| and -|CTRL-W_l| commands. The |CTRL-W_k| and |CTRL-W_j| commands have been changed -to jump to the window above or below the cursor position. - -The vertical and horizontal splits can be mixed as you like. Resizing windows -is easy when using the mouse, just position the pointer on a status line or -vertical separator and drag it. In the GUI a special mouse pointer shape -indicates where you can drag a status or separator line. - -To resize vertically split windows use the |CTRL-W_<| and |CTRL-W_>| commands. -To make a window the maximum width use the CTRL-W | command |CTRL-W_bar|. - -To force a new window to use the full width or height of the Vim window, -these two modifiers are available: - :topleft {cmd} New window appears at the top with full - width or at the left with full height. - :botright {cmd} New window appears at the bottom with full - width or at the right with full height. -This can be combined with ":vertical" to force a vertical split: > - :vert bot dsplit DEBUG -This will open a window at the far right, occupying the full height of the Vim -window, with the cursor on the first definition of "DEBUG". -The help window is opened at the top, like ":topleft" was used, if the current -window is fewer than 80 characters wide. - -A few options can be used to set the preferences for vertically split windows. -They work similar to their existing horizontal equivalents: - horizontal vertical ~ - 'splitbelow' 'splitright' - 'winheight' 'winwidth' - 'winminheight' 'winminwidth' -It's possible to set 'winminwidth' to zero, so that temporarily unused windows -hardly take up space without closing them. - -The new 'eadirection' option tells where 'equalalways' applies: - :set eadirection=both both directions - :set eadirection=ver equalize window heights - :set eadirection=hor equalize windows widths -This can be used to avoid changing window sizes when you want to keep them. - -Since windows can become quite narrow with vertical splits, text lines will -often not fit. The 'sidescrolloff' has been added to keep some context left -and right of the cursor. The 'listchars' option has been extended with the -"precedes" item, to show a "<" for example, when there is text left off the -screen. (Utz-Uwe Haus) - -"-O" command line argument: Like "-o" but split windows vertically. (Scott -Urban) - -Added commands to move the current window to the very top (CTRL-W K), bottom -(CTRL-W J), left (CTRL-W H) and right (CTRL-W L). In the new position the -window uses the full width/height of the screen. - -When there is not enough room in the status line for both the file name and -the ruler, use up to half the width for the ruler. Useful for narrow windows. - - -Diff mode *new-diff-mode* ---------- - -In diff mode Vim shows the differences between two, three or four files. -Folding is used to hide the parts of the file that are equal. -Highlighting is used to show deleted and changed lines. -See |diff-mode|. - -An easy way to start in diff mode is to start Vim as "vimdiff file1 file2". -Added the vimdiff manpage. - -In a running Vim the |:diffsplit| command starts diff mode for the current -file and another file. The |:diffpatch| command starts diff mode using the -current file and a patch file. The |:diffthis| command starts diff mode for -the current window. - -Differences can be removed with the |:diffget| and |:diffput| commands. - -- The 'diff' option switches diff mode on in a window. -- The |:diffupdate| command refreshes the diffs. -- The 'diffopt' option changes how diffs are displayed. -- The 'diffexpr' option can be set how a diff is to be created. -- The 'patchexpr' option can be set how patch is applied to a file. -- Added the "diff" folding method. When opening a window for diff-mode, set - 'foldlevel' to zero and 'foldenable' on, to close the folds. -- Added the DiffAdd, DiffChange, DiffDelete and DiffText highlight groups to - specify the highlighting for differences. The defaults are ugly... -- Unix: make a vimdiff symbolic link for "make install". -- Removed the now obsolete "vimdiff.vim" script from the distribution. -- Added the "[c" and "]c" commands to move to the next/previous change in diff - mode. - - -Easy Vim: click-and-type *new-evim* ------------------------- - -eVim stands for "Easy Vim". This is a separate program, but can also be -started as "vim -y". - -This starts Vim with 'insertmode' set to allow click-and-type editing. The -$VIMRUNTIME/evim.vim script is used to add mappings and set options to be able -to do most things like Notepad. This is only for people who can't stand two -modes. - -eView does the same but in readonly mode. - -In the GUI a CTRL-C now only interrupts when busy with something, not when -waiting for a character. Allows using CTRL-C to copy text to the clipboard. - - -User manual *new-user-manual* ------------ - -The user manual has been added. It is organised around editing tasks. It -reads like a book, from start to end. It should allow beginners to start -learning Vim. It helps everybody to learn using the most useful Vim features. -It is much easier to read than the reference manual, but omits details. See -|user-manual|. - -The user manual includes parts of the Vim book by Steve Oualline |frombook|. -It is published under the OPL |manual-copyright|. - -When syntax highlighting is not enabled, the characters in the help file which -mark examples ('>' and '<') and header lines ('~') are replaced with a space. - -When closing the help window, the window layout is restored from before -opening it, if the window layout didn't change since then. -When opening the help window, put it at the top of the Vim window if the -current window is fewer than 80 characters and not full width. - - -Flexible indenting *new-indent-flex* ------------------- - -Automatic indenting is now possible for any language. It works with a Vim -script, which makes it very flexible to compute the indent. - -The ":filetype indent on" command enables using the provided indent scripts. -This is explained in the user manual: |30.3|. - -The 'indentexpr' option is evaluated to get the indent for a line. The -'indentkeys' option tells when to trigger re-indenting. Normally these -options are set from an indent script. Like Syntax files, indent scripts will -be created and maintained by many people. - - -Extended search patterns *new-searchpat* ------------------------- - -Added the possibility to match more than one line with a pattern. (partly by -Loic Grenie) -New items in a search pattern for multi-line matches: -\n match end-of-line, also in [] -\_[] match characters in range and end-of-line -\_x match character class and end-of-line -\_. match any character or end-of-line -\_^ match start-of-line, can be used anywhere in the regexp -\_$ match end-of-line, can be used anywhere in the regexp - -Various other new items in search patterns: -\c ignore case for the whole pattern -\C match case for the whole pattern -\m magic on for the following -\M magic off for the following -\v make following characters "very magic" -\V make following characters "very nomagic" - -\@! don't match atom before this. - Example: "foo\(bar\)\@!" matches "foo " but not "foobar". -\@= match atom, resulting in zero-width match - Example: "foo\(bar\)\@=" matches "foo" in "foobar". -\@<! don't match preceding atom before the current position -\@<= match preceding atom before the current position -\@> match preceding atom as a subexpression - -\& match only when branch before and after it match - -\%[] optionally match a list of atoms; "end\%[if]" matches "end", - "endi" and "endif" -\%(\) like \(\), but without creating a back-reference; there can be - any number of these, overcomes the limit of nine \( \) pairs -\%^ match start-of-file (Chase Tingley) -\%$ match end-of-file (Chase Tingley) -\%# Match with the cursor position. (Chase Tingley) -\? Just like "\=" but can't be used in a "?" command. - -\%23l match in line 23 -\%<23l match before line 23 -\%>23l match after line 23 -\%23c, \%<23c, \%>23c match in/before/after column 23 -\%23v, \%<23v, \%>23v match in/before/after virtual column 23 - - -For syntax items: -\z(...\) external reference match set (in region start pattern) -\z1 - \z9 external reference match use (in region skip or end pattern) - (Scott Bigham) - -\zs use position as start of match -\ze use position as end of match - -Removed limit of matching only up to 32767 times with *, \+, etc. - -Added support to match multi-byte characters. (partly by Muraoka Taro) -Made "\<" and "\>" work for UTF-8. (Muraoka Taro) - - -UTF-8 support *new-utf-8* -------------- - -Vim can now edit files in UTF-8 encoding. Up to 31 bit characters can be -used, but only 16 bit characters are displayed. Up to two combining -characters are supported, they overprint the preceding character. -Double-wide characters are also supported. See |UTF-8|. - -UCS-2, UCS-4 and UTF-16 encodings are supported too, they are converted to -UTF-8 internally. There is also support for editing Unicode files in a Latin1 -environment. Other encodings are converted with iconv() or an external -converter specified with 'charconvert'. - -Many new items for Multi-byte support: -- Added 'encoding' option: specifies character encoding used inside Vim. It - can be any 8-bit encoding, some double-byte encodings or Unicode. - It is initialized from the environment when a supported value is found. -- Added 'fileencoding' and 'fileencodings': specify character coding in a - file, similar to 'fileformat' and 'fileformats'. - When 'encoding' is "utf-8" and 'fileencodings' is "utf-8,latin1" this will - automatically switch to latin1 if a file does not contain valid UTF-8. -- Added 'bomb' option and detection of a BOM at the start of a file. Can be - used with "ucs-bom" in 'fileencodings' to automatically detect a Unicode - file if it starts with a BOM. Especially useful on MS-Windows (NT and - 2000), which uses ucs-2le files with a BOM (e.g., when exporting the - registry). -- Added the 'termencoding' option: Specifies the encoding used for the - terminal. Useful to put Vim in utf-8 mode while in a non-Unicode locale: > - :let &termencoding = &encoding - :set encoding=utf-8 -- When 'viminfo' contains the 'c' flag, the viminfo file is converted from the - 'encoding' it was written with to the current 'encoding'. -- Added ":scriptencoding" command: convert lines in a sourced script to - 'encoding'. Useful for menu files. -- Added 'guifontwide' to specify a font for double-wide characters. -- Added Korean support for character class detection. Also fix cls() in - search.c. (Chong-Dae Park) -- Win32: Typing multi-byte characters without IME. (Alexander Smishlajev) -- Win32 with Mingw: compile with iconv library. (Ron Aaron) -- Win32 with MSVC: dynamically load iconv.dll library. (Muraoka Taro) -- Make it possible to build a version with multi-byte and iconv support with - Borland 5.5. (Yasuhiro Matsumoto) -- Added 'delcombine' option: Delete combining character separately. (Ron - Aaron) -- The "xfontset" feature isn't required for "xim". These are now two - independent features. -- XIM: enable XIM when typing a language character (Insert mode, Search - pattern, "f" or "r" command). Disable XIM when typing a Normal mode - command. -- When the XIM is active, show "XIM" in the 'showmode' message. (Nam SungHyun) -- Support "CursorIM" for XIM. (Nam SungHyun) -- Added 'm' flag to 'formatoptions': When wrapping words, allow splitting at - each multibyte character, not only at a space. -- Made ":syntax keyword" work with multi-byte characters. -- Added support for Unicode upper/lowercase flipping and comparing. (based on - patch by Raphael Finkel) - Let "~" on multi-byte characters that have a third case ("title case") - switch between the three cases. (Raphael Finkel) - -Allow defining digraphs for multi-byte characters. -Added RFC1345 digraphs for Unicode. -Most Normal mode commands that accept a character argument, like "r", "t" and -"f" now accept a digraph. The 'D' flag in 'cpoptions' disables this to remain -Vi compatible. - -Added Language mapping and 'keymap' to be able to type multi-byte characters: -- Added the ":lmap" command and friends: Define mappings that are used when - typing characters in the language of the text. Also for "r", "t", etc. In - Insert and Command-line mode CTRL-^ switches the use of the mappings on/off. - CTRL-^ also toggles the use of an input method when no language mappings are - present. Allows switching the IM back on halfway typing. -- "<char-123>" argument to ":map", allows to specify the decimal, octal or - hexadecimal value of a character. -- Implemented the 'keymap' option: Load a keymap file. Uses ":lnoremap" to - define mappings for the keymap. The new ":loadkeymap" command is used in - the keymap file. -- Added 'k' flag in 'statusline': Value of "b:keymap_name" or 'keymap' when - it's being used. Uses "<lang>" when no keymap is loaded and ":lmap"s are - active. Show this text in the default statusline too. -- Added the 'iminsert' and 'imsearch' options: Specify use of langmap mappings - and Input Method with an option. (Muraoka Taro) - Added 'imcmdline' option: When set the input method is always enabled when - starting to edit a command line. Useful for a XIM that uses dead keys to - type accented characters. - Added 'imactivatekey' option to better control XIM. (Muraoka Taro) -- When typing a mapping that's not finished yet, display the last character - under the cursor in Insert mode and Command-line mode. Looks good for dead - characters. -- Made the 'langmap' option recognize multi-byte characters. But mapping only - works for 8-bit characters. Helps when using UTF-8. -- Use a different cursor for when ":lmap" mappings are active. Can specify - two highlight groups for an item in 'guicursor'. By default "lCursor" and - "Cursor" are equal, the user must set a color he likes. - Use the cursor color for hangul input as well. (Sung-Hyun Nam) -- Show "(lang)" for 'showmode' when language mapping is enabled. -- UTF-8: Made "r" work with a ":lmap" that includes a composing character. - Also works for "f", which now works to find a character that includes a - composing character. - -Other multi-byte character additions: -- Support double-byte single-width characters for euc-jp: Characters starting - with 0x8E. Added ScreenLines2[] to store the second byte. - - -Multi-language support *new-multi-lang* ----------------------- - -The messages used in Vim can be translated. Several translations are -available. This uses the gettext mechanism. It allows adding a translation -without recompiling Vim. |multi-lang| (partly by Marcin Dalecki) - -The translation files are in the src/po directory. The src/po/README.txt file -explains a few things about doing a translation. - -Menu translations are available as well. This uses the new |:menutranslate| -command. The translations are found in the runtime directory "lang". This -allows a user to add a translation. - -Added |:language| command to set the language (locale) for messages, time and -character type. This allows switching languages in Vim without changing the -locale outside of Vim. - -Made it possible to have vimtutor use different languages. (Eduardo Fernandez) -Spanish (Eduardo Fernandez), Italian (Antonio Colombo), Japanese (Yasuhiro -Matsumoto) and French (Adrien Beau) translations are included. -Added "vimtutor.bat": script to start Vim on a copy of the tutor file for -MS-Windows. (Dan Sharp) - -- Added v:lang variable to be able to get current language setting. - (Marcin Dalecki) Also v:lc_time and v:ctype. -- Make it possible to translate the dialogs used by the menus. Uses global - "menutrans_" variables. ":menutrans clear" deletes them. -- removed "broken locale" (Marcin Dalecki). -- Don't use color names in icons, use RGB values. The names could be - translated. -- Win32: Added global IME support (Muraoka) -- Win32: Added dynamic loading of IME support. -- ":messages" prints a message about who maintains the messages or the - translations. Useful to find out where to make a remark about a wrong - translation. -- --disable-nls argument for configure: Disable use of gettext(). (Sung-Hyun - Nam) -- Added NLS support for Win32 with the MingW compiler. (Eduardo Fernandez) -- When available, call bind_textdomain_codeset() to have gettext() translate - messages to 'encoding'. This requires GNU gettext 0.10.36 or later. -- Added gettext support for Win32. This means messages will be translated - when the locale is set and libintl.dll can be found. (Muraoka Taro) - Also made it work with MingW compiler. (Eduardo Fernandez) - Detect the language and set $LANG to get the appropriate translated messages - (if supported). Also use $LANG to select a language, v:lang is a very - different kind of name. -- Made gvimext.dll use translated messages, if possible. (Yasuhiro Matsumoto) - - -Plugin support *new-plugins* --------------- - -To make it really easy to load a Vim script when starting Vim, the "plugin" -runtime directory can be used. All "*.vim" files in it will be automatically -loaded. For Unix, the directory "~/.vim/plugin" is used by default. The -'runtimepath' option can be set to look in other directories for plugins. -|load-plugins| |add-plugin| - -The |:runtime| command has been added to load one or more files in -'runtimepath'. - -Standard plugins: -netrw.vim - Edit files over a network |new-network-files| -gzip.vim - Edit compressed files -explorer.vim - Browse directories |new-file-browser| - -Added support for local help files. |add-local-help|. -When searching for help tags, all "doc/tags" files in 'runtimepath' are used. -Added the ":helptags" command: Generate a tags file for a help directory. -The first line of each help file is automagically added to the "LOCAL -ADDITIONS" section in doc/help.txt. - -Added the <unique> argument to ":map": only add a mapping when it wasn't -defined before. - -When displaying an option value with 'verbose' set will give a message about -where the option was last set. Very useful to find out which script did set -the value. - -The new |:scriptnames| command displays a list of all scripts that have been -sourced. - -GUI: For Athena, Motif and GTK look for a toolbar bitmap in the "bitmaps" -directories in 'runtimepath'. Allows adding your own bitmaps. - - -Filetype plugins *new-filetype-plugins* ------------------ - -A new group of files has been added to do settings for specific file types. -These can be options and mappings which are specifically used for one value of -'filetype'. - -The files are located in "$VIMRUNTIME/ftplugin". The 'runtimepath' option -makes it possible to use several sets of plugins: Your own, system-wide, -included in the Vim distribution, etc. - -To be able to make this work, several features were added: -- Added the "s:" variables, local to a script. Avoids name conflicts with - global variables. They can be used in the script and in functions, - autocommands and user commands defined in the script. They are kept between - invocations of the same script. |s:var| -- Added the global value for local options. This value is used when opening - a new buffer or editing another file. The option value specified in a - modeline or filetype setting is not carried over to another buffer. - ":set" sets both the local and the global value. - ":setlocal" sets the local option value only. - ":setglobal" sets or displays the global value for a local option. - ":setlocal name<" sets a local option to its global value. -- Added the buffer-local value for some global options: 'equalprg', 'makeprg', - 'errorformat', 'grepprg', 'path', 'dictionary', 'thesaurus', 'tags', - 'include' and 'define'. This allows setting a local value for these global - options, without making it incompatible. -- Added mappings and abbreviations local to a buffer: ":map <buffer>". -- In a mapping "<Leader>" can be used to get the value of the "mapleader" - variable. This simplifies mappings that use "mapleader". "<Leader>" - defaults to "\". "<LocalLeader>" does the same with "maplocalleader". This - is to be used for mappings local to a buffer. -- Added <SID> Script ID to define functions and mappings local to a script. -- Added <script> argument to ":noremap" and ":noremenu": Only remap - script-local mappings. Avoids that mappings from other scripts get in the - way, but does allow using mappings defined in the script. -- User commands can be local to a buffer: ":command -buffer". - -The new ":setfiletype" command is used in the filetype detection autocommands, -to avoid that 'filetype' is set twice. - - -File browser *new-file-browser* ------------- - -When editing a directory, the explorer plugin will list the files in the -directory. Pressing <Enter> on a file name edits that file. Pressing <Enter> -on a directory moves the browser to that directory. - -There are several other possibilities, such as opening a file in the preview -window, renaming files and deleting files. - - -Editing files over a network *new-network-files* ----------------------------- - -Files starting with scp://, rcp://, ftp:// and http:// are recognized as -remote files. An attempt is made to access these files with the indicated -method. For http:// only reading is possible, for the others writing is also -supported. Uses the netrw.vim script as a standard "plugin". |netrw| - -Made "gf" work on a URL. It no longer assumes the file is local on the -computer (mostly didn't work anyway, because the full path was required). -Adjusted test2 for this. - -Allow using a URL in 'path'. Makes ":find index.html" work. - -GTK: Allow dropping a http:// and ftp:// URL on Vim. The netrw plugin takes -care of downloading the file. (MiKael Berthe) - - -Window for command-line editing *new-cmdwin* -------------------------------- - -The Command-line window can be used to edit a command-line with Normal and -Insert mode commands. When it is opened it contains the history. This allows -copying parts of previous command lines. |cmdwin| - -The command-line window can be opened from the command-line with the key -specified by the 'cedit' option (like Nvi). It can also be opened directly -from Normal mode with "q:", "q/" and "q?". - -The 'cmdwinheight' is used to specify the initial height of the window. - -In Insert mode CTRL-X CTRL-V can be used to complete an Ex command line, like -it's done on the command-line. This is also useful for writing Vim scripts! - -Additionally, there is "improved Ex mode". Entered when Vim is started as -"exim" or "vim -E", and with the "gQ" command. Works like repeated use of -":", with full command-line editing and completion. (Ulf Carlsson) - - -Debugging mode *new-debug-mode* --------------- - -In debugging mode sourced scripts and user functions can be executed line by -line. There are commands to step over a command or step into it. |debug-mode| - -Breakpoints can be set to run until a certain line in a script or user -function is executed. |:breakadd| - -Debugging can be started with ":debug {cmd}" to debug what happens when a -command executes. The |-D| argument can be used to debug while starting up. - - -Cursor in virtual position *new-virtedit* --------------------------- - -Added the 'virtualedit' option: Allow positioning the cursor where there is no -actual character in Insert mode, Visual mode or always. (Matthias Kramm) -This is especially useful in Visual-block mode. It allows positioning a -corner of the area where there is no text character. (Many improvements by -Chase Tingley) - - -Debugger interface *new-debug-itf* ------------------- - -This was originally made to work with Sun Visual Workshop. (Gordon Prieur) -See |debugger.txt|, |sign.txt| and |workshop.txt|. - -Added the ":sign" command to define and place signs. They can be displayed -with two ASCII characters or an icon. The line after it can be highlighted. -Useful to display breakpoints and the current PC position. - -Added the |:wsverb| command to execute debugger commands. - -Added balloon stuff: 'balloondelay' and 'ballooneval' options. - -Added "icon=" argument for ":menu". Allows defining a specific icon for a -ToolBar item. - - -Communication between Vims *new-vim-server* --------------------------- - -Added communication between two Vims. Makes it possible to send commands from -one Vim to another. Works for X-Windows and MS-Windows |clientserver|. - -Use "--remote" to have files be edited in an already running Vim. -Use "--remote-wait" to do the same and wait for the editing to finish. -Use "--remote-send" to send commands from one Vim to another. -Use "--remote-expr" to have an expression evaluated in another Vim. -Use "--serverlist" to list the currently available Vim servers. (X only) -There are also functions to communicate between the server and the client. -|remote_send()| |remote_expr()| - -(X-windows version implemented by Flemming Madsen, MS-Windows version by Paul -Moore) - -Added the command server name to the window title, so you can see which server -name belongs to which Vim. - -Removed the OleVim directory and SendToVim.exe and EditWithVim.exe from the -distribution. Can now use "gvim --remote" and "gvim --remote-send", which is -portable. - -GTK+: Support running Vim inside another window. Uses the --socketid argument -(Neil Bird) - - -Buffer type options *new-buftype* -------------------- - -The 'buftype' and 'bufhidden' options have been added. They can be set to -have different kinds of buffers. For example: -- 'buftype' = "quickfix": buffer with error list -- 'buftype' = "nofile" and 'bufhidden' = "delete": scratch buffer that will be - deleted as soon as there is no window displaying it. - -'bufhidden' can be used to overrule the 'hidden' option for one buffer. - -In combination with 'buflisted' and 'swapfile' this offers the possibility to -use various kinds of special buffers. See |special-buffers|. - - -Printing *new-printing* --------- - -Included first implementation of the ":hardcopy" command for printing -to paper. For MS-Windows any installed printer can be used. For other -systems a PostScript file is generated, which can be printed with the -'printexpr' option. -(MS-Windows part by Vince Negri, Vipin Aravind, PostScript by Vince Negri and -Mike Williams) - -Made ":hardcopy" work with multi-byte characters. (Muraoka Taro, Yasuhiro -Matsumoto) - -Added options to tune the way printing works: (Vince Negri) -- 'printoptions' defines various things. -- 'printheader' specifies the header format. Added "N" field to 'statusline' - for the page number. -- 'printfont' specifies the font name and attributes. -- 'printdevice' defines the default printer for ":hardcopy!". - - -Ports *ports-6* ------ - -Port to OS/390 Unix (Ralf Schandl) -- A lot of changes to handle EBCDIC encoding. -- Changed Ctrl('x') to Ctrl_x define. - -Included jsbmouse support. (Darren Garth) -Support for dec mouse in Unix. (Steve Wall) - -Port to 16-bit MS Windows (Windows 3.1x) (Vince Negri) - -Port to QNX. Supports the Photon GUI, mouse, etc. (Julian Kinraid) - -Allow cross-compiling the Win32 version with Make_ming.mak. (Ron Aaron) -Added Python support for compiling with Mingw. (Ron Aaron) - -Dos 32 bit: Added support the Windows clipboard. (David Kotchan) - -Win32: Dynamically load Perl and Python. Allows compiling Vim with these -interfaces and will try to find the DLLs at runtime. (Muraoka Taro) - -Compiling the Win32 GUI with Cygwin. Also compile vimrun, dosinst and -uninstall. (Gerfried) - -Mac: Make Vim compile with the free MPW compiler supplied by Apple. And -updates for CodeWarrior. (Axel Kielhorn) - -Added typecasts and ifdefs as a start to make Vim work on Win64 (George -Reilly) - - -Quickfix extended *quickfix-6* ------------------ - -Added the "error window". It contains all the errors of the current error -list. Pressing <Enter> in a line makes Vim jump to that line (in another -window). This makes it easy to navigate through the error list. -|quickfix-window|. - -- |:copen| opens the quickfix window. -- |:cclose| closes the quickfix window. -- |:cwindow| takes care that there is a quickfix window only when there are - recognized errors. (Dan Sharp) - -- Quickfix also knows "info", next to "warning" and "error" types. "%I" can be - used for the start of a multi-line informational message. (Tony Leneis) -- The "%p" argument can be used in 'errorformat' to get the column number from - a line where "^" points to the column. (Stefan Roemer) -- When using "%f" in 'errorformat' on a DOS/Windows system, also include "c:" - in the filename, even when using "%f:". - - -Operator modifiers *new-operator-mod* ------------------- - -Insert "v", "V" or CTRL-V between an operator and a motion command to force -the operator to work characterwise, linewise or blockwise. |o_v| - - -Search Path *new-search-path* ------------ - -Vim can search in a directory tree not only in downwards but also upwards. -Works for the 'path', 'cdpath' and 'tags' options. (Ralf Schandl) - -Also use "**" for 'tags' option. (Ralf Schandl) - -Added 'includeexpr', can be used to modify file name found by 'include' -option. -Also use 'includeexpr' for "gf" and "<cfile>" when the file can't be found -without modification. Useful for doing "gf" on the name after an include or -import statement. - -Added the 'cdpath' option: Locations to find a ":cd" argument. (Raf) - -Added the 'suffixesadd' option: Suffixes to be added to a file name when -searching for a file for the "gf", "[I", etc. commands. - - -Writing files improved *new-file-writing* ----------------------- - -Added the 'backupcopy' option: Select whether a file is to be copied or -renamed to make a backup file. Useful on Unix to speed up writing an ordinary -file. Useful on other systems to preserve file attributes and when editing a -file on a Unix filesystem. - -Added the 'autowriteall' option. Works like 'autowrite' but for more -commands. - -Added the 'backupskip' option: A list of file patterns to skip making a backup -file when it matches. The default for Unix includes "/tmp/*", this makes -"crontab -e" work. - -Added support for Access Control Lists (ACL) for FreeBSD and Win32. The ACL -is copied from the original file to the new file (or the backup if it's -copied). -ACL is also supported for AIX, Solaris and generic POSIX. (Tomas Ogren) -And on SGI. - - -Argument list *new-argument-list* -------------- - -The support for the argument list has been extended. It can now be -manipulated to contain the files you want it to contain. - -The argument list can now be local to a window. It is created with the -|:arglocal| command. The |:argglobal| command can be used to go back to the -global argument list. - -The |:argdo| command executes a command on all files in the argument list. - -File names can be added to the argument list with |:argadd|. File names can -be removed with |:argdelete|. - -"##" can be used like "#", it is replaced by all the names in the argument -list concatenated. Useful for ":grep foo ##". - -The |:argedit| adds a file to the argument list and edits it. Like ":argadd" -and then ":edit". - - -Restore a View *new-View* --------------- - -The ":mkview" command writes a Vim script with the settings and mappings for -one window. When the created file is sourced, the view of the window is -restored. It's like ":mksession" for one window. -The View also contains the local argument list and manually created, opened -and closed folds. - -Added the ":loadview" command and the 'viewdir' option: Allows for saving and -restoring views of a file with simple commands. ":mkview 1" saves view 1 for -the current file, ":loadview 1" loads it again. Also allows quickly switching -between two views on one file. And saving and restoring manual folds and the -folding state. - -Added 'viewoptions' to specify how ":mkview" works. - -":mksession" now also works fine with vertical splits. It has been further -improved and restores the view of each window. It also works properly with -preview and quickfix windows. - -'sessionoptions' is used for ":mkview" as well. -Added "curdir" and "sesdir" to 'sessionoptions'. Allows selection of what -the current directory will be restored to. - -The session file now also contains the argument list(s). - - -Color schemes *new-color-schemes* -------------- - -Support for loading a color scheme. Added the ":colorscheme" command. -Automatically add menu entries for available schemes. -Should now properly reset the colors when 'background' or 't_Co' is changed. -":highlight clear" sets the default colors again. -":syntax reset" sets the syntax highlight colors back to the defaults. -For ":set bg&" guess the value. This allows a color scheme to switch back to -the default colors. -When syntax highlighting is switched on and a color scheme was defined, reload -the color scheme to define the colors. - - -Various new items *new-items-6* ------------------ - -Normal mode commands: ~ - -"gi" Jump to the ^ mark and start Insert mode. Also works when the - mark is just after the line. |gi| - -"g'm" and "g`m" - Jump to a mark without changing the jumplist. Now you can use - g`" to jump to the last known position in a file without side - effects. Also useful in mappings. - -[', [`, ]' and ]` - move the cursor to the next/previous lowercase mark. - -g_ Go to last non-blank in line. (Steve Wall) - - -Options: ~ - -'autoread' When detected that a file changed outside of Vim, - automatically read a buffer again when it's not changed. - It has a global and a local value. Use ":setlocal autoread<" - to go back to using the global value for 'autoread'. - -'debug' When set to "msg" it will print error messages that would - otherwise be omitted. Useful for debugging 'indentexpr' and - 'foldexpr'. - -'lispwords' List of words used for lisp indenting. It was previously hard - coded. Added a number of Lisp names to the default. - -'fold...' Many new options for folding. - -'modifiable' When off, it is impossible to make changes to a buffer. - The %m and %M items in 'statusline' show a '-'. - -'previewwindow' Set in the preview window. Used in a session file to mark a - window as the preview window. - -'printfont' -'printexpr' -'printheader' -'printdevice' -'printoptions' for ":hardcopy". - -'buflisted' Makes a buffer appear in the buffer list or not. - -Use "vim{version}:" for modelines, only to be executed when the version is ->= {version}. Also "vim>{version}", "vim<{version}" and "vim={version}". - - -Ex commands: ~ - -:sav[eas][!] {file} - Works like ":w file" and ":e #", but without loading the file - again and avoiding other side effects. |:saveas| - -:silent[!] {cmd} - Execute a command silently. Also don't use a delay that would - come after the message. And don't do 'showmatch'. - RISCOS: Removed that "!~cmd" didn't output anything, and - didn't wait for <Enter> afterwards. Can use ":silent !cmd" - now. -:menu <silent> Add a menu that won't echo Ex commands. -:map <silent> Add a mapping that won't echo Ex commands. - -:checktime Check for changed buffers. - -:verbose {cmd} Set 'verbose' for one command. - -:echomsg {expr} -:echoerr {expr} Like ":echo" but store the message in the history. (Mark - Waggoner) - -:grepadd Works just like ":grep" but adds to the current error list - instead of defining a new list. |:grepadd| - -:finish Finish sourcing a file. Can be used to skip the rest of a Vim - script. |:finish| - -:leftabove -:aboveleft Split left/above current window. - -:rightbelow -:belowright Split right/below current window. - -:first, :bfirst, :ptfirst, etc. - Alias for ":rewind". It's more logical compared to ":last". - -:enew Edit a new, unnamed buffer. This is needed, because ":edit" - re-edits the same file. (Wall) - -:quitall Same as ":qall". - -:match Define match highlighting local to a window. Allows - highlighting an item in the current window without interfering - with syntax highlighting. - -:menu enable -:menu disable Commands to enable/disable menu entries without removing them. - (Monish Shah) - -:windo Execute a command in all windows. -:bufdo Execute a command in all buffers. - -:wincmd Window (CTRL-W) command. Useful when a Normal mode command - can't be used (e.g., for a CursorHold autocommand). See - |CursorHold-example| for a nice application with it. - -:lcd and :lchdir - Set local directory for a window. (Benjie Chen) - -:hide {command} - Execute {command} with 'hidden' set. - -:emenu in Visual mode to execute a ":vmenu" entry. - -:popup Pop up a popup menu. - -:redraw Redraw the screen even when busy with a script or function. - -:hardcopy Print to paper. - -:compiler Load a Vim script to do settings for a specific compiler. - -:z# List numbered lines. (Bohdan Vlasyuk) - - -New marks: ~ - -'( and ') Begin or end of current sentence. Useful in Ex commands. -'{ and '} Begin or end of current paragraph. Useful in Ex commands. -'. Position of the last change in the current buffer. -'^ Position where Insert mode was stopped. - -Store the ^ and . marks in the viminfo file. Makes it possible to jump to the -last insert position or changed text. - - -New functions: ~ -argidx() Current index in argument list. -buflisted() Checks if the buffer exists and has 'buflisted' set. -cindent() Get indent according to 'cindent'. -eventhandler() Returns 1 when inside an event handler and interactive - commands can't be used. -executable() Checks if a program or batch script can be executed. -filewritable() Checks if a file can be written. (Ron Aaron) -foldclosed() Find out if there is a closed fold. (Johannes Zellner). -foldcloseend() Find the end of a closed fold. -foldlevel() Find out the foldlevel. (Johannes Zellner) -foreground() Move the GUI window to the foreground. -getchar() Get one character from the user. Can be used to define a - mapping that takes an argument. -getcharmod() Get last used key modifier. -getbufvar() gets the value of an option or local variable in a buffer (Ron - Aaron) -getfsize() Return the size of a file. -getwinvar() gets the value of an option or local variable in a window (Ron - Aaron) -globpath() Find matching files in a list of directories. -hasmapto() Detect if a mapping to a string is already present. -iconv() Convert a string from one encoding to another. -indent() gets the indent of a line (Ron Aaron) -inputdialog() Like input() but use a GUI dialog when possible. Currently - only works for Win32, Motif, Athena and GTK. - Use inputdialog() for the Edit/Settings/Text Width menu. Also - for the Help/Find.. and Toolbar FindHelp items. - (Win32 support by Thore B. Karlsen) - (Win16 support by Vince Negri) -inputsecret() Ask the user to type a string without showing the typed keys. - (Charles Campbell) -libcall() for Unix (Neil Bird, Johannes Zellner, Stephen Wall) -libcallnr() for Win32 and Unix -lispindent() Get indent according to 'lisp'. -mode() Return a string that indicates the current mode. -nextnonblank() Skip blank lines forwards. -prevnonblank() Skip blank lines backwards. Useful to for indent scripts. -resolve() MS-Windows: resolve a shortcut to the file it points to. - Unix: resolve a symbolic link. -search() Search for a pattern. -searchpair() Search for matching pair. Can be used in indent files to find - the "if" matching an endif. -setbufvar() sets an option or variable local to a buffer (Ron Aaron) -setwinvar() sets an option or variable local to a window (Ron Aaron) -stridx() Search for first occurrence of one string in another. -strridx() Search for last occurrence of one string in another. -tolower() Convert string to all-lowercase. -toupper() Convert string to all-uppercase. -type() Check the type of an expression. -wincol() window column of the cursor -winwidth() Width of a window. (Johannes Zellner) -winline() window line of the cursor - - -Added expansion of curly braces in variable and function names. This can be -used for variable names that include the value of an option. Or a primitive -form of arrays. (Vince Negri) - - -New autocommand events: ~ -BufWinEnter Triggered when a buffer is displayed in a window, after using - the modelines. Can be used to load a view. -BufWinLeave Triggered when a buffer is no longer in a window. Also - triggered when exiting Vim. Can be used to save views. -FileChangedRO Triggered before making the first change to a read-only file. - Can be used to check-out the file. (Scott Graham) -TermResponse Triggered when the terminal replies to the version-request. - The v:termresponse internal variable holds the result. Can be - used to react to the version of the terminal. (Ronald Schild) -FileReadCmd Triggered before reading a file. -BufReadCmd Triggered before reading a file into a buffer. -FileWriteCmd Triggered before writing a file. -BufWriteCmd Triggered before writing a buffer into a file. -FileAppendCmd Triggered before appending to a file. -FuncUndefined Triggered when a user function is not defined. (Ron Aaron) - -The autocommands for the *Cmd events read or write the file instead of normal -file read/write. Use this in netrw.vim to be able to edit files on a remote -system. (Charles Campbell) - - -New Syntax files: ~ - -bdf BDF font definition (Nikolai Weibull) -catalog SGML catalog (Johannes Zellner) -debchangelog Debian Changelog (Wichert Akkerman) -debcontrol Debian Control (Wichert Akkerman) -dot dot (Markus Mottl) -dsl DSSSL syntax (Johannes Zellner) -eterm Eterm configuration (Nikolai Weibull) -indent Indent profile (Nikolai Weibull) -lftp LFTP (Nikolai Weibull) -lynx Lynx config (Doug Kearns) -mush mush sourcecode (Bek Oberin) -natural Natural (Marko Leipert) -pilrc Pal resource compiler (Brian Schau) -plm PL/M (Philippe Coulonges) -povini Povray configuration (David Necas) -ratpoison Ratpoison config/command (Doug Kearns) -readline readline config (Nikolai Weibull) -screen Screen RC (Nikolai Weibull) -specman Specman (Or Freund) -sqlforms SQL*Forms (Austin Ziegler) -terminfo terminfo (Nikolai Weibull) -tidy Tidy configuration (Doug Kearns) -wget Wget configuration (Doug Kearns) - - -Updated many syntax files to work both with Vim 5.7 and 6.0. - -Interface to Ruby. (Shugo Maeda) -Support dynamic loading of the Ruby interface on MS-Windows. (Muraoka Taro) -Support this for Mingw too. (Benoit Cerrina) - -Win32: Added possibility to load TCL dynamically. (Muraoka Taro) -Also for Borland 5.5. (Dan Sharp) - -Win32: When editing a file that is a shortcut (*.lnk file), edit the file it -links to. Unless 'binary' is set, then edit the shortcut file itself. -(Yasuhiro Matsumoto) - -The ":command" command now accepts a "-bar" argument. This allows the user -command to be followed by "| command". - -The preview window is now also used by these commands: -- |:pedit| edits the specified file in the preview window -- |:psearch| searches for a word in included files, like |:ijump|, and - displays the found text in the preview window. -Added the CTRL-W P command: go to preview window. - -MS-DOS and MS-Windows also read the system-wide vimrc file $VIM/vimrc. Mostly -for NT systems with multiple users. - -A double-click of the mouse on a character that has a "%" match selects from -that character to the match. Similar to "v%". - -"-S session.vim" argument: Source a script file when starting up. Convenient -way to start Vim with a session file. - -Added "--cmd {command}" Vim argument to execute a command before a vimrc file -is loaded. (Vince Negri) - -Added the "-M" Vim argument: reset 'modifiable' and 'write', thus disallow -making changes and writing files. - -Added runtime/delmenu.vim. Source this to remove all menus and prepare for -loading new menus. Useful when changing 'langmenu'. - -Perl script to filter Perl error messages to quickfix usable format. (Joerg -Ziefle) - -Added runtime/macros/less.vim: Vim script to simulate less, but with syntax -highlighting. - -MS-Windows install program: (Jon Merz) -- The Win32 program can now create shortcuts on the desktop and install Vim in - the Start menu. -- Possibly remove old "Edit with Vim" entries. -- The Vim executable is never moved or $PATH changed. A small batch file is - created in a directory in $PATH. Fewer choices to be made. -- Detect already installed Vim versions and offer to uninstall them first. - -Improved the MS-Windows uninstal program. It now also deletes the entries in -the Start menu, icons from the desktop and the created batch files. (Jon Merz) -Also made it possible to delete only some of these. Also unregister gvim for -OLE. - -Generate a self-installing Vim package for MS-Windows. This uses NSIS. (Jon -Merz et al.) - -Added ":filetype detect". Try detecting the filetype again. Helps when -writing a new shell script, after adding "#!/bin/csh". - -Added ":augroup! name" to delete an autocommand group. Needed for the -client-server "--remote-wait". - -Add the Vim version number to the viminfo file, useful for debugging. - -============================================================================== -IMPROVEMENTS *improvements-6* - -Added the 'n' flag in 'cpoptions': When omitted text of wrapped lines is not -put between line numbers from 'number' option. Makes it a lot easier to read -wrapped lines. - -When there is a format error in a tags file, the byte position is reported so -that the error can be located. - -"gf" works in Visual mode: Use the selected text as the file name. (Chase -Tingley) - -Allow ambiguous mappings. Thus "aa" and "aaa" can both be mapped, the longest -matching one is used. Especially useful for ":lmap" and 'keymap'. - -Encryption: Ask the key to be typed twice when crypting the first time. -Otherwise a typo might cause the text to be lost forever. (Chase Tingley) - -The window title now has "VIM" on the end. The file name comes first, useful -in the taskbar. A "+" is added when the file is modified. "=" is added for -a read-only file. "-" is added for a file with 'modifiable' off. - -In Visual mode, mention the size of the selected area in the 'showcmd' -position. - -Added the "b:changedtick" variable. Incremented at each change, also for -undo. Can be used to take action only if the buffer has been changed. - -In the replacement string of a ":s" command "\=" can be used to replace with -the result of an expression. From this expression the submatch() function can -be used to access submatches. - -When doing ":qall" and there is a change in a buffer that is being edited in -another window, jump to that window, instead of editing that buffer in the -current window. - -Added the "++enc=" and "++ff=" arguments to file read/write commands to force -using the given 'encoding' or 'fileformat'. And added the "v:cmdarg" -variable, to be used for FileReadCmd autocommands that read/write the file -themselves. - -When reading stdin, first read the text in binary mode and then re-read it -with automatic selection of 'fileformat' and 'fileencoding'. This avoids -problems with not being able to rewind the file (e.g., when a line near the -end of the file ends in LF instead of CR-LF). -When reading text from stdin and the buffer is empty, don't mark it changed. -Allows exiting without trouble. - -Added an ID to many error messages. This will make it easier to find help for -a message. - -Insert mode: -- "CTRL-G j" and "CTRL-G k" can be used to insert in another line in the same - column. Useful for editing a table. -- Added Thesaurus completion with CTRL-X CTRL-T. (Vince Negri) -- Added the 'thesaurus' option, to use instead of 'dictionary' for thesaurus - completion. Added the 's' flag in 'complete'. -- Made CTRL-X CTRL-L in Insert mode use the 'complete' option. It now also - scans other loaded buffers for matching lines. -- CTRL-R now also works in Insert mode while doing completion with CTRL-X or - CTRL-N. (Neil Bird) -- When doing Insert mode completion, when completion is finished check for a - match with words from 'cinkeys' or 'indentkeys'. - -Performance: -- Made display updating more efficient. Insert/delete lines may be used for - all changes, also for undo/redo. -- The display is not redrawn when there is typeahead in Insert mode. Speeds - up CTRL-R a lot. -- Improved speed of screen output for 32 bit DOS version. (Vince Negri) -- When dragging with the mouse, there is a lookahead to skip mouse codes when - there is another one next. Makes dragging with the mouse a lot faster. -- Also a memory usage improvement: When calling u_save with a single line, - don't save it if the line was recently saved for the same undo already. -- When using a script that appends one character at a time, the amount of - allocated memory was growing steadily. Also when 'undolevels' is -1. - Caused by the line saved for "U" never to be freed. Now free an undo block - when it becomes empty. -- GUI and Dos32: Use a vertical scroll region, to make scrolling in a - vertically split window faster. No need to redraw the whole window. -- When scrolling isn't possible with terminal codes (e.g., for a vertically - split window) redraw from ScreenLines[]. That should be faster than going - through the lines with win_line(), especially when using syntax - highlighting. -- The Syntax menu is now pre-generated by a separate script. Makes loading - the menu 70% faster. This can halve the startup time of gvim. -- When doing ":help tag", don't open help.txt first, jump directly to the help - tag. It's faster and avoids an extra message. -- Win32: When a file name doesn't end in ".lnk" don't try resolving a - shortcut, it takes quite a bit of time. -- Don't update the mouse pointer shape while there are typeahead characters. -- Change META[] from a string into an array, avoids using strchr() on it. -- Don't clear the command line when adding characters, avoids that screen_fill - is called but doesn't do anything. - -Robustness: -- Unix: Check for running out of stack space when executing a regexp. Avoids - a nasty crash. Only works when the system supports running the signal - function on another stack. -- Disallow ":source <dirname>". On unix it's possible to read a directory, - does not make sense to use it as Vim commands. - -Security: -- When reading from or writing to a temporary file, check that it isn't a - symbolic link. Gives some protection against symlink attacks. -- When creating a backup file copy or a swap file, check for it already - existing to avoid a symlink attack. (Colin Phipps) -- Evaluating options which are an expression is done in a |sandbox|. If the - option was set by a modeline, it cannot cause damage. -- Use a secure way to generate temp file names: Create a private directory for - temp files. Used for Unix, MS-DOS and OS/2. -- 'makeef' can be empty, which means that an internally generated file name is - used. The old default was "/tmp/file", which is a security risk. - Writing 'makeef' in the current directory fails in a read-only directory and - causes trouble when using ":grep" on all files. Made the default empty for - all systems, so that a temp file is used. -- The command from a tags file is executed in the sandbox for better security. -- The Ruby, Tcl and Python interfaces cannot be used from the sandbox. They - might do dangerous things. Perl is still possible, but limited to the Safe - environment. (Donnie Smith) - -Syntax highlighting: -- Optimized the speed by caching the state stack all over the file, not just - the part being displayed. Required for folding. -- Added ":syntax sync fromstart": Always parse from the start of the file. -- Added the "display" argument for syntax items: use the item only when - displaying the result. Can make parsing faster for text that isn't going to - be displayed. -- When using CTRL-L, the cached states are deleted, to force parsing the text - again. -- Use elfhash algorithm for table of keywords. This should give a better - distribution and speedup keyword lookup. (Campbell) -- Also allow the "lc" leading context for skip and end patterns. (Scott - Bigham) -- Syntax items can have the "extend" argument to undo the effect of a - "keepend" argument of an item it is contained in. Makes it possible to have - some contained items extend a region while others don't. -- ":syntax clear" now deletes the b:current_syntax variable. That's logical, - since no syntax is defined after this command. -- Added ":syntax enable": switch on syntax highlighting without changing the - colors. This allows specifying the colors in the .vimrc file without the - need for a mysyntaxfile. -- Added ":syntax reset": reset the colors to their defaults. -- Added the "contains=TOP" and "contains=CONTAINED" arguments. Makes it - possible to define a transparent item that doesn't contain itself. -- Added a "containedin" argument to syntax items. Allows adding a contained - item to an existing item (e.g., to highlight a name in a comment). - -Modeless selection: -- When in the command-line window, use modeless selection in the other - windows. Makes it possible to copy visible text to the command-line window. -- Support modeless selection on the cmdline in a terminal. Previously it was - only possible for the GUI. -- Make double-right-click in modeless selection select a whole word. Single - right click doesn't use the word selection started by a double-left-click. - Makes it work like in Visual mode. -- The modeless selection no longer has an implied automatic copy to the - clipboard. It now obeys the 'a' and 'A' flags in 'guioptions' or - "autoselect" and "autoselectml" in 'clipboard'. -- Added the CTRL-Y command in Cmdline-mode to copy the modeless selection to - the clipboard. Also works at the hit-enter prompt and the more prompt. - Removed the mappings in runtime/mswin.vim for CTRL-Y and CTRL-Z in - cmdline-mode to be able to use CTRL-Y in the new way. - -Reduced the amount of stack space used by regmatch() to allow it to handle -complicated patterns on a longer text. - -'isfname' now includes '%' and '#'. Makes "vim dir\#file" work for MS-DOS. - -Added keypad special keys <kEnter>, <k0> - <k9>. When not mapped they behave -like the ASCII equivalent. (Ivan Wellesz and Vince Negri) -Recognize a few more xterm keys: <C-Right>, <C-Left>, <C-End>, <C-Home> - -Also trigger the BufUnload event when Vim is going to exit. Perhaps a script -needs to do some cleaning up. - -Expand expression in backticks: `={expr}`. Can be used where backtick -expansion is done. (Vince Negri) - -GUI: -- Added 'L' and 'R' flags in 'guioptions': Add a left or right scrollbar only - when there is a vertically split window. -- X11: When a color can't be allocated, use the nearest match from the - colormap. This avoids that black is used for many things. (Monish Shah) - Also do this for the menu and scrollbar, to avoid that they become black. -- Win32 and X11: Added 'mouseshape' option: Adjust the mouse pointer shape to - the current mode. (Vince Negri) -- Added the 'linespace' option: Insert a pixel line between lines. (Nam) -- Allow modeless selection (without moving the cursor) by keeping CTRL and - SHIFT pressed. (Ivan Wellesz) -- Motif: added toolbar. (Gordon Prieur) Also added tooltips. -- Athena: added toolbar and tooltips. (David Harrison -- based on Gordon - Prieur's work) -- Made the 'toolbar' option work for Athena and Motif. Can now switch between - text and icons on the fly. (David Harrison) -- Support menu separator lines for Athena. (David Harrison) -- Athena: Adjust the arrow pixmap used in a pullright menu to the size of the - font. (David Harrison) -- Win32: Added "c" flag to 'guifont' to be able to specify the charset. (Artem - Khodush) -- When no --enable-xim argument is given, automatically enable it when a X GUI - is used. Required for dead key support (and multi-byte input). -- After a file selection dialog, check that the edited files were not changed - or deleted. The Win32 dialog allows deleting and renaming files. -- Motif and Athena: Added support for "editres". (Marcin Dalecki) -- Motif and Athena: Added "menuFont" to be able to specify a font or fontset - for the menus. Can also be set with the "Menu" highlight group. Useful - when the locale is different from 'encoding'. (David Harrison) - When FONTSET_ALWAYS is defined, always use a fontset for the menus. Should - avoid trouble with changing from a font to a fontset. (David Harrison) -- Highlighting and font for the tooltips can be specified with the "Tooltip" - highlight group. (David Harrison) -- The Cmdline-mode menus can be used at the more-prompt. This mostly works - fine, because they start with a CTRL-C. The "Copy" menu works to copy the - modeless selection. Allows copying the output of ":set all" or ":intro" - without auto-selection. -- When starting the GUI when there is no terminal connected to stdout and - stderr, display error messages in a dialog. Previously they wouldn't be - displayed at all. -- Allow setting 'browsedir' to the name of a directory, to be used for the - file dialog. (Dan Sharp) -- b:browsefilter and g:browsefilter can be set to the filters used for the - file dialog. Supported for Win32 and Motif GUI. (Dan Sharp) - -X11: -- Support for the clipboard selection as register "+. When exiting or - suspending copy the selection to cut buffer 0. Should allow copy/paste with - more applications in a X11-standard way. (Neil Bird) -- Use the X clipboard in any terminal, not just in an xterm. - Added "exclude:" in 'clipboard': Specify a pattern to match against terminal - names for which no connection should be made to the X server. The default - currently work for FreeBSD and Linux consoles. -- Added a few messages for when 'verbose' is non-zero to show what happens - when trying to connect to the X server. Should help when trying to find out - why startup is slow. - -GTK GUI: (partly by Marcin Dalecki) -- With some fonts the characters can be taller than ascent + descent. E.g., - "-misc-fixed-*-*-*-*-18-*-*-*-*-*-iso10646-1". Add one to the character - cell height. -- Implement "no" value for 'winaltkeys': don't use Alt-Key as a menu shortcut, - when 'wak' changed after creating the menus. -- Setting 'wak' after the GUI started works. -- recycle text GC's to reduce communication. -- Adjust icon size to window manager. -- Cleanup in font handling. -- Replace XQueryColor with GDK calls. -- Gnome support. Detects Gnome in configure and uses different widgets. - Otherwise it's much like GTK. (Andy Kahn) - It is disabled by default, because it causes a few problems. -- Removed the special code to fork first and then start the GUI. Now use - _exit() instead of exit(), this works fine without special tricks. -- Dialogs sometimes appeared a bit far away. Position the dialogs inside - the gvim window. (Brent Verner) -- When dropping a file on Vim, remove extra slashes from the start of the - path. Also shorten the file name if possible. - -Motif: (Marcin Dalecki) -- Made the dialog layout better. -- Added find and find/replace dialogs. -- For the menus, change "iso-8859" to "iso_8859", Linux appears to need this. -- Added icon to dialogs, like for GTK. -- Use XPM bitmaps for the icon when possible. Use the Solaris XpmP.h include - file when it's available. -- Change the shadow of the toolbar items to get a visual feedback of it being - pressed on non-LessTif. -- Use gadgets instead of windows for some items for speed. - -Command line completion: -- Complete environment variable names. (Mike Steed) -- For ":command", added a few completion methods: "mapping", "function", - "expression" and "environment". -- When a function doesn't take arguments, let completion add () instead of (. - -For MS-DOS, MS-Windows and OS/2: Expand %VAR% environment variables like $VAR. -(Walter Briscoe) - -Redirect messages to the clipboard ":redir @*" and to the unnamed register -":redir @"". (Wall) - -":let @/ = ''" clears the search pattern, instead of setting it to an empty -string. - -Expression evaluation: -- "? :" can be used like in C. -- col("$") returns the length of the cursor line plus one. (Stephen P. Wall) -- Optional extra argument for match(), matchend() and matchstr(): Offset to - start looking for a match. -- Made third argument to strpart() optional. (Paul Moore, Zdenek Sekera) -- exists() can also be used to check for Ex commands and defined autocommands. -- Added extra argument to input(): Default text. -- Also set "v:errmsg" when using ":silent! cmd". -- Added the v:prevcount variable: v:count for the previous command. -- Added "v:progname", name with which Vim was started. (Vince Negri) -- In the verbose message about returning from a function, also show the return - value. - -Cscope: -- Added the cscope_connection() function. (Andy Kahn) -- ":cscope kill -1" kills all cscope connections. (Andy Kahn) -- Added the 'cscopepathcomp' option. (Scott Hauck) -- Added ":scscope" command, split window and execute Cscope command. (Jason - Duell) - -VMS: -- Command line arguments are always uppercase. Interpret a "-X" argument as - "-x" and "-/X" as "-X". -- Set 'makeprg' and 'grepprg' to meaningful defaults. (Zoltan Arpadffy) -- Use the X-clipboard feature and the X command server. (Zoltan Arpadffy) - -Macintosh: (Dany St-Amant) -- Allow a tags file to have CR, CR-LF or LF line separator. (Axel Kielhorn) -- Carbonized (while keeping non Carbon code) - (Some work "stolen" from Ammon Skidmore) -- Improved the menu item index handling (should be faster) -- Runtime commands now handle / in file name (MacOS 9 version) -- Added ":winpos" support. -- Support using "~" in file names for home directory. - -Options: -- When using set += or ^= , check for items used twice. Duplicates are - removed. (Vince Negri) -- When setting an option that is a list of flags, remove duplicate flags. -- If possible, use getrlimit() to set 'maxmemtot' and 'maxmem'. (Pina) -- Added "alpha" to 'nrformats': increment or decrement an alphabetic character - with CTRL-A and CTRL-X. -- ":set opt&vi" sets an option to its Vi default, ":set opt&vim" to its Vim - default. Useful to set 'cpo' to its Vim default without knowing what flags - that includes. -- 'scrolloff' now also applies to a long, wrapped line that doesn't fit in the - window. -- Added more option settings to the default menus. -- Updated the option window with new options. Made it a bit easier to read. - -Internal changes: -- Split line pointers in text part and attributes part. Allows for future - change to make attribute more than one byte. -- Provide a qsort() function for systems that don't have it. -- Changed the big switch for Normal mode commands into a table. This cleans - up the code considerably and avoids trouble for some optimizing compilers. -- Assigned a negative value to special keys, to avoid them being mixed up with - Unicode characters. -- Global variables expand_context and expand_pattern were not supposed to be - global. Pass them to ExpandOne() and all functions called by it. -- No longer use the global reg_ic flag. It caused trouble and in a few places - it was not set. -- Removed the use of the stuff buffer for "*", "K", CTRL-], etc. Avoids - problem with autocommands. -- Moved some code from ex_docmd.c to ex_cmds2.c. The file was getting too - big. Also moved some code from screen.c to move.c. -- Don't include the CRC table for encryption, generate it. Saves quite a bit - of space in the source code. (Matthias Kramm) -- Renamed multibyte.c to mbyte.c to avoid a problem with 8.3 filesystems. -- Removed the GTK implementation of ":findhelp", it now uses the - ToolBar.FindHelp menu entry. -- Renamed mch_windexit() to mch_exit(), mch_init() to mch_early_init() and - mch_shellinit() to mch_init(). - -Highlighting: -- In a ":highlight" listing, show "xxx" with the highlight color. -- Added support for xterm with 88 or 256 colors. The right color numbers will - be used for the name used in a ":highlight" command. (Steve Wall) -- Added "default" argument for ":highlight". When included, the command is - ignored if highlighting for the group was already defined. - All syntax files now use ":hi default ..." to allow the user to specify - colors in his vimrc file. Also, the "if did_xxx_syntax_inits" is not needed - anymore. This greatly simplifies using non-default colors for a specific - language. -- Adjusted colortest.vim: Included colors on normal background and reduced the - size by using a while loop. (Rafael Garcia-Suarez) -- Added the "DarkYellow" color name. Just to make the list of standard colors - consistent, it's not really a nice color to use. - -When an xterm is in 8-bit mode this is detected by the code returned for -|t_RV|. All key codes are automatically converted to their 8-bit versions. - -The OPT_TCAP_QUERY in xterm patch level 141 and later is used to obtain the -actual key codes used and the number of colors for t_Co. Only when |t_RV| is -also used. - -":browse set" now also works in the console mode. ":browse edit" will give an -error message. - -":bdelete" and ":bunload" only report the number of deleted/unloaded buffers -when more than 'report'. The message was annoying when deleting a buffer in a -script. - -Jump list: -- The number of marks kept in the jumplist has been increased from 50 to 100. -- The jumplist is now stored in the viminfo file. CTRL-O can be used to jump - to positions from a previous edit session. -- When doing ":split" copy the jumplist to the new window. - -Also set the '[ and '] marks for the "~" and "r" commands. These marks are -now always set when making a change with a Normal mode command. - -Python interface: Allow setting the width of a vertically split window. (John -Cook) - -Added "=word" and "=~word" to 'cinkeys' (also used in 'indentkeys'). - -Added "j1" argument in 'cinoptions': indent {} inside () for Java. (Johannes -Zellner) -Added the "l" flag in 'cinoptions'. (Anduin Withers) -Added 'C', 'U', 'w' and 'm' flags to 'cinoptions'. (Servatius Brandt) - -When doing ":wall" or ":wqall" and a modified buffer doesn't have a name, -mention its buffer number in the error message. - -":function Name" lists the function with line numbers. Makes it easier to -find out where an error happened. - -In non-blockwise Visual mode, "r" replaces all selected characters with the -typed one, like in blockwise Visual mode. - -When editing the last file in the argument list in any way, allow exiting. -Previously this was only possible when getting to that file with ":next" or -":last". - -Added the '1' flag to 'formatoptions'. (Vit Stradal) -Added 'n' flag in 'formatoptions': format a numbered list. - -Swap file: -- When a swap file already exists, and the user selects "Delete" at the - ATTENTION prompt, use the same ".swp" swapfile, to avoid creating a ".swo" - file which won't always be found. -- When giving the ATTENTION message and the date of the file is newer than the - date of swap file, give a warning about this. -- Made the info for an existing swap file a bit shorter, so that it still fits - on a 24 line screen. -- It was possible to make a symlink with the name of a swap file, linking to a - file that doesn't exist. Vim would then silently use another file (if open - with O_EXCL refuses a symlink). Now check for a symlink to exist. Also do - another check for an existing swap file just before creating it to catch a - symlink attack. - -The g CTRL-G command also works in Visual mode and counts the number of words. -(Chase Tingley) - -Give an error message when using 'shell' and it's empty. - -Added the possibility to include "%s" in 'shellpipe'. - -Added "uhex" value for 'display': show non-printable characters as <xx>. -Show unprintable characters with NonText highlighting, also in the command -line. - -When asked to display the value of a hidden option, tell it's not supported. - -Win32: -- When dropping a shortcut on gvim (.lnk file) edit the target, not the - shortcut itself. (Yasuhiro Matsumoto) -- Added C versions of the OpenWithVim and SendToVim programs. (Walter Briscoe) -- When 'shell' is "cmd" or "cmd.exe", set 'shellredir' to redirect stderr too. - Also check for the Unix shell names. -- When $HOMEDRIVE and $HOMEPATH are defined, use them to define $HOME. (Craig - Barkhouse) - -Win32 console version: -- Includes the user and system name in the ":version" message, when available. - It generates a pathdef.c file for this. (Jon Miner) -- Set the window icon to Vim's icon (only for Windows 2000). While executing - a shell command, modify the window title to show this. When exiting, - restore the cursor position too. (Craig Barkhouse) -- The Win32 console version can be compiled with OLE support. It can only - function as a client, not as an OLE server. - -Errorformat: -- Let "%p" in 'errorformat' (column of error indicated by a row of characters) - also accept a line of dots. -- Added "%v" item in 'errorformat': Virtual column number. (Dan Sharp) -- Added a default 'errorformat' value for VMS. (Jim Bush) - -The "p" command can now be used in Visual mode. It overwrites the selected -text with the contents of a register. - -Highlight the <> items in the intro message to make clear they are special. - -When using the "c" flag for ":substitute", allow typing "l" for replacing this -item and then stop: "last". - -When printing a verbose message about sourcing another file, print the line -number. - -When resizing the Vim window, don't use 'equalalways'. Avoids that making the -Vim window smaller makes split windows bigger. And it's what the docs say. - -When typing CTRL-D in Insert mode, just after an autoindent, then hitting CR -kept the remaining white space. Now made it work like BS: delete the -autoindent to avoid a blank non-empty line results. - -Added a GetHwnd() call to the OLE interface. (Vince Negri) - -Made ":normal" work in an event handler. Useful when dropping a file on Vim -and for CursorHold autocommands. - -For the MS-Windows version, don't change to the directory of the file when a -slash is used instead of a backslash. Explorer should always use a backslash, -the user can use a slash when typing the command. - -Timestamps: -- When a buffer was changed outside of Vim and regaining focus, give a dialog - to allow the user to reload the file. Now also for other GUIs than - MS-Windows. And also used in the console, when compiled with dialog - support. -- Inspect the file contents to find out if it really changed, ignore - situations where only the time stamp changed (e.g., checking the file out - from CVS). -- When checking the timestamp, first check if the file size changed, to avoid - a file compare then. Makes it quicker for large (log) files that are - appended to. -- Don't give a warning for a changed or deleted file when 'buftype' is set. -- No longer warn for a changed directory. This avoids that the file explorer - produces warnings. -- Checking timestamps is only done for buffers that are not hidden. These - will be checked when they become unhidden. -- When checking for a file being changed outside of Vim, also check if the - file permissions changed. When the file contents didn't change but the - permissions did, give a warning. -- Avoid checking too often, otherwise the dialog keeps popping up for a log - file that steadily grows. - -Mapping <M-A> when 'encoding' is "latin1" and then setting 'encoding' to -"utf-8" causes the first byte of a multi-byte to be mapped. Can cause very -hard to find problems. Disallow mapping part of a multi-byte character. - -For ":python" and ":tcl" accept an in-line script. (Johannes Zellner) -Also for ":ruby" and ":perl". (Benoit Cerrina) - -Made ":syn include" use 'runtimepath' when the file name is not a full path. - -When 'switchbuf' contains "split" and the current window is empty, don't split -the window. - -Unix: Catch SIGPWR to preserve files when the power is about to go down. - -Sniff interface: (Anton Leherbauer) -- fixed windows code, esp. the event handling stuff -- adaptations for sniff 4.x ($SNIFF_DIR4) -- support for adding sniff requests at runtime - -Support the notation <A-x> as an alias for <M-x>. This logical, since the Alt -key is used. - -":find" accepts a count, which means that the count'th match in 'path' is -used. - -":ls" and ":buffers" output shows modified/readonly/modifiable flag. When a -buffer is active show "a" instead of nothing. When a buffer isn't loaded -show nothing instead of "-". - -Unix install: -- When installing the tools, set absolute paths in tools scripts efm_perl.pl - and mve.awk. Avoids that the user has to edit these files. -- Install Icons for KDE when the directories exist and the icons do not exist - yet. - -Added has("win95"), to be able to distinguish between MS-Windows 95/98/ME and -NT/2000/XP in a Vim script. - -When a ":cd" command was typed, echo the new current directory. (Dan Sharp) - -When using ":winpos" before the GUI window has been opened, remember the -values until it is opened. - -In the ":version" output, add "/dyn" for features that are dynamically loaded. -This indicates the feature may not always work. - -On Windows NT it is possible that a directory is read-only, but a file can be -deleted. When making a backup by renaming the file and 'backupdir' doesn't -use the current directory, this causes the original file to be deleted, -without the possibility to create a new file. Give an extra error message -then to warn to user about this. - -Made CTRL-R CTRL-O at the command line work like CTRL-R CTRL-R, so that it's -consistent with Insert mode. - -============================================================================== -COMPILE TIME CHANGES *compile-changes-6* - -All generated files have been moved out of the "src" directory. This makes it -easy to see which files are not edited by hand. The files generated by -configure are now in the "src/auto" directory. For Unix, compiled object -files go in the objects directory. - -The source archive was over the 1.4M floppy limit. The archives are now split -up into two runtime and two source archives. Also provide a bzip2 compressed -archive that contains all the sources and runtime files. - -Added "reconfig" as a target for make. Useful when changing some of the -arguments that require flushing the cache, such as switching from GTK to -Motif. Adjusted the meaning of GUI_INC_LOC and GUI_LIB_LOC to be consistent -over different GUIs. - -Added src/README.txt to give an overview of the main parts of the source code. - -The Unix Makefile now fully supports using $(DESTDIR) to install to a specific -location. Replaces the manual setting of *ENDLOC variables. - -Added the possibility for a maintainer of a binary version to include his -e-mail address with the --with-compiledby configure argument. - -Included features are now grouped in "tiny", "small", "normal", "big" and -"huge". This replaces "min-features" and "max-features". Using "tiny" -disables multiple windows for a really small Vim. - -For the tiny version or when FEAT_WINDOWS is not defined: Firstwin and lastwin -are equal to curwin and don't use w_next and w_prev. - -Added the +listcmds feature. Can be used to compile without the Vim commands -that manipulate the buffer list and argument list (the buffer list itself is -still there, can't do without it). - -Added the +vreplace feature. It is disabled in the "small" version to avoid -that the 16 bit DOS version runs out of memory. - -Removed GTK+ support for versions older than 1.1.16. - -The configure checks for using PTYs have been improved. Code taken from a -recent version of screen. - -Added configure options to install Vim, Ex and View under another name (e.g., -vim6, ex6 and view6). - -Added "--with-global-runtime" configure argument. Allows specifying the -global directory used in the 'runtimepath' default. - -Made enabling the SNiFF+ interface possible with a configure argument. - -Configure now always checks /usr/local/lib for libraries and -/usr/local/include for include files. Helps finding the stuff for iconv() and -gettext(). - -Moved the command line history stuff into the +cmdline_hist feature, to -exclude the command line history from the tiny version. - -MS-Windows: Moved common functions from Win16 and Win32 to os_mswin.c. Avoids -having to change two files for one problem. (Vince Negri) - -Moved common code from gui_w16.c and gui_w32.c to gui_w48.c (Vince Negri) - -The jumplist is now a separate feature. It is disabled for the "small" -version (16 bit MS-DOS). - -Renamed all types ending in _t to end in _T. Avoids potential problems with -system types. - -Added a configure check for X11 header files that implicitly define the return -type to int. (Steve Wall) - -"make doslang" in the top directory makes an archive with the menu and .mo -files for Windows. This uses the files generated on Unix, these should work -on MS-Windows as well. - -Merged a large part of os_vms.c with os_unix.c. The code was duplicated in -the past which made maintenance more work. (Zoltan Arpadffy) - -Updated the Borland C version 5 Makefile: (Dan Sharp) -- Fixed the Perl build -- Added python and tcl builds -- Added dynamic perl and dynamic python builds -- Added uninstal.exe build -- Use "yes" and "no" for the options, like in Make_mvc.mak. - -Win32: Merged Make_gvc.mak and Make_ovc.mak into one file: Make_ivc.mak. It's -much smaller, many unnecessary text has been removed. (Walter Briscoe) -Added Make_dvc.mak to be able to debug exe generated with Make_mvc.mak in -MS-Devstudio. (Walter Briscoe) - -MS-Windows: The big gvim.exe, which includes OLE, now also includes -dynamically loaded Tcl, Perl and Python. This uses ActivePerl 5.6.1, -ActivePython 2.1.1 and ActiveTCL 8.3.3 - -Added AC_EXEEXT to configure.in, to check if the executable needs ".exe" for -Cygwin or MingW. Renamed SUFFIX to EXEEXT in Makefile. - -Win32: Load comdlg32.dll delayed for faster startup. Only when using VC 6. -(Vipin Aravind) - -Win32: When compiling with Borland, allow using IME. (Yasuhiro Matsumoto) - -Win32: Added Makefile for Borland 5 to compile gvimext.dll. (Yasuhiro -Matsumoto) - -============================================================================== -BUG FIXES *bug-fixes-6* - -When checking the command name for "gvim", "ex", etc. ignore case. Required -for systems where case is ignored in command names. - -Search pattern "[a-c-e]" also matched a 'd' and didn't match a '-'. - -When double-clicking in another window, wasn't recognized as double click, -because topline is different. Added set_mouse_topline(). - -The BROKEN_LOCALE check was broken. (Marcin Dalecki) - -When "t_Co" is set, the default colors remain the same, thus wrong. Reset the -colors after changing "t_Co". (Steve Wall) - -When exiting with ":wqall" the messages about writing files could overwrite -each other and be lost forever. - -When starting Vim with an extremely long file name (around 1024 characters) it -would crash. Added a few checks to avoid buffer overflows. - -CTRL-E could get stuck in a file with very long lines. - -":au syntax<Tab>" expanded event names while it should expand groups starting -with "syntax". - -When expanding a file name caused an error (e.g., for <amatch>) it was -produced even when inside an "if 0". - -'cindent' formatted C comments differently from what the 'comments' option -specified. (Steve Wall) - -Default for 'grepprg' didn't include the file name when only grepping in one -file. Now /dev/null has been added for Unix. - -Opening the option window twice caused trouble. Now the cursor goes to the -existing option window. - -":sview" and ":view" didn't set 'readonly' for an existing buffer. Now do set -'readonly', unless the buffer is also edited in another window. - -GTK GUI: When 'guioptions' excluded 'g', the more prompt caused the toolbar -and menubar to disappear and resize the window (which clears the text). -Now always grey-out the toplevel menus to avoid that the menubar changes size -or disappears. - -When re-using the current buffer for a new buffer, buffer-local variables were -not deleted. - -GUI: when 'scrolloff' is 0 dragging the mouse above the window didn't cause a -down scroll. Now pass on a mouse event with mouse_row set to -1. - -Win32: Console version didn't work on telnet, because of switching between two -console screens. Now use one console screen and save/restore the contents -when needed. (Craig Barkhouse) - -When reading a file the magic number for encryption was included in the file -length. (Antonio Colombo) - -The quickfix window contained leading whitespace and NULs for multi-line -messages. (David Harrison) - -When using cscope, redundant tags were removed. This caused a numbering -problem, because they were all listed. Don't remove redundant cscope tags. -(David Bustos). - -Cscope: Test for which matches are in the current buffer sometimes failed, -causing a jump to another match than selected. (David Bustos) - -Win32: Buffer overflow when adding a charset name in a font. - -'titlestring' and 'iconstring' were evaluating an expression in the current -context, which could be a user function, which is a problem for local -variables vs global variables. - -Win32 GUI: Mapping <M-F> didn't work. Now handle SHIFT and CTRL in -_OnSysChar(). - -Win32 GUI: (on no file), :vs<CR>:q<CR> left a trail of pixels down the middle. -Could also happen for the ruler. screen_puts() didn't clear the right char in -ScreenLines[] for the bold trick. - -Win32: ":%!sort|uniq" didn't work, because the input file name touches the -"|". Insert a space before the "|". - -OS/2: Expanding wildcards included non-existing files. Caused ":runtime" to -fail, which caused syntax highlighting to fail. - -Pasting a register containing CTRL-R on the command line could cause an -endless loop that can't be interrupted. Now it can be stopped with CTRL-C. - -When 'verbose' is set, a message for file read/write could overwrite the -previous message. -When 'verbose' is set, the header from ":select" was put after the last -message. Now start a new line. - -The hit-enter prompt reacted to the response of the t_RV string, causing -messages at startup to disappear. - -When t_Co was set to 1, colors were still used. Now only use color when t_Co -> 1. - -Listing functions with ":function" didn't quit when 'q' or ':' was typed at -the more prompt. - -Use mkstemp() instead of mktemp() when it's available, avoids a warning for -linking on FreeBSD. - -When doing Insert mode completion it's possible that b_sfname is NULL. Don't -give it to printf() for the "Scanning" message. - -":set runtimepath-=$VIMRUNTIME" didn't work, because expansion of wildcards -was done after trying to remove the string. Now for ":set opt+=val" and ":set -opt-=val" the expansion of wildcards is done before adding or removing "val". - -Using CTRL-V with the "r" command with a blockwise Visual selection inserted a -CTRL-V instead of getting a special character. - -Unix: Changed the order of libraries: Put -lXdmcp after -lX11 and -lSM -lICE -after -lXdmcp. Should fix link problem on HP-UX 10.20. - -Don't remove the last "-lm" from the link line. Vim may link but fail later -when the GUI starts. - -When the shell returns with an error when trying to expand wildcards, do -include the pattern when the "EW_NOTFOUND" flag was set. -When expanding wildcards with the shell fails, give a clear error message -instead of just "1 returned". - -Selecting a Visual block, with the start partly on a Tab, deleting it leaves -the cursor too far to the left. Causes "s" to work in the wrong position. - -Pound sign in normal.c caused trouble on some compilers. Use 0xA3 instead. - -Warning for changing a read-only file wasn't given when 'insertmode' was set. - -Win32: When 'shellxquote' is set to a double quote (e.g., using csh), ":!start -notepad file" doesn't work. Remove the double quotes added by 'shellxquote' -when using ":!start". (Pavol Juhas) - -The "<f-args>" argument of ":command" didn't accept Tabs for white space. -Also, don't add an empty argument when there are trailing blanks. - -":e test\\je" edited "test\je", but ":next test\\je" edited "testje". -Backslashes were removed one time too many for ":next". - -VMS: "gf" didn't work properly. Use vms_fixfilename() to translate the file -name. (Zoltan Arpadffy) - -After ":hi Normal ctermbg=black ctermfg=white" and suspending Vim not all -characters are redrawn with the right background. - -When doing "make test" without +eval or +windows feature, many tests failed. -Now have test1 generate a script to copy the correct output, so that a test -that doesn't work is skipped. - -On FreeBSD the Perl interface added "-lc" to the link command and Python added -"-pthread". These two don't work together, because the libc_r library should -be used. Removed "-lc" from Perl, it should not be needed. -Also: Add "-pthread" to $LIBS, so that the checks for functions is done with -libc_r. Sigaltstack() appears to be missing from libc_r. - -The Syntax sub-menus were getting too long, reorganized them and added another -level for some languages. - -Visual block "r"eplace didn't work well when a Tab is partly included. -(Matthias Kramm) - -When yanking a Visual block, where some lines end halfway the block, putting -the text somewhere else doesn't insert a block. Padd with spaces for missing -characters. Added "y_width" to struct yankreg. (Matthias Kramm) - -If a substitute string has a multibyte character after a backslash only the -first byte of it was skipped. (Muraoka Taro) - -Win32: Numeric keypad keys were missing from the builtin termcap entry. - -When a file was read-only ":wa!" didn't force it to be written. (Vince Negri) - -Amiga: A file name starting with a colon was considered absolute but it isn't. -Amiga: ":pwd" added a slash when in the root of a drive. - -Don't let 'ttymouse' default to "dec" when compiled with dec mouse support. -It breaks the gpm mouse (Linux console). - -The prototypes for the Perl interface didn't work for threaded Perl. Added a -sed command to remove the prototypes from proto/if_perl.pro and added them -manually to if_perl.xs. - -When ":w!" resets the 'readonly' option the title and status lines were not -updated. - -":args" showed the current file when the argument list was empty. Made this -work like Vi: display nothing. - -"99:<C-U>echo v:count" echoed "99" in Normal mode, but 0 in Visual mode. -Don't set v:count when executing a stuffed command. - -Amiga: Got a requester for "home:" because it's in the default runtime path. -Don't bring up a requester when searching for a file in 'path', sourcing the -.vimrc file or using ":runtime". - -Win16 and Win32: Considered a file "\path\file" absolute. Can cause the same -file to appear as two different buffers. - -Win32: Renaming a file to an empty string crashed Vim. Happened when using -explorer.vim and hitting ESC at the rename prompt. - -Win32: strftime() crashed when called with a "-1" value for the time. - -Win32 with Borland compiler: mch_FullName() didn't work, caused tag file not -to be found. - -Cscope sometimes jumped to the wrong tag. (David Bustos) - -OS/2: Could not find the tags file. mch_expand_wildcards() added another -slash to a directory name. - -When using ">>" the `] mark was not in the last column. - -When Vim was compiled without menu support, filetype.vim was still trying to -source the menu.vim script. (Rafael Garcia-Suarez) - -":ptag" added an item to the tag stack. - -Win32 IME: "gr" didn't use IME mode. - -In the "vim --help" message the term "options" was used for arguments. That's -confusing, call them "arguments". - -When there are two windows, and a BufUnload autocommand for closing window #1 -closed window #2, Vim would crash. - -When there is a preview window and only one other window, ":q" wouldn't exit. - -In Insert mode, when cancelling a digraph with ESC, the '?' wasn't removed. - -On Unix glob(".*") returned "." and "..", on Windows it didn't. On Windows -glob("*") also returned files starting with a dot. Made this work like Unix -on all systems. - -Win32: Removed old code to open a console. Vimrun is now used and works fine. - -Compute the room needed by the intro message accurately, so that it also fits -on a 25 line console. (Craig Barkhouse) - -":ptnext" was broken. Now remember the last tag used in the preview window -separately from the tagstack. - -Didn't check for "-display" being the last argument. (Wichert Akkerman) - -GTK GUI: When starting "gvim" under some conditions there would be an X error. -Don't replace the error handler when creating the xterm clipboard. (Wichert -Akkerman) - -Adding a space after a help tag caused the tag not to be found. E.g., ":he -autoindent ". - -Was trying to expand a URL into a full path name. On Windows this resulted in -the current directory to be prepended to the URL. Added vim_isAbsName() and -vim_FullName() to avoid that various machine specific functions do it -differently. - -":n *.c" ":cd .." ":n" didn't use the original directory of the file. Vi only -does it for the current file (looks like a bug). Now remember the buffer used -for the entry in the argument list and use it's name (adjusted when doing -":cd"), unless it's deleted. - -When inserting a special key as its name ("<F8>" as four characters) after -moving around in Insert mode, undo didn't work properly. - -Motif GUI: When using the right mouse button, for some people gvim froze for -a couple of seconds (Motif 1.2?). This doesn't happen when there is no Popup -menu. Solved by only creating a popup menu when 'mousemodel' is "popup" or -"popup_setpos". (David Harrison) - -Motif: When adding many menu items, the "Help" menu disappeared but the -menubar didn't wrap. Now manually set the menubar height. - -When using <BS> in Insert mode to remove a line break, or using "J" to join -lines, the cursor could end up halfway a multi-byte character. (Muraoka Taro) - -Removed defining SVR4 in configure. It causes problems for some X header -files and doesn't appear to be used anywhere. - -When 'wildignore' is used, 'ignorecase' for a tag match was not working. - -When 'wildignore' contains "*~" it was impossible to edit a file ending in a -"~". Now don't recognize a file ending in "~" as containing wildcards. - -Disabled the mouse code for OS/2. It was not really used. - -":mksession" always used the full path name for a buffer, also when the short -name could be used. -":mkvimrc" and ":mksession" didn't save 'wildchar' and 'pastetoggle' in such a -way that they would be restored. Now use the key name if possible, this is -portable. - -After recovering a file and abandoning it, an ":edit" command didn't give the -ATTENTION prompt again. Would be useful to be able to delete the file in an -easy way. Reset the BF_RECOVERED flag when unloading the buffer. - -histdel() could match or ignore case, depending on what happened before it. -Now always match case. - -When a window size was specified when splitting a window, it would still get -the size from 'winheight' or 'winwidth' if it's larger. - -When using "append" or "insert" inside a function definition, a line starting -with "function" or "endfunction" caused confusion. Now recognize the commands -and skip lines until a ".". - -At the end of any function or sourced file need_wait_return could be reset, -causing messages to disappear when redrawing. - -When in a while loop the line number for error messages stayed fixed. Now the -line number is remembered in the while loop. - -"cd c:/" didn't work on MS-DOS. mch_isdir() removed a trailing slash. - -MS-Windows: getftime() didn't work when a directory had a trailing slash or -backslash. Didn't show the time in the explorer because of this. - -When doing wildcard completion, a directory "a/" sorted after "a-b". Now -recognize path separators when sorting files. - -Non-Unix systems: When editing "c:/dir/../file" and "c:/file" they were -created as different buffers, although it's the same file. Expand to a full -file name also when an absolute name contains "..". - -"g&" didn't repeat the last substitute properly. - -When 'clipboard' was set to "unnamed", a "Y" command would not write to "0. -Now make a copy of register 0 to the clipboard register. - -When the search pattern matches in many ways, it could not always be -interrupted with a CTRL-C. And CTRL-C would have to be hit once for every -line when 'hlsearch' is on. -When 'incsearch' is on and interrupting the search for a match, don't abandon -the command line. - -When turning a directory name into a full path, e.g., with fnamemodify(), -sometimes a slash was added. Make this consistent: Don't add a slash. - -When a file name contains a "!", using it in a shell command will cause -trouble: ":!cat %". Escape the "!" to avoid that. Escape it another time -when 'shell' contains "sh". - -Completing a file name that has a tail that starts with a "~" didn't work: -":e view/~<Tab>". - -Using a ":command" argument that contains < and > but not for a special -argument was not skipped properly. - -The DOS install program: On Win2000 the check for a vim.exe or gvim.exe in -$PATH didn't work, it always found it in the current directory. -Rename the vim.exe in the current dir to avoid this. (Walter Briscoe) - -In the MS-DOS/Windows install program, use %VIM% instead of an absolute path, -so that moving Vim requires only one change in the batch file. - -Mac: mch_FullName() changed the "fname" argument and didn't always initialize -the buffer. - -MS-DOS: mch_FullName() didn't fix forward/backward slashes in an absolute file -name. - -"echo expand("%:p:h")" with an empty file name removed one directory name on -MS-DOS. For Unix, when the file name is a directory, the directory name was -removed. Now make it consistent: "%:p" adds a path separator for all systems, -but no path separator is added in other situations. - -Unix: When checking for a CTRL-C (could happen any time) and there is an X -event (e.g., clipboard updated) and there is typeahead, Vim would hang until a -character was typed. - -MS-DOS, MS-Windows and Amiga: expanding "$ENV/foo" when $ENV ends in a colon, -had the slash removed. - -":he \^=" gave an error for using \_. ":he ^=" didn't find tag :set^=. Even -"he :set^=" didn't find it. - -A tags file name "D:/tags" was used as file "tags" in "D:". That doesn't work -when the current path for D: isn't the root of the drive. - -Removed calls to XtInitializeWidgetClass(), they shouldn't be necessary. - -When using a dtterm or various other color terminals, and the Normal group has -been set to use a different background color, the background wouldn't always -be displayed with that color. Added check for "ut" termcap entry: If it's -missing, clearing the screen won't give us the current background color. Need -to draw each character instead. Vim now also works when the "cl" (clear -screen) termcap entry is missing. - -When repeating a "/" search command with a line offset, the "n" did use the -offset but didn't make the motion linewise. Made "d/pat/+2" and "dn" do the -same. - -Win32: Trying to use ":tearoff" for a menu that doesn't exist caused a crash. - -OpenPTY() didn't work on Sequent. Add a configure check for getpseudotty(). - -C-indenting: Indented a line starting with ")" with the matching "(", but not -a line starting with "x)" looks strange. Also compute the indent for aligning -with items inside the () and use the lowest indent. - -MS-DOS and Windows: ":n *.vim" also matched files ending in "~". -Moved mch_expandpath() from os_win16.c and os_msdos.c to misc1.c, they are -equal. - -Macintosh: (Dany St-Amant) -- In Vi-compatible mode didn't read files with CR line separators. -- Fixed a bug in the handling of Activate/Deactivate Event -- Fixed a bug in gui_mch_dialog (using wrong pointer) - -Multibyte GDK XIM: While composing a multibyte-word, if user presses a -mouse button, then the word is removed. It should remain and composing end. -(Sung-Hyun Nam) - -MS-DOS, MS-Windows and OS/2: When reading from stdin, automatic CR-LF -conversion by the C library got in the way of detecting a "dos" 'fileformat'. - -When 'smartcase' is set, patterns with "\S" would also make 'ignorecase' -reset. - -When clicking the mouse in a column larger than 222, it moved to the first -column. Can't encode a larger number in a character. Now limit the number to -222, don't jump back to the first column. - -GUI: In some versions CSI would cause trouble, either when typed directly or -when part of a multi-byte sequence. - -When using multibyte characters in a ":normal" command, a trailing byte that -is CSI or K_SPECIAL caused problems. - -Wildmenu didn't handle multi-byte characters. - -":sleep 10" could not be interrupted on Windows, while "gs" could. Made them -both work the same. - -Unix: When waiting for a character is interrupted by an X-windows event (e.g., -to obtain the contents of the selection), the wait time would not be honored. -A message could be overwritten quickly. Now compute the remaining waiting -time. - -Windows: Completing "\\share\c$\S" inserted a backslash before the $ and then -the name is invalid. Don't insert the backslash. - -When doing an auto-write before ":make", IObuff was overwritten and the wrong -text displayed later. - -On the Mac the directories "c:/tmp" and "c:/temp" were used in the defaults -for 'backupdir' and 'directory', they don't exist. - -The check for a new file not to be on an MS-DOS filesystem created the file -temporarily, which can be slow. Don't do this if there is another check for -the swap file being on an MS-DOS filesystem. - -Don't give the "Changing a readonly file" warning when reading from stdin. - -When using the "Save As" menu entry and not entering a file name, would get an -error message for the trailing ":edit #". Now only do that when the -alternate file name was changed. - -When Vim owns the X11 selection and is being suspended, an application that -tries to use the selection hangs. When Vim continues it could no longer -obtain the selection. Now give up the selection when suspending. - -option.h and globals.h were included in some files, while they were already -included in vim.h. Moved the definition of EXTERN to vim.h to avoid doing it -twice. - -When repeating an operator that used a search pattern and the search pattern -contained characters that have a special meaning on the cmdline (e.g., CTRL-U) -it didn't work. - -Fixed various problems with using K_SPECIAL (0x80) and CSI (0x9b) as a byte in -a (multibyte) character. For example, the "r" command could not be repeated. - -The DOS/Windows install program didn't always work from a directory with a -long filename, because $VIM and the executable name would not have the same -path. - -Multi-byte: -- Using an any-but character range [^x] in a regexp didn't work for UTF-8. - (Muraoka Taro) -- When backspacing over inserted characters in Replace mode multi-byte - characters were not handled correctly. (Muraoka Taro) -- Search commands "#" and "*" didn't work with multibyte characters. (Muraoka - Taro) -- Word completion in Insert mode didn't work with multibyte characters. - (Muraoka Taro) -- Athena/Motif GUI: when 'linespace' is non-zero the cursor would be drawn too - wide (number of bytes instead of cell width). -- When changing 'encoding' to "euc-jp" and inserting a character Vim would - crash. -- For euc-jp characters positioning the cursor would sometimes be wrong. - Also, with two characters with 0x8e leading byte only the first one would be - displayed. -- When using DYNAMIC_ICONV on Win32 conversion might fail because of using the - wrong error number. (Muraoka Taro) -- Using Alt-x in the GUI while 'encoding' was set to "utf-8" didn't produce - the right character. -- When using Visual block selection and only the left halve of a double-wide - character is selected, the highlighting continued to the end of the line. -- Visual-block delete didn't work properly when deleting the right halve of a - double-wide character. -- Overstrike mode for the cmdline replaced only the first byte of a multibyte - character. -- The cursor in Replace mode (also in the cmdline) was to small on a - double-wide character. -- When a multibyte character contained a 0x80 byte, it didn't work (was using - a CSI byte instead). (Muraoka Taro) -- Wordwise selection with the mouse didn't work. -- Yanking a modeless selection of multi-byte characters didn't work. -- When 'selection' is "exclusive", selecting a word that ends in a multi-byte - character used wrong highlighting for the following character. - -Win32 with Make_mvc.mak: Didn't compile for debugging. (Craig Barkhouse) - -Win32 GUI: When "vimrun.exe" is used to execute an external command, don't -give a message box with the return value, it was already printed by vimrun. -Also avoid printing the return value of the shell when ":silent!" is used. - -Win32: selecting a lot of text and using the "find/replace" dialog caused a -crash. - -X11 GUI: When typing a character with the 8th bit set and the Meta/Alt -modifier, the modifier was removed without changing the character. - -Truncating a message to make it fit on the command line, using "..." for the -middle, didn't always compute the space correctly. - -Could not imap <C-@>. Now it works like <Nul>. - -VMS: -- Fixed a few things for VAXC. os_vms_fix.com had some strange CTRL-M - characters. (Zoltan Arpadffy and John W. Hamill) -- Added VMS-specific defaults for the 'isfname' and 'isprint' options. - (Zoltan Arpadffy) -- Removed os_vms_osdef.h, it's no longer used. - -The gzip plugin used a ":normal" command, this doesn't work when dropping a -compressed file on Vim. - -In very rare situations a binary search for a tag would fail, because an -uninitialized value happens to be half the size of the tag file. (Narendran) - -When using BufEnter and BufLeave autocommands to enable/disable a menu, it -wasn't updated right away. - -When doing a replace with the "c"onfirm flag, the cursor was positioned after -the ruler, instead of after the question. With a long replacement string the -screen could scroll up and cause a "more" prompt. Now the message is -truncated to make it fit. - -Motif: The autoconf check for the Xp library didn't work. - -When 'verbose' is set to list lines of a sourced file, defining a function -would reset the counter used for the "more" prompt. - -In the Win32 find/replace dialog, a '/' character caused problems. Escape it -with a backslash. - -Starting a shell with ":sh" was different from starting a shell for CTRL-Z -when suspending doesn't work. They now work the same way. - -Jumping to a file mark while in a changed buffer gave a "mark not set" error. - -":execute histget("cmd")" causes an endless loop and crashed Vim. Now catch -all commands that cause too much recursiveness. - -Removed "Failed to open input method" error message, too many people got this -when they didn't want to use a XIM. - -GUI: When compiled without the +windows feature, the scrollbar would start -below line one. - -Removed the trick with redefining character class functions from regexp.c. - -Win32 GUI: Find dialog gives focus back to main window, when typing a -character mouse pointer is blanked, it didn't reappear when moving it in the -dialog window. (Vince Negri) - -When recording and typing a CTRL-C, no character was recorded. When in Insert -mode or cancelling half a command, playing back the recorded sequence wouldn't -work. Now record the CTRL-C. - -When the GUI was started, mouse codes for DEC and netterm were still checked -for. - -GUI: When scrolling and 'writedelay' is non-zero, the character under the -cursor was displayed in the wrong position (one line above/below with -CTRL-E/CTRL-Y). - -A ":normal" command would reset the 'scrollbind' info. Causes problems when -using a ":normal" command in an autocommand for opening a file. - -Windows GUI: a point size with a dot, like "7.5", wasn't recognized. (Muraoka -Taro) - -When 'scrollbind' wasn't set would still remember the current position, -wasting time. - -GTK: Crash when 'shell' doesn't exist and doing":!ls". Use _exit() instead of -exit() when the child couldn't execute the shell. - -Multi-byte: -- GUI with double-byte encoding: a mouse click in left halve of double-wide - character put the cursor in previous char. -- Using double-byte encoding and 'selection' is "exclusive": "vey" and "^Vey" - included the character after the word. -- When using a double-byte encoding and there is a lead byte at the end of the - line, the preceding line would be displayed. "ga" also showed wrong info. -- "gf" didn't include multi-byte characters before the cursor properly. - (Muraoka Taro) - -GUI: The cursor was sometimes not removed when scrolling. Changed the policy -from redrawing the cursor after each call to gui_write() to only update it at -the end of update_screen() or when setting the cursor position. Also only -update the scrollbars at the end of update_screen(), that's the only place -where the window text may have been scrolled. - -Formatting "/*<Tab>long text", produced "* <Tab>" in the next line. Now -remove the space before the Tab. -Formatting "/*<Tab> long text", produced "* <Tab> long text" in the next -line. Now keep the space after the Tab. - -In some places non-ASCII alphabetical characters were accepted, which could -cause problems. For example, ":X" (X being such a character). - -When a pattern matches the end of the line, the last character in the line was -highlighted for 'hlsearch'. That looks wrong for "/\%3c". Now highlight the -character just after the line. - -Motif: If a dialog was closed by clicking on the "X" of the window frame Vim -would no longer respond. - -When using CTRL-X or CTRL-A on a number with many leading zeros, Vim would -crash. (Matsumoto) - -When 'insertmode' is set, the mapping in mswin.vim for CTRL-V didn't work in -Select mode. Insert mode wasn't restarted after overwriting the text. -Now allow nesting Insert mode with insert and change commands. CTRL-O -cwfoo<Esc> now also works. - -Clicking with the right mouse button in another window started Visual mode, -but used the start position of the current window. Caused ml_get errors when -the line number was invalid. Now stay in the same window. - -When 'selection' is "exclusive", "gv" sometimes selected one character fewer. - -When 'comments' contains more than one start/middle/end triplet, the optional -flags could be mixed up. Also didn't align the end with the middle part. - -Double-right-click in Visual mode didn't update the shown mode. - -When the Normal group has a font name, it was never used when starting up. -Now use it when 'guifont' and 'guifontset' are empty. -Setting a font name to a highlight group before the GUI was started didn't -work. - -"make test" didn't use the name of the generated Vim executable. - -'cindent' problems: -- Aligned with an "else" inside a do-while loop for a line below that loop. - (Meikel Brandmeyer) -- A line before a function would be indented even when terminated with a - semicolon. (Meikel Brandmeyer) -- 'cindent' gave too much indent to a line after a "};" that ends an array - init. -- Support declaration lines ending in "," and "\". (Meikel Brandmeyer) -- A case statement inside a do-while loop was used for indenting a line after - the do-while loop. (Meikel Brandmeyer) -- When skipping a string in a line with one double quote it could continue in - the previous line. (Meikel Brandmeyer) - -When 'list' is set, 'hlsearch' didn't highlight a match at the end of the -line. Now highlight the '$'. - -The Paste menu item in the menu bar, the popup menu and the toolbar were all -different. Now made them all equal to how it was done in mswin.vim. - -st_dev can be smaller than "unsigned". The compiler may give an overflow -warning. Added a configure check for dev_t. - -Athena: closing a confirm() dialog killed Vim. - -Various typos in the documentation. (Matt Dunford) - -Python interface: The definition of _DEBUG could cause trouble, undefine it. -The error message for not being able to load the shared library wasn't -translated. (Muraoka Taro) - -Mac: (Dany St-Amant and Axel Kielhorn) -- Several fixes. -- Vim was eating 80% of the CPU time. -- The project os_mac.pbxproj didn't work, Moved it to a subdirectory. -- Made the menu priority work for the menubar. -- Fixed a problem with dragging the scrollbar. -- Cleaned up the various #ifdefs. - -Unix: When catching a deadly signal and we keep getting one use _exit() to -exit in a quick and dirty way. - -Athena menu ordering didn't work correctly. (David Harrison) - -A ":make" or ":grep" command with a long argument could cause a crash. - -Doing ":new file" and using "Quit" for the ATTENTION dialog still opened a new -window. - -GTK: When starting the GUI and there is an error in the .vimrc file, don't -present the wait-return prompt, since the message was given in the terminal. - -When there was an error in a .vimrc file the terminal where gvim was started -could be cleared. Set msg_row in main.c before writing any messages. - -GTK and X11 GUI: When trying to read characters from the user (e.g. with -input()) before the Vim window was opened caused Vim to hang when it was -started from the desktop. - -OS/390 uses 31 bit pointers. That broke some computations with MAX_COL. -Reduce MAX_COL by one bit for OS/390. (Ralf Schandl) - -When defining a function and it already exists, Vim didn't say it existed -until after typing it. Now do this right away when typing it. - -The message remembered for displaying later (keep_msg) was sometimes pointing -into a generic buffer, which might be changed by the time the message is -displayed. Now make a copy of the message. - -When using multi-byte characters in a menu and a trailing byte is a backslash, -the menu would not be created correctly. (Muraoka Taro) -Using a multibyte character in the substitute string where a trail byte is a -backslash didn't work. (Muraoka Taro) - -When setting "t_Co" in a vimrc file, then setting it automatically from an -xterm termresponse and then setting it again manually caused a crash. - -When getting the value of a string option that is not supported, the number -zero was returned. This breaks a check like "&enc == "asdf". Now an empty -string is returned for string options. - -Crashed when starting the GTK GUI while using 'notitle' in the vimrc, setting -'title' in the gvimrc and starting the GUI with ":gui". Closed the connection -to the X server accidentally. - -Had to hit return after selecting an entry for ":ts". - -The message from ":cn" message was sometimes cleared. Now display it after -redrawing if it doesn't cause a scroll (truncated when necessary). - -hangulin.c didn't compile when the GUI was disabled. Disable it when it won't -work. - -When setting a termcap option like "t_CO", the value could be displayed as -being for a normal key with a modifier, like "<M-=>". - -When expanding the argument list, entries which are a directory name did not -get included. This stopped "vim c:/" from opening the file explorer. - -":syn match sd "^" nextgroup=asdf" skipped the first column and matched the -nextgroup in the second column. - -GUI: When 'lazyredraw' is set, 'showmatch' didn't work. Required flushing -the output. - -Don't define the <NetMouse> termcode in an xterm, reduces the problem when -someone types <Esc> } in Insert mode. - -Made slash_adjust() work correctly for multi-byte characters. (Yasuhiro -Matsumoto) -Using a filename in Big5 encoding for autocommands didn't work (backslash in -trailbyte). (Yasuhiro Matsumoto) - -DOS and Windows: Expanding *.vim also matched file.vimfoo. Expand path like -Unix to avoid problems with Windows dir functions. Merged the DOS and Win32 -functions. - -Win32: Gvimext could not edit more than a few files at once, the length of the -argument was fixed. - -"ls -1 * | xargs vim" worked, but the input was in cooked mode. Now switch to -raw mode when needed. Use dup() to copy the stderr file descriptor to stdin -to make shell commands work. No longer requires an external program to do -this. - -When using ":filetype off", ftplugin and indent usage would be switched off at -the same time. Don't do this, setting 'filetype' manually can still use them. - -GUI: When writing a double-byte character, it could be split up in two calls -to gui_write(), which doesn't work. Now flush before the output buffer -becomes full. - -When 'laststatus' is set and 'cmdheight' is two or bigger, the intro message -would be written over the status line. -The ":intro" command didn't work when there wasn't enough room. - -Configuring for Ruby failed with a recent version of Ruby. (Akinori Musha) - -Athena: When deleting the directory in which Vim was started, using the file -browser made Vim exit. Removed the use of XtAppError(). - -When using autoconf 2.50, UNIX was not defined. Moved the comment for "#undef -UNIX" to a separate line. - -Win32: Disabled _OnWindowPosChanging() to make maximize work better. - -Win32: Compiling with VC 4.0 didn't work. (Walter Briscoe) - -Athena: -- Finally fixed the problems with deleting a menu. (David Harrison) -- Athena: When closing the confirm() dialog, worked like OK was pressed, - instead of Cancel. - -The file explorer didn't work in compatible mode, because of line -continuation. - -Didn't give an error message for ":digraph a". - -When using Ex mode in the GUI and typing a special key, <BS> didn't delete it -correctly. Now display '?' for a special key. - -When an operator is pending, clicking in another window made it apply to that -window, even though the line numbers could be beyond the end of the buffer. - -When a function call doesn't have a terminating ")" Vim could crash. - -Perl interface: could crash on exit with perl 5.6.1. (Anduin Withers) - -Using %P in 'errorformat' wasn't handled correctly. (Tomas Zellerin) - -Using a syntax cluster that includes itself made Vim crash. - -GUI: With 'ls' set to 2, dragging the status line all the way up, then making -the Vim window smaller: Could not the drag status line anymore. - -"vim -c startinsert! file" placed cursor on last char of a line, instead of -after it. A ":set" command in the buffer menu set w_set_curswant. Now don't -do this when w_curswant is MAXCOL. - -Win32: When the gvim window was maximized and selecting another font, the -window would no longer fill the screen. - -The line with 'pastetoggle' in ":options" didn't show the right value when it -is a special key. Hitting <CR> didn't work either. - -Formatting text, resulting in a % landing in the first line, repeated the % in -the following lines, like it's the start of a comment. - -GTK: When adding a toolbar item while gvim is already running, it wasn't -possible to use the tooltip. Now it works by adding the tooltip first. - -The output of "g CTRL-G" mentioned "Char" but it's actually bytes. - -Searching for the end of a oneline region didn't work correctly when there is -an offset for the highlighting. - -Syntax highlighting: When synchronizing on C-comments, //*/ was seen as the -start of a comment. - -Win32: Without scrollbars present, the MS mouse scroll wheel didn't work. -Also handle the scrollbars when they are not visible. - -Motif: When there is no right scrollbar, the bottom scrollbar would still -leave room for it. (Marcin Dalecki) - -When changing 'guicursor' and the value is invalid, some of the effects would -still take place. Now first check for errors and only make the new value -effective when it's OK. - -Using "A" In Visual block mode, appending to lines that don't extend into the -block, padding was wrong. - -When pasting a block of text, a character that occupies more than one screen -column could be deleted and spaces inserted instead. Now only do that with a -tab. - -Fixed conversion of documentation to HTML using Perl. (Dan Sharp) - -Give an error message when a menu name starts with a dot. - -Avoid a hang when executing a shell from the GUI on HP-UX by pushing "ptem" -even when sys/ptem.h isn't present. - -When creating the temp directory, make sure umask is 077, otherwise the -directory is not accessible when it was set to 0177. - -Unix: When resizing the window and a redraw is a bit slow, could get a window -resize event while redrawing, resulting in a messed up window. Any input -(e.g., a mouse click) would redraw. - -The "%B" item in the status line became zero in Insert mode (that's normal) -for another than the current window. - -The menu entries to convert to xxd and back didn't work in Insert mode. - -When ":vglobal" didn't find a line where the pattern doesn't match, the error -message would be the wrong way around. - -When ignoring a multi-line error message with "%-A", the continuation lines -would be used anyway. (Servatius Brandt) - -"grx" on a double-wide character inserted "x", instead of replacing the -character with "x ". "gR" on <xx> ('display' set the "uhex") didn't replace -at all. When doing "gRxx" on a control character the first "x" would be -inserted, breaking the alignment. - -Added "0)" to 'cinkeys', so that when typing a ) it is put in the same place -as where "==" would put it. - -Win32: When maximized, adding/removing toolbar didn't resize the text area. - -When using <C-RightMouse> a count was discarded. - -When typing CTRL-V and <RightMouse> in the command line, would insert -<LeftMouse>. - -Using "vis" or "vas" when 'selection' is exclusive didn't include the last -character. - -When adding to an option like 'grepprg', leading space would be lost. Don't -expand environment variables when there is no comma separating the items. - -GUI: When using a bold-italic font, would still use the bold trick and -underlining. - -Motif: The default button didn't work in dialogs, the first one was always -used. Had to give input focus to the default button. - -When using CTRL-T to jump within the same file, the '' mark wasn't set. - -Undo wasn't Vi compatible when using the 'c' flag for ":s". Now it undoes the -whole ":s" command instead of each confirmed replacement. - -The Buffers menu, when torn-off, disappeared when being refreshed. Add a -dummy item to avoid this. - -Removed calling msg_start() in main(), it should not be needed. - -vim_strpbrk() did not support multibyte characters. (Muraoka Taro) - -The Amiga version didn't compile, the code was too big for relative jumps. -Moved a few files from ex_docmd.c to ex_cmds2.c - -When evaluating the "= register resulted in the "= register being changed, Vim -would crash. - -When doing ":view file" and it fails, the current buffer was made read-only. - -Motif: For some people the separators in the toolbar disappeared when resizing -the Vim window. (Marcin Dalecki) - -Win32 GUI: when setting 'lines' to a huge number, would not compute the -available space correctly. Was counting the menu height twice. - -Conversion of the docs to HTML didn't handle the line with the +quickfix tag -correctly. (Antonio Colombo) - -Win32: fname_case() didn't handle multi-byte characters correctly. (Yasuhiro -Matsumoto) - -The Cygwin version had trouble with fchdir(). Don't use that function for -Cygwin. - -The generic check in scripts.vim for "conf" syntax was done before some checks -in filetype.vim, resulting in "conf" syntax too often. - -Dos32: Typing lagged behind. Would wait for one biostick when checking if a -character is available. - -GTK: When setting 'columns' while starting up "gvim", would set the width of -the terminal it was started in. - -When using ESC in Insert mode, an autoindent that wraps to the next line -caused the cursor to move to the end of the line temporarily. When the -character before the cursor was a double-wide multi-byte character the cursor -would be on the right halve, which causes problems with some terminals. - -Didn't handle multi-byte characters correctly when expanding a file name. -(Yasuhiro Matsumoto) - -Win32 GUI: Errors generated before the GUI is decided to start were not -reported. - -globpath() didn't reserve enough room for concatenated results. (Anduin -Withers) - -When expanding an option that is very long already, don't do the expansion, it -would be truncated to MAXPATHL. (Anduin Withers) - -When 'selection' is "exclusive", using "Fx" in Visual mode only moved until -just after the character. - -When using IME on the console to enter a file name, the screen may scroll up. -Redraw the screen then. (Yasuhiro Matsumoto) - -Motif: In the find/replace dialog the "Replace" button didn't work first time, -second time it replaced all matches. Removed the use of ":s///c". -GTK: Similar problems with the find/replace dialog, moved the code to a common -function. - -X11: Use shared GC's for text. (Marcin Dalecki) - -"]i" found the match under the cursor, instead of the first one below it. -Same for "]I", "] CTRL-I", "]d", "]D" and "] CTRL-D". - -Win16: When maximized and the font is changed, don't change the window size. -(Vince Negri) - -When 'lbr' is set, deleting a block of text could leave the cursor in the -wrong position. - -Win32: When opening a file with the "Edit with Vim" popup menu entry, -wildcards would cause trouble. Added the "--literal" argument to avoid -expanding file names. - -When using "gv", it didn't restore that "$" was used in Visual block mode. - -Win32 GUI: While waiting for a shell command to finish, the window wasn't -redrawn at all. (Yasuhiro Matsumoto) - -Syntax highlighting: A match that continues on a next line because of a -contained region didn't end when that region ended. - -The ":s" command didn't allow flags like 'e' and 'i' right after it. - -When using ":s" to split a line, marks were moved to the next line. Vi keeps -them in the first line. - -When using ":n" ":rew", the previous context mark was at the top of the file, -while Vi puts it in the same place as the cursor. Made it Vi compatible. - -Fixed Vi incompatibility: Text was not put in register 1 when using "c" and -"d" with a motion character, when deleting within one line with one of the -commands: % ( ) `<character> / ? N n { } - -Win32 GUI: The tooltip for tear-off items remained when the tear-off item was -no longer selected. - -GUI: When typing ":" at the more prompt, would return to Normal mode and not -redraw the screen. - -When starting Vim with an argument "-c g/at/p" the printed lines would -overwrite each other. - -BeOS: Didn't compile. Configure didn't add the os_beos files, the QNX check -removed them. Various changes to os_beos.cc. (Joshua Haberman) -Removed the check for the hardware platform, the BeBox has not been produced -for a long time now. - -Win32 GUI: don't use a message box when the shell returns an error code, -display the message in the Vim window. - -Make_mvc.mak always included "/debug" for linking. "GUI=no" argument didn't -work. Use "DEBUG=yes" instead of "DEBUG=1" to make it consistent. (Dan Sharp) - -When a line in the tags file ended in ;" (no TAB following) the command would -not be recognized as a search command. - -X11: The inputMethod resource never worked. Don't use the "none" input method -for SGI, it apparently makes the first character in Input method dropped. - -Fixed incorrect tests in os_mac.h. (Axel Kielhorn) - -Win32 console: When the console where Vim runs in is closed, Vim could hang in -trying to restore the window icon. (Yasuhiro Matsumoto) - -When using ":3call func()" or ":3,3call func() the line number was ignored. - -When 'showbreak' and 'linebreak' were both set, Visual highlighting sometimes -continued until the end of the line. - -GTK GUI: Tearoff items were added even when 'guioptions' didn't contain 't' -when starting up. - -MS-Windows: When the current directory includes a "~", searching files with -"gf" or ":find" didn't work. A "$" in the directory had the same problem. -Added mch_has_exp_wildcard() functions. - -When reducing the Vim window height while starting up, would get an -out-of-memory error message. - -When editing a very long search pattern, 'incsearch' caused the redraw of the -command line to fail. - -Motif GUI: On some systems the "Help" menu would not be on the far right, as -it should be. On some other systems (esp. IRIX) the command line would not -completely show. Solution is to only resize the menubar for Lesstif. - -Using "%" in a line that contains "\\" twice didn't take care of the quotes -properly. Now make a difference between \" and \\". - -For non-Unix systems a dummy file is created when finding a swap name to -detect a 8.3 filesystem. When there is an existing swap file, would get a -warning for the file being created outside of Vim. Also, when closing the Vim -window the file would remain. - -Motif: The menu height was always computed, using a "-menuheight" argument -was setting the room for the command line. Now make clear the argument is not -supported. - -For some (EBCDIC) systems, POUND was equal to '#'. Added an #if for that to -avoid a duplicate case in a switch. - -The GUI may have problems when forking. Always call _exit() instead of exit() -in the parent, the child will call exit(). - -Win32 GUI: Accented characters were often wrong in dialogs and tearoff menus. -Now use CP_ACP instead of CP_OEMCP. (Vince Negri) - -When displaying text with syntax highlighting causes an error (e.g., running -out of stack) the syntax highlighting is disabled to avoid further messages. - -When a command in a .vimrc or .gvimrc causes an ATTENTION prompt, and Vim was -started from the desktop (no place to display messages) it would hang. Now -open the GUI window early to be able to display the messages and pop up the -dialog. - -"r<CR>" on a multi-byte character deleted only the first byte of the -character. "3r<CR>" deleted three bytes instead of three characters. - -When interrupting reading a file, Vi considers the buffer modified. Added the -'i' flag in 'cpoptions' flag for this (we don't want it modified to be able to -do ":q"). - -When using an item in 'guicursor' that starts with a colon, Vim would get -stuck or crash. - -When putting a file mark in a help file and later jumping back to it, the -options would not be set. Extended the modeline in all help files to make -this work better. - -When a modeline contained "::" the local option values would be printed. Now -ignore it. - -Some help files did not use a 8.3 names, which causes problems when using -MS-DOS unzip. Renamed "multibyte.txt" to "mbyte.txt", "rightleft.txt" to -"rileft.txt", "tagsearch.txt" to "tagsrch.txt", "os_riscos.txt" to -"os_risc.txt". - -When Visual mode is blockwise, using "iw" or "aw" made it characterwise. That -doesn't seem right, only do this when in linewise mode. But then do it -always, not only when start and end of Visual mode are equal. - -When using "viw" on a single-letter word and 'selection' is exclusive, would -not include the word. - -When formatting text from Insert mode, using CTRL-O, could mess up undo -information. - -While writing a file (also for the backup file) there was no check for an -interrupt (hitting CTRL-C). Vim could hang when writing a large file over a -slow network, and moving the mouse didn't make it appear (when 'mousehide' is -set) and the screen wasn't updated in the GUI. Also allow interrupting when -syncing the swap file, it can take a long time. - -When using ":mksession" while there is help window, it would later be restored -to the right file but not marked as a help buffer. ":help" would then open -another window. Now use the value "help" for 'buftype' to mark a help buffer. - -The session file contained absolute path names in option values, that doesn't -work when the home directory depends on the situation. Replace the home -directory with ~/ when possible. - -When using 'showbreak' a TAB just after the shown break would not be counted -correctly, the cursor would be positioned wrong. - -With 'showbreak' set to "--->" or "------->" and 'sts' set to 4, inserting -tabs did not work right. Could cause a crash. Backspacing was also wrong, -could get stuck at a line break. - -Win32: crashed when tearing off a menu with over 300 items. - -GUI: A menu or toolbar item would appear when only a tooltip was defined for -it. - -When 'scrolloff' is non-zero and "$" is in 'cpoptions', using "s" while the -last line of the file is the first line on screen, the text wasn't displayed. - -When running "autoconf", delete the configure cache to force starting cleanly -when configure is run again. - -When changing the Normal colors for cterm, the value of 'background' was -changed even when the GUI was used. - -The warning for a missing vimrun.exe was always given on startup, but some -people just editing a file don't need to be bothered by it. Only show it when -vimrun would be used. - -When using "%" in a multibyte text it could get confused by trailbytes that -match. (Muraoka Taro) - -Termcap entry for RiscOS was wrong, using 7 and 8 in octal codes. - -Athena: The title of a dialog window and the file selector window were not -set. (David Harrison) - -The "htmlLink" highlight group specified colors, which gives problems when -using a color scheme. Added the "Underlined" highlight group for this. - -After using ":insert" or ":change" the '[ mark would be one line too low. - -When looking for the file name after a match with 'include' one character was -skipped. Same for 'define'. - -Win32 and DJGPP: When editing a file with a short name in a directory, and -editing the same file but using the long name, would end up with two buffers -on the same file. - -"gf" on a filename that starts with "../" only worked when the file being -edited is in the current directory. An include file search didn't work -properly for files starting with "../" or ".". Now search both relative to -the file and to the current directory. - -When 'printheader', 'titlestring', 'iconstring', 'rulerformat' or 'statusline' -contained "%{" but no following "}" memory was corrupted and a crash could -happen. - -":0append" and then inserting two lines did not redraw the blank lines that -were scrolled back down. - -When using insert mode completion in a narrow window, the message caused a -scroll up. Now shorten the message if it doesn't fit and avoid writing the -ruler over the message. - -XIM still didn't work correctly on some systems, especially SGI/IRIX. Added -the 'imdisable' option, which is set by default for that system. - -Patch 6.0aw.008 -Problem: When the first character of a file name is over 127, the Buffers - menu entry would get a negative priority and cause problems. -Solution: Reduce the multiplier for the first character when computing - the hash value for a Buffers menu entry. -Files: runtime/menu.vim - -Patch 6.0aw.010 -Problem: Win32: ":browse edit dir/dir" didn't work. (Vikas) -Solution: Change slashes to backslashes in the directory passed to the file - browser. -Files: src/gui_w48.c - -Athena file browser: On some systems wcstombs() can't be used to get the -length of a multi-byte string. Use the maximum length then. (Yasuhiro -Matsumoto) - -Patch 6.0ax.001 -Problem: When 'patchmode' is set, appending to a file gives an empty - original file. (Ed Ralston) -Solution: Also make a backup copy when appending and 'patchmode' is set. -Files: src/fileio.c - -Patch 6.0ax.002 -Problem: When 'patchmode' is set, appending to a compressed file gives an - uncompressed original file. (Ed Ralston) -Solution: Create the original file before decompressing. -Files: runtime/plugin/gzip.vim - -Patch 6.0ax.005 -Problem: Athena file selector keeps the title of the first invocation. -Solution: Set the title each time the file selector is opened. (David - Harrison) -Files: src/gui_at_fs.c - -Patch 6.0ax.007 -Problem: When using GPM (mouse driver in a Linux console) a double click is - interpreted as a scroll wheel click. -Solution: Check if GPM is being used when deciding if a mouse event is for - the scroll wheel. -Files: src/term.c - -Patch 6.0ax.010 -Problem: The Edit.Save menu and the Save toolbar button didn't work when - the buffer has no file name. -Solution: Use a file browser to ask for a file name. Also fix the toolbar - Find item in Visual mode. -Files: runtime/menu.vim - -Patch 6.0ax.012 -Problem: When 'cpoptions' contains "$", breaking a line for 'textwidth' - doesn't redraw properly. (Stefan Schulze) -Solution: Remove the dollar before breaking the line. -Files: src/edit.c - -Patch 6.0ax.014 -Problem: Win32: On Windows 98 ":make -f file" doesn't work when 'shell' is - "command.com" and 'makeprg' is "nmake". The environment isn't - passed on to "nmake". -Solution: Also use vimrun.exe when redirecting the output of a command. -Files: src/os_win32.c - -Patch 6.0ax.016 -Problem: The version number was reported wrong in the intro screen. -Solution: Check for a version number with two additional letters. -Files: src/version.c - -Patch 6.0ax.019 -Problem: When scrolling a window with folds upwards, switching to another - vertically split window and back may not update the scrollbar. -Solution: Limit w_botline to the number of lines in the buffer plus one. -Files: src/move.c - - -============================================================================== -VERSION 6.1 *version-6.1* - -This section is about improvements made between version 6.0 and 6.1. - -This is a bug-fix release, there are not really any new features. - - -Changed *changed-6.1* -------- - -'iminsert' and 'imsearch' are no longer set as a side effect of defining a -language-mapping using ":lmap". - - -Added *added-6.1* ------ - -Syntax files: -ampl AMPL (David Krief) -ant Ant (Johannes Zellner) -baan Baan (Her van de Vliert) -cs C# (Johannes Zellner) -lifelines Lifelines (Patrick Texier) -lscript LotusScript (Taryn East) -moo MOO (Timo Frenay) -nsis NSIS (Alex Jakushev) -ppd Postscript Printer Description (Bjoern Jacke) -rpl RPL/2 (Joel Bertrand) -scilab Scilab (Benoit Hamelin) -splint Splint (Ralf Wildenhues) -sqlj SQLJ (Andreas Fischbach) -wvdial WvDial (Prahlad Vaidyanathan) -xf86conf XFree86 config (Nikolai Weibull) -xmodmap Xmodmap (Nikolai Weibull) -xslt Xslt (Johannes Zellner) -monk Monk (Mike Litherland) -xsd Xsd (Johannes Zellner) -cdl CDL (Raul Segura Acevedo) -sendpr Send-pr (Hendrik Scholz) - -Added indent file for Scheme. (Dorai Sitaram) -Added indent file for Prolog. (Kontra Gergely) -Added indent file for Povray (David Necas) -Added indent file for IDL (Aleksandar Jelenak) -Added C# indent and ftplugin scripts. - -Added Ukrainian menu translations. (Bohdan Vlasyuk) -Added ASCII version of the Czech menus. (Jiri Brezina) - -Added Simplified Chinese translation of the tutor. (Mendel L Chan) - -Added Russian keymap for yawerty keyboard. - -Added an explanation of using the vimrc file in the tutor. -Changed tutor.vim to get the right encoding for the Taiwainese tutor. - -Added Russian tutor. (Andrey Kiselev) -Added Polish tutor. (Mikolaj Machowski) - -Added darkblue color scheme. (Bohdan Vlasyuk) - -When packing the dos language archive automatically generate the .mo files -that are required. - -Improved NSIS script to support NSIS 180. Added icons for the -enabled/disabled status. (Mirek Pruchnik) - -cp1250 version of the Slovak message translations. - -Compiler plugins for IRIX compilers. (David Harrison) - - -Fixed *fixed-6.1* ------ - -The license text was updated to make the meaning clearer and make it -compatible with the GNU GPL. Otherwise distributors have a problem when -linking Vim with a GPL'ed library. - -When installing the "less.sh" script it was not made executable. (Chuck Berg) - -Win32: The "9" key on the numpad wasn't working. (Julian Kinraid) - -The NSIS install script didn't work with NSIS 1.80 or later. Also add -Vim-specific icons. (Pruchnik) - -The script for conversion to HTML contained an "if" in the wrong place. -(Michael Geddes) - -Allow using ":ascii" in the sandbox, it's harmless. - -Removed creat() from osdef2.h.in, it wasn't used and may cause a problem when -it's redefined to creat64(). - -The text files in the VisVim directory were in "dos" format. This caused -problems when applying a patch. Now keep them in "unix" format and convert -them to "dos" format only for the PC archives. - -Add ruby files to the dos source archive, they can be used by Make_mvc.mak. -(Mirek Pruchnik) - -"cp -f" doesn't work on all systems. Change "cp -f" in the Makefile to "rm --f" and "cp". - -Didn't compile on a Compaq Tandem Himalaya OSS. (Michael A. Benzinger) - -The GTK file selection dialog didn't include the "Create Dir", "Delete File" -and "Rename File" buttons. - -When doing ":browse source" the dialog has the title "Run Macro". Better -would be "Source Vim script". (Yegappan Lakshmanan) - -Win32: Don't use the printer font as default for the font dialog. - -"make doslang" didn't work when configure didn't run (yet). Set $MAKEMO to -"yes". (Mirek Pruchnik) - -The ToolBar TagJump item used "g]", which prompts for a selection even when -there is only one matching tag. Use "g<C-]>" instead. - -The ming makefile for message translations didn't have the right list of -files. - -The MS-Windows 3.1 version complains about LIBINTL.DLL not found. Compile -this version without message translations. - -The Borland 5 makefile contained a check for Ruby which is no longer needed. -The URLs for the TCL library was outdated. (Dan Sharp) - -The eviso.ps file was missing from the DOS runtime archive, it's needed for -printing PostScript in the 32bit DOS version. - -In menu files ":scriptencoding" was used in a wrong way after patch 6.1a.032 -Now use ":scriptencoding" in the file where the translations are given. Do -the same for all menus in latin1 encoding. - -Included a lot of fixes for the Macintosh, mostly to make it work with Carbon. -(Dany StAmant, Axel Kielhorn, Benji Fisher) - -Improved the vimtutor shell script to use $TMPDIR when it exists, and delete -the copied file when exiting in an abnormal way. (Max Ischenko) - -When "iconv.dll" can't be found, try using "libiconv.dll". - -When encryption is used, filtering with a shell command wasn't possible. - -DJGPP: ":cd c:" always failed, can't get permissions for "c:". -Win32: ":cd c:/" failed if the previous current directory on c: had become -invalid. - -DJGPP: Shift-Del and Del both produce \316\123. Default mapping for Del is -wrong. Disabled it. - -Dependencies on header files in MingW makefile was wrong. - -Win32: Don't use ACL stuff for MSVC 4.2, it's not supported. (Walter Briscoe) - -Win32 with Borland: bcc.cfg was caching the value for $(BOR), but providing a -different argument to make didn't regenerate it. - -Win32 with MSVC: Make_ivc.mak generates a new if_ole.h in a different -directory, the if_ole.h in the src directory may be used instead. Delete the -distributed file. - -When a window is vertically split and then ":ball" is used, the window layout -is messed up, can cause a crash. (Muraoka Taro) - -When 'insertmode' is set, using File/New menu and then double clicking, "i" is -soon inserted. (Merlin Hansen) - -When Select mode is active and using the Buffers menu to switch to another -buffer, an old selection comes back. Reset VIsual_reselect for a ":buffer" -command. - -When Select mode is active and 'insertmode' is set, using the Buffers menu to -switch to another buffer, did not return to Insert mode. Make sure -"restart_edit" is set. - -When double clicking on the first character of a word while 'selection' is -"exclusive" didn't select that word. - - -Patch 6.0.001 -Problem: Loading the sh.vim syntax file causes error messages . (Corinna - Vinschen) -Solution: Add an "if". (Charles Campbell) -Files: runtime/syntax/sh.vim - -Patch 6.0.002 -Problem: Using a '@' item in 'viminfo' doesn't work. (Marko Leipert) -Solution: Add '@' to the list of accepted items. -Files: src/option.c - -Patch 6.0.003 -Problem: The configure check for ACLs on AIX doesn't work. -Solution: Fix the test program so that it compiles. (Tomas Ogren) -Files: src/configure.in, src/auto/configure - -Patch 6.0.004 -Problem: The find/replace dialog doesn't reuse a previous argument - properly. -Solution: After removing a "\V" terminate the string. (Zwane Mwaikambo) -Files: src/gui.c - -Patch 6.0.005 -Problem: In Insert mode, "CTRL-O :ls" has a delay before redrawing. -Solution: Don't delay just after wait_return() was called. Added the - did_wait_return flag. -Files: src/globals.h, src/message.c, src/normal.c, src/screen.c - -Patch 6.0.006 -Problem: With a vertical split, 'number' set and 'scrolloff' non-zero, - making the window width very small causes a crash. (Niklas - Lindstrom) -Solution: Check for a zero width. -Files: src/move.c - -Patch 6.0.007 -Problem: When setting 'filetype' while there is no FileType autocommand, a - following ":setfiletype" would set 'filetype' again. (Kobus - Retief) -Solution: Set did_filetype always when 'filetype' has been set. -Files: src/option.c - -Patch 6.0.008 -Problem: 'imdisable' is missing from the options window. (Michael Naumann) -Solution: Add an entry for it. -Files: runtime/optwin.vim - -Patch 6.0.009 -Problem: Nextstep doesn't have S_ISBLK. (John Beppu) -Solution: Define S_ISBLK using S_IFBLK. -Files: src/os_unix.h - -Patch 6.0.010 -Problem: Using "gf" on a file name starting with "./" or "../" in a buffer - without a name causes a crash. (Roy Lewis) -Solution: Check for a NULL file name. -Files: src/misc2.c - -Patch 6.0.011 -Problem: Python: After replacing or deleting lines get an ml_get error. - (Leo Lipelis) -Solution: Adjust the cursor position for deleted or added lines. -Files: src/if_python.c - -Patch 6.0.012 -Problem: Polish translations contain printf format errors, this can result - in a crash when using one of them. -Solution: Fix for translated messages. (Michal Politowski) -Files: src/po/pl.po - -Patch 6.0.013 -Problem: Using ":silent! cmd" still gives some error messages, like for an - invalid range. (Salman Halim) -Solution: Reset emsg_silent after calling emsg() in do_one_cmd(). -Files: src/ex_docmd.c - -Patch 6.0.014 -Problem: When 'modifiable' is off and 'virtualedit' is "all", "rx" on a TAB - still changes the buffer. (Muraoka Taro) -Solution: Check if saving the line for undo fails. -Files: src/normal.c - -Patch 6.0.015 -Problem: When 'cpoptions' includes "S" and "filetype plugin on" has been - used, can get an error for deleting the b:did_ftplugin variable. - (Ralph Henderson) -Solution: Only delete the variable when it exists. -Files: runtime/ftplugin.vim - -Patch 6.0.016 -Problem: bufnr(), bufname() and bufwinnr() don't find unlisted buffers when - the argument is a string. (Hari Krishna Dara) - Also for setbufvar() and getbufvar(). -Solution: Also find unlisted buffers. -Files: src/eval.c - -Patch 6.0.017 -Problem: When 'ttybuiltin' is set and a builtin termcap entry defines t_Co - and the external one doesn't, it gets reset to empty. (David - Harrison) -Solution: Only set t_Co when it wasn't set yet. -Files: src/term.c - -Patch 6.0.018 -Problem: Initializing 'encoding' may cause a crash when setlocale() is not - used. (Dany St-Amant) -Solution: Check for a NULL pointer. -Files: src/mbyte.c - -Patch 6.0.019 -Problem: Converting a string with multi-byte characters to a printable - string, e.g., with strtrans(), may cause a crash. (Tomas Zellerin) -Solution: Correctly compute the length of the result in transstr(). -Files: src/charset.c - -Patch 6.0.020 -Problem: When obtaining the value of a global variable internally, could - get the function-local value instead. Applies to using <Leader> - and <LocalLeader> and resetting highlighting in a function. -Solution: Prepend "g:" to the variable name. (Aric Blumer) -Files: src/syntax.c, src/term.c - -Patch 6.0.021 -Problem: The 'cscopepathcomp' option didn't work. -Solution: Change USE_CSCOPE to FEAT_CSCOPE. (Mark Feng) -Files: src/option.c - -Patch 6.0.022 -Problem: When using the 'langmap' option, the second character of a command - starting with "g" isn't adjusted. -Solution: Apply 'langmap' to the second character. (Alex Kapranoff) -Files: src/normal.c - -Patch 6.0.023 -Problem: Loading the lhaskell syntax doesn't work. (Thore B. Karlsen) -Solution: Use ":runtime" instead of "source" to load haskell.vim. -Files: runtime/syntax/lhaskell.vim - -Patch 6.0.024 -Problem: Using "CTRL-V u 9900" in Insert mode may cause a crash. (Noah - Levitt) -Solution: Don't insert a NUL byte in the text, use a newline. -Files: src/misc1.c - -Patch 6.0.025 -Problem: The pattern "\vx(.|$)" doesn't match "x" at the end of a line. - (Preben Peppe Guldberg) -Solution: Always see a "$" as end-of-line after "\v". Do the same for "^". -Files: src/regexp.c - -Patch 6.0.026 -Problem: GTK: When using arrow keys to navigate through the menus, the - separators are selected. -Solution: Set the separators "insensitive". (Pavel Kankovsky) -Files: src/gui_gtk.c, src/gui_gtk_x11.c - -Patch 6.0.027 -Problem: VMS: Printing doesn't work, the file is deleted too quickly. - No longer need the VMS specific printing menu. - gethostname() is not available with VAXC. - The makefile was lacking selection of the tiny-huge feature set. -Solution: Adjust the 'printexpr' option default. Fix the other problems and - update the documentation. (Zoltan Arpadffy) -Files: runtime/doc/os_vms.txt, runtime/menu.vim, src/INSTALLvms.txt, - src/Make_vms.mms, src/option.c, src/os_unix.c, src/os_vms_conf.h - -Patch 6.0.028 -Problem: Can't compile without +virtualedit and with +visualextra. (Geza - Lakner) -Solution: Add an #ifdef for +virtualedit. -Files: src/ops.c - -Patch 6.0.029 -Problem: When making a change in line 1, then in line 2 and then deleting - line 1, undo info could be wrong. Only when the changes are undone - at once. (Gerhard Hochholzer) -Solution: When not saving a line for undo because it was already done - before, remember for which entry the last line must be computed. - Added ue_getbot_entry pointer for this. When the number of lines - changes, adjust the position of newer undo entries. -Files: src/structs.h, src/undo.c - -Patch 6.0.030 -Problem: Using ":source! file" doesn't work inside a loop or after - ":argdo". (Pavol Juhas) -Solution: Execute the commands in the file right away, do not let the main - loop do it. -Files: src/ex_cmds2.c, src/ex_docmd.c, src/getchar.c, src/globals.h, - src/proto/ex_docmd.pro, src/proto/getchar.pro - -Patch 6.0.031 -Problem: Nextstep doesn't have setenv() or putenv(). (John Beppu) -Solution: Move putenv() from pty.c to misc2.c -Files: src/misc2.c, src/pty.c - -Patch 6.0.032 -Problem: When changing a setting that affects all folds, they are not - displayed immediately. -Solution: Set the redraw flag in foldUpdateAll(). -Files: src/fold.c - -Patch 6.0.033 -Problem: Using 'wildmenu' on MS-Windows, file names that include a space - are only displayed starting with that space. (Xie Yuheng) -Solution: Don't recognize a backslash before a space as a path separator. -Files: src/screen.c - -Patch 6.0.034 -Problem: Calling searchpair() with three arguments could result in a crash - or strange error message. (Kalle Bjorklid) -Solution: Don't use the fifth argument when there is no fourth argument. -Files: src/eval.c - -Patch 6.0.035 -Problem: The menu item Edit/Global_Settings/Toggle_Toolbar doesn't work - when 'ignorecase' is set. (Allen Castaban) -Solution: Always match case when checking if a flag is already present in - 'guioptions'. -Files: runtime/menu.vim - -Patch 6.0.036 -Problem: OS/2, MS-DOS and MS-Windows: Using a path that starts with a - slash in 'tags' doesn't work as expected. (Mathias Koehrer) -Solution: Only use the drive, not the whole path to the current directory. - Also make it work for "c:dir/file". -Files: src/misc2.c - -Patch 6.0.037 -Problem: When the user has set "did_install_syntax_menu" to avoid the - default Syntax menu it still appears. (Virgilio) -Solution: Don't add the three default items when "did_install_syntax_menu" - is set. -Files: runtime/menu.vim - -Patch 6.0.038 -Problem: When 'selection' is "exclusive", deleting a block of text at the - end of a line can leave the cursor beyond the end of the line. -Solution: Correct the cursor position. -Files: src/ops.c - -Patch 6.0.039 -Problem: "gP" leaves the cursor in the wrong position when 'virtualedit' is - used. Using "c" in blockwise Visual mode leaves the cursor in a - strange position. -Solution: For "gP" reset the "coladd" field for the '] mark. For "c" leave - the cursor on the last inserted character. -Files: src/ops.c - -Patch 6.0.040 -Problem: When 'fileencoding' is invalid and writing fails because of - this, the original file is gone. (Eric Carlier) -Solution: Restore the original file from the backup. -Files: src/fileio.c - -Patch 6.0.041 -Problem: Using ":language messages en" when LC_MESSAGES is undefined - results in setting LC_CTYPE. (Eric Carlier) -Solution: Set $LC_MESSAGES instead. -Files: src/ex_cmds2.c - -Patch 6.0.042 -Problem: ":mksession" can't handle file names with a space. -Solution: Escape special characters in file names with a backslash. -Files: src/ex_docmd.c - -Patch 6.0.043 -Problem: Patch 6.0.041 was wrong. -Solution: Use mch_getenv() instead of vim_getenv(). -Files: src/ex_cmds2.c - -Patch 6.0.044 -Problem: Using a "containedin" list for a syntax item doesn't work for an - item that doesn't have a "contains" argument. Also, "containedin" - doesn't ignore a transparent item. (Timo Frenay) -Solution: When there is a "containedin" argument somewhere, always check for - contained items. Don't check for the transparent item but the - item it's contained in. -Files: src/structs.h, src/syntax.c - -Patch 6.0.045 -Problem: After creating a fold with a Visual selection, another window - with the same buffer still has inverted text. (Sami Salonen) -Solution: Redraw the inverted text. -Files: src/normal.c - -Patch 6.0.046 -Problem: When getrlimit() returns an 8 byte number the check for running - out of stack may fail. (Anthony Meijer) -Solution: Skip the stack check if the limit doesn't fit in a long. -Files: src/auto/configure, src/config.h.in, src/configure.in, - src/os_unix.c - -Patch 6.0.047 -Problem: Using a regexp with "\(\)" inside a "\%[]" item causes a crash. - (Samuel Lacas) -Solution: Don't allow nested atoms inside "\%[]". -Files: src/regexp.c - -Patch 6.0.048 -Problem: Win32: In the console the mouse doesn't always work correctly. - Sometimes after getting focus a mouse movement is interpreted like - a button click. -Solution: Use a different function to obtain the number of mouse buttons. - Avoid recognizing a button press from undefined bits. (Vince Negri) -Files: src/os_win32.c - -Patch 6.0.049 -Problem: When using evim the intro screen is misleading. (Adrian Nagle) -Solution: Mention whether 'insertmode' is set and the menus to be used. -Files: runtime/menu.vim, src/version.c - -Patch 6.0.050 -Problem: UTF-8: "viw" doesn't include non-ASCII characters before the - cursor. (Bertilo Wennergren) -Solution: Use dec_cursor() instead of decrementing the column number. -Files: src/search.c - -Patch 6.0.051 -Problem: UTF-8: Using CTRL-R on the command line doesn't insert composing - characters. (Ron Aaron) -Solution: Also include the composing characters and fix redrawing them. -Files: src/ex_getln.c, src/ops.c - -Patch 6.0.052 -Problem: The check for rlim_t in patch 6.0.046 does not work on some - systems. (Zdenek Sekera) -Solution: Also look in sys/resource.h for rlim_t. -Files: src/auto/configure, src/configure.in - -Patch 6.0.053 (extra) -Problem: Various problems with QNX. -Solution: Minor fix for configure. Switch on terminal clipboard support in - main.c. Fix "pterm" mouse support. os_qnx.c didn't build without - photon. (Julian Kinraid) -Files: src/auto/configure, src/configure.in, src/gui_photon.c, - src/main.c, src/misc2.c, src/option.h, src/os_qnx.c, src/os_qnx.h, - src/syntax.c - -Patch 6.0.054 -Problem: When using mswin.vim, CTRL-V pastes a block of text like it is - normal text. Using CTRL-V in blockwise Visual mode leaves "x" - characters behind. -Solution: Make CTRL-V work as it should. Do the same for the Paste menu - entries. -Files: runtime/menu.vim, runtime/mswin.vim - -Patch 6.0.055 -Problem: GTK: The selection isn't copied the first time. -Solution: Own the selection at the right moment. -Files: src/gui_gtk_x11.c - -Patch 6.0.056 -Problem: Using "CTRL-O cw" in Insert mode results in a nested Insert mode. - <Esc> doesn't leave Insert mode then. -Solution: Only use nested Insert mode when 'insertmode' is set or when a - mapping is used. -Files: src/normal.c - -Patch 6.0.057 -Problem: Using ":wincmd g}" in a function doesn't work. (Gary Holloway) -Solution: Execute the command directly, instead of putting it in the - typeahead buffer. -Files: src/normal.c, src/proto/normal.pro, src/window.c - -Patch 6.0.058 -Problem: When a Cursorhold autocommand moved the cursor, the ruler wasn't - updated. (Bohdan Vlasyuk) -Solution: Update the ruler after executing the autocommands. -Files: src/gui.c - -Patch 6.0.059 -Problem: Highlighting for 'hlsearch' isn't visible in lines that are - highlighted for diff highlighting. (Gary Holloway) -Solution: Let 'hlsearch' highlighting overrule diff highlighting. -Files: src/screen.c - -Patch 6.0.060 -Problem: Motif: When the tooltip is to be popped up, Vim crashes. - (Gary Holloway) -Solution: Check for a NULL return value from gui_motif_fontset2fontlist(). -Files: src/gui_beval.c - -Patch 6.0.061 -Problem: The toolbar buttons to load and save a session do not correctly - use v:this_session. -Solution: Check for v:this_session to be empty instead of existing. -Files: runtime/menu.vim - -Patch 6.0.062 -Problem: Crash when 'verbose' is > 3 and using ":shell". (Yegappan - Lakshmanan) -Solution: Avoid giving a NULL pointer to printf(). Also output a newline - and switch the cursor on. -Files: src/misc2.c - -Patch 6.0.063 -Problem: When 'cpoptions' includes "$", using "cw" to type a ')' on top of - the "$" doesn't update syntax highlighting after it. -Solution: Stop displaying the "$" when typing a ')' in its position. -Files: src/search.c - -Patch 6.0.064 (extra) -Problem: The NSIS install script doesn't work with newer versions of NSIS. - The diff feature doesn't work when there isn't a good diff.exe on - the system. -Solution: Replace the GetParentDir instruction by a user function. - Fix a few cosmetic problems. Use defined constants for the - version number, so that it's defined in one place only. - Only accept the install directory when it ends in "vim". - (Eduardo Fernandez) - Add a diff.exe and use it from the default _vimrc. -Files: nsis/gvim.nsi, nsis/README.txt, src/dosinst.c - -Patch 6.0.065 -Problem: When using ":normal" in 'indentexpr' it may use redo characters - before its argument. (Neil Bird) -Solution: Save and restore the stuff buffer in ex_normal(). -Files: src/ex_docmd.c, src/getchar.c, src/globals.h, src/structs.h - -Patch 6.0.066 -Problem: Sometimes undo for one command is split into two undo actions. - (Halim Salman) -Solution: Don't set the undo-synced flag when reusing a line that was - already saved for undo. -Files: src/undo.c - -Patch 6.0.067 -Problem: if_xcmdsrv.c doesn't compile on systems where fd_set isn't defined - in the usual header file (e.g., AIX). (Mark Waggoner) -Solution: Include sys/select.h in if_xcmdsrv.c for systems that have it. -Files: src/if_xcmdsrv.c - -Patch 6.0.068 -Problem: When formatting a Visually selected area with "gq" and the number - of lines increases the last line may not be redrawn correctly. - (Yegappan Lakshmanan) -Solution: Correct the area to be redrawn for inserted/deleted lines. -Files: src/ops.c - -Patch 6.0.069 -Problem: Using "K" on a word that includes a "!" causes a "No previous - command" error, because the "!" is expanded. (Craig Jeffries) -Solution: Put a backslash before the "!". -Files: src/normal.c - -Patch 6.0.070 -Problem: Win32: The error message for a failed dynamic linking of a Perl, - Ruby, Tcl and Python library is unclear about what went wrong. -Solution: Give the name of the library or function that could not be loaded. - Also for the iconv and gettext libraries when 'verbose' is set. -Files: src/eval.c, src/if_perl.xs, src/if_python.c, src/if_ruby.c, - src/if_tcl.c, src/mbyte.c, src/os_win32.c, src/proto/if_perl.pro, - src/proto/if_python.pro, src/proto/if_ruby.pro, - src/proto/if_tcl.pro, src/proto/mbyte.pro - -Patch 6.0.071 -Problem: The "iris-ansi" builtin termcap isn't very good. -Solution: Fix the wrong entries. (David Harrison) -Files: src/term.c - -Patch 6.0.072 -Problem: When 'lazyredraw' is set, a mapping that stops Visual mode, moves - the cursor and starts Visual mode again causes a redraw problem. - (Brian Silverman) -Solution: Redraw both the old and the new Visual area when necessary. -Files: src/normal.c, src/screen.c - -Patch 6.0.073 (extra) -Problem: DJGPP: When using CTRL-Z to start a shell, the prompt is halfway - the text. (Volker Kiefel) -Solution: Position the system cursor before starting the shell. -Files: src/os_msdos.c - -Patch 6.0.074 -Problem: When using "&" in a substitute string a multi-byte character with - a trailbyte 0x5c is not handled correctly. -Solution: Recognize multi-byte characters inside the "&" part. (Muraoka Taro) -Files: src/regexp.c - -Patch 6.0.075 -Problem: When closing a horizontally split window while 'eadirection' is - "hor" another horizontally split window is still resized. (Aron - Griffis) -Solution: Only resize windows in the same top frame as the window that is - split or closed. -Files: src/main.c, src/proto/window.pro, src/window.c - -Patch 6.0.076 -Problem: Warning for wrong pointer type when compiling. -Solution: Use char instead of char_u pointer. -Files: src/version.c - -Patch 6.0.077 -Problem: Patch 6.0.075 was incomplete. -Solution: Fix another call to win_equal(). -Files: src/option.c - -Patch 6.0.078 -Problem: Using "daw" at the end of a line on a single-character word didn't - include the white space before it. At the end of the file it - didn't work at all. (Gavin Sinclair) -Solution: Include the white space before the word. -Files: src/search.c - -Patch 6.0.079 -Problem: When "W" is in 'cpoptions' and 'backupcopy' is "no" or "auto", can - still overwrite a read-only file, because it's renamed. (Gary - Holloway) -Solution: Add a check for a read-only file before renaming the file to - become the backup. -Files: src/fileio.c - -Patch 6.0.080 -Problem: When using a session file that has the same file in two windows, - the fileinfo() call in do_ecmd() causes a scroll and a hit-enter - prompt. (Robert Webb) -Solution: Don't scroll this message when 'shortmess' contains 'O'. -Files: src/ex_cmds.c - -Patch 6.0.081 -Problem: After using ":saveas" the new buffer name is added to the Buffers - menu with a wrong number. (Chauk-Mean Proum) -Solution: Trigger BufFilePre and BufFilePost events for the renamed buffer - and BufAdd for the old name (which is with a new buffer). -Files: src/ex_cmds.c - -Patch 6.0.082 -Problem: When swapping screens in an xterm and there is an (error) message - from the vimrc script, the shell prompt is after the message. -Solution: Output a newline when there was output on the alternate screen. - Also when starting the GUI. -Files: src/main.c - -Patch 6.0.083 -Problem: GTK: When compiled without menu support the buttons in a dialog - don't have any text. (Erik Edelmann) -Solution: Add the text also when GTK_USE_ACCEL isn't defined. And define - GTK_USE_ACCEL also when not using menus. -Files: src/gui_gtk.c - -Patch 6.0.084 -Problem: UTF-8: a "r" command with an argument that is a keymap for a - character with a composing character can't be repeated with ".". - (Raphael Finkel) -Solution: Add the composing characters to the redo buffer. -Files: src/normal.c - -Patch 6.0.085 -Problem: When 'mousefocus' is set, using "s" to go to Insert mode and then - moving the mouse pointer to another window stops Insert mode, - while this doesn't happen with "a" or "i". (Robert Webb) -Solution: Reset finish_op before calling edit(). -Files: src/normal.c - -Patch 6.0.086 -Problem: When using "gu" the message says "~ed". -Solution: Make the message say "changed". -Files: src/ops.c - -Patch 6.0.087 (lang) -Problem: Message translations are incorrect, which may cause a crash. - (Peter Figura) - The Turkish translations needed more work and the maintainer - didn't have time. -Solution: Fix order of printf arguments. Remove %2$d constructs. - Add "-v" to msgfmt to get a warning for wrong translations. - Don't install the Turkish translations for now. - Update a few more translations. -Files: src/po/Makefile, src/po/af.po, src/po/cs.po, src/po/cs.cp1250.po, - src/po/de.po, src/po/es.po, src/po/fr.po, src/po/it.po, - src/po/ja.po, src/po/ja.sjis.po, src/po/ko.po, src/po/pl.po, - src/po/sk.po, src/po/uk.po, src/po/zh_CN.UTF-8.po, - src/po/zh_CN.cp936.po, src/po/zh_CN.po, src/po/zh_TW.po - -Patch 6.0.088 -Problem: "." doesn't work after using "rx" in Visual mode. (Charles - Campbell) -Solution: Also store the replacement character in the redo buffer. -Files: src/normal.c - -Patch 6.0.089 -Problem: In a C file, using "==" to align a line starting with "* " after - a line with "* -" indents one space too few. (Piet Delport) -Solution: Align with the previous line if the comment-start-string matches - there. -Files: src/misc1.c - -Patch 6.0.090 -Problem: When a wrapping line does not fit in a window and 'scrolloff' is - bigger than half the window height, moving the cursor left or - right causes the screen to flash badly. (Lubomir Host) -Solution: When there is not enough room to show 'scrolloff' screen lines and - near the end of the line, show the end of the line. -Files: src/move.c - -Patch 6.0.091 -Problem: Using CTRL-O in Insert mode, while 'virtualedit' is "all" and the - cursor is after the end-of-line, moves the cursor left. (Yegappan - Lakshmanan) -Solution: Keep the cursor in the same position. -Files: src/edit.c - -Patch 6.0.092 -Problem: The explorer plugin doesn't ignore case of 'suffixes' on - MS-Windows. (Mike Williams) -Solution: Match or ignore case as appropriate for the OS. -Files: runtime/plugin/explorer.vim - -Patch 6.0.093 -Problem: When the Tcl library couldn't be loaded dynamically, get an error - message when closing a buffer or window. (Muraoka Taro) -Solution: Only free structures if already using the Tcl interpreter. -Files: src/if_tcl.c - -Patch 6.0.094 -Problem: Athena: When clicking in the horizontal scrollbar Vim crashes. - (Paul Ackersviller) -Solution: Use the thumb size instead of the window pointer of the scrollbar - (which is NULL). (David Harrison) - Also avoid that scrolling goes the wrong way in a narrow window. -Files: src/gui_athena.c - -Patch 6.0.095 -Problem: Perl: Deleting lines may leave the cursor beyond the end of the - file. -Solution: Check the cursor position after deleting a line. (Serguei) -Files: src/if_perl.xs - -Patch 6.0.096 -Problem: When ":saveas fname" fails because the file already exists, the - file name is changed anyway and a following ":w" will overwrite - the file. (Eric Carlier) -Solution: Don't change the file name if the file already exists. -Files: src/ex_cmds.c - -Patch 6.0.097 -Problem: Re-indenting in Insert mode with CTRL-F may cause a crash with a - multi-byte encoding. -Solution: Avoid using a character before the start of a line. (Sergey - Vlasov) -Files: src/edit.c - -Patch 6.0.098 -Problem: GTK: When using Gnome the "Search" and "Search and Replace" dialog - boxes are not translated. -Solution: Define ENABLE_NLS before including gnome.h. (Eduardo Fernandez) -Files: src/gui_gtk.c, src/gui_gtk_x11.c - -Patch 6.0.099 -Problem: Cygwin: When running Vi compatible MS-DOS line endings cause - trouble. -Solution: Make the default for 'fileformats' "unix,dos" in Vi compatible - mode. (Michael Schaap) -Files: src/option.h - -Patch 6.0.100 -Problem: ":badd +0 test%file" causes a crash. -Solution: Take into account that the "+0" is NUL terminated when allocating - room for replacing the "%". -Files: src/ex_docmd.c - -Patch 6.0.101 -Problem: ":mksession" doesn't restore editing a file that has a '#' or '%' - in its name. (Wolfgang Blankenburg) -Solution: Put a backslash before the '#' and '%'. -Files: src/ex_docmd.c - -Patch 6.0.102 -Problem: When changing folds the cursor may appear halfway a closed fold. - (Nam SungHyun) -Solution: Set w_cline_folded correctly. (Yasuhiro Matsumoto) -Files: src/move.c - -Patch 6.0.103 -Problem: When using 'scrollbind' a large value of 'scrolloff' will make the - scroll binding stop near the end of the file. (Coen Engelbarts) -Solution: Don't use 'scrolloff' when limiting the topline for scroll - binding. (Dany StAmant) -Files: src/normal.c - -Patch 6.0.104 -Problem: Multi-byte: When '$' is in 'cpoptions', typing a double-wide - character that overwrites the left halve of an old double-wide - character causes a redraw problem and the cursor stops blinking. -Solution: Clear the right half of the old character. (Yasuhiro Matsumoto) -Files: src/edit.c, src/screen.c - -Patch 6.0.105 -Problem: Multi-byte: In a window of one column wide, with syntax - highlighting enabled a crash might happen. -Solution: Skip getting the syntax attribute when the character doesn't fit - anyway. (Yasuhiro Matsumoto) -Files: src/screen.c - -Patch 6.0.106 (extra) -Problem: Win32: When the printer font is wrong, there is no error message. -Solution: Give an appropriate error message. (Yasuhiro Matsumoto) -Files: src/os_mswin.c - -Patch 6.0.107 (extra) -Problem: VisVim: When editing another file, a modified file may be written - unexpectedly and without warning. -Solution: Split the window if a file was modified. -Files: VisVim/Commands.cpp - -Patch 6.0.108 -Problem: When using folding could try displaying line zero, resulting in an - error for a NULL pointer. -Solution: Stop decrementing w_topline when the first line of a window is in - a closed fold. -Files: src/window.c - -Patch 6.0.109 -Problem: XIM: When the input method is enabled, repeating an insertion with - "." disables it. (Marcel Svitalsky) -Solution: Don't store the input method status when a command comes from the - stuff buffer. -Files: src/ui.c - -Patch 6.0.110 -Problem: Using undo after executing "OxjAxkdd" from a register in - an empty buffer gives an error message. (Gerhard Hochholzer) -Solution: Don't adjust the bottom line number of an undo block when it's - zero. Add a test for this problem. -Files: src/undo.c, src/testdir/test20.in, src/testdir/test20.ok - -Patch 6.0.111 -Problem: The virtcol() function doesn't take care of 'virtualedit'. -Solution: Add the column offset when needed. (Yegappan Lakshmanan) -Files: src/eval.c - -Patch 6.0.112 -Problem: The explorer plugin doesn't sort directories with a space or - special character after a directory with a shorter name. -Solution: Ignore the trailing slash when comparing directory names. (Mike - Williams) -Files: runtime/plugin/explorer.vim - -Patch 6.0.113 -Problem: ":edit ~/fname" doesn't work if $HOME includes a space. Also, - expanding wildcards with the shell may fail. (John Daniel) -Solution: Escape spaces with a backslash when needed. -Files: src/ex_docmd.c, src/misc1.c, src/proto/misc1.pro, src/os_unix.c - -Patch 6.0.114 -Problem: Using ":p" with fnamemodify() didn't expand "~/" or "~user/" to a - full path. For Win32 the current directory was prepended. - (Michael Geddes) -Solution: Expand the home directory. -Files: src/eval.c - -Patch 6.0.115 (extra) -Problem: Win32: When using a dialog with a textfield it cannot scroll the - text. -Solution: Add ES_AUTOHSCROLL to the textfield style. (Pedro Gomes) -Files: src/gui_w32.c - -Patch 6.0.116 (extra) -Problem: MS-Windows NT/2000/XP: filewritable() doesn't work correctly for - filesystems that use ACLs. -Solution: Use ACL functions to check if a file is writable. (Mike Williams) -Files: src/eval.c, src/macros.h, src/os_win32.c, src/proto/os_win32.pro - -Patch 6.0.117 (extra) -Problem: Win32: when disabling the menu, "set lines=999" doesn't use all - the available screen space. -Solution: Don't subtract the fixed caption height but the real menu height - from the available screen space. Also: Avoid recursion in - gui_mswin_get_menu_height(). -Files: src/gui_w32.c, src/gui_w48.c - -Patch 6.0.118 -Problem: When $TMPDIR is a relative path, the temp directory is missing a - trailing slash and isn't deleted when Vim exits. (Peter Holm) -Solution: Add the slash after expanding the directory to an absolute path. -Files: src/fileio.c - -Patch 6.0.119 (depends on patch 6.0.116) -Problem: VMS: filewritable() doesn't work properly. -Solution: Use the same method as for Unix. (Zoltan Arpadffy) -Files: src/eval.c - -Patch 6.0.120 -Problem: The conversion to html isn't compatible with XHTML. -Solution: Quote the values. (Jess Thrysoee) -Files: runtime/syntax/2html.vim - -Patch 6.0.121 (extra) (depends on patch 6.0.116) -Problem: Win32: After patch 6.0.116 Vim doesn't compile with mingw32. -Solution: Add an #ifdef HAVE_ACL. -Files: src/os_win32.c - -Patch 6.0.122 (extra) -Problem: Win16: Same resize problems as patch 6.0.117 fixed for Win32. And - dialog textfield problem from patch 6.0.115. -Solution: Set old_menu_height only when used. Add ES_AUTOHSCROLL flag. - (Vince Negri) -Files: src/gui_w16.c - -Patch 6.0.123 (depends on patch 6.0.119) -Problem: Win16: Compilation problems. -Solution: Move "&&" to other lines. (Vince Negri) -Files: src/eval.c - -Patch 6.0.124 -Problem: When using a ":substitute" command that starts with "\=" - (evaluated as an expression), "~" was still replaced with the - previous substitute string. -Solution: Skip the replacement when the substitute string starts with "\=". - Also adjust the documentation about doubling backslashes. -Files: src/ex_cmds.c, runtime/doc/change.txt - -Patch 6.0.125 (extra) -Problem: Win32: When using the multi_byte_ime feature pressing the shift - key would be handled as if a character was entered, thus mappings - with a shifted key didn't work. (Charles Campbell) -Solution: Ignore pressing the shift, control and alt keys. -Files: src/os_win32.c - -Patch 6.0.126 -Problem: The python library was always statically linked. -Solution: Link the python library dynamically. (Matthias Klose) -Files: src/auto/configure, src/configure.in - -Patch 6.0.127 -Problem: When using a terminal that swaps screens and the Normal background - color has a different background, using an external command may - cause the color of the wrong screen to be changed. (Mark Waggoner) -Solution: Don't call screen_stop_highlight() in stoptermcap(). -Files: src/term.c - -Patch 6.0.128 -Problem: When moving a vertically split window to the far left or right, - the scrollbars are not adjusted. (Scott E Lee) When 'mousefocus' - is set the mouse pointer wasn't adjusted. -Solution: Adjust the scrollbars and the mouse pointer. -Files: src/window.c - -Patch 6.0.129 -Problem: When using a very long file name, ":ls" (repeated a few times) - causes a crash. Test with "vim `perl -e 'print "A"x1000'`". - (Tejeda) -Solution: Terminate a string before getting its length in buflist_list(). -Files: src/buffer.c - -Patch 6.0.130 -Problem: When using ":cprev" while the error window is open, and the new - line at the top wraps, the window isn't correctly drawn. - (Yegappan Lakshmanan) -Solution: When redrawing the topline don't scroll twice. -Files: src/screen.c - -Patch 6.0.131 -Problem: When using bufname() and there are two matches for listed buffers - and one match for an unlisted buffer, the unlisted buffer is used. - (Aric Blumer) -Solution: When there is a match with a listed buffer, don't check for - unlisted buffers. -Files: src/buffer.c - -Patch 6.0.132 -Problem: When setting 'iminsert' in the vimrc and using an xterm with two - screens the ruler is drawn in the wrong screen. (Igor Goldenberg) -Solution: Only draw the ruler when using the right screen. -Files: src/option.c - -Patch 6.0.133 -Problem: When opening another buffer while 'keymap' is set and 'iminsert' - is zero, 'iminsert' is set to one unexpectedly. (Igor Goldenberg) -Solution: Don't set 'iminsert' as a side effect of defining a ":lmap" - mapping. Only do that when 'keymap' is set. -Files: src/getchar.c, src/option.c - -Patch 6.0.134 -Problem: When completing ":set tags=" a path with an embedded space causes - the completion to stop. (Sektor van Skijlen) -Solution: Escape spaces with backslashes, like for ":set path=". Also take - backslashes into account when searching for the start of the path - to complete (e.g., for 'backupdir' and 'cscopeprg'). -Files: src/ex_docmd.c, src/ex_getln.c, src/option.c, src/structs.h - -Patch 6.0.135 -Problem: Menus that are not supposed to do anything used "<Nul>", which - still produced an error beep. - When CTRL-O is mapped for Insert mode, ":amenu" commands didn't - work in Insert mode. - Menu language falls back to English when $LANG ends in "@euro". -Solution: Use "<Nop>" for a menu item that doesn't do anything, just like - mappings. - Use ":anoremenu" instead of ":amenu". - Ignore "@euro" in the locale name. -Files: runtime/makemenu.vim, runtime/menu.vim, src/menu.c - -Patch 6.0.136 -Problem: When completing in Insert mode, a mapping could be unexpectedly - applied. -Solution: Don't use mappings when checking for a typed character. -Files: src/edit.c - -Patch 6.0.137 -Problem: GUI: When using the find or find/replace dialog from Insert mode, - the input mode is stopped. -Solution: Don't use the input method status when the main window doesn't - have focus. -Files: src/ui.c - -Patch 6.0.138 -Problem: GUI: When using the find or find/replace dialog from Insert mode, - the text is inserted when CTRL-O is mapped. (Andre Pang) - When opening the dialog again, a whole word search isn't - recognized. - When doing "replace all" a whole word search was never done. -Solution: Don't put a search or replace command in the input buffer, - execute it directly. - Recognize "\<" and "\>" after removing "\V". - Add "\<" and "\>" also for "replace all". -Files: src/gui.c - -Patch 6.0.139 -Problem: When stopping 'wildmenu' completion, the statusline of the - bottom-left vertically split window isn't redrawn. (Yegappan - Lakshmanan) -Solution: Redraw all the bottom statuslines. -Files: src/ex_getln.c, src/proto/screen.pro, src/screen.c - -Patch 6.0.140 -Problem: Memory allocated for local mappings and abbreviations is leaked - when the buffer is wiped out. -Solution: Clear the local mappings when deleting a buffer. -Files: src/buffer.c, src/getchar.c, src/proto/getchar.pro, src/vim.h - -Patch 6.0.141 -Problem: When using ":enew" in an empty buffer, some buffer-local things - are not cleared. b:keymap_name is not set. -Solution: Clear user commands and mappings local to the buffer when re-using - the current buffer. Reload the keymap. -Files: src/buffer.c - -Patch 6.0.142 -Problem: When Python is linked statically, loading dynamic extensions might - fail. -Solution: Add an extra linking flag when needed. (Andrew Rodionoff) -Files: src/configure.in, src/auto/configure - -Patch 6.0.143 -Problem: When a syntax item includes a line break in a pattern, the syntax - may not be updated properly when making a change. -Solution: Add the "linebreaks" argument to ":syn sync". -Files: runtime/doc/syntax.txt, src/screen.c, src/structs.h, src/syntax.c - -Patch 6.0.144 -Problem: After patch 6.0.088 redoing "veU" doesn't work. -Solution: Don't add the "U" to the redo buffer, it will be used as an undo - command. -Files: src/normal.c - -Patch 6.0.145 -Problem: When Vim can't read any input it might get stuck. When - redirecting stdin and stderr Vim would not read commands from a - file. (Servatius Brandt) -Solution: When repeatedly trying to read a character when it's not possible, - exit Vim. When stdin and stderr are not a tty, still try reading - from them, but don't do a blocking wait. -Files: src/ui.c - -Patch 6.0.146 -Problem: When 'statusline' contains "%{'-'}" this results in a zero. - (Milan Vancura) -Solution: Don't handle numbers with a minus as a number, they were not - displayed anyway. -Files: src/buffer.c - -Patch 6.0.147 -Problem: It's not easy to mark a Vim version as being modified. The new - license requires this. -Solution: Add the --modified-by argument to configure and the MODIFIED_BY - define. It's used in the intro screen and the ":version" output. -Files: src/auto/configure, src/configure.in, src/config.h.in, - src/feature.h, src/version.c - -Patch 6.0.148 -Problem: After "p" in an empty line, `[ goes to the second character. - (Kontra Gergely) -Solution: Don't increment the column number in an empty line. -Files: src/ops.c - -Patch 6.0.149 -Problem: The pattern "\(.\{-}\)*" causes a hang. When using a search - pattern that causes a stack overflow to be detected Vim could - still hang. -Solution: Correctly report "operand could be empty" when using "\{-}". - Check for "out_of_stack" inside loops to avoid a hang. -Files: src/regexp.c - -Patch 6.0.150 -Problem: When using a multi-byte encoding, patch 6.0.148 causes "p" to work - like "P". (Sung-Hyun Nam) -Solution: Compute the byte length of a multi-byte character. -Files: src/ops.c - -Patch 6.0.151 -Problem: Redrawing the status line and ruler can be wrong when it contains - multi-byte characters. -Solution: Use character width and byte length correctly. (Yasuhiro Matsumoto) -Files: src/screen.c - -Patch 6.0.152 -Problem: strtrans() could hang on an illegal UTF-8 byte sequence. -Solution: Skip over illegal bytes. (Yasuhiro Matsumoto) -Files: src/charset.c - -Patch 6.0.153 -Problem: When using (illegal) double-byte characters and Vim syntax - highlighting Vim can crash. (Yasuhiro Matsumoto) -Solution: Increase a pointer over a character instead of a byte. -Files: src/regexp.c - -Patch 6.0.154 -Problem: MS-DOS and MS-Windows: The menu entries for xxd don't work when - there is no xxd in the path. - When converting back from Hex the filetype may remain "xxd" if it - is not detected. -Solution: When xxd is not in the path use the one in the runtime directory, - where the install program has put it. - Clear the 'filetype' option before detecting the new value. -Files: runtime/menu.vim - -Patch 6.0.155 -Problem: Mac: compilation problems in ui.c after patch 6.0.145. (Axel - Kielhorn) -Solution: Don't call mch_inchar() when NO_CONSOLE is defined. -Files: src/ui.c - -Patch 6.0.156 -Problem: Starting Vim with the -b argument and two files, ":next" doesn't - set 'binary' in the second file, like Vim 5.7. (Norman Diamond) -Solution: Set the global value for 'binary'. -Files: src/option.c - -Patch 6.0.157 -Problem: When defining a user command with "-complete=dir" files will also - be expanded. Also, "-complete=mapping" doesn't appear to work. - (Michael Naumann) -Solution: Use the expansion flags defined with the user command. - Handle expanding mappings specifically. -Files: src/ex_docmd.c - -Patch 6.0.158 -Problem: When getting the warning for a file being changed outside of Vim - and reloading the file, the 'readonly' option is reset, even when - the permissions didn't change. (Marcel Svitalsky) -Solution: Keep 'readonly' set when reloading a file and the permissions - didn't change. -Files: src/fileio.c - -Patch 6.0.159 -Problem: Wildcard expansion for ":emenu" also shows separators. -Solution: Skip menu separators for ":emenu", ":popup" and ":tearoff". - Also, don't handle ":tmenu" as if it was ":tearoff". And leave - out the alternatives with "&" included. -Files: src/menu.c - -Patch 6.0.160 -Problem: When compiling with GCC 3.0.2 and using the "-O2" argument, the - optimizer causes a problem that makes Vim crash. -Solution: Add a configure check to avoid "-O2" for this version of gcc. -Files: src/configure.in, src/auto/configure - -Patch 6.0.161 (extra) -Problem: Win32: Bitmaps don't work with signs. -Solution: Make it possible to use bitmaps with signs. (Muraoka Taro) -Files: src/ex_cmds.c, src/feature.h, src/gui_w32.c, src/gui_x11.c, - src/proto/gui_w32.pro, src/proto/gui_x11.pro - -Patch 6.0.162 -Problem: Client-server: An error message for a wrong expression appears in - the server instead of the client. -Solution: Pass the error message from the server to the client. Also - adjust the example code. (Flemming Madsen) -Files: src/globals.h, src/if_xcmdsrv.c, src/main.c, src/os_mswin.c, - src/proto/if_xcmdsrv.pro, src/proto/os_mswin.pro, - runtime/doc/eval.txt, runtime/tools/xcmdsrv_client.c - -Patch 6.0.163 -Problem: When using a GUI dialog, a file name is sometimes used like it was - a directory. -Solution: Separate path and file name properly. - For GTK, Motif and Athena concatenate directory and file name for - the default selection. -Files: src/diff.c, src/ex_cmds.c, src/ex_cmds2.c, src/ex_docmd.c, - src/gui_athena.c, src/gui_gtk.c, src/gui_motif.c, src/message.c - -Patch 6.0.164 -Problem: After patch 6.0.135 the menu entries for pasting don't work in - Insert and Visual mode. (Muraoka Taro) -Solution: Add <script> to allow script-local mappings. -Files: runtime/menu.vim - -Patch 6.0.165 -Problem: Using --remote and executing locally gives unavoidable error - messages. -Solution: Add --remote-silent and --remote-wait-silent to silently execute - locally. - For Win32 there was no error message when a server didn't exist. -Files: src/eval.c, src/if_xcmdsrv.c, src/main.c, src/os_mswin.c, - src/proto/if_xcmdsrv.pro, src/proto/os_mswin.pro - -Patch 6.0.166 -Problem: GUI: There is no way to avoid dialogs to pop up. -Solution: Add the 'c' flag to 'guioptions': Use console dialogs. (Yegappan - Lakshmanan) -Files: runtime/doc/options.txt, src/option.h, src/message.c - -Patch 6.0.167 -Problem: When 'fileencodings' is "latin2" some characters in the help files - are displayed wrong. -Solution: Force the 'fileencoding' for the help files to be "latin1". -Files: src/fileio.c - -Patch 6.0.168 -Problem: ":%s/\n/#/" doesn't replace at an empty line. (Bruce DeVisser) -Solution: Don't skip matches after joining two lines. -Files: src/ex_cmds.c - -Patch 6.0.169 -Problem: When run as evim and the GUI can't be started we get stuck in a - terminal without menus in Insert mode. -Solution: Exit when using "evim" and "gvim -y" when the GUI can't be - started. -Files: src/main.c - -Patch 6.0.170 -Problem: When printing double-width characters the size of tabs after them - is wrong. (Muraoka Taro) -Solution: Correctly compute the column after a double-width character. -Files: src/ex_cmds2.c - -Patch 6.0.171 -Problem: With 'keymodel' including "startsel", in Insert mode after the end - of a line, shift-Left does not move the cursor. (Steve Hall) -Solution: CTRL-O doesn't move the cursor left, need to do that explicitly. -Files: src/edit.c - -Patch 6.0.172 -Problem: CTRL-Q doesn't replace CTRL-V after CTRL-X in Insert mode while it - does in most other situations. -Solution: Make CTRL-X CTRL-Q work like CTRL-X CTRL-V in Insert mode. -Files: src/edit.c - -Patch 6.0.173 -Problem: When using "P" to insert a line break the cursor remains past the - end of the line. -Solution: Check for the cursor being beyond the end of the line. -Files: src/ops.c - -Patch 6.0.174 -Problem: After using "gd" or "gD" the search direction for "n" may still be - backwards. (Servatius Brandt) -Solution: Reset the search direction to forward. -Files: src/normal.c, src/search.c, src/proto/search.pro - -Patch 6.0.175 -Problem: ":help /\z(\)" doesn't work. (Thomas Koehler) -Solution: Double the backslashes. -Files: src/ex_cmds.c - -Patch 6.0.176 -Problem: When killed by a signal autocommands are still triggered as if - nothing happened. -Solution: Add the v:dying variable to allow autocommands to work differently - when a deadly signal has been trapped. -Files: src/eval.c, src/os_unix.c, src/vim.h - -Patch 6.0.177 -Problem: When 'commentstring' is empty and 'foldmethod' is "marker", "zf" - doesn't work. (Thomas S. Urban) -Solution: Add the marker even when 'commentstring' is empty. -Files: src/fold.c, src/normal.c - -Patch 6.0.178 -Problem: Uninitialized memory read from xp_backslash field. -Solution: Initialize xp_backslash field properly. -Files: src/eval.c, src/ex_docmd.c, src/ex_getln.c, src/misc1.c, src/tag.c - -Patch 6.0.179 -Problem: Win32: When displaying UTF-8 characters may read uninitialized - memory. -Solution: Add utfc_ptr2len_check_len() to avoid reading past the end of a - string. -Files: src/mbyte.c, src/proto/mbyte.pro, src/gui_w32.c - -Patch 6.0.180 -Problem: Expanding environment variables in a string that ends in a - backslash could go past the end of the string. -Solution: Detect the trailing backslash. -Files: src/misc1.c - -Patch 6.0.181 -Problem: When using ":cd dir" memory was leaked. -Solution: Free the allocated memory. Also avoid an uninitialized memory - read. -Files: src/misc2.c - -Patch 6.0.182 -Problem: When using a regexp on multi-byte characters, could try to read a - character before the start of the line. -Solution: Don't decrement a pointer to before the start of the line. -Files: src/regexp.c - -Patch 6.0.183 -Problem: Leaking memory when ":func!" redefines a function. -Solution: Free the function name when it's not used. -Files: src/eval.c - -Patch 6.0.184 -Problem: Leaking memory when expanding option values. -Solution: Don't always copy the expanded option into allocated memory. -Files: src/option.c - -Patch 6.0.185 -Problem: Crash in Vim when pasting a selection in another application, on a - 64 bit machine. -Solution: Fix the format for an Atom to 32 bits. (Peter Derr) -Files: src/ui.c - -Patch 6.0.186 -Problem: X11: Three warnings when compiling the client-server code. -Solution: Add a typecast to unsigned char. -Files: src/if_xcmdsrv.c - -Patch 6.0.187 -Problem: "I" in Visual mode and then "u" reports too many changes. (Andrew - Stryker) - "I" in Visual linewise mode adjusts the indent for no apparent - reason. -Solution: Only save those lines for undo that are changed. - Don't change the indent after inserting in Visual linewise mode. -Files: src/ops.c - -Patch 6.0.188 -Problem: Win32: After patch 6.0.161 signs defined in the vimrc file don't - work. -Solution: Initialize the sign icons after initializing the GUI. (Vince - Negri) -Files: src/gui.c, src/gui_x11.c - -Patch 6.0.189 -Problem: The size of the Visual area isn't always displayed when scrolling - ('ruler' off, 'showcmd' on). Also not when using a search - command. (Sylvain Hitier) -Solution: Redisplay the size of the selection after showing the mode. -Files: src/screen.c - -Patch 6.0.190 -Problem: GUI: when 'mouse' is empty a click with the middle button still - moves the cursor. -Solution: Paste at the cursor position instead of the mouse position. -Files: src/normal.c - -Patch 6.0.191 -Problem: When no servers are available serverlist() gives an error instead - of returning an empty string. (Hari Krishna) -Solution: Don't give an error message. -Files: src/eval.c - -Patch 6.0.192 -Problem: When 'virtualedit' is set, "ylj" goes to the wrong column. (Andrew - Nikitin) -Solution: Reset the flag that w_virtcol is valid when moving the cursor back - to the start of the operated area. -Files: src/normal.c - -Patch 6.0.193 -Problem: When 'virtualedit' is set, col(".") after the end of the line - should return one extra. -Solution: Add one to the column. -Files: src/eval.c - -Patch 6.0.194 -Problem: "--remote-silent" tries to send a reply to the client, like it was - "--remote-wait". -Solution: Properly check for the argument. -Files: src/main.c - -Patch 6.0.195 -Problem: When 'virtualedit' is set and a search starts in virtual space - ":call search('x')" goes to the wrong position. (Eric Long) -Solution: Reset coladd when finding a match. -Files: src/search.c - -Patch 6.0.196 -Problem: When 'virtualedit' is set, 'selection' is "exclusive" and visually - selecting part of a tab at the start of a line, "x" joins it with - the previous line. Also, when the selection spans more than one - line the whole tab is deleted. -Solution: Take coladd into account when adjusting for 'selection' being - "exclusive". Also expand a tab into spaces when deleting more - than one line. -Files: src/normal.c, src/ops.c - -Patch 6.0.197 -Problem: When 'virtualedit' is set and 'selection' is "exclusive", "v$x" - doesn't delete the last character in the line. (Eric Long) -Solution: Don't reset the inclusive flag. (Helmut Stiegler) -Files: src/normal.c - -Patch 6.0.198 -Problem: When 'virtualedit' is set and 'showbreak' is not empty, moving the - cursor over the line break doesn't work properly. (Eric Long) -Solution: Make getviscol() and getviscol2() use getvvcol() to obtain the - virtual cursor position. Adjust coladvance() and oneleft() to - skip over the 'showbreak' characters. -Files: src/edit.c, src/misc2.c - -Patch 6.0.199 -Problem: Multi-byte: could use iconv() after calling iconv_end(). - (Yasuhiro Matsumoto) -Solution: Stop converting input and output stream after calling iconv_end(). -Files: src/mbyte.c - -Patch 6.0.200 -Problem: A script that starts with "#!perl" isn't recognized as a Perl - filetype. -Solution: Ignore a missing path in a script header. Also, speed up - recognizing scripts by simplifying the patterns used. -Files: runtime/scripts.vim - -Patch 6.0.201 -Problem: When scrollbinding and doing a long jump, switching windows jumps - to another position in the file. Scrolling a few lines at a time - is OK. (Johannes Zellner) -Solution: When setting w_topline reset the flag that indicates w_botline is - valid. -Files: src/diff.c - -Patch 6.0.202 -Problem: The "icon=" argument for the menu command to define a toolbar icon - with a file didn't work for GTK. (Christian J. Robinson) - For Motif and Athena a full path was required. -Solution: Search the icon file using the specified path. Expand environment - variables in the file name. -Files: src/gui_gtk.c, src/gui_x11.c - -Patch 6.0.203 -Problem: Can change 'fileformat' even though 'modifiable' is off. - (Servatius Brandt) -Solution: Correct check for kind of set command. -Files: src/option.c - -Patch 6.0.204 -Problem: ":unlet" doesn't work for variables with curly braces. (Thomas - Scott Urban) -Solution: Handle variable names with curly braces properly. (Vince Negri) -Files: src/eval.c - -Patch 6.0.205 (extra) -Problem: "gvim -f" still forks when using the batch script to start Vim. -Solution: Add an argument to "start" to use a foreground session (Michael - Geddes) -Files: src/dosinst.c - -Patch 6.0.206 -Problem: Unix: if expanding a wildcard in a file name results in a - wildcard character and there are more parts in the path with a - wildcard, it is expanded again. - Windows: ":edit \[abc]" could never edit the file "[abc]". -Solution: Don't expand wildcards in already expanded parts. - Don't remove backslashes used to escape the special meaning of a - wildcard; can edit "[abc]" if '[' is removed from 'isfname'. -Files: src/misc1.c, src/os_unix.c - -Patch 6.0.207 (extra) -Problem: Win32: The shortcuts and start menu entries let Vim startup in the - desktop directory, which is not very useful. -Solution: Let shortcuts start Vim in $HOME or $HOMEDIR$HOMEPATH. -Files: src/dosinst.c - -Patch 6.0.208 -Problem: GUI: When using a keymap and the cursor is not blinking, CTRL-^ in - Insert mode doesn't directly change the cursor color. (Alex - Solow) -Solution: Force a redraw of the cursor after CTRL-^. -Files: src/edit.c - -Patch 6.0.209 -Problem: GUI GTK: After selecting a 'guifont' with the font dialog there - are redraw problems for multi-byte characters. -Solution: Separate the font dialog from setting the new font name to avoid - that "*" is used to find wide and bold fonts. - When redrawing extra characters for the bold trick, take care of - UTF-8 characters. -Files: src/gui.c, src/gui_gtk_x11.c, src/option.c, src/proto/gui.pro, - src/proto/gui_gtk_x11.pro - -Patch 6.0.210 -Problem: After patch 6.0.167 it's no longer possible to edit a help file in - another encoding than latin1. -Solution: Let the "++enc=" argument overrule the encoding. -Files: src/fileio.c - -Patch 6.0.211 -Problem: When reading a file fails, the buffer is empty, but it might still - be possible to write it with ":w" later. The original file is - lost then. (Steve Amerige) -Solution: Set the 'readonly' option for the buffer. -Files: src/fileio.c - -Patch 6.0.212 -Problem: GUI GTK: confirm("foo", "") causes a crash. -Solution: Don't make a non-existing button the default. Add a default "OK" - button if none is specified. -Files: src/eval.c, src/gui_gtk.c - -Patch 6.0.213 -Problem: When a file name contains unprintable characters, CTRL-G and other - commands don't work well. -Solution: Turn unprintable into printable characters. (Yasuhiro Matsumoto) -Files: src/buffer.c, src/charset.c - -Patch 6.0.214 -Problem: When there is a buffer without a name, empty entries appear in the - jumplist saved in the viminfo file. -Solution: Don't write jumplist entries without a file name. -Files: src/mark.c - -Patch 6.0.215 -Problem: After using "/" from Visual mode the Paste menu and Toolbar - entries don't work. Pasting with the middle mouse doesn't work - and modeless selection doesn't work. -Solution: Use the command line mode menus and use the mouse like in the - command line. -Files: src/gui.c, src/menu.c, src/ui.c - -Patch 6.0.216 -Problem: After reloading a file, displayed in another window than the - current one, which was changed outside of Vim the part of the file - around the cursor set by autocommands may be displayed, but - jumping back to the original cursor position when entering the - window again. -Solution: Restore the topline of the window. -Files: src/fileio.c - -Patch 6.0.217 -Problem: When getting help from a help file that was used before, an empty - unlisted buffer remains in the buffer list. (Eric Long) -Solution: Wipe out the buffer used to do the tag jump from. -Files: src/buffer.c, src/ex_cmds.c, src/proto/buffer.pro - -Patch 6.0.218 -Problem: With explorer plugin: "vim -o filename dirname" doesn't load the - explorer window until entering the window. -Solution: Call s:EditDir() for each window after starting up. -Files: runtime/plugin/explorer.vim - -Patch 6.0.219 -Problem: ":setlocal" and ":setglobal", without arguments, display terminal - options. (Zdenek Sekera) -Solution: Skip terminal options for these two commands. -Files: src/option.c - -Patch 6.0.220 -Problem: After patch 6.0.218 get a beep on startup. (Muraoka Taro) -Solution: Don't try going to another window when there isn't one. -Files: runtime/plugin/explorer.vim - -Patch 6.0.221 -Problem: When using ":bdel" and all other buffers are unloaded the lowest - numbered buffer is jumped to instead of the most recent one. (Dave - Cecil) -Solution: Prefer an unloaded buffer from the jumplist. -Files: src/buffer.c - -Patch 6.0.222 -Problem: When 'virtualedit' is set and using autoindent, pressing Esc after - starting a new line leaves behind part of the autoindent. (Helmut - Stiegler) -Solution: After deleting the last char in the line adjust the cursor - position in del_bytes(). -Files: src/misc1.c, src/ops.c - -Patch 6.0.223 -Problem: When splitting a window that contains the explorer, hitting CR on - a file name gives error messages. -Solution: Set the window variables after splitting the window. -Files: runtime/plugin/explorer.vim - -Patch 6.0.224 -Problem: When 'sidescroll' and 'sidescrolloff' are set in a narrow window - the text may jump left-right and the cursor is displayed in the - wrong position. (Aric Blumer) -Solution: When there is not enough room, compute the left column for the - window to put the cursor in the middle. -Files: src/move.c - -Patch 6.0.225 -Problem: In Visual mode "gk" gets stuck in a closed fold. (Srinath - Avadhanula) -Solution: Behave differently in a closed fold. -Files: src/normal.c - -Patch 6.0.226 -Problem: When doing ":recover file" get the ATTENTION prompt. - After recovering the same file five times get a read error or a - crash. (Alex Davis) -Solution: Set the recoverymode flag before setting the file name. - Correct the amount of used memory for the size of block zero. -Files: src/ex_docmd.c - -Patch 6.0.227 (extra) -Problem: The RISC OS port has several problems. -Solution: Update the makefile and fix some of the problems. (Andy Wingate) -Files: src/Make_ro.mak, src/os_riscos.c, src/os_riscos.h, - src/proto/os_riscos.pro, src/search.c - -Patch 6.0.228 -Problem: After putting text in Visual mode the '] mark is not at the end of - the put text. - Undo doesn't work properly when putting a word into a Visual - selection that spans more than one line. -Solution: Correct the '] mark for the deleting the Visually selected text. - #ifdef code that depends on FEAT_VISUAL properly. - Also fix that "d" crossing line boundary puts '[ just before - deleted text. - Fix undo by saving all deleted lines at once. -Files: src/ex_docmd.c, src/globals.h, src/normal.c, src/ops.c, - src/structs.h, src/vim.h - -Patch 6.0.229 -Problem: Multi-byte: With 'm' in 'formatoptions', formatting doesn't break - at a multi-byte char followed by an ASCII char, and the other way - around. (Muraoka Taro) - When joining lines a space is inserted between multi-byte - characters, which is not always wanted. -Solution: Check for multi-byte character before and after the breakpoint. - Don't insert a space before or after a multi-byte character when - joining lines and the 'M' flag is in 'formatoptions'. Don't - insert a space between multi-byte characters when the 'B' flag is - in 'formatoptions'. -Files: src/edit.c, src/ops.c, src/option.h - -Patch 6.0.230 -Problem: The ":" used as a motion after an operator is exclusive, but - sometimes it should be inclusive. -Solution: Make the "v" in between an operator and motion toggle - inclusive/exclusive. (Servatius Brandt) -Files: runtime/doc/motion.txt, src/normal.c - -Patch 6.0.231 -Problem: "gd" and "gD" don't work when the variable matches in a comment - just above the match to be found. (Servatius Brandt) -Solution: Continue searching in the first column below the comment. -Files: src/normal.c - -Patch 6.0.232 -Problem: "vim --version" prints on stderr while "vim --help" prints on - stdout. -Solution: Make "vim --version" use stdout. -Files: runtime/doc/starting.txt, src/globals.h, src/main.c, src/message.c - -Patch 6.0.233 -Problem: "\1\{,8}" in a regexp is not allowed, but it should work, because - there is an upper limit. (Jim Battle) -Solution: Allow using "\{min,max}" after an atom that can be empty if there - is an upper limit. -Files: src/regexp.c - -Patch 6.0.234 -Problem: It's not easy to set the cursor position without modifying marks. -Solution: Add the cursor() function. (Yegappan Lakshmanan) -Files: runtime/doc/eval.txt, src/eval.c - -Patch 6.0.235 -Problem: When writing a file and renaming the original file to make the - backup, permissions could change when setting the owner. -Solution: Only set the owner when it's needed and set the permissions again - afterwards. - When 'backupcopy' is "auto" check that the owner and permissions - of a newly created file can be set properly. -Files: src/fileio.c - -Patch 6.0.236 -Problem: ":edit" without argument should move cursor to line 1 in Vi - compatible mode. -Solution: Add 'g' flag to 'cpoptions'. -Files: runtime/doc/options.txt, src/ex_docmd.c, src/option.h - -Patch 6.0.237 -Problem: In a C file, using the filetype plugin, re-indenting a comment - with two spaces after the middle "*" doesn't align properly. -Solution: Don't use a middle entry from a start/middle/end to line up with - the start of the comment when the start part doesn't match with - the actual comment start. -Files: src/misc1.c - -Patch 6.0.238 -Problem: Using a ":substitute" command with a substitute() call in the - substitution expression causes errors. (Srinath Avadhanula) -Solution: Save and restore pointers when doing substitution recursively. -Files: src/regexp.c - -Patch 6.0.239 -Problem: Using "A" to append after a Visually selected block which is after - the end of the line, spaces are inserted in the wrong line and - other unexpected effects. (Michael Naumann) -Solution: Don't advance the cursor to the next line. -Files: src/ops.c - -Patch 6.0.240 -Problem: Win32: building with Python 2.2 doesn't work. -Solution: Add support for Python 2.2 with dynamic linking. (Paul Moore) -Files: src/if_python.c - -Patch 6.0.241 -Problem: Win32: Expanding the old value of an option that is a path that - starts with a backslash, an extra backslash is inserted. -Solution: Only insert backslashes where needed. - Also handle multi-byte characters properly when removing - backslashes. -Files: src/option.c - -Patch 6.0.242 -Problem: GUI: On a system with an Exceed X server sometimes get a "Bad - Window" error. (Tommi Maekitalo) -Solution: When forking, use a pipe to wait in the parent for the child to - have done the setsid() call. -Files: src/gui.c - -Patch 6.0.243 -Problem: Unix: "vim --version" outputs a NL before the last line instead of - after it. (Charles Campbell) -Solution: Send the NL to the same output stream as the text. -Files: src/message.c, src/os_unix.c, src/proto/message.pro - -Patch 6.0.244 -Problem: Multi-byte: Problems with (illegal) UTF-8 characters in menu and - file name (e.g., icon text, status line). -Solution: Correctly handle unprintable characters. Catch illegal UTF-8 - characters and replace them with <xx>. Truncating the status line - wasn't done correctly at a multi-byte character. (Yasuhiro - Matsumoto) - Added correct_cmdspos() and transchar_byte(). -Files: src/buffer.c, src/charset.c, src/ex_getln.c, src/gui.c, - src/message.c, src/screen.c, src/vim.h - -Patch 6.0.245 -Problem: After using a color scheme, setting the 'background' option might - not work. (Peter Horst) -Solution: Disable the color scheme if it switches 'background' back to the - wrong value. -Files: src/option.c - -Patch 6.0.246 -Problem: ":echomsg" didn't use the highlighting set by ":echohl". (Gary - Holloway) -Solution: Use the specified attributes for the message. (Yegappan - Lakshmanan) -Files: src/eval.c - -Patch 6.0.247 -Problem: GTK GUI: Can't use gvim in a kpart widget. -Solution: Add the "--echo-wid" argument to let Vim echo the window ID on - stdout. (Philippe Fremy) -Files: runtime/doc/starting.txt, src/globals.h, src/gui_gtk_x11.c, - src/main.c - -Patch 6.0.248 -Problem: When using compressed help files and 'encoding' isn't "latin1", - Vim converts the help file before decompressing. (David Reviejo) -Solution: Don't convert a help file when 'binary' is set. -Files: src/fileio.c - -Patch 6.0.249 -Problem: "vim -t edit -c 'sta ex_help'" doesn't move cursor to edit(). -Solution: Don't set the cursor on the first line for "-c" arguments when - there also is a "-t" argument. -Files: src/main.c - -Patch 6.0.250 (extra) -Problem: Macintosh: Various problems when compiling. -Solution: Various fixes, mostly #ifdefs. (Dany St. Amant) -Files: src/gui_mac.c, src/main.c, src/misc2.c, src/os_mac.h, - src/os_mac.pbproj/project.pbxproj, src/os_unix.c - -Patch 6.0.251 (extra) -Problem: Macintosh: menu shortcuts are not very clear. -Solution: Show the shortcut with the Mac clover symbol. (raindog) -Files: src/gui_mac.c - -Patch 6.0.252 -Problem: When a user function was defined with "abort", an error that is - not inside if/endif or while/endwhile doesn't abort the function. - (Servatius Brandt) -Solution: Don't reset did_emsg when the function is to be aborted. -Files: src/ex_docmd.c - -Patch 6.0.253 -Problem: When 'insertmode' is set, after "<C-O>:edit file" the next <C-O> - doesn't work. (Benji Fisher) <C-L> has the same problem. -Solution: Reset need_start_insertmode once in edit(). -Files: src/edit.c - -Patch 6.0.254 (extra) -Problem: Borland C++ 5.5: Checking for stack overflow doesn't work - correctly. Matters when using a complicated regexp. -Solution: Remove -N- from Make_bc5.mak. (Yasuhiro Matsumoto) -Files: src/Make_bc5.mak - -Patch 6.0.255 (extra) (depends on patch 6.0.116 and 6.0.121) -Problem: Win32: ACL support doesn't work well on Samba drives. -Solution: Add a check for working ACL support. (Mike Williams) -Files: src/os_win32.c - -Patch 6.0.256 (extra) -Problem: Win32: ":highlight Comment guifg=asdf" does not give an error - message. (Randall W. Morris) Also for other systems. -Solution: Add gui_get_color() to give one error message for all systems. -Files: src/gui.c, src/gui_amiga.c, src/gui_athena.c, src/gui_motif.c, - src/gui_riscos.c, src/gui_x11.c, src/gui_gtk_x11.c, - src/proto/gui.pro, src/syntax.c - -Patch 6.0.257 -Problem: Win32: When 'mousefocus' is set and there is a BufRead - autocommand, after the dialog for permissions changed outside of - Vim: 'mousefocus' stops working. (Robert Webb) -Solution: Reset need_mouse_correct after checking timestamps. -Files: src/fileio.c - -Patch 6.0.258 -Problem: When 'scrolloff' is 999 and there are folds, the text can jump up - and down when moving the cursor down near the end of the file. - (Lubomir Host) -Solution: When putting the cursor halfway the window start counting lines at - the end of a fold. -Files: src/move.c - -Patch 6.0.259 -Problem: MS-DOS: after editing the command line the cursor shape may remain - like in Insert mode. (Volker Kiefel) -Solution: Reset the cursor shape after editing the command line. -Files: src/ex_getln.c - -Patch 6.0.260 -Problem: GUI: May crash while starting up when giving an error message for - missing color. (Servatius Brandt) -Solution: Don't call gui_write() when still starting up. Don't give error - message for empty color name. Don't use 't_vb' while the GUI is - still starting up. -Files: src/fileio.c, src/gui.c, src/misc1.c, src/ui.c - -Patch 6.0.261 -Problem: nr2char() and char2nr() don't work with multi-byte characters. -Solution: Use 'encoding' for these functions. (Yasuhiro Matsumoto) -Files: runtime/doc/eval.txt, src/eval.c - -Patch 6.0.262 (extra) -Problem: Win32: IME doesn't work properly. OnImeComposition() isn't used - at all. -Solution: Adjust various things for IME. -Files: src/globals.h, src/gui_w32.c, src/mbyte.c, src/proto/ui.pro, - src/structs.h, src/ui.c - -Patch 6.0.263 -Problem: GTK: When a dialog is closed by the window manager, Vim hangs. - (Christian J. Robinson) -Solution: Use GTK_WIDGET_DRAWABLE() instead of GTK_WIDGET_VISIBLE(). -Files: src/gui_gtk.c, src/gui_gtk_x11.c - -Patch 6.0.264 -Problem: The amount of virtual memory is used to initialize 'maxmemtot', - which may be much more than the amount of physical memory, - resulting in a lot of swapping. -Solution: Get the amount of physical memory with sysctl(), sysconf() or - sysinfo() when possible. -Files: src/auto/configure, src/configure.in, src/config.h.in, - src/os_unix.c, src/os_unix.h - -Patch 6.0.265 -Problem: Win32: Using backspace while 'fkmap' is set causes a crash. - (Jamshid Oasjmoha) -Solution: Don't try mapping special keys. -Files: src/farsi.c - -Patch 6.0.266 -Problem: The rename() function deletes the file if the old and the new name - are the same. (Volker Kiefel) -Solution: Don't do anything if the names are equal. -Files: src/fileio.c - -Patch 6.0.267 -Problem: UTF-8: Although 'isprint' says a character is printable, - utf_char2cells() still considers it unprintable. -Solution: Use vim_isprintc() for characters upto 0x100. (Yasuhiro Matsumoto) -Files: src/mbyte.c - -Patch 6.0.268 (extra) (depends on patch 6.0.255) -Problem: Win32: ACL check crashes when using forward slash in file name. -Solution: Improve the check for the path in the file name. -Files: src/os_win32.c - -Patch 6.0.269 -Problem: Unprintable characters in a file name may cause problems when - using the 'statusline' option or when 'buftype' is "nofile". -Solution: call trans_characters() for the resulting statusline. (Yasuhiro - Matsumoto) -Files: src/buffer.c, src/screen.c, src/charset.c - -Patch 6.0.270 (depends on patch 6.0.267) -Problem: A tab causes UTF-8 text to be displayed in the wrong position. - (Ron Aaron) -Solution: Correct utf_char2cells() again. -Files: src/mbyte.c - -Patch 6.1a.001 (extra) -Problem: 32bit DOS: copying text to the clipboard may cause a crash. - (Jonathan D Johnston) -Solution: Don't copy one byte too much in SetClipboardData(). -Files: src/os_msdos.c - -Patch 6.1a.002 -Problem: GTK: On some configurations, when closing a dialog from the window - manager, Vim hangs. -Solution: Catch the "destroy" signal. (Aric Blumer) -Files: src/gui_gtk.c - -Patch 6.1a.003 -Problem: Multi-byte: With UTF-8 double-wide char and 'virtualedit' set: - yanking in Visual mode doesn't include the last byte. (Eric Long) -Solution: Don't add a space for a double-wide character. -Files: src/ops.c - -Patch 6.1a.004 (extra) -Problem: MINGW: undefined type. (Ron Aaron) -Solution: Make GetCompositionString_inUCS2() static. -Files: src/gui_w32.c, src/gui_w48.c, src/proto/gui_w32.pro - -Patch 6.1a.005 (extra) -Problem: Win32: ":hardcopy" doesn't work after ":hardcopy!". (Jonathan - Johnston) -Solution: Don't keep the driver context when using ":hardcopy!". (Vince - Negri) -Files: src/os_mswin.c - -Patch 6.1a.006 -Problem: multi-byte: after setting 'encoding' the window title might be - wrong. -Solution: Force resetting the title. (Yasuhiro Matsumoto) -Files: src/option.c - -Patch 6.1a.007 -Problem: Filetype detection for "*.inc" doesn't work. -Solution: Use a ":let" command. (David Schweikert) -Files: runtime/filetype.vim - -Patch 6.1a.008 (extra) -Problem: Win32: ACL detection for network shares doesn't work. -Solution: Include the trailing (back)slash in the root path. (Mike Williams) -Files: src/os_win32.c - -Patch 6.1a.009 -Problem: When using "\@<=" or "\@<!" in a pattern, a "\1" may refer to a () - part that follows, but it generates an error message. -Solution: Allow a forward reference when there is a following "\@<=" or - "\@<!". -Files: runtime/doc/pattern.txt, src/regexp.c - -Patch 6.1a.010 -Problem: When using ":help" and opening a new window, the alternate file - isn't set. -Solution: Set the alternate file to the previously edited file. -Files: src/ex_cmds.c - -Patch 6.1a.011 -Problem: GTK: ":set co=77", change width with the mouse, ":set co=77" - doesn't resize the window. (Darren Hiebert) -Solution: Set the form size after handling a resize event. -Files: src/gui_gtk_x11.c - -Patch 6.1a.012 -Problem: GTK: The file browser always returns a full path. (Lohner) -Solution: Shorten the file name if possible. -Files: src/gui_gtk.c - -Patch 6.1a.013 -Problem: When using "=~word" in 'cinkeys' or 'indentkeys', the case of the - last character of the word isn't ignored. (Raul Segura Acevedo) -Solution: Ignore case when checking the last typed character. -Files: src/edit.c - -Patch 6.1a.014 -Problem: After patch 6.1a.006 can't compile without the title feature. -Solution: Add an #ifdef. -Files: src/option.c - -Patch 6.1a.015 -Problem: MS-Windows: When expanding a file name that contains a '[' or '{' - an extra backslash is inserted. (Raul Segura Acevedo) -Solution: Avoid adding the backslash. -Files: src/ex_getln.c - -Patch 6.1a.016 -Problem: Completion after ":language" doesn't include "time". (Raul Segura - Acevedo) -Solution: Add the alternative to the completions. -Files: src/ex_cmds2.c - -Patch 6.1a.017 -Problem: Clicking the mouse in the top row of a window where the first line - doesn't fit moves the cursor to the wrong column. -Solution: Add the skipcol also for the top row of a window. -Files: src/ui.c - -Patch 6.1a.018 -Problem: When 'scrolloff' is one and the window height is one, "gj" can put - the cursor above the window. (Raul Segura Acevedo) -Solution: Don't let skipcol become bigger than the cursor column. -Files: src/move.c - -Patch 6.1a.019 -Problem: When using a composing character on top of an ASCII character, the - "l" command clears the composing character. Only when 'ruler' and - 'showcmd' are off. (Raphael Finkel) -Solution: Don't move the cursor by displaying characters when there are - composing characters. -Files: src/screen.c - -Patch 6.1a.020 -Problem: GTK: after patch 6.1a.011 resizing with the mouse doesn't always - work well for small sizes. (Adrien Beau) -Solution: Use another way to avoid the problem with ":set co=77". -Files: src/gui_gtk_x11.c - -Patch 6.1a.021 -Problem: Several Syntax menu entries are wrong or confusing. -Solution: Rephrase and correct the menu entries. (Adrien Beau) -Files: runtime/makemenu.vim, runtime/menu.vim - -Patch 6.1a.022 -Problem: A tags file might be used twice on case insensitive systems. - (Rick Swanton) -Solution: Don't use the same file name twice in the default for the 'tags' - option. Ignore case when comparing names of already visited - files. -Files: src/misc2.c, src/option.c - -Patch 6.1a.023 -Problem: When starting the GUI get "C" characters echoed in the terminal. -Solution: Don't try sending a clear-screen command while the GUI is starting - up. -Files: src/screen.c - -Patch 6.1a.024 -Problem: In other editors CTRL-F is often used for a find dialog. -Solution: In evim use CTRL-F for the find dialog. -Files: runtime/evim.vim - -Patch 6.1a.025 -Problem: The choices for the fileformat dialog can't be translated. -Solution: Add g:menutrans_fileformat_choices. (Adrien Beau) -Files: runtime/menu.vim - -Patch 6.1a.026 -Problem: Indenting Java files is wrong with "throws", "extends" and - "implements" clauses. -Solution: Update the Java indent script. -Files: runtime/indent/java.vim - -Patch 6.1a.027 -Problem: A few Syntax menu entries missing or incorrect. -Solution: Add and correct the menu entries. (Adrien Beau) - Shorten a few menus to avoid they become too long. -Files: runtime/makemenu.vim, runtime/menu.vim - -Patch 6.1a.028 -Problem: XIM: problems with feedback and some input methods. -Solution: Use iconv for calculating the cells. Remove the queue for - key_press_event only when text was changed. (Yasuhiro Matsumoto) -Files: src/globals.h, src/mbyte.c, src/screen.c - -Patch 6.1a.029 -Problem: After patch 6.1a.028 can't compile GTK version with XIM but - without multi-byte chars. -Solution: Add an #ifdef. (Aschwin Marsman) -Files: src/mbyte.c - -Patch 6.1a.030 -Problem: With double-byte encodings toupper() and tolower() may have wrong - results. -Solution: Skip double-byte characters. (Eric Long) -Files: src/eval.c - -Patch 6.1a.031 -Problem: Accessing the 'balloondelay' variable may cause a crash. -Solution: Make the variable for 'balloondelay' a long. (Olaf Seibert) -Files: src/option.h - -Patch 6.1a.032 (extra) -Problem: Some menu files used a wrong encoding name for "scriptencoding". -Solution: Move the translations to a separate file, which is sourced after - setting "scriptencoding". - Also add Czech menu translations in ASCII and update the other - encodings. -Files: runtime/lang/menu_cs_cz.iso_8859-1.vim, - runtime/lang/menu_cs_cz.iso_8859-2.vim, - runtime/lang/menu_czech_czech_republic.1250.vim, - runtime/lang/menu_czech_czech_republic.1252.vim, - runtime/lang/menu_czech_czech_republic.ascii.vim, - runtime/lang/menu_de_de.iso_8859-1.vim, - runtime/lang/menu_de_de.latin1.vim, - runtime/lang/menu_fr_fr.iso_8859-1.vim, - runtime/lang/menu_fr_fr.latin1.vim, - runtime/lang/menu_french_france.1252.vim, - runtime/lang/menu_german_germany.1252.vim, - runtime/lang/menu_ja_jp.euc-jp.vim, - runtime/lang/menu_ja_jp.utf-8.vim, - runtime/lang/menu_japanese_japan.932.vim - -Patch 6.1a.033 -Problem: XIM: doesn't reset input context. -Solution: call xim_reset() with im_set_active(FALSE). (Takuhiro Nishioka) -Files: src/mbyte.c - -Patch 6.1a.034 (extra) -Problem: Win32: The ACL checks for a readonly file still don't work well. -Solution: Remove the ACL checks, go back to how it worked in Vim 6.0. -Files: src/os_win32.c - -Patch 6.1a.035 -Problem: multi-byte: When using ":sh" in the GUI, typed and displayed - multi-byte characters are not handled correctly. -Solution: Deal with multi-byte characters to and from the shell. (Yasuhiro - Matsumoto) Also handle UTF-8 composing characters. -Files: src/os_unix.c - -Patch 6.1a.036 -Problem: GTK: the save-yourself event was not handled. -Solution: Catch the save-yourself event and preserve swap files. (Neil Bird) -Files: src/gui_gtk_x11.c - -Patch 6.1a.037 -Problem: The MS-Windows key mapping doesn't include CTRL-S for saving. - (Vlad Sandrini) -Solution: Map CTRL-S to ":update". -Files: runtime/mswin.vim - -Patch 6.1a.038 -Problem: Solaris: Including both sys/sysctl.h and sys/sysinfo.h doesn't - work. (Antonio Colombo) -Solution: Don't include sys/sysinfo.h when not calling sysinfo(). -Files: src/os_unix.c - -Patch 6.1a.039 -Problem: Not all visual basic files are recognized. -Solution: Add checks to catch *.ctl files. (Raul Segura Acevedo) -Files: runtime/filetype.vim - -Patch 6.1a.040 -Problem: A *.pl file is recognized as Perl, but it could be a prolog file. -Solution: Check the first non-empty line. (Kontra Gergely) -Files: runtime/filetype.vim - -Patch 6.1a.041 -Problem: When pressing the left mouse button in the command line and them - moving the mouse upwards, nearly all the text is selected. -Solution: Don't try extending a modeless selection when there isn't one. -Files: src/ui.c - -Patch 6.1a.042 -Problem: When merging files, ":diffput" and ":diffget" are used a lot, but - they require a lot of typing. -Solution: Add "dp" for ":diffput" and "do" for ":diffget". -Files: runtime/doc/diff.txt, src/diff.c, src/normal.c, src/proto/diff.pro - - -Patch 6.1b.001 (extra) -Problem: Checking for wildcards in a path does not handle multi-byte - characters with a trail byte which is a wildcard. -Solution: Handle multi-byte characters correctly. (Muraoka Taro) -Files: src/os_amiga.c, src/os_mac.c, src/os_msdos.c, src/os_mswin.c, - src/os_unix.c - -Patch 6.1b.002 -Problem: A regexp that ends in "\{" is not flagged as an error. May cause - a stack overflow when 'incsearch' is set. (Gerhard Hochholzer) -Solution: Handle a missing "}" as an error. -Files: src/regexp.c - -Patch 6.1b.003 (extra) -Problem: The RISC OS GUI doesn't compile. -Solution: Include changes since Vim 5.7. (Andy Wingate) -Files: src/Make_ro.mak, src/gui_riscos.c, src/os_riscos.c, - src/os_riscos.h, src/proto/gui_riscos.pro - -Patch 6.1b.004 -Problem: col("'>") returns a negative number for linewise selection. (Neil - Bird) -Solution: Don't add one to MAXCOL. -Files: src/eval.c - -Patch 6.1b.005 -Problem: Using a search pattern that causes an out-of-stack error while - 'hlsearch' is set keeps giving the hit-Enter prompt. - A search pattern that takes a long time delays typing when - 'incsearch' is set. -Solution: Stop 'hlsearch' highlighting when the regexp causes an error. - Stop searching for 'incsearch' when a character is typed. -Files: src/globals.h, src/message.c, src/screen.c, src/search.c, - src/vim.h - -Patch 6.1b.006 -Problem: When entering a composing character on the command line with - CTRL-V, the text isn't redrawn correctly. -Solution: Redraw the text under and after the cursor. -Files: src/ex_getln.c - -Patch 6.1b.007 -Problem: When the cursor is in the white space between two sentences, "dis" - deletes the first character of the following sentence, "das" - deletes a space after the sentence. -Solution: Backup the cursor one character in these situations. -Files: src/search.c - -Patch 6.1b.008 -Problem: *.xsl files are not recognized as xslt but xml. - Monk files are not recognized. -Solution: Delete the duplicate line for *.xsl. (Johannes Zellner) - Recognize monk files. -Files: runtime/filetype.vim - -Patch 6.1b.009 -Problem: Can't always compile small features and then adding eval feature, - "sandbox" is undefined. (Axel Kielhorn) -Solution: Always define "sandbox" when the eval feature is used. -Files: src/globals.h - -Patch 6.1b.010 (extra) -Problem: When compiling gvimext.cpp with MSVC 4.2 get a number of warnings. -Solution: Change "true" to "TRUE". (Walter Briscoe) -Files: GvimExt/gvimext.cpp - -Patch 6.1b.011 -Problem: When using a very long string for confirm(), can't quit the - displaying at the more prompt. (Hari Krishna Dara) -Solution: Jump to the end of the message to show the choices. -Files: src/message.c - -Patch 6.1b.012 -Problem: Multi-byte: When 'showbreak' is set and a double-wide character - doesn't fit at the right window edge the cursor gets stuck there. - Using cursor-left gets stuck when 'virtualedit' is set. (Eric - Long) -Solution: Fix the way the extra ">" character is counted when 'showbreak' is - set. Don't correct cursor for virtual editing on a double-wide - character. -Files: src/charset.c, src/edit.c - -Patch 6.1b.013 -Problem: A user command that partly matches with a buffer-local user - command and matches full with a global user command unnecessarily - gives an 'ambiguous command' error. -Solution: Find the full global match even after a partly local match. -Files: src/ex_docmd.c - -Patch 6.1b.014 -Problem: EBCDIC: switching mouse events off causes garbage on screen. - Positioning the cursor in the GUI causes garbage. -Solution: Insert an ESC in the terminal code. (Ralf Schandl) - Use "\b" instead of "\010" for KS_LE. -Files: src/os_unix.c, src/term.c - -Patch 6.1b.015 -Problem: Vimtutor has a typo. Get a warning for "tempfile" if it - doesn't exist. -Solution: Move a quote to the end of a line. (Max Ischenko) - Use "mktemp" first, more systems have it. -Files: src/vimtutor - -Patch 6.1b.016 -Problem: GTK: loading a fontset that works partly, Vim might hang or crash. -Solution: Avoid that char_width becomes zero. (Yasuhiro Matsumoto) -Files: src/gui_gtk_x11.c - -Patch 6.1b.017 -Problem: GUI: When using ":shell" and there is a beep, nothing happens. -Solution: Call vim_beep() to produce the beep from the shell. (Yasuhiro - Matsumoto) -Files: src/message.c - -Patch 6.1b.018 (depends on 6.1b.006) -Problem: When entering the encryption key, special keys may still reveal - the typed characters. -Solution: Make sure stars are used or nothing is shown in all cases. -Files: src/digraph.c, src/getchar.c, src/ex_getln.c - -Patch 6.1b.019 (depends on 6.1b.005) -Problem: A search pattern that takes a long time slows down typing when - 'incsearch' is set. -Solution: Pass SEARCH_PEEK to dosearch(). -Files: src/ex_getln.c - -Patch 6.1b.020 -Problem: When using the matchit plugin, "%" finds a match on the "end" of a - ":syntax region" command in Vim scripts. -Solution: Skip over ":syntax region" commands by setting b:match_skip. -Files: runtime/ftplugin/vim.vim - -Patch 6.1b.021 -Problem: when 'mousefocus' is set, CTRL-W CTRL-] sometimes doesn't warp the - pointer to the new window. (Robert Webb) -Solution: Don't reset need_mouse_correct when checking the timestamp of a - file. -Files: src/fileio.c - -Patch 6.1b.022 -Problem: With lots of folds "j" does not obey 'scrolloff' properly. - (Srinath Avadhanula) -Solution: Go to end of the fold before counting context lines. -Files: src/move.c - -Patch 6.1b.023 -Problem: On MS-Windows system() may cause checking timestamps, because Vim - loses and gains input focus, while this doesn't happen on Unix. -Solution: Don't check timestamps while system() is busy. -Files: src/ex_cmds2.c, src/fileio.c, src/globals.h, src/misc1.c - -Patch 6.1b.024 (extra) -Problem: Gettext 0.11 complains that "sjis" is not a standard name. -Solution: Use "cp932" instead. -Files: src/po/sjiscorr.c - -Patch 6.1b.025 (extra) -Problem: Win32: When closing gvim while it is minimized and has a changed - file, the file-changed dialog pops up in a corner of the screen. -Solution: Put the dialog in the middle of the screen. -Files: src/gui_w48.c - -Patch 6.1b.026 -Problem: When 'diffopt' contains 'iwhite' but not 'icase': differences in - case are not highlighted properly. (Gerhard Hochholzer) -Solution: Don't ignore case when ignoring white space differences. -Files: src/diff.c - -Patch 6.1b.027 -Problem: "vim --remote +" may cause a crash. -Solution: Check for missing file name argument. (Martin Kahlert) -Files: src/main.c - -Patch 6.1b.028 (extra) -Problem: Win16: Can't compile after patch 6.1b.025. -Solution: Add code specifically for Win16. (Vince Negri) -Files: src/gui_w48.c - -Patch 6.1b.029 -Problem: Win32: When a directory on an NTFS partition is read/execute (no - delete,modify,write) and the file has modify rights, trying to - write the file deletes it. Making the file read/write/execute - (not delete) solves it. (Mark Canup) -Solution: Use the Unix code to check for a writable directory. If not, then - make a backup copy and overwrite the file. -Files: src/fileio.c - -Patch 6.1b.030 (extra) -Problem: Mac: small mistake in the build script and prototypes. -Solution: Fix the build script and add the prototypes. (Axel Kielhorn) -Files: src/os_mac.build, src/gui_mac.c - -Patch 6.1b.031 (extra) -Problem: Win32 GUI: ":set guifont=*" doesn't set 'guifont' to the resulting - font name. (Vlad Sandrini) -Solution: Put the code back in gui_mch_init_font() to form the font name out - of the logfont. -Files: src/gui_w48.c - -Patch 6.1b.032 -Problem: Athena: Setting a color scheme before the GUI has started causes a - crash. (Todd Blumer) -Solution: Don't try using color names that haven't been set yet. -Files: src/gui_athena.c - -Patch 6.1b.033 -Problem: When using a count after a ":s" command may get ml_get errors. - (Dietmar Lang) -Solution: Check that the resulting range does not go past the end of the - buffer. -Files: src/ex_cmds.c - -Patch 6.1b.034 -Problem: After sourcing mswin.vim, when using <C-S-Right> after - auto-indenting and then <Del>, get warning for allocating - ridiculous amount of memory. (Dave Delgreco) -Solution: Adjust the start of the Visual area when deleting the auto-indent. -Files: src/edit.c - -Patch 6.1b.035 -Problem: When using evim, dropping a file on Vim and then double clicking - on a word, it is changed to "i". (Merlin Hansen) -Solution: Reset need_start_insertmode after editing the file. -Files: src/ex_docmd.c - - -============================================================================== -VERSION 6.2 *version-6.2* - -This section is about improvements made between version 6.1 and 6.2. - -This is mainly a bug-fix release. There are also a few new features. - -Main new features: -- Support for GTK 2. (Daniel Elstner) -- Support for editing Arabic text. (Nadim Shaikli & Isam Bayazidi) -- ":try" command and exception handling. (Servatius Brandt) -- Support for the neXtaw GUI toolkit (mostly like Athena). (Alexey Froloff) -- Cscope support for Win32. (Khorev Sergey) -- Support for PostScript printing in various 8-bit encodings. (Mike Williams) - - -Changed *changed-6.2* -------- - -Removed the scheme indent file, the internal Lisp indenting works well now. - -Moved the GvimEXt, OleVim and VisVim directories into the "src" directory. -This is more consistent with how xxd is handled. - -The VisVim.dll file is installed in the top directory, next to gvimext.dll, -instead of in a subdirectory "VisVim". Fixes that NSIS was uninstalling it -from the wrong directory. - -Removed the art indent file, it didn't do anything. - -submatch() returned line breaks with CR instead of LF. - -Changed the Win32 Makefiles to become more uniform and compile gvimext.dll. -(Dan Sharp) - -'cindent': Align a "//" comment with a "//" comment in a previous line. -(Helmut Stiegler) - -Previously only for xterm-like terminals parent widgets were followed to find -the title and icon label. Now do this for all terminal emulators. - -Made it possible to recognize backslashes for "%" matching. The 'M' flag in -'cpoptions' disables it. (Haakon Riiser) - -Removed the Make_tcc.mak makefile for Turbo C. It didn't work and we probably -can't make it work (the compiler runs out of memory). - -Even though the documentation refers to keywords, "[ CTRL-D" was using -'isident' to find matches. Changed it to use 'iskeyword'. Also applies to -other commands that search for defined words in included files such as -":dsearch", "[D" and "[d". - -Made 'keywordprg' global-local. (Christian Robinson) - -Enabled the Netbeans interface by default. Reversed the configure argument -from "--enable-netbeans" to "--disable-netbeans". - - -Added *added-6.2* ------ - -New options: - 'arabic' - 'arabicshape' - 'ambiwidth' - 'autochdir' - 'casemap' - 'copyindent' - 'cscopequickfix' - 'preserveindent' - 'printencoding' - 'rightleftcmd' - 'termbidi' - 'toolbariconsize' - 'winfixheight' - -New keymaps: - Serbian (Aleksandar Veselinovic) - Chinese Pinyin (Fredrik Roubert) - Esperanto (Antoine J. Mechelynck) - -New syntax files: - Valgrind (Roger Luethi) - Smarty template (Manfred Stienstra) - MySQL (Kenneth Pronovici) - RockLinux package description (Piotr Esden-Tempski) - MMIX (Dirk Huesken) - gkrellmrc (David Necas) - Tilde (Tobias Rundtrom) - Logtalk (Paulo Moura) - PLP (Juerd Waalboer) - fvwm2m4 (David Necas) - IPfilter (Hendrik Scholz) - fstab (Radu Dineiu) - Quake (Nikolai Weibull) - Occam (Mario Schweigler) - lpc (Shizhu Pan) - Exim conf (David Necas) - EDIF (Artem Zankovich) - .cvsrc (Nikolai Weibull) - .fetchmailrc (Nikolai Weibull) - GNU gpg (Nikolai Weibull) - Grub (Nikolai Weibull) - Modconf (Nikolai Weibull) - RCS (Dmitry Vasiliev) - Art (Dorai Sitaram) - Renderman Interface Bytestream (Andrew J Bromage) - Mailcap (Doug Kearns) - Subversion commit file (Dmitry Vasiliev) - Microsoft IDL (Vadim Zeitlin) - WildPackets EtherPeek Decoder (Christopher Shinn) - Spyce (Rimon Barr) - Resolv.conf (Radu Dineiu) - A65 (Clemens Kirchgatterer) - sshconfig and sshdconfig (David Necas) - Cheetah and HTMLCheetah (Max Ischenko) - Packet filter (Camiel Dobbelaar) - -New indent files: - Eiffel (David Clarke) - Tilde (Tobias Rundtrom) - Occam (Mario Schweigler) - Art (Dorai Sitaram) - PHP (Miles Lott) - Dylan (Brent Fulgham) - -New tutor translations: - Slovak (Lubos Celko) - Greek (Christos Kontas) - German (Joachim Hofmann) - Norwegian (Øyvind Holm) - -New filetype plugins: - Occam (Mario Schweigler) - Art (Dorai Sitaram) - ant.vim, aspvbs.vim, config.vim, csc.vim, csh.vim, dtd.vim, html.vim, - jsp.vim, pascal.vim, php.vim, sgml.vim, sh.vim, svg.vim, tcsh.vim, - xhtml.vim, xml.vim, xsd.vim. (Dan Sharp) - -New compiler plugins: - Checkstyle (Doug Kearns) - g77 (Ralf Wildenhues) - fortran (Johann-Guenter Simon) - Xmllint (Doug Kearns) - Ruby (Tim Hammerquist) - Modelsim vcom (Paul Baleme) - -New menu translations: - Brazilian (José de Paula) - British (Mike Williams) - Korean in UTF-8. (Nam SungHyun) - Norwegian (Øyvind Holm) - Serbian (Aleksandar Jelenak) - -New message translation for Norwegian. (Øyvind Holm) - -New color scheme: - desert (Hans Fugal) - -Arabic specific features. 'arabicshape', 'termbidi', 'arabic' and -'rightleftcmd' options. (Nadim Shaikli & Isam Bayazidi) - -Support for neXtaw GUI toolkit, mostly like Athena. (Alexey Froloff) - -Win32: cscope support. (Khorev Sergey) - -VMS: various improvements to documentation and makefiles. (Zoltan Arpadffy) - -Added "x" key to the explorer plugin: execute the default action. (Yasuhiro -Matsumoto) - -Compile gvimext.dll with MingW. (Rene de Zwart) - -Add the "tohtml.vim" plugin. It defines the ":TOhtml" user command, an easy -way to convert text to HTML. - -Added ":try" / ":catch" / ":finally" / ":endtry" commands. Add E999 numbers -to all error messages, so that they can be caught by the number. -(Servatius Brandt) -Moved part of ex_docmd.c to the new ex_eval.c source file. - -Include support for GTK+ 2.2.x (Daniel Elstner) -Adds the "~" register: drag & drop text. -Adds the 'toolbariconsize' option. -Add -Dalloca when running lint to work around a problem with alloca() -prototype. - -When selecting an item in the error window to jump to, take some effort to -find an ordinary window to show the file in (not a preview window). - -Support for PostScript printing of various 8-bit encodings. (Mike Williams) - -inputdialog() accepts a third argument that is used when the dialog is -cancelled. Makes it possible to see a difference between cancelling and -entering nothing. - -Included Aap recipes. Can be used to update Vim to the latest version, -building and installing. - -"/" option in 'cinoptions': extra indent for comment lines. (Helmut Stiegler) - -Vim variable "v:register" and functions setreg(), getreg() and getregtype(). -(Michael Geddes) - -"v" flag in 'cpoptions': Leave text on screen with backspace in Insert mode. -(Phillip Vandry) - -Dosinst.exe also finds gvimext.dll in the "GvimExt" directory. Useful when -running install in the "src" directory for testing. - -Support tag files that were sorted with case ignored. (Flemming Madsen) - -When completing a wildcard in a leading path element, as in "../*/Makefile", -only the last part ("Makefile") was listed. Support custom defined -command line completion. (Flemming Madsen) - -Also recognize "rxvt" as an xterm-like terminal. (Tomas Styblo) - -Proper X11 session management. Fixes that the WM_SAVE_YOURSELF event was not -used by popular desktops. (Neil Bird) -Not used for Gnome 2, it has its own handling. - -Support BOR, DEBUG and SPAWNO arguments for the Borland 3 Makefile. (Walter -Briscoe) - -Support page breaks for printing. Adds the "formfeed" field in -'printoptions'. (Mike Williams) - -Mac OSX: multi-language support: iconv and gettext. (Muraoka Taro, Axel -Kielhorn) - -"\Z" flag in patterns: ignore differences in combining characters. (Ron Aaron) - -Added 'preserveindent' and 'copyindent' options. They use existing white -space characters instead of using Tabs as much as possible. (Chris Leishman) - -Updated Unicode tables to Unicode 4.0. (Raphael Finkel) - -Support for the mouse wheel in rxvt. (AIDA Shinra) - -Win32: Added ":8" file modifier to get short filename. Test50 tests the ":8" -expansion on Win32 systems. (Michael Geddes) - -'cscopequickfix' option: Open quickfix window for Cscope commands. Also -cleanup the code for giving messages. (Khorev Sergey) - -GUI: Support more than 222 columns for mouse positions. - -":stopinsert" command: Don't return to Insert mode. - -"interrupt" command for debug mode. Useful for simulating CTRL-C. (Servatius -Brandt) - - -Fixed *fixed-6.2* ------ - -Removed a few unused #defines from config.h.in, os_os2_cfg.h and os_vms_conf.h. - -The Vim icons in PNG format didn't have a transparent background. (Greg -Roelofs) - -Fixed a large number of spelling mistakes in the docs. (Adri Verhoef) - -The #defines for prototype generation were causing trouble. Changed them to -typedefs. - -A new version of libintl.h uses __asm__, which confuses cproto. Define a -dummy __asm__ macro. - -When 'virtualedit' is set can't move to halfway an unprintable character. -Cripples CTRL-V selection. (Taro Muraoka) -Allow moving to halfway an unprintable character. Don't let getvvcol() change -the pos->coladd argument. - -When a tab wraps to the next line, 'listchars' is set and 'foldcolumn' is -non-zero, only one character of the foldcolumn is highlighted. (Muraoka Taro) - -When using ":catch" without an argument Vim crashes. (Yasuhiro Matsumoto) -When no argument given use the ".*" pattern. - -Win32: When gvim.exe is started from a shortcut with the window style property -set to maximize Vim doesn't start with a maximized window. (Yasuhiro -Matsumoto) Open the window with the default size and don't call ShowWindow() -again when it's already visible. (Helmut Stiegler) - -gui_gtk.c used MAX, but it's undefined to avoid a conflict with system header -files. - -Win32: When closing a window from a mapping some pixels remain on the -statusline. (Yasuhiro Matsumoto) - -A column number in an errorformat that goes beyond the end of the line may -cause a crash. - -":throw 'test'" crashes Vim. (Yasuhiro Matsumoto) - -The file selector's scrollbar colors are not set after doing a ":hi Scrollbar -guifg=color". And the file selector's colors are not changed by the -colorscheme command. (David Harrison) - -Motif: When compiling with FEAT_FOOTER defined, the text area gets a few -pixels extra space on the right. Remove the special case in -gui_get_base_width(). (David Harrison) - -Using CTRL-R CTRL-P in Insert mode puts the '] mark in the wrong position. -(Helmut Stiegler) - -When 'formatoptions' includes "awct" a non-comment wasn't auto-formatted. - -Using a "--cmd" argument more than 10 times caused a crash. - -DEC style mouse support didn't work if the page field is not empty. -(Uribarri) - -"vim -l one two" did only set 'lisp' in the first file. Vi does it for every -file. - -":set tw<" didn't work. Was checking for '^' instead of '<'. - -In ":hardcopy > %.ps" the "%" was not expanded to the current filename. - -Made ":redraw" also update the Visual area. - -When a not implemented command, such as ":perl", has wrong arguments the less -important error was reported, giving the user the idea the command could work. - -On non-Unix systems autocommands for writing did not attempt a match with the -short file name, causing a pattern like "a/b" to fail. - -VMS: e_screenmode was not defined and a few other fixes for VMS. (Zoltan -Arpadffy) - -redraw_msg() depended on FEAT_ARABIC instead of FEAT_RIGHTLEFT. (Walter -Briscoe) - -Various changes for the PC Makefiles. (Walter Briscoe) - -Use _truename() instead of our own code to expand a file name into a full -path. (Walter Briscoe) - -Error in filetype check for /etc/modutils. (Lubomir Host) - -Cscope interface: allocated a buffer too small. - -Win16: remove a trailing backslash from a path when obtaining the permission -flags. (Vince Negri) - -When searching for tags with case ignored Vim could hang. - -When searching directories with a stopdir could get a crash. Did not -re-allocate enough memory. (Vince Negri) - -A user command may cause a crash. Don't use the command index when it's -negative. (Vince Negri) - -putenv() didn't work for MingW and Cygwin. (Dan Sharp) - -Many functions were common between os_msdos.c and os_win16.c. Use os_msdos.c -for compiling the Win16 version and remove the functions from os_win16.c. -(Vince Negri) - -For terminals that behave like an xterm but didn't have a name that is -recognized, the window title would not always be set. - -When syntax highlighting is off ":hardcopy" could still attempt printing -colors. - -Crash when using ":catch" without an argument. (Servatius Brandt) - -Win32: ":n #" doubled the backslashes. - -Fixed Arabic shaping for the command line. (Nadim Shaikli) - -Avoid splitting up a string displayed on the command line into individual -characters, it breaks Arabic shaping. - -Updated Cygwin and MingW makefiles to use more dependencies. (Dan Sharp) - -2html.vim didn't work with 'nomagic' set. - -When a local argument list is used and doing ":only" Vim could crash later. -(Muraoka Taro) - -When using "%P" in 'statusline' and the fillchar is "-", a percentage of 3% -could result in "-3%". Also avoid changing a space inside a filename to the -fill character. - -MSwin: Handling of backslashes and double quotes for command line arguments -was not like what other applications do. (Walter Briscoe) - -Test32 sometimes didn't work, because test11.out was written as TEST11.OUT. - -Avoid pointer conversions warnings for Borland C 5.5 in dosinst.c and -uninstal.c. - -More improvements for Make_bc3.mak file. (Walter Briscoe) - -When ":syn sync linebreaks=1" is used, editing the first line caused a redraw -of the whole screen. - -Making translated messages didn't work, if_perl.xs wasn't found. (Vlad -Sandrini) - -Motif and Athena: moving Vim to the foreground didn't uniconify it. Use -XMapRaised() instead of XRaiseWindow(). (Srikanth Sankaran) - -When using ":ptag" in a window where 'scrollbind' is set the preview window -would also have 'scrollbind' set. Also reset 'foldcolumn' and 'diff'. - -Various commands that split a window took over 'scrollbind', which is hardly -ever desired. Esp. for "q:" and ":copen". Mostly reset 'scrollbind' when -splitting a window. - -When 'shellslash' is set in the vimrc file the first entry of ":scriptnames" -would still have backslashes. Entries in the quickfix list could also have -wrong (back)slashes. - -Win32: printer dialog texts were not translated. (Yasuhiro Matsumoto) - -When using a multi-byte character with a K_SPECIAL byte or a special key code -with "--remote-send" the received byte sequence was mangled. Put it in the -typeahead buffer instead of the input buffer. - -Win32: The cursor position was incorrect after changing cursor shape. -(Yasuhiro Matsumoto). - -Win32: When 'encoding' is not the current codepage the title could not be set -to non-ascii characters. - -"vim -d scp://machine/file1 scp://machine/file2" did not work, there was only -one window. Fixed the netrw plugin not to wipe out the buffer if it is -displayed in other windows. - -"/$" caused "e" in last column of screen to disappear, a highlighted blank was -displayed instead. - -":s/ *\ze\n//e" removed the line break and introduced arbitrary text. Was -using the line count including what matched after the "\ze". - -Using the "c" flag with ":s" changed the behavior when a line break is -replaced and "\@<=" is used. Without "c" a following match was not found. - -":%s/\vA@<=\nB@=//gce" got stuck on "A\nB" when entering "n". - -VMS: add HAVE_STRFTIME in the config file. (Zoltan Arpadffy) - -When a delete prompts if a delete should continue when yanking is not -possible, restore msg_silent afterwards. - -":sign" did not complain about a missing argument. - -When adding or deleting a sign 'hlsearch' highlighting could disappear. -Use the generic functions for updating signs. - -On MS-Windows NT, 2K and XP don't use command.com but cmd.exe for testing. -Makes the tests work on more systems. - -In the DOS tests don't create "/tmp" to avoid an error. - -Mac classic: Problems with reading files with CR vs CR/LF. Rely on the -library version of fgets() to work correctly for Metrowerks 2.2. (Axel -Kielhorn) - -When typing a password a "*" was shown for each byte instead of for each -character. Added multi-byte handling to displaying the stars. (Yasuhiro -Matsumoto) - -When using Perl 5.6 accessing $curbuf doesn't work. Add an #ifdef to use -different code for 5.6 and 5.8. (Dan Sharp) - -MingW and Cygwin: Don't strip the debug executable. (Dan Sharp) - -An assignment to a variable with curlies that includes "==" doesn't work. -Skip over the curlies before searching for an "=". (Vince Negri) - -When cancelling the selection of alternate matching tags the tag stack index -could be advanced too far, resulting in an error message when using CTRL-T. - - -Patch 6.1.001 -Problem: When formatting UTF-8 text it might be wrapped at a space that is - followed by a composing character. (Raphael Finkel) - Also correct a display error for removing a composing char on top - of a space. -Solution: Check for a composing character on a space. -Files: src/edit.c, src/misc1.c, src/screen.c - -Patch 6.1.002 (extra) -Problem: Win32: after a ":popup" command the mouse pointer stays hidden. -Solution: Unhide the mouse pointer before showing the menu. -Files: src/gui_w48.c - -Patch 6.1.003 -Problem: When 'laststatus' is zero and there is a vertical split, the - vertical separator is drawn in the command line. (Srikant - Sankaran) -Solution: Don't draw the vertical separator where there is no statusline. -Files: src/screen.c - -Patch 6.1.004 -Problem: Unicode 3.2 changes width and composing of a few characters. - (Markus Kuhn) -Solution: Adjust the Unicode functions for the character width and composing - characters. -Files: src/mbyte.c - -Patch 6.1.005 -Problem: When using more than 50 items in 'statusline' Vim might crash. - (Steve Hall) -Solution: Increment itemcnt in check_stl_option(). (Flemming Madsen) -Files: src/option.c - -Patch 6.1.006 -Problem: When using "P" in Visual mode to put linewise selected text, the - wrong text is deleted. (Jakub Turski) -Solution: Put the text before the Visual area and correct the text to be - deleted for the inserted lines. - Also fix that "p" of linewise text in Visual block mode doesn't - work correctly. -Files: src/normal.c, src/ops.c - -Patch 6.1.007 -Problem: Using ":filetype plugin off" when filetype plugins were never - enabled causes an error message. (Yiu Wing) -Solution: Use ":silent!" to avoid the error message. -Files: runtime/ftplugof.vim - -Patch 6.1.008 -Problem: The "%" command doesn't ignore \" inside a string, it's seen as - the end of the string. (Ken Clark) -Solution: Skip a double quote preceded by an odd number of backslashes. -Files: src/search.c - -Patch 6.1.009 -Problem: Vim crashes when using a huge number for the maxwid value in a - statusline. (Robert M. Nowotniak) -Solution: Check for an overflow that makes maxwid negative. -Files: src/buffer.c - -Patch 6.1.010 -Problem: Searching backwards for a question mark with "?\?" doesn't work. - (Alan Isaac) Same problem in ":s?\??" and ":g?\??". -Solution: Change the "\?" in a pattern to "?" when using "?" as delimiter. -Files: src/ex_cmds.c, src/ex_docmd.c, src/proto/regexp.pro, src/regexp.c, - src/search.c, src/syntax.c, src/tag.c - -Patch 6.1.011 -Problem: XIM: doesn't work correctly when 'number' is set. Also, a focus - problem when selecting candidates. -Solution: Fix the XIM problems. (Yasuhiro Matsumoto) -Files: src/mbyte.c, src/screen.c - -Patch 6.1.012 -Problem: A system() call might fail if fread() does CR-LF to LF - translation. -Solution: Open the output file in binary mode. (Pavol Huhas) -Files: src/misc1.c - -Patch 6.1.013 -Problem: Win32: The default for 'printexpr' doesn't work when there are - special characters in 'printdevice'. -Solution: Add double quotes around the device name. (Mike Williams) -Files: runtime/doc/option.txt, src/option.c - -Patch 6.1.014 -Problem: An operator like "r" used in Visual block mode doesn't use - 'virtualedit' when it's set to "block". -Solution: Check for 'virtualedit' being active in Visual block mode when the - operator was started. -Files: src/ex_docmd.c, src/globals.h, src/misc2.c, src/normal.c, - src/ops.c, src/undo.c - -Patch 6.1.015 -Problem: After patch 6.1.014 can't compile with tiny features. (Christian - J. Robinson) -Solution: Add the missing define of virtual_op. -Files: src/vim.h - -Patch 6.1.016 (extra) -Problem: Win32: Outputting Hebrew or Arabic text might have a problem with - reversing. -Solution: Replace the RevOut() function with ETO_IGNORELANGUAGE. (Ron Aaron) -Files: src/gui_w32.c - -Patch 6.1.017 -Problem: Cygwin: After patch 6.1.012 Still doesn't do binary file I/O. - (Pavol Juhas) -Solution: Define BINARY_FILE_IO for Cygwin. -Files: src/os_unix.h - -Patch 6.1.018 -Problem: Error message when using cterm highlighting. (Leonardo Di Lella) -Solution: Remove a backslash before a question mark. -Files: runtime/syntax/cterm.vim - -Patch 6.1.019 (extra) -Problem: Win32: File name is messed up when editing just a drive name. - (Walter Briscoe) -Solution: Append a NUL after the drive name. (Vince Negri) -Files: src/os_win32.c - -Patch 6.1.020 -Problem: col("'>") returns a huge number after using Visual line mode. -Solution: Return the length of the line instead. -Files: src/eval.c - -Patch 6.1.021 (depends on patch 6.1.009) -Problem: Vim crashes when using a huge number for the minwid value in a - statusline. (Robert M. Nowotniak) -Solution: Check for an overflow that makes minwid negative. -Files: src/buffer.c - -Patch 6.1.022 -Problem: Grabbing the status line above the command-line window works like - the bottom status line was grabbed. (Jim Battle) -Solution: Make it possible to grab the status line above the command-line - window, so that it can be resized. -Files: src/ui.c - -Patch 6.1.023 (extra) -Problem: VMS: running tests doesn't work properly. -Solution: Adjust the makefile. (Zoltan Arpadffy) -Files: src/testdir/Make_vms.mms - -Patch 6.1.024 -Problem: When header files use a new syntax for declaring functions, Vim - can't figure out missing prototypes properly. -Solution: Accept braces around a function name. (M. Warner Losh) -Files: src/osdef.sh - -Patch 6.1.025 -Problem: Five messages for "vim --help" don't start with a capital. (Vlad - Sandrini) -Solution: Make the messages consistent. -Files: src/main.c - -Patch 6.1.026 -Problem: *.patch files are not recognized as diff files. In a script a - "VAR=val" argument after "env" isn't ignored. PHP scripts are not - recognized. -Solution: Add *.patch for diff filetypes. Ignore "VAR=val". Recognize PHP - scripts. (Roman Neuhauser) -Files: runtime/filetype.vim, runtime/scripts.vim - -Patch 6.1.027 -Problem: When 'foldcolumn' is non-zero, a special character that wraps to - the next line disturbs the foldcolumn highlighting. (Yasuhiro - Matsumoto) -Solution: Only use the special highlighting when drawing text characters. -Files: src/screen.c - -Patch 6.1.028 -Problem: Client-server: When a --remote-expr fails, Vim still exits with - status zero. -Solution: Exit Vim with a non-zero status to indicate the --remote-expr - failed. (Thomas Scott Urban) -Files: src/main.c - -Patch 6.1.029 -Problem: When 'encoding' is an 8-bit encoding other than "latin1", editing - a utf-8 or other Unicode file uses the wrong conversion. (Jan - Fedak) -Solution: Don't use Unicode to latin1 conversion for 8-bit encodings other - than "latin1". -Files: src/fileio.c - -Patch 6.1.030 -Problem: When CTRL-N is mapped in Insert mode, it is also mapped after - CTRL-X CTRL-N, while it is not mapped after CTRL-X CTRL-F. - (Kontra Gergely) -Solution: Don't map CTRL-N after CTRL-X CTRL-N. Same for CTRL-P. -Files: src/getchar.c - -Patch 6.1.031 -Problem: Cygwin: Xxd could read a file in text mode instead of binary mode. -Solution: Use "rb" or "rt" when needed. (Pavol Juhas) -Files: src/xxd/xxd.c - -Patch 6.1.032 -Problem: Can't specify a quickfix file without jumping to the first error. -Solution: Add the ":cgetfile" command. (Yegappan Lakshmanan) -Files: runtime/doc/index.txt, runtime/doc/quickfix.txt, src/ex_cmds.h, - src/quickfix.c - -Patch 6.1.033 -Problem: GUI: When the selection is lost and the Visual highlighting is - changed to underlining, the cursor is left in a different - position. (Christian Michon) -Solution: Update the cursor position after redrawing the selection. -Files: src/ui.c - -Patch 6.1.034 -Problem: A CVS diff file isn't recognized as diff filetype. -Solution: Skip lines starting with "? " before checking for an "Index:" line. -Files: runtime/scripts.vim - -Patch 6.1.035 (extra, depends on 6.1.016) -Problem: Win32: Outputting Hebrew or Arabic text might have a problem with - reversing on MS-Windows 95/98/ME. -Solution: Restore the RevOut() function and use it in specific situations - only. (Ron Aaron) -Files: src/gui_w32.c - -Patch 6.1.036 -Problem: This command may cause a crash: ":v/./,//-j". (Ralf Arens) -Solution: Compute the right length of the regexp when it's empty. -Files: src/search.c - -Patch 6.1.037 -Problem: When 'lazyredraw' is set, pressing "q" at the hit-enter prompt - causes an incomplete redraw and the cursor isn't positioned. - (Lubomir Host) -Solution: Overrule 'lazyredraw' when do_redraw is set. -Files: src/main.c, src/screen.c - -Patch 6.1.038 -Problem: Multi-byte: When a ":s" command contains a multi-byte character - where the trail byte is '~' the text is messed up. -Solution: Properly skip multi-byte characters in regtilde() (Muraoka Taro) -Files: src/regexp.c - -Patch 6.1.039 -Problem: When folds are defined and the file is changed outside of Vim, - reloading the file doesn't update the folds. (Anders - Schack-Nielsen) -Solution: Recompute the folds after reloading the file. -Files: src/fileio.c - -Patch 6.1.040 -Problem: When changing directory for expanding a file name fails there is - no error message. -Solution: Give an error message for this situation. Don't change directory - if we can't return to the original directory. -Files: src/diff.c, src/ex_docmd.c, src/globals.h, src/misc1.c, - src/os_unix.c - -Patch 6.1.041 -Problem: ":mkvimrc" doesn't handle a mapping that has a leading space in - the rhs. (Davyd Ondrejko) -Solution: Insert a CTRL-V before the leading space. Also display leading - and trailing white space in <> form. -Files: src/getchar.c, src/message.c - -Patch 6.1.042 -Problem: "vim -r" doesn't show all matches when 'wildignore' removes swap - files. (Steve Talley) -Solution: Keep all matching swap file names. -Files: src/memline.c - -Patch 6.1.043 -Problem: After patch 6.1.040 a few warnings are produced. -Solution: Add a type cast to "char *" for mch_chdir(). (Axel Kielhorn) -Files: src/diff.c, src/ex_docmd.c.c, src/misc1.c, src/os_unix.c - -Patch 6.1.044 (extra) -Problem: GUI: When using the find/replace dialog with text that contains a - slash, an invalid substitute command is generated. - On Win32 a find doesn't work when 'insertmode' is set. -Solution: Escape slashes with a backslash. - Make the Win32, Motif and GTK gui use common code for the - find/replace dialog. - Add the "match case" option for Motif and GTK. -Files: src/feature.h, src/proto/gui.pro, src/gui.c, src/gui.h, - src/gui_motif.c, src/gui_gtk.c, src/gui_w48.c - -Patch 6.1.045 -Problem: In Visual mode, with lots of folds and 'scrolloff' set to 999, - moving the cursor down near the end of the file causes the text to - jump up and down. (Lubomir Host) -Solution: Take into account that the cursor may be on the last line of a - closed fold. -Files: src/move.c - -Patch 6.1.046 -Problem: X11 GUI: ":set lsp=2 gcr=n-v-i:hor1-blinkon0" draws a black - rectangle. ":set lsp=2 gcr=n-v-i:hor10-blinkon0" makes the cursor - disappear. (Nam SungHyun) -Solution: Correctly compute the height of the horizontal cursor. -Files: src/gui_gtk_x11.c, src/gui_x11.c - -Patch 6.1.047 -Problem: When skipping commands after an error was encountered, expressions - for ":if", ";elseif" and ":while" are still evaluated. -Solution: Skip the expression after an error. (Servatius Brandt) -Files: src/ex_docmd.c - -Patch 6.1.048 -Problem: Unicode 3.2 changes were missing a few Hangul Jamo characters. -Solution: Recognize more characters as composing characters. (Jungshik Shin) -Files: src/mbyte.c - -Patch 6.1.049 (extra) -Problem: On a 32 bit display a valid color may cause an error message, - because its pixel value is negative. (Chris Paulson-Ellis) -Solution: Check for -11111 instead of the color being negative. - Don't add one to the pixel value, -1 may be used for white. -Files: src/globals.h, src/gui.c, src/gui.h, src/gui_amiga.c, - src/gui_athena.c, src/gui_beos.cc, src/gui_gtk_x11.c, - src/gui_mac.c, src/gui_motif.c, src/gui_photon.c, - src/gui_riscos.c, src/gui_w16.c, src/gui_w32.c, src/gui_w48.c, - src/gui_x11.c, src/mbyte.c, src/syntax.c - -Patch 6.1.050 (depends on 6.1.049) -Problem: After patch 6.1.049 the non-GUI version doesn't compile. -Solution: Add an #ifdef FEAT_GUI. (Robert Stanton) -Files: src/syntax.c - -Patch 6.1.051 (depends on 6.1.044) -Problem: Doesn't compile with GUI and small features. -Solution: Adjust the #if for ga_append(). -Files: src/misc2.c - -Patch 6.1.052 -Problem: Unix: The executable() function doesn't work when the "which" - command isn't available. -Solution: Go through $PATH manually. Also makes it work for VMS. -Files: src/os_unix.c - -Patch 6.1.053 -Problem: When 'sessionoptions' contains "globals", or "localoptions" and an - option value contains a line break, the resulting script is wrong. -Solution: Use "\n" and "\r" for a line break. (Srinath Avadhanula) -Files: src/eval.c - -Patch 6.1.054 -Problem: GUI: A mouse click is not recognized at the more prompt, even when - 'mouse' includes 'r'. -Solution: Recognize a mouse click at the more prompt. - Also accept a mouse click in the last line in the GUI. - Add "ml" entry in 'mouseshape'. -Files: src/gui.c, src/message.c, src/misc1.c, src/misc2.c, src/option.c, - src/structs.h - -Patch 6.1.055 -Problem: When editing a compressed file, Vim will inspect the contents to - guess the filetype. -Solution: Don't source scripts.vim for .Z, .gz, .bz2, .zip and .tgz files. -Files: runtime/filetype.vim, runtime/plugin/gzip.vim - -Patch 6.1.056 -Problem: Loading the Syntax menu can take quite a bit of time. -Solution: Add the "skip_syntax_sel_menu" variable. When it's defined the - available syntax files are not in the Syntax menu. -Files: runtime/doc/gui.txt, runtime/menu.vim - -Patch 6.1.057 -Problem: An ESC inside a mapping doesn't work as documented when - 'insertmode' is set, it does go from Visual or Normal mode to - Insert mode. (Benji Fisher) -Solution: Make it work as documented. -Files: src/normal.c - -Patch 6.1.058 -Problem: When there is a closed fold just above the first line in the - window, using CTRL-X CTRL-Y in Insert mode will show only one line - of the fold. (Alexey Marinichev) -Solution: Correct the topline by putting it at the start of the fold. -Files: src/move.c - -Patch 6.1.059 -Problem: ":redir > ~/file" doesn't work. (Stephen Rasku) -Solution: Expand environment variables in the ":redir >" argument. -Files: src/ex_docmd.c - -Patch 6.1.060 -Problem: When 'virtualedit' is set and 'selection' is "exclusive", deleting - a character just before a tab changes the tab into spaces. Undo - doesn't restore the tab. (Helmut Stiegler) -Solution: Don't replace the tab by spaces when it's not needed. Correctly - save the line before it's changed. -Files: src/ops.c - -Patch 6.1.061 -Problem: When 'virtualedit' is set and 'selection' is "exclusive", a Visual - selection that ends just after a tab doesn't include that tab in - the highlighting. (Helmut Stiegler) -Solution: Use a different way to exclude the character under the cursor. -Files: src/screen.c - -Patch 6.1.062 -Problem: The "man" filetype plugin doesn't work properly on Solaris 5. -Solution: Use a different way to detect that "man -s" should be used. (Hugh - Sasse) -Files: runtime/ftplugin/man.vim - -Patch 6.1.063 -Problem: Java indenting doesn't work properly. -Solution: Ignore comments when checking if the indent doesn't increase after - a "}". -Files: runtime/indent/java.vim - -Patch 6.1.064 -Problem: The URLs that the netrw plugin recognized for ftp and rcp did not - conform to the standard method://[user@]host[:port]/path. -Solution: Use ftp://[user@]host[[:#]port]/path, which supports both the new - and the previous style. Also added a bit of dav/cadaver support. - (Charles Campbell) -Files: runtime/plugin/netrw.vim - -Patch 6.1.065 -Problem: VMS: The colorscheme, keymap and compiler menus are not filled in. -Solution: Ignore case when looking for ".vim" files. (Coen Engelbarts) -Files: runtime/menu.vim - -Patch 6.1.066 (extra) -Problem: When calling system() in a plugin reading stdin hangs. -Solution: Don't set the terminal to RAW mode when it wasn't in RAW mode - before the system() call. -Files: src/os_amiga.c, src/os_msdos.c, src/os_riscos.c, src/os_unix.c, - src/os_win16.c, src/os_win32.c - -Patch 6.1.067 -Problem: ":set viminfo+=f0" is not working. (Benji Fisher) -Solution: Check the "f" flag instead of "'" in 'viminfo'. -Files: src/mark.c - -Patch 6.1.068 -Problem: When a file is reloaded after it was changed outside of Vim, diff - mode isn't updated. (Michael Naumann) -Solution: Invalidate the diff info so that it's updated when needed. -Files: src/fileio.c - -Patch 6.1.069 -Problem: When 'showmatch' is set and "$" is in 'cpoptions', using - "C}<Esc>" may forget to remove the "$". (Preben Guldberg) -Solution: Restore dollar_vcol after displaying the matching cursor position. -Files: src/search.c - -Patch 6.1.070 (depends on 6.1.060) -Problem: Compiler warning for signed/unsigned mismatch. (Mike Williams) -Solution: Add a typecast to int. -Files: src/ops.c - -Patch 6.1.071 -Problem: When 'selection' is exclusive, g CTRL-G in Visual mode counts one - character too much. (David Necas) -Solution: Subtract one from the end position. -Files: src/ops.c - -Patch 6.1.072 -Problem: When a file name in a tags file starts with http:// or something - else for which there is a BufReadCmd autocommand, the file isn't - opened anyway. -Solution: Check if there is a matching BufReadCmd autocommand and try to - open the file. -Files: src/fileio.c, src/proto/fileio.pro, src/tag.c - -Patch 6.1.073 (extra) -Problem: BC5: Can't easily specify a tiny, small, normal, big or huge - version. -Solution: Allow selecting the version with the FEATURES variable. (Ajit - Thakkar) -Files: src/Make_bc5.mak - -Patch 6.1.074 -Problem: When 'cdpath' includes "../..", changing to a directory in which - we currently already are doesn't work. ff_check_visited() adds - the directory both when using it as the root for searching and for - the actual matches. (Stephen Rasku) -Solution: Use a separate list for the already searched directories. -Files: src/misc2.c - -Patch 6.1.075 (depends on 6.1.072) -Problem: Can't compile fileio.c on MS-Windows. -Solution: Add a declaration for the "p" pointer. (Madoka Machitani) -Files: src/fileio.c - -Patch 6.1.076 (extra) -Problem: Macintosh: explorer plugin doesn't work on Mac Classic. - IME doesn't work. Dialog boxes don't work on Mac OS X -Solution: Fix explorer plugin and key modifiers. (Axel Kielhorn) - Fix IME support. (Muraoka Taro) - Disable dialog boxes. (Benji Fisher) -Files: src/edit.c, src/feature.h, src/gui_mac.c, src/os_mac.c - -Patch 6.1.077 -Problem: On a Debian system with ACL linking fails. (Lubomir Host) -Solution: When the "acl" library is used, check if the "attr" library is - present and use it. -Files: src/auto/configure, src/configure.in, src/link.sh - -Patch 6.1.078 -Problem: When using 'foldmethod' "marker" and the end marker appears before - the start marker in the file, no fold is found. (Nazri Ramliy) -Solution: Don't let the fold depth go negative. -Files: src/fold.c - -Patch 6.1.079 -Problem: When using "s" in Visual block mode with 'virtualedit' set, when - the selected block is after the end of some lines the wrong text - is inserted and some lines are skipped. (Servatius Brandt) -Solution: Insert the right text and extend short lines. -Files: src/ops.c - -Patch 6.1.080 -Problem: When using gcc with /usr/local already in the search path, adding - it again causes problems. -Solution: Adjust configure.in to avoid adding /usr/local/include and - /usr/local/lib when using GCC and they are already used. (Johannes - Zellner) -Files: src/auto/configure, src/configure.in - -Patch 6.1.081 -Problem: ":help CTRL-\_CTRL-N" doesn't work. (Christian J. Robinson) -Solution: Double the backslash to avoid the special meaning of "\_". -Files: src/ex_cmds.c - -Patch 6.1.082 -Problem: On MS-Windows the vimrc_example.vim script is sourced and then - mswin.vim. This enables using select mode, but since "p" is - mapped it doesn't replace the selection. -Solution: Remove the mapping of "p" from vimrc_example.vim, it's obsolete. - (Vlad Sandrini) -Files: runtime/vimrc_example.vim - -Patch 6.1.083 -Problem: When $LANG is "sk" or "sk_sk", the Slovak menu file isn't found. - (Martin Lacko) -Solution: Guess the right menu file based on the system. -Files: runtime/lang/menu_sk_sk.vim - -Patch 6.1.084 (depends on 6.1.080) -Problem: "include" and "lib" are mixed up when checking the directories gcc - already searches. -Solution: Swap the variable names. (SunHo Kim) -Files: src/auto/configure, src/configure.in - -Patch 6.1.085 -Problem: When using CTRL-O CTRL-\ CTRL-N from Insert mode, the displayed - mode "(insert)" isn't removed. (Benji Fisher) -Solution: Clear the command line. -Files: src/normal.c - -Patch 6.1.086 (depends on 6.1.049) -Problem: The guifg color for CursorIM doesn't take effect. -Solution: Use the foreground color when it's defined. (Muraoka Taro) -Files: src/gui.c - -Patch 6.1.087 -Problem: A thesaurus with Japanese characters has problems with characters - in different word classes. -Solution: Only separate words with single-byte non-word characters. - (Muraoka Taro) -Files: src/edit.c - -Patch 6.1.088 (extra) -Problem: Win32: no debugging info is generated. Tags file excludes .cpp - files. -Solution: Add "/map" to compiler flags. Add "*.cpp" to ctags command. - (Muraoka Taro) -Files: src/Make_mvc.mak - -Patch 6.1.089 -Problem: On BSDI systems there is no ss_sp field in stack_t. (Robert Jan) -Solution: Use ss_base instead. -Files: src/auto/configure, src/configure.in, src/config.h.in, - src/os_unix.c - -Patch 6.1.090 -Problem: CTRL-F gets stuck when 'scrolloff' is non-zero and there is a mix - of long wrapping lines and a non-wrapping line. -Solution: Check that CTRL-F scrolls at least one line. -Files: src/move.c - -Patch 6.1.091 -Problem: GTK: Can't change preeditstate without setting 'imactivatekey'. -Solution: Add some code to change preeditstate for OnTheSpot. (Yasuhiro - Matsumoto) -Files: src/mbyte.c - -Patch 6.1.092 -Problem: ":mapclear <buffer>" doesn't work. (Srikanth Adayapalam) -Solution: Allow an argument for ":mapclear". -Files: src/ex_cmds.h - -Patch 6.1.093 (extra) -Problem: Mac and MS-Windows GUI: when scrolling while ":s" is working the - results can be messed up, because the cursor is moved. -Solution: Disallow direct scrolling when not waiting for a character. -Files: src/gui_mac.c, src/gui_w16.c, src/gui_w32.c, src/gui_w48.c - -Patch 6.1.094 -Problem: Cygwin: Passing a file name that has backslashes isn't handled - very well. -Solution: Convert file name arguments to Posix. (Chris Metcalf) -Files: src/main.c - -Patch 6.1.095 -Problem: When using signs can free an item on the stack. - Overruling sign colors doesn't work. (Srikanth Sankaran) -Solution: Don't free the item on the stack. Use NULL instead of "none" for - the value of the color. -Files: src/gui_x11.c - -Patch 6.1.096 -Problem: When erasing the right halve of a double-byte character, it may - cause further characters to be erased. (Yasuhiro Matsumoto) -Solution: Make sure only one character is erased. -Files: src/screen.c - -Patch 6.1.097 (depends on 6.1.090) -Problem: When 'scrolloff' is set to a huge value, CTRL-F at the end of the - file scrolls one line. (Lubomir Host) -Solution: Don't scroll when CTRL-F detects the end-of-file. -Files: src/move.c - -Patch 6.1.098 -Problem: MS-Windows: When the xxd program is under "c:\program files" the - "Convert to Hex" menu doesn't work. (Brian Mathis) -Solution: Put the path to xxd in double quotes. -Files: runtime/menu.vim - -Patch 6.1.099 -Problem: Memory corrupted when closing a fold with more than 99999 lines. -Solution: Allocate more space for the fold text. (Walter Briscoe) -Files: src/eval.c - -Patch 6.1.100 (extra, depends on 6.1.088) -Problem: Win32: VC5 and earlier don't support the /mapinfo option. -Solution: Add "/mapinfo" only when "MAP=lines" is specified. (Muraoka Taro) -Files: src/Make_mvc.mak - -Patch 6.1.101 -Problem: After using ":options" the tabstop of a new window is 15. Entry - in ":options" window for 'autowriteall' is wrong. (Antoine J - Mechelynck) Can't insert a space in an option value. -Solution: Use ":setlocal" instead of ":set". Change "aw" to "awa". - Don't map space in Insert mode. -Files: runtime/optwin.vim - -Patch 6.1.102 -Problem: Unprintable and multi-byte characters in a statusline item are not - truncated correctly. (Yasuhiro Matsumoto) -Solution: Count the width of characters instead of the number of bytes. -Files: src/buffer.c - -Patch 6.1.103 -Problem: A function returning from a while loop, with 'verbose' set to 12 - or higher, doesn't mention the return value. A function with the - 'abort' attribute may return -1 while the verbose message says - something else. -Solution: Move the verbose message about returning from a function to - call_func(). (Servatius Brandt) -Files: src/eval.c - -Patch 6.1.104 -Problem: GCC 3.1 appears to have an optimizer problem that makes test 3 - crash. -Solution: For GCC 3.1 add -fno-strength-reduce to avoid the optimizer bug. - Filter out extra info from "gcc --version". -Files: src/auto/configure, src/configure.in - -Patch 6.1.105 -Problem: Win32: The default for 'shellpipe' doesn't redirect stderr. (Dion - Nicolaas) -Solution: Redirect stderr, depending on the shell (like for 'shellredir'). -Files: src/option.c - -Patch 6.1.106 -Problem: The maze program crashes. -Solution: Change "11" to "27" and it works. (Greg Roelofs) -Files: runtime/macros/maze/mazeansi.c - -Patch 6.1.107 -Problem: When 'list' is set the current line in the error window may be - displayed wrong. (Muraoka Taro) -Solution: Don't continue the line after the $ has been displayed and the - rightmost column is reached. -Files: src/screen.c - -Patch 6.1.108 -Problem: When interrupting a filter command such as "!!sleep 20" the file - becomes read-only. (Mark Brader) -Solution: Only set the read-only flag when opening a buffer is interrupted. - When the shell command was interrupted, read the output that was - produced so far. -Files: src/ex_cmds.c, src/fileio.c - -Patch 6.1.109 -Problem: When 'eadirection' is "hor", using CTRL-W = doesn't equalize the - window heights. (Roman Neuhauser) -Solution: Ignore 'eadirection' for CTRL-W = -Files: src/window.c - -Patch 6.1.110 -Problem: When using ":badd file" when "file" is already present but not - listed, it stays unlisted. (David Frey) -Solution: Set 'buflisted'. -Files: src/buffer.c - -Patch 6.1.111 -Problem: It's not possible to detect using the Unix sources on Win32 or Mac. -Solution: Add has("macunix") and has("win32unix"). -Files: runtime/doc/eval.txt, src/eval.c - -Patch 6.1.112 -Problem: When using ":argdo", ":bufdo" or ":windo", CTRL-O doesn't go to - the cursor position from before this command but every position - where the argument was executed. -Solution: Only remember the cursor position from before the ":argdo", - ":bufdo" and ":windo". -Files: src/ex_cmds2.c, src/mark.c - -Patch 6.1.113 -Problem: ":bufdo bwipe" only wipes out half the buffers. (Roman Neuhauser) -Solution: Decide what buffer to go to next before executing the command. -Files: src/ex_cmds2.c - -Patch 6.1.114 -Problem: ":python import vim", ":python vim.current.buffer[0:0] = []" gives - a lalloc(0) error. (Chris Southern) -Solution: Don't allocate an array when it's size is zero. -Files: src/if_python.c - -Patch 6.1.115 -Problem: "das" on the white space at the end of a paragraph does not delete - the "." the sentence ends with. -Solution: Don't exclude the last character when it is not white space. -Files: src/search.c - -Patch 6.1.116 -Problem: When 'endofline' is changed while 'binary' is set a file should be - considered modified. (Olaf Buddenhagen) -Solution: Remember the 'eol' value when editing started and consider the - file changed when the current value is different and 'binary' is - set. Also fix that the window title isn't updated when 'ff' or - 'bin' changes. -Files: src/option.c, src/structs.h - -Patch 6.1.117 -Problem: Small problem with editing a file over ftp: and with Cygwin. -Solution: Remove a dot from a ":normal" command. Use "cygdrive" where - appropriate. (Charles Campbell) -Files: runtime/plugin/netrw.vim - -Patch 6.1.118 -Problem: When a file in diff mode is reloaded because it changed outside - of Vim, other windows in diff mode are not always updated. - (Michael Naumann) -Solution: After reloading a file in diff mode mark all windows in diff mode - for redraw. -Files: src/diff.c - -Patch 6.1.119 (extra) -Problem: With the Sniff interface, using Sniff 4.0.X on HP-UX, there may be - a crash when connecting to Sniff. -Solution: Initialize sniff_rq_sep such that its value can be changed. - (Martin Egloff) -Files: src/if_sniff.c - -Patch 6.1.120 (depends on 6.1.097) -Problem: When 'scrolloff' is non-zero and there are folds, CTRL-F at the - end of the file scrolls part of a closed fold. (Lubomir Host) -Solution: Adjust the first line to the start of a fold. -Files: src/move.c - -Patch 6.1.121 (depends on 6.1.098) -Problem: When starting Select mode from Insert mode, then using the Paste - menu entry, the cursor is left before the last pasted character. - (Mario Schweigler) -Solution: Set the cursor for Insert mode one character to the right. -Files: runtime/menu.vim - -Patch 6.1.122 -Problem: ":file name" creates a new buffer to hold the old buffer name, - which becomes the alternate file. This buffer is unexpectedly - listed. -Solution: Create the buffer for the alternate name unlisted. -Files: src/ex_cmds.c - -Patch 6.1.123 -Problem: A ":match" command with more than one argument doesn't report an - error. -Solution: Check for extra characters. (Servatius Brandt) -Files: src/ex_docmd.c - -Patch 6.1.124 -Problem: When trying to exit and there is a hidden buffer that had 'eol' - off and 'bin' set exiting isn't possible. (John McGowan) -Solution: Set b_start_eol when clearing the buffer. -Files: src/buffer.c - -Patch 6.1.125 -Problem: Explorer plugin asks for saving a modified buffer even when it's - open in another window as well. -Solution: Count the number of windows using the buffer. -Files: runtime/plugin/explorer.vim - -Patch 6.1.126 -Problem: Adding the choices in the syntax menu is consuming much of the - startup time of the GUI while it's not often used. -Solution: Only add the choices when the user wants to use them. -Files: Makefile, runtime/makemenu.vim, runtime/menu.vim, - runtime/synmenu.vim, src/Makefile - -Patch 6.1.127 -Problem: When using "--remote file" and the server has 'insertmode' set, - commands are inserted instead of being executed. (Niklas Volbers) -Solution: Go to Normal mode again after the ":drop" command. -Files: src/main.c - -Patch 6.1.128 -Problem: The expression "input('very long prompt')" puts the cursor in the - wrong line (column is OK). -Solution: Add the wrapped lines to the indent. (Yasuhiro Matsumoto) -Files: src/ex_getln.c - -Patch 6.1.129 -Problem: On Solaris editing "file/" and then "file" results in using the - same buffer. (Jim Battle) -Solution: Before using stat(), check that there is no illegal trailing - slash. -Files: src/auto/configure, src/config.h.in, src/configure.in, - src/macros.h src/misc2.c, src/proto/misc2.pro - -Patch 6.1.130 -Problem: The documentation for some of the 'errorformat' items is unclear. -Solution: Add more examples and explain hard to understand items. (Stefan - Roemer) -Files: runtime/doc/quickfix.txt - -Patch 6.1.131 -Problem: X11 GUI: when expanding a CSI byte in the input stream to K_CSI, - the CSI byte itself isn't copied. -Solution: Copy the CSI byte. -Files: src/gui_x11.c - -Patch 6.1.132 -Problem: Executing a register in Ex mode may cause commands to be skipped. - (John McGowan) -Solution: In Ex mode use an extra check if the register contents was - consumed, to avoid input goes into the typeahead buffer. -Files: src/ex_docmd.c - -Patch 6.1.133 -Problem: When drawing double-wide characters in the statusline, may clear - half of a character. (Yasuhiro Matsumoto) -Solution: Force redraw of the next character by setting the attributes - instead of putting a NUL in ScreenLines[]. Do put a NUL in - ScreenLines[] when overwriting half of a double-wide character. -Files: src/screen.c - -Patch 6.1.134 -Problem: An error for a trailing argument of ":match" should not be given - after ":if 0". (Servatius Brandt) -Solution: Only do the check when executing commands. -Files: src/ex_docmd.c - -Patch 6.1.135 -Problem: Passing a command to the shell that includes a newline always has - a backslash before the newline. -Solution: Remove one backslash before the newline. (Servatius Brandt) -Files: src/ex_docmd.c - -Patch 6.1.136 -Problem: When $TERM is "linux" the default for 'background' is "dark", even - though the GUI uses a light background. (Hugh Allen) -Solution: Don't mark the option as set when defaulting to "dark" for the - linux console. Also reset 'background' to "light" when the GUI - has a light background. -Files: src/option.c - -Patch 6.1.137 -Problem: Converting to HTML has a clumsy way of dealing with tabs which may - change the highlighting. -Solution: Replace tabs with spaces after converting a line to HTML. (Preben - Guldberg) -Files: runtime/syntax/2html.vim - -Patch 6.1.138 (depends on 6.1.126) -Problem: Adding extra items to the Syntax menu can't be done when the "Show - individual choices" menu is used. -Solution: Use ":runtime!" instead of ":source", so that all synmenu.vim - files in the runtime path are loaded. (Servatius Brandt) - Also fix that a translated menu can't be removed. -Files: runtime/menu.vim - -Patch 6.1.139 -Problem: Cygwin: PATH_MAX is not defined. -Solution: Include limits.h. (Dan Sharp) -Files: src/main.c - -Patch 6.1.140 -Problem: Cygwin: ":args `ls *.c`" does not work if the shell command - produces CR NL line separators. -Solution: Remove the CR characters ourselves. (Pavol Juhas) -Files: src/os_unix.c - -Patch 6.1.141 -Problem: ":wincmd gx" may cause problems when mixed with other commands. - ":wincmd c" doesn't close the window immediately. (Benji Fisher) -Solution: Pass the extra command character directly instead of using the - stuff buffer and call ex_close() directly. -Files: src/ex_docmd.c, src/normal.c, src/proto/normal.pro, - src/proto/window.pro, src/window.c - -Patch 6.1.142 -Problem: Defining paragraphs without a separating blank line isn't - possible. Paragraphs can't be formatted automatically. -Solution: Allow defining paragraphs with lines that end in white space. - Added the 'w' and 'a' flags in 'formatoptions'. -Files: runtime/doc/change.txt, src/edit.c, src/misc1.c, src/normal.c, - src/option.h, src/ops.c, src/proto/edit.pro, src/proto/ops.pro, - src/vim.h - -Patch 6.1.143 (depends on 6.1.142) -Problem: Auto formatting near the end of the file moves the cursor to a - wrong position. In Insert mode some lines are made one char too - narrow. When deleting a line undo might not always work properly. -Solution: Don't always move to the end of the line in the last line. Don't - position the cursor past the end of the line in Insert mode. - After deleting a line save the cursor line for undo. -Files: src/edit.c, src/ops.c, src/normal.c - -Patch 6.1.144 -Problem: Obtaining the size of a line in screen characters can be wrong. - A pointer may wrap around zero. -Solution: In win_linetabsize() check for a MAXCOL length argument. (Jim - Dunleavy) -Files: src/charset.c - -Patch 6.1.145 -Problem: GTK: Drag&drop with more than 3 files may cause a crash. (Mickael - Marchand) -Solution: Rewrite the code that parses the received list of files to be more - robust. -Files: src/charset.c, src/gui_gtk_x11.c - -Patch 6.1.146 -Problem: MS-Windows: When $HOME is constructed from $HOMEDRIVE and - $HOMEPATH, it is not used for storing the _viminfo file. (Normal - Diamond) -Solution: Set $HOME with the value obtained from $HOMEDRIVE and $HOMEPATH. -Files: src/misc1.c - -Patch 6.1.147 (extra) -Problem: MS-Windows: When a dialog has no default button, pressing Enter - ends it anyway and all buttons are selected. -Solution: Don't end a dialog when there is no default button. Don't select - all button when there is no default. (Vince Negri) -Files: src/gui_w32.c - -Patch 6.1.148 (extra) -Problem: MS-Windows: ACL is not properly supported. -Solution: Add an access() replacement that also works for ACL. (Mike - Williams) -Files: runtime/doc/editing.txt, src/os_win32.c - -Patch 6.1.149 (extra) -Problem: MS-Windows: Can't use diff mode from the file explorer. -Solution: Add a "diff with Vim" context menu entry. (Dan Sharp) -Files: GvimExt/gvimext.cpp, GvimExt/gvimext.h - -Patch 6.1.150 -Problem: OS/2, MS-Windows and MS-DOS: When 'shellslash' is set getcwd() - still uses backslash. (Yegappan Lakshmanan) -Solution: Adjust slashes in getcwd(). -Files: src/eval.c - -Patch 6.1.151 (extra) -Problem: Win32: The NTFS substream isn't copied. -Solution: Copy the substream when making a backup copy. (Muraoka Taro) -Files: src/fileio.c, src/os_win32.c, src/proto/os_win32.pro - -Patch 6.1.152 -Problem: When $LANG is iso8859-1 translated menus are not used. -Solution: Change iso8859 to iso_8859. -Files: runtime/menu.vim - -Patch 6.1.153 -Problem: Searching in included files may search recursively when the path - starts with "../". (Sven Berkvens-Matthijsse) -Solution: Compare full file names, use inode/device when possible. -Files: src/search.c - -Patch 6.1.154 (extra) -Problem: DJGPP: "vim -h" leaves the cursor in a wrong position. -Solution: Don't position the cursor using uninitialized variables. (Jim - Dunleavy) -Files: src/os_msdos.c - -Patch 6.1.155 -Problem: Win32: Cursor may sometimes disappear in Insert mode. -Solution: Change "hor10" in 'guicursor' to "hor15". (Walter Briscoe) -Files: src/option.c - -Patch 6.1.156 -Problem: Conversion between DBCS and UCS-2 isn't implemented cleanly. -Solution: Clean up a few things. -Files: src/mbyte.c, src/structs.h - -Patch 6.1.157 -Problem: 'hlsearch' highlights only the second comma in ",,,,," with - "/,\@<=[^,]*". (Preben Guldberg) -Solution: Also check for an empty match to start just after a previous - match. -Files: src/screen.c - -Patch 6.1.158 -Problem: "zs" and "ze" don't work correctly with ":set nowrap siso=1". - (Preben Guldberg) -Solution: Take 'siso' into account when computing the horizontal scroll - position for "zs" and "ze". -Files: src/normal.c - -Patch 6.1.159 -Problem: When expanding an abbreviation that includes a multi-byte - character too many characters are deleted. (Andrey Urazov) -Solution: Delete the abbreviation counting characters instead of bytes. -Files: src/getchar.c - -Patch 6.1.160 -Problem: ":$read file.gz" doesn't work. (Preben Guldberg) -Solution: Don't use the '[ mark after it has become invalid. -Files: runtime/plugin/gzip.vim - -Patch 6.1.161 (depends on 6.1.158) -Problem: Warning for signed/unsigned compare. Can set 'siso' to a negative - value. (Mike Williams) -Solution: Add a typecast. Add a check for 'siso' being negative. -Files: src/normal.c, src/option.c - -Patch 6.1.162 -Problem: Python interface: Didn't initialize threads properly. -Solution: Call PyEval_InitThreads() when starting up. -Files: src/if_python.c - -Patch 6.1.163 -Problem: Win32: Can't compile with Python after 6.1.162. -Solution: Dynamically load PyEval_InitThreads(). (Dan Sharp) -Files: src/if_python.c - -Patch 6.1.164 -Problem: If 'modifiable' is off, converting to xxd fails and 'filetype' is - changed to "xxd" anyway. -Solution: Don't change 'filetype' when conversion failed. -Files: runtime/menu.vim - -Patch 6.1.165 -Problem: Making changes in several lines and then a change in one of these - lines that splits it in two or more lines, undo information was - corrupted. May cause a crash. (Dave Fishburn) -Solution: When skipping to save a line for undo because it was already - saved, move it to become the last saved line, so that when the - command changes the line count other saved lines are not involved. -Files: src/undo.c - -Patch 6.1.166 -Problem: When 'autoindent' is set and mswin.vim has been sourced, pasting - with CTRL-V just after auto-indenting removes the indent. (Shlomi - Fish) -Solution: First insert an "x" and delete it again, so that the auto-indent - remains. -Files: runtime/mswin.vim - -Patch 6.1.167 -Problem: When giving a negative argument to ":retab" strange things start - happening. (Hans Ginzel) -Solution: Check for a negative value. -Files: src/ex_cmds.c - -Patch 6.1.168 -Problem: Pressing CTRL-C at the hit-enter prompt doesn't end the prompt. -Solution: Make CTRL-C stop the hit-enter prompt. -Files: src/message.c - -Patch 6.1.169 -Problem: bufexists() finds a buffer by using the name of a symbolic link to - it, but bufnr() doesn't. (Yegappan Lakshmanan) -Solution: When bufnr() can't find a buffer, try using the same method as - bufexists(). -Files: src/eval.c - -Patch 6.1.170 -Problem: Using ":mksession" uses the default session file name, but "vim - -S" doesn't. (Hans Ginzel) -Solution: Use the default session file name if "-S" is the last command - line argument or another option follows. -Files: runtime/doc/starting.txt, src/main.c - -Patch 6.1.171 -Problem: When opening a line just above a closed fold with "O" and the - comment leader is automatically inserted, the cursor is displayed - in the first column. (Sung-Hyun Nam) -Solution: Update the flag that indicates the cursor is in a closed fold. -Files: src/misc1.c - -Patch 6.1.172 -Problem: Command line completion of ":tag /pat" does not show the same - results as the tags the command actually finds. (Gilles Roy) -Solution: Don't modify the pattern to make it a regexp. -Files: src/ex_getln.c, src/tag.c - -Patch 6.1.173 -Problem: When using remote control to edit a position in a file and this - file is the current buffer and it's modified, the window is split - and the ":drop" command fails. -Solution: Don't split the window, keep editing the same buffer. - Use the ":drop" command in VisVim to avoid the problem there. -Files: src/ex_cmds.c, src/ex_cmds2.c, src/proto/ex_cmds2.pro, - VisVim/Commands.cpp - -Patch 6.1.174 -Problem: It is difficult to know in a script whether an option not only - exists but really works. -Solution: Add "exists('+option')". -Files: runtime/doc/eval.txt, src/eval.c - -Patch 6.1.175 -Problem: When reading commands from a pipe and a CTRL-C is pressed, Vim - will hang. (Piet Delport) -Solution: Don't keep reading characters to clear typeahead when an interrupt - was detected, stop when a single CTRL-C is read. -Files: src/getchar.c, src/ui.c - -Patch 6.1.176 -Problem: When the stack limit is very big a false out-of-stack error may - be detected. -Solution: Add a check for overflow of the stack limit computation. (Jim - Dunleavy) -Files: src/os_unix.c - -Patch 6.1.177 (depends on 6.1.141) -Problem: ":wincmd" does not allow a following command. (Gary Johnson) -Solution: Check for a following " | cmd". Also give an error for trailing - characters. -Files: src/ex_docmd.c - -Patch 6.1.178 -Problem: When 'expandtab' is set "r<C-V><Tab>" still expands the Tab. - (Bruce deVisser) -Solution: Replace with a literal Tab. -Files: src/normal.c - -Patch 6.1.179 (depends on 6.1.091) -Problem: When using X11R5 XIMPreserveState is undefined. (Albert Chin) -Solution: Include the missing definitions. -Files: src/mbyte.c - -Patch 6.1.180 -Problem: Use of the GUI code for forking is inconsistent. -Solution: Define MAY_FORK and use it for later #ifdefs. (Ben Fowlwer) -Files: src/gui.c - -Patch 6.1.181 -Problem: If the terminal doesn't wrap from the last char in a line to the - next line, the last column is blanked out. (Peter Karp) -Solution: Don't output a space to mark the wrap, but the same character - again. -Files: src/screen.c - -Patch 6.1.182 (depends on 6.1.142) -Problem: It is not possible to auto-format comments only. (Moshe Kaminsky) -Solution: When the 'a' and 'c' flags are in 'formatoptions' only auto-format - comments. -Files: runtime/doc/change.txt, src/edit.c - -Patch 6.1.183 -Problem: When 'fencs' is empty and 'enc' is utf-8, reading a file with - illegal bytes gives "CONVERSION ERROR" even though no conversion - is done. 'readonly' is set, even though writing the file results - in an unmodified file. -Solution: For this specific error use "ILLEGAL BYTE" and don't set - 'readonly'. -Files: src/fileio.c - -Patch 6.1.184 (extra) -Problem: The extra mouse buttons found on some mice don't work. -Solution: Support two extra buttons for MS-Windows. (Michael Geddes) -Files: runtime/doc/term.txt, src/edit.c, src/ex_getln.c, src/gui.c, - src/gui_w32.c, src/gui_w48.c, src/keymap.h, src/message.c, - src/misc1.c, src/misc2.c, src/normal.c, src/vim.h - -Patch 6.1.185 (depends on 6.1.182) -Problem: Can't compile without +comments feature. -Solution: Add #ifdef FEAT_COMMENTS. (Christian J. Robinson) -Files: src/edit.c - -Patch 6.1.186 (depends on 6.1.177) -Problem: ":wincmd" does not allow a following comment. (Aric Blumer) -Solution: Check for a following double quote. -Files: src/ex_docmd.c - -Patch 6.1.187 -Problem: Using ":doarg" with 'hidden' set and the current file is the only - argument and was modified gives an error message. (Preben - Guldberg) -Solution: Don't try re-editing the same file. -Files: src/ex_cmds2.c - -Patch 6.1.188 (depends on 6.1.173) -Problem: Unused variable in the small version. -Solution: Move the declaration for "p" inside #ifdef FEAT_LISTCMDS. -Files: src/ex_cmds2.c - -Patch 6.1.189 -Problem: inputdialog() doesn't work when 'c' is in 'guioptions'. (Aric - Blumer) -Solution: Fall back to the input() function in this situation. -Files: src/eval.c - -Patch 6.1.190 (extra) -Problem: VMS: doesn't build with GTK GUI. Various other problems. -Solution: Fix building for GTK. Improved Perl, Python and TCL support. - Improved VMS documentation. (Zoltan Arpadffy) - Added Vimtutor for VMS (T. R. Wyant) -Files: runtime/doc/os_vms.txt, src/INSTALLvms.txt, src/gui_gtk_f.h, - src/if_tcl.c, src/main.c, src/gui_gtk_vms.h, src/Make_vms.mms, - src/os_vms.opt, src/proto/if_tcl.pro, vimtutor.com, - src/testdir/Make_vms.mms - -Patch 6.1.191 -Problem: When using "vim -s script" and redirecting the output, the delay - for the "Output is not to a terminal" warning slows Vim down too - much. -Solution: Don't delay when reading commands from a script. -Files: src/main.c - -Patch 6.1.192 -Problem: ":diffsplit" doesn't add "hor" to 'scrollopt'. (Gary Johnson) -Solution: Add "hor" to 'scrollopt' each time ":diffsplit" is used. -Files: src/diff.c, src/main.c - -Patch 6.1.193 -Problem: Crash in in_id_list() for an item with a "containedin" list. (Dave - Fishburn) -Solution: Check for a negative syntax id, used for keywords. -Files: src/syntax.c - -Patch 6.1.194 -Problem: When "t_ti" is set but it doesn't cause swapping terminal pages, - "ZZ" may cause the shell prompt to appear on top of the file-write - message. -Solution: Scroll the text up in the Vim page before swapping to the terminal - page. (Michael Schroeder) -Files: src/os_unix.c - -Patch 6.1.195 -Problem: The quickfix and preview windows always keep their height, while - other windows can't fix their height. -Solution: Add the 'winfixheight' option, so that a fixed height can be - specified for any window. Also fix that the wildmenu may resize a - one-line window to a two-line window if 'ls' is zero. -Files: runtime/doc/options.txt, runtime/optwin.vim, src/ex_cmds.c, - src/ex_getln.c, src/globals.h, src/option.c, src/quickfix.c, - src/screen.c, src/structs.h, src/window.c - -Patch 6.1.196 (depends on 6.1.084) -Problem: On Mac OS X 10.2 generating osdef.h fails. -Solution: Add -no-cpp-precomp to avoid using precompiled header files, which - disables printing the search path. (Ben Fowler) -Files: src/auto/configure, src/configure.in - -Patch 6.1.197 -Problem: ":help <C-V><C-\><C-V><C-N>" (resulting in <1c><0e>) gives an - error message. (Servatius Brandt) -Solution: Double the backslash in "CTRL-\". -Files: src/ex_cmds.c - -Patch 6.1.198 (extra) (depends on 6.1.076) -Problem: Mac OS X: Dialogues don't work. -Solution: Fix a crashing problem for some GUI dialogues. Fix a problem when - saving to a new file from the GUI. (Peter Cucka) -Files: src/feature.h, src/gui_mac.c - -Patch 6.1.199 -Problem: 'guifontwide' doesn't work on Win32. -Solution: Output each wide character separately. (Michael Geddes) -Files: src/gui.c - -Patch 6.1.200 -Problem: ":syn sync fromstart" is not skipped after ":if 0". This can make - syntax highlighting very slow. -Solution: Check "eap->skip" appropriately. (Rob West) -Files: src/syntax.c - -Patch 6.1.201 (depends on 6.1.192) -Problem: Warning for illegal pointer combination. (Zoltan Arpadffy) -Solution: Add a typecast. -Files: src/diff.c - -Patch 6.1.202 (extra)(depends on 6.1.148) -Problem: Win32: filewritable() doesn't work properly on directories. -Solution: fix filewritable(). (Mike Williams) -Files: src/os_win32.c - -Patch 6.1.203 -Problem: ":%s/~//" causes a crash after ":%s/x//". (Gary Holloway) -Solution: Avoid reading past the end of a line when "~" is empty. -Files: src/regexp.c - -Patch 6.1.204 (depends on 6.1.129) -Problem: Warning for an illegal pointer on Solaris. -Solution: Add a typecast. (Derek Wyatt) -Files: src/misc2.c - -Patch 6.1.205 -Problem: The gzip plugin changes the alternate file when editing a - compressed file. (Oliver Fuchs) -Solution: Temporarily remove the 'a' and 'A' flags from 'cpo'. -Files: runtime/plugin/gzip.vim - -Patch 6.1.206 -Problem: The script generated with ":mksession" doesn't work properly when - some commands are mapped. -Solution: Use ":normal!" instead of ":normal". And use ":wincmd" where - possible. (Muraoka Taro) -Files: src/ex_docmd.c, src/fold.c - -Patch 6.1.207 -Problem: Indenting a Java file hangs below a line with a comment after a - command. -Solution: Break out of a loop. (Andre Pang) - Also line up } with matching {. -Files: runtime/indent/java.vim - -Patch 6.1.208 -Problem: Can't use the buffer number from the Python interface. -Solution: Add buffer.number. (Michal Vitecek) -Files: src/if_python.c - -Patch 6.1.209 -Problem: Printing doesn't work on Mac OS classic. -Solution: Use a ":" for path separator when opening the resource file. (Axel - Kielhorn) -Files: src/ex_cmds2.c - -Patch 6.1.210 -Problem: When there is an iconv() conversion error when reading a file - there can be an error the next time iconv() is used. -Solution: Reset the state of the iconv() descriptor. (Yasuhiro Matsumoto) -Files: src/fileio.c - -Patch 6.1.211 -Problem: The message "use ! to override" is confusing. -Solution: Make it "add ! to override". -Files: src/buffer.c, src/eval.c, src/ex_docmd.c, src/fileio.c, - src/globals.h - -Patch 6.1.212 -Problem: When Vim was started with "-R" ":new" creates a buffer - 'noreadonly' while ":enew" has 'readonly' set. (Preben Guldberg) -Solution: Don't set 'readonly in a new empty buffer for ":enew". -Files: src/ex_docmd.c - -Patch 6.1.213 -Problem: Using CTRL-W H may cause a big gap to appear below the last - window. (Aric Blumer) -Solution: Don't set the window height when there is a vertical split. - (Yasuhiro Matsumoto) -Files: src/window.c - -Patch 6.1.214 -Problem: When installing Vim and the runtime files were checked out from - CVS the CVS directories will also be installed. -Solution: Avoid installing the CVS dirs and their contents. -Files: src/Makefile - -Patch 6.1.215 -Problem: Win32: ":pwd" uses backslashes even when 'shellslash' is set. - (Xiangjiang Ma) -Solution: Adjust backslashes before printing the message. -Files: src/ex_docmd.c - -Patch 6.1.216 -Problem: When dynamically loading the iconv library, the error codes may be - confused. -Solution: Use specific error codes for iconv and redefine them for dynamic - loading. (Yasuhiro Matsumoto) -Files: src/fileio.c, src/mbyte.c, src/vim.h - -Patch 6.1.217 -Problem: When sourcing the same Vim script using a different name (symbolic - link or MS-Windows 8.3 name) it is listed twice with - ":scriptnames". (Tony Mechelynck) -Solution: Turn the script name into a full path before using it. On Unix - compare inode/device numbers. -Files: src/ex_cmds2.c - -Patch 6.1.218 -Problem: No error message for using the function argument "5+". (Servatius - Brandt) -Solution: Give an error message if a function or variable is expected but is - not found. -Files: src/eval.c - -Patch 6.1.219 -Problem: When using ":amenu :b 1<CR>" with a Visual selection and - 'insertmode' is set, Vim does not return to Insert mode. (Mickael - Marchand) -Solution: Add the command CTRL-\ CTRL-G that goes to Insert mode if - 'insertmode' is set and to Normal mode otherwise. Append this to - menus defined with ":amenu". -Files: src/edit.c, src/ex_getln.c, src/normal.c - -Patch 6.1.220 -Problem: When using a BufReadPost autocommand that changes the line count, - e.g., "$-1join", reloading a file that was changed outside Vim - does not work properly. (Alan G Isaac) -Solution: Make the buffer empty before reading the new version of the file. - Save the lines in a dummy buffer, so that they can be put back - when reading the file fails. -Files: src/buffer.c, src/ex_cmds.c, src/fileio.c, src/globals.h, - src/proto/buffer.pro - -Patch 6.1.221 -Problem: Changing case may not work properly, depending on the current - locale. -Solution: Add the 'casemap' option to let the user chose how changing case - is to be done. - Also fix lowering case when an UTF-8 character doesn't keep the - same byte length. -Files: runtime/doc/options.txt, src/ascii.h, src/auto/configure, - src/buffer.c, src/charset.c, src/config.h.in, src/configure.in, - src/diff.c, src/edit.c, src/eval.c, src/ex_cmds2.c, - src/ex_docmd.c, src/ex_getln.c, src/fileio.c, src/gui_amiga.c - src/gui_mac.c, src/gui_photon.c, src/gui_w48.c, src/gui_beos.cc, - src/macros.h, src/main.c, src/mbyte.c, src/menu.c, src/message.c, - src/misc1.c, src/misc2.c, src/option.c, src/os_msdos.c, - src/os_mswin.c, src/proto/charset.pro, src/regexp.c, src/option.h, - src/syntax.c - -Patch 6.1.222 (depends on 6.1.219) -Problem: Patch 6.1.219 was incomplete. -Solution: Add the changes for ":amenu". -Files: src/menu.c - -Patch 6.1.223 (extra) -Problem: Win32: When IME is activated 'iminsert' is set, but it might never - be reset when IME is disabled. (Muraoka Taro) - All systems: 'iminsert' is set to 2 when leaving Insert mode, even - when langmap is being used. (Peter Valach) -Solution: Don't set "b_p_iminsert" in _OnImeNotify(). (Muraoka Taro) - Don't store the status of the input method in 'iminsert' when - 'iminsert' is one. Also for editing the command line and for - arguments to Normal mode commands. -Files: src/edit.c, src/ex_getln.c, src/gui_w32.c, src/normal.c - -Patch 6.1.224 -Problem: "expand('$VAR')" returns an empty string when the expanded $VAR - is not an existing file. (Aric Blumer) -Solution: Included non-existing files, as documented. -Files: src/eval.c - -Patch 6.1.225 -Problem: Using <C-O><C-^> in Insert mode has a delay when starting "vim -u - NONE" and ":set nocp hidden". (Emmanuel) do_ecmd() uses - fileinfo(), the redraw is done after a delay to give the user time - to read the message. -Solution: Put the message from fileio() in "keep_msg", so that the redraw is - done before the delay (still needed to avoid the mode message - overwrites the fileinfo() message). -Files: src/buffer.c - -Patch 6.1.226 -Problem: Using ":debug" with a ":normal" command may cause a hang. (Colin - Keith) -Solution: Save the typeahead buffer when obtaining a debug command. -Files: src/ex_cmds2.c, src/getchar.c, src/proto/getchar.pro - -Patch 6.1.227 -Problem: It is possible to use a variable name "asdf:asdf" and ":let j:asdf - = 5" does not give an error message. (Mikolaj Machowski) -Solution: Check for a ":" inside the variable name. -Files: src/eval.c - -Patch 6.1.228 (extra) -Problem: Win32: The special output function for Hangul is used too often, - causing special handling for other situations to be skipped. - bInComposition is always FALSE, causing ImeGetTempComposition() - always to return NULL. -Solution: Remove HanExtTextOut(). Delete the dead code around - bInComposition and ImeGetTempComposition(). -Files: src/gui_w16.c, src/gui_w32.c, src/gui_w48.c - -Patch 6.1.229 -Problem: Win32: Conversion to/from often used codepages requires the iconv - library, which is not always available. -Solution: Use standard MS-Windows functions for the conversion when - possible. (mostly by Glenn Maynard) - Also fixes missing declaration for patch 6.1.220. -Files: src/fileio.c - -Patch 6.1.230 (extra) -Problem: Win16: building doesn't work. -Solution: Exclude the XBUTTON handling. (Vince Negri) -Files: src/gui_w48.c - -Patch 6.1.231 -Problem: Double clicking with the mouse to select a word does not work for - multi-byte characters. -Solution: Use vim_iswordc() instead of vim_isIDc(). This means 'iskeyword' - is used instead of 'isident'. Also fix that mixing ASCII with - multi-byte word characters doesn't work, the mouse class for - punctuation and word characters was mixed up. -Files: src/normal.c - -Patch 6.1.232 (depends on 6.1.226) -Problem: Using ex_normal_busy while it might not be available. (Axel - Kielhorn) -Solution: Only use ex_normal_busy when FEAT_EX_EXTRA is defined. -Files: src/ex_cmds2.c - -Patch 6.1.233 -Problem: ":help expr-||" does not work. -Solution: Don't use the '|' as a command separator -Files: src/ex_cmds.c - -Patch 6.1.234 (depends on 6.1.217) -Problem: Get a warning for using a negative value for st_dev. -Solution: Don't assign a negative value to st_dev. -Files: src/ex_cmds2.c - -Patch 6.1.235 (depends on 6.1.223) -Problem: 'iminsert' is changed from 1 to 2 when leaving Insert mode. (Peter - Valach) -Solution: Check "State" before resetting it to NORMAL. -Files: src/edit.c - -Patch 6.1.236 -Problem: Memory leaks when appending lines for ":diffget" or ":diffput" and - when reloading a changed buffer. -Solution: Free a line after calling ml_append(). -Files: src/diff.c, src/fileio.c - -Patch 6.1.237 -Problem: Putting in Visual block mode does not work correctly when "$" was - used or when the first line is short. (Christian Michon) -Solution: First delete the selected text and then put the new text. Save - and restore registers as necessary. -Files: src/globals.h, src/normal.c, src/ops.c, src/proto/ops.pro, - src/vim.h - -Patch 6.1.238 (extra) -Problem: Win32: The "icon=" argument for the ":menu" command does not - search for the bitmap file. -Solution: Expand environment variables and search for the bitmap file. - (Vince Negri) - Make it consistent, use the same mechanism for X11 and GTK. -Files: src/gui.c src/gui_gtk.c, src/gui_w32.c, src/gui_x11.c, - src/proto/gui.pro - -Patch 6.1.239 -Problem: Giving an error for missing :endif or :endwhile when being - interrupted. -Solution: Don't give these messages when interrupted. -Files: src/ex_docmd.c, src/os_unix.c - -Patch 6.1.240 (extra) -Problem: Win32 with BCC 5: CPU may be defined in the environment, which - causes a wrong argument for the compiler. (Walter Briscoe) -Solution: Use CPUNR instead of CPU. -Files: src/Make_bc5.mak - -Patch 6.1.241 -Problem: Something goes wrong when drawing or undrawing the cursor. -Solution: Remember when the cursor invalid in a better way. -Files: src/gui.c - -Patch 6.1.242 -Problem: When pasting a large number of lines on the command line it is not - possible to interrupt. (Jean Jordaan) -Solution: Check for an interrupt after each pasted line. -Files: src/ops.c - -Patch 6.1.243 (extra) -Problem: Win32: When the OLE version is started and wasn't registered, a - message pops up to suggest registering, even when this isn't - possible (when the registry is not writable). -Solution: Check if registering is possible before asking whether it should - be done. (Walter Briscoe) - Also avoid restarting Vim after registering. -Files: src/if_ole.cpp - -Patch 6.1.244 -Problem: Patch 6.1.237 was missing the diff for vim.h. (Igor Goldenberg) -Solution: Include it here. -Files: src/vim.h - -Patch 6.1.245 -Problem: Comparing with ignored case does not work properly for Unicode - with a locale where case folding an ASCII character results in a - multi-byte character. (Glenn Maynard) -Solution: Handle ignore-case compare for Unicode differently. -Files: src/mbyte.c - -Patch 6.1.246 -Problem: ":blast" goes to the first buffer if the last one is unlisted. - (Andrew Stryker) -Solution: From the last buffer search backwards for the first listed buffer - instead of forwards. -Files: src/ex_docmd.c - -Patch 6.1.247 -Problem: ACL support doesn't always work properly. -Solution: Add a configure argument to disable ACL "--disable-acl". (Thierry - Vignaud) -Files: src/auto/configure, src/configure.in - -Patch 6.1.248 -Problem: Typing 'q' at the more-prompt for ":let" does not quit the - listing. (Hari Krishna Dara) -Solution: Quit the listing when got_int is set. -Files: src/eval.c - -Patch 6.1.249 -Problem: Can't expand a path on the command line if it includes a "|" as a - trail byte of a multi-byte character. -Solution: Check for multi-byte characters. (Yasuhiro Matsumoto) -Files: src/ex_docmd.c - -Patch 6.1.250 -Problem: When changing the value of 'lines' inside the expression set with - 'diffexpr' Vim might crash. (Dave Fishburn) -Solution: Don't allow changing the screen size while updating the screen. -Files: src/globals.h, src/option.c, src/screen.c - -Patch 6.1.251 -Problem: Can't use completion for ":lcd" and ":lchdir" like ":cd". -Solution: Expand directory names for these commands. (Servatius Brandt) -Files: src/ex_docmd.c - -Patch 6.1.252 -Problem: "vi}" does not include a line break when the "}" is at the start - of a following line. (Kamil Burzynski) -Solution: Include the line break. -Files: src/search.c - -Patch 6.1.253 (extra) -Problem: Win32 with Cygwin: Changes the path of arguments in a wrong way. - (Xiangjiang Ma) -Solution: Don't use cygwin_conv_to_posix_path() for the Win32 version. - Update the Cygwin makefile to support more features. (Dan Sharp) -Files: src/Make_cyg.mak, src/if_ole.cpp, src/main.c - -Patch 6.1.254 -Problem: exists("foo{bar}") does not work. ':unlet v{"a"}r' does not work. - ":let v{a}r1 v{a}r2" does not work. ":func F{(1)}" does not work. - ":delfunc F{" does not give an error message. ':delfunc F{"F"}' - does not work. -Solution: Support magic braces for the exists() argument. (Vince Negri) - Check for trailing comments explicitly for ":unlet". Add support - for magic braces in further arguments of ":let". Look for a - parenthesis only after the function name. (Servatius Brandt) - Also expand magic braces for "exists('*expr')". Give an error - message for an invalid ":delfunc" argument. Allow quotes in the - ":delfunc" argument. -Files: src/eval.c, src/ex_cmds.h, src/ex_docmd.c - -Patch 6.1.255 (depends on 6.1.254) -Problem: Crash when loading menu.vim a second time. (Christian Robinson) - ":unlet garbage foo" tries unletting "foo" after an error message. - (Servatius Brandt) - Very long function arguments cause very long messages when - 'verbose' is 14 or higher. -Solution: Avoid reading from uninitialized memory. - Break out of a loop after an invalid argument for ":unlet". - Truncate long function arguments to 80 characters. -Files: src/eval.c - -Patch 6.1.256 (depends on 6.1.255) -Problem: Defining a function after ":if 0" could still cause an error - message for an existing function. - Leaking memory when there are trailing characters for ":delfunc". -Solution: Check the "skip" flag. Free the memory. (Servatius Brandt) -Files: src/eval.c - -Patch 6.1.257 -Problem: ":cwindow" always sets the previous window to the last but one - window. (Benji Fisher) -Solution: Set the previous window properly. -Files: src/globals.c, src/quickfix.c, src/window.c - -Patch 6.1.258 -Problem: Buffers menu doesn't work properly for multibyte buffer names. -Solution: Use a pattern to get the left and right part of the name. - (Yasuhiro Matsumoto) -Files: runtime/menu.vim - -Patch 6.1.259 (extra) -Problem: Mac: with 'patchmode' is used filenames are truncated. -Solution: Increase the BASENAMELEN for Mac OS X. (Ed Ralston) -Files: src/os_mac.h - -Patch 6.1.260 (depends on 6.1.104) -Problem: GCC 3.2 still seems to have an optimizer problem. (Zvi Har'El) -Solution: Use the same configure check as used for GCC 3.1. -Files: src/auto/configure, src/configure.in - -Patch 6.1.261 -Problem: When deleting a line in a buffer which is not the current buffer, - using the Perl interface Delete(), the cursor in the current - window may move. (Chris Houser) -Solution: Don't adjust the cursor position when changing another buffer. -Files: src/if_perl.xs - -Patch 6.1.262 -Problem: When jumping over folds with "z[", "zj" and "zk" the previous - position is not remembered. (Hari Krishna Dara) -Solution: Set the previous context mark before jumping. -Files: src/fold.c - -Patch 6.1.263 -Problem: When typing a multi-byte character that triggers an abbreviation - it is not inserted properly. -Solution: Handle adding the typed multi-byte character. (Yasuhiro Matsumoto) -Files: src/getchar.c - -Patch 6.1.264 (depends on patch 6.1.254) -Problem: exists() does not work for built-in functions. (Steve Wall) -Solution: Don't check for the function name to start with a capital. -Files: src/eval.c - -Patch 6.1.265 -Problem: libcall() can be used in 'foldexpr' to call any system function. - rename(), delete() and remote_send() can also be used in - 'foldexpr'. These are security problems. (Georgi Guninski) -Solution: Don't allow using libcall(), rename(), delete(), remote_send() and - similar functions in the sandbox. -Files: src/eval.c - -Patch 6.1.266 (depends on 6.1.265) -Problem: Win32: compile error in eval.c. (Bill McCarthy) -Solution: Move a variable declaration. -Files: src/eval.c - -Patch 6.1.267 -Problem: Using "p" to paste into a Visual selected area may cause a crash. -Solution: Allocate enough memory for saving the register contents. (Muraoka - Taro) -Files: src/ops.c - -Patch 6.1.268 -Problem: When triggering an abbreviation with a multi-byte character, this - character is not correctly inserted after expanding the - abbreviation. (Taro Muraoka) -Solution: Add ABBR_OFF to all characters above 0xff. -Files: src/edit.c, src/ex_getln.c, src/getchar.c - -Patch 6.1.269 -Problem: After using input() text written with ":redir" gets extra indent. - (David Fishburn) -Solution: Restore msg_col after using input(). -Files: src/ex_getln.c - -Patch 6.1.270 (depends on 6.1.260) -Problem: GCC 3.2.1 still seems to have an optimizer problem. -Solution: Use the same configure check as used for GCC 3.1. -Files: src/auto/configure, src/configure.in - -Patch 6.1.271 -Problem: When compiling without the +syntax feature there are errors. -Solution: Don't use some code for syntax highlighting. (Roger Cornelius) - Make test 45 work without syntax highlighting. - Also fix an error in a pattern matching: "\%(" was not supported. -Files: src/ex_cmds2.c, src/regexp.c, src/testdir/test45.in - -Patch 6.1.272 -Problem: After using ":set define<" a crash may happen. (Christian Robinson) -Solution: Make a copy of the option value in allocated memory. -Files: src/option.c - -Patch 6.1.273 -Problem: When the cursor doesn't blink, redrawing an exposed area may hide - the cursor. -Solution: Always draw the cursor, also when it didn't move. (Muraoka Taro) -Files: src/gui.c - -Patch 6.1.274 (depends on 6.1.210) -Problem: Resetting the iconv() state after each error is wrong for an - incomplete sequence. -Solution: Don't reset the iconv() state. -Files: src/fileio.c - -Patch 6.1.275 -Problem: When using "v" in a startup script, get warning message that - terminal cannot highlight. (Charles Campbell) -Solution: Only give the message after the terminal has been initialized. -Files: src/normal.c - -Patch 6.1.276 -Problem: "gvim --remote file" doesn't prompt for an encryption key. -Solution: The further characters the client sends to the server are used. - Added inputsave() and inputrestore() to allow prompting the - user directly and not using typeahead. - Also fix possible memory leak for ":normal". -Files: src/eval.c, src/ex_cmds2.c, src/ex_docmd.c, src/getchar.c, - src/main.c, src/proto/getchar.pro, src/proto/ui.pro, - src/runtime/doc/eval.txt, src/structs.h, src/ui.c, src/vim.h - -Patch 6.1.277 (depends on 6.1.276) -Problem: Compilation error when building with small features. -Solution: Define trash_input_buf() when needed. (Kelvin Lee) -Files: src/ui.c - -Patch 6.1.278 -Problem: When using signs the line number of a closed fold doesn't line up - with the other line numbers. (Kamil Burzynski) -Solution: Insert two spaces for the sign column. -Files: src/screen.c - -Patch 6.1.279 -Problem: The prototype for smsg() and smsg_attr() do not match the function - definition. This may cause trouble for some compilers. (Nix) -Solution: Use va_list for systems that have stdarg.h. Use "int" instead of - "void" for the return type. -Files: src/auto/configure, src/config.h.in, src/configure.in, - src/proto.h, src/message.c - -Patch 6.1.280 -Problem: It's possible to use an argument "firstline" or "lastline" for a - function but using "a:firstline" or "a:lastline" in the function - won't work. (Benji Fisher) -Solution: Give an error message for these arguments. - Also avoid that the following function body causes a whole row of - errors, skip over it after an error in the first line. -Files: src/eval.c - -Patch 6.1.281 -Problem: In Insert mode CTRL-X CTRL-G leaves the cursor after the ruler. -Solution: Set the cursor position before waiting for the argument of CTRL-G. - (Yasuhiro Matsumoto) -Files: src/edit.c - -Patch 6.1.282 -Problem: Elvis uses "se" in a modeline, Vim doesn't recognize this. -Solution: Also accept "se " where "set " is accepted in a modeline. - (Yasuhiro Matsumoto) -Files: src/buffer.c - -Patch 6.1.283 -Problem: For ":sign" the icon file name cannot contain a space. -Solution: Handle backslashes in the file name. (Yasuhiro Matsumoto) -Files: src/ex_cmds.c - -Patch 6.1.284 -Problem: On Solaris there is a warning for "struct utimbuf". -Solution: Move including "utime.h" to outside the function. (Derek Wyatt) -Files: src/fileio.c - -Patch 6.1.285 -Problem: Can't wipe out a buffer with 'bufhide' option. -Solution: Add "wipe" value to 'bufhide'. (Yegappan Lakshmanan) -Files: runtime/doc/options.txt, src/buffer.c, src/option.c, - src/quickfix.c - -Patch 6.1.286 -Problem: 'showbreak' cannot contain multi-byte characters. -Solution: Allow using all printable characters for 'showbreak'. -Files: src/charset.c, src/move.c, src/option.c - -Patch 6.1.287 (depends on 6.1.285) -Problem: Effect of "delete" and "wipe" in 'bufhide' were mixed up. -Solution: Wipe out when wiping out is asked for. -Files: src/buffer.c - -Patch 6.1.288 -Problem: ":silent function F" hangs. (Hari Krishna Dara) -Solution: Don't use msg_col, it is not incremented when using ":silent". - Also made the function output look a bit better. Don't translate - "function". -Files: src/eval.c - -Patch 6.1.289 (depends on 6.1.278) -Problem: Compiler warning for pointer. (Axel Kielhorn) -Solution: Add a typecast for " ". -Files: src/screen.c - -Patch 6.1.290 (extra) -Problem: Truncating long text for message box may break multi-byte - character. -Solution: Adjust to start of multi-byte character. (Yasuhiro Matsumoto) -Files: src/os_mswin.c - -Patch 6.1.291 (extra) -Problem: Win32: CTRL-@ doesn't work. Don't even get a message for it. -Solution: Recognize the keycode for CTRL-@. (Yasuhiro Matsumoto) -Files: src/gui_w48.c - -Patch 6.1.292 (extra, depends on 6.1.253) -Problem: Win32: Can't compile with new MingW compiler. - Borland 5 makefile doesn't generate pathdef.c. -Solution: Remove -wwide-multiply argument. (Rene de Zwart) - Various fixes for other problems in Win32 makefiles. (Dan Sharp) -Files: src/Make_bc5.mak, src/Make_cyg.mak, src/Make_ming.mak, - src/Make_mvc.mak - -Patch 6.1.293 -Problem: byte2line() returns a wrong result for some values. -Solution: Change ">=" to ">" in ml_find_line_or_offset(). (Bradford C Smith) - Add one to the line number when at the end of a block. -Files: src/memline.c - -Patch 6.1.294 -Problem: Can't include a multi-byte character in a string by its hex value. - (Benji Fisher) -Solution: Add "\u....": a character specified with up to four hex numbers - and stored according to the value of 'encoding'. -Files: src/eval.c - -Patch 6.1.295 (extra) -Problem: Processing the cs.po file generates an error. (Rahul Agrawal) -Solution: Fix the printf format characters in the translation. -Files: src/po/cs.po - -Patch 6.1.296 -Problem: Win32: When cancelling the font dialog 'guifont' remains set to - "*". -Solution: Restore the old value of 'guifont' (Yasuhiro Matsumoto) -Files: src/option.c - -Patch 6.1.297 -Problem: "make test" fails in test6 in an UTF-8 environment. (Benji Fisher) -Solution: Before executing the BufReadPost autocommands save the current - fileencoding, so that the file isn't marked changed. -Files: src/fileio.c - -Patch 6.1.298 -Problem: When using signs and the first line of a closed fold has a sign - it can be redrawn as if the fold was open. (Kamil Burzynski) -Solution: Don't redraw a sign inside a closed fold. -Files: src/screen.c - -Patch 6.1.299 -Problem: ":edit +set\ ro file" doesn't work. -Solution: Halve the number of backslashes in the "+cmd" argument. -Files: src/ex_docmd.c - -Patch 6.1.300 (extra) -Problem: Handling of ETO_IGNORELANGUAGE is confusing. -Solution: Clean up the handling of ETO_IGNORELANGUAGE. (Glenn Maynard) -Files: src/gui_w32.c - -Patch 6.1.301 (extra) -Problem: French translation of file-save dialog doesn't show file name. -Solution: Insert a star in the printf string. (Francois Terrot) -Files: src/po/fr.po - -Patch 6.1.302 -Problem: Counting lines of the Visual area is incorrect for closed folds. - (Mikolaj Machowski) -Solution: Correct the start and end for the closed fold. -Files: src/normal.c - -Patch 6.1.303 (extra) -Problem: The Top/Bottom/All text does not always fit in the ruler when - translated to Japanese. Problem with a character being wider when - in a bold font. -Solution: Use ETO_PDY to specify the width of each character. (Yasuhiro - Matsumoto) -Files: src/gui_w32.c - -Patch 6.1.304 (extra, depends on 6.1.292) -Problem: Win32: Postscript is always enabled in the MingW Makefile. - Pathdef.c isn't generated properly with Make_bc5.mak. (Yasuhiro - Matsumoto) -Solution: Change an ifdef to an ifeq. (Madoka Machitani) - Use the Borland make redirection to generate pathdef.c. (Maurice - Barnum) -Files: src/Make_bc5.mak, src/Make_ming.mak - -Patch 6.1.305 -Problem: When 'verbose' is 14 or higher, a function call may cause reading - uninitialized data. (Walter Briscoe) -Solution: Check for end-of-string in trunc_string(). -Files: src/message.c - -Patch 6.1.306 -Problem: The AIX VisualAge cc compiler doesn't define __STDC__. -Solution: Use __EXTENDED__ like __STDC__. (Jess Thrysoee) -Files: src/os_unix.h - -Patch 6.1.307 -Problem: When a double-byte character has an illegal tail byte the display - is messed up. (Yasuhiro Matsumoto) -Solution: Draw "XX" instead of the wrong character. -Files: src/screen.c - -Patch 6.1.308 -Problem: Can't reset the Visual mode returned by visualmode(). -Solution: Use an optional argument to visualmode(). (Charles Campbell) -Files: runtime/doc/eval.txt, src/eval.c, src/normal.c, - src/structs.h - -Patch 6.1.309 -Problem: The tutor doesn't select German if the locale name is - "German_Germany.1252". (Joachim Hofmann) -Solution: Check for "German" in the locale name. Also check for - ".ge". And include the German and Greek tutors. -Files: runtime/tutor/tutor.de, runtime/tutor/tutor.vim, - runtime/tutor/tutor.gr, runtime/tutor/tutor.gr.cp737 - -Patch 6.1.310 (depends on 6.1.307) -Problem: All double-byte characters are displayed as "XX". -Solution: Use ">= 32" instead of "< 32". (Yasuhiro Matsumoto) -Files: src/screen.c - -Patch 6.1.311 (extra) -Problem: VMS: path in window title doesn't include necessary separator. - file version doesn't always work properly with Unix. - Crashes because of memory overwrite in GUI. - Didn't always handle files with lowercase and correct path. -Solution: Fix the problems. Remove unnecessary file name translations. - (Zoltan Arpadffy) -Files: src/buffer.c, src/ex_cmds2.c, src/fileio.c, src/memline.c, - src/misc1.c, src/misc2.c, src/os_unix.c, src/os_vms.c, src/tag.c - -Patch 6.1.312 -Problem: When using ":silent" debugging is also done silently. -Solution: Disable silence while at the debug prompt. -Files: src/ex_cmds2.c - -Patch 6.1.313 -Problem: When a ":drop fname" command is used and "fname" is open in - another window, it is also opened in the current window. -Solution: Change to the window with "fname" instead. - Don't redefine the argument list when dropping only one file. -Files: runtime/doc/windows.txt, src/ex_cmds2.c, src/ex_cmds.c, - src/ex_docmd.c, src/proto/ex_cmds2.pro, src/proto/ex_docmd.pro - -Patch 6.1.314 (depends on 6.1.126) -Problem: Missing backslash in "Generic Config file" syntax menu. -Solution: Insert the backslash. (Zak Beck) -Files: runtime/makemenu.vim, runtime/synmenu.vim - -Patch 6.1.315 (extra) -Problem: A very long hostname may lead to an unterminated string. Failing - to obtain a hostname may result in garbage. (Walter Briscoe) -Solution: Add a NUL at the end of the hostname buffer. -Files: src/os_mac.c, src/os_msdos.c, src/os_unix.c, src/os_win16.c, - src/os_win32.c - -Patch 6.1.316 -Problem: When exiting with "wq" and there is a hidden buffer, after the - "file changed" dialog there is a warning for a changed buffer. - (Ajit Thakkar) -Solution: Do update the buffer timestamps when exiting. -Files: src/fileio.c - -Patch 6.1.317 -Problem: Closing a window may cause some of the remaining windows to be - positioned wrong if there is a mix of horizontal and vertical - splits. (Stefan Ingi Valdimarsson) -Solution: Update the frame sizes before updating the window positions. -Files: src/window.c - -Patch 6.1.318 -Problem: auto/pathdef.c can include wrong quotes when a compiler flag - includes quotes. -Solution: Put a backslash before the quotes in compiler flags. (Shinra Aida) -Files: src/Makefile - -Patch 6.1.319 (depends on 6.1.276) -Problem: Using "--remote +cmd file" does not execute "cmd". -Solution: Call inputrestore() in the same command line as inputsave(), - otherwise it will never get executed. -Files: src/main.c - -Patch 6.1.320 (depends on 6.1.313) -Problem: When a ":drop one\ file" command is used the file "one\ file" is - opened, the backslash is not removed. (Taro Muraoka) -Solution: Handle backslashes correctly. Always set the argument list to - keep it simple. -Files: runtime/doc/windows.txt, src/ex_cmds.c - -Patch 6.1.321 -Problem: When 'mouse' includes 'n' but not 'v', don't allow starting Visual - mode with the mouse. -Solution: Don't use MOUSE_MAY_VIS when there is no 'v' in 'mouse'. (Flemming - Madsen) -Files: src/normal.c - -Patch 6.1.322 (extra, depends on 6.1.315) -Problem: Win32: The host name is always "PC " plus the real host name. -Solution: Don't insert "PC " before the host name. -Files: src/os_win32.c - -Patch 6.1.323 -Problem: ":registers" doesn't stop listing for a "q" at the more prompt. - (Hari Krishna Dara) -Solution: Check for interrupt and got_int. -Files: src/ops.c, src/proto/ops.pro - -Patch 6.1.324 -Problem: Crash when dragging a vertical separator when <LeftMouse> is - remapped to jump to another window. -Solution: Pass the window pointer to the function doing the dragging instead - of always using the current window. (Daniel Elstner) - Also fix that starting a drag changes window focus. -Files: src/normal.c, src/proto/window.pro, src/ui.c, src/vim.h, - src/window.c - -Patch 6.1.325 -Problem: Shift-Tab is not automatically recognized in an xterm. -Solution: Add <Esc>[Z as the termcap code. (Andrew Pimlott) -Files: src/term.c - -Patch 6.1.326 -Problem: Using a search pattern may read from uninitialized data (Yasuhiro - Matsumoto) -Solution: Initialize pointers to NULL. -Files: src/regexp.c - -Patch 6.1.327 -Problem: When opening the "mbyte.txt" help file the utf-8 characters are - unreadable, because the fileencoding is forced to be latin1. -Solution: Check for utf-8 encoding first in help files. (Daniel Elstner) -Files: runtime/doc/mbyte.txt, src/fileio.c - -Patch 6.1.328 -Problem: Prototype for enc_canon_search() is missing. -Solution: Add the prototype. (Walter Briscoe) -Files: src/mbyte.c - -Patch 6.1.329 -Problem: When editing a file "a b c" replacing "%" in ":Cmd %" or ":next %" - does not work properly. (Hari Krishna Dara) -Solution: Always escape spaces when expanding "%". Don't split argument for - <f-args> in a user command when only one argument is used. -Files: src/ex_docmd.c - -Patch 6.1.330 -Problem: GTK, Motif and Athena: Keypad keys produce the same code as - non-keypad keys, making it impossible to map them separately. -Solution: Use different termcap codes for the keypad keys. (Neil Bird) -Files: src/gui_gtk_x11.c, src/gui_x11.c - -Patch 6.1.331 -Problem: When translating the help files, "LOCAL ADDITIONS" no longer marks - the spot where help files from plugins are to be listed. -Solution: Add a "local-additions" tag and use that to find the right spot. -Files: runtime/doc/help.txt, src/ex_cmds.c - -Patch 6.1.332 (extra) -Problem: Win32: Loading Perl dynamically doesn't work with Perl 5.8. - Perl 5.8 also does not work with Cygwin and Ming. -Solution: Adjust the function calls. (Taro Muraoka) - Adjust the cyg and ming makefiles. (Dan Sharp) -Files: src/Make_cyg.mak, src/Make_ming.mak, src/Make_mvc.mak, - src/if_perl.xs - -Patch 6.1.333 (extra) -Problem: Win32: Can't handle Unicode text on the clipboard. - Can't pass NUL byte, it becomes a line break. (Bruce DeVisser) -Solution: Support Unicode for the clipboard (Ron Aaron and Glenn Maynard) - Also support copy/paste of NUL bytes. -Files: src/os_mswin.c, src/os_win16.c src/os_win32.c - -Patch 6.1.334 (extra, depends on 6.1.303) -Problem: Problem with drawing Hebrew characters. -Solution: Only use ETO_PDY for Windows NT and the like. (Yasuhiro Matsumoto) -Files: src/gui_w32.c - -Patch 6.1.335 (extra) -Problem: Failure of obtaining the cursor position and window size is - ignored. -Solution: Remove a semicolon after an "if". (Walter Briscoe) -Files: src/gui_w32.c - -Patch 6.1.336 (extra) -Problem: Warning for use of function prototypes of smsg(). -Solution: Define HAVE_STDARG_H. (Walter Briscoe) -Files: src/os_win32.h - -Patch 6.1.337 -Problem: When using "finish" in debug mode in function B() for ":call - A(B())" does not stop after B() is finished. -Solution: Increase debug_level while evaluating a function. -Files: src/ex_docmd.c - -Patch 6.1.338 -Problem: When using a menu that checks out the current file from Insert - mode, there is no warning for the changed file until exiting - Insert mode. (Srikanth Sankaran) -Solution: Add a check for need_check_timestamps in the Insert mode loop. -Files: src/edit.c - -Patch 6.1.339 -Problem: Completion doesn't allow "g:" in ":let g:did_<Tab>". (Benji - Fisher) -Solution: Return "g:var" for global variables when that is what is being - expanded. (Flemming Madsen) -Files: src/eval.c - -Patch 6.1.340 (extra, depends on 6.1.332) -Problem: Win32: Can't compile the Perl interface with nmake. -Solution: Don't compare the version number as a string but as a number. - (Juergen Kraemer) -Files: src/Make_mvc.mak - -Patch 6.1.341 -Problem: In Insert mode with 'rightleft' set the cursor is drawn halfway a - double-wide character. For CTRL-R and CTRL-K in Insert mode the " - or ? is not displayed. -Solution: Draw the cursor in the next character cell. Display the " or ? - over the right half of the double-wide character. (Yasuhiro - Matsumoto) Also fix that cancelling a digraph doesn't redraw - a double-byte character correctly. -Files: src/edit.c, src/gui.c, src/mbyte.c - -Patch 6.1.342 (depends on 6.1.341) -Problem: With 'rightleft' set typing "c" on a double-wide character causes - the cursor to be displayed one cell to the left. -Solution: Draw the cursor in the next character cell. (Yasuhiro Matsumoto) -Files: src/gui.c - -Patch 6.1.343 (depends on 6.1.342) -Problem: Cannot compile with the +multi_byte feature but without +rightleft. - Cannot compile without the GUI. -Solution: Fix the #ifdefs. (partly by Nam SungHyun) -Files: src/gui.c, src/mbyte.c, src/ui.c - -Patch 6.1.344 -Problem: When using ":silent filetype" the output is still put in the - message history. (Hari Krishna Dara) -Solution: Don't add messages in the history when ":silent" is used. -Files: src/message.c - -Patch 6.1.345 (extra) -Problem: Win32: 'imdisable' doesn't work. -Solution: Make 'imdisable' work. (Yasuhiro Matsumoto) -Files: src/gui_w32.c - -Patch 6.1.346 -Problem: The scroll wheel can only scroll the current window. -Solution: Make the scroll wheel scroll the window that the mouse points to. - (Daniel Elstner) -Files: src/edit.c, src/gui.c, src/normal.c, src/term.c - -Patch 6.1.347 -Problem: When using cscope to list matching tags, the listed number is - sometimes not equal to what cscope uses. (Vihren Milev) -Solution: For cscope tags use only one table, don't give tags in the current - file a higher priority. -Files: src/tag.c - -Patch 6.1.348 -Problem: Wildmode with wildmenu: ":set wildmode=list,full", ":colorscheme - <tab>" results in "zellner" instead of the first entry. (Anand - Hariharan) -Solution: Don't call ExpandOne() from globpath(). (Flemming Madsen) -Files: src/ex_getln.c - -Patch 6.1.349 -Problem: "vim --serverlist" when no server was ever started gives an error - message without "\n". - "vim --serverlist" doesn't exit when the X server can't be - contacted, it starts Vim unexpectedly. (Ricardo Signes) -Solution: Don't give an error when no Vim server was ever started. - Treat failing of opening the display equal to errors inside the - remote*() functions. (Flemming Madsen) -Files: src/if_xcmdsrv.c, src/main.c - -Patch 6.1.350 -Problem: When entering a buffer with ":bnext" for the first time, using an - autocommand to restore the last used cursor position doesn't work. - (Paolo Giarusso) -Solution: Don't use the last known cursor position of the current Vim - invocation if an autocommand changed the position. -Files: src/buffer.c - -Patch 6.1.351 (depends on 6.1.349) -Problem: Crash when starting Vim the first time in an X server. (John - McGowan) -Solution: Don't call xFree() with a fixed string. -Files: src/if_xcmdsrv.c - -Patch 6.1.352 (extra, depends on 6.1.345) -Problem: Win32: Crash when setting "imdisable" in _vimrc. -Solution: Don't call IME functions when imm32.dll was not loaded (yet). - Also add typecasts to avoid Compiler warnings for - ImmAssociateContext() argument. -Files: src/gui_w32.c - -Patch 6.1.353 (extra, depends on 6.1.334) -Problem: Problem with drawing Arabic characters. -Solution: Don't use ETO_PDY, do use padding. -Files: src/gui_w32.c - -Patch 6.1.354 (extra, depends on 6.1.333) -Problem: MS-Windows 98: Notepad can't paste text copied from Vim when - 'encoding' is "utf-8". -Solution: Also make CF_TEXT available on the clipboard. (Ron Aaron) -Files: src/os_mswin.c - -Patch 6.1.355 -Problem: In a regexp '\n' will never match anything in a string. -Solution: Make '\n' match a newline character. -Files: src/buffer.c, src/edit.c, src/eval.c, src/ex_cmds2.c, - src/ex_docmd.c, src/ex_getln.c, src/fileio.c, src/misc1.c, - src/option.c, src/os_mac.c, src/os_unix.c, src/quickfix.c, - src/regexp.c, src/search.c, src/syntax.c, src/tag.c, src/vim.h - -Patch 6.1.356 (extra, depends on, well, eh, several others) -Problem: Compiler warnings for using convert_setup() and a few other - things. -Solution: Add typecasts. -Files: src/mbyte.c, src/os_mswin.c, src/proto/os_win32.pro, src/os_win32.c - -Patch 6.1.357 -Problem: CR in the quickfix window jumps to the error under the cursor, but - this doesn't work in Insert mode. (Srikanth Sankaran) -Solution: Handle CR in Insert mode in the quickfix window. -Files: src/edit.c - -Patch 6.1.358 -Problem: The tutor doesn't select another locale version properly. -Solution: Insert the "let" command. (Yasuhiro Matsumoto) -Files: runtime/tutor/tutor.vim - -Patch 6.1.359 (extra) -Problem: Mac Carbon: Vim doesn't get focus when started from the command - line. Crash when using horizontal scroll bar. -Solution: Set Vim as the frontprocess. Fix scrolling. (Peter Cucka) -Files: src/gui_mac.c - -Patch 6.1.360 (depends on 6.1.341) -Problem: In Insert mode CTRL-K ESC messes up a multi-byte character. - (Anders Helmersson) -Solution: Save all bytes of a character when displaying a character - temporarily. -Files: src/edit.c, src/proto/screen.pro, src/screen.c - -Patch 6.1.361 -Problem: Cannot jump to a file mark with ":'M". -Solution: Allow jumping to another file for a mark in an Ex address when it - is the only thing in the command line. -Files: src/ex_docmd.c - -Patch 6.1.362 -Problem: tgetent() may return zero for success. tgetflag() may return -1 - for an error. -Solution: Check tgetflag() for returning a positive value. Add an autoconf - check for the value that tgetent() returns. -Files: src/auto/configure, src/config.h.in, src/configure.in, src/term.c - -Patch 6.1.363 -Problem: byte2line() can return one more than the number of lines. -Solution: Return -1 if the offset is one byte past the end. -Files: src/memline.c - -Patch 6.1.364 -Problem: That the FileChangedShell autocommand event never nests makes it - difficult to reload a file in a normal way. -Solution: Allow nesting for the FileChangedShell event but do not allow - triggering itself again. - Also avoid autocommands for the cmdline window in rare cases. -Files: src/ex_getln.c, src/fileio.c, src/window.c - -Patch 6.1.365 (depends on 6.1.217) -Problem: Setting a breakpoint in a sourced file with a relative path name - doesn't work. (Servatius Brandt) -Solution: Expand the file name to a full path. -Files: src/ex_cmds2.c - -Patch 6.1.366 -Problem: Can't use Vim with Netbeans. -Solution: Add the Netbeans interface. Includes support for sign icons and - "-fg" and "-bg" arguments for GTK. Add the 'autochdir' - option. (Gordon Prieur, George Hernandez, Dave Weatherford) - Make it possible to display both a sign with a text and one with - line highlighting in the same line. - Add support for Agide, interface version 2.1. - Also fix that when 'iskeyword' includes '?' the "*" command - doesn't work properly on a word that includes "?" (Bill McCarthy): - Don't escape "?" to "\?" when searching forward. -Files: runtime/doc/Makefile, runtime/doc/netbeans.txt, - runtime/doc/options.txt, runtime/doc/various.txt, - src/Makefile, src/auto/configure, src/buffer.c, src/config.h.in, - src/config.mk.in, src/configure.in, src/edit.c, src/ex_cmds.c, - src/ex_docmd.c, src/feature.h, src/fileio.c, src/globals.h, - src/gui.c, src/gui_beval.c, src/gui_gtk_x11.c, src/gui_x11.c, - src/main.c, src/memline.c, src/misc1.c, src/misc2.c, src/move.c, - src/nbdebug.c, src/nbdebug.h, src/netbeans.c, src/normal.c, - src/ops.c, src/option.c, src/option.h, src/proto/buffer.pro, - src/proto/gui_beval.pro, src/proto/gui_gtk_x11.pro, - src/proto/gui_x11.pro, src/proto/misc2.pro, - src/proto/netbeans.pro, src/proto/normal.pro, src/proto/ui.pro, - src/proto.h, src/screen.c, src/structs.h, src/ui.c, src/undo.c, - src/vim.h, src/window.c, src/workshop.c - -Patch 6.1.367 (depends on 6.1.365) -Problem: Setting a breakpoint in a function doesn't work. For a sourced - file it doesn't work when symbolic links are involved. (Servatius - Brandt) -Solution: Expand the file name in the same way as do_source() does. Don't - prepend the path to a function name. -Files: src/ex_cmds2.c - -Patch 6.1.368 -Problem: Completion for ":map" does not include <silent> and <script>. - ":mkexrc" do not save the <silent> attribute of mappings. -Solution: Add "<silent>" to the generated map commands when appropriate. - (David Elstner) - Add <silent> and <script> to command line completion. -Files: src/getchar.c - -Patch 6.1.369 (extra) -Problem: VMS: Vim hangs when attempting to edit a read-only file in the - terminal. Problem with VMS filenames for quickfix. -Solution: Rewrite low level input. Remove version number from file name in - a couple more places. Fix crash after patch 6.1.362. Correct - return code for system(). (Zoltan Arpadffy, Tomas Stehlik) -Files: src/misc1.c, src/os_unix.c, src/os_vms.c, src/proto/os_vms.pro, - src/os_vms_conf.h, src/quickfix.c, src/ui.c - -Patch 6.1.370 -Problem: #ifdef nesting is unclear. -Solution: Insert spaces to indicate the nesting. -Files: src/os_unix.c - -Patch 6.1.371 -Problem: "%V" in 'statusline' doesn't show "0-1" in an empty line. -Solution: Add one to the column when comparing with virtual column (Andrew - Pimlott) -Files: src/buffer.c - -Patch 6.1.372 -Problem: With 16 bit ints there are compiler warnings. (Walter Briscoe) -Solution: Change int into long. -Files: src/structs.h, src/syntax.c - -Patch 6.1.373 -Problem: The default page header for printing is not translated. -Solution: Add _() around the two places where "Page" is used. (Mike - Williams) Translate the default value of the 'titleold' and - 'printheader' options. -Files: src/ex_cmds2.c, src/option.c - -Patch 6.1.374 (extra) -Problem: MS-Windows: Cannot build GvimExt with MingW or Cygwin. -Solution: Add makefile and modified resource files. (Rene de Zwart) - Also support Cygwin. (Alejandro Lopez_Valencia) -Files: GvimExt/Make_cyg.mak, GvimExt/Make_ming.mak, GvimExt/Makefile, - GvimExt/gvimext_ming.def, GvimExt/gvimext_ming.rc - -Patch 6.1.375 -Problem: MS-Windows: ':!dir "%"' does not work for a file name with spaces. - (Xiangjiang Ma) -Solution: Don't insert backslashes for spaces in a shell command. -Files: src/ex_docmd.c - -Patch 6.1.376 -Problem: "vim --version" and "vim --help" have a non-zero exit code. - That is unusual. (Petesea) -Solution: Use a zero exit code. -Files: src/main.c - -Patch 6.1.377 -Problem: Can't add words to 'lispwords' option. -Solution: Add P_COMMA and P_NODUP flags. (Haakon Riiser) -Files: src/option.c - -Patch 6.1.378 -Problem: When two buffer-local user commands are ambiguous, a full match - with a global user command isn't found. (Hari Krishna Dara) -Solution: Detect this situation and accept the global command. -Files: src/ex_docmd.c - -Patch 6.1.379 -Problem: Linux with kernel 2.2 can't use the alternate stack in combination - with threading, causes an infinite loop. -Solution: Don't use the alternate stack in this situation. -Files: src/os_unix.c - -Patch 6.1.380 -Problem: When 'winminheight' is zero and the quickfix window is zero lines, - entering the window doesn't make it higher. (Christian J. - Robinson) -Solution: Make sure the current window is at least one line high. -Files: src/window.c - -Patch 6.1.381 -Problem: When a BufWriteCmd is used and it leaves the buffer modified, the - window may still be closed. (Hari Krishna Dara) -Solution: Return FAIL from buf_write() when the buffer is still modified - after a BufWriteCmd autocommand was used. -Files: src/fileio.c - -Patch 6.1.382 (extra) -Problem: Win32 GUI: When using two monitors, the code that checks/fixes the - window size and position (e.g. when a font changes) doesn't work - properly. (George Reilly) -Solution: Handle a double monitor situation. (Helmut Stiegler) -Files: src/gui_w32.c - -Patch 6.1.383 -Problem: The filling of the status line doesn't work properly for - multi-byte characters. (Nam SungHyun) - There is no check for going past the end of the buffer. -Solution: Properly distinguish characters and bytes. Properly check for - running out of buffer space. -Files: src/buffer.c, src/ex_cmds2.c, src/proto/buffer.pro, src/screen.c - -Patch 6.1.384 -Problem: It is not possible to find if a certain patch has been included. - (Lubomir Host) -Solution: Support using has() to check if a patch was included. -Files: runtime/doc/eval.txt, src/eval.c, src/proto/version.pro, - src/version.c - -Patch 6.1.385 (depends on 6.1.383) -Problem: Can't compile without the multi-byte feature. -Solution: Move an #ifdef. (Christian J. Robinson) -Files: src/buffer.c - -Patch 6.1.386 -Problem: Get duplicate tags when running ":helptags". -Solution: Do the other halve of moving a section to another help file. -Files: runtime/tagsrch.txt - -Patch 6.1.387 (depends on 6.1.373) -Problem: Compiler warning for pointer cast. -Solution: Add (char_u *). -Files: src/option.c - -Patch 6.1.388 (depends on 6.1.384) -Problem: Compiler warning for pointer cast. -Solution: Add (char *). Only include has_patch() when used. -Files: src/eval.c, src/version.c - -Patch 6.1.389 (depends on 6.1.366) -Problem: Balloon evaluation doesn't work for GTK. - has("balloon_eval") doesn't work. -Solution: Add balloon evaluation for GTK. Also improve displaying of signs. - (Daniel Elstner) - Also make ":gui" start the netbeans connection and avoid using - netbeans functions when the connection is not open. -Files: src/Makefile, src/feature.h, src/gui.c, src/gui.h, - src/gui_beval.c, src/gui_beval.h, src/gui_gtk.c, - src/gui_gtk_x11.c, src/eval.c, src/memline.c, src/menu.c, - src/netbeans.c, src/proto/gui_beval.pro, src/proto/gui_gtk.pro, - src/structs.h, src/syntax.c, src/ui.c, src/workshop.c - -Patch 6.1.390 (depends on 6.1.389) -Problem: It's not possible to tell Vim to save and exit through the - Netbeans interface. Would still try to send balloon eval text - after the connection is closed. - Can't use Unicode characters for sign text. -Solution: Add functions "saveAndExit" and "getModified". Check for a - working connection before sending a balloonText event. - various other cleanups. - Support any character for sign text. (Daniel Elstner) -Files: runtime/doc/netbeans.txt, runtime/doc/sign.txt, src/ex_cmds.c, - src/netbeans.c, src/screen.c - -Patch 6.1.391 -Problem: ml_get() error when using virtualedit. (Charles Campbell) -Solution: Get a line from a specific window, not the current one. -Files: src/charset.c - -Patch 6.1.392 (depends on 6.1.383) -Problem: Highlighting in the 'statusline' is in the wrong position when an - item is truncated. (Zak Beck) -Solution: Correct the start of 'statusline' items properly for a truncated - item. -Files: src/buffer.c - -Patch 6.1.393 -Problem: When compiled with Python and threads, detaching the terminal may - cause Vim to loop forever. -Solution: Add -pthread to $CFLAGS when using Python and gcc. (Daniel - Elstner) -Files: src/auto/configure,, src/configure.in - -Patch 6.1.394 (depends on 6.1.390) -Problem: The netbeans interface doesn't recognize multibyte glyph names. -Solution: Check the number of cells rather than bytes to decide - whether a glyph name is not a filename. (Daniel Elstner) -Files: src/netbeans.c - -Patch 6.1.395 (extra, depends on 6.1.369) -Problem: VMS: OLD_VMS is never defined. Missing function prototype. -Solution: Define OLD_VMS in Make_vms.mms. Add vms_sys_status() to - os_vms.pro. (Zoltan Arpadffy) -Files: src/Make_vms.mms, src/proto/os_vms.pro - -Patch 6.1.396 (depends on 6.1.330) -Problem: Compiler warnings for using enum. -Solution: Add typecast to char_u. -Files: src/gui_gtk_x11.c, src/gui_x11.c - -Patch 6.1.397 (extra) -Problem: The install program may use a wrong path for the diff command if - there is a space in the install directory path. -Solution: Use double quotes around the path if necessary. (Alejandro - Lopez-Valencia) Also use double quotes around the file name - arguments. -Files: src/dosinst.c - -Patch 6.1.398 -Problem: Saving the typeahead for debug mode causes trouble for a test - script. (Servatius Brandt) -Solution: Add the ":debuggreedy" command to avoid saving the typeahead. -Files: runtime/doc/repeat.txt, src/ex_cmds.h, src/ex_cmds2.c, - src/ex_docmd.c, src/proto/ex_cmds2.pro - -Patch 6.1.399 -Problem: Warning for unused variable. -Solution: Remove the variable two_or_more. -Files: src/ex_cmds.c - -Patch 6.1.400 (depends on 6.1.381) -Problem: When a BufWriteCmd wipes out the buffer it may still be accessed. -Solution: Don't try accessing a buffer that has been wiped out. -Files: src/fileio.c - -Patch 6.1.401 (extra) -Problem: Building the Win16 version with Borland 5.01 doesn't work. - "make test" doesn't work with Make_dos.mak. (Walter Briscoe) -Solution: Various fixes to the w16 makefile. (Walter Briscoe) - Don't use deltree. Use "mkdir \tmp" instead of "mkdir /tmp". -Files: src/Make_w16.mak, src/testdir/Make_dos.mak - -Patch 6.1.402 -Problem: When evaluating a function name with curly braces, an error - is not handled consistently. -Solution: Accept the result of an curly braces expression when an - error was encountered. Skip evaluating an expression in curly - braces when skipping. (Servatius Brandt) -Files: src/eval.c - -Patch 6.1.403 (extra) -Problem: MS-Windows 16 bit: compiler warnings. -Solution: Add typecasts. (Walter Briscoe) -Files: src/ex_cmds2.c, src/gui_w48.c, src/os_mswin.c, src/os_win16.c, - src/syntax.c - -Patch 6.1.404 (extra) -Problem: Various small problems. -Solution: Fix comments. Various small additions, changes in indent, removal - of unused items and fixes. -Files: Makefile, README.txt, runtime/menu.vim, runtime/vimrc_example.vim, - src/INSTALL, src/INSTALLole.txt, src/Make_bc5.mak, - src/Make_cyg.mak, src/Make_ming.mak, src/Makefile, - src/config.h.in, src/edit.c, src/eval.c, src/ex_cmds2.c, - src/ex_docmd.c, src/ex_getln.c, src/fileio.c, src/getchar.c, - src/gui.c, src/gui_gtk.c, src/gui_photon.c, src/if_cscope.c, - src/if_python.c, src/keymap.h, src/mark.c, src/mbyte.c, - src/message.c, src/misc1.c, src/misc2.c, src/normal.c, - src/option.c, src/os_os2_cfg.h, src/os_win32.c, - src/proto/getchar.pro, src/proto/message.pro, - src/proto/regexp.pro, src/screen.c, src/structs.h, src/syntax.c, - src/term.c, src/testdir/test15.in, src/testdir/test15.ok, - src/vim.rc, src/xxd/Make_cyg.mak, src/xxd/Makefile - -Patch 6.1.405 -Problem: A few files are missing from the toplevel Makefile. -Solution: Add the missing files. -Files: Makefile - -Patch 6.1.406 (depends on 6.1.392) -Problem: When a statusline item doesn't fit arbitrary text appears. - (Christian J. Robinson) -Solution: When there is just enough room but not for the "<" truncate the - statusline item like there is no room. -Files: src/buffer.c - -Patch 6.1.407 -Problem: ":set scrollbind | help" scrollbinds the help window. (Andrew - Pimlott) -Solution: Reset 'scrollbind' when opening a help window. -Files: src/ex_cmds.c - -Patch 6.1.408 -Problem: When 'rightleft' is set unprintable character 0x0c is displayed as - ">c0<". -Solution: Reverse the text of the hex character. -Files: src/screen.c - -Patch 6.1.409 -Problem: Generating tags for the help doesn't work for some locales. -Solution: Set LANG=C LC_ALL=C in the environment for "sort". (Daniel - Elstner) -Files: runtime/doc/Makefile - -Patch 6.1.410 (depends on 6.1.390) -Problem: Linking error when compiling with Netbeans but without sign icons. - (Malte Neumann) -Solution: Don't define buf_signcount() when sign icons are unavailable. -Files: src/buffer.c - -Patch 6.1.411 -Problem: When 'virtualedit' is set, highlighting a Visual block beyond the - end of a line may be wrong. -Solution: Correct the virtual column when the end of the line is before the - displayed part of the line. (Muraoka Taro) -Files: src/screen.c - -Patch 6.1.412 -Problem: When swapping terminal screens and using ":gui" to start the GUI, - the shell prompt may be after a hit-enter prompt. -Solution: Output a newline in the terminal when starting the GUI and there - was a hit-enter prompt.. -Files: src/gui.c - -Patch 6.1.413 -Problem: When 'clipboard' contains "unnamed", "p" in Visual mode doesn't - work correctly. -Solution: Save the register before overwriting it and put the resulting text - on the clipboard afterwards. (Muraoka Taro) -Files: src/normal.c, src/ops.c - -Patch 6.1.414 (extra, depends on 6.1.369) -Problem: VMS: Vim busy waits when waiting for input. -Solution: Delay for a short while before getting another character. (Zoltan - Arpadffy) -Files: src/os_vms.c - -Patch 6.1.415 -Problem: When there is a vertical split and a quickfix window, reducing the - size of the Vim window may result in a wrong window layout and a - crash. -Solution: When reducing the window size and there is not enough space for - 'winfixheight' set the frame height to the larger height, so that - there is a retry while ignoring 'winfixheight'. (Yasuhiro - Matsumoto) -Files: src/window.c - -Patch 6.1.416 (depends on 6.1.366) -Problem: When using the Netbeans interface, a line with a sign cannot be - changed. -Solution: Respect the GUARDEDOFFSET for sign IDs when checking for a guarded - area. -Files: src/netbeans.c - -Patch 6.1.417 -Problem: Unprintable multi-byte characters are not handled correctly. - Multi-byte characters above 0xffff are displayed as another - character. -Solution: Handle unprintable multi-byte characters. Display multi-byte - characters above 0xffff with a marker. Recognize UTF-16 words and - BOM words as unprintable. (Daniel Elstner) -Files: src/charset.c, src/mbyte.c, src/screen.c - -Patch 6.1.418 -Problem: The result of strftime() is in the current locals. Need to - convert it to 'encoding'. -Solution: Obtain the current locale and convert the argument for strftime() - to it and the result back to 'encoding'. (Daniel Elstner) -Files: src/eval.c, src/ex_cmds.c, src/ex_cmds2.c, src/mbyte.c, - src/proto/mbyte.pro, src/option.c, src/os_mswin.c - -Patch 6.1.419 -Problem: Vim doesn't compile on AIX 5.1. -Solution: Don't define _NO_PROTO on this system. (Uribarri) -Files: src/auto/configure, src/configure.in - -Patch 6.1.420 (extra) -Problem: convert_input() has an unnecessary STRLEN(). - Conversion from UCS-2 to a codepage uses word count instead of - byte count. -Solution: Remove the STRLEN() call. (Daniel Elstner) - Always use byte count for string_convert(). -Files: src/gui_w32.c, src/mbyte.c - -Patch 6.1.421 (extra, depends on 6.1.354) -Problem: MS-Windows 9x: When putting text on the clipboard it can be in - the wrong encoding. -Solution: Convert text to the active codepage for CF_TEXT. (Glenn Maynard) -Files: src/os_mswin.c - -Patch 6.1.422 -Problem: Error in .vimrc doesn't cause hit-enter prompt when swapping - screens. (Neil Bird) -Solution: Set msg_didany also when sending a message to the terminal - directly. -Files: src/message.c - -Patch 6.1.423 -Problem: Can't find arbitrary text in help files. -Solution: Added the ":helpgrep" command. -Files: runtime/doc/various.txt, src/ex_cmds.h, src/ex_docmd.c, - src/proto/quickfix.pro, src/quickfix.c - -Patch 6.1.424 (extra) -Problem: Win32: Gvim compiled with VC++ 7.0 run on Windows 95 does not show - menu items. -Solution: Define $WINVER to avoid an extra item is added to MENUITEMINFO. - (Muraoka Taro) -Files: src/Make_mvc.mak - -Patch 6.1.425 -Problem: ":helptags $VIMRUNTIME/doc" does not add the "help-tags" tag. -Solution: Do add the "help-tags" tag for that specific directory. -Files: src/ex_cmds.c - -Patch 6.1.426 -Problem: "--remote-wait +cmd file" waits forever. (Valery Kondakoff) -Solution: Don't wait for the "+cmd" argument to have been edited. -Files: src/main.c - -Patch 6.1.427 -Problem: Several error messages for regexp patterns are not translated. -Solution: Use _() properly. (Muraoka Taro) -Files: src/regexp.c - -Patch 6.1.428 -Problem: FreeBSD: wait() may hang when compiled with Python support and - doing a system() call in a startup script. -Solution: Use waitpid() instead of wait() and poll every 10 msec, just like - what is done in the GUI. -Files: src/os_unix.c - -Patch 6.1.429 (depends on 6.1.390) -Problem: Crash when using showmarks.vim plugin. (Charles Campbell) -Solution: Check for sign_get_text() returning a NULL pointer. -Files: src/screen.c - -Patch 6.1.430 -Problem: In Lisp code backslashed parens should be ignored for "%". (Dorai) -Solution: Skip over backslashed parens. -Files: src/search.c - -Patch 6.1.431 -Problem: Debug commands end up in redirected text. -Solution: Disable redirection while handling debug commands. -Files: src/ex_cmds2.c - -Patch 6.1.432 (depends on 6.1.375) -Problem: MS-Windows: ":make %:p" inserts extra backslashes. (David Rennalls) -Solution: Don't add backslashes, handle it like ":!cmd". -Files: src/ex_docmd.c - -Patch 6.1.433 -Problem: ":popup" only works for Win32. -Solution: Add ":popup" support for GTK. (Daniel Elstner) -Files: runtime/doc/gui.txt, src/ex_docmd.c, src/gui_gtk.c, src/menu.c, - src/proto/gui_gtk.pro - -Patch 6.1.434 (extra) -Problem: Win32: When there are more than 32767 lines, the scrollbar has a - roundoff error. -Solution: Make a click on an arrow move one line. Also move the code to - gui_w48.c, there is hardly any difference between the 16 bit and - 32 bit versions. (Walter Briscoe) -Files: src/gui_w16.c, src/gui_w32.c, src/gui_w48.c - -Patch 6.1.435 -Problem: ":winsize x" resizes the Vim window to the minimal size. (Andrew - Pimlott) -Solution: Give an error message for wrong arguments of ":winsize" and - ":winpos". -Files: src/ex_docmd.c - -Patch 6.1.436 -Problem: When a long UTF-8 file contains an illegal byte it's hard to find - out where it is. (Ron Aaron) -Solution: Add the line number to the error message. -Files: src/fileio.c - -Patch 6.1.437 (extra, depends on 6.1.421) -Problem: Using multi-byte functions when they are not available. -Solution: Put the clipboard conversion inside an #ifdef. (Vince Negri) - Also fix a pointer type mistake. (Walter Briscoe) -Files: src/os_mswin.c - -Patch 6.1.438 -Problem: When Perl has thread support Vim cannot use the Perl interface. -Solution: Add a configure check and disable Perl when it will not work. - (Aron Griffis) -Files: src/auto/configure, src/configure.in - -Patch 6.1.439 -Problem: Netbeans: A "create" function doesn't actually create a buffer, - following functions may fail. -Solution: Create a Vim buffer without a name when "create" is called. - (Gordon Prieur) -Files: runtime/doc/netbeans.txt, src/netbeans.c - -Patch 6.1.440 -Problem: The "@*" command doesn't obtain the actual contents of the - clipboard. (Hari Krishna Dara) -Solution: Obtain the clipboard text before executing the command. -Files: src/ops.c - -Patch 6.1.441 -Problem: "zj" and "zk" cannot be used as a motion command after an - operator. (Ralf Hetzel) -Solution: Accept these commands as motion commands. -Files: src/normal.c - -Patch 6.1.442 -Problem: Unicode 3.2 defines more space and punctuation characters. -Solution: Add the new characters to the Unicode tables. (Raphael Finkel) -Files: src/mbyte.c - -Patch 6.1.443 (extra) -Problem: Win32: The gvimext.dll build with Borland 5.5 requires another - DLL. -Solution: Build a statically linked version by default. (Dan Sharp) -Files: GvimExt/Make_bc5.mak - -Patch 6.1.444 (extra) -Problem: Win32: Enabling a build with gettext support is not consistent. -Solution: Use "GETTEXT" for Borland and msvc makefiles. (Dan Sharp) -Files: src/Make_bc5.mak, src/Make_mvc.mak - -Patch 6.1.445 (extra) -Problem: DJGPP: get warning for argument of putenv() -Solution: Define HAVE_PUTENV to use DJGPP's putenv(). (Walter Briscoe) -Files: src/os_msdos.h - -Patch 6.1.446 (extra) -Problem: Win32: The MingW makefile uses a different style of arguments than - other makefiles. - Dynamic IME is not supported for Cygwin. -Solution: Use "no" and "yes" style arguments. Remove the use of the - dyn-ming.h include file. (Dan Sharp) - Do not include the ime.h file and adjust the makefile. (Alejandro - Lopez-Valencia) -Files: src/Make_cyg.mak, src/Make_ming.mak, src/gui_w32.c, - src/if_perl.xs, src/if_python.c, src/if_ruby.c, src/os_win32.c - -Patch 6.1.447 -Problem: "make install" uses "make" directly for generating help tags. -Solution: Use $(MAKE) instead of "make". (Tim Mooney) -Files: src/Makefile - -Patch 6.1.448 -Problem: 'titlestring' has a default maximum width of 50 chars per item. -Solution: Remove the default maximum (also for 'statusline'). -Files: src/buffer.c - -Patch 6.1.449 -Problem: When "1" and "a" are in 'formatoptions', auto-formatting always - moves a newly added character to the next line. (Servatius Brandt) -Solution: Don't move a single character to the next line when it was just - typed. -Files: src/edit.c - -Patch 6.1.450 -Problem: Termcap entry "kB" for back-tab is not recognized. -Solution: Use back-tab as the shift-tab code. -Files: src/keymap.h, src/misc2.c, src/term.c - -Patch 6.1.451 -Problem: GUI: When text in the find dialog contains a slash, a backslash is - inserted the next time it is opened. (Mezz) -Solution: Remove escaped backslashes and question marks. (Daniel Elstner) -Files: src/gui.c - -Patch 6.1.452 (extra, after 6.1.446) -Problem: Win32: IME support doesn't work for MSVC. -Solution: Use _MSC_VER instead of __MSVC. (Alejandro Lopez-Valencia) -Files: src/gui_w32.c - -Patch 6.1.453 (after 6.1.429) -Problem: When compiled without sign icons but with sign support, adding a - sign may cause a crash. -Solution: Check for the text sign to exist before using it. (Kamil - Burzynski) -Files: src/screen.c - -Patch 6.1.454 (extra) -Problem: Win32: pasting Russian text in Vim with 'enc' set to cp1251 - results in utf-8 bytes. (Perelyubskiy) - Conversion from DBCS to UCS2 does not work when 'encoding' is not - the active codepage. -Solution: Introduce enc_codepage and use it for conversion to 'encoding' - (Glenn Maynard) - Use MultiByteToWideChar() and WideCharToMultiByte() instead of - iconv(). Should do most needed conversions without iconv.dll. -Files: src/globals.h, src/gui_w32.c, src/mbyte.c, src/os_mswin.c, - src/proto/mbyte.pro, src/proto/os_mswin.pro, src/structs.h - -Patch 6.1.455 -Problem: Some Unicode characters can be one or two character cells wide. -Solution: Add the 'ambiwidth' option to tell Vim how to display these - characters. (Jungshik Shin) - Also reset the script ID when setting an option to its default - value, so that ":verbose set" won't give wrong info. -Files: runtime/doc/options.txt, src/mbyte.c, src/option.c, src/option.h - -Patch 6.1.456 (extra, after 6.1.454) -Problem: Win32: IME doesn't work. -Solution: ImmGetCompositionStringW() returns the size in bytes, not words. - (Yasuhiro Matsumoto) Also fix typecast problem. -Files: src/gui_w32.c, src/os_mswin.c - -Patch 6.1.457 -Problem: An empty register in viminfo causes conversion to fail. -Solution: Don't convert an empty string. (Yasuhiro Matsumoto) -Files: src/ex_cmds.c, src/mbyte.c - -Patch 6.1.458 -Problem: Compiler warning for pointer. -Solution: Add a typecast. -Files: src/ex_cmds.c - -Patch 6.1.459 (extra) -Problem: Win32: libcall() may return an invalid pointer and cause Vim to - crash. -Solution: Add a strict check for the returned pointer. (Bruce Mellows) -Files: src/os_mswin.c - -Patch 6.1.460 -Problem: GTK: after scrolling the text one line with a key, clicking the - arrow of the scrollbar does not always work. (Nam SungHyun) -Solution: Always update the scrollbar thumb when the value changed, even - when it would not move, like for RISCOS. (Daniel Elstner) -Files: src/gui.c, src/gui.h - -Patch 6.1.461 -Problem: When a keymap is active, typing a character in Select mode does - not use it. (Benji Fisher) -Solution: Apply Insert mode mapping to the character typed in Select mode. -Files: src/normal.c - -Patch 6.1.462 -Problem: When autocommands wipe out a buffer, a crash may happen. (Hari - Krishna Dara) -Solution: Don't decrement the window count of a buffer before calling the - autocommands for it. When re-using the current buffer, watch out - for autocommands changing the current buffer. -Files: src/buffer.c, src/ex_cmds.c, src/proto/buffer.pro - -Patch 6.1.463 -Problem: When writing a compressed file, the file name that gzip stores in - the file is the weird temporary file name. (David Rennalls) -Solution: Use the real file name when possible. -Files: runtime/plugin/gzip.vim - -Patch 6.1.464 -Problem: Crash when using C++ syntax highlighting. (Gerhard Hochholzer) -Solution: Check for a negative index. -Files: src/syntax.c - -Patch 6.1.465 (after 6.1.454) -Problem: Compile error when using cygwin. -Solution: Change #ifdef WIN32 to #ifdef WIN3264. (Alejandro Lopez-Valencia) - Undefine WIN32 after including windows.h -Files: src/mbyte.c - -Patch 6.1.466 -Problem: The "-f" argument is a bit obscure. -Solution: Add the "--nofork" argument. Improve the help text a bit. -Files: runtime/doc/starting.txt, src/main.c - -Patch 6.1.467 -Problem: Setting the window title doesn't work for Chinese. -Solution: Use an X11 function to convert text to a text property. (Kentaro - Nakazawa) -Files: src/os_unix.c - -Patch 6.1.468 -Problem: ":mksession" also stores folds for buffers which will not be - restored. -Solution: Only store folds for a buffer with 'buftype' empty and help files. -Files: src/ex_docmd.c - -Patch 6.1.469 -Problem: 'listchars' cannot contain multi-byte characters. -Solution: Handle multi-byte UTF-8 list characters. (Matthew Samsonoff) -Files: src/message.c, src/option.c, src/screen.c - -Patch 6.1.470 (lang) -Problem: Polish messages don't show up correctly on MS-Windows. -Solution: Convert messages to cp1250. (Mikolaj Machowski) - Also add English message translations, because it got in the way - of the patch. -Files: Makefile, src/po/Makefile, src/po/en_gb.po, src/po/pl.po - -Patch 6.1.471 -Problem: ":jumps" output continues after pressing "q" at the more-prompt. - (Hari Krishna Dara) -Solution: Check for "got_int" being set. -Files: src/mark.c - -Patch 6.1.472 -Problem: When there is an authentication error when connecting to the X - server Vim exits. -Solution: Use XSetIOErrorHandler() to catch the error and longjmp() to avoid - the exit. Also do this in the main loop, so that when the X - server exits a Vim running in a console isn't killed. -Files: src/globals.h, src/main.c, src/os_unix.c - -Patch 6.1.473 -Problem: Referring to $curwin or $curbuf in Perl 5.6 causes a crash. -Solution: Add "pTHX_" to cur_val(). (Yasuhiro Matsumoto) -Files: src/if_perl.xs - -Patch 6.1.474 -Problem: When opening the command-line window in Ex mode it's impossible to - go back. (Pavol Juhas) -Solution: Reset "exmode_active" and restore it when the command-line window - is closed. -Files: src/ex_getln.c - - -Patch 6.2f.001 -Problem: The configure check for Ruby didn't work properly for Ruby 1.8.0. -Solution: Change the way the Ruby check is done. (Aron Griffis) -Files: src/auto/configure, src/configure.in - -Patch 6.2f.002 -Problem: The output of ":ls" doesn't show whether a buffer had read errors. -Solution: Add the "x" flag in the ":ls" output. -Files: runtime/doc/windows.txt, src/buffer.c - -Patch 6.2f.003 -Problem: Test49 doesn't properly test the behavior of ":catch" without an - argument. -Solution: Update test49. (Servatius Brandt) -Files: src/testdir/test49.ok, src/testdir/test49.vim - -Patch 6.2f.004 -Problem: "vim --version" always uses CR/LF in the output. -Solution: Omit the CR. -Files: src/message.c, src/os_unix.c - -Patch 6.2f.005 -Problem: Two error messages without a colon after the number. -Solution: Add the colon. (Taro Muraoka) -Files: src/if_cscope.c - -Patch 6.2f.006 -Problem: When saving a file takes a while and Vim regains focus this can - result in a "file changed outside of Vim" warning and ml_get() - errors. (Mike Williams) -Solution: Add the "b_saving" flag to avoid checking the timestamp while the - buffer is being saved. (Michael Schaap) -Files: src/fileio.c, src/structs.h - -Patch 6.2f.007 -Problem: Irix compiler complains about multiple defined symbols. - vsnprintf() is not available. (Charles Campbell) -Solution: Insert EXTERN for variables in globals.h. Change the configure - check for vsnprintf() from compiling to linking. -Files: src/auto/configure, src/configure.in, src/globals.h - -Patch 6.2f.008 -Problem: The Aap recipe doesn't work with Aap 0.149. -Solution: Change targetarg to TARGETARG. Update the mysign file. -Files: src/main.aap, src/mysign - -Patch 6.2f.009 (extra) -Problem: Small problem when building with Borland 5.01. -Solution: Use mkdir() instead of _mkdir(). (Walter Briscoe) -Files: src/dosinst.h - -Patch 6.2f.010 -Problem: Warning for missing prototypes. -Solution: Add missing prototypes. (Walter Briscoe) -Files: src/if_cscope.c - -Patch 6.2f.011 -Problem: The configure script doesn't work with autoconf 2.5x. -Solution: Add square brackets around a header check. (Aron Griffis) - Note: touch src/auto/configure after applying this patch. -Files: src/configure.in - -Patch 6.2f.012 -Problem: ":echoerr" doesn't work correctly inside try/endtry. -Solution: Don't reset did_emsg inside a try/endtry. (Servatius Brandt) -Files: src/eval.c - -Patch 6.2f.013 (extra) -Problem: Macintosh: Compiler warning for a trigraph. -Solution: Insert a backslash before each question mark. (Peter Cucka) -Files: src/os_mac.h - -Patch 6.2f.014 (extra) -Problem: Macintosh: ex_eval is not included in the project file. -Solution: Add ex_eval. (Dany St-Amant) -Files: src/os_mac.pbproj/project.pbxproj - -Patch 6.2f.015 (extra) -Problem: Win32: When changing header files not all source files involved - are recompiled. -Solution: Improve the dependency rules. (Dan Sharp) -Files: src/Make_cyg.mak, src/Make_ming.mak - -Patch 6.2f.016 -Problem: "vim --version > ff" on non-Unix systems results in a file with a - missing line break at the end. (Bill McCArthy) -Solution: Add a line break. -Files: src/main.c - -Patch 6.2f.017 -Problem: Unix: starting Vim in the background and then bringing it to the - foreground may cause the terminal settings to be wrong. -Solution: Check for tcsetattr() to return an error, retry when it does. - (Paul Tapper) -Files: src/os_unix.c - -Patch 6.2f.018 -Problem: Mac OS X 10.2: OK is defined to zero in cursus.h while Vim uses - one. Redefining it causes a warning message. -Solution: Undefine OK before defining it to one. (Taro Muraoka) -Files: src/vim.h - -Patch 6.2f.019 -Problem: Mac OS X 10.2: COLOR_BLACK and COLOR_WHITE are defined in - curses.h. -Solution: Rename them to PRCOLOR_BLACK and PRCOLOR_WHITE. -Files: src/ex_cmds2.c - -Patch 6.2f.020 -Problem: Win32: test50 produces beeps and fails with some versions of diff. -Solution: Remove empty lines and convert the output to dos fileformat. -Files: src/testdir/test50.in - -Patch 6.2f.021 -Problem: Running configure with "--enable-netbeans" disables Netbeans. - (Gordon Prieur) -Solution: Fix the tests in configure.in where the default is to enable a - feature. Fix that "--enable-acl" reported "yes" confusingly. -Files: src/auto/configure, src/configure.in, src/mysign - -Patch 6.2f.022 -Problem: A bogus value for 'foldmarker' is not rejected, possibly causing a - hang. (Derek Wyatt) -Solution: Check for a non-empty string before and after the comma. -Files: src/option.c - -Patch 6.2f.023 -Problem: When the help files are not in $VIMRUNTIME but 'helpfile' is - correct Vim still can't find the help files. -Solution: Also look for a tags file in the directory of 'helpfile'. -Files: src/tag.c - -Patch 6.2f.024 -Problem: When 'delcombine' is set and a character has more than two - composing characters "x" deletes them all. -Solution: Always delete only the last composing character. -Files: src/misc1.c - -Patch 6.2f.025 -Problem: When reading a file from stdin that has DOS line endings but a - missing end-of-line for the last line 'fileformat' becomes "unix". - (Bill McCarthy) -Solution: Don't add the missing line break when re-reading the text from the - buffer. -Files: src/fileio.c - -Patch 6.2f.026 -Problem: When typing new text at the command line, old composing characters - may be displayed. -Solution: Don't read composing characters from after the end of the - text to be displayed. -Files: src/ex_getln.c, src/mbyte.c, src/message.c, src/proto/mbyte.pro, - src/screen.c - -Patch 6.2f.027 -Problem: Compiler warnings for unsigned char pointers. (Tony Leneis) -Solution: Add typecasts to char pointer. -Files: src/quickfix.c - -Patch 6.2f.028 -Problem: GTK: When 'imactivatekey' is empty and XIM is inactive it can't be - made active again. Cursor isn't updated immediately when changing - XIM activation. Japanese XIM may hang when using 'imactivatekey'. - Can't activate XIM after typing fFtT command or ":sh". -Solution: Properly set the flag that indicates the IM is active. Update the - cursor right away. Do not send a key-release event. Handle - Normal mode and running an external command differently. - (Yasuhiro Matsumoto) -Files: src/mbyte.c - -Patch 6.2f.029 -Problem: Mixing use of int and enum. -Solution: Adjust argument type of cs_usage_msg(). Fix wrong typedef. -Files: src/if_cscope.c, src/if_cscope.h - -Patch 6.2f.030 (after 6.2f.028) -Problem: Cursor moves up when using XIM. -Solution: Reset im_preedit_cursor. (Yasuhiro Matsumoto) -Files: src/mbyte.c - -Patch 6.2f.031 -Problem: Crash when listing a function argument in the debugger. (Ron Aaron) -Solution: Init the name field of an argument to NULL. -Files: src/eval.c - -Patch 6.2f.032 -Problem: When a write fails for a ":silent!" while inside try/endtry the - BufWritePost autocommands are not triggered. -Solution: Check the emsg_silent flag in should_abort(). (Servatius Brandt) -Files: src/ex_eval.c, src/testdir/test49.ok, src/testdir/test49.vim - -Patch 6.2f.033 -Problem: Cscope: re-entrance problem for ":cscope" command. Checking for - duplicate database didn't work well for Win95. Didn't check for - duplicate databases after an empty entry. -Solution: Don't set postponed_split too early. Remember first empty - database entry. (Sergey Khorev) -Files: src/if_cscope.c - -Patch 6.2f.034 -Problem: The netbeans interface cannot be used on systems without - vsnprintf(). (Tony Leneis) -Solution: Use EMSG(), EMSGN() and EMSG2() instead. -Files: src/auto/configure, src/configure.in, src/netbeans.c - -Patch 6.2f.035 -Problem: The configure check for the netbeans interface doesn't work if the - socket and nsl libraries are required. -Solution: Check for the socket and nsl libraries before the netbeans check. -Files: src/auto/configure, src/configure.in - -Patch 6.2f.036 -Problem: Moving leftwards over text with an illegal UTF-8 byte moves one - byte instead of one character. -Solution: Ignore an illegal byte after the cursor position. -Files: src/mbyte.c - -Patch 6.2f.037 -Problem: When receiving a Netbeans command at the hit-enter or more prompt - the screen is redrawn but Vim is still waiting at the prompt. -Solution: Quit the prompt like a CTRL-C was typed. -Files: src/netbeans.c - -Patch 6.2f.038 -Problem: The dependency to run autoconf causes a patch for configure.in - to run autoconf, even though the configure script was updated as - well. -Solution: Only run autoconf with "make autoconf". -Files: src/Makefile - -Patch 6.2f.039 -Problem: CTRL-W K makes the new top window very high. -Solution: When 'equalalways' is set equalize the window heights. -Files: src/window.c - - -============================================================================== -VERSION 6.3 *version-6.3* - -This section is about improvements made between version 6.2 and 6.3. - -This is mainly a bug-fix release. There are also a few new features. -The major number of new items is in the runtime files and translations. - - -Changed *changed-6.3* -------- - -The intro message also displays a note about sponsoring Vim, mixed randomly -with the message about helping children in Uganda. - -Included the translated menus, keymaps and tutors with the normal runtime -files. The separate "lang" archive now only contains translated messages. - -Made the translated menu file names a bit more consistent. Use "latin1" for -"iso_8859-1" and "iso_8859-15". - -Removed the "file_select.vim" script from the distribution. It's not more -useful than other scripts that can be downloaded from www.vim.org. - -The "runtime/doc/tags" file is now always in unix fileformat. On MS-Windows -it used to be dos fileformat, but ":helptags" generates a unix format file. - - -Added *added-6.3* ------ - -New commands: - :cNfile go to last error in previous file - :cpfile idem - :changes print the change list - :keepmarks following command keeps marks where they are - :keepjumps following command keeps jumplist and marks - :lockmarks following command keeps marks where they are - :redrawstatus force a redraw of the status line(s) - -New options: - 'antialias' Mac OS X: use smooth, antialiased fonts - 'helplang' preferred help languages - -Syntax files: - Arch inventory (Nikolai Weibull) - Calendar (Nikolai Weibull) - Ch (Wayne Cheng) - Controllable Regex Mutilator (Nikolai Weibull) - D (Jason Mills) - Desktop (Mikolaj Machowski) - Dircolors (Nikolai Weibull) - Elinks configuration (Nikolai Weibull) - FASM (Ron Aaron) - GrADS scripts (Stefan Fronzek) - Icewm menu (James Mahler) - LDIF (Zak Johnson) - Locale input, fdcc. (Dwayne Bailey) - Pinfo config (Nikolai Weibull) - Pyrex (Marco Barisione) - Relax NG Compact (Nikolai Weibull) - Slice (Morel Bodin) - VAX Macro Assembly (Tom Uijldert) - grads (Stefan Fronzek) - libao (Nikolai Weibull) - mplayer (Nikolai Weibull) - rst (Nikolai Weibull) - tcsh (Gautam Iyer) - yaml (Nikolai Weibull) - -Compiler plugins: - ATT dot (Marcos Macedo) - Apple Project Builder (Alexander von Below) - Intel (David Harrison) - bdf (Nikolai Weibull) - icc (Peter Puck) - javac (Doug Kearns) - neato (Marcos Macedo) - onsgmls (Robert B. Rowsome) - perl (Christian J. Robinson) - rst (Nikolai Weibull) - se (SmartEiffel) (Doug Kearns) - tcl (Doug Kearns) - xmlwf (Robert B. Rowsome) - -Filetype plugins: - Aap (Bram Moolenaar) - Ch (Wayne Cheng) - Css (Nikolai Weibull) - Pyrex (Marco Barisione) - Rst (Nikolai Weibull) - -Indent scripts: - Aap (Bram Moolenaar) - Ch (Wayne Cheng) - DocBook (Nikolai Weibull) - MetaPost (Eugene Minkovskii) - Objective-C (Kazunobu Kuriyama) - Pyrex (Marco Barisione) - Rst (Nikolai Weibull) - Tcsh (Gautam Iyer) - XFree86 configuration file (Nikolai Weibull) - Zsh (Nikolai Weibull) - -Keymaps: - Greek for cp1253 (Panagiotis Louridas) - Hungarian (Magyar) (Laszlo Zavaleta) - Persian-Iranian (Behnam Esfahbod) - -Message translations: - Catalan (Ernest Adrogue) - Russian (Vassily Ragosin) - Swedish (Johan Svedberg) - -Menu translations: - Catalan (Ernest Adrogue) - Russian (Tim Alexeevsky) - Swedish (Johan Svedberg) - -Tutor translations: - Catalan (Ernest Adrogue) - Russian in cp1251 (Alexey Froloff) - Slovak in cp1250 and iso8859-2 (Lubos Celko) - Swedish (Johan Svedberg) - Korean (Kee-Won Seo) - UTF-8 version of the Japanese tutor (Yasuhiro Matsumoto) Use this as - the original, create the other Japanese tutor by conversion. - -Included "russian.txt" help file. (Vassily Ragosin) - -Include Encapsulated PostScript and PDF versions of the Vim logo in the extra -archive. - -The help highlighting finds the highlight groups and shows them in the color -that is actually being used. (idea from Yakov Lerner) - -The big Win32 version is now compiled with Ruby interface, version 1.8. For -Python version 2.3 is used. For Perl version 5.8 is used. - -The "ftdetect" directory is mentioned in the documentation. The DOS install -program creates it. - - -Fixed *fixed-6.3* ------ - -Test 42 failed on MS-Windows. Set and reset 'fileformat' and 'binary' options -here and there. (Walter Briscoe) - -The explorer plugin didn't work for double-byte 'encoding's. - -Use "copy /y" in Make_bc5.mak to avoid a prompt for overwriting. - -Patch 6.2.001 -Problem: The ":stopinsert" command doesn't have a help tag. -Solution: Add the tag. (Antoine J. Mechelynck) -Files: runtime/doc/insert.txt, runtime/doc/tags - -Patch 6.2.002 -Problem: When compiled with the +multi_byte feature but without +eval, - displaying UTF-8 characters may cause a crash. (Karsten Hopp) -Solution: Also set the default for 'ambiwidth' when compiled without the - +eval feature. -Files: src/option.c - -Patch 6.2.003 -Problem: GTK 2: double-wide characters below 256 are not displayed - correctly. -Solution: Check the cell width for characters above 127. (Yasuhiro - Matsumoto) -Files: src/gui_gtk_x11.c - -Patch 6.2.004 -Problem: With a line-Visual selection at the end of the file a "p" command - puts the text one line upwards. -Solution: Detect that the last line was deleted and put forward. (Taro - Muraoka) -Files: src/normal.c - -Patch 6.2.005 -Problem: GTK: the "Find" and "Find and Replace" tools don't work. (Aschwin - Marsman) -Solution: Show the dialog after creating it. (David Necas) -Files: src/gui_gtk.c - -Patch 6.2.006 -Problem: The Netbeans code contains an obsolete function that uses "vim61" - and sets the fall-back value for $VIMRUNTIME. -Solution: Delete the obsolete function. -Files: src/main.c, src/netbeans.c, src/proto/netbeans.pro - -Patch 6.2.007 -Problem: Listing tags for Cscope doesn't always work. -Solution: Avoid using smgs_attr(). (Sergey Khorev) -Files: src/if_cscope.c - -Patch 6.2.008 -Problem: XIM with GTK 2: After backspacing preedit characters are wrong. -Solution: Reset the cursor position. (Yasuhiro Matsumoto) -Files: src/mbyte.c - -Patch 6.2.009 -Problem: Win32: The self-installing executable "Full" selection only - selects some of the items to install. (Salman Mohsin) -Solution: Change commas to spaces in between section numbers. -Files: nsis/gvim.nsi - -Patch 6.2.010 -Problem: When 'virtualedit' is effective and a line starts with a - multi-byte character, moving the cursor right doesn't work. -Solution: Obtain the right character to compute the column offset. (Taro - Muraoka) -Files: src/charset.c - -Patch 6.2.011 -Problem: Alpha OSF1: stat() is a macro and doesn't allow an #ifdef halfway. - (Moshe Kaminsky) -Solution: Move the #ifdef outside of stat(). -Files: src/os_unix.c - -Patch 6.2.012 -Problem: May hang when polling for a character. -Solution: Break the wait loop when not waiting for a character. -Files: src/os_unix.c - -Patch 6.2.013 (extra) -Problem: Win32: The registry key for uninstalling GvimExt still uses "6.1". -Solution: Change the version number to "6.2". (Ajit Thakkar) -Files: src/GvimExt/GvimExt.reg - -Patch 6.2.014 (after 6.2.012) -Problem: XSMP doesn't work when using poll(). -Solution: Use xsmp_idx instead of gpm_idx. (Neil Bird) -Files: src/os_unix.c - -Patch 6.2.015 -Problem: The +xsmp feature is never enabled. -Solution: Move the #define for USE_XSMP to below where WANT_X11 is defined. - (Alexey Froloff) -Files: src/feature.h - -Patch 6.2.016 -Problem: Using ":scscope find" with 'cscopequickfix' does not always split - the window. (Gary Johnson) - Win32: ":cscope add" could make the script that contains it - read-only until the corresponding ":cscope kill". - Errors during ":cscope add" may not be handled properly. -Solution: When using the quickfix window may need to split the window. - Avoid file handle inheritance for the script. - Check for a failed connection and/or process. (Sergey Khorev) -Files: src/ex_cmds2.c, src/if_cscope.c - -Patch 6.2.017 -Problem: Test11 sometimes prompts the user, because a file would have been - changed outside of Vim. (Antonio Colombo) -Solution: Add a FileChangedShell autocommand to avoid the prompt. -Files: src/testdir/test11.in - -Patch 6.2.018 -Problem: When using the XSMP protocol and reading from stdin Vim may wait - for a key to be pressed. -Solution: Avoid that RealWaitForChar() is used recursively. -Files: src/os_unix.c - -Patch 6.2.019 (lang) -Problem: Loading the Portuguese menu causes an error message. -Solution: Join two lines. (Jose Pedro Oliveira, José de Paula) -Files: runtime/lang/menu_pt_br.vim - -Patch 6.2.020 -Problem: The "Syntax/Set syntax only" menu item causes an error message. - (Oyvind Holm) -Solution: Set the script-local variable in a function. (Benji Fisher) -Files: runtime/synmenu.vim - -Patch 6.2.021 -Problem: The user manual section on exceptions contains small mistakes. -Solution: Give a good example of an error that could be missed and other - improvements. (Servatius Brandt) -Files: runtime/doc/usr_41.txt - -Patch 6.2.022 (extra) -Problem: Win32: After deleting a menu item it still appears in a tear-off - window. -Solution: Set the mode to zero for the deleted item. (Yasuhiro Matsumoto) -Files: src/gui_w32.c - -Patch 6.2.023 (extra) -Problem: Win32: Make_ivc.mak does not clean everything. -Solution: Delete more files in the clean rule. (Walter Briscoe) -Files: src/Make_ivc.mak - -Patch 6.2.024 (extra) -Problem: Win32: Compiler warnings for typecasts. -Solution: Use DWORD instead of WORD. (Walter Briscoe) -Files: src/gui_w32.c - -Patch 6.2.025 -Problem: Missing prototype for sigaltstack(). -Solution: Add the prototype when it is not found in a header file. -Files: src/os_unix.c - -Patch 6.2.026 -Problem: Warning for utimes() argument. -Solution: Add a typecast. -Files: src/fileio.c - -Patch 6.2.027 -Problem: Warning for uninitialized variable. -Solution: Set mb_l to one when not using multi-byte characters. -Files: src/message.c - -Patch 6.2.028 -Problem: Cscope connection may kill Vim process and others. -Solution: Check for pid being larger than one. (Khorev Sergey) -Files: src/if_cscope.c - -Patch 6.2.029 -Problem: When using the remote server functionality Vim may leak memory. - (Srikanth Sankaran) -Solution: Free the result of XListProperties(). -Files: src/if_xcmdsrv.c - -Patch 6.2.030 -Problem: Mac: Warning for not being able to use precompiled header files. -Solution: Don't redefine select. Use -no-cpp-precomp for compiling, so that - function prototypes are still found. -Files: src/os_unix.c, src/osdef.sh - -Patch 6.2.031 -Problem: The langmenu entry in the options window doesn't work. (Rodolfo - Lima) - With GTK 1 the ":options" command causes an error message. - (Michael Naumann) -Solution: Change "lmenu" to "langmenu". Only display the 'tbis' option for - GTK 2. -Files: runtime/optwin.vim - -Patch 6.2.032 -Problem: The lpc filetype is never recognized. (Shizhu Pan) -Solution: Check for g:lpc_syntax_for_c instead of the local variable - lpc_syntax_for_c. (Benji Fisher) -Files: runtime/filetype.vim - -Patch 6.2.033 (extra) -Problem: Mac: Various compiler warnings. -Solution: Don't include Classic-only headers in Unix version. - Remove references to several unused variables. (Ben Fowler) - Fix double definition of DEFAULT_TERM. - Use int instead of unsigned short for pixel values, so that the - negative error values are recognized. -Files: src/gui_mac.c, src/term.c - -Patch 6.2.034 -Problem: Mac: Compiler warning for redefining DEFAULT_TERM. -Solution: Fix double definition of DEFAULT_TERM. -Files: src/term.c - -Patch 6.2.035 -Problem: Mac: Compiler warnings in Python interface. -Solution: Make a difference between pure Mac and Unix-Mac. (Peter Cucka) -Files: src/if_python.c - -Patch 6.2.036 (extra) -Problem: Mac Unix version: If foo is a directory, then ":e f<Tab>" should - expand to ":e foo/" instead of ":e foo" . (Vadim Zeitlin) -Solution: Define DONT_ADD_PATHSEP_TO_DIR only for pure Mac. (Benji Fisher) -Files: src/os_mac.h - -Patch 6.2.037 -Problem: Win32: converting an encoding name to a codepage could result in - an arbitrary number. -Solution: make encname2codepage() return zero if the encoding name doesn't - contain a codepage number. -Files: src/mbyte.c - -Patch 6.2.038 (extra) -Problem: Warning messages when using the MingW compiler. (Bill McCarthy) - Can't compile console version without +mouse feature. -Solution: Initialize variables, add parenthesis. - Add an #ifdef around g_nMouseClick. (Ajit Thakkar) -Files: src/eval.c, src/os_win32.c, src/gui_w32.c, src/dosinst.c - -Patch 6.2.039 (extra) -Problem: More warning messages when using the MingW compiler. -Solution: Initialize variables. (Bill McCarthy) -Files: src/os_mswin.c - -Patch 6.2.040 -Problem: FreeBSD: Crash while starting up when compiled with +xsmp feature. -Solution: Pass a non-NULL argument to IceAddConnectionWatch(). -Files: src/os_unix.c - -Patch 6.2.041 (extra, after 6.2.033) -Problem: Mac: Compiler warnings for conversion types, missing prototype, - missing return type. -Solution: Change sscanf "%hd" to "%d", the argument is an int now. Add - gui_mch_init_check() prototype. Add "int" to termlib functions. -Files: src/gui_mac.c, src/proto/gui_mac.pro, src/termlib.c. - -Patch 6.2.042 (extra) -Problem: Cygwin: gcc 3.2 has an optimizer problem, sometimes causing a - crash. -Solution: Add -fno-strength-reduce to the compiler arguments. (Dan Sharp) -Files: src/Make_cyg.mak - -Patch 6.2.043 -Problem: Compiling with both netbeans and workshop doesn't work. -Solution: Move the shellRectangle() function to gui_x11.c. (Gordon Prieur) -Files: src/gui_x11.c, src/integration.c, src/netbeans.c, - src/proto/netbeans.pro - -Patch 6.2.044 -Problem: ":au filetypedetect" gives an error for a non-existing event name, - but it's actually a non-existing group name. (Antoine Mechelynck) -Solution: Make the error message clearer. -Files: src/fileio.c - -Patch 6.2.045 -Problem: Obtaining the '( mark changes the '' mark. (Gary Holloway) -Solution: Don't set the '' mark when searching for the start/end of the - current sentence/paragraph. -Files: src/mark.c - -Patch 6.2.046 -Problem: When evaluating an argument of a function throws an exception the - function is still called. (Hari Krishna Dara) -Solution: Don't call the function when an exception was thrown. -Files: src/eval.c - -Patch 6.2.047 (extra) -Problem: Compiler warnings when using MingW. (Bill McCarthy) -Solution: Give the s_dwLastClickTime variable a type. Initialize dwEndTime. -Files: src/os_win32.c - -Patch 6.2.048 -Problem: The Python interface doesn't compile with Python 2.3 when - dynamically loaded. -Solution: Use dll_PyObject_Malloc and dll_PyObject_Free. (Paul Moore) -Files: src/if_python.c - -Patch 6.2.049 -Problem: Using a "-range=" argument with ":command" doesn't work and - doesn't generate an error message. -Solution: Generate an error message. -Files: src/ex_docmd.c - -Patch 6.2.050 -Problem: Test 32 didn't work on MS-Windows. -Solution: Write the temp file in Unix fileformat. (Walter Briscoe) -Files: src/testdir/test32.in - -Patch 6.2.051 -Problem: When using "\=submatch(0)" in a ":s" command, line breaks become - NUL characters. -Solution: Change NL to CR characters, so that they become line breaks. -Files: src/regexp.c - -Patch 6.2.052 -Problem: A few messages are not translated. -Solution: Add _() to the messages. (Muraoka Taro) -Files: src/ex_cmds.c - -Patch 6.2.053 -Problem: Prototype for bzero() doesn't match most systems. -Solution: Use "void *" instead of "char *" and "size_t" instead of "int". -Files: src/osdef1.h.in - -Patch 6.2.054 -Problem: A double-byte character with a second byte that is a backslash - causes problems inside a string. -Solution: Skip over multi-byte characters in a string properly. (Yasuhiro - Matsumoto) -Files: src/eval.c - -Patch 6.2.055 -Problem: Using col('.') from CTRL-O in Insert mode does not return the - correct value for multi-byte characters. -Solution: Correct the cursor position when it is necessary, move to the - first byte of a multi-byte character. (Yasuhiro Matsumoto) -Files: src/edit.c - -Patch 6.2.056 (extra) -Problem: Building with Sniff++ doesn't work. -Solution: Use the multi-threaded libc when needed. (Holger Ditting) -Files: src/Make_mvc.mak - -Patch 6.2.057 (extra) -Problem: Mac: With -DMACOS_X putenv() is defined twice, it is in a system - library. Get a warning for redefining OK. Unused variables in - os_mac.c -Solution: Define HAVE_PUTENV. Undefine OK after including curses.h. - Remove declarations for unused variables. -Files: src/os_mac.c, src/os_mac.h, src/vim.h - -Patch 6.2.058 -Problem: When 'autochdir' is set ":bnext" to a buffer without a name causes - a crash. -Solution: Don't call vim_chdirfile() when the file name is NULL. (Taro - Muraoka) -Files: src/buffer.c - -Patch 6.2.059 -Problem: When 'scrolloff' is a large number and listing completion results - on the command line, then executing a command that jumps close to - where the cursor was before, part of the screen is not updated. - (Yakov Lerner) -Solution: Don't skip redrawing part of the window when it was scrolled. -Files: src/screen.c - -Patch 6.2.060 (extra) -Problem: Win32: When 'encoding' is set to "iso-8859-7" copy/paste to/from - the clipboard gives a lalloc(0) error. (Kriton Kyrimis) -Solution: When the string length is zero allocate one byte. Also fix that - when the length of the Unicode text is zero (conversion from - 'encoding' to UCS-2 was not possible) the normal text is used. -Files: src/os_mswin.c - -Patch 6.2.061 -Problem: GUI: Using the left mouse button with the shift key should work - like "*" but it scrolls instead. (Martin Beller) -Solution: Don't recognize an rxvt scroll wheel event when using the GUI. -Files: src/term.c - -Patch 6.2.062 -Problem: When one buffer uses a syntax with "containedin" and another - buffer does not, redrawing depends on what the current buffer is. - (Brett Pershing Stahlman) -Solution: Use "syn_buf" instead of "curbuf" to get the b_syn_containedin - flag. -Files: src/syntax.c - -Patch 6.2.063 -Problem: When using custom completion end up with no matches. -Solution: Make cmd_numfiles and cmd_files local to completion to avoid that - they are overwritten when ExpandOne() is called recursively by - f_glob(). -Files: src/eval.c, src/ex_docmd.c, src/ex_getln.c, src/proto/ex_getln.pro, - src/misc1.c, src/structs.h, src/tag.c - -Patch 6.2.064 -Problem: resolve() only handles one symbolic link, need to repeat it to - resolve all of them. Then need to simplify the file name. -Solution: Make resolve() resolve all symbolic links and simplify the result. - Add simplify() to just simplify a file name. Fix that test49 - doesn't work if /tmp is a symbolic link. (Servatius Brandt) -Files: runtime/doc/eval.txt, src/eval.c, src/tag.c, - src/testdir/test49.vim - -Patch 6.2.065 -Problem: ":windo 123" only updates other windows when entering them. - (Walter Briscoe) -Solution: Update the topline before going to the next window. -Files: src/ex_cmds2.c - -Patch 6.2.066 (extra) -Problem: Ruby interface doesn't work with Ruby 1.8.0. -Solution: Change "defout" to "stdout". (Aron Grifis) - Change dynamic loading. (Taro Muraoka) -Files: src/if_ruby.c, src/Make_mvc.mak - -Patch 6.2.067 -Problem: When searching for a string that starts with a composing character - the command line isn't drawn properly. -Solution: Don't count the space to draw the composing character on and - adjust the cursor column after drawing the string. -Files: src/message.c - -Patch 6.2.068 -Problem: Events for the netbeans interface that include a file name with - special characters don't work properly. -Solution: Use nb_quote() on the file name. (Sergey Khorev) -Files: src/netbeans.c - -Patch 6.2.069 (after 6.2.064) -Problem: Unused variables "limit" and "new_st" and unused label "fail" in - some situation. (Bill McCarthy) -Solution: Put the declarations inside an #ifdef. (Servatius Brandt) -Files: src/eval.c, src/tag.c - -Patch 6.2.070 (after 6.2.069) -Problem: Still unused variable "new_st". (Bill McCarthy) -Solution: Move the declaration to the right block this time. -Files: src/tag.c - -Patch 6.2.071 -Problem: 'statusline' can only contain 50 % items. (Antony Scriven) -Solution: Allow 80 items and mention it in the docs. -Files: runtime/doc/option.txt, src/vim.h - -Patch 6.2.072 -Problem: When using expression folding, foldexpr() mostly returns -1 for - the previous line, which makes it difficult to write a fold - expression. -Solution: Make the level of the previous line available while still looking - for the end of a fold. -Files: src/fold.c - -Patch 6.2.073 -Problem: When adding detection of a specific filetype for a plugin you need - to edit "filetype.vim". -Solution: Source files from the "ftdetect" directory, so that a filetype - detection plugin only needs to be dropped in a directory. -Files: runtime/doc/filetype.txt, runtime/doc/usr_05.txt, - runtime/doc/usr_41.txt, runtime/filetype.vim - -Patch 6.2.074 -Problem: Warnings when compiling the Python interface. (Ajit Thakkar) -Solution: Use ANSI function declarations. -Files: src/if_python.c - -Patch 6.2.075 -Problem: When the temp file for writing viminfo can't be used "NULL" - appears in the error message. (Ben Lavender) -Solution: Print the original file name when there is no temp file name. -Files: src/ex_cmds.c - -Patch 6.2.076 -Problem: The tags listed for cscope are in the wrong order. (Johannes - Stezenbach) -Solution: Remove the reordering of tags for the current file. (Sergey - Khorev) -Files: src/if_cscope.c - -Patch 6.2.077 -Problem: When a user function specifies custom completion, the function - gets a zero argument instead of an empty string when there is no - word before the cursor. (Preben Guldberg) -Solution: Don't convert an empty string to a zero. -Files: src/eval.c - -Patch 6.2.078 -Problem: "make test" doesn't work if Vim wasn't compiled yet. (Ed Avis) -Solution: Build Vim before running the tests. -Files: src/Makefile - -Patch 6.2.079 -Problem: ":w ++enc=utf-8 !cmd" doesn't work. -Solution: Check for the "++" argument before the "!". -Files: src/ex_docmd.c - -Patch 6.2.080 -Problem: When 't_ti' is not empty but doesn't swap screens, using "ZZ" in - an unmodified file doesn't clear the last line. -Solution: Call msg_clr_eos() when needed. (Michael Schroeder) -Files: src/os_unix.c - -Patch 6.2.081 -Problem: Problem when using a long multibyte string for the statusline. -Solution: Use the right pointer to get the cell size. (Taro Muraoka) -Files: src/buffer.c - -Patch 6.2.082 -Problem: Can't compile with Perl 5.8.1. -Solution: Rename "e_number" to "e_number_exp". (Sascha Blank) -Files: src/digraph.c, src/globals.h - -Patch 6.2.083 -Problem: When a compiler uses ^^^^ to mark a word the information is not - visible in the quickfix window. (Srikanth Sankaran) -Solution: Don't remove the indent for a line that is not recognized as an - error message. -Files: src/quickfix.c - -Patch 6.2.084 -Problem: "g_" in Visual mode always goes to the character after the line. - (Jean-Rene David) -Solution: Ignore the NUL at the end of the line. -Files: src/normal.c - -Patch 6.2.085 -Problem: ":verbose set ts" doesn't say an option was set with a "-c" or - "--cmd" argument. -Solution: Remember the option was set from a Vim argument. -Files: src/main.c, src/ex_cmds2.c, src/vim.h - -Patch 6.2.086 -Problem: "{" and "}" stop inside a closed fold. -Solution: Only stop once inside a closed fold. (Stephen Riehm) -Files: src/search.c - -Patch 6.2.087 -Problem: CTRL-^ doesn't use the 'confirm' option. Same problem with - ":bnext". (Yakov Lerner) -Solution: Put up a dialog for a changed file when 'confirm' is set in more - situations. -Files: src/buffer.c, src/ex_cmds.c - -Patch 6.2.088 -Problem: When 'sidescrolloff' is set 'showmatch' doesn't work correctly if - the match is less than 'sidescrolloff' off from the side of the - window. (Roland Stahn) -Solution: Set 'sidescrolloff' to zero while displaying the match. -Files: src/search.c - -Patch 6.2.089 -Problem: ":set isk+=" adds a comma. (Mark Waggoner) -Solution: Don't add a comma when the added value is empty. -Files: src/option.c - -Patch 6.2.090 (extra) -Problem: Win32: MingW compiler complains about #pragmas. (Bill McCarthy) -Solution: Put an #ifdef around the #pragmas. -Files: src/os_win32.c - -Patch 6.2.091 -Problem: When an autocommand is triggered when a file is dropped on Vim and - it produces output, messages from a following command may be - scrolled unexpectedly. (David Rennalls) -Solution: Save and restore msg_scroll in handle_drop(). -Files: src/ex_docmd.c - -Patch 6.2.092 -Problem: Invalid items appear in the help file tags. (Antonio Colombo) -Solution: Only accept tags with white space before the first "*". -Files: runtime/doc/doctags.c, src/ex_cmds.c - -Patch 6.2.093 -Problem: ":nnoremenu" also defines menu for Visual mode. (Klaus Bosau) -Solution: Check the second command character for an "o", not the third. -Files: src/menu.c - -Patch 6.2.094 -Problem: Can't compile with GTK and tiny features. -Solution: Include handle_drop() and vim_chdirfile() when FEAT_DND is defined. - Do not try to split the window. -Files: src/ex_docmd.c, src/misc2.c - -Patch 6.2.095 -Problem: The message "Cannot go to buffer x" is confusing for ":buf 6". - (Frans Englich) -Solution: Make it "Buffer x does not exist". -Files: src/buffer.c - -Patch 6.2.096 -Problem: Win32: ":let @* = ''" put a newline on the clipboard. (Klaus - Bosau) -Solution: Put zero bytes on the clipboard for an empty string. -Files: src/ops.c - -Patch 6.2.097 -Problem: Setting or resetting 'insertmode' in a BufEnter autocommand - doesn't always have immediate effect. (Nagger) -Solution: When 'insertmode' is set, set need_start_insertmode, when it's - reset set stop_insert_mode. -Files: src/option.c - -Patch 6.2.098 (after 6.2.097) -Problem: Can't build Vim with tiny features. (Christian J. Robinson) -Solution: Declare stop_insert_mode always. -Files: src/edit.c, src/globals.h - -Patch 6.2.099 (extra) -Problem: Test 49 fails. (Mikolaj Machowski) -Solution: The Polish translation must not change "E116" to "R116". -Files: src/po/pl.po - -Patch 6.2.100 -Problem: "make proto" fails when compiled with the Perl interface. -Solution: Remove "-fno.*" from PERL_CFLAGS, cproto sees it as its option. -Files: src/auto/configure, src/configure.in - -Patch 6.2.101 -Problem: When using syntax folding, opening a file slows down a lot when - it's size increases by only 20%. (Gary Johnson) -Solution: The array with cached syntax states is leaking entries. After - cleaning up the list obtain the current entry again. -Files: src/syntax.c - -Patch 6.2.102 -Problem: The macros equal() and CR conflict with a Carbon header file. -Solution: Rename equal() to equalpos(). Rename CR to CAR. - Do this in the non-extra files only. -Files: src/ascii.h, src/buffer.c, src/charset.c, src/edit.c, src/eval.c, - src/ex_cmds.c, src/ex_cmds2.c, src/ex_getln.c, src/fileio.c, - src/getchar.c, src/gui.c, src/gui_athena.c, src/gui_gtk_x11.c, - src/gui_motif.c, src/macros.h, src/mark.c, src/message.c, - src/misc1.c, src/misc2.c, src/normal.c, src/ops.c, src/os_unix.c, - src/regexp.c, src/search.c, src/ui.c, src/workshop.c - -Patch 6.2.103 (extra) -Problem: The macros equal() and CR conflict with a Carbon header file. -Solution: Rename equal() to equalpos(). Rename CR to CAR. - Do this in the extra files only. -Files: src/gui_photon.c, src/gui_w48.c - -Patch 6.2.104 -Problem: Unmatched braces in the table with options. -Solution: Move the "}," outside of the #ifdef. (Yakov Lerner) -Files: src/option.c - -Patch 6.2.105 -Problem: When the cursor is past the end of the line when calling - get_c_indent() a crash might occur. -Solution: Don't look past the end of the line. (NJ Verenini) -Files: src/misc1.c - -Patch 6.2.106 -Problem: Tag searching gets stuck on a very long line in the tags file. -Solution: When skipping back to search the first matching tag remember the - offset where searching started looking for a line break. -Files: src/tag.c - -Patch 6.2.107 (extra) -Problem: The NetBeans interface cannot be used on Win32. -Solution: Add support for the NetBeans for Win32. Add support for reading - XPM files on Win32. Also fixes that a sign icon with a space in - the file name did not work through the NetBeans interface. - (Sergey Khorev) - Also: avoid repeating error messages when the connection is lost. -Files: Makefile, runtime/doc/netbeans.txt, src/Make_bc5.mak, - src/Make_cyg.mak, src/Make_ming.mak, src/Make_mvc.mak, - src/bigvim.bat, src/feature.h, src/gui_beval.c, src/gui_beval.h, - src/gui_w32.c, src/gui_w48.c, src/menu.c, src/nbdebug.c, - src/nbdebug.h, src/netbeans.c, src/os_mswin.c, src/os_win32.h, - src/proto/gui_beval.pro, src/proto/gui_w32.pro, - src/proto/netbeans.pro, src/proto.h, src/version.c, src/vim.h, - src/xpm_w32.c, src/xpm_w32.h - -Patch 6.2.108 -Problem: Crash when giving a message about ignoring case in a tag. (Manfred - Kuehn) -Solution: Use a longer buffer for the message. -Files: src/tag.c - -Patch 6.2.109 -Problem: Compiler warnings with various Amiga compilers. -Solution: Add typecast, prototypes, et al. that are also useful for other - systems. (Flavio Stanchina) -Files: src/eval.c, src/ops.c - -Patch 6.2.110 -Problem: When $LANG includes the encoding, a menu without an encoding name - is not found. -Solution: Also look for a menu file without any encoding. -Files: runtime/menu.vim - -Patch 6.2.111 -Problem: Encoding "cp1251" is not recognized. -Solution: Add "cp1251" to the table of encodings. (Alexey Froloff) -Files: src/mbyte.c - -Patch 6.2.112 -Problem: After applying patches test32 fails. (Antonio Colombo) -Solution: Have "make clean" in the testdir delete *.rej and *.orig files. - Use this when doing "make clean" in the src directory. -Files: src/Makefile, src/testdir/Makefile - -Patch 6.2.113 -Problem: Using ":startinsert" after "$" works like "a" instead of "i". - (Ajit Thakkar) -Solution: Reset "w_curswant" for ":startinsert" and reset o_eol in edit(). -Files: src/edit.c, src/ex_docmd.c - -Patch 6.2.114 -Problem: When stdout is piped through "tee", the size of the screen may not - be correct. -Solution: Use stdin instead of stdout for ioctl() when stdin is a tty and - stdout isn't. -Files: src/os_unix.c - -Patch 6.2.115 (extra) -Problem: Compiler warnings with various Amiga compilers. -Solution: Add typecast, prototypes, et al. Those changes that are - Amiga-specific. (Flavio Stanchina) -Files: src/fileio.c, src/memfile.c, src/os_amiga.c, src/os_amiga.h, - src/vim.h - -Patch 6.2.116 (extra) -Problem: German keyboard with Numlock set different from system startup - causes problems. -Solution: Ignore keys with code 0xff. (Helmut Stiegler) -Files: src/gui_w48.c - -Patch 6.2.117 -Problem: Breakpoints in loops of sourced files and functions are not - detected. (Hari Krishna Dara) -Solution: Check for breakpoints when using lines that were previously read. - (Servatius Brandt) -Files: src/eval.c, src/ex_cmds2.c, src/ex_docmd.c, src/proto/eval.pro, - src/proto/ex_cmds2.pro - -Patch 6.2.118 (extra) -Problem: Mac: Compiling is done in a non-standard way. -Solution: Use the Unix method for Mac OS X, with autoconf. Add "CARBONGUI" - to Makefile and configure. (Eric Kow) - Move a few prototypes from os_mac.pro to gui_mac.pro. -Files: src/Makefile, src/auto/configure, src/configure.in, - src/config.mk.in, src/gui_mac.c, src/os_mac.h, src/os_macosx.c, - src/proto/gui_mac.pro, src/proto/os_mac.pro, - src/infplist.xml, src/vim.h - -Patch 6.2.119 (after 6.2.107) -Problem: When packing the MS-Windows archives a few files are missing. - (Guopeng Wen) -Solution: Add gui_beval.* to the list of generic source files. -Files: Makefile - -Patch 6.2.120 -Problem: Win32 GUI: The console dialogs are not supported on MS-Windows, - disabling the 'c' flag of 'guioptions'. (Servatius Brandt) -Solution: Define FEAT_CON_DIALOG also for GUI-only builds. -Files: src/feature.h - -Patch 6.2.121 (after 6.2.118) -Problem: Not all make programs support "+=". (Charles Campbell) -Solution: Use a normal assignment. -Files: src/Makefile - -Patch 6.2.122 (after 6.2.119) -Problem: Not all shells can expand [^~]. File missing. (Guopeng Wen) -Solution: Use a simpler pattern. Add the Aap recipe for the maze program - and a clean version of the source code. -Files: Makefile, runtime/macros/maze/Makefile, - runtime/macros/maze/README.txt, runtime/macros/maze/main.aap, - runtime/macros/maze/mazeclean.c - -Patch 6.2.123 (after 6.2.118) -Problem: Running configure fails. (Tony Leneis) -Solution: Change "==" to "=" for a test. -Files: src/auto/configure, src/configure.in - -Patch 6.2.124 (after 6.2.121)(extra) -Problem: Mac: Recursive use of M4FLAGS causes problems. When running Vim - directly it can't find the runtime files. (Emily Jackson) - Using GNU constructs causes warnings with other make programs. - (Ronald Schild) -Solution: Use another name for the M4FLAGS variable. - Don't remove "Vim.app" from the path. - Update the explanation for compiling on the Mac. (Eric Kow) - Don't use $(shell ) and $(addprefix ). -Files: src/INSTALLmac.txt, src/Makefile, src/misc1.c - -Patch 6.2.125 (after 6.2.107) -Problem: The "winsock2.h" file isn't always available. -Solution: Don't include this header file. -Files: src/netbeans.c - -Patch 6.2.126 -Problem: Typing CTRL-C at a confirm() prompt doesn't throw an exception. -Solution: Reset "mapped_ctrl_c" in get_keystroke(), so that "got_int" is set - in _OnChar(). -Files: src/misc1.c - -Patch 6.2.127 (extra) -Problem: Win32 console: Typing CTRL-C doesn't throw an exception. -Solution: Set got_int immediately when CTRL-C is typed, don't wait for - mch_breakcheck() being called. -Files: src/os_win32.c - -Patch 6.2.128 (after 6.2.118) -Problem: src/auto/configure is not consistent with src/configure.in. -Solution: Use the newly generated configure script. -Files: src/auto/configure - -Patch 6.2.129 -Problem: When 'number' is set 'wrapmargin' does not work Vi-compatible. - (Yasuhiro Matsumoto) -Solution: Reduce the textwidth when 'number' is set. Also for 'foldcolumn' - and similar things. -Files: src/edit.c - -Patch 6.2.130 (extra) -Problem: Win32 console: When 'restorescreen' is not set exiting Vim causes - the screen to be cleared. (Michael A. Mangino) -Solution: Don't clear the screen when exiting and 'restorescreen' isn't set. -Files: src/os_win32.c - -Patch 6.2.131 (extra) -Problem: Win32: Font handles are leaked. -Solution: Free italic, bold and bold-italic handles before overwriting them. - (Michael Wookey) -Files: src/gui_w48.c - -Patch 6.2.132 (extra) -Problem: Win32: console version doesn't work on latest Windows Server 2003. -Solution: Copy 12000 instead of 15000 cells at a time to avoid running out - of memory. -Files: src/os_win32.c - -Patch 6.2.133 -Problem: When starting the GUI a bogus error message about 'imactivatekey' - may be given. -Solution: Only check the value of 'imactivatekey' when the GUI is running. -Files: src/gui.c, src/option.c - -Patch 6.2.134 (extra) -Problem: Win32: When scrolling parts of the window are redrawn when this - isn't necessary. -Solution: Only invalidate parts of the window when they are obscured by - other windows. (Michael Wookey) -Files: src/gui_w48.c - -Patch 6.2.135 -Problem: An item <> in the ":command" argument is interpreted as <args>. -Solution: Avoid that <> is recognized as <args>. -Files: src/ex_docmd.c - -Patch 6.2.136 -Problem: ":e ++enc=latin1 newfile" doesn't set 'fenc' when the file doesn't - exist. (Miroslaw Dobrzanski-Neumann) -Solution: Set 'fileencoding' to the specified encoding when editing a file - that does not exist. -Files: src/fileio.c - -Patch 6.2.137 -Problem: "d:cmd<CR>" cannot be repeated with ".". Breaks repeating "d%" - when using the matchit plugin. -Solution: Store the command to be repeated. This is restricted to - single-line commands. -Files: src/ex_docmd.c, src/globals.h, src/normal.c, src/vim.h - -Patch 6.2.138 (extra) -Problem: Compilation problem on VMS with dynamic buffer on the stack. -Solution: Read one byte less than the size of the buffer, so that we can - check for the string length without an extra buffer. -Files: src/os_vms.c - -Patch 6.2.139 -Problem: Code is repeated in the two Perl files. -Solution: Move common code from if_perl.xs and if_perlsfio.c to vim.h. - Also fix a problem with generating prototypes. -Files: src/if_perl.xs, src/if_perlsfio.c, src/vim.h - -Patch 6.2.140 (after 6.2.121) -Problem: Mac: Compiling with Python and Perl doesn't work. -Solution: Adjust the configure check for Python to use "-framework Python" - for Python 2.3 on Mac OS/X. - Move "-ldl" after "DynaLoader.a" in the link command. - Change "perllibs" to "PERL_LIBS". -Files: src/auto/configure, src/configure.in, src/config.mk.in - -Patch 6.2.141 (extra) -Problem: Mac: The b_FSSpec field is sometimes unused. -Solution: Change the #ifdef to FEAT_CW_EDITOR and defined it in feature.h -Files: src/fileio.c, src/gui_mac.c, src/structs.h, src/feature.h - -Patch 6.2.142 (after 6.2.124) -Problem: Mac: building without GUI through configure doesn't work. - When the system is slow, unpacking the resource file takes too - long. -Solution: Don't always define FEAT_GUI_MAC when MACOS is defined, define it - in the Makefile. - Add a configure option to skip Darwin detection. - Use a Python script to unpack the resources to avoid a race - condition. (Taro Muraoka) -Files: Makefile, src/Makefile, src/auto/configure, src/configure.in, - src/dehqx.py, src/vim.h - -Patch 6.2.143 -Problem: Using "K" on Visually selected text doesn't work if it ends in - a multi-byte character. -Solution: Include all the bytes of the last character. (Taro Muraoka) -Files: src/normal.c - -Patch 6.2.144 -Problem: When "g:html_use_css" is set the HTML header generated by the - 2html script is wrong. -Solution: Add the header after adding HREF for links. - Also use ":normal!" instead of ":normal" to avoid mappings - getting in the way. -Files: runtime/syntax/2html.vim - -Patch 6.2.145 (after 6.2.139) -Problem: Undefining "bool" doesn't work for older systems. (Wojtek Pilorz) -Solution: Only undefine "bool" on Mac OS. -Files: src/vim.h - -Patch 6.2.146 -Problem: On some systems the prototype for iconv() is wrong, causing a - warning message. -Solution: Use a cast (void *) to avoid the warning. (Charles Campbell) -Files: src/fileio.c, src/mbyte.c - -Patch 6.2.147 -Problem: ":s/pat/\=col('.')" always replaces with "1". -Solution: Set the cursor to the start of the match before substituting. - (Helmut Stiegler) -Files: src/ex_cmds.c - -Patch 6.2.148 -Problem: Can't break an Insert into several undoable parts. -Solution: Add the CTRL-G u command. -Files: runtime/doc/insert.txt, src/edit.c - -Patch 6.2.149 -Problem: When the cursor is on a line past 21,474,748 the indicated - percentage of the position is invalid. With that many lines - "100%" causes a negative cursor line number, resulting in a crash. - (Daniel Goujot) -Solution: Divide by 100 instead of multiplying. Avoid overflow when - computing the line number for "100%". -Files: src/buffer.c, src/ex_cmds2.c, src/normal.c - -Patch 6.2.150 -Problem: When doing "vim - < file" lines are broken at NUL chars. - (Daniel Goujot) -Solution: Change NL characters back to NUL when reading from the temp - buffer. -Files: src/fileio.c - -Patch 6.2.151 -Problem: When doing "vim --remote +startinsert file" some commands are - inserted as text. (Klaus Bosau) -Solution: Put all the init commands in one Ex line, not using a <CR>, so - that Insert mode isn't started too early. -Files: src/main.c - -Patch 6.2.152 -Problem: The cursor() function doesn't reset the column offset for - 'virtualedit'. -Solution: Reset the offset to zero. (Helmut Stiegler) -Files: src/eval.c - -Patch 6.2.153 -Problem: Win32: ":lang german" doesn't use German messages. -Solution: Add a table to translate the Win32 language names to two-letter - language codes. -Files: src/ex_cmds2.c - -Patch 6.2.154 -Problem: Python bails out when giving a warning message. (Eugene - Minkovskii) -Solution: Set sys.argv[] to an empty string. -Files: src/if_python.c - -Patch 6.2.155 -Problem: Win32: Using ":tjump www" in a help file gives two results. - (Dave Roberts) -Solution: Ignore differences between slashes and backslashes when checking - for identical tag matches. -Files: src/tag.c - -Patch 6.2.156 (after 6.2.125) -Problem: Win32: Netbeans fails to build, EINTR is not defined. -Solution: Redefine EINTR to WSAEINTR. (Mike Williams) -Files: src/netbeans.c - -Patch 6.2.157 -Problem: Using "%p" in 'errorformat' gives a column number that is too - high. -Solution: Set the flag to use the number as a virtual column. (Lefteris - Koutsoloukas) -Files: src/quickfix.c - -Patch 6.2.158 -Problem: The sed command on Solaris and HPUX doesn't work for a line that - doesn't end in a newline. -Solution: Add a newline when feeding text to sed. (Mark Waggoner) -Files: src/configure.in, src/auto/configure - -Patch 6.2.159 -Problem: When using expression folding and 'foldopen' is "undo" an undo - command doesn't always open the fold. -Solution: Save and restore the KeyTyped variable when evaluating 'foldexpr'. - (Taro Muraoka) -Files: src/fold.c - -Patch 6.2.160 -Problem: When 'virtualedit' is "all" and 'selection is "exclusive", - selecting a double-width character below a single-width character - may cause a crash. -Solution: Avoid overflow on unsigned integer decrement. (Taro Muraoka) -Files: src/normal.c - -Patch 6.2.161 (extra) -Problem: VMS: Missing header file. Reading input busy loops. -Solution: Include termdef.h. Avoid the use of a wait function in - vms_read(). (Frank Ries) -Files: src/os_unix.h, src/os_vms.c - -Patch 6.2.162 -Problem: ":redraw" doesn't always display the text that includes the cursor - position, e.g. after ":call cursor(1, 0)". (Eugene Minkovskii) -Solution: Call update_topline() before redrawing. -Files: src/ex_docmd.c - -Patch 6.2.163 -Problem: "make install" may also copy AAPDIR directories. -Solution: Delete AAPDIR directories, just like CVS directories. -Files: src/Makefile - -Patch 6.2.164 (after 6.2.144) -Problem: When "g:html_use_css" is set the HTML header generated by the - 2html script is still wrong. -Solution: Search for a string instead of jumping to a fixed line number. - Go to the start of the line before inserting the header. - (Jess Thrysoee) -Files: runtime/syntax/2html.vim - -Patch 6.2.165 -Problem: The configure checks hang when using autoconf 2.57. -Solution: Invoke AC_PROGRAM_EGREP to set $EGREP. (Aron Griffis) -Files: src/auto/configure, src/configure.in - -Patch 6.2.166 -Problem: When $GZIP contains "-N" editing compressed files doesn't work - properly. -Solution: Add "-n" to "gzip -d" to avoid restoring the file name. (Oyvind - Holm) -Files: runtime/plugin/gzip.vim - -Patch 6.2.167 -Problem: The Python interface leaks memory when assigning lines to a - buffer. (Sergey Khorev) -Solution: Do not copy the line when calling ml_replace(). -Files: src/if_python.c - -Patch 6.2.168 -Problem: Python interface: There is no way to get the indices from a range - object. -Solution: Add the "start" and "end" attributes. (Maurice S. Barnum) -Files: src/if_python.c, runtime/doc/if_pyth.txt - -Patch 6.2.169 -Problem: The prototype for _Xmblen() appears in a recent XFree86 header - file, causing a warning for our prototype. (Hisashi T Fujinaka) -Solution: Move the prototype to an osdef file, so that it's filtered out. -Files: src/mbyte.c, src/osdef2.h.in - -Patch 6.2.170 -Problem: When using Sun WorkShop the current directory isn't changed to - where the file is. -Solution: Set the 'autochdir' option when using WorkShop. And avoid using - the basename when 'autochdir' is not set. -Files: src/gui_x11.c, src/ex_cmds.c - -Patch 6.2.171 (after 6.2.163) -Problem: The "-or" argument of "find" doesn't work for SysV systems. -Solution: Use "-o" instead. (Gordon Prieur) -Files: src/Makefile - -Patch 6.2.172 (after 6.2.169) -Problem: The prototype for _Xmblen() still causes trouble. -Solution: Include the X11 header file that defines the prototype. -Files: src/osdef2.h.in, src/osdef.sh - -Patch 6.2.173 (extra) -Problem: Win32: Ruby interface doesn't work with Ruby 1.8.0 for other - compilers than MSVC. -Solution: Fix the BC5, Cygwin and Mingw makefiles. (Dan Sharp) -Files: src/Make_bc5.mak, src/Make_cyg.mak, src/Make_ming.mak - -Patch 6.2.174 -Problem: After the ":intro" message only a mouse click in the last line - gets past the hit-return prompt. -Solution: Accept a click at or below the hit-return prompt. -Files: src/gui.c, src/message.c - -Patch 6.2.175 -Problem: Changing 'backupext' in a *WritePre autocommand doesn't work. - (William Natter) -Solution: Move the use of p_bex to after executing the *WritePre - autocommands. Also avoids reading allocated memory after freeing. -Files: src/fileio.c - -Patch 6.2.176 -Problem: Accented characters in translated help files are not handled - correctly. (Fabien Vayssiere) -Solution: Include "192-255" in 'iskeyword' for the help window. -Files: src/ex_cmds.c - -Patch 6.2.177 (extra) -Problem: VisVim: Opening a file with a space in the name doesn't work. (Rob - Retter) Arbitrary commands are being executed. (Neil Bird) -Solution: Put a backslash in front of every space in the file name. - (Gerard Blais) Terminate the CTRL-\ CTRL-N command with a NUL. -Files: src/VisVim/Commands.cpp, src/VisVim/VisVim.rc - -Patch 6.2.178 -Problem: People who don't know how to exit Vim try pressing CTRL-C. -Solution: Give a message how to exit Vim when CTRL-C is pressed and it - doesn't cancel anything. -Files: src/normal.c - -Patch 6.2.179 (extra) -Problem: The en_gb messages file isn't found on case sensitive systems. -Solution: Rename en_gb to en_GB. (Mike Williams) -Files: src/po/en_gb.po, src/po/en_GB.po, src/po/Make_ming.mak, - src/po/Make_mvc.mak, src/po/Makefile, src/po/README_mvc.txt - -Patch 6.2.180 -Problem: Compiling with GTK2 on Win32 doesn't work. -Solution: Include gdkwin32.h instead of gdkx.h. (Srinath Avadhanula) -Files: src/gui_gtk.c, src/gui_gtk_f.c, src/gui_gtk_x11.c, src/mbyte.c - -Patch 6.2.181 (after 6.2.171) -Problem: The "-o" argument of "find" has lower priority than the implied - "and" with "-print". -Solution: Add parenthesis around the "-o" expression. (Gordon Prieur) -Files: src/Makefile - -Patch 6.2.182 (after 6.2.094) -Problem: Compilation with tiny features fails because of missing - get_past_head() function. -Solution: Adjust the #ifdef for get_past_head(). -Files: src/misc1.c - -Patch 6.2.183 (after 6.2.178) -Problem: Warning for char/unsigned char mixup. -Solution: Use MSG() instead of msg(). (Tony Leneis) -Files: src/normal.c - -Patch 6.2.184 -Problem: With 'formatoptions' set to "1aw" inserting text may cause the - paragraph to be ended. (Alan Schmitt) -Solution: Temporarily add an extra space to make the paragraph continue - after moving the word after the cursor to the next line. - Also format when pressing Esc. -Files: src/edit.c, src/normal.c, src/proto/edit.pro - -Patch 6.2.185 -Problem: Restoring a session with zero-height windows does not work - properly. (Charles Campbell) -Solution: Accept a zero argument to ":resize" as intended. Add a window - number argument to ":resize" to be able to set the size of other - windows, because the current window cannot be zero-height. - Fix the explorer plugin to avoid changing the window sizes. Add - the winrestcmd() function for this. -Files: runtime/doc/eval.txt, runtime/plugin/explorer.vim, src/eval.c, - src/ex_cmds.h, src/ex_docmd.c, src/proto/window.pro, src/window.c - -Patch 6.2.186 (after 6.2.185) -Problem: Documentation file eval.txt contains examples without indent. -Solution: Insert the indent. Also fix other mistakes. -Files: runtime/doc/eval.txt - -Patch 6.2.187 -Problem: Using Insure++ reveals a number of bugs. (Dominique Pelle) -Solution: Initialize variables where needed. Free allocated memory to avoid - leaks. Fix comparing tags to avoid reading past allocated memory. -Files: src/buffer.c, src/diff.c, src/fileio.c, src/mark.c, src/misc1.c, - src/misc2.c, src/ops.c, src/option.c, src/tag.c, src/ui.c - -Patch 6.2.188 (extra) -Problem: MS-Windows: Multi-byte characters in a filename cause trouble for - the window title. -Solution: Return when the wide function for setting the title did its work. -Files: src/gui_w48.c - -Patch 6.2.189 -Problem: When setting 'viminfo' after editing a new buffer its marks are - not stored. (Keith Roberts) -Solution: Set the "b_marks_read" flag when skipping to read marks from the - viminfo file. -Files: src/fileio.c - -Patch 6.2.190 -Problem: When editing a compressed files, marks are lost. -Solution: Add the ":lockmarks" modifier and use it in the gzip plugin. - Make exists() also check for command modifiers, so that the - existence of ":lockmarks" can be checked for. - Also add ":keepmarks" to avoid that marks are deleted when - filtering text. - When deleting lines put marks 'A - 'Z and '0 - '9 at the first - deleted line instead of clearing the mark. They were kept in the - viminfo file anyway. - Avoid that the gzip plugin puts deleted text in registers. -Files: runtime/doc/motion.txt, runtime/plugin/gzip.vim, src/ex_cmds.c, - src/ex_docmd.c, src/mark.c, src/structs.h - -Patch 6.2.191 -Problem: The intro message is outdated. Information about sponsoring and - registering is missing. -Solution: Show info about sponsoring and registering Vim in the intro - message now and then. Add help file about sponsoring. -Files: runtime/doc/help.txt, runtime/doc/sponsor.txt, runtime/doc/tags, - runtime/menu.vim, src/version.c - -Patch 6.2.192 -Problem: Using CTRL-T and CTRL-D with "gR" messes up the text. (Jonahtan - Hankins) -Solution: Avoid calling change_indent() recursively. -Files: src/edit.c - -Patch 6.2.193 -Problem: When recalling a search pattern from the history from a ":s,a/c," - command the '/' ends the search string. (JC van Winkel) -Solution: Store the separator character with the history entries. Escape - characters when needed, replace the old separator with the new one. - Also fixes that recalling a "/" search for a "?" command messes up - trailing flags. -Files: src/eval.c, src/ex_getln.c, src/normal.c, src/proto/ex_getln.pro, - src/search.c, src/tag.c - -Patch 6.2.194 (after 6.2.068) -Problem: For NetBeans, instead of writing the file and sending an event - about it, tell NetBeans to write the file. -Solution: Add the "save" command, "netbeansBuffer" command and - "buttonRelease" event to the netbeans protocol. Updated the - interface to version 2.2. (Gordon Prieur) - Also: open a fold when the cursor has been positioned. - Also: fix memory leak, free result of nb_quote(). -Files: runtime/doc/netbeans.txt, src/fileio.c, src/netbeans.c, - src/normal.c, src/proto/netbeans.pro, src/structs.h - -Patch 6.2.195 (after 6.2.190) -Problem: Compiling fails for missing CPO_REMMARK symbol. -Solution: Add the patch I forgot to include... -Files: src/option.h - -Patch 6.2.196 (after 6.2.191) -Problem: Rebuilding the documentation doesn't use the sponsor.txt file. -Solution: Add sponsor.txt to the Makefile. (Christian J. Robinson) -Files: runtime/doc/Makefile - -Patch 6.2.197 -Problem: It is not possible to force a redraw of status lines. (Gary - Johnson) -Solution: Add the ":redrawstatus" command. -Files: runtime/doc/various.txt, src/ex_cmds.h, src/ex_docmd.c, - src/screen.c - -Patch 6.2.198 -Problem: A few messages are not translated. (Ernest Adrogue) -Solution: Mark the messages to be translated. -Files: src/ex_cmds.c - -Patch 6.2.199 (after 6.2.194) -Problem: Vim doesn't work perfectly well with NetBeans. -Solution: When NetBeans saves the file, reset the timestamp to avoid "file - changed" warnings. Close a buffer in a proper way. Don't try - giving a debug message with an invalid pointer. Send a - newDotAndMark message when needed. Report a change by the "r" - command to NetBeans. (Gordon Prieur) -Files: src/netbeans.c, src/normal.c - -Patch 6.2.200 -Problem: When recovering a file, 'fileformat' is always the default, thus - writing the file may result in differences. (Penelope Fudd) -Solution: Before recovering the file try reading the original file to obtain - the values of 'fileformat', 'fileencoding', etc. -Files: src/memline.c - -Patch 6.2.201 -Problem: When 'autowriteall' is set ":qall" still refuses to exit if there - is a modified buffer. (Antoine Mechelynck) -Solution: Attempt writing modified buffers as intended. -Files: src/ex_cmds2.c - -Patch 6.2.202 -Problem: Filetype names of CHILL and ch script are confusing. -Solution: Rename "ch" to "chill" and "chscript" to "ch". -Files: runtime/filetype.vim, runtime/makemenu.vim, runtime/synmenu.vim - runtime/syntax/ch.vim, runtime/syntax/chill.vim - -Patch 6.2.203 -Problem: With characterwise text that has more than one line, "3P" works - wrong. "3p" has the same problem. There also is a display - problem. (Daniel Goujot) -Solution: Perform characterwise puts with a count in the right position. -Files: src/ops.c - -Patch 6.2.204 (after 6.2.086) -Problem: "]]" in a file with closed folds moves to the end of the file. - (Nam SungHyun) -Solution: Find one position in each closed fold, then move to after the fold. -Files: src/search.c - -Patch 6.2.205 (extra) -Problem: MS-Windows: When the taskbar is at the left or top of the screen, - the Vim window placement is wrong. -Solution: Compute the size and position of the window correctly. (Taro - Muraoka) -Files: src/gui_w32.c, src/gui_w48.c - -Patch 6.2.206 -Problem: Multi-byte characters cannot be used as hotkeys in a console - dialog. (Mattias Erkisson) -Solution: Handle multi-byte characters properly. Also put () or [] around - default hotkeys. -Files: src/message.c, src/macros.h - -Patch 6.2.207 -Problem: When 'encoding' is a multi-byte encoding, expanding an - abbreviation that starts where insertion started results in - characters before the insertion to be deleted. (Xiangjiang Ma) -Solution: Stop searching leftwards for the start of the word at the position - where insertion started. -Files: src/getchar.c - -Patch 6.2.208 -Problem: When using fold markers, three lines in a row have the start - marker and deleting the first one with "dd", a nested fold is not - deleted. (Kamil Burzynski) - Using marker folding, a level 1 fold doesn't stop when it is - followed by "{{{2", starting a level 2 fold. -Solution: Don't stop updating folds at the end of a change when the nesting - level of folds is larger than the fold level. - Correctly compute the number of folds that start at "{{{2". - Also avoid a crash for a NULL pointer. -Files: src/fold.c - -Patch 6.2.209 -Problem: A bogus fold is created when using "P" while the cursor is in the - middle of a closed fold. (Kamil Burzynski) -Solution: Correct the line number where marks are modified for closed folds. -Files: src/ops.c - -Patch 6.2.210 (extra) -Problem: Mac OSX: antialiased fonts are not supported. -Solution: Add the 'antialias' option to switch on antialiasing on Mac OSX - 10.2 and later. (Peter Cucka) -Files: runtime/doc/options.txt, src/gui_mac.c, src/option.h, src/option.c - -Patch 6.2.211 (extra) -Problem: Code for handling file dropped on Vim is duplicated. -Solution: Move the common code to gui_handle_drop(). - Add code to drop the files in the window under the cursor. - Support drag&drop on the Macintosh. (Taro Muraoka) - When dropping a directory name edit that directory (using the - explorer plugin) - Fix that changing directory with Shift pressed didn't work for - relative path names. -Files: src/fileio.c, src/gui.c, src/gui_gtk_x11.c, src/gui_mac.c, - src/gui_w48.c, src/proto/fileio.pro, src/proto/gui.pro - -Patch 6.2.212 (after 6.2.199) -Problem: NetBeans: Replacing with a count is not handled correctly. -Solution: Move reporting the change outside of the loop for the count. - (Gordon Prieur) -Files: src/normal.c - -Patch 6.2.213 (after 6.2.208) -Problem: Using marker folding, "{{{1" doesn't start a new fold when already - at fold level 1. (Servatius Brandt) -Solution: Correctly compute the number of folds that start at "{{{1". -Files: src/fold.c - -Patch 6.2.214 (after 6.2.211) (extra) -Problem: Warning for an unused variable. -Solution: Delete the declaration. (Bill McCarthy) -Files: src/gui_w48.c - -Patch 6.2.215 -Problem: NetBeans: problems saving an unmodified file. -Solution: Add isNetbeansModified() function. Disable netbeans_unmodified(). - (Gordon Prieur) -Files: src/fileio.c, src/netbeans.c, src/proto/netbeans.pro, - runtime/doc/netbeans.txt, runtime/doc/tags - -Patch 6.2.216 (after 6.2.206) -Problem: Multi-byte characters still cannot be used as hotkeys in a console - dialog. (Mattias Erkisson) -Solution: Make get_keystroke() handle multi-byte characters. -Files: src/misc1.c - -Patch 6.2.217 -Problem: GTK: setting the title doesn't always work correctly. -Solution: Invoke gui_mch_settitle(). (Tomas Stehlik) -Files: src/os_unix.c - -Patch 6.2.218 -Problem: Warning for function without prototype. -Solution: Add argument types to the msgCB field of the BalloonEval struct. -Files: src/gui_beval.h - -Patch 6.2.219 -Problem: Syntax highlighting hangs on an empty match of an item with a - nextgroup. (Charles Campbell) -Solution: Remember that the item has already matched and don't match it - again at the same position. -Files: src/syntax.c - -Patch 6.2.220 -Problem: When a Vim server runs in a console a remote command isn't handled - before a key is typed. (Joshua Neuheisel) -Solution: Don't try reading more input when a client-server command has been - received. -Files: src/os_unix.c - -Patch 6.2.221 -Problem: No file name completion for ":cscope add". -Solution: Add the XFILE flag to ":cscope". (Gary Johnson) -Files: src/ex_cmds.h - -Patch 6.2.222 -Problem: Using "--remote" several times on a row only opens some of the - files. (Dany St-Amant) -Solution: Don't delete all typeahead when the server receives a command from - a client, only delete typed characters. -Files: src/main.c - -Patch 6.2.223 -Problem: Cscope: Avoid a hang when cscope waits for a response while Vim - waits for a prompt. - Error messages from Cscope mess up the display. -Solution: Detect the hit-enter message and respond by sending a return - character to cscope. (Gary Johnson) - Use EMSG() and strerror() when possible. Replace perror() with - PERROR() everywhere, add emsg3(). -Files: src/diff.c, src/if_cscope.c, src/integration.c, src/message.c, - src/proto/message.pro, src/misc2.c, src/netbeans.c, src/vim.h - -Patch 6.2.224 -Problem: Mac: Can't compile with small features. (Axel Kielhorn) -Solution: Also include vim_chdirfile() when compiling for the Mac. -Files: src/misc2.c - -Patch 6.2.225 -Problem: NetBeans: Reported modified state isn't exactly right. -Solution: Report a file being modified in the NetBeans way. -Files: src/netbeans.c - -Patch 6.2.226 (after 6.2.107) (extra) -Problem: The "ws2-32.lib" file isn't always available. -Solution: Use "WSock32.lib" instead. (Taro Muraoka, Dan Sharp) -Files: src/Make_cyg.mak, src/Make_ming.mak, src/Make_mvc.mak - -Patch 6.2.227 (extra) -Problem: The "PC" symbol is defined but not used anywhere. -Solution: Remove "-DPC" from the makefiles. -Files: src/Make_bc3.mak, src/Make_bc5.mak, src/Make_cyg.mak, - src/Make_ming.mak - -Patch 6.2.228 -Problem: Receiving CTRL-\ CTRL-N after typing "f" or "m" doesn't switch Vim - back to Normal mode. Same for CTRL-\ CTRL-G. -Solution: Check if the character typed after a command is CTRL-\ and obtain - another character to check for CTRL-N or CTRL-G, waiting up to - 'ttimeoutlen' msec. -Files: src/normal.c - -Patch 6.2.229 -Problem: ":function" with a name that uses magic curlies does not work - inside a function. (Servatius Brandt) -Solution: Skip over the function name properly. -Files: src/eval.c - -Patch 6.2.230 (extra) -Problem: Win32: a complex pattern may cause a crash. -Solution: Use __try and __except to catch the exception and handle it - gracefully, when possible. Add myresetstkoflw() to reset the - stack overflow. (Benjamin Peterson) -Files: src/Make_bc5.mak, src/os_mswin.c src/os_win32.c, src/os_win32.h, - src/proto/os_win32.pro, src/regexp.c - -Patch 6.2.231 (after 6.2.046) -Problem: Various problems when an error exception is raised from within a - builtin function. When it is invoked while evaluating arguments - to a function following arguments are still evaluated. When - invoked with a line range it will be called for remaining lines. -Solution: Update "force_abort" also after calling a builtin function, so - that aborting() always returns the correct value. (Servatius - Brandt) -Files: src/eval.c, src/ex_eval.c, src/proto/ex_eval.pro, - src/testdir/test49.ok, src/testdir/test49.vim - -Patch 6.2.232 -Problem: ":python vim.command('python print 2*2')" crashes Vim. (Eugene - Minkovskii) -Solution: Disallow executing a Python command recursively and give an error - message. -Files: src/if_python.c - -Patch 6.2.233 -Problem: On Mac OSX adding -pthread for Python only generates a warning. - The test for Perl threads rejects Perl while it's OK. - Tcl doesn't work at all. - The test for Ruby fails if ruby exists but there are no header - files. The Ruby library isn't detected properly -Solution: Avoid adding -pthread on Mac OSX. Accept Perl threads when it's - not the 5.5 threads. - Use the Tcl framework for header files. For Ruby rename cWindow - to cVimWindow to avoid a name clash. (Ken Scott) - Only enable Ruby when the header files can be found. Use "-lruby" - instead of "libruby.a" when it can't be found. -Files: src/auto/configure, src/configure.in, src/if_ruby.c - -Patch 6.2.234 -Problem: GTK 2 GUI: ":sp" and the ":q" leaves the cursor on the command - line. -Solution: Flush output before removing scrollbars. Also do this in other - places where gui_mch_*() functions are invoked. -Files: src/ex_cmds.c, src/option.c, src/window.c - -Patch 6.2.235 (extra) -Problem: Win32: Cursor isn't removed with a 25x80 window and doing: - "1830ia<Esc>400a-<Esc>0w0". (Yasuhiro Matsumoto) -Solution: Remove the call to gui_undraw_cursor() from gui_mch_insert_lines(). -Files: src/gui_w48.c - -Patch 6.2.236 -Problem: Using gvim with Agide gives "connection lost" error messages. -Solution: Only give the "connection lost" message when the buffer was once - owned by NetBeans. -Files: src/netbeans.c, src/structs.h - -Patch 6.2.237 -Problem: GTK 2: Thai text is drawn wrong. It changes when moving the - cursor over it. -Solution: Disable the shaping engine, it moves combining characters to a - wrong position and combines characters, while drawing the cursor - doesn't combine characters. -Files: src/gui_gtk_x11.c - -Patch 6.2.238 (after 6.2.231) -Problem: ":function" does not work inside a while loop. (Servatius Brandt) -Solution: Add get_while_line() and pass it to do_one_cmd() when in a while - loop, so that all lines are stored and can be used again when - repeating the loop. - Adjust test 49 so that it checks for the fixed problems. - (Servatius Brandt) -Files: src/digraph.c, src/ex_cmds2.c, src/ex_docmd.c, src/ex_eval.c, - src/proto/ex_cmds2.pro, src/proto/ex_docmd.pro, - src/testdir/test49.in, src/testdir/test49.ok, - src/testdir/test49.vim - -Patch 6.2.239 -Problem: GTK 2: With closed folds the arrow buttons of a vertical scrollbar - often doesn't scroll. (Moshe Kaminsky) -Solution: Hackish solution: Detect that the button was pressed from the - mouse pointer position. -Files: src/gui_gtk.c, src/gui.c - -Patch 6.2.240 -Problem: GTK 2: Searching for bitmaps for the toolbar doesn't work as with - other systems. Need to explicitly use "icon=name". (Ned Konz, - Christian J. Robinson) -Solution: Search for icons like done for Motif. -Files: src/gui_gtk.c - -Patch 6.2.241 -Problem: GTK 2: Search and Search/Replace dialogs are synced, that makes no - sense. Buttons are sometimes greyed-out. (Jeremy Messenger) -Solution: Remove the code to sync the two dialogs. Adjust the code to react - to an empty search string to also work for GTK2. (David Necas) -Files: src/gui_gtk.c - -Patch 6.2.242 -Problem: Gnome: "vim --help" only shows the Gnome arguments, not the Vim - arguments. -Solution: Don't let the Gnome code remove the "--help" argument and don't - exit at the end of usage(). -Files: src/gui_gtk_x11.c, src/main.c - -Patch 6.2.243 (extra) -Problem: Mac: Dropping a file on a Vim icon causes a hit-enter prompt. -Solution: Move the dropped files to the global argument list, instead of the - usual drop handling. (Eckehard Berns) -Files: src/main.c, src/gui_mac.c - -Patch 6.2.244 -Problem: ':echo "\xf7"' displays the illegal byte as if it was a character - and leaves "cho" after it. -Solution: When checking the length of a UTF-8 byte sequence and it's shorter - than the number of bytes available, assume it's an illegal byte. -Files: src/mbyte.c - -Patch 6.2.245 -Problem: Completion doesn't work for ":keepmarks" and ":lockmarks". -Solution: Add the command modifiers to the table of commands. (Madoka - Machitani) -Files: src/ex_cmds.h, src/ex_docmd.c - -Patch 6.2.246 -Problem: Mac: Starting Vim from Finder doesn't show error messages. -Solution: Recognize that output is being displayed by stderr being - "/dev/console". (Eckehard Berns) -Files: src/main.c, src/message.c - -Patch 6.2.247 (after 6.2.193) -Problem: When using a search pattern from the viminfo file the last - character is replaced with a '/'. -Solution: Store the separator character in the right place. (Kelvin Lee) -Files: src/ex_getln.c - -Patch 6.2.248 -Problem: GTK: When XIM is enabled normal "2" and keypad "2" cannot be - distinguished. -Solution: Detect that XIM changes the keypad key to the expected ASCII - character and fall back to the non-XIM code. (Neil Bird) -Files: src/gui_gtk_x11.c, src/mbyte.c, src/proto/mbyte.pro - -Patch 6.2.249 -Problem: ":cnext" moves to the error in the next file, but there is no - method to go back. -Solution: Add ":cpfile" and ":cNfile". -Files: src/ex_cmds.h, src/quickfix.c, src/vim.h, runtime/doc/quickfix.txt - -Patch 6.2.250 -Problem: Memory leaks when using signs. (Xavier de Gaye) -Solution: Delete the list of signs when unloading a buffer. -Files: src/buffer.c - -Patch 6.2.251 -Problem: GTK: The 'v' flag in 'guioptions' doesn't work. (Steve Hall) - Order of buttons is reversed for GTK 2.2.4. Don't always get - focus back after handling a dialog. -Solution: Make buttons appear vertically when desired. Reverse the order in - which buttons are added to a dialog. Move mouse pointer around - when the dialog is done and we don't have focus. -Files: src/gui_gtk.c - -Patch 6.2.252 (extra, after 6.2.243) -Problem: Mac: Dropping a file on a Vim icon causes a hit-enter prompt for - Mac OS classic. -Solution: Remove the #ifdef from the code that fixes it for Mac OSX. -Files: src/gui_mac.c - -Patch 6.2.253 -Problem: When 'tagstack' is not set a ":tag id" command does not work after - a ":tjump" command. -Solution: Set "new_tag" when 'tagstack' isn't set. (G. Narendran) -Files: src/tag.c - -Patch 6.2.254 -Problem: May run out of space for error messages. -Solution: Keep room for two more bytes. -Files: src/quickfix.c - -Patch 6.2.255 -Problem: GTK: A new item in the popup menu is put just after instead of - just before the right item. (Gabriel Zachmann) -Solution: Don't increment the menu item index. -Files: src/gui_gtk.c - -Patch 6.2.256 -Problem: Mac: "macroman" encoding isn't recognized, need to use - "8bit-macroman. -Solution: Recognize "macroman" with an alias "mac". (Eckehard Berns) -Files: src/mbyte.c - -Patch 6.2.257 (after 6.2.250) -Problem: Signs are deleted for ":bdel", but they could still be useful. -Solution: Delete signs only for ":bwipe". -Files: src/buffer.c - -Patch 6.2.258 -Problem: GUI: can't disable (grey-out) a popup menu item. (Ajit Thakkar) -Solution: Loop over the popup menus for all modes. -Files: src/menu.c - -Patch 6.2.259 -Problem: If there are messages when exiting, on the console there is a - hit-enter prompt while the message can be read; in the GUI the - message may not be visible. -Solution: Use the hit-enter prompt when there is an error message from - writing the viminfo file or autocommands, or when there is any - output in the GUI and 'verbose' is set. Don't use a hit-enter - prompt for the non-GUI version unless there is an error message. -Files: src/main.c - -Patch 6.2.260 -Problem: GTK 2: Can't quit a dialog with <Esc>. - GTK 1 and 2: <Enter> always gives a result, even when the default - button has been disabled. -Solution: Handle these keys explicitly. When no default button is specified - use the first one (works mostly like it was before). -Files: src/gui_gtk.c - -Patch 6.2.261 -Problem: When 'autoindent' and 'cindent' are set and a line is recognized - as a comment, starting a new line won't do 'cindent' formatting. -Solution: Also use 'cindent' formatting for lines that are used as a - comment. (Servatius Brandt) -Files: src/misc1.c - -Patch 6.2.262 -Problem: 1 CTRL-W w beeps, even though going to the first window is - possible. (Charles Campbell) -Solution: Don't beep. -Files: src/window.c - -Patch 6.2.263 -Problem: Lint warnings: Duplicate function prototypes, duplicate macros, - use of a zero character instead of a zero pointer, unused - variable. Clearing allocated memory in a complicated way. -Solution: Remove the function prototypes from farsi.h. Remove the - duplicated lines in keymap.h. Change getvcol() argument from NUL - to NULL. Remove the "col" variable in regmatch(). Use - lalloc_clear() instead of lalloc(). (Walter Briscoe) -Files: src/farsi.h, src/keymap.h, src/ops.c, src/regexp.c, src/search.c - -Patch 6.2.264 (after 6.2.247) -Problem: Writing past allocated memory when using a command line from the - viminfo file. -Solution: Store the NUL in the right place. -Files: src/ex_getln.c - -Patch 6.2.265 -Problem: Although ":set" is not allowed in the sandbox, ":let &opt = val" - works. -Solution: Do allow changing options in the sandbox, but not the ones that - can't be changed from a modeline. -Files: src/ex_cmds.h, src/options.c - -Patch 6.2.266 -Problem: When redirecting output and using ":silent", line breaks are - missing from output of ":map" and ":tselect". Alignment of - columns is wrong. -Solution: Insert a line break where "msg_didout" was tested. Update msg_col - when redirecting and using ":silent". -Files: src/getchar.c, src/message.c - -Patch 6.2.267 (extra) -Problem: Win32: "&&" in a tearoff menu is not shown. (Luc Hermitte) -Solution: Use the "name" item from the menu instead of the "dname" item. -Files: src/gui_w32.c, src/menu.c - -Patch 6.2.268 -Problem: GUI: When changing 'guioptions' part of the window may be off - screen. (Randall Morris) -Solution: Adjust the size of the window when changing 'guioptions', but only - when adding something. -Files: src/gui.c - -Patch 6.2.269 -Problem: Diff mode does not highlight a change in a combining character. - (Raphael Finkel) -Solution: Make diff_find_change() multi-byte aware: find the start byte of - a character that contains a change. -Files: src/diff.c - -Patch 6.2.270 -Problem: Completion in Insert mode, then repeating with ".", doesn't handle - composing characters in the completed text. (Raphael Finkel) -Solution: Don't skip over composing chars when adding completed text to the - redo buffer. -Files: src/getchar.c - -Patch 6.2.271 -Problem: NetBeans: Can't do "tail -f" on the log. Passing socket info with - an argument or environment variable is not secure. -Solution: Wait after initializing the log. Allow passing the socket info - through a file. (Gordon Prieur) -Files: runtime/doc/netbeans.txt, src/main.c, src/netbeans.c - -Patch 6.2.272 -Problem: When the "po" directory exists, but "po/Makefile" doesn't, - building fails. Make loops when the "po" directory has been - deleted after running configure. -Solution: Check for the "po/Makefile" instead of just the "po" directory. - Check this again before trying to run make with that Makefile. -Files: src/auto/configure, src/configure.in, src/Makefile - -Patch 6.2.273 -Problem: Changing the sort order in an explorer window for an empty - directory produces error messages. (Doug Kearns) -Solution: When an invalid range is used for a function that is not going to - be executed, skip over the arguments anyway. -Files: src/eval.c - -Patch 6.2.274 -Problem: ":print" skips empty lines when 'list' is set and there is no - "eol" in 'listchars'. (Yakov Lerner) -Solution: Skip outputting a space for an empty line only when 'list' is set - and the end-of-line character is not empty. -Files: src/message.c - -Patch 6.2.275 (extra, after 6.2.267) -Problem: Warning for uninitialized variable when using gcc. -Solution: Initialize "acLen" to zero. (Bill McCarthy) -Files: src/gui_w32.c - -Patch 6.2.276 -Problem: ":echo X()" does not put a line break between the message that X() - displays and the text that X() returns. (Yakov Lerner) -Solution: Invoke msg_start() after evaluating the argument. -Files: src/eval.c - -Patch 6.2.277 -Problem: Vim crashes when a ":runtime ftplugin/ada.vim" causes a recursive - loop. (Robert Nowotniak) -Solution: Restore "msg_list" before returning from do_cmdline(). -Files: src/ex_docmd.c - -Patch 6.2.278 -Problem: Using "much" instead of "many". -Solution: Correct the error message. -Files: src/eval.c - -Patch 6.2.279 -Problem: There is no default choice for a confirm() dialog, now that it is - possible not to have a default choice. -Solution: Make the first choice the default choice. -Files: runtime/doc/eval.txt, src/eval.c - -Patch 6.2.280 -Problem: "do" and ":diffget" don't work in the first line and the last line - of a buffer. (Aron Griffis) -Solution: Find a difference above the first line and below the last line. - Also fix a few display updating bugs. -Files: src/diff.c, src/fold.c, src/move.c - -Patch 6.2.281 -Problem: PostScript printing doesn't work on Mac OS X 10.3.2. -Solution: Adjust the header file. (Mike Williams) -Files: runtime/print/prolog.ps - -Patch 6.2.282 -Problem: When using CTRL-O to go back to a help file, it becomes listed. - (Andrew Nesbit) - Using ":tag" or ":tjump" in a help file doesn't keep the help file - settings (e.g. for 'iskeyword'). -Solution: Don't mark a buffer as listed when its help flag is set. Put all - the option settings for a help buffer together in do_ecmd(). -Files: src/ex_cmds.c - -Patch 6.2.283 -Problem: The "local additions" in help.txt are used without conversion, - causing latin1 characters showing up wrong when 'enc' is utf-8. - (Antoine J. Mechelynck) -Solution: Convert the text to 'encoding'. -Files: src/ex_cmds.c - -Patch 6.2.284 -Problem: Listing a function puts "endfunction" in the message history. - Typing "q" at the more prompt isn't handled correctly when listing - variables and functions. (Hara Krishna Dara) -Solution: Don't use msg() for "endfunction". Check "got_int" regularly. -Files: src/eval.c - -Patch 6.2.285 -Problem: GUI: In a single wrapped line that fills the window, "gj" in the - last screen line leaves the cursor behind. (Ivan Tarasov) -Solution: Undraw the cursor before scrolling the text up. -Files: src/gui.c - -Patch 6.2.286 -Problem: When trying to rename a file and it doesn't exist, the destination - file is deleted anyway. (Luc Deux) -Solution: Don't delete the destination when the source doesn't exist. (Taro - Muraoka) -Files: src/fileio.c - -Patch 6.2.287 (after 6.2.264) -Problem: Duplicate lines are added to the viminfo file. -Solution: Compare with existing entries without an offset. Also fixes - reading very long history lines from viminfo. -Files: src/ex_getln.c - -Patch 6.2.288 (extra) -Problem: Mac: An external program can't be interrupted. -Solution: Don't use the 'c' key for backspace. (Eckehard Berns) -Files: src/gui_mac.c - -Patch 6.2.289 -Problem: Compiling the Tcl interface with thread support causes ":make" to - fail. (Juergen Salk) -Solution: Use $TCL_DEFS from the Tcl config script to obtain the required - compile flags for using the thread library. -Files: src/auto/configure, src/configure.in - -Patch 6.2.290 (extra) -Problem: Mac: The mousewheel doesn't work. -Solution: Add mousewheel support. Also fix updating the thumb after a drag - and then using another way to scroll. (Eckehard Berns) -Files: src/gui_mac.c - -Patch 6.2.291 (extra) -Problem: Mac: the plus button and close button don't do anything. -Solution: Make the plus button maximize the window and the close button - close Vim. (Eckehard Berns) -Files: src/gui.c, src/gui_mac.c - -Patch 6.2.292 -Problem: Motif: When removing GUI arguments from argv[] a "ps -ef" shows - the last argument repeated. -Solution: Set argv[argc] to NULL. (Michael Jarvis) -Files: src/gui_x11.c - -Patch 6.2.293 (after 6.2.255) -Problem: GTK: A new item in a menu is put before the tearoff item. -Solution: Do increment the menu item index for non-popup menu items. -Files: src/gui_gtk.c - -Patch 6.2.294 (extra) -Problem: Mac: Cannot use modifiers with Space, Tab, Enter and Escape. -Solution: Handle all modifiers for these keys. (Eckehard Berns) -Files: src/gui_mac.c - -Patch 6.2.295 -Problem: When in debug mode, receiving a message from a remote client - causes a crash. Evaluating an expression causes Vim to wait for - "cont" to be typed, without a prompt. (Hari Krishna Dara) -Solution: Disable debugging when evaluating an expression for a client. - (Michael Geddes) Don't try reading into the typeahead buffer when - it may have been filled in another way. -Files: src/ex_getln.c, src/getchar.c, src/if_xcmdsrv.c, src/main.c, - src/misc1.c, src/proto/getchar.pro, src/proto/main.pro, - src/proto/os_unix.pro, src/proto/ui.pro, src/structs.h, - src/os_unix.c, src/ui.c - -Patch 6.2.296 (extra) -Problem: Same as 6.2.295. -Solution: Extra files for patch 6.2.295. -Files: src/os_amiga.c, src/os_msdos.c, src/os_riscos.c, src/os_win32.c, - src/proto/os_amiga.pro, src/proto/os_msdos.pro, - src/proto/os_riscos.pro, src/proto/os_win32.pro - -Patch 6.2.297 (after 6.2.232) -Problem: Cannot invoke Python commands recursively. -Solution: With Python 2.3 and later use the available mechanisms to invoke - Python recursively. (Matthew Mueller) -Files: src/if_python.c - -Patch 6.2.298 -Problem: A change always sets the '. mark and an insert always sets the '^ - mark, even when this is not wanted. - Cannot go back to the position of older changes without undoing - those changes. -Solution: Add the ":keepjumps" command modifier. - Add the "g," and "g;" commands. -Files: runtime/doc/motion.txt, src/ex_cmds.h, src/ex_docmd.c, src/edit.c, - src/mark.c, src/misc1.c, src/normal.c, src/proto/mark.pro, - src/structs.h, src/undo.c - -Patch 6.2.299 -Problem: Can only use one language for help files. -Solution: Add the 'helplang' option to select the preferred language(s). - Make ":helptags" generate tags files for all languages. -Files: runtime/doc/options.txt, runtime/doc/various.txt, src/Makefile, - src/ex_cmds.c, src/ex_cmds2.c, src/ex_cmds.h, src/ex_getln.c, - src/normal.c, src/option.c, src/option.h, src/proto/ex_cmds.pro, - src/proto/ex_cmds2.pro, src/proto/option.pro, src/structs.h, - src/tag.c, src/vim.h - -Patch 6.2.300 (after 6.2.297) -Problem: Cannot build Python interface with Python 2.2 or earlier. -Solution: Add a semicolon. -Files: src/if_python.c - -Patch 6.2.301 -Problem: The "select all" item from the popup menu doesn't work for Select - mode. -Solution: Use the same commands as for the "Edit.select all" menu. - (Benji Fisher) -Files: runtime/menu.vim - -Patch 6.2.302 -Problem: Using "CTRL-O ." in Insert mode doesn't work properly. (Benji - Fisher) -Solution: Restore "restart_edit" after an insert command that was not typed. - Avoid waiting with displaying the mode when there is no text to be - overwritten. - Fix that "CTRL-O ." sometimes doesn't put the cursor back after - the end-of-line. Only reset the flag that CTRL-O was used past - the end of the line when restarting editing. Update "o_lnum" - number when inserting text and "o_eol" is set. -Files: src/edit.c, src/normal.c - -Patch 6.2.303 -Problem: Cannot use Unicode digraphs while 'encoding' is not Unicode. -Solution: Convert the character from Unicode to 'encoding' when needed. - Use the Unicode digraphs for the Macintosh. (Eckehard Berns) -Files: src/digraph.c - -Patch 6.2.304 (extra, after 6.2.256) -Problem: Mac: No proper support for 'encoding'. Conversion without iconv() - is not possible. -Solution: Convert input from 'termencoding' to 'encoding'. Add - mac_string_convert(). Convert text for the clipboard when needed. - (Eckehard Berns) -Files: src/gui_mac.c, src/mbyte.c, src/structs.h, src/vim.h - -Patch 6.2.305 (after 6.2.300) -Problem: Win32: Cannot build Python interface with Python 2.3. (Ajit - Thakkar) -Solution: Add two functions to the dynamic loading feature. -Files: src/if_python.c - -Patch 6.2.306 (extra) -Problem: Win32: Building console version with BCC 5.5 gives a warning for - get_cmd_args() prototype missing. (Ajit Thakkar) -Solution: Don't build os_w32exe.c for the console version. -Files: src/Make_bc5.mak - -Patch 6.2.307 (after 6.2.299) -Problem: Installing help files fails. -Solution: Expand wildcards for translated help files separately. -Files: src/Makefile - -Patch 6.2.308 -Problem: Not all systems have "whoami", resulting in an empty user name. -Solution: Use "logname" when possible, "whoami" otherwise. (David Boyce) -Files: src/Makefile - -Patch 6.2.309 -Problem: "3grx" waits for two ESC to be typed. (Jens Paulus) -Solution: Append the ESC to the stuff buffer when redoing the "gr" insert. -Files: src/edit.c - -Patch 6.2.310 -Problem: When setting 'undolevels' to -1, making a change and setting - 'undolevels' to a positive value an "undo list corrupt" error - occurs. (Madoka Machitani) -Solution: Sync undo before changing 'undolevels'. -Files: src/option.c - -Patch 6.2.311 (after 6.2.298) -Problem: When making several changes in one line the changelist grows - quickly. There is no error message for reaching the end of the - changelist. Reading changelist marks from viminfo doesn't work - properly. -Solution: Only make a new entry in the changelist when making a change in - another line or 'textwidth' columns away. Add E662, E663 and E664 - error messages. Put a changelist mark from viminfo one position - before the end. -Files: runtime/doc/motion.txt, src/mark.c, src/misc1.c, src/normal.c - -Patch 6.2.312 (after 6.2.299) -Problem: "make install" clears the screen when installing the docs. -Solution: Execute ":helptags" in silent mode. -Files: runtime/doc/Makefile - -Patch 6.2.313 -Problem: When opening folds in a diff window, other diff windows no longer - show the same text. -Solution: Sync the folds in diff windows. -Files: src/diff.c, src/fold.c, src/move.c, src/proto/diff.pro, - src/proto/move.pro - -Patch 6.2.314 -Problem: When 'virtualedit' is set "rx" may cause a crash with a blockwise - selection and using "$". (Moritz Orbach) -Solution: Don't try replacing chars in a line that has no characters in the - block. -Files: src/ops.c - -Patch 6.2.315 -Problem: Using CTRL-C in a Visual mode mapping while 'insertmode' is set - stops Vim from returning to Insert mode. -Solution: Don't reset "restart_edit" when a CTRL-C is found and 'insertmode' - is set. -Files: src/normal.c - -Patch 6.2.316 (after 6.2.312) -Problem: "make install" tries connecting to the X server when installing - the docs. (Stephen Thomas) -Solution: Add the "-X" argument. -Files: runtime/doc/Makefile - -Patch 6.2.317 (after 6.2.313) -Problem: When using "zi" in a diff window, other diff windows are not - adjusted. (Richard Curnow) -Solution: Distribute a change in 'foldenable' to other diff windows. -Files: src/normal.c - -Patch 6.2.318 -Problem: When compiling with _THREAD_SAFE external commands don't echo - typed characters. -Solution: Don't set the terminal mode to TMODE_SLEEP when it's already at - TMODE_COOK. -Files: src/os_unix.c - -Patch 6.2.319 (extra) -Problem: Building gvimext.dll with Mingw doesn't work properly. -Solution: Use gcc instead of dllwrap. Use long option names. (Alejandro - Lopez-Valencia) -Files: src/GvimExt/Make_ming.mak - -Patch 6.2.320 -Problem: Win32: Adding and removing the menubar resizes the Vim window. - (Jonathon Merz) -Solution: Don't let a resize event change 'lines' unexpectedly. -Files: src/gui.c - -Patch 6.2.321 -Problem: When using modeless selection, wrapping lines are not recognized, - a line break is always inserted. -Solution: Add LineWraps[] to remember whether a line wrapped or not. -Files: src/globals.h, src/screen.c, src/ui.c - -Patch 6.2.322 -Problem: With 'showcmd' set, after typing "dd" the next "d" may not be - displayed. (Jens Paulus) -Solution: Redraw the command line after updating the screen, scrolling may - have set "clear_cmdline". -Files: src/screen.c - -Patch 6.2.323 -Problem: Win32: expanding "~/file" in an autocommand pattern results in - backslashes, while this pattern should only have forward slashes. -Solution: Make expanding environment variables respect 'shellslash' and set - p_ssl when expanding the autocommand pattern. -Files: src/fileio.c, src/misc1.c, src/proto/fileio.pro - -Patch 6.2.324 (extra) -Problem: Win32: when "vimrun.exe" has a path with white space, such as - "Program Files", executing external commands may fail. -Solution: Put double quotes around the path to "vimrun". -Files: src/os_win32.c - -Patch 6.2.325 -Problem: When $HOME includes a space, doing ":set tags=~/tags" doesn't - work, the space is used to separate file names. (Brett Stahlman) -Solution: Escape the space with a backslash. -Files: src/option.c - -Patch 6.2.326 -Problem: ":windo set syntax=foo" doesn't work. (Tim Chase) -Solution: Don't change 'eventignore' for ":windo". -Files: src/ex_cmds2.c - -Patch 6.2.327 -Problem: When formatting text all marks in the formatted lines are lost. - A word is not joined to a previous line when this would be - possible. (Mikolaj Machowski) -Solution: Try to keep marks in the same position as much as possible. - Also keep mark positions when joining lines. - Start auto-formatting in the previous line when appropriate. - Add the "gw" operator: Like "gq" but keep the cursor where it is. -Files: runtime/doc/change.txt, src/edit.c, src/globals.h, src/mark.c, - src/misc1.c, src/normal.c, src/ops.c, src/proto/edit.pro, - src/proto/mark.pro, src/proto/ops.pro, src/structs.h, src/vim.h - -Patch 6.2.328 -Problem: XIM with GTK: It is hard to understand what XIM is doing. -Solution: Add xim_log() to log XIM events and help with debugging. -Files: src/mbyte.c - -Patch 6.2.329 -Problem: ":=" does not work Vi compatible. (Antony Scriven) -Solution: Print the last line number instead of the current line. Don't - print "line". -Files: src/ex_cmds.h, src/ex_docmd.c - -Patch 6.2.330 (extra, after 6.2.267) -Problem: Win32: Crash when tearing off a menu. -Solution: Terminate a string with a NUL. (Yasuhiro Matsumoto) -Files: src/gui_w32.c - -Patch 6.2.331 (after 6.2.327) -Problem: "gwap" leaves cursor in the wrong line. -Solution: Remember the cursor position before finding the ends of the - paragraph. -Files: src/normal.c, src/ops.c, src/structs.h - -Patch 6.2.332 (extra) -Problem: Amiga: Compile error for string array. Compiling the Amiga GUI - doesn't work. -Solution: Use a char pointer instead. Move including "gui_amiga.h" to after - including "vim.h". Add a semicolon. (Ali Akcaagac) -Files: src/gui_amiga.c, src/os_amiga.c - -Patch 6.2.333 (extra) -Problem: Win32: printing doesn't work with specified font charset. -Solution: Use the specified font charset. (Mike Williams) -Files: src/os_mswin.c - -Patch 6.2.334 (extra, after 6.2.296) -Problem: Win32: evaluating client expression in debug mode requires typing - "cont". -Solution: Use eval_client_expr_to_string(). -Files: src/os_mswin.c - -Patch 6.2.335 -Problem: The ":sign" command cannot be followed by another command. -Solution: Add TRLBAR to the command flags. -Files: src/ex_cmds.h - -Patch 6.2.336 (after 6.2.327) -Problem: Mixup of items in an expression. -Solution: Move "== NUL" to the right spot. -Files: src/edit.c - -Patch 6.2.337 (extra, after 6.2.319) -Problem: Building gvimext.dll with Mingw doesn't work properly. -Solution: Fix white space and other details. (Alejandro Lopez-Valencia) -Files: src/GvimExt/Make_ming.mak - -Patch 6.2.338 (after 6.2.331) -Problem: When undoing "gwap" the cursor is always put at the start of the - paragraph. When undoing auto-formatting the cursor may be above - the change. -Solution: Try to move the cursor back to where it was or to the first line - that actually changed. -Files: src/normal.c, src/ops.c, src/undo.c - -Patch 6.2.339 -Problem: Crash when using many different highlight groups and a User - highlight group. (Juergen Kraemer) -Solution: Do not use the sg_name_u pointer when it is NULL. Also simplify - use of the highlight group table. -Files: src/syntax.c - -Patch 6.2.340 -Problem: ":reg" doesn't show the actual contents of the clipboard if it was - filled outside of Vim. (Stuart MacDonald) -Solution: Obtain the clipboard contents before displaying it. -Files: src/ops.c - -Patch 6.2.341 (extra) -Problem: Win32: When the path to diff.exe contains a space and using the - vimrc generated by the install program, diff mode does not work. -Solution: Put the first double quote just before the space instead of before - the path. -Files: src/dosinst.c - -Patch 6.2.342 (extra) -Problem: Win32: macros are not always used as expected. -Solution: Define WINVER to 0x0400 instead of 0x400. (Alejandro - Lopez-Valencia) -Files: src/Make_bc5.mak, src/Make_cyg.mak, src/Make_mvc.mak - -Patch 6.2.343 -Problem: Title doesn't work with some window managers. X11: Setting the - text property for the window title is hard coded. -Solution: Use STRING format when possible. Use the UTF-8 function when - it's available and 'encoding' is utf-8. Use - XStringListToTextProperty(). Do the same for the icon name. - (David Harrison) -Files: src/os_unix.c - -Patch 6.2.344 (extra, after 6.2.337) -Problem: Cannot build gvimext.dll with MingW on Linux. -Solution: Add support for cross compiling. (Ronald Hoellwarth) -Files: src/GvimExt/Make_ming.mak - -Patch 6.2.345 (extra) -Problem: Win32: Copy/paste between two Vims fails if 'encoding' is not set - properly or there are illegal bytes. -Solution: Use a raw byte format. Always set it when copying. When pasting - use the raw format if 'encoding' is the same. -Files: src/os_mswin.c, src/os_win16.c, src/os_win32.c, src/vim.h - -Patch 6.2.346 -Problem: Win32 console: After using "chcp" Vim does not detect the - different codepage. -Solution: Use GetConsoleCP() and when it is different from GetACP() set - 'termencoding'. -Files: src/option.c - -Patch 6.2.347 (extra) -Problem: Win32: XP theme support is missing. -Solution: Add a manifest and refer to it from the resource file. (Michael - Wookey) -Files: Makefile, src/gvim.exe.mnf, src/vim.rc - -Patch 6.2.348 -Problem: Win32: "vim c:\dir\(test)" doesn't work, because the 'isfname' - default value doesn't contain parenthesis. -Solution: Temporarily add '(' and ')' to 'isfname' when expanding file name - arguments. -Files: src/main.c - -Patch 6.2.349 -Problem: Finding a match using 'matchpairs' may cause a crash. - 'matchpairs' is not used for 'showmatch'. -Solution: Don't look past the NUL in 'matchpairs'. Use 'matchpairs' for - 'showmatch'. (Dave Olszewkski) -Files: src/misc1.c, src/normal.c, src/proto/search.pro, src/search.c - -Patch 6.2.350 -Problem: Not enough info about startup timing. -Solution: Add a few more TIME_MSG() calls. -Files: src/main.c - -Patch 6.2.351 -Problem: Win32: $HOME may be set to %USERPROFILE%. -Solution: Expand %VAR% at the start of $HOME. -Files: src/misc1.c - -Patch 6.2.352 (after 6.2.335) -Problem: ":sign texthl=||" does not work. -Solution: Remove the check for a following command. Give an error for extra - arguments after "buff=1". -Files: src/ex_cmds.c, src/ex_cmds.h - -Patch 6.2.353 (extra) -Problem: Win32: Supported server name length is limited. (Paul Bossi) -Solution: Use MAX_PATH instead of 25. -Files: src/os_mswin.c - -Patch 6.2.354 (extra) -Problem: Win32: When the mouse pointer is on a tear-off menu it is hidden - when typing but is not redisplayed when moved. (Markx Hackmann) -Solution: Handle the pointer move event for the tear-off menu window. -Files: src/gui_w32.c - -Patch 6.2.355 (after 6.2.303) -Problem: When 'encoding' is a double-byte encoding different from the - current locale, the width of characters is not correct. - Possible failure and memory leak when using iconv, Unicode - digraphs and 'encoding' is not "utf-8". -Solution: Use iconv() to discover the actual width of characters. - Add the "vc_fail" field to vimconv_T. - When converting a digraph, init the conversion type to NONE and - cleanup afterwards. -Files: src/digraph.c, src/mbyte.c, src/structs.h - -Patch 6.2.356 -Problem: When using a double-byte 'encoding' and 'selection' is - "exclusive", "vy" only yanks the first byte of a double-byte - character. (Xiangjiang Ma) -Solution: Correct the column in unadjust_for_sel() to position on the first - byte, always include the trailing byte of the selected text. -Files: src/normal.c - -Patch 6.2.357 (after 6.2.321) -Problem: Memory leak when resizing the Vim window. -Solution: Free the LineWraps array. -Files: src/screen.c - -Patch 6.2.358 (after 6.2.299) -Problem: Memory leak when using ":help" and the language doesn't match. -Solution: Free the array with matching tags. -Files: src/ex_cmds.c - -Patch 6.2.359 (after 6.2.352) -Problem: Compiler warning for long to int type cast. -Solution: Add explicit type cast. -Files: src/ex_cmds.c - -Patch 6.2.360 -Problem: "100|" in an empty line results in a ruler "1,0-100". (Pavol - Juhas) -Solution: Recompute w_virtcol if the target column was not reached. -Files: src/misc2.c - -Patch 6.2.361 (extra) -Problem: Win32: Run gvim, ":set go-=m", use Alt-Tab, keep Alt pressed while - pressing Esc, then release Alt: Cursor disappears and typing a key - causes a beep. (Hari Krishna Dara) -Solution: Don't ignore the WM_SYSKEYUP event when the menu is disabled. -Files: src/gui_w32.c - -Patch 6.2.362 (extra, after 6.2.347) -Problem: Win32: The manifest causes Gvim not to work. (Dave Roberts) -Solution: Change "x86" to "X86". (Serge Pirotte) -Files: src/gvim.exe.mnf - -Patch 6.2.363 -Problem: In an empty file with 'showmode' off, "i" doesn't change the ruler - from "0-1" to "1". Typing "x<BS>" does show "1", but then <Esc> - doesn't make it "0-1" again. Same problem for ruler in - statusline. (Andrew Pimlott) -Solution: Remember the "empty line" flag with Insert mode and'ed to it. -Files: src/screen.c - -Patch 6.2.364 -Problem: HTML version of the documentation doesn't mention the encoding, - which is a problem for mbyte.txt. -Solution: Adjust the awk script. (Ilya Sher) -Files: runtime/doc/makehtml.awk - -Patch 6.2.365 -Problem: The configure checks for Perl and Python may add compile and link - arguments that break building Vim. -Solution: Do a sanity check: try building with the arguments. -Files: src/auto/configure, src/configure.in - -Patch 6.2.366 -Problem: When the GUI can't start because no valid font is found, there is - no error message. (Ugen) -Solution: Add an error message. -Files: src/gui.c - -Patch 6.2.367 -Problem: Building the help tags file while installing may fail if there is - another Vim in $PATH. -Solution: Specify the just installed Vim executable. (Gordon Prieur) -Files: src/Makefile - -Patch 6.2.368 -Problem: When 'autochdir' is set, closing a window doesn't change to the - directory of the new current window. (Salman Halim) -Solution: Handle 'autochdir' always when a window becomes the current one. -Files: src/window.c - -Patch 6.2.369 -Problem: Various memory leaks: when using globpath(), when searching for - help tags files, when defining a function inside a function, when - giving an error message through an exception, for the final "." - line in ":append", in expression "cond ? a : b" that fails and for - missing ")" in an expression. Using NULL pointer when adding - first user command and for pointer computations with regexp. - (tests by Dominique Pelle) -Solution: Fix the leaks by freeing the allocated memory. Don't use the - array of user commands when there are no entries. Use a macro - instead of a function call for saving and restoring regexp states. -Files: src/eval.c, src/ex_cmds.c, src/ex_docmd.c, src/ex_getln.c, - src/misc2.c, src/regexp.c, src/screen.c, src/tag.c - -Patch 6.2.370 (extra, after6.2.341) -Problem: Win32: When the path to diff.exe contains a space and using the - vimrc generated by the install program, diff mode may not work. - (Alejandro Lopez-Valencia) -Solution: Do not use double quotes for arguments that do not have a space. -Files: src/dosinst.c - -Patch 6.2.371 -Problem: When 'virtualedit' is set and there is a Tab before the next "x", - "dtx" does not delete the whole Tab. (Ken Hashishi) -Solution: Move the cursor to the last position of the Tab. Also for - "df<Tab>". -Files: src/normal.c - -Patch 6.2.372 -Problem: When using balloon evaluation, no value is displayed for members - of structures and items of an array. -Solution: Include "->", "." and "[*]" in the expression. -Files: src/gui_beval.c, src/normal.c, src/vim.h - -Patch 6.2.373 -Problem: When 'winminheight' is zero and a window is reduced to zero - height, the ruler always says "Top" instead of the cursor - position. (Antoine J. Mechelynck) -Solution: Don't recompute w_topline for a zero-height window. -Files: src/window.c - -Patch 6.2.374 -Problem: ":echo "hello" | silent normal n" removes the "hello" message. - (Servatius Brandt) -Solution: Don't echo the search string when ":silent" was used. Also don't - show the mode. In general: don't clear to the end of the screen. -Files: src/gui.c, src/message.c, src/os_unix.c, src/proto/message.pro, - src/screen.c, src/search.c, src/window.c - -Patch 6.2.375 -Problem: When changing 'guioptions' the hit-enter prompt may be below the - end of the Vim window. -Solution: Call screen_alloc() before showing the prompt. -Files: src/message.c - -Patch 6.2.376 -Problem: Win32: Ruby interface cannot be dynamically linked with Ruby 1.6. -Solution: Add #ifdefs around use of rb_w32_snprintf(). (Benoît Cerrina) -Files: src/if_ruby.c - -Patch 6.2.377 (after 6.2.372) -Problem: Compiler warnings for signed/unsigned compare. (Michael Wookey) -Solution: Add type cast. -Files: src/normal.c - -Patch 6.2.378 (extra, after 6.2.118) -Problem: Mac: cannot build with Project Builder. -Solution: Add remove_tail_with_ext() to locate and remove the "build" - directory from the runtime path. Include os_unix.c when needed. - (Dany St Amant) -Files: src/misc1.c, src/os_macosx.c, src/vim.h - -Patch 6.2.379 -Problem: Using ":mkvimrc" in the ":options" window sets 'bufhidden' to - "delete". (Michael Naumann) -Solution: Do not add buffer-specific option values to a global vimrc file. -Files: src/option.c - -Patch 6.2.380 (extra) -Problem: DOS: "make test" fails when running it again. Can't "make test" - with Borland C. -Solution: Make sure ".out" files are deleted when they get in the way. Add - a "test" target to the Borland C Makefile. -Files: src/Make_bc5.mak, src/testdir/Make_dos.mak - -Patch 6.2.381 -Problem: Setting 'fileencoding' to a comma separated list (confusing it - with 'fileencodings') does not result in an error message. - Setting 'fileencoding' in an empty file marks it as modified. - There is no "+" in the title after setting 'fileencoding'. -Solution: Check for a comma in 'fileencoding'. Only consider a non-empty - file modified by changing 'fileencoding'. Update the title after - changing 'fileencoding'. -Files: src/option.c - -Patch 6.2.382 -Problem: Running "make test" puts marks from test files in viminfo. -Solution: Specify a different viminfo file to use. -Files: src/testdir/test15.in, src/testdir/test49.in - -Patch 6.2.383 -Problem: ":hi foo term='bla" crashes Vim. (Antony Scriven) -Solution: Check that the closing ' is there. -Files: src/syntax.c - -Patch 6.2.384 -Problem: ":menu a.&b" ":unmenu a.b" only works if "&b" isn't translated. -Solution: Also compare the names without '&' characters. -Files: src/menu.c - -Patch 6.2.385 (extra) -Problem: Win32: forward_slash() and trash_input_buf() are undefined when - compiling with small features. (Ajit Thakkar) -Solution: Change the #ifdefs for forward_slash(). Don't call - trash_input_buf() if the input buffer isn't used. -Files: src/fileio.c, src/os_win32.c - -Patch 6.2.386 -Problem: Wasting time trying to read marks from the viminfo file for a - buffer without a name. -Solution: Skip reading marks when the buffer has no name. -Files: src/fileio.c - -Patch 6.2.387 -Problem: There is no highlighting of translated items in help files. -Solution: Search for a "help_ab.vim" syntax file when the help file is - called "*.abx". Also improve the help highlighting a bit. -Files: runtime/syntax/help.vim - -Patch 6.2.388 -Problem: GTK: When displaying some double-width characters they are drawn - as single-width, because of conversion to UTF-8. -Solution: Check the width that GTK uses and add a space if it's one instead - of two. -Files: src/gui_gtk_x11.c - -Patch 6.2.389 -Problem: When working over a slow connection, it's very annoying that the - last line is partly drawn and then cleared for every change. -Solution: Don't redraw the bottom line if no rows were inserted or deleted. - Don't draw the line if we know "@" lines will be used. -Files: src/screen.c - -Patch 6.2.390 -Problem: Using "r*" in Visual mode on multi-byte characters only replaces - every other character. (Tyson Roberts) -Solution: Correct the cursor position after replacing each character. -Files: src/ops.c - -Patch 6.2.391 (extra) -Problem: The ":highlight" command is not tested. -Solution: Add a test script for ":highlight". -Files: src/testdir/Makefile, src/testdir/Make_amiga.mak, - src/testdir/Make_dos.mak, src/testdir/Make_os2.mak, - src/testdir/Make_vms.mms, src/testdir/test51.in, - src/testdir/test51.ok - -Patch 6.2.392 (after 6.2.384) -Problem: Unused variable. -Solution: Remove "dlen". -Files: src/menu.c - -Patch 6.2.393 -Problem: When using very long lines the viminfo file can become very big. -Solution: Add the "s" flag to 'viminfo': skip registers with more than the - specified Kbyte of text. -Files: runtime/doc/options.txt, src/ops.c, src/option.c - -Patch 6.2.394 (after 6.2.391) -Problem: Test 51 fails on a terminal with 8 colors. (Tony Leneis) -Solution: Use "DarkBlue" instead of "Blue" to avoid the "bold" attribute. -Files: src/testdir/test51.in - -Patch 6.2.395 -Problem: When using ":tag" or ":pop" the previous matching tag is used. - But since the current file is different, the ordering of the tags - may change. -Solution: Remember what the current buffer was for when re-using cur_match. -Files: src/edit.c, src/ex_cmds.c, src/proto/tag.pro, src/structs.h, - src/tag.c - -Patch 6.2.396 -Problem: When CTRL-T jumps to another file and an autocommand moves the - cursor to the '" mark, don't end up on the right line. (Michal - Malecki) -Solution: Set the line number after loading the file. -Files: src/tag.c - -Patch 6.2.397 -Problem: When using a double-byte 'encoding' mapping <M-x> doesn't work. - (Yasuhiro Matsumoto) -Solution: Do not set the 8th bit of the character but use a modifier. -Files: src/gui_gtk_x11.c, src/gui_x11.c, src/misc2.c - -Patch 6.2.398 (extra) -Problem: Win32 console: no extra key modifiers are supported. -Solution: Encode the modifiers into the input stream. Also fix that special - keys are converted and stop working when 'tenc' is set. Also fix - that when 'tenc' is initialized the input and output conversion is - not setup properly until 'enc' or 'tenc' is set. -Files: src/getchar.c, src/option.c, src/os_win32.c - -Patch 6.2.399 -Problem: A ":set" command that fails still writes a message when it is - inside a try/catch block. -Solution: Include all the text of the message in the error message. -Files: src/charset.c, src/option.c - -Patch 6.2.400 -Problem: Can't compile if_xcmdsrv.c on HP-UX 11.0. -Solution: Include header file poll.h. (Malte Neumann) -Files: src/if_xcmdsrv.c - -Patch 6.2.401 -Problem: When opening a buffer that was previously opened, Vim does not - restore the cursor position if the first line starts with white - space. (Gregory Margo) -Solution: Don't skip restoring the cursor position if it is past the blanks - in the first line. -Files: src/buffer.c - -Patch 6.2.402 -Problem: Mac: "make install" doesn't generate help tags. (Benji Fisher) -Solution: Generate help tags before copying the runtime files. -Files: src/Makefile - -Patch 6.2.403 -Problem: ":@y" checks stdin if there are more commands to execute. This - fails if stdin is not connected, e.g., when starting the GUI from - KDE. (Ned Konz) -Solution: Only check for a next command if there still is typeahead. -Files: src/ex_docmd.c - -Patch 6.2.404 -Problem: Our own function to determine width of Unicode characters may get - outdated. (Markus Kuhn) -Solution: Use wcwidth() when it is available. Also use iswprint(). -Files: src/auto/configure, src/configure.in, src/config.h.in, src/mbyte.c - -Patch 6.2.405 -Problem: Cannot map zero without breaking the count before a command. - (Benji Fisher) -Solution: Disable mapping zero when entering a count. -Files: src/getchar.c, src/globals.h, src/normal.c - -Patch 6.2.406 -Problem: ":help \zs", ":help \@=" and similar don't find useful help. -Solution: Prepend "/\" to the arguments to find the desired help tag. -Files: src/ex_cmds.c - -Patch 6.2.407 (after 6.2.299) -Problem: ":help \@<=" doesn't find help. -Solution: Avoid that ":help \@<=" searches for the "<=" language. -Files: src/tag.c - -Patch 6.2.408 -Problem: ":compiler" is not consistent: Sets local options and a global - variable. (Douglas Potts) There is no error message when a - compiler is not supported. -Solution: Use ":compiler!" to set a compiler globally, otherwise it's local - to the buffer and "b:current_compiler" is used. Give an error - when no compiler script could be found. - Note: updated compiler plugins can be found at - ftp://ftp.vim.org/pub/vim/runtime/compiler/ -Files: runtime/compiler/msvc.vim, runtime/doc/quickfix.txt, src/eval.c, - src/ex_cmds2.c - -Patch 6.2.409 -Problem: The cursor ends up in the last column instead of after the line - when doing "i//<Esc>o" with 'indentexpr' set to "cindent(v:lnum)". - (Toby Allsopp) -Solution: Adjust the cursor as if in Insert mode. -Files: src/misc1.c - -Patch 6.2.410 (after 6.2.389) -Problem: In diff mode, when there are more filler lines than fit in the - window, they are not drawn. -Solution: Check for filler lines when skipping to draw a line that doesn't - fit. -Files: src/screen.c - -Patch 6.2.411 -Problem: A "\n" inside a string is not seen as a line break by the regular - expression matching. (Hari Krishna Dara) -Solution: Add the vim_regexec_nl() function for strings where "\n" is to be - matched with a line break. -Files: src/eval.c, src/ex_eval.c, src/proto/regexp.c, src/regexp.c - -Patch 6.2.412 -Problem: Ruby: "ruby << EOF" inside a function doesn't always work. Also - for ":python", ":tcl" and ":perl". -Solution: Check for "<< marker" and skip until "marker" before checking for - "endfunction". -Files: src/eval.c - -Patch 6.2.413 (after 6.2.411) -Problem: Missing prototype for vim_regexec_nl(). (Marcel Svitalsky) -Solution: Now really include the prototype. -Files: src/proto/regexp.pro - -Patch 6.2.414 -Problem: The function used for custom completion of user commands cannot - have <SID> to make it local. (Hari Krishna Dara) -Solution: Pass the SID of the script where the user command was defined on - to the completion. Also clean up #ifdefs. -Files: src/ex_docmd.c, src/eval.c, src/ex_getln.c, src/structs.h - -Patch 6.2.415 -Problem: Vim may crash after a sequence of events that change the window - size. The window layout assumes a larger window than is actually - available. (Servatius Brandt) -Solution: Invoke win_new_shellsize() from screenalloc() instead of from - set_shellsize(). -Files: src/screen.c, src/term.c - -Patch 6.2.416 -Problem: Compiler warning for incompatible pointer. -Solution: Remove the "&" in the call to poll(). (Xavier de Gaye) -Files: src/os_unix.c - -Patch 6.2.417 (after 6.2.393) -Problem: Many people forget that the '"' item in 'viminfo' needs to be - preceded with a backslash, -Solution: Add '<' as an alias for the '"' item. -Files: runtime/doc/options.txt, src/ops.c, src/option.c - -Patch 6.2.418 -Problem: Using ":nnoremap <F12> :echo "cheese" and ":cabbr cheese xxx": - when pressing <F12> still uses the abbreviation. (Hari Krishna) -Solution: Also apply "noremap" to abbreviations. -Files: src/getchar.c - -Patch 6.2.419 (extra) -Problem: Win32: Cannot open the Vim window inside another application. -Solution: Add the "-P" argument to specify the window title of the - application to run inside. (Zibo Zhao) -Files: runtime/doc/starting.txt, src/main.c, src/gui_w32.c, - src/gui_w48.c, src/if_ole.cpp, src/os_mswin.c, - src/proto/gui_w32.pro - -Patch 6.2.420 -Problem: Cannot specify a file to be edited in binary mode without setting - the global value of the 'binary' option. -Solution: Support ":edit ++bin file". -Files: runtime/doc/editing.txt, src/buffer.c, src/eval.c, src/ex_cmds.h, - src/ex_docmd.c, src/fileio.c, src/misc2.c - -Patch 6.2.421 -Problem: Cannot set the '[ and '] mark, which may be necessary when an - autocommand simulates reading a file. -Solution: Allow using "m[" and "m]". -Files: runtime/doc/motion.txt, src/mark.c - -Patch 6.2.422 -Problem: In CTRL-X completion messages the "/" makes them less readable. -Solution: Remove the slashes. (Antony Scriven) -Files: src/edit.c - -Patch 6.2.423 -Problem: ":vertical wincmd ]" does not split vertically. -Solution: Add "postponed_split_flags". -Files: src/ex_docmd.c, src/globals.h, src/if_cscope.c, src/tag.c - -Patch 6.2.424 -Problem: A BufEnter autocommand that sets an option stops 'mousefocus' from - working in Insert mode (Normal mode is OK). (Gregory Seidman) -Solution: In the Insert mode loop invoke gui_mouse_correct() when needed. -Files: src/edit.c - -Patch 6.2.425 -Problem: Vertical split and command line window: can only drag status line - above the cmdline window on the righthand side, not lefthand side. -Solution: Check the status line row instead of the window pointer. -Files: src/ui.c - -Patch 6.2.426 -Problem: A syntax region end match with a matchgroup that includes a line - break only highlights the last line with matchgroup. (Gary - Holloway) -Solution: Also use the line number of the position where the region - highlighting ends. -Files: src/syntax.c - -Patch 6.2.427 (extra) -Problem: When pasting a lot of text in a multi-byte encoding, conversion - from 'termencoding' to 'encoding' may fail for some characters. - (Kuang-che Wu) -Solution: When there is an incomplete byte sequence at the end of the read - text keep it for the next time. -Files: src/mbyte.c, src/os_amiga.c, src/os_mswin.c, src/proto/mbyte.pro, - src/proto/os_mswin.pro, src/ui.c - -Patch 6.2.428 -Problem: The X11 clipboard supports the Vim selection for char/line/block - mode, but since the encoding is not included can't copy/paste - between two Vims with a different 'encoding'. -Solution: Add a new selection format that includes the 'encoding'. Perform - conversion when necessary. -Files: src/gui_gtk_x11.c, src/ui.c, src/vim.h - -Patch 6.2.429 -Problem: Unix: glob() doesn't work for a directory with a single quote in - the name. (Nazri Ramliy) -Solution: When using the shell to expand, only put double quotes around - spaces and single quotes, not the whole thing. -Files: src/os_unix.c - -Patch 6.2.430 -Problem: BOM at start of a vim script file is not recognized and causes an - error message. -Solution: Detect the BOM and skip over it. Also fix that after using - ":scriptencoding" the iconv() file descriptor was not closed - (memory leak). -Files: src/ex_cmds2.c - -Patch 6.2.431 -Problem: When using the horizontal scrollbar, the scrolling is limited to - the length of the cursor line. -Solution: Make the scroll limit depend on the longest visible line. The - cursor is moved when necessary. Including the 'h' flag in - 'guioptions' disables this. -Files: runtime/doc/gui.txt, runtime/doc/options.txt, src/gui.c, - src/misc2.c, src/option.h - -Patch 6.2.432 (after 6.2.430 and 6.2.431) -Problem: Lint warnings. -Solution: Add type casts. -Files: src/ex_cmds2.c, src/gui.c - -Patch 6.2.433 -Problem: Translating "VISUAL" and "BLOCK" separately doesn't give a good - result. (Alejandro Lopez Valencia) -Solution: Use a string for each combination. -Files: src/screen.c - -Patch 6.2.434 (after 6.2.431) -Problem: Compiler warning. (Salman Halim) -Solution: Add type casts. -Files: src/gui.c - -Patch 6.2.435 -Problem: When there are vertically split windows the minimal Vim window - height is computed wrong. -Solution: Use frame_minheight() to correctly compute the minimal height. -Files: src/window.c - -Patch 6.2.436 -Problem: Running the tests changes the user's viminfo file. -Solution: In test 49 tell the extra Vim to use the test viminfo file. -Files: src/testdir/test49.vim - -Patch 6.2.437 -Problem: ":mksession" always puts "set nocompatible" in the session file. - This changes option settings. (Ron Aaron) -Solution: Add an "if" to only change 'compatible' when needed. -Files: src/ex_docmd.c - -Patch 6.2.438 -Problem: When the 'v' flag is present in 'cpoptions', backspacing and then - typing text again: one character too much is overtyped before - inserting is done again. -Solution: Set "dollar_vcol" to the right column. -Files: src/edit.c - -Patch 6.2.439 -Problem: GTK 2: Changing 'lines' may cause a mismatch between the window - layout and the size of the window. -Solution: Disable the hack with force_shell_resize_idle(). -Files: src/gui_gtk_x11.c - -Patch 6.2.440 -Problem: When 'lazyredraw' is set the window title is still updated. - The size of the Visual area and the ruler are displayed too often. -Solution: Postpone redrawing the window title. Only show the Visual area - size when waiting for a character. Don't draw the ruler - unnecessary. -Files: src/buffer.c, src/normal.c, src/screen.c - -Patch 6.2.441 -Problem: ":unabbreviate foo " doesn't work, because of the trailing space, - while an abbreviation with a trailing space is not possible. (Paul - Jolly) -Solution: Accept a match with the lhs of an abbreviation without the - trailing space. -Files: src/getchar.c - -Patch 6.2.442 -Problem: Cannot manipulate the command line from a function. -Solution: Add getcmdline(), getcmdpos() and setcmdpos() functions and the - CTRL-\ e command. -Files: runtime/doc/cmdline.txt, runtime/doc/eval.txt, src/eval.c - src/ex_getln.c, src/ops.c, src/proto/ex_getln.pro, - src/proto/ops.pro - -Patch 6.2.443 -Problem: With ":silent! echoerr something" you don't get the position of - the error. emsg() only writes the message itself and returns. -Solution: Also redirect the position of the error. -Files: src/message.c - -Patch 6.2.444 -Problem: When adding the 'c' flag to a ":substitute" command it may replace - more times than without the 'c' flag. Happens for a match that - starts with "\ze" (Marcel Svitalsk) and when using "\@<=" (Klaus - Bosau). -Solution: Correct "prev_matchcol" when replacing the line. Don't replace - the line when the pattern uses look-behind matching. -Files: src/ex_cmds.c, src/proto/regexp.pro, src/regexp.c - -Patch 6.2.445 -Problem: Copying vimtutor to /tmp/something is not secure, a symlink may - cause trouble. -Solution: Create a directory and create the file in it. Use "umask" to - create the directory with mode 700. (Stefan Nordhausen) -Files: src/vimtutor - -Patch 6.2.446 (after 6.2.404) -Problem: Using library functions wcwidth() and iswprint() results in - display problems for Hebrew characters. (Ron Aaron) -Solution: Disable the code to use the library functions, use our own. -Files: src/mbyte.c - -Patch 6.2.447 (after 6.2.440) -Problem: Now that the title is only updated when redrawing, it is no longer - possible to show it while executing a function. (Madoka Machitani) -Solution: Make ":redraw" also update the title. -Files: src/ex_docmd.c - -Patch 6.2.448 (after 6.2.427) -Problem: Mac: conversion done when 'termencoding' differs from 'encoding' - fails when pasting a longer text. -Solution: Check for an incomplete sequence at the end of the chunk to be - converted. (Eckehard Berns) -Files: src/mbyte.c - -Patch 6.2.449 (after 6.2.431) -Problem: Get error messages when switching files. -Solution: Check for a valid line number when calculating the width of the - horizontal scrollbar. (Helmut Stiegler) -Files: src/gui.c - -Patch 6.2.450 -Problem: " #include" and " #define" are not recognized with the default - option values for 'include' and 'defined'. (RG Kiran) -Solution: Adjust the default values to allow white space before the #. -Files: runtime/doc/options.txt, src/option.c - -Patch 6.2.451 -Problem: GTK: when using XIM there are various problems, including setting - 'modified' and breaking undo at the wrong moment. -Solution: Add "xim_changed_while_preediting", "preedit_end_col" and - im_is_preediting(). (Yasuhiro Matsumoto) -Files: src/ex_getln.c, src/globals.h, src/gui_gtk.c, src/gui_gtk_x11.c, - src/mbyte.c, src/misc1.c, src/proto/mbyte.pro, src/screen.c, - src/undo.c - -Patch 6.2.452 -Problem: In diff mode, when DiffAdd and DiffText highlight settings are - equal, an added line is highlighted with DiffChange. (Tom Schumm) -Solution: Remember the diff highlight type instead of the attributes. -Files: src/screen.c - -Patch 6.2.453 -Problem: ":s/foo\|\nbar/x/g" does not replace two times in "foo\nbar". - (Pavel Papushev) -Solution: When the pattern can match a line break also try matching at the - NUL at the end of a line. -Files: src/ex_cmds.c, src/regexp.c - -Patch 6.2.454 -Problem: ":let b:changedtick" doesn't work. (Alan Schmitt) ":let - b:changedtick = 99" does not give an error message. -Solution: Add code to recognize ":let b:changedtick". -Files: src/eval.c - -Patch 6.2.455 (after 6.2.297) -Problem: In Python commands the current locale changes how certain Python - functions work. (Eugene M. Minkovskii) -Solution: Set the LC_NUMERIC locale to "C" while executing a Python command. -Files: src/if_python.c - -Patch 6.2.456 (extra) -Problem: Win32: Editing a file by its Unicode name (dropping it on Vim or - using the file selection dialog) doesn't work. (Yakov Lerner, Alex - Jakushev) -Solution: Use wide character functions when file names are involved and - convert from/to 'encoding' where needed. -Files: src/gui_w48.c, src/macros.h, src/memfile.c, src/memline.c, - src/os_mswin.c, src/os_win32.c - -Patch 6.2.457 (after 6.2.244) -Problem: When 'encoding' is "utf-8" and writing text with chars above 0x80 - in latin1, conversion is wrong every 8200 bytes. (Oyvind Holm) -Solution: Correct the utf_ptr2len_check_len() function and fix the problem - of displaying 0xf7 in utfc_ptr2len_check_len(). -Files: src/mbyte.c - -Patch 6.2.458 -Problem: When 'virtualedit' is set "$" doesn't move to the end of an - unprintable character, causing "y$" not to include that character. - (Fred Ma) -Solution: Set "coladd" to move the cursor to the end of the character. -Files: src/misc2.c - -Patch 6.2.459 (after 6.2.454) -Problem: Variable "b" cannot be written. (Salman Halim) -Solution: Compare strings properly. -Files: src/eval.c - -Patch 6.2.460 (extra, after 6.2.456) -Problem: Compiler warnings for missing prototypes. -Solution: Include the missing prototypes. -Files: src/proto/os_win32.pro - -Patch 6.2.461 -Problem: After using a search command "x" starts putting single characters - in the numbered registers. -Solution: Reset "use_reg_one" at the right moment. -Files: src/normal.c - -Patch 6.2.462 -Problem: Finding a matching parenthesis does not correctly handle a - backslash in a trailing byte. -Solution: Handle multi-byte characters correctly. (Taro Muraoka) -Files: src/search.c - -Patch 6.2.463 (extra) -Problem: Win32: An NTFS file system may contain files with extra info - streams. The current method to copy them creates one and then - deletes it again. (Peter Toennies) Also, only three streams with - hard coded names are copied. -Solution: Use BackupRead() to check which info streams the original file - contains and only copy these streams. -Files: src/os_win32.c - -Patch 6.2.464 (extra, after 6.2.427) -Problem: Amiga: Compilation error with gcc. (Ali Akcaagac) -Solution: Move the #ifdef outside of Read(). -Files: src/os_amiga.c - -Patch 6.2.465 -Problem: When resizing the GUI window the window manager sometimes moves it - left of or above the screen. (Michael McCarty) -Solution: Check the window position after resizing it and move it onto the - screen when it isn't. -Files: src/gui.c - -Patch 6.2.466 (extra, after 6.2.456) -Problem: Win32: Compiling with Borland C fails, and an un/signed warning. -Solution: Redefine wcsicmp() to wcscmpi() and add type casts. (Yasuhiro - Matsumoto) -Files: src/os_win32.c - -Patch 6.2.467 (extra, after 6.2.463) -Problem: Win32: can't compile without multi-byte feature. (Ajit Thakkar) -Solution: Add #ifdefs around the info stream code. -Files: src/os_win32.c - -Patch 6.2.468 -Problem: Compiler warnings for shadowed variables. (Matthias Mohr) -Solution: Delete superfluous variables and rename others. -Files: src/eval.c, src/ex_docmd.c, src/ex_eval.c, src/if_cscope.c, - src/fold.c, src/option.c, src/os_unix.c, src/quickfix.c, - src/regexp.c - -Patch 6.2.469 (extra, after 6.2.456) -Problem: Win32: Can't create swap file when 'encoding' differs from the - active code page. (Kriton Kyrimis) -Solution: In enc_to_ucs2() terminate the converted string with a NUL -Files: src/os_mswin.c - -Patch 6.2.470 -Problem: The name returned by tempname() may be equal to the file used for - shell output when ignoring case. -Solution: Skip 'O' and 'I' in tempname(). -Files: src/eval.c - -Patch 6.2.471 -Problem: "-L/usr/lib" is used in the link command, even though it's - supposed to be filtered out. "-lw" and "-ldl" are not - automatically added when needed for "-lXmu". (Antonio Colombo) -Solution: Check for a space after the argument instead of before. Also - remove "-R/usr/lib" if it's there. Check for "-lw" and "-ldl" - before trying "-lXmu". -Files: src/auto/configure, src/configure.in, src/link.sh - -Patch 6.2.472 -Problem: When using a FileChangedShell autocommand that changes the current - buffer, a buffer exists that can't be wiped out. - Also, Vim sometimes crashes when executing an external command - that changes the buffer and a FileChangedShell autocommand is - used. (Hari Krishna Dara) - Users are confused by the warning for a file being changed outside - of Vim. -Solution: Avoid that the window counter for a buffer is incremented twice. - Avoid that buf_check_timestamp() is used recursively. - Add a hint to look in the help for more info. -Files: src/ex_cmds.c, src/fileio.c - -Patch 6.2.473 -Problem: Using CTRL-] in a help buffer without a name causes a crash. -Solution: Check for name to be present before using it. (Taro Muraoka) -Files: src/tag.c - -Patch 6.2.474 (extra, after 6.2.456) -Problem: When Vim is starting up conversion is done unnecessarily. Failure - to find the runtime files on Windows 98. (Randall W. Morris) -Solution: Init enc_codepage negative, only use it when not negative. - Don't use GetFileAttributesW() on Windows 98 or earlier. -Files: src/globals.h, src/gui_w32.c, src/gui_w48.c, src/os_mswin.c, - src/os_win32.c - -Patch 6.2.475 -Problem: Commands after "perl <<EOF" are parsed as Vim commands when they - are not executed. -Solution: Properly skip over the perl commands. -Files: src/ex_docmd.c, src/ex_getln.c, src/if_perl.xs, src/if_python.c, - src/if_ruby.c, src/if_tcl.c, src/misc2.c - -Patch 6.2.476 -Problem: When reloading a hidden buffer changed outside of Vim and the - current buffer is read-only, the reloaded buffer becomes - read-only. (Hari Krishna Dara) -Solution: Save the 'readonly' flag of the reloaded buffer instead of the - current buffer. -Files: src/fileio.c - -Patch 6.2.477 -Problem: Using remote_send(v:servername, "\<C-V>") causes Vim to hang. - (Yakov Lerner) -Solution: When the resulting string is empty don't set received_from_client. -Files: src/main.c - -Patch 6.2.478 -Problem: Win32: "--remote file" fails changing directory if the current - directory name starts with a single quote. (Iestyn Walters) -Solution: Add a backslash where it will be removed later. -Files: src/main.c, src/misc2.c, src/proto/misc2.pro - -Patch 6.2.479 -Problem: The error message for errors during recovery goes unnoticed. -Solution: Avoid that the hit-enter prompt overwrites the message. Add a few - lines to make the error stand out. -Files: src/main.c, src/message.c, src/memline.c - -Patch 6.2.480 -Problem: NetBeans: Using negative index in array. backslash at end of - message may cause Vim to crash. (Xavier de Gaye) -Solution: Initialize buf_list_used to zero. Check for trailing backslash. -Files: src/netbeans.c - -Patch 6.2.481 -Problem: When writing a file it is not possible to specify that hard and/or - symlinks are to be broken instead of preserved. -Solution: Add the "breaksymlink" and "breakhardlink" values to 'backupcopy'. - (Simon Ekstrand) -Files: runtime/doc/options.txt, src/fileio.c, src/option.c, src/option.h - -Patch 6.2.482 -Problem: Repeating insert of CTRL-K 1 S doesn't work. The superscript 1 is - considered to be a digit. (Juergen Kraemer) -Solution: In vim_isdigit() only accept '0' to '9'. Use VIM_ISDIGIT() for - speed where possible. Also add vim_isxdigit(). -Files: src/buffer.c, src/charset.c, src/diff.c, src/digraph.c, - src/edit.c, src/eval.c,, src/ex_cmds.c, src/ex_cmds2.c, - src/ex_docmd.c, src/ex_eval.c, src/ex_getln.c, - src/if_xcmdsrv.c, src/farsi.c, src/fileio.c, src/fold.c, - src/getchar.c, src/gui.c, src/if_cscope.c, src/macros.h, - src/main.c, src/mark.c, src/mbyte.c, src/menu.c, src/misc1.c, - src/misc2.c, src/normal.c, src/ops.c, src/option.c, - src/proto/charset.pro, src/regexp.c, src/screen.c, src/search.c, - src/syntax.c, src/tag.c, src/term.c, src/termlib.c - -Patch 6.2.483 (extra, after 6.2.482) -Problem: See 6.2.482. -Solution: Extra part of patch 6.2.482. -Files: src/gui_photon.c, src/gui_w48.c, src/os_msdos.c, src/os_mswin.c - -Patch 6.2.484 -Problem: MS-Windows: With the included diff.exe, differences after a CTRL-Z - are not recognized. (Peter Keresztes) -Solution: Write the files with unix fileformat and invoke diff with --binary - if possible. -Files: src/diff.c - -Patch 6.2.485 -Problem: A BufWriteCmd autocommand cannot know if "!" was used or not. - (Hari Krishna Dara) -Solution: Add the v:cmdbang variable. -Files: runtime/doc/eval.txt, src/eval.c, src/proto/eval.pro, - src/fileio.c, src/vim.h - -Patch 6.2.486 (6.2.482) -Problem: Diff for eval.c is missing. -Solution: Addition to patch 6.2.482. -Files: src/eval.c - -Patch 6.2.487 (extra, after 6.2.456) -Problem: Compiler warnings for wrong prototype. (Alejandro Lopez Valencia) -Solution: Delete the prototype for Handle_WM_Notify(). -Files: src/proto/gui_w32.pro - -Patch 6.2.488 -Problem: Missing ")" in *.ch filetype detection. -Solution: Add the ")". (Ciaran McCreesh) -Files: runtime/filetype.vim - -Patch 6.2.489 -Problem: When accidentally opening a session in Vim which has already been - opened in another Vim there is a long row of ATTENTION prompts. - Need to quit each of them to get out. (Robert Webb) -Solution: Add the "Abort" alternative to the dialog. -Files: src/memline.c - -Patch 6.2.490 -Problem: With 'paragraph' it is not possible to use a single dot as a - paragraph boundary. (Dorai Sitaram) -Solution: Allow using " " (two spaces) in 'paragraph' to match ".$" or - ". $" -Files: src/search.c - -Patch 6.2.491 -Problem: Decrementing a position doesn't take care of multi-byte chars. -Solution: Adjust the column for multi-byte characters. Remove mb_dec(). - (Yasuhiro Matsumoto) -Files: src/mbyte.c, src/misc2.c, src/proto/mbyte.pro - -Patch 6.2.492 -Problem: When using ":redraw" while there is a message, the next ":echo" - still causes text to scroll. (Yasuhiro Matsumoto) -Solution: Reset msg_didout and msg_col, so that after ":redraw" the next - message overwrites an existing one. -Files: src/ex_docmd.c - -Patch 6.2.493 -Problem: "@x" doesn't work when 'insertmode' is set. (Benji Fisher) -Solution: Put "restart_edit" in the typeahead buffer, so that it's used - after executing the register contents. -Files: src/ops.c - -Patch 6.2.494 -Problem: Using diff mode with two windows, when moving horizontally in - inserted lines, a fold in the other window may open. -Solution: Compute the line number in the other window correctly. -Files: src/diff.c - -Patch 6.2.495 (extra, after 6.2.456) -Problem: Win32: The file dialog doesn't work on Windows 95. -Solution: Put the wide code of gui_mch_browse() in gui_mch_browseW() and use - it only on Windows NT/2000/XP. -Files: src/gui_w32.c, src/gui_w48.c - -Patch 6.2.496 -Problem: FreeBSD 4.x: When compiled with the pthread library (Python) a - complicated pattern may cause Vim to crash. Catching the signal - doesn't work. -Solution: When compiled with threads, instead of using the normal stacksize - limit, use the size of the initial stack. -Files: src/auto/configure, src/config.h.in, src/configure.in, - src/os_unix.c - -Patch 6.2.497 (extra) -Problem: Russian messages are only available in one encoding. -Solution: Convert the messages to MS-Windows codepages. (Vassily Ragosin) -Files: src/po/Makefile - -Patch 6.2.498 -Problem: Non-latin1 help files are not properly supported. -Solution: Support utf-8 help files and convert them to 'encoding' when - needed. -Files: src/fileio.c - -Patch 6.2.499 -Problem: When writing a file and halting the system, the file might be lost - when using a journaling file system. -Solution: Use fsync() to flush the file data to disk after writing a file. - (Radim Kolar) -Files: src/fileio.c - -Patch 6.2.500 (extra) -Problem: The DOS/MS-Windows the installer doesn't use the --binary flag for - diff. -Solution: Add --binary to the diff argument in MyDiff(). (Alejandro Lopez- - Valencia) -Files: src/dosinst.c - -Patch 6.2.501 -Problem: Vim does not compile with MorphOS. -Solution: Add a Makefile and a few changes to make Vim work with MorphOS. - (Ali Akcaagac) -Files: runtime/doc/os_amiga.txt, src/INSTALLami.txt, - src/Make_morphos.mak, src/memfile.c, src/term.c - -Patch 6.2.502 -Problem: Building fails for generating message files. -Solution: Add dummy message files. -Files: src/po/ca.po, src/po/ru.po, src/po/sv.po - -Patch 6.2.503 -Problem: Mac: Can't compile MacRoman conversions without the GUI. -Solution: Also link with the Carbon framework for the terminal version, for - the MacRoman conversion functions. (Eckehard Berns) - Remove -ltermcap from the GUI link command, it is not needed. -Files: src/auto/configure, src/Makefile, src/configure.in - -Patch 6.2.504 -Problem: Various problems with 'cindent', among which that a - list of variable declarations is not indented properly. -Solution: Fix the wrong indenting. Improve indenting of C++ methods. - Add the 'i', 'b' and 'W' options to 'cinoptions'. (mostly by - Helmut Stiegler) - Improve indenting of preprocessor-continuation lines. -Files: runtime/doc/indent.txt, src/misc1.c, src/testdir/test3.in, - src/testdir/test3.ok - -Patch 6.2.505 -Problem: Help for -P argument is missing. (Ronald Hoellwarth) -Solution: Add the patch that was missing in 6.2.419. -Files: runtime/doc/starting.txt - -Patch 6.2.506 (extra) -Problem: Win32: When 'encoding' is a codepage then reading a utf-8 file - only works when iconv is available. Writing a file in another - codepage uses the wrong kind of conversion. -Solution: Use internal conversion functions. Enable reading and writing - files with 'fileencoding' different from 'encoding' for all valid - codepages and utf-8 without the need for iconv. -Files: src/fileio.c, src/testdir/Make_dos.mak, src/testdir/test52.in, - src/testdir/test52.ok - -Patch 6.2.507 -Problem: The ownership of the file with the password for the NetBeans - connection is not checked. "-nb={file}" doesn't work for GTK. -Solution: Only accept the file when owned by the user and not accessible by - others. Detect "-nb=" for GTK. -Files: src/netbeans.c, src/gui_gtk_x11.c - -Patch 6.2.508 -Problem: Win32: "v:lang" does not show the current language for messages if - it differs from the other locale settings. -Solution: Use the value of the $LC_MESSAGES environment variable. -Files: src/ex_cmds2.c - -Patch 6.2.509 (after 6.2.508) -Problem: Crash when $LANG is not set. -Solution: Add check for NULL pointer. (Ron Aaron) -Files: src/ex_cmds2.c - -Patch 6.2.510 (after 6.2.507) -Problem: Warning for pointer conversion. -Solution: Add a type cast. -Files: src/gui_gtk_x11.c - -Patch 6.2.511 -Problem: Tags in Russian help files are in utf-8 encoding, which may be - different from 'encoding'. -Solution: Use the "TAG_FILE_ENCODING" field in the tags file to specify the - encoding of the tags. Convert help tags from 'encoding' to the - tag file encoding when searching for matches, do the reverse when - listing help tags. -Files: runtime/doc/tagsrch.txt, src/ex_cmds.c, src/tag.c - -Patch 6.2.512 -Problem: Translating "\"\n" is useless. (Gerfried Fuchs) -Solution: Remove the _() around it. -Files: src/main.c, src/memline.c - -Patch 6.2.513 (after 6.2.507) -Problem: NetBeans: the check for owning the connection info file can be - simplified. (Nikolay Molchanov) -Solution: Only check if the access mode is right. -Files: src/netbeans.c - -Patch 6.2.514 -Problem: When a highlight/syntax group name contains invalid characters - there is no warning. -Solution: Add an error for unprintable characters and a warning for other - invalid characters. -Files: src/syntax.c - -Patch 6.2.515 -Problem: When using the options window 'swapfile' is reset. -Solution: Use ":setlocal" instead of ":set". -Files: runtime/optwin.vim - -Patch 6.2.516 -Problem: The sign column cannot be seen, looks like there are two spaces - before the text. (Rob Retter) -Solution: Add the SignColumn highlight group. -Files: runtime/doc/options.txt, runtime/doc/sign.txt, src/option.c, - src/screen.c, src/syntax.c, src/vim.h - -Patch 6.2.517 -Problem: Using "r*" in Visual mode on multi-byte characters replaces - too many characters. In Visual Block mode replacing with a - multi-byte character doesn't work. -Solution: Adjust the operator end for the difference in byte length of the - original and the replaced character. Insert all bytes of a - multi-byte character, take care of double-wide characters. -Files: src/ops.c - -Patch 6.2.518 -Problem: Last line of a window is not updated after using "J" and then "D". - (Adri Verhoef) -Solution: When no line is found below a change that doesn't need updating, - update all lines below the change. -Files: src/screen.c - -Patch 6.2.519 -Problem: Mac: cannot read/write files in MacRoman format. -Solution: Do internal conversion from/to MacRoman to/from utf-8 and latin1. - (Eckehard Berns) -Files: src/fileio.c - -Patch 6.2.520 (extra) -Problem: The NSIS installer is outdated. -Solution: Make it work with NSIS 2.0. Also include console executables for - Win 95/98/ME and Win NT/2000/XP. Use LZWA compression. Use - "/oname" to avoid having to rename files before running NSIS. -Files: Makefile, nsis/gvim.nsi - -Patch 6.2.521 -Problem: When using silent Ex mode the "changing a readonly file" warning - is omitted but the one second wait isn't. (Yakov Lerner) -Solution: Skip the delay when "silent_mode" is set. -Files: src/misc1.c - -Patch 6.2.522 -Problem: GUI: when changing 'cmdheight' in the gvimrc file the window - layout is messed up. (Keith Dart) -Solution: Skip updating the window layout when changing 'cmdheight' while - still starting up. -Files: src/option.c - -Patch 6.2.523 -Problem: When loading a session and aborting when a swap file already - exists, the user is left with useless windows. (Robert Webb) -Solution: Load one file before creating the windows. -Files: src/ex_docmd.c - -Patch 6.2.524 (extra, after 6.2.520) -Problem: Win32: (un)installing gvimext.dll may fail if it was used. - The desktop and start menu links are created for the current user - instead of all users. - Using the home directory as working directory for the links is a - bad idea for multi-user systems. - Cannot use Vim from the "Open With..." menu. -Solution: Force a reboot if necessary. (Alejandro Lopez-Valencia) Also use - macros for the directory of the source and runtime files. Use - "CSIDL_COMMON_*" instead of "CSIDL_*" when possible. - Do not specify a working directory in the links. - Add Vim to the "Open With..." menu. (Giuseppe Bilotta) -Files: nsis/gvim.nsi, src/dosinst.c, src/dosinst.h, src/uninstal.c - -Patch 6.2.525 -Problem: When the history contains a very long line ":history" causes a - crash. (Volker Kiefel) -Solution: Shorten the history entry to fit it in one line. -Files: src/ex_getln.c - -Patch 6.2.526 -Problem: When s:lang is "ja" the Japanese menus are not used. -Solution: Add 'encoding' to the language when there is no charset. -Files: runtime/menu.vim - -Patch 6.2.527 -Problem: The 2html script uses ":wincmd p", which breaks when using some - autocommands. -Solution: Remember the window numbers and jump to them with ":wincmd w". - Also add XHTML support. (Panagiotis Issaris) -Files: runtime/syntax/2html.vim - -Patch 6.2.528 -Problem: NetBeans: Changes of the "~" command are not reported. -Solution: Call netbeans_inserted() after performing "~". (Gordon Prieur) - Also change NetBeans debugging to append to the log file. - Also fix that "~" in Visual block mode changes too much if there - are multi-byte characters. -Files: src/nbdebug.c, src/normal.c, src/ops.c - -Patch 6.2.529 (extra) -Problem: VisVim only works for Admin. Doing it for one user doesn't work. - (Alexandre Gouraud) -Solution: When registering the module fails, simply continue. -Files: src/VisVim/VisVim.cpp - -Patch 6.2.530 -Problem: Warning for missing prototype on the Amiga. -Solution: Include time.h -Files: src/version.c - -Patch 6.2.531 -Problem: In silent ex mode no messages are given, which makes debugging - very difficult. -Solution: Do output messages when 'verbose' is set. -Files: src/message.c, src/ui.c - -Patch 6.2.532 (extra) -Problem: Compiling for Win32s with VC 4.1 doesn't work. -Solution: Don't use CP_UTF8 if it's not defined. Don't use CSIDL_COMMON* - when not defined. -Files: src/dosinst.h, src/fileio.c - -Win32 console: After patch 6.2.398 Ex mode did not work. (Yasuhiro Matsumoto) - -Patch 6.3a.001 -Problem: Win32: if testing for the "--binary" option fails, diff isn't used - at all. -Solution: Handle the "ok" flag properly. (Yasuhiro Matsumoto) -Files: src/diff.c - -Patch 6.3a.002 -Problem: NetBeans: An insert command from NetBeans beyond the end of a - buffer crashes Vim. (Xavier de Gaye) -Solution: Use a local pos_T structure for the position. -Files: src/netbeans.c - -Patch 6.3a.003 -Problem: E315 error with auto-formatting comments. (Henry Van Roessel) -Solution: Pass the line number to same_leader(). -Files: src/ops.c - -Patch 6.3a.004 -Problem: Test32 fails on Windows XP for the DJGPP version. Renaming - test11.out fails. -Solution: Don't try renaming, create new files to use for the test. -Files: src/testdir/test32.in, src/testdir/test32.ok - -Patch 6.3a.005 -Problem: ":checkpath!" does not use 'includeexpr'. -Solution: Use a file name that was found directly. When a file was not - found and the located name is empty, use the rest of the line. -Files: src/search.c - -Patch 6.3a.006 -Problem: "yip" moves the cursor to the first yanked line, but not to the - first column. Looks like not all text was yanked. (Jens Paulus) -Solution: Move the cursor to the first column. -Files: src/search.c - -Patch 6.3a.007 -Problem: 'cindent' recognizes "enum" but not "typedef enum". -Solution: Skip over "typedef" before checking for "enum". (Helmut Stiegler) - Also avoid that searching for this item goes too far back. -Files: src/misc1.c, src/testdir/test3.in, src/testdir/test3.ok - -Patch 6.3a.008 (extra) -Problem: Windows 98: Some of the wide functions are not implemented, - resulting in file I/O to fail. This depends on what Unicode - support is installed. -Solution: Handle the failure and fall back to non-wide functions. -Files: src/os_win32.c - -Patch 6.3a.009 -Problem: Win32: Completion of filenames does not work properly when - 'encoding' differs from the active code page. -Solution: Use wide functions for expanding wildcards when appropriate. -Files: src/misc1.c - -Patch 6.3a.010 (extra) -Problem: Win32: Characters in the window title that do not appear in the - active codepage are replaced by a question mark. -Solution: Use DefWindowProcW() instead of DefWindowProc() when possible. -Files: src/glbl_ime.cpp, src/globals.h, src/proto/gui_w16.pro, - src/proto/gui_w32.pro, src/gui_w16.c, src/gui_w32.c, src/gui_w48.c - -Patch 6.3a.011 -Problem: Using the explorer plugin changes a local directory to the global - directory. -Solution: Don't use ":chdir" to restore the current directory. Make - "expand('%:p')" remove "/../" and "/./" items from the path. -Files: runtime/plugin/explorer.vim, src/eval.c, src/os_unix.c - -Patch 6.3a.012 (extra) -Problem: On Windows 98 the installer doesn't work, don't even get the "I - agree" button. The check for the path ending in "vim" makes the - browse dialog hard to use. The default path when no previous Vim - is installed is "c:\vim" instead of "c:\Program Files\Vim". -Solution: Remove the background gradient command. Change the - .onVerifyInstDir function to a leave function for the directory - page. Don't let the install program default to c:\vim when no - path could be found. -Files: nsis/gvim.nsi, src/dosinst.c - -Patch 6.3a.013 (extra) -Problem: Win32: Characters in the menu that are not in the active codepage - are garbled. -Solution: Convert menu strings from 'encoding' to the active codepage. -Files: src/gui_w32.c, src/gui_w48.c - -Patch 6.3a.014 -Problem: Using multi-byte text and highlighting in a statusline causes gaps - to appear. (Helmut Stiegler) -Solution: Advance the column by text width instead of number of bytes. Add - the vim_strnsize() function. -Files: src/charset.c, src/proto/charset.pro, src/screen.c - -Patch 6.3a.015 -Problem: Using the "select all" menu item when 'insertmode' is set and - clicking the mouse button doesn't return to Insert mode. The - Buffers/Delete menu doesn't offer a choice to abandon a changed - buffer. (Jens Paulus) -Solution: Don't use CTRL-\ CTRL-N. Add ":confirm" for the Buffers menu - items. -Files: runtime/menu.vim - -Patch 6.3a.016 -Problem: After cancelling the ":confirm" dialog the error message and - hit-enter prompt may not be displayed properly. -Solution: Flush output after showing the dialog. -Files: src/message.c - -Patch 6.3a.017 -Problem: servername() doesn't work when Vim was started with the "-X" - argument or when the "exclude" in 'clipboard' matches the terminal - name. (Robert Nowotniak) -Solution: Force connecting to the X server when using client-server - commands. -Files: src/eval.c, src/globals.h, src/os_unix.c - -Patch 6.3a.018 (after 6.3a.017) -Problem: Compiler warning for return value of make_connection(). -Solution: Use void return type. -Files: src/eval.c - -Patch 6.3a.019 (extra) -Problem: Win32: typing non-latin1 characters doesn't work. -Solution: Invoke _OnChar() directly to avoid that the argument is truncated - to a byte. Convert the UTF-16 character to bytes according to - 'encoding' and ignore 'termencoding'. Same for _OnSysChar(). -Files: src/gui_w32.c, src/gui_w48.c - -Patch 6.3a.020 (extra) -Problem: Missing support for AROS (AmigaOS reimplementation). Amiga GUI - doesn't work. -Solution: Add AROS support. (Adam Chodorowski) - Fix Amiga GUI problems. (Georg Steger, Ali Akcaagac) -Files: Makefile, src/Make_aros.mak, src/gui_amiga.c, src/gui_amiga.h, - src/memfile.c, src/os_amiga.c, src/term.c - -Patch 6.3a.021 (after 6.3a.017) -Problem: Can't compile with X11 but without GUI. -Solution: Put use of "gui.in_use" inside an #ifdef. -Files: src/eval.c - -Patch 6.3a.022 -Problem: When typing Tabs when 'softtabstop' is used and 'list' is set a - tab is counted for two spaces. -Solution: Use the "L" flag in 'cpoptions' to tell whether a tab is counted - as two spaces or as 'tabstop'. (Antony Scriven) -Files: runtime/doc/options.txt, src/edit.c - -Patch 6.3a.023 -Problem: Completion on the command line doesn't handle backslashes - properly. Only the tail of matches is shown, even when not - completing filenames. -Solution: When turning the string into a pattern double backslashes. Don't - omit the path when not expanding files or directories. -Files: src/ex_getln.c - -Patch 6.3a.024 -Problem: The "save all" toolbar item fails for buffers that don't have a - name. When using ":wa" or closing the Vim window and there are - nameless buffers, browsing for a name may cause the name being - given to the wrong buffer or not stored properly. ":browse" only - worked for one file. -Solution: Use ":confirm browse" for "save all". - Pass buffer argument to setfname(). Restore "browse" flag and - "forceit" after doing the work for one file. -Files: runtime/menu.vim, src/buffer.c, src/ex_cmds.c, src/ex_cmds2.c, - src/ex_docmd.c, src/ex_getln.c, src/fileio.c, src/memline.c, - src/message.c, src/window.c, src/proto/buffer.pro, - src/proto/ex_cmds2.pro, src/proto/memline.pro - -Patch 6.3a.025 -Problem: Setting 'virtualedit' moves the cursor. (Benji Fisher) -Solution: Update the virtual column before using it. -Files: src/option.c - -Patch 6.3a.026 (extra, after 6.3a.008) -Problem: Editing files on Windows 98 doesn't work when 'encoding' is - "utf-8" (Antoine Mechelynck) - Warning for missing function prototype. -Solution: For all wide functions check if it failed because it is not - implemented. Use ANSI function declaration for char_to_string(). -Files: src/gui_w48.c, src/os_mswin.c, src/os_win32.c - -Patch 6.3a.027 (extra, after 6.3a.026) -Problem: Compiler warning for function argument. -Solution: Declare both char and WCHAR arrays. -Files: src/gui_w48.c - -Patch 6.3a.028 -Problem: ":normal ." doesn't work inside a function, because redo is saved - and restored. (Benji Fisher) -Solution: Make a copy of the redo buffer when executing a function. -Files: src/getchar.c - -Patch 6.3b.001 (extra) -Problem: Bcc 5: The generated auto/pathdef can't be compiled. -Solution: Fix the way quotes and backslashes are escaped. -Files: src/Make_bc5.mak - -Patch 6.3b.002 -Problem: Win32: conversion during file write fails when a double-byte - character is split over two writes. -Solution: Fix the conversion retry without a trailing byte. (Taro Muraoka) -Files: src/fileio.c - -Patch 6.3b.003 (extra) -Problem: Win32: When compiling with Borland C 5.5 and 'encoding' is "utf-8" - then Vim can't open files under MS-Windows 98. (Antoine J. - Mechelynck) -Solution: Don't use _wstat(), _wopen() and _wfopen() in this situation. -Files: src/os_mswin.c, src/os_win32.c - -Patch 6.3b.004 -Problem: ":helpgrep" includes a trailing CR in the text line. -Solution: Remove the CR. -Files: src/quickfix.c - -Patch 6.3b.005 -Problem: ":echo &g:ai" results in the local option value. (Salman Halim) -Solution: Pass the flags from find_option_end() to get_option_value(). -Files: src/eval.c - -Patch 6.3b.006 -Problem: When using "mswin.vim", CTRL-V in Insert mode leaves cursor before - last pasted character. (Mathew Davis) -Solution: Use the same Paste() function as in menu.vim. -Files: runtime/mswin.vim - -Patch 6.3b.007 -Problem: Session file doesn't restore view on windows properly. (Robert - Webb) -Solution: Restore window sizes both before and after restoring the view, so - that the view, cursor position and size are restored properly. -Files: src/ex_docmd.c - -Patch 6.3b.008 -Problem: Using ":finally" in a user command doesn't always work. (Hari - Krishna Dara) -Solution: Don't assume that using getexline() means the command was typed. -Files: src/ex_docmd.c - -Patch 6.3b.009 (extra) -Problem: Win32: When the -P argument is not found in a window title, there - is no error message. -Solution: When the window can't be found give an error message and exit. - Also use try/except to catch failing to open the MDI window. - (Michael Wookey) -Files: src/gui_w32.c - -Patch 6.3b.010 -Problem: Win32: Using the "-D" argument and expanding arguments may cause a - hang, because the terminal isn't initialized yet. (Vince Negri) -Solution: Don't go into debug mode before the terminal is initialized. -Files: src/main.c - -Patch 6.3b.011 -Problem: Using CTRL-\ e while obtaining an expression aborts the command - line. (Hari Krishna Dara) -Solution: Insert the CTRL-\ e as typed. -Files: src/ex_getln.c - -Patch 6.3b.012 (after 6.3b.010) -Problem: Can't compile with tiny features. (Norbert Tretkowski) -Solution: Add #ifdefs. -Files: src/main.c - -Patch 6.3b.013 -Problem: Loading a session file results in editing the wrong file in the - first window when this is not the file at the current position in - the argument list. (Robert Webb) -Solution: Check w_arg_idx_invalid to decide whether to edit a file. -Files: src/ex_docmd.c - -Patch 6.3b.014 -Problem: ":runtime! foo*.vim" may using freed memory when a sourced script - changes the value of 'runtimepath'. -Solution: Make a copy of 'runtimepath' when looping over the matches. -Files: src/ex_cmds2.c - -Patch 6.3b.015 -Problem: Get lalloc(0) error when using "p" in Visual mode while - 'clipboard' contains "autoselect,unnamed". (Mark Wagonner) -Solution: Avoid allocating zero bytes. Obtain the clipboard when necessary. -Files: src/ops.c - -Patch 6.3b.016 -Problem: When 'virtualedit' is used "x" doesn't delete the last character - of a line that has as many characters as 'columns'. (Yakov Lerner) -Solution: When the cursor isn't moved let oneright() return FAIL. -Files: src/edit.c - -Patch 6.3b.017 -Problem: Win32: "vim --remote-wait" doesn't exit when the server finished - editing the file. (David Fishburn) -Solution: In the rrhelper plugin change backslashes to forward slashes and - escape special characters. -Files: runtime/plugin/rrhelper.vim - -Patch 6.3b.018 -Problem: The list of help files in the "local additions" table doesn't - recognize utf-8 encoding. (Yasuhiro Matsumoto) -Solution: Recognize utf-8 characters. -Files: src/ex_cmds.c - -Patch 6.3b.019 -Problem: When $VIMRUNTIME is not a full path name the "local additions" - table lists all the help files. -Solution: Use fullpathcmp() instead of fnamecmp() to compare the directory - names. -Files: src/ex_cmds.c - -Patch 6.3b.020 -Problem: When using CTRL-^ when entering a search string, the item in the - statusline that indicates the keymap is not updated. (Ilya - Dogolazky) -Solution: Mark the statuslines for updating. -Files: src/ex_getln.c - -Patch 6.3b.021 -Problem: The swapfile is not readable for others, the ATTENTION prompt does - not show all info when someone else is editing the same file. - (Marcel Svitalsky) -Solution: Use the protection of original file for the swapfile and set it - after creating the swapfile. -Files: src/fileio.c - -Patch 6.3b.022 -Problem: Using "4v" to select four times the old Visual area may put the - cursor beyond the end of the line. (Jens Paulus) -Solution: Correct the cursor column. -Files: src/normal.c - -Patch 6.3b.023 -Problem: When "3dip" starts in an empty line, white lines after the - non-white lines are not deleted. (Jens Paulus) -Solution: Include the white lines. -Files: src/search.c - -Patch 6.3b.024 -Problem: "2daw" does not delete leading white space like "daw" does. (Jens - Paulus) -Solution: Include the white space when a count is used. -Files: src/search.c - -Patch 6.3b.025 -Problem: Percentage in ruler isn't updated when a line is deleted. (Jens - Paulus) -Solution: Check for a change in line count when deciding to update the ruler. -Files: src/screen.c, src/structs.h - -Patch 6.3b.026 -Problem: When selecting "abort" at the ATTENTION prompt for a file that is - already being edited Vim crashes. -Solution: Don't abort creating a new buffer when we really need it. -Files: src/buffer.c, src/vim.h - -Patch 6.3b.027 -Problem: Win32: When enabling the menu in a maximized window, Vim uses more - lines than what is room for. (Shizhu Pan) -Solution: When deciding to call shell_resized(), also compare the text area - size with Rows and Columns, not just with screen_Rows and - screen_Columns. -Files: src/gui.c - -Patch 6.3b.028 -Problem: When in diff mode, setting 'rightleft' causes a crash. (Eddine) -Solution: Check for last column differently when 'rightleft' is set. -Files: src/screen.c - -Patch 6.3b.029 -Problem: Win32: warning for uninitialized variable. -Solution: Initialize to zero. -Files: src/misc1.c - -Patch 6.3b.030 -Problem: After Visually selecting four characters, changing it to other - text, Visually selecting and yanking two characters: "." changes - four characters, another "." changes two characters. (Robert Webb) -Solution: Don't store the size of the Visual area when redo is active. -Files: src/normal.c - -============================================================================== -VERSION 6.4 *version-6.4* - -This section is about improvements made between version 6.3 and 6.4. - -This is a bug-fix release. There are also a few new features. The major -number of new items is in the runtime files and translations. - -The big MS-Windows version now uses: - Ruby version 1.8.3 - Perl version 5.8.7 - Python version 2.4.2 - - -Changed *changed-6.4* -------- - -Removed runtime/tools/tcltags, Exuberant ctags does it better. - - -Added *added-6.4* ------ - -Alsaconf syntax file (Nikolai Weibull) -Eruby syntax, indent, compiler and ftplugin file (Doug Kearns) -Esterel syntax file (Maurizio Tranchero) -Mathematica indent file (Steve Layland) -Netrc syntax file (Nikolai Weibull) -PHP compiler file (Doug Kearns) -Pascal indent file (Neil Carter) -Prescribe syntax file (Klaus Muth) -Rubyunit compiler file (Doug Kearns) -SMTPrc syntax file (Kornel Kielczewski) -Sudoers syntax file (Nikolai Weibull) -TPP syntax file (Gerfried Fuchs) -VHDL ftplugin file (R. Shankar) -Verilog-AMS syntax file (S. Myles Prather) - -Bulgarian keymap (Alberto Mardegan) -Canadian keymap (Eric Joanis) - -Hungarian menu translations in UTF-8 (Kantra Gergely) -Ukrainian menu translations (Bohdan Vlasyuk) - -Irish message translations (Kevin Patrick Scannell) - -Configure also checks for tclsh8.4. - - -Fixed *fixed-6.4* ------ - -"dFxd;" deleted the character under the cursor, "d;" didn't remember the -exclusiveness of the motion. - -When using "set laststatus=2 cmdheight=2" in the .gvimrc you may only get one -line for the cmdline. (Christian Robinson) Invoke command_height() after the -GUI has started up. - -Gcc would warn "dereferencing type-punned pointer will break strict -aliasing -rules". Avoid using typecasts for variable pointers. - -Gcc 3.x interprets the -MM argument differently. Change "-I /path" to -"-isystem /path" for "make depend". - - -Patch 6.3.001 -Problem: ":browse split" gives the file selection dialog twice. (Gordon - Bazeley) Same problem for ":browse diffpatch". -Solution: Reset cmdmod.browse before calling do_ecmd(). -Files: src/diff.c, src/ex_docmd.c - -Patch 6.3.002 -Problem: When using translated help files with non-ASCII latin1 characters - in the first line the utf-8 detection is wrong. -Solution: Properly detect utf-8 characters. When a mix of encodings is - detected continue with the next language and avoid a "no matches" - error because of "got_int" being set. Add the directory name to - the error message for a duplicate tag. -Files: src/ex_cmds.c - -Patch 6.3.003 -Problem: Crash when using a console dialog and the first choice does not - have a default button. (Darin Ohashi) -Solution: Allocate two more characters for the [] around the character for - the default choice. -Files: src/message.c - -Patch 6.3.004 -Problem: When searching for a long string (140 chars in a 80 column - terminal) get three hit-enter prompts. (Robert Webb) -Solution: Avoid the hit-enter prompt when giving the message for wrapping - around the end of the buffer. Don't give that message again when - the string was not found. -Files: src/message.c, src/search.c - -Patch 6.3.005 -Problem: Crash when searching for a pattern with a character offset and - starting in a closed fold. (Frank Butler) -Solution: Check for the column to be past the end of the line. Also fix - that a pattern with a character offset relative to the end isn't - read back from the viminfo properly. -Files: src/search.c - -Patch 6.3.006 -Problem: ":breakadd file *foo" prepends the current directory to the file - pattern. (Hari Krishna Dara) -Solution: Keep the pattern as-is. -Files: src/ex_cmds2.c - -Patch 6.3.007 -Problem: When there is a buffer with 'buftype' set to "nofile" and using a - ":cd" command, the swap file is not deleted when exiting. -Solution: Use the full path of the swap file also for "nofile" buffers. -Files: src/fileio.c - -Patch 6.3.008 -Problem: Compiling fails under OS/2. -Solution: Include "e_screenmode" also for OS/2. (David Sanders) -Files: src/globals.h - -Patch 6.3.009 (after 6.3.006) -Problem: ":breakadd file /path/foo.vim" does not match when a symbolic link - is involved. (Servatius Brandt) -Solution: Do expand the pattern when it does not start with "*". -Files: runtime/doc/repeat.txt, src/ex_cmds2.c - -Patch 6.3.010 -Problem: When writing to a named pipe there is an error for fsync() - failing. -Solution: Ignore the fsync() error for devices. -Files: src/fileio.c - -Patch 6.3.011 -Problem: Crash when the completion function of a user-command uses a - "normal :cmd" command. (Hari Krishna Dara) -Solution: Save the command line when invoking the completion function. -Files: src/ex_getln.c - -Patch 6.3.012 -Problem: Internal lalloc(0) error when using a complicated multi-line - pattern in a substitute command. (Luc Hermitte) -Solution: Avoid going past the end of a line. -Files: src/ex_cmds.c - -Patch 6.3.013 -Problem: Crash when editing a command line and typing CTRL-R = to evaluate - a function that uses "normal :cmd". (Hari Krishna Dara) -Solution: Save and restore the command line when evaluating an expression - for CTRL-R =. -Files: src/ex_getln.c, src/ops.c, src/proto/ex_getln.pro, - src/proto/ops.pro - -Patch 6.3.014 -Problem: When using Chinese or Taiwanese the default for 'helplang' is - wrong. (Simon Liang) -Solution: Use the part of the locale name after "zh_". -Files: src/option.c - -Patch 6.3.015 -Problem: The string that winrestcmd() returns may end in garbage. -Solution: NUL-terminate the string. (Walter Briscoe) -Files: src/eval.c - -Patch 6.3.016 -Problem: The default value for 'define' has "\s" before '#'. -Solution: Add a star after "\s". (Herculano de Lima Einloft Neto) -Files: src/option.c - -Patch 6.3.017 -Problem: "8zz" may leave the cursor beyond the end of the line. (Niko - Maatjes) -Solution: Correct the cursor column after moving to another line. -Files: src/normal.c - -Patch 6.3.018 -Problem: ":0argadd zero" added the argument after the first one, instead of - before it. (Adri Verhoef) -Solution: Accept a zero range for ":argadd". -Files: src/ex_cmds.h - -Patch 6.3.019 -Problem: Crash in startup for debug version. (David Rennals) -Solution: Move the call to nbdebug_wait() to after allocating NameBuff. -Files: src/main.c - -Patch 6.3.020 -Problem: When 'encoding' is "utf-8" and 'delcombine' is set, "dw" does not - delete a word but only a combining character of the first - character, if there is one. (Raphael Finkel) -Solution: Correctly check that one character is being deleted. -Files: src/misc1.c - -Patch 6.3.021 -Problem: When the last character of a file name is a multi-byte character - and the last byte is a path separator, the file cannot be edited. -Solution: Check for the last byte to be part of a multi-byte character. - (Taro Muraoka) -Files: src/fileio.c - -Patch 6.3.022 (extra) -Problem: Win32: When the last character of a file name is a multi-byte - character and the last byte is a path separator, the file cannot - be written. A trail byte that is a space makes that a file cannot - be opened from the command line. -Solution: Recognize double-byte characters when parsing the command line. - In mch_stat() check for the last byte to be part of a multi-byte - character. (Taro Muraoka) -Files: src/gui_w48.c, src/os_mswin.c - -Patch 6.3.023 -Problem: When the "to" part of a mapping starts with its "from" part, - abbreviations for the same characters is not possible. For - example, when <Space> is mapped to something that starts with a - space, typing <Space> does not expand abbreviations. -Solution: Only disable expanding abbreviations when a mapping is not - remapped, don't disable it when the RHS of a mapping starts with - the LHS. -Files: src/getchar.c, src/vim.h - -Patch 6.3.024 -Problem: In a few places a string in allocated memory is not terminated - with a NUL. -Solution: Add ga_append(NUL) in script_get(), gui_do_findrepl() and - serverGetVimNames(). -Files: src/ex_getln.c, src/gui.c, src/if_xcmdsrv.c, src/os_mswin.c - -Patch 6.3.025 (extra) -Problem: Missing NUL for list of server names. -Solution: Add ga_append(NUL) in serverGetVimNames(). -Files: src/os_mswin.c - -Patch 6.3.026 -Problem: When ~/.vim/after/syntax/syncolor.vim contains a command that - reloads the colors an endless loop and/or a crash may occur. -Solution: Only free the old value of an option when it was originally - allocated. Limit recursiveness of init_highlight() to 5 levels. -Files: src/option.c, src/syntax.c - -Patch 6.3.027 -Problem: VMS: Writing a file may insert extra CR characters. Not all - terminals are recognized correctly. Vt320 doesn't support colors. - Environment variables are not expanded correctly. -Solution: Use another method to write files. Add vt320 termcap codes for - colors. (Zoltan Arpadffy) -Files: src/fileio.c, src/misc1.c, src/os_unix.c, src/structs.h, - src/term.c - -Patch 6.3.028 -Problem: When appending to a file the BOM marker may be written. (Alex - Jakushev) -Solution: Do not write the BOM marker when appending. -Files: src/fileio.c - -Patch 6.3.029 -Problem: Crash when inserting a line break. (Walter Briscoe) -Solution: In the syntax highlighting code, don't use an old state after a - change was made, current_col may be past the end of the line. -Files: src/syntax.c - -Patch 6.3.030 -Problem: GTK 2: Crash when sourcing a script that deletes the menus, sets - 'encoding' to "utf-8" and loads the menus again. GTK error - message when tooltip text is in a wrong encoding. -Solution: Don't copy characters from the old screen to the new screen when - switching 'encoding' to utf-8, they may be invalid. Only set the - tooltip when it is valid utf-8. -Files: src/gui_gtk.c, src/mbyte.c, src/proto/mbyte.pro, src/screen.c - -Patch 6.3.031 -Problem: When entering a mapping and pressing Tab halfway the command line - isn't redrawn properly. (Adri Verhoef) -Solution: Reposition the cursor after drawing over the "..." of the - completion attempt. -Files: src/ex_getln.c - -Patch 6.3.032 -Problem: Using Python 2.3 with threads doesn't work properly. -Solution: Release the lock after initialization. -Files: src/if_python.c - -Patch 6.3.033 -Problem: When a mapping ends in a Normal mode command of more than one - character Vim doesn't return to Insert mode. -Solution: Check that the mapping has ended after obtaining all characters of - the Normal mode command. -Files: src/normal.c - -Patch 6.3.034 -Problem: VMS: crash when using ":help". -Solution: Avoid using "tags-??", some Open VMS systems can't handle the "?" - wildcard. (Zoltan Arpadffy) -Files: src/tag.c - -Patch 6.3.035 (extra) -Problem: RISC OS: Compile errors. -Solution: Change e_screnmode to e_screenmode. Change the way - __riscosify_control is set. Improve the makefile. (Andy Wingate) -Files: src/os_riscos.c, src/search.c, src/Make_ro.mak - -Patch 6.3.036 -Problem: ml_get errors when the whole file is a fold, switching - 'foldmethod' and doing "zj". (Christian J. Robinson) Was not - deleting the fold but creating a fold with zero lines. -Solution: Delete the fold properly. -Files: src/fold.c - -Patch 6.3.037 (after 6.3.032) -Problem: Warning for unused variable. -Solution: Change the #ifdefs for the saved thread stuff. -Files: src/if_python.c - -Patch 6.3.038 (extra) -Problem: Win32: When the "file changed" dialog pops up after a click that - gives gvim focus and not moving the mouse after that, the effect - of the click may occur when moving the mouse later. (Ken Clark) - Happened because the release event was missed. -Solution: Clear the s_button_pending variable when any input is received. -Files: src/gui_w48.c - -Patch 6.3.039 -Problem: When 'number' is set and inserting lines just above the first - displayed line (in another window on the same buffer), the line - numbers are not updated. (Hitier Sylvain) -Solution: When 'number' is set and lines are inserted/deleted redraw all - lines below the change. -Files: src/screen.c - -Patch 6.3.040 -Problem: Error handling does not always work properly and may cause a - buffer to be marked as if it's viewed in a window while it isn't. - Also when selecting "Abort" at the attention prompt. -Solution: Add enter_cleanup() and leave_cleanup() functions to move - saving/restoring things for error handling to one place. - Clear a buffer read error when it's unloaded. -Files: src/buffer.c, src/ex_docmd.c, src/ex_eval.c, - src/proto/ex_eval.pro, src/structs.h, src/vim.h - -Patch 6.3.041 (extra) -Problem: Win32: When the path to a file has Russian characters, ":cd %:p:h" - doesn't work. (Valery Kondakoff) -Solution: Use a wide function to change directory. -Files: src/os_mswin.c - -Patch 6.3.042 -Problem: When there is a closed fold at the top of the window, CTRL-X - CTRL-E in Insert mode reduces the size of the fold instead of - scrolling the text up. (Gautam) -Solution: Scroll over the closed fold. -Files: src/move.c - -Patch 6.3.043 -Problem: 'hlsearch' highlighting sometimes disappears when inserting text - in PHP code with syntax highlighting. (Marcel Svitalsky) -Solution: Don't use pointers to remember where a match was found, use an - index. The pointers may become invalid when searching in other - lines. -Files: src/screen.c - -Patch 6.3.044 (extra) -Problem: Mac: When 'linespace' is non-zero the Insert mode cursor leaves - pixels behind. (Richard Sandilands) -Solution: Erase the character cell before drawing the text when needed. -Files: src/gui_mac.c - - -Patch 6.3.045 -Problem: Unusual characters in an option value may cause unexpected - behavior, especially for a modeline. (Ciaran McCreesh) -Solution: Don't allow setting termcap options or 'printdevice' in a - modeline. Don't list options for "termcap" and "all" in a - modeline. Don't allow unusual characters in 'filetype', 'syntax', - 'backupext', 'keymap', 'patchmode' and 'langmenu'. -Files: src/option.c, runtime/doc/options.txt - -Patch 6.3.046 -Problem: ":registers" doesn't show multi-byte characters properly. - (Valery Kondakoff) -Solution: Get the length of each character before displaying it. -Files: src/ops.c - -Patch 6.3.047 (extra) -Problem: Win32 with Borland C 5.5 on Windows XP: A new file is created with - read-only attributes. (Tony Mechelynck) -Solution: Don't use the _wopen() function for Borland. -Files: src/os_win32.c - -Patch 6.3.048 (extra) -Problem: Build problems with VMS on IA64. -Solution: Add dependencies to the build file. (Zoltan Arpadffy) -Files: src/Make_vms.mms - -Patch 6.3.049 (after 6.3.045) -Problem: Compiler warning for "char" vs "char_u" mixup. (Zoltan Arpadffy) -Solution: Add a typecast. -Files: src/option.c - -Patch 6.3.050 -Problem: When SIGHUP is received while busy exiting, non-reentrant - functions such as free() may cause a crash. -Solution: Ignore SIGHUP when exiting because of an error. (Scott Anderson) -Files: src/misc1.c, src/main.c - -Patch 6.3.051 -Problem: When 'wildmenu' is set and completed file names contain multi-byte - characters Vim may crash. -Solution: Reserve room for multi-byte characters. (Yasuhiro Matsumoto) -Files: src/screen.c - -Patch 6.3.052 (extra) -Problem: Windows 98: typed keys that are not ASCII may not work properly. - For example with a Russian input method. (Jiri Jezdinsky) -Solution: Assume that the characters arrive in the current codepage instead - of UCS-2. Perform conversion based on that. -Files: src/gui_w48.c - -Patch 6.3.053 -Problem: Win32: ":loadview" cannot find a file with non-ASCII characters. - (Valerie Kondakoff) -Solution: Use mch_open() instead of open() to open the file. -Files: src/ex_cmds2.c - -Patch 6.3.054 -Problem: When 'insertmode' is set <C-L>4ixxx<C-L> hangs Vim. (Jens Paulus) - Vim is actually still working but redraw is disabled. -Solution: When stopping Insert mode with CTRL-L don't put an Esc in the redo - buffer but a CTRL-L. -Files: src/edit.c - -Patch 6.3.055 (after 6.3.013) -Problem: Can't use getcmdline(), getcmdpos() or setcmdpos() with <C-R>= - when editing a command line. Using <C-\>e may crash Vim. (Peter - Winters) -Solution: When moving ccline out of the way for recursive use, make it - available to the functions that need it. Also save and restore - ccline when calling get_expr_line(). Make ccline.cmdbuf NULL at - the end of getcmdline(). -Files: src/ex_getln.c - -Patch 6.3.056 -Problem: The last characters of a multi-byte file name may not be displayed - in the window title. -Solution: Avoid to remove a multi-byte character where the last byte looks - like a path separator character. (Yasuhiro Matsumoto) -Files: src/buffer.c, src/ex_getln.c - -Patch 6.3.057 -Problem: When filtering lines folds are not updated. (Carl Osterwisch) -Solution: Update folds for filtered lines. -Files: src/ex_cmds.c - -Patch 6.3.058 -Problem: When 'foldcolumn' is equal to the window width and 'wrap' is on - Vim may crash. Disabling the vertical split feature breaks - compiling. (Peter Winters) -Solution: Check for zero room for wrapped text. Make compiling without - vertical splits possible. -Files: src/move.c, src/quickfix.c, src/screen.c, src/netbeans.c - -Patch 6.3.059 -Problem: Crash when expanding an ":edit" command containing several spaces - with the shell. (Brian Hirt) -Solution: Allocate enough space for the quotes. -Files: src/os_unix.c - -Patch 6.3.060 -Problem: Using CTRL-R CTRL-O in Insert mode with an invalid register name - still causes something to be inserted. -Solution: Check the register name for being valid. -Files: src/edit.c - -Patch 6.3.061 -Problem: When editing a utf-8 file in an utf-8 xterm and there is a - multi-byte character in the last column, displaying is messed up. - (Joël Rio) -Solution: Check for a multi-byte character, not a multi-column character. -Files: src/screen.c - -Patch 6.3.062 -Problem: ":normal! gQ" hangs. -Solution: Quit getcmdline() and do_exmode() when out of typeahead. -Files: src/ex_getln.c, src/ex_docmd.c - -Patch 6.3.063 -Problem: When a CursorHold autocommand changes to another window - (temporarily) 'mousefocus' stops working. -Solution: Call gui_mouse_correct() after triggering CursorHold. -Files: src/gui.c - -Patch 6.3.064 -Problem: line2byte(line("$") + 1) sometimes returns the wrong number. - (Charles Campbell) -Solution: Flush the cached line before counting the bytes. -Files: src/memline.c - -Patch 6.3.065 -Problem: The euro digraph doesn't always work. -Solution: Add an "e=" digraph for Unicode euro character and adjust the - help files. -Files: src/digraph.c, runtime/doc/digraph.txt - -Patch 6.3.066 -Problem: Backup file may get wrong permissions. -Solution: Use permissions of original file for backup file in more places. -Files: src/fileio.c - -Patch 6.3.067 (after 6.3.066) -Problem: Newly created file gets execute permission. -Solution: Check for "perm" to be negative before using it. -Files: src/fileio.c - -Patch 6.3.068 -Problem: When editing a compressed file xxx.gz which is a symbolic link to - the actual file a ":write" renames the link. -Solution: Resolve the link, so that the actual file is renamed and - compressed. -Files: runtime/plugin/gzip.vim - -Patch 6.3.069 -Problem: When converting text with illegal characters Vim may crash. -Solution: Avoid that too much is subtracted from the length. (Da Woon Jung) -Files: src/mbyte.c - -Patch 6.3.070 -Problem: After ":set number linebreak wrap" and a vertical split, moving - the vertical separator far left will crash Vim. (Georg Dahn) -Solution: Avoid dividing by zero. -Files: src/charset.c - -Patch 6.3.071 -Problem: The message for CTRL-X mode is still displayed after an error for - 'thesaurus' or 'dictionary' being empty. -Solution: Clear "edit_submode". -Files: src/edit.c - -Patch 6.3.072 -Problem: Crash in giving substitute message when language is Chinese and - encoding is utf-8. (Yongwei) -Solution: Make the msg_buf size larger when using multi-byte. -Files: src/vim.h - -Patch 6.3.073 -Problem: Win32 GUI: When the Vim window is partly above or below the - screen, scrolling causes display errors when the taskbar is not on - that side. -Solution: Use the SW_INVALIDATE flag when the Vim window is partly below or - above the screen. -Files: src/gui_w48.c - -Patch 6.3.074 -Problem: When mswin.vim is used and 'insertmode' is set, typing text in - Select mode and then using CTRL-V results in <SNR>99_Pastegi. - (Georg Dahn) -Solution: When restart_edit is set use "d" instead of "c" to remove the - selected text to avoid calling edit() twice. -Files: src/normal.c - -Patch 6.3.075 -Problem: After unloading another buffer, syntax highlighting in the current - buffer may be wrong when it uses "containedin". (Eric Arnold) -Solution: Use "buf" instead of "curbuf" in syntax_clear(). -Files: src/syntax.c - -Patch 6.3.076 -Problem: Crash when using cscope and there is a parse error (e.g., line too - long). (Alexey I. Froloff) -Solution: Pass the actual number of matches to cs_manage_matches() and - correctly handle the error situation. -Files: src/if_cscope.c - -Patch 6.3.077 (extra) -Problem: VMS: First character input after ESC was not recognized. -Solution: Added TRM$M_TM_TIMED in vms_read(). (Zoltan Arpadffy) -Files: src/os_vms.c - -Patch 6.3.078 (extra, after 6.3.077) -Problem: VMS: Performance issue after patch 6.3.077 -Solution: Add a timeout in the itemlist. (Zoltan Arpadffy) -Files: src/os_vms.c - -Patch 6.3.079 -Problem: Crash when executing a command in the command line window while - syntax highlighting is enabled. (Pero Brbora) -Solution: Don't use a pointer to a buffer that has been deleted. -Files: src/syntax.c - -Patch 6.3.080 (extra) -Problem: Win32: With 'encoding' set to utf-8 while the current codepage is - Chinese editing a file with some specific characters in the name - fails. -Solution: Use _wfullpath() instead of _fullpath() when necessary. -Files: src/os_mswin.c - -Patch 6.3.081 -Problem: Unix: glob() may execute a shell command when it's not wanted. - (Georgi Guninski) -Solution: Verify the sandbox flag is not set. -Files: src/os_unix.c - -Patch 6.3.082 (after 6.3.081) -Problem: Unix: expand() may execute a shell command when it's not wanted. - (Georgi Guninski) -Solution: A more generic solution than 6.3.081. -Files: src/os_unix.c - -Patch 6.3.083 -Problem: VMS: The vt320 termcap entry is incomplete. -Solution: Add missing function keys. (Zoltan Arpadffy) -Files: src/term.c - -Patch 6.3.084 (extra) -Problem: Cygwin: compiling with DEBUG doesn't work. Perl path was ignored. - Failure when $(OUTDIR) already exists. "po" makefile is missing. -Solution: Use changes tested in Vim 7. (Tony Mechelynck) -Files: src/Make_cyg.mak, src/po/Make_cyg.mak - -Patch 6.3.085 -Problem: Crash in syntax highlighting code. (Marc Espie) -Solution: Prevent current_col going past the end of the line. -Files: src/syntax.c - -Patch 6.3.086 (extra) -Problem: Can't produce message translation file with msgfmt that checks - printf strings. -Solution: Fix the Russian translation. -Files: src/po/ru.po, src/po/ru.cp1251.po - -Patch 6.3.087 -Problem: MS-DOS: Crash. (Jason Hood) -Solution: Don't call fname_case() with a NULL pointer. -Files: src/ex_cmds.c - -Patch 6.3.088 -Problem: Editing ".in" causes error E218. (Stefan Karlsson) -Solution: Require some characters before ".in". Same for ".orig" and others. -Files: runtime/filetype.vim - -Patch 6.3.089 -Problem: A session file doesn't work when created while the current - directory contains a space or the directory of the session files - contains a space. (Paolo Giarrusso) -Solution: Escape spaces with a backslash. -Files: src/ex_docmd.c - -Patch 6.3.090 -Problem: A very big value for 'columns' or 'lines' may cause a crash. -Solution: Limit the values to 10000 and 1000. -Files: src/option.c - -Patch 6.4a.001 -Problem: The Unix Makefile contained too many dependencies and a few - uncommented lines. -Solution: Run "make depend" with manual changes to avoid a gcc - incompatibility. Comment a few lines. -Files: src/Makefile - -Patch 6.4b.001 -Problem: Vim reports "Vim 6.4a" in the ":version" output. -Solution: Change "a" to "b". (Tony Mechelynck) -Files: src/version.h - -Patch 6.4b.002 -Problem: In Insert mode, pasting a multi-byte character after the end of - the line leaves the cursor just before that character. -Solution: Make sure "gP" leaves the cursor in the right place when - 'virtualedit' is set. -Files: src/ops.c - -Patch 6.4b.003 (after 6.4b.002) -Problem: The problem still exists when 'encoding' is set to "cp936". -Solution: Fix the problem in getvvcol(), compute the coladd field correctly. -Files: src/charset.c, src/ops.c - -Patch 6.4b.004 -Problem: Selecting a {} block with "viB" includes the '}' when there is an - empty line before it. -Solution: Don't advance the cursor to include a line break when it's already - at the line break. -Files: src/search.c - - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/version7.txt b/share/vim/vim72/doc/version7.txt deleted file mode 100644 index fecac5395b..0000000000 --- a/share/vim/vim72/doc/version7.txt +++ /dev/null @@ -1,7146 +0,0 @@ -*version7.txt* For Vim version 7.2. Last change: 2008 Aug 09 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - *vim7* -Welcome to Vim 7! A large number of features has been added. This file -mentions all the new items, changes to existing features and bug fixes -since Vim 6.x. Use this command to see the version you are using: > - :version - -See |vi_diff.txt| for an overview of differences between Vi and Vim 7.0. -See |version4.txt| for differences between Vim 3.x and Vim 4.x. -See |version5.txt| for differences between Vim 4.x and Vim 5.x. -See |version6.txt| for differences between Vim 5.x and Vim 6.x. - -INCOMPATIBLE CHANGES |incompatible-7| - -NEW FEATURES |new-7| - -Vim script enhancements |new-vim-script| -Spell checking |new-spell| -Omni completion |new-omni-completion| -MzScheme interface |new-MzScheme| -Printing multi-byte text |new-print-multi-byte| -Tab pages |new-tab-pages| -Undo branches |new-undo-branches| -Extended Unicode support |new-more-unicode| -More highlighting |new-more-highlighting| -Translated manual pages |new-manpage-trans| -Internal grep |new-vimgrep| -Scroll back in messages |new-scroll-back| -Cursor past end of the line |new-onemore| -POSIX compatibility |new-posix| -Debugger support |new-debug-support| -Remote file explorer |new-netrw-explore| -Define an operator |new-define-operator| -Mapping to an expression |new-map-expression| -Visual and Select mode mappings |new-map-select| -Location list |new-location-list| -Various new items |new-items-7| - -IMPROVEMENTS |improvements-7| - -COMPILE TIME CHANGES |compile-changes-7| - -BUG FIXES |bug-fixes-7| - -VERSION 7.1 |version-7.1| -Changed |changed-7.1| -Added |added-7.1| -Fixed |fixed-7.1| - -VERSION 7.2 |version-7.2| -Changed |changed-7.2| -Added |added-7.2| -Fixed |fixed-7.2| - -============================================================================== -INCOMPATIBLE CHANGES *incompatible-7* - -These changes are incompatible with previous releases. Check this list if you -run into a problem when upgrading from Vim 6.x to 7.0. - -A ":write file" command no longer resets the 'modified' flag of the buffer, -unless the '+' flag is in 'cpoptions' |cpo-+|. This was illogical, since the -buffer is still modified compared to the original file. And when undoing -all changes the file would actually be marked modified. It does mean that -":quit" fails now. - -":helpgrep" now uses a help window to display a match. - -In an argument list double quotes could be used to include spaces in a file -name. This caused a difference between ":edit" and ":next" for escaping -double quotes and it is incompatible with some versions of Vi. - Command Vim 6.x file name Vim 7.x file name ~ - :edit foo\"888 foo"888 foo"888 - :next foo\"888 foo888 foo"888 - :next a\"b c\"d ab cd a"b and c"d - -In a |literal-string| a single quote can be doubled to get one. -":echo 'a''b'" would result in "a b", but now that two quotes stand for one it -results in "a'b". - -When overwriting a file with ":w! fname" there was no warning for when "fname" -was being edited by another Vim. Vim now gives an error message |E768|. - -The support for Mac OS 9 has been removed. - -Files ending in .tex now have 'filetype' set to "context", "plaintex", or -"tex". |ft-tex-plugin| - - -Minor incompatibilities: - -For filetype detection: For many types, use */.dir/filename instead of -~/.dir/filename, so that it also works for other user's files. - -For quite a few filetypes the indent settings have been moved from the -filetype plugin to the indent plugin. If you used: > - :filetype plugin on -Then some indent settings may be missing. You need to use: > - :filetype plugin indent on - -":0verbose" now sets 'verbose' to zero instead of one. - -Removed the old and incomplete "VimBuddy" code. - -Buffers without a name report "No Name" instead of "No File". It was -confusing for buffers with a name and 'buftype' set to "nofile". - -When ":file xxx" is used in a buffer without a name, the alternate file name -isn't set. This avoids creating buffers without a name, they are not useful. - -The "2html.vim" script now converts closed folds to HTML. This means the HTML -looks like it's displayed, with the same folds open and closed. Use "zR", or -"let html_ignore_folding=1", if no folds should appear in the HTML. (partly by -Carl Osterwisch) -Diff mode is now also converted to HTML as it is displayed. - -Win32: The effect of the <F10> key depended on 'winaltkeys'. Now it depends -on whether <F10> has been mapped or not. This allows mapping <F10> without -changing 'winaltkeys'. - -When 'octal' is in 'nrformats' and using CTRL-A on "08" it became "018", which -is illogical. Now it becomes "9". The leading zero(s) is(are) removed to -avoid the number becoming octal after incrementing "009" to "010". - -When 'encoding' is set to a Unicode encoding, the value for 'fileencodings' -now includes "default" before "latin1". This means that for files with 8-bit -encodings the default is to use the encoding specified by the environment, if -possible. Previously latin1 would always be used, which is wrong in a -non-latin1 environment, such as Russian. - -Previously Vim would exit when there are two windows, both of them displaying -a help file, and using ":quit". Now only the window is closed. - -"-w {scriptout}" only works when {scriptout} doesn't start with a digit. -Otherwise it's used to set the 'window' option. - -Previously <Home> and <xHome> could be mapped separately. This had the -disadvantage that all mappings (with modifiers) had to be duplicated, since -you can't be sure what the keyboard generates. Now all <xHome> are internally -translated to <Home>, both for the keys and for mappings. Also for <xEnd>, -<xF1>, etc. - -":put" now leaves the cursor on the last inserted line. - -When a .gvimrc file exists then 'compatible' is off, just like when a ".vimrc" -file exists. - -When making a string upper-case with "vlllU" or similar then the German sharp -s is replaced with "SS". This does not happen with "~" to avoid backwards -compatibility problems and because "SS" can't be changed back to a sharp s. - -"gd" previously found the very first occurrence of a variable in a function, -that could be the function argument without type. Now it finds the position -where the type is given. - -The line continuation in functions was not taken into account, line numbers in -errors were logical lines, not lines in the sourced file. That made it -difficult to locate errors. Now the line number in the sourced file is -reported, relative to the function start. This also means that line numbers -for ":breakadd func" are different. - -When defining a user command with |:command| the special items could be -abbreviated. This caused unexpected behavior, such as <li> being recognized -as <line1>. The items can no longer be abbreviated. - -When executing a FileChangedRO autocommand it is no longer allowed to switch -to another buffer or edit another file. This is to prevent crashes (the event -is triggered deep down in the code where changing buffers is not anticipated). -It is still possible to reload the buffer. - -At the |more-prompt| and the |hit-enter-prompt|, when the 'more' option is -set, the 'k', 'u', 'g' and 'b' keys are now used to scroll back to previous -messages. Thus they are no longer used as typeahead. - -============================================================================== -NEW FEATURES *new-7* - -Vim script enhancements *new-vim-script* ------------------------ - -In Vim scripts the following types have been added: - - |List| ordered list of items - |Dictionary| associative array of items - |Funcref| reference to a function - -Many functions and commands have been added to support the new types. - -The |string()| function can be used to get a string representation of a -variable. Works for Numbers, Strings and composites of them. Then |eval()| -can be used to turn the string back into the variable value. - -The |:let| command can now use "+=", "-=" and ".=": > - :let var += expr " works like :let var = var + expr - :let var -= expr " works like :let var = var - expr - :let var .= string " works like :let var = var . string - -With the |:profile| command you can find out where your function or script -is wasting time. - -In the Python interface vim.eval() also handles Dictionaries and Lists. -|python-eval| (G. Sumner Hayes) - -The |getscript| plugin was added as a convenient way to update scripts from -www.vim.org automatically. (Charles Campbell) - -The |vimball| plugin was added as a convenient way to distribute a set of -files for a plugin (plugin file, autoload script, documentation). (Charles -Campbell) - - -Spell checking *new-spell* --------------- - -Spell checking has been integrated in Vim. There were a few implementations -with scripts, but they were slow and/or required an external program. - -The 'spell' option is used to switch spell checking on or off -The 'spelllang' option is used to specify the accepted language(s) -The 'spellfile' option specifies where new words are added -The 'spellsuggest' option specifies the methods used for making suggestions - -The |[s| and |]s| commands can be used to move to the next or previous error -The |zg| and |zw| commands can be used to add good and wrong words -The |z=| command can be used to list suggestions and correct the word -The |:mkspell| command is used to generate a Vim spell file from word lists - -The "undercurl" highlighting attribute was added to nicely point out spelling -mistakes in the GUI (based on patch from Marcin Dalecki). -The "guisp" color can be used to give it a color different from foreground and -background. -The number of possible different highlight attributes was raised from about -220 to over 30000. This allows for the attributes of spelling to be combined -with syntax highlighting attributes. This is also used for syntax -highlighting and marking the Visual area. - -Much more info here: |spell|. - - -Omni completion *new-omni-completion* ---------------- - -This could also be called "intellisense", but that is a trademark. It is a -smart kind of completion. The text in front of the cursor is inspected to -figure out what could be following. This may suggest struct and class -members, system functions, etc. - -Use CTRL-X CTRL-O in Insert mode to start the completion. |i_CTRL-X_CTRL-O| - -The 'omnifunc' option is set by filetype plugins to define the function that -figures out the completion. - -Currently supported languages: - C |ft-c-omni| - (X)HTML with CSS |ft-html-omni| - JavaScript |ft-javascript-omni| - PHP |ft-php-omni| - Python - Ruby |ft-ruby-omni| - SQL |ft-sql-omni| - XML |ft-xml-omni| - any language with syntax highlighting |ft-syntax-omni| - -You can add your own omni completion scripts. - -When the 'completeopt' option contains "menu" then matches for Insert mode -completion are displayed in a (rather primitive) popup menu. - - -MzScheme interface *new-MzScheme* ------------------- - -The MzScheme interpreter is supported. |MzScheme| - -The |:mzscheme| command can be used to execute MzScheme commands -The |:mzfile| command can be used to execute an MzScheme script file - -This depends on Vim being compiled with the |+mzscheme| feature. - - -Printing multi-byte text *new-print-multi-byte* ------------------------- - -The |:hardcopy| command now supports printing multi-byte characters when using -PostScript. - -The 'printmbcharset' and 'printmbfont' options are used for this. -Also see |postscript-cjk-printing|. (Mike Williams) - - -Tab pages *new-tab-pages* ---------- - -A tab page is page with one or more windows with a label (aka tab) at the top. -By clicking on the label you can quickly switch between the tab pages. And -with the keyboard, using the |gt| (Goto Tab) command. This is a convenient -way to work with many windows. - -To start Vim with each file argument in a separate tab page use the |-p| -argument. The maximum number of pages can be set with 'tabpagemax'. - -The line with tab labels is either made with plain text and highlighting or -with a GUI mechanism. The GUI labels look better but are only available on a -few systems. The line can be customized with 'tabline', 'guitablabel' and -'guitabtooltip'. Whether it is displayed is set with 'showtabline'. Whether -to use the GUI labels is set with the "e" flag in 'guioptions'. - -The |:tab| command modifier can be used to have most commands that open a new -window open a new tab page instead. - -The |--remote-tab| argument can be used to edit a file in a new tab page in an -already running Vim server. - -Variables starting with "t:" are local to a tab page. - -More info here: |tabpage| -Most of the GUI stuff was implemented by Yegappan Lakshmanan. - - -Undo branches *new-undo-branches* -------------- - -Previously there was only one line of undo-redo. If, after undoing a number -of changes, a new change was made all the undone changes were lost. This -could lead to accidentally losing work. - -Vim now makes an undo branch in this situation. Thus you can go back to the -text after any change, even if they were undone. So long as you do not run -into 'undolevels', when undo information is freed up to limit the memory used. - -To be able to navigate the undo branches each change is numbered sequentially. -The commands |g-| and |:earlier| go back in time, to older changes. The -commands |g+| and |:later| go forward in time, to newer changes. - -The changes are also timestamped. Use ":earlier 10m" to go to the text as it -was about ten minutes earlier. - -The |:undolist| command can be used to get an idea of which undo branches -exist. The |:undo| command now takes an argument to directly jump to a -specific position in this list. The |changenr()| function can be used to -obtain the change number. - -There is no graphical display of the tree with changes, navigation can be -quite confusing. - - -Extended Unicode support *new-more-unicode* ------------------------- - -Previously only two combining characters were displayed. The limit is now -raised to 6. This can be set with the 'maxcombine' option. The default is -still 2. - -|ga| now shows all combining characters, not just the first two. - -Previously only 16 bit Unicode characters were supported for displaying. Now -the full 32 bit character set can be used. Unless manually disabled at -compile time to save a bit of memory. - -For pattern matching it is now possible to search for individual composing -characters. |patterns-composing| - -The |8g8| command searches for an illegal UTF-8 byte sequence. - - -More highlighting *new-more-highlighting* ------------------ - -Highlighting matching parens: - -When moving the cursor through the text and it is on a paren, then the -matching paren can be highlighted. This uses the new |CursorMoved| -autocommand event. - -This means some commands are executed every time you move the cursor. If this -slows you down too much switch it off with: > - :NoMatchParen - -See |matchparen| for more information. - -The plugin uses the |:match| command. It now supports three match patterns. -The plugin uses the third one. The first one is for the user and the second -one can be used by another plugin. - -Highlighting the cursor line and column: - -The 'cursorline' and 'cursorcolumn' options have been added. These highlight -the screen line and screen column of the cursor. This makes the cursor -position easier to spot. 'cursorcolumn' is also useful to align text. This -may make screen updating quite slow. The CursorColumn and CursorLine -highlight groups allow changing the colors used. |hl-CursorColumn| -|hl-CursorLine| - -The number of possible different highlight attributes was raised from about -220 to over 30000. This allows for the attributes of spelling to be combined -with syntax highlighting attributes. This is also used for syntax -highlighting, marking the Visual area, CursorColumn, etc. - - -Translated manual pages *new-manpage-trans* ------------------------ - -The manual page of Vim and associated programs is now also available in -several other languages. - -French - translated by David Blanchet -Italian - translated by Antonio Colombo -Russian - translated by Vassily Ragosin -Polish - translated by Mikolaj Machowski - -The Unix Makefile installs the Italian manual pages in .../man/it/man1/, -.../man/it.ISO8859-1/man1/ and .../man/it.UTF-8/man1/. There appears to be no -standard for what encoding goes in the "it" directory, the 8-bit encoded file -is used there as a best guess. -Other languages are installed in similar places. -The translated pages are not automatically installed when Vim was configured -with "--disable-nls", but "make install-languages install-tool-languages" will -do it anyway. - - -Internal grep *new-vimgrep* -------------- - -The ":vimgrep" command can be used to search for a pattern in a list of files. -This is like the ":grep" command, but no external program is used. Besides -better portability, handling of different file encodings and using multi-line -patterns, this also allows grepping in compressed and remote files. -|:vimgrep|. - -If you want to use the search results in a script you can use the -|getqflist()| function. - -To grep files in various directories the "**" pattern can be used. It expands -into an arbitrary depth of directories. "**" can be used in all places where -file names are expanded, thus also with |:next| and |:args|. - - -Scroll back in messages *new-scroll-back* ------------------------ - -When displaying messages, at the |more-prompt| and the |hit-enter-prompt|, The -'k', 'u', 'g' and 'b' keys can be used to scroll back to previous messages. -This is especially useful for commands such as ":syntax", ":autocommand" and -":highlight". This is implemented in a generic way thus it works for all -commands and highlighting is kept. Only works when the 'more' option is set. -Previously it only partly worked for ":clist". - -The |g<| command can be used to see the last page of messages after you have -hit <Enter> at the |hit-enter-prompt|. Then you can scroll further back. - - -Cursor past end of the line *new-onemore* ---------------------------- - -When the 'virtualedit' option contains "onemore" the cursor can move just past -the end of the line. As if it's on top of the line break. - -This makes some commands more consistent. Previously the cursor was always -past the end of the line if the line was empty. But it is far from Vi -compatible. It may also break some plugins or Vim scripts. Use with care! - -The patch was provided by Mattias Flodin. - - -POSIX compatibility *new-posix* -------------------- - -The POSIX test suite was used to verify POSIX compatibility. A number of -problems have been fixed to make Vim more POSIX compatible. Some of them -conflict with traditional Vi or expected behavior. The $VIM_POSIX environment -variable can be set to get POSIX compatibility. See |posix|. - -Items that were fixed for both Vi and POSIX compatibility: -- repeating "R" with a count only overwrites text once; added the 'X' flag to - 'cpoptions' |cpo-X| -- a vertical movement command that moves to a non-existing line fails; added - the '-' flag to 'cpoptions' |cpo--| -- when preserving a file and doing ":q!" the file can be recovered; added the - '&' flag to 'cpoptions' |cpo-&| -- The 'window' option is partly implemented. It specifies how much CTRL-F and - CTRL-B scroll when there is one window. The "-w {number}" argument is now - accepted. "-w {scriptout}" only works when {scriptout} doesn't start with a - digit. -- Allow "-c{command}" argument, no space between "-c" and {command}. -- When writing a file with ":w!" don't reset 'readonly' when 'Z' is present in - 'cpoptions'. -- Allow 'l' and '#' flags for ":list", ":print" and ":number". -- Added the '.' flag to 'cpoptions': ":cd" fails when the buffer is modified. -- In Ex mode with an empty buffer ":read file" doesn't keep an empty line - above or below the new lines. -- Remove a backslash before a NL for the ":global" command. -- When ":append", ":insert" or ":change" is used with ":global", get the - inserted lines from the command. Can use backslash-NL to separate lines. -- Can use ":global /pat/ visual" to execute Normal mode commands at each - matched line. Use "Q" to continue and go to the next line. -- The |:open| command has been partially implemented. It stops Ex mode, but - redraws the whole screen, not just one line as open mode is supposed to do. -- Support using a pipe to read the output from and write input to an external - command. Added the 'shelltemp' option and has("filterpipe"). -- In ex silent mode the ":set" command output is displayed. -- The ":@@" and ":**" give an error message when no register was used before. -- The search pattern "[]-`]" matches ']', '^', '_' and '`'. -- Autoindent for ":insert" is using the line below the insert. -- Autoindent for ":change" is using the first changed line. -- Editing Ex command lines is not done in cooked mode, because CTRL-D and - CTRL-T cannot be handled then. -- In Ex mode, "1,3" prints three lines. "%" prints all lines. -- In Ex mode "undo" would undo all changes since Ex mode was started. -- Implemented the 'prompt' option. - - -Debugger support *new-debug-support* ----------------- - -The 'balloonexpr' option has been added. This is a generic way to implement -balloon functionality. You can use it to show info for the word under the -mouse pointer. - - -Remote file explorer *new-netrw-explore* --------------------- - -The netrw plugin now also supports viewing a directory, when "scp://" is used. -Deleting and renaming files is possible. - -To avoid duplicating a lot of code, the previous file explorer plugin has been -integrated in the netrw plugin. This means browsing local and remote files -works the same way. - -":browse edit" and ":browse split" use the netrw plugin when it's available -and a GUI dialog is not possible. - -The netrw plugin is maintained by Charles Campbell. - - -Define an operator *new-define-operator* ------------------- - -Previously it was not possible to define your own operator; a command that is -followed by a {motion}. Vim 7 introduces the 'operatorfunc' option and the -|g@| operator. This makes it possible to define a mapping that works like an -operator. The actual work is then done by a function, which is invoked -through the |g@| operator. - -See |:map-operator| for the explanation and an example. - - -Mapping to an expression *new-map-expression* ------------------------- - -The {rhs} argument of a mapping can be an expression. That means the -resulting characters can depend on the context. Example: > - :inoremap <expr> . InsertDot() -Here the dot will be mapped to whatever InsertDot() returns. - -This also works for abbreviations. See |:map-<expr>| for the details. - - -Visual and Select mode mappings *new-map-select* -------------------------------- - -Previously Visual mode mappings applied both to Visual and Select mode. With -a trick to have the mappings work in Select mode like they would in Visual -mode. - -Commands have been added to define mappings for Visual and Select mode -separately: |:xmap| and |:smap|. With the associated "noremap" and "unmap" -commands. - -The same is done for menus: |:xmenu|, |:smenu|, etc. - - -Location list *new-location-list* -------------- - -The support for a per-window quickfix list (location list) is added. The -location list can be displayed in a location window (similar to the quickfix -window). You can open more than one location list window. A set of commands -similar to the quickfix commands are added to browse the location list. -(Yegappan Lakshmanan) - - -Various new items *new-items-7* ------------------ - -Normal mode commands: ~ - -a", a' and a` New text objects to select quoted strings. |a'| -i", i' and i` (Taro Muraoka) - -CTRL-W <Enter> In the quickfix window: opens a new window to show the - location of the error under the cursor. - -|at| and |it| text objects select a block of text between HTML or XML tags. - -<A-LeftMouse> ('mousemodel' "popup" or "popup-setpos") -<A-RightMouse> ('mousemodel' "extend") - Make a blockwise selection. |<A-LeftMouse>| - -gF Start editing the filename under the cursor and jump - to the line number following the file name. - (Yegappan Lakshmanan) - -CTRL-W F Start editing the filename under the cursor in a new - window and jump to the line number following the file - name. (Yegappan Lakshmanan) - -Insert mode commands: ~ - -CTRL-\ CTRL-O Execute a Normal mode command. Like CTRL-O but - without moving the cursor. |i_CTRL-\_CTRL-O| - -Options: ~ - -'balloonexpr' expression for text to show in evaluation balloon -'completefunc' The name of the function used for user-specified - Insert mode completion. CTRL-X CTRL-U can be used in - Insert mode to do any kind of completion. (Taro - Muraoka) -'completeopt' Enable popup menu and other settings for Insert mode - completion. -'cursorcolumn' highlight column of the cursor -'cursorline' highlight line of the cursor -'formatexpr' expression for formatting text with |gq| and when text - goes over 'textwidth' in Insert mode. -'formatlistpat' pattern to recognize a numbered list for formatting. - (idea by Hugo Haas) -'fsync' Whether fsync() is called after writing a file. - (Ciaran McCreesh) -'guitablabel' expression for text to display in GUI tab page label -'guitabtooltip' expression for text to display in GUI tab page tooltip -'macatsui' Mac: use ATSUI text display functions -'maxcombine' maximum number of combining characters displayed -'maxmempattern' maximum amount of memory to use for pattern matching -'mkspellmem' parameters for |:mkspell| memory use -'mzquantum' Time in msec to schedule MzScheme threads. -'numberwidth' Minimal width of the space used for the 'number' - option. (Emmanuel Renieris) -'omnifunc' The name of the function used for omni completion. -'operatorfunc' function to be called for |g@| operator -'printmbcharset' CJK character set to be used for :hardcopy -'printmbfont' font names to be used for CJK output of :hardcopy -'pumheight' maximum number of items to show in the popup menu -'quoteescape' Characters used to escape quotes inside a string. - Used for the a", a' and a` text objects. |a'| -'shelltemp' whether to use a temp file or pipes for shell commands -'showtabline' whether to show the tab pages line -'spell' switch spell checking on/off -'spellcapcheck' pattern to locate the end of a sentence -'spellfile' file where good and wrong words are added -'spelllang' languages to check spelling for -'spellsuggest' methods for spell suggestions -'synmaxcol' maximum column to look for syntax items; avoids very - slow redrawing when there are very long lines -'tabline' expression for text to display in the tab pages line -'tabpagemax' maximum number of tab pages to open for |-p| -'verbosefile' Log messages in a file. -'wildoptions' "tagfile" value enables listing the file name of - matching tags for CTRL-D command line completion. - (based on an idea from Yegappan Lakshmanan) -'winfixwidth' window with fixed width, similar to 'winfixheight' - - -Ex commands: ~ - -Win32: The ":winpos" command now also works in the console. (Vipin Aravind) - -|:startreplace| Start Replace mode. (Charles Campbell) -|:startgreplace| Start Virtual Replace mode. - -|:0file| Removes the name of the buffer. (Charles Campbell) - -|:diffoff| Switch off diff mode in the current window or in all - windows. - -|:delmarks| Delete marks. - -|:exusage| Help for Ex commands (Nvi command). -|:viusage| Help for Vi commands (Nvi command). - -|:sort| Sort lines in the buffer without depending on an - external command. (partly by Bryce Wagner) - -|:vimgrep| Internal grep command, search for a pattern in files. -|:vimgrepadd| Like |:vimgrep| but don't make a new list. - -|:caddfile| Add error messages to an existing quickfix list - (Yegappan Lakshmanan). -|:cbuffer| Read error lines from a buffer. (partly by Yegappan - Lakshmanan) -|:cgetbuffer| Create a quickfix list from a buffer but don't jump to - the first error. -|:caddbuffer| Add errors from the current buffer to the quickfix - list. -|:cexpr| Read error messages from a Vim expression (Yegappan - Lakshmanan). -|:caddexpr| Add error messages from a Vim expression to an - existing quickfix list. (Yegappan Lakshmanan). -|:cgetexpr| Create a quickfix list from a Vim expression, but - don't jump to the first error. (Yegappan Lakshmanan). - -|:lfile| Like |:cfile| but use the location list. -|:lgetfile| Like |:cgetfile| but use the location list. -|:laddfile| Like |:caddfile| but use the location list. -|:lbuffer| Like |:cbuffer| but use the location list. -|:lgetbuffer| Like |:cgetbuffer| but use the location list. -|:laddbuffer| Like |:caddbuffer| but use the location list. -|:lexpr| Like |:cexpr| but use the location list. -|:lgetexpr| Like |:cgetexpr| but use the location list. -|:laddexpr| Like |:caddexpr| but use the location list. -|:ll| Like |:cc| but use the location list. -|:llist| Like |:clist| but use the location list. -|:lnext| Like |:cnext| but use the location list. -|:lprevious| Like |:cprevious| but use the location list. -|:lNext| Like |:cNext| but use the location list. -|:lfirst| Like |:cfirst| but use the location list. -|:lrewind| Like |:crewind| but use the location list. -|:llast| Like |:clast| but use the location list. -|:lnfile| Like |:cnfile| but use the location list. -|:lpfile| Like |:cpfile| but use the location list. -|:lNfile| Like |:cNfile| but use the location list. -|:lolder| Like |:colder| but use the location list. -|:lnewer| Like |:cnewer| but use the location list. -|:lwindow| Like |:cwindow| but use the location list. -|:lopen| Like |:copen| but use the location list. -|:lclose| Like |:cclose| but use the location list. -|:lmake| Like |:make| but use the location list. -|:lgrep| Like |:grep| but use the location list. -|:lgrepadd| Like |:grepadd| but use the location list. -|:lvimgrep| Like |:vimgrep| but use the location list. -|:lvimgrepadd| Like |:vimgrepadd| but use the location list. -|:lhelpgrep| Like |:helpgrep| but use the location list. -|:lcscope| Like |:cscope| but use the location list. -|:ltag| Jump to a tag and add matching tags to a location list. - -|:undojoin| Join a change with the previous undo block. -|:undolist| List the leafs of the undo tree. - -|:earlier| Go back in time for changes in the text. -|:later| Go forward in time for changes in the text. - -|:for| Loop over a |List|. -|:endfor| - -|:lockvar| Lock a variable, prevents it from being changed. -|:unlockvar| Unlock a locked variable. - -|:mkspell| Create a Vim spell file. -|:spellgood| Add a word to the list of good words. -|:spellwrong| Add a word to the list of bad words -|:spelldump| Dump list of good words. -|:spellinfo| Show information about the spell files used. -|:spellrepall| Repeat a spelling correction for the whole buffer. -|:spellundo| Remove a word from list of good and bad words. - -|:mzscheme| Execute MzScheme commands. -|:mzfile| Execute an MzScheme script file. - -|:nbkey| Pass a key to NetBeans for processing. - -|:profile| Commands for Vim script profiling. -|:profdel| Stop profiling for specified items. - -|:smap| Select mode mapping. -|:smapclear| -|:snoremap| -|:sunmap| - -|:xmap| Visual mode mapping, not used for Select mode. -|:xmapclear| -|:xnoremap| -|:xunmap| - -|:smenu| Select mode menu. -|:snoremenu| -|:sunmenu| - -|:xmenu| Visual mode menu, not used for Select mode. -|:xnoremenu| -|:xunmenu| - -|:tabclose| Close the current tab page. -|:tabdo| Perform a command in every tab page. -|:tabedit| Edit a file in a new tab page. -|:tabnew| Open a new tab page. -|:tabfind| Search for a file and open it in a new tab page. -|:tabnext| Go to the next tab page. -|:tabprevious| Go to the previous tab page. -|:tabNext| Go to the previous tab page. -|:tabfirst| Go to the first tab page. -|:tabrewind| Go to the first tab page. -|:tablast| Go to the last tab page. -|:tabmove| Move the current tab page elsewhere. -|:tabonly| Close all other tab pages. -|:tabs| List the tab pages and the windows they contain. - -Ex command modifiers: ~ - -|:keepalt| Do not change the alternate file. - -|:noautocmd| Do not trigger autocommand events. - -|:sandbox| Execute a command in the sandbox. - -|:tab| When opening a new window create a new tab page. - - -Ex command arguments: ~ - -|++bad| Specify what happens with characters that can't be - converted and illegal bytes. (code example by Yasuhiro - Matsumoto) - Also, when a conversion error occurs or illegal bytes - are found include the line number in the error - message. - - -New and extended functions: ~ - -|add()| append an item to a List -|append()| append List of lines to the buffer -|argv()| without an argument return the whole argument list -|browsedir()| dialog to select a directory -|bufnr()| takes an extra argument: create buffer -|byteidx()| index of a character (Ilya Sher) -|call()| call a function with List as arguments -|changenr()| number of current change -|complete()| set matches for Insert mode completion -|complete_add()| add match for 'completefunc' -|complete_check()| check for key pressed, for 'completefunc' -|copy()| make a shallow copy of a List or Dictionary -|count()| count nr of times a value is in a List or Dictionary -|cursor()| also accepts an offset for 'virtualedit', and - the first argument can be a list: [lnum, col, off] -|deepcopy()| make a full copy of a List or Dictionary -|diff_filler()| returns number of filler lines above line {lnum}. -|diff_hlID()| returns the highlight ID for diff mode -|empty()| check if List or Dictionary is empty -|eval()| evaluate {string} and return the result -|extend()| append one List to another or add items from one - Dictionary to another -|feedkeys()| put characters in the typeahead buffer -|filter()| remove selected items from a List or Dictionary -|finddir()| find a directory in 'path' -|findfile()| find a file in 'path' (Johannes Zellner) -|foldtextresult()| the text displayed for a closed fold at line "lnum" -|function()| make a Funcref out of a function name -|garbagecollect()| cleanup unused |Lists| and |Dictionaries| with circular - references -|get()| get an item from a List or Dictionary -|getbufline()| get a list of lines from a specified buffer - (Yegappan Lakshmanan) -|getcmdtype()| return the current command-line type - (Yegappan Lakshmanan) -|getfontname()| get actual font name being used -|getfperm()| get file permission string (Nikolai Weibull) -|getftype()| get type of file (Nikolai Weibull) -|getline()| with second argument: get List with buffer lines -|getloclist()| list of location list items (Yegappan Lakshmanan) -|getpos()| return a list with the position of cursor, mark, etc. -|getqflist()| list of quickfix errors (Yegappan Lakshmanan) -|getreg()| get contents of a register -|gettabwinvar()| get variable from window in specified tab page. -|has_key()| check whether a key appears in a Dictionary -|haslocaldir()| check if current window used |:lcd| -|hasmapto()| check for a mapping to a string -|index()| index of item in List -|inputlist()| prompt the user to make a selection from a list -|insert()| insert an item somewhere in a List -|islocked()| check if a variable is locked -|items()| get List of Dictionary key-value pairs -|join()| join List items into a String -|keys()| get List of Dictionary keys -|len()| number of items in a List or Dictionary -|map()| change each List or Dictionary item -|maparg()| extra argument: use abbreviation -|mapcheck()| extra argument: use abbreviation -|match()| extra argument: count -|matcharg()| return arguments of |:match| command -|matchend()| extra argument: count -|matchlist()| list with match and submatches of a pattern in a string -|matchstr()| extra argument: count -|max()| maximum value in a List or Dictionary -|min()| minimum value in a List or Dictionary -|mkdir()| create a directory -|pathshorten()| reduce directory names to a single character -|printf()| format text -|pumvisible()| check whether the popup menu is displayed -|range()| generate a List with numbers -|readfile()| read a file into a list of lines -|reltime()| get time value, possibly relative -|reltimestr()| turn a time value into a string -|remove()| remove one or more items from a List or Dictionary -|repeat()| repeat "expr" "count" times (Christophe Poucet) -|reverse()| reverse the order of a List -|search()| extra argument: -|searchdecl()| search for declaration of variable -|searchpair()| extra argument: line to stop searching -|searchpairpos()| return a List with the position of the match -|searchpos()| return a List with the position of the match -|setloclist()| modify a location list (Yegappan Lakshmanan) -|setpos()| set cursor or mark to a position -|setqflist()| modify a quickfix list (Yegappan Lakshmanan) -|settabwinvar()| set variable in window of specified tab page -|sort()| sort a List -|soundfold()| get the sound-a-like equivalent of a word -|spellbadword()| get a badly spelled word -|spellsuggest()| get suggestions for correct spelling -|split()| split a String into a List -|str2nr()| convert a string to a number, base 8, 10 or 16 -|stridx()| extra argument: start position -|strridx()| extra argument: start position -|string()| string representation of a List or Dictionary -|system()| extra argument: filters {input} through a shell command -|tabpagebuflist()| List of buffers in a tab page -|tabpagenr()| number of current or last tab page -|tabpagewinnr()| window number in a tab page -|tagfiles()| List with tags file names -|taglist()| get list of matching tags (Yegappan Lakshmanan) -|tr()| translate characters (Ron Aaron) -|values()| get List of Dictionary values -|winnr()| takes an argument: what window to use -|winrestview()| restore the view of the current window -|winsaveview()| save the view of the current window -|writefile()| write a list of lines into a file - -User defined functions can now be loaded automatically from the "autoload" -directory in 'runtimepath'. See |autoload-functions|. - - -New Vim variables: ~ - -|v:insertmode| used for |InsertEnter| and |InsertChange| autocommands -|v:val| item value in a |map()| or |filter()| function -|v:key| item key in a |map()| or |filter()| function -|v:profiling| non-zero after a ":profile start" command -|v:fcs_reason| the reason why |FileChangedShell| was triggered -|v:fcs_choice| what should happen after |FileChangedShell| -|v:beval_bufnr| buffer number for 'balloonexpr' -|v:beval_winnr| window number for 'balloonexpr' -|v:beval_lnum| line number for 'balloonexpr' -|v:beval_col| column number for 'balloonexpr' -|v:beval_text| text under the mouse pointer for 'balloonexpr' -|v:scrollstart| what caused the screen to be scrolled up -|v:swapname| name of the swap file for the |SwapExists| event -|v:swapchoice| what to do for an existing swap file -|v:swapcommand| command to be executed after handling |SwapExists| -|v:char| argument for evaluating 'formatexpr' - - -New autocommand events: ~ - -|ColorScheme| after loading a color scheme - -|CursorHoldI| the user doesn't press a key for a while in Insert mode -|CursorMoved| the cursor was moved in Normal mode -|CursorMovedI| the cursor was moved in Insert mode - -|FileChangedShellPost| after handling a file changed outside of Vim - -|InsertEnter| starting Insert or Replace mode -|InsertChange| going from Insert to Replace mode or back -|InsertLeave| leaving Insert or Replace mode - -|MenuPopup| just before showing popup menu - -|QuickFixCmdPre| before :make, :grep et al. (Ciaran McCreesh) -|QuickFixCmdPost| after :make, :grep et al. (Ciaran McCreesh) - -|SessionLoadPost| after loading a session file. (Yegappan Lakshmanan) - -|ShellCmdPost| after executing a shell command -|ShellFilterPost| after filtering with a shell command - -|SourcePre| before sourcing a Vim script - -|SpellFileMissing| when a spell file can't be found - -|SwapExists| found existing swap file when editing a file - -|TabEnter| just after entering a tab page -|TabLeave| just before leaving a tab page - -|VimResized| after the Vim window size changed (Yakov Lerner) - - -New highlight groups: ~ - -Pmenu Popup menu: normal item |hl-Pmenu| -PmenuSel Popup menu: selected item |hl-PmenuSel| -PmenuThumb Popup menu: scrollbar |hl-PmenuThumb| -PmenuSbar Popup menu: Thumb of the scrollbar |hl-PmenuSbar| - -TabLine tab pages line, inactive label |hl-TabLine| -TabLineSel tab pages line, selected label |hl-TabLineSel| -TabLineFill tab pages line, filler |hl-TabLineFill| - -SpellBad badly spelled word |hl-SpellBad| -SpellCap word with wrong caps |hl-SpellCap| -SpellRare rare word |hl-SpellRare| -SpellLocal word only exists in other region |hl-SpellLocal| - -CursorColumn 'cursorcolumn' |hl-CursorColumn| -CursorLine 'cursorline' |hl-CursorLine| - -MatchParen matching parens |pi_paren.txt| |hl-MatchParen| - - -New items in search patterns: ~ -|/\%d| \%d123 search for character with decimal number -|/\]| [\d123] idem, in a collection -|/\%o| \%o103 search for character with octal number -|/\]| [\o1o3] idem, in a collection -|/\%x| \%x1a search for character with 2 pos. hex number -|/\]| [\x1a] idem, in a collection -|/\%u| \%u12ab search for character with 4 pos. hex number -|/\]| [\u12ab] idem, in a collection -|/\%U| \%U1234abcd search for character with 8 pos. hex number -|/\]| [\U1234abcd] idem, in a collection - (The above partly by Ciaran McCreesh) - -|/[[=| [[=a=]] an equivalence class (only for latin1 characters) -|/[[.| [[.a.]] a collation element (only works with single char) - -|/\%'m| \%'m match at mark m -|/\%<'m| \%<'m match before mark m -|/\%>'m| \%>'m match after mark m -|/\%V| \%V match in Visual area - -Nesting |/multi| items no longer is an error when an empty match is possible. - -It is now possible to use \{0}, it matches the preceding atom zero times. Not -useful, just for compatibility. - - -New Syntax/Indent/FTplugin files: ~ - -Moved all the indent settings from the filetype plugin to the indent file. -Implemented b:undo_indent to undo indent settings when setting 'filetype' to a -different value. - -a2ps syntax and ftplugin file. (Nikolai Weibull) -ABAB/4 syntax file. (Marius van Wyk) -alsaconf ftplugin file. (Nikolai Weibull) -AppendMatchGroup ftplugin file. (Dave Silvia) -arch ftplugin file. (Nikolai Weibull) -asterisk and asteriskvm syntax file. (Tilghman Lesher) -BDF ftplugin file. (Nikolai Weibull) -BibTeX indent file. (Dorai Sitaram) -BibTeX Bibliography Style syntax file. (Tim Pope) -BTM ftplugin file. (Bram Moolenaar) -calendar ftplugin file. (Nikolai Weibull) -Changelog indent file. (Nikolai Weibull) -ChordPro syntax file. (Niels Bo Andersen) -Cmake indent and syntax file. (Andy Cedilnik) -conf ftplugin file. (Nikolai Weibull) -context syntax and ftplugin file. (Nikolai Weibull) -CRM114 ftplugin file. (Nikolai Weibull) -cvs RC ftplugin file. (Nikolai Weibull) -D indent file. (Jason Mills) -Debian Sources.list syntax file. (Matthijs Mohlmann) -dictconf and dictdconf syntax, indent and ftplugin files. (Nikolai Weibull) -diff ftplugin file. (Bram Moolenaar) -dircolors ftplugin file. (Nikolai Weibull) -django and htmldjango syntax file. (Dave Hodder) -doxygen syntax file. (Michael Geddes) -elinks ftplugin file. (Nikolai Weibull) -eterm ftplugin file. (Nikolai Weibull) -eviews syntax file. (Vaidotas Zemlys) -fetchmail RC ftplugin file. (Nikolai Weibull) -FlexWiki syntax and ftplugin file. (George Reilly) -Generic indent file. (Dave Silvia) -gpg ftplugin file. (Nikolai Weibull) -gretl syntax file. (Vaidotas Zemlys) -groovy syntax file. (Alessio Pace) -group syntax and ftplugin file. (Nikolai Weibull) -grub ftplugin file. (Nikolai Weibull) -Haskell ftplugin file. (Nikolai Weibull) -help ftplugin file. (Nikolai Weibull) -indent ftplugin file. (Nikolai Weibull) -Javascript ftplugin file. (Bram Moolenaar) -Kconfig ftplugin and syntax file. (Nikolai Weibull) -ld syntax, indent and ftplugin file. (Nikolai Weibull) -lftp ftplugin file. (Nikolai Weibull) -libao config ftplugin file. (Nikolai Weibull) -limits syntax and ftplugin file. (Nikolai Weibull) -Lisp indent file. (Sergey Khorev) -loginaccess and logindefs syntax and ftplugin file. (Nikolai Weibull) -m4 ftplugin file. (Nikolai Weibull) -mailaliases syntax file. (Nikolai Weibull) -mailcap ftplugin file. (Nikolai Weibull) -manconf syntax and ftplugin file. (Nikolai Weibull) -matlab ftplugin file. (Jake Wasserman) -Maxima syntax file. (Robert Dodier) -MGL syntax file. (Gero Kuhlmann) -modconf ftplugin file. (Nikolai Weibull) -mplayer config ftplugin file. (Nikolai Weibull) -Mrxvtrc syntax and ftplugin file. (Gautam Iyer) -MuPAD source syntax, indent and ftplugin. (Dave Silvia) -mutt RC ftplugin file. (Nikolai Weibull) -nanorc syntax and ftplugin file. (Nikolai Weibull) -netrc ftplugin file. (Nikolai Weibull) -pamconf syntax and ftplugin file. (Nikolai Weibull) -Pascal indent file. (Neil Carter) -passwd syntax and ftplugin file. (Nikolai Weibull) -PHP compiler plugin. (Doug Kearns) -pinfo ftplugin file. (Nikolai Weibull) -plaintex syntax and ftplugin files. (Nikolai Weibull, Benji Fisher) -procmail ftplugin file. (Nikolai Weibull) -prolog ftplugin file. (Nikolai Weibull) -protocols syntax and ftplugin file. (Nikolai Weibull) -quake ftplugin file. (Nikolai Weibull) -racc syntax and ftplugin file. (Nikolai Weibull) -readline ftplugin file. (Nikolai Weibull) -rhelp syntax file. (Johannes Ranke) -rnoweb syntax file. (Johannes Ranke) -Relax NG compact ftplugin file. (Nikolai Weibull) -Scheme indent file. (Sergey Khorev) -screen ftplugin file. (Nikolai Weibull) -sensors syntax and ftplugin file. (Nikolai Weibull) -services syntax and ftplugin file. (Nikolai Weibull) -setserial syntax and ftplugin file. (Nikolai Weibull) -sieve syntax and ftplugin file. (Nikolai Weibull) -SiSU syntax file (Ralph Amissah) -Sive syntax file. (Nikolai Weibull) -slp config, reg and spi syntax and ftplugin files. (Nikolai Weibull) -SML indent file. (Saikat Guha) -SQL anywhere syntax and indent file. (David Fishburn) -SQL indent file. -SQL-Informix syntax file. (Dean L Hill) -SQL: Handling of various variants. (David Fishburn) -sshconfig ftplugin file. (Nikolai Weibull) -Stata and SMCL syntax files. (Jeff Pitblado) -sudoers ftplugin file. (Nikolai Weibull) -sysctl syntax and ftplugin file. (Nikolai Weibull) -terminfo ftplugin file. (Nikolai Weibull) -trustees syntax file. (Nima Talebi) -Vera syntax file. (David Eggum) -udev config, permissions and rules syntax and ftplugin files. (Nikolai Weibull) -updatedb syntax and ftplugin file. (Nikolai Weibull) -VHDL indent file (Gerald Lai) -WSML syntax file. (Thomas Haselwanter) -Xdefaults ftplugin file. (Nikolai Weibull) -XFree86 config ftplugin file. (Nikolai Weibull) -xinetd syntax, indent and ftplugin file. (Nikolai Weibull) -xmodmap ftplugin file. (Nikolai Weibull) -Xquery syntax file. (Jean-Marc Vanel) -xsd (XML schema) indent file. -YAML ftplugin file. (Nikolai Weibull) -Zsh ftplugin file. (Nikolai Weibull) - - -New Keymaps: ~ - -Sinhala (Sri Lanka) (Harshula Jayasuriya) -Tamil in TSCII encoding (Yegappan Lakshmanan) -Greek in cp737 (Panagiotis Louridas) -Polish-slash (HS6_06) -Ukrainian-jcuken (Anatoli Sakhnik) -Kana (Edward L. Fox) - - -New message translations: ~ - -The Ukrainian messages are now also available in cp1251. -Vietnamese message translations and menu. (Phan Vinh Thinh) - - -Others: ~ - -The |:read| command has the |++edit| argument. This means it will use the -detected 'fileformat', 'fileencoding' and other options for the buffer. This -also fixes the problem that editing a compressed file didn't set these -options. - -The Netbeans interface was updated for Sun Studio 10. The protocol number -goes from 2.2 to 2.3. (Gordon Prieur) - -Mac: When starting up Vim will load the $VIMRUNTIME/macmap.vim script to -define default command-key mappings. (mostly by Benji Fisher) - -Mac: Add the selection type to the clipboard, so that Block, line and -character selections can be used between two Vims. (Eckehard Berns) -Also fixes the problem that setting 'clipboard' to "unnamed" breaks using -"yyp". - -Mac: GUI font selector. (Peter Cucka) - -Mac: support for multi-byte characters. (Da Woon Jung) -This doesn't always work properly. If you see text drawing problems try -switching the 'macatsui' option off. - -Mac: Support the xterm mouse in the non-GUI version. - -Mac: better integration with Xcode. Post a fake mouse-up event after the odoc -event and the drag receive handler to work around a stall after Vim loads a -file. Fixed an off-by-one line number error. (Da Woon Jung) - -Mac: When started from Finder change directory to the file being edited or the -user home directory. - -Added the t_SI and t_EI escape sequences for starting and ending Insert mode. -To be used to set the cursor shape to a bar or a block. No default values, -they are not supported by termcap/terminfo. - -GUI font selector for Motif. (Marcin Dalecki) - -Nicer toolbar buttons for Motif. (Marcin Dalecki) - -Mnemonics for the Motif find/replace dialog. (Marcin Dalecki) - -Included a few improvements for Motif from Marcin Dalecki. Draw label -contents ourselves to make them handle fonts in a way configurable by Vim and -a bit less dependent on the X11 font management. - -Autocommands can be defined local to a buffer. This means they will also work -when the buffer does not have a name or no specific name. See -|autocmd-buflocal|. (Yakov Lerner) - -For xterm most combinations of modifiers with function keys are recognized. -|xterm-modifier-keys| - -When 'verbose' is set the output of ":highlight" will show where a highlight -item was last set. -When 'verbose' is set the output of the ":map", ":abbreviate", ":command", -":function" and ":autocmd" commands will show where it was last defined. -(Yegappan Lakshmanan) - -":function /pattern" lists functions matching the pattern. - -"1gd" can be used like "gd" but ignores matches in a {} block that ends before -the cursor position. Likewise for "1gD" and "gD". - -'scrolljump' can be set to a negative number to scroll a percentage of the -window height. - -The |v:scrollstart| variable has been added to help finding the location in -your script that causes the hit-enter prompt. - -To make it possible to handle the situation that a file is being edited that -is already being edited by another Vim instance, the |SwapExists| event has -been added. The |v:swapname|, |v:swapchoice| and |v:swapcommand| variables -can be used, for example to use the |client-server| functionality to bring the -other Vim to the foreground. -When starting Vim with a "-t tag" argument, there is an existing swapfile and -the user selects "quit" or "abort" then exit Vim. - -Undo now also restores the '< and '> marks. "gv" selects the same area as -before the change and undo. - -When editing a search pattern for a "/" or "?" command and 'incsearch' is set -CTRL-L can be used to add a character from the current match. CTRL-R CTRL-W -will add a word, but exclude the part of the word that was already typed. - -Ruby interface: add line number methods. (Ryan Paul) - -The $MYVIMRC environment variable is set to the first found vimrc file. -The $MYGVIMRC environment variable is set to the first found gvimrc file. - -============================================================================== -IMPROVEMENTS *improvements-7* - -":helpgrep" accepts a language specifier after the pattern: "pat@it". - -Moved the help for printing to a separate help file. It's quite a lot now. - -When doing completion for ":!cmd", ":r !cmd" or ":w !cmd" executable files are -found in $PATH instead of looking for ordinary files in the current directory. - -When ":silent" is used and a backwards range is given for an Ex command the -range is swapped automatically instead of asking if that is OK. - -The pattern matching code was changed from a recursive function to an -iterative mechanism. This avoids out-of-stack errors. State is stored in -allocated memory, running out of memory can always be detected. Allows -matching more complex things, but Vim may seem to hang while doing that. - -Previously some options were always evaluated in the |sandbox|. Now that only -happens when the option was set from a modeline or in secure mode. Applies to -'balloonexpr', 'foldexpr', 'foldtext' and 'includeexpr'. (Sumner Hayes) - -Some commands and expressions could have nasty side effects, such as using -CTRL-R = while editing a search pattern and the expression invokes a function -that jumps to another window. The |textlock| has been added to prevent this -from happening. - -":breakadd here" and ":breakdel here" can be used to set or delete a -breakpoint at the cursor. - -It is now possible to define a function with: > - :exe "func Test()\n ...\n endfunc" - -The tutor was updated to make it simpler to use and text was added to explain -a few more important commands. Used ideas from Gabriel Zachmann. - -Unix: When libcall() fails obtain an error message with dlerror() and display -it. (Johannes Zellner) - -Mac and Cygwin: When editing an existing file make the file name the same case -of the edited file. Thus when typing ":e os_UNIX.c" the file name becomes -"os_unix.c". - -Added "nbsp" in 'listchars'. (David Blanchet) - -Added the "acwrite" value for the 'buftype' option. This is for a buffer that -does not have a name that refers to a file and is written with BufWriteCmd -autocommands. - -For lisp indenting and matching parenthesis: (Sergey Khorev) -- square brackets are recognized properly -- #\(, #\), #\[ and #\] are recognized as character literals -- Lisp line comments (delimited by semicolon) are recognized - -Added the "count" argument to match(), matchend() and matchstr(). (Ilya Sher) - -winnr() takes an optional "$" or "#" argument. (Nikolai Weibull, Yegappan -Lakshmanan) - -Added 's' flag to search(): set ' mark if cursor moved. (Yegappan Lakshmanan) -Added 'n' flag to search(): don't move the cursor. (Nikolai Weibull) -Added 'c' flag to search(): accept match at the cursor. -Added 'e' flag to search(): move to end of the match. (Benji Fisher) -Added 'p' flag to search(): return number of sub-pattern. (Benji Fisher) -These also apply to searchpos(), searchpair() and searchpairpos(). - -The search() and searchpair() functions have an extra argument to specify -where to stop searching. Speeds up searches that should not continue too far. - -When uncompressing fails in the gzip plugin, give an error message but don't -delete the raw text. Helps if the file has a .gz extension but is not -actually compressed. (Andrew Pimlott) - -When C, C++ or IDL syntax is used, may additionally load doxygen syntax. -(Michael Geddes) - -Support setting 'filetype' and 'syntax' to "aaa.bbb" for "aaa" plus "bbb" -filetype or syntax. - -The ":registers" command now displays multi-byte characters properly. - -VMS: In the usage message mention that a slash can be used to make a flag -upper case. Add color support to the builtin vt320 terminal codes. -(Zoltan Arpadffy) - -For the '%' item in 'viminfo', allow a number to set a maximum for the number -of buffers. - -For recognizing the file type: When a file looks like a shell script, check -for an "exec" command that starts the tcl interpreter. (suggested by Alexios -Zavras) - -Support conversion between utf-8 and latin9 (iso-8859-15) internally, so that -digraphs still work when iconv is not available. - -When a session file is loaded while editing an unnamed, empty buffer that -buffer is wiped out. Avoids that there is an unused buffer in the buffer -list. - -Win32: When libintl.dll supports bind_textdomain_codeset(), use it. -(NAKADAIRA Yukihiro) - -Win32: Vim was not aware of hard links on NTFS file systems. These are -detected now for when 'backupcopy' is "auto". Also fixed a bogus "file has -been changed since reading it" error for links. - -When foldtext() finds no text after removing the comment leader, use the -second line of the fold. Helps for C-style /* */ comments where the first -line is just "/*". - -When editing the same file from two systems (e.g., Unix and MS-Windows) there -mostly was no warning for an existing swap file, because the name of the -edited file differs (e.g., y:\dir\file vs /home/me/dir/file). Added a flag to -the swap file to indicate it is in the same directory as the edited file. The -used path then doesn't matter and the check for editing the same file is much -more reliable. - -Unix: When editing a file through a symlink the swap file would use the name -of the symlink. Now use the name of the actual file, so that editing the same -file twice is detected. (suggestions by Stefano Zacchiroli and James Vega) - -Client-server communication now supports 'encoding'. When setting 'encoding' -in a Vim server to "utf-8", and using "vim --remote fname" in a console, -"fname" is converted from the console encoding to utf-8. Also allows Vims -with different 'encoding' settings to exchange messages. - -Internal: Changed ga_room into ga_maxlen, so that it doesn't need to be -incremented/decremented each time. - -When a register is empty it is not stored in the viminfo file. - -Removed the tcltags script, it's obsolete. - -":redir @*>>" and ":redir @+>>" append to the clipboard. Better check for -invalid characters after the register name. |:redir| - -":redir => variable" and ":redir =>> variable" write or append to a variable. -(Yegappan Lakshmanan) |:redir| - -":redir @{a-z}>>" appends to register a to z. (Yegappan Lakshmanan) - -The 'verbosefile' option can be used to log messages in a file. Verbose -messages are not displayed then. The "-V{filename}" argument can be used to -log startup messages. - -":let g:" lists global variables. -":let b:" lists buffer-local variables. -":let w:" lists window-local variables. -":let v:" lists Vim variables. - -The stridx() and strridx() functions take a third argument, where to start -searching. (Yegappan Lakshmanan) - -The getreg() function takes an extra argument to be able to get the expression -for the '=' register instead of the result of evaluating it. - -The setline() function can take a List argument to set multiple lines. When -the line number is just below the last line the line is appended. - -g CTRL-G also shows the number of characters if it differs from the number of -bytes. - -Completion for ":debug" and entering an expression for the '=' register. Skip -":" between range and command name. (Peter winters) - -CTRL-Q in Insert mode now works like CTRL-V by default. Previously it was -ignored. - -When "beep" is included in 'debug' a function or script that causes a beep -will result in a message with the source of the error. - -When completing buffer names, match with "\(^\|[\/]\)" instead of "^", so that -":buf stor<Tab>" finds both "include/storage.h" and "storage/main.c". - -To count items (pattern matches) without changing the buffer the 'n' flag has -been added to |:substitute|. See |count-items|. - -In a |:substitute| command the \u, \U, \l and \L items now also work for -multi-byte characters. - -The "screen.linux" $TERM name is recognized to set the default for -'background' to "dark". (Ciaran McCreesh) Also for "cygwin" and "putty". - -The |FileChangedShell| autocommand event can now use the |v:fcs_reason| -variable that specifies what triggered the event. |v:fcs_choice| can be used -to reload the buffer or ask the user what to do. - -Not all modifiers were recognized for xterm function keys. Added the -possibility in term codes to end in ";*X" or "O*X", where X is any character -and the * stands for the modifier code. -Added the <xUp>, <xDown>, <xLeft> and <xRight> keys, to be able to recognize -the two forms that xterm can send their codes in and still handle all possible -modifiers. - -getwinvar() now also works to obtain a buffer-local option from the specified -window. - -Added the "%s" item to 'errorformat'. (Yegappan Lakshmanan) -Added the "%>" item to 'errorformat'. - -For 'errorformat' it was not possible to have a file name that contains the -character that follows after "%f". For example, in "%f:%l:%m" the file name -could not contain ":". Now include the first ":" where the rest of the -pattern matches. In the example a ":" not followed by a line number is -included in the file name. (suggested by Emanuele Giaquinta) - -GTK GUI: use the GTK file dialog when it's available. Mix from patches by -Grahame Bowland and Evan Webb. - -Added ":scriptnames" to bugreport.vim, so that we can see what plugins were -used. - -Win32: If the user changes the setting for the number of lines a scroll wheel -click scrolls it is now used immediately. Previously Vim would need to be -restarted. - -When using @= in an expression the value is expression @= contains. ":let @= -= value" can be used to set the register contents. - -A ! can be added to ":popup" to have the popup menu appear at the mouse -pointer position instead of the text cursor. - -The table with encodings has been expanded with many MS-Windows codepages, -such as cp1250 and cp737, so that these can also be used on Unix without -prepending "8bit-". -When an encoding name starts with "microsoft-cp" ignore the "microsoft-" part. - -Added the "customlist" completion argument to a user-defined command. The -user-defined completion function should return the completion candidates as a -Vim List and the returned results are not filtered by Vim. (Yegappan -Lakshmanan) - -Win32: Balloons can have multiple lines if common controls supports it. -(Sergey Khorev) - -For command-line completion the matches for various types of arguments are now -sorted: user commands, variables, syntax names, etc. - -When no locale is set, thus using the "C" locale, Vim will work with latin1 -characters, using its own isupper()/toupper()/etc. functions. - -When using an rxvt terminal emulator guess the value of 'background' using the -COLORFGBG environment variable. (Ciaran McCreesh) - -Also support t_SI and t_EI on Unix with normal features. (Ciaran McCreesh) - -When 'foldcolumn' is one then put as much info in it as possible. This allows -closing a fold with the mouse by clicking on the '-'. - -input() takes an optional completion argument to specify the type of -completion supported for the input. (Yegappan Lakshmanan) - -"dp" works with more than two buffers in diff mode if there is only one where -'modifiable' is set. - -The 'diffopt' option has three new values: "horizontal", "vertical" and -"foldcolumn". - -When the 'include' option contains \zs the file name found is what is being -matched from \zs to the end or \ze. Useful to pass more to 'includeexpr'. - -Loading plugins on startup now supports subdirectories in the plugin -directory. |load-plugins| - -In the foldcolumn always show the '+' for a closed fold, so that it can be -opened easily. It may overwrite another character, esp. if 'foldcolumn' is 1. - -It is now possible to get the W10 message again by setting 'readonly'. Useful -in the FileChangedRO autocommand when checking out the file fails. - -Unix: When open() returns EFBIG give an appropriate message. - -":mksession" sets the SessionLoad variable to notify plugins. A modeline is -added to the session file to set 'filetype' to "vim". - -In the ATTENTION prompt put the "Delete it" choice before "Quit" to make it -more logical. (Robert Webb) - -When appending to a file while the buffer has no name the name of the appended -file would be used for the current buffer. But the buffer contents is -actually different from the file content. Don't set the file name, unless the -'P' flag is present in 'cpoptions'. - -When starting to edit a new file and the directory for the file doesn't exist -then Vim will report "[New DIRECTORY]" instead of "[New File] to give the user -a hint that something might be wrong. - -Win32: Preserve the hidden attribute of the viminfo file. - -In Insert mode CTRL-A didn't keep the last inserted text when using CTRL-O and -then a cursor key. Now keep the previously inserted text if nothing is -inserted after the CTRL-O. Allows using CTRL-O commands to move the cursor -without losing the last inserted text. - -The exists() function now supports checking for autocmd group definition -and for supported autocommand events. (Yegappan Lakshmanan) - -Allow using ":global" in the sandbox, it doesn't do anything harmful by -itself. - -":saveas asdf.c" will set 'filetype' to c when it's empty. Also for ":w -asdf.c" when it sets the filename for the buffer. - -Insert mode completion for whole lines now also searches unloaded buffers. - -The colortest.vim script can now be invoked directly with ":source" or -":runtime syntax/colortest.vim". - -The 'statusline' option can be local to the window, so that each window can -have a different value. (partly by Yegappan Lakshmanan) - -The 'statusline' option and other options that support the same format can now -use these new features: -- When it starts with "%!" the value is first evaluated as an expression - before parsing the value. -- "%#HLname#" can be used to start highlighting with HLname. - -When 'statusline' is set to something that causes an error message then it is -made empty to avoid an endless redraw loop. Also for other options, such at -'tabline' and 'titlestring'. ":verbose set statusline" will mention that it -was set in an error handler. - -When there are several matching tags, the ":tag <name>" and CTRL-] commands -jump to the [count] matching tag. (Yegappan Lakshmanan) - -Win32: In the batch files generated by the install program, use $VIMRUNTIME or -$VIM if it's set. Example provided by Mathias Michaelis. -Also create a vimtutor.bat batch file. - -The 'balloonexpr' option is now |global-local|. - -The system() function now runs in cooked mode, thus can be interrupted by -CTRL-C. - -============================================================================== -COMPILE TIME CHANGES *compile-changes-7* - -Dropped the support for the BeOS and Amiga GUI. They were not maintained and -probably didn't work. If you want to work on this: get the Vim 6.x version -and merge it back in. - -When running the tests and one of them fails to produce "test.out" the -following tests are still executed. This helps when running out of memory. - -When compiling with EXITFREE defined and the ccmalloc library it is possible -to detect memory leaks. Some memory will always reported as leaked, such as -allocated by X11 library functions and the memory allocated in alloc_cmdbuff() -to store the ":quit" command. - -Moved the code for printing to src/hardcopy.c. - -Moved some code from main() to separate functions to make it easier to see -what is being done. Using a structure to avoid a lot of arguments to the -functions. - -Moved unix_expandpath() to misc1.c, so that it can also be used by os_mac.c -without copying the code. - ---- Mac --- - -"make" now creates the Vim.app directory and "make install" copies it to its -final destination. (Raf) - -Put the runtime directory not directly in Vim.app but in -Vim.app/Contents/Resources/vim, so that it's according to Mac specs. - -Made it possible to compile with Motif, Athena or GTK without tricks and still -being able to use the MacRoman conversion. Added the os_mac_conv.c file. - -When running "make install" the runtime files are installed as for Unix. -Avoids that too many files are copied. When running "make" a link to the -runtime files is created to avoid a recursive copy that takes much time. - -Configure will attempt to build Vim for both Intel and PowerPC. The ---with-mac-arch configure argument can change it. - ---- Win32 --- - -The Make_mvc.mak file was adjusted to work with the latest MS compilers, -including the free version of Visual Studio 2005. (George Reilly) - -INSTALLpc.txt was updated for the recent changes. (George Reilly) - -The distributed executable is now produced with the free Visual C++ Toolkit -2003 and other free SDK chunks. msvcsetup.bat was added to support this. - -Also generate the .pdb file that can be used to generate a useful crash report -on MS-Windows. (George Reilly) - -============================================================================== -BUG FIXES *bug-fixes-7* - -When using PostScript printing on MS-DOS the default 'printexpr' used "lpr" -instead of "copy". When 'printdevice' was empty the copy command did not -work. Use "LPT1" then. - -The GTK font dialog uses a font size zero when the font name doesn't include a -size. Use a default size of 10. - -This example in the documentation didn't work: - :e `=foo . ".c" ` -Skip over the expression in `=expr` when looking for comments, |, % and #. - -When ":helpgrep" doesn't find anything there is no error message. - -"L" and "H" did not take closed folds into account. - -Win32: The "-P title" argument stopped at the first title that matched, even -when it doesn't support MDI. - -Mac GUI: CTRL-^ and CTRL-@ did not work. - -"2daw" on "word." at the end of a line didn't include the preceding white -space. - -Win32: Using FindExecutable() doesn't work to find a program. Use -SearchPath() instead. For executable() use $PATHEXT when the program searched -for doesn't have an extension. - -When 'virtualedit' is set, moving the cursor up after appending a character -may move it to a different column. Was caused by auto-formatting moving the -cursor and not putting it back where it was. - -When indent was added automatically and then moving the cursor, the indent was -not deleted (like when pressing ESC). The "I" flag in 'cpoptions' can be used -to make it work the old way. - -When opening a command-line window, 'textwidth' gets set to 78 by the Vim -filetype plugin. Reset 'textwidth' to 0 to avoid lines are broken. - -After using cursor(line, col) moving up/down doesn't keep the same column. - -Win32: Borland C before 5.5 requires using ".u." for LowPart and HighPart -fields. (Walter Briscoe) - -On Sinix SYS_NMLN isn't always defined. Define it ourselves. (Cristiano De -Michele) - -Printing with PostScript may keep the printer waiting for more. Append a -CTRL-D to the printer output. (Mike Williams) - -When converting a string with a hex or octal number the leading '-' was -ignored. ":echo '-05' + 0" resulted in 5 instead of -5. - -Using "@:" to repeat a command line didn't work when it contains control -characters. Also remove "'<,'>" when in Visual mode to avoid that it appears -twice. - -When using file completion for a user command, it would not expand environment -variables like for a regular command with a file argument. - -'cindent': When the argument of a #define looks like a C++ class the next line -is indented too much. - -When 'comments' includes multi-byte characters inserting the middle part and -alignment may go wrong. 'cindent' also suffers from this for right-aligned -items. - -Win32: when 'encoding' is set to "utf-8" getenv() still returns strings in the -active codepage. Convert to utf-8. Also for $HOME. - -The default for 'helplang' was "zh" for both "zh_cn" and "zh_tw". Now use -"cn" or "tw" as intended. - -When 'bin' is set and 'eol' is not set then line2byte() added the line break -after the last line while it's not there. - -Using foldlevel() in a WinEnter autocommand may not work. Noticed when -resizing the GUI shell upon startup. - -Python: Using buffer.append(f.readlines()) didn't work. Allow appending a -string with a trailing newline. The newline is ignored. - -When using the ":saveas f2" command for buffer "f1", the Buffers menu would -contain "f2" twice, one of them leading to "f1". Also trigger the BufFilePre -and BufFilePost events for the alternate buffer that gets the old name. - -strridx() did not work well when the needle is empty. (Ciaran McCreesh) - -GTK: Avoid a potential hang in gui_mch_wait_for_chars() when input arrives -just before it is invoked - -VMS: Occasionally CR characters were inserted in the file. Expansion of -environment variables was not correct. (Zoltan Arpadffy) - -UTF-8: When 'delcombine' is set "dw" only deleted the last combining character -from the first character of the word. - -When using ":sball" in an autocommand only the filetype in one buffer was -detected. Reset did_filetype in enter_buffer(). - -When using ":argdo" and the window already was at the first argument index, -but not actually editing it, the current buffer would be used instead. - -When ":next dir/*" includes many matches, adding the names to the argument -list may take an awful lot of time and can't be interrupted. Allow -interrupting this. - -When editing a file that was already loaded in a buffer, modelines were not -used. Now window-local options in the modeline are set. Buffer-local options -and global options remain unmodified. - -Win32: When 'encoding' is set to "utf-8" in the vimrc file, files from the -command line with non-ASCII characters are not used correctly. Recode the -file names when 'encoding' is set, using the Unicode command line. - -Win32 console: When the default for 'encoding' ends up to be "latin1", the -default value of 'isprint' was wrong. - -When an error message is given while waiting for a character (e.g., when an -xterm reports the number of colors), the hit-enter prompt overwrote the last -line. Don't reset msg_didout in normal_cmd() for K_IGNORE. - -Mac GUI: Shift-Tab didn't work. - -When defining tooltip text, don't translate terminal codes, since it's not -going to be used like a command. - -GTK 2: Check the tooltip text for valid utf-8 characters to avoid getting a -GTK error. Invalid characters may appear when 'encoding' is changed. - -GTK 2: Add a safety check for invalid utf-8 sequences, they can crash pango. - -Win32: When 'encoding' is changed while starting up, use the Unicode command -line to convert the file arguments to 'encoding'. Both for the GUI and the -console version. - -Win32 GUI: latin9 text (iso-8859-15) was not displayed correctly, because -there is no codepage for latin9. Do our own conversion from latin9 to UCS2. - -When two versions of GTK+ 2 are installed it was possible to use the header -files from one and the library from the other. Use GTK_LIBDIR to put the -directory for the library early in the link flags. - -With the GUI find/replace dialog a replace only worked if the pattern was -literal text. Now it works for any pattern. - -When 'equalalways' is set and 'eadirection' is "hor", ":quit" would still -cause equalizing window heights in the vertical direction. - -When ":emenu" is used in a startup script the command was put in the typeahead -buffer, causing a prompt for the crypt key to be messed up. - -Mac OS/X: The default for 'isprint' included characters 128-160, causes -problems for Terminal.app. - -When a syntax item with "containedin" is used, it may match in the start or -end of a region with a matchgroup, while this doesn't happen for a "contains" -argument. - -When a transparent syntax items matches in another item where the highlighting -has already stopped (because of a he= argument), the highlighting would come -back. - -When cscope is used to set the quickfix error list, it didn't get set if there -was only one match. (Sergey Khorev) - -When 'confirm' is set and using ":bdel" in a modified buffer, then selecting -"cancel", would still give an error message. - -The PopUp menu items that started Visual mode didn't work when not in Normal -mode. Switching between selecting a word and a line was not possible. - -Win32: The keypad decimal point always resulted in a '.', while on some -keyboards it's a ','. Use MapVirtualKey(VK_DECIMAL, 2). - -Removed unused function DisplayCompStringOpaque() from gui_w32.c - -In Visual mode there is not always an indication whether the line break is -selected or not. Highlight the character after the line when the line break -is included, e.g., after "v$o". - -GTK: The <F10> key can't be mapped, it selects the menu. Disable that with a -GTK setting and do select the menu when <F10> isn't mapped. (David Necas) - -After "Y" '[ and '] were not at start/end of the yanked text. - -When a telnet connection is dropped Vim preserves files and exits. While -doing that a SIGHUP may arrive and disturb us, thus ignore it. (Scott -Anderson) Also postpone SIGHUP, SIGQUIT and SIGTERM until it's safe to -handle. Added handle_signal(). - -When completing a file name on the command line backslashes are required for -white space. Was only done for a space, not for a Tab. - -When configure could not find a terminal library, compiling continued for a -long time before reporting the problem. Added a configure check for tgetent() -being found in a library. - -When the cursor is on the first char of the last line a ":g/pat/s///" command -may cause the cursor to be displayed below the text. - -Win32: Editing a file with non-ASCII characters doesn't work when 'encoding' -is "utf-8". use _wfullpath() instead of _fullpath(). (Yu-sung Moon) - -When recovering the 'fileformat' and 'fileencoding' were taken from the -original file instead of from the swapfile. When the file didn't exist, was -empty or the option was changed (e.g., with ":e ++fenc=cp123 file") it could -be wrong. Now store 'fileformat' and 'fileencoding' in the swapfile and use -the values when recovering. - -":bufdo g/something/p" overwrites each last printed text line with the file -message for the next buffer. Temporarily clear 'shortmess' to avoid that. - -Win32: Cannot edit a file starting with # with --remote. Do escape % and # -when building the ":drop" command. - -A comment or | just after a expression-backtick argument was not recognized. -E.g. in :e `="foo"`"comment. - -"(" does not stop at an empty sentence (single dot and white space) while ")" -does. Also breaks "das" on that dot. - -When doing "yy" with the cursor on a TAB the ruler could be wrong and "k" -moved the cursor to another column. - -When 'commentstring' is '"%s' and there is a double quote in the line a double -quote before the fold marker isn't removed in the text displayed for a closed -fold. - -In Visual mode, when 'bin' and 'eol' set, g CTRL-G counted the last line -break, resulting in "selected 202 of 201 bytes". - -Motif: fonts were not used for dialog components. (Marcin Dalecki) - -Motif: After using a toolbar button the keyboard focus would be on the toolbar -(Lesstif problem). (Marcin Dalecki) - -When using "y<C-V>`x" where mark x is in the first column, the last line was -not included. - -Not all test scripts work properly on MS-Windows when checked out from CVS. -Use a Vim command to fix all fileformats to dos before executing the tests. - -When using ":new" and the file fits in the window, lines could still be above -the window. Now remove empty lines instead of keeping the relative position. - -Cmdline completion didn't work after ":let var1 var<Tab>". - -When using ":startinsert" or ":startreplace" when already in Insert mode -(possible when using CTRL-R =), pressing Esc would directly restart Insert -mode. (Peter Winters) - -"2daw" didn't work at end of file if the last word is a single character. - -Completion for ":next a'<Tab>" put a backslash before single quote, but it was -not removed when editing a file. Now halve backslashes in save_patterns(). -Also fix expanding a file name with the shell that contains "\'". - -When doing "1,6d|put" only "fewer lines" was reported. Now a following "more -lines" overwrites the message. - -Configure could not handle "-Dfoo=long\ long" in the TCL config output. - -When searching backwards, using a pattern that matches a newline and uses \zs -after that, didn't find a match. Could also get a hang or end up in the right -column in the wrong line. - -When $LANG is "sl" for slovenian, the slovak menu was used, since "slovak" -starts with "sl". - -When 'paste' is set in the GUI the Paste toolbar button doesn't work. Clear -'paste' when starting the GUI. - -A message about a wrong viminfo line included the trailing NL. - -When 'paste' is set in the GUI the toolbar button doesn't work in Insert mode. -Use ":exe" in menu.vim to avoid duplicating the commands, instead of using a -mapping. - -Treat "mlterm" as an xterm-like terminal. (Seiichi Sato) - -":z.4" and ":z=4" didn't work Vi compatible. - -When sourcing a file, editing it and sourcing it again, it could appear twice -in ":scriptnames" and get a new <SID>, because the inode has changed. - -When $SHELL is set but empty the 'shell' option would be empty. Don't use an -empty $SHELL value. - -A command "w! file" in .vimrc or $EXINIT didn't work. Now it writes an empty -file. - -When a CTRL-F command at the end of the file failed, the cursor was still -moved to the start of the line. Now it remains where it is. - -When using ":s" or "&" to repeat the last substitute and "$" was used to put -the cursor in the last column, put the cursor in the last column again. This -is Vi compatible. - -Vim is not fully POSIX compliant but sticks with traditional Vi behavior. -Added a few flags in 'cpoptions' to behave the POSIX way when wanted. The -$VIM_POSIX environment variable is checked to set the default. - -Appending to a register didn't insert a line break like Vi. Added the '>' -flag to 'cpoptions' for this. - -Using "I" in a line with only blanks appended to the line. This is not Vi -compatible. Added the 'H' flag in 'coptions' for this. - -When joining multiple lines the cursor would be at the last joint, but Vi -leaves it at the position where "J" would put it. Added the 'q' flag in -'cpoptions' for this. - -Autoindent didn't work for ":insert" and ":append". - -Using ":append" in an empty buffer kept the dummy line. Now it's deleted to -be Vi compatible. - -When reading commands from a file and stdout goes to a terminal, would still -request the xterm version. Vim can't read it, thus the output went to the -shell and caused trouble there. - -When redirecting to a register with an invalid name the redirection would -still be done (after an error message). Now reset "redir_reg". (Yegappan -Lakshmanan) - -It was not possible to use a NL after a backslash in Ex mode. This is -sometimes used to feed multiple lines to a shell command. - -When 'cmdheight' is set to 2 in .vimrc and the GUI uses the number of lines -from the terminal we actually get 3 lines for the cmdline in gvim. - -When setting $HOME allocated memory would leak. - -Win32: bold characters may sometimes write in another character cell. Use -unicodepdy[] as for UTF-8. (Taro Muraoka) - -":w fname" didn't work for files with 'buftype' set to "nofile". - -The method used to locate user commands for completion differed from when they -are executed. Ambiguous command names were not completed properly. - -Incremental search may cause a crash when there is a custom statusline that -indirectly invokes ":normal". - -Diff mode failed when $DIFF_OPTIONS was set in the environment. Unset it -before invoking "diff". - -Completion didn't work after ":argdo", ":windo" and ":bufdo". Also for ":set -&l:opt" and ":set &g:opt". (Peter Winters) - -When setting 'ttymouse' to "dec" in an xterm that supports the DEC mouse -locator it doesn't work. Now switch off the mouse before selecting another -mouse model. - -When the CursorHold event is triggered and the commands peek for typed -characters the typeahead buffer may be messed up, e.g., when a mouse-up event -is received. Avoid invoking the autocommands from the function waiting for a -character, let it put K_CURSORHOLD in the input buffer. - -Removed the "COUNT" flag from ":argadd", to avoid ":argadd 1*" to be used like -":1argadd *". Same for ":argdelete" and ":argedit". - -Avoid that $LANG is used for the menus when LC_MESSAGES is "en_US". - -Added backslashes before dashes in the vim.1 manual page to make the appear as -real dashes. (Pierr Habouzit) - -Where "gq" left the cursor depended on the value of 'formatprg'. Now "gq" -always leaves the cursor at the last line of the formatted text. - -When editing a compressed file, such as "changelog.Debian.gz" file, filetype -detection may try to check the contents of the file while it's still -compressed. Skip setting 'filetype' for compressed files until they have been -decompressed. Required for patterns that end in a "*". - -Starting with an argument "+cmd" or "-S script" causes the cursor the be moved -to the first line. That breaks a BufReadPost autocommand that uses g`". -Don't move the cursor if it's somewhere past the first line. - -"gg=G" while 'modifiable' is off was uninterruptible. - -When 'encoding' is "sjis" inserting CTRL-V u d800 a few times causes a crash. -Don't insert a DBCS character with a NUL second byte. - -In Insert mode CTRL-O <Home> didn't move the cursor. Made "ins_at_eol" global -and reset it in nv_home(). - -Wildcard expansion failed: ":w /tmp/$$.`echo test`". Don't put quotes around -spaces inside backticks. - -After this sequence of commands: Y V p gv: the wrong line is selected. Now -let "gv" select the text that was put, since the original text is deleted. -This should be the most useful thing to do. - -":sleep 100u" sleeps for 100 seconds, not 100 usec as one might expect. Give -an error message when the argument isn't recognized. - -In gui_mch_draw_string() in gui_w32.c "unibuflen" wasn't static, resulting in -reallocating the buffer every time. (Alexei Alexandrov) - -When using a Python "atexit" function it was not invoked when Vim exits. Now -call Py_Finalize() for that. (Ugo Di Girolamo) -This breaks the thread stuff though, fixed by Ugo. - -GTK GUI: using a .vimrc with "set cmdheight=2 lines=43" and ":split" right -after startup, the window layout is messed up. (Michael Schaap) Added -win_new_shellsize() call in gui_init() to fix the topframe size. - -Trick to get ...MOUSE_NM not used when there are vertical splits. Now pass -column -1 for the left most window and add MOUSE_COLOFF for others. Limits -mouse column to 10000. - -searchpair() may hang when the end pattern has "\zs" at the end. Check that -we find the same position again and advance one character. - -When in diff mode and making a change that causes the "changed" highlighting -to disappear or reappear, it was still highlighted in another window. - -When a ":next" command fails because the user selects "Abort" at the ATTENTION -prompt the argument index was advanced anyway. - -When "~" is in 'iskeyword' the "gd" doesn't work, it's used for the previous -substitute pattern. Put "\V" in the pattern to avoid that. - -Use of sprintf() sometimes didn't check properly for buffer overflow. Also -when using smsg(). Included code for snprintf() to avoid having to do size -checks where invoking them - -":help \=<Tab>" didn't find "sub-replace-\=". Wild menu for help tags didn't -show backslashes. ":he :s\=" didn't work. - -When reading an errorfile "~/" in a file name was not expanded. - -GTK GUI: When adding a scrollbar (e.g. when using ":vsplit") in a script or -removing it the window size may change. GTK sends us resize events when we -change the window size ourselves, but they may come at an unexpected moment. -Peek for a character to get any window resize events and fix 'columns' and -'lines' to undo this. - -When using the GTK plug mechanism, resizing and focus was not working -properly. (Neil Bird) - -After deleting files from the argument list a session file generated with -":mksession" may contain invalid ":next" commands. - -When 'shortmess' is empty and 'keymap' set to accents, in Insert mode CTRL-N -may cause the hit-enter prompt. Typing 'a then didn't result in the accented -character. Put the character typed at the prompt back in the typeahead buffer -so that mapping is done in the right mode. - -setbufvar() and setwinvar() did not give error messages. - -It was possible to set a variable with an illegal name, e.g. with setbufvar(). -It was possible to define a function with illegal name, e.t. ":func F{-1}()" - -CTRL-W F and "gf" didn't use the same method to get the file name. - -When reporting a conversion error the line number of the last error could be -given. Now report the first encountered error. - -When using ":e ++enc=name file" and iconv() was used for conversion an error -caused a fall-back to no conversion. Now replace a character with '?' and -continue. - -When opening a new buffer the local value of 'bomb' was not initialized from -the global value. - -Win32: When using the "Edit with Vim" entry the file name was limited to about -200 characters. - -When using command line completion for ":e *foo" and the file "+foo" exists -the resulting command ":e +foo" doesn't work. Now insert a backslash: ":e -\+foo". - -When the translation of "-- More --" was not 10 characters long the following -message would be in the wrong position. - -At the more-prompt the last character in the last line wasn't drawn. - -When deleting non-existing text while 'virtualedit' is set the '[ and '] marks -were not set. - -Win32: Could not use "**/" in 'path', it had to be "**\". - -The search pattern "\n" did not match at the end of the last line. - -Searching for a pattern backwards, starting on the NUL at the end of the line -and 'encoding' is "utf-8" would match the pattern just before it incorrectly. -Affected searchpair('/\*', '', '\*/'). - -For the Find/Replace dialog it was possible that not finding the text resulted -in an error message while redrawing, which cleared the syntax highlighting -while it was being used, resulting in a crash. Now don't clear syntax -highlighting, disable it with b_syn_error. - -Win32: Combining UTF-8 characters were drawn on the previous character. -Could be noticed with a Thai font. - -Output of ":function" could leave some of the typed text behind. (Yegappan -Lakshmanan) - -When the command line history has only a few lines the command line window -would be opened with these lines above the first window line. - -When using a command line window for search strings ":qa" would result in -searching for "qa" instead of quitting all windows. - -GUI: When scrolling with the scrollbar and there is a line that doesn't fit -redrawing may fail. Make sure w_skipcol is valid before redrawing. - -Limit the values of 'columns' and 'lines' to avoid an overflow in Rows * -Columns. Fixed bad effects when running out of memory (command line would be -reversed, ":qa!" resulted in ":!aq"). - -Motif: "gvim -iconic" opened the window anyway. (David Harrison) - -There is a tiny chance that a symlink gets created between checking for an -existing file and creating a file. Use the O_NOFOLLOW for open() if it's -available. - -In an empty line "ix<CTRL-O>0" moved the cursor to after the line instead of -sticking to the first column. - -When using ":wq" and a BufWriteCmd autocmd uses inputsecret() the text was -echoed anyway. Set terminal to raw mode in getcmdline(). - -Unix: ":w a;b~c" caused an error in expanding wildcards. - -When appending to a file with ":w >>fname" in a buffer without a name, causing -the buffer to use "fname", the modified flag was reset. - -When appending to the current file the "not edited" flag would be reset. -":w" would overwrite the file accidentally. - -Unix: When filtering text with an external command Vim would still read input, -causing text typed for the command (e.g., a password) to be eaten and echoed. -Don't read input when the terminal is in cooked mode. - -The Cygwin version of xxd used CR/LF line separators. (Corinna Vinschen) - -Unix: When filtering text through a shell command some resulting text may be -dropped. Now after detecting that the child has exited try reading some more -of its output. - -When inside input(), using "CTRL-R =" and the expression throws an exception -the command line was not abandoned but it wasn't used either. Now abandon -typing the command line. - -'delcombine' was also used in Visual and Select mode and for commands like -"cl". That was illogical and has been disabled. - -When recording while a CursorHold autocommand was defined special keys would -appear in the register. Now the CursorHold event is not triggered while -recording. - -Unix: the src/configure script used ${srcdir-.}, not all shells understand -that. Use ${srcdir:-.} instead. - -When editing file "a" which is a symlink to file "b" that doesn't exist, -writing file "a" to create "b" and then ":split b" resulted in two buffers on -the same file with two different swapfile names. Now set the inode in the -buffer when creating a new file. - -When 'esckeys' is not set don't send the xterm code to request the version -string, because it may cause trouble in Insert mode. - -When evaluating an expression for CTRL-R = on the command line it was possible -to call a function that opens a new window, resulting in errors for -incremental search, and many other nasty things were possible. Now use the -|textlock| to disallow changing the buffer or jumping to another window -to protect from unexpected behavior. Same for CTRL-\ e. - -"d(" deleted the character under the cursor, while the documentation specified -an exclusive motion. Vi also doesn't delete the character under the cursor. - -Shift-Insert in Insert mode could put the cursor before the last character -when it just fits in the window. In coladvance() don't stop at the window -edge when filling with spaces and when in Insert mode. In mswin.vim avoid -getting a beep from the "l" command. - -Win32 GUI: When Alt-F4 is used to close the window and Cancel is selected in -the dialog then Vim would insert <M-F4> in the text. Now it's ignored. - -When ":silent! {cmd}" caused the swap file dialog, which isn't displayed, -there would still be a hit-enter prompt. - -Requesting the termresponse (|t_RV|) early may cause problems with "-c" -arguments that invoke an external command or even "-c quit". Postpone it -until after executing "-c" arguments. - -When typing in Insert mode so that a new line is started, using CTRL-G u to -break undo and start a new change, then joining the lines with <BS> caused -undo info to be missing. Now reset the insertion start point. - -Syntax HL: When a region start match has a matchgroup and an offset that -happens to be after the end of the line then it continued in the next line and -stopped at the region end match, making the region continue after that. -Now check for the column being past the end of the line in syn_add_end_off(). - -When changing a file, setting 'swapfile' off and then on again, making another -change and killing Vim, then some blocks may be missing from the swapfile. -When 'swapfile' is switched back on mark all blocks in the swapfile as dirty. -Added mf_set_dirty(). - -Expanding wildcards in a command like ":e aap;<>!" didn't work. Put -backslashes before characters that are special to the shell. (Adri Verhoef) - -A CursorHold autocommand would cause a message to be cleared. Don't show the -special key for the event for 'showcmd'. - -When expanding a file name for a shell command, as in "!cmd foo<Tab>" or ":r -!cmd foo<Tab>" also escape characters that are special for the shell: -"!;&()<>". - -When the name of the buffer was set by a ":r fname" command |cpo-f| no -autocommands were triggered to notify about the change in the buffer list. - -In the quickfix buffer 'bufhidden' was set to "delete", which caused closing -the quickfix window to leave an unlisted "No Name" buffer behind every time. - -Win32: when using two screens of different size, setting 'lines' to a large -value didn't fill the whole screen. (SungHyun Nam) - -Win32 installer: The generated _vimrc contained an absolute path to diff.exe. -After upgrading it becomes invalid. Now use $VIMRUNTIME instead. - -The command line was cleared to often when 'showmode' was set and ":silent -normal vy" was used. Don't clear the command line unless the mode was -actually displayed. Added the "mode_displayed" variable. - -The "load session" toolbar item could not handle a space or other special -characters in v:this_session. - -":set sta ts=8 sw=4 sts=2" deleted 4 spaces halfway a line instead of 2. - -In a multi-byte file the foldmarker could be recognized in the trail byte. -(Taro Muraoka) - -Pasting with CTRL-V and menu didn't work properly when some commands are -mapped. Use ":normal!" instead of ":normal". (Tony Apuzzo) - -Crashed when expanding a file name argument in backticks. - -In some situations the menu and scrollbar didn't work, when the value contains -a CSI byte. (Yukihiro Nakadaira) - -GTK GUI: When drawing the balloon focus changes and we might get a key release -event that removed the balloon again. Ignore the key release event. - -'titleold' was included in ":mkexrc" and ":mksession" files. - -":set background&" didn't use the same logic as was used when starting up. - -When "umask" is set such that nothing is writable then the viminfo file would -be written without write permission. (Julian Bridle) - -Motif: In diff mode dragging one scrollbar didn't update the scrollbar of the -other diff'ed window. - -When editing in an xterm with a different number of colors than expected the -screen would be cleared and redrawn, causing the message about the edited file -to be cleared. Now set "keep_msg" to redraw the last message. - -For a color terminal: When the Normal HL uses bold, possibly to make the color -lighter, and another HL group specifies a color it might become light as well. -Now reset bold if a HL group doesn't specify bold itself. - -When using 256 color xterm the color 255 would show up as color 0. Use a -short instead of a char to store the color number. - -ml_get errors when searching for "\n\zs" in an empty file. - -When selecting a block and using "$" to select until the end of every line and -not highlighting the character under the cursor the first character of the -block could be unhighlighted. - -When counting words for the Visual block area and using "$" to select until -the end of every line only up to the length of the last line was counted. - -"dip" in trailing empty lines left one empty line behind. - -The script ID was only remembered globally for each option. When a buffer- or -window-local option was set the same "last set" location was changed for all -buffers and windows. Now remember the script ID for each local option -separately. - -GUI: The "Replace All" button didn't handle backslashes in the replacement in -the same way as "Replace". Escape backslashes so that they are taken -literally. - -When using Select mode from Insert mode and typing a key, causing lines to be -deleted and a message displayed, delayed the effect of inserting the key. -Now overwrite the message without delay. - -When 'whichwrap' includes "l" then "dl" and "yl" on a single letter line -worked differently. Now recognize all operators when using "l" at the end of -a line. - -GTK GUI: when the font selector returned a font name with a comma in it then -it would be handled like two font names. Now put a backslash before the -comma. - -MS-DOS, Win32: When 'encoding' defaults to "latin1" then the value for -'iskeyword' was still for CPxxx. And when 'nocompatible' was set 'isprint' -would also be the wrong value. - -When a command was defined not to take arguments and no '|' no warning message -would be given for using a '|'. Also with ":loadkeymap". - -Motif: When using a fontset and 'encoding' is "utf-8" and sizeof(wchar_t) != -sizeof(XChar2b) then display was wrong. (Yukihiro Nakadaira) - -":all" always set the current window to the first window, even when it -contains a buffer that is not in the argument list (can't be closed because it -is modified). Now go to the window that has the first item of the argument -list. - -GUI: To avoid left-over pixels from bold text all characters after a character -with special attributes were redrawn. Now only do this for characters that -actually are bold. Speeds up displaying considerably. - -When only highlighting changes and the text is scrolled at the same time -everything is redraw instead of using a scroll and updating the changed text. -E.g., when using ":match" to highlight a paren that the cursor landed on. -Added SOME_VALID: Redraw the whole window but also try to scroll to minimize -redrawing. - -Win32: When using Korean IME making it active didn't work properly. (Moon, -Yu-sung, 2005 March 21) - -Ruby interface: when inserting/deleting lines display wasn't updated. (Ryan -Paul) - ---- fixes since Vim 7.0b --- - -Getting the GCC version in configure didn't work with Solaris sed. First -strip any "darwin." and then get the version number. - -The "autoload" directory was missing from the self-installing executable for -MS-Windows. - -The MS-Windows install program would find "vimtutor.bat" in the install -directory. After changing to "c:" also change to "\" to avoid looking in the -install directory. - -To make the 16 bit DOS version compile exclude not used highlight -initializations and build a tiny instead of small version. - -finddir() and findfile() accept a negative count and return a List then. - -The Python indent file contained a few debugging statements, removed. - -Expanding {} for a function name, resulting in a name starting with "s:" was -not handled correctly. - -Spelling: renamed COMPOUNDMAX to COMPOUNDWORDMAX. Added several items to be -able to handle the new Hungarian dictionary. - -Mac: Default to building for the current platform only, that is much faster -than building a universal binary. Also, using Perl/Python/etc. only works for -the current platform. - -The time on undo messages disappeared for someone. Using %T for strftime() -apparently doesn't work everywhere. Use %H:%M:%S instead. - -Typing BS at the "z=" prompt removed the prompt. - ---- fixes and changes since Vim 7.0c --- - -When jumping to another tab page the Vim window size was always set, even when -nothing in the layout changed. - -Win32 GUI tab pages line wasn't always enabled. Do a proper check for the -compiler version. - -Win32: When switching between tab pages the Vim window was moved when part of -it was outside of the screen. Now only do that in the direction of a size -change. - -Win32: added menu to GUI tab pages line. (Yegappan Lakshmanan) - -Mac: Added document icons. (Benji Fisher) - -Insert mode completion: Using Enter to accept the current match causes -confusion. Use CTRL-Y instead. Also, use CTRL-E to go back to the typed -text. - -GUI: When there are left and right scrollbars, ":tabedit" kept them instead of -using the one that isn't needed. - -Using "gP" to replace al the text could leave the cursor below the last line, -causing ml_get errors. - -When 'cursorline' is set don't use the highlighting when Visual mode is -active, otherwise it's difficult to see the selected area. - -The matchparen plugin restricts the search to 100 lines, to avoid a long delay -when there are closed folds. - -Sometimes using CTRL-X s to list spelling suggestions used text from another -line. - -Win32: Set the default for 'isprint' back to the wrong default "@,~-255", -because many people use Windows-1252 while 'encoding' is "latin1". - -GTK: Added a workaround for gvim crashing when used over an untrusted ssh -link, caused by GTK doing something nasty. (Ed Catmur) - -Win32: The font used for the tab page labels is too big. Use the system menu -font. (George Reilly) - -Win32: Adjusting the window position and size to keep it on the screen didn't -work properly when the taskbar is on the left or top of the screen. - -The installman.sh and installml.sh scripts use ${10}, that didn't work with -old shells. And use "test -f" instead of "test -e". - -Win32: When 'encoding' was set in the vimrc then a directory argument for diff -mode didn't work. - -GUI: at the inputlist() prompt the cursorshape was adjusted as if the windows -were still at their old position. - -The parenmatch plugin didn't remember the highlighting per window. - -Using ":bd" for a buffer that's the current window in another tab page caused -a crash. - -For a new tab page the 'scroll' option wasn't set to a good default. - -Using an end offset for a search "/pat/e" didn't work properly for multi-byte -text. (Yukihiro Nakadaira) - -":s/\n/,/" doubled the text when used on the last line. - -When "search" is in 'foldopen' "[s" and "]s" now open folds. - -When using a numbered function "dict" can be omitted, but "self" didn't work -then. Always add FC_DICT to the function flags when it's part of a -dictionary. - -When "--remote-tab" executes locally it left an empty tab page. - -"gvim -u NONE", ":set cursorcolumn", "C" in the second line didn't update -text. Do update further lines even though the "$" is displayed. - -VMS: Support GTK better, also enable +clientserver. (Zoltan Arpadffy) - -When highlighting of statusline or tabline is changed there was no redraw to -show the effect. - -Mac: Added "CFBundleIdentifier" to infplist.xml. - -Added tabpage-local variables t:var. - -Win32: Added double-click in tab pages line creates new tab. (Yegappan -Lakshmanan) - -Motif: Added GUI tab pages line. (Yegappan Lakshmanan) - -Fixed crash when 'lines' was set to 1000 in a modeline. - -When init_spellfile() finds a writable directory in 'runtimepath' but it -doesn't contain a "spell" directory, create one. - -Win32: executable() also finds "xxd" in the directory where Vim was started, -but "!xxd" doesn't work. Append the Vim starting directory to $PATH. - -The tab page labels are shortened, directory names are reduced to a single -letter by default. Added the pathshorten() function to allow a user to do the -same. - -":saveas" now resets 'readonly' if the file was successfully written. - -Set $MYVIMRC file to the first found .vimrc file. -Set $MYGVIMRC file to the first found .gvimrc file. -Added menu item "Startup Settings" that edits the $MYVIMRC file - -Added matcharg(). - -Error message E745 appeared twice. Renamed one to E786. - -Fixed crash when using "au BufRead * Sexplore" and doing ":help". Was wiping -out a buffer that's still in a window. - -":hardcopy" resulted in an error message when 'encoding' is "utf-8" and -'printencoding' is empty. Now it assumes latin1. (Mike Williams) - -The check for the toolbar feature for Motif, depending on certain included -files, wasn't detailed enough, causing building to fail in gui_xmebw.c. - -Using CTRL-E in Insert mode completion after CTRL-P inserted the first match -instead of the original text. - -When displaying a UTF-8 character with a zero lower byte Vim might think the -previous character is double-wide. - -The "nbsp" item of 'listchars' didn't work when 'encoding' was utf-8. - -Motif: when Xm/xpm.h is missing gui_xmebw.c would not compile. -HAVE_XM_UNHIGHLIGHTT_H was missing a T. - -Mac: Moved the .icns files into src/os_mac_rsrc, so that they can all be -copied at once. Adjusted the Info.plist file for three icons. - -When Visual mode is active while switching to another tabpage could get ml_get -errors. - -When 'list' is set, 'nowrap' the $ in the first column caused 'cursorcolumn' -to move to the right. - -When a line wraps, 'cursorcolumn' was never displayed past the end of the -line. - -'autochdir' was only available when compiled with NetBeans and GUI. Now it's -a separate feature, also available in the "big" version. - -Added CTRL-W gf: open file under cursor in new tab page. - -When using the menu in the tab pages line, "New Tab" opens the new tab before -where the click was. Beyond the labels the new tab appears at the end instead -of after the current tab page. - -Inside a mapping with an expression getchar() could not be used. - -When vgetc is used recursively vgetc_busy protects it from being used -recursively. But after a ":normal" command the protection was reset. - -":s/a/b/n" didn't work when 'modifiable' was off. - -When $VIMRUNTIME includes a multi-byte character then rgb.txt could not be -found. (Yukihiro Nakadaira) - -":mkspell" didn't work correctly for non-ASCII affix flags when conversion is -needed on the spell file. - -glob('/dir/\$ABC/*') didn't work. - -When using several tab pages and changing 'cmdheight' the display could become -messed up. Now store the value of 'cmdheight' separately for each tab page. - -The user of the Enter key while the popup menu is visible was still confusing. -Now use Enter to select the match after using a cursor key. - -Added "usetab" to 'switchbuf'. - - ---- fixes and changes since Vim 7.0d --- - -Added CTRL-W T: move a window to a new tab page. - -Using CTRL-X s in Insert mode to complete spelling suggestions and using BS -deleted characters before the bad word. - -A few small fixes for the VMS makefile. (Zoltan Arpadffy) - -With a window of 91 lines 45 cols, ":vsp" scrolled the window. Copy w_wrow -when splitting a window and skip setting the height when it's already at the -right value. - -Using <silent> in a mapping with a shell command and the GUI caused redraw -to use wrong attributes. - -Win32: Using MSVC 4.1 for install.exe resulted in the start menu items to be -created in the administrator directory instead of "All Users". Define the -CSIDL_ items if they are missing. - -Motif: The GUI tabline did not use the space above the right scrollbar. Work -around a bug in the Motif library. (Yegappan Lakshmanan) - -The extra files for XML Omni completion are now also installed. -|xml-omni-datafile| - -GTK GUI: when 'm' is missing from 'guioptions' during startup and pressing -<F10> GTK produced error messages. Now do create the menu but disable it just -after the first gui_mch_update(). - -":mkspell" doesn't work well with the Hungarian dictionary from the Hunspell -project. Back to the Myspell dictionary. - -In help files hide the | used around tags. - -Renamed pycomplete to pythoncomplete. - -Added "tabpages" to 'sessionoptions'. - -When 'guitablabel' is set the effect wasn't visible right away. - -Fixed a few 'cindent' errors. - -When completing menu names, e.g., after ":emenu", don't sort the entries but -keep them in the original order. - -Fixed a crash when editing a directory in diff mode. Don't trigger -autocommands when executing the diff command. - -Getting a keystroke could get stuck if 'encoding' is a multi-byte encoding and -typing a special key. - -When 'foldignore' is set the folds were not updated right away. - -When a list is indexed with [a : b] and b was greater than the length an error -message was given. Now silently truncate the result. - -When using BS during Insert mode completion go back to the original text, so -that CTRL-N selects the first matching entry. - -Added the 'M' flag to 'cinoptions'. - -Win32: Make the "gvim --help" window appear in the middle of the screen -instead of at an arbitrary position. (Randall W. Morris) - -Added gettabwinvar() and settabwinvar(). - -Command line completion: pressing <Tab> after ":e /usr/*" expands the whole -tree, because it becomes ":e /usr/**". Don't add a star if there already is -one. - -Added grey10 to grey90 to all GUIs, so that they can all be used for -initializing highlighting. Use grey40 for CursorColumn and CursorLine when -'background' is "dark". - -When reading a file and using iconv for conversion, an incomplete byte -sequence at the end caused problems. (Yukihiro Nakadaira) - - ---- fixes and changes since Vim 7.0e --- - -Default color for MatchParen when 'background' is "dark" is now DarkCyan. - -":syn off" had to be used twice in a file that sets 'syntax' in a modeline. -(Michael Geddes) - -When using ":vsp" or ":sp" the available space wasn't used equally between -windows. (Servatius Brandt) - -Expanding <cWORD> on a trailing blank resulted in the first word in the line -if 'encoding' is a multi-byte encoding. - -Spell checking: spellbadword() didn't see a missing capital in the first word -of a line. Popup menu now only suggest the capitalized word when appropriate. - -When using whole line completion CTRL-L moves through the matches but it -didn't work when at the original text. - -When completion finds the longest match, don't go to the first match but stick -at the original text, so that CTRL-N selects the first one. - -Recognize "zsh-beta" like "zsh" for setting the 'shellpipe' default. (James -Vega) - -When using ":map <expr>" and the expression results in something with a -special byte (NUL or CSI) then it didn't work properly. Now escape special -bytes. - -The default Visual highlighting for a color xterm with 8 colors was a magenta -background, which made magenta text disappear. Now use reverse in this -specific situation. - -After completing the longest match "." didn't insert the same text. Repeating -also didn't work correctly for multi-byte text. - -When using Insert mode completion and BS the whole word that was completed -would result in all possible matches. Now stop completion. Also fixes that -for spell completion the previous word was deleted. - -GTK: When 'encoding' is "latin1" and using non-ASCII characters in a file name -the tab page label was wrong and an error message would be given. - -The taglist() function could hang on a tags line with a non-ASCII character. - -Win32: When 'encoding' differs from the system encoding tab page labels with -non-ASCII characters looked wrong. (Yegappan Lakshmanan) - -Motif: building failed when Xm/Notebook.h doesn't exist. Added a configure -check, disable GUI tabline when it's missing. - -Mac: When compiled without multi-byte feature the clipboard didn't work. - -It was possible to switch to another tab page when the cmdline window is open. - -Completion could hang when 'lines' is 6 and a preview window was opened. - -Added CTRL-W gF: open file under cursor in new tab page and jump to the line -number following the file name. -Added 'guitabtooltip'. Implemented for Win32 (Yegappan Lakshmanan). - -Added "throw" to 'debug' option: throw an exception for error messages even -whey they would otherwise be ignored. - -When 'keymap' is set and a line contains an invalid entry could get a "No -mapping found" warning instead of a proper error message. - -Motif: default to using XpmAttributes instead of XpmAttributes_21. - -A few more changes for 64 bit MS-Windows. (George Reilly) - -Got ml_get errors when doing "o" and selecting in other window where there are -less line shorter than the cursor position in the other window. ins_mouse() -was using position in wrong window. - -Win32 GUI: Crash when giving a lot of messages during startup. Allocate twice -as much memory for the dialog template. - -Fixed a few leaks and wrong pointer use reported by coverity. - -When showing menus the mode character was sometimes wrong. - -Added feedkeys(). (Yakov Lerner) - -Made matchlist() always return all submatches. - -Moved triggering QuickFixCmdPost to before jumping to the first location. - -Mac: Added the 'macatsui' option as a temporary work around for text drawing -problems. - -Line completion on "/**" gave error messages when scanning an unloaded buffer. - ---- fixes and changes since Vim 7.0f --- - -Win32: The height of the tab page labels is now adjusted to the font height. -(Yegappan Lakshmanan) - -Win32: selecting the tab label was off by one. (Yegappan Lakshmanan) - -Added tooltips for Motif and GTK tab page labels. (Yegappan Lakshmanan) - -When 'encoding' is "utf-8" then ":help spell" would report an illegal byte and -the file was not converted from latin1 to utf-8. Now retry with latin1 if -reading the file as utf-8 results in illegal bytes. - -Escape the argument of feedkeys() before putting it in the typeahead buffer. -(Yukihiro Nakadaira) - -Added the v:char variable for evaluating 'formatexpr'. (Yukihiro Nakadaira) - -With 8 colors Search highlighting combined with Statement highlighted text -made the text disappear. - -VMS: avoid warnings for redefining MAX and MIN. (Zoltan Arpadffy) - -When 'virtualedit' includes "onemore", stopping Visual selection would still -move the cursor left. - -Prevent that using CTRL-R = in Insert mode can start Visual mode. - -Fixed a crash that occurred when in Insert mode with completion active and a -mapping caused edit() to be called recursively. - -When using CTRL-O in Insert mode just after the last character while -'virtualedit' is "all", then typing CR moved the last character to the next -line. Call coladvance() before starting the new line. - -When using |:shell| ignore clicks on the tab page labels. Also when using the -command line window. - -When 'eventignore' is "all" then adding more to ignoring some events, e.g., -for ":vimgrep", would actually trigger more events. - -Win32: When a running Vim uses server name GVIM1 then "gvim --remote fname" -didn't find it. When looking for a server name that doesn't end in a digit -and it is not found then use another server with that name and a number (just -like on Unix). - -When using "double" in 'spellsuggest' when the language doesn't support sound -folding resulted in too many suggestions. - -Win32: Dropping a shortcut on the Vim icon didn't edit the referred file like -editing it in another way would. Use fname_expand() in buf_set_name() instead -of simply make the file name a full path. - -Using feedkeys() could cause Vim to hang. - -When closing another tab page from the tabline menu in Insert mode the tabline -was not updated right away. - -The syntax menu didn't work in compatible mode. - -After using ":tag id" twice with the same "id", ":ts" and then ":pop" a ":ts" -reported no matching tag. Clear the cached tag name. - -In Insert mode the matchparen plugin highlighted the wrong paren when there is -a string just next to a paren. - -GTK: After opening a new tab page the text was sometimes not drawn correctly. -Flush output and catch up with events when updating the tab page labels. - -In the GUI, using CTRL-W q to close the last window of a tab page could cause -a crash. - -GTK: The tab pages line menu was not converted from 'encoding' to utf-8. - -Typing a multi-byte character or a special key at the hit-enter prompt did not -work. - -When 'virtualedit' contains "onemore" CTRL-O in Insert mode still moved the -cursor left when it was after the end of the line, even though it's allowed to -be there. - -Added test for using tab pages. - -towupper() and towlower() were not used, because of checking for -__STDC__ISO_10646__ instead of __STDC_ISO_10646__. (sertacyildiz) - -For ":map <expr>" forbid changing the text, jumping to another buffer and -using ":normal" to avoid nasty side effects. - ---- fixes and changes since Vim 7.0g --- - -Compilation error on HP-UX, use of "dlerr" must be inside a #ifdef. -(Gary Johnson) - -Report +reltime feature in ":version" output. - -The tar and zip plugins detect failure to get the contents of the archive and -edit the file as-is. - -When the result of 'guitablabel' is empty fall back to the default label. - -Fixed crash when using ":insert" in a while loop and missing "endwhile". - -"gt" and other commands could move to another window when |textlock| active -and when the command line window was open. - -Spell checking a file with syntax highlighting and a bad word at the end of -the line is ignored could make "]s" hang. - -Mac: inputdialog() didn't work when compiled with big features. - -Interrupting ":vimgrep" while it is busy loading a file left a modified and -hidden buffer behind. Use enter_cleanup() and leave_cleanup() around -wipe_buffer(). - -When making 'keymap' empty the b:keymap_name variable wasn't deleted. - -Using CTRL-N that searches a long time, pressing space to interrupt the -searching and accept the first match, the popup menu was still displayed -briefly. - -When setting the Vim window height with -geometry the 'window' option could be -at a value that makes CTRL-F behave differently. - -When opening a quickfix window in two tabs they used different buffers, -causing redrawing problems later. Now use the same buffer for all quickfix -windows. (Yegappan Lakshmanan) - -When 'mousefocus' is set moving the mouse to the text tab pages line would -move focus to the first window. Also, the mouse pointer would jump to the -active window. - -In a session file, when an empty buffer is wiped out, do this silently. - -When one window has the cursor on the last line and another window is resized -to make that window smaller, the cursor line could go below the displayed -lines. In win_new_height() subtract one from the available space. -Also avoid that using "~" lines makes the window scroll down. - -Mac: When sourcing the "macmap.vim" script and then finding a .vimrc file the -'cpo' option isn't set properly, because it was already set and restored. -Added the <special> argument to ":map", so that 'cpo' doesn't need to be -changed to be able to use <> notation. Also do this for ":menu" for -consistency. - -When using "/encoding=abc" in a spell word list, only "bc" was used. - -When 'encoding' and 'printencoding' were both "utf-8" then ":hardcopy" didn't -work. (Mike Williams) - -Mac: When building with "--disable-gui" the install directory would still be -"/Applications" and Vim.app would be installed. Now install in /usr/local as -usual for a console application. - -GUI: when doing completion and there is one match and still searching for -another, the cursor was displayed at the end of the line instead of after the -match. Now show the cursor after the match while still searching for matches. - -GUI: The mouse shape changed on the statusline even when 'mouse' was empty and -they can't be dragged.. - -GTK2: Selecting a button in the confirm() dialog with Tab or cursor keys and -hitting Enter didn't select that button. Removed GTK 1 specific code. (Neil -Bird) - -When evaluating 'balloonexpr' takes a long time it could be called -recursively, which could cause a crash. - -exists() could not be used to detect whether ":2match" is supported. Added a -check for it specifically. - -GTK1: Tab page labels didn't work. (Yegappan Lakshmanan) - -Insert mode completion: When finding matches use 'ignorecase', but when adding -matches to the list don't use it, so that all words with different case are -added, "word", "Word" and "WORD". - -When 'cursorline' and 'hlsearch' are set and the search pattern is "x\n" -the rest of the line was highlighted as a match. - -Cursor moved while evaluating 'balloonexpr' that invokes ":isearch" and -redirects the output. Don't move the cursor to the command line if msg_silent -is set. - -exists() ignored text after a function name and option name, which could -result in false positives. - -exists() ignored characters after the recognized word, which can be wrong when -using a name with non-keyword characters. Specifically, these calls no longer -allow characters after the name: exists('*funcname') exists('*funcname(...') -exists('&option') exists(':cmd') exists('g:name') exists('g:name[n]') -exists('g:name.n') - -Trigger the TabEnter autocommand only after entering the current window of the -tab page, otherwise the commands are executed with an invalid current window. - -Win32: When using two monitors and Vim is on the second monitor, changing the -width of the Vim window could make it jump to the first monitor. - -When scrolling back at the more prompt and the quitting a line of text would -be left behind when 'cmdheight' is 2 or more. - -Fixed a few things for Insert mode completion, especially when typing BS, -CTRL-N or a printable character while still searching for matches. - - -============================================================================== -VERSION 7.1 *version-7.1* - -This section is about improvements made between version 7.0 and 7.1. - -This is a bug-fix release, there are no fancy new features. - - -Changed *changed-7.1* -------- - -Added setting 'mouse' in vimrc_example.vim. - -When building with MZscheme also look for include files in the "plt" -subdirectory. That's where they are for FreeBSD. - -The Ruby interface module is now called "Vim" instead of "VIM". But "VIM" is -an alias, so it's backwards compatible. (Tim Pope) - - -Added *added-7.1* ------ - -New syntax files: - /var/log/messages (Yakov Lerner) - Autohotkey (Nikolai Weibull) - AutoIt v3 (Jared Breland) - Bazaar commit file "bzr". (Dmitry Vasiliev) - Cdrdao TOC (Nikolai Weibull) - Cmusrc (Nikolai Weibull) - Conary recipe (rPath Inc) - Framescript (Nikolai Weibull) - FreeBasic (Mark Manning) - Hamster (David Fishburn) - IBasic (Mark Manning) - Initng (Elan Ruusamae) - Ldapconf (Nikolai Weibull) - Litestep (Nikolai Weibull) - Privoxy actions file (Doug Kearns) - Streaming Descriptors "sd" (Puria Nafisi Azizi) - -New tutor files: - Czech (Lubos Turek) - Hungarian (Arpad Horvath) - Turkish (Serkan kkk) - utf-8 version of Greek tutor. - utf-8 version of Russian tutor. - utf-8 version of Slowak tutor. - -New filetype plugins: - Bst (Tim Pope) - Cobol (Tim Pope) - Fvwm (Gautam Iyer) - Hamster (David Fishburn) - Django HTML template (Dave Hodder) - -New indent files: - Bst (Tim Pope) - Cobol (Tim Pope) - Hamster (David Fishburn) - Django HTML template (Dave Hodder) - Javascript - JSP (David Fishburn) - -New keymap files: - Bulgarian (Boyko Bantchev) - Mongolian (Natsagdorj Shagdar) - Thaana (Ibrahim Fayaz) - Vietnamese (Samuel Thibault) - -Other new runtime files: - Ada support files. (Neil Bird, Martin Krischik) - Slovenian menu translations (Mojca Miklavec) - Mono C# compiler plugin (Jarek Sobiecki) - - -Fixed *fixed-7.1* ------ - -Could not build the Win32s version. Added a few structure definitions in -src/gui_w32.c - - -Patch 7.0.001 -Problem: ":set spellsuggest+=10" does not work. (Suresh Govindachar) -Solution: Add P_COMMA to the 'spellsuggest' flags. -Files: src/option.c - -Patch 7.0.002 -Problem: C omni completion has a problem with tags files with a path - containing "#" or "%". -Solution: Escape these characters. (Sebastian Baberowski) -Files: runtime/autoload/ccomplete.vim - -Patch 7.0.003 -Problem: GUI: clicking in the lower part of a label in the tab pages line - while 'mousefocus' is set may warp the mouse pointer. (Robert - Webb) -Solution: Check for a negative mouse position. -Files: src/gui.c - -Patch 7.0.004 -Problem: Compiler warning for debug_saved used before set. (Todd Blumer) -Solution: Remove the "else" for calling save_dbg_stuff(). -Files: src/ex_docmd.c - -Patch 7.0.005 (extra) -Problem: Win32: The installer doesn't remove the "autoload" and "spell" - directories. (David Fishburn) -Solution: Add the directories to the list to be removed. -Files: nsis/gvim.nsi - -Patch 7.0.006 -Problem: Mac: "make shadow" doesn't make a link for infplist.xml. (Axel - Kielhorn) -Solution: Make the link. -Files: src/Makefile - -Patch 7.0.007 -Problem: AIX: compiling fails for message.c. (Ruediger Hornig) -Solution: Move the #if outside of memchr(). -Files: src/message.c - -Patch 7.0.008 -Problem: Can't call a function that uses both <SID> and {expr}. (Thomas) -Solution: Check both the expanded and unexpanded name for <SID>. -Files: src/eval.c - -Patch 7.0.009 -Problem: ml_get errors with both 'sidescroll' and 'spell' set. -Solution: Use ml_get_buf() instead of ml_get(), get the line from the right - buffer, not the current one. -Files: src/spell.c - -Patch 7.0.010 -Problem: The spellfile plugin required typing login name and password. -Solution: Use "anonymous" and "vim7user" by default. No need to setup a - .netrc file. -Files: runtime/autoload/spellfile.vim - -Patch 7.0.011 -Problem: Can't compile without the folding and with the eval feature. -Solution: Add an #ifdef. (Vallimar) -Files: src/option.c - -Patch 7.0.012 -Problem: Using the matchparen plugin, moving the cursor in Insert mode to a - shorter line that ends in a brace, changes the preferred column -Solution: Use winsaveview()/winrestview() instead of getpos()/setpos(). -Files: runtime/plugin/matchparen.vim - -Patch 7.0.013 -Problem: Insert mode completion: using CTRL-L to add an extra character - also deselects the current match, making it impossible to use - CTRL-L a second time. -Solution: Keep the current match. Also make CTRL-L work at the original - text, using the first displayed match. -Files: src/edit.c - -Patch 7.0.014 -Problem: Compiling gui_xmebw.c fails on Dec Alpha Tru64. (Rolfe) -Solution: Disable some code for Motif 1.2 and older. -Files: src/gui_xmebw.c - -Patch 7.0.015 -Problem: Athena: compilation problems with modern compiler. -Solution: Avoid type casts for lvalue. (Alexey Froloff) -Files: src/gui_at_fs.c - -Patch 7.0.016 -Problem: Printing doesn't work for "dec-mcs" encoding. -Solution: Add "dec-mcs", "mac-roman" and "hp-roman8" to the list of - recognized 8-bit encodings. (Mike Williams) -Files: src/mbyte.c - -Patch 7.0.017 (after 7.0.014) -Problem: Linking gui_xmebw.c fails on Dec Alpha Tru64. (Rolfe) -Solution: Adjust defines for Motif 1.2 and older. -Files: src/gui_xmebw.c - -Patch 7.0.018 -Problem: VMS: plugins are not loaded on startup. -Solution: Remove "**" from the path. (Zoltan Arpadffy) -Files: src/main.c - -Patch 7.0.019 -Problem: Repeating "VjA789" may cause a crash. (James Vega) -Solution: Check the cursor column after moving it to another line. -Files: src/ops.c - -Patch 7.0.020 -Problem: Crash when using 'mousefocus'. (William Fulton) -Solution: Make buffer for mouse coordinates 2 bytes longer. (Juergen Weigert) -Files: src/gui.c - -Patch 7.0.021 -Problem: Crash when using "\\[" and "\\]" in 'errorformat'. (Marc Weber) -Solution: Check for valid submatches after matching the pattern. -Files: src/quickfix.c - -Patch 7.0.022 -Problem: Using buffer.append() in Ruby may append the line to the wrong - buffer. (Alex Norman) -Solution: Properly switch to the buffer to do the appending. Also for - buffer.delete() and setting a buffer line. -Files: src/if_ruby.c - -Patch 7.0.023 -Problem: Crash when doing spell completion in an empty line and pressing - CTRL-E. -Solution: Check for a zero pointer. (James Vega) - Also handle a situation without a matching pattern better, report - "No matches" instead of remaining in undefined CTRL-X mode. And - get out of CTRL-X mode when typing a letter. -Files: src/edit.c - -Patch 7.0.024 -Problem: It is possible to set arbitrary "v:" variables. -Solution: Disallow setting "v:" variables that are not predefined. -Files: src/eval.c - -Patch 7.0.025 -Problem: Crash when removing an element of a:000. (Nikolai Weibull) -Solution: Mark the a:000 list with VAR_FIXED. -Files: src/eval.c - -Patch 7.0.026 -Problem: Using libcall() may show an old error. -Solution: Invoke dlerror() to clear a previous error. (Yukihiro Nakadaira) -Files: src/os_unix.c - -Patch 7.0.027 (extra) -Problem: Win32: When compiled with SNIFF gvim may hang on exit. -Solution: Translate and dispatch the WM_USER message. (Mathias Michaelis) -Files: src/gui_w48.c - -Patch 7.0.028 (extra) -Problem: OS/2: Vim doesn't compile with gcc 3.2.1. -Solution: Add argument to after_pathsep(), don't define vim_handle_signal(), - define HAVE_STDARG_H. (David Sanders) -Files: src/os_unix.c, src/vim.h, src/os_os2_cfg.h - -Patch 7.0.029 -Problem: getchar() may not position the cursor after a space. -Solution: Position the cursor explicitly. -Files: src/eval.c - -Patch 7.0.030 -Problem: The ":compiler" command can't be used in a FileChangedRO event. - (Hari Krishna Dara) -Solution: Add the CMDWIN flag to the ":compiler" command. -Files: src/ex_cmds.h - -Patch 7.0.031 -Problem: When deleting a buffer the buffer-local mappings for Select mode - remain. -Solution: Add the Select mode bit to MAP_ALL_MODES. (Edwin Steiner) -Files: src/vim.h - -Patch 7.0.032 (extra, after 7.0.027) -Problem: Missing semicolon. -Solution: Add the semicolon. -Files: src/gui_w48.c - -Patch 7.0.033 -Problem: When pasting text, with the menu or CTRL-V, autoindent is removed. -Solution: Use "x<BS>" to avoid indent to be removed. (Benji Fisher) -Files: runtime/autoload/paste.vim - -Patch 7.0.034 -Problem: After doing completion and typing more characters or using BS - repeating with "." didn't work properly. (Martin Stubenschrott) -Solution: Don't put BS and other characters in the redo buffer right away, - do this when finishing completion. -Files: src/edit.c - -Patch 7.0.035 -Problem: Insert mode completion works when typed but not when replayed from - a register. (Hari Krishna Dara) - Also: Mappings for Insert mode completion don't always work. -Solution: When finding a non-completion key in the input don't interrupt - completion when it wasn't typed. - Do use mappings when checking for typeahead while still finding - completions. Avoids that completion is interrupted too soon. - Use "compl_pending" in a different way. -Files: src/edit.c - -Patch 7.0.036 -Problem: Can't compile with small features and syntax highlighting or the - diff feature. -Solution: Define LINE_ATTR whenever syntax highlighting or the diff feature - is enabled. -Files: src/screen.c - -Patch 7.0.037 -Problem: Crash when resizing the GUI window vertically when there is a line - that doesn't fit. -Solution: Don't redraw while the screen data is invalid. -Files: src/screen.c - -Patch 7.0.038 -Problem: When calling complete() from an Insert mode expression mapping - text could be inserted in an improper way. -Solution: Make undo_allowed() global and use it in complete(). -Files: src/undo.c, src/proto/undo.pro, src/eval.c - -Patch 7.0.039 -Problem: Calling inputdialog() with a third argument in the console doesn't - work. -Solution: Make a separate function for input() and inputdialog(). (Yegappan - Lakshmanan) -Files: src/eval.c - -Patch 7.0.040 -Problem: When 'cmdheight' is larger than 1 using inputlist() or selecting - a spell suggestion with the mouse gets the wrong entry. -Solution: Start listing the first alternative on the last line of the screen. -Files: src/eval.c, src/spell.c - -Patch 7.0.041 -Problem: cursor([1, 1]) doesn't work. (Peter Hodge) -Solution: Allow leaving out the third item of the list and use zero for the - virtual column offset. -Files: src/eval.c - -Patch 7.0.042 -Problem: When pasting a block of text in Insert mode Vim hangs or crashes. - (Noam Halevy) -Solution: Avoid that the cursor is positioned past the NUL of a line. -Files: src/ops.c - -Patch 7.0.043 -Problem: Using "%!" at the start of 'statusline' doesn't work. -Solution: Recognize the special item when the option is being set. -Files: src/option.c - -Patch 7.0.044 -Problem: Perl: setting a buffer line in another buffer may result in - changing the current buffer. -Solution: Properly change to the buffer to be changed. -Files: src/if_perl.xs - -Patch 7.0.045 (extra) -Problem: Win32: Warnings when compiling OLE version with MSVC 2005. -Solution: Move including vim.h to before windows.h. (Ilya Bobir) -Files: src/if_ole.cpp - -Patch 7.0.046 -Problem: The matchparen plugin ignores parens in strings, but not in single - quotes, often marked with "character". -Solution: Also ignore parens in syntax items matching "character". -Files: runtime/plugin/matchparen.vim - -Patch 7.0.047 -Problem: When running configure the exit status is wrong. -Solution: Handle the exit status properly. (Matthew Woehlke) -Files: configure, src/configure - -Patch 7.0.048 -Problem: Writing a compressed file fails when there are parens in the name. - (Wang Jian) -Solution: Put quotes around the temp file name. -Files: runtime/autoload/gzip.vim - -Patch 7.0.049 -Problem: Some TCL scripts are not recognized. (Steven Atkinson) -Solution: Check for "exec wish" in the file. -Files: runtime/scripts.vim - -Patch 7.0.050 -Problem: After using the netbeans interface close command a stale pointer - may be used. -Solution: Clear the pointer to the closed buffer. (Xaview de Gaye) -Files: src/netbeans.c - -Patch 7.0.051 (after 7.0.44) -Problem: The Perl interface doesn't compile or doesn't work properly. -Solution: Remove the spaces before #ifdef and avoid an empty line above it. -Files: src/if_perl.xs - -Patch 7.0.052 -Problem: The user may not be aware that the Vim server allows others more - functionality than desired. -Solution: When running Vim as root don't become a Vim server without an - explicit --servername argument. -Files: src/main.c - -Patch 7.0.053 -Problem: Shortening a directory name may fail when there are multi-byte - characters. -Solution: Copy the correct bytes. (Titov Anatoly) -Files: src/misc1.c - -Patch 7.0.054 -Problem: Mac: Using a menu name that only has a mnemonic or accelerator - causes a crash. (Elliot Shank) -Solution: Check for an empty menu name. Also delete empty submenus that - were created before detecting the error. -Files: src/menu.c - -Patch 7.0.055 -Problem: ":startinsert" in a CmdwinEnter autocommand doesn't take immediate - effect. (Bradley White) -Solution: Put a NOP key in the typeahead buffer. Also avoid that using - CTRL-C to go back to the command line moves the cursor left. -Files: src/edit.c, src/ex_getln.c - -Patch 7.0.056 -Problem: "#!something" gives an error message. -Solution: Ignore this line, so that it can be used in an executable Vim - script. -Files: src/ex_docmd.c - -Patch 7.0.057 (extra, after 7.0.45) -Problem: Win32: Compilation problem with Borland C 5.5. -Solution: Include vim.h as before. (Mark S. Williams) -Files: src/if_ole.cpp - -Patch 7.0.058 -Problem: The gbk and gb18030 encodings are not recognized. -Solution: Add aliases to cp936. (Edward L. Fox) -Files: src/mbyte.c - -Patch 7.0.059 -Problem: The Perl interface doesn't compile with ActiveState Perl 5.8.8. -Solution: Remove the __attribute__() items. (Liu Yubao) -Files: src/if_perl.xs - -Patch 7.0.060 (after 7.0.51) -Problem: Code for temporarily switching to another buffer is duplicated in - quite a few places. -Solution: Use aucmd_prepbuf() and aucmd_restbuf() also when FEAT_AUTOCMD is - not defined. -Files: src/buffer.c, src/eval.c, src/fileio.c, src/if_ruby.c, - src/if_perl.xs, src/quickfix.c, src/structs.h - -Patch 7.0.061 -Problem: Insert mode completion for Vim commands may crash if there is - nothing to complete. -Solution: Instead of freeing the pattern make it empty, so that a "not - found" error is given. (Yukihiro Nakadaira) -Files: src/edit.c - -Patch 7.0.062 -Problem: Mac: Crash when using the popup menu for spell correction. The - popup menu appears twice when letting go of the right mouse button - early. -Solution: Don't show the popup menu on the release of the right mouse - button. Also check that a menu pointer is actually valid. -Files: src/proto/menu.pro, src/menu.c, src/normal.c, src/term.c - -Patch 7.0.063 -Problem: Tiny chance for a memory leak. (coverity) -Solution: Free pointer when next memory allocation fails. -Files: src/eval.c - -Patch 7.0.064 -Problem: Using uninitialized variable. (Tony Mechelynck) -Solution: When not used set "temp" to zero. Also avoid a warning for - "files" in ins_compl_dictionaries(). -Files: src/edit.c - -Patch 7.0.065 (extra) -Problem: Mac: left-right movement of the scrollwheel causes up-down - scrolling. -Solution: Ignore mouse wheel events that are not up-down. (Nicolas Weber) -Files: src/gui_mac.c - -Patch 7.0.066 -Problem: After the popup menu for Insert mode completion overlaps the tab - pages line it is not completely removed. -Solution: Redraw the tab pages line after removing the popup menu. (Ori - Avtalion) -Files: src/popupmnu.c - -Patch 7.0.067 -Problem: Undo doesn't always work properly when using "scim" input method. - Undo is split up when using preediting. -Solution: Reset xim_has_preediting also when preedit_start_col is not - MAXCOL. Don't split undo when <Left> is used while preediting. - (Yukihiro Nakadaira) -Files: src/edit.c, src/mbyte.c - -Patch 7.0.068 -Problem: When 'ignorecase' is set and using Insert mode completion, - typing characters to change the list of matches, case is not - ignored. (Hugo Ahlenius) -Solution: Store the 'ignorecase' flag with the matches where needed. -Files: src/edit.c, src/search.c, src/spell.c - -Patch 7.0.069 -Problem: Setting 'guitablabel' to %!expand(\%) causes Vim to free an - invalid pointer. (Kim Schulz) -Solution: Don't try freeing a constant string pointer. -Files: src/buffer.c - -Patch 7.0.070 -Problem: Compiler warnings for shadowed variables and uninitialized - variables. -Solution: Rename variables such as "index", "msg" and "dup". Initialize - variables. -Files: src/edit.c, src/eval.c, src/ex_cmds.c, src/ex_cmds2.c, - src/ex_docmd.c, src/gui_beval.c, src/gui_gtk.c, src/gui_gtk_x11.c, - src/hardcopy.c, src/if_cscope.c, src/main.c, src/mbyte.c, - src/memline.c, src/netbeans.c, src/normal.c, src/option.c, - src/os_unix.c, src/quickfix.c, src/regexp.c, src/screen.c, - src/search.c, src/spell.c, src/ui.c, src/undo.c, src/window.c, - src/version.c - -Patch 7.0.071 -Problem: Using an empty search pattern may cause a crash. -Solution: Avoid using a NULL pointer. -Files: src/search.c - -Patch 7.0.072 -Problem: When starting the GUI fails there is no way to adjust settings or - do something else. -Solution: Add the GUIFailed autocommand event. -Files: src/fileio.c, src/gui.c, src/vim.h - -Patch 7.0.073 -Problem: Insert mode completion: Typing <CR> sometimes selects the original - text instead of keeping what was typed. (Justin Constantino) -Solution: Don't let <CR> select the original text if there is no popup menu. -Files: src/edit.c - -Patch 7.0.074 (extra) -Problem: Win32: tooltips were not converted from 'encoding' to Unicode. -Solution: Set the tooltip to use Unicode and do the conversion. Also - cleanup the code for the tab pages tooltips. (Yukihiro Nakadaira) -Files: src/gui_w32.c, src/gui_w48.c - -Patch 7.0.075 -Problem: winsaveview() did not store the actual value of the desired cursor - column. This could move the cursor in the matchparen plugin. -Solution: Call update_curswant() before using the value w_curswant. -Files: src/eval.c - -Patch 7.0.076 (after 7.0.010) -Problem: Automatic downloading of spell files only works for ftp. -Solution: Don't add login and password for non-ftp URLs. (Alexander Patrakov) -Files: runtime/autoload/spellfile.vim - -Patch 7.0.077 -Problem: ":unlet v:this_session" causes a crash. (Marius Roets) -Solution: When trying to unlet a fixed variable give an error message. -Files: src/eval.c - -Patch 7.0.078 -Problem: There are two error messages E46. -Solution: Change the number for the sandbox message to E794. -Files: src/globals.h - -Patch 7.0.079 -Problem: Russian tutor doesn't work when 'encoding' is "utf-8". -Solution: Use tutor.ru.utf-8 as the master, and generate the other encodings - from it. Select the right tutor depending on 'encoding'. (Alexey - Froloff) -Files: runtime/tutor/Makefile, runtime/tutor/tutor.vim, - runtime/tutor/tutor.ru.utf-8 - -Patch 7.0.080 -Problem: Generating auto/pathdef.c fails for CFLAGS with a backslash. -Solution: Double backslashes in the string. (Alexey Froloff) -Files: src/Makefile - -Patch 7.0.081 -Problem: Command line completion doesn't work for a shell command with an - absolute path. -Solution: Don't use $PATH when there is an absolute path. -Files: src/ex_getln.c - -Patch 7.0.082 -Problem: Calling a function that waits for input may cause List and - Dictionary arguments to be freed by the garbage collector. -Solution: Keep a list of all arguments to internal functions. -Files: src/eval.c - -Patch 7.0.083 -Problem: Clicking with the mouse on an item for inputlist() doesn't work - when 'compatible' is set and/or when 'cmdheight' is more than one. - (Christian J. Robinson) -Solution: Also decrement "lines_left" when 'more' isn't set. Set - "cmdline_row" to zero to get all mouse events. -Files: src/message.c, src/misc1.c - -Patch 7.0.084 -Problem: The garbage collector may do its work while some Lists or - Dictionaries are used internally, e.g., by ":echo" that runs into - the more-prompt or ":echo [garbagecollect()]". -Solution: Only do garbage collection when waiting for a character at the - toplevel. Let garbagecollect() set a flag that is handled at the - toplevel before waiting for a character. -Files: src/eval.c, src/getchar.c, src/globals.h, src/main.c - -Patch 7.0.085 -Problem: When doing "make test" the viminfo file is modified. -Solution: Use another viminfo file after setting 'compatible. -Files: src/testdir/test56.in - -Patch 7.0.086 -Problem: getqflist() returns entries for pattern and text with the number - zero. Passing these to setqflist() results in the string "0". -Solution: Use an empty string instead of the number zero. -Files: src/quickfix.c - -Patch 7.0.087 -Problem: After ":file fname" and ":saveas fname" the 'autochdir' option - does not take effect. (Yakov Lerner) - Commands for handling 'autochdir' are repeated many times. -Solution: Add the DO_AUTOCHDIR macro and do_autochdir(). Use it for - ":file fname" and ":saveas fname". -Files: src/proto/buffer.pro, src/buffer.c, src/ex_cmds.c, src/macros.h, - src/netbeans.c, src/option.c, src/window.c - -Patch 7.0.088 -Problem: When compiled with Perl the generated prototypes have "extern" - unnecessarily added. -Solution: Remove the "-pipe" argument from PERL_CFLAGS. -Files: src/auto/configure, src/configure.in - -Patch 7.0.089 -Problem: "ga" does not work properly for a non-Unicode multi-byte encoding. -Solution: Only check for composing chars for utf-8. (Taro Muraoka) -Files: src/ex_cmds.c - -Patch 7.0.090 -Problem: Cancelling the conform() dialog on the console with Esc requires - typing it twice. (Benji Fisher) -Solution: When the start of an escape sequence is found use 'timeoutlen' or - 'ttimeoutlen'. -Files: src/misc1.c - -Patch 7.0.091 -Problem: Using winrestview() while 'showcmd' is set causes the cursor to be - displayed in the wrong position. (Yakov Lerner) -Solution: Set the window topline properly. -Files: src/eval.c - -Patch 7.0.092 (after 7.0.082 and 7.0.084) -Problem: The list of internal function arguments is obsolete now that - garbage collection is only done at the toplevel. -Solution: Remove the list of all arguments to internal functions. -Files: src/eval.c - -Patch 7.0.093 -Problem: The matchparen plugin can't handle a 'matchpairs' value where a - colon is matched. -Solution: Change the split() that is used to change 'matchpairs' into a - List. -Files: runtime/plugin/matchparen.vim - -Patch 7.0.094 -Problem: When a hidden buffer is made the current buffer and another file - edited later, the file message will still be given. Using - ":silent" also doesn't prevent the file message. (Marvin Renich) -Solution: Reset the need_fileinfo flag when reading a file. Don't set - need_fileinfo when msg_silent is set. -Files: src/buffer.c, src/fileio.c - -Patch 7.0.095 -Problem: The Greek tutor is not available in utf-8. "el" is used for the - language, only "gr" for the country is recognized. -Solution: Add the utf-8 Greek tutor. Use it for conversion to iso-8859-7 - and cp737. (Lefteris Dimitroulakis) -Files: runtime/tutor/Makefile, runtime/tutor/tutor.gr.utf-8, - runtime/tutor/tutor.vim - -Patch 7.0.096 -Problem: taglist() returns the filename relative to the tags file, while - the directory of the tags file is unknown. (Hari Krishna Dara) -Solution: Expand the file name. (Yegappan Lakshmanan) -Files: src/tag.c - -Patch 7.0.097 -Problem: ":tabclose N" that closes another tab page does not remove the tab - pages line. Same problem when using the mouse. -Solution: Adjust the tab pages line when needed in tabpage_close_other(). -Files: src/ex_docmd.c - -Patch 7.0.098 -Problem: Redirecting command output in a cmdline completion function - doesn't work. (Hari Krishna Dara) -Solution: Enable redirection when redirection is started. -Files: src/ex_docmd.c, src/ex_getln.c - -Patch 7.0.099 -Problem: GUI: When the popup menu is visible using the scrollbar messes up - the display. -Solution: Disallow scrolling the current window. Redraw the popup menu - after scrolling another window. -Files: src/gui.c - -Patch 7.0.100 -Problem: "zug" may report the wrong filename. (Lawrence Kesteloot) -Solution: Call home_replace() to fill NameBuff[]. -Files: src/spell.c - -Patch 7.0.101 -Problem: When the "~/.vim/spell" directory does not exist "zg" may create - a wrong directory. "zw" doesn't work. -Solution: Use the directory of the file name instead of NameBuff. For "zw" - not only remove a good word but also add the word with "!". -Files: src/spell.c - -Patch 7.0.102 -Problem: Redrawing cmdline is not correct when using SCIM. -Solution: Don't call im_get_status(). (Yukihiro Nakadaira) -Files: src/ex_getln.c - -Patch 7.0.103 (after 7.0.101) -Problem: Compiler warning for uninitialized variable. (Tony Mechelynck) -Solution: Init variable. -Files: src/spell.c - -Patch 7.0.104 -Problem: The CursorHoldI event only triggers once in Insert mode. It also - triggers after CTRL-V and other two-key commands. -Solution: Set "did_cursorhold" before getting a second key. Reset - "did_cursorhold" after handling a command. -Files: src/edit.c, src/fileio.c - -Patch 7.0.105 -Problem: When using incremental search the statusline ruler isn't updated. - (Christoph Koegl) -Solution: Update the statusline when it contains the ruler. -Files: src/ex_getln.c - -Patch 7.0.106 -Problem: The spell popup menu uses ":amenu", triggering mappings. Other - PopupMenu autocommands are removed. (John Little) -Solution: Use ":anoremenu" and use an autocmd group. -Files: runtime/menu.vim - -Patch 7.0.107 -Problem: Incremental search doesn't redraw the text tabline. (Ilya Bobir) - Also happens in other situations with one window in a tab page. -Solution: Redraw the tabline after clearing the screen. -Files: src/screen.c - -Patch 7.0.108 (extra) -Problem: Amiga: Compilation problem. -Solution: Have mch_mkdir() return a failure flag. (Willy Catteau) -Files: src/os_amiga.c, src/proto/os_amiga.pro - -Patch 7.0.109 -Problem: Lisp indenting is confused by escaped quotes in strings. (Dorai - Sitaram) -Solution: Check for backslash inside strings. (Sergey Khorev) -Files: src/misc1.c - -Patch 7.0.110 -Problem: Amiga: Compilation problems when not using libnix. -Solution: Change a few #ifdefs. (Willy Catteau) -Files: src/memfile.c - -Patch 7.0.111 -Problem: The gzip plugin can't handle filenames with single quotes. -Solution: Add and use the shellescape() function. (partly by Alexey Froloff) -Files: runtime/autoload/gzip.vim, runtime/doc/eval.txt, src/eval.c, - src/mbyte.c, src/misc2.c, src/proto/misc2.pro - -Patch 7.0.112 -Problem: Python interface does not work with Python 2.5. -Solution: Change PyMem_DEL() to Py_DECREF(). (Sumner Hayes) -Files: src/if_python.c - -Patch 7.0.113 -Problem: Using CTRL-L in Insert completion when there is no current match - may cause a crash. (Yukihiro Nakadaira) -Solution: Check for compl_leader to be NULL -Files: src/edit.c - -Patch 7.0.114 -Problem: When aborting an insert with CTRL-C an extra undo point is - created in the GUI. (Yukihiro Nakadaira) -Solution: Call gotchars() only when advancing. -Files: src/getchar.c - -Patch 7.0.115 -Problem: When 'ignorecase' is set, Insert mode completion only adds "foo" - and not "Foo" when both are found. - A found match isn't displayed right away when 'completeopt' does - not have "menu" or "menuone". -Solution: Do not ignore case when checking if a completion match already - exists. call ins_compl_check_keys() also when not using a popup - menu. (Yukihiro Nakadaira) -Files: src/edit.c - -Patch 7.0.116 -Problem: 64 bit Windows version reports "32 bit" in the ":version" output. - (M. Veerman) -Solution: Change the text for Win64. -Files: src/version.c - -Patch 7.0.117 -Problem: Using "extend" on a syntax item inside a region with "keepend", an - intermediate item may be truncated. - When applying the "keepend" and there is an offset to the end - pattern the highlighting of a contained item isn't adjusted. -Solution: Use the seen_keepend flag to remember when to apply the "keepend" - flag. Adjust the keepend highlighting properly. (Ilya Bobir) -Files: src/syntax.c - -Patch 7.0.118 -Problem: printf() does not do zero padding for strings. -Solution: Do allow zero padding for strings. -Files: src/message.c - -Patch 7.0.119 -Problem: When going back from Insert to Normal mode the CursorHold event - doesn't trigger. (Yakov Lerner) -Solution: Reset "did_cursorhold" when leaving Insert mode. -Files: src/edit.c - -Patch 7.0.120 -Problem: Crash when using CTRL-R = at the command line and entering - "getreg('=')". (James Vega) -Solution: Avoid recursiveness of evaluating the = register. -Files: src/ops.c - -Patch 7.0.121 -Problem: GUI: Dragging the last status line doesn't work when there is a - text tabline. (Markus Wolf) -Solution: Take the text tabline into account when deciding to start modeless - selection. -Files: src/gui.c - -Patch 7.0.122 -Problem: GUI: When clearing after a bold, double-wide character half a - character may be drawn. -Solution: Check for double-wide character and redraw it. (Yukihiro Nakadaira) -Files: src/screen.c - -Patch 7.0.123 -Problem: On SCO Openserver configure selects the wrong terminal library. -Solution: Put terminfo before the other libraries. (Roger Cornelius) - Also fix a small problem compiling on Mac without Darwin. -Files: src/configure.in, src/auto/configure - -Patch 7.0.124 -Problem: getwinvar() obtains a dictionary with window-local variables, but - it's always for the current window. -Solution: Get the variables of the specified window. (Geoff Reedy) -Files: src/eval.c - -Patch 7.0.125 -Problem: When "autoselect" is in the 'clipboard' option then the '< and '> - marks are set while Visual mode is still active. -Solution: Don't set the '< and '> marks when yanking the selected area for - the clipboard. -Files: src/normal.c - -Patch 7.0.126 -Problem: When 'formatexpr' uses setline() and later internal formatting is - used undo information is not correct. (Jiri Cerny, Benji Fisher) -Solution: Set ins_need_undo after using 'formatexpr'. -Files: src/edit.c - -Patch 7.0.127 -Problem: Crash when swap files has invalid timestamp. -Solution: Check return value of ctime() for being NULL. -Files: src/memline.c - -Patch 7.0.128 -Problem: GUI: when closing gvim is cancelled because there is a changed - buffer the screen isn't updated to show the changed buffer in the - current window. (Krzysztof Kacprzak) -Solution: Redraw when closing gvim is cancelled. -Files: src/gui.c - -Patch 7.0.129 -Problem: GTK GUI: the GTK file dialog can't handle a relative path. -Solution: Make the initial directory a full path before passing it to GTK. - (James Vega) Also postpone adding the default file name until - after setting the directory. -Files: src/gui_gtk.c - -Patch 7.0.130 (extra) -Problem: Win32: Trying to edit or write devices may cause Vim to get stuck. -Solution: Add the 'opendevice' option, default off. Disallow - reading/writing from/to devices when it's off. - Also detect more devices by the full name starting with "\\.\". -Files: runtime/doc/options.txt, src/fileio.c, src/option.c, src/option.h, - src/os_win32.c - -Patch 7.0.131 -Problem: Win32: "vim -r" does not list all the swap files. -Solution: Also check for swap files starting with a dot. -Files: src/memline.c - -Patch 7.0.132 (after 7.0.130) -Problem: Win32: Crash when Vim reads from stdin. -Solution: Only use mch_nodetype() when there is a file name. -Files: src/fileio.c - -Patch 7.0.133 -Problem: When searching included files messages are added to the history. -Solution: Set msg_hist_off for messages about scanning included files. - Set msg_silent to avoid message about wrapping around. -Files: src/edit.c, src/globals.h, src/message.c, src/search.c - -Patch 7.0.134 -Problem: Crash when comparing a recursively looped List or Dictionary. -Solution: Limit recursiveness for comparing to 1000. -Files: src/eval.c - -Patch 7.0.135 -Problem: Crash when garbage collecting list or dict with loop. -Solution: Don't use DEL_REFCOUNT but don't recurse into Lists and - Dictionaries when freeing them in the garbage collector. - Also add allocated Dictionaries to the list of Dictionaries to - avoid leaking memory. -Files: src/eval.c, src/proto/eval.pro, src/tag.c - -Patch 7.0.136 -Problem: Using "O" while matching parens are highlighted may not remove the - highlighting. (Ilya Bobir) -Solution: Also trigger CursorMoved when a line is inserted under the cursor. -Files: src/misc1.c - -Patch 7.0.137 -Problem: Configure check for big features is wrong. -Solution: Change "==" to "=". (Martti Kuparinen) -Files: src/auto/configure, src/configure.in - -Patch 7.0.138 (extra) -Problem: Mac: modifiers don't work with function keys. -Solution: Use GetEventParameter() to obtain modifiers. (Nicolas Weber) -Files: src/gui_mac.c - -Patch 7.0.139 -Problem: Using CTRL-PageUp or CTRL-PageDown in Insert mode to go to another - tab page does not prepare for undo properly. (Stefano Zacchiroli) -Solution: Call start_arrow() before switching tab page. -Files: src/edit.c - -Patch 7.0.140 (after 7.0.134) -Problem: Comparing recursively looped List or Dictionary doesn't work well. -Solution: Detect comparing a List or Dictionary with itself. -Files: src/eval.c - -Patch 7.0.141 -Problem: When pasting a while line on the command line an extra CR is added - literally. -Solution: Don't add the trailing CR when pasting with the mouse. -Files: src/ex_getln.c, src/proto/ops.pro, src/ops.c - -Patch 7.0.142 -Problem: Using the middle mouse button in Select mode to paste text results - in an extra "y". (Kriton Kyrimis) -Solution: Let the middle mouse button replace the selected text with the - contents of the clipboard. -Files: src/normal.c - -Patch 7.0.143 -Problem: Setting 'scroll' to its default value was not handled correctly. -Solution: Compare the right field to PV_SCROLL. -Files: src/option.c - -Patch 7.0.144 -Problem: May compare two unrelated pointers when matching a pattern against - a string. (Dominique Pelle) -Solution: Avoid calling reg_getline() when REG_MULTI is false. -Files: src/regexp.c - -Patch 7.0.145 (after 7.0.142) -Problem: Compiler warning. -Solution: Add type cast. -Files: src/normal.c - -Patch 7.0.146 -Problem: When 'switchbuf' is set to "usetab" and the current tab has only a - quickfix window, jumping to an error always opens a new window. - Also, when the buffer is open in another tab page it's not found. -Solution: Check for the "split" value of 'switchbuf' properly. Search in - other tab pages for the desired buffer. (Yegappan Lakshmanan) -Files: src/buffer.c, src/quickfix.c - -Patch 7.0.147 -Problem: When creating a session file and there are several tab pages and - some windows have a local directory a short file name may be used - when it's not valid. (Marius Roets) - A session with multiple tab pages may result in "No Name" buffers. - (Bill McCarthy) -Solution: Don't enter tab pages when going through the list, only use a - pointer to the first window in each tab page. - Use "tabedit" instead of "tabnew | edit" when possible. -Files: src/ex_docmd.c - -Patch 7.0.148 -Problem: When doing "call a.xyz()" and "xyz" does not exist in dictionary - "a" there is no error message. (Yegappan Lakshmanan) -Solution: Add the error message. -Files: src/eval.c - -Patch 7.0.149 -Problem: When resizing a window that shows "~" lines the text sometimes - jumps down. -Solution: Remove code that uses "~" lines in some situations. Fix the - computation of the screen line of the cursor. Also set w_skipcol - to handle very long lines. -Files: src/misc1.c, src/window.c - -Patch 7.0.150 -Problem: When resizing the Vim window scrollbinding doesn't work. (Yakov - Lerner) -Solution: Do scrollbinding in set_shellsize(). -Files: src/term.c - -Patch 7.0.151 -Problem: Buttons in file dialog are not according to Gnome guidelines. -Solution: Swap Cancel and Open buttons. (Stefano Zacchiroli) -Files: src/gui_gtk.c - -Patch 7.0.152 -Problem: Crash when using lesstif 2. -Solution: Fill in the extension field. (Ben Hutchings) -Files: src/gui_xmebw.c - -Patch 7.0.153 -Problem: When using cscope and opening the temp file fails Vim crashes. - (Kaya Bekiroglu) -Solution: Check for NULL pointer returned from mch_open(). -Files: src/if_cscope.c - -Patch 7.0.154 -Problem: When 'foldnextmax' is negative Vim can hang. (James Vega) -Solution: Avoid the fold level becoming negative. -Files: src/fold.c, src/syntax.c - -Patch 7.0.155 -Problem: When getchar() returns a mouse button click there is no way to get - the mouse coordinates. -Solution: Add v:mouse_win, v:mouse_lnum and v:mouse_col. -Files: runtime/doc/eval.txt, src/eval.c, src/vim.h - -Patch 7.0.156 (extra) -Problem: Vim doesn't compile for Amiga OS 4. -Solution: Various changes for Amiga OS4. (Peter Bengtsson) -Files: src/feature.h, src/mbyte.c, src/memfile.c, src/memline.c, - src/os_amiga.c, src/os_amiga.h, src/pty.c - -Patch 7.0.157 -Problem: When a function is used recursively the profiling information is - invalid. (Mikolaj Machowski) -Solution: Put the start time on the stack instead of in the function. -Files: src/eval.c - -Patch 7.0.158 -Problem: In a C file with ":set foldmethod=syntax", typing {<CR> on the - last line results in the cursor being in a closed fold. (Gautam - Iyer) -Solution: Open fold after inserting a new line. -Files: src/edit.c - -Patch 7.0.159 -Problem: When there is an I/O error in the swap file the cause of the error - cannot be seen. -Solution: Use PERROR() instead of EMSG() where possible. -Files: src/memfile.c - -Patch 7.0.160 -Problem: ":@a" echoes the command, Vi doesn't do that. -Solution: Set the silent flag in the typeahead buffer to avoid echoing the - command. -Files: src/ex_docmd.c, src/normal.c, src/ops.c, src/proto/ops.pro - -Patch 7.0.161 -Problem: Win32: Tab pages line popup menu isn't using the right encoding. - (Yongwei Wu) -Solution: Convert the text when necessary. Also fixes the Find/Replace - dialog title. (Yegappan Lakshmanan) -Files: src/gui_w48.c - -Patch 7.0.162 -Problem: "vim -o a b" when file "a" triggers the ATTENTION dialog, - selecting "Quit" exits Vim instead of editing "b" only. - When file "b" triggers the ATTENTION dialog selecting "Quit" or - "Abort" results in editing file "a" in that window. -Solution: When selecting "Abort" exit Vim. When selecting "Quit" close the - window. Also avoid hit-enter prompt when selecting Abort. -Files: src/buffer.c, src/main.c - -Patch 7.0.163 -Problem: Can't retrieve the position of a sign after it was set. -Solution: Add the netbeans interface getAnno command. (Xavier de Gaye) -Files: runtime/doc/netbeans.txt, src/netbeans.c - -Patch 7.0.164 -Problem: ":redir @+" doesn't work. -Solution: Accept "@+" just like "@*". (Yegappan Lakshmanan) -Files: src/ex_docmd.c - -Patch 7.0.165 -Problem: Using CTRL-L at the search prompt adds a "/" and other characters - without escaping, causing the pattern not to match. -Solution: Escape special characters with a backslash. -Files: src/ex_getln.c - -Patch 7.0.166 -Problem: Crash in cscope code when connection could not be opened. - (Kaya Bekiroglu) -Solution: Check for the file descriptor to be NULL. -Files: src/if_cscope.c - -Patch 7.0.167 -Problem: ":function" redefining a dict function doesn't work properly. - (Richard Emberson) -Solution: Allow a function name to be a number when it's a function - reference. -Files: src/eval.c - -Patch 7.0.168 -Problem: Using uninitialized memory and memory leak. (Dominique Pelle) -Solution: Use alloc_clear() instead of alloc() for w_lines. Free - b_ml.ml_stack after recovery. -Files: src/memline.c, src/window.c - -Patch 7.0.169 -Problem: With a Visual block selection, with the cursor in the left upper - corner, pressing "I" doesn't remove the highlighting. (Guopeng - Wen) -Solution: When checking if redrawing is needed also check if Visual - selection is still active. -Files: src/screen.c - -Patch 7.0.170 (extra) -Problem: Win32: Using "gvim --remote-tab foo" when gvim is minimized while - it previously was maximized, un-maximizing doesn't work properly. - And the labels are not displayed properly when 'encoding' is - utf-8. -Solution: When minimized check for SW_SHOWMINIMIZED. When updating the tab - pages line use TCM_SETITEMW instead of TCM_INSERTITEMW. (Liu - Yubao) -Files: src/gui_w48.c - -Patch 7.0.171 (extra) -Problem: VMS: A file name with multiple paths is written in the wrong file. -Solution: Get the actually used file name. (Zoltan Arpadffy) - Also add info to the :version command about compilation. -Files: src/Make_vms.mms, src/buffer.c, src/os_unix.c, src/version.c - -Patch 7.0.172 -Problem: Crash when recovering and quitting at the "press-enter" prompt. -Solution: Check for "msg_list" to be NULL. (Liu Yubao) -Files: src/ex_eval.c - -Patch 7.0.173 -Problem: ":call f().TT()" doesn't work. (Richard Emberson) -Solution: When a function returns a Dictionary or another composite continue - evaluating what follows. -Files: src/eval.c - -Patch 7.0.174 -Problem: ":mksession" doesn't restore window layout correctly in tab pages - other than the current one. (Zhibin He) -Solution: Use the correct topframe for producing the window layout commands. -Files: src/ex_docmd.c - -Patch 7.0.175 -Problem: The result of tr() is missing the terminating NUL. (Ingo Karkat) -Solution: Add the NUL. -Files: src/eval.c - -Patch 7.0.176 -Problem: ":emenu" isn't executed directly, causing the encryption key - prompt to fail. (Life Jazzer) -Solution: Fix wrong #ifdef. -Files: src/menu.c - -Patch 7.0.177 -Problem: When the press-enter prompt gets a character from a non-remappable - mapping, it's put back in the typeahead buffer as remappable, - which may cause an endless loop. -Solution: Restore the non-remappable flag and the silent flag when putting a - char back in the typeahead buffer. -Files: src/getchar.c, src/message.c, src/normal.c - -Patch 7.0.178 -Problem: When 'enc' is "utf-8" and 'ignorecase' is set the result of ":echo - ("\xe4" == "\xe4")" varies. -Solution: In mb_strnicmp() avoid looking past NUL bytes. -Files: src/mbyte.c - -Patch 7.0.179 -Problem: Using ":recover" or "vim -r" without a swapfile crashes Vim. -Solution: Check for "buf" to be unequal NULL. (Yukihiro Nakadaira) -Files: src/memline.c - -Patch 7.0.180 (extra, after 7.0.171) -Problem: VMS: build failed. Problem with swapfiles. -Solution: Add "compiled_arch". Always expand path and pass it to - buf_modname(). (Zoltan Arpadffy) -Files: src/globals.h, src/memline.c, src/os_unix.c, runtime/menu.vim - -Patch 7.0.181 -Problem: When reloading a file that starts with an empty line, the reloaded - buffer has an extra empty line at the end. (Motty Lentzitzky) -Solution: Delete all lines, don't use bufempty(). -Files: src/fileio.c - -Patch 7.0.182 -Problem: When using a mix of undo and "g-" it may no longer be possible to - go to every point in the undo tree. (Andy Wokula) -Solution: Correctly update pointers in the undo tree. -Files: src/undo.c - -Patch 7.0.183 -Problem: Crash in ":let" when redirecting to a variable that's being - displayed. (Thomas Link) -Solution: When redirecting to a variable only do the assignment when - stopping redirection to avoid that setting the variable causes a - freed string to be accessed. -Files: src/eval.c - -Patch 7.0.184 -Problem: When the cscope program is called "mlcscope" the Cscope interface - doesn't work. -Solution: Accept "\S*cscope:" instead of "cscope:". (Frodak D. Baksik) -Files: src/if_cscope.c - -Patch 7.0.185 -Problem: Multi-byte characters in a message are displayed with attributes - from what comes before it. -Solution: Don't use the attributes for a multi-byte character. Do use - attributes for special characters. (Yukihiro Nakadaira) -Files: src/message.c - -Patch 7.0.186 -Problem: Get an ml_get error when 'encoding' is "utf-8" and searching for - "/\_s*/e" in an empty buffer. (Andrew Maykov) -Solution: Don't try getting the line just below the last line. -Files: src/search.c - -Patch 7.0.187 -Problem: Can't source a remote script properly. -Solution: Add the SourceCmd event. (Charles Campbell) -Files: runtime/doc/autocmd.txt, src/ex_cmds2.c, src/fileio.c, src/vim.h - -Patch 7.0.188 (after 7.0.186) -Problem: Warning for wrong pointer type. -Solution: Add a type cast. -Files: src/search.c - -Patch 7.0.189 -Problem: Translated message about finding matches is truncated. (Yukihiro - Nakadaira) -Solution: Enlarge the buffer. Also use vim_snprintf(). -Files: src/edit.c - -Patch 7.0.190 -Problem: "syntax spell default" results in an error message. -Solution: Change 4 to 7 for STRNICMP(). (Raul Nunez de Arenas Coronado) -Files: src/syntax.c - -Patch 7.0.191 -Problem: The items used by getqflist() and setqflist() don't match. -Solution: Support the "bufnum" item for setqflist(). (Yegappan Lakshmanan) -Files: runtime/doc/eval.txt, src/quickfix.c - -Patch 7.0.192 -Problem: When 'swapfile' is switched off in an empty file it is possible - that not all blocks are loaded into memory, causing ml_get errors - later. -Solution: Rename "dont_release" to "mf_dont_release" and also use it to - avoid using the cached line and locked block. -Files: src/globals.h, src/memfile.c, src/memline.c - -Patch 7.0.193 -Problem: Using --remote or --remote-tab with an argument that matches - 'wildignore' causes a crash. -Solution: Check the argument count before using ARGLIST[0]. -Files: src/ex_cmds.c - -Patch 7.0.194 -Problem: Once an ml_get error is given redrawing part of the screen may - cause it again, resulting in an endless loop. -Solution: Don't give the error message for a recursive call. -Files: src/memline.c - -Patch 7.0.195 -Problem: When a buffer is modified and 'autowriteall' is set, ":quit" - results in an endless loop when there is a conversion error while - writing. (Nikolai Weibull) -Solution: Make autowrite() return FAIL if the buffer is still changed after - writing it. - /* put the cursor on the last char, for 'tw' formatting */ -Files: src/ex_cmds2.c - -Patch 7.0.196 -Problem: When using ":vert ball" the computation of the mouse pointer - position may be off by one column. (Stefan Karlsson) -Solution: Recompute the frame width when moving the vertical separator from - one window to another. -Files: src/window.c - -Patch 7.0.197 (extra) -Problem: Win32: Compiling with EXITFREE doesn't work. -Solution: Adjust a few #ifdefs. (Alexei Alexandrof) -Files: src/misc2.c, src/os_mswin.c - -Patch 7.0.198 (extra) -Problem: Win32: Compiler warnings. No need to generate gvim.exe.mnf. -Solution: Add type casts. Use "*" for processorArchitecture. (George Reilly) -Files: src/Make_mvc.mak, src/eval.c, src/gvim.exe.mnf, src/misc2.c - -Patch 7.0.199 -Problem: When using multi-byte characters the combination of completion and - formatting may result in a wrong cursor position. -Solution: Don't decrement the cursor column, use dec_cursor(). (Yukihiro - Nakadaira) Also check for the column to be zero. -Files: src/edit.c - -Patch 7.0.200 -Problem: Memory leaks when out of memory. -Solution: Free the memory. -Files: src/edit.c, src/diff.c - -Patch 7.0.201 -Problem: Message for ":diffput" about buffer not being in diff mode may be - wrong. -Solution: Check for buffer in diff mode but not modifiable. -Files: src/diff.c - -Patch 7.0.202 -Problem: Problems on Tandem systems while compiling and at runtime. -Solution: Recognize root uid is 65535. Check select() return value for it - not being supported. Avoid wrong function prototypes. Mention - use of -lfloss. (Matthew Woehlke) -Files: src/Makefile, src/ex_cmds.c, src/fileio.c, src/main.c, - src/osdef1.h.in, src/osdef2.h.in, src/os_unix.c, src/pty.c, - src/vim.h - -Patch 7.0.203 -Problem: 0x80 characters in a register are not handled correctly for the - "@" command. -Solution: Escape CSI and 0x80 characters. (Yukihiro Nakadaira) -Files: src/ops.c - -Patch 7.0.204 -Problem: Cscope: Parsing matches for listing isn't done properly. -Solution: Check for line number being found. (Yu Zhao) -Files: src/if_cscope.c - -Patch 7.0.205 (after 7.0.203) -Problem: Can't compile. -Solution: Always include the vim_strsave_escape_csi function. -Files: src/getchar.c - -Patch 7.0.206 (after 7.0.058) -Problem: Some characters of the "gb18030" encoding are not handled - properly. -Solution: Do not use "cp936" as an alias for "gb18030" encoding. Instead - initialize 'encoding' to "cp936". -Files: src/mbyte.c, src/option.c - -Patch 7.0.207 -Problem: After patch 2.0.203 CSI and K_SPECIAL characters are escaped when - recorded and then again when the register is executed. -Solution: Remove escaping before putting the recorded characters in a - register. (Yukihiro Nakadaira) -Files: src/getchar.c, src/ops.c, src/proto/getchar.pro - -Patch 7.0.208 (after 7.0.171 and 7.0.180) -Problem: VMS: changes to path handling cause more trouble than they solve. -Solution: Revert changes. -Files: src/buffer.c, src/memline.c, src/os_unix.c - -Patch 7.0.209 -Problem: When replacing a line through Python the cursor may end up beyond - the end of the line. -Solution: Check the cursor column after replacing the line. -Files: src/if_python.c - -Patch 7.0.210 -Problem: ":cbuffer" and ":lbuffer" always fail when the buffer is modified. - (Gary Johnson) -Solution: Support adding a !. (Yegappan Lakshmanan) -Files: runtime/doc/quickfix.txt, src/ex_cmds.h - -Patch 7.0.211 -Problem: With ":set cindent noai bs=0" using CTRL-U in Insert mode will - delete auto-indent. After ":set ai" it doesn't. -Solution: Also check 'cindent' being set. (Ryan Lortie) -Files: src/edit.c - -Patch 7.0.212 -Problem: The GUI can't be terminated with SIGTERM. (Mark Logan) -Solution: Use the signal protection in the GUI as in the console, allow - signals when waiting for 100 msec or longer. -Files: src/ui.c - -Patch 7.0.213 -Problem: When 'spellfile' has two regions that use the same sound folding - using "z=" will cause memory to be freed twice. (Mark Woodward) -Solution: Clear the hashtable properly so that the items are only freed once. -Files: src/spell.c - -Patch 7.0.214 -Problem: When using <f-args> in a user command it's not possible to have an - argument end in '\ '. -Solution: Change the handling of backslashes. (Yakov Lerner) -Files: runtime/doc/map.txt, src/ex_docmd.c - -Patch 7.0.215 (extra) -Problem: Mac: Scrollbar size isn't set. Context menu has disabled useless - Help entry. Call to MoreMasterPointers() is ignored. -Solution: Call SetControlViewSize() in gui_mch_set_scrollbar_thumb(). Use - kCMHelpItemRemoveHelp for ContextualMenuSelect(). Remove call to - MoreMasterPointers(). (Nicolas Weber) -Files: src/gui_mac.c - -Patch 7.0.216 -Problem: ":tab wincmd ]" does not open a tab page. (Tony Mechelynck) -Solution: Copy the cmdmod.tab value to postponed_split_tab and use it. -Files: src/globals.h, src/ex_docmd.c, src/if_cscope.c, src/window.c - -Patch 7.0.217 -Problem: This hangs when pressing "n": ":%s/\n/,\r/gc". (Ori Avtalion) -Solution: Set "skip_match" to advance to the next line. -Files: src/ex_cmds.c - -Patch 7.0.218 -Problem: "%B" in 'statusline' always shows zero in Insert mode. (DervishD) -Solution: Remove the exception for Insert mode, check the column for being - valid instead. -Files: src/buffer.c - -Patch 7.0.219 -Problem: When using the 'editexisting.vim' script and a file is being - edited in another tab page the window is split. The "+123" - argument is not used. -Solution: Make the tab page with the file the current tab page. Set - v:swapcommand when starting up to the first "+123" or "-c" command - line argument. -Files: runtime/macros/editexisting.vim, src/main.c - -Patch 7.0.220 -Problem: Crash when using winnr('#') in a new tab page. (Andy Wokula) -Solution: Check for not finding the window. -Files: src/eval.c - -Patch 7.0.221 -Problem: finddir() uses 'path' by default, where "." means relative to the - current file. But it works relative to the current directory. - (Tye Zdrojewski) -Solution: Add the current buffer name to find_file_in_path_option() for the - relative file name. -Files: runtime/doc/eval.txt, src/eval.c - -Patch 7.0.222 -Problem: Perl indenting using 'cindent' works almost right. -Solution: Recognize '#' to start a comment. (Alex Manoussakis) Added '#' - flag in 'cinoptions'. -Files: runtime/doc/indent.txt, src/misc1.c - -Patch 7.0.223 -Problem: Unprintable characters in completion text mess up the popup menu. - (Gombault Damien) -Solution: Use strtrans() to make the text printable. -Files: src/charset.c, src/popupmnu.c - -Patch 7.0.224 -Problem: When expanding "##" spaces are escaped twice. (Pavol Juhas) -Solution: Don't escape the spaces that separate arguments. -Files: src/eval.c, src/ex_docmd.c, src/proto/ex_docmd.pro - -Patch 7.0.225 -Problem: When using setline() in an InsertEnter autocommand and doing "A" - the cursor ends up on the last byte in the line. (Yukihiro - Nakadaira) -Solution: Only adjust the column when using setline() for the cursor line. - Move it back to the head byte if necessary. -Files: src/eval.c, src/misc2.c - -Patch 7.0.226 -Problem: Display flickering when updating signs through the netbeans - interface. (Xavier de Gaye) -Solution: Remove the redraw_later(CLEAR) call. -Files: src/netbeans.c - -Patch 7.0.227 -Problem: Crash when closing a window in the GUI. (Charles Campbell) -Solution: Don't call out_flush() from win_free(). -Files: src/window.c - -Patch 7.0.228 -Problem: Cygwin: problem with symlink to DOS style path. -Solution: Invoke cygwin_conv_to_posix_path(). (Luca Masini) -Files: src/os_unix.c - -Patch 7.0.229 -Problem: When 'pastetoggle' starts with Esc then pressing Esc in Insert - mode will not time out. (Jeffery Small) -Solution: Use KL_PART_KEY instead of KL_PART_MAP, so that 'ttimeout' applies - to the 'pastetoggle' key. -Files: src/getchar.c - -Patch 7.0.230 -Problem: After using ":lcd" a script doesn't know how to restore the - current directory. -Solution: Add the haslocaldir() function. (Bob Hiestand) -Files: runtime/doc/usr_41.txt, runtime/doc/eval.txt, src/eval.c - -Patch 7.0.231 -Problem: When recovering from a swap file the page size is likely to be - different from the minimum. The block used for the first page - then has a buffer of the wrong size, causing a crash when it's - reused later. (Zephaniah Hull) -Solution: Reallocate the buffer when the page size changes. Also check that - the page size is at least the minimum value. -Files: src/memline.c - -Patch 7.0.232 (extra) -Problem: Mac: doesn't support GUI tab page labels. -Solution: Add GUI tab page labels. (Nicolas Weber) -Files: src/feature.h, src/gui.c, src/gui.h, src/gui_mac.c, - src/proto/gui_mac.pro - -Patch 7.0.233 (extra) -Problem: Mac: code formatted badly. -Solution: Fix code formatting -Files: src/gui_mac.c - -Patch 7.0.234 -Problem: It's possible to use feedkeys() from a modeline. That is a - security issue, can be used for a trojan horse. -Solution: Disallow using feedkeys() in the sandbox. -Files: src/eval.c - -Patch 7.0.235 -Problem: It is possible to use writefile() in the sandbox. -Solution: Add a few more checks for the sandbox. -Files: src/eval.c - -Patch 7.0.236 -Problem: Linux 2.4 uses sysinfo() with a mem_unit field, which is not - backwards compatible. -Solution: Add an autoconf check for sysinfo.mem_unit. Let mch_total_mem() - return Kbyte to avoid overflow. -Files: src/auto/configure, src/configure.in, src/config.h.in, - src/option.c, src/os_unix.c - -Patch 7.0.237 -Problem: For root it is recommended to not use 'modeline', but in - not-compatible mode the default is on. -Solution: Let 'modeline' default to off for root. -Files: runtime/doc/options.txt, src/option.c - -Patch 7.0.238 -Problem: Crash when ":match" pattern runs into 'maxmempattern'. (Yakov - Lerner) -Solution: Don't free the regexp program of match_hl. -Files: src/screen.c - -Patch 7.0.239 -Problem: When using local directories and tab pages ":mksession" uses a - short file name when it shouldn't. Window-local options from a - modeline may be applied to the wrong window. (Teemu Likonen) -Solution: Add the did_lcd flag, use the full path when it's set. Don't use - window-local options from the modeline when using the current - window for another buffer in ":doautoall". -Files: src/fileio.c, src/ex_docmd.c - -Patch 7.0.240 -Problem: Crash when splitting a window in the GUI. (opposite of 7.0.227) -Solution: Don't call out_flush() from win_alloc(). Also avoid this for - win_delete(). Also block autocommands while the window structure - is invalid. -Files: src/window.c - -Patch 7.0.241 -Problem: ":windo throw 'foo'" loops forever. (Andy Wokula) -Solution: Detect that win_goto() doesn't work. -Files: src/ex_cmds2.c - -Patch 7.0.242 (extra) -Problem: Win32: Using "-register" in a Vim that does not support OLE causes - a crash. -Solution: Don't use EMSG() but mch_errmsg(). Check p_go for being NULL. - (partly by Michael Wookey) -Files: src/gui_w32.c - -Patch 7.0.243 (extra) -Problem: Win32: When GvimExt is built with MSVC 2005 or later, the "Edit - with vim" context menu doesn't appear in the Windows Explorer. -Solution: Embed the linker manifest file into the resources of GvimExt.dll. - (Mathias Michaelis) -Files: src/GvimExt/Makefile - - -Fixes after Vim 7.1a BETA: - -The extra archive had CVS directories included below "farsi" and -"runtime/icons". CVS was missing the farsi icon files. - -Fix compiling with Gnome 2.18, undefine bind_textdomain_codeset. (Daniel -Drake) - -Mac: "make install" didn't copy rgb.txt. - -When editing a compressed file while there are folds caused "ml_get" errors -and some lines could be missing. When decompressing failed option values were -not restored. - - -Patch 7.1a.001 -Problem: Crash when downloading a spell file. (Szabolcs Horvat) -Solution: Avoid that did_set_spelllang() is used recursively when a new - window is opened for the download. - Also avoid wiping out the wrong buffer. -Files: runtime/autoload/spellfile.vim, src/buffer.c, src/ex_cmds.c, - src/spell.c - -Patch 7.1a.002 (extra) -Problem: Compilation error with MingW. -Solution: Check for LPTOOLTIPTEXT to be defined. -Files: src/gui_w32.c - - -Fixes after Vim 7.1b BETA: - -Made the Mzscheme interface build both with old and new versions of Mzscheme, -using an #ifdef. (Sergey Khorev) -Mzscheme interface didn't link, missing function. Changed order of libraries -in the configure script. - -Ruby interface didn't compile on Mac. Changed #ifdef. (Kevin Ballard) - -Patch 7.1b.001 (extra) -Problem: Random text in a source file. No idea how it got there. -Solution: Delete the text. -Files: src/gui_w32.c - -Patch 7.1b.002 -Problem: When 'maxmem' is large there can be an overflow in computations. - (Thomas Wiegner) -Solution: Use the same mechanism as in mch_total_mem(): first reduce the - multiplier as much as possible. -Files: src/memfile.c - -============================================================================== -VERSION 7.2 *version-7.2* - -This section is about improvements made between version 7.1 and 7.2. - -This is mostly a bug-fix release. The main new feature is floating point -support. |Float| - - -Changed *changed-7.2* -------- - -Changed the command line buffer name from "command-line" to "[Command Line]". - -Removed optional ! for ":caddexpr", ":cgetexpr", ":cgetfile", ":laddexpr", -":lgetexpr" and ":lgetfile". They are not needed. (Yegappan Lakshmanan) - -An offset for syntax matches worked on bytes instead of characters. That is -inconsistent and can easily be done wrong. Use character offsets now. -(Yukihiro Nakadaira) - -The FileChangedShellPost event was also given when a file didn't change. -(John Little) - -When the current line is long (doesn't fit) the popup menu can't be seen. -Display it below the screen line instead of below the text line. -(Francois Ingelrest) - -Switched to autoconf version 2.62. - -Moved including fcntl.h to vim.h and removed it from all .c files. - -Introduce macro STRMOVE(d, s), like STRCPY() for overlapping strings. -Use it instead of mch_memmove(p, p + x, STRLEN(p + x) + 1). - -Removed the bulgarian.vim keymap file, two more standard ones replace it. -(Boyko Bantchev) - -Increased the maximum number of tag matches for command line completion from -200 to 300. - -Renamed help file sql.txt to ft_sql.txt and ada.txt to ft_ada.txt. - - -Added *added-7.2* ------ - -New syntax files: - CUDA (Timothy B. Terriberry) - Cdrdao config (Nikolai Weibull) - Coco/R (Ashish Shukla) - Denyhosts config (Nikolai Weibull) - Dtrace script (Nicolas Weber) - Git output, commit, config, rebase, send-email (Tim Pope) - HASTE and HastePreProc (M. Tranchero) - Haml (Tim Pope) - Host conf (Nikolai Weibull) - Linden script (Timo Frenay) - MS messages (Kevin Locke) - PDF (Tim Pope) - ProMeLa (Maurizio Tranchero) - Reva Foth (Ron Aaron) - Sass (Tim Pope) - Symbian meta-makefile, MMP (Ron Aaron) - VOS CM macro (Andrew McGill) - XBL (Doug Kearns) - -New tutor files: - Made UTF-8 versions of all the tutor files. - Greek renamed from ".gr" to ".el" (Greek vs Greece). - Esperanto (Dominique Pelle) - Croatian (Paul B. Mahol) - -New filetype plugins: - Cdrdao config (Nikolai Weibull) - Debian control files (Debian Vim maintainers) - Denyhosts (Nikolai Weibull) - Dos .ini file (Nikolai Weibull) - Dtrace script (Nicolas Weber) - FnameScript (Nikolai Weibull) - Git, Git config, Git commit, Git rebase, Git send-email (Tim Pope) - Haml (Tim Pope) - Host conf (Nikolai Weibull) - Host access (Nikolai Weibull) - Logtalk (Paulo Moura) - MS messages (Kevin Locke) - NSIS script (Nikolai Weibull) - PDF (Tim Pope) - Reva Forth (Ron Aaron) - Sass (Tim Pope) - -New indent files: - DTD (Nikolai Weibull) - Dtrace script (Nicolas Weber) - Erlang (Csaba Hoch) - FrameScript (Nikolai Weibull) - Git config (Tim Pope) - Haml (Tim Pope) - Logtalk (Paulo Moura) - Sass (Tim Pope) - Tiny Fugue (Christian J. Robinson) - -New compiler plugins: - RSpec (Tim Pope) - -New keymap files: - Croatian (Paul B. Mahol) - Russian Dvorak (Serhiy Boiko) - Ukrainian Dvorak (Serhiy Boiko) - Removed plain Bulgarian, "bds" and phonetic are sufficient. - -Other new runtime files: - Esperanto menu and message translations. (Dominique Pelle) - Finnish menu and message translations. (Flammie Pirinen) - Brazilian Portugese message translations. (Eduardo Dobay) - -Added floating point support. |Float| - -Added argument to mode() to return a bit more detail about the current mode. -(Ben Schmidt) - -Added support for BSD console mouse: |sysmouse|. (Paul Mahol) - -Added the "newtab" value for the 'switchbuf' option. (partly by Yegappan -Lakshmanan) - -Improved error messages for the netbeans interface. (Philippe Fremy) - -Added support for using xterm mouse codes for screen. (Micah Cowan) - -Added support for cross compiling: -Adjusted configure.in and added INSTALLcross.txt. (Marc Haisenko) Fixed -mistakes in configure.in after that. -Don't use /usr/local/include and /usr/local/lib in configure. (Philip -Prindeville) -For cross compiling the Cygwin version on Unix, change VIM.TLB to vim.tlb in -src/vim.rc. (Tsuneo Nakagawa) - -Added v:searchforward variable: What direction we're searching in. (Yakov -Lerner) - - -Fixed *fixed-7.2* ------ - -Patch 7.1.001 -Problem: Still can't build with Gnome libraries. -Solution: Fix typo in bind_textdomain_codeset. (Mike Kelly) -Files: src/gui_gtk.c, src/gui_gtk_x11.c - -Patch 7.1.002 -Problem: Oracle Pro*C/C++ files are not detected. -Solution: Add the missing star. (Micah J. Cowan) -Files: runtime/filetype.vim - -Patch 7.1.003 (extra) -Problem: The "Tear off this menu" message appears in the message history - when using a menu. (Yongwei Wu) -Solution: Disable message history when displaying the menu tip. -Files: src/gui_w32.c - -Patch 7.1.004 -Problem: Crash when doing ":next directory". (Raphael Finkel) -Solution: Do not use "buf", it may be invalid after autocommands. -Files: src/ex_cmds.c - -Patch 7.1.005 -Problem: "cit" used on <foo></foo> deletes <foo>. Should not delete - anything and start insertion, like "ci'" does on "". (Michal - Bozon) -Solution: Handle an empty object specifically. Made it work consistent for - various text objects. -Files: src/search.c - -Patch 7.1.006 -Problem: Resetting 'modified' in a StdinReadPost autocommand doesn't work. -Solution: Set 'modified' before the autocommands instead of after it. -Files: src/buffer.c - -Patch 7.1.007 (extra) -Problem: Mac: Context menu doesn't work on Intel Macs. - Scrollbars are not dimmed when Vim is not the active application. -Solution: Remove the test whether context menus are supported. They are - always there in OS/X. Handle the dimming. (Nicolas Weber) -Files: src/gui_mac.c, src/gui.h - -Patch 7.1.008 -Problem: getfsize() returns a negative number for very big files. -Solution: Check for overflow and return -2. -Files: runtime/doc/eval.txt, src/eval.c - -Patch 7.1.009 -Problem: In diff mode, displaying the difference between a tab and spaces - is not highlighted correctly. -Solution: Only change highlighting at the end of displaying a tab. -Files: src/screen.c - -Patch 7.1.010 -Problem: The Gnome session file doesn't restore tab pages. -Solution: Add SSOP_TABPAGES to the session flags. (Matias D'Ambrosio) -Files: src/gui_gtk_x11.c - -Patch 7.1.011 -Problem: Possible buffer overflow when $VIMRUNTIME is very long. (Victor - Stinner) -Solution: Use vim_snprintf(). -Files: src/main.c - -Patch 7.1.012 -Problem: ":let &shiftwidth = 'asdf'" doesn't produce an error message. -Solution: Check for a string argument. (Chris Lubinski) -Files: src/option.c - -Patch 7.1.013 -Problem: ":syn include" only loads the first file, while it is documented - as doing the equivalent of ":runtime!". -Solution: Change the argument to source_runtime(). (James Vega) -Files: src/syntax.c - -Patch 7.1.014 -Problem: Crash when doing C indenting. (Chris Monson) -Solution: Obtain the current line again after invoking cin_islabel(). -Files: src/edit.c - -Patch 7.1.015 -Problem: MzScheme interface: current-library-collection-paths produces no - list. Interface doesn't build on a Mac. -Solution: Use a list instead of a pair. (Bernhard Fisseni) Use "-framework" - argument for MZSCHEME_LIBS in configure. -Files: src/configure.in, src/if_mzsch.c, src/auto/configure - -Patch 7.1.016 (after patch 7.1.012) -Problem: Error message about setting 'diff' to a string. -Solution: Don't pass an empty string to set_option_value() when setting - 'diff'. -Files: src/quickfix.c, src/popupmnu.c - -Patch 7.1.017 -Problem: ":confirm w" does give a prompt when 'readonly' is set, but not - when the file permissions are read-only. (Michael Schaap) -Solution: Provide a dialog in both situations. (Chris Lubinski) -Files: src/ex_cmds.c, src/fileio.c, src/proto/fileio.pro - -Patch 7.1.018 -Problem: When 'virtualedit' is set a "p" of a block just past the end of - the line inserts before the cursor. (Engelke) -Solution: Check for the cursor being just after the line (Chris Lubinski) -Files: src/ops.c - -Patch 7.1.019 -Problem: ":py" asks for an argument, ":py asd" then gives the error that - ":py" isn't implemented. Should already happen for ":py". -Solution: Compare with ex_script_ni. (Chris Lubinski) -Files: src/ex_docmd.c - -Patch 7.1.020 -Problem: Reading from uninitialized memory when using a dialog. (Dominique - Pelle) -Solution: In msg_show_console_dialog() append a NUL after every appended - character. -Files: src/message.c - -Patch 7.1.021 (after 7.1.015) -Problem: Mzscheme interface doesn't compile on Win32. -Solution: Fix the problem that 7.1.015 fixed in a better way. (Sergey Khorev) -Files: src/if_mzsch.c - -Patch 7.1.022 -Problem: When setting 'keymap' twice the b:keymap_name variable isn't set. - (Milan Berta) -Solution: Don't unlet b:keymap_name for ":loadkeymap". (Martin Toft) -Files: src/digraph.c - -Patch 7.1.023 -Problem: "dw" in a line with one character deletes the line. Vi and nvi - don't do this. (Kjell Arne Rekaa) -Solution: Check for one-character words especially. -Files: src/search.c - -Patch 7.1.024 -Problem: Using a pointer that has become invalid. (Chris Monson) -Solution: Obtain the line pointer again after we looked at another line. -Files: src/search.c - -Patch 7.1.025 -Problem: search() and searchpos() don't use match under cursor at start of - line when using 'bc' flags. (Viktor Kojouharov) -Solution: Don't go to the previous line when the 'c' flag is present. - Also fix that "j" doesn't move the cursor to the right column. -Files: src/eval.c, src/search.c - -Patch 7.1.026 -Problem: "[p" doesn't work in Visual mode. (David Brown) -Solution: Use checkclearop() instead of checkclearopq(). -Files: src/normal.c - -Patch 7.1.027 -Problem: On Sun systems opening /dev/fd/N doesn't work, and they are used - by process substitutions. -Solution: Allow opening specific character special files for Sun systems. - (Gary Johnson) -Files: src/fileio.c, src/os_unix.h - -Patch 7.1.028 -Problem: Can't use last search pattern for ":sort". (Brian McKee) -Solution: When the pattern is emtpy use the last search pattern. (Martin - Toft) -Files: runtime/doc/change.txt, src/ex_cmds.c - -Patch 7.1.029 (after 7.1.019) -Problem: Can't compile when all interfaces are used. (Taylor Venable) -Solution: Only check for ex_script_ni when it's defined. -Files: src/ex_docmd.c - -Patch 7.1.030 -Problem: The "vimtutor" shell script checks for "vim6" but not for "vim7". - (Christian Robinson) -Solution: Check for more versions, but prefer using "vim". -Files: src/vimtutor - -Patch 7.1.031 -Problem: virtcol([123, '$']) doesn't work. (Michael Schaap) -Solution: When '$' is used for the column number get the last column. -Files: runtime/doc/eval.txt, src/eval.c - -Patch 7.1.032 -Problem: Potential crash when editing a command line. (Chris Monson) -Solution: Check the position to avoid access before the start of an array. -Files: src/ex_getln.c - -Patch 7.1.033 -Problem: A buffer is marked modified when it was first deleted and then - added again using a ":next" command. (John Mullin) -Solution: When checking if a buffer is modified use the BF_NEVERLOADED flag. -Files: src/option.c - -Patch 7.1.034 -Problem: Win64: A few compiler warnings. Problems with optimizer. -Solution: Use int instead of size_t. Disable the optimizer in one function. - (George V. Reilly) -Files: src/eval.c, src/spell.c - -Patch 7.1.035 -Problem: After ":s/./&/#" all listed lines have a line number. (Yakov - Lerner) -Solution: Reset the line number flag when not using the "&" flag. -Files: src/ex_cmds.c - -Patch 7.1.036 -Problem: Completing ":echohl" argument should include "None". (Ori - Avtalion) ":match" should have "none" too. -Solution: Add flags to use expand_highlight(). Also fix that when disabling - FEAT_CMDL_COMPL compilation fails. (Chris Lubinski) -Files: src/eval.c, src/ex_docmd.c, src/ex_getln.c, src/proto/syntax.pro - src/syntax.c - -Patch 7.1.037 -Problem: strcpy() used for overlapping strings. (Chris Monson) -Solution: Use mch_memmove() instead. -Files: src/option.c - -Patch 7.1.038 -Problem: When 'expandtab' is set then a Tab copied for 'copyindent' is - expanded to spaces, even when 'preserveindent' is set. (Alexei - Alexandrov) -Solution: Remove the check for 'expandtab'. Also fix that ">>" doesn't obey - 'preserveindent'. (Chris Lubinski) -Files: src/misc1.c - -Patch 7.1.039 -Problem: A tag in a help file that starts with "help-tags" and contains a - percent sign may make Vim crash. (Ulf Harnhammar) -Solution: Use puts() instead of fprintf(). -Files: src/ex_cmds.c - -Patch 7.1.040 -Problem: ":match" only supports three matches. -Solution: Add functions clearmatches(), getmatches(), matchadd(), - matchdelete() and setmatches(). Changed the data structures for - this. A small bug in syntax.c is fixed, so newly created - highlight groups can have their name resolved correctly from their - ID. (Martin Toft) -Files: runtime/doc/eval.txt, runtime/doc/pattern.txt, - runtime/doc/usr_41.txt, src/eval.c, src/ex_docmd.c, - src/proto/window.pro, src/screen.c, src/structs.h, src/syntax.c, - src/testdir/Makefile, src/testdir/test63.in, - src/testdir/test63.ok, src/window.c - -Patch 7.1.041 (extra, after 7.1.040) -Problem: Some changes for patch 7.1.040 are in extra files. -Solution: Update the extra files. -Files: src/testdir/Make_amiga.mak, src/testdir/Make_dos.mak, - src/testdir/Make_os2.mak, src/testdir/Make_vms.mms - -Patch 7.1.042 (after 7.1.040) -Problem: Internal error when using matchadd(). (David Larson) -Solution: Check the third argument to be present before using the fourth - argument. (Martin Toft) -Files: src/eval.c - -Patch 7.1.043 -Problem: In Ex mode using CTRL-D twice may cause a crash. Cursor isn't - positioned properly after CTRL-D. -Solution: Set prev_char properly. Position the cursor correctly. (Antony - Scriven) -Files: src/ex_getln.c - -Patch 7.1.044 -Problem: In Insert mode 0 CTRL-T deletes all indent, it should add indent. - (Gautam Iyer) -Solution: Check for CTRL-D typed. -Files: src/edit.c - -Patch 7.1.045 -Problem: Unnecessary screen redrawing. (Jjgod Jiang) -Solution: Reset "must_redraw" after clearing the screen. -Files: src/screen.c - -Patch 7.1.046 -Problem: ":s" command removes combining characters. (Ron Aaron) -Solution: Copy composing characters individually. (Chris Lubinski) -Files: src/regexp.c - -Patch 7.1.047 -Problem: vim_regcomp() called with invalid argument. (Xiaozhou Liu) -Solution: Change TRUE to RE_MAGIC + RE_STRING. -Files: src/ex_eval.c - -Patch 7.1.048 -Problem: The matchparen plugin doesn't update the match when scrolling with - the mouse wheel. (Ilya Bobir) -Solution: Set the match highlighting for text that can be scrolled into the - viewable area without moving the cursor. (Chris Lubinski) -Files: runtime/plugin/matchparen.vim - -Patch 7.1.049 -Problem: Cannot compile GTK2 version with Hangul input feature. -Solution: Don't define FEAT_XFONTSET when using GTK2. -Files: src/feature.h - -Patch 7.1.050 -Problem: Possible crash when using C++ indenting. (Chris Monson) -Solution: Keep the line pointer to the line to compare with. Avoid going - past the end of line. -Files: src/misc1.c - -Patch 7.1.051 -Problem: Accessing uninitialized memory when finding spell suggestions. -Solution: Don't try swapping characters at the end of a word. -Files: src/spell.c - -Patch 7.1.052 -Problem: When creating a new match not all fields are initialized, which - may lead to unpredictable results. -Solution: Initialise rmm_ic and rmm_maxcol. -Files: src/window.c - -Patch 7.1.053 -Problem: Accessing uninitialized memory when giving a message. -Solution: Check going the length before checking for a NUL byte. -Files: src/message.c - -Patch 7.1.054 -Problem: Accessing uninitialized memory when displaying the fold column. -Solution: Add a NUL to the extra array. (Dominique Pelle). Also do this in - a couple of other situations. -Files: src/screen.c - -Patch 7.1.055 -Problem: Using strcpy() with arguments that overlap. -Solution: Use mch_memmove() instead. -Files: src/buffer.c, src/charset.c, src/eval.c, src/ex_getln.c, - src/misc1.c, src/regexp.c, src/termlib.c - -Patch 7.1.056 -Problem: More prompt does not behave correctly after scrolling back. - (Randall W. Morris) -Solution: Avoid lines_left becomes negative. (Chris Lubinski) Don't check - mp_last when deciding to show the more prompt. (Martin Toft) -Files: src/message.c - -Patch 7.1.057 -Problem: Problem with CursorHoldI when using "r" in Visual mode (Max - Dyckhoff) -Solution: Ignore CursorHold(I) when getting a second character for a Normal - mode command. Also abort the "r" command in Visual when a special - key is typed. -Files: src/normal.c - -Patch 7.1.058 -Problem: When 'rightleft' is set the completion menu is positioned wrong. - (Baha-Eddine MOKADEM) -Solution: Fix the completion menu. (Martin Toft) -Files: src/popupmnu.c, src/proto/search.pro, src/search.c - -Patch 7.1.059 -Problem: When in Ex mode and doing "g/^/vi" and then pressing CTRL-C Vim - hangs and beeps. (Antony Scriven) -Solution: Clear "got_int" in the main loop to avoid the hang. When typing - CTRL-C twice in a row abort the ":g" command. This is Vi - compatible. -Files: src/main.c - -Patch 7.1.060 -Problem: Splitting quickfix window messes up window layout. (Marius - Gedminas) -Solution: Compute the window size in a smarter way. (Martin Toft) -Files: src/window.c - -Patch 7.1.061 -Problem: Win32: When 'encoding' is "latin1" 'ignorecase' doesn't work for - characters with umlaut. (Joachim Hofmann) -Solution: Do not use islower()/isupper()/tolower()/toupper() but our own - functions. (Chris Lubinski) -Files: src/mbyte.c, src/regexp.c, src/vim.h - -Patch 7.1.062 (after 7.1.038) -Problem: Indents of C comments can be wrong. (John Mullin) -Solution: Adjust ind_len. (Chris Lubinski) -Files: src/misc1.c - -Patch 7.1.063 (after 7.1.040) -Problem: Warning for uninitialized variable. -Solution: Initialise it to NULL. -Files: src/ex_docmd.c - -Patch 7.1.064 -Problem: On Interix some files appear not to exist. -Solution: Remove the top bit from st_mode. (Ligesh) -Files: src/os_unix.c - -Patch 7.1.065 (extra) -Problem: Win32: Compilation problem for newer version of w32api. -Solution: Only define __IID_DEFINED__ when needed. (Chris Sutcliffe) -Files: src/Make_ming.mak, src/iid_ole.c - -Patch 7.1.066 -Problem: When 'bomb' is set or reset the file should be considered - modified. (Tony Mechelynck) -Solution: Handle like 'endofline'. (Martin Toft) -Files: src/buffer.c, src/fileio.c, src/option.c, src/structs.h - -Patch 7.1.067 -Problem: 'thesaurus' doesn't work when 'infercase' is set. (Mohsin) -Solution: Don't copy the characters being completed but check the case and - apply it to the suggested word. Also fix that the first word in - the thesaurus line is not used. (Martin Toft) -Files: src/edit.c - -Patch 7.1.068 -Problem: When 'equalalways' is set and splitting a window, it's possible - that another small window gets bigger. -Solution: Only equalize window sizes when after a split the windows are - smaller than another window. (Martin Toft) -Files: runtime/doc/options.txt, runtime/doc/windows.txt, src/window.c - -Patch 7.1.069 -Problem: GTK GUI: When using confirm() without a default button there still - is a default choice. -Solution: Ignore Enter and Space when there is no default button. (Chris - Lubinski) -Files: src/gui_gtk.c - -Patch 7.1.070 (extra) -Problem: Win32 GUI: When using confirm() without a default button there - still is a default choice. -Solution: Set focus on something else than a button. (Chris Lubinski) -Files: src/gui_w32.c - -Patch 7.1.071 (after 7.1.040) -Problem: Regexp patterns are not tested. -Solution: Add a basic test, to be expanded later. - Also add (commented-out) support for valgrind. -Files: src/testdir/Makefile, src/testdir/test64.in, src/testdir/test64.ok - -Patch 7.1.072 (extra, after 7.1.041 and 7.1.071) -Problem: Some changes for patch 7.1.071 are in extra files. -Solution: Update the extra files. Also fix a few warnings from the DOS test - makefile. -Files: src/testdir/Make_amiga.mak, src/testdir/Make_dos.mak, - src/testdir/Make_os2.mak, src/testdir/Make_vms.mms - -Patch 7.1.073 (after 7.1.062) -Problem: Wrong cursor position and crash when 'preserveindent' is set. - (Charles Campbell) -Solution: Handle the situation that we start without indent. (Chris - Lubinski) -Files: src/misc1.c - -Patch 7.1.074 -Problem: Crash when calling string() on a recursively nested List. -Solution: Check result value for being NULL. (Yukihiro Nakadaira) -Files: src/eval.c - -Patch 7.1.075 -Problem: ":let v:statusmsg" reads memory already freed. -Solution: Don't set v:statusmsg when listing it. -Files: src/eval.c - -Patch 7.1.076 -Problem: Another strcpy() with overlapping arguments. -Solution: Use mch_memmove(). (Dominique Pelle) And another one. -Files: src/ex_docmd.c, src/normal.c - -Patch 7.1.077 -Problem: Using "can_spell" without initializing it. (Dominique Pelle) -Solution: Set a default for get_syntax_attr(). -Files: src/syntax.c - -Patch 7.1.078 -Problem: Dropping a file name on gvim that contains a CSI byte doesn't work - when editing the command line. -Solution: Escape the CSI byte when inserting in the input buffer. (Yukihiro - Nakadaira) -Files: src/gui.c, src/ui.c - -Patch 7.1.079 -Problem: When the locale is "C" and 'encoding' is "latin1" then the "@" - character in 'isfname', 'isprint', etc. doesn't pick up accented - characters. -Solution: Instead of isalpha() use MB_ISLOWER() and MB_ISUPPER(). -Files: src/charset.c, src/macros.h - -Patch 7.1.080 (extra) -Problem: Compiler warnings for using "const char *" for "char *". -Solution: Add type casts. (Chris Sutcliffe) -Files: src/GvimExt/gvimext.cpp - -Patch 7.1.081 -Problem: Command line completion for a shell command: "cat </tmp/file<Tab>" - doesn't work. -Solution: Start the file name at any character that can't be in a file name. - (Martin Toft) -Files: src/ex_docmd.c - -Patch 7.1.082 -Problem: After a ":split" the matchparen highlighting isn't there. -Solution: Install a WinEnter autocommand. Also fixes that after - ":NoMatchParen" only the current window is updated. (Martin Toft) -Files: runtime/doc/pi_paren.txt, runtime/plugin/matchparen.vim - -Patch 7.1.083 (after 7.1.081) -Problem: Command line completion doesn't work with wildcards. -Solution: Add vim_isfilec_or_wc() and use it. (Martin Toft) -Files: src/charset.c, src/proto/charset.pro, src/ex_docmd.c - -Patch 7.1.084 -Problem: Using the "-nb" argument twice causes netbeans not to get - fileOpened events. -Solution: Change "&" to "&&". (Xavier de Gaye) -Files: src/ex_cmds.c - -Patch 7.1.085 -Problem: ":e fold.c" then ":sp fold.c" results in folds of original window - to disappear. (Akita Noek) -Solution: Invoke foldUpdateAll() for all windows of the changed buffer. - (Martin Toft) -Files: src/ex_cmds.c - -Patch 7.1.086 -Problem: Crash when using specific Python syntax highlighting. (Quirk) -Solution: Check for a negative index, coming from a keyword match at the - start of a line from a saved state. -Files: src/syntax.c - -Patch 7.1.087 -Problem: Reading past ":cscope find" command. Writing past end of a buffer. -Solution: Check length of the argument before using the pattern. Use - vim_strncpy(). (Dominique Pelle) -Files: if_cscope.c - -Patch 7.1.088 (extra) -Problem: The coordinates used by ":winpos" differ from what getwinposx() - and getwinposy() return. -Solution: Use MoveWindowStructure() instead of MoveWindow(). (Michael Henry) -Files: src/gui_mac.c - -Patch 7.1.089 -Problem: ":let loaded_getscriptPlugin" doesn't clear to eol, result is - "#1in". -Solution: Clear to the end of the screen after displaying the first variable - value. -Files: src/eval.c - -Patch 7.1.090 -Problem: Compiler warning on Mac OS X 10.5. -Solution: Don't redeclare sigaltstack(). (Hisashi T Fujinaka) -Files: src/os_unix.c - -Patch 7.1.091 (extra) -Problem: Win32: Can't embed Vim inside another application. -Solution: Add the --windowid argument. (Nageshwar) -Files: runtime/doc/gui_w32.txt, runtime/doc/starting.txt, - runtime/doc/vi_diff.txt, src/globals.h, src/gui_w32.c, src/main.c - -Patch 7.1.092 (extra, after 7.1.088) -Problem: Wrong arguments for MoveWindowStructure(). -Solution: Remove "TRUE". (Michael Henry) -Files: src/gui_mac.c - -Patch 7.1.093 -Problem: Reading past end of a screen line when determining cell width. - (Dominique Pelle) -Solution: Add an argument to mb_off2cells() for the maximum offset. -Files: src/globals.h, src/gui.c, src/mbyte.c, src/proto/mbyte.pro, - src/screen.c - -Patch 7.1.094 -Problem: When checking if syntax highlighting is present, looking in the - current buffer instead of the specified one. -Solution: Use "buf" instead of "curbuf". -Files: src/syntax.c - -Patch 7.1.095 -Problem: The FocusLost and FocusGained autocommands are triggered - asynchronously in the GUI. This may cause arbitrary problems. -Solution: Put the focus event in the input buffer and handle it when ready - for it. -Files: src/eval.c, src/getchar.c, src/gui.c, src/gui_gtk_x11.c, - src/keymap.h - -Patch 7.1.096 -Problem: Reading past end of a string when resizing Vim. (Dominique Pelle) -Solution: Check the string pointer before getting the char it points to. -Files: src/message.c - -Patch 7.1.097 -Problem: ":setlocal stl=%!1+1" does not work. -Solution: Adjust check for pointer. (Politz) -Files: src/option.c - -Patch 7.1.098 -Problem: ":call s:var()" doesn't work if "s:var" is a Funcref. (Andy Wokula) -Solution: Before converting "s:" into a script ID, check if it is a Funcref. -Files: src/eval.c - -Patch 7.1.099 -Problem: When the 'keymap' and 'paste' options have a non-default value, - ":mkexrc" and ":mksession" do not correctly set the options. -Solution: Set the options with side effects before other options. -Files: src/option.c - -Patch 7.1.100 -Problem: Win32: Executing cscope doesn't always work properly. -Solution: Use another way to invoke cscope. (Mike Williams) -Files: src/if_cscope.c, src/if_cscope.h, src/main.c, - src/proto/if_cscope.pro - -Patch 7.1.101 -Problem: Ruby: The Buffer.line= method does not work. -Solution: Add the "self" argument to set_current_line(). (Jonathan Hankins) -Files: src/if_ruby.c - -Patch 7.1.102 -Problem: Perl interface doesn't compile with new version of Perl. -Solution: Add two variables to the dynamic library loading. (Suresh - Govindachar) -Files: src/if_perl.xs - -Patch 7.1.103 -Problem: Using "dw" with the cursor past the end of the last line (using - CTRL-\ CTRL-O from Insert mode) deletes a character. (Tim Chase) -Solution: Don't move the cursor back when the movement failed. -Files: src/normal.c - -Patch 7.1.104 (after 7.1.095) -Problem: When 'lazyredraw' is set a focus event causes redraw to be - postponed until a key is pressed. -Solution: Instead of not returning from vgetc() when a focus event is - encountered return K_IGNORE. Add plain_vgetc() for when the - caller doesn't want to get K_IGNORE. -Files: src/digraph.c, src/edit.c, src/ex_cmds.c, src/ex_getln.c, - src/getchar.c, src/normal.c, src/proto/getchar.pro, src/window.c - -Patch 7.1.105 -Problem: Internal error when using "0 ? {'a': 1} : {}". (A.Politz) -Solution: When parsing a dictionary value without using the value, don't try - obtaining the key name. -Files: src/eval.c - -Patch 7.1.106 -Problem: ":messages" doesn't quit listing on ":". -Solution: Break the loop when "got_int" is set. -Files: src/message.c - -Patch 7.1.107 -Problem: When doing a block selection and using "s" to change the text, - while triggering auto-indenting, causes the wrong text to be - repeated in other lines. (Adri Verhoef) -Solution: Compute the change of indent and compensate for that. -Files: src/ops.c - -Patch 7.1.108 (after 7.1.100) -Problem: Win32: Compilation problems in Cscope code. (Jeff Lanzarotta) -Solution: Use (long) instead of (intptr_t) when it's not defined. -Files: src/if_cscope.c - -Patch 7.1.109 -Problem: GTK: when there are many tab pages, clicking on the arrow left of - the labels moves to the next tab page on the right. (Simeon Bird) -Solution: Check the X coordinate of the click and pass -1 as value for the - left arrow. -Files: src/gui_gtk_x11.c, src/term.c - -Patch 7.1.110 (after 7.1.102) -Problem: Win32: Still compilation problems with Perl. -Solution: Change the #ifdefs. (Suresh Govindachar) -Files: src/if_perl.xs - -Patch 7.1.111 -Problem: When using ":vimgrep" with the "j" flag folds from another buffer - may be displayed. (A.Politz) -Solution: When not jumping to another buffer update the folds. -Files: src/quickfix.c - -Patch 7.1.112 -Problem: Using input() with a wrong argument may crash Vim. (A.Politz) -Solution: Init the input() return value to NULL. -Files: src/eval.c - -Patch 7.1.113 -Problem: Using map() to go over an empty list causes memory to be freed - twice. (A.Politz) -Solution: Don't clear the typeval in restore_vimvar(). -Files: src/eval.c - -Patch 7.1.114 -Problem: Memory leak in getmatches(). -Solution: Don't increment the refcount twice. -Files: src/eval.c - -Patch 7.1.115 (after 7.1.105) -Problem: Compiler warning for uninitialized variable. (Tony Mechelynck) -Solution: Init variable to NULL. -Files: src/eval.c - -Patch 7.1.116 -Problem: Cannot display Unicode characters above 0x10000. -Solution: Remove the replacement with a question mark when UNICODE16 is not - defined. (partly by Nicolas Weber) -Files: src/screen.c - -Patch 7.1.117 -Problem: Can't check wether Vim was compiled with Gnome. (Tony Mechelynck) -Solution: Add gui_gnome to the has() list. -Files: src/eval.c - -Patch 7.1.118 (after 7.1.107) -Problem: Compiler warning for Visual C compiler. -Solution: Add typecast. (Mike Williams) -Files: src/ops.c - -Patch 7.1.119 -Problem: Crash when 'cmdheight' set to very large value. (A.Politz) -Solution: Limit 'cmdheight' to 'lines' minus one. Store right value of - 'cmdheight' when running out of room. -Files: src/option.c, src/window.c - -Patch 7.1.120 -Problem: Can't properly check memory leaks while running tests. -Solution: Add an argument to garbagecollect(). Delete functions and - variables in the test scripts. -Files: runtime/doc/eval.txt src/eval.c, src/globals.h, src/main.c, - src/testdir/Makefile, src/testdir/test14.in, - src/testdir/test26.in, src/testdir/test34.in, - src/testdir/test45.in, src/testdir/test47.in, - src/testdir/test49.in, src/testdir/test55.in, - src/testdir/test56.in, src/testdir/test58.in, - src/testdir/test59.in, src/testdir/test60.in, - src/testdir/test60.vim, src/testdir/test62.in, - src/testdir/test63.in, src/testdir/test64.in, - -Patch 7.1.121 -Problem: Using ":cd %:h" when editing a file in the current directory - results in an error message for using an empty string. -Solution: When "%:h" results in an empty string use ".". -Files: src/eval.c - -Patch 7.1.122 -Problem: Mac: building Vim.app fails. Using wrong architecture. -Solution: Use line continuation for the gui_bundle dependency. Detect the - system architecture with "uname -a". -Files: src/main.aap - -Patch 7.1.123 -Problem: Win32: ":edit foo ~ foo" expands "~". -Solution: Change the call to expand_env(). -Files: src/ex_docmd.c, src/misc1.c, src/proto/misc1.pro, src/option.c - -Patch 7.1.124 (extra) -Problem: Mac: When dropping a file on Vim.app that is already in the buffer - list (from .viminfo) results in editing an empty, unnamed buffer. - (Axel Kielhorn) Also: warning for unused variable. -Solution: Move to the buffer of the first argument. Delete unused variable. -Files: src/gui_mac.c - -Patch 7.1.125 -Problem: The TermResponse autocommand event is not always triggered. (Aron - Griffix) -Solution: When unblocking autocommands check if v:termresponse changed and - trigger the event then. -Files: src/buffer.c, src/diff.c, src/ex_getln.c, src/fileio.c, - src/globals.h, src/misc2.c, src/proto/fileio.pro, src/window.c - -Patch 7.1.126 (extra) -Problem: ":vimgrep */*" fails when a BufRead autocommand changes directory. - (Bernhard Kuhn) -Solution: Change back to the original directory after loading a file. - Also: use shorten_fname1() to avoid duplicating code. -Files: src/buffer.c, src/ex_docmd.c, src/fileio.c, src/gui_gtk.c, - src/gui_w48.c, src/proto/ex_docmd.pro, src/proto/fileio.pro, - src/quickfix.c - -Patch 7.1.127 -Problem: Memory leak when doing cmdline completion. (Dominique Pelle) -Solution: Free "orig" argument of ExpandOne() when it's not used. -Files: src/ex_getln.c - -Patch 7.1.128 (extra) -Problem: Build problems with new version of Cygwin. -Solution: Remove -D__IID_DEFINED__, like with MingW. (Guopeng Wen) -Files: src/Make_cyg.mak - -Patch 7.1.129 (extra) -Problem: Win32: Can't get the user name when it is longer than 15 - characters. -Solution: Use UNLEN instead of MAX_COMPUTERNAME_LENGTH. (Alexei Alexandrov) -Files: src/os_win32.c - -Patch 7.1.130 -Problem: Crash with specific order of undo and redo. (A.Politz) -Solution: Clear and adjust pointers properly. Add u_check() for debugging. -Files: src/undo.c, src/structs.h - -Patch 7.1.131 -Problem: ":mksession" always adds ":setlocal autoread". (Christian J. - Robinson) -Solution: Skip boolean global/local option using global value. -Files: src/option.c - -Patch 7.1.132 -Problem: getpos("'>") may return a negative column number for a Linewise - selection. (A.Politz) -Solution: Don't add one to MAXCOL. -Files: src/eval.c - -Patch 7.1.133 (after 7.1.126) -Problem: shorten_fname1() linked when it's not needed. -Solution: Add #ifdef. -Files: src/fileio.c - -Patch 7.1.134 (extra) -Problem: Win32: Can't build with VC8 -Solution: Detect the MSVC version instead of using NMAKE_VER. - (Mike Williams) -Files: src/Make_mvc.mak - -Patch 7.1.135 -Problem: Win32: When editing a file c:\tmp\foo and c:\tmp\\foo we have two - buffers for the same file. (Suresh Govindachar) -Solution: Invoke FullName_save() when a path contains "//" or "\\". -Files: src/buffer.c - -Patch 7.1.136 -Problem: Memory leak when using Ruby syntax highlighting. (Dominique Pelle) -Solution: Free the contained-in list. -Files: src/syntax.c - -Patch 7.1.137 -Problem: Build failure when using EXITFREE. (Dominique Pelle) -Solution: Add an #ifdef around using clip_exclude_prog. -Files: src/misc2.c - -Patch 7.1.138 -Problem: The Perl Msg() function doesn't stop when "q" is typed at the more - prompt. (Hari Krishna Dara) -Solution: Check got_int. -Files: src/if_perl.xs - -Patch 7.1.139 -Problem: When using marker folding and ending Insert mode with CTRL-C the - current fold is truncated. (Fred Kater) -Solution: Ignore got_int while updating folds. -Files: src/fold.c - -Patch 7.1.140 -Problem: v:count is set only after typing a non-digit, that makes it - difficult to make a nice mapping. -Solution: Set v:count while still typing the count. -Files: src/normal.c - -Patch 7.1.141 -Problem: GTK: -geom argument doesn't support a negative offset. -Solution: Compute position from the right/lower corner. -Files: src/gui_gtk_x11.c - -Patch 7.1.142 -Problem: ":redir @A>" doesn't work. -Solution: Ignore the extra ">" also when appending. (James Vega) -Files: src/ex_docmd.c - -Patch 7.1.143 -Problem: Uninitialized memory read when diffing three files. (Dominique - Pelle) -Solution: Remove "+ !notset" so that we don't use fields that were not - computed. -Files: src/diff.c - -Patch 7.1.144 -Problem: After ":diffup" cursor can be in the wrong position. -Solution: Force recomputing the cursor position. -Files: src/diff.c - -Patch 7.1.145 -Problem: Insert mode completion: When using the popup menu, after - completing a word and typing a non-word character Vim is still - completing the same word, following CTRL-N doesn't work. - Insert mode Completion: When using CTRL-X O and there is only - "struct." before the cursor, typing one char to reduce the - matches, then BS completion stops. -Solution: When typing a character that is not part of the item being - completed, stop complete mode. For whole line completion also - accept a space. For file name completion stop at a path - separator. - For omni completion stay in completion mode even if completing - with empty string. -Files: src/edit.c - -Patch 7.1.146 (extra) -Problem: VMS: Files with a very rare record organization (VFC) cannot be - properly written by Vim. - On older VAX systems mms runs into a syntax error. -Solution: Check for this special situation. Do not wrap a comment, make it - one long line. (Zoltan Arpadffy) -Files: src/fileio.c, src/Make_vms.mms - -Patch 7.1.147 (after 7.1.127) -Problem: Freeing memory already freed when completing user name. (Meino - Cramer) -Solution: Use a flag to remember if "orig" needs to be freed. -Files: src/ex_getln.c - -Patch 7.1.148 -Problem: Some types are not found by configure. -Solution: Test for the sys/types.h header file. (Sean Boudreau) -Files: src/configure.in, src/auto/configure - -Patch 7.1.149 -Problem: GTK GUI: When the completion popup menu is used scrolling another - window by the scrollbar is OK, but using the scroll wheel it - behaves line <Enter>. -Solution: Ignore K_MOUSEDOWN and K_MOUSEUP. Fix redrawing the popup menu. -Files: src/edit.c, src/gui.c - -Patch 7.1.150 -Problem: When 'clipboard' has "unnamed" using "p" in Visual mode doesn't - work correctly. (Jianrong Yu) -Solution: When 'clipboard' has "unnamed" also obtain the selection when - getting the default register. -Files: src/ops.c - -Patch 7.1.151 -Problem: Using whole line completion with 'ignorecase' and 'infercase' set - and the line is empty get an lalloc(0) error. -Solution: Don't try changing case for an empty match. (Matthew Wozniski) -Files: src/edit.c - -Patch 7.1.152 -Problem: Display problem when 'hls' and 'cursorcolumn' are set and - searching for "$". (John Mullin) Also when scrolling - horizontally when 'wrap' is off. -Solution: Keep track of the column where highlighting was set. Check the - column offset when skipping characters. -Files: src/screen.c - -Patch 7.1.153 -Problem: Compiler warnings on SGI. Undefined XpmAllocColor (Charles - Campbell) -Solution: Add type casts. Init st_dev and st_ino separately. Don't use - type casts for vim_snprintf() when HAVE_STDARG_H is defined. - Define XpmAllocColor when needed. -Files: src/eval.c, src/ex_cmds.c, src/fileio.c, src/misc2.c, - src/gui_xmebw.c - -Patch 7.1.154 -Problem: Compiler warning for signed/unsigned compare. -Solution: Add type cast. -Files: src/screen.c - -Patch 7.1.155 -Problem: Crash when 'undolevels' is 0 and repeating "udd". (James Vega) -Solution: When there is only one branch use u_freeheader() to delete it. -Files: src/undo.c - -Patch 7.1.156 -Problem: Overlapping arguments for strcpy() when expanding command line - variables. -Solution: Use mch_memmove() instead of STRCPY(). Also fix a few typos. - (Dominique Pelle) -Files: src/ex_docmd.c - -Patch 7.1.157 -Problem: In Ex mode, :" gives an error at end-of-file. (Michael Hordijk) -Solution: Only give an error for an empty line, not for a comment. -Files: src/ex_docmd.c - -Patch 7.1.158 (extra) -Problem: Win32 console: When 'encoding' is "utf-8" and typing Alt-y the - result is wrong. Win32 GUI: Alt-y results in "u" when 'encoding' - is "cp1250" (Lukas Cerman) -Solution: For utf-8 don't set the 7th bit in a byte, convert to the correct - byte sequence. For cp1250, when conversion to 'encoding' results - in the 7th bit not set, set the 7th bit after conversion. -Files: src/os_win32.c, src/gui_w48.c - -Patch 7.1.159 -Problem: strcpy() has overlapping arguments. -Solution: Use mch_memmove() instead. (Dominique Pelle) -Files: src/ex_cmds.c - -Patch 7.1.160 -Problem: When a focus autocommand is defined, getting or losing focus - causes the hit-enter prompt to be redrawn. (Bjorn Winckler) -Solution: Overwrite the last line. -Files: src/message.c - -Patch 7.1.161 -Problem: Compilation errors with tiny features and EXITFREE. -Solution: Add #ifdefs. (Dominique Pelle) -Files: src/edit.c, src/misc2.c - -Patch 7.1.162 -Problem: Crash when using a modifier before "while" or "for". (A.Politz) -Solution: Skip modifiers when checking for a loop command. -Files: src/proto/ex_docmd.pro, src/ex_docmd.c, src/ex_eval.c - -Patch 7.1.163 -Problem: Warning for the unknown option 'bufsecret'. -Solution: Remove the lines .vim that use this option. (Andy Wokula) -Files: runtime/menu.vim - -Patch 7.1.164 -Problem: Reading past end of regexp pattern. (Dominique Pelle) -Solution: Use utf_ptr2len(). -Files: src/regexp.c - -Patch 7.1.165 -Problem: Crash related to getting X window ID. (Dominique Pelle) -Solution: Don't trust the window ID that we got in the past, check it every - time. -Files: src/os_unix.c - -Patch 7.1.166 -Problem: Memory leak for using "gp" in Visual mode. -Solution: Free memory in put_register(). (Dominique Pelle) -Files: src/ops.c - -Patch 7.1.167 -Problem: Xxd crashes when using "xxd -b -c 110". (Debian bug 452789) -Solution: Allocate more memory. Fix check for maximum number of columns. -Files: src/xxd/xxd.c - -Patch 7.1.168 (extra) -Problem: Win32 GUI: Since patch 7.1.095, when the Vim window does not have - focus, clicking in it doesn't position the cursor. (Juergen - Kraemer) -Solution: Don't reset s_button_pending just after receiving focus. -Files: src/gui_w48.c - -Patch 7.1.169 -Problem: Using uninitialized variable when system() fails. (Dominique - Pelle) -Solution: Let system() return an empty string when it fails. -Files: src/eval.c - -Patch 7.1.170 -Problem: Valgrind warning for overlapping arguments for strcpy(). -Solution: Use mch_memmove() instead. (Dominique Pelle) -Files: src/getchar.c - -Patch 7.1.171 -Problem: Reading one byte before allocated memory. -Solution: Check index not to become negative. (Dominique Pelle) -Files: src/ex_getln.c - -Patch 7.1.172 -Problem: When 'buftype' is "acwrite" Vim still checks if the file or - directory exists before overwriting. -Solution: Don't check for overwriting when the buffer name is not a file - name. -Files: src/ex_cmds.c - -Patch 7.1.173 -Problem: Accessing freed memory. (Dominique Pelle) -Solution: Don't call reg_getline() to check if a line is the first in the - file. -Files: src/regexp.c - -Patch 7.1.174 -Problem: Writing NUL past end of a buffer. -Solution: Copy one byte less when using strncat(). (Dominique Pelle) -Files: src/ex_cmds.c, src/ex_docmd.c, - -Patch 7.1.175 -Problem: <BS> doesn't work with some combination of 'sts', 'linebreak' and - 'backspace'. (Francois Ingelrest) -Solution: When adding white space results in not moving back delete one - character. -Files: src/edit.c - -Patch 7.1.176 -Problem: Building with Aap fails when the "compiledby" argument contains - '<' or '>' characters. (Alex Yeh) -Solution: Change how quoting is done in the Aap recipe. -Files: src/main.aap - -Patch 7.1.177 -Problem: Freeing memory twice when in debug mode while reading a script. -Solution: Ignore script input while in debug mode. -Files: src/ex_cmds2.c, src/getchar.c, src/globals.h - -Patch 7.1.178 -Problem: "%" doesn't work on "/* comment *//* comment */". -Solution: Don't handle the "//" in "*//*" as a C++ comment. (Markus - Heidelberg) -Files: src/search.c - -Patch 7.1.179 -Problem: Need to check for TCL 8.5. -Solution: Adjust configure script. (Alexey Froloff) -Files: src/configure.in, src/auto/configure - -Patch 7.1.180 -Problem: Regexp patterns not tested sufficiently. -Solution: Add more checks to the regexp test. -Files: src/testdir/test64.in, src/testdir/test64.ok - -Patch 7.1.181 -Problem: Accessing uninitialized memory in Farsi mode. (Dominique Pelle) -Solution: Only invoke lrF_sub() when there is something to do. -Files: src/ex_cmds.c - -Patch 7.1.182 -Problem: When using tab pages and an argument list the session file may - contain wrong "next" commands. (Alexander Bluem) -Solution: Use "argu" commands and only when needed. -Files: src/ex_docmd.c - -Patch 7.1.183 -Problem: "Internal error" for ":echo matchstr('a', 'a\%[\&]')" (Mitanu - Paul) -Solution: Inside "\%[]" detect \&, \| and \) as an error. -Files: src/regexp.c - -Patch 7.1.184 -Problem: Crash when deleting backwards over a line break in Insert mode. -Solution: Don't advance the cursor when it's already on the NUL after a - line. (Matthew Wozniski) -Files: src/normal.c - -Patch 7.1.185 -Problem: Using "gR" with a multi-byte encoding and typing a CR pushes - characters onto the replace stack incorrectly, resulting in BS - putting back the wrong characters. (Paul B. Mahol) -Solution: Push multi-byte characters onto the replace stack in reverse byte - order. Add replace_push_mb(). -Files: src/edit.c, src/misc1.c, src/proto/edit.pro - -Patch 7.1.186 -Problem: "expand('<afile>')" returns a bogus value after changing - directory. (Dave Fishburn) -Solution: Copy "autocmd_fname" to allocated memory and expand to full - filename. Shorten the path when expanding <afile>. -Files: src/ex_docmd.c, src/fileio.c - -Patch 7.1.187 -Problem: Win32 GUI: Custom completion using system() no longer works - after patch 7.1.104. (Erik Falor) -Solution: Loop when safe_vgetc() returns K_IGNORE. -Files: src/ex_getln.c - -Patch 7.1.188 -Problem: When 'showmode' is off the message for changing a readonly file is - given in the second column instead of the first. (Payl B. Mahol) -Solution: Put the W10 message in the first column. -Files: src/edit.c - -Patch 7.1.189 (after 7.1.104) -Problem: Patch 7.1.104 was incomplete. -Solution: Also call plain_vgetc() in ask_yesno(). -Files: src/misc1.c - -Patch 7.1.190 -Problem: Cursor after end-of-line: "iA sentence.<Esc>)" -Solution: Move cursor back and make motion inclusive. -Files: src/normal.c - -Patch 7.1.191 -Problem: Win32 GUI: after patch 7.1.168 there is still a problem when - clicking in a scrollbar. (Juergen Jottkaerr) -Solution: Don't check the input buffer when dragging the scrollbar. -Files: src/gui.c - -Patch 7.1.192 -Problem: With Visual block selection, "s" and typing something, CTRL-C - doesn't stop Vim from repeating the replacement in other lines, - like happens for "I". -Solution: Check for "got_int" to be set. -Files: src/ops.c - -Patch 7.1.193 -Problem: Some Vim 5.x digraphs are missing in Vim 7, even though the - character pairs are not used. (Philippe de Muyter) -Solution: Add those Vim 5.x digraphs that don't conflict with others. -Files: src/digraph.c - -Patch 7.1.194 -Problem: ":echo glob('~/{}')" results in /home/user//. -Solution: Don't add a slash if there already is one. -Files: src/os_unix.c - -Patch 7.1.195 -Problem: '0 mark doesn't work for "~/foo ~ foo". -Solution: Don't expand the whole file name, only "~/". -Files: src/mark.c - -Patch 7.1.196 (extra) -Problem: Win32 GUI: "\n" in a tooltip doesn't cause a line break. (Erik - Falor) -Solution: Use the TTM_SETMAXTIPWIDTH message. -Files: src/gui_w32.c - -Patch 7.1.197 -Problem: Mac: "make install" doesn't work when prefix defined. -Solution: Pass different arguments to "make installruntime". (Jjgod Jiang) -Files: src/Makefile - -Patch 7.1.198 -Problem: Hang when using ":s/\n//gn". (Burak Gorkemli) -Solution: Set "skip_match". -Files: src/ex_cmds.c - -Patch 7.1.199 -Problem: Can't do command line completion for a specific file name - extension. -Solution: When the pattern ends in "$" don't add a star for completion and - remove the "$" before matching with file names. -Files: runtime/doc/cmdline.txt, src/ex_getln.c - -Patch 7.1.200 (after 7.1.177 and 7.1.182) -Problem: Compiler warnings for uninitialized variables. -Solution: Init variables. -Files: src/ex_cmds2.c, src/ex_docmd.c - -Patch 7.1.201 -Problem: When reading stdin 'fenc' and 'ff are not set. -Solution: Set the options after reading stdin. (Ben Schmidt) -Files: src/fileio.c - -Patch 7.1.202 -Problem: Incomplete utf-8 byte sequence is not checked for validity. -Solution: Check the bytes that are present for being valid. (Ben Schmidt) -Files: src/mbyte.c - -Patch 7.1.203 -Problem: When 'virtualedit' is "onemore" then "99|" works but ":normal 99|" - doesn't. (Andy Wokula) -Solution: Check for "onemore" flag in check_cursor_col(). -Files: src/misc2.c - -Patch 7.1.204 (extra) -Problem: Win32: Using the example at 'balloonexpr' the balloon disappears - after four seconds and then comes back again. Also moves the - mouse pointer a little bit. (Yongwei Wu) -Solution: Set the autopop time to 30 seconds (the max value). (Sergey - Khorev) Move the mouse two pixels forward and one back to end up - in the same position (really!). -Files: src/gui_w32.c - -Patch 7.1.205 -Problem: Can't get the operator in an ":omap". -Solution: Add the "v:operator" variable. (Ben Schmidt) -Files: runtime/doc/eval.txt, src/eval.c, src/normal.c, src/vim.h - -Patch 7.1.206 -Problem: Compiler warnings when using MODIFIED_BY. -Solution: Add type casts. (Ben Schmidt) -Files: src/version.c - -Patch 7.1.207 -Problem: Netbeans: "remove" cannot delete one line. -Solution: Remove partial lines and whole lines properly. Avoid a memory - leak. (Xavier de Gaye) -Files: src/netbeans.c - -Patch 7.1.208 -Problem: On Alpha get an unaligned access error. -Solution: Store the dictitem pointer before using it. (Matthew Luckie) -Files: src/eval.c - -Patch 7.1.209 -Problem: GTK: When using the netrw plugin and doing ":gui" Vim hangs. -Solution: Stop getting a selection after three seconds. This is a hack. -Files: src/gui_gtk_x11.c - -Patch 7.1.210 -Problem: Listing mapping for 0xdb fails when 'encoding' is utf-8. (Tony - Mechelynck) -Solution: Recognize K_SPECIAL KS_EXTRA KE_CSI as a CSI byte. -Files: src/mbyte.c - -Patch 7.1.211 -Problem: The matchparen plugin may take an unexpected amount of time, so - that it looks like Vim hangs. -Solution: Add a timeout to searchpair(), searchpairpos(), search() and - searchpos(). Use half a second timeout in the plugin. -Files: runtime/doc/eval.txt, runtime/plugin/matchparen.vim, src/edit.c, - src/eval.c, src/ex_cmds2.c, src/ex_docmd.c, src/normal.c, - src/proto/eval.pro, src/proto/ex_cmds2.pro, src/proto/search.pro, - src/search.c - -Patch 7.1.212 -Problem: Accessing a byte before a line. -Solution: Check that the column is 1 or more. (Dominique Pelle) -Files: src/edit.c - -Patch 7.1.213 -Problem: A ":tabedit" command that results in the "swap file exists" dialog - and selecting "abort" doesn't close the new tab. (Al Budden) -Solution: Pass "old_curwin" to do_exedit(). -Files: src/ex_docmd.c - -Patch 7.1.214 -Problem: ":1s/g\n\zs1//" deletes characters from the first line. (A Politz) -Solution: Start replacing in the line where the match starts. -Files: src/ex_cmds.c - -Patch 7.1.215 -Problem: It is difficult to figure out what syntax items are nested at a - certain position. -Solution: Add the synstack() function. -Files: runtime/doc/eval.txt, src/eval.c, src/proto/syntax.pro, - src/syntax.c - -Patch 7.1.216 -Problem: Variants of --remote-tab are not mentioned for "vim --help". -Solution: Display optional -wait and -silent. -Files: src/main.c - -Patch 7.1.217 -Problem: The "help-tags" tag may be missing from runtime/doc/tags when it - was generated during "make install". -Solution: Add the "++t" argument to ":helptags" to force adding the tag. -Files: runtime/doc/Makefile, runtime/doc/various.txt, src/ex_cmds.c, - src/ex_cmds.h - -Patch 7.1.218 -Problem: A syntax region without a "keepend", containing a region with - "extend" could be truncated at the end of the containing region. -Solution: Do not call syn_update_ends() when there are no keepend items. -Files: src/syntax.c - -Patch 7.1.219 (after 7.1.215) -Problem: synstack() returns situation after the current character, can't - see the state for a one-character region. -Solution: Don't update ending states in the requested column. -Files: runtime/doc/eval.txt, src/eval.c, src/hardcopy.c, - src/proto/syntax.pro, src/screen.c, src/spell.c, src/syntax.c - -Patch 7.1.220 -Problem: When a ")" or word movement command moves the cursor back from the - end of the line it may end up on the trail byte of a multi-byte - character. It's also moved back when it isn't needed. -Solution: Add the adjust_cursor() function. -Files: src/normal.c - -Patch 7.1.221 -Problem: When inserting a "(", triggering the matchparen plugin, the - following highlighting may be messed up. -Solution: Before triggering the CursorMovedI autocommands update the display - to update the stored syntax stacks for the change. -Files: src/edit.c - -Patch 7.1.222 (after 7.1.217) -Problem: Wildcards in argument of ":helptags" are not expanded. (Marcel - Svitalsky) -Solution: Expand wildcards in the directory name. -Files: src/ex_cmds.c - -Patch 7.1.223 -Problem: glob() doesn't work properly when 'shell' is "sh" or "bash" and - the expanded name contains spaces, '~', single quotes and other - special characters. (Adri Verhoef, Charles Campbell) -Solution: For Posix shells define a vimglob() function to list the matches - instead of using "echo" directly. -Files: src/os_unix.c - -Patch 7.1.224 -Problem: When using "vim -F -o file1 file2" only one window is - right-to-left. Same for "-H". (Ben Schmidt) -Solution: use set_option_value() to set 'rightleft'. -Files: src/main.c - -Patch 7.1.225 -Problem: Using uninitialized value when XGetWMNormalHints() fails. -Solution: Check the return value. (Dominique Pelle) -Files: src/os_unix.c - -Patch 7.1.226 -Problem: Command line completion doesn't work when a file name contains a - '&' character. -Solution: Accept all characters in a file name, except ones that end a - command or white space. -Files: src/ex_docmd.c - -Patch 7.1.227 -Problem: Hang in syntax HL when moving over a ")". (Dominique Pelle) -Solution: Avoid storing a syntax state in the wrong position in the list of - remembered states. -Files: src/syntax.c - -Patch 7.1.228 -Problem: When 'foldmethod' is "indent" and a fold is created with ">>" it - can't be closed with "zc". (Daniel Shahaf) -Solution: Reset the "small" flag of a fold when adding a line to it. -Files: src/fold.c - -Patch 7.1.229 -Problem: A fold is closed when it shouldn't when 'foldmethod' is "indent" - and backspacing a non-white character so that the indent increases. -Solution: Keep the fold open after backspacing a character. -Files: src/edit.c - -Patch 7.1.230 -Problem: Memory leak when executing SourceCmd autocommands. -Solution: Free the memory. (Dominique Pelle) -Files: src/ex_cmds2.c - -Patch 7.1.231 -Problem: When shifting lines the change is acted upon multiple times. -Solution: Don't have shift_line() call changed_bytes. -Files: src/edit.c, src/ops.c, src/proto/edit.pro, src/proto/ops.pro - -Patch 7.1.232 (after 7.1.207 and 7.1.211) -Problem: Compiler warnings with MSVC. -Solution: Add type casts. (Mike Williams) -Files: src/ex_cmds2.c, src/netbeans.c - -Patch 7.1.233 -Problem: Crash when doing Insert mode completion for a user defined - command. (Yegappan Lakshmanan) -Solution: Don't use the non-existing command line. -Files: src/ex_getln.c - -Patch 7.1.234 -Problem: When diff'ing three files the third one isn't displayed correctly. - (Gary Johnson) -Solution: Compute the size of diff blocks correctly when merging blocks. - Compute filler lines correctly when scrolling. -Files: src/diff.c - -Patch 7.1.235 -Problem: Pattern matching is slow when using a lot of simple patterns. -Solution: Avoid allocating memory by not freeing it when it's not so much. - (Alexei Alexandrov) -Files: src/regexp.c - -Patch 7.1.236 -Problem: When using 'incsearch' and 'hlsearch' a complicated pattern may - make Vim hang until CTRL-C is pressed. -Solution: Add the 'redrawtime' option. -Files: runtime/doc/options.txt, src/ex_cmds.c, src/ex_docmd.c, - src/ex_getln.c, src/gui.c, src/misc1.c, src/normal.c, - src/option.c, src/quickfix.c, src/regexp.c, src/proto/regexp.pro, - src/proto/search.pro, src/search.c, src/screen.c, - src/option.h, src/spell.c, src/structs.h, src/syntax.c, src/tag.c, - src/vim.h - -Patch 7.1.237 -Problem: Compiler warning on an Alpha processor in Motif code. -Solution: Change a typecast. (Adri Verhoef) -Files: src/gui_motif.c - -Patch 7.1.238 -Problem: Using the 'c' flag with searchpair() may cause it to fail. Using - the 'r' flag doesn't work when 'wrapscan' is set. (A.Politz) -Solution: Only use the 'c' flag for the first search, not for repeating. - When using 'r' imply 'W'. (Antony Scriven) -Files: src/eval.c - -Patch 7.1.239 (after 7.1.233) -Problem: Compiler warning for sprintf() argument. -Solution: Add a typecast. (Nico Weber) -Files: src/ex_getln.c - -Patch 7.1.240 -Problem: When "gUe" turns a German sharp s into SS the operation stops - before the end of the word. Latin2 has the same sharp s but it's - not changed to SS there. -Solution: Make sure all the characters are operated upon. Detect the sharp - s in latin2. Also fixes that changing case of a multi-byte - character that changes the byte count doesn't always work. -Files: src/ops.c - -Patch 7.1.241 -Problem: Focus change events not always ignored. (Erik Falor) -Solution: Ignore K_IGNORE in Insert mode in a few more places. -Files: src/edit.c - -Patch 7.1.242 (after 7.1.005) -Problem: "cib" doesn't work properly on "(x)". (Tim Pope) -Solution: Use ltoreq() instead of lt(). Also fix "ciT" on "<a>x</a>". -Files: src/search.c - -Patch 7.1.243 (after 7.1.240) -Problem: "U" doesn't work on all text in Visual mode. (Adri Verhoef) -Solution: Loop over all the lines to be changed. Add tests for this. -Files: src/ops.c, src/testdir/test39.in, src/testdir/test39.ok - -Patch 7.1.244 -Problem: GUI may have part of the command line cut off. -Solution: Don't round the number of lines up, always round down. - (Tony Houghton, Scott Dillard) -Files: src/gui.c - -Patch 7.1.245 -Problem: Pressing CTRL-\ three times causes Vim to quit. (Ranganath Rao). - Also for f CTRL-\ CTRL-\. -Solution: When going to cooked mode in mch_delay() set a flag to ignore - SIGQUIT. -Files: src/os_unix.c - -Patch 7.1.246 -Problem: Configure hangs when the man pager is something strange. (lorien) -Solution: Set MANPAGER and PAGER to "cat". (Micah Cowan) -Files: src/auto/configure, src/configure.in - -Patch 7.1.247 -Problem: When using Netbeans backspacing in Insert mode skips a character - now and then. (Ankit Jain) -Solution: Avoid calling netbeans_removed(), it frees the line pointer. - (partly by Dominique Pelle). -Files: src/misc1.c - -Patch 7.1.248 -Problem: Can't set the '" mark. Can't know if setpos() was successful. -Solution: Allow setting the '" mark with setpos(). Have setpos() return a - value indicating success/failure. -Files: runtime/doc/eval.txt, src/eval.c, src/mark.c - -Patch 7.1.249 -Problem: After "U" the cursor can be past end of line. (Adri Verhoef) -Solution: Adjust the cursor position in u_undoline(). -Files: src/undo.c - -Patch 7.1.250 -Problem: ":setglobal fenc=anything" gives an error message in a buffer - where 'modifiable' is off. (Ben Schmidt) -Solution: Don't give an error if 'modifiable' doesn't matter. -Files: src/option.c - -Patch 7.1.251 -Problem: Using freed memory when spell checking enabled. -Solution: Obtain the current line again after calling spell_move_to(). - (Dominique Pelle) -Files: src/screen.c - -Patch 7.1.252 (after 7.1.243) -Problem: Test 39 fails when the environment has a utf-8 locale. (Dominique - Pelle) -Solution: Force 'encoding' to be latin1. -Files: src/testdir/test39.in - -Patch 7.1.253 -Problem: ":sort" doesn't work in a one line file. (Patrick Texier) -Solution: Don't sort if there is only one line. (Dominique Pelle) -Files: src/ex_cmds.c - -Patch 7.1.254 -Problem: Tests 49 and 55 fail when the locale is French. -Solution: Using C messages for test 49. Filter the error message in test 55 - such that it works when the number is halfway the message. -Files: src/testdir/test49.in, src/testdir/test55.in - -Patch 7.1.255 -Problem: Vim doesn't support utf-32. (Yongwei Wu) -Solution: Add aliases for utf-32, it's the same as ucs-4. -Files: src/mbyte.c - -Patch 7.1.256 -Problem: findfile() also returns directories. -Solution: Cleanup the code for finding files and directories in a list of - directories. Remove the ugly global ff_search_ctx. -Files: src/eval.c, src/misc2.c, src/vim.h, src/tag.c - -Patch 7.1.257 -Problem: Configure can't always find the Tcl header files. -Solution: Also look in /usr/local/include/tcl$tclver and - /usr/include/tcl$tclver (James Vega) -Files: src/auto/configure, src/configure.in - -Patch 7.1.258 -Problem: Crash when doing "d/\n/e" and 'virtualedit' is "all". (Andy Wokula) -Solution: Avoid that the column becomes negative. Also fixes other problems - with the end of a pattern match is in column zero. (A.Politz) -Files: src/search.c - -Patch 7.1.259 -Problem: Cursor is in the wrong position when 'rightleft' is set, - 'encoding' is "utf-8" and on an illegal byte. (Dominique Pelle) -Solution: Only put the cursor in the first column when actually on a - double-wide character. (Yukihiro Nakadaira) -Files: src/screen.c - -Patch 7.1.260 -Problem: Cursor positioning problem after ^@ wrapping halfway when - 'encoding' is utf-8. -Solution: Only count a position for printable characters. (partly by - Yukihiro Nakadaira) -Files: src/charset.c - -Patch 7.1.261 -Problem: When a 2 byte BOM is detected Vim uses UCS-2, which doesn't work - for UTF-16 text. (Tony Mechelynck) -Solution: Default to UTF-16. -Files: src/fileio.c, src/testdir/test42.ok - -Patch 7.1.262 -Problem: Can't get the process ID of Vim. -Solution: Implement getpid(). -Files: src/eval.c, runtime/doc/eval.txt - -Patch 7.1.263 -Problem: The filetype can consist of two dot separated names. This works - for syntax and ftplugin, but not for indent. (Brett Stahlman) -Solution: Use split() and loop over each dot separated name. -Files: runtime/indent.vim - -Patch 7.1.264 -Problem: Crash when indenting lines. (Dominique Pelle) -Solution: Set the cursor column when changing the cursor line. -Files: src/ops.c, src/misc1.c - -Patch 7.1.265 -Problem: When 'isfname' contains a space, cmdline completion can hang. - (James Vega) -Solution: Reset the "len" variable. -Files: src/ex_docmd.c - -Patch 7.1.266 -Problem: When the version string returned by the terminal contains - unexpected characters, it is used as typed input. (James Vega) -Solution: Assume the escape sequence ends in a letter. -Files: src/term.c - -Patch 7.1.267 -Problem: When changing folds cursor may be positioned in the wrong place. -Solution: Call changed_window_setting_win() instead of - changed_window_setting(). -Files: src/fold.c - -Patch 7.1.268 -Problem: Always shows "+" at end of screen line with: ":set - listchars=eol:$,extends:+ nowrap list cursorline" (Gary Johnson) -Solution: Check for lcs_eol_one instead of lcs_eol. -Files: src/screen.c - -Patch 7.1.269 -Problem: The matchparen plugin has an arbitrary limit for the number of - lines to look for a match. -Solution: Rely on the searchpair() timeout. -Files: runtime/plugin/matchparen.vim - -Patch 7.1.270 -Problem: ":?foo?" matches in current line since patch 7.1.025. (A.Politz) -Solution: Remove the SEARCH_START flag. -Files: src/ex_docmd.c, src/search.c - -Patch 7.1.271 -Problem: In a Vim build without autocommands, checking a file that was - changed externally causes the current buffer to be changed - unexpectedly. (Karsten Hopp) -Solution: Store "curbuf" instead of "buf". -Files: src/fileio.c - -Patch 7.1.272 -Problem: The special buffer name [Location List] is not used for a buffer - displayed in another tab page. -Solution: Use FOR_ALL_TAB_WINDOWS instead of FOR_ALL_WINDOWS. (Hiroaki - Nishihara) -Files: src/buffer.c - -Patch 7.1.273 -Problem: When profiling on Linux Vim exits early. (Liu Yubao) -Solution: When profiling don't exit on SIGPROF. -Files: src/Makefile, src/os_unix.c - -Patch 7.1.274 (after 7.1.272) -Problem: Compiler warning for optimized build. -Solution: Init win to NULL. -Files: src/buffer.c - -Patch 7.1.275 (extra) -Problem: Mac: ATSUI and 'antialias' don't work properly together. -Solution: Fix this and the input method. (Jjgod Jiang) -Files: src/vim.h, src/gui_mac.c - -Patch 7.1.276 -Problem: "gw" uses 'formatexpr', even though the docs say it doesn't. -Solution: Don't use 'formatexpr' for "gw". -Files: src/vim.h, src/edit.c, src/ops.c, src/proto/ops.pro - -Patch 7.1.277 -Problem: Default for 'paragraphs' misses some items (Colin Watson) -Solution: Add TP, HP, Pp, Lp and It to 'paragraphs'. (James Vega) -Files: runtime/doc/options.txt, src/option.c - -Patch 7.1.278 (extra, after 7.1.275) -Problem: Build failure when USE_CARBONKEYHANDLER is not defined. -Solution: Remove #ifdef. -Files: src/gui_mac.c - -Patch 7.1.279 -Problem: When using cscope temporary files are left behind. -Solution: Send the quit command to cscope and give it two seconds to exit - nicely before killing it. (partly by Dominique Pelle) -Files: src/if_cscope.c - -Patch 7.1.280 (after 7.1.275) -Problem: Mac: build problems when not using multibyte feature. (Nicholas - Stallard) -Solution: Don't define USE_IM_CONTROL when not using multibyte. -Files: src/vim.h - -Patch 7.1.281 (after 7.1.279) -Problem: sa.sa_mask is not initialized. Cscope may not exit. -Solution: Use sigemptyset(). Use SIGKILL instead of SIGTERM. (Dominique - Pelle) -Files: src/if_cscope.c - -Patch 7.1.282 (extra) -Problem: Win64: Edit with Vim context menu isn't installed correctly. - Compiler warnings and a few other things. -Solution: Add [ and ] to entry of class name. Use UINT_PTR instead of UINT. - And a fixes for the other things. (George V. Reilly) -Files: src/GvimExt/Makefile, src/dosinst.c, src/if_ole.cpp, src/if_ole.h, - src/if_ole.idl, src/INSTALLpc.txt, src/Make_mvc.mak, - src/os_win32.c, - -Patch 7.1.283 -Problem: Non-extra part for 7.1.282. -Solution: Various changes. -Files: src/ex_docmd.c, src/globals.h, src/if_cscope.c, src/main.c, - src/mark.c, src/netbeans.c, src/popupmnu.c, src/vim.h, - src/window.c - -Patch 7.1.284 -Problem: Compiler warnings for functions without prototype. -Solution: Add the function prototypes. (Patrick Texier) -Files: src/eval.c, src/quickfix.c - -Patch 7.1.285 (extra) -Problem: Mac: dialog hotkeys don't work. -Solution: Add hotkey support. (Dan Sandler) -Files: src/gui_mac.c - -Patch 7.1.286 (after 7.1.103) -Problem: "w" at the end of the buffer moves the cursor past the end of the - line. (Markus Heidelberg) -Solution: Move the cursor back from the NUL when it was moved forward. -Files: src/normal.c - -Patch 7.1.287 -Problem: Crash when reversing a list after using it. (Andy Wokula) -Solution: Update the pointer to the last used element. (Dominique Pelle) -Files: src/eval.c - -Patch 7.1.288 (after 7.1.281) -Problem: Cscope still leaves behind temp files when using gvim. -Solution: When getting the ECHILD error loop for a while until cscope exits. - (Dominique Pelle) -Files: if_cscope.c - -Patch 7.1.289 -Problem: When EXITFREE is defined and 'acd' is set freed memory is used. - (Dominique Pelle) -Solution: Reset p_acd before freeing all buffers. -Files: src/misc2.c - -Patch 7.1.290 -Problem: Reading bytes that were not written when spell checking and a line - has a very large indent. -Solution: Don't copy the start of the next line when it only contains - spaces. (Dominique Pelle) -Files: src/spell.c - -Patch 7.1.291 (after 7.1.288) -Problem: Compiler warning. -Solution: Change 50 to 50L. -Files: src/if_cscope.c - -Patch 7.1.292 -Problem: When using a pattern with "\@<=" the submatches can be wrong. - (Brett Stahlman) -Solution: Save the submatches when attempting a look-behind match. -Files: src/regexp.c - -Patch 7.1.293 -Problem: Spell checking considers super- and subscript characters as word - characters. -Solution: Recognize the Unicode super and subscript characters. -Files: src/spell.c - -Patch 7.1.294 -Problem: Leaking memory when executing a shell command. -Solution: Free memory when not able to save for undo. (Dominique Pelle) -Files: src/ex_cmds.c - -Patch 7.1.295 -Problem: Vimtutor only works with vim, not gvim. -Solution: Add the -g flag to vimtutor. (Dominique Pelle) Add gvimtutor. -Files: src/Makefile, src/gvimtutor, src/vimtutor, runtime/doc/vimtutor.1 - -Patch 7.1.296 -Problem: SELinux is not supported. -Solution: Detect the selinux library and use mch_copy_sec(). (James Vega) -Files: src/auto/configure, src/config.h.in, src/configure.in, - src/fileio.c, src/memfile.c, src/os_unix.c, src/proto/os_unix.pro - -Patch 7.1.297 -Problem: When using the search/replace dialog the parenmatch highlighting - can be wrong. (Tim Duncan) -Solution: In the GUI redraw function invoke the CursorMoved autocmd. -Files: src/gui.c - -Patch 7.1.298 (after 7.1.295) -Problem: src/gvimtutor is not distributed. -Solution: Add it to the list of distributed files. -Files: Filelist - -Patch 7.1.299 -Problem: Filetype detection doesn't work properly for file names ending in - a part that is ignored and contain a space or other special - characters. -Solution: Escape the special characters using the new fnameescape function. -Files: runtime/doc/eval.txt, runtime/filetype.vim, src/eval.c, - src/ex_getln.c, src/proto/ex_getln.pro, src/vim.h - -Patch 7.1.300 -Problem: Value of asmsyntax argument isn't checked for valid characters. -Solution: Only accepts letters and digits. -Files: runtime/filetype.vim - -Patch 7.1.301 -Problem: When the "File/Save" menu is used in Insert mode, a tab page label - is not updated to remove the "+". -Solution: Call draw_tabline() from showruler(). (Bjorn Winckler) -Files: src/screen.c - -Patch 7.1.302 (after 7.1.299) -Problem: Compilation error on MS-Windows. -Solution: Don't use xp_shell when it's not defined. -Files: src/ex_getln.c - -Patch 7.1.303 (after 7.1.302) -Problem: Compilation error on MS-Windows, again. -Solution: Declare p. -Files: src/ex_getln.c - -Patch 7.1.304 -Problem: Shortpath_for_invalid_fname() does not work correctly and is - unnecessary complex. -Solution: Clean up shortpath_for_invalid_fname(). (mostly by Yegappan - Lakshmanan) -Files: src/eval.c - -Patch 7.1.305 -Problem: Editing a compressed file with special characters in the name - doesn't work properly. -Solution: Escape special characters. -Files: runtime/autoload/gzip.vim - -Patch 7.1.306 -Problem: Some Unicode characters are handled like word characters while - they are symbols. -Solution: Adjust the table for Unicode classification. -Files: src/mbyte.c - -Patch 7.1.307 -Problem: Many warnings when compiling with Python 2.5. -Solution: Use ssize_t instead of int for some types. (James Vega) -Files: src/if_python.c - -Patch 7.1.308 -Problem: When in readonly mode ":options" produces an error. -Solution: Reset 'readonly'. (Gary Johnson) -Files: runtime/optwin.vim - -Patch 7.1.309 -Problem: Installing and testing with a shadow directory doesn't work. - (James Vega) -Solution: Add "po" to the list of directories to link. Also link the Vim - scripts in testdir. And a few more small fixes. -Files: src/Makefile - -Patch 7.1.310 -Problem: Incomplete utf-8 byte sequence at end of the file is not detected. - Accessing memory that wasn't written. -Solution: Check the last bytes in the buffer for being a valid utf-8 - character. (mostly by Ben Schmidt) - Also fix that the reported line number of the error was wrong. -Files: src/fileio.c - -Patch 7.1.311 -Problem: Compiler warning for missing sentinel in X code. -Solution: Change 0 to NULL. (Markus Heidelberg) -Files: src/mbyte.c - -Patch 7.1.312 -Problem: The .po files have mistakes in error numbers. -Solution: Search for these mistakes in the check script. (Dominique Pelle) -Files: src/po/check.vim - -Patch 7.1.313 -Problem: When the netbeans interface setModified call is used the status - lines and window title are not updated. -Solution: Redraw the status lines and title. (Philippe Fremy) -Files: src/netbeans.c - -Patch 7.1.314 -Problem: The value of 'pastetoggle' is written to the session file without - any escaping. (Randall Hansen) -Solution: Use put_escstr(). (Ben Schmidt) -Files: src/option.c - -Patch 7.1.315 -Problem: Crash with specific search pattern using look-behind match. - (Andreas Politz) -Solution: Also save the value of "need_clear_subexpr". -Files: src/regexp.c - -Patch 7.1.316 -Problem: When 'cscopetag' is set ":tag" gives an error message instead of - going to the next tag in the tag stack. -Solution: Don't call do_cstag() when there is no argument. (Mark Goldman) -Files: src/ex_docmd.c - -Patch 7.1.317 -Problem: Compiler warnings in Motif calls. -Solution: Change zero to NULL. (Dominique Pelle) -Files: src/gui_motif.c - -Patch 7.1.318 -Problem: Memory leak when closing xsmp connection. Crash on exit when - using Lesstif. -Solution: Don't close the X display to work around a Lesstif bug. Free - clientid. Also fix a leak for Motif and Athena. (Dominique Pelle) -Files: src/gui_x11.c, src/os_unix.c - -Patch 7.1.319 -Problem: When a register has an illegal utf-8 sequence, pasting it on the - command line causes an illegal memory access. -Solution: Use mb_cptr2char_adv(). (Dominique Pelle) -Files: src/ex_getln.c - -Patch 7.1.320 (extra) -Problem: Win64: Warnings while compiling Python interface. -Solution: Use PyInt in more places. Also update version message for the - console. (George Reilly) -Files: src/if_python.c, src/version.c - -Patch 7.1.321 (extra) -Problem: Win32 / Win64: Install file is outdated. -Solution: Update the text for recent compiler. (George Reilly) -Files: src/INSTALLpc.txt - -Patch 7.1.322 -Problem: Can't get start of Visual area in an <expr> mapping. -Solution: Add the 'v' argument to getpos(). -Files: runtime/doc/eval.txt, src/eval.c - -Patch 7.1.323 -Problem: Test 19 fails with some termcaps. (Dominique Pelle) -Solution: Set the t_kb and t_kD termcap values. -Files: src/testdir/test19.in, src/testdir/test38.in - -Patch 7.1.324 -Problem: File name path length on Unix is limited to 1024. -Solution: Use PATH_MAX when it's more than 1000. -Files: src/os_unix.h - -Patch 7.1.325 -Problem: When editing a command line that's longer than available space in - the window, the characters at the end are in reverse order. -Solution: Increment the insert position even when the command line doesn't - fit. (Ingo Karkat) -Files: src/ex_getln.c - -Patch 7.1.326 -Problem: ":s!from!to!" works, but ":smagic!from!to!" doesn't. It sees the - "!" as a flag to to the command. Same for ":snomagic". (Johan - Spetz) -Solution: When checking for a forced command also ignore ":smagic" and - ":snomagic". (Ian Kelling) -Files: src/ex_docmd.c - -Patch 7.1.327 -Problem: The GUI tutor is installed when there is no GUI version. -Solution: Only install gvimtutor when building a GUI version. -Files: src/Makefile - -Patch 7.1.328 -Problem: Crash when using Cygwin and non-posix path name in tags file. -Solution: Use separate buffer for posix path. (Ben Schmidt) -Files: src/os_unix.c - -Patch 7.1.329 -Problem: When the popup menu is removed a column of cells, the right halve - of double-wide characters, may not be redrawn. -Solution: Check if the right halve of a character needs to be redrawn. - (Yukihiro Nakadaira) -Files: src/screen.c - -Patch 7.1.330 -Problem: Reading uninitialized memory when using Del in replace mode. -Solution: Use utfc_ptr2len_len() instead of mb_ptr2len(). (Dominique Pelle) -Files: src/misc1.c - - -Warning for missing sentinel in gui_xmldlg.c. (Dominique Pelle) - -A search offset from the end of a match didn't work properly for multi-byte -characters. (Yukihiro Nakadaira) - -When displaying the value of 'key' don't show "*****" when the value is empty. -(Ben Schmidt) - -Internal error when compiled with EXITFREE and using the nerd_tree plugin. -Set last_msg_hist to NULL when history becomes empty. Call -free_all_functions() after garbage collection. (Dominique Pelle) - -GTK with XIM: <S-Space> does not work. (Yukihiro Nakadaira) - -Some shells do not support "echo -n", which breaks glob(). Use "echo" instead -of "echo -n $1; echo". (Gary Johnson) - -"echo 22,44" printed "22" on top of the command, the error messages caused -the rest not to be cleared. Added the need_clr_eos flag. - -Netbeans events are handled while updating the screen, causing a crash. -Change the moment when events are handled. Rename nb_parse_messages() to -netbeans_parse_messages(). (Xavier de Gaye) - -Test 11 was broken after patch 7.1.186 on Win32 console. (Daniel Shahaf) -Use shellescape() on the file name. - -IM was turned off in im_preedit_end_cb() for no good reason. (Takuhiro -Nishioka) - -A corrupted spell file could cause Vim to use lots of memory. Better -detection for running into the end of the file. (idea from James Vega) - -Mac: Included a patch to make it build with GTK. Moved language init to -mac_lang_init() function. (Ben Schmidt) - -Problem with 'wildmenu' after ":lcd", up/down arrows don't work. (Erik Falor) - -Fix configure.in to avoid "implicitly declared" warnings when running -configure. - -Fixed a memory leak when redefining a keymap. (Dominique Pelle) - -Setting 'pastetoggle' to "jj" didn't work. - -'ic' and 'smartcase' don't work properly when using \%V in a search pattern. -(Kana Natsuno) - -Patch 7.2a.001 -Problem: On some systems X11/Xlib.h exists (from X11-dev package) but - X11/Intrinsic.h does not (in Xt-dev package). This breaks the - build. Also, on Solaris 9 sys/ptem.h isn't found. -Solution: Have configure only accept X11 when X11/Intrinsic.h exists. - Check for sys/ptem.h while including sys/stream.h. (Vladimir - Marek) -Files: src/auto/configure, src/configure.in - -Patch 7.2a.002 -Problem: getbufvar(N, "") gets the dictionary of the current buffer instead - of buffer N. -Solution: Set curbuf before calling find_var_in_ht(). (Kana Natsuno) -Files: src/eval.c - -Patch 7.2a.003 -Problem: Leaking memory when using ":file name" and using access control - lists. -Solution: Invoke mch_free_acl() in vim_rename(). (Dominique Pelle) -Files: src/fileio.c - -Patch 7.2a.004 -Problem: Some systems can't get spell files by ftp. -Solution: Use http when it looks like it's possible. (James Vega) -Files: runtime/autoload/spellfile.vim - -Patch 7.2a.005 -Problem: A few error messages use confusing names. Misspelling. -Solution: Change "dissallows" to "disallows". (Dominique Pelle) Change - "number" to "Number". -Files: src/eval.c, src/fileio.c - -Patch 7.2a.006 -Problem: Reading past NUL in a string. -Solution: Check for invalid utf-8 byte sequence. (Dominique Pelle) -Files: src/charset.c - -Patch 7.2a.007 -Problem: ":let v = 1.2.3" was OK in Vim 7.1, now it gives an error. -Solution: Don't look for a floating point number after the "." operator. -Files: src/eval.c - -Patch 7.2a.008 -Problem: printf("%g", 1) doesn't work. -Solution: Convert Number to Float when needed. -Files: src/message.c - -Patch 7.2a.009 -Problem: cygwin_conv_to_posix_path() does not specify buffer size. -Solution: Use new Cygwin function: cygwin_conv_path(). (Corinna Vinschen) -Files: src/main.c, src/os_unix.c - -Patch 7.2a.010 -Problem: When a file name has an illegal byte sequence Vim may read - uninitialised memory. -Solution: Don't use UTF_COMPOSINGLIKE() on an illegal byte. In - msg_outtrans_len_attr() use char2cells() instead of ptr2cells(). - In utf_ptr2char() don't check second byte when first byte is - illegal. (Dominique Pelle) -Files: src/mbyte.c, src/message.c - -Patch 7.2a.011 -Problem: The Edit/Startup Settings menu doesn't work. -Solution: Expand environment variables. (Ben Schmidt) -Files: runtime/menu.vim - -Patch 7.2a.012 -Problem: Compiler warnings for casting int to pointer. -Solution: Add cast to long in between. (Martin Toft) -Files: src/gui_gtk_x11.c - -Patch 7.2a.013 -Problem: shellescape() does not escape "%" and "#" characters. -Solution: Add find_cmdline_var() and use it when the second argument to - shellescape() is non-zero. -Files: runtime/doc/eval.txt, src/eval.c, src/ex_docmd.c, - src/proto/ex_docmd.pro, src/proto/misc2.pro, src/misc2.c - -Patch 7.2a.014 -Problem: Problem with % in message. -Solution: Put % in single quotes. -Files: src/eval.c - -Patch 7.2a.015 (after 7.2a.010) -Problem: Misaligned messages. -Solution: Compute length of unprintable chars correctly. -Files: src/message.c - -Patch 7.2a.016 -Problem: Using CTRL-W v in the quickfix window results in two quickfix - windows, which is not allowed. ":tab split" should be allowed to - open a new quickfix window in another tab. -Solution: For CTRL-W v instead of splitting the window open a new one. - When using ":tab" do allow splitting the quickfix window (was - already included in patch 7.2a.013). -Files: src/window.c - -Patch 7.2a.017 -Problem: ":doautoall" executes autocommands for all buffers instead of just - for loaded buffers. -Solution: Change "curbuf" to "buf". -Files: src/fileio.c - -Patch 7.2a.018 -Problem: Compiler warnings when compiling with Gnome. (Tony Mechelynck) -Solution: Add type casts. -Files: src/gui_gtk_x11.c - -Patch 7.2a.019 -Problem: ":let &g:tw = 44" sets the local option value. (Cyril Slobin) -Solution: Use get_varp_scope() instead of get_varp(). (Ian Kelling) -Files: src/option.c - -There is no way to avoid adding /usr/local/{include|lib} to the build -commands. Add the --with-local-dir argument to configure. (Michael -Haubenwallner) - -When using CTRL-D after ":help", the number of matches could be thousands. -Restrict to TAG_MANY to avoid this taking too long. (Ian Kelling) - -The popup menu could be placed at a weird location. Caused by w_wcol computed -by curs_columns(). (Dominique Pelle) - -Overlapping STRCPY() arguments when using %r item in 'errorformat'. Use -STRMOVE() instead. (Ralf Wildenhues) - -Mac: On Leopard gvim, when using the mouse wheel nothing would happen until -another event occurs, such as moving the mouse. Then the recorded scrolling -would take place all at once. (Eckehard Berns) - -Solution for cursor color not reflecting IM status for GTK 2. Add -preedit_is_active flag. (SungHyun Nam) - -filereadable() can hang on a FIFO on Linux. Use open() instead of fopen(), -with O_NONBLOCK. (suggested by Lars Kotthoff) - -Included patch to support Perl 5.10. (Yasuhiro Matsumoto) - -When files are dropped on gvim while the screen is being updated, ignore the -drop command to avoid freeing memory that is being used. - -In a terminal, when drawing the popup menu over double-wide characters, half -characters may not be cleared properly. (Yukihiro Nakadaira) - -The #ifdef for including "vimio.h" was inconsistent. In a few files it -depended on MSWIN, which isn't defined until later. - -Patch 7.2b.001 -Problem: Compilation problem: mb_fix_col() missing with multi-byte feature - but without GUI or clipboard. -Solution: Remove #ifdef. -Files: src/mbyte.c - -Patch 7.2b.002 -Problem: Compiler warnings for signed/unsigned mismatch. -Solution: Add type casts. -Files: src/screen.c - -Patch 7.2b.003 -Problem: Still a compilation problem, check_col() and check_row() missing. -Solution: Add FEAT_MBYTE to the #if. -Files: src/ui.c - -Patch 7.2b.004 -Problem: Trying to free memory for a static string when using ":helpgrep". - (George Reilly) -Solution: Set 'cpo' to empty_option instead of an empty string. Also for - searchpair() and substitute(). -Files: src/quickfix.c, src/eval.c - -Patch 7.2b.005 -Problem: The special character "!" isn't handled properly in shellescape(). - (Jan Minar) -Solution: Escape "!" when using a "csh" like shell and with - shellescape(s, 1). Twice for both. Also escape <NL>. -Files: src/misc2.c - -Patch 7.2b.006 -Problem: Reading past end of string when reading info from tags line. -Solution: Break the loop when encountering a NUL. (Dominique Pelle) -Files: src/tag.c - -Patch 7.2b.007 -Problem: Part of a message cannot be translated. -Solution: Put _() around the message. -Files: src/search.c - -Patch 7.2b.008 -Problem: A few filetypes are not detected or not detected properly. -Solution: Add filetype detection patterns. (Nikolai Weibull) -Files: runtime/filetype.vim - -Patch 7.2b.009 -Problem: Reading past end of screen line. (Epicurus) -Solution: Avoid going past the value of Columns. -Files: src/screen.c - -Patch 7.2b.010 -Problem: ":mksession" doesn't work for ":map , foo", ":sunmap ,". (Ethan - Mallove) -Solution: Check for "nxo", "nso" and other strange mapping combinations. -Files: src/getchar.c - -Patch 7.2b.011 -Problem: Configure for TCL ends up with include file in compiler command. - (Richard Hogg) -Solution: Delete items from $TCL_DEFS that do not start with a dash. -Files: src/auto/configure, src/configure.in - -Patch 7.2b.012 -Problem: Build failure with +multi_byte but without +diff. -Solution: Add #ifdef. (Patrick Texier) -Files: src/main.c - -Patch 7.2b.013 -Problem: Build fails with tiny features and Perl. (Dominique Pelle) -Solution: Define missing functions. Also when compiling Python. -Files: src/if_perl.xs, src/if_python.c - -Patch 7.2b.014 -Problem: Configure uses an unsafe temp file to store commands. -Solution: Create the temp file in local directory. -Files: src/auto/configure, src/configure.in - -Patch 7.2b.015 -Problem: Build fails on Mac when using Aap. -Solution: Fix typo in configure script. -Files: src/auto/configure, src/configure.in - -Patch 7.2b.016 -Problem: Build fails with normal features but without +autocmd. -Solution: Fix #ifdefs. (Ian Kelling) -Files: src/eval.c, src/ex_cmds.c, src/quickfix.c, src/option.c, - src/ex_docmd.c - -Patch 7.2b.017 -Problem: "vim -O foo foo" results in only one window. (Zdenek Sekera) -Solution: Handle result of ATTENTION prompt properly. (Ian Kelling) -Files: src/main.c - -Patch 7.2b.018 -Problem: When doing command line completion on a file name for a csh-like - shell argument a '!' character isn't escaped properly. -Solution: Add another backslash. -Files: src/ex_getln.c, src/misc2.c, src/proto/misc2.pro, src/screen.c - -Patch 7.2b.019 (extra) -Problem: Win32: Various compiler warnings. -Solution: Use __w64 attribute. Comment-out unused parameters. Adjust a few - #ifdefs. (George Reilly) -Files: src/gui_w48.c, src/GvimExt/gvimext.cpp, src/Make_mvc.mak, - src/os_mswin.c, src/os_win32.c, src/vim.h - -Patch 7.2b.020 -Problem: ":sort n" doesn't handle negative numbers. (James Vega) -Solution: Include '-' in the number. -Files: src/charset.c, src/ex_cmds.c - -Patch 7.2b.021 -Problem: Reloading doesn't read the BOM correctly. (Steve Gardner) -Solution: Accept utf-8 BOM when specified file encoding is utf-8. -Files: src/fileio.c - -Patch 7.2b.022 -Problem: When using ":normal" while updating the status line the count of - an operator is lost. (Dominique Pelle) -Solution: Save and restore "opcount". -Files: src/ex_docmd.c, src/globals.h, src/normal.c - -Patch 7.2b.023 -Problem: Crash when using the result of synstack(0,0). (Matt Wozniski) -Solution: Check for v_list to be NULL in a few more places. -Files: src/eval.c - -Patch 7.2b.024 -Problem: Using ":gui" while the netrw plugin is active causes a delay in - updating the display. -Solution: Don't check for terminal codes when starting the GUI. -Files: src/term.c - -Patch 7.2b.025 -Problem: When the CursorHold event triggers a pending count is lost. - (Juergen Kraemer) -Solution: Save the counts and restore them. -Files: src/normal.c, src/structs.h - -Patch 7.2b.026 -Problem: The GTK 2 file chooser causes the ~/.recently-used.xbel file to be - written over and over again. This may cause a significant - slowdown. (Guido Berhoerster) -Solution: Don't use the GTK 2 file chooser. -Files: src/gui_gtk.c - -Patch 7.2b.027 -Problem: Memory leak for Python, Perl, etc. script command with end marker. -Solution: Free the memory of the end marker. (Andy Kittner) -Files: src/ex_getln.c - -Patch 7.2b.028 -Problem: Reading uninitialized memory when doing ":gui -f". (Dominique - Pelle) -Solution: Don't position the cursor when the screen size is invalid. -Files: src/gui.c - -Patch 7.2b.029 -Problem: ":help a" doesn't jump to "a" tag in docs. (Tony Mechelynck) -Solution: Get all tags and throw away more than TAG_MANY after sorting. - When there is no argument find matches for "help" to avoid a long - delay. -Files: src/ex_cmds.c, src/ex_getln.c - -Patch 7.2b.030 -Problem: When changing the value of t_Co from 8 to 16 the Visual - highlighting keeps both reverse and a background color. -Solution: Remove the attribute when setting the default highlight color. - (Markus Heidelberg) -Files: src/syntax.c - -Error when cancelling completion menu and auto-formatting. (fixed by Ian -Kelling) - -Patch 7.2c.001 -Problem: ":let x=[''] | let x += x" causes hang. (Matt Wozniski) -Solution: Only insert elements up to the original length of the List. -Files: runtime/doc/eval.txt, src/eval.c - -Patch 7.2c.002 -Problem: fnameescape() doesn't handle a leading '+' or '>'. (Jan Minar) -Solution: Escape a leading '+' and '>'. And a single '-'. -Files: runtime/doc/eval.txt, src/ex_getln.c - -Patch 7.2c.003 -Problem: Searching for "foo\%[bar]\+" gives a "Corrupted regexp program" - error. (Joachim Hofmann) -Solution: Mark the \%[] item as not being simple. -Files: src/regexp.c - -On Vista access to system directories is virtualized. (Michael Mutschler) -Adjusted the manifest file to avoid this. (George Reilly) - -Memory leak when using CTRL-C to cancel listing the jump list. (Dominique -Pelle) - -Mac: Could not build with Perl interface. - - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/vi_diff.txt b/share/vim/vim72/doc/vi_diff.txt deleted file mode 100644 index 06d327cfc7..0000000000 --- a/share/vim/vim72/doc/vi_diff.txt +++ /dev/null @@ -1,1009 +0,0 @@ -*vi_diff.txt* For Vim version 7.2. Last change: 2008 Jun 28 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Differences between Vim and Vi *vi-differences* - -Throughout the help files differences between Vim and Vi/Ex are given in -curly braces, like "{not in Vi}". This file only lists what has not been -mentioned in other files and gives an overview. - -Vim is mostly POSIX 1003.2-1 compliant. The only command known to be missing -is ":open". There are probably a lot of small differences (either because Vim -is missing something or because Posix is beside the mark). - -1. Simulated command |simulated-command| -2. Missing options |missing-options| -3. Limits |limits| -4. The most interesting additions |vim-additions| -5. Other vim features |other-features| -6. Command-line arguments |cmdline-arguments| -7. POSIX compliance |posix-compliance| - -============================================================================== -1. Simulated command *simulated-command* - -This command is in Vi, but Vim only simulates it: - - *:o* *:op* *:open* -:[range]o[pen] Works like |:visual|: end Ex mode. - {Vi: start editing in open mode} - -:[range]o[pen] /pattern/ As above, additionally move the cursor to the - column where "pattern" matches in the cursor - line. - -Vim does not support open mode, since it's not really useful. For those -situations where ":open" would start open mode Vim will leave Ex mode, which -allows executing the same commands, but updates the whole screen instead of -only one line. - -============================================================================== -2. Missing options *missing-options* - -These options are in the Unix Vi, but not in Vim. If you try to set one of -them you won't get an error message, but the value is not used and cannot be -printed. - -autoprint (ap) boolean (default on) *'autoprint'* *'ap'* -beautify (bf) boolean (default off) *'beautify'* *'bf'* -flash (fl) boolean (default ??) *'flash'* *'fl'* -graphic (gr) boolean (default off) *'graphic'* *'gr'* -hardtabs (ht) number (default 8) *'hardtabs'* *'ht'* - number of spaces that a <Tab> moves on the display -mesg boolean (default on) *'mesg'* -novice boolean (default off) *'novice'* -open boolean (default on) *'open'* -optimize (op) boolean (default off) *'optimize'* *'op'* -redraw boolean (default off) *'redraw'* -slowopen (slow) boolean (default off) *'slowopen'* *'slow'* -sourceany boolean (default off) *'sourceany'* -w300 number (default 23) *'w300'* -w1200 number (default 23) *'w1200'* -w9600 number (default 23) *'w9600'* - -============================================================================== -3. Limits *limits* - -Vim has only a few limits for the files that can be edited {Vi: can not handle -<Nul> characters and characters above 128, has limited line length, many other -limits}. - *E340* -Maximum line length On machines with 16-bit ints (Amiga and MS-DOS real - mode): 32767, otherwise 2147483647 characters. - Longer lines are split. -Maximum number of lines 2147483647 lines. -Maximum file size 2147483647 bytes (2 Gbyte) when a long integer is - 32 bits. Much more for 64 bit longs. Also limited - by available disk space for the |swap-file|. - *E75* -Length of a file path Unix and Win32: 1024 characters, otherwise 256 - characters (or as much as the system supports). -Length of an expanded string option - Unix and Win32: 1024 characters, otherwise 256 - characters -Maximum display width Unix and Win32: 1024 characters, otherwise 255 - characters -Maximum lhs of a mapping 50 characters. -Number of different highlighting types: over 30000 -Range of a Number variable: -2147483648 to 2147483647 (more on 64 bit - systems) - -Information for undo and text in registers is kept in memory, thus when making -(big) changes the amount of (virtual) memory available limits the number of -undo levels and the text that can be kept in registers. Other things are also -kept in memory: Command-line history, error messages for Quickfix mode, etc. - -Memory usage limits -------------------- - -The option 'maxmem' ('mm') is used to set the maximum memory used for one -buffer (in kilobytes). 'maxmemtot' is used to set the maximum memory used for -all buffers (in kilobytes). The defaults depend on the system used. For the -Amiga and MS-DOS, 'maxmemtot' is set depending on the amount of memory -available. -These are not hard limits, but tell Vim when to move text into a swap file. -If you don't like Vim to swap to a file, set 'maxmem' and 'maxmemtot' to a -very large value. The swap file will then only be used for recovery. If you -don't want a swap file at all, set 'updatecount' to 0, or use the "-n" -argument when starting Vim. - -============================================================================== -4. The most interesting additions *vim-additions* - -Vi compatibility. |'compatible'| - Although Vim is 99% Vi compatible, some things in Vi can be - considered to be a bug, or at least need improvement. But still, Vim - starts in a mode which behaves like the "real" Vi as much as possible. - To make Vim behave a little bit better, try resetting the 'compatible' - option: - :set nocompatible - Or start Vim with the "-N" argument: - vim -N - Vim starts with 'nocompatible' automatically if you have a .vimrc - file. See |startup|. - The 'cpoptions' option can be used to set Vi compatibility on/off for - a number of specific items. - -Support for different systems. - Vim can be used on: - - All Unix systems (it works on all systems it was tested on, although - the GUI and Perl interface may not work everywhere). - - Amiga (500, 1000, 1200, 2000, 3000, 4000, ...). - - MS-DOS in real-mode (no additional drivers required). - - In protected mode on Windows 3.1 and MS-DOS (DPMI driver required). - - Windows 95 and Windows NT, with support for long file names. - - OS/2 (needs emx.dll) - - Atari MiNT - - VMS - - BeOS - - Macintosh - - Risc OS - - IBM OS/390 - Note that on some systems features need to be disabled to reduce - resource usage, esp. on MS-DOS. For some outdated systems you need to - use an older Vim version. - -Multi level undo. |undo| - 'u' goes backward in time, 'CTRL-R' goes forward again. Set option - 'undolevels' to the number of changes to be remembered (default 1000). - Set 'undolevels' to 0 for a vi-compatible one level undo. Set it to - -1 for no undo at all. - When all changes in a buffer have been undone, the buffer is not - considered changed anymore. You can exit it with :q, without <!>. - When undoing a few changes and then making a new change Vim will - create a branch in the undo tree. This means you can go back to any - state of the text, there is no risk of a change causing text to be - lost forever. |undo-tree| - -Graphical User Interface (GUI). |gui| - Included support for GUI: menu's, mouse, scrollbars, etc. You can - define your own menus. Better support for CTRL/SHIFT/ALT keys in - combination with special keys and mouse. Supported for various - platforms, such as X11 (with Motif and Athena interfaces), GTK, Win32 - (Windows 95 and later), BeOS, Amiga and Macintosh. - -Multiple windows and buffers. |windows.txt| - Vim can split the screen into several windows, each editing a - different buffer or the same buffer at a different location. Buffers - can still be loaded (and changed) but not displayed in a window. This - is called a hidden buffer. Many commands and options have been added - for this facility. - Vim can also use multiple tab pages, each with one or more windows. A - line with tab labels can be used to quickly switch between these pages. - |tab-page| - -Syntax highlighting. |:syntax| - Vim can highlight keywords, patterns and other things. This is - defined by a number of |:syntax| commands, and can be made to - highlight most languages and file types. A number of files are - included for highlighting the most common languages, like C, C++, - Java, Pascal, Makefiles, shell scripts, etc. The colors used for - highlighting can be defined for ordinary terminals, color terminals - and the GUI with the |:highlight| command. A convenient way to do - this is using a |:colorscheme| command. - The highlighted text can be exported as HTML. |convert-to-HTML| - Other items that can be highlighted are matches with the search string - |'hlsearch'|, matching parens |matchparen| and the cursor line and - column |'cursorline'| |'cursorcolumn'|. - -Spell checking. |spell| - When the 'spell' option is set Vim will highlight spelling mistakes. - About 40 languages are currently supported, selected with the - 'spelllang' option. In source code only comments and strings are - checked for spelling. - -Folding. |folding| - A range of lines can be shown as one "folded" line. This allows - overviewing a file and moving blocks of text around quickly. - Folds can be created manually, from the syntax of the file, by indent, - etc. - -Diff mode. |diff| - Vim can show two versions of a file with the differences highlighted. - Parts of the text that are equal are folded away. Commands can be - used to move text from one version to the other. - -Plugins. |add-plugin| - The functionality can be extended by dropping a plugin file in the - right directory. That's an easy way to start using Vim scripts - written by others. Plugins can be for all kind of files, or - specifically for a filetype. - -Repeat a series of commands. |q| - "q{c}" starts recording typed characters into named register {c}. - A subsequent "q" stops recording. The register can then be executed - with the "@{c}" command. This is very useful to repeat a complex - action. - -Flexible insert mode. |ins-special-special| - The arrow keys can be used in insert mode to move around in the file. - This breaks the insert in two parts as far as undo and redo is - concerned. - - CTRL-O can be used to execute a single Normal mode command. This is - almost the same as hitting <Esc>, typing the command and doing |a|. - -Visual mode. |Visual-mode| - Visual mode can be used to first highlight a piece of text and then - give a command to do something with it. This is an (easy to use) - alternative to first giving the operator and then moving to the end of - the text to be operated upon. - |v| and |V| are used to start Visual mode. |v| works on characters - and |V| on lines. Move the cursor to extend the Visual area. It is - shown highlighted on the screen. By typing "o" the other end of the - Visual area can be moved. The Visual area can be affected by an - operator: - d delete - c change - y yank - > or < insert or delete indent - ! filter through external program - = filter through indent - : start |:| command for the Visual lines. - gq format text to 'textwidth' columns - J join lines - ~ swap case - u make lowercase - U make uppercase - -Block operators. |visual-block| - With Visual mode a rectangular block of text can be selected. Start - Visual mode with CTRL-V. The block can be deleted ("d"), yanked ("y") - or its case can be changed ("~", "u" and "U"). A deleted or yanked - block can be put into the text with the "p" and "P" commands. - -Help system. |:help| - Help is displayed in a window. The usual commands can be used to - move around, search for a string, etc. Tags can be used to jump - around in the help files, just like hypertext links. The |:help| - command takes an argument to quickly jump to the info on a subject. - <F1> is the quick access to the help system. The name of the help - index file can be set with the 'helpfile' option. - -Command-line editing and history. |cmdline-editing| - You can insert or delete at any place in the command-line using the - cursor keys. The right/left cursor keys can be used to move - forward/backward one character. The shifted right/left cursor keys - can be used to move forward/backward one word. CTRL-B/CTRL-E can be - used to go to the begin/end of the command-line. - |cmdline-history| - The command-lines are remembered. The up/down cursor keys can be used - to recall previous command-lines. The 'history' option can be set to - the number of lines that will be remembered. There is a separate - history for commands and for search patterns. - -Command-line completion. |cmdline-completion| - While entering a command-line (on the bottom line of the screen) - <Tab> can be typed to complete - what example ~ - - command :e<Tab> - - tag :ta scr<Tab> - - option :set sc<Tab> - - option value :set hf=<Tab> - - file name :e ve<Tab> - - etc. - - If there are multiple matches, CTRL-N (next) and CTRL-P (previous) - will walk through the matches. <Tab> works like CTRL-N, but wraps - around to the first match. - - The 'wildchar' option can be set to the character for command-line - completion, <Tab> is the default. CTRL-D can be typed after an - (incomplete) wildcard; all matches will be listed. CTRL-A will insert - all matches. CTRL-L will insert the longest common part of the - matches. - -Insert-mode completion. |ins-completion| - In Insert mode the CTRL-N and CTRL-P keys can be used to complete a - word that appears elsewhere. |i_CTRL-N| - With CTRL-X another mode is entered, through which completion can be - done for: - |i_CTRL-X_CTRL-F| file names - |i_CTRL-X_CTRL-K| words from 'dictionary' files - |i_CTRL-X_CTRL-T| words from 'thesaurus' files - |i_CTRL-X_CTRL-I| words from included files - |i_CTRL-X_CTRL-L| whole lines - |i_CTRL-X_CTRL-]| words from the tags file - |i_CTRL-X_CTRL-D| definitions or macros - |i_CTRL-X_CTRL-O| Omni completion: clever completion - specifically for a file type - etc. - -Long line support. |'wrap'| |'linebreak'| - If the 'wrap' option is off, long lines will not wrap and only part - of them will be shown. When the cursor is moved to a part that is not - shown, the screen will scroll horizontally. The minimum number of - columns to scroll can be set with the 'sidescroll' option. The |zh| - and |zl| commands can be used to scroll sideways. - Alternatively, long lines are broken in between words when the - 'linebreak' option is set. This allows editing a single-line - paragraph conveniently (e.g. when the text is later read into a DTP - program). Move the cursor up/down with the |gk| and |gj| commands. - -Text formatting. |formatting| - The 'textwidth' option can be used to automatically limit the line - length. This supplements the 'wrapmargin' option of Vi, which was not - very useful. The |gq| operator can be used to format a piece of text - (for example, |gqap| formats the current paragraph). Commands for - text alignment: |:center|, |:left| and |:right|. - -Extended search patterns. |pattern| - There are many extra items to match various text items. Examples: - A "\n" can be used in a search pattern to match a line break. - "x\{2,4}" matches "x" 2 to 4 times. - "\s" matches a white space character. - -Directory, remote and archive browsing. |netrw| - Vim can browse the file system. Simply edit a directory. Move around - in the list with the usual commands and press <Enter> to go to the - directory or file under the cursor. - This also works for remote files over ftp, http, ssh, etc. - Zip and tar archives can also be browsed. |tar| |zip| - -Edit-compile-edit speedup. |quickfix| - The |:make| command can be used to run the compilation and jump to the - first error. A file with compiler error messages is interpreted. Vim - jumps to the first error. - - Each line in the error file is scanned for the name of a file, line - number and error message. The 'errorformat' option can be set to a - list of scanf-like strings to handle output from many compilers. - - The |:cn| command can be used to jump to the next error. - |:cl| lists all the error messages. Other commands are available. - The 'makeef' option has the name of the file with error messages. - The 'makeprg' option contains the name of the program to be executed - with the |:make| command. - The 'shellpipe' option contains the string to be used to put the - output of the compiler into the errorfile. - -Finding matches in files. |:vimgrep| - Vim can search for a pattern in multiple files. This uses the - advanced Vim regexp pattern, works on all systems and also works to - search in compressed files. - -Improved indenting for programs. |'cindent'| - When the 'cindent' option is on the indent of each line is - automatically adjusted. C syntax is mostly recognized. The indent - for various styles can be set with 'cinoptions'. The keys to trigger - indenting can be set with 'cinkeys'. - - Comments can be automatically formatted. The 'comments' option can be - set to the characters that start and end a comment. This works best - for C code, but also works for e-mail (">" at start of the line) and - other types of text. The |=| operator can be used to re-indent - lines. - - For many other languages an indent plugin is present to support - automatic indenting. |30.3| - -Searching for words in included files. |include-search| - The |[i| command can be used to search for a match of the word under - the cursor in the current and included files. The 'include' option - can be set to a pattern that describes a command to include a file - (the default is for C programs). - The |[I| command lists all matches, the |[_CTRL-I| command jumps to - a match. - The |[d|, |[D| and |[_CTRL-D| commands do the same, but only for - lines where the pattern given with the 'define' option matches. - -Automatic commands. |autocommand| - Commands can be automatically executed when reading a file, writing a - file, jumping to another buffer, etc., depending on the file name. - This is useful to set options and mappings for C programs, - documentation, plain text, e-mail, etc. This also makes it possible - to edit compressed files. - -Scripts and Expressions. |expression| - Commands have been added to form up a powerful script language. - |:if| Conditional execution, which can be used for example - to set options depending on the value of $TERM. - |:while| Repeat a number of commands. - |:for| Loop over a list. - |:echo| Print the result of an expression. - |:let| Assign a value to an internal variable, option, etc. - Variable types are Number, String, List and Dictionary. - |:execute| Execute a command formed by an expression. - |:try| Catch exceptions. - etc., etc. See |eval|. - Debugging and profiling are supported. |debug-scripts| |profile| - If this is not enough, an interface is provided to |Python|, |Ruby|, - |Tcl|, |Perl| and |MzScheme|. - -Viminfo. |viminfo-file| - The command-line history, marks and registers can be stored in a file - that is read on startup. This can be used to repeat a search command - or command-line command after exiting and restarting Vim. It is also - possible to jump right back to where the last edit stopped with |'0|. - The 'viminfo' option can be set to select which items to store in the - .viminfo file. This is off by default. - -Printing. |printing| - The |:hardcopy| command sends text to the printer. This can include - syntax highlighting. - -Mouse support. |mouse-using| - The mouse is supported in the GUI version, in an xterm for Unix, for - BSDs with sysmouse, for Linux with gpm, for MS-DOS, and Win32. It - can be used to position the cursor, select the visual area, paste a - register, etc. - -Usage of key names. |<>| |key-notation| - Special keys now all have a name like <Up>, <End>, etc. - This name can be used in mappings, to make it easy to edit them. - -Editing binary files. |edit-binary| - Vim can edit binary files. You can change a few characters in an - executable file, without corrupting it. Vim doesn't remove NUL - characters (they are represented as <NL> internally). - |-b| command-line argument to start editing a binary file - |'binary'| Option set by |-b|. Prevents adding an <EOL> for the - last line in the file. - -Multi-language support. |multi-lang| - Files in double-byte or multi-byte encodings can be edited. There is - UTF-8 support to be able to edit various languages at the same time, - without switching fonts. |UTF-8| - Messages and menus are available in different languages. - -Move cursor beyond lines. - When the 'virtualedit' option is set the cursor can move all over the - screen, also where there is no text. This is useful to edit tables - and figures easily. - -============================================================================== -5. Other vim features *other-features* - -A random collection of nice extra features. - - -When Vim is started with "-s scriptfile", the characters read from -"scriptfile" are treated as if you typed them. If end of file is reached -before the editor exits, further characters are read from the console. - -The "-w" option can be used to record all typed characters in a script file. -This file can then be used to redo the editing, possibly on another file or -after changing some commands in the script file. - -The "-o" option opens a window for each argument. "-o4" opens four windows. - -Vi requires several termcap entries to be able to work full-screen. Vim only -requires the "cm" entry (cursor motion). - - -In command mode: - -When the 'showcmd' option is set, the command characters are shown in the last -line of the screen. They are removed when the command is finished. - -If the 'ruler' option is set, the current cursor position is shown in the -last line of the screen. - -"U" still works after having moved off the last changed line and after "u". - -Characters with the 8th bit set are displayed. The characters between '~' and -0xa0 are displayed as "~?", "~@", "~A", etc., unless they are included in the -'isprint' option. - -"][" goes to the next ending of a C function ('}' in column 1). -"[]" goes to the previous ending of a C function ('}' in column 1). - -"]f", "[f" and "gf" start editing the file whose name is under the cursor. -CTRL-W f splits the window and starts editing the file whose name is under -the cursor. - -"*" searches forward for the identifier under the cursor, "#" backward. -"K" runs the program defined by the 'keywordprg' option, with the identifier -under the cursor as argument. - -"%" can be preceded with a count. The cursor jumps to the line that -percentage down in the file. The normal "%" function to jump to the matching -brace skips braces inside quotes. - -With the CTRL-] command, the cursor may be in the middle of the identifier. - -The used tags are remembered. Commands that can be used with the tag stack -are CTRL-T, ":pop" and ":tag". ":tags" lists the tag stack. - -The 'tags' option can be set to a list of tag file names. Thus multiple -tag files can be used. For file names that start with "./", the "./" is -replaced with the path of the current file. This makes it possible to use a -tags file in the same directory as the file being edited. - -Previously used file names are remembered in the alternate file name list. -CTRL-^ accepts a count, which is an index in this list. -":files" command shows the list of alternate file names. -"#<N>" is replaced with the <N>th alternate file name in the list. -"#<" is replaced with the current file name without extension. - -Search patterns have more features. The <NL> character is seen as part of the -search pattern and the substitute string of ":s". Vi sees it as the end of -the command. - -Searches can put the cursor on the end of a match and may include a character -offset. - -Count added to "~", ":next", ":Next", "n" and "N". - -The command ":next!" with 'autowrite' set does not write the file. In vi the -file was written, but this is considered to be a bug, because one does not -expect it and the file is not written with ":rewind!". - -In Vi when entering a <CR> in replace mode deletes a character only when 'ai' -is set (but does not show it until you hit <Esc>). Vim always deletes a -character (and shows it immediately). - -Added :wnext command. Same as ":write" followed by ":next". - -The ":w!" command always writes, also when the file is write protected. In Vi -you would have to do ":!chmod +w %" and ":set noro". - -When 'tildeop' has been set, "~" is an operator (must be followed by a -movement command). - -With the "J" (join) command you can reset the 'joinspaces' option to have only -one space after a period (Vi inserts two spaces). - -"cw" can be used to change white space formed by several characters (Vi is -confusing: "cw" only changes one space, while "dw" deletes all white space). - -"o" and "O" accept a count for repeating the insert (Vi clears a part of -display). - -Flags after Ex commands not supported (no plans to include it). - -On non-UNIX systems ":cd" command shows current directory instead of going to -the home directory (there isn't one). ":pwd" prints the current directory on -all systems. - -After a ":cd" command the file names (in the argument list, opened files) -still point to the same files. In Vi ":cd" is not allowed in a changed file; -otherwise the meaning of file names change. - -":source!" command reads Vi commands from a file. - -":mkexrc" command writes current modified options and mappings to a ".exrc" -file. ":mkvimrc" writes to a ".vimrc" file. - -No check for "tail recursion" with mappings. This allows things like -":map! foo ^]foo". - -When a mapping starts with number, vi loses the count typed before it (e.g. -when using the mapping ":map g 4G" the command "7g" goes to line 4). This is -considered a vi bug. Vim concatenates the counts (in the example it becomes -"74G"), as most people would expect. - -The :put! command inserts the contents of a register above the current line. - -The "p" and "P" commands of vi cannot be repeated with "." when the putted -text is less than a line. In Vim they can always be repeated. - -":noremap" command can be used to enter a mapping that will not be remapped. -This is useful to exchange the meaning of two keys. ":cmap", ":cunmap" and -":cnoremap" can be used for mapping in command-line editing only. ":imap", -":iunmap" and ":inoremap" can be used for mapping in insert mode only. -Similar commands exist for abbreviations: ":noreabbrev", ":iabbrev" -":cabbrev", ":iunabbrev", ":cunabbrev", ":inoreabbrev", ":cnoreabbrev". - -In Vi the command ":map foo bar" would remove a previous mapping -":map bug foo". This is considered a bug, so it is not included in Vim. -":unmap! foo" does remove ":map! bug foo", because unmapping would be very -difficult otherwise (this is vi compatible). - -The ':' register contains the last command-line. -The '%' register contains the current file name. -The '.' register contains the last inserted text. - -":dis" command shows the contents of the yank registers. - -CTRL-O/CTRL-I can be used to jump to older/newer positions. These are the -same positions as used with the '' command, but may be in another file. The -":jumps" command lists the older positions. - -If the 'shiftround' option is set, an indent is rounded to a multiple of -'shiftwidth' with ">" and "<" commands. - -The 'scrolljump' option can be set to the minimum number of lines to scroll -when the cursor gets off the screen. Use this when scrolling is slow. - -The 'scrolloff' option can be set to the minimum number of lines to keep -above and below the cursor. This gives some context to where you are -editing. When set to a large number the cursor line is always in the middle -of the window. - -Uppercase marks can be used to jump between files. The ":marks" command lists -all currently set marks. The commands "']" and "`]" jump to the end of the -previous operator or end of the text inserted with the put command. "'[" and -"`[" do jump to the start. - -The 'shelltype' option can be set to reflect the type of shell used on the -Amiga. - -The 'highlight' option can be set for the highlight mode to be used for -several commands. - -The CTRL-A (add) and CTRL-X (subtract) commands are new. The count to the -command (default 1) is added to/subtracted from the number at or after the -cursor. That number may be decimal, octal (starts with a '0') or hexadecimal -(starts with '0x'). Very useful in macros. - -With the :set command the prefix "inv" can be used to invert boolean options. - -In both Vi and Vim you can create a line break with the ":substitute" command -by using a CTRL-M. For Vi this means you cannot insert a real CTRL-M in the -text. With Vim you can put a real CTRL-M in the text by preceding it with a -CTRL-V. - - -In Insert mode: - -If the 'revins' option is set, insert happens backwards. This is for typing -Hebrew. When inserting normal characters the cursor will not be shifted and -the text moves rightwards. Backspace, CTRL-W and CTRL-U will also work in -the opposite direction. CTRL-B toggles the 'revins' option. In replace mode -'revins' has no effect. Only when enabled at compile time. - -The backspace key can be used just like CTRL-D to remove auto-indents. - -You can backspace, CTRL-U and CTRL-W over line breaks if the 'backspace' (bs) -option includes "eol". You can backspace over the start of insert if the -'backspace' option includes "start". - -When the 'paste' option is set, a few option are reset and mapping in insert -mode and abbreviation are disabled. This allows for pasting text in windowing -systems without unexpected results. When the 'paste' option is reset, the old -option values are restored. - -CTRL-T/CTRL-D always insert/delete an indent in the current line, no matter -what column the cursor is in. - -CTRL-@ (insert previously inserted text) works always (Vi: only when typed as -first character). - -CTRL-A works like CTRL-@ but does not leave insert mode. - -CTRL-R {0-9a-z..} can be used to insert the contents of a register. - -When the 'smartindent' option is set, C programs will be better auto-indented. -With 'cindent' even more. - -CTRL-Y and CTRL-E can be used to copy a character from above/below the -current cursor position. - -After CTRL-V you can enter a three digit decimal number. This byte value is -inserted in the text as a single character. Useful for international -characters that are not on your keyboard. - -When the 'expandtab' (et) option is set, a <Tab> is expanded to the -appropriate number of spaces. - -The window always reflects the contents of the buffer (Vi does not do this -when changing text and in some other cases). - -If Vim is compiled with DIGRAPHS defined, digraphs are supported. A set of -normal digraphs is included. They are shown with the ":digraph" command. -More can be added with ":digraph {char1}{char2} {number}". A digraph is -entered with "CTRL-K {char1} {char2}" or "{char1} BS {char2}" (only when -'digraph' option is set). - -When repeating an insert, e.g. "10atest <Esc>" vi would only handle wrapmargin -for the first insert. Vim does it for all. - -A count to the "i" or "a" command is used for all the text. Vi uses the count -only for one line. "3iabc<NL>def<Esc>" would insert "abcabcabc<NL>def" in Vi -but "abc<NL>defabc<NL>defabc<NL>def" in Vim. - - -In Command-line mode: - -<Esc> terminates the command-line without executing it. In vi the command -line would be executed, which is not what most people expect (hitting <Esc> -should always get you back to command mode). To avoid problems with some -obscure macros, an <Esc> in a macro will execute the command. If you want a -typed <Esc> to execute the command like vi does you can fix this with - ":cmap ^V<Esc> ^V<CR>" - -General: - -The 'ttimeout' option is like 'timeout', but only works for cursor and -function keys, not for ordinary mapped characters. The 'timeoutlen' option -gives the number of milliseconds that is waited for. If the 'esckeys' option -is not set, cursor and function keys that start with <Esc> are not recognized -in insert mode. - -There is an option for each terminal string. Can be used when termcap is not -supported or to change individual strings. - -The 'fileformat' option can be set to select the <EOL>: "dos" <CR><NL>, "unix" -<NL> or "mac" <CR>. -When the 'fileformats' option is not empty, Vim tries to detect the type of -<EOL> automatically. The 'fileformat' option is set accordingly. - -On systems that have no job control (older Unix systems and non-Unix systems) -the CTRL-Z, ":stop" or ":suspend" command starts a new shell. - -If Vim is started on the Amiga without an interactive window for output, a -window is opened (and :sh still works). You can give a device to use for -editing with the |-d| argument, e.g. "-d con:20/20/600/150". - -The 'columns' and 'lines' options are used to set or get the width and height -of the display. - -Option settings are read from the first and last few lines of the file. -Option 'modelines' determines how many lines are tried (default is 5). Note -that this is different from the Vi versions that can execute any Ex command -in a modeline (a major security problem). |trojan-horse| - -If the 'insertmode' option is set (e.g. in .exrc), Vim starts in insert mode. -And it comes back there, when pressing <Esc>. - -Undo information is kept in memory. Available memory limits the number and -size of change that can be undone. This may be a problem with MS-DOS, is -hardly a problem on the Amiga and almost never with Unix and Win32. - -If the 'backup' or 'writebackup' option is set: Before a file is overwritten, -a backup file (.bak) is made. If the "backup" option is set it is left -behind. - -Vim creates a file ending in ".swp" to store parts of the file that have been -changed or that do not fit in memory. This file can be used to recover from -an aborted editing session with "vim -r file". Using the swap file can be -switched off by setting the 'updatecount' option to 0 or starting Vim with -the "-n" option. Use the 'directory' option for placing the .swp file -somewhere else. - -Vim is able to work correctly on filesystems with 8.3 file names, also when -using messydos or crossdos filesystems on the Amiga, or any 8.3 mounted -filesystem under Unix. See |'shortname'|. - -Error messages are shown at least one second (Vi overwrites error messages). - -If Vim gives the |hit-enter| prompt, you can hit any key. Characters other -than <CR>, <NL> and <Space> are interpreted as the (start of) a command. (Vi -only accepts a command starting with ':'). - -The contents of the numbered and unnamed registers is remembered when -changing files. - -The "No lines in buffer" message is a normal message instead of an error -message, since that may cause a mapping to be aborted. - -The AUX: device of the Amiga is supported. - -============================================================================== -6. Command-line arguments *cmdline-arguments* - -Different versions of Vi have different command-line arguments. This can be -confusing. To help you, this section gives an overview of the differences. - -Five variants of Vi will be considered here: - Elvis Elvis version 2.1b - Nvi Nvi version 1.79 - Posix Posix 1003.2 - Vi Vi version 3.7 (for Sun 4.1.x) - Vile Vile version 7.4 (incomplete) - Vim Vim version 5.2 - -Only Vim is able to accept options in between and after the file names. - -+{command} Elvis, Nvi, Posix, Vi, Vim: Same as "-c {command}". - -- Nvi, Posix, Vi: Run Ex in batch mode. - Vim: Read file from stdin (use -s for batch mode). - --- Vim: End of options, only file names are following. - ---cmd {command} Vim: execute {command} before sourcing vimrc files. - ---echo-wid Vim: GTK+ echoes the Window ID on stdout - ---help Vim: show help message and exit. - ---literal Vim: take file names literally, don't expand wildcards. - ---nofork Vim: same as |-f| - ---noplugin[s] Vim: Skip loading plugins. - ---remote Vim: edit the files in another Vim server - ---remote-expr {expr} Vim: evaluate {expr} in another Vim server - ---remote-send {keys} Vim: send {keys} to a Vim server and exit - ---remote-silent {file} Vim: edit the files in another Vim server if possible - ---remote-wait Vim: edit the files in another Vim server and wait for it - ---remote-wait-silent Vim: like --remote-wait, no complaints if not possible - ---role {role} Vim: GTK+ 2: set role of main window - ---serverlist Vim: Output a list of Vim servers and exit - ---servername {name} Vim: Specify Vim server name - ---socketid {id} Vim: GTK window socket to run Vim in - ---windowid {id} Vim: Win32 window ID to run Vim in - ---version Vim: show version message and exit. - --? Vile: print usage summary and exit. - --a Elvis: Load all specified file names into a window (use -o for - Vim). - --A Vim: Start in Arabic mode (when compiled with Arabic). - --b {blksize} Elvis: Use {blksize} blocksize for the session file. --b Vim: set 'binary' mode. - --C Vim: Compatible mode. - --c {command} Elvis, Nvi, Posix, Vim: run {command} as an Ex command after - loading the edit buffer. - Vim: allow up to 10 "-c" arguments - --d {device} Vim: Use {device} for I/O (Amiga only). {only when compiled - without the |+diff| feature} --d Vim: start with 'diff' set. |vimdiff| - --dev {device} Vim: Use {device} for I/O (Amiga only). - --D Vim: debug mode. - --e Elvis, Nvi, Vim: Start in Ex mode, as if the executable is - called "ex". - --E Vim: Start in improved Ex mode |gQ|, like "exim". - --f Vim: Run GUI in foreground (Amiga: don't open new window). --f {session} Elvis: Use {session} as the session file. - --F Vim: Start in Farsi mode (when compiled with Farsi). - Nvi: Fast start, don't read the entire file when editing - starts. - --G {gui} Elvis: Use the {gui} as user interface. - --g Vim: Start GUI. --g N Vile: start editing at line N - --h Vim: Give help message. - Vile: edit the help file - --H Vim: start Hebrew mode (when compiled with it). - --i Elvis: Start each window in Insert mode. --i {viminfo} Vim: Use {viminfo} for viminfo file. - --L Vim: Same as "-r" (also in some versions of Vi). - --l Nvi, Vi, Vim: Set 'lisp' and 'showmatch' options. - --m Vim: Modifications not allowed to be written, resets 'write' - option. - --M Vim: Modifications not allowed, resets 'modifiable' and the - 'write' option. - --N Vim: No-compatible mode. - --n Vim: No swap file used. - --nb[args] Vim: open a NetBeans interface connection - --O[N] Vim: Like -o, but use vertically split windows. - --o[N] Vim: Open [N] windows, or one for each file. - --p[N] Vim: Open [N] tab pages, or one for each file. - --P {parent-title} Win32 Vim: open Vim inside a parent application window - --q {name} Vim: Use {name} for quickfix error file. --q{name} Vim: Idem. - --R Elvis, Nvi, Posix, Vile, Vim: Set the 'readonly' option. - --r Elvis, Nvi, Posix, Vi, Vim: Recovery mode. - --S Nvi: Set 'secure' option. --S {script} Vim: source script after starting up. - --s Nvi, Posix, Vim: Same as "-" (silent mode), when in Ex mode. - Elvis: Sets the 'safer' option. --s {scriptin} Vim: Read from script file {scriptin}; only when not in Ex - mode. --s {pattern} Vile: search for {pattern} - --t {tag} Elvis, Nvi, Posix, Vi, Vim: Edit the file containing {tag}. --t{tag} Vim: Idem. - --T {term} Vim: Set terminal name to {term}. - --u {vimrc} Vim: Read initializations from {vimrc} file. - --U {gvimrc} Vim: Read GUI initializations from {gvimrc} file. - --v Nvi, Posix, Vi, Vim: Begin in Normal mode (visual mode, in Vi - terms). - Vile: View mode, no changes possible. - --V Elvis, Vim: Verbose mode. --V{nr} Vim: Verbose mode with specified level. - --w {size} Elvis, Posix, Nvi, Vi, Vim: Set value of 'window' to {size}. --w{size} Nvi, Vi: Same as "-w {size}". --w {name} Vim: Write to script file {name} (must start with non-digit). - --W {name} Vim: Append to script file {name}. - --x Vi, Vim: Ask for encryption key. See |encryption|. - --X Vim: Don't connect to the X server. - --y Vim: Start in easy mode, like |evim|. - --Z Vim: restricted mode - -@{cmdfile} Vile: use {cmdfile} as startup file. - -============================================================================== -7. POSIX compliance *posix* *posix-compliance* - -In 2005 the POSIX test suite was run to check the compatibility of Vim. Most -of the test was executed properly. There are the few things where Vim -is not POSIX compliant, even when run in Vi compatibility mode. - -Set the $VIM_POSIX environment variable to have 'cpoptions' include the POSIX -flags when Vim starts up. This makes Vim run as POSIX as it can. That's -a bit different from being Vi compatible. - -This is where Vim does not behave as POSIX specifies and why: - - *posix-screen-size* - The $COLUMNS and $LINES environment variables are ignored by Vim if - the size can be obtained from the terminal in a more reliable way. - Add the '|' flag to 'cpoptions' to have $COLUMNS and $LINES overrule - sizes obtained in another way. - - The "{" and "}" commands don't stop at a "{" in the original Vi, but - POSIX specifies it does. Add the '{' flag to 'cpoptions' if you want - it the POSIX way. - - The "D", "o" and "O" commands accept a count. Also when repeated. - Add the '#' flag to 'cpoptions' if you want to ignore the count. - - The ":cd" command fails if the current buffer is modified when the '.' - flag is present in 'cpoptions'. - - There is no ATTENTION message, the "A" flag is added to 'shortmess'. - -These are remarks about running the POSIX test suite: -- vi test 33 sometimes fails for unknown reasons -- vi test 250 fails; behavior will be changed in a new revision - http://www.opengroup.org/austin/mailarchives/ag-review/msg01710.html -- vi test 310 fails; exit code non-zero when any error occurred? -- ex test 24 fails because test is wrong. Changed between SUSv2 and SUSv3. -- ex tests 47, 48, 49, 72, 73 fail because .exrc file isn't read in silent - mode and $EXINIT isn't used. -- ex tests 76, 78 fail because echo is used instead of printf. (fixed) - Also: problem with \s not changed to space. -- ex test 355 fails because 'window' isn't used for "30z". -- ex test 368 fails because shell command isn't echoed in silent mode. -- ex test 394 fails because "=" command output isn't visible in silent mode. -- ex test 411 fails because test file is wrong, contains stray ':'. -- ex test 475 and 476 fail because reprint output isn't visible in silent mode. -- ex test 480 and 481 fail because the tags file has spaces instead of a tab. -- ex test 502 fails because .exrc isn't read in silent mode. -- ex test 509 fails because .exrc isn't read in silent mode. and exit code is - 1 instead of 2. -- ex test 534 fails because .exrc isn't read in silent mode. - - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/vim-fr.1 b/share/vim/vim72/doc/vim-fr.1 deleted file mode 100644 index 3b49351bff..0000000000 --- a/share/vim/vim72/doc/vim-fr.1 +++ /dev/null @@ -1,586 +0,0 @@ -.\" Traduction Lundi 7 août 2000 par Richard Hitier -.\" (richard.hitier@dial.oleane.com) -.\" Mise à jour de la traduction par David Blanchet -.\" (david.blanchet@free.fr) 2006-06-10 -.\" -.TH VIM 1 "22 Février 2002" -.SH NOM -vim \- Vi IMproved, éditeur de texte pour programmeurs -.SH SYNOPSIS -.br -.B vim -[options] [fichier ...] -.br -.B vim -[options] \- -.br -.B vim -[options] \-t marqueur -.br -.B vim -[options] \-q [fichiererreurs] -.PP -.br -.B ex -.br -.B view -.br -.B gvim -.B gview -.B evim -.B eview -.br -.B rvim -.B rview -.B rgvim -.B rgview -.SH DESCRIPTION -.B Vim -est un éditeur de texte proposant une compatibilité ascendante -avec Vi. Il permet d'éditer n'importe quel type de texte brut. -Il est particulièrement adapté pour l'édition des programmes. -.PP -Il comporte de nombreuses améliorations par rapport à Vi : annulation sur -plusieurs niveaux, fenêtres et tampons multiples, coloration syntaxique, -édition en ligne de commande, complètement des noms de fichiers, aide en -ligne, sélection visuelle, etc. -Voir ":help vi_diff.txt" pour un résumé des différences entre -.B Vim -et Vi. -.PP -Pendant l'exécution de -.B Vim -\, une aide abondante est accessible au travers du système d'aide -en ligne, grâce à la commande ":help". -Voir la section AIDE EN LIGNE plus bas. -.PP -Le plus souvent -.B Vim -est démarré pour éditer un unique fichier avec la commande -.PP - vim fichier -.PP -Plus généralement, -.B Vim -est lancé avec : -.PP - vim [options] [listefichiers] -.PP -Si la listefichiers est omise, l'éditeur démarre avec un tampon vide. -Autrement, l'une des quatre méthodes suivantes vous permettra de choisir -un ou plusieurs fichiers à éditer. -.TP 12 -fichier ... -Une liste de noms de fichiers. -Le premier sera le fichier courant et sera lu dans le tampon. -Le curseur sera placé sur la première ligne du tampon. -Vous pouvez passer aux autres fichiers avec la commande ":next". -Pour éditer un fichier débutant par un tiret, faites précéder la -liste de fichiers par "\-\-". -.TP -\- -Le fichier à éditer est lu sur l'entrée standard (stdin). Les commandes sont -lues depuis stderr, qui devrait être un terminal. -.TP -\-t {marqueur} -Le fichier à éditer et la position initiale du curseur dépendent -d'un "marqueur", qui est une sorte d'étiquette. -{marqueur} est recherché dans le fichier des marqueurs, le fichier correspondant -devient le fichier courant et la commande associée est exécutée. -Principalement utile pour les programmes en C ; dans ce cas, {marqueur} -peut être le nom d'une fonction. -Au final, le fichier contenant cette fonction devient le fichier -courant et le curseur est placé au début de la fonction. -Voir ":help tag\-commands". -.TP -\-q [fichiererreurs] -Démarre en mode Mise-au-point (QuickFix). -Le fichier [fichiererreurs] est lu et la première erreur est affichée. -Si [fichiererreurs] est omis, le nom du fichier est lu dans -l'option 'errorfile' ("AztecC.Err" par défaut sur Amiga, "errors.err" sur les -autres systèmes). -La commande ":cn" permet de sauter aux erreurs suivantes. -Voir ":help quickfix". -.PP -.B Vim -se comporte différemment selon le nom de la commande (l'exécutable peut -cependant être le même fichier). -.TP 10 -vim -La façon "normale", le comportement par défaut. -.TP -ex -Démarre en mode Ex. -La commande ":vi" permet de passer en mode Normal. -Ce mode est également accessible avec l'argument "\-e". -.TP -view -Démarre en mode Lecture-Seule. Vous êtes protégé de l'écriture accidentelle -des fichiers. Ce mode est également accessible avec l'argument "\-R". -.TP -gvim gview -La version graphique. -Ouvre une nouvelle fenêtre. -Également accessible avec l'argument "\-g". -.TP -evim eview -La version graphique en mode Débutant (easy). -Ouvre une nouvelle fenêtre. -Également accessible avec l'argument "\-y". -.TP -rvim rview rgvim rgview -Comme ci-dessus, mais avec des restrictions. Il vous sera impossible de -lancer des commandes du shell, ou de suspendre -.B Vim. -Également accessible avec l'argument "\-Z". -.SH OPTIONS -Les options peuvent être spécifiées dans n'importe quel ordre, -avant ou après les noms de fichiers. Les options sans arguments -peuvent être combinées après un unique tiret. -.TP 12 -+[num] -Place le curseur sur la ligne "num" dans le premier fichier. -Si "num" est omis, le curseur sera placé sur la dernière ligne. -.TP -+/{motif} -Place le curseur sur la première occurrence de {motif} dans le premier fichier. -Voir ":help search\-pattern" pour connaître les motifs de recherches -disponibles. -.TP -+{commande} -.TP -\-c {commande} -Exécute {commande} après la lecture du premier fichier. -{commande} est interprétée comme une commande Ex. -Si la {commande} contient des espaces, elle doit être entourée -de doubles-apostrophes (cela dépend du shell utilisé). -Exemple: Vim "+set si" main.c -.br -Note : vous pouvez utiliser jusqu'à 10 commandes "+" ou "\-c". -.TP -\-S {fichier} -Source {fichier} après la lecture du premier fichier. -C'est équivalent à \-c "source {fichier}". -{fichier} ne peut pas débuter par un '\-'. -Si {fichier} est omis, "Session.vim" est utilisé (cela ne fonctionne que si -\-S est le dernier argument). -.TP -\-\-cmd {commande} -Comme "\-c", mais la commande est exécutée juste avant de traiter les fichiers -vimrc. -Vous pouvez utiliser jusqu'à 10 de ces commandes, indépendamment des -commandes "\-c". -.TP -\-A -Si -.B Vim -a été compilé avec le support de la fonctionnalité ARABIC pour l'édition de -fichiers de droite à gauche et les claviers arabes, cette option lance -.B Vim -en mode Arabe, c.-à-d. que l'option 'arabic' est activée. -Sinon, un message d'erreur est émis et -.B Vim -quitte. -.TP -\-b -Mode Binaire. -Active plusieurs options pour permettre l'édition -d'un fichier binaire ou exécutable. -.TP -\-C -Compatible. Active l'option 'compatible'. -.B Vim -se comportera alors quasiment comme Vi, même s'il existe un fichier .vimrc. -.TP -\-d -Démarre en mode Diff. -Deux ou trois noms de fichiers doivent être spécifiés. -.B Vim -ouvrira alors tous les fichiers et affichera leurs différences. -Fonctionne comme vimdiff(1). -.TP -\-d {périph} -Ouvre {périph} pour l'utiliser comme terminal. -Uniquement sur Amiga. -Exemple: -"\-d con:20/30/600/150". -.TP -\-D -Debogage. Passe en mode Débogage lors de l'exécution de la première commande -d'un script. -.TP -\-e -Démarre -.B Vim -en mode Ex, comme si l'exécutable s'appelait "ex". -.TP -\-E -Démarre -.B Vim -en mode Ex amélioré, comme si l'exécutable "exim" avait été invoqué. -.TP -\-f -Premier-plan (Foreground). Pour la version graphique, -.B Vim -ne forke pas et ne se détache pas du shell dans lequel il a été invoqué. -Sur Amiga, -.B Vim -n'est pas relancé pour ouvrir une nouvelle fenêtre. -Cette option est utile quand -.B Vim -est exécuté par un programme qui attend la fin de la session d'édition -(par exemple mail). -Sur Amiga, les commandes ":sh" et ":!" ne fonctionneront pas. -.TP -\-\-nofork -Premier-plan (Foreground). Pour la version graphique, -.B Vim -ne forkera pas et ne se détachera pas du shell dans lequel il a été lancé. -.TP -\-F -Si -.B Vim -a été compilé avec le support de la fonctionnalité FKMAP pour l'édition de -fichiers de droite à gauche et les claviers farsi, cette option lance -.B Vim -en mode Farsi, c.-à-d. avec les options 'fkmap' et 'rightleft' activées. -Sinon, un message d'erreur est émis et -.B Vim -quitte. -.TP -\-g -Si -.B Vim -a été compilé avec le support de l'IHM graphique, cette option active -l'IHM graphique. Si le support n'a pas été compilé, un message d'erreur -est émis et -.B Vim -quitte. -.TP -\-h -Donne une aide succincte sur les arguments et les options de la ligne de -commande. Après cela, -.B Vim -quitte. -.TP -\-H -Si -.B Vim -a été compilé avec le support de la fonctionnalité RIGHTLEFT pour l'édition de -fichiers de droite à gauche et les claviers hébreu, cette option lance -.B Vim -en mode Hébreu, c.-à-d. avec les options 'hkmap' et 'rightleft' activées. -Sinon, un message d'erreur est émis et -.B Vim -quitte. -.TP -\-i {viminfo} -Lorsque l'utilisation d'un fichier viminfo est activée, cette option indique -le nom de fichier à utiliser à la place de "~/.viminfo" par défaut. -Il est possible d'empêcher l'utilisation d'un fichier ".viminfo", en -spécifiant le nom de fichier "NONE". -.TP -\-L -Comme \-r. -.TP -\-l -Mode Lisp. -Active les options 'lisp' et 'showmatch'. -.TP -\-m -Empêche la modification des fichiers. -Désactive l'option 'write'. -Vous pouvez toujours modifier le tampon, mais il vous sera impossible -d'écrire le fichier. -.TP -\-M -N'autorise aucune modification. les options 'modifiable' et 'write' sont -désactivées, de sorte que les changements ne sont pas autorisés et que les -fichiers ne peuvent pas être écrits. Note : ces options peuvent être activées -pour autoriser les modifications. -.TP -\-N -Mode Non-compatible. Désactive l'option 'compatible'. -Cela améliorera le comportement de -.B Vim -\, mais il sera moins conforme à celui de Vi, même s'il n'existe aucun -fichier ".vimrc". -.TP -\-n -N'utilise pas de fichier d'échange (swapfile). -Le recouvrement après un plantage sera impossible. -Utile pour éditer un fichier sur un support très lent (disquette par ex.). -Également activable avec ":set uc=0". -Il est possible de l'annuler avec ":set uc=200". -.TP -\-nb -Devient un serveur d'édition pour NetBeans. Consulter la documentation à ce -sujet pour davantage de détails. -.TP -\-o[N] -Ouvre N fenêtres les unes au-dessus des autres. -Quand N est omis, ouvre une fenêtre pour chaque fichier. -.TP -\-O[N] -Ouvre N fenêtres côte à côte. -Quand N est omis, ouvre une fenêtre pour chaque fichier fichier. -.TP -\-p[N] -Ouvre N onglets. -Quand N est omis, ouvre un onglet pour chaque fichier fichier. -.TP -\-R -Mode Lecture-Seule. -Active l'option 'readonly'. -Vous pouvez toujours éditer le tampon, mais il vous sera impossible de -d'écraser accidentellement un fichier. -Si vous voulez écraser un fichier, ajoutez un point d'exclamation à la commande -Ex, comme dans ":w!". -L'option \-R impose l'option \-n (voir ci-dessus). -L'option 'readonly' peut être désactivée avec ":set noro". -Voir ":help 'readonly'". -.TP -\-r -Donne la liste des fichiers d'échange, avec des informations pour les utiliser -à des fins de recouvrement. -.TP -\-r {file} -Mode Recouvrement. -Utilise le fichier d'échange pour récouvrer d'une session d'édition plantée. -Le fichier d'échange est un fichier avec le même nom que le fichier texte, -suivi du suffixe ".swp". -Voir ":help recovery". -.TP -\-s -Mode Silencieux. Disponible uniquement quand -.B Vim -est lancé en tant que "ex" ou quand l'option "\-e" a été spécifiée avant -l'option "\-s". -.TP -\-s {scriptEntrée} -Lit le fichier de script {scriptEntrée}. -Les caractères du fichier sont interprétés comme si vous les tapiez. -La commande ":source! {scriptEntrée}" donne le même résultat. -Si la fin du fichier est atteinte avant que l'éditeur quitte, les caractères -suivants sont lus depuis le clavier. -.TP -\-T {terminal} -Indique à -.B Vim -le nom du terminal utilisé. -Cela n'est requis que lorsque la détection automatique échoue. -Le {terminal} devrait être connu de -.B Vim -(intégré) ou défini dans le fichier termcap ou terminfo. -.TP -\-u {vimrc} -Utilise les commandes du fichier {vimrc} pour les initialisations. -Toutes les autres initialisations sont omises. -À utiliser pour éditer un type de fichiers particulier. -Cela permet aussi d'omettre toute initialisation en spécifiant le nom de -fichier "NONE". -Voir ":help initialization" dans Vim pour davantage de détails. -.TP -\-U {gvimrc} -Utilise les commandes du fichier {gvimrc} pour l'initialisation de l'IHM -graphique. -Toutes les autres initialisations graphiques sont omises. -Cela permet aussi d'omettre toute initialisation graphique en spécifiant le nom -de fichier "NONE". -Voir ":help gui\-init" dans Vim pour davantage de détails. -.TP -\-V[N] -Mode Verbeux. -Donne des messages à propos des fichiers sourcés, ainsi que sur la lecture -et les écritures dans le fichier viminfo. le nombre optionnel N précise la -valeur de l'option 'verbose' (10 par défaut). -.TP -\-v -Démarre -.B Vim -en mode Vi, comme si l'exécutable s'appelait "vi". Cela n'a d'effet que si -l'exécutable invoqué est "ex". -.TP -\-w {scriptSortie} -Tous les caractères que vous tapez sont enregistrés dans le fichier -{scriptSortie}, jusqu'à ce que vous quittiez -.B Vim. -C'est utile quand vous voulez créer un fichier de script à utiliser avec -"vim \-s" ou ":source!". -Si le fichier {scriptSortie} existe, les caractères sont ajoutés à la fin. -.TP -\-W {scriptSortie} -Comme \-w, mais un fichier existant sera écrasé. -.TP -\-x -Chiffre les fichiers lors de l'écriture. Une clé de chiffrement sera demandée. -.TP -\-X -Ne se connecte pas au serveur X. Accélère le temps de démarrage dans un -terminal, mais le titre de la fenêtre et le presse-papier seront inaccessibles. -.TP -\-y -Démarre -.B Vim -en mode Débutant (easy), comme si l'exécutable s'appelait "evim" ou "eview". -Donne à -.B Vim -un comportement plus proche des éditeurs « cliquez-tapez ». -.TP -\-Z -Mode restreint. Fonctionne comme si l'exécutable commençait par la lettre 'r'. -.TP -\-\- -Délimite la fin des options. -Les arguments qui suivent seront considérés comme des noms de fichiers. -Cela permet d'éditer des fichier débutant par un '\-'. -.TP -\-\-echo\-wid -IHM graphique GTK uniquement : retourne la Window ID sur stdout. -.TP -\-\-help -Donne un message d'aide et quitte, comme "\-h". -.TP -\-\-literal -Prend les arguments de noms de fichiers littéralement, sans étendre les -jokers. N'a aucun effet sur Unix, où le shell étend les jokers. -.TP -\-\-noplugin -Ne charge pas les greffons. Implicite avec \-u NONE. -.TP -\-\-remote -Se connecte à un serveur Vim et lui fait éditer les fichiers spécifiés dans -le reste des arguments. Si aucun serveur n'est trouvé, un avertissement est -émis et les fichiers sont édités dans le Vim courant. -.TP -\-\-remote\-expr {expr} -Se connecte à un serveur Vim, y évalue {expr} et affiche le résultat sur la -sortie standard (stdout). -.TP -\-\-remote\-send {touches} -Se connecte à un serveur Vim et y envoie {touches}. -.TP -\-\-remote\-silent -Comme \-\-remote, mais sans émettre d'avertissement si aucun serveur n'est -trouvé. -.TP -\-\-remote\-wait -Comme \-\-remote, mais Vim ne quitte pas tant que le fichier est en cours -d'édition. -.TP -\-\-remote\-wait\-silent -Comme \-\-remote\-wait, mais sans émettre d'avertissement si aucun serveur n'est -trouvé. -.TP -\-\-serverlist -Donne la liste des noms de tous les serveurs Vim disponibles. -.TP -\-\-servername {nom} -Utilise {nom} pour le nom de serveur. Ce nom est donné au Vim courant, à moins -qu'il ne soit utilisé avec un argument \-\-remote. Dans ce cas, il s'agit du nom -du serveur auquel se connecter. -.TP -\-\-socketid {id} -IHM graphique GTK+ uniquement : utilise le mécanisme GtkPlug pour faire -fonctionner gvim dans une autre fenêtre. -.TP -\-\-version -Affiche les informations sur la version puis quitte. -.SH AIDE EN LIGNE -Taper ":help" dans -.B Vim -pour commencer. -Taper ":help sujet" pour obtenir de l'aide sur un sujet précis. -Par exemple : ":help ZZ" pour consulter l'aide sur la commande "ZZ". -Utiliser <Tab> et CTRL\-D pour compléter les sujets (":help -cmdline\-completion"). -Des marqueurs sont inclus dans l'aide et vous permettent de sauter d'un endroit -à un autre (comme des liens hypertextes, voir ":help"). -L'ensemble des fichiers de la documentation peut être consulté de cette -façon, par exemple ":help syntax.txt". -.SH FICHIERS -.TP 15 -/usr/local/lib/vim/doc/*.txt -Les fichiers de la documentation de -.B Vim. -Utiliser ":help doc\-file\-list" pour obtenir la liste complète. -.TP -/usr/local/lib/vim/doc/tags -Le fichier des marqueurs utilisé pour trouver les informations dans les -fichiers de la documentation. -.TP -/usr/local/lib/vim/syntax/syntax.vim -Initialisation de la syntaxe pour l'ensemble du système. -.TP -/usr/local/lib/vim/syntax/*.vim -Fichiers de syntaxe pour différents langages. -.TP -/usr/local/lib/vim/vimrc -Initialisation de -.B Vim -pour l'ensemble du système. -.TP -~/.vimrc -Initialisation de -.B Vim -de votre compte utilisateur. -.TP -/usr/local/lib/vim/gvimrc -Initialisation de gvim pour l'ensemble du système. -.TP -~/.gvimrc -Initialisation de gvim pour votre compte utilisateur. -.TP -/usr/local/lib/vim/optwin.vim -Script utilisé pour la commande ":options", une manière pratique de consulter -et de modifier les options. -.TP -/usr/local/lib/vim/menu.vim -Initialisation des menus de gvim pour l'ensemble du système. -.TP -/usr/local/lib/vim/bugreport.vim -Script pour générer un rapport de bogue. Voir ":help bugs". -.TP -/usr/local/lib/vim/filetype.vim -Script pour détecter le type d'un fichier d'après son nom. -Voir ":help 'filetype'". -.TP -/usr/local/lib/vim/scripts.vim -Script pour détecter le type d'un fichier d'après son contenu. -Voir ":help 'filetype'". -.TP -/usr/local/lib/vim/print/*.ps -Fichiers utilisés pour l'impression PostScript. -.PP -Pour disposer d'informations récentes, consulter le site Internet de VIM : -.br -<URL:http://www.vim.org/> -.SH VOIR AUSSI -vimtutor(1) -.SH AUTEUR -La majeure partie de -.B Vim -a été écrite par Bram Moolenaar, avec l'aide de nombreux autres contributeurs. -Voir ":help credits" dans -.B Vim. -.br -.B Vim -est basé sur Stevie, réalisé par Tim Thompson, -Tony Andrews et G.R. (Fred) Walter. -Toutefois, pratiquement rien du code original ne subsiste. -.SH BOGUES -Probablement. -Voir ":help todo" pour consulter la liste des problèmes connus. -.PP -NOTE : Remarquez que bon nombre de points, qui pourraient être considérés comme -des bugs par certains, sont en fait dus à une reproduction trop fidèle -du comportement de Vi. Et si vous pensez que d'autres points sont des -bugs "parce que Vi le fait différemment", vous devriez jeter un oeil -attentif au fichier vi_diff.txt (ou taper ":help vi_diff.txt" dans Vim). -Regardez aussi les options 'compatible' et 'coptions'. -.SH TRADUCTION -Cette page de manuel a été traduite par Richard Hitier. -<richard.hitier@dial.oleane.com> 2000-08-07. -.br -Cette page de manuel a été mise à jour par David Blanchet. -<david.blanchet@free.fr> 2006-04-10. diff --git a/share/vim/vim72/doc/vim-fr.UTF-8.1 b/share/vim/vim72/doc/vim-fr.UTF-8.1 deleted file mode 100644 index 6e7b183be1..0000000000 --- a/share/vim/vim72/doc/vim-fr.UTF-8.1 +++ /dev/null @@ -1,586 +0,0 @@ -.\" Traduction Lundi 7 août 2000 par Richard Hitier -.\" (richard.hitier@dial.oleane.com) -.\" Mise à jour de la traduction par David Blanchet -.\" (david.blanchet@free.fr) 2006-06-10 -.\" -.TH VIM 1 "22 Février 2002" -.SH NOM -vim \- Vi IMproved, éditeur de texte pour programmeurs -.SH SYNOPSIS -.br -.B vim -[options] [fichier ...] -.br -.B vim -[options] \- -.br -.B vim -[options] \-t marqueur -.br -.B vim -[options] \-q [fichiererreurs] -.PP -.br -.B ex -.br -.B view -.br -.B gvim -.B gview -.B evim -.B eview -.br -.B rvim -.B rview -.B rgvim -.B rgview -.SH DESCRIPTION -.B Vim -est un éditeur de texte proposant une compatibilité ascendante -avec Vi. Il permet d'éditer n'importe quel type de texte brut. -Il est particulièrement adapté pour l'édition des programmes. -.PP -Il comporte de nombreuses améliorations par rapport à Vi : annulation sur -plusieurs niveaux, fenêtres et tampons multiples, coloration syntaxique, -édition en ligne de commande, complètement des noms de fichiers, aide en -ligne, sélection visuelle, etc. -Voir ":help vi_diff.txt" pour un résumé des différences entre -.B Vim -et Vi. -.PP -Pendant l'exécution de -.B Vim -\, une aide abondante est accessible au travers du système d'aide -en ligne, grâce à la commande ":help". -Voir la section AIDE EN LIGNE plus bas. -.PP -Le plus souvent -.B Vim -est démarré pour éditer un unique fichier avec la commande -.PP - vim fichier -.PP -Plus généralement, -.B Vim -est lancé avec : -.PP - vim [options] [listefichiers] -.PP -Si la listefichiers est omise, l'éditeur démarre avec un tampon vide. -Autrement, l'une des quatre méthodes suivantes vous permettra de choisir -un ou plusieurs fichiers à éditer. -.TP 12 -fichier ... -Une liste de noms de fichiers. -Le premier sera le fichier courant et sera lu dans le tampon. -Le curseur sera placé sur la première ligne du tampon. -Vous pouvez passer aux autres fichiers avec la commande ":next". -Pour éditer un fichier débutant par un tiret, faites précéder la -liste de fichiers par "\-\-". -.TP -\- -Le fichier à éditer est lu sur l'entrée standard (stdin). Les commandes sont -lues depuis stderr, qui devrait être un terminal. -.TP -\-t {marqueur} -Le fichier à éditer et la position initiale du curseur dépendent -d'un "marqueur", qui est une sorte d'étiquette. -{marqueur} est recherché dans le fichier des marqueurs, le fichier correspondant -devient le fichier courant et la commande associée est exécutée. -Principalement utile pour les programmes en C ; dans ce cas, {marqueur} -peut être le nom d'une fonction. -Au final, le fichier contenant cette fonction devient le fichier -courant et le curseur est placé au début de la fonction. -Voir ":help tag\-commands". -.TP -\-q [fichiererreurs] -Démarre en mode Mise-au-point (QuickFix). -Le fichier [fichiererreurs] est lu et la première erreur est affichée. -Si [fichiererreurs] est omis, le nom du fichier est lu dans -l'option 'errorfile' ("AztecC.Err" par défaut sur Amiga, "errors.err" sur les -autres systèmes). -La commande ":cn" permet de sauter aux erreurs suivantes. -Voir ":help quickfix". -.PP -.B Vim -se comporte différemment selon le nom de la commande (l'exécutable peut -cependant être le même fichier). -.TP 10 -vim -La façon "normale", le comportement par défaut. -.TP -ex -Démarre en mode Ex. -La commande ":vi" permet de passer en mode Normal. -Ce mode est également accessible avec l'argument "\-e". -.TP -view -Démarre en mode Lecture-Seule. Vous êtes protégé de l'écriture accidentelle -des fichiers. Ce mode est également accessible avec l'argument "\-R". -.TP -gvim gview -La version graphique. -Ouvre une nouvelle fenêtre. -Également accessible avec l'argument "\-g". -.TP -evim eview -La version graphique en mode Débutant (easy). -Ouvre une nouvelle fenêtre. -Également accessible avec l'argument "\-y". -.TP -rvim rview rgvim rgview -Comme ci-dessus, mais avec des restrictions. Il vous sera impossible de -lancer des commandes du shell, ou de suspendre -.B Vim. -Également accessible avec l'argument "\-Z". -.SH OPTIONS -Les options peuvent être spécifiées dans n'importe quel ordre, -avant ou après les noms de fichiers. Les options sans arguments -peuvent être combinées après un unique tiret. -.TP 12 -+[num] -Place le curseur sur la ligne "num" dans le premier fichier. -Si "num" est omis, le curseur sera placé sur la dernière ligne. -.TP -+/{motif} -Place le curseur sur la première occurrence de {motif} dans le premier fichier. -Voir ":help search\-pattern" pour connaître les motifs de recherches -disponibles. -.TP -+{commande} -.TP -\-c {commande} -Exécute {commande} après la lecture du premier fichier. -{commande} est interprétée comme une commande Ex. -Si la {commande} contient des espaces, elle doit être entourée -de doubles-apostrophes (cela dépend du shell utilisé). -Exemple: Vim "+set si" main.c -.br -Note : vous pouvez utiliser jusqu'à 10 commandes "+" ou "\-c". -.TP -\-S {fichier} -Source {fichier} après la lecture du premier fichier. -C'est équivalent à \-c "source {fichier}". -{fichier} ne peut pas débuter par un '\-'. -Si {fichier} est omis, "Session.vim" est utilisé (cela ne fonctionne que si -\-S est le dernier argument). -.TP -\-\-cmd {commande} -Comme "\-c", mais la commande est exécutée juste avant de traiter les fichiers -vimrc. -Vous pouvez utiliser jusqu'à 10 de ces commandes, indépendamment des -commandes "\-c". -.TP -\-A -Si -.B Vim -a été compilé avec le support de la fonctionnalité ARABIC pour l'édition de -fichiers de droite à gauche et les claviers arabes, cette option lance -.B Vim -en mode Arabe, c.-à-d. que l'option 'arabic' est activée. -Sinon, un message d'erreur est émis et -.B Vim -quitte. -.TP -\-b -Mode Binaire. -Active plusieurs options pour permettre l'édition -d'un fichier binaire ou exécutable. -.TP -\-C -Compatible. Active l'option 'compatible'. -.B Vim -se comportera alors quasiment comme Vi, même s'il existe un fichier .vimrc. -.TP -\-d -Démarre en mode Diff. -Deux ou trois noms de fichiers doivent être spécifiés. -.B Vim -ouvrira alors tous les fichiers et affichera leurs différences. -Fonctionne comme vimdiff(1). -.TP -\-d {périph} -Ouvre {périph} pour l'utiliser comme terminal. -Uniquement sur Amiga. -Exemple: -"\-d con:20/30/600/150". -.TP -\-D -Debogage. Passe en mode Débogage lors de l'exécution de la première commande -d'un script. -.TP -\-e -Démarre -.B Vim -en mode Ex, comme si l'exécutable s'appelait "ex". -.TP -\-E -Démarre -.B Vim -en mode Ex amélioré, comme si l'exécutable "exim" avait été invoqué. -.TP -\-f -Premier-plan (Foreground). Pour la version graphique, -.B Vim -ne forke pas et ne se détache pas du shell dans lequel il a été invoqué. -Sur Amiga, -.B Vim -n'est pas relancé pour ouvrir une nouvelle fenêtre. -Cette option est utile quand -.B Vim -est exécuté par un programme qui attend la fin de la session d'édition -(par exemple mail). -Sur Amiga, les commandes ":sh" et ":!" ne fonctionneront pas. -.TP -\-\-nofork -Premier-plan (Foreground). Pour la version graphique, -.B Vim -ne forkera pas et ne se détachera pas du shell dans lequel il a été lancé. -.TP -\-F -Si -.B Vim -a été compilé avec le support de la fonctionnalité FKMAP pour l'édition de -fichiers de droite à gauche et les claviers farsi, cette option lance -.B Vim -en mode Farsi, c.-à-d. avec les options 'fkmap' et 'rightleft' activées. -Sinon, un message d'erreur est émis et -.B Vim -quitte. -.TP -\-g -Si -.B Vim -a été compilé avec le support de l'IHM graphique, cette option active -l'IHM graphique. Si le support n'a pas été compilé, un message d'erreur -est émis et -.B Vim -quitte. -.TP -\-h -Donne une aide succincte sur les arguments et les options de la ligne de -commande. Après cela, -.B Vim -quitte. -.TP -\-H -Si -.B Vim -a été compilé avec le support de la fonctionnalité RIGHTLEFT pour l'édition de -fichiers de droite à gauche et les claviers hébreu, cette option lance -.B Vim -en mode Hébreu, c.-à-d. avec les options 'hkmap' et 'rightleft' activées. -Sinon, un message d'erreur est émis et -.B Vim -quitte. -.TP -\-i {viminfo} -Lorsque l'utilisation d'un fichier viminfo est activée, cette option indique -le nom de fichier à utiliser à la place de "~/.viminfo" par défaut. -Il est possible d'empêcher l'utilisation d'un fichier ".viminfo", en -spécifiant le nom de fichier "NONE". -.TP -\-L -Comme \-r. -.TP -\-l -Mode Lisp. -Active les options 'lisp' et 'showmatch'. -.TP -\-m -Empêche la modification des fichiers. -Désactive l'option 'write'. -Vous pouvez toujours modifier le tampon, mais il vous sera impossible -d'écrire le fichier. -.TP -\-M -N'autorise aucune modification. les options 'modifiable' et 'write' sont -désactivées, de sorte que les changements ne sont pas autorisés et que les -fichiers ne peuvent pas être écrits. Note : ces options peuvent être activées -pour autoriser les modifications. -.TP -\-N -Mode Non-compatible. Désactive l'option 'compatible'. -Cela améliorera le comportement de -.B Vim -\, mais il sera moins conforme à celui de Vi, même s'il n'existe aucun -fichier ".vimrc". -.TP -\-n -N'utilise pas de fichier d'échange (swapfile). -Le recouvrement après un plantage sera impossible. -Utile pour éditer un fichier sur un support très lent (disquette par ex.). -Également activable avec ":set uc=0". -Il est possible de l'annuler avec ":set uc=200". -.TP -\-nb -Devient un serveur d'édition pour NetBeans. Consulter la documentation à ce -sujet pour davantage de détails. -.TP -\-o[N] -Ouvre N fenêtres les unes au-dessus des autres. -Quand N est omis, ouvre une fenêtre pour chaque fichier. -.TP -\-O[N] -Ouvre N fenêtres côte à côte. -Quand N est omis, ouvre une fenêtre pour chaque fichier fichier. -.TP -\-p[N] -Ouvre N onglets. -Quand N est omis, ouvre un onglet pour chaque fichier fichier. -.TP -\-R -Mode Lecture-Seule. -Active l'option 'readonly'. -Vous pouvez toujours éditer le tampon, mais il vous sera impossible de -d'écraser accidentellement un fichier. -Si vous voulez écraser un fichier, ajoutez un point d'exclamation à la commande -Ex, comme dans ":w!". -L'option \-R impose l'option \-n (voir ci-dessus). -L'option 'readonly' peut être désactivée avec ":set noro". -Voir ":help 'readonly'". -.TP -\-r -Donne la liste des fichiers d'échange, avec des informations pour les utiliser -à des fins de recouvrement. -.TP -\-r {file} -Mode Recouvrement. -Utilise le fichier d'échange pour récouvrer d'une session d'édition plantée. -Le fichier d'échange est un fichier avec le même nom que le fichier texte, -suivi du suffixe ".swp". -Voir ":help recovery". -.TP -\-s -Mode Silencieux. Disponible uniquement quand -.B Vim -est lancé en tant que "ex" ou quand l'option "\-e" a été spécifiée avant -l'option "\-s". -.TP -\-s {scriptEntrée} -Lit le fichier de script {scriptEntrée}. -Les caractères du fichier sont interprétés comme si vous les tapiez. -La commande ":source! {scriptEntrée}" donne le même résultat. -Si la fin du fichier est atteinte avant que l'éditeur quitte, les caractères -suivants sont lus depuis le clavier. -.TP -\-T {terminal} -Indique à -.B Vim -le nom du terminal utilisé. -Cela n'est requis que lorsque la détection automatique échoue. -Le {terminal} devrait être connu de -.B Vim -(intégré) ou défini dans le fichier termcap ou terminfo. -.TP -\-u {vimrc} -Utilise les commandes du fichier {vimrc} pour les initialisations. -Toutes les autres initialisations sont omises. -À utiliser pour éditer un type de fichiers particulier. -Cela permet aussi d'omettre toute initialisation en spécifiant le nom de -fichier "NONE". -Voir ":help initialization" dans Vim pour davantage de détails. -.TP -\-U {gvimrc} -Utilise les commandes du fichier {gvimrc} pour l'initialisation de l'IHM -graphique. -Toutes les autres initialisations graphiques sont omises. -Cela permet aussi d'omettre toute initialisation graphique en spécifiant le nom -de fichier "NONE". -Voir ":help gui\-init" dans Vim pour davantage de détails. -.TP -\-V[N] -Mode Verbeux. -Donne des messages à propos des fichiers sourcés, ainsi que sur la lecture -et les écritures dans le fichier viminfo. le nombre optionnel N précise la -valeur de l'option 'verbose' (10 par défaut). -.TP -\-v -Démarre -.B Vim -en mode Vi, comme si l'exécutable s'appelait "vi". Cela n'a d'effet que si -l'exécutable invoqué est "ex". -.TP -\-w {scriptSortie} -Tous les caractères que vous tapez sont enregistrés dans le fichier -{scriptSortie}, jusqu'à ce que vous quittiez -.B Vim. -C'est utile quand vous voulez créer un fichier de script à utiliser avec -"vim \-s" ou ":source!". -Si le fichier {scriptSortie} existe, les caractères sont ajoutés à la fin. -.TP -\-W {scriptSortie} -Comme \-w, mais un fichier existant sera écrasé. -.TP -\-x -Chiffre les fichiers lors de l'écriture. Une clé de chiffrement sera demandée. -.TP -\-X -Ne se connecte pas au serveur X. Accélère le temps de démarrage dans un -terminal, mais le titre de la fenêtre et le presse-papier seront inaccessibles. -.TP -\-y -Démarre -.B Vim -en mode Débutant (easy), comme si l'exécutable s'appelait "evim" ou "eview". -Donne à -.B Vim -un comportement plus proche des éditeurs « cliquez-tapez ». -.TP -\-Z -Mode restreint. Fonctionne comme si l'exécutable commençait par la lettre 'r'. -.TP -\-\- -Délimite la fin des options. -Les arguments qui suivent seront considérés comme des noms de fichiers. -Cela permet d'éditer des fichier débutant par un '\-'. -.TP -\-\-echo\-wid -IHM graphique GTK uniquement : retourne la Window ID sur stdout. -.TP -\-\-help -Donne un message d'aide et quitte, comme "\-h". -.TP -\-\-literal -Prend les arguments de noms de fichiers littéralement, sans étendre les -jokers. N'a aucun effet sur Unix, où le shell étend les jokers. -.TP -\-\-noplugin -Ne charge pas les greffons. Implicite avec \-u NONE. -.TP -\-\-remote -Se connecte à un serveur Vim et lui fait éditer les fichiers spécifiés dans -le reste des arguments. Si aucun serveur n'est trouvé, un avertissement est -émis et les fichiers sont édités dans le Vim courant. -.TP -\-\-remote\-expr {expr} -Se connecte à un serveur Vim, y évalue {expr} et affiche le résultat sur la -sortie standard (stdout). -.TP -\-\-remote\-send {touches} -Se connecte à un serveur Vim et y envoie {touches}. -.TP -\-\-remote\-silent -Comme \-\-remote, mais sans émettre d'avertissement si aucun serveur n'est -trouvé. -.TP -\-\-remote\-wait -Comme \-\-remote, mais Vim ne quitte pas tant que le fichier est en cours -d'édition. -.TP -\-\-remote\-wait\-silent -Comme \-\-remote\-wait, mais sans émettre d'avertissement si aucun serveur n'est -trouvé. -.TP -\-\-serverlist -Donne la liste des noms de tous les serveurs Vim disponibles. -.TP -\-\-servername {nom} -Utilise {nom} pour le nom de serveur. Ce nom est donné au Vim courant, à moins -qu'il ne soit utilisé avec un argument \-\-remote. Dans ce cas, il s'agit du nom -du serveur auquel se connecter. -.TP -\-\-socketid {id} -IHM graphique GTK+ uniquement : utilise le mécanisme GtkPlug pour faire -fonctionner gvim dans une autre fenêtre. -.TP -\-\-version -Affiche les informations sur la version puis quitte. -.SH AIDE EN LIGNE -Taper ":help" dans -.B Vim -pour commencer. -Taper ":help sujet" pour obtenir de l'aide sur un sujet précis. -Par exemple : ":help ZZ" pour consulter l'aide sur la commande "ZZ". -Utiliser <Tab> et CTRL\-D pour compléter les sujets (":help -cmdline\-completion"). -Des marqueurs sont inclus dans l'aide et vous permettent de sauter d'un endroit -à un autre (comme des liens hypertextes, voir ":help"). -L'ensemble des fichiers de la documentation peut être consulté de cette -façon, par exemple ":help syntax.txt". -.SH FICHIERS -.TP 15 -/usr/local/lib/vim/doc/*.txt -Les fichiers de la documentation de -.B Vim. -Utiliser ":help doc\-file\-list" pour obtenir la liste complète. -.TP -/usr/local/lib/vim/doc/tags -Le fichier des marqueurs utilisé pour trouver les informations dans les -fichiers de la documentation. -.TP -/usr/local/lib/vim/syntax/syntax.vim -Initialisation de la syntaxe pour l'ensemble du système. -.TP -/usr/local/lib/vim/syntax/*.vim -Fichiers de syntaxe pour différents langages. -.TP -/usr/local/lib/vim/vimrc -Initialisation de -.B Vim -pour l'ensemble du système. -.TP -~/.vimrc -Initialisation de -.B Vim -de votre compte utilisateur. -.TP -/usr/local/lib/vim/gvimrc -Initialisation de gvim pour l'ensemble du système. -.TP -~/.gvimrc -Initialisation de gvim pour votre compte utilisateur. -.TP -/usr/local/lib/vim/optwin.vim -Script utilisé pour la commande ":options", une manière pratique de consulter -et de modifier les options. -.TP -/usr/local/lib/vim/menu.vim -Initialisation des menus de gvim pour l'ensemble du système. -.TP -/usr/local/lib/vim/bugreport.vim -Script pour générer un rapport de bogue. Voir ":help bugs". -.TP -/usr/local/lib/vim/filetype.vim -Script pour détecter le type d'un fichier d'après son nom. -Voir ":help 'filetype'". -.TP -/usr/local/lib/vim/scripts.vim -Script pour détecter le type d'un fichier d'après son contenu. -Voir ":help 'filetype'". -.TP -/usr/local/lib/vim/print/*.ps -Fichiers utilisés pour l'impression PostScript. -.PP -Pour disposer d'informations récentes, consulter le site Internet de VIM : -.br -<URL:http://www.vim.org/> -.SH VOIR AUSSI -vimtutor(1) -.SH AUTEUR -La majeure partie de -.B Vim -a été écrite par Bram Moolenaar, avec l'aide de nombreux autres contributeurs. -Voir ":help credits" dans -.B Vim. -.br -.B Vim -est basé sur Stevie, réalisé par Tim Thompson, -Tony Andrews et G.R. (Fred) Walter. -Toutefois, pratiquement rien du code original ne subsiste. -.SH BOGUES -Probablement. -Voir ":help todo" pour consulter la liste des problèmes connus. -.PP -NOTE : Remarquez que bon nombre de points, qui pourraient être considérés comme -des bugs par certains, sont en fait dus à une reproduction trop fidèle -du comportement de Vi. Et si vous pensez que d'autres points sont des -bugs "parce que Vi le fait différemment", vous devriez jeter un oeil -attentif au fichier vi_diff.txt (ou taper ":help vi_diff.txt" dans Vim). -Regardez aussi les options 'compatible' et 'coptions'. -.SH TRADUCTION -Cette page de manuel a été traduite par Richard Hitier. -<richard.hitier@dial.oleane.com> 2000-08-07. -.br -Cette page de manuel a été mise à jour par David Blanchet. -<david.blanchet@free.fr> 2006-04-10. diff --git a/share/vim/vim72/doc/vim-it.1 b/share/vim/vim72/doc/vim-it.1 deleted file mode 100644 index 1a8967fd90..0000000000 --- a/share/vim/vim72/doc/vim-it.1 +++ /dev/null @@ -1,566 +0,0 @@ -.TH VIM 1 "22 febbraio 2002" -.SH NOME -vim \- VI Migliorato, un editor di testi per programmatori -.SH SINTASSI -.br -.B vim -[opzioni] [file ..] -.br -.B vim -[opzioni] \- -.br -.B vim -[opzioni] \-t tag -.br -.B vim -[opzioni] \-q [file_errori] -.PP -.br -.B ex -.br -.B view -.br -.B gvim -.B gview -.B evim -.B eview -.br -.B rvim -.B rview -.B rgvim -.B rgview -.SH DESCRIZIONE -.B Vim -Un editore di testi, compatibile con, e migliore di, Vi. -Può essere usato per editare qualsiasi file di testo. -Particolarmente utile per editare programmi. -.PP -Ci sono parecchi miglioramenti rispetto a Vi: undo multipli, -finestre e buffer multipli, evidenziazione sintattica, possibilità -di modificare la linea di comando, completamento nomi file, help -in linea, selezione testi in modalità visuale, etc.. -Vedere ":help vi_diff.txt" per un sommario delle differenze fra -.B Vim -e Vi. -.PP -Mentre usate -.B Vim -potete ricevere molto aiuto dal sistema di help online, col comando ":help". -Vedere qui sotto la sezione AIUTO ONLINE. -.PP -Quasi sempre -.B Vim -viene invocato, per modificare un file, col comando -.PP - vim file -.PP -Più in generale -.B Vim -viene invocato con: -.PP - vim [opzioni] [lista_file] -.PP -Se lista_file non è presente, l'editor inizia aprendo un buffer vuoto. -Altrimenti, una e una sola delle quattro maniere indicate qui sotto può -essere usata per scegliere uno o più file da modificare. -.TP 12 -file .. -Una lista di nomi di file. -Il primo di questi sarà il file corrente, e verrà letto nel buffer. -Il cursore sarà posizionato sulla prima linea del buffer. -Potete arrivare agli altri file col comando ":next". -Per editare un file il cui nome inizia per "\-" premettete "\-\-" alla -lista_file. -.TP -\- -Il file da editare è letto dallo "stdin" [di solito, ma non -necessriamente, il terminale \- NdT]. I comandi sono letti da "stderr", -che dovrebbe essere un terminale [tty]. -.TP -\-t {tag} -Il file da editare e la posizione iniziale del cursore dipendono da "tag", -una specie di "etichetta" a cui saltare. -{tag} viene cercata nel file tags, ed il file ad essa associato diventa -quello corrente, ed il comando ad essa associato viene eseguito. -Di solito si usa per programmi C, nel qual caso {tag} potrebbe essere un -nome di funzione. -L'effetto è che il file contenente quella funzione diventa il file corrente -e il cursore è posizionato all'inizio della funzione. -Vedere ":help tag-commands". -.TP -\-q [file_errori] -Inizia nella modalità quickFix [correzione veloce]. -Il file [file_errori] è letto e il primo errore è visualizzato. -Se [file_errori] non è indicato, il suo nome è ottenuto dal valore -dell'opzione 'errorfile' (che, se non specificata, vale "AztecC.Err" -per l'Amiga, "errors.err" su altri sistemi). -Si può saltare all'errore successivo col comando ":cn". -Vedere ":help quickfix". -.PP -.B Vim -si comporta in modo diverso se invocato con nomi differenti (il programma -eseguibile "sottostante" può essere sempre lo stesso). -.TP 10 -vim -Modalità "Normal", comportamento normale. -.TP -ex -Inizia in modalità "Ex". -Si può passare in modalità "Normal" col comandi ":vi". -Si può invocare la modalità "Ex" anche con l'argomento "\-e". -.TP -view -Inizia in modalità "Sola Lettura". Non potete modificare i file. -Si può invocare la modalità "Sola Lettura" anche con l'argomento "\-R". -.TP -gvim gview -La versione GUI [Graphical User Interface]. -Apre una nuova finestra. -Si può invocare la modalità "GUI" anche con l'argomento "\-g". -.TP -evim eview -La versione GUI in modalità "Facile" (semplificata). -Apre una nuova finestra. -Si può invocare la modalità "Facile" anche con l'argomento "\-y". -.TP -rvim rview rgvim rgview -Come sopra, ma con restrizioni ai comandi. Non si potrnno eseguire comandi -dello shell o sospendere -.B Vim. -Si può invocare la modalità "Ristretta" anche con l'argomento "\-Z". -.SH OPZIONI -Le opzioni possono essere in un ordine qualsiasi, prima o dopo i nomi di -file. Opzioni che non necessitano un argomento possono essere raggruppate -dietro a un solo "\-". -.TP 12 -+[numero] -Per il primo file il cursore sarà posizionato sulla linea "numero". -Se "numero" manca, il cursore sarà posizionato sull'ultima linea del file. -.TP -+/{espressione} -Per il primo file il cursore sarà posizionato alla -prima occorrenza di {espressione}. -Vedere ":help search-pattern" per come specificare l'espressione. -.TP -+{comando} -.TP -\-c {comando} -{comando} sarà eseguito dopo che il -primo file è stato letto. -{comando} è interpretato come un comando Ex. -Se il {comando} contiene spazi deve essere incluso fra doppi apici -(o altro delimitatore, a seconda dello shell che si sta usando). -Esempio: Vim "+set si" main.c -.br -Note: Si possono avere fino a 10 comandi "+" o "\-c". -.TP -\-S {file} -I comandi contenuti in {file} sono eseguiti dopo la lettura del primo file. -Equivalente a \-c "source {file}". -{file} non può avere un nome che inizia per '\-'. -Se {file} è omesso si usa "Session.vim" (funziona solo se \-S è l'ultimo -argomento specificato). -.TP -\-\-cmd {comando} -Come "\-c", ma il comando è eseguito PRIMA -di eseguire qualsiasi file vimrc. -Si possono usare fino a 10 di questi comandi, indipendentemente dai comandi -"\-c". -.TP -\-A -Se -.B Vim -è stato compilato con supporto ARABIC per editare file con orientamento -destra-sinistra e tastiera con mappatura Araba, questa opzione inizia -.B Vim -in modalità "Arabic", cioè impostando 'arabic'. -Altrimenti viene dato un messaggio di errore e -.B Vim -termina in modo anormale. -.TP -\-b -Modalità "Binaria". -Vengono impostate alcune opzioni che permettono di modificare un file -binario o un programma eseguibile. -.TP -\-C -Compatibile. Imposta l'opzione 'compatible'. -In questo modo -.B Vim -ha quasi lo stesso comportamento di Vi, anche in presenza di un file -di configurazione .vimrc [proprio di Vim \- NdT]. -.TP -\-d -Inizia in modalità "Diff" [differenze]. -Dovrebbero esserci come argomenti due o tre nomi di file. -.B Vim -aprirà tutti i file evidenziando le differenze fra gli stessi. -Funziona come vimdiff(1). -.TP -\-d {dispositivo} -Apre {dispositivo} per usarlo come terminale. -Solo per l'Amiga. -Esempio: -"\-d con:20/30/600/150". -.TP -\-D -Debugging. Vim si mette in modalità "debugging" a partire -dall'esecuzione del primo comando da uno script. -.TP -\-e -Eseguire -.B Vim -in modalità "Ex", come se il programma eseguito sia "ex". -.TP -\-E -Eseguire -.B Vim -in modalità "Ex" migliorata, come se il programma eseguito sia "exim". -.TP -\-f -Direttamente [Foreground]. Per la versione GUI, -.B Vim -non crea [fork] una nuova finestra, indipendente dallo shell di invocazione. -Per l'Amiga, -.B Vim -non è fatto ripartire per aprire una nuova finestra. -Opzione da usare quando -.B Vim -è eseguito da un programma che attende la fine della -sessione di edit (ad es. mail). -Sull'Amiga i comandi ":sh" e ":!" non sono disponibili. -.TP -\-\-nofork -Direttamente [Foreground]. Per la versione GUI, -.B Vim -non crea [fork] una nuova finestra, indipendente dallo shell di invocazione. -.TP -\-F -Se -.B Vim -è stato compilato con supporto FKMAP per editare file con orientamento -destra-sinistra e tastiera con mappatura Farsi, questa opzione inizia -.B Vim -in modalità "Farsi", cioè impostando 'fkmap' e 'rightleft'. -Altrimenti viene dato un messaggio di errore e -.B Vim -termina in modo anormale. -.TP -\-g -Se -.B Vim -è stato compilato con supporto GUI, questa opzione chiede di usarla. -Se Vim è stato compilato senza supporto GUI viene dato un messaggio di errore e -.B Vim -termina in modo anormale. -.TP -\-h -Un po' di aiuto su opzioni e argomenti che si possono dare invocando Vim. -Subito dopo -.B Vim -esce. -.TP -\-H -Se -.B Vim -è stato compilato col supporto RIGHTLEFT per editare file con orientamento -destra-sinistra e tastiera con mappatura Ebraica, questa opzione inizia -.B Vim -in modalità "Ebraica", cioè impostando 'hkmap' e 'rightleft'. -Altrimenti viene dato un messaggio di errore e -.B Vim -termina in modo anormale. -.TP -\-i {viminfo} -Se è abilitato l'uso di un file viminfo, questa opzione indica il nome -del file da usare invece di quello predefinito "~/.viminfo". -Si può anche evitare l'uso di un file .viminfo, dando come nome "NONE". -.TP -\-L -Equivalente a \-r. -.TP -\-l -Modalità Lisp. -Imposta le opzini 'lisp' e 'showmatch'. -.TP -\-m -Inibisce modifica file. -Annulla l'opzione 'write'. -E' ancora possibile modificare un buffer [in memoria \- Ndt], ma non scriverlo. -.TP -\-M -Modifiche non permesse. Le opzioni 'modifiable' e 'write' sono annullate, -in modo da impedire sia modifiche che riscritture. Da notare che queste -opzioni possono essere abilitate in seguito, permettendo così modifiche. -.TP -\-N -Modalità "Non-compatibile". Annulla l'opzione 'compatible'. -Così -.B Vim -va un po' meglio, ma è meno compatibile con Vi, anche in assenza di un -file .vimrc. -.TP -\-n -Inibisce l'uso di un file di swap. -Il recupero dopo una caduta di macchina diventa impossibile. -Utile per editare un file su un supporto molto lento (ad es. floppy). -Il comando ":set uc=0" ha lo stesso effetto. -Per abilitare il recupero usare ":set uc=200". -.TP -\-nb -Diviene un Editor server per NetBeans. Vedere la documentazione per dettagli. -.TP -\-o[N] -Apri N finestre in orizzontale. -Se N manca, apri una finestra per ciascun file. -.TP -\-O[N] -Apri N finestre, in verticale. -Se N manca, apri una finestra per ciascun file. -.TP -\-R -Modalità "Sola Lettura". -Imposta l'opzione 'readonly'. -Si può ancora modificare il buffer, ma siete protetti da una riscrittura -involontaria. -Se volete davvero riscrivere il file, aggiungete un punto esclamativo -al comando "Ex", come in ":w!". -L'opzione \-R implica anche l'opzione \-n (vedere sotto). -L'opzione 'readonly' può essere annullata con ":set noro". -Vedere ":help 'readonly'". -.TP -\-r -Lista file di swap, assieme a dati utili per un recupero. -.TP -\-r {file} -Modalità "Recovery". -Il file di swap è usato per recuperare una sessione di edit finita male. -Il file di swap è un file con lo stesso nome file del file di testo -editato, col suffisso ".swp". -Vedere ":help recovery". -.TP -\-s -Modalità silenziosa. Solo quando invocato come "Ex" o quando l'opzione -"\-e" è stata data prima dell'opzione "\-s". -.TP -\-s {scriptin} -Lo script file {scriptin} è letto. -I caratteri nel file sono interpretati come se immessi da voi. -Lo stesso si può ottenere col comando ":source! {scriptin}". -Se la fine del file di input viene raggiunta prima che Vim termini, -l'ulteriore input viene preso dalla tastiera. -.TP -\-T {terminale} -Dice a -.B Vim -quale tipo di terminale state usando. -Utile solo se il terminale non viene riconosciuto correttamente da Vim. -Dovrebbe essere un terminale noto a -.B Vim -(internamente) o definito nel file termcap o terminfo. -.TP -\-u {vimrc} -Usa i comandi nel file {vimrc} per inizializzazioni. -Tutte le altre inizializzazioni non sono eseguite. -Usate questa opzione per editare qualche file di tipo speciale. -Può anche essere usato per non fare alcuna inizializzazione dando -come nome "NONE". -Vedere ":help initialization" da vim per ulteriori dettagli. -.TP -\-U {gvimrc} -Usa i comandi nel file {gvimrc} per inizializzazioni GUI. -Tutte le altre inizializzazioni GUI non sono eseguite. -Può anche essere usata per non fare alcuna inizializzazione GUI dando -come nome "NONE". -Vedere ":help gui-init" da vim per ulteriori dettagli. -.TP -\-V[N] -Verboso. Vim manda messaggi relativi agli script file che esegue -e quando legge o scrive un file viminfo. Il numero opzionale N è il valore -dell'opzione 'verbose'. -Il valore predefinito è 10. -.TP -\-v -Inizia -.B Vim -in modalità "Vi", come se il programma eseguibile fosse "vi". Questo ha -effetto solo quando Vim viene invocato con il nome "ex". -.TP -\-w {scriptout} -Ogni carattere immesso viene registrato nel file {scriptout}, -finché non uscite da -.B Vim. -Utile se si vuole creare uno script file da usare con "vim \-s" o -":source!". -Se il file {scriptout} esiste, quel che immettete viene aggiunto in fondo. -.TP -\-W {scriptout} -Come \-w, ma uno script file esistente viene sovrascritto. -.TP -\-x -Uso di cifratura nella scrittura dei file. E' necessario immettere -una chiave di cifratura. -.TP -\-X -Non connetterti al server X. Vim parte più rapidamente, -ma il titolo della finestra e la clipboard non sono disponibili. -.TP -\-y -Eseguire -.B Vim -in modalità "Facile" (semplificata), come se l'eseguibile invocato -sia "evim" o "eview". -Fa sì che -.B Vim -si comporti come un editor che usa solo il mouse e i caratteri. -.TP -\-Z -Modalità "Ristretta". Vim si comporta come se invocato con un nome -che inizia per "r". -.TP -\-\- -Specifica la fine delle opzioni. -Argomenti specificati dopo questo sono considerati nomi file. -Si può usare per editare un file il cui nome inizi per '-'. -.TP -\-\-echo\-wid -Solo con GUI GTK: Visualizza Window ID su "stdout". -.TP -\-\-help -Vim dà un messaggio ed esce, come con l'argomento "-h". -.TP -\-\-literal -Considera i nomi passati come argomenti letterai, senza espandere -metacaratteri. Non necessario in Unix, lo shell espande i metacaratteri. -.TP -\-\-noplugin -Non caricare plugin. Implicito se si specifica \-u NONE. -.TP -\-\-remote -Connettersi a un server Vim e chiedere di editare i file elencati come altri -argomenti. Se non si trova un server viene dato un messaggio e i file sono -editati nel Vim corrente. -.TP -\-\-remote\-expr {expr} -Connettersi a un server Vim, valutare ivi {expr} e stampare il risultatoi -su "stdout". -.TP -\-\-remote\-send {chiavi} -Connettersi a un server Vim e spedirgli {chiavi}. -.TP -\-\-remote\-silent -Come \-\-remote, ma senza avvisare se non si trova un server. -.TP -\-\-remote-wait -Come \-\-remote, ma Vim non termina finché i file non sono stati editati. -.TP -\-\-remote\-wait\-silent -Come \-\-remote\-wait, ma senza avvisare se non si trova un server. -.TP -\-\-serverlist -Lista i nomi di tutti i server Vim disponibili. -.TP -\-\-servername {nome} -Usa {nome} come nome server. Usato per il Vim corrente, a meno che sia -usato con l'argomento \-\-remote, nel qual caso indica il server a cui -connettersi. -.TP -\-\-socketid {id} -Solo con GUI GTK: Usa il meccanismo GtkPlug per eseguire gvim in un'altra -finestra. -.TP -\-\-version -Stampa la versione di Vim ed esci. -.SH AIUTO ONLINE -Battere ":help" in -.B Vim -per iniziare. -Battere ":help argomento" per ricevere aiuto su uno specifico argomento. -Per esempio: ":help ZZ" per ricevere aiuto sul comando "ZZ". -Usare <Tab> e CTRL\-D per completare gli argomenti -(":help cmdline\-completion"). -Ci sono "tag" nei file di help per saltare da un argomento a un altro -(simili a legami ipertestuali, vedere ":help"). -Tutti i file di documentazione possono essere navigati così. Ad es.: -":help syntax.txt". -.SH FILE -.TP 15 -/usr/local/lib/vim/doc/*.txt -I file di documentazione di -.B Vim -. -Usate ":help doc\-file\-list" per avere la lista completa. -.TP -/usr/local/lib/vim/doc/tags -Il file di tags usato per trovare informazioni nei file di documentazione. -.TP -/usr/local/lib/vim/syntax/syntax.vim -Inizializzazioni sintattiche a livello di sistema. -.TP -/usr/local/lib/vim/syntax/*.vim -File di colorazione sintattica per vari linguaggi. -.TP -/usr/local/lib/vim/vimrc -Inizializzazioni -.B Vim -a livello di sistema. -.TP -~/.vimrc -Le vostre personali inizializzazioni di -.B Vim -. -.TP -/usr/local/lib/vim/gvimrc -Inizializzazioni gvim a livello di sistema. -.TP -~/.gvimrc -Le vostre personali inizializzazioni di gvim. -.TP -/usr/local/lib/vim/optwin.vim -Script Vim usato dal comando ":options", un modo semplice -per visualizzare e impostare opzioni. -.TP -/usr/local/lib/vim/menu.vim -Inzializzazioni del menu gvim a livello di sistema. -.TP -/usr/local/lib/vim/bugreport.vim -Script Vim per generare una segnalazione di errore. Vedere ":help bugs". -.TP -/usr/local/lib/vim/filetype.vim -Script Vim per determinare il tipo di un file a partire dal suo nome. -Vedere ":help 'filetype'". -.TP -/usr/local/lib/vim/scripts.vim -Script Vim per determinare il tipo di un file a partire dal suo contenuto. -Vedere ":help 'filetype'". -.TP -/usr/local/lib/vim/print/*.ps -File usati per stampa PostScript. -.PP -Per informazioni aggiornate [in inglese \- NdT] vedere la home page di Vim: -.br -<URL:http://www.vim.org/> -.SH VEDERE ANCHE -vimtutor(1) -.SH AUTORE -Buona parte di -.B Vim -è stato scritto da Bram Moolenaar, con molto aiuto da altri. -Vedere ":help credits" in -.B Vim. -.br -.B Vim -è basato su Stevie, scritto da: Tim Thompson, -Tony Andrews e G.R. (Fred) Walter. -In verità, poco o nulla è rimasto del loro codice originale. -.SH BACHI -Probabili. -Vedere ":help todo" per una lista di problemi noti. -.PP -Si noti che un certo numero di comportamenti che possono essere considerati -errori da qualcuno, sono in effetti causati da una riproduzione fin troppo -fedele del comportamento di Vi. -Se ritenete che altre cose siano errori "perché Vi si comporta diversamente", -date prima un'occhiata al file vi_diff.txt -(o battere :help vi_diff.txt da Vim). -Date anche un'occhiata alle opzioni 'compatible' e 'cpoptions. diff --git a/share/vim/vim72/doc/vim-it.UTF-8.1 b/share/vim/vim72/doc/vim-it.UTF-8.1 deleted file mode 100644 index a7ea5f99c6..0000000000 --- a/share/vim/vim72/doc/vim-it.UTF-8.1 +++ /dev/null @@ -1,566 +0,0 @@ -.TH VIM 1 "22 febbraio 2002" -.SH NOME -vim \- VI Migliorato, un editor di testi per programmatori -.SH SINTASSI -.br -.B vim -[opzioni] [file ..] -.br -.B vim -[opzioni] \- -.br -.B vim -[opzioni] \-t tag -.br -.B vim -[opzioni] \-q [file_errori] -.PP -.br -.B ex -.br -.B view -.br -.B gvim -.B gview -.B evim -.B eview -.br -.B rvim -.B rview -.B rgvim -.B rgview -.SH DESCRIZIONE -.B Vim -Un editore di testi, compatibile con, e migliore di, Vi. -Può essere usato per editare qualsiasi file di testo. -Particolarmente utile per editare programmi. -.PP -Ci sono parecchi miglioramenti rispetto a Vi: undo multipli, -finestre e buffer multipli, evidenziazione sintattica, possibilità -di modificare la linea di comando, completamento nomi file, help -in linea, selezione testi in modalità visuale, etc.. -Vedere ":help vi_diff.txt" per un sommario delle differenze fra -.B Vim -e Vi. -.PP -Mentre usate -.B Vim -potete ricevere molto aiuto dal sistema di help online, col comando ":help". -Vedere qui sotto la sezione AIUTO ONLINE. -.PP -Quasi sempre -.B Vim -viene invocato, per modificare un file, col comando -.PP - vim file -.PP -Più in generale -.B Vim -viene invocato con: -.PP - vim [opzioni] [lista_file] -.PP -Se lista_file non è presente, l'editor inizia aprendo un buffer vuoto. -Altrimenti, una e una sola delle quattro maniere indicate qui sotto può -essere usata per scegliere uno o più file da modificare. -.TP 12 -file .. -Una lista di nomi di file. -Il primo di questi sarà il file corrente, e verrà letto nel buffer. -Il cursore sarà posizionato sulla prima linea del buffer. -Potete arrivare agli altri file col comando ":next". -Per editare un file il cui nome inizia per "\-" premettete "\-\-" alla -lista_file. -.TP -\- -Il file da editare è letto dallo "stdin" [di solito, ma non -necessriamente, il terminale \- NdT]. I comandi sono letti da "stderr", -che dovrebbe essere un terminale [tty]. -.TP -\-t {tag} -Il file da editare e la posizione iniziale del cursore dipendono da "tag", -una specie di "etichetta" a cui saltare. -{tag} viene cercata nel file tags, ed il file ad essa associato diventa -quello corrente, ed il comando ad essa associato viene eseguito. -Di solito si usa per programmi C, nel qual caso {tag} potrebbe essere un -nome di funzione. -L'effetto è che il file contenente quella funzione diventa il file corrente -e il cursore è posizionato all'inizio della funzione. -Vedere ":help tag-commands". -.TP -\-q [file_errori] -Inizia nella modalità quickFix [correzione veloce]. -Il file [file_errori] è letto e il primo errore è visualizzato. -Se [file_errori] non è indicato, il suo nome è ottenuto dal valore -dell'opzione 'errorfile' (che, se non specificata, vale "AztecC.Err" -per l'Amiga, "errors.err" su altri sistemi). -Si può saltare all'errore successivo col comando ":cn". -Vedere ":help quickfix". -.PP -.B Vim -si comporta in modo diverso se invocato con nomi differenti (il programma -eseguibile "sottostante" può essere sempre lo stesso). -.TP 10 -vim -Modalità "Normal", comportamento normale. -.TP -ex -Inizia in modalità "Ex". -Si può passare in modalità "Normal" col comandi ":vi". -Si può invocare la modalità "Ex" anche con l'argomento "\-e". -.TP -view -Inizia in modalità "Sola Lettura". Non potete modificare i file. -Si può invocare la modalità "Sola Lettura" anche con l'argomento "\-R". -.TP -gvim gview -La versione GUI [Graphical User Interface]. -Apre una nuova finestra. -Si può invocare la modalità "GUI" anche con l'argomento "\-g". -.TP -evim eview -La versione GUI in modalità "Facile" (semplificata). -Apre una nuova finestra. -Si può invocare la modalità "Facile" anche con l'argomento "\-y". -.TP -rvim rview rgvim rgview -Come sopra, ma con restrizioni ai comandi. Non si potrnno eseguire comandi -dello shell o sospendere -.B Vim. -Si può invocare la modalità "Ristretta" anche con l'argomento "\-Z". -.SH OPZIONI -Le opzioni possono essere in un ordine qualsiasi, prima o dopo i nomi di -file. Opzioni che non necessitano un argomento possono essere raggruppate -dietro a un solo "\-". -.TP 12 -+[numero] -Per il primo file il cursore sarà posizionato sulla linea "numero". -Se "numero" manca, il cursore sarà posizionato sull'ultima linea del file. -.TP -+/{espressione} -Per il primo file il cursore sarà posizionato alla -prima occorrenza di {espressione}. -Vedere ":help search-pattern" per come specificare l'espressione. -.TP -+{comando} -.TP -\-c {comando} -{comando} sarà eseguito dopo che il -primo file è stato letto. -{comando} è interpretato come un comando Ex. -Se il {comando} contiene spazi deve essere incluso fra doppi apici -(o altro delimitatore, a seconda dello shell che si sta usando). -Esempio: Vim "+set si" main.c -.br -Note: Si possono avere fino a 10 comandi "+" o "\-c". -.TP -\-S {file} -I comandi contenuti in {file} sono eseguiti dopo la lettura del primo file. -Equivalente a \-c "source {file}". -{file} non può avere un nome che inizia per '\-'. -Se {file} è omesso si usa "Session.vim" (funziona solo se \-S è l'ultimo -argomento specificato). -.TP -\-\-cmd {comando} -Come "\-c", ma il comando è eseguito PRIMA -di eseguire qualsiasi file vimrc. -Si possono usare fino a 10 di questi comandi, indipendentemente dai comandi -"\-c". -.TP -\-A -Se -.B Vim -è stato compilato con supporto ARABIC per editare file con orientamento -destra-sinistra e tastiera con mappatura Araba, questa opzione inizia -.B Vim -in modalità "Arabic", cioè impostando 'arabic'. -Altrimenti viene dato un messaggio di errore e -.B Vim -termina in modo anormale. -.TP -\-b -Modalità "Binaria". -Vengono impostate alcune opzioni che permettono di modificare un file -binario o un programma eseguibile. -.TP -\-C -Compatibile. Imposta l'opzione 'compatible'. -In questo modo -.B Vim -ha quasi lo stesso comportamento di Vi, anche in presenza di un file -di configurazione .vimrc [proprio di Vim \- NdT]. -.TP -\-d -Inizia in modalità "Diff" [differenze]. -Dovrebbero esserci come argomenti due o tre nomi di file. -.B Vim -aprirà tutti i file evidenziando le differenze fra gli stessi. -Funziona come vimdiff(1). -.TP -\-d {dispositivo} -Apre {dispositivo} per usarlo come terminale. -Solo per l'Amiga. -Esempio: -"\-d con:20/30/600/150". -.TP -\-D -Debugging. Vim si mette in modalità "debugging" a partire -dall'esecuzione del primo comando da uno script. -.TP -\-e -Eseguire -.B Vim -in modalità "Ex", come se il programma eseguito sia "ex". -.TP -\-E -Eseguire -.B Vim -in modalità "Ex" migliorata, come se il programma eseguito sia "exim". -.TP -\-f -Direttamente [Foreground]. Per la versione GUI, -.B Vim -non crea [fork] una nuova finestra, indipendente dallo shell di invocazione. -Per l'Amiga, -.B Vim -non è fatto ripartire per aprire una nuova finestra. -Opzione da usare quando -.B Vim -è eseguito da un programma che attende la fine della -sessione di edit (ad es. mail). -Sull'Amiga i comandi ":sh" e ":!" non sono disponibili. -.TP -\-\-nofork -Direttamente [Foreground]. Per la versione GUI, -.B Vim -non crea [fork] una nuova finestra, indipendente dallo shell di invocazione. -.TP -\-F -Se -.B Vim -è stato compilato con supporto FKMAP per editare file con orientamento -destra-sinistra e tastiera con mappatura Farsi, questa opzione inizia -.B Vim -in modalità "Farsi", cioè impostando 'fkmap' e 'rightleft'. -Altrimenti viene dato un messaggio di errore e -.B Vim -termina in modo anormale. -.TP -\-g -Se -.B Vim -è stato compilato con supporto GUI, questa opzione chiede di usarla. -Se Vim è stato compilato senza supporto GUI viene dato un messaggio di errore e -.B Vim -termina in modo anormale. -.TP -\-h -Un po' di aiuto su opzioni e argomenti che si possono dare invocando Vim. -Subito dopo -.B Vim -esce. -.TP -\-H -Se -.B Vim -è stato compilato col supporto RIGHTLEFT per editare file con orientamento -destra-sinistra e tastiera con mappatura Ebraica, questa opzione inizia -.B Vim -in modalità "Ebraica", cioè impostando 'hkmap' e 'rightleft'. -Altrimenti viene dato un messaggio di errore e -.B Vim -termina in modo anormale. -.TP -\-i {viminfo} -Se è abilitato l'uso di un file viminfo, questa opzione indica il nome -del file da usare invece di quello predefinito "~/.viminfo". -Si può anche evitare l'uso di un file .viminfo, dando come nome "NONE". -.TP -\-L -Equivalente a \-r. -.TP -\-l -Modalità Lisp. -Imposta le opzini 'lisp' e 'showmatch'. -.TP -\-m -Inibisce modifica file. -Annulla l'opzione 'write'. -E' ancora possibile modificare un buffer [in memoria \- Ndt], ma non scriverlo. -.TP -\-M -Modifiche non permesse. Le opzioni 'modifiable' e 'write' sono annullate, -in modo da impedire sia modifiche che riscritture. Da notare che queste -opzioni possono essere abilitate in seguito, permettendo così modifiche. -.TP -\-N -Modalità "Non-compatibile". Annulla l'opzione 'compatible'. -Così -.B Vim -va un po' meglio, ma è meno compatibile con Vi, anche in assenza di un -file .vimrc. -.TP -\-n -Inibisce l'uso di un file di swap. -Il recupero dopo una caduta di macchina diventa impossibile. -Utile per editare un file su un supporto molto lento (ad es. floppy). -Il comando ":set uc=0" ha lo stesso effetto. -Per abilitare il recupero usare ":set uc=200". -.TP -\-nb -Diviene un Editor server per NetBeans. Vedere la documentazione per dettagli. -.TP -\-o[N] -Apri N finestre in orizzontale. -Se N manca, apri una finestra per ciascun file. -.TP -\-O[N] -Apri N finestre, in verticale. -Se N manca, apri una finestra per ciascun file. -.TP -\-R -Modalità "Sola Lettura". -Imposta l'opzione 'readonly'. -Si può ancora modificare il buffer, ma siete protetti da una riscrittura -involontaria. -Se volete davvero riscrivere il file, aggiungete un punto esclamativo -al comando "Ex", come in ":w!". -L'opzione \-R implica anche l'opzione \-n (vedere sotto). -L'opzione 'readonly' può essere annullata con ":set noro". -Vedere ":help 'readonly'". -.TP -\-r -Lista file di swap, assieme a dati utili per un recupero. -.TP -\-r {file} -Modalità "Recovery". -Il file di swap è usato per recuperare una sessione di edit finita male. -Il file di swap è un file con lo stesso nome file del file di testo -editato, col suffisso ".swp". -Vedere ":help recovery". -.TP -\-s -Modalità silenziosa. Solo quando invocato come "Ex" o quando l'opzione -"\-e" è stata data prima dell'opzione "\-s". -.TP -\-s {scriptin} -Lo script file {scriptin} è letto. -I caratteri nel file sono interpretati come se immessi da voi. -Lo stesso si può ottenere col comando ":source! {scriptin}". -Se la fine del file di input viene raggiunta prima che Vim termini, -l'ulteriore input viene preso dalla tastiera. -.TP -\-T {terminale} -Dice a -.B Vim -quale tipo di terminale state usando. -Utile solo se il terminale non viene riconosciuto correttamente da Vim. -Dovrebbe essere un terminale noto a -.B Vim -(internamente) o definito nel file termcap o terminfo. -.TP -\-u {vimrc} -Usa i comandi nel file {vimrc} per inizializzazioni. -Tutte le altre inizializzazioni non sono eseguite. -Usate questa opzione per editare qualche file di tipo speciale. -Può anche essere usato per non fare alcuna inizializzazione dando -come nome "NONE". -Vedere ":help initialization" da vim per ulteriori dettagli. -.TP -\-U {gvimrc} -Usa i comandi nel file {gvimrc} per inizializzazioni GUI. -Tutte le altre inizializzazioni GUI non sono eseguite. -Può anche essere usata per non fare alcuna inizializzazione GUI dando -come nome "NONE". -Vedere ":help gui-init" da vim per ulteriori dettagli. -.TP -\-V[N] -Verboso. Vim manda messaggi relativi agli script file che esegue -e quando legge o scrive un file viminfo. Il numero opzionale N è il valore -dell'opzione 'verbose'. -Il valore predefinito è 10. -.TP -\-v -Inizia -.B Vim -in modalità "Vi", come se il programma eseguibile fosse "vi". Questo ha -effetto solo quando Vim viene invocato con il nome "ex". -.TP -\-w {scriptout} -Ogni carattere immesso viene registrato nel file {scriptout}, -finché non uscite da -.B Vim. -Utile se si vuole creare uno script file da usare con "vim \-s" o -":source!". -Se il file {scriptout} esiste, quel che immettete viene aggiunto in fondo. -.TP -\-W {scriptout} -Come \-w, ma uno script file esistente viene sovrascritto. -.TP -\-x -Uso di cifratura nella scrittura dei file. E' necessario immettere -una chiave di cifratura. -.TP -\-X -Non connetterti al server X. Vim parte più rapidamente, -ma il titolo della finestra e la clipboard non sono disponibili. -.TP -\-y -Eseguire -.B Vim -in modalità "Facile" (semplificata), come se l'eseguibile invocato -sia "evim" o "eview". -Fa sì che -.B Vim -si comporti come un editor che usa solo il mouse e i caratteri. -.TP -\-Z -Modalità "Ristretta". Vim si comporta come se invocato con un nome -che inizia per "r". -.TP -\-\- -Specifica la fine delle opzioni. -Argomenti specificati dopo questo sono considerati nomi file. -Si può usare per editare un file il cui nome inizi per '-'. -.TP -\-\-echo\-wid -Solo con GUI GTK: Visualizza Window ID su "stdout". -.TP -\-\-help -Vim dà un messaggio ed esce, come con l'argomento "-h". -.TP -\-\-literal -Considera i nomi passati come argomenti letterai, senza espandere -metacaratteri. Non necessario in Unix, lo shell espande i metacaratteri. -.TP -\-\-noplugin -Non caricare plugin. Implicito se si specifica \-u NONE. -.TP -\-\-remote -Connettersi a un server Vim e chiedere di editare i file elencati come altri -argomenti. Se non si trova un server viene dato un messaggio e i file sono -editati nel Vim corrente. -.TP -\-\-remote\-expr {expr} -Connettersi a un server Vim, valutare ivi {expr} e stampare il risultatoi -su "stdout". -.TP -\-\-remote\-send {chiavi} -Connettersi a un server Vim e spedirgli {chiavi}. -.TP -\-\-remote\-silent -Come \-\-remote, ma senza avvisare se non si trova un server. -.TP -\-\-remote-wait -Come \-\-remote, ma Vim non termina finché i file non sono stati editati. -.TP -\-\-remote\-wait\-silent -Come \-\-remote\-wait, ma senza avvisare se non si trova un server. -.TP -\-\-serverlist -Lista i nomi di tutti i server Vim disponibili. -.TP -\-\-servername {nome} -Usa {nome} come nome server. Usato per il Vim corrente, a meno che sia -usato con l'argomento \-\-remote, nel qual caso indica il server a cui -connettersi. -.TP -\-\-socketid {id} -Solo con GUI GTK: Usa il meccanismo GtkPlug per eseguire gvim in un'altra -finestra. -.TP -\-\-version -Stampa la versione di Vim ed esci. -.SH AIUTO ONLINE -Battere ":help" in -.B Vim -per iniziare. -Battere ":help argomento" per ricevere aiuto su uno specifico argomento. -Per esempio: ":help ZZ" per ricevere aiuto sul comando "ZZ". -Usare <Tab> e CTRL\-D per completare gli argomenti -(":help cmdline\-completion"). -Ci sono "tag" nei file di help per saltare da un argomento a un altro -(simili a legami ipertestuali, vedere ":help"). -Tutti i file di documentazione possono essere navigati così. Ad es.: -":help syntax.txt". -.SH FILE -.TP 15 -/usr/local/lib/vim/doc/*.txt -I file di documentazione di -.B Vim -. -Usate ":help doc\-file\-list" per avere la lista completa. -.TP -/usr/local/lib/vim/doc/tags -Il file di tags usato per trovare informazioni nei file di documentazione. -.TP -/usr/local/lib/vim/syntax/syntax.vim -Inizializzazioni sintattiche a livello di sistema. -.TP -/usr/local/lib/vim/syntax/*.vim -File di colorazione sintattica per vari linguaggi. -.TP -/usr/local/lib/vim/vimrc -Inizializzazioni -.B Vim -a livello di sistema. -.TP -~/.vimrc -Le vostre personali inizializzazioni di -.B Vim -. -.TP -/usr/local/lib/vim/gvimrc -Inizializzazioni gvim a livello di sistema. -.TP -~/.gvimrc -Le vostre personali inizializzazioni di gvim. -.TP -/usr/local/lib/vim/optwin.vim -Script Vim usato dal comando ":options", un modo semplice -per visualizzare e impostare opzioni. -.TP -/usr/local/lib/vim/menu.vim -Inzializzazioni del menu gvim a livello di sistema. -.TP -/usr/local/lib/vim/bugreport.vim -Script Vim per generare una segnalazione di errore. Vedere ":help bugs". -.TP -/usr/local/lib/vim/filetype.vim -Script Vim per determinare il tipo di un file a partire dal suo nome. -Vedere ":help 'filetype'". -.TP -/usr/local/lib/vim/scripts.vim -Script Vim per determinare il tipo di un file a partire dal suo contenuto. -Vedere ":help 'filetype'". -.TP -/usr/local/lib/vim/print/*.ps -File usati per stampa PostScript. -.PP -Per informazioni aggiornate [in inglese \- NdT] vedere la home page di Vim: -.br -<URL:http://www.vim.org/> -.SH VEDERE ANCHE -vimtutor(1) -.SH AUTORE -Buona parte di -.B Vim -è stato scritto da Bram Moolenaar, con molto aiuto da altri. -Vedere ":help credits" in -.B Vim. -.br -.B Vim -è basato su Stevie, scritto da: Tim Thompson, -Tony Andrews e G.R. (Fred) Walter. -In verità, poco o nulla è rimasto del loro codice originale. -.SH BACHI -Probabili. -Vedere ":help todo" per una lista di problemi noti. -.PP -Si noti che un certo numero di comportamenti che possono essere considerati -errori da qualcuno, sono in effetti causati da una riproduzione fin troppo -fedele del comportamento di Vi. -Se ritenete che altre cose siano errori "perché Vi si comporta diversamente", -date prima un'occhiata al file vi_diff.txt -(o battere :help vi_diff.txt da Vim). -Date anche un'occhiata alle opzioni 'compatible' e 'cpoptions. diff --git a/share/vim/vim72/doc/vim-pl.1 b/share/vim/vim72/doc/vim-pl.1 deleted file mode 100644 index 3fa34e2991..0000000000 --- a/share/vim/vim72/doc/vim-pl.1 +++ /dev/null @@ -1,555 +0,0 @@ -.TH VIM 1 "2002 Lut 22" -.SH NAME -vim \- Vi rozbudowany, edytor tekstu dla programisty -.SH SYNOPSIS -.br -.B vim -[opcje] [plik ..] -.br -.B vim -[opcje] \- -.br -.B vim -[opcje] \-t znacznik -.br -.B vim -[opcje] \-q [plik b³êdu] -.PP -.br -.B ex -.br -.B view -.br -.B gvim -.B gview -.B evim -.B eview -.br -.B rvim -.B rview -.B rgvim -.B rgview -.SH OPIS -.B Vim -jest edytorem tekstu kompatybilnym z Vi. Mo¿e byæ -u¿ywany do edycji wszelkiego rodzaju plików tekstowych. -U¿yteczny zw³aszcza przy edycji programów. -.PP -Posiada wiele usprawnieñ w porównaniu z Vi: wielo poziomowe cofanie zmian, -wiele okien i buforów, pod¶wietlanie sk³adni, edycja linii poleceñ, -uzupe³nianie nazw plików, pomoc on-line, wizualna selekcja, itd. -Zobacz ":help vi_diff.txt" dla podsumowania ró¿niæ pomiêdzy -.B Vimem -i Vi. -.PP -W czasie korzystania z -.B Vima -mo¿na uzyskaæ obszern± pomoc z systemu pomocy on-line dziêki poleceniu ":help". -Zobacz rozdzia³ POMOC ON-LINE poni¿ej. -.PP -Najczê¶ciej -.B Vim -jest uruchamiany do edycji pojedynczego pliku poleceniem -.PP - vim plik -.PP -Bardziej ogólnie -.B Vim -jest uruchamiany poprzez: -.PP - vim [opcje] [lista plików] -.PP -Je¶li brak listy plików edytor rozpocznie z pustym buforem. W innym -wypadku istnieje dok³adnie jedna z czterech mo¿liwo¶ci by wybraæ jeden -lub wiêcej plików do edycji. -.TP 12 -plik .. -Lista nazw plików. -Pierwsza nazwa bêdzie nazw± bie¿±cego pliku, który zostanie wczytany -do bufora. Kursor zostanie umieszczony w pierwszym wierszu. Do -kolejnych plików mo¿na przej¶æ dziêki poleceniu ":next". By otworzyæ -plik, którego nazwa zaczyna siê od my¶lnika nale¿y listê plików -poprzedziæ "\-\-". -.TP -\- -Plik do edycji jest wczytany ze standardowego wej¶cia. Polecenia s± -odczytywane ze standardowego wyj¶cia b³êdów, którym powinien byæ -terminal (tty). -.TP -\-t {znacznik} -Plik do edycji i pocz±tkowa pozycja kursora zale¿y od "znacznika", -rodzaju etykiety goto. -{znacznika} szuka siê w pliku tags, zwi±zany z nim plik staje siê -plikiem bie¿±cym i wykonuje siê powi±zane polecenie. -Zazwyczaj u¿ywa siê tego sposobu dla programów w C, w których wypadku -{znacznik} powinien byæ nazw± funkcji. -W efekcie plik zawieraj±cy okre¶lon± funkcjê staje siê plikiem -bie¿±cym a kursor jest umieszczony na pocz±tku funkcji. -Zobacz ":help tag-commands". -.TP -\-q [plik_b³êdów] -Zacznij w trybie quickFix. -Plik [plik_b³êdów] zostaje zinterpretowany i poka¿e siê pierwszy b³±d. -Je¶li brak opcji [plik_b³êdów] nazwa pliku zostanie pobrana z opcji -'errorfile' (domy¶lnie "AztecC.Err" dla Amigi, "errros.err" dla innych -systemów. -Do kolejnych b³êdów mo¿na przeskoczyæ dziêki poleceniu ":cn". -Zobacz ":help quickfix". -.PP -W zale¿no¶ci od wywo³ania -.B Vim -zachowuje siê inaczej (program mo¿e byæ ca³y czas tym samym -plikiem). -.TP 10 -vim -"Normalny" sposób, wszystko jest domy¶lne. -.TP -ex -Zacznij w trybie Ex. -Przejd¼ do trybu Normalnego poleceniem ":vi". -Mo¿na tak¿e uruchomiæ poprzez argument "\-e". -.TP -view -Zacznij w trybie tylko do odczytu. W ten sposób bêdziesz chroniony -przed zapisywaniem pliku. Mo¿na tak¿e uruchomiæ poprzez argument -"\-R". -.TP -gvim gview -Wersja GUI. -Uruchamia nowe okno. -Mo¿na tak¿e uruchomiæ poprzez argument "\-g". -.TP -evim eview -Wersja GUI w ³atwym trybie. -Uruchamia nowe okno. -Mo¿na tak¿e uruchomiæ poprzez argument "\-y". -.TP -rvim rview rgvim rgview -Podobnie jak powy¿ej, ale z ograniczeniami. Nie bêdzie mo¿na uruchomiæ -poleceñ pow³oki lub zawiesiæ -.B Vima. -Mo¿na tak¿e uruchomiæ poprzez argument "\-Z". -.SH OPCJE -Opcje mo¿na podaæ w dowolnej kolejno¶ci, przed lub po nazwach plików. -Opcje bez argumentów mo¿na ³±czyæ po pojedynczym my¶lniku. -.TP 12 -+[num] -W pierwszym pliku kursor zostanie umieszczony w wierszu "num". -Je¶li brak "num" kursor zostanie umieszczony w ostatnim wierszu. -.TP -+/{wzór} -W pierwszym pliku kursor zostanie umieszczony na pierwszym wyst±pieniu -{wzór}. -Zobacz ":help search-pattern" by dowiedzieæ siê jakie s± mo¿liwo¶ci -wzorów wyszukiwania. -.TP -+{polecenie} -.TP -\-c {polecenie} -{polecenie} zostanie wykonane po tym jak wczyta siê pierwszy plik. -{polecenie} jest interpretowane jako polecenie Ex. -Je¶li {poleceni} zawiera bia³e znaki musi byæ umieszczone w podwójnych -cudzys³owach (zale¿y to od u¿ywanej pow³oki). -Przyk³ad: Vim "+set si" main.c -.br -Uwaga: Mo¿na u¿yæ do 10 poleceñ "+" lub "\-c". -.TP -\-S {plik} -{plik} zostanie zinterpretowany po wczytaniu pierwszego pliku. -Jest równowa¿ne \-c "source {plik}". -{plik} nie mo¿e zaczynaæ siê '\-'. -Je¶li nie podano {plik} zostanie u¿yty "Session.vim" (dzia³a tylko -wtedy je¶li \-S jest ostatnim argumentem). -.TP -\-\-cmd {polecenie} -Podobne do "\-c", ale polecenie jest wykonywane tu¿ przed -interpretacj± jakiegokolwiek pliku vimrc. -Mo¿na u¿yæ do 10 takich poleceñ, niezale¿ni od poleceñ od "\-c" -.TP -\-A -Je¶li -.B Vim -zosta³ skompilowany ze wsparciem dla jêzyków arabskich (edycja od -prawej do lewej i arabska mapa klawiatury) ta opcja uruchamia -.B Vima -w trybie arabskim, np. ustawia siê opcja 'arabic'. W innym wypadku -pojawi siê komunikat b³êdu i -.B Vim -zakoñczy dzia³anie. -.TP -\-b -Tryb binarny. -Ustawi siê kilka opcji, które umo¿liwi± edycjê plików binarnych lub -wykonywalnych. -.TP -\-C -Kompatybilny. Ustawia opcjê 'compatible'. -W ten sposób -.B Vim -bêdzie zachowywa³ siê jak Vi, nawet je¶li istnieje plik .vimrc. -.TP -\-d -Uruchom w trybie diff. -Powinno byæ dwa lub trzy nazwy plików jako argumenty. -.B Vim -otworzy wszystkie te pliki i poka¿e ró¿nice miêdzy nimi. -Dzia³a jak vimdiff(1). -.TP -\-d {urz±dzenie} -Otwórz {urz±dzenie} by u¿ywaæ jako terminal. -Tylko na Amidze. -Przyk³ad: -"\-d con:20/30/600/150". -.TP -\-D -Debugowanie. Przejd¼ do trybu debugowanie wykonuj±c pierwsze polecenie -ze skryptu. -.TP -\-e -Uruchom -.B Vima -w trybie Ex, dzia³a tak samo jakby wywo³ano program jako "ex". -.TP -\-E -Uruchom -.B Vima -w ulepszonym trybie Ex, dzia³a tak samo jakby wywo³ano program jako -"exim". -.TP -\-f -Pierszy plan. Dla wersji GUI. -.B Vim -nie nie oddzieli siê od pow³oki w jakiej zosta³ uruchomiony. Na Amidze -.B Vim -nie jest uruchomiony ponownie by otworzyæ nowe okno. -Opcja powinna byæ u¿yta kiedy -.B Vim -jest wywo³ywany przez program, który ma zaczekaæ na koniec sesji (np. -mail). -Na Amidze polecenia ":sh" i ":!" nie bêd± dzia³aæ. -.TP -\-\-nofork -Pierwszy plan. Dla wersji GUI. -.B Vim -nie oddzieli siê od pow³oki w jakiej zosta³ uruchomiony. -.TP -\-F -Je¶li Vim zosta³ skompilowany ze wsparciem FKMAP dla edycji tekstów od -prawej do lewej i mapowania klawiatury Farsi, ta opcja uruchomi -.B Vima -w trybie Farsi, np. zostawi± ustawione opcje 'fkmap' i 'rightleft'. -W innym wypadku pojawi siê komunikat b³êdu i -.B Vim -zakoñczy dzia³anie. -.TP -\-g -Je¶li -.B Vim -zosta³ skompilowany ze wsparciem dla GUI ta opcja uruchomi GUI. -W innym wypadku pojawi siê komunikat b³êdu i -.B Vim -zakoñczy dzia³anie. -.TP -\-h -Wy¶wietli krótk± pomoc o argumentach linii poleceñ i opcjach. Potem -.B Vim -zakoñczy dzia³anie. -.TP -\-H -Je¶li -.B Vim -zosta³ skompilowany ze wsparciem RIGHTLEFT dla edycji od prawej do -lewej oraz ma mapowanie klawiatury dla hebrajskiego, ta opcja uruchomi -.B Vima -w trybie hebrajskim, np. ustawi opcje 'hkmap' i 'rightleft'. -W innym wypadku pojawi siê komunikat b³êdu i -.B Vim -zakoñczy dzia³anie. -.TP -\-i {viminfo} -Kiedy -.B Vim -u¿ywa pliku viminfo ta opcja wska¿e jakiego pliku u¿yæ zamiast -domy¶lnego "~/.viminfo". -Mo¿na te¿ omin±æ u¿ycie pliku .viminfo przez podanie nazwy "NONE". -.TP -\-L -To samo co \-r. -.TP -\-l -Tryb Lisp. -Ustawia opcje 'lisp' i 'showmatch'. -.TP -\-m -Zmiana pliku jest niemo¿liwa. -Przestawia opcjê 'write'. -Mo¿na ca³y czas zmieniæ zawarto¶æ bufora, ale zapisanie pliku nie jest -mo¿liwa. -.TP -\-M -Opcje 'modifiable' i 'write' zostan± wy³±czone, tak wiêc zmiany -w pliku oraz ich zapisanie nie s± mo¿liwe. Mo¿na warto¶æ tych opcji -zmieniæ. -.TP -\-N -Tryb niekompatibylny. Przestawia opcjê 'compatible'. Dziêki temu -.B Vim -bêdzie zachowywa³ siê odrobinê lepiej, ale mniej zgodznie z Vi nawet -je¶li nie istnieje plik .vimrc. -.TP -\-n -Nie powstanie plik wymiany. Odzyskanie pliku po wypadku nie bêdzie -mo¿liwe. -Wygodne je¶li instnieje potrzeba edycji na bardzo wolnym medium (np. -dyskietce). Ten cel mo¿na osi±gn±æ tak¿e przez ":set uc=0". Mo¿na -odwróciæ przez ":set uc=200". -.TP -\-nb -Uruchom jako serwer edytora dla NetBeans. Zobacz dokumentacjê by -dowiedzieæ siê wiêcej. -.TP -\-o[N] -Otwórz N okien w stosie. -Kiedy brak N, otwórz jedno okno dla ka¿dego pliku. -.TP -\-O[N] -Otwórz N okien obok siebie. -Kiedy brak N, otwórz jedno okno dla ka¿dego pliku. -.TP -\-p[N] -Otwórz N kart. -Kiedy brak N, otwórz jedn± kartê dla ka¿dego pliku. -.TP -\-R -Tryb tylko do odczytu. -Zostanie ustawiona opcja 'readonly'. -Ca³y czas mo¿na zmieniaæ bufor, ale bêdzie istnia³a blokada przed przypadkowym -zapisaniem pliku. -Je¶li chcesz zapisaæ plik dodaj wykrzyknik do polecenia Ex, np. ":w!". -Opcja \-R implikuje opcjê \-n (zobacz poni¿ej). -Opcja 'readonly' mo¿e zostaæ przestawiona poprzez ":set noro". -Zobacz ":help 'readonly'". -.TP -\-r -Wypisz listê plików wymiany razem z informacjami o nich. -.TP -\-r {plik} -Tryb odzyskiwania danych. -Plik wymiany zostanie wykorzystany do odzyskania gwa³townie przerwanej sesji. -Plik wymiany to plik z tak± sam± nazw± co plik oryginalny z dodanym ".swp". -Zobacz ":help recovery". -.TP -\-s -Tryb cichy. Rozpoczêty tylko kiedy uruchomiony jako "Ex" lub opcja -"\-e" zosta³a podana przed opcj± "\-s". -.TP -\-s {skrypt} -Zostanie wczytany plik {skrypt}. -Znaki w pliku zostan± zinterpretowane jakby by³y wpisywane. -To samo mo¿na osi±gn±æ poprzez polecenie ":source! {skrypt}". -Je¶li osi±gniêto koniec pliku zanim edytor zakoñczy³ dzia³anie, dalsze -znaki odczytywane s± z klawiatury. -.TP -\-T {terminal} -Przekazuje -.B Vimowi -nazwê terminalu jakiego u¿ywasz. -Wymagane tylko wtedy je¶li nie dzia³a automatycznie. -Powinien byæ to terminal znany -.B Vimowi -(builtin) lub zdefiniowany w plikach termcap lub terminfo. -.TP -\-u {vimrc} -U¿yj poleceñ z pliku {vimrc} w czasie uruchamiania. -Wszystkie inne mo¿liwe pliki uruchamiania zostan± pominiête. -U¿ywaj do edytowania plików specjalnych. -Mo¿na pomin±æ tak¿e wszystkie mo¿liwe pliki uruchamiania poprzez -podanie nazwy "NONE". -Zobacz ":help initialization" by poznaæ wiêcej szczegó³ów. -.TP -\-U {gvimrc} -U¿yj poleceñ z pliku {gvimrc} w czasie uruchamiania GUI. -Wszystkie inne mo¿liwe pliki uruchamiania GUI zostan± pominiête. -Mo¿na pomin±æ tak¿e wszystkie mo¿liwe pliki uruchamiania GUI poprzez -podanie nazwy "NONE". -Zobacz ":help gui-init" by poznaæ wiêcej szczegó³ów. -.TP -\-V[N] -Tryb gadatliwy. Wypisz wiadomo¶ci o tym jaki pliki s± wczytywane -i o informacjach pobieranych i dodawanych do pliku viminfo. Opcjonalny -argument N jest warto¶ci± 'verbose'. Domy¶lnie 10. -.TP -\-v -Uruchom -.B Vima -w trybie Vi, tak jakby program by³ nazwany "vi". Ma znaczenie -tylko wtedy je¶li program nazwany jest "ex". -.TP -\-w {plik} -Wszystkie wci¶niêcia klawiszy, a¿ do zakoñczenia dzia³ania programu, -s± zapisywane w {plik} . -U¿yteczne je¶li chce siê stworzyæ skrypt do u¿ycia z "vim \-s" lub -":source!". -Je¶li {plik} istnieje, znaki s± dopisywane. -.TP -\-W {plik} -Podobnie do \-w, ale istniej±cy plik jest nadpisywany. -.TP -\-x -U¿yj szyfrowania podczas zapisywania plików. Zostaniesz poproszony -o podanie klucza. -.TP -\-X -Nie ³±cz z serwerem X. Skraca czas uruchamiania w terminalu, ale tytu³ -okna i schowek nie bêd± wykorzystywane. -.TP -\-y -Uruchom -.B Vima -w ³atwym trybie, tak jakby program zosta³ wywo³any "evim" lub "eview". -.B Vim -bêdzie zachowywa³ siê bardziej jak edytor kliknij-i-wpisz. -.TP -\-Z -Tryb ograniczony. Zachowuje siê jakby nazwa programu zaczyna³a siê od -"r". -.TP -\-\- -Oznacza koniec opcji. -Argumenty po tej opcji bêd± traktowane jak nazwy plików. U¿ywa siê do -otwierania plików, których nazwy zaczynaj± siê od '\-'. -.TP -\-\-echo\-wid -Wy³±cznie GTK GUI: wypisz ID okna na standardowe wyj¶cie. -.TP -\-\-help -Wy¶wietl informacjê o pomocy i zakoñczy, to samo co"\-h". -.TP -\-\-literal -Potraktuj nazwy plików dos³ownie i nie rozwi±zuj kwantyfikatorów. Nie -ma znaczenia na Uniksach gdzie pow³oka rozwi±zuje kwantyfikatorów -.TP -\-\-noplugin -Pomiñ ³adowanie wtyczek. Implikowane przy \-u NONE. -.TP -\-\-remote -Po³±cz siê z serwerem Vima i edytuj w nim resztê argumentów. Je¶li nie -znaleziono serwera zostanie zg³oszony b³±d a pliki bêd± otwarte -w bie¿±cym Vimie. -.TP -\-\-remote\-expr {wyra¿enie} -Po³±cz z serwerem Vima, rozwi±¿ w nim {wyra¿enie} i wypisz rozwi±zanie -na standardowe wyj¶cie. -.TP -\-\-remote\-send {klawisze} -Po³±cz z serwerem Vima i wy¶lij do niego {klawisze}. -.TP -\-\-remote\-silent -Tak samo jak \-remote, ale bez ostrze¿enia kiedy nie znaleziono -serwera. -.TP -\-\-remote\-wait -Tak samo jak \-remote, ale Vim nie zakoñczy dopóki pliki nie zostan± -otwarte. -.TP -\-\-remote\-wait\-silent -Tak samo jak \-\-remote\-wait, ale bez ostrze¿enie kiedy nie -znaleziono serwera. -.TP -\-\-serverlist -Wypisz nazwy wszystkich serwerów Vima jakie mo¿na znale¼æ. -.TP -\-\-servername {nazwa} -U¿yj {nazwa} jako nazwy serwera. Wykorzystane dla bie¿±cego Vima o ile -nie po³±czone z argumentem \-\-remote, wtedy jest to nazwa serwera do -po³±czenia. -.TP -\-\-socketid {id} -Wy³±cznie GTK GUI: U¿yj mechanizmu GtkPlug by uruchomiæ gvima w innym -oknie. -.TP -\-\-version -Wypisz informacjê o wersji i zakoñcz. -.SH POMOC ON-LINE -By rozpocz±æ wpisz ":help" w -.B Vimie -Wpisz ":help temat" by uzyskaæ pomoc na okre¶lony temat. -Przyk³ad: ":help ZZ" by uzyskaæ pomoc na temat polecenia "ZZ". -U¿yj <Tab> i CTRL\-D aby uzupe³niæ tematy (":help -cmdline\-completion"). W plikach pomocy istniej± znaczniki by u³atwiæ -skakanie z jednego miejsca do innego (rodzaj linków hipertekstowych, -zobacz ":help"). -Mo¿na w ten sposób zobaczyæ ca³± dokumentacjê, np. ":help syntax.txt". -.SH PLIKI -.TP 15 -/usr/local/lib/vim/doc/*.txt -Dokumentacja -.B Vima -U¿yj ":help doc\-file\-list" aby uzyskaæ pe³n± listê. -.TP -/usr/local/lib/vim/syntax/syntax.vim -Globalne uruchamianie pod¶wietlania sk³adni. -.TP -/usr/local/lib/vim/syntax/*.vim -Pliki sk³adni dla ró¿nych jêzyków. -.TP -/usr/local/lib/vim/vimrc -Globalny plik uruchamiania -.B Vima -.TP -~/.vimrc -Osobiste parametry uruchamiania -.B Vima -.TP -/usr/local/lib/vim/gvimrc -Globalne uruchamianie gvima. -.TP -~/.gvimrc -Osobiste parametry uruchamiania gvima. -.TP -/usr/local/lib/vim/optwin.vim -Skrypt u¿ywany w poleceniu ":options", dobry sposób do przegl±dania -i ustawiania opcji. -.TP -/usr/local/lib/vim/menu.vim -Globalne uruchamianie menu gvima. -.TP -/usr/local/lib/vim/bugreport.vim -Skrypt s³u¿±cy do tworzenia raportów o b³êdach. Zobacz ":help bugs". -.TP -/usr/local/lib/vim/filetype.vim -Skrypt do wykrywania typu pliku wed³ug jego nazwy. Zobacz ":help 'filetype'". -.TP -/usr/local/lib/vim/scripts.vim -Skrypt do wykrywania typu pliku wed³ug jego zawarto¶ci. Zobacz ":help 'filetype'". -.TP -/usr/local/lib/vim/print/*.ps -Pliku u¿ywane do drukowania PostScriptu. -.PP -Naj¶wie¿sze wiadomo¶ci na stronie -.B Vima: -.br -<URL:http://www.vim.org/> -.SH ZOBACZ TAK¯E -vimtutor(1) -.SH AUTOR -.B Vim -zosta³ napisany przez Brama Moolenaara z du¿± pomoc± innych osób. -Zobacz ":help credits" w -.B Vimie. -.br -.B Vim -bazuje na Steviem, nad którym pracowali: Tim Thompson, Tony Andrews -i G.R. (Fred) Walter. -Ma³o ju¿ zosta³o z oryginalnego kodu. -.SH B£ÊDY -Prawdopodobne. -Zobacz ":help todo" by poznaæ listê znanych problemów. -.PP -Pamiêtaj ¿e pewna ilo¶æ problemów, które mog± byæ uznawane przez -niektórych ludzi za b³êdy s± w rzeczywisto¶ci spowodowane wierno¶ci± -w odtwarzaniu zachowania Vi. -Je¶li s±dzisz, ¿e inne rzeczy s± b³êdami "poniewa¿ Vi robi to -inaczej", powiniene¶ przyjrzeæ siê bli¿ej plikowi vi_diff.txt (lub -wpisaæ ":help vi_diff.txt" w Vimie). -Sprawd¼ tak¿e opis opcji 'compatible' i 'cpoptions'. diff --git a/share/vim/vim72/doc/vim-pl.UTF-8.1 b/share/vim/vim72/doc/vim-pl.UTF-8.1 deleted file mode 100644 index 365da5a41f..0000000000 --- a/share/vim/vim72/doc/vim-pl.UTF-8.1 +++ /dev/null @@ -1,555 +0,0 @@ -.TH VIM 1 "2002 Lut 22" -.SH NAME -vim \- Vi rozbudowany, edytor tekstu dla programisty -.SH SYNOPSIS -.br -.B vim -[opcje] [plik ..] -.br -.B vim -[opcje] \- -.br -.B vim -[opcje] \-t znacznik -.br -.B vim -[opcje] \-q [plik błędu] -.PP -.br -.B ex -.br -.B view -.br -.B gvim -.B gview -.B evim -.B eview -.br -.B rvim -.B rview -.B rgvim -.B rgview -.SH OPIS -.B Vim -jest edytorem tekstu kompatybilnym z Vi. Może być -używany do edycji wszelkiego rodzaju plików tekstowych. -Użyteczny zwłaszcza przy edycji programów. -.PP -Posiada wiele usprawnień w porównaniu z Vi: wielo poziomowe cofanie zmian, -wiele okien i buforów, podświetlanie składni, edycja linii poleceń, -uzupełnianie nazw plików, pomoc on-line, wizualna selekcja, itd. -Zobacz ":help vi_diff.txt" dla podsumowania różnić pomiędzy -.B Vimem -i Vi. -.PP -W czasie korzystania z -.B Vima -można uzyskać obszerną pomoc z systemu pomocy on-line dzięki poleceniu ":help". -Zobacz rozdział POMOC ON-LINE poniżej. -.PP -Najczęściej -.B Vim -jest uruchamiany do edycji pojedynczego pliku poleceniem -.PP - vim plik -.PP -Bardziej ogólnie -.B Vim -jest uruchamiany poprzez: -.PP - vim [opcje] [lista plików] -.PP -Jeśli brak listy plików edytor rozpocznie z pustym buforem. W innym -wypadku istnieje dokładnie jedna z czterech możliwości by wybrać jeden -lub więcej plików do edycji. -.TP 12 -plik .. -Lista nazw plików. -Pierwsza nazwa będzie nazwą bieżącego pliku, który zostanie wczytany -do bufora. Kursor zostanie umieszczony w pierwszym wierszu. Do -kolejnych plików można przejść dzięki poleceniu ":next". By otworzyć -plik, którego nazwa zaczyna się od myślnika należy listę plików -poprzedzić "\-\-". -.TP -\- -Plik do edycji jest wczytany ze standardowego wejścia. Polecenia są -odczytywane ze standardowego wyjścia błędów, którym powinien być -terminal (tty). -.TP -\-t {znacznik} -Plik do edycji i początkowa pozycja kursora zależy od "znacznika", -rodzaju etykiety goto. -{znacznika} szuka się w pliku tags, związany z nim plik staje się -plikiem bieżącym i wykonuje się powiązane polecenie. -Zazwyczaj używa się tego sposobu dla programów w C, w których wypadku -{znacznik} powinien być nazwą funkcji. -W efekcie plik zawierający określoną funkcję staje się plikiem -bieżącym a kursor jest umieszczony na początku funkcji. -Zobacz ":help tag-commands". -.TP -\-q [plik_błędów] -Zacznij w trybie quickFix. -Plik [plik_błędów] zostaje zinterpretowany i pokaże się pierwszy błąd. -Jeśli brak opcji [plik_błędów] nazwa pliku zostanie pobrana z opcji -'errorfile' (domyślnie "AztecC.Err" dla Amigi, "errros.err" dla innych -systemów. -Do kolejnych błędów można przeskoczyć dzięki poleceniu ":cn". -Zobacz ":help quickfix". -.PP -W zależności od wywołania -.B Vim -zachowuje się inaczej (program może być cały czas tym samym -plikiem). -.TP 10 -vim -"Normalny" sposób, wszystko jest domyślne. -.TP -ex -Zacznij w trybie Ex. -Przejdź do trybu Normalnego poleceniem ":vi". -Można także uruchomić poprzez argument "\-e". -.TP -view -Zacznij w trybie tylko do odczytu. W ten sposób będziesz chroniony -przed zapisywaniem pliku. Można także uruchomić poprzez argument -"\-R". -.TP -gvim gview -Wersja GUI. -Uruchamia nowe okno. -Można także uruchomić poprzez argument "\-g". -.TP -evim eview -Wersja GUI w łatwym trybie. -Uruchamia nowe okno. -Można także uruchomić poprzez argument "\-y". -.TP -rvim rview rgvim rgview -Podobnie jak powyżej, ale z ograniczeniami. Nie będzie można uruchomić -poleceń powłoki lub zawiesić -.B Vima. -Można także uruchomić poprzez argument "\-Z". -.SH OPCJE -Opcje można podać w dowolnej kolejności, przed lub po nazwach plików. -Opcje bez argumentów można łączyć po pojedynczym myślniku. -.TP 12 -+[num] -W pierwszym pliku kursor zostanie umieszczony w wierszu "num". -Jeśli brak "num" kursor zostanie umieszczony w ostatnim wierszu. -.TP -+/{wzór} -W pierwszym pliku kursor zostanie umieszczony na pierwszym wystąpieniu -{wzór}. -Zobacz ":help search-pattern" by dowiedzieć się jakie są możliwości -wzorów wyszukiwania. -.TP -+{polecenie} -.TP -\-c {polecenie} -{polecenie} zostanie wykonane po tym jak wczyta się pierwszy plik. -{polecenie} jest interpretowane jako polecenie Ex. -Jeśli {poleceni} zawiera białe znaki musi być umieszczone w podwójnych -cudzysłowach (zależy to od używanej powłoki). -Przykład: Vim "+set si" main.c -.br -Uwaga: Można użyć do 10 poleceń "+" lub "\-c". -.TP -\-S {plik} -{plik} zostanie zinterpretowany po wczytaniu pierwszego pliku. -Jest równoważne \-c "source {plik}". -{plik} nie może zaczynać się '\-'. -Jeśli nie podano {plik} zostanie użyty "Session.vim" (działa tylko -wtedy jeśli \-S jest ostatnim argumentem). -.TP -\-\-cmd {polecenie} -Podobne do "\-c", ale polecenie jest wykonywane tuż przed -interpretacją jakiegokolwiek pliku vimrc. -Można użyć do 10 takich poleceń, niezależni od poleceń od "\-c" -.TP -\-A -Jeśli -.B Vim -został skompilowany ze wsparciem dla języków arabskich (edycja od -prawej do lewej i arabska mapa klawiatury) ta opcja uruchamia -.B Vima -w trybie arabskim, np. ustawia się opcja 'arabic'. W innym wypadku -pojawi się komunikat błędu i -.B Vim -zakończy działanie. -.TP -\-b -Tryb binarny. -Ustawi się kilka opcji, które umożliwią edycję plików binarnych lub -wykonywalnych. -.TP -\-C -Kompatybilny. Ustawia opcję 'compatible'. -W ten sposób -.B Vim -będzie zachowywał się jak Vi, nawet jeśli istnieje plik .vimrc. -.TP -\-d -Uruchom w trybie diff. -Powinno być dwa lub trzy nazwy plików jako argumenty. -.B Vim -otworzy wszystkie te pliki i pokaże różnice między nimi. -Działa jak vimdiff(1). -.TP -\-d {urządzenie} -Otwórz {urządzenie} by używać jako terminal. -Tylko na Amidze. -Przykład: -"\-d con:20/30/600/150". -.TP -\-D -Debugowanie. Przejdź do trybu debugowanie wykonując pierwsze polecenie -ze skryptu. -.TP -\-e -Uruchom -.B Vima -w trybie Ex, działa tak samo jakby wywołano program jako "ex". -.TP -\-E -Uruchom -.B Vima -w ulepszonym trybie Ex, działa tak samo jakby wywołano program jako -"exim". -.TP -\-f -Pierszy plan. Dla wersji GUI. -.B Vim -nie nie oddzieli się od powłoki w jakiej został uruchomiony. Na Amidze -.B Vim -nie jest uruchomiony ponownie by otworzyć nowe okno. -Opcja powinna być użyta kiedy -.B Vim -jest wywoływany przez program, który ma zaczekać na koniec sesji (np. -mail). -Na Amidze polecenia ":sh" i ":!" nie będą działać. -.TP -\-\-nofork -Pierwszy plan. Dla wersji GUI. -.B Vim -nie oddzieli się od powłoki w jakiej został uruchomiony. -.TP -\-F -Jeśli Vim został skompilowany ze wsparciem FKMAP dla edycji tekstów od -prawej do lewej i mapowania klawiatury Farsi, ta opcja uruchomi -.B Vima -w trybie Farsi, np. zostawią ustawione opcje 'fkmap' i 'rightleft'. -W innym wypadku pojawi się komunikat błędu i -.B Vim -zakończy działanie. -.TP -\-g -Jeśli -.B Vim -został skompilowany ze wsparciem dla GUI ta opcja uruchomi GUI. -W innym wypadku pojawi się komunikat błędu i -.B Vim -zakończy działanie. -.TP -\-h -Wyświetli krótką pomoc o argumentach linii poleceń i opcjach. Potem -.B Vim -zakończy działanie. -.TP -\-H -Jeśli -.B Vim -został skompilowany ze wsparciem RIGHTLEFT dla edycji od prawej do -lewej oraz ma mapowanie klawiatury dla hebrajskiego, ta opcja uruchomi -.B Vima -w trybie hebrajskim, np. ustawi opcje 'hkmap' i 'rightleft'. -W innym wypadku pojawi się komunikat błędu i -.B Vim -zakończy działanie. -.TP -\-i {viminfo} -Kiedy -.B Vim -używa pliku viminfo ta opcja wskaże jakiego pliku użyć zamiast -domyślnego "~/.viminfo". -Można też ominąć użycie pliku .viminfo przez podanie nazwy "NONE". -.TP -\-L -To samo co \-r. -.TP -\-l -Tryb Lisp. -Ustawia opcje 'lisp' i 'showmatch'. -.TP -\-m -Zmiana pliku jest niemożliwa. -Przestawia opcję 'write'. -Można cały czas zmienić zawartość bufora, ale zapisanie pliku nie jest -możliwa. -.TP -\-M -Opcje 'modifiable' i 'write' zostaną wyłączone, tak więc zmiany -w pliku oraz ich zapisanie nie są możliwe. Można wartość tych opcji -zmienić. -.TP -\-N -Tryb niekompatibylny. Przestawia opcję 'compatible'. Dzięki temu -.B Vim -będzie zachowywał się odrobinę lepiej, ale mniej zgodznie z Vi nawet -jeśli nie istnieje plik .vimrc. -.TP -\-n -Nie powstanie plik wymiany. Odzyskanie pliku po wypadku nie będzie -możliwe. -Wygodne jeśli instnieje potrzeba edycji na bardzo wolnym medium (np. -dyskietce). Ten cel można osiągnąć także przez ":set uc=0". Można -odwrócić przez ":set uc=200". -.TP -\-nb -Uruchom jako serwer edytora dla NetBeans. Zobacz dokumentację by -dowiedzieć się więcej. -.TP -\-o[N] -Otwórz N okien w stosie. -Kiedy brak N, otwórz jedno okno dla każdego pliku. -.TP -\-O[N] -Otwórz N okien obok siebie. -Kiedy brak N, otwórz jedno okno dla każdego pliku. -.TP -\-p[N] -Otwórz N kart. -Kiedy brak N, otwórz jedną kartę dla każdego pliku. -.TP -\-R -Tryb tylko do odczytu. -Zostanie ustawiona opcja 'readonly'. -Cały czas można zmieniać bufor, ale będzie istniała blokada przed przypadkowym -zapisaniem pliku. -Jeśli chcesz zapisać plik dodaj wykrzyknik do polecenia Ex, np. ":w!". -Opcja \-R implikuje opcję \-n (zobacz poniżej). -Opcja 'readonly' może zostać przestawiona poprzez ":set noro". -Zobacz ":help 'readonly'". -.TP -\-r -Wypisz listę plików wymiany razem z informacjami o nich. -.TP -\-r {plik} -Tryb odzyskiwania danych. -Plik wymiany zostanie wykorzystany do odzyskania gwałtownie przerwanej sesji. -Plik wymiany to plik z taką samą nazwą co plik oryginalny z dodanym ".swp". -Zobacz ":help recovery". -.TP -\-s -Tryb cichy. Rozpoczęty tylko kiedy uruchomiony jako "Ex" lub opcja -"\-e" została podana przed opcją "\-s". -.TP -\-s {skrypt} -Zostanie wczytany plik {skrypt}. -Znaki w pliku zostaną zinterpretowane jakby były wpisywane. -To samo można osiągnąć poprzez polecenie ":source! {skrypt}". -Jeśli osiągnięto koniec pliku zanim edytor zakończył działanie, dalsze -znaki odczytywane są z klawiatury. -.TP -\-T {terminal} -Przekazuje -.B Vimowi -nazwę terminalu jakiego używasz. -Wymagane tylko wtedy jeśli nie działa automatycznie. -Powinien być to terminal znany -.B Vimowi -(builtin) lub zdefiniowany w plikach termcap lub terminfo. -.TP -\-u {vimrc} -Użyj poleceń z pliku {vimrc} w czasie uruchamiania. -Wszystkie inne możliwe pliki uruchamiania zostaną pominięte. -Używaj do edytowania plików specjalnych. -Można pominąć także wszystkie możliwe pliki uruchamiania poprzez -podanie nazwy "NONE". -Zobacz ":help initialization" by poznać więcej szczegółów. -.TP -\-U {gvimrc} -Użyj poleceń z pliku {gvimrc} w czasie uruchamiania GUI. -Wszystkie inne możliwe pliki uruchamiania GUI zostaną pominięte. -Można pominąć także wszystkie możliwe pliki uruchamiania GUI poprzez -podanie nazwy "NONE". -Zobacz ":help gui-init" by poznać więcej szczegółów. -.TP -\-V[N] -Tryb gadatliwy. Wypisz wiadomości o tym jaki pliki są wczytywane -i o informacjach pobieranych i dodawanych do pliku viminfo. Opcjonalny -argument N jest wartością 'verbose'. Domyślnie 10. -.TP -\-v -Uruchom -.B Vima -w trybie Vi, tak jakby program był nazwany "vi". Ma znaczenie -tylko wtedy jeśli program nazwany jest "ex". -.TP -\-w {plik} -Wszystkie wciśnięcia klawiszy, aż do zakończenia działania programu, -są zapisywane w {plik} . -Użyteczne jeśli chce się stworzyć skrypt do użycia z "vim \-s" lub -":source!". -Jeśli {plik} istnieje, znaki są dopisywane. -.TP -\-W {plik} -Podobnie do \-w, ale istniejący plik jest nadpisywany. -.TP -\-x -Użyj szyfrowania podczas zapisywania plików. Zostaniesz poproszony -o podanie klucza. -.TP -\-X -Nie łącz z serwerem X. Skraca czas uruchamiania w terminalu, ale tytuł -okna i schowek nie będą wykorzystywane. -.TP -\-y -Uruchom -.B Vima -w łatwym trybie, tak jakby program został wywołany "evim" lub "eview". -.B Vim -będzie zachowywał się bardziej jak edytor kliknij-i-wpisz. -.TP -\-Z -Tryb ograniczony. Zachowuje się jakby nazwa programu zaczynała się od -"r". -.TP -\-\- -Oznacza koniec opcji. -Argumenty po tej opcji będą traktowane jak nazwy plików. Używa się do -otwierania plików, których nazwy zaczynają się od '\-'. -.TP -\-\-echo\-wid -Wyłącznie GTK GUI: wypisz ID okna na standardowe wyjście. -.TP -\-\-help -Wyświetl informację o pomocy i zakończy, to samo co"\-h". -.TP -\-\-literal -Potraktuj nazwy plików dosłownie i nie rozwiązuj kwantyfikatorów. Nie -ma znaczenia na Uniksach gdzie powłoka rozwiązuje kwantyfikatorów -.TP -\-\-noplugin -Pomiń ładowanie wtyczek. Implikowane przy \-u NONE. -.TP -\-\-remote -Połącz się z serwerem Vima i edytuj w nim resztę argumentów. Jeśli nie -znaleziono serwera zostanie zgłoszony błąd a pliki będą otwarte -w bieżącym Vimie. -.TP -\-\-remote\-expr {wyrażenie} -Połącz z serwerem Vima, rozwiąż w nim {wyrażenie} i wypisz rozwiązanie -na standardowe wyjście. -.TP -\-\-remote\-send {klawisze} -Połącz z serwerem Vima i wyślij do niego {klawisze}. -.TP -\-\-remote\-silent -Tak samo jak \-remote, ale bez ostrzeżenia kiedy nie znaleziono -serwera. -.TP -\-\-remote\-wait -Tak samo jak \-remote, ale Vim nie zakończy dopóki pliki nie zostaną -otwarte. -.TP -\-\-remote\-wait\-silent -Tak samo jak \-\-remote\-wait, ale bez ostrzeżenie kiedy nie -znaleziono serwera. -.TP -\-\-serverlist -Wypisz nazwy wszystkich serwerów Vima jakie można znaleźć. -.TP -\-\-servername {nazwa} -Użyj {nazwa} jako nazwy serwera. Wykorzystane dla bieżącego Vima o ile -nie połączone z argumentem \-\-remote, wtedy jest to nazwa serwera do -połączenia. -.TP -\-\-socketid {id} -Wyłącznie GTK GUI: Użyj mechanizmu GtkPlug by uruchomić gvima w innym -oknie. -.TP -\-\-version -Wypisz informację o wersji i zakończ. -.SH POMOC ON-LINE -By rozpocząć wpisz ":help" w -.B Vimie -Wpisz ":help temat" by uzyskać pomoc na określony temat. -Przykład: ":help ZZ" by uzyskać pomoc na temat polecenia "ZZ". -Użyj <Tab> i CTRL\-D aby uzupełnić tematy (":help -cmdline\-completion"). W plikach pomocy istnieją znaczniki by ułatwić -skakanie z jednego miejsca do innego (rodzaj linków hipertekstowych, -zobacz ":help"). -Można w ten sposób zobaczyć całą dokumentację, np. ":help syntax.txt". -.SH PLIKI -.TP 15 -/usr/local/lib/vim/doc/*.txt -Dokumentacja -.B Vima -Użyj ":help doc\-file\-list" aby uzyskać pełną listę. -.TP -/usr/local/lib/vim/syntax/syntax.vim -Globalne uruchamianie podświetlania składni. -.TP -/usr/local/lib/vim/syntax/*.vim -Pliki składni dla różnych języków. -.TP -/usr/local/lib/vim/vimrc -Globalny plik uruchamiania -.B Vima -.TP -~/.vimrc -Osobiste parametry uruchamiania -.B Vima -.TP -/usr/local/lib/vim/gvimrc -Globalne uruchamianie gvima. -.TP -~/.gvimrc -Osobiste parametry uruchamiania gvima. -.TP -/usr/local/lib/vim/optwin.vim -Skrypt używany w poleceniu ":options", dobry sposób do przeglądania -i ustawiania opcji. -.TP -/usr/local/lib/vim/menu.vim -Globalne uruchamianie menu gvima. -.TP -/usr/local/lib/vim/bugreport.vim -Skrypt służący do tworzenia raportów o błędach. Zobacz ":help bugs". -.TP -/usr/local/lib/vim/filetype.vim -Skrypt do wykrywania typu pliku według jego nazwy. Zobacz ":help 'filetype'". -.TP -/usr/local/lib/vim/scripts.vim -Skrypt do wykrywania typu pliku według jego zawartości. Zobacz ":help 'filetype'". -.TP -/usr/local/lib/vim/print/*.ps -Pliku używane do drukowania PostScriptu. -.PP -Najświeższe wiadomości na stronie -.B Vima: -.br -<URL:http://www.vim.org/> -.SH ZOBACZ TAKŻE -vimtutor(1) -.SH AUTOR -.B Vim -został napisany przez Brama Moolenaara z dużą pomocą innych osób. -Zobacz ":help credits" w -.B Vimie. -.br -.B Vim -bazuje na Steviem, nad którym pracowali: Tim Thompson, Tony Andrews -i G.R. (Fred) Walter. -Mało już zostało z oryginalnego kodu. -.SH BŁĘDY -Prawdopodobne. -Zobacz ":help todo" by poznać listę znanych problemów. -.PP -Pamiętaj że pewna ilość problemów, które mogą być uznawane przez -niektórych ludzi za błędy są w rzeczywistości spowodowane wiernością -w odtwarzaniu zachowania Vi. -Jeśli sądzisz, że inne rzeczy są błędami "ponieważ Vi robi to -inaczej", powinieneś przyjrzeć się bliżej plikowi vi_diff.txt (lub -wpisać ":help vi_diff.txt" w Vimie). -Sprawdź także opis opcji 'compatible' i 'cpoptions'. diff --git a/share/vim/vim72/doc/vim-ru.1 b/share/vim/vim72/doc/vim-ru.1 deleted file mode 100644 index bb2597fead..0000000000 --- a/share/vim/vim72/doc/vim-ru.1 +++ /dev/null @@ -1,489 +0,0 @@ -.TH VIM 1 "2002 Feb 22" -.SH éíñ -vim \- Vi IMproved (õÌÕÞÛÅÎÎÙÊ Vi), ÔÅËÓÔÏ×ÙÊ ÒÅÄÁËÔÏÒ ÄÌÑ ÐÒÏÇÒÁÍÍÉÓÔÏ× -.SH ëïíáîäîáñ óôòïëá -.br -.B vim -[ËÌÀÞÉ] [ÆÁÊÌ ..] -.br -.B vim -[ËÌÀÞÉ] - -.br -.B vim -[ËÌÀÞÉ] \-t ÍÅÔËÁ -.br -.B vim -[ËÌÀÞÉ] \-q [ÆÁÊÌ ÏÛÉÂÏË] -.PP -.br -.B ex -.br -.B view -.br -.B gvim -.B gview -.br -.B rvim -.B rview -.B rgvim -.B rgview -.SH ïðéóáîéå -.B Vim --- ÔÅËÓÔÏ×ÙÊ ÒÅÄÁËÔÏÒ, ÏÂÒÁÔÎÏ-ÓÏ×ÍÅÓÔÉÍÙÊ Ó Vi. -ïÎ ÍÏÖÅÔ ÂÙÔØ ÉÓÐÏÌØÚÏ×ÁÎ ÄÌÑ ÐÒÁ×ËÉ ×ÓÅÈ ×ÉÄÏ× ÐÒÏÓÔÏÇÏ ÔÅËÓÔÁ. -ïÓÏÂÅÎÎÏ ÏÎ ÈÏÒÏÛ ÄÌÑ ÐÒÁ×ËÉ ÉÓÈÏÄÎÙÈ ÔÅËÓÔÏ× ÐÒÏÇÒÁÍÍ. -.PP -ðÏ ÓÒÁ×ÎÅÎÉÀ Ó Vi, -.B Vim -ÉÍÅÅÔ ÍÎÏÇÏ ÕÓÏ×ÅÒÛÅÎÓÔ×Ï×ÁÎÉÊ: ÍÎÏÇÏËÒÁÔÎÁÑ ÏÔÍÅÎÁ ÏÐÅÒÁÃÉÊ, -ÍÎÏÖÅÓÔ×ÅÎÎÏÓÔØ ÏËÏÎ É ÂÕÆÅÒÏ×, ÐÏÄÓ×ÅÔËÁ ÓÉÎÔÁËÓÉÓÁ, ÐÒÁ×ËÁ ËÏÍÁÎÄÎÏÊ ÓÔÒÏËÉ, -Á×ÔÏÄÏÐÏÌÎÅÎÉÅ ÉͣΠÆÁÊÌÏ×, ×ÓÔÒÏÅÎÎÁÑ ÓÐÒÁ×ËÁ, ×ÉÚÕÁÌØÎÏÅ ×ÙÄÅÌÅÎÉÅ É Ô.Ð. -óÍ. ":help vi_diff.txt" ÄÌÑ ÐÏÌÕÞÅÎÉÑ ÐÏÌÎÏÇÏ ÓÐÉÓËÁ ÒÁÚÌÉÞÉÊ ÍÅÖÄÕ -.B Vim -É Vi. -.PP -÷Ï ×ÒÅÍÑ ÒÁÂÏÔÙ × -.B Vim -ÍÏÖÎÏ ÐÏÌÕÞÉÔØ ÓÐÒÁ×ËÕ Ó ÐÏÍÏÝØÀ ÓÉÓÔÅÍÙ ×ÓÔÒÏÅÎÎÏÊ ÓÐÒÁ×ËÉ (ËÏÍÁÎÄÁ ":help"). -óÍ. ÒÁÚÄÅÌ "÷óôòïåîîáñ óðòá÷ëá" ÎÉÖÅ ÐÏ ÔÅËÓÔÕ. -.PP -þÁÝÅ ×ÓÅÇÏ -.B Vim -ÚÁÐÕÓËÁÀÔ ÄÌÑ ÐÒÁ×ËÉ ÏÄÎÏÇÏ ÆÁÊÌÁ ÐÒÉ ÐÏÍÏÝÉ ËÏÍÁÎÄÙ -.PP - vim ÆÁÊÌ -.PP -÷ ÏÂÝÅÍ ×ÉÄÅ ËÏÍÁÎÄÁ ÚÁÐÕÓËÁ -.B Vim -×ÙÇÌÑÄÉÔ ÔÁË: -.PP - vim [ËÌÀÞÉ] [ÓÐÉÓÏË ÆÁÊÌÏ×] -.PP -åÓÌÉ ÓÐÉÓÏË ÆÁÊÌÏ× ÏÔÓÕÔÓÔ×ÕÅÔ, ÒÅÄÁËÔÏÒ ÎÁÞÎ£Ô ÒÁÂÏÔÕ Ó ÐÕÓÔÙÍ ÂÕÆÅÒÏÍ. -÷ ÐÒÏÔÉ×ÎÏÍ ÓÌÕÞÁÅ ÉÍÑ ÆÁÊÌÁ ÄÏÌÖÎÏ ÂÙÔØ ÕËÁÚÁÎÏ ÏÄÎÉÍ ÉÚ ÓÌÅÄÕÀÝÉÈ ÞÅÔÙÒ£È ÓÐÏÓÏÂÏ×: -.TP 12 -ÆÁÊÌ .. -óÐÉÓÏË ÉͣΠÆÁÊÌÏ×. -ðÅÒ×ÙÊ ÆÁÊÌ ÂÕÄÅÔ ÏÂßÑ×ÌÅÎ ÁËÔÉ×ÎÙÍ É ÚÁÇÒÕÖÅÎ × ÂÕÆÅÒ. ëÕÒÓÏÒ ÂÕÄÅÔ ÐÏÍÅݣΠ-× ÐÅÒ×ÏÊ ÓÔÒÏËÅ ÂÕÆÅÒÁ. äÏÓÔÕÐ Ë ÄÒÕÇÉÍ ÆÁÊÌÁÍ ÍÏÖÅÔ ÂÙÔØ ÏÓÕÝÅÓÔ×̣ΠÐÒÉ -ÐÏÍÏÝÉ ËÏÍÁÎÄÙ ":next". þÔÏÂÙ ÐÒÁ×ÉÔØ ÆÁÊÌ, ÉÍÑ ËÏÔÏÒÏÇÏ ÎÁÞÉÎÁÅÔÓÑ Ó ÓÉÍ×ÏÌÁ -"ÄÅÆÉÓ" (-), ÐÅÒÅÄ ÓÐÉÓËÏÍ ÆÁÊÌÏ× ÎÅÏÂÈÏÄÉÍÏ ÐÏÓÔÁ×ÉÔØ "--". -.TP -- -æÁÊÌ ÂÕÄÅÔ ÐÒÏÞÉÔÁÎ ÉÚ ÐÏÔÏËÁ ÓÔÁÎÄÁÒÔÎÏÇÏ ××ÏÄÁ. ëÏÍÁÎÄÙ ÂÕÄÕÔ ÓÞÉÔÙ×ÁÔØÓÑ -ÉÚ ÓÔÁÎÄÁÒÔÎÏÇÏ ÐÏÔÏËÁ ÄÉÁÇÎÏÓÔÉËÉ (stderr), ËÏÔÏÒÙÊ ÄÏÌÖÅÎ ÂÙÔØ -ÔÅÒÍÉÎÁÌÏÍ. -.TP --t {ÍÅÔËÁ} -éÍÑ ÆÁÊÌÁ É ÎÁÞÁÌØÎÁÑ ÐÏÚÉÃÉÑ ËÕÒÓÏÒÁ ÚÁ×ÉÓÑÔ ÏÔ "ÍÅÔËÉ", ÐÏÈÏÖÅÊ ÎÁ ÍÅÔËÕ goto. -{ÍÅÔËÁ} ÉÝÅÔÓÑ × ÆÁÊÌÅ ÍÅÔÏË, ÓÏÏÔ×ÅÔÓÔ×ÕÀÝÉÊ ÆÁÊÌ ÓÔÁÎÏ×ÉÔÓÑ ÁËÔÉ×ÎÙÍ, Á -ÓÏÏÔ×ÅÔÓÔ×ÕÀÝÁÑ ËÏÍÁÎÄÁ ÉÓÐÏÌÎÑÅÔÓÑ. -þÁÝÅ ×ÓÅÇÏ ÉÓÐÏÌØÚÕÅÔÓÑ × ÐÒÏÇÒÁÍÍÁÈ ÎÁ ÑÚÙËÅ óÉ, ÇÄÅ {ÍÅÔËÁ} ÍÏÖÅÔ ÂÙÔØ ÉÍÅÎÅÍ -ÆÕÎËÃÉÉ. -æÁÊÌ, ÓÏÄÅÒÖÁÝÉÊ ÆÕÎËÃÉÀ, ÓÔÁÎÏ×ÉÔÓÑ ÁËÔÉ×ÎÙÍ, Á ËÕÒÓÏÒ ÐÏÍÅÝÁÅÔÓÑ × ÎÁÞÁÌÏ ÆÕÎËÃÉÉ. -óÍ. ":help tag-commands". -.TP --q [ÆÁÊÌ ÏÛÉÂÏË] -îÁÞÁÔØ ÒÁÂÏÔÕ × ÒÅÖÉÍÅ ÂÙÓÔÒÏÇÏ ÉÓÐÒÁ×ÌÅÎÉÑ. -ðÒÉ ÜÔÏÍ ÓÞÉÔÙ×ÁÅÔÓÑ [ÆÁÊÌ ÏÛÉÂÏË] É ÐÅÒ×ÁÑ ÏÛÉÂËÁ ×Ù×ÏÄÉÔÓÑ ÎÁ ÜËÒÁÎ. -åÓÌÉ [ÆÁÊÌ ÏÛÉÂÏË] ÎÅ ÕËÁÚÁÎ, ÉÍÑ ÆÁÊÌÁ ÂÅÒ£ÔÓÑ ÉÚ ÚÎÁÞÅÎÉÑ ÏÐÃÉÉ 'errorfile' -(ÐÏ ÕÍÏÌÞÁÎÉÀ: "AztecC.Err" ÄÌÑ Amiga, "errors.err" ÄÌÑ ÄÒÕÇÉÈ ÓÉÓÔÅÍ). -ë ÓÌÅÄÕÀÝÉÍ ÏÛÉÂËÁÍ ÍÏÖÎÏ ÐÅÒÅÊÔÉ ÐÏ ËÏÍÁÎÄÅ ":cn". -óÍ. ":help quickfix". -.PP -.B Vim -×ÅÄ£Ô ÓÅÂÑ ÐÏ-ÒÁÚÎÏÍÕ × ÚÁ×ÉÓÉÍÏÓÔÉ ÏÔ ÉÍÅÎÉ ËÏÍÁÎÄÙ (ÉÓÐÏÌÎÑÅÍÙÊ ÆÁÊÌ ÍÏÖÅÔ -ÂÙÔØ ÏÄÎÉÍ É ÔÅÍ ÖÅ). -.TP 10 -vim -"îÏÒÍÁÌØÎÙÊ" ÚÁÐÕÓË, ×Ó£ ÐÏ ÕÍÏÌÞÁÎÉÀ. -.TP -ex -úÁÐÕÓË × ÒÅÖÉÍÅ Ex. äÌÑ ÐÅÒÅÈÏÄÁ × ÎÏÒÍÁÌØÎÙÊ ÒÅÖÉÍ -ÎÅÏÂÈÏÄÉÍÏ ×ÙÐÏÌÎÉÔØ ËÏÍÁÎÄÕ ":vi". òÅÖÉÍ Ex ×ËÌÀÞÁÅÔ -ÔÁËÖÅ ËÌÀÞ "-e". -.TP -view -úÁÐÕÓË × ÒÅÖÉÍÅ "ÔÏÌØËÏ ÄÌÑ ÞÔÅÎÉÑ". ÷Ù ÂÕÄÅÔÅ ÚÁÝÉÝÅÎÙ ÏÔ ÓÌÕÞÁÊÎÏÊ ÚÁÐÉÓÉ -ÆÁÊÌÁ. ôÏ ÖÅ ÓÁÍÏÅ ÍÏÖÎÏ ÓÄÅÌÁÔØ ËÌÀÞÏÍ "-R". -.TP -gvim gview -÷ÅÒÓÉÑ Ó ÇÒÁÆÉÞÅÓËÉÍ ÉÎÔÅÒÆÅÊÓÏÍ. úÁÐÕÓËÁÅÔÓÑ × ÎÏ×ÏÍ ÏËÎÅ. -ôÏ ÖÅ ÓÁÍÏÅ ÍÏÖÎÏ ÓÄÅÌÁÔØ ÐÒÉ ÚÁÐÕÓËÅ Ó ËÌÀÞÏÍ "-g". -.TP -rvim rview rgvim rgview -ëÁË É ÐÒÅÄÙÄÕÝÉÅ ËÏÍÁÎÄÙ, ÎÏ Ó ÏÇÒÁÎÉÞÅÎÉÑÍÉ. îÅÌØÚÑ ÚÁÐÕÓËÁÔØ ËÏÍÁÎÄÙ ÏÂÏÌÏÞËÉ -ÉÌÉ ÐÒÉÏÓÔÁÎÁ×ÌÉ×ÁÔØ ÒÁÂÏÔÕ -.B Vim. -÷ÍÅÓÔÏ ÐÒÉÓÔÁ×ËÉ "r" ÍÏÖÎÏ ÉÓÐÏÌØÚÏ×ÁÔØ ËÌÀÞ "-Z". -.SH ëìàþé -ëÌÀÞÉ ÍÏÇÕÔ ÂÙÔØ ÕËÁÚÁÎÙ × ÌÀÂÏÍ ÐÏÒÑÄËÅ, ÄÏ ÉÌÉ ÐÏÓÌÅ ÉͣΠ-ÆÁÊÌÏ×. ëÌÀÞÉ ÂÅÚ ÁÒÇÕÍÅÎÔÏ× ÍÏÇÕÔ ÂÙÔØ ÏÂßÅÄÉÎÅÎÙ ÐÏÄ ÏÄÎÉÍ -ÄÅÆÉÓÏÍ. -.TP 12 -+[ÎÏÍÅÒ] -÷ ÐÅÒ×ÏÍ ÆÁÊÌÅ ËÕÒÓÏÒ ÂÕÄÅÔ ÐÏÍÅݣΠÎÁ ÓÔÒÏËÕ Ó ÕËÁÚÁÎÎÙÍ ÎÏÍÅÒÏÍ. -åÓÌÉ "ÎÏÍÅÒ" ÎÅ ÕËÁÚÁÎ, ËÕÒÓÏÒ ÂÕÄÅÔ ÐÏÍÅݣΠÎÁ ÐÏÓÌÅÄÎÀÀ ÓÔÒÏËÕ. -.TP -+/{ÛÁÂÌÏÎ} -÷ ÐÅÒ×ÏÍ ÆÁÊÌÅ ËÕÒÓÏÒ ÂÕÄÅÔ ÐÏÍÅݣΠÎÁ ÍÅÓÔÏ ÐÅÒ×ÏÇÏ ÓÏ×ÐÁÄÅÎÉÑ -Ó ÕËÁÚÁÎÎÙÍ ÛÁÂÌÏÎÏÍ. óÍ. ":help search-pattern" ÄÌÑ ÐÏÌÕÞÅÎÉÑ -ÓÐÉÓËÁ ÄÏÐÕÓÔÉÍÙÈ ÛÁÂÌÏÎÏ×. -.TP -+{ËÏÍÁÎÄÁ} -.TP --c {ËÏÍÁÎÄÁ} -{ËÏÍÁÎÄÁ} ÉÓÐÏÌÎÑÅÔÓÑ ÐÏÓÌÅ ÚÁÇÒÕÚËÉ ÐÅÒ×ÏÇÏ ÆÁÊÌÁ ËÁË ËÏÍÁÎÄÁ Ex. -åÓÌÉ {ËÏÍÁÎÄÁ} ÓÏÄÅÒÖÉÔ ÐÒÏÂÅÌÙ, ÔÏ ÏÎÁ ÄÏÌÖÎÁ ÂÙÔØ ÚÁËÌÀÞÅÎÁ × -Ä×ÏÊÎÙÅ ËÁ×ÙÞËÉ (× ÚÁ×ÉÓÉÍÏÓÔÉ ÏÔ ÉÓÐÏÌØÚÕÅÍÏÊ ÏÂÏÌÏÞËÉ). -ðÒÉÍÅÒ: vim "+set si" main.c -.br -ðÒÉÍÅÞÁÎÉÅ: íÏÖÎÏ ÕËÁÚÙ×ÁÔØ ÄÏ ÄÅÓÑÔÉ ËÏÍÁÎÄ "+" ÉÌÉ "-c". -.TP ---cmd {ËÏÍÁÎÄÁ} -ëÁË "-c", ÎÏ ËÏÍÁÎÄÁ ÉÓÐÏÌÎÑÅÔÓÑ ÐÅÒÅÄ ÏÂÒÁÂÏÔËÏÊ ÌÀÂÏÇÏ ÆÁÊÌÁ -ÎÁÓÔÒÏÅË (vimrc). -íÏÖÎÏ ÕËÁÚÙ×ÁÔØ ÄÏ ÄÅÓÑÔÉ ÔÁËÉÈ ËÏÍÁÎÄ, ÎÅÚÁ×ÉÓÉÍÏ ÏÔ ËÏÌÉÞÅÓÔ×Á -ËÏÍÁÎÄ "-c". -.TP --A -åÓÌÉ -.B Vim -ÂÙÌ ÓÏÂÒÁÎ Ó ÐÏÄÄÅÒÖËÏÊ ÁÒÁÂÓËÏÇÏ ÑÚÙËÁ ÄÌÑ ÐÒÁ×ËÉ ÆÁÊÌÏ×, -ÎÁÂÒÁÎÎÙÈ ÓÐÒÁ×Á ÎÁÌÅ×Ï, É Ó ÐÏÄÄÅÒÖËÏÊ ÁÒÁÂÓËÏÊ ËÌÁ×ÉÁÔÕÒÙ, -ÜÔÏÔ ËÌÀÞ ÚÁÐÕÓËÁÅÔ -.B Vim -× ÁÒÁÂÓËÏÍ ÒÅÖÉÍÅ, Ó ×ËÌÀÞÅÎÎÏÊ ÏÐÃÉÅÊ 'arabic'. ÷ ÐÒÏÔÉ×ÎÏÍ -ÓÌÕÞÁÅ -.B Vim -ÚÁ×ÅÒÛÁÅÔ ÒÁÂÏÔÕ Ó ÏÛÉÂËÏÊ. -.TP --b -ä×ÏÉÞÎÙÊ ÒÅÖÉÍ. -ðÒÏÉÚ×ÏÄÉÔÓÑ ÎÁÓÔÒÏÊËÁ ÎÅËÏÔÏÒÙÈ ÏÐÃÉÊ, ÄÅÌÁÀÝÉÈ ×ÏÚÍÏÖÎÏÊ ÐÒÁ×ËÕ -Ä×ÏÉÞÎÏÇÏ ÉÌÉ ÉÓÐÏÌÎÑÅÍÏÇÏ ÆÁÊÌÁ. -.TP --C -òÅÖÉÍ ÓÏ×ÍÅÓÔÉÍÏÓÔÉ. ÷ËÌÀÞÁÅÔ ÏÐÃÉÀ 'compatible'. -.B Vim -ÂÕÄÅÔ ÒÁÂÏÔÁÔØ ÐÏÞÔÉ ËÁË Vi, ÄÁÖÅ ÅÓÌÉ ÓÕÝÅÓÔ×ÕÅÔ ÆÁÊÌ .vimrc. -.TP --d -òÅÖÉÍ ÐÏÉÓËÁ ÒÁÚÌÉÞÉÊ. -äÏÌÖÎÏ ÂÙÔØ ÕËÁÚÁÎÏ Ä×Á ÉÌÉ ÔÒÉ ÉÍÅÎÉ ÆÁÊÌÁ. -.B Vim -ÏÔËÒÏÅÔ ×ÓÅ ÆÁÊÌÙ É ÐÏËÁÖÅÔ ÒÁÚÌÉÞÉÑ ÍÅÖÄÕ ÎÉÍÉ -(ËÁË vimdiff(1)). -.TP --d {ÕÓÔÒÏÊÓÔ×Ï} -ïÔËÒÙÔØ {ÕÓÔÒÏÊÓÔ×Ï} ÄÌÑ ÉÓÐÏÌØÚÏ×ÁÎÉÑ × ËÁÞÅÓÔ×Å ÔÅÒÍÉÎÁÌÁ (ÔÏÌØËÏ ÎÁ Amiga). -ðÒÉÍÅÒ: -"\-d con:20/30/600/150". -.TP --e -úÁÐÕÓÔÉÔØ -.B Vim -× ÒÅÖÉÍÅ Ex, ËÁË ÂÕÄÔÏ ÉÓÐÏÌÎÑÅÍÙÊ ÆÁÊÌ ÉÍÅÅÔ ÉÍÑ "ex". -.TP --f -òÅÖÉÍ ÁËÔÉ×ÎÏÇÏ ÐÒÉÌÏÖÅÎÉÑ. ÷ÅÒÓÉÑ -.B Vim -Ó ÇÒÁÆÉÞÅÓËÉÍ ÉÎÔÅÒÆÅÊÓÏÍ ÎÅ ÂÕÄÅÔ ×ÅÔ×ÉÔØÓÑ É ÏÔËÌÀÞÁÔØÓÑ -ÏÔ ÚÁÐÕÓÔÉ×ÛÅÊ Å£ ÏÂÏÌÏÞËÉ. îÁ ÐÌÁÔÆÏÒÍÅ Amiga -.B Vim -ÎÅ ÂÕÄÅÔ ÓÏÚÄÁ×ÁÔØ ÎÏ×ÏÅ ÏËÎÏ. üÔÏÔ ËÌÀÞ ÎÕÖÎÏ ÉÓÐÏÌØÚÏ×ÁÔØ, -ËÏÇÄÁ -.B Vim -ÚÁÐÕÓËÁÅÔÓÑ ÐÒÏÇÒÁÍÍÏÊ, ËÏÔÏÒÁÑ ÄÏÌÖÎÁ ÖÄÁÔØ ÚÁ×ÅÒÛÅÎÉÑ -ÓÅÁÎÓÁ ÐÒÁ×ËÉ (ÎÁÐÒÉÍÅÒ, ÐÒÏÇÒÁÍÍÁ ÄÌÑ ÒÁÂÏÔÙ Ó ÜÌÅËÔÒÏÎÎÏÊ ÐÏÞÔÏÊ). -îÁ ÐÌÁÔÆÏÒÍÅ Amiga ËÏÍÁÎÄÙ ":sh" É ":!" ÎÅ ÂÕÄÕÔ ÒÁÂÏÔÁÔØ. -.TP ---nofork -òÅÖÉÍ ÁËÔÉ×ÎÏÇÏ ÐÒÉÌÏÖÅÎÉÑ. ÷ÅÒÓÉÑ -.B Vim -Ó ÇÒÁÆÉÞÅÓËÉÍ ÉÎÔÅÒÆÅÊÓÏÍ ÎÅ ÂÕÄÅÔ ×ÅÔ×ÉÔØÓÑ É ÏÔËÌÀÞÁÔØÓÑ -ÏÔ ÚÁÐÕÓÔÉ×ÛÅÊ Å£ ÏÂÏÌÏÞËÉ. -.TP --F -åÓÌÉ -.B Vim -ÂÙÌ ÓÏÂÒÁÎ Ó ÐÏÄÄÅÒÖËÏÊ FKMAP ÄÌÑ ÐÒÁ×ËÉ ÔÅËÓÔÁ ÓÐÒÁ×Á ÎÁÌÅ×Ï -É ÎÁÓÔÒÏÅË ËÌÁ×ÉÁÔÕÒÙ ÄÌÑ ÑÚÙËÁ ÆÁÒÓÉ, ÜÔÏÔ ËÌÀÞ ÚÁÐÕÓËÁÅÔ -.B Vim -× ÒÅÖÉÍÅ ÆÁÒÓÉ, ÉÎÁÞÅ ÇÏ×ÏÒÑ, Ó ×ËÌÀÞ£ÎÎÙÍÉ ÏÐÃÉÑÍÉ -'fkmap' É 'rightleft'. -÷ ÐÒÏÔÉ×ÎÏÍ ÓÌÕÞÁÅ -.B Vim -ÚÁ×ÅÒÛÁÅÔ ÒÁÂÏÔÕ Ó ÓÏÏÂÝÅÎÉÅÍ Ï ÏÛÉÂËÅ. -.TP --g -åÓÌÉ -.B Vim -ÂÙÌ ÓÏÂÒÁÎ Ó ÐÏÄÄÅÒÖËÏÊ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ, ÜÔÏÔ ËÌÀÞ -×ËÌÀÞÁÅÔ ÇÒÁÆÉÞÅÓËÉÊ ÉÎÔÅÒÆÅÊÓ. ÷ ÐÒÏÔÉ×ÎÏÍ ÓÌÕÞÁÅ -.B Vim -ÚÁ×ÅÒÛÁÅÔ ÒÁÂÏÔÕ Ó ÓÏÏÂÝÅÎÉÅÍ Ï ÏÛÉÂËÅ. -.TP --h -÷Ù×ÏÄÉÔ ËÒÁÔËÕÀ ÉÎÆÏÒÍÁÃÉÀ Ï ÁÒÇÕÍÅÎÔÁÈ É ËÌÀÞÁÈ ËÏÍÁÎÄÎÏÊ ÓÔÒÏËÉ. -ðÏÓÌÅ ÜÔÏÇÏ -.B Vim -ÚÁ×ÅÒÛÁÅÔ ÒÁÂÏÔÕ. -.TP --H -åÓÌÉ -.B Vim -ÂÙÌ ÓÏÂÒÁÎ Ó ÐÏÄÄÅÒÖËÏÊ ÐÒÁ×ËÉ ÔÅËÓÔÁ ÓÐÒÁ×Á ÎÁÌÅ×Ï -É ÎÁÓÔÒÏÅË ËÌÁ×ÉÁÔÕÒÙ ÄÌÑ É×ÒÉÔÁ, ÜÔÏÔ ËÌÀÞ ÚÁÐÕÓËÁÅÔ -.B Vim -× ÒÅÖÉÍÅ É×ÒÉÔÁ, ÉÎÁÞÅ ÇÏ×ÏÒÑ, Ó ×ËÌÀÞ£ÎÎÙÍÉ ÏÐÃÉÑÍÉ 'hkmap' É 'rightleft'. -÷ ÐÒÏÔÉ×ÎÏÍ ÓÌÕÞÁÅ -.B Vim -ÚÁ×ÅÒÛÁÅÔ ÒÁÂÏÔÕ Ó ÓÏÏÂÝÅÎÉÅÍ Ï ÏÛÉÂËÅ. -.TP --i {viminfo} -åÓÌÉ ÉÓÐÏÌØÚÕÅÔÓÑ ÆÁÊÌ viminfo, ÔÏ ÜÔÏÔ ËÌÀÞ ÚÁÄÁ£Ô ÉÍÑ ÔÁËÏÇÏ ÆÁÊÌÁ (×ÍÅÓÔÏ -"~/.viminfo" ÐÏ ÕÍÏÌÞÁÎÉÀ). íÏÖÎÏ ÔÁËÖÅ ÉÚÂÅÖÁÔØ ÉÓÐÏÌØÚÏ×ÁÎÉÑ ÆÁÊÌÁ viminfo -ÐÕÔ£Í ÕËÁÚÁÎÉÑ ÉÍÅÎÉ "NONE". -.TP --L -ôÏ ÖÅ, ÞÔÏ É -r. -.TP --l -òÅÖÉÍ Lisp. ÷ËÌÀÞÁÀÔÓÑ ÏÐÃÉÉ 'lisp' É 'showmatch'. -.TP --m -éÚÍÅÎÅÎÉÅ ÆÁÊÌÏ× ÚÁÐÒÅÝÅÎÏ. ðÒÉ ÜÔÏÍ ÏÔËÌÀÞÁÅÔÓÑ ÏÐÃÉÑ 'write', ÐÏÜÔÏÍÕ -ÚÁÐÉÓØ ÆÁÊÌÏ× ÓÔÁÎÏ×ÉÔÓÑ ÎÅ×ÏÚÍÏÖÎÏÊ. -.TP --N -òÅÖÉÍ ÎÅÐÏÌÎÏÊ ÓÏ×ÍÅÓÔÉÍÏÓÔÉ. ïÔËÌÀÞÁÅÔÓÑ 'compatible'. -.B Vim -ÂÕÄÅÔ ÒÁÂÏÔÁÔØ ÌÕÞÛÅ, ÎÏ ÎÅ ÂÕÄÅÔ ÐÏÌÎÏÓÔØÀ ÓÏ×ÍÅÓÔÉÍ Ó Vi, ÄÁÖÅ ÅÓÌÉ -ÏÔÓÕÔÓÔ×ÕÅÔ ÆÁÊÌ ÓÃÅÎÁÒÉÑ ÎÁÓÔÒÏÅË (.vimrc). -.TP --n -îÅ ÉÓÐÏÌØÚÏ×ÁÔØ Ó×ÏÐ-ÆÁÊÌ. ÷ÏÓÓÔÁÎÏ×ÌÅÎÉÅ ÐÒÉ ÓÂÏÅ × ÒÁÂÏÔÅ ÂÕÄÅÔ ÎÅ×ÏÚÍÏÖÎÏ. -õÄÏÂÎÏ ÄÌÑ ÐÒÁ×ËÉ ÆÁÊÌÁ ÎÁ ÏÞÅÎØ ÍÅÄÌÅÎÎÏÍ ÎÏÓÉÔÅÌÅ (ÎÁÐÒÉÍÅÒ, ÇÉÂËÏÍ ÄÉÓËÅ). -ôÏ ÖÅ ÓÁÍÏÅ ÍÏÖÎÏ ÓÄÅÌÁÔØ ËÏÍÁÎÄÏÊ ":set uc=0". ïÔÍÅÎÁ -- ":set uc=200". -.TP --o[N] -ïÔËÒÙÔØ N ÏËÏÎ, ÒÁÚÄÅÌ£ÎÎÙÈ ÐÏ ÇÏÒÉÚÏÎÔÁÌÉ. åÓÌÉ N ÎÅ ÕËÁÚÁÎÏ, ÔÏ ÏÔËÒÙ×ÁÅÔÓÑ -ÐÏ ÏÄÎÏÍÕ ÏËÎÕ ÎÁ ËÁÖÄÙÊ ÆÁÊÌ. -.TP --O[N] -ïÔËÒÙÔØ N ÏËÏÎ, ÒÁÚÄÅÌ£ÎÎÙÈ ÐÏ ×ÅÒÔÉËÁÌÉ. åÓÌÉ N ÎÅ ÕËÁÚÁÎÏ, ÔÏ ÏÔËÒÙ×ÁÅÔÓÑ -ÐÏ ÏÄÎÏÍÕ ÏËÎÕ ÎÁ ËÁÖÄÙÊ ÆÁÊÌ. -.TP --R -òÅÖÉÍ "ÔÏÌØËÏ ÄÌÑ ÞÔÅÎÉÑ". ÷ËÌÀÞÁÅÔÓÑ ÏÐÃÉÑ 'readonly'. -æÁÊÌ × ÂÕÆÅÒÅ ÄÏÓÔÕÐÅÎ ÄÌÑ ÒÅÄÁËÔÉÒÏ×ÁÎÉÑ, ÎÏ ÅÇÏ ËÏÐÉÀ ÎÁ ÄÉÓËÅ ÎÅÌØÚÑ -ÓÌÕÞÁÊÎÏ ÐÅÒÅÚÁÐÉÓÁÔØ. äÌÑ ÓÏÈÒÁÎÅÎÉÑ ÆÁÊÌÁ ÎÅÏÂÈÏÄÉÍÏ ÄÏÂÁ×ÉÔØ ×ÏÓËÌÉÃÁÔÅÌØÎÙÊ -ÚÎÁË Ë ÓÏÏÔ×ÅÔÓÔ×ÕÀÝÅÊ ËÏÍÁÎÄÅ Ex (ÎÁÐÒÉÍÅÒ, ":w!"). -ëÌÀÞ "-R" ÐÏÄÒÁÚÕÍÅ×ÁÅÔ ÔÁËÖÅ, ÞÔÏ ÉÓÐÏÌØÚÕÅÔÓÑ É ËÌÀÞ "-n" (ÓÍ. ×ÙÛÅ). -ïÐÃÉÑ 'readonly' ÍÏÖÅÔ ÂÙÔØ ×ÙËÌÀÞÅÎÁ ÐÏ ËÏÍÁÎÄÅ ":set noro". -óÍ. ":help 'readonly'". -.TP --r -÷Ù×ÅÓÔÉ ÓÐÉÓÏË Ó×ÏÐ-ÆÁÊÌÏ× É ÉÎÆÏÒÍÁÃÉÀ Ï ÉÈ ÉÓÐÏÌØÚÏ×ÁÎÉÉ ÄÌÑ ×ÏÓÓÔÁÎÏ×ÌÅÎÉÑ ÐÏÓÌÅ ÓÂÏÑ. -.TP --r {ÆÁÊÌ} -òÅÖÉÍ ×ÏÓÓÔÁÎÏ×ÌÅÎÉÑ. -äÌÑ ×ÏÓÓÔÁÎÏ×ÌÅÎÉÑ ÐÏÓÌÅ ÓÂÏÑ ÂÕÄÅÔ ÉÓÐÏÌØÚÏ×ÁÎ Ó×ÏÐ-ÆÁÊÌ. -ó×ÏÐ-ÆÁÊÌ ÉÍÅÅÔ ÔÏ ÖÅ ÉÍÑ, ÞÔÏ É ÔÅËÓÔÏ×ÙÊ ÆÁÊÌ, ÎÏ Ó ÄÏÂÁ×ÌÅÎÉÅÍ ÒÁÓÛÉÒÅÎÉÑ ".swp". -óÍ. ":help recovery". -.TP --s -ôÉÈÉÊ ÒÅÖÉÍ. ôÏÌØËÏ ÐÒÉ ÚÁÐÕÓËÅ ËÁË "Ex" ÉÌÉ ÅÓÌÉ ÐÅÒÅÄ "-s" ÕËÁÚÁÎ ËÌÀÞ "-e". -.TP --s {scriptin} -óÞÉÔÙ×ÁÅÔÓÑ ÆÁÊÌ ÓÃÅÎÁÒÉÑ {scriptin}. ðÒÉ ÜÔÏÍ, ÓÏÄÅÒÖÉÍÏÅ ÆÁÊÌÁ ×ÏÓÐÒÉÎÉÍÁÅÔÓÑ -× ×ÉÄÅ ËÏÍÁÎÄ, ËÁË ÅÓÌÉ ÂÙ ÏÎÉ ÂÙÌÉ ÎÁÂÒÁÎÙ ÎÁ ËÏÎÓÏÌÉ. -ôÏ ÖÅ ÓÁÍÏÅ ÄÏÓÔÉÇÁÅÔÓÑ ËÏÍÁÎÄÏÊ ":source! {scriptin}". -åÓÌÉ ËÏÎÅà ÆÁÊÌÁ ÓÞÉÔÙ×ÁÅÔÓÑ ÄÏ ÚÁ×ÅÒÛÅÎÉÑ ÒÁÂÏÔÙ ÒÅÄÁËÔÏÒÁ, ÔÏ × ÄÁÌØÎÅÊÛÅÍ -××ÏÄ ÏÓÕÝÅÓÔ×ÌÑÅÔÓÑ Ó ËÌÁ×ÉÁÔÕÒÙ. -.TP --T {terminal} -óÏÏÂÝÁÅÔ -.B Vim -ÔÉÐ ÉÓÐÏÌØÚÕÅÍÏÇÏ ÔÅÒÍÉÎÁÌÁ. îÅÏÂÈÏÄÉÍÏ ÔÏÌØËÏ × ÔÅÈ ÓÉÔÕÁÃÉÑÈ, ËÏÇÄÁ -Á×ÔÏÍÁÔÉÞÅÓËÏÅ ÏÐÒÅÄÅÌÅÎÉÅ ÔÅÒÍÉÎÁÌÁ ÎÅ ÒÁÂÏÔÁÅÔ. éÍÑ ÔÅÒÍÉÎÁÌÁ ÄÏÌÖÎÏ ÂÙÔØ -ÉÚ×ÅÓÔÎÏ -.B Vim -(×ÓÔÒÏÅÎÏ × ÎÅÇÏ) ÉÌÉ ÏÐÒÅÄÅÌÅÎÏ × ÆÁÊÌÁÈ termcap ÉÌÉ terminfo. -.TP --u {vimrc} -éÓÐÏÌØÚÏ×ÁÔØ ËÏÍÁÎÄÙ ÉÚ ÆÁÊÌÁ ÓÃÅÎÁÒÉÑ {vimrc} ÄÌÑ ÎÁÓÔÒÏÊËÉ. -÷ÓÅ ÏÓÔÁÌØÎÙÅ ÆÁÊÌÙ ÎÁÓÔÒÏÅË ÐÒÏÐÕÓËÁÀÔÓÑ. -õÄÏÂÎÏ ÄÌÑ ÒÅÄÁËÔÉÒÏ×ÁÎÉÑ ÓÐÅÃÉÁÌØÎÙÈ ÔÉÐÏ× ÆÁÊÌÏ×. -þÔÏÂÙ ÉÚÂÅÖÁÔØ ÉÓÐÏÌØÚÏ×ÁÎÉÑ ÓÃÅÎÁÒÉÅ× ÎÁÓÔÒÏÅË ×ÏÏÂÝÅ, ÍÏÖÎÏ ÉÓÐÏÌØÚÏ×ÁÔØ -ÉÍÑ "NONE". óÍ. ":help initialization". -.TP --U {gvimrc} -éÓÐÏÌØÚÏ×ÁÔØ ËÏÍÁÎÄÙ ÉÚ ÆÁÊÌÁ ÓÃÅÎÁÒÉÑ {gvimrc} ÄÌÑ ÎÁÓÔÒÏÊËÉ ÇÒÁÆÉÞÅÓËÏÇÏ -ÉÎÔÅÒÆÅÊÓÁ. -÷ÓÅ ÏÓÔÁÌØÎÙÅ ÆÁÊÌÙ ÎÁÓÔÒÏÅË ÄÌÑ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ ÐÒÏÐÕÓËÁÀÔÓÑ. -þÔÏÂÙ ÉÚÂÅÖÁÔØ ÉÓÐÏÌØÚÏ×ÁÎÉÑ ÓÃÅÎÁÒÉÅ× ÎÁÓÔÒÏÅË ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ ×ÏÏÂÝÅ, -ÍÏÖÎÏ ÉÓÐÏÌØÚÏ×ÁÔØ ÉÍÑ "NONE". óÍ. ":help gui-init". -.TP --V -"âÏÌÔÌÉ×ÙÊ" ÒÅÖÉÍ. ÷Ù×ÏÄÉÔØ ÓÏÏÂÝÅÎÉÑ Ï ÔÏÍ, ËÁËÉÅ ÆÁÊÌÙ ÞÉÔÁÀÔÓÑ, É Ï -ÞÔÅÎÉÉ-ÚÁÐÉÓÉ ÆÁÊÌÁ viminfo. -.TP --v -úÁÐÕÓÔÉÔØ -.B Vim -× ÒÅÖÉÍÅ Vi, ËÁË ÂÕÄÔÏ ÉÓÐÏÌÎÑÅÍÙÊ ÆÁÊÌ ÉÍÅÅÔ ÉÍÑ "vi". éÍÅÅÔ ÓÍÙÓÌ ÔÏÌØËÏ ÅÓÌÉ -ÉÓÐÏÌÎÑÅÍÙÊ ÆÁÊÌ ÉÍÅÅÔ ÉÍÑ "ex". -.TP --w {scriptout} -÷ÓÅ ÓÉÍ×ÏÌÙ, ××ÅÄ£ÎÎÙÅ Ó ËÌÁ×ÉÁÔÕÒÙ ×ÐÌÏÔØ ÄÏ ÍÏÍÅÎÔÁ ÚÁ×ÅÒÛÅÎÉÑ ÒÁÂÏÔÙ, -ÚÁÐÉÓÙ×ÁÀÔÓÑ × ÆÁÊÌ {scriptout}. -õÄÏÂÎÏ × ÔÏÍ ÓÌÕÞÁÅ, ËÏÇÄÁ ×Ù ÈÏÔÉÔÅ ÓÏÚÄÁÔØ ÆÁÊÌ ÓÃÅÎÁÒÉÑ ÄÌÑ ÐÏÓÌÅÄÕÀÝÅÇÏ -ÉÓÐÏÌØÚÏ×ÁÎÉÑ Ó "vim -s" ÉÌÉ ":source!". åÓÌÉ ÆÁÊÌ {scriptout} ÕÖÅ ÓÕÝÅÓÔ×ÕÅÔ, -ÔÏ ÎÏ×ÙÅ ÓÉÍ×ÏÌÙ ÂÕÄÕÔ ÄÏÂÁ×ÌÑÀÔÓÑ × ËÏÎÅà ÆÁÊÌÁ. -.TP --W {scriptout} -ëÁË "-w", ÎÏ ÕÖÅ ÓÕÝÅÓÔ×ÕÀÝÉÊ ÆÁÊÌ ÂÕÄÅÔ ÐÅÒÅÚÁÐÉÓÁÎ. -.TP --x -ûÉÆÒÏ×ÁÔØ ÚÁÐÉÓÙ×ÁÅÍÙÅ ÆÁÊÌÙ. âÕÄÅÔ ×ÙÄÁÎÏ ÐÒÉÇÌÁÛÅÎÉÅ ××ÅÓÔÉ ÐÁÒÏÌØ. -.TP --X -îÅ ÐÏÄËÌÀÞÁÔØÓÑ Ë X-ÓÅÒ×ÅÒÕ. õÓËÏÒÑÅÔ ÚÁÇÒÕÚËÕ ÎÁ ËÏÎÓÏÌÉ, ÎÏ ÄÅÌÁÅÔ ÎÅ×ÏÚÍÏÖÎÙÍ -ÉÓÐÏÌØÚÏ×ÁÎÉÅ ÚÁÇÏÌÏ×ËÁ ÏËÎÁ É ÂÕÆÅÒÁ ÏÂÍÅÎÁ. -.TP --Z -ïÇÒÁÎÉÞÅÎÎÙÊ ÒÅÖÉÍ. òÁÂÏÔÁÅÔ ÔÁË ÖÅ, ËÁË É ÐÒÏÇÒÁÍÍÙ, ÎÁÞÉÎÁÀÝÉÅÓÑ Ó "r". -.TP --- -ëÏÎÅà ËÌÀÞÅÊ. ÷ÓÅ ÏÓÔÁÌØÎÙÅ ÁÒÇÕÍÅÎÔÙ ÒÁÓÓÍÁÔÒÉ×ÁÀÔÓÑ ËÁË ÉÍÅÎÁ ÆÁÊÌÏ×. -íÏÖÅÔ ÂÙÔØ ÉÓÐÏÌØÚÏ×ÁÎÏ ÄÌÑ ÐÒÁ×ËÉ ÆÁÊÌÏ×, ÉÍÅÎÁ ËÏÔÏÒÙÈ ÎÁÞÉÎÁÀÔÓÑ Ó ÄÅÆÉÓÁ. -.TP ---help -÷Ù×ÅÓÔÉ ËÒÁÔËÕÀ ÓÐÒÁ×ËÕ É ÚÁ×ÅÒÛÉÔØ ÒÁÂÏÔÕ. ôÏ ÖÅ, ÞÔÏ É "-h". -.TP ---version -÷Ù×ÅÓÔÉ ÉÎÆÏÒÍÁÃÉÀ Ï ×ÅÒÓÉÉ ÐÒÏÇÒÁÍÍÙ É ÚÁ×ÅÒÛÉÔØ ÒÁÂÏÔÕ. -.TP ---remote -ðÏÄËÌÀÞÉÔØÓÑ Ë ÓÅÒ×ÅÒÕ Vim É ÚÁÓÔÁ×ÉÔØ ÅÇÏ ÐÒÁ×ÉÔØ ÆÁÊÌÙ, ÕËÁÚÁÎÎÙÅ × -ÐÏÓÌÅÄÕÀÝÉÈ ÁÒÇÕÍÅÎÔÁÈ. åÓÌÉ ÓÅÒ×ÅÒ ÎÅ ÎÁÊÄÅÎ, ×Ù×ÏÄÉÔÓÑ ÐÒÅÄÕÐÒÅÖÄÅÎÉÅ, -Á ÆÁÊÌÙ ÐÒÁ×ÑÔÓÑ × ÍÅÓÔÎÏÊ ËÏÐÉÉ Vim. -.TP ---remote-expr {×ÙÒÁÖÅÎÉÅ} -ðÏÄËÌÀÞÉÔØÓÑ Ë ÓÅÒ×ÅÒÕ Vim É ×ÙÞÉÓÌÉÔØ ÎÁ Î£Í ÕËÁÚÁÎÎÏÅ {×ÙÒÁÖÅÎÉÅ}. -òÅÚÕÌØÔÁÔ ×ÙÞÉÓÌÅÎÉÑ ÂÕÄÅÔ ×Ù×ÅÄÅÎ × ÐÏÔÏË ÓÔÁÎÄÁÒÔÎÏÇÏ ×Ù×ÏÄÁ (stdout). -.TP ---remote-send {ËÌÀÞÉ} -ðÏÄËÌÀÞÉÔØÓÑ Ë ÓÅÒ×ÅÒÕ Vim É ÐÅÒÅÄÁÔØ ÅÍÕ ÕËÁÚÁÎÎÙÅ {ËÌÀÞÉ}. -.TP ---remote-silent -ëÁË "--remote", ÎÏ ÂÅÚ ×Ù×ÏÄÁ ÐÒÅÄÕÐÒÅÖÄÅÎÉÑ, ÅÓÌÉ ÓÅÒ×ÅÒ ÎÅ ÎÁÊÄÅÎ. -.TP ---remote-wait -ëÁË "--remote", ÎÏ Vim ÎÅ ÂÕÄÅÔ ÚÁ×ÅÒÛÁÔØ ÒÁÂÏÔÕ ÄÏ ÔÅÈ ÐÏÒ, ÐÏËÁ ÎÅ ÂÕÄÅÔ -×ÙÐÏÌÎÅÎÁ ÐÒÁ×ËÁ ×ÓÅÈ ÆÁÊÌÏ×. -.TP ---remote-wait-silent -ëÁË "--remote-wait", ÎÏ ÂÅÚ ×Ù×ÏÄÁ ÐÒÅÄÕÐÒÅÖÄÅÎÉÑ, ÅÓÌÉ ÓÅÒ×ÅÒ ÎÅ ÎÁÊÄÅÎ. -.TP ---serverlist -÷Ù×ÅÓÔÉ ÓÐÉÓÏË ×ÓÅÈ ÄÏÓÔÕÐÎÙÈ ÓÅÒ×ÅÒÏ× Vim. -.TP ---servername {ÉÍÑ} -éÓÐÏÌØÚÏ×ÁÔØ ÕËÁÚÁÎÎÏÅ {ÉÍÑ} × ËÁÞÅÓÔ×Å ÉÍÅÎÉ ÓÅÒ×ÅÒÁ. åÓÌÉ ËÌÀÞ -"--remote" ÎÅ ÕËÁÚÁÎ, ÔÏ {ÉÍÑ} ÐÒÉÓ×ÁÉ×ÁÅÔÓÑ ÄÁÎÎÏÊ ËÏÐÉÉ Vim, -× ÐÒÏÔÉ×ÎÏÍ ÓÌÕÞÁÅ ÕËÁÚÙ×ÁÅÔ ÎÁ ÉÍÑ ÓÅÒ×ÅÒÁ, Ë ËÏÔÏÒÏÍÕ ÓÌÅÄÕÅÔ -ÐÏÄËÌÀÞÉÔØÓÑ. -.TP ---socketid {id} -ôÏÌØËÏ ÄÌÑ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ GTK: ÉÓÐÏÌØÚÏ×ÁÔØ ÍÅÈÁÎÉÚÍ GtkPlug ÄÌÑ -ÚÁÐÕÓËÁ gvim × ÏÔÄÅÌØÎÏÍ ÏËÎÅ. -.TP ---echo-wid -ôÏÌØËÏ ÄÌÑ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ GTK: ×Ù×ÅÓÔÉ ÉÄÅÎÔÉÆÉËÁÔÏÒ ÏËÎÁ (Window ID) -× ÐÏÔÏË ÓÔÁÎÄÁÒÔÎÏÇÏ ×Ù×ÏÄÁ (stdout). -.SH ÷óôòïåîîáñ óðòá÷ëá -äÌÑ ÎÁÞÁÌÁ, ÎÁÂÅÒÉÔÅ ËÏÍÁÎÄÕ ":help". -÷×ÅÄÉÔÅ ":help ÔÅÍÁ", ÞÔÏÂÙ ÐÏÌÕÞÉÔØ ÓÐÒÁ×ËÕ ÐÏ ËÏÎËÒÅÔÎÏÊ ÔÅÍÅ. -îÁÐÒÉÍÅÒ, ËÏÍÁÎÄÁ ":help ZZ" ×Ù×ÅÄÅÔ ÉÎÆÏÒÍÁÃÉÀ Ï ËÏÍÁÎÄÅ "ZZ". -éÓÐÏÌØÚÕÊÔÅ <Tab> É CTRL-D ÄÌÑ Á×ÔÏÍÁÔÉÞÅÓËÏÇÏ ÄÏÐÏÌÎÅÎÉÑ -ÎÁÚ×ÁÎÉÊ ÔÅÍ (":help cmdline-completion"). -äÌÑ ÂÙÓÔÒÏÇÏ ÐÅÒÅÍÅÝÅÎÉÑ ÐÏ ÓÐÒÁ×ÏÞÎÉËÕ ÉÓÐÏÌØÚÕÀÔÓÑ ÍÅÔËÉ (ÞÔÏ-ÔÏ -×ÒÏÄÅ ÇÉÐÅÒÔÅËÓÔÏ×ÙÈ ÓÓÙÌÏË, ÓÍ. ":help"). ôÁËÉÍ ÏÂÒÁÚÏÍ ÍÏÖÎÏ -ÐÒÏÓÍÁÔÒÉ×ÁÔØ ×ÓÅ ÆÁÊÌÙ ÓÐÒÁ×ËÉ, ÎÁÐÒÉÍÅÒ ":help syntax.txt". -.SH æáêìù -.TP 15 -/usr/local/lib/vim/doc/*.txt -æÁÊÌÙ ÓÐÒÁ×ÏÞÎÉËÁ -.B Vim. -óÍ. ":help doc-file-list" ÄÌÑ ÐÏÌÕÞÅÎÉÑ ÐÏÌÎÏÇÏ ÓÐÉÓËÁ. -.TP -/usr/local/lib/vim/doc/tags -æÁÊÌ ÍÅÔÏË, ÉÓÐÏÌØÚÕÅÍÙÊ ÄÌÑ ÐÏÉÓËÁ ÉÎÆÏÒÍÁÃÉÉ × ÆÁÊÌÁÈ ÓÐÒÁ×ËÉ. -.TP -/usr/local/lib/vim/syntax/syntax.vim -óÉÓÔÅÍÎÙÅ ÎÁÓÔÒÏÊËÉ ÓÉÎÔÁËÓÉÓÁ. -.TP -/usr/local/lib/vim/syntax/*.vim -æÁÊÌÙ ÓÉÎÔÁËÓÉÓÁ ÄÌÑ ÒÁÚÎÙÈ ÑÚÙËÏ×. -.TP -/usr/local/lib/vim/vimrc -óÉÓÔÅÍÎÙÅ ÎÁÓÔÒÏÊËÉ -.B Vim. -.TP -/usr/local/lib/vim/gvimrc -óÉÓÔÅÍÎÙÊ ÎÁÓÔÒÏÊËÉ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ. -.TP -/usr/local/lib/vim/optwin.vim -óÃÅÎÁÒÉÊ, ÉÓÐÏÌØÚÕÅÍÙÊ ÐÒÉ ×ÙÐÏÌÎÅÎÉÉ ËÏÍÁÎÄÙ ":options". -èÏÒÏÛÉÊ ÓÐÏÓÏ ÐÒÏÓÍÁÔÒÉ×ÁÔØ É ÉÚÍÅÎÑÔØ ÎÁÓÔÒÏÊËÉ. -.TP -/usr/local/lib/vim/menu.vim -óÉÓÔÅÍÎÙÅ ÎÁÓÔÒÏÊËÉ ÍÅÎÀ ÄÌÑ gvim. -.TP -/usr/local/lib/vim/bugreport.vim -óÃÅÎÁÒÉÊ ÄÌÑ ÓÏÚÄÁÎÉÑ ÏÔÞ£ÔÁ Ï ÏÂÎÁÒÕÖÅÎÎÙÈ ÇÌÀËÁÈ. óÍ. ":help bugs". -.TP -/usr/local/lib/vim/filetype.vim -óÃÅÎÁÒÉÊ ÄÌÑ ÏÐÒÅÄÅÌÅÎÉÑ ÔÉÐÁ ÆÁÊÌÁ ÐÏ ÉÍÅÎÉ. óÍ. ":help 'filetype'". -.TP -/usr/local/lib/vim/scripts.vim -óÃÅÎÁÒÉÊ ÄÌÑ ÏÐÒÅÄÅÌÅÎÉÑ ÔÉÐÁ ÆÁÊÌÁ ÐÏ ÓÏÄÅÒÖÉÍÏÍÕ. óÍ. ":help 'filetype'". -.TP -/usr/local/lib/vim/print/*.ps -æÁÊÌÙ ÄÌÑ ÐÅÞÁÔÉ PostScript. -.PP -âÏÌÅÅ Ó×ÅÖÁÑ ÉÎÆÏÒÍÁÃÉÑ -- ÎÁ ÓÁÊÔÅ VIM: -.br -<URL:http://www.vim.org/> -.SH óíïôòé ôáëöå -vimtutor(1) -.SH á÷ôïòù -âÏÌØÛÁÑ ÞÁÓÔØ -.B Vim -ÓÏÚÄÁÎÁ âÒÁÍÏÍ íÏÏÌÅÎÁÁÒÏÍ (Bram Moolenaar), ËÏÔÏÒÏÍÕ ÐÏÍÏÇÁÅÔ ÏÇÒÏÍÎÏÅ -ËÏÌÉÞÅÓÔ×Ï ÌÀÄÅÊ. óÍ. ":help credits" × -.B Vim. -.br -.B Vim -ÂÁÚÉÒÕÅÔÓÑ ÎÁ ËÏÄÅ ÒÅÄÁËÔÏÒÁ Stevie, ÎÁÐÉÓÁÎÎÏÇÏ ôÉÍÏÍ ôÏÍÐÓÏÎÏÍ (Tim Thompson), -ôÏÎÉ üÎÄÒÀÓÏÍ (Tony Andrews) É ç. ò. (æÒÅÄÏÍ) õÏÌÔÅÒÏÍ (G.R. (Fred) Walter). -ïÄÎÁËÏ, × ÎÁÓÔÏÑÝÅÅ ×ÒÅÍÑ × Vim ÐÏÞÔÉ ÎÅ ÏÓÔÁÌÏÓØ ÎÉÞÅÇÏ ÏÔ ÉÓÔÏÒÉÞÅÓËÏÇÏ ËÏÄÁ -ÅÇÏ ÐÒÅÄÛÅÓÔ×ÅÎÎÉËÁ. -.br -òÕÓÓËÁÑ ÌÏËÁÌÉÚÁÃÉÑ -.B Vim -×ÙÐÏÌÎÑÅÔÓÑ × ÒÁÍËÁÈ ÐÒÏÅËÔÁ "òÕ÷ÉÍ", -ÓÍ. <URL:http://sourceforge.net/projects/ruvim/>. -.SH çìàëé -óËÏÒÅÅ ×ÓÅÇÏ ÅÓÔØ. -óÍ. ":help todo" -- ÓÐÉÓÏË ÉÚ×ÅÓÔÎÙÈ ÐÒÏÂÌÅÍ. -.PP -úÁÍÅÔÉÍ, ÞÔÏ ÍÎÏÇÉÅ ×ÅÝÉ, ËÏÔÏÒÙÅ ÓÞÉÔÁÀÔÓÑ ÇÌÀËÁÍÉ, ÎÁ ÓÁÍÏÍ ÄÅÌÅ -Ñ×ÌÑÀÔÓÑ ÒÅÚÕÌØÔÁÔÏÍ ÓÌÉÛËÏÍ ÐÏÌÎÏÇÏ ×ÏÓÐÒÏÉÚ×ÅÄÅÎÉÑ ÐÏ×ÅÄÅÎÉÑ Vi. -åÓÌÉ ×Ù ÄÕÍÁÅÔÅ, ÞÔÏ ÞÔÏ-ÔÏ Ñ×ÌÑÅÔÓÑ ÏÛÉÂËÏÊ ÔÏÌØËÏ ÐÏÔÏÍÕ, ÞÔÏ -"Vi ÄÅÌÁÅÔ ÜÔÏ ÐÏ-ÄÒÕÇÏÍÕ", ×ÎÉÍÁÔÅÌØÎÏ ÐÒÏÞÉÔÁÊÔÅ ÆÁÊÌ vi_diff.txt -(ÉÌÉ ÎÁÂÅÒÉÔÅ ":help vi_diff.txt" × Vim) É ÉÓÐÏÌØÚÕÊÔÅ ÏÐÃÉÉ 'compatible' -É 'cpoptions'. diff --git a/share/vim/vim72/doc/vim-ru.UTF-8.1 b/share/vim/vim72/doc/vim-ru.UTF-8.1 deleted file mode 100644 index 78127a1ccb..0000000000 --- a/share/vim/vim72/doc/vim-ru.UTF-8.1 +++ /dev/null @@ -1,489 +0,0 @@ -.TH VIM 1 "2002 Feb 22" -.SH ИМЯ -vim \- Vi IMproved (Улучшенный Vi), текстовый редактор для программистов -.SH КОМАНДНАЯ СТРОКА -.br -.B vim -[ключи] [файл ..] -.br -.B vim -[ключи] - -.br -.B vim -[ключи] \-t метка -.br -.B vim -[ключи] \-q [файл ошибок] -.PP -.br -.B ex -.br -.B view -.br -.B gvim -.B gview -.br -.B rvim -.B rview -.B rgvim -.B rgview -.SH ОПИСАНИЕ -.B Vim --- текстовый редактор, обратно-совместимый с Vi. -Он может быть использован для правки всех видов простого текста. -Особенно он хорош для правки исходных текстов программ. -.PP -По сравнению с Vi, -.B Vim -имеет много усовершенствований: многократная отмена операций, -множественность окон и буферов, подсветка синтаксиса, правка командной строки, -автодополнение имён файлов, встроенная справка, визуальное выделение и т.п. -См. ":help vi_diff.txt" для получения полного списка различий между -.B Vim -и Vi. -.PP -Во время работы в -.B Vim -можно получить справку с помощью системы встроенной справки (команда ":help"). -См. раздел "ВСТРОЕННАЯ СПРАВКА" ниже по тексту. -.PP -Чаще всего -.B Vim -запускают для правки одного файла при помощи команды -.PP - vim файл -.PP -В общем виде команда запуска -.B Vim -выглядит так: -.PP - vim [ключи] [список файлов] -.PP -Если список файлов отсутствует, редактор начнёт работу с пустым буфером. -В противном случае имя файла должно быть указано одним из следующих четырёх способов: -.TP 12 -файл .. -Список имён файлов. -Первый файл будет объявлен активным и загружен в буфер. Курсор будет помещён -в первой строке буфера. Доступ к другим файлам может быть осуществлён при -помощи команды ":next". Чтобы править файл, имя которого начинается с символа -"дефис" (-), перед списком файлов необходимо поставить "--". -.TP -- -Файл будет прочитан из потока стандартного ввода. Команды будут считываться -из стандартного потока диагностики (stderr), который должен быть -терминалом. -.TP --t {метка} -Имя файла и начальная позиция курсора зависят от "метки", похожей на метку goto. -{метка} ищется в файле меток, соответствующий файл становится активным, а -соответствующая команда исполняется. -Чаще всего используется в программах на языке Си, где {метка} может быть именем -функции. -Файл, содержащий функцию, становится активным, а курсор помещается в начало функции. -См. ":help tag-commands". -.TP --q [файл ошибок] -Начать работу в режиме быстрого исправления. -При этом считывается [файл ошибок] и первая ошибка выводится на экран. -Если [файл ошибок] не указан, имя файла берётся из значения опции 'errorfile' -(по умолчанию: "AztecC.Err" для Amiga, "errors.err" для других систем). -К следующим ошибкам можно перейти по команде ":cn". -См. ":help quickfix". -.PP -.B Vim -ведёт себя по-разному в зависимости от имени команды (исполняемый файл может -быть одним и тем же). -.TP 10 -vim -"Нормальный" запуск, всё по умолчанию. -.TP -ex -Запуск в режиме Ex. Для перехода в нормальный режим -необходимо выполнить команду ":vi". Режим Ex включает -также ключ "-e". -.TP -view -Запуск в режиме "только для чтения". Вы будете защищены от случайной записи -файла. То же самое можно сделать ключом "-R". -.TP -gvim gview -Версия с графическим интерфейсом. Запускается в новом окне. -То же самое можно сделать при запуске с ключом "-g". -.TP -rvim rview rgvim rgview -Как и предыдущие команды, но с ограничениями. Нельзя запускать команды оболочки -или приостанавливать работу -.B Vim. -Вместо приставки "r" можно использовать ключ "-Z". -.SH КЛЮЧИ -Ключи могут быть указаны в любом порядке, до или после имён -файлов. Ключи без аргументов могут быть объединены под одним -дефисом. -.TP 12 -+[номер] -В первом файле курсор будет помещён на строку с указанным номером. -Если "номер" не указан, курсор будет помещён на последнюю строку. -.TP -+/{шаблон} -В первом файле курсор будет помещён на место первого совпадения -с указанным шаблоном. См. ":help search-pattern" для получения -списка допустимых шаблонов. -.TP -+{команда} -.TP --c {команда} -{команда} исполняется после загрузки первого файла как команда Ex. -Если {команда} содержит пробелы, то она должна быть заключена в -двойные кавычки (в зависимости от используемой оболочки). -Пример: vim "+set si" main.c -.br -Примечание: Можно указывать до десяти команд "+" или "-c". -.TP ---cmd {команда} -Как "-c", но команда исполняется перед обработкой любого файла -настроек (vimrc). -Можно указывать до десяти таких команд, независимо от количества -команд "-c". -.TP --A -Если -.B Vim -был собран с поддержкой арабского языка для правки файлов, -набранных справа налево, и с поддержкой арабской клавиатуры, -этот ключ запускает -.B Vim -в арабском режиме, с включенной опцией 'arabic'. В противном -случае -.B Vim -завершает работу с ошибкой. -.TP --b -Двоичный режим. -Производится настройка некоторых опций, делающих возможной правку -двоичного или исполняемого файла. -.TP --C -Режим совместимости. Включает опцию 'compatible'. -.B Vim -будет работать почти как Vi, даже если существует файл .vimrc. -.TP --d -Режим поиска различий. -Должно быть указано два или три имени файла. -.B Vim -откроет все файлы и покажет различия между ними -(как vimdiff(1)). -.TP --d {устройство} -Открыть {устройство} для использования в качестве терминала (только на Amiga). -Пример: -"\-d con:20/30/600/150". -.TP --e -Запустить -.B Vim -в режиме Ex, как будто исполняемый файл имеет имя "ex". -.TP --f -Режим активного приложения. Версия -.B Vim -с графическим интерфейсом не будет ветвиться и отключаться -от запустившей её оболочки. На платформе Amiga -.B Vim -не будет создавать новое окно. Этот ключ нужно использовать, -когда -.B Vim -запускается программой, которая должна ждать завершения -сеанса правки (например, программа для работы с электронной почтой). -На платформе Amiga команды ":sh" и ":!" не будут работать. -.TP ---nofork -Режим активного приложения. Версия -.B Vim -с графическим интерфейсом не будет ветвиться и отключаться -от запустившей её оболочки. -.TP --F -Если -.B Vim -был собран с поддержкой FKMAP для правки текста справа налево -и настроек клавиатуры для языка фарси, этот ключ запускает -.B Vim -в режиме фарси, иначе говоря, с включёнными опциями -'fkmap' и 'rightleft'. -В противном случае -.B Vim -завершает работу с сообщением об ошибке. -.TP --g -Если -.B Vim -был собран с поддержкой графического интерфейса, этот ключ -включает графический интерфейс. В противном случае -.B Vim -завершает работу с сообщением об ошибке. -.TP --h -Выводит краткую информацию об аргументах и ключах командной строки. -После этого -.B Vim -завершает работу. -.TP --H -Если -.B Vim -был собран с поддержкой правки текста справа налево -и настроек клавиатуры для иврита, этот ключ запускает -.B Vim -в режиме иврита, иначе говоря, с включёнными опциями 'hkmap' и 'rightleft'. -В противном случае -.B Vim -завершает работу с сообщением об ошибке. -.TP --i {viminfo} -Если используется файл viminfo, то этот ключ задаёт имя такого файла (вместо -"~/.viminfo" по умолчанию). Можно также избежать использования файла viminfo -путём указания имени "NONE". -.TP --L -То же, что и -r. -.TP --l -Режим Lisp. Включаются опции 'lisp' и 'showmatch'. -.TP --m -Изменение файлов запрещено. При этом отключается опция 'write', поэтому -запись файлов становится невозможной. -.TP --N -Режим неполной совместимости. Отключается 'compatible'. -.B Vim -будет работать лучше, но не будет полностью совместим с Vi, даже если -отсутствует файл сценария настроек (.vimrc). -.TP --n -Не использовать своп-файл. Восстановление при сбое в работе будет невозможно. -Удобно для правки файла на очень медленном носителе (например, гибком диске). -То же самое можно сделать командой ":set uc=0". Отмена -- ":set uc=200". -.TP --o[N] -Открыть N окон, разделённых по горизонтали. Если N не указано, то открывается -по одному окну на каждый файл. -.TP --O[N] -Открыть N окон, разделённых по вертикали. Если N не указано, то открывается -по одному окну на каждый файл. -.TP --R -Режим "только для чтения". Включается опция 'readonly'. -Файл в буфере доступен для редактирования, но его копию на диске нельзя -случайно перезаписать. Для сохранения файла необходимо добавить восклицательный -знак к соответствующей команде Ex (например, ":w!"). -Ключ "-R" подразумевает также, что используется и ключ "-n" (см. выше). -Опция 'readonly' может быть выключена по команде ":set noro". -См. ":help 'readonly'". -.TP --r -Вывести список своп-файлов и информацию об их использовании для восстановления после сбоя. -.TP --r {файл} -Режим восстановления. -Для восстановления после сбоя будет использован своп-файл. -Своп-файл имеет то же имя, что и текстовый файл, но с добавлением расширения ".swp". -См. ":help recovery". -.TP --s -Тихий режим. Только при запуске как "Ex" или если перед "-s" указан ключ "-e". -.TP --s {scriptin} -Считывается файл сценария {scriptin}. При этом, содержимое файла воспринимается -в виде команд, как если бы они были набраны на консоли. -То же самое достигается командой ":source! {scriptin}". -Если конец файла считывается до завершения работы редактора, то в дальнейшем -ввод осуществляется с клавиатуры. -.TP --T {terminal} -Сообщает -.B Vim -тип используемого терминала. Необходимо только в тех ситуациях, когда -автоматическое определение терминала не работает. Имя терминала должно быть -известно -.B Vim -(встроено в него) или определено в файлах termcap или terminfo. -.TP --u {vimrc} -Использовать команды из файла сценария {vimrc} для настройки. -Все остальные файлы настроек пропускаются. -Удобно для редактирования специальных типов файлов. -Чтобы избежать использования сценариев настроек вообще, можно использовать -имя "NONE". См. ":help initialization". -.TP --U {gvimrc} -Использовать команды из файла сценария {gvimrc} для настройки графического -интерфейса. -Все остальные файлы настроек для графического интерфейса пропускаются. -Чтобы избежать использования сценариев настроек графического интерфейса вообще, -можно использовать имя "NONE". См. ":help gui-init". -.TP --V -"Болтливый" режим. Выводить сообщения о том, какие файлы читаются, и о -чтении-записи файла viminfo. -.TP --v -Запустить -.B Vim -в режиме Vi, как будто исполняемый файл имеет имя "vi". Имеет смысл только если -исполняемый файл имеет имя "ex". -.TP --w {scriptout} -Все символы, введённые с клавиатуры вплоть до момента завершения работы, -записываются в файл {scriptout}. -Удобно в том случае, когда вы хотите создать файл сценария для последующего -использования с "vim -s" или ":source!". Если файл {scriptout} уже существует, -то новые символы будут добавляются в конец файла. -.TP --W {scriptout} -Как "-w", но уже существующий файл будет перезаписан. -.TP --x -Шифровать записываемые файлы. Будет выдано приглашение ввести пароль. -.TP --X -Не подключаться к X-серверу. Ускоряет загрузку на консоли, но делает невозможным -использование заголовка окна и буфера обмена. -.TP --Z -Ограниченный режим. Работает так же, как и программы, начинающиеся с "r". -.TP --- -Конец ключей. Все остальные аргументы рассматриваются как имена файлов. -Может быть использовано для правки файлов, имена которых начинаются с дефиса. -.TP ---help -Вывести краткую справку и завершить работу. То же, что и "-h". -.TP ---version -Вывести информацию о версии программы и завершить работу. -.TP ---remote -Подключиться к серверу Vim и заставить его править файлы, указанные в -последующих аргументах. Если сервер не найден, выводится предупреждение, -а файлы правятся в местной копии Vim. -.TP ---remote-expr {выражение} -Подключиться к серверу Vim и вычислить на нём указанное {выражение}. -Результат вычисления будет выведен в поток стандартного вывода (stdout). -.TP ---remote-send {ключи} -Подключиться к серверу Vim и передать ему указанные {ключи}. -.TP ---remote-silent -Как "--remote", но без вывода предупреждения, если сервер не найден. -.TP ---remote-wait -Как "--remote", но Vim не будет завершать работу до тех пор, пока не будет -выполнена правка всех файлов. -.TP ---remote-wait-silent -Как "--remote-wait", но без вывода предупреждения, если сервер не найден. -.TP ---serverlist -Вывести список всех доступных серверов Vim. -.TP ---servername {имя} -Использовать указанное {имя} в качестве имени сервера. Если ключ -"--remote" не указан, то {имя} присваивается данной копии Vim, -в противном случае указывает на имя сервера, к которому следует -подключиться. -.TP ---socketid {id} -Только для графического интерфейса GTK: использовать механизм GtkPlug для -запуска gvim в отдельном окне. -.TP ---echo-wid -Только для графического интерфейса GTK: вывести идентификатор окна (Window ID) -в поток стандартного вывода (stdout). -.SH ВСТРОЕННАЯ СПРАВКА -Для начала, наберите команду ":help". -Введите ":help тема", чтобы получить справку по конкретной теме. -Например, команда ":help ZZ" выведет информацию о команде "ZZ". -Используйте <Tab> и CTRL-D для автоматического дополнения -названий тем (":help cmdline-completion"). -Для быстрого перемещения по справочнику используются метки (что-то -вроде гипертекстовых ссылок, см. ":help"). Таким образом можно -просматривать все файлы справки, например ":help syntax.txt". -.SH ФАЙЛЫ -.TP 15 -/usr/local/lib/vim/doc/*.txt -Файлы справочника -.B Vim. -См. ":help doc-file-list" для получения полного списка. -.TP -/usr/local/lib/vim/doc/tags -Файл меток, используемый для поиска информации в файлах справки. -.TP -/usr/local/lib/vim/syntax/syntax.vim -Системные настройки синтаксиса. -.TP -/usr/local/lib/vim/syntax/*.vim -Файлы синтаксиса для разных языков. -.TP -/usr/local/lib/vim/vimrc -Системные настройки -.B Vim. -.TP -/usr/local/lib/vim/gvimrc -Системный настройки графического интерфейса. -.TP -/usr/local/lib/vim/optwin.vim -Сценарий, используемый при выполнении команды ":options". -Хороший способ просматривать и изменять настройки. -.TP -/usr/local/lib/vim/menu.vim -Системные настройки меню для gvim. -.TP -/usr/local/lib/vim/bugreport.vim -Сценарий для создания отчёта об обнаруженных глюках. См. ":help bugs". -.TP -/usr/local/lib/vim/filetype.vim -Сценарий для определения типа файла по имени. См. ":help 'filetype'". -.TP -/usr/local/lib/vim/scripts.vim -Сценарий для определения типа файла по содержимому. См. ":help 'filetype'". -.TP -/usr/local/lib/vim/print/*.ps -Файлы для печати PostScript. -.PP -Более свежая информация -- на сайте VIM: -.br -<URL:http://www.vim.org/> -.SH СМОТРИ ТАКЖЕ -vimtutor(1) -.SH АВТОРЫ -Большая часть -.B Vim -создана Брамом Мооленааром (Bram Moolenaar), которому помогает огромное -количество людей. См. ":help credits" в -.B Vim. -.br -.B Vim -базируется на коде редактора Stevie, написанного Тимом Томпсоном (Tim Thompson), -Тони Эндрюсом (Tony Andrews) и Г. Р. (Фредом) Уолтером (G.R. (Fred) Walter). -Однако, в настоящее время в Vim почти не осталось ничего от исторического кода -его предшественника. -.br -Русская локализация -.B Vim -выполняется в рамках проекта "РуВим", -см. <URL:http://sourceforge.net/projects/ruvim/>. -.SH ГЛЮКИ -Скорее всего есть. -См. ":help todo" -- список известных проблем. -.PP -Заметим, что многие вещи, которые считаются глюками, на самом деле -являются результатом слишком полного воспроизведения поведения Vi. -Если вы думаете, что что-то является ошибкой только потому, что -"Vi делает это по-другому", внимательно прочитайте файл vi_diff.txt -(или наберите ":help vi_diff.txt" в Vim) и используйте опции 'compatible' -и 'cpoptions'. diff --git a/share/vim/vim72/doc/vimdiff-fr.1 b/share/vim/vim72/doc/vimdiff-fr.1 deleted file mode 100644 index 8341b50447..0000000000 --- a/share/vim/vim72/doc/vimdiff-fr.1 +++ /dev/null @@ -1,53 +0,0 @@ -.TH VIMDIFF 1 "30 mars 2001" -.SH NOM -vimdiff \- ouvre deux ou trois versions d'un fichier dans Vim et affiche -leurs différences -.SH SYNOPSIS -.br -.B vimdiff -[options] fichier1 fichier2 [fichier3] -.PP -.B gvimdiff -.SH DESCRIPTION -.B Vimdiff -démarre -.B Vim -avec deux (ou trois) fichiers. -Chaque fichier est ouvert dans sa propre fenêtre. -Les différences entres ces fichiers sont mises en surbrillance. -C'est un outil très pratique pour visualiser et reporter les -changements entre deux versions d'un même fichier. -.PP -Consulter vim(1) pour des informations sur l'éditeur Vim lui-même. -.PP -Si -.B gvimdiff -est invoqué, l'IHM graphique est démarrée quand elle est disponible. -.PP -L'option 'diff' est activée dans chacune des fenêtres, ce qui provoque la mise -en surbrillance des différences. -.br -Les options 'wrap' et 'scrollbind' sont activées pour donner un aspect -agréable au texte. -.br -L'option 'foldmethod' est fixée à "diff", ce qui replie les lignes consécutives -identiques. 'foldcolumn' est fixé à 2 pour trouver les replis rapidement et -les ouvrir ou les fermer facilement. -.SH ARGUMENTS -La fenêtre de Vim est partagée verticalement afin d'afficher les lignes -correspondantes les unes en face des autres, comme si l'argument "\-O" était -spécifié. Utilisez l'argument "\-o" pour obtenir un partage horizontal à la -place. -.PP -Pour connaître les autres arguments disponibles, consultez vim(1). -.SH VOIR AUSSI -vim(1) -.SH AUTEUR -La majeure partie de -.B Vim -a été écrite par Bram Moolenaar, avec l'aide de nombreux autres contributeurs. -Voir ":help credits" dans -.B Vim. -.SH TRADUCTION -Cette page de manuel a été traduite par David Blanchet -<david.blanchet@free.fr> 2005-03-12. diff --git a/share/vim/vim72/doc/vimdiff-fr.UTF-8.1 b/share/vim/vim72/doc/vimdiff-fr.UTF-8.1 deleted file mode 100644 index 5f09ee4b7e..0000000000 --- a/share/vim/vim72/doc/vimdiff-fr.UTF-8.1 +++ /dev/null @@ -1,53 +0,0 @@ -.TH VIMDIFF 1 "30 mars 2001" -.SH NOM -vimdiff \- ouvre deux ou trois versions d'un fichier dans Vim et affiche -leurs différences -.SH SYNOPSIS -.br -.B vimdiff -[options] fichier1 fichier2 [fichier3] -.PP -.B gvimdiff -.SH DESCRIPTION -.B Vimdiff -démarre -.B Vim -avec deux (ou trois) fichiers. -Chaque fichier est ouvert dans sa propre fenêtre. -Les différences entres ces fichiers sont mises en surbrillance. -C'est un outil très pratique pour visualiser et reporter les -changements entre deux versions d'un même fichier. -.PP -Consulter vim(1) pour des informations sur l'éditeur Vim lui-même. -.PP -Si -.B gvimdiff -est invoqué, l'IHM graphique est démarrée quand elle est disponible. -.PP -L'option 'diff' est activée dans chacune des fenêtres, ce qui provoque la mise -en surbrillance des différences. -.br -Les options 'wrap' et 'scrollbind' sont activées pour donner un aspect -agréable au texte. -.br -L'option 'foldmethod' est fixée à "diff", ce qui replie les lignes consécutives -identiques. 'foldcolumn' est fixé à 2 pour trouver les replis rapidement et -les ouvrir ou les fermer facilement. -.SH ARGUMENTS -La fenêtre de Vim est partagée verticalement afin d'afficher les lignes -correspondantes les unes en face des autres, comme si l'argument "\-O" était -spécifié. Utilisez l'argument "\-o" pour obtenir un partage horizontal à la -place. -.PP -Pour connaître les autres arguments disponibles, consultez vim(1). -.SH VOIR AUSSI -vim(1) -.SH AUTEUR -La majeure partie de -.B Vim -a été écrite par Bram Moolenaar, avec l'aide de nombreux autres contributeurs. -Voir ":help credits" dans -.B Vim. -.SH TRADUCTION -Cette page de manuel a été traduite par David Blanchet -<david.blanchet@free.fr> 2005-03-12. diff --git a/share/vim/vim72/doc/vimdiff-it.1 b/share/vim/vim72/doc/vimdiff-it.1 deleted file mode 100644 index 8d812283d1..0000000000 --- a/share/vim/vim72/doc/vimdiff-it.1 +++ /dev/null @@ -1,48 +0,0 @@ -.TH VIMDIFF 1 "30 marzo 2001" -.SH NOME -vimdiff \- modifica due o tre versioni di un file con Vim, visualizzando le -differenze -.SH SINTASSI -.br -.B vimdiff -[opzioni] file1 file2 [file3] -.PP -.B gvimdiff -.SH DESCRIZIONE -.B Vimdiff -inizia -.B Vim -per due (o tre) file. -Ogni file ha una sua finestra. -Le differenze fra file sono evidenziate. -E' una maniera elegante per controllare modifiche e portare modifiche -verso un'altra versione dello stesso file. -.PP -Vedere vim(1) per dettagli su Vim in generale. -.PP -Se iniziato con -.B gvimdiff -la GUI sarà utilizzata, se disponibile. -.PP -In ogni finestra l'opzione 'diff' è impostata, evidenziando così le -differenze. -.br -Le opzioni 'wrap' e 'scrollbind' sono impostate per migliorare la -visibilità del testo. -.br -L'opzione 'foldmethod' è impostata al valore "diff", che mette gruppi di -linee uguali fra i diversi file in una piegatura. 'foldcolumn' è impostato -a due per poter facilmente visualizzare le piegature, aprirle e chiuderle. -.SH OPZIONI -Lo schermo è diviso verticalmente, come se aveste usato l'opzione "\-O". -Per dividerlo orizzontalmente, usare l'opzione "\-o". -.PP -Per tutte le altre opzioni, vedere vim(1). -.SH VEDERE ANCHE -vim(1) -.SH AUTORE -Buona parte di -.B Vim -è stato scritto da Bram Moolenaar, con molto aiuto da altri. -Vedere ":help credits" in -.B Vim. diff --git a/share/vim/vim72/doc/vimdiff-it.UTF-8.1 b/share/vim/vim72/doc/vimdiff-it.UTF-8.1 deleted file mode 100644 index e71e774e8b..0000000000 --- a/share/vim/vim72/doc/vimdiff-it.UTF-8.1 +++ /dev/null @@ -1,48 +0,0 @@ -.TH VIMDIFF 1 "30 marzo 2001" -.SH NOME -vimdiff \- modifica due o tre versioni di un file con Vim, visualizzando le -differenze -.SH SINTASSI -.br -.B vimdiff -[opzioni] file1 file2 [file3] -.PP -.B gvimdiff -.SH DESCRIZIONE -.B Vimdiff -inizia -.B Vim -per due (o tre) file. -Ogni file ha una sua finestra. -Le differenze fra file sono evidenziate. -E' una maniera elegante per controllare modifiche e portare modifiche -verso un'altra versione dello stesso file. -.PP -Vedere vim(1) per dettagli su Vim in generale. -.PP -Se iniziato con -.B gvimdiff -la GUI sarà utilizzata, se disponibile. -.PP -In ogni finestra l'opzione 'diff' è impostata, evidenziando così le -differenze. -.br -Le opzioni 'wrap' e 'scrollbind' sono impostate per migliorare la -visibilità del testo. -.br -L'opzione 'foldmethod' è impostata al valore "diff", che mette gruppi di -linee uguali fra i diversi file in una piegatura. 'foldcolumn' è impostato -a due per poter facilmente visualizzare le piegature, aprirle e chiuderle. -.SH OPZIONI -Lo schermo è diviso verticalmente, come se aveste usato l'opzione "\-O". -Per dividerlo orizzontalmente, usare l'opzione "\-o". -.PP -Per tutte le altre opzioni, vedere vim(1). -.SH VEDERE ANCHE -vim(1) -.SH AUTORE -Buona parte di -.B Vim -è stato scritto da Bram Moolenaar, con molto aiuto da altri. -Vedere ":help credits" in -.B Vim. diff --git a/share/vim/vim72/doc/vimdiff-pl.1 b/share/vim/vim72/doc/vimdiff-pl.1 deleted file mode 100644 index ac3de3f8ed..0000000000 --- a/share/vim/vim72/doc/vimdiff-pl.1 +++ /dev/null @@ -1,46 +0,0 @@ -.TH VIMDIFF 1 "2001 Mar 30" -.SH NAZWA -vimdiff \- edytuj dwie lub trzy wersje pliku w Vimie i zobacz ró¿nice -.SH SYNOPSIS -.br -.B vimdiff -[opcje] plik1 plik2 [plik3] -.PP -.B gvimdiff -.SH OPIS -.B Vimdiff -uruchomi -.B Vima -z dwoma (lub trzema plikami), ka¿dy z nich we w³asnym oknie. -Ró¿nice miêdzy plikami zostan± pod¶wietlone. -Jest to dobry sposób by przeanalizowaæ ró¿nice i przenie¶æ zmiany z jednej -wersji pliku do innej. -.PP -Zobacz vim(1) by poznaæ wiêcej szczegó³ów o samym Vimie. -.PP -Kiedy uruchomiony jako -.B gvimdiff -zostanie uruchomione GUI (je¶li dostêpne). -.PP -W ka¿dym oknie zostanie ustawiona opcja 'diff', która spowoduje -pod¶wietlenie ró¿nic. -.br -Opcje 'wrap' i 'scrollbind' zostan± ustawione by tekst dobrze siê -przegl±da³o. -.br -Opcja 'foldmethod' zostanie ustawiona na "diff", dziêki temu -niezmienione linie zostan± zwiniête. 'foldcolumn' bêdzie równe 2 aby -³atwo wyszukiwaæ, otwieraæ i zamykaæ zwiniêcia. -.SH OPCJE -Pionowy podzia³ jest u¿yty do wyrównania linii, tak jakby u¿yto -opcji "\-O". Aby uzyskaæ poziomy podzia³ u¿yj opcji "\-o". -.PP -Aby poznaæ inne opcje zobacz vim(1). -.SH ZOBACZ TAK¯E -vim(1) -.SH AUTOR -Wiêkszo¶æ -.B Vima -zosta³a napisana przez Brama Moolenaara przy pomocy wielu innych osób. -Zobacz ":help credits w -.B Vimie. diff --git a/share/vim/vim72/doc/vimdiff-pl.UTF-8.1 b/share/vim/vim72/doc/vimdiff-pl.UTF-8.1 deleted file mode 100644 index 0d9186eb47..0000000000 --- a/share/vim/vim72/doc/vimdiff-pl.UTF-8.1 +++ /dev/null @@ -1,46 +0,0 @@ -.TH VIMDIFF 1 "2001 Mar 30" -.SH NAZWA -vimdiff \- edytuj dwie lub trzy wersje pliku w Vimie i zobacz różnice -.SH SYNOPSIS -.br -.B vimdiff -[opcje] plik1 plik2 [plik3] -.PP -.B gvimdiff -.SH OPIS -.B Vimdiff -uruchomi -.B Vima -z dwoma (lub trzema plikami), każdy z nich we własnym oknie. -Różnice między plikami zostaną podświetlone. -Jest to dobry sposób by przeanalizować różnice i przenieść zmiany z jednej -wersji pliku do innej. -.PP -Zobacz vim(1) by poznać więcej szczegółów o samym Vimie. -.PP -Kiedy uruchomiony jako -.B gvimdiff -zostanie uruchomione GUI (jeśli dostępne). -.PP -W każdym oknie zostanie ustawiona opcja 'diff', która spowoduje -podświetlenie różnic. -.br -Opcje 'wrap' i 'scrollbind' zostaną ustawione by tekst dobrze się -przeglądało. -.br -Opcja 'foldmethod' zostanie ustawiona na "diff", dzięki temu -niezmienione linie zostaną zwinięte. 'foldcolumn' będzie równe 2 aby -łatwo wyszukiwać, otwierać i zamykać zwinięcia. -.SH OPCJE -Pionowy podział jest użyty do wyrównania linii, tak jakby użyto -opcji "\-O". Aby uzyskać poziomy podział użyj opcji "\-o". -.PP -Aby poznać inne opcje zobacz vim(1). -.SH ZOBACZ TAKŻE -vim(1) -.SH AUTOR -Większość -.B Vima -została napisana przez Brama Moolenaara przy pomocy wielu innych osób. -Zobacz ":help credits w -.B Vimie. diff --git a/share/vim/vim72/doc/vimdiff-ru.1 b/share/vim/vim72/doc/vimdiff-ru.1 deleted file mode 100644 index 7517f87e03..0000000000 --- a/share/vim/vim72/doc/vimdiff-ru.1 +++ /dev/null @@ -1,50 +0,0 @@ -.TH VIMDIFF 1 "2001 March 30" -.SH éíñ -vimdiff \- ÐÏÚ×ÏÌÑÅÔ ÒÅÄÁËÔÉÒÏ×ÁÔØ Ä×Å ÉÌÉ ÔÒÉ ×ÅÒÓÉÉ ÆÁÊÌÁ Ó ÐÏÍÏÝØÀ Vim -Ó ÏÔÏÂÒÁÖÅÎÉÅÍ ÒÁÚÌÉÞÉÊ. -.SH ëïíáîäîáñ óôòïëá -.br -.B vimdiff -[ËÌÀÞÉ] ÆÁÊÌ1 ÆÁÊÌ2 [ÆÁÊÌ3] -.PP -.B gvimdiff -.SH ïðéóáîéå -ëÏÍÁÎÄÁ -.B vimdiff -ÚÁÇÒÕÖÁÅÔ × -.B Vim -Ä×Á (ÉÌÉ ÔÒÉ) ÆÁÊÌÁ. ëÁÖÄÙÊ ÆÁÊÌ ÏÔËÒÙ×ÁÅÔÓÑ × ÓÏÂÓÔ×ÅÎÎÏÍ ÏËÎÅ. -òÁÚÌÉÞÉÑ ÍÅÖÄÕ ÆÁÊÌÁÍÉ ÏÔÏÂÒÁÖÁÀÔÓÑ Ó ÐÏÍÏÝØÀ ÐÏÄÓ×ÅÔËÉ ÓÉÎÔÁËÓÉÓÁ. -üÔÁ ËÏÍÁÎÄÁ ÐÏÚ×ÏÌÑÅÔ ÎÁÇÌÑÄÎÏ ÏÔÏÂÒÁÖÁÔØ ×ÎÅÓ£ÎÎÙÅ ÉÚÍÅÎÅÎÉÑ É ÐÅÒÅÎÏÓÉÔØ -ÒÁÚÌÉÞÁÀÝÉÅÓÑ ÆÒÁÇÍÅÎÔÙ ÉÚ ÏÄÎÏÊ ×ÅÒÓÉÉ ÆÁÊÌÁ × ÄÒÕÇÕÀ. -.PP -ðÏÄÒÏÂÎÅÅ Ï Vim ÓÍ. ÎÁ ÓÔÒÁÎÉÃÅ ÓÐÒÁ×ÏÞÎÉËÁ vim(1). -.PP -ðÒÉ ÚÁÐÕÓËÅ Ó ÐÏÍÏÝØÀ ËÏÍÁÎÄÙ -.B gvimdiff -ÒÅÄÁËÔÏÒ ÚÁÐÕÓËÁÅÔÓÑ × ÒÅÖÉÍÅ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ, ÅÓÌÉ ÜÔÏ ×ÏÚÍÏÖÎÏ. -.PP -÷ ËÁÖÄÏÍ ÏËÎÅ ×ËÌÀÞÁÅÔÓÑ ÏÐÃÉÑ 'diff', ÞÔÏ ÐÏÚ×ÏÌÑÅÔ ÉÓÐÏÌØÚÏ×ÁÔØ ÐÏÄÓ×ÅÔËÕ -ÓÉÎÔÁËÓÉÓÁ ÄÌÑ ÏÔÏÂÒÁÖÅÎÉÑ ÒÁÚÌÉÞÉÊ ÍÅÖÄÕ ÆÁÊÌÁÍÉ. -.br -äÌÑ ÕÌÕÞÛÅÎÉÑ ÒÁÂÏÔÙ Ó ÆÁÊÌÁÍÉ × ÒÅÖÉÍÅ ÏÔÏÂÒÁÖÅÎÉÑ ÏÔÌÉÞÉÊ ÔÁËÖÅ ×ËÌÀÞÁÀÔÓÑ -ÏÐÃÉÉ 'wrap' É 'scrollbind'. -.br -úÎÁÞÅÎÉÅ ÏÐÃÉÉ 'foldmethod' ÕÓÔÁÎÁ×ÌÉ×ÁÅÔÓÑ ÒÁ×ÎÙÍ "diff", ÞÔÏ ÐÏÚ×ÏÌÑÅÔ -ÐÒÑÔÁÔØ × ÓËÌÁÄËÕ ÏÂÌÁÓÔÉ ÔÅËÓÔÁ, ËÏÔÏÒÙÅ ÎÅ ÏÔÌÉÞÁÀÔÓÑ × ÒÁÚÌÉÞÎÙÈ ×ÅÒÓÉÑÈ ÆÁÊÌÁ. -úÎÁÞÅÎÉÅ ÏÐÃÉÉ 'foldcolumn' ÕÓÔÁÎÁ×ÌÉ×ÁÅÔÓÑ ÒÁ×ÎÙÍ 2, ÞÔÏÂÙ ÂÙÌÏ ÐÒÏÝÅ -ÎÁÈÏÄÉÔØ, ÏÔËÒÙ×ÁÔØ É ÚÁËÒÙ×ÁÔØ ÔÁËÉÅ ÓËÌÁÄËÉ. -.SH ëìàþé úáðõóëá -äÌÑ ×ÙÒÁ×ÎÉ×ÁÎÉÑ ÓÔÒÏË ÍÅÖÄÕ ÏËÎÁÍÉ ÉÓÐÏÌØÚÕÅÔÓÑ ×ÅÒÔÉËÁÌØÎÏÅ ÒÁÚÄÅÌÅÎÉÅ ÏËÏÎ, -ËÁË ÅÓÌÉ ÂÙ ÉÓÐÏÌØÚÏ×ÁÌÓÑ ËÌÀÞ "-O". äÌÑ ÔÏÇÏ, ÞÔÏÂÙ ÉÓÐÏÌØÚÏ×ÁÔØ ÒÁÚÄÅÌÅÎÉÅ -ÏËÏÎ ÐÏ ÇÏÒÉÚÏÎÔÁÌÉ, ÓÌÅÄÕÅÔ ÕËÁÚÁÔØ × ËÏÍÁÎÄÎÏÊ ÓÔÒÏËÅ ËÌÀÞ "-o". -.PP -ïÓÔÁÌØÎÙÅ ËÌÀÞÉ ËÏÍÁÎÄÎÏÊ ÓÔÒÏËÉ ÒÁÓÓÍÁÔÒÉ×ÁÀÔÓÑ ÎÁ ÓÔÒÁÎÉÃÅ ÓÐÒÁ×ÏÞÎÉËÁ vim(1). -.SH óíïôòé ôáëöå -vim(1) -.SH á÷ôïòù -âÏÌØÛÁÑ ÞÁÓÔØ -.B Vim -ÓÏÚÄÁÎÁ âÒÁÍÏÍ íÏÏÌÅÎÁÁÒÏÍ (Bram Moolenaar), ËÏÔÏÒÏÍÕ ÐÏÍÏÇÁÅÔ ÏÇÒÏÍÎÏÅ -ËÏÌÉÞÅÓÔ×Ï ÌÀÄÅÊ. óÍ. ":help credits" × -.B Vim. diff --git a/share/vim/vim72/doc/vimdiff-ru.UTF-8.1 b/share/vim/vim72/doc/vimdiff-ru.UTF-8.1 deleted file mode 100644 index 978c905492..0000000000 --- a/share/vim/vim72/doc/vimdiff-ru.UTF-8.1 +++ /dev/null @@ -1,50 +0,0 @@ -.TH VIMDIFF 1 "2001 March 30" -.SH ИМЯ -vimdiff \- позволяет редактировать две или три версии файла с помощью Vim -с отображением различий. -.SH КОМАНДНАЯ СТРОКА -.br -.B vimdiff -[ключи] файл1 файл2 [файл3] -.PP -.B gvimdiff -.SH ОПИСАНИЕ -Команда -.B vimdiff -загружает в -.B Vim -два (или три) файла. Каждый файл открывается в собственном окне. -Различия между файлами отображаются с помощью подсветки синтаксиса. -Эта команда позволяет наглядно отображать внесённые изменения и переносить -различающиеся фрагменты из одной версии файла в другую. -.PP -Подробнее о Vim см. на странице справочника vim(1). -.PP -При запуске с помощью команды -.B gvimdiff -редактор запускается в режиме графического интерфейса, если это возможно. -.PP -В каждом окне включается опция 'diff', что позволяет использовать подсветку -синтаксиса для отображения различий между файлами. -.br -Для улучшения работы с файлами в режиме отображения отличий также включаются -опции 'wrap' и 'scrollbind'. -.br -Значение опции 'foldmethod' устанавливается равным "diff", что позволяет -прятать в складку области текста, которые не отличаются в различных версиях файла. -Значение опции 'foldcolumn' устанавливается равным 2, чтобы было проще -находить, открывать и закрывать такие складки. -.SH КЛЮЧИ ЗАПУСКА -Для выравнивания строк между окнами используется вертикальное разделение окон, -как если бы использовался ключ "-O". Для того, чтобы использовать разделение -окон по горизонтали, следует указать в командной строке ключ "-o". -.PP -Остальные ключи командной строки рассматриваются на странице справочника vim(1). -.SH СМОТРИ ТАКЖЕ -vim(1) -.SH АВТОРЫ -Большая часть -.B Vim -создана Брамом Мооленааром (Bram Moolenaar), которому помогает огромное -количество людей. См. ":help credits" в -.B Vim. diff --git a/share/vim/vim72/doc/vimtutor-fr.1 b/share/vim/vim72/doc/vimtutor-fr.1 deleted file mode 100644 index ab5d298908..0000000000 --- a/share/vim/vim72/doc/vimtutor-fr.1 +++ /dev/null @@ -1,55 +0,0 @@ -.TH VIMTUTOR 1 "2 avril 2001" -.SH NAME -vimtutor \- tutoriel Vim -.SH SYNOPSIS -.br -.B vimtutor [langue] -.SH DESCRIPTION -.B Vimtutor -lance le tutoriel -.B Vim -\. -Il copie d'abord le fichier du tutoriel, afin que vous puissiez le modifier -sans altérer le fichier original. -.PP -.B Vimtutor -est utile pour les personnes souhaitant apprendre leurs premières commandes -.B Vim -\. -.PP -L'argument optionnel [langue] est le nom d'une langue, spécifiée par son -symbole à deux lettres, tels que "it" ou "es". Si l'argument [langue] est omis, -la langue de la région linguistique actuelle sera retenue. Si le tutoriel est -disponible dans cette langue, il est proposé. Sinon, c'est la version anglaise -qui est proposée. -.PP -.B Vim -est toujours lancé en mode Compatible Vi. -.SH FICHIERS -.TP 15 -/usr/local/lib/vim/tutor/tutor[.langue] -Les fichiers textes de -.B Vimtutor -\. -.TP 15 -/usr/local/lib/vim/tutor/tutor.vim -Le script Vim utilisé pour copier les fichiers texte de -.B Vimtutor -\. -.SH AUTEUR -.B Vimtutor -a été écrit à l'origine pour Vi par Michael C. Pierce et Robert K. Ware, de la -Colorado School of Mines, en reprenant des idées émises par Charles Smith, de -la Colorado State University. -E-mail : bware@mines.colorado.edu. -.br -Il a été modifié pour -.B Vim -par Bram Moolenaar. -Pour connaître le nom des traducteurs, consultez les fichiers textes du -tutoriel. -.SH VOIR AUSSI -vim(1) -.SH TRADUCTION -Cette page de manuel a été traduite par David Blanchet -<david.blanchet@free.fr> 2004-12-27. diff --git a/share/vim/vim72/doc/vimtutor-fr.UTF-8.1 b/share/vim/vim72/doc/vimtutor-fr.UTF-8.1 deleted file mode 100644 index a41e163118..0000000000 --- a/share/vim/vim72/doc/vimtutor-fr.UTF-8.1 +++ /dev/null @@ -1,55 +0,0 @@ -.TH VIMTUTOR 1 "2 avril 2001" -.SH NAME -vimtutor \- tutoriel Vim -.SH SYNOPSIS -.br -.B vimtutor [langue] -.SH DESCRIPTION -.B Vimtutor -lance le tutoriel -.B Vim -\. -Il copie d'abord le fichier du tutoriel, afin que vous puissiez le modifier -sans altérer le fichier original. -.PP -.B Vimtutor -est utile pour les personnes souhaitant apprendre leurs premières commandes -.B Vim -\. -.PP -L'argument optionnel [langue] est le nom d'une langue, spécifiée par son -symbole à deux lettres, tels que "it" ou "es". Si l'argument [langue] est omis, -la langue de la région linguistique actuelle sera retenue. Si le tutoriel est -disponible dans cette langue, il est proposé. Sinon, c'est la version anglaise -qui est proposée. -.PP -.B Vim -est toujours lancé en mode Compatible Vi. -.SH FICHIERS -.TP 15 -/usr/local/lib/vim/tutor/tutor[.langue] -Les fichiers textes de -.B Vimtutor -\. -.TP 15 -/usr/local/lib/vim/tutor/tutor.vim -Le script Vim utilisé pour copier les fichiers texte de -.B Vimtutor -\. -.SH AUTEUR -.B Vimtutor -a été écrit à l'origine pour Vi par Michael C. Pierce et Robert K. Ware, de la -Colorado School of Mines, en reprenant des idées émises par Charles Smith, de -la Colorado State University. -E-mail : bware@mines.colorado.edu. -.br -Il a été modifié pour -.B Vim -par Bram Moolenaar. -Pour connaître le nom des traducteurs, consultez les fichiers textes du -tutoriel. -.SH VOIR AUSSI -vim(1) -.SH TRADUCTION -Cette page de manuel a été traduite par David Blanchet -<david.blanchet@free.fr> 2004-12-27. diff --git a/share/vim/vim72/doc/vimtutor-it.1 b/share/vim/vim72/doc/vimtutor-it.1 deleted file mode 100644 index 9adaa722c1..0000000000 --- a/share/vim/vim72/doc/vimtutor-it.1 +++ /dev/null @@ -1,54 +0,0 @@ -.TH VIMTUTOR 1 "2001 April 2" -.SH NOME -vimtutor \- the Vim tutor -.SH SINTASSI -.br -.B vimtutor [lingua] -.SH DESCRIZIONE -.B Vimtutor -inizia il -.B Vim -tutor. -It copies the tutor file first, so that it can be modified without changing -the original file. -.PP -The -.B Vimtutor -is useful for people that want to learn their first -.B Vim -commands. -.PP -The optional [language] argument is the two\-letter name of a language, like -"it" or "es". -If the [language] argument is missing, the language of the current locale will -be used. -If a tutor in this language is available, it will be used. -Otherwise the English version will be used. -.PP -.B Vim -is always started in Vi compatible mode. -.SH FILE -.TP 15 -/usr/local/lib/vim/tutor/tutor[.language] -The -.B Vimtutor -text file(s). -.TP 15 -/usr/local/lib/vim/tutor/tutor.vim -The Vim script used to copy the -.B Vimtutor -text file. -.SH AUTORE -The -.B Vimtutor -è stato scritto in origine per Vi da Michael C. Pierce e Robert K. Ware, -Colorado School of Mines, usando idee fornite da Charles Smith, -Colorado State University. -E\-mail: bware@mines.colorado.edu. -.br -E' stato modificato per -.B Vim -da Bram Moolenaar. -Per i nomi dei traduttori, vedere i file usati nelle rispettive lingue. -.SH VEDERE ANCHE -vim(1) diff --git a/share/vim/vim72/doc/vimtutor-it.UTF-8.1 b/share/vim/vim72/doc/vimtutor-it.UTF-8.1 deleted file mode 100644 index 2b65c3c031..0000000000 --- a/share/vim/vim72/doc/vimtutor-it.UTF-8.1 +++ /dev/null @@ -1,54 +0,0 @@ -.TH VIMTUTOR 1 "2001 April 2" -.SH NOME -vimtutor \- the Vim tutor -.SH SINTASSI -.br -.B vimtutor [lingua] -.SH DESCRIZIONE -.B Vimtutor -inizia il -.B Vim -tutor. -It copies the tutor file first, so that it can be modified without changing -the original file. -.PP -The -.B Vimtutor -is useful for people that want to learn their first -.B Vim -commands. -.PP -The optional [language] argument is the two\-letter name of a language, like -"it" or "es". -If the [language] argument is missing, the language of the current locale will -be used. -If a tutor in this language is available, it will be used. -Otherwise the English version will be used. -.PP -.B Vim -is always started in Vi compatible mode. -.SH FILE -.TP 15 -/usr/local/lib/vim/tutor/tutor[.language] -The -.B Vimtutor -text file(s). -.TP 15 -/usr/local/lib/vim/tutor/tutor.vim -The Vim script used to copy the -.B Vimtutor -text file. -.SH AUTORE -The -.B Vimtutor -è stato scritto in origine per Vi da Michael C. Pierce e Robert K. Ware, -Colorado School of Mines, usando idee fornite da Charles Smith, -Colorado State University. -E\-mail: bware@mines.colorado.edu. -.br -E' stato modificato per -.B Vim -da Bram Moolenaar. -Per i nomi dei traduttori, vedere i file usati nelle rispettive lingue. -.SH VEDERE ANCHE -vim(1) diff --git a/share/vim/vim72/doc/vimtutor-pl.1 b/share/vim/vim72/doc/vimtutor-pl.1 deleted file mode 100644 index a7ac50f62a..0000000000 --- a/share/vim/vim72/doc/vimtutor-pl.1 +++ /dev/null @@ -1,48 +0,0 @@ -.TH VIMTUTOR 1 "2001 Kwi 2" -.SH NAZWA -vimtutor \- nauczyciel Vima -.SH SYNOPSIS -.br -.B vimtutor [jêzyk] -.SH OPIS -.B Vimtutor -uruchamia nauczycie -.B Vima. -Najpierw kopiuje w³a¶ciwy plik, dziêki temu mo¿na go zmieniaæ bez obaw -utraty tre¶ci. -.PP -.B Vimtutor -przyda siê ludziom, którzy chc± siê nauczyæ pierwszych poleceñ -.B Vima -.PP -Opcjonalny argument [jêzyk] jest dwu literowym kodem jêzyka, tak jak -"it" lub "es". -Je¶li brak argumentu [jêzyk] zostanie u¿yty jêzyk bie¿±cej -lokalizacji. -Je¶li nauczyciel w tym jêzyku jest dostêpny, zostanie u¿yty \- w innym -wypadku zostanie wykorzystana wersja angielska. -.PP -.B Vim -jest uruchamiany zawsze w trybie kompatybilno¶ci z Vi -.SH PLIKI -.TP 15 -/usr/local/lib/vim/tutor/tutor[.languague] -Tekstowe pliki -.B Vimtutora. -.TP 15 -/usr/local/lib/vim/tutor/tutor.vim -Skrypt Vima u¿ywany do kopiowania pliku -.B Vimtutora. -.SH AUTOR -.B Vimtutor -zosta³ pocz±tkowo napisany dla Vim przez Michaela C. Pierce'a -i Roberta K. Ware'a z Colorado School of Mines zainspirowani przez -Charlesa Smitha z Colorado State University. -E-mail: bware@mines.colorado.edu -.br -Zmodyfikowany na potrzeby -.B Vima -przez Brama Moolenaara. -Nazwiska t³umaczy w plikach. -.SH ZOBACZ TAK¯E -vim(1) diff --git a/share/vim/vim72/doc/vimtutor-pl.UTF-8.1 b/share/vim/vim72/doc/vimtutor-pl.UTF-8.1 deleted file mode 100644 index 78ee1be632..0000000000 --- a/share/vim/vim72/doc/vimtutor-pl.UTF-8.1 +++ /dev/null @@ -1,48 +0,0 @@ -.TH VIMTUTOR 1 "2001 Kwi 2" -.SH NAZWA -vimtutor \- nauczyciel Vima -.SH SYNOPSIS -.br -.B vimtutor [język] -.SH OPIS -.B Vimtutor -uruchamia nauczycie -.B Vima. -Najpierw kopiuje właściwy plik, dzięki temu można go zmieniać bez obaw -utraty treści. -.PP -.B Vimtutor -przyda się ludziom, którzy chcą się nauczyć pierwszych poleceń -.B Vima -.PP -Opcjonalny argument [język] jest dwu literowym kodem języka, tak jak -"it" lub "es". -Jeśli brak argumentu [język] zostanie użyty język bieżącej -lokalizacji. -Jeśli nauczyciel w tym języku jest dostępny, zostanie użyty \- w innym -wypadku zostanie wykorzystana wersja angielska. -.PP -.B Vim -jest uruchamiany zawsze w trybie kompatybilności z Vi -.SH PLIKI -.TP 15 -/usr/local/lib/vim/tutor/tutor[.languague] -Tekstowe pliki -.B Vimtutora. -.TP 15 -/usr/local/lib/vim/tutor/tutor.vim -Skrypt Vima używany do kopiowania pliku -.B Vimtutora. -.SH AUTOR -.B Vimtutor -został początkowo napisany dla Vim przez Michaela C. Pierce'a -i Roberta K. Ware'a z Colorado School of Mines zainspirowani przez -Charlesa Smitha z Colorado State University. -E-mail: bware@mines.colorado.edu -.br -Zmodyfikowany na potrzeby -.B Vima -przez Brama Moolenaara. -Nazwiska tłumaczy w plikach. -.SH ZOBACZ TAKŻE -vim(1) diff --git a/share/vim/vim72/doc/vimtutor.1 b/share/vim/vim72/doc/vimtutor.1 deleted file mode 100644 index 12bde7e485..0000000000 --- a/share/vim/vim72/doc/vimtutor.1 +++ /dev/null @@ -1,57 +0,0 @@ -.TH VIMTUTOR 1 "2001 April 2" -.SH NAME -vimtutor \- the Vim tutor -.SH SYNOPSIS -.br -.B vimtutor [-g] [language] -.SH DESCRIPTION -.B Vimtutor -starts the -.B Vim -tutor. -It copies the tutor file first, so that it can be modified without changing -the original file. -.PP -The -.B Vimtutor -is useful for people that want to learn their first -.B Vim -commands. -.PP -The optional argument -g starts vimtutor with gvim rather than vim, if the -GUI version of vim is available, or falls back to Vim if gvim is not found. -.PP -The optional [language] argument is the two-letter name of a language, like -"it" or "es". -If the [language] argument is missing, the language of the current locale will -be used. -If a tutor in this language is available, it will be used. -Otherwise the English version will be used. -.PP -.B Vim -is always started in Vi compatible mode. -.SH FILES -.TP 15 -/usr/local/lib/vim/tutor/tutor[.language] -The -.B Vimtutor -text file(s). -.TP 15 -/usr/local/lib/vim/tutor/tutor.vim -The Vim script used to copy the -.B Vimtutor -text file. -.SH AUTHOR -The -.B Vimtutor -was originally written for Vi by Michael C. Pierce and Robert K. Ware, -Colorado School of Mines using ideas supplied by Charles Smith, -Colorado State University. -E-mail: bware@mines.colorado.edu. -.br -It was modified for -.B Vim -by Bram Moolenaar. -For the names of the translators see the tutor files. -.SH SEE ALSO -vim(1) diff --git a/share/vim/vim72/doc/vimtutor.man b/share/vim/vim72/doc/vimtutor.man deleted file mode 100644 index 6399d23b52..0000000000 --- a/share/vim/vim72/doc/vimtutor.man +++ /dev/null @@ -1,50 +0,0 @@ -VIMTUTOR(1) VIMTUTOR(1) - - - -NAME - vimtutor - the Vim tutor - -SYNOPSIS - vimtutor [-g] [language] - -DESCRIPTION - Vimtutor starts the Vim tutor. It copies the tutor file first, so that - it can be modified without changing the original file. - - The Vimtutor is useful for people that want to learn their first Vim - commands. - - The optional argument -g starts vimtutor with gvim rather than vim, if - the GUI version of vim is available, or falls back to Vim if gvim is - not found. - - The optional [language] argument is the two-letter name of a language, - like "it" or "es". If the [language] argument is missing, the language - of the current locale will be used. If a tutor in this language is - available, it will be used. Otherwise the English version will be - used. - - Vim is always started in Vi compatible mode. - -FILES - /usr/local/lib/vim/tutor/tutor[.language] - The Vimtutor text file(s). - - /usr/local/lib/vim/tutor/tutor.vim - The Vim script used to copy the Vimtutor text file. - -AUTHOR - The Vimtutor was originally written for Vi by Michael C. Pierce and - Robert K. Ware, Colorado School of Mines using ideas supplied by - Charles Smith, Colorado State University. E-mail: bware@mines.col- - orado.edu. - It was modified for Vim by Bram Moolenaar. For the names of the trans- - lators see the tutor files. - -SEE ALSO - vim(1) - - - - 2001 April 2 VIMTUTOR(1) diff --git a/share/vim/vim72/doc/visual.txt b/share/vim/vim72/doc/visual.txt deleted file mode 100644 index e817f0908f..0000000000 --- a/share/vim/vim72/doc/visual.txt +++ /dev/null @@ -1,499 +0,0 @@ -*visual.txt* For Vim version 7.2. Last change: 2006 Sep 26 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Visual mode *Visual* *Visual-mode* *visual-mode* - -Visual mode is a flexible and easy way to select a piece of text for an -operator. It is the only way to select a block of text. - -This is introduced in section |04.4| of the user manual. - -1. Using Visual mode |visual-use| -2. Starting and stopping Visual mode |visual-start| -3. Changing the Visual area |visual-change| -4. Operating on the Visual area |visual-operators| -5. Blockwise operators |blockwise-operators| -6. Repeating |visual-repeat| -7. Examples |visual-examples| -8. Select mode |Select-mode| - -{Vi has no Visual mode, the name "visual" is used for Normal mode, to -distinguish it from Ex mode} -{not available when the |+visual| feature was disabled when compiling} - -============================================================================== -1. Using Visual mode *visual-use* - -Using Visual mode consists of three parts: -1. Mark the start of the text with "v", "V" or CTRL-V. - The character under the cursor will be used as the start. -2. Move to the end of the text. - The text from the start of the Visual mode up to and including the - character under the cursor is highlighted. -3. Type an operator command. - The highlighted characters will be operated upon. - -The 'highlight' option can be used to set the display mode to use for -highlighting in Visual mode. -The 'virtualedit' option can be used to allow positioning the cursor to -positions where there is no actual character. - -The highlighted text normally includes the character under the cursor. -However, when the 'selection' option is set to "exclusive" and the cursor is -after the Visual area, the character under the cursor is not included. - -With "v" the text before the start position and after the end position will -not be highlighted. However, all uppercase and non-alpha operators, except -"~" and "U", will work on whole lines anyway. See the list of operators -below. - - *visual-block* -With CTRL-V (blockwise Visual mode) the highlighted text will be a rectangle -between start position and the cursor. However, some operators work on whole -lines anyway (see the list below). The change and substitute operators will -delete the highlighted text and then start insertion at the top left -position. - -============================================================================== -2. Starting and stopping Visual mode *visual-start* - - *v* *characterwise-visual* -v start Visual mode per character. - - *V* *linewise-visual* -V start Visual mode linewise. - - *CTRL-V* *blockwise-visual* -CTRL-V start Visual mode blockwise. Note: Under Windows - CTRL-V could be mapped to paste text, it doesn't work - to start Visual mode then, see |CTRL-V-alternative|. - -If you use <Esc>, click the left mouse button or use any command that -does a jump to another buffer while in Visual mode, the highlighting stops -and no text is affected. Also when you hit "v" in characterwise Visual mode, -"CTRL-V" in blockwise Visual mode or "V" in linewise Visual mode. If you hit -CTRL-Z the highlighting stops and the editor is suspended or a new shell is -started |CTRL-Z|. - - new mode after typing: *v_v* *v_CTRL-V* *v_V* -old mode "v" "CTRL-V" "V" ~ - -Normal Visual blockwise Visual linewise Visual -Visual Normal blockwise Visual linewise Visual -blockwise Visual Visual Normal linewise Visual -linewise Visual Visual blockwise Visual Normal - - *gv* *v_gv* *reselect-Visual* -gv Start Visual mode with the same area as the previous - area and the same mode. - In Visual mode the current and the previous Visual - area are exchanged. - After using "p" or "P" in Visual mode the text that - was put will be selected. - - *<LeftMouse>* -<LeftMouse> Set the current cursor position. If Visual mode is - active it is stopped. Only when 'mouse' option is - contains 'n' or 'a'. If the position is within 'so' - lines from the last line on the screen the text is - scrolled up. If the position is within 'so' lines from - the first line on the screen the text is scrolled - down. - - *<RightMouse>* -<RightMouse> Start Visual mode if it is not active. The text from - the cursor position to the position of the click is - highlighted. If Visual mode was already active move - the start or end of the highlighted text, which ever - is closest, to the position of the click. Only when - 'mouse' option contains 'n' or 'a'. - - Note: when 'mousemodel' is set to "popup", - <S-LeftMouse> has to be used instead of <RightMouse>. - - *<LeftRelease>* -<LeftRelease> This works like a <LeftMouse>, if it is not at - the same position as <LeftMouse>. In an older version - of xterm you won't see the selected area until the - button is released, unless there is access to the - display where the xterm is running (via the DISPLAY - environment variable or the -display argument). Only - when 'mouse' option contains 'n' or 'a'. - -If Visual mode is not active and the "v", "V" or CTRL-V is preceded with a -count, the size of the previously highlighted area is used for a start. You -can then move the end of the highlighted area and give an operator. The type -of the old area is used (character, line or blockwise). -- Linewise Visual mode: The number of lines is multiplied with the count. -- Blockwise Visual mode: The number of lines and columns is multiplied with - the count. -- Normal Visual mode within one line: The number of characters is multiplied - with the count. -- Normal Visual mode with several lines: The number of lines is multiplied - with the count, in the last line the same number of characters is used as - in the last line in the previously highlighted area. -The start of the text is the Cursor position. If the "$" command was used as -one of the last commands to extend the highlighted text, the area will be -extended to the rightmost column of the longest line. - -If you want to highlight exactly the same area as the last time, you can use -"gv" |gv| |v_gv|. - - *v_<Esc>* -<Esc> In Visual mode: Stop Visual mode. - - *v_CTRL-C* -CTRL-C In Visual mode: Stop Visual mode. When insert mode is - pending (the mode message shows - "-- (insert) VISUAL --"), it is also stopped. - -============================================================================== -3. Changing the Visual area *visual-change* - - *v_o* -o Go to Other end of highlighted text: The current - cursor position becomes the start of the highlighted - text and the cursor is moved to the other end of the - highlighted text. The highlighted area remains the - same. - - *v_O* -O Go to Other end of highlighted text. This is like - "o", but in Visual block mode the cursor moves to the - other corner in the same line. When the corner is at - a character that occupies more than one position on - the screen (e.g., a <Tab>), the highlighted text may - change. - - *v_$* -When the "$" command is used with blockwise Visual mode, the right end of the -highlighted text will be determined by the longest highlighted line. This -stops when a motion command is used that does not move straight up or down. - -For moving the end of the block many commands can be used, but you cannot -use Ex commands, commands that make changes or abandon the file. Commands -(starting with) ".", "&", CTRL-^, "Z", CTRL-], CTRL-T, CTRL-R, CTRL-I -and CTRL-O cause a beep and Visual mode continues. - -When switching to another window on the same buffer, the cursor position in -that window is adjusted, so that the same Visual area is still selected. This -is especially useful to view the start of the Visual area in one window, and -the end in another. You can then use <RightMouse> (or <S-LeftMouse> when -'mousemodel' is "popup") to drag either end of the Visual area. - -============================================================================== -4. Operating on the Visual area *visual-operators* - -The operators that can be used are: - ~ switch case |v_~| - d delete |v_d| - c change (4) |v_c| - y yank |v_y| - > shift right (4) |v_>| - < shift left (4) |v_<| - ! filter through external command (1) |v_!| - = filter through 'equalprg' option command (1) |v_=| - gq format lines to 'textwidth' length (1) |v_gq| - -The objects that can be used are: - aw a word (with white space) |v_aw| - iw inner word |v_iw| - aW a WORD (with white space) |v_aW| - iW inner WORD |v_iW| - as a sentence (with white space) |v_as| - is inner sentence |v_is| - ap a paragraph (with white space) |v_ap| - ip inner paragraph |v_ip| - ab a () block (with parenthesis) |v_ab| - ib inner () block |v_ib| - aB a {} block (with braces) |v_aB| - iB inner {} block |v_iB| - a< a <> block (with <>) |v_a<| - i< inner <> block |v_i<| - a[ a [] block (with []) |v_a[| - i[ inner [] block |v_i[| - -Additionally the following commands can be used: - : start ex command for highlighted lines (1) |v_:| - r change (4) |v_r| - s change |v_s| - C change (2)(4) |v_C| - S change (2) |v_S| - R change (2) |v_R| - x delete |v_x| - D delete (3) |v_D| - X delete (2) |v_X| - Y yank (2) |v_Y| - p put |v_p| - J join (1) |v_J| - U make uppercase |v_U| - u make lowercase |v_u| - ^] find tag |v_CTRL-]| - I block insert |v_b_I| - A block append |v_b_A| - -(1): Always whole lines, see |:visual_example|. -(2): Whole lines when not using CTRL-V. -(3): Whole lines when not using CTRL-V, delete until the end of the line when - using CTRL-V. -(4): When using CTRL-V operates on the block only. - -Note that the ":vmap" command can be used to specifically map keys in Visual -mode. For example, if you would like the "/" command not to extend the Visual -area, but instead take the highlighted text and search for that: > - :vmap / y/<C-R>"<CR> -(In the <> notation |<>|, when typing it you should type it literally; you -need to remove the 'B' and '<' flags from 'cpoptions'.) - -If you want to give a register name using the """ command, do this just before -typing the operator character: "v{move-around}"xd". - -If you want to give a count to the command, do this just before typing the -operator character: "v{move-around}3>" (move lines 3 indents to the right). - - *{move-around}* -The {move-around} is any sequence of movement commands. Note the difference -with {motion}, which is only ONE movement command. - -Another way to operate on the Visual area is using the |/\%V| item in a -pattern. For example, to replace all '(' in the Visual area with '#': > - - :%s/\%V(/X/g - -============================================================================== -5. Blockwise operators *blockwise-operators* - -{not available when compiled without the |+visualextra| feature} - -Reminder: Use 'virtualedit' to be able to select blocks that start or end -after the end of a line or halfway a tab. - -Visual-block Insert *v_b_I* -With a blockwise selection, I{string}<ESC> will insert {string} at the start -of block on every line of the block, provided that the line extends into the -block. Thus lines that are short will remain unmodified. TABs are split to -retain visual columns. -See |v_b_I_example|. - -Visual-block Append *v_b_A* -With a blockwise selection, A{string}<ESC> will append {string} to the end of -block on every line of the block. There is some differing behavior where the -block RHS is not straight, due to different line lengths: - -1. Block was created with <C-v>$ - In this case the string is appended to the end of each line. -2. Block was created with <C-v>{move-around} - In this case the string is appended to the end of the block on each line, - and whitespace is inserted to pad to the end-of-block column. -See |v_b_A_example|. -Note: "I" and "A" behave differently for lines that don't extend into the -selected block. This was done intentionally, so that you can do it the way -you want. - -Visual-block change *v_b_c* -All selected text in the block will be replaced by the same text string. When -using "c" the selected text is deleted and Insert mode started. You can then -enter text (without a line break). When you hit <Esc>, the same string is -inserted in all previously selected lines. - -Visual-block Change *v_b_C* -Like using "c", but the selection is extended until the end of the line for -all lines. - - *v_b_<* -Visual-block Shift *v_b_>* -The block is shifted by 'shiftwidth'. The RHS of the block is irrelevant. The -LHS of the block determines the point from which to apply a right shift, and -padding includes TABs optimally according to 'ts' and 'et'. The LHS of the -block determines the point upto which to shift left. - Note: v_< padding is buggy if the Visual Block starts and ends in the same - TAB. (Vim 5.4c) -See |v_b_>_example|. -See |v_b_<_example|. - -Visual-block Replace *v_b_r* -Every screen char in the highlighted region is replaced with the same char, ie -TABs are split and the virtual whitespace is replaced, maintaining screen -layout. -See |v_b_r_example|. - - -============================================================================== -6. Repeating *visual-repeat* - -When repeating a Visual mode operator, the operator will be applied to the -same amount of text as the last time: -- Linewise Visual mode: The same number of lines. -- Blockwise Visual mode: The same number of lines and columns. -- Normal Visual mode within one line: The same number of characters. -- Normal Visual mode with several lines: The same number of lines, in the - last line the same number of characters as in the last line the last time. -The start of the text is the Cursor position. If the "$" command was used as -one of the last commands to extend the highlighted text, the repeating will -be applied up to the rightmost column of the longest line. - - -============================================================================== -7. Examples *visual-examples* - - *:visual_example* -Currently the ":" command works on whole lines only. When you select part of -a line, doing something like ":!date" will replace the whole line. If you -want only part of the line to be replaced you will have to make a mapping for -it. In a future release ":" may work on partial lines. - -Here is an example, to replace the selected text with the output of "date": > - :vmap _a <Esc>`>a<CR><Esc>`<i<CR><Esc>!!date<CR>kJJ - -(In the <> notation |<>|, when typing it you should type it literally; you -need to remove the 'B' and '<' flags from 'cpoptions') - -What this does is: -<Esc> stop Visual mode -`> go to the end of the Visual area -a<CR><Esc> break the line after the Visual area -`< jump to the start of the Visual area -i<CR><Esc> break the line before the Visual area -!!date<CR> filter the Visual text through date -kJJ Join the lines back together - - *visual-search* -Here is an idea for a mapping that makes it possible to do a search for the -selected text: > - :vmap X y/<C-R>"<CR> - -(In the <> notation |<>|, when typing it you should type it literally; you -need to remove the 'B' and '<' flags from 'cpoptions') - -Note that special characters (like '.' and '*') will cause problems. - -Visual-block Examples *blockwise-examples* -With the following text, I will indicate the commands to produce the block and -the results below. In all cases, the cursor begins on the 'a' in the first -line of the test text. -The following modeline settings are assumed ":ts=8:sw=4:". - -It will be helpful to -:set hls -/<TAB> -where <TAB> is a real TAB. This helps visualise the operations. - -The test text is: - -abcdefghijklmnopqrstuvwxyz -abc defghijklmnopqrstuvwxyz -abcdef ghi jklmnopqrstuvwxyz -abcdefghijklmnopqrstuvwxyz - -1. fo<C-v>3jISTRING<ESC> *v_b_I_example* - -abcdefghijklmnSTRINGopqrstuvwxyz -abc STRING defghijklmnopqrstuvwxyz -abcdef ghi STRING jklmnopqrstuvwxyz -abcdefghijklmnSTRINGopqrstuvwxyz - -2. fo<C-v>3j$ASTRING<ESC> *v_b_A_example* - -abcdefghijklmnopqrstuvwxyzSTRING -abc defghijklmnopqrstuvwxyzSTRING -abcdef ghi jklmnopqrstuvwxyzSTRING -abcdefghijklmnopqrstuvwxyzSTRING - -3. fo<C-v>3j3l<.. *v_b_<_example* - -abcdefghijklmnopqrstuvwxyz -abc defghijklmnopqrstuvwxyz -abcdef ghi jklmnopqrstuvwxyz -abcdefghijklmnopqrstuvwxyz - -4. fo<C-v>3j>.. *v_b_>_example* - -abcdefghijklmn opqrstuvwxyz -abc defghijklmnopqrstuvwxyz -abcdef ghi jklmnopqrstuvwxyz -abcdefghijklmn opqrstuvwxyz - -5. fo<C-v>5l3jrX *v_b_r_example* - -abcdefghijklmnXXXXXXuvwxyz -abc XXXXXXhijklmnopqrstuvwxyz -abcdef ghi XXXXXX jklmnopqrstuvwxyz -abcdefghijklmnXXXXXXuvwxyz - -============================================================================== -8. Select mode *Select* *Select-mode* - -Select mode looks like Visual mode, but the commands accepted are quite -different. This resembles the selection mode in Microsoft Windows. -When the 'showmode' option is set, "-- SELECT --" is shown in the last line. - -Entering Select mode: -- Using the mouse to select an area, and 'selectmode' contains "mouse". - 'mouse' must also contain a flag for the current mode. -- Using a non-printable movement command, with the Shift key pressed, and - 'selectmode' contains "key". For example: <S-Left> and <S-End>. 'keymodel' - must also contain "startsel". -- Using "v", "V" or CTRL-V command, and 'selectmode' contains "cmd". -- Using "gh", "gH" or "g_CTRL-H" command in Normal mode. -- From Visual mode, press CTRL-G. *v_CTRL-G* - -Commands in Select mode: -- Printable characters, <NL> and <CR> cause the selection to be deleted, and - Vim enters Insert mode. The typed character is inserted. -- Non-printable movement commands, with the Shift key pressed, extend the - selection. 'keymodel' must include "startsel". -- Non-printable movement commands, with the Shift key NOT pressed, stop Select - mode. 'keymodel' must include "stopsel". -- ESC stops Select mode. -- CTRL-O switches to Visual mode for the duration of one command. *v_CTRL-O* -- CTRL-G switches to Visual mode. - -Otherwise, typed characters are handled as in Visual mode. - -When using an operator in Select mode, and the selection is linewise, the -selected lines are operated upon, but like in characterwise selection. For -example, when a whole line is deleted, it can later be pasted halfway a line. - - -Mappings and menus in Select mode. *Select-mode-mapping* - -When mappings and menus are defined with the |:vmap| or |:vmenu| command they -work both in Visual mode and in Select mode. When these are used in Select -mode Vim automatically switches to Visual mode, so that the same behavior as -in Visual mode is effective. If you don't want this use |:xmap| or |:smap|. - -After the mapping or menu finishes, the selection is enabled again and Select -mode entered, unless the selected area was deleted, another buffer became -the current one or the window layout was changed. - -When a character was typed that causes the selection to be deleted and Insert -mode started, Insert mode mappings are applied to this character. This may -cause some confusion, because it means Insert mode mappings apply to a -character typed in Select mode. Language mappings apply as well. - - *gV* *v_gV* -gV Avoid the automatic reselection of the Visual area - after a Select mode mapping or menu has finished. - Put this just before the end of the mapping or menu. - At least it should be after any operations on the - selection. - - *gh* -gh Start Select mode, characterwise. This is like "v", - but starts Select mode instead of Visual mode. - Mnemonic: "get highlighted". - - *gH* -gH Start Select mode, linewise. This is like "V", - but starts Select mode instead of Visual mode. - Mnemonic: "get Highlighted". - - *g_CTRL-H* -g CTRL-H Start Select mode, blockwise. This is like CTRL-V, - but starts Select mode instead of Visual mode. - Mnemonic: "get Highlighted". - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/windows.txt b/share/vim/vim72/doc/windows.txt deleted file mode 100644 index b1d81a3c19..0000000000 --- a/share/vim/vim72/doc/windows.txt +++ /dev/null @@ -1,1188 +0,0 @@ -*windows.txt* For Vim version 7.2. Last change: 2008 Aug 09 - - - VIM REFERENCE MANUAL by Bram Moolenaar - - -Editing with multiple windows and buffers. *windows* *buffers* - -The commands which have been added to use multiple windows and buffers are -explained here. Additionally, there are explanations for commands that work -differently when used in combination with more than one window. - -The basics are explained in chapter 7 and 8 of the user manual |usr_07.txt| -|usr_08.txt|. - -1. Introduction |windows-intro| -2. Starting Vim |windows-starting| -3. Opening and closing a window |opening-window| -4. Moving cursor to other windows |window-move-cursor| -5. Moving windows around |window-moving| -6. Window resizing |window-resize| -7. Argument and buffer list commands |buffer-list| -8. Do a command in all buffers or windows |list-repeat| -9. Tag or file name under the cursor |window-tag| -10. The preview window |preview-window| -11. Using hidden buffers |buffer-hidden| -12. Special kinds of buffers |special-buffers| - -{Vi does not have any of these commands} -{not able to use multiple windows when the |+windows| feature was disabled at -compile time} -{not able to use vertically split windows when the |+vertsplit| feature was -disabled at compile time} - -============================================================================== -1. Introduction *windows-intro* *window* - -A window is a viewport onto a buffer. You can use multiple windows on one -buffer, or several windows on different buffers. - -A buffer is a file loaded into memory for editing. The original file remains -unchanged until you write the buffer to the file. - -A buffer can be in one of three states: - - *active-buffer* -active: The buffer is displayed in a window. If there is a file for this - buffer, it has been read into the buffer. The buffer may have been - modified since then and thus be different from the file. - *hidden-buffer* -hidden: The buffer is not displayed. If there is a file for this buffer, it - has been read into the buffer. Otherwise it's the same as an active - buffer, you just can't see it. - *inactive-buffer* -inactive: The buffer is not displayed and does not contain anything. Options - for the buffer are remembered if the file was once loaded. It can - contain marks from the |viminfo| file. But the buffer doesn't - contain text. - -In a table: - -state displayed loaded ":buffers" ~ - in window shows ~ -active yes yes 'a' -hidden no yes 'h' -inactive no no ' ' - -Note: All CTRL-W commands can also be executed with |:wincmd|, for those -places where a Normal mode command can't be used or is inconvenient. - -The main Vim window can hold several split windows. There are also tab pages -|tab-page|, each of which can hold multiple windows. - -============================================================================== -2. Starting Vim *windows-starting* - -By default, Vim starts with one window, just like Vi. - -The "-o" and "-O" arguments to Vim can be used to open a window for each file -in the argument list. The "-o" argument will split the windows horizontally; -the "-O" argument will split the windows vertically. If both "-o" and "-O" -are given, the last one encountered will be used to determine the split -orientation. For example, this will open three windows, split horizontally: > - vim -o file1 file2 file3 - -"-oN", where N is a decimal number, opens N windows split horizontally. If -there are more file names than windows, only N windows are opened and some -files do not get a window. If there are more windows than file names, the -last few windows will be editing empty buffers. Similarly, "-ON" opens N -windows split vertically, with the same restrictions. - -If there are many file names, the windows will become very small. You might -want to set the 'winheight' and/or 'winwidth' options to create a workable -situation. - -Buf/Win Enter/Leave |autocommand|s are not executed when opening the new -windows and reading the files, that's only done when they are really entered. - - *status-line* -A status line will be used to separate windows. The 'laststatus' option tells -when the last window also has a status line: - 'laststatus' = 0 never a status line - 'laststatus' = 1 status line if there is more than one window - 'laststatus' = 2 always a status line - -You can change the contents of the status line with the 'statusline' option. -This option can be local to the window, so that you can have a different -status line in each window. - -Normally, inversion is used to display the status line. This can be changed -with the 's' character in the 'highlight' option. For example, "sb" sets it to -bold characters. If no highlighting is used for the status line ("sn"), the -'^' character is used for the current window, and '=' for other windows. If -the mouse is supported and enabled with the 'mouse' option, a status line can -be dragged to resize windows. - -Note: If you expect your status line to be in reverse video and it isn't, -check if the 'highlight' option contains "si". In version 3.0, this meant to -invert the status line. Now it should be "sr", reverse the status line, as -"si" now stands for italic! If italic is not available on your terminal, the -status line is inverted anyway; you will only see this problem on terminals -that have termcap codes for italics. - -============================================================================== -3. Opening and closing a window *opening-window* *E36* - -CTRL-W s *CTRL-W_s* -CTRL-W S *CTRL-W_S* -CTRL-W CTRL-S *CTRL-W_CTRL-S* -:[N]sp[lit] [++opt] [+cmd] *:sp* *:split* - Split current window in two. The result is two viewports on - the same file. Make new window N high (default is to use half - the height of the current window). Reduces the current window - height to create room (and others, if the 'equalalways' option - is set, 'eadirection' isn't "hor", and one of them is higher - than the current or the new window). - Note: CTRL-S does not work on all terminals and might block - further input, use CTRL-Q to get going again. - Also see |++opt| and |+cmd|. - -CTRL-W CTRL-V *CTRL-W_CTRL-V* -CTRL-W v *CTRL-W_v* -:[N]vs[plit] [++opt] [+cmd] [file] *:vs* *:vsplit* - Like |:split|, but split vertically. The windows will be - spread out horizontally if - 1. a width was not specified, - 2. 'equalalways' is set, - 3. 'eadirection' isn't "ver", and - 4. one of the other windows is wider than the current or new - window. - Note: In other places CTRL-Q does the same as CTRL-V, but here - it doesn't! - -CTRL-W n *CTRL-W_n* -CTRL-W CTRL_N *CTRL-W_CTRL-N* -:[N]new [++opt] [+cmd] *:new* - Create a new window and start editing an empty file in it. - Make new window N high (default is to use half the existing - height). Reduces the current window height to create room (and - others, if the 'equalalways' option is set and 'eadirection' - isn't "hor"). - Also see |++opt| and |+cmd|. - If 'fileformats' is not empty, the first format given will be - used for the new buffer. If 'fileformats' is empty, the - 'fileformat' of the current buffer is used. This can be - overridden with the |++opt| argument. - Autocommands are executed in this order: - 1. WinLeave for the current window - 2. WinEnter for the new window - 3. BufLeave for the current buffer - 4. BufEnter for the new buffer - This behaves like a ":split" first, and then a ":e" command. - -:[N]vne[w] [++opt] [+cmd] [file] *:vne* *:vnew* - Like |:new|, but split vertically. If 'equalalways' is set - and 'eadirection' isn't "ver" the windows will be spread out - horizontally, unless a width was specified. - -:[N]new [++opt] [+cmd] {file} -:[N]sp[lit] [++opt] [+cmd] {file} *:split_f* - Create a new window and start editing file {file} in it. - If [+cmd] is given, execute the command when the file has been - loaded |+cmd|. - Also see |++opt|. - Make new window N high (default is to use half the existing - height). Reduces the current window height to create room - (and others, if the 'equalalways' option is set). - -:[N]sv[iew] [++opt] [+cmd] {file} *:sv* *:sview* *splitview* - Same as ":split", but set 'readonly' option for this buffer. - -:[N]sf[ind] [++opt] [+cmd] {file} *:sf* *:sfind* *splitfind* - Same as ":split", but search for {file} in 'path' like in - |:find|. Doesn't split if {file} is not found. - -CTRL-W CTRL-^ *CTRL-W_CTRL-^* *CTRL-W_^* -CTRL-W ^ Does ":split #", split window in two and edit alternate file. - When a count is given, it becomes ":split #N", split window - and edit buffer N. - -Note that the 'splitbelow' and 'splitright' options influence where a new -window will appear. - - *:vert* *:vertical* -:vert[ical] {cmd} - Execute {cmd}. If it contains a command that splits a window, - it will be split vertically. - Doesn't work for |:execute| and |:normal|. - -:lefta[bove] {cmd} *:lefta* *:leftabove* -:abo[veleft] {cmd} *:abo* *:aboveleft* - Execute {cmd}. If it contains a command that splits a window, - it will be opened left (vertical split) or above (horizontal - split) the current window. Overrules 'splitbelow' and - 'splitright'. - Doesn't work for |:execute| and |:normal|. - -:rightb[elow] {cmd} *:rightb* *:rightbelow* -:bel[owright] {cmd} *:bel* *:belowright* - Execute {cmd}. If it contains a command that splits a window, - it will be opened right (vertical split) or below (horizontal - split) the current window. Overrules 'splitbelow' and - 'splitright'. - Doesn't work for |:execute| and |:normal|. - - *:topleft* *E442* -:to[pleft] {cmd} - Execute {cmd}. If it contains a command that splits a window, - it will appear at the top and occupy the full width of the Vim - window. When the split is vertical the window appears at the - far left and occupies the full height of the Vim window. - Doesn't work for |:execute| and |:normal|. - - *:botright* -:bo[tright] {cmd} - Execute {cmd}. If it contains a command that splits a window, - it will appear at the bottom and occupy the full width of the - Vim window. When the split is vertical the window appears at - the far right and occupies the full height of the Vim window. - Doesn't work for |:execute| and |:normal|. - -These command modifiers can be combined to make a vertically split window -occupy the full height. Example: > - :vertical topleft edit tags -Opens a vertically split, full-height window on the "tags" file at the far -left of the Vim window. - - -Closing a window ----------------- - -CTRL-W q *CTRL-W_q* -CTRL-W CTRL-Q *CTRL-W_CTRL-Q* -:q[uit] Quit current window. When quitting the last window (not - counting a help window), exit Vim. - When 'hidden' is set, and there is only one window for the - current buffer, it becomes hidden. - When 'hidden' is not set, and there is only one window for the - current buffer, and the buffer was changed, the command fails. - (Note: CTRL-Q does not work on all terminals) - -:q[uit]! Quit current window. If this was the last window for a buffer, - any changes to that buffer are lost. When quitting the last - window (not counting help windows), exit Vim. The contents of - the buffer are lost, even when 'hidden' is set. - -CTRL-W c *CTRL-W_c* *:clo* *:close* -:clo[se][!] Close current window. When the 'hidden' option is set, or - when the buffer was changed and the [!] is used, the buffer - becomes hidden (unless there is another window editing it). - When there is only one window in the current tab page and - there is another tab page, this closes the current tab page. - |tab-page|. - This command fails when: *E444* - - There is only one window on the screen. - - When 'hidden' is not set, [!] is not used, the buffer has - changes, and there is no other window on this buffer. - Changes to the buffer are not written and won't get lost, so - this is a "safe" command. - -CTRL-W CTRL-C *CTRL-W_CTRL-C* - You might have expected that CTRL-W CTRL-C closes the current - window, but that does not work, because the CTRL-C cancels the - command. - - *:hide* -:hid[e] Quit current window, unless it is the last window on the - screen. The buffer becomes hidden (unless there is another - window editing it or 'bufhidden' is "unload" or "delete"). - If the window is the last one in the current tab page the tab - page is closed. |tab-page| - The value of 'hidden' is irrelevant for this command. - Changes to the buffer are not written and won't get lost, so - this is a "safe" command. - -:hid[e] {cmd} Execute {cmd} with 'hidden' is set. The previous value of - 'hidden' is restored after {cmd} has been executed. - Example: > - :hide edit Makefile -< This will edit "Makefile", and hide the current buffer if it - has any changes. - -CTRL-W o *CTRL-W_o* *E445* -CTRL-W CTRL-O *CTRL-W_CTRL-O* *:on* *:only* -:on[ly][!] Make the current window the only one on the screen. All other - windows are closed. - When the 'hidden' option is set, all buffers in closed windows - become hidden. - When 'hidden' is not set, and the 'autowrite' option is set, - modified buffers are written. Otherwise, windows that have - buffers that are modified are not removed, unless the [!] is - given, then they become hidden. But modified buffers are - never abandoned, so changes cannot get lost. - -============================================================================== -4. Moving cursor to other windows *window-move-cursor* - -CTRL-W <Down> *CTRL-W_<Down>* -CTRL-W CTRL-J *CTRL-W_CTRL-J* *CTRL-W_j* -CTRL-W j Move cursor to Nth window below current one. Uses the cursor - position to select between alternatives. - -CTRL-W <Up> *CTRL-W_<Up>* -CTRL-W CTRL-K *CTRL-W_CTRL-K* *CTRL-W_k* -CTRL-W k Move cursor to Nth window above current one. Uses the cursor - position to select between alternatives. - -CTRL-W <Left> *CTRL-W_<Left>* -CTRL-W CTRL-H *CTRL-W_CTRL-H* -CTRL-W <BS> *CTRL-W_<BS>* *CTRL-W_h* -CTRL-W h Move cursor to Nth window left of current one. Uses the - cursor position to select between alternatives. - -CTRL-W <Right> *CTRL-W_<Right>* -CTRL-W CTRL-L *CTRL-W_CTRL-L* *CTRL-W_l* -CTRL-W l Move cursor to Nth window right of current one. Uses the - cursor position to select between alternatives. - -CTRL-W w *CTRL-W_w* *CTRL-W_CTRL-W* -CTRL-W CTRL-W Without count: move cursor to window below/right of the - current one. If there is no window below or right, go to - top-left window. - With count: go to Nth window (windows are numbered from - top-left to bottom-right). To obtain the window number see - |bufwinnr()| and |winnr()|. - - *CTRL-W_W* -CTRL-W W Without count: move cursor to window above/left of current - one. If there is no window above or left, go to bottom-right - window. With count: go to Nth window (windows are numbered - from top-left to bottom-right). - -CTRL-W t *CTRL-W_t* *CTRL-W_CTRL-T* -CTRL-W CTRL-T Move cursor to top-left window. - -CTRL-W b *CTRL-W_b* *CTRL-W_CTRL-B* -CTRL-W CTRL-B Move cursor to bottom-right window. - -CTRL-W p *CTRL-W_p* *CTRL-W_CTRL-P* -CTRL-W CTRL-P Go to previous (last accessed) window. - - *CTRL-W_P* *E441* -CTRL-W P Go to preview window. When there is no preview window this is - an error. - {not available when compiled without the |+quickfix| feature} - -If Visual mode is active and the new window is not for the same buffer, the -Visual mode is ended. If the window is on the same buffer, the cursor -position is set to keep the same Visual area selected. - - *:winc* *:wincmd* -These commands can also be executed with ":wincmd": - -:[count]winc[md] {arg} - Like executing CTRL-W [count] {arg}. Example: > - :wincmd j -< Moves to the window below the current one. - This command is useful when a Normal mode cannot be used (for - the |CursorHold| autocommand event). Or when a Normal mode - command is inconvenient. - The count can also be a window number. Example: > - :exe nr . "wincmd w" -< This goes to window "nr". - -============================================================================== -5. Moving windows around *window-moving* - -CTRL-W r *CTRL-W_r* *CTRL-W_CTRL-R* *E443* -CTRL-W CTRL-R Rotate windows downwards/rightwards. The first window becomes - the second one, the second one becomes the third one, etc. - The last window becomes the first window. The cursor remains - in the same window. - This only works within the row or column of windows that the - current window is in. - - *CTRL-W_R* -CTRL-W R Rotate windows upwards/leftwards. The second window becomes - the first one, the third one becomes the second one, etc. The - first window becomes the last window. The cursor remains in - the same window. - This only works within the row or column of windows that the - current window is in. - -CTRL-W x *CTRL-W_x* *CTRL-W_CTRL-X* -CTRL-W CTRL-X Without count: Exchange current window with next one. If there - is no next window, exchange with previous window. - With count: Exchange current window with Nth window (first - window is 1). The cursor is put in the other window. - When vertical and horizontal window splits are mixed, the - exchange is only done in the row or column of windows that the - current window is in. - -The following commands can be used to change the window layout. For example, -when there are two vertically split windows, CTRL-W K will change that in -horizontally split windows. CTRL-W H does it the other way around. - - *CTRL-W_K* -CTRL-W K Move the current window to be at the very top, using the full - width of the screen. This works like closing the current - window and then creating another one with ":topleft split", - except that the current window contents is used for the new - window. - - *CTRL-W_J* -CTRL-W J Move the current window to be at the very bottom, using the - full width of the screen. This works like closing the current - window and then creating another one with ":botright split", - except that the current window contents is used for the new - window. - - *CTRL-W_H* -CTRL-W H Move the current window to be at the far left, using the - full height of the screen. This works like closing the - current window and then creating another one with - ":vert topleft split", except that the current window contents - is used for the new window. - {not available when compiled without the +vertsplit feature} - - *CTRL-W_L* -CTRL-W L Move the current window to be at the far right, using the full - height of the screen. This works like closing the - current window and then creating another one with - ":vert botright split", except that the current window - contents is used for the new window. - {not available when compiled without the +vertsplit feature} - - *CTRL-W_T* -CTRL-W T Move the current window to a new tab page. This fails if - there is only one window in the current tab page. - When a count is specified the new tab page will be opened - before the tab page with this index. Otherwise it comes after - the current tab page. - -============================================================================== -6. Window resizing *window-resize* - - *CTRL-W_=* -CTRL-W = Make all windows (almost) equally high and wide, but use - 'winheight' and 'winwidth' for the current window. - Windows with 'winfixheight' set keep their height and windows - with 'winfixwidth' set keep their width. - -:res[ize] -N *:res* *:resize* *CTRL-W_-* -CTRL-W - Decrease current window height by N (default 1). - If used after 'vertical': decrease width by N. - -:res[ize] +N *CTRL-W_+* -CTRL-W + Increase current window height by N (default 1). - If used after 'vertical': increase width by N. - -:res[ize] [N] -CTRL-W CTRL-_ *CTRL-W_CTRL-_* *CTRL-W__* -CTRL-W _ Set current window height to N (default: highest possible). - -z{nr}<CR> Set current window height to {nr}. - - *CTRL-W_<* -CTRL-W < Decrease current window width by N (default 1). - - *CTRL-W_>* -CTRL-W > Increase current window width by N (default 1). - -:vertical res[ize] [N] *:vertical-resize* *CTRL-W_bar* -CTRL-W | Set current window width to N (default: widest possible). - -You can also resize a window by dragging a status line up or down with the -mouse. Or by dragging a vertical separator line left or right. This only -works if the version of Vim that is being used supports the mouse and the -'mouse' option has been set to enable it. - -The option 'winheight' ('wh') is used to set the minimal window height of the -current window. This option is used each time another window becomes the -current window. If the option is '0', it is disabled. Set 'winheight' to a -very large value, e.g., '9999', to make the current window always fill all -available space. Set it to a reasonable value, e.g., '10', to make editing in -the current window comfortable. - -The equivalent 'winwidth' ('wiw') option is used to set the minimal width of -the current window. - -When the option 'equalalways' ('ea') is set, all the windows are automatically -made the same size after splitting or closing a window. If you don't set this -option, splitting a window will reduce the size of the current window and -leave the other windows the same. When closing a window, the extra lines are -given to the window above it. - -The 'eadirection' option limits the direction in which the 'equalalways' -option is applied. The default "both" resizes in both directions. When the -value is "ver" only the heights of windows are equalized. Use this when you -have manually resized a vertically split window and want to keep this width. -Likewise, "hor" causes only the widths of windows to be equalized. - -The option 'cmdheight' ('ch') is used to set the height of the command-line. -If you are annoyed by the |hit-enter| prompt for long messages, set this -option to 2 or 3. - -If there is only one window, resizing that window will also change the command -line height. If there are several windows, resizing the current window will -also change the height of the window below it (and sometimes the window above -it). - -The minimal height and width of a window is set with 'winminheight' and -'winminwidth'. These are hard values, a window will never become smaller. - -============================================================================== -7. Argument and buffer list commands *buffer-list* - - args list buffer list meaning ~ -1. :[N]argument [N] 11. :[N]buffer [N] to arg/buf N -2. :[N]next [file ..] 12. :[N]bnext [N] to Nth next arg/buf -3. :[N]Next [N] 13. :[N]bNext [N] to Nth previous arg/buf -4. :[N]previous [N] 14. :[N]bprevious [N] to Nth previous arg/buf -5. :rewind / :first 15. :brewind / :bfirst to first arg/buf -6. :last 16. :blast to last arg/buf -7. :all 17. :ball edit all args/buffers - 18. :unhide edit all loaded buffers - 19. :[N]bmod [N] to Nth modified buf - - split & args list split & buffer list meaning ~ -21. :[N]sargument [N] 31. :[N]sbuffer [N] split + to arg/buf N -22. :[N]snext [file ..] 32. :[N]sbnext [N] split + to Nth next arg/buf -23. :[N]sNext [N] 33. :[N]sbNext [N] split + to Nth previous arg/buf -24. :[N]sprevious [N] 34. :[N]sbprevious [N] split + to Nth previous arg/buf -25. :srewind / :sfirst 35. :sbrewind / :sbfirst split + to first arg/buf -26. :slast 36. :sblast split + to last arg/buf -27. :sall 37. :sball edit all args/buffers - 38. :sunhide edit all loaded buffers - 39. :[N]sbmod [N] split + to Nth modified buf - -40. :args list of arguments -41. :buffers list of buffers - -The meaning of [N] depends on the command: - [N] is number of buffers to go forward/backward on ?2, ?3, and ?4 - [N] is an argument number, defaulting to current argument, for 1 and 21 - [N] is a buffer number, defaulting to current buffer, for 11 and 31 - [N] is a count for 19 and 39 - -Note: ":next" is an exception, because it must accept a list of file names -for compatibility with Vi. - - -The argument list and multiple windows --------------------------------------- - -The current position in the argument list can be different for each window. -Remember that when doing ":e file", the position in the argument list stays -the same, but you are not editing the file at that position. To indicate -this, the file message (and the title, if you have one) shows -"(file (N) of M)", where "(N)" is the current position in the file list, and -"M" the number of files in the file list. - -All the entries in the argument list are added to the buffer list. Thus, you -can also get to them with the buffer list commands, like ":bnext". - -:[N]al[l][!] [N] *:al* *:all* *:sal* *:sall* -:[N]sal[l][!] [N] - Rearrange the screen to open one window for each argument. - All other windows are closed. When a count is given, this is - the maximum number of windows to open. - With the |:tab| modifier open a tab page for each argument. - When there are more arguments than 'tabpagemax' further ones - become split windows in the last tab page. - When the 'hidden' option is set, all buffers in closed windows - become hidden. - When 'hidden' is not set, and the 'autowrite' option is set, - modified buffers are written. Otherwise, windows that have - buffers that are modified are not removed, unless the [!] is - given, then they become hidden. But modified buffers are - never abandoned, so changes cannot get lost. - [N] is the maximum number of windows to open. 'winheight' - also limits the number of windows opened ('winwidth' if - |:vertical| was prepended). - Buf/Win Enter/Leave autocommands are not executed for the new - windows here, that's only done when they are really entered. - -:[N]sa[rgument][!] [++opt] [+cmd] [N] *:sa* *:sargument* - Short for ":split | argument [N]": split window and go to Nth - argument. But when there is no such argument, the window is - not split. Also see |++opt| and |+cmd|. - -:[N]sn[ext][!] [++opt] [+cmd] [file ..] *:sn* *:snext* - Short for ":split | [N]next": split window and go to Nth next - argument. But when there is no next file, the window is not - split. Also see |++opt| and |+cmd|. - -:[N]spr[evious][!] [++opt] [+cmd] [N] *:spr* *:sprevious* -:[N]sN[ext][!] [++opt] [+cmd] [N] *:sN* *:sNext* - Short for ":split | [N]Next": split window and go to Nth - previous argument. But when there is no previous file, the - window is not split. Also see |++opt| and |+cmd|. - - *:sre* *:srewind* -:sre[wind][!] [++opt] [+cmd] - Short for ":split | rewind": split window and go to first - argument. But when there is no argument list, the window is - not split. Also see |++opt| and |+cmd|. - - *:sfir* *:sfirst* -:sfir[st] [++opt] [+cmd] - Same as ":srewind". - - *:sla* *:slast* -:sla[st][!] [++opt] [+cmd] - Short for ":split | last": split window and go to last - argument. But when there is no argument list, the window is - not split. Also see |++opt| and |+cmd|. - - *:dr* *:drop* -:dr[op] [++opt] [+cmd] {file} .. - Edit the first {file} in a window. - - If the file is already open in a window change to that - window. - - If the file is not open in a window edit the file in the - current window. If the current buffer can't be |abandon|ed, - the window is split first. - The |argument-list| is set, like with the |:next| command. - The purpose of this command is that it can be used from a - program that wants Vim to edit another file, e.g., a debugger. - When using the |:tab| modifier each argument is opened in a - tab page. The last window is used if it's empty. - Also see |++opt| and |+cmd|. - {only available when compiled with the +gui feature} - -============================================================================== -8. Do a command in all buffers or windows *list-repeat* - - *:windo* -:windo {cmd} Execute {cmd} in each window. - It works like doing this: > - CTRL-W t - :{cmd} - CTRL-W w - :{cmd} - etc. -< This only operates in the current tab page. - When an error is detected on one window, further - windows will not be visited. - The last window (or where an error occurred) becomes - the current window. - {cmd} can contain '|' to concatenate several commands. - {cmd} must not open or close windows or reorder them. - {not in Vi} {not available when compiled without the - |+listcmds| feature} - Also see |:tabdo|, |:argdo| and |:bufdo|. - - *:bufdo* -:bufdo[!] {cmd} Execute {cmd} in each buffer in the buffer list. - It works like doing this: > - :bfirst - :{cmd} - :bnext - :{cmd} - etc. -< When the current file can't be |abandon|ed and the [!] - is not present, the command fails. - When an error is detected on one buffer, further - buffers will not be visited. - Unlisted buffers are skipped. - The last buffer (or where an error occurred) becomes - the current buffer. - {cmd} can contain '|' to concatenate several commands. - {cmd} must not delete buffers or add buffers to the - buffer list. - Note: While this command is executing, the Syntax - autocommand event is disabled by adding it to - 'eventignore'. This considerably speeds up editing - each buffer. - {not in Vi} {not available when compiled without the - |+listcmds| feature} - Also see |:tabdo|, |:argdo| and |:windo|. - -Examples: > - - :windo set nolist nofoldcolumn | normal zn - -This resets the 'list' option and disables folding in all windows. > - - :bufdo set fileencoding= | update - -This resets the 'fileencoding' in each buffer and writes it if this changed -the buffer. The result is that all buffers will use the 'encoding' encoding -(if conversion works properly). - -============================================================================== -9. Tag or file name under the cursor *window-tag* - - *:sta* *:stag* -:sta[g][!] [tagname] - Does ":tag[!] [tagname]" and splits the window for the found - tag. See also |:tag|. - -CTRL-W ] *CTRL-W_]* *CTRL-W_CTRL-]* -CTRL-W CTRL-] Split current window in two. Use identifier under cursor as a - tag and jump to it in the new upper window. Make new window N - high. - - *CTRL-W_g]* -CTRL-W g ] Split current window in two. Use identifier under cursor as a - tag and perform ":tselect" on it in the new upper window. - Make new window N high. - - *CTRL-W_g_CTRL-]* -CTRL-W g CTRL-] Split current window in two. Use identifier under cursor as a - tag and perform ":tjump" on it in the new upper window. Make - new window N high. - -CTRL-W f *CTRL-W_f* *CTRL-W_CTRL-F* -CTRL-W CTRL-F Split current window in two. Edit file name under cursor. - Like ":split gf", but window isn't split if the file does not - exist. - Uses the 'path' variable as a list of directory names where to - look for the file. Also the path for current file is - used to search for the file name. - If the name is a hypertext link that looks like - "type://machine/path", only "/path" is used. - If a count is given, the count'th matching file is edited. - {not available when the |+file_in_path| feature was disabled - at compile time} - -CTRL-W F *CTRL-W_F* - Split current window in two. Edit file name under cursor and - jump to the line number following the file name. See |gF| for - details on how the line number is obtained. - {not available when the |+file_in_path| feature was disabled - at compile time} - -CTRL-W gf *CTRL-W_gf* - Open a new tab page and edit the file name under the cursor. - Like "tab split" and "gf", but the new tab page isn't created - if the file does not exist. - {not available when the |+file_in_path| feature was disabled - at compile time} - -CTRL-W gF *CTRL-W_gF* - Open a new tab page and edit the file name under the cursor - and jump to the line number following the file name. Like - "tab split" and "gF", but the new tab page isn't created if - the file does not exist. - {not available when the |+file_in_path| feature was disabled - at compile time} - -Also see |CTRL-W_CTRL-I|: open window for an included file that includes -the keyword under the cursor. - -============================================================================== -10. The preview window *preview-window* - -The preview window is a special window to show (preview) another file. It is -normally a small window used to show an include file or definition of a -function. -{not available when compiled without the |+quickfix| feature} - -There can be only one preview window (per tab page). It is created with one -of the commands below. The 'previewheight' option can be set to specify the -height of the preview window when it's opened. The 'previewwindow' option is -set in the preview window to be able to recognize it. The 'winfixheight' -option is set to have it keep the same height when opening/closing other -windows. - - *:pta* *:ptag* -:pta[g][!] [tagname] - Does ":tag[!] [tagname]" and shows the found tag in a - "Preview" window without changing the current buffer or cursor - position. If a "Preview" window already exists, it is re-used - (like a help window is). If a new one is opened, - 'previewheight' is used for the height of the window. See - also |:tag|. - See below for an example. |CursorHold-example| - Small difference from |:tag|: When [tagname] is equal to the - already displayed tag, the position in the matching tag list - is not reset. This makes the CursorHold example work after a - |:ptnext|. - -CTRL-W z *CTRL-W_z* -CTRL-W CTRL-Z *CTRL-W_CTRL-Z* *:pc* *:pclose* -:pc[lose][!] Close any "Preview" window currently open. When the 'hidden' - option is set, or when the buffer was changed and the [!] is - used, the buffer becomes hidden (unless there is another - window editing it). The command fails if any "Preview" buffer - cannot be closed. See also |:close|. - - *:pp* *:ppop* -:[count]pp[op][!] - Does ":[count]pop[!]" in the preview window. See |:pop| and - |:ptag|. {not in Vi} - -CTRL-W } *CTRL-W_}* - Use identifier under cursor as a tag and perform a :ptag on - it. Make the new Preview window (if required) N high. If N is - not given, 'previewheight' is used. - -CTRL-W g } *CTRL-W_g}* - Use identifier under cursor as a tag and perform a :ptjump on - it. Make the new Preview window (if required) N high. If N is - not given, 'previewheight' is used. - - *:ped* *:pedit* -:ped[it][!] [++opt] [+cmd] {file} - Edit {file} in the preview window. The preview window is - opened like with |:ptag|. The current window and cursor - position isn't changed. Useful example: > - :pedit +/fputc /usr/include/stdio.h -< - *:ps* *:psearch* -:[range]ps[earch][!] [count] [/]pattern[/] - Works like |:ijump| but shows the found match in the preview - window. The preview window is opened like with |:ptag|. The - current window and cursor position isn't changed. Useful - example: > - :psearch popen -< Like with the |:ptag| command, you can use this to - automatically show information about the word under the - cursor. This is less clever than using |:ptag|, but you don't - need a tags file and it will also find matches in system - include files. Example: > - :au! CursorHold *.[ch] nested exe "silent! psearch " . expand("<cword>") -< Warning: This can be slow. - -Example *CursorHold-example* > - - :au! CursorHold *.[ch] nested exe "silent! ptag " . expand("<cword>") - -This will cause a ":ptag" to be executed for the keyword under the cursor, -when the cursor hasn't moved for the time set with 'updatetime'. The "nested" -makes other autocommands be executed, so that syntax highlighting works in the -preview window. The "silent!" avoids an error message when the tag could not -be found. Also see |CursorHold|. To disable this again: > - - :au! CursorHold - -A nice addition is to highlight the found tag, avoid the ":ptag" when there -is no word under the cursor, and a few other things: > - - :au! CursorHold *.[ch] nested call PreviewWord() - :func PreviewWord() - : if &previewwindow " don't do this in the preview window - : return - : endif - : let w = expand("<cword>") " get the word under cursor - : if w =~ '\a' " if the word contains a letter - : - : " Delete any existing highlight before showing another tag - : silent! wincmd P " jump to preview window - : if &previewwindow " if we really get there... - : match none " delete existing highlight - : wincmd p " back to old window - : endif - : - : " Try displaying a matching tag for the word under the cursor - : try - : exe "ptag " . w - : catch - : return - : endtry - : - : silent! wincmd P " jump to preview window - : if &previewwindow " if we really get there... - : if has("folding") - : silent! .foldopen " don't want a closed fold - : endif - : call search("$", "b") " to end of previous line - : let w = substitute(w, '\\', '\\\\', "") - : call search('\<\V' . w . '\>') " position cursor on match - : " Add a match highlight to the word at this position - : hi previewWord term=bold ctermbg=green guibg=green - : exe 'match previewWord "\%' . line(".") . 'l\%' . col(".") . 'c\k*"' - : wincmd p " back to old window - : endif - : endif - :endfun - -============================================================================== -11. Using hidden buffers *buffer-hidden* - -A hidden buffer is not displayed in a window, but is still loaded into memory. -This makes it possible to jump from file to file, without the need to read or -write the file every time you get another buffer in a window. -{not available when compiled without the |+listcmds| feature} - - *:buffer-!* -If the option 'hidden' ('hid') is set, abandoned buffers are kept for all -commands that start editing another file: ":edit", ":next", ":tag", etc. The -commands that move through the buffer list sometimes make the current buffer -hidden although the 'hidden' option is not set. This happens when a buffer is -modified, but is forced (with '!') to be removed from a window, and -'autowrite' is off or the buffer can't be written. - -You can make a hidden buffer not hidden by starting to edit it with any -command. Or by deleting it with the ":bdelete" command. - -The 'hidden' is global, it is used for all buffers. The 'bufhidden' option -can be used to make an exception for a specific buffer. It can take these -values: - <empty> Use the value of 'hidden'. - hide Hide this buffer, also when 'hidden' is not set. - unload Don't hide but unload this buffer, also when 'hidden' - is set. - delete Delete the buffer. - - *hidden-quit* -When you try to quit Vim while there is a hidden, modified buffer, you will -get an error message and Vim will make that buffer the current buffer. You -can then decide to write this buffer (":wq") or quit without writing (":q!"). -Be careful: there may be more hidden, modified buffers! - -A buffer can also be unlisted. This means it exists, but it is not in the -list of buffers. |unlisted-buffer| - - -:files[!] *:files* -:buffers[!] *:buffers* *:ls* -:ls[!] Show all buffers. Example: - - 1 #h "/test/text" line 1 ~ - 2u "asdf" line 0 ~ - 3 %a+ "version.c" line 1 ~ - - When the [!] is included the list will show unlisted buffers - (the term "unlisted" is a bit confusing then...). - - Each buffer has a unique number. That number will not change, - so you can always go to a specific buffer with ":buffer N" or - "N CTRL-^", where N is the buffer number. - - Indicators (chars in the same column are mutually exclusive): - u an unlisted buffer (only displayed when [!] is used) - |unlisted-buffer| - % the buffer in the current window - # the alternate buffer for ":e #" and CTRL-^ - a an active buffer: it is loaded and visible - h a hidden buffer: It is loaded, but currently not - displayed in a window |hidden-buffer| - - a buffer with 'modifiable' off - = a readonly buffer - + a modified buffer - x a buffer with read errors - - *:bad* *:badd* -:bad[d] [+lnum] {fname} - Add file name {fname} to the buffer list, without loading it. - If "lnum" is specified, the cursor will be positioned at that - line when the buffer is first entered. Note that other - commands after the + will be ignored. - -:[N]bd[elete][!] *:bd* *:bdel* *:bdelete* *E516* -:bd[elete][!] [N] - Unload buffer [N] (default: current buffer) and delete it from - the buffer list. If the buffer was changed, this fails, - unless when [!] is specified, in which case changes are lost. - The file remains unaffected. Any windows for this buffer are - closed. If buffer [N] is the current buffer, another buffer - will be displayed instead. This is the most recent entry in - the jump list that points into a loaded buffer. - Actually, the buffer isn't completely deleted, it is removed - from the buffer list |unlisted-buffer| and option values, - variables and mappings/abbreviations for the buffer are - cleared. - -:bdelete[!] {bufname} *E93* *E94* - Like ":bdelete[!] [N]", but buffer given by name. Note that a - buffer whose name is a number cannot be referenced by that - name; use the buffer number instead. Insert a backslash - before a space in a buffer name. - -:bdelete[!] N1 N2 ... - Do ":bdelete[!]" for buffer N1, N2, etc. The arguments can be - buffer numbers or buffer names (but not buffer names that are - a number). Insert a backslash before a space in a buffer - name. - -:N,Mbdelete[!] Do ":bdelete[!]" for all buffers in the range N to M - |inclusive|. - -:[N]bw[ipeout][!] *:bw* *:bwipe* *:bwipeout* *E517* -:bw[ipeout][!] {bufname} -:N,Mbw[ipeout][!] -:bw[ipeout][!] N1 N2 ... - Like |:bdelete|, but really delete the buffer. Everything - related to the buffer is lost. All marks in this buffer - become invalid, option settings are lost, etc. Don't use this - unless you know what you are doing. - -:[N]bun[load][!] *:bun* *:bunload* *E515* -:bun[load][!] [N] - Unload buffer [N] (default: current buffer). The memory - allocated for this buffer will be freed. The buffer remains - in the buffer list. - If the buffer was changed, this fails, unless when [!] is - specified, in which case the changes are lost. - Any windows for this buffer are closed. If buffer [N] is the - current buffer, another buffer will be displayed instead. - This is the most recent entry in the jump list that points - into a loaded buffer. - -:bunload[!] {bufname} - Like ":bunload[!] [N]", but buffer given by name. Note that a - buffer whose name is a number cannot be referenced by that - name; use the buffer number instead. Insert a backslash - before a space in a buffer name. - -:N,Mbunload[!] Do ":bunload[!]" for all buffers in the range N to M - |inclusive|. - -:bunload[!] N1 N2 ... - Do ":bunload[!]" for buffer N1, N2, etc. The arguments can be - buffer numbers or buffer names (but not buffer names that are - a number). Insert a backslash before a space in a buffer - name. - -:[N]b[uffer][!] [N] *:b* *:bu* *:buf* *:buffer* *E86* - Edit buffer [N] from the buffer list. If [N] is not given, - the current buffer remains being edited. See |:buffer-!| for - [!]. This will also edit a buffer that is not in the buffer - list, without setting the 'buflisted' flag. - -:[N]b[uffer][!] {bufname} - Edit buffer for {bufname} from the buffer list. See - |:buffer-!| for [!]. This will also edit a buffer that is not - in the buffer list, without setting the 'buflisted' flag. - -:[N]sb[uffer] [N] *:sb* *:sbuffer* - Split window and edit buffer [N] from the buffer list. If [N] - is not given, the current buffer is edited. Respects the - "useopen" setting of 'switchbuf' when splitting. This will - also edit a buffer that is not in the buffer list, without - setting the 'buflisted' flag. - -:[N]sb[uffer] {bufname} - Split window and edit buffer for {bufname} from the buffer - list. This will also edit a buffer that is not in the buffer - list, without setting the 'buflisted' flag. - Note: If what you want to do is split the buffer, make a copy - under another name, you can do it this way: > - :w foobar | sp # - -:[N]bn[ext][!] [N] *:bn* *:bnext* *E87* - Go to [N]th next buffer in buffer list. [N] defaults to one. - Wraps around the end of the buffer list. - See |:buffer-!| for [!]. - If you are in a help buffer, this takes you to the next help - buffer (if there is one). Similarly, if you are in a normal - (non-help) buffer, this takes you to the next normal buffer. - This is so that if you have invoked help, it doesn't get in - the way when you're browsing code/text buffers. The next three - commands also work like this. - - *:sbn* *:sbnext* -:[N]sbn[ext] [N] - Split window and go to [N]th next buffer in buffer list. - Wraps around the end of the buffer list. Uses 'switchbuf' - -:[N]bN[ext][!] [N] *:bN* *:bNext* *:bp* *:bprevious* *E88* -:[N]bp[revious][!] [N] - Go to [N]th previous buffer in buffer list. [N] defaults to - one. Wraps around the start of the buffer list. - See |:buffer-!| for [!] and 'switchbuf'. - -:[N]sbN[ext] [N] *:sbN* *:sbNext* *:sbp* *:sbprevious* -:[N]sbp[revious] [N] - Split window and go to [N]th previous buffer in buffer list. - Wraps around the start of the buffer list. - Uses 'switchbuf'. - - *:br* *:brewind* -:br[ewind][!] Go to first buffer in buffer list. If the buffer list is - empty, go to the first unlisted buffer. - See |:buffer-!| for [!]. - - *:bf* *:bfirst* -:bf[irst] Same as ":brewind". - - *:sbr* *:sbrewind* -:sbr[ewind] Split window and go to first buffer in buffer list. If the - buffer list is empty, go to the first unlisted buffer. - Respects the 'switchbuf' option. - - *:sbf* *:sbfirst* -:sbf[irst] Same as ":sbrewind". - - *:bl* *:blast* -:bl[ast][!] Go to last buffer in buffer list. If the buffer list is - empty, go to the last unlisted buffer. - See |:buffer-!| for [!]. - - *:sbl* *:sblast* -:sbl[ast] Split window and go to last buffer in buffer list. If the - buffer list is empty, go to the last unlisted buffer. - Respects 'switchbuf' option. - -:[N]bm[odified][!] [N] *:bm* *:bmodified* *E84* - Go to [N]th next modified buffer. Note: this command also - finds unlisted buffers. If there is no modified buffer the - command fails. - -:[N]sbm[odified] [N] *:sbm* *:sbmodified* - Split window and go to [N]th next modified buffer. - Respects 'switchbuf' option. - Note: this command also finds buffers not in the buffer list. - -:[N]unh[ide] [N] *:unh* *:unhide* *:sun* *:sunhide* -:[N]sun[hide] [N] - Rearrange the screen to open one window for each loaded buffer - in the buffer list. When a count is given, this is the - maximum number of windows to open. - -:[N]ba[ll] [N] *:ba* *:ball* *:sba* *:sball* -:[N]sba[ll] [N] Rearrange the screen to open one window for each buffer in - the buffer list. When a count is given, this is the maximum - number of windows to open. 'winheight' also limits the number - of windows opened ('winwidth' if |:vertical| was prepended). - Buf/Win Enter/Leave autocommands are not executed for the new - windows here, that's only done when they are really entered. - When the |:tab| modifier is used new windows are opened in a - new tab, up to 'tabpagemax'. - -Note: All the commands above that start editing another buffer, keep the -'readonly' flag as it was. This differs from the ":edit" command, which sets -the 'readonly' flag each time the file is read. - -============================================================================== -12. Special kinds of buffers *special-buffers* - -Instead of containing the text of a file, buffers can also be used for other -purposes. A few options can be set to change the behavior of a buffer: - 'bufhidden' what happens when the buffer is no longer displayed - in a window. - 'buftype' what kind of a buffer this is - 'swapfile' whether the buffer will have a swap file - 'buflisted' buffer shows up in the buffer list - -A few useful kinds of a buffer: - -quickfix Used to contain the error list or the location list. See - |:cwindow| and |:lwindow|. This command sets the 'buftype' - option to "quickfix". You are not supposed to change this! - 'swapfile' is off. - -help Contains a help file. Will only be created with the |:help| - command. The flag that indicates a help buffer is internal - and can't be changed. The 'buflisted' option will be reset - for a help buffer. - -directory Displays directory contents. Can be used by a file explorer - plugin. The buffer is created with these settings: > - :setlocal buftype=nowrite - :setlocal bufhidden=delete - :setlocal noswapfile -< The buffer name is the name of the directory and is adjusted - when using the |:cd| command. - -scratch Contains text that can be discarded at any time. It is kept - when closing the window, it must be deleted explicitly. - Settings: > - :setlocal buftype=nofile - :setlocal bufhidden=hide - :setlocal noswapfile -< The buffer name can be used to identify the buffer. - - *unlisted-buffer* -unlisted The buffer is not in the buffer list. It is not used for - normal editing, but to show a help file, remember a file name - or marks. The ":bdelete" command will also set this option, - thus it doesn't completely delete the buffer. Settings: > - :setlocal nobuflisted -< - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/workshop.txt b/share/vim/vim72/doc/workshop.txt deleted file mode 100644 index 0ec4555365..0000000000 --- a/share/vim/vim72/doc/workshop.txt +++ /dev/null @@ -1,98 +0,0 @@ -*workshop.txt* For Vim version 7.2. Last change: 2006 Apr 24 - - - VIM REFERENCE MANUAL by Gordon Prieur - - -Sun Visual WorkShop Features *workshop* *workshop-support* - -1. Introduction |workshop-intro| -2. Commands |workshop-commands| -3. Compiling vim/gvim for WorkShop |workshop-compiling| -4. Configuring gvim for a WorkShop release tree |workshop-configure| -5. Obtaining the latest version of the XPM library |workshop-xpm| - -{Vi does not have any of these features} -{only available when compiled with the |+sun_workshop| feature} - -============================================================================== -1. Introduction *workshop-intro* - -Sun Visual WorkShop has an "Editor of Choice" feature designed to let users -debug using their favorite editors. For the 6.0 release we have added support -for gvim. A workshop debug session will have a debugging window and an editor -window (possibly others as well). The user can do many debugging operations -from the editor window, minimizing the need to switch from window to window. - -The version of vim shipped with Sun Visual WorkShop 6 (also called Forte -Developer 6) is vim 5.3. The features in this release are much more reliable -than the vim/gvim shipped with Visual WorkShop. VWS users wishing to use vim -as their editor should compile these sources and install them in their -workshop release tree. - -============================================================================== -2. Commands *workshop-commands* - - *:ws* *:wsverb* -:ws[verb] verb Pass the verb to the verb executor - -Pass the verb to a workshop function which gathers some arguments and -sends the verb and data to workshop over an IPC connection. - -============================================================================== -3. Compiling vim/gvim for WorkShop *workshop-compiling* - -Compiling vim with FEAT_SUN_WORKSHOP turns on all compile time flags necessary -for building a vim to work with Visual WorkShop. The features required for VWS -have been built and tested using the Sun compilers from the VWS release. They -have not been built or tested using Gnu compilers. This does not mean the -features won't build and run if compiled with gcc, just that nothing is -guaranteed with gcc! - -============================================================================== -4. Configuring gvim for a WorkShop release tree *workshop-configure* - -There are several assumptions which must be met in order to compile a gvim for -use with Sun Visual WorkShop 6. - - o You should use the compiler in VWS rather than gcc. We have neither - built nor tested with gcc and cannot guarantee it will build properly. - - o You must supply your own XPM library. See |workshop-xpm| below for - details on obtaining the latest version of XPM. - - o Edit the Makefile in the src directory and uncomment the lines for Sun - Visual WorkShop. You can easily find these by searching for the string - FEAT_SUN_WORKSHOP - - o We also suggest you use Motif for your gui. This will provide gvim with - the same look-and-feel as the rest of Sun Visual WorkShop. - -The following configuration line can be used to configure vim to build for use -with Sun Visual WorkShop: - - $ CC=cc configure --enable-workshop --enable-gui=motif \ - -prefix=<VWS-install-dir>/contrib/contrib6/<vim-version> - -The VWS-install-dir should be the base directory where your Sun Visual WorkShop -was installed. By default this is /opt/SUNWspro. It will normally require -root permissions to install the vim release. You will also need to change the -symlink <VWS-install-dir>/bin/gvim to point to the vim in your newly installed -directory. The <vim-version> should be a unique version string. I use "vim" -concatenated with the equivalent of version.h's VIM_VERSION_SHORT. - -============================================================================== -5. Obtaining the latest version of the XPM library *workshop-xpm* - -The XPM library is required to show images within Vim with Motif or Athena. -Without it the toolbar and signs will be disabled. - -The XPM library is provide by Arnaud Le Hors of the French National Institute -for Research in Computer Science and Control. It can be downloaded from -http://koala.ilog.fr/ftp/pub/xpm. The current release, as of this writing, is -xpm-3.4k-solaris.tgz, which is a gzip'ed tar file. If you create the directory -/usr/local/xpm and untar the file there you can use the uncommented lines in -the Makefile without changing them. If you use another xpm directory you will -need to change the XPM_DIR in src/Makefile. - - vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim72/doc/xxd-fr.1 b/share/vim/vim72/doc/xxd-fr.1 deleted file mode 100644 index dfbc291032..0000000000 --- a/share/vim/vim72/doc/xxd-fr.1 +++ /dev/null @@ -1,395 +0,0 @@ -.TH XXD 1 "août 1996" "Page de manuel pour xxd" -.\" -.\" 21st May 1996 -.\" Man page author: -.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.\" Changes by Bram Moolenaar <Bram@vim.org> -.\" French translation by David Blanchet <david.blanchet@free.fr> 2005-03 -.SH NOM -.I xxd -\- convertit en représentation hexadécimale et inversement. -.SH SYNOPSIS -.B xxd -\-h[elp] -.br -.B xxd -[options] [fichier_entree [fichier_sortie]] -.br -.B xxd -\-r[evert] [options] [fichier_entree [fichier_sortie]] -.SH DESCRIPTION -.I xxd -crée un fichier contenant la représentation hexadécimale d'un fichier -binaire ou de l'entrée standard. -Il peut également convertir un fichier de codes hexadécimaux en un fichier -binaire. -Comme -.BR uuencode (1) -et -.BR uudecode (1) -il permet la transmission de données binaires dans une représentation ASCII -compatible avec le courrier électronique, mais a l'avantage de décoder la -sortie standard. -De plus, il peut être utilisé pour appliquer des rustines à des fichiers -binaires. -.SH OPTIONS -Si aucun -.I fichier_entree -n'est spécifié, l'entrée standard est utilisée. -Si -.I fichier_entree -correspond au caractère -.RB '\-' -\, l'entrée standard est employée comme source des données en entrée. -Si aucun -.I fichier_sortie -n'est spécifié (ou qu'un caractère -.RB '\-' -est donné à sa place), le résultat est envoyé sur la sortie standard. -.PP -NOTE : un analyseur paresseux est utilisé. Il ne vérifie pas au-delà de la -première lettre de l'option, à moins que cette dernière ne requiert un -paramètre. -L'espace entre l'option et son paramètre est optionnel. -Les paramètres des options peuvent être spécifiés en notation décimale, -hexadécimale ou octale. -Ainsi -.BR \-c8 , -.BR "\-c 8" , -.B \-c 010 -et -.B \-cols 8 -sont tous équivalents. -.TP -.IR \-a " | " \-autoskip -active la fonctionnalité "autoskip" : le caractère '*' remplace les lignes -d'octets nuls. Désactivée par défaut. -.TP -.IR \-b " | " \-bits -Convertit en binaires plutôt qu'en hexadécimal. -Cette option écrit les octets comme une séquence de "1" et de "0" au lieu -d'une conversion en hexadécimal traditionnel. Chaque ligne est précédée par un -numéro de ligne en hexadécimal et suivie de la représentation ASCII (ou -EBCDIC) correspondante. Les options \-r, \-p, \-i ne fonctionnent pas dans ce -mode. -.TP -.IR "\-c cols " | " \-cols cols" -place -.RI < cols > -octets par ligne. 16 par défaut (\-i : 12, \-ps : 30, \-b : 6). Maximum 256. -.TP -.IR \-E " | " \-EBCDIC -Passe le codage des caractères de la colonne de droite de ASCII à EBCDIC. -Cela ne change pas la représentation hexadécimale. Cette option est sans effet -quand elle est utilisée avec \-r, \-p or \-i. -.TP -.IR "\-g octets " | " \-groupsize octets" -Regroupe les octets (deux chiffres hexadécimaux ou huit chiffres binaires) -par groupe de -.RI < octets > -\, séparés par des espaces blancs. Spécifiez -.I \-g 0 -pour supprimer le regroupement. -.RI < octets > -vaut 2 par défaut dans le mode normal et \fI1\fP en -représentation binaire. Le regroupement ne s'applique pas aux styles -Postscript et Include. -.TP -.IR \-h " | " \-help -Affiche un résumé des commandes disponibles et quitte. Aucune conversion n'est -effectuée. -.TP -.IR \-i " | " \-include -produit une sortie dans le style #include (fichier C à inclure). La définition -complète d'un tableau statique est écrite et est nommée d'après le fichier -d'origine, à moins que xxd lise depuis l'entrée standard. -.TP -.IR "\-l long " | " \-len long" -Arrête après l'écriture de -.RI < long > -octets. -.TP -.IR \-p " | " \-ps " | " \-postscript " | " \-plain -Produit une conversion continue dans le style Postscript (postscript continuous -hexdumd style). -Également connu sous le nom de « conversion brute » (plain hexdump style). -.TP -.IR \-r " | " \-revert -Opération inverse : convertit un fichier hexadécimal en un fichier binaire (ou -applique une rustine à un fichier binaire). -Si l'écriture n'a pas lieu sur la sortie standard, xxd écrit dans le fichier -qu'il produit sans le tronquer. Utilisez la combinaison -.I \-r \-p -pour lire de l'hexadécimal brut sans information sur le numéro des lignes et -sans format de colonnes particulier. Des espaces blancs et coupures de lignes -supplémentaires sont autorisés à n'importe quel endroit. -.TP -.I \-seek décalage -Utilisé après l'option -.IR \-r : -inverse la conversion en ajoutant -.RI < décalage > -aux positions dans le fichier données dans le code hexadécimal. -.TP -.I \-s [+][\-]décalage -Débute au -.RI < décalage > -absolu ou relatif dans fichier_entree. -\fI+ fRindique que le décalage est relatif à la position courante dans -l'entrée standard (sans effet si la lecture n'a pas lieu sur l'entrée -standard). \fI\- \fRindique un décalage en caractères depuis la fin de -l'entrée (utilisé avec \fI+\fR, désigne la position avant la position -actuelle de l'entrée standard). -Sans l'option \-s, xxd démarre à la position courante du fichier. -.TP -.I \-u -Utilise des chiffres hexadécimaux majuscules. La casse par défaut est -minuscule. -.TP -.IR \-v " | " \-version -Affiche la version de xxd. -.SH MISE EN GARDE -.I xxd \-r -effectue des opérations internes un peu obscures lors de l'évaluation -des informations sur les numéros de lignes. Si le fichier de sortie est -adressable, alors les numéros de lignes au début de chaque ligne d'hexadécimal -peuvent être désordonnées, des lignes peuvent manquer ou se chevaucher. Dans -ces cas, xxd utilisera lseek(2) pour déterminer la prochaine position. Si le -fichier n'est pas adressable, seuls les vides sont autorisés, et ils seront -comblés par des octets nuls. -.PP -.I xxd \-r -ne génère aucune erreur lors de l'analyse. Le problème sont passés -silencieusement. -.PP -Lors de l'édition de la représentation hexadécimale, veuillez noter que -.I xxd \-r -ignore tout ce qui se trouve sur la ligne après avoir lu suffisamment de -données hexadécimales (voir l'option \-c). Cela signifie également que les -modifications dans la colonne ASCII (ou EBCDIC) sont toujours ignorées. La -conversion inverse de données hexadécimales brutes (postscript) avec xxd \-r -\-p ne dépend pas d'un nombre correct de colonnes. Dans ce cas, tout ce qui -ressemble à une paire de chiffres hexadécimaux est interprété. -.PP -Remarquez la différence entre -.br -\fI% xxd \-i fichier\fR -.br -et -.br -\fI% xxd \-i < fichier\fR -.PP -.I xxd \-s \+seek -peut différer de -.IR "xxd \-s seek" , -car lseek(2) est utilisé pour « revenir en arrière ». Le '+' fait une -différence quand la source des données est l'entrée standard et si la position -dans le fichier de l'entrée standard n'est pas au début du fichier lorsque xxd -est démarré et qu'il reçoit ses données. -L'exemple suivant peut vous aider à comprendre (ou bien vous perdre davantage -encore !)... -.PP -Remettre l'entrée standard au départ avant de lire ; nécessaire car 'cat' a -déjà lu jusqu'à la fin de l'entrée standard. -.br -\fI% sh \-c 'cat > donnees_binaires; xxd \-s 0 > donnees_hexa' < fichier\fR -.PP -Convertir à partir de la position 0x480 (= 1024 + 128) du fichier. -Le symbole '+' signifie "relativement à la position actuelle', ainsi 128 est -ajouté aux 1024 octets comptabilisés pour dd. -.br -\fI% sh \-c 'dd of=donnees_binaires bs=1k count=1; xxd \-s +128 > -donnees_hexa' < fichier\fR -.PP -Convertir de fichier depuis la position 0x100 (= 1024 \- 768) du fichier. -.br -\fI% sh \-c 'dd of=donnees_binaires bs=1k count=1; xxd \-s +\-768 > -donnees_hexa' < fichier\fR -.PP -Toutefois, cette situation est peu fréquente et l'utilisation de '+' est -rarement requise. L'auteur préfère surveiller les effets de xxd avec strace(1) -ou truss(1) quand \-s est employé. -.SH EXEMPLES -Afficher la totalité du -.B fichier -sauf les trois premières lignes (0x30 octets en hexadécimal). -.br -\fI% xxd \-s 0x30 fichier\fR -.PP -afficher les trois dernières lignes (0x30 octets en hexadécimal) du -.B fichier -\. -.br -\fI% xxd \-s \-0x30 fichier\fR -.PP -.br -Afficher 120 octets convertis en continu, avec 20 octets par ligne. -.br -\fI% xxd \-l 120 \-ps \-c 20 xxd\-fr.1\fR -.br -2e54482058584420312022616ffb742031393936 -.br -22202250616765206465206d616e75656c20706f -.br -757220787864220a2e5c220a2e5c222032317374 -.br -204d617920313939360a2e5c22204d616e207061 -.br -676520617574686f723a0a2e5c2220202020546f -.br -6e79204e7567656e74203c746f6e79407363746e -.br -204e7567656e74203c746f6e79407363746e7567 -.br -2e54482058584420312022417567757374203139 -.PP -Convertir les 120 premiers octets de cette page de manuel avec 12 octets par -ligne. -.br -\fI% xxd \-l 120 \-c 12 xxd\-fr.1\fR -.br -0000000: 2e54 4820 5858 4420 3120 2261 .TH XXD 1 "a -.br -000000c: 6ffb 7420 3139 3936 2220 2250 o.t 1996" "P -.br -0000018: 6167 6520 6465 206d 616e 7565 age de manue -.br -0000024: 6c20 706f 7572 2078 7864 220a l pour xxd". -.br -0000030: 2e5c 220a 2e5c 2220 3231 7374 .\"..\" 21st -.br -000003c: 204d 6179 2031 3939 360a 2e5c May 1996..\ -.br -0000048: 2220 4d61 6e20 7061 6765 2061 " Man page a -.br -0000054: 7574 686f 723a 0a2e 5c22 2020 uthor:..\" -.br -0000060: 2020 546f 6e79 204e 7567 656e Tony Nugen -.br -000006c: 7420 3c74 6f6e 7940 7363 746e t <tony@sctn -.PP -Afficher la date écrite au début du fichier xxd\-fr.1. -.br -\fI% xxd \-s 0x38 \-l 13 \-c 13 xxd.1\fR -.br -0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 -.PP -Copier -.B fichier_entree -vers -.B fichier_sortie -en ajoutant 100 octets de valeur 0x00 avant. -.br -\fI% xxd fichier_entree | xxd \-r \-s 100 \> fichier_sortie\fR -.PP -Patcher la date dans le fichier xxd.1 -.br -\fI% echo '0000037: 3574 68' | xxd \-r \- xxd\-fr.1\fR -.br -\fI% xxd \-s 0x38 \-l 13 \-c 13 xxd\-fr.1\fR -.br -0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 -.PP -Créer un fichier de 65537 octets tous nuls (0x00), -sauf le dernier qui vaut 'A' (0x41 en hexadécimal). -.br -\fI% echo '010000: 41' | xxd \-r \> fichier\fR -.PP -.br -Convertir le fichier de l'exemple précédent avec la fonctionnalité "autoskip". -.br -\fI% xxd \-a \-c 12 fichier\fR -.br -0000000: 0000 0000 0000 0000 0000 0000 ............ -.br -* -.br -000fffc: 0000 0000 40 ....A -.PP -Créer un fichier d'un octet, contenant seulement le caractère 'A'. -Les nombres après '\-r \-s' s'ajoutent au numéros de lignes trouvées dans le -fichier ; XXX in effects, les octets initiaux sont supprimés. -.br -\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> fichier\fR -.PP -Utiliser xxd comme filtre dans un éditeur tel que -.B vim(1) -pour convertir une zone comprise entre les marques 'a' et 'z'. -.br -\fI:'a,'z!xxd\fR -.PP -Utiliser xxd comme filtre dans un éditeur tel que -.B vim(1) -pour récupérer une conversion binaire comprise entre les marques 'a' et 'z'. -.br -\fI:'a,'z!xxd \-r\fR -.PP -Utiliser xxd comme filtre dans un éditeur tel que -.B vim(1) -pour récupérer une ligne convertie. Placez le curseur sur la ligne et tapez : -.br -\fI!!xxd \-r\fR -.PP -Lire des caractères depuis une connexion série : -.br -\fI% xxd \-c1 < /dev/term/b &\fR -.br -\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR -.br -\fI% echo \-n foo > /dev/term/b\fR -.SH VALEURS DE RETOUR -Les erreurs suivantes sont rapportées : -.TP -0 -aucune erreur ne s'est produit. -.TP -\-1 -opération non supportée ( -.I xxd \-r \-i -reste impossible). -.TP -1 -erreur lors de l'analyse des options. -.TP -2 -problème avec le fichier d'entrée. -.TP -3 -problème avec le fichier de sortie. -.TP -4, 5 -la position spécifiée n'est pas atteignable. -.SH VOIR AUSSI -uuencode(1), uudecode(1), patch(1) -.SH AVERTISSEMENTS -L'étrangeté de cet outil reflète celle du cerveau de ses créateurs. -Utilisez cet outil à vos risques et périls. Dupliquez vos fichiers. -Surveillez l'outil. Devenez un gourou. -.SH VERSION -Cette page de manuel documente la version 1.7 de xxd. -.SH AUTEUR -(c) 1990-1997 par Juergen Weigert -.br -<jnweiger@informatik.uni-erlangen.de> -.LP -"Distribute freely and credit me, -.br -make money and share with me, -.br -lose money and don't ask me." -.PP -Distribution libre en citant l'auteur, -.br -gagnez de l'argent, pensez à moi, -.br -perdez de l'argent, oubliez-moi. -.PP -Page de manuel débutée par Tony Nugent -.br -<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.br -Modifications mineures par Bram Moolenaar. -Édité par Juergen Weigert. -.SH TRADUCTION -Cette page de manuel a été traduite par David Blanchet -<david.blanchet@free.fr> 2004-12-24. diff --git a/share/vim/vim72/doc/xxd-fr.UTF-8.1 b/share/vim/vim72/doc/xxd-fr.UTF-8.1 deleted file mode 100644 index 7bdb655bae..0000000000 --- a/share/vim/vim72/doc/xxd-fr.UTF-8.1 +++ /dev/null @@ -1,395 +0,0 @@ -.TH XXD 1 "août 1996" "Page de manuel pour xxd" -.\" -.\" 21st May 1996 -.\" Man page author: -.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.\" Changes by Bram Moolenaar <Bram@vim.org> -.\" French translation by David Blanchet <david.blanchet@free.fr> 2005-03 -.SH NOM -.I xxd -\- convertit en représentation hexadécimale et inversement. -.SH SYNOPSIS -.B xxd -\-h[elp] -.br -.B xxd -[options] [fichier_entree [fichier_sortie]] -.br -.B xxd -\-r[evert] [options] [fichier_entree [fichier_sortie]] -.SH DESCRIPTION -.I xxd -crée un fichier contenant la représentation hexadécimale d'un fichier -binaire ou de l'entrée standard. -Il peut également convertir un fichier de codes hexadécimaux en un fichier -binaire. -Comme -.BR uuencode (1) -et -.BR uudecode (1) -il permet la transmission de données binaires dans une représentation ASCII -compatible avec le courrier électronique, mais a l'avantage de décoder la -sortie standard. -De plus, il peut être utilisé pour appliquer des rustines à des fichiers -binaires. -.SH OPTIONS -Si aucun -.I fichier_entree -n'est spécifié, l'entrée standard est utilisée. -Si -.I fichier_entree -correspond au caractère -.RB '\-' -\, l'entrée standard est employée comme source des données en entrée. -Si aucun -.I fichier_sortie -n'est spécifié (ou qu'un caractère -.RB '\-' -est donné à sa place), le résultat est envoyé sur la sortie standard. -.PP -NOTE : un analyseur paresseux est utilisé. Il ne vérifie pas au-delà de la -première lettre de l'option, à moins que cette dernière ne requiert un -paramètre. -L'espace entre l'option et son paramètre est optionnel. -Les paramètres des options peuvent être spécifiés en notation décimale, -hexadécimale ou octale. -Ainsi -.BR \-c8 , -.BR "\-c 8" , -.B \-c 010 -et -.B \-cols 8 -sont tous équivalents. -.TP -.IR \-a " | " \-autoskip -active la fonctionnalité "autoskip" : le caractère '*' remplace les lignes -d'octets nuls. Désactivée par défaut. -.TP -.IR \-b " | " \-bits -Convertit en binaires plutôt qu'en hexadécimal. -Cette option écrit les octets comme une séquence de "1" et de "0" au lieu -d'une conversion en hexadécimal traditionnel. Chaque ligne est précédée par un -numéro de ligne en hexadécimal et suivie de la représentation ASCII (ou -EBCDIC) correspondante. Les options \-r, \-p, \-i ne fonctionnent pas dans ce -mode. -.TP -.IR "\-c cols " | " \-cols cols" -place -.RI < cols > -octets par ligne. 16 par défaut (\-i : 12, \-ps : 30, \-b : 6). Maximum 256. -.TP -.IR \-E " | " \-EBCDIC -Passe le codage des caractères de la colonne de droite de ASCII à EBCDIC. -Cela ne change pas la représentation hexadécimale. Cette option est sans effet -quand elle est utilisée avec \-r, \-p or \-i. -.TP -.IR "\-g octets " | " \-groupsize octets" -Regroupe les octets (deux chiffres hexadécimaux ou huit chiffres binaires) -par groupe de -.RI < octets > -\, séparés par des espaces blancs. Spécifiez -.I \-g 0 -pour supprimer le regroupement. -.RI < octets > -vaut 2 par défaut dans le mode normal et \fI1\fP en -représentation binaire. Le regroupement ne s'applique pas aux styles -Postscript et Include. -.TP -.IR \-h " | " \-help -Affiche un résumé des commandes disponibles et quitte. Aucune conversion n'est -effectuée. -.TP -.IR \-i " | " \-include -produit une sortie dans le style #include (fichier C à inclure). La définition -complète d'un tableau statique est écrite et est nommée d'après le fichier -d'origine, à moins que xxd lise depuis l'entrée standard. -.TP -.IR "\-l long " | " \-len long" -Arrête après l'écriture de -.RI < long > -octets. -.TP -.IR \-p " | " \-ps " | " \-postscript " | " \-plain -Produit une conversion continue dans le style Postscript (postscript continuous -hexdumd style). -Également connu sous le nom de « conversion brute » (plain hexdump style). -.TP -.IR \-r " | " \-revert -Opération inverse : convertit un fichier hexadécimal en un fichier binaire (ou -applique une rustine à un fichier binaire). -Si l'écriture n'a pas lieu sur la sortie standard, xxd écrit dans le fichier -qu'il produit sans le tronquer. Utilisez la combinaison -.I \-r \-p -pour lire de l'hexadécimal brut sans information sur le numéro des lignes et -sans format de colonnes particulier. Des espaces blancs et coupures de lignes -supplémentaires sont autorisés à n'importe quel endroit. -.TP -.I \-seek décalage -Utilisé après l'option -.IR \-r : -inverse la conversion en ajoutant -.RI < décalage > -aux positions dans le fichier données dans le code hexadécimal. -.TP -.I \-s [+][\-]décalage -Débute au -.RI < décalage > -absolu ou relatif dans fichier_entree. -\fI+ fRindique que le décalage est relatif à la position courante dans -l'entrée standard (sans effet si la lecture n'a pas lieu sur l'entrée -standard). \fI\- \fRindique un décalage en caractères depuis la fin de -l'entrée (utilisé avec \fI+\fR, désigne la position avant la position -actuelle de l'entrée standard). -Sans l'option \-s, xxd démarre à la position courante du fichier. -.TP -.I \-u -Utilise des chiffres hexadécimaux majuscules. La casse par défaut est -minuscule. -.TP -.IR \-v " | " \-version -Affiche la version de xxd. -.SH MISE EN GARDE -.I xxd \-r -effectue des opérations internes un peu obscures lors de l'évaluation -des informations sur les numéros de lignes. Si le fichier de sortie est -adressable, alors les numéros de lignes au début de chaque ligne d'hexadécimal -peuvent être désordonnées, des lignes peuvent manquer ou se chevaucher. Dans -ces cas, xxd utilisera lseek(2) pour déterminer la prochaine position. Si le -fichier n'est pas adressable, seuls les vides sont autorisés, et ils seront -comblés par des octets nuls. -.PP -.I xxd \-r -ne génère aucune erreur lors de l'analyse. Le problème sont passés -silencieusement. -.PP -Lors de l'édition de la représentation hexadécimale, veuillez noter que -.I xxd \-r -ignore tout ce qui se trouve sur la ligne après avoir lu suffisamment de -données hexadécimales (voir l'option \-c). Cela signifie également que les -modifications dans la colonne ASCII (ou EBCDIC) sont toujours ignorées. La -conversion inverse de données hexadécimales brutes (postscript) avec xxd \-r -\-p ne dépend pas d'un nombre correct de colonnes. Dans ce cas, tout ce qui -ressemble à une paire de chiffres hexadécimaux est interprété. -.PP -Remarquez la différence entre -.br -\fI% xxd \-i fichier\fR -.br -et -.br -\fI% xxd \-i < fichier\fR -.PP -.I xxd \-s \+seek -peut différer de -.IR "xxd \-s seek" , -car lseek(2) est utilisé pour « revenir en arrière ». Le '+' fait une -différence quand la source des données est l'entrée standard et si la position -dans le fichier de l'entrée standard n'est pas au début du fichier lorsque xxd -est démarré et qu'il reçoit ses données. -L'exemple suivant peut vous aider à comprendre (ou bien vous perdre davantage -encore !)... -.PP -Remettre l'entrée standard au départ avant de lire ; nécessaire car 'cat' a -déjà lu jusqu'à la fin de l'entrée standard. -.br -\fI% sh \-c 'cat > donnees_binaires; xxd \-s 0 > donnees_hexa' < fichier\fR -.PP -Convertir à partir de la position 0x480 (= 1024 + 128) du fichier. -Le symbole '+' signifie "relativement à la position actuelle', ainsi 128 est -ajouté aux 1024 octets comptabilisés pour dd. -.br -\fI% sh \-c 'dd of=donnees_binaires bs=1k count=1; xxd \-s +128 > -donnees_hexa' < fichier\fR -.PP -Convertir de fichier depuis la position 0x100 (= 1024 \- 768) du fichier. -.br -\fI% sh \-c 'dd of=donnees_binaires bs=1k count=1; xxd \-s +\-768 > -donnees_hexa' < fichier\fR -.PP -Toutefois, cette situation est peu fréquente et l'utilisation de '+' est -rarement requise. L'auteur préfère surveiller les effets de xxd avec strace(1) -ou truss(1) quand \-s est employé. -.SH EXEMPLES -Afficher la totalité du -.B fichier -sauf les trois premières lignes (0x30 octets en hexadécimal). -.br -\fI% xxd \-s 0x30 fichier\fR -.PP -afficher les trois dernières lignes (0x30 octets en hexadécimal) du -.B fichier -\. -.br -\fI% xxd \-s \-0x30 fichier\fR -.PP -.br -Afficher 120 octets convertis en continu, avec 20 octets par ligne. -.br -\fI% xxd \-l 120 \-ps \-c 20 xxd\-fr.1\fR -.br -2e54482058584420312022616ffb742031393936 -.br -22202250616765206465206d616e75656c20706f -.br -757220787864220a2e5c220a2e5c222032317374 -.br -204d617920313939360a2e5c22204d616e207061 -.br -676520617574686f723a0a2e5c2220202020546f -.br -6e79204e7567656e74203c746f6e79407363746e -.br -204e7567656e74203c746f6e79407363746e7567 -.br -2e54482058584420312022417567757374203139 -.PP -Convertir les 120 premiers octets de cette page de manuel avec 12 octets par -ligne. -.br -\fI% xxd \-l 120 \-c 12 xxd\-fr.1\fR -.br -0000000: 2e54 4820 5858 4420 3120 2261 .TH XXD 1 "a -.br -000000c: 6ffb 7420 3139 3936 2220 2250 o.t 1996" "P -.br -0000018: 6167 6520 6465 206d 616e 7565 age de manue -.br -0000024: 6c20 706f 7572 2078 7864 220a l pour xxd". -.br -0000030: 2e5c 220a 2e5c 2220 3231 7374 .\"..\" 21st -.br -000003c: 204d 6179 2031 3939 360a 2e5c May 1996..\ -.br -0000048: 2220 4d61 6e20 7061 6765 2061 " Man page a -.br -0000054: 7574 686f 723a 0a2e 5c22 2020 uthor:..\" -.br -0000060: 2020 546f 6e79 204e 7567 656e Tony Nugen -.br -000006c: 7420 3c74 6f6e 7940 7363 746e t <tony@sctn -.PP -Afficher la date écrite au début du fichier xxd\-fr.1. -.br -\fI% xxd \-s 0x38 \-l 13 \-c 13 xxd.1\fR -.br -0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 -.PP -Copier -.B fichier_entree -vers -.B fichier_sortie -en ajoutant 100 octets de valeur 0x00 avant. -.br -\fI% xxd fichier_entree | xxd \-r \-s 100 \> fichier_sortie\fR -.PP -Patcher la date dans le fichier xxd.1 -.br -\fI% echo '0000037: 3574 68' | xxd \-r \- xxd\-fr.1\fR -.br -\fI% xxd \-s 0x38 \-l 13 \-c 13 xxd\-fr.1\fR -.br -0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 -.PP -Créer un fichier de 65537 octets tous nuls (0x00), -sauf le dernier qui vaut 'A' (0x41 en hexadécimal). -.br -\fI% echo '010000: 41' | xxd \-r \> fichier\fR -.PP -.br -Convertir le fichier de l'exemple précédent avec la fonctionnalité "autoskip". -.br -\fI% xxd \-a \-c 12 fichier\fR -.br -0000000: 0000 0000 0000 0000 0000 0000 ............ -.br -* -.br -000fffc: 0000 0000 40 ....A -.PP -Créer un fichier d'un octet, contenant seulement le caractère 'A'. -Les nombres après '\-r \-s' s'ajoutent au numéros de lignes trouvées dans le -fichier ; XXX in effects, les octets initiaux sont supprimés. -.br -\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> fichier\fR -.PP -Utiliser xxd comme filtre dans un éditeur tel que -.B vim(1) -pour convertir une zone comprise entre les marques 'a' et 'z'. -.br -\fI:'a,'z!xxd\fR -.PP -Utiliser xxd comme filtre dans un éditeur tel que -.B vim(1) -pour récupérer une conversion binaire comprise entre les marques 'a' et 'z'. -.br -\fI:'a,'z!xxd \-r\fR -.PP -Utiliser xxd comme filtre dans un éditeur tel que -.B vim(1) -pour récupérer une ligne convertie. Placez le curseur sur la ligne et tapez : -.br -\fI!!xxd \-r\fR -.PP -Lire des caractères depuis une connexion série : -.br -\fI% xxd \-c1 < /dev/term/b &\fR -.br -\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR -.br -\fI% echo \-n foo > /dev/term/b\fR -.SH VALEURS DE RETOUR -Les erreurs suivantes sont rapportées : -.TP -0 -aucune erreur ne s'est produit. -.TP -\-1 -opération non supportée ( -.I xxd \-r \-i -reste impossible). -.TP -1 -erreur lors de l'analyse des options. -.TP -2 -problème avec le fichier d'entrée. -.TP -3 -problème avec le fichier de sortie. -.TP -4, 5 -la position spécifiée n'est pas atteignable. -.SH VOIR AUSSI -uuencode(1), uudecode(1), patch(1) -.SH AVERTISSEMENTS -L'étrangeté de cet outil reflète celle du cerveau de ses créateurs. -Utilisez cet outil à vos risques et périls. Dupliquez vos fichiers. -Surveillez l'outil. Devenez un gourou. -.SH VERSION -Cette page de manuel documente la version 1.7 de xxd. -.SH AUTEUR -(c) 1990-1997 par Juergen Weigert -.br -<jnweiger@informatik.uni-erlangen.de> -.LP -"Distribute freely and credit me, -.br -make money and share with me, -.br -lose money and don't ask me." -.PP -Distribution libre en citant l'auteur, -.br -gagnez de l'argent, pensez à moi, -.br -perdez de l'argent, oubliez-moi. -.PP -Page de manuel débutée par Tony Nugent -.br -<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.br -Modifications mineures par Bram Moolenaar. -Édité par Juergen Weigert. -.SH TRADUCTION -Cette page de manuel a été traduite par David Blanchet -<david.blanchet@free.fr> 2004-12-24. diff --git a/share/vim/vim72/doc/xxd-it.1 b/share/vim/vim72/doc/xxd-it.1 deleted file mode 100644 index 41298495a0..0000000000 --- a/share/vim/vim72/doc/xxd-it.1 +++ /dev/null @@ -1,402 +0,0 @@ -.TH XXD 1 "Agosto 1996" "Pagina di manuale per xxd" -.\" -.\" 21 Maggio 1996 -.\" Autore della pagina di manuale: -.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.\" Modificato da Bram Moolenaar <Bram@vim.org> -.SH NOME -.I xxd -\- Produce esadecimale da un file binario o viceversa. -.SH SINTASSI -.B xxd -\-h[elp] -.br -.B xxd -[opzioni] [input_file [output_file]] -.br -.B xxd -\-r[evert] [opzioni] [input_file [output_file]] -.SH DESCRIZIONE -.I xxd -crea un'immagine esadecimale di un dato file o dello "standard input". -Può anche ottenere da un'immagine esadecimale il file binario originale. -Come -.BR uuencode (1) -e -.BR uudecode (1) -permette di trasmettere dati binari in una rapresentazione ASCII "a prova -di email", ma ha anche il vantaggio di poter decodificare sullo "standard -output". Inoltre, può essere usato per effettuare delle modifiche (patch) -a file binari. -.SH OPZIONI -Se non si specifica un -.I input_file -il programma legge dallo "standard input". -Se -.I input_file -è specificato come il carattere -.RB \` \- ' -, l'input è letto dallo "standard input". -Se non si specifica un -.I output_file -(o si mette al suo posto il carattere -.RB \` \- ' -), i risultati sono inviati allo "standard output". -.PP -Si noti che la scansione dei caratteri è "pigra", e non controlla oltre -la prima lettera dell'opzione, a meno che l'opzione sia seguita da un -parametro. -Gli spazi fra una singola lettera di opzione e il corrispondente parametro -dopo di essa sono facoltativi. -I parametri delle opzioni possono essere specificati usando la notazione -decimale, esadecimale oppure ottale. -Pertanto -.BR \-c8 , -.BR "\-c 8" , -.B \-c 010 -e -.B \-cols 8 -sono notazioni equivalenti fra loro. -.PP -.TP -.IR \-a " | " \-autoskip -Richiesta di autoskip: Un singolo '*' rimpiazza linee di zeri binari. -Valore predefinito: off. -.TP -.IR \-b " | " \-bits -Richiesta di una immagine binaria (cifre binarie), invece che esadecimale. -Questa opzione scrive un byte come otto cifre "1" e "0" invece di usare i -numeri esadecimali. Ogni linea è preceduta da un indirizzo in esadecimale e -seguita da una decodifica ascii (o ebcdic). Le opzioni specificabili dalla -linea comando \-r, \-p, \-i non funzionano in questo modo. -.TP -.IR "\-c colonne " | " \-cols colonne" -.IR "\-c colonne " | " \-cols colonne" -In ogni linea sono formattate -.RI < colonne > -colonne. Valore predefinito 16 (\-i: 12, \-ps: 30, \-b: 6). -Valore massimo 256. -.TP -.IR \-E " | " \-EBCDIC -Cambia la codifica della colonna di destra da ASCII a EBCDIC. -Questo non modifica la rappresentazione esadecimale. Non ha senso -specificare questa opzione in combinazione con \-r, \-p o \-i. -.TP -.IR "\-g bytes " | " \-groupsize bytes" -Inserisci ogni -.RI < bytes > -bytes di output (di due caratteri esadecimali o otto numeri binari ognuno) -uno spazio bianco. -Specificando -.I \-g 0 -i bytes di output non sono separati da alcuno spazio. -.RI < Bytes "> ha come valore predefinito " 2 -in modalità normale [esadecimale] e \fI1\fP in modalità binaria. -Il raggruppamento non si applica agli stili "PostScript" e "include". -.TP -.IR \-h " | " \-help -stampa un sommario dei comandi disponibili ed esce. Non viene fatto -null'altro. -.TP -.IR \-i " | " \-include -L'output è nello stile dei file "include" in C. Viene preparata la -definizione completa di un "array" [vettore], dandogli il nome del -file di input), tranne che nel caso in cui xxd legga dallo "standard input". -.TP -.IR "\-l lunghezza " | " \-len lunghezza" -Il programma esce dopo aver scritto -.RI < lunghezza > -bytes. -.TP -.IR \-p " | " \-ps " | " \-postscript " | " \-plain -L'output è nello stile di un dump continuo sotto postscript. -Noto anche come stile esadecimale semplice [plain]. -.TP -.IR \-r " | " \-revert -ricostruzione: converte (o mette una patch) a partire dall'immagine -esadecimale, creando [o modificando] il file binario. -Se non diretto allo "standard output", xxd scrive nel suo file di output -in maniera continua, senza interruzioni. Usare la combinazione -.I \-r \-p -per leggere dump in stile esadecimale semplice [plain], senza l'informazione -di numero di linea e senza un particolare tracciato di colonna. Degli spazi -o delle linee vuote possono essere inserite a piacere [e vengono ingorate]. -.TP -.I \-seek distanza -Usato con l'opzione -.IR \-r : -(ricostruzione), -.RI < distanza > -viene aggiunta alla posizione nel file trovata nella immagine -esadecimale. -.TP -.I \-s [+][\-]seek -Inizia a -.RI < seek > -bytes assoluti (o relativi) di distanza all'interno di input_file. -\fI+ \fRindica che il "seek" è relativo alla posizione corrente nel file -"standard input" (non significativa quando non si legge da "standard input"). -\fI\- \fRindica che il "seek" dovrebbe posizionarsi ad quel numero di -caratteri dalla fine dell'input (o se in combinazione con -\fI+ \fR: prime della posizione corrente nel file "standard input"). -Se non si specifica una opzione \-s option, xxd inizia alla posizione -corrente all'interno del file. -.TP -.I \-u -usa lettere esadecimali maiuscole. Il valore predefinito è di usare -lettere minuscole. -.TP -.IR \-v " | " \-version -visualizza la stringa contenente la versione del programma. -.SH ATTENZIONE -.PP -.I xxd \-r -è capace di operare "magie" nell'utilizzare l'informazione "numero di linea". -Se sul file di output ci si può posizionare usando la "seek", il numero di -linea all'inizio di ogni riga esadecimale può essere non ordinato, delle -linee possono mancare delle linee, oppure esserci delle sovrapposizioni. -In simili casi xxd userà lseek(2) per raggiungere la posizione d'inizio. -Se il file di output non consente di usare "seek", sono permessi solo dei -"buchi", che saranno riempiti con zeri binari. -.PP -.I xxd \-r -non genera mai errori di specifica parametri. I parametri non riconosciuti -sono silenziosamente ignorati. -.PP -Nel modificare immagini esadecimali, tenete conto che -.I xxd \-r -salta il resto della linea, dopo aver letto abbastanza caratteri contenenti -dati esadecimali (vedere opzione \-c). Ciò implica pure che le modifiche alle -colonne di caratteri stampabili ascii (o ebcdic) sono sempre ignorate. -La ricostruzione da un file immagine esadecimale in stile semplice -(postscript) con xxd \-r \-p non dipende dal numero corrretto di colonne. -IN questo caso, qualsiasi cosa assomigli a una coppia di cifre esadecimali -è interpretata [e utilizzata]. -.PP -Notare la differenza fra -.br -\fI% xxd \-i file\fR -.br -e -.br -\fI% xxd \-i \< file\fR -.PP -.I xxd \-s \+seek -può comportarsi in modo diverso da -.IR "xxd \-s seek" -, perché lseek(2) è usata per tornare indietro nel file di input. Il '+' -fa differenza se il file di input è lo "standard input", e se la pozione nel -file di "standard input" non è all'inizio del file quando xxd è eseguito, -con questo input. -I seguenti esempi possono contribuire a chiarire il concetto -(o ad oscurarlo!)... -.PP -Riavvolge lo "standard input" prima di leggere; necessario perché `cat' -ha già letto lo stesso file ["file"] fino alla fine dello "standard input". -.br -\fI% sh \-c 'cat > copia_normale; xxd \-s 0 > copia_esadecimale' < file -.PP -Stampa immagine esadecimale dalla posizione file 0x480 (=1024+128) in poi. -Il segno `+' vuol dire "rispetto alla posizione corrente", quindi il `128' -si aggiunge a 1k (1024) dove `dd' si era fermato. -.br -\fI% sh \-c 'dd of=normale bs=1k count=1; xxd \-s +128 > esadecimale' < file -.PP -Immagine esadecimale dalla posizione 0x100 ( = 1024\-768 ) del file in avanti. -.br -\fI% sh \-c 'dd of=normale bs=1k count=1; xxd \-s +-768 > esadecimale' < file -.PP -Comunque, questo capita raramente, e l'uso del `+' di rado. -L'autore preferisce monitorare il comportamento di xxd con strace(1) o -truss(1), quando si usa l'opzione \-s. -.SH ESEMPI -.PP -.br -Stampa tutto tranne le prime tre linee (0x30 bytes esadecimali) di -.B file -\. -.br -\fI% xxd \-s 0x30 file -.PP -.br -Stampa 3 linee (0x30 bytes esadecimali) alla fine di -.B file -\. -.br -\fI% xxd \-s \-0x30 file -.PP -.br -Stampa 120 bytes come immagine esadecimale continua con 20 bytes per linea. -.br -\fI% xxd \-l 120 \-ps \-c 20 xxd.1\fR - -.br -2e54482058584420312022417567757374203139 -.br -39362220224d616e75616c207061676520666f72 -.br -20787864220a2e5c220a2e5c222032317374204d -.br -617920313939360a2e5c22204d616e2070616765 -.br -20617574686f723a0a2e5c2220202020546f6e79 -.br -204e7567656e74203c746f6e79407363746e7567 -.br - -.br -Stampa i primi 120 bytes della pagina di manuale vim.1 a 12 bytes per linea. -.br -\fI% xxd \-l 120 \-c 12 xxd.1\fR - - -.br -0000000: 2e54 4820 5858 4420 3120 2241 .TH XXD 1 "A -.br -000000c: 7567 7573 7420 3139 3936 2220 ugust 1996" -.br -0000018: 224d 616e 7561 6c20 7061 6765 "Manual page -.br -0000024: 2066 6f72 2078 7864 220a 2e5c for xxd"..\ -.br -0000030: 220a 2e5c 2220 3231 7374 204d "..\" 21st M -.br -000003c: 6179 2031 3939 360a 2e5c 2220 ay 1996..\" -.br -0000048: 4d61 6e20 7061 6765 2061 7574 Man page aut -.br -0000054: 686f 723a 0a2e 5c22 2020 2020 hor:..\" -.br -0000060: 546f 6e79 204e 7567 656e 7420 Tony Nugent -.br -000006c: 3c74 6f6e 7940 7363 746e 7567 <tony@sctnug -.PP -.br -Visualizza la data dal file xxd.1 -.br -\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR -.br -0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 -.PP -.br -Copiare -.B input_file -su -.B output_file -premettendogli 100 bytes a 0x00. -.br -\fI% xxd input_file | xxd \-r \-s 100 \> output_file\fR -.br - -.br -Modificare (patch) la data nel file xxd.1 -.br -\fI% echo '0000037: 3574 68' | xxd \-r \- xxd.1\fR -.br -\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR -.br -0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 -.PP -.br -Creare un file di 65537 tutto a 0x00, -tranne che l'ultimo carattere che è una 'A' (esadecimale 0x41). -.br -\fI% echo '010000: 41' | xxd \-r \> file\fR -.PP -.br -Stampa una immagine esadecimale del file di cui sopra con opzione autoskip. -.br -\fI% xxd \-a \-c 12 file\fR -.br -0000000: 0000 0000 0000 0000 0000 0000 ............ -.br -* -.br -000fffc: 0000 0000 40 ....A -.PP -Crea un file di 1 byte che contiene il solo carattere 'A'. -Il numero dopo '\-r \-s' viene aggiunto a quello trovato nel file; -in pratica, i bytes precedenti non sono stampati. -.br -\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> file\fR -.PP -Usare xxd come filtro all'interno di un editor come -.B vim(1) -per ottenere una immagine esadecimale di una parte di file -delimitata dai mark `a' e `z'. -.br -\fI:'a,'z!xxd\fR -.PP -Usare xxd come filtro all'interno di un editor come -.B vim(1) -per ricostruire un pezzo di file binario da una immagine esadecimale -delimitata dai mark `a' e `z'. -.br -\fI:'a,'z!xxd \-r\fR -.PP -Usare xxd come filtro all'interno di un editor come -.B vim(1) -per ricostruire una sola linea di file binario da una immagine esadecimale, -Portare il cursore sopra la linea e battere: -.br -\fI!!xxd \-r\fR -.PP -Per leggere singoli charatteri da una linea seriale -.br -\fI% xxd \-c1 < /dev/term/b &\fR -.br -\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR -.br -\fI% echo \-n foo > /dev/term/b\fR -.PP -.SH CODICI DI RITORNO -Il programma può restituire questi codici di errore: -.TP -0 -nessun errore rilevato. -.TP -\-1 -operazione non supportata ( -.I xxd \-r \-i -non ancora possible). -.TP -1 -errore durante la scansione parametri. -.TP -2 -problemi con il file di input. -.TP -3 -problemi con il file di output. -.TP -4,5 -posizione "seek" specificata non raggiungibile all'interno del file. -.SH VEDERE ANCHE -uuencode(1), uudecode(1), patch(1) -.br -.SH AVVERTIMENTI -La stranezza dello strumento rispecchia la mente del suo creatore. -Usate a vostro rischio e pericolo. Copiate i file. Tracciate l'esecuzione. -Diventate un mago. -.br -.SH VERSIONE -Questa pagina di manuale documenta la versione 1.7 di xxd. -.SH AUTORE -.br -(c) 1990-1997 Juergen Weigert -.br -<jnweiger@informatik.uni-erlangen.de> -.LP -Distribuite liberamente ed attribuitemi il credito, -.br -fate soldi e condivideteli con me -.br -perdete soldi e non venite a chiederli a me. -.PP -Pagina di manuale messa in piedi da Tony Nugent -.br -<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.br -Piccole modifiche di Bram Moolenaar. -Modificato da Juergen Weigert. -.PP diff --git a/share/vim/vim72/doc/xxd-it.UTF-8.1 b/share/vim/vim72/doc/xxd-it.UTF-8.1 deleted file mode 100644 index 52114eb267..0000000000 --- a/share/vim/vim72/doc/xxd-it.UTF-8.1 +++ /dev/null @@ -1,402 +0,0 @@ -.TH XXD 1 "Agosto 1996" "Pagina di manuale per xxd" -.\" -.\" 21 Maggio 1996 -.\" Autore della pagina di manuale: -.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.\" Modificato da Bram Moolenaar <Bram@vim.org> -.SH NOME -.I xxd -\- Produce esadecimale da un file binario o viceversa. -.SH SINTASSI -.B xxd -\-h[elp] -.br -.B xxd -[opzioni] [input_file [output_file]] -.br -.B xxd -\-r[evert] [opzioni] [input_file [output_file]] -.SH DESCRIZIONE -.I xxd -crea un'immagine esadecimale di un dato file o dello "standard input". -Può anche ottenere da un'immagine esadecimale il file binario originale. -Come -.BR uuencode (1) -e -.BR uudecode (1) -permette di trasmettere dati binari in una rapresentazione ASCII "a prova -di email", ma ha anche il vantaggio di poter decodificare sullo "standard -output". Inoltre, può essere usato per effettuare delle modifiche (patch) -a file binari. -.SH OPZIONI -Se non si specifica un -.I input_file -il programma legge dallo "standard input". -Se -.I input_file -è specificato come il carattere -.RB \` \- ' -, l'input è letto dallo "standard input". -Se non si specifica un -.I output_file -(o si mette al suo posto il carattere -.RB \` \- ' -), i risultati sono inviati allo "standard output". -.PP -Si noti che la scansione dei caratteri è "pigra", e non controlla oltre -la prima lettera dell'opzione, a meno che l'opzione sia seguita da un -parametro. -Gli spazi fra una singola lettera di opzione e il corrispondente parametro -dopo di essa sono facoltativi. -I parametri delle opzioni possono essere specificati usando la notazione -decimale, esadecimale oppure ottale. -Pertanto -.BR \-c8 , -.BR "\-c 8" , -.B \-c 010 -e -.B \-cols 8 -sono notazioni equivalenti fra loro. -.PP -.TP -.IR \-a " | " \-autoskip -Richiesta di autoskip: Un singolo '*' rimpiazza linee di zeri binari. -Valore predefinito: off. -.TP -.IR \-b " | " \-bits -Richiesta di una immagine binaria (cifre binarie), invece che esadecimale. -Questa opzione scrive un byte come otto cifre "1" e "0" invece di usare i -numeri esadecimali. Ogni linea è preceduta da un indirizzo in esadecimale e -seguita da una decodifica ascii (o ebcdic). Le opzioni specificabili dalla -linea comando \-r, \-p, \-i non funzionano in questo modo. -.TP -.IR "\-c colonne " | " \-cols colonne" -.IR "\-c colonne " | " \-cols colonne" -In ogni linea sono formattate -.RI < colonne > -colonne. Valore predefinito 16 (\-i: 12, \-ps: 30, \-b: 6). -Valore massimo 256. -.TP -.IR \-E " | " \-EBCDIC -Cambia la codifica della colonna di destra da ASCII a EBCDIC. -Questo non modifica la rappresentazione esadecimale. Non ha senso -specificare questa opzione in combinazione con \-r, \-p o \-i. -.TP -.IR "\-g bytes " | " \-groupsize bytes" -Inserisci ogni -.RI < bytes > -bytes di output (di due caratteri esadecimali o otto numeri binari ognuno) -uno spazio bianco. -Specificando -.I \-g 0 -i bytes di output non sono separati da alcuno spazio. -.RI < Bytes "> ha come valore predefinito " 2 -in modalità normale [esadecimale] e \fI1\fP in modalità binaria. -Il raggruppamento non si applica agli stili "PostScript" e "include". -.TP -.IR \-h " | " \-help -stampa un sommario dei comandi disponibili ed esce. Non viene fatto -null'altro. -.TP -.IR \-i " | " \-include -L'output è nello stile dei file "include" in C. Viene preparata la -definizione completa di un "array" [vettore], dandogli il nome del -file di input), tranne che nel caso in cui xxd legga dallo "standard input". -.TP -.IR "\-l lunghezza " | " \-len lunghezza" -Il programma esce dopo aver scritto -.RI < lunghezza > -bytes. -.TP -.IR \-p " | " \-ps " | " \-postscript " | " \-plain -L'output è nello stile di un dump continuo sotto postscript. -Noto anche come stile esadecimale semplice [plain]. -.TP -.IR \-r " | " \-revert -ricostruzione: converte (o mette una patch) a partire dall'immagine -esadecimale, creando [o modificando] il file binario. -Se non diretto allo "standard output", xxd scrive nel suo file di output -in maniera continua, senza interruzioni. Usare la combinazione -.I \-r \-p -per leggere dump in stile esadecimale semplice [plain], senza l'informazione -di numero di linea e senza un particolare tracciato di colonna. Degli spazi -o delle linee vuote possono essere inserite a piacere [e vengono ingorate]. -.TP -.I \-seek distanza -Usato con l'opzione -.IR \-r : -(ricostruzione), -.RI < distanza > -viene aggiunta alla posizione nel file trovata nella immagine -esadecimale. -.TP -.I \-s [+][\-]seek -Inizia a -.RI < seek > -bytes assoluti (o relativi) di distanza all'interno di input_file. -\fI+ \fRindica che il "seek" è relativo alla posizione corrente nel file -"standard input" (non significativa quando non si legge da "standard input"). -\fI\- \fRindica che il "seek" dovrebbe posizionarsi ad quel numero di -caratteri dalla fine dell'input (o se in combinazione con -\fI+ \fR: prime della posizione corrente nel file "standard input"). -Se non si specifica una opzione \-s option, xxd inizia alla posizione -corrente all'interno del file. -.TP -.I \-u -usa lettere esadecimali maiuscole. Il valore predefinito è di usare -lettere minuscole. -.TP -.IR \-v " | " \-version -visualizza la stringa contenente la versione del programma. -.SH ATTENZIONE -.PP -.I xxd \-r -è capace di operare "magie" nell'utilizzare l'informazione "numero di linea". -Se sul file di output ci si può posizionare usando la "seek", il numero di -linea all'inizio di ogni riga esadecimale può essere non ordinato, delle -linee possono mancare delle linee, oppure esserci delle sovrapposizioni. -In simili casi xxd userà lseek(2) per raggiungere la posizione d'inizio. -Se il file di output non consente di usare "seek", sono permessi solo dei -"buchi", che saranno riempiti con zeri binari. -.PP -.I xxd \-r -non genera mai errori di specifica parametri. I parametri non riconosciuti -sono silenziosamente ignorati. -.PP -Nel modificare immagini esadecimali, tenete conto che -.I xxd \-r -salta il resto della linea, dopo aver letto abbastanza caratteri contenenti -dati esadecimali (vedere opzione \-c). Ciò implica pure che le modifiche alle -colonne di caratteri stampabili ascii (o ebcdic) sono sempre ignorate. -La ricostruzione da un file immagine esadecimale in stile semplice -(postscript) con xxd \-r \-p non dipende dal numero corrretto di colonne. -IN questo caso, qualsiasi cosa assomigli a una coppia di cifre esadecimali -è interpretata [e utilizzata]. -.PP -Notare la differenza fra -.br -\fI% xxd \-i file\fR -.br -e -.br -\fI% xxd \-i \< file\fR -.PP -.I xxd \-s \+seek -può comportarsi in modo diverso da -.IR "xxd \-s seek" -, perché lseek(2) è usata per tornare indietro nel file di input. Il '+' -fa differenza se il file di input è lo "standard input", e se la pozione nel -file di "standard input" non è all'inizio del file quando xxd è eseguito, -con questo input. -I seguenti esempi possono contribuire a chiarire il concetto -(o ad oscurarlo!)... -.PP -Riavvolge lo "standard input" prima di leggere; necessario perché `cat' -ha già letto lo stesso file ["file"] fino alla fine dello "standard input". -.br -\fI% sh \-c 'cat > copia_normale; xxd \-s 0 > copia_esadecimale' < file -.PP -Stampa immagine esadecimale dalla posizione file 0x480 (=1024+128) in poi. -Il segno `+' vuol dire "rispetto alla posizione corrente", quindi il `128' -si aggiunge a 1k (1024) dove `dd' si era fermato. -.br -\fI% sh \-c 'dd of=normale bs=1k count=1; xxd \-s +128 > esadecimale' < file -.PP -Immagine esadecimale dalla posizione 0x100 ( = 1024\-768 ) del file in avanti. -.br -\fI% sh \-c 'dd of=normale bs=1k count=1; xxd \-s +-768 > esadecimale' < file -.PP -Comunque, questo capita raramente, e l'uso del `+' di rado. -L'autore preferisce monitorare il comportamento di xxd con strace(1) o -truss(1), quando si usa l'opzione \-s. -.SH ESEMPI -.PP -.br -Stampa tutto tranne le prime tre linee (0x30 bytes esadecimali) di -.B file -\. -.br -\fI% xxd \-s 0x30 file -.PP -.br -Stampa 3 linee (0x30 bytes esadecimali) alla fine di -.B file -\. -.br -\fI% xxd \-s \-0x30 file -.PP -.br -Stampa 120 bytes come immagine esadecimale continua con 20 bytes per linea. -.br -\fI% xxd \-l 120 \-ps \-c 20 xxd.1\fR - -.br -2e54482058584420312022417567757374203139 -.br -39362220224d616e75616c207061676520666f72 -.br -20787864220a2e5c220a2e5c222032317374204d -.br -617920313939360a2e5c22204d616e2070616765 -.br -20617574686f723a0a2e5c2220202020546f6e79 -.br -204e7567656e74203c746f6e79407363746e7567 -.br - -.br -Stampa i primi 120 bytes della pagina di manuale vim.1 a 12 bytes per linea. -.br -\fI% xxd \-l 120 \-c 12 xxd.1\fR - - -.br -0000000: 2e54 4820 5858 4420 3120 2241 .TH XXD 1 "A -.br -000000c: 7567 7573 7420 3139 3936 2220 ugust 1996" -.br -0000018: 224d 616e 7561 6c20 7061 6765 "Manual page -.br -0000024: 2066 6f72 2078 7864 220a 2e5c for xxd"..\ -.br -0000030: 220a 2e5c 2220 3231 7374 204d "..\" 21st M -.br -000003c: 6179 2031 3939 360a 2e5c 2220 ay 1996..\" -.br -0000048: 4d61 6e20 7061 6765 2061 7574 Man page aut -.br -0000054: 686f 723a 0a2e 5c22 2020 2020 hor:..\" -.br -0000060: 546f 6e79 204e 7567 656e 7420 Tony Nugent -.br -000006c: 3c74 6f6e 7940 7363 746e 7567 <tony@sctnug -.PP -.br -Visualizza la data dal file xxd.1 -.br -\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR -.br -0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 -.PP -.br -Copiare -.B input_file -su -.B output_file -premettendogli 100 bytes a 0x00. -.br -\fI% xxd input_file | xxd \-r \-s 100 \> output_file\fR -.br - -.br -Modificare (patch) la data nel file xxd.1 -.br -\fI% echo '0000037: 3574 68' | xxd \-r \- xxd.1\fR -.br -\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR -.br -0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 -.PP -.br -Creare un file di 65537 tutto a 0x00, -tranne che l'ultimo carattere che è una 'A' (esadecimale 0x41). -.br -\fI% echo '010000: 41' | xxd \-r \> file\fR -.PP -.br -Stampa una immagine esadecimale del file di cui sopra con opzione autoskip. -.br -\fI% xxd \-a \-c 12 file\fR -.br -0000000: 0000 0000 0000 0000 0000 0000 ............ -.br -* -.br -000fffc: 0000 0000 40 ....A -.PP -Crea un file di 1 byte che contiene il solo carattere 'A'. -Il numero dopo '\-r \-s' viene aggiunto a quello trovato nel file; -in pratica, i bytes precedenti non sono stampati. -.br -\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> file\fR -.PP -Usare xxd come filtro all'interno di un editor come -.B vim(1) -per ottenere una immagine esadecimale di una parte di file -delimitata dai mark `a' e `z'. -.br -\fI:'a,'z!xxd\fR -.PP -Usare xxd come filtro all'interno di un editor come -.B vim(1) -per ricostruire un pezzo di file binario da una immagine esadecimale -delimitata dai mark `a' e `z'. -.br -\fI:'a,'z!xxd \-r\fR -.PP -Usare xxd come filtro all'interno di un editor come -.B vim(1) -per ricostruire una sola linea di file binario da una immagine esadecimale, -Portare il cursore sopra la linea e battere: -.br -\fI!!xxd \-r\fR -.PP -Per leggere singoli charatteri da una linea seriale -.br -\fI% xxd \-c1 < /dev/term/b &\fR -.br -\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR -.br -\fI% echo \-n foo > /dev/term/b\fR -.PP -.SH CODICI DI RITORNO -Il programma può restituire questi codici di errore: -.TP -0 -nessun errore rilevato. -.TP -\-1 -operazione non supportata ( -.I xxd \-r \-i -non ancora possible). -.TP -1 -errore durante la scansione parametri. -.TP -2 -problemi con il file di input. -.TP -3 -problemi con il file di output. -.TP -4,5 -posizione "seek" specificata non raggiungibile all'interno del file. -.SH VEDERE ANCHE -uuencode(1), uudecode(1), patch(1) -.br -.SH AVVERTIMENTI -La stranezza dello strumento rispecchia la mente del suo creatore. -Usate a vostro rischio e pericolo. Copiate i file. Tracciate l'esecuzione. -Diventate un mago. -.br -.SH VERSIONE -Questa pagina di manuale documenta la versione 1.7 di xxd. -.SH AUTORE -.br -(c) 1990-1997 Juergen Weigert -.br -<jnweiger@informatik.uni-erlangen.de> -.LP -Distribuite liberamente ed attribuitemi il credito, -.br -fate soldi e condivideteli con me -.br -perdete soldi e non venite a chiederli a me. -.PP -Pagina di manuale messa in piedi da Tony Nugent -.br -<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.br -Piccole modifiche di Bram Moolenaar. -Modificato da Juergen Weigert. -.PP diff --git a/share/vim/vim72/doc/xxd-pl.1 b/share/vim/vim72/doc/xxd-pl.1 deleted file mode 100644 index 00cbbffee3..0000000000 --- a/share/vim/vim72/doc/xxd-pl.1 +++ /dev/null @@ -1,389 +0,0 @@ -.TH XXD 1 "Sierpieñ 1996" "Strona podrêcznika dla xxd" -.\" -.\" 21st May 1996 -.\" Man page author: -.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.\" Changes by Bram Moolenaar <Bram@vim.org> -.SH NAZWA -.I xxd -\- zrzut pliku do hex lub odwrotnie -.SH SYNOPSIS -.B xxd -\-h[elp] -.br -.B xxd -[opcje] [plik_we [plik_wy]] -.br -.B xxd -\-r[evert] [opcje] [plik_we [plik_wy]] -.SH OPIS -.I xxd -tworzy zrzut heksowy podanego pliku na standardowe wyj¶cie. -Mo¿e tak¿e przetworzyæ zrzut heksowy z powrotem do oryginalnej, -binarnej formy. -Podobnie jak -.BR uuencode (1) -i -.BR uudecode (1) -pozwala na przekazanie danych binarnych w bezpiecznej w poczcie formie -ASCII, ale ma zalety dekodowania na standardowe wyj¶cie. -Ponadto mo¿na go u¿yæ do przeprowadzenia ³atania plików binarnych. -.SH OPCJE -Je¶li nie podano -.I plik_we -xxd czyta ze standardowego wej¶cie. -Je¶li okre¶lono -.I plik_wy -jako znak -.RB \` \- ' -wtedy dane wej¶ciowe czytane s± ze standardowego wej¶cia. -Je¶li nie podano -.I plik_wy -(lub podano jako -.RB \` \- ' -), wyniki s± wysy³ane na standardowe wyj¶cie. -.PP -Pamiêtaj, ¿e u¿yty zosta³ "leniwy" parser, który nie sprawdza wiêcej -ni¿ pierwszej litery opcji (o ile ta nie zosta³a obdarzona -parametrem). Spacje miêdzy jedno literowymi opcjami i ich parametrami -s± opcjonalne. Parametry opcji mog± byæ okre¶lone w notacji dziesiêtnej, -heksadecymalej lub oktalnej. -St±d -.BR \-c8 , -.BR "\-c 8" , -.B \-c 010 -i -.B \-cols 8 -s± sobie równowa¿ne. -.PP -.TP -.IR \-a " | " \-autoskip -prze³±cza autoskip: pojedyncza '*' zastêpuje linie nul. Domy¶lnie -wy³±czone. -.TP -.IR \-b " | " \-bits -Prze³±cza do zrzutu bitowego (cyfr binarnych) zamiast heksowego. -Opcja ta zapisuje oktety ajko osiem cyfr 1 lub 0 zamias normalnego -zrzutu heksowego. Ka¿da linia jest poprzedzona przez -heksadecymalny numer linii a za nim jego reprezentacja w ascii (lub -ebcdic). Opcje linii poleceñ \-r, \-p, \-i nie dzia³aj± w tym -trybie. -.TP -.IR "\-c cols " | " \-cols cols" -formatuje liczbê -.RI < cols > -oktetów na wiersz. Domy¶lnie 16 (\-i: 12, \-ps: 30, \-b: 6). Maks. -256. -.TP -.IR \-E " | "\-EBCDIC -zmienia kodowanie znaków w prawej kolumnie z ASCII na EBCDIC. -Nie zmienia prezentacji heksadecymalej. Opcja nie dzia³a w po³±czeniu -z \-r, \-p lub \-i. -.TP -.IR "\-g bajtów " | " \-groupsize bajtów" -oddziela wyj¶cie ka¿dych -.RI < bajtów > -bajtów (dwa heksowe znaki lub osiem cyfr binarnych ka¿de) przez bia³y -znak. -Okre¶l -.I \-g 0 -by wy³±czyæ grupowanie. -.RI < Bajtów "> domy¶lnie jest " 2 -w trybie normalnym i \fI1\fP w trybie bitów. -Grupowanie nie dzia³a w trybie postscriptu lub w³±czania. -.TP -.IR \-h " | " \-help -wypisuje podsumowanie dostêpnych poleceñ i koñczy dzia³anie. Nie -zostaje przeprowadzony ¿aden zrzut. -.TP -.IR \-i " | " \-include -wyj¶cie w stylu w³±czania pliku w C. Zostaje zapisana kompletna -statyczna tablica definicji (nazwana wed³ug pliku wej¶cia), o ile xxd -nie czyta ze standardowego wej¶cia. -.TP -.IR "\-l len " | "\-len len" -zakoñcz po wypisaniu -.RI < len> -oktetów. -.TP -.IR \-p " | " \-ps " | " \-postscript " | " \-plain -wyj¶cie w postcriptowym ci±g³ym stylu zrzutu heksowego. Znany tak¿e -jako zwyk³y zrzut heksowy. -.TP -.IR \-r " | " \-revert -odwróæ operacjê: przekonwertuj (lub za³ataj) zrzut heksowy w binarkê. -Je¶li nie zapisuje na standardowe wyj¶cie, xxd zapisze plik wyj¶ciowy -bez obcinania go. U¿yj kombinacji -.I \-r \-p -by odczytaæ zwyk³y zrzut heksadecymalny bez numerów linii -i okre¶lonego uk³adu kolumn. Dodatkowe bia³e znaki i ³amanie wierszy -s± dozwolone wszêdzie. -.TP -.I \-seek offset -Kiedy u¿yty po -.IR \-r : -odwraca z -.RI < offset > -dodanym do pozycji w pliku odnalezionym w zrzucie heksowym. -.TP -.I \-s [+][\-]seek -zaczyna na -.RI < seek > -bajtów abs. (lub wzg.) offsecie pliku wej¶ciowego. -\fI+ fRwskazuje, ¿e seek jest wzglêdne do bie¿±cej pozycji pliku (bez -znaczenia je¶li nie wczytuje ze standardowego wej¶cia). \fI\- \fRwskazuje -¿e seek powinno byæ o tyle znaków od koñca wej¶cia (lub je¶li -po³±czone z \fI+\fR: przezhd bie¿±c± pozycj± pliku na standardowym -wej¶ciu). -Bez opcji \-s xxd zaczyna od bie¿±cej pozycji w pliku. -.TP -.I \-u -u¿yj wielkich liter w znakach heksowych. Domy¶lnie s± ma³e znaki. -.TP -.IR \-v " | " \-version -pokazuje wersjê programu. -.SH OSTRZE¯ENIA -.PP -.I xxd \-r -potrafi okre¶liæ numery linii. Je¶li plik wyj¶cia jest mo¿liwy do -przeszukania wtedy numery linii na pocz±tku wiersza zrzutu heksowego -mog± byæ nie po kolei, mo¿e brakowaæ wierszy lub nak³adaæ siê na -siebie. W takich wypadkach xxd u¿yje lseek(2) by znale¼æ nastêpn± -pozycjê. Je¶li plik wyj¶ciowy nie jest mo¿liwy do przeszukania mo¿liwe -s± tylko przerwy, które zostan± wype³nione bajtami null. -.PP -.I xxd \-r -nigdy nie podaje b³êdów analizy. ¦mieci s± ignorowane. -.PP -W czasie edycji zrzutów heksowych, proszê zauwa¿yæ ¿e -.I xxd \-r -pomija wszystko w linii wej¶cia po odczytaniu wystarczaj±cej ilo¶ci -kolumn danych heksadecymalnych (zobacz opcjê \-c). Oznacza to tak¿e, -¿e zmiany w drukowanych kolumnach ascii (lub ebcdic) s± zawsze -ignorowane. Odwrócenie zwyk³ego (lub postscriptowego) stylu zrzutu -poprzez xxd \-r \-p nie zale¿y od kolejno¶ci kolumn. Tutaj cokolwiej -co wygl±da jak para cyfr heks jest interpretowane. -.PP -Zauwa¿ ró¿nicê miêdzy -.br -\fI% xxd \-i plik\fR -.br -i -.br -\fI% xxd \-i < plik\fR -.PP -.I xxd \-s \+seek -mo¿e byæ ró¿ne od -.IR "xxd \-s seek" , -poniewa¿ lseek(2) jest u¿yty do "przewiniêcie" wej¶cia. '+' robi -ró¿nicê je¶li ¼ród³em wej¶cia jest standardowe wej¶cie i je¶li pozycja -w pliku ze standardowego wej¶cia nie jest pocz±tkiem pliku w chwili -uruchomienia xxd. Nastêpuj±ce przyk³ady mog± wyja¶niæ (lub bardziej -zmyliæ!)... -.PP -Przewiñ standardowe wej¶cie przed przeczytaniem; potrzebne poniewa¿ -`cat' ju¿ odczyta³ do koñca standardowego wej¶cia. -.br -\fI% sh \-c 'cat > zwyk³a_kopia; xxd \-s 0 > hex_kopia' < plik -.PP -Zrzut heksowy od pozycji pliku 0x480 (=1024+128) w przód. -Znak `+' oznacza "wzglêdny wobec bie¿±cej pozycji", st±d `128' dodaje -do 1k gdzie zakoñczy³ dd. -.br -\fI% sh \-c 'dd of=plain_snippet bs=1k count=1; xxd \-s +128 > hex_snippet' < file -.PP -Zrzut heksowy od pozycji pliku 0x100 ( = 1024\-768) dalej. -.br -\fI% sh \-c 'dd of=plain_snippet bs=1k count=1; xxd \-s +-768 > hex_snippet' < file -.PP -Jakkolwiek, jest to rzadka sytuacja i u¿ycie `+' jest rzadko -potrzebne. -Autor woli monitorowaæ dzia³anie xxd przy pomocy strace(1) lub truss(1) kiedy \-s jest u¿yte. -.SH PRZYK£ADY -.PP -.br -Wypisz wszystko z wyj±tkiem pierwszych trzech linii (heksowe 0x30 bajtów) -.B pliku -\. -.br -\fI% xxd \-s 0x30 plik -.PP -.br -Wypisz trzy linie (heksowe 0x30 bajtów) z koñca -.B pliku -\. -.br -\fI% xxd \-s \-0x30 plik -.PP -.br -Wypisz 120 bajtów jako ci±g³y zrzut heksowy z 20 oktetami na liniê. -.br -\fI% xxd \-l 120 \-ps \-c 20 xxd.1\fR -.br -2e54482058584420312022417567757374203139 -.br -39362220224d616e75616c207061676520666f72 -.br -20787864220a2e5c220a2e5c222032317374204d -.br -617920313939360a2e5c22204d616e2070616765 -.br -20617574686f723a0a2e5c2220202020546f6e79 -.br -204e7567656e74203c746f6e79407363746e7567 -.br - -.br -Zrzut heksowy z pierwszymi 120 bajtami tej strony podrêcznika z 12 -oktetami na liniê. -.br -\fI% xxd \-l 120 \-c 12 xxd.1\fR -.br -0000000: 2e54 4820 5858 4420 3120 2241 .TH XXD 1 "A -.br -000000c: 7567 7573 7420 3139 3936 2220 ugust 1996" -.br -0000018: 224d 616e 7561 6c20 7061 6765 "Manual page -.br -0000024: 2066 6f72 2078 7864 220a 2e5c for xxd"..\\ -.br -0000030: 220a 2e5c 2220 3231 7374 204d "..\\" 21st M -.br -000003c: 6179 2031 3939 360a 2e5c 2220 ay 1996..\\" -.br -0000048: 4d61 6e20 7061 6765 2061 7574 Man page aut -.br -0000054: 686f 723a 0a2e 5c22 2020 2020 hor:..\\" -.br -0000060: 546f 6e79 204e 7567 656e 7420 Tony Nugent -.br -000006c: 3c74 6f6e 7940 7363 746e 7567 <tony@sctnug -.PP -.br -Poka¿ tylko datê z pliku xxd.1 -.br -\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR -.br -0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 -.PP -.br -Kopiuj -.B plik_we -do -.B plik_wy -i poprzed¼ 100 bajtami o warto¶ci 0x00. -.br -\fI% xxd plik_we | xxd \-r \-s 100 \> plik_wy\fR -.br - -.br -Podmieñ datê w pliku xxd.1 -.br -\fI% echo '0000037: 3574 68' | xxd \-r \- xxd.1\fR -.br -\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR -.br -0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 -.PP -.br -Utwórz plik o 65537 bajtach, wszystkich równych 0x00, -z wyj±tkiem ostatniego, który ma byæ 'A' (hex 0x41). -.br -\fI% echo '010000: 41' | xxd \-r \> plik\fR -.PP -.br -Zrzut heksowy tego pliku z autoskipem. -.br -\fI% xxd \-a \-c 12 plik\fR -.br -0000000: 0000 0000 0000 0000 0000 0000 ............ -.br -* -.br -000fffc: 0000 0000 40 ....A -.PP -Utwórz jedno bajtowy plik zawieraj±cy pojedncz± literê 'A'. -Liczba po '\-r \-s' dodaje numery linii znalezione w pliku; -w efekcie poprzedzaj±ce bajty s± ukryte. -.br -\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> plik\fR -.PP -U¿yj xxd jako filtra wewn±trz edytora takiego jak -.B vim(1) -aby uzyskaæ zrzut heksowy zakresu miêdzy markerami `a' i `z'. -.br -\fI:'a,'z!xxd\fR -.PP -U¿yj xxd jako filtra wewn±trz edytora takiego jak -.B vim(1) -by odzyskaæ binarny zrzut heksowy zakresu pomiêdzy markerami `a' -i `z'. -.br -\fI:'a,'z!xxd \-r\fR -.PP -U¿yj xxd jako filtra wewn±trz edytora takiego jak -.B vim(1) -by odzyskaæ jedn± liniê zrzutu heksowego. Przejd¼ z kursorem na liniê -i wpisz: -.br -\fI!!xxd \-r\fR -.PP -Odczytaj pojednycze znaki z portu szeregowego -.br -\fI% xxd \-c1 < /dev/term/b &\fR -.br -\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR -.br -\fI% echo \-n foo > /dev/term/b\fR -.PP -.SH "ZWRACANE WARTO¦CI" -Zwracane s± nastêpuj±ce warto¶ci b³êdów: -.TP -0 -nie znaleziono b³êdów. -.TP -\-1 -operacja nie jest wspierana ( -.I xxd \-r \-i -ca³y czas niemo¿liwa). -.TP -1 -b³±d w czasie analizowania opcji. -.TP -2 -problemy z plikiem wej¶ciowym. -.TP -3 -problemy z plikiem wyj¶ciowym. -.TP -4,5 -¿±dana pozycja jest nieosi±galna. -.SH "ZOBACZ TAK¯E" -uuencode(1), uudecode(1), patch(1) -.br -.SH OSTRZE¯ENIA -Dziwaczno¶æ narzêdzi dorównuje dziwaczno¶ci mózgu twórcy. -U¿ywaj wy³±cznie na w³asn± odpowiedzialno¶æ. Kopiuj pliki. Analizuj -je. Stañ siê czarodziejem. -.br -.SH WERSJA -Strona podrêcznika opisuje xxd w wersji 1.7 -.SH AUTOR -.br -(c) 1990-1997 by Juergen Weigert -.br -<jnweiger@informatik.uni-erlangen.de> -.LP -Kopiuj do woli i podaj moje dane, -.br -zarabiaj pieni±dze i dziel siê ze mn±, -.br -traæ pieni±dze i nie miej do mnie pretensji. -.PP -Strona podrêcznika zapocz±tkowana przez Tony'ego Nugenta -.br -<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.br -Ma³e zmiany: Bram Moolenaar. -Redakcja: Juergen Weigert. -.PP diff --git a/share/vim/vim72/doc/xxd-pl.UTF-8.1 b/share/vim/vim72/doc/xxd-pl.UTF-8.1 deleted file mode 100644 index 669ffc2ea9..0000000000 --- a/share/vim/vim72/doc/xxd-pl.UTF-8.1 +++ /dev/null @@ -1,389 +0,0 @@ -.TH XXD 1 "Sierpień 1996" "Strona podręcznika dla xxd" -.\" -.\" 21st May 1996 -.\" Man page author: -.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.\" Changes by Bram Moolenaar <Bram@vim.org> -.SH NAZWA -.I xxd -\- zrzut pliku do hex lub odwrotnie -.SH SYNOPSIS -.B xxd -\-h[elp] -.br -.B xxd -[opcje] [plik_we [plik_wy]] -.br -.B xxd -\-r[evert] [opcje] [plik_we [plik_wy]] -.SH OPIS -.I xxd -tworzy zrzut heksowy podanego pliku na standardowe wyjście. -Może także przetworzyć zrzut heksowy z powrotem do oryginalnej, -binarnej formy. -Podobnie jak -.BR uuencode (1) -i -.BR uudecode (1) -pozwala na przekazanie danych binarnych w bezpiecznej w poczcie formie -ASCII, ale ma zalety dekodowania na standardowe wyjście. -Ponadto można go użyć do przeprowadzenia łatania plików binarnych. -.SH OPCJE -Jeśli nie podano -.I plik_we -xxd czyta ze standardowego wejście. -Jeśli określono -.I plik_wy -jako znak -.RB \` \- ' -wtedy dane wejściowe czytane są ze standardowego wejścia. -Jeśli nie podano -.I plik_wy -(lub podano jako -.RB \` \- ' -), wyniki są wysyłane na standardowe wyjście. -.PP -Pamiętaj, że użyty został "leniwy" parser, który nie sprawdza więcej -niż pierwszej litery opcji (o ile ta nie została obdarzona -parametrem). Spacje między jedno literowymi opcjami i ich parametrami -są opcjonalne. Parametry opcji mogą być określone w notacji dziesiętnej, -heksadecymalej lub oktalnej. -Stąd -.BR \-c8 , -.BR "\-c 8" , -.B \-c 010 -i -.B \-cols 8 -są sobie równoważne. -.PP -.TP -.IR \-a " | " \-autoskip -przełącza autoskip: pojedyncza '*' zastępuje linie nul. Domyślnie -wyłączone. -.TP -.IR \-b " | " \-bits -Przełącza do zrzutu bitowego (cyfr binarnych) zamiast heksowego. -Opcja ta zapisuje oktety ajko osiem cyfr 1 lub 0 zamias normalnego -zrzutu heksowego. Każda linia jest poprzedzona przez -heksadecymalny numer linii a za nim jego reprezentacja w ascii (lub -ebcdic). Opcje linii poleceń \-r, \-p, \-i nie działają w tym -trybie. -.TP -.IR "\-c cols " | " \-cols cols" -formatuje liczbę -.RI < cols > -oktetów na wiersz. Domyślnie 16 (\-i: 12, \-ps: 30, \-b: 6). Maks. -256. -.TP -.IR \-E " | "\-EBCDIC -zmienia kodowanie znaków w prawej kolumnie z ASCII na EBCDIC. -Nie zmienia prezentacji heksadecymalej. Opcja nie działa w połączeniu -z \-r, \-p lub \-i. -.TP -.IR "\-g bajtów " | " \-groupsize bajtów" -oddziela wyjście każdych -.RI < bajtów > -bajtów (dwa heksowe znaki lub osiem cyfr binarnych każde) przez biały -znak. -Określ -.I \-g 0 -by wyłączyć grupowanie. -.RI < Bajtów "> domyślnie jest " 2 -w trybie normalnym i \fI1\fP w trybie bitów. -Grupowanie nie działa w trybie postscriptu lub włączania. -.TP -.IR \-h " | " \-help -wypisuje podsumowanie dostępnych poleceń i kończy działanie. Nie -zostaje przeprowadzony żaden zrzut. -.TP -.IR \-i " | " \-include -wyjście w stylu włączania pliku w C. Zostaje zapisana kompletna -statyczna tablica definicji (nazwana według pliku wejścia), o ile xxd -nie czyta ze standardowego wejścia. -.TP -.IR "\-l len " | "\-len len" -zakończ po wypisaniu -.RI < len> -oktetów. -.TP -.IR \-p " | " \-ps " | " \-postscript " | " \-plain -wyjście w postcriptowym ciągłym stylu zrzutu heksowego. Znany także -jako zwykły zrzut heksowy. -.TP -.IR \-r " | " \-revert -odwróć operację: przekonwertuj (lub załataj) zrzut heksowy w binarkę. -Jeśli nie zapisuje na standardowe wyjście, xxd zapisze plik wyjściowy -bez obcinania go. Użyj kombinacji -.I \-r \-p -by odczytać zwykły zrzut heksadecymalny bez numerów linii -i określonego układu kolumn. Dodatkowe białe znaki i łamanie wierszy -są dozwolone wszędzie. -.TP -.I \-seek offset -Kiedy użyty po -.IR \-r : -odwraca z -.RI < offset > -dodanym do pozycji w pliku odnalezionym w zrzucie heksowym. -.TP -.I \-s [+][\-]seek -zaczyna na -.RI < seek > -bajtów abs. (lub wzg.) offsecie pliku wejściowego. -\fI+ fRwskazuje, że seek jest względne do bieżącej pozycji pliku (bez -znaczenia jeśli nie wczytuje ze standardowego wejścia). \fI\- \fRwskazuje -że seek powinno być o tyle znaków od końca wejścia (lub jeśli -połączone z \fI+\fR: przezhd bieżącą pozycją pliku na standardowym -wejściu). -Bez opcji \-s xxd zaczyna od bieżącej pozycji w pliku. -.TP -.I \-u -użyj wielkich liter w znakach heksowych. Domyślnie są małe znaki. -.TP -.IR \-v " | " \-version -pokazuje wersję programu. -.SH OSTRZEŻENIA -.PP -.I xxd \-r -potrafi określić numery linii. Jeśli plik wyjścia jest możliwy do -przeszukania wtedy numery linii na początku wiersza zrzutu heksowego -mogą być nie po kolei, może brakować wierszy lub nakładać się na -siebie. W takich wypadkach xxd użyje lseek(2) by znaleźć następną -pozycję. Jeśli plik wyjściowy nie jest możliwy do przeszukania możliwe -są tylko przerwy, które zostaną wypełnione bajtami null. -.PP -.I xxd \-r -nigdy nie podaje błędów analizy. Śmieci są ignorowane. -.PP -W czasie edycji zrzutów heksowych, proszę zauważyć że -.I xxd \-r -pomija wszystko w linii wejścia po odczytaniu wystarczającej ilości -kolumn danych heksadecymalnych (zobacz opcję \-c). Oznacza to także, -że zmiany w drukowanych kolumnach ascii (lub ebcdic) są zawsze -ignorowane. Odwrócenie zwykłego (lub postscriptowego) stylu zrzutu -poprzez xxd \-r \-p nie zależy od kolejności kolumn. Tutaj cokolwiej -co wygląda jak para cyfr heks jest interpretowane. -.PP -Zauważ różnicę między -.br -\fI% xxd \-i plik\fR -.br -i -.br -\fI% xxd \-i < plik\fR -.PP -.I xxd \-s \+seek -może być różne od -.IR "xxd \-s seek" , -ponieważ lseek(2) jest użyty do "przewinięcie" wejścia. '+' robi -różnicę jeśli źródłem wejścia jest standardowe wejście i jeśli pozycja -w pliku ze standardowego wejścia nie jest początkiem pliku w chwili -uruchomienia xxd. Następujące przykłady mogą wyjaśnić (lub bardziej -zmylić!)... -.PP -Przewiń standardowe wejście przed przeczytaniem; potrzebne ponieważ -`cat' już odczytał do końca standardowego wejścia. -.br -\fI% sh \-c 'cat > zwykła_kopia; xxd \-s 0 > hex_kopia' < plik -.PP -Zrzut heksowy od pozycji pliku 0x480 (=1024+128) w przód. -Znak `+' oznacza "względny wobec bieżącej pozycji", stąd `128' dodaje -do 1k gdzie zakończył dd. -.br -\fI% sh \-c 'dd of=plain_snippet bs=1k count=1; xxd \-s +128 > hex_snippet' < file -.PP -Zrzut heksowy od pozycji pliku 0x100 ( = 1024\-768) dalej. -.br -\fI% sh \-c 'dd of=plain_snippet bs=1k count=1; xxd \-s +-768 > hex_snippet' < file -.PP -Jakkolwiek, jest to rzadka sytuacja i użycie `+' jest rzadko -potrzebne. -Autor woli monitorować działanie xxd przy pomocy strace(1) lub truss(1) kiedy \-s jest użyte. -.SH PRZYKŁADY -.PP -.br -Wypisz wszystko z wyjątkiem pierwszych trzech linii (heksowe 0x30 bajtów) -.B pliku -\. -.br -\fI% xxd \-s 0x30 plik -.PP -.br -Wypisz trzy linie (heksowe 0x30 bajtów) z końca -.B pliku -\. -.br -\fI% xxd \-s \-0x30 plik -.PP -.br -Wypisz 120 bajtów jako ciągły zrzut heksowy z 20 oktetami na linię. -.br -\fI% xxd \-l 120 \-ps \-c 20 xxd.1\fR -.br -2e54482058584420312022417567757374203139 -.br -39362220224d616e75616c207061676520666f72 -.br -20787864220a2e5c220a2e5c222032317374204d -.br -617920313939360a2e5c22204d616e2070616765 -.br -20617574686f723a0a2e5c2220202020546f6e79 -.br -204e7567656e74203c746f6e79407363746e7567 -.br - -.br -Zrzut heksowy z pierwszymi 120 bajtami tej strony podręcznika z 12 -oktetami na linię. -.br -\fI% xxd \-l 120 \-c 12 xxd.1\fR -.br -0000000: 2e54 4820 5858 4420 3120 2241 .TH XXD 1 "A -.br -000000c: 7567 7573 7420 3139 3936 2220 ugust 1996" -.br -0000018: 224d 616e 7561 6c20 7061 6765 "Manual page -.br -0000024: 2066 6f72 2078 7864 220a 2e5c for xxd"..\\ -.br -0000030: 220a 2e5c 2220 3231 7374 204d "..\\" 21st M -.br -000003c: 6179 2031 3939 360a 2e5c 2220 ay 1996..\\" -.br -0000048: 4d61 6e20 7061 6765 2061 7574 Man page aut -.br -0000054: 686f 723a 0a2e 5c22 2020 2020 hor:..\\" -.br -0000060: 546f 6e79 204e 7567 656e 7420 Tony Nugent -.br -000006c: 3c74 6f6e 7940 7363 746e 7567 <tony@sctnug -.PP -.br -Pokaż tylko datę z pliku xxd.1 -.br -\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR -.br -0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 -.PP -.br -Kopiuj -.B plik_we -do -.B plik_wy -i poprzedź 100 bajtami o wartości 0x00. -.br -\fI% xxd plik_we | xxd \-r \-s 100 \> plik_wy\fR -.br - -.br -Podmień datę w pliku xxd.1 -.br -\fI% echo '0000037: 3574 68' | xxd \-r \- xxd.1\fR -.br -\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR -.br -0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 -.PP -.br -Utwórz plik o 65537 bajtach, wszystkich równych 0x00, -z wyjątkiem ostatniego, który ma być 'A' (hex 0x41). -.br -\fI% echo '010000: 41' | xxd \-r \> plik\fR -.PP -.br -Zrzut heksowy tego pliku z autoskipem. -.br -\fI% xxd \-a \-c 12 plik\fR -.br -0000000: 0000 0000 0000 0000 0000 0000 ............ -.br -* -.br -000fffc: 0000 0000 40 ....A -.PP -Utwórz jedno bajtowy plik zawierający pojednczą literę 'A'. -Liczba po '\-r \-s' dodaje numery linii znalezione w pliku; -w efekcie poprzedzające bajty są ukryte. -.br -\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> plik\fR -.PP -Użyj xxd jako filtra wewnątrz edytora takiego jak -.B vim(1) -aby uzyskać zrzut heksowy zakresu między markerami `a' i `z'. -.br -\fI:'a,'z!xxd\fR -.PP -Użyj xxd jako filtra wewnątrz edytora takiego jak -.B vim(1) -by odzyskać binarny zrzut heksowy zakresu pomiędzy markerami `a' -i `z'. -.br -\fI:'a,'z!xxd \-r\fR -.PP -Użyj xxd jako filtra wewnątrz edytora takiego jak -.B vim(1) -by odzyskać jedną linię zrzutu heksowego. Przejdź z kursorem na linię -i wpisz: -.br -\fI!!xxd \-r\fR -.PP -Odczytaj pojednycze znaki z portu szeregowego -.br -\fI% xxd \-c1 < /dev/term/b &\fR -.br -\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR -.br -\fI% echo \-n foo > /dev/term/b\fR -.PP -.SH "ZWRACANE WARTOŚCI" -Zwracane są następujące wartości błędów: -.TP -0 -nie znaleziono błędów. -.TP -\-1 -operacja nie jest wspierana ( -.I xxd \-r \-i -cały czas niemożliwa). -.TP -1 -błąd w czasie analizowania opcji. -.TP -2 -problemy z plikiem wejściowym. -.TP -3 -problemy z plikiem wyjściowym. -.TP -4,5 -żądana pozycja jest nieosiągalna. -.SH "ZOBACZ TAKŻE" -uuencode(1), uudecode(1), patch(1) -.br -.SH OSTRZEŻENIA -Dziwaczność narzędzi dorównuje dziwaczności mózgu twórcy. -Używaj wyłącznie na własną odpowiedzialność. Kopiuj pliki. Analizuj -je. Stań się czarodziejem. -.br -.SH WERSJA -Strona podręcznika opisuje xxd w wersji 1.7 -.SH AUTOR -.br -(c) 1990-1997 by Juergen Weigert -.br -<jnweiger@informatik.uni-erlangen.de> -.LP -Kopiuj do woli i podaj moje dane, -.br -zarabiaj pieniądze i dziel się ze mną, -.br -trać pieniądze i nie miej do mnie pretensji. -.PP -Strona podręcznika zapoczątkowana przez Tony'ego Nugenta -.br -<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> -.br -Małe zmiany: Bram Moolenaar. -Redakcja: Juergen Weigert. -.PP diff --git a/share/vim/vim72/evim.vim b/share/vim/vim72/evim.vim deleted file mode 100644 index 754729048e..0000000000 --- a/share/vim/vim72/evim.vim +++ /dev/null @@ -1,66 +0,0 @@ -" Vim script for Evim key bindings -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2006 Mar 29 - -" Don't use Vi-compatible mode. -set nocompatible - -" Use the mswin.vim script for most mappings -source <sfile>:p:h/mswin.vim - -" Vim is in Insert mode by default -set insertmode - -" Make a buffer hidden when editing another one -set hidden - -" Make cursor keys ignore wrapping -inoremap <Down> <C-R>=pumvisible() ? "\<lt>Down>" : "\<lt>C-O>gj"<CR> -inoremap <Up> <C-R>=pumvisible() ? "\<lt>Up>" : "\<lt>C-O>gk"<CR> - -" CTRL-F does Find dialog instead of page forward -noremap <C-F> :promptfind<CR> -vnoremap <C-F> y:promptfind <C-R>"<CR> -onoremap <C-F> <C-C>:promptfind<CR> -inoremap <C-F> <C-O>:promptfind<CR> -cnoremap <C-F> <C-C>:promptfind<CR> - - -set backspace=2 " allow backspacing over everything in insert mode -set autoindent " always set autoindenting on -if has("vms") - set nobackup " do not keep a backup file, use versions instead -else - set backup " keep a backup file -endif -set history=50 " keep 50 lines of command line history -set ruler " show the cursor position all the time -set incsearch " do incremental searching -set mouse=a " always use the mouse - -" Don't use Ex mode, use Q for formatting -map Q gq - -" Switch syntax highlighting on, when the terminal has colors -" Highlight the last used search pattern on the next search command. -if &t_Co > 2 || has("gui_running") - syntax on - set hlsearch - nohlsearch -endif - -" Only do this part when compiled with support for autocommands. -if has("autocmd") - - " Enable file type detection. - " Use the default filetype settings, so that mail gets 'tw' set to 72, - " 'cindent' is on in C files, etc. - " Also load indent files, to automatically do language-dependent indenting. - filetype plugin indent on - - " For all text files set 'textwidth' to 78 characters. - au FileType text setlocal tw=78 - -endif " has("autocmd") - -" vim: set sw=2 : diff --git a/share/vim/vim72/filetype.vim b/share/vim/vim72/filetype.vim deleted file mode 100644 index a8e6261e91..0000000000 --- a/share/vim/vim72/filetype.vim +++ /dev/null @@ -1,2442 +0,0 @@ -" Vim support file to detect file types -" -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2008 Aug 03 - -" Listen very carefully, I will say this only once -if exists("did_load_filetypes") - finish -endif -let did_load_filetypes = 1 - -" Line continuation is used here, remove 'C' from 'cpoptions' -let s:cpo_save = &cpo -set cpo&vim - -augroup filetypedetect - -" Ignored extensions -if exists("*fnameescape") -au BufNewFile,BufRead ?\+.orig,?\+.bak,?\+.old,?\+.new,?\+.dpkg-dist,?\+.dpkg-old,?\+.rpmsave,?\+.rpmnew - \ exe "doau filetypedetect BufRead " . fnameescape(expand("<afile>:r")) -au BufNewFile,BufRead *~ - \ let s:name = expand("<afile>") | - \ let s:short = substitute(s:name, '\~$', '', '') | - \ if s:name != s:short && s:short != "" | - \ exe "doau filetypedetect BufRead " . fnameescape(s:short) | - \ endif | - \ unlet! s:name s:short -au BufNewFile,BufRead ?\+.in - \ if expand("<afile>:t") != "configure.in" | - \ exe "doau filetypedetect BufRead " . fnameescape(expand("<afile>:r")) | - \ endif -elseif &verbose > 0 - echomsg "Warning: some filetypes will not be recognized because this version of Vim does not have fnameescape()" -endif - -" Pattern used to match file names which should not be inspected. -" Currently finds compressed files. -if !exists("g:ft_ignore_pat") - let g:ft_ignore_pat = '\.\(Z\|gz\|bz2\|zip\|tgz\)$' -endif - -" Function used for patterns that end in a star: don't set the filetype if the -" file name matches ft_ignore_pat. -func! s:StarSetf(ft) - if expand("<amatch>") !~ g:ft_ignore_pat - exe 'setf ' . a:ft - endif -endfunc - -" Abaqus or Trasys -au BufNewFile,BufRead *.inp call s:Check_inp() - -func! s:Check_inp() - if getline(1) =~ '^\*' - setf abaqus - else - let n = 1 - if line("$") > 500 - let nmax = 500 - else - let nmax = line("$") - endif - while n <= nmax - if getline(n) =~? "^header surface data" - setf trasys - break - endif - let n = n + 1 - endwhile - endif -endfunc - -" A-A-P recipe -au BufNewFile,BufRead *.aap setf aap - -" A2ps printing utility -au BufNewFile,BufRead etc/a2ps.cfg,etc/a2ps/*.cfg,a2psrc,.a2psrc setf a2ps - -" ABAB/4 -au BufNewFile,BufRead *.abap setf abap - -" ABC music notation -au BufNewFile,BufRead *.abc setf abc - -" ABEL -au BufNewFile,BufRead *.abl setf abel - -" AceDB -au BufNewFile,BufRead *.wrm setf acedb - -" Ada (83, 9X, 95) -au BufNewFile,BufRead *.adb,*.ads,*.ada setf ada -if has("vms") - au BufNewFile,BufRead *.gpr,*.ada_m,*.adc setf ada -else - au BufNewFile,BufRead *.gpr setf ada -endif - -" AHDL -au BufNewFile,BufRead *.tdf setf ahdl - -" AMPL -au BufNewFile,BufRead *.run setf ampl - -" Ant -au BufNewFile,BufRead build.xml setf ant - -" Apache style config file -au BufNewFile,BufRead proftpd.conf* call s:StarSetf('apachestyle') - -" Apache config file -au BufNewFile,BufRead .htaccess setf apache -au BufNewFile,BufRead httpd.conf*,srm.conf*,access.conf*,apache.conf*,apache2.conf*,/etc/apache2/*.conf* call s:StarSetf('apache') - -" XA65 MOS6510 cross assembler -au BufNewFile,BufRead *.a65 setf a65 - -" Applix ELF -au BufNewFile,BufRead *.am - \ if expand("<afile>") !~? 'Makefile.am\>' | setf elf | endif - -" ALSA configuration -au BufNewFile,BufRead ~/.asoundrc,/usr/share/alsa/alsa.conf,/etc/asound.conf setf alsaconf - -" Arc Macro Language -au BufNewFile,BufRead *.aml setf aml - -" Arch Inventory file -au BufNewFile,BufRead .arch-inventory,=tagging-method setf arch - -" ART*Enterprise (formerly ART-IM) -au BufNewFile,BufRead *.art setf art - -" ASN.1 -au BufNewFile,BufRead *.asn,*.asn1 setf asn - -" Active Server Pages (with Visual Basic Script) -au BufNewFile,BufRead *.asa - \ if exists("g:filetype_asa") | - \ exe "setf " . g:filetype_asa | - \ else | - \ setf aspvbs | - \ endif - -" Active Server Pages (with Perl or Visual Basic Script) -au BufNewFile,BufRead *.asp - \ if exists("g:filetype_asp") | - \ exe "setf " . g:filetype_asp | - \ elseif getline(1) . getline(2) . getline(3) =~? "perlscript" | - \ setf aspperl | - \ else | - \ setf aspvbs | - \ endif - -" Grub (must be before catch *.lst) -au BufNewFile,BufRead /boot/grub/menu.lst,/boot/grub/grub.conf,/etc/grub.conf setf grub - -" Assembly (all kinds) -" *.lst is not pure assembly, it has two extra columns (address, byte codes) -au BufNewFile,BufRead *.asm,*.[sS],*.[aA],*.mac,*.lst call s:FTasm() - -" This function checks for the kind of assembly that is wanted by the user, or -" can be detected from the first five lines of the file. -func! s:FTasm() - " make sure b:asmsyntax exists - if !exists("b:asmsyntax") - let b:asmsyntax = "" - endif - - if b:asmsyntax == "" - call s:FTasmsyntax() - endif - - " if b:asmsyntax still isn't set, default to asmsyntax or GNU - if b:asmsyntax == "" - if exists("g:asmsyntax") - let b:asmsyntax = g:asmsyntax - else - let b:asmsyntax = "asm" - endif - endif - - exe "setf " . fnameescape(b:asmsyntax) -endfunc - -func! s:FTasmsyntax() - " see if file contains any asmsyntax=foo overrides. If so, change - " b:asmsyntax appropriately - let head = " ".getline(1)." ".getline(2)." ".getline(3)." ".getline(4). - \" ".getline(5)." " - let match = matchstr(head, '\sasmsyntax=\zs[a-zA-Z0-9]\+\ze\s') - if match != '' - let b:asmsyntax = match - elseif ((head =~? '\.title') || (head =~? '\.ident') || (head =~? '\.macro') || (head =~? '\.subtitle') || (head =~? '\.library')) - let b:asmsyntax = "vmasm" - endif -endfunc - -" Macro (VAX) -au BufNewFile,BufRead *.mar setf vmasm - -" Atlas -au BufNewFile,BufRead *.atl,*.as setf atlas - -" Autoit v3 -au BufNewFile,BufRead *.au3 setf autoit - -" Autohotkey -au BufNewFile,BufRead *.ahk setf autohotkey - -" Automake -au BufNewFile,BufRead [mM]akefile.am,GNUmakefile.am setf automake - -" Autotest .at files are actually m4 -au BufNewFile,BufRead *.at setf m4 - -" Avenue -au BufNewFile,BufRead *.ave setf ave - -" Awk -au BufNewFile,BufRead *.awk setf awk - -" B -au BufNewFile,BufRead *.mch,*.ref,*.imp setf b - -" BASIC or Visual Basic -au BufNewFile,BufRead *.bas call s:FTVB("basic") - -" Check if one of the first five lines contains "VB_Name". In that case it is -" probably a Visual Basic file. Otherwise it's assumed to be "alt" filetype. -func! s:FTVB(alt) - if getline(1).getline(2).getline(3).getline(4).getline(5) =~? 'VB_Name\|Begin VB\.\(Form\|MDIForm\|UserControl\)' - setf vb - else - exe "setf " . a:alt - endif -endfunc - -" Visual Basic Script (close to Visual Basic) -au BufNewFile,BufRead *.vbs,*.dsm,*.ctl setf vb - -" IBasic file (similar to QBasic) -au BufNewFile,BufRead *.iba,*.ibi setf ibasic - -" FreeBasic file (similar to QBasic) -au BufNewFile,BufRead *.fb,*.bi setf freebasic - -" Batch file for MSDOS. -au BufNewFile,BufRead *.bat,*.sys setf dosbatch -" *.cmd is close to a Batch file, but on OS/2 Rexx files also use *.cmd. -au BufNewFile,BufRead *.cmd - \ if getline(1) =~ '^/\*' | setf rexx | else | setf dosbatch | endif - -" Batch file for 4DOS -au BufNewFile,BufRead *.btm call s:FTbtm() -func! s:FTbtm() - if exists("g:dosbatch_syntax_for_btm") && g:dosbatch_syntax_for_btm - setf dosbatch - else - setf btm - endif -endfunc - -" BC calculator -au BufNewFile,BufRead *.bc setf bc - -" BDF font -au BufNewFile,BufRead *.bdf setf bdf - -" BibTeX bibliography database file -au BufNewFile,BufRead *.bib setf bib - -" BibTeX Bibliography Style -au BufNewFile,BufRead *.bst setf bst - -" BIND configuration -au BufNewFile,BufRead named.conf,rndc.conf setf named - -" BIND zone -au BufNewFile,BufRead named.root setf bindzone -au BufNewFile,BufRead *.db call s:BindzoneCheck('') - -func! s:BindzoneCheck(default) - if getline(1).getline(2).getline(3).getline(4) =~ '^; <<>> DiG [0-9.]\+ <<>>\|BIND.*named\|$ORIGIN\|$TTL\|IN\s\+SOA' - setf bindzone - elseif a:default != '' - exe 'setf ' . a:default - endif -endfunc - -" Blank -au BufNewFile,BufRead *.bl setf blank - -" Blkid cache file -au BufNewFile,BufRead /etc/blkid.tab,/etc/blkid.tab.old setf xml - -" C or lpc -au BufNewFile,BufRead *.c call s:FTlpc() - -func! s:FTlpc() - if exists("g:lpc_syntax_for_c") - let lnum = 1 - while lnum <= 12 - if getline(lnum) =~# '^\(//\|inherit\|private\|protected\|nosave\|string\|object\|mapping\|mixed\)' - setf lpc - return - endif - let lnum = lnum + 1 - endwhile - endif - setf c -endfunc - -" Calendar -au BufNewFile,BufRead calendar setf calendar -au BufNewFile,BufRead */.calendar/*, - \*/share/calendar/*/calendar.*,*/share/calendar/calendar.* - \ call s:StarSetf('calendar') - -" C# -au BufNewFile,BufRead *.cs setf cs - -" Cdrdao TOC -au BufNewFile,BufRead *.toc setf cdrtoc - -" Cdrdao config -au BufNewFile,BufRead etc/cdrdao.conf,etc/defaults/cdrdao,etc/default/cdrdao,~/.cdrdao setf cdrdaoconf - -" Cfengine -au BufNewFile,BufRead cfengine.conf setf cfengine - -" Comshare Dimension Definition Language -au BufNewFile,BufRead *.cdl setf cdl - -" Conary Recipe -au BufNewFile,BufRead *.recipe setf conaryrecipe - -" Controllable Regex Mutilator -au BufNewFile,BufRead *.crm setf crm - -" Cyn++ -au BufNewFile,BufRead *.cyn setf cynpp - -" Cynlib -" .cc and .cpp files can be C++ or Cynlib. -au BufNewFile,BufRead *.cc - \ if exists("cynlib_syntax_for_cc")|setf cynlib|else|setf cpp|endif -au BufNewFile,BufRead *.cpp - \ if exists("cynlib_syntax_for_cpp")|setf cynlib|else|setf cpp|endif - -" C++ -if has("fname_case") - au BufNewFile,BufRead *.cxx,*.c++,*.C,*.H,*.hh,*.hxx,*.hpp,*.moc,*.tcc,*.inl setf cpp -else - au BufNewFile,BufRead *.cxx,*.c++,*.hh,*.hxx,*.hpp,*.moc,*.tcc,*.inl setf cpp -endif - -" .h files can be C, Ch C++, ObjC or ObjC++. -" Set c_syntax_for_h if you want C, ch_syntax_for_h if you want Ch. ObjC is -" detected automatically. -au BufNewFile,BufRead *.h call s:FTheader() - -func! s:FTheader() - if match(getline(1, min([line("$"), 200])), '^@\(interface\|end\|class\)') > -1 - setf objc - elseif exists("c_syntax_for_h") - setf c - elseif exists("ch_syntax_for_h") - setf ch - else - setf cpp - endif -endfunc - -" Ch (CHscript) -au BufNewFile,BufRead *.chf setf ch - -" TLH files are C++ headers generated by Visual C++'s #import from typelibs -au BufNewFile,BufRead *.tlh setf cpp - -" Cascading Style Sheets -au BufNewFile,BufRead *.css setf css - -" Century Term Command Scripts (*.cmd too) -au BufNewFile,BufRead *.con setf cterm - -" Changelog -au BufNewFile,BufRead changelog.Debian,changelog.dch,NEWS.Debian,NEWS.dch - \ setf debchangelog - -au BufNewFile,BufRead [cC]hange[lL]og - \ if getline(1) =~ '; urgency=' - \| setf debchangelog - \| else - \| setf changelog - \| endif - -au BufNewFile,BufRead NEWS - \ if getline(1) =~ '; urgency=' - \| setf debchangelog - \| endif - -" CHILL -au BufNewFile,BufRead *..ch setf chill - -" Changes for WEB and CWEB or CHILL -au BufNewFile,BufRead *.ch call s:FTchange() - -" This function checks if one of the first ten lines start with a '@'. In -" that case it is probably a change file. -" If the first line starts with # or ! it's probably a ch file. -" If a line has "main", "include", "//" ir "/*" it's probably ch. -" Otherwise CHILL is assumed. -func! s:FTchange() - let lnum = 1 - while lnum <= 10 - if getline(lnum)[0] == '@' - setf change - return - endif - if lnum == 1 && (getline(1)[0] == '#' || getline(1)[0] == '!') - setf ch - return - endif - if getline(lnum) =~ "MODULE" - setf chill - return - endif - if getline(lnum) =~ 'main\s*(\|#\s*include\|//' - setf ch - return - endif - let lnum = lnum + 1 - endwhile - setf chill -endfunc - -" ChordPro -au BufNewFile,BufRead *.chopro,*.crd,*.cho,*.crdpro,*.chordpro setf chordpro - -" Clean -au BufNewFile,BufRead *.dcl,*.icl setf clean - -" Clever -au BufNewFile,BufRead *.eni setf cl - -" Clever or dtd -au BufNewFile,BufRead *.ent call s:FTent() - -func! s:FTent() - " This function checks for valid cl syntax in the first five lines. - " Look for either an opening comment, '#', or a block start, '{". - " If not found, assume SGML. - let lnum = 1 - while lnum < 6 - let line = getline(lnum) - if line =~ '^\s*[#{]' - setf cl - return - elseif line !~ '^\s*$' - " Not a blank line, not a comment, and not a block start, - " so doesn't look like valid cl code. - break - endif - let lnum = lnum + 1 - endw - setf dtd -endfunc - -" Clipper (or FoxPro; could also be eviews) -au BufNewFile,BufRead *.prg - \ if exists("g:filetype_prg") | - \ exe "setf " . g:filetype_prg | - \ else | - \ setf clipper | - \ endif - -" Cmake -au BufNewFile,BufRead CMakeLists.txt,*.cmake,*.cmake.in setf cmake - -" Cmusrc -au BufNewFile,BufRead ~/.cmus/{autosave,rc,command-history,*.theme} setf cmusrc -au BufNewFile,BufRead */cmus/{rc,*.theme} setf cmusrc - -" Cobol -au BufNewFile,BufRead *.cbl,*.cob,*.lib setf cobol -" cobol or zope form controller python script? (heuristic) -au BufNewFile,BufRead *.cpy - \ if getline(1) =~ '^##' | - \ setf python | - \ else | - \ setf cobol | - \ endif - -" Coco/R -au BufNewFile,BufRead *.atg setf coco - -" Cold Fusion -au BufNewFile,BufRead *.cfm,*.cfi,*.cfc setf cf - -" Configure scripts -au BufNewFile,BufRead configure.in,configure.ac setf config - -" CUDA Cumpute Unified Device Architecture -au BufNewFile,BufRead *.cu setf cuda - -" WildPackets EtherPeek Decoder -au BufNewFile,BufRead *.dcd setf dcd - -" Enlightenment configuration files -au BufNewFile,BufRead *enlightenment/*.cfg setf c - -" Eterm -au BufNewFile,BufRead *Eterm/*.cfg setf eterm - -" Lynx config files -au BufNewFile,BufRead lynx.cfg setf lynx - -" Quake -au BufNewFile,BufRead *baseq[2-3]/*.cfg,*id1/*.cfg setf quake -au BufNewFile,BufRead *quake[1-3]/*.cfg setf quake - -" Quake C -au BufNewFile,BufRead *.qc setf c - -" Configure files -au BufNewFile,BufRead *.cfg setf cfg - -" Communicating Sequential Processes -au BufNewFile,BufRead *.csp,*.fdr setf csp - -" CUPL logic description and simulation -au BufNewFile,BufRead *.pld setf cupl -au BufNewFile,BufRead *.si setf cuplsim - -" Debian Control -au BufNewFile,BufRead */debian/control setf debcontrol -au BufNewFile,BufRead control - \ if getline(1) =~ '^Source:' - \| setf debcontrol - \| endif - -" Debian Sources.list -au BufNewFile,BufRead /etc/apt/sources.list setf debsources - -" Deny hosts -au BufNewFile,BufRead denyhosts.conf setf denyhosts - -" ROCKLinux package description -au BufNewFile,BufRead *.desc setf desc - -" the D language or dtrace -au BufNewFile,BufRead *.d call s:DtraceCheck() - -func! s:DtraceCheck() - let lines = getline(1, min([line("$"), 100])) - if match(lines, '^#!\S\+dtrace\|#pragma\s\+D\s\+option\|:\S\{-}:\S\{-}:') > -1 - setf dtrace - else - setf d - endif -endfunc - -" Desktop files -au BufNewFile,BufRead *.desktop,.directory setf desktop - -" Dict config -au BufNewFile,BufRead dict.conf,.dictrc setf dictconf - -" Dictd config -au BufNewFile,BufRead dictd.conf setf dictdconf - -" Diff files -au BufNewFile,BufRead *.diff,*.rej,*.patch setf diff - -" Dircolors -au BufNewFile,BufRead .dir_colors,/etc/DIR_COLORS setf dircolors - -" Diva (with Skill) or InstallShield -au BufNewFile,BufRead *.rul - \ if getline(1).getline(2).getline(3).getline(4).getline(5).getline(6) =~? 'InstallShield' | - \ setf ishd | - \ else | - \ setf diva | - \ endif - -" DCL (Digital Command Language - vms) or DNS zone file -au BufNewFile,BufRead *.com call s:BindzoneCheck('dcl') - -" DOT -au BufNewFile,BufRead *.dot setf dot - -" Dylan - lid files -au BufNewFile,BufRead *.lid setf dylanlid - -" Dylan - intr files (melange) -au BufNewFile,BufRead *.intr setf dylanintr - -" Dylan -au BufNewFile,BufRead *.dylan setf dylan - -" Microsoft Module Definition -au BufNewFile,BufRead *.def setf def - -" Dracula -au BufNewFile,BufRead *.drac,*.drc,*lvs,*lpe setf dracula - -" dsl -au BufNewFile,BufRead *.dsl setf dsl - -" DTD (Document Type Definition for XML) -au BufNewFile,BufRead *.dtd setf dtd - -" EDIF (*.edf,*.edif,*.edn,*.edo) -au BufNewFile,BufRead *.ed\(f\|if\|n\|o\) setf edif - -" Embedix Component Description -au BufNewFile,BufRead *.ecd setf ecd - -" Eiffel or Specman -au BufNewFile,BufRead *.e,*.E call s:FTe() - -" Elinks configuration -au BufNewFile,BufRead */etc/elinks.conf,*/.elinks/elinks.conf setf elinks - -func! s:FTe() - let n = 1 - while n < 100 && n < line("$") - if getline(n) =~ "^\\s*\\(<'\\|'>\\)\\s*$" - setf specman - return - endif - let n = n + 1 - endwhile - setf eiffel -endfunc - -" ERicsson LANGuage; Yaws is erlang too -au BufNewFile,BufRead *.erl,*.hrl,*.yaws setf erlang - -" Elm Filter Rules file -au BufNewFile,BufRead filter-rules setf elmfilt - -" ESMTP rc file -au BufNewFile,BufRead *esmtprc setf esmtprc - -" ESQL-C -au BufNewFile,BufRead *.ec,*.EC setf esqlc - -" Esterel -au BufNewFile,BufRead *.strl setf esterel - -" Essbase script -au BufNewFile,BufRead *.csc setf csc - -" Exim -au BufNewFile,BufRead exim.conf setf exim - -" Expect -au BufNewFile,BufRead *.exp setf expect - -" Exports -au BufNewFile,BufRead exports setf exports - -" Factor -au BufNewFile,BufRead *.factor setf factor - -" Fetchmail RC file -au BufNewFile,BufRead .fetchmailrc setf fetchmail - -" FlexWiki -au BufNewFile,BufRead *.wiki setf flexwiki - -" Focus Executable -au BufNewFile,BufRead *.fex,*.focexec setf focexec - -" Focus Master file (but not for auto.master) -au BufNewFile,BufRead auto.master setf conf -au BufNewFile,BufRead *.mas,*.master setf master - -" Forth -au BufNewFile,BufRead *.fs,*.ft setf forth - -" Reva Forth -au BufNewFile,BufRead *.frt setf reva - -" Fortran -if has("fname_case") - au BufNewFile,BufRead *.F,*.FOR,*.FPP,*.FTN,*.F77,*.F90,*.F95 setf fortran -endif -au BufNewFile,BufRead *.f,*.for,*.fortran,*.fpp,*.ftn,*.f77,*.f90,*.f95 setf fortran - -" Framescript -au BufNewFile,BufRead *.fsl setf framescript - -" FStab -au BufNewFile,BufRead fstab,mtab setf fstab - -" GDB command files -au BufNewFile,BufRead .gdbinit setf gdb - -" GDMO -au BufNewFile,BufRead *.mo,*.gdmo setf gdmo - -" Gedcom -au BufNewFile,BufRead *.ged setf gedcom - -" Git -autocmd BufNewFile,BufRead *.git/COMMIT_EDITMSG setf gitcommit -autocmd BufNewFile,BufRead *.git/config,.gitconfig setf gitconfig -autocmd BufNewFile,BufRead git-rebase-todo setf gitrebase -autocmd BufNewFile,BufRead .msg.[0-9]* - \ if getline(1) =~ '^From.*# This line is ignored.$' | - \ setf gitsendemail | - \ endif -autocmd BufNewFile,BufRead *.git/** - \ if getline(1) =~ '^\x\{40\}\>\|^ref: ' | - \ setf git | - \ endif - -" Gkrellmrc -au BufNewFile,BufRead gkrellmrc,gkrellmrc_? setf gkrellmrc - -" GP scripts (2.0 and onward) -au BufNewFile,BufRead *.gp,.gprc setf gp - -" GPG -au BufNewFile,BufRead */.gnupg/options setf gpg -au BufNewFile,BufRead */.gnupg/gpg.conf setf gpg -au BufNewFile,BufRead /usr/**/gnupg/options.skel setf gpg - -" Gnuplot scripts -au BufNewFile,BufRead *.gpi setf gnuplot - -" GrADS scripts -au BufNewFile,BufRead *.gs setf grads - -" Gretl -au BufNewFile,BufRead *.gretl setf gretl - -" Groovy -au BufNewFile,BufRead *.groovy setf groovy - -" GNU Server Pages -au BufNewFile,BufRead *.gsp setf gsp - -" Group file -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 - -" GTK RC -au BufNewFile,BufRead .gtkrc,gtkrc setf gtkrc - -" Haml -au BufNewFile,BufRead *.haml setf haml - -" Hamster Classic | Playground files -au BufNewFile,BufRead *.hsc,*.hsm setf hamster - -" Haskell -au BufNewFile,BufRead *.hs setf haskell -au BufNewFile,BufRead *.lhs setf lhaskell -au BufNewFile,BufRead *.chs setf chaskell - -" Haste -au BufNewFile,BufRead *.ht setf haste -au BufNewFile,BufRead *.htpp setf hastepreproc - -" Hercules -au BufNewFile,BufRead *.vc,*.ev,*.rs,*.sum,*.errsum setf hercules - -" HEX (Intel) -au BufNewFile,BufRead *.hex,*.h32 setf hex - -" Tilde (must be before HTML) -au BufNewFile,BufRead *.t.html setf tilde - -" HTML (.shtml and .stm for server side) -au BufNewFile,BufRead *.html,*.htm,*.shtml,*.stm call s:FThtml() - -" Distinguish between HTML, XHTML and Django -func! s:FThtml() - let n = 1 - while n < 10 && n < line("$") - if getline(n) =~ '\<DTD\s\+XHTML\s' - setf xhtml - return - endif - if getline(n) =~ '{%\s*\(extends\|block\)\>' - setf htmldjango - return - endif - let n = n + 1 - endwhile - setf html -endfunc - -" HTML with Ruby - eRuby -au BufNewFile,BufRead *.erb,*.rhtml setf eruby - -" HTML with M4 -au BufNewFile,BufRead *.html.m4 setf htmlm4 - -" HTML Cheetah template -au BufNewFile,BufRead *.tmpl setf htmlcheetah - -" Host config -au BufNewFile,BufRead /etc/host.conf setf hostconf - -" Hosts access -au BufNewFile,BufRead /etc/hosts.allow,/etc/hosts.deny setf hostsaccess - -" Hyper Builder -au BufNewFile,BufRead *.hb setf hb - -" Icon -au BufNewFile,BufRead *.icn setf icon - -" IDL (Interface Description Language) -au BufNewFile,BufRead *.idl call s:FTidl() - -" Distinguish between standard IDL and MS-IDL -func! s:FTidl() - let n = 1 - while n < 50 && n < line("$") - if getline(n) =~ '^\s*import\s\+"\(unknwn\|objidl\)\.idl"' - setf msidl - return - endif - let n = n + 1 - endwhile - setf idl -endfunc - -" Microsoft IDL (Interface Description Language) Also *.idl -" MOF = WMI (Windows Management Instrumentation) Managed Object Format -au BufNewFile,BufRead *.odl,*.mof setf msidl - -" Icewm menu -au BufNewFile,BufRead */.icewm/menu setf icemenu - -" Indent profile (must come before IDL *.pro!) -au BufNewFile,BufRead .indent.pro setf indent -au BufNewFile,BufRead indent.pro call s:ProtoCheck('indent') - -" IDL (Interactive Data Language) -au BufNewFile,BufRead *.pro call s:ProtoCheck('idlang') - -" Distinguish between "default" and Cproto prototype file. */ -func! s:ProtoCheck(default) - " Cproto files have a comment in the first line and a function prototype in - " the second line, it always ends in ";". Indent files may also have - " comments, thus we can't match comments to see the difference. - if getline(2) =~ ';$' - setf cpp - else - exe 'setf ' . a:default - endif -endfunc - - -" Indent RC -au BufNewFile,BufRead indentrc setf indent - -" Inform -au BufNewFile,BufRead *.inf,*.INF setf inform - -" Initng -au BufNewFile,BufRead /etc/initng/**/*.i,*.ii setf initng - -" Ipfilter -au BufNewFile,BufRead ipf.conf,ipf6.conf,ipf.rules setf ipfilter - -" Informix 4GL (source - canonical, include file, I4GL+M4 preproc.) -au BufNewFile,BufRead *.4gl,*.4gh,*.m4gl setf fgl - -" .INI file for MSDOS -au BufNewFile,BufRead *.ini setf dosini - -" SysV Inittab -au BufNewFile,BufRead inittab setf inittab - -" Inno Setup -au BufNewFile,BufRead *.iss setf iss - -" JAL -au BufNewFile,BufRead *.jal,*.JAL setf jal - -" Jam -au BufNewFile,BufRead *.jpl,*.jpr setf jam - -" Java -au BufNewFile,BufRead *.java,*.jav setf java - -" JavaCC -au BufNewFile,BufRead *.jj,*.jjt setf javacc - -" JavaScript, ECMAScript -au BufNewFile,BufRead *.js,*.javascript,*.es setf javascript - -" Java Server Pages -au BufNewFile,BufRead *.jsp setf jsp - -" Java Properties resource file (note: doesn't catch font.properties.pl) -au BufNewFile,BufRead *.properties,*.properties_??,*.properties_??_?? setf jproperties -au BufNewFile,BufRead *.properties_??_??_* call s:StarSetf('jproperties') - -" Jess -au BufNewFile,BufRead *.clp setf jess - -" Jgraph -au BufNewFile,BufRead *.jgr setf jgraph - -" Kixtart -au BufNewFile,BufRead *.kix setf kix - -" Kimwitu[++] -au BufNewFile,BufRead *.k setf kwt - -" KDE script -au BufNewFile,BufRead *.ks setf kscript - -" Kconfig -au BufNewFile,BufRead Kconfig,Kconfig.debug setf kconfig - -" Lace (ISE) -au BufNewFile,BufRead *.ace,*.ACE setf lace - -" Latte -au BufNewFile,BufRead *.latte,*.lte setf latte - -" Limits -au BufNewFile,BufRead /etc/limits setf limits - -" LambdaProlog (*.mod too, see Modsim) -au BufNewFile,BufRead *.sig setf lprolog - -" LDAP LDIF -au BufNewFile,BufRead *.ldif setf ldif - -" Ld loader -au BufNewFile,BufRead *.ld setf ld - -" Lex -au BufNewFile,BufRead *.lex,*.l setf lex - -" Libao -au BufNewFile,BufRead /etc/libao.conf,*/.libao setf libao - -" Libsensors -au BufNewFile,BufRead /etc/sensors.conf setf sensors - -" LFTP -au BufNewFile,BufRead lftp.conf,.lftprc,*lftp/rc setf lftp - -" Lifelines (or Lex for C++!) -au BufNewFile,BufRead *.ll setf lifelines - -" Lilo: Linux loader -au BufNewFile,BufRead lilo.conf* call s:StarSetf('lilo') - -" Lisp (*.el = ELisp, *.cl = Common Lisp, *.jl = librep Lisp) -if has("fname_case") - au BufNewFile,BufRead *.lsp,*.lisp,*.el,*.cl,*.jl,*.L,.emacs,.sawfishrc setf lisp -else - au BufNewFile,BufRead *.lsp,*.lisp,*.el,*.cl,*.jl,.emacs,.sawfishrc setf lisp -endif - -" SBCL implementation of Common Lisp -au BufNewFile,BufRead sbclrc,.sbclrc setf lisp - -" Lite -au BufNewFile,BufRead *.lite,*.lt setf lite - -" LiteStep RC files -au BufNewFile,BufRead */LiteStep/*/*.rc setf litestep - -" Login access -au BufNewFile,BufRead /etc/login.access setf loginaccess - -" Login defs -au BufNewFile,BufRead /etc/login.defs setf logindefs - -" Logtalk -au BufNewFile,BufRead *.lgt setf logtalk - -" LOTOS -au BufNewFile,BufRead *.lot,*.lotos setf lotos - -" Lout (also: *.lt) -au BufNewFile,BufRead *.lou,*.lout setf lout - -" Lua -au BufNewFile,BufRead *.lua setf lua - -" Linden Scripting Language (Second Life) -au BufNewFile,BufRead *.lsl setf lsl - -" Lynx style file (or LotusScript!) -au BufNewFile,BufRead *.lss setf lss - -" M4 -au BufNewFile,BufRead *.m4 - \ if expand("<afile>") !~? 'html.m4$\|fvwm2rc' | setf m4 | endif - -" MaGic Point -au BufNewFile,BufRead *.mgp setf mgp - -" Mail (for Elm, trn, mutt, muttng, rn, slrn) -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 - -" Mail aliases -au BufNewFile,BufRead /etc/mail/aliases,/etc/aliases setf mailaliases - -" Mailcap configuration file -au BufNewFile,BufRead .mailcap,mailcap setf mailcap - -" Makefile -au BufNewFile,BufRead *[mM]akefile,*.mk,*.mak,*.dsp setf make - -" MakeIndex -au BufNewFile,BufRead *.ist,*.mst setf ist - -" Manpage -au BufNewFile,BufRead *.man setf man - -" Man config -au BufNewFile,BufRead /etc/man.conf,man.config setf manconf - -" Maple V -au BufNewFile,BufRead *.mv,*.mpl,*.mws setf maple - -" Map (UMN mapserver config file) -au BufNewFile,BufRead *.map setf map - -" Mason -au BufNewFile,BufRead *.mason,*.mhtml setf mason - -" Matlab or Objective C -au BufNewFile,BufRead *.m call s:FTm() - -func! s:FTm() - let n = 1 - while n < 10 - let line = getline(n) - if line =~ '^\s*\(#\s*\(include\|import\)\>\|/\*\)' - setf objc - return - endif - if line =~ '^\s*%' - setf matlab - return - endif - if line =~ '^\s*(\*' - setf mma - return - endif - let n = n + 1 - endwhile - if exists("g:filetype_m") - exe "setf " . g:filetype_m - else - setf matlab - endif -endfunc - -" Mathematica notebook -au BufNewFile,BufRead *.nb setf mma - -" Maya Extension Language -au BufNewFile,BufRead *.mel setf mel - -" Messages -au BufNewFile,BufRead /var/log/messages,/var/log/messages.*[0-9] setf messages - -" Metafont -au BufNewFile,BufRead *.mf setf mf - -" MetaPost -au BufNewFile,BufRead *.mp setf mp - -" MGL -au BufNewFile,BufRead *.mgl setf mgl - -" MMIX or VMS makefile -au BufNewFile,BufRead *.mms call s:FTmms() - -" Symbian meta-makefile definition (MMP) -au BufNewFile,BufRead *.mmp setf mmp - -func! s:FTmms() - let n = 1 - while n < 10 - let line = getline(n) - if line =~ '^\s*\(%\|//\)' || line =~ '^\*' - setf mmix - return - endif - if line =~ '^\s*#' - setf make - return - endif - let n = n + 1 - endwhile - setf mmix -endfunc - - -" Modsim III (or LambdaProlog) -au BufNewFile,BufRead *.mod - \ if getline(1) =~ '\<module\>' | - \ setf lprolog | - \ else | - \ setf modsim3 | - \ endif - -" Modula 2 -au BufNewFile,BufRead *.m2,*.DEF,*.MOD,*.md,*.mi setf modula2 - -" Modula 3 (.m3, .i3, .mg, .ig) -au BufNewFile,BufRead *.[mi][3g] setf modula3 - -" Monk -au BufNewFile,BufRead *.isc,*.monk,*.ssc,*.tsc setf monk - -" MOO -au BufNewFile,BufRead *.moo setf moo - -" Modconf -au BufNewFile,BufRead /etc/modules.conf,/etc/conf.modules setf modconf -au BufNewFile,BufRead /etc/modutils/* - \ if executable(expand("<afile>")) != 1 - \| call s:StarSetf('modconf') - \|endif - -" Mplayer config -au BufNewFile,BufRead mplayer.conf,*/.mplayer/config setf mplayerconf - -" Moterola S record -au BufNewFile,BufRead *.s19,*.s28,*.s37 setf srec - -" Mrxvtrc -au BufNewFile,BufRead mrxvtrc,.mrxvtrc setf mrxvtrc - -" Msql -au BufNewFile,BufRead *.msql setf msql - -" Mysql -au BufNewFile,BufRead *.mysql setf mysql - -" M$ Resource files -au BufNewFile,BufRead *.rc setf rc - -" MuPAD source -au BufRead,BufNewFile *.mu setf mupad - -" Mush -au BufNewFile,BufRead *.mush setf mush - -" Mutt setup file (also for Muttng) -au BufNewFile,BufRead Mutt{ng,}rc setf muttrc - -" Nano -au BufNewFile,BufRead /etc/nanorc,.nanorc setf nanorc - -" Nastran input/DMAP -"au BufNewFile,BufRead *.dat setf nastran - -" Natural -au BufNewFile,BufRead *.NS[ACGLMNPS] setf natural - -" Netrc -au BufNewFile,BufRead .netrc setf netrc - -" Novell netware batch files -au BufNewFile,BufRead *.ncf setf ncf - -" Nroff/Troff (*.ms and *.t are checked below) -au BufNewFile,BufRead *.me - \ if expand("<afile>") != "read.me" && expand("<afile>") != "click.me" | - \ setf nroff | - \ endif -au BufNewFile,BufRead *.tr,*.nr,*.roff,*.tmac,*.mom setf nroff -au BufNewFile,BufRead *.[1-9] call s:FTnroff() - -" This function checks if one of the first five lines start with a dot. In -" that case it is probably an nroff file: 'filetype' is set and 1 is returned. -func! s:FTnroff() - if getline(1)[0] . getline(2)[0] . getline(3)[0] . getline(4)[0] . getline(5)[0] =~ '\.' - setf nroff - return 1 - endif - return 0 -endfunc - -" Nroff or Objective C++ -au BufNewFile,BufRead *.mm call s:FTmm() - -func! s:FTmm() - let n = 1 - while n < 10 - let line = getline(n) - if line =~ '^\s*\(#\s*\(include\|import\)\>\|/\*\)' - setf objcpp - return - endif - let n = n + 1 - endwhile - setf nroff -endfunc - -" Not Quite C -au BufNewFile,BufRead *.nqc setf nqc - -" NSIS -au BufNewFile,BufRead *.nsi setf nsis - -" OCAML -au BufNewFile,BufRead *.ml,*.mli,*.mll,*.mly setf ocaml - -" Occam -au BufNewFile,BufRead *.occ setf occam - -" Omnimark -au BufNewFile,BufRead *.xom,*.xin setf omnimark - -" OpenROAD -au BufNewFile,BufRead *.or setf openroad - -" OPL -au BufNewFile,BufRead *.[Oo][Pp][Ll] setf opl - -" Oracle config file -au BufNewFile,BufRead *.ora setf ora - -" Packet filter conf -au BufNewFile,BufRead pf.conf setf pf - -" Pam conf -au BufNewFile,BufRead /etc/pam.conf setf pamconf - -" PApp -au BufNewFile,BufRead *.papp,*.pxml,*.pxsl setf papp - -" Password file -au BufNewFile,BufRead /etc/passwd,/etc/passwd-,/etc/passwd.edit,/etc/shadow,/etc/shadow-,/var/backups/passwd.bak,/var/backups/shadow.bak setf passwd - -" Pascal (also *.p) -au BufNewFile,BufRead *.pas setf pascal - -" Delphi project file -au BufNewFile,BufRead *.dpr setf pascal - -" PDF -au BufNewFile,BufRead *.pdf setf pdf - -" Perl -if has("fname_case") - au BufNewFile,BufRead *.pl,*.PL call s:FTpl() -else - au BufNewFile,BufRead *.pl call s:FTpl() -endif -au BufNewFile,BufRead *.plx setf perl - -func! s:FTpl() - if exists("g:filetype_pl") - exe "setf " . g:filetype_pl - else - " recognize Prolog by specific text in the first non-empty line - " require a blank after the '%' because Perl uses "%list" and "%translate" - let l = getline(nextnonblank(1)) - if l =~ '\<prolog\>' || l =~ '^\s*\(%\+\(\s\|$\)\|/\*\)' || l =~ ':-' - setf prolog - else - setf perl - endif - endif -endfunc - -" Perl, XPM or XPM2 -au BufNewFile,BufRead *.pm - \ if getline(1) =~ "XPM2" | - \ setf xpm2 | - \ elseif getline(1) =~ "XPM" | - \ setf xpm | - \ else | - \ setf perl | - \ endif - -" Perl POD -au BufNewFile,BufRead *.pod setf pod - -" Php, php3, php4, etc. -" Also Phtml (was used for PHP 2 in the past) -" Also .ctp for Cake template file -au BufNewFile,BufRead *.php,*.php\d,*.phtml,*.ctp setf php - -" Pike -au BufNewFile,BufRead *.pike,*.lpc,*.ulpc,*.pmod setf pike - -" Pinfo config -au BufNewFile,BufRead */etc/pinforc,*/.pinforc setf pinfo - -" Palm Resource compiler -au BufNewFile,BufRead *.rcp setf pilrc - -" Pine config -au BufNewFile,BufRead .pinerc,pinerc,.pinercex,pinercex setf pine - -" PL/M (also: *.inp) -au BufNewFile,BufRead *.plm,*.p36,*.pac setf plm - -" PL/SQL -au BufNewFile,BufRead *.pls,*.plsql setf plsql - -" PLP -au BufNewFile,BufRead *.plp setf plp - -" PO and PO template (GNU gettext) -au BufNewFile,BufRead *.po,*.pot setf po - -" Postfix main config -au BufNewFile,BufRead main.cf setf pfmain - -" PostScript (+ font files, encapsulated PostScript, Adobe Illustrator) -au BufNewFile,BufRead *.ps,*.pfa,*.afm,*.eps,*.epsf,*.epsi,*.ai setf postscr - -" PostScript Printer Description -au BufNewFile,BufRead *.ppd setf ppd - -" Povray -au BufNewFile,BufRead *.pov setf pov - -" Povray configuration -au BufNewFile,BufRead .povrayrc setf povini - -" Povray, PHP or assembly -au BufNewFile,BufRead *.inc call s:FTinc() - -func! s:FTinc() - if exists("g:filetype_inc") - exe "setf " . g:filetype_inc - else - let lines = getline(1).getline(2).getline(3) - if lines =~? "perlscript" - setf aspperl - elseif lines =~ "<%" - setf aspvbs - elseif lines =~ "<?" - setf php - else - call s:FTasmsyntax() - if exists("b:asmsyntax") - exe "setf " . fnameescape(b:asmsyntax) - else - setf pov - endif - endif - endif -endfunc - -" Printcap and Termcap -au BufNewFile,BufRead *printcap - \ let b:ptcap_type = "print" | setf ptcap -au BufNewFile,BufRead *termcap - \ let b:ptcap_type = "term" | setf ptcap - -" PCCTS / ANTRL -"au BufNewFile,BufRead *.g setf antrl -au BufNewFile,BufRead *.g setf pccts - -" PPWizard -au BufNewFile,BufRead *.it,*.ih setf ppwiz - -" Oracle Pro*C/C++ -au BufNewFile,BufRead *.pc setf proc - -" Privoxy actions file -au BufNewFile,BufRead *.action setf privoxy - -" Procmail -au BufNewFile,BufRead .procmail,.procmailrc setf procmail - -" Progress or CWEB -au BufNewFile,BufRead *.w call s:FTprogress_cweb() - -func! s:FTprogress_cweb() - if exists("g:filetype_w") - exe "setf " . g:filetype_w - return - endif - if getline(1) =~ '&ANALYZE' || getline(3) =~ '&GLOBAL-DEFINE' - setf progress - else - setf cweb - endif -endfunc - -" Progress or assembly -au BufNewFile,BufRead *.i call s:FTprogress_asm() - -func! s:FTprogress_asm() - if exists("g:filetype_i") - exe "setf " . g:filetype_i - return - endif - " This function checks for an assembly comment the first ten lines. - " If not found, assume Progress. - let lnum = 1 - while lnum <= 10 && lnum < line('$') - let line = getline(lnum) - if line =~ '^\s*;' || line =~ '^\*' - call s:FTasm() - return - elseif line !~ '^\s*$' || line =~ '^/\*' - " Not an empty line: Doesn't look like valid assembly code. - " Or it looks like a Progress /* comment - break - endif - let lnum = lnum + 1 - endw - setf progress -endfunc - -" Progress or Pascal -au BufNewFile,BufRead *.p call s:FTprogress_pascal() - -func! s:FTprogress_pascal() - if exists("g:filetype_p") - exe "setf " . g:filetype_p - return - endif - " This function checks for valid Pascal syntax in the first ten lines. - " Look for either an opening comment or a program start. - " If not found, assume Progress. - let lnum = 1 - while lnum <= 10 && lnum < line('$') - let line = getline(lnum) - if line =~ '^\s*\(program\|unit\|procedure\|function\|const\|type\|var\)\>' - \ || line =~ '^\s*{' || line =~ '^\s*(\*' - setf pascal - return - elseif line !~ '^\s*$' || line =~ '^/\*' - " Not an empty line: Doesn't look like valid Pascal code. - " Or it looks like a Progress /* comment - break - endif - let lnum = lnum + 1 - endw - setf progress -endfunc - - -" Software Distributor Product Specification File (POSIX 1387.2-1995) -au BufNewFile,BufRead *.psf setf psf -au BufNewFile,BufRead INDEX,INFO - \ if getline(1) =~ '^\s*\(distribution\|installed_software\|root\|bundle\|product\)\s*$' | - \ setf psf | - \ endif - -" Prolog -au BufNewFile,BufRead *.pdb setf prolog - -" Promela -au BufNewFile,BufRead *.pml setf promela - -" Protocols -au BufNewFile,BufRead /etc/protocols setf protocols - -" Pyrex -au BufNewFile,BufRead *.pyx,*.pxd setf pyrex - -" Python -au BufNewFile,BufRead *.py,*.pyw setf python - -" Quixote (Python-based web framework) -au BufNewFile,BufRead *.ptl setf python - -" Radiance -au BufNewFile,BufRead *.rad,*.mat setf radiance - -" Ratpoison config/command files -au BufNewFile,BufRead .ratpoisonrc,ratpoisonrc setf ratpoison - -" RCS file -au BufNewFile,BufRead *\,v setf rcs - -" Readline -au BufNewFile,BufRead .inputrc,inputrc setf readline - -" Registry for MS-Windows -au BufNewFile,BufRead *.reg - \ if getline(1) =~? '^REGEDIT[0-9]*\s*$\|^Windows Registry Editor Version \d*\.\d*\s*$' | setf registry | endif - -" Renderman Interface Bytestream -au BufNewFile,BufRead *.rib setf rib - -" Rexx -au BufNewFile,BufRead *.rexx,*.rex,*.jrexx,*.rxj,*.orx setf rexx - -" R (Splus) -if has("fname_case") - au BufNewFile,BufRead *.s,*.S setf r -else - au BufNewFile,BufRead *.s setf r -endif - -" R Help file -if has("fname_case") - au BufNewFile,BufRead *.rd,*.Rd setf rhelp -else - au BufNewFile,BufRead *.rd setf rhelp -endif - -" R noweb file -if has("fname_case") - au BufNewFile,BufRead *.Rnw,*.rnw,*.Snw,*.snw setf rnoweb -else - au BufNewFile,BufRead *.rnw,*.snw setf rnoweb -endif - -" Rexx, Rebol or R -au BufNewFile,BufRead *.r,*.R call s:FTr() - -func! s:FTr() - let max = line("$") > 50 ? 50 : line("$") - - for n in range(1, max) - " Rebol is easy to recognize, check for that first - if getline(n) =~? '\<REBOL\>' - setf rebol - return - endif - endfor - - for n in range(1, max) - " R has # comments - if getline(n) =~ '^\s*#' - setf r - return - endif - " Rexx has /* comments */ - if getline(n) =~ '^\s*/\*' - setf rexx - return - endif - endfor - - " Nothing recognized, assume Rexx - setf rexx -endfunc - -" Remind -au BufNewFile,BufRead .reminders* call s:StarSetf('remind') - -" Resolv.conf -au BufNewFile,BufRead resolv.conf setf resolv - -" Relax NG Compact -au BufNewFile,BufRead *.rnc setf rnc - -" RPL/2 -au BufNewFile,BufRead *.rpl setf rpl - -" Robots.txt -au BufNewFile,BufRead robots.txt setf robots - -" Rpcgen -au BufNewFile,BufRead *.x setf rpcgen - -" reStructuredText Documentation Format -au BufNewFile,BufRead *.rst setf rst - -" RTF -au BufNewFile,BufRead *.rtf setf rtf - -" Interactive Ruby shell -au BufNewFile,BufRead .irbrc,irbrc setf ruby - -" Ruby -au BufNewFile,BufRead *.rb,*.rbw,*.gem,*.gemspec setf ruby - -" Ruby on Rails -au BufNewFile,BufRead *.builder,*.rxml,*.rjs setf ruby - -" Rantfile and Rakefile is like Ruby -au BufNewFile,BufRead [rR]antfile,*.rant,[rR]akefile,*.rake setf ruby - -" S-lang (or shader language!) -au BufNewFile,BufRead *.sl setf slang - -" Samba config -au BufNewFile,BufRead smb.conf setf samba - -" SAS script -au BufNewFile,BufRead *.sas setf sas - -" Sass -au BufNewFile,BufRead *.sass setf sass - -" Sather -au BufNewFile,BufRead *.sa setf sather - -" Scilab -au BufNewFile,BufRead *.sci,*.sce setf scilab - -" SD: Streaming Descriptors -au BufNewFile,BufRead *.sd setf sd - -" SDL -au BufNewFile,BufRead *.sdl,*.pr setf sdl - -" sed -au BufNewFile,BufRead *.sed setf sed - -" Sieve (RFC 3028) -au BufNewFile,BufRead *.siv setf sieve - -" Sendmail -au BufNewFile,BufRead sendmail.cf setf sm - -" Sendmail .mc files are actually m4. Could also be MS Message text file. -au BufNewFile,BufRead *.mc call s:McSetf() - -func! s:McSetf() - " Rely on the file to start with a comment. - " MS message text files use ';', Sendmail files use '#' or 'dnl' - for lnum in range(1, min([line("$"), 20])) - let line = getline(lnum) - if line =~ '^\s*\(#\|dnl\)' - setf m4 " Sendmail .mc file - return - elseif line =~ '^\s*;' - setf msmessages " MS Message text file - return - endif - endfor - setf m4 " Default: Sendmail .mc file -endfunc - -" Services -au BufNewFile,BufRead /etc/services setf services - -" Service Location config -au BufNewFile,BufRead /etc/slp.conf setf slpconf - -" Service Location registration -au BufNewFile,BufRead /etc/slp.reg setf slpreg - -" Service Location SPI -au BufNewFile,BufRead /etc/slp.spi setf slpspi - -" Setserial config -au BufNewFile,BufRead /etc/serial.conf setf setserial - -" SGML -au BufNewFile,BufRead *.sgm,*.sgml - \ if getline(1).getline(2).getline(3).getline(4).getline(5) =~? 'linuxdoc' | - \ setf sgmllnx | - \ elseif getline(1) =~ '<!DOCTYPE.*DocBook' || getline(2) =~ '<!DOCTYPE.*DocBook' | - \ let b:docbk_type="sgml" | - \ setf docbk | - \ else | - \ setf sgml | - \ endif - -" SGMLDECL -au BufNewFile,BufRead *.decl,*.dcl,*.dec - \ if getline(1).getline(2).getline(3) =~? '^<!SGML' | - \ setf sgmldecl | - \ endif - -" SGML catalog file -au BufNewFile,BufRead catalog setf catalog -au BufNewFile,BufRead sgml.catalog* call s:StarSetf('catalog') - -" Shell scripts (sh, ksh, bash, bash2, csh); Allow .profile_foo etc. -" Gentoo ebuilds are actually bash scripts -au BufNewFile,BufRead .bashrc*,bashrc,bash.bashrc,.bash_profile*,.bash_logout*,*.bash,*.ebuild call SetFileTypeSH("bash") -au BufNewFile,BufRead .kshrc*,*.ksh call SetFileTypeSH("ksh") -au BufNewFile,BufRead /etc/profile,.profile*,*.sh,*.env call SetFileTypeSH(getline(1)) - -" Also called from scripts.vim. -func! SetFileTypeSH(name) - if expand("<amatch>") =~ g:ft_ignore_pat - return - endif - if a:name =~ '\<ksh\>' - let b:is_kornshell = 1 - if exists("b:is_bash") - unlet b:is_bash - endif - if exists("b:is_sh") - unlet b:is_sh - endif - elseif exists("g:bash_is_sh") || a:name =~ '\<bash\>' || a:name =~ '\<bash2\>' - let b:is_bash = 1 - if exists("b:is_kornshell") - unlet b:is_kornshell - endif - if exists("b:is_sh") - unlet b:is_sh - endif - elseif a:name =~ '\<sh\>' - let b:is_sh = 1 - if exists("b:is_kornshell") - unlet b:is_kornshell - endif - if exists("b:is_bash") - unlet b:is_bash - endif - endif - call SetFileTypeShell("sh") -endfunc - -" For shell-like file types, check for an "exec" command hidden in a comment, -" as used for Tcl. -" Also called from scripts.vim, thus can't be local to this script. -func! SetFileTypeShell(name) - if expand("<amatch>") =~ g:ft_ignore_pat - return - endif - let l = 2 - while l < 20 && l < line("$") && getline(l) =~ '^\s*\(#\|$\)' - " Skip empty and comment lines. - let l = l + 1 - endwhile - if l < line("$") && getline(l) =~ '\s*exec\s' && getline(l - 1) =~ '^\s*#.*\\$' - " Found an "exec" line after a comment with continuation - let n = substitute(getline(l),'\s*exec\s\+\([^ ]*/\)\=', '', '') - if n =~ '\<tclsh\|\<wish' - setf tcl - return - endif - endif - exe "setf " . a:name -endfunc - -" tcsh scripts -au BufNewFile,BufRead .tcshrc*,*.tcsh,tcsh.tcshrc,tcsh.login call SetFileTypeShell("tcsh") - -" csh scripts, but might also be tcsh scripts (on some systems csh is tcsh) -au BufNewFile,BufRead .login*,.cshrc*,csh.cshrc,csh.login,csh.logout,*.csh,.alias call s:CSH() - -func! s:CSH() - if exists("g:filetype_csh") - call SetFileTypeShell(g:filetype_csh) - elseif &shell =~ "tcsh" - call SetFileTypeShell("tcsh") - else - call SetFileTypeShell("csh") - endif -endfunc - -" Z-Shell script -au BufNewFile,BufRead .zprofile,/etc/zprofile,.zfbfmarks setf zsh -au BufNewFile,BufRead .zsh*,.zlog*,.zcompdump* call s:StarSetf('zsh') -au BufNewFile,BufRead *.zsh setf zsh - -" Scheme -au BufNewFile,BufRead *.scm,*.ss setf scheme - -" Screen RC -au BufNewFile,BufRead .screenrc,screenrc setf screen - -" Simula -au BufNewFile,BufRead *.sim setf simula - -" SINDA -au BufNewFile,BufRead *.sin,*.s85 setf sinda - -" SiSU -au BufNewFile,BufRead *.sst,*.ssm,*.ssi,*.-sst,*._sst setf sisu -au BufNewFile,BufRead *.sst.meta,*.-sst.meta,*._sst.meta setf sisu - -" SKILL -au BufNewFile,BufRead *.il,*.ils,*.cdf setf skill - -" SLRN -au BufNewFile,BufRead .slrnrc setf slrnrc -au BufNewFile,BufRead *.score setf slrnsc - -" Smalltalk (and TeX) -au BufNewFile,BufRead *.st setf st -au BufNewFile,BufRead *.cls - \ if getline(1) =~ '^%' | - \ setf tex | - \ else | - \ setf st | - \ endif - -" Smarty templates -au BufNewFile,BufRead *.tpl setf smarty - -" SMIL or XML -au BufNewFile,BufRead *.smil - \ if getline(1) =~ '<?\s*xml.*?>' | - \ setf xml | - \ else | - \ setf smil | - \ endif - -" SMIL or SNMP MIB file -au BufNewFile,BufRead *.smi - \ if getline(1) =~ '\<smil\>' | - \ setf smil | - \ else | - \ setf mib | - \ endif - -" SMITH -au BufNewFile,BufRead *.smt,*.smith setf smith - -" Snobol4 and spitbol -au BufNewFile,BufRead *.sno,*.spt setf snobol4 - -" SNMP MIB files -au BufNewFile,BufRead *.mib,*.my setf mib - -" Snort Configuration -au BufNewFile,BufRead *.hog,snort.conf,vision.conf setf hog -au BufNewFile,BufRead *.rules call s:FTRules() - -let s:ft_rules_udev_rules_pattern = '^\s*\cudev_rules\s*=\s*"\([^"]\{-1,}\)/*".*' -func! s:FTRules() - if expand('<amatch>:p') =~ '^/etc/udev/\%(rules\.d/\)\=.*\.rules$' - setf udevrules - return - endif - try - let config_lines = readfile('/etc/udev/udev.conf') - catch /^Vim\%((\a\+)\)\=:E484/ - setf hog - return - endtry - let dir = expand('<amatch>:p:h') - for line in config_lines - if line =~ s:ft_rules_udev_rules_pattern - let udev_rules = substitute(line, s:ft_rules_udev_rules_pattern, '\1', "") - if dir == udev_rules - setf udevrules - endif - break - endif - endfor - setf hog -endfunc - - -" Spec (Linux RPM) -au BufNewFile,BufRead *.spec setf spec - -" Speedup (AspenTech plant simulator) -au BufNewFile,BufRead *.speedup,*.spdata,*.spd setf spup - -" Slice -au BufNewFile,BufRead *.ice setf slice - -" Spice -au BufNewFile,BufRead *.sp,*.spice setf spice - -" Spyce -au BufNewFile,BufRead *.spy,*.spi setf spyce - -" Squid -au BufNewFile,BufRead squid.conf setf squid - -" SQL for Oracle Designer -au BufNewFile,BufRead *.tyb,*.typ,*.tyc,*.pkb,*.pks setf sql - -" SQL -au BufNewFile,BufRead *.sql call s:SQL() - -func! s:SQL() - if exists("g:filetype_sql") - exe "setf " . g:filetype_sql - else - setf sql - endif -endfunc - -" SQLJ -au BufNewFile,BufRead *.sqlj setf sqlj - -" SQR -au BufNewFile,BufRead *.sqr,*.sqi setf sqr - -" OpenSSH configuration -au BufNewFile,BufRead ssh_config,*/.ssh/config setf sshconfig - -" OpenSSH server configuration -au BufNewFile,BufRead sshd_config setf sshdconfig - -" Stata -au BufNewFile,BufRead *.ado,*.class,*.do,*.imata,*.mata setf stata - -" SMCL -au BufNewFile,BufRead *.hlp,*.ihlp,*.smcl setf smcl - -" Stored Procedures -au BufNewFile,BufRead *.stp setf stp - -" Standard ML -au BufNewFile,BufRead *.sml setf sml - -" Sratus VOS command macro -au BufNewFile,BufRead *.cm setf voscm - -" Sysctl -au BufNewFile,BufRead /etc/sysctl.conf setf sysctl - -" Sudoers -au BufNewFile,BufRead /etc/sudoers,sudoers.tmp setf sudoers - -" If the file has an extension of 't' and is in a directory 't' then it is -" almost certainly a Perl test file. -" If the first line starts with '#' and contains 'perl' it's probably a Perl -" file. -" (Slow test) If a file contains a 'use' statement then it is almost certainly -" a Perl file. -func! s:FTperl() - if expand("%:e") == 't' && expand("%:p:h:t") == 't' - setf perl - return 1 - endif - if getline(1)[0] == '#' && getline(1) =~ 'perl' - setf perl - return 1 - endif - if search('^use\s\s*\k', 'nc', 30) - setf perl - return 1 - endif - return 0 -endfunc - -" Tads (or Nroff or Perl test file) -au BufNewFile,BufRead *.t - \ if !s:FTnroff() && !s:FTperl() | setf tads | endif - -" Tags -au BufNewFile,BufRead tags setf tags - -" TAK -au BufNewFile,BufRead *.tak setf tak - -" Tcl (JACL too) -au BufNewFile,BufRead *.tcl,*.tk,*.itcl,*.itk,*.jacl setf tcl - -" TealInfo -au BufNewFile,BufRead *.tli setf tli - -" Telix Salt -au BufNewFile,BufRead *.slt setf tsalt - -" Terminfo -au BufNewFile,BufRead *.ti setf terminfo - -" TeX -au BufNewFile,BufRead *.latex,*.sty,*.dtx,*.ltx,*.bbl setf tex -au BufNewFile,BufRead *.tex call s:FTtex() - -" Choose context, plaintex, or tex (LaTeX) based on these rules: -" 1. Check the first line of the file for "%&<format>". -" 2. Check the first 1000 non-comment lines for LaTeX or ConTeXt keywords. -" 3. Default to "latex" or to g:tex_flavor, can be set in user's vimrc. -func! s:FTtex() - let firstline = getline(1) - if firstline =~ '^%&\s*\a\+' - let format = tolower(matchstr(firstline, '\a\+')) - let format = substitute(format, 'pdf', '', '') - if format == 'tex' - let format = 'plain' - endif - else - " Default value, may be changed later: - let format = exists("g:tex_flavor") ? g:tex_flavor : 'plain' - " Save position, go to the top of the file, find first non-comment line. - let save_cursor = getpos('.') - call cursor(1,1) - let firstNC = search('^\s*[^[:space:]%]', 'c', 1000) - if firstNC " Check the next thousand lines for a LaTeX or ConTeXt keyword. - let lpat = 'documentclass\>\|usepackage\>\|begin{\|newcommand\>\|renewcommand\>' - 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\>' - let kwline = search('^\s*\\\%(' . lpat . '\)\|^\s*\\\(' . cpat . '\)', - \ 'cnp', firstNC + 1000) - if kwline == 1 " lpat matched - let format = 'latex' - elseif kwline == 2 " cpat matched - let format = 'context' - endif " If neither matched, keep default set above. - " let lline = search('^\s*\\\%(' . lpat . '\)', 'cn', firstNC + 1000) - " let cline = search('^\s*\\\%(' . cpat . '\)', 'cn', firstNC + 1000) - " if cline > 0 - " let format = 'context' - " endif - " if lline > 0 && (cline == 0 || cline > lline) - " let format = 'tex' - " endif - endif " firstNC - call setpos('.', save_cursor) - endif " firstline =~ '^%&\s*\a\+' - - " Translation from formats to file types. TODO: add AMSTeX, RevTex, others? - if format == 'plain' - setf plaintex - elseif format == 'context' - setf context - else " probably LaTeX - setf tex - endif - return -endfunc - -" ConTeXt -au BufNewFile,BufRead tex/context/*/*.tex,*.mkii,*.mkiv setf context - -" Texinfo -au BufNewFile,BufRead *.texinfo,*.texi,*.txi setf texinfo - -" TeX configuration -au BufNewFile,BufRead texmf.cnf setf texmf - -" Tidy config -au BufNewFile,BufRead .tidyrc,tidyrc setf tidy - -" TF mud client -au BufNewFile,BufRead *.tf,.tfrc,tfrc setf tf - -" TPP - Text Presentation Program -au BufNewFile,BufReadPost *.tpp setf tpp - -" Trustees -au BufNewFile,BufRead trustees.conf setf trustees - -" TSS - Geometry -au BufNewFile,BufReadPost *.tssgm setf tssgm - -" TSS - Optics -au BufNewFile,BufReadPost *.tssop setf tssop - -" TSS - Command Line (temporary) -au BufNewFile,BufReadPost *.tsscl setf tsscl - -" Motif UIT/UIL files -au BufNewFile,BufRead *.uit,*.uil setf uil - -" Udev conf -au BufNewFile,BufRead /etc/udev/udev.conf setf udevconf - -" Udev permissions -au BufNewFile,BufRead /etc/udev/permissions.d/*.permissions setf udevperm -" -" Udev symlinks config -au BufNewFile,BufRead /etc/udev/cdsymlinks.conf setf sh - -" UnrealScript -au BufNewFile,BufRead *.uc setf uc - -" Updatedb -au BufNewFile,BufRead /etc/updatedb.conf setf updatedb - -" Vera -au BufNewFile,BufRead *.vr,*.vri,*.vrh setf vera - -" Verilog HDL -au BufNewFile,BufRead *.v setf verilog - -" Verilog-AMS HDL -au BufNewFile,BufRead *.va,*.vams setf verilogams - -" VHDL -au BufNewFile,BufRead *.hdl,*.vhd,*.vhdl,*.vbe,*.vst setf vhdl -au BufNewFile,BufRead *.vhdl_[0-9]* call s:StarSetf('vhdl') - -" Vim script -au BufNewFile,BufRead *.vim,*.vba,.exrc,_exrc setf vim - -" Viminfo file -au BufNewFile,BufRead .viminfo,_viminfo setf viminfo - -" Virata Config Script File -au BufRead,BufNewFile *.hw,*.module,*.pkg setf virata - -" Visual Basic (also uses *.bas) or FORM -au BufNewFile,BufRead *.frm call s:FTVB("form") - -" SaxBasic is close to Visual Basic -au BufNewFile,BufRead *.sba setf vb - -" Vgrindefs file -au BufNewFile,BufRead vgrindefs setf vgrindefs - -" VRML V1.0c -au BufNewFile,BufRead *.wrl setf vrml - -" Webmacro -au BufNewFile,BufRead *.wm setf webmacro - -" Wget config -au BufNewFile,BufRead .wgetrc,wgetrc setf wget - -" Website MetaLanguage -au BufNewFile,BufRead *.wml setf wml - -" Winbatch -au BufNewFile,BufRead *.wbt setf winbatch - -" WSML -au BufNewFile,BufRead *.wsml setf wsml - -" WvDial -au BufNewFile,BufRead wvdial.conf,.wvdialrc setf wvdial - -" CVS RC file -au BufNewFile,BufRead .cvsrc setf cvsrc - -" CVS commit file -au BufNewFile,BufRead cvs\d\+ setf cvs - -" WEB (*.web is also used for Winbatch: Guess, based on expecting "%" comment -" lines in a WEB file). -au BufNewFile,BufRead *.web - \ if getline(1)[0].getline(2)[0].getline(3)[0].getline(4)[0].getline(5)[0] =~ "%" | - \ setf web | - \ else | - \ setf winbatch | - \ endif - -" Windows Scripting Host and Windows Script Component -au BufNewFile,BufRead *.ws[fc] setf wsh - -" XHTML -au BufNewFile,BufRead *.xhtml,*.xht setf xhtml - -" X Pixmap (dynamically sets colors, use BufEnter to make it work better) -au BufEnter *.xpm - \ if getline(1) =~ "XPM2" | - \ setf xpm2 | - \ else | - \ setf xpm | - \ endif -au BufEnter *.xpm2 setf xpm2 - -" XFree86 config -au BufNewFile,BufRead XF86Config - \ if getline(1) =~ '\<XConfigurator\>' | - \ let b:xf86c_xfree86_version = 3 | - \ endif | - \ setf xf86conf - -" Xorg config -au BufNewFile,BufRead xorg.conf,xorg.conf-4 let b:xf86c_xfree86_version = 4 | setf xf86conf - -" Xinetd conf -au BufNewFile,BufRead /etc/xinetd.conf setf xinetd - -" XS Perl extension interface language -au BufNewFile,BufRead *.xs setf xs - -" X resources file -au BufNewFile,BufRead .Xdefaults,.Xpdefaults,.Xresources,xdm-config,*.ad setf xdefaults - -" Xmath -au BufNewFile,BufRead *.msc,*.msf setf xmath -au BufNewFile,BufRead *.ms - \ if !s:FTnroff() | setf xmath | endif - -" XML specific variants: docbk and xbl -au BufNewFile,BufRead *.xml call s:FTxml() - -func! s:FTxml() - let n = 1 - while n < 100 && n < line("$") - let line = getline(n) - if line =~ '<!DOCTYPE.*DocBook' - let b:docbk_type = "xml" - setf docbk - return - endif - if line =~ 'xmlns:xbl="http://www.mozilla.org/xbl"' - setf xbl - return - endif - let n += 1 - endwhile - setf xml -endfunc - -" XMI (holding UML models) is also XML -au BufNewFile,BufRead *.xmi setf xml - -" CSPROJ files are Visual Studio.NET's XML-based project config files -au BufNewFile,BufRead *.csproj,*.csproj.user setf xml - -" Qt Linguist translation source and Qt User Interface Files are XML -au BufNewFile,BufRead *.ts,*.ui setf xml - -" TPM's are RDF-based descriptions of TeX packages (Nikolai Weibull) -au BufNewFile,BufRead *.tpm setf xml - -" Xdg menus -au BufNewFile,BufRead /etc/xdg/menus/*.menu setf xml - -" ATI graphics driver configuration -au BufNewFile,BufRead fglrxrc setf xml - -" XLIFF (XML Localisation Interchange File Format) is also XML -au BufNewFile,BufRead *.xlf setf xml -au BufNewFile,BufRead *.xliff setf xml - -" X11 xmodmap (also see below) -au BufNewFile,BufRead *Xmodmap setf xmodmap - -" Xquery -au BufNewFile,BufRead *.xq,*.xql,*.xqm,*.xquery,*.xqy setf xquery - -" XSD -au BufNewFile,BufRead *.xsd setf xsd - -" Xslt -au BufNewFile,BufRead *.xsl,*.xslt setf xslt - -" Yacc -au BufNewFile,BufRead *.yy setf yacc - -" Yacc or racc -au BufNewFile,BufRead *.y call s:FTy() - -func! s:FTy() - let n = 1 - while n < 100 && n < line("$") - let line = getline(n) - if line =~ '^\s*%' - setf yacc - return - endif - if getline(n) =~ '^\s*\(#\|class\>\)' && getline(n) !~ '^\s*#\s*include' - setf racc - return - endif - let n = n + 1 - endwhile - setf yacc -endfunc - - -" Yaml -au BufNewFile,BufRead *.yaml,*.yml setf yaml - -" Zope -" dtml (zope dynamic template markup language), pt (zope page template), -" cpt (zope form controller page template) -au BufNewFile,BufRead *.dtml,*.pt,*.cpt call s:FThtml() -" zsql (zope sql method) -au BufNewFile,BufRead *.zsql call s:SQL() - -" Z80 assembler asz80 -au BufNewFile,BufRead *.z8a setf z8a - -augroup END - - -" Source the user-specified filetype file, for backwards compatibility with -" Vim 5.x. -if exists("myfiletypefile") && filereadable(expand(myfiletypefile)) - execute "source " . myfiletypefile -endif - - -" Check for "*" after loading myfiletypefile, so that scripts.vim is only used -" when there are no matching file name extensions. -" Don't do this for compressed files. -augroup filetypedetect -au BufNewFile,BufRead * - \ if !did_filetype() && expand("<amatch>") !~ g:ft_ignore_pat - \ | runtime! scripts.vim | endif -au StdinReadPost * if !did_filetype() | runtime! scripts.vim | endif - - -" Extra checks for when no filetype has been detected now. Mostly used for -" patterns that end in "*". E.g., "zsh*" matches "zsh.vim", but that's a Vim -" script file. -" Most of these should call s:StarSetf() to avoid names ending in .gz and the -" like are used. - -" More Apache files. -au BufNewFile,BufRead /etc/apache2/conf.*/*,/etc/apache2/sites-*/*,/etc/apache2/mods-*/* call s:StarSetf('apache') - -" Asterisk config file -au BufNewFile,BufRead *asterisk/*.conf* call s:StarSetf('asterisk') -au BufNewFile,BufRead *asterisk*/*voicemail.conf* call s:StarSetf('asteriskvm') - -" Bazaar version control -au BufNewFile,BufRead bzr_log.* setf bzr - -" BIND zone -au BufNewFile,BufRead */named/db.*,*/bind/db.* call s:StarSetf('bindzone') - -" Changelog -au BufNewFile,BufRead [cC]hange[lL]og* - \ if getline(1) =~ '; urgency=' - \| call s:StarSetf('debchangelog') - \|else - \| call s:StarSetf('changelog') - \|endif - -" Crontab -au BufNewFile,BufRead crontab,crontab.*,/etc/cron.d/* call s:StarSetf('crontab') - -" Debian Sources.list -au BufNewFile,BufRead /etc/apt/sources.list.d/* call s:StarSetf('debsources') - -" Dracula -au BufNewFile,BufRead drac.* call s:StarSetf('dracula') - -" Fvwm -au BufNewFile,BufRead */.fvwm/* call s:StarSetf('fvwm') -au BufNewFile,BufRead *fvwmrc*,*fvwm95*.hook - \ let b:fvwm_version = 1 | call s:StarSetf('fvwm') -au BufNewFile,BufRead *fvwm2rc* - \ if expand("<afile>:e") == "m4" - \| call s:StarSetf('fvwm2m4') - \|else - \| let b:fvwm_version = 2 | call s:StarSetf('fvwm') - \|endif - -" GTK RC -au BufNewFile,BufRead .gtkrc*,gtkrc* call s:StarSetf('gtkrc') - -" Jam -au BufNewFile,BufRead Prl*.*,JAM*.* call s:StarSetf('jam') - -" Jargon -au! BufNewFile,BufRead *jarg* - \ if getline(1).getline(2).getline(3).getline(4).getline(5) =~? 'THIS IS THE JARGON FILE' - \| call s:StarSetf('jargon') - \|endif - -" Kconfig -au BufNewFile,BufRead Kconfig.* call s:StarSetf('kconfig') - -" Makefile -au BufNewFile,BufRead [mM]akefile* call s:StarSetf('make') - -" Ruby Makefile -au BufNewFile,BufRead [rR]akefile* call s:StarSetf('ruby') - -" Mail (also matches muttrc.vim, so this is below the other checks) -au BufNewFile,BufRead mutt[[:alnum:]._-]\{6\} setf mail - -" Modconf -au BufNewFile,BufRead /etc/modprobe.* call s:StarSetf('modconf') - -" Mutt setup file -au BufNewFile,BufRead .mutt{ng,}rc*,*/.mutt{ng,}/mutt{ng,}rc* call s:StarSetf('muttrc') -au BufNewFile,BufRead mutt{ng,}rc*,Mutt{ng,}rc* call s:StarSetf('muttrc') - -" Nroff macros -au BufNewFile,BufRead tmac.* call s:StarSetf('nroff') - -" Pam conf -au BufNewFile,BufRead /etc/pam.d/* call s:StarSetf('pamconf') - -" Printcap and Termcap -au BufNewFile,BufRead *printcap* - \ if !did_filetype() - \| let b:ptcap_type = "print" | call s:StarSetf('ptcap') - \|endif -au BufNewFile,BufRead *termcap* - \ if !did_filetype() - \| let b:ptcap_type = "term" | call s:StarSetf('ptcap') - \|endif - -" Vim script -au BufNewFile,BufRead *vimrc* call s:StarSetf('vim') - -" Subversion commit file -au BufNewFile,BufRead svn-commit*.tmp setf svn - -" X resources file -au BufNewFile,BufRead Xresources*,*/app-defaults/*,*/Xresources/* call s:StarSetf('xdefaults') - -" XFree86 config -au BufNewFile,BufRead XF86Config-4* - \ let b:xf86c_xfree86_version = 4 | call s:StarSetf('xf86conf') -au BufNewFile,BufRead XF86Config* - \ if getline(1) =~ '\<XConfigurator\>' - \| let b:xf86c_xfree86_version = 3 - \|endif - \|call s:StarSetf('xf86conf') - -" X11 xmodmap -au BufNewFile,BufRead *xmodmap* call s:StarSetf('xmodmap') - -" Xinetd conf -au BufNewFile,BufRead /etc/xinetd.d/* call s:StarSetf('xinetd') - -" Z-Shell script -au BufNewFile,BufRead zsh*,zlog* call s:StarSetf('zsh') - - -" Generic configuration file (check this last, it's just guessing!) -au BufNewFile,BufRead,StdinReadPost * - \ if !did_filetype() && expand("<amatch>") !~ g:ft_ignore_pat - \ && (getline(1) =~ '^#' || getline(2) =~ '^#' || getline(3) =~ '^#' - \ || getline(4) =~ '^#' || getline(5) =~ '^#') | - \ setf conf | - \ endif - -" Use the plugin-filetype checks last, they may overrule any of the previously -" detected filetypes. -runtime! ftdetect/*.vim - -augroup END - - -" If the GUI is already running, may still need to install the Syntax menu. -" Don't do it when the 'M' flag is included in 'guioptions'. -if has("menu") && has("gui_running") - \ && !exists("did_install_syntax_menu") && &guioptions !~# "M" - source <sfile>:p:h/menu.vim -endif - -" Function called for testing all functions defined here. These are -" script-local, thus need to be executed here. -" Returns a string with error messages (hopefully empty). -func! TestFiletypeFuncs(testlist) - let output = '' - for f in a:testlist - try - exe f - catch - let output = output . "\n" . f . ": " . v:exception - endtry - endfor - return output -endfunc - -" Restore 'cpoptions' -let &cpo = s:cpo_save -unlet s:cpo_save diff --git a/share/vim/vim72/ftplugin/AppendMatchGroup.vim b/share/vim/vim72/ftplugin/AppendMatchGroup.vim deleted file mode 100644 index 34e80b5f83..0000000000 --- a/share/vim/vim72/ftplugin/AppendMatchGroup.vim +++ /dev/null @@ -1,125 +0,0 @@ -" Vim filetype plugin file utility -" Language: * (various) -" Maintainer: Dave Silvia <dsilvia@mchsi.com> -" Date: 6/30/2004 - -" The start of match (b:SOM) default is: -" '\<' -" The end of match (b:EOM) default is: -" '\>' -" -" If you want to use some other start/end of match, just assign the -" value to the b:SOM|EOM variable in your filetype script. -" -" SEE: :h pattern.txt -" :h pattern-searches -" :h regular-expression -" :h matchit - -let s:myName=expand("<sfile>:t") - -" matchit.vim not loaded -- don't do anyting -if !exists("loaded_matchit") - echomsg s:myName.": matchit.vim not loaded -- finishing without loading" - finish -endif - -" already been here -- don't redefine -if exists("*AppendMatchGroup") - finish -endif - -" Function To Build b:match_words -" The following function, 'AppendMatchGroup', helps to increase -" readability of your filetype script if you choose to use matchit. -" It also precludes many construction errors, reducing the -" construction to simply invoking the function with the match words. -" As an example, let's take the ubiquitous if/then/else/endif type -" of construct. This is how the entry in your filetype script would look. -" -" " source the AppendMatchGroup function file -" runtime ftplugin/AppendMatchGroup.vim -" -" " fill b:match_words -" call AppendMatchGroup('if,then,else,endif') -" -" And the b:match_words constructed would look like: -" -" \<if\>:\<then\>:\<else\>:\<endif\> -" -" Use of AppendMatchGroup makes your filetype script is a little -" less busy and a lot more readable. Additionally, it -" checks three critical things: -" -" 1) Do you have at least 2 entries in your match group. -" -" 2) Does the buffer variable 'b:match_words' exist? if not, create it. -" -" 3) If the buffer variable 'b:match_words' does exist, is the last -" character a ','? If not, add it before appending. -" -" You should now be able to match 'if/then/else/endif' in succession -" in your source file, in just about any construction you may have -" chosen for them. -" -" To add another group, simply call 'AppendMatchGroup again. E.G.: -" -" call AppendMatchGroup('while,do,endwhile') - -function AppendMatchGroup(mwordList) - let List=a:mwordList - let Comma=match(List,',') - if Comma == -1 || Comma == strlen(List)-1 - echoerr "Must supply a comma separated list of at least 2 entries." - echoerr "Supplied list: <".List.">" - return - endif - let listEntryBegin=0 - let listEntryEnd=Comma - let listEntry=strpart(List,listEntryBegin,listEntryEnd-listEntryBegin) - let List=strpart(List,Comma+1) - let Comma=match(List,',') - " if listEntry is all spaces || List is empty || List is all spaces - if (match(listEntry,'\s\+') == 0 && match(listEntry,'\S\+') == -1) - \ || List == '' || (match(List,'\s\+') == 0 && match(List,'\S\+') == -1) - echoerr "Can't use all spaces for an entry <".listEntry.">" - echoerr "Remaining supplied list: <".List.">" - return - endif - - if !exists("b:SOM") - let b:SOM='\<' - endif - if !exists("b:EOM") - let b:EOM='\>' - endif - if !exists("b:match_words") - let b:match_words='' - endif - if b:match_words != '' && match(b:match_words,',$') == -1 - let b:match_words=b:match_words.',' - endif - " okay, all set add first entry in this list - let b:match_words=b:match_words.b:SOM.listEntry.b:EOM.':' - while Comma != -1 - let listEntryEnd=Comma - let listEntry=strpart(List,listEntryBegin,listEntryEnd-listEntryBegin) - let List=strpart(List,Comma+1) - let Comma=match(List,',') - " if listEntry is all spaces - if match(listEntry,'\s\+') == 0 && match(listEntry,'\S\+') == -1 - echoerr "Can't use all spaces for an entry <".listEntry."> - skipping" - echoerr "Remaining supplied list: <".List.">" - continue - endif - let b:match_words=b:match_words.b:SOM.listEntry.b:EOM.':' - endwhile - let listEntry=List - let b:match_words=b:match_words.b:SOM.listEntry.b:EOM -endfunction - -" TODO: Write a wrapper to handle multiple groups in one function call. -" Don't see a lot of utility in this as it would undoubtedly warrant -" continuation lines in the filetype script and it would be a toss -" up as to which is more readable: individual calls one to a line or -" a single call with continuation lines. I vote for the former. diff --git a/share/vim/vim72/ftplugin/abaqus.vim b/share/vim/vim72/ftplugin/abaqus.vim deleted file mode 100644 index 17985b3327..0000000000 --- a/share/vim/vim72/ftplugin/abaqus.vim +++ /dev/null @@ -1,79 +0,0 @@ -" Vim filetype plugin file -" Language: Abaqus finite element input file (www.abaqus.com) -" Maintainer: Carl Osterwisch <osterwischc@asme.org> -" Last Change: 2004 Jul 06 - -" Only do this when not done yet for this buffer -if exists("b:did_ftplugin") | finish | endif - -" Don't load another plugin for this buffer -let b:did_ftplugin = 1 - -" Save the compatibility options and temporarily switch to vim defaults -let s:cpo_save = &cpoptions -set cpoptions&vim - -" Folding -if version >= 600 - " Fold all lines that do not begin with * - setlocal foldexpr=getline(v:lnum)[0]!=\"\*\" - setlocal foldmethod=expr -endif - -" Set the format of the include file specification for Abaqus -" Used in :check gf ^wf [i and other commands -setlocal include=\\<\\cINPUT\\s*= - -" Remove characters up to the first = when evaluating filenames -setlocal includeexpr=substitute(v:fname,'.\\{-}=','','') - -" Remove comma from valid filename characters since it is used to -" separate keyword parameters -setlocal isfname-=, - -" Define format of comment lines (see 'formatoptions' for uses) -setlocal comments=:** -setlocal commentstring=**%s - -" Definitions start with a * and assign a NAME, NSET, or ELSET -" Used in [d ^wd and other commands -setlocal define=^\\*\\a.*\\c\\(NAME\\\|NSET\\\|ELSET\\)\\s*= - -" Abaqus keywords and identifiers may include a - character -setlocal iskeyword+=- - -" Set the file browse filter (currently only supported under Win32 gui) -if has("gui_win32") && !exists("b:browsefilter") - let b:browsefilter = "Abaqus Input Files (*.inp *.inc)\t*.inp;*.inc\n" . - \ "Abaqus Results (*.dat)\t*.dat\n" . - \ "Abaqus Messages (*.pre *.msg *.sta)\t*.pre;*.msg;*.sta\n" . - \ "All Files (*.*)\t*.*\n" -endif - -" Define keys used to move [count] sections backward or forward. -" TODO: Make this do something intelligent in visual mode. -nnoremap <silent> <buffer> [[ :call <SID>Abaqus_Jump('?^\*\a?')<CR> -nnoremap <silent> <buffer> ]] :call <SID>Abaqus_Jump('/^\*\a/')<CR> -function! <SID>Abaqus_Jump(motion) range - let s:count = v:count1 - mark ' - while s:count > 0 - silent! execute a:motion - let s:count = s:count - 1 - endwhile -endfunction - -" Define key to toggle commenting of the current line or range -noremap <silent> <buffer> <m-c> :call <SID>Abaqus_ToggleComment()<CR>j -function! <SID>Abaqus_ToggleComment() range - if strpart(getline(a:firstline), 0, 2) == "**" - " Un-comment all lines in range - silent execute a:firstline . ',' . a:lastline . 's/^\*\*//' - else - " Comment all lines in range - silent execute a:firstline . ',' . a:lastline . 's/^/**/' - endif -endfunction - -" Restore saved compatibility options -let &cpoptions = s:cpo_save diff --git a/share/vim/vim72/ftplugin/ant.vim b/share/vim/vim72/ftplugin/ant.vim deleted file mode 100644 index d45ef3bb25..0000000000 --- a/share/vim/vim72/ftplugin/ant.vim +++ /dev/null @@ -1,43 +0,0 @@ -" Vim filetype plugin file -" Language: ant -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2003 Sep 29 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "XML Files (*.xml)\t*.xml\n" . - \ "All Files (*.*)\t*.*\n" - -runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim -let b:did_ftplugin = 1 - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter -endif - -" Change the :browse e filter to primarily show Ant-related files. -if has("gui_win32") - let b:browsefilter = "Build Files (build.xml)\tbuild.xml\n" . - \ "Java Files (*.java)\t*.java\n" . - \ "Properties Files (*.prop*)\t*.prop*\n" . - \ "Manifest Files (*.mf)\t*.mf\n" . - \ s:browsefilter -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "unlet! b:browsefilter | " . s:undo_ftplugin - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/aspvbs.vim b/share/vim/vim72/ftplugin/aspvbs.vim deleted file mode 100644 index e3bc70980e..0000000000 --- a/share/vim/vim72/ftplugin/aspvbs.vim +++ /dev/null @@ -1,59 +0,0 @@ -" Vim filetype plugin file -" Language: aspvbs -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2004 Jun 28 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "HTML Files (*.html, *.htm)\t*.htm*\n" . - \ "All Files (*.*)\t*.*\n" -let s:match_words = "" - -runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim -let b:did_ftplugin = 1 - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter -endif -if exists("b:match_words") - let s:match_words = b:match_words -endif - -" ASP: Active Server Pages (with Visual Basic Script) -" thanks to Gontran BAERTS -if exists("loaded_matchit") - let s:notend = '\%(\<end\s\+\)\@<!' - let b:match_ignorecase = 1 - let b:match_words = - \ s:notend . '\<if\>\%(.\{-}then\s\+\w\)\@!:\<elseif\>:^\s*\<else\>:\<end\s\+\<if\>,' . - \ s:notend . '\<select\s\+case\>:\<case\>:\<case\s\+else\>:\<end\s\+select\>,' . - \ '^\s*\<sub\>:\<end\s\+sub\>,' . - \ '^\s*\<function\>:\<end\s\+function\>,' . - \ '\<class\>:\<end\s\+class\>,' . - \ '^\s*\<do\>:\<loop\>,' . - \ '^\s*\<for\>:\<next\>,' . - \ '\<while\>:\<wend\>,' . - \ s:match_words -endif - -" Change the :browse e filter to primarily show ASP-related files. -if has("gui_win32") - let b:browsefilter="ASP Files (*.asp)\t*.asp\n" . s:browsefilter -endif - -let b:undo_ftplugin = "unlet! b:match_words b:match_ignorecase b:browsefilter | " . s:undo_ftplugin - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/changelog.vim b/share/vim/vim72/ftplugin/changelog.vim deleted file mode 100644 index 924d35daed..0000000000 --- a/share/vim/vim72/ftplugin/changelog.vim +++ /dev/null @@ -1,259 +0,0 @@ -" Vim filetype plugin file -" Language: generic Changelog file -" Maintainer: Nikolai Weibull <now@bitwi.se> -" Latest Revision: 2007-05-21 -" Variables: -" g:changelog_timeformat (deprecated: use g:changelog_dateformat instead) - -" description: the timeformat used in ChangeLog entries. -" default: "%Y-%m-%d". -" g:changelog_dateformat - -" description: the format sent to strftime() to generate a date string. -" default: "%Y-%m-%d". -" g:changelog_username - -" description: the username to use in ChangeLog entries -" default: try to deduce it from environment variables and system files. -" Local Mappings: -" <Leader>o - -" adds a new changelog entry for the current user for the current date. -" Global Mappings: -" <Leader>o - -" switches to the ChangeLog buffer opened for the current directory, or -" opens it in a new buffer if it exists in the current directory. Then -" it does the same as the local <Leader>o described above. -" Notes: -" run 'runtime ftplugin/changelog.vim' to enable the global mapping for -" changelog files. -" TODO: -" should we perhaps open the ChangeLog file even if it doesn't exist already? -" Problem is that you might end up with ChangeLog files all over the place. - -" If 'filetype' isn't "changelog", we must have been to add ChangeLog opener -if &filetype == 'changelog' - if exists('b:did_ftplugin') - finish - endif - let b:did_ftplugin = 1 - - let s:cpo_save = &cpo - set cpo&vim - - " Set up the format used for dates. - if !exists('g:changelog_dateformat') - if exists('g:changelog_timeformat') - let g:changelog_dateformat = g:changelog_timeformat - else - let g:changelog_dateformat = "%Y-%m-%d" - endif - endif - - " Try to figure out a reasonable username of the form: - " Full Name <user@host>. - if !exists('g:changelog_username') - if exists('$EMAIL') && $EMAIL != '' - let g:changelog_username = $EMAIL - elseif exists('$EMAIL_ADDRESS') && $EMAIL_ADDRESS != '' - " This is some Debian junk if I remember correctly. - let g:changelog_username = $EMAIL_ADDRESS - else - " Get the users login name. - let login = system('whoami') - if v:shell_error - let login = 'unknown' - else - let newline = stridx(login, "\n") - if newline != -1 - let login = strpart(login, 0, newline) - endif - endif - - " Try to get the full name from gecos field in /etc/passwd. - if filereadable('/etc/passwd') - for line in readfile('/etc/passwd') - if line =~ '^' . login - let name = substitute(line,'^\%([^:]*:\)\{4}\([^:]*\):.*$','\1','') - " Only keep stuff before the first comma. - let comma = stridx(name, ',') - if comma != -1 - let name = strpart(name, 0, comma) - endif - " And substitute & in the real name with the login of our user. - let amp = stridx(name, '&') - if amp != -1 - let name = strpart(name, 0, amp) . toupper(login[0]) . - \ strpart(login, 1) . strpart(name, amp + 1) - endif - endif - endfor - endif - - " If we haven't found a name, try to gather it from other places. - if !exists('name') - " Maybe the environment has something of interest. - if exists("$NAME") - let name = $NAME - else - " No? well, use the login name and capitalize first - " character. - let name = toupper(login[0]) . strpart(login, 1) - endif - endif - - " Get our hostname. - let hostname = system('hostname') - if v:shell_error - let hostname = 'localhost' - else - let newline = stridx(hostname, "\n") - if newline != -1 - let hostname = strpart(hostname, 0, newline) - endif - endif - - " And finally set the username. - let g:changelog_username = name . ' <' . login . '@' . hostname . '>' - endif - endif - - " Format used for new date entries. - if !exists('g:changelog_new_date_format') - let g:changelog_new_date_format = "%d %u\n\n\t* %c\n\n" - endif - - " Format used for new entries to current date entry. - if !exists('g:changelog_new_entry_format') - let g:changelog_new_entry_format = "\t* %c" - endif - - " Regular expression used to find a given date entry. - if !exists('g:changelog_date_entry_search') - let g:changelog_date_entry_search = '^\s*%d\_s*%u' - endif - - " Regular expression used to find the end of a date entry - if !exists('g:changelog_date_end_entry_search') - let g:changelog_date_end_entry_search = '^\s*$' - endif - - - " Substitutes specific items in new date-entry formats and search strings. - " Can be done with substitute of course, but unclean, and need \@! then. - function! s:substitute_items(str, date, user) - let str = a:str - let middles = {'%': '%', 'd': a:date, 'u': a:user, 'c': '{cursor}'} - let i = stridx(str, '%') - while i != -1 - let inc = 0 - if has_key(middles, str[i + 1]) - let mid = middles[str[i + 1]] - let str = strpart(str, 0, i) . mid . strpart(str, i + 2) - let inc = strlen(mid) - endif - let i = stridx(str, '%', i + 1 + inc) - endwhile - return str - endfunction - - " Position the cursor once we've done all the funky substitution. - function! s:position_cursor() - if search('{cursor}') > 0 - let lnum = line('.') - let line = getline(lnum) - let cursor = stridx(line, '{cursor}') - call setline(lnum, substitute(line, '{cursor}', '', '')) - endif - startinsert! - endfunction - - " Internal function to create a new entry in the ChangeLog. - function! s:new_changelog_entry() - " Deal with 'paste' option. - let save_paste = &paste - let &paste = 1 - call cursor(1, 1) - " Look for an entry for today by our user. - let date = strftime(g:changelog_dateformat) - let search = s:substitute_items(g:changelog_date_entry_search, date, - \ g:changelog_username) - if search(search) > 0 - " Ok, now we look for the end of the date entry, and add an entry. - call cursor(nextnonblank(line('.') + 1), 1) - if search(g:changelog_date_end_entry_search, 'W') > 0 - let p = line('.') - 1 - else - let p = line('.') - endif - let ls = split(s:substitute_items(g:changelog_new_entry_format, '', ''), - \ '\n') - call append(p, ls) - call cursor(p + 1, 1) - else - " Flag for removing empty lines at end of new ChangeLogs. - let remove_empty = line('$') == 1 - - " No entry today, so create a date-user header and insert an entry. - let todays_entry = s:substitute_items(g:changelog_new_date_format, - \ date, g:changelog_username) - " Make sure we have a cursor positioning. - if stridx(todays_entry, '{cursor}') == -1 - let todays_entry = todays_entry . '{cursor}' - endif - - " Now do the work. - call append(0, split(todays_entry, '\n')) - - " Remove empty lines at end of file. - if remove_empty - $-/^\s*$/-1,$delete - endif - - " Reposition cursor once we're done. - call cursor(1, 1) - endif - - call s:position_cursor() - - " And reset 'paste' option - let &paste = save_paste - endfunction - - if exists(":NewChangelogEntry") != 2 - map <buffer> <silent> <Leader>o <Esc>:call <SID>new_changelog_entry()<CR> - command! -nargs=0 NewChangelogEntry call s:new_changelog_entry() - endif - - let b:undo_ftplugin = "setl com< fo< et< ai<" - - setlocal comments= - setlocal formatoptions+=t - setlocal noexpandtab - setlocal autoindent - - if &textwidth == 0 - setlocal textwidth=78 - let b:undo_ftplugin .= " tw<" - endif - - let &cpo = s:cpo_save - unlet s:cpo_save -else - " Add the Changelog opening mapping - nmap <silent> <Leader>o :call <SID>open_changelog()<CR> - - function! s:open_changelog() - if !filereadable('ChangeLog') - return - endif - let buf = bufnr('ChangeLog') - if buf != -1 - if bufwinnr(buf) != -1 - execute bufwinnr(buf) . 'wincmd w' - else - execute 'sbuffer' buf - endif - else - split ChangeLog - endif - - call s:new_changelog_entry() - endfunction -endif diff --git a/share/vim/vim72/ftplugin/config.vim b/share/vim/vim72/ftplugin/config.vim deleted file mode 100644 index 427d0ed70c..0000000000 --- a/share/vim/vim72/ftplugin/config.vim +++ /dev/null @@ -1,41 +0,0 @@ -" Vim filetype plugin file -" Language: config -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2004 Jul 08 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "Bourne Shell Files (*.sh)\t*.sh\n" . - \ "All Files (*.*)\t*.*\n" -let s:match_words = "" - -runtime! ftplugin/sh.vim ftplugin/sh_*.vim ftplugin/sh/*.vim -let b:did_ftplugin = 1 - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter -endif - -" Change the :browse e filter to primarily show configure-related files. -if has("gui_win32") - let b:browsefilter="Configure Scripts (configure.*, config.*)\tconfigure*;config.*\n" . - \ s:browsefilter -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "unlet! b:browsefilter | " . b:undo_ftplugin - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/csc.vim b/share/vim/vim72/ftplugin/csc.vim deleted file mode 100644 index d9f901086f..0000000000 --- a/share/vim/vim72/ftplugin/csc.vim +++ /dev/null @@ -1,26 +0,0 @@ -" Vim filetype plugin file -" Language: csc -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2003 Sep 29 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif -let b:did_ftplugin = 1 - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -if exists("loaded_matchit") - let b:match_words= - \ '\<fix\>:\<endfix\>,' . - \ '\<if\>:\<else\%(if\)\=\>:\<endif\>,' . - \ '\<!loopondimensions\>\|\<!looponselected\>:\<!endloop\>' -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "unlet! b:match_words" - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/csh.vim b/share/vim/vim72/ftplugin/csh.vim deleted file mode 100644 index d053cbbdeb..0000000000 --- a/share/vim/vim72/ftplugin/csh.vim +++ /dev/null @@ -1,47 +0,0 @@ -" Vim filetype plugin file -" Language: csh -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2003 Sep 29 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif -let b:did_ftplugin = 1 - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -setlocal commentstring=#%s -setlocal formatoptions-=t -setlocal formatoptions+=crql - -" Csh: thanks to Johannes Zellner -" - Both foreach and end must appear alone on separate lines. -" - The words else and endif must appear at the beginning of input lines; -" the if must appear alone on its input line or after an else. -" - Each case label and the default label must appear at the start of a -" line. -" - while and end must appear alone on their input lines. -if exists("loaded_matchit") - let b:match_words = - \ '^\s*\<if\>.*(.*).*\<then\>:'. - \ '^\s*\<else\>\s\+\<if\>.*(.*).*\<then\>:^\s*\<else\>:'. - \ '^\s*\<endif\>,'. - \ '\%(^\s*\<foreach\>\s\+\S\+\|^s*\<while\>\).*(.*):'. - \ '\<break\>:\<continue\>:^\s*\<end\>,'. - \ '^\s*\<switch\>.*(.*):^\s*\<case\>\s\+:^\s*\<default\>:^\s*\<endsw\>' -endif - -" Change the :browse e filter to primarily show csh-related files. -if has("gui_win32") - let b:browsefilter="csh Scripts (*.csh)\t*.csh\n" . - \ "All Files (*.*)\t*.*\n" -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "setlocal commentstring< formatoptions<" . - \ " | unlet! b:match_words b:browsefilter" - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/debchangelog.vim b/share/vim/vim72/ftplugin/debchangelog.vim deleted file mode 100644 index 00a025b47c..0000000000 --- a/share/vim/vim72/ftplugin/debchangelog.vim +++ /dev/null @@ -1,374 +0,0 @@ -" Vim filetype plugin file (GUI menu, folding and completion) -" Language: Debian Changelog -" Maintainer: Debian Vim Maintainers <pkg-vim-maintainers@lists.alioth.debian.org> -" Former Maintainers: Michael Piefel <piefel@informatik.hu-berlin.de> -" Stefano Zacchiroli <zack@debian.org> -" Last Change: 2008-03-08 -" License: GNU GPL, version 2.0 or later -" URL: http://git.debian.org/?p=pkg-vim/vim.git;a=blob_plain;f=runtime/ftplugin/debchangelog.vim;hb=debian - -" Bug completion requires apt-listbugs installed for Debian packages or -" python-launchpad-bugs installed for Ubuntu packages - -if exists("b:did_ftplugin") - finish -endif -let b:did_ftplugin=1 - -" {{{1 Local settings (do on every load) -if exists("g:debchangelog_fold_enable") - setlocal foldmethod=expr - setlocal foldexpr=DebGetChangelogFold(v:lnum) - setlocal foldtext=DebChangelogFoldText() -endif - -" Debian changelogs are not supposed to have any other text width, -" so the user cannot override this setting -setlocal tw=78 -setlocal comments=f:* - -" Clean unloading -let b:undo_ftplugin = "setlocal tw< comments< foldmethod< foldexpr< foldtext<" -" }}}1 - -if exists("g:did_changelog_ftplugin") - finish -endif - -" Don't load another plugin (this is global) -let g:did_changelog_ftplugin = 1 - -" {{{1 GUI menu - -" Helper functions returning various data. -" Returns full name, either from $DEBFULLNAME or debianfullname. -" TODO Is there a way to determine name from anywhere else? -function <SID>FullName() - if exists("$DEBFULLNAME") - return $DEBFULLNAME - elseif exists("g:debianfullname") - return g:debianfullname - else - return "Your Name" - endif -endfunction - -" Returns email address, from $DEBEMAIL, $EMAIL or debianemail. -function <SID>Email() - if exists("$DEBEMAIL") - return $DEBEMAIL - elseif exists("$EMAIL") - return $EMAIL - elseif exists("g:debianemail") - return g:debianemail - else - return "your@email.address" - endif -endfunction - -" Returns date in RFC822 format. -function <SID>Date() - let savelang = v:lc_time - execute "language time C" - let dateandtime = strftime("%a, %d %b %Y %X %z") - execute "language time " . savelang - return dateandtime -endfunction - -function <SID>WarnIfNotUnfinalised() - if match(getline("."), " -- [[:alpha:]][[:alnum:].]")!=-1 - echohl WarningMsg - echo "The entry has not been unfinalised before editing." - echohl None - return 1 - endif - return 0 -endfunction - -function <SID>Finalised() - let savelinenum = line(".") - normal 1G - call search("^ -- ") - if match(getline("."), " -- [[:alpha:]][[:alnum:].]")!=-1 - let returnvalue = 1 - else - let returnvalue = 0 - endif - execute savelinenum - return returnvalue -endfunction - -" These functions implement the menus -function NewVersion() - " The new entry is unfinalised and shall be changed - amenu disable Changelog.New\ Version - amenu enable Changelog.Add\ Entry - amenu enable Changelog.Close\ Bug - amenu enable Changelog.Set\ Distribution - amenu enable Changelog.Set\ Urgency - amenu disable Changelog.Unfinalise - amenu enable Changelog.Finalise - call append(0, substitute(getline(1), '-\([[:digit:]]\+\))', '-$$\1)', '')) - call append(1, "") - call append(2, "") - call append(3, " -- ") - call append(4, "") - call Urgency("low") - normal 1G0 - call search(")") - normal h - normal  - call setline(1, substitute(getline(1), '-\$\$', '-', '')) - if exists("g:debchangelog_fold_enable") - foldopen - endif - call AddEntry() -endfunction - -function AddEntry() - normal 1G - call search("^ -- ") - normal kk - call append(".", " * ") - normal jjj - let warn=<SID>WarnIfNotUnfinalised() - normal kk - if warn - echohl MoreMsg - call input("Hit ENTER") - echohl None - endif - startinsert! -endfunction - -function CloseBug() - normal 1G - call search("^ -- ") - let warn=<SID>WarnIfNotUnfinalised() - normal kk - call append(".", " * (closes: #" . input("Bug number to close: ") . ")") - normal j^ll - startinsert -endfunction - -function Distribution(dist) - call setline(1, substitute(getline(1), ") [[:lower:] ]*;", ") " . a:dist . ";", "")) -endfunction - -function Urgency(urg) - call setline(1, substitute(getline(1), "urgency=.*$", "urgency=" . a:urg, "")) -endfunction - -function <SID>UnfinaliseMenu() - " This means the entry shall be changed - amenu disable Changelog.New\ Version - amenu enable Changelog.Add\ Entry - amenu enable Changelog.Close\ Bug - amenu enable Changelog.Set\ Distribution - amenu enable Changelog.Set\ Urgency - amenu disable Changelog.Unfinalise - amenu enable Changelog.Finalise -endfunction - -function Unfinalise() - call <SID>UnfinaliseMenu() - normal 1G - call search("^ -- ") - call setline(".", " -- ") -endfunction - -function <SID>FinaliseMenu() - " This means the entry should not be changed anymore - amenu enable Changelog.New\ Version - amenu disable Changelog.Add\ Entry - amenu disable Changelog.Close\ Bug - amenu disable Changelog.Set\ Distribution - amenu disable Changelog.Set\ Urgency - amenu enable Changelog.Unfinalise - amenu disable Changelog.Finalise -endfunction - -function Finalise() - call <SID>FinaliseMenu() - normal 1G - call search("^ -- ") - call setline(".", " -- " . <SID>FullName() . " <" . <SID>Email() . "> " . <SID>Date()) -endfunction - - -function <SID>MakeMenu() - amenu &Changelog.&New\ Version :call NewVersion()<CR> - amenu Changelog.&Add\ Entry :call AddEntry()<CR> - amenu Changelog.&Close\ Bug :call CloseBug()<CR> - menu Changelog.-sep- <nul> - - amenu Changelog.Set\ &Distribution.&unstable :call Distribution("unstable")<CR> - amenu Changelog.Set\ Distribution.&frozen :call Distribution("frozen")<CR> - amenu Changelog.Set\ Distribution.&stable :call Distribution("stable")<CR> - menu Changelog.Set\ Distribution.-sep- <nul> - amenu Changelog.Set\ Distribution.frozen\ unstable :call Distribution("frozen unstable")<CR> - amenu Changelog.Set\ Distribution.stable\ unstable :call Distribution("stable unstable")<CR> - amenu Changelog.Set\ Distribution.stable\ frozen :call Distribution("stable frozen")<CR> - amenu Changelog.Set\ Distribution.stable\ frozen\ unstable :call Distribution("stable frozen unstable")<CR> - - amenu Changelog.Set\ &Urgency.&low :call Urgency("low")<CR> - amenu Changelog.Set\ Urgency.&medium :call Urgency("medium")<CR> - amenu Changelog.Set\ Urgency.&high :call Urgency("high")<CR> - - menu Changelog.-sep- <nul> - amenu Changelog.U&nfinalise :call Unfinalise()<CR> - amenu Changelog.&Finalise :call Finalise()<CR> - - if <SID>Finalised() - call <SID>FinaliseMenu() - else - call <SID>UnfinaliseMenu() - endif -endfunction - -augroup changelogMenu -au BufEnter * if &filetype == "debchangelog" | call <SID>MakeMenu() | endif -au BufLeave * if &filetype == "debchangelog" | aunmenu Changelog | endif -augroup END - -" }}} -" {{{1 folding - -" look for an author name in the [zonestart zoneend] lines searching backward -function! s:getAuthor(zonestart, zoneend) - let linepos = a:zoneend - while linepos >= a:zonestart - let line = getline(linepos) - if line =~ '^ --' - return substitute(line, '^ --\s*\([^<]\+\)\s*.*', '\1', '') - endif - let linepos -= 1 - endwhile - return '[unknown]' -endfunction - -" Look for a package source name searching backward from the givenline and -" returns it. Return the empty string if the package name can't be found -function! DebGetPkgSrcName(lineno) - let lineidx = a:lineno - let pkgname = '' - while lineidx > 0 - let curline = getline(lineidx) - if curline =~ '^\S' - let pkgname = matchlist(curline, '^\(\S\+\).*$')[1] - break - endif - let lineidx = lineidx - 1 - endwhile - return pkgname -endfunction - -function! DebChangelogFoldText() - if v:folddashes == '-' " changelog entry fold - return foldtext() . ' -- ' . s:getAuthor(v:foldstart, v:foldend) . ' ' - endif - return foldtext() -endfunction - -function! DebGetChangelogFold(lnum) - let line = getline(a:lnum) - if line =~ '^\w\+' - return '>1' " beginning of a changelog entry - endif - if line =~ '^\s\+\[.*\]' - return '>2' " beginning of an author-specific chunk - endif - if line =~ '^ --' - return '1' - endif - return '=' -endfunction - -if exists("g:debchangelog_fold_enable") - silent! foldopen! " unfold the entry the cursor is on (usually the first one) -endif - -" }}} - -" {{{1 omnicompletion for Closes: # - -if !exists('g:debchangelog_listbugs_severities') - let g:debchangelog_listbugs_severities = 'critical,grave,serious,important,normal,minor,wishlist' -endif - -fun! DebCompleteBugs(findstart, base) - if a:findstart - let line = getline('.') - - " try to detect whether this is closes: or lp: - let g:debchangelog_complete_mode = 'debbugs' - let try_colidx = col('.') - 1 - let colidx = -1 " default to no-completion-possible - - while try_colidx > 0 && line[try_colidx - 1] =~ '\s\|\d\|#\|,\|:' - let try_colidx = try_colidx - 1 - if line[try_colidx] == '#' && colidx == -1 - " found hash, where we complete from: - let colidx = try_colidx - elseif line[try_colidx] == ':' - if try_colidx > 1 && strpart(line, try_colidx - 2, 3) =~ '\clp:' - let g:debchangelog_complete_mode = 'lp' - endif - break - endif - endwhile - return colidx - else " return matches: - let bug_lines = [] - if g:debchangelog_complete_mode == 'lp' - if ! has('python') - echoerr 'vim must be built with Python support to use LP bug completion' - return - endif - let pkgsrc = DebGetPkgSrcName(line('.')) - python << EOF -import vim -try: - from launchpadbugs import connector - buglist = connector.ConnectBugList() - bl = list(buglist('https://bugs.launchpad.net/ubuntu/+source/%s' % vim.eval('pkgsrc'))) - bl.sort(None, int) - liststr = '[' - for bug in bl: - liststr += "'#%d - %s'," % (int(bug), bug.summary.replace('\'', '\'\'')) - liststr += ']' - vim.command('silent let bug_lines = %s' % liststr) -except ImportError: - vim.command('echoerr \'python-launchpad-bugs needs to be installed to use Launchpad bug completion\'') -EOF - else - if ! filereadable('/usr/sbin/apt-listbugs') - echoerr 'apt-listbugs not found, you should install it to use Closes bug completion' - return - endif - let pkgsrc = DebGetPkgSrcName(line('.')) - let listbugs_output = system('/usr/sbin/apt-listbugs -s ' . g:debchangelog_listbugs_severities . ' list ' . pkgsrc . ' | grep "^ #" 2> /dev/null') - let bug_lines = split(listbugs_output, '\n') - endif - let completions = [] - for line in bug_lines - let parts = matchlist(line, '^\s*\(#\S\+\)\s*-\s*\(.*\)$') - " filter only those which match a:base: - if parts[1] !~ "^" . a:base - continue - endif - let completion = {} - let completion['word'] = parts[1] - let completion['menu'] = parts[2] - let completion['info'] = parts[0] - let completions += [completion] - endfor - return completions - endif -endfun - -setlocal omnifunc=DebCompleteBugs - -" }}} - -" vim: set foldmethod=marker: diff --git a/share/vim/vim72/ftplugin/debcontrol.vim b/share/vim/vim72/ftplugin/debcontrol.vim deleted file mode 100644 index 2fb2ee7d34..0000000000 --- a/share/vim/vim72/ftplugin/debcontrol.vim +++ /dev/null @@ -1,70 +0,0 @@ -" Vim filetype plugin file (GUI menu and folding) -" Language: Debian control files -" Maintainer: Debian Vim Maintainers <pkg-vim-maintainers@lists.alioth.debian.org> -" Former Maintainer: Pierre Habouzit <madcoder@debian.org> -" Last Change: 2008-03-08 -" URL: http://git.debian.org/?p=pkg-vim/vim.git;a=blob_plain;f=runtime/ftplugin/debcontrol.vim;hb=debian - -" Do these settings once per buffer -if exists("b:did_ftplugin") - finish -endif -let b:did_ftplugin=1 - -" {{{1 Local settings (do on every load) -if exists("g:debcontrol_fold_enable") - setlocal foldmethod=expr - setlocal foldexpr=DebControlFold(v:lnum) - setlocal foldtext=DebControlFoldText() -endif -setlocal textwidth=0 - -" Clean unloading -let b:undo_ftplugin = "setlocal tw< foldmethod< foldexpr< foldtext<" - -" }}}1 - -" {{{1 folding - -function! s:getField(f, lnum) - let line = getline(a:lnum) - let fwdsteps = 0 - while line !~ '^'.a:f.':' - let fwdsteps += 1 - let line = getline(a:lnum + fwdsteps) - if line == '' - return 'unknown' - endif - endwhile - return substitute(line, '^'.a:f.': *', '', '') -endfunction - -function! DebControlFoldText() - if v:folddashes == '-' " debcontrol entry fold - let type = substitute(getline(v:foldstart), ':.*', '', '') - if type == 'Source' - let ftext = substitute(foldtext(), ' *Source: *', ' ', '') - return ftext . ' -- ' . s:getField('Maintainer', v:foldstart) . ' ' - endif - let arch = s:getField('Architecture', v:foldstart) - let ftext = substitute(foldtext(), ' *Package: *', ' [' . arch . '] ', '') - return ftext . ': ' . s:getField('Description', v:foldstart) . ' ' - endif - return foldtext() -endfunction - -function! DebControlFold(l) - - " This is for not merging blank lines around folds to them - if getline(a:l) =~ '^Source:' - return '>1' - endif - - if getline(a:l) =~ '^Package:' - return '>1' - endif - - return '=' -endfunction - -" }}}1 diff --git a/share/vim/vim72/ftplugin/dosbatch.vim b/share/vim/vim72/ftplugin/dosbatch.vim deleted file mode 100644 index 91d57d9bab..0000000000 --- a/share/vim/vim72/ftplugin/dosbatch.vim +++ /dev/null @@ -1,21 +0,0 @@ -" Vim filetype plugin file -" Language: MS-DOS .bat files -" Maintainer: Mike Williams <mrw@eandem.co.uk> -" Last Change: 5th February 2003 - -" Only do this when not done yet for this buffer -if exists("b:did_ftplugin") - finish -endif - -" Don't load another plugin for this buffer -let b:did_ftplugin = 1 - -" BAT comment formatting -setlocal comments=b:rem,b:@rem,b:REM,b:@REM,b::: -setlocal formatoptions-=t formatoptions+=rol - -" Define patterns for the browse file filter -if has("gui_win32") && !exists("b:browsefilter") - let b:browsefilter = "DOS Batch Files (*.bat, *.btm, *.cmd)\t*.bat;*.btm;*.cmd\nAll Files (*.*)\t*.*\n" -endif diff --git a/share/vim/vim72/ftplugin/dtd.vim b/share/vim/vim72/ftplugin/dtd.vim deleted file mode 100644 index 3b15bda3c4..0000000000 --- a/share/vim/vim72/ftplugin/dtd.vim +++ /dev/null @@ -1,39 +0,0 @@ -" Vim filetype plugin file -" Language: dtd -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 30 Jun 2008 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif -let b:did_ftplugin = 1 - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -setlocal commentstring=<!--%s--> -setlocal comments=s:<!--,m:\ \ \ \ \ ,e:--> - -setlocal formatoptions-=t -if !exists("g:ft_dtd_autocomment") || (g:ft_dtd_autocomment == 1) - setlocal formatoptions+=croql -endif - -if exists("loaded_matchit") - let b:match_words = '<!--:-->,<!:>' -endif - -" Change the :browse e filter to primarily show Java-related files. -if has("gui_win32") - let b:browsefilter="DTD Files (*.dtd)\t*.dtd\n" . - \ "XML Files (*.xml)\t*.xml\n" . - \ "All Files (*.*)\t*.*\n" -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "setlocal commentstring< comments< formatoptions<" . - \ " | unlet! b:matchwords b:browsefilter" - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/eruby.vim b/share/vim/vim72/ftplugin/eruby.vim deleted file mode 100644 index 9e121c20ba..0000000000 --- a/share/vim/vim72/ftplugin/eruby.vim +++ /dev/null @@ -1,101 +0,0 @@ -" Vim filetype plugin -" Language: eRuby -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> -" Info: $Id: eruby.vim,v 1.12 2008/06/29 04:18:43 tpope Exp $ -" URL: http://vim-ruby.rubyforge.org -" Anon CVS: See above site -" Release Coordinator: Doug Kearns <dougkearns@gmail.com> - -" Only do this when not done yet for this buffer -if exists("b:did_ftplugin") - finish -endif - -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "All Files (*.*)\t*.*\n" -let s:match_words = "" - -if !exists("g:eruby_default_subtype") - let g:eruby_default_subtype = "html" -endif - -if !exists("b:eruby_subtype") - let s:lines = getline(1)."\n".getline(2)."\n".getline(3)."\n".getline(4)."\n".getline(5)."\n".getline("$") - let b:eruby_subtype = matchstr(s:lines,'eruby_subtype=\zs\w\+') - if b:eruby_subtype == '' - let b:eruby_subtype = matchstr(substitute(expand("%:t"),'\c\%(\.erb\|\.eruby\)\+$','',''),'\.\zs\w\+$') - endif - if b:eruby_subtype == 'rhtml' - let b:eruby_subtype = 'html' - elseif b:eruby_subtype == 'rb' - let b:eruby_subtype = 'ruby' - elseif b:eruby_subtype == 'yml' - let b:eruby_subtype = 'yaml' - elseif b:eruby_subtype == 'js' - let b:eruby_subtype = 'javascript' - elseif b:eruby_subtype == 'txt' - " Conventional; not a real file type - let b:eruby_subtype = 'text' - elseif b:eruby_subtype == '' - let b:eruby_subtype = g:eruby_default_subtype - endif -endif - -if exists("b:eruby_subtype") && b:eruby_subtype != '' - exe "runtime! ftplugin/".b:eruby_subtype.".vim ftplugin/".b:eruby_subtype."_*.vim ftplugin/".b:eruby_subtype."/*.vim" -else - runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim -endif -unlet! b:did_ftplugin - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin - unlet b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter - unlet b:browsefilter -endif -if exists("b:match_words") - let s:match_words = b:match_words - unlet b:match_words -endif - -runtime! ftplugin/ruby.vim ftplugin/ruby_*.vim ftplugin/ruby/*.vim -let b:did_ftplugin = 1 - -" Combine the new set of values with those previously included. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin . " | " . s:undo_ftplugin -endif -if exists ("b:browsefilter") - let s:browsefilter = substitute(b:browsefilter,'\cAll Files (\*\.\*)\t\*\.\*\n','','') . s:browsefilter -endif -if exists("b:match_words") - let s:match_words = b:match_words . ',' . s:match_words -endif - -" Change the browse dialog on Win32 to show mainly eRuby-related files -if has("gui_win32") - let b:browsefilter="eRuby Files (*.erb, *.rhtml)\t*.erb;*.rhtml\n" . s:browsefilter -endif - -" Load the combined list of match_words for matchit.vim -if exists("loaded_matchit") - let b:match_words = s:match_words -endif - -" TODO: comments= -setlocal commentstring=<%#%s%> - -let b:undo_ftplugin = "setl cms< " - \ " | unlet! b:browsefilter b:match_words | " . s:undo_ftplugin - -let &cpo = s:save_cpo - -" vim: nowrap sw=2 sts=2 ts=8: diff --git a/share/vim/vim72/ftplugin/fortran.vim b/share/vim/vim72/ftplugin/fortran.vim deleted file mode 100644 index c817b3b787..0000000000 --- a/share/vim/vim72/ftplugin/fortran.vim +++ /dev/null @@ -1,117 +0,0 @@ -" Vim settings file -" Language: Fortran90 (and Fortran95, Fortran77, F and elf90) -" Version: 0.45 -" Last Change: 2006 Apr. 03 -" URL: http://www.unb.ca/chem/ajit/ftplugin/fortran.vim -" Maintainer: Ajit J. Thakkar <ajit@unb.ca>; <http://www.unb.ca/chem/ajit/> -" Usage: Do :help fortran-plugin from Vim -" Credits: Useful suggestions were made by Stefano Zacchiroli - -" Only do these settings when not done yet for this buffer -if exists("b:did_ftplugin") - finish -endif - -" Don't do other file type settings for this buffer -let b:did_ftplugin = 1 - -" Determine whether this is a fixed or free format source file -" if this hasn't been done yet -if !exists("b:fortran_fixed_source") - if exists("fortran_free_source") - " User guarantees free source form - let b:fortran_fixed_source = 0 - elseif exists("fortran_fixed_source") - " User guarantees fixed source form - let b:fortran_fixed_source = 1 - else - " f90 and f95 allow both fixed and free source form - " assume fixed source form unless signs of free source form - " are detected in the first five columns of the first 250 lines - " Detection becomes more accurate and time-consuming if more lines - " are checked. Increase the limit below if you keep lots of comments at - " the very top of each file and you have a fast computer - let s:lmax = 250 - if ( s:lmax > line("$") ) - let s:lmax = line("$") - endif - let b:fortran_fixed_source = 1 - let s:ln=1 - while s:ln <= s:lmax - let s:test = strpart(getline(s:ln),0,5) - if s:test[0] !~ '[Cc*!#]' && s:test !~ '^ \+[!#]' && s:test =~ '[^ 0-9\t]' - let b:fortran_fixed_source = 0 - break - endif - let s:ln = s:ln + 1 - endwhile - endif -endif - -" Set comments and textwidth according to source type -if (b:fortran_fixed_source == 1) - setlocal comments=:!,:*,:C - " Fixed format requires a textwidth of 72 for code - setlocal tw=72 - " If you need to add "&" on continued lines so that the code is - " compatible with both free and fixed format, then you should do so - " in column 73 and uncomment the next line - " setlocal tw=73 -else - setlocal comments=:! - " Free format allows a textwidth of 132 for code but 80 is more usual - setlocal tw=80 -endif - -" Set commentstring for foldmethod=marker -setlocal cms=!%s - -" Tabs are not a good idea in Fortran so the default is to expand tabs -if !exists("fortran_have_tabs") - setlocal expandtab -endif - -" Set 'formatoptions' to break comment and text lines but allow long lines -setlocal fo+=tcql - -setlocal include=^\\c#\\=\\s*include\\s\\+ -setlocal suffixesadd+=.f95,.f90,.for,.f,.F,.f77,.ftn,.fpp - -let s:cposet=&cpoptions -set cpoptions-=C - -" Define patterns for the matchit plugin -if !exists("b:match_words") - let s:notend = '\%(\<end\s\+\)\@<!' - let s:notselect = '\%(\<select\s\+\)\@<!' - let s:notelse = '\%(\<end\s\+\|\<else\s\+\)\@<!' - let s:notprocedure = '\%(\s\+procedure\>\)\@!' - let b:match_ignorecase = 1 - let b:match_words = - \ '\<select\s*case\>:' . s:notselect. '\<case\>:\<end\s*select\>,' . - \ s:notelse . '\<if\s*(.\+)\s*then\>:' . - \ '\<else\s*\%(if\s*(.\+)\s*then\)\=\>:\<end\s*if\>,'. - \ 'do\s\+\(\d\+\):\%(^\s*\)\@<=\1\s,'. - \ s:notend . '\<do\>:\<end\s*do\>,'. - \ s:notelse . '\<where\>:\<elsewhere\>:\<end\s*where\>,'. - \ s:notend . '\<type\s*[^(]:\<end\s*type\>,'. - \ s:notend . '\<interface\>:\<end\s*interface\>,'. - \ s:notend . '\<subroutine\>:\<end\s*subroutine\>,'. - \ s:notend . '\<function\>:\<end\s*function\>,'. - \ s:notend . '\<module\>' . s:notprocedure . ':\<end\s*module\>,'. - \ s:notend . '\<program\>:\<end\s*program\>' -endif - -" File filters for :browse e -if has("gui_win32") && !exists("b:browsefilter") - let b:browsefilter = "Fortran Files (*.f;*.F;*.for;*.f77;*.f90;*.f95;*.fpp;*.ftn)\t*.f;*.F;*.for;*.f77;*.f90;*.f95;*.fpp;*.ftn\n" . - \ "All Files (*.*)\t*.*\n" -endif - -let b:undo_ftplugin = "setl fo< com< tw< cms< et< inc<" - \ . "| unlet! b:match_ignorecase b:match_words b:browsefilter" - -let &cpoptions=s:cposet -unlet s:cposet - -" vim:sw=2 diff --git a/share/vim/vim72/ftplugin/git.vim b/share/vim/vim72/ftplugin/git.vim deleted file mode 100644 index 9ac1aa1517..0000000000 --- a/share/vim/vim72/ftplugin/git.vim +++ /dev/null @@ -1,34 +0,0 @@ -" Vim filetype plugin -" Language: generic git output -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> -" Last Change: 2008 Jul 30 - -" Only do this when not done yet for this buffer -if (exists("b:did_ftplugin")) - finish -endif -let b:did_ftplugin = 1 - -if !exists('b:git_dir') - if expand('%:p') =~# '\.git\>' - let b:git_dir = matchstr(expand('%:p'),'.*\.git\>') - elseif $GIT_DIR != '' - let b:git_dir = $GIT_DIR - endif - if (has('win32') || has('win64')) && exists('b:git_dir') - let b:git_dir = substitute(b:git_dir,'\\','/','g') - endif -endif - -if exists('*shellescape') && exists('b:git_dir') && b:git_dir != '' - if b:git_dir =~# '/\.git$' " Not a bare repository - let &l:path = escape(fnamemodify(b:git_dir,':h'),'\, ').','.&l:path - endif - let &l:path = escape(b:git_dir,'\, ').','.&l:path - let &l:keywordprg = 'git --git-dir='.shellescape(b:git_dir).' show' -else - setlocal keywordprg=git\ show -endif - -setlocal includeexpr=substitute(v:fname,'^[^/]\\+/','','') -let b:undo_ftplugin = "setl keywordprg< path< includeexpr<" diff --git a/share/vim/vim72/ftplugin/gitcommit.vim b/share/vim/vim72/ftplugin/gitcommit.vim deleted file mode 100644 index bfc5b33f28..0000000000 --- a/share/vim/vim72/ftplugin/gitcommit.vim +++ /dev/null @@ -1,68 +0,0 @@ -" Vim filetype plugin -" Language: git config file -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> -" Last Change: 2008 Jun 04 - -" Only do this when not done yet for this buffer -if (exists("b:did_ftplugin")) - finish -endif - -runtime! ftplugin/git.vim -let b:did_ftplugin = 1 - -if &textwidth == 0 - " make sure that log messages play nice with git-log on standard terminals - setlocal textwidth=72 - if !exists("b:undo_ftplugin") - let b:undo_ftplugin = "" - endif - let b:undo_ftplugin = b:undo_ftplugin . "|setl tw<" -endif - -if exists("g:no_gitcommit_commands") || v:version < 700 - finish -endif - -if !exists("b:git_dir") - let b:git_dir = expand("%:p:h") -endif - -" Automatically diffing can be done with: -" autocmd FileType gitcommit DiffGitCached | wincmd p -command! -bang -bar -buffer -complete=custom,s:diffcomplete -nargs=* DiffGitCached :call s:gitdiffcached(<bang>0,b:git_dir,<f-args>) - -function! s:diffcomplete(A,L,P) - let args = "" - if a:P <= match(a:L." -- "," -- ")+3 - let args = args . "-p\n--stat\n--shortstat\n--summary\n--patch-with-stat\n--no-renames\n-B\n-M\n-C\n" - end - if exists("b:git_dir") && a:A !~ '^-' - let tree = fnamemodify(b:git_dir,':h') - if strpart(getcwd(),0,strlen(tree)) == tree - let args = args."\n".system("git diff --cached --name-only") - endif - endif - return args -endfunction - -function! s:gitdiffcached(bang,gitdir,...) - let tree = fnamemodify(a:gitdir,':h') - let name = tempname() - let git = "git" - if strpart(getcwd(),0,strlen(tree)) != tree - let git .= " --git-dir=".(exists("*shellescape") ? shellescape(a:gitdir) : '"'.a:gitdir.'"') - endif - if a:0 - let extra = join(map(copy(a:000),exists("*shellescape") ? 'shellescape(v:val)' : "'\"'.v:val.'\"'")) - else - let extra = "-p --stat=".&columns - endif - call system(git." diff --cached --no-color ".extra." > ".(exists("*shellescape") ? shellescape(name) : name)) - exe "pedit ".(exists("*fnameescape") ? fnameescape(name) : name) - wincmd P - let b:git_dir = a:gitdir - command! -bang -bar -buffer -complete=custom,s:diffcomplete -nargs=* DiffGitCached :call s:gitdiffcached(<bang>0,b:git_dir,<f-args>) - nnoremap <silent> q :q<CR> - setlocal buftype=nowrite nobuflisted noswapfile nomodifiable filetype=git -endfunction diff --git a/share/vim/vim72/ftplugin/gitconfig.vim b/share/vim/vim72/ftplugin/gitconfig.vim deleted file mode 100644 index ee33baff23..0000000000 --- a/share/vim/vim72/ftplugin/gitconfig.vim +++ /dev/null @@ -1,15 +0,0 @@ -" Vim filetype plugin -" Language: git config file -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> -" Last Change: 2007 Dec 16 - -" Only do this when not done yet for this buffer -if (exists("b:did_ftplugin")) - finish -endif -let b:did_ftplugin = 1 - -setlocal formatoptions-=t formatoptions+=croql -setlocal comments=:#,:; commentstring=;\ %s - -let b:undo_ftplugin = "setl fo< com< cms<" diff --git a/share/vim/vim72/ftplugin/gitrebase.vim b/share/vim/vim72/ftplugin/gitrebase.vim deleted file mode 100644 index 6e0e6c19c5..0000000000 --- a/share/vim/vim72/ftplugin/gitrebase.vim +++ /dev/null @@ -1,41 +0,0 @@ -" Vim filetype plugin -" Language: git rebase --interactive -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> -" Last Change: 2008 Apr 16 - -" Only do this when not done yet for this buffer -if (exists("b:did_ftplugin")) - finish -endif - -runtime! ftplugin/git.vim -let b:did_ftplugin = 1 - -setlocal comments=:# commentstring=#\ %s formatoptions-=t -if !exists("b:undo_ftplugin") - let b:undo_ftplugin = "" -endif -let b:undo_ftplugin = b:undo_ftplugin."|setl com< cms< fo<" - -function! s:choose(word) - s/^\(\w\+\>\)\=\(\s*\)\ze\x\{4,40\}\>/\=(strlen(submatch(1)) == 1 ? a:word[0] : a:word) . substitute(submatch(2),'^$',' ','')/e -endfunction - -function! s:cycle() - call s:choose(get({'s':'edit','p':'squash'},getline('.')[0],'pick')) -endfunction - -command! -buffer -bar Pick :call s:choose('pick') -command! -buffer -bar Squash :call s:choose('squash') -command! -buffer -bar Edit :call s:choose('edit') -command! -buffer -bar Cycle :call s:cycle() -" The above are more useful when they are mapped; for example: -"nnoremap <buffer> <silent> S :Cycle<CR> - -if exists("g:no_plugin_maps") || exists("g:no_gitrebase_maps") - finish -endif - -nnoremap <buffer> <expr> K col('.') < 7 && expand('<Lt>cword>') =~ '\X' && getline('.') =~ '^\w\+\s\+\x\+\>' ? 'wK' : 'K' - -let b:undo_ftplugin = b:undo_ftplugin . "|nunmap <buffer> K" diff --git a/share/vim/vim72/ftplugin/gitsendemail.vim b/share/vim/vim72/ftplugin/gitsendemail.vim deleted file mode 100644 index a83e48afff..0000000000 --- a/share/vim/vim72/ftplugin/gitsendemail.vim +++ /dev/null @@ -1,6 +0,0 @@ -" Vim filetype plugin -" Language: git send-email message -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> -" Last Change: 2007 Dec 16 - -runtime! ftplugin/mail.vim diff --git a/share/vim/vim72/ftplugin/haml.vim b/share/vim/vim72/ftplugin/haml.vim deleted file mode 100644 index 0a39d5ef3a..0000000000 --- a/share/vim/vim72/ftplugin/haml.vim +++ /dev/null @@ -1,66 +0,0 @@ -" Vim filetype plugin -" Language: Haml -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> - -" Only do this when not done yet for this buffer -if exists("b:did_ftplugin") - finish -endif - -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "All Files (*.*)\t*.*\n" -let s:match_words = "" - -runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim -unlet! b:did_ftplugin - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin - unlet b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter - unlet b:browsefilter -endif -if exists("b:match_words") - let s:match_words = b:match_words - unlet b:match_words -endif - -runtime! ftplugin/ruby.vim ftplugin/ruby_*.vim ftplugin/ruby/*.vim -let b:did_ftplugin = 1 - -" Combine the new set of values with those previously included. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin . " | " . s:undo_ftplugin -endif -if exists ("b:browsefilter") - let s:browsefilter = substitute(b:browsefilter,'\cAll Files (\*\.\*)\t\*\.\*\n','','') . s:browsefilter -endif -if exists("b:match_words") - let s:match_words = b:match_words . ',' . s:match_words -endif - -" Change the browse dialog on Win32 to show mainly Haml-related files -if has("gui_win32") - let b:browsefilter="Haml Files (*.haml)\t*.haml\nSass Files (*.sass)\t*.sass\n" . s:browsefilter -endif - -" Load the combined list of match_words for matchit.vim -if exists("loaded_matchit") - let b:match_words = s:match_words -endif - -setlocal commentstring=-#\ %s - -let b:undo_ftplugin = "setl cms< com< " - \ " | unlet! b:browsefilter b:match_words | " . s:undo_ftplugin - -let &cpo = s:save_cpo - -" vim:set sw=2: diff --git a/share/vim/vim72/ftplugin/help.vim b/share/vim/vim72/ftplugin/help.vim deleted file mode 100644 index 5c6dac8210..0000000000 --- a/share/vim/vim72/ftplugin/help.vim +++ /dev/null @@ -1,19 +0,0 @@ -" Vim filetype plugin file -" Language: Vim help file -" Maintainer: Nikolai Weibull <now@bitwi.se> -" Latest Revision: 2008-07-09 - -if exists("b:did_ftplugin") - finish -endif -let b:did_ftplugin = 1 - -let s:cpo_save = &cpo -set cpo&vim - -let b:undo_ftplugin = "setl fo< tw<" - -setlocal formatoptions+=tcroql textwidth=78 - -let &cpo = s:cpo_save -unlet s:cpo_save diff --git a/share/vim/vim72/ftplugin/html.vim b/share/vim/vim72/ftplugin/html.vim deleted file mode 100644 index 6c8607d92b..0000000000 --- a/share/vim/vim72/ftplugin/html.vim +++ /dev/null @@ -1,90 +0,0 @@ -" Vim filetype plugin file -" Language: html -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2007 Nov 20 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif -let b:did_ftplugin = 1 - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -setlocal matchpairs+=<:> -setlocal commentstring=<!--%s--> -setlocal comments=s:<!--,m:\ \ \ \ ,e:--> - -if exists("g:ft_html_autocomment") && (g:ft_html_autocomment == 1) - setlocal formatoptions-=t formatoptions+=croql -endif - - -if exists('&omnifunc') - " Distinguish between HTML versions - " To use with other HTML versions add another - " elseif condition to match proper DOCTYPE - setlocal omnifunc=htmlcomplete#CompleteTags - - if &filetype == 'xhtml' - let b:html_omni_flavor = 'xhtml10s' - else - let b:html_omni_flavor = 'html401t' - endif - let i = 1 - let line = "" - while i < 10 && i < line("$") - let line = getline(i) - if line =~ '<!DOCTYPE.*\<DTD ' - break - endif - let i += 1 - endwhile - if line =~ '<!DOCTYPE.*\<DTD ' " doctype line found above - if line =~ ' HTML 3\.2' - let b:html_omni_flavor = 'html32' - elseif line =~ ' XHTML 1\.1' - let b:html_omni_flavor = 'xhtml11' - else " two-step detection with strict/frameset/transitional - if line =~ ' XHTML 1\.0' - let b:html_omni_flavor = 'xhtml10' - elseif line =~ ' HTML 4\.01' - let b:html_omni_flavor = 'html401' - elseif line =~ ' HTML 4.0\>' - let b:html_omni_flavor = 'html40' - endif - if line =~ '\<Transitional\>' - let b:html_omni_flavor .= 't' - elseif line =~ '\<Frameset\>' - let b:html_omni_flavor .= 'f' - else - let b:html_omni_flavor .= 's' - endif - endif - endif -endif - -" HTML: thanks to Johannes Zellner and Benji Fisher. -if exists("loaded_matchit") - let b:match_ignorecase = 1 - let b:match_words = '<:>,' . - \ '<\@<=[ou]l\>[^>]*\%(>\|$\):<\@<=li\>:<\@<=/[ou]l>,' . - \ '<\@<=dl\>[^>]*\%(>\|$\):<\@<=d[td]\>:<\@<=/dl>,' . - \ '<\@<=\([^/][^ \t>]*\)[^>]*\%(>\|$\):<\@<=/\1>' -endif - -" Change the :browse e filter to primarily show HTML-related files. -if has("gui_win32") - let b:browsefilter="HTML Files (*.html,*.htm)\t*.htm;*.html\n" . - \ "JavaScript Files (*.js)\t*.js\n" . - \ "Cascading StyleSheets (*.css)\t*.css\n" . - \ "All Files (*.*)\t*.*\n" -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "setlocal commentstring< matchpairs< omnifunc< comments< formatoptions<" . - \ " | unlet! b:match_ignorecase b:match_skip b:match_words b:browsefilter" - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/java.vim b/share/vim/vim72/ftplugin/java.vim deleted file mode 100644 index 96e62c692a..0000000000 --- a/share/vim/vim72/ftplugin/java.vim +++ /dev/null @@ -1,50 +0,0 @@ -" Vim filetype plugin file -" Language: Java -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Change: 2005 Mar 28 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif -let b:did_ftplugin = 1 - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -" For filename completion, prefer the .java extension over the .class -" extension. -set suffixes+=.class - -" Enable gf on import statements. Convert . in the package -" name to / and append .java to the name, then search the path. -setlocal includeexpr=substitute(v:fname,'\\.','/','g') -setlocal suffixesadd=.java -if exists("g:ftplugin_java_source_path") - let &l:path=g:ftplugin_java_source_path . ',' . &l:path -endif - -" Set 'formatoptions' to break comment lines but not other lines, -" and insert the comment leader when hitting <CR> or using "o". -setlocal formatoptions-=t formatoptions+=croql - -" Set 'comments' to format dashed lists in comments. Behaves just like C. -setlocal comments& comments^=sO:*\ -,mO:*\ \ ,exO:*/ - -setlocal commentstring=//%s - -" Change the :browse e filter to primarily show Java-related files. -if has("gui_win32") - let b:browsefilter="Java Files (*.java)\t*.java\n" . - \ "Properties Files (*.prop*)\t*.prop*\n" . - \ "Manifest Files (*.mf)\t*.mf\n" . - \ "All Files (*.*)\t*.*\n" -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "setlocal suffixes< suffixesadd<" . - \ " formatoptions< comments< commentstring< path< includeexpr<" . - \ " | unlet! b:browsefilter" - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/jsp.vim b/share/vim/vim72/ftplugin/jsp.vim deleted file mode 100644 index 4987cc5c5d..0000000000 --- a/share/vim/vim72/ftplugin/jsp.vim +++ /dev/null @@ -1,66 +0,0 @@ -" Vim filetype plugin file -" Language: jsp -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2005 Oct 10 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "Java Files (*.java)\t*.java\n" . - \ "HTML Files (*.html, *.htm)\t*.html;*.htm\n" . - \ "All Files (*.*)\t*.*\n" -let s:match_words = "" - -runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim -unlet b:did_ftplugin - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin - unlet b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter - unlet b:browsefilter -endif -if exists("b:match_words") - let s:match_words = b:match_words - unlet b:match_words -endif - -runtime! ftplugin/java.vim ftplugin/java_*.vim ftplugin/java/*.vim -let b:did_ftplugin = 1 - -" Combine the new set of values with those previously included. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin . " | " . s:undo_ftplugin -endif -if exists ("b:browsefilter") - let s:browsefilter = b:browsefilter . s:browsefilter -endif -if exists("b:match_words") - let s:match_words = b:match_words . ',' . s:match_words -endif - -" Load the combined list of match_words for matchit.vim -if exists("loaded_matchit") - let b:match_words = s:match_words -endif - -" Change the :browse e filter to primarily show JSP-related files. -if has("gui_win32") - let b:browsefilter="JSP Files (*.jsp)\t*.jsp\n" . s:browsefilter -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "unlet! b:browsefilter b:match_words | " . s:undo_ftplugin - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/mail.vim b/share/vim/vim72/ftplugin/mail.vim deleted file mode 100644 index 34e1d3c22f..0000000000 --- a/share/vim/vim72/ftplugin/mail.vim +++ /dev/null @@ -1,35 +0,0 @@ -" Vim filetype plugin file -" Language: Mail -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2007 Apr 30 - -" Only do this when not done yet for this buffer -if exists("b:did_ftplugin") - finish -endif -let b:did_ftplugin = 1 - -let b:undo_ftplugin = "setl modeline< tw< fo<" - -" Don't use modelines in e-mail messages, avoid trojan horses and nasty -" "jokes" (e.g., setting 'textwidth' to 5). -setlocal nomodeline - -" many people recommend keeping e-mail messages 72 chars wide -if &tw == 0 - setlocal tw=72 -endif - -" Set 'formatoptions' to break text lines and keep the comment leader ">". -setlocal fo+=tcql - -" Add mappings, unless the user didn't want this. -if !exists("no_plugin_maps") && !exists("no_mail_maps") - " Quote text by inserting "> " - if !hasmapto('<Plug>MailQuote') - vmap <buffer> <LocalLeader>q <Plug>MailQuote - nmap <buffer> <LocalLeader>q <Plug>MailQuote - endif - vnoremap <buffer> <Plug>MailQuote :s/^/> /<CR>:noh<CR>`` - nnoremap <buffer> <Plug>MailQuote :.,$s/^/> /<CR>:noh<CR>`` -endif diff --git a/share/vim/vim72/ftplugin/man.vim b/share/vim/vim72/ftplugin/man.vim deleted file mode 100644 index a58d2977a9..0000000000 --- a/share/vim/vim72/ftplugin/man.vim +++ /dev/null @@ -1,181 +0,0 @@ -" Vim filetype plugin file -" Language: man -" Maintainer: Nam SungHyun <namsh@kldp.org> -" Last Change: 2007 Nov 30 - -" To make the ":Man" command available before editing a manual page, source -" this script from your startup vimrc file. - -" If 'filetype' isn't "man", we must have been called to only define ":Man". -if &filetype == "man" - - " Only do this when not done yet for this buffer - if exists("b:did_ftplugin") - finish - endif - let b:did_ftplugin = 1 - - " allow dot and dash in manual page name. - setlocal iskeyword+=\.,- - - " Add mappings, unless the user didn't want this. - if !exists("no_plugin_maps") && !exists("no_man_maps") - if !hasmapto('<Plug>ManBS') - nmap <buffer> <LocalLeader>h <Plug>ManBS - endif - nnoremap <buffer> <Plug>ManBS :%s/.\b//g<CR>:setl nomod<CR>'' - - nnoremap <buffer> <c-]> :call <SID>PreGetPage(v:count)<CR> - nnoremap <buffer> <c-t> :call <SID>PopPage()<CR> - endif - -endif - -if exists(":Man") != 2 - com -nargs=+ Man call s:GetPage(<f-args>) - nmap <Leader>K :call <SID>PreGetPage(0)<CR> -endif - -" Define functions only once. -if !exists("s:man_tag_depth") - -let s:man_tag_depth = 0 - -let s:man_sect_arg = "" -let s:man_find_arg = "-w" -try - if !has("win32") && $OSTYPE !~ 'cygwin\|linux' && system('uname -s') =~ "SunOS" && system('uname -r') =~ "^5" - let s:man_sect_arg = "-s" - let s:man_find_arg = "-l" - endif -catch /E145:/ - " Ignore the error in restricted mode -endtry - -func <SID>PreGetPage(cnt) - if a:cnt == 0 - let old_isk = &iskeyword - setl iskeyword+=(,) - let str = expand("<cword>") - let &l:iskeyword = old_isk - let page = substitute(str, '(*\(\k\+\).*', '\1', '') - let sect = substitute(str, '\(\k\+\)(\([^()]*\)).*', '\2', '') - if match(sect, '^[0-9 ]\+$') == -1 - let sect = "" - endif - if sect == page - let sect = "" - endif - else - let sect = a:cnt - let page = expand("<cword>") - endif - call s:GetPage(sect, page) -endfunc - -func <SID>GetCmdArg(sect, page) - if a:sect == '' - return a:page - endif - return s:man_sect_arg.' '.a:sect.' '.a:page -endfunc - -func <SID>FindPage(sect, page) - let where = system("/usr/bin/man ".s:man_find_arg.' '.s:GetCmdArg(a:sect, a:page)) - if where !~ "^/" - if matchstr(where, " [^ ]*$") !~ "^ /" - return 0 - endif - endif - return 1 -endfunc - -func <SID>GetPage(...) - if a:0 >= 2 - let sect = a:1 - let page = a:2 - elseif a:0 >= 1 - let sect = "" - let page = a:1 - else - return - endif - - " To support: nmap K :Man <cword> - if page == '<cword>' - let page = expand('<cword>') - endif - - if sect != "" && s:FindPage(sect, page) == 0 - let sect = "" - endif - if s:FindPage(sect, page) == 0 - echo "\nCannot find a '".page."'." - return - endif - exec "let s:man_tag_buf_".s:man_tag_depth." = ".bufnr("%") - exec "let s:man_tag_lin_".s:man_tag_depth." = ".line(".") - exec "let s:man_tag_col_".s:man_tag_depth." = ".col(".") - let s:man_tag_depth = s:man_tag_depth + 1 - - " Use an existing "man" window if it exists, otherwise open a new one. - if &filetype != "man" - let thiswin = winnr() - exe "norm! \<C-W>b" - if winnr() > 1 - exe "norm! " . thiswin . "\<C-W>w" - while 1 - if &filetype == "man" - break - endif - exe "norm! \<C-W>w" - if thiswin == winnr() - break - endif - endwhile - endif - if &filetype != "man" - new - setl nonu fdc=0 - endif - endif - silent exec "edit $HOME/".page.".".sect."~" - " Avoid warning for editing the dummy file twice - setl buftype=nofile noswapfile - - setl ma - silent exec "norm 1GdG" - let $MANWIDTH = winwidth(0) - silent exec "r!/usr/bin/man ".s:GetCmdArg(sect, page)." | col -b" - " Remove blank lines from top and bottom. - while getline(1) =~ '^\s*$' - silent norm ggdd - endwhile - while getline('$') =~ '^\s*$' - silent norm Gdd - endwhile - 1 - setl ft=man nomod - setl bufhidden=hide - setl nobuflisted -endfunc - -func <SID>PopPage() - if s:man_tag_depth > 0 - let s:man_tag_depth = s:man_tag_depth - 1 - exec "let s:man_tag_buf=s:man_tag_buf_".s:man_tag_depth - exec "let s:man_tag_lin=s:man_tag_lin_".s:man_tag_depth - exec "let s:man_tag_col=s:man_tag_col_".s:man_tag_depth - exec s:man_tag_buf."b" - exec s:man_tag_lin - exec "norm ".s:man_tag_col."|" - exec "unlet s:man_tag_buf_".s:man_tag_depth - exec "unlet s:man_tag_lin_".s:man_tag_depth - exec "unlet s:man_tag_col_".s:man_tag_depth - unlet s:man_tag_buf s:man_tag_lin s:man_tag_col - endif -endfunc - -endif - -" vim: set sw=2: diff --git a/share/vim/vim72/ftplugin/mupad.vim b/share/vim/vim72/ftplugin/mupad.vim deleted file mode 100644 index ef3a4fe28f..0000000000 --- a/share/vim/vim72/ftplugin/mupad.vim +++ /dev/null @@ -1,30 +0,0 @@ -" Vim filetype plugin file -" Language: MuPAD source files -" Maintainer: Dave Silvia <dsilvia@mchsi.com> -" Filenames: *.mu -" Date: 6/30/2004 - -if exists("b:did_ftplugin") | finish | endif -let b:did_ftplugin = 1 - -" Change the :browse e filter to primarily show MuPAD source files. -if has("gui_win32") - let b:browsefilter= - \ "MuPAD source (*.mu)\t*.mu\n" . - \ "All Files (*.*)\t*.*\n" -endif - -" matchit.vim not loaded -- don't do anyting below -if !exists("loaded_matchit") - " echomsg "matchit.vim not loaded -- finishing" - finish -endif - -" source the AppendMatchGroup function file -runtime ftplugin/AppendMatchGroup.vim - -" fill b:match_words for MuPAD -call AppendMatchGroup('domain,end_domain') -call AppendMatchGroup('proc,begin,end_proc') -call AppendMatchGroup('if,then,elif,else,end_if') -call AppendMatchGroup('\%(for\|while\|repeat\|case\),of,do,break,next,until,\%(end_for\|end_while\|end_repeat\|end_case\)') diff --git a/share/vim/vim72/ftplugin/ocaml.vim b/share/vim/vim72/ftplugin/ocaml.vim deleted file mode 100644 index 7acf493280..0000000000 --- a/share/vim/vim72/ftplugin/ocaml.vim +++ /dev/null @@ -1,591 +0,0 @@ -" Language: OCaml -" Maintainer: David Baelde <firstname.name@ens-lyon.org> -" Mike Leary <leary@nwlink.com> -" Markus Mottl <markus.mottl@gmail.com> -" Stefano Zacchiroli <zack@bononia.it> -" Vincent Aravantinos <firstname.name@imag.fr> -" URL: http://www.ocaml.info/vim/ftplugin/ocaml.vim -" Last Change: 2008 Jul 17 - Bugfix related to fnameescape (VA) -" 2007 Sep 09 - Added .annot support for ocamlbuild, python not -" needed anymore (VA) -" 2006 May 01 - Added .annot support for file.whateverext (SZ) -" 2006 Apr 11 - Fixed an initialization bug; fixed ASS abbrev (MM) -" 2005 Oct 13 - removed GPL; better matchit support (MM, SZ) -" -if exists("b:did_ftplugin") - finish -endif -let b:did_ftplugin=1 - -" some macro -if exists('*fnameescape') - function! s:Fnameescape(s) - return fnameescape(a:s) - endfun -else - function! s:Fnameescape(s) - return escape(a:s," \t\n*?[{`$\\%#'\"|!<") - endfun -endif - -" Error handling -- helps moving where the compiler wants you to go -let s:cposet=&cpoptions -set cpo-=C -setlocal efm= - \%EFile\ \"%f\"\\,\ line\ %l\\,\ characters\ %c-%*\\d:, - \%EFile\ \"%f\"\\,\ line\ %l\\,\ character\ %c:%m, - \%+EReference\ to\ unbound\ regexp\ name\ %m, - \%Eocamlyacc:\ e\ -\ line\ %l\ of\ \"%f\"\\,\ %m, - \%Wocamlyacc:\ w\ -\ %m, - \%-Zmake%.%#, - \%C%m, - \%D%*\\a[%*\\d]:\ Entering\ directory\ `%f', - \%X%*\\a[%*\\d]:\ Leaving\ directory\ `%f', - \%D%*\\a:\ Entering\ directory\ `%f', - \%X%*\\a:\ Leaving\ directory\ `%f', - \%DMaking\ %*\\a\ in\ %f - -" Add mappings, unless the user didn't want this. -if !exists("no_plugin_maps") && !exists("no_ocaml_maps") - " (un)commenting - if !hasmapto('<Plug>Comment') - nmap <buffer> <LocalLeader>c <Plug>LUncomOn - vmap <buffer> <LocalLeader>c <Plug>BUncomOn - nmap <buffer> <LocalLeader>C <Plug>LUncomOff - vmap <buffer> <LocalLeader>C <Plug>BUncomOff - endif - - nnoremap <buffer> <Plug>LUncomOn mz0i(* <ESC>$A *)<ESC>`z - nnoremap <buffer> <Plug>LUncomOff :s/^(\* \(.*\) \*)/\1/<CR>:noh<CR> - vnoremap <buffer> <Plug>BUncomOn <ESC>:'<,'><CR>`<O<ESC>0i(*<ESC>`>o<ESC>0i*)<ESC>`< - vnoremap <buffer> <Plug>BUncomOff <ESC>:'<,'><CR>`<dd`>dd`< - - if !hasmapto('<Plug>Abbrev') - iabbrev <buffer> ASS (assert (0=1) (* XXX *)) - endif -endif - -" Let % jump between structure elements (due to Issac Trotts) -let b:mw = '' -let b:mw = b:mw . ',\<let\>:\<and\>:\(\<in\>\|;;\)' -let b:mw = b:mw . ',\<if\>:\<then\>:\<else\>' -let b:mw = b:mw . ',\<\(for\|while\)\>:\<do\>:\<done\>,' -let b:mw = b:mw . ',\<\(object\|sig\|struct\|begin\)\>:\<end\>' -let b:mw = b:mw . ',\<\(match\|try\)\>:\<with\>' -let b:match_words = b:mw - -let b:match_ignorecase=0 - -" switching between interfaces (.mli) and implementations (.ml) -if !exists("g:did_ocaml_switch") - let g:did_ocaml_switch = 1 - map <LocalLeader>s :call OCaml_switch(0)<CR> - map <LocalLeader>S :call OCaml_switch(1)<CR> - fun OCaml_switch(newwin) - if (match(bufname(""), "\\.mli$") >= 0) - let fname = s:Fnameescape(substitute(bufname(""), "\\.mli$", ".ml", "")) - if (a:newwin == 1) - exec "new " . fname - else - exec "arge " . fname - endif - elseif (match(bufname(""), "\\.ml$") >= 0) - let fname = s:Fnameescape(bufname("")) . "i" - if (a:newwin == 1) - exec "new " . fname - else - exec "arge " . fname - endif - endif - endfun -endif - -" Folding support - -" Get the modeline because folding depends on indentation -let s:s = line2byte(line('.'))+col('.')-1 -if search('^\s*(\*:o\?caml:') - let s:modeline = getline(".") -else - let s:modeline = "" -endif -if s:s > 0 - exe 'goto' s:s -endif - -" Get the indentation params -let s:m = matchstr(s:modeline,'default\s*=\s*\d\+') -if s:m != "" - let s:idef = matchstr(s:m,'\d\+') -elseif exists("g:omlet_indent") - let s:idef = g:omlet_indent -else - let s:idef = 2 -endif -let s:m = matchstr(s:modeline,'struct\s*=\s*\d\+') -if s:m != "" - let s:i = matchstr(s:m,'\d\+') -elseif exists("g:omlet_indent_struct") - let s:i = g:omlet_indent_struct -else - let s:i = s:idef -endif - -" Set the folding method -if exists("g:ocaml_folding") - setlocal foldmethod=expr - setlocal foldexpr=OMLetFoldLevel(v:lnum) -endif - -" - Only definitions below, executed once ------------------------------------- - -if exists("*OMLetFoldLevel") - finish -endif - -function s:topindent(lnum) - let l = a:lnum - while l > 0 - if getline(l) =~ '\s*\%(\<struct\>\|\<sig\>\|\<object\>\)' - return indent(l) - endif - let l = l-1 - endwhile - return -s:i -endfunction - -function OMLetFoldLevel(l) - - " This is for not merging blank lines around folds to them - if getline(a:l) !~ '\S' - return -1 - endif - - " We start folds for modules, classes, and every toplevel definition - if getline(a:l) =~ '^\s*\%(\<val\>\|\<module\>\|\<class\>\|\<type\>\|\<method\>\|\<initializer\>\|\<inherit\>\|\<exception\>\|\<external\>\)' - exe 'return ">' (indent(a:l)/s:i)+1 '"' - endif - - " Toplevel let are detected thanks to the indentation - if getline(a:l) =~ '^\s*let\>' && indent(a:l) == s:i+s:topindent(a:l) - exe 'return ">' (indent(a:l)/s:i)+1 '"' - endif - - " We close fold on end which are associated to struct, sig or object. - " We use syntax information to do that. - if getline(a:l) =~ '^\s*end\>' && synIDattr(synID(a:l, indent(a:l)+1, 0), "name") != "ocamlKeyword" - return (indent(a:l)/s:i)+1 - endif - - " Folds end on ;; - if getline(a:l) =~ '^\s*;;' - exe 'return "<' (indent(a:l)/s:i)+1 '"' - endif - - " Comments around folds aren't merged to them. - if synIDattr(synID(a:l, indent(a:l)+1, 0), "name") == "ocamlComment" - return -1 - endif - - return '=' -endfunction - -" Vim support for OCaml .annot files -" -" Last Change: 2007 Jul 17 -" Maintainer: Vincent Aravantinos <vincent.aravantinos@gmail.com> -" License: public domain -" -" Originally inspired by 'ocaml-dtypes.vim' by Stefano Zacchiroli. -" The source code is quite radically different for we not use python anymore. -" However this plugin should have the exact same behaviour, that's why the -" following lines are the quite exact copy of Stefano's original plugin : -" -" << -" Executing Ocaml_print_type(<mode>) function will display in the Vim bottom -" line(s) the type of an ocaml value getting it from the corresponding .annot -" file (if any). If Vim is in visual mode, <mode> should be "visual" and the -" selected ocaml value correspond to the highlighted text, otherwise (<mode> -" can be anything else) it corresponds to the literal found at the current -" cursor position. -" -" Typing '<LocalLeader>t' (LocalLeader defaults to '\', see :h LocalLeader) -" will cause " Ocaml_print_type function to be invoked with the right -" argument depending on the current mode (visual or not). -" >> -" -" If you find something not matching this behaviour, please signal it. -" -" Differences are: -" - no need for python support -" + plus : more portable -" + minus: no more lazy parsing, it looks very fast however -" -" - ocamlbuild support, ie. -" + the plugin finds the _build directory and looks for the -" corresponding file inside; -" + if the user decides to change the name of the _build directory thanks -" to the '-build-dir' option of ocamlbuild, the plugin will manage in -" most cases to find it out (most cases = if the source file has a unique -" name among your whole project); -" + if ocamlbuild is not used, the usual behaviour holds; ie. the .annot -" file should be in the same directory as the source file; -" + for vim plugin programmers: -" the variable 'b:_build_dir' contains the inferred path to the build -" directory, even if this one is not named '_build'. -" -" Bonus : -" - latin1 accents are handled -" - lists are handled, even on multiple lines, you don't need the visual mode -" (the cursor must be on the first bracket) -" - parenthesized expressions, arrays, and structures (ie. '(...)', '[|...|]', -" and '{...}') are handled the same way - - " Copied from Stefano's original plugin : - " << - " .annot ocaml file representation - " - " File format (copied verbatim from caml-types.el) - " - " file ::= block * - " block ::= position <SP> position <LF> annotation * - " position ::= filename <SP> num <SP> num <SP> num - " annotation ::= keyword open-paren <LF> <SP> <SP> data <LF> close-paren - " - " <SP> is a space character (ASCII 0x20) - " <LF> is a line-feed character (ASCII 0x0A) - " num is a sequence of decimal digits - " filename is a string with the lexical conventions of O'Caml - " open-paren is an open parenthesis (ASCII 0x28) - " close-paren is a closed parenthesis (ASCII 0x29) - " data is any sequence of characters where <LF> is always followed by - " at least two space characters. - " - " - in each block, the two positions are respectively the start and the - " end of the range described by the block. - " - in a position, the filename is the name of the file, the first num - " is the line number, the second num is the offset of the beginning - " of the line, the third num is the offset of the position itself. - " - the char number within the line is the difference between the third - " and second nums. - " - " For the moment, the only possible keyword is \"type\"." - " >> - - -" 1. Finding the annotation file even if we use ocamlbuild - - " In: two strings representing paths - " Out: one string representing the common prefix between the two paths - function! s:Find_common_path (p1,p2) - let temp = a:p2 - while matchstr(a:p1,temp) == '' - let temp = substitute(temp,'/[^/]*$','','') - endwhile - return temp - endfun - - " After call: - " - b:annot_file_path : - " path to the .annot file corresponding to the - " source file (dealing with ocamlbuild stuff) - " - b:_build_path: - " path to the build directory even if this one is - " not named '_build' - " - b:source_file_relative_path : - " relative path of the source file *in* the build - " directory ; this is how it is reffered to in the - " .annot file - function! s:Locate_annotation() - if !b:annotation_file_located - - silent exe 'cd' s:Fnameescape(expand('%:p:h')) - - let annot_file_name = s:Fnameescape(expand('%:r')).'.annot' - - " 1st case : the annot file is in the same directory as the buffer (no ocamlbuild) - let b:annot_file_path = findfile(annot_file_name,'.') - if b:annot_file_path != '' - let b:annot_file_path = getcwd().'/'.b:annot_file_path - let b:_build_path = '' - let b:source_file_relative_path = s:Fnameescape(expand('%')) - else - " 2nd case : the buffer and the _build directory are in the same directory - " .. - " / \ - " / \ - " _build .ml - " - let b:_build_path = finddir('_build','.') - if b:_build_path != '' - let b:_build_path = getcwd().'/'.b:_build_path - let b:annot_file_path = findfile(annot_file_name,'_build') - if b:annot_file_path != '' - let b:annot_file_path = getcwd().'/'.b:annot_file_path - endif - let b:source_file_relative_path = s:Fnameescape(expand('%')) - else - " 3rd case : the _build directory is in a directory higher in the file hierarchy - " (it can't be deeper by ocamlbuild requirements) - " .. - " / \ - " / \ - " _build ... - " \ - " \ - " .ml - " - let b:_build_path = finddir('_build',';') - if b:_build_path != '' - let project_path = substitute(b:_build_path,'/_build$','','') - let path_relative_to_project = s:Fnameescape(substitute(expand('%:p:h'),project_path.'/','','')) - let b:annot_file_path = findfile(annot_file_name,project_path.'/_build/'.path_relative_to_project) - let b:source_file_relative_path = s:Fnameescape(substitute(expand('%:p'),project_path.'/','','')) - else - let b:annot_file_path = findfile(annot_file_name,'**') - "4th case : what if the user decided to change the name of the _build directory ? - " -> we relax the constraints, it should work in most cases - if b:annot_file_path != '' - " 4a. we suppose the renamed _build directory is in the current directory - let b:_build_path = matchstr(b:annot_file_path,'^[^/]*') - if b:annot_file_path != '' - let b:annot_file_path = getcwd().'/'.b:annot_file_path - let b:_build_path = getcwd().'/'.b:_build_path - endif - let b:source_file_relative_path = s:Fnameescape(expand('%')) - else - " 4b. anarchy : the renamed _build directory may be higher in the hierarchy - " this will work if the file for which we are looking annotations has a unique name in the whole project - " if this is not the case, it may still work, but no warranty here - let b:annot_file_path = findfile(annot_file_name,'**;') - let project_path = s:Find_common_path(b:annot_file_path,expand('%:p:h')) - let b:_build_path = matchstr(b:annot_file_path,project_path.'/[^/]*') - let b:source_file_relative_path = substitute(expand('%:p'),project_path.'/','','') - endif - endif - endif - endif - - if b:annot_file_path == '' - throw 'E484: no annotation file found' - endif - - silent exe 'cd' '-' - - let b:annotation_file_located = 1 - endif - endfun - - " This in order to locate the .annot file only once - let b:annotation_file_located = 0 - -" 2. Finding the type information in the annotation file - - " a. The annotation file is opened in vim as a buffer that - " should be (almost) invisible to the user. - - " After call: - " The current buffer is now the one containing the .annot file. - " We manage to keep all this hidden to the user's eye. - function! s:Enter_annotation_buffer() - let s:current_pos = getpos('.') - let s:current_hidden = &l:hidden - set hidden - let s:current_buf = bufname('%') - if bufloaded(b:annot_file_path) - silent exe 'keepj keepalt' 'buffer' s:Fnameescape(b:annot_file_path) - else - silent exe 'keepj keepalt' 'view' s:Fnameescape(b:annot_file_path) - endif - endfun - - " After call: - " The original buffer has been restored in the exact same state as before. - function! s:Exit_annotation_buffer() - silent exe 'keepj keepalt' 'buffer' s:Fnameescape(s:current_buf) - let &l:hidden = s:current_hidden - call setpos('.',s:current_pos) - endfun - - " After call: - " The annot file is loaded and assigned to a buffer. - " This also handles the modification date of the .annot file, eg. after a - " compilation. - function! s:Load_annotation() - if bufloaded(b:annot_file_path) && b:annot_file_last_mod < getftime(b:annot_file_path) - call s:Enter_annotation_buffer() - silent exe "bunload" - call s:Exit_annotation_buffer() - endif - if !bufloaded(b:annot_file_path) - call s:Enter_annotation_buffer() - setlocal nobuflisted - setlocal bufhidden=hide - setlocal noswapfile - setlocal buftype=nowrite - call s:Exit_annotation_buffer() - let b:annot_file_last_mod = getftime(b:annot_file_path) - endif - endfun - - "b. 'search' and 'match' work to find the type information - - "In: - lin1,col1: postion of expression first char - " - lin2,col2: postion of expression last char - "Out: - the pattern to be looked for to find the block - " Must be called in the source buffer (use of line2byte) - function! s:Block_pattern(lin1,lin2,col1,col2) - let start_num1 = a:lin1 - let start_num2 = line2byte(a:lin1) - 1 - let start_num3 = start_num2 + a:col1 - let start_pos = '"'.b:source_file_relative_path.'" '.start_num1.' '.start_num2.' '.start_num3 - let end_num1 = a:lin2 - let end_num2 = line2byte(a:lin2) - 1 - let end_num3 = end_num2 + a:col2 - let end_pos = '"'.b:source_file_relative_path.'" '.end_num1.' '.end_num2.' '.end_num3 - return '^'.start_pos.' '.end_pos."$" - " rq: the '^' here is not totally correct regarding the annot file "grammar" - " but currently the annotation file respects this, and it's a little bit faster with the '^'; - " can be removed safely. - endfun - - "In: (the cursor position should be at the start of an annotation) - "Out: the type information - " Must be called in the annotation buffer (use of search) - function! s:Match_data() - " rq: idem as previously, in the following, the '^' at start of patterns is not necessary - keepj while search('^type($','ce',line(".")) == 0 - keepj if search('^.\{-}($','e') == 0 - throw "no_annotation" - endif - keepj if searchpair('(','',')') == 0 - throw "malformed_annot_file" - endif - endwhile - let begin = line(".") + 1 - keepj if searchpair('(','',')') == 0 - throw "malformed_annot_file" - endif - let end = line(".") - 1 - return join(getline(begin,end),"\n") - endfun - - "In: the pattern to look for in order to match the block - "Out: the type information (calls s:Match_data) - " Should be called in the annotation buffer - function! s:Extract_type_data(block_pattern) - call s:Enter_annotation_buffer() - try - if search(a:block_pattern,'e') == 0 - throw "no_annotation" - endif - call cursor(line(".") + 1,1) - let annotation = s:Match_data() - finally - call s:Exit_annotation_buffer() - endtry - return annotation - endfun - - "c. link this stuff with what the user wants - " ie. get the expression selected/under the cursor - - let s:ocaml_word_char = '\w|[À-ÿ]|''' - - "In: the current mode (eg. "visual", "normal", etc.) - "Out: the borders of the expression we are looking for the type - function! s:Match_borders(mode) - if a:mode == "visual" - let cur = getpos(".") - normal `< - let col1 = col(".") - let lin1 = line(".") - normal `> - let col2 = col(".") - let lin2 = line(".") - call cursor(cur[1],cur[2]) - return [lin1,lin2,col1-1,col2] - else - let cursor_line = line(".") - let cursor_col = col(".") - let line = getline('.') - if line[cursor_col-1:cursor_col] == '[|' - let [lin2,col2] = searchpairpos('\[|','','|\]','n') - return [cursor_line,lin2,cursor_col-1,col2+1] - elseif line[cursor_col-1] == '[' - let [lin2,col2] = searchpairpos('\[','','\]','n') - return [cursor_line,lin2,cursor_col-1,col2] - elseif line[cursor_col-1] == '(' - let [lin2,col2] = searchpairpos('(','',')','n') - return [cursor_line,lin2,cursor_col-1,col2] - elseif line[cursor_col-1] == '{' - let [lin2,col2] = searchpairpos('{','','}','n') - return [cursor_line,lin2,cursor_col-1,col2] - else - let [lin1,col1] = searchpos('\v%('.s:ocaml_word_char.'|\.)*','ncb') - let [lin2,col2] = searchpos('\v%('.s:ocaml_word_char.'|\.)*','nce') - if col1 == 0 || col2 == 0 - throw "no_expression" - endif - return [cursor_line,cursor_line,col1-1,col2] - endif - endif - endfun - - "In: the current mode (eg. "visual", "normal", etc.) - "Out: the type information (calls s:Extract_type_data) - function! s:Get_type(mode) - let [lin1,lin2,col1,col2] = s:Match_borders(a:mode) - return s:Extract_type_data(s:Block_pattern(lin1,lin2,col1,col2)) - endfun - - "d. main - "In: the current mode (eg. "visual", "normal", etc.) - "After call: the type information is displayed - if !exists("*Ocaml_get_type") - function Ocaml_get_type(mode) - call s:Locate_annotation() - call s:Load_annotation() - return s:Get_type(a:mode) - endfun - endif - - if !exists("*Ocaml_get_type_or_not") - function Ocaml_get_type_or_not(mode) - let t=reltime() - try - return Ocaml_get_type(a:mode) - catch - return "" - endtry - endfun - endif - - if !exists("*Ocaml_print_type") - function Ocaml_print_type(mode) - if expand("%:e") == "mli" - echohl ErrorMsg | echo "No annotations for interface (.mli) files" | echohl None - return - endif - try - echo Ocaml_get_type(a:mode) - catch /E484:/ - echohl ErrorMsg | echo "No type annotations (.annot) file found" | echohl None - catch /no_expression/ - echohl ErrorMsg | echo "No expression found under the cursor" | echohl None - catch /no_annotation/ - echohl ErrorMsg | echo "No type annotation found for the given text" | echohl None - catch /malformed_annot_file/ - echohl ErrorMsg | echo "Malformed .annot file" | echohl None - endtry - endfun - endif - -" Maps - map <silent> <LocalLeader>t :call Ocaml_print_type("normal")<CR> - vmap <silent> <LocalLeader>t :<C-U>call Ocaml_print_type("visual")<CR>`< - -let &cpoptions=s:cposet -unlet s:cposet - -" vim:sw=2 fdm=indent diff --git a/share/vim/vim72/ftplugin/pascal.vim b/share/vim/vim72/ftplugin/pascal.vim deleted file mode 100644 index c138dda9ca..0000000000 --- a/share/vim/vim72/ftplugin/pascal.vim +++ /dev/null @@ -1,15 +0,0 @@ -" Vim filetype plugin file -" Language: pascal -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2005 Sep 05 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif -let b:did_ftplugin = 1 - -if exists("loaded_matchit") - let b:match_words='\<\%(begin\|case\|try\)\>:\<end\>' -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "unlet! b:match_words" diff --git a/share/vim/vim72/ftplugin/perl.vim b/share/vim/vim72/ftplugin/perl.vim deleted file mode 100644 index 3771005644..0000000000 --- a/share/vim/vim72/ftplugin/perl.vim +++ /dev/null @@ -1,71 +0,0 @@ -" Vim filetype plugin file -" Language: Perl -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Change: 17 Jul 2008 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif -let b:did_ftplugin = 1 - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -setlocal formatoptions+=crq -setlocal keywordprg=perldoc\ -f - -setlocal comments=:# -setlocal commentstring=#%s - -" Change the browse dialog on Win32 to show mainly Perl-related files -if has("gui_win32") - let b:browsefilter = "Perl Source Files (*.pl)\t*.pl\n" . - \ "Perl Modules (*.pm)\t*.pm\n" . - \ "Perl Documentation Files (*.pod)\t*.pod\n" . - \ "All Files (*.*)\t*.*\n" -endif - -" Provided by Ned Konz <ned at bike-nomad dot com> -"--------------------------------------------- -setlocal include=\\<\\(use\\\|require\\)\\> -setlocal includeexpr=substitute(substitute(v:fname,'::','/','g'),'$','.pm','') -setlocal define=[^A-Za-z_] - -" The following line changes a global variable but is necessary to make -" gf and similar commands work. The change to iskeyword was incorrect. -" Thanks to Andrew Pimlott for pointing out the problem. If this causes a -" problem for you, add an after/ftplugin/perl.vim file that contains -" set isfname-=: -set isfname+=: -"setlocal iskeyword=48-57,_,A-Z,a-z,: - -" Set this once, globally. -if !exists("perlpath") - if executable("perl") - try - if &shellxquote != '"' - let perlpath = system('perl -e "print join(q/,/,@INC)"') - else - let perlpath = system("perl -e 'print join(q/,/,@INC)'") - endif - let perlpath = substitute(perlpath,',.$',',,','') - catch /E145:/ - let perlpath = ".,," - endtry - else - " If we can't call perl to get its path, just default to using the - " current directory and the directory of the current file. - let perlpath = ".,," - endif -endif - -let &l:path=perlpath -"--------------------------------------------- - -" Undo the stuff we changed. -let b:undo_ftplugin = "setlocal fo< com< cms< inc< inex< def< isf< kp<" . - \ " | unlet! b:browsefilter" - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/php.vim b/share/vim/vim72/ftplugin/php.vim deleted file mode 100644 index c9a0bc72fc..0000000000 --- a/share/vim/vim72/ftplugin/php.vim +++ /dev/null @@ -1,82 +0,0 @@ -" Vim filetype plugin file -" Language: php -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2007 Nov 10 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "HTML Files (*.html, *.htm)\t*.html;*.htm\n" . - \ "All Files (*.*)\t*.*\n" -let s:match_words = "" - -runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim -let b:did_ftplugin = 1 - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter -endif -if exists("b:match_words") - let s:match_words = b:match_words -endif -if exists("b:match_skip") - unlet b:match_skip -endif - -" Change the :browse e filter to primarily show PHP-related files. -if has("gui_win32") - let b:browsefilter="PHP Files (*.php)\t*.php\n" . s:browsefilter -endif - -" ### -" Provided by Mikolaj Machowski <mikmach at wp dot pl> -setlocal include=\\\(require\\\|include\\\)\\\(_once\\\)\\\? -" Disabled changing 'iskeyword', it breaks a command such as "*" -" setlocal iskeyword+=$ - -if exists("loaded_matchit") - let b:match_words = '<?php:?>,\<switch\>:\<endswitch\>,' . - \ '\<if\>:\<elseif\>:\<else\>:\<endif\>,' . - \ '\<while\>:\<endwhile\>,' . - \ '\<do\>:\<while\>,' . - \ '\<for\>:\<endfor\>,' . - \ '\<foreach\>:\<endforeach\>,' . - \ '(:),[:],{:},' . - \ s:match_words -endif -" ### - -if exists('&omnifunc') - setlocal omnifunc=phpcomplete#CompletePHP -endif - -" Section jumping: [[ and ]] provided by Antony Scriven <adscriven at gmail dot com> -let s:function = '\(abstract\s\+\|final\s\+\|private\s\+\|protected\s\+\|public\s\+\|static\s\+\)*function' -let s:class = '\(abstract\s\+\|final\s\+\)*class' -let s:interface = 'interface' -let s:section = '\(.*\%#\)\@!\_^\s*\zs\('.s:function.'\|'.s:class.'\|'.s:interface.'\)' -exe 'nno <buffer> <silent> [[ ?' . escape(s:section, '|') . '?<CR>:nohls<CR>' -exe 'nno <buffer> <silent> ]] /' . escape(s:section, '|') . '/<CR>:nohls<CR>' -exe 'ono <buffer> <silent> [[ ?' . escape(s:section, '|') . '?<CR>:nohls<CR>' -exe 'ono <buffer> <silent> ]] /' . escape(s:section, '|') . '/<CR>:nohls<CR>' - -setlocal commentstring=/*%s*/ - -" Undo the stuff we changed. -let b:undo_ftplugin = "setlocal commentstring< include< omnifunc<" . - \ " | unlet! b:browsefilter b:match_words | " . - \ s:undo_ftplugin - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/ruby.vim b/share/vim/vim72/ftplugin/ruby.vim deleted file mode 100644 index 7dfdfb5ad7..0000000000 --- a/share/vim/vim72/ftplugin/ruby.vim +++ /dev/null @@ -1,230 +0,0 @@ -" Vim filetype plugin -" Language: Ruby -" Maintainer: Gavin Sinclair <gsinclair at gmail.com> -" Info: $Id: ruby.vim,v 1.40 2008/06/29 04:18:43 tpope Exp $ -" URL: http://vim-ruby.rubyforge.org -" Anon CVS: See above site -" Release Coordinator: Doug Kearns <dougkearns@gmail.com> -" ---------------------------------------------------------------------------- -" -" Original matchit support thanks to Ned Konz. See his ftplugin/ruby.vim at -" http://bike-nomad.com/vim/ruby.vim. -" ---------------------------------------------------------------------------- - -" Only do this when not done yet for this buffer -if (exists("b:did_ftplugin")) - finish -endif -let b:did_ftplugin = 1 - -let s:cpo_save = &cpo -set cpo&vim - -if has("gui_running") && !has("gui_win32") - setlocal keywordprg=ri\ -T -else - setlocal keywordprg=ri -endif - -" Matchit support -if exists("loaded_matchit") && !exists("b:match_words") - let b:match_ignorecase = 0 - - let b:match_words = - \ '\<\%(if\|unless\|case\|while\|until\|for\|do\|class\|module\|def\|begin\)\>=\@!' . - \ ':' . - \ '\<\%(else\|elsif\|ensure\|when\|rescue\|break\|redo\|next\|retry\)\>' . - \ ':' . - \ '\<end\>' . - \ ',{:},\[:\],(:)' - - let b:match_skip = - \ "synIDattr(synID(line('.'),col('.'),0),'name') =~ '" . - \ "\\<ruby\\%(String\\|StringDelimiter\\|ASCIICode\\|Escape\\|" . - \ "Interpolation\\|NoInterpolation\\|Comment\\|Documentation\\|" . - \ "ConditionalModifier\\|RepeatModifier\\|OptionalDo\\|" . - \ "Function\\|BlockArgument\\|KeywordAsMethod\\|ClassVariable\\|" . - \ "InstanceVariable\\|GlobalVariable\\|Symbol\\)\\>'" -endif - -setlocal formatoptions-=t formatoptions+=croql - -setlocal include=^\\s*\\<\\(load\\\|\w*require\\)\\> -setlocal includeexpr=substitute(substitute(v:fname,'::','/','g'),'$','.rb','') -setlocal suffixesadd=.rb - -if exists("&ofu") && has("ruby") - setlocal omnifunc=rubycomplete#Complete -endif - -" To activate, :set ballooneval -if has('balloon_eval') && exists('+balloonexpr') - setlocal balloonexpr=RubyBalloonexpr() -endif - - -" TODO: -"setlocal define=^\\s*def - -setlocal comments=:# -setlocal commentstring=#\ %s - -if !exists("s:rubypath") - if has("ruby") && has("win32") - ruby VIM::command( 'let s:rubypath = "%s"' % ($: + begin; require %q{rubygems}; Gem.all_load_paths.sort.uniq; rescue LoadError; []; end).join(%q{,}) ) - let s:rubypath = '.,' . substitute(s:rubypath, '\%(^\|,\)\.\%(,\|$\)', ',,', '') - elseif executable("ruby") - let s:code = "print ($: + begin; require %q{rubygems}; Gem.all_load_paths.sort.uniq; rescue LoadError; []; end).join(%q{,})" - if &shellxquote == "'" - let s:rubypath = system('ruby -e "' . s:code . '"') - else - let s:rubypath = system("ruby -e '" . s:code . "'") - endif - let s:rubypath = '.,' . substitute(s:rubypath, '\%(^\|,\)\.\%(,\|$\)', ',,', '') - else - " If we can't call ruby to get its path, just default to using the - " current directory and the directory of the current file. - let s:rubypath = ".,," - endif -endif - -let &l:path = s:rubypath - -if has("gui_win32") && !exists("b:browsefilter") - let b:browsefilter = "Ruby Source Files (*.rb)\t*.rb\n" . - \ "All Files (*.*)\t*.*\n" -endif - -let b:undo_ftplugin = "setl fo< inc< inex< sua< def< com< cms< path< kp<" - \."| unlet! b:browsefilter b:match_ignorecase b:match_words b:match_skip" - \."| if exists('&ofu') && has('ruby') | setl ofu< | endif" - \."| if has('balloon_eval') && exists('+bexpr') | setl bexpr< | endif" - -if !exists("g:no_plugin_maps") && !exists("g:no_ruby_maps") - - noremap <silent> <buffer> [m :<C-U>call <SID>searchsyn('\<def\>','rubyDefine','b')<CR> - noremap <silent> <buffer> ]m :<C-U>call <SID>searchsyn('\<def\>','rubyDefine','')<CR> - noremap <silent> <buffer> [M :<C-U>call <SID>searchsyn('\<end\>','rubyDefine','b')<CR> - noremap <silent> <buffer> ]M :<C-U>call <SID>searchsyn('\<end\>','rubyDefine','')<CR> - - noremap <silent> <buffer> [[ :<C-U>call <SID>searchsyn('\<\%(class\<Bar>module\)\>','rubyModule\<Bar>rubyClass','b')<CR> - noremap <silent> <buffer> ]] :<C-U>call <SID>searchsyn('\<\%(class\<Bar>module\)\>','rubyModule\<Bar>rubyClass','')<CR> - noremap <silent> <buffer> [] :<C-U>call <SID>searchsyn('\<end\>','rubyModule\<Bar>rubyClass','b')<CR> - noremap <silent> <buffer> ][ :<C-U>call <SID>searchsyn('\<end\>','rubyModule\<Bar>rubyClass','')<CR> - - let b:undo_ftplugin = b:undo_ftplugin - \."| sil! exe 'unmap <buffer> [[' | sil! exe 'unmap <buffer> ]]' | sil! exe 'unmap <buffer> []' | sil! exe 'unmap <buffer> ]['" - \."| sil! exe 'unmap <buffer> [m' | sil! exe 'unmap <buffer> ]m' | sil! exe 'unmap <buffer> [M' | sil! exe 'unmap <buffer> ]M'" -endif - -let &cpo = s:cpo_save -unlet s:cpo_save - -if exists("g:did_ruby_ftplugin_functions") - finish -endif -let g:did_ruby_ftplugin_functions = 1 - -function! RubyBalloonexpr() - if !exists('s:ri_found') - let s:ri_found = executable('ri') - endif - if s:ri_found - let line = getline(v:beval_lnum) - let b = matchstr(strpart(line,0,v:beval_col),'\%(\w\|[:.]\)*$') - let a = substitute(matchstr(strpart(line,v:beval_col),'^\w*\%([?!]\|\s*=\)\?'),'\s\+','','g') - let str = b.a - let before = strpart(line,0,v:beval_col-strlen(b)) - let after = strpart(line,v:beval_col+strlen(a)) - if str =~ '^\.' - let str = substitute(str,'^\.','#','g') - if before =~ '\]\s*$' - let str = 'Array'.str - elseif before =~ '}\s*$' - " False positives from blocks here - let str = 'Hash'.str - elseif before =~ "[\"'`]\\s*$" || before =~ '\$\d\+\s*$' - let str = 'String'.str - elseif before =~ '\$\d\+\.\d\+\s*$' - let str = 'Float'.str - elseif before =~ '\$\d\+\s*$' - let str = 'Integer'.str - elseif before =~ '/\s*$' - let str = 'Regexp'.str - else - let str = substitute(str,'^#','.','') - endif - endif - let str = substitute(str,'.*\.\s*to_f\s*\.\s*','Float#','') - let str = substitute(str,'.*\.\s*to_i\%(nt\)\=\s*\.\s*','Integer#','') - let str = substitute(str,'.*\.\s*to_s\%(tr\)\=\s*\.\s*','String#','') - let str = substitute(str,'.*\.\s*to_sym\s*\.\s*','Symbol#','') - let str = substitute(str,'.*\.\s*to_a\%(ry\)\=\s*\.\s*','Array#','') - let str = substitute(str,'.*\.\s*to_proc\s*\.\s*','Proc#','') - if str !~ '^\w' - return '' - endif - silent! let res = substitute(system("ri -f simple -T \"".str.'"'),'\n$','','') - if res =~ '^Nothing known about' || res =~ '^Bad argument:' || res =~ '^More than one method' - return '' - endif - return res - else - return "" - endif -endfunction - -function! s:searchsyn(pattern,syn,flags) - norm! m' - let i = 0 - let cnt = v:count ? v:count : 1 - while i < cnt - let i = i + 1 - let line = line('.') - let col = col('.') - let pos = search(a:pattern,'W'.a:flags) - while pos != 0 && s:synname() !~# a:syn - let pos = search(a:pattern,'W'.a:flags) - endwhile - if pos == 0 - call cursor(line,col) - return - endif - endwhile -endfunction - -function! s:synname() - return synIDattr(synID(line('.'),col('.'),0),'name') -endfunction - -" -" Instructions for enabling "matchit" support: -" -" 1. Look for the latest "matchit" plugin at -" -" http://www.vim.org/scripts/script.php?script_id=39 -" -" It is also packaged with Vim, in the $VIMRUNTIME/macros directory. -" -" 2. Copy "matchit.txt" into a "doc" directory (e.g. $HOME/.vim/doc). -" -" 3. Copy "matchit.vim" into a "plugin" directory (e.g. $HOME/.vim/plugin). -" -" 4. Ensure this file (ftplugin/ruby.vim) is installed. -" -" 5. Ensure you have this line in your $HOME/.vimrc: -" filetype plugin on -" -" 6. Restart Vim and create the matchit documentation: -" -" :helptags ~/.vim/doc -" -" Now you can do ":help matchit", and you should be able to use "%" on Ruby -" keywords. Try ":echo b:match_words" to be sure. -" -" Thanks to Mark J. Reed for the instructions. See ":help vimrc" for the -" locations of plugin directories, etc., as there are several options, and it -" differs on Windows. Email gsinclair@soyabean.com.au if you need help. -" - -" vim: nowrap sw=2 sts=2 ts=8: diff --git a/share/vim/vim72/ftplugin/sass.vim b/share/vim/vim72/ftplugin/sass.vim deleted file mode 100644 index ad039772ad..0000000000 --- a/share/vim/vim72/ftplugin/sass.vim +++ /dev/null @@ -1,18 +0,0 @@ -" Vim filetype plugin -" Language: Sass -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> - -" Only do this when not done yet for this buffer -if exists("b:did_ftplugin") - finish -endif -let b:did_ftplugin = 1 - -let b:undo_ftplugin = "setl cms< inc< ofu<" - -setlocal commentstring=//\ %s -setlocal omnifunc=csscomplete#CompleteCSS - -let &l:include = '^\s*@import\s\+\%(url(\)\=' - -" vim:set sw=2: diff --git a/share/vim/vim72/ftplugin/sgml.vim b/share/vim/vim72/ftplugin/sgml.vim deleted file mode 100644 index 4a19ddae74..0000000000 --- a/share/vim/vim72/ftplugin/sgml.vim +++ /dev/null @@ -1,39 +0,0 @@ -" Vim filetype plugin file -" Language: sgml -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2003 Sep 30 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "XML Files (*.xml)\t*.xml\n" . - \ "All Files (*.*)\t*.*\n" - -runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim -let b:did_ftplugin = 1 - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter -endif - -" Change the :browse e filter to primarily show xml-related files. -if has("gui_win32") - let b:browsefilter="SGML Files (*.sgml,*.sgm)\t*.sgm*\n" . s:browsefilter -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "unlet! b:browsefilter | " . s:undo_ftplugin - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/sh.vim b/share/vim/vim72/ftplugin/sh.vim deleted file mode 100644 index 183215a129..0000000000 --- a/share/vim/vim72/ftplugin/sh.vim +++ /dev/null @@ -1,38 +0,0 @@ -" Vim filetype plugin file -" Language: sh -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2003 Sep 29 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif -let b:did_ftplugin = 1 - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -setlocal commentstring=#%s - -" Shell: thanks to Johannes Zellner -if exists("loaded_matchit") - let s:sol = '\%(;\s*\|^\s*\)\@<=' " start of line - let b:match_words = - \ s:sol.'if\>:' . s:sol.'elif\>:' . s:sol.'else\>:' . s:sol. 'fi\>,' . - \ s:sol.'\%(for\|while\)\>:' . s:sol. 'done\>,' . - \ s:sol.'case\>:' . s:sol. 'esac\>' -endif - -" Change the :browse e filter to primarily show shell-related files. -if has("gui_win32") - let b:browsefilter="Bourne Shell Scripts (*.sh)\t*.sh\n" . - \ "Korn Shell Scripts (*.ksh)\t*.ksh\n" . - \ "Bash Shell Scripts (*.bash)\t*.bash\n" . - \ "All Files (*.*)\t*.*\n" -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "setlocal cms< | unlet! b:browsefilter b:match_words" - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/sql.vim b/share/vim/vim72/ftplugin/sql.vim deleted file mode 100644 index 9f40b019af..0000000000 --- a/share/vim/vim72/ftplugin/sql.vim +++ /dev/null @@ -1,425 +0,0 @@ -" SQL filetype plugin file -" Language: SQL (Common for Oracle, Microsoft SQL Server, Sybase) -" Version: 4.0 -" Maintainer: David Fishburn <fishburn at ianywhere dot com> -" Last Change: Wed 27 Feb 2008 04:35:21 PM Eastern Standard Time -" Download: http://vim.sourceforge.net/script.php?script_id=454 - -" For more details please use: -" :h sql.txt -" -" This file should only contain values that are common to all SQL languages -" Oracle, Microsoft SQL Server, Sybase ASA/ASE, MySQL, and so on -" If additional features are required create: -" vimfiles/after/ftplugin/sql.vim (Windows) -" .vim/after/ftplugin/sql.vim (Unix) -" to override and add any of your own settings. - - -" This file also creates a command, SQLSetType, which allows you to change -" SQL dialects on the fly. For example, if I open an Oracle SQL file, it -" is color highlighted appropriately. If I open an Informix SQL file, it -" will still be highlighted according to Oracles settings. By running: -" :SQLSetType sqlinformix -" -" All files called sqlinformix.vim will be loaded from the indent and syntax -" directories. This allows you to easily flip SQL dialects on a per file -" basis. NOTE: you can also use completion: -" :SQLSetType <tab> -" -" To change the default dialect, add the following to your vimrc: -" let g:sql_type_default = 'sqlanywhere' - - -" Only do this when not done yet for this buffer -if exists("b:did_ftplugin") - finish -endif - -let s:save_cpo = &cpo -set cpo= - -" Disable autowrapping for code, but enable for comments -" t Auto-wrap text using textwidth -" c Auto-wrap comments using textwidth, inserting the current comment -" leader automatically. -setlocal formatoptions-=t -setlocal formatoptions-=c - -" Functions/Commands to allow the user to change SQL syntax dialects -" through the use of :SQLSetType <tab> for completion. -" This works with both Vim 6 and 7. - -if !exists("*SQL_SetType") - " NOTE: You cannot use function! since this file can be - " sourced from within this function. That will result in - " an error reported by Vim. - function SQL_GetList(ArgLead, CmdLine, CursorPos) - - if !exists('s:sql_list') - " Grab a list of files that contain "sql" in their names - let list_indent = globpath(&runtimepath, 'indent/*sql*') - let list_syntax = globpath(&runtimepath, 'syntax/*sql*') - let list_ftplugin = globpath(&runtimepath, 'ftplugin/*sql*') - - let sqls = "\n".list_indent."\n".list_syntax."\n".list_ftplugin."\n" - - " Strip out everything (path info) but the filename - " Regex - " From between two newline characters - " Non-greedily grab all characters - " Followed by a valid filename \w\+\.\w\+ (sql.vim) - " Followed by a newline, but do not include the newline - " - " Replace it with just the filename (get rid of PATH) - " - " Recursively, since there are many filenames that contain - " the word SQL in the indent, syntax and ftplugin directory - let sqls = substitute( sqls, - \ '[\n]\%(.\{-}\)\(\w\+\.\w\+\)\n\@=', - \ '\1\n', - \ 'g' - \ ) - - " Remove duplicates, since sqlanywhere.vim can exist in the - " sytax, indent and ftplugin directory, yet we only want - " to display the option once - let index = match(sqls, '.\{-}\ze\n') - while index > -1 - " Get the first filename - let file = matchstr(sqls, '.\{-}\ze\n', index) - " Recursively replace any *other* occurrence of that - " filename with nothing (ie remove it) - let sqls = substitute(sqls, '\%>'.(index+strlen(file)).'c\<'.file.'\>\n', '', 'g') - " Move on to the next filename - let index = match(sqls, '.\{-}\ze\n', (index+strlen(file)+1)) - endwhile - - " Sort the list if using version 7 - if v:version >= 700 - let mylist = split(sqls, "\n") - let mylist = sort(mylist) - let sqls = join(mylist, "\n") - endif - - let s:sql_list = sqls - endif - - return s:sql_list - - endfunction - - function SQL_SetType(name) - - " User has decided to override default SQL scripts and - " specify a vendor specific version - " (ie Oracle, Informix, SQL Anywhere, ...) - " So check for an remove any settings that prevent the - " scripts from being executed, and then source the - " appropriate Vim scripts. - if exists("b:did_ftplugin") - unlet b:did_ftplugin - endif - if exists("b:current_syntax") - " echomsg 'SQLSetType - clearing syntax' - syntax clear - endif - if exists("b:did_indent") - " echomsg 'SQLSetType - clearing indent' - unlet b:did_indent - " Set these values to their defaults - setlocal indentkeys& - setlocal indentexpr& - endif - - " Ensure the name is in the correct format - let new_sql_type = substitute(a:name, - \ '\s*\([^\.]\+\)\(\.\w\+\)\?', '\L\1', '') - - " Do not specify a buffer local variable if it is - " the default value - if new_sql_type == 'sql' - let new_sql_type = 'sqloracle' - endif - let b:sql_type_override = new_sql_type - - " Vim will automatically source the correct files if we - " change the filetype. You cannot do this with setfiletype - " since that command will only execute if a filetype has - " not already been set. In this case we want to override - " the existing filetype. - let &filetype = 'sql' - endfunction - command! -nargs=* -complete=custom,SQL_GetList SQLSetType :call SQL_SetType(<q-args>) - -endif - -if exists("b:sql_type_override") - " echo 'sourcing buffer ftplugin/'.b:sql_type_override.'.vim' - if globpath(&runtimepath, 'ftplugin/'.b:sql_type_override.'.vim') != '' - exec 'runtime ftplugin/'.b:sql_type_override.'.vim' - " else - " echomsg 'ftplugin/'.b:sql_type_override.' not exist, using default' - endif -elseif exists("g:sql_type_default") - " echo 'sourcing global ftplugin/'.g:sql_type_default.'.vim' - if globpath(&runtimepath, 'ftplugin/'.g:sql_type_default.'.vim') != '' - exec 'runtime ftplugin/'.g:sql_type_default.'.vim' - " else - " echomsg 'ftplugin/'.g:sql_type_default.'.vim not exist, using default' - endif -endif - -" If the above runtime command succeeded, do not load the default settings -if exists("b:did_ftplugin") - finish -endif - -let b:undo_ftplugin = "setl comments<" - -" Don't load another plugin for this buffer -let b:did_ftplugin = 1 -let b:current_ftplugin = 'sql' - -" Win32 can filter files in the browse dialog -if has("gui_win32") && !exists("b:browsefilter") - let b:browsefilter = "SQL Files (*.sql)\t*.sql\n" . - \ "All Files (*.*)\t*.*\n" -endif - -" Some standard expressions for use with the matchit strings -let s:notend = '\%(\<end\s\+\)\@<!' -let s:when_no_matched_or_others = '\%(\<when\>\%(\s\+\%(\%(\<not\>\s\+\)\?<matched\>\)\|\<others\>\)\@!\)' -let s:or_replace = '\%(or\s\+replace\s\+\)\?' - -" Define patterns for the matchit macro -if !exists("b:match_words") - " SQL is generally case insensitive - let b:match_ignorecase = 1 - - " Handle the following: - " if - " elseif | elsif - " else [if] - " end if - " - " [while condition] loop - " leave - " break - " continue - " exit - " end loop - " - " for - " leave - " break - " continue - " exit - " end loop - " - " do - " statements - " doend - " - " case - " when - " when - " default - " end case - " - " merge - " when not matched - " when matched - " - " EXCEPTION - " WHEN column_not_found THEN - " WHEN OTHERS THEN - " - " create[ or replace] procedure|function|event - - let b:match_words = - \ '\<begin\>:\<end\>\W*$,'. - \ - \ s:notend . '\<if\>:'. - \ '\<elsif\>\|\<elseif\>\|\<else\>:'. - \ '\<end\s\+if\>,'. - \ - \ '\<do\>\|'. - \ '\<while\>\|'. - \ '\%(' . s:notend . '\<loop\>\)\|'. - \ '\%(' . s:notend . '\<for\>\):'. - \ '\<exit\>\|\<leave\>\|\<break\>\|\<continue\>:'. - \ '\%(\<end\s\+\%(for\|loop\>\)\)\|\<doend\>,'. - \ - \ '\%('. s:notend . '\<case\>\):'. - \ '\%('.s:when_no_matched_or_others.'\):'. - \ '\%(\<when\s\+others\>\|\<end\s\+case\>\),' . - \ - \ '\<merge\>:' . - \ '\<when\s\+not\s\+matched\>:' . - \ '\<when\s\+matched\>,' . - \ - \ '\%(\<create\s\+' . s:or_replace . '\)\?'. - \ '\%(function\|procedure\|event\):'. - \ '\<returns\?\>' - " \ '\<begin\>\|\<returns\?\>:'. - " \ '\<end\>\(;\)\?\s*$' - " \ '\<exception\>:'.s:when_no_matched_or_others. - " \ ':\<when\s\+others\>,'. - " - " \ '\%(\<exception\>\|\%('. s:notend . '\<case\>\)\):'. - " \ '\%(\<default\>\|'.s:when_no_matched_or_others.'\):'. - " \ '\%(\%(\<when\s\+others\>\)\|\<end\s\+case\>\),' . -endif - -" Define how to find the macro definition of a variable using the various -" [d, [D, [_CTRL_D and so on features -" Match these values ignoring case -" ie DECLARE varname INTEGER -let &l:define = '\c\<\(VARIABLE\|DECLARE\|IN\|OUT\|INOUT\)\>' - - -" Mappings to move to the next BEGIN ... END block -" \W - no characters or digits -nmap <buffer> <silent> ]] :call search('\\c^\\s*begin\\>', 'W' )<CR> -nmap <buffer> <silent> [[ :call search('\\c^\\s*begin\\>', 'bW' )<CR> -nmap <buffer> <silent> ][ :call search('\\c^\\s*end\\W*$', 'W' )<CR> -nmap <buffer> <silent> [] :call search('\\c^\\s*end\\W*$', 'bW' )<CR> -vmap <buffer> <silent> ]] :<C-U>exec "normal! gv"<Bar>call search('\\c^\\s*begin\\>', 'W' )<CR> -vmap <buffer> <silent> [[ :<C-U>exec "normal! gv"<Bar>call search('\\c^\\s*begin\\>', 'bW' )<CR> -vmap <buffer> <silent> ][ :<C-U>exec "normal! gv"<Bar>call search('\\c^\\s*end\\W*$', 'W' )<CR> -vmap <buffer> <silent> [] :<C-U>exec "normal! gv"<Bar>call search('\\c^\\s*end\\W*$', 'bW' )<CR> - - -" By default only look for CREATE statements, but allow -" the user to override -if !exists('g:ftplugin_sql_statements') - let g:ftplugin_sql_statements = 'create' -endif - -" Predefined SQL objects what are used by the below mappings using -" the ]} style maps. -" This global variable allows the users to override it's value -" from within their vimrc. -" Note, you cannot use \?, since these patterns can be used to search -" backwards, you must use \{,1} -if !exists('g:ftplugin_sql_objects') - let g:ftplugin_sql_objects = 'function,procedure,event,' . - \ '\\(existing\\\\|global\\s\\+temporary\\s\\+\\)\\\{,1}' . - \ 'table,trigger' . - \ ',schema,service,publication,database,datatype,domain' . - \ ',index,subscription,synchronization,view,variable' -endif - -" Replace all ,'s with bars, except ones with numbers after them. -" This will most likely be a \{,1} string. -let s:ftplugin_sql_objects = - \ '\\c^\\s*' . - \ '\\(\\(' . - \ substitute(g:ftplugin_sql_statements, ',\d\@!', '\\\\\\|', 'g') . - \ '\\)\\s\\+\\(or\\s\\+replace\\\s\+\\)\\{,1}\\)\\{,1}' . - \ '\\<\\(' . - \ substitute(g:ftplugin_sql_objects, ',\d\@!', '\\\\\\|', 'g') . - \ '\\)\\>' - -" Mappings to move to the next CREATE ... block -exec "nmap <buffer> <silent> ]} :call search('".s:ftplugin_sql_objects."', 'W')<CR>" -exec "nmap <buffer> <silent> [{ :call search('".s:ftplugin_sql_objects."', 'bW')<CR>" -" Could not figure out how to use a :call search() string in visual mode -" without it ending visual mode -" Unfortunately, this will add a entry to the search history -exec 'vmap <buffer> <silent> ]} /'.s:ftplugin_sql_objects.'<CR>' -exec 'vmap <buffer> <silent> [{ ?'.s:ftplugin_sql_objects.'<CR>' - -" Mappings to move to the next COMMENT -" -" Had to double the \ for the \| separator since this has a special -" meaning on maps -let b:comment_leader = '\\(--\\\|\\/\\/\\\|\\*\\\|\\/\\*\\\|\\*\\/\\)' -" Find the start of the next comment -let b:comment_start = '^\\(\\s*'.b:comment_leader.'.*\\n\\)\\@<!'. - \ '\\(\\s*'.b:comment_leader.'\\)' -" Find the end of the previous comment -let b:comment_end = '\\(^\\s*'.b:comment_leader.'.*\\n\\)'. - \ '\\(^\\s*'.b:comment_leader.'\\)\\@!' -" Skip over the comment -let b:comment_jump_over = "call search('". - \ '^\\(\\s*'.b:comment_leader.'.*\\n\\)\\@<!'. - \ "', 'W')" -let b:comment_skip_back = "call search('". - \ '^\\(\\s*'.b:comment_leader.'.*\\n\\)\\@<!'. - \ "', 'bW')" -" Move to the start and end of comments -exec 'nnoremap <silent><buffer> ]" :call search('."'".b:comment_start."'".', "W" )<CR>' -exec 'nnoremap <silent><buffer> [" :call search('."'".b:comment_end."'".', "W" )<CR>' -exec 'vnoremap <silent><buffer> ]" :<C-U>exec "normal! gv"<Bar>call search('."'".b:comment_start."'".', "W" )<CR>' -exec 'vnoremap <silent><buffer> [" :<C-U>exec "normal! gv"<Bar>call search('."'".b:comment_end."'".', "W" )<CR>' - -" Comments can be of the form: -" /* -" * -" */ -" or -" -- -" or -" // -setlocal comments=s1:/*,mb:*,ex:*/,:--,:// - -" Set completion with CTRL-X CTRL-O to autoloaded function. -if exists('&omnifunc') - " Since the SQL completion plugin can be used in conjunction - " with other completion filetypes it must record the previous - " OMNI function prior to setting up the SQL OMNI function - let b:sql_compl_savefunc = &omnifunc - - " This is used by the sqlcomplete.vim plugin - " Source it for it's global functions - runtime autoload/syntaxcomplete.vim - - setlocal omnifunc=sqlcomplete#Complete - " Prevent the intellisense plugin from loading - let b:sql_vis = 1 - if !exists('g:omni_sql_no_default_maps') - " Static maps which use populate the completion list - " using Vim's syntax highlighting rules - imap <buffer> <c-c>a <C-\><C-O>:call sqlcomplete#Map('syntax')<CR><C-X><C-O> - imap <buffer> <c-c>k <C-\><C-O>:call sqlcomplete#Map('sqlKeyword')<CR><C-X><C-O> - imap <buffer> <c-c>f <C-\><C-O>:call sqlcomplete#Map('sqlFunction')<CR><C-X><C-O> - imap <buffer> <c-c>o <C-\><C-O>:call sqlcomplete#Map('sqlOption')<CR><C-X><C-O> - imap <buffer> <c-c>T <C-\><C-O>:call sqlcomplete#Map('sqlType')<CR><C-X><C-O> - imap <buffer> <c-c>s <C-\><C-O>:call sqlcomplete#Map('sqlStatement')<CR><C-X><C-O> - " Dynamic maps which use populate the completion list - " using the dbext.vim plugin - imap <buffer> <c-c>t <C-\><C-O>:call sqlcomplete#Map('table')<CR><C-X><C-O> - imap <buffer> <c-c>p <C-\><C-O>:call sqlcomplete#Map('procedure')<CR><C-X><C-O> - imap <buffer> <c-c>v <C-\><C-O>:call sqlcomplete#Map('view')<CR><C-X><C-O> - imap <buffer> <c-c>c <C-\><C-O>:call sqlcomplete#Map('column')<CR><C-X><C-O> - imap <buffer> <c-c>l <C-\><C-O>:call sqlcomplete#Map('column_csv')<CR><C-X><C-O> - " The next 3 maps are only to be used while the completion window is - " active due to the <CR> at the beginning of the map - imap <buffer> <c-c>L <C-Y><C-\><C-O>:call sqlcomplete#Map('column_csv')<CR><C-X><C-O> - " <C-Right> is not recognized on most Unix systems, so only create - " these additional maps on the Windows platform. - " If you would like to use these maps, choose a different key and make - " the same map in your vimrc. - if has('win32') - imap <buffer> <c-right> <C-R>=sqlcomplete#DrillIntoTable()<CR> - imap <buffer> <c-left> <C-R>=sqlcomplete#DrillOutOfColumns()<CR> - endif - " Remove any cached items useful for schema changes - imap <buffer> <c-c>R <C-\><C-O>:call sqlcomplete#Map('resetCache')<CR><C-X><C-O> - endif - - if b:sql_compl_savefunc != "" - " We are changing the filetype to SQL from some other filetype - " which had OMNI completion defined. We need to activate the - " SQL completion plugin in order to cache some of the syntax items - " while the syntax rules for SQL are active. - call sqlcomplete#PreCacheSyntax() - endif -endif - -let &cpo = s:save_cpo - -" vim:sw=4: - diff --git a/share/vim/vim72/ftplugin/svg.vim b/share/vim/vim72/ftplugin/svg.vim deleted file mode 100644 index 4544172d05..0000000000 --- a/share/vim/vim72/ftplugin/svg.vim +++ /dev/null @@ -1,39 +0,0 @@ -" Vim filetype plugin file -" Language: svg -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2003 Sep 29 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "XML Files (*.xml)\t*.xml\n" . - \ "All Files (*.*)\t*.*\n" - -runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim -let b:did_ftplugin = 1 - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter -endif - -" Change the :browse e filter to primarily show xml-related files. -if has("gui_win32") - let b:browsefilter="SVG Files (*.svg)\t*.svg\n" . s:browsefilter -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "unlet! b:browsefilter | " . s:undo_ftplugin - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/tcsh.vim b/share/vim/vim72/ftplugin/tcsh.vim deleted file mode 100644 index 4c724e68b3..0000000000 --- a/share/vim/vim72/ftplugin/tcsh.vim +++ /dev/null @@ -1,39 +0,0 @@ -" Vim filetype plugin file -" Language: tcsh -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2003 Sep 29 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "csh Files (*.csh)\t*.csh\n" . - \ "All Files (*.*)\t*.*\n" - -runtime! ftplugin/csh.vim ftplugin/csh_*.vim ftplugin/csh/*.vim -let b:did_ftplugin = 1 - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter -endif - -" Change the :browse e filter to primarily show tcsh-related files. -if has("gui_win32") - let b:browsefilter="tcsh Scripts (*.tcsh)\t*.tcsh\n" . s:browsefilter -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "unlet! b:browsefilter | " . s:undo_ftplugin - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/verilog.vim b/share/vim/vim72/ftplugin/verilog.vim deleted file mode 100644 index 1d37d601ac..0000000000 --- a/share/vim/vim72/ftplugin/verilog.vim +++ /dev/null @@ -1,51 +0,0 @@ -" Vim filetype plugin file -" Language: Verilog HDL -" Maintainer: Chih-Tsun Huang <cthuang@larc.ee.nthu.edu.tw> -" Last Change: Mon Sep 5 11:05:54 CST 2005 and 2006 April 30 -" URL: http://larc.ee.nthu.edu.tw/~cthuang/vim/ftplugin/verilog.vim - -" Only do this when not done yet for this buffer -if exists("b:did_ftplugin") - finish -endif - -" Don't load another plugin for this buffer -let b:did_ftplugin = 1 - -" Undo the plugin effect -let b:undo_ftplugin = "setlocal fo< com< tw<" - \ . "| unlet! b:browsefilter b:match_ignorecase b:match_words" - -" Set 'formatoptions' to break comment lines but not other lines, -" and insert the comment leader when hitting <CR> or using "o". -setlocal fo-=t fo+=croqlm1 - -" Set 'comments' to format dashed lists in comments. -setlocal comments=sO:*\ -,mO:*\ \ ,exO:*/,s1:/*,mb:*,ex:*/,:// - -" Format comments to be up to 78 characters long -if &textwidth == 0 - setlocal tw=78 -endif - -set cpo-=C - -" Win32 can filter files in the browse dialog -if has("gui_win32") && !exists("b:browsefilter") - let b:browsefilter = "Verilog Source Files (*.v)\t*.v\n" . - \ "All Files (*.*)\t*.*\n" -endif - -" Let the matchit plugin know what items can be matched. -if exists("loaded_matchit") - let b:match_ignorecase=0 - let b:match_words= - \ '\<begin\>:\<end\>,' . - \ '\<case\>\|\<casex\>\|\<casez\>:\<endcase\>,' . - \ '\<module\>:\<endmodule\>,' . - \ '\<if\>:\<else\>,' . - \ '\<function\>:\<endfunction\>,' . - \ '`ifdef\>:`else\>:`endif\>,' . - \ '\<task\>:\<endtask\>,' . - \ '\<specify\>:\<endspecify\>' -endif diff --git a/share/vim/vim72/ftplugin/vim.vim b/share/vim/vim72/ftplugin/vim.vim deleted file mode 100644 index ca66597d8a..0000000000 --- a/share/vim/vim72/ftplugin/vim.vim +++ /dev/null @@ -1,70 +0,0 @@ -" Vim filetype plugin -" Language: Vim -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2008 Feb 27 - -" Only do this when not done yet for this buffer -if exists("b:did_ftplugin") - finish -endif - -" Don't load another plugin for this buffer -let b:did_ftplugin = 1 - -let cpo_save = &cpo -set cpo-=C - -let b:undo_ftplugin = "setl fo< com< tw< commentstring<" - \ . "| unlet! b:match_ignorecase b:match_words b:match_skip" - -" Set 'formatoptions' to break comment lines but not other lines, -" and insert the comment leader when hitting <CR> or using "o". -setlocal fo-=t fo+=croql - -" Set 'comments' to format dashed lists in comments -setlocal com=sO:\"\ -,mO:\"\ \ ,eO:\"\",:\" - -" Format comments to be up to 78 characters long -if &tw == 0 - setlocal tw=78 -endif - -" Comments start with a double quote -setlocal commentstring=\"%s - -" Move around functions. -nnoremap <silent><buffer> [[ m':call search('^\s*fu\%[nction]\>', "bW")<CR> -vnoremap <silent><buffer> [[ m':<C-U>exe "normal! gv"<Bar>call search('^\s*fu\%[nction]\>', "bW")<CR> -nnoremap <silent><buffer> ]] m':call search('^\s*fu\%[nction]\>', "W")<CR> -vnoremap <silent><buffer> ]] m':<C-U>exe "normal! gv"<Bar>call search('^\s*fu\%[nction]\>', "W")<CR> -nnoremap <silent><buffer> [] m':call search('^\s*endf*\%[unction]\>', "bW")<CR> -vnoremap <silent><buffer> [] m':<C-U>exe "normal! gv"<Bar>call search('^\s*endf*\%[unction]\>', "bW")<CR> -nnoremap <silent><buffer> ][ m':call search('^\s*endf*\%[unction]\>', "W")<CR> -vnoremap <silent><buffer> ][ m':<C-U>exe "normal! gv"<Bar>call search('^\s*endf*\%[unction]\>', "W")<CR> - -" Move around comments -nnoremap <silent><buffer> ]" :call search('^\(\s*".*\n\)\@<!\(\s*"\)', "W")<CR> -vnoremap <silent><buffer> ]" :<C-U>exe "normal! gv"<Bar>call search('^\(\s*".*\n\)\@<!\(\s*"\)', "W")<CR> -nnoremap <silent><buffer> [" :call search('\%(^\s*".*\n\)\%(^\s*"\)\@!', "bW")<CR> -vnoremap <silent><buffer> [" :<C-U>exe "normal! gv"<Bar>call search('\%(^\s*".*\n\)\%(^\s*"\)\@!', "bW")<CR> - -" Let the matchit plugin know what items can be matched. -if exists("loaded_matchit") - let b:match_ignorecase = 0 - let b:match_words = - \ '\<fu\%[nction]\>:\<retu\%[rn]\>:\<endf\%[unction]\>,' . - \ '\<wh\%[ile]\>:\<brea\%[k]\>:\<con\%[tinue]\>:\<endw\%[hile]\>,' . - \ '\<for\>:\<brea\%[k]\>:\<con\%[tinue]\>:\<endfo\%[r]\>,' . - \ '\<if\>:\<el\%[seif]\>:\<en\%[dif]\>,' . - \ '\<try\>:\<cat\%[ch]\>:\<fina\%[lly]\>:\<endt\%[ry]\>,' . - \ '\<aug\%[roup]\s\+\%(END\>\)\@!\S:\<aug\%[roup]\s\+END\>,' . - \ '(:)' - " Ignore ":syntax region" commands, the 'end' argument clobbers if-endif - let b:match_skip = 'getline(".") =~ "^\\s*sy\\%[ntax]\\s\\+region" || - \ synIDattr(synID(line("."),col("."),1),"name") =~? "comment\\|string"' -endif - -let &cpo = cpo_save - -" removed this, because 'cpoptions' is a global option. -" setlocal cpo+=M " makes \%( match \) diff --git a/share/vim/vim72/ftplugin/xhtml.vim b/share/vim/vim72/ftplugin/xhtml.vim deleted file mode 100644 index e03407be5e..0000000000 --- a/share/vim/vim72/ftplugin/xhtml.vim +++ /dev/null @@ -1,66 +0,0 @@ -" Vim filetype plugin file -" Language: xhtml -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2004 Jul 08 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "HTML Files (*.html, *.htm)\t*.html;*.htm\n" . - \ "XML Files (*.xml)\t*.xml\n" . - \ "All Files (*.*)\t*.*\n" -let s:match_words = "" - -runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim -unlet b:did_ftplugin - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin - unlet b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter - unlet b:browsefilter -endif -if exists("b:match_words") - let s:match_words = b:match_words - unlet b:match_words -endif - -runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim -let b:did_ftplugin = 1 - -" Combine the new set of values with those previously included. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin . " | " . s:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter . s:browsefilter -endif -if exists("b:match_words") - let s:match_words = b:match_words . "," . s:match_words -endif - -" Load the combined list of match_words for matchit.vim -if exists("loaded_matchit") - let b:match_words = s:match_words -endif - -" Change the :browse e filter to primarily show tcsh-related files. -if has("gui_win32") - let b:browsefilter="XHTML files (*.xhtml, *.xhtm)\t*.xhtml;*.xhtm\n" . s:browsefilter -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "unlet! b:browsefilter b:match_words | " . s:undo_ftplugin - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/xml.vim b/share/vim/vim72/ftplugin/xml.vim deleted file mode 100644 index 55d9ee6c5b..0000000000 --- a/share/vim/vim72/ftplugin/xml.vim +++ /dev/null @@ -1,63 +0,0 @@ -" Vim filetype plugin file -" Language: xml -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 30 Jun 2008 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif -let b:did_ftplugin = 1 - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -setlocal commentstring=<!--%s--> -setlocal comments=s:<!--,m:\ \ \ \ \ ,e:--> - -setlocal formatoptions-=t -if !exists("g:ft_xml_autocomment") || (g:ft_xml_autocomment == 1) - setlocal formatoptions+=croql -endif - - -" XML: thanks to Johannes Zellner and Akbar Ibrahim -" - case sensitive -" - don't match empty tags <fred/> -" - match <!--, --> style comments (but not --, --) -" - match <!, > inlined dtd's. This is not perfect, as it -" gets confused for example by -" <!ENTITY gt ">"> -if exists("loaded_matchit") - let b:match_ignorecase=0 - let b:match_words = - \ '<:>,' . - \ '<\@<=!\[CDATA\[:]]>,'. - \ '<\@<=!--:-->,'. - \ '<\@<=?\k\+:?>,'. - \ '<\@<=\([^ \t>/]\+\)\%(\s\+[^>]*\%([^/]>\|$\)\|>\|$\):<\@<=/\1>,'. - \ '<\@<=\%([^ \t>/]\+\)\%(\s\+[^/>]*\|$\):/>' -endif - -" -" For Omni completion, by Mikolaj Machowski. -if exists('&ofu') - setlocal ofu=xmlcomplete#CompleteTags -endif -command! -nargs=+ XMLns call xmlcomplete#CreateConnection(<f-args>) -command! -nargs=? XMLent call xmlcomplete#CreateEntConnection(<f-args>) - - -" Change the :browse e filter to primarily show xml-related files. -if has("gui_win32") - let b:browsefilter="XML Files (*.xml)\t*.xml\n" . - \ "DTD Files (*.dtd)\t*.dtd\n" . - \ "All Files (*.*)\t*.*\n" -endif - -" Undo the stuff we changed. -let b:undo_ftplugin = "setlocal commentstring< comments< formatoptions<" . - \ " | unlet! b:match_ignorecase b:match_words b:browsefilter" - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/xs.vim b/share/vim/vim72/ftplugin/xs.vim deleted file mode 100644 index cf33182584..0000000000 --- a/share/vim/vim72/ftplugin/xs.vim +++ /dev/null @@ -1,12 +0,0 @@ -" Vim filetype plugin file -" Language: XS (Perl extension interface language) -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2001 Sep 18 - -" Only do this when not done yet for this buffer -if exists("b:did_ftplugin") - finish -endif - -" Just use the C plugin for now. -runtime! ftplugin/c.vim ftplugin/c_*.vim ftplugin/c/*.vim diff --git a/share/vim/vim72/ftplugin/xsd.vim b/share/vim/vim72/ftplugin/xsd.vim deleted file mode 100644 index 1cd7adc764..0000000000 --- a/share/vim/vim72/ftplugin/xsd.vim +++ /dev/null @@ -1,38 +0,0 @@ -" Vim filetype plugin file -" Language: xsd -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2003 Sep 29 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif - -" Make sure the continuation lines below do not cause problems in -" compatibility mode. -let s:save_cpo = &cpo -set cpo-=C - -" Define some defaults in case the included ftplugins don't set them. -let s:undo_ftplugin = "" -let s:browsefilter = "XML Files (*.xml)\t*.xml\n" . - \ "All Files (*.*)\t*.*\n" - -runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim -let b:did_ftplugin = 1 - -" Override our defaults if these were set by an included ftplugin. -if exists("b:undo_ftplugin") - let s:undo_ftplugin = b:undo_ftplugin -endif -if exists("b:browsefilter") - let s:browsefilter = b:browsefilter -endif - -" Change the :browse e filter to primarily show xsd-related files. -if has("gui_win32") - let b:browsefilter="XSD Files (*.xsd)\t*.xsd\n" . s:browsefilter -endif - -let b:undo_ftplugin = "unlet! b:browsefilter | " . s:undo_ftplugin - -" Restore the saved compatibility options. -let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/xslt.vim b/share/vim/vim72/ftplugin/xslt.vim deleted file mode 100644 index 958043274b..0000000000 --- a/share/vim/vim72/ftplugin/xslt.vim +++ /dev/null @@ -1,16 +0,0 @@ -" Vim filetype plugin file -" Language: xslt -" Maintainer: Dan Sharp <dwsharp at hotmail dot com> -" Last Changed: 2004 Jul 08 -" URL: http://mywebpage.netscape.com/sharppeople/vim/ftplugin - -if exists("b:did_ftplugin") | finish | endif - -runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim - -let b:did_ftplugin = 1 - -" Change the :browse e filter to primarily show xsd-related files. -if has("gui_win32") && exists("b:browsefilter") - let b:browsefilter="XSLT Files (*.xsl,*.xslt)\t*.xsl;*.xslt\n" . b:browsefilter -endif diff --git a/share/vim/vim72/indent/GenericIndent.vim b/share/vim/vim72/indent/GenericIndent.vim deleted file mode 100644 index 67afd70ce3..0000000000 --- a/share/vim/vim72/indent/GenericIndent.vim +++ /dev/null @@ -1,322 +0,0 @@ -" Vim indent file generic utility functions -" Language: * (various) -" Maintainer: Dave Silvia <dsilvia@mchsi.com> -" Date: 6/30/2004 - -" SUMMARY: To use GenericIndent, indent/<your_filename>.vim would have the -" following general format: -" -" if exists("b:did_indent") | finish | endif -" let b:did_indent = 1 -" runtime indent/GenericIndent.vim -" let b:indentStmts='' -" let b:dedentStmts='' -" let b:allStmts='' -" setlocal indentexpr=GenericIndent() -" setlocal indentkeys=<your_keys> -" call GenericIndentStmts(<your_stmts>) -" call GenericDedentStmts(<your_stmts>) -" call GenericAllStmts() -" -" END SUMMARY: - -" NOTE: b:indentStmts, b:dedentStmts, and b:allStmts need to be initialized -" to '' before callin the functions because 'indent.vim' explicitly -" 'unlet's b:did_indent. This means that the lists will compound if -" you change back and forth between buffers. This is true as of -" version 6.3, 6/23/2004. -" -" NOTE: By default, GenericIndent is case sensitive. -" let b:case_insensitive=1 if you want to ignore case, e.g. DOS batch files - -" The function 'GenericIndent' is data driven and handles most all cases of -" indent checking if you first set up the data. To use this function follow -" the example below (taken from the file indent/MuPAD_source.vim) -" -" Before you start, source this file in indent/<your_script>.vim to have it -" define functions for your use. -" -"runtime indent/GenericIndent.vim -" -" The data is in 5 sets: -" -" First, set the data set 'indentexpr' to GenericIndent(). -" -"setlocal indentexpr=GenericIndent() -" -" Second, set the data set 'indentkeys' to the keywords/expressions that need -" to be checked for 'indenting' _as_ they typed. -" -"setlocal indentkeys==end_proc,=else,=then,=elif,=end_if,=end_case,=until,=end_repeat,=end_domain,=end_for,=end_while,=end,o,O -" -" NOTE: 'o,O' at the end of the previous line says you wish to be called -" whenever a newline is placed in the buffer. This allows the previous line -" to be checked for indentation parameters. -" -" Third, set the data set 'b:indentStmts' to the keywords/expressions that, when -" they are on a line _when_ you _press_ the _<Enter>_ key, -" you wish to have the next line indented. -" -"call GenericIndentStmts('begin,if,then,else,elif,case,repeat,until,domain,do') -" -" Fourth, set the data set 'b:dedentStmts' to the keywords/expressions that, when -" they are on a line you are currently typing, you wish to have that line -" 'dedented' (having already been indented because of the previous line's -" indentation). -" -"call GenericDedentStmts('end_proc,then,else,elif,end_if,end_case,until,end_repeat,end_domain,end_for,end_while,end') -" -" Fifth, set the data set 'b:allStmts' to the concatenation of the third and -" fourth data sets, used for checking when more than one keyword/expression -" is on a line. -" -"call GenericAllStmts() -" -" NOTE: GenericIndentStmts uses two variables: 'b:indentStmtOpen' and -" 'b:indentStmtClose' which default to '\<' and '\>' respectively. You can -" set (let) these to any value you wish before calling GenericIndentStmts with -" your list. Similarly, GenericDedentStmts uses 'b:dedentStmtOpen' and -" 'b:dedentStmtClose'. -" -" NOTE: Patterns may be used in the lists passed to Generic[In|De]dentStmts -" since each element in the list is copied verbatim. -" -" Optionally, you can set the DEBUGGING flag within your script to have the -" debugging messages output. See below for description. This can also be set -" (let) from the command line within your editing buffer. -" -"let b:DEBUGGING=1 -" -" See: -" :h runtime -" :set runtimepath ? -" to familiarize yourself with how this works and where you should have this -" file and your file(s) installed. -" -" For help with setting 'indentkeys' see: -" :h indentkeys -" Also, for some good examples see 'indent/sh.vim' and 'indent/vim.vim' as -" well as files for other languages you may be familiar with. -" -" -" Alternatively, if you'd rather specify yourself, you can enter -" 'b:indentStmts', 'b:dedentStmts', and 'b:allStmts' 'literally': -" -"let b:indentStmts='\<begin\>\|\<if\>\|\<then\>\|\<else\>\|\<elif\>\|\<case\>\|\<repeat\>\|\<until\>\|\<domain\>\|\<do\>' -"let b:dedentStmts='\<end_proc\>\|\<else\>\|\<elif\>\|\<end_if\>\|\<end_case\>\|\<until\>\|\<end_repeat\>\|\<end_domain\>\|\<end_for\>\|\<end_while\>\|\<end\>' -"let b:allStmts=b:indentStmts.'\|'.b:dedentStmts -" -" This is only useful if you have particularly different parameters for -" matching each statement. - -" RECAP: From indent/MuPAD_source.vim -" -"if exists("b:did_indent") | finish | endif -" -"let b:did_indent = 1 -" -"runtime indent/GenericIndent.vim -" -"setlocal indentexpr=GenericIndent() -"setlocal indentkeys==end_proc,=then,=else,=elif,=end_if,=end_case,=until,=end_repeat,=end_domain,=end_for,=end_while,=end,o,O -"call GenericIndentStmts('begin,if,then,else,elif,case,repeat,until,domain,do') -"call GenericDedentStmts('end_proc,then,else,elif,end_if,end_case,until,end_repeat,end_domain,end_for,end_while,end') -"call GenericAllStmts() -" -" END RECAP: - -let s:hit=0 -let s:lastVlnum=0 -let s:myScriptName=expand("<sfile>:t") - -if exists("*GenericIndent") - finish -endif - -function GenericAllStmts() - let b:allStmts=b:indentStmts.'\|'.b:dedentStmts - call DebugGenericIndent(expand("<sfile>").": "."b:indentStmts: ".b:indentStmts.", b:dedentStmts: ".b:dedentStmts.", b:allStmts: ".b:allStmts) -endfunction - -function GenericIndentStmts(stmts) - let Stmts=a:stmts - let Comma=match(Stmts,',') - if Comma == -1 || Comma == strlen(Stmts)-1 - echoerr "Must supply a comma separated list of at least 2 entries." - echoerr "Supplied list: <".Stmts.">" - return - endif - - if !exists("b:indentStmtOpen") - let b:indentStmtOpen='\<' - endif - if !exists("b:indentStmtClose") - let b:indentStmtClose='\>' - endif - if !exists("b:indentStmts") - let b:indentStmts='' - endif - if b:indentStmts != '' - let b:indentStmts=b:indentStmts.'\|' - endif - call DebugGenericIndent(expand("<sfile>").": "."b:indentStmtOpen: ".b:indentStmtOpen.", b:indentStmtClose: ".b:indentStmtClose.", b:indentStmts: ".b:indentStmts.", Stmts: ".Stmts) - let stmtEntryBegin=0 - let stmtEntryEnd=Comma - let stmtEntry=strpart(Stmts,stmtEntryBegin,stmtEntryEnd-stmtEntryBegin) - let Stmts=strpart(Stmts,Comma+1) - let Comma=match(Stmts,',') - let b:indentStmts=b:indentStmts.b:indentStmtOpen.stmtEntry.b:indentStmtClose - while Comma != -1 - let stmtEntryEnd=Comma - let stmtEntry=strpart(Stmts,stmtEntryBegin,stmtEntryEnd-stmtEntryBegin) - let Stmts=strpart(Stmts,Comma+1) - let Comma=match(Stmts,',') - let b:indentStmts=b:indentStmts.'\|'.b:indentStmtOpen.stmtEntry.b:indentStmtClose - endwhile - let stmtEntry=Stmts - let b:indentStmts=b:indentStmts.'\|'.b:indentStmtOpen.stmtEntry.b:indentStmtClose -endfunction - -function GenericDedentStmts(stmts) - let Stmts=a:stmts - let Comma=match(Stmts,',') - if Comma == -1 || Comma == strlen(Stmts)-1 - echoerr "Must supply a comma separated list of at least 2 entries." - echoerr "Supplied list: <".Stmts.">" - return - endif - - if !exists("b:dedentStmtOpen") - let b:dedentStmtOpen='\<' - endif - if !exists("b:dedentStmtClose") - let b:dedentStmtClose='\>' - endif - if !exists("b:dedentStmts") - let b:dedentStmts='' - endif - if b:dedentStmts != '' - let b:dedentStmts=b:dedentStmts.'\|' - endif - call DebugGenericIndent(expand("<sfile>").": "."b:dedentStmtOpen: ".b:dedentStmtOpen.", b:dedentStmtClose: ".b:dedentStmtClose.", b:dedentStmts: ".b:dedentStmts.", Stmts: ".Stmts) - let stmtEntryBegin=0 - let stmtEntryEnd=Comma - let stmtEntry=strpart(Stmts,stmtEntryBegin,stmtEntryEnd-stmtEntryBegin) - let Stmts=strpart(Stmts,Comma+1) - let Comma=match(Stmts,',') - let b:dedentStmts=b:dedentStmts.b:dedentStmtOpen.stmtEntry.b:dedentStmtClose - while Comma != -1 - let stmtEntryEnd=Comma - let stmtEntry=strpart(Stmts,stmtEntryBegin,stmtEntryEnd-stmtEntryBegin) - let Stmts=strpart(Stmts,Comma+1) - let Comma=match(Stmts,',') - let b:dedentStmts=b:dedentStmts.'\|'.b:dedentStmtOpen.stmtEntry.b:dedentStmtClose - endwhile - let stmtEntry=Stmts - let b:dedentStmts=b:dedentStmts.'\|'.b:dedentStmtOpen.stmtEntry.b:dedentStmtClose -endfunction - -" Debugging function. Displays messages in the command area which can be -" reviewed using ':messages'. To turn it on use ':let b:DEBUGGING=1'. Once -" on, turn off by using ':let b:DEBUGGING=0. If you don't want it at all and -" feel it's slowing down your editing (you must have an _awfully_ slow -" machine!;-> ), you can just comment out the calls to it from 'GenericIndent' -" below. No need to remove the function or the calls, tho', as you never can -" tell when they might come in handy!;-) -function DebugGenericIndent(msg) - if exists("b:DEBUGGING") && b:DEBUGGING - echomsg '['.s:hit.']'.s:myScriptName."::".a:msg - endif -endfunction - -function GenericIndent() - " save ignore case option. Have to set noignorecase for the match - " functions to do their job the way we want them to! - " NOTE: if you add a return to this function be sure you do - " if IgnoreCase | set ignorecase | endif - " before returning. You can just cut and paste from here. - let IgnoreCase=&ignorecase - " let b:case_insensitive=1 if you want to ignore case, e.g. DOS batch files - if !exists("b:case_insensitive") - set noignorecase - endif - " this is used to let DebugGenericIndent display which invocation of the - " function goes with which messages. - let s:hit=s:hit+1 - let lnum=v:lnum - let cline=getline(lnum) - let lnum=prevnonblank(lnum) - if lnum==0 | if IgnoreCase | set ignorecase | endif | return 0 | endif - let pline=getline(lnum) - let ndnt=indent(lnum) - if !exists("b:allStmts") - call GenericAllStmts() - endif - - call DebugGenericIndent(expand("<sfile>").": "."cline=<".cline.">, pline=<".pline.">, lnum=".lnum.", v:lnum=".v:lnum.", ndnt=".ndnt) - if lnum==v:lnum - " current line, only check dedent - " - " just dedented this line, don't need to do it again. - " another dedentStmts was added or an end%[_*] was completed. - if s:lastVlnum==v:lnum - if IgnoreCase | set ignorecase | endif - return ndnt - endif - let s:lastVlnum=v:lnum - call DebugGenericIndent(expand("<sfile>").": "."Checking dedent") - let srcStr=cline - let dedentKeyBegin=match(srcStr,b:dedentStmts) - if dedentKeyBegin != -1 - let dedentKeyEnd=matchend(srcStr,b:dedentStmts) - let dedentKeyStr=strpart(srcStr,dedentKeyBegin,dedentKeyEnd-dedentKeyBegin) - "only dedent if it's the beginning of the line - if match(srcStr,'^\s*\<'.dedentKeyStr.'\>') != -1 - call DebugGenericIndent(expand("<sfile>").": "."It's the beginning of the line, dedent") - let ndnt=ndnt-&shiftwidth - endif - endif - call DebugGenericIndent(expand("<sfile>").": "."dedent - returning ndnt=".ndnt) - else - " previous line, only check indent - call DebugGenericIndent(expand("<sfile>").": "."Checking indent") - let srcStr=pline - let indentKeyBegin=match(srcStr,b:indentStmts) - if indentKeyBegin != -1 - " only indent if it's the last indentStmts in the line - let allKeyBegin=match(srcStr,b:allStmts) - let allKeyEnd=matchend(srcStr,b:allStmts) - let allKeyStr=strpart(srcStr,allKeyBegin,allKeyEnd-allKeyBegin) - let srcStr=strpart(srcStr,allKeyEnd) - let allKeyBegin=match(srcStr,b:allStmts) - if allKeyBegin != -1 - " not the end of the line, check what is and only indent if - " it's an indentStmts - call DebugGenericIndent(expand("<sfile>").": "."Multiple words in line, checking if last is indent") - while allKeyBegin != -1 - let allKeyEnd=matchend(srcStr,b:allStmts) - let allKeyStr=strpart(srcStr,allKeyBegin,allKeyEnd-allKeyBegin) - let srcStr=strpart(srcStr,allKeyEnd) - let allKeyBegin=match(srcStr,b:allStmts) - endwhile - if match(b:indentStmts,allKeyStr) != -1 - call DebugGenericIndent(expand("<sfile>").": "."Last word in line is indent") - let ndnt=ndnt+&shiftwidth - endif - else - " it's the last indentStmts in the line, go ahead and indent - let ndnt=ndnt+&shiftwidth - endif - endif - call DebugGenericIndent(expand("<sfile>").": "."indent - returning ndnt=".ndnt) - endif - if IgnoreCase | set ignorecase | endif - return ndnt -endfunction - - -" TODO: I'm open! -" -" BUGS: You tell me! Probably. I just haven't found one yet or haven't been -" told about one. -" diff --git a/share/vim/vim72/indent/cmake.vim b/share/vim/vim72/indent/cmake.vim deleted file mode 100644 index 4315ad23af..0000000000 --- a/share/vim/vim72/indent/cmake.vim +++ /dev/null @@ -1,92 +0,0 @@ -" ============================================================================= -" -" Program: CMake - Cross-Platform Makefile Generator -" Module: $RCSfile: cmake-indent.vim,v $ -" Language: VIM -" Date: $Date: 2006/09/23 21:09:08 $ -" Version: $Revision: 1.7 $ -" -" ============================================================================= - -" Vim indent file -" Language: CMake (ft=cmake) -" Author: Andy Cedilnik <andy.cedilnik@kitware.com> -" Maintainer: Andy Cedilnik <andy.cedilnik@kitware.com> -" Last Change: $Date: 2006/09/23 21:09:08 $ -" Version: $Revision: 1.7 $ -" -" Licence: The CMake license applies to this file. See -" http://www.cmake.org/HTML/Copyright.html -" This implies that distribution with Vim is allowed - -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -setlocal indentexpr=CMakeGetIndent(v:lnum) - -" Only define the function once. -if exists("*CMakeGetIndent") - finish -endif - -fun! CMakeGetIndent(lnum) - let this_line = getline(a:lnum) - - " Find a non-blank line above the current line. - let lnum = a:lnum - let lnum = prevnonblank(lnum - 1) - let previous_line = getline(lnum) - - " Hit the start of the file, use zero indent. - if lnum == 0 - return 0 - endif - - let ind = indent(lnum) - - let or = '\|' - " Regular expressions used by line indentation function. - let cmake_regex_comment = '#.*' - let cmake_regex_identifier = '[A-Za-z][A-Za-z0-9_]*' - let cmake_regex_quoted = '"\([^"\\]\|\\.\)*"' - let cmake_regex_arguments = '\(' . cmake_regex_quoted . - \ or . '\$(' . cmake_regex_identifier . ')' . - \ or . '[^()\\#"]' . or . '\\.' . '\)*' - - let cmake_indent_comment_line = '^\s*' . cmake_regex_comment - let cmake_indent_blank_regex = '^\s*$' - let cmake_indent_open_regex = '^\s*' . cmake_regex_identifier . - \ '\s*(' . cmake_regex_arguments . - \ '\(' . cmake_regex_comment . '\)\?$' - - let cmake_indent_close_regex = '^' . cmake_regex_arguments . - \ ')\s*' . - \ '\(' . cmake_regex_comment . '\)\?$' - - let cmake_indent_begin_regex = '^\s*\(IF\|MACRO\|FOREACH\|ELSE\|ELSEIF\|WHILE\)\s*(' - let cmake_indent_end_regex = '^\s*\(ENDIF\|ENDFOREACH\|ENDMACRO\|ELSE\|ELSEIF\|ENDWHILE\)\s*(' - - " Add - if previous_line =~? cmake_indent_comment_line " Handle comments - let ind = ind - else - if previous_line =~? cmake_indent_begin_regex - let ind = ind + &sw - endif - if previous_line =~? cmake_indent_open_regex - let ind = ind + &sw - endif - endif - - " Subtract - if this_line =~? cmake_indent_end_regex - let ind = ind - &sw - endif - if previous_line =~? cmake_indent_close_regex - let ind = ind - &sw - endif - - return ind -endfun diff --git a/share/vim/vim72/indent/cpp.vim b/share/vim/vim72/indent/cpp.vim deleted file mode 100644 index 9ae126ac4d..0000000000 --- a/share/vim/vim72/indent/cpp.vim +++ /dev/null @@ -1,13 +0,0 @@ -" Vim indent file -" Language: C++ -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2001 Jun 12 - -" Only load this indent file when no other was loaded. -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -" C++ indenting is built-in, thus this is very simple -setlocal cindent diff --git a/share/vim/vim72/indent/eruby.vim b/share/vim/vim72/indent/eruby.vim deleted file mode 100644 index 931eaac385..0000000000 --- a/share/vim/vim72/indent/eruby.vim +++ /dev/null @@ -1,78 +0,0 @@ -" Vim indent file -" Language: eRuby -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> -" Info: $Id: eruby.vim,v 1.16 2008/06/29 04:18:43 tpope Exp $ -" URL: http://vim-ruby.rubyforge.org -" Anon CVS: See above site -" Release Coordinator: Doug Kearns <dougkearns@gmail.com> - -if exists("b:did_indent") - finish -endif - -runtime! indent/ruby.vim -unlet! b:did_indent -setlocal indentexpr= - -if exists("b:eruby_subtype") - exe "runtime! indent/".b:eruby_subtype.".vim" -else - runtime! indent/html.vim -endif -unlet! b:did_indent - -if &l:indentexpr == '' - if &l:cindent - let &l:indentexpr = 'cindent(v:lnum)' - else - let &l:indentexpr = 'indent(prevnonblank(v:lnum-1))' - endif -endif -let b:eruby_subtype_indentexpr = &l:indentexpr - -let b:did_indent = 1 - -setlocal indentexpr=GetErubyIndent() -setlocal indentkeys=o,O,*<Return>,<>>,{,},0),0],o,O,!^F,=end,=else,=elsif,=rescue,=ensure,=when - -" Only define the function once. -if exists("*GetErubyIndent") - finish -endif - -function! GetErubyIndent(...) - if a:0 && a:1 == '.' - let v:lnum = line('.') - elseif a:0 && a:1 =~ '^\d' - let v:lnum = a:1 - endif - let vcol = col('.') - call cursor(v:lnum,1) - let inruby = searchpair('<%','','%>','W') - call cursor(v:lnum,vcol) - if inruby && getline(v:lnum) !~ '^<%\|^\s*-\=%>' - let ind = GetRubyIndent() - else - exe "let ind = ".b:eruby_subtype_indentexpr - endif - let lnum = prevnonblank(v:lnum-1) - let line = getline(lnum) - let cline = getline(v:lnum) - if cline =~# '<%-\=\s*\%(}\|end\|else\|\%(ensure\|rescue\|elsif\|when\).\{-\}\)\s*\%(-\=%>\|$\)' - let ind = ind - &sw - endif - if line =~# '\%({\|\<do\)\%(\s*|[^|]*|\)\=\s*-\=%>' - let ind = ind + &sw - elseif line =~# '<%-\=\s*\%(module\|class\|def\|if\|for\|while\|until\|else\|elsif\|case\|when\|unless\|begin\|ensure\|rescue\)\>.*%>' - let ind = ind + &sw - endif - if line =~# '^\s*<%[=#-]\=\s*$' && cline !~# '^\s*end\>' - let ind = ind + &sw - endif - if cline =~# '^\s*-\=%>\s*$' - let ind = ind - &sw - endif - return ind -endfunction - -" vim:set sw=2 sts=2 ts=8 noet: diff --git a/share/vim/vim72/indent/fortran.vim b/share/vim/vim72/indent/fortran.vim deleted file mode 100644 index 7a6b04f280..0000000000 --- a/share/vim/vim72/indent/fortran.vim +++ /dev/null @@ -1,167 +0,0 @@ -" Vim indent file -" Language: Fortran95 (and Fortran90, Fortran77, F and elf90) -" Version: 0.37 -" URL: http://www.unb.ca/chem/ajit/indent/fortran.vim -" Last Change: 2006 Nov 16 -" Maintainer: Ajit J. Thakkar <ajit@unb.ca>; <http://www.unb.ca/chem/ajit/> -" Usage: Do :help fortran-indent from Vim - -" Only load this indent file when no other was loaded. -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -setlocal indentkeys+==~end,=~case,=~if,=~else,=~do,=~where,=~elsewhere,=~select -setlocal indentkeys+==~endif,=~enddo,=~endwhere,=~endselect -setlocal indentkeys+==~type,=~interface - -" Determine whether this is a fixed or free format source file -" if this hasn't been done yet -if !exists("b:fortran_fixed_source") - if exists("fortran_free_source") - " User guarantees free source form - let b:fortran_fixed_source = 0 - elseif exists("fortran_fixed_source") - " User guarantees fixed source form - let b:fortran_fixed_source = 1 - else - " f90 and f95 allow both fixed and free source form - " assume fixed source form unless signs of free source form - " are detected in the first five columns of the first 250 lines - " Detection becomes more accurate and time-consuming if more lines - " are checked. Increase the limit below if you keep lots of comments at - " the very top of each file and you have a fast computer - let s:lmax = 250 - if ( s:lmax > line("$") ) - let s:lmax = line("$") - endif - let b:fortran_fixed_source = 1 - let s:ln=1 - while s:ln <= s:lmax - let s:test = strpart(getline(s:ln),0,5) - if s:test[0] !~ '[Cc*!#]' && s:test !~ '^ \+[!#]' && s:test =~ '[^ 0-9\t]' - let b:fortran_fixed_source = 0 - break - endif - let s:ln = s:ln + 1 - endwhile - endif -endif - -" Define the appropriate indent function but only once -if (b:fortran_fixed_source == 1) - setlocal indentexpr=FortranGetFixedIndent() - if exists("*FortranGetFixedIndent") - finish - endif -else - setlocal indentexpr=FortranGetFreeIndent() - if exists("*FortranGetFreeIndent") - finish - endif -endif - -let s:cposet=&cpoptions -set cpoptions-=C - -function FortranGetIndent(lnum) - let ind = indent(a:lnum) - let prevline=getline(a:lnum) - " Strip tail comment - let prevstat=substitute(prevline, '!.*$', '', '') - - "Indent do loops only if they are all guaranteed to be of do/end do type - if exists("b:fortran_do_enddo") || exists("g:fortran_do_enddo") - if prevstat =~? '^\s*\(\d\+\s\)\=\s*\(\a\w*\s*:\)\=\s*do\>' - let ind = ind + &sw - endif - if getline(v:lnum) =~? '^\s*\(\d\+\s\)\=\s*end\s*do\>' - let ind = ind - &sw - endif - endif - - "Add a shiftwidth to statements following if, else, case, - "where, elsewhere, type and interface statements - if prevstat =~? '^\s*\(\d\+\s\)\=\s*\(else\|case\|where\|elsewhere\)\>' - \ ||prevstat =~? '^\s*\(\d\+\s\)\=\s*\(type\|interface\)\>' - \ || prevstat =~? '^\s*\(\d\+\s\)\=\s*\(\a\w*\s*:\)\=\s*if\>' - let ind = ind + &sw - " Remove unwanted indent after logical and arithmetic ifs - if prevstat =~? '\<if\>' && prevstat !~? '\<then\>' - let ind = ind - &sw - endif - " Remove unwanted indent after type( statements - if prevstat =~? '\<type\s*(' - let ind = ind - &sw - endif - endif - - "Subtract a shiftwidth from else, elsewhere, case, end if, - " end where, end select, end interface and end type statements - if getline(v:lnum) =~? '^\s*\(\d\+\s\)\=\s*' - \. '\(else\|elsewhere\|case\|end\s*\(if\|where\|select\|interface\|type\)\)\>' - let ind = ind - &sw - " Fix indent for case statement immediately after select - if prevstat =~? '\<select\>' - let ind = ind + &sw - endif - endif - - return ind -endfunction - -function FortranGetFreeIndent() - "Find the previous non-blank line - let lnum = prevnonblank(v:lnum - 1) - - "Use zero indent at the top of the file - if lnum == 0 - return 0 - endif - - let ind=FortranGetIndent(lnum) - return ind -endfunction - -function FortranGetFixedIndent() - let currline=getline(v:lnum) - "Don't indent comments, continuation lines and labelled lines - if strpart(currline,0,6) =~ '[^ \t]' - let ind = indent(v:lnum) - return ind - endif - - "Find the previous line which is not blank, not a comment, - "not a continuation line, and does not have a label - let lnum = v:lnum - 1 - while lnum > 0 - let prevline=getline(lnum) - if (prevline =~ "^[C*!]") || (prevline =~ "^\s*$") - \ || (strpart(prevline,5,1) !~ "[ 0]") - " Skip comments, blank lines and continuation lines - let lnum = lnum - 1 - else - let test=strpart(prevline,0,5) - if test =~ "[0-9]" - " Skip lines with statement numbers - let lnum = lnum - 1 - else - break - endif - endif - endwhile - - "First line must begin at column 7 - if lnum == 0 - return 6 - endif - - let ind=FortranGetIndent(lnum) - return ind -endfunction - -let &cpoptions=s:cposet -unlet s:cposet - -" vim:sw=2 tw=130 diff --git a/share/vim/vim72/indent/gitconfig.vim b/share/vim/vim72/indent/gitconfig.vim deleted file mode 100644 index 7ce0c715bd..0000000000 --- a/share/vim/vim72/indent/gitconfig.vim +++ /dev/null @@ -1,35 +0,0 @@ -" Vim indent file -" Language: git config file -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> -" Last Change: 2008 Jun 04 - -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -setlocal autoindent -setlocal indentexpr=GetGitconfigIndent() -setlocal indentkeys=o,O,*<Return>,0[,],0;,0#,=,!^F - -" Only define the function once. -if exists("*GetGitconfigIndent") - finish -endif - -function! GetGitconfigIndent() - let line = getline(prevnonblank(v:lnum-1)) - let cline = getline(v:lnum) - if line =~ '\\\@<!\%(\\\\\)*\\$' - " odd number of slashes, in a line continuation - return 2 * &sw - elseif cline =~ '^\s*\[' - return 0 - elseif cline =~ '^\s*\a' - return &sw - elseif cline == '' && line =~ '^\[' - return &sw - else - return -1 - endif -endfunction diff --git a/share/vim/vim72/indent/haml.vim b/share/vim/vim72/indent/haml.vim deleted file mode 100644 index c1feee09a9..0000000000 --- a/share/vim/vim72/indent/haml.vim +++ /dev/null @@ -1,73 +0,0 @@ -" Vim indent file -" Language: HAML -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> -" Last Change: 2007 Dec 16 - -if exists("b:did_indent") - finish -endif -runtime! indent/ruby.vim -unlet! b:did_indent -let b:did_indent = 1 - -setlocal autoindent sw=2 et -setlocal indentexpr=GetHamlIndent() -setlocal indentkeys=o,O,*<Return>,},],0),!^F,=end,=else,=elsif,=rescue,=ensure,=when - -" Only define the function once. -if exists("*GetHamlIndent") - finish -endif - -let s:attributes = '\%({.\{-\}}\|\[.\{-\}\]\)' -let s:tag = '\%([%.#][[:alnum:]_-]\+\|'.s:attributes.'\)*[<>]*' - -if !exists('g:haml_self_closing_tags') - let g:haml_self_closing_tags = 'meta|link|img|hr|br' -endif - -function! GetHamlIndent() - let lnum = prevnonblank(v:lnum-1) - if lnum == 0 - return 0 - endif - let line = substitute(getline(lnum),'\s\+$','','') - let cline = substitute(substitute(getline(v:lnum),'\s\+$','',''),'^\s\+','','') - let lastcol = strlen(line) - let line = substitute(line,'^\s\+','','') - let indent = indent(lnum) - let cindent = indent(v:lnum) - if cline =~# '\v^-\s*%(elsif|else|when)>' - let indent = cindent < indent ? cindent : indent - &sw - endif - let increase = indent + &sw - if indent == indent(lnum) - let indent = cindent <= indent ? -1 : increase - endif - "let indent = indent == indent(lnum) ? -1 : indent - "let indent = indent > indent(lnum) + &sw ? indent(lnum) + &sw : indent - - let group = synIDattr(synID(lnum,lastcol,1),'name') - - if line =~ '^!!!' - return indent - elseif line =~ '^/\%(\[[^]]*\]\)\=$' - return increase - elseif line =~ '^:' - return increase - elseif line =~ '^'.s:tag.'[=~-]\s*\%(\%(if\|else\|elsif\|unless\|case\|when\|while\|until\|for\|begin\|module\|class\|def\)\>\%(.*\<end\>\)\@!\|.*do |[^|]*|\s*$\)' - return increase - elseif line == '-#' - return increase - elseif group =~? '\v^(hamlSelfCloser)$' || line =~? '^%\v%('.g:haml_self_closing_tags.')>' - return indent - elseif group =~? '\v^%(hamlTag|hamlAttributesDelimiter|hamlObjectDelimiter|hamlClass|hamlId|htmlTagName|htmlSpecialTagName)$' - return increase - elseif synIDattr(synID(v:lnum,1,1),'name') ==? 'hamlRubyFilter' - return GetRubyIndent() - else - return indent - endif -endfunction - -" vim:set sw=2: diff --git a/share/vim/vim72/indent/javascript.vim b/share/vim/vim72/indent/javascript.vim deleted file mode 100644 index cf4a4f3ce4..0000000000 --- a/share/vim/vim72/indent/javascript.vim +++ /dev/null @@ -1,15 +0,0 @@ -" Vim indent file -" Language: Javascript -" Maintainer: None! Wanna improve this? -" Last Change: 2007 Jan 22 - -" Only load this indent file when no other was loaded. -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -" C indenting is not too bad. -setlocal cindent - -let b:undo_indent = "setl cin<" diff --git a/share/vim/vim72/indent/mupad.vim b/share/vim/vim72/indent/mupad.vim deleted file mode 100644 index 307aaf047f..0000000000 --- a/share/vim/vim72/indent/mupad.vim +++ /dev/null @@ -1,35 +0,0 @@ -" Vim indent file -" Language: MuPAD source files -" Maintainer: Dave Silvia <dsilvia@mchsi.com> -" Filenames: *.mu -" Date: 6/30/2004 - -if exists("b:did_indent") - finish -endif - -let b:did_indent = 1 - -runtime indent/GenericIndent.vim - -let b:indentStmts='' -let b:dedentStmts='' -let b:allStmts='' -" NOTE: b:indentStmts, b:dedentStmts, and b:allStmts need to be initialized -" to '' before callin the functions because 'indent.vim' explicitly -" 'unlet's b:did_indent. This means that the lists will compound if -" you change back and forth between buffers. This is true as of -" version 6.3, 6/23/2004. -setlocal indentexpr=GenericIndent() -setlocal indentkeys==end_proc,=then,=else,=elif,=end_if,=end_case,=until,=end_repeat,=end_domain,=end_for,=end_while,=end,o,O - -call GenericIndentStmts('begin,if,then,else,elif,case,repeat,until,domain,do') -call GenericDedentStmts('end_proc,then,else,elif,end_if,end_case,until,end_repeat,end_domain,end_for,end_while,end') -call GenericAllStmts() - - -" TODO: More comprehensive indentstmt, dedentstmt, and indentkeys values. -" -" BUGS: You tell me! Probably. I just haven't found one yet or haven't been -" told about one. -" diff --git a/share/vim/vim72/indent/perl.vim b/share/vim/vim72/indent/perl.vim deleted file mode 100644 index b3a9fc0214..0000000000 --- a/share/vim/vim72/indent/perl.vim +++ /dev/null @@ -1,180 +0,0 @@ -" Vim indent file -" Language: Perl -" Author: Rafael Garcia-Suarez <rgarciasuarez@free.fr> -" URL: http://rgarciasuarez.free.fr/vim/indent/perl.vim -" Last Change: 2005 Sep 07 - -" Suggestions and improvements by : -" Aaron J. Sherman (use syntax for hints) -" Artem Chuprina (play nice with folding) - -" TODO things that are not or not properly indented (yet) : -" - Continued statements -" print "foo", -" "bar"; -" print "foo" -" if bar(); -" - Multiline regular expressions (m//x) -" (The following probably needs modifying the perl syntax file) -" - qw() lists -" - Heredocs with terminators that don't match \I\i* - -" Only load this indent file when no other was loaded. -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -" Is syntax highlighting active ? -let b:indent_use_syntax = has("syntax") - -setlocal indentexpr=GetPerlIndent() -setlocal indentkeys+=0=,0),0=or,0=and -if !b:indent_use_syntax - setlocal indentkeys+=0=EO -endif - -" Only define the function once. -if exists("*GetPerlIndent") - finish -endif - -let s:cpo_save = &cpo -set cpo-=C - -function GetPerlIndent() - - " Get the line to be indented - let cline = getline(v:lnum) - - " Indent POD markers to column 0 - if cline =~ '^\s*=\L\@!' - return 0 - endif - - " Don't reindent coments on first column - if cline =~ '^#.' - return 0 - endif - - " Get current syntax item at the line's first char - let csynid = '' - if b:indent_use_syntax - let csynid = synIDattr(synID(v:lnum,1,0),"name") - endif - - " Don't reindent POD and heredocs - if csynid == "perlPOD" || csynid == "perlHereDoc" || csynid =~ "^pod" - return indent(v:lnum) - endif - - " Indent end-of-heredocs markers to column 0 - if b:indent_use_syntax - " Assumes that an end-of-heredoc marker matches \I\i* to avoid - " confusion with other types of strings - if csynid == "perlStringStartEnd" && cline =~ '^\I\i*$' - return 0 - endif - else - " Without syntax hints, assume that end-of-heredocs markers begin with EO - if cline =~ '^\s*EO' - return 0 - endif - endif - - " Now get the indent of the previous perl line. - - " Find a non-blank line above the current line. - let lnum = prevnonblank(v:lnum - 1) - " Hit the start of the file, use zero indent. - if lnum == 0 - return 0 - endif - let line = getline(lnum) - let ind = indent(lnum) - " Skip heredocs, POD, and comments on 1st column - if b:indent_use_syntax - let skippin = 2 - while skippin - let synid = synIDattr(synID(lnum,1,0),"name") - if (synid == "perlStringStartEnd" && line =~ '^\I\i*$') - \ || (skippin != 2 && synid == "perlPOD") - \ || (skippin != 2 && synid == "perlHereDoc") - \ || synid == "perlComment" - \ || synid =~ "^pod" - let lnum = prevnonblank(lnum - 1) - if lnum == 0 - return 0 - endif - let line = getline(lnum) - let ind = indent(lnum) - let skippin = 1 - else - let skippin = 0 - endif - endwhile - else - if line =~ "^EO" - let lnum = search("<<[\"']\\=EO", "bW") - let line = getline(lnum) - let ind = indent(lnum) - endif - endif - - " Indent blocks enclosed by {} or () - if b:indent_use_syntax - " Find a real opening brace - let bracepos = match(line, '[(){}]', matchend(line, '^\s*[)}]')) - while bracepos != -1 - let synid = synIDattr(synID(lnum, bracepos + 1, 0), "name") - " If the brace is highlighted in one of those groups, indent it. - " 'perlHereDoc' is here only to handle the case '&foo(<<EOF)'. - if synid == "" - \ || synid == "perlMatchStartEnd" - \ || synid == "perlHereDoc" - \ || synid =~ "^perlFiledescStatement" - \ || synid =~ '^perl\(Sub\|BEGINEND\|If\)Fold' - let brace = strpart(line, bracepos, 1) - if brace == '(' || brace == '{' - let ind = ind + &sw - else - let ind = ind - &sw - endif - endif - let bracepos = match(line, '[(){}]', bracepos + 1) - endwhile - let bracepos = matchend(cline, '^\s*[)}]') - if bracepos != -1 - let synid = synIDattr(synID(v:lnum, bracepos, 0), "name") - if synid == "" - \ || synid == "perlMatchStartEnd" - \ || synid =~ '^perl\(Sub\|BEGINEND\|If\)Fold' - let ind = ind - &sw - endif - endif - else - if line =~ '[{(]\s*\(#[^)}]*\)\=$' - let ind = ind + &sw - endif - if cline =~ '^\s*[)}]' - let ind = ind - &sw - endif - endif - - " Indent lines that begin with 'or' or 'and' - if cline =~ '^\s*\(or\|and\)\>' - if line !~ '^\s*\(or\|and\)\>' - let ind = ind + &sw - endif - elseif line =~ '^\s*\(or\|and\)\>' - let ind = ind - &sw - endif - - return ind - -endfunction - -let &cpo = s:cpo_save -unlet s:cpo_save - -" vim:ts=8:sts=2:sw=2 diff --git a/share/vim/vim72/indent/php.vim b/share/vim/vim72/indent/php.vim deleted file mode 100644 index 6124eb2f66..0000000000 --- a/share/vim/vim72/indent/php.vim +++ /dev/null @@ -1,738 +0,0 @@ -" Vim indent file -" Language: PHP -" Author: John Wellesz <John.wellesz (AT) teaser (DOT) fr> -" URL: http://www.2072productions.com/vim/indent/php.vim -" Last Change: 2008 June 7th -" Newsletter: http://www.2072productions.com/?to=php-indent-for-vim-newsletter.php -" Version: 1.28 -" -" If you find a bug, please e-mail me at John.wellesz (AT) teaser (DOT) fr -" with an example of code that breaks the algorithm. -" -" ---> The change log and all the comments have been removed from this file. -" -" For a complete change log and fully commented code, download the script on -" 2072productions.com at the URI provided above. -" -" If you find a bug, please e-mail me at John.wellesz (AT) teaser (DOT) fr -" with an example of code that breaks the algorithm. -" -" -" Thanks a lot for using this script. -" -" -" NOTE: This script must be used with PHP syntax ON and with the php syntax -" script by Lutz Eymers (http://www.isp.de/data/php.vim ) or with the -" script by Peter Hodge (http://www.vim.org/scripts/script.php?script_id=1571 ) -" the later is bunbdled by default with vim 7. -" -" -" In the case you have syntax errors in your script such as HereDoc end -" identifiers not at col 1 you'll have to indent your file 2 times (This -" script will automatically put HereDoc end identifiers at col 1 if -" they are followed by a ';'). -" -" -" NOTE: If you are editing file in Unix file format and that (by accident) -" there are '\r' before new lines, this script won't be able to proceed -" correctly and will make many mistakes because it won't be able to match -" '\s*$' correctly. -" So you have to remove those useless characters first with a command like: -" -" :%s /\r$//g -" -" or simply 'let' the option PHP_removeCRwhenUnix to 1 and the script will -" silently remove them when VIM load this script (at each bufread). -" -" -" Options: PHP_autoformatcomment = 0 to not enable autoformating of comment by -" default, if set to 0, this script will let the 'formatoptions' setting intact. -" -" Options: PHP_default_indenting = # of sw (default is 0), # of sw will be -" added to the indent of each line of PHP code. -" -" Options: PHP_removeCRwhenUnix = 1 to make the script automatically remove CR -" at end of lines (by default this option is unset), NOTE that you -" MUST remove CR when the fileformat is UNIX else the indentation -" won't be correct! -" -" Options: PHP_BracesAtCodeLevel = 1 to indent the '{' and '}' at the same -" level than the code they contain. -" Exemple: -" Instead of: -" if ($foo) -" { -" foo(); -" } -" -" You will write: -" if ($foo) -" { -" foo(); -" } -" -" NOTE: The script will be a bit slower if you use this option because -" some optimizations won't be available. -" -" Options: PHP_vintage_case_default_indent = 1 (defaults to 0) to add a meaningless indent -" befaore 'case:' and 'default":' statement in switch block -" - -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - - -let php_sync_method = 0 - - -if exists("PHP_default_indenting") - let b:PHP_default_indenting = PHP_default_indenting * &sw -else - let b:PHP_default_indenting = 0 -endif - -if exists("PHP_BracesAtCodeLevel") - let b:PHP_BracesAtCodeLevel = PHP_BracesAtCodeLevel -else - let b:PHP_BracesAtCodeLevel = 0 -endif - - -if exists("PHP_autoformatcomment") - let b:PHP_autoformatcomment = PHP_autoformatcomment -else - let b:PHP_autoformatcomment = 1 -endif - -if exists("PHP_vintage_case_default_indent") - let b:PHP_vintage_case_default_indent = PHP_vintage_case_default_indent -else - let b:PHP_vintage_case_default_indent = 0 -endif - - - -let b:PHP_lastindented = 0 -let b:PHP_indentbeforelast = 0 -let b:PHP_indentinghuge = 0 -let b:PHP_CurrentIndentLevel = b:PHP_default_indenting -let b:PHP_LastIndentedWasComment = 0 -let b:PHP_InsideMultilineComment = 0 -let b:InPHPcode = 0 -let b:InPHPcode_checked = 0 -let b:InPHPcode_and_script = 0 -let b:InPHPcode_tofind = "" -let b:PHP_oldchangetick = b:changedtick -let b:UserIsTypingComment = 0 -let b:optionsset = 0 - -setlocal nosmartindent -setlocal noautoindent -setlocal nocindent -setlocal nolisp - -setlocal indentexpr=GetPhpIndent() -setlocal indentkeys=0{,0},0),:,!^F,o,O,e,*<Return>,=?>,=<?,=*/ - - - -let s:searchpairflags = 'bWr' - -if &fileformat == "unix" && exists("PHP_removeCRwhenUnix") && PHP_removeCRwhenUnix - silent! %s/\r$//g -endif - -if exists("*GetPhpIndent") - finish " XXX -endif - -let s:endline= '\s*\%(//.*\|#.*\|/\*.*\*/\s*\)\=$' -let s:PHP_startindenttag = '<?\%(.*?>\)\@!\|<script[^>]*>\%(.*<\/script>\)\@!' -"setlocal debug=msg " XXX - - -function! GetLastRealCodeLNum(startline) " {{{ - - let lnum = a:startline - - if b:GetLastRealCodeLNum_ADD && b:GetLastRealCodeLNum_ADD == lnum + 1 - let lnum = b:GetLastRealCodeLNum_ADD - endif - - let old_lnum = lnum - - while lnum > 1 - let lnum = prevnonblank(lnum) - let lastline = getline(lnum) - - if b:InPHPcode_and_script && lastline =~ '?>\s*$' - let lnum = lnum - 1 - elseif lastline =~ '^\s*?>.*<?\%(php\)\=\s*$' - let lnum = lnum - 1 - elseif lastline =~ '^\s*\%(//\|#\|/\*.*\*/\s*$\)' - let lnum = lnum - 1 - elseif lastline =~ '\*/\s*$' - call cursor(lnum, 1) - if lastline !~ '^\*/' - call search('\*/', 'W') - endif - let lnum = searchpair('/\*', '', '\*/', s:searchpairflags, 'Skippmatch2()') - - let lastline = getline(lnum) - if lastline =~ '^\s*/\*' - let lnum = lnum - 1 - else - break - endif - - - elseif lastline =~? '\%(//\s*\|?>.*\)\@<!<?\%(php\)\=\s*$\|^\s*<script\>' - - while lastline !~ '\(<?.*\)\@<!?>' && lnum > 1 - let lnum = lnum - 1 - let lastline = getline(lnum) - endwhile - if lastline =~ '^\s*?>' - let lnum = lnum - 1 - else - break - endif - - - elseif lastline =~? '^\a\w*;\=$' && lastline !~? s:notPhpHereDoc " XXX 0607 - let tofind=substitute( lastline, '\(\a\w*\);\=', '<<<''\\=\1''\\=$', '') " XXX 0607 - while getline(lnum) !~? tofind && lnum > 1 - let lnum = lnum - 1 - endwhile - else - break - endif - endwhile - - if lnum==1 && getline(lnum)!~ '<?' - let lnum=0 - endif - - if b:InPHPcode_and_script && !b:InPHPcode - let b:InPHPcode_and_script = 0 - endif - - - - return lnum -endfunction " }}} - -function! Skippmatch2() - - let line = getline(".") - - if line =~ '\%(".*\)\@<=/\*\%(.*"\)\@=' || line =~ '\%(\%(//\|#\).*\)\@<=/\*' - return 1 - else - return 0 - endif -endfun - -function! Skippmatch() " {{{ - let synname = synIDattr(synID(line("."), col("."), 0), "name") - if synname == "Delimiter" || synname == "phpRegionDelimiter" || synname =~# "^phpParent" || synname == "phpArrayParens" || synname =~# '^php\%(Block\|Brace\)' || synname == "javaScriptBraces" || synname =~# "^phpComment" && b:UserIsTypingComment - return 0 - else - return 1 - endif -endfun " }}} - -function! FindOpenBracket(lnum) " {{{ - call cursor(a:lnum, 1) - return searchpair('{', '', '}', 'bW', 'Skippmatch()') -endfun " }}} - -function! FindTheIfOfAnElse (lnum, StopAfterFirstPrevElse) " {{{ - - if getline(a:lnum) =~# '^\s*}\s*else\%(if\)\=\>' - let beforeelse = a:lnum - else - let beforeelse = GetLastRealCodeLNum(a:lnum - 1) - endif - - if !s:level - let s:iftoskip = 0 - endif - - if getline(beforeelse) =~# '^\s*\%(}\s*\)\=else\%(\s*if\)\@!\>' - let s:iftoskip = s:iftoskip + 1 - endif - - if getline(beforeelse) =~ '^\s*}' - let beforeelse = FindOpenBracket(beforeelse) - - if getline(beforeelse) =~ '^\s*{' - let beforeelse = GetLastRealCodeLNum(beforeelse - 1) - endif - endif - - - if !s:iftoskip && a:StopAfterFirstPrevElse && getline(beforeelse) =~# '^\s*\%([}]\s*\)\=else\%(if\)\=\>' - return beforeelse - endif - - if getline(beforeelse) !~# '^\s*if\>' && beforeelse>1 || s:iftoskip && beforeelse>1 - - if s:iftoskip && getline(beforeelse) =~# '^\s*if\>' - let s:iftoskip = s:iftoskip - 1 - endif - - let s:level = s:level + 1 - let beforeelse = FindTheIfOfAnElse(beforeelse, a:StopAfterFirstPrevElse) - endif - - return beforeelse - -endfunction " }}} - -function! IslinePHP (lnum, tofind) " {{{ - let cline = getline(a:lnum) - - if a:tofind=="" - let tofind = "^\\s*[\"']*\\s*\\zs\\S" - else - let tofind = a:tofind - endif - - let tofind = tofind . '\c' - - let coltotest = match (cline, tofind) + 1 - - let synname = synIDattr(synID(a:lnum, coltotest, 0), "name") - - if synname =~ '^php' || synname=="Delimiter" || synname =~? '^javaScript' - return synname - else - return "" - endif -endfunction " }}} - -let s:notPhpHereDoc = '\%(break\|return\|continue\|exit\|else\)' -let s:blockstart = '\%(\%(\%(}\s*\)\=else\%(\s\+\)\=\)\=if\>\|else\>\|while\>\|switch\>\|for\%(each\)\=\>\|declare\>\|class\>\|interface\>\|abstract\>\|try\>\|catch\>\)' - -let s:autorestoptions = 0 -if ! s:autorestoptions - au BufWinEnter,Syntax *.php,*.php3,*.php4,*.php5 call ResetOptions() - let s:autorestoptions = 1 -endif - -function! ResetOptions() - if ! b:optionsset - if b:PHP_autoformatcomment - - setlocal comments=s1:/*,mb:*,ex:*/,://,:# - - setlocal formatoptions-=t - setlocal formatoptions+=q - setlocal formatoptions+=r - setlocal formatoptions+=o - setlocal formatoptions+=w - setlocal formatoptions+=c - setlocal formatoptions+=b - endif - let b:optionsset = 1 - endif -endfunc - -function! GetPhpIndent() - - let b:GetLastRealCodeLNum_ADD = 0 - - let UserIsEditing=0 - if b:PHP_oldchangetick != b:changedtick - let b:PHP_oldchangetick = b:changedtick - let UserIsEditing=1 - endif - - if b:PHP_default_indenting - let b:PHP_default_indenting = g:PHP_default_indenting * &sw - endif - - let cline = getline(v:lnum) - - if !b:PHP_indentinghuge && b:PHP_lastindented > b:PHP_indentbeforelast - if b:PHP_indentbeforelast - let b:PHP_indentinghuge = 1 - echom 'Large indenting detected, speed optimizations engaged (v1.28)' - endif - let b:PHP_indentbeforelast = b:PHP_lastindented - endif - - if b:InPHPcode_checked && prevnonblank(v:lnum - 1) != b:PHP_lastindented - if b:PHP_indentinghuge - echom 'Large indenting deactivated' - let b:PHP_indentinghuge = 0 - let b:PHP_CurrentIndentLevel = b:PHP_default_indenting - endif - let b:PHP_lastindented = v:lnum - let b:PHP_LastIndentedWasComment=0 - let b:PHP_InsideMultilineComment=0 - let b:PHP_indentbeforelast = 0 - - let b:InPHPcode = 0 - let b:InPHPcode_checked = 0 - let b:InPHPcode_and_script = 0 - let b:InPHPcode_tofind = "" - - elseif v:lnum > b:PHP_lastindented - let real_PHP_lastindented = b:PHP_lastindented - let b:PHP_lastindented = v:lnum - endif - - - if !b:InPHPcode_checked " {{{ One time check - let b:InPHPcode_checked = 1 - - let synname = "" - if cline !~ '<?.*?>' - let synname = IslinePHP (prevnonblank(v:lnum), "") - endif - - if synname!="" - if synname != "phpHereDoc" && synname != "phpHereDocDelimiter" - let b:InPHPcode = 1 - let b:InPHPcode_tofind = "" - - if synname =~# "^phpComment" - let b:UserIsTypingComment = 1 - else - let b:UserIsTypingComment = 0 - endif - - if synname =~? '^javaScript' - let b:InPHPcode_and_script = 1 - endif - - else - let b:InPHPcode = 0 - let b:UserIsTypingComment = 0 - - let lnum = v:lnum - 1 - while getline(lnum) !~? '<<<''\=\a\w*''\=$' && lnum > 1 - let lnum = lnum - 1 - endwhile - - let b:InPHPcode_tofind = substitute( getline(lnum), '^.*<<<''\=\(\a\w*\)''\=$', '^\\s*\1;\\=$', '') " XXX 0607 - endif - else - let b:InPHPcode = 0 - let b:UserIsTypingComment = 0 - let b:InPHPcode_tofind = '<?\%(.*?>\)\@!\|<script.*>' - endif - endif "!b:InPHPcode_checked }}} - - - " Test if we are indenting PHP code {{{ - let lnum = prevnonblank(v:lnum - 1) - let last_line = getline(lnum) - - if b:InPHPcode_tofind!="" - if cline =~? b:InPHPcode_tofind - let b:InPHPcode = 1 - let b:InPHPcode_tofind = "" - let b:UserIsTypingComment = 0 - if cline =~ '\*/' - call cursor(v:lnum, 1) - if cline !~ '^\*/' - call search('\*/', 'W') - endif - let lnum = searchpair('/\*', '', '\*/', s:searchpairflags, 'Skippmatch2()') - - let b:PHP_CurrentIndentLevel = b:PHP_default_indenting - - let b:PHP_LastIndentedWasComment = 0 - - if cline =~ '^\s*\*/' - return indent(lnum) + 1 - else - return indent(lnum) - endif - - elseif cline =~? '<script\>' - let b:InPHPcode_and_script = 1 - let b:GetLastRealCodeLNum_ADD = v:lnum - endif - endif - endif - - if b:InPHPcode - - if !b:InPHPcode_and_script && last_line =~ '\%(<?.*\)\@<!?>\%(.*<?\)\@!' && IslinePHP(lnum, '?>')=~"Delimiter" - if cline !~? s:PHP_startindenttag - let b:InPHPcode = 0 - let b:InPHPcode_tofind = s:PHP_startindenttag - elseif cline =~? '<script\>' - let b:InPHPcode_and_script = 1 - endif - - elseif last_line =~? '<<<''\=\a\w*''\=$' " XXX 0607 - let b:InPHPcode = 0 - let b:InPHPcode_tofind = substitute( last_line, '^.*<<<''\=\(\a\w*\)''\=$', '^\\s*\1;\\=$', '') " XXX 0607 - - elseif !UserIsEditing && cline =~ '^\s*/\*\%(.*\*/\)\@!' && getline(v:lnum + 1) !~ '^\s*\*' - let b:InPHPcode = 0 - let b:InPHPcode_tofind = '\*/' - - elseif cline =~? '^\s*</script>' - let b:InPHPcode = 0 - let b:InPHPcode_tofind = s:PHP_startindenttag - endif - endif " }}} - - - if !b:InPHPcode && !b:InPHPcode_and_script - return -1 - endif - - " Indent successive // or # comment the same way the first is {{{ - if cline =~ '^\s*\%(//\|#\|/\*.*\*/\s*$\)' - if b:PHP_LastIndentedWasComment == 1 - return indent(real_PHP_lastindented) - endif - let b:PHP_LastIndentedWasComment = 1 - else - let b:PHP_LastIndentedWasComment = 0 - endif " }}} - - " Indent multiline /* comments correctly {{{ - - if b:PHP_InsideMultilineComment || b:UserIsTypingComment - if cline =~ '^\s*\*\%(\/\)\@!' - if last_line =~ '^\s*/\*' - return indent(lnum) + 1 - else - return indent(lnum) - endif - else - let b:PHP_InsideMultilineComment = 0 - endif - endif - - if !b:PHP_InsideMultilineComment && cline =~ '^\s*/\*' && cline !~ '\*/\s*$' - if getline(v:lnum + 1) !~ '^\s*\*' - return -1 - endif - let b:PHP_InsideMultilineComment = 1 - endif " }}} - - - " Things always indented at col 1 (PHP delimiter: <?, ?>, Heredoc end) {{{ - if cline =~# '^\s*<?' && cline !~ '?>' - return 0 - endif - - if cline =~ '^\s*?>' && cline !~# '<?' - return 0 - endif - - if cline =~? '^\s*\a\w*;$\|^\a\w*$' && cline !~? s:notPhpHereDoc " XXX 0607 - return 0 - endif " }}} - - let s:level = 0 - - let lnum = GetLastRealCodeLNum(v:lnum - 1) - - let last_line = getline(lnum) - let ind = indent(lnum) - let endline= s:endline - - if ind==0 && b:PHP_default_indenting - let ind = b:PHP_default_indenting - endif - - if lnum == 0 - return b:PHP_default_indenting - endif - - - if cline =~ '^\s*}\%(}}\)\@!' - let ind = indent(FindOpenBracket(v:lnum)) - let b:PHP_CurrentIndentLevel = b:PHP_default_indenting - return ind - endif - - if cline =~ '^\s*\*/' - call cursor(v:lnum, 1) - if cline !~ '^\*/' - call search('\*/', 'W') - endif - let lnum = searchpair('/\*', '', '\*/', s:searchpairflags, 'Skippmatch2()') - - let b:PHP_CurrentIndentLevel = b:PHP_default_indenting - - if cline =~ '^\s*\*/' - return indent(lnum) + 1 - else - return indent(lnum) - endif - endif - - let defaultORcase = '^\s*\%(default\|case\).*:' - - if last_line =~ '[;}]'.endline && last_line !~ '^)' && last_line !~# defaultORcase " Added && last_line !~ '^)' on 2007-12-30 - if ind==b:PHP_default_indenting - return b:PHP_default_indenting - elseif b:PHP_indentinghuge && ind==b:PHP_CurrentIndentLevel && cline !~# '^\s*\%(else\|\%(case\|default\).*:\|[})];\=\)' && last_line !~# '^\s*\%(\%(}\s*\)\=else\)' && getline(GetLastRealCodeLNum(lnum - 1))=~';'.endline - return b:PHP_CurrentIndentLevel - endif - endif - - let LastLineClosed = 0 - - let terminated = '\%(;\%(\s*?>\)\=\|<<<''\=\a\w*''\=$\|^\s*}\)'.endline " XXX 0607 - - let unstated = '\%(^\s*'.s:blockstart.'.*)\|\%(//.*\)\@<!\<e'.'lse\>\)'.endline - - if ind != b:PHP_default_indenting && cline =~# '^\s*else\%(if\)\=\>' - let b:PHP_CurrentIndentLevel = b:PHP_default_indenting - return indent(FindTheIfOfAnElse(v:lnum, 1)) - elseif cline =~ '^\s*)\=\s*{' - let previous_line = last_line - let last_line_num = lnum - - while last_line_num > 1 - - if previous_line =~ '^\s*\%(' . s:blockstart . '\|\%([a-zA-Z]\s*\)*function\)' - - let ind = indent(last_line_num) - - if b:PHP_BracesAtCodeLevel - let ind = ind + &sw - endif - - return ind - endif - - let last_line_num = last_line_num - 1 - let previous_line = getline(last_line_num) - endwhile - - elseif last_line =~# unstated && cline !~ '^\s*);\='.endline - let ind = ind + &sw " we indent one level further when the preceding line is not stated - return ind - - elseif (ind != b:PHP_default_indenting || last_line =~ '^)' ) && last_line =~ terminated " Added || last_line =~ '^)' on 2007-12-30 (array indenting [rpblem broke other things) - let previous_line = last_line - let last_line_num = lnum - let LastLineClosed = 1 - - while 1 - if previous_line =~ '^\s*}' - let last_line_num = FindOpenBracket(last_line_num) - - if getline(last_line_num) =~ '^\s*{' - let last_line_num = GetLastRealCodeLNum(last_line_num - 1) - endif - - let previous_line = getline(last_line_num) - - continue - else - - if getline(last_line_num) =~# '^\s*else\%(if\)\=\>' - let last_line_num = FindTheIfOfAnElse(last_line_num, 0) - continue - endif - - - let last_match = last_line_num - - let one_ahead_indent = indent(last_line_num) - let last_line_num = GetLastRealCodeLNum(last_line_num - 1) - let two_ahead_indent = indent(last_line_num) - let after_previous_line = previous_line - let previous_line = getline(last_line_num) - - - if previous_line =~# defaultORcase.'\|{'.endline - break - endif - - if after_previous_line=~# '^\s*'.s:blockstart.'.*)'.endline && previous_line =~# '[;}]'.endline - break - endif - - if one_ahead_indent == two_ahead_indent || last_line_num < 1 - if previous_line =~# '\%(;\|^\s*}\)'.endline || last_line_num < 1 - break - endif - endif - endif - endwhile - - if indent(last_match) != ind - let ind = indent(last_match) - let b:PHP_CurrentIndentLevel = b:PHP_default_indenting - - if cline =~# defaultORcase - let ind = ind - &sw - endif - return ind - endif - endif - - let plinnum = GetLastRealCodeLNum(lnum - 1) - let pline = getline(plinnum) - - let last_line = substitute(last_line,"\\(//\\|#\\)\\(\\(\\([^\"']*\\([\"']\\)[^\"']*\\5\\)\\+[^\"']*$\\)\\|\\([^\"']*$\\)\\)",'','') - - - if ind == b:PHP_default_indenting - if last_line =~ terminated - let LastLineClosed = 1 - endif - endif - - if !LastLineClosed - - if last_line =~# '[{(]'.endline || last_line =~? '\h\w*\s*(.*,$' && pline !~ '[,(]'.endline - - if !b:PHP_BracesAtCodeLevel || last_line !~# '^\s*{' - let ind = ind + &sw - endif - - if b:PHP_BracesAtCodeLevel || b:PHP_vintage_case_default_indent == 1 || cline !~# defaultORcase - let b:PHP_CurrentIndentLevel = ind - - return ind - endif - - elseif last_line =~ '\S\+\s*),'.endline - call cursor(lnum, 1) - call search('),'.endline, 'W') - let openedparent = searchpair('(', '', ')', 'bW', 'Skippmatch()') - if openedparent != lnum - let ind = indent(openedparent) - endif - elseif last_line =~ '^\s*'.s:blockstart - let ind = ind + &sw - - elseif last_line =~# defaultORcase - let ind = ind + &sw - - - elseif pline =~ '\%(;\%(\s*?>\)\=\|<<<''\=\a\w*''\=$\|^\s*}\|{\)'.endline . '\|' . defaultORcase - - let ind = ind + &sw - endif - - endif - - if cline =~ '^\s*);\=' - let ind = ind - &sw - elseif cline =~# defaultORcase && last_line !~# defaultORcase - let ind = ind - &sw - - endif - - let b:PHP_CurrentIndentLevel = ind - return ind -endfunction diff --git a/share/vim/vim72/indent/ruby.vim b/share/vim/vim72/indent/ruby.vim deleted file mode 100644 index 4a3012f94f..0000000000 --- a/share/vim/vim72/indent/ruby.vim +++ /dev/null @@ -1,378 +0,0 @@ -" Vim indent file -" Language: Ruby -" Maintainer: Nikolai Weibull <now at bitwi.se> -" Info: $Id: ruby.vim,v 1.47 2008/06/29 04:18:43 tpope Exp $ -" URL: http://vim-ruby.rubyforge.org -" Anon CVS: See above site -" Release Coordinator: Doug Kearns <dougkearns@gmail.com> - -" 0. Initialization {{{1 -" ================= - -" Only load this indent file when no other was loaded. -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -setlocal nosmartindent - -" Now, set up our indentation expression and keys that trigger it. -setlocal indentexpr=GetRubyIndent() -setlocal indentkeys=0{,0},0),0],!^F,o,O,e -setlocal indentkeys+==end,=elsif,=when,=ensure,=rescue,==begin,==end - -" Only define the function once. -if exists("*GetRubyIndent") - finish -endif - -let s:cpo_save = &cpo -set cpo&vim - -" 1. Variables {{{1 -" ============ - -" Regex of syntax group names that are or delimit string or are comments. -let s:syng_strcom = '\<ruby\%(String\|StringEscape\|ASCIICode' . - \ '\|Interpolation\|NoInterpolation\|Comment\|Documentation\)\>' - -" Regex of syntax group names that are strings. -let s:syng_string = - \ '\<ruby\%(String\|Interpolation\|NoInterpolation\|StringEscape\)\>' - -" Regex of syntax group names that are strings or documentation. -let s:syng_stringdoc = - \'\<ruby\%(String\|Interpolation\|NoInterpolation\|StringEscape\|Documentation\)\>' - -" Expression used to check whether we should skip a match with searchpair(). -let s:skip_expr = - \ "synIDattr(synID(line('.'),col('.'),1),'name') =~ '".s:syng_strcom."'" - -" Regex used for words that, at the start of a line, add a level of indent. -let s:ruby_indent_keywords = '^\s*\zs\<\%(module\|class\|def\|if\|for' . - \ '\|while\|until\|else\|elsif\|case\|when\|unless\|begin\|ensure' . - \ '\|rescue\)\>' . - \ '\|\%([*+/,=-]\|<<\|>>\|:\s\)\s*\zs' . - \ '\<\%(if\|for\|while\|until\|case\|unless\|begin\)\>' - -" Regex used for words that, at the start of a line, remove a level of indent. -let s:ruby_deindent_keywords = - \ '^\s*\zs\<\%(ensure\|else\|rescue\|elsif\|when\|end\)\>' - -" Regex that defines the start-match for the 'end' keyword. -"let s:end_start_regex = '\%(^\|[^.]\)\<\%(module\|class\|def\|if\|for\|while\|until\|case\|unless\|begin\|do\)\>' -" TODO: the do here should be restricted somewhat (only at end of line)? -let s:end_start_regex = '^\s*\zs\<\%(module\|class\|def\|if\|for' . - \ '\|while\|until\|case\|unless\|begin\)\>' . - \ '\|\%([*+/,=-]\|<<\|>>\|:\s\)\s*\zs' . - \ '\<\%(if\|for\|while\|until\|case\|unless\|begin\)\>' . - \ '\|\<do\>' - -" Regex that defines the middle-match for the 'end' keyword. -let s:end_middle_regex = '\<\%(ensure\|else\|\%(\%(^\|;\)\s*\)\@<=\<rescue\>\|when\|elsif\)\>' - -" Regex that defines the end-match for the 'end' keyword. -let s:end_end_regex = '\%(^\|[^.:@$]\)\@<=\<end\>' - -" Expression used for searchpair() call for finding match for 'end' keyword. -let s:end_skip_expr = s:skip_expr . - \ ' || (expand("<cword>") == "do"' . - \ ' && getline(".") =~ "^\\s*\\<\\(while\\|until\\|for\\)\\>")' - -" Regex that defines continuation lines, not including (, {, or [. -let s:continuation_regex = '\%([\\*+/.,:]\|\%(<%\)\@<![=-]\|\W[|&?]\|||\|&&\)\s*\%(#.*\)\=$' - -" Regex that defines continuation lines. -" TODO: this needs to deal with if ...: and so on -let s:continuation_regex2 = - \ '\%([\\*+/.,:({[]\|\%(<%\)\@<![=-]\|\W[|&?]\|||\|&&\)\s*\%(#.*\)\=$' - -" Regex that defines blocks. -let s:block_regex = - \ '\%(\<do\>\|{\)\s*\%(|\%([*@]\=\h\w*,\=\s*\)\%(,\s*[*@]\=\h\w*\)*|\)\=\s*\%(#.*\)\=$' - -" 2. Auxiliary Functions {{{1 -" ====================== - -" Check if the character at lnum:col is inside a string, comment, or is ascii. -function s:IsInStringOrComment(lnum, col) - return synIDattr(synID(a:lnum, a:col, 1), 'name') =~ s:syng_strcom -endfunction - -" Check if the character at lnum:col is inside a string. -function s:IsInString(lnum, col) - return synIDattr(synID(a:lnum, a:col, 1), 'name') =~ s:syng_string -endfunction - -" Check if the character at lnum:col is inside a string or documentation. -function s:IsInStringOrDocumentation(lnum, col) - return synIDattr(synID(a:lnum, a:col, 1), 'name') =~ s:syng_stringdoc -endfunction - -" Find line above 'lnum' that isn't empty, in a comment, or in a string. -function s:PrevNonBlankNonString(lnum) - let in_block = 0 - let lnum = prevnonblank(a:lnum) - while lnum > 0 - " Go in and out of blocks comments as necessary. - " If the line isn't empty (with opt. comment) or in a string, end search. - let line = getline(lnum) - if line =~ '^=begin$' - if in_block - let in_block = 0 - else - break - endif - elseif !in_block && line =~ '^=end$' - let in_block = 1 - elseif !in_block && line !~ '^\s*#.*$' && !(s:IsInStringOrComment(lnum, 1) - \ && s:IsInStringOrComment(lnum, strlen(line))) - break - endif - let lnum = prevnonblank(lnum - 1) - endwhile - return lnum -endfunction - -" Find line above 'lnum' that started the continuation 'lnum' may be part of. -function s:GetMSL(lnum) - " Start on the line we're at and use its indent. - let msl = a:lnum - let lnum = s:PrevNonBlankNonString(a:lnum - 1) - while lnum > 0 - " If we have a continuation line, or we're in a string, use line as MSL. - " Otherwise, terminate search as we have found our MSL already. - let line = getline(lnum) - let col = match(line, s:continuation_regex2) + 1 - if (col > 0 && !s:IsInStringOrComment(lnum, col)) - \ || s:IsInString(lnum, strlen(line)) - let msl = lnum - else - break - endif - let lnum = s:PrevNonBlankNonString(lnum - 1) - endwhile - return msl -endfunction - -" Check if line 'lnum' has more opening brackets than closing ones. -function s:LineHasOpeningBrackets(lnum) - let open_0 = 0 - let open_2 = 0 - let open_4 = 0 - let line = getline(a:lnum) - let pos = match(line, '[][(){}]', 0) - while pos != -1 - if !s:IsInStringOrComment(a:lnum, pos + 1) - let idx = stridx('(){}[]', line[pos]) - if idx % 2 == 0 - let open_{idx} = open_{idx} + 1 - else - let open_{idx - 1} = open_{idx - 1} - 1 - endif - endif - let pos = match(line, '[][(){}]', pos + 1) - endwhile - return (open_0 > 0) . (open_2 > 0) . (open_4 > 0) -endfunction - -function s:Match(lnum, regex) - let col = match(getline(a:lnum), a:regex) + 1 - return col > 0 && !s:IsInStringOrComment(a:lnum, col) ? col : 0 -endfunction - -function s:MatchLast(lnum, regex) - let line = getline(a:lnum) - let col = match(line, '.*\zs' . a:regex) - while col != -1 && s:IsInStringOrComment(a:lnum, col) - let line = strpart(line, 0, col) - let col = match(line, '.*' . a:regex) - endwhile - return col + 1 -endfunction - -" 3. GetRubyIndent Function {{{1 -" ========================= - -function GetRubyIndent() - " 3.1. Setup {{{2 - " ---------- - - " Set up variables for restoring position in file. Could use v:lnum here. - let vcol = col('.') - - " 3.2. Work on the current line {{{2 - " ----------------------------- - - " Get the current line. - let line = getline(v:lnum) - let ind = -1 - - " If we got a closing bracket on an empty line, find its match and indent - " according to it. For parentheses we indent to its column - 1, for the - " others we indent to the containing line's MSL's level. Return -1 if fail. - let col = matchend(line, '^\s*[]})]') - if col > 0 && !s:IsInStringOrComment(v:lnum, col) - call cursor(v:lnum, col) - let bs = strpart('(){}[]', stridx(')}]', line[col - 1]) * 2, 2) - if searchpair(escape(bs[0], '\['), '', bs[1], 'bW', s:skip_expr) > 0 - if line[col-1]==')' && col('.') != col('$') - 1 - let ind = virtcol('.')-1 - else - let ind = indent(s:GetMSL(line('.'))) - endif - endif - return ind - endif - - " If we have a =begin or =end set indent to first column. - if match(line, '^\s*\%(=begin\|=end\)$') != -1 - return 0 - endif - - " If we have a deindenting keyword, find its match and indent to its level. - " TODO: this is messy - if s:Match(v:lnum, s:ruby_deindent_keywords) - call cursor(v:lnum, 1) - if searchpair(s:end_start_regex, s:end_middle_regex, s:end_end_regex, 'bW', - \ s:end_skip_expr) > 0 - let line = getline('.') - if strpart(line, 0, col('.') - 1) =~ '=\s*$' && - \ strpart(line, col('.') - 1, 2) !~ 'do' - let ind = virtcol('.') - 1 - else - let ind = indent('.') - endif - endif - return ind - endif - - " If we are in a multi-line string or line-comment, don't do anything to it. - if s:IsInStringOrDocumentation(v:lnum, matchend(line, '^\s*') + 1) - return indent('.') - endif - - " 3.3. Work on the previous line. {{{2 - " ------------------------------- - - " Find a non-blank, non-multi-line string line above the current line. - let lnum = s:PrevNonBlankNonString(v:lnum - 1) - - " If the line is empty and inside a string, use the previous line. - if line =~ '^\s*$' && lnum != prevnonblank(v:lnum - 1) - return indent(prevnonblank(v:lnum)) - endif - - " At the start of the file use zero indent. - if lnum == 0 - return 0 - endif - - " Set up variables for current line. - let line = getline(lnum) - let ind = indent(lnum) - - " If the previous line ended with a block opening, add a level of indent. - if s:Match(lnum, s:block_regex) - return indent(s:GetMSL(lnum)) + &sw - endif - - " If the previous line contained an opening bracket, and we are still in it, - " add indent depending on the bracket type. - if line =~ '[[({]' - let counts = s:LineHasOpeningBrackets(lnum) - if counts[0] == '1' && searchpair('(', '', ')', 'bW', s:skip_expr) > 0 - if col('.') + 1 == col('$') - return ind + &sw - else - return virtcol('.') - endif - elseif counts[1] == '1' || counts[2] == '1' - return ind + &sw - else - call cursor(v:lnum, vcol) - end - endif - - " If the previous line ended with an "end", match that "end"s beginning's - " indent. - let col = s:Match(lnum, '\%(^\|[^.:@$]\)\<end\>\s*\%(#.*\)\=$') - if col > 0 - call cursor(lnum, col) - if searchpair(s:end_start_regex, '', s:end_end_regex, 'bW', - \ s:end_skip_expr) > 0 - let n = line('.') - let ind = indent('.') - let msl = s:GetMSL(n) - if msl != n - let ind = indent(msl) - end - return ind - endif - end - - let col = s:Match(lnum, s:ruby_indent_keywords) - if col > 0 - call cursor(lnum, col) - let ind = virtcol('.') - 1 + &sw -" let ind = indent(lnum) + &sw - " TODO: make this better (we need to count them) (or, if a searchpair - " fails, we know that something is lacking an end and thus we indent a - " level - if s:Match(lnum, s:end_end_regex) - let ind = indent('.') - endif - return ind - endif - - " 3.4. Work on the MSL line. {{{2 - " -------------------------- - - " Set up variables to use and search for MSL to the previous line. - let p_lnum = lnum - let lnum = s:GetMSL(lnum) - - " If the previous line wasn't a MSL and is continuation return its indent. - " TODO: the || s:IsInString() thing worries me a bit. - if p_lnum != lnum - if s:Match(p_lnum,s:continuation_regex)||s:IsInString(p_lnum,strlen(line)) - return ind - endif - endif - - " Set up more variables, now that we know we wasn't continuation bound. - let line = getline(lnum) - let msl_ind = indent(lnum) - - " If the MSL line had an indenting keyword in it, add a level of indent. - " TODO: this does not take into account contrived things such as - " module Foo; class Bar; end - if s:Match(lnum, s:ruby_indent_keywords) - let ind = msl_ind + &sw - if s:Match(lnum, s:end_end_regex) - let ind = ind - &sw - endif - return ind - endif - - " If the previous line ended with [*+/.-=], indent one extra level. - if s:Match(lnum, s:continuation_regex) - if lnum == p_lnum - let ind = msl_ind + &sw - else - let ind = msl_ind - endif - endif - - " }}}2 - - return ind -endfunction - -" }}}1 - -let &cpo = s:cpo_save -unlet s:cpo_save - -" vim:set sw=2 sts=2 ts=8 noet: diff --git a/share/vim/vim72/indent/sass.vim b/share/vim/vim72/indent/sass.vim deleted file mode 100644 index 45ca50f689..0000000000 --- a/share/vim/vim72/indent/sass.vim +++ /dev/null @@ -1,39 +0,0 @@ -" Vim indent file -" Language: SASS -" Maintainer: Tim Pope <vimNOSPAM@tpope.info> -" Last Change: 2007 Dec 16 - -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -setlocal autoindent sw=2 et -setlocal indentexpr=GetSassIndent() -setlocal indentkeys=o,O,*<Return>,<:>,!^F - -" Only define the function once. -if exists("*GetSassIndent") - finish -endif - -let s:property = '^\s*:\|^\s*[[:alnum:]-]\+:' - -function! GetSassIndent() - let lnum = prevnonblank(v:lnum-1) - let line = substitute(getline(lnum),'\s\+$','','') - let cline = substitute(substitute(getline(v:lnum),'\s\+$','',''),'^\s\+','','') - let lastcol = strlen(line) - let line = substitute(line,'^\s\+','','') - let indent = indent(lnum) - let cindent = indent(v:lnum) - if line !~ s:property && cline =~ s:property - return indent + &sw - "elseif line =~ s:property && cline !~ s:property - "return indent - &sw - else - return -1 - endif -endfunction - -" vim:set sw=2: diff --git a/share/vim/vim72/indent/sh.vim b/share/vim/vim72/indent/sh.vim deleted file mode 100644 index 483e5430ec..0000000000 --- a/share/vim/vim72/indent/sh.vim +++ /dev/null @@ -1,52 +0,0 @@ -" Vim indent file -" Language: Shell Script -" Maintainer: Nikolai Weibull <now@bitwi.se> -" Latest Revision: 2006-04-19 - -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -setlocal indentexpr=GetShIndent() -setlocal indentkeys+==then,=do,=else,=elif,=esac,=fi,=fin,=fil,=done -setlocal indentkeys-=:,0# - -if exists("*GetShIndent") - finish -endif - -let s:cpo_save = &cpo -set cpo&vim - -function GetShIndent() - let lnum = prevnonblank(v:lnum - 1) - if lnum == 0 - return 0 - endif - - " Add a 'shiftwidth' after if, while, else, case, until, for, function() - " Skip if the line also contains the closure for the above - let ind = indent(lnum) - let line = getline(lnum) - if line =~ '^\s*\(if\|then\|do\|else\|elif\|case\|while\|until\|for\)\>' - \ || line =~ '^\s*\<\k\+\>\s*()\s*{' - \ || line =~ '^\s*{' - if line !~ '\(esac\|fi\|done\)\>\s*$' && line !~ '}\s*$' - let ind = ind + &sw - endif - endif - - " Subtract a 'shiftwidth' on a then, do, else, esac, fi, done - " Retain the indentation level if line matches fin (for find) - let line = getline(v:lnum) - if (line =~ '^\s*\(then\|do\|else\|elif\|esac\|fi\|done\)\>' || line =~ '^\s*}') - \ && line !~ '^\s*fi[ln]\>' - let ind = ind - &sw - endif - - return ind -endfunction - -let &cpo = s:cpo_save -unlet s:cpo_save diff --git a/share/vim/vim72/indent/tf.vim b/share/vim/vim72/indent/tf.vim deleted file mode 100644 index 61cebc3a67..0000000000 --- a/share/vim/vim72/indent/tf.vim +++ /dev/null @@ -1,72 +0,0 @@ -" Vim indent file -" Language: tf (TinyFugue) -" Maintainer: Christian J. Robinson <infynity@onewest.net> -" URL: http://www.infynity.spodzone.com/vim/indent/tf.vim -" Last Change: 2002 May 29 - -" Only load this indent file when no other was loaded. -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -setlocal indentexpr=GetTFIndent() -setlocal indentkeys-=0{,0} indentkeys-=0# indentkeys-=: -setlocal indentkeys+==/endif,=/then,=/else,=/done,0; - -" Only define the function once: -if exists("*GetTFIndent") - finish -endif - -function GetTFIndent() - " Find a non-blank line above the current line: - let lnum = prevnonblank(v:lnum - 1) - - " No indent for the start of the file: - if lnum == 0 - return 0 - endif - - let ind = indent(lnum) - let line = getline(lnum) - - " No indentation if the previous line didn't end with "\": - " (Could be annoying, but it lets you know if you made a mistake.) - if line !~ '\\$' - return 0 - endif - - if line =~ '\(/def.*\\\|/for.*\(%;\s*\)\@\<!\\\)$' - let ind = ind + &sw - elseif line =~ '\(/if\|/else\|/then\)' - if line !~ '/endif' - let ind = ind + &sw - endif - elseif line =~ '/while' - if line !~ '/done' - let ind = ind + &sw - endif - endif - - let line = getline(v:lnum) - - if line =~ '\(/else\|/endif\|/then\)' - if line !~ '/if' - let ind = ind - &sw - endif - elseif line =~ '/done' - if line !~ '/while' - let ind = ind - &sw - endif - endif - - " Comments at the beginning of a line: - if line =~ '^\s*;' - let ind = 0 - endif - - - return ind - -endfunction diff --git a/share/vim/vim72/indent/vb.vim b/share/vim/vim72/indent/vb.vim deleted file mode 100644 index 85021bd7d9..0000000000 --- a/share/vim/vim72/indent/vb.vim +++ /dev/null @@ -1,75 +0,0 @@ -" Vim indent file -" Language: VisualBasic (ft=vb) / Basic (ft=basic) / SaxBasic (ft=vb) -" Author: Johannes Zellner <johannes@zellner.org> -" Last Change: Fri, 18 Jun 2004 07:22:42 CEST - -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -setlocal autoindent -setlocal indentexpr=VbGetIndent(v:lnum) -setlocal indentkeys& -setlocal indentkeys+==~else,=~elseif,=~end,=~wend,=~case,=~next,=~select,=~loop,<:> - -let b:undo_indent = "set ai< indentexpr< indentkeys<" - -" Only define the function once. -if exists("*VbGetIndent") - finish -endif - -fun! VbGetIndent(lnum) - " labels and preprocessor get zero indent immediately - let this_line = getline(a:lnum) - let LABELS_OR_PREPROC = '^\s*\(\<\k\+\>:\s*$\|#.*\)' - if this_line =~? LABELS_OR_PREPROC - return 0 - endif - - " Find a non-blank line above the current line. - " Skip over labels and preprocessor directives. - let lnum = a:lnum - while lnum > 0 - let lnum = prevnonblank(lnum - 1) - let previous_line = getline(lnum) - if previous_line !~? LABELS_OR_PREPROC - break - endif - endwhile - - " Hit the start of the file, use zero indent. - if lnum == 0 - return 0 - endif - - let ind = indent(lnum) - - " Add - if previous_line =~? '^\s*\<\(begin\|\%(\%(private\|public\|friend\)\s\+\)\=\%(function\|sub\|property\)\|select\|case\|default\|if\>.\{-}\<then\>\s*$\|else\|elseif\|do\|for\|while\|enum\|with\)\>' - let ind = ind + &sw - endif - - " Subtract - if this_line =~? '^\s*\<end\>\s\+\<select\>' - if previous_line !~? '^\s*\<select\>' - let ind = ind - 2 * &sw - else - " this case is for an empty 'select' -- 'end select' - " (w/o any case statements) like: - " - " select case readwrite - " end select - let ind = ind - &sw - endif - elseif this_line =~? '^\s*\<\(end\|else\|until\|loop\|next\|wend\)\>' - let ind = ind - &sw - elseif this_line =~? '^\s*\<\(case\|default\)\>' - if previous_line !~? '^\s*\<select\>' - let ind = ind - &sw - endif - endif - - return ind -endfun diff --git a/share/vim/vim72/indent/vhdl.vim b/share/vim/vim72/indent/vhdl.vim deleted file mode 100644 index 9940cc5b5e..0000000000 --- a/share/vim/vim72/indent/vhdl.vim +++ /dev/null @@ -1,406 +0,0 @@ -" VHDL indent ('93 syntax) -" Language: VHDL -" Maintainer: Gerald Lai <laigera+vim?gmail.com> -" Version: 1.54 -" Last Change: 2007 Aug 17 -" URL: http://www.vim.org/scripts/script.php?script_id=1450 - -" only load this indent file when no other was loaded -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -" setup indent options for local VHDL buffer -setlocal indentexpr=GetVHDLindent() -setlocal indentkeys=!^F,o,O,0(,0) -setlocal indentkeys+==~begin,=~end\ ,=~end\ ,=~is,=~select,=~when -setlocal indentkeys+==~if,=~then,=~elsif,=~else -setlocal indentkeys+==~case,=~loop,=~for,=~generate,=~record,=~units,=~process,=~block,=~function,=~component,=~procedure -setlocal indentkeys+==~architecture,=~configuration,=~entity,=~package - -" constants -" not a comment -let s:NC = '\%(--.*\)\@<!' -" end of string -let s:ES = '\s*\%(--.*\)\=$' -" no "end" keyword in front -let s:NE = '\%(\<end\s\+\)\@<!' - -" option to disable alignment of generic/port mappings -if !exists("g:vhdl_indent_genportmap") - let g:vhdl_indent_genportmap = 1 -endif - -" option to disable alignment of right-hand side assignment "<=" statements -if !exists("g:vhdl_indent_rhsassign") - let g:vhdl_indent_rhsassign = 1 -endif - -" only define indent function once -if exists("*GetVHDLindent") - finish -endif - -function GetVHDLindent() - " store current line & string - let curn = v:lnum - let curs = getline(curn) - - " find previous line that is not a comment - let prevn = prevnonblank(curn - 1) - let prevs = getline(prevn) - while prevn > 0 && prevs =~ '^\s*--' - let prevn = prevnonblank(prevn - 1) - let prevs = getline(prevn) - endwhile - let prevs_noi = substitute(prevs, '^\s*', '', '') - - " default indent starts as previous non-comment line's indent - let ind = prevn > 0 ? indent(prevn) : 0 - " backup default - let ind2 = ind - - " indent: special; kill string so it would not affect other filters - " keywords: "report" + string - " where: anywhere in current or previous line - let s0 = s:NC.'\<report\>\s*".*"' - if curs =~? s0 - let curs = "" - endif - if prevs =~? s0 - let prevs = "" - endif - - " indent: previous line's comment position, otherwise follow next non-comment line if possible - " keyword: "--" - " where: start of current line - if curs =~ '^\s*--' - let pn = curn - 1 - let ps = getline(pn) - if curs =~ '^\s*--\s' && ps =~ '--' - return indent(pn) + stridx(substitute(ps, '^\s*', '', ''), '--') - else - " find nextnonblank line that is not a comment - let nn = nextnonblank(curn + 1) - let ns = getline(nn) - while nn > 0 && ns =~ '^\s*--' - let nn = nextnonblank(nn + 1) - let ns = getline(nn) - endwhile - let n = indent(nn) - return n != -1 ? n : ind - endif - endif - - " **************************************************************************************** - " indent: align generic variables & port names - " keywords: "generic", "map", "port" + "(", provided current line is part of mapping - " where: anywhere in previous 2 lines - " find following previous non-comment line - let pn = prevnonblank(prevn - 1) - let ps = getline(pn) - while pn > 0 && ps =~ '^\s*--' - let pn = prevnonblank(pn - 1) - let ps = getline(pn) - endwhile - if (curs =~ '^\s*)' || curs =~? '^\s*\%(\<\%(generic\|map\|port\)\>.*\)\@<!\S\+\s*\%(=>\s*\S\+\|:[^=]\@=\s*\%(\%(in\|out\|inout\|buffer\|linkage\)\>\|\w\+\s\+:=\)\)') && (prevs =~? s:NC.'\<\%(generic\|map\|port\)\s*(\%(\s*\w\)\=' || (ps =~? s:NC.'\<\%(generic\|map\|port\)'.s:ES && prevs =~ '^\s*(')) - " align closing ")" with opening "(" - if curs =~ '^\s*)' - return ind2 + stridx(prevs_noi, '(') - endif - let m = matchend(prevs_noi, '(\s*\ze\w') - if m != -1 - return ind2 + m - else - if g:vhdl_indent_genportmap - return ind2 + stridx(prevs_noi, '(') + &sw - else - return ind2 + &sw - endif - endif - endif - - " indent: align conditional/select statement - " keywords: variable + "<=" without ";" ending - " where: start of previous line - if prevs =~? '^\s*\S\+\s*<=[^;]*'.s:ES - if g:vhdl_indent_rhsassign - return ind2 + matchend(prevs_noi, '<=\s*\ze.') - else - return ind2 + &sw - endif - endif - - " indent: backtrace previous non-comment lines for next smaller or equal size indent - " keywords: "end" + "record", "units" - " where: start of previous line - " keyword: ")" - " where: start of previous line - " keyword: without "<=" + ";" ending - " where: anywhere in previous line - " keyword: "=>" + ")" ending, provided current line does not begin with ")" - " where: anywhere in previous line - " _note_: indent allowed to leave this filter - let m = 0 - if prevs =~? '^\s*end\s\+\%(record\|units\)\>' - let m = 3 - elseif prevs =~ '^\s*)' - let m = 1 - elseif prevs =~ s:NC.'\%(<=.*\)\@<!;'.s:ES || (curs !~ '^\s*)' && prevs =~ s:NC.'=>.*'.s:NC.')'.s:ES) - let m = 2 - endif - - if m > 0 - let pn = prevnonblank(prevn - 1) - let ps = getline(pn) - while pn > 0 - let t = indent(pn) - if ps !~ '^\s*--' && t < ind - " make sure one of these is true - " keywords: variable + "<=" without ";" ending - " where: start of previous non-comment line - " keywords: "generic", "map", "port" - " where: anywhere in previous non-comment line - " keyword: "(" - " where: start of previous non-comment line - if m < 3 && ps !~? '^\s*\S\+\s*<=[^;]*'.s:ES - if ps =~? s:NC.'\<\%(generic\|map\|port\)\>' || ps =~ '^\s*(' - let ind = t - endif - break - endif - let ind = t - if m > 1 - " find following previous non-comment line - let ppn = prevnonblank(pn - 1) - let pps = getline(ppn) - while ppn > 0 && pps =~ '^\s*--' - let ppn = prevnonblank(ppn - 1) - let pps = getline(ppn) - endwhile - " indent: follow - " keyword: "select" - " where: end of following previous non-comment line - " keyword: "type" - " where: start of following previous non-comment line - if m == 2 - let s1 = s:NC.'\<select'.s:ES - if ps !~? s1 && pps =~? s1 - let ind = indent(ppn) - endif - elseif m == 3 - let s1 = '^\s*type\>' - if ps !~? s1 && pps =~? s1 - let ind = indent(ppn) - endif - endif - endif - break - endif - let pn = prevnonblank(pn - 1) - let ps = getline(pn) - endwhile - endif - - " indent: follow indent of previous opening statement, otherwise -sw - " keyword: "begin" - " where: anywhere in current line - if curs =~? s:NC.'\<begin\>' - let ind = ind - &sw - " find previous opening statement of - " keywords: "architecture", "block", "entity", "function", "generate", "procedure", "process" - let s2 = s:NC.s:NE.'\<\%(architecture\|block\|entity\|function\|generate\|procedure\|process\)\>' - if (curs !~? s2.'.*'.s:NC.'\<begin\>.*'.s:ES && prevs =~? s2) || m == 1 - let ind = ind + &sw - endif - return ind - endif - - " indent: +sw if previous line is previous opening statement - " keywords: "record", "units" - " where: anywhere in current line - if curs =~? s:NC.s:NE.'\<\%(record\|units\)\>' - " find previous opening statement of - " keyword: "type" - let s3 = s:NC.s:NE.'\<type\>' - if curs !~? s3.'.*'.s:NC.'\<\%(record\|units\)\>.*'.s:ES && prevs =~? s3 - let ind = ind + &sw - endif - return ind - endif - - " **************************************************************************************** - " indent: 0 - " keywords: "architecture", "configuration", "entity", "library", "package" - " where: start of current line - if curs =~? '^\s*\%(architecture\|configuration\|entity\|library\|package\)\>' - return 0 - endif - - " indent: maintain indent of previous opening statement - " keyword: "is" - " where: start of current line - " find previous opening statement of - " keywords: "architecture", "block", "configuration", "entity", "function", "package", "procedure", "process", "type" - if curs =~? '^\s*\<is\>' && prevs =~? s:NC.s:NE.'\<\%(architecture\|block\|configuration\|entity\|function\|package\|procedure\|process\|type\)\>' - return ind2 - endif - - " indent: maintain indent of previous opening statement - " keyword: "then" - " where: start of current line - " find previous opening statement of - " keywords: "elsif", "if" - if curs =~? '^\s*\<then\>' && prevs =~? s:NC.'\%(\<elsif\>\|'.s:NE.'\<if\>\)' - return ind2 - endif - - " indent: maintain indent of previous opening statement - " keyword: "generate" - " where: start of current line - " find previous opening statement of - " keywords: "for", "if" - if curs =~? '^\s*\<generate\>' && prevs =~? s:NC.s:NE.'\%(\%(\<wait\s\+\)\@<!\<for\|\<if\)\>' - return ind2 - endif - - " indent: +sw - " keywords: "block", "process" - " removed: "begin", "case", "elsif", "if", "loop", "record", "units", "while" - " where: anywhere in previous line - if prevs =~? s:NC.s:NE.'\<\%(block\|process\)\>' - return ind + &sw - endif - - " indent: +sw - " keywords: "architecture", "configuration", "entity", "package" - " removed: "component", "for", "when", "with" - " where: start of previous line - if prevs =~? '^\s*\%(architecture\|configuration\|entity\|package\)\>' - return ind + &sw - endif - - " indent: +sw - " keyword: "select" - " removed: "generate", "is", "=>" - " where: end of previous line - if prevs =~? s:NC.'\<select'.s:ES - return ind + &sw - endif - - " indent: +sw - " keyword: "begin", "loop", "record", "units" - " where: anywhere in previous line - " keyword: "component", "else", "for" - " where: start of previous line - " keyword: "generate", "is", "then", "=>" - " where: end of previous line - " _note_: indent allowed to leave this filter - if prevs =~? s:NC.'\%(\<begin\>\|'.s:NE.'\<\%(loop\|record\|units\)\>\)' || prevs =~? '^\s*\%(component\|else\|for\)\>' || prevs =~? s:NC.'\%('.s:NE.'\<generate\|\<\%(is\|then\)\|=>\)'.s:ES - let ind = ind + &sw - endif - - " **************************************************************************************** - " indent: -sw - " keywords: "when", provided previous line does not begin with "when", does not end with "is" - " where: start of current line - let s4 = '^\s*when\>' - if curs =~? s4 - if prevs =~? s:NC.'\<is'.s:ES - return ind - elseif prevs !~? s4 - return ind - &sw - else - return ind2 - endif - endif - - " indent: -sw - " keywords: "else", "elsif", "end" + "block", "for", "function", "generate", "if", "loop", "procedure", "process", "record", "units" - " where: start of current line - if curs =~? '^\s*\%(else\|elsif\|end\s\+\%(block\|for\|function\|generate\|if\|loop\|procedure\|process\|record\|units\)\)\>' - return ind - &sw - endif - - " indent: backtrace previous non-comment lines - " keyword: "end" + "case", "component" - " where: start of current line - let m = 0 - if curs =~? '^\s*end\s\+case\>' - let m = 1 - elseif curs =~? '^\s*end\s\+component\>' - let m = 2 - endif - - if m > 0 - " find following previous non-comment line - let pn = prevn - let ps = getline(pn) - while pn > 0 - if ps !~ '^\s*--' - "indent: -2sw - "keywords: "end" + "case" - "where: start of previous non-comment line - "indent: -sw - "keywords: "when" - "where: start of previous non-comment line - "indent: follow - "keywords: "case" - "where: start of previous non-comment line - if m == 1 - if ps =~? '^\s*end\s\+case\>' - return indent(pn) - 2 * &sw - elseif ps =~? '^\s*when\>' - return indent(pn) - &sw - elseif ps =~? '^\s*case\>' - return indent(pn) - endif - "indent: follow - "keyword: "component" - "where: start of previous non-comment line - elseif m == 2 - if ps =~? '^\s*component\>' - return indent(pn) - endif - endif - endif - let pn = prevnonblank(pn - 1) - let ps = getline(pn) - endwhile - return ind - &sw - endif - - " indent: -sw - " keyword: ")" - " where: start of current line - if curs =~ '^\s*)' - return ind - &sw - endif - - " indent: 0 - " keywords: "end" + "architecture", "configuration", "entity", "package" - " where: start of current line - if curs =~? '^\s*end\s\+\%(architecture\|configuration\|entity\|package\)\>' - return 0 - endif - - " indent: -sw - " keywords: "end" + identifier - " where: start of current line - "if curs =~? '^\s*end\s\+\w\+\>' - if curs =~? '^\s*end\s' - return ind - &sw - endif - - " **************************************************************************************** - " indent: maintain indent of previous opening statement - " keywords: without "generic", "map", "port" + ":" but not ":=" + "in", "out", "inout", "buffer", "linkage", variable & ":=" - " where: start of current line - if curs =~? '^\s*\%(\<\%(generic\|map\|port\)\>.*\)\@<!\S\+\s*:[^=]\@=\s*\%(\%(in\|out\|inout\|buffer\|linkage\)\>\|\w\+\s\+:=\)' - return ind2 - endif - - " return leftover filtered indent - return ind -endfunction diff --git a/share/vim/vim72/indent/xml.vim b/share/vim/vim72/indent/xml.vim deleted file mode 100644 index 340981b3dd..0000000000 --- a/share/vim/vim72/indent/xml.vim +++ /dev/null @@ -1,88 +0,0 @@ -" Language: xml -" Maintainer: Johannes Zellner <johannes@zellner.org> -" Last Change: Tue, 27 Apr 2004 14:54:59 CEST -" Notes: 1) does not indent pure non-xml code (e.g. embedded scripts) -" 2) will be confused by unbalanced tags in comments -" or CDATA sections. -" TODO: implement pre-like tags, see xml_indent_open / xml_indent_close - -" Only load this indent file when no other was loaded. -if exists("b:did_indent") - finish -endif -let b:did_indent = 1 - -" [-- local settings (must come before aborting the script) --] -setlocal indentexpr=XmlIndentGet(v:lnum,1) -setlocal indentkeys=o,O,*<Return>,<>>,<<>,/,{,} - -set cpo-=C - -if !exists('b:xml_indent_open') - let b:xml_indent_open = '.\{-}<\a' - " pre tag, e.g. <address> - " let b:xml_indent_open = '.\{-}<[/]\@!\(address\)\@!' -endif - -if !exists('b:xml_indent_close') - let b:xml_indent_close = '.\{-}</' - " end pre tag, e.g. </address> - " let b:xml_indent_close = '.\{-}</\(address\)\@!' -endif - -" [-- finish, if the function already exists --] -if exists('*XmlIndentGet') | finish | endif - -fun! <SID>XmlIndentWithPattern(line, pat) - let s = substitute('x'.a:line, a:pat, "\1", 'g') - return strlen(substitute(s, "[^\1].*$", '', '')) -endfun - -" [-- check if it's xml --] -fun! <SID>XmlIndentSynCheck(lnum) - if '' != &syntax - let syn1 = synIDattr(synID(a:lnum, 1, 1), 'name') - let syn2 = synIDattr(synID(a:lnum, strlen(getline(a:lnum)) - 1, 1), 'name') - if '' != syn1 && syn1 !~ 'xml' && '' != syn2 && syn2 !~ 'xml' - " don't indent pure non-xml code - return 0 - endif - endif - return 1 -endfun - -" [-- return the sum of indents of a:lnum --] -fun! <SID>XmlIndentSum(lnum, style, add) - let line = getline(a:lnum) - if a:style == match(line, '^\s*</') - return (&sw * - \ (<SID>XmlIndentWithPattern(line, b:xml_indent_open) - \ - <SID>XmlIndentWithPattern(line, b:xml_indent_close) - \ - <SID>XmlIndentWithPattern(line, '.\{-}/>'))) + a:add - else - return a:add - endif -endfun - -fun! XmlIndentGet(lnum, use_syntax_check) - " Find a non-empty line above the current line. - let lnum = prevnonblank(a:lnum - 1) - - " Hit the start of the file, use zero indent. - if lnum == 0 - return 0 - endif - - if a:use_syntax_check - if 0 == <SID>XmlIndentSynCheck(lnum) || 0 == <SID>XmlIndentSynCheck(a:lnum) - return indent(a:lnum) - endif - endif - - let ind = <SID>XmlIndentSum(lnum, -1, indent(lnum)) - let ind = <SID>XmlIndentSum(a:lnum, 0, ind) - - return ind -endfun - -" vim:ts=8 diff --git a/share/vim/vim72/keymap/bulgarian-bds.vim b/share/vim/vim72/keymap/bulgarian-bds.vim deleted file mode 100644 index bf837c8645..0000000000 --- a/share/vim/vim72/keymap/bulgarian-bds.vim +++ /dev/null @@ -1,159 +0,0 @@ -" Vim keymap file for Bulgarian and Russian characters, "bds" layout. -" Most of it can be used with both utf-8 and cp1251 file encodings, except -" the accented vowels which can only be stored in utf-8. -" This file itself is in utf-8. - -" Maintainer: Boyko Bantchev <boykobb@gmail.com> -" URI: http://www.math.bas.bg/bantchev/vim/bulgarian-bds.vim -" Last Changed: 2008 June 28 - -" This keymap corresponds to what is called Bulgarian standard typewriter -" keyboard layout (BDS, БДС). -" -" Note that, in addition to the Bulgarian alphabet, the BDS layout prescribes -" the presence of the following characters: -" — The Russian letters ы (small), and Э and э (capital and small). -" — The latin capital letters I and V – used to type Roman numerals -" without having to leave Cyrillic mode. -" -" Some punctuation characters present in ascii are mapped in BDS to keys -" different from the ones they occupy in the qwerty layout, because the latter -" keys are used to type other characters. -" -" In this keymap, also defined (besides BDS) are: -" — The Russian letters Ё and ё (capital and small), as well as the -" Russian capital letter Ы (see above for the small counterpart). -" This way, using the bulgarian-bds keymap, one can access both -" the Bulgarian and the Russian alphabets. -" — The quotation marks „ “ ” ‘ ’ (used in the Bulgarian and English -" quotation styles), as well as « » (Russian quotation style). -" — The characters §, №, – (en-dash), — (em-dash), …, •, ·, ±, °, ¬, -" ¤, and €. -" -" The keymap also defines key combinations for accented vowels in Bulgarian. -" -" For details of what key or key combination maps to what character, please -" see below the map table itself. - -scriptencoding utf-8 - -let b:keymap_name = "bds" - -loadkeymap -D А CYRILLIC CAPITAL LETTER A -? Б CYRILLIC CAPITAL LETTER BE -L В CYRILLIC CAPITAL LETTER VE -H Г CYRILLIC CAPITAL LETTER GHE -O Д CYRILLIC CAPITAL LETTER DE -E Е CYRILLIC CAPITAL LETTER IE -E:: Ё CYRILLIC CAPITAL LETTER IO -G Ж CYRILLIC CAPITAL LETTER ZHE -P З CYRILLIC CAPITAL LETTER ZE -R И CYRILLIC CAPITAL LETTER I -X Й CYRILLIC CAPITAL LETTER SHORT I -U К CYRILLIC CAPITAL LETTER KA -> Л CYRILLIC CAPITAL LETTER EL -: М CYRILLIC CAPITAL LETTER EM -K Н CYRILLIC CAPITAL LETTER EN -F О CYRILLIC CAPITAL LETTER O -M П CYRILLIC CAPITAL LETTER PE -< Р CYRILLIC CAPITAL LETTER ER -I С CYRILLIC CAPITAL LETTER ES -J Т CYRILLIC CAPITAL LETTER TE -W У CYRILLIC CAPITAL LETTER U -B Ф CYRILLIC CAPITAL LETTER EF -N Х CYRILLIC CAPITAL LETTER HA -{ Ц CYRILLIC CAPITAL LETTER TSE -\" Ч CYRILLIC CAPITAL LETTER CHE -T Ш CYRILLIC CAPITAL LETTER SHA -Y Щ CYRILLIC CAPITAL LETTER SHCHA -C Ъ CYRILLIC CAPITAL LETTER HARD SIGN -CX Ы CYRILLIC CAPITAL LETTER YERU -A Ь CYRILLIC CAPITAL LETTER SOFT SIGN -V Э CYRILLIC CAPITAL LETTER REVERSED E -Z Ю CYRILLIC CAPITAL LETTER YU -S Я CYRILLIC CAPITAL LETTER YA -d а CYRILLIC SMALL LETTER A -\/ б CYRILLIC SMALL LETTER BE -l в CYRILLIC SMALL LETTER VE -h г CYRILLIC SMALL LETTER GHE -o д CYRILLIC SMALL LETTER DE -e е CYRILLIC SMALL LETTER IE -e:: ё CYRILLIC SMALL LETTER IO -g ж CYRILLIC SMALL LETTER ZHE -p з CYRILLIC SMALL LETTER ZE -r и CYRILLIC SMALL LETTER I -x й CYRILLIC SMALL LETTER SHORT I -u к CYRILLIC SMALL LETTER KA -\. л CYRILLIC SMALL LETTER EL -; м CYRILLIC SMALL LETTER EM -k н CYRILLIC SMALL LETTER EN -f о CYRILLIC SMALL LETTER O -m п CYRILLIC SMALL LETTER PE -, р CYRILLIC SMALL LETTER ER -i с CYRILLIC SMALL LETTER ES -j т CYRILLIC SMALL LETTER TE -w у CYRILLIC SMALL LETTER U -b ф CYRILLIC SMALL LETTER EF -n х CYRILLIC SMALL LETTER HA -[ ц CYRILLIC SMALL LETTER TSE -' ч CYRILLIC SMALL LETTER CHE -t ш CYRILLIC SMALL LETTER SHA -y щ CYRILLIC SMALL LETTER SHCHA -c ъ CYRILLIC SMALL LETTER HARD SIGN -Q ы CYRILLIC SMALL LETTER YERU -a ь CYRILLIC SMALL LETTER SOFT SIGN -v э CYRILLIC SMALL LETTER REVERSED E -z ю CYRILLIC SMALL LETTER YU -s я CYRILLIC SMALL LETTER YA -_ I LATIN CAPITAL LETTER I -+ V LATIN CAPITAL LETTER V -$ " QUOTATION MARK -\\ ( LEFT PARENTHESIS -| ) RIGHT PARENTHESIS -# + PLUS SIGN -q , COMMA -( - HYPHEN-MINUS -= . FULL STOP (PERIOD) -* / SOLIDUS (SLASH) -& : COLON -] ; SEMICOLON -^ = EQUALS SIGN -@ ? QUESTION MARK -} § SECTION SIGN (PARAGRAPH SIGN) -) № NUMERO SIGN --- – EN DASH ---- — EM DASH -.. … HORIZONTAL ELLIPSIS -`` “ LEFT DOUBLE QUOTATION MARK -'' ” RIGHT DOUBLE QUOTATION MARK -,, „ DOUBLE LOW-9 QUOTATION MARK -`. ‘ LEFT SINGLE QUOTATION MARK -'. ’ RIGHT SINGLE QUOTATION MARK -<< « LEFT-POINTING DOUBLE ANGLE QUOTATION MARK ->> » RIGHT-POINTING DOUBLE ANGLE QUOTATION MARK -** • BULLET -,. · MIDDLE DOT -+- ± PLUS-MINUS SIGN -^o ° DEGREE SIGN -~~ ¬ NOT SIGN -@@ ¤ CURRENCY SIGN -$$ € EURO SIGN - -" accented vowels cannot map onto cp1251 – use utf-8 file encoding -`D А̀ CYRILLIC CAPITAL LETTER A + GRAVE ACCENT (COMPOSED) -`d а̀ CYRILLIC SMALL LETTER A + GRAVE ACCENT (COMPOSED) -`E Ѐ CYRILLIC CAPITAL LETTER IE + GRAVE ACCENT (COMPOSED) -`e ѐ CYRILLIC SMALL LETTER IE + GRAVE ACCENT (COMPOSED) -`R Ѝ CYRILLIC CAPITAL LETTER I + GRAVE ACCENT (COMPOSED) -`r ѝ CYRILLIC SMALL LETTER I + GRAVE ACCENT (COMPOSED) -`F О̀ CYRILLIC CAPITAL LETTER O + GRAVE ACCENT (COMPOSED) -`f о̀ CYRILLIC SMALL LETTER O + GRAVE ACCENT (COMPOSED) -`W У̀ CYRILLIC CAPITAL LETTER U + GRAVE ACCENT (COMPOSED) -`w у̀ CYRILLIC SMALL LETTER U + GRAVE ACCENT (COMPOSED) -`C Ъ̀ CYRILLIC CAPITAL LETTER HARD SIGN + GRAVE ACCENT (COMPOSED) -`c ъ̀ CYRILLIC SMALL LETTER HARD SIGN + GRAVE ACCENT (COMPOSED) -`Z Ю̀ CYRILLIC CAPITAL LETTER YU + GRAVE ACCENT (COMPOSED) -`z ю̀ CYRILLIC SMALL LETTER YU + GRAVE ACCENT (COMPOSED) -`S Я̀ CYRILLIC CAPITAL LETTER YA + GRAVE ACCENT (COMPOSED) -`s я̀ CYRILLIC SMALL LETTER YA + GRAVE ACCENT (COMPOSED) diff --git a/share/vim/vim72/keymap/bulgarian-phonetic.vim b/share/vim/vim72/keymap/bulgarian-phonetic.vim deleted file mode 100644 index bac2e7ebee..0000000000 --- a/share/vim/vim72/keymap/bulgarian-phonetic.vim +++ /dev/null @@ -1,141 +0,0 @@ -" Vim keymap file for Bulgarian and Russian characters, "phonetic" layout. -" Most of it can be used with both utf-8 and cp1251 file encodings, except -" the accented vowels which can only be stored in utf-8. -" This file itself is in utf-8. - -" Maintainer: Boyko Bantchev <boykobb@gmail.com> -" URI: http://www.math.bas.bg/bantchev/vim/bulgarian-phonetic.vim -" Last Changed: 2008 June 28 - -" For a rationale for the layout and additional info on typing in Bulgarian -" using Unicode Cyrillic please see: - -" This keymap corresponds to what is called "phonetic layout" in Bulgaria: -" Cyrillic letters tend to be mapped to their Latin homophones, if present. -" Most keys corresponding to punctuation characters are left unmapped, so -" they retain their usual (qwerty) meanings in Cyrillic typing. -" -" In addition to the Bulgarian alphabet, the keymap makes accessible the -" following characters: -" — The letters Ё and ё, Э and э, and Ы and ы (in pairs of capital and -" small). These are the letters in the Russian alphabet that are not -" present in Bulgarian, so using the bulgarian-phonetic keymap one can -" type in Russian, too. -" — The quotation marks „ “ ” ‘ ’ (used in the Bulgarian and English -" quotation styles), as well as « » (Russian quotation style). -" — The characters §, №, – (en-dash), — (em-dash), …, •, ·, ±, °, ¬, -" ¤, and €. -" -" The keymap also defines key combinations for accented vowels in Bulgarian. -" -" For details of what key or key combination maps to what character, please -" see below the map table itself. - -scriptencoding utf-8 - -let b:keymap_name = "pho" - -loadkeymap -A А CYRILLIC CAPITAL LETTER A -B Б CYRILLIC CAPITAL LETTER BE -W В CYRILLIC CAPITAL LETTER VE -G Г CYRILLIC CAPITAL LETTER GHE -D Д CYRILLIC CAPITAL LETTER DE -E Е CYRILLIC CAPITAL LETTER IE -E:: Ё CYRILLIC CAPITAL LETTER IO -V Ж CYRILLIC CAPITAL LETTER ZHE -Z З CYRILLIC CAPITAL LETTER ZE -I И CYRILLIC CAPITAL LETTER I -J Й CYRILLIC CAPITAL LETTER SHORT I -K К CYRILLIC CAPITAL LETTER KA -L Л CYRILLIC CAPITAL LETTER EL -M М CYRILLIC CAPITAL LETTER EM -N Н CYRILLIC CAPITAL LETTER EN -O О CYRILLIC CAPITAL LETTER O -P П CYRILLIC CAPITAL LETTER PE -R Р CYRILLIC CAPITAL LETTER ER -S С CYRILLIC CAPITAL LETTER ES -T Т CYRILLIC CAPITAL LETTER TE -U У CYRILLIC CAPITAL LETTER U -F Ф CYRILLIC CAPITAL LETTER EF -H Х CYRILLIC CAPITAL LETTER HA -C Ц CYRILLIC CAPITAL LETTER TSE -~ Ч CYRILLIC CAPITAL LETTER CHE -{ Ш CYRILLIC CAPITAL LETTER SHA -} Щ CYRILLIC CAPITAL LETTER SHCHA -Y Ъ CYRILLIC CAPITAL LETTER HARD SIGN -YI Ы CYRILLIC CAPITAL LETTER YERU -X Ь CYRILLIC CAPITAL LETTER SOFT SIGN -YE Э CYRILLIC CAPITAL LETTER REVERSED E -| Ю CYRILLIC CAPITAL LETTER YU -Q Я CYRILLIC CAPITAL LETTER YA -a а CYRILLIC SMALL LETTER A -b б CYRILLIC SMALL LETTER BE -w в CYRILLIC SMALL LETTER VE -g г CYRILLIC SMALL LETTER GHE -d д CYRILLIC SMALL LETTER DE -e е CYRILLIC SMALL LETTER IE -e:: ё CYRILLIC SMALL LETTER IO -v ж CYRILLIC SMALL LETTER ZHE -z з CYRILLIC SMALL LETTER ZE -i и CYRILLIC SMALL LETTER I -j й CYRILLIC SMALL LETTER SHORT I -k к CYRILLIC SMALL LETTER KA -l л CYRILLIC SMALL LETTER EL -m м CYRILLIC SMALL LETTER EM -n н CYRILLIC SMALL LETTER EN -o о CYRILLIC SMALL LETTER O -p п CYRILLIC SMALL LETTER PE -r р CYRILLIC SMALL LETTER ER -s с CYRILLIC SMALL LETTER ES -t т CYRILLIC SMALL LETTER TE -u у CYRILLIC SMALL LETTER U -f ф CYRILLIC SMALL LETTER EF -h х CYRILLIC SMALL LETTER HA -c ц CYRILLIC SMALL LETTER TSE -` ч CYRILLIC SMALL LETTER CHE -[ ш CYRILLIC SMALL LETTER SHA -] щ CYRILLIC SMALL LETTER SHCHA -y ъ CYRILLIC SMALL LETTER HARD SIGN -yi ы CYRILLIC SMALL LETTER YERU -x ь CYRILLIC SMALL LETTER SOFT SIGN -ye э CYRILLIC SMALL LETTER REVERSED E -\\ ю CYRILLIC SMALL LETTER YU -q я CYRILLIC SMALL LETTER YA -!! § SECTION SIGN (PARAGRAPH SIGN) -## № NUMERO SIGN --- – EN DASH ---- — EM DASH -.. … HORIZONTAL ELLIPSIS -`` “ LEFT DOUBLE QUOTATION MARK -'' ” RIGHT DOUBLE QUOTATION MARK -,, „ DOUBLE LOW-9 QUOTATION MARK -`. ‘ LEFT SINGLE QUOTATION MARK -'. ’ RIGHT SINGLE QUOTATION MARK -<< « LEFT-POINTING DOUBLE ANGLE QUOTATION MARK ->> » RIGHT-POINTING DOUBLE ANGLE QUOTATION MARK -** • BULLET -,. · MIDDLE DOT -+- ± PLUS-MINUS SIGN -^o ° DEGREE SIGN -~~ ¬ NOT SIGN -@@ ¤ CURRENCY SIGN -$$ € EURO SIGN - -" accented vowels cannot map onto cp1251 – use utf-8 file encoding -'A А̀ CYRILLIC CAPITAL LETTER A + GRAVE ACCENT (COMPOSED) -'a а̀ CYRILLIC SMALL LETTER A + GRAVE ACCENT (COMPOSED) -'E Ѐ CYRILLIC CAPITAL LETTER IE + GRAVE ACCENT (COMPOSED) -'e ѐ CYRILLIC SMALL LETTER IE + GRAVE ACCENT (COMPOSED) -'I Ѝ CYRILLIC CAPITAL LETTER I + GRAVE ACCENT (COMPOSED) -'i ѝ CYRILLIC SMALL LETTER I + GRAVE ACCENT (COMPOSED) -'O О̀ CYRILLIC CAPITAL LETTER O + GRAVE ACCENT (COMPOSED) -'o о̀ CYRILLIC SMALL LETTER O + GRAVE ACCENT (COMPOSED) -'U У̀ CYRILLIC CAPITAL LETTER U + GRAVE ACCENT (COMPOSED) -'u у̀ CYRILLIC SMALL LETTER U + GRAVE ACCENT (COMPOSED) -'Y Ъ̀ CYRILLIC CAPITAL LETTER HARD SIGN + GRAVE ACCENT (COMPOSED) -'y ъ̀ CYRILLIC SMALL LETTER HARD SIGN + GRAVE ACCENT (COMPOSED) -'| Ю̀ CYRILLIC CAPITAL LETTER YU + GRAVE ACCENT (COMPOSED) -'\\ ю̀ CYRILLIC SMALL LETTER YU + GRAVE ACCENT (COMPOSED) -'Q Я̀ CYRILLIC CAPITAL LETTER YA + GRAVE ACCENT (COMPOSED) -'q я̀ CYRILLIC SMALL LETTER YA + GRAVE ACCENT (COMPOSED) diff --git a/share/vim/vim72/keymap/czech_utf-8.vim b/share/vim/vim72/keymap/czech_utf-8.vim deleted file mode 100644 index 227f80bef9..0000000000 --- a/share/vim/vim72/keymap/czech_utf-8.vim +++ /dev/null @@ -1,78 +0,0 @@ -" Maintainer: Jiri Tobisek <tobich@yahoo.com> -" Last Changed: 2001 Sep 30 - -let b:keymap = "czech" - -loadkey -0 é -9 í -8 ÷ -7 ý -6 ŵ -5 ř -4 ī -3 ŷ -2 ě -1 + -` ; -) 0 -( 9 -* 8 -& 7 -^ 6 -% 5 -$ 4 -# 3 -@ 2 -! 1 -] ) -} ( -[ ú -{ / -' § -" ! -; ů -: " -/ - -? _ -> : -< ? -| ' -~u ů -~U Ů -\\a ä -\\e ë -\\i ï -\\o ö -\\u å -\\y ÿ -\\A Ä -\\E Ë -\\I ì -\\O Ö -\\U ö -\\Y Ÿ -=a ÷ -=e é -=i í -=o ó -=u ú -=y ý -=A Á -=E É -=I ë -=O Ó -=U ù -=Y û -+c ī -+d Ĭ -+e ě -+n ň -+r ř -+s ŷ -+t š -+z ŵ -"y z If you prefere 'quertz' keyboard -"Y Z instead of 'querty', -"z y just uncomment these -"Z Y four last lines diff --git a/share/vim/vim72/lang/menu_de_de.latin1.vim b/share/vim/vim72/lang/menu_de_de.latin1.vim deleted file mode 100644 index f374465186..0000000000 --- a/share/vim/vim72/lang/menu_de_de.latin1.vim +++ /dev/null @@ -1,303 +0,0 @@ -" Menu Translations: German / Deutsch -" Maintainer: Georg Dahn <gorgyd@yahoo.co.uk> -" Originally By: Marcin Dalecki <dalecki@cs.net.pl> -" Johannes Zellner <johannes@zellner.org> -" Last Change: Sat, 11 Mar 2006 22:40:00 CEST -" vim:set foldmethod=marker tabstop=8: - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 - -" The translations below are in latin1, but they work for cp1252 and -" iso-8859-15 without conversion as well. -if &enc != "cp1252" && &enc != "iso-8859-15" - scriptencoding latin1 -endif - -" {{{ FILE / DATEI -menutrans &File &Datei -menutrans &Open\.\.\.<Tab>:e &Öffnen\.\.\.<Tab>:e -menutrans Sp&lit-Open\.\.\.<Tab>:sp In\ geteiltem\ &Fenster\ öffnen\.\.\.<Tab>:sp -menutrans Open\ Tab\.\.\.<Tab>:tabnew In\ neuem\ &Tab\ öffnen\.\.\.<Tab>:tabnew -menutrans &New<Tab>:enew &Neue\ Datei<Tab>:enew -menutrans &Close<Tab>:close S&chließen<Tab>:close -menutrans &Save<Tab>:w &Speichern<Tab>:w -menutrans Save\ &As\.\.\.<Tab>:sav Speichern\ &als\.\.\.<Tab>:sav -menutrans &Print &Drucken -menutrans Sa&ve-Exit<Tab>:wqa Speichern\ und\ Be&enden<Tab>:wqa -menutrans E&xit<Tab>:qa &Beenden<Tab>:qa - -if has("diff") - menutrans Split\ &Diff\ with\.\.\. D&ifferenz\ in\ geteiltem\ Fenster\ mit\.\.\. - menutrans Split\ Patched\ &By\.\.\. &Patch\ in\ geteiltem\ Fenster\ mit\.\.\. -endif -" }}} FILE / DATEI - -" {{{ EDIT / EDITIEREN -menutrans &Edit &Editieren -menutrans &Undo<Tab>u Z&urück<Tab>u -menutrans &Redo<Tab>^R Vo&r<Tab>^R -menutrans Rep&eat<Tab>\. &Wiederholen<Tab>\. -menutrans Cu&t<Tab>"+x &Ausschneiden<Tab>"+x -menutrans &Copy<Tab>"+y &Kopieren<Tab>"+y -menutrans &Paste<Tab>"+gP Ein&fügen<Tab>"+gP -menutrans Put\ &Before<Tab>[p Da&vor\ einfügen<Tab>[p -menutrans Put\ &After<Tab>]p Da&nach\ einfügen<Tab>]p -menutrans &Delete<Tab>x &Löschen<Tab>x -menutrans &Select\ All<Tab>ggVG Alles\ &markieren<Tab>ggVG -menutrans &Find\.\.\. &Suchen\.\.\. -menutrans Find\ and\ Rep&lace\.\.\. Suchen\ und\ &Ersetzen\.\.\. - -" [-- SETTINGS --] -" XXX &E would conflict with 'Suchen\ und\ &Ersetzen', see above -menutrans Settings\ &Window E&instellungen\.\.\. -menutrans &Global\ Settings &Globale\ Einstellungen -menutrans Startup\ &Settings &Starteinstellungen - -menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! &Hervorhebungen\ ein-\ und\ ausschalten<Tab>:set\ hls! -menutrans Toggle\ &Ignore-case<Tab>:set\ ic! Großschreibung\ &ignorieren\ oder\ benutzen<Tab>:set\ ic! -menutrans Toggle\ &Showmatch<Tab>:set\ sm! Anzeige\ des\ passenden\ &Symbols\ ein-\ und\ ausschalten<Tab>:set\ sm! - -menutrans &Context\ lines &Zusammenhang - -menutrans &Virtual\ Edit &Virtueller\ Editier-Modus -menutrans Never Nie -menutrans Block\ Selection Block-Auswahl -menutrans Insert\ mode Einfüge-Modus -menutrans Block\ and\ Insert Block-Auswahl\ und\ Einfüge-Modus -menutrans Always Immer -menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Einfüge-&Modus\ ein-\ und\ ausschalten<Tab>:set\ im! -menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Vi-Kompatibilität\ ein-\ und\ ausschalten<Tab>:set\ cp! - -menutrans Search\ &Path\.\.\. Such-&Pfad\.\.\. -menutrans Ta&g\ Files\.\.\. Ta&g-Dateien\.\.\. - -menutrans Toggle\ &Toolbar Werkzeugleiste\ ein-\ und\ ausschalten -menutrans Toggle\ &Bottom\ Scrollbar Unteren\ Rollbalken\ ein-\ und\ ausschalten -menutrans Toggle\ &Left\ Scrollbar Linken\ Rollbalken\ ein-\ und\ ausschalten -menutrans Toggle\ &Right\ Scrollbar Rechten\ Rollbalken\ ein-\ und\ ausschalten - -" Edit/File Settings -menutrans F&ile\ Settings &Datei-Einstellungen - -" Boolean options -menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! Anzeige\ der\ Zeilen&nummer\ ein-\ und\ ausschalten<Tab>:set\ nu! -menutrans Toggle\ &List\ Mode<Tab>:set\ list! &List-Modus\ ein-\ und\ ausschalten<Tab>:set\ list! -menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! &Zeilenumbruch\ ein-\ und\ ausschalten<Tab>:set\ wrap! -menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! Umbruch\ an\ &Wortgrenzen\ ein-\ und\ ausschalten<Tab>:set\ lbr! -menutrans Toggle\ &expand-tab<Tab>:set\ et! &Erweiterung\ von\ Tabulatoren\ ein-\ und\ ausschalten<Tab>:set\ et! -menutrans Toggle\ &auto-indent<Tab>:set\ ai! &Automatische\ Einrückung\ ein-\ und\ ausschalten<Tab>:set\ ai! -menutrans Toggle\ &C-indenting<Tab>:set\ cin! &C-Einrückung\ ein-\ und\ ausschalten<Tab>:set\ cin! - -" other options -menutrans &Shiftwidth &Schiebeweite -menutrans Soft\ &Tabstop &Tabulator -menutrans Te&xt\ Width\.\.\. Te&xtbreite\.\.\. -menutrans &File\ Format\.\.\. &Dateiformat\.\.\. -menutrans C&olor\ Scheme F&arbschema\.\.\. -menutrans &Keymap &Tastaturbelegung -" }}} EDIT / EDITIEREN - -" {{{ TOOLS / WERKZEUGE -if has("spell") - menutrans &Spelling &Rechtschreibung - menutrans &Spell\ Check\ On &Rechtschreibprüfung\ an - menutrans Spell\ Check\ &Off Rechtschreibprüfung\ &aus - menutrans To\ &Next\ error<Tab>]s Zum\ &nächsten\ Fehler<Tab>]s - menutrans To\ &Previous\ error<Tab>[s Zum\ &vorherigen\ Fehler<Tab>[s - menutrans Suggest\ &Corrections<Tab>z= &Korrekturvorschläge<Tab>z= - menutrans &Repeat\ correction<Tab>:spellrepall &Wiederhole\ Korrektur<Tab>:spellrepall - menutrans Set\ language\ to\ "en" Verwende\ Wörterbuch\ "en" - menutrans Set\ language\ to\ "en_au" Verwende\ Wörterbuch\ "en_au" - menutrans Set\ language\ to\ "en_ca" Verwende\ Wörterbuch\ "en_ca" - menutrans Set\ language\ to\ "en_gb" Verwende\ Wörterbuch\ "en_gb" - menutrans Set\ language\ to\ "en_nz" Verwende\ Wörterbuch\ "en_nz" - menutrans Set\ language\ to\ "en_us" Verwende\ Wörterbuch\ "en_us" - menutrans Set\ language\ to\ "de" Verwende\ Wörterbuch\ "de" - menutrans &Find\ More\ Languages &Suche\ nach\ Wörterbüchern -endif -if has("folding") - menutrans &Folding Fa<ung - " open close folds - menutrans &Enable/Disable\ folds<Tab>zi &Ein-\ und\ ausschalten<Tab>zi - menutrans &View\ Cursor\ Line<Tab>zv Momentane\ &Position\ anzeigen<Tab>zv - menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx &Ausschließlich\ momentane\ Position\ anzeigen<Tab>zMzx - menutrans C&lose\ more\ folds<Tab>zm Faltungen\ &schließen<Tab>zm - menutrans &Close\ all\ folds<Tab>zM Alle\ Faltungen\ schließen<Tab>zM - menutrans O&pen\ more\ folds<Tab>zr Faltungen\ &öffnen<Tab>zr - menutrans &Open\ all\ folds<Tab>zR Alle\ Faltungen\ öffnen<Tab>zR - " fold method - menutrans Fold\ Met&hod Faltungs-&Methode - menutrans M&anual &Manuell - menutrans I&ndent &Einrückungen - menutrans E&xpression &Ausdruck - menutrans S&yntax &Syntax - menutrans &Diff &Differenz - menutrans Ma&rker Ma&rkierungen - " create and delete folds - " TODO accelerators - menutrans Create\ &Fold<Tab>zf Faltung\ erzeugen<Tab>zf - menutrans &Delete\ Fold<Tab>zd Faltung\ löschen<Tab>zd - menutrans Delete\ &All\ Folds<Tab>zD Alle\ Faltungen\ löschen<Tab>zD - " moving around in folds - menutrans Fold\ column\ &width &Breite\ der\ Faltungsspalte -endif " has folding - -if has("diff") - menutrans &Diff &Differenz - menutrans &Update &Aktualisieren - menutrans &Get\ Block Block\ &einfügen - menutrans &Put\ Block Block\ &übertragen -endif - -menutrans &Tools &Werkzeuge -menutrans &Jump\ to\ this\ tag<Tab>g^] &Springe\ zum\ Tag<Tab>g^] -menutrans Jump\ &back<Tab>^T Springe\ &zurück<Tab>^T -menutrans Build\ &Tags\ File Erstelle\ &Tag-Datei -menutrans &Make<Tab>:make &Erstellen<Tab>:make -menutrans &List\ Errors<Tab>:cl &Fehler\ anzeigen<Tab>:cl -menutrans L&ist\ Messages<Tab>:cl! &Hinweise\ anzeigen<Tab>:cl! -menutrans &Next\ Error<Tab>:cn Zum\ &nächsten\ Fehler<Tab>:cn -menutrans &Previous\ Error<Tab>:cp Zum\ &vorherigen\ Fehler<Tab>:cp -menutrans &Older\ List<Tab>:cold &Ältere\ Liste<Tab>:cold -menutrans N&ewer\ List<Tab>:cnew &Neuere\ Liste<Tab>:cnew - -menutrans Error\ &Window Feh&ler-Fenster -menutrans Se&t\ Compiler &Compiler -menutrans Se&T\ Compiler &Compiler -menutrans &Update<Tab>:cwin &Aktualisieren<Tab>:cwin -menutrans &Open<Tab>:copen &Öffnen<Tab>:copen -menutrans &Close<Tab>:cclose &Schließen<Tab>:cclose - -menutrans &Convert\ to\ HEX<Tab>:%!xxd Nach\ HE&X\ konvertieren<Tab>:%!xxd -menutrans Conve&rt\ back<Tab>:%!xxd\ -r Zurück\ konvertieren<Tab>:%!xxd\ -r -" }}} TOOLS / WERKZEUGE - -" {{{ SYNTAX / SYNTAX -menutrans &Syntax &Syntax -menutrans &Show\ filetypes\ in\ menu Dateitypen\ an&zeigen -menutrans Set\ '&syntax'\ only Nur\ '&syntax'\ setzen -menutrans Set\ '&filetype'\ too Auch\ '&filetype'\ setzen -menutrans &Off &Aus -menutrans &Manual &Manuell -menutrans A&utomatic A&utomatisch -menutrans on/off\ for\ &This\ file An/Aus (diese\ &Datei) -menutrans Co&lor\ test Test\ der\ Farben -menutrans &Highlight\ test Test\ der\ Un&terstreichungen -menutrans &Convert\ to\ HTML Konvertieren\ nach\ &HTML -" }}} SYNTAX / SYNTAX - -" {{{ BUFFERS / PUFFER -menutrans &Buffers &Puffer -menutrans &Refresh\ menu &Aktualisieren -menutrans Delete Löschen -menutrans &Alternate &Wechseln -menutrans &Next &Nächster -menutrans &Previous &Vorheriger -" }}} BUFFERS / PUFFER - -" {{{ WINDOW / ANSICHT -menutrans &Window &Ansicht -menutrans &New<Tab>^Wn &Neu<Tab>^Wn -menutrans S&plit<Tab>^Ws Aufs&palten<Tab>^Ws -menutrans Split\ &Vertically<Tab>^Wv &Vertikal\ aufspalten<Tab>^Wv -menutrans Split\ File\ E&xplorer Ver&zeichnis -menutrans Sp&lit\ To\ #<Tab>^W^^ Aufspa<en\ in\ #<Tab>^W^^ -menutrans &Close<Tab>^Wc &Schließen<Tab>^Wc -menutrans Close\ &Other(s)<Tab>^Wo &Andere\ schließen<Tab>^Wo -menutrans Ne&xt<Tab>^Ww N&ächstes<Tab>^Ww -menutrans P&revious<Tab>^WW Vor&heriges<Tab>^WW -menutrans &Equal\ Size<Tab>^W= &Gleiche\ Höhen<Tab>^W= -menutrans &Max\ Height<Tab>^W_ &Maximale\ Höhe<Tab>^W_ -menutrans M&in\ Height<Tab>^W1_ M&inimale\ Höhe<Tab>^W1_ -menutrans Max\ &Width<Tab>^W\| Maximale\ &Breite<Tab>^W\| -menutrans Min\ Widt&h<Tab>^W1\| Minimale\ Brei&te<Tab>^W1\| -menutrans Move\ &To V&erschiebe\ nach -menutrans &Top<Tab>^WK &Oben<Tab>^WK -menutrans &Bottom<Tab>^WJ &Unten<Tab>^WJ -menutrans &Left\ side<Tab>^WH &Links<Tab>^WH -menutrans &Right\ side<Tab>^WL &Rechts<Tab>^WL -menutrans Rotate\ &Up<Tab>^WR Rotiere\ nach\ &oben<Tab>^WR -menutrans Rotate\ &Down<Tab>^Wr Rotiere\ nach\ &unten<Tab>^Wr -menutrans Select\ Fo&nt\.\.\. Auswahl\ der\ Schriftart\.\.\. -" }}} WINDOW / ANSICHT - -" {{{ HELP / HILFE -menutrans &Help &Hilfe -menutrans &Overview<Tab><F1> &Überblick<Tab><F1> -menutrans &User\ Manual &Handbuch -menutrans &How-to\ links How-to\ &Index -menutrans &GUI &Graphische\ Oberfläche -menutrans &Credits &Autoren -menutrans Co&pying &Urheberrecht -menutrans O&rphans &Waisen -menutrans &Find\.\.\. &Suchen\.\.\. " conflicts with Edit.Find -menutrans &Version &Version -menutrans &About &Titelseite -" }}} HELP / HILFE - -" {{{ POPUP -menutrans &Undo &Zurück -menutrans Cu&t Aus&schneiden -menutrans &Copy &Kopieren -menutrans &Paste &Einfügen -menutrans &Delete &Löschen -menutrans Select\ Blockwise Auswahl\ blockartig -menutrans Select\ &Word Auswahl\ des\ &Wortes -menutrans Select\ &Sentence Auswahl\ des\ Sa&tzes -menutrans Select\ Pa&ragraph Auswahl\ des\ Absatzes -menutrans Select\ &Line Auswahl\ der\ &Zeile -menutrans Select\ &Block Auswahl\ des\ &Blocks -menutrans Select\ &All &Alles\ Auswählen -" }}} POPUP - -" {{{ TOOLBAR -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open Datei öffnen - tmenu ToolBar.Save Datei speichern - tmenu ToolBar.SaveAll Alle Dateien speichern - tmenu ToolBar.Print Drucken - tmenu ToolBar.Undo Zurück - tmenu ToolBar.Redo Wiederholen - tmenu ToolBar.Cut Ausschneiden - tmenu ToolBar.Copy Kopieren - tmenu ToolBar.Paste Einfügen - tmenu ToolBar.Find Suchen... - tmenu ToolBar.FindNext Suche nächsten - tmenu ToolBar.FindPrev Suche vorherigen - tmenu ToolBar.Replace Suchen und Ersetzen... - if 0 " disabled; These are in the Windows menu - tmenu ToolBar.New Neue Ansicht - tmenu ToolBar.WinSplit Ansicht aufspalten - tmenu ToolBar.WinMax Ansicht maximale Höhen - tmenu ToolBar.WinMin Ansicht minimale Höhen - tmenu ToolBar.WinClose Ansicht schließen - endif - tmenu ToolBar.LoadSesn Sitzung laden - tmenu ToolBar.SaveSesn Sitzung speichern - tmenu ToolBar.RunScript Vim-Skript ausführen - tmenu ToolBar.Make Erstellen - tmenu ToolBar.Shell Shell starten - tmenu ToolBar.RunCtags Erstelle Tag-Datei - tmenu ToolBar.TagJump Springe zum Tag - tmenu ToolBar.Help Hilfe! - tmenu ToolBar.FindHelp Hilfe durchsuchen... - endfun -endif -" }}} TOOLBAR - -" {{{ DIALOG TEXTS -let g:menutrans_no_file = "[Keine Datei]" -let g:menutrans_help_dialog = "Geben Sie einen Befehl oder ein Wort ein, für das Sie Hilfe benötigen:\n\nVerwenden Sie i_ für Eingabe ('input') Befehle (z.B.: i_CTRL-X)\nVerwenden Sie c_ für Befehls-Zeilen ('command-line') Befehle (z.B.: c_<Del>)\nVerwenden Sie ' für Options-Namen (z.B.: 'shiftwidth')" -let g:menutrans_path_dialog = "Geben Sie Such-Pfade für Dateien ein.\nTrennen Sie die Verzeichnis-Namen durch Kommata." -let g:menutrans_tags_dialog = "Geben Sie die Namen der 'tag'-Dateien ein.\nTrennen Sie die Namen durch Kommata." -let g:menutrans_textwidth_dialog = "Geben Sie eine neue Text-Breite ein (oder 0, um die Formatierung abzuschalten)" -let g:menutrans_fileformat_dialog = "Wählen Sie ein Datei-Format aus" -" }}} diff --git a/share/vim/vim72/lang/menu_es_es.latin1.vim b/share/vim/vim72/lang/menu_es_es.latin1.vim deleted file mode 100644 index 8001100451..0000000000 --- a/share/vim/vim72/lang/menu_es_es.latin1.vim +++ /dev/null @@ -1,297 +0,0 @@ -" Menu Translations: Español -" Maintainer: Alejandro López-Valencia <dradul@users.sourceforge.net> -" Version: 6.4.p0-1 -" Last Change: 2005 Dec 01 -" - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 - -" The translations below are in latin1, but they work for cp1252, -" iso-8859-15 without conversion as well. -if &enc != "cp1252" && &enc != "iso-8859-15" - scriptencoding latin1 -endif - - -" Help menu -menutrans &Help Ay&uda -menutrans &Overview<Tab><F1> Tabla\ de\ &contenidos<Tab><F1> -menutrans &User\ Manual &Manual\ del\ usuario -menutrans &How-to\ links &Enlaces\ a\ ¿Cómo\ hago\.\.\.? -menutrans &Find\.\.\. &Buscar\ en\ la\ ayuda -menutrans &Credits &Reconocimientos -menutrans O&rphans Ayude\ a\ los\ niños\ &huérfanos -menutrans Co&pying &Términos\ de\ Licencia -menutrans Sponsor/Register Benefactor/Regístrese -menutrans &Version &Versión\ e\ \información\ de\ configuración -menutrans &About &Acerca\ de\ Vim. - -" File menu -menutrans &File &Archivo -menutrans &Open\.\.\.<Tab>:e &Abrir\.\.\.<Tab>:e -menutrans Sp&lit-Open\.\.\.<Tab>:sp A&brir\ en\ otra\ ventana\.\.\.<Tab>:sp -menutrans &New<Tab>:enew &Nuevo<Tab>:enew -menutrans &Close<Tab>:close &Cerrar<Tab>:close -menutrans &Save<Tab>:w &Guardar<Tab>:w -menutrans Save\ &As\.\.\.<Tab>:sav Guardar\ &como\.\.\.<Tab>:sav -menutrans Split\ &Diff\ with\.\.\. &Mostrar\ diferencias\ con\.\.\. -menutrans Split\ Patched\ &By\.\.\. Mostrar\ &parcheado\ por\.\.\. -menutrans &Print &Imprimir -menutrans Sa&ve-Exit<Tab>:wqa Gua&rdar\ y\ salir<Tab>:wqa -menutrans E&xit<Tab>:qa &Salir<Tab>:qa - -" Edit menu -menutrans &Edit &Editar -menutrans &Undo<Tab>u &Deshacer<Tab>u -menutrans &Redo<Tab>^R &Rehacer<Tab>^R -menutrans Rep&eat<Tab>\. Repe&tir<Tab>\. -menutrans Cu&t<Tab>"+x Cor&tar<Tab>"+x -menutrans &Copy<Tab>"+y &Copiar<Tab>"+y -menutrans &Paste<Tab>"+gP &Pegar<Tab>"+gP -menutrans Put\ &Before<Tab>[p Poner\ &antes<Tab>[p -menutrans Put\ &After<Tab>]p Poner\ &después<Tab>]p -if has("win32") || has("win16") - menutrans &Delete<Tab>x S&uprimir<Tab>x -endif -menutrans &Select\ all<Tab>ggVG &Seleccionar\ todo<Tab>ggVG -menutrans &Find\.\.\. &Buscar\.\.\. -menutrans &Find<Tab>/ &Buscar<Tab>/ -menutrans Find\ and\ Rep&lace\.\.\. Buscar\ y\ R&eemplazar\.\.\. -menutrans Find\ and\ Rep&lace<Tab>:%s Buscar\ y\ R&eemplazar<Tab>:%s -menutrans Find\ and\ Rep&lace Buscar\ y\ R&eemplazar -menutrans Find\ and\ Rep&lace<Tab>:s Buscar\ y\ R&eemplazar<Tab>:s -menutrans Settings\ &Window &Ventana\ de\ opciones - -" Edit/Global Settings -menutrans &Global\ Settings Opciones\ &globales - -menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! Activar/Desactivar\ &realzado\ de\ sintaxis<Tab>:set\ hls! -menutrans Toggle\ &Ignore-case<Tab>:set\ ic! Activar/Desactivar\ &ignorar\ mayúsculas\ y\ minúsculas<Tab>:set\ ic! -menutrans Toggle\ &Showmatch<Tab>:set\ sm! Activar/Desactivar\ &mostrar\ coincidencias<Tab>:set\ sm! - -menutrans &Context\ lines Líneas\ de\ &contexto - -menutrans &Virtual\ Edit Edición\ &virtual -menutrans Never Nunca -menutrans Block\ Selection Selección\ de\ bloque -menutrans Insert\ mode Modo\ de\ inserción -menutrans Block\ and\ Insert Bloque\ e\ inserción -menutrans Always Siempre - -menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Activar/Desactivar\ modo\ de\ in&serción<Tab>:set\ im! -menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Activar/Desactivar\ compatiblidad\ con\ Vi<Tab>:set\ cp! - -menutrans Search\ &Path\.\.\. Ruta\ de\ &búsqueda\.\.\. - -menutrans Ta&g\ Files\.\.\. Ficheros\ de\ &etiquetas\.\.\. - -" GUI options -menutrans Toggle\ &Toolbar Ocultar/Mostrar\ barra\ de\ &herramientas -menutrans Toggle\ &Bottom\ Scrollbar Ocultar/Mostrar\ barra\ de\ desplazamiento\ &inferior -menutrans Toggle\ &Left\ Scrollbar Ocultar/Mostrar\ barra\ de\ desplazamiento\ i&zquierda -menutrans Toggle\ &Right\ Scrollbar Ocultar/Mostrar\ barra\ de\ desplazamiento\ &derecha - -let g:menutrans_path_dialog = "Introduzca la ruta de búsqueda para los ficheros.\nSepare los nombres de los directorios con una coma." -let g:menutrans_tags_dialog = "Introduzca los nombres de los fichero de tags.\nSepare los nombres con una coma." - -" Edit/File Settings -menutrans F&ile\ Settings Opciones\ del\ &fichero - -" Boolean options -menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! Activar/Desactivar\ &numeración\ de\ líneas<Tab>:set\ nu! -menutrans Toggle\ &List\ Mode<Tab>:set\ list! Activar/Desactivar\ modo\ de\ lista<Tab>:set\ list! -menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! Activar/Desactivar\ &quiebre\ de\ líneas<Tab>:set\ wrap! -menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! Activar/Desactivar\ quiebre\ entre\ &palabras<Tab>:set\ lbr! -menutrans Toggle\ &expand-tab<Tab>:set\ et! Activar/Desactivar\ &expansión\ de\ marcas\ de\ \tabulado<Tab>:set\ et! -menutrans Toggle\ &auto-indent<Tab>:set\ ai! Activar/Desactivar\ &auto-sangrado<Tab>:set\ ai! -menutrans Toggle\ &C-indenting<Tab>:set\ cin! Activar/Desactivar\ sangrado\ &C<Tab>:set\ cin! - -" other options -menutrans &Shiftwidth Anchura\ del\ &sangrado - -menutrans Soft\ &Tabstop &Tabulado\ «blando» - -menutrans Te&xt\ Width\.\.\. Anchura\ del\ te&xto\.\.\. -let g:menutrans_textwidth_dialog = "Introduzca el nuevo ancho del texto (0 para desactivar el quiebre de línea): " - -menutrans &File\ Format\.\.\. &Formato\ del\ fichero\.\.\. -let g:menutrans_fileformat_dialog = "Seleccione el formato para escribir el fichero" - -menutrans C&olor\ Scheme Esquema\ de\ c&olores -menutrans blue azul -menutrans darkblue azul\ oscuro -menutrans default original -menutrans desert desierto -menutrans evening vespertino -menutrans morning matutino -menutrans peachpuff melocotón -menutrans shine brillante - -menutrans Select\ Fo&nt\.\.\. Seleccionar\ fue&nte\.\.\. - -menutrans &Keymap Asociación\ de\ teclados -menutrans None Ninguna -menutrans accents acentos -menutrans arabic árabe -menutrans czech checo -menutrans greek griego -menutrans hebrew hebreo -menutrans hebrewp hebreo\ fonético -menutrans lithuanian-baltic lituano-báltico -menutrans russian-jcuken ruso-«jcuken» -menutrans russian-jcukenwin ruso-«jcuken»\ Windows -menutrans russian-yawerty ruso-«yawerty» -menutrans serbian-latin serbio-latino -menutrans serbian serbio -menutrans slovak eslovaco - - -" Programming menu -menutrans &Tools &Herramientas -menutrans &Jump\ to\ this\ tag<Tab>g^] &Saltar\ a\ este\ etiqueta<Tab>g^] -menutrans Jump\ &back<Tab>^T Saltar\ &atrás<Tab>^T -menutrans Build\ &Tags\ File Crear\ fichero\ de\ &etiquetas\ -menutrans &Diff Modo\ de\ &diferencias -menutrans &Folding &Plegado -menutrans &Make<Tab>:make Ejecutar\ «&Make»<Tab>:make -menutrans &List\ Errors<Tab>:cl &Lista\ de\ errores<Tab>:cl -menutrans L&ist\ Messages<Tab>:cl! L&ista\ de\ mensajes<Tab>:cl! -menutrans &Next\ Error<Tab>:cn &Error\ siguiente<Tab>:cn -menutrans &Previous\ Error<Tab>:cp Error\ p&revio<Tab>:cp -menutrans &Older\ List<Tab>:cold Lista\ de\ &viejos\ a\ nuevos<Tab>:cold -menutrans N&ewer\ List<Tab>:cnew Lista\ de\ &nuevos\ a\ viejos<Tab>:cnew -menutrans Error\ &Window Ven&tana\ de\ errores -menutrans &Set\ Compiler Esco&ger\ el\ compilador\ a\ usar -menutrans &Convert\ to\ HEX<Tab>:%!xxd Convertir\ a\ formato\ &hexadecimal<Tab>:%!xxd -menutrans Conve&rt\ back<Tab>:%!xxd\ -r &Convertir\ al\ formato\ original<Tab>:%!xxd\ -r - -" Tools.Fold Menu -menutrans &Enable/Disable\ folds<Tab>zi &Activar/Desactivar\ pliegues<Tab>zi -menutrans &View\ Cursor\ Line<Tab>zv &Ver\ línea\ del\ cursor<Tab>zv -menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx Ve&r\ sólo\ la\ línea\ del\ cursor<Tab>zMzx -menutrans C&lose\ more\ folds<Tab>zm C&errar\ más\ pliegues<Tab>zm -menutrans &Close\ all\ folds<Tab>zM &Cerrar\ todos\ los\ pliegues<Tab>zM -menutrans O&pen\ more\ folds<Tab>zr Abrir\ &más\ pliegues<Tab>zr -menutrans &Open\ all\ folds<Tab>zR &Abrir\ todos\ los\ pliegues<Tab>zR -" fold method -menutrans Fold\ Met&hod &Método\ de\ plegado -" create and delete folds -menutrans Create\ &Fold<Tab>zf Crear\ &pliegue<Tab>zf -menutrans &Delete\ Fold<Tab>zd &Suprimir\ pliegue<Tab>zd -menutrans Delete\ &All\ Folds<Tab>zD Suprimir\ &todos\ los\ pligues<Tab>zD -" moving around in folds -menutrans Fold\ col&umn\ width A&nchura\ de\ columna\ del\ pliegue - -" Tools.Diff Menu -menutrans &Update &Actualizar -menutrans &Get\ Block &Obtener\ bloque -menutrans &Put\ Block &Poner\ bloque - -"Tools.Error Menu -menutrans &Update<Tab>:cwin &Actualizar -menutrans &Open<Tab>:copen A&brir -menutrans &Close<Tab>:cclose &Cerrar - -" Names for buffer menu. -menutrans &Buffers &Buffers -menutrans &Refresh\ menu &Refrescar\ menú -menutrans &Delete &Suprimir -menutrans &Alternate &Alternar -menutrans &Next Si&guiente -menutrans &Previous &Previo -let g:menutrans_no_file = "[Sin fichero]" - -" Window menu -menutrans &Window &Ventana -menutrans &New<Tab>^Wn Ventana\ &nueva<Tab>^Wn -menutrans S&plit<Tab>^Ws &Dividir\ la\ ventana<Tab>^Ws -menutrans Sp&lit\ To\ #<Tab>^W^^ D&ividir\ en\ el\ marcador\ (#)<Tab>^W^^ -menutrans Split\ &Vertically<Tab>^Wv Dividir\ &verticalmente<Tab>^Wv -menutrans Split\ File\ E&xplorer &Abrir\ el\ «Explorador\ de\ ficheros» -menutrans &Close<Tab>^Wc &Cerrar\ esta\ ventana<Tab>^Wc -menutrans Close\ &Other(s)<Tab>^Wo Cerrar\ &otra(s)\ ventana(s)<Tab>^Wo -menutrans Move\ &To Mov&er\ a -menutrans &Top<Tab>^WK &Arriba<Tab>^WK -menutrans &Bottom<Tab>^WJ A&bajo<Tab>^WJ -menutrans &Left\ side<Tab>^WH Lado\ &izquierdo<Tab>^WH -menutrans &Right\ side<Tab>^WL Lado\ &derecho<Tab>^WL -menutrans Rotate\ &Up<Tab>^WR &Rotar\ hacia\ arriba<Tab>^WR -menutrans Rotate\ &Down<Tab>^Wr Rotar\ hacia\ a&bajo<Tab>^Wr -menutrans &Equal\ Size<Tab>^W= Mismo\ &tamaño<Tab>^W= -menutrans &Max\ Height<Tab>^W_ Altura\ &máxima<Tab>^W_ -menutrans M&in\ Height<Tab>^W1_ Altura\ mí&nima<Tab>^W1_ -menutrans Max\ &Width<Tab>^W\| Anchura\ má&xima<Tab>^W\| -menutrans Min\ Widt&h<Tab>^W1\| Anc&hura\ mínima<Tab>^W1\| - -" The popup menu -menutrans &Undo &Deshacer -menutrans Cu&t Cor&tar -menutrans &Copy &Copiar -menutrans &Paste &Pegar -menutrans &Delete &Borrar -menutrans Select\ Blockwise Seleccionar\ por\ bloque -menutrans Select\ &Word Seleccionar\ &palabra -menutrans Select\ &Line Seleccionar\ una\ &línea -menutrans Select\ &Block Seleccionar\ un\ &bloque -menutrans Select\ &All Seleccionar\ &todo - -" The GUI toolbar -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open Abrir fichero - tmenu ToolBar.Save Guardar fichero - tmenu ToolBar.SaveAll Guardar todos los ficheros - tmenu ToolBar.Print Imprimir - tmenu ToolBar.Undo Deshacer - tmenu ToolBar.Redo Rehacer - tmenu ToolBar.Cut Cortar - tmenu ToolBar.Copy Copiar - tmenu ToolBar.Paste Pegar - tmenu ToolBar.Find Buscar... - tmenu ToolBar.FindNext Buscar siguiente - tmenu ToolBar.FindPrev Buscar precedente - tmenu ToolBar.Replace Buscar y reemplazar - if 0 " disabled; These are in the Windows menu - tmenu ToolBar.New Ventana nueva - tmenu ToolBar.WinSplit Dividir ventana - tmenu ToolBar.WinMax Altura máxima - tmenu ToolBar.WinMin Altura mínima - tmenu ToolBar.WinVSplit Dividir verticalmente - tmenu ToolBar.WinMaxWidth Anchura máxima - tmenu ToolBar.WinMinWidth Anchura mínima - tmenu ToolBar.WinClose Cerrar ventana - endif - tmenu ToolBar.LoadSesn Cargar sesión - tmenu ToolBar.SaveSesn Guardar sesión - tmenu ToolBar.RunScript Ejecutar un archivo de órdenes - tmenu ToolBar.Make Ejecutar «Make» - tmenu ToolBar.Shell Abrir un intérprete de comandos - tmenu ToolBar.RunCtags Generar un fichero de etiquetas - tmenu ToolBar.TagJump Saltar a una etiqueta - tmenu ToolBar.Help Ayuda - tmenu ToolBar.FindHelp Buscar en la ayuda... - endfun -endif - -" Syntax menu -menutrans &Syntax &Sintaxis -menutrans &Show\ filetypes\ in\ menu &Mostrar\ listas\ de\ «tipo\ de\ fichero» -menutrans Set\ '&syntax'\ only Activar\ sólo\ sintaxis -menutrans Set\ '&filetype'\ too Activar\ también\ «tipo\ de\ fichero» -menutrans &Off &Desactivar\ sintaxis -menutrans &Manual sintaxis\ &manual -menutrans A&utomatic sintaxis\ a&utomática -menutrans on/off\ for\ &This\ file Activar/Desactivar\ en\ es&te\ fichero -menutrans Co&lor\ test &Prueba\ de\ colores -menutrans &Highlight\ test Prueba\ de\ &realzado -menutrans &Convert\ to\ HTML &Convertir\ a\ HTML - -" Find Help dialog text -let g:menutrans_help_dialog = "Introduzca un nombre de comando o palabra para obtener ayuda;\n\nAnteponga i_ para comandos de entrada (e.g.: i_CTRL-X)\nAnteponga c_ para comandos de la línea de comandos (e.g.: c_<Del>)\nAnteponga ` para un nombre de opción (e.g.: `shiftwidth`)" diff --git a/share/vim/vim72/lang/menu_it_it.latin1.vim b/share/vim/vim72/lang/menu_it_it.latin1.vim deleted file mode 100644 index aac8fb6408..0000000000 --- a/share/vim/vim72/lang/menu_it_it.latin1.vim +++ /dev/null @@ -1,349 +0,0 @@ -" Menu Translations: Italian / Italiano -" Maintainer: Antonio Colombo <azc100@gmail.com> -" Vlad Sandrini <vlad.gently@gmail.com> -" Last Change: 2006 Apr 03 - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 - -scriptencoding iso-8859-1 - -" Help / Aiuto -menut &Help &Aiuto -menut &Overview<Tab><F1> &Panoramica<Tab><F1> -menut &User\ Manual Manuale\ &Utente -menut &How-to\ links Co&me\.\.\. -"menut &GUI &GUI -menut &Credits Cr&editi -menut Co&pying C&opie -menut &Sponsor/Register &Sponsor/Registrazione -menut O&rphans O&rfani -"menut &Find\.\.\. &Cerca\.\.\. -"NOTA: fa conflitto con 'cerca' nel menu 'modifica' -menut &Version &Versione -menut &About &Intro - -let g:menutrans_help_dialog = "Batti un comando o una parola per cercare aiuto:\n\nPremetti i_ per comandi in modalità Input (ad.es.: i_CTRL-X)\nPremetti c_ per comandi che editano la linea-comandi (ad.es.: c_<Del>)\nPremetti ' per un nome di opzione (ad.es.: 'shiftwidth')" - -" File menu -"menut &File &File -" -menut &Open\.\.\.<Tab>:e &Apri\.\.\.<Tab>:e -menut Sp&lit-Open\.\.\.<Tab>:sp A&pri\ nuova\ Finestra\.\.\.<Tab>:sp -menut Open\ Tab\.\.\.<Tab>:tabnew Apri\ nuova\ &Linguetta\.\.\.<Tab>:tabnew -menut &New<Tab>:enew &Nuovo<Tab>:enew -menut &Close<Tab>:close &Chiudi<Tab>:close -menut &Save<Tab>:w &Salva<Tab>:w -menut Save\ &As\.\.\.<Tab>:sav Salva\ &con\ nome\.\.\.<Tab>:sav - -if has("diff") - menut Split\ &Diff\ with\.\.\. Finestra\ &Differenza\ con\.\.\. - menut Split\ Patched\ &By\.\.\. Finestra\ Patc&h\ da\.\.\. -endif - -menut &Print S&tampa -menut Sa&ve-Exit<Tab>:wqa Sa&lva\ ed\ esci<Tab>:wqa -menut E&xit<Tab>:qa &Esci<Tab>:qa - -" Edit / Modifica - -menut &Edit &Modifica -menut &Undo<Tab>u &Annulla<Tab>u -menut &Redo<Tab>^R &Ripristina<Tab>^R -menut Rep&eat<Tab>\. Ri&peti<Tab>\. -menut Cu&t<Tab>"+x &Taglia<Tab>"+x -menut &Copy<Tab>"+y &Copia<Tab>"+y -menut &Paste<Tab>"+gP &Incolla<Tab>"+gP -menut Put\ &Before<Tab>[p &Metti\ davanti<Tab>[p -menut Put\ &After<Tab>]p M&etti\ dietro<Tab>]p -menut &Delete<Tab>x Cance&lla<Tab>x -menut &Select\ all<Tab>ggVG Seleziona\ &tutto<Tab>ggVG -menut &Select\ All<Tab>ggVG Seleziona\ &tutto<Tab>ggVG -menut &Find\.\.\. &Cerca\.\.\. -menut Find\ and\ Rep&lace\.\.\. &Sostituisci\.\.\. -menut Settings\ &Window &Finestra\ Impostazioni -menut Startup\ &Settings Impostazioni\ di\ &Avvio -menut &Global\ Settings Impostazioni\ &Globali -menut Question Domanda - -" Edit / Modifica Impostazioni Globali -menut &Global\ Settings Impostazioni\ &Globali -menut Toggle\ Pattern\ &Highlight<Tab>:set\ hls! &Evidenzia\ ricerche\ Sì/No<Tab>:set\ hls! -menut Toggle\ &Ignore-case<Tab>:set\ ic! &Ignora\ maiusc\.-minusc\.\ Sì/No<Tab>:set\ ic! -menut Toggle\ &Showmatch<Tab>:set\ sm! Indica\ &Corrispondente\ Sì/No<Tab>:set\ sm! - -menut &Context\ lines &Linee\ di\ contesto -menut &Virtual\ Edit &Edit\ Virtuale - -menut Never Mai -menut Block\ Selection Selezione\ Blocco -menut Insert\ mode Modalità\ Inserimento -menut Block\ and\ Insert Selezione\ Blocco+Inserimento -menut Always Sempre - -menut Toggle\ Insert\ &Mode<Tab>:set\ im! &Modalità\ Inserimento\ Sì/No<Tab>:set\ im! -menut Toggle\ Vi\ C&ompatible<Tab>:set\ cp! C&ompatibile\ Vi\ Sì/No<Tab>:set\ cp! -menut Search\ &Path\.\.\. &Percorso\ di\ ricerca\.\.\. -menut Ta&g\ Files\.\.\. File\ Ta&g\.\.\. -" -" Opzioni GUI -menut Toggle\ &Toolbar Barra\ S&trumenti\ Sì/No -menut Toggle\ &Bottom\ Scrollbar Barra\ Scorrimento\ in\ &fondo\ Sì/No -menut Toggle\ &Left\ Scrollbar Barra\ Scorrimento\ a\ &sinistra\ Sì/No -menut Toggle\ &Right\ Scrollbar Barra\ Scorrimento\ a\ &destra\ Sì/No - -let g:menutrans_path_dialog = "Batti percorso di ricerca per i file.\nSepara fra loro i nomi di directory con una virgola." -let g:menutrans_tags_dialog = "Batti nome dei file di tag.\nSepara fra loro i nomi di directory con una virgola." - -" Edit / Impostazioni File -menut F&ile\ Settings &Impostazioni\ File - -" Boolean options -menut Toggle\ Line\ &Numbering<Tab>:set\ nu! &Numerazione\ \ Sì/No<Tab>:set\ nu! -menut Toggle\ &List\ Mode<Tab>:set\ list! Modalità\ &Lista\ Sì/No<Tab>:set\ list! -menut Toggle\ Line\ &Wrap<Tab>:set\ wrap! Linee\ &Continuate\ Sì/No<Tab>:set\ wrap! -menut Toggle\ W&rap\ at\ word<Tab>:set\ lbr! A\ capo\ alla\ &parola\ Sì/No<Tab>:set\ lbr! -menut Toggle\ &expand-tab<Tab>:set\ et! &Espandi\ Tabulazione\ Sì/No<Tab>:set\ et! -menut Toggle\ &auto-indent<Tab>:set\ ai! Indentazione\ &automatica\ Sì/No<Tab>:set ai! -menut Toggle\ &C-indenting<Tab>:set\ cin! Indentazione\ stile\ &C\ Sì/No<Tab>:set cin! - -" altre opzioni -menut &Shiftwidth &Spazi\ Rientranza -menut Soft\ &Tabstop &Tabulazione\ Software -menut Te&xt\ Width\.\.\. Lunghe&zza\ Riga\.\.\. -menut &File\ Format\.\.\. Formato\ &File\.\.\. - -let g:menutrans_textwidth_dialog = "Batti nuova lunghezza linea (0 per inibire la formattazione): " - -let g:menutrans_fileformat_dialog = "Scegli formato con cui scrivere il file" - -menut C&olor\ Scheme Schema\ C&olori - -menut default normale -menut DEFAULT NORMALE -menut evening notturno -menut EVENING NOTTURNO -menut morning diurno -menut MORNING DIURNO -menut shine brillante -menut SHINE BRILLANTE -menut peachpuff pesca -menut PEACHPUF PESCA - -menut &Keymap &Mappa\ tastiera - -menut None nessuna -menut accents accenti -menut ACCENTS ACCENTI -menut hebrew ebraico -menut HEBREW EBRAICO -menut hebrew_iso-8859-8 ebraico_iso-8859-8 -menut hebrew_cp1255 ebraico_cp1255 -menut hebrew_utf-8 ebraico_utf-8 -menut hebrewp_iso-8859-8 ebraico_p_iso-8859-8 -menut HEBREW- EBRAICO+ -menut hebrewp EBRAICOP -menut HEBREWP EBRAICOP -menut russian-jcuken cirillico-jcuken -menut russian-jcukenwin cirillico-jcuken-win -menut RUSSIAN CIRILLICO -menut RUSSIAN- CIRILLICO- - -menut Select\ Fo&nt\.\.\. Scegli\ &Font\.\.\. - -" Menu strumenti programmazione -menut &Tools &Strumenti - -menut &Jump\ to\ this\ tag<Tab>g^] &Vai\ a\ questa\ Tag<Tab>g^] -menut Jump\ &back<Tab>^T Torna\ &indietro<Tab>^T -menut Build\ &Tags\ File Costruisci\ File\ &Tags\ - -" Menu ortografia / Spelling -menut &Spelling &Ortografia - -menut &Spell\ Check\ On Attiva\ &Controllo\ ortografico -menut Spell\ Check\ &Off &Disattiva\ controllo\ ortografico -menut To\ &Next\ error<Tab>]s Errore\ &Seguente<tab>]s -menut To\ &Previous\ error<Tab>[s Errore\ &Precedente<tab>[s -menut Suggest\ &Corrections<Tab>z= &Suggerimenti<Tab>z= -menut &Repeat\ correction<Tab>:spellrepall &Ripeti\ correzione<Tab>:spellrepall -menut Set\ language\ to\ "en" Imposta\ lingua\ a\ "en" -menut Set\ language\ to\ "en_au" Imposta\ lingua\ a\ "en_au" -menut Set\ language\ to\ "en_ca" Imposta\ lingua\ a\ "en_ca" -menut Set\ language\ to\ "en_gb" Imposta\ lingua\ a\ "en_gb" -menut Set\ language\ to\ "en_nz" Imposta\ lingua\ a\ "en_nz" -menut Set\ language\ to\ "en_us" Imposta\ lingua\ a\ "en_us" -menut Set\ language\ to\ "it" Imposta\ lingua\ a\ "it" -menut Set\ language\ to\ "it_it" Imposta\ lingua\ a\ "it_it" -menut Set\ language\ to\ "it_ch" Imposta\ lingua\ a\ "it_ch" -menut &Find\ More\ Languages &Trova\ altre\ lingue - -" Menu piegature / Fold -if has("folding") - menut &Folding &Piegature - " apri e chiudi piegature - menut &Enable/Disable\ folds<Tab>zi Pi&egature\ Sì/No<Tab>zi - menut &View\ Cursor\ Line<Tab>zv &Vedi\ linea\ col\ Cursore<Tab>zv - menut Vie&w\ Cursor\ Line\ only<Tab>zMzx Vedi\ &solo\ linea\ col\ Cursore<Tab>zMzx - menut C&lose\ more\ folds<Tab>zm C&hiudi\ più\ Piegature<Tab>zm - menut &Close\ all\ folds<Tab>zM &Chiudi\ tutte\ le\ Piegature<Tab>zM - menut O&pen\ more\ folds<Tab>zr A&pri\ più\ Piegature<Tab>zr - menut &Open\ all\ folds<Tab>zR &Apri\ tutte\ le\ Piegature<Tab>zR - " metodo piegatura - menut Fold\ Met&hod Meto&do\ Piegatura - menut M&anual &Manuale - menut I&ndent &Nidificazione - menut E&xpression &Espressione\ Reg\. - menut S&yntax &Sintassi - menut &Diff &Differenza - menut Ma&rker Mar&catura - " crea e cancella piegature - menut Create\ &Fold<Tab>zf Crea\ &Piegatura<Tab>zf - menut &Delete\ Fold<Tab>zd &Leva\ Piegatura<Tab>zd - menut Delete\ &All\ Folds<Tab>zD Leva\ &tutte\ le\ Piegature<Tab>zD - " movimenti all'interno delle piegature - menut Fold\ col&umn\ width Larghezza\ piegat&ure\ in\ colonne -endif " has folding - -if has("diff") - menut &Diff &Differenza - " - menut &Update &Aggiorna - menut &Get\ Block &Importa\ Differenze - menut &Put\ Block &Esporta\ Differenze -endif " has diff - -menut &Make<Tab>:make Esegui\ &Make<Tab>:make - -menut &List\ Errors<Tab>:cl Lista\ &Errori<Tab>:cl -menut L&ist\ Messages<Tab>:cl! Lista\ &Messaggi<Tab>:cl! -menut &Next\ Error<Tab>:cn Errore\ S&uccessivo<Tab>:cn -menut &Previous\ Error<Tab>:cp Errore\ &Precedente<Tab>:cp -menut &Older\ List<Tab>:cold Lista\ men&o\ recente<Tab>:cold -menut N&ewer\ List<Tab>:cnew Lista\ più\ rece&nte<Tab>:cnew - -menut Error\ &Window &Finestra\ errori - -menut &Update<Tab>:cwin A&ggiorna<Tab>:cwin -menut &Open<Tab>:copen &Apri<Tab>:copen -menut &Close<Tab>:cclose &Chiudi<Tab>:cclose - -menut &Convert\ to\ HEX<Tab>:%!xxd &Converti\ a\ Esadecimale<Tab>:%!xxd -menut Conve&rt\ back<Tab>:%!xxd\ -r Conve&rti\ da\ Esadecimale<Tab>:%!xxd\ -r - -menut &SeT\ Compiler Impo&sta\ Compilatore - -" Buffers / Buffer -menut &Buffers &Buffer - -menut &Refresh\ menu A&ggiorna\ menu -menut &Delete &Elimina -menut &Alternate &Alternato -menut &Next &Successivo -menut &Previous &Precedente -menut [No\ File] [Nessun\ File] -" Syntax / Sintassi -menut &Syntax &Sintassi -menut &Show\ filetypes\ in\ menu Mo&stra\ tipi\ di\ file\ nel\ menu -menut Set\ '&syntax'\ only Attiva\ solo\ \ '&syntax' -menut Set\ '&filetype'\ too Attiva\ anche\ '&filetype' -menut &Off &Disattiva -menut &Manual &Manuale -menut A&utomatic A&utomatico -menut on/off\ for\ &This\ file Attiva\ Sì/No\ su\ ques&to\ file -menut Co&lor\ test Test\ &Colori -menut &Highlight\ test Test\ &Evidenziamento -menut &Convert\ to\ HTML Converti\ ad\ &HTML - -let g:menutrans_no_file = "[Senza nome]" - -" Window / Finestra -menut &Window &Finestra - -menut &New<Tab>^Wn &Nuova<Tab>^Wn -menut S&plit<Tab>^Ws &Dividi\ lo\ schermo<Tab>^Ws -menut Sp&lit\ To\ #<Tab>^W^^ D&ividi\ verso\ #<Tab>^W^^ -menut Split\ &Vertically<Tab>^Wv Di&vidi\ verticalmente<Tab>^Wv -menut Split\ File\ E&xplorer Aggiungi\ finestra\ E&xplorer - -menut &Close<Tab>^Wc &Chiudi<Tab>^Wc -menut Close\ &Other(s)<Tab>^Wo C&hiudi\ altra(e)<Tab>^Wo - -menut Move\ &To &Muovi\ verso - -menut &Top<Tab>^WK &Cima<Tab>^WK -menut &Bottom<Tab>^WJ &Fondo<Tab>^WJ -menut &Left\ side<Tab>^WH Lato\ &Sinistro<Tab>^WH -menut &Right\ side<Tab>^WL Lato\ &Destro<Tab>^WL -menut Rotate\ &Up<Tab>^WR Ruota\ verso\ l'&alto<Tab>^WR -menut Rotate\ &Down<Tab>^Wr Ruota\ verso\ il\ &basso<Tab>^Wr - -menut &Equal\ Size<Tab>^W= &Uguale\ ampiezza<Tab>^W= -menut &Max\ Height<Tab>^W_ &Altezza\ massima<Tab>^W_ -menut M&in\ Height<Tab>^W1_ A<ezza\ minima<Tab>^W1_ -menut Max\ &Width<Tab>^W\| Larghezza\ massima<Tab>^W\| -menut Min\ Widt&h<Tab>^W1\| Larghezza\ minima<Tab>^W1\| - -" The popup menu -menut &Undo &Annulla -menut Cu&t &Taglia -menut &Copy &Copia -menut &Paste &Incolla -menut &Delete &Elimina - -menut Select\ Blockwise Seleziona\ in\ blocco -menut Select\ &Word Seleziona\ &Parola -menut Select\ &Line Seleziona\ &Linea -menut Select\ &Block Seleziona\ &Blocco -menut Select\ &All Seleziona\ T&utto - -" The GUI Toolbar / Barra Strumenti -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open Apri - tmenu ToolBar.Save Salva - tmenu ToolBar.SaveAll Salva Tutto - tmenu ToolBar.Print Stampa - tmenu ToolBar.Undo Annulla - tmenu ToolBar.Redo Ripristina - tmenu ToolBar.Cut Taglia - tmenu ToolBar.Copy Copia - tmenu ToolBar.Paste Incolla - - if !has("gui_athena") - tmenu ToolBar.Find Cerca - tmenu ToolBar.FindNext Cerca Successivo - tmenu ToolBar.FindPrev Cerca Precedente - tmenu ToolBar.Replace Sostituisci - endif - -if 0 " disabled; These are in the Windows menu - tmenu ToolBar.New Nuova finestra - tmenu ToolBar.WinSplit Dividi finestra - tmenu ToolBar.WinMax Massima ampiezza - tmenu ToolBar.WinMin Minima ampiezza - tmenu ToolBar.WinVSplit Dividi verticalmente - tmenu ToolBar.WinMaxWidth Massima larghezza - tmenu ToolBar.WinMinWidth Minima larghezza - tmenu ToolBar.WinClose Chiudi finestra -endif - - tmenu ToolBar.LoadSesn Carica Sessione - tmenu ToolBar.SaveSesn Salva Sessione - tmenu ToolBar.RunScript Esegui Script - tmenu ToolBar.Make Make - tmenu ToolBar.Shell Shell - tmenu ToolBar.RunCtags Esegui Ctags - tmenu ToolBar.TagJump Vai a Tag - tmenu ToolBar.Help Aiuto - tmenu ToolBar.FindHelp Cerca in Aiuto - endfun -endif - -" vim: set sw=2 : diff --git a/share/vim/vim72/lang/menu_ja_jp.euc-jp.vim b/share/vim/vim72/lang/menu_ja_jp.euc-jp.vim deleted file mode 100644 index ee9f0e50e0..0000000000 --- a/share/vim/vim72/lang/menu_ja_jp.euc-jp.vim +++ /dev/null @@ -1,338 +0,0 @@ -" vi:set ts=8 sts=8 sw=8 tw=0: -" -" Menu Translations: Japanese (EUC-JP) -" Translated By: MURAOKA Taro <koron@tka.att.ne.jp> -" Last Change: 18-Apr-2006. - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 - -scriptencoding euc-jp - -" Help menu -menutrans &Help ¥Ø¥ë¥×(&H) -menutrans &Overview<Tab><F1> ³µÎ¬(&O)<Tab><F1> -menutrans &User\ Manual ¥æ¡¼¥¶¥Þ¥Ë¥å¥¢¥ë(&U) -menutrans &How-to\ links &How-to¥ê¥ó¥¯ -menutrans &Credits ¥¯¥ì¥¸¥Ã¥È(&C) -menutrans Co&pying Ãøºî¸¢¾ðÊó(&P) -menutrans &Sponsor/Register ¥¹¥Ý¥ó¥µ¡¼/ÅÐÏ¿(&S) -menutrans O&rphans ¸É»ù(&R) -menutrans &Version ¥Ð¡¼¥¸¥ç¥ó¾ðÊó(&V) -menutrans &About Vim¤Ë¤Ä¤¤¤Æ(&A) - -let g:menutrans_help_dialog = "¥Ø¥ë¥×¤ò¸¡º÷¤·¤¿¤¤¥³¥Þ¥ó¥É¤â¤·¤¯¤Ïñ¸ì¤òÆþÎϤ·¤Æ¤¯¤À¤µ¤¤:\n\nÁÞÆþ¥â¡¼¥É¤Î¥³¥Þ¥ó¥É¤Ë¤Ï i_ ¤òÀèƬ¤ËÉղä·¤Þ¤¹. (Îã: i_CTRL-X)\n¥³¥Þ¥ó¥É¥é¥¤¥óÊÔ½¸¥³¥Þ¥ó¥É¤Ë¤Ï c_ ¤òÀèƬ¤ËÉղä·¤Þ¤¹. (Îã: c_<Del>)\n¥ª¥×¥·¥ç¥ó¤Î̾Á°¤Ë¤Ï ' ¤òÉղä·¤Þ¤¹. (Îã: 'shiftwidth')" - -" File menu -menutrans &File ¥Õ¥¡¥¤¥ë(&F) -menutrans &Open\.\.\.<Tab>:e ³«¤¯(&O)\.\.\.<Tab>:e -menutrans Sp&lit-Open\.\.\.<Tab>:sp ʬ³ä¤·¤Æ³«¤¯(&L)\.\.\.<Tab>:sp -menutrans Open\ Tab\.\.\.<Tab>:tabnew ¥¿¥Ö¥Ú¡¼¥¸¤Ç³«¤¯<Tab>:tabnew -menutrans &New<Tab>:enew ¿·µ¬ºîÀ®(&N)<Tab>:enew -menutrans &Close<Tab>:close ÊĤ¸¤ë(&C)<Tab>:close -menutrans &Save<Tab>:w Êݸ(&S)<Tab>:w -menutrans Save\ &As\.\.\.<Tab>:sav ̾Á°¤òÉÕ¤±¤ÆÊݸ(&A)\.\.\.<Tab>:sav -menutrans Split\ &Diff\ with\.\.\. º¹Ê¬É½¼¨(&D)\.\.\. -menutrans Split\ Patched\ &By\.\.\. ¥Ñ¥Ã¥Á·ë²Ì¤òɽ¼¨(&B)\.\.\. -menutrans &Print °õºþ(&P) -menutrans Sa&ve-Exit<Tab>:wqa Êݸ¤·¤Æ½ªÎ»(&V)<Tab>:wqa -menutrans E&xit<Tab>:qa ½ªÎ»(&X)<Tab>:qa - -" Edit menu -menutrans &Edit ÊÔ½¸(&E) -menutrans &Undo<Tab>u ¼è¤ê¾Ã¤¹(&U)<Tab>u -menutrans &Redo<Tab>^R ¤â¤¦°ìÅÙ¤ä¤ë(&R)<Tab>^R -menutrans Rep&eat<Tab>\. ·«¤êÊÖ¤¹(&E)<Tab>\. -menutrans Cu&t<Tab>"+x ÀÚ¤ê¼è¤ê(&T)<Tab>"+x -menutrans &Copy<Tab>"+y ¥³¥Ô¡¼(&C)<Tab>"+y -menutrans &Paste<Tab>"+gP Ž¤êÉÕ¤±(&P)<Tab>"+gP -menutrans Put\ &Before<Tab>[p Á°¤ËŽ¤ë(&B)<Tab>[p -menutrans Put\ &After<Tab>]p ¸å¤ËŽ¤ë(&A)<Tab>]p -menutrans &Delete<Tab>x ¾Ã¤¹(&D)<Tab>x -menutrans &Select\ All<Tab>ggVG Á´¤ÆÁªÂò(&S)<Tab>ggVG -menutrans &Find\.\.\. ¸¡º÷(&F)\.\.\. -menutrans &Find<Tab>/ ¸¡º÷(&F)<Tab>/ -menutrans Find\ and\ Rep&lace\.\.\. ÃÖ´¹(&L)\.\.\. -menutrans Find\ and\ Rep&lace<Tab>:%s ÃÖ´¹(&L)<Tab>:%s -menutrans Find\ and\ Rep&lace<Tab>:s ÃÖ´¹(&L)<Tab>:s -"menutrans Options\.\.\. ¥ª¥×¥·¥ç¥ó(&O)\.\.\. -menutrans Settings\ &Window ÀßÄꥦ¥£¥ó¥É¥¦(&W) -menutrans Startup\ &Settings µ¯Æ°»þ¤ÎÀßÄê(&S) - -" Edit/Global Settings -menutrans &Global\ Settings Á´ÂÎÀßÄê(&G) -menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! - \ ¥Ñ¥¿¡¼¥ó¶¯Ä´ÀÚÂØ(&H)<Tab>:set\ hls! -menutrans Toggle\ &Ignore-case<Tab>:set\ ic! - \ Â羮ʸ»ú¶èÊÌÀÚÂØ(&I)<Tab>:set\ ic! -menutrans Toggle\ &Showmatch<Tab>:set\ sm! - \ ¥Þ¥Ã¥Áɽ¼¨ÀÚÂØ(&S)<Tab>:set\ sm! -menutrans &Context\ lines ¥«¡¼¥½¥ë¼þÊÕ¹Ô¿ô(&C) -menutrans &Virtual\ Edit ²¾ÁÛÊÔ½¸(&V) -menutrans Never ̵¸ú -menutrans Block\ Selection ¥Ö¥í¥Ã¥¯ÁªÂò»þ -menutrans Insert\ mode ÁÞÆþ¥â¡¼¥É»þ -menutrans Block\ and\ Insert ¥Ö¥í¥Ã¥¯/ÁÞÆþ¥â¡¼¥É»þ -menutrans Always ¾ï»þ -menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! - \ ÁÞÆþ(½é¿´¼Ô)¥â¡¼¥ÉÀÚÂØ(&M)<Tab>:set\ im! -menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! - \ Vi¸ß´¹¥â¡¼¥ÉÀÚÂØ(&O)<Tab>:set\ cp! -menutrans Search\ &Path\.\.\. ¸¡º÷¥Ñ¥¹(&P)\.\.\. -menutrans Ta&g\ Files\.\.\. ¥¿¥°¥Õ¥¡¥¤¥ë(&G)\.\.\. -" -" GUI options -menutrans Toggle\ &Toolbar ¥Ä¡¼¥ë¥Ð¡¼É½¼¨ÀÚÂØ(&T) -menutrans Toggle\ &Bottom\ Scrollbar ¥¹¥¯¥í¡¼¥ë¥Ð¡¼(²¼)ɽ¼¨ÀÚÂØ(&B) -menutrans Toggle\ &Left\ Scrollbar ¥¹¥¯¥í¡¼¥ë¥Ð¡¼(º¸)ɽ¼¨ÀÚÂØ(&L) -menutrans Toggle\ &Right\ Scrollbar ¥¹¥¯¥í¡¼¥ë¥Ð¡¼(±¦)ɽ¼¨ÀÚÂØ(&R) - -let g:menutrans_path_dialog = "¥Õ¥¡¥¤¥ë¤Î¸¡º÷¥Ñ¥¹¤òÆþÎϤ·¤Æ¤¯¤À¤µ¤¤:\n¥Ç¥£¥ì¥¯¥È¥ê̾¤Ï¥«¥ó¥Þ ( , ) ¤Ç¶èÀڤäƤ¯¤À¤µ¤¤." -let g:menutrans_tags_dialog = "¥¿¥°¥Õ¥¡¥¤¥ë¤Î̾Á°¤òÆþÎϤ·¤Æ¤¯¤À¤µ¤¤:\n̾Á°¤Ï¥«¥ó¥Þ ( , ) ¤Ç¶èÀڤäƤ¯¤À¤µ¤¤." - -" Edit/File Settings - -" Boolean options -menutrans F&ile\ Settings ¥Õ¥¡¥¤¥ëÀßÄê(&I) -menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! - \ ¹ÔÈÖ¹æɽ¼¨ÀÚÂØ(&N)<Tab>:set\ nu! -menutrans Toggle\ &List\ Mode<Tab>:set\ list! - \ ¥ê¥¹¥È¥â¡¼¥ÉÀÚÂØ(&L)<Tab>:set\ list! -menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! - \ ¹ÔÀÞÊÖ¤·ÀÚÂØ(&W)<Tab>:set\ wrap! -menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! - \ ñ¸ìÀÞÊÖ¤·ÀÚÂØ(&R)<Tab>:set\ lbr! -menutrans Toggle\ &expand-tab<Tab>:set\ et! - \ ¥¿¥ÖŸ³«ÀÚÂØ(&E)<Tab>:set\ et! -menutrans Toggle\ &auto-indent<Tab>:set\ ai! - \ ¼«Æ°»ú²¼¤²ÀÚÂØ(&A)<Tab>:set\ ai! -menutrans Toggle\ &C-indenting<Tab>:set\ cin! - \ C¸À¸ì»ú²¼¤²ÀÚÂØ(&C)<Tab>:set\ cin! - -" other options -menutrans &Shiftwidth ¥·¥Õ¥ÈÉý(&S) -menutrans Soft\ &Tabstop ¥½¥Õ¥È¥¦¥§¥¢¥¿¥ÖÉý(&T) -menutrans Te&xt\ Width\.\.\. ¥Æ¥­¥¹¥ÈÉý(&X)\.\.\. -menutrans &File\ Format\.\.\. ²þ¹Ôµ­¹æÁªÂò(&F)\.\.\. - -let g:menutrans_textwidth_dialog = "¥Æ¥­¥¹¥È¤ÎÉý('textwidth')¤òÀßÄꤷ¤Æ¤¯¤À¤µ¤¤ (0¤ÇÀ°·Á¤ò̵¸ú²½):" -let g:menutrans_fileformat_dialog = "¥Õ¥¡¥¤¥ë½ÐÎϤκݤβþ¹Ôµ­¹æ¤Î·Á¼°¤òÁª¤ó¤Ç¤¯¤À¤µ¤¤." -let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\n¥­¥ã¥ó¥»¥ë(&C)" - -menutrans C&olor\ Scheme ¿§¥Æ¡¼¥ÞÁªÂò(&O) -menutrans &Keymap ¥­¡¼¥Þ¥Ã¥×(&K) -menutrans None ¤Ê¤· - -" Programming menu -menutrans &Tools ¥Ä¡¼¥ë(&T) -menutrans &Jump\ to\ this\ tag<Tab>g^] ¥¿¥°¥¸¥ã¥ó¥×(&J)<Tab>g^] -menutrans Jump\ &back<Tab>^T Ìá¤ë(&B)<Tab>^T -menutrans Build\ &Tags\ File ¥¿¥°¥Õ¥¡¥¤¥ëºîÀ®(&T) -menutrans &Make<Tab>:make ¥á¥¤¥¯(&M)<Tab>:make -menutrans &List\ Errors<Tab>:cl ¥¨¥é¡¼¥ê¥¹¥È(&L)<Tab>:cl -menutrans L&ist\ Messages<Tab>:cl! ¥á¥Ã¥»¡¼¥¸¥ê¥¹¥È(&I)<Tab>:cl! -menutrans &Next\ Error<Tab>:cn ¼¡¤Î¥¨¥é¡¼¤Ø(&N)<Tab>:cn -menutrans &Previous\ Error<Tab>:cp Á°¤Î¥¨¥é¡¼¤Ø(&P)<Tab>:cp -menutrans &Older\ List<Tab>:cold ¸Å¤¤¥ê¥¹¥È(&O)<Tab>:cold -menutrans N&ewer\ List<Tab>:cnew ¿·¤·¤¤¥ê¥¹¥È(&E)<Tab>:cnew -menutrans Error\ &Window ¥¨¥é¡¼¥¦¥£¥ó¥É¥¦(&W) -menutrans &Update<Tab>:cwin ¹¹¿·(&U)<Tab>:cwin -menutrans &Open<Tab>:copen ³«¤¯(&O)<Tab>:copen -menutrans &Close<Tab>:cclose ÊĤ¸¤ë(&C)<Tab>:cclose -menutrans &Convert\ to\ HEX<Tab>:%!xxd HEX¤ØÊÑ´¹(&C)<Tab>:%!xxd -menutrans Conve&rt\ back<Tab>:%!xxd\ -r HEX¤«¤éµÕÊÑ´¹(&R)<Tab>%!xxd\ -r -menutrans Se&T\ Compiler ¥³¥ó¥Ñ¥¤¥éÀßÄê(&T) - -" Tools.Spelling Menu -menutrans &Spelling ¥¹¥Ú¥ê¥ó¥°(&S) -menutrans &Spell\ Check\ On ¥¹¥Ú¥ë¥Á¥§¥Ã¥¯Í­¸ú(&S) -menutrans Spell\ Check\ &Off ¥¹¥Ú¥ë¥Á¥§¥Ã¥¯Í­¸ú(&O) -menutrans To\ &Next\ error<Tab>]s ¼¡¤Î¥¨¥é¡¼(&N)<Tab>]s -menutrans To\ &Previous\ error<Tab>[s Á°¤Î¥¨¥é¡¼(&P)<Tab>[s -menutrans Suggest\ &Corrections<Tab>z= ½¤Àµ¸õÊä(&C)<Tab>z= -menutrans &Repeat\ correction<Tab>:spellrepall ½¤Àµ¤ò·«¤êÊÖ¤¹(&R)<Tab>:spellrepall -menutrans Set\ language\ to\ "en" ¸À¸ì¤ò\ "en"\ ¤ËÀßÄꤹ¤ë -menutrans Set\ language\ to\ "en_au" ¸À¸ì¤ò\ "en_au"\ ¤ËÀßÄꤹ¤ë -menutrans Set\ language\ to\ "en_ca" ¸À¸ì¤ò\ "en_ca"\ ¤ËÀßÄꤹ¤ë -menutrans Set\ language\ to\ "en_gb" ¸À¸ì¤ò\ "en_gb"\ ¤ËÀßÄꤹ¤ë -menutrans Set\ language\ to\ "en_nz" ¸À¸ì¤ò\ "en_nz"\ ¤ËÀßÄꤹ¤ë -menutrans Set\ language\ to\ "en_us" ¸À¸ì¤ò\ "en_us"\ ¤ËÀßÄꤹ¤ë -menutrans &Find\ More\ Languages ¾¤Î¸À¸ì¤ò¸¡º÷¤¹¤ë(&F) - -" Tools.Fold Menu -menutrans &Folding ÀÞ¾ö¤ß(&F) -" open close folds -menutrans &Enable/Disable\ folds<Tab>zi Í­¸ú/̵¸úÀÚÂØ(&E)<Tab>zi -menutrans &View\ Cursor\ Line<Tab>zv ¥«¡¼¥½¥ë¹Ô¤òɽ¼¨(&V)<Tab>zv -menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx ¥«¡¼¥½¥ë¹Ô¤À¤±¤òɽ¼¨(&W)<Tab>zMzx -menutrans C&lose\ more\ folds<Tab>zm ÀÞ¾ö¤ß¤òÊĤ¸¤ë(&L)<Tab>zm -menutrans &Close\ all\ folds<Tab>zM Á´ÀÞ¾ö¤ß¤òÊĤ¸¤ë(&C)<Tab>zM -menutrans O&pen\ more\ folds<Tab>zr ÀÞ¾ö¤ß¤ò³«¤¯(&P)<Tab>zr -menutrans &Open\ all\ folds<Tab>zR Á´ÀÞ¾ö¤ß¤ò³«¤¯(&O)<Tab>zR -" fold method -menutrans Fold\ Met&hod ÀÞ¾ö¤ßÊýË¡(&H) -menutrans M&anual ¼êÆ°(&A) -menutrans I&ndent ¥¤¥ó¥Ç¥ó¥È(&N) -menutrans E&xpression ¼°É¾²Á(&X) -menutrans S&yntax ¥·¥ó¥¿¥Ã¥¯¥¹(&Y) -menutrans &Diff º¹Ê¬(&D) -menutrans Ma&rker ¥Þ¡¼¥«¡¼(&R) -" create and delete folds -menutrans Create\ &Fold<Tab>zf ÀÞ¾ö¤ßºîÀ®(&F)<Tab>zf -menutrans &Delete\ Fold<Tab>zd ÀÞ¾ö¤ßºï½ü(&D)<Tab>zd -menutrans Delete\ &All\ Folds<Tab>zD Á´ÀÞ¾ö¤ßºï½ü(&A)<Tab>zD -" moving around in folds -menutrans Fold\ col&umn\ width ÀÞ¾ö¤ß¥«¥é¥àÉý(&U) - -menutrans &Update ¹¹¿·(&U) -menutrans &Get\ Block ¥Ö¥í¥Ã¥¯Ãê½Ð(&G) -menutrans &Put\ Block ¥Ö¥í¥Ã¥¯Å¬ÍÑ(&P) - -" Names for buffer menu. -menutrans &Buffers ¥Ð¥Ã¥Õ¥¡(&B) -menutrans &Refresh\ menu ¥á¥Ë¥å¡¼ºÆÆɹþ(&R) -menutrans &Delete ºï½ü(&D) -menutrans &Alternate ΢¤ØÀÚÂØ(&A) -menutrans &Next ¼¡¤Î¥Ð¥Ã¥Õ¥¡(&N) -menutrans &Previous Á°¤Î¥Ð¥Ã¥Õ¥¡(&P) -menutrans [No\ File] [̵Âê] -let g:menutrans_no_file = "[̵Âê]" - -" Window menu -menutrans &Window ¥¦¥£¥ó¥É¥¦(&W) -menutrans &New<Tab>^Wn ¿·µ¬ºîÀ®(&N)<Tab>^Wn -menutrans S&plit<Tab>^Ws ʬ³ä(&P)<Tab>^Ws -menutrans Sp&lit\ To\ #<Tab>^W^^ ΢¥Ð¥Ã¥Õ¥¡¤Øʬ³ä(&L)<Tab>^W^^ -menutrans Split\ &Vertically<Tab>^Wv ¿âľʬ³ä(&V)<Tab>^Wv -menutrans Split\ File\ E&xplorer ¥Õ¥¡¥¤¥ë¥¨¥¯¥¹¥×¥í¡¼¥é(&X) -menutrans &Close<Tab>^Wc ÊĤ¸¤ë(&C)<Tab>^Wc -menutrans Move\ &To °ÜÆ°(&T) -menutrans &Top<Tab>^WK ¾å(&T)<Tab>^WK -menutrans &Bottom<Tab>^WJ ²¼(&B)<Tab>^WJ -menutrans &Left\ side<Tab>^WH º¸(&L)<Tab>^WH -menutrans &Right\ side<Tab>^WL ±¦(&R)<Tab>^WL -menutrans Close\ &Other(s)<Tab>^Wo ¾¤òÊĤ¸¤ë(&O)<Tab>^Wo -menutrans Ne&xt<Tab>^Ww ¼¡¤Ø(&X)<Tab>^Ww -menutrans P&revious<Tab>^WW Á°¤Ø(&R)<Tab>^WW -menutrans &Equal\ Size<Tab>^W= Ʊ¤¸¹â¤µ¤Ë(&E)<Tab>^W= -menutrans &Max\ Height<Tab>^W_ ºÇÂç¹â¤Ë(&M)<Tab>^W_ -menutrans M&in\ Height<Tab>^W1_ ºÇ¾®¹â¤Ë(&i)<Tab>^W1_ -menutrans Max\ &Width<Tab>^W\| ºÇÂçÉý¤Ë(&W)<Tab>^W\| -menutrans Min\ Widt&h<Tab>^W1\| ºÇ¾®Éý¤Ë(&H)<Tab>^W1\| -menutrans Rotate\ &Up<Tab>^WR ¾å¤Ë¥í¡¼¥Æ¡¼¥·¥ç¥ó(&U)<Tab>^WR -menutrans Rotate\ &Down<Tab>^Wr ²¼¤Ë¥í¡¼¥Æ¡¼¥·¥ç¥ó(&D)<Tab>^Wr -menutrans Select\ Fo&nt\.\.\. ¥Õ¥©¥ó¥ÈÀßÄê(&N)\.\.\. - -" The popup menu -menutrans &Undo ¼è¤ê¾Ã¤¹(&U) -menutrans Cu&t ÀÚ¤ê¼è¤ê(&T) -menutrans &Copy ¥³¥Ô¡¼(&C) -menutrans &Paste Ž¤êÉÕ¤±(&P) -menutrans &Delete ºï½ü(&D) -menutrans Select\ Blockwise ¶ë·Á¥Ö¥í¥Ã¥¯ÁªÂò -menutrans Select\ &Word ñ¸ìÁªÂò(&W) -menutrans Select\ &Line ¹ÔÁªÂò(&L) -menutrans Select\ &Block ¥Ö¥í¥Ã¥¯ÁªÂò(&B) -menutrans Select\ &All ¤¹¤Ù¤ÆÁªÂò(&A) - -" The GUI toolbar (for Win32 or GTK) -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open ¥Õ¥¡¥¤¥ë¤ò³«¤¯ - tmenu ToolBar.Save ¸½ºß¤Î¥Õ¥¡¥¤¥ë¤òÊݸ - tmenu ToolBar.SaveAll ¤¹¤Ù¤Æ¤Î¥Õ¥¡¥¤¥ë¤òÊݸ - tmenu ToolBar.Print °õºþ - tmenu ToolBar.Undo ¼è¤ê¾Ã¤· - tmenu ToolBar.Redo ¤â¤¦°ìÅÙ¤ä¤ë - tmenu ToolBar.Cut ¥¯¥ê¥Ã¥×¥Ü¡¼¥É¤ØÀÚ¤ê¼è¤ê - tmenu ToolBar.Copy ¥¯¥ê¥Ã¥×¥Ü¡¼¥É¤Ø¥³¥Ô¡¼ - tmenu ToolBar.Paste ¥¯¥ê¥Ã¥×¥Ü¡¼¥É¤«¤éŽ¤êÉÕ¤± - tmenu ToolBar.Find ¸¡º÷... - tmenu ToolBar.FindNext ¼¡¤ò¸¡º÷ - tmenu ToolBar.FindPrev Á°¤ò¸¡º÷ - tmenu ToolBar.Replace ÃÖ´¹... - if 0 " disabled; These are in the Windows menu - tmenu ToolBar.New ¿·µ¬¥¦¥£¥ó¥É¥¦ºîÀ® - tmenu ToolBar.WinSplit ¥¦¥£¥ó¥É¥¦Ê¬³ä - tmenu ToolBar.WinMax ¥¦¥£¥ó¥É¥¦ºÇÂç²½ - tmenu ToolBar.WinMin ¥¦¥£¥ó¥É¥¦ºÇ¾®²½ - tmenu ToolBar.WinClose ¥¦¥£¥ó¥É¥¦¤òÊĤ¸¤ë - endif - tmenu ToolBar.LoadSesn ¥»¥Ã¥·¥ç¥óÆɹþ - tmenu ToolBar.SaveSesn ¥»¥Ã¥·¥ç¥óÊݸ - tmenu ToolBar.RunScript Vim¥¹¥¯¥ê¥×¥È¼Â¹Ô - tmenu ToolBar.Make ¥×¥í¥¸¥§¥¯¥È¤òMake - tmenu ToolBar.Shell ¥·¥§¥ë¤ò³«¤¯ - tmenu ToolBar.RunCtags tagsºîÀ® - tmenu ToolBar.TagJump ¥¿¥°¥¸¥ã¥ó¥× - tmenu ToolBar.Help Vim¥Ø¥ë¥× - tmenu ToolBar.FindHelp Vim¥Ø¥ë¥×¸¡º÷ - endfun -endif - -" Syntax menu -menutrans &Syntax ¥·¥ó¥¿¥Ã¥¯¥¹(&S) -menutrans &Show\ filetypes\ in\ menu Âбþ·Á¼°¤ò¥á¥Ë¥å¡¼¤Ëɽ¼¨(&S) -menutrans Set\ '&syntax'\ only 'syntax'¤À¤±ÀßÄê(&S) -menutrans Set\ '&filetype'\ too 'filetype'¤âÀßÄê(&F) -menutrans &Off ̵¸ú²½(&O) -menutrans &Manual ¼êÆ°ÀßÄê(&M) -menutrans A&utomatic ¼«Æ°ÀßÄê(&U) -menutrans on/off\ for\ &This\ file - \ ¥ª¥ó/¥ª¥ÕÀÚÂØ(&T) -menutrans Co&lor\ test ¥«¥é¡¼¥Æ¥¹¥È(&L) -menutrans &Highlight\ test ¥Ï¥¤¥é¥¤¥È¥Æ¥¹¥È(&H) -menutrans &Convert\ to\ HTML HTML¤Ø¥³¥ó¥Ð¡¼¥È(&C) - -" Japanese specific menu -" À®ÈݤÏiconv¼¡Â衢ɬ¤º¤·¤â»ØÄꤷ¤¿¥¨¥ó¥³¡¼¥É¤Ë¤Ê¤ë¤ï¤±¤Ç¤Ï¤Ê¤¤¤³¤È¤ËÃí°Õ -if has('iconv') - " iconv¤Î¥Ð¡¼¥¸¥ç¥óȽÄê - let support_jisx0213 = (iconv("\x87\x64\x87\x6a", 'cp932', 'euc-jisx0213') ==# "\xad\xc5\xad\xcb") ? 1 : 0 - " - " Æɤ߹þ¤ß - an 10.395 ¥Õ¥¡¥¤¥ë(&F).-SEPICONV- <Nop> - an 10.396.100.100 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..SJIS(&S)<Tab>fenc=cp932 :browse confirm e ++enc=cp932<CR> - if !support_jisx0213 - an 10.396.100.110 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jp :browse confirm e ++enc=euc-jp<CR> - an 10.396.100.120 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :browse confirm e ++enc=iso-2022-jp<CR> - else - an 10.396.100.110 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :browse confirm e ++enc=euc-jisx0213<CR> - an 10.396.100.120 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :browse confirm e ++enc=iso-2022-jp-3<CR> - endif - an 10.396.100.130 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :browse confirm e ++enc=utf-8<CR> - - " ºÆÆɹþ - an 10.396.110.100 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..SJIS(&S)<Tab>fenc=cp932 :e ++enc=cp932<CR> - if !support_jisx0213 - an 10.396.110.110 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jp :e ++enc=euc-jp<CR> - an 10.396.110.120 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :e ++enc=iso-2022-jp<CR> - else - an 10.396.110.110 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :e ++enc=euc-jisx0213<CR> - an 10.396.110.120 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :e ++enc=iso-2022-jp-3<CR> - endif - an 10.396.110.130 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :e ++enc=utf-8<CR> - - " Êݸ - an 10.396.115 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..-SEP1- <Nop> - an 10.396.120.100 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..SJIS(&S)<Tab>fenc=cp932 :set fenc=cp932 \| w<CR> - if !support_jisx0213 - an 10.396.120.110 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jp :set fenc=euc-jp \| w<CR> - an 10.396.120.120 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :set fenc=iso-2022-jp \| w<CR> - else - an 10.396.120.110 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :set fenc=euc-jisx0213 \| w<CR> - an 10.396.120.120 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :set fenc=iso-2022-jp-3 \| w<CR> - endif - an 10.396.120.130 ¥Õ¥¡¥¤¥ë(&F).¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :set fenc=utf-8 \| w<CR> -endif - -" filler to avoid the line above being recognized as a modeline -" filler -" filler -" filler diff --git a/share/vim/vim72/lang/menu_ja_jp.utf-8.vim b/share/vim/vim72/lang/menu_ja_jp.utf-8.vim deleted file mode 100644 index c36d6a0496..0000000000 --- a/share/vim/vim72/lang/menu_ja_jp.utf-8.vim +++ /dev/null @@ -1,338 +0,0 @@ -" vi:set ts=8 sts=8 sw=8 tw=0: -" -" Menu Translations: Japanese (UTF-8) -" Translated By: MURAOKA Taro <koron@tka.att.ne.jp> -" Last Change: 18-Apr-2006. - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 - -scriptencoding utf-8 - -" Help menu -menutrans &Help ヘルプ(&H) -menutrans &Overview<Tab><F1> 概略(&O)<Tab><F1> -menutrans &User\ Manual ユーザマニュアル(&U) -menutrans &How-to\ links &How-toリンク -menutrans &Credits クレジット(&C) -menutrans Co&pying 著作権情報(&P) -menutrans &Sponsor/Register スポンサー/登録(&S) -menutrans O&rphans 孤児(&R) -menutrans &Version バージョン情報(&V) -menutrans &About Vimについて(&A) - -let g:menutrans_help_dialog = "ヘルプを検索したいコマンドもしくは単語を入力してください:\n\n挿入モードのコマンドには i_ を先頭に付加します. (例: i_CTRL-X)\nコマンドライン編集コマンドには c_ を先頭に付加します. (例: c_<Del>)\nオプションの名前には ' を付加します. (例: 'shiftwidth')" - -" File menu -menutrans &File ファイル(&F) -menutrans &Open\.\.\.<Tab>:e 開く(&O)\.\.\.<Tab>:e -menutrans Sp&lit-Open\.\.\.<Tab>:sp 分割して開く(&L)\.\.\.<Tab>:sp -menutrans Open\ Tab\.\.\.<Tab>:tabnew タブページで開く<Tab>:tabnew -menutrans &New<Tab>:enew 新規作成(&N)<Tab>:enew -menutrans &Close<Tab>:close 閉じる(&C)<Tab>:close -menutrans &Save<Tab>:w 保存(&S)<Tab>:w -menutrans Save\ &As\.\.\.<Tab>:sav 名前を付けて保存(&A)\.\.\.<Tab>:sav -menutrans Split\ &Diff\ with\.\.\. 差分表示(&D)\.\.\. -menutrans Split\ Patched\ &By\.\.\. パッチ結果を表示(&B)\.\.\. -menutrans &Print 印刷(&P) -menutrans Sa&ve-Exit<Tab>:wqa 保存して終了(&V)<Tab>:wqa -menutrans E&xit<Tab>:qa 終了(&X)<Tab>:qa - -" Edit menu -menutrans &Edit 編集(&E) -menutrans &Undo<Tab>u 取り消す(&U)<Tab>u -menutrans &Redo<Tab>^R もう一度やる(&R)<Tab>^R -menutrans Rep&eat<Tab>\. 繰り返す(&E)<Tab>\. -menutrans Cu&t<Tab>"+x 切り取り(&T)<Tab>"+x -menutrans &Copy<Tab>"+y コピー(&C)<Tab>"+y -menutrans &Paste<Tab>"+gP 貼り付け(&P)<Tab>"+gP -menutrans Put\ &Before<Tab>[p 前に貼る(&B)<Tab>[p -menutrans Put\ &After<Tab>]p 後に貼る(&A)<Tab>]p -menutrans &Delete<Tab>x 消す(&D)<Tab>x -menutrans &Select\ All<Tab>ggVG 全て選択(&S)<Tab>ggVG -menutrans &Find\.\.\. 検索(&F)\.\.\. -menutrans &Find<Tab>/ 検索(&F)<Tab>/ -menutrans Find\ and\ Rep&lace\.\.\. 置換(&L)\.\.\. -menutrans Find\ and\ Rep&lace<Tab>:%s 置換(&L)<Tab>:%s -menutrans Find\ and\ Rep&lace<Tab>:s 置換(&L)<Tab>:s -"menutrans Options\.\.\. オプション(&O)\.\.\. -menutrans Settings\ &Window 設定ウィンドウ(&W) -menutrans Startup\ &Settings 起動時の設定(&S) - -" Edit/Global Settings -menutrans &Global\ Settings 全体設定(&G) -menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! - \ パターン強調切替(&H)<Tab>:set\ hls! -menutrans Toggle\ &Ignore-case<Tab>:set\ ic! - \ 大小文字区別切替(&I)<Tab>:set\ ic! -menutrans Toggle\ &Showmatch<Tab>:set\ sm! - \ マッチ表示切替(&S)<Tab>:set\ sm! -menutrans &Context\ lines カーソル周辺行数(&C) -menutrans &Virtual\ Edit 仮想編集(&V) -menutrans Never 無効 -menutrans Block\ Selection ブロック選択時 -menutrans Insert\ mode 挿入モード時 -menutrans Block\ and\ Insert ブロック/挿入モード時 -menutrans Always 常時 -menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! - \ 挿入(初心者)モード切替(&M)<Tab>:set\ im! -menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! - \ Vi互換モード切替(&O)<Tab>:set\ cp! -menutrans Search\ &Path\.\.\. 検索パス(&P)\.\.\. -menutrans Ta&g\ Files\.\.\. タグファイル(&G)\.\.\. -" -" GUI options -menutrans Toggle\ &Toolbar ツールバー表示切替(&T) -menutrans Toggle\ &Bottom\ Scrollbar スクロールバー(下)表示切替(&B) -menutrans Toggle\ &Left\ Scrollbar スクロールバー(左)表示切替(&L) -menutrans Toggle\ &Right\ Scrollbar スクロールバー(右)表示切替(&R) - -let g:menutrans_path_dialog = "ファイルの検索パスを入力してください:\nディレクトリ名はカンマ ( , ) で区切ってください." -let g:menutrans_tags_dialog = "タグファイルの名前を入力してください:\n名前はカンマ ( , ) で区切ってください." - -" Edit/File Settings - -" Boolean options -menutrans F&ile\ Settings ファイル設定(&I) -menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! - \ 行番号表示切替(&N)<Tab>:set\ nu! -menutrans Toggle\ &List\ Mode<Tab>:set\ list! - \ リストモード切替(&L)<Tab>:set\ list! -menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! - \ 行折返し切替(&W)<Tab>:set\ wrap! -menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! - \ 単語折返し切替(&R)<Tab>:set\ lbr! -menutrans Toggle\ &expand-tab<Tab>:set\ et! - \ タブ展開切替(&E)<Tab>:set\ et! -menutrans Toggle\ &auto-indent<Tab>:set\ ai! - \ 自動字下げ切替(&A)<Tab>:set\ ai! -menutrans Toggle\ &C-indenting<Tab>:set\ cin! - \ C言語字下げ切替(&C)<Tab>:set\ cin! - -" other options -menutrans &Shiftwidth シフト幅(&S) -menutrans Soft\ &Tabstop ソフトウェアタブ幅(&T) -menutrans Te&xt\ Width\.\.\. テキスト幅(&X)\.\.\. -menutrans &File\ Format\.\.\. 改行記号選択(&F)\.\.\. - -let g:menutrans_textwidth_dialog = "テキストの幅('textwidth')を設定してください (0で整形を無効化):" -let g:menutrans_fileformat_dialog = "ファイル出力の際の改行記号の形式を選んでください." -let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\nキャンセル(&C)" - -menutrans C&olor\ Scheme 色テーマ選択(&O) -menutrans &Keymap キーマップ(&K) -menutrans None なし - -" Programming menu -menutrans &Tools ツール(&T) -menutrans &Jump\ to\ this\ tag<Tab>g^] タグジャンプ(&J)<Tab>g^] -menutrans Jump\ &back<Tab>^T 戻る(&B)<Tab>^T -menutrans Build\ &Tags\ File タグファイル作成(&T) -menutrans &Make<Tab>:make メイク(&M)<Tab>:make -menutrans &List\ Errors<Tab>:cl エラーリスト(&L)<Tab>:cl -menutrans L&ist\ Messages<Tab>:cl! メッセージリスト(&I)<Tab>:cl! -menutrans &Next\ Error<Tab>:cn 次のエラーへ(&N)<Tab>:cn -menutrans &Previous\ Error<Tab>:cp 前のエラーへ(&P)<Tab>:cp -menutrans &Older\ List<Tab>:cold 古いリスト(&O)<Tab>:cold -menutrans N&ewer\ List<Tab>:cnew 新しいリスト(&E)<Tab>:cnew -menutrans Error\ &Window エラーウィンドウ(&W) -menutrans &Update<Tab>:cwin 更新(&U)<Tab>:cwin -menutrans &Open<Tab>:copen 開く(&O)<Tab>:copen -menutrans &Close<Tab>:cclose 閉じる(&C)<Tab>:cclose -menutrans &Convert\ to\ HEX<Tab>:%!xxd HEXへ変換(&C)<Tab>:%!xxd -menutrans Conve&rt\ back<Tab>:%!xxd\ -r HEXから逆変換(&R)<Tab>%!xxd\ -r -menutrans Se&T\ Compiler コンパイラ設定(&T) - -" Tools.Spelling Menu -menutrans &Spelling スペリング(&S) -menutrans &Spell\ Check\ On スペルチェック有効(&S) -menutrans Spell\ Check\ &Off スペルチェック有効(&O) -menutrans To\ &Next\ error<Tab>]s 次のエラー(&N)<Tab>]s -menutrans To\ &Previous\ error<Tab>[s 前のエラー(&P)<Tab>[s -menutrans Suggest\ &Corrections<Tab>z= 修正候補(&C)<Tab>z= -menutrans &Repeat\ correction<Tab>:spellrepall 修正を繰り返す(&R)<Tab>:spellrepall -menutrans Set\ language\ to\ "en" 言語を\ "en"\ に設定する -menutrans Set\ language\ to\ "en_au" 言語を\ "en_au"\ に設定する -menutrans Set\ language\ to\ "en_ca" 言語を\ "en_ca"\ に設定する -menutrans Set\ language\ to\ "en_gb" 言語を\ "en_gb"\ に設定する -menutrans Set\ language\ to\ "en_nz" 言語を\ "en_nz"\ に設定する -menutrans Set\ language\ to\ "en_us" 言語を\ "en_us"\ に設定する -menutrans &Find\ More\ Languages 他の言語を検索する(&F) - -" Tools.Fold Menu -menutrans &Folding 折畳み(&F) -" open close folds -menutrans &Enable/Disable\ folds<Tab>zi 有効/無効切替(&E)<Tab>zi -menutrans &View\ Cursor\ Line<Tab>zv カーソル行を表示(&V)<Tab>zv -menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx カーソル行だけを表示(&W)<Tab>zMzx -menutrans C&lose\ more\ folds<Tab>zm 折畳みを閉じる(&L)<Tab>zm -menutrans &Close\ all\ folds<Tab>zM 全折畳みを閉じる(&C)<Tab>zM -menutrans O&pen\ more\ folds<Tab>zr 折畳みを開く(&P)<Tab>zr -menutrans &Open\ all\ folds<Tab>zR 全折畳みを開く(&O)<Tab>zR -" fold method -menutrans Fold\ Met&hod 折畳み方法(&H) -menutrans M&anual 手動(&A) -menutrans I&ndent インデント(&N) -menutrans E&xpression 式評価(&X) -menutrans S&yntax シンタックス(&Y) -menutrans &Diff 差分(&D) -menutrans Ma&rker マーカー(&R) -" create and delete folds -menutrans Create\ &Fold<Tab>zf 折畳み作成(&F)<Tab>zf -menutrans &Delete\ Fold<Tab>zd 折畳み削除(&D)<Tab>zd -menutrans Delete\ &All\ Folds<Tab>zD 全折畳み削除(&A)<Tab>zD -" moving around in folds -menutrans Fold\ col&umn\ width 折畳みカラム幅(&U) - -menutrans &Update 更新(&U) -menutrans &Get\ Block ブロック抽出(&G) -menutrans &Put\ Block ブロック適用(&P) - -" Names for buffer menu. -menutrans &Buffers バッファ(&B) -menutrans &Refresh\ menu メニュー再読込(&R) -menutrans &Delete 削除(&D) -menutrans &Alternate 裏へ切替(&A) -menutrans &Next 次のバッファ(&N) -menutrans &Previous 前のバッファ(&P) -menutrans [No\ File] [無題] -let g:menutrans_no_file = "[無題]" - -" Window menu -menutrans &Window ウィンドウ(&W) -menutrans &New<Tab>^Wn 新規作成(&N)<Tab>^Wn -menutrans S&plit<Tab>^Ws 分割(&P)<Tab>^Ws -menutrans Sp&lit\ To\ #<Tab>^W^^ 裏バッファへ分割(&L)<Tab>^W^^ -menutrans Split\ &Vertically<Tab>^Wv 垂直分割(&V)<Tab>^Wv -menutrans Split\ File\ E&xplorer ファイルエクスプローラ(&X) -menutrans &Close<Tab>^Wc 閉じる(&C)<Tab>^Wc -menutrans Move\ &To 移動(&T) -menutrans &Top<Tab>^WK 上(&T)<Tab>^WK -menutrans &Bottom<Tab>^WJ 下(&B)<Tab>^WJ -menutrans &Left\ side<Tab>^WH 左(&L)<Tab>^WH -menutrans &Right\ side<Tab>^WL 右(&R)<Tab>^WL -menutrans Close\ &Other(s)<Tab>^Wo 他を閉じる(&O)<Tab>^Wo -menutrans Ne&xt<Tab>^Ww 次へ(&X)<Tab>^Ww -menutrans P&revious<Tab>^WW 前へ(&R)<Tab>^WW -menutrans &Equal\ Size<Tab>^W= 同じ高さに(&E)<Tab>^W= -menutrans &Max\ Height<Tab>^W_ 最大高に(&M)<Tab>^W_ -menutrans M&in\ Height<Tab>^W1_ 最小高に(&i)<Tab>^W1_ -menutrans Max\ &Width<Tab>^W\| 最大幅に(&W)<Tab>^W\| -menutrans Min\ Widt&h<Tab>^W1\| 最小幅に(&H)<Tab>^W1\| -menutrans Rotate\ &Up<Tab>^WR 上にローテーション(&U)<Tab>^WR -menutrans Rotate\ &Down<Tab>^Wr 下にローテーション(&D)<Tab>^Wr -menutrans Select\ Fo&nt\.\.\. フォント設定(&N)\.\.\. - -" The popup menu -menutrans &Undo 取り消す(&U) -menutrans Cu&t 切り取り(&T) -menutrans &Copy コピー(&C) -menutrans &Paste 貼り付け(&P) -menutrans &Delete 削除(&D) -menutrans Select\ Blockwise 矩形ブロック選択 -menutrans Select\ &Word 単語選択(&W) -menutrans Select\ &Line 行選択(&L) -menutrans Select\ &Block ブロック選択(&B) -menutrans Select\ &All すべて選択(&A) - -" The GUI toolbar (for Win32 or GTK) -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open ファイルを開く - tmenu ToolBar.Save 現在のファイルを保存 - tmenu ToolBar.SaveAll すべてのファイルを保存 - tmenu ToolBar.Print 印刷 - tmenu ToolBar.Undo 取り消し - tmenu ToolBar.Redo もう一度やる - tmenu ToolBar.Cut クリップボードへ切り取り - tmenu ToolBar.Copy クリップボードへコピー - tmenu ToolBar.Paste クリップボードから貼り付け - tmenu ToolBar.Find 検索... - tmenu ToolBar.FindNext 次を検索 - tmenu ToolBar.FindPrev 前を検索 - tmenu ToolBar.Replace 置換... - if 0 " disabled; These are in the Windows menu - tmenu ToolBar.New 新規ウィンドウ作成 - tmenu ToolBar.WinSplit ウィンドウ分割 - tmenu ToolBar.WinMax ウィンドウ最大化 - tmenu ToolBar.WinMin ウィンドウ最小化 - tmenu ToolBar.WinClose ウィンドウを閉じる - endif - tmenu ToolBar.LoadSesn セッション読込 - tmenu ToolBar.SaveSesn セッション保存 - tmenu ToolBar.RunScript Vimスクリプト実行 - tmenu ToolBar.Make プロジェクトをMake - tmenu ToolBar.Shell シェルを開く - tmenu ToolBar.RunCtags tags作成 - tmenu ToolBar.TagJump タグジャンプ - tmenu ToolBar.Help Vimヘルプ - tmenu ToolBar.FindHelp Vimヘルプ検索 - endfun -endif - -" Syntax menu -menutrans &Syntax シンタックス(&S) -menutrans &Show\ filetypes\ in\ menu 対応形式をメニューに表示(&S) -menutrans Set\ '&syntax'\ only 'syntax'だけ設定(&S) -menutrans Set\ '&filetype'\ too 'filetype'も設定(&F) -menutrans &Off 無効化(&O) -menutrans &Manual 手動設定(&M) -menutrans A&utomatic 自動設定(&U) -menutrans on/off\ for\ &This\ file - \ オン/オフ切替(&T) -menutrans Co&lor\ test カラーテスト(&L) -menutrans &Highlight\ test ハイライトテスト(&H) -menutrans &Convert\ to\ HTML HTMLへコンバート(&C) - -" Japanese specific menu -" 成否はiconv次第、必ずしも指定したエンコードになるわけではないことに注意 -if has('iconv') - " iconvのバージョン判定 - let support_jisx0213 = (iconv("\x87\x64\x87\x6a", 'cp932', 'euc-jisx0213') ==# "\xad\xc5\xad\xcb") ? 1 : 0 - " - " 読み込み - an 10.395 ファイル(&F).-SEPICONV- <Nop> - an 10.396.100.100 ファイル(&F).エンコード指定(&E)\.\.\..開く(&O)\.\.\..SJIS(&S)<Tab>fenc=cp932 :browse confirm e ++enc=cp932<CR> - if !support_jisx0213 - an 10.396.100.110 ファイル(&F).エンコード指定(&E)\.\.\..開く(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jp :browse confirm e ++enc=euc-jp<CR> - an 10.396.100.120 ファイル(&F).エンコード指定(&E)\.\.\..開く(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :browse confirm e ++enc=iso-2022-jp<CR> - else - an 10.396.100.110 ファイル(&F).エンコード指定(&E)\.\.\..開く(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :browse confirm e ++enc=euc-jisx0213<CR> - an 10.396.100.120 ファイル(&F).エンコード指定(&E)\.\.\..開く(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :browse confirm e ++enc=iso-2022-jp-3<CR> - endif - an 10.396.100.130 ファイル(&F).エンコード指定(&E)\.\.\..開く(&O)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :browse confirm e ++enc=utf-8<CR> - - " 再読込 - an 10.396.110.100 ファイル(&F).エンコード指定(&E)\.\.\..再読込(&R)\.\.\..SJIS(&S)<Tab>fenc=cp932 :e ++enc=cp932<CR> - if !support_jisx0213 - an 10.396.110.110 ファイル(&F).エンコード指定(&E)\.\.\..再読込(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jp :e ++enc=euc-jp<CR> - an 10.396.110.120 ファイル(&F).エンコード指定(&E)\.\.\..再読込(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :e ++enc=iso-2022-jp<CR> - else - an 10.396.110.110 ファイル(&F).エンコード指定(&E)\.\.\..再読込(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :e ++enc=euc-jisx0213<CR> - an 10.396.110.120 ファイル(&F).エンコード指定(&E)\.\.\..再読込(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :e ++enc=iso-2022-jp-3<CR> - endif - an 10.396.110.130 ファイル(&F).エンコード指定(&E)\.\.\..再読込(&R)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :e ++enc=utf-8<CR> - - " 保存 - an 10.396.115 ファイル(&F).エンコード指定(&E)\.\.\..-SEP1- <Nop> - an 10.396.120.100 ファイル(&F).エンコード指定(&E)\.\.\..保存(&S)\.\.\..SJIS(&S)<Tab>fenc=cp932 :set fenc=cp932 \| w<CR> - if !support_jisx0213 - an 10.396.120.110 ファイル(&F).エンコード指定(&E)\.\.\..保存(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jp :set fenc=euc-jp \| w<CR> - an 10.396.120.120 ファイル(&F).エンコード指定(&E)\.\.\..保存(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :set fenc=iso-2022-jp \| w<CR> - else - an 10.396.120.110 ファイル(&F).エンコード指定(&E)\.\.\..保存(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :set fenc=euc-jisx0213 \| w<CR> - an 10.396.120.120 ファイル(&F).エンコード指定(&E)\.\.\..保存(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :set fenc=iso-2022-jp-3 \| w<CR> - endif - an 10.396.120.130 ファイル(&F).エンコード指定(&E)\.\.\..保存(&S)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :set fenc=utf-8 \| w<CR> -endif - -" filler to avoid the line above being recognized as a modeline -" filler -" filler -" filler diff --git a/share/vim/vim72/lang/menu_japanese_japan.932.vim b/share/vim/vim72/lang/menu_japanese_japan.932.vim deleted file mode 100644 index 5c836becb6..0000000000 --- a/share/vim/vim72/lang/menu_japanese_japan.932.vim +++ /dev/null @@ -1,338 +0,0 @@ -" vi:set ts=8 sts=8 sw=8 tw=0: -" -" Menu Translations: Japanese (CP932) -" Translated By: MURAOKA Taro <koron@tka.att.ne.jp> -" Last Change: 18-Apr-2006. - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 - -scriptencoding cp932 - -" Help menu -menutrans &Help ƒwƒ‹ƒv(&H) -menutrans &Overview<Tab><F1> ŠT—ª(&O)<Tab><F1> -menutrans &User\ Manual ƒ†�[ƒUƒ}ƒjƒ…ƒAƒ‹(&U) -menutrans &How-to\ links &How-toƒŠƒ“ƒN -menutrans &Credits ƒNƒŒƒWƒbƒg(&C) -menutrans Co&pying ’˜�쌠�î•ñ(&P) -menutrans &Sponsor/Register ƒXƒ|ƒ“ƒT�[/“o˜^(&S) -menutrans O&rphans ŒÇŽ™(&R) -menutrans &Version ƒo�[ƒWƒ‡ƒ“�î•ñ(&V) -menutrans &About Vim‚ɂ‚¢‚Ä(&A) - -let g:menutrans_help_dialog = "ƒwƒ‹ƒv‚ðŒŸ�õ‚µ‚½‚¢ƒRƒ}ƒ“ƒh‚à‚µ‚­‚Í’PŒê‚ð“ü—Í‚µ‚Ä‚­‚¾‚³‚¢:\n\n‘}“üƒ‚�[ƒh‚̃Rƒ}ƒ“ƒh‚É‚Í i_ ‚ð�擪‚É•t‰Á‚µ‚Ü‚·. (—á: i_CTRL-X)\nƒRƒ}ƒ“ƒhƒ‰ƒCƒ“•Ò�WƒRƒ}ƒ“ƒh‚É‚Í c_ ‚ð�擪‚É•t‰Á‚µ‚Ü‚·. (—á: c_<Del>)\nƒIƒvƒVƒ‡ƒ“‚Ì–¼‘O‚É‚Í ' ‚ð•t‰Á‚µ‚Ü‚·. (—á: 'shiftwidth')" - -" File menu -menutrans &File ƒtƒ@ƒCƒ‹(&F) -menutrans &Open\.\.\.<Tab>:e ŠJ‚­(&O)\.\.\.<Tab>:e -menutrans Sp&lit-Open\.\.\.<Tab>:sp •ªŠ„‚µ‚ÄŠJ‚­(&L)\.\.\.<Tab>:sp -menutrans Open\ Tab\.\.\.<Tab>:tabnew ƒ^ƒuƒy�[ƒW‚ÅŠJ‚­<Tab>:tabnew -menutrans &New<Tab>:enew �V‹K�ì�¬(&N)<Tab>:enew -menutrans &Close<Tab>:close •Â‚¶‚é(&C)<Tab>:close -menutrans &Save<Tab>:w •Û‘¶(&S)<Tab>:w -menutrans Save\ &As\.\.\.<Tab>:sav –¼‘O‚ð•t‚¯‚Ä•Û‘¶(&A)\.\.\.<Tab>:sav -menutrans Split\ &Diff\ with\.\.\. �·•ª•\Ž¦(&D)\.\.\. -menutrans Split\ Patched\ &By\.\.\. ƒpƒbƒ`Œ‹‰Ê‚ð•\Ž¦(&B)\.\.\. -menutrans &Print ˆó�ü(&P) -menutrans Sa&ve-Exit<Tab>:wqa •Û‘¶‚µ‚Ä�I—¹(&V)<Tab>:wqa -menutrans E&xit<Tab>:qa �I—¹(&X)<Tab>:qa - -" Edit menu -menutrans &Edit •Ò�W(&E) -menutrans &Undo<Tab>u Žæ‚è�Á‚·(&U)<Tab>u -menutrans &Redo<Tab>^R ‚à‚¤ˆê“x‚â‚é(&R)<Tab>^R -menutrans Rep&eat<Tab>\. ŒJ‚è•Ô‚·(&E)<Tab>\. -menutrans Cu&t<Tab>"+x �Ø‚èŽæ‚è(&T)<Tab>"+x -menutrans &Copy<Tab>"+y ƒRƒs�[(&C)<Tab>"+y -menutrans &Paste<Tab>"+gP “\‚è•t‚¯(&P)<Tab>"+gP -menutrans Put\ &Before<Tab>[p ‘O‚É“\‚é(&B)<Tab>[p -menutrans Put\ &After<Tab>]p Œã‚É“\‚é(&A)<Tab>]p -menutrans &Delete<Tab>x �Á‚·(&D)<Tab>x -menutrans &Select\ All<Tab>ggVG ‘S‚Ä‘I‘ð(&S)<Tab>ggVG -menutrans &Find\.\.\. ŒŸ�õ(&F)\.\.\. -menutrans &Find<Tab>/ ŒŸ�õ(&F)<Tab>/ -menutrans Find\ and\ Rep&lace\.\.\. ’uŠ·(&L)\.\.\. -menutrans Find\ and\ Rep&lace<Tab>:%s ’uŠ·(&L)<Tab>:%s -menutrans Find\ and\ Rep&lace<Tab>:s ’uŠ·(&L)<Tab>:s -"menutrans Options\.\.\. ƒIƒvƒVƒ‡ƒ“(&O)\.\.\. -menutrans Settings\ &Window �Ý’èƒEƒBƒ“ƒhƒE(&W) -menutrans Startup\ &Settings ‹N“®Žž‚Ì�Ý’è(&S) - -" Edit/Global Settings -menutrans &Global\ Settings ‘S‘Ì�Ý’è(&G) -menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! - \ ƒpƒ^�[ƒ“‹­’²�Ø‘Ö(&H)<Tab>:set\ hls! -menutrans Toggle\ &Ignore-case<Tab>:set\ ic! - \ ‘å�¬•¶Žš‹æ•Ê�Ø‘Ö(&I)<Tab>:set\ ic! -menutrans Toggle\ &Showmatch<Tab>:set\ sm! - \ ƒ}ƒbƒ`•\Ž¦�Ø‘Ö(&S)<Tab>:set\ sm! -menutrans &Context\ lines ƒJ�[ƒ\ƒ‹Žü•Ó�s�”(&C) -menutrans &Virtual\ Edit ‰¼‘z•Ò�W(&V) -menutrans Never –³Œø -menutrans Block\ Selection ƒuƒ�ƒbƒN‘I‘ðŽž -menutrans Insert\ mode ‘}“üƒ‚�[ƒhŽž -menutrans Block\ and\ Insert ƒuƒ�ƒbƒN/‘}“üƒ‚�[ƒhŽž -menutrans Always �펞 -menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! - \ ‘}“ü(�‰�SŽÒ)ƒ‚�[ƒh�Ø‘Ö(&M)<Tab>:set\ im! -menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! - \ ViŒÝŠ·ƒ‚�[ƒh�Ø‘Ö(&O)<Tab>:set\ cp! -menutrans Search\ &Path\.\.\. ŒŸ�õƒpƒX(&P)\.\.\. -menutrans Ta&g\ Files\.\.\. ƒ^ƒOƒtƒ@ƒCƒ‹(&G)\.\.\. -" -" GUI options -menutrans Toggle\ &Toolbar ƒc�[ƒ‹ƒo�[•\Ž¦�Ø‘Ö(&T) -menutrans Toggle\ &Bottom\ Scrollbar ƒXƒNƒ��[ƒ‹ƒo�[(‰º)•\Ž¦�Ø‘Ö(&B) -menutrans Toggle\ &Left\ Scrollbar ƒXƒNƒ��[ƒ‹ƒo�[(�¶)•\Ž¦�Ø‘Ö(&L) -menutrans Toggle\ &Right\ Scrollbar ƒXƒNƒ��[ƒ‹ƒo�[(‰E)•\Ž¦�Ø‘Ö(&R) - -let g:menutrans_path_dialog = "ƒtƒ@ƒCƒ‹‚ÌŒŸ�õƒpƒX‚ð“ü—Í‚µ‚Ä‚­‚¾‚³‚¢:\nƒfƒBƒŒƒNƒgƒŠ–¼‚̓Jƒ“ƒ} ( , ) ‚Å‹æ�Ø‚Á‚Ä‚­‚¾‚³‚¢." -let g:menutrans_tags_dialog = "ƒ^ƒOƒtƒ@ƒCƒ‹‚Ì–¼‘O‚ð“ü—Í‚µ‚Ä‚­‚¾‚³‚¢:\n–¼‘O‚̓Jƒ“ƒ} ( , ) ‚Å‹æ�Ø‚Á‚Ä‚­‚¾‚³‚¢." - -" Edit/File Settings - -" Boolean options -menutrans F&ile\ Settings ƒtƒ@ƒCƒ‹�Ý’è(&I) -menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! - \ �s”Ô�†•\Ž¦�Ø‘Ö(&N)<Tab>:set\ nu! -menutrans Toggle\ &List\ Mode<Tab>:set\ list! - \ ƒŠƒXƒgƒ‚�[ƒh�Ø‘Ö(&L)<Tab>:set\ list! -menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! - \ �s�Ü•Ô‚µ�Ø‘Ö(&W)<Tab>:set\ wrap! -menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! - \ ’PŒê�Ü•Ô‚µ�Ø‘Ö(&R)<Tab>:set\ lbr! -menutrans Toggle\ &expand-tab<Tab>:set\ et! - \ ƒ^ƒu“WŠJ�Ø‘Ö(&E)<Tab>:set\ et! -menutrans Toggle\ &auto-indent<Tab>:set\ ai! - \ Ž©“®Žš‰º‚°�Ø‘Ö(&A)<Tab>:set\ ai! -menutrans Toggle\ &C-indenting<Tab>:set\ cin! - \ CŒ¾ŒêŽš‰º‚°�Ø‘Ö(&C)<Tab>:set\ cin! - -" other options -menutrans &Shiftwidth ƒVƒtƒg•�(&S) -menutrans Soft\ &Tabstop ƒ\ƒtƒgƒEƒFƒAƒ^ƒu•�(&T) -menutrans Te&xt\ Width\.\.\. ƒeƒLƒXƒg•�(&X)\.\.\. -menutrans &File\ Format\.\.\. ‰ü�s‹L�†‘I‘ð(&F)\.\.\. - -let g:menutrans_textwidth_dialog = "ƒeƒLƒXƒg‚Ì•�('textwidth')‚ð�ݒ肵‚Ä‚­‚¾‚³‚¢ (0‚Å�®Œ`‚𖳌ø‰»):" -let g:menutrans_fileformat_dialog = "ƒtƒ@ƒCƒ‹�o—Í‚Ì�ۂ̉ü�s‹L�†‚ÌŒ`Ž®‚ð‘I‚ñ‚Å‚­‚¾‚³‚¢." -let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\nƒLƒƒƒ“ƒZƒ‹(&C)" - -menutrans C&olor\ Scheme �Fƒe�[ƒ}‘I‘ð(&O) -menutrans &Keymap ƒL�[ƒ}ƒbƒv(&K) -menutrans None ‚È‚µ - -" Programming menu -menutrans &Tools ƒc�[ƒ‹(&T) -menutrans &Jump\ to\ this\ tag<Tab>g^] ƒ^ƒOƒWƒƒƒ“ƒv(&J)<Tab>g^] -menutrans Jump\ &back<Tab>^T –ß‚é(&B)<Tab>^T -menutrans Build\ &Tags\ File ƒ^ƒOƒtƒ@ƒCƒ‹�ì�¬(&T) -menutrans &Make<Tab>:make ƒ�ƒCƒN(&M)<Tab>:make -menutrans &List\ Errors<Tab>:cl ƒGƒ‰�[ƒŠƒXƒg(&L)<Tab>:cl -menutrans L&ist\ Messages<Tab>:cl! ƒ�ƒbƒZ�[ƒWƒŠƒXƒg(&I)<Tab>:cl! -menutrans &Next\ Error<Tab>:cn ŽŸ‚̃Gƒ‰�[‚Ö(&N)<Tab>:cn -menutrans &Previous\ Error<Tab>:cp ‘O‚̃Gƒ‰�[‚Ö(&P)<Tab>:cp -menutrans &Older\ List<Tab>:cold ŒÃ‚¢ƒŠƒXƒg(&O)<Tab>:cold -menutrans N&ewer\ List<Tab>:cnew �V‚µ‚¢ƒŠƒXƒg(&E)<Tab>:cnew -menutrans Error\ &Window ƒGƒ‰�[ƒEƒBƒ“ƒhƒE(&W) -menutrans &Update<Tab>:cwin �X�V(&U)<Tab>:cwin -menutrans &Open<Tab>:copen ŠJ‚­(&O)<Tab>:copen -menutrans &Close<Tab>:cclose •Â‚¶‚é(&C)<Tab>:cclose -menutrans &Convert\ to\ HEX<Tab>:%!xxd HEX‚Ö•ÏŠ·(&C)<Tab>:%!xxd -menutrans Conve&rt\ back<Tab>:%!xxd\ -r HEX‚©‚ç‹t•ÏŠ·(&R)<Tab>%!xxd\ -r -menutrans Se&T\ Compiler ƒRƒ“ƒpƒCƒ‰�Ý’è(&T) - -" Tools.Spelling Menu -menutrans &Spelling ƒXƒyƒŠƒ“ƒO(&S) -menutrans &Spell\ Check\ On ƒXƒyƒ‹ƒ`ƒFƒbƒN—LŒø(&S) -menutrans Spell\ Check\ &Off ƒXƒyƒ‹ƒ`ƒFƒbƒN—LŒø(&O) -menutrans To\ &Next\ error<Tab>]s ŽŸ‚̃Gƒ‰�[(&N)<Tab>]s -menutrans To\ &Previous\ error<Tab>[s ‘O‚̃Gƒ‰�[(&P)<Tab>[s -menutrans Suggest\ &Corrections<Tab>z= �C�³Œó•â(&C)<Tab>z= -menutrans &Repeat\ correction<Tab>:spellrepall �C�³‚ðŒJ‚è•Ô‚·(&R)<Tab>:spellrepall -menutrans Set\ language\ to\ "en" Œ¾Œê‚ð\ "en"\ ‚É�Ý’è‚·‚é -menutrans Set\ language\ to\ "en_au" Œ¾Œê‚ð\ "en_au"\ ‚É�Ý’è‚·‚é -menutrans Set\ language\ to\ "en_ca" Œ¾Œê‚ð\ "en_ca"\ ‚É�Ý’è‚·‚é -menutrans Set\ language\ to\ "en_gb" Œ¾Œê‚ð\ "en_gb"\ ‚É�Ý’è‚·‚é -menutrans Set\ language\ to\ "en_nz" Œ¾Œê‚ð\ "en_nz"\ ‚É�Ý’è‚·‚é -menutrans Set\ language\ to\ "en_us" Œ¾Œê‚ð\ "en_us"\ ‚É�Ý’è‚·‚é -menutrans &Find\ More\ Languages ‘¼‚ÌŒ¾Œê‚ðŒŸ�õ‚·‚é(&F) - -" Tools.Fold Menu -menutrans &Folding �Ü�ô‚Ý(&F) -" open close folds -menutrans &Enable/Disable\ folds<Tab>zi —LŒø/–³Œø�Ø‘Ö(&E)<Tab>zi -menutrans &View\ Cursor\ Line<Tab>zv ƒJ�[ƒ\ƒ‹�s‚ð•\Ž¦(&V)<Tab>zv -menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx ƒJ�[ƒ\ƒ‹�s‚¾‚¯‚ð•\Ž¦(&W)<Tab>zMzx -menutrans C&lose\ more\ folds<Tab>zm �Ü�ô‚Ý‚ð•Â‚¶‚é(&L)<Tab>zm -menutrans &Close\ all\ folds<Tab>zM ‘S�Ü�ô‚Ý‚ð•Â‚¶‚é(&C)<Tab>zM -menutrans O&pen\ more\ folds<Tab>zr �Ü�ô‚Ý‚ðŠJ‚­(&P)<Tab>zr -menutrans &Open\ all\ folds<Tab>zR ‘S�Ü�ô‚Ý‚ðŠJ‚­(&O)<Tab>zR -" fold method -menutrans Fold\ Met&hod �Ü�ô‚Ý•û–@(&H) -menutrans M&anual Žè“®(&A) -menutrans I&ndent ƒCƒ“ƒfƒ“ƒg(&N) -menutrans E&xpression Ž®•]‰¿(&X) -menutrans S&yntax ƒVƒ“ƒ^ƒbƒNƒX(&Y) -menutrans &Diff �·•ª(&D) -menutrans Ma&rker ƒ}�[ƒJ�[(&R) -" create and delete folds -menutrans Create\ &Fold<Tab>zf �Ü�ô‚Ý�ì�¬(&F)<Tab>zf -menutrans &Delete\ Fold<Tab>zd �Ü�ô‚Ý�í�œ(&D)<Tab>zd -menutrans Delete\ &All\ Folds<Tab>zD ‘S�Ü�ô‚Ý�í�œ(&A)<Tab>zD -" moving around in folds -menutrans Fold\ col&umn\ width �Ü�ô‚݃Jƒ‰ƒ€•�(&U) - -menutrans &Update �X�V(&U) -menutrans &Get\ Block ƒuƒ�ƒbƒN’Š�o(&G) -menutrans &Put\ Block ƒuƒ�ƒbƒN“K—p(&P) - -" Names for buffer menu. -menutrans &Buffers ƒoƒbƒtƒ@(&B) -menutrans &Refresh\ menu ƒ�ƒjƒ…�[�Ä“Ç�ž(&R) -menutrans &Delete �í�œ(&D) -menutrans &Alternate — ‚Ö�Ø‘Ö(&A) -menutrans &Next ŽŸ‚̃oƒbƒtƒ@(&N) -menutrans &Previous ‘O‚̃oƒbƒtƒ@(&P) -menutrans [No\ File] [–³‘è] -let g:menutrans_no_file = "[–³‘è]" - -" Window menu -menutrans &Window ƒEƒBƒ“ƒhƒE(&W) -menutrans &New<Tab>^Wn �V‹K�ì�¬(&N)<Tab>^Wn -menutrans S&plit<Tab>^Ws •ªŠ„(&P)<Tab>^Ws -menutrans Sp&lit\ To\ #<Tab>^W^^ — ƒoƒbƒtƒ@‚Ö•ªŠ„(&L)<Tab>^W^^ -menutrans Split\ &Vertically<Tab>^Wv �‚’¼•ªŠ„(&V)<Tab>^Wv -menutrans Split\ File\ E&xplorer ƒtƒ@ƒCƒ‹ƒGƒNƒXƒvƒ��[ƒ‰(&X) -menutrans &Close<Tab>^Wc •Â‚¶‚é(&C)<Tab>^Wc -menutrans Move\ &To ˆÚ“®(&T) -menutrans &Top<Tab>^WK �ã(&T)<Tab>^WK -menutrans &Bottom<Tab>^WJ ‰º(&B)<Tab>^WJ -menutrans &Left\ side<Tab>^WH �¶(&L)<Tab>^WH -menutrans &Right\ side<Tab>^WL ‰E(&R)<Tab>^WL -menutrans Close\ &Other(s)<Tab>^Wo ‘¼‚ð•Â‚¶‚é(&O)<Tab>^Wo -menutrans Ne&xt<Tab>^Ww ŽŸ‚Ö(&X)<Tab>^Ww -menutrans P&revious<Tab>^WW ‘O‚Ö(&R)<Tab>^WW -menutrans &Equal\ Size<Tab>^W= “¯‚¶�‚‚³‚É(&E)<Tab>^W= -menutrans &Max\ Height<Tab>^W_ �Å‘å�‚‚É(&M)<Tab>^W_ -menutrans M&in\ Height<Tab>^W1_ �Å�¬�‚‚É(&i)<Tab>^W1_ -menutrans Max\ &Width<Tab>^W\| �Å‘å•�‚É(&W)<Tab>^W\| -menutrans Min\ Widt&h<Tab>^W1\| �Å�¬•�‚É(&H)<Tab>^W1\| -menutrans Rotate\ &Up<Tab>^WR �ã‚Ƀ��[ƒe�[ƒVƒ‡ƒ“(&U)<Tab>^WR -menutrans Rotate\ &Down<Tab>^Wr ‰º‚Ƀ��[ƒe�[ƒVƒ‡ƒ“(&D)<Tab>^Wr -menutrans Select\ Fo&nt\.\.\. ƒtƒHƒ“ƒg�Ý’è(&N)\.\.\. - -" The popup menu -menutrans &Undo Žæ‚è�Á‚·(&U) -menutrans Cu&t �Ø‚èŽæ‚è(&T) -menutrans &Copy ƒRƒs�[(&C) -menutrans &Paste “\‚è•t‚¯(&P) -menutrans &Delete �í�œ(&D) -menutrans Select\ Blockwise ‹éŒ`ƒuƒ�ƒbƒN‘I‘ð -menutrans Select\ &Word ’PŒê‘I‘ð(&W) -menutrans Select\ &Line �s‘I‘ð(&L) -menutrans Select\ &Block ƒuƒ�ƒbƒN‘I‘ð(&B) -menutrans Select\ &All ‚·‚ׂđI‘ð(&A) - -" The GUI toolbar (for Win32 or GTK) -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open ƒtƒ@ƒCƒ‹‚ðŠJ‚­ - tmenu ToolBar.Save Œ»�݂̃tƒ@ƒCƒ‹‚ð•Û‘¶ - tmenu ToolBar.SaveAll ‚·‚ׂẴtƒ@ƒCƒ‹‚ð•Û‘¶ - tmenu ToolBar.Print ˆó�ü - tmenu ToolBar.Undo Žæ‚è�Á‚µ - tmenu ToolBar.Redo ‚à‚¤ˆê“x‚â‚é - tmenu ToolBar.Cut ƒNƒŠƒbƒvƒ{�[ƒh‚Ö�Ø‚èŽæ‚è - tmenu ToolBar.Copy ƒNƒŠƒbƒvƒ{�[ƒh‚ÖƒRƒs�[ - tmenu ToolBar.Paste ƒNƒŠƒbƒvƒ{�[ƒh‚©‚ç“\‚è•t‚¯ - tmenu ToolBar.Find ŒŸ�õ... - tmenu ToolBar.FindNext ŽŸ‚ðŒŸ�õ - tmenu ToolBar.FindPrev ‘O‚ðŒŸ�õ - tmenu ToolBar.Replace ’uŠ·... - if 0 " disabled; These are in the Windows menu - tmenu ToolBar.New �V‹KƒEƒBƒ“ƒhƒE�ì�¬ - tmenu ToolBar.WinSplit ƒEƒBƒ“ƒhƒE•ªŠ„ - tmenu ToolBar.WinMax ƒEƒBƒ“ƒhƒE�ő剻 - tmenu ToolBar.WinMin ƒEƒBƒ“ƒhƒE�Å�¬‰» - tmenu ToolBar.WinClose ƒEƒBƒ“ƒhƒE‚ð•Â‚¶‚é - endif - tmenu ToolBar.LoadSesn ƒZƒbƒVƒ‡ƒ““Ç�ž - tmenu ToolBar.SaveSesn ƒZƒbƒVƒ‡ƒ“•Û‘¶ - tmenu ToolBar.RunScript VimƒXƒNƒŠƒvƒgŽÀ�s - tmenu ToolBar.Make ƒvƒ�ƒWƒFƒNƒg‚ðMake - tmenu ToolBar.Shell ƒVƒFƒ‹‚ðŠJ‚­ - tmenu ToolBar.RunCtags tags�ì�¬ - tmenu ToolBar.TagJump ƒ^ƒOƒWƒƒƒ“ƒv - tmenu ToolBar.Help Vimƒwƒ‹ƒv - tmenu ToolBar.FindHelp Vimƒwƒ‹ƒvŒŸ�õ - endfun -endif - -" Syntax menu -menutrans &Syntax ƒVƒ“ƒ^ƒbƒNƒX(&S) -menutrans &Show\ filetypes\ in\ menu ‘ΉžŒ`Ž®‚ðƒ�ƒjƒ…�[‚É•\Ž¦(&S) -menutrans Set\ '&syntax'\ only 'syntax'‚¾‚¯�Ý’è(&S) -menutrans Set\ '&filetype'\ too 'filetype'‚à�Ý’è(&F) -menutrans &Off –³Œø‰»(&O) -menutrans &Manual Žè“®�Ý’è(&M) -menutrans A&utomatic Ž©“®�Ý’è(&U) -menutrans on/off\ for\ &This\ file - \ ƒIƒ“/ƒIƒt�Ø‘Ö(&T) -menutrans Co&lor\ test ƒJƒ‰�[ƒeƒXƒg(&L) -menutrans &Highlight\ test ƒnƒCƒ‰ƒCƒgƒeƒXƒg(&H) -menutrans &Convert\ to\ HTML HTML‚ÖƒRƒ“ƒo�[ƒg(&C) - -" Japanese specific menu -" �¬”Û‚ÍiconvŽŸ‘æ�A•K‚¸‚µ‚àŽw’肵‚½ƒGƒ“ƒR�[ƒh‚É‚È‚é‚킯‚Å‚Í‚È‚¢‚±‚Æ‚É’�ˆÓ -if has('iconv') - " iconv‚̃o�[ƒWƒ‡ƒ“”»’è - let support_jisx0213 = (iconv("\x87\x64\x87\x6a", 'cp932', 'euc-jisx0213') ==# "\xad\xc5\xad\xcb") ? 1 : 0 - " - " “Ç‚Ý�ž‚Ý - an 10.395 ƒtƒ@ƒCƒ‹(&F).-SEPICONV- <Nop> - an 10.396.100.100 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..SJIS(&S)<Tab>fenc=cp932 :browse confirm e ++enc=cp932<CR> - if !support_jisx0213 - an 10.396.100.110 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jp :browse confirm e ++enc=euc-jp<CR> - an 10.396.100.120 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :browse confirm e ++enc=iso-2022-jp<CR> - else - an 10.396.100.110 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :browse confirm e ++enc=euc-jisx0213<CR> - an 10.396.100.120 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :browse confirm e ++enc=iso-2022-jp-3<CR> - endif - an 10.396.100.130 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :browse confirm e ++enc=utf-8<CR> - - " �Ä“Ç�ž - an 10.396.110.100 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..SJIS(&S)<Tab>fenc=cp932 :e ++enc=cp932<CR> - if !support_jisx0213 - an 10.396.110.110 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jp :e ++enc=euc-jp<CR> - an 10.396.110.120 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :e ++enc=iso-2022-jp<CR> - else - an 10.396.110.110 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :e ++enc=euc-jisx0213<CR> - an 10.396.110.120 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :e ++enc=iso-2022-jp-3<CR> - endif - an 10.396.110.130 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :e ++enc=utf-8<CR> - - " •Û‘¶ - an 10.396.115 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..-SEP1- <Nop> - an 10.396.120.100 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..SJIS(&S)<Tab>fenc=cp932 :set fenc=cp932 \| w<CR> - if !support_jisx0213 - an 10.396.120.110 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jp :set fenc=euc-jp \| w<CR> - an 10.396.120.120 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :set fenc=iso-2022-jp \| w<CR> - else - an 10.396.120.110 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :set fenc=euc-jisx0213 \| w<CR> - an 10.396.120.120 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :set fenc=iso-2022-jp-3 \| w<CR> - endif - an 10.396.120.130 ƒtƒ@ƒCƒ‹(&F).ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :set fenc=utf-8 \| w<CR> -endif - -" filler to avoid the line above being recognized as a modeline -" filler -" filler -" filler diff --git a/share/vim/vim72/lang/menu_ko_kr.euckr.vim b/share/vim/vim72/lang/menu_ko_kr.euckr.vim deleted file mode 100644 index b8fa625893..0000000000 --- a/share/vim/vim72/lang/menu_ko_kr.euckr.vim +++ /dev/null @@ -1,243 +0,0 @@ -" Menu Translations: Korean -" Maintainer: Nam SungHyun <namsh@kldp.org> -" Last Change: 2003 Apr 25 - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 - -scriptencoding euc-kr - -" Help menu -menutrans &Help µµ¿ò¸»(&H) -menutrans &Overview<Tab><F1> °³°ü(&O)<Tab><F1> -menutrans &User\ Manual »ç¿ëÀÚ\ ¸Å´º¾ó(&U) -menutrans &How-to\ links ¾îÂîÇϳª\ ¸ñ·Ï(&H) -menutrans &GUI ±¸ÀÌ(&G) -menutrans &Find\.\.\. ã±â(&F)\.\.\. -menutrans &Credits °í¸¶¿î\ ºÐ(&C) -menutrans Co&pying ÀúÀÛ±Ç(&p) -menutrans O&rphans °í¾Æ(&r) -menutrans &Version ¹öÀü(&V) -menutrans &About ÀÌ\ ÇÁ·Î±×·¥Àº(&A) - -" File menu -menutrans &File ÆÄÀÏ(&F) -menutrans &Open\.\.\.<Tab>:e ¿­±â(&O)\.\.\.<Tab>:e -menutrans Sp&lit-Open\.\.\.<Tab>:sp ³ª´²¼­\ ¿­±â(&l)\.\.\.<Tab>:sp -menutrans &New<Tab>:enew »õ·Î¿î(&N)<Tab>:enew -menutrans &Close<Tab>:close ´Ý±â(&C)<Tab>:close -menutrans &Save<Tab>:w ÀúÀå(&S)<Tab>:w -menutrans Save\ &As\.\.\.<Tab>:sav ´Ù¸¥\ À̸§À¸·Î\ ÀúÀå(&A)\.\.\.<Tab>:sav -"menutrans Split\ &Diff\ with\.\.\. Split\ &Diff\ with\.\.\. -"menutrans Split\ Patched\ &By\.\.\. Split\ Patched\ &By\.\.\. -menutrans &Print Àμâ(&P) -menutrans Sa&ve-Exit<Tab>:wqa ÀúÀåÇÏ°í\ ³¡³»±â(&v)<Tab>:wqa -menutrans E&xit<Tab>:qa ³¡³»±â(&x)<Tab>:qa - -" Edit menu -menutrans &Edit ÆíÁý(&E) -menutrans &Undo<Tab>u Ãë¼Ò(&U)<Tab>u -menutrans &Redo<Tab>^R ´Ù½Ã ½ÇÇà(&R)<Tab>^R -menutrans Rep&eat<Tab>\. µÇÇ®ÀÌ(&e)<Tab>\. -menutrans Cu&t<Tab>"+x ÀÚ¸£±â(&t)<Tab>"+x -menutrans &Copy<Tab>"+y º¹»ç(&C)<Tab>"+y -menutrans &Paste<Tab>"+gP ºÙÀ̱â(&P)<Tab>"+gP -menutrans Put\ &Before<Tab>[p ¾Õ¿¡\ ºÙÀ̱â(&B)<Tab>[p -menutrans Put\ &After<Tab>]p µÚ¿¡\ ºÙÀ̱â(&A)<Tab>]p -menutrans &Delete<Tab>x Áö¿ì±â(&D)<Tab>x -menutrans &Select\ All<Tab>ggVG ¸ðµÎ\ °í¸£±â(&S)<Tab>ggVG -menutrans &Find\.\.\. ã±â(&F)\.\.\. -menutrans Find\ and\ Rep&lace\.\.\. ã¾Æ¼­\ ¹Ù²Ù±â(&l)\.\.\. -menutrans Settings\ &Window ¼³Á¤\ â(&W) - -" Edit/Global Settings -menutrans &Global\ Settings Àü¿ª\ ¼³Á¤(&G) -menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! ÆÐÅÏ\ ÇÏÀ̶óÀÌÆ®\ Åä±Û(&H)<Tab>:set\ hls! -menutrans Toggle\ &Ignore-case<Tab>:set\ ic! ´ë¼Ò¹®ÀÚ\ ±¸ºÐ\ Åä±Û(&I)<Tab>:set\ ic! -menutrans Toggle\ &Showmatch<Tab>:set\ sm! Showmatch\ Åä±Û(&S)<Tab>:set\ sm! -menutrans &Context\ lines ÄÜÅؽºÆ®\ ÁÙ(&C) -menutrans &Virtual\ Edit °¡»ó\ ÆíÁý(&V) -menutrans Never »ç¿ë ¾È ÇÔ -menutrans Block\ Selection ºí·°\ °í¸£±â -menutrans Insert\ mode »ðÀÔ\ ¸ðµå -menutrans Block\ and\ Insert ºí·°°ú\ »ðÀÔ -menutrans Always Ç×»ó\ »ç¿ë -menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! »ðÀÔ\ ¸ðµå\ Åä±Û(&M)<Tab>:set\ im! -menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Vi\ ȣȯ\ Åä±Û(&o)<Tab>:set\ cp! -menutrans Search\ &Path\.\.\. ã±â\ °æ·Î(&P)\.\.\. -menutrans Ta&g\ Files\.\.\. ²¿¸®Ç¥\ ÆÄÀÏ(&g)\.\.\. - -" GUI options -menutrans Toggle\ &Toolbar µµ±¸¸·´ë\ Åä±Û(&T) -menutrans Toggle\ &Bottom\ Scrollbar ¹Ù´Ú\ ½ºÅ©·Ñ¹Ù\ Åä±Û(&B) -menutrans Toggle\ &Left\ Scrollbar ¿ÞÂÊ\ ½ºÅ©·Ñ¹Ù\ Åä±Û(&L) -menutrans Toggle\ &Right\ Scrollbar ¿À¸¥ÂÊ\ ½ºÅ©·Ñ¹Ù\ Åä±Û(&R) - -" Edit/File Settings -menutrans F&ile\ Settings ÆÄÀÏ\ ¼³Á¤(&i) - -" Boolean options -menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! ÁÙ\ ¹øÈ£ºÙÀ̱â\ Åä±Û(&N)<Tab>:set\ nu! -menutrans Toggle\ &List\ Mode<Tab>:set\ list! ¸ñ·Ï\ ¸ðµå\ Åä±Û(&L)<Tab>:set\ list! -menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! ÁÙ\ Wrap\ Åä±Û(&W)<Tab>:set\ wrap! -menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! ³¹¸»¿¡¼­\ Wrap\ Åä±Û(&r)<Tab>:set\ lbr! -menutrans Toggle\ &expand-tab<Tab>:set\ et! ÅÇ\ È®Àå\ Åä±Û(&e)<Tab>:set\ et! -menutrans Toggle\ &auto-indent<Tab>:set\ ai! ÀÚµ¿Àε§Æ®\ Åä±Û(&a)<Tab>:set\ ai! -menutrans Toggle\ &C-indenting<Tab>:set\ cin! C-Àε§ÆÃ\ Åä±Û(&C)<Tab>:set\ cin! - -" other options -menutrans &Shiftwidth ½¬ÇÁÆ® ³Êºñ(&S) -menutrans Soft\ &Tabstop ¼ÒÇÁÆ®\ ÅǽºÅé(&T) -menutrans Te&xt\ Width\.\.\. ÅؽºÆ®\ ³Êºñ(&x)\.\.\. -menutrans &File\ Format\.\.\. ÆÄÀÏ\ Çü½Ä(&F)\.\.\. -menutrans C&olor\ Scheme Ä÷¯\ ½ºÅ´(&o) -menutrans &Keymap Å°¸Ê(&K) - -menutrans Select\ Fo&nt\.\.\. ±Û²Ã\ °í¸£±â(&F)\.\.\. - -" Programming menu -menutrans &Tools µµ±¸(&T) -menutrans &Jump\ to\ this\ tag<Tab>g^] ÀÌ\ ²¿¸®Ç¥·Î\ °¡±â(&J)<Tab>g^] -menutrans Jump\ &back<Tab>^T µÚ·Î\ °¡±â(&b)<Tab>^T -menutrans Build\ &Tags\ File ²¿¸®Ç¥\ ÆÄÀÏ\ ¸¸µé±â(&T) - -" Tools.Fold Menu -menutrans &Folding Á¢±â(&F) -" open close folds -menutrans &Enable/Disable\ folds<Tab>zi Á¢´Â\ ±â´É\ »ç¿ë\ Åä±Û(&E)<Tab>zi -menutrans &View\ Cursor\ Line<Tab>zv Ä¿¼­\ ÁÙ\ º¸±â(&V)<Tab>zv -menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx Ä¿¼­\ ÁÙ¸¸\ º¸±â(&w)<Tab>zMzx -menutrans C&lose\ more\ folds<Tab>zm ´õ\ ¸¹Àº\ Á¢±â\ ´Ý±â(&l)<Tab>zm -menutrans &Close\ all\ folds<Tab>zM Á¢Èù\ ºÎºÐ\ ¸ðµÎ\ Á¢±â(&C)<Tab>zM -menutrans O&pen\ more\ folds<Tab>zr ´õ ¸¹Àº\ Á¢±â\ ¿­±â(&p)<Tab>zr -menutrans &Open\ all\ folds<Tab>zR Á¢Èù\ ºÎºÐ\ ¸ðµÎ\ Æì±â(&O)<Tab>zR -" fold method -menutrans Fold\ Met&hod Á¢´Â\ ¹æ¹ý(&h) -menutrans M&anual ¼öµ¿(&a) -menutrans I&ndent µé¿©¾²±â(&n) -menutrans E&xpression Ç¥Çö½Ä(&x) -menutrans S&yntax ½ÅÅýº(&y) -"menutrans &Diff &Diff -menutrans Ma&rker ²¿¸®Ç¥(&r) -" create and delete folds -menutrans Create\ &Fold<Tab>zf »õ·Î Á¢±â(&F)<Tab>zf -menutrans &Delete\ Fold<Tab>zd ¿ÏÀüÈ÷ Æì±â(&D)<Tab>zd -menutrans Delete\ &All\ Folds<Tab>zD ¸ðµÎ\ Æì±â(&A)<Tab>zD -" moving around in folds -menutrans Fold\ column\ &width Á¢À»\ Ä­\ ³Êºñ(&w) - -"menutrans &Diff &Diff -menutrans &Update °»½Å(&U) -menutrans &Get\ Block ºí·°\ °¡Á®¿À±â(&G) -menutrans &Put\ Block ºí·°\ Áý¾î³Ö±â(&P) - -menutrans &Make<Tab>:make Make(&M)<Tab>:make -menutrans &List\ Errors<Tab>:cl ¿¡·¯\ ¸ñ·Ï\ º¸±â(&L)<Tab>:cl -menutrans L&ist\ Messages<Tab>:cl! ¸Þ½ÃÁö\ ¸ñ·Ï\ º¸±â(&i)<Tab>:cl! -menutrans &Next\ Error<Tab>:cn ´ÙÀ½\ ¿¡·¯(&N)<Tab>:cn -menutrans &Previous\ Error<Tab>:cp ÀÌÀü\ ¿¡·¯(&P)<Tab>:cp -menutrans &Older\ List<Tab>:cold ¿À·¡µÈ\ ¸ñ·Ï(&O)<Tab>:cold -menutrans N&ewer\ List<Tab>:cnew »õ·Î¿î\ ¸ñ·Ï(&e)<Tab>:cnew -menutrans Error\ &Window ¿¡·¯\ â(&W) -menutrans &Update<Tab>:cwin °»½Å(&U)<Tab>:cwin -menutrans &Open<Tab>:copen ¿­±â(&O)<Tab>:copen -menutrans &Close<Tab>:cclose ´Ý±â(&C)<Tab>:cclose -menutrans &Set\ Compiler ÄÄÆÄÀÏ·¯\ ¼³Á¤(&S) -menutrans &Convert\ to\ HEX<Tab>:%!mc\ vim:xxd ½ÊÀ°ÁøÀ¸·Î\ º¯È¯<Tab>:%!mc\ vim:xxd -menutrans &Convert\ to\ HEX<Tab>:%!xxd ½ÊÀ°ÁøÀ¸·Î\ º¯È¯(&C)<Tab>:%!xxd -menutrans Conve&rt\ back<Tab>:%!mc\ vim:xxd\ -r ¿ø·¡´ë·Î\ º¯È¯(&r)<Tab>:%!mc\ vim:xxd\ -r -menutrans Conve&rt\ back<Tab>:%!xxd\ -r ¿ø·¡´ë·Î\ º¯È¯(&r)<Tab>:%!xxd\ -r - -" Names for buffer menu. -menutrans &Buffers ¹öÆÛ(&B) -menutrans &Refresh\ menu Â÷¸²Ç¥\ ´Ù½Ã±×¸®±â(&R) -menutrans &Delete Áö¿ì±â(&D) -menutrans &Alternate ±³Ã¼(&A) -menutrans &Next ´ÙÀ½(&N) -menutrans &Previous ÀÌÀü(&P) - -" Window menu -menutrans &Window â(&W) -menutrans &New<Tab>^Wn »õ\ â(&N)<Tab>^Wn -menutrans S&plit<Tab>^Ws ³ª´©±â(&p)<Tab>^Ws -menutrans Sp&lit\ To\ #<Tab>^W^^ #À¸·Î\ ³ª´©±â(&l)<Tab>^W^^ -menutrans Split\ &Vertically<Tab>^Wv ¼¼·Î·Î\ ³ª´©±â(&V)<Tab>^Wv -menutrans Split\ File\ E&xplorer ÆÄÀÏ\ ÀͽºÇ÷η¯\ ³ª´©±â - -menutrans &Close<Tab>^Wc ´Ý±â(&C)<Tab>^Wc -menutrans Close\ &Other(s)<Tab>^Wo ´Ù¸¥\ â\ ´Ý±â(&O)<Tab>^Wo - -menutrans Move\ &To À̵¿(&T) -menutrans &Top<Tab>^WK ²À´ë±â(&T)<Tab>^WK -menutrans &Bottom<Tab>^WJ ¹Ù´Ú(&B)<Tab>^WJ -menutrans &Left\ side<Tab>^WH ¿ÞÂÊ(&L)<Tab>^WH -menutrans &Right\ side<Tab>^WL ¿À¸¥ÂÊ(&R)<Tab>^WL -menutrans Rotate\ &Up<Tab>^WR À§·Î\ ȸÀü(&U)<Tab>^WR -menutrans Rotate\ &Down<Tab>^Wr ¾Æ·¡·Î\ ȸÀü(&D)<Tab>^Wr - -menutrans &Equal\ Size<Tab>^W= °°Àº\ ³ôÀÌ·Î(&E)<Tab>^W= -menutrans &Max\ Height<Tab>^W_ ÃÖ´ë\ ³ôÀÌ·Î(&M)<Tab>^W_ -menutrans M&in\ Height<Tab>^W1_ ÃÖ¼Ò\ ³ôÀÌ·Î(&i)<Tab>^W1_ -menutrans Max\ &Width<Tab>^W\| ÃÖ´ë\ ³ÐÀÌ·Î(&W)<Tab>^W\| -menutrans Min\ Widt&h<Tab>^W1\| ÃÖ¼Ò\ ³ÐÀÌ·Î(&h)<Tab>^W1\| - -" The popup menu -menutrans &Undo Ãë¼Ò(&U) -menutrans Cu&t ÀÚ¸£±â(&t) -menutrans &Copy º¹»ç(&C) -menutrans &Paste ºÙÀ̱â(&P) -menutrans &Delete Áö¿ì±â(&D) -menutrans Select\ Blockwise »ç°¢Çü\ °í¸£±â -menutrans Select\ &Word ³¹¸»\ °í¸£±â(&W) -menutrans Select\ &Line ÁÙ\ °í¸£±â(&L) -menutrans Select\ &Block ±¸È¹\ °í¸£±â(&B) -menutrans Select\ &All ¸ðµÎ\ °í¸£±â(&A) - -" The GUI toolbar -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open ÆÄÀÏ ¿­±â - tmenu ToolBar.Save ÇöÀç ÆÄÀÏ ÀúÀå - tmenu ToolBar.SaveAll ¸ðµÎ ÀúÀå - tmenu ToolBar.Print Àμâ - tmenu ToolBar.Undo Ãë¼Ò - tmenu ToolBar.Redo ´Ù½Ã ½ÇÇà - tmenu ToolBar.Cut ÀÚ¸£±â - tmenu ToolBar.Copy º¹»ç - tmenu ToolBar.Paste ºÙÀ̱â - tmenu ToolBar.Find ã±â... - tmenu ToolBar.FindNext ´ÙÀ½ ã±â - tmenu ToolBar.FindPrev ÀÌÀü ã±â - tmenu ToolBar.Replace ¹Ù²Ù±â - tmenu ToolBar.LoadSesn ¼¼¼Ç Àоî¿À±â - tmenu ToolBar.SaveSesn ¼¼¼Ç ÀúÀå - tmenu ToolBar.RunScript ½ºÅ©¸³Æ® ½ÇÇà - tmenu ToolBar.Make Make - tmenu ToolBar.Shell ½© - tmenu ToolBar.RunCtags ²¿¸®Ç¥ ¸¸µé±â - tmenu ToolBar.TagJump ²¿¸®Ç¥·Î °¡±â - tmenu ToolBar.Help µµ¿ò¸» - tmenu ToolBar.FindHelp µµ¿ò¸» ã±â... - endfun -endif - -" Syntax menu -menutrans &Syntax ¹®¹ý(&S) -menutrans &Show\ filetypes\ in\ menu ¸ðµç\ ¼±Åð¡´ÉÇÑ\ Ç׸ñ\ º¸±â(&S) -menutrans Set\ '&syntax'\ only 'syntax'¸¸\ ¼³Á¤(&s) -menutrans Set\ '&filetype'\ too 'filetype'µµ\ ¼³Á¤(&f) -menutrans &Off ²ô±â(&O) -menutrans &Manual ¼öµ¿(&M) -menutrans A&utomatic ÀÚµ¿(&u) -menutrans on/off\ for\ &This\ file ÀÌ\ ÆÄÀϸ¸\ Äѱâ/²ô±â(&T) - -menutrans Co&lor\ test »ö\ ½ÃÇè(&l) -menutrans &Highlight\ test Highlight\ ½ÃÇè(&H) -menutrans &Convert\ to\ HTML HTML·Î\ º¯È¯(&C) - diff --git a/share/vim/vim72/lang/menu_ko_kr.utf-8.vim b/share/vim/vim72/lang/menu_ko_kr.utf-8.vim deleted file mode 100644 index 8e507d5fb4..0000000000 --- a/share/vim/vim72/lang/menu_ko_kr.utf-8.vim +++ /dev/null @@ -1,243 +0,0 @@ -" Menu Translations: Korean -" Maintainer: Nam SungHyun <namsh@kldp.org> -" Last Change: 2003 Apr 25 - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 - -scriptencoding utf-8 - -" Help menu -menutrans &Help 도움말(&H) -menutrans &Overview<Tab><F1> 개관(&O)<Tab><F1> -menutrans &User\ Manual 사용자\ 매뉴얼(&U) -menutrans &How-to\ links 어찌하나\ 목록(&H) -menutrans &GUI 구이(&G) -menutrans &Find\.\.\. 찾기(&F)\.\.\. -menutrans &Credits 고마운\ 분(&C) -menutrans Co&pying 저작권(&p) -menutrans O&rphans 고아(&r) -menutrans &Version 버전(&V) -menutrans &About 이\ 프로그램은(&A) - -" File menu -menutrans &File 파일(&F) -menutrans &Open\.\.\.<Tab>:e 열기(&O)\.\.\.<Tab>:e -menutrans Sp&lit-Open\.\.\.<Tab>:sp 나눠서\ 열기(&l)\.\.\.<Tab>:sp -menutrans &New<Tab>:enew 새로운(&N)<Tab>:enew -menutrans &Close<Tab>:close 닫기(&C)<Tab>:close -menutrans &Save<Tab>:w 저장(&S)<Tab>:w -menutrans Save\ &As\.\.\.<Tab>:sav 다른\ 이름으로\ 저장(&A)\.\.\.<Tab>:sav -"menutrans Split\ &Diff\ with\.\.\. Split\ &Diff\ with\.\.\. -"menutrans Split\ Patched\ &By\.\.\. Split\ Patched\ &By\.\.\. -menutrans &Print 인쇄(&P) -menutrans Sa&ve-Exit<Tab>:wqa 저장하고\ 끝내기(&v)<Tab>:wqa -menutrans E&xit<Tab>:qa 끝내기(&x)<Tab>:qa - -" Edit menu -menutrans &Edit 편집(&E) -menutrans &Undo<Tab>u 취소(&U)<Tab>u -menutrans &Redo<Tab>^R 다시 실행(&R)<Tab>^R -menutrans Rep&eat<Tab>\. 되풀이(&e)<Tab>\. -menutrans Cu&t<Tab>"+x 자르기(&t)<Tab>"+x -menutrans &Copy<Tab>"+y 복사(&C)<Tab>"+y -menutrans &Paste<Tab>"+gP 붙이기(&P)<Tab>"+gP -menutrans Put\ &Before<Tab>[p 앞에\ 붙이기(&B)<Tab>[p -menutrans Put\ &After<Tab>]p 뒤에\ 붙이기(&A)<Tab>]p -menutrans &Delete<Tab>x 지우기(&D)<Tab>x -menutrans &Select\ All<Tab>ggVG 모두\ 고르기(&S)<Tab>ggVG -menutrans &Find\.\.\. 찾기(&F)\.\.\. -menutrans Find\ and\ Rep&lace\.\.\. 찾아서\ 바꾸기(&l)\.\.\. -menutrans Settings\ &Window 설정\ 창(&W) - -" Edit/Global Settings -menutrans &Global\ Settings 전역\ 설정(&G) -menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! 패턴\ 하이라이트\ 토글(&H)<Tab>:set\ hls! -menutrans Toggle\ &Ignore-case<Tab>:set\ ic! 대소문자\ 구분\ 토글(&I)<Tab>:set\ ic! -menutrans Toggle\ &Showmatch<Tab>:set\ sm! Showmatch\ 토글(&S)<Tab>:set\ sm! -menutrans &Context\ lines 콘텍스트\ 줄(&C) -menutrans &Virtual\ Edit 가상\ 편집(&V) -menutrans Never 사용 안 함 -menutrans Block\ Selection 블럭\ 고르기 -menutrans Insert\ mode 삽입\ 모드 -menutrans Block\ and\ Insert 블럭과\ 삽입 -menutrans Always 항상\ 사용 -menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! 삽입\ 모드\ 토글(&M)<Tab>:set\ im! -menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Vi\ 호환\ 토글(&o)<Tab>:set\ cp! -menutrans Search\ &Path\.\.\. 찾기\ 경로(&P)\.\.\. -menutrans Ta&g\ Files\.\.\. 꼬리표\ 파일(&g)\.\.\. - -" GUI options -menutrans Toggle\ &Toolbar 도구막대\ 토글(&T) -menutrans Toggle\ &Bottom\ Scrollbar 바닥\ 스크롤바\ 토글(&B) -menutrans Toggle\ &Left\ Scrollbar 왼쪽\ 스크롤바\ 토글(&L) -menutrans Toggle\ &Right\ Scrollbar 오른쪽\ 스크롤바\ 토글(&R) - -" Edit/File Settings -menutrans F&ile\ Settings 파일\ 설정(&i) - -" Boolean options -menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! 줄\ 번호붙이기\ 토글(&N)<Tab>:set\ nu! -menutrans Toggle\ &List\ Mode<Tab>:set\ list! 목록\ 모드\ 토글(&L)<Tab>:set\ list! -menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! 줄\ Wrap\ 토글(&W)<Tab>:set\ wrap! -menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! 낱말에서\ Wrap\ 토글(&r)<Tab>:set\ lbr! -menutrans Toggle\ &expand-tab<Tab>:set\ et! 탭\ 확장\ 토글(&e)<Tab>:set\ et! -menutrans Toggle\ &auto-indent<Tab>:set\ ai! 자동인덴트\ 토글(&a)<Tab>:set\ ai! -menutrans Toggle\ &C-indenting<Tab>:set\ cin! C-인덴팅\ 토글(&C)<Tab>:set\ cin! - -" other options -menutrans &Shiftwidth 쉬프트 너비(&S) -menutrans Soft\ &Tabstop 소프트\ 탭스톱(&T) -menutrans Te&xt\ Width\.\.\. 텍스트\ 너비(&x)\.\.\. -menutrans &File\ Format\.\.\. 파일\ 형식(&F)\.\.\. -menutrans C&olor\ Scheme 컬러\ 스킴(&o) -menutrans &Keymap 키맵(&K) - -menutrans Select\ Fo&nt\.\.\. 글꼴\ 고르기(&F)\.\.\. - -" Programming menu -menutrans &Tools 도구(&T) -menutrans &Jump\ to\ this\ tag<Tab>g^] 이\ 꼬리표로\ 가기(&J)<Tab>g^] -menutrans Jump\ &back<Tab>^T 뒤로\ 가기(&b)<Tab>^T -menutrans Build\ &Tags\ File 꼬리표\ 파일\ 만들기(&T) - -" Tools.Fold Menu -menutrans &Folding 접기(&F) -" open close folds -menutrans &Enable/Disable\ folds<Tab>zi 접는\ 기능\ 사용\ 토글(&E)<Tab>zi -menutrans &View\ Cursor\ Line<Tab>zv 커서\ 줄\ 보기(&V)<Tab>zv -menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx 커서\ 줄만\ 보기(&w)<Tab>zMzx -menutrans C&lose\ more\ folds<Tab>zm 더\ 많은\ 접기\ 닫기(&l)<Tab>zm -menutrans &Close\ all\ folds<Tab>zM 접힌\ 부분\ 모두\ 접기(&C)<Tab>zM -menutrans O&pen\ more\ folds<Tab>zr 더 많은\ 접기\ 열기(&p)<Tab>zr -menutrans &Open\ all\ folds<Tab>zR 접힌\ 부분\ 모두\ 펴기(&O)<Tab>zR -" fold method -menutrans Fold\ Met&hod 접는\ 방법(&h) -menutrans M&anual 수동(&a) -menutrans I&ndent 들여쓰기(&n) -menutrans E&xpression 표현식(&x) -menutrans S&yntax 신택스(&y) -"menutrans &Diff &Diff -menutrans Ma&rker 꼬리표(&r) -" create and delete folds -menutrans Create\ &Fold<Tab>zf 새로 접기(&F)<Tab>zf -menutrans &Delete\ Fold<Tab>zd 완전히 펴기(&D)<Tab>zd -menutrans Delete\ &All\ Folds<Tab>zD 모두\ 펴기(&A)<Tab>zD -" moving around in folds -menutrans Fold\ column\ &width 접을\ 칸\ 너비(&w) - -"menutrans &Diff &Diff -menutrans &Update 갱신(&U) -menutrans &Get\ Block 블럭\ 가져오기(&G) -menutrans &Put\ Block 블럭\ 집어넣기(&P) - -menutrans &Make<Tab>:make Make(&M)<Tab>:make -menutrans &List\ Errors<Tab>:cl 에러\ 목록\ 보기(&L)<Tab>:cl -menutrans L&ist\ Messages<Tab>:cl! 메시지\ 목록\ 보기(&i)<Tab>:cl! -menutrans &Next\ Error<Tab>:cn 다음\ 에러(&N)<Tab>:cn -menutrans &Previous\ Error<Tab>:cp 이전\ 에러(&P)<Tab>:cp -menutrans &Older\ List<Tab>:cold 오래된\ 목록(&O)<Tab>:cold -menutrans N&ewer\ List<Tab>:cnew 새로운\ 목록(&e)<Tab>:cnew -menutrans Error\ &Window 에러\ 창(&W) -menutrans &Update<Tab>:cwin 갱신(&U)<Tab>:cwin -menutrans &Open<Tab>:copen 열기(&O)<Tab>:copen -menutrans &Close<Tab>:cclose 닫기(&C)<Tab>:cclose -menutrans &Set\ Compiler 컴파일러\ 설정(&S) -menutrans &Convert\ to\ HEX<Tab>:%!mc\ vim:xxd 십육진으로\ 변환<Tab>:%!mc\ vim:xxd -menutrans &Convert\ to\ HEX<Tab>:%!xxd 십육진으로\ 변환(&C)<Tab>:%!xxd -menutrans Conve&rt\ back<Tab>:%!mc\ vim:xxd\ -r 원래대로\ 변환(&r)<Tab>:%!mc\ vim:xxd\ -r -menutrans Conve&rt\ back<Tab>:%!xxd\ -r 원래대로\ 변환(&r)<Tab>:%!xxd\ -r - -" Names for buffer menu. -menutrans &Buffers 버퍼(&B) -menutrans &Refresh\ menu 차림표\ 다시그리기(&R) -menutrans &Delete 지우기(&D) -menutrans &Alternate 교체(&A) -menutrans &Next 다음(&N) -menutrans &Previous 이전(&P) - -" Window menu -menutrans &Window 창(&W) -menutrans &New<Tab>^Wn 새\ 창(&N)<Tab>^Wn -menutrans S&plit<Tab>^Ws 나누기(&p)<Tab>^Ws -menutrans Sp&lit\ To\ #<Tab>^W^^ #으로\ 나누기(&l)<Tab>^W^^ -menutrans Split\ &Vertically<Tab>^Wv 세로로\ 나누기(&V)<Tab>^Wv -menutrans Split\ File\ E&xplorer 파일\ 익스플로러\ 나누기 - -menutrans &Close<Tab>^Wc 닫기(&C)<Tab>^Wc -menutrans Close\ &Other(s)<Tab>^Wo 다른\ 창\ 닫기(&O)<Tab>^Wo - -menutrans Move\ &To 이동(&T) -menutrans &Top<Tab>^WK 꼭대기(&T)<Tab>^WK -menutrans &Bottom<Tab>^WJ 바닥(&B)<Tab>^WJ -menutrans &Left\ side<Tab>^WH 왼쪽(&L)<Tab>^WH -menutrans &Right\ side<Tab>^WL 오른쪽(&R)<Tab>^WL -menutrans Rotate\ &Up<Tab>^WR 위로\ 회전(&U)<Tab>^WR -menutrans Rotate\ &Down<Tab>^Wr 아래로\ 회전(&D)<Tab>^Wr - -menutrans &Equal\ Size<Tab>^W= 같은\ 높이로(&E)<Tab>^W= -menutrans &Max\ Height<Tab>^W_ 최대\ 높이로(&M)<Tab>^W_ -menutrans M&in\ Height<Tab>^W1_ 최소\ 높이로(&i)<Tab>^W1_ -menutrans Max\ &Width<Tab>^W\| 최대\ 넓이로(&W)<Tab>^W\| -menutrans Min\ Widt&h<Tab>^W1\| 최소\ 넓이로(&h)<Tab>^W1\| - -" The popup menu -menutrans &Undo 취소(&U) -menutrans Cu&t 자르기(&t) -menutrans &Copy 복사(&C) -menutrans &Paste 붙이기(&P) -menutrans &Delete 지우기(&D) -menutrans Select\ Blockwise 사각형\ 고르기 -menutrans Select\ &Word 낱말\ 고르기(&W) -menutrans Select\ &Line 줄\ 고르기(&L) -menutrans Select\ &Block 구획\ 고르기(&B) -menutrans Select\ &All 모두\ 고르기(&A) - -" The GUI toolbar -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open 파일 열기 - tmenu ToolBar.Save 현재 파일 저장 - tmenu ToolBar.SaveAll 모두 저장 - tmenu ToolBar.Print 인쇄 - tmenu ToolBar.Undo 취소 - tmenu ToolBar.Redo 다시 실행 - tmenu ToolBar.Cut 자르기 - tmenu ToolBar.Copy 복사 - tmenu ToolBar.Paste 붙이기 - tmenu ToolBar.Find 찾기... - tmenu ToolBar.FindNext 다음 찾기 - tmenu ToolBar.FindPrev 이전 찾기 - tmenu ToolBar.Replace 바꾸기 - tmenu ToolBar.LoadSesn 세션 읽어오기 - tmenu ToolBar.SaveSesn 세션 저장 - tmenu ToolBar.RunScript 스크립트 실행 - tmenu ToolBar.Make Make - tmenu ToolBar.Shell 쉘 - tmenu ToolBar.RunCtags 꼬리표 만들기 - tmenu ToolBar.TagJump 꼬리표로 가기 - tmenu ToolBar.Help 도움말 - tmenu ToolBar.FindHelp 도움말 찾기... - endfun -endif - -" Syntax menu -menutrans &Syntax 문법(&S) -menutrans &Show\ filetypes\ in\ menu 모든\ 선택가능한\ 항목\ 보기(&S) -menutrans Set\ '&syntax'\ only 'syntax'만\ 설정(&s) -menutrans Set\ '&filetype'\ too 'filetype'도\ 설정(&f) -menutrans &Off 끄기(&O) -menutrans &Manual 수동(&M) -menutrans A&utomatic 자동(&u) -menutrans on/off\ for\ &This\ file 이\ 파일만\ 켜기/끄기(&T) - -menutrans Co&lor\ test 색\ 시험(&l) -menutrans &Highlight\ test Highlight\ 시험(&H) -menutrans &Convert\ to\ HTML HTML로\ 변환(&C) - diff --git a/share/vim/vim72/lang/menu_ko_kr.vim b/share/vim/vim72/lang/menu_ko_kr.vim deleted file mode 100644 index 26a959a94b..0000000000 --- a/share/vim/vim72/lang/menu_ko_kr.vim +++ /dev/null @@ -1,5 +0,0 @@ -" Menu Translations: Korean -" Translated By: Nam SungHyun <namsh@kldp.org> -" Last Change: 2003 Feb 24 - -source <sfile>:p:h/menu_ko_kr.euckr.vim diff --git a/share/vim/vim72/lang/menu_pl_pl.iso_8859-2.vim b/share/vim/vim72/lang/menu_pl_pl.iso_8859-2.vim deleted file mode 100644 index df78de8e19..0000000000 --- a/share/vim/vim72/lang/menu_pl_pl.iso_8859-2.vim +++ /dev/null @@ -1,286 +0,0 @@ -" Menu Translations: Polish -" Maintainer: Mikolaj Machowski ( mikmach AT wp DOT pl ) -" Initial Translation: Marcin Dalecki <martin@dalecki.de> -" Last Change: 4 May 2006 - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 - -scriptencoding iso-8859-2 - -" Help menu -menutrans &Help Po&moc -menutrans &Overview<Tab><F1> &Spis\ tre¶ci<Tab><F1> -menutrans &How-to\ links &Odno¶niki\ JTZ -menutrans &Credits Po&dziêkowania -menutrans &User\ Manual Podrêcznik\ &u¿ytkownika -menutrans Co&pying &Kopiowanie -menutrans &Version &Wersja -menutrans &About o\ &Programie -menutrans &Sponsor/Register &Sponsorowanie/Rejestracja -menutrans O&rphans Sie&roty - -" File menu -menutrans &File &Plik -menutrans &Open\.\.\.<Tab>:e &Otwórz\.\.\.<Tab>:e -menutrans Sp&lit-Open\.\.\.<Tab>:sp Otwórz\ z\ &podzia³em\.\.\.<Tab>:sp -menutrans &New<Tab>:enew &Nowy<Tab>:enew -menutrans &Close<Tab>:close &Zamknij<Tab>:close -menutrans &Save<Tab>:w Za&pisz<Tab>:w -menutrans Save\ &As\.\.\.<Tab>:sav Zapisz\ &jako\.\.\.<Tab>:sav -menutrans Split\ &Diff\ with\.\.\. Podziel\ na\ diff-a\ miêdzy\.\.\. -menutrans Split\ Patched\ &By\.\.\. Podziel\ ³atane\ przez\.\.\. -menutrans &Print &Drukuj -menutrans Sa&ve-Exit<Tab>:wqa W&yj¶cie\ z\ zapisem<Tab>:wqa -menutrans E&xit<Tab>:qa &Wyj¶cie<Tab>:qa -menutrans Open\ Tab\.\.\.<Tab>:tabnew Otwórz\ &kartê\.\.\.<Tab>:tabnew - -" Edit menu -menutrans &Edit &Edycja -menutrans &Undo<Tab>u &Cofnij<Tab>u -menutrans &Redo<Tab>^R &Ponów<Tab>^R -menutrans Rep&eat<Tab>\. P&owtórz<Tab>\. -menutrans Cu&t<Tab>"+x W&ytnij<Tab>"+x -menutrans &Copy<Tab>"+y &Kopiuj<Tab>"+y -menutrans &Paste<Tab>"+gP &Wklej<Tab>"+gP -menutrans Put\ &Before<Tab>[p Wstaw\ p&rzed<Tab>[p -menutrans Put\ &After<Tab>]p Wstaw\ p&o<Tab>]p -menutrans &Select\ All<Tab>ggVG Z&aznacz\ ca³o¶æ<Tab>ggVG -menutrans &Find\.\.\. &Szukaj\.\.\. -menutrans &Find<Tab>/ &Szukaj<Tab>/ -menutrans Find\ and\ Rep&lace\.\.\. &Zamieñ\.\.\. -menutrans Find\ and\ Rep&lace<Tab>:%s &Zamieñ<Tab>:%s -menutrans Find\ and\ Rep&lace &Zamieñ -menutrans Find\ and\ Rep&lace<Tab>:s &Zamieñ<Tab>:s -menutrans Options\.\.\. Opcje\.\.\. -menutrans Settings\ &Window Ustawienia -menutrans &Global\ Settings Ustawienia\ &globalne -menutrans Startup\ &Settings Ustawienia\ &startowe -menutrans F&ile\ Settings Ustawienia\ dla\ pliku -menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! &Numerowanie\ wierszy<Tab>:set\ nu! -menutrans Toggle\ &List\ Mode<Tab>:set\ list! Tryb\ &listowania<Tab>:set\ list! -menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! Za&wijanie\ wierszy<Tab>:set\ wrap! -menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! £amanie\ wie&rsza<Tab>:set\ lbr! -menutrans Toggle\ &expand-tab<Tab>:set\ et! Rozwijani&e\ tabulatorów<Tab>:set\ et! -menutrans Toggle\ &auto-indent<Tab>:set\ ai! &Automatyczne\ wciêcia<Tab>:set\ ai! -menutrans Toggle\ &C-indenting<Tab>:set\ cin! Wciêcia\ &C<Tab>:set\ cin! -menutrans &Shiftwidth &Szeroko¶æ\ wciêcia -menutrans Te&xt\ Width\.\.\. D³ugo¶æ\ linii\.\.\. -menutrans &File\ Format\.\.\. &Format\ pliku\.\.\. -menutrans Soft\ &Tabstop Rozmiar\ &tabulacji -menutrans C&olor\ Scheme Zestawy\ kolorów -menutrans &Keymap Uk³ady\ klawiatury -menutrans None ¿aden -menutrans accents akcenty -menutrans hebrew hebrajski -menutrans hebrewp hebrajski\ p -menutrans russian-jcuken rosyjski-jcuken -menutrans russian-jcukenwin rosyjski-jcukenwin - -menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! Podkre¶lanie\ &wzorców<Tab>:set\ hls! - -menutrans Toggle\ &Ignore-case<Tab>:set\ ic! &Ignorowanie\ wielko¶ci<Tab>:set\ ic! -menutrans Toggle\ &Showmatch<Tab>:set\ sm! &Pokazywanie\ pasuj±cych<Tab>:set\ sm! - -menutrans &Context\ lines Wiersze\ &kontekstowe -menutrans &Virtual\ Edit Obróbka\ &wirtualna - -menutrans Never Nigdy -menutrans Block\ Selection Zaznaczanie\ zakresu -menutrans Insert\ mode Tryb\ wprowadzania -menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Tryb\ zg&odno¶ci\ z\ Vi<Tab>:set\ cp! -menutrans Block\ and\ Insert Zakres\ i\ wprowadzanie -menutrans Always Zawsze - -menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Tryb\ wprowadzania<Tab>:set\ im! -menutrans Search\ &Path\.\.\. Scie¿ka\ poszukiwania\.\.\. -menutrans Ta&g\ Files\.\.\. Pliki\ tagów\.\.\. - - -" -" GUI options -menutrans Toggle\ &Toolbar Pasek\ narzêdzi -menutrans Toggle\ &Bottom\ Scrollbar Dolny\ przewijacz -menutrans Toggle\ &Left\ Scrollbar &Lewy\ przewijacz -menutrans Toggle\ &Right\ Scrollbar P&rawy\ przewijacz - -" Programming menu -menutrans &Tools &Narzêdzia -menutrans &Jump\ to\ this\ tag<Tab>g^] &Skocz\ do\ taga<Tab>g^] -menutrans Jump\ &back<Tab>^T Skok\ w\ &ty³<Tab>^T -menutrans Build\ &Tags\ File &Twórz\ plik\ tagów -" Spelling -menutrans &Spelling Pi&sownia -menutrans &Spell\ Check\ On W³±cz -menutrans Spell\ Check\ &Off Wy³±cz -menutrans To\ &Next\ error<Tab>]s Do\ &nastêpnego\ b³êdu<Tab>]s -menutrans To\ &Previous\ error<Tab>[s Do\ &poprzedniego\ b³êdu<Tab>[s -menutrans Suggest\ &Corrections<Tab>z= Sugestie\ poprawek<Tab>z= -menutrans &Repeat\ correction<Tab>:spellrepall Powtó&z\ poprawkê<Tab>:spellrepall -menutrans Set\ language\ to\ "en" Ustaw\ jêzyk\ na\ "en" -menutrans Set\ language\ to\ "en_au" Ustaw\ jêzyk\ na\ "en_au" -menutrans Set\ language\ to\ "en_ca" Ustaw\ jêzyk\ na\ "en_ca" -menutrans Set\ language\ to\ "en_gb" Ustaw\ jêzyk\ na\ "en_gb" -menutrans Set\ language\ to\ "en_nz" Ustaw\ jêzyk\ na\ "en_nz" -menutrans Set\ language\ to\ "en_us" Ustaw\ jêzyk\ na\ "en_us" -menutrans Set\ language\ to\ "pl" Ustaw\ jêzyk\ na\ "pl" -menutrans &Find\ More\ Languages &Znajd¼\ wiêcej\ jêzyków - -" Folding -menutrans &Folding &Zwijanie -menutrans &Enable/Disable\ folds<Tab>zi &Zwiñ/rozwiñ<Tab>zi -menutrans &View\ Cursor\ Line<Tab>zv &Linia\ kursora<Tab>zv -menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx &Tylko\ linia\ kursora<Tab>zMzx -menutrans C&lose\ more\ folds<Tab>zm Zwiñ\ wiêcej<Tab>zm -menutrans &Close\ all\ folds<Tab>zM Z&wiñ\ wszystkie<Tab>zM -menutrans &Open\ all\ folds<Tab>zR Rozwiñ\ wszystkie<Tab>zR -menutrans O&pen\ more\ folds<Tab>zr R&ozwiñ\ wiêcej<Tab>zr - -menutrans Create\ &Fold<Tab>zf T&wórz\ zawiniêcie<Tab>zf -menutrans &Delete\ Fold<Tab>zd U&suñ\ zawiniêcie<Tab>zd -menutrans Delete\ &All\ Folds<Tab>zD &Usuñ\ wszystkie\ zawiniêcia<Tab>zD -menutrans Fold\ column\ &width Szeroko¶æ\ kolumny\ za&winiêæ -menutrans Fold\ Met&hod Me&toda\ zawijania -menutrans M&anual &Rêcznie -menutrans I&ndent W&ciêcie -menutrans E&xpression W&yrazenie -menutrans S&yntax S&k³adnia -menutrans Ma&rker Zn&acznik - -" Diff -menutrans &Update &Od¶wie¿ -menutrans &Get\ Block &Pobierz\ blok -menutrans &Put\ Block &Wstaw\ blok - -" Make and stuff... -menutrans &Make<Tab>:make M&ake<Tab>:make -menutrans &List\ Errors<Tab>:cl &Poka¿\ b³êdy<Tab>:cl -menutrans L&ist\ Messages<Tab>:cl! W&ylicz\ powiadomienia<Tab>:cl! -menutrans &Next\ Error<Tab>:cn &Nastêpny\ b³±d<Tab>:cn -menutrans &Previous\ Error<Tab>:cp &Poprzedni\ b³±d<Tab>:cp -menutrans &Older\ List<Tab>:cold &Starsza\ lista<Tab>:cold -menutrans N&ewer\ List<Tab>:cnew N&owsza\ lista<Tab>:cnew -menutrans Error\ &Window Okno\ komu&nikatów -menutrans &Update<Tab>:cwin Akt&ualizuj<Tab>:cwin -menutrans &Close<Tab>:cclose &Zamknij<Tab>:cclose -menutrans &Open<Tab>:copen &Otwórz<Tab>:copen - -menutrans Se&T\ Compiler U&staw\ kompilator -menutrans &Convert\ to\ HEX<Tab>:%!xxd Kody\ szesnastkowe<Tab>:%!xxd -menutrans Conve&rt\ back<Tab>:%!xxd\ -r Zwyk³y\ tekst<Tab>:%!xxd\ -r - -" Names for buffer menu. -menutrans &Buffers &Bufory -menutrans &Refresh\ menu Od¶wie¿ -menutrans Delete Skasuj -menutrans &Alternate &Zmieñ -menutrans &Next &Nastêpny -menutrans &Previous &Poprzedni -menutrans [No\ File] [Brak\ Pliku] - -" Window menu -menutrans &Window &Widoki -menutrans &New<Tab>^Wn &Nowy<Tab>^Wn -menutrans S&plit<Tab>^Ws Po&dziel<Tab>^Ws -menutrans Sp&lit\ To\ #<Tab>^W^^ P&odziel\ na\ #<Tab>^W^^ -menutrans Split\ &Vertically<Tab>^Wv Podziel\ pionowo<Tab>^Wv -menutrans Split\ File\ E&xplorer Otwórz\ mened¿er\ plików - -menutrans &Close<Tab>^Wc &Zamknij<Tab>^Wc -menutrans Close\ &Other(s)<Tab>^Wo Zamknij\ &inne<Tab>^Wo -menutrans Ne&xt<Tab>^Ww &Nastêpny<Tab>^Ww -menutrans P&revious<Tab>^WW &Poprzedni<Tab>^WW -menutrans &Equal\ Size<Tab>^W= &Wyrównaj\ wysoko¶ci<Tab>^W= -menutrans &Max\ Height<Tab>^W_ Z&maksymalizuj\ wysoko¶æ<Tab>^W_ -menutrans M&in\ Height<Tab>^W1_ Zminim&alizuj\ wysoko¶æ<Tab>^W1_ -menutrans Max\ Width<Tab>^W\| Maksymalna\ szeroko¶æ<Tab>^W\| -menutrans Min\ Width<Tab>^W1\| Minimalna\ szeroko¶æ<Tab>^W1\| -menutrans Max\ &Width<Tab>^W\| Zmaksymalizuj\ szeroko¶æ<Tab>^W\| -menutrans Min\ Widt&h<Tab>^W1\| Zminimalizuj\ szeroko¶æ<Tab>^W1\| -menutrans Move\ &To &Id¼\ do -menutrans &Top<Tab>^WK &Góra<Tab>^WK -menutrans &Bottom<Tab>^WJ &Dó³<Tab>^WJ -menutrans &Left\ side<Tab>^WH &Lewa\ strona<Tab>^WH -menutrans &Right\ side<Tab>^WL &Prawa\ strona<Tab>^WL -menutrans Rotate\ &Up<Tab>^WR Obróæ\ w\ &górê<Tab>^WR -menutrans Rotate\ &Down<Tab>^Wr Obróæ\ w\ &dó³<Tab>^Wr -menutrans Split\ &Vertically<Tab>^Wv &Podziel\ w\ poziomie<Tab>^Wv -menutrans Select\ Fo&nt\.\.\. Wybierz\ &czcionkê\.\.\. - -" The popup menu -menutrans &Undo &Cofnij -menutrans Cu&t W&ytnij -menutrans &Copy &Kopiuj -menutrans &Paste &Wklej -menutrans &Delete &Skasuj -menutrans Select\ Blockwise Zaznacz\ &blok -menutrans Select\ &Sentence Zaznacz\ &zdanie -menutrans Select\ Pa&ragraph Zaznacz\ aka&pit -menutrans Select\ &Word Zaznacz\ &s³owo -menutrans Select\ &Line Zaznacz\ w&iersz -menutrans Select\ &Block Zaznacz\ &blok -menutrans Select\ &All Zaznacz\ c&a³o¶æ -menutrans Input\ &Methods Wprowadza&nie - -" The GUI toolbar -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open Otwórz plik - tmenu ToolBar.Save Zapisz bie¿±cy plik - tmenu ToolBar.SaveAll Zapisz wszystkie pliki - tmenu ToolBar.Print Drukuj - tmenu ToolBar.Undo Cofnij - tmenu ToolBar.Redo Ponów - tmenu ToolBar.Cut Wytnij - tmenu ToolBar.Copy Skopiuj - tmenu ToolBar.Paste Wklej - tmenu ToolBar.Find Szukaj... - tmenu ToolBar.FindNext Szukaj nastêpnego - tmenu ToolBar.FindPrev Szukaj poprzedniego - tmenu ToolBar.Replace Szukaj i zamieniaj... - if 0 " disabled; These are in the Windows menu - tmenu ToolBar.New Nowy widok - tmenu ToolBar.WinSplit Podziel widok - tmenu ToolBar.WinMax Zmaksymalizuj widok - tmenu ToolBar.WinMin Zminimalizuj widok - tmenu ToolBar.WinClose Zamknij widok - endif - tmenu ToolBar.LoadSesn Za³aduj sesjê - tmenu ToolBar.SaveSesn Zachowaj bie¿±c± sesjê - tmenu ToolBar.RunScript Uruchom skrypt Vima - tmenu ToolBar.Make Wykonaj bie¿±cy projekt - tmenu ToolBar.Shell Otwórz pow³okê - tmenu ToolBar.RunCtags Twórz tagi w bie¿±cym katalogu - tmenu ToolBar.TagJump Skok do taga pod kursorem - tmenu ToolBar.Help Pomoc Vima - tmenu ToolBar.FindHelp Przeszukuj pomoc Vim-a - endfun -endif - -" Syntax menu -menutrans &Syntax &Sk³adnia -menutrans &Show\ filetypes\ in\ menu Poka¿\ typy\ &plików\ w\ menu -menutrans Set\ '&syntax'\ only Ustaw\ tylko\ '&syntax' -menutrans Set\ '&filetype'\ too Ustaw\ równie¿\ '&filetype' -menutrans &Off &Wy³±cz -menutrans &Manual &Rêcznie -menutrans A&utomatic A&utomatyczne -menutrans on/off\ for\ &This\ file w³±cz/w&y³±cz\ dla\ pliku -menutrans Co&lor\ test Test\ &kolorów -menutrans &Highlight\ test &Test\ pod¶wietlania -menutrans &Convert\ to\ HTML Przetwórz\ na\ &HTML - -" dialog texts -let menutrans_no_file = "[Brak pliku]" -let menutrans_help_dialog = "Wprowad¼ komendê lub s³owo, aby otrzymaæ pomoc o:\n\nPrzedrostek i_ oznacza komendê trybu Wprowadzania (np. i_CTRL-X)\nPrzedrostek c_ oznacza komendê edycji wiersza komend (np. c_<Del>)\nPrzedrostek ' oznacza nazwê opcji (np. 'shiftwidth')" -let g:menutrans_path_dialog = "Wprowad¼ ¶cie¿kê poszukiwania plików.\nProszê rozdzielaæ nazwy katalogów przecinkiem." -let g:menutrans_tags_dialog = "Podaj nazwy plików tagów.\nProszê rozdzielaæ nazwy przecinkiem." -let g:menutrans_textwidth_dialog = "Wprowad¼ now± szeroko¶æ tekstu (0 wy³±cza przewijanie): " -let g:menutrans_fileformat_dialog = "Wybierz format w którym ten plik ma byæ zapisany" -let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\n&Anuluj" diff --git a/share/vim/vim72/lang/menu_pl_pl.utf-8.vim b/share/vim/vim72/lang/menu_pl_pl.utf-8.vim deleted file mode 100644 index 42b164c8a8..0000000000 --- a/share/vim/vim72/lang/menu_pl_pl.utf-8.vim +++ /dev/null @@ -1,286 +0,0 @@ -" Menu Translations: Polish -" Maintainer: Mikolaj Machowski ( mikmach AT wp DOT pl ) -" Initial Translation: Marcin Dalecki <martin@dalecki.de> -" Last Change: 4 May 2006 - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 - -scriptencoding utf-8 - -" Help menu -menutrans &Help Po&moc -menutrans &Overview<Tab><F1> &Spis\ treści<Tab><F1> -menutrans &How-to\ links &Odnośniki\ JTZ -menutrans &Credits Po&dziękowania -menutrans &User\ Manual Podręcznik\ &użytkownika -menutrans Co&pying &Kopiowanie -menutrans &Version &Wersja -menutrans &About o\ &Programie -menutrans &Sponsor/Register &Sponsorowanie/Rejestracja -menutrans O&rphans Sie&roty - -" File menu -menutrans &File &Plik -menutrans &Open\.\.\.<Tab>:e &Otwórz\.\.\.<Tab>:e -menutrans Sp&lit-Open\.\.\.<Tab>:sp Otwórz\ z\ &podziałem\.\.\.<Tab>:sp -menutrans &New<Tab>:enew &Nowy<Tab>:enew -menutrans &Close<Tab>:close &Zamknij<Tab>:close -menutrans &Save<Tab>:w Za&pisz<Tab>:w -menutrans Save\ &As\.\.\.<Tab>:sav Zapisz\ &jako\.\.\.<Tab>:sav -menutrans Split\ &Diff\ with\.\.\. Podziel\ na\ diff-a\ między\.\.\. -menutrans Split\ Patched\ &By\.\.\. Podziel\ łatane\ przez\.\.\. -menutrans &Print &Drukuj -menutrans Sa&ve-Exit<Tab>:wqa W&yjście\ z\ zapisem<Tab>:wqa -menutrans E&xit<Tab>:qa &Wyjście<Tab>:qa -menutrans Open\ Tab\.\.\.<Tab>:tabnew Otwórz\ &kartę\.\.\.<Tab>:tabnew - -" Edit menu -menutrans &Edit &Edycja -menutrans &Undo<Tab>u &Cofnij<Tab>u -menutrans &Redo<Tab>^R &Ponów<Tab>^R -menutrans Rep&eat<Tab>\. P&owtórz<Tab>\. -menutrans Cu&t<Tab>"+x W&ytnij<Tab>"+x -menutrans &Copy<Tab>"+y &Kopiuj<Tab>"+y -menutrans &Paste<Tab>"+gP &Wklej<Tab>"+gP -menutrans Put\ &Before<Tab>[p Wstaw\ p&rzed<Tab>[p -menutrans Put\ &After<Tab>]p Wstaw\ p&o<Tab>]p -menutrans &Select\ All<Tab>ggVG Z&aznacz\ całość<Tab>ggVG -menutrans &Find\.\.\. &Szukaj\.\.\. -menutrans &Find<Tab>/ &Szukaj<Tab>/ -menutrans Find\ and\ Rep&lace\.\.\. &Zamień\.\.\. -menutrans Find\ and\ Rep&lace<Tab>:%s &Zamień<Tab>:%s -menutrans Find\ and\ Rep&lace &Zamień -menutrans Find\ and\ Rep&lace<Tab>:s &Zamień<Tab>:s -menutrans Options\.\.\. Opcje\.\.\. -menutrans Settings\ &Window Ustawienia -menutrans &Global\ Settings Ustawienia\ &globalne -menutrans Startup\ &Settings Ustawienia\ &startowe -menutrans F&ile\ Settings Ustawienia\ dla\ pliku -menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! &Numerowanie\ wierszy<Tab>:set\ nu! -menutrans Toggle\ &List\ Mode<Tab>:set\ list! Tryb\ &listowania<Tab>:set\ list! -menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! Za&wijanie\ wierszy<Tab>:set\ wrap! -menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! Łamanie\ wie&rsza<Tab>:set\ lbr! -menutrans Toggle\ &expand-tab<Tab>:set\ et! Rozwijani&e\ tabulatorów<Tab>:set\ et! -menutrans Toggle\ &auto-indent<Tab>:set\ ai! &Automatyczne\ wcięcia<Tab>:set\ ai! -menutrans Toggle\ &C-indenting<Tab>:set\ cin! Wcięcia\ &C<Tab>:set\ cin! -menutrans &Shiftwidth &Szerokość\ wcięcia -menutrans Te&xt\ Width\.\.\. Długość\ linii\.\.\. -menutrans &File\ Format\.\.\. &Format\ pliku\.\.\. -menutrans Soft\ &Tabstop Rozmiar\ &tabulacji -menutrans C&olor\ Scheme Zestawy\ kolorów -menutrans &Keymap Układy\ klawiatury -menutrans None żaden -menutrans accents akcenty -menutrans hebrew hebrajski -menutrans hebrewp hebrajski\ p -menutrans russian-jcuken rosyjski-jcuken -menutrans russian-jcukenwin rosyjski-jcukenwin - -menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! Podkreślanie\ &wzorców<Tab>:set\ hls! - -menutrans Toggle\ &Ignore-case<Tab>:set\ ic! &Ignorowanie\ wielkości<Tab>:set\ ic! -menutrans Toggle\ &Showmatch<Tab>:set\ sm! &Pokazywanie\ pasujących<Tab>:set\ sm! - -menutrans &Context\ lines Wiersze\ &kontekstowe -menutrans &Virtual\ Edit Obróbka\ &wirtualna - -menutrans Never Nigdy -menutrans Block\ Selection Zaznaczanie\ zakresu -menutrans Insert\ mode Tryb\ wprowadzania -menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Tryb\ zg&odności\ z\ Vi<Tab>:set\ cp! -menutrans Block\ and\ Insert Zakres\ i\ wprowadzanie -menutrans Always Zawsze - -menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Tryb\ wprowadzania<Tab>:set\ im! -menutrans Search\ &Path\.\.\. Scieżka\ poszukiwania\.\.\. -menutrans Ta&g\ Files\.\.\. Pliki\ tagów\.\.\. - - -" -" GUI options -menutrans Toggle\ &Toolbar Pasek\ narzędzi -menutrans Toggle\ &Bottom\ Scrollbar Dolny\ przewijacz -menutrans Toggle\ &Left\ Scrollbar &Lewy\ przewijacz -menutrans Toggle\ &Right\ Scrollbar P&rawy\ przewijacz - -" Programming menu -menutrans &Tools &Narzędzia -menutrans &Jump\ to\ this\ tag<Tab>g^] &Skocz\ do\ taga<Tab>g^] -menutrans Jump\ &back<Tab>^T Skok\ w\ &tył<Tab>^T -menutrans Build\ &Tags\ File &Twórz\ plik\ tagów -" Spelling -menutrans &Spelling Pi&sownia -menutrans &Spell\ Check\ On Włącz -menutrans Spell\ Check\ &Off Wyłącz -menutrans To\ &Next\ error<Tab>]s Do\ &następnego\ błędu<Tab>]s -menutrans To\ &Previous\ error<Tab>[s Do\ &poprzedniego\ błędu<Tab>[s -menutrans Suggest\ &Corrections<Tab>z= Sugestie\ poprawek<Tab>z= -menutrans &Repeat\ correction<Tab>:spellrepall Powtó&z\ poprawkę<Tab>:spellrepall -menutrans Set\ language\ to\ "en" Ustaw\ język\ na\ "en" -menutrans Set\ language\ to\ "en_au" Ustaw\ język\ na\ "en_au" -menutrans Set\ language\ to\ "en_ca" Ustaw\ język\ na\ "en_ca" -menutrans Set\ language\ to\ "en_gb" Ustaw\ język\ na\ "en_gb" -menutrans Set\ language\ to\ "en_nz" Ustaw\ język\ na\ "en_nz" -menutrans Set\ language\ to\ "en_us" Ustaw\ język\ na\ "en_us" -menutrans Set\ language\ to\ "pl" Ustaw\ język\ na\ "pl" -menutrans &Find\ More\ Languages &Znajdź\ więcej\ języków - -" Folding -menutrans &Folding &Zwijanie -menutrans &Enable/Disable\ folds<Tab>zi &Zwiń/rozwiń<Tab>zi -menutrans &View\ Cursor\ Line<Tab>zv &Linia\ kursora<Tab>zv -menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx &Tylko\ linia\ kursora<Tab>zMzx -menutrans C&lose\ more\ folds<Tab>zm Zwiń\ więcej<Tab>zm -menutrans &Close\ all\ folds<Tab>zM Z&wiń\ wszystkie<Tab>zM -menutrans &Open\ all\ folds<Tab>zR Rozwiń\ wszystkie<Tab>zR -menutrans O&pen\ more\ folds<Tab>zr R&ozwiń\ więcej<Tab>zr - -menutrans Create\ &Fold<Tab>zf T&wórz\ zawinięcie<Tab>zf -menutrans &Delete\ Fold<Tab>zd U&suń\ zawinięcie<Tab>zd -menutrans Delete\ &All\ Folds<Tab>zD &Usuń\ wszystkie\ zawinięcia<Tab>zD -menutrans Fold\ column\ &width Szerokość\ kolumny\ za&winięć -menutrans Fold\ Met&hod Me&toda\ zawijania -menutrans M&anual &Ręcznie -menutrans I&ndent W&cięcie -menutrans E&xpression W&yrazenie -menutrans S&yntax S&kładnia -menutrans Ma&rker Zn&acznik - -" Diff -menutrans &Update &Odśwież -menutrans &Get\ Block &Pobierz\ blok -menutrans &Put\ Block &Wstaw\ blok - -" Make and stuff... -menutrans &Make<Tab>:make M&ake<Tab>:make -menutrans &List\ Errors<Tab>:cl &Pokaż\ błędy<Tab>:cl -menutrans L&ist\ Messages<Tab>:cl! W&ylicz\ powiadomienia<Tab>:cl! -menutrans &Next\ Error<Tab>:cn &Następny\ błąd<Tab>:cn -menutrans &Previous\ Error<Tab>:cp &Poprzedni\ błąd<Tab>:cp -menutrans &Older\ List<Tab>:cold &Starsza\ lista<Tab>:cold -menutrans N&ewer\ List<Tab>:cnew N&owsza\ lista<Tab>:cnew -menutrans Error\ &Window Okno\ komu&nikatów -menutrans &Update<Tab>:cwin Akt&ualizuj<Tab>:cwin -menutrans &Close<Tab>:cclose &Zamknij<Tab>:cclose -menutrans &Open<Tab>:copen &Otwórz<Tab>:copen - -menutrans Se&T\ Compiler U&staw\ kompilator -menutrans &Convert\ to\ HEX<Tab>:%!xxd Kody\ szesnastkowe<Tab>:%!xxd -menutrans Conve&rt\ back<Tab>:%!xxd\ -r Zwykły\ tekst<Tab>:%!xxd\ -r - -" Names for buffer menu. -menutrans &Buffers &Bufory -menutrans &Refresh\ menu Odśwież -menutrans Delete Skasuj -menutrans &Alternate &Zmień -menutrans &Next &Następny -menutrans &Previous &Poprzedni -menutrans [No\ File] [Brak\ Pliku] - -" Window menu -menutrans &Window &Widoki -menutrans &New<Tab>^Wn &Nowy<Tab>^Wn -menutrans S&plit<Tab>^Ws Po&dziel<Tab>^Ws -menutrans Sp&lit\ To\ #<Tab>^W^^ P&odziel\ na\ #<Tab>^W^^ -menutrans Split\ &Vertically<Tab>^Wv Podziel\ pionowo<Tab>^Wv -menutrans Split\ File\ E&xplorer Otwórz\ menedżer\ plików - -menutrans &Close<Tab>^Wc &Zamknij<Tab>^Wc -menutrans Close\ &Other(s)<Tab>^Wo Zamknij\ &inne<Tab>^Wo -menutrans Ne&xt<Tab>^Ww &Następny<Tab>^Ww -menutrans P&revious<Tab>^WW &Poprzedni<Tab>^WW -menutrans &Equal\ Size<Tab>^W= &Wyrównaj\ wysokości<Tab>^W= -menutrans &Max\ Height<Tab>^W_ Z&maksymalizuj\ wysokość<Tab>^W_ -menutrans M&in\ Height<Tab>^W1_ Zminim&alizuj\ wysokość<Tab>^W1_ -menutrans Max\ Width<Tab>^W\| Maksymalna\ szerokość<Tab>^W\| -menutrans Min\ Width<Tab>^W1\| Minimalna\ szerokość<Tab>^W1\| -menutrans Max\ &Width<Tab>^W\| Zmaksymalizuj\ szerokość<Tab>^W\| -menutrans Min\ Widt&h<Tab>^W1\| Zminimalizuj\ szerokość<Tab>^W1\| -menutrans Move\ &To &Idź\ do -menutrans &Top<Tab>^WK &Góra<Tab>^WK -menutrans &Bottom<Tab>^WJ &Dół<Tab>^WJ -menutrans &Left\ side<Tab>^WH &Lewa\ strona<Tab>^WH -menutrans &Right\ side<Tab>^WL &Prawa\ strona<Tab>^WL -menutrans Rotate\ &Up<Tab>^WR Obróć\ w\ &górę<Tab>^WR -menutrans Rotate\ &Down<Tab>^Wr Obróć\ w\ &dół<Tab>^Wr -menutrans Split\ &Vertically<Tab>^Wv &Podziel\ w\ poziomie<Tab>^Wv -menutrans Select\ Fo&nt\.\.\. Wybierz\ &czcionkę\.\.\. - -" The popup menu -menutrans &Undo &Cofnij -menutrans Cu&t W&ytnij -menutrans &Copy &Kopiuj -menutrans &Paste &Wklej -menutrans &Delete &Skasuj -menutrans Select\ Blockwise Zaznacz\ &blok -menutrans Select\ &Sentence Zaznacz\ &zdanie -menutrans Select\ Pa&ragraph Zaznacz\ aka&pit -menutrans Select\ &Word Zaznacz\ &słowo -menutrans Select\ &Line Zaznacz\ w&iersz -menutrans Select\ &Block Zaznacz\ &blok -menutrans Select\ &All Zaznacz\ c&ałość -menutrans Input\ &Methods Wprowadza&nie - -" The GUI toolbar -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open Otwórz plik - tmenu ToolBar.Save Zapisz bieżący plik - tmenu ToolBar.SaveAll Zapisz wszystkie pliki - tmenu ToolBar.Print Drukuj - tmenu ToolBar.Undo Cofnij - tmenu ToolBar.Redo Ponów - tmenu ToolBar.Cut Wytnij - tmenu ToolBar.Copy Skopiuj - tmenu ToolBar.Paste Wklej - tmenu ToolBar.Find Szukaj... - tmenu ToolBar.FindNext Szukaj następnego - tmenu ToolBar.FindPrev Szukaj poprzedniego - tmenu ToolBar.Replace Szukaj i zamieniaj... - if 0 " disabled; These are in the Windows menu - tmenu ToolBar.New Nowy widok - tmenu ToolBar.WinSplit Podziel widok - tmenu ToolBar.WinMax Zmaksymalizuj widok - tmenu ToolBar.WinMin Zminimalizuj widok - tmenu ToolBar.WinClose Zamknij widok - endif - tmenu ToolBar.LoadSesn Załaduj sesję - tmenu ToolBar.SaveSesn Zachowaj bieżącą sesję - tmenu ToolBar.RunScript Uruchom skrypt Vima - tmenu ToolBar.Make Wykonaj bieżący projekt - tmenu ToolBar.Shell Otwórz powłokę - tmenu ToolBar.RunCtags Twórz tagi w bieżącym katalogu - tmenu ToolBar.TagJump Skok do taga pod kursorem - tmenu ToolBar.Help Pomoc Vima - tmenu ToolBar.FindHelp Przeszukuj pomoc Vim-a - endfun -endif - -" Syntax menu -menutrans &Syntax &Składnia -menutrans &Show\ filetypes\ in\ menu Pokaż\ typy\ &plików\ w\ menu -menutrans Set\ '&syntax'\ only Ustaw\ tylko\ '&syntax' -menutrans Set\ '&filetype'\ too Ustaw\ również\ '&filetype' -menutrans &Off &Wyłącz -menutrans &Manual &Ręcznie -menutrans A&utomatic A&utomatyczne -menutrans on/off\ for\ &This\ file włącz/w&yłącz\ dla\ pliku -menutrans Co&lor\ test Test\ &kolorów -menutrans &Highlight\ test &Test\ podświetlania -menutrans &Convert\ to\ HTML Przetwórz\ na\ &HTML - -" dialog texts -let menutrans_no_file = "[Brak pliku]" -let menutrans_help_dialog = "Wprowadź komendę lub słowo, aby otrzymać pomoc o:\n\nPrzedrostek i_ oznacza komendę trybu Wprowadzania (np. i_CTRL-X)\nPrzedrostek c_ oznacza komendę edycji wiersza komend (np. c_<Del>)\nPrzedrostek ' oznacza nazwę opcji (np. 'shiftwidth')" -let g:menutrans_path_dialog = "Wprowadź ścieżkę poszukiwania plików.\nProszę rozdzielać nazwy katalogów przecinkiem." -let g:menutrans_tags_dialog = "Podaj nazwy plików tagów.\nProszę rozdzielać nazwy przecinkiem." -let g:menutrans_textwidth_dialog = "Wprowadź nową szerokość tekstu (0 wyłącza przewijanie): " -let g:menutrans_fileformat_dialog = "Wybierz format w którym ten plik ma być zapisany" -let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\n&Anuluj" diff --git a/share/vim/vim72/lang/menu_polish_poland.1250.vim b/share/vim/vim72/lang/menu_polish_poland.1250.vim deleted file mode 100644 index 9900f91c98..0000000000 --- a/share/vim/vim72/lang/menu_polish_poland.1250.vim +++ /dev/null @@ -1,286 +0,0 @@ -" Menu Translations: Polish -" Maintainer: Mikolaj Machowski ( mikmach AT wp DOT pl ) -" Initial Translation: Marcin Dalecki <martin@dalecki.de> -" Last Change: 4 May 2006 - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 - -scriptencoding cp1250 - -" Help menu -menutrans &Help Po&moc -menutrans &Overview<Tab><F1> &Spis\ treœci<Tab><F1> -menutrans &How-to\ links &Odnoœniki\ JTZ -menutrans &Credits Po&dziêkowania -menutrans &User\ Manual Podrêcznik\ &u¿ytkownika -menutrans Co&pying &Kopiowanie -menutrans &Version &Wersja -menutrans &About o\ &Programie -menutrans &Sponsor/Register &Sponsorowanie/Rejestracja -menutrans O&rphans Sie&roty - -" File menu -menutrans &File &Plik -menutrans &Open\.\.\.<Tab>:e &Otwórz\.\.\.<Tab>:e -menutrans Sp&lit-Open\.\.\.<Tab>:sp Otwórz\ z\ &podzia³em\.\.\.<Tab>:sp -menutrans &New<Tab>:enew &Nowy<Tab>:enew -menutrans &Close<Tab>:close &Zamknij<Tab>:close -menutrans &Save<Tab>:w Za&pisz<Tab>:w -menutrans Save\ &As\.\.\.<Tab>:sav Zapisz\ &jako\.\.\.<Tab>:sav -menutrans Split\ &Diff\ with\.\.\. Podziel\ na\ diff-a\ miêdzy\.\.\. -menutrans Split\ Patched\ &By\.\.\. Podziel\ ³atane\ przez\.\.\. -menutrans &Print &Drukuj -menutrans Sa&ve-Exit<Tab>:wqa W&yjœcie\ z\ zapisem<Tab>:wqa -menutrans E&xit<Tab>:qa &Wyjœcie<Tab>:qa -menutrans Open\ Tab\.\.\.<Tab>:tabnew Otwórz\ &kartê\.\.\.<Tab>:tabnew - -" Edit menu -menutrans &Edit &Edycja -menutrans &Undo<Tab>u &Cofnij<Tab>u -menutrans &Redo<Tab>^R &Ponów<Tab>^R -menutrans Rep&eat<Tab>\. P&owtórz<Tab>\. -menutrans Cu&t<Tab>"+x W&ytnij<Tab>"+x -menutrans &Copy<Tab>"+y &Kopiuj<Tab>"+y -menutrans &Paste<Tab>"+gP &Wklej<Tab>"+gP -menutrans Put\ &Before<Tab>[p Wstaw\ p&rzed<Tab>[p -menutrans Put\ &After<Tab>]p Wstaw\ p&o<Tab>]p -menutrans &Select\ All<Tab>ggVG Z&aznacz\ ca³oœæ<Tab>ggVG -menutrans &Find\.\.\. &Szukaj\.\.\. -menutrans &Find<Tab>/ &Szukaj<Tab>/ -menutrans Find\ and\ Rep&lace\.\.\. &Zamieñ\.\.\. -menutrans Find\ and\ Rep&lace<Tab>:%s &Zamieñ<Tab>:%s -menutrans Find\ and\ Rep&lace &Zamieñ -menutrans Find\ and\ Rep&lace<Tab>:s &Zamieñ<Tab>:s -menutrans Options\.\.\. Opcje\.\.\. -menutrans Settings\ &Window Ustawienia -menutrans &Global\ Settings Ustawienia\ &globalne -menutrans Startup\ &Settings Ustawienia\ &startowe -menutrans F&ile\ Settings Ustawienia\ dla\ pliku -menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! &Numerowanie\ wierszy<Tab>:set\ nu! -menutrans Toggle\ &List\ Mode<Tab>:set\ list! Tryb\ &listowania<Tab>:set\ list! -menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! Za&wijanie\ wierszy<Tab>:set\ wrap! -menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! £amanie\ wie&rsza<Tab>:set\ lbr! -menutrans Toggle\ &expand-tab<Tab>:set\ et! Rozwijani&e\ tabulatorów<Tab>:set\ et! -menutrans Toggle\ &auto-indent<Tab>:set\ ai! &Automatyczne\ wciêcia<Tab>:set\ ai! -menutrans Toggle\ &C-indenting<Tab>:set\ cin! Wciêcia\ &C<Tab>:set\ cin! -menutrans &Shiftwidth &Szerokoœæ\ wciêcia -menutrans Te&xt\ Width\.\.\. D³ugoœæ\ linii\.\.\. -menutrans &File\ Format\.\.\. &Format\ pliku\.\.\. -menutrans Soft\ &Tabstop Rozmiar\ &tabulacji -menutrans C&olor\ Scheme Zestawy\ kolorów -menutrans &Keymap Uk³ady\ klawiatury -menutrans None ¿aden -menutrans accents akcenty -menutrans hebrew hebrajski -menutrans hebrewp hebrajski\ p -menutrans russian-jcuken rosyjski-jcuken -menutrans russian-jcukenwin rosyjski-jcukenwin - -menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! Podkreœlanie\ &wzorców<Tab>:set\ hls! - -menutrans Toggle\ &Ignore-case<Tab>:set\ ic! &Ignorowanie\ wielkoœci<Tab>:set\ ic! -menutrans Toggle\ &Showmatch<Tab>:set\ sm! &Pokazywanie\ pasuj¹cych<Tab>:set\ sm! - -menutrans &Context\ lines Wiersze\ &kontekstowe -menutrans &Virtual\ Edit Obróbka\ &wirtualna - -menutrans Never Nigdy -menutrans Block\ Selection Zaznaczanie\ zakresu -menutrans Insert\ mode Tryb\ wprowadzania -menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Tryb\ zg&odnoœci\ z\ Vi<Tab>:set\ cp! -menutrans Block\ and\ Insert Zakres\ i\ wprowadzanie -menutrans Always Zawsze - -menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Tryb\ wprowadzania<Tab>:set\ im! -menutrans Search\ &Path\.\.\. Scie¿ka\ poszukiwania\.\.\. -menutrans Ta&g\ Files\.\.\. Pliki\ tagów\.\.\. - - -" -" GUI options -menutrans Toggle\ &Toolbar Pasek\ narzêdzi -menutrans Toggle\ &Bottom\ Scrollbar Dolny\ przewijacz -menutrans Toggle\ &Left\ Scrollbar &Lewy\ przewijacz -menutrans Toggle\ &Right\ Scrollbar P&rawy\ przewijacz - -" Programming menu -menutrans &Tools &Narzêdzia -menutrans &Jump\ to\ this\ tag<Tab>g^] &Skocz\ do\ taga<Tab>g^] -menutrans Jump\ &back<Tab>^T Skok\ w\ &ty³<Tab>^T -menutrans Build\ &Tags\ File &Twórz\ plik\ tagów -" Spelling -menutrans &Spelling Pi&sownia -menutrans &Spell\ Check\ On W³¹cz -menutrans Spell\ Check\ &Off Wy³¹cz -menutrans To\ &Next\ error<Tab>]s Do\ &nastêpnego\ b³êdu<Tab>]s -menutrans To\ &Previous\ error<Tab>[s Do\ &poprzedniego\ b³êdu<Tab>[s -menutrans Suggest\ &Corrections<Tab>z= Sugestie\ poprawek<Tab>z= -menutrans &Repeat\ correction<Tab>:spellrepall Powtó&z\ poprawkê<Tab>:spellrepall -menutrans Set\ language\ to\ "en" Ustaw\ jêzyk\ na\ "en" -menutrans Set\ language\ to\ "en_au" Ustaw\ jêzyk\ na\ "en_au" -menutrans Set\ language\ to\ "en_ca" Ustaw\ jêzyk\ na\ "en_ca" -menutrans Set\ language\ to\ "en_gb" Ustaw\ jêzyk\ na\ "en_gb" -menutrans Set\ language\ to\ "en_nz" Ustaw\ jêzyk\ na\ "en_nz" -menutrans Set\ language\ to\ "en_us" Ustaw\ jêzyk\ na\ "en_us" -menutrans Set\ language\ to\ "pl" Ustaw\ jêzyk\ na\ "pl" -menutrans &Find\ More\ Languages &ZnajdŸ\ wiêcej\ jêzyków - -" Folding -menutrans &Folding &Zwijanie -menutrans &Enable/Disable\ folds<Tab>zi &Zwiñ/rozwiñ<Tab>zi -menutrans &View\ Cursor\ Line<Tab>zv &Linia\ kursora<Tab>zv -menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx &Tylko\ linia\ kursora<Tab>zMzx -menutrans C&lose\ more\ folds<Tab>zm Zwiñ\ wiêcej<Tab>zm -menutrans &Close\ all\ folds<Tab>zM Z&wiñ\ wszystkie<Tab>zM -menutrans &Open\ all\ folds<Tab>zR Rozwiñ\ wszystkie<Tab>zR -menutrans O&pen\ more\ folds<Tab>zr R&ozwiñ\ wiêcej<Tab>zr - -menutrans Create\ &Fold<Tab>zf T&wórz\ zawiniêcie<Tab>zf -menutrans &Delete\ Fold<Tab>zd U&suñ\ zawiniêcie<Tab>zd -menutrans Delete\ &All\ Folds<Tab>zD &Usuñ\ wszystkie\ zawiniêcia<Tab>zD -menutrans Fold\ column\ &width Szerokoœæ\ kolumny\ za&winiêæ -menutrans Fold\ Met&hod Me&toda\ zawijania -menutrans M&anual &Rêcznie -menutrans I&ndent W&ciêcie -menutrans E&xpression W&yrazenie -menutrans S&yntax S&k³adnia -menutrans Ma&rker Zn&acznik - -" Diff -menutrans &Update &Odœwie¿ -menutrans &Get\ Block &Pobierz\ blok -menutrans &Put\ Block &Wstaw\ blok - -" Make and stuff... -menutrans &Make<Tab>:make M&ake<Tab>:make -menutrans &List\ Errors<Tab>:cl &Poka¿\ b³êdy<Tab>:cl -menutrans L&ist\ Messages<Tab>:cl! W&ylicz\ powiadomienia<Tab>:cl! -menutrans &Next\ Error<Tab>:cn &Nastêpny\ b³¹d<Tab>:cn -menutrans &Previous\ Error<Tab>:cp &Poprzedni\ b³¹d<Tab>:cp -menutrans &Older\ List<Tab>:cold &Starsza\ lista<Tab>:cold -menutrans N&ewer\ List<Tab>:cnew N&owsza\ lista<Tab>:cnew -menutrans Error\ &Window Okno\ komu&nikatów -menutrans &Update<Tab>:cwin Akt&ualizuj<Tab>:cwin -menutrans &Close<Tab>:cclose &Zamknij<Tab>:cclose -menutrans &Open<Tab>:copen &Otwórz<Tab>:copen - -menutrans Se&T\ Compiler U&staw\ kompilator -menutrans &Convert\ to\ HEX<Tab>:%!xxd Kody\ szesnastkowe<Tab>:%!xxd -menutrans Conve&rt\ back<Tab>:%!xxd\ -r Zwyk³y\ tekst<Tab>:%!xxd\ -r - -" Names for buffer menu. -menutrans &Buffers &Bufory -menutrans &Refresh\ menu Odœwie¿ -menutrans Delete Skasuj -menutrans &Alternate &Zmieñ -menutrans &Next &Nastêpny -menutrans &Previous &Poprzedni -menutrans [No\ File] [Brak\ Pliku] - -" Window menu -menutrans &Window &Widoki -menutrans &New<Tab>^Wn &Nowy<Tab>^Wn -menutrans S&plit<Tab>^Ws Po&dziel<Tab>^Ws -menutrans Sp&lit\ To\ #<Tab>^W^^ P&odziel\ na\ #<Tab>^W^^ -menutrans Split\ &Vertically<Tab>^Wv Podziel\ pionowo<Tab>^Wv -menutrans Split\ File\ E&xplorer Otwórz\ mened¿er\ plików - -menutrans &Close<Tab>^Wc &Zamknij<Tab>^Wc -menutrans Close\ &Other(s)<Tab>^Wo Zamknij\ &inne<Tab>^Wo -menutrans Ne&xt<Tab>^Ww &Nastêpny<Tab>^Ww -menutrans P&revious<Tab>^WW &Poprzedni<Tab>^WW -menutrans &Equal\ Size<Tab>^W= &Wyrównaj\ wysokoœci<Tab>^W= -menutrans &Max\ Height<Tab>^W_ Z&maksymalizuj\ wysokoœæ<Tab>^W_ -menutrans M&in\ Height<Tab>^W1_ Zminim&alizuj\ wysokoœæ<Tab>^W1_ -menutrans Max\ Width<Tab>^W\| Maksymalna\ szerokoœæ<Tab>^W\| -menutrans Min\ Width<Tab>^W1\| Minimalna\ szerokoœæ<Tab>^W1\| -menutrans Max\ &Width<Tab>^W\| Zmaksymalizuj\ szerokoœæ<Tab>^W\| -menutrans Min\ Widt&h<Tab>^W1\| Zminimalizuj\ szerokoœæ<Tab>^W1\| -menutrans Move\ &To &IdŸ\ do -menutrans &Top<Tab>^WK &Góra<Tab>^WK -menutrans &Bottom<Tab>^WJ &Dó³<Tab>^WJ -menutrans &Left\ side<Tab>^WH &Lewa\ strona<Tab>^WH -menutrans &Right\ side<Tab>^WL &Prawa\ strona<Tab>^WL -menutrans Rotate\ &Up<Tab>^WR Obróæ\ w\ &górê<Tab>^WR -menutrans Rotate\ &Down<Tab>^Wr Obróæ\ w\ &dó³<Tab>^Wr -menutrans Split\ &Vertically<Tab>^Wv &Podziel\ w\ poziomie<Tab>^Wv -menutrans Select\ Fo&nt\.\.\. Wybierz\ &czcionkê\.\.\. - -" The popup menu -menutrans &Undo &Cofnij -menutrans Cu&t W&ytnij -menutrans &Copy &Kopiuj -menutrans &Paste &Wklej -menutrans &Delete &Skasuj -menutrans Select\ Blockwise Zaznacz\ &blok -menutrans Select\ &Sentence Zaznacz\ &zdanie -menutrans Select\ Pa&ragraph Zaznacz\ aka&pit -menutrans Select\ &Word Zaznacz\ &s³owo -menutrans Select\ &Line Zaznacz\ w&iersz -menutrans Select\ &Block Zaznacz\ &blok -menutrans Select\ &All Zaznacz\ c&a³oœæ -menutrans Input\ &Methods Wprowadza&nie - -" The GUI toolbar -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open Otwórz plik - tmenu ToolBar.Save Zapisz bie¿¹cy plik - tmenu ToolBar.SaveAll Zapisz wszystkie pliki - tmenu ToolBar.Print Drukuj - tmenu ToolBar.Undo Cofnij - tmenu ToolBar.Redo Ponów - tmenu ToolBar.Cut Wytnij - tmenu ToolBar.Copy Skopiuj - tmenu ToolBar.Paste Wklej - tmenu ToolBar.Find Szukaj... - tmenu ToolBar.FindNext Szukaj nastêpnego - tmenu ToolBar.FindPrev Szukaj poprzedniego - tmenu ToolBar.Replace Szukaj i zamieniaj... - if 0 " disabled; These are in the Windows menu - tmenu ToolBar.New Nowy widok - tmenu ToolBar.WinSplit Podziel widok - tmenu ToolBar.WinMax Zmaksymalizuj widok - tmenu ToolBar.WinMin Zminimalizuj widok - tmenu ToolBar.WinClose Zamknij widok - endif - tmenu ToolBar.LoadSesn Za³aduj sesjê - tmenu ToolBar.SaveSesn Zachowaj bie¿¹c¹ sesjê - tmenu ToolBar.RunScript Uruchom skrypt Vima - tmenu ToolBar.Make Wykonaj bie¿¹cy projekt - tmenu ToolBar.Shell Otwórz pow³okê - tmenu ToolBar.RunCtags Twórz tagi w bie¿¹cym katalogu - tmenu ToolBar.TagJump Skok do taga pod kursorem - tmenu ToolBar.Help Pomoc Vima - tmenu ToolBar.FindHelp Przeszukuj pomoc Vim-a - endfun -endif - -" Syntax menu -menutrans &Syntax &Sk³adnia -menutrans &Show\ filetypes\ in\ menu Poka¿\ typy\ &plików\ w\ menu -menutrans Set\ '&syntax'\ only Ustaw\ tylko\ '&syntax' -menutrans Set\ '&filetype'\ too Ustaw\ równie¿\ '&filetype' -menutrans &Off &Wy³¹cz -menutrans &Manual &Rêcznie -menutrans A&utomatic A&utomatyczne -menutrans on/off\ for\ &This\ file w³¹cz/w&y³¹cz\ dla\ pliku -menutrans Co&lor\ test Test\ &kolorów -menutrans &Highlight\ test &Test\ podœwietlania -menutrans &Convert\ to\ HTML Przetwórz\ na\ &HTML - -" dialog texts -let menutrans_no_file = "[Brak pliku]" -let menutrans_help_dialog = "WprowadŸ komendê lub s³owo, aby otrzymaæ pomoc o:\n\nPrzedrostek i_ oznacza komendê trybu Wprowadzania (np. i_CTRL-X)\nPrzedrostek c_ oznacza komendê edycji wiersza komend (np. c_<Del>)\nPrzedrostek ' oznacza nazwê opcji (np. 'shiftwidth')" -let g:menutrans_path_dialog = "WprowadŸ œcie¿kê poszukiwania plików.\nProszê rozdzielaæ nazwy katalogów przecinkiem." -let g:menutrans_tags_dialog = "Podaj nazwy plików tagów.\nProszê rozdzielaæ nazwy przecinkiem." -let g:menutrans_textwidth_dialog = "WprowadŸ now¹ szerokoœæ tekstu (0 wy³¹cza przewijanie): " -let g:menutrans_fileformat_dialog = "Wybierz format w którym ten plik ma byæ zapisany" -let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\n&Anuluj" diff --git a/share/vim/vim72/lang/menu_sr.utf-8.vim b/share/vim/vim72/lang/menu_sr.utf-8.vim deleted file mode 100644 index 915c31a586..0000000000 --- a/share/vim/vim72/lang/menu_sr.utf-8.vim +++ /dev/null @@ -1,3 +0,0 @@ -" Menu Translations: Serbian - -source <sfile>:p:h/menu_sr_yu.utf-8.vim diff --git a/share/vim/vim72/lang/menu_sr_yu.utf-8.vim b/share/vim/vim72/lang/menu_sr_yu.utf-8.vim deleted file mode 100644 index 733566387d..0000000000 --- a/share/vim/vim72/lang/menu_sr_yu.utf-8.vim +++ /dev/null @@ -1,261 +0,0 @@ -" Menu Translations: Serbian -" Maintainer: Aleksandar Jelenak <ajelenak AT yahoo.com> -" Last Change: Fri, 30 May 2003 10:17:39 Eastern Daylight Time - -" Quit when menu translations have already been done. -if exists("did_menu_trans") - finish -endif -let did_menu_trans = 1 -scriptencoding utf-8 - -" Help menu -menutrans &Help Помо&ћ -menutrans &Overview<Tab><F1> &Преглед<Tab><F1> -menutrans &User\ Manual &Упутство\ за\ кориснике -menutrans &How-to\ links &Како\ да\.\.\. -menutrans &Find &Нађи -menutrans &Credits &Заслуге -menutrans Co&pying П&реузимање -menutrans O&rphans &Сирочићи -menutrans &Version &Верзија -menutrans &About &О\ програму - -" File menu -menutrans &File &Датотека -menutrans &Open\.\.\.<Tab>:e &Отвори\.\.\.<Tab>:e -menutrans Sp&lit-Open\.\.\.<Tab>:sp &Подели-отвори\.\.\.<Tab>:sp -menutrans &New<Tab>:enew &Нова<Tab>:enew -menutrans &Close<Tab>:close &Затвори<Tab>:close -menutrans &Save<Tab>:w &Сачувај<Tab>:w -menutrans Save\ &As\.\.\.<Tab>:sav Сачувај\ &као\.\.\.<Tab>:sav -menutrans Split\ &Diff\ with\.\.\. Подели\ и\ &упореди\ са\.\.\. -menutrans Split\ Patched\ &By\.\.\. По&дели\ и\ преправи\ са\.\.\. -menutrans &Print Шта&мпај -menutrans Sa&ve-Exit<Tab>:wqa Сачувај\ и\ за&врши<Tab>:wqa -menutrans E&xit<Tab>:qa К&рај<Tab>:qa - -" Edit menu -menutrans &Edit &Уређивање -menutrans &Undo<Tab>u &Врати<Tab>u -menutrans &Redo<Tab>^R &Поврати<Tab>^R -menutrans Rep&eat<Tab>\. П&онови<Tab>\. -menutrans Cu&t<Tab>"+x Исе&ци<Tab>"+x -menutrans &Copy<Tab>"+y &Копирај<Tab>"+y -menutrans &Paste<Tab>"+gP &Убаци<Tab>"+gP -menutrans &Paste<Tab>"+P &Убаци<Tab>"+gP -menutrans Put\ &Before<Tab>[p Стави\ пре&д<Tab>[p -menutrans Put\ &After<Tab>]p Стави\ &иза<Tab>]p -menutrans &Delete<Tab>x Из&бриши<Tab>x -menutrans &Select\ all<Tab>ggVG Изабери\ св&е<Tab>ggVG -menutrans &Find\.\.\. &Нађи\.\.\. -menutrans Find\ and\ Rep&lace\.\.\. Нађи\ и\ &замени\.\.\. -menutrans Settings\ &Window П&розор\ подешавања -menutrans &Global\ Settings Оп&шта\ подешавања -menutrans F&ile\ Settings Подешавања\ за\ да&тотеке -menutrans &Shiftwidth &Померај -menutrans Soft\ &Tabstop &Мека\ табулација -menutrans Te&xt\ Width\.\.\. &Ширина\ текста\.\.\. -menutrans &File\ Format\.\.\. &Врста\ датотеке\.\.\. -menutrans C&olor\ Scheme Бо&је -menutrans &Keymap Прес&ликавање\ тастатуре -menutrans Select\ Fo&nt\.\.\. Избор\ &фонта\.\.\. - -" Edit/Global Settings -menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! Нагласи\ &образце\ (да/не)<Tab>:set\ hls! -menutrans Toggle\ &Ignore-case<Tab>:set\ ic! Занемари\ \величину\ &слова\ (да/не)<Tab>:set\ ic! -menutrans Toggle\ &Showmatch<Tab>:set\ sm! Провери\ пратећу\ &заграду\ (да/не)<Tab>:set\ sm! -menutrans &Context\ lines Видљиви\ &редови -menutrans &Virtual\ Edit Виртуелно\ &уређивање -menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Режим\ у&носа\ (да/не)<Tab>:set\ im! -menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! '&Vi'\ сагласно\ (да/не)<Tab>:set\ cp! -menutrans Search\ &Path\.\.\. Путања\ &претраге\.\.\. -menutrans Ta&g\ Files\.\.\. &Датотеке\ ознака\.\.\. -menutrans Toggle\ &Toolbar Линија\ са\ &алаткама\ (да/не) -menutrans Toggle\ &Bottom\ Scrollbar Доња\ л&инија\ клизања\ (да/не) -menutrans Toggle\ &Left\ Scrollbar &Лева\ линија\ клизања\ (да/не) -menutrans Toggle\ &Right\ Scrollbar &Десна\ линија\ клизања\ (да/не) - -" Edit/Global Settings/Virtual Edit -menutrans Never Никад -menutrans Block\ Selection Избор\ блока -menutrans Insert\ mode Режим\ уноса -menutrans Block\ and\ Insert Блок\ и\ унос -menutrans Always Увек - -" Edit/File Settings -menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! Редни\ &бројеви\ (да/не)<Tab>:set\ nu! -menutrans Toggle\ &List\ Mode<Tab>:set\ list! Режим\ &листе\ (да/не)<Tab>:set\ list! -menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! Обавијање\ &редова\ (да/не)<Tab>:set\ wrap! -menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! Преломи\ &на\ реч\ (да/не)<Tab>:set\ lbr! -menutrans Toggle\ &expand-tab<Tab>:set\ et! Размаци\ уместо\ &табулације\ (да/не)<Tab>:set\ et! -menutrans Toggle\ &auto-indent<Tab>:set\ ai! Ауто-&увлачење\ (да/не)<Tab>:set\ ai! -menutrans Toggle\ &C-indenting<Tab>:set\ cin! &Це-увлачење\ (да/не)<Tab>:set\ cin! - -" Edit/Keymap -menutrans None Ниједан - -" Tools menu -menutrans &Tools &Алатке -menutrans &Jump\ to\ this\ tag<Tab>g^] Скочи\ на\ &ову\ ознаку<Tab>g^] -menutrans Jump\ &back<Tab>^T Скочи\ &натраг<Tab>^T -menutrans Build\ &Tags\ File Изгради\ &датотеку\ ознака -menutrans &Folding &Подвијање -menutrans Create\ &Fold<Tab>zf С&твори\ подвијутак<Tab>zf -menutrans &Delete\ Fold<Tab>zd О&бриши\ подвијутак<Tab>zd -menutrans Delete\ &All\ Folds<Tab>zD Обриши\ све\ по&двијутке<Tab>zD -menutrans Fold\ column\ &width Ширина\ &реда\ подвијутка -menutrans &Diff &Упоређивање -menutrans &Make<Tab>:make 'mak&е'<Tab>:make -menutrans &List\ Errors<Tab>:cl Списак\ &грешака<Tab>:cl -menutrans L&ist\ Messages<Tab>:cl! Сп&исак\ порука<Tab>:cl! -menutrans &Next\ Error<Tab>:cn С&ледећа\ грешка<Tab>:cn -menutrans &Previous\ Error<Tab>:cp Пре&тходна\ грешка<Tab>:cp -menutrans &Older\ List<Tab>:cold Стари\ списа&к<Tab>:cold -menutrans N&ewer\ List<Tab>:cnew Но&ви\ списак<Tab>:cnew -menutrans Error\ &Window Прозор\ са\ г&решкама -menutrans &Set\ Compiler И&забери\ преводиоца -menutrans &Convert\ to\ HEX<Tab>:%!xxd Претвори\ у\ &ХЕКС<Tab>:%!xxd -menutrans Conve&rt\ back<Tab>:%!xxd\ -r Вр&ати\ у\ првобитан\ облик<Tab>:%!xxd\ -r - -" Tools/Folding -menutrans &Enable/Disable\ folds<Tab>zi &Омогући/прекини\ подвијање<Tab>zi -menutrans &View\ Cursor\ Line<Tab>zv &Покажи\ ред\ са\ курсором<Tab>zv -menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx Покажи\ &само\ ред\ са\ курсором<Tab>zMzx -menutrans C&lose\ more\ folds<Tab>zm &Затвори\ више\ подвијутака<Tab>zm -menutrans &Close\ all\ folds<Tab>zM Затвори\ с&ве\ подвијутке<Tab>zM -menutrans O&pen\ more\ folds<Tab>zr Отвори\ виш&е\ подвијутака<Tab>zr -menutrans &Open\ all\ folds<Tab>zR О&твори\ све\ подвијутке<Tab>zR -menutrans Fold\ Met&hod &Начин\ подвијања - -" Tools/Folding/Fold Method -menutrans M&anual &Ручно -menutrans I&ndent &Увученост -menutrans E&xpression &Израз -menutrans S&yntax &Синтакса -"menutrans &Diff -menutrans Ma&rker &Ознака - -" Tools/Diff -menutrans &Update &Ажурирај -menutrans &Get\ Block &Прихвати\ измену -menutrans &Put\ Block Пре&баци\ измену - -" Tools/Error Window -menutrans &Update<Tab>:cwin &Ажурирај<Tab>:cwin -menutrans &Open<Tab>:copen &Отвори<Tab>:copen -menutrans &Close<Tab>:cclose &Затвори<Tab>:cclose - -" Bufers menu -menutrans &Buffers &Бафери -menutrans &Refresh\ menu &Ажурирај -menutrans Delete &Обриши -menutrans &Alternate А&лтернативни -menutrans &Next &Следећи -menutrans &Previous &Претходни -menutrans [No\ File] [Нема\ датотеке] - -" Window menu -menutrans &Window &Прозор -menutrans &New<Tab>^Wn &Нови<Tab>^Wn -menutrans S&plit<Tab>^Ws &Подели<Tab>^Ws -menutrans Sp&lit\ To\ #<Tab>^W^^ Подели\ са\ &алтернативним<Tab>^W^^ -menutrans Split\ &Vertically<Tab>^Wv Подели\ &усправно<Tab>^Wv -menutrans Split\ File\ E&xplorer Подели\ за\ преглед\ &датотека -menutrans &Close<Tab>^Wc &Затвори<Tab>^Wc -menutrans Close\ &Other(s)<Tab>^Wo Затвори\ &остале<Tab>^Wo -"menutrans Ne&xt<Tab>^Ww &Следећи<Tab>^Ww -"menutrans P&revious<Tab>^WW П&ретходни<Tab>^WW -menutrans Move\ &To Пре&мести -menutrans Rotate\ &Up<Tab>^WR &Кружно\ нагоре<Tab>^WR -menutrans Rotate\ &Down<Tab>^Wr Кружно\ надол&е<Tab>^Wr -menutrans &Equal\ Size<Tab>^W= &Исте\ величине<Tab>^W= -menutrans &Max\ Height<Tab>^W_ Максимална\ &висина<Tab>^W_ -menutrans M&in\ Height<Tab>^W1_ Минима&лна\ висина<Tab>^W1_ -menutrans Max\ &Width<Tab>^W\| Максимална\ &ширина<Tab>^W\| -menutrans Min\ Widt&h<Tab>^W1\| Минимална\ ши&рина<Tab>^W1\| - -" Window/Move To -menutrans &Top<Tab>^WK &Врх<Tab>^WK -menutrans &Bottom<Tab>^WJ &Подножје<Tab>^WJ -menutrans &Left\ side<Tab>^WH У&лево<Tab>^WH -menutrans &Right\ side<Tab>^WL У&десно<Tab>^WL - -" The popup menu -menutrans &Undo &Врати -menutrans Cu&t &Исеци -menutrans &Copy &Копирај -menutrans &Paste &Убаци -menutrans &Delete И&збриши -menutrans Select\ Blockwise Бирај\ &правоугаоно -menutrans Select\ &Word Изабери\ &реч -menutrans Select\ &Line Изабери\ р&ед -menutrans Select\ &Block Изабери\ &блок -menutrans Select\ &All Изабери\ &све - -" The GUI toolbar -if has("toolbar") - if exists("*Do_toolbar_tmenu") - delfun Do_toolbar_tmenu - endif - fun Do_toolbar_tmenu() - tmenu ToolBar.Open Учитај - tmenu ToolBar.Save Сачувај - tmenu ToolBar.SaveAll Сачувај све - tmenu ToolBar.Print Штампај - tmenu ToolBar.Undo Врати - tmenu ToolBar.Redo Поврати - tmenu ToolBar.Cut Исеци - tmenu ToolBar.Copy Копирај - tmenu ToolBar.Paste Убаци - tmenu ToolBar.Find Нађи - tmenu ToolBar.FindNext Нађи следећи - tmenu ToolBar.FindPrev Нађи претходни - tmenu ToolBar.Replace Замени - tmenu ToolBar.New Нови - tmenu ToolBar.WinSplit Подели прозор - tmenu ToolBar.WinMax Максимална висина - tmenu ToolBar.WinMin Минимална висина - tmenu ToolBar.WinVSplit Подели усправно - tmenu ToolBar.WinMaxWidth Максимална ширина - tmenu ToolBar.WinMinWidth Минимална ширина - tmenu ToolBar.WinClose Затвори прозор - tmenu ToolBar.LoadSesn Учитај сеансу - tmenu ToolBar.SaveSesn Сачувај сеансу - tmenu ToolBar.RunScript Изврши спис - tmenu ToolBar.Make 'make' - tmenu ToolBar.Shell Оперативно окружење - tmenu ToolBar.RunCtags Направи ознаке - tmenu ToolBar.TagJump Иди на ознаку - tmenu ToolBar.Help Помоћ - tmenu ToolBar.FindHelp Нађи објашњење - endfun -endif - -" Syntax menu -menutrans &Syntax &Синтакса -menutrans &Show\ filetypes\ in\ menu Избор\ 'filetype'\ из\ &менија -menutrans Set\ '&syntax'\ only Поде&си\ 'syntax'\ само -menutrans Set\ '&filetype'\ too Подеси\ 'filetype'\ &такође -menutrans &Off &Искључено -menutrans &Manual &Ручно -menutrans A&utomatic &Аутоматски -menutrans on/off\ for\ &This\ file Да/не\ за\ ову\ &датотеку -menutrans Co&lor\ test Провера\ &боја -menutrans &Highlight\ test Провера\ исти&цања -menutrans &Convert\ to\ HTML Претвори\ &у\ HTML - -" dialog texts -let menutrans_help_dialog = "Унесите наредбу или реч чије појашњење тражите:\n\nДодајте i_ за наредбе уноса (нпр. i_CTRL-X)\nДодајте c_ за наредбе командног режима (нпр. с_<Del>)\nДодајте ' за имена опција (нпр. 'shiftwidth')" - -let g:menutrans_path_dialog = "Унесите пут претраге за датотеке\nРаздвојите зарезима имена директоријума." - -let g:menutrans_tags_dialog = "Унесите имена датотека са ознакама\nРаздвојите зарезима имена." - -let g:menutrans_textwidth_dialog = "Унесите нову ширину текста (0 спречава прелом)" - -let g:menutrans_fileformat_dialog = "Изаберите врсту датотеке" - -let menutrans_no_file = "[Нема датотеке]" - -" vim: tw=0 keymap=serbcyril-US diff --git a/share/vim/vim72/macros/matchit.vim b/share/vim/vim72/macros/matchit.vim deleted file mode 100644 index e41cda9e17..0000000000 --- a/share/vim/vim72/macros/matchit.vim +++ /dev/null @@ -1,812 +0,0 @@ -" matchit.vim: (global plugin) Extended "%" matching -" Last Change: Fri Jan 25 10:00 AM 2008 EST -" Maintainer: Benji Fisher PhD <benji@member.AMS.org> -" Version: 1.13.2, for Vim 6.3+ -" URL: http://www.vim.org/script.php?script_id=39 - -" Documentation: -" The documentation is in a separate file, matchit.txt . - -" Credits: -" Vim editor by Bram Moolenaar (Thanks, Bram!) -" Original script and design by Raul Segura Acevedo -" Support for comments by Douglas Potts -" Support for back references and other improvements by Benji Fisher -" Support for many languages by Johannes Zellner -" Suggestions for improvement, bug reports, and support for additional -" languages by Jordi-Albert Batalla, Neil Bird, Servatius Brandt, Mark -" Collett, Stephen Wall, Dany St-Amant, Yuheng Xie, and Johannes Zellner. - -" Debugging: -" If you'd like to try the built-in debugging commands... -" :MatchDebug to activate debugging for the current buffer -" This saves the values of several key script variables as buffer-local -" variables. See the MatchDebug() function, below, for details. - -" TODO: I should think about multi-line patterns for b:match_words. -" This would require an option: how many lines to scan (default 1). -" This would be useful for Python, maybe also for *ML. -" TODO: Maybe I should add a menu so that people will actually use some of -" the features that I have implemented. -" TODO: Eliminate the MultiMatch function. Add yet another argument to -" Match_wrapper() instead. -" TODO: Allow :let b:match_words = '\(\(foo\)\(bar\)\):\3\2:end\1' -" TODO: Make backrefs safer by using '\V' (very no-magic). -" TODO: Add a level of indirection, so that custom % scripts can use my -" work but extend it. - -" allow user to prevent loading -" and prevent duplicate loading -if exists("loaded_matchit") || &cp - finish -endif -let loaded_matchit = 1 -let s:last_mps = "" -let s:last_words = ":" - -let s:save_cpo = &cpo -set cpo&vim - -nnoremap <silent> % :<C-U>call <SID>Match_wrapper('',1,'n') <CR> -nnoremap <silent> g% :<C-U>call <SID>Match_wrapper('',0,'n') <CR> -vnoremap <silent> % :<C-U>call <SID>Match_wrapper('',1,'v') <CR>m'gv`` -vnoremap <silent> g% :<C-U>call <SID>Match_wrapper('',0,'v') <CR>m'gv`` -onoremap <silent> % v:<C-U>call <SID>Match_wrapper('',1,'o') <CR> -onoremap <silent> g% v:<C-U>call <SID>Match_wrapper('',0,'o') <CR> - -" Analogues of [{ and ]} using matching patterns: -nnoremap <silent> [% :<C-U>call <SID>MultiMatch("bW", "n") <CR> -nnoremap <silent> ]% :<C-U>call <SID>MultiMatch("W", "n") <CR> -vmap [% <Esc>[%m'gv`` -vmap ]% <Esc>]%m'gv`` -" vnoremap <silent> [% :<C-U>call <SID>MultiMatch("bW", "v") <CR>m'gv`` -" vnoremap <silent> ]% :<C-U>call <SID>MultiMatch("W", "v") <CR>m'gv`` -onoremap <silent> [% v:<C-U>call <SID>MultiMatch("bW", "o") <CR> -onoremap <silent> ]% v:<C-U>call <SID>MultiMatch("W", "o") <CR> - -" text object: -vmap a% <Esc>[%v]% - -" Auto-complete mappings: (not yet "ready for prime time") -" TODO Read :help write-plugin for the "right" way to let the user -" specify a key binding. -" let g:match_auto = '<C-]>' -" let g:match_autoCR = '<C-CR>' -" if exists("g:match_auto") -" execute "inoremap " . g:match_auto . ' x<Esc>"=<SID>Autocomplete()<CR>Pls' -" endif -" if exists("g:match_autoCR") -" execute "inoremap " . g:match_autoCR . ' <CR><C-R>=<SID>Autocomplete()<CR>' -" endif -" if exists("g:match_gthhoh") -" execute "inoremap " . g:match_gthhoh . ' <C-O>:call <SID>Gthhoh()<CR>' -" endif " gthhoh = "Get the heck out of here!" - -let s:notslash = '\\\@<!\%(\\\\\)*' - -function! s:Match_wrapper(word, forward, mode) range - " In s:CleanUp(), :execute "set" restore_options . - let restore_options = (&ic ? " " : " no") . "ignorecase" - if exists("b:match_ignorecase") - let &ignorecase = b:match_ignorecase - endif - let restore_options = " ve=" . &ve . restore_options - set ve= - " If this function was called from Visual mode, make sure that the cursor - " is at the correct end of the Visual range: - if a:mode == "v" - execute "normal! gv\<Esc>" - endif - " In s:CleanUp(), we may need to check whether the cursor moved forward. - let startline = line(".") - let startcol = col(".") - " Use default behavior if called with a count. - if v:count - exe "normal! " . v:count . "%" - return s:CleanUp(restore_options, a:mode, startline, startcol) - end - - " First step: if not already done, set the script variables - " s:do_BR flag for whether there are backrefs - " s:pat parsed version of b:match_words - " s:all regexp based on s:pat and the default groups - " - if !exists("b:match_words") || b:match_words == "" - let match_words = "" - " Allow b:match_words = "GetVimMatchWords()" . - elseif b:match_words =~ ":" - let match_words = b:match_words - else - execute "let match_words =" b:match_words - endif -" Thanks to Preben "Peppe" Guldberg and Bram Moolenaar for this suggestion! - if (match_words != s:last_words) || (&mps != s:last_mps) || - \ exists("b:match_debug") - let s:last_words = match_words - let s:last_mps = &mps - " The next several lines were here before - " BF started messing with this script. - " quote the special chars in 'matchpairs', replace [,:] with \| and then - " append the builtin pairs (/*, */, #if, #ifdef, #else, #elif, #endif) - " let default = substitute(escape(&mps, '[$^.*~\\/?]'), '[,:]\+', - " \ '\\|', 'g').'\|\/\*\|\*\/\|#if\>\|#ifdef\>\|#else\>\|#elif\>\|#endif\>' - let default = escape(&mps, '[$^.*~\\/?]') . (strlen(&mps) ? "," : "") . - \ '\/\*:\*\/,#if\%(def\)\=:#else\>:#elif\>:#endif\>' - " s:all = pattern with all the keywords - let match_words = match_words . (strlen(match_words) ? "," : "") . default - if match_words !~ s:notslash . '\\\d' - let s:do_BR = 0 - let s:pat = match_words - else - let s:do_BR = 1 - let s:pat = s:ParseWords(match_words) - endif - let s:all = substitute(s:pat, s:notslash . '\zs[,:]\+', '\\|', 'g') - let s:all = '\%(' . s:all . '\)' - " let s:all = '\%(' . substitute(s:all, '\\\ze[,:]', '', 'g') . '\)' - if exists("b:match_debug") - let b:match_pat = s:pat - endif - endif - - " Second step: set the following local variables: - " matchline = line on which the cursor started - " curcol = number of characters before match - " prefix = regexp for start of line to start of match - " suffix = regexp for end of match to end of line - " Require match to end on or after the cursor and prefer it to - " start on or before the cursor. - let matchline = getline(startline) - if a:word != '' - " word given - if a:word !~ s:all - echohl WarningMsg|echo 'Missing rule for word:"'.a:word.'"'|echohl NONE - return s:CleanUp(restore_options, a:mode, startline, startcol) - endif - let matchline = a:word - let curcol = 0 - let prefix = '^\%(' - let suffix = '\)$' - " Now the case when "word" is not given - else " Find the match that ends on or after the cursor and set curcol. - let regexp = s:Wholematch(matchline, s:all, startcol-1) - let curcol = match(matchline, regexp) - " If there is no match, give up. - if curcol == -1 - return s:CleanUp(restore_options, a:mode, startline, startcol) - endif - let endcol = matchend(matchline, regexp) - let suf = strlen(matchline) - endcol - let prefix = (curcol ? '^.*\%' . (curcol + 1) . 'c\%(' : '^\%(') - let suffix = (suf ? '\)\%' . (endcol + 1) . 'c.*$' : '\)$') - endif - if exists("b:match_debug") - let b:match_match = matchstr(matchline, regexp) - let b:match_col = curcol+1 - endif - - " Third step: Find the group and single word that match, and the original - " (backref) versions of these. Then, resolve the backrefs. - " Set the following local variable: - " group = colon-separated list of patterns, one of which matches - " = ini:mid:fin or ini:fin - " - " Reconstruct the version with unresolved backrefs. - let patBR = substitute(match_words.',', - \ s:notslash.'\zs[,:]*,[,:]*', ',', 'g') - let patBR = substitute(patBR, s:notslash.'\zs:\{2,}', ':', 'g') - " Now, set group and groupBR to the matching group: 'if:endif' or - " 'while:endwhile' or whatever. A bit of a kluge: s:Choose() returns - " group . "," . groupBR, and we pick it apart. - let group = s:Choose(s:pat, matchline, ",", ":", prefix, suffix, patBR) - let i = matchend(group, s:notslash . ",") - let groupBR = strpart(group, i) - let group = strpart(group, 0, i-1) - " Now, matchline =~ prefix . substitute(group,':','\|','g') . suffix - if s:do_BR " Do the hard part: resolve those backrefs! - let group = s:InsertRefs(groupBR, prefix, group, suffix, matchline) - endif - if exists("b:match_debug") - let b:match_wholeBR = groupBR - let i = matchend(groupBR, s:notslash . ":") - let b:match_iniBR = strpart(groupBR, 0, i-1) - endif - - " Fourth step: Set the arguments for searchpair(). - let i = matchend(group, s:notslash . ":") - let j = matchend(group, '.*' . s:notslash . ":") - let ini = strpart(group, 0, i-1) - let mid = substitute(strpart(group, i,j-i-1), s:notslash.'\zs:', '\\|', 'g') - let fin = strpart(group, j) - "Un-escape the remaining , and : characters. - let ini = substitute(ini, s:notslash . '\zs\\\(:\|,\)', '\1', 'g') - let mid = substitute(mid, s:notslash . '\zs\\\(:\|,\)', '\1', 'g') - let fin = substitute(fin, s:notslash . '\zs\\\(:\|,\)', '\1', 'g') - " searchpair() requires that these patterns avoid \(\) groups. - let ini = substitute(ini, s:notslash . '\zs\\(', '\\%(', 'g') - let mid = substitute(mid, s:notslash . '\zs\\(', '\\%(', 'g') - let fin = substitute(fin, s:notslash . '\zs\\(', '\\%(', 'g') - " Set mid. This is optimized for readability, not micro-efficiency! - if a:forward && matchline =~ prefix . fin . suffix - \ || !a:forward && matchline =~ prefix . ini . suffix - let mid = "" - endif - " Set flag. This is optimized for readability, not micro-efficiency! - if a:forward && matchline =~ prefix . fin . suffix - \ || !a:forward && matchline !~ prefix . ini . suffix - let flag = "bW" - else - let flag = "W" - endif - " Set skip. - if exists("b:match_skip") - let skip = b:match_skip - elseif exists("b:match_comment") " backwards compatibility and testing! - let skip = "r:" . b:match_comment - else - let skip = 's:comment\|string' - endif - let skip = s:ParseSkip(skip) - if exists("b:match_debug") - let b:match_ini = ini - let b:match_tail = (strlen(mid) ? mid.'\|' : '') . fin - endif - - " Fifth step: actually start moving the cursor and call searchpair(). - " Later, :execute restore_cursor to get to the original screen. - let restore_cursor = virtcol(".") . "|" - normal! g0 - let restore_cursor = line(".") . "G" . virtcol(".") . "|zs" . restore_cursor - normal! H - let restore_cursor = "normal!" . line(".") . "Gzt" . restore_cursor - execute restore_cursor - call cursor(0, curcol + 1) - " normal! 0 - " if curcol - " execute "normal!" . curcol . "l" - " endif - if skip =~ 'synID' && !(has("syntax") && exists("g:syntax_on")) - let skip = "0" - else - execute "if " . skip . "| let skip = '0' | endif" - endif - let sp_return = searchpair(ini, mid, fin, flag, skip) - let final_position = "call cursor(" . line(".") . "," . col(".") . ")" - " Restore cursor position and original screen. - execute restore_cursor - normal! m' - if sp_return > 0 - execute final_position - endif - return s:CleanUp(restore_options, a:mode, startline, startcol, mid.'\|'.fin) -endfun - -" Restore options and do some special handling for Operator-pending mode. -" The optional argument is the tail of the matching group. -fun! s:CleanUp(options, mode, startline, startcol, ...) - execute "set" a:options - " Open folds, if appropriate. - if a:mode != "o" - if &foldopen =~ "percent" - normal! zv - endif - " In Operator-pending mode, we want to include the whole match - " (for example, d%). - " This is only a problem if we end up moving in the forward direction. - elseif (a:startline < line(".")) || - \ (a:startline == line(".") && a:startcol < col(".")) - if a:0 - " Check whether the match is a single character. If not, move to the - " end of the match. - let matchline = getline(".") - let currcol = col(".") - let regexp = s:Wholematch(matchline, a:1, currcol-1) - let endcol = matchend(matchline, regexp) - if endcol > currcol " This is NOT off by one! - execute "normal!" . (endcol - currcol) . "l" - endif - endif " a:0 - endif " a:mode != "o" && etc. - return 0 -endfun - -" Example (simplified HTML patterns): if -" a:groupBR = '<\(\k\+\)>:</\1>' -" a:prefix = '^.\{3}\(' -" a:group = '<\(\k\+\)>:</\(\k\+\)>' -" a:suffix = '\).\{2}$' -" a:matchline = "123<tag>12" or "123</tag>12" -" then extract "tag" from a:matchline and return "<tag>:</tag>" . -fun! s:InsertRefs(groupBR, prefix, group, suffix, matchline) - if a:matchline !~ a:prefix . - \ substitute(a:group, s:notslash . '\zs:', '\\|', 'g') . a:suffix - return a:group - endif - let i = matchend(a:groupBR, s:notslash . ':') - let ini = strpart(a:groupBR, 0, i-1) - let tailBR = strpart(a:groupBR, i) - let word = s:Choose(a:group, a:matchline, ":", "", a:prefix, a:suffix, - \ a:groupBR) - let i = matchend(word, s:notslash . ":") - let wordBR = strpart(word, i) - let word = strpart(word, 0, i-1) - " Now, a:matchline =~ a:prefix . word . a:suffix - if wordBR != ini - let table = s:Resolve(ini, wordBR, "table") - else - " let table = "----------" - let table = "" - let d = 0 - while d < 10 - if tailBR =~ s:notslash . '\\' . d - " let table[d] = d - let table = table . d - else - let table = table . "-" - endif - let d = d + 1 - endwhile - endif - let d = 9 - while d - if table[d] != "-" - let backref = substitute(a:matchline, a:prefix.word.a:suffix, - \ '\'.table[d], "") - " Are there any other characters that should be escaped? - let backref = escape(backref, '*,:') - execute s:Ref(ini, d, "start", "len") - let ini = strpart(ini, 0, start) . backref . strpart(ini, start+len) - let tailBR = substitute(tailBR, s:notslash . '\zs\\' . d, - \ escape(backref, '\\'), 'g') - endif - let d = d-1 - endwhile - if exists("b:match_debug") - if s:do_BR - let b:match_table = table - let b:match_word = word - else - let b:match_table = "" - let b:match_word = "" - endif - endif - return ini . ":" . tailBR -endfun - -" Input a comma-separated list of groups with backrefs, such as -" a:groups = '\(foo\):end\1,\(bar\):end\1' -" and return a comma-separated list of groups with backrefs replaced: -" return '\(foo\):end\(foo\),\(bar\):end\(bar\)' -fun! s:ParseWords(groups) - let groups = substitute(a:groups.",", s:notslash.'\zs[,:]*,[,:]*', ',', 'g') - let groups = substitute(groups, s:notslash . '\zs:\{2,}', ':', 'g') - let parsed = "" - while groups =~ '[^,:]' - let i = matchend(groups, s:notslash . ':') - let j = matchend(groups, s:notslash . ',') - let ini = strpart(groups, 0, i-1) - let tail = strpart(groups, i, j-i-1) . ":" - let groups = strpart(groups, j) - let parsed = parsed . ini - let i = matchend(tail, s:notslash . ':') - while i != -1 - " In 'if:else:endif', ini='if' and word='else' and then word='endif'. - let word = strpart(tail, 0, i-1) - let tail = strpart(tail, i) - let i = matchend(tail, s:notslash . ':') - let parsed = parsed . ":" . s:Resolve(ini, word, "word") - endwhile " Now, tail has been used up. - let parsed = parsed . "," - endwhile " groups =~ '[^,:]' - let parsed = substitute(parsed, ',$', '', '') - return parsed -endfun - -" TODO I think this can be simplified and/or made more efficient. -" TODO What should I do if a:start is out of range? -" Return a regexp that matches all of a:string, such that -" matchstr(a:string, regexp) represents the match for a:pat that starts -" as close to a:start as possible, before being preferred to after, and -" ends after a:start . -" Usage: -" let regexp = s:Wholematch(getline("."), 'foo\|bar', col(".")-1) -" let i = match(getline("."), regexp) -" let j = matchend(getline("."), regexp) -" let match = matchstr(getline("."), regexp) -fun! s:Wholematch(string, pat, start) - let group = '\%(' . a:pat . '\)' - let prefix = (a:start ? '\(^.*\%<' . (a:start + 2) . 'c\)\zs' : '^') - let len = strlen(a:string) - let suffix = (a:start+1 < len ? '\(\%>'.(a:start+1).'c.*$\)\@=' : '$') - if a:string !~ prefix . group . suffix - let prefix = '' - endif - return prefix . group . suffix -endfun - -" No extra arguments: s:Ref(string, d) will -" find the d'th occurrence of '\(' and return it, along with everything up -" to and including the matching '\)'. -" One argument: s:Ref(string, d, "start") returns the index of the start -" of the d'th '\(' and any other argument returns the length of the group. -" Two arguments: s:Ref(string, d, "foo", "bar") returns a string to be -" executed, having the effect of -" :let foo = s:Ref(string, d, "start") -" :let bar = s:Ref(string, d, "len") -fun! s:Ref(string, d, ...) - let len = strlen(a:string) - if a:d == 0 - let start = 0 - else - let cnt = a:d - let match = a:string - while cnt - let cnt = cnt - 1 - let index = matchend(match, s:notslash . '\\(') - if index == -1 - return "" - endif - let match = strpart(match, index) - endwhile - let start = len - strlen(match) - if a:0 == 1 && a:1 == "start" - return start - 2 - endif - let cnt = 1 - while cnt - let index = matchend(match, s:notslash . '\\(\|\\)') - 1 - if index == -2 - return "" - endif - " Increment if an open, decrement if a ')': - let cnt = cnt + (match[index]=="(" ? 1 : -1) " ')' - " let cnt = stridx('0(', match[index]) + cnt - let match = strpart(match, index+1) - endwhile - let start = start - 2 - let len = len - start - strlen(match) - endif - if a:0 == 1 - return len - elseif a:0 == 2 - return "let " . a:1 . "=" . start . "| let " . a:2 . "=" . len - else - return strpart(a:string, start, len) - endif -endfun - -" Count the number of disjoint copies of pattern in string. -" If the pattern is a literal string and contains no '0' or '1' characters -" then s:Count(string, pattern, '0', '1') should be faster than -" s:Count(string, pattern). -fun! s:Count(string, pattern, ...) - let pat = escape(a:pattern, '\\') - if a:0 > 1 - let foo = substitute(a:string, '[^'.a:pattern.']', "a:1", "g") - let foo = substitute(a:string, pat, a:2, "g") - let foo = substitute(foo, '[^' . a:2 . ']', "", "g") - return strlen(foo) - endif - let result = 0 - let foo = a:string - let index = matchend(foo, pat) - while index != -1 - let result = result + 1 - let foo = strpart(foo, index) - let index = matchend(foo, pat) - endwhile - return result -endfun - -" s:Resolve('\(a\)\(b\)', '\(c\)\2\1\1\2') should return table.word, where -" word = '\(c\)\(b\)\(a\)\3\2' and table = '-32-------'. That is, the first -" '\1' in target is replaced by '\(a\)' in word, table[1] = 3, and this -" indicates that all other instances of '\1' in target are to be replaced -" by '\3'. The hard part is dealing with nesting... -" Note that ":" is an illegal character for source and target, -" unless it is preceded by "\". -fun! s:Resolve(source, target, output) - let word = a:target - let i = matchend(word, s:notslash . '\\\d') - 1 - let table = "----------" - while i != -2 " There are back references to be replaced. - let d = word[i] - let backref = s:Ref(a:source, d) - " The idea is to replace '\d' with backref. Before we do this, - " replace any \(\) groups in backref with :1, :2, ... if they - " correspond to the first, second, ... group already inserted - " into backref. Later, replace :1 with \1 and so on. The group - " number w+b within backref corresponds to the group number - " s within a:source. - " w = number of '\(' in word before the current one - let w = s:Count( - \ substitute(strpart(word, 0, i-1), '\\\\', '', 'g'), '\(', '1') - let b = 1 " number of the current '\(' in backref - let s = d " number of the current '\(' in a:source - while b <= s:Count(substitute(backref, '\\\\', '', 'g'), '\(', '1') - \ && s < 10 - if table[s] == "-" - if w + b < 10 - " let table[s] = w + b - let table = strpart(table, 0, s) . (w+b) . strpart(table, s+1) - endif - let b = b + 1 - let s = s + 1 - else - execute s:Ref(backref, b, "start", "len") - let ref = strpart(backref, start, len) - let backref = strpart(backref, 0, start) . ":". table[s] - \ . strpart(backref, start+len) - let s = s + s:Count(substitute(ref, '\\\\', '', 'g'), '\(', '1') - endif - endwhile - let word = strpart(word, 0, i-1) . backref . strpart(word, i+1) - let i = matchend(word, s:notslash . '\\\d') - 1 - endwhile - let word = substitute(word, s:notslash . '\zs:', '\\', 'g') - if a:output == "table" - return table - elseif a:output == "word" - return word - else - return table . word - endif -endfun - -" Assume a:comma = ",". Then the format for a:patterns and a:1 is -" a:patterns = "<pat1>,<pat2>,..." -" a:1 = "<alt1>,<alt2>,..." -" If <patn> is the first pattern that matches a:string then return <patn> -" if no optional arguments are given; return <patn>,<altn> if a:1 is given. -fun! s:Choose(patterns, string, comma, branch, prefix, suffix, ...) - let tail = (a:patterns =~ a:comma."$" ? a:patterns : a:patterns . a:comma) - let i = matchend(tail, s:notslash . a:comma) - if a:0 - let alttail = (a:1 =~ a:comma."$" ? a:1 : a:1 . a:comma) - let j = matchend(alttail, s:notslash . a:comma) - endif - let current = strpart(tail, 0, i-1) - if a:branch == "" - let currpat = current - else - let currpat = substitute(current, s:notslash . a:branch, '\\|', 'g') - endif - while a:string !~ a:prefix . currpat . a:suffix - let tail = strpart(tail, i) - let i = matchend(tail, s:notslash . a:comma) - if i == -1 - return -1 - endif - let current = strpart(tail, 0, i-1) - if a:branch == "" - let currpat = current - else - let currpat = substitute(current, s:notslash . a:branch, '\\|', 'g') - endif - if a:0 - let alttail = strpart(alttail, j) - let j = matchend(alttail, s:notslash . a:comma) - endif - endwhile - if a:0 - let current = current . a:comma . strpart(alttail, 0, j-1) - endif - return current -endfun - -" Call this function to turn on debugging information. Every time the main -" script is run, buffer variables will be saved. These can be used directly -" or viewed using the menu items below. -if !exists(":MatchDebug") - command! -nargs=0 MatchDebug call s:Match_debug() -endif - -fun! s:Match_debug() - let b:match_debug = 1 " Save debugging information. - " pat = all of b:match_words with backrefs parsed - amenu &Matchit.&pat :echo b:match_pat<CR> - " match = bit of text that is recognized as a match - amenu &Matchit.&match :echo b:match_match<CR> - " curcol = cursor column of the start of the matching text - amenu &Matchit.&curcol :echo b:match_col<CR> - " wholeBR = matching group, original version - amenu &Matchit.wh&oleBR :echo b:match_wholeBR<CR> - " iniBR = 'if' piece, original version - amenu &Matchit.ini&BR :echo b:match_iniBR<CR> - " ini = 'if' piece, with all backrefs resolved from match - amenu &Matchit.&ini :echo b:match_ini<CR> - " tail = 'else\|endif' piece, with all backrefs resolved from match - amenu &Matchit.&tail :echo b:match_tail<CR> - " fin = 'endif' piece, with all backrefs resolved from match - amenu &Matchit.&word :echo b:match_word<CR> - " '\'.d in ini refers to the same thing as '\'.table[d] in word. - amenu &Matchit.t&able :echo '0:' . b:match_table . ':9'<CR> -endfun - -" Jump to the nearest unmatched "(" or "if" or "<tag>" if a:spflag == "bW" -" or the nearest unmatched "</tag>" or "endif" or ")" if a:spflag == "W". -" Return a "mark" for the original position, so that -" let m = MultiMatch("bW", "n") ... execute m -" will return to the original position. If there is a problem, do not -" move the cursor and return "", unless a count is given, in which case -" go up or down as many levels as possible and again return "". -" TODO This relies on the same patterns as % matching. It might be a good -" idea to give it its own matching patterns. -fun! s:MultiMatch(spflag, mode) - if !exists("b:match_words") || b:match_words == "" - return "" - end - let restore_options = (&ic ? "" : "no") . "ignorecase" - if exists("b:match_ignorecase") - let &ignorecase = b:match_ignorecase - endif - let startline = line(".") - let startcol = col(".") - - " First step: if not already done, set the script variables - " s:do_BR flag for whether there are backrefs - " s:pat parsed version of b:match_words - " s:all regexp based on s:pat and the default groups - " This part is copied and slightly modified from s:Match_wrapper(). - let default = escape(&mps, '[$^.*~\\/?]') . (strlen(&mps) ? "," : "") . - \ '\/\*:\*\/,#if\%(def\)\=:#else\>:#elif\>:#endif\>' - " Allow b:match_words = "GetVimMatchWords()" . - if b:match_words =~ ":" - let match_words = b:match_words - else - execute "let match_words =" b:match_words - endif - if (match_words != s:last_words) || (&mps != s:last_mps) || - \ exists("b:match_debug") - let s:last_words = match_words - let s:last_mps = &mps - if match_words !~ s:notslash . '\\\d' - let s:do_BR = 0 - let s:pat = match_words - else - let s:do_BR = 1 - let s:pat = s:ParseWords(match_words) - endif - let s:all = '\%(' . substitute(s:pat . (strlen(s:pat)?",":"") . default, - \ '[,:]\+','\\|','g') . '\)' - if exists("b:match_debug") - let b:match_pat = s:pat - endif - endif - - " Second step: figure out the patterns for searchpair() - " and save the screen, cursor position, and 'ignorecase'. - " - TODO: A lot of this is copied from s:Match_wrapper(). - " - maybe even more functionality should be split off - " - into separate functions! - let cdefault = (s:pat =~ '[^,]$' ? "," : "") . default - let open = substitute(s:pat . cdefault, - \ s:notslash . '\zs:.\{-}' . s:notslash . ',', '\\),\\(', 'g') - let open = '\(' . substitute(open, s:notslash . '\zs:.*$', '\\)', '') - let close = substitute(s:pat . cdefault, - \ s:notslash . '\zs,.\{-}' . s:notslash . ':', '\\),\\(', 'g') - let close = substitute(close, '^.\{-}' . s:notslash . ':', '\\(', '') . '\)' - if exists("b:match_skip") - let skip = b:match_skip - elseif exists("b:match_comment") " backwards compatibility and testing! - let skip = "r:" . b:match_comment - else - let skip = 's:comment\|string' - endif - let skip = s:ParseSkip(skip) - " let restore_cursor = line(".") . "G" . virtcol(".") . "|" - " normal! H - " let restore_cursor = "normal!" . line(".") . "Gzt" . restore_cursor - let restore_cursor = virtcol(".") . "|" - normal! g0 - let restore_cursor = line(".") . "G" . virtcol(".") . "|zs" . restore_cursor - normal! H - let restore_cursor = "normal!" . line(".") . "Gzt" . restore_cursor - execute restore_cursor - - " Third step: call searchpair(). - " Replace '\('--but not '\\('--with '\%(' and ',' with '\|'. - let openpat = substitute(open, '\(\\\@<!\(\\\\\)*\)\@<=\\(', '\\%(', 'g') - let openpat = substitute(openpat, ',', '\\|', 'g') - let closepat = substitute(close, '\(\\\@<!\(\\\\\)*\)\@<=\\(', '\\%(', 'g') - let closepat = substitute(closepat, ',', '\\|', 'g') - if skip =~ 'synID' && !(has("syntax") && exists("g:syntax_on")) - let skip = '0' - else - execute "if " . skip . "| let skip = '0' | endif" - endif - mark ' - let level = v:count1 - while level - if searchpair(openpat, '', closepat, a:spflag, skip) < 1 - call s:CleanUp(restore_options, a:mode, startline, startcol) - return "" - endif - let level = level - 1 - endwhile - - " Restore options and return a string to restore the original position. - call s:CleanUp(restore_options, a:mode, startline, startcol) - return restore_cursor -endfun - -" Search backwards for "if" or "while" or "<tag>" or ... -" and return "endif" or "endwhile" or "</tag>" or ... . -" For now, this uses b:match_words and the same script variables -" as s:Match_wrapper() . Later, it may get its own patterns, -" either from a buffer variable or passed as arguments. -" fun! s:Autocomplete() -" echo "autocomplete not yet implemented :-(" -" if !exists("b:match_words") || b:match_words == "" -" return "" -" end -" let startpos = s:MultiMatch("bW") -" -" if startpos == "" -" return "" -" endif -" " - TODO: figure out whether 'if' or '<tag>' matched, and construct -" " - the appropriate closing. -" let matchline = getline(".") -" let curcol = col(".") - 1 -" " - TODO: Change the s:all argument if there is a new set of match pats. -" let regexp = s:Wholematch(matchline, s:all, curcol) -" let suf = strlen(matchline) - matchend(matchline, regexp) -" let prefix = (curcol ? '^.\{' . curcol . '}\%(' : '^\%(') -" let suffix = (suf ? '\).\{' . suf . '}$' : '\)$') -" " Reconstruct the version with unresolved backrefs. -" let patBR = substitute(b:match_words.',', '[,:]*,[,:]*', ',', 'g') -" let patBR = substitute(patBR, ':\{2,}', ':', "g") -" " Now, set group and groupBR to the matching group: 'if:endif' or -" " 'while:endwhile' or whatever. -" let group = s:Choose(s:pat, matchline, ",", ":", prefix, suffix, patBR) -" let i = matchend(group, s:notslash . ",") -" let groupBR = strpart(group, i) -" let group = strpart(group, 0, i-1) -" " Now, matchline =~ prefix . substitute(group,':','\|','g') . suffix -" if s:do_BR -" let group = s:InsertRefs(groupBR, prefix, group, suffix, matchline) -" endif -" " let g:group = group -" -" " - TODO: Construct the closing from group. -" let fake = "end" . expand("<cword>") -" execute startpos -" return fake -" endfun - -" Close all open structures. "Get the heck out of here!" -" fun! s:Gthhoh() -" let close = s:Autocomplete() -" while strlen(close) -" put=close -" let close = s:Autocomplete() -" endwhile -" endfun - -" Parse special strings as typical skip arguments for searchpair(): -" s:foo becomes (current syntax item) =~ foo -" S:foo becomes (current syntax item) !~ foo -" r:foo becomes (line before cursor) =~ foo -" R:foo becomes (line before cursor) !~ foo -fun! s:ParseSkip(str) - let skip = a:str - if skip[1] == ":" - if skip[0] == "s" - let skip = "synIDattr(synID(line('.'),col('.'),1),'name') =~? '" . - \ strpart(skip,2) . "'" - elseif skip[0] == "S" - let skip = "synIDattr(synID(line('.'),col('.'),1),'name') !~? '" . - \ strpart(skip,2) . "'" - elseif skip[0] == "r" - let skip = "strpart(getline('.'),0,col('.'))=~'" . strpart(skip,2). "'" - elseif skip[0] == "R" - let skip = "strpart(getline('.'),0,col('.'))!~'" . strpart(skip,2). "'" - endif - endif - return skip -endfun - -let &cpo = s:save_cpo - -" vim:sts=2:sw=2: diff --git a/share/vim/vim72/makemenu.vim b/share/vim/vim72/makemenu.vim deleted file mode 100644 index 5f7883c79a..0000000000 --- a/share/vim/vim72/makemenu.vim +++ /dev/null @@ -1,583 +0,0 @@ -" Script to define the syntax menu in synmenu.vim -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2008 Jul 13 - -" This is used by "make menu" in the src directory. -edit <sfile>:p:h/synmenu.vim - -/The Start Of The Syntax Menu/+1,/The End Of The Syntax Menu/-1d -let s:lnum = line(".") - 1 -call append(s:lnum, "") -let s:lnum = s:lnum + 1 - -" Use the SynMenu command and function to define all menu entries -command! -nargs=* SynMenu call <SID>Syn(<q-args>) - -let s:cur_menu_name = "" -let s:cur_menu_nr = 0 -let s:cur_menu_item = 0 -let s:cur_menu_char = "" - -fun! <SID>Syn(arg) - " isolate menu name: until the first dot - let i = match(a:arg, '\.') - let menu_name = strpart(a:arg, 0, i) - let r = strpart(a:arg, i + 1, 999) - " isolate submenu name: until the colon - let i = match(r, ":") - let submenu_name = strpart(r, 0, i) - " after the colon is the syntax name - let syntax_name = strpart(r, i + 1, 999) - - if s:cur_menu_name != menu_name - let s:cur_menu_name = menu_name - let s:cur_menu_nr = s:cur_menu_nr + 10 - let s:cur_menu_item = 100 - let s:cur_menu_char = submenu_name[0] - else - " When starting a new letter, insert a menu separator. - let c = submenu_name[0] - if c != s:cur_menu_char - exe 'an 50.' . s:cur_menu_nr . '.' . s:cur_menu_item . ' &Syntax.' . menu_name . ".-" . c . '- <nul>' - let s:cur_menu_item = s:cur_menu_item + 10 - let s:cur_menu_char = c - endif - endif - call append(s:lnum, 'an 50.' . s:cur_menu_nr . '.' . s:cur_menu_item . ' &Syntax.' . menu_name . "." . submenu_name . ' :cal SetSyn("' . syntax_name . '")<CR>') - let s:cur_menu_item = s:cur_menu_item + 10 - let s:lnum = s:lnum + 1 -endfun - -SynMenu AB.A2ps\ config:a2ps -SynMenu AB.Aap:aap -SynMenu AB.ABAP/4:abap -SynMenu AB.Abaqus:abaqus -SynMenu AB.ABC\ music\ notation:abc -SynMenu AB.ABEL:abel -SynMenu AB.AceDB\ model:acedb -SynMenu AB.Ada:ada -SynMenu AB.AfLex:aflex -SynMenu AB.ALSA\ config:alsaconf -SynMenu AB.Altera\ AHDL:ahdl -SynMenu AB.Amiga\ DOS:amiga -SynMenu AB.AMPL:ampl -SynMenu AB.Ant\ build\ file:ant -SynMenu AB.ANTLR:antlr -SynMenu AB.Apache\ config:apache -SynMenu AB.Apache-style\ config:apachestyle -SynMenu AB.Applix\ ELF:elf -SynMenu AB.Arc\ Macro\ Language:aml -SynMenu AB.Arch\ inventory:arch -SynMenu AB.ART:art -SynMenu AB.ASP\ with\ VBScript:aspvbs -SynMenu AB.ASP\ with\ Perl:aspperl -SynMenu AB.Assembly.680x0:asm68k -SynMenu AB.Assembly.Flat:fasm -SynMenu AB.Assembly.GNU:asm -SynMenu AB.Assembly.GNU\ H-8300:asmh8300 -SynMenu AB.Assembly.Intel\ IA-64:ia64 -SynMenu AB.Assembly.Microsoft:masm -SynMenu AB.Assembly.Netwide:nasm -SynMenu AB.Assembly.PIC:pic -SynMenu AB.Assembly.Turbo:tasm -SynMenu AB.Assembly.VAX\ Macro\ Assembly:vmasm -SynMenu AB.Assembly.Z-80:z8a -SynMenu AB.Assembly.xa\ 6502\ cross\ assember:a65 -SynMenu AB.ASN\.1:asn -SynMenu AB.Asterisk\ config:asterisk -SynMenu AB.Asterisk\ voicemail\ config:asteriskvm -SynMenu AB.Atlas:atlas -SynMenu AB.AutoHotKey:autohotkey -SynMenu AB.AutoIt:autoit -SynMenu AB.Automake:automake -SynMenu AB.Avenue:ave -SynMenu AB.Awk:awk -SynMenu AB.AYacc:ayacc - -SynMenu AB.B:b -SynMenu AB.Baan:baan -SynMenu AB.Basic.FreeBasic:freebasic -SynMenu AB.Basic.IBasic:ibasic -SynMenu AB.Basic.QBasic:basic -SynMenu AB.Basic.Visual\ Basic:vb -SynMenu AB.Bazaar\ commit\ file:bzr -SynMenu AB.BC\ calculator:bc -SynMenu AB.BDF\ font:bdf -SynMenu AB.BibTeX.Bibliography\ database:bib -SynMenu AB.BibTeX.Bibliography\ Style:bst -SynMenu AB.BIND.BIND\ config:named -SynMenu AB.BIND.BIND\ zone:bindzone -SynMenu AB.Blank:blank - -SynMenu C.C:c -SynMenu C.C++:cpp -SynMenu C.C#:cs -SynMenu C.Calendar:calendar -SynMenu C.Cascading\ Style\ Sheets:css -SynMenu C.CDL:cdl -SynMenu C.Cdrdao\ TOC:cdrtoc -SynMenu C.Cdrdao\ config:cdrdaoconf -SynMenu C.Century\ Term:cterm -SynMenu C.CH\ script:ch -SynMenu C.ChangeLog:changelog -SynMenu C.Cheetah\ template:cheetah -SynMenu C.CHILL:chill -SynMenu C.ChordPro:chordpro -SynMenu C.Clean:clean -SynMenu C.Clever:cl -SynMenu C.Clipper:clipper -SynMenu C.Cmake:cmake -SynMenu C.Cmusrc:cmusrc -SynMenu C.Cobol:cobol -SynMenu C.Coco/R:coco -SynMenu C.Cold\ Fusion:cf -SynMenu C.Conary\ Recipe:conaryrecipe -SynMenu C.Config.Cfg\ Config\ file:cfg -SynMenu C.Config.Configure\.in:config -SynMenu C.Config.Generic\ Config\ file:conf -SynMenu C.CRM114:crm -SynMenu C.Crontab:crontab -SynMenu C.CSP:csp -SynMenu C.Ctrl-H:ctrlh -SynMenu C.CUDA:cuda -SynMenu C.CUPL.CUPL:cupl -SynMenu C.CUPL.Simulation:cuplsim -SynMenu C.CVS.commit\ file:cvs -SynMenu C.CVS.cvsrc:cvsrc -SynMenu C.Cyn++:cynpp -SynMenu C.Cynlib:cynlib - -SynMenu DE.D:d -SynMenu DE.Debian.Debian\ ChangeLog:debchangelog -SynMenu DE.Debian.Debian\ Control:debcontrol -SynMenu DE.Debian.Debian\ Sources\.list:debsources -SynMenu DE.Denyhosts:denyhosts -SynMenu DE.Desktop:desktop -SynMenu DE.Dict\ config:dictconf -SynMenu DE.Dictd\ config:dictdconf -SynMenu DE.Diff:diff -SynMenu DE.Digital\ Command\ Lang:dcl -SynMenu DE.Dircolors:dircolors -SynMenu DE.Django\ template:django -SynMenu DE.DNS/BIND\ zone:bindzone -SynMenu DE.DocBook.auto-detect:docbk -SynMenu DE.DocBook.SGML:docbksgml -SynMenu DE.DocBook.XML:docbkxml -SynMenu DE.Dot:dot -SynMenu DE.Doxygen.C\ with\ doxygen:c.doxygen -SynMenu DE.Doxygen.C++\ with\ doxygen:cpp.doxygen -SynMenu DE.Doxygen.IDL\ with\ doxygen:idl.doxygen -SynMenu DE.Doxygen.Java\ with\ doxygen:java.doxygen -SynMenu DE.Dracula:dracula -SynMenu DE.DSSSL:dsl -SynMenu DE.DTD:dtd -SynMenu DE.DTML\ (Zope):dtml -SynMenu DE.DTrace:dtrace -SynMenu DE.Dylan.Dylan:dylan -SynMenu DE.Dylan.Dylan\ interface:dylanintr -SynMenu DE.Dylan.Dylan\ lid:dylanlid - -SynMenu DE.EDIF:edif -SynMenu DE.Eiffel:eiffel -SynMenu DE.Elinks\ config:elinks -SynMenu DE.Elm\ filter\ rules:elmfilt -SynMenu DE.Embedix\ Component\ Description:ecd -SynMenu DE.ERicsson\ LANGuage:erlang -SynMenu DE.ESMTP\ rc:esmtprc -SynMenu DE.ESQL-C:esqlc -SynMenu DE.Essbase\ script:csc -SynMenu DE.Esterel:esterel -SynMenu DE.Eterm\ config:eterm -SynMenu DE.Eviews:eviews -SynMenu DE.Exim\ conf:exim -SynMenu DE.Expect:expect -SynMenu DE.Exports:exports - -SynMenu FG.Fetchmail:fetchmail -SynMenu FG.FlexWiki:flexwiki -SynMenu FG.Focus\ Executable:focexec -SynMenu FG.Focus\ Master:master -SynMenu FG.FORM:form -SynMenu FG.Forth:forth -SynMenu FG.Fortran:fortran -SynMenu FG.FoxPro:foxpro -SynMenu FG.FrameScript:framescript -SynMenu FG.Fstab:fstab -SynMenu FG.Fvwm.Fvwm\ configuration:fvwm1 -SynMenu FG.Fvwm.Fvwm2\ configuration:fvwm2 -SynMenu FG.Fvwm.Fvwm2\ configuration\ with\ M4:fvwm2m4 - -SynMenu FG.GDB\ command\ file:gdb -SynMenu FG.GDMO:gdmo -SynMenu FG.Gedcom:gedcom -SynMenu FG.Git.Output:git -SynMenu FG.Git.Commit:gitcommit -SynMenu FG.Git.Config:gitconfig -SynMenu FG.Git.Rebase:gitrebase -SynMenu FG.Git.Send\ Email:gitsendemail -SynMenu FG.Gkrellmrc:gkrellmrc -SynMenu FG.GP:gp -SynMenu FG.GPG:gpg -SynMenu FG.Group\ file:group -SynMenu FG.Grub:grub -SynMenu FG.GNU\ Server\ Pages:gsp -SynMenu FG.GNUplot:gnuplot -SynMenu FG.GrADS\ scripts:grads -SynMenu FG.Gretl:gretl -SynMenu FG.Groff:groff -SynMenu FG.Groovy:groovy -SynMenu FG.GTKrc:gtkrc - -SynMenu HIJK.Haml:haml -SynMenu HIJK.Hamster:hamster -SynMenu HIJK.Haskell.Haskell:haskell -SynMenu HIJK.Haskell.Haskell-c2hs:chaskell -SynMenu HIJK.Haskell.Haskell-literate:lhaskell -SynMenu HIJK.HASTE:haste -SynMenu HIJK.HASTE\ preproc:hastepreproc -SynMenu HIJK.Hercules:hercules -SynMenu HIJK.Hex\ dump.XXD:xxd -SynMenu HIJK.Hex\ dump.Intel\ MCS51:hex -SynMenu HIJK.HTML.HTML:html -SynMenu HIJK.HTML.HTML\ with\ M4:htmlm4 -SynMenu HIJK.HTML.HTML\ with\ Ruby\ (eRuby):eruby -SynMenu HIJK.HTML.Cheetah\ HTML\ template:htmlcheetah -SynMenu HIJK.HTML.Django\ HTML\ template:htmldjango -SynMenu HIJK.HTML.HTML/OS:htmlos -SynMenu HIJK.HTML.XHTML:xhtml -SynMenu HIJK.Host\.conf:hostconf -SynMenu HIJK.Hyper\ Builder:hb -SynMenu HIJK.Icewm\ menu:icemenu -SynMenu HIJK.Icon:icon -SynMenu HIJK.IDL\Generic\ IDL:idl -SynMenu HIJK.IDL\Microsoft\ IDL:msidl -SynMenu HIJK.Indent\ profile:indent -SynMenu HIJK.Inform:inform -SynMenu HIJK.Informix\ 4GL:fgl -SynMenu HIJK.Initng:initng -SynMenu HIJK.Inittab:inittab -SynMenu HIJK.Inno\ setup:iss -SynMenu HIJK.InstallShield\ script:ishd -SynMenu HIJK.Interactive\ Data\ Lang:idlang -SynMenu HIJK.IPfilter:ipfilter -SynMenu HIJK.JAL:jal -SynMenu HIJK.JAM:jam -SynMenu HIJK.Jargon:jargon -SynMenu HIJK.Java.Java:java -SynMenu HIJK.Java.JavaCC:javacc -SynMenu HIJK.Java.Java\ Server\ Pages:jsp -SynMenu HIJK.Java.Java\ Properties:jproperties -SynMenu HIJK.JavaScript:javascript -SynMenu HIJK.Jess:jess -SynMenu HIJK.Jgraph:jgraph -SynMenu HIJK.Kconfig:kconfig -SynMenu HIJK.KDE\ script:kscript -SynMenu HIJK.Kimwitu++:kwt -SynMenu HIJK.KixTart:kix - -SynMenu L-Ma.Lace:lace -SynMenu L-Ma.LamdaProlog:lprolog -SynMenu L-Ma.Latte:latte -SynMenu L-Ma.Ld\ script:ld -SynMenu L-Ma.LDAP.LDIF:ldif -SynMenu L-Ma.LDAP.Configuration:ldapconf -SynMenu L-Ma.Lex:lex -SynMenu L-Ma.LFTP\ config:lftp -SynMenu L-Ma.Libao:libao -SynMenu L-Ma.LifeLines\ script:lifelines -SynMenu L-Ma.Lilo:lilo -SynMenu L-Ma.Limits\ config:limits -SynMenu L-Ma.Linden\ scripting:lsl -SynMenu L-Ma.Lisp:lisp -SynMenu L-Ma.Lite:lite -SynMenu L-Ma.LiteStep\ RC:litestep -SynMenu L-Ma.Locale\ Input:fdcc -SynMenu L-Ma.Login\.access:loginaccess -SynMenu L-Ma.Login\.defs:logindefs -SynMenu L-Ma.Logtalk:logtalk -SynMenu L-Ma.LOTOS:lotos -SynMenu L-Ma.LotusScript:lscript -SynMenu L-Ma.Lout:lout -SynMenu L-Ma.LPC:lpc -SynMenu L-Ma.Lua:lua -SynMenu L-Ma.Lynx\ Style:lss -SynMenu L-Ma.Lynx\ config:lynx -SynMenu L-Ma.M4:m4 -SynMenu L-Ma.MaGic\ Point:mgp -SynMenu L-Ma.Mail:mail -SynMenu L-Ma.Mail\ aliases:mailaliases -SynMenu L-Ma.Mailcap:mailcap -SynMenu L-Ma.Makefile:make -SynMenu L-Ma.MakeIndex:ist -SynMenu L-Ma.Man\ page:man -SynMenu L-Ma.Man\.conf:manconf -SynMenu L-Ma.Maple\ V:maple -SynMenu L-Ma.Mason:mason -SynMenu L-Ma.Mathematica:mma -SynMenu L-Ma.Matlab:matlab -SynMenu L-Ma.Maxima:maxima - -SynMenu Me-NO.MEL\ (for\ Maya):mel -SynMenu Me-NO.Messages\ (/var/log):messages -SynMenu Me-NO.Metafont:mf -SynMenu Me-NO.MetaPost:mp -SynMenu Me-NO.MGL:mgl -SynMenu Me-NO.MMIX:mmix -SynMenu Me-NO.Modconf:modconf -SynMenu Me-NO.Model:model -SynMenu Me-NO.Modsim\ III:modsim3 -SynMenu Me-NO.Modula\ 2:modula2 -SynMenu Me-NO.Modula\ 3:modula3 -SynMenu Me-NO.Monk:monk -SynMenu Me-NO.Mplayer\ config:mplayerconf -SynMenu Me-NO.MOO:moo -SynMenu Me-NO.Mrxvtrc:mrxvtrc -SynMenu Me-NO.MS-DOS/Windows.4DOS\ \.bat\ file:btm -SynMenu Me-NO.MS-DOS/Windows.\.bat\/\.cmd\ file:dosbatch -SynMenu Me-NO.MS-DOS/Windows.\.ini\ file:dosini -SynMenu Me-NO.MS-DOS/Windows.Message\ text:msmessages -SynMenu Me-NO.MS-DOS/Windows.Module\ Definition:def -SynMenu Me-NO.MS-DOS/Windows.Registry:registry -SynMenu Me-NO.MS-DOS/Windows.Resource\ file:rc -SynMenu Me-NO.Msql:msql -SynMenu Me-NO.MuPAD:mupad -SynMenu Me-NO.MUSHcode:mush -SynMenu Me-NO.Muttrc:muttrc -SynMenu Me-NO.Nanorc:nanorc -SynMenu Me-NO.Nastran\ input/DMAP:nastran -SynMenu Me-NO.Natural:natural -SynMenu Me-NO.Netrc:netrc -SynMenu Me-NO.Novell\ NCF\ batch:ncf -SynMenu Me-NO.Not\ Quite\ C\ (LEGO):nqc -SynMenu Me-NO.Nroff:nroff -SynMenu Me-NO.NSIS\ script:nsis -SynMenu Me-NO.Objective\ C:objc -SynMenu Me-NO.Objective\ C++:objcpp -SynMenu Me-NO.OCAML:ocaml -SynMenu Me-NO.Occam:occam -SynMenu Me-NO.Omnimark:omnimark -SynMenu Me-NO.OpenROAD:openroad -SynMenu Me-NO.Open\ Psion\ Lang:opl -SynMenu Me-NO.Oracle\ config:ora - -SynMenu PQ.Packet\ filter\ conf:pf -SynMenu PQ.Palm\ resource\ compiler:pilrc -SynMenu PQ.Pam\ config:pamconf -SynMenu PQ.PApp:papp -SynMenu PQ.Pascal:pascal -SynMenu PQ.Password\ file:passwd -SynMenu PQ.PCCTS:pccts -SynMenu PQ.PDF:pdf -SynMenu PQ.Perl.Perl:perl -SynMenu PQ.Perl.Perl\ POD:pod -SynMenu PQ.Perl.Perl\ XS:xs -SynMenu PQ.PHP.PHP\ 3-4:php -SynMenu PQ.PHP.Phtml\ (PHP\ 2):phtml -SynMenu PQ.Pike:pike -SynMenu PQ.Pine\ RC:pine -SynMenu PQ.Pinfo\ RC:pinfo -SynMenu PQ.PL/M:plm -SynMenu PQ.PL/SQL:plsql -SynMenu PQ.PLP:plp -SynMenu PQ.PO\ (GNU\ gettext):po -SynMenu PQ.Postfix\ main\ config:pfmain -SynMenu PQ.PostScript.PostScript:postscr -SynMenu PQ.PostScript.PostScript\ Printer\ Description:ppd -SynMenu PQ.Povray.Povray\ scene\ descr:pov -SynMenu PQ.Povray.Povray\ configuration:povini -SynMenu PQ.PPWizard:ppwiz -SynMenu PQ.Prescribe\ (Kyocera):prescribe -SynMenu PQ.Printcap:pcap -SynMenu PQ.Privoxy:privoxy -SynMenu PQ.Procmail:procmail -SynMenu PQ.Product\ Spec\ File:psf -SynMenu PQ.Progress:progress -SynMenu PQ.Prolog:prolog -SynMenu PQ.ProMeLa:promela -SynMenu PQ.Protocols:protocols -SynMenu PQ.Purify\ log:purifylog -SynMenu PQ.Pyrex:pyrex -SynMenu PQ.Python:python -SynMenu PQ.Quake:quake -SynMenu PQ.Quickfix\ window:qf - -SynMenu R-Sg.R.R:r -SynMenu R-Sg.R.R\ help:rhelp -SynMenu R-Sg.R.R\ noweb:rnoweb -SynMenu R-Sg.Racc\ input:racc -SynMenu R-Sg.Radiance:radiance -SynMenu R-Sg.Ratpoison:ratpoison -SynMenu R-Sg.RCS.RCS\ log\ output:rcslog -SynMenu R-Sg.RCS.RCS\ file:rcs -SynMenu R-Sg.Readline\ config:readline -SynMenu R-Sg.Rebol:rebol -SynMenu R-Sg.Remind:remind -SynMenu R-Sg.Relax\ NG\ compact:rnc -SynMenu R-Sg.Renderman.Renderman\ Shader\ Lang:sl -SynMenu R-Sg.Renderman.Renderman\ Interface\ Bytestream:rib -SynMenu R-Sg.Resolv\.conf:resolv -SynMenu R-Sg.Reva\ Forth:reva -SynMenu R-Sg.Rexx:rexx -SynMenu R-Sg.Robots\.txt:robots -SynMenu R-Sg.RockLinux\ package\ desc\.:desc -SynMenu R-Sg.Rpcgen:rpcgen -SynMenu R-Sg.RPL/2:rpl -SynMenu R-Sg.ReStructuredText:rst -SynMenu R-Sg.RTF:rtf -SynMenu R-Sg.Ruby:ruby -SynMenu R-Sg.S-Lang:slang -SynMenu R-Sg.Samba\ config:samba -SynMenu R-Sg.SAS:sas -SynMenu R-Sg.Sass:sass -SynMenu R-Sg.Sather:sather -SynMenu R-Sg.Scheme:scheme -SynMenu R-Sg.Scilab:scilab -SynMenu R-Sg.Screen\ RC:screen -SynMenu R-Sg.SDL:sdl -SynMenu R-Sg.Sed:sed -SynMenu R-Sg.Sendmail\.cf:sm -SynMenu R-Sg.Send-pr:sendpr -SynMenu R-Sg.Sensors\.conf:sensors -SynMenu R-Sg.Service\ Location\ config:slpconf -SynMenu R-Sg.Service\ Location\ registration:slpreg -SynMenu R-Sg.Service\ Location\ SPI:slpspi -SynMenu R-Sg.Services:services -SynMenu R-Sg.Setserial\ config:setserial -SynMenu R-Sg.SGML.SGML\ catalog:catalog -SynMenu R-Sg.SGML.SGML\ DTD:sgml -SynMenu R-Sg.SGML.SGML\ Declaration:sgmldecl -SynMenu R-Sg.SGML.SGML-linuxdoc:sgmllnx - -SynMenu Sh-S.Shell\ script.sh\ and\ ksh:sh -SynMenu Sh-S.Shell\ script.csh:csh -SynMenu Sh-S.Shell\ script.tcsh:tcsh -SynMenu Sh-S.Shell\ script.zsh:zsh -SynMenu Sh-S.SiCAD:sicad -SynMenu Sh-S.Sieve:sieve -SynMenu Sh-S.Simula:simula -SynMenu Sh-S.Sinda.Sinda\ compare:sindacmp -SynMenu Sh-S.Sinda.Sinda\ input:sinda -SynMenu Sh-S.Sinda.Sinda\ output:sindaout -SynMenu Sh-S.SiSU:sisu -SynMenu Sh-S.SKILL.SKILL:skill -SynMenu Sh-S.SKILL.SKILL\ for\ Diva:diva -SynMenu Sh-S.Slice:slice -SynMenu Sh-S.SLRN.Slrn\ rc:slrnrc -SynMenu Sh-S.SLRN.Slrn\ score:slrnsc -SynMenu Sh-S.SmallTalk:st -SynMenu Sh-S.Smarty\ Templates:smarty -SynMenu Sh-S.SMIL:smil -SynMenu Sh-S.SMITH:smith -SynMenu Sh-S.SNMP\ MIB:mib -SynMenu Sh-S.SNNS.SNNS\ network:snnsnet -SynMenu Sh-S.SNNS.SNNS\ pattern:snnspat -SynMenu Sh-S.SNNS.SNNS\ result:snnsres -SynMenu Sh-S.Snobol4:snobol4 -SynMenu Sh-S.Snort\ Configuration:hog -SynMenu Sh-S.SPEC\ (Linux\ RPM):spec -SynMenu Sh-S.Specman:specman -SynMenu Sh-S.Spice:spice -SynMenu Sh-S.Spyce:spyce -SynMenu Sh-S.Speedup:spup -SynMenu Sh-S.Splint:splint -SynMenu Sh-S.Squid\ config:squid -SynMenu Sh-S.SQL.ESQL-C:esqlc -SynMenu Sh-S.SQL.MySQL:mysql -SynMenu Sh-S.SQL.PL/SQL:plsql -SynMenu Sh-S.SQL.SQL\ Anywhere:sqlanywhere -SynMenu Sh-S.SQL.SQL\ (automatic):sql -SynMenu Sh-S.SQL.SQL\ (Oracle):sqloracle -SynMenu Sh-S.SQL.SQL\ Forms:sqlforms -SynMenu Sh-S.SQL.SQLJ:sqlj -SynMenu Sh-S.SQL.SQL-Informix:sqlinformix -SynMenu Sh-S.SQR:sqr -SynMenu Sh-S.Ssh.ssh_config:sshconfig -SynMenu Sh-S.Ssh.sshd_config:sshdconfig -SynMenu Sh-S.Standard\ ML:sml -SynMenu Sh-S.Stata.SMCL:smcl -SynMenu Sh-S.Stata.Stata:stata -SynMenu Sh-S.Stored\ Procedures:stp -SynMenu Sh-S.Strace:strace -SynMenu Sh-S.Streaming\ descriptor\ file:sd -SynMenu Sh-S.Subversion\ commit:svn -SynMenu Sh-S.Sudoers:sudoers -SynMenu Sh-S.Symbian\ meta-makefile:mmp -SynMenu Sh-S.Sysctl\.conf:sysctl - -SynMenu TUV.TADS:tads -SynMenu TUV.Tags:tags -SynMenu TUV.TAK.TAK\ compare:takcmp -SynMenu TUV.TAK.TAK\ input:tak -SynMenu TUV.TAK.TAK\ output:takout -SynMenu TUV.Tcl/Tk:tcl -SynMenu TUV.TealInfo:tli -SynMenu TUV.Telix\ Salt:tsalt -SynMenu TUV.Termcap/Printcap:ptcap -SynMenu TUV.Terminfo:terminfo -SynMenu TUV.TeX.TeX/LaTeX:tex -SynMenu TUV.TeX.plain\ TeX:plaintex -SynMenu TUV.TeX.ConTeXt:context -SynMenu TUV.TeX.TeX\ configuration:texmf -SynMenu TUV.TeX.Texinfo:texinfo -SynMenu TUV.TF\ mud\ client:tf -SynMenu TUV.Tidy\ configuration:tidy -SynMenu TUV.Tilde:tilde -SynMenu TUV.TPP:tpp -SynMenu TUV.Trasys\ input:trasys -SynMenu TUV.Trustees:trustees -SynMenu TUV.TSS.Command\ Line:tsscl -SynMenu TUV.TSS.Geometry:tssgm -SynMenu TUV.TSS.Optics:tssop -SynMenu TUV.Udev\ config:udevconf -SynMenu TUV.Udev\ permissions:udevperm -SynMenu TUV.Udev\ rules:udevrules -SynMenu TUV.UIT/UIL:uil -SynMenu TUV.UnrealScript:uc -SynMenu TUV.Updatedb\.conf:updatedb -SynMenu TUV.Valgrind:valgrind -SynMenu TUV.Vera:vera -SynMenu TUV.Verilog-AMS\ HDL:verilogams -SynMenu TUV.Verilog\ HDL:verilog -SynMenu TUV.Vgrindefs:vgrindefs -SynMenu TUV.VHDL:vhdl -SynMenu TUV.Vim.Vim\ help\ file:help -SynMenu TUV.Vim.Vim\ script:vim -SynMenu TUV.Vim.Viminfo\ file:viminfo -SynMenu TUV.Virata\ config:virata -SynMenu TUV.Visual\ Basic:vb -SynMenu TUV.VOS\ CM\ macro:voscm -SynMenu TUV.VRML:vrml -SynMenu TUV.VSE\ JCL:vsejcl - -SynMenu WXYZ.WEB.CWEB:cweb -SynMenu WXYZ.WEB.WEB:web -SynMenu WXYZ.WEB.WEB\ Changes:change -SynMenu WXYZ.Webmacro:webmacro -SynMenu WXYZ.Website\ MetaLanguage:wml -SynMenu WXYZ.wDiff:wdiff -SynMenu WXYZ.Wget\ config:wget -SynMenu WXYZ.Whitespace\ (add):whitespace -SynMenu WXYZ.WildPackets\ EtherPeek\ Decoder:dcd -SynMenu WXYZ.WinBatch/Webbatch:winbatch -SynMenu WXYZ.Windows\ Scripting\ Host:wsh -SynMenu WXYZ.WSML:wsml -SynMenu WXYZ.WvDial:wvdial -SynMenu WXYZ.X\ Keyboard\ Extension:xkb -SynMenu WXYZ.X\ Pixmap:xpm -SynMenu WXYZ.X\ Pixmap\ (2):xpm2 -SynMenu WXYZ.X\ resources:xdefaults -SynMenu WXYZ.XBL:xbl -SynMenu WXYZ.Xinetd\.conf:xinetd -SynMenu WXYZ.Xmodmap:xmodmap -SynMenu WXYZ.Xmath:xmath -SynMenu WXYZ.XML:xml -SynMenu WXYZ.XML\ Schema\ (XSD):xsd -SynMenu WXYZ.XQuery:xquery -SynMenu WXYZ.Xslt:xslt -SynMenu WXYZ.XFree86\ Config:xf86conf -SynMenu WXYZ.YAML:yaml -SynMenu WXYZ.Yacc:yacc - -call append(s:lnum, "") - -wq diff --git a/share/vim/vim72/menu.vim b/share/vim/vim72/menu.vim deleted file mode 100644 index fab890e68e..0000000000 --- a/share/vim/vim72/menu.vim +++ /dev/null @@ -1,1105 +0,0 @@ -" Vim support file to define the default menus -" You can also use this as a start for your own set of menus. -" -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2008 Jun 30 - -" Note that ":an" (short for ":anoremenu") is often used to make a menu work -" in all modes and avoid side effects from mappings defined by the user. - -" Make sure the '<' and 'C' flags are not included in 'cpoptions', otherwise -" <CR> would not be recognized. See ":help 'cpoptions'". -let s:cpo_save = &cpo -set cpo&vim - -" Avoid installing the menus twice -if !exists("did_install_default_menus") -let did_install_default_menus = 1 - - -if exists("v:lang") || &langmenu != "" - " Try to find a menu translation file for the current language. - if &langmenu != "" - if &langmenu =~ "none" - let s:lang = "" - else - let s:lang = &langmenu - endif - else - let s:lang = v:lang - endif - " A language name must be at least two characters, don't accept "C" - if strlen(s:lang) > 1 - " When the language does not include the charset add 'encoding' - if s:lang =~ '^\a\a$\|^\a\a_\a\a$' - let s:lang = s:lang . '.' . &enc - endif - - " We always use a lowercase name. - " Change "iso-8859" to "iso_8859" and "iso8859" to "iso_8859", some - " systems appear to use this. - " Change spaces to underscores. - let s:lang = substitute(tolower(s:lang), '\.iso-', ".iso_", "") - let s:lang = substitute(s:lang, '\.iso8859', ".iso_8859", "") - let s:lang = substitute(s:lang, " ", "_", "g") - " Remove "@euro", otherwise "LC_ALL=de_DE@euro gvim" will show English menus - let s:lang = substitute(s:lang, "@euro", "", "") - " Change "iso_8859-1" and "iso_8859-15" to "latin1", we always use the - " same menu file for them. - let s:lang = substitute(s:lang, 'iso_8859-15\=$', "latin1", "") - menutrans clear - exe "runtime! lang/menu_" . s:lang . ".vim" - - if !exists("did_menu_trans") - " There is no exact match, try matching with a wildcard added - " (e.g. find menu_de_de.iso_8859-1.vim if s:lang == de_DE). - let s:lang = substitute(s:lang, '\.[^.]*', "", "") - exe "runtime! lang/menu_" . s:lang . "[^a-z]*vim" - - if !exists("did_menu_trans") && strlen($LANG) > 1 && s:lang !~ '^en_us' - " On windows locale names are complicated, try using $LANG, it might - " have been set by set_init_1(). But don't do this for "en" or "en_us". - " But don't match "slovak" when $LANG is "sl". - exe "runtime! lang/menu_" . tolower($LANG) . "[^a-z]*vim" - endif - endif - endif -endif - - -" Help menu -an 9999.10 &Help.&Overview<Tab><F1> :help<CR> -an 9999.20 &Help.&User\ Manual :help usr_toc<CR> -an 9999.30 &Help.&How-to\ links :help how-to<CR> -an <silent> 9999.40 &Help.&Find\.\.\. :call <SID>Helpfind()<CR> -an 9999.45 &Help.-sep1- <Nop> -an 9999.50 &Help.&Credits :help credits<CR> -an 9999.60 &Help.Co&pying :help copying<CR> -an 9999.70 &Help.&Sponsor/Register :help sponsor<CR> -an 9999.70 &Help.O&rphans :help kcc<CR> -an 9999.75 &Help.-sep2- <Nop> -an 9999.80 &Help.&Version :version<CR> -an 9999.90 &Help.&About :intro<CR> - -fun! s:Helpfind() - if !exists("g:menutrans_help_dialog") - let g:menutrans_help_dialog = "Enter a command or word to find help on:\n\nPrepend i_ for Input mode commands (e.g.: i_CTRL-X)\nPrepend c_ for command-line editing commands (e.g.: c_<Del>)\nPrepend ' for an option name (e.g.: 'shiftwidth')" - endif - let h = inputdialog(g:menutrans_help_dialog) - if h != "" - let v:errmsg = "" - silent! exe "help " . h - if v:errmsg != "" - echo v:errmsg - endif - endif -endfun - -" File menu -an 10.310 &File.&Open\.\.\.<Tab>:e :browse confirm e<CR> -an 10.320 &File.Sp&lit-Open\.\.\.<Tab>:sp :browse sp<CR> -an 10.320 &File.Open\ Tab\.\.\.<Tab>:tabnew :browse tabnew<CR> -an 10.325 &File.&New<Tab>:enew :confirm enew<CR> -an <silent> 10.330 &File.&Close<Tab>:close - \ :if winheight(2) < 0 <Bar> - \ confirm enew <Bar> - \ else <Bar> - \ confirm close <Bar> - \ endif<CR> -an 10.335 &File.-SEP1- <Nop> -an <silent> 10.340 &File.&Save<Tab>:w :if expand("%") == ""<Bar>browse confirm w<Bar>else<Bar>confirm w<Bar>endif<CR> -an 10.350 &File.Save\ &As\.\.\.<Tab>:sav :browse confirm saveas<CR> - -if has("diff") - an 10.400 &File.-SEP2- <Nop> - an 10.410 &File.Split\ &Diff\ with\.\.\. :browse vert diffsplit<CR> - an 10.420 &File.Split\ Patched\ &By\.\.\. :browse vert diffpatch<CR> -endif - -if has("printer") - an 10.500 &File.-SEP3- <Nop> - an 10.510 &File.&Print :hardcopy<CR> - vunmenu &File.&Print - vnoremenu &File.&Print :hardcopy<CR> -elseif has("unix") - an 10.500 &File.-SEP3- <Nop> - an 10.510 &File.&Print :w !lpr<CR> - vunmenu &File.&Print - vnoremenu &File.&Print :w !lpr<CR> -endif -an 10.600 &File.-SEP4- <Nop> -an 10.610 &File.Sa&ve-Exit<Tab>:wqa :confirm wqa<CR> -an 10.620 &File.E&xit<Tab>:qa :confirm qa<CR> - -func! <SID>SelectAll() - exe "norm gg" . (&slm == "" ? "VG" : "gH\<C-O>G") -endfunc - -func! s:FnameEscape(fname) - if exists('*fnameescape') - return fnameescape(a:fname) - return escape(a:fname, " \t\n*?[{`$\\%#'\"|!<") -endfunc - -" Edit menu -an 20.310 &Edit.&Undo<Tab>u u -an 20.320 &Edit.&Redo<Tab>^R <C-R> -an 20.330 &Edit.Rep&eat<Tab>\. . - -an 20.335 &Edit.-SEP1- <Nop> -vnoremenu 20.340 &Edit.Cu&t<Tab>"+x "+x -vnoremenu 20.350 &Edit.&Copy<Tab>"+y "+y -cnoremenu 20.350 &Edit.&Copy<Tab>"+y <C-Y> -nnoremenu 20.360 &Edit.&Paste<Tab>"+gP "+gP -cnoremenu &Edit.&Paste<Tab>"+gP <C-R>+ -exe 'vnoremenu <script> &Edit.&Paste<Tab>"+gP ' . paste#paste_cmd['v'] -exe 'inoremenu <script> &Edit.&Paste<Tab>"+gP ' . paste#paste_cmd['i'] -nnoremenu 20.370 &Edit.Put\ &Before<Tab>[p [p -inoremenu &Edit.Put\ &Before<Tab>[p <C-O>[p -nnoremenu 20.380 &Edit.Put\ &After<Tab>]p ]p -inoremenu &Edit.Put\ &After<Tab>]p <C-O>]p -if has("win32") || has("win16") - vnoremenu 20.390 &Edit.&Delete<Tab>x x -endif -noremenu <script> <silent> 20.400 &Edit.&Select\ All<Tab>ggVG :<C-U>call <SID>SelectAll()<CR> -inoremenu <script> <silent> 20.400 &Edit.&Select\ All<Tab>ggVG <C-O>:call <SID>SelectAll()<CR> -cnoremenu <script> <silent> 20.400 &Edit.&Select\ All<Tab>ggVG <C-U>call <SID>SelectAll()<CR> - -an 20.405 &Edit.-SEP2- <Nop> -if has("win32") || has("win16") || has("gui_gtk") || has("gui_kde") || has("gui_motif") - an 20.410 &Edit.&Find\.\.\. :promptfind<CR> - vunmenu &Edit.&Find\.\.\. - vnoremenu <silent> &Edit.&Find\.\.\. y:promptfind <C-R>=<SID>FixFText()<CR><CR> - an 20.420 &Edit.Find\ and\ Rep&lace\.\.\. :promptrepl<CR> - vunmenu &Edit.Find\ and\ Rep&lace\.\.\. - vnoremenu <silent> &Edit.Find\ and\ Rep&lace\.\.\. y:promptrepl <C-R>=<SID>FixFText()<CR><CR> -else - an 20.410 &Edit.&Find<Tab>/ / - an 20.420 &Edit.Find\ and\ Rep&lace<Tab>:%s :%s/ - vunmenu &Edit.Find\ and\ Rep&lace<Tab>:%s - vnoremenu &Edit.Find\ and\ Rep&lace<Tab>:s :s/ -endif - -an 20.425 &Edit.-SEP3- <Nop> -an 20.430 &Edit.Settings\ &Window :options<CR> -an 20.435 &Edit.Startup\ &Settings :call <SID>EditVimrc()<CR> - -fun! s:EditVimrc() - if $MYVIMRC != '' - let fname = $MYVIMRC - elseif has("win32") || has("dos32") || has("dos16") || has("os2") - if $HOME != '' - let fname = $HOME . "/_vimrc" - else - let fname = $VIM . "/_vimrc" - endif - elseif has("amiga") - let fname = "s:.vimrc" - else - let fname = $HOME . "/.vimrc" - endif - let fname = s:FnameEscape(fname) - if &mod - exe "split " . fname - else - exe "edit " . fname - endif -endfun - -fun! s:FixFText() - " Fix text in nameless register to be used with :promptfind. - return substitute(@", "[\r\n]", '\\n', 'g') -endfun - -" Edit/Global Settings -an 20.440.100 &Edit.&Global\ Settings.Toggle\ Pattern\ &Highlight<Tab>:set\ hls! :set hls! hls?<CR> -an 20.440.110 &Edit.&Global\ Settings.Toggle\ &Ignore-case<Tab>:set\ ic! :set ic! ic?<CR> -an 20.440.110 &Edit.&Global\ Settings.Toggle\ &Showmatch<Tab>:set\ sm! :set sm! sm?<CR> - -an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 1\ :set so=1<CR> -an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 2\ :set so=2<CR> -an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 3\ :set so=3<CR> -an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 4\ :set so=4<CR> -an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 5\ :set so=5<CR> -an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 7\ :set so=7<CR> -an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 10\ :set so=10<CR> -an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 100\ :set so=100<CR> - -an 20.440.130.40 &Edit.&Global\ Settings.&Virtual\ Edit.Never :set ve=<CR> -an 20.440.130.50 &Edit.&Global\ Settings.&Virtual\ Edit.Block\ Selection :set ve=block<CR> -an 20.440.130.60 &Edit.&Global\ Settings.&Virtual\ Edit.Insert\ mode :set ve=insert<CR> -an 20.440.130.70 &Edit.&Global\ Settings.&Virtual\ Edit.Block\ and\ Insert :set ve=block,insert<CR> -an 20.440.130.80 &Edit.&Global\ Settings.&Virtual\ Edit.Always :set ve=all<CR> -an 20.440.140 &Edit.&Global\ Settings.Toggle\ Insert\ &Mode<Tab>:set\ im! :set im!<CR> -an 20.440.145 &Edit.&Global\ Settings.Toggle\ Vi\ C&ompatible<Tab>:set\ cp! :set cp!<CR> -an <silent> 20.440.150 &Edit.&Global\ Settings.Search\ &Path\.\.\. :call <SID>SearchP()<CR> -an <silent> 20.440.160 &Edit.&Global\ Settings.Ta&g\ Files\.\.\. :call <SID>TagFiles()<CR> -" -" GUI options -an 20.440.300 &Edit.&Global\ Settings.-SEP1- <Nop> -an <silent> 20.440.310 &Edit.&Global\ Settings.Toggle\ &Toolbar :call <SID>ToggleGuiOption("T")<CR> -an <silent> 20.440.320 &Edit.&Global\ Settings.Toggle\ &Bottom\ Scrollbar :call <SID>ToggleGuiOption("b")<CR> -an <silent> 20.440.330 &Edit.&Global\ Settings.Toggle\ &Left\ Scrollbar :call <SID>ToggleGuiOption("l")<CR> -an <silent> 20.440.340 &Edit.&Global\ Settings.Toggle\ &Right\ Scrollbar :call <SID>ToggleGuiOption("r")<CR> - -fun! s:SearchP() - if !exists("g:menutrans_path_dialog") - let g:menutrans_path_dialog = "Enter search path for files.\nSeparate directory names with a comma." - endif - let n = inputdialog(g:menutrans_path_dialog, substitute(&path, '\\ ', ' ', 'g')) - if n != "" - let &path = substitute(n, ' ', '\\ ', 'g') - endif -endfun - -fun! s:TagFiles() - if !exists("g:menutrans_tags_dialog") - let g:menutrans_tags_dialog = "Enter names of tag files.\nSeparate the names with a comma." - endif - let n = inputdialog(g:menutrans_tags_dialog, substitute(&tags, '\\ ', ' ', 'g')) - if n != "" - let &tags = substitute(n, ' ', '\\ ', 'g') - endif -endfun - -fun! s:ToggleGuiOption(option) - " If a:option is already set in guioptions, then we want to remove it - if match(&guioptions, "\\C" . a:option) > -1 - exec "set go-=" . a:option - else - exec "set go+=" . a:option - endif -endfun - -" Edit/File Settings - -" Boolean options -an 20.440.100 &Edit.F&ile\ Settings.Toggle\ Line\ &Numbering<Tab>:set\ nu! :set nu! nu?<CR> -an 20.440.110 &Edit.F&ile\ Settings.Toggle\ &List\ Mode<Tab>:set\ list! :set list! list?<CR> -an 20.440.120 &Edit.F&ile\ Settings.Toggle\ Line\ &Wrap<Tab>:set\ wrap! :set wrap! wrap?<CR> -an 20.440.130 &Edit.F&ile\ Settings.Toggle\ W&rap\ at\ word<Tab>:set\ lbr! :set lbr! lbr?<CR> -an 20.440.160 &Edit.F&ile\ Settings.Toggle\ &expand-tab<Tab>:set\ et! :set et! et?<CR> -an 20.440.170 &Edit.F&ile\ Settings.Toggle\ &auto-indent<Tab>:set\ ai! :set ai! ai?<CR> -an 20.440.180 &Edit.F&ile\ Settings.Toggle\ &C-indenting<Tab>:set\ cin! :set cin! cin?<CR> - -" other options -an 20.440.600 &Edit.F&ile\ Settings.-SEP2- <Nop> -an 20.440.610.20 &Edit.F&ile\ Settings.&Shiftwidth.2 :set sw=2 sw?<CR> -an 20.440.610.30 &Edit.F&ile\ Settings.&Shiftwidth.3 :set sw=3 sw?<CR> -an 20.440.610.40 &Edit.F&ile\ Settings.&Shiftwidth.4 :set sw=4 sw?<CR> -an 20.440.610.50 &Edit.F&ile\ Settings.&Shiftwidth.5 :set sw=5 sw?<CR> -an 20.440.610.60 &Edit.F&ile\ Settings.&Shiftwidth.6 :set sw=6 sw?<CR> -an 20.440.610.80 &Edit.F&ile\ Settings.&Shiftwidth.8 :set sw=8 sw?<CR> - -an 20.440.620.20 &Edit.F&ile\ Settings.Soft\ &Tabstop.2 :set sts=2 sts?<CR> -an 20.440.620.30 &Edit.F&ile\ Settings.Soft\ &Tabstop.3 :set sts=3 sts?<CR> -an 20.440.620.40 &Edit.F&ile\ Settings.Soft\ &Tabstop.4 :set sts=4 sts?<CR> -an 20.440.620.50 &Edit.F&ile\ Settings.Soft\ &Tabstop.5 :set sts=5 sts?<CR> -an 20.440.620.60 &Edit.F&ile\ Settings.Soft\ &Tabstop.6 :set sts=6 sts?<CR> -an 20.440.620.80 &Edit.F&ile\ Settings.Soft\ &Tabstop.8 :set sts=8 sts?<CR> - -an <silent> 20.440.630 &Edit.F&ile\ Settings.Te&xt\ Width\.\.\. :call <SID>TextWidth()<CR> -an <silent> 20.440.640 &Edit.F&ile\ Settings.&File\ Format\.\.\. :call <SID>FileFormat()<CR> -fun! s:TextWidth() - if !exists("g:menutrans_textwidth_dialog") - let g:menutrans_textwidth_dialog = "Enter new text width (0 to disable formatting): " - endif - let n = inputdialog(g:menutrans_textwidth_dialog, &tw) - if n != "" - " remove leading zeros to avoid it being used as an octal number - let &tw = substitute(n, "^0*", "", "") - endif -endfun - -fun! s:FileFormat() - if !exists("g:menutrans_fileformat_dialog") - let g:menutrans_fileformat_dialog = "Select format for writing the file" - endif - if !exists("g:menutrans_fileformat_choices") - let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\n&Cancel" - endif - if &ff == "dos" - let def = 2 - elseif &ff == "mac" - let def = 3 - else - let def = 1 - endif - let n = confirm(g:menutrans_fileformat_dialog, g:menutrans_fileformat_choices, def, "Question") - if n == 1 - set ff=unix - elseif n == 2 - set ff=dos - elseif n == 3 - set ff=mac - endif -endfun - -" Setup the Edit.Color Scheme submenu -let s:n = globpath(&runtimepath, "colors/*.vim") -let s:idx = 100 -while strlen(s:n) > 0 - let s:i = stridx(s:n, "\n") - if s:i < 0 - let s:name = s:n - let s:n = "" - else - let s:name = strpart(s:n, 0, s:i) - let s:n = strpart(s:n, s:i + 1, 19999) - endif - " Ignore case for VMS and windows - let s:name = substitute(s:name, '\c.*[/\\:\]]\([^/\\:]*\)\.vim', '\1', '') - exe "an 20.450." . s:idx . ' &Edit.C&olor\ Scheme.' . s:name . " :colors " . s:name . "<CR>" - unlet s:name - unlet s:i - let s:idx = s:idx + 10 -endwhile -unlet s:n -unlet s:idx - -" Setup the Edit.Keymap submenu -if has("keymap") - let s:n = globpath(&runtimepath, "keymap/*.vim") - if s:n != "" - let s:idx = 100 - an 20.460.90 &Edit.&Keymap.None :set keymap=<CR> - while strlen(s:n) > 0 - let s:i = stridx(s:n, "\n") - if s:i < 0 - let s:name = s:n - let s:n = "" - else - let s:name = strpart(s:n, 0, s:i) - let s:n = strpart(s:n, s:i + 1, 19999) - endif - " Ignore case for VMS and windows - let s:name = substitute(s:name, '\c.*[/\\:\]]\([^/\\:_]*\)\(_[0-9a-zA-Z-]*\)\=\.vim', '\1', '') - exe "an 20.460." . s:idx . ' &Edit.&Keymap.' . s:name . " :set keymap=" . s:name . "<CR>" - unlet s:name - unlet s:i - let s:idx = s:idx + 10 - endwhile - unlet s:idx - endif - unlet s:n -endif -if has("win32") || has("win16") || has("gui_motif") || has("gui_gtk") || has("gui_kde") || has("gui_photon") || has("gui_mac") - an 20.470 &Edit.Select\ Fo&nt\.\.\. :set guifont=*<CR> -endif - -" Programming menu -if !exists("g:ctags_command") - if has("vms") - let g:ctags_command = "mc vim:ctags *.*" - else - let g:ctags_command = "ctags -R ." - endif -endif - -an 40.300 &Tools.&Jump\ to\ this\ tag<Tab>g^] g<C-]> -vunmenu &Tools.&Jump\ to\ this\ tag<Tab>g^] -vnoremenu &Tools.&Jump\ to\ this\ tag<Tab>g^] g<C-]> -an 40.310 &Tools.Jump\ &back<Tab>^T <C-T> -an 40.320 &Tools.Build\ &Tags\ File :exe "!" . g:ctags_command<CR> - -if has("folding") || has("spell") - an 40.330 &Tools.-SEP1- <Nop> -endif - -" Tools.Spelling Menu -if has("spell") - an 40.335.110 &Tools.&Spelling.&Spell\ Check\ On :set spell<CR> - an 40.335.120 &Tools.&Spelling.Spell\ Check\ &Off :set nospell<CR> - an 40.335.130 &Tools.&Spelling.To\ &Next\ error<Tab>]s ]s - an 40.335.130 &Tools.&Spelling.To\ &Previous\ error<Tab>[s [s - an 40.335.140 &Tools.&Spelling.Suggest\ &Corrections<Tab>z= z= - an 40.335.150 &Tools.&Spelling.&Repeat\ correction<Tab>:spellrepall :spellrepall<CR> - an 40.335.200 &Tools.&Spelling.-SEP1- <Nop> - an 40.335.210 &Tools.&Spelling.Set\ language\ to\ "en" :set spl=en spell<CR> - an 40.335.220 &Tools.&Spelling.Set\ language\ to\ "en_au" :set spl=en_au spell<CR> - an 40.335.230 &Tools.&Spelling.Set\ language\ to\ "en_ca" :set spl=en_ca spell<CR> - an 40.335.240 &Tools.&Spelling.Set\ language\ to\ "en_gb" :set spl=en_gb spell<CR> - an 40.335.250 &Tools.&Spelling.Set\ language\ to\ "en_nz" :set spl=en_nz spell<CR> - an 40.335.260 &Tools.&Spelling.Set\ language\ to\ "en_us" :set spl=en_us spell<CR> - an <silent> 40.335.270 &Tools.&Spelling.&Find\ More\ Languages :call <SID>SpellLang()<CR> - - let s:undo_spellang = ['aun &Tools.&Spelling.&Find\ More\ Languages'] - func! s:SpellLang() - for cmd in s:undo_spellang - exe "silent! " . cmd - endfor - let s:undo_spellang = [] - - if &enc == "iso-8859-15" - let enc = "latin1" - else - let enc = &enc - endif - - let found = 0 - let s = globpath(&rtp, "spell/*." . enc . ".spl") - if s != "" - let n = 300 - for f in split(s, "\n") - let nm = substitute(f, '.*spell[/\\]\(..\)\.[^/\\]*\.spl', '\1', "") - if nm != "en" && nm !~ '/' - let found += 1 - let menuname = '&Tools.&Spelling.Set\ language\ to\ "' . nm . '"' - exe 'an 40.335.' . n . ' ' . menuname . ' :set spl=' . nm . ' spell<CR>' - let s:undo_spellang += ['aun ' . menuname] - endif - let n += 10 - endfor - endif - if found == 0 - echomsg "Could not find other spell files" - elseif found == 1 - echomsg "Found spell file " . nm - else - echomsg "Found " . found . " more spell files" - endif - " Need to redo this when 'encoding' is changed. - augroup spellmenu - au! EncodingChanged * call <SID>SpellLang() - augroup END - endfun - -endif - -" Tools.Fold Menu -if has("folding") - " open close folds - an 40.340.110 &Tools.&Folding.&Enable/Disable\ folds<Tab>zi zi - an 40.340.120 &Tools.&Folding.&View\ Cursor\ Line<Tab>zv zv - an 40.340.120 &Tools.&Folding.Vie&w\ Cursor\ Line\ only<Tab>zMzx zMzx - an 40.340.130 &Tools.&Folding.C&lose\ more\ folds<Tab>zm zm - an 40.340.140 &Tools.&Folding.&Close\ all\ folds<Tab>zM zM - an 40.340.150 &Tools.&Folding.O&pen\ more\ folds<Tab>zr zr - an 40.340.160 &Tools.&Folding.&Open\ all\ folds<Tab>zR zR - " fold method - an 40.340.200 &Tools.&Folding.-SEP1- <Nop> - an 40.340.210 &Tools.&Folding.Fold\ Met&hod.M&anual :set fdm=manual<CR> - an 40.340.210 &Tools.&Folding.Fold\ Met&hod.I&ndent :set fdm=indent<CR> - an 40.340.210 &Tools.&Folding.Fold\ Met&hod.E&xpression :set fdm=expr<CR> - an 40.340.210 &Tools.&Folding.Fold\ Met&hod.S&yntax :set fdm=syntax<CR> - an 40.340.210 &Tools.&Folding.Fold\ Met&hod.&Diff :set fdm=diff<CR> - an 40.340.210 &Tools.&Folding.Fold\ Met&hod.Ma&rker :set fdm=marker<CR> - " create and delete folds - vnoremenu 40.340.220 &Tools.&Folding.Create\ &Fold<Tab>zf zf - an 40.340.230 &Tools.&Folding.&Delete\ Fold<Tab>zd zd - an 40.340.240 &Tools.&Folding.Delete\ &All\ Folds<Tab>zD zD - " moving around in folds - an 40.340.300 &Tools.&Folding.-SEP2- <Nop> - an 40.340.310.10 &Tools.&Folding.Fold\ col&umn\ width.\ &0\ :set fdc=0<CR> - an 40.340.310.20 &Tools.&Folding.Fold\ col&umn\ width.\ &2\ :set fdc=2<CR> - an 40.340.310.30 &Tools.&Folding.Fold\ col&umn\ width.\ &3\ :set fdc=3<CR> - an 40.340.310.40 &Tools.&Folding.Fold\ col&umn\ width.\ &4\ :set fdc=4<CR> - an 40.340.310.50 &Tools.&Folding.Fold\ col&umn\ width.\ &5\ :set fdc=5<CR> - an 40.340.310.60 &Tools.&Folding.Fold\ col&umn\ width.\ &6\ :set fdc=6<CR> - an 40.340.310.70 &Tools.&Folding.Fold\ col&umn\ width.\ &7\ :set fdc=7<CR> - an 40.340.310.80 &Tools.&Folding.Fold\ col&umn\ width.\ &8\ :set fdc=8<CR> -endif " has folding - -if has("diff") - an 40.350.100 &Tools.&Diff.&Update :diffupdate<CR> - an 40.350.110 &Tools.&Diff.&Get\ Block :diffget<CR> - vunmenu &Tools.&Diff.&Get\ Block - vnoremenu &Tools.&Diff.&Get\ Block :diffget<CR> - an 40.350.120 &Tools.&Diff.&Put\ Block :diffput<CR> - vunmenu &Tools.&Diff.&Put\ Block - vnoremenu &Tools.&Diff.&Put\ Block :diffput<CR> -endif - -an 40.358 &Tools.-SEP2- <Nop> -an 40.360 &Tools.&Make<Tab>:make :make<CR> -an 40.370 &Tools.&List\ Errors<Tab>:cl :cl<CR> -an 40.380 &Tools.L&ist\ Messages<Tab>:cl! :cl!<CR> -an 40.390 &Tools.&Next\ Error<Tab>:cn :cn<CR> -an 40.400 &Tools.&Previous\ Error<Tab>:cp :cp<CR> -an 40.410 &Tools.&Older\ List<Tab>:cold :colder<CR> -an 40.420 &Tools.N&ewer\ List<Tab>:cnew :cnewer<CR> -an 40.430.50 &Tools.Error\ &Window.&Update<Tab>:cwin :cwin<CR> -an 40.430.60 &Tools.Error\ &Window.&Open<Tab>:copen :copen<CR> -an 40.430.70 &Tools.Error\ &Window.&Close<Tab>:cclose :cclose<CR> - -an 40.520 &Tools.-SEP3- <Nop> -an <silent> 40.530 &Tools.&Convert\ to\ HEX<Tab>:%!xxd - \ :call <SID>XxdConv()<CR> -an <silent> 40.540 &Tools.Conve&rt\ back<Tab>:%!xxd\ -r - \ :call <SID>XxdBack()<CR> - -" Use a function to do the conversion, so that it also works with 'insertmode' -" set. -func! s:XxdConv() - let mod = &mod - if has("vms") - %!mc vim:xxd - else - call s:XxdFind() - exe '%!"' . g:xxdprogram . '"' - endif - if getline(1) =~ "^0000000:" " only if it worked - set ft=xxd - endif - let &mod = mod -endfun - -func! s:XxdBack() - let mod = &mod - if has("vms") - %!mc vim:xxd -r - else - call s:XxdFind() - exe '%!"' . g:xxdprogram . '" -r' - endif - set ft= - doautocmd filetypedetect BufReadPost - let &mod = mod -endfun - -func! s:XxdFind() - if !exists("g:xxdprogram") - " On the PC xxd may not be in the path but in the install directory - if (has("win32") || has("dos32")) && !executable("xxd") - let g:xxdprogram = $VIMRUNTIME . (&shellslash ? '/' : '\') . "xxd.exe" - else - let g:xxdprogram = "xxd" - endif - endif -endfun - -" Setup the Tools.Compiler submenu -let s:n = globpath(&runtimepath, "compiler/*.vim") -let s:idx = 100 -while strlen(s:n) > 0 - let s:i = stridx(s:n, "\n") - if s:i < 0 - let s:name = s:n - let s:n = "" - else - let s:name = strpart(s:n, 0, s:i) - let s:n = strpart(s:n, s:i + 1, 19999) - endif - " Ignore case for VMS and windows - let s:name = substitute(s:name, '\c.*[/\\:\]]\([^/\\:]*\)\.vim', '\1', '') - exe "an 30.440." . s:idx . ' &Tools.Se&T\ Compiler.' . s:name . " :compiler " . s:name . "<CR>" - unlet s:name - unlet s:i - let s:idx = s:idx + 10 -endwhile -unlet s:n -unlet s:idx - -if !exists("no_buffers_menu") - -" Buffer list menu -- Setup functions & actions - -" wait with building the menu until after loading 'session' files. Makes -" startup faster. -let s:bmenu_wait = 1 - -if !exists("bmenu_priority") - let bmenu_priority = 60 -endif - -func! s:BMAdd() - if s:bmenu_wait == 0 - " when adding too many buffers, redraw in short format - if s:bmenu_count == &menuitems && s:bmenu_short == 0 - call s:BMShow() - else - call <SID>BMFilename(expand("<afile>"), expand("<abuf>")) - let s:bmenu_count = s:bmenu_count + 1 - endif - endif -endfunc - -func! s:BMRemove() - if s:bmenu_wait == 0 - let name = expand("<afile>") - if isdirectory(name) - return - endif - let munge = <SID>BMMunge(name, expand("<abuf>")) - - if s:bmenu_short == 0 - exe 'silent! aun &Buffers.' . munge - else - exe 'silent! aun &Buffers.' . <SID>BMHash2(munge) . munge - endif - let s:bmenu_count = s:bmenu_count - 1 - endif -endfunc - -" Create the buffer menu (delete an existing one first). -func! s:BMShow(...) - let s:bmenu_wait = 1 - let s:bmenu_short = 1 - let s:bmenu_count = 0 - " - " get new priority, if exists - if a:0 == 1 - let g:bmenu_priority = a:1 - endif - - " remove old menu, if exists; keep one entry to avoid a torn off menu to - " disappear. - silent! unmenu &Buffers - exe 'noremenu ' . g:bmenu_priority . ".1 &Buffers.Dummy l" - silent! unmenu! &Buffers - - " create new menu; set 'cpo' to include the <CR> - let cpo_save = &cpo - set cpo&vim - exe 'an <silent> ' . g:bmenu_priority . ".2 &Buffers.&Refresh\\ menu :call <SID>BMShow()<CR>" - exe 'an ' . g:bmenu_priority . ".4 &Buffers.&Delete :confirm bd<CR>" - exe 'an ' . g:bmenu_priority . ".6 &Buffers.&Alternate :confirm b #<CR>" - exe 'an ' . g:bmenu_priority . ".7 &Buffers.&Next :confirm bnext<CR>" - exe 'an ' . g:bmenu_priority . ".8 &Buffers.&Previous :confirm bprev<CR>" - exe 'an ' . g:bmenu_priority . ".9 &Buffers.-SEP- :" - let &cpo = cpo_save - unmenu &Buffers.Dummy - - " figure out how many buffers there are - let buf = 1 - while buf <= bufnr('$') - if bufexists(buf) && !isdirectory(bufname(buf)) && buflisted(buf) - let s:bmenu_count = s:bmenu_count + 1 - endif - let buf = buf + 1 - endwhile - if s:bmenu_count <= &menuitems - let s:bmenu_short = 0 - endif - - " iterate through buffer list, adding each buffer to the menu: - let buf = 1 - while buf <= bufnr('$') - if bufexists(buf) && !isdirectory(bufname(buf)) && buflisted(buf) - call <SID>BMFilename(bufname(buf), buf) - endif - let buf = buf + 1 - endwhile - let s:bmenu_wait = 0 - aug buffer_list - au! - au BufCreate,BufFilePost * call <SID>BMAdd() - au BufDelete,BufFilePre * call <SID>BMRemove() - aug END -endfunc - -func! s:BMHash(name) - " Make name all upper case, so that chars are between 32 and 96 - let nm = substitute(a:name, ".*", '\U\0', "") - if has("ebcdic") - " HACK: Replace all non alphabetics with 'Z' - " Just to make it work for now. - let nm = substitute(nm, "[^A-Z]", 'Z', "g") - let sp = char2nr('A') - 1 - else - let sp = char2nr(' ') - endif - " convert first six chars into a number for sorting: - return (char2nr(nm[0]) - sp) * 0x800000 + (char2nr(nm[1]) - sp) * 0x20000 + (char2nr(nm[2]) - sp) * 0x1000 + (char2nr(nm[3]) - sp) * 0x80 + (char2nr(nm[4]) - sp) * 0x20 + (char2nr(nm[5]) - sp) -endfunc - -func! s:BMHash2(name) - let nm = substitute(a:name, ".", '\L\0', "") - " Not exactly right for EBCDIC... - if nm[0] < 'a' || nm[0] > 'z' - return '&others.' - elseif nm[0] <= 'd' - return '&abcd.' - elseif nm[0] <= 'h' - return '&efgh.' - elseif nm[0] <= 'l' - return '&ijkl.' - elseif nm[0] <= 'p' - return '&mnop.' - elseif nm[0] <= 't' - return '&qrst.' - else - return '&u-z.' - endif -endfunc - -" insert a buffer name into the buffer menu: -func! s:BMFilename(name, num) - if isdirectory(a:name) - return - endif - let munge = <SID>BMMunge(a:name, a:num) - let hash = <SID>BMHash(munge) - if s:bmenu_short == 0 - let name = 'an ' . g:bmenu_priority . '.' . hash . ' &Buffers.' . munge - else - let name = 'an ' . g:bmenu_priority . '.' . hash . '.' . hash . ' &Buffers.' . <SID>BMHash2(munge) . munge - endif - " set 'cpo' to include the <CR> - let cpo_save = &cpo - set cpo&vim - exe name . ' :confirm b' . a:num . '<CR>' - let &cpo = cpo_save -endfunc - -" Truncate a long path to fit it in a menu item. -if !exists("g:bmenu_max_pathlen") - let g:bmenu_max_pathlen = 35 -endif -func! s:BMTruncName(fname) - let name = a:fname - if g:bmenu_max_pathlen < 5 - let name = "" - else - let len = strlen(name) - if len > g:bmenu_max_pathlen - let amountl = (g:bmenu_max_pathlen / 2) - 2 - let amountr = g:bmenu_max_pathlen - amountl - 3 - let pattern = '^\(.\{,' . amountl . '}\).\{-}\(.\{,' . amountr . '}\)$' - let left = substitute(name, pattern, '\1', '') - let right = substitute(name, pattern, '\2', '') - if strlen(left) + strlen(right) < len - let name = left . '...' . right - endif - endif - endif - return name -endfunc - -func! s:BMMunge(fname, bnum) - let name = a:fname - if name == '' - if !exists("g:menutrans_no_file") - let g:menutrans_no_file = "[No file]" - endif - let name = g:menutrans_no_file - else - let name = fnamemodify(name, ':p:~') - endif - " detach file name and separate it out: - let name2 = fnamemodify(name, ':t') - if a:bnum >= 0 - let name2 = name2 . ' (' . a:bnum . ')' - endif - let name = name2 . "\t" . <SID>BMTruncName(fnamemodify(name,':h')) - let name = escape(name, "\\. \t|") - let name = substitute(name, "&", "&&", "g") - let name = substitute(name, "\n", "^@", "g") - return name -endfunc - -" When just starting Vim, load the buffer menu later -if has("vim_starting") - augroup LoadBufferMenu - au! VimEnter * if !exists("no_buffers_menu") | call <SID>BMShow() | endif - au VimEnter * au! LoadBufferMenu - augroup END -else - call <SID>BMShow() -endif - -endif " !exists("no_buffers_menu") - -" Window menu -an 70.300 &Window.&New<Tab>^Wn <C-W>n -an 70.310 &Window.S&plit<Tab>^Ws <C-W>s -an 70.320 &Window.Sp&lit\ To\ #<Tab>^W^^ <C-W><C-^> -an 70.330 &Window.Split\ &Vertically<Tab>^Wv <C-W>v -if has("vertsplit") - an <silent> 70.332 &Window.Split\ File\ E&xplorer :call MenuExplOpen()<CR> - if !exists("*MenuExplOpen") - fun MenuExplOpen() - if @% == "" - 20vsp . - else - exe "20vsp " . s:FnameEscape(expand("%:p:h")) - endif - endfun - endif -endif -an 70.335 &Window.-SEP1- <Nop> -an 70.340 &Window.&Close<Tab>^Wc :confirm close<CR> -an 70.345 &Window.Close\ &Other(s)<Tab>^Wo :confirm only<CR> -an 70.350 &Window.-SEP2- <Nop> -an 70.355 &Window.Move\ &To.&Top<Tab>^WK <C-W>K -an 70.355 &Window.Move\ &To.&Bottom<Tab>^WJ <C-W>J -an 70.355 &Window.Move\ &To.&Left\ side<Tab>^WH <C-W>H -an 70.355 &Window.Move\ &To.&Right\ side<Tab>^WL <C-W>L -an 70.360 &Window.Rotate\ &Up<Tab>^WR <C-W>R -an 70.362 &Window.Rotate\ &Down<Tab>^Wr <C-W>r -an 70.365 &Window.-SEP3- <Nop> -an 70.370 &Window.&Equal\ Size<Tab>^W= <C-W>= -an 70.380 &Window.&Max\ Height<Tab>^W_ <C-W>_ -an 70.390 &Window.M&in\ Height<Tab>^W1_ <C-W>1_ -an 70.400 &Window.Max\ &Width<Tab>^W\| <C-W>\| -an 70.410 &Window.Min\ Widt&h<Tab>^W1\| <C-W>1\| - -" The popup menu -an 1.10 PopUp.&Undo u -an 1.15 PopUp.-SEP1- <Nop> -vnoremenu 1.20 PopUp.Cu&t "+x -vnoremenu 1.30 PopUp.&Copy "+y -cnoremenu 1.30 PopUp.&Copy <C-Y> -nnoremenu 1.40 PopUp.&Paste "+gP -cnoremenu 1.40 PopUp.&Paste <C-R>+ -exe 'vnoremenu <script> 1.40 PopUp.&Paste ' . paste#paste_cmd['v'] -exe 'inoremenu <script> 1.40 PopUp.&Paste ' . paste#paste_cmd['i'] -vnoremenu 1.50 PopUp.&Delete x -an 1.55 PopUp.-SEP2- <Nop> -vnoremenu 1.60 PopUp.Select\ Blockwise <C-V> - -nnoremenu 1.70 PopUp.Select\ &Word vaw -onoremenu 1.70 PopUp.Select\ &Word aw -vnoremenu 1.70 PopUp.Select\ &Word <C-C>vaw -inoremenu 1.70 PopUp.Select\ &Word <C-O>vaw -cnoremenu 1.70 PopUp.Select\ &Word <C-C>vaw - -nnoremenu 1.73 PopUp.Select\ &Sentence vas -onoremenu 1.73 PopUp.Select\ &Sentence as -vnoremenu 1.73 PopUp.Select\ &Sentence <C-C>vas -inoremenu 1.73 PopUp.Select\ &Sentence <C-O>vas -cnoremenu 1.73 PopUp.Select\ &Sentence <C-C>vas - -nnoremenu 1.77 PopUp.Select\ Pa&ragraph vap -onoremenu 1.77 PopUp.Select\ Pa&ragraph ap -vnoremenu 1.77 PopUp.Select\ Pa&ragraph <C-C>vap -inoremenu 1.77 PopUp.Select\ Pa&ragraph <C-O>vap -cnoremenu 1.77 PopUp.Select\ Pa&ragraph <C-C>vap - -nnoremenu 1.80 PopUp.Select\ &Line V -onoremenu 1.80 PopUp.Select\ &Line <C-C>V -vnoremenu 1.80 PopUp.Select\ &Line <C-C>V -inoremenu 1.80 PopUp.Select\ &Line <C-O>V -cnoremenu 1.80 PopUp.Select\ &Line <C-C>V - -nnoremenu 1.90 PopUp.Select\ &Block <C-V> -onoremenu 1.90 PopUp.Select\ &Block <C-C><C-V> -vnoremenu 1.90 PopUp.Select\ &Block <C-C><C-V> -inoremenu 1.90 PopUp.Select\ &Block <C-O><C-V> -cnoremenu 1.90 PopUp.Select\ &Block <C-C><C-V> - -noremenu <script> <silent> 1.100 PopUp.Select\ &All :<C-U>call <SID>SelectAll()<CR> -inoremenu <script> <silent> 1.100 PopUp.Select\ &All <C-O>:call <SID>SelectAll()<CR> -cnoremenu <script> <silent> 1.100 PopUp.Select\ &All <C-U>call <SID>SelectAll()<CR> - -if has("spell") - " Spell suggestions in the popup menu. Note that this will slow down the - " appearance of the menu! - func! <SID>SpellPopup() - if exists("s:changeitem") && s:changeitem != '' - call <SID>SpellDel() - endif - - " Return quickly if spell checking is not enabled. - if !&spell || &spelllang == '' - return - endif - - let curcol = col('.') - let [w, a] = spellbadword() - if col('.') > curcol " don't use word after the cursor - let w = '' - call cursor(0, curcol) " put the cursor back where it was - endif - if w != '' - if a == 'caps' - let s:suglist = [substitute(w, '.*', '\u&', '')] - else - let s:suglist = spellsuggest(w, 10) - endif - if len(s:suglist) <= 0 - call cursor(0, curcol) " put the cursor back where it was - else - let s:changeitem = 'change\ "' . escape(w, ' .'). '"\ to' - let s:fromword = w - let pri = 1 - for sug in s:suglist - exe 'anoremenu 1.5.' . pri . ' PopUp.' . s:changeitem . '.' . escape(sug, ' .') - \ . ' :call <SID>SpellReplace(' . pri . ')<CR>' - let pri += 1 - endfor - - let s:additem = 'add\ "' . escape(w, ' .') . '"\ to\ word\ list' - exe 'anoremenu 1.6 PopUp.' . s:additem . ' :spellgood ' . w . '<CR>' - - let s:ignoreitem = 'ignore\ "' . escape(w, ' .') . '"' - exe 'anoremenu 1.7 PopUp.' . s:ignoreitem . ' :spellgood! ' . w . '<CR>' - - anoremenu 1.8 PopUp.-SpellSep- : - endif - endif - endfunc - - func! <SID>SpellReplace(n) - let l = getline('.') - call setline('.', strpart(l, 0, col('.') - 1) . s:suglist[a:n - 1] - \ . strpart(l, col('.') + len(s:fromword) - 1)) - endfunc - - func! <SID>SpellDel() - exe "aunmenu PopUp." . s:changeitem - exe "aunmenu PopUp." . s:additem - exe "aunmenu PopUp." . s:ignoreitem - aunmenu PopUp.-SpellSep- - let s:changeitem = '' - endfun - - augroup SpellPopupMenu - au! MenuPopup * call <SID>SpellPopup() - augroup END -endif - -" The GUI toolbar (for MS-Windows and GTK) -if has("toolbar") - an 1.10 ToolBar.Open :browse confirm e<CR> - an <silent> 1.20 ToolBar.Save :if expand("%") == ""<Bar>browse confirm w<Bar>else<Bar>confirm w<Bar>endif<CR> - an 1.30 ToolBar.SaveAll :browse confirm wa<CR> - - if has("printer") - an 1.40 ToolBar.Print :hardcopy<CR> - vunmenu ToolBar.Print - vnoremenu ToolBar.Print :hardcopy<CR> - elseif has("unix") - an 1.40 ToolBar.Print :w !lpr<CR> - vunmenu ToolBar.Print - vnoremenu ToolBar.Print :w !lpr<CR> - endif - - an 1.45 ToolBar.-sep1- <Nop> - an 1.50 ToolBar.Undo u - an 1.60 ToolBar.Redo <C-R> - - an 1.65 ToolBar.-sep2- <Nop> - vnoremenu 1.70 ToolBar.Cut "+x - vnoremenu 1.80 ToolBar.Copy "+y - cnoremenu 1.80 ToolBar.Copy <C-Y> - nnoremenu 1.90 ToolBar.Paste "+gP - cnoremenu ToolBar.Paste <C-R>+ - exe 'vnoremenu <script> ToolBar.Paste ' . paste#paste_cmd['v'] - exe 'inoremenu <script> ToolBar.Paste ' . paste#paste_cmd['i'] - - if !has("gui_athena") - an 1.95 ToolBar.-sep3- <Nop> - an 1.100 ToolBar.Replace :promptrepl<CR> - vunmenu ToolBar.Replace - vnoremenu ToolBar.Replace y:promptrepl <C-R>=<SID>FixFText()<CR><CR> - an 1.110 ToolBar.FindNext n - an 1.120 ToolBar.FindPrev N - endif - - an 1.215 ToolBar.-sep5- <Nop> - an <silent> 1.220 ToolBar.LoadSesn :call <SID>LoadVimSesn()<CR> - an <silent> 1.230 ToolBar.SaveSesn :call <SID>SaveVimSesn()<CR> - an 1.240 ToolBar.RunScript :browse so<CR> - - an 1.245 ToolBar.-sep6- <Nop> - an 1.250 ToolBar.Make :make<CR> - an 1.270 ToolBar.RunCtags :exe "!" . g:ctags_command<CR> - an 1.280 ToolBar.TagJump g<C-]> - - an 1.295 ToolBar.-sep7- <Nop> - an 1.300 ToolBar.Help :help<CR> - an <silent> 1.310 ToolBar.FindHelp :call <SID>Helpfind()<CR> - -" Only set the tooltips here if not done in a language menu file -if exists("*Do_toolbar_tmenu") - call Do_toolbar_tmenu() -else - let did_toolbar_tmenu = 1 - tmenu ToolBar.Open Open file - tmenu ToolBar.Save Save current file - tmenu ToolBar.SaveAll Save all files - tmenu ToolBar.Print Print - tmenu ToolBar.Undo Undo - tmenu ToolBar.Redo Redo - tmenu ToolBar.Cut Cut to clipboard - tmenu ToolBar.Copy Copy to clipboard - tmenu ToolBar.Paste Paste from Clipboard - if !has("gui_athena") - tmenu ToolBar.Find Find... - tmenu ToolBar.FindNext Find Next - tmenu ToolBar.FindPrev Find Previous - tmenu ToolBar.Replace Find / Replace... - endif - tmenu ToolBar.LoadSesn Choose a session to load - tmenu ToolBar.SaveSesn Save current session - tmenu ToolBar.RunScript Choose a Vim Script to run - tmenu ToolBar.Make Make current project (:make) - tmenu ToolBar.RunCtags Build tags in current directory tree (!ctags -R .) - tmenu ToolBar.TagJump Jump to tag under cursor - tmenu ToolBar.Help Vim Help - tmenu ToolBar.FindHelp Search Vim Help -endif - -" Select a session to load; default to current session name if present -fun! s:LoadVimSesn() - if strlen(v:this_session) > 0 - let name = s:FnameEscape(v:this_session) - else - let name = "Session.vim" - endif - execute "browse so " . name -endfun - -" Select a session to save; default to current session name if present -fun! s:SaveVimSesn() - if strlen(v:this_session) == 0 - let v:this_session = "Session.vim" - endif - execute "browse mksession! " . s:FnameEscape(v:this_session) -endfun - -endif - -endif " !exists("did_install_default_menus") - -" Define these items always, so that syntax can be switched on when it wasn't. -" But skip them when the Syntax menu was disabled by the user. -if !exists("did_install_syntax_menu") - an 50.212 &Syntax.&Manual :syn manual<CR> - an 50.214 &Syntax.A&utomatic :syn on<CR> - an <silent> 50.216 &Syntax.on/off\ for\ &This\ file :call <SID>SynOnOff()<CR> - if !exists("*s:SynOnOff") - fun s:SynOnOff() - if has("syntax_items") - syn clear - else - if !exists("g:syntax_on") - syn manual - endif - set syn=ON - endif - endfun - endif -endif - - -" Install the Syntax menu only when filetype.vim has been loaded or when -" manual syntax highlighting is enabled. -" Avoid installing the Syntax menu twice. -if (exists("did_load_filetypes") || exists("syntax_on")) - \ && !exists("did_install_syntax_menu") - let did_install_syntax_menu = 1 - -" Skip setting up the individual syntax selection menus unless -" do_syntax_sel_menu is defined (it takes quite a bit of time). -if exists("do_syntax_sel_menu") - runtime! synmenu.vim -else - an 50.10 &Syntax.&Show\ filetypes\ in\ menu :let do_syntax_sel_menu = 1<Bar>runtime! synmenu.vim<Bar>aunmenu &Syntax.&Show\ filetypes\ in\ menu<CR> - an 50.195 &Syntax.-SEP1- <Nop> -endif - -an 50.210 &Syntax.&Off :syn off<CR> -an 50.700 &Syntax.-SEP3- <Nop> -an 50.710 &Syntax.Co&lor\ test :sp $VIMRUNTIME/syntax/colortest.vim<Bar>so %<CR> -an 50.720 &Syntax.&Highlight\ test :runtime syntax/hitest.vim<CR> -an 50.730 &Syntax.&Convert\ to\ HTML :runtime syntax/2html.vim<CR> - -endif " !exists("did_install_syntax_menu") - -" Restore the previous value of 'cpoptions'. -let &cpo = s:cpo_save -unlet s:cpo_save - -" vim: set sw=2 : diff --git a/share/vim/vim72/optwin.vim b/share/vim/vim72/optwin.vim deleted file mode 100644 index 7392b53bdc..0000000000 --- a/share/vim/vim72/optwin.vim +++ /dev/null @@ -1,1312 +0,0 @@ -" These commands create the option window. -" -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2008 May 12 - -" If there already is an option window, jump to that one. -if bufwinnr("option-window") > 0 - let s:thiswin = winnr() - while 1 - if @% == "option-window" - finish - endif - exe "norm! \<C-W>w" - if s:thiswin == winnr() - break - endif - endwhile -endif - -" Make sure the '<' flag is not included in 'cpoptions', otherwise <CR> would -" not be recognized. See ":help 'cpoptions'". -let s:cpo_save = &cpo -set cpo&vim - -" function to be called when <CR> is hit in the option-window -fun! <SID>CR() - - " If on a continued comment line, go back to the first comment line - let lnum = line(".") - let line = getline(lnum) - while line[0] == "\t" - let lnum = lnum - 1 - let line = getline(lnum) - endwhile - - " <CR> on a "set" line executes the option line - if match(line, "^ \tset ") >= 0 - - " For a local option: go to the previous window - " If this is a help window, go to the window below it - let thiswin = winnr() - let local = <SID>Find(lnum) - if local >= 0 - exe line - call <SID>Update(lnum, line, local, thiswin) - endif - - " <CR> on a "option" line shows help for that option - elseif match(line, "^[a-z]") >= 0 - let name = substitute(line, '\([^\t]*\).*', '\1', "") - exe "help '" . name . "'" - - " <CR> on an index line jumps to the group - elseif match(line, '^ \=[0-9]') >= 0 - exe "norm! /" . line . "\<CR>zt" - endif -endfun - -" function to be called when <Space> is hit in the option-window -fun! <SID>Space() - - let lnum = line(".") - let line = getline(lnum) - - " <Space> on a "set" line refreshes the option line - if match(line, "^ \tset ") >= 0 - - " For a local option: go to the previous window - " If this is a help window, go to the window below it - let thiswin = winnr() - let local = <SID>Find(lnum) - if local >= 0 - call <SID>Update(lnum, line, local, thiswin) - endif - - endif -endfun - -" find the window in which the option applies -" returns 0 for global option, 1 for local option, -1 for error -fun! <SID>Find(lnum) - if getline(a:lnum - 1) =~ "(local to" - let local = 1 - let thiswin = winnr() - exe "norm! \<C-W>p" - if exists("b:current_syntax") && b:current_syntax == "help" - exe "norm! \<C-W>j" - if winnr() == thiswin - exe "norm! \<C-W>j" - endif - endif - else - let local = 0 - endif - if local && (winnr() == thiswin || (exists("b:current_syntax") - \ && b:current_syntax == "help")) - echo "Don't know in which window" - let local = -1 - endif - return local -endfun - -" Update a "set" line in the option window -fun! <SID>Update(lnum, line, local, thiswin) - " get the new value of the option and update the option window line - if match(a:line, "=") >= 0 - let name = substitute(a:line, '^ \tset \([^=]*\)=.*', '\1', "") - else - let name = substitute(a:line, '^ \tset \(no\)\=\([a-z]*\).*', '\2', "") - endif - if name == "pt" && &pt =~ "\x80" - let val = <SID>PTvalue() - else - exe "let val = substitute(&" . name . ', "[ \\t\\\\\"|]", "\\\\\\0", "g")' - endif - if a:local - exe "norm! " . a:thiswin . "\<C-W>w" - endif - if match(a:line, "=") >= 0 || (val != "0" && val != "1") - call setline(a:lnum, " \tset " . name . "=" . val) - else - if val - call setline(a:lnum, " \tset " . name . "\tno" . name) - else - call setline(a:lnum, " \tset no" . name . "\t" . name) - endif - endif - set nomodified -endfun - -" Reset 'title' and 'icon' to make it work faster. -let s:old_title = &title -let s:old_icon = &icon -let s:old_sc = &sc -let s:old_ru = &ru -set notitle noicon nosc noru - -" If the current window is a help window, try finding a non-help window. -" Relies on syntax highlighting to be switched on. -let s:thiswin = winnr() -while exists("b:current_syntax") && b:current_syntax == "help" - exe "norm! \<C-W>w" - if s:thiswin == winnr() - break - endif -endwhile - -" Open the window -new option-window -setlocal ts=15 tw=0 noro - -" Insert help and a "set" command for each option. -call append(0, '" Each "set" line shows the current value of an option (on the left).') -call append(1, '" Hit <CR> on a "set" line to execute it.') -call append(2, '" A boolean option will be toggled.') -call append(3, '" For other options you can edit the value.') -call append(4, '" Hit <CR> on a help line to open a help window on this option.') -call append(5, '" Hit <CR> on an index line to jump there.') -call append(6, '" Hit <Space> on a "set" line to refresh it.') - -" These functions are called often below. Keep them fast! - -" Init a local binary option -fun! <SID>BinOptionL(name) - exe "norm! \<C-W>p" - exe "let val = &" . a:name - exe "norm! \<C-W>p" - call append("$", substitute(substitute(" \tset " . val . a:name . "\t" . - \!val . a:name, "0", "no", ""), "1", "", "")) -endfun - -" Init a global binary option -fun! <SID>BinOptionG(name, val) - call append("$", substitute(substitute(" \tset " . a:val . a:name . "\t" . - \!a:val . a:name, "0", "no", ""), "1", "", "")) -endfun - -" Init a local string option -fun! <SID>OptionL(name) - exe "norm! \<C-W>p" - exe "let val = substitute(&" . a:name . ', "[ \\t\\\\\"|]", "\\\\\\0", "g")' - exe "norm! \<C-W>p" - call append("$", " \tset " . a:name . "=" . val) -endfun - -" Init a global string option -fun! <SID>OptionG(name, val) - call append("$", " \tset " . a:name . "=" . substitute(a:val, '[ \t\\"|]', - \ '\\\0', "g")) -endfun - -let s:idx = 1 -let s:lnum = line("$") -call append("$", "") - -fun! <SID>Header(text) - let line = s:idx . " " . a:text - if s:idx < 10 - let line = " " . line - endif - call append("$", "") - call append("$", line) - call append("$", "") - call append(s:lnum, line) - let s:idx = s:idx + 1 - let s:lnum = s:lnum + 1 -endfun - -" Get the value of 'pastetoggle'. It could be a special key. -fun! <SID>PTvalue() - redir @a - silent set pt - redir END - return substitute(@a, '[^=]*=\(.*\)', '\1', "") -endfun - -" Restore the previous value of 'cpoptions' here, it's used below. -let &cpo = s:cpo_save - -" List of all options, organized by function. -" The text should be sufficient to know what the option is used for. - -call <SID>Header("important") -call append("$", "compatible\tbehave very Vi compatible (not advisable)") -call <SID>BinOptionG("cp", &cp) -call append("$", "cpoptions\tlist of flags to specify Vi compatibility") -call <SID>OptionG("cpo", &cpo) -call append("$", "insertmode\tuse Insert mode as the default mode") -call <SID>BinOptionG("im", &im) -call append("$", "paste\tpaste mode, insert typed text literally") -call <SID>BinOptionG("paste", &paste) -call append("$", "pastetoggle\tkey sequence to toggle paste mode") -if &pt =~ "\x80" - call append("$", " \tset pt=" . <SID>PTvalue()) -else - call <SID>OptionG("pt", &pt) -endif -call append("$", "runtimepath\tlist of directories used for runtime files and plugins") -call <SID>OptionG("rtp", &rtp) -call append("$", "helpfile\tname of the main help file") -call <SID>OptionG("hf", &hf) - - -call <SID>Header("moving around, searching and patterns") -call append("$", "whichwrap\tlist of flags specifying which commands wrap to another line") -call append("$", "\t(local to window)") -call <SID>OptionL("ww") -call append("$", "startofline\tmany jump commands move the cursor to the first non-blank") -call append("$", "\tcharacter of a line") -call <SID>BinOptionG("sol", &sol) -call append("$", "paragraphs\tnroff macro names that separate paragraphs") -call <SID>OptionG("para", ¶) -call append("$", "sections\tnroff macro names that separate sections") -call <SID>OptionG("sect", §) -call append("$", "path\tlist of directory names used for file searching") -call append("$", "\t(global or local to buffer)") -call <SID>OptionG("pa", &pa) -call append("$", "cdpath\tlist of directory names used for :cd") -call <SID>OptionG("cd", &cd) -if has("netbeans_intg") || has("sun_workshop") - call append("$", "autochdir\tchange to directory of file in buffer") - call <SID>BinOptionG("acd", &acd) -endif -call append("$", "wrapscan\tsearch commands wrap around the end of the buffer") -call <SID>BinOptionG("ws", &ws) -call append("$", "incsearch\tshow match for partly typed search command") -call <SID>BinOptionG("is", &is) -call append("$", "magic\tchange the way backslashes are used in search patterns") -call <SID>BinOptionG("magic", &magic) -call append("$", "ignorecase\tignore case when using a search pattern") -call <SID>BinOptionG("ic", &ic) -call append("$", "smartcase\toverride 'ignorecase' when pattern has upper case characters") -call <SID>BinOptionG("scs", &scs) -call append("$", "casemap\tWhat method to use for changing case of letters") -call <SID>OptionG("cmp", &cmp) -call append("$", "maxmempattern\tmaximum amount of memory in Kbyte used for pattern matching") -call append("$", " \tset mmp=" . &mmp) -call append("$", "define\tpattern for a macro definition line") -call append("$", "\t(global or local to buffer)") -call <SID>OptionG("def", &def) -if has("find_in_path") - call append("$", "include\tpattern for an include-file line") - call append("$", "\t(local to buffer)") - call <SID>OptionL("inc") - call append("$", "includeexpr\texpression used to transform an include line to a file name") - call append("$", "\t(local to buffer)") - call <SID>OptionL("inex") -endif - - -call <SID>Header("tags") -call append("$", "tagbsearch\tuse binary searching in tags files") -call <SID>BinOptionG("tbs", &tbs) -call append("$", "taglength\tnumber of significant characters in a tag name or zero") -call append("$", " \tset tl=" . &tl) -call append("$", "tags\tlist of file names to search for tags") -call append("$", "\t(global or local to buffer)") -call <SID>OptionG("tag", &tag) -call append("$", "tagrelative\tfile names in a tags file are relative to the tags file") -call <SID>BinOptionG("tr", &tr) -call append("$", "tagstack\ta :tag command will use the tagstack") -call <SID>BinOptionG("tgst", &tgst) -call append("$", "showfulltag\twhen completing tags in Insert mode show more info") -call <SID>BinOptionG("sft", &sft) -if has("cscope") - call append("$", "cscopeprg\tcommand for executing cscope") - call <SID>OptionG("csprg", &csprg) - call append("$", "cscopetag\tuse cscope for tag commands") - call <SID>BinOptionG("cst", &cst) - call append("$", "cscopetagorder\t0 or 1; the order in which \":cstag\" performs a search") - call append("$", " \tset csto=" . &csto) - call append("$", "cscopeverbose\tgive messages when adding a cscope database") - call <SID>BinOptionG("csverb", &csverb) - call append("$", "cscopepathcomp\thow many components of the path to show") - call append("$", " \tset cspc=" . &cspc) - call append("$", "cscopequickfix\tWhen to open a quickfix window for cscope") - call <SID>OptionG("csqf", &csqf) -endif - - -call <SID>Header("displaying text") -call append("$", "scroll\tnumber of lines to scroll for CTRL-U and CTRL-D") -call append("$", "\t(local to window)") -call <SID>OptionL("scr") -call append("$", "scrolloff\tnumber of screen lines to show around the cursor") -call append("$", " \tset so=" . &so) -call append("$", "wrap\tlong lines wrap") -call <SID>BinOptionG("wrap", &wrap) -call append("$", "linebreak\twrap long lines at a character in 'breakat'") -call append("$", "\t(local to window)") -call <SID>BinOptionL("lbr") -call append("$", "breakat\twhich characters might cause a line break") -call <SID>OptionG("brk", &brk) -call append("$", "showbreak\tstring to put before wrapped screen lines") -call <SID>OptionG("sbr", &sbr) -call append("$", "sidescroll\tminimal number of columns to scroll horizontally") -call append("$", " \tset ss=" . &ss) -call append("$", "sidescrolloff\tminimal number of columns to keep left and right of the cursor") -call append("$", " \tset siso=" . &siso) -call append("$", "display\tinclude \"lastline\" to show the last line even if it doesn't fit") -call append("$", "\tinclude \"uhex\" to show unprintable characters as a hex number") -call <SID>OptionG("dy", &dy) -call append("$", "fillchars\tcharacters to use for the status line, folds and filler lines") -call <SID>OptionG("fcs", &fcs) -call append("$", "cmdheight\tnumber of lines used for the command-line") -call append("$", " \tset ch=" . &ch) -call append("$", "columns\twidth of the display") -call append("$", " \tset co=" . &co) -call append("$", "lines\tnumber of lines in the display") -call append("$", " \tset lines=" . &lines) -call append("$", "lazyredraw\tdon't redraw while executing macros") -call <SID>BinOptionG("lz", &lz) -if has("reltime") - call append("$", "redrawtime\ttimeout for 'hlsearch' and :match highlighting in msec") - call append("$", " \tset rdt=" . &rdt) -endif -call append("$", "writedelay\tdelay in msec for each char written to the display") -call append("$", "\t(for debugging)") -call append("$", " \tset wd=" . &wd) -call append("$", "list\tshow <Tab> as ^I and end-of-line as $") -call append("$", "\t(local to window)") -call <SID>BinOptionL("list") -call append("$", "listchars\tlist of strings used for list mode") -call <SID>OptionG("lcs", &lcs) -call append("$", "number\tshow the line number for each line") -call append("$", "\t(local to window)") -call <SID>BinOptionL("nu") -if has("linebreak") - call append("$", "numberwidth\tnumber of columns to use for the line number") - call append("$", "\t(local to window)") - call <SID>OptionL("nuw") -endif - - -call <SID>Header("syntax, highlighting and spelling") -call append("$", "background\t\"dark\" or \"light\"; the background color brightness") -call <SID>OptionG("bg", &bg) -if has("autocmd") - call append("$", "filetype\ttype of file; triggers the FileType event when set") - call append("$", "\t(local to buffer)") - call <SID>OptionL("ft") -endif -if has("syntax") - call append("$", "syntax\tname of syntax highlighting used") - call append("$", "\t(local to buffer)") - call <SID>OptionL("syn") - call append("$", "synmaxcol\tmaximum column to look for syntax items") - call append("$", "\t(local to buffer)") - call <SID>OptionL("smc") -endif -call append("$", "highlight\twhich highlighting to use for various occasions") -call <SID>OptionG("hl", &hl) -call append("$", "hlsearch\thighlight all matches for the last used search pattern") -call <SID>BinOptionG("hls", &hls) -if has("syntax") - call append("$", "cursorcolumn\thighlight the screen column of the cursor") - call append("$", "\t(local to window)") - call <SID>BinOptionL("cuc") - call append("$", "cursorline\thighlight the screen line of the cursor") - call append("$", "\t(local to window)") - call <SID>BinOptionL("cul") - call append("$", "spell\thighlight spelling mistakes") - call append("$", "\t(local to window)") - call <SID>BinOptionL("spell") - call append("$", "spelllang\tlist of accepted languages") - call append("$", "\t(local to buffer)") - call <SID>OptionL("spl") - call append("$", "spellfile\tfile that \"zg\" adds good words to") - call append("$", "\t(local to buffer)") - call <SID>OptionL("spf") - call append("$", "spellcapcheck\tpattern to locate the end of a sentence") - call append("$", "\t(local to buffer)") - call <SID>OptionL("spc") - call append("$", "spellsuggest\tmethods used to suggest corrections") - call <SID>OptionG("sps", &sps) - call append("$", "mkspellmem\tamount of memory used by :mkspell before compressing") - call <SID>OptionG("msm", &msm) -endif - - -call <SID>Header("multiple windows") -call append("$", "laststatus\t0, 1 or 2; when to use a status line for the last window") -call append("$", " \tset ls=" . &ls) -if has("statusline") - call append("$", "statusline\talternate format to be used for a status line") - call <SID>OptionG("stl", &stl) -endif -call append("$", "equalalways\tmake all windows the same size when adding/removing windows") -call <SID>BinOptionG("ea", &ea) -if has("vertsplit") - call append("$", "eadirection\tin which direction 'equalalways' works: \"ver\", \"hor\" or \"both\"") - call <SID>OptionG("ead", &ead) -endif -call append("$", "winheight\tminimal number of lines used for the current window") -call append("$", " \tset wh=" . &wh) -call append("$", "winminheight\tminimal number of lines used for any window") -call append("$", " \tset wmh=" . &wmh) -call append("$", "winfixheight\tkeep the height of the window") -call append("$", "\t(local to window)") -call <SID>BinOptionL("wfh") -if has("vertsplit") -call append("$", "winfixwidth\tkeep the width of the window") -call append("$", "\t(local to window)") -call <SID>BinOptionL("wfw") - call append("$", "winwidth\tminimal number of columns used for the current window") - call append("$", " \tset wiw=" . &wiw) - call append("$", "winminwidth\tminimal number of columns used for any window") - call append("$", " \tset wmw=" . &wmw) -endif -call append("$", "helpheight\tinitial height of the help window") -call append("$", " \tset hh=" . &hh) -if has("quickfix") - call append("$", "previewheight\tdefault height for the preview window") - call append("$", " \tset pvh=" . &pvh) - call append("$", "previewwindow\tidentifies the preview window") - call append("$", "\t(local to window)") - call <SID>BinOptionL("pvw") -endif -call append("$", "hidden\tdon't unload a buffer when no longer shown in a window") -call <SID>BinOptionG("hid", &hid) -call append("$", "switchbuf\t\"useopen\" and/or \"split\"; which window to use when jumping") -call append("$", "\tto a buffer") -call <SID>OptionG("swb", &swb) -call append("$", "splitbelow\ta new window is put below the current one") -call <SID>BinOptionG("sb", &sb) -if has("vertsplit") - call append("$", "splitright\ta new window is put right of the current one") - call <SID>BinOptionG("spr", &spr) -endif -if has("scrollbind") - call append("$", "scrollbind\tthis window scrolls together with other bound windows") - call append("$", "\t(local to window)") - call <SID>BinOptionL("scb") - call append("$", "scrollopt\t\"ver\", \"hor\" and/or \"jump\"; list of options for 'scrollbind'") - call <SID>OptionG("sbo", &sbo) -endif - - -call <SID>Header("multiple tab pages") -call append("$", "showtabline\t0, 1 or 2; when to use a tab pages line") -call append("$", " \tset stal=" . &stal) -call append("$", "tabpagemax\tmaximum number of tab pages to open for -p and \"tab all\"") -call append("$", " \tset tpm=" . &tpm) -call append("$", "tabline\tcustom tab pages line") -call <SID>OptionG("tal", &tal) -if has("gui") - call append("$", "guitablabel\tcustom tab page label for the GUI") - call <SID>OptionG("gtl", >l) - call append("$", "guitabtooltip\tcustom tab page tooltip for the GUI") - call <SID>OptionG("gtt", >t) -endif - - -call <SID>Header("terminal") -call append("$", "term\tname of the used terminal") -call <SID>OptionG("term", &term) -call append("$", "ttytype\talias for 'term'") -call <SID>OptionG("tty", &tty) -call append("$", "ttybuiltin\tcheck built-in termcaps first") -call <SID>BinOptionG("tbi", &tbi) -call append("$", "ttyfast\tterminal connection is fast") -call <SID>BinOptionG("tf", &tf) -call append("$", "weirdinvert\tterminal that requires extra redrawing") -call <SID>BinOptionG("wiv", &wiv) -call append("$", "esckeys\trecognize keys that start with <Esc> in Insert mode") -call <SID>BinOptionG("ek", &ek) -call append("$", "scrolljump\tminimal number of lines to scroll at a time") -call append("$", " \tset sj=" . &sj) -call append("$", "ttyscroll\tmaximum number of lines to use scrolling instead of redrawing") -call append("$", " \tset tsl=" . &tsl) -if has("gui") || has("msdos") || has("win32") - call append("$", "guicursor\tspecifies what the cursor looks like in different modes") - call <SID>OptionG("gcr", &gcr) -endif -if has("title") - let &title = s:old_title - call append("$", "title\tshow info in the window title") - call <SID>BinOptionG("title", &title) - set notitle - call append("$", "titlelen\tpercentage of 'columns' used for the window title") - call append("$", " \tset titlelen=" . &titlelen) - call append("$", "titlestring\twhen not empty, string to be used for the window title") - call <SID>OptionG("titlestring", &titlestring) - call append("$", "titleold\tstring to restore the title to when exiting Vim") - call <SID>OptionG("titleold", &titleold) - let &icon = s:old_icon - call append("$", "icon\tset the text of the icon for this window") - call <SID>BinOptionG("icon", &icon) - set noicon - call append("$", "iconstring\twhen not empty, text for the icon of this window") - call <SID>OptionG("iconstring", &iconstring) -endif -if has("win32") - call append("$", "restorescreen\trestore the screen contents when exiting Vim") - call <SID>BinOptionG("rs", &rs) -endif - - -call <SID>Header("using the mouse") -call append("$", "mouse\tlist of flags for using the mouse") -call <SID>OptionG("mouse", &mouse) -if has("gui") - call append("$", "mousefocus\tthe window with the mouse pointer becomes the current one") - call <SID>BinOptionG("mousef", &mousef) - call append("$", "mousehide\thide the mouse pointer while typing") - call <SID>BinOptionG("mh", &mh) -endif -call append("$", "mousemodel\t\"extend\", \"popup\" or \"popup_setpos\"; what the right") -call append("$", "\tmouse button is used for") -call <SID>OptionG("mousem", &mousem) -call append("$", "mousetime\tmaximum time in msec to recognize a double-click") -call append("$", " \tset mouset=" . &mouset) -call append("$", "ttymouse\t\"xterm\", \"xterm2\", \"dec\" or \"netterm\"; type of mouse") -call <SID>OptionG("ttym", &ttym) -if has("mouseshape") - call append("$", "mouseshape\twhat the mouse pointer looks like in different modes") - call <SID>OptionG("mouses", &mouses) -endif - - -if has("gui") - call <SID>Header("GUI") - call append("$", "guifont\tlist of font names to be used in the GUI") - call <SID>OptionG("gfn", &gfn) - if has("xfontset") - call append("$", "guifontset\tpair of fonts to be used, for multibyte editing") - call <SID>OptionG("gfs", &gfs) - endif - call append("$", "guifontwide\tlist of font names to be used for double-wide characters") - call <SID>OptionG("gfw", &gfw) - if has("mac") - call append("$", "antialias\tuse smooth, antialiased fonts") - call <SID>BinOptionG("anti", &anti) - endif - call append("$", "guioptions\tlist of flags that specify how the GUI works") - call <SID>OptionG("go", &go) - if has("gui_gtk") - call append("$", "toolbar\t\"icons\", \"text\" and/or \"tooltips\"; how to show the toolbar") - call <SID>OptionG("tb", &tb) - if has("gui_gtk2") - call append("$", "toolbariconsize\tSize of toolbar icons") - call <SID>OptionG("tbis", &tbis) - endif - call append("$", "guiheadroom\troom (in pixels) left above/below the window") - call append("$", " \tset ghr=" . &ghr) - endif - call append("$", "guipty\tuse a pseudo-tty for I/O to external commands") - call <SID>BinOptionG("guipty", &guipty) - if has("browse") - call append("$", "browsedir\t\"last\", \"buffer\" or \"current\": which directory used for the file browser") - call <SID>OptionG("bsdir", &bsdir) - endif - if has("multi_lang") - call append("$", "langmenu\tlanguage to be used for the menus") - call <SID>OptionG("langmenu", &lm) - endif - call append("$", "menuitems\tmaximum number of items in one menu") - call append("$", " \tset mis=" . &mis) - if has("winaltkeys") - call append("$", "winaltkeys\t\"no\", \"yes\" or \"menu\"; how to use the ALT key") - call <SID>OptionG("wak", &wak) - endif - call append("$", "linespace\tnumber of pixel lines to use between characters") - call append("$", " \tset lsp=" . &lsp) - if has("balloon_eval") - call append("$", "balloondelay\tdelay in milliseconds before a balloon may pop up") - call append("$", " \tset bdlay=" . &bdlay) - call append("$", "ballooneval\twhether the balloon evaluation is to be used") - call <SID>BinOptionG("beval", &beval) - if has("eval") - call append("$", "balloonexpr\texpression to show in balloon eval") - call append("$", " \tset bexpr=" . &bexpr) - endif - endif - if exists("+macatsui") - call append("$", "macatsui\tuse ATSUI text drawing; disable to avoid display problems") - call <SID>OptionG("macatsui", &macatsui) - endif -endif - -if has("printer") - call <SID>Header("printing") - call append("$", "printoptions\tlist of items that control the format of :hardcopy output") - call <SID>OptionG("popt", &popt) - call append("$", "printdevice\tname of the printer to be used for :hardcopy") - call <SID>OptionG("pdev", &pdev) - if has("postscript") - call append("$", "printexpr\texpression used to print the PostScript file for :hardcopy") - call <SID>OptionG("pexpr", &pexpr) - endif - call append("$", "printfont\tname of the font to be used for :hardcopy") - call <SID>OptionG("pfn", &pfn) - call append("$", "printheader\tformat of the header used for :hardcopy") - call <SID>OptionG("pheader", &pheader) - if has("postscript") - call append("$", "printencoding\tencoding used to print the PostScript file for :hardcopy") - call <SID>OptionG("penc", &penc) - endif - if has("multi_byte") - call append("$", "printmbcharset\tthe CJK character set to be used for CJK output from :hardcopy") - call <SID>OptionG("pmbcs", &pmbcs) - call append("$", "printmbfont\tlist of font names to be used for CJK output from :hardcopy") - call <SID>OptionG("pmbfn", &pmbfn) - endif -endif - -call <SID>Header("messages and info") -call append("$", "terse\tadd 's' flag in 'shortmess' (don't show search message)") -call <SID>BinOptionG("terse", &terse) -call append("$", "shortmess\tlist of flags to make messages shorter") -call <SID>OptionG("shm", &shm) -call append("$", "showcmd\tshow (partial) command keys in the status line") -let &sc = s:old_sc -call <SID>BinOptionG("sc", &sc) -set nosc -call append("$", "showmode\tdisplay the current mode in the status line") -call <SID>BinOptionG("smd", &smd) -call append("$", "ruler\tshow cursor position below each window") -let &ru = s:old_ru -call <SID>BinOptionG("ru", &ru) -set noru -if has("statusline") - call append("$", "rulerformat\talternate format to be used for the ruler") - call <SID>OptionG("ruf", &ruf) -endif -call append("$", "report\tthreshold for reporting number of changed lines") -call append("$", " \tset report=" . &report) -call append("$", "verbose\tthe higher the more messages are given") -call append("$", " \tset vbs=" . &vbs) -call append("$", "verbosefile\tfile to write messages in") -call <SID>OptionG("vfile", &vfile) -call append("$", "more\tpause listings when the screen is full") -call <SID>BinOptionG("more", &more) -if has("dialog_con") || has("dialog_gui") - call append("$", "confirm\tstart a dialog when a command fails") - call <SID>BinOptionG("cf", &cf) -endif -call append("$", "errorbells\tring the bell for error messages") -call <SID>BinOptionG("eb", &eb) -call append("$", "visualbell\tuse a visual bell instead of beeping") -call <SID>BinOptionG("vb", &vb) -if has("multi_lang") - call append("$", "helplang\tlist of preferred languages for finding help") - call <SID>OptionG("hlg", &hlg) -endif - - -call <SID>Header("selecting text") -call append("$", "selection\t\"old\", \"inclusive\" or \"exclusive\"; how selecting text behaves") -call <SID>OptionG("sel", &sel) -call append("$", "selectmode\t\"mouse\", \"key\" and/or \"cmd\"; when to start Select mode") -call append("$", "\tinstead of Visual mode") -call <SID>OptionG("slm", &slm) -if has("clipboard") - call append("$", "clipboard\t\"unnamed\" to use the * register like unnamed register") - call append("$", "\t\"autoselect\" to always put selected text on the clipboard") - call <SID>OptionG("cb", &cb) -endif -call append("$", "keymodel\t\"startsel\" and/or \"stopsel\"; what special keys can do") -call <SID>OptionG("km", &km) - - -call <SID>Header("editing text") -call append("$", "undolevels\tmaximum number of changes that can be undone") -call append("$", " \tset ul=" . &ul) -call append("$", "modified\tchanges have been made and not written to a file") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("mod") -call append("$", "readonly\tbuffer is not to be written") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("ro") -call append("$", "modifiable\tchanges to the text are not possible") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("ma") -call append("$", "textwidth\tline length above which to break a line") -call append("$", "\t(local to buffer)") -call <SID>OptionL("tw") -call append("$", "wrapmargin\tmargin from the right in which to break a line") -call append("$", "\t(local to buffer)") -call <SID>OptionL("wm") -call append("$", "backspace\tspecifies what <BS>, CTRL-W, etc. can do in Insert mode") -call append("$", " \tset bs=" . &bs) -call append("$", "comments\tdefinition of what comment lines look like") -call append("$", "\t(local to buffer)") -call <SID>OptionL("com") -call append("$", "formatoptions\tlist of flags that tell how automatic formatting works") -call append("$", "\t(local to buffer)") -call <SID>OptionL("fo") -call append("$", "formatlistpat\tpattern to recognize a numbered list") -call append("$", "\t(local to buffer)") -call <SID>OptionL("flp") -if has("eval") - call append("$", "formatexpr\texpression used for \"gq\" to format lines") - call append("$", "\t(local to buffer)") - call <SID>OptionL("fex") -endif -if has("insert_expand") - call append("$", "complete\tspecifies how Insert mode completion works for CTRL-N and CTRL-P") - call append("$", "\t(local to buffer)") - call <SID>OptionL("cpt") - call append("$", "completeopt\twhether to use a popup menu for Insert mode completion") - call <SID>OptionG("cot", &cot) - call append("$", "pumheight\tmaximum height of the popup menu") - call <SID>OptionG("ph", &ph) - call append("$", "completefunc\tuser defined function for Insert mode completion") - call append("$", "\t(local to buffer)") - call <SID>OptionL("cfu") - call append("$", "omnifunc\tfunction for filetype-specific Insert mode completion") - call append("$", "\t(local to buffer)") - call <SID>OptionL("ofu") - call append("$", "dictionary\tlist of dictionary files for keyword completion") - call append("$", "\t(global or local to buffer)") - call <SID>OptionG("dict", &dict) - call append("$", "thesaurus\tlist of thesaurus files for keyword completion") - call append("$", "\t(global or local to buffer)") - call <SID>OptionG("tsr", &tsr) -endif -call append("$", "infercase\tadjust case of a keyword completion match") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("inf") -if has("digraphs") - call append("$", "digraph\tenable entering digraps with c1 <BS> c2") - call <SID>BinOptionG("dg", &dg) -endif -call append("$", "tildeop\tthe \"~\" command behaves like an operator") -call <SID>BinOptionG("top", &top) -call append("$", "operatorfunc\tfunction called for the\"g@\" operator") -call <SID>OptionG("opfunc", &opfunc) -call append("$", "showmatch\tWhen inserting a bracket, briefly jump to its match") -call <SID>BinOptionG("sm", &sm) -call append("$", "matchtime\ttenth of a second to show a match for 'showmatch'") -call append("$", " \tset mat=" . &mat) -call append("$", "matchpairs\tlist of pairs that match for the \"%\" command") -call append("$", "\t(local to buffer)") -call <SID>OptionL("mps") -call append("$", "joinspaces\tuse two spaces after '.' when joining a line") -call <SID>BinOptionG("js", &js) -call append("$", "nrformats\t\"alpha\", \"octal\" and/or \"hex\"; number formats recognized for") -call append("$", "\tCTRL-A and CTRL-X commands") -call append("$", "\t(local to buffer)") -call <SID>OptionL("nf") - - -call <SID>Header("tabs and indenting") -call append("$", "tabstop\tnumber of spaces a <Tab> in the text stands for") -call append("$", "\t(local to buffer)") -call <SID>OptionL("ts") -call append("$", "shiftwidth\tnumber of spaces used for each step of (auto)indent") -call append("$", "\t(local to buffer)") -call <SID>OptionL("sw") -call append("$", "smarttab\ta <Tab> in an indent inserts 'shiftwidth' spaces") -call <SID>BinOptionG("sta", &sta) -call append("$", "softtabstop\tif non-zero, number of spaces to insert for a <Tab>") -call append("$", "\t(local to buffer)") -call <SID>OptionL("sts") -call append("$", "shiftround\tround to 'shiftwidth' for \"<<\" and \">>\"") -call <SID>BinOptionG("sr", &sr) -call append("$", "expandtab\texpand <Tab> to spaces in Insert mode") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("et") -call append("$", "autoindent\tautomatically set the indent of a new line") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("ai") -if has("smartindent") - call append("$", "smartindent\tdo clever autoindenting") - call append("$", "\t(local to buffer)") - call <SID>BinOptionL("si") -endif -if has("cindent") - call append("$", "cindent\tenable specific indenting for C code") - call append("$", "\t(local to buffer)") - call <SID>BinOptionL("cin") - call append("$", "cinoptions\toptions for C-indenting") - call append("$", "\t(local to buffer)") - call <SID>OptionL("cino") - call append("$", "cinkeys\tkeys that trigger C-indenting in Insert mode") - call append("$", "\t(local to buffer)") - call <SID>OptionL("cink") - call append("$", "cinwords\tlist of words that cause more C-indent") - call append("$", "\t(local to buffer)") - call <SID>OptionL("cinw") - call append("$", "indentexpr\texpression used to obtain the indent of a line") - call append("$", "\t(local to buffer)") - call <SID>OptionL("inde") - call append("$", "indentkeys\tkeys that trigger indenting with 'indentexpr' in Insert mode") - call append("$", "\t(local to buffer)") - call <SID>OptionL("indk") -endif -call append("$", "copyindent\tCopy whitespace for indenting from previous line") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("ci") -call append("$", "preserveindent\tPreserve kind of whitespace when changing indent") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("pi") -if has("lispindent") - call append("$", "lisp\tenable lisp mode") - call append("$", "\t(local to buffer)") - call <SID>BinOptionL("lisp") - call append("$", "lispwords\twords that change how lisp indenting works") - call <SID>OptionG("lw", &lw) -endif - - -if has("folding") - call <SID>Header("folding") - call append("$", "foldenable\tset to display all folds open") - call append("$", "\t(local to window)") - call <SID>BinOptionL("fen") - call append("$", "foldlevel\tfolds with a level higher than this number will be closed") - call append("$", "\t(local to window)") - call <SID>OptionL("fdl") - call append("$", "foldlevelstart\tvalue for 'foldlevel' when starting to edit a file") - call append("$", " \tset fdls=" . &fdls) - call append("$", "foldcolumn\twidth of the column used to indicate folds") - call append("$", "\t(local to window)") - call <SID>OptionL("fdc") - call append("$", "foldtext\texpression used to display the text of a closed fold") - call append("$", "\t(local to window)") - call <SID>OptionL("fdt") - call append("$", "foldclose\tset to \"all\" to close a fold when the cursor leaves it") - call <SID>OptionG("fcl", &fcl) - call append("$", "foldopen\tspecifies for which commands a fold will be opened") - call <SID>OptionG("fdo", &fdo) - call append("$", "foldminlines\tminimum number of screen lines for a fold to be closed") - call append("$", "\t(local to window)") - call <SID>OptionL("fml") - call append("$", "commentstring\ttemplate for comments; used to put the marker in") - call <SID>OptionL("cms") - call append("$", "foldmethod\tfolding type: \"manual\", \"indent\", \"expr\", \"marker\" or \"syntax\"") - call append("$", "\t(local to window)") - call <SID>OptionL("fdm") - call append("$", "foldexpr\texpression used when 'foldmethod' is \"expr\"") - call append("$", "\t(local to window)") - call <SID>OptionL("fde") - call append("$", "foldignore\tused to ignore lines when 'foldmethod' is \"indent\"") - call append("$", "\t(local to window)") - call <SID>OptionL("fdi") - call append("$", "foldmarker\tmarkers used when 'foldmethod' is \"marker\"") - call append("$", "\t(local to window)") - call <SID>OptionL("fmr") - call append("$", "foldnestmax\tmaximum fold depth for when 'foldmethod is \"indent\" or \"syntax\"") - call append("$", "\t(local to window)") - call <SID>OptionL("fdn") -endif - - -if has("diff") - call <SID>Header("diff mode") - call append("$", "diff\tuse diff mode for the current window") - call append("$", "\t(local to window)") - call <SID>BinOptionL("diff") - call append("$", "diffopt\toptions for using diff mode") - call <SID>OptionG("dip", &dip) - call append("$", "diffexpr\texpression used to obtain a diff file") - call <SID>OptionG("dex", &dex) - call append("$", "patchexpr\texpression used to patch a file") - call <SID>OptionG("pex", &pex) -endif - - -call <SID>Header("mapping") -call append("$", "maxmapdepth\tmaximum depth of mapping") -call append("$", " \tset mmd=" . &mmd) -call append("$", "remap\trecognize mappings in mapped keys") -call <SID>BinOptionG("remap", &remap) -call append("$", "timeout\tallow timing out halfway into a mapping") -call <SID>BinOptionG("to", &to) -call append("$", "ttimeout\tallow timing out halfway into a key code") -call <SID>BinOptionG("ttimeout", &ttimeout) -call append("$", "timeoutlen\ttime in msec for 'timeout'") -call append("$", " \tset tm=" . &tm) -call append("$", "ttimeoutlen\ttime in msec for 'ttimeout'") -call append("$", " \tset ttm=" . &ttm) - - -call <SID>Header("reading and writing files") -call append("$", "modeline\tenable using settings from modelines when reading a file") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("ml") -call append("$", "modelines\tnumber of lines to check for modelines") -call append("$", " \tset mls=" . &mls) -call append("$", "binary\tbinary file editing") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("bin") -call append("$", "endofline\tlast line in the file has an end-of-line") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("eol") -if has("multi_byte") - call append("$", "bomb\tPrepend a Byte Order Mark to the file") - call append("$", "\t(local to buffer)") - call <SID>BinOptionL("bomb") -endif -call append("$", "fileformat\tend-of-line format: \"dos\", \"unix\" or \"mac\"") -call append("$", "\t(local to buffer)") -call <SID>OptionL("ff") -call append("$", "fileformats\tlist of file formats to look for when editing a file") -call <SID>OptionG("ffs", &ffs) -call append("$", "textmode\tobsolete, use 'fileformat'") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("tx") -call append("$", "textauto\tobsolete, use 'fileformats'") -call <SID>BinOptionG("ta", &ta) -call append("$", "write\twriting files is allowed") -call <SID>BinOptionG("write", &write) -call append("$", "writebackup\twrite a backup file before overwriting a file") -call <SID>BinOptionG("wb", &wb) -call append("$", "backup\tkeep a backup after overwriting a file") -call <SID>BinOptionG("bk", &bk) -call append("$", "backupskip\tpatterns that specify for which files a backup is not made") -call append("$", " \tset bsk=" . &bsk) -call append("$", "backupcopy\twhether to make the backup as a copy or rename the existing file") -call append("$", " \tset bkc=" . &bkc) -call append("$", "backupdir\tlist of directories to put backup files in") -call <SID>OptionG("bdir", &bdir) -call append("$", "backupext\tfile name extension for the backup file") -call <SID>OptionG("bex", &bex) -call append("$", "autowrite\tautomatically write a file when leaving a modified buffer") -call <SID>BinOptionG("aw", &aw) -call append("$", "autowriteall\tas 'autowrite', but works with more commands") -call <SID>BinOptionG("awa", &awa) -call append("$", "writeany\talways write without asking for confirmation") -call <SID>BinOptionG("wa", &wa) -call append("$", "autoread\tautomatically read a file when it was modified outside of Vim") -call append("$", "\t(global or local to buffer)") -call <SID>BinOptionG("ar", &ar) -call append("$", "patchmode\tkeep oldest version of a file; specifies file name extension") -call <SID>OptionG("pm", &pm) -call append("$", "fsync\tforcibly sync the file to disk after writing it") -call <SID>BinOptionG("fs", &fs) -if !has("msdos") - call append("$", "shortname\tuse 8.3 file names") - call append("$", "\t(local to buffer)") - call <SID>BinOptionL("sn") -endif - - -call <SID>Header("the swap file") -call append("$", "directory\tlist of directories for the swap file") -call <SID>OptionG("dir", &dir) -call append("$", "swapfile\tuse a swap file for this buffer") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("swf") -call append("$", "swapsync\t\"sync\", \"fsync\" or empty; how to flush a swap file to disk") -call <SID>OptionG("sws", &sws) -call append("$", "updatecount\tnumber of characters typed to cause a swap file update") -call append("$", " \tset uc=" . &uc) -call append("$", "updatetime\ttime in msec after which the swap file will be updated") -call append("$", " \tset ut=" . &ut) -call append("$", "maxmem\tmaximum amount of memory in Kbyte used for one buffer") -call append("$", " \tset mm=" . &mm) -call append("$", "maxmemtot\tmaximum amount of memory in Kbyte used for all buffers") -call append("$", " \tset mmt=" . &mmt) - - -call <SID>Header("command line editing") -call append("$", "history\thow many command lines are remembered ") -call append("$", " \tset hi=" . &hi) -call append("$", "wildchar\tkey that triggers command-line expansion") -call append("$", " \tset wc=" . &wc) -call append("$", "wildcharm\tlike 'wildchar' but can also be used in a mapping") -call append("$", " \tset wcm=" . &wcm) -call append("$", "wildmode\tspecifies how command line completion works") -call <SID>OptionG("wim", &wim) -if has("wildoptions") - call append("$", "wildoptions\tempty or \"tagfile\" to list file name of matching tags") - call <SID>OptionG("wop", &wop) -endif -call append("$", "suffixes\tlist of file name extensions that have a lower priority") -call <SID>OptionG("su", &su) -if has("file_in_path") - call append("$", "suffixesadd\tlist of file name extensions added when searching for a file") - call append("$", "\t(local to buffer)") - call <SID>OptionL("sua") -endif -if has("wildignore") - call append("$", "wildignore\tlist of patterns to ignore files for file name completion") - call <SID>OptionG("wig", &wig) -endif -if has("wildmenu") - call append("$", "wildmenu\tcommand-line completion shows a list of matches") - call <SID>BinOptionG("wmnu", &wmnu) -endif -if has("vertsplit") - call append("$", "cedit\tkey used to open the command-line window") - call <SID>OptionG("cedit", &cedit) - call append("$", "cmdwinheight\theight of the command-line window") - call <SID>OptionG("cwh", &cwh) -endif - - -call <SID>Header("executing external commands") -call append("$", "shell\tname of the shell program used for external commands") -call <SID>OptionG("sh", &sh) -if has("amiga") - call append("$", "shelltype\twhen to use the shell or directly execute a command") - call append("$", " \tset st=" . &st) -endif -call append("$", "shellquote\tcharacter(s) to enclose a shell command in") -call <SID>OptionG("shq", &shq) -call append("$", "shellxquote\tlike 'shellquote' but include the redirection") -call <SID>OptionG("sxq", &sxq) -call append("$", "shellcmdflag\targument for 'shell' to execute a command") -call <SID>OptionG("shcf", &shcf) -call append("$", "shellredir\tused to redirect command output to a file") -call <SID>OptionG("srr", &srr) -call append("$", "shelltemp\tuse a temp file for shell commands instead of using a pipe") -call <SID>BinOptionG("stmp", &stmp) -call append("$", "equalprg\tprogram used for \"=\" command") -call append("$", "\t(global or local to buffer)") -call <SID>OptionG("ep", &ep) -call append("$", "formatprg\tprogram used to format lines with \"gq\" command") -call <SID>OptionG("fp", &fp) -call append("$", "keywordprg\tprogram used for the \"K\" command") -call <SID>OptionG("kp", &kp) -call append("$", "warn\twarn when using a shell command and a buffer has changes") -call <SID>BinOptionG("warn", &warn) - - -if has("quickfix") - call <SID>Header("running make and jumping to errors") - call append("$", "errorfile\tname of the file that contains error messages") - call <SID>OptionG("ef", &ef) - call append("$", "errorformat\tlist of formats for error messages") - call append("$", "\t(global or local to buffer)") - call <SID>OptionG("efm", &efm) - call append("$", "makeprg\tprogram used for the \":make\" command") - call append("$", "\t(global or local to buffer)") - call <SID>OptionG("mp", &mp) - call append("$", "shellpipe\tstring used to put the output of \":make\" in the error file") - call <SID>OptionG("sp", &sp) - call append("$", "makeef\tname of the errorfile for the 'makeprg' command") - call <SID>OptionG("mef", &mef) - call append("$", "grepprg\tprogram used for the \":grep\" command") - call append("$", "\t(global or local to buffer)") - call <SID>OptionG("gp", &gp) - call append("$", "grepformat\tlist of formats for output of 'grepprg'") - call <SID>OptionG("gfm", &gfm) -endif - - -if has("msdos") || has("os2") || has("win16") || has("win32") || has("osfiletype") - call <SID>Header("system specific") - if has("msdos") - call append("$", "bioskey\tcall the BIOS to get a keyoard character") - call <SID>BinOptionG("biosk", &biosk) - call append("$", "conskey\tuse direct console I/O to get a keyboard character") - call <SID>BinOptionG("consk", &consk) - endif - if has("osfiletype") - call append("$", "osfiletype\tOS-specific information about the type of file") - call append("$", "\t(local to buffer)") - call <SID>OptionL("oft") - endif - if has("msdos") || has("os2") || has("win16") || has("win32") - call append("$", "shellslash\tuse forward slashes in file names; for Unix-like shells") - call <SID>BinOptionG("ssl", &ssl) - endif -endif - - -call <SID>Header("language specific") -call append("$", "isfname\tspecifies the characters in a file name") -call <SID>OptionG("isf", &isf) -call append("$", "isident\tspecifies the characters in an identifier") -call <SID>OptionG("isi", &isi) -call append("$", "iskeyword\tspecifies the characters in a keyword") -call append("$", "\t(local to buffer)") -call <SID>OptionL("isk") -call append("$", "isprint\tspecifies printable characters") -call <SID>OptionG("isp", &isp) -if has("textobjects") - call append("$", "quoteescape\tspecifies escape characters in a string") - call append("$", "\t(local to buffer)") - call <SID>OptionL("qe") -endif -if has("rightleft") - call append("$", "rightleft\tdisplay the buffer right-to-left") - call append("$", "\t(local to window)") - call <SID>BinOptionL("rl") - call append("$", "rightleftcmd\tWhen to edit the command-line right-to-left") - call append("$", "\t(local to window)") - call <SID>OptionL("rlc") - call append("$", "revins\tInsert characters backwards") - call <SID>BinOptionG("ri", &ri) - call append("$", "allowrevins\tAllow CTRL-_ in Insert and Command-line mode to toggle 'revins'") - call <SID>BinOptionG("ari", &ari) - call append("$", "aleph\tthe ASCII code for the first letter of the Hebrew alphabet") - call append("$", " \tset al=" . &al) - call append("$", "hkmap\tuse Hebrew keyboard mapping") - call <SID>BinOptionG("hk", &hk) - call append("$", "hkmapp\tuse phonetic Hebrew keyboard mapping") - call <SID>BinOptionG("hkp", &hkp) -endif -if has("farsi") - call append("$", "altkeymap\tuse Farsi as the second language when 'revins' is set") - call <SID>BinOptionG("akm", &akm) - call append("$", "fkmap\tuse Farsi keyboard mapping") - call <SID>BinOptionG("fk", &fk) -endif -if has("arabic") - call append("$", "arabic\tPrepare for editing Arabic text") - call append("$", "\t(local to window)") - call <SID>BinOptionL("arab") - call append("$", "arabicshape\tPerform shaping of Arabic characters") - call <SID>BinOptionG("arshape", &arshape) - call append("$", "termbidi\tTerminal will perform bidi handling") - call <SID>BinOptionG("tbidi", &tbidi) -endif -if has("keymap") - call append("$", "keymap\tname of a keyboard mappping") - call <SID>OptionL("kmp") -endif -if has("langmap") - call append("$", "langmap\ttranslate characters for Normal mode") - call <SID>OptionG("lmap", &lmap) -endif -if has("xim") - call append("$", "imdisable\twhen set never use IM; overrules following IM options") - call <SID>BinOptionG("imd", &imd) -endif -call append("$", "iminsert\tin Insert mode: 1: use :lmap; 2: use IM; 0: neither") -call append("$", "\t(local to window)") -call <SID>OptionL("imi") -call append("$", "imsearch\tentering a search pattern: 1: use :lmap; 2: use IM; 0: neither") -call append("$", "\t(local to window)") -call <SID>OptionL("ims") -if has("xim") - call append("$", "imcmdline\twhen set always use IM when starting to edit a command line") - call <SID>BinOptionG("imc", &imc) -endif - - -if has("multi_byte") - call <SID>Header("multi-byte characters") - call append("$", "encoding\tcharacter encoding used in Vim: \"latin1\", \"utf-8\"") - call append("$", "\t\"euc-jp\", \"big5\", etc.") - call <SID>OptionG("enc", &enc) - call append("$", "fileencoding\tcharacter encoding for the current file") - call append("$", "\t(local to buffer)") - call <SID>OptionL("fenc") - call append("$", "fileencodings\tautomatically detected character encodings") - call <SID>OptionG("fencs", &fencs) - call append("$", "termencoding\tcharacter encoding used by the terminal") - call <SID>OptionG("tenc", &tenc) - call append("$", "charconvert\texpression used for character encoding conversion") - call <SID>OptionG("ccv", &ccv) - call append("$", "delcombine\tDelete combining (composing) characters on their own") - call <SID>BinOptionG("deco", &deco) - call append("$", "maxcombine\tMaximum number of combining (composing) characters displayed") - call <SID>OptionG("mco", &mco) - if has("xim") && has("gui_gtk") - call append("$", "imactivatekey\tkey that activates the X input method") - call <SID>OptionG("imak", &imak) - endif - call append("$", "ambiwidth\tWidth of ambiguous width characters") - call <SID>OptionG("ambw", &ambw) -endif - - -call <SID>Header("various") -if has("virtualedit") - call append("$", "virtualedit\twhen to use virtual editing: \"block\", \"insert\" and/or \"all\"") - call <SID>OptionG("ve", &ve) -endif -if has("autocmd") - call append("$", "eventignore\tlist of autocommand events which are to be ignored") - call <SID>OptionG("ei", &ei) -endif -call append("$", "loadplugins\tload plugin scripts when starting up") -call <SID>BinOptionG("lpl", &lpl) -call append("$", "exrc\tenable reading .vimrc/.exrc/.gvimrc in the current directory") -call <SID>BinOptionG("ex", &ex) -call append("$", "secure\tsafer working with script files in the current directory") -call <SID>BinOptionG("secure", &secure) -call append("$", "gdefault\tuse the 'g' flag for \":substitute\"") -call <SID>BinOptionG("gd", &gd) -call append("$", "edcompatible\t'g' and 'c' flags of \":substitute\" toggle") -call <SID>BinOptionG("ed", &ed) -if exists("+opendevice") - call append("$", "opendevice\tallow reading/writing devices") - call <SID>BinOptionG("odev", &odev) -endif -if exists("+maxfuncdepth") - call append("$", "maxfuncdepth\tmaximum depth of function calls") - call append("$", " \tset mfd=" . &mfd) -endif -if has("mksession") - call append("$", "sessionoptions\tlist of words that specifies what to put in a session file") - call <SID>OptionG("ssop", &ssop) - call append("$", "viewoptions\tlist of words that specifies what to save for :mkview") - call <SID>OptionG("vop", &vop) - call append("$", "viewdir\tdirectory where to store files with :mkview") - call <SID>OptionG("vdir", &vdir) -endif -if has("viminfo") - call append("$", "viminfo\tlist that specifies what to write in the viminfo file") - call <SID>OptionG("vi", &vi) -endif -if has("quickfix") - call append("$", "bufhidden\twhat happens with a buffer when it's no longer in a window") - call append("$", "\t(local to buffer)") - call <SID>OptionL("bh") - call append("$", "buftype\t\"\", \"nofile\", \"nowrite\" or \"quickfix\": type of buffer") - call append("$", "\t(local to buffer)") - call <SID>OptionL("bt") -endif -call append("$", "buflisted\twhether the buffer shows up in the buffer list") -call append("$", "\t(local to buffer)") -call <SID>BinOptionL("bl") -call append("$", "debug\tset to \"msg\" to see all error messages") -call append("$", " \tset debug=" . &debug) -if has("mzscheme") - call append("$", "mzquantum\tinterval in milliseconds between polls for MzScheme threads") - call append("$", " \tset mzq=" . &mzq) -endif - -set cpo&vim - -" go to first line -1 - -" reset 'modified', so that ":q" can be used to close the window -setlocal nomodified - -if has("syntax") - " Use Vim highlighting, with some additional stuff - setlocal ft=vim - syn match optwinHeader "^ \=[0-9].*" - syn match optwinName "^[a-z]*\t" nextgroup=optwinComment - syn match optwinComment ".*" contained - syn match optwinComment "^\t.*" - if !exists("did_optwin_syntax_inits") - let did_optwin_syntax_inits = 1 - hi link optwinHeader Title - hi link optwinName Identifier - hi link optwinComment Comment - endif -endif - -" Install autocommands to enable mappings in option-window -noremap <silent> <buffer> <CR> <C-\><C-N>:call <SID>CR()<CR> -inoremap <silent> <buffer> <CR> <Esc>:call <SID>CR()<CR> -noremap <silent> <buffer> <Space> :call <SID>Space()<CR> - -" Make the buffer be deleted when the window is closed. -setlocal buftype=nofile bufhidden=delete noswapfile - -augroup optwin - au! BufUnload,BufHidden option-window nested - \ call <SID>unload() | delfun <SID>unload -augroup END - -fun! <SID>unload() - delfun <SID>CR - delfun <SID>Space - delfun <SID>Find - delfun <SID>Update - delfun <SID>OptionL - delfun <SID>OptionG - delfun <SID>BinOptionL - delfun <SID>BinOptionG - delfun <SID>Header - au! optwin -endfun - -" Restore the previous value of 'title' and 'icon'. -let &title = s:old_title -let &icon = s:old_icon -let &ru = s:old_ru -let &sc = s:old_sc -let &cpo = s:cpo_save -unlet s:old_title s:old_icon s:old_ru s:old_sc s:cpo_save s:idx s:lnum diff --git a/share/vim/vim72/plugin/getscriptPlugin.vim b/share/vim/vim72/plugin/getscriptPlugin.vim deleted file mode 100644 index 4fd36db596..0000000000 --- a/share/vim/vim72/plugin/getscriptPlugin.vim +++ /dev/null @@ -1,38 +0,0 @@ -" --------------------------------------------------------------------- -" getscriptPlugin.vim -" Author: Charles E. Campbell, Jr. -" Date: Jan 07, 2008 -" Installing: :help glvs-install -" Usage: :help glvs -" -" GetLatestVimScripts: 642 1 :AutoInstall: getscript.vim -" -" (Rom 15:11 WEB) Again, "Praise the Lord, all you Gentiles! Let -" all the peoples praise Him." -" --------------------------------------------------------------------- -" Initialization: {{{1 -" if you're sourcing this file, surely you can't be -" expecting vim to be in its vi-compatible mode -if &cp || exists("g:loaded_getscriptPlugin") - if &verbose - echo "GetLatestVimScripts is not vi-compatible; not loaded (you need to set nocp)" - endif - finish -endif -let g:loaded_getscriptPlugin = "v31" -let s:keepcpo = &cpo -set cpo&vim - -" --------------------------------------------------------------------- -" Public Interface: {{{1 -com! -nargs=0 GetLatestVimScripts call getscript#GetLatestVimScripts() -com! -nargs=0 GetScripts call getscript#GetLatestVimScripts() -silent! com -nargs=0 GLVS call getscript#GetLatestVimScripts() - -" --------------------------------------------------------------------- -" Restore Options: {{{1 -let &cpo= s:keepcpo -unlet s:keepcpo - -" --------------------------------------------------------------------- -" vim: ts=8 sts=2 fdm=marker nowrap diff --git a/share/vim/vim72/plugin/gzip.vim b/share/vim/vim72/plugin/gzip.vim deleted file mode 100644 index 6560238719..0000000000 --- a/share/vim/vim72/plugin/gzip.vim +++ /dev/null @@ -1,36 +0,0 @@ -" Vim plugin for editing compressed files. -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2005 Jul 26 - -" Exit quickly when: -" - this plugin was already loaded -" - when 'compatible' is set -" - some autocommands are already taking care of compressed files -if exists("loaded_gzip") || &cp || exists("#BufReadPre#*.gz") - finish -endif -let loaded_gzip = 1 - -augroup gzip - " Remove all gzip autocommands - au! - - " Enable editing of gzipped files. - " The functions are defined in autoload/gzip.vim. - " - " Set binary mode before reading the file. - " Use "gzip -d", gunzip isn't always available. - autocmd BufReadPre,FileReadPre *.gz,*.bz2,*.Z setlocal bin - autocmd BufReadPost,FileReadPost *.gz call gzip#read("gzip -dn") - autocmd BufReadPost,FileReadPost *.bz2 call gzip#read("bzip2 -d") - autocmd BufReadPost,FileReadPost *.Z call gzip#read("uncompress") - autocmd BufWritePost,FileWritePost *.gz call gzip#write("gzip") - autocmd BufWritePost,FileWritePost *.bz2 call gzip#write("bzip2") - autocmd BufWritePost,FileWritePost *.Z call gzip#write("compress -f") - autocmd FileAppendPre *.gz call gzip#appre("gzip -dn") - autocmd FileAppendPre *.bz2 call gzip#appre("bzip2 -d") - autocmd FileAppendPre *.Z call gzip#appre("uncompress") - autocmd FileAppendPost *.gz call gzip#write("gzip") - autocmd FileAppendPost *.bz2 call gzip#write("bzip2") - autocmd FileAppendPost *.Z call gzip#write("compress -f") -augroup END diff --git a/share/vim/vim72/plugin/matchparen.vim b/share/vim/vim72/plugin/matchparen.vim deleted file mode 100644 index f38e4819d6..0000000000 --- a/share/vim/vim72/plugin/matchparen.vim +++ /dev/null @@ -1,150 +0,0 @@ -" Vim plugin for showing matching parens -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2008 Feb 27 - -" Exit quickly when: -" - this plugin was already loaded (or disabled) -" - when 'compatible' is set -" - the "CursorMoved" autocmd event is not availble. -if exists("g:loaded_matchparen") || &cp || !exists("##CursorMoved") - finish -endif -let g:loaded_matchparen = 1 - -augroup matchparen - " Replace all matchparen autocommands - autocmd! CursorMoved,CursorMovedI,WinEnter * call s:Highlight_Matching_Pair() -augroup END - -" Skip the rest if it was already done. -if exists("*s:Highlight_Matching_Pair") - finish -endif - -let cpo_save = &cpo -set cpo-=C - -" The function that is invoked (very often) to define a ":match" highlighting -" for any matching paren. -function! s:Highlight_Matching_Pair() - " Remove any previous match. - if exists('w:paren_hl_on') && w:paren_hl_on - 3match none - let w:paren_hl_on = 0 - endif - - " Avoid that we remove the popup menu. - " Return when there are no colors (looks like the cursor jumps). - if pumvisible() || (&t_Co < 8 && !has("gui_running")) - return - endif - - " Get the character under the cursor and check if it's in 'matchpairs'. - let c_lnum = line('.') - let c_col = col('.') - let before = 0 - - let c = getline(c_lnum)[c_col - 1] - let plist = split(&matchpairs, '.\zs[:,]') - let i = index(plist, c) - if i < 0 - " not found, in Insert mode try character before the cursor - if c_col > 1 && (mode() == 'i' || mode() == 'R') - let before = 1 - let c = getline(c_lnum)[c_col - 2] - let i = index(plist, c) - endif - if i < 0 - " not found, nothing to do - return - endif - endif - - " Figure out the arguments for searchpairpos(). - if i % 2 == 0 - let s_flags = 'nW' - let c2 = plist[i + 1] - else - let s_flags = 'nbW' - let c2 = c - let c = plist[i - 1] - endif - if c == '[' - let c = '\[' - let c2 = '\]' - endif - - " Find the match. When it was just before the cursor move it there for a - " moment. - if before > 0 - let save_cursor = winsaveview() - call cursor(c_lnum, c_col - before) - endif - - " When not in a string or comment ignore matches inside them. - let s_skip ='synIDattr(synID(line("."), col("."), 0), "name") ' . - \ '=~? "string\\|character\\|singlequote\\|comment"' - execute 'if' s_skip '| let s_skip = 0 | endif' - - " Limit the search to lines visible in the window. - let stoplinebottom = line('w$') - let stoplinetop = line('w0') - if i % 2 == 0 - let stopline = stoplinebottom - else - let stopline = stoplinetop - endif - - try - " Limit the search time to 300 msec to avoid a hang on very long lines. - " This fails when a timeout is not supported. - let [m_lnum, m_col] = searchpairpos(c, '', c2, s_flags, s_skip, stopline, 300) - catch /E118/ - " Can't use the timeout, restrict the stopline a bit more to avoid taking - " a long time on closed folds and long lines. - " The "viewable" variables give a range in which we can scroll while - " keeping the cursor at the same position. - " adjustedScrolloff accounts for very large numbers of scrolloff. - let adjustedScrolloff = min([&scrolloff, (line('w$') - line('w0')) / 2]) - let bottom_viewable = min([line('$'), c_lnum + &lines - adjustedScrolloff - 2]) - let top_viewable = max([1, c_lnum-&lines+adjustedScrolloff + 2]) - " one of these stoplines will be adjusted below, but the current values are - " minimal boundaries within the current window - if i % 2 == 0 - if has("byte_offset") && has("syntax_items") && &smc > 0 - let stopbyte = min([line2byte("$"), line2byte(".") + col(".") + &smc * 2]) - let stopline = min([bottom_viewable, byte2line(stopbyte)]) - else - let stopline = min([bottom_viewable, c_lnum + 100]) - endif - let stoplinebottom = stopline - else - if has("byte_offset") && has("syntax_items") && &smc > 0 - let stopbyte = max([1, line2byte(".") + col(".") - &smc * 2]) - let stopline = max([top_viewable, byte2line(stopbyte)]) - else - let stopline = max([top_viewable, c_lnum - 100]) - endif - let stoplinetop = stopline - endif - let [m_lnum, m_col] = searchpairpos(c, '', c2, s_flags, s_skip, stopline) - endtry - - if before > 0 - call winrestview(save_cursor) - endif - - " If a match is found setup match highlighting. - if m_lnum > 0 && m_lnum >= stoplinetop && m_lnum <= stoplinebottom - exe '3match MatchParen /\(\%' . c_lnum . 'l\%' . (c_col - before) . - \ 'c\)\|\(\%' . m_lnum . 'l\%' . m_col . 'c\)/' - let w:paren_hl_on = 1 - endif -endfunction - -" Define commands that will disable and enable the plugin. -command! NoMatchParen windo 3match none | unlet! g:loaded_matchparen | - \ au! matchparen -command! DoMatchParen runtime plugin/matchparen.vim | windo doau CursorMoved - -let &cpo = cpo_save diff --git a/share/vim/vim72/plugin/netrwPlugin.vim b/share/vim/vim72/plugin/netrwPlugin.vim deleted file mode 100644 index 7d2ca0bbb3..0000000000 --- a/share/vim/vim72/plugin/netrwPlugin.vim +++ /dev/null @@ -1,180 +0,0 @@ -" netrwPlugin.vim: Handles file transfer and remote directory listing across a network -" PLUGIN SECTION -" Date: Aug 01, 2008 -" Maintainer: Charles E Campbell, Jr <NdrOchip@ScampbellPfamily.AbizM-NOSPAM> -" GetLatestVimScripts: 1075 1 :AutoInstall: netrw.vim -" Copyright: Copyright (C) 1999-2008 Charles E. Campbell, Jr. {{{1 -" Permission is hereby granted to use and distribute this code, -" with or without modifications, provided that this copyright -" notice is copied with it. Like anything else that's free, -" netrw.vim, netrwPlugin.vim, and netrwSettings.vim are provided -" *as is* and comes with no warranty of any kind, either -" expressed or implied. By using this plugin, you agree that -" in no event will the copyright holder be liable for any damages -" resulting from the use of this software. -" -" But be doers of the Word, and not only hearers, deluding your own selves {{{1 -" (James 1:22 RSV) -" =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=- - -" --------------------------------------------------------------------- -" Load Once: {{{1 -if &cp || exists("g:loaded_netrwPlugin") - finish -endif -let g:loaded_netrwPlugin = "v132" -let s:keepcpo = &cpo -if v:version < 700 - echohl WarningMsg | echo "***netrw*** you need vim version 7.0 for this version of netrw" | echohl None - finish -endif -let s:keepcpo= &cpo -set cpo&vim - -" --------------------------------------------------------------------- -" Public Interface: {{{1 - -" Local Browsing: {{{2 -augroup FileExplorer - au! - au BufEnter * silent! call s:LocalBrowse(expand("<amatch>")) - if has("win32") || has("win95") || has("win64") || has("win16") - au BufEnter .* silent! call s:LocalBrowse(expand("<amatch>")) - endif -augroup END - -" Network Browsing Reading Writing: {{{2 -augroup Network - au! - if has("win32") || has("win95") || has("win64") || has("win16") - au BufReadCmd file://* exe "silent doau BufReadPre ".fnameescape(netrw#RFC2396(expand("<amatch>")))|exe 'e '.fnameescape(substitute(netrw#RFC2396(expand("<amatch>")),'file://\(.*\)','\1',""))|exe "bwipe ".fnameescape(expand("<amatch>"))|exe "silent doau BufReadPost ".fnameescape(netrw#RFC2396(expand("<amatch>"))) - else - au BufReadCmd file://* exe "silent doau BufReadPre ".fnameescape(netrw#RFC2396(expand("<amatch>")))|exe 'e '.fnameescape(substitute(netrw#RFC2396(expand("<amatch>")),'file://\(.*\)','\1',""))|exe "bwipe ".fnameescape(expand("<amatch>"))|exe "silent doau BufReadPost ".fnameescape(netrw#RFC2396(expand("<amatch>"))) - au BufReadCmd file://localhost/* exe "silent doau BufReadPre ".fnameescape(netrw#RFC2396(expand("<amatch>")))|exe 'e '.fnameescape(substitute(netrw#RFC2396(expand("<amatch>")),'file://localhost/\(.*\)','\1',""))|exe "bwipe ".fnameescape(substitute(expand("<amatch>"),'file://\(\k\+@\)\=','',''))|exe "silent doau BufReadPost ".fnameescape(netrw#RFC2396(expand("<amatch>"))) - endif - au BufReadCmd ftp://*,rcp://*,scp://*,http://*,dav://*,davs://*,rsync://*,sftp://* exe "silent doau BufReadPre ".fnameescape(expand("<amatch>"))|exe '2Nread '.fnameescape(expand("<amatch>"))|exe "silent doau BufReadPost ".fnameescape(expand("<amatch>")) - au FileReadCmd ftp://*,rcp://*,scp://*,http://*,dav://*,davs://*,rsync://*,sftp://* exe "silent doau FileReadPre ".fnameescape(expand("<amatch>"))|exe 'Nread '.fnameescape(expand("<amatch>"))|exe "silent doau FileReadPost ".fnameescape(expand("<amatch>")) - au BufWriteCmd ftp://*,rcp://*,scp://*,dav://*,davs://*,rsync://*,sftp://* exe "silent doau BufWritePre ".fnameescape(expand("<amatch>"))|exe 'Nwrite '.fnameescape(expand("<amatch>"))|exe "silent doau BufWritePost ".fnameescape(expand("<amatch>")) - au FileWriteCmd ftp://*,rcp://*,scp://*,dav://*,davs://*,rsync://*,sftp://* exe "silent doau FileWritePre ".fnameescape(expand("<amatch>"))|exe "'[,']".'Nwrite '.fnameescape(expand("<amatch>"))|exe "silent doau FileWritePost ".fnameescape(expand("<amatch>")) - try - au SourceCmd ftp://*,rcp://*,scp://*,http://*,dav://*,davs://*,rsync://*,sftp://* exe 'Nsource '.fnameescape(expand("<amatch>")) - catch /^Vim\%((\a\+)\)\=:E216/ - au SourcePre ftp://*,rcp://*,scp://*,http://*,dav://*,davs://*,rsync://*,sftp://* exe 'Nsource '.fnameescape(expand("<amatch>")) - endtry -augroup END - -" Commands: :Nread, :Nwrite, :NetUserPass {{{2 -com! -count=1 -nargs=* Nread call netrw#NetrwSavePosn()<bar>call netrw#NetRead(<count>,<f-args>)<bar>call netrw#NetrwRestorePosn() -com! -range=% -nargs=* Nwrite call netrw#NetrwSavePosn()<bar><line1>,<line2>call netrw#NetWrite(<f-args>)<bar>call netrw#NetrwRestorePosn() -com! -nargs=* NetUserPass call NetUserPass(<f-args>) -com! -nargs=* Nsource call netrw#NetrwSavePosn()<bar>call netrw#NetSource(<f-args>)<bar>call netrw#NetrwRestorePosn() - -" Commands: :Explore, :Sexplore, Hexplore, Vexplore {{{2 -com! -nargs=* -bar -bang -count=0 -complete=dir Explore call netrw#Explore(<count>,0,0+<bang>0,<q-args>) -com! -nargs=* -bar -bang -count=0 -complete=dir Sexplore call netrw#Explore(<count>,1,0+<bang>0,<q-args>) -com! -nargs=* -bar -bang -count=0 -complete=dir Hexplore call netrw#Explore(<count>,1,2+<bang>0,<q-args>) -com! -nargs=* -bar -bang -count=0 -complete=dir Vexplore call netrw#Explore(<count>,1,4+<bang>0,<q-args>) -com! -nargs=* -bar -count=0 -complete=dir Texplore call netrw#Explore(<count>,0,6 ,<q-args>) -com! -nargs=* -bar -bang Nexplore call netrw#Explore(-1,0,0,<q-args>) -com! -nargs=* -bar -bang Pexplore call netrw#Explore(-2,0,0,<q-args>) - -" Commands: NetrwSettings {{{2 -com! -nargs=0 NetrwSettings call netrwSettings#NetrwSettings() -com! -bang NetrwClean call netrw#NetrwClean(<bang>0) - -" Maps: -if !exists("g:netrw_nogx") && maparg('g','n') == "" - if !hasmapto('<Plug>NetrwBrowseX') - nmap <unique> gx <Plug>NetrwBrowseX - endif - nno <silent> <Plug>NetrwBrowseX :call netrw#NetrwBrowseX(expand("<cWORD>"),0)<cr> -endif - -" --------------------------------------------------------------------- -" LocalBrowse: {{{2 -fun! s:LocalBrowse(dirname) - " unfortunate interaction -- debugging calls can't be used here; - " the BufEnter event causes triggering when attempts to write to - " the DBG buffer are made. -" echomsg "dirname<".a:dirname.">" - if has("amiga") - " The check against '' is made for the Amiga, where the empty - " string is the current directory and not checking would break - " things such as the help command. - if a:dirname != '' && isdirectory(a:dirname) - silent! call netrw#LocalBrowseCheck(a:dirname) - endif - elseif isdirectory(a:dirname) -" echomsg "dirname<".dirname."> isdir" - silent! call netrw#LocalBrowseCheck(a:dirname) - endif - " not a directory, ignore it -endfun - -" --------------------------------------------------------------------- -" NetrwStatusLine: {{{1 -fun! NetrwStatusLine() -" let g:stlmsg= "Xbufnr=".w:netrw_explore_bufnr." bufnr=".bufnr("%")." Xline#".w:netrw_explore_line." line#".line(".") - if !exists("w:netrw_explore_bufnr") || w:netrw_explore_bufnr != bufnr("%") || !exists("w:netrw_explore_line") || w:netrw_explore_line != line(".") || !exists("w:netrw_explore_list") - let &stl= s:netrw_explore_stl - if exists("w:netrw_explore_bufnr")|unlet w:netrw_explore_bufnr|endif - if exists("w:netrw_explore_line")|unlet w:netrw_explore_line|endif - return "" - else - return "Match ".w:netrw_explore_mtchcnt." of ".w:netrw_explore_listlen - endif -endfun - -" ------------------------------------------------------------------------ -" NetUserPass: set username and password for subsequent ftp transfer {{{1 -" Usage: :call NetUserPass() -- will prompt for userid and password -" :call NetUserPass("uid") -- will prompt for password -" :call NetUserPass("uid","password") -- sets global userid and password -fun! NetUserPass(...) - - " get/set userid - if a:0 == 0 -" call Dfunc("NetUserPass(a:0<".a:0.">)") - if !exists("g:netrw_uid") || g:netrw_uid == "" - " via prompt - let g:netrw_uid= input('Enter username: ') - endif - else " from command line -" call Dfunc("NetUserPass(a:1<".a:1.">) {") - let g:netrw_uid= a:1 - endif - - " get password - if a:0 <= 1 " via prompt -" call Decho("a:0=".a:0." case <=1:") - let g:netrw_passwd= inputsecret("Enter Password: ") - else " from command line -" call Decho("a:0=".a:0." case >1: a:2<".a:2.">") - let g:netrw_passwd=a:2 - endif -" call Dret("NetUserPass") -endfun - -" ------------------------------------------------------------------------ -" NetReadFixup: this sort of function is typically written by the user {{{1 -" to handle extra junk that their system's ftp dumps -" into the transfer. This function is provided as an -" example and as a fix for a Windows 95 problem: in my -" experience, win95's ftp always dumped four blank lines -" at the end of the transfer. -if has("win95") && exists("g:netrw_win95ftp") && g:netrw_win95ftp - fun! NetReadFixup(method, line1, line2) -" call Dfunc("NetReadFixup(method<".a:method."> line1=".a:line1." line2=".a:line2.")") - if method == 3 " ftp (no <.netrc>) - let fourblanklines= line2 - 3 - silent fourblanklines.",".line2."g/^\s*/d" - endif -" call Dret("NetReadFixup") - endfun -endif - -" ------------------------------------------------------------------------ -" Modelines And Restoration: {{{1 -let &cpo= s:keepcpo -unlet s:keepcpo -" vim:ts=8 fdm=marker diff --git a/share/vim/vim72/plugin/rrhelper.vim b/share/vim/vim72/plugin/rrhelper.vim deleted file mode 100644 index 302177cb2d..0000000000 --- a/share/vim/vim72/plugin/rrhelper.vim +++ /dev/null @@ -1,52 +0,0 @@ -" Vim plugin with helper function(s) for --remote-wait -" Maintainer: Flemming Madsen <fma@cci.dk> -" Last Change: 2008 May 29 - -" Has this already been loaded? -if exists("loaded_rrhelper") - finish -endif -let loaded_rrhelper = 1 - -" Setup answers for a --remote-wait client who will assume -" a SetupRemoteReplies() function in the command server - -if has("clientserver") - function SetupRemoteReplies() - let cnt = 0 - let max = argc() - - let id = expand("<client>") - if id == 0 - return - endif - while cnt < max - " Handle same file from more clients and file being more than once - " on the command line by encoding this stuff in the group name - let uniqueGroup = "RemoteReply_".id."_".cnt - - " Path separators are always forward slashes for the autocommand pattern. - " Escape special characters with a backslash. - let f = substitute(argv(cnt), '\\', '/', "g") - if exists('*fnameescape') - let f = fnameescape(f) - else - let f = escape(f, " \t\n*?[{`$\\%#'\"|!<") - endif - execute "augroup ".uniqueGroup - execute "autocmd ".uniqueGroup." BufUnload ". f ." call DoRemoteReply('".id."', '".cnt."', '".uniqueGroup."', '". f ."')" - let cnt = cnt + 1 - endwhile - augroup END - endfunc - - function DoRemoteReply(id, cnt, group, file) - call server2client(a:id, a:cnt) - execute 'autocmd! '.a:group.' BufUnload '.a:file - execute 'augroup! '.a:group - endfunc - -endif - - -" vim: set sw=2 sts=2 : diff --git a/share/vim/vim72/plugin/tarPlugin.vim b/share/vim/vim72/plugin/tarPlugin.vim deleted file mode 100644 index 2ddf7f3484..0000000000 --- a/share/vim/vim72/plugin/tarPlugin.vim +++ /dev/null @@ -1,49 +0,0 @@ -" tarPlugin.vim -- a Vim plugin for browsing tarfiles -" Original was copyright (c) 2002, Michael C. Toren <mct@toren.net> -" Modified by Charles E. Campbell, Jr. -" Distributed under the GNU General Public License. -" -" Updates are available from <http://michael.toren.net/code/>. If you -" find this script useful, or have suggestions for improvements, please -" let me know. -" Also look there for further comments and documentation. -" -" This part only sets the autocommands. The functions are in autoload/tar.vim. -" --------------------------------------------------------------------- -" Load Once: {{{1 -if &cp || exists("g:loaded_tarPlugin") - finish -endif -let g:loaded_tarPlugin = "v23" -let s:keepcpo = &cpo -set cpo&vim - -" --------------------------------------------------------------------- -" Public Interface: {{{1 -augroup tar - au! - au BufReadCmd tarfile::* call tar#Read(expand("<amatch>"), 1) - au FileReadCmd tarfile::* call tar#Read(expand("<amatch>"), 0) - au BufWriteCmd tarfile::* call tar#Write(expand("<amatch>")) - au FileWriteCmd tarfile::* call tar#Write(expand("<amatch>")) - - if has("unix") - au BufReadCmd tarfile::*/* call tar#Read(expand("<amatch>"), 1) - au FileReadCmd tarfile::*/* call tar#Read(expand("<amatch>"), 0) - au BufWriteCmd tarfile::*/* call tar#Write(expand("<amatch>")) - au FileWriteCmd tarfile::*/* call tar#Write(expand("<amatch>")) - endif - - au BufReadCmd *.tar.gz call tar#Browse(expand("<amatch>")) - au BufReadCmd *.tar call tar#Browse(expand("<amatch>")) - au BufReadCmd *.lrp call tar#Browse(expand("<amatch>")) - au BufReadCmd *.tar.bz2 call tar#Browse(expand("<amatch>")) - au BufReadCmd *.tar.Z call tar#Browse(expand("<amatch>")) - au BufReadCmd *.tgz call tar#Browse(expand("<amatch>")) -augroup END - -" --------------------------------------------------------------------- -" Restoration And Modelines: {{{1 -" vim: fdm=marker -let &cpo= s:keepcpo -unlet s:keepcpo diff --git a/share/vim/vim72/plugin/tohtml.vim b/share/vim/vim72/plugin/tohtml.vim deleted file mode 100644 index 9914bed6d3..0000000000 --- a/share/vim/vim72/plugin/tohtml.vim +++ /dev/null @@ -1,27 +0,0 @@ -" Vim plugin for converting a syntax highlighted file to HTML. -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2003 Apr 06 - -" Don't do this when: -" - when 'compatible' is set -" - this plugin was already loaded -" - user commands are not available. -if !&cp && !exists(":TOhtml") && has("user_commands") - command -range=% TOhtml :call Convert2HTML(<line1>, <line2>) - - func Convert2HTML(line1, line2) - if a:line2 >= a:line1 - let g:html_start_line = a:line1 - let g:html_end_line = a:line2 - else - let g:html_start_line = a:line2 - let g:html_end_line = a:line1 - endif - - runtime syntax/2html.vim - - unlet g:html_start_line - unlet g:html_end_line - endfunc - -endif diff --git a/share/vim/vim72/plugin/vimballPlugin.vim b/share/vim/vim72/plugin/vimballPlugin.vim deleted file mode 100644 index 630bb9fbaa..0000000000 --- a/share/vim/vim72/plugin/vimballPlugin.vim +++ /dev/null @@ -1,36 +0,0 @@ -" vimballPlugin : construct a file containing both paths and files -" Author: Charles E. Campbell, Jr. -" Copyright: (c) 2004-2007 by Charles E. Campbell, Jr. -" The VIM LICENSE applies to Vimball.vim, and Vimball.txt -" (see |copyright|) except use "Vimball" instead of "Vim". -" No warranty, express or implied. -" *** *** Use At-Your-Own-Risk! *** *** -" -" (Rom 2:1 WEB) Therefore you are without excuse, O man, whoever you are who -" judge. For in that which you judge another, you condemn yourself. For -" you who judge practice the same things. -" GetLatestVimScripts: 1502 1 :AutoInstall: vimball.vim - -" --------------------------------------------------------------------- -" Load Once: {{{1 -if &cp || exists("g:loaded_vimballPlugin") - finish -endif -let g:loaded_vimballPlugin = "v29" -let s:keepcpo = &cpo -set cpo&vim - -" ------------------------------------------------------------------------------ -" Public Interface: {{{1 -com! -ra -complete=file -na=+ -bang MkVimball call vimball#MkVimball(<line1>,<line2>,<bang>0,<f-args>) -com! -na=? -complete=dir UseVimball call vimball#Vimball(1,<f-args>) -com! -na=0 VimballList call vimball#Vimball(0) -com! -na=* -complete=dir RmVimball call vimball#SaveSettings()|call vimball#RmVimball(<f-args>)|call vimball#RestoreSettings() -au BufEnter *.vba.gz,*.vba.bz2,*.vba.zip call vimball#Decompress(expand("<amatch>")) -au BufEnter *.vba setlocal ff=unix noma bt=nofile fmr=[[[,]]] fdm=marker|call vimball#ShowMesg(0,"Source this file to extract it! (:so %)") - -" ===================================================================== -" Restoration And Modelines: {{{1 -" vim: fdm=marker -let &cpo= s:keepcpo -unlet s:keepcpo diff --git a/share/vim/vim72/plugin/zipPlugin.vim b/share/vim/vim72/plugin/zipPlugin.vim deleted file mode 100644 index b80ecc610f..0000000000 --- a/share/vim/vim72/plugin/zipPlugin.vim +++ /dev/null @@ -1,50 +0,0 @@ -" zipPlugin.vim: Handles browsing zipfiles -" PLUGIN PORTION -" Date: Oct 05, 2007 -" Maintainer: Charles E Campbell, Jr <NdrOchip@ScampbellPfamily.AbizM-NOSPAM> -" License: Vim License (see vim's :help license) -" Copyright: Copyright (C) 2005,2006 Charles E. Campbell, Jr. {{{1 -" Permission is hereby granted to use and distribute this code, -" with or without modifications, provided that this copyright -" notice is copied with it. Like anything else that's free, -" zipPlugin.vim is provided *as is* and comes with no warranty -" of any kind, either expressed or implied. By using this -" plugin, you agree that in no event will the copyright -" holder be liable for any damages resulting from the use -" of this software. -" -" (James 4:8 WEB) Draw near to God, and he will draw near to you. -" Cleanse your hands, you sinners; and purify your hearts, you double-minded. -" --------------------------------------------------------------------- -" Load Once: {{{1 -if &cp || exists("g:loaded_zipPlugin") - finish -endif -let g:loaded_zipPlugin = "v22" -let s:keepcpo = &cpo -set cpo&vim - -" --------------------------------------------------------------------- -" Public Interface: {{{1 -augroup zip - au! - au BufReadCmd zipfile:* call zip#Read(expand("<amatch>"), 1) - au FileReadCmd zipfile:* call zip#Read(expand("<amatch>"), 0) - au BufWriteCmd zipfile:* call zip#Write(expand("<amatch>")) - au FileWriteCmd zipfile:* call zip#Write(expand("<amatch>")) - - if has("unix") - au BufReadCmd zipfile:*/* call zip#Read(expand("<amatch>"), 1) - au FileReadCmd zipfile:*/* call zip#Read(expand("<amatch>"), 0) - au BufWriteCmd zipfile:*/* call zip#Write(expand("<amatch>")) - au FileWriteCmd zipfile:*/* call zip#Write(expand("<amatch>")) - endif - - au BufReadCmd *.zip,*.jar,*.xpi,*.war,*.ear call zip#Browse(expand("<amatch>")) -augroup END - -" --------------------------------------------------------------------- -" Restoration And Modelines: {{{1 -" vim: fdm=marker -let &cpo= s:keepcpo -unlet s:keepcpo diff --git a/share/vim/vim72/scripts.vim b/share/vim/vim72/scripts.vim deleted file mode 100644 index d20ab09ad8..0000000000 --- a/share/vim/vim72/scripts.vim +++ /dev/null @@ -1,355 +0,0 @@ -" Vim support file to detect file types in scripts -" -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last change: 2008 Aug 09 - -" This file is called by an autocommand for every file that has just been -" loaded into a buffer. It checks if the type of file can be recognized by -" the file contents. The autocommand is in $VIMRUNTIME/filetype.vim. - - -" Only do the rest when the FileType autocommand has not been triggered yet. -if did_filetype() - finish -endif - -" Load the user defined scripts file first -" Only do this when the FileType autocommand has not been triggered yet -if exists("myscriptsfile") && filereadable(expand(myscriptsfile)) - execute "source " . myscriptsfile - if did_filetype() - finish - endif -endif - -" Line continuation is used here, remove 'C' from 'cpoptions' -let s:cpo_save = &cpo -set cpo&vim - -let s:line1 = getline(1) - -if s:line1 =~ "^#!" - " A script that starts with "#!". - - " Check for a line like "#!/usr/bin/env VAR=val bash". Turn it into - " "#!/usr/bin/bash" to make matching easier. - if s:line1 =~ '^#!\s*\S*\<env\s' - let s:line1 = substitute(s:line1, '\S\+=\S\+', '', 'g') - let s:line1 = substitute(s:line1, '\<env\s\+', '', '') - endif - - " Get the program name. - " Only accept spaces in PC style paths: "#!c:/program files/perl [args]". - " If the word env is used, use the first word after the space: - " "#!/usr/bin/env perl [path/args]" - " If there is no path use the first word: "#!perl [path/args]". - " Otherwise get the last word after a slash: "#!/usr/bin/perl [path/args]". - if s:line1 =~ '^#!\s*\a:[/\\]' - let s:name = substitute(s:line1, '^#!.*[/\\]\(\i\+\).*', '\1', '') - elseif s:line1 =~ '^#!.*\<env\>' - let s:name = substitute(s:line1, '^#!.*\<env\>\s\+\(\i\+\).*', '\1', '') - elseif s:line1 =~ '^#!\s*[^/\\ ]*\>\([^/\\]\|$\)' - let s:name = substitute(s:line1, '^#!\s*\([^/\\ ]*\>\).*', '\1', '') - else - let s:name = substitute(s:line1, '^#!\s*\S*[/\\]\(\i\+\).*', '\1', '') - endif - - " tcl scripts may have #!/bin/sh in the first line and "exec wish" in the - " third line. Suggested by Steven Atkinson. - if getline(3) =~ '^exec wish' - let s:name = 'wish' - endif - - " Bourne-like shell scripts: bash bash2 ksh ksh93 sh - if s:name =~ '^\(bash\d*\|\|ksh\d*\|sh\)\>' - call SetFileTypeSH(s:line1) " defined in filetype.vim - - " csh scripts - elseif s:name =~ '^csh\>' - if exists("g:filetype_csh") - call SetFileTypeShell(g:filetype_csh) - else - call SetFileTypeShell("csh") - endif - - " tcsh scripts - elseif s:name =~ '^tcsh\>' - call SetFileTypeShell("tcsh") - - " Z shell scripts - elseif s:name =~ '^zsh\>' - set ft=zsh - - " TCL scripts - elseif s:name =~ '^\(tclsh\|wish\|expectk\|itclsh\|itkwish\)\>' - set ft=tcl - - " Expect scripts - elseif s:name =~ '^expect\>' - set ft=expect - - " Gnuplot scripts - elseif s:name =~ '^gnuplot\>' - set ft=gnuplot - - " Makefiles - elseif s:name =~ 'make\>' - set ft=make - - " Lua - elseif s:name =~ 'lua' - set ft=lua - - " Perl - elseif s:name =~ 'perl' - set ft=perl - - " PHP - elseif s:name =~ 'php' - set ft=php - - " Python - elseif s:name =~ 'python' - set ft=python - - " Groovy - elseif s:name =~ '^groovy\>' - set ft=groovy - - " Ruby - elseif s:name =~ 'ruby' - set ft=ruby - - " BC calculator - elseif s:name =~ '^bc\>' - set ft=bc - - " sed - elseif s:name =~ 'sed\>' - set ft=sed - - " OCaml-scripts - elseif s:name =~ 'ocaml' - set ft=ocaml - - " Awk scripts - elseif s:name =~ 'awk\>' - set ft=awk - - " Website MetaLanguage - elseif s:name =~ 'wml' - set ft=wml - - " Scheme scripts - elseif s:name =~ 'scheme' - set ft=scheme - - " CFEngine scripts - elseif s:name =~ 'cfengine' - set ft=cfengine - - endif - unlet s:name - -else - " File does not start with "#!". - - let s:line2 = getline(2) - let s:line3 = getline(3) - let s:line4 = getline(4) - let s:line5 = getline(5) - - " Bourne-like shell scripts: sh ksh bash bash2 - if s:line1 =~ '^:$' - call SetFileTypeSH(s:line1) " defined in filetype.vim - - " Z shell scripts - elseif s:line1 =~ '^#compdef\>' || s:line1 =~ '^#autoload\>' - set ft=zsh - - " ELM Mail files - elseif s:line1 =~ '^From \([a-zA-Z][a-zA-Z_0-9\.=-]*\(@[^ ]*\)\=\|-\) .* \(19\|20\)\d\d$' - set ft=mail - - " Mason - elseif s:line1 =~ '^<[%&].*>' - set ft=mason - - " Vim scripts (must have '" vim' as the first line to trigger this) - elseif s:line1 =~ '^" *[vV]im$' - set ft=vim - - " MOO - elseif s:line1 =~ '^\*\* LambdaMOO Database, Format Version \%([1-3]\>\)\@!\d\+ \*\*$' - set ft=moo - - " Diff file: - " - "diff" in first line (context diff) - " - "Only in " in first line - " - "--- " in first line and "+++ " in second line (unified diff). - " - "*** " in first line and "--- " in second line (context diff). - " - "# It was generated by makepatch " in the second line (makepatch diff). - " - "Index: <filename>" in the first line (CVS file) - " - "=== ", line of "=", "---", "+++ " (SVK diff) - " - "=== ", "--- ", "+++ " (bzr diff, common case) - " - "=== (removed|added|renamed|modified)" (bzr diff, alternative) - elseif s:line1 =~ '^\(diff\>\|Only in \|\d\+\(,\d\+\)\=[cda]\d\+\>\|# It was generated by makepatch \|Index:\s\+\f\+\r\=$\|===== \f\+ \d\+\.\d\+ vs edited\|==== //\f\+#\d\+\)' - \ || (s:line1 =~ '^--- ' && s:line2 =~ '^+++ ') - \ || (s:line1 =~ '^\* looking for ' && s:line2 =~ '^\* comparing to ') - \ || (s:line1 =~ '^\*\*\* ' && s:line2 =~ '^--- ') - \ || (s:line1 =~ '^=== ' && ((s:line2 =~ '^=\{66\}' && s:line3 =~ '^--- ' && s:line4 =~ '^+++') || (s:line2 =~ '^--- ' && s:line3 =~ '^+++ '))) - \ || (s:line1 =~ '^=== \(removed\|added\|renamed\|modified\)') - set ft=diff - - " PostScript Files (must have %!PS as the first line, like a2ps output) - elseif s:line1 =~ '^%![ \t]*PS' - set ft=postscr - - " M4 scripts: Guess there is a line that starts with "dnl". - elseif s:line1 =~ '^\s*dnl\>' - \ || s:line2 =~ '^\s*dnl\>' - \ || s:line3 =~ '^\s*dnl\>' - \ || s:line4 =~ '^\s*dnl\>' - \ || s:line5 =~ '^\s*dnl\>' - set ft=m4 - - " AmigaDos scripts - elseif $TERM == "amiga" - \ && (s:line1 =~ "^;" || s:line1 =~ '^\.[bB][rR][aA]') - set ft=amiga - - " SiCAD scripts (must have procn or procd as the first line to trigger this) - elseif s:line1 =~? '^ *proc[nd] *$' - set ft=sicad - - " Purify log files start with "**** Purify" - elseif s:line1 =~ '^\*\*\*\* Purify' - set ft=purifylog - - " XML - elseif s:line1 =~ '<?\s*xml.*?>' - set ft=xml - - " XHTML (e.g.: PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN") - elseif s:line1 =~ '\<DTD\s\+XHTML\s' - set ft=xhtml - - " HTML (e.g.: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN") - elseif s:line1 =~? '\<DOCTYPE\s\+html\>' - set ft=html - - " PDF - elseif s:line1 =~ '^%PDF-' - set ft=pdf - - " XXD output - elseif s:line1 =~ '^\x\{7}: \x\{2} \=\x\{2} \=\x\{2} \=\x\{2} ' - set ft=xxd - - " RCS/CVS log output - elseif s:line1 =~ '^RCS file:' || s:line2 =~ '^RCS file:' - set ft=rcslog - - " CVS commit - elseif s:line2 =~ '^CVS:' || getline("$") =~ '^CVS: ' - set ft=cvs - - " Prescribe - elseif s:line1 =~ '^!R!' - set ft=prescribe - - " Send-pr - elseif s:line1 =~ '^SEND-PR:' - set ft=sendpr - - " SNNS files - elseif s:line1 =~ '^SNNS network definition file' - set ft=snnsnet - elseif s:line1 =~ '^SNNS pattern definition file' - set ft=snnspat - elseif s:line1 =~ '^SNNS result file' - set ft=snnsres - - " Virata - elseif s:line1 =~ '^%.\{-}[Vv]irata' - \ || s:line2 =~ '^%.\{-}[Vv]irata' - \ || s:line3 =~ '^%.\{-}[Vv]irata' - \ || s:line4 =~ '^%.\{-}[Vv]irata' - \ || s:line5 =~ '^%.\{-}[Vv]irata' - set ft=virata - - " Strace - elseif s:line1 =~ '^\(\[pid \d\+\] \)\=[0-9:.]* *execve(' || s:line1 =~ '^__libc_start_main' - set ft=strace - - " VSE JCL - elseif s:line1 =~ '^\* $$ JOB\>' || s:line1 =~ '^// *JOB\>' - set ft=vsejcl - - " TAK and SINDA - elseif s:line4 =~ 'K & K Associates' || s:line2 =~ 'TAK 2000' - set ft=takout - elseif s:line3 =~ 'S Y S T E M S I M P R O V E D ' - set ft=sindaout - elseif getline(6) =~ 'Run Date: ' - set ft=takcmp - elseif getline(9) =~ 'Node File 1' - set ft=sindacmp - - " DNS zone files - elseif s:line1.s:line2.s:line3.s:line4 =~ '^; <<>> DiG [0-9.]\+ <<>>\|BIND.*named\|$ORIGIN\|$TTL\|IN\s\+SOA' - set ft=bindzone - - " BAAN - elseif s:line1 =~ '|\*\{1,80}' && s:line2 =~ 'VRC ' - \ || s:line2 =~ '|\*\{1,80}' && s:line3 =~ 'VRC ' - set ft=baan - - " Valgrind - elseif s:line1 =~ '^==\d\+== valgrind' || s:line3 =~ '^==\d\+== Using valgrind' - set ft=valgrind - - " Renderman Interface Bytestream - elseif s:line1 =~ '^##RenderMan' - set ft=rib - - " Scheme scripts - elseif s:line1 =~ 'exec\s\+\S*scheme' || s:line2 =~ 'exec\s\+\S*scheme' - set ft=scheme - - " Git output - elseif s:line1 =~ '^\(commit\|tree\|object\) \x\{40\}$\|^tag \S\+$' - set ft=git - - " CVS diff - else - let lnum = 1 - while getline(lnum) =~ "^? " && lnum < line("$") - let lnum = lnum + 1 - endwhile - if getline(lnum) =~ '^Index:\s\+\f\+$' - set ft=diff - - " locale input files: Formal Definitions of Cultural Conventions - " filename must be like en_US, fr_FR@euro or en_US.UTF-8 - elseif expand("%") =~ '\a\a_\a\a\($\|[.@]\)\|i18n$\|POSIX$\|translit_' - let lnum = 1 - while lnum < 100 && lnum < line("$") - if getline(lnum) =~ '^LC_\(IDENTIFICATION\|CTYPE\|COLLATE\|MONETARY\|NUMERIC\|TIME\|MESSAGES\|PAPER\|TELEPHONE\|MEASUREMENT\|NAME\|ADDRESS\)$' - setf fdcc - break - endif - let lnum = lnum + 1 - endwhile - endif - - endif - - unlet s:line2 s:line3 s:line4 s:line5 - -endif - -" Restore 'cpoptions' -let &cpo = s:cpo_save - -unlet s:cpo_save s:line1 diff --git a/share/vim/vim72/spell/README.txt b/share/vim/vim72/spell/README.txt deleted file mode 100644 index d2a9c17dc3..0000000000 --- a/share/vim/vim72/spell/README.txt +++ /dev/null @@ -1,90 +0,0 @@ -The spell files included here are in Vim's special format. You can't edit -them. See ":help spell" for more information. - - -COPYRIGHT - -The files used as input for the spell files come from the OpenOffice.org spell -files. Most of them go under the LGPL or a similar license. - -Copyright notices for specific languages are in README_??.txt. Note that the -files for different regions are merged, both to save space and to make it -possible to highlight words for another region different from bad words. - -Most of the soundslike mappings come from Aspell ??_phonet.dat files: -ftp://ftp.gnu.org/gnu/aspell/dict/. Most go under the GPL or LGPL copyright. - - -GENERATING .SPL FILES - -This involves downloading the files from the OpenOffice.org server, applying a -patch and running Vim to generate the .spl file. To do this all in one go use -the Aap program (www.a-a-p.org). It's simple to install, it only requires -Python. - -You can also do it manually: -1. Fetch the right spell file from: - http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries - -2. Unzip the archive: - unzip LL_RR.zip - -3. Apply the patch: - patch < LL_RR.diff - -4. If the language has multiple regions do the above for each region. E.g., - for English there are five regions: US, CA, AU, NZ and GB. - -5. Run Vim and execute ":mkspell". Make sure you do this with the correct - locale, that influences the upper/lower case letters and word characters. - On Unix it's something like: - env LANG=en_US.UTF-8 vim - mkspell! en en_US en_AU en_CA en_GB en_NZ - -6. Repeat step 5 for other locales. For English you could generate a spell - file for latin1, utf-8 and ASCII. ASCII only makes sense for languages - that have very few words with non-ASCII letters. - -Now you understand why I prefer using the Aap recipe :-). - - -MAINTAINING A LANGUAGE - -Every language should have a maintainer. His tasks are to track the changes -in the OpenOffice.org spell files and make updated patches. Words that -haven't been added/removed from the OpenOffice lists can also be handled by -the patches. - -It is important to keep the version of the .dic and .aff files that you -started with. When OpenOffice brings out new versions of these files you can -find out what changed and take over these changes in your patch. When there -are very many changes you can do it the other way around: re-apply the changes -for Vim to the new versions of the .dic and .aff files. - -This procedure should work well: - -1. Obtain the zip archive with the .aff and .dic files. Unpack it as - explained above and copy (don't rename!) the .aff and .dic files to - .orig.aff and .orig.dic. Using the Aap recipe should work, it will make - the copies for you. - -2. Tweak the .aff and .dic files to generate the perfect .spl file. Don't - change too much, the OpenOffice people are not stupid. However, you may - want to remove obvious mistakes. And remove single-letter words that - aren't really words, they mess up the suggestions (English has this - problem). You can use the "fixdup" Vim script to find duplicate words. - -3. Make the diff file. "aap diff" will do this for you. If a diff would be - too big you might consider writing a Vim script to do systematic changes. - Do check that someone else can reproduce building the spell file. Send the - result to Bram for inclusion in the distribution. Bram will generate the - .spl file and upload it to the ftp server (if he can't generate it you will - have to send him the .spl file too). - -4. When OpenOffice makes a new zip file available you need to update the - patch. "aap check" should do most of the work for you: if there are - changes the .new.dic and .new.aff files will appear. You can now figure - out the differences with .orig.dic and .orig.aff, adjust the .dic and .aff - files and finally move the .new.dic to .orig.dic and .new.aff to .orig.aff. - -5. Repeat step 4. regularly. diff --git a/share/vim/vim72/spell/README_en.txt b/share/vim/vim72/spell/README_en.txt deleted file mode 100644 index f8513286ab..0000000000 --- a/share/vim/vim72/spell/README_en.txt +++ /dev/null @@ -1,914 +0,0 @@ -en_US -20040623 release. --- -This dictionary is based on a subset of the original -English wordlist created by Kevin Atkinson for Pspell -and Aspell and thus is covered by his original -LGPL license. The affix file is a heavily modified -version of the original english.aff file which was -released as part of Geoff Kuenning's Ispell and as -such is covered by his BSD license. - -Thanks to both authors for there wonderful work. - - -=================================================== -en_AU: -This dictionary was based on the en_GB Myspell dictionary -which in turn was initially based on a subset of the -original English wordlist created by Kevin Atkinson for -Pspell and Aspell and thus is covered by his original -LGPL licence. - -The credit for this en_AU dictionary goes to: - -Kelvin Eldridge (maintainer) -Jean Hollis Weber -David Wilson - -- Words incorrect in Australian English removed -- a list from the previously removed words with corrected spelling was added -- a list of major rivers was added -- a list of place names was added -- a list of Australian mammals was added -- a list of Aboriginal/Koori words commonly used was added - -A total of 119,267 words are now recognized -by the dictionary. - -Of course, special thanks go to the editors of the -en_GB dictionary (David Bartlett, Brian Kelk and -Andrew Brown) which provided the starting point -for this dictionary. - -The affix file is currently a duplicate of the en_AU.aff -created completely from scratch by David Bartlett and -Andrew Brown, based on the published -rules for MySpell and is also provided under the LGPL. - -If you find omissions or bugs or have new words to -add to the dictionary, please contact the en_AU -maintainer at: - - "Kelvin" <audictionary@onlineconnections.com.au> - - - -=================================================== -en_CA: -The dictionary file was created using the "final" English and Canadian SCOWL (Spell Checker Oriented Word Lists) wordlists available at Kevin's Word Lists Page (http://wordlist.sourceforge.net). Lists with the suffixes 10, 20, 35, 50, 65 and 65 were used. Lists with the suffixes 70, 80 and 95 were excluded. Copyright information for SCOWL and the wordlists used in creating it is reproduced below. - -The affix file is identical to the MySpell English (United States) affix file. It is a heavily modified version of the original english.aff file which was released as part of Geoff Kuenning's Ispell and as such is covered by his BSD license. - ---- - -COPYRIGHT, SOURCES, and CREDITS from SCOWL readme file: - -The collective work is Copyright 2000 by Kevin Atkinson as well as any -of the copyrights mentioned below: - - Copyright 2000 by Kevin Atkinson - - Permission to use, copy, modify, distribute and sell these word - lists, the associated scripts, the output created from the scripts, - and its documentation for any purpose is hereby granted without fee, - provided that the above copyright notice appears in all copies and - that both that copyright notice and this permission notice appear in - supporting documentation. Kevin Atkinson makes no representations - about the suitability of this array for any purpose. It is provided - "as is" without express or implied warranty. - -Alan Beale <biljir@pobox.com> also deserves special credit as he has, -in addition to providing the 12Dicts package and being a major -contributor to the ENABLE word list, given me an incredible amount of -feedback and created a number of special lists (those found in the -Supplement) in order to help improve the overall quality of SCOWL. - -The 10 level includes the 1000 most common English words (according to -the Moby (TM) Words II [MWords] package), a subset of the 1000 most -common words on the Internet (again, according to Moby Words II), and -frequently class 16 from Brian Kelk's "UK English Wordlist -with Frequency Classification". - -The MWords package was explicitly placed in the public domain: - - The Moby lexicon project is complete and has - been place into the public domain. Use, sell, - rework, excerpt and use in any way on any platform. - - Placing this material on internal or public servers is - also encouraged. The compiler is not aware of any - export restrictions so freely distribute world-wide. - - You can verify the public domain status by contacting - - Grady Ward - 3449 Martha Ct. - Arcata, CA 95521-4884 - - grady@netcom.com - grady@northcoast.com - -The "UK English Wordlist With Frequency Classification" is also in the -Public Domain: - - Date: Sat, 08 Jul 2000 20:27:21 +0100 - From: Brian Kelk <Brian.Kelk@cl.cam.ac.uk> - -> I was wondering what the copyright status of your "UK English - > Wordlist With Frequency Classification" word list as it seems to - > be lacking any copyright notice. - - There were many many sources in total, but any text marked - "copyright" was avoided. Locally-written documentation was one - source. An earlier version of the list resided in a filespace called - PUBLIC on the University mainframe, because it was considered public - domain. - - Date: Tue, 11 Jul 2000 19:31:34 +0100 - - > So are you saying your word list is also in the public domain? - - That is the intention. - -The 20 level includes frequency classes 7-15 from Brian's word list. - -The 35 level includes frequency classes 2-6 and words appearing in at -least 11 of 12 dictionaries as indicated in the 12Dicts package. All -words from the 12Dicts package have had likely inflections added via -my inflection database. - -The 12Dicts package and Supplement is in the Public Domain. - -The WordNet database, which was used in the creation of the -Inflections database, is under the following copyright: - - This software and database is being provided to you, the LICENSEE, - by Princeton University under the following license. By obtaining, - using and/or copying this software and database, you agree that you - have read, understood, and will comply with these terms and - conditions.: - - Permission to use, copy, modify and distribute this software and - database and its documentation for any purpose and without fee or - royalty is hereby granted, provided that you agree to comply with - the following copyright notice and statements, including the - disclaimer, and that the same appear on ALL copies of the software, - database and documentation, including modifications that you make - for internal use or for distribution. - - WordNet 1.6 Copyright 1997 by Princeton University. All rights - reserved. - - THIS SOFTWARE AND DATABASE IS PROVIDED "AS IS" AND PRINCETON - UNIVERSITY MAKES NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR - IMPLIED. BY WAY OF EXAMPLE, BUT NOT LIMITATION, PRINCETON - UNIVERSITY MAKES NO REPRESENTATIONS OR WARRANTIES OF MERCHANT- - ABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR THAT THE USE OF THE - LICENSED SOFTWARE, DATABASE OR DOCUMENTATION WILL NOT INFRINGE ANY - THIRD PARTY PATENTS, COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS. - - The name of Princeton University or Princeton may not be used in - advertising or publicity pertaining to distribution of the software - and/or database. Title to copyright in this software, database and - any associated documentation shall at all times remain with - Princeton University and LICENSEE agrees to preserve same. - -The 50 level includes Brian's frequency class 1, words words appearing -in at least 5 of 12 of the dictionaries as indicated in the 12Dicts -package, and uppercase words in at least 4 of the previous 12 -dictionaries. A decent number of proper names is also included: The -top 1000 male, female, and Last names from the 1990 Census report; a -list of names sent to me by Alan Beale; and a few names that I added -myself. Finally a small list of abbreviations not commonly found in -other word lists is included. - -The name files form the Census report is a government document which I -don't think can be copyrighted. - -The name list from Alan Beale is also derived from the linux words -list, which is derived from the DEC list. He also added a bunch of -miscellaneous names to the list, which he released to the Public Domain. - -The DEC Word list doesn't have a formal name. It is labeled as "FILE: -english.words; VERSION: DEC-SRC-92-04-05" and was put together by Jorge -Stolfi <stolfi@src.dec.com> DEC Systems Research Center. The DEC Word -list has the following copyright statement: - - (NON-)COPYRIGHT STATUS - - To the best of my knowledge, all the files I used to build these - wordlists were available for public distribution and use, at least - for non-commercial purposes. I have confirmed this assumption with - the authors of the lists, whenever they were known. - - Therefore, it is safe to assume that the wordlists in this package - can also be freely copied, distributed, modified, and used for - personal, educational, and research purposes. (Use of these files in - commercial products may require written permission from DEC and/or - the authors of the original lists.) - - Whenever you distribute any of these wordlists, please distribute - also the accompanying README file. If you distribute a modified - copy of one of these wordlists, please include the original README - file with a note explaining your modifications. Your users will - surely appreciate that. - - (NO-)WARRANTY DISCLAIMER - - These files, like the original wordlists on which they are based, - are still very incomplete, uneven, and inconsitent, and probably - contain many errors. They are offered "as is" without any warranty - of correctness or fitness for any particular purpose. Neither I nor - my employer can be held responsible for any losses or damages that - may result from their use. - -However since this Word List is used in the linux.words package which -the author claims is free of any copyright I assume it is OK to use -for most purposes. If you want to use this in a commercial project -and this concerns you the information from the DEC word list can -easily be removed without much sacrifice in quality as only the name -lists were used. - -The file special-jargon.50 uses common.lst and word.lst from the -"Unofficial Jargon File Word Lists" which is derived from "The Jargon -File". All of which is in the Public Domain. This file also contain -a few extra UNIX terms which are found in the file "unix-terms" in the -special/ directory. - -The 60 level includes Brian's frequency class 0 and all words -appearing in at least 2 of the 12 dictionaries as indicated by the -12Dicts package. A large number of names are also included: The 4,946 -female names and 3,897 male names from the MWords package and the -files "computer.names", "misc.names", and "org.names" from the DEC -package. - -The 65 level includes words found in the Ispell "medium" word list. -The Ispell word lists are under the same copyright of Ispell itself -which is: - - Copyright 1993, Geoff Kuenning, Granada Hills, CA - All rights reserved. - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions - are met: - - 1. Redistributions of source code must retain the above copyright - notice, this list of conditions and the following disclaimer. - 2. Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - 3. All modifications to the source code must be clearly marked as - such. Binary redistributions based on modified source code - must be clearly marked as modified versions in the documentation - and/or other materials provided with the distribution. - 4. All advertising materials mentioning features or use of this software - must display the following acknowledgment: - This product includes software developed by Geoff Kuenning and - other unpaid contributors. - 5. The name of Geoff Kuenning may not be used to endorse or promote - products derived from this software without specific prior - written permission. - - THIS SOFTWARE IS PROVIDED BY GEOFF KUENNING AND CONTRIBUTORS ``AS - IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT - LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS - FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GEOFF - KUENNING OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, - INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, - BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN - ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE - POSSIBILITY OF SUCH DAMAGE. - -The 70 level includes the 74,550 common dictionary words and the 21,986 names -list from the MWords package. The common dictionary words, like those -from the 12Dicts package, have had all likely inflections added. - -The 80 level includes the ENABLE word list, all the lists in the -ENABLE supplement package (except for ABLE), the "UK Advanced Cryptics -Dictionary" (UKACD), the list of signature words in from YAWL package, -and the 10,196 places list from the MWords package. - -The ENABLE package, mainted by M\Cooper <thegrendel@theriver.com>, -is in the Public Domain: - - The ENABLE master word list, WORD.LST, is herewith formally released - into the Public Domain. Anyone is free to use it or distribute it in - any manner they see fit. No fee or registration is required for its - use nor are "contributions" solicited (if you feel you absolutely - must contribute something for your own peace of mind, the authors of - the ENABLE list ask that you make a donation on their behalf to your - favorite charity). This word list is our gift to the Scrabble - community, as an alternate to "official" word lists. Game designers - may feel free to incorporate the WORD.LST into their games. Please - mention the source and credit us as originators of the list. Note - that if you, as a game designer, use the WORD.LST in your product, - you may still copyright and protect your product, but you may *not* - legally copyright or in any way restrict redistribution of the - WORD.LST portion of your product. This *may* under law restrict your - rights to restrict your users' rights, but that is only fair. - -UKACD, by J Ross Beresford <ross@bryson.demon.co.uk>, is under the -following copyright: - - Copyright (c) J Ross Beresford 1993-1999. All Rights Reserved. - - The following restriction is placed on the use of this publication: - if The UK Advanced Cryptics Dictionary is used in a software package - or redistributed in any form, the copyright notice must be - prominently displayed and the text of this document must be included - verbatim. - - There are no other restrictions: I would like to see the list - distributed as widely as possible. - -The 95 level includes the 354,984 single words and 256,772 compound -words from the MWords package, ABLE.LST from the ENABLE Supplement, -and some additional words found in my part-of-speech database that -were not found anywhere else. - -Accent information was taken from UKACD. - -My VARCON package was used to create the American, British, and -Canadian word list. - -Since the original word lists used used in the -VARCON package came from the Ispell distribution they are under the -Ispell copyright. - -The variant word lists were created from a list of variants found in -the 12dicts supplement package as well as a list of variants I created -myself. - - - - -=================================================== -en_GB: -This dictionary was initially based on a subset of the -original English wordlist created by Kevin Atkinson for -Pspell and Aspell and thus is covered by his original -LGPL licence. - -It has been extensively updated by David Bartlett, Brian Kelk -and Andrew Brown: -- numerous Americanism have been removed -- numerous American spellings have been corrected -- missing words have been added -- many errors have been corrected -- compound hyphenated words have been added where appropriate - -Valuable inputs to this process were received from many other -people - far too numerous to name. Serious thanks to you all -for your greatly appreciated help. - -This word list is intended to be a good representation of -current modern British English and thus it should be a good -basis for Commonwealth English in most countries of the world -outside North America. - -The affix file has been created completely from scratch -by David Bartlett and Andrew Brown, based on the published -rules for MySpell and is also provided under the LGPL. - -In creating the affix rules an attempt has been made to -reproduce the most general rules for English word -formation, rather than merely use it as a means to -compress the size of the dictionary. It is hoped that this -will facilitate future localisation to other variants of -English. - -Please let David Bartlett <dwb@openoffice.org> know of any -errors that you find. - -The current release is R 1.18, 11/04/05 -=================================================== -en_NZ: -I. Copyright -II. Copying (Licence) ----------------------------- - -I. Copyright - -NZ English Dictionary v0.9 beta - Build 06SEP03 -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -NB This is an initial version, please check: -http://lingucomponent.openoffice.org/download_dictionary.html -or -http://www.girlza.com/dictionary/download.html -for a final version, after a little while (no hurry). - -This dictionary is based on the en_GB Myspell dictionary -which in turn was initially based on a subset of the -original English wordlist created by Kevin Atkinson for -Pspell and Aspell and thus is covered by his original -LGPL licence. - - -Introduction -~~~~~~~~~~~~ -en_NZ.dic has been altered to include New Zealand places, -including major cities and towns, and major suburbs. It -also contains NZ words, organisations and expressions. - -en_NZ.aff has had a few REPlace strings added, but is -basically unchanged. - - -Acknowledgements -~~~~~~~~~~~~~~~~ -Thanks must go to the original creators of the British -dictionary, David Bartlett, Brian Kelk and Andrew Brown. - -I wouldn't have started this without seeing the Australian -dictionary, thanks Kelvin Eldridge, Jean Hollis Weber and -David Wilson. - -And thank you to all who've contributed to OpenOffice.org. - - -License -~~~~~~~ -This dictionary is covered by the GNU Lesser General Public -License, viewable at http://www.gnu.org/copyleft/lesser.html - - -Issues -~~~~~~ -Many of the proper nouns already in the dictionary do not have -an affix for 's. -All my new words start after the z's of the original dictionary. - - -Contact -~~~~~~~ -Contact Tristan Burtenshaw (hooty@slingshot.co.nz) with any words, -places or other suggestions for the dictionary. - - - -II. Copying - - GNU LESSER GENERAL PUBLIC LICENSE - Version 2.1, February 1999 - - Copyright (C) 1991, 1999 Free Software Foundation, Inc. - 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA - Everyone is permitted to copy and distribute verbatim copies - of this license document, but changing it is not allowed. - -[This is the first released version of the Lesser GPL. It also counts - as the successor of the GNU Library Public License, version 2, hence - the version number 2.1.] - - Preamble - - The licenses for most software are designed to take away your -freedom to share and change it. By contrast, the GNU General Public -Licenses are intended to guarantee your freedom to share and change -free software--to make sure the software is free for all its users. - - This license, the Lesser General Public License, applies to some -specially designated software packages--typically libraries--of the -Free Software Foundation and other authors who decide to use it. You -can use it too, but we suggest you first think carefully about whether -this license or the ordinary General Public License is the better -strategy to use in any particular case, based on the explanations below. - - When we speak of free software, we are referring to freedom of use, -not price. Our General Public Licenses are designed to make sure that -you have the freedom to distribute copies of free software (and charge -for this service if you wish); that you receive source code or can get -it if you want it; that you can change the software and use pieces of -it in new free programs; and that you are informed that you can do -these things. - - To protect your rights, we need to make restrictions that forbid -distributors to deny you these rights or to ask you to surrender these -rights. These restrictions translate to certain responsibilities for -you if you distribute copies of the library or if you modify it. - - For example, if you distribute copies of the library, whether gratis -or for a fee, you must give the recipients all the rights that we gave -you. You must make sure that they, too, receive or can get the source -code. If you link other code with the library, you must provide -complete object files to the recipients, so that they can relink them -with the library after making changes to the library and recompiling -it. And you must show them these terms so they know their rights. - - We protect your rights with a two-step method: (1) we copyright the -library, and (2) we offer you this license, which gives you legal -permission to copy, distribute and/or modify the library. - - To protect each distributor, we want to make it very clear that -there is no warranty for the free library. Also, if the library is -modified by someone else and passed on, the recipients should know -that what they have is not the original version, so that the original -author's reputation will not be affected by problems that might be -introduced by others. - - Finally, software patents pose a constant threat to the existence of -any free program. We wish to make sure that a company cannot -effectively restrict the users of a free program by obtaining a -restrictive license from a patent holder. Therefore, we insist that -any patent license obtained for a version of the library must be -consistent with the full freedom of use specified in this license. - - Most GNU software, including some libraries, is covered by the -ordinary GNU General Public License. This license, the GNU Lesser -General Public License, applies to certain designated libraries, and -is quite different from the ordinary General Public License. We use -this license for certain libraries in order to permit linking those -libraries into non-free programs. - - When a program is linked with a library, whether statically or using -a shared library, the combination of the two is legally speaking a -combined work, a derivative of the original library. The ordinary -General Public License therefore permits such linking only if the -entire combination fits its criteria of freedom. The Lesser General -Public License permits more lax criteria for linking other code with -the library. - - We call this license the "Lesser" General Public License because it -does Less to protect the user's freedom than the ordinary General -Public License. It also provides other free software developers Less -of an advantage over competing non-free programs. These disadvantages -are the reason we use the ordinary General Public License for many -libraries. However, the Lesser license provides advantages in certain -special circumstances. - - For example, on rare occasions, there may be a special need to -encourage the widest possible use of a certain library, so that it becomes -a de-facto standard. To achieve this, non-free programs must be -allowed to use the library. A more frequent case is that a free -library does the same job as widely used non-free libraries. In this -case, there is little to gain by limiting the free library to free -software only, so we use the Lesser General Public License. - - In other cases, permission to use a particular library in non-free -programs enables a greater number of people to use a large body of -free software. For example, permission to use the GNU C Library in -non-free programs enables many more people to use the whole GNU -operating system, as well as its variant, the GNU/Linux operating -system. - - Although the Lesser General Public License is Less protective of the -users' freedom, it does ensure that the user of a program that is -linked with the Library has the freedom and the wherewithal to run -that program using a modified version of the Library. - - The precise terms and conditions for copying, distribution and -modification follow. Pay close attention to the difference between a -"work based on the library" and a "work that uses the library". The -former contains code derived from the library, whereas the latter must -be combined with the library in order to run. - - GNU LESSER GENERAL PUBLIC LICENSE - TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION - - 0. This License Agreement applies to any software library or other -program which contains a notice placed by the copyright holder or -other authorized party saying it may be distributed under the terms of -this Lesser General Public License (also called "this License"). -Each licensee is addressed as "you". - - A "library" means a collection of software functions and/or data -prepared so as to be conveniently linked with application programs -(which use some of those functions and data) to form executables. - - The "Library", below, refers to any such software library or work -which has been distributed under these terms. A "work based on the -Library" means either the Library or any derivative work under -copyright law: that is to say, a work containing the Library or a -portion of it, either verbatim or with modifications and/or translated -straightforwardly into another language. (Hereinafter, translation is -included without limitation in the term "modification".) - - "Source code" for a work means the preferred form of the work for -making modifications to it. For a library, complete source code means -all the source code for all modules it contains, plus any associated -interface definition files, plus the scripts used to control compilation -and installation of the library. - - Activities other than copying, distribution and modification are not -covered by this License; they are outside its scope. The act of -running a program using the Library is not restricted, and output from -such a program is covered only if its contents constitute a work based -on the Library (independent of the use of the Library in a tool for -writing it). Whether that is true depends on what the Library does -and what the program that uses the Library does. - - 1. You may copy and distribute verbatim copies of the Library's -complete source code as you receive it, in any medium, provided that -you conspicuously and appropriately publish on each copy an -appropriate copyright notice and disclaimer of warranty; keep intact -all the notices that refer to this License and to the absence of any -warranty; and distribute a copy of this License along with the -Library. - - You may charge a fee for the physical act of transferring a copy, -and you may at your option offer warranty protection in exchange for a -fee. - - 2. You may modify your copy or copies of the Library or any portion -of it, thus forming a work based on the Library, and copy and -distribute such modifications or work under the terms of Section 1 -above, provided that you also meet all of these conditions: - - a) The modified work must itself be a software library. - - b) You must cause the files modified to carry prominent notices - stating that you changed the files and the date of any change. - - c) You must cause the whole of the work to be licensed at no - charge to all third parties under the terms of this License. - - d) If a facility in the modified Library refers to a function or a - table of data to be supplied by an application program that uses - the facility, other than as an argument passed when the facility - is invoked, then you must make a good faith effort to ensure that, - in the event an application does not supply such function or - table, the facility still operates, and performs whatever part of - its purpose remains meaningful. - - (For example, a function in a library to compute square roots has - a purpose that is entirely well-defined independent of the - application. Therefore, Subsection 2d requires that any - application-supplied function or table used by this function must - be optional: if the application does not supply it, the square - root function must still compute square roots.) - -These requirements apply to the modified work as a whole. If -identifiable sections of that work are not derived from the Library, -and can be reasonably considered independent and separate works in -themselves, then this License, and its terms, do not apply to those -sections when you distribute them as separate works. But when you -distribute the same sections as part of a whole which is a work based -on the Library, the distribution of the whole must be on the terms of -this License, whose permissions for other licensees extend to the -entire whole, and thus to each and every part regardless of who wrote -it. - -Thus, it is not the intent of this section to claim rights or contest -your rights to work written entirely by you; rather, the intent is to -exercise the right to control the distribution of derivative or -collective works based on the Library. - -In addition, mere aggregation of another work not based on the Library -with the Library (or with a work based on the Library) on a volume of -a storage or distribution medium does not bring the other work under -the scope of this License. - - 3. You may opt to apply the terms of the ordinary GNU General Public -License instead of this License to a given copy of the Library. To do -this, you must alter all the notices that refer to this License, so -that they refer to the ordinary GNU General Public License, version 2, -instead of to this License. (If a newer version than version 2 of the -ordinary GNU General Public License has appeared, then you can specify -that version instead if you wish.) Do not make any other change in -these notices. - - Once this change is made in a given copy, it is irreversible for -that copy, so the ordinary GNU General Public License applies to all -subsequent copies and derivative works made from that copy. - - This option is useful when you wish to copy part of the code of -the Library into a program that is not a library. - - 4. You may copy and distribute the Library (or a portion or -derivative of it, under Section 2) in object code or executable form -under the terms of Sections 1 and 2 above provided that you accompany -it with the complete corresponding machine-readable source code, which -must be distributed under the terms of Sections 1 and 2 above on a -medium customarily used for software interchange. - - If distribution of object code is made by offering access to copy -from a designated place, then offering equivalent access to copy the -source code from the same place satisfies the requirement to -distribute the source code, even though third parties are not -compelled to copy the source along with the object code. - - 5. A program that contains no derivative of any portion of the -Library, but is designed to work with the Library by being compiled or -linked with it, is called a "work that uses the Library". Such a -work, in isolation, is not a derivative work of the Library, and -therefore falls outside the scope of this License. - - However, linking a "work that uses the Library" with the Library -creates an executable that is a derivative of the Library (because it -contains portions of the Library), rather than a "work that uses the -library". The executable is therefore covered by this License. -Section 6 states terms for distribution of such executables. - - When a "work that uses the Library" uses material from a header file -that is part of the Library, the object code for the work may be a -derivative work of the Library even though the source code is not. -Whether this is true is especially significant if the work can be -linked without the Library, or if the work is itself a library. The -threshold for this to be true is not precisely defined by law. - - If such an object file uses only numerical parameters, data -structure layouts and accessors, and small macros and small inline -functions (ten lines or less in length), then the use of the object -file is unrestricted, regardless of whether it is legally a derivative -work. (Executables containing this object code plus portions of the -Library will still fall under Section 6.) - - Otherwise, if the work is a derivative of the Library, you may -distribute the object code for the work under the terms of Section 6. -Any executables containing that work also fall under Section 6, -whether or not they are linked directly with the Library itself. - - 6. As an exception to the Sections above, you may also combine or -link a "work that uses the Library" with the Library to produce a -work containing portions of the Library, and distribute that work -under terms of your choice, provided that the terms permit -modification of the work for the customer's own use and reverse -engineering for debugging such modifications. - - You must give prominent notice with each copy of the work that the -Library is used in it and that the Library and its use are covered by -this License. You must supply a copy of this License. If the work -during execution displays copyright notices, you must include the -copyright notice for the Library among them, as well as a reference -directing the user to the copy of this License. Also, you must do one -of these things: - - a) Accompany the work with the complete corresponding - machine-readable source code for the Library including whatever - changes were used in the work (which must be distributed under - Sections 1 and 2 above); and, if the work is an executable linked - with the Library, with the complete machine-readable "work that - uses the Library", as object code and/or source code, so that the - user can modify the Library and then relink to produce a modified - executable containing the modified Library. (It is understood - that the user who changes the contents of definitions files in the - Library will not necessarily be able to recompile the application - to use the modified definitions.) - - b) Use a suitable shared library mechanism for linking with the - Library. A suitable mechanism is one that (1) uses at run time a - copy of the library already present on the user's computer system, - rather than copying library functions into the executable, and (2) - will operate properly with a modified version of the library, if - the user installs one, as long as the modified version is - interface-compatible with the version that the work was made with. - - c) Accompany the work with a written offer, valid for at - least three years, to give the same user the materials - specified in Subsection 6a, above, for a charge no more - than the cost of performing this distribution. - - d) If distribution of the work is made by offering access to copy - from a designated place, offer equivalent access to copy the above - specified materials from the same place. - - e) Verify that the user has already received a copy of these - materials or that you have already sent this user a copy. - - For an executable, the required form of the "work that uses the -Library" must include any data and utility programs needed for -reproducing the executable from it. However, as a special exception, -the materials to be distributed need not include anything that is -normally distributed (in either source or binary form) with the major -components (compiler, kernel, and so on) of the operating system on -which the executable runs, unless that component itself accompanies -the executable. - - It may happen that this requirement contradicts the license -restrictions of other proprietary libraries that do not normally -accompany the operating system. Such a contradiction means you cannot -use both them and the Library together in an executable that you -distribute. - - 7. You may place library facilities that are a work based on the -Library side-by-side in a single library together with other library -facilities not covered by this License, and distribute such a combined -library, provided that the separate distribution of the work based on -the Library and of the other library facilities is otherwise -permitted, and provided that you do these two things: - - a) Accompany the combined library with a copy of the same work - based on the Library, uncombined with any other library - facilities. This must be distributed under the terms of the - Sections above. - - b) Give prominent notice with the combined library of the fact - that part of it is a work based on the Library, and explaining - where to find the accompanying uncombined form of the same work. - - 8. You may not copy, modify, sublicense, link with, or distribute -the Library except as expressly provided under this License. Any -attempt otherwise to copy, modify, sublicense, link with, or -distribute the Library is void, and will automatically terminate your -rights under this License. However, parties who have received copies, -or rights, from you under this License will not have their licenses -terminated so long as such parties remain in full compliance. - - 9. You are not required to accept this License, since you have not -signed it. However, nothing else grants you permission to modify or -distribute the Library or its derivative works. These actions are -prohibited by law if you do not accept this License. Therefore, by -modifying or distributing the Library (or any work based on the -Library), you indicate your acceptance of this License to do so, and -all its terms and conditions for copying, distributing or modifying -the Library or works based on it. - - 10. Each time you redistribute the Library (or any work based on the -Library), the recipient automatically receives a license from the -original licensor to copy, distribute, link with or modify the Library -subject to these terms and conditions. You may not impose any further -restrictions on the recipients' exercise of the rights granted herein. -You are not responsible for enforcing compliance by third parties with -this License. - - 11. If, as a consequence of a court judgment or allegation of patent -infringement or for any other reason (not limited to patent issues), -conditions are imposed on you (whether by court order, agreement or -otherwise) that contradict the conditions of this License, they do not -excuse you from the conditions of this License. If you cannot -distribute so as to satisfy simultaneously your obligations under this -License and any other pertinent obligations, then as a consequence you -may not distribute the Library at all. For example, if a patent -license would not permit royalty-free redistribution of the Library by -all those who receive copies directly or indirectly through you, then -the only way you could satisfy both it and this License would be to -refrain entirely from distribution of the Library. - -If any portion of this section is held invalid or unenforceable under any -particular circumstance, the balance of the section is intended to apply, -and the section as a whole is intended to apply in other circumstances. - -It is not the purpose of this section to induce you to infringe any -patents or other property right claims or to contest validity of any -such claims; this section has the sole purpose of protecting the -integrity of the free software distribution system which is -implemented by public license practices. Many people have made -generous contributions to the wide range of software distributed -through that system in reliance on consistent application of that -system; it is up to the author/donor to decide if he or she is willing -to distribute software through any other system and a licensee cannot -impose that choice. - -This section is intended to make thoroughly clear what is believed to -be a consequence of the rest of this License. - - 12. If the distribution and/or use of the Library is restricted in -certain countries either by patents or by copyrighted interfaces, the -original copyright holder who places the Library under this License may add -an explicit geographical distribution limitation excluding those countries, -so that distribution is permitted only in or among countries not thus -excluded. In such case, this License incorporates the limitation as if -written in the body of this License. - - 13. The Free Software Foundation may publish revised and/or new -versions of the Lesser General Public License from time to time. -Such new versions will be similar in spirit to the present version, -but may differ in detail to address new problems or concerns. - -Each version is given a distinguishing version number. If the Library -specifies a version number of this License which applies to it and -"any later version", you have the option of following the terms and -conditions either of that version or of any later version published by -the Free Software Foundation. If the Library does not specify a -license version number, you may choose any version ever published by -the Free Software Foundation. - - 14. If you wish to incorporate parts of the Library into other free -programs whose distribution conditions are incompatible with these, -write to the author to ask for permission. For software which is -copyrighted by the Free Software Foundation, write to the Free -Software Foundation; we sometimes make exceptions for this. Our -decision will be guided by the two goals of preserving the free status -of all derivatives of our free software and of promoting the sharing -and reuse of software generally. - - NO WARRANTY - - 15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO -WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. -EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR -OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY -KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR -PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE -LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME -THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. - - 16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN -WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY -AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU -FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR -CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE -LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING -RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A -FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF -SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH -DAMAGES. - - END OF TERMS AND CONDITIONS - diff --git a/share/vim/vim72/spell/bg/main.aap b/share/vim/vim72/spell/bg/main.aap deleted file mode 100644 index 2ccea86c68..0000000000 --- a/share/vim/vim72/spell/bg/main.aap +++ /dev/null @@ -1,80 +0,0 @@ -# Aap recipe for Bulgarian Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = bg_BG.aff bg_BG.dic - -all: $SPELLDIR/bg.cp1251.spl $SPELLDIR/bg.utf-8.spl ../README_bg.txt - -$SPELLDIR/bg.cp1251.spl : $FILES - :sys env LANG=bg_BG.CP1251 $VIM -u NONE -e -c "mkspell! $SPELLDIR/bg bg_BG" -c q - -$SPELLDIR/bg.utf-8.spl : $FILES - :sys env LANG=bg_BG.UTF-8 $VIM -u NONE -e -c "mkspell! $SPELLDIR/bg bg_BG" -c q - -../README_bg.txt: README_bg_BG.txt - :copy $source $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} bg_BG.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -# This is a bit tricky, since the file name includes the date. -bg_BG.aff bg_BG.dic: {buildcheck=} - :assertpkg unzip patch - :fetch bg_BG.zip - :sys $UNZIP bg_BG.zip - :delete bg_BG.zip - :sys $VIM bg_BG.aff -e -c "set ff=unix" -c update -c q - :sys $VIM bg_BG.dic -e -c "set ff=unix" -c update -c q - :sys $VIM README_bg_BG.txt -e -c "set ff=unix" -c update -c q - @if not os.path.exists('bg_BG.orig.aff'): - :copy bg_BG.aff bg_BG.orig.aff - @if not os.path.exists('bg_BG.orig.dic'): - :copy bg_BG.dic bg_BG.orig.dic - @if os.path.exists('bg_BG.diff'): - :sys patch <bg_BG.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 bg_BG.orig.aff bg_BG.aff >bg_BG.diff - :sys {force} diff -a -C 1 bg_BG.orig.dic bg_BG.dic >>bg_BG.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch bg_BG.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../bg_BG.zip - :sys {force} diff ../bg_BG.orig.aff bg_BG.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy bg_BG.aff ../bg_BG.new.aff - :sys {force} diff ../bg_BG.orig.dic bg_BG.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy bg_BG.dic ../bg_BG.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete bg_BG.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/ca/main.aap b/share/vim/vim72/spell/ca/main.aap deleted file mode 100644 index 2182f29164..0000000000 --- a/share/vim/vim72/spell/ca/main.aap +++ /dev/null @@ -1,81 +0,0 @@ -# Aap recipe for Catelan (Spain) Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = ca_ES.aff ca_ES.dic - -all: $SPELLDIR/ca.latin1.spl $SPELLDIR/ca.utf-8.spl ../README_ca.txt - -$SPELLDIR/ca.latin1.spl : $FILES - :sys env LANG=ca_ES.ISO8859-1 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/ca ca_ES" -c q - -$SPELLDIR/ca.utf-8.spl : $FILES - :sys env LANG=ca_ES.UTF-8 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/ca ca_ES" -c q - -../README_ca.txt : README_ca_ES.txt - :copy $source $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} ca_ES.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -# Make sure the files are in Unix fileformat -ca_ES.aff ca_ES.dic: {buildcheck=} - :assertpkg unzip patch - :fetch ca_ES.zip - :sys $UNZIP ca_ES.zip - :delete ca_ES.zip - :sys $VIM ca_ES.aff -c "set ff=unix" -c "update" -c q - :sys $VIM ca_ES.dic -c "set ff=unix" -c "update" -c q - @if not os.path.exists('ca_ES.orig.aff'): - :copy ca_ES.aff ca_ES.orig.aff - @if not os.path.exists('ca_ES.orig.dic'): - :copy ca_ES.dic ca_ES.orig.dic - @if os.path.exists('ca_ES.diff'): - :sys patch <ca_ES.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 ca_ES.orig.aff ca_ES.aff >ca_ES.diff - :sys {force} diff -a -C 1 ca_ES.orig.dic ca_ES.dic >>ca_ES.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch ca_ES.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../ca_ES.zip - :sys {force} diff ../ca_ES.orig.aff ca_ES.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy ca_ES.aff ../ca_ES.new.aff - :sys {force} diff ../ca_ES.orig.dic ca_ES.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy ca_ES.dic ../ca_ES.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete ca_ES.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/cy/main.aap b/share/vim/vim72/spell/cy/main.aap deleted file mode 100644 index ce6cb840f8..0000000000 --- a/share/vim/vim72/spell/cy/main.aap +++ /dev/null @@ -1,82 +0,0 @@ -# Aap recipe for Welsh Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = cy_GB.aff cy_GB.dic - -all: $SPELLDIR/cy.iso-8859-14.spl $SPELLDIR/cy.utf-8.spl \ - ../README_cy.txt - -$SPELLDIR/cy.iso-8859-14.spl : $FILES - :sys $VIM -u NONE -e -c "set enc=iso-8859-14" - -c "mkspell! $SPELLDIR/cy cy_GB" -c q - -$SPELLDIR/cy.utf-8.spl : $FILES - :sys $VIM -u NONE -e -c "set enc=utf-8" - -c "mkspell! $SPELLDIR/cy cy_GB" -c q - -../README_cy.txt : README_cy_GB.txt - :copy $source $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} cy_GB.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -cy_GB.aff cy_GB.dic: {buildcheck=} - :assertpkg unzip patch - :fetch cy_GB.zip - :sys $UNZIP cy_GB.zip - :delete cy_GB.zip - :sys $VIM cy_GB.aff -e -c "set ff=unix" -c update -c q - :sys $VIM cy_GB.dic -e -c "set ff=unix" -c update -c q - :sys $VIM README_cy_GB.txt -e -c "set ff=unix" -c update -c q - @if not os.path.exists('cy_GB.orig.aff'): - :copy cy_GB.aff cy_GB.orig.aff - @if not os.path.exists('cy_GB.orig.dic'): - :copy cy_GB.dic cy_GB.orig.dic - @if os.path.exists('cy_GB.diff'): - :sys patch <cy_GB.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 cy_GB.orig.aff cy_GB.aff >cy_GB.diff - :sys {force} diff -a -C 1 cy_GB.orig.dic cy_GB.dic >>cy_GB.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch cy_GB.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../cy_GB.zip - :sys {force} diff ../cy_GB.orig.aff cy_GB.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy cy_GB.aff ../cy_GB.new.aff - :sys {force} diff ../cy_GB.orig.dic cy_GB.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy cy_GB.dic ../cy_GB.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete cy_GB.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/de/main.aap b/share/vim/vim72/spell/de/main.aap deleted file mode 100644 index b4cf32115b..0000000000 --- a/share/vim/vim72/spell/de/main.aap +++ /dev/null @@ -1,236 +0,0 @@ -# Aap recipe for German Vim spell files. -# -# Since there is a big discussion about whether to use the old or the new -# spelling rules, both have been included. -# "de": all possible words allowed -# "de_de": old and new German spelling -# "de_19": old German spelling -# "de_20": new German spelling -# "de_AT": Austrian spelling -# "de_CH": Swiss spelling - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -REGIONS = DE 19 20 AT CH -DE_REGIONS = de_$*REGIONS - -SPELLDIR = .. -FILES = de_$*(REGIONS).aff de_$*(REGIONS).dic - -ZIPFILE_DE = de_DE_comb.zip -ZIPFILE_19 = de_OLDSPELL.zip -ZIPFILE_20 = de_DE_neu.zip -ZIPFILE_AT = de_DE.zip -ZIPFILE_CH = de_CH.zip -ZIPFILES = $ZIPFILE_DE $ZIPFILE_19 $ZIPFILE_20 $ZIPFILE_AT $ZIPFILE_CH - -READMES = README_de_$*(REGIONS).txt - -all: $SPELLDIR/de.latin1.spl $SPELLDIR/de.utf-8.spl ../README_de.txt - -$SPELLDIR/de.latin1.spl : $FILES - :sys env LANG=de_DE.ISO8859-1 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/de $DE_REGIONS" -c q - -$SPELLDIR/de.utf-8.spl : $FILES - :sys env LANG=de_DE.UTF-8 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/de $DE_REGIONS" -c q - -../README_de.txt: $READMES - :print de_DE (combined) >! $target - :cat README_de_DE.txt >> $target - :print =================================================== >>$target - :print de_19 (old) >> $target - :cat README_de_19.txt >> $target - :print =================================================== >>$target - :print de_20 (new) >> $target - :cat README_de_20.txt >> $target - :print =================================================== >>$target - :print de_AT (Austria) >> $target - :cat README_de_AT.txt >> $target - :print =================================================== >>$target - :print de_CH (Swiss) >> $target - :cat README_de_CH.txt >> $target - -# -# Fetching the files from the OpenOffice.org site. -# The OLDSPELL file comes from elsewhere -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -DEDIR = http://www.j3e.de/myspell -:attr {fetch = $OODIR/%file%} $ZIPFILES -:attr {fetch = $DEDIR/%file%} $ZIPFILE_19 - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -de_DE.aff de_DE.dic: {buildcheck=} - :assertpkg unzip patch - :fetch $ZIPFILE_DE - :sys $UNZIP $ZIPFILE_DE - :delete $ZIPFILE_DE - :move de_DE_comb.aff de_DE.aff - :move de_DE_comb.dic de_DE.dic - :move README_de_DE_comb.txt README_de_DE.txt - @if not os.path.exists('de_DE.orig.aff'): - :copy de_DE.aff de_DE.orig.aff - @if not os.path.exists('de_DE.orig.dic'): - :copy de_DE.dic de_DE.orig.dic - @if os.path.exists('de_DE.diff'): - :sys patch <de_DE.diff - -de_19.aff de_19.dic: {buildcheck=} - :assertpkg unzip patch - :fetch $ZIPFILE_19 - :sys $UNZIP $ZIPFILE_19 - :delete $ZIPFILE_19 - :move de_OLDSPELL.aff de_19.aff - :move de_OLDSPELL.dic de_19.dic - # there is no README file - :print There is no README file for the old spelling >!README_de_19.txt - @if not os.path.exists('de_19.orig.aff'): - :copy de_19.aff de_19.orig.aff - @if not os.path.exists('de_19.orig.dic'): - :copy de_19.dic de_19.orig.dic - @if os.path.exists('de_19.diff'): - :sys patch <de_19.diff - -de_20.aff de_20.dic: {buildcheck=} - :assertpkg unzip patch - :fetch $ZIPFILE_20 - :sys $UNZIP $ZIPFILE_20 - :delete $ZIPFILE_20 - :move de_DE_neu.aff de_20.aff - :move de_DE_neu.dic de_20.dic - :move README_de_DE_neu.txt README_de_20.txt - @if not os.path.exists('de_20.orig.aff'): - :copy de_20.aff de_20.orig.aff - @if not os.path.exists('de_20.orig.dic'): - :copy de_20.dic de_20.orig.dic - @if os.path.exists('de_20.diff'): - :sys patch <de_20.diff - -# The de_AT.dic is included in de_DE.zip. We rename the files and concatenate -# them. Complication is that de_AT.dic is missing a newline at the end. -# And the de_DE.dic file is used for something else. -de_AT.aff de_AT.dic: {buildcheck=} - :assertpkg unzip patch - - # Move de_DE files out of the way. - @if os.path.exists('de_DE.aff'): - :move de_DE.aff de_DE.temp.aff - @if os.path.exists('de_DE.dic'): - :move de_DE.dic de_DE.temp.dic - @if os.path.exists('README_de_DE.txt'): - :move README_de_DE.txt README_de_DE.temp.txt - - :fetch $ZIPFILE_AT - :sys $UNZIP $ZIPFILE_AT - :delete $ZIPFILE_AT - - :print >>de_AT.dic - # delete the first line, the word count - :sys $VIM de_DE.dic -e -c 1delete -c wq - :cat de_DE.dic >>de_AT.dic - :delete de_DE.dic - :move de_DE.aff de_AT.aff - :move README_de_DE.txt README_de_AT.txt - - @if os.path.exists('de_DE.temp.aff'): - :move de_DE.temp.aff de_DE.aff - @if os.path.exists('de_DE.temp.dic'): - :move de_DE.temp.dic de_DE.dic - @if os.path.exists('README_de_DE.temp.txt'): - :move README_de_DE.temp.txt README_de_DE.txt - - @if not os.path.exists('de_AT.orig.aff'): - :copy de_AT.aff de_AT.orig.aff - @if not os.path.exists('de_AT.orig.dic'): - :copy de_AT.dic de_AT.orig.dic - @if os.path.exists('de_AT.diff'): - :sys patch <de_AT.diff - -de_CH.aff de_CH.dic: {buildcheck=} - :assertpkg unzip patch - :fetch $ZIPFILE_CH - :sys $UNZIP $ZIPFILE_CH - :delete $ZIPFILE_CH - @if not os.path.exists('de_CH.orig.aff'): - :copy de_CH.aff de_CH.orig.aff - @if not os.path.exists('de_CH.orig.dic'): - :copy de_CH.dic de_CH.orig.dic - @if os.path.exists('de_CH.diff'): - :sys patch <de_CH.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. -diff: - :assertpkg diff - :sys {force} diff -a -C 1 de_DE.orig.aff de_DE.aff >de_DE.diff - :sys {force} diff -a -C 1 de_DE.orig.dic de_DE.dic >>de_DE.diff - :sys {force} diff -a -C 1 de_19.orig.aff de_19.aff >de_19.diff - :sys {force} diff -a -C 1 de_19.orig.dic de_19.dic >>de_19.diff - :sys {force} diff -a -C 1 de_20.orig.aff de_20.aff >de_20.diff - :sys {force} diff -a -C 1 de_20.orig.dic de_20.dic >>de_20.diff - :sys {force} diff -a -C 1 de_AT.orig.aff de_AT.aff >de_AT.diff - :sys {force} diff -a -C 1 de_AT.orig.dic de_AT.dic >>de_AT.diff - :sys {force} diff -a -C 1 de_CH.orig.aff de_CH.aff >de_CH.diff - :sys {force} diff -a -C 1 de_CH.orig.dic de_CH.dic >>de_CH.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip patch - :fetch $ZIPFILES - :mkdir tmp - :cd tmp - @try: - # Do the _AT one first, it overwrites the _DE files. - :sys $UNZIP ../$ZIPFILE_AT - :print >>de_AT.dic - # delete the first line, the word count - :sys ../$VIM de_DE.dic -e -c 1delete -c wq - :cat de_DE.dic >>de_AT.dic - :delete de_DE.dic - :move de_DE.aff de_AT.aff - :move README_de_DE.txt README_de_AT.txt - - :sys $UNZIP ../$ZIPFILE_DE - :move de_DE_comb.aff de_DE.aff - :move de_DE_comb.dic de_DE.dic - :move README_de_DE_comb.txt README_de_DE.txt - - :sys $UNZIP ../$ZIPFILE_19 - :move de_OLDSPELL.aff de_19.aff - :move de_OLDSPELL.dic de_19.dic - # there is no README file - :print There is no README file for the old spelling >!README_de_19.txt - :sys $UNZIP ../$ZIPFILE_20 - :move de_DE_neu.aff de_20.aff - :move de_DE_neu.dic de_20.dic - :move README_de_DE_neu.txt README_de_20.txt - - :sys $UNZIP ../$ZIPFILE_CH - - @import stat - @for nm in ['de_DE', 'de_19', 'de_20', 'de_AT', 'de_CH']: - @for ext in ['aff', 'dic']: - :sys {force} diff ../$(nm).orig.$ext $(nm).$ext >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy $(nm).$ext ../$(nm).new.$ext - :sys {force} diff ../README_$(nm).txt README_$(nm).txt >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy README_$(nm).txt ../README_$(nm).new.txt - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete $ZIPFILES - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/eo/main.aap b/share/vim/vim72/spell/eo/main.aap deleted file mode 100644 index 19b7555ab5..0000000000 --- a/share/vim/vim72/spell/eo/main.aap +++ /dev/null @@ -1,80 +0,0 @@ -# Aap recipe for Esperanto Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = eo_l3.aff eo_l3.dic - -all: $SPELLDIR/eo.iso-8859-3.spl $SPELLDIR/eo.utf-8.spl ../README_eo.txt - -$SPELLDIR/eo.iso-8859-3.spl : $FILES - :sys $VIM -u NONE -e -c "set enc=iso-8859-3" - -c "mkspell! $SPELLDIR/eo eo_l3" -c q - -$SPELLDIR/eo.utf-8.spl : $FILES - :sys $VIM -u NONE -e -c "set enc=utf-8" - -c "mkspell! $SPELLDIR/eo eo_l3" -c q - -../README_eo.txt : README_eo_l3.txt - :copy $source $target - # fix missing newline - :sys $VIM $target -e -c "set ff=unix" -c wq - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} eo.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -eo_l3.aff eo_l3.dic: {buildcheck=} - :assertpkg unzip patch - :fetch eo.zip - :sys $UNZIP eo.zip - :delete eo.zip - @if not os.path.exists('eo_l3.orig.aff'): - :copy eo_l3.aff eo_l3.orig.aff - @if not os.path.exists('eo_l3.orig.dic'): - :copy eo_l3.dic eo_l3.orig.dic - @if os.path.exists('eo_l3.diff'): - :sys patch <eo_l3.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 eo_l3.orig.aff eo_l3.aff >eo_l3.diff - :sys {force} diff -a -C 1 eo_l3.orig.dic eo_l3.dic >>eo_l3.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch eo.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../eo.zip - :sys {force} diff ../eo_l3.orig.aff eo_l3.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy eo_l3.aff ../eo_l3.new.aff - :sys {force} diff ../eo_l3.orig.dic eo_l3.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy eo_l3.dic ../eo_l3.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete eo.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/es/es_MX.diff b/share/vim/vim72/spell/es/es_MX.diff deleted file mode 100644 index 59d8312701..0000000000 --- a/share/vim/vim72/spell/es/es_MX.diff +++ /dev/null @@ -1,6975 +0,0 @@ -*** es_MX.orig.aff Thu Aug 25 19:19:45 2005 ---- es_MX.aff Thu Aug 25 19:19:45 2005 -*************** -*** 1,4 **** -! SET ISO8859-1 -! TRY aroeinltcsdumpbgvfhzóíjqáéñxyúüCkAMIESPGRJBFDVTHUOwLNKZÁY -! - SFX A Y 93 ---- 1,23 ---- -! SET ISO8859-1 -! TRY aroeinltcsdumpbgvfhzóíjqáéñxyúüCkAMIESPGRJBFDVTHUOwLNKZÁY -! -! FOL ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ -! LOW ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ -! UPP ßÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞÿ -! -! SOFOFROM abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþßÿÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞ¿ -! SOFOTO ebctefghejklnnepkrstevvkesebctefghejklnnepkrstevvkeseeeeeeeceeeeeeeedneeeeeeeeeeepseeeeeeeeceeeeeeeedneeeeeeeeeeep? -! -! MAP 9 -! MAP aàáâãäå -! MAP eèéêë -! MAP iìíîï -! MAP oòóôõö -! MAP uùúûü -! MAP nñ -! MAP cç -! MAP yÿý -! MAP sß -! -! - SFX A Y 93 -*************** -*** 7,12 **** - SFX A é ote é -! SFX A é ota é -! SFX A a illa a -! SFX A a illas a -! SFX A a ita a - SFX A a itas a ---- 26,31 ---- - SFX A é ote é -! SFX A é ota é -! SFX A a illa a -! SFX A a illas a -! SFX A a ita a - SFX A a itas a -*************** -*** 21,28 **** - SFX A co quilla co -! SFX A co quillas co -! SFX A co quillo co - SFX A co quillos co - SFX A co quita co -! SFX A co quitas co -! SFX A co quito co - SFX A co quitos co ---- 40,47 ---- - SFX A co quilla co -! SFX A co quillas co -! SFX A co quillo co - SFX A co quillos co - SFX A co quita co -! SFX A co quitas co -! SFX A co quito co - SFX A co quitos co -*************** -*** 36,59 **** - SFX A go guillo go -! SFX A go guillos go -! SFX A go guito go -! SFX A go guitos go -! SFX A io illa io -! SFX A io illas io -! SFX A io ita io -! SFX A io itas io -! SFX A io illo io -! SFX A io illos io -! SFX A io ito io -! SFX A io itos io -! SFX A o ito o -! SFX A o itos o -! SFX A o illo o -! SFX A o illos o -! SFX A o ita o -! SFX A o itas o -! SFX A o illa o -! SFX A o illas o -! SFX A o ota o -! SFX A o otas o -! SFX A o ote o - SFX A o otes o ---- 55,78 ---- - SFX A go guillo go -! SFX A go guillos go -! SFX A go guito go -! SFX A go guitos go -! SFX A io illa io -! SFX A io illas io -! SFX A io ita io -! SFX A io itas io -! SFX A io illo io -! SFX A io illos io -! SFX A io ito io -! SFX A io itos io -! SFX A o ito o -! SFX A o itos o -! SFX A o illo o -! SFX A o illos o -! SFX A o ita o -! SFX A o itas o -! SFX A o illa o -! SFX A o illas o -! SFX A o ota o -! SFX A o otas o -! SFX A o ote o - SFX A o otes o -*************** -*** 70,73 **** - SFX A zo cita zo -! SFX A zo citas zo -! SFX A zo cito zo - SFX A zo citos zo ---- 89,92 ---- - SFX A zo cita zo -! SFX A zo citas zo -! SFX A zo cito zo - SFX A zo citos zo -*************** -*** 76,85 **** - SFX A 0 cillo [er] -! SFX A 0 cillos [er] -! SFX A 0 cito [er] -! SFX A 0 citos [er] -! SFX A 0 cita [er] -! SFX A 0 citas [er] -! SFX A 0 sote [er] -! SFX A 0 sotes [er] -! SFX A 0 sota [er] - SFX A 0 sotas [er] ---- 95,104 ---- - SFX A 0 cillo [er] -! SFX A 0 cillos [er] -! SFX A 0 cito [er] -! SFX A 0 citos [er] -! SFX A 0 cita [er] -! SFX A 0 citas [er] -! SFX A 0 sote [er] -! SFX A 0 sotes [er] -! SFX A 0 sota [er] - SFX A 0 sotas [er] -*************** -*** 88,118 **** - SFX A 0 illo [ls] -! SFX A 0 illos [ls] -! SFX A 0 ita [ls] -! SFX A 0 itas [ls] -! SFX A 0 ito [ls] -! SFX A 0 itos [ls] -! SFX A 0 ota [ls] -! SFX A 0 otas [ls] -! SFX A 0 ote [ls] - SFX A 0 otes [ls] - -! SFX J Y 12 -! SFX J e ísimo e -! SFX J e ísimos e -! SFX J e ísima e -! SFX J e ísimas e -! SFX J o ísimo o -! SFX J o ísima o -! SFX J o ísimos o -! SFX J o ísimas o -! SFX J 0 ísimo l -! SFX J 0 ísima l -! SFX J 0 ísimos l -! SFX J 0 ísimas l -! - SFX M Y 8 - SFX M ble bilidad ble -! SFX M ble bilidades ble - SFX M o idad o -! SFX M o idades o - SFX M o amente o ---- 107,137 ---- - SFX A 0 illo [ls] -! SFX A 0 illos [ls] -! SFX A 0 ita [ls] -! SFX A 0 itas [ls] -! SFX A 0 ito [ls] -! SFX A 0 itos [ls] -! SFX A 0 ota [ls] -! SFX A 0 otas [ls] -! SFX A 0 ote [ls] - SFX A 0 otes [ls] - -! SFX J Y 12 -! SFX J e ísimo e -! SFX J e ísimos e -! SFX J e ísima e -! SFX J e ísimas e -! SFX J o ísimo o -! SFX J o ísima o -! SFX J o ísimos o -! SFX J o ísimas o -! SFX J 0 ísimo l -! SFX J 0 ísima l -! SFX J 0 ísimos l -! SFX J 0 ísimas l -! - SFX M Y 8 - SFX M ble bilidad ble -! SFX M ble bilidades ble - SFX M o idad o -! SFX M o idades o - SFX M o amente o -*************** -*** 120,3490 **** - SFX M 0 idades [elnrsz] -! SFX M 0 mente [elnrsz] -! -! SFX N Y 2 -! SFX N r damente [ai]r -! SFX N er idamente er -! -! SFX P Y 20 -! SFX P e a e -! SFX P o a o -! SFX P 0 s [eo] -! SFX P o as o -! SFX P e as e -! SFX P án ana án -! SFX P án anes án -! SFX P án anas án -! SFX P ín ina ín -! SFX P ín ines ín -! SFX P ín inas ín -! SFX P ón ona ón -! SFX P ón ones ón -! SFX P ón onas ón -! SFX P 0 a [^aons] -! SFX P 0 es [^aons] -! SFX P 0 as [^aons] -! SFX P és esa és -! SFX P és eses és -! SFX P és esas és -! -! SFX H Y 2 -! SFX H r ción [ai]r -! SFX H r ciones [ai]r -! -! SFX I Y 4 -! SFX I r miento [ai]r -! SFX I r mientos [ai]r -! SFX I er imiento er -! SFX I er imientos er -! -! SFX L Y 6 -! SFX L r nte ar -! SFX L r ntes ar -! SFX L er iente er -! SFX L er ientes er -! SFX L r ente ir -! SFX L r entes ir -! -! SFX R Y 20 -! SFX R 0 me [aei]r -! SFX R 0 te [aei]r -! SFX R 0 se [aei]r -! SFX R 0 nos [aei]r -! SFX R 0 os [aei]r -! SFX R ar ándome ar -! SFX R ar ándote ar -! SFX R ar ándose ar -! SFX R ar ándonos ar -! SFX R ar ándoos ar -! SFX R er iéndome er -! SFX R er iéndote er -! SFX R er iéndose er -! SFX R er iéndonos er -! SFX R er iéndoos er -! SFX R r éndome ir -! SFX R r éndote ir -! SFX R r éndose ir -! SFX R r éndonos ir -! SFX R r éndoos ir -! -! SFX S Y 11 -! SFX S 0 s [aeiouáéó] -! SFX S 0 es [úídjlry] -! SFX S z ces z -! SFX S 0 es [^é]s -! SFX S 0 es [^áéíóú]n -! SFX S án anes án -! SFX S én enes én -! SFX S ín ines ín -! SFX S ón ones ón -! SFX S ún unes ún -! SFX S és eses és -! -! SFX T Y 24 -! SFX T 0 lo [aei]r -! SFX T 0 la [aei]r -! SFX T 0 le [aei]r -! SFX T 0 los [aei]r -! SFX T 0 las [aei]r -! SFX T 0 les [aei]r -! SFX T ar ándolo ar -! SFX T ar ándola ar -! SFX T ar ándole ar -! SFX T ar ándolos ar -! SFX T ar ándolas ar -! SFX T ar ándoles ar -! SFX T er iéndolo er -! SFX T er iéndola er -! SFX T er iéndole er -! SFX T er iéndolos er -! SFX T er iéndolas er -! SFX T er iéndoles er -! SFX T r éndolo ir -! SFX T r éndola ir -! SFX T r éndole ir -! SFX T r éndolos ir -! SFX T r éndolas ir -! SFX T r éndoles ir -! -! SFX U Y 120 -! SFX U ar ármelo ar -! SFX U ar ártelo ar -! SFX U ar árselo ar -! SFX U ar árnoslo ar -! SFX U ar ároslo ar -! SFX U ar ármela ar -! SFX U ar ártela ar -! SFX U ar ársela ar -! SFX U ar árnosla ar -! SFX U ar árosla ar -! SFX U ar ármelos ar -! SFX U ar ártelos ar -! SFX U ar árselos ar -! SFX U ar árnoslos ar -! SFX U ar ároslos ar -! SFX U ar ármelas ar -! SFX U ar ártelas ar -! SFX U ar árselas ar -! SFX U ar árnoslas ar -! SFX U ar ároslas ar -! SFX U ar ándomelo ar -! SFX U ar ándotelo ar -! SFX U ar ándoselo ar -! SFX U ar ándonoslo ar -! SFX U ar ándooslo ar -! SFX U ar ándomela ar -! SFX U ar ándotela ar -! SFX U ar ándosela ar -! SFX U ar ándonosla ar -! SFX U ar ándoosla ar -! SFX U ar ándomelos ar -! SFX U ar ándotelos ar -! SFX U ar ándoselos ar -! SFX U ar ándonoslos ar -! SFX U ar ándooslos ar -! SFX U ar ándomelas ar -! SFX U ar ándotelas ar -! SFX U ar ándoselas ar -! SFX U ar ándonoslas ar -! SFX U ar ándooslas ar -! SFX U er érmelo er -! SFX U er értelo er -! SFX U er érselo er -! SFX U er érnoslo er -! SFX U er éroslo er -! SFX U er érmela er -! SFX U er értela er -! SFX U er érsela er -! SFX U er érnosla er -! SFX U er érosla er -! SFX U er érmelos er -! SFX U er értelos er -! SFX U er érselos er -! SFX U er érnoslos er -! SFX U er éroslos er -! SFX U er érmelas er -! SFX U er értelas er -! SFX U er érselas er -! SFX U er érnoslas er -! SFX U er éroslas er -! SFX U er iéndomelo er -! SFX U er iéndotelo er -! SFX U er iéndoselo er -! SFX U er iéndonoslo er -! SFX U er iéndooslo er -! SFX U er iéndomela er -! SFX U er iéndotela er -! SFX U er iéndosela er -! SFX U er iéndonosla er -! SFX U er iéndoosla er -! SFX U er iéndomelos er -! SFX U er iéndotelos er -! SFX U er iéndoselos er -! SFX U er iéndonoslos er -! SFX U er iéndooslos er -! SFX U er iéndomelas er -! SFX U er iéndotelas er -! SFX U er iéndoselas er -! SFX U er iéndonoslas er -! SFX U er iéndooslas er -! SFX U ir írmelo ir -! SFX U ir írtelo ir -! SFX U ir írselo ir -! SFX U ir írnoslo ir -! SFX U ir íroslo ir -! SFX U ir írmela ir -! SFX U ir írtela ir -! SFX U ir írsela ir -! SFX U ir írnosla ir -! SFX U ir írosla ir -! SFX U ir írmelas ir -! SFX U ir írtelas ir -! SFX U ir írselas ir -! SFX U ir írnoslas ir -! SFX U ir íroslas ir -! SFX U ir írmelos ir -! SFX U ir írtelos ir -! SFX U ir írselos ir -! SFX U ir írnoslos ir -! SFX U ir íroslos ir -! SFX U r éndomelo ir -! SFX U r éndotelo ir -! SFX U r éndoselo ir -! SFX U r éndonoslo ir -! SFX U r éndooslo ir -! SFX U r éndomela ir -! SFX U r éndotela ir -! SFX U r éndosela ir -! SFX U r éndonosla ir -! SFX U r éndoosla ir -! SFX U r éndomelos ir -! SFX U r éndotelos ir -! SFX U r éndoselos ir -! SFX U r éndonoslos ir -! SFX U r éndooslos ir -! SFX U r éndomelas ir -! SFX U r éndotelas ir -! SFX U r éndoselas ir -! SFX U r éndonoslas ir -! SFX U r éndooslas ir -! -! SFX V Y 169 -! SFX V ar o ar -! SFX V er o [^cg]er -! SFX V cer zo cer -! SFX V ger jo ger -! SFX V ir o [^cgu]ir -! SFX V cir zo cir -! SFX V gir jo gir -! SFX V uir o guir -! SFX V quir co quir -! SFX V r s [ae]r -! SFX V ir es ir -! SFX V ar a ar -! SFX V er e er -! SFX V ir e ir -! SFX V r mos [aei]r -! SFX V ar áis ar -! SFX V er éis er -! SFX V ir ís ir -! SFX V r n [ae]r -! SFX V ir en ir -! SFX V r ba ar -! SFX V er ía er -! SFX V ir ía ir -! SFX V r bas ar -! SFX V er ías er -! SFX V ir ías ir -! SFX V ar ábamos ar -! SFX V er íamos er -! SFX V ir íamos ir -! SFX V r bais ar -! SFX V er íais er -! SFX V ir íais ir -! SFX V r ban ar -! SFX V er ían er -! SFX V ir ían ir -! SFX V ar é [^czg]ar -! SFX V car qué car -! SFX V ar ué gar -! SFX V zar cé zar -! SFX V er í er -! SFX V ir í ir -! SFX V r ste [ai]r -! SFX V er iste er -! SFX V ar ó ar -! SFX V er ió er -! SFX V r ó ir -! SFX V er imos er -! SFX V r steis [ai]r -! SFX V er isteis er -! SFX V 0 on ar -! SFX V er ieron er -! SFX V r eron ir -! SFX V 0 é [aei]r -! SFX V 0 ás [aei]r -! SFX V 0 á [aei]r -! SFX V 0 emos [aei]r -! SFX V 0 éis [aei]r -! SFX V 0 án [aei]r -! SFX V 0 ía [aei]r -! SFX V 0 ías [aei]r -! SFX V 0 íamos [aei]r -! SFX V 0 íais [aei]r -! SFX V 0 ían [aei]r -! SFX V ar e [^czg]ar -! SFX V car que car -! SFX V ar ue gar -! SFX V zar ce zar -! SFX V er a [^cg]er -! SFX V cer za cer -! SFX V ger ja ger -! SFX V ir a [^cgu]ir -! SFX V cir za cir -! SFX V gir ja gir -! SFX V uir a guir -! SFX V quir ca quir -! SFX V ar es [^czg]ar -! SFX V car ques car -! SFX V ar ues gar -! SFX V zar ces zar -! SFX V er as [^cg]er -! SFX V cer zas cer -! SFX V ger jas ger -! SFX V ir as [^cgu]ir -! SFX V cir zas cir -! SFX V gir jas gir -! SFX V uir as guir -! SFX V quir cas quir -! SFX V ar emos [^czg]ar -! SFX V car quemos car -! SFX V ar uemos gar -! SFX V zar cemos zar -! SFX V er amos [^cg]er -! SFX V cer zamos cer -! SFX V ger jamos ger -! SFX V ir amos [^cgu]ir -! SFX V cir zamos cir -! SFX V gir jamos gir -! SFX V uir amos guir -! SFX V quir camos quir -! SFX V ar éis [^czg]ar -! SFX V car quéis car -! SFX V ar uéis gar -! SFX V zar céis zar -! SFX V er áis [^cg]er -! SFX V cer záis cer -! SFX V ger jáis ger -! SFX V ir áis [^cgu]ir -! SFX V cir záis cir -! SFX V gir jáis gir -! SFX V uir áis guir -! SFX V quir cáis quir -! SFX V ar en [^czg]ar -! SFX V car quen car -! SFX V ar uen gar -! SFX V zar cen zar -! SFX V er an [^cg]er -! SFX V cer zan cer -! SFX V ger jan ger -! SFX V ir an [^cgu]ir -! SFX V cir zan cir -! SFX V gir jan gir -! SFX V uir an guir -! SFX V quir can quir -! SFX V r se ar -! SFX V r ra ar -! SFX V er iese er -! SFX V er iera er -! SFX V r ese ir -! SFX V r era ir -! SFX V r ses ar -! SFX V r ras ar -! SFX V er ieses er -! SFX V er ieras er -! SFX V r eses ir -! SFX V r eras ir -! SFX V ar ásemos ar -! SFX V ar áramos ar -! SFX V er iésemos er -! SFX V er iéramos er -! SFX V r ésemos ir -! SFX V r éramos ir -! SFX V r seis ar -! SFX V r rais ar -! SFX V er ieseis er -! SFX V er ierais er -! SFX V r eseis ir -! SFX V r erais ir -! SFX V r sen ar -! SFX V r ran ar -! SFX V er iesen er -! SFX V er ieran er -! SFX V r esen ir -! SFX V r eran ir -! SFX V r re ar -! SFX V er iere er -! SFX V r ere ir -! SFX V r res ar -! SFX V er ieres er -! SFX V r eres ir -! SFX V ar áremos ar -! SFX V er iéremos er -! SFX V r éremos ir -! SFX V r reis ar -! SFX V er iereis er -! SFX V r ereis ir -! SFX V r ren ar -! SFX V er ieren er -! SFX V r eren ir -! SFX V r d r -! -! SFX X Y 11 -! SFX X r do [ai]r -! SFX X r dos [ai]r -! SFX X r da [ai]r -! SFX X r das [ai]r -! SFX X er ido er -! SFX X er idos er -! SFX X er ida er -! SFX X er idas er -! SFX X r ndo ar -! SFX X er iendo er -! SFX X r endo ir -! -! SFX W Y 197 S -! SFX W ar a andar -! SFX W ar a guar -! SFX W er a [eo]er -! SFX W r ba ar -! SFX W obar ueba obar -! SFX W ebir iba ebir -! SFX W erbar ierba erbar -! SFX W ibir íba ohibir -! SFX W ocar ueca ocar -! SFX W olcar uelca olcar -! SFX W orcar uerca orcar -! SFX W cer zca [^c]ocer -! SFX W cer zca [^fh]acer -! SFX W cer zca ecer -! SFX W cir zca ucir -! SFX W eder ieda eder -! SFX W odar ueda odar -! SFX W oder ueda oder -! SFX W edir ida edir -! SFX W oldar uelda [^g]oldar -! SFX W oldar üelda goldar -! SFX W endar ienda endar -! SFX W ender ienda ender -! SFX W endir inda endir -! SFX W erder ierda erder -! SFX W ordar uerda ordar -! SFX W order uerda order -! SFX W cer ga [fh]acer -! SFX W er ga [eo]ner -! SFX W er ga aler -! SFX W ir ga alir -! SFX W gar ega ugar -! SFX W egar iega egar -! SFX W ogar uega ogar -! SFX W ecir iga ecir -! SFX W eguir iga eguir -! SFX W er iga aer -! SFX W er iga oer -! SFX W ír iga oír -! SFX W olgar uelga olgar -! SFX W enir enga enir -! SFX W engar ienga engar -! SFX W enchir incha enchir -! SFX W egir ija egir -! SFX W ijar íja [ae]hijar -! SFX W oblar uebla oblar -! SFX W emblar iembla emblar -! SFX W elar iela elar -! SFX W olar uela olar -! SFX W oler uela oler -! SFX W ollar uella [^g]ollar -! SFX W ollar üella gollar -! SFX W ilar íla [ae]hilar -! SFX W emir ima emir -! SFX W ormir uerma ormir -! SFX W umar úma [ae]humar -! SFX W onar uena onar -! SFX W ernar ierna ernar -! SFX W erner ierna erner -! SFX W ernir ierna ernir -! SFX W ornar uerna ornar -! SFX W inar ína [aeo]hinar -! SFX W unir úna eunir -! SFX W aber epa saber -! SFX W caber quepa caber -! SFX W r ra [^a]ndar -! SFX W r ra [^d]ar -! SFX W r ra [^n]dar -! SFX W ebrar iebra ebrar -! SFX W embrar iembra embrar -! SFX W edrar iedra edrar -! SFX W endrar iendra endrar -! SFX W r era alir -! SFX W r era ernir -! SFX W r era eunir -! SFX W r era ohibir -! SFX W er iera [^fh]acer -! SFX W er iera aler -! SFX W er iera e[cd]er -! SFX W er iera ender -! SFX W er iera er[dnt]er -! SFX W er iera o[clv]er -! SFX W er iera olver -! SFX W er iera or[cd]er -! SFX W erer iera erer -! SFX W erir iera erir -! SFX W eír iera eír -! SFX W irir iera irir -! SFX W ebir ibiera ebir -! SFX W acer iciera [fh]acer -! SFX W edir idiera edir -! SFX W endir indiera endir -! SFX W oder udiera oder -! SFX W egir igiera egir -! SFX W enchir inchiera enchir -! SFX W emir imiera emir -! SFX W ormir urmiera ormir -! SFX W enir iniera enir -! SFX W aber upiera aber -! SFX W erir iriera erir -! SFX W irir iriera irir -! SFX W orir uriera orir -! SFX W erer isiera erer -! SFX W oner usiera oner -! SFX W etir itiera etir -! SFX W entir intiera entir -! SFX W ertir irtiera ertir -! SFX W estir istiera estir -! SFX W eguir iguiera eguir -! SFX W ervir irviera ervir -! SFX W ar uviera andar -! SFX W ener uviera ener -! SFX W cir jera ucir -! SFX W er jera raer -! SFX W ecir ijera ecir -! SFX W orar uera [^g]orar -! SFX W orir uera orir -! SFX W er yera [eo]er -! SFX W er yera caer -! SFX W ir yera [^g]uir -! SFX W ír yera oír -! SFX W üir uyera güir -! SFX W eñir iñera eñir -! SFX W orar üera gorar -! SFX W errar ierra errar -! SFX W ontrar uentra ontrar -! SFX W ostrar uestra ostrar -! SFX W esar iesa esar -! SFX W osar uesa osar -! SFX W ensar iensa ensar -! SFX W usar úsa [ae]husar -! SFX W etar ieta etar -! SFX W etir ita etir -! SFX W oltar uelta oltar -! SFX W entar ienta entar -! SFX W entir ienta entir -! SFX W ontar uenta ontar -! SFX W ertar ierta ertar -! SFX W erter ierta erter -! SFX W ertir ierta ertir -! SFX W ortar uerta ortar -! SFX W estar iesta estar -! SFX W ostar uesta ostar -! SFX W estir ista estir -! SFX W itar íta [ae]hitar -! SFX W evar ieva evar -! SFX W ovar ueva ovar -! SFX W over ueva over -! SFX W olver uelva olver -! SFX W ervir irva ervir -! SFX W er ya oer -! SFX W ir ya [^g]uir -! SFX W üir uya güir -! SFX W ezar ieza ezar -! SFX W ocer ueza cocer -! SFX W enzar ienza enzar -! SFX W onzar üenza gonzar -! SFX W orcer uerza orcer -! SFX W orzar uerza orzar -! SFX W izar íza [ae]izar -! SFX W 0 ía [^fh]acer -! SFX W 0 ía [aeo]er -! SFX W 0 ía [io]rir -! SFX W 0 ía [üu]ir -! SFX W 0 ía ar -! SFX W 0 ía e[bdgmrtñ]ir -! SFX W 0 ía e[cd]er -! SFX W 0 ía e[ns]tir -! SFX W 0 ía enchir -! SFX W 0 ía ender -! SFX W 0 ía endir -! SFX W 0 ía er[dnt]er -! SFX W 0 ía er[ntv]ir -! SFX W 0 ía eunir -! SFX W 0 ía o[clv]er -! SFX W 0 ía olver -! SFX W 0 ía or[cd]er -! SFX W 0 ía ormir -! SFX W 0 ía ucir -! SFX W er ía er -! SFX W eír ía eír -! SFX W iar ía iar -! SFX W ir ía ir -! SFX W ír ía ír -! SFX W cer ría [fh]acer -! SFX W er ría aber -! SFX W er ría erer -! SFX W er ría oder -! SFX W er dría [eo]ner -! SFX W er dría aler -! SFX W ir dría alir -! SFX W ir dría enir -! SFX W ecir iría ecir -! SFX W ír iría [eo]ír -! SFX W oñar ueña oñar -! SFX W eñir iña eñir -! SFX W uar úa [^g]uar -! -! SFX W Y 264 S -! SFX W ar e andar -! SFX W er e [^c]ocer -! SFX W er e [cr]aer -! SFX W er e [eo]er -! SFX W er e a[bcl]er -! SFX W er e ecer -! SFX W er e oner -! SFX W ir e alir -! SFX W ir e ucir -! SFX W obar uebe obar -! SFX W ebir ibe ebir -! SFX W erbar ierbe erbar -! SFX W ibir íbe ohibir -! SFX W ezar iece ezar -! SFX W ocer uece cocer -! SFX W acer ice [fh]acer -! SFX W ecir ice ecir -! SFX W enzar ience enzar -! SFX W onzar üence gonzar -! SFX W orcer uerce orcer -! SFX W orzar uerce orzar -! SFX W izar íce [ae]izar -! SFX W eder iede eder -! SFX W odar uede odar -! SFX W oder uede oder -! SFX W edir ide edir -! SFX W oldar uelde [^g]oldar -! SFX W oldar üelde goldar -! SFX W endar iende endar -! SFX W ender iende ender -! SFX W endir inde endir -! SFX W erder ierde erder -! SFX W ordar uerde ordar -! SFX W order uerde order -! SFX W oder ude oder -! SFX W egir ige egir -! SFX W enchir inche enchir -! SFX W cir je ucir -! SFX W er je raer -! SFX W ecir ije ecir -! SFX W ijar íje [ae]hijar -! SFX W oblar ueble oblar -! SFX W emblar iemble emblar -! SFX W elar iele elar -! SFX W olar uele olar -! SFX W oler uele oler -! SFX W ollar uelle [^g]ollar -! SFX W ollar üelle gollar -! SFX W ilar íle [ae]hilar -! SFX W emir ime emir -! SFX W ormir uerme ormir -! SFX W umar úme [ae]humar -! SFX W ener iene ener -! SFX W enir iene enir -! SFX W onar uene onar -! SFX W enir ine enir -! SFX W ernar ierne ernar -! SFX W erner ierne erner -! SFX W ernir ierne ernir -! SFX W ornar uerne ornar -! SFX W inar íne [aeo]hinar -! SFX W unir úne eunir -! SFX W aber upe aber -! SFX W r re [^a]ndar -! SFX W r re [^d]ar -! SFX W r re [^n]dar -! SFX W ebrar iebre ebrar -! SFX W embrar iembre embrar -! SFX W edrar iedre edrar -! SFX W endrar iendre endrar -! SFX W r ere alir -! SFX W r ere ernir -! SFX W r ere eunir -! SFX W r ere ohibir -! SFX W er iere [^fh]acer -! SFX W er iere aler -! SFX W er iere e[cd]er -! SFX W er iere ender -! SFX W er iere er[dnt]er -! SFX W er iere o[clv]er -! SFX W er iere olver -! SFX W er iere or[cd]er -! SFX W erer iere erer -! SFX W erir iere erir -! SFX W eír iere eír -! SFX W irir iere irir -! SFX W ebir ibiere ebir -! SFX W acer iciere [fh]acer -! SFX W edir idiere edir -! SFX W endir indiere endir -! SFX W oder udiere oder -! SFX W egir igiere egir -! SFX W enchir inchiere enchir -! SFX W emir imiere emir -! SFX W ormir urmiere ormir -! SFX W enir iniere enir -! SFX W aber upiere aber -! SFX W erir iriere erir -! SFX W irir iriere irir -! SFX W orir uriere orir -! SFX W erer isiere erer -! SFX W oner usiere oner -! SFX W etir itiere etir -! SFX W entir intiere entir -! SFX W ertir irtiere ertir -! SFX W estir istiere estir -! SFX W eguir iguiere eguir -! SFX W ervir irviere ervir -! SFX W ar uviere andar -! SFX W ener uviere ener -! SFX W cir jere ucir -! SFX W er jere raer -! SFX W ecir ijere ecir -! SFX W orar uere [^g]orar -! SFX W orir uere orir -! SFX W er yere [eo]er -! SFX W er yere caer -! SFX W ir yere [^g]uir -! SFX W ír yere oír -! SFX W üir uyere güir -! SFX W eñir iñere eñir -! SFX W orar üere gorar -! SFX W errar ierre errar -! SFX W ontrar uentre ontrar -! SFX W ostrar uestre ostrar -! SFX W r se [^a]ndar -! SFX W r se [^d]ar -! SFX W r se [^n]dar -! SFX W r ese alir -! SFX W r ese ernir -! SFX W r ese eunir -! SFX W r ese ohibir -! SFX W er iese [^fh]acer -! SFX W er iese aler -! SFX W er iese e[cd]er -! SFX W er iese ender -! SFX W er iese er[dnt]er -! SFX W er iese o[clv]er -! SFX W er iese olver -! SFX W er iese or[cd]er -! SFX W esar iese esar -! SFX W eír iese eír -! SFX W ebir ibiese ebir -! SFX W acer iciese [fh]acer -! SFX W edir idiese edir -! SFX W endir indiese endir -! SFX W oder udiese oder -! SFX W egir igiese egir -! SFX W enchir inchiese enchir -! SFX W emir imiese emir -! SFX W ormir urmiese ormir -! SFX W enir iniese enir -! SFX W aber upiese aber -! SFX W erir iriese erir -! SFX W irir iriese irir -! SFX W orir uriese orir -! SFX W erer isiese erer -! SFX W oner usiese oner -! SFX W etir itiese etir -! SFX W entir intiese entir -! SFX W ertir irtiese ertir -! SFX W estir istiese estir -! SFX W eguir iguiese eguir -! SFX W ervir irviese ervir -! SFX W ar uviese andar -! SFX W ener uviese ener -! SFX W cir jese ucir -! SFX W er jese raer -! SFX W ecir ijese ecir -! SFX W osar uese osar -! SFX W er yese [eo]er -! SFX W er yese caer -! SFX W ir yese [^g]uir -! SFX W ír yese oír -! SFX W üir uyese güir -! SFX W eñir iñese eñir -! SFX W erer ise erer -! SFX W ensar iense ensar -! SFX W oner use oner -! SFX W umar úse [ae]husar -! SFX W etar iete etar -! SFX W etir ite etir -! SFX W oltar uelte oltar -! SFX W entar iente entar -! SFX W entir iente entir -! SFX W ontar uente ontar -! SFX W ertar ierte ertar -! SFX W erter ierte erter -! SFX W ertir ierte ertir -! SFX W ortar uerte ortar -! SFX W r ste [^a]ndar -! SFX W r ste [^d]ar -! SFX W r ste [^n]dar -! SFX W r ste [eo]ír -! SFX W r ste [üu]ir -! SFX W r ste alir -! SFX W r ste ebir -! SFX W r ste edir -! SFX W r ste egir -! SFX W r ste emir -! SFX W r ste enchir -! SFX W r ste endir -! SFX W r ste entir -! SFX W r ste erir -! SFX W r ste ernir -! SFX W r ste ertir -! SFX W r ste ervir -! SFX W r ste estir -! SFX W r ste etir -! SFX W r ste eunir -! SFX W r ste eñir -! SFX W r ste irir -! SFX W r ste orir -! SFX W r ste ormir -! SFX W estar ieste estar -! SFX W ostar ueste ostar -! SFX W er iste [^fh]acer -! SFX W er iste aler -! SFX W er iste e[cd]er -! SFX W er iste ender -! SFX W er iste er[dnt]er -! SFX W er iste o[clv]er -! SFX W er iste olver -! SFX W er iste or[cd]er -! SFX W estir iste estir -! SFX W acer iciste [fh]acer -! SFX W oder udiste oder -! SFX W cir jiste ucir -! SFX W er jiste raer -! SFX W ecir ijiste ecir -! SFX W enir iniste enir -! SFX W aber upiste aber -! SFX W erer isiste erer -! SFX W oner usiste oner -! SFX W ar uviste andar -! SFX W ener uviste ener -! SFX W er íste [eo]er -! SFX W er íste caer -! SFX W itar íte [ae]hitar -! SFX W gar egue ugar -! SFX W egar iegue egar -! SFX W ogar uegue ogar -! SFX W eguir igue eguir -! SFX W olgar uelgue olgar -! SFX W engar iengue engar -! SFX W ocar ueque ocar -! SFX W olcar uelque olcar -! SFX W orcar uerque orcar -! SFX W evar ieve evar -! SFX W ovar ueve ovar -! SFX W over ueve over -! SFX W olver uelve olver -! SFX W ervir irve ervir -! SFX W ar uve andar -! SFX W ener uve ener -! SFX W ír ye oír -! SFX W uir uye [^g]uir -! SFX W üir uye güir -! SFX W eír íe eír -! SFX W iar íe iar -! SFX W oñar ueñe oñar -! SFX W eñir iñe eñir -! SFX W uar úe [^g]uar -! SFX W uar üe guar -! -! -! SFX W Y 195 S -! SFX W er an [eo]er -! SFX W r ban ar -! SFX W obar ueban obar -! SFX W ebir iban ebir -! SFX W erbar ierban erbar -! SFX W ibir íban ohibir -! SFX W ocar uecan ocar -! SFX W olcar uelcan olcar -! SFX W orcar uercan orcar -! SFX W cer zcan [^c]ocer -! SFX W cer zcan [^fh]acer -! SFX W cer zcan ecer -! SFX W cir zcan ucir -! SFX W eder iedan eder -! SFX W odar uedan odar -! SFX W oder uedan oder -! SFX W edir idan edir -! SFX W oldar ueldan [^g]oldar -! SFX W oldar üeldan goldar -! SFX W endar iendan endar -! SFX W ender iendan ender -! SFX W endir indan endir -! SFX W erder ierdan erder -! SFX W ordar uerdan ordar -! SFX W order uerdan order -! SFX W cer gan [fh]acer -! SFX W er gan [eo]ner -! SFX W er gan aler -! SFX W ir gan alir -! SFX W gar egan ugar -! SFX W egar iegan egar -! SFX W ogar uegan ogar -! SFX W ecir igan ecir -! SFX W eguir igan eguir -! SFX W er igan aer -! SFX W er igan oer -! SFX W ír igan oír -! SFX W olgar uelgan olgar -! SFX W enir engan enir -! SFX W engar iengan engar -! SFX W enchir inchan enchir -! SFX W egir ijan egir -! SFX W ijar íjan [ae]hijar -! SFX W oblar ueblan oblar -! SFX W emblar iemblan emblar -! SFX W elar ielan elar -! SFX W olar uelan olar -! SFX W oler uelan oler -! SFX W ollar uellan [^g]ollar -! SFX W ollar üellan gollar -! SFX W ilar ílan [ae]hilar -! SFX W emir iman emir -! SFX W ormir uerman ormir -! SFX W umar úman [ae]humar -! SFX W onar uenan onar -! SFX W ernar iernan ernar -! SFX W erner iernan erner -! SFX W ernir iernan ernir -! SFX W ornar uernan ornar -! SFX W inar ínan [aeo]hinar -! SFX W unir únan eunir -! SFX W aber epan saber -! SFX W caber quepan caber -! SFX W r ran [^a]ndar -! SFX W r ran [^d]ar -! SFX W r ran [^n]dar -! SFX W ebrar iebran ebrar -! SFX W embrar iembran embrar -! SFX W edrar iedran edrar -! SFX W endrar iendran endrar -! SFX W r eran alir -! SFX W r eran ernir -! SFX W r eran eunir -! SFX W r eran ohibir -! SFX W er ieran [^fh]acer -! SFX W er ieran aler -! SFX W er ieran e[cd]er -! SFX W er ieran ender -! SFX W er ieran er[dnt]er -! SFX W er ieran o[clv]er -! SFX W er ieran olver -! SFX W er ieran or[cd]er -! SFX W erer ieran erer -! SFX W erir ieran erir -! SFX W eír ieran eír -! SFX W irir ieran irir -! SFX W ebir ibieran ebir -! SFX W acer icieran [fh]acer -! SFX W edir idieran edir -! SFX W endir indieran endir -! SFX W oder udieran oder -! SFX W egir igieran egir -! SFX W enchir inchieran enchir -! SFX W emir imieran emir -! SFX W ormir urmieran ormir -! SFX W enir inieran enir -! SFX W aber upieran aber -! SFX W erir irieran erir -! SFX W irir irieran irir -! SFX W orir urieran orir -! SFX W erer isieran erer -! SFX W oner usieran oner -! SFX W etir itieran etir -! SFX W entir intieran entir -! SFX W ertir irtieran ertir -! SFX W estir istieran estir -! SFX W eguir iguieran eguir -! SFX W ervir irvieran ervir -! SFX W ar uvieran andar -! SFX W ener uvieran ener -! SFX W cir jeran ucir -! SFX W er jeran raer -! SFX W ecir ijeran ecir -! SFX W orar ueran [^g]orar -! SFX W orir ueran orir -! SFX W er yeran [eo]er -! SFX W er yeran caer -! SFX W ir yeran [^g]uir -! SFX W ír yeran oír -! SFX W üir uyeran güir -! SFX W eñir iñeran eñir -! SFX W orar üeran gorar -! SFX W errar ierran errar -! SFX W ontrar uentran ontrar -! SFX W ostrar uestran ostrar -! SFX W esar iesan esar -! SFX W osar uesan osar -! SFX W ensar iensan ensar -! SFX W usar úsan [ae]husar -! SFX W etar ietan etar -! SFX W etir itan etir -! SFX W oltar ueltan oltar -! SFX W entar ientan entar -! SFX W entir ientan entir -! SFX W ontar uentan ontar -! SFX W ertar iertan ertar -! SFX W erter iertan erter -! SFX W ertir iertan ertir -! SFX W ortar uertan ortar -! SFX W estar iestan estar -! SFX W ostar uestan ostar -! SFX W estir istan estir -! SFX W itar ítan [ae]hitar -! SFX W evar ievan evar -! SFX W ovar uevan ovar -! SFX W over uevan over -! SFX W olver uelvan olver -! SFX W ervir irvan ervir -! SFX W er yan oer -! SFX W ir yan [^g]uir -! SFX W üir uyan güir -! SFX W ezar iezan ezar -! SFX W ocer uezan cocer -! SFX W enzar ienzan enzar -! SFX W onzar üenzan gonzar -! SFX W orcer uerzan orcer -! SFX W orzar uerzan orzar -! SFX W izar ízan [ae]izar -! SFX W 0 ían [^fh]acer -! SFX W 0 ían [aeo]er -! SFX W 0 ían [io]rir -! SFX W 0 ían [üu]ir -! SFX W 0 ían ar -! SFX W 0 ían e[bdgmrtñ]ir -! SFX W 0 ían e[cd]er -! SFX W 0 ían e[ns]tir -! SFX W 0 ían enchir -! SFX W 0 ían ender -! SFX W 0 ían endir -! SFX W 0 ían er[dnt]er -! SFX W 0 ían er[ntv]ir -! SFX W 0 ían eunir -! SFX W 0 ían o[clv]er -! SFX W 0 ían olver -! SFX W 0 ían or[cd]er -! SFX W 0 ían ormir -! SFX W 0 ían ucir -! SFX W er ían er -! SFX W eír ían eír -! SFX W iar ían iar -! SFX W ir ían ir -! SFX W ír ían ír -! SFX W cer rían [fh]acer -! SFX W er rían aber -! SFX W er rían erer -! SFX W er rían oder -! SFX W er drían [eo]ner -! SFX W er drían aler -! SFX W ir drían alir -! SFX W ir drían enir -! SFX W ecir irían ecir -! SFX W ír irían [eo]ír -! SFX W oñar ueñan oñar -! SFX W eñir iñan eñir -! SFX W uar úan [^g]uar -! -! -! SFX W Y 202 S -! SFX W ar en andar -! SFX W ir en alir -! SFX W ir en ucir -! SFX W obar ueben obar -! SFX W ebir iben ebir -! SFX W erbar ierben erbar -! SFX W ibir íben ohibir -! SFX W ezar iecen ezar -! SFX W ocer uecen cocer -! SFX W ecir icen ecir -! SFX W enzar iencen enzar -! SFX W onzar üencen gonzar -! SFX W orcer uercen orcer -! SFX W orzar uercen orzar -! SFX W izar ícen [ae]izar -! SFX W eder ieden eder -! SFX W odar ueden odar -! SFX W oder ueden oder -! SFX W edir iden edir -! SFX W oldar uelden [^g]oldar -! SFX W oldar üelden goldar -! SFX W endar ienden endar -! SFX W ender ienden ender -! SFX W endir inden endir -! SFX W erder ierden erder -! SFX W ordar uerden ordar -! SFX W order uerden order -! SFX W egir igen egir -! SFX W enchir inchen enchir -! SFX W ijar íjen [ae]hijar -! SFX W oblar ueblen oblar -! SFX W emblar iemblen emblar -! SFX W elar ielen elar -! SFX W olar uelen olar -! SFX W oler uelen oler -! SFX W ollar uellen [^g]ollar -! SFX W ollar üellen gollar -! SFX W ilar ílen [ae]hilar -! SFX W emir imen emir -! SFX W ormir uermen ormir -! SFX W umar úmen [ae]humar -! SFX W ener ienen ener -! SFX W enir ienen enir -! SFX W onar uenen onar -! SFX W ernar iernen ernar -! SFX W erner iernen erner -! SFX W ernir iernen ernir -! SFX W ornar uernen ornar -! SFX W inar ínen [aeo]hinar -! SFX W unir únen eunir -! SFX W r ren [^a]ndar -! SFX W r ren [^d]ar -! SFX W r ren [^n]dar -! SFX W ebrar iebren ebrar -! SFX W embrar iembren embrar -! SFX W edrar iedren edrar -! SFX W endrar iendren endrar -! SFX W r eren alir -! SFX W r eren ernir -! SFX W r eren eunir -! SFX W r eren ohibir -! SFX W er ieren [^fh]acer -! SFX W er ieren aler -! SFX W er ieren e[cd]er -! SFX W er ieren ender -! SFX W er ieren er[dnt]er -! SFX W er ieren o[clv]er -! SFX W er ieren olver -! SFX W er ieren or[cd]er -! SFX W erer ieren erer -! SFX W erir ieren erir -! SFX W eír ieren eír -! SFX W irir ieren irir -! SFX W ebir ibieren ebir -! SFX W acer icieren [fh]acer -! SFX W edir idieren edir -! SFX W endir indieren endir -! SFX W oder udieren oder -! SFX W egir igieren egir -! SFX W enchir inchieren enchir -! SFX W emir imieren emir -! SFX W ormir urmieren ormir -! SFX W enir inieren enir -! SFX W aber upieren aber -! SFX W erir irieren erir -! SFX W irir irieren irir -! SFX W orir urieren orir -! SFX W erer isieren erer -! SFX W oner usieren oner -! SFX W etir itieren etir -! SFX W entir intieren entir -! SFX W ertir irtieren ertir -! SFX W estir istieren estir -! SFX W eguir iguieren eguir -! SFX W ervir irvieren ervir -! SFX W ar uvieren andar -! SFX W ener uvieren ener -! SFX W cir jeren ucir -! SFX W er jeren raer -! SFX W ecir ijeren ecir -! SFX W orar ueren [^g]orar -! SFX W orir ueren orir -! SFX W er yeren [eo]er -! SFX W er yeren caer -! SFX W ir yeren [^g]uir -! SFX W ír yeren oír -! SFX W üir uyeren güir -! SFX W eñir iñeren eñir -! SFX W orar üeren gorar -! SFX W errar ierren errar -! SFX W ontrar uentren ontrar -! SFX W ostrar uestren ostrar -! SFX W r sen [^a]ndar -! SFX W r sen [^d]ar -! SFX W r sen [^n]dar -! SFX W r esen alir -! SFX W r esen ernir -! SFX W r esen eunir -! SFX W r esen ohibir -! SFX W er iesen [^fh]acer -! SFX W er iesen aler -! SFX W er iesen e[cd]er -! SFX W er iesen ender -! SFX W er iesen er[dnt]er -! SFX W er iesen o[clv]er -! SFX W er iesen olver -! SFX W er iesen or[cd]er -! SFX W esar iesen esar -! SFX W eír iesen eír -! SFX W ebir ibiesen ebir -! SFX W acer iciesen [fh]acer -! SFX W edir idiesen edir -! SFX W endir indiesen endir -! SFX W oder udiesen oder -! SFX W egir igiesen egir -! SFX W enchir inchiesen enchir -! SFX W emir imiesen emir -! SFX W ormir urmiesen ormir -! SFX W enir iniesen enir -! SFX W aber upiesen aber -! SFX W erir iriesen erir -! SFX W irir iriesen irir -! SFX W orir uriesen orir -! SFX W erer isiesen erer -! SFX W oner usiesen oner -! SFX W etir itiesen etir -! SFX W entir intiesen entir -! SFX W ertir irtiesen ertir -! SFX W estir istiesen estir -! SFX W eguir iguiesen eguir -! SFX W ervir irviesen ervir -! SFX W ar uviesen andar -! SFX W ener uviesen ener -! SFX W cir jesen ucir -! SFX W er jesen raer -! SFX W ecir ijesen ecir -! SFX W osar uesen osar -! SFX W er yesen [eo]er -! SFX W er yesen caer -! SFX W ir yesen [^g]uir -! SFX W ír yesen oír -! SFX W üir uyesen güir -! SFX W eñir iñesen eñir -! SFX W ensar iensen ensar -! SFX W usar úsen [ae]husar -! SFX W etar ieten etar -! SFX W etir iten etir -! SFX W oltar uelten oltar -! SFX W entar ienten entar -! SFX W entir ienten entir -! SFX W ontar uenten ontar -! SFX W ertar ierten ertar -! SFX W erter ierten erter -! SFX W ertir ierten ertir -! SFX W ortar uerten ortar -! SFX W estar iesten estar -! SFX W ostar uesten ostar -! SFX W estir isten estir -! SFX W itar íten [ae]hitar -! SFX W gar eguen ugar -! SFX W egar ieguen egar -! SFX W ogar ueguen ogar -! SFX W eguir iguen eguir -! SFX W olgar uelguen olgar -! SFX W engar ienguen engar -! SFX W ocar uequen ocar -! SFX W olcar uelquen olcar -! SFX W orcar uerquen orcar -! SFX W evar ieven evar -! SFX W ovar ueven ovar -! SFX W over ueven over -! SFX W olver uelven olver -! SFX W ervir irven ervir -! SFX W ir yen [^g]uir -! SFX W ír yen oír -! SFX W üir uyen güir -! SFX W eír íen eír -! SFX W iar íen iar -! SFX W oñar ueñen oñar -! SFX W eñir iñen eñir -! SFX W uar úen [^g]uar -! SFX W uar üen guar -! -! -! SFX W Y 49 S -! SFX W 0 on [^a]ndar -! SFX W 0 on [^d]ar -! SFX W 0 on [^n]dar -! SFX W r eron alir -! SFX W r eron ernir -! SFX W r eron eunir -! SFX W r eron irir -! SFX W r eron ohibir -! SFX W er ieron [^fh]acer -! SFX W er ieron aler -! SFX W er ieron e[cd]er -! SFX W er ieron ender -! SFX W er ieron er[dnt]er -! SFX W er ieron o[clv]er -! SFX W er ieron olver -! SFX W er ieron or[cd]er -! SFX W eír ieron eír -! SFX W ebir ibieron ebir -! SFX W acer icieron [fh]acer -! SFX W edir idieron edir -! SFX W endir indieron endir -! SFX W oder udieron oder -! SFX W egir igieron egir -! SFX W enchir inchieron enchir -! SFX W emir imieron emir -! SFX W ormir urmieron ormir -! SFX W enir inieron enir -! SFX W aber upieron aber -! SFX W erir irieron erir -! SFX W orir urieron orir -! SFX W erer isieron erer -! SFX W oner usieron oner -! SFX W etir itieron etir -! SFX W entir intieron entir -! SFX W ertir irtieron ertir -! SFX W estir istieron estir -! SFX W eguir iguieron eguir -! SFX W ervir irvieron ervir -! SFX W ar uvieron andar -! SFX W ener uvieron ener -! SFX W cir jeron ucir -! SFX W er jeron raer -! SFX W ecir ijeron ecir -! SFX W er yeron [eo]er -! SFX W er yeron caer -! SFX W ir yeron [^g]uir -! SFX W ír yeron oír -! SFX W üir uyeron güir -! SFX W eñir iñeron eñir -! -! -! SFX W Y 29 S -! SFX W 0 án [^fh]acer -! SFX W 0 án [aeo]er -! SFX W 0 án [io]rir -! SFX W 0 án [üu]ir -! SFX W 0 án ar -! SFX W 0 án e[bdgmrtñ]ir -! SFX W 0 án e[cd]er -! SFX W 0 án e[ns]tir -! SFX W 0 án enchir -! SFX W 0 án ender -! SFX W 0 án endir -! SFX W 0 án er[dnt]er -! SFX W 0 án er[ntv]ir -! SFX W 0 án eunir -! SFX W 0 án o[clv]er -! SFX W 0 án olver -! SFX W 0 án or[cd]er -! SFX W 0 án ormir -! SFX W 0 án ucir -! SFX W cer rán [fh]acer -! SFX W er rán aber -! SFX W er rán erer -! SFX W er rán oder -! SFX W er drán [eo]ner -! SFX W er drán aler -! SFX W ir drán alir -! SFX W ir drán enir -! SFX W ecir irán ecir -! SFX W ír irán [eo]ír -! -! -! SFX W Y 126 S -! SFX W ar o andar -! SFX W ar o guar -! SFX W er o [eo]er -! SFX W obar uebo obar -! SFX W ebir ibo ebir -! SFX W erbar ierbo erbar -! SFX W ibir íbo ohibir -! SFX W ocar ueco ocar -! SFX W olcar uelco olcar -! SFX W orcar uerco orcar -! SFX W cer zco [^c]ocer -! SFX W cer zco [^fh]acer -! SFX W cer zco ecer -! SFX W ucir uzco ucir -! SFX W eder iedo eder -! SFX W odar uedo odar -! SFX W oder uedo oder -! SFX W edir ido edir -! SFX W oldar ueldo [^g]oldar -! SFX W oldar üeldo goldar -! SFX W endar iendo endar -! SFX W ender iendo ender -! SFX W endir indo endir -! SFX W erder ierdo erder -! SFX W ordar uerdo ordar -! SFX W order uerdo order -! SFX W oder udo oder -! SFX W cer go [fh]acer -! SFX W er go aler -! SFX W er go ener -! SFX W er go oner -! SFX W ir go alir -! SFX W ir go enir -! SFX W gar ego ugar -! SFX W egar iego egar -! SFX W ogar uego ogar -! SFX W ecir igo ecir -! SFX W eguir igo eguir -! SFX W er igo [cr]aer -! SFX W er igo oer -! SFX W ír igo oír -! SFX W olgar uelgo olgar -! SFX W engar iengo engar -! SFX W enchir incho enchir -! SFX W cir jo ucir -! SFX W er jo raer -! SFX W ecir ijo ecir -! SFX W egir ijo egir -! SFX W ijar íjo [ae]hijar -! SFX W oblar ueblo oblar -! SFX W emblar iemblo emblar -! SFX W elar ielo elar -! SFX W olar uelo olar -! SFX W oler uelo oler -! SFX W ollar uello [^g]ollar -! SFX W ollar üello gollar -! SFX W ilar ílo [ae]hilar -! SFX W emir imo emir -! SFX W ormir uermo ormir -! SFX W umar úmo [ae]humar -! SFX W onar ueno onar -! SFX W enir ino enir -! SFX W ernar ierno ernar -! SFX W erner ierno erner -! SFX W ernir ierno ernir -! SFX W ornar uerno ornar -! SFX W inar íno [aeo]hinar -! SFX W unir úno eunir -! SFX W caber quepo caber -! SFX W aber upo aber -! SFX W ebrar iebro ebrar -! SFX W embrar iembro embrar -! SFX W edrar iedro edrar -! SFX W endrar iendro endrar -! SFX W erer iero erer -! SFX W erir iero erir -! SFX W irir iero irir -! SFX W orar uero [^g]orar -! SFX W orir uero orir -! SFX W orar üero gorar -! SFX W errar ierro errar -! SFX W ontrar uentro ontrar -! SFX W ostrar uestro ostrar -! SFX W esar ieso esar -! SFX W osar ueso osar -! SFX W erer iso erer -! SFX W ensar ienso ensar -! SFX W oner uso oner -! SFX W usar úso [ae]husar -! SFX W etar ieto etar -! SFX W etir ito etir -! SFX W oltar uelto oltar -! SFX W entar iento entar -! SFX W entir iento entir -! SFX W ontar uento ontar -! SFX W ertar ierto ertar -! SFX W erter ierto erter -! SFX W ertir ierto ertir -! SFX W ortar uerto ortar -! SFX W estar iesto estar -! SFX W ostar uesto ostar -! SFX W estir isto estir -! SFX W itar íto [ae]hitar -! SFX W evar ievo evar -! SFX W ovar uevo ovar -! SFX W over uevo over -! SFX W olver uelvo olver -! SFX W ervir irvo ervir -! SFX W ar uvo andar -! SFX W ener uvo ener -! SFX W er yo oer -! SFX W uir uyo [^g]uir -! SFX W üir uyo güir -! SFX W ezar iezo ezar -! SFX W ocer uezo cocer -! SFX W acer izo [fh]acer -! SFX W enzar ienzo enzar -! SFX W onzar üenzo gonzar -! SFX W orcer uerzo orcer -! SFX W orzar uerzo orzar -! SFX W izar ízo [ae]izar -! SFX W eír ío eír -! SFX W iar ío iar -! SFX W oñar ueño oñar -! SFX W eñir iño eñir -! SFX W uar úo [^g]uar -! -! -! -! SFX W Y 195 S -! SFX W er as [eo]er -! SFX W r bas ar -! SFX W obar uebas obar -! SFX W ebir ibas ebir -! SFX W erbar ierbas erbar -! SFX W ibir íbas ohibir -! SFX W ocar uecas ocar -! SFX W olcar uelcas olcar -! SFX W orcar uercas orcar -! SFX W cer zcas [^c]ocer -! SFX W cer zcas [^fh]acer -! SFX W cer zcas ecer -! SFX W cir zcas ucir -! SFX W eder iedas eder -! SFX W odar uedas odar -! SFX W oder uedas oder -! SFX W edir idas edir -! SFX W oldar ueldas [^g]oldar -! SFX W oldar üeldas goldar -! SFX W endar iendas endar -! SFX W ender iendas ender -! SFX W endir indas endir -! SFX W erder ierdas erder -! SFX W ordar uerdas ordar -! SFX W order uerdas order -! SFX W cer gas [fh]acer -! SFX W er gas [eo]ner -! SFX W er gas aler -! SFX W ir gas alir -! SFX W gar egas ugar -! SFX W egar iegas egar -! SFX W ogar uegas ogar -! SFX W ecir igas ecir -! SFX W eguir igas eguir -! SFX W er igas aer -! SFX W er igas oer -! SFX W ír igas oír -! SFX W olgar uelgas olgar -! SFX W enir engas enir -! SFX W engar iengas engar -! SFX W enchir inchas enchir -! SFX W egir ijas egir -! SFX W ijar íjas [ae]hijar -! SFX W oblar ueblas oblar -! SFX W emblar iemblas emblar -! SFX W elar ielas elar -! SFX W olar uelas olar -! SFX W oler uelas oler -! SFX W ollar uellas [^g]ollar -! SFX W ollar üellas gollar -! SFX W ilar ílas [ae]hilar -! SFX W emir imas emir -! SFX W ormir uermas ormir -! SFX W umar úmas [ae]humar -! SFX W onar uenas onar -! SFX W ernar iernas ernar -! SFX W erner iernas erner -! SFX W ernir iernas ernir -! SFX W ornar uernas ornar -! SFX W inar ínas [aeo]hinar -! SFX W unir únas eunir -! SFX W aber epas saber -! SFX W caber quepas caber -! SFX W r ras [^a]ndar -! SFX W r ras [^d]ar -! SFX W r ras [^n]dar -! SFX W ebrar iebras ebrar -! SFX W embrar iembras embrar -! SFX W edrar iedras edrar -! SFX W endrar iendras endrar -! SFX W r eras alir -! SFX W r eras ernir -! SFX W r eras eunir -! SFX W r eras ohibir -! SFX W er ieras [^fh]acer -! SFX W er ieras aler -! SFX W er ieras e[cd]er -! SFX W er ieras ender -! SFX W er ieras er[dnt]er -! SFX W er ieras o[clv]er -! SFX W er ieras olver -! SFX W er ieras or[cd]er -! SFX W erer ieras erer -! SFX W erir ieras erir -! SFX W eír ieras eír -! SFX W irir ieras irir -! SFX W ebir ibieras ebir -! SFX W acer icieras [fh]acer -! SFX W edir idieras edir -! SFX W endir indieras endir -! SFX W oder udieras oder -! SFX W egir igieras egir -! SFX W enchir inchieras enchir -! SFX W emir imieras emir -! SFX W ormir urmieras ormir -! SFX W enir inieras enir -! SFX W aber upieras aber -! SFX W erir irieras erir -! SFX W irir irieras irir -! SFX W orir urieras orir -! SFX W erer isieras erer -! SFX W oner usieras oner -! SFX W etir itieras etir -! SFX W entir intieras entir -! SFX W ertir irtieras ertir -! SFX W estir istieras estir -! SFX W eguir iguieras eguir -! SFX W ervir irvieras ervir -! SFX W ar uvieras andar -! SFX W ener uvieras ener -! SFX W cir jeras ucir -! SFX W er jeras raer -! SFX W ecir ijeras ecir -! SFX W orar ueras [^g]orar -! SFX W orir ueras orir -! SFX W er yeras [eo]er -! SFX W er yeras caer -! SFX W ir yeras [^g]uir -! SFX W ír yeras oír -! SFX W üir uyeras güir -! SFX W eñir iñeras eñir -! SFX W orar üeras gorar -! SFX W errar ierras errar -! SFX W ontrar uentras ontrar -! SFX W ostrar uestras ostrar -! SFX W esar iesas esar -! SFX W osar uesas osar -! SFX W ensar iensas ensar -! SFX W usar úsas [ae]husar -! SFX W etar ietas etar -! SFX W etir itas etir -! SFX W oltar ueltas oltar -! SFX W entar ientas entar -! SFX W entir ientas entir -! SFX W ontar uentas ontar -! SFX W ertar iertas ertar -! SFX W erter iertas erter -! SFX W ertir iertas ertir -! SFX W ortar uertas ortar -! SFX W estar iestas estar -! SFX W ostar uestas ostar -! SFX W estir istas estir -! SFX W itar ítas [ae]hitar -! SFX W evar ievas evar -! SFX W ovar uevas ovar -! SFX W over uevas over -! SFX W olver uelvas olver -! SFX W ervir irvas ervir -! SFX W er yas oer -! SFX W ir yas [^g]uir -! SFX W üir uyas güir -! SFX W ezar iezas ezar -! SFX W ocer uezas cocer -! SFX W enzar ienzas enzar -! SFX W onzar üenzas gonzar -! SFX W orcer uerzas orcer -! SFX W orzar uerzas orzar -! SFX W izar ízas [ae]izar -! SFX W 0 ías [^fh]acer -! SFX W 0 ías [aeo]er -! SFX W 0 ías [io]rir -! SFX W 0 ías [üu]ir -! SFX W 0 ías ar -! SFX W 0 ías e[bdgmrtñ]ir -! SFX W 0 ías e[cd]er -! SFX W 0 ías e[ns]tir -! SFX W 0 ías enchir -! SFX W 0 ías ender -! SFX W 0 ías endir -! SFX W 0 ías er[dnt]er -! SFX W 0 ías er[ntv]ir -! SFX W 0 ías eunir -! SFX W 0 ías o[clv]er -! SFX W 0 ías olver -! SFX W 0 ías or[cd]er -! SFX W 0 ías ormir -! SFX W 0 ías ucir -! SFX W er ías er -! SFX W eír ías eír -! SFX W iar ías iar -! SFX W ir ías ir -! SFX W ír ías ír -! SFX W cer rías [fh]acer -! SFX W er rías aber -! SFX W er rías erer -! SFX W er rías oder -! SFX W er drías [eo]ner -! SFX W er drías aler -! SFX W ir drías alir -! SFX W ir drías enir -! SFX W ecir irías ecir -! SFX W ír irías [eo]ír -! SFX W oñar ueñas oñar -! SFX W eñir iñas eñir -! SFX W uar úas [^g]uar -! -! -! -! SFX W Y 202 S -! SFX W ar es andar -! SFX W ir es ucir -! SFX W r es alir -! SFX W obar uebes obar -! SFX W ebir ibes ebir -! SFX W erbar ierbes erbar -! SFX W ibir íbes ohibir -! SFX W ezar ieces ezar -! SFX W ocer ueces cocer -! SFX W ecir ices ecir -! SFX W enzar iences enzar -! SFX W onzar üences gonzar -! SFX W orcer uerces orcer -! SFX W orzar uerces orzar -! SFX W izar íces [ae]izar -! SFX W eder iedes eder -! SFX W odar uedes odar -! SFX W oder uedes oder -! SFX W edir ides edir -! SFX W oldar ueldes [^g]oldar -! SFX W oldar üeldes goldar -! SFX W endar iendes endar -! SFX W ender iendes ender -! SFX W endir indes endir -! SFX W erder ierdes erder -! SFX W ordar uerdes ordar -! SFX W order uerdes order -! SFX W egir iges egir -! SFX W enchir inches enchir -! SFX W ijar íjes [ae]hijar -! SFX W oblar uebles oblar -! SFX W emblar iembles emblar -! SFX W elar ieles elar -! SFX W olar ueles olar -! SFX W oler ueles oler -! SFX W ollar uelles [^g]ollar -! SFX W ollar üelles gollar -! SFX W ilar íles [ae]hilar -! SFX W emir imes emir -! SFX W ormir uermes ormir -! SFX W umar úmes [ae]humar -! SFX W ener ienes ener -! SFX W enir ienes enir -! SFX W onar uenes onar -! SFX W ernar iernes ernar -! SFX W erner iernes erner -! SFX W ernir iernes ernir -! SFX W ornar uernes ornar -! SFX W inar ínes [aeo]hinar -! SFX W unir únes eunir -! SFX W r res [^a]ndar -! SFX W r res [^d]ar -! SFX W r res [^n]dar -! SFX W ebrar iebres ebrar -! SFX W embrar iembres embrar -! SFX W edrar iedres edrar -! SFX W endrar iendres endrar -! SFX W r eres alir -! SFX W r eres ernir -! SFX W r eres eunir -! SFX W r eres ohibir -! SFX W er ieres [^fh]acer -! SFX W er ieres aler -! SFX W er ieres e[cd]er -! SFX W er ieres ender -! SFX W er ieres er[dnt]er -! SFX W er ieres o[clv]er -! SFX W er ieres olver -! SFX W er ieres or[cd]er -! SFX W erer ieres erer -! SFX W erir ieres erir -! SFX W eír ieres eír -! SFX W irir ieres irir -! SFX W ebir ibieres ebir -! SFX W acer icieres [fh]acer -! SFX W edir idieres edir -! SFX W endir indieres endir -! SFX W oder udieres oder -! SFX W egir igieres egir -! SFX W enchir inchieres enchir -! SFX W emir imieres emir -! SFX W ormir urmieres ormir -! SFX W enir inieres enir -! SFX W aber upieres aber -! SFX W erir irieres erir -! SFX W irir irieres irir -! SFX W orir urieres orir -! SFX W erer isieres erer -! SFX W oner usieres oner -! SFX W etir itieres etir -! SFX W entir intieres entir -! SFX W ertir irtieres ertir -! SFX W estir istieres estir -! SFX W eguir iguieres eguir -! SFX W ervir irvieres ervir -! SFX W ar uvieres andar -! SFX W ener uvieres ener -! SFX W cir jeres ucir -! SFX W er jeres raer -! SFX W ecir ijeres ecir -! SFX W orar ueres [^g]orar -! SFX W orir ueres orir -! SFX W er yeres [eo]er -! SFX W er yeres caer -! SFX W ir yeres [^g]uir -! SFX W ír yeres oír -! SFX W üir uyeres güir -! SFX W eñir iñeres eñir -! SFX W orar üeres gorar -! SFX W errar ierres errar -! SFX W ontrar uentres ontrar -! SFX W ostrar uestres ostrar -! SFX W r ses [^a]ndar -! SFX W r ses [^d]ar -! SFX W r ses [^n]dar -! SFX W r eses alir -! SFX W r eses ernir -! SFX W r eses eunir -! SFX W r eses ohibir -! SFX W er ieses [^fh]acer -! SFX W er ieses aler -! SFX W er ieses e[cd]er -! SFX W er ieses ender -! SFX W er ieses er[dnt]er -! SFX W er ieses o[clv]er -! SFX W er ieses olver -! SFX W er ieses or[cd]er -! SFX W esar ieses esar -! SFX W eír ieses eír -! SFX W ebir ibieses ebir -! SFX W acer icieses [fh]acer -! SFX W edir idieses edir -! SFX W endir indieses endir -! SFX W oder udieses oder -! SFX W egir igieses egir -! SFX W enchir inchieses enchir -! SFX W emir imieses emir -! SFX W ormir urmieses ormir -! SFX W enir inieses enir -! SFX W aber upieses aber -! SFX W erir irieses erir -! SFX W irir irieses irir -! SFX W orir urieses orir -! SFX W erer isieses erer -! SFX W oner usieses oner -! SFX W etir itieses etir -! SFX W entir intieses entir -! SFX W ertir irtieses ertir -! SFX W estir istieses estir -! SFX W eguir iguieses eguir -! SFX W ervir irvieses ervir -! SFX W ar uvieses andar -! SFX W ener uvieses ener -! SFX W cir jeses ucir -! SFX W er jeses raer -! SFX W ecir ijeses ecir -! SFX W osar ueses osar -! SFX W er yeses [eo]er -! SFX W er yeses caer -! SFX W ir yeses [^g]uir -! SFX W ír yeses oír -! SFX W üir uyeses güir -! SFX W eñir iñeses eñir -! SFX W ensar ienses ensar -! SFX W usar úses [ae]husar -! SFX W etar ietes etar -! SFX W etir ites etir -! SFX W oltar ueltes oltar -! SFX W entar ientes entar -! SFX W entir ientes entir -! SFX W ontar uentes ontar -! SFX W ertar iertes ertar -! SFX W erter iertes erter -! SFX W ertir iertes ertir -! SFX W ortar uertes ortar -! SFX W estar iestes estar -! SFX W ostar uestes ostar -! SFX W estir istes estir -! SFX W itar ítes [ae]hitar -! SFX W gar egues ugar -! SFX W egar iegues egar -! SFX W ogar uegues ogar -! SFX W eguir igues eguir -! SFX W olgar uelgues olgar -! SFX W engar iengues engar -! SFX W ocar ueques ocar -! SFX W olcar uelques olcar -! SFX W orcar uerques orcar -! SFX W evar ieves evar -! SFX W ovar ueves ovar -! SFX W over ueves over -! SFX W olver uelves olver -! SFX W ervir irves ervir -! SFX W ír yes oír -! SFX W uir uyes [^g]uir -! SFX W üir uyes güir -! SFX W eír íes eír -! SFX W iar íes iar -! SFX W oñar ueñes oñar -! SFX W eñir iñes eñir -! SFX W uar úes [^g]uar -! SFX W uar ües guar -! -! -! SFX W Y 49 S -! SFX W r rais [^a]ndar -! SFX W r rais [^d]ar -! SFX W r rais [^n]dar -! SFX W r erais alir -! SFX W r erais ernir -! SFX W r erais eunir -! SFX W r erais ohibir -! SFX W er ierais [^fh]acer -! SFX W er ierais aler -! SFX W er ierais e[cd]er -! SFX W er ierais ender -! SFX W er ierais er[dnt]er -! SFX W er ierais o[clv]er -! SFX W er ierais olver -! SFX W er ierais or[cd]er -! SFX W eír ierais eír -! SFX W ebir ibierais ebir -! SFX W acer icierais [fh]acer -! SFX W edir idierais edir -! SFX W endir indierais endir -! SFX W oder udierais oder -! SFX W egir igierais egir -! SFX W enchir inchierais enchir -! SFX W emir imierais emir -! SFX W ormir urmierais ormir -! SFX W enir inierais enir -! SFX W aber upierais aber -! SFX W erir irierais erir -! SFX W irir irierais irir -! SFX W orir urierais orir -! SFX W erer isierais erer -! SFX W oner usierais oner -! SFX W etir itierais etir -! SFX W entir intierais entir -! SFX W ertir irtierais ertir -! SFX W estir istierais estir -! SFX W eguir iguierais eguir -! SFX W ervir irvierais ervir -! SFX W ar uvierais andar -! SFX W ener uvierais ener -! SFX W cir jerais ucir -! SFX W er jerais raer -! SFX W ecir ijerais ecir -! SFX W er yerais [eo]er -! SFX W er yerais caer -! SFX W ir yerais [^g]uir -! SFX W ír yerais oír -! SFX W üir uyerais güir -! SFX W eñir iñerais eñir -! -! -! -! SFX W Y 32 S -! SFX W 0 íais [^fh]acer -! SFX W 0 íais [aeo]er -! SFX W 0 íais [io]rir -! SFX W 0 íais [üu]ir -! SFX W 0 íais ar -! SFX W 0 íais e[bdgmrtñ]ir -! SFX W 0 íais e[cd]er -! SFX W 0 íais e[ns]tir -! SFX W 0 íais enchir -! SFX W 0 íais ender -! SFX W 0 íais endir -! SFX W 0 íais er[dnt]er -! SFX W 0 íais er[ntv]ir -! SFX W 0 íais eunir -! SFX W 0 íais o[clv]er -! SFX W 0 íais olver -! SFX W 0 íais or[cd]er -! SFX W 0 íais ormir -! SFX W 0 íais ucir -! SFX W er íais er -! SFX W ir íais ir -! SFX W ír íais ír -! SFX W cer ríais [fh]acer -! SFX W er ríais aber -! SFX W er ríais erer -! SFX W er ríais oder -! SFX W er dríais [eo]ner -! SFX W er dríais aler -! SFX W ir dríais alir -! SFX W ir dríais enir -! SFX W ecir iríais ecir -! SFX W ír iríais [eo]ír -! -! -! -! SFX W Y 48 S -! SFX W r reis [^a]ndar -! SFX W r reis [^d]ar -! SFX W r reis [^n]dar -! SFX W r ereis alir -! SFX W r ereis ernir -! SFX W r ereis ohibir -! SFX W er iereis [^fh]acer -! SFX W er iereis aler -! SFX W er iereis e[cd]er -! SFX W er iereis ender -! SFX W er iereis er[dnt]er -! SFX W er iereis o[clv]er -! SFX W er iereis olver -! SFX W er iereis or[cd]er -! SFX W eír iereis eír -! SFX W ebir ibiereis ebir -! SFX W acer iciereis [fh]acer -! SFX W edir idiereis edir -! SFX W endir indiereis endir -! SFX W oder udiereis oder -! SFX W egir igiereis egir -! SFX W enchir inchiereis enchir -! SFX W emir imiereis emir -! SFX W ormir urmiereis ormir -! SFX W enir iniereis enir -! SFX W aber upiereis aber -! SFX W erir iriereis erir -! SFX W irir iriereis irir -! SFX W orir uriereis orir -! SFX W oner usiereis oner -! SFX W etir itiereis etir -! SFX W entir intiereis entir -! SFX W ertir irtiereis ertir -! SFX W estir istiereis estir -! SFX W eguir iguiereis eguir -! SFX W ervir irviereis ervir -! SFX W ar uviereis andar -! SFX W ener uviereis ener -! SFX W cir jereis ucir -! SFX W er jereis raer -! SFX W ecir ijereis ecir -! SFX W er yereis [eo]er -! SFX W er yereis caer -! SFX W ir yereis [^g]uir -! SFX W ír yereis oír -! SFX W üir uyereis güir -! SFX W eñir iñereis eñir -! SFX W erer isiéreis erer -! -! -! -! SFX W Y 49 S -! SFX W r seis [^a]ndar -! SFX W r seis [^d]ar -! SFX W r seis [^n]dar -! SFX W r eseis alir -! SFX W r eseis ernir -! SFX W r eseis eunir -! SFX W r eseis ohibir -! SFX W er ieseis [^fh]acer -! SFX W er ieseis aler -! SFX W er ieseis e[cd]er -! SFX W er ieseis ender -! SFX W er ieseis er[dnt]er -! SFX W er ieseis o[clv]er -! SFX W er ieseis olver -! SFX W er ieseis or[cd]er -! SFX W eír ieseis eír -! SFX W ebir ibieseis ebir -! SFX W acer icieseis [fh]acer -! SFX W edir idieseis edir -! SFX W endir indieseis endir -! SFX W oder udieseis oder -! SFX W egir igieseis egir -! SFX W enchir inchieseis enchir -! SFX W emir imieseis emir -! SFX W ormir urmieseis ormir -! SFX W enir inieseis enir -! SFX W aber upieseis aber -! SFX W erir irieseis erir -! SFX W irir irieseis irir -! SFX W orir urieseis orir -! SFX W erer isieseis erer -! SFX W oner usieseis oner -! SFX W etir itieseis etir -! SFX W entir intieseis entir -! SFX W ertir irtieseis ertir -! SFX W estir istieseis estir -! SFX W eguir iguieseis eguir -! SFX W ervir irvieseis ervir -! SFX W ar uvieseis andar -! SFX W ener uvieseis ener -! SFX W cir jeseis ucir -! SFX W er jeseis raer -! SFX W ecir ijeseis ecir -! SFX W er yeseis [eo]er -! SFX W er yeseis caer -! SFX W ir yeseis [^g]uir -! SFX W ír yeseis oír -! SFX W üir uyeseis güir -! SFX W eñir iñeseis eñir -! -! -! -! SFX W Y 45 S -! SFX W r steis [^a]ndar -! SFX W r steis [^d]ar -! SFX W r steis [^n]dar -! SFX W r steis [eo]ír -! SFX W r steis [üu]ir -! SFX W r steis alir -! SFX W r steis ebir -! SFX W r steis edir -! SFX W r steis egir -! SFX W r steis emir -! SFX W r steis enchir -! SFX W r steis endir -! SFX W r steis entir -! SFX W r steis erir -! SFX W r steis ernir -! SFX W r steis ertir -! SFX W r steis ervir -! SFX W r steis estir -! SFX W r steis etir -! SFX W r steis eunir -! SFX W r steis eñir -! SFX W r steis irir -! SFX W r steis orir -! SFX W r steis ormir -! SFX W er isteis [^fh]acer -! SFX W er isteis aler -! SFX W er isteis e[cd]er -! SFX W er isteis ender -! SFX W er isteis er[dnt]er -! SFX W er isteis o[clv]er -! SFX W er isteis olver -! SFX W er isteis or[cd]er -! SFX W acer icisteis [fh]acer -! SFX W oder udisteis oder -! SFX W cir jisteis ucir -! SFX W er jisteis raer -! SFX W ecir ijisteis ecir -! SFX W enir inisteis enir -! SFX W aber upisteis aber -! SFX W erer isisteis erer -! SFX W oner usisteis oner -! SFX W ar uvisteis andar -! SFX W ener uvisteis ener -! SFX W er ísteis [eo]er -! SFX W er ísteis caer -! -! -! -! SFX W Y 54 S -! SFX W ar áis ar -! SFX W er áis [eo]er -! SFX W er áis eder -! SFX W er áis ender -! SFX W er áis erder -! SFX W er áis erer -! SFX W er áis erner -! SFX W er áis erter -! SFX W er áis oder -! SFX W er áis oler -! SFX W er áis olver -! SFX W er áis order -! SFX W er áis over -! SFX W ir áis ernir -! SFX W ir áis eunir -! SFX W ir áis irir -! SFX W ir áis ohibir -! SFX W ebir ibáis ebir -! SFX W cer zcáis [^c]ocer -! SFX W cer zcáis [^fh]acer -! SFX W cer zcáis ecer -! SFX W cir zcáis ucir -! SFX W edir idáis edir -! SFX W endir indáis endir -! SFX W cer gáis [fh]acer -! SFX W er gáis [eo]ner -! SFX W er gáis aler -! SFX W ir gáis alir -! SFX W ecir igáis ecir -! SFX W eguir igáis eguir -! SFX W er igáis aer -! SFX W er igáis oer -! SFX W ír igáis oír -! SFX W enir engáis enir -! SFX W enchir incháis enchir -! SFX W eír iáis eír -! SFX W egir ijáis egir -! SFX W emir imáis emir -! SFX W ormir urmáis ormir -! SFX W aber epáis saber -! SFX W caber quepáis caber -! SFX W erir iráis erir -! SFX W orir uráis orir -! SFX W etir itáis etir -! SFX W entir intáis entir -! SFX W ertir irtáis ertir -! SFX W estir istáis estir -! SFX W ervir irváis ervir -! SFX W er yáis oer -! SFX W ir yáis [^g]uir -! SFX W üir uyáis güir -! SFX W cer záis cocer -! SFX W cer záis orcer -! SFX W emir iñáis eñir -! -! -! -! SFX W Y 84 S -! SFX W 0 éis [^fh]acer -! SFX W 0 éis [aeo]er -! SFX W 0 éis [io]rir -! SFX W 0 éis [üu]ir -! SFX W 0 éis ar -! SFX W 0 éis e[bdgmrtñ]ir -! SFX W 0 éis e[cd]er -! SFX W 0 éis e[ns]tir -! SFX W 0 éis enchir -! SFX W 0 éis ender -! SFX W 0 éis endir -! SFX W 0 éis er[dnt]er -! SFX W 0 éis er[ntv]ir -! SFX W 0 éis eunir -! SFX W 0 éis o[clv]er -! SFX W 0 éis olver -! SFX W 0 éis or[cd]er -! SFX W 0 éis ormir -! SFX W 0 éis ucir -! SFX W ar éis [^g]uar -! SFX W ar éis [ae]hu[ms]ar -! SFX W ar éis [ae]ndar -! SFX W ar éis [aeo]hi[jlnt]ar -! SFX W ar éis ebrar -! SFX W ar éis edrar -! SFX W ar éis elar -! SFX W ar éis emblar -! SFX W ar éis embrar -! SFX W ar éis endrar -! SFX W ar éis ensar -! SFX W ar éis entar -! SFX W ar éis erbar -! SFX W ar éis ernar -! SFX W ar éis errar -! SFX W ar éis ertar -! SFX W ar éis esar -! SFX W ar éis estar -! SFX W ar éis etar -! SFX W ar éis evar -! SFX W ar éis iar -! SFX W ar éis obar -! SFX W ar éis oblar -! SFX W ar éis odar -! SFX W ar éis olar -! SFX W ar éis oldar -! SFX W ar éis ollar -! SFX W ar éis oltar -! SFX W ar éis onar -! SFX W ar éis ontar -! SFX W ar éis ontrar -! SFX W ar éis orar -! SFX W ar éis ordar -! SFX W ar éis ornar -! SFX W ar éis ortar -! SFX W ar éis osar -! SFX W ar éis ostar -! SFX W ar éis ostrar -! SFX W ar éis ovar -! SFX W ar éis oñar -! SFX W er éis er -! SFX W zar céis [ae]izar -! SFX W zar céis enzar -! SFX W zar céis ezar -! SFX W zar céis gonzar -! SFX W zar céis orzar -! SFX W cer réis [fh]acer -! SFX W er réis aber -! SFX W er réis erer -! SFX W er réis oder -! SFX W er dréis [eo]ner -! SFX W er dréis aler -! SFX W ir dréis alir -! SFX W ir dréis enir -! SFX W ecir iréis ecir -! SFX W ír iréis [eo]ír -! SFX W ar uéis olgar -! SFX W gar guéis egar -! SFX W gar guéis engar -! SFX W gar guéis ugar -! SFX W ogar guéis ogar -! SFX W car quéis olcar -! SFX W car quéis orcar -! SFX W ocar quéis ocar -! SFX W uar üéis guar -! -! -! SFX W Y 338 S -! SFX W r mos r -! SFX W er amos [eo]er -! SFX W er amos eder -! SFX W er amos ender -! SFX W er amos erder -! SFX W er amos erer -! SFX W er amos erner -! SFX W er amos erter -! SFX W er amos oder -! SFX W er amos oler -! SFX W er amos olver -! SFX W er amos order -! SFX W er amos over -! SFX W ir amos ernir -! SFX W ir amos eunir -! SFX W ir amos irir -! SFX W ir amos ohibir -! SFX W ebir ibamos ebir -! SFX W ar ábamos ar -! SFX W cer zcamos [^c]ocer -! SFX W cer zcamos [^fh]acer -! SFX W cer zcamos ecer -! SFX W cir zcamos ucir -! SFX W edir idamos edir -! SFX W endir indamos endir -! SFX W cer gamos [fh]acer -! SFX W er gamos [eo]ner -! SFX W er gamos aler -! SFX W ir gamos alir -! SFX W ecir igamos ecir -! SFX W eguir igamos eguir -! SFX W er igamos aer -! SFX W er igamos oer -! SFX W ír igamos oír -! SFX W enir engamos enir -! SFX W enchir inchamos enchir -! SFX W eír iamos eír -! SFX W egir ijamos egir -! SFX W emir imamos emir -! SFX W ormir urmamos ormir -! SFX W aber epamos saber -! SFX W caber quepamos caber -! SFX W erir iramos erir -! SFX W orir uramos orir -! SFX W ar áramos [^a]ndar -! SFX W ar áramos [^d]ar -! SFX W ar áramos [^n]dar -! SFX W r éramos alir -! SFX W r éramos ernir -! SFX W r éramos eunir -! SFX W r éramos ohibir -! SFX W er iéramos [^fh]acer -! SFX W er iéramos aler -! SFX W er iéramos e[cd]er -! SFX W er iéramos ender -! SFX W er iéramos er[dnt]er -! SFX W er iéramos o[clv]er -! SFX W er iéramos olver -! SFX W er iéramos or[cd]er -! SFX W eír iéramos eír -! SFX W ebir ibiéramos ebir -! SFX W acer iciéramos [fh]acer -! SFX W edir idiéramos edir -! SFX W endir indiéramos endir -! SFX W oder udiéramos oder -! SFX W egir igiéramos egir -! SFX W enchir inchiéramos enchir -! SFX W emir imiéramos emir -! SFX W ormir urmiéramos ormir -! SFX W enir iniéramos enir -! SFX W aber upiéramos aber -! SFX W erir iriéramos erir -! SFX W irir iriéramos irir -! SFX W orir uriéramos orir -! SFX W erer isiéramos erer -! SFX W oner usiéramos oner -! SFX W etir itiéramos etir -! SFX W entir intiéramos entir -! SFX W ertir irtiéramos ertir -! SFX W estir istiéramos estir -! SFX W eguir iguiéramos eguir -! SFX W ervir irviéramos ervir -! SFX W ar uviéramos andar -! SFX W ener uviéramos ener -! SFX W cir jéramos ucir -! SFX W er jéramos raer -! SFX W ecir ijéramos ecir -! SFX W er yéramos [eo]er -! SFX W er yéramos caer -! SFX W ir yéramos [^g]uir -! SFX W ír yéramos oír -! SFX W üir uyéramos güir -! SFX W eñir iñéramos eñir -! SFX W etir itamos etir -! SFX W entir intamos entir -! SFX W ertir irtamos ertir -! SFX W estir istamos estir -! SFX W ervir irvamos ervir -! SFX W er yamos oer -! SFX W ir yamos [^g]uir -! SFX W üir uyamos güir -! SFX W cer zamos cocer -! SFX W cer zamos orcer -! SFX W 0 íamos [^fh]acer -! SFX W 0 íamos [aeo]er -! SFX W 0 íamos [io]rir -! SFX W 0 íamos [üu]ir -! SFX W 0 íamos ar -! SFX W 0 íamos e[bdgmrtñ]ir -! SFX W 0 íamos e[cd]er -! SFX W 0 íamos e[ns]tir -! SFX W 0 íamos enchir -! SFX W 0 íamos ender -! SFX W 0 íamos endir -! SFX W 0 íamos er[dnt]er -! SFX W 0 íamos er[ntv]ir -! SFX W 0 íamos eunir -! SFX W 0 íamos o[clv]er -! SFX W 0 íamos olver -! SFX W 0 íamos or[cd]er -! SFX W 0 íamos ormir -! SFX W 0 íamos ucir -! SFX W er íamos er -! SFX W ir íamos ir -! SFX W ír íamos ír -! SFX W cer ríamos [fh]acer -! SFX W er ríamos aber -! SFX W er ríamos erer -! SFX W er ríamos oder -! SFX W er dríamos [eo]ner -! SFX W er dríamos aler -! SFX W ir dríamos alir -! SFX W ir dríamos enir -! SFX W ecir iríamos ecir -! SFX W ír iríamos [eo]ír -! SFX W eñir iñamos eñir -! SFX W 0 emos [^fh]acer -! SFX W 0 emos [aeo]er -! SFX W 0 emos [io]rir -! SFX W 0 emos [üu]ir -! SFX W 0 emos ar -! SFX W 0 emos e[bdgmrtñ]ir -! SFX W 0 emos e[cd]er -! SFX W 0 emos e[ns]tir -! SFX W 0 emos enchir -! SFX W 0 emos ender -! SFX W 0 emos endir -! SFX W 0 emos er[dnt]er -! SFX W 0 emos er[ntv]ir -! SFX W 0 emos eunir -! SFX W 0 emos o[clv]er -! SFX W 0 emos olver -! SFX W 0 emos or[cd]er -! SFX W 0 emos ormir -! SFX W 0 emos ucir -! SFX W ar emos [^g]uar -! SFX W ar emos [ae]hu[ms]ar -! SFX W ar emos [ae]ndar -! SFX W ar emos [aeo]hi[jlnt]ar -! SFX W ar emos ebrar -! SFX W ar emos edrar -! SFX W ar emos elar -! SFX W ar emos emblar -! SFX W ar emos embrar -! SFX W ar emos endrar -! SFX W ar emos ensar -! SFX W ar emos entar -! SFX W ar emos erbar -! SFX W ar emos ernar -! SFX W ar emos errar -! SFX W ar emos ertar -! SFX W ar emos esar -! SFX W ar emos estar -! SFX W ar emos etar -! SFX W ar emos evar -! SFX W ar emos obar -! SFX W ar emos oblar -! SFX W ar emos odar -! SFX W ar emos olar -! SFX W ar emos oldar -! SFX W ar emos ollar -! SFX W ar emos oltar -! SFX W ar emos onar -! SFX W ar emos ontar -! SFX W ar emos ontrar -! SFX W ar emos orar -! SFX W ar emos ordar -! SFX W ar emos ornar -! SFX W ar emos ortar -! SFX W ar emos osar -! SFX W ar emos ostar -! SFX W ar emos ostrar -! SFX W ar emos ovar -! SFX W ar emos oñar -! SFX W zar cemos [ae]izar -! SFX W zar cemos enzar -! SFX W zar cemos ezar -! SFX W zar cemos gonzar -! SFX W zar cemos orzar -! SFX W iar iemos iar -! SFX W cer remos [fh]acer -! SFX W er remos aber -! SFX W er remos erer -! SFX W er remos oder -! SFX W er dremos [eo]ner -! SFX W er dremos aler -! SFX W ir dremos alir -! SFX W ir dremos enir -! SFX W ecir iremos ecir -! SFX W ír iremos [eo]ír -! SFX W ar áremos [^a]ndar -! SFX W ar áremos [^d]ar -! SFX W ar áremos [^n]dar -! SFX W r éremos alir -! SFX W r éremos ernir -! SFX W r éremos eunir -! SFX W r éremos ohibir -! SFX W er iéremos [^fh]acer -! SFX W er iéremos aler -! SFX W er iéremos e[cd]er -! SFX W er iéremos ender -! SFX W er iéremos er[dnt]er -! SFX W er iéremos o[clv]er -! SFX W er iéremos olver -! SFX W er iéremos or[cd]er -! SFX W eír iéremos eír -! SFX W ebir ibiéremos ebir -! SFX W acer iciéremos [fh]acer -! SFX W edir idiéremos edir -! SFX W endir indiéremos endir -! SFX W oder udiéremos oder -! SFX W egir igiéremos egir -! SFX W enchir inchiéremos enchir -! SFX W emir imiéremos emir -! SFX W ormir urmiéremos ormir -! SFX W enir iniéremos enir -! SFX W aber upiéremos aber -! SFX W erir iriéremos erir -! SFX W irir iriéremos irir -! SFX W orir uriéremos orir -! SFX W erer isiéremos erer -! SFX W oner usiéremos oner -! SFX W etir itiéremos etir -! SFX W entir intiéremos entir -! SFX W ertir irtiéremos ertir -! SFX W estir istiéremos estir -! SFX W eguir iguiéremos eguir -! SFX W ervir irviéremos ervir -! SFX W ar uviéremos andar -! SFX W ener uviéremos ener -! SFX W cir jéremos ucir -! SFX W er jéremos raer -! SFX W ecir ijéremos ecir -! SFX W er yéremos [eo]er -! SFX W er yéremos caer -! SFX W ir yéremos [^g]uir -! SFX W ír yéremos oír -! SFX W üir uyéremos güir -! SFX W eñir iñéremos eñir -! SFX W ar ásemos [^d]ar -! SFX W ar ásemos [^n]dar -! SFX W r ásemos [^a]ndar -! SFX W r ésemos alir -! SFX W r ésemos ernir -! SFX W r ésemos eunir -! SFX W r ésemos ohibir -! SFX W er iésemos [^fh]acer -! SFX W er iésemos aler -! SFX W er iésemos e[cd]er -! SFX W er iésemos ender -! SFX W er iésemos er[dnt]er -! SFX W er iésemos o[clv]er -! SFX W er iésemos olver -! SFX W er iésemos or[cd]er -! SFX W eír iésemos eír -! SFX W ebir ibiésemos ebir -! SFX W acer iciésemos [fh]acer -! SFX W edir idiésemos edir -! SFX W endir indiésemos endir -! SFX W oder udiésemos oder -! SFX W egir igiésemos egir -! SFX W enchir inchiésemos enchir -! SFX W emir imiésemos emir -! SFX W ormir urmiésemos ormir -! SFX W enir iniésemos enir -! SFX W aber upiésemos aber -! SFX W erir iriésemos erir -! SFX W irir iriésemos irir -! SFX W orir uriésemos orir -! SFX W erer isiésemos erer -! SFX W oner usiésemos oner -! SFX W etir itiésemos etir -! SFX W entir intiésemos entir -! SFX W ertir irtiésemos ertir -! SFX W estir istiésemos estir -! SFX W eguir iguiésemos eguir -! SFX W ervir irviésemos ervir -! SFX W ar uviésemos andar -! SFX W ener uviésemos ener -! SFX W cir jésemos ucir -! SFX W er jésemos raer -! SFX W ecir ijésemos ecir -! SFX W er yésemos [eo]er -! SFX W er yésemos caer -! SFX W ir yésemos [^g]uir -! SFX W ír yésemos oír -! SFX W üir uyésemos güir -! SFX W eñir iñésemos eñir -! SFX W ar uemos olgar -! SFX W gar guemos egar -! SFX W gar guemos engar -! SFX W gar guemos ogar -! SFX W gar guemos ugar -! SFX W car quemos ocar -! SFX W car quemos olcar -! SFX W car quemos orcar -! SFX W uar üemos guar -! SFX W er imos [^fh]acer -! SFX W er imos aler -! SFX W er imos e[cd]er -! SFX W er imos ender -! SFX W er imos er[dnt]er -! SFX W er imos o[clv]er -! SFX W er imos olver -! SFX W er imos or[cd]er -! SFX W acer icimos [fh]acer -! SFX W oder udimos oder -! SFX W cir jimos ucir -! SFX W er jimos raer -! SFX W ecir ijimos ecir -! SFX W enir inimos enir -! SFX W aber upimos aber -! SFX W erer isimos erer -! SFX W oner usimos oner -! SFX W ar uvimos andar -! SFX W ener uvimos ener -! SFX W er ímos [eo]er -! SFX W er ímos caer -! -! -! -! SFX W Y 29 S -! SFX W 0 ás [^fh]acer -! SFX W 0 ás [aeo]er -! SFX W 0 ás [io]rir -! SFX W 0 ás [üu]ir -! SFX W 0 ás ar -! SFX W 0 ás e[bdgmrtñ]ir -! SFX W 0 ás e[cd]er -! SFX W 0 ás e[ns]tir -! SFX W 0 ás enchir -! SFX W 0 ás ender -! SFX W 0 ás endir -! SFX W 0 ás er[dnt]er -! SFX W 0 ás er[ntv]ir -! SFX W 0 ás eunir -! SFX W 0 ás o[clv]er -! SFX W 0 ás olver -! SFX W 0 ás or[cd]er -! SFX W 0 ás ormir -! SFX W 0 ás ucir -! SFX W cer rás [fh]acer -! SFX W er rás aber -! SFX W er rás erer -! SFX W er rás oder -! SFX W er drás [eo]ner -! SFX W er drás aler -! SFX W ir drás alir -! SFX W ir drás enir -! SFX W ecir irás ecir -! SFX W ír irás [eo]ír -! -! -! SFX W Y 29 S -! SFX W 0 á [^fh]acer -! SFX W 0 á [aeo]er -! SFX W 0 á [io]rir -! SFX W 0 á [üu]ir -! SFX W 0 á ar -! SFX W 0 á e[bdgmrtñ]ir -! SFX W 0 á e[cd]er -! SFX W 0 á e[ns]tir -! SFX W 0 á enchir -! SFX W 0 á ender -! SFX W 0 á endir -! SFX W 0 á er[dnt]er -! SFX W 0 á er[ntv]ir -! SFX W 0 á eunir -! SFX W 0 á o[clv]er -! SFX W 0 á olver -! SFX W 0 á or[cd]er -! SFX W 0 á ormir -! SFX W 0 á ucir -! SFX W cer rá [fh]acer -! SFX W er rá aber -! SFX W er rá erer -! SFX W er rá oder -! SFX W er drá [eo]ner -! SFX W er drá aler -! SFX W ir drá alir -! SFX W ir drá enir -! SFX W ecir irá ecir -! SFX W ír irá [eo]ír -! -! -! -! SFX W Y 38 S -! SFX W 0 é [^fh]acer -! SFX W 0 é [aeo]er -! SFX W 0 é [io]rir -! SFX W 0 é [üu]ir -! SFX W 0 é ar -! SFX W 0 é e[bdgmrtñ]ir -! SFX W 0 é e[cd]er -! SFX W 0 é e[ns]tir -! SFX W 0 é enchir -! SFX W 0 é ender -! SFX W 0 é endir -! SFX W 0 é er[dnt]er -! SFX W 0 é er[ntv]ir -! SFX W 0 é eunir -! SFX W 0 é o[clv]er -! SFX W 0 é olver -! SFX W 0 é or[cd]er -! SFX W 0 é ormir -! SFX W 0 é ucir -! SFX W aber é saber -! SFX W ar é [^a]ndar -! SFX W ar é [^cguzd]ar -! SFX W ar é [^g]uar -! SFX W ar é [^n]dar -! SFX W zar cé zar -! SFX W cer ré [fh]acer -! SFX W er ré aber -! SFX W er ré erer -! SFX W er ré oder -! SFX W er dré [eo]ner -! SFX W er dré aler -! SFX W ir dré alir -! SFX W ir dré enir -! SFX W ecir iré ecir -! SFX W ír iré [eo]ír -! SFX W ar ué gar -! SFX W car qué car -! SFX W uar üé guar -! -! -! SFX W Y 31 S -! SFX W er í [^fh]acer -! SFX W er í [eo]er -! SFX W er í aler -! SFX W er í caer -! SFX W er í e[cd]er -! SFX W er í ender -! SFX W er í er[dnt]er -! SFX W er í o[clv]er -! SFX W er í olver -! SFX W er í or[cd]er -! SFX W ir í [üu]ir -! SFX W ir í alir -! SFX W ir í ebir -! SFX W ir í edir -! SFX W ir í egir -! SFX W ir í emir -! SFX W ir í enchir -! SFX W ir í endir -! SFX W ir í entir -! SFX W ir í erir -! SFX W ir í ernir -! SFX W ir í ertir -! SFX W ir í ervir -! SFX W ir í estir -! SFX W ir í etir -! SFX W ir í eunir -! SFX W ir í eñir -! SFX W ir í irir -! SFX W ir í orir -! SFX W ir í ormir -! SFX W ír í [eo]ír -! -! -! -! SFX W Y 39 S -! SFX W ar ó [^a]ndar -! SFX W ar ó [^d]ar -! SFX W ar ó [^n]dar -! SFX W r ó alir -! SFX W r ó ernir -! SFX W r ó eunir -! SFX W r ó irir -! SFX W r ó ohibir -! SFX W er ió [^fh]acer -! SFX W er ió aler -! SFX W er ió e[cd]er -! SFX W er ió ender -! SFX W er ió er[dnt]er -! SFX W er ió o[clv]er -! SFX W er ió olver -! SFX W er ió or[cd]er -! SFX W er ió order -! SFX W eír ió eír -! SFX W ebir ibió ebir -! SFX W edir idió edir -! SFX W endir indió endir -! SFX W egir igió egir -! SFX W enchir inchió enchir -! SFX W emir imió emir -! SFX W ormir urmió ormir -! SFX W erir irió erir -! SFX W orir urió orir -! SFX W etir itió etir -! SFX W entir intió entir -! SFX W ertir irtió ertir -! SFX W estir istió estir -! SFX W eguir iguió eguir -! SFX W ervir irvió ervir -! SFX W er yó [eo]er -! SFX W er yó caer -! SFX W ir yó [^g]uir -! SFX W ír yó oír -! SFX W üir uyó güir -! SFX W eñir iñó eñir -! -! -! -! SFX W Y 21 -! SFX W r d [aeií]r -! SFX W r n [^c]ocer -! SFX W r n [cr]aer -! SFX W r n [eo]er -! SFX W r n a[bcl]er -! SFX W r n andar -! SFX W r n ecer -! SFX W r n guar -! SFX W r n oner -! SFX W r s [^c]ocer -! SFX W r s [cr]aer -! SFX W r s [eo]er -! SFX W r s a[bcl]er -! SFX W r s andar -! SFX W r s ecer -! SFX W r s guar -! SFX W r s oner -! SFX W r bais ar -! SFX W ir ís ir -! SFX W ír ís ír -! SFX W cer z [fh]acer -! -! SFX Y Y 102 -! SFX Y er ído [aeo]er -! SFX Y er ídos [aeo]er -! SFX Y er ída [aeo]er -! SFX Y er ídas [aeo]er -! SFX Y acer echo [fh]acer -! SFX Y acer echos [fh]acer -! SFX Y acer echa [fh]acer -! SFX Y acer echas [fh]acer -! SFX Y er ido oder -! SFX Y er idos oder -! SFX Y er ida oder -! SFX Y er idas oder -! SFX Y olver uelto olver -! SFX Y olver ueltos olver -! SFX Y olver uelta olver -! SFX Y olver ueltas olver -! SFX Y oner uesto oner -! SFX Y oner uestos oner -! SFX Y oner uesta oner -! SFX Y oner uestas oner -! SFX Y rir ierto abrir -! SFX Y rir iertos abrir -! SFX Y rir ierta abrir -! SFX Y rir iertas abrir -! SFX Y r do e[bdgmnrtñ]ir -! SFX Y r dos e[bdgmnrtñ]ir -! SFX Y r da e[bdgmnrtñ]ir -! SFX Y r das e[bdgmnrtñ]ir -! SFX Y ecir icho ecir -! SFX Y ecir ichos ecir -! SFX Y ecir icha ecir -! SFX Y ecir ichas ecir -! SFX Y r do [eo]ír -! SFX Y r dos [eo]ír -! SFX Y r da [eo]ír -! SFX Y r das [eo]ír -! SFX Y r do enchir -! SFX Y r dos enchir -! SFX Y r da enchir -! SFX Y r das enchir -! SFX Y r do en[dt]ir -! SFX Y r dos en[dt]ir -! SFX Y r da en[dt]ir -! SFX Y r das en[dt]ir -! SFX Y r do er[tv]ir -! SFX Y r dos er[tv]ir -! SFX Y r da er[tv]ir -! SFX Y r das er[tv]ir -! SFX Y r do estir -! SFX Y r dos estir -! SFX Y r da estir -! SFX Y r das estir -! SFX Y bir to ibir -! SFX Y bir tos ibir -! SFX Y bir ta ibir -! SFX Y bir tas ibir -! SFX Y orir uerto orir -! SFX Y orir uertos orir -! SFX Y orir uerta orir -! SFX Y orir uertas orir -! SFX Y r do ormir -! SFX Y r dos ormir -! SFX Y r da ormir -! SFX Y r das ormir -! SFX Y rir ierto ubrir -! SFX Y rir iertos ubrir -! SFX Y rir ierta ubrir -! SFX Y rir iertas ubrir -! SFX Y r do [üu]ir -! SFX Y r da [üu]ir -! SFX Y r dos [üu]ir -! SFX Y r das [üu]ir -! SFX Y er iendo [fh]acer -! SFX Y er yendo [aeo]er -! SFX Y oder udiendo oder -! SFX Y er iendo olver -! SFX Y er iendo oner -! SFX Y r endo abrir -! SFX Y ebir ibiendo ebir -! SFX Y ecir iciendo ecir -! SFX Y edir idiendo edir -! SFX Y egir igiendo egir -! SFX Y emir imiendo emir -! SFX Y eír iendo eír -! SFX Y eñir iñendo eñir -! SFX Y enchir inchiendo enchir -! SFX Y endir indiendo endir -! SFX Y enir iniendo enir -! SFX Y entir intiendo entir -! SFX Y ertir irtiendo ertir -! SFX Y ervir irviendo ervir -! SFX Y estir istiendo estir -! SFX Y eguir iguiendo eguir -! SFX Y erir iriendo erir -! SFX Y etir itiendo etir -! SFX Y r endo ibir -! SFX Y ír yendo oír -! SFX Y orir uriendo orir -! SFX Y ormir urmiendo ormir -! SFX Y r endo ubrir -! SFX Y ir yendo [^g]uir -! SFX Y üir uyendo güir -! -! SFX O Y 115 -! SFX O 0 me [eií]r -! SFX O 0 te [eií]r -! SFX O 0 se [eií]r -! SFX O 0 nos [eií]r -! SFX O 0 os [eií]r -! SFX O er yéndome [aeo]er -! SFX O er yéndote [aeo]er -! SFX O er yéndose [aeo]er -! SFX O er yéndonos [aeo]er -! SFX O er yéndoos [aeo]er -! SFX O oder udiéndome oder -! SFX O oder udiéndote oder -! SFX O oder udiéndose oder -! SFX O oder udiéndonos oder -! SFX O oder udiéndoos oder -! SFX O ebir ibiéndome ebir -! SFX O ebir ibiéndote ebir -! SFX O ebir ibiéndose ebir -! SFX O ebir ibiéndonos ebir -! SFX O ebir ibiéndoos ebir -! SFX O ecir iciéndome ecir -! SFX O ecir iciéndote ecir -! SFX O ecir iciéndose ecir -! SFX O ecir iciéndonos ecir -! SFX O ecir iciéndoos ecir -! SFX O edir idiéndome edir -! SFX O edir idiéndote edir -! SFX O edir idiéndose edir -! SFX O edir idiéndonos edir -! SFX O edir idiéndoos edir -! SFX O egir igiéndome egir -! SFX O egir igiéndote egir -! SFX O egir igiéndose egir -! SFX O egir igiéndonos egir -! SFX O egir igiéndoos egir -! SFX O emir imiéndome emir -! SFX O emir imiéndote emir -! SFX O emir imiéndose emir -! SFX O emir imiéndonos emir -! SFX O emir imiéndoos emir -! SFX O eír iéndome eír -! SFX O eír iéndote eír -! SFX O eír iéndose eír -! SFX O eír iéndonos eír -! SFX O eír iéndoos eír -! SFX O eñir iñéndome eñir -! SFX O eñir iñéndote eñir -! SFX O eñir iñéndose eñir -! SFX O eñir iñéndonos eñir -! SFX O eñir iñéndoos eñir -! SFX O endir indiéndome endir -! SFX O endir indiéndote endir -! SFX O endir indiéndose endir -! SFX O endir indiéndonos endir -! SFX O endir indiéndoos endir -! SFX O enir iniéndome enir -! SFX O enir iniéndote enir -! SFX O enir iniéndose enir -! SFX O enir iniéndonos enir -! SFX O enir iniéndoos enir -! SFX O entir intiéndome entir -! SFX O entir intiéndote entir -! SFX O entir intiéndose entir -! SFX O entir intiéndonos entir -! SFX O entir intiéndoos entir -! SFX O ertir irtiéndome ertir -! SFX O ertir irtiéndote ertir -! SFX O ertir irtiéndose ertir -! SFX O ertir irtiéndonos ertir -! SFX O ertir irtiéndoos ertir -! SFX O ervir irviéndome ervir -! SFX O ervir irviéndote ervir -! SFX O ervir irviéndose ervir -! SFX O ervir irviéndonos ervir -! SFX O ervir irviéndoos ervir -! SFX O estir istiéndome estir -! SFX O estir istiéndote estir -! SFX O estir istiéndose estir -! SFX O estir istiéndonos estir -! SFX O estir istiéndoos estir -! SFX O eguir iguiéndome eguir -! SFX O eguir iguiéndote eguir -! SFX O eguir iguiéndose eguir -! SFX O eguir iguiéndonos eguir -! SFX O eguir iguiéndoos eguir -! SFX O erir iriéndome erir -! SFX O erir iriéndote erir -! SFX O erir iriéndose erir -! SFX O erir iriéndonos erir -! SFX O erir iriéndoos erir -! SFX O etir itiéndome etir -! SFX O etir itiéndote etir -! SFX O etir itiéndose etir -! SFX O etir itiéndonos etir -! SFX O etir itiéndoos etir -! SFX O ír yéndome oír -! SFX O ír yéndote oír -! SFX O ír yéndose oír -! SFX O ír yéndonos oír -! SFX O ír yéndoos oír -! SFX O orir uriéndome orir -! SFX O orir uriéndote orir -! SFX O orir uriéndose orir -! SFX O orir uriéndonos orir -! SFX O orir uriéndoos orir -! SFX O ormir urmiéndome ormir -! SFX O ormir urmiéndote ormir -! SFX O ormir urmiéndose ormir -! SFX O ormir urmiéndonos ormir -! SFX O ormir urmiéndoos ormir -! SFX O ir yéndome [^g]uir -! SFX O ir yéndote [^g]uir -! SFX O ir yéndose [^g]uir -! SFX O ir yéndonos [^g]uir -! SFX O ir yéndoos [^g]uir -! -! SFX Q Y 138 -! SFX Q 0 lo [eií]r -! SFX Q 0 la [eií]r -! SFX Q 0 los [eií]r -! SFX Q 0 las [eií]r -! SFX Q 0 le [eií]r -! SFX Q 0 les [eií]r -! SFX Q er yéndolo [aeo]er -! SFX Q er yéndola [aeo]er -! SFX Q er yéndolos [aeo]er -! SFX Q er yéndolas [aeo]er -! SFX Q er yéndole [aeo]er -! SFX Q er yéndoles [aeo]er -! SFX Q oder udiéndolo oder -! SFX Q oder udiéndola oder -! SFX Q oder udiéndolos oder -! SFX Q oder udiéndolas oder -! SFX Q oder udiéndole oder -! SFX Q oder udiéndoles oder -! SFX Q ebir ibiéndolo ebir -! SFX Q ebir ibiéndolos ebir -! SFX Q ebir ibiéndola ebir -! SFX Q ebir ibiéndolas ebir -! SFX Q ebir ibiéndole ebir -! SFX Q ebir ibiéndoles ebir -! SFX Q ecir iciéndolo ecir -! SFX Q ecir iciéndolos ecir -! SFX Q ecir iciéndola ecir -! SFX Q ecir iciéndolas ecir -! SFX Q ecir iciéndole ecir -! SFX Q ecir iciéndoles ecir -! SFX Q edir idiéndolo edir -! SFX Q edir idiéndolos edir -! SFX Q edir idiéndola edir -! SFX Q edir idiéndolas edir -! SFX Q edir idiéndole edir -! SFX Q edir idiéndoles edir -! SFX Q egir igiéndolo egir -! SFX Q egir igiéndolos egir -! SFX Q egir igiéndola egir -! SFX Q egir igiéndolas egir -! SFX Q egir igiéndole egir -! SFX Q egir igiéndoles egir -! SFX Q emir imiéndolo emir -! SFX Q emir imiéndolos emir -! SFX Q emir imiéndola emir -! SFX Q emir imiéndolas emir -! SFX Q emir imiéndole emir -! SFX Q emir imiéndoles emir -! SFX Q eír iéndolo eír -! SFX Q eír iéndolos eír -! SFX Q eír iéndola eír -! SFX Q eír iéndolas eír -! SFX Q eír iéndole eír -! SFX Q eír iéndoles eír -! SFX Q eñir iñéndolo eñir -! SFX Q eñir iñéndolos eñir -! SFX Q eñir iñéndola eñir -! SFX Q eñir iñéndolas eñir -! SFX Q eñir iñéndole eñir -! SFX Q eñir iñéndoles eñir -! SFX Q endir indiéndolo endir -! SFX Q endir indiéndolos endir -! SFX Q endir indiéndola endir -! SFX Q endir indiéndolas endir -! SFX Q endir indiéndole endir -! SFX Q endir indiéndoles endir -! SFX Q enir iniéndolo enir -! SFX Q enir iniéndolos enir -! SFX Q enir iniéndola enir -! SFX Q enir iniéndolas enir -! SFX Q enir iniéndole enir -! SFX Q enir iniéndoles enir -! SFX Q entir intiéndolo entir -! SFX Q entir intiéndolos entir -! SFX Q entir intiéndola entir -! SFX Q entir intiéndolas entir -! SFX Q entir intiéndole entir -! SFX Q entir intiéndoles entir -! SFX Q ertir irtiéndolo ertir -! SFX Q ertir irtiéndolos ertir -! SFX Q ertir irtiéndola ertir -! SFX Q ertir irtiéndolas ertir -! SFX Q ertir irtiéndole ertir -! SFX Q ertir irtiéndoles ertir -! SFX Q ervir irviéndolo ervir -! SFX Q ervir irviéndolos ervir -! SFX Q ervir irviéndola ervir -! SFX Q ervir irviéndolas ervir -! SFX Q ervir irviéndole ervir -! SFX Q ervir irviéndoles ervir -! SFX Q estir istiéndolo estir -! SFX Q estir istiéndolos estir -! SFX Q estir istiéndola estir -! SFX Q estir istiéndolas estir -! SFX Q estir istiéndole estir -! SFX Q estir istiéndoles estir -! SFX Q eguir iguiéndolo eguir -! SFX Q eguir iguiéndolos eguir -! SFX Q eguir iguiéndola eguir -! SFX Q eguir iguiéndolas eguir -! SFX Q eguir iguiéndole eguir -! SFX Q eguir iguiéndoles eguir -! SFX Q erir iriéndolo erir -! SFX Q erir iriéndolos erir -! SFX Q erir iriéndola erir -! SFX Q erir iriéndolas erir -! SFX Q erir iriéndole erir -! SFX Q erir iriéndoles erir -! SFX Q etir itiéndolo etir -! SFX Q etir itiéndolos etir -! SFX Q etir itiéndola etir -! SFX Q etir itiéndolas etir -! SFX Q etir itiéndole etir -! SFX Q etir itiéndoles etir -! SFX Q ír yéndolo oír -! SFX Q ír yéndolos oír -! SFX Q ír yéndola oír -! SFX Q ír yéndolas oír -! SFX Q ír yéndole oír -! SFX Q ír yéndoles oír -! SFX Q orir uriéndolo orir -! SFX Q orir uriéndolos orir -! SFX Q orir uriéndola orir -! SFX Q orir uriéndolas orir -! SFX Q orir uriéndole orir -! SFX Q orir uriéndoles orir -! SFX Q ormir urmiéndolo ormir -! SFX Q ormir urmiéndolos ormir -! SFX Q ormir urmiéndola ormir -! SFX Q ormir urmiéndolas ormir -! SFX Q ormir urmiéndole ormir -! SFX Q ormir urmiéndoles ormir -! SFX Q ir yéndolo [^g]uir -! SFX Q ir yéndolos [^g]uir -! SFX Q ir yéndola [^g]uir -! SFX Q ir yéndolas [^g]uir -! SFX Q ir yéndole [^g]uir -! SFX Q ir yéndoles [^g]uir -! -! SFX Z Y 171 -! SFX Z er érmelo er -! SFX Z er érmela er -! SFX Z er érmelos er -! SFX Z er érmelas er -! SFX Z er értelo er -! SFX Z er értela er -! SFX Z er értelos er -! SFX Z er értelas er -! SFX Z er érselo er -! SFX Z er érsela er -! SFX Z er érselos er -! SFX Z er érselas er -! SFX Z er éroslo er -! SFX Z er érosla er -! SFX Z er éroslos er -! SFX Z er éroslas er -! SFX Z er érnoslo er -! SFX Z er érnosla er -! SFX Z er érnoslos er -! SFX Z er érnoslas er -! SFX Z er érnosles er -! SFX Z ir írmelo ir -! SFX Z ir írmela ir -! SFX Z ir írmele ir -! SFX Z ir írmelos ir -! SFX Z ir írmelas ir -! SFX Z ir írmeles ir -! SFX Z ir írtelo ir -! SFX Z ir írtela ir -! SFX Z ir írtele ir -! SFX Z ir írtelos ir -! SFX Z ir írtelas ir -! SFX Z ir írteles ir -! SFX Z ir írselo ir -! SFX Z ir írsela ir -! SFX Z ir írsele ir -! SFX Z ir írselos ir -! SFX Z ir írselas ir -! SFX Z ir írseles ir -! SFX Z ir íroslo ir -! SFX Z ir írosla ir -! SFX Z ir írosle ir -! SFX Z ir íroslos ir -! SFX Z ir íroslas ir -! SFX Z ir írosles ir -! SFX Z ir írnoslo ir -! SFX Z ir írnosla ir -! SFX Z ir írnosle ir -! SFX Z ir írnoslos ir -! SFX Z ir írnoslas ir -! SFX Z ir írnosles ir -! SFX Z er yéndomelo [aeo]er -! SFX Z er yéndomela [aeo]er -! SFX Z er yéndomele [aeo]er -! SFX Z er yéndomelos [aeo]er -! SFX Z er yéndomelas [aeo]er -! SFX Z er yéndomeles [aeo]er -! SFX Z er yéndotelo [aeo]er -! SFX Z er yéndotela [aeo]er -! SFX Z er yéndotele [aeo]er -! SFX Z er yéndotelos [aeo]er -! SFX Z er yéndotelas [aeo]er -! SFX Z er yéndoteles [aeo]er -! SFX Z er yéndoselo [aeo]er -! SFX Z er yéndosela [aeo]er -! SFX Z er yéndosele [aeo]er -! SFX Z er yéndoselos [aeo]er -! SFX Z er yéndoselas [aeo]er -! SFX Z er yéndoseles [aeo]er -! SFX Z er yéndooslo [aeo]er -! SFX Z er yéndoosla [aeo]er -! SFX Z er yéndoosle [aeo]er -! SFX Z er yéndooslos [aeo]er -! SFX Z er yéndooslas [aeo]er -! SFX Z er yéndoosles [aeo]er -! SFX Z er yéndonoslo [aeo]er -! SFX Z er yéndonosla [aeo]er -! SFX Z er yéndonosle [aeo]er -! SFX Z er yéndonoslos [aeo]er -! SFX Z er yéndonoslas [aeo]er -! SFX Z er yéndonosles [aeo]er -! SFX Z ir yéndomelo [^g]uir -! SFX Z ir yéndomelos [^g]uir -! SFX Z ir yéndomela [^g]uir -! SFX Z ir yéndomelas [^g]uir -! SFX Z ir yéndomele [^g]uir -! SFX Z ir yéndomeles [^g]uir -! SFX Z ir yéndotelo [^g]uir -! SFX Z ir yéndotelos [^g]uir -! SFX Z ir yéndotela [^g]uir -! SFX Z ir yéndotelas [^g]uir -! SFX Z ir yéndotele [^g]uir -! SFX Z ir yéndoteles [^g]uir -! SFX Z ir yéndoselo [^g]uir -! SFX Z ir yéndoselos [^g]uir -! SFX Z ir yéndosela [^g]uir -! SFX Z ir yéndoselas [^g]uir -! SFX Z ir yéndosele [^g]uir -! SFX Z ir yéndoseles [^g]uir -! SFX Z ir yéndooslo [^g]uir -! SFX Z ir yéndooslos [^g]uir -! SFX Z ir yéndoosla [^g]uir -! SFX Z ir yéndooslas [^g]uir -! SFX Z ir yéndoosle [^g]uir -! SFX Z ir yéndoosles [^g]uir -! SFX Z ir yéndonoslo [^g]uir -! SFX Z ir yéndonoslos [^g]uir -! SFX Z ir yéndonosla [^g]uir -! SFX Z ir yéndonoslas [^g]uir -! SFX Z ir yéndonosle [^g]uir -! SFX Z ir yéndonosles [^g]uir -! SFX Z egir igiéndomelo egir -! SFX Z egir igiéndomelos egir -! SFX Z egir igiéndomela egir -! SFX Z egir igiéndomelas egir -! SFX Z egir igiéndomele egir -! SFX Z egir igiéndomeles egir -! SFX Z egir igiéndotelo egir -! SFX Z egir igiéndotelos egir -! SFX Z egir igiéndotela egir -! SFX Z egir igiéndotelas egir -! SFX Z egir igiéndotele egir -! SFX Z egir igiéndoteles egir -! SFX Z egir igiéndoselo egir -! SFX Z egir igiéndoselos egir -! SFX Z egir igiéndosela egir -! SFX Z egir igiéndoselas egir -! SFX Z egir igiéndosele egir -! SFX Z egir igiéndoseles egir -! SFX Z egir igiéndooslo egir -! SFX Z egir igiéndooslos egir -! SFX Z egir igiéndoosla egir -! SFX Z egir igiéndooslas egir -! SFX Z egir igiéndoosle egir -! SFX Z egir igiéndoosles egir -! SFX Z egir igiéndonoslo egir -! SFX Z egir igiéndonoslos egir -! SFX Z egir igiéndonosla egir -! SFX Z egir igiéndonoslas egir -! SFX Z egir igiéndonosle egir -! SFX Z egir igiéndonosles egir -! SFX Z eguir iguiéndomelo eguir -! SFX Z eguir iguiéndomelos eguir -! SFX Z eguir iguiéndomela eguir -! SFX Z eguir iguiéndomelas eguir -! SFX Z eguir iguiéndomele eguir -! SFX Z eguir iguiéndomeles eguir -! SFX Z eguir iguiéndotelo eguir -! SFX Z eguir iguiéndotelos eguir -! SFX Z eguir iguiéndotela eguir -! SFX Z eguir iguiéndotelas eguir -! SFX Z eguir iguiéndotele eguir -! SFX Z eguir iguiéndoteles eguir -! SFX Z eguir iguiéndoselo eguir -! SFX Z eguir iguiéndoselos eguir -! SFX Z eguir iguiéndosela eguir -! SFX Z eguir iguiéndoselas eguir -! SFX Z eguir iguiéndosele eguir -! SFX Z eguir iguiéndoseles eguir -! SFX Z eguir iguiéndooslo eguir -! SFX Z eguir iguiéndooslos eguir -! SFX Z eguir iguiéndoosla eguir -! SFX Z eguir iguiéndooslas eguir -! SFX Z eguir iguiéndoosle eguir -! SFX Z eguir iguiéndoosles eguir -! SFX Z eguir iguiéndonoslo eguir -! SFX Z eguir iguiéndonoslos eguir -! SFX Z eguir iguiéndonosla eguir -! SFX Z eguir iguiéndonoslas eguir -! SFX Z eguir iguiéndonosle eguir -! SFX Z eguir iguiéndonosles eguir ---- 139,3509 ---- - SFX M 0 idades [elnrsz] -! SFX M 0 mente [elnrsz] -! -! SFX N Y 2 -! SFX N r damente [ai]r -! SFX N er idamente er -! -! SFX P Y 20 -! SFX P e a e -! SFX P o a o -! SFX P 0 s [eo] -! SFX P o as o -! SFX P e as e -! SFX P án ana án -! SFX P án anes án -! SFX P án anas án -! SFX P ín ina ín -! SFX P ín ines ín -! SFX P ín inas ín -! SFX P ón ona ón -! SFX P ón ones ón -! SFX P ón onas ón -! SFX P 0 a [^aons] -! SFX P 0 es [^aons] -! SFX P 0 as [^aons] -! SFX P és esa és -! SFX P és eses és -! SFX P és esas és -! -! SFX H Y 2 -! SFX H r ción [ai]r -! SFX H r ciones [ai]r -! -! SFX I Y 4 -! SFX I r miento [ai]r -! SFX I r mientos [ai]r -! SFX I er imiento er -! SFX I er imientos er -! -! SFX L Y 6 -! SFX L r nte ar -! SFX L r ntes ar -! SFX L er iente er -! SFX L er ientes er -! SFX L r ente ir -! SFX L r entes ir -! -! SFX R Y 20 -! SFX R 0 me [aei]r -! SFX R 0 te [aei]r -! SFX R 0 se [aei]r -! SFX R 0 nos [aei]r -! SFX R 0 os [aei]r -! SFX R ar ándome ar -! SFX R ar ándote ar -! SFX R ar ándose ar -! SFX R ar ándonos ar -! SFX R ar ándoos ar -! SFX R er iéndome er -! SFX R er iéndote er -! SFX R er iéndose er -! SFX R er iéndonos er -! SFX R er iéndoos er -! SFX R r éndome ir -! SFX R r éndote ir -! SFX R r éndose ir -! SFX R r éndonos ir -! SFX R r éndoos ir -! -! SFX S Y 11 -! SFX S 0 s [aeiouáéó] -! SFX S 0 es [úídjlry] -! SFX S z ces z -! SFX S 0 es [^é]s -! SFX S 0 es [^áéíóú]n -! SFX S án anes án -! SFX S én enes én -! SFX S ín ines ín -! SFX S ón ones ón -! SFX S ún unes ún -! SFX S és eses és -! -! SFX T Y 24 -! SFX T 0 lo [aei]r -! SFX T 0 la [aei]r -! SFX T 0 le [aei]r -! SFX T 0 los [aei]r -! SFX T 0 las [aei]r -! SFX T 0 les [aei]r -! SFX T ar ándolo ar -! SFX T ar ándola ar -! SFX T ar ándole ar -! SFX T ar ándolos ar -! SFX T ar ándolas ar -! SFX T ar ándoles ar -! SFX T er iéndolo er -! SFX T er iéndola er -! SFX T er iéndole er -! SFX T er iéndolos er -! SFX T er iéndolas er -! SFX T er iéndoles er -! SFX T r éndolo ir -! SFX T r éndola ir -! SFX T r éndole ir -! SFX T r éndolos ir -! SFX T r éndolas ir -! SFX T r éndoles ir -! -! SFX U Y 120 -! SFX U ar ármelo ar -! SFX U ar ártelo ar -! SFX U ar árselo ar -! SFX U ar árnoslo ar -! SFX U ar ároslo ar -! SFX U ar ármela ar -! SFX U ar ártela ar -! SFX U ar ársela ar -! SFX U ar árnosla ar -! SFX U ar árosla ar -! SFX U ar ármelos ar -! SFX U ar ártelos ar -! SFX U ar árselos ar -! SFX U ar árnoslos ar -! SFX U ar ároslos ar -! SFX U ar ármelas ar -! SFX U ar ártelas ar -! SFX U ar árselas ar -! SFX U ar árnoslas ar -! SFX U ar ároslas ar -! SFX U ar ándomelo ar -! SFX U ar ándotelo ar -! SFX U ar ándoselo ar -! SFX U ar ándonoslo ar -! SFX U ar ándooslo ar -! SFX U ar ándomela ar -! SFX U ar ándotela ar -! SFX U ar ándosela ar -! SFX U ar ándonosla ar -! SFX U ar ándoosla ar -! SFX U ar ándomelos ar -! SFX U ar ándotelos ar -! SFX U ar ándoselos ar -! SFX U ar ándonoslos ar -! SFX U ar ándooslos ar -! SFX U ar ándomelas ar -! SFX U ar ándotelas ar -! SFX U ar ándoselas ar -! SFX U ar ándonoslas ar -! SFX U ar ándooslas ar -! SFX U er érmelo er -! SFX U er értelo er -! SFX U er érselo er -! SFX U er érnoslo er -! SFX U er éroslo er -! SFX U er érmela er -! SFX U er értela er -! SFX U er érsela er -! SFX U er érnosla er -! SFX U er érosla er -! SFX U er érmelos er -! SFX U er értelos er -! SFX U er érselos er -! SFX U er érnoslos er -! SFX U er éroslos er -! SFX U er érmelas er -! SFX U er értelas er -! SFX U er érselas er -! SFX U er érnoslas er -! SFX U er éroslas er -! SFX U er iéndomelo er -! SFX U er iéndotelo er -! SFX U er iéndoselo er -! SFX U er iéndonoslo er -! SFX U er iéndooslo er -! SFX U er iéndomela er -! SFX U er iéndotela er -! SFX U er iéndosela er -! SFX U er iéndonosla er -! SFX U er iéndoosla er -! SFX U er iéndomelos er -! SFX U er iéndotelos er -! SFX U er iéndoselos er -! SFX U er iéndonoslos er -! SFX U er iéndooslos er -! SFX U er iéndomelas er -! SFX U er iéndotelas er -! SFX U er iéndoselas er -! SFX U er iéndonoslas er -! SFX U er iéndooslas er -! SFX U ir írmelo ir -! SFX U ir írtelo ir -! SFX U ir írselo ir -! SFX U ir írnoslo ir -! SFX U ir íroslo ir -! SFX U ir írmela ir -! SFX U ir írtela ir -! SFX U ir írsela ir -! SFX U ir írnosla ir -! SFX U ir írosla ir -! SFX U ir írmelas ir -! SFX U ir írtelas ir -! SFX U ir írselas ir -! SFX U ir írnoslas ir -! SFX U ir íroslas ir -! SFX U ir írmelos ir -! SFX U ir írtelos ir -! SFX U ir írselos ir -! SFX U ir írnoslos ir -! SFX U ir íroslos ir -! SFX U r éndomelo ir -! SFX U r éndotelo ir -! SFX U r éndoselo ir -! SFX U r éndonoslo ir -! SFX U r éndooslo ir -! SFX U r éndomela ir -! SFX U r éndotela ir -! SFX U r éndosela ir -! SFX U r éndonosla ir -! SFX U r éndoosla ir -! SFX U r éndomelos ir -! SFX U r éndotelos ir -! SFX U r éndoselos ir -! SFX U r éndonoslos ir -! SFX U r éndooslos ir -! SFX U r éndomelas ir -! SFX U r éndotelas ir -! SFX U r éndoselas ir -! SFX U r éndonoslas ir -! SFX U r éndooslas ir -! -! SFX V Y 169 -! SFX V ar o ar -! SFX V er o [^cg]er -! SFX V cer zo cer -! SFX V ger jo ger -! SFX V ir o [^cgu]ir -! SFX V cir zo cir -! SFX V gir jo gir -! SFX V uir o guir -! SFX V quir co quir -! SFX V r s [ae]r -! SFX V ir es ir -! SFX V ar a ar -! SFX V er e er -! SFX V ir e ir -! SFX V r mos [aei]r -! SFX V ar áis ar -! SFX V er éis er -! SFX V ir ís ir -! SFX V r n [ae]r -! SFX V ir en ir -! SFX V r ba ar -! SFX V er ía er -! SFX V ir ía ir -! SFX V r bas ar -! SFX V er ías er -! SFX V ir ías ir -! SFX V ar ábamos ar -! SFX V er íamos er -! SFX V ir íamos ir -! SFX V r bais ar -! SFX V er íais er -! SFX V ir íais ir -! SFX V r ban ar -! SFX V er ían er -! SFX V ir ían ir -! SFX V ar é [^czg]ar -! SFX V car qué car -! SFX V ar ué gar -! SFX V zar cé zar -! SFX V er í er -! SFX V ir í ir -! SFX V r ste [ai]r -! SFX V er iste er -! SFX V ar ó ar -! SFX V er ió er -! SFX V r ó ir -! SFX V er imos er -! SFX V r steis [ai]r -! SFX V er isteis er -! SFX V 0 on ar -! SFX V er ieron er -! SFX V r eron ir -! SFX V 0 é [aei]r -! SFX V 0 ás [aei]r -! SFX V 0 á [aei]r -! SFX V 0 emos [aei]r -! SFX V 0 éis [aei]r -! SFX V 0 án [aei]r -! SFX V 0 ía [aei]r -! SFX V 0 ías [aei]r -! SFX V 0 íamos [aei]r -! SFX V 0 íais [aei]r -! SFX V 0 ían [aei]r -! SFX V ar e [^czg]ar -! SFX V car que car -! SFX V ar ue gar -! SFX V zar ce zar -! SFX V er a [^cg]er -! SFX V cer za cer -! SFX V ger ja ger -! SFX V ir a [^cgu]ir -! SFX V cir za cir -! SFX V gir ja gir -! SFX V uir a guir -! SFX V quir ca quir -! SFX V ar es [^czg]ar -! SFX V car ques car -! SFX V ar ues gar -! SFX V zar ces zar -! SFX V er as [^cg]er -! SFX V cer zas cer -! SFX V ger jas ger -! SFX V ir as [^cgu]ir -! SFX V cir zas cir -! SFX V gir jas gir -! SFX V uir as guir -! SFX V quir cas quir -! SFX V ar emos [^czg]ar -! SFX V car quemos car -! SFX V ar uemos gar -! SFX V zar cemos zar -! SFX V er amos [^cg]er -! SFX V cer zamos cer -! SFX V ger jamos ger -! SFX V ir amos [^cgu]ir -! SFX V cir zamos cir -! SFX V gir jamos gir -! SFX V uir amos guir -! SFX V quir camos quir -! SFX V ar éis [^czg]ar -! SFX V car quéis car -! SFX V ar uéis gar -! SFX V zar céis zar -! SFX V er áis [^cg]er -! SFX V cer záis cer -! SFX V ger jáis ger -! SFX V ir áis [^cgu]ir -! SFX V cir záis cir -! SFX V gir jáis gir -! SFX V uir áis guir -! SFX V quir cáis quir -! SFX V ar en [^czg]ar -! SFX V car quen car -! SFX V ar uen gar -! SFX V zar cen zar -! SFX V er an [^cg]er -! SFX V cer zan cer -! SFX V ger jan ger -! SFX V ir an [^cgu]ir -! SFX V cir zan cir -! SFX V gir jan gir -! SFX V uir an guir -! SFX V quir can quir -! SFX V r se ar -! SFX V r ra ar -! SFX V er iese er -! SFX V er iera er -! SFX V r ese ir -! SFX V r era ir -! SFX V r ses ar -! SFX V r ras ar -! SFX V er ieses er -! SFX V er ieras er -! SFX V r eses ir -! SFX V r eras ir -! SFX V ar ásemos ar -! SFX V ar áramos ar -! SFX V er iésemos er -! SFX V er iéramos er -! SFX V r ésemos ir -! SFX V r éramos ir -! SFX V r seis ar -! SFX V r rais ar -! SFX V er ieseis er -! SFX V er ierais er -! SFX V r eseis ir -! SFX V r erais ir -! SFX V r sen ar -! SFX V r ran ar -! SFX V er iesen er -! SFX V er ieran er -! SFX V r esen ir -! SFX V r eran ir -! SFX V r re ar -! SFX V er iere er -! SFX V r ere ir -! SFX V r res ar -! SFX V er ieres er -! SFX V r eres ir -! SFX V ar áremos ar -! SFX V er iéremos er -! SFX V r éremos ir -! SFX V r reis ar -! SFX V er iereis er -! SFX V r ereis ir -! SFX V r ren ar -! SFX V er ieren er -! SFX V r eren ir -! SFX V r d r -! -! SFX X Y 11 -! SFX X r do [ai]r -! SFX X r dos [ai]r -! SFX X r da [ai]r -! SFX X r das [ai]r -! SFX X er ido er -! SFX X er idos er -! SFX X er ida er -! SFX X er idas er -! SFX X r ndo ar -! SFX X er iendo er -! SFX X r endo ir -! -! SFX W Y 197 S -! SFX W ar a andar -! SFX W ar a guar -! SFX W er a [eo]er -! SFX W r ba ar -! SFX W obar ueba obar -! SFX W ebir iba ebir -! SFX W erbar ierba erbar -! SFX W ibir íba ohibir -! SFX W ocar ueca ocar -! SFX W olcar uelca olcar -! SFX W orcar uerca orcar -! SFX W cer zca [^c]ocer -! SFX W cer zca [^fh]acer -! SFX W cer zca ecer -! SFX W cir zca ucir -! SFX W eder ieda eder -! SFX W odar ueda odar -! SFX W oder ueda oder -! SFX W edir ida edir -! SFX W oldar uelda [^g]oldar -! SFX W oldar üelda goldar -! SFX W endar ienda endar -! SFX W ender ienda ender -! SFX W endir inda endir -! SFX W erder ierda erder -! SFX W ordar uerda ordar -! SFX W order uerda order -! SFX W cer ga [fh]acer -! SFX W er ga [eo]ner -! SFX W er ga aler -! SFX W ir ga alir -! SFX W gar ega ugar -! SFX W egar iega egar -! SFX W ogar uega ogar -! SFX W ecir iga ecir -! SFX W eguir iga eguir -! SFX W er iga aer -! SFX W er iga oer -! SFX W ír iga oír -! SFX W olgar uelga olgar -! SFX W enir enga enir -! SFX W engar ienga engar -! SFX W enchir incha enchir -! SFX W egir ija egir -! SFX W ijar íja [ae]hijar -! SFX W oblar uebla oblar -! SFX W emblar iembla emblar -! SFX W elar iela elar -! SFX W olar uela olar -! SFX W oler uela oler -! SFX W ollar uella [^g]ollar -! SFX W ollar üella gollar -! SFX W ilar íla [ae]hilar -! SFX W emir ima emir -! SFX W ormir uerma ormir -! SFX W umar úma [ae]humar -! SFX W onar uena onar -! SFX W ernar ierna ernar -! SFX W erner ierna erner -! SFX W ernir ierna ernir -! SFX W ornar uerna ornar -! SFX W inar ína [aeo]hinar -! SFX W unir úna eunir -! SFX W aber epa saber -! SFX W caber quepa caber -! SFX W r ra [^a]ndar -! SFX W r ra [^d]ar -! SFX W r ra [^n]dar -! SFX W ebrar iebra ebrar -! SFX W embrar iembra embrar -! SFX W edrar iedra edrar -! SFX W endrar iendra endrar -! SFX W r era alir -! SFX W r era ernir -! SFX W r era eunir -! SFX W r era ohibir -! SFX W er iera [^fh]acer -! SFX W er iera aler -! SFX W er iera e[cd]er -! SFX W er iera ender -! SFX W er iera er[dnt]er -! SFX W er iera o[clv]er -! SFX W er iera olver -! SFX W er iera or[cd]er -! SFX W erer iera erer -! SFX W erir iera erir -! SFX W eír iera eír -! SFX W irir iera irir -! SFX W ebir ibiera ebir -! SFX W acer iciera [fh]acer -! SFX W edir idiera edir -! SFX W endir indiera endir -! SFX W oder udiera oder -! SFX W egir igiera egir -! SFX W enchir inchiera enchir -! SFX W emir imiera emir -! SFX W ormir urmiera ormir -! SFX W enir iniera enir -! SFX W aber upiera aber -! SFX W erir iriera erir -! SFX W irir iriera irir -! SFX W orir uriera orir -! SFX W erer isiera erer -! SFX W oner usiera oner -! SFX W etir itiera etir -! SFX W entir intiera entir -! SFX W ertir irtiera ertir -! SFX W estir istiera estir -! SFX W eguir iguiera eguir -! SFX W ervir irviera ervir -! SFX W ar uviera andar -! SFX W ener uviera ener -! SFX W cir jera ucir -! SFX W er jera raer -! SFX W ecir ijera ecir -! SFX W orar uera [^g]orar -! SFX W orir uera orir -! SFX W er yera [eo]er -! SFX W er yera caer -! SFX W ir yera [^g]uir -! SFX W ír yera oír -! SFX W üir uyera güir -! SFX W eñir iñera eñir -! SFX W orar üera gorar -! SFX W errar ierra errar -! SFX W ontrar uentra ontrar -! SFX W ostrar uestra ostrar -! SFX W esar iesa esar -! SFX W osar uesa osar -! SFX W ensar iensa ensar -! SFX W usar úsa [ae]husar -! SFX W etar ieta etar -! SFX W etir ita etir -! SFX W oltar uelta oltar -! SFX W entar ienta entar -! SFX W entir ienta entir -! SFX W ontar uenta ontar -! SFX W ertar ierta ertar -! SFX W erter ierta erter -! SFX W ertir ierta ertir -! SFX W ortar uerta ortar -! SFX W estar iesta estar -! SFX W ostar uesta ostar -! SFX W estir ista estir -! SFX W itar íta [ae]hitar -! SFX W evar ieva evar -! SFX W ovar ueva ovar -! SFX W over ueva over -! SFX W olver uelva olver -! SFX W ervir irva ervir -! SFX W er ya oer -! SFX W ir ya [^g]uir -! SFX W üir uya güir -! SFX W ezar ieza ezar -! SFX W ocer ueza cocer -! SFX W enzar ienza enzar -! SFX W onzar üenza gonzar -! SFX W orcer uerza orcer -! SFX W orzar uerza orzar -! SFX W izar íza [ae]izar -! SFX W 0 ía [^fh]acer -! SFX W 0 ía [aeo]er -! SFX W 0 ía [io]rir -! SFX W 0 ía [üu]ir -! SFX W 0 ía ar -! SFX W 0 ía e[bdgmrtñ]ir -! SFX W 0 ía e[cd]er -! SFX W 0 ía e[ns]tir -! SFX W 0 ía enchir -! SFX W 0 ía ender -! SFX W 0 ía endir -! SFX W 0 ía er[dnt]er -! SFX W 0 ía er[ntv]ir -! SFX W 0 ía eunir -! SFX W 0 ía o[clv]er -! SFX W 0 ía olver -! SFX W 0 ía or[cd]er -! SFX W 0 ía ormir -! SFX W 0 ía ucir -! SFX W er ía er -! SFX W eír ía eír -! SFX W iar ía iar -! SFX W ir ía ir -! SFX W ír ía ír -! SFX W cer ría [fh]acer -! SFX W er ría aber -! SFX W er ría erer -! SFX W er ría oder -! SFX W er dría [eo]ner -! SFX W er dría aler -! SFX W ir dría alir -! SFX W ir dría enir -! SFX W ecir iría ecir -! SFX W ír iría [eo]ír -! SFX W oñar ueña oñar -! SFX W eñir iña eñir -! SFX W uar úa [^g]uar -! -! SFX W Y 264 S -! SFX W ar e andar -! SFX W er e [^c]ocer -! SFX W er e [cr]aer -! SFX W er e [eo]er -! SFX W er e a[bcl]er -! SFX W er e ecer -! SFX W er e oner -! SFX W ir e alir -! SFX W ir e ucir -! SFX W obar uebe obar -! SFX W ebir ibe ebir -! SFX W erbar ierbe erbar -! SFX W ibir íbe ohibir -! SFX W ezar iece ezar -! SFX W ocer uece cocer -! SFX W acer ice [fh]acer -! SFX W ecir ice ecir -! SFX W enzar ience enzar -! SFX W onzar üence gonzar -! SFX W orcer uerce orcer -! SFX W orzar uerce orzar -! SFX W izar íce [ae]izar -! SFX W eder iede eder -! SFX W odar uede odar -! SFX W oder uede oder -! SFX W edir ide edir -! SFX W oldar uelde [^g]oldar -! SFX W oldar üelde goldar -! SFX W endar iende endar -! SFX W ender iende ender -! SFX W endir inde endir -! SFX W erder ierde erder -! SFX W ordar uerde ordar -! SFX W order uerde order -! SFX W oder ude oder -! SFX W egir ige egir -! SFX W enchir inche enchir -! SFX W cir je ucir -! SFX W er je raer -! SFX W ecir ije ecir -! SFX W ijar íje [ae]hijar -! SFX W oblar ueble oblar -! SFX W emblar iemble emblar -! SFX W elar iele elar -! SFX W olar uele olar -! SFX W oler uele oler -! SFX W ollar uelle [^g]ollar -! SFX W ollar üelle gollar -! SFX W ilar íle [ae]hilar -! SFX W emir ime emir -! SFX W ormir uerme ormir -! SFX W umar úme [ae]humar -! SFX W ener iene ener -! SFX W enir iene enir -! SFX W onar uene onar -! SFX W enir ine enir -! SFX W ernar ierne ernar -! SFX W erner ierne erner -! SFX W ernir ierne ernir -! SFX W ornar uerne ornar -! SFX W inar íne [aeo]hinar -! SFX W unir úne eunir -! SFX W aber upe aber -! SFX W r re [^a]ndar -! SFX W r re [^d]ar -! SFX W r re [^n]dar -! SFX W ebrar iebre ebrar -! SFX W embrar iembre embrar -! SFX W edrar iedre edrar -! SFX W endrar iendre endrar -! SFX W r ere alir -! SFX W r ere ernir -! SFX W r ere eunir -! SFX W r ere ohibir -! SFX W er iere [^fh]acer -! SFX W er iere aler -! SFX W er iere e[cd]er -! SFX W er iere ender -! SFX W er iere er[dnt]er -! SFX W er iere o[clv]er -! SFX W er iere olver -! SFX W er iere or[cd]er -! SFX W erer iere erer -! SFX W erir iere erir -! SFX W eír iere eír -! SFX W irir iere irir -! SFX W ebir ibiere ebir -! SFX W acer iciere [fh]acer -! SFX W edir idiere edir -! SFX W endir indiere endir -! SFX W oder udiere oder -! SFX W egir igiere egir -! SFX W enchir inchiere enchir -! SFX W emir imiere emir -! SFX W ormir urmiere ormir -! SFX W enir iniere enir -! SFX W aber upiere aber -! SFX W erir iriere erir -! SFX W irir iriere irir -! SFX W orir uriere orir -! SFX W erer isiere erer -! SFX W oner usiere oner -! SFX W etir itiere etir -! SFX W entir intiere entir -! SFX W ertir irtiere ertir -! SFX W estir istiere estir -! SFX W eguir iguiere eguir -! SFX W ervir irviere ervir -! SFX W ar uviere andar -! SFX W ener uviere ener -! SFX W cir jere ucir -! SFX W er jere raer -! SFX W ecir ijere ecir -! SFX W orar uere [^g]orar -! SFX W orir uere orir -! SFX W er yere [eo]er -! SFX W er yere caer -! SFX W ir yere [^g]uir -! SFX W ír yere oír -! SFX W üir uyere güir -! SFX W eñir iñere eñir -! SFX W orar üere gorar -! SFX W errar ierre errar -! SFX W ontrar uentre ontrar -! SFX W ostrar uestre ostrar -! SFX W r se [^a]ndar -! SFX W r se [^d]ar -! SFX W r se [^n]dar -! SFX W r ese alir -! SFX W r ese ernir -! SFX W r ese eunir -! SFX W r ese ohibir -! SFX W er iese [^fh]acer -! SFX W er iese aler -! SFX W er iese e[cd]er -! SFX W er iese ender -! SFX W er iese er[dnt]er -! SFX W er iese o[clv]er -! SFX W er iese olver -! SFX W er iese or[cd]er -! SFX W esar iese esar -! SFX W eír iese eír -! SFX W ebir ibiese ebir -! SFX W acer iciese [fh]acer -! SFX W edir idiese edir -! SFX W endir indiese endir -! SFX W oder udiese oder -! SFX W egir igiese egir -! SFX W enchir inchiese enchir -! SFX W emir imiese emir -! SFX W ormir urmiese ormir -! SFX W enir iniese enir -! SFX W aber upiese aber -! SFX W erir iriese erir -! SFX W irir iriese irir -! SFX W orir uriese orir -! SFX W erer isiese erer -! SFX W oner usiese oner -! SFX W etir itiese etir -! SFX W entir intiese entir -! SFX W ertir irtiese ertir -! SFX W estir istiese estir -! SFX W eguir iguiese eguir -! SFX W ervir irviese ervir -! SFX W ar uviese andar -! SFX W ener uviese ener -! SFX W cir jese ucir -! SFX W er jese raer -! SFX W ecir ijese ecir -! SFX W osar uese osar -! SFX W er yese [eo]er -! SFX W er yese caer -! SFX W ir yese [^g]uir -! SFX W ír yese oír -! SFX W üir uyese güir -! SFX W eñir iñese eñir -! SFX W erer ise erer -! SFX W ensar iense ensar -! SFX W oner use oner -! SFX W umar úse [ae]husar -! SFX W etar iete etar -! SFX W etir ite etir -! SFX W oltar uelte oltar -! SFX W entar iente entar -! SFX W entir iente entir -! SFX W ontar uente ontar -! SFX W ertar ierte ertar -! SFX W erter ierte erter -! SFX W ertir ierte ertir -! SFX W ortar uerte ortar -! SFX W r ste [^a]ndar -! SFX W r ste [^d]ar -! SFX W r ste [^n]dar -! SFX W r ste [eo]ír -! SFX W r ste [üu]ir -! SFX W r ste alir -! SFX W r ste ebir -! SFX W r ste edir -! SFX W r ste egir -! SFX W r ste emir -! SFX W r ste enchir -! SFX W r ste endir -! SFX W r ste entir -! SFX W r ste erir -! SFX W r ste ernir -! SFX W r ste ertir -! SFX W r ste ervir -! SFX W r ste estir -! SFX W r ste etir -! SFX W r ste eunir -! SFX W r ste eñir -! SFX W r ste irir -! SFX W r ste orir -! SFX W r ste ormir -! SFX W estar ieste estar -! SFX W ostar ueste ostar -! SFX W er iste [^fh]acer -! SFX W er iste aler -! SFX W er iste e[cd]er -! SFX W er iste ender -! SFX W er iste er[dnt]er -! SFX W er iste o[clv]er -! SFX W er iste olver -! SFX W er iste or[cd]er -! SFX W estir iste estir -! SFX W acer iciste [fh]acer -! SFX W oder udiste oder -! SFX W cir jiste ucir -! SFX W er jiste raer -! SFX W ecir ijiste ecir -! SFX W enir iniste enir -! SFX W aber upiste aber -! SFX W erer isiste erer -! SFX W oner usiste oner -! SFX W ar uviste andar -! SFX W ener uviste ener -! SFX W er íste [eo]er -! SFX W er íste caer -! SFX W itar íte [ae]hitar -! SFX W gar egue ugar -! SFX W egar iegue egar -! SFX W ogar uegue ogar -! SFX W eguir igue eguir -! SFX W olgar uelgue olgar -! SFX W engar iengue engar -! SFX W ocar ueque ocar -! SFX W olcar uelque olcar -! SFX W orcar uerque orcar -! SFX W evar ieve evar -! SFX W ovar ueve ovar -! SFX W over ueve over -! SFX W olver uelve olver -! SFX W ervir irve ervir -! SFX W ar uve andar -! SFX W ener uve ener -! SFX W ír ye oír -! SFX W uir uye [^g]uir -! SFX W üir uye güir -! SFX W eír íe eír -! SFX W iar íe iar -! SFX W oñar ueñe oñar -! SFX W eñir iñe eñir -! SFX W uar úe [^g]uar -! SFX W uar üe guar -! -! -! SFX W Y 195 S -! SFX W er an [eo]er -! SFX W r ban ar -! SFX W obar ueban obar -! SFX W ebir iban ebir -! SFX W erbar ierban erbar -! SFX W ibir íban ohibir -! SFX W ocar uecan ocar -! SFX W olcar uelcan olcar -! SFX W orcar uercan orcar -! SFX W cer zcan [^c]ocer -! SFX W cer zcan [^fh]acer -! SFX W cer zcan ecer -! SFX W cir zcan ucir -! SFX W eder iedan eder -! SFX W odar uedan odar -! SFX W oder uedan oder -! SFX W edir idan edir -! SFX W oldar ueldan [^g]oldar -! SFX W oldar üeldan goldar -! SFX W endar iendan endar -! SFX W ender iendan ender -! SFX W endir indan endir -! SFX W erder ierdan erder -! SFX W ordar uerdan ordar -! SFX W order uerdan order -! SFX W cer gan [fh]acer -! SFX W er gan [eo]ner -! SFX W er gan aler -! SFX W ir gan alir -! SFX W gar egan ugar -! SFX W egar iegan egar -! SFX W ogar uegan ogar -! SFX W ecir igan ecir -! SFX W eguir igan eguir -! SFX W er igan aer -! SFX W er igan oer -! SFX W ír igan oír -! SFX W olgar uelgan olgar -! SFX W enir engan enir -! SFX W engar iengan engar -! SFX W enchir inchan enchir -! SFX W egir ijan egir -! SFX W ijar íjan [ae]hijar -! SFX W oblar ueblan oblar -! SFX W emblar iemblan emblar -! SFX W elar ielan elar -! SFX W olar uelan olar -! SFX W oler uelan oler -! SFX W ollar uellan [^g]ollar -! SFX W ollar üellan gollar -! SFX W ilar ílan [ae]hilar -! SFX W emir iman emir -! SFX W ormir uerman ormir -! SFX W umar úman [ae]humar -! SFX W onar uenan onar -! SFX W ernar iernan ernar -! SFX W erner iernan erner -! SFX W ernir iernan ernir -! SFX W ornar uernan ornar -! SFX W inar ínan [aeo]hinar -! SFX W unir únan eunir -! SFX W aber epan saber -! SFX W caber quepan caber -! SFX W r ran [^a]ndar -! SFX W r ran [^d]ar -! SFX W r ran [^n]dar -! SFX W ebrar iebran ebrar -! SFX W embrar iembran embrar -! SFX W edrar iedran edrar -! SFX W endrar iendran endrar -! SFX W r eran alir -! SFX W r eran ernir -! SFX W r eran eunir -! SFX W r eran ohibir -! SFX W er ieran [^fh]acer -! SFX W er ieran aler -! SFX W er ieran e[cd]er -! SFX W er ieran ender -! SFX W er ieran er[dnt]er -! SFX W er ieran o[clv]er -! SFX W er ieran olver -! SFX W er ieran or[cd]er -! SFX W erer ieran erer -! SFX W erir ieran erir -! SFX W eír ieran eír -! SFX W irir ieran irir -! SFX W ebir ibieran ebir -! SFX W acer icieran [fh]acer -! SFX W edir idieran edir -! SFX W endir indieran endir -! SFX W oder udieran oder -! SFX W egir igieran egir -! SFX W enchir inchieran enchir -! SFX W emir imieran emir -! SFX W ormir urmieran ormir -! SFX W enir inieran enir -! SFX W aber upieran aber -! SFX W erir irieran erir -! SFX W irir irieran irir -! SFX W orir urieran orir -! SFX W erer isieran erer -! SFX W oner usieran oner -! SFX W etir itieran etir -! SFX W entir intieran entir -! SFX W ertir irtieran ertir -! SFX W estir istieran estir -! SFX W eguir iguieran eguir -! SFX W ervir irvieran ervir -! SFX W ar uvieran andar -! SFX W ener uvieran ener -! SFX W cir jeran ucir -! SFX W er jeran raer -! SFX W ecir ijeran ecir -! SFX W orar ueran [^g]orar -! SFX W orir ueran orir -! SFX W er yeran [eo]er -! SFX W er yeran caer -! SFX W ir yeran [^g]uir -! SFX W ír yeran oír -! SFX W üir uyeran güir -! SFX W eñir iñeran eñir -! SFX W orar üeran gorar -! SFX W errar ierran errar -! SFX W ontrar uentran ontrar -! SFX W ostrar uestran ostrar -! SFX W esar iesan esar -! SFX W osar uesan osar -! SFX W ensar iensan ensar -! SFX W usar úsan [ae]husar -! SFX W etar ietan etar -! SFX W etir itan etir -! SFX W oltar ueltan oltar -! SFX W entar ientan entar -! SFX W entir ientan entir -! SFX W ontar uentan ontar -! SFX W ertar iertan ertar -! SFX W erter iertan erter -! SFX W ertir iertan ertir -! SFX W ortar uertan ortar -! SFX W estar iestan estar -! SFX W ostar uestan ostar -! SFX W estir istan estir -! SFX W itar ítan [ae]hitar -! SFX W evar ievan evar -! SFX W ovar uevan ovar -! SFX W over uevan over -! SFX W olver uelvan olver -! SFX W ervir irvan ervir -! SFX W er yan oer -! SFX W ir yan [^g]uir -! SFX W üir uyan güir -! SFX W ezar iezan ezar -! SFX W ocer uezan cocer -! SFX W enzar ienzan enzar -! SFX W onzar üenzan gonzar -! SFX W orcer uerzan orcer -! SFX W orzar uerzan orzar -! SFX W izar ízan [ae]izar -! SFX W 0 ían [^fh]acer -! SFX W 0 ían [aeo]er -! SFX W 0 ían [io]rir -! SFX W 0 ían [üu]ir -! SFX W 0 ían ar -! SFX W 0 ían e[bdgmrtñ]ir -! SFX W 0 ían e[cd]er -! SFX W 0 ían e[ns]tir -! SFX W 0 ían enchir -! SFX W 0 ían ender -! SFX W 0 ían endir -! SFX W 0 ían er[dnt]er -! SFX W 0 ían er[ntv]ir -! SFX W 0 ían eunir -! SFX W 0 ían o[clv]er -! SFX W 0 ían olver -! SFX W 0 ían or[cd]er -! SFX W 0 ían ormir -! SFX W 0 ían ucir -! SFX W er ían er -! SFX W eír ían eír -! SFX W iar ían iar -! SFX W ir ían ir -! SFX W ír ían ír -! SFX W cer rían [fh]acer -! SFX W er rían aber -! SFX W er rían erer -! SFX W er rían oder -! SFX W er drían [eo]ner -! SFX W er drían aler -! SFX W ir drían alir -! SFX W ir drían enir -! SFX W ecir irían ecir -! SFX W ír irían [eo]ír -! SFX W oñar ueñan oñar -! SFX W eñir iñan eñir -! SFX W uar úan [^g]uar -! -! -! SFX W Y 202 S -! SFX W ar en andar -! SFX W ir en alir -! SFX W ir en ucir -! SFX W obar ueben obar -! SFX W ebir iben ebir -! SFX W erbar ierben erbar -! SFX W ibir íben ohibir -! SFX W ezar iecen ezar -! SFX W ocer uecen cocer -! SFX W ecir icen ecir -! SFX W enzar iencen enzar -! SFX W onzar üencen gonzar -! SFX W orcer uercen orcer -! SFX W orzar uercen orzar -! SFX W izar ícen [ae]izar -! SFX W eder ieden eder -! SFX W odar ueden odar -! SFX W oder ueden oder -! SFX W edir iden edir -! SFX W oldar uelden [^g]oldar -! SFX W oldar üelden goldar -! SFX W endar ienden endar -! SFX W ender ienden ender -! SFX W endir inden endir -! SFX W erder ierden erder -! SFX W ordar uerden ordar -! SFX W order uerden order -! SFX W egir igen egir -! SFX W enchir inchen enchir -! SFX W ijar íjen [ae]hijar -! SFX W oblar ueblen oblar -! SFX W emblar iemblen emblar -! SFX W elar ielen elar -! SFX W olar uelen olar -! SFX W oler uelen oler -! SFX W ollar uellen [^g]ollar -! SFX W ollar üellen gollar -! SFX W ilar ílen [ae]hilar -! SFX W emir imen emir -! SFX W ormir uermen ormir -! SFX W umar úmen [ae]humar -! SFX W ener ienen ener -! SFX W enir ienen enir -! SFX W onar uenen onar -! SFX W ernar iernen ernar -! SFX W erner iernen erner -! SFX W ernir iernen ernir -! SFX W ornar uernen ornar -! SFX W inar ínen [aeo]hinar -! SFX W unir únen eunir -! SFX W r ren [^a]ndar -! SFX W r ren [^d]ar -! SFX W r ren [^n]dar -! SFX W ebrar iebren ebrar -! SFX W embrar iembren embrar -! SFX W edrar iedren edrar -! SFX W endrar iendren endrar -! SFX W r eren alir -! SFX W r eren ernir -! SFX W r eren eunir -! SFX W r eren ohibir -! SFX W er ieren [^fh]acer -! SFX W er ieren aler -! SFX W er ieren e[cd]er -! SFX W er ieren ender -! SFX W er ieren er[dnt]er -! SFX W er ieren o[clv]er -! SFX W er ieren olver -! SFX W er ieren or[cd]er -! SFX W erer ieren erer -! SFX W erir ieren erir -! SFX W eír ieren eír -! SFX W irir ieren irir -! SFX W ebir ibieren ebir -! SFX W acer icieren [fh]acer -! SFX W edir idieren edir -! SFX W endir indieren endir -! SFX W oder udieren oder -! SFX W egir igieren egir -! SFX W enchir inchieren enchir -! SFX W emir imieren emir -! SFX W ormir urmieren ormir -! SFX W enir inieren enir -! SFX W aber upieren aber -! SFX W erir irieren erir -! SFX W irir irieren irir -! SFX W orir urieren orir -! SFX W erer isieren erer -! SFX W oner usieren oner -! SFX W etir itieren etir -! SFX W entir intieren entir -! SFX W ertir irtieren ertir -! SFX W estir istieren estir -! SFX W eguir iguieren eguir -! SFX W ervir irvieren ervir -! SFX W ar uvieren andar -! SFX W ener uvieren ener -! SFX W cir jeren ucir -! SFX W er jeren raer -! SFX W ecir ijeren ecir -! SFX W orar ueren [^g]orar -! SFX W orir ueren orir -! SFX W er yeren [eo]er -! SFX W er yeren caer -! SFX W ir yeren [^g]uir -! SFX W ír yeren oír -! SFX W üir uyeren güir -! SFX W eñir iñeren eñir -! SFX W orar üeren gorar -! SFX W errar ierren errar -! SFX W ontrar uentren ontrar -! SFX W ostrar uestren ostrar -! SFX W r sen [^a]ndar -! SFX W r sen [^d]ar -! SFX W r sen [^n]dar -! SFX W r esen alir -! SFX W r esen ernir -! SFX W r esen eunir -! SFX W r esen ohibir -! SFX W er iesen [^fh]acer -! SFX W er iesen aler -! SFX W er iesen e[cd]er -! SFX W er iesen ender -! SFX W er iesen er[dnt]er -! SFX W er iesen o[clv]er -! SFX W er iesen olver -! SFX W er iesen or[cd]er -! SFX W esar iesen esar -! SFX W eír iesen eír -! SFX W ebir ibiesen ebir -! SFX W acer iciesen [fh]acer -! SFX W edir idiesen edir -! SFX W endir indiesen endir -! SFX W oder udiesen oder -! SFX W egir igiesen egir -! SFX W enchir inchiesen enchir -! SFX W emir imiesen emir -! SFX W ormir urmiesen ormir -! SFX W enir iniesen enir -! SFX W aber upiesen aber -! SFX W erir iriesen erir -! SFX W irir iriesen irir -! SFX W orir uriesen orir -! SFX W erer isiesen erer -! SFX W oner usiesen oner -! SFX W etir itiesen etir -! SFX W entir intiesen entir -! SFX W ertir irtiesen ertir -! SFX W estir istiesen estir -! SFX W eguir iguiesen eguir -! SFX W ervir irviesen ervir -! SFX W ar uviesen andar -! SFX W ener uviesen ener -! SFX W cir jesen ucir -! SFX W er jesen raer -! SFX W ecir ijesen ecir -! SFX W osar uesen osar -! SFX W er yesen [eo]er -! SFX W er yesen caer -! SFX W ir yesen [^g]uir -! SFX W ír yesen oír -! SFX W üir uyesen güir -! SFX W eñir iñesen eñir -! SFX W ensar iensen ensar -! SFX W usar úsen [ae]husar -! SFX W etar ieten etar -! SFX W etir iten etir -! SFX W oltar uelten oltar -! SFX W entar ienten entar -! SFX W entir ienten entir -! SFX W ontar uenten ontar -! SFX W ertar ierten ertar -! SFX W erter ierten erter -! SFX W ertir ierten ertir -! SFX W ortar uerten ortar -! SFX W estar iesten estar -! SFX W ostar uesten ostar -! SFX W estir isten estir -! SFX W itar íten [ae]hitar -! SFX W gar eguen ugar -! SFX W egar ieguen egar -! SFX W ogar ueguen ogar -! SFX W eguir iguen eguir -! SFX W olgar uelguen olgar -! SFX W engar ienguen engar -! SFX W ocar uequen ocar -! SFX W olcar uelquen olcar -! SFX W orcar uerquen orcar -! SFX W evar ieven evar -! SFX W ovar ueven ovar -! SFX W over ueven over -! SFX W olver uelven olver -! SFX W ervir irven ervir -! SFX W ir yen [^g]uir -! SFX W ír yen oír -! SFX W üir uyen güir -! SFX W eír íen eír -! SFX W iar íen iar -! SFX W oñar ueñen oñar -! SFX W eñir iñen eñir -! SFX W uar úen [^g]uar -! SFX W uar üen guar -! -! -! SFX W Y 49 S -! SFX W 0 on [^a]ndar -! SFX W 0 on [^d]ar -! SFX W 0 on [^n]dar -! SFX W r eron alir -! SFX W r eron ernir -! SFX W r eron eunir -! SFX W r eron irir -! SFX W r eron ohibir -! SFX W er ieron [^fh]acer -! SFX W er ieron aler -! SFX W er ieron e[cd]er -! SFX W er ieron ender -! SFX W er ieron er[dnt]er -! SFX W er ieron o[clv]er -! SFX W er ieron olver -! SFX W er ieron or[cd]er -! SFX W eír ieron eír -! SFX W ebir ibieron ebir -! SFX W acer icieron [fh]acer -! SFX W edir idieron edir -! SFX W endir indieron endir -! SFX W oder udieron oder -! SFX W egir igieron egir -! SFX W enchir inchieron enchir -! SFX W emir imieron emir -! SFX W ormir urmieron ormir -! SFX W enir inieron enir -! SFX W aber upieron aber -! SFX W erir irieron erir -! SFX W orir urieron orir -! SFX W erer isieron erer -! SFX W oner usieron oner -! SFX W etir itieron etir -! SFX W entir intieron entir -! SFX W ertir irtieron ertir -! SFX W estir istieron estir -! SFX W eguir iguieron eguir -! SFX W ervir irvieron ervir -! SFX W ar uvieron andar -! SFX W ener uvieron ener -! SFX W cir jeron ucir -! SFX W er jeron raer -! SFX W ecir ijeron ecir -! SFX W er yeron [eo]er -! SFX W er yeron caer -! SFX W ir yeron [^g]uir -! SFX W ír yeron oír -! SFX W üir uyeron güir -! SFX W eñir iñeron eñir -! -! -! SFX W Y 29 S -! SFX W 0 án [^fh]acer -! SFX W 0 án [aeo]er -! SFX W 0 án [io]rir -! SFX W 0 án [üu]ir -! SFX W 0 án ar -! SFX W 0 án e[bdgmrtñ]ir -! SFX W 0 án e[cd]er -! SFX W 0 án e[ns]tir -! SFX W 0 án enchir -! SFX W 0 án ender -! SFX W 0 án endir -! SFX W 0 án er[dnt]er -! SFX W 0 án er[ntv]ir -! SFX W 0 án eunir -! SFX W 0 án o[clv]er -! SFX W 0 án olver -! SFX W 0 án or[cd]er -! SFX W 0 án ormir -! SFX W 0 án ucir -! SFX W cer rán [fh]acer -! SFX W er rán aber -! SFX W er rán erer -! SFX W er rán oder -! SFX W er drán [eo]ner -! SFX W er drán aler -! SFX W ir drán alir -! SFX W ir drán enir -! SFX W ecir irán ecir -! SFX W ír irán [eo]ír -! -! -! SFX W Y 126 S -! SFX W ar o andar -! SFX W ar o guar -! SFX W er o [eo]er -! SFX W obar uebo obar -! SFX W ebir ibo ebir -! SFX W erbar ierbo erbar -! SFX W ibir íbo ohibir -! SFX W ocar ueco ocar -! SFX W olcar uelco olcar -! SFX W orcar uerco orcar -! SFX W cer zco [^c]ocer -! SFX W cer zco [^fh]acer -! SFX W cer zco ecer -! SFX W ucir uzco ucir -! SFX W eder iedo eder -! SFX W odar uedo odar -! SFX W oder uedo oder -! SFX W edir ido edir -! SFX W oldar ueldo [^g]oldar -! SFX W oldar üeldo goldar -! SFX W endar iendo endar -! SFX W ender iendo ender -! SFX W endir indo endir -! SFX W erder ierdo erder -! SFX W ordar uerdo ordar -! SFX W order uerdo order -! SFX W oder udo oder -! SFX W cer go [fh]acer -! SFX W er go aler -! SFX W er go ener -! SFX W er go oner -! SFX W ir go alir -! SFX W ir go enir -! SFX W gar ego ugar -! SFX W egar iego egar -! SFX W ogar uego ogar -! SFX W ecir igo ecir -! SFX W eguir igo eguir -! SFX W er igo [cr]aer -! SFX W er igo oer -! SFX W ír igo oír -! SFX W olgar uelgo olgar -! SFX W engar iengo engar -! SFX W enchir incho enchir -! SFX W cir jo ucir -! SFX W er jo raer -! SFX W ecir ijo ecir -! SFX W egir ijo egir -! SFX W ijar íjo [ae]hijar -! SFX W oblar ueblo oblar -! SFX W emblar iemblo emblar -! SFX W elar ielo elar -! SFX W olar uelo olar -! SFX W oler uelo oler -! SFX W ollar uello [^g]ollar -! SFX W ollar üello gollar -! SFX W ilar ílo [ae]hilar -! SFX W emir imo emir -! SFX W ormir uermo ormir -! SFX W umar úmo [ae]humar -! SFX W onar ueno onar -! SFX W enir ino enir -! SFX W ernar ierno ernar -! SFX W erner ierno erner -! SFX W ernir ierno ernir -! SFX W ornar uerno ornar -! SFX W inar íno [aeo]hinar -! SFX W unir úno eunir -! SFX W caber quepo caber -! SFX W aber upo aber -! SFX W ebrar iebro ebrar -! SFX W embrar iembro embrar -! SFX W edrar iedro edrar -! SFX W endrar iendro endrar -! SFX W erer iero erer -! SFX W erir iero erir -! SFX W irir iero irir -! SFX W orar uero [^g]orar -! SFX W orir uero orir -! SFX W orar üero gorar -! SFX W errar ierro errar -! SFX W ontrar uentro ontrar -! SFX W ostrar uestro ostrar -! SFX W esar ieso esar -! SFX W osar ueso osar -! SFX W erer iso erer -! SFX W ensar ienso ensar -! SFX W oner uso oner -! SFX W usar úso [ae]husar -! SFX W etar ieto etar -! SFX W etir ito etir -! SFX W oltar uelto oltar -! SFX W entar iento entar -! SFX W entir iento entir -! SFX W ontar uento ontar -! SFX W ertar ierto ertar -! SFX W erter ierto erter -! SFX W ertir ierto ertir -! SFX W ortar uerto ortar -! SFX W estar iesto estar -! SFX W ostar uesto ostar -! SFX W estir isto estir -! SFX W itar íto [ae]hitar -! SFX W evar ievo evar -! SFX W ovar uevo ovar -! SFX W over uevo over -! SFX W olver uelvo olver -! SFX W ervir irvo ervir -! SFX W ar uvo andar -! SFX W ener uvo ener -! SFX W er yo oer -! SFX W uir uyo [^g]uir -! SFX W üir uyo güir -! SFX W ezar iezo ezar -! SFX W ocer uezo cocer -! SFX W acer izo [fh]acer -! SFX W enzar ienzo enzar -! SFX W onzar üenzo gonzar -! SFX W orcer uerzo orcer -! SFX W orzar uerzo orzar -! SFX W izar ízo [ae]izar -! SFX W eír ío eír -! SFX W iar ío iar -! SFX W oñar ueño oñar -! SFX W eñir iño eñir -! SFX W uar úo [^g]uar -! -! -! -! SFX W Y 195 S -! SFX W er as [eo]er -! SFX W r bas ar -! SFX W obar uebas obar -! SFX W ebir ibas ebir -! SFX W erbar ierbas erbar -! SFX W ibir íbas ohibir -! SFX W ocar uecas ocar -! SFX W olcar uelcas olcar -! SFX W orcar uercas orcar -! SFX W cer zcas [^c]ocer -! SFX W cer zcas [^fh]acer -! SFX W cer zcas ecer -! SFX W cir zcas ucir -! SFX W eder iedas eder -! SFX W odar uedas odar -! SFX W oder uedas oder -! SFX W edir idas edir -! SFX W oldar ueldas [^g]oldar -! SFX W oldar üeldas goldar -! SFX W endar iendas endar -! SFX W ender iendas ender -! SFX W endir indas endir -! SFX W erder ierdas erder -! SFX W ordar uerdas ordar -! SFX W order uerdas order -! SFX W cer gas [fh]acer -! SFX W er gas [eo]ner -! SFX W er gas aler -! SFX W ir gas alir -! SFX W gar egas ugar -! SFX W egar iegas egar -! SFX W ogar uegas ogar -! SFX W ecir igas ecir -! SFX W eguir igas eguir -! SFX W er igas aer -! SFX W er igas oer -! SFX W ír igas oír -! SFX W olgar uelgas olgar -! SFX W enir engas enir -! SFX W engar iengas engar -! SFX W enchir inchas enchir -! SFX W egir ijas egir -! SFX W ijar íjas [ae]hijar -! SFX W oblar ueblas oblar -! SFX W emblar iemblas emblar -! SFX W elar ielas elar -! SFX W olar uelas olar -! SFX W oler uelas oler -! SFX W ollar uellas [^g]ollar -! SFX W ollar üellas gollar -! SFX W ilar ílas [ae]hilar -! SFX W emir imas emir -! SFX W ormir uermas ormir -! SFX W umar úmas [ae]humar -! SFX W onar uenas onar -! SFX W ernar iernas ernar -! SFX W erner iernas erner -! SFX W ernir iernas ernir -! SFX W ornar uernas ornar -! SFX W inar ínas [aeo]hinar -! SFX W unir únas eunir -! SFX W aber epas saber -! SFX W caber quepas caber -! SFX W r ras [^a]ndar -! SFX W r ras [^d]ar -! SFX W r ras [^n]dar -! SFX W ebrar iebras ebrar -! SFX W embrar iembras embrar -! SFX W edrar iedras edrar -! SFX W endrar iendras endrar -! SFX W r eras alir -! SFX W r eras ernir -! SFX W r eras eunir -! SFX W r eras ohibir -! SFX W er ieras [^fh]acer -! SFX W er ieras aler -! SFX W er ieras e[cd]er -! SFX W er ieras ender -! SFX W er ieras er[dnt]er -! SFX W er ieras o[clv]er -! SFX W er ieras olver -! SFX W er ieras or[cd]er -! SFX W erer ieras erer -! SFX W erir ieras erir -! SFX W eír ieras eír -! SFX W irir ieras irir -! SFX W ebir ibieras ebir -! SFX W acer icieras [fh]acer -! SFX W edir idieras edir -! SFX W endir indieras endir -! SFX W oder udieras oder -! SFX W egir igieras egir -! SFX W enchir inchieras enchir -! SFX W emir imieras emir -! SFX W ormir urmieras ormir -! SFX W enir inieras enir -! SFX W aber upieras aber -! SFX W erir irieras erir -! SFX W irir irieras irir -! SFX W orir urieras orir -! SFX W erer isieras erer -! SFX W oner usieras oner -! SFX W etir itieras etir -! SFX W entir intieras entir -! SFX W ertir irtieras ertir -! SFX W estir istieras estir -! SFX W eguir iguieras eguir -! SFX W ervir irvieras ervir -! SFX W ar uvieras andar -! SFX W ener uvieras ener -! SFX W cir jeras ucir -! SFX W er jeras raer -! SFX W ecir ijeras ecir -! SFX W orar ueras [^g]orar -! SFX W orir ueras orir -! SFX W er yeras [eo]er -! SFX W er yeras caer -! SFX W ir yeras [^g]uir -! SFX W ír yeras oír -! SFX W üir uyeras güir -! SFX W eñir iñeras eñir -! SFX W orar üeras gorar -! SFX W errar ierras errar -! SFX W ontrar uentras ontrar -! SFX W ostrar uestras ostrar -! SFX W esar iesas esar -! SFX W osar uesas osar -! SFX W ensar iensas ensar -! SFX W usar úsas [ae]husar -! SFX W etar ietas etar -! SFX W etir itas etir -! SFX W oltar ueltas oltar -! SFX W entar ientas entar -! SFX W entir ientas entir -! SFX W ontar uentas ontar -! SFX W ertar iertas ertar -! SFX W erter iertas erter -! SFX W ertir iertas ertir -! SFX W ortar uertas ortar -! SFX W estar iestas estar -! SFX W ostar uestas ostar -! SFX W estir istas estir -! SFX W itar ítas [ae]hitar -! SFX W evar ievas evar -! SFX W ovar uevas ovar -! SFX W over uevas over -! SFX W olver uelvas olver -! SFX W ervir irvas ervir -! SFX W er yas oer -! SFX W ir yas [^g]uir -! SFX W üir uyas güir -! SFX W ezar iezas ezar -! SFX W ocer uezas cocer -! SFX W enzar ienzas enzar -! SFX W onzar üenzas gonzar -! SFX W orcer uerzas orcer -! SFX W orzar uerzas orzar -! SFX W izar ízas [ae]izar -! SFX W 0 ías [^fh]acer -! SFX W 0 ías [aeo]er -! SFX W 0 ías [io]rir -! SFX W 0 ías [üu]ir -! SFX W 0 ías ar -! SFX W 0 ías e[bdgmrtñ]ir -! SFX W 0 ías e[cd]er -! SFX W 0 ías e[ns]tir -! SFX W 0 ías enchir -! SFX W 0 ías ender -! SFX W 0 ías endir -! SFX W 0 ías er[dnt]er -! SFX W 0 ías er[ntv]ir -! SFX W 0 ías eunir -! SFX W 0 ías o[clv]er -! SFX W 0 ías olver -! SFX W 0 ías or[cd]er -! SFX W 0 ías ormir -! SFX W 0 ías ucir -! SFX W er ías er -! SFX W eír ías eír -! SFX W iar ías iar -! SFX W ir ías ir -! SFX W ír ías ír -! SFX W cer rías [fh]acer -! SFX W er rías aber -! SFX W er rías erer -! SFX W er rías oder -! SFX W er drías [eo]ner -! SFX W er drías aler -! SFX W ir drías alir -! SFX W ir drías enir -! SFX W ecir irías ecir -! SFX W ír irías [eo]ír -! SFX W oñar ueñas oñar -! SFX W eñir iñas eñir -! SFX W uar úas [^g]uar -! -! -! -! SFX W Y 202 S -! SFX W ar es andar -! SFX W ir es ucir -! SFX W r es alir -! SFX W obar uebes obar -! SFX W ebir ibes ebir -! SFX W erbar ierbes erbar -! SFX W ibir íbes ohibir -! SFX W ezar ieces ezar -! SFX W ocer ueces cocer -! SFX W ecir ices ecir -! SFX W enzar iences enzar -! SFX W onzar üences gonzar -! SFX W orcer uerces orcer -! SFX W orzar uerces orzar -! SFX W izar íces [ae]izar -! SFX W eder iedes eder -! SFX W odar uedes odar -! SFX W oder uedes oder -! SFX W edir ides edir -! SFX W oldar ueldes [^g]oldar -! SFX W oldar üeldes goldar -! SFX W endar iendes endar -! SFX W ender iendes ender -! SFX W endir indes endir -! SFX W erder ierdes erder -! SFX W ordar uerdes ordar -! SFX W order uerdes order -! SFX W egir iges egir -! SFX W enchir inches enchir -! SFX W ijar íjes [ae]hijar -! SFX W oblar uebles oblar -! SFX W emblar iembles emblar -! SFX W elar ieles elar -! SFX W olar ueles olar -! SFX W oler ueles oler -! SFX W ollar uelles [^g]ollar -! SFX W ollar üelles gollar -! SFX W ilar íles [ae]hilar -! SFX W emir imes emir -! SFX W ormir uermes ormir -! SFX W umar úmes [ae]humar -! SFX W ener ienes ener -! SFX W enir ienes enir -! SFX W onar uenes onar -! SFX W ernar iernes ernar -! SFX W erner iernes erner -! SFX W ernir iernes ernir -! SFX W ornar uernes ornar -! SFX W inar ínes [aeo]hinar -! SFX W unir únes eunir -! SFX W r res [^a]ndar -! SFX W r res [^d]ar -! SFX W r res [^n]dar -! SFX W ebrar iebres ebrar -! SFX W embrar iembres embrar -! SFX W edrar iedres edrar -! SFX W endrar iendres endrar -! SFX W r eres alir -! SFX W r eres ernir -! SFX W r eres eunir -! SFX W r eres ohibir -! SFX W er ieres [^fh]acer -! SFX W er ieres aler -! SFX W er ieres e[cd]er -! SFX W er ieres ender -! SFX W er ieres er[dnt]er -! SFX W er ieres o[clv]er -! SFX W er ieres olver -! SFX W er ieres or[cd]er -! SFX W erer ieres erer -! SFX W erir ieres erir -! SFX W eír ieres eír -! SFX W irir ieres irir -! SFX W ebir ibieres ebir -! SFX W acer icieres [fh]acer -! SFX W edir idieres edir -! SFX W endir indieres endir -! SFX W oder udieres oder -! SFX W egir igieres egir -! SFX W enchir inchieres enchir -! SFX W emir imieres emir -! SFX W ormir urmieres ormir -! SFX W enir inieres enir -! SFX W aber upieres aber -! SFX W erir irieres erir -! SFX W irir irieres irir -! SFX W orir urieres orir -! SFX W erer isieres erer -! SFX W oner usieres oner -! SFX W etir itieres etir -! SFX W entir intieres entir -! SFX W ertir irtieres ertir -! SFX W estir istieres estir -! SFX W eguir iguieres eguir -! SFX W ervir irvieres ervir -! SFX W ar uvieres andar -! SFX W ener uvieres ener -! SFX W cir jeres ucir -! SFX W er jeres raer -! SFX W ecir ijeres ecir -! SFX W orar ueres [^g]orar -! SFX W orir ueres orir -! SFX W er yeres [eo]er -! SFX W er yeres caer -! SFX W ir yeres [^g]uir -! SFX W ír yeres oír -! SFX W üir uyeres güir -! SFX W eñir iñeres eñir -! SFX W orar üeres gorar -! SFX W errar ierres errar -! SFX W ontrar uentres ontrar -! SFX W ostrar uestres ostrar -! SFX W r ses [^a]ndar -! SFX W r ses [^d]ar -! SFX W r ses [^n]dar -! SFX W r eses alir -! SFX W r eses ernir -! SFX W r eses eunir -! SFX W r eses ohibir -! SFX W er ieses [^fh]acer -! SFX W er ieses aler -! SFX W er ieses e[cd]er -! SFX W er ieses ender -! SFX W er ieses er[dnt]er -! SFX W er ieses o[clv]er -! SFX W er ieses olver -! SFX W er ieses or[cd]er -! SFX W esar ieses esar -! SFX W eír ieses eír -! SFX W ebir ibieses ebir -! SFX W acer icieses [fh]acer -! SFX W edir idieses edir -! SFX W endir indieses endir -! SFX W oder udieses oder -! SFX W egir igieses egir -! SFX W enchir inchieses enchir -! SFX W emir imieses emir -! SFX W ormir urmieses ormir -! SFX W enir inieses enir -! SFX W aber upieses aber -! SFX W erir irieses erir -! SFX W irir irieses irir -! SFX W orir urieses orir -! SFX W erer isieses erer -! SFX W oner usieses oner -! SFX W etir itieses etir -! SFX W entir intieses entir -! SFX W ertir irtieses ertir -! SFX W estir istieses estir -! SFX W eguir iguieses eguir -! SFX W ervir irvieses ervir -! SFX W ar uvieses andar -! SFX W ener uvieses ener -! SFX W cir jeses ucir -! SFX W er jeses raer -! SFX W ecir ijeses ecir -! SFX W osar ueses osar -! SFX W er yeses [eo]er -! SFX W er yeses caer -! SFX W ir yeses [^g]uir -! SFX W ír yeses oír -! SFX W üir uyeses güir -! SFX W eñir iñeses eñir -! SFX W ensar ienses ensar -! SFX W usar úses [ae]husar -! SFX W etar ietes etar -! SFX W etir ites etir -! SFX W oltar ueltes oltar -! SFX W entar ientes entar -! SFX W entir ientes entir -! SFX W ontar uentes ontar -! SFX W ertar iertes ertar -! SFX W erter iertes erter -! SFX W ertir iertes ertir -! SFX W ortar uertes ortar -! SFX W estar iestes estar -! SFX W ostar uestes ostar -! SFX W estir istes estir -! SFX W itar ítes [ae]hitar -! SFX W gar egues ugar -! SFX W egar iegues egar -! SFX W ogar uegues ogar -! SFX W eguir igues eguir -! SFX W olgar uelgues olgar -! SFX W engar iengues engar -! SFX W ocar ueques ocar -! SFX W olcar uelques olcar -! SFX W orcar uerques orcar -! SFX W evar ieves evar -! SFX W ovar ueves ovar -! SFX W over ueves over -! SFX W olver uelves olver -! SFX W ervir irves ervir -! SFX W ír yes oír -! SFX W uir uyes [^g]uir -! SFX W üir uyes güir -! SFX W eír íes eír -! SFX W iar íes iar -! SFX W oñar ueñes oñar -! SFX W eñir iñes eñir -! SFX W uar úes [^g]uar -! SFX W uar ües guar -! -! -! SFX W Y 49 S -! SFX W r rais [^a]ndar -! SFX W r rais [^d]ar -! SFX W r rais [^n]dar -! SFX W r erais alir -! SFX W r erais ernir -! SFX W r erais eunir -! SFX W r erais ohibir -! SFX W er ierais [^fh]acer -! SFX W er ierais aler -! SFX W er ierais e[cd]er -! SFX W er ierais ender -! SFX W er ierais er[dnt]er -! SFX W er ierais o[clv]er -! SFX W er ierais olver -! SFX W er ierais or[cd]er -! SFX W eír ierais eír -! SFX W ebir ibierais ebir -! SFX W acer icierais [fh]acer -! SFX W edir idierais edir -! SFX W endir indierais endir -! SFX W oder udierais oder -! SFX W egir igierais egir -! SFX W enchir inchierais enchir -! SFX W emir imierais emir -! SFX W ormir urmierais ormir -! SFX W enir inierais enir -! SFX W aber upierais aber -! SFX W erir irierais erir -! SFX W irir irierais irir -! SFX W orir urierais orir -! SFX W erer isierais erer -! SFX W oner usierais oner -! SFX W etir itierais etir -! SFX W entir intierais entir -! SFX W ertir irtierais ertir -! SFX W estir istierais estir -! SFX W eguir iguierais eguir -! SFX W ervir irvierais ervir -! SFX W ar uvierais andar -! SFX W ener uvierais ener -! SFX W cir jerais ucir -! SFX W er jerais raer -! SFX W ecir ijerais ecir -! SFX W er yerais [eo]er -! SFX W er yerais caer -! SFX W ir yerais [^g]uir -! SFX W ír yerais oír -! SFX W üir uyerais güir -! SFX W eñir iñerais eñir -! -! -! -! SFX W Y 32 S -! SFX W 0 íais [^fh]acer -! SFX W 0 íais [aeo]er -! SFX W 0 íais [io]rir -! SFX W 0 íais [üu]ir -! SFX W 0 íais ar -! SFX W 0 íais e[bdgmrtñ]ir -! SFX W 0 íais e[cd]er -! SFX W 0 íais e[ns]tir -! SFX W 0 íais enchir -! SFX W 0 íais ender -! SFX W 0 íais endir -! SFX W 0 íais er[dnt]er -! SFX W 0 íais er[ntv]ir -! SFX W 0 íais eunir -! SFX W 0 íais o[clv]er -! SFX W 0 íais olver -! SFX W 0 íais or[cd]er -! SFX W 0 íais ormir -! SFX W 0 íais ucir -! SFX W er íais er -! SFX W ir íais ir -! SFX W ír íais ír -! SFX W cer ríais [fh]acer -! SFX W er ríais aber -! SFX W er ríais erer -! SFX W er ríais oder -! SFX W er dríais [eo]ner -! SFX W er dríais aler -! SFX W ir dríais alir -! SFX W ir dríais enir -! SFX W ecir iríais ecir -! SFX W ír iríais [eo]ír -! -! -! -! SFX W Y 48 S -! SFX W r reis [^a]ndar -! SFX W r reis [^d]ar -! SFX W r reis [^n]dar -! SFX W r ereis alir -! SFX W r ereis ernir -! SFX W r ereis ohibir -! SFX W er iereis [^fh]acer -! SFX W er iereis aler -! SFX W er iereis e[cd]er -! SFX W er iereis ender -! SFX W er iereis er[dnt]er -! SFX W er iereis o[clv]er -! SFX W er iereis olver -! SFX W er iereis or[cd]er -! SFX W eír iereis eír -! SFX W ebir ibiereis ebir -! SFX W acer iciereis [fh]acer -! SFX W edir idiereis edir -! SFX W endir indiereis endir -! SFX W oder udiereis oder -! SFX W egir igiereis egir -! SFX W enchir inchiereis enchir -! SFX W emir imiereis emir -! SFX W ormir urmiereis ormir -! SFX W enir iniereis enir -! SFX W aber upiereis aber -! SFX W erir iriereis erir -! SFX W irir iriereis irir -! SFX W orir uriereis orir -! SFX W oner usiereis oner -! SFX W etir itiereis etir -! SFX W entir intiereis entir -! SFX W ertir irtiereis ertir -! SFX W estir istiereis estir -! SFX W eguir iguiereis eguir -! SFX W ervir irviereis ervir -! SFX W ar uviereis andar -! SFX W ener uviereis ener -! SFX W cir jereis ucir -! SFX W er jereis raer -! SFX W ecir ijereis ecir -! SFX W er yereis [eo]er -! SFX W er yereis caer -! SFX W ir yereis [^g]uir -! SFX W ír yereis oír -! SFX W üir uyereis güir -! SFX W eñir iñereis eñir -! SFX W erer isiéreis erer -! -! -! -! SFX W Y 49 S -! SFX W r seis [^a]ndar -! SFX W r seis [^d]ar -! SFX W r seis [^n]dar -! SFX W r eseis alir -! SFX W r eseis ernir -! SFX W r eseis eunir -! SFX W r eseis ohibir -! SFX W er ieseis [^fh]acer -! SFX W er ieseis aler -! SFX W er ieseis e[cd]er -! SFX W er ieseis ender -! SFX W er ieseis er[dnt]er -! SFX W er ieseis o[clv]er -! SFX W er ieseis olver -! SFX W er ieseis or[cd]er -! SFX W eír ieseis eír -! SFX W ebir ibieseis ebir -! SFX W acer icieseis [fh]acer -! SFX W edir idieseis edir -! SFX W endir indieseis endir -! SFX W oder udieseis oder -! SFX W egir igieseis egir -! SFX W enchir inchieseis enchir -! SFX W emir imieseis emir -! SFX W ormir urmieseis ormir -! SFX W enir inieseis enir -! SFX W aber upieseis aber -! SFX W erir irieseis erir -! SFX W irir irieseis irir -! SFX W orir urieseis orir -! SFX W erer isieseis erer -! SFX W oner usieseis oner -! SFX W etir itieseis etir -! SFX W entir intieseis entir -! SFX W ertir irtieseis ertir -! SFX W estir istieseis estir -! SFX W eguir iguieseis eguir -! SFX W ervir irvieseis ervir -! SFX W ar uvieseis andar -! SFX W ener uvieseis ener -! SFX W cir jeseis ucir -! SFX W er jeseis raer -! SFX W ecir ijeseis ecir -! SFX W er yeseis [eo]er -! SFX W er yeseis caer -! SFX W ir yeseis [^g]uir -! SFX W ír yeseis oír -! SFX W üir uyeseis güir -! SFX W eñir iñeseis eñir -! -! -! -! SFX W Y 45 S -! SFX W r steis [^a]ndar -! SFX W r steis [^d]ar -! SFX W r steis [^n]dar -! SFX W r steis [eo]ír -! SFX W r steis [üu]ir -! SFX W r steis alir -! SFX W r steis ebir -! SFX W r steis edir -! SFX W r steis egir -! SFX W r steis emir -! SFX W r steis enchir -! SFX W r steis endir -! SFX W r steis entir -! SFX W r steis erir -! SFX W r steis ernir -! SFX W r steis ertir -! SFX W r steis ervir -! SFX W r steis estir -! SFX W r steis etir -! SFX W r steis eunir -! SFX W r steis eñir -! SFX W r steis irir -! SFX W r steis orir -! SFX W r steis ormir -! SFX W er isteis [^fh]acer -! SFX W er isteis aler -! SFX W er isteis e[cd]er -! SFX W er isteis ender -! SFX W er isteis er[dnt]er -! SFX W er isteis o[clv]er -! SFX W er isteis olver -! SFX W er isteis or[cd]er -! SFX W acer icisteis [fh]acer -! SFX W oder udisteis oder -! SFX W cir jisteis ucir -! SFX W er jisteis raer -! SFX W ecir ijisteis ecir -! SFX W enir inisteis enir -! SFX W aber upisteis aber -! SFX W erer isisteis erer -! SFX W oner usisteis oner -! SFX W ar uvisteis andar -! SFX W ener uvisteis ener -! SFX W er ísteis [eo]er -! SFX W er ísteis caer -! -! -! -! SFX W Y 54 S -! SFX W ar áis ar -! SFX W er áis [eo]er -! SFX W er áis eder -! SFX W er áis ender -! SFX W er áis erder -! SFX W er áis erer -! SFX W er áis erner -! SFX W er áis erter -! SFX W er áis oder -! SFX W er áis oler -! SFX W er áis olver -! SFX W er áis order -! SFX W er áis over -! SFX W ir áis ernir -! SFX W ir áis eunir -! SFX W ir áis irir -! SFX W ir áis ohibir -! SFX W ebir ibáis ebir -! SFX W cer zcáis [^c]ocer -! SFX W cer zcáis [^fh]acer -! SFX W cer zcáis ecer -! SFX W cir zcáis ucir -! SFX W edir idáis edir -! SFX W endir indáis endir -! SFX W cer gáis [fh]acer -! SFX W er gáis [eo]ner -! SFX W er gáis aler -! SFX W ir gáis alir -! SFX W ecir igáis ecir -! SFX W eguir igáis eguir -! SFX W er igáis aer -! SFX W er igáis oer -! SFX W ír igáis oír -! SFX W enir engáis enir -! SFX W enchir incháis enchir -! SFX W eír iáis eír -! SFX W egir ijáis egir -! SFX W emir imáis emir -! SFX W ormir urmáis ormir -! SFX W aber epáis saber -! SFX W caber quepáis caber -! SFX W erir iráis erir -! SFX W orir uráis orir -! SFX W etir itáis etir -! SFX W entir intáis entir -! SFX W ertir irtáis ertir -! SFX W estir istáis estir -! SFX W ervir irváis ervir -! SFX W er yáis oer -! SFX W ir yáis [^g]uir -! SFX W üir uyáis güir -! SFX W cer záis cocer -! SFX W cer záis orcer -! SFX W emir iñáis eñir -! -! -! -! SFX W Y 84 S -! SFX W 0 éis [^fh]acer -! SFX W 0 éis [aeo]er -! SFX W 0 éis [io]rir -! SFX W 0 éis [üu]ir -! SFX W 0 éis ar -! SFX W 0 éis e[bdgmrtñ]ir -! SFX W 0 éis e[cd]er -! SFX W 0 éis e[ns]tir -! SFX W 0 éis enchir -! SFX W 0 éis ender -! SFX W 0 éis endir -! SFX W 0 éis er[dnt]er -! SFX W 0 éis er[ntv]ir -! SFX W 0 éis eunir -! SFX W 0 éis o[clv]er -! SFX W 0 éis olver -! SFX W 0 éis or[cd]er -! SFX W 0 éis ormir -! SFX W 0 éis ucir -! SFX W ar éis [^g]uar -! SFX W ar éis [ae]hu[ms]ar -! SFX W ar éis [ae]ndar -! SFX W ar éis [aeo]hi[jlnt]ar -! SFX W ar éis ebrar -! SFX W ar éis edrar -! SFX W ar éis elar -! SFX W ar éis emblar -! SFX W ar éis embrar -! SFX W ar éis endrar -! SFX W ar éis ensar -! SFX W ar éis entar -! SFX W ar éis erbar -! SFX W ar éis ernar -! SFX W ar éis errar -! SFX W ar éis ertar -! SFX W ar éis esar -! SFX W ar éis estar -! SFX W ar éis etar -! SFX W ar éis evar -! SFX W ar éis iar -! SFX W ar éis obar -! SFX W ar éis oblar -! SFX W ar éis odar -! SFX W ar éis olar -! SFX W ar éis oldar -! SFX W ar éis ollar -! SFX W ar éis oltar -! SFX W ar éis onar -! SFX W ar éis ontar -! SFX W ar éis ontrar -! SFX W ar éis orar -! SFX W ar éis ordar -! SFX W ar éis ornar -! SFX W ar éis ortar -! SFX W ar éis osar -! SFX W ar éis ostar -! SFX W ar éis ostrar -! SFX W ar éis ovar -! SFX W ar éis oñar -! SFX W er éis er -! SFX W zar céis [ae]izar -! SFX W zar céis enzar -! SFX W zar céis ezar -! SFX W zar céis gonzar -! SFX W zar céis orzar -! SFX W cer réis [fh]acer -! SFX W er réis aber -! SFX W er réis erer -! SFX W er réis oder -! SFX W er dréis [eo]ner -! SFX W er dréis aler -! SFX W ir dréis alir -! SFX W ir dréis enir -! SFX W ecir iréis ecir -! SFX W ír iréis [eo]ír -! SFX W ar uéis olgar -! SFX W gar guéis egar -! SFX W gar guéis engar -! SFX W gar guéis ugar -! SFX W ogar guéis ogar -! SFX W car quéis olcar -! SFX W car quéis orcar -! SFX W ocar quéis ocar -! SFX W uar üéis guar -! -! -! SFX W Y 338 S -! SFX W r mos r -! SFX W er amos [eo]er -! SFX W er amos eder -! SFX W er amos ender -! SFX W er amos erder -! SFX W er amos erer -! SFX W er amos erner -! SFX W er amos erter -! SFX W er amos oder -! SFX W er amos oler -! SFX W er amos olver -! SFX W er amos order -! SFX W er amos over -! SFX W ir amos ernir -! SFX W ir amos eunir -! SFX W ir amos irir -! SFX W ir amos ohibir -! SFX W ebir ibamos ebir -! SFX W ar ábamos ar -! SFX W cer zcamos [^c]ocer -! SFX W cer zcamos [^fh]acer -! SFX W cer zcamos ecer -! SFX W cir zcamos ucir -! SFX W edir idamos edir -! SFX W endir indamos endir -! SFX W cer gamos [fh]acer -! SFX W er gamos [eo]ner -! SFX W er gamos aler -! SFX W ir gamos alir -! SFX W ecir igamos ecir -! SFX W eguir igamos eguir -! SFX W er igamos aer -! SFX W er igamos oer -! SFX W ír igamos oír -! SFX W enir engamos enir -! SFX W enchir inchamos enchir -! SFX W eír iamos eír -! SFX W egir ijamos egir -! SFX W emir imamos emir -! SFX W ormir urmamos ormir -! SFX W aber epamos saber -! SFX W caber quepamos caber -! SFX W erir iramos erir -! SFX W orir uramos orir -! SFX W ar áramos [^a]ndar -! SFX W ar áramos [^d]ar -! SFX W ar áramos [^n]dar -! SFX W r éramos alir -! SFX W r éramos ernir -! SFX W r éramos eunir -! SFX W r éramos ohibir -! SFX W er iéramos [^fh]acer -! SFX W er iéramos aler -! SFX W er iéramos e[cd]er -! SFX W er iéramos ender -! SFX W er iéramos er[dnt]er -! SFX W er iéramos o[clv]er -! SFX W er iéramos olver -! SFX W er iéramos or[cd]er -! SFX W eír iéramos eír -! SFX W ebir ibiéramos ebir -! SFX W acer iciéramos [fh]acer -! SFX W edir idiéramos edir -! SFX W endir indiéramos endir -! SFX W oder udiéramos oder -! SFX W egir igiéramos egir -! SFX W enchir inchiéramos enchir -! SFX W emir imiéramos emir -! SFX W ormir urmiéramos ormir -! SFX W enir iniéramos enir -! SFX W aber upiéramos aber -! SFX W erir iriéramos erir -! SFX W irir iriéramos irir -! SFX W orir uriéramos orir -! SFX W erer isiéramos erer -! SFX W oner usiéramos oner -! SFX W etir itiéramos etir -! SFX W entir intiéramos entir -! SFX W ertir irtiéramos ertir -! SFX W estir istiéramos estir -! SFX W eguir iguiéramos eguir -! SFX W ervir irviéramos ervir -! SFX W ar uviéramos andar -! SFX W ener uviéramos ener -! SFX W cir jéramos ucir -! SFX W er jéramos raer -! SFX W ecir ijéramos ecir -! SFX W er yéramos [eo]er -! SFX W er yéramos caer -! SFX W ir yéramos [^g]uir -! SFX W ír yéramos oír -! SFX W üir uyéramos güir -! SFX W eñir iñéramos eñir -! SFX W etir itamos etir -! SFX W entir intamos entir -! SFX W ertir irtamos ertir -! SFX W estir istamos estir -! SFX W ervir irvamos ervir -! SFX W er yamos oer -! SFX W ir yamos [^g]uir -! SFX W üir uyamos güir -! SFX W cer zamos cocer -! SFX W cer zamos orcer -! SFX W 0 íamos [^fh]acer -! SFX W 0 íamos [aeo]er -! SFX W 0 íamos [io]rir -! SFX W 0 íamos [üu]ir -! SFX W 0 íamos ar -! SFX W 0 íamos e[bdgmrtñ]ir -! SFX W 0 íamos e[cd]er -! SFX W 0 íamos e[ns]tir -! SFX W 0 íamos enchir -! SFX W 0 íamos ender -! SFX W 0 íamos endir -! SFX W 0 íamos er[dnt]er -! SFX W 0 íamos er[ntv]ir -! SFX W 0 íamos eunir -! SFX W 0 íamos o[clv]er -! SFX W 0 íamos olver -! SFX W 0 íamos or[cd]er -! SFX W 0 íamos ormir -! SFX W 0 íamos ucir -! SFX W er íamos er -! SFX W ir íamos ir -! SFX W ír íamos ír -! SFX W cer ríamos [fh]acer -! SFX W er ríamos aber -! SFX W er ríamos erer -! SFX W er ríamos oder -! SFX W er dríamos [eo]ner -! SFX W er dríamos aler -! SFX W ir dríamos alir -! SFX W ir dríamos enir -! SFX W ecir iríamos ecir -! SFX W ír iríamos [eo]ír -! SFX W eñir iñamos eñir -! SFX W 0 emos [^fh]acer -! SFX W 0 emos [aeo]er -! SFX W 0 emos [io]rir -! SFX W 0 emos [üu]ir -! SFX W 0 emos ar -! SFX W 0 emos e[bdgmrtñ]ir -! SFX W 0 emos e[cd]er -! SFX W 0 emos e[ns]tir -! SFX W 0 emos enchir -! SFX W 0 emos ender -! SFX W 0 emos endir -! SFX W 0 emos er[dnt]er -! SFX W 0 emos er[ntv]ir -! SFX W 0 emos eunir -! SFX W 0 emos o[clv]er -! SFX W 0 emos olver -! SFX W 0 emos or[cd]er -! SFX W 0 emos ormir -! SFX W 0 emos ucir -! SFX W ar emos [^g]uar -! SFX W ar emos [ae]hu[ms]ar -! SFX W ar emos [ae]ndar -! SFX W ar emos [aeo]hi[jlnt]ar -! SFX W ar emos ebrar -! SFX W ar emos edrar -! SFX W ar emos elar -! SFX W ar emos emblar -! SFX W ar emos embrar -! SFX W ar emos endrar -! SFX W ar emos ensar -! SFX W ar emos entar -! SFX W ar emos erbar -! SFX W ar emos ernar -! SFX W ar emos errar -! SFX W ar emos ertar -! SFX W ar emos esar -! SFX W ar emos estar -! SFX W ar emos etar -! SFX W ar emos evar -! SFX W ar emos obar -! SFX W ar emos oblar -! SFX W ar emos odar -! SFX W ar emos olar -! SFX W ar emos oldar -! SFX W ar emos ollar -! SFX W ar emos oltar -! SFX W ar emos onar -! SFX W ar emos ontar -! SFX W ar emos ontrar -! SFX W ar emos orar -! SFX W ar emos ordar -! SFX W ar emos ornar -! SFX W ar emos ortar -! SFX W ar emos osar -! SFX W ar emos ostar -! SFX W ar emos ostrar -! SFX W ar emos ovar -! SFX W ar emos oñar -! SFX W zar cemos [ae]izar -! SFX W zar cemos enzar -! SFX W zar cemos ezar -! SFX W zar cemos gonzar -! SFX W zar cemos orzar -! SFX W iar iemos iar -! SFX W cer remos [fh]acer -! SFX W er remos aber -! SFX W er remos erer -! SFX W er remos oder -! SFX W er dremos [eo]ner -! SFX W er dremos aler -! SFX W ir dremos alir -! SFX W ir dremos enir -! SFX W ecir iremos ecir -! SFX W ír iremos [eo]ír -! SFX W ar áremos [^a]ndar -! SFX W ar áremos [^d]ar -! SFX W ar áremos [^n]dar -! SFX W r éremos alir -! SFX W r éremos ernir -! SFX W r éremos eunir -! SFX W r éremos ohibir -! SFX W er iéremos [^fh]acer -! SFX W er iéremos aler -! SFX W er iéremos e[cd]er -! SFX W er iéremos ender -! SFX W er iéremos er[dnt]er -! SFX W er iéremos o[clv]er -! SFX W er iéremos olver -! SFX W er iéremos or[cd]er -! SFX W eír iéremos eír -! SFX W ebir ibiéremos ebir -! SFX W acer iciéremos [fh]acer -! SFX W edir idiéremos edir -! SFX W endir indiéremos endir -! SFX W oder udiéremos oder -! SFX W egir igiéremos egir -! SFX W enchir inchiéremos enchir -! SFX W emir imiéremos emir -! SFX W ormir urmiéremos ormir -! SFX W enir iniéremos enir -! SFX W aber upiéremos aber -! SFX W erir iriéremos erir -! SFX W irir iriéremos irir -! SFX W orir uriéremos orir -! SFX W erer isiéremos erer -! SFX W oner usiéremos oner -! SFX W etir itiéremos etir -! SFX W entir intiéremos entir -! SFX W ertir irtiéremos ertir -! SFX W estir istiéremos estir -! SFX W eguir iguiéremos eguir -! SFX W ervir irviéremos ervir -! SFX W ar uviéremos andar -! SFX W ener uviéremos ener -! SFX W cir jéremos ucir -! SFX W er jéremos raer -! SFX W ecir ijéremos ecir -! SFX W er yéremos [eo]er -! SFX W er yéremos caer -! SFX W ir yéremos [^g]uir -! SFX W ír yéremos oír -! SFX W üir uyéremos güir -! SFX W eñir iñéremos eñir -! SFX W ar ásemos [^d]ar -! SFX W ar ásemos [^n]dar -! SFX W r ásemos [^a]ndar -! SFX W r ésemos alir -! SFX W r ésemos ernir -! SFX W r ésemos eunir -! SFX W r ésemos ohibir -! SFX W er iésemos [^fh]acer -! SFX W er iésemos aler -! SFX W er iésemos e[cd]er -! SFX W er iésemos ender -! SFX W er iésemos er[dnt]er -! SFX W er iésemos o[clv]er -! SFX W er iésemos olver -! SFX W er iésemos or[cd]er -! SFX W eír iésemos eír -! SFX W ebir ibiésemos ebir -! SFX W acer iciésemos [fh]acer -! SFX W edir idiésemos edir -! SFX W endir indiésemos endir -! SFX W oder udiésemos oder -! SFX W egir igiésemos egir -! SFX W enchir inchiésemos enchir -! SFX W emir imiésemos emir -! SFX W ormir urmiésemos ormir -! SFX W enir iniésemos enir -! SFX W aber upiésemos aber -! SFX W erir iriésemos erir -! SFX W irir iriésemos irir -! SFX W orir uriésemos orir -! SFX W erer isiésemos erer -! SFX W oner usiésemos oner -! SFX W etir itiésemos etir -! SFX W entir intiésemos entir -! SFX W ertir irtiésemos ertir -! SFX W estir istiésemos estir -! SFX W eguir iguiésemos eguir -! SFX W ervir irviésemos ervir -! SFX W ar uviésemos andar -! SFX W ener uviésemos ener -! SFX W cir jésemos ucir -! SFX W er jésemos raer -! SFX W ecir ijésemos ecir -! SFX W er yésemos [eo]er -! SFX W er yésemos caer -! SFX W ir yésemos [^g]uir -! SFX W ír yésemos oír -! SFX W üir uyésemos güir -! SFX W eñir iñésemos eñir -! SFX W ar uemos olgar -! SFX W gar guemos egar -! SFX W gar guemos engar -! SFX W gar guemos ogar -! SFX W gar guemos ugar -! SFX W car quemos ocar -! SFX W car quemos olcar -! SFX W car quemos orcar -! SFX W uar üemos guar -! SFX W er imos [^fh]acer -! SFX W er imos aler -! SFX W er imos e[cd]er -! SFX W er imos ender -! SFX W er imos er[dnt]er -! SFX W er imos o[clv]er -! SFX W er imos olver -! SFX W er imos or[cd]er -! SFX W acer icimos [fh]acer -! SFX W oder udimos oder -! SFX W cir jimos ucir -! SFX W er jimos raer -! SFX W ecir ijimos ecir -! SFX W enir inimos enir -! SFX W aber upimos aber -! SFX W erer isimos erer -! SFX W oner usimos oner -! SFX W ar uvimos andar -! SFX W ener uvimos ener -! SFX W er ímos [eo]er -! SFX W er ímos caer -! -! -! -! SFX W Y 29 S -! SFX W 0 ás [^fh]acer -! SFX W 0 ás [aeo]er -! SFX W 0 ás [io]rir -! SFX W 0 ás [üu]ir -! SFX W 0 ás ar -! SFX W 0 ás e[bdgmrtñ]ir -! SFX W 0 ás e[cd]er -! SFX W 0 ás e[ns]tir -! SFX W 0 ás enchir -! SFX W 0 ás ender -! SFX W 0 ás endir -! SFX W 0 ás er[dnt]er -! SFX W 0 ás er[ntv]ir -! SFX W 0 ás eunir -! SFX W 0 ás o[clv]er -! SFX W 0 ás olver -! SFX W 0 ás or[cd]er -! SFX W 0 ás ormir -! SFX W 0 ás ucir -! SFX W cer rás [fh]acer -! SFX W er rás aber -! SFX W er rás erer -! SFX W er rás oder -! SFX W er drás [eo]ner -! SFX W er drás aler -! SFX W ir drás alir -! SFX W ir drás enir -! SFX W ecir irás ecir -! SFX W ír irás [eo]ír -! -! -! SFX W Y 29 S -! SFX W 0 á [^fh]acer -! SFX W 0 á [aeo]er -! SFX W 0 á [io]rir -! SFX W 0 á [üu]ir -! SFX W 0 á ar -! SFX W 0 á e[bdgmrtñ]ir -! SFX W 0 á e[cd]er -! SFX W 0 á e[ns]tir -! SFX W 0 á enchir -! SFX W 0 á ender -! SFX W 0 á endir -! SFX W 0 á er[dnt]er -! SFX W 0 á er[ntv]ir -! SFX W 0 á eunir -! SFX W 0 á o[clv]er -! SFX W 0 á olver -! SFX W 0 á or[cd]er -! SFX W 0 á ormir -! SFX W 0 á ucir -! SFX W cer rá [fh]acer -! SFX W er rá aber -! SFX W er rá erer -! SFX W er rá oder -! SFX W er drá [eo]ner -! SFX W er drá aler -! SFX W ir drá alir -! SFX W ir drá enir -! SFX W ecir irá ecir -! SFX W ír irá [eo]ír -! -! -! -! SFX W Y 38 S -! SFX W 0 é [^fh]acer -! SFX W 0 é [aeo]er -! SFX W 0 é [io]rir -! SFX W 0 é [üu]ir -! SFX W 0 é ar -! SFX W 0 é e[bdgmrtñ]ir -! SFX W 0 é e[cd]er -! SFX W 0 é e[ns]tir -! SFX W 0 é enchir -! SFX W 0 é ender -! SFX W 0 é endir -! SFX W 0 é er[dnt]er -! SFX W 0 é er[ntv]ir -! SFX W 0 é eunir -! SFX W 0 é o[clv]er -! SFX W 0 é olver -! SFX W 0 é or[cd]er -! SFX W 0 é ormir -! SFX W 0 é ucir -! SFX W aber é saber -! SFX W ar é [^a]ndar -! SFX W ar é [^cguzd]ar -! SFX W ar é [^g]uar -! SFX W ar é [^n]dar -! SFX W zar cé zar -! SFX W cer ré [fh]acer -! SFX W er ré aber -! SFX W er ré erer -! SFX W er ré oder -! SFX W er dré [eo]ner -! SFX W er dré aler -! SFX W ir dré alir -! SFX W ir dré enir -! SFX W ecir iré ecir -! SFX W ír iré [eo]ír -! SFX W ar ué gar -! SFX W car qué car -! SFX W uar üé guar -! -! -! SFX W Y 31 S -! SFX W er í [^fh]acer -! SFX W er í [eo]er -! SFX W er í aler -! SFX W er í caer -! SFX W er í e[cd]er -! SFX W er í ender -! SFX W er í er[dnt]er -! SFX W er í o[clv]er -! SFX W er í olver -! SFX W er í or[cd]er -! SFX W ir í [üu]ir -! SFX W ir í alir -! SFX W ir í ebir -! SFX W ir í edir -! SFX W ir í egir -! SFX W ir í emir -! SFX W ir í enchir -! SFX W ir í endir -! SFX W ir í entir -! SFX W ir í erir -! SFX W ir í ernir -! SFX W ir í ertir -! SFX W ir í ervir -! SFX W ir í estir -! SFX W ir í etir -! SFX W ir í eunir -! SFX W ir í eñir -! SFX W ir í irir -! SFX W ir í orir -! SFX W ir í ormir -! SFX W ír í [eo]ír -! -! -! -! SFX W Y 39 S -! SFX W ar ó [^a]ndar -! SFX W ar ó [^d]ar -! SFX W ar ó [^n]dar -! SFX W r ó alir -! SFX W r ó ernir -! SFX W r ó eunir -! SFX W r ó irir -! SFX W r ó ohibir -! SFX W er ió [^fh]acer -! SFX W er ió aler -! SFX W er ió e[cd]er -! SFX W er ió ender -! SFX W er ió er[dnt]er -! SFX W er ió o[clv]er -! SFX W er ió olver -! SFX W er ió or[cd]er -! SFX W er ió order -! SFX W eír ió eír -! SFX W ebir ibió ebir -! SFX W edir idió edir -! SFX W endir indió endir -! SFX W egir igió egir -! SFX W enchir inchió enchir -! SFX W emir imió emir -! SFX W ormir urmió ormir -! SFX W erir irió erir -! SFX W orir urió orir -! SFX W etir itió etir -! SFX W entir intió entir -! SFX W ertir irtió ertir -! SFX W estir istió estir -! SFX W eguir iguió eguir -! SFX W ervir irvió ervir -! SFX W er yó [eo]er -! SFX W er yó caer -! SFX W ir yó [^g]uir -! SFX W ír yó oír -! SFX W üir uyó güir -! SFX W eñir iñó eñir -! -! -! -! SFX W Y 21 -! SFX W r d [aeií]r -! SFX W r n [^c]ocer -! SFX W r n [cr]aer -! SFX W r n [eo]er -! SFX W r n a[bcl]er -! SFX W r n andar -! SFX W r n ecer -! SFX W r n guar -! SFX W r n oner -! SFX W r s [^c]ocer -! SFX W r s [cr]aer -! SFX W r s [eo]er -! SFX W r s a[bcl]er -! SFX W r s andar -! SFX W r s ecer -! SFX W r s guar -! SFX W r s oner -! SFX W r bais ar -! SFX W ir ís ir -! SFX W ír ís ír -! SFX W cer z [fh]acer -! -! SFX Y Y 102 -! SFX Y er ído [aeo]er -! SFX Y er ídos [aeo]er -! SFX Y er ída [aeo]er -! SFX Y er ídas [aeo]er -! SFX Y acer echo [fh]acer -! SFX Y acer echos [fh]acer -! SFX Y acer echa [fh]acer -! SFX Y acer echas [fh]acer -! SFX Y er ido oder -! SFX Y er idos oder -! SFX Y er ida oder -! SFX Y er idas oder -! SFX Y olver uelto olver -! SFX Y olver ueltos olver -! SFX Y olver uelta olver -! SFX Y olver ueltas olver -! SFX Y oner uesto oner -! SFX Y oner uestos oner -! SFX Y oner uesta oner -! SFX Y oner uestas oner -! SFX Y rir ierto abrir -! SFX Y rir iertos abrir -! SFX Y rir ierta abrir -! SFX Y rir iertas abrir -! SFX Y r do e[bdgmnrtñ]ir -! SFX Y r dos e[bdgmnrtñ]ir -! SFX Y r da e[bdgmnrtñ]ir -! SFX Y r das e[bdgmnrtñ]ir -! SFX Y ecir icho ecir -! SFX Y ecir ichos ecir -! SFX Y ecir icha ecir -! SFX Y ecir ichas ecir -! SFX Y r do [eo]ír -! SFX Y r dos [eo]ír -! SFX Y r da [eo]ír -! SFX Y r das [eo]ír -! SFX Y r do enchir -! SFX Y r dos enchir -! SFX Y r da enchir -! SFX Y r das enchir -! SFX Y r do en[dt]ir -! SFX Y r dos en[dt]ir -! SFX Y r da en[dt]ir -! SFX Y r das en[dt]ir -! SFX Y r do er[tv]ir -! SFX Y r dos er[tv]ir -! SFX Y r da er[tv]ir -! SFX Y r das er[tv]ir -! SFX Y r do estir -! SFX Y r dos estir -! SFX Y r da estir -! SFX Y r das estir -! SFX Y bir to ibir -! SFX Y bir tos ibir -! SFX Y bir ta ibir -! SFX Y bir tas ibir -! SFX Y orir uerto orir -! SFX Y orir uertos orir -! SFX Y orir uerta orir -! SFX Y orir uertas orir -! SFX Y r do ormir -! SFX Y r dos ormir -! SFX Y r da ormir -! SFX Y r das ormir -! SFX Y rir ierto ubrir -! SFX Y rir iertos ubrir -! SFX Y rir ierta ubrir -! SFX Y rir iertas ubrir -! SFX Y r do [üu]ir -! SFX Y r da [üu]ir -! SFX Y r dos [üu]ir -! SFX Y r das [üu]ir -! SFX Y er iendo [fh]acer -! SFX Y er yendo [aeo]er -! SFX Y oder udiendo oder -! SFX Y er iendo olver -! SFX Y er iendo oner -! SFX Y r endo abrir -! SFX Y ebir ibiendo ebir -! SFX Y ecir iciendo ecir -! SFX Y edir idiendo edir -! SFX Y egir igiendo egir -! SFX Y emir imiendo emir -! SFX Y eír iendo eír -! SFX Y eñir iñendo eñir -! SFX Y enchir inchiendo enchir -! SFX Y endir indiendo endir -! SFX Y enir iniendo enir -! SFX Y entir intiendo entir -! SFX Y ertir irtiendo ertir -! SFX Y ervir irviendo ervir -! SFX Y estir istiendo estir -! SFX Y eguir iguiendo eguir -! SFX Y erir iriendo erir -! SFX Y etir itiendo etir -! SFX Y r endo ibir -! SFX Y ír yendo oír -! SFX Y orir uriendo orir -! SFX Y ormir urmiendo ormir -! SFX Y r endo ubrir -! SFX Y ir yendo [^g]uir -! SFX Y üir uyendo güir -! -! SFX O Y 115 -! SFX O 0 me [eií]r -! SFX O 0 te [eií]r -! SFX O 0 se [eií]r -! SFX O 0 nos [eií]r -! SFX O 0 os [eií]r -! SFX O er yéndome [aeo]er -! SFX O er yéndote [aeo]er -! SFX O er yéndose [aeo]er -! SFX O er yéndonos [aeo]er -! SFX O er yéndoos [aeo]er -! SFX O oder udiéndome oder -! SFX O oder udiéndote oder -! SFX O oder udiéndose oder -! SFX O oder udiéndonos oder -! SFX O oder udiéndoos oder -! SFX O ebir ibiéndome ebir -! SFX O ebir ibiéndote ebir -! SFX O ebir ibiéndose ebir -! SFX O ebir ibiéndonos ebir -! SFX O ebir ibiéndoos ebir -! SFX O ecir iciéndome ecir -! SFX O ecir iciéndote ecir -! SFX O ecir iciéndose ecir -! SFX O ecir iciéndonos ecir -! SFX O ecir iciéndoos ecir -! SFX O edir idiéndome edir -! SFX O edir idiéndote edir -! SFX O edir idiéndose edir -! SFX O edir idiéndonos edir -! SFX O edir idiéndoos edir -! SFX O egir igiéndome egir -! SFX O egir igiéndote egir -! SFX O egir igiéndose egir -! SFX O egir igiéndonos egir -! SFX O egir igiéndoos egir -! SFX O emir imiéndome emir -! SFX O emir imiéndote emir -! SFX O emir imiéndose emir -! SFX O emir imiéndonos emir -! SFX O emir imiéndoos emir -! SFX O eír iéndome eír -! SFX O eír iéndote eír -! SFX O eír iéndose eír -! SFX O eír iéndonos eír -! SFX O eír iéndoos eír -! SFX O eñir iñéndome eñir -! SFX O eñir iñéndote eñir -! SFX O eñir iñéndose eñir -! SFX O eñir iñéndonos eñir -! SFX O eñir iñéndoos eñir -! SFX O endir indiéndome endir -! SFX O endir indiéndote endir -! SFX O endir indiéndose endir -! SFX O endir indiéndonos endir -! SFX O endir indiéndoos endir -! SFX O enir iniéndome enir -! SFX O enir iniéndote enir -! SFX O enir iniéndose enir -! SFX O enir iniéndonos enir -! SFX O enir iniéndoos enir -! SFX O entir intiéndome entir -! SFX O entir intiéndote entir -! SFX O entir intiéndose entir -! SFX O entir intiéndonos entir -! SFX O entir intiéndoos entir -! SFX O ertir irtiéndome ertir -! SFX O ertir irtiéndote ertir -! SFX O ertir irtiéndose ertir -! SFX O ertir irtiéndonos ertir -! SFX O ertir irtiéndoos ertir -! SFX O ervir irviéndome ervir -! SFX O ervir irviéndote ervir -! SFX O ervir irviéndose ervir -! SFX O ervir irviéndonos ervir -! SFX O ervir irviéndoos ervir -! SFX O estir istiéndome estir -! SFX O estir istiéndote estir -! SFX O estir istiéndose estir -! SFX O estir istiéndonos estir -! SFX O estir istiéndoos estir -! SFX O eguir iguiéndome eguir -! SFX O eguir iguiéndote eguir -! SFX O eguir iguiéndose eguir -! SFX O eguir iguiéndonos eguir -! SFX O eguir iguiéndoos eguir -! SFX O erir iriéndome erir -! SFX O erir iriéndote erir -! SFX O erir iriéndose erir -! SFX O erir iriéndonos erir -! SFX O erir iriéndoos erir -! SFX O etir itiéndome etir -! SFX O etir itiéndote etir -! SFX O etir itiéndose etir -! SFX O etir itiéndonos etir -! SFX O etir itiéndoos etir -! SFX O ír yéndome oír -! SFX O ír yéndote oír -! SFX O ír yéndose oír -! SFX O ír yéndonos oír -! SFX O ír yéndoos oír -! SFX O orir uriéndome orir -! SFX O orir uriéndote orir -! SFX O orir uriéndose orir -! SFX O orir uriéndonos orir -! SFX O orir uriéndoos orir -! SFX O ormir urmiéndome ormir -! SFX O ormir urmiéndote ormir -! SFX O ormir urmiéndose ormir -! SFX O ormir urmiéndonos ormir -! SFX O ormir urmiéndoos ormir -! SFX O ir yéndome [^g]uir -! SFX O ir yéndote [^g]uir -! SFX O ir yéndose [^g]uir -! SFX O ir yéndonos [^g]uir -! SFX O ir yéndoos [^g]uir -! -! SFX Q Y 138 -! SFX Q 0 lo [eií]r -! SFX Q 0 la [eií]r -! SFX Q 0 los [eií]r -! SFX Q 0 las [eií]r -! SFX Q 0 le [eií]r -! SFX Q 0 les [eií]r -! SFX Q er yéndolo [aeo]er -! SFX Q er yéndola [aeo]er -! SFX Q er yéndolos [aeo]er -! SFX Q er yéndolas [aeo]er -! SFX Q er yéndole [aeo]er -! SFX Q er yéndoles [aeo]er -! SFX Q oder udiéndolo oder -! SFX Q oder udiéndola oder -! SFX Q oder udiéndolos oder -! SFX Q oder udiéndolas oder -! SFX Q oder udiéndole oder -! SFX Q oder udiéndoles oder -! SFX Q ebir ibiéndolo ebir -! SFX Q ebir ibiéndolos ebir -! SFX Q ebir ibiéndola ebir -! SFX Q ebir ibiéndolas ebir -! SFX Q ebir ibiéndole ebir -! SFX Q ebir ibiéndoles ebir -! SFX Q ecir iciéndolo ecir -! SFX Q ecir iciéndolos ecir -! SFX Q ecir iciéndola ecir -! SFX Q ecir iciéndolas ecir -! SFX Q ecir iciéndole ecir -! SFX Q ecir iciéndoles ecir -! SFX Q edir idiéndolo edir -! SFX Q edir idiéndolos edir -! SFX Q edir idiéndola edir -! SFX Q edir idiéndolas edir -! SFX Q edir idiéndole edir -! SFX Q edir idiéndoles edir -! SFX Q egir igiéndolo egir -! SFX Q egir igiéndolos egir -! SFX Q egir igiéndola egir -! SFX Q egir igiéndolas egir -! SFX Q egir igiéndole egir -! SFX Q egir igiéndoles egir -! SFX Q emir imiéndolo emir -! SFX Q emir imiéndolos emir -! SFX Q emir imiéndola emir -! SFX Q emir imiéndolas emir -! SFX Q emir imiéndole emir -! SFX Q emir imiéndoles emir -! SFX Q eír iéndolo eír -! SFX Q eír iéndolos eír -! SFX Q eír iéndola eír -! SFX Q eír iéndolas eír -! SFX Q eír iéndole eír -! SFX Q eír iéndoles eír -! SFX Q eñir iñéndolo eñir -! SFX Q eñir iñéndolos eñir -! SFX Q eñir iñéndola eñir -! SFX Q eñir iñéndolas eñir -! SFX Q eñir iñéndole eñir -! SFX Q eñir iñéndoles eñir -! SFX Q endir indiéndolo endir -! SFX Q endir indiéndolos endir -! SFX Q endir indiéndola endir -! SFX Q endir indiéndolas endir -! SFX Q endir indiéndole endir -! SFX Q endir indiéndoles endir -! SFX Q enir iniéndolo enir -! SFX Q enir iniéndolos enir -! SFX Q enir iniéndola enir -! SFX Q enir iniéndolas enir -! SFX Q enir iniéndole enir -! SFX Q enir iniéndoles enir -! SFX Q entir intiéndolo entir -! SFX Q entir intiéndolos entir -! SFX Q entir intiéndola entir -! SFX Q entir intiéndolas entir -! SFX Q entir intiéndole entir -! SFX Q entir intiéndoles entir -! SFX Q ertir irtiéndolo ertir -! SFX Q ertir irtiéndolos ertir -! SFX Q ertir irtiéndola ertir -! SFX Q ertir irtiéndolas ertir -! SFX Q ertir irtiéndole ertir -! SFX Q ertir irtiéndoles ertir -! SFX Q ervir irviéndolo ervir -! SFX Q ervir irviéndolos ervir -! SFX Q ervir irviéndola ervir -! SFX Q ervir irviéndolas ervir -! SFX Q ervir irviéndole ervir -! SFX Q ervir irviéndoles ervir -! SFX Q estir istiéndolo estir -! SFX Q estir istiéndolos estir -! SFX Q estir istiéndola estir -! SFX Q estir istiéndolas estir -! SFX Q estir istiéndole estir -! SFX Q estir istiéndoles estir -! SFX Q eguir iguiéndolo eguir -! SFX Q eguir iguiéndolos eguir -! SFX Q eguir iguiéndola eguir -! SFX Q eguir iguiéndolas eguir -! SFX Q eguir iguiéndole eguir -! SFX Q eguir iguiéndoles eguir -! SFX Q erir iriéndolo erir -! SFX Q erir iriéndolos erir -! SFX Q erir iriéndola erir -! SFX Q erir iriéndolas erir -! SFX Q erir iriéndole erir -! SFX Q erir iriéndoles erir -! SFX Q etir itiéndolo etir -! SFX Q etir itiéndolos etir -! SFX Q etir itiéndola etir -! SFX Q etir itiéndolas etir -! SFX Q etir itiéndole etir -! SFX Q etir itiéndoles etir -! SFX Q ír yéndolo oír -! SFX Q ír yéndolos oír -! SFX Q ír yéndola oír -! SFX Q ír yéndolas oír -! SFX Q ír yéndole oír -! SFX Q ír yéndoles oír -! SFX Q orir uriéndolo orir -! SFX Q orir uriéndolos orir -! SFX Q orir uriéndola orir -! SFX Q orir uriéndolas orir -! SFX Q orir uriéndole orir -! SFX Q orir uriéndoles orir -! SFX Q ormir urmiéndolo ormir -! SFX Q ormir urmiéndolos ormir -! SFX Q ormir urmiéndola ormir -! SFX Q ormir urmiéndolas ormir -! SFX Q ormir urmiéndole ormir -! SFX Q ormir urmiéndoles ormir -! SFX Q ir yéndolo [^g]uir -! SFX Q ir yéndolos [^g]uir -! SFX Q ir yéndola [^g]uir -! SFX Q ir yéndolas [^g]uir -! SFX Q ir yéndole [^g]uir -! SFX Q ir yéndoles [^g]uir -! -! SFX Z Y 171 -! SFX Z er érmelo er -! SFX Z er érmela er -! SFX Z er érmelos er -! SFX Z er érmelas er -! SFX Z er értelo er -! SFX Z er értela er -! SFX Z er értelos er -! SFX Z er értelas er -! SFX Z er érselo er -! SFX Z er érsela er -! SFX Z er érselos er -! SFX Z er érselas er -! SFX Z er éroslo er -! SFX Z er érosla er -! SFX Z er éroslos er -! SFX Z er éroslas er -! SFX Z er érnoslo er -! SFX Z er érnosla er -! SFX Z er érnoslos er -! SFX Z er érnoslas er -! SFX Z er érnosles er -! SFX Z ir írmelo ir -! SFX Z ir írmela ir -! SFX Z ir írmele ir -! SFX Z ir írmelos ir -! SFX Z ir írmelas ir -! SFX Z ir írmeles ir -! SFX Z ir írtelo ir -! SFX Z ir írtela ir -! SFX Z ir írtele ir -! SFX Z ir írtelos ir -! SFX Z ir írtelas ir -! SFX Z ir írteles ir -! SFX Z ir írselo ir -! SFX Z ir írsela ir -! SFX Z ir írsele ir -! SFX Z ir írselos ir -! SFX Z ir írselas ir -! SFX Z ir írseles ir -! SFX Z ir íroslo ir -! SFX Z ir írosla ir -! SFX Z ir írosle ir -! SFX Z ir íroslos ir -! SFX Z ir íroslas ir -! SFX Z ir írosles ir -! SFX Z ir írnoslo ir -! SFX Z ir írnosla ir -! SFX Z ir írnosle ir -! SFX Z ir írnoslos ir -! SFX Z ir írnoslas ir -! SFX Z ir írnosles ir -! SFX Z er yéndomelo [aeo]er -! SFX Z er yéndomela [aeo]er -! SFX Z er yéndomele [aeo]er -! SFX Z er yéndomelos [aeo]er -! SFX Z er yéndomelas [aeo]er -! SFX Z er yéndomeles [aeo]er -! SFX Z er yéndotelo [aeo]er -! SFX Z er yéndotela [aeo]er -! SFX Z er yéndotele [aeo]er -! SFX Z er yéndotelos [aeo]er -! SFX Z er yéndotelas [aeo]er -! SFX Z er yéndoteles [aeo]er -! SFX Z er yéndoselo [aeo]er -! SFX Z er yéndosela [aeo]er -! SFX Z er yéndosele [aeo]er -! SFX Z er yéndoselos [aeo]er -! SFX Z er yéndoselas [aeo]er -! SFX Z er yéndoseles [aeo]er -! SFX Z er yéndooslo [aeo]er -! SFX Z er yéndoosla [aeo]er -! SFX Z er yéndoosle [aeo]er -! SFX Z er yéndooslos [aeo]er -! SFX Z er yéndooslas [aeo]er -! SFX Z er yéndoosles [aeo]er -! SFX Z er yéndonoslo [aeo]er -! SFX Z er yéndonosla [aeo]er -! SFX Z er yéndonosle [aeo]er -! SFX Z er yéndonoslos [aeo]er -! SFX Z er yéndonoslas [aeo]er -! SFX Z er yéndonosles [aeo]er -! SFX Z ir yéndomelo [^g]uir -! SFX Z ir yéndomelos [^g]uir -! SFX Z ir yéndomela [^g]uir -! SFX Z ir yéndomelas [^g]uir -! SFX Z ir yéndomele [^g]uir -! SFX Z ir yéndomeles [^g]uir -! SFX Z ir yéndotelo [^g]uir -! SFX Z ir yéndotelos [^g]uir -! SFX Z ir yéndotela [^g]uir -! SFX Z ir yéndotelas [^g]uir -! SFX Z ir yéndotele [^g]uir -! SFX Z ir yéndoteles [^g]uir -! SFX Z ir yéndoselo [^g]uir -! SFX Z ir yéndoselos [^g]uir -! SFX Z ir yéndosela [^g]uir -! SFX Z ir yéndoselas [^g]uir -! SFX Z ir yéndosele [^g]uir -! SFX Z ir yéndoseles [^g]uir -! SFX Z ir yéndooslo [^g]uir -! SFX Z ir yéndooslos [^g]uir -! SFX Z ir yéndoosla [^g]uir -! SFX Z ir yéndooslas [^g]uir -! SFX Z ir yéndoosle [^g]uir -! SFX Z ir yéndoosles [^g]uir -! SFX Z ir yéndonoslo [^g]uir -! SFX Z ir yéndonoslos [^g]uir -! SFX Z ir yéndonosla [^g]uir -! SFX Z ir yéndonoslas [^g]uir -! SFX Z ir yéndonosle [^g]uir -! SFX Z ir yéndonosles [^g]uir -! SFX Z egir igiéndomelo egir -! SFX Z egir igiéndomelos egir -! SFX Z egir igiéndomela egir -! SFX Z egir igiéndomelas egir -! SFX Z egir igiéndomele egir -! SFX Z egir igiéndomeles egir -! SFX Z egir igiéndotelo egir -! SFX Z egir igiéndotelos egir -! SFX Z egir igiéndotela egir -! SFX Z egir igiéndotelas egir -! SFX Z egir igiéndotele egir -! SFX Z egir igiéndoteles egir -! SFX Z egir igiéndoselo egir -! SFX Z egir igiéndoselos egir -! SFX Z egir igiéndosela egir -! SFX Z egir igiéndoselas egir -! SFX Z egir igiéndosele egir -! SFX Z egir igiéndoseles egir -! SFX Z egir igiéndooslo egir -! SFX Z egir igiéndooslos egir -! SFX Z egir igiéndoosla egir -! SFX Z egir igiéndooslas egir -! SFX Z egir igiéndoosle egir -! SFX Z egir igiéndoosles egir -! SFX Z egir igiéndonoslo egir -! SFX Z egir igiéndonoslos egir -! SFX Z egir igiéndonosla egir -! SFX Z egir igiéndonoslas egir -! SFX Z egir igiéndonosle egir -! SFX Z egir igiéndonosles egir -! SFX Z eguir iguiéndomelo eguir -! SFX Z eguir iguiéndomelos eguir -! SFX Z eguir iguiéndomela eguir -! SFX Z eguir iguiéndomelas eguir -! SFX Z eguir iguiéndomele eguir -! SFX Z eguir iguiéndomeles eguir -! SFX Z eguir iguiéndotelo eguir -! SFX Z eguir iguiéndotelos eguir -! SFX Z eguir iguiéndotela eguir -! SFX Z eguir iguiéndotelas eguir -! SFX Z eguir iguiéndotele eguir -! SFX Z eguir iguiéndoteles eguir -! SFX Z eguir iguiéndoselo eguir -! SFX Z eguir iguiéndoselos eguir -! SFX Z eguir iguiéndosela eguir -! SFX Z eguir iguiéndoselas eguir -! SFX Z eguir iguiéndosele eguir -! SFX Z eguir iguiéndoseles eguir -! SFX Z eguir iguiéndooslo eguir -! SFX Z eguir iguiéndooslos eguir -! SFX Z eguir iguiéndoosla eguir -! SFX Z eguir iguiéndooslas eguir -! SFX Z eguir iguiéndoosle eguir -! SFX Z eguir iguiéndoosles eguir -! SFX Z eguir iguiéndonoslo eguir -! SFX Z eguir iguiéndonoslos eguir -! SFX Z eguir iguiéndonosla eguir -! SFX Z eguir iguiéndonoslas eguir -! SFX Z eguir iguiéndonosle eguir -! SFX Z eguir iguiéndonosles eguir -*** es_MX.orig.dic Thu Aug 25 19:19:45 2005 ---- es_MX.dic Thu Aug 25 20:15:59 2005 -*************** -*** 1218,1220 **** - Internet -- intraocular - Irapuato ---- 1218,1219 ---- -*************** -*** 33345,33347 **** - nanear/PSVWX -- nanche/S - nanjea/S ---- 33344,33345 ---- diff --git a/share/vim/vim72/spell/es/main.aap b/share/vim/vim72/spell/es/main.aap deleted file mode 100644 index 3a03bffe0a..0000000000 --- a/share/vim/vim72/spell/es/main.aap +++ /dev/null @@ -1,92 +0,0 @@ -# Aap recipe for Spanish Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -REGIONS = ES MX -ES_REGIONS = es_$*REGIONS - -SPELLDIR = .. -FILES = es_$*(REGIONS).aff es_$*(REGIONS).dic - -ZIPFILE_ES = es_ES.zip -ZIPFILE_MX = es_MX.zip -ZIPFILES = $ZIPFILE_ES $ZIPFILE_MX - -READMES = README_es_$*(REGIONS).txt - -all: $SPELLDIR/es.latin1.spl $SPELLDIR/es.utf-8.spl ../README_es.txt - -$SPELLDIR/es.latin1.spl : $FILES - :sys env LANG=es_ES.ISO8859-1 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/es $ES_REGIONS" -c q - -$SPELLDIR/es.utf-8.spl : $FILES - :sys env LANG=es_ES.UTF-8 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/es $ES_REGIONS" -c q - -../README_es.txt: $READMES - :print es_ES >! $target - :cat README_es_ES.txt >> $target - :print =================================================== >>$target - :print es_MX >> $target - :cat README_es_MX.txt >> $target - -# -# Fetching the files from the OpenOffice.org site. -# The OLDSPELL file comes from elsewhere -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} $ZIPFILES - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -es_ES.aff es_ES.dic: {buildcheck=} - :assertpkg unzip patch - :fetch $ZIPFILE_ES - :sys $UNZIP $ZIPFILE_ES - :delete Changelog_es_ES.txt - :delete $ZIPFILE_ES - @if not os.path.exists('es_ES.orig.aff'): - :copy es_ES.aff es_ES.orig.aff - @if not os.path.exists('es_ES.orig.dic'): - :copy es_ES.dic es_ES.orig.dic - @if os.path.exists('es_ES.diff'): - :sys patch <es_ES.diff - -es_MX.aff es_MX.dic: {buildcheck=} - :assertpkg unzip patch - :fetch $ZIPFILE_MX - :print No copyright information for es_MX wordlist >! README_es_MX.txt - :sys $UNZIP $ZIPFILE_MX - :delete $ZIPFILE_MX - :sys $VIM -e -c "set ff=unix | wq" es_MX.dic - @if not os.path.exists('es_MX.orig.aff'): - :copy es_MX.aff es_MX.orig.aff - @if not os.path.exists('es_MX.orig.dic'): - :copy es_MX.dic es_MX.orig.dic - @if os.path.exists('es_MX.diff'): - :sys patch <es_MX.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. -diff: - :assertpkg diff - :sys {force} diff -a -C 1 es_ES.orig.aff es_ES.aff >es_ES.diff - :sys {force} diff -a -C 1 es_ES.orig.dic es_ES.dic >>es_ES.diff - :sys {force} diff -a -C 1 es_MX.orig.aff es_MX.aff >es_MX.diff - :sys {force} diff -a -C 1 es_MX.orig.dic es_MX.dic >>es_MX.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :print TODO!!!! - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/fr/main.aap b/share/vim/vim72/spell/fr/main.aap deleted file mode 100644 index b207b6e662..0000000000 --- a/share/vim/vim72/spell/fr/main.aap +++ /dev/null @@ -1,126 +0,0 @@ -# Aap recipe for French Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = fr_FR.aff fr_FR.dic - -all: $SPELLDIR/fr.latin1.spl $SPELLDIR/fr.utf-8.spl ../README_fr.txt - -# The spell file is iso-8859-15, but Vim normally uses "latin1" for this. -# This is OK for the utf-8 files, but for latin1 we need to avoid the "oe" -# character. When unpacking we create four files: -# fr_FR_latin1.aff modified file -# fr_FR_latin1.dic modified file -# fr_FR_iso15.aff original file (after applying diff) -# fr_FR_iso15.dic original file (after applying diff) -# Just before using the dictionary files, the right ones are copied to -# fr_FR.aff -# fr_FR.dic - -$SPELLDIR/fr.latin1.spl : $FILES - :copy {force} fr_FR_latin1.aff fr_FR.aff - :copy {force} fr_FR_latin1.dic fr_FR.dic - :sys env LANG=fr_FR.ISO8859-15 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/fr fr_FR" -c q - -$SPELLDIR/fr.utf-8.spl : $FILES - :copy {force} fr_FR_iso15.aff fr_FR.aff - :copy {force} fr_FR_iso15.dic fr_FR.dic - :sys env LANG=fr_FR.UTF-8 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/fr fr_FR" -c q - -../README_fr.txt : README_fr_FR.txt - :cat $source >!$target - -# -# Used to fetch the files from OpenOffice.org. Those are old. -# Later versions are elsewhere. -# -#OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -ZIPFILE = http://dico.savant.free.fr/_download/fr_FR_1-1-6.zip - -:attr {fetch = $ZIPFILE} fr_FR.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -fr_FR.aff fr_FR.dic: {buildcheck=} - :assertpkg unzip patch - :fetch fr_FR.zip - :sys $UNZIP fr_FR.zip - :delete fr_FR.zip - @if not os.path.exists('fr_FR.orig.aff'): - :copy fr_FR.aff fr_FR.orig.aff - @if not os.path.exists('fr_FR.orig.dic'): - :copy fr_FR.dic fr_FR.orig.dic - @if os.path.exists('fr_FR.diff'): - :sys patch <fr_FR.diff - - # Keep the unmodified files (after diff) for ISO-8859-15. - :copy fr_FR.aff fr_FR_iso15.aff - :copy fr_FR.dic fr_FR_iso15.dic - # For the latin1 .dic file change all the "oe" characters to the two - # characters "oe". - :sys $VIM -u NONE -e -c "set enc=latin1" - -c "e fr_FR.dic" - -c "%s/½/oe/g" - -c "w! fr_FR_latin1.dic" - -c q - # For the latin1 .aff file delete all the "oe" and "OE" characters and - # delete the REP lines with those characters. - :sys $VIM -u NONE -e -c "set enc=latin1" - -c "e fr_FR.aff" - -c "%s/½//g" - -c "%s/¼//g" - -c "%g/REP.*oe/d" - -c "w! fr_FR_latin1.aff" - -c q - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. -# This uses the iso-8859-15 files. -diff: - :assertpkg diff - :copy {force} fr_FR_iso15.aff fr_FR.aff - :copy {force} fr_FR_iso15.dic fr_FR.dic - :sys {force} diff -a -C 1 fr_FR.orig.aff fr_FR.aff >fr_FR.diff - :sys {force} diff -a -C 1 fr_FR.orig.dic fr_FR.dic >>fr_FR.diff - -# Delete all the unpacked and generated files, including the "orig" files. -clean: - :delete {force} fr_FR.zip fr_FR.aff fr_FR.dic - fr_FR.aff.orig fr_FR.dic.orig - fr_FR.orig.aff fr_FR.orig.dic - fr_FR_latin1.aff fr_FR_latin1.dic - fr_FR_iso15.aff fr_FR_iso15.dic - README_fr_FR.txt - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch fr_FR.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../fr_FR.zip - :sys {force} diff ../fr_FR.orig.aff fr_FR.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy fr_FR.aff ../fr_FR.new.aff - :sys {force} diff ../fr_FR.orig.dic fr_FR.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy fr_FR.dic ../fr_FR.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete fr_FR.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/gd/main.aap b/share/vim/vim72/spell/gd/main.aap deleted file mode 100644 index 658cbfc057..0000000000 --- a/share/vim/vim72/spell/gd/main.aap +++ /dev/null @@ -1,77 +0,0 @@ -# Aap recipe for Scottish Gaelic Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = gd_GB.aff gd_GB.dic - -all: $SPELLDIR/gd.latin1.spl $SPELLDIR/gd.utf-8.spl ../README_gd.txt - -$SPELLDIR/gd.latin1.spl : $FILES - :sys env LANG=gd_GB.ISO8859-1 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/gd gd_GB" -c q - -$SPELLDIR/gd.utf-8.spl : $FILES - :sys $VIM -u NONE -e -c "set enc=utf-8" -c "mkspell! $SPELLDIR/gd gd_GB" -c q - -../README_gd.txt : README_gd_GB.txt - :copy $source $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} gd_GB.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -gd_GB.aff gd_GB.dic: {buildcheck=} - :assertpkg unzip patch - :fetch gd_GB.zip - :sys $UNZIP gd_GB.zip - :delete gd_GB.zip - @if not os.path.exists('gd_GB.orig.aff'): - :copy gd_GB.aff gd_GB.orig.aff - @if not os.path.exists('gd_GB.orig.dic'): - :copy gd_GB.dic gd_GB.orig.dic - @if os.path.exists('gd_GB.diff'): - :sys patch <gd_GB.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 gd_GB.orig.aff gd_GB.aff >gd_GB.diff - :sys {force} diff -a -C 1 gd_GB.orig.dic gd_GB.dic >>gd_GB.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch gd_GB.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../gd_GB.zip - :sys {force} diff ../gd_GB.orig.aff gd_GB.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy gd_GB.aff ../gd_GB.new.aff - :sys {force} diff ../gd_GB.orig.dic gd_GB.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy gd_GB.dic ../gd_GB.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete gd_GB.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/ku/main.aap b/share/vim/vim72/spell/ku/main.aap deleted file mode 100644 index 200fb2f1e3..0000000000 --- a/share/vim/vim72/spell/ku/main.aap +++ /dev/null @@ -1,82 +0,0 @@ -# Aap recipe for Kurdish Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = ku_TR.aff ku_TR.dic - -# I don't have a Kurdish locale, us the Turkish one. -all: $SPELLDIR/ku.iso-8859-9.spl $SPELLDIR/ku.utf-8.spl \ - ../README_ku.txt - -$SPELLDIR/ku.iso-8859-9.spl : $FILES - :sys env LANG=tr_TR.ISO8859-9 $VIM -u NONE -e -c "mkspell! $SPELLDIR/ku ku_TR" -c q - -$SPELLDIR/ku.utf-8.spl : $FILES - :sys env LANG=tr_TR.UTF-8 $VIM -u NONE -e -c "mkspell! $SPELLDIR/ku ku_TR" -c q - -../README_ku.txt: README_ku_TR.txt - :copy $source $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} ku_TR.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -# This is a bit tricky, since the file name includes the date. -ku_TR.aff ku_TR.dic: {buildcheck=} - :assertpkg unzip patch - :fetch ku_TR.zip - :sys $UNZIP ku_TR.zip - :delete ku_TR.zip - :sys $VIM ku_TR.aff -e -c "set ff=unix" -c update -c q - :sys $VIM ku_TR.dic -e -c "set ff=unix" -c update -c q - :sys $VIM README_ku_TR.txt -e -c "set ff=unix" -c update -c q - @if not os.path.exists('ku_TR.orig.aff'): - :copy ku_TR.aff ku_TR.orig.aff - @if not os.path.exists('ku_TR.orig.dic'): - :copy ku_TR.dic ku_TR.orig.dic - @if os.path.exists('ku_TR.diff'): - :sys patch <ku_TR.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 ku_TR.orig.aff ku_TR.aff >ku_TR.diff - :sys {force} diff -a -C 1 ku_TR.orig.dic ku_TR.dic >>ku_TR.diff - - -# Check for updated spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch ku_TR.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../ku_TR.zip - :sys {force} diff ../ku_TR.orig.aff ku_TR.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy ku_TR.aff ../ku_TR.new.aff - :sys {force} diff ../ku_TR.orig.dic ku_TR.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy ku_TR.dic ../ku_TR.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete ku_TR.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/la/main.aap b/share/vim/vim72/spell/la/main.aap deleted file mode 100644 index 0cf1d8ab3a..0000000000 --- a/share/vim/vim72/spell/la/main.aap +++ /dev/null @@ -1,78 +0,0 @@ -# Aap recipe for Latin Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = la.aff la.dic - -all: $SPELLDIR/la.latin1.spl $SPELLDIR/la.utf-8.spl ../README_la.txt - -$SPELLDIR/la.latin1.spl : $FILES - :sys env LANG=la_LN.ISO8859-1 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/la la" -c q - -$SPELLDIR/la.utf-8.spl : $FILES - :sys $VIM -u NONE -e -c "set enc=utf-8" - -c "mkspell! $SPELLDIR/la la" -c q - -../README_la.txt : README_la.txt - :copy $source $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} la.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -la.aff la.dic: {buildcheck=} - :assertpkg unzip patch - :fetch la.zip - :sys $UNZIP la.zip - :delete la.zip - @if not os.path.exists('la.orig.aff'): - :copy la.aff la.orig.aff - @if not os.path.exists('la.orig.dic'): - :copy la.dic la.orig.dic - @if os.path.exists('la.diff'): - :sys patch <la.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 la.orig.aff la.aff >la.diff - :sys {force} diff -a -C 1 la.orig.dic la.dic >>la.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch la.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../la.zip - :sys {force} diff ../la.orig.aff la.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy la.aff ../la.new.aff - :sys {force} diff ../la.orig.dic la.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy la.dic ../la.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete la.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/lv/main.aap b/share/vim/vim72/spell/lv/main.aap deleted file mode 100644 index 10cacd82a6..0000000000 --- a/share/vim/vim72/spell/lv/main.aap +++ /dev/null @@ -1,83 +0,0 @@ -# Aap recipe for Latvian Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = lv_LV.aff lv_LV.dic - -# I don't have a Latvian locale, use Lithuanian instead. -all: $SPELLDIR/lv.iso-8859-13.spl $SPELLDIR/lv.utf-8.spl \ - ../README_lv.txt - -$SPELLDIR/lv.iso-8859-13.spl : $FILES - :sys env LANG=lt_LT.ISO8859-13 $VIM -u NONE -e -c "mkspell! $SPELLDIR/lv lv_LV" -c q - -$SPELLDIR/lv.utf-8.spl : $FILES - :sys env LANG=lt_LT.UTF-8 $VIM -u NONE -e -c "mkspell! $SPELLDIR/lv lv_LV" -c q - -../README_lv.txt: README_lv_LV.txt - :copy $source $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} lv_LV.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -# This is a bit tricky, since the file name includes the date. -lv_LV.aff lv_LV.dic: {buildcheck=} - :assertpkg unzip patch - :fetch lv_LV.zip - :sys $UNZIP lv_LV.zip - :delete lv_LV.zip - :delete changelog.txt gpl.txt lin-lv_LV_add.sh win-lv_LV_add.bat - :sys $VIM lv_LV.aff -e -N -c "%s/\r//" -c update -c q - :sys $VIM lv_LV.dic -e -N -c "%s/\r//" -c update -c q - :sys $VIM README_lv_LV.txt -e -c "set ff=unix" -c update -c q - @if not os.path.exists('lv_LV.orig.aff'): - :copy lv_LV.aff lv_LV.orig.aff - @if not os.path.exists('lv_LV.orig.dic'): - :copy lv_LV.dic lv_LV.orig.dic - @if os.path.exists('lv_LV.diff'): - :sys patch <lv_LV.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 lv_LV.orig.aff lv_LV.aff >lv_LV.diff - :sys {force} diff -a -C 1 lv_LV.orig.dic lv_LV.dic >>lv_LV.diff - - -# Check for updated spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch lv_LV.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../lv_LV.zip - :sys {force} diff ../lv_LV.orig.aff lv_LV.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy lv_LV.aff ../lv_LV.new.aff - :sys {force} diff ../lv_LV.orig.dic lv_LV.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy lv_LV.dic ../lv_LV.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete lv_LV.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/main.aap b/share/vim/vim72/spell/main.aap deleted file mode 100644 index a0e1fe3a2e..0000000000 --- a/share/vim/vim72/spell/main.aap +++ /dev/null @@ -1,26 +0,0 @@ -# Toplevel Aap recipe for Vim spell files -# -# Usage: -# aap generate all the .spl files -# aap diff create all the diff files - -# "hu" is at the end, because it takes a very long time. -LANG = af am bg ca cs cy da de el en eo es fr fo ga gd gl he hr id it ku - la lt lv mg mi ms nb nl nn ny pl pt ro ru rw sk sl sv sw - tet th tl tn uk yi zu hu - -# TODO: -# Finnish doesn't work, the dictionary fi_FI.zip file contains hyphenation... - -diff: $*LANG/diff - :print Done. - -@for l in string.split(_no.LANG): - :child $l/main.aap - -# The existing .spl files need to be generated when the spell file format -# changes. Depending on the Vim executable does that, but results in doing it -# much too often. Generate a dummy .spl file and let the .spl depend on it, so -# that they are outdated when it changes. -:child check/main.aap -*.spl: check/check.latin1.spl diff --git a/share/vim/vim72/spell/ms/main.aap b/share/vim/vim72/spell/ms/main.aap deleted file mode 100644 index 5716b3b692..0000000000 --- a/share/vim/vim72/spell/ms/main.aap +++ /dev/null @@ -1,81 +0,0 @@ -# Aap recipe for Malay Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = ms_MY.aff ms_MY.dic - -# I do not have a Malay locale, use the Dutch one instead. -all: $SPELLDIR/ms.latin1.spl $SPELLDIR/ms.utf-8.spl ../README_ms.txt - -$SPELLDIR/ms.latin1.spl : $FILES - :sys env LANG=nl_NL.ISO8859-1 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/ms ms_MY" -c q - -$SPELLDIR/ms.utf-8.spl : $FILES - :sys env LANG=nl_NL.UTF-8 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/ms ms_MY" -c q - -../README_ms.txt : README_ms_MY.txt - :copy $source $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} ms_MY.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -ms_MY.aff ms_MY.dic: {buildcheck=} - :assertpkg unzip patch - :fetch ms_MY.zip - :sys $UNZIP ms_MY.zip - :delete ms_MY.zip - :sys $VIM ms_MY.aff -e -c "set ff=unix" -c update -c q - :sys $VIM ms_MY.dic -e -c "set ff=unix" -c update -c q - @if not os.path.exists('ms_MY.orig.aff'): - :copy ms_MY.aff ms_MY.orig.aff - @if not os.path.exists('ms_MY.orig.dic'): - :copy ms_MY.dic ms_MY.orig.dic - @if os.path.exists('ms_MY.diff'): - :sys patch <ms_MY.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 ms_MY.orig.aff ms_MY.aff >ms_MY.diff - :sys {force} diff -a -C 1 ms_MY.orig.dic ms_MY.dic >>ms_MY.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch ms_MY.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../ms_MY.zip - :sys {force} diff ../ms_MY.orig.aff ms_MY.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy ms_MY.aff ../ms_MY.new.aff - :sys {force} diff ../ms_MY.orig.dic ms_MY.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy ms_MY.dic ../ms_MY.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete ms_MY.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/nb/main.aap b/share/vim/vim72/spell/nb/main.aap deleted file mode 100644 index f7805ea1c0..0000000000 --- a/share/vim/vim72/spell/nb/main.aap +++ /dev/null @@ -1,78 +0,0 @@ -# Aap recipe for Dutch Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = nb_NO.aff nb_NO.dic - -all: $SPELLDIR/nb.latin1.spl $SPELLDIR/nb.utf-8.spl ../README_nb.txt - -$SPELLDIR/nb.latin1.spl : $FILES - :sys env LANG=no_NO.ISO8859-1 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/nb nb_NO" -c q - -$SPELLDIR/nb.utf-8.spl : $FILES - :sys env LANG=no_NO.UTF-8 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/nb nb_NO" -c q - -../README_nb.txt : README_nb_NO.txt - :copy $source $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} nb_NO.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -nb_NO.aff nb_NO.dic: {buildcheck=} - :assertpkg unzip patch - :fetch nb_NO.zip - :sys $UNZIP nb_NO.zip - :delete nb_NO.zip - @if not os.path.exists('nb_NO.orig.aff'): - :copy nb_NO.aff nb_NO.orig.aff - @if not os.path.exists('nb_NO.orig.dic'): - :copy nb_NO.dic nb_NO.orig.dic - @if os.path.exists('nb_NO.diff'): - :sys patch <nb_NO.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 nb_NO.orig.aff nb_NO.aff >nb_NO.diff - :sys {force} diff -a -C 1 nb_NO.orig.dic nb_NO.dic >>nb_NO.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch nb_NO.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../nb_NO.zip - :sys {force} diff ../nb_NO.orig.aff nb_NO.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy nb_NO.aff ../nb_NO.new.aff - :sys {force} diff ../nb_NO.orig.dic nb_NO.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy nb_NO.dic ../nb_NO.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete nb_NO.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/nl/main.aap b/share/vim/vim72/spell/nl/main.aap deleted file mode 100644 index 764a58924f..0000000000 --- a/share/vim/vim72/spell/nl/main.aap +++ /dev/null @@ -1,78 +0,0 @@ -# Aap recipe for Dutch Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = nl_NL.aff nl_NL.dic - -all: $SPELLDIR/nl.latin1.spl $SPELLDIR/nl.utf-8.spl ../README_nl.txt - -$SPELLDIR/nl.latin1.spl : $FILES - :sys env LANG=nl_NL.ISO8859-1 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/nl nl_NL" -c q - -$SPELLDIR/nl.utf-8.spl : $FILES - :sys env LANG=nl_NL.UTF-8 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/nl nl_NL" -c q - -../README_nl.txt : README_nl_NL.txt README_vim.txt - :cat $source >! $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} nl_NL.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -nl_NL.aff nl_NL.dic: {buildcheck=} - :assertpkg unzip patch - :fetch nl_NL.zip - :sys $UNZIP nl_NL.zip - :delete nl_NL.zip - @if not os.path.exists('nl_NL.orig.aff'): - :copy nl_NL.aff nl_NL.orig.aff - @if not os.path.exists('nl_NL.orig.dic'): - :copy nl_NL.dic nl_NL.orig.dic - @if os.path.exists('nl_NL.diff'): - :sys patch <nl_NL.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 nl_NL.orig.aff nl_NL.aff >nl_NL.diff - :sys {force} diff -a -C 1 nl_NL.orig.dic nl_NL.dic >>nl_NL.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch nl_NL.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../nl_NL.zip - :sys {force} diff ../nl_NL.orig.aff nl_NL.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy nl_NL.aff ../nl_NL.new.aff - :sys {force} diff ../nl_NL.orig.dic nl_NL.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy nl_NL.dic ../nl_NL.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete nl_NL.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/nl/nl_NL.diff b/share/vim/vim72/spell/nl/nl_NL.diff deleted file mode 100644 index de864fdad0..0000000000 --- a/share/vim/vim72/spell/nl/nl_NL.diff +++ /dev/null @@ -1,85009 +0,0 @@ -*** nl_NL.orig.aff Sun Jul 3 18:24:07 2005 ---- nl_NL.aff Fri Mar 10 10:03:48 2006 -*************** -*** 1,5 **** - SET ISO8859-1 - TRY esianrtolcdugmphbyfvkwjkqxz-ëéèêïîäàâöüû'ESIANRTOLCDUGMPHBYFVKWJKQXZ - -! NOSPLITSUGS - ---- 1,35 ---- - SET ISO8859-1 -+ -+ NAME Nederlands -+ AUTHOR Various, edited by Bram Moolenaar -+ VERSION 0.8 -+ - TRY esianrtolcdugmphbyfvkwjkqxz-ëéèêïîäàâöüû'ESIANRTOLCDUGMPHBYFVKWJKQXZ - -! FOL ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ -! LOW ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ -! UPP ßÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞÿ -! -! SOFOFROM abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþßÿÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞ¿ -! SOFOTO ebctefghejklnnepkrstevvkesebctefghejklnnepkrstevvkeseeeeeeeceeeeeeeedneeeeeeeeeeepseeeeeeeeceeeeeeeedneeeeeeeeeeep? -! -! MIDWORD '- -! -! KEEPCASE = -! RARE ? -! BAD ! -! -! #NOSPLITSUGS -! NOSUGGEST * -! -! MAP 9 -! MAP aàáâãäå -! MAP eèéêë -! MAP iìíîï -! MAP oòóôõö -! MAP uùúûü -! MAP nñ -! MAP cç -! MAP yÿý -! MAP sß - -*************** -*** 33,52 **** - SFX J N 18 -! SFX J 0 tje [aeiou][aeiou] -! SFX J 0 tjes [aeiou][aeiou] -! SFX J 0 atje [^aeiou]a -! SFX J 0 atjes [^aeiou]a -! SFX J 0 etje [^aeiou]i -! SFX J 0 etjes [^aeiou]i - SFX J 0 'tje [^aeiou]y -! SFX J 0 'tjes [^aeiou]y - SFX J 0 otje [^aeiou]o -! SFX J 0 otjes [^aeiou]o - SFX J 0 utje [^aeiou]u -! SFX J 0 utjes [^aeiou]u -! SFX J 0 tje [aeiou][lnrw] -! SFX J 0 tjes [aeiou][lnrw] -! SFX J 0 pje [aeiou][m] -! SFX J 0 pjes [aeiou][m] -! SFX J 0 je [aeiou][bcdfgkpt] -! SFX J 0 jes [aeiou][bcdfgkpt] - ---- 63,82 ---- - SFX J N 18 -! SFX J 0 tje [aeiou][aeiou] -! SFX J 0 tjes [aeiou][aeiou] -! SFX J 0 atje [^aeiou]a -! SFX J 0 atjes [^aeiou]a -! SFX J 0 etje [^aeiou]i -! SFX J 0 etjes [^aeiou]i - SFX J 0 'tje [^aeiou]y -! SFX J 0 'tjes [^aeiou]y - SFX J 0 otje [^aeiou]o -! SFX J 0 otjes [^aeiou]o - SFX J 0 utje [^aeiou]u -! SFX J 0 utjes [^aeiou]u -! SFX J 0 tje [aeiou][lnrw] -! SFX J 0 tjes [aeiou][lnrw] -! SFX J 0 pje [aeiou][m] -! SFX J 0 pjes [aeiou][m] -! SFX J 0 je [aeiou][bcdfgkpt] -! SFX J 0 jes [aeiou][bcdfgkpt] - -*************** -*** 253,255 **** - REP ubi ibu -! REP croc krok - REP ten than ---- 283,285 ---- - REP ubi ibu -! REP croc krok - REP ten than -*************** -*** 288,290 **** - REP capucino cappuccino -! REP celcius Celsius - REP kado cadeau ---- 318,320 ---- - REP capucino cappuccino -! REP celcius Celsius - REP kado cadeau -*************** -*** 294,300 **** - REP committee comité -! REP komitee comité -! REP komittee comité -! REP kommitee comité - REP kommittee comité -! REP kwis quiz - REP kwissen quizzen ---- 324,330 ---- - REP committee comité -! REP komitee comité -! REP komittee comité -! REP kommitee comité - REP kommittee comité -! REP kwis quiz - REP kwissen quizzen -*************** -*** 302,304 **** - REP copy kopij -! REP pitoresque pittoreske - REP reikweite reikwijdte ---- 332,334 ---- - REP copy kopij -! REP pitoresque pittoreske - REP reikweite reikwijdte -*************** -*** 314,319 **** - REP klup club -! REP wiskid whizzkid -! REP kontakt contact -! REP kontekst context -! REP korrekt correct - REP kritikus criticus ---- 344,349 ---- - REP klup club -! REP wiskid whizzkid -! REP kontakt contact -! REP kontekst context -! REP korrekt correct - REP kritikus criticus -*************** -*** 333 **** ---- 363,366 ---- - REP aflassen afgelasten -+ REP svp s.v.p. -+ REP zoz z.o.z. -+ REP hopenlijk hopelijk -*** nl_NL.orig.dic Sun Jul 3 18:24:07 2005 ---- nl_NL.dic Thu Feb 21 21:06:03 2008 -*************** -*** 1,3 **** - 119937 -! 'Versie-12-8-2003. Copyright (c) Nederlandse Tex Gebruikersgroep en S.Brouwer' - 's-Graveland ---- 1,3 ---- - 119937 -! #Versie-12-8-2003. Copyright (c) Nederlandse Tex Gebruikersgroep en S.Brouwer' - 's-Graveland -*************** -*** 8,9 **** ---- 8,11 ---- - 's-Hertogenbosch -+ fietsstandaard -+ fietslantaarn - A4 -*************** -*** 91,93 **** - Athene -- Athene - Atjees/E ---- 93,94 ---- -*************** -*** 216,217 **** ---- 217,220 ---- - Brussels/E -+ BTW -+ B.T.W. - Budel -*************** -*** 325,326 **** ---- 328,330 ---- - Duurstede -+ DVD - Dwingeloo -*************** -*** 914,916 **** - Oranjegezind/E -! Oranjehemd - Oranjehuis ---- 918,920 ---- - Oranjegezind/E -! #Oranjehemd We hebben al oranjehemd - Oranjehuis -*************** -*** 1323,1326 **** - Winterswijk -! Witrus -! Witrussisch - Wittem ---- 1327,1330 ---- - Winterswijk -! #Witrus fout volgens Van Dale -! #Witrussisch fout volgens Van Dale - Wittem -*************** -*** 2998,3000 **** - achterwagen/S -! achterwand - achterweg/NE ---- 3002,3004 ---- - achterwagen/S -! achterwand/N - achterweg/NE -*************** -*** 4896,4897 **** ---- 4900,4902 ---- - aidsepidemie -+ aidspreventieprogramma - aidspreventieprogramma's -*************** -*** 5175,5177 **** - allergeen/P -! allergeschikste - allergie ---- 5180,5183 ---- - allergeen/P -! #allergeschikste fout volgens Van Dale -! allergeschiktste - allergie -*************** -*** 7485,7486 **** ---- 7491,7500 ---- - avond/SN -+ 's avonds/= -+ 's middags/= -+ 's ochtends/= -+ 's morgens/= -+ 's Avonds -+ 's Middags -+ 's Ochtends -+ 's Morgens - avondappèl/S -*************** -*** 7669,7671 **** - baardscheerder/S -! baardschrapper/S - baardvin/M ---- 7683,7686 ---- - baardscheerder/S -! #baardschrapper/S fout volgens Van Dale -! baardschraper/S - baardvin/M -*************** -*** 10502,10504 **** - beredder/DWI -! beredderingskosten - bereden/O ---- 10517,10520 ---- - beredder/DWI -! #beredderingskosten fout volgens Van Dale -! bereddingskosten - bereden/O -*************** -*** 20561,20563 **** - curare -! curatele/N - curatelestelling ---- 20577,20580 ---- - curare -! #curatele/N curatelen is fout volgens Van Dale -! curatele - curatelestelling -*************** -*** 20681,20682 **** ---- 20698,20700 ---- - cytostatica -+ d.m.v. - daad/P -*************** -*** 25834,25836 **** - driesprong/N -! driest/TRH - driestal/M ---- 25852,25856 ---- - driesprong/N -! #driest/TRH driestst is fout volgens Van Dale -! driest/RH -! driestste - driestal/M -*************** -*** 28239,28241 **** - entraineer/WP -! entre-deutje - entre-deux/S ---- 28259,28261 ---- - entraineer/WP -! #entre-deutje fout volgens Van Dale - entre-deux/S -*************** -*** 31092,31094 **** - fotokopie -! fotokopieer/WP - fotokopieerapparaat ---- 31112,31115 ---- - fotokopie -! #fotokopieer/WP fotokopieren is fout volgens Van Dale -! fotokopieer/W - fotokopieerapparaat -*************** -*** 41809,41811 **** - hartelozer -! hartelust - harten/S ---- 41830,41832 ---- - hartelozer -! hartenlust - harten/S -*************** -*** 42393,42395 **** - helderziender -! helderzienst - heldhaftig/ETRH ---- 42414,42417 ---- - helderziender -! #helderzienst fout volgens Van Dale -! helderziendst - heldhaftig/ETRH -*************** -*** 46300,46301 **** ---- 46322,46324 ---- - informaticus -+ informatie/S - informatie-uitwisseling -*************** -*** 54255,54257 **** - kornalijn/N -! kornel/M - kornet/M ---- 54278,54282 ---- - kornalijn/N -! #kornel/M kornellen is fout volgens Van Dale -! kornel -! kornels - kornet/M -*************** -*** 55926,55929 **** - kustweggetje/S -! kut/M -! kutje - kuttenkop ---- 55951,55954 ---- - kustweggetje/S -! kut/M* -! kutje/* - kuttenkop -*************** -*** 58883,58885 **** - lijkrede/S -! lijkredenen - lijkroof ---- 58908,58910 ---- - lijkrede/S -! #lijkredenen fout volgens Van Dale - lijkroof -*************** -*** 59340,59342 **** - lofredenaar/S -! lofredenen - lofspraak/P ---- 59365,59367 ---- - lofredenaar/S -! #lofredenen fout volgens Van Dale - lofspraak/P -*************** -*** 60083,60085 **** - lukte/G -! lul/GWM - lulleman/M ---- 60108,60110 ---- - lukte/G -! lul/GWM* - lulleman/M -*************** -*** 60087,60089 **** - lullepraat -! lulletje/S - lullig ---- 60112,60114 ---- - lullepraat -! lulletje/S* - lullig -*************** -*** 60206,60208 **** ---- 60231,60238 ---- - löss -+ m.a.w. -+ m.b.t. -+ m.n. - ma/JW -+ mm -+ mg - maag -*************** -*** 70861,70863 **** - ontsmettingsdienst/N -! ontsmettingsdient - ontsmettingsmiddel/N ---- 70891,70893 ---- - ontsmettingsdienst/N -! #ontsmettingsdient fout volgens Van Dale - ontsmettingsmiddel/N -*************** -*** 77678,77680 **** - platvoetwacht -! platvorm - platwalsen ---- 77708,77710 ---- - platvoetwacht -! #platvorm fout volgens Van Dale - platwalsen -*************** -*** 77996,77997 **** ---- 78026,78028 ---- - pluisje -+ pluisjes - pluist/UF -*************** -*** 80310,80312 **** - programmablad -! programmaboekje - programmacode ---- 80341,80343 ---- - programmablad -! programmaboekje/S - programmacode -*************** -*** 80489,80491 **** - pront/RTE -! pronunciamento - pronunciatie/S ---- 80520,80523 ---- - pront/RTE -! #pronunciamento fout volgens Van Dale -! pronunciamiento - pronunciatie/S -*************** -*** 95724,95726 **** - stoppertje/V -! stoppertjes/V - stopping/VNK ---- 95756,95759 ---- - stoppertje/V -! #stoppertjes/V verstoppertjes is fout volgens Van Dale -! stoppertjes - stopping/VNK -*************** -*** 97474,97475 **** ---- 97507,97510 ---- - suïciderisico/X -+ s.v.p. -+ z.o.z. - swagger/S -*************** -*** 99366,99368 **** - tennisracket/S -! tennisraket/M - tennisrokje ---- 99401,99403 ---- - tennisracket/S -! #tennisraket/M waarschijnlijk fout - tennisrokje -*************** -*** 99899,99901 **** - terugziet -! terugzijn - terugzoeken ---- 99934,99936 ---- - terugziet -! #terugzijn fout volgens Van Dale - terugzoeken -*************** -*** 100011,100013 **** - teven/S -! tevergeefs/E - tevoorschijn ---- 100046,100049 ---- - teven/S -! #tevergeefs/E tevergeefse is fout volgens Van Dale -! tevergeefs - tevoorschijn -*************** -*** 100485,100487 **** - tijdsdruk -! tijdsduur/P - tijdseenheid ---- 100521,100524 ---- - tijdsdruk -! #tijdsduur/P tijdsduren is fout volgens Van Dale -! tijdsduur - tijdseenheid -*************** -*** 101428,101429 **** ---- 101465,101468 ---- - toezichthouder/S -+ toezichthoudersaansprakelijkheidsverzekering -+ toezichthoudersaansprakelijkheidsverzekeringen - toezie/N -*************** -*** 103707,103708 **** ---- 103746,103748 ---- - tête-à-tête/S -+ u - uchtend/N -*************** -*** 108982,108984 **** - violistisch -! violoncel/SM - violoncellist/N ---- 109022,109026 ---- - violistisch -! #violoncel/SM violoncels is fout volgens Van Dale -! violoncel/M -! violoncellen - violoncellist/N -*************** -*** 109497,109499 **** - vliegenscheet/P -! vliegenstront/N - vliegensvlug ---- 109539,109542 ---- - vliegenscheet/P -! #vliegenstront/N vliegenstronten is fout volgens Van Dale -! vliegenstront - vliegensvlug -*************** -*** 110847,110848 **** ---- 110890,110892 ---- - voorjaarscollectie/S -+ voorjaarsconferentie/S - voorjaarsmoeheid -*************** -*** 113996,113998 **** - weervloed -! weervoer/N - weervoorspeller/S ---- 114040,114044 ---- - weervloed -! #weervoer/N weervoeren is fout volgens Van Dale -! weervoer -! wedervoeren - weervoorspeller/S -*************** -*** 114822,114824 **** - wereld/SN -! wereldbank - wereldbeeld ---- 114868,114871 ---- - wereld/SN -! #wereldbank fout volgens Van Dale -! Wereldbank - wereldbeeld -*************** -*** 115268,115270 **** - wetens/OG -! wetenschap/SM - wetenschappelijk/TREHO ---- 115315,115318 ---- - wetens/OG -! #wetenschap/SM wetenschaps is fout volgens Van Dale -! wetenschap/M - wetenschappelijk/TREHO -*************** -*** 115747,115749 **** - willekeur/N -! willekeurig/OENRTH - willekeurige/O ---- 115795,115798 ---- - willekeur/N -! #willekeurig/OENRTH willekeurige is fout volgens Van Dale -! willekeurig/OERTH - willekeurige/O -*************** -*** 116672,116674 **** - wouter/S -! wouterman/S - wouw/N ---- 116721,116725 ---- - wouter/S -! #wouterman/S woutermans is fout volgens Van Dale -! wouterman -! woutermannetje - wouw/N -*************** -*** 117602,117604 **** - zegelwet/M -! zegen/FCGSWNIU - zegenbede/N ---- 117653,117656 ---- - zegelwet/M -! #zegen/FCGSWNIU uitzegen is fout volgens Van Dale -! zegen/FCGSWNI - zegenbede/N -*************** -*** 119938 **** ---- 119990,204386 ---- - überhaupt -+ Christiaan/X -+ Fred/X -+ Jansen/X -+ Janssen/X -+ Moolenaar/X -+ Renee/X -+ René/X -+ Renée/X -+ Walter/X -+ Verhagen/X -+ # toevoegingen uit de Woordenlijst van 30 mei 1996 -+ a capella -+ a fortiori -+ a priori -+ a vista -+ ad hominem -+ afrikaan -+ afterpil -+ alma mater -+ anorexia nervosa -+ apelazerus -+ art nouveau -+ au bain marie -+ auctor intellectualis -+ avant la lettre -+ bal masqué -+ basso continuo -+ batavier -+ benefit of the doubt -+ black box -+ black jack -+ black power -+ blue jeans -+ boogie woogie -+ bric à brac -+ bungee jumping -+ capita selecta -+ chaise longue -+ chinezen -+ coming man -+ comme il faut -+ #commedia dell' arte fout volgens Van Dale -+ commedia dell'arte -+ communis opinio -+ consilium abeundi -+ couleur locale -+ coûte que coûte -+ dalai lama -+ de jure -+ deus ex machina -+ domus Dei -+ dramatis personae -+ eigener beweging -+ en plein public -+ en profil -+ enfant terrible -+ entre nous -+ fait accompli -+ faux pas -+ femme fatale -+ filet d'anvers -+ fin de siècle -+ finishing touch -+ franse -+ fransman -+ gotisch -+ happy few -+ hora est -+ hors d'oeuvre -+ in absentia -+ in abstracto -+ in allen gevalle -+ in extenso -+ in koelen bloede -+ in memoriam -+ in statu nascendi -+ in triplo -+ in voce -+ invite -+ ipso facto -+ jalousie de métier -+ jehova -+ jeune premier -+ joint venture -+ jus d'orange -+ kalis -+ kousjer -+ laisser faire -+ laissez passer -+ lapis lazuli -+ latino -+ logos -+ maître d'hôtel -+ minimal art -+ naar den vleze -+ non sequitur -+ off line -+ om den brode -+ on line -+ oratio pro domo -+ orchestreren -+ pain à la grecque -+ par excellence -+ pas de deux -+ paso doble -+ patates frites -+ peau de pêche -+ perpetuum mobile -+ plat du jour -+ pool -+ poste restante -+ pot au feu -+ procesverbaal -+ promilitair -+ public relations -+ pur sang -+ qualitate qua -+ questionnaire -+ rector magnificus -+ remedial teacher -+ remedial teaching -+ rigor mortis -+ romein -+ self-fulfilling prophecy -+ septic tank -+ short story -+ sotto voce -+ stehgeiger -+ sub rosa -+ sur place -+ t-bonesteak -+ te bestemder plaatse -+ te bestemder tijd -+ te elfder ure -+ te eniger tijd -+ te gelde maken -+ te onzen voordele -+ ten algemenen nutte -+ ten anderen male -+ ten besluite -+ ten bewijze -+ ten derde male -+ ten geschenke geven -+ ten geschenke krijgen -+ ten tweede male -+ ten vervolge op -+ ter aangehaalder plaatse -+ ter bestemder plaatse -+ ter bestemder tijd -+ ter beurze -+ ter eenre zijde -+ ter elfder ure -+ ter kerke -+ ter ore -+ terneerliggen -+ terneerslaan -+ terneervallen -+ tertiair -+ top secret -+ tot bloedens toe -+ total loss -+ turken -+ upper ten -+ ups and downs -+ van koninklijken bloede -+ van zinnens zijn -+ viola da gamba -+ white spirit -+ wishful thinking -+ à gogo -+ à propos -+ a.s. -+ evt. -+ enz. -+ t\/m -+ TCP\/IP -+ bijv. -+ t.n.v. -+ m.b.v. -+ et al. -+ Abraham -+ Anita -+ Boudewijn -+ Bram -+ Edwin -+ Erwin -+ Gerard -+ Gert -+ Google -+ Jos -+ Laurens -+ Leon -+ Linda -+ Luc -+ Luuk -+ Marion -+ Paul -+ Nikon -+ Pentax -+ Minolta -+ Mariëlle -+ Jeroen -+ Wytze -+ Océ -+ Philips -+ Shell -+ KPN -+ FNV -+ CNV -+ NLUUG -+ ICCF -+ aidsvoorlichting -+ # Woorden uit de Woordenlijst Nederlandse Taal - Officiële Spelling 2005 -+ # TODO: werkwoord vervoegingen -+ 's anderendaags -+ 't is dief en diefjesmaat -+ 11 julifeest -+ 11 julifeesten -+ 11 juliviering -+ 11 julivieringen -+ 21 juliviering -+ 21 julivieringen -+ 24 uursdienst -+ 24 uurseconomie -+ 24 uursservice -+ 3D-visualisatie -+ 3D-visualisaties -+ 50 eurobiljet -+ 50 eurobiljetten -+ 8 uurjournaal -+ A-attest -+ A-attesten -+ A-biljet -+ A-biljetten -+ A-bom -+ A-bommen -+ A-merk -+ A-merken -+ A-omroep -+ A-omroepen -+ A-status -+ A4'tje -+ A4'tjes -+ A4-formaat -+ AAW-voorziening -+ ABC-eilanden -+ ABC-wapens -+ ADHD -+ ADHD-kind -+ ADHD-kinderen -+ ADSL -+ ADSL-aansluiting -+ ADSL-aansluitingen -+ AMvB -+ AOV -+ AOV'er -+ AOV'ers -+ AOV-uitkering -+ AOV-uitkeringen -+ AOW -+ AOW'er -+ AOW'ers -+ AOW-premie -+ AOW-uitkering -+ AOW-uitkeringen -+ AROB -+ AROB-rechter -+ AROB-rechters -+ ASFA -+ ATB -+ ATB's -+ ATM-kaart -+ ATM-kaarten -+ AWACS-vliegtuig -+ AWACS-vliegtuigen -+ AWBZ-premie -+ AWW-premie -+ AWW-uitkering -+ Aarlenaar -+ Aarlenaars -+ Aarlenaarse -+ Aarlenaren -+ Aarlens -+ Aarlense -+ Aboriginals -+ Absurdistan -+ Academy Award -+ Adek -+ Administratieve Rechtspraak Overheidsbeschikkingen -+ Adonai -+ Afrikaanssprekend -+ Afrikaanssprekende -+ Afro-Amerikaan -+ Afro-Amerikanen -+ Afro-Surinaams -+ Afro-Surinaamse -+ Afro-Surinamer -+ Afro-Surinamers -+ Ajacied -+ Ajacieden -+ Ajaxsupporter -+ Ajaxsupporters -+ Al Qaida -+ Albanië -+ Albinees -+ Albinezen -+ Algemeen Oudedagsvoorzieningsfonds -+ Allahoe akbar -+ Allerheiligenvloed -+ Alpijnse -+ Amati's -+ Amazonegebied -+ Ambonezen -+ American dream -+ American football -+ Amerikaans-Engels -+ Amsterdammer -+ Anansi -+ Anansitori -+ Anansitori's -+ Anderlechtenaar -+ Anderlechtenaren -+ Anderlechtsupporter -+ Anderlechtsupporters -+ Andesgebergte -+ Andorra -+ Andorrees -+ Andorrese -+ Andorrezen -+ Andromedanevel -+ Angelsaksen -+ Anglo-Amerikaans -+ Anglo-Amerikaanse -+ Angola -+ Angolees -+ Angolese -+ Angolezen -+ Anjerrevolutie -+ Antillenroute -+ Antilliaan -+ Antilliaans -+ Antilliaans-Nederlands -+ Antilliaans-Nederlandse -+ Anton de Kom Universiteit -+ Antwerpenaar -+ Antwerpenaars -+ Antwerpenaren -+ Antwerps -+ Antwerpse -+ Apaches -+ Arabisch-nationalistisch -+ Arabisch-nationalistische -+ Arabischtalig -+ Arabischtalige -+ Arbitragehof -+ Arboraad -+ Arbowet -+ Arcadië -+ Arctica -+ Ardeens -+ Ardeense -+ Ardennen -+ Ardennenoffensief -+ Ardenner ham -+ Ardense hesp -+ Arelaar -+ Arelaars -+ Arelaarse -+ Arelaren -+ Arels -+ Arelse -+ Argentinië -+ Armeens -+ Armeense -+ Arnhemmer -+ Arnhemmers -+ Arnhems -+ Arnhemse -+ Arnhemsen -+ Arowak -+ Arowakken -+ Arowaks -+ Arowakse -+ Arthurroman -+ Arthurromans -+ Aruba -+ Arubaan -+ Arubaans -+ Arubaanse -+ Arubanen -+ Asen -+ Asjkenazi -+ Asjkenazi's -+ Asjkenazim -+ Asjkenazisch -+ Asjkenazische -+ Assembleecommissie -+ Assembleecommissies -+ Assembleevergadering -+ Assembleevergaderingen -+ Assenaar -+ Assenaars -+ Assens -+ Assense -+ Asser -+ Assers -+ Assyrisch -+ Assyrische -+ Asymmetric Digital Subscriber Line -+ Atjeh -+ Atjese -+ Attention Deficit Hyperactivity Disorder -+ Attisch -+ Attische -+ Aucaans -+ Aucaanse -+ Aucaner -+ Aucaners -+ Ave Maria's -+ Ave Mariaatje -+ Azoren -+ Azteeks -+ Azteekse -+ B -+ B-52 -+ B-52-bommenwerper -+ B-52-bommenwerpers -+ B-acteur -+ B-acteurs -+ B-attest -+ B-attesten -+ B-film -+ B-films -+ B-kant -+ B-omroep -+ B-omroepen -+ B-status -+ B-weg -+ B-wegen -+ BN'er -+ BN'ers -+ BOG -+ BS -+ BS'er -+ BS'ers -+ BSE -+ BV -+ BV's -+ Bacchusfeest -+ Bahama-eilanden -+ Balkanoorlog -+ Balkanoorlogen -+ Bankcommissie -+ Bantoeneger -+ Bantoes -+ Bantoetaal -+ Bantoetalen -+ Barentszzee -+ Bartholomeusnacht -+ Bask -+ Basken -+ Baskenland -+ Baskisch -+ Baskisch-nationalistisch -+ Baskisch-nationalistische -+ Baskische -+ Batavieren -+ Bauhaus -+ Baäl -+ Beatlesplaat -+ Beatlesplaten -+ Belarus -+ Belarussen -+ Belarussisch -+ Belarussische -+ Belgenmop -+ Belgenmoppen -+ Belgisch-Limburg -+ Belgisch-Nederlands -+ Belial -+ Bemiddelingsraad -+ Benelux-land -+ Benelux-landen -+ Berbers -+ Berbervolk -+ Berbervolken -+ Bergenaar -+ Bergenaars -+ Bergenaren -+ Bergens -+ Bergense -+ Bergs -+ Bergse -+ Berlijner -+ Berlijners -+ Berlijns -+ Bermudadriehoek -+ Betuweroute -+ Betuwespoorlijn -+ Bhagwanbeweging -+ Bijbellezen -+ Bijbelspreuken -+ Bijbelstudie -+ Bijbelstudies -+ Bijzondere Opsporingsbrigade -+ Birma -+ Birmaan -+ Birmaans -+ Birmaanse -+ Birmanen -+ Birmaspoorlijn -+ Birmees -+ Birmese -+ Birmezen -+ Black Power -+ Blaricummer -+ Blaricummers -+ Bodo -+ Boedapest -+ Boeddhabeelden -+ Boekenweekessay -+ Boekenweekgeschenk -+ Boekenweekuitgave -+ Boekenweekuitgaven -+ Boerenkrijg -+ Boerenrepubliek -+ Boerenrepublieken -+ Bolivia -+ Boliviaan -+ Boliviaans -+ Boliviaanse -+ Bolivianen -+ Bollywoodfilm -+ Bollywoodfilms -+ Bonaire -+ Bonairiaan -+ Bonairiaans -+ Bonairiaanse -+ Bonairiaansen -+ Bonairianen -+ Bondsdagpresident -+ Bondsdagpresidente -+ Bondsdagvoorzitter -+ Boni's -+ Bosnisch -+ Bosniër -+ Bosniërs -+ Bossche -+ Bosschenaar -+ Bosschenaars -+ Bosschenaarse -+ Bosschenaren -+ Boterwet -+ Botnische Golf -+ Boviene Spongiforme Encefalopathie -+ Bq -+ Brabançonne -+ Braziliaans-Portugees -+ Braziliaans-Portugese -+ Brits-Engels -+ Brits-Indisch -+ Brits-Indische -+ Brits-Indiër -+ Brits-Indiërs -+ Brokopondo -+ Brokopondonees -+ Brokopondonese -+ Brokopondonezen -+ Bruggeling -+ Bruggelinge -+ Bruggelingen -+ Brugman -+ Brugs -+ Brugse -+ Brusselaar -+ Brusselaars -+ Brusselaren -+ Bussumer -+ Bussumers -+ Byzantijn -+ Byzantijnen -+ C-attest -+ C-attesten -+ C-omroep -+ C-omroepen -+ C-status -+ C14-datering -+ C14-dateringen -+ C14-methode -+ CAT-scan -+ CAT-scans -+ CBB -+ CBS-cijfer -+ CBS-cijfers -+ CBS-koersindex -+ CDA'er -+ CDA'ers -+ CDA-leden -+ CDA-lid -+ CO2-emissie -+ CO2-emissies -+ CO2-heffing -+ CO2-probleem -+ Cajun -+ Cajuns -+ Canadees-Engels -+ Canarische Eilanden -+ Caraïben -+ Caraïbisch -+ Caraïbisch-Engels1 -+ Caraïbisch-Engels2 -+ Caraïbisch-Engelse -+ Caraïbisch-Nederlands1 -+ Caraïbisch-Nederlands2 -+ Caraïbisch-Nederlandse -+ Caraïeb -+ Caribbean community -+ Caribisch-Engels -+ Caribisch-Engelse -+ Caribisch-Nederlands -+ Caribisch-Nederlandse -+ Caricom -+ Caricom-land -+ Caricom-landen -+ Centraal Bureau voor Burgerzaken -+ Champions League -+ Champions Leaguewedstrijd -+ Champions Leaguewedstrijden -+ Chanoeka -+ Cherokee -+ Cherokee-indiaan -+ Cherokee-indianen -+ Cherokees -+ Chileen -+ Chileens -+ Chileense -+ Chilenen -+ Chinees-Indisch -+ Chinees-Indische -+ Chiro -+ Chirojeugd -+ Chirojongen -+ Chirojongens -+ Chiromeisje -+ Chiromeisjes -+ Christian Science -+ Christusfiguur -+ Christuslegende -+ Christuslegenden -+ Christuslegendes -+ Christusmonogram -+ Christusmonogrammen -+ Cito -+ Cito-toets -+ Cito-toetsen -+ Cockneydialect -+ Colombiaan -+ Colombiaans -+ Colombiaanse -+ Colombianen -+ Commewijne -+ Commewijner -+ Commewijners -+ Commewijns -+ Commewijnse -+ Concertgebouworkest -+ Congo-Brazzaville -+ Congo-Kinshasa -+ Congolees -+ Congolese -+ Congolezen -+ Cornisch -+ Coroniaan -+ Coroniaans -+ Coroniaanse -+ Coronianen -+ Coronie -+ Costa Rica -+ Costa Ricaan -+ Costa Ricaans -+ Costa Ricaanse -+ Costa Ricanen -+ Cuba -+ Cycladisch -+ Cycladische -+ Cypriotische -+ Cyprus -+ D-sluiting -+ D-trein -+ D-treinen -+ DDT -+ DNA -+ DNA-keten -+ DNA-ketens -+ DNA-leden -+ DNA-lid -+ DNA-molecule -+ DNA-moleculen -+ DNA-molecules -+ DNA-onderzoek -+ DNA-streng -+ DNA-strengen -+ DNA-structuur -+ DNA-techniek -+ DNA-technologie -+ DNA-test -+ DNA-testen -+ DNA-tests -+ DNA-voorzitter -+ Damslapers -+ Danish blue -+ Daviscupfinale -+ Decembermoorden -+ Deuteronomium -+ Divali -+ Dode Zeerollen -+ Doema -+ Dokkumer -+ Dokkumers -+ Dolle Mina -+ Don Juan -+ Don Quichot -+ Donaumonarchie -+ Dorische -+ Dow-Jones -+ Dow-Jonesindex -+ Downing Street -+ Drent -+ Drenten -+ Drentenaar -+ Drentenaars -+ Drentenaren -+ Drents -+ Drentse -+ Dubbelmonarchie -+ Duitsgezind -+ Duitsgezinde -+ Duitslandkunde -+ Duitssprekend -+ Duitssprekende -+ Duitssprekenden -+ E-weg -+ E-wegen -+ EHBO -+ EHBO'er -+ EHBO'ers -+ EHBO-diploma -+ EHBO-diploma's -+ EHBO-post -+ EHBO-posten -+ EU -+ EU-ambassadeur -+ EU-ambassadeurs -+ EU-ambtenaar -+ EU-ambtenaren -+ EU-begroting -+ EU-commissaris -+ EU-commissarissen -+ EU-ingezetene -+ EU-ingezetenen -+ EU-land -+ EU-landen -+ EU-lidstaat -+ EU-lidstaten -+ EU-minister -+ EU-ministerraad -+ EU-ministers -+ EU-partner -+ EU-partners -+ EU-richtlijn -+ EU-richtlijnen -+ EU-uitgave -+ EU-uitgaven -+ EU-verdrag -+ EU-verdragen -+ Ecuador -+ Ecuadoraan -+ Ecuadoraans -+ Ecuadoraanse -+ Ecuadoranen -+ Egyptenaren -+ El Salvador -+ Elfstedentochten -+ Elohim -+ Elvislookalike -+ Elvislookalikes -+ Elysée -+ Emmaüsgangers -+ Engelandvaarder -+ Engelandvaarders -+ Engelssprekend -+ Engelssprekende -+ Erasmusprijs -+ Ertsgebergte -+ Eskimocultuur -+ Eskimohut -+ Eskimohutten -+ Est -+ Esten -+ Estisch -+ Estische -+ Estland -+ Estlander -+ Estlanders -+ Estlands -+ Estlandse -+ Ests -+ Estse -+ Euraziatisch -+ Euraziatische -+ Eurazië -+ Europabeker -+ Europabekers -+ Europabeleid -+ Europacupfinales -+ Europagezind -+ Europagezinde -+ Europapolitiek -+ Europarlementariërs -+ Europarlementsleden -+ Europarlementslid -+ Europeeër -+ Europeeërs -+ Europese Vrijhandelsassociatie -+ Eurovisiesongfestival -+ Eustatiaan -+ Eustatiaans -+ Eustatiaanse -+ Eustatiaansen -+ Eustatianen -+ F-16 -+ F-16's -+ F-16-gevechtsvliegtuig -+ F-16-gevechtsvliegtuigen -+ FAQ -+ FAQ's -+ FM -+ FM-band -+ FM-frequentie -+ FM-frequenties -+ FM-zender -+ FM-zenders -+ Faeröer -+ Faeröerder -+ Faeröerders -+ Faeröers -+ Faeröerse -+ Feyenoorder -+ Feyenoorders -+ Feyenoordsupporter -+ Feyenoordsupporters -+ Fins-Oegrisch -+ Fins-Oegrische -+ Flevolander -+ Flevolanders -+ Flevolands -+ Flevolandse -+ Florentijns -+ Florentijnse -+ Franglais -+ Frans Jozefland -+ Frans-Guyaan -+ Frans-Guyaans -+ Frans-Guyaanse -+ Frans-Guyana -+ Frans-Guyanees -+ Frans-Guyanen -+ Frans-Guyanese -+ Frans-Guyanezen -+ Frans-Polynesië -+ Fransgezind -+ Fransgezinde -+ Franssprekend -+ Franssprekende -+ Friestalig -+ Friestalige -+ Friestaligen -+ GHz -+ Galapagoseilanden -+ Gallo-Romaans -+ Gallo-Romaanse -+ Gallo-Romeins -+ Gallo-Romeinse -+ Gehenna -+ Gelderlander -+ Gelderlanders -+ Gelderlands -+ Gelderlandse -+ Gelders -+ Geldersen -+ Geldersman -+ Geldersmannen -+ Gentenaar -+ Gentenaars -+ Gentenaren -+ Gents -+ Gentse -+ Gestapo-chef -+ Gestapo-chefs -+ Ghana -+ Ghanees -+ Ghanese -+ Ghanezen -+ Gibraltar -+ Gibraltarees -+ Gibraltarese -+ Gibraltarezen -+ Goidelisch -+ Goidelische -+ Golf van Biskaje -+ Golfoorlogsyndroom -+ Golgotha -+ Gooise matras -+ Gouds -+ Goudse -+ Greenwichtijd -+ Grieks-orthodox -+ Grieks-orthodoxe -+ Griekstalig -+ Griekstalige -+ Groenlands -+ Groenlandse -+ Groninger -+ Groningers -+ Gronings -+ Groot-Brittannië -+ Groot-Nederlands -+ Groot-Nederlandse -+ Guatemala -+ Guatemalaan -+ Guatemalaans -+ Guatemalaanse -+ Guatemalanen -+ Guatemalteek -+ Guatemalteeks -+ Guatemalteekse -+ Guatemalteken -+ Guinees biggetje -+ Guinese biggetjes -+ Gurkha -+ Gurkha's -+ Guyaan -+ Guyaans -+ Guyana -+ Guyanees -+ Guyanen -+ Guyanese -+ Guyanezen -+ H-bom -+ H-bommen -+ H.K.H. -+ HTM -+ HTML -+ Haarlemmer -+ Haarlemmers -+ Haarlems -+ Haarlemse -+ Hagenaar -+ Hagenaars -+ Hagenaren -+ Hagenees -+ Hagenezen -+ Hamas -+ Hamasstrijder -+ Hamasstrijders -+ Hare Koninklijke Hoogheid -+ Hasselaar -+ Hasselaarse -+ Hasselaren -+ Hasseltenaar -+ Hasseltenaren -+ Hasselts -+ Hasseltse -+ Heiland -+ Hemelwagen -+ Henegouwer -+ Henegouwers -+ Henegouws -+ Henegouwse -+ Herzegovina -+ Hezbollah -+ Hezbollahstrijder -+ Hezbollahstrijders -+ Hilversummer -+ Hilversummers -+ Hinderwetvergunning -+ Hinderwetvergunningen -+ Hindi -+ Hindoestaan -+ Hindoestaans -+ Hindoestanen -+ Hindostaan -+ Hindostaans -+ Hindostaanse -+ Hindostanen -+ Hitler-Duitsland -+ Hogerhuis -+ Hogerhuisleden -+ Hogerhuislid -+ Holi -+ Hollandermop -+ Hollandermoppen -+ Hollywoodfilm -+ Hollywoodfilms -+ Homerusvertaling -+ Homerusvertalingen -+ Hongaarstalig -+ Hongaarstalige -+ Hongkong -+ Hongkong-Chinees -+ Hongkong-Chinezen -+ Hongkonger -+ Hongkongers -+ Hongkongs -+ Hongkongse -+ Hooglander -+ Hooglanders -+ Hubertusdag -+ Hyper Text Markup -+ Hyper Text Markup Language -+ I-profiel -+ I-profielen -+ ICT -+ ICT-bedrijf -+ ICT-bedrijven -+ ICT-beleid -+ ICT-branche -+ ICT-sector -+ ID-bewijs -+ ID-bewijzen -+ ID-kaart -+ ID-kaarten -+ IJslander -+ IJslanders -+ IJslands -+ IJslandse -+ IJzerbedevaart -+ IJzerbedevaarten -+ IQ -+ IQ-test -+ IQ-testen -+ IQ-tests -+ IR-trein -+ IR-treinen -+ ISBN -+ ISBN-nummer -+ ISBN-nummers -+ ISO-norm -+ ISO-normen -+ IT -+ IT'er -+ IT'ers -+ IT-sector -+ Iberiër -+ Iberiërs -+ Iers-Engels -+ Inca's -+ Indian summer -+ Indian summers -+ Indo-Europeaan -+ Indo-Europeanen -+ Indo-Europees -+ Indo-Europese -+ Indo-Germaan -+ Indo-Germaans -+ Indo-Germaanse -+ Indo-Germanen -+ Indochina -+ Ingveoons -+ Ingveoonse -+ International Standard Book Number -+ Inuit -+ Ionische -+ Iraaks -+ Irakees -+ Irakezen -+ Irish coffee -+ Irish coffees -+ Israëli's -+ Israëliër -+ Italiaanstalig -+ Italiaanstalige -+ Italisch -+ Italische -+ Jakarta -+ James Bondfilm -+ James Bondfilms -+ Jan Klaassen -+ Japannertje -+ Jemen -+ Jeugdparlement -+ Jiddisj -+ Jiddisje -+ Jodenbegraafplaats -+ Jodenbegraafplaatsen -+ Jodenhaat -+ Jodenmop -+ Jodenmoppen -+ Jodenster -+ Jodensterren -+ Jodenvervolging -+ Jodenvervolgingen -+ Jodenvraagstuk -+ Jodenwet -+ Jodenwetten -+ Jom Kipoer -+ Jordanees -+ Jordanezen -+ Jordanië -+ Jordaniër -+ Jordaniërs -+ Junglecommando -+ Jut en Jul -+ K2-top -+ KB -+ KZ -+ KZ's -+ KZ-syndroom -+ Kaaps -+ Kaapse -+ Kaapverdiaan -+ Kaapverdianen -+ Kaapverdisch -+ Kaapverdische -+ Kaapverdië -+ Kaapverdiër -+ Kaapverdiërs -+ Kabylen -+ Kabylisch -+ Kabylische -+ Kafkafan -+ Kafkafans -+ Kamercommissies -+ Kamergebouw -+ Kamerlidmaatschap -+ Kamerlijst -+ Kamermeerderheden -+ Kamerreces -+ Kamervergadering -+ Kamervoorzitters -+ Kanaaleiland -+ Kanaaleilanden -+ Kanaalzone -+ Kanaalzwemmers -+ Kanaäniet -+ Kanaänieten -+ Kaninefaat -+ Kaninefaten -+ Karelroman -+ Karelromans -+ Karolingers -+ Karolingisch -+ Karolingische -+ Kattegat -+ Kenia -+ Keniaan -+ Keniaans -+ Keniaanse -+ Kenianen -+ Keti Koti -+ Khmers -+ Klassiekarabisch -+ Klassiekarabische -+ Klein-Azië -+ Knesset -+ Koerd -+ Koerdenleider -+ Koerdenleiders -+ Koerdenvraagstuk -+ Koerdisch -+ Koerdische -+ Kol Nidrei -+ Konzentrationslager -+ Koptische -+ Korangeleerde -+ Korangeleerden -+ Koranscholen -+ Koranschool -+ Koranspreuk -+ Koranspreuken -+ Korantekst -+ Koranteksten -+ Koranvertaling -+ Koranvertalingen -+ Korinthisch -+ Korinthische -+ Krijgshof -+ Krim-Gotisch -+ Kroaat -+ Kroaten -+ Kroatisch -+ Kroatische -+ Kroatië -+ Kromanti -+ Kultuurkamer -+ Kwinti -+ Kwinti's -+ L-kamer -+ L-kamers -+ L-profiel -+ L-profielen -+ L-vormig -+ L-vormige -+ L.S. -+ Laagland-Schots -+ Ladino -+ Lagerhuisdebat -+ Lagerhuisleden -+ Lagerhuislid -+ Land van Kokanje -+ Landbouwschap -+ Landwacht -+ Lapland -+ Latijns-Amerika -+ Latijns-Amerikaans -+ Latijns-Amerikaanse -+ Leeuwardens -+ Leeuwardense -+ Leeuwarder -+ Leeuwarders -+ Leeuwardse -+ Lelystads -+ Lelystadse -+ Lelystatter -+ Lelystatters -+ Leopoldsorde -+ Letlander -+ Letlanders -+ Letlandse -+ Lets -+ Leuvenaar -+ Leuvenaars -+ Leuvenaren -+ Leuvens -+ Leuvense -+ Libië -+ Libiër -+ Libiërs -+ Liechtenstein -+ Liechtensteiner -+ Liechtensteiners -+ Liechtensteins -+ Liechtensteinse -+ Lieve-Heer -+ Lieve-Vrouw -+ Limburger -+ Limburgers -+ Litouwen -+ Lloyd's-leden -+ Lloyd's-lid -+ Lodewijk XIV -+ Lodewijk XV-meubel -+ Lodewijk XV-meubels -+ Londentrip -+ Longobarden -+ Luikenaar -+ Luikenaars -+ Luikenaren -+ Luiker -+ Luiks -+ Luikse -+ M -+ ME'ers -+ ME-busje -+ ME-busjes -+ ME-patiënt -+ ME-patiënten -+ ME-peloton -+ ME-pelotons -+ ME-syndroom -+ MKZ -+ MKZ-crisis -+ MRI-scan -+ MRI-scans -+ MX-raket -+ MX-raketten -+ Maagdeneilanden -+ Maagdenhuisbezetting -+ Maastrichtenaar -+ Maastrichtenaars -+ Maastrichtenaren -+ Maastrichter -+ Maastrichts -+ Maastrichtse -+ Maaswater -+ Macedonisch -+ Macedonische -+ Macedonië -+ Macedoniër -+ Macedoniërs -+ Maghrebland -+ Maghreblanden -+ Majorca -+ Maleier -+ Maleisië -+ Maleisiërs -+ Maltese -+ Maltezen -+ Maltezer kruis -+ Maltezer leeuwtje -+ Maltezer leeuwtjes -+ Mammoetwet -+ Mantsjoe -+ Mantsjoes -+ Manx -+ Maori -+ Maori's -+ Maria-Hemelvaart -+ Maria-Lichtmis -+ Mariakapel -+ Mariakapellen -+ Mariakapelletje -+ Marialegende -+ Marialegenden -+ Marialegendes -+ Mariaverering -+ Marokkaans-Arabisch -+ Marokkaans-Arabische -+ Marowijne -+ Marowijner -+ Marowijners -+ Marowijns -+ Marowijnse -+ Matawai -+ Max Havelaarkoffie -+ Maya's -+ Mayacultuur -+ Mayastad -+ Mayasteden -+ Mefistofeles -+ Megila -+ Megille -+ Meirevolutie -+ Mekkaganger -+ Mekkagangers -+ Mensenzoon -+ Merovingers -+ Merovingisch -+ Merovingische -+ Mesopotamisch -+ Mesopotamische -+ Mesopotamië -+ Mgr. -+ Middelburger -+ Middelburgers -+ Middelburgs -+ Middelburgse -+ Middelfries -+ Middelfriese -+ Middellandse Zeegebied -+ Middellandse Zeelanden -+ Midden-Afrika -+ Midden-Amerika -+ Midden-Amerikaans -+ Midden-Amerikaanse -+ Midden-Europees -+ Midden-Europese -+ Midden-Oosten -+ Midden-Oostenbeleid -+ Midden-Oosters -+ Midden-Oosterse -+ Migs -+ Miradj -+ Misjna -+ Moerasarabier -+ Moerasarabieren -+ Mohammed -+ Mokumer -+ Mokumers -+ Mokums -+ Mokumse -+ Molièrevertaling -+ Molukken -+ Molukker -+ Molukkers -+ Molukse -+ Mongolisch -+ Mongolische -+ Mongolië -+ Mongoliërs -+ Mont Blancbeklimming -+ Monumentendag -+ Moravisch -+ Moravische -+ Moskoviet -+ Moskovieten -+ Moskovisch -+ Moskovische -+ Mount Everestexpeditie -+ Muiderkring -+ Multatulibiografie -+ Myanmar -+ Myanmarees -+ Myanmarese -+ Myanmarezen -+ NAVO -+ NAVO-bases -+ NAVO-basis -+ NAVO-basissen -+ NAVO-bondgenootschap -+ NAVO-dubbelbesluit -+ NAVO-eenheden -+ NAVO-eenheid -+ NAVO-gevechtsvliegtuig -+ NAVO-gevechtsvliegtuigen -+ NAVO-hoofdkwartier -+ NAVO-land -+ NAVO-landen -+ NAVO-lidmaatschap -+ NAVO-verdragsgebied -+ NB -+ NMBS -+ NMBS-station -+ NMBS-stations -+ NS -+ NS-station -+ NS-stations -+ NSB'er -+ NSB'ers -+ NSB-familie -+ NSB-families -+ NT2 -+ NT2-onderwijs -+ Naams -+ Naamse -+ Namenaar -+ Namenaars -+ Namenaren -+ Natin -+ Nauw van Calais -+ Nauw van Kales -+ Navajo's -+ Navajo-indiaan -+ Navajo-indianen -+ Neder-Duitser -+ Neder-Duitsers -+ Nederbelg -+ Nederbelgen -+ Nederlandkunde -+ regeringscentrum -+ Nederlands-Antilliaan -+ Nederlands-Antilliaans -+ Nederlands-Antilliaanse -+ Nederlands-Antillianen -+ Nederlands-Indisch -+ Nederlands-Indische -+ Nederlands-Indië -+ Nederlands-hervormd -+ Nederlands-hervormde -+ Nederlandssprekend -+ Nedersaksen -+ Nedersaksisch -+ Nedersaksische -+ Nengre -+ Neolatijns -+ Neolatijnse -+ Nepal -+ Nepalees -+ Nepalese -+ Nepalezen -+ Nergenshuizen -+ New York -+ New Yorker -+ New Yorkers -+ New Yorks -+ New Yorkse -+ Nickeriaan -+ Nickeriaans -+ Nickeriaanse -+ Nickerianen -+ Nickerie -+ Nieuw-Zeeland -+ Nieuw-Zeelander -+ Nieuw-Zeelanders -+ Nieuw-Zeelands -+ Nieuw-Zeelandse -+ Nieuwgrieks -+ Nipkowschijf -+ Nobelcomité -+ Nobelprijskandidaat -+ Nobelprijskandidaten -+ Noord-Afrika -+ Noord-Afrikaan -+ Noord-Afrikaans -+ Noord-Afrikaanse -+ Noord-Afrikanen -+ Noord-Brabanders -+ Noord-Brabant -+ Noord-Brabantse -+ Noord-Europa -+ Noord-Europeaan -+ Noord-Europeanen -+ Noord-Europees -+ Noord-Europese -+ Noord-Germaans -+ Noord-Germaanse -+ Noord-Holland -+ Noord-Hollanders -+ Noord-Hollandse -+ Noord-Ier -+ Noord-Ieren -+ Noord-Ierland -+ Noord-Iers -+ Noord-Ierse -+ Noord-Nederlandse -+ Noord-Rijnland-Westfalen -+ Noordzee-Germaans -+ Noordzeekust -+ Noordzeeolie -+ Noordzeestrand -+ Noordzeestranden -+ Nova Zembla -+ Numeri -+ OCMW -+ OPEC-land -+ OPEC-landen -+ Oder-Neissegrens -+ Oegaritisch -+ Oegaritische -+ Oekraïens -+ Oekraïense -+ Oekraïne -+ Oeraals -+ Oerals -+ Oernevel -+ Oktoberrevolutie -+ Olympus -+ Oman -+ Onafhankelijkheidsdag -+ Onze-Lieve-Vrouwekerk -+ Oorlogswinter -+ Oost-Europa -+ Oost-Europadeskundige -+ Oost-Europadeskundigen -+ Oost-Europeaan -+ Oost-Europeanen -+ Oost-Europese -+ Oost-Germaans -+ Oost-Germaanse -+ Oost-Indische -+ Oost-Romeins -+ Oost-Romeinse -+ Oost-Vlaams -+ Oost-Vlaamse -+ Oost-Vlaanderen -+ Oost-Vlaming -+ Oost-Vlamingen -+ Oost-Westverbinding -+ Oostkantons -+ Opiumwet -+ Opperlands -+ Opperlandse -+ Oranje-elftal -+ Oranje-international -+ Oranje-internationals -+ Oranjefan -+ Oranjefans -+ Oranjefeest -+ Oranjefeesten -+ Oranjehotel -+ Oranjeklanten -+ Oranjeploeg -+ Oranjeselectie -+ Oranjespeler -+ Oranjespelers -+ Oranjestad -+ Oranjesupporter -+ Oranjesupporters -+ Oranjeteam -+ Oranjeteams -+ Oranjevereniging -+ Oranjeverenigingen -+ Oranjevorst -+ Oranjevorsten -+ Oranjezon -+ Oranjezonnetje -+ Oscars -+ Oscaruitreiking -+ Osmaanse -+ Ostrogoten -+ Ostrogotisch -+ Ostrogotische -+ Oud-Grieks -+ Oud-Griekse -+ Oud-Romeins -+ Oud-Romeinse -+ Oudegyptisch -+ Oudegyptische -+ Oudfries -+ Oudfriese -+ Oudgrieks -+ Oudgriekse -+ Oudindisch -+ Oudindische -+ Oudkerkslavisch -+ Oudnoors -+ Oudnoorse -+ Overijsselaar -+ Overijsselaars -+ Overijsselaren -+ Overijssels -+ P-trein -+ P-treinen -+ PEN-club -+ PET-scan -+ PET-scans -+ PPS -+ PS -+ PSV'er -+ PSV'ers -+ Pakistaan -+ Pakistani -+ Palingoproer -+ Panamees -+ Panamese -+ Panamezen -+ Papoeaatje -+ Paraan -+ Paraans -+ Paraanse -+ Paramaccaans -+ Paramaccaanse -+ Paramaccaner -+ Paramaccaners -+ Paramaribo -+ Paramariboos -+ Paramaribose -+ Paramariboër -+ Paramariboërs -+ Paranen -+ Parbo -+ Parijse -+ Parijzenaar -+ Parijzenaars -+ Parisien -+ Parisienne -+ Parisiennes -+ Parisiens -+ Pasjtoe -+ Peruaanse -+ Peruvianen -+ Petrussleutel -+ Phagwa -+ Picasso -+ Picasso's -+ Poldernederlands -+ Polynesië -+ Porto Ricaan -+ Porto Ricaans -+ Porto Ricaanse -+ Porto Ricanen -+ Porto Rico -+ Portugees-Israëlitisch -+ Portugees-Israëlitische -+ Postbanknummer -+ Postbankrekening -+ Praags -+ Pueblo-indiaan -+ Pueblo-indianen -+ Puerto Ricaan -+ Puerto Ricaans -+ Puerto Ricaanse -+ Puerto Ricanen -+ Puerto Rico -+ PvdA'er -+ PvdA'ers -+ PvdA-leden -+ PvdA-lid -+ Pyreneeën -+ Queen Annestijl -+ RNA-molecule -+ RNA-moleculen -+ RNA-molecules -+ Randstedelijke -+ Randstedeling -+ Randstedelingen -+ Rembrandtjaar -+ Reykjavik -+ Riagg -+ Riagg-centra -+ Riagg-centrum -+ Riffijn -+ Riffijnen -+ Rijksinstituut voor ziekte- en invaliditeitsverzekering -+ Rijndal -+ Rijnoever -+ Rijnoevers -+ Rijnoeverstaat -+ Rijnoeverstaten -+ Rijnwater -+ Riziv -+ Rode Duivelswedstrijd -+ Roma -+ Romeinsrechtelijk -+ Romeinsrechtelijke -+ Romereis -+ Romereizen -+ Roodkapje -+ Rosj Hasjana -+ Rotarians -+ Rotjeknor -+ Rotterdammers -+ Rotterdammertje -+ Rotterdams -+ Rubenstentoonstelling -+ Rubenstentoonstellingen -+ Rubicon -+ Ruslandkenner -+ Ruslandkenners -+ Ruslandkunde -+ Russisch-orthodox -+ Russisch-orthodoxe -+ Russischtalig -+ Russischtalige -+ S-bocht -+ S-bochten -+ S-haak -+ S-haken -+ S-vormig -+ S-vormige -+ SARS -+ SGML -+ SIS-kaart -+ SIS-kaarten -+ SOS -+ SRD -+ SS'er -+ SS'ers -+ STER-reclames -+ SUV -+ SUV's -+ SUV-wagen -+ SUV-wagens -+ Saba -+ Sabaan -+ Sabaans -+ Sabaanse -+ Sabaansen -+ Sabanen -+ Sabijns -+ Sabijnse -+ Saliërs -+ Salvadoraan -+ Salvadoraans -+ Salvadoraanse -+ Salvadoranen -+ Same -+ Samisch -+ Samische -+ San Andreasbreuk -+ San Marinees -+ San Marinese -+ San Marinezen -+ San Marino -+ Saoedi-Arabisch -+ Saoedi-Arabische -+ Saoedi-Arabië -+ Saoedisch -+ Saoedische -+ Saoediër -+ Saoediërs -+ Saramacca -+ Saramaccaans -+ Saramaccaanse -+ Saramaccaner -+ Saramaccaners -+ Sarnami -+ Sassanidisch -+ Sassanidische -+ Sassanieden -+ Saudi -+ Saudi-Arabisch -+ Saudi-Arabische -+ Saudisch -+ Saudische -+ Saudiër -+ Saudiërs -+ Save Our Souls -+ Scheldeoever -+ Scheldeoevers -+ Schengenakkoord -+ Schengenland -+ Schengenlanden -+ Schortelwoensdag -+ Schriftgedeelte -+ Schriftgedeelten -+ Schriftgedeeltes -+ Schriftplaats -+ Schriftplaatsen -+ Schriftwoorden -+ Secretaressedag -+ Sefard -+ Sefardim -+ Sefardische -+ Senaatscommissie -+ Senaatscommissies -+ Senaatsfractie -+ Senaatsgebouw -+ Senaatshoorzitting -+ Senaatshoorzittingen -+ Senaatslid -+ Senaatsverkiezing -+ Senaatsverkiezingen -+ Senaatsvoorzitter -+ Senaatszetel -+ Senaatszetels -+ Senegal -+ Senegalees -+ Senegalese -+ Senegalezen -+ Servië -+ Servo-Kroatisch -+ Servo-Kroatische -+ Severe Acute Respiratory Syndrome -+ Shakespearedrama -+ Shakespearedrama's -+ Sherpa's -+ Shiva -+ Simchat Thora -+ Sint-Bernhardpas -+ Sint-Elizabethsvloed -+ Sint-Eustachius -+ Sint-Maarten -+ Sint-Maartenaar -+ Sint-Maartenaren -+ Sint-Maartens -+ Sint-Maartense -+ Sinti -+ Sion -+ Sipaliwinees -+ Sipaliwinese -+ Sipaliwini -+ Sipaliwiniër -+ Sipaliwiniërs -+ Sjavoeot -+ Slavischsprekend -+ Slavischsprekende -+ Sleeswijk-Holstein -+ Slovaak -+ Slovaaks -+ Slovaakse -+ Slovaken -+ Slovakije -+ Sloveen -+ Sloveens -+ Sloveense -+ Slovenen -+ Slovenië -+ Slowaak -+ Slowaaks -+ Slowaakse -+ Slowaken -+ Slowakije -+ SoW-kerk -+ SoW-kerken -+ Soekot -+ Somalisch -+ Somalische -+ Somaliër -+ Somaliërs -+ Sovjet-Joden -+ Sovjet-Jood -+ Sovjet-Russisch -+ Sovjet-Russische -+ Sovjet-Unie -+ Sovjet-communisme -+ Sovjet-socialisme -+ Sovjetburger -+ Sovjetburgers -+ Sovjetleger -+ Sovjetoverheersing -+ Spaanssprekend -+ Spaanssprekende -+ Sport Utility Vehicle -+ Sranan -+ Srananman -+ Srananmans -+ Sranantongo -+ Sri Krisjna -+ Sri Lanka -+ Sri Lankaan -+ Sri Lankaans -+ Sri Lankaanse -+ Sri Lankanen -+ Staatsdoema -+ Stadsfries -+ Standaardnederlands -+ Standard Generalized Markup Language -+ Stanfries -+ Stanfriezen -+ Statenfracties -+ Statenlid -+ Statenvergadering -+ Statenvergaderingen -+ Statenverkiezing -+ Statiaan -+ Statianen -+ Stille Oceaangebied -+ Sturm und Drang -+ Sudeten-Duitser -+ Sudeten-Duitsers -+ Suikerfeest -+ Surinaams-Javaans -+ Surinaams-Javaanse -+ Surinaams-Nederlands -+ Surinaams-Nederlandse -+ Surinamer -+ Swahili -+ Syrisch -+ Syrisch-orthodox -+ Syrisch-orthodoxe -+ Syrische -+ Syrië -+ Syriër -+ Syriërs -+ T-balk -+ T-balken -+ T-biljet -+ T-biljetten -+ T-kruising -+ T-kruisingen -+ T-profiel -+ T-profielen -+ T-shirts -+ T-zone -+ T-zones -+ TEE-trein -+ TEE-treinen -+ TGV -+ Tafelberg -+ Tafelronde -+ Talmoedische -+ Talmudica -+ Tanzania -+ Tanzaniaan -+ Tanzaniaans -+ Tanzaniaanse -+ Tanzanianen -+ Temmincks strandloper -+ Temmincks strandlopers -+ Tenach -+ Teutoons -+ Teutoonse -+ Texelaar -+ Texelaars -+ Texelaren -+ Thailander -+ Thailanders -+ Thailands -+ Thailandse -+ Theems -+ Tiroolse -+ Toeareg -+ Toearegs -+ Tonga-eilanden -+ Tosefta -+ Tour de France -+ Trio's -+ Trojaan -+ Trojanen -+ Tunesisch -+ Tunesische -+ Tunesië -+ Turkssprekend -+ Turkssprekende -+ Turkstalig -+ Turkstalige -+ Tweede Kamercommissies -+ Tweede Kamergebouw -+ Tweede Kamerlidmaatschap -+ Twentenaar -+ Twentenaren -+ Twents -+ Twentse -+ U-bahn -+ U-balk -+ U-balken -+ U-bocht -+ U-bochten -+ U-boot -+ U-boten -+ U-ijzer -+ U-profiel -+ U-profielen -+ URL -+ URL's -+ US-dollar -+ US-dollars -+ Uniform Resource Locator -+ Urdu -+ Uruguay -+ Uruguayaan -+ Uruguayaans -+ Uruguayaanse -+ Uruguayanen -+ Uruguees -+ Uruguese -+ Uruguezen -+ Utrechtenaar -+ Utrechtenaars -+ Utrechtenaren -+ Utrechter -+ Utrechters -+ Utrechts -+ V-effect -+ V-effecten -+ V-hals -+ V-halzen -+ V-profiel -+ V-profielen -+ V-riem -+ V-riemen -+ V-snaar -+ V-snaren -+ V-teken -+ V-tekens -+ V-vorm -+ V-vormen -+ V-vormig -+ V-vormige -+ V-wapen -+ V-wapens -+ V1-bom -+ V1-bommen -+ VN -+ VN-vredesmacht -+ VN-waarnemer -+ VN-waarnemers -+ VSB -+ VUT-gelden -+ VUT-gerechtigd -+ VUT-gerechtigde -+ VUT-premie -+ VUT-premies -+ VUT-regeling -+ VVD'er -+ VVD'ers -+ VVV -+ VVV-kantoor -+ VVV-kantoren -+ Valentijnsdag -+ Van Ostaijengedicht -+ Vaticaanse -+ Vaticaanstad -+ VenW -+ Venezuela -+ Venus -+ Verkavelingsvlaams -+ Vermeylenfonds -+ Vierschansentoernooi -+ Vierwoudstrekenmeer -+ Vietnamsyndroom -+ Vietnamveteraan -+ Vietnamveteranen -+ Vikingtijd -+ Vinex -+ Vinex-wijk -+ Vinex-wijken -+ Visigoten -+ Visigotische -+ Vlaams-Brabant -+ Vlaams-Nederlands -+ Vlaams-nationalist -+ Vlaams-nationalisten -+ Vlaams-nationalistisch -+ Vlaams-nationalistische -+ Vlaamsgezindheid -+ Vlaamstalig -+ Vlaamstalige -+ Volksunie -+ Vondelkenner -+ Vroegmiddelnederlands -+ Vroegmiddelnederlandse -+ Vuelta -+ W. -+ W.v.Str. -+ WA -+ WA-verzekering -+ WAM-sticker -+ WAM-stickers -+ WAO'er -+ WAO'ers -+ WAO-uitkering -+ WOB -+ WW-uitkering -+ WW-uitkeringen -+ Waals-Brabant -+ Wagneruitvoering -+ Wagneruitvoeringen -+ Wajana -+ Wajana's -+ Wales -+ Wanica -+ Wanicaan -+ Wanicaans -+ Wanicaanse -+ Wanicanen -+ Warau -+ Weesgegroetje -+ Wehrmacht -+ Welsh -+ Welshe -+ Welshman -+ Welshmen -+ Werelddierendag -+ Wereldgezondheidsorganisatie -+ Wereldhandelsorganisatie -+ Wereldschaakfederatie -+ Wereldtennisbond -+ Wereldvoetbalbond -+ Wereldvoetbalfederatie -+ West-Europa -+ West-Europeaan -+ West-Europeanen -+ West-Fries -+ West-Friese -+ West-Friezen -+ West-Germaans -+ West-Germaanse -+ West-Vlaanderen -+ West-Vlaming -+ West-Vlamingen -+ Wetstraat -+ Willemsfonds -+ Wit-Rus -+ Wit-Rusland -+ Wit-Russen -+ Wit-Russisch -+ Wit-Russische -+ Witte Huiswoordvoerder -+ WvS -+ X-chromosomen -+ X-chromosoom -+ Y-chromosomen -+ Y-chromosoom -+ Z-kaart -+ Z-kaarten -+ Z-opleiding -+ Z-opleidingen -+ Z-profiel -+ Z-profielen -+ Z-verpleegkundige -+ Z-verpleegkundigen -+ Z-vormig -+ Z-vormige -+ Zaanse klok -+ Zeeuws-Vlaanderen -+ Zion -+ Zonnekoning -+ Zuid-Afrikaans-Engels -+ Zuid-Afrikaanse -+ Zuid-Europa -+ Zuid-Europeaan -+ Zuid-Europeanen -+ Zuid-Europese -+ Zuid-Holland -+ Zuid-Hollander -+ Zuid-Hollanders -+ Zuid-Molukken -+ Zuid-Molukkers -+ Zuid-Vlaams -+ Zuid-Vlaamse -+ Zuiderzeepolder -+ Zuiderzeepolders -+ Zuidzee -+ Zuidzee-eiland -+ Zuidzee-eilanden -+ Zwarte Zeevloot -+ Zwartvoetindiaan -+ Zwartvoetindianen -+ Zwitsers-Duits -+ Zwollenaar -+ Zwollenaars -+ Zwollenaren -+ Zwoller -+ Zwols -+ Zwolse -+ a priori's -+ a's -+ a'tje -+ a-capellakoor -+ a-capellakoren -+ a-priorische -+ a.m. -+ a.u.b. -+ blz. -+ e.d. -+ aagje -+ aagjes -+ aaibaar -+ aaibaarheidsfactor -+ aaibare -+ aalsperen -+ aalvlug -+ aalvlugge -+ Alpen -+ aanbestedingsregel -+ aanbestedingsregeling -+ aanbestedingsregels -+ aanbevelingscomité -+ aanbevelingscomités -+ aanbiedingsfolder -+ aanbodbeleid -+ aanbodcurve -+ aanbodcurven -+ aanbodcurves -+ aanbodeconomie -+ aanbodkant -+ aanbodverhouding -+ aanbodverhoudingen -+ aanbodzijde -+ aandachtsterrein -+ aandachtsvelden -+ aandeelhoudend -+ aandeelhoudende -+ aandeelhoudersvergaderingen -+ aandeelhouderswaarde -+ aandelenbeurs -+ aandelenbeurzen -+ aandelenkoersindex -+ aandelenlease -+ aandelenportefeuille -+ aandelenverkoop -+ aandelenzwendel -+ aandenkens -+ aandrijfkracht -+ aandrijfmechanisme -+ aandrijfsysteem -+ aangegooid -+ aangekakt -+ aangekoerst -+ aangemodderd -+ aangepastheid -+ aangerommeld -+ aangestiefeld -+ aangestraald -+ aangiftebereidheid -+ aangiftes -+ aanhankelijkheidsbetuigingen -+ aanhoudingsmandaat -+ aanjaagfunctie -+ aankoersen -+ aankomsthallen -+ aankomstplaats -+ aankoopbudget -+ aankoopbudgetten -+ aankoopkoers -+ aankoopsommen -+ aanlandingspunt -+ aanlegvergunning -+ aanlegvergunningen -+ aanleunwoning -+ aanleunwoningen -+ aanlijngebod -+ aanloopfasen -+ aanloopfases -+ aanloophuis -+ aanmelder -+ aanmelders -+ aanmoedigingsbeleid -+ aannamebeleid -+ aannemerij -+ aannemerscombinatie -+ aannemerskartel -+ aannemerswereld -+ aannemingsmaatschappij -+ aanpassingsklas -+ aanpassingsklassen -+ aanpassingsprobleem -+ aanpassingsproces -+ aanraakscherm -+ aanraakschermen -+ aanraders -+ aanrekening -+ aanslagregelaar -+ aanslagregelaars -+ aanslagvoet -+ aansluitingstreffer -+ aanspeelbaar -+ aanspeelbare -+ aanspeelpunt -+ aanspeelpunten -+ aansprakelijkheidsverzekeraar -+ aansprakelijkheidsverzekeraars -+ aanspreekpunten -+ aanstelleritis -+ aanstellingsbrief -+ aanstellingsbrieven -+ aanstellingskeuring -+ aanstellingskeuringen -+ aanstralen -+ aantekenschriften -+ aantrekkingspool -+ aanvaardingsrede -+ aanvaardingstoespraak -+ aanvalletje -+ aanvalsacties -+ aanvalsgolf -+ aanvalsgolven -+ aanvalskracht -+ aanvalsleider -+ aanvalslinies -+ aanvalspoging -+ aanvalspogingen -+ aanvalsspel -+ aanvangsklassen -+ aanvangsuur -+ aanvliegrouten -+ aanvoerdersband -+ aanvoerderschap -+ aanvoerhavens -+ aanvoertroepen -+ aanvoerweg -+ aanvoerwegen -+ aanvullingsregeling -+ aanwakkering -+ aanwervingsstop -+ aanwijzingsbevoegdheden -+ aanwijzingsbevoegdheid -+ aanwijzingsborden -+ aanwijzingsrecht -+ aap-noot-mies -+ aardappelbloem -+ aardappelkevers -+ aardappeloogst -+ aardappelras -+ aardappelrassen -+ aardappelsalade -+ aardappelsalades -+ aardappelschillen -+ aardappelschilmesjes -+ aardappelsoort -+ aardappelteelt -+ aardappelveld -+ aardappelvelden -+ aardappelzetmeel -+ aardbeitje -+ aardbevingsgebieden -+ aardbevingsgordels -+ aardelektroden -+ aardelektrodes -+ aardetint -+ aardetinten -+ aardewerkfabrikant -+ aardewerkindustrie -+ aardgasmotor -+ aardgasprijs -+ aardgasprijzen -+ aardgasreserve -+ aardgasreserves -+ aardgastankers -+ aardgasterminals -+ aardgasveld -+ aardgasvelden -+ aardgasvoorraad -+ aardgasvoorraden -+ aardgaswinning -+ aardgeschiedenis -+ aardgloben -+ aardklemmen -+ aardkleurig -+ aardkleurige -+ aardlekschakelaar -+ aardlekschakelaars -+ aardmassa's -+ aardobservatie -+ aardolie-industrie -+ aardoliemaatschappij -+ aardplaat -+ aardplaten -+ aardpolen -+ aardrijkskundeleraar -+ aardrijkskundeles -+ aardrijkskundelessen -+ aardschol -+ aardschollen -+ aardstralenkastje -+ aardstralenkastjes -+ aardstraling -+ aardstromen -+ aardstroom -+ aardwarmte -+ aarsopeningen -+ aartsconservatief -+ aartsconservatieven -+ aartsdiocees -+ aartsdiocesen -+ aartshuichelaar -+ aartshuichelaars -+ aartsrivale -+ aartsrivalen -+ aartsrivales -+ aarzelaar -+ aarzelaars -+ aaseters -+ abaja -+ abaja's -+ abc's -+ abc'tje -+ abdijbier -+ abdijcomplex -+ abdijgebouw -+ abdijgebouwen -+ abdominale -+ abgeseild -+ abonneebestand -+ abonneeservice -+ abonnementstarief -+ aborteurs -+ abortieve -+ abortuspil -+ abortuspillen -+ abortussen -+ abortustoerisme -+ abortusverbod -+ abortusvraagstuk -+ abortuswetten -+ abraham -+ abrahams -+ abrikooskleurig -+ abrikooskleurige -+ abrikozenjam -+ abseilen -+ absences -+ absentenlijsten -+ absolutistische -+ absorptielijn -+ absorptielijnen -+ absorptiespectra -+ absorptievermogen -+ abstinentieverschijnsel -+ abstinentieverschijnselen -+ abstracta -+ abstractiegraad -+ abstractieniveaus -+ abstractievermogen -+ abstrahering -+ abstraheringen -+ absurdisten -+ abundante -+ acacia's -+ acaciaatje -+ academieleden -+ academielid -+ academieopleiding -+ academietijd -+ acajoubomen -+ acajouboom -+ acanthusblad -+ acanthusbladeren -+ acceleratiepompen -+ accelereerde -+ accent grave -+ accentloos -+ accentloze -+ accents circonflexes -+ accents graves -+ accentverlegging -+ acceptatieplicht -+ accessit -+ accessits -+ accommodatiefonds -+ accordeondeur -+ accordeondeuren -+ accordeonmuziek -+ accountant-administratieconsulent -+ accountants-administratieconsulenten -+ accountantscontrole -+ accountantsonderzoek -+ accountmanager -+ accountmanagers -+ accounts -+ accreditaties -+ acculader -+ acculaders -+ acculturatieproces -+ accumulatieve -+ accumuleerde -+ accuoplader -+ accuopladers -+ accuplaat -+ aces -+ acetaten -+ achilleshielen -+ achillespeesblessure -+ achillespeesblessuren -+ achillespeesblessures -+ achtbanen -+ achtduizender -+ achtduizenders -+ achteraanzichten -+ achterafbuurt -+ achterafbuurten -+ achterafstraat -+ achterafstraatje -+ achterafzaaltje -+ achterafzaaltjes -+ achterbakken -+ achterbaksheden -+ achterbout -+ achterbouten -+ achterbouw -+ achterbumpers -+ achterflappen -+ achtergedeelte -+ achtergedeelten -+ achtergedeeltes -+ achtergrondgeluid -+ achtergrondgeluiden -+ achterhaaldheid -+ achterhammen -+ achterhoedegevechten -+ achterhoedespelers -+ achteringangen -+ achterkaft -+ achterkamertje -+ achterkleppen -+ achterkwab -+ achterkwabben -+ achterlandverbinding -+ achterlandverbindingen -+ achterlangs -+ achterlichaam -+ achterlichamen -+ achterlijken -+ achterlijn -+ achtermuren -+ achteromgekeken -+ achteromgezien -+ achteropgehinkt -+ achterophinken -+ achterovergekamd -+ achterovergeleund -+ achteroverkammen -+ achteroverleunen -+ achterpanden -+ achterportier -+ achterportieren -+ achterraam -+ achterraampje -+ achterramen -+ achterspatborden -+ achterspoilers -+ achterstandsgebied -+ achterstandsgebieden -+ achterstandsituatie -+ achterstandsituaties -+ achterstandswijken -+ achtersteek -+ achtersteken -+ achtertoneel -+ achtertuinen -+ achtertuintje -+ achteruitgestoken -+ achteruitkijkspiegels -+ achteruitkijkspiegeltje -+ achteruitsteken -+ achtervangers -+ achtervoet -+ achtervoeten -+ achtervolgingsploeg -+ achtervolgingswaan -+ achtervolgingswaanzin -+ achtervolgingswedstrijd -+ achtervolgingswedstrijden -+ achtervork -+ achterzaal -+ achterzaaltje -+ achthoek -+ achthoeken -+ achthoekig -+ achthoekige -+ achtkamp -+ achtkoppig -+ achtkoppige -+ achtling -+ achtlingen -+ achtpuntig -+ achtpuntige -+ achttiende-eeuwer -+ achttiende-eeuwers -+ achttienjarig -+ achttienjarige -+ achtuurjournaal -+ acme -+ acme's -+ acne's -+ acoeti -+ acoeti's -+ acquireerde -+ acquireren -+ acrobates -+ acrylverf -+ acteerprestatie -+ acteerprestaties -+ acteerprijs -+ acteerprijzen -+ acteerstijl -+ acteertalent -+ acteerwerk -+ acteur-regisseur -+ acteursregisseur -+ acteurstheater -+ acteurstoneel -+ acteursvakbond -+ actiecentra -+ actiecomedy -+ actiecomedy's -+ actiefilm -+ actiefilms -+ actiegevoerd -+ actiekomedie -+ actiekomedies -+ actieleider -+ actieleiders -+ actiepartij -+ actieprogramma's -+ actiethriller -+ actiethrillers -+ actionisten -+ activistische -+ activiteitencentra -+ activiteitencentrum -+ actor -+ actoren -+ actriceje -+ actricetje -+ actualiteitenshow -+ actualiteitenshows -+ actualiteitswaarde -+ acupuncturisten -+ ad-hocbeslissing -+ ad-hocbeslissingen -+ ad-interimaanstelling -+ ad-interimaanstellingen -+ adagio's -+ adam -+ addax -+ addaxen -+ addenoi -+ addicts -+ adelaarshorst -+ adelaarskop -+ ademanalyse -+ ademcentra -+ ademcentrum -+ ademhalingsmoeilijkheden -+ ademhalingsoefening -+ ademhalingsstoornis -+ ademhalingsstoornissen -+ ademhalingstoestel -+ ademhalingswegen -+ ademstilstand -+ ademstoot -+ ademstoten -+ ademtests -+ adhortatieven -+ adipositas -+ adjudant-chef -+ adjudant-chefs -+ adjudant-onderofficier -+ adjudant-onderofficieren -+ adjunct-chefs -+ adjunct-directrices -+ adjunct-inspecteurs -+ administratiefrechtelijk -+ administratiefrechtelijke -+ administratienummer -+ administratiesysteem -+ administratiesystemen -+ administratoren -+ administrators -+ administratrices -+ adoptiecentra -+ adoptiecentrum -+ adoptiefkind -+ adoptiefkinderen -+ adoptiefouder -+ adoptiefzoon -+ adoptiefzoons -+ adoptiekind -+ adoptiekinderen -+ adoreerde -+ adrenalinegehalte -+ adresbanden -+ adresbandje -+ adresfirma's -+ adressenbank -+ adressenbanken -+ adressenboek -+ adressenboeken -+ adressenboekje -+ adresseringen -+ adreswijzigingen -+ adsorbeerde -+ adukibonen -+ adukiboon -+ adult -+ adulte -+ adulten -+ adventieve -+ adventieven -+ adventskaarsen -+ advertentie-inkomsten -+ advertentieafdeling -+ advertentiekolom -+ advertentieomzet -+ advertentierubriek -+ advertentierubrieken -+ advertentieruimte -+ advertentievolume -+ adviesinstanties -+ advieskoers -+ advieslichaam -+ advieslichamen -+ adviesraden -+ adviseurschap -+ adviseurschappen -+ adviseursfunctie -+ adviseuseje -+ adviseusen -+ adviseusetje -+ advocaat-fiscaal -+ advocaat-generaal -+ advocaten-fiscaal -+ advocaten-generaal -+ advocatencollectieven -+ advocatenpraktijk -+ advocatenpraktijken -+ advocates -+ aero-elasticiteit -+ aerobe -+ aerobiccen -+ aerobict -+ aerobicte -+ aeroclub -+ aeroclubs -+ aerodroom -+ aerodynamica -+ aerodynamisch -+ aerodynamische -+ aeronaut -+ aeronauten -+ aeronautiek -+ aeroob -+ aerosol -+ aerosolverpakking -+ aerosolverpakkingen -+ aerostatica -+ afasiepatiënt -+ afasiepatiënten -+ afbakbrood -+ afbakbroodje -+ afbakbroodjes -+ afbietsen -+ afbladdering -+ afblaffen -+ afblussen -+ afboekingen -+ afboorden -+ afbraakbuurt -+ afbraakbuurten -+ afbraakproces -+ afbraakwerken -+ afbreekbaarheid -+ afchecken -+ afdaler -+ afdalers -+ afdeklaag -+ afdelingsvoorzitters -+ afdokken -+ afdroogdoeken -+ afdruiprekken -+ afdwinging -+ affairetje -+ afficheje -+ affiliaties -+ affirmaties -+ affirmeerde -+ affrontelijk -+ affrontelijke -+ afgebietst -+ afgeblaft -+ afgeblust -+ afgeboord -+ afgedicht -+ afgehard -+ afgekat -+ afgelastingen -+ afgelebberd -+ afgenokt -+ afgeschat -+ afgeserveerd -+ afgestruind -+ afgetaaid -+ afgetruggeld -+ afgevuld -+ afgewaardeerd -+ afgezeken -+ afghanen -+ afgiftekantoor -+ afgiftekantoren -+ afgiftekoers -+ afgiften -+ afgrensbaar -+ afgrensbare -+ afgrenzingen -+ afgronddiep -+ afgronddiepe -+ afgunstwekkend -+ afgunstwekkende -+ afhaalcentra -+ afhaalcentrum -+ afhaalmaaltijd -+ afhaalrestaurants -+ afhalingen -+ afhandelingskosten -+ afhankelijkheidspositie -+ afhankelijkheidsverhouding -+ afharden -+ afkatten -+ afkickboerderij -+ afkickboerderijen -+ afkickcentra -+ afkickkliniek -+ afkickklinieken -+ afkickverschijnsel -+ afkickverschijnselen -+ afknappers -+ afknijper -+ afknijpers -+ afkoelsnelheid -+ afkoopregeling -+ aflebberen -+ afleesapparatuur -+ afleesbare -+ afleesfouten -+ afleesinstrument -+ afleesinstrumenten -+ afleveringsbewijs -+ afleveringsbewijzen -+ afloopdag -+ afloopdagen -+ afloopdata -+ afloopmaand -+ afloopmaanden -+ aflossingsregeling -+ aflossingsvrij -+ aflossingsvrije -+ afluisteraar -+ afluisteraars -+ afluisterapparaat -+ afluisterapparaten -+ afluisterbaar -+ afluisterbare -+ afluisterschandaal -+ afluisterschandalen -+ afmeldkaart -+ afnamegarantie -+ afnamegaranties -+ afnameprijs -+ afnames -+ afpersingspraktijken -+ afrader -+ afraders -+ afregelen -+ afremming -+ afrikanen -+ afrikaniseerde -+ afrikaniseren -+ afrikanisering -+ afrikanistiek -+ afritsbroek -+ afritsbroeken -+ afro -+ afrodisiaca -+ afroepcontracten -+ afrokapsel -+ afrokapsels -+ afrolook -+ afruiltransactie -+ afscheidingsbeweging -+ afscheidingsbewegingen -+ afscheidingsoorlog -+ afscheidingsstreven -+ afscheidingsstrijd -+ afscheidsborrel -+ afscheidsborrels -+ afscheidscadeau -+ afscheidscadeaus -+ afscheidscadeautje -+ afscheidscolleges -+ afscheidsfeesten -+ afscheidsgeschenk -+ afscheidslied -+ afscheidspremie -+ afscheidspremies -+ afscheidsreceptie -+ afscheidsscène -+ afscheidstournee -+ afscheidswoord -+ afscheidswoorden -+ afschotvergunning -+ afschrijvingskosten -+ afschrikking -+ afschrikkingseffect -+ afschrikkingsevenwicht -+ afschrikkingsmacht -+ afschrikkingstheorie -+ afschrikmiddel -+ afserveren -+ afslachting -+ afslankingsoperatie -+ afslankingsoperaties -+ afslankingsplan -+ afslankingsplannen -+ afslankingsproces -+ afsluitingsfeest -+ afsluitprovisies -+ afspiegelingscolleges -+ afsplitsingen -+ afspringende -+ ijzerschilfers -+ afstammingsgegevens -+ afstammingslijn -+ afstandsbaby -+ afstandsbaby's -+ afstandskinderen -+ afstandsmaat -+ afstandsmaten -+ afstandsmoeders -+ afstandsschot -+ afstandsschoten -+ afstandsvader -+ afstandsvaders -+ afstemknoppen -+ afstotelijkheid -+ afstotingsreactie -+ afstotingsreacties -+ afstotingsverschijnsel -+ afstotingsverschijnselen -+ afstruinen -+ afstudeerder -+ afstudeeropdrachten -+ afstudeerprojecten -+ afstudeerscripties -+ aftaaien -+ aftelsom -+ aften -+ afterbeat -+ afterparty -+ afterparty's -+ afterpillen -+ aftersales -+ aftershavelotion -+ aftershavelotions -+ aftersun -+ aftersuns -+ aftitelingen -+ aftoppingen -+ aftrekbaarheid -+ aftrekmogelijkheden -+ aftrekmogelijkheid -+ aftrekregeling -+ aftruggelen -+ afvalberg -+ afvalbergen -+ afvalemmer -+ afvalemmers -+ afvalhoop -+ afvalhopen -+ afvalhout -+ afvallingskoers -+ afvallingskoersen -+ afvallingsrace -+ afvallingsraces -+ afvallozing -+ afvallozingen -+ afvalmateriaal -+ afvaloven -+ afvalovens -+ afvalprobleem -+ afvalproblemen -+ afvalproducten -+ afvalraces -+ afvalstoffenheffing -+ afvalstoffenwet -+ afvalverbrandingscapaciteit -+ afvalverbrandingsinstallatie -+ afvalverbrandingsinstallaties -+ afvalverbrandingsoven -+ afvalverbrandingsovens -+ afvalverwerkend -+ afvalverwerkende -+ afvalverwerker -+ afvalverwerkers -+ afvalverwerking -+ afvalverwerkingsbedrijf -+ afvalverwerkingsinstallatie -+ afvalverwerkingsinstallaties -+ afvalverwijdering -+ afvalverwijderingsbedrijf -+ afvalwaterzuivering -+ afvalwedstrijden -+ afvloeiingen -+ afvloeiingskosten -+ afvloeiingslijst -+ afvloeiingslijsten -+ afvloeiingsmaatregel -+ afvloeiingsmaatregelen -+ afvoertroepen -+ afvoerweg -+ afvoerwegen -+ afvullen -+ afwaardering -+ afwasborstels -+ afwasborsteltje -+ afwasser -+ afwassers -+ afwasteil -+ afwasteilen -+ afwasteiltje -+ afweerapparaat -+ afweerhouding -+ afweerraket -+ afweerraketten -+ afweerreacties -+ afweersysteem -+ afwerkplaats -+ afwerkplaatsen -+ afwerkplek -+ afwerkplekken -+ afwezigheidslijst -+ afwezigheidslijsten -+ afwijkingsmogelijkheid -+ afwijzingsbrief -+ afwijzingsbrieven -+ afwikkelingen -+ afzegger -+ afzeggers -+ afzetbalk -+ afzetbalken -+ afzetmogelijkheid -+ afzetprijs -+ afzetprijzen -+ afzetprobleem -+ afzettingsprocedure -+ afzijdige -+ afzuigkappen -+ afzuigsysteem -+ afzwaaiers -+ afzwakking -+ agaragar -+ agaveplant -+ agaveplanten -+ agaves -+ agence -+ agences -+ agenderingsbevoegdheid -+ agent-provocateur -+ agentenuniformrokje -+ agentenuniformrokjes -+ agents-provocateurs -+ agglomeratieraad -+ agglomeratieraden -+ aggravaties -+ aggregaatstoestand -+ aggregaatstoestanden -+ agioreserve -+ agiostock -+ agitprops -+ agnosten -+ agogen -+ agogentaal -+ agorafobie -+ agressieveling -+ agressievelingen -+ agressors -+ agricultuur -+ agro-economie -+ agro-industrie -+ agro-industrieel -+ agro-industriële -+ agroalimentair -+ agroalimentaire -+ agrobiologie -+ agrobiologisch -+ agrobiologische -+ agrochemisch -+ agrochemische -+ agronomische -+ agrotechnologisch -+ agrotechnologische -+ aha-effect -+ aha-erlebnis -+ aha-erlebnissen -+ aha-ervaring -+ aha-ervaringen -+ ahornsiroop -+ ahs -+ aide-mémoiretje -+ aidsafdeling -+ aidsbesmetting -+ aidspatiënt -+ aidspatiënten -+ aidsremmer -+ aidsslachtoffer -+ aidsslachtoffers -+ aidstest -+ aidstests -+ aidstijdperk -+ aidsvaccin -+ aidsvirus -+ aio -+ aio's -+ aioli -+ aioplaats -+ aioplaatsen -+ aiostelsel -+ airbrush -+ airbussen -+ aircootje -+ aircospecialist -+ aircospecialisten -+ airhostess -+ airhostessen -+ airmail -+ airmarshal -+ airmarshals -+ airmile -+ airmiles -+ airplay -+ airstrip -+ airstrips -+ ajb -+ akela's -+ akeleien -+ aken -+ aki -+ akkerbouwbedrijf -+ akkerbouwer -+ akkerbouwers -+ akkerbouwgebied -+ akkerbouwgebieden -+ akkerbouwgewas -+ akkerbouwgewassen -+ akkerbouwgrond -+ akkerbouwproduct -+ akkerbouwproducten -+ akkoordverklaring -+ akoleien -+ al dente -+ alangalang -+ alarmbelprocedure -+ alarmcentrales -+ alarmfase -+ alarmfasen -+ alarmfunctie -+ alarmistische -+ alarmlijn -+ alarmpistool -+ alarmtoestanden -+ alba amicorum -+ album amicorum -+ albumpje -+ alchemistische -+ alchimistische -+ alcoholarm -+ alcoholarme -+ alcoholici -+ alcoholistische -+ alcoholpercentage -+ alcoholpercentages -+ alcoholprobleem -+ alcoholproblemen -+ alcoholpromillages -+ alcoholtests -+ alcoholverbod -+ alcoholvergiftiging -+ alcolade -+ aleatorische -+ aleviet -+ alevieten -+ alevitisch -+ alevitische -+ alfa-effect -+ alfabetiseringscursus -+ alfabetiseringscursussen -+ alfadeeltje -+ alfadeeltjes -+ alfastraling -+ alfawetenschap -+ alfawetenschappen -+ algemeenverbindendverklaring -+ algenbloei -+ algengroei -+ alia -+ alimentatiegeld -+ alinea-indeling -+ all right -+ all terrain bicycle -+ all-in -+ all-informule -+ all-informules -+ all-inpakket -+ all-inpakketten -+ all-inprijs -+ all-inprijzen -+ alledaagsheden -+ alleen-zijn -+ alleengaande -+ alleengaanden -+ alleensprekend -+ alleenverdienende -+ alleenvertoningsrecht -+ allegretto's -+ allegro's -+ alleluja's -+ alleraardigst -+ alleraardigste -+ allerarmst -+ allerbekendst -+ allerbekendste -+ allerbelabberdst -+ allerduurst -+ allerduurste -+ allereenvoudigst -+ allereenvoudigste -+ allergevoeligst -+ allergevoeligste -+ allergologen -+ allerheiligste -+ allerhoogste -+ allerkleinst -+ allermooist -+ allermooiste -+ allernieuwst -+ allernieuwste -+ allersimpelst -+ allersimpelste -+ allersterkst -+ allersterkste -+ allerverrukkelijkst -+ allerverrukkelijkste -+ allerzachtst -+ allerzachtste -+ allerzwakste -+ allerzwaksten -+ allerzwartst -+ allerzwartste -+ allesbeheersend -+ allesbeheersende -+ allesbranders -+ allesoverheersend -+ allesreinigers -+ allesvernietigend -+ alloceerde -+ alloceren -+ allochtonenbeleid -+ allochtonenproblematiek -+ allofonen -+ allogene -+ allomorfen -+ alloniemen -+ allrisk -+ allriskverzekering -+ allriskverzekeringen -+ allrounder -+ allrounders -+ allroundster -+ allroundsters -+ allterrainbike -+ allterrainbikes -+ alludeerde -+ allweather -+ allweatherkleding -+ alma -+ alma's -+ almachtsfantasie -+ almachtsfantasieën -+ almaviva's -+ aloeëtje -+ alomvattendheid -+ alpaca's -+ alpengebied -+ alpengebieden -+ alpenkauw -+ alpenkauwen -+ alpenkraai -+ alpenkraaien -+ alpenlandschap -+ alpentop -+ alpentoppen -+ alpenvereniging -+ alpenweides -+ alpiene -+ alpijnse -+ alpineski -+ alpineskiede -+ alpineskiet -+ alpinistische -+ alpino's -+ alpinopet -+ alpinopetten -+ alsjeblief -+ altaars -+ altaïstiek -+ altereerde -+ alternatieveling -+ alternatievelingen -+ altfluit -+ altfluiten -+ althea's -+ althobo -+ althobo's -+ altisten -+ alto -+ alto's -+ altsax -+ altsaxen -+ altsaxofonist -+ altsaxofonisten -+ altsaxofoon -+ altsaxofoons -+ alttoets -+ alttoetsen -+ altviolist -+ altviolisten -+ aluminiumindustrie -+ aluminiumoxide -+ aluminiumproductie -+ aluminiumsulfaat -+ alumni -+ alveolaire -+ alveolairen -+ alverman -+ alvermannen -+ alzheimer -+ alzheimerpatiënt -+ alzheimerpatiënten -+ ama -+ ama's -+ amah -+ amahs -+ amai -+ amalgama's -+ amanda's -+ amandelgeest -+ amandelontsteking -+ amandelontstekingen -+ amandelstaven -+ amants -+ amarillo's -+ amateurarcheologen -+ amateurarcheoloog -+ amateurbepaling -+ amateurbepalingen -+ amateurbokser -+ amateurboksers -+ amateurkampioen -+ amateurkampioenschap -+ amateuronderzoeker -+ amateuropname -+ amateuropnamen -+ amateuropnames -+ amateurtje -+ amateurvereniging -+ amateurverenigingen -+ amateurvoetballer -+ amateurvoetballers -+ amateurwielrennen -+ amateurwielrenner -+ amateurwielrenners -+ ambachtsgildes -+ ambachtskunst -+ ambassadegebouw -+ ambassadegebouwen -+ ambassadepersoneel -+ ambassadesecretaris -+ ambassadestaf -+ ambassadeurschap -+ ambassadeursniveau -+ ambassadeurspost -+ ambassadeursposten -+ ambassadeurswerk -+ ambassadewijk -+ amberkleurig -+ ambetant -+ ambetante -+ ambetanter -+ ambetantst -+ ambigue -+ ambiguïteiten -+ ambitieniveau -+ ambivalenties -+ ambo's -+ ambras -+ ambtenaartje -+ ambtenarenapparaat -+ ambtenarenbond -+ ambtenarencentrales -+ ambtenarenrecht -+ ambtenarenreglement -+ ambtenarensalaris -+ ambtenarensalarissen -+ ambtenarenstaat -+ ambtgenotes -+ ambtsgebieden -+ ambtsjubileum -+ ambulancehulp -+ ambulanceje -+ ambulancepersoneel -+ ambulanciers -+ ambulatoria -+ ambulatoriums -+ amendementsrecht -+ amendering -+ amenderingen -+ amerikaan -+ amerikanen -+ amerikaniseerde -+ amerikaniseren -+ amerikanisering -+ amerikanist -+ amerikanisten -+ amfetaminegebruik -+ amfetamines -+ amfibievoertuigen -+ amfora's -+ amigo's -+ aminozuur -+ aminozuurvolgorde -+ ammoniakemissie -+ ammoniakgeur -+ ammoniakuitstoot -+ ammonieten -+ amnestieregeling -+ amnestiewet -+ amnioscopen -+ amnioscopieën -+ amoebeabces -+ amoebeabcessen -+ amoebedysenterie -+ amoebes -+ ampexen -+ amplitudemodulatie -+ amplitudo's -+ ampulletje -+ ams -+ ams'er -+ ams'ers -+ amsoi -+ amto -+ amuse-gueules -+ amusementshal -+ amusementshallen -+ amusementsindustrie -+ amusementsmuziek -+ amusementssector -+ amusementswereld -+ amuses -+ amyotrofie -+ anabolisch -+ anabolische -+ anaconda's -+ anaerobe -+ anaeroob -+ anaforische -+ anafylactische -+ analfabete -+ analfabetische -+ analgetica -+ analysanten -+ analysatoren -+ analysators -+ analyseerbare -+ analyseresultaat -+ analysetechniek -+ anamneses -+ ananassap -+ anarchistencomplot -+ anarchistencomplotten -+ anchormen -+ anchorwoman -+ anchorwomen -+ ancien régime -+ anciens -+ andante's -+ andantino's -+ anders-zijn -+ anderskleurige -+ anderskleurigen -+ andersluidend -+ andersluidende -+ anderstalig -+ anderstalige -+ andersvalide -+ andersvaliden -+ andesgier -+ andesgieren -+ andragogen -+ andragogische -+ andragologen -+ andreaskruisen -+ androgene -+ androgyne -+ andschapsarchitecten -+ anekdotetje -+ anemoontje -+ anesthesiologen -+ angejiddeld -+ angejiddelde -+ angelusklok -+ angelusklokken -+ angiosperm -+ angiosperme -+ angisa -+ angisa's -+ anglofielen -+ angora's -+ angostura -+ angstaanval -+ angstcomplexen -+ angstgegner -+ angstgegners -+ angsthaas -+ angsthazen -+ angstneurose -+ angstneurosen -+ angstneuroses -+ angstpsychosen -+ angstpsychoses -+ angstreacties -+ angstschreeuwen -+ ani -+ anijstablet -+ anijstabletten -+ animatiefilm -+ animatiefilms -+ animaties -+ animatietechniek -+ animators -+ animistische -+ anita -+ anita's -+ ankerkader -+ ankerkaders -+ ankerman -+ ankermannen -+ ankerplaatsen -+ ankerpunt -+ ankerpunten -+ ankertouwen -+ ankervrouw -+ ankervrouwen -+ anlaut -+ annexatiepolitiek -+ anno Domini -+ annuleringsverzekeringen -+ anodiseerde -+ anomale -+ anonimiseerde -+ anoraks -+ anorexia-nervosapatiënt -+ anorexia-nervosapatiënten -+ anschluss -+ ansichten -+ ansichtkaarten -+ ansjovisfilet -+ ansjovisfilets -+ ante meridiem -+ anten -+ antenne-inrichting -+ antennekabel -+ antennekabels -+ antennetje -+ antennewoud -+ antennewouden -+ anthuriums -+ anti-Amerikaans -+ anti-Amerikaanse -+ anti-Joods -+ anti-Joodse -+ anti-Nederlands -+ anti-Nederlandse -+ anti-Russisch -+ anti-Russische -+ anti-Vietnamdemonstratie -+ anti-Vietnamdemonstraties -+ anti-Vietnamees -+ anti-Vietnamese -+ anti-imperialistisch -+ anti-imperialistische -+ anti-inflationair -+ anti-inflationaire -+ anti-inflatoir -+ anti-inflatoire -+ anti-intellectuele -+ anti-islamitisch -+ anti-islamitische -+ antiamerikanisme -+ antiapartheidsbeweging -+ antiapartheidsbewegingen -+ antiautoritair -+ antiautoritaire -+ antiballistisch -+ antiballistische -+ antibiotisch -+ antibiotische -+ antibolsjewistisch -+ antibolsjewistische -+ antibraakmiddel -+ antichristen -+ anticoagulantia -+ anticommunisme -+ anticommunistisch -+ anticommunistische -+ anticonceptiepillen -+ anticonceptiva -+ anticonceptivum -+ antideeltje -+ antideeltjes -+ antidepressiva -+ antidepressivum -+ antidiscriminatiewet -+ antiekbeurs -+ antiekbeurzen -+ antiekhandel -+ antiekveilingen -+ antiekwinkels -+ antiekwinkeltje -+ antiekzaak -+ antifascist -+ antifascisten -+ antifascistisch -+ antifascistische -+ antigeluid -+ antigen -+ antigifcentra -+ antigifcentrum -+ antiglobalist -+ antiglobalisten -+ antihelden -+ antiheldin -+ antiheldinnen -+ antihistaminica -+ antihistaminicum -+ antikapitalistisch -+ antikapitalistische -+ antiklerikalisme -+ antikraak -+ antikritieken -+ antilichaam -+ antilopes -+ antimaffiapolitie -+ antimaterie -+ antimetrie -+ antimetrieën -+ antimuggenspray -+ antimuggensprays -+ antinarcoticabrigade -+ antinarcoticabrigaden -+ antinarcoticabrigades -+ antinazi -+ antinazi's -+ antinazistisch -+ antinazistische -+ antiorangist -+ antipapistisch -+ antipapistische -+ antipersoneelsmijn -+ antipersoneelsmijnen -+ antiproton -+ antiprotonen -+ antipsychiatrie -+ antiquarenbeurs -+ antiracismebeweging -+ antiracist -+ antiracisten -+ antiracistisch -+ antiracistische -+ antiraketraket -+ antiraketraketten -+ antireclame -+ antirookcampagne -+ antirookcampagnes -+ antiroosshampoo -+ antiroosshampoos -+ antisandinistisch -+ antisandinistische -+ antisera -+ antiserum -+ antiserums -+ antislip -+ antislipcursussen -+ antisociaal -+ antisociale -+ antisocialistisch -+ antisocialistische -+ antistatische -+ antistrofes -+ antitankgeschut -+ antitankraket -+ antitankraketten -+ antiterreureenheden -+ antiterreureenheid -+ antiterreurpolitie -+ antiterrorisme -+ antiterroristisch -+ antiterroristische -+ antitoxines -+ antitrustwet -+ antitrustwetten -+ antiviraal -+ antivirale -+ antiwesterse -+ antizionisme -+ antizionistisch -+ antizionistische -+ antonpieckachtig -+ antonpieckachtige -+ antraciete -+ antracietgrijs -+ antracietgrijze -+ antracietkleurig -+ antracietkleurige -+ antrax -+ antropobiologie -+ antropocentrisch -+ antropocentrische -+ antropogene -+ antropologes -+ antropomorfische -+ antropomorfismen -+ antroponiemen -+ antroponymie -+ antroposofen -+ antropoïden -+ anussen -+ aoristi -+ aorta's -+ aortaklep -+ apaches -+ apachetraan -+ apaiseerde -+ apartheidsbewind -+ apartheidsregime -+ apartheidsstaat -+ apartheidstijd -+ apatriden -+ apenbroodbomen -+ apenbroodboom -+ apenjaren -+ apenkolonie -+ apenkolonies -+ apennootje -+ apennootjes -+ apenpak -+ apenpakken -+ apenrotsen -+ apenstaartje -+ apenstaartjes -+ aperitiefconcert -+ aperitiefconcerten -+ aperturen -+ aperçu's -+ aperçuutje -+ apetrotse -+ apezatte -+ apfelstrudel -+ apinti -+ apk-keuring -+ apocalyps -+ apocalypsen -+ apocope's -+ apocopeerde -+ apocopes -+ apografen -+ apokoinous -+ apolitieke -+ apollinisch -+ apollinische -+ apologen -+ apologische -+ apoplectische -+ apothekerscoöperatie -+ apothekersorganisatie -+ apothema's -+ apparaatskosten -+ appartementenblok -+ appartementenblokken -+ appartementenhotel -+ appartementsblok -+ appartementsblokken -+ appelgebak -+ appellantes -+ appellations -+ appelplaats -+ appelrechter -+ appelsiensap -+ appelvormig -+ appelvormige -+ appelwang -+ appelwangen -+ appelwangetje -+ appendanceje -+ appendances -+ appetizers -+ applausmachine -+ applausvervanging -+ applausvervangingen -+ applauswissel -+ applauswissels -+ applicatiecursussen -+ applique -+ appliqueerde -+ appliques -+ appositionele -+ après-skiede -+ après-skiet -+ après-skiën -+ aquacultuur -+ aquamarijne -+ aquanauten -+ aquarelleerde -+ aquatint -+ aquatinten -+ ara's -+ arabicakoffie -+ arabier -+ arabieren -+ arabiseerde -+ arabisering -+ arachideolie -+ arachnofobie -+ aramidevezel -+ arbeiderisme -+ arbeidersbuurt -+ arbeidersgezin -+ arbeidersjongen -+ arbeidersjongens -+ arbeiderskind -+ arbeiderskinderen -+ arbeidersmassa's -+ arbeidersmilieu -+ arbeidersmilieus -+ arbeidersparadijzen -+ arbeidersraden -+ arbeidersstad -+ arbeidersvrouw -+ arbeidersvrouwen -+ arbeiderswijk -+ arbeiderswijken -+ arbeidsbemiddelaar -+ arbeidsbemiddelaars -+ arbeidsbesparende -+ arbeidsconflicten -+ arbeidsdag -+ arbeidsdagen -+ arbeidsethiek -+ arbeidsgeneesheer -+ arbeidsgeneesheren -+ arbeidsgeschiktheid -+ arbeidsgewenning -+ arbeidshof -+ arbeidshygiëne -+ arbeidsinkomen -+ arbeidsinkomens -+ arbeidsinkomensquote -+ arbeidsinspecteur -+ arbeidsinspecteurs -+ arbeidsinzet -+ arbeidskostenforfait -+ arbeidskundigen -+ arbeidsleer -+ arbeidsloze -+ arbeidsmarktsituatie -+ arbeidsmigratie -+ arbeidsomstandighedenbeleid -+ arbeidsonbekwaamheid -+ arbeidsongeschiktheidspensioen -+ arbeidsongeschiktheidsregeling -+ arbeidsongeschiktheidswetten -+ arbeidsongevallen -+ arbeidspatronen -+ arbeidsplaatsenovereenkomst -+ arbeidspool -+ arbeidspools -+ arbeidsrechtbank -+ arbeidsrechtbanken -+ arbeidsrechtelijk -+ arbeidsrechten -+ arbeidsreserves -+ arbeidsrust -+ arbeidsschuwe -+ arbeidsslag -+ arbeidsterrein -+ arbeidsterreinen -+ arbeidstijdverlenging -+ arbeidstoeslagen -+ arbeidsvergunningen -+ arbeidsvolume -+ arbeidsvoorwaardelijk -+ arbeidsvoorwaardennota -+ arbeidsvoorzieningen -+ arbeidsvoorzieningsbeleid -+ arbeidszaken -+ arbiterskorps -+ arbitrageaankoop -+ arbitrageaankopen -+ arbitrageprocedure -+ arbitragezaak -+ arbodienst -+ arcadia's -+ archaïcum -+ archeofyt -+ archeofyten -+ archeologe -+ archeologes -+ archetypes -+ archiefbescheiden -+ archiefdoos -+ archiefdozen -+ archiefexemplaar -+ archiefexemplaren -+ archiefonderzoek -+ archiefruimte -+ archiefruimten -+ archiefruimtes -+ archiefwet -+ archievenkamer -+ archievenkamers -+ architectenduo -+ architectenvereniging -+ architectenverenigingen -+ architectenwinkels -+ architectuurcritici -+ architectuurcriticus -+ architectuurgeschiedenis -+ architectuurmuseum -+ architectuurprijs -+ architectuurprijzen -+ architectuurstudie -+ architectuurtekening -+ architectuurtekeningen -+ archivalische -+ arendsvluchten -+ arganolie -+ arganvrucht -+ arganvruchten -+ argumentering -+ aride -+ aristocrate -+ aristotelische -+ ariërverklaring -+ ariërverklaringen -+ armada's -+ armdik -+ armdikke -+ armeeën -+ armetierigheid -+ armgebaar -+ armgebaren -+ arminiaan -+ arminianen -+ armleggers -+ armlengten -+ armlengtes -+ armoedebestrijding -+ armoedegrens -+ armoedeprobleem -+ armoedevraagstuk -+ armoedje -+ armoeiig -+ armoeiige -+ armoelijder -+ armoelijders -+ armoezaaier -+ armoezaaiers -+ armspier -+ armspieren -+ armworp -+ armworpen -+ armworstelen -+ armzwaaien -+ arnhemmer -+ arpeggio's -+ arrestantenwagen -+ arrestantenwagens -+ arrestantenzorg -+ arrestantes -+ arrestatiebevelen -+ arrestatiegolf -+ arrestatieteam -+ arrestatieteams -+ arrivés -+ arrondissementsparketten -+ art deco -+ art-decostijl -+ artdirectors -+ arterieklem -+ arterieklemmen -+ arteriogram -+ arteriogrammen -+ arteriële -+ artes -+ articulatieplaats -+ articulatieplaatsen -+ articulatorische -+ artiestenfoyer -+ artiestenstal -+ artiestenwereld -+ artikelenreeks -+ artikelenserie -+ artillerie-eenheden -+ artillerie-eenheid -+ artillerieaanval -+ artillerieaanvallen -+ artillerieduel -+ artillerieduels -+ artilleriegeschut -+ artilleriestelling -+ artilleriestellingen -+ artisanale -+ artistiekelingen -+ artistiekerige -+ arts-assistent -+ arts-assistenten -+ arts-patiëntrelatie -+ artsenmonsters -+ artsenopleiding -+ artsenpraktijk -+ artsensyndicaat -+ artsensyndicaten -+ artsenvereniging -+ artsenverenigingen -+ artwork -+ artworks -+ asbakkenrassen -+ asbesthoudend -+ asbesthoudende -+ asbeststof -+ asbestvezel -+ asbestvezels -+ asbestvrij -+ asbestvrije -+ ascendanten -+ ascorbinezuur -+ asemde -+ asfaltdakwerk -+ asfaltjungle -+ asgrijs -+ asgrijze -+ asielaanvraag -+ asielaanvrage -+ asielaanvragen -+ asielgerechtigde -+ asielgerechtigden -+ asiels -+ asielwet -+ asielwetgeving -+ asielzoekerscentra -+ asielzoekerscentrum -+ asielzoekster -+ asielzoeksters -+ askegel -+ askegels -+ askussen -+ askussens -+ asla's -+ asladen -+ aslijn -+ aslijnen -+ asmogendheden -+ aso -+ aso's -+ asparagussen -+ aspecifieke -+ aspergekoppen -+ aspergepunten -+ asperger -+ aspergersyndroom -+ aspergeteelt -+ aspergeteler -+ aspergetelers -+ aspics -+ aspidistra's -+ aspirant-ministers -+ aspiratieniveaus -+ aspirinen -+ aspirines -+ asresten -+ assemblage-industrie -+ assemblagebedrijf -+ assemblagefabriek -+ assemblagehal -+ assemblagehallen -+ assemblages -+ assembleeleden -+ assembleelid -+ assemblees -+ assembleevoorzitter -+ assems -+ assepoezen -+ assertiviteitstrainingen -+ assessment -+ assessments -+ assetmanagement -+ assistent-bondscoach -+ assistent-bondscoaches -+ assistent-geneeskundige -+ assistent-geneeskundigen -+ assistent-manager -+ assistent-scheidsrechter -+ assistent-scheidsrechters -+ assistentschappen -+ assists -+ associatieakkoord -+ associatieovereenkomst -+ associatieovereenkomsten -+ associatieverdrag -+ associatieverdragen -+ associatievermogen -+ associeetje -+ assurantiebedrijf -+ assurantiebemiddeling -+ assurantiebemiddelingsbedrijf -+ assyriologen -+ assyriologie -+ assyriologisch -+ assyriologische -+ assyrioloog -+ astatische -+ asteroïdengordels -+ astertje -+ asthenische -+ astmapatiënten -+ astmatici -+ astraallichaam -+ astraallichamen -+ astringente -+ astrodynamica -+ astrofysica -+ astrofysici -+ astrofysische -+ astrolabia -+ astrologe -+ astrologes -+ astroturf -+ asymptoten -+ asyndeta -+ asystolieën -+ at-teken -+ at-tekens -+ atactische -+ atalanta's -+ atavismen -+ atelierbezoek -+ atelierhouder -+ atelierhouders -+ ateliertje -+ atelierwoning -+ atelierwoningen -+ athematische -+ atheïstische -+ atlanten -+ atlantici -+ atlanticum -+ atletendorp -+ atletenmakelaar -+ atletes -+ atletiekclub -+ atletiekclubs -+ atletiekkampioenschap -+ atletiekkampioenschappen -+ atletiekploeg -+ atletiekploegen -+ atletieksport -+ atletiekstadion -+ atletiekstadions -+ atletiekunie -+ atomiseerde -+ atoomaanvallen -+ atoomafval -+ atoombewapening -+ atoomcentra -+ atoomcentrales -+ atoomdeskundige -+ atoomdeskundigen -+ atoomduikboten -+ atoomenergieagentschap -+ atoomgeleerde -+ atoomgeleerden -+ atoomklok -+ atoomklokken -+ atoomkoppen -+ atoomnummer -+ atoomnummers -+ atoomonderzeeër -+ atoomonderzeeërs -+ atoomoorlogen -+ atoompacifisten -+ atoomparaplu's -+ atoomraket -+ atoomraketten -+ atoomreactoren -+ atoomreactors -+ atoomschepen -+ atoomschip -+ atoomschuilkelders -+ atoomsplitsingen -+ atoomstroom -+ atoomwapenprogramma -+ atopie -+ atopische -+ attaca's -+ attacheerde -+ attacheetje -+ attachékoffers -+ attachékoffertje -+ attaqueerde -+ attaques -+ attentaten -+ attituden -+ attitudeverandering -+ attitudeveranderingen -+ attributies -+ atv -+ atv-dag -+ atv-dagen -+ atypische -+ au bain-marie -+ aubergines -+ auctoriale -+ aucuba's -+ audiciens -+ audio-cd -+ audio-cd's -+ audioboek -+ audioboeken -+ audiocassettes -+ audiofonen -+ audiokabel -+ audiokabels -+ audiologen -+ audioproducten -+ audiotheken -+ audiotoer -+ audiotoers -+ audiotorens -+ auditdienst -+ auditdiensten -+ auditeerde -+ auditeur-generaal -+ auditeur-militair -+ auditeurs-generaal -+ auditeurs-militair -+ auditiezaal -+ auditiezalen -+ auditoraten -+ auditoren -+ auditors -+ aufklärung -+ augiasstal -+ augiasstallen -+ augustusdag -+ augustusdagen -+ auralezen -+ aurelia -+ aurelia's -+ auslaut -+ ausputzers -+ aussie -+ aussie-Engels -+ aussies -+ australe -+ auteursfilms -+ auteursrechtelijk -+ auteursrechtelijke -+ auteursrechtenbureau -+ auteursrechtenbureaus -+ auteursrechtenorganisatie -+ auteurswet -+ autisten -+ auto-export -+ auto-exporten -+ auto-immuunziekte -+ auto-immuunziekten -+ auto-import -+ auto-importen -+ auto-importeur -+ auto-importeurs -+ auto-inbraak -+ auto-inbraken -+ auto-industrie -+ auto-onderdeel -+ auto-onderdelen -+ autoalarm -+ autoalarmen -+ autobanden -+ autobanen -+ autobelasting -+ autobenzine -+ autobezit -+ autobezitters -+ autobom -+ autobomaanslag -+ autobomaanslagen -+ autobommen -+ autobranche -+ autocarrosserie -+ autocontrole -+ autocontroles -+ autocrossen -+ autocue -+ autocues -+ autodafe's -+ autodate -+ autodaten -+ autodatet -+ autodatete -+ autodealer -+ autodealers -+ autodidactische -+ autodiefstal -+ autodiefstallen -+ autofabriek -+ autofabrikant -+ autofusie -+ autogiro's -+ autokerkhoven -+ autokeuringen -+ autokraker -+ autokrakers -+ autolakken -+ autolamp -+ autolampen -+ autoleasebedrijf -+ autolicht -+ autolichten -+ autolobby -+ autologische -+ autoluw -+ autoluwe -+ automarkt -+ automarkten -+ automatenhallen -+ automatieken -+ automatieën -+ automatisatie -+ automatisaties -+ automatiseringsbedrijf -+ automatiseringssectoren -+ automatiseringssectors -+ automobielbranche -+ automobielinspectie -+ automobielsector -+ automodel -+ automodellen -+ automotoren -+ automotors -+ autoniem -+ autonieme -+ autoniemen -+ autonomen -+ autonomieakkoord -+ autonomieplan -+ autonomievergroting -+ autonomistische -+ autonummers -+ autopette -+ autoproductie -+ autopsies -+ autopsieën -+ autoraam -+ autoraampje -+ autoracen -+ autoreis -+ autoreizen -+ autorenbanen -+ autoreply -+ autoresponder -+ autoresponders -+ autoreverse -+ autorijles -+ autorijlessen -+ autorijscholen -+ autoroute -+ autorouten -+ autoroutes -+ autosalons -+ autoschade -+ autoschadeherstel -+ autoschepen -+ autoschip -+ autoshops -+ autoshow -+ autoshowroom -+ autoshowrooms -+ autoshows -+ autoslaaptreinen -+ autosleuteltje -+ autosloper -+ autosloperij -+ autosloperijen -+ autoslopers -+ autoslotspray -+ autoslotsprays -+ autosnelwegen -+ autospiegels -+ autospiegeltje -+ autostoel -+ autostoelen -+ autostop -+ autostrada's -+ autostradebrug -+ autostuur -+ autotelefoonverkeer -+ autotreinen -+ autotunnels -+ autotypes -+ autoverhuren -+ autoverkoop -+ autoverkopen -+ autoverschrikker -+ autoverschrikkers -+ autovervoer -+ autowegenvignet -+ autowegenvignetten -+ autozoektocht -+ autozoektochten -+ avant-gardetoneel -+ avant-gardisten -+ avant-gardistische -+ avant-première -+ avant-premières -+ ave's -+ aveetje -+ avenues -+ averechte -+ aversies -+ aversieve -+ avifauna's -+ avocado's -+ avondappel -+ avondappels -+ avondboterham -+ avondcursus -+ avondcursussen -+ avonddis -+ avondjurken -+ avondkranten -+ avondlessen -+ avondlijk -+ avondlijke -+ avondmaalstafel -+ avondmaalstafels -+ avondmaalsviering -+ avondmaalsvieringen -+ avondmens -+ avondmensen -+ avondmis -+ avondmist -+ avondnevel -+ avondonderwijs -+ avondpartijen -+ avondpermissies -+ avondploeg -+ avondploegen -+ avondstudent -+ avondstudenten -+ avondvierdaagsen -+ avondvlucht -+ avondvluchten -+ avondvoorstellingen -+ avondwandeling -+ avondwandelingen -+ avondwandelingetje -+ avondwedstrijden -+ avondwijdingen -+ avondwinkels -+ avonturenboek -+ avonturenboeken -+ avonturenfilms -+ avonturenverhaal -+ avonturenverhalen -+ avonturistisch -+ avonturistische -+ avontuurlijkheid -+ awara -+ awara's -+ awari -+ awari's -+ axels -+ axillaire -+ axolotls -+ ayatollahs -+ azc -+ azc's -+ azertyklavier -+ azertyklavieren -+ azijnpisser -+ azijnpissers -+ azimuts -+ azuki -+ azuki's -+ b's -+ b'tje -+ b.d. -+ b.g.g. -+ b.v.d. -+ baadde -+ baanatletiek -+ baancafeetje -+ baancafé -+ baancafés -+ baancommissarissen -+ baanderde -+ baanderen -+ baanloze -+ baanlozen -+ baanrecords -+ baanrenner -+ baanrenners -+ baansport -+ baansporten -+ baantjestrekker -+ baantjestrekkers -+ baanvast -+ baanvaste -+ baanvastheid -+ baardapen -+ baardhaartje -+ baardmankruik -+ baardmankruiken -+ baardmannen -+ baardstoppel -+ baardstoppels -+ baardwalvis -+ baardwalvissen -+ baarkruk -+ baarkrukken -+ baarmoederhalskanker -+ baarmoederkanker -+ baarmoederkoek -+ baarmoedermonden -+ baarmoederslijmvliezen -+ baartje -+ baba's -+ babbelbox -+ babbelboxen -+ babe -+ babes -+ babi pangang -+ babi's -+ babiroesa -+ babiroesa's -+ babyboomgeneratie -+ babydolls -+ babyeczeem -+ babyfoons -+ babykamers -+ babylanceje -+ babylancen -+ babylances -+ babymais -+ babymaïs -+ babyshampoo -+ babyshampoos -+ babysits -+ babysitte -+ babysitters -+ babyuitzet -+ baccaratje -+ bachelor-master -+ bachelor-masteropleiding -+ bachelor-masteropleidingen -+ bacheloropleiding -+ bacheloropleidingen -+ bachelors -+ bachelors-masters -+ bacillaire -+ back-upbestand -+ back-upbestanden -+ back-uppen -+ back-upt -+ back-upte -+ backbencher -+ backbenchers -+ backhands -+ backlijn -+ backlist -+ backlists -+ backoffice -+ backoffices -+ backpack -+ backpacken -+ backpacker -+ backpackers -+ backpackt -+ backpackte -+ backslash -+ backslashes -+ backspaces -+ backspin -+ backspins -+ backstage -+ backstagepasje -+ backstagepasjes -+ backt -+ backte -+ baco -+ baco's -+ bacootje -+ bacovenwinkel -+ bacovenwinkels -+ bacterie-infectie -+ bacterie-infecties -+ bacterieculturen -+ bacteriecultures -+ bacterieflora -+ bacteriekolonie -+ bacteriekolonies -+ bacteriekweken -+ bacteriocide -+ bacteriociden -+ badderde -+ badderen -+ baddoeken -+ badges -+ badhandje -+ badhandjes -+ badhokjes -+ badineerde -+ badjing -+ badjings -+ badkamerdeur -+ badkamerdeuren -+ badkamertegel -+ badkamertegels -+ badlakens -+ badmat -+ badmatten -+ badmintonbond -+ badmintonclub -+ badmintonclubs -+ badmintonde -+ badmintonner -+ badmintonners -+ badmintonploeg -+ badmintonploegen -+ badmintonracket -+ badmintonrackets -+ badmintonselectie -+ badmintonshuttle -+ badmintonshuttles -+ badmintonsport -+ badmintonster -+ badmintonsters -+ badmintontoernooi -+ badmintontoernooien -+ badmintonwereld -+ badmodes -+ badslipper -+ badstad -+ badsteden -+ badstranden -+ badtassen -+ baf -+ bagageafdeling -+ bagageafdelingen -+ bagageafhandeling -+ bagagedepots -+ bagagemandje -+ bagagemandjes -+ bagagerekken -+ bagagereçu's -+ bagagerijtuigen -+ bagageruimten -+ bagageruimtes -+ bagagewagentje -+ bagatelles -+ bagel -+ bagels -+ baggermateriaal -+ baggerschepen -+ baggerschip -+ baggerslib -+ baggerspecie -+ baggerwerken -+ baghera's -+ bagno's -+ bahai -+ bahaïsme -+ bahco's -+ baissedekking -+ baissedekkingen -+ baissepositie -+ baisseposities -+ baissetransactie -+ baissetransacties -+ bajesen -+ bajonetfittingen -+ bakabana -+ bakabana's -+ bakbanaan -+ bakbananen -+ bakerrijmpje -+ bakkeljauw -+ bakkenisten -+ bakkerij-patisserie -+ bakkersgast -+ bakkersgasten -+ bakkersvet -+ bakkersvetten -+ bakkersvrouw -+ bakkertje -+ bakkies -+ baklap -+ baklappen -+ bakluchten -+ bakra -+ bakra's -+ baksen -+ baksis -+ baksjisj -+ baksjisje -+ baksjisjen -+ bakste -+ baksteenarchitectuur -+ baksteenrode -+ baksteenrood -+ bakvet -+ bakvormen -+ balaanname -+ balaannames -+ balalaika's -+ balalaikaorkest -+ balalaikaorkesten -+ balanceerkunst -+ balanscijfers -+ balanspositie -+ balansregelaar -+ balansregelaars -+ balartiest -+ balartiesten -+ balcirculatie -+ balgevoel -+ balie-employeetje -+ balie-employé -+ balie-employés -+ baliemedewerkster -+ baliemedewerksters -+ baljurken -+ balkaniseerde -+ balkanisering -+ balkanvergeet-mij-niet -+ balkanvergeet-mij-nietje -+ balkonscène -+ balkonscènes -+ balkunstenaar -+ balkunstenaars -+ balladetje -+ balladezanger -+ balladezangers -+ ballastschop -+ ballastschoppen -+ ballaststof -+ ballaststoffen -+ ballenmeisje -+ ballenmeisjes -+ ballententen -+ balletacademie -+ balletgezelschap -+ balletgezelschappen -+ balletgroep -+ balletgroepen -+ balletje-balletje -+ balletkunst -+ balletorkest -+ balletorkesten -+ balletschoen -+ balletschoenen -+ balletschoentje -+ balletschool -+ ballingsoorden -+ ballistische -+ ballonfokken -+ ballonglas -+ ballonglazen -+ ballontenten -+ ballonvaarders -+ ballonvaarten -+ ballonvaren -+ ballpoints -+ ballroomdans -+ ballrooms -+ balneologie -+ balneologisch -+ balneologische -+ balpennetje -+ bals masqués -+ balsamicoazijn -+ balsemkruid -+ balsemkruiden -+ balsemlucht -+ baltsgedrag -+ baltste -+ baltstijd -+ baltsvluchten -+ balvaardig -+ balvaardige -+ balvaardigheid -+ balverliefd -+ balverliefde -+ balverlies -+ balvirtuoos -+ balvirtuoze -+ balvirtuozen -+ bama -+ bama's -+ bamafoon -+ bamafoons -+ bamaopleiding -+ bamaopleidingen -+ bambini -+ bamboepaal -+ bamboepalen -+ bamboespruit -+ bami goreng -+ bamiballen -+ bamis -+ bamischijf -+ bamischijven -+ bammoeder -+ bammoeders -+ bamzaaide -+ banalisering -+ bananenimport -+ bananenrepublieken -+ bananenvliegen -+ bandbreuk -+ bandbreuken -+ bandenfabriek -+ bandenpatroon -+ bandera's -+ banderilla's -+ banderillero's -+ bandgeheugen -+ bandgeheugens -+ bandleiders -+ bandmaat -+ bandoneonisten -+ bandoneons -+ bandopnames -+ bandopnemer -+ bandopnemers -+ bandplooibroek -+ bandplooibroeken -+ bandponsers -+ bandrecordertje -+ bandschuurmachines -+ bandsnelheden -+ bandsnelheid -+ bandzaag -+ bandzagen -+ banengroei -+ banenmarkten -+ banenplannen -+ banenpool -+ banenpooler -+ banenpoolers -+ banenpools -+ bangbroek -+ bangbroeken -+ bangeschijter -+ bangeschijters -+ bangige -+ banjerde -+ banjo's -+ bankbestuur -+ bankbiljettenomloop -+ bankbiljettenpers -+ bankboekjes -+ bankconti -+ bankconto -+ bankconto's -+ bankdeposito's -+ bankdisconto's -+ bankdrukken -+ bankemployeetje -+ bankencommissie -+ bankenconsortium -+ bankensector -+ bankensyndicaat -+ bankgaranties -+ bankgiro's -+ bankgirocentrales -+ bankierde -+ bankiersfamilie -+ bankierswereld -+ bankkaarten -+ bankkluis -+ bankkluizen -+ bankkredieten -+ bankloket -+ bankloketten -+ bankmannen -+ bankoperaties -+ bankovervaller -+ bankovervallers -+ bankpasje -+ bankrente -+ banksaldo's -+ bankstelletje -+ banktegoed -+ banktegoeden -+ banktransactie -+ bankverkeer -+ bankwerken -+ bankzitter -+ bankzitters -+ bantamgewichten -+ bantengs -+ banvloekte -+ baobab -+ baobabbomen -+ baobabboom -+ baobabs -+ baptisteria -+ bar mitswa -+ bar-dancing -+ bar-dancings -+ bar-restaurant -+ bara -+ bara's -+ barakkenkamp -+ barbarakruid -+ barbecuede -+ barbecuet -+ barbecueën -+ barbedienden -+ barbediendes -+ barbershop -+ barbershopkoor -+ barbershopkoren -+ barbershops -+ barbertjes -+ barbiepop -+ barbiepoppen -+ barbituraten -+ barcodes -+ barema -+ barema's -+ barenswee -+ baretje -+ barette -+ barettes -+ barettetje -+ baribal -+ baribals -+ baritonsaxofonist -+ baritonsaxofonisten -+ baritonsaxofoon -+ baritonsaxofoons -+ bariumpap -+ bariumsulfaat -+ barkeepers -+ barkeepster -+ barkeepsters -+ barkelners -+ barmeisjes -+ barmeubel -+ barmeubelen -+ barmeubels -+ barnevelder -+ barnevelders -+ barnumachtig -+ barnumachtige -+ barnumreclame -+ barokconcert -+ barokconcerten -+ barokorkest -+ barokorkesten -+ baroktuin -+ barpianist -+ barracuda's -+ barragepartijtje -+ barragepartijtjes -+ barreerde -+ barretje -+ barrièretje -+ barré -+ barréakkoord -+ barréakkoorden -+ barrés -+ bars-dancings -+ bars-restaurants -+ barstensvol -+ barstensvolle -+ bartender -+ bartenders -+ barzois -+ bas-bariton -+ bas-baritons -+ basdrum -+ baseballcaps -+ baseballde -+ baseballpetten -+ baseballt -+ basede -+ baseliners -+ baselines -+ basementen -+ basenpaar -+ basenparen -+ baset -+ basfluit -+ basfluiten -+ basgitaren -+ bashoorns -+ bashoren -+ bashorens -+ basilica's -+ basilicumblaadje -+ basilicumblaadjes -+ basisakkoord -+ basisartsen -+ basisbedrag -+ basisbehoefte -+ basisbehoeften -+ basisbeurs -+ basischemicaliën -+ basischemie -+ basiscursussen -+ basisfunctie -+ basisfuncties -+ basisgemeenschap -+ basisgemeenschappen -+ basisgemeente -+ basisgemeenten -+ basisgemeentes -+ basisgezondheidsdienst -+ basisgezondheidszorg -+ basishoek -+ basishoeken -+ basisideeën -+ basisindustrieën -+ basisinkomens -+ basisjaren -+ basislonen -+ basismetaal -+ basispakket -+ basisploeg -+ basispremies -+ basisprijzen -+ basispunt -+ basispunten -+ basisrente -+ basisscholen -+ basisschoolleerling -+ basisschoolleerlingen -+ basisspeler -+ basisspelers -+ basistarieven -+ basisteksten -+ basiswoordenlijst -+ basiswoordenlijsten -+ basketbalcompetitie -+ basketbalde -+ basketbalfederatie -+ basketballen -+ basketballer -+ basketballers -+ basketbalspelers -+ basketbalwedstrijd -+ basketbalwedstrijden -+ baskets -+ basketschoen -+ basketschoenen -+ basketspeler -+ basketspelers -+ baskette -+ basketten -+ basketter -+ basketters -+ baskiet -+ baskieten -+ basklarinetten -+ basmati -+ basmatirijst -+ basralokus -+ basreflexkasten -+ bassets -+ basta's -+ bastaardhond -+ bastaardhonden -+ bat mitswa -+ bataljonsstaf -+ batches -+ bathyscafen -+ batje -+ batons -+ bats -+ batsmen -+ batte -+ batter -+ batterijkip -+ batterijkippen -+ batterijlader -+ batterijladers -+ batterijlamp -+ batterijlampen -+ batterijontstekingen -+ batterijoplader -+ batterijopladers -+ batters -+ battingwicket -+ battingwickets -+ battledressen -+ bauxietbedrijf -+ bauxietmaatschappij -+ bauxietmarkt -+ bauxietsector -+ bauxietstad -+ bavaroistje -+ baxters -+ bazigheid -+ bazooka's -+ bazuinkoor -+ bazuinkoren -+ baäl -+ bbp -+ bc. -+ beaamd -+ beachvolleybal -+ beademingen -+ beademingsapparaat -+ beademingsapparatuur -+ beademingstoestellen -+ beagle -+ beagles -+ beamer -+ beamers -+ beangstigend -+ bearnaisesaus -+ beatbox -+ beatboxen -+ beate -+ beatgroepen -+ beatlehaar -+ beatmis -+ beatmissen -+ beatniks -+ beats -+ beats per minute -+ beaufortschaal -+ beautycases -+ beautyfarm -+ beautyfarms -+ beautés -+ bebloemd -+ bebloemde -+ bebophaar -+ beboterd -+ beboterde -+ beboteren -+ bebrild -+ bebrilde -+ becquerel -+ bedampen -+ bedampt -+ bedampte -+ bedbanken -+ bedde in -+ beddenlakens -+ beddenplanken -+ beddenspreien -+ bedelarmbanden -+ bedeltjes -+ bedenker -+ bedenkster -+ bedenksters -+ bedes -+ bedevaartsoord -+ bedevaartsoorden -+ bedevaartsplaatsen -+ bedevaartstocht -+ bedevaartvaantje -+ bedevaartvaantjes -+ bedgeheimen -+ bedgenotes -+ bediendecontracten -+ bediendevakbonden -+ bedieners -+ bedieningsfouten -+ bedilzuchtig -+ bedilzuchtige -+ bedingingen -+ bedisselcultuur -+ bedlamp -+ bedlampen -+ bedoeken -+ bedoekt -+ bedoekte -+ bedolah -+ bedpan -+ bedpannen -+ bedplank -+ bedplanken -+ bedplassen -+ bedplasser -+ bedreiger -+ bedreigers -+ bedriegertjes -+ bedrijfs-cao -+ bedrijfs-pc-netwerk -+ bedrijfsadministraties -+ bedrijfsadvocaat -+ bedrijfsadvocaten -+ bedrijfschappen -+ bedrijfsculturen -+ bedrijfsethiek -+ bedrijfsgericht -+ bedrijfsgerichte -+ bedrijfsingenieur -+ bedrijfsintern -+ bedrijfsinterne -+ bedrijfskantines -+ bedrijfsklare -+ bedrijfskrediet -+ bedrijfskredieten -+ bedrijfslaboratoria -+ bedrijfslaboratorium -+ bedrijfsleidingen -+ bedrijfsonzeker -+ bedrijfsonzekere -+ bedrijfsplan -+ bedrijfspsychologen -+ bedrijfsrevisor -+ bedrijfsrevisoren -+ bedrijfsrevisors -+ bedrijfsruimten -+ bedrijfsruimtes -+ bedrijfsspecifiek -+ bedrijfsspecifieke -+ bedrijfstak-cao -+ bedrijfstakgewijs -+ bedrijfstakgewijze -+ bedrijfstakregeling -+ bedrijfstechniek -+ bedrijfstechnische -+ bedrijfsuitgaven -+ bedrijfsvergunningen -+ bedrijfsvoorheffing -+ bedrijfsvoorheffingen -+ bedrijfsvoorlichters -+ bedrijfszekere -+ bedrijfszetel -+ bedrijfszetels -+ bedrijvencentra -+ bedrijvencentrum -+ bedrijvencomplex -+ bedrijvenpark -+ bedrijvenparken -+ bedrijventerrein -+ bedrijventerreinen -+ bedscènes -+ bedstedeplank -+ bedstedeplanken -+ bedstedes -+ bedsteeplank -+ bedsteeplanken -+ bedwants -+ bedwantsen -+ beekdal -+ beekdalen -+ beeldbanden -+ beelddragers -+ beeldenrijk -+ beeldenrijke -+ beeldenstormen -+ beeldententoonstelling -+ beeldfrequentie -+ beeldfrequenties -+ beeldhoeken -+ beeldhouwsters -+ beeldradio -+ beeldrecht -+ beeldregie -+ beeldromans -+ beeldschermpje -+ beeldschriften -+ beeldtechnici -+ beeldtelefoons -+ beeldverbinding -+ beeldverbindingen -+ beeldverslagen -+ beencel -+ beencellen -+ beenderstelsel -+ beenfracturen -+ beengezwellen -+ beenhard -+ beenharde -+ beenmergcel -+ beenmergcellen -+ beenmergontstekingen -+ beenmergtransplantatie -+ beenmergtransplantaties -+ beenpit -+ beenpitten -+ beenslagen -+ beenstompen -+ beenwarmers -+ beenweefsels -+ beenworpen -+ beerton -+ beertonnen -+ beestenbenden -+ beestenbendes -+ beestenvoer -+ beestmensen -+ beestte -+ beetgaar -+ beetgare -+ beetgegrepen -+ beetgehouden -+ beetgekregen -+ beetgrijpen -+ beethouden -+ befte -+ beganegrondwoning -+ beganegrondwoningen -+ begeertes -+ begeesterd -+ begeesterde -+ begeesteren -+ begeestering -+ begeleidingsbands -+ begeleidingsgroep -+ begeleidingsinstituut -+ begeleidingsmuziek -+ begeleidingsorkest -+ begeleidingsorkesten -+ begeleidingsteam -+ begeleidwonenproject -+ begeleidwonenprojecten -+ begierd -+ begierde -+ begilde -+ beginfasen -+ beginfases -+ begingeneriek -+ begingenerieken -+ beginjaar -+ beginnerscursus -+ beginnerscursussen -+ beginopstelling -+ beginselakkoord -+ beginselenwet -+ beginselovereenkomst -+ beginsignalen -+ begintitel -+ begintitels -+ begintune -+ begintunes -+ begintunetje -+ beginwoord -+ beginwoorden -+ beglazingen -+ begonia's -+ begoniaatje -+ begrafenisvereniging -+ begrenzer -+ begrenzers -+ begrijpelijkerwijze -+ begrippenapparaat -+ begrippenkaders -+ begrippenpaar -+ begrippenparen -+ begripsinhoud -+ begripsinhouden -+ begripsmatig -+ begripsmatige -+ begripsomschrijvingen -+ begripsvormingen -+ begripvol -+ begripvolle -+ begrotingsakkoord -+ begrotingsoverschrijding -+ begrotingsoverschrijdingen -+ begrotingsruimten -+ begrotingsruimtes -+ begrotingsstukken -+ begrotingsvoorstel -+ begrotingsvoorstellen -+ begunstigingen -+ behaatje -+ behandelbaar -+ behandelbare -+ behandelcentra -+ behandelcentrum -+ behandelingsduur -+ behandelingswijzen -+ behandelkamers -+ behandelstoelen -+ behandeltafel -+ behapbaar -+ behapbare -+ behartiger -+ behartigers -+ behavioristische -+ beheerkosten -+ beheermaatregel -+ beheermaatregelen -+ beheermaatschappij -+ beheerovereenkomst -+ beheerovereenkomsten -+ beheerpersoneel -+ beheerplan -+ beheerplannen -+ beheersbare -+ beheersgebied -+ beheersgebieden -+ beheersmaatschappij -+ beheersmatig -+ beheersovereenkomst -+ beheersovereenkomsten -+ beheerstaak -+ beheerstichting -+ beheerstichtingen -+ beheerstructuur -+ beheersvormen -+ beheertaak -+ beheertaken -+ beheervorm -+ beheervormen -+ beheime -+ behemoth -+ behemoths -+ behendigheidsspelen -+ behoeftepatroon -+ behoeftes -+ behoorlijkheid -+ behoudsgezind -+ behoudsgezinde -+ behoudzuchtig -+ behoudzuchtige -+ beier -+ beieren -+ beiers -+ beigeachtig -+ beigeachtige -+ beignetje -+ bejaagbaar -+ bejaagbare -+ bejaardencentra -+ bejaardenflat -+ bejaardenhome -+ bejaardenhomes -+ bejaardenhulpen -+ bejaardenpaspoorten -+ bejaardenpassen -+ bejaging -+ bekampen -+ bekampt -+ bekampte -+ bekendgestaan -+ bekentenisliteratuur -+ bekentenislitteratuur -+ bekercompetitie -+ bekerde -+ bekerduel -+ bekerduels -+ bekerfinale -+ bekerfinales -+ bekerhouder -+ bekerhouders -+ bekertoernooi -+ bekertoernooien -+ bekervoetbal -+ bekkenfractuur -+ beklagcommissie -+ beklagcommissies -+ beklagrecht -+ beklemmingen -+ beklemtoning -+ beknelling -+ bekostigingssystematiek -+ bekrachtigingen -+ bekvechtte -+ belachelijkheden -+ belachelijkheid -+ beladingsgraad -+ belangenbehartigingsorganisatie -+ belangenconflict -+ belangenconflicten -+ belangenpartij -+ belangenpartijen -+ belangenvermenging -+ belangenverstrengelingen -+ belangenvertegenwoordiger -+ belanggesteld -+ belangstellen -+ belangstellingssfeer -+ belastingaangifteformulier -+ belastingaangifteformulieren -+ belastingafdracht -+ belastingafdrachten -+ belastingambtenaar -+ belastingambtenaren -+ belastingbrief -+ belastingbrieven -+ belastingcontroleur -+ belastingcontroleurs -+ belastingfraude -+ belastingheffing -+ belastingheffingen -+ belastinginspecteurs -+ belastinginspectie -+ belastinginspecties -+ belastingjaar -+ belastingjaren -+ belastingkamers -+ belastingmaatregel -+ belastingontduikingen -+ belastingontvanger -+ belastingontvangers -+ belastingopbrengst -+ belastingopbrengsten -+ belastingparadijs -+ belastingparadijzen -+ belastingquoten -+ belastingrechtspraak -+ belastingschijven -+ belastingtarieven -+ belastingtelefoon -+ belastingverhoging -+ belastingverhogingen -+ belastingverlagingen -+ belastingverzwaring -+ belastingverzwaringen -+ belatafeld -+ belatafelde -+ belatafelen -+ belbus -+ belbussen -+ belcanto's -+ belcanto-opera -+ belcanto-opera's -+ beleefdheidsfrase -+ beleerd -+ beleerde -+ beleggersgroep -+ beleggerskringen -+ beleggersmarkt -+ beleggerspubliek -+ beleggingmaatschappij -+ beleggingsadvies -+ beleggingsadviezen -+ beleggingsanalist -+ beleggingsanalisten -+ beleggingsclub -+ beleggingsclubs -+ beleggingsexpert -+ beleggingsexperts -+ beleggingsportefeuille -+ beleggingsrekening -+ beleidsadviseur -+ beleidsadviseurs -+ beleidsbepaler -+ beleidsbepalers -+ beleidscentra -+ beleidscentrum -+ beleidsconvenant -+ beleidsfout -+ beleidsfouten -+ beleidsinhoudelijk -+ beleidsinhoudelijke -+ beleidskwesties -+ beleidsmaker -+ beleidsmakers -+ beleidsmatige -+ beleidsmedewerkster -+ beleidsmedewerksters -+ beleidsondersteunend -+ beleidsondersteunende -+ beleidsstudie -+ beleidsstudies -+ beleidsstuk -+ beleidswetenschappen -+ beleningsfaciliteit -+ beleningstarief -+ beleningstarieven -+ beleren -+ belerend -+ belerende -+ belevingswaarde -+ belevingswerelden -+ belg -+ belgen -+ belgicist -+ belgicisten -+ belgicistisch -+ belgicistische -+ belichters -+ belichtingsmeters -+ belijning -+ belkaart -+ belkaarten -+ belle époque -+ bellengeblazen -+ bellentableau -+ bellentableaus -+ beller -+ bellers -+ belles -+ belofte-eed -+ beloftevol -+ beloftevolle -+ beloningsverhouding -+ beloningsverschil -+ beloningsverschillen -+ beloningsvorm -+ beloodsing -+ beloopbaar -+ beloopbare -+ beltegoeden -+ beltonen -+ beltoon -+ belucht -+ beluchten -+ beluchting -+ beluchtte -+ beluistering -+ belvorming -+ belwinkel -+ belwinkels -+ bemeesterd -+ bemeesterde -+ bemeesteren -+ bemerking -+ bemerkingen -+ bemiddelaarsrol -+ bemiddelbaar -+ bemiddelbare -+ bemiddelingscommissie -+ bemiddelingspoging -+ bemiddelingspogingen -+ bemiddelingsrol -+ bemoederde -+ bemoeials -+ bemoeizuchtig -+ bemoeizuchtige -+ benadrukking -+ benauwenis -+ benauwenissen -+ benchmark -+ benchmarken -+ benchmarking -+ benchmarks -+ benchmarkt -+ benchmarkte -+ bendeleider -+ bendeleiders -+ bendeoorlog -+ bendeoorlogen -+ bendewezen -+ bendir -+ bendirs -+ benedenbuurman -+ benedenbuurvrouw -+ benedendeks -+ benedenlands -+ benedenlandse -+ benedenmaats -+ benedenmaatse -+ benedenruimte -+ benedenstroom -+ benedenstroomse -+ benedenwaartse -+ benedenwindse -+ benedenwoningen -+ benedictijnenabdij -+ benefietconcert -+ benefietconcerten -+ benefiets -+ benefietvoorstellingen -+ benefietwedstrijden -+ benenwerk -+ beng -+ benigne -+ benoemingenbeleid -+ benoemingsbeleid -+ benoemingscommissie -+ benoemingscommissies -+ benoemingsprocedures -+ benoemingstermijn -+ bensjen -+ bensjte -+ bents -+ benuttigd -+ benuttigde -+ benuttigen -+ benzine-injectie -+ benzine-injecties -+ benzineaansteker -+ benzineaanstekers -+ benzineaccijns -+ benzineaccijnzen -+ benzinebommen -+ benzinebon -+ benzinebonnen -+ benzineleiding -+ benzineleidingen -+ benzinelucht -+ benzinepomphouder -+ benzinepomphouders -+ benzineprijs -+ benzineprijzen -+ benzinestank -+ benzinetanks -+ benzineverbruik -+ benzoëzuur -+ beo's -+ beoordelingscommissies -+ bepaalbare -+ bepaaldelijke -+ bepantsering -+ beplating -+ bepleiter -+ bepleiters -+ bepruiken -+ bepruikt -+ bepruikte -+ berberaap -+ berberapen -+ berbers -+ berceuseje -+ berceuses -+ berceusetje -+ bere-interessant -+ bere-interessante -+ beredderig -+ beredderige -+ beregeld -+ beregelde -+ beregelen -+ beregening -+ beregeningsinstallatie -+ beregeningsinstallaties -+ beregoede -+ bereikbaarheidsprobleem -+ bereikbaarheidsproblemen -+ bereikbaarheidstoeslag -+ berekenende -+ berekeningsmethoden -+ berekeningsmethodes -+ berenboek -+ berenburg -+ berenburger -+ berenhap -+ berenhappen -+ berenhol -+ berenholen -+ berenklauwen -+ berenkuilen -+ berenleider -+ berenleiders -+ berenlul -+ berenlullen -+ berenmutsen -+ berenvel -+ berenvellen -+ beresterke -+ beretrotse -+ bergamotolie -+ bergbeken -+ bergbeklimmen -+ bergdorp -+ bergdorpen -+ berger -+ bergers -+ bergetappen -+ bergetappes -+ bergflank -+ bergflanken -+ bergformaties -+ berggids -+ berggidsen -+ berghokken -+ berghutten -+ bergingsoperatie -+ bergingsoperaties -+ bergingsploeg -+ bergingsploegen -+ bergingswerk -+ bergingswerkzaamheden -+ bergkappen -+ bergklassement -+ bergklassementen -+ bergkoning -+ bergkoningen -+ berglandschap -+ berglandschappen -+ bergmeertje -+ bergmeubelen -+ bergmeubels -+ bergriviertje -+ bergtijdritten -+ bergumermeerklasse -+ bergvolk -+ bergvolken -+ bergvolkeren -+ bergwandeling -+ bergwandelingen -+ bergwater -+ bergweg -+ bergwegen -+ bergweggetje -+ bergweides -+ berichtencentrum -+ berichtenstroom -+ berichtenverkeer -+ berkenstam -+ berkenstammen -+ berlinerbol -+ berlinerbollen -+ bermuda's -+ bernhardtiti -+ bernhardtiti's -+ beroepbare -+ beroepengidsen -+ beroeper -+ beroepers -+ beroepingswerk -+ beroepsacteur -+ beroepsacteurs -+ beroepsarbeid -+ beroepsbeoefenaar -+ beroepsbeoefenaars -+ beroepsblinde -+ beroepschrift -+ beroepschriften -+ beroepscodes -+ beroepscollege -+ beroepsdeformaties -+ beroepskeuzevoorlichting -+ beroepskostenvergoeding -+ beroepskostenvergoedingen -+ beroepsmatige -+ beroepsmisvormingen -+ beroepsmoordenaar -+ beroepsmoordenaars -+ beroepsoriëntatie -+ beroepsprofiel -+ beroepsprofielen -+ beroepssport -+ beroepssporten -+ beroepstrots -+ beroepsvoetbal -+ beroepswielrennen -+ beroepswielrenner -+ beroepswielrenners -+ beroete -+ berstensvolle -+ beschavingsproces -+ beschavingsziekten -+ beschavingsziektes -+ beschermelingetje -+ beschermingsaandeel -+ beschermingsaandelen -+ beschermingsgebied -+ beschermingsgebieden -+ beschermingsmaatregel -+ beschermingsmaatregelen -+ beschermingsmacht -+ beschermingszone -+ beschermingszones -+ beschermlaag -+ beschermlaagje -+ beschermlagen -+ beschermwaardig -+ beschermwaardige -+ beschermwaardigheid -+ bescheurkalenders -+ beschikbaarstelling -+ beschikkingsmacht -+ beschouwelijkheid -+ beschouwingswijze -+ beschouwingswijzen -+ beschuitbollen -+ beschuitgras -+ beslagkommen -+ beslagname -+ beslagnames -+ beslismoment -+ beslismomenten -+ beslisruimte -+ beslissingspartij -+ beslissingspartijen -+ beslissingspartijtje -+ beslissingsrecht -+ beslissingsvrijheid -+ besluitvormend -+ besluitvormer -+ besluitvormers -+ besluitvormingscentrum -+ besluitvormingsprocedure -+ besluitvormingsprocedures -+ besluitvormingsstructuur -+ besmettingen -+ besmettingsbron -+ besmettingsgeval -+ besmettingsgevallen -+ besmettingskans -+ besmettingsrisico -+ besmuikte -+ besnijdenissen -+ besnijder -+ besnijders -+ besparingsbeleid -+ besparingsmaatregel -+ besparingsmaatregelen -+ bespelers -+ bespeurbaar -+ bespeurbare -+ bespreekbaarheid -+ bespreker -+ besprekers -+ bespuugd -+ bespuugde -+ bessenjam -+ bestaansbasis -+ bestaansgrond -+ bestaansgronden -+ bestaansrechten -+ bestaansreden -+ bestaansredenen -+ bestaansvoorwaarde -+ bestaanszekerheden -+ bestandslijnen -+ bestandsovereenkomst -+ bestandsovereenkomsten -+ bestandsschending -+ bestandsschendingen -+ bestandsvervuiling -+ bestbetaald -+ bestbetaalde -+ bestedingsbeperkingen -+ bestedingsimpuls -+ bestedingsimpulsen -+ bestedingsmogelijkheden -+ bestedingsmogelijkheid -+ bestedingspakketten -+ bestedingspatronen -+ bestekbakken -+ bestelautootje -+ bestelbons -+ bestelbus -+ bestelbusje -+ bestelbussen -+ bestelletje -+ bestemmingsheffing -+ bestemmingsheffingen -+ bestemmingsplanprocedure -+ bestemmingsplanprocedures -+ bestiaria -+ bestiariums -+ bestolenen -+ bestratingen -+ bestrijdingsmethode -+ bestrijdingsmethoden -+ bestrijdingsmethodes -+ bestrijdingsmiddelengebruik -+ bestrijdingsmiddelenwet -+ bestrijdingswijze -+ bestrijdingswijzen -+ bestsellerauteur -+ bestsellerauteurs -+ bestsellerlijst -+ bestsellerlijsten -+ bestsellerschrijver -+ bestsellerschrijvers -+ bestsellerslijst -+ bestsellerslijsten -+ besturenbond -+ besturenbonden -+ besturenorganisatie -+ besturenraad -+ bestuurderspartij -+ bestuurdersstoel -+ bestuurlijk-technisch -+ bestuurlijk-technische -+ bestuursbevoegdheden -+ bestuursbevoegdheid -+ bestuurscentrum -+ bestuursdienst -+ bestuurshervorming -+ bestuurshervormingen -+ bestuurskundig -+ bestuurskundigen -+ bestuurslagen -+ bestuursmacht -+ bestuursmandaat -+ bestuursmandaten -+ bestuursmodel -+ bestuursmodellen -+ bestuursopzichter -+ bestuursopzichters -+ bestuursorganisatie -+ bestuursraad -+ bestuursraden -+ bestuursrechtelijk -+ bestuursrechtelijke -+ bestuurssecretaris -+ bestuurssecretarissen -+ bestuursverkiezing -+ bestuursverkiezingen -+ bestuursvoorzitters -+ bestuurswetenschappen -+ bestuurswijziging -+ bestuurswijzigingen -+ bestuurswisseling -+ bestuurswisselingen -+ bestuurszetel -+ bestuurszetels -+ bestverkocht -+ bestverkochte -+ bestverkopend -+ bestverkopende -+ betaal-tv -+ betaalbaarheid -+ betaalpassen -+ betaalrekening -+ betaalrekeningen -+ betaalterminal -+ betaalterminals -+ betalingsbalanshulp -+ betalingsbalansprobleem -+ betalingsbalansproblemen -+ betalingsbalanssteun -+ betalingsbalanstekort -+ betalingsbalanstekorten -+ betalingsplicht -+ betalingssysteem -+ betalingswijzen -+ betastingen -+ betbetovergrootmoeder -+ betbetovergrootmoeders -+ betekenisgeving -+ betekenisloosheid -+ betekenisontwikkeling -+ betekenisontwikkelingen -+ betekenisverandering -+ betekenisveranderingen -+ betellen -+ beterweter -+ beterweters -+ betoelaagd -+ betoelaagde -+ betoelagen -+ betoelaging -+ betoelagingen -+ betonelement -+ betonelementen -+ betonmuren -+ betonmuur -+ betonplaat -+ betonschaar -+ betonscharen -+ betonskeletten -+ betonstaal -+ betontegel -+ betontegels -+ betonwerker -+ betonwerkers -+ betovergrootouder -+ betrekkelijkheden -+ bett. -+ betuttelaars -+ betuttelingen -+ betweterig -+ betweterige -+ betwijfelbaar -+ betwijfelbare -+ beugelzagen -+ beurelen -+ beursbarometer -+ beurscrash -+ beursfonds -+ beursfondsen -+ beursgang -+ beursgenoteerd -+ beursgenoteerde -+ beursgoeroe -+ beurshausse -+ beursindexen -+ beursintroductie -+ beursintroducties -+ beursleden -+ beurslid -+ beursmakelaar -+ beursmalaise -+ beursoverval -+ beursreglementen -+ beursschandaal -+ beursschandalen -+ beursval -+ beursvloer -+ beurswaakhond -+ beurswaakhonden -+ beurswezen -+ beurtrol -+ beurtstaking -+ beurtstakingen -+ beurtsysteem -+ beurzenstelsel -+ beveiligingsbedrijf -+ beveiligingscamera -+ beveiligingscamera's -+ beveiligingsindustrie -+ beveiligingsmaatregel -+ beveiligingsmaatregelen -+ beveiligingsorganisatie -+ bevek -+ beveks -+ bevelende -+ bevelslijn -+ bevelslijnen -+ bevelsstructuur -+ bevestigingsmiddel -+ bevestigingspunt -+ bevestigingspunten -+ bevindelijkheid -+ bevlogenen -+ bevoegden -+ bevoegdhedenverdeling -+ bevoegdheidseis -+ bevoegdheidseisen -+ bevolkingsboekhouding -+ bevolkingscentra -+ bevolkingscentrum -+ bevolkingsconcentratie -+ bevolkingsconcentraties -+ bevolkingsdruk -+ bevolkingsexplosies -+ bevolkingslaag -+ bevolkingslagen -+ bevolkingspiramiden -+ bevolkingspiramides -+ bevolkingsprognose -+ bevolkingsprognoses -+ bevolkingstoename -+ bevoogdde -+ bevoogding -+ bevooroordeling -+ bevoorradingsvaart -+ bevriezingen -+ bevrijdingsactie -+ bevrijdingsbewegingen -+ bevrijdingsfeest -+ bevrijdingsfeesten -+ bevrijdingslegers -+ bevrijdingstheologen -+ bevrijdingstheologie -+ bevrijdingstheoloog -+ bevuiling -+ bewaarmiddel -+ bewaarmiddelen -+ bewaartijden -+ bewakingsapparatuur -+ bewakingsbeambte -+ bewakingsbeambten -+ bewakingsfirma -+ bewakingsfirma's -+ bewakingspersoneel -+ bewakingssysteem -+ bewapeningsindustrie -+ bewapeningsplan -+ bewapeningsplannen -+ bewapeningsprogramma -+ bewapeningsprogramma's -+ bewapeningsrace -+ bewegelijkheid -+ beweger -+ bewegers -+ bewegingsapparaat -+ bewegingsdrang -+ bewegingsenergie -+ bewegingskunst -+ bewegingsmogelijkheden -+ bewegingsmogelijkheid -+ bewegingsruimte -+ bewegingsstoornis -+ bewegingsstoornissen -+ bewegingstheater -+ bewegingstherapeuten -+ bewegingstherapieën -+ bewegingswet -+ bewegingswetenschap -+ bewegingswetenschappen -+ bewegingswetten -+ beweginkje -+ bewegwijzerd -+ bewegwijzerde -+ bewening -+ bewerkbaar -+ bewerkbare -+ bewezenverklaring -+ bewezenverklaringen -+ bewijsgaring -+ bewilligingsverklaring -+ bewilligingsverklaringen -+ bewindsliedenoverleg -+ bewindspersonen -+ bewindspersonenoverleg -+ bewindsvrouwen -+ bewolkingsgraad -+ bewonerscomité -+ bewonerscomités -+ bewonerscommissie -+ bewonerscommissies -+ bewonersorganisatie -+ bewoningsgeschiedenis -+ bewoningslaag -+ bewoningslagen -+ bewustgemaakt -+ bewustmaken -+ bewustwordingsproject -+ bewustwordingsprojecten -+ bewustzijnsdalingen -+ bewustzijnsinhoud -+ bewustzijnsinhouden -+ bewustzijnsniveaus -+ bewustzijnstoestand -+ bewustzijnsverlies -+ bewustzijnsvernauwingen -+ bewustzijnsverruimende -+ bewustzijnsverruiming -+ bewustzijnverruimend -+ bewustzijnverruimende -+ bezemkast -+ bezemkasten -+ bezemklassen -+ bezemwagens -+ bezetenheidsdans -+ bezetenheidsdansen -+ bezettingsactie -+ bezettingsacties -+ bezettingsgraden -+ bezettingsjaar -+ bezettingsjaren -+ bezettingsmacht -+ bezettingsmachten -+ bezettingstijd -+ bezettingszone -+ bezettingszones -+ bezieldheid -+ bezieler -+ bezielers -+ bezigheidstherapieën -+ bezinningsperiode -+ bezitsconstructie -+ bezitsconstructies -+ bezitsdrang -+ bezitsverhouding -+ bezitsverhoudingen -+ bezitterig -+ bezitterige -+ bezoekdag -+ bezoekdagen -+ bezoekdata -+ bezoekdatum -+ bezoekdatums -+ bezoekersruimte -+ bezoekersstromen -+ bezoekersstroom -+ bezorgdienst -+ bezorgingen -+ bezuiniger -+ bezuinigers -+ bezuinigingsbeleid -+ bezuinigingsoperatie -+ bezuinigingsronden -+ bezuinigingsrondes -+ bezuinigingsvoorstel -+ bezuinigingsvoorstellen -+ bezwaarmaker -+ bezwaarmakers -+ bezwaarprocedure -+ bezwaarprocedures -+ bezwaarschriftprocedure -+ bezwaarschriftprocedures -+ bezwarenprocedure -+ bezwarenprocedures -+ bezweringsformule -+ beëlzebub -+ beëlzebubs -+ beïnvloedbaarheid -+ beïnvloedingen -+ beïnvloedingsmogelijkheden -+ beïnvloedingsmogelijkheid -+ bh -+ bh's -+ bi -+ bi's -+ bib -+ bibberaties -+ bibbergeld -+ biblebelt -+ bibliobussen -+ bibliotheekboek -+ bibliotheekboeken -+ bibliotheekcentrale -+ bibliotheekcentrales -+ bibliotheekwezen -+ biccen -+ bicommunautair -+ bicommunautaire -+ bidetje -+ bidonnetje -+ bidons -+ bidonvilles -+ bidsprinkhaan -+ bidsprinkhanen -+ biebs -+ biechthokje -+ biechthokjes -+ biedermeiertijd -+ biedermeiertje -+ biedermeiertjes -+ biedingen -+ biedingsbericht -+ biedstijl -+ biedsysteem -+ biedverloop -+ bierbak -+ bierbakken -+ biergarten -+ biergartens -+ biergist -+ bierhal -+ bierkaartje -+ bierkaartjes -+ bierproductie -+ bierschuim -+ biersoorten -+ biertent -+ biervaatje -+ bierverbruik -+ bierwachten -+ biesbok -+ biesbokken -+ bietencampagne -+ bietsers -+ bigband -+ bigbandleider -+ bigbandleiders -+ bigbandmuziek -+ bigbands -+ bigbangtheorie -+ biggenkruid -+ bij geruchte vernemen -+ bijballen -+ bijbanen -+ bijbelpapier -+ bijbelslot -+ bijbelsloten -+ bijberoep -+ bijberoepen -+ bijdetijdse -+ bijdrager -+ bijdrageregeling -+ bijdragers -+ bijdrages -+ bijdruk -+ bijectie -+ bijecties -+ bijeengescharreld -+ bijeffect -+ bijensteek -+ bijensteken -+ bijgedachtes -+ bijgedrukt -+ bijgegooid -+ bijgeklust -+ bijgeladen -+ bijgeplakt -+ bijgepraat -+ bijgeschoold -+ bijgevoederd -+ bijgevoerd -+ bijgezeten -+ bijgooien -+ bijholteontstekingen -+ bijklussen -+ bijklusser -+ bijklussers -+ bijkrediet -+ bijkredieten -+ bijladen -+ bijltjesdag -+ bijmenging -+ bijna-akkoord -+ bijna-botsing -+ bijna-botsingen -+ bijna-doodervaring -+ bijna-doodervaringen -+ bijna-kabinetscrisis -+ bijna-ongeluk -+ bijna-ongelukken -+ bijna-ramp -+ bijna-rampen -+ bijna-unanimiteit -+ bijnierschorshormonen -+ bijnierschorshormoon -+ bijnummers -+ bijoutje -+ bijplakken -+ bijprogramma's -+ bijrolacteur -+ bijrolacteurs -+ bijrolletje -+ bijschildklier -+ bijschildklieren -+ bijscholingen -+ bijscholingscursus -+ bijscholingscursussen -+ bijscholingsprogramma -+ bijscholingsprogramma's -+ bijsluitertekst -+ bijstandsambtenaar -+ bijstandsambtenaren -+ bijstandsgerechtigd -+ bijstandsgerechtigde -+ bijstandsregeling -+ bijstandsuitkeringen -+ bijstandsvrouwen -+ bijstandswetten -+ bijtgaar -+ bijtgare -+ bijtgraag -+ bijtgrage -+ bijtring -+ bijtringen -+ bijvangst -+ bijvangsten -+ bijverdienregeling -+ bijverlichting -+ bijverzekerd -+ bijverzekeren -+ bijverzekering -+ bijvoederen -+ bijvoeren -+ bijvrouw -+ bijvrouwen -+ bijzaal -+ bijzaaltje -+ bijzalen -+ biker -+ bikers -+ bikker -+ bikkers -+ bilan -+ bilans -+ bilateraaltje -+ bilateraaltjes -+ bildungsroman -+ bildungsromans -+ biljarden -+ biljartclub -+ biljartclubs -+ biljarter -+ biljarters -+ biljarts -+ biljarttafel -+ biljarttafels -+ biljettenautomaat -+ biljettenautomaten -+ billboard -+ billboardformaat -+ billboards -+ billenknijper -+ billenknijpers -+ billentikker -+ billentikkers -+ bilnaden -+ bilspleet -+ bilspleten -+ bima -+ bima's -+ bimetaal -+ binationale -+ bindmorfeem -+ bindmorfemen -+ bindweefselcel -+ bindweefselcellen -+ bingode -+ bingoot -+ bingoën -+ binnenbekleding -+ binnenbochten -+ binnenboordmotor -+ binnenboordmotoren -+ binnendiameter -+ binnendringers -+ binnenduingebied -+ binnenduinrand -+ binnenduwen -+ binnenflap -+ binnengebleven -+ binnengeduwd -+ binnengegleden -+ binnengeklommen -+ binnengemarcheerd -+ binnengemeentelijk -+ binnengemeentelijke -+ binnengerend -+ binnengerijfd -+ binnengerold -+ binnengeschoten -+ binnengeschreden -+ binnengespeeld -+ binnengevaren -+ binnengevlucht -+ binnengewandeld -+ binnengewipt -+ binnengezeild -+ binnenglijden -+ binnengrens -+ binnengrenzen -+ binnenhofs -+ binnenhofse -+ binnenhuisinrichting -+ binnenkerkelijk -+ binnenkerkelijke -+ binnenklimaat -+ binnenklimmen -+ binnenkoer -+ binnenkoeren -+ binnenlagen -+ binnenlandbewoner -+ binnenlandbewoners -+ binnenlijnen -+ binnenmarcheren -+ binnenmarkt -+ binnenmeer -+ binnenmeren -+ binnenmotor -+ binnenoor -+ binnenopnames -+ binnenpad -+ binnenpaden -+ binnenpost -+ binnenpret -+ binnenpretjes -+ binnenrand -+ binnenrennen -+ binnenrijm -+ binnenrijmen -+ binnenrijven -+ binnenring -+ binnenrollen -+ binnenschepen -+ binnenschieten -+ binnenschrijden -+ binnenslepen -+ binnenspelen -+ binnenspiegels -+ binnenstedelijk -+ binnenstedelijke -+ binnenstraat -+ binnenstraten -+ binnenstromen -+ binnentrap -+ binnentuin -+ binnenvaarder -+ binnenvaarders -+ binnenvaartconflict -+ binnenvaartschipper -+ binnenvaartschippers -+ binnenvaartuigen -+ binnenvaartvloot -+ binnenvaren -+ binnenvelden -+ binnenvelders -+ binnenverlichtingen -+ binnenvissers -+ binnenvlucht -+ binnenvluchten -+ binnenwacht -+ binnenzeilen -+ binoculairs -+ bio -+ bio's -+ biobakken -+ biochemici -+ biochemieconcern -+ biochemische -+ biociden -+ biocides -+ biodiversiteitsverdrag -+ biofruit -+ biofysici -+ biogene -+ biogenetische -+ biografe -+ biografes -+ biografietje -+ biokatalysatoren -+ biologes -+ biologielokaal -+ biologieonderwijs -+ biologiestudent -+ biologiestudenten -+ biologiewinkel -+ biologiewinkels -+ biologisch-dynamisch -+ biologisch-dynamische -+ biomechanische -+ biometrisch -+ biometrische -+ biopic -+ biopics -+ bioreactoren -+ bioritmen -+ bioscoopbezoeker -+ bioscoopbonden -+ bioscoopbonnen -+ bioscoopexploitant -+ bioscoopexploitanten -+ bioscoopjournaal -+ bioscoopjournaals -+ bioscoopkaartje -+ bioscoopkaartjes -+ bioscoopladder -+ bioscoopreclames -+ bioscoopstoel -+ bioscooptheater -+ bioscoopzaal -+ bioscoopzaaltje -+ biotechnologiebedrijf -+ biotopen -+ biowetenschappen -+ bipolaire -+ birambi -+ birambi's -+ birdie -+ birdies -+ birmaan -+ birmanen -+ biseks -+ biseksualiteit -+ bisjaar -+ bismillah -+ bisschoppenconferentie -+ bisschoppensynode -+ bisschopswijn -+ bisschopswijnen -+ bisschopszetel -+ bisschopwijnen -+ bissers -+ bisstudent -+ bisstudenten -+ biste -+ bitawiwiri -+ bitch -+ bitches -+ bitmap -+ bitmaps -+ bits per second -+ bitter lemon -+ bitterballen -+ bitterblad -+ bittergarnituren -+ bitterkoekjespudding -+ bitterkoekjespuddinkje -+ bitterkoud -+ bitterpee -+ bitterpeeën -+ bitumineerde -+ blaarkop -+ blaarkoppen -+ blaasjesziekte -+ blaaskanker -+ blaaskapellen -+ blaaskwartetten -+ blaaskwintet -+ blaaskwintetten -+ blaasontstekingen -+ blaasontstekinkje -+ blaasorkesten -+ blaasproeven -+ blaaswier -+ blaaswieren -+ blabla -+ blablafiguren -+ blablafiguur -+ black boxen -+ black metal -+ black-outs -+ bladachtig -+ bladachtige -+ bladbegonia's -+ bladderig -+ bladderige -+ bladerboek -+ bladerboeken -+ bladerdak -+ bladerdek -+ bladgeel -+ bladmetaal -+ bladmetalen -+ bladspiegels -+ bladval -+ bladvezel -+ bladvezels -+ bladvormen -+ bladziekten -+ bladziektes -+ bladzijtje -+ blakaman -+ blakamans -+ blakst -+ blancheerde -+ blanda's -+ blankhouten -+ blankvoorn -+ blasfemeerde -+ blasfemische -+ blauwbaarden -+ blauwborst -+ blauwborsten -+ blauwgeverfd -+ blauwgeverfde -+ blauwgroene -+ blauwhelm -+ blauwhelmen -+ blauwvoeterie -+ blauwvos -+ blauwvossen -+ blauwwier -+ blauwwieren -+ blauwwit -+ blauwwitte -+ blauwzuurgas -+ blazersensemble -+ blazerssectie -+ bleekgeel -+ bleekgele -+ bleekneusje -+ bleekneusjes -+ bleekneuzen -+ bleekscheet -+ bleekscheten -+ bleekschijter -+ bleekschijters -+ blenden -+ blender -+ blenders -+ blerken -+ blerkte -+ blessureleed -+ blessuretje -+ blessurevrij -+ blessurevrije -+ blessuurtje -+ blieps -+ blijf-van-mijn-lijfhuis -+ blijf-van-mijn-lijfhuizen -+ blijfhuis -+ blijfhuizen -+ blikjeswaren -+ bliksemaanval -+ bliksemaanvallen -+ bliksembezoeken -+ blikseminslagen -+ bliksemoorlogen -+ bliksemoperaties -+ bliksemschichten -+ bliksemse -+ bliksemslag -+ bliksemslagen -+ blikvelden -+ blikvernauwingen -+ blikvoedsel -+ blimbing -+ blimbings -+ blinddammen -+ blindedarmoperatie -+ blindedarmoperaties -+ blindelingse -+ blindenbibliotheken -+ blindengeleidehonden -+ blindenstip -+ blindenstippen -+ blindenstokken -+ blindgestaard -+ blindgevaren -+ blindstaren -+ blindvaren -+ blitse -+ blitskikkers -+ blockbuster -+ blockbusters -+ blocnotevel -+ blocnotevellen -+ blocnotevelletje -+ bloedader -+ bloedaderen -+ bloedaders -+ bloedbaden -+ bloedbanden -+ bloedbanen -+ bloedbanken -+ bloedbeelden -+ bloedbroeder -+ bloedbroeders -+ bloedcel -+ bloedcellen -+ bloeddonatie -+ bloeddonaties -+ bloeddonors -+ bloeddoping -+ bloeddorstigheid -+ bloeddrukdaling -+ bloeddrukmeters -+ bloeddruppel -+ bloeddruppels -+ bloeddruppeltje -+ bloedfactor -+ bloedfactoren -+ bloedgang -+ bloedgroepenstrijd -+ bloedgroepgenoot -+ bloedhete -+ bloedinkje -+ bloedlijn -+ bloedlijnen -+ bloedmonster -+ bloedmonsters -+ bloednerveus -+ bloednerveuze -+ bloedplaatjes -+ bloedprocessies -+ bloedproeven -+ bloedproppen -+ bloedserieus -+ bloedserieuze -+ bloedspatten -+ bloedspiegel -+ bloedspiegels -+ bloedsporen -+ bloedstolseltje -+ bloedsuikergehalten -+ bloedsuikergehaltes -+ bloedsuikers -+ bloedsuikerspiegels -+ bloedtest -+ bloedtests -+ bloedvatwand -+ bloedvatwanden -+ bloedvolume -+ bloedvorm -+ bloedvorming -+ bloedwijnen -+ bloeiperiode -+ bloeiseizoen -+ bloeitijden -+ bloembladeren -+ bloembollensector -+ bloembollenteelt -+ bloemencorso's -+ bloemencorsootje -+ bloemengeuren -+ bloemenhandel -+ bloemenkrans -+ bloemenkransen -+ bloemenmannen -+ bloemenpracht -+ bloemenspuiten -+ bloemenstal -+ bloemenstalen -+ bloemenstoet -+ bloemenstoeten -+ bloementeelt -+ bloementeler -+ bloementelers -+ bloemententoonstelling -+ bloemenveiling -+ bloemenveilingen -+ bloemenzee -+ bloemenzeeën -+ bloemetjesbehang -+ bloemetjesjurk -+ bloemetjesjurken -+ bloemetjesmotief -+ bloemkooloor -+ bloemkooloren -+ bloemkwekerijen -+ bloemleesde -+ bloemlezen -+ bloemlezer -+ bloemlezers -+ bloemmotieven -+ bloempotkapsel -+ bloempotkapsels -+ bloemstilleven -+ bloemstillevens -+ bloemsuiker -+ bloemzak -+ bloemzakken -+ bloesemgeur -+ bloesemtak -+ bloesemtakken -+ blog -+ blogde -+ bloggen -+ blogs -+ blogt -+ blokbanden -+ blokbeest -+ blokbeesten -+ blokcursussen -+ blokdenken -+ blokdiagrammen -+ blokhak -+ blokhakken -+ blokhoofden -+ blokhut -+ blokhutten -+ blokkadeactie -+ blokkadeacties -+ blokkeringen -+ blokletterde -+ blokletteren -+ blokperiode -+ blokpolis -+ blokpolissen -+ blokrijden -+ blokuren -+ blokuur -+ blokverwarmingen -+ bloodst -+ bloody mary -+ bloody mary's -+ bloopers -+ blootblaadje -+ blootblad -+ blootbladen -+ blootgelegen -+ blootstellingen -+ blossen -+ bloteriken -+ blouseje -+ blousons -+ blow-outs -+ blowde -+ blowers -+ blowt -+ blowtje -+ blubberde -+ bluegrass -+ bluejeans -+ bluesband -+ bluesgitarist -+ bluesmuziek -+ bluesrock -+ blueszanger -+ blueszangeres -+ blufferig -+ blufferige -+ blunderaar -+ blunderaars -+ blusboten -+ bluswerk -+ bluswerkzaamheden -+ blèten -+ blètte -+ bnp -+ boards -+ bobbaan -+ bobbelgum -+ bobby's -+ bobijnhouder -+ bobijnhouders -+ bobines -+ bobo -+ bobo's -+ bobs -+ bobsleebaan -+ bobsleebond -+ bobsleede -+ bobsleeploeg -+ bobsleeër -+ bobsleeërs -+ bobtails -+ bochtafsnijding -+ bochtafsnijdingen -+ bochtenwerk -+ bodega's -+ bodemanalyses -+ bodemarchief -+ bodemattest -+ bodemattesten -+ bodembedekker -+ bodembedekkers -+ bodembescherming -+ bodembeslag -+ bodembroeder -+ bodembroeders -+ bodemdaling -+ bodemdegradatie -+ bodemdier -+ bodemdieren -+ bodemfauna -+ bodemkoers -+ bodemkoersen -+ bodemkundig -+ bodemkundige -+ bodemkundigen -+ bodemlaag -+ bodemlagen -+ bodemmonsters -+ bodempensioenen -+ bodemprocedure -+ bodemprocedures -+ bodemprofielen -+ bodemrijkdommen -+ bodemsanering -+ bodemsaneringsregeling -+ bodemschat -+ bodemstructuren -+ bodemuitkeringen -+ bodemvocht -+ bodemvochtigheid -+ bodemvondst -+ bodemvondsten -+ bodemvoorzieningen -+ bodemziekte -+ bodemziekten -+ bodemziektes -+ bodybag -+ bodybags -+ bodyboard -+ bodyboardde -+ bodyboarden -+ bodyboardt -+ bodybuild -+ bodybuildde -+ bodybuilden -+ bodybuilder -+ bodybuilders -+ bodybuildt -+ bodychecks -+ bodyliners -+ bodymilk -+ bodypaint -+ bodypaints -+ bodysafe -+ bodysafes -+ bodyscan -+ bodyscans -+ bodysuit -+ bodysuits -+ bodywarmers -+ boeddhologen -+ boeddhologie -+ boeddhologisch -+ boeddhologische -+ boeddholoog -+ boedelschuld -+ boegbeelden -+ boeggolf -+ boegschroeven -+ boeienkoningen -+ boekbespreker -+ boekblok -+ boekblokken -+ boekdrukker -+ boekdrukkers -+ boekenbals -+ boekenbank -+ boekenbezit -+ boekenbons -+ boekenclubs -+ boekenfonds -+ boekengidsen -+ boekenhuur -+ boekenleggers -+ boekenonderzoek -+ boekenverzamelaar -+ boekenverzamelaars -+ boekhandelketen -+ boekhandelsgroep -+ boekhandelsketen -+ boekhoudtechniek -+ boekingsbureau -+ boekingssysteem -+ boeklong -+ boeklongen -+ boekuitgaven -+ boekverbrandingen -+ boekverkopersbond -+ boekwetenschap -+ boekwezen -+ boekwinkeltje -+ boekwinsten -+ boemelbussen -+ boemerangeffecten -+ boerderijdier -+ boerderijdieren -+ boerenafkomst -+ boerenbuiten -+ boerengezin -+ boerengolf -+ boerenham -+ boerenhoeves -+ boerenhofstedes -+ boerenkaffers -+ boerenkapel -+ boerenkazen -+ boerenlul -+ boerenlullen -+ boerenmarkt -+ boerenmarkten -+ boerenmetworst -+ boerenmetworsten -+ boerenstiel -+ boerenstulp -+ boerenstulpen -+ boerenwormkruid -+ boerinnenbond -+ boerinnenbonden -+ boerka -+ boerka's -+ boeteprediker -+ boetepredikers -+ boetesysteem -+ boetpredicatie -+ boetpredicaties -+ boetpredicatiën -+ boetprocessie -+ boetprocessies -+ boevenpak -+ boevenwagens -+ boezemfibrilleren -+ bofkont -+ bofkonten -+ bogey -+ bogeys -+ bohemer -+ bohemers -+ bohemien -+ bohemienne -+ bohemiennes -+ bohemiens -+ bokkenpootje -+ bokkenpootjes -+ bokkenwagens -+ bokkinees -+ bokkinezen -+ bokkraan -+ bokkranen -+ boksbal -+ boksballen -+ boksbond -+ boksbonden -+ boksersneuzen -+ bokspringen -+ boksringen -+ boksschool -+ bolbliksems -+ bolderkarren -+ bolderpen -+ bolderpennen -+ bolero's -+ boletri -+ boliden -+ bolivar -+ bolivars -+ bolknakken -+ bolknaks -+ bolkoppen -+ bollantaarn -+ bollantaarns -+ bollantaren -+ bollantarens -+ bollebof -+ bollebofs -+ bollekes -+ bollenstreken -+ bollenteelt -+ bollewangenhapsnoet -+ bolspits -+ bolspitsen -+ bolstaande -+ bolvormen -+ bolwoning -+ bolwoningen -+ bomauto -+ bombardementsvlucht -+ bombardementsvluchten -+ bombarden -+ bombardes -+ bombel -+ bombels -+ bomberjack -+ bomberjacks -+ bomcheck -+ bomchecken -+ bomcheckt -+ bomcheckte -+ bomenbestand -+ bomendijk -+ bomenlaan -+ bomma -+ bomma's -+ bommeldingen -+ bommencampagne -+ bommenrichter -+ bommenrichters -+ bommentapijten -+ bommoeder -+ bommoeders -+ bompa -+ bompa's -+ bomtrechters -+ bomvrouw -+ bomvrouwen -+ bon vivant -+ bon vivants -+ bondgenotes -+ bondsbureaus -+ bondscoachschap -+ bondsdagen -+ bondselftallen -+ bondskanseliers -+ bondskanselierschap -+ bondsland -+ bondslanden -+ bondsman -+ bondsploeg -+ bondsploegen -+ bondspresidenten -+ bondspresidentschap -+ bondssponsor -+ bondstrainers -+ bondsvergadering -+ bondsvertegenwoordiger -+ bondsvertegenwoordigers -+ bondsvoorzitters -+ bonensalade -+ bongerds -+ bongo's -+ bonhomme -+ bonhommes -+ boni's -+ bonificatieseconde -+ bonificatieseconden -+ bonne bouche -+ bonnes bouches -+ bonobo's -+ bonsaibomen -+ bonsaiboom -+ bonsaiboompje -+ bonsais -+ bontbekplevier -+ bontbekplevieren -+ bontbladig -+ bontebok -+ bontebokken -+ bonthandel -+ bontmanteltje -+ bontstola's -+ bonus-malusregeling -+ boobytraps -+ boodschappenlijsten -+ boodschappenwagen -+ boodschappenwagens -+ boodschapperig -+ boodschapperige -+ boodschapperstof -+ boogbal -+ boogbruggetje -+ boogfries -+ boogfriezen -+ boogiewoogie -+ boogiewoogies -+ boogschieten -+ boogveld -+ boogvelden -+ boogvormen -+ booleaans -+ booleaanse -+ boomblaadje -+ boomblad -+ boombladen -+ boombladeren -+ boomblaren -+ boomboa -+ boomboa's -+ boomchirurgen -+ boomdiagram -+ boomdiagrammen -+ boomgroepen -+ boomhut -+ boomhutten -+ boomkikker -+ boomkikkers -+ boomkor -+ boomkorren -+ boomkorvisserij -+ boomkruiper -+ boomkruipers -+ boomlang -+ boomlange -+ boomvrucht -+ boomvruchten -+ boomzaad -+ boomzagen -+ boontjedief -+ boontjedieven -+ boordcomputer -+ boordcomputers -+ boordinstrument -+ boordinstrumenten -+ boordpapieren -+ boordradio -+ boordwijdte -+ booreilanden -+ boorgruis -+ boorhamer -+ boorhamers -+ boorinstallaties -+ boorkernen -+ boorkoppen -+ boorlocatie -+ boorlocaties -+ boorpijp -+ boorpijpen -+ boorplatformen -+ boorplatforms -+ boorschepen -+ boorspillen -+ boortollen -+ boorwerkzaamheden -+ boosters -+ booteigenaar -+ booteigenaars -+ booteigenaren -+ booten -+ boothals -+ boothalzen -+ bootleg -+ bootlegging -+ bootlegs -+ bootlengten -+ bootlengtes -+ bootrace -+ bootraces -+ bootreis -+ bootreizen -+ bootsnelheid -+ boppers -+ boppertje -+ bordeauxrode -+ bordeauxrood -+ bordeelbezoek -+ bordeelsluiper -+ bordeelsluipers -+ bordeelverbod -+ bordelaises -+ bordendoeken -+ bordenwarmers -+ borderlinepatiënt -+ borderlinepatiënten -+ borderliner -+ borderliners -+ borderterriër -+ borderterriërs -+ bordkarton -+ bordkartonnen -+ bordreclame -+ bordspel -+ bordspelen -+ borduurgarens -+ borelingen -+ borgpennen -+ borgsommen -+ borrelgarnituren -+ borrelglaasje -+ borrelnoot -+ borreluurtje -+ borsalino's -+ borstamputaties -+ borstelgras -+ borstharen -+ borstkolf -+ borstkolven -+ borstmicrofoons -+ borstprothese -+ borstprothesen -+ borstprotheses -+ borstslagen -+ borstspier -+ borstspieren -+ borstwervel -+ borstwervels -+ bosaanleg -+ bosaanplanten -+ bosaardbei -+ bosaardbeien -+ bosaardbeitje -+ bosananas -+ bosananassen -+ bosbodem -+ bosbodems -+ bosbouwbedrijf -+ bosbouwer -+ bosbouwers -+ bosbouwkundig -+ bosbouwkundige -+ bosbouwkundigen -+ bosbouwproject -+ bosfazant -+ bosfazanten -+ bosgeest -+ bosgeesten -+ bosgeuren -+ bosgezicht -+ boskabouter -+ boskabouters -+ boskap -+ bosklas -+ bosklassen -+ boslandcreolen -+ boslandcreool -+ boslandcreools -+ boslandcreoolse -+ boslanddignitaris -+ boslanddignitarissen -+ boslandschap -+ boslopen -+ bosmeester -+ bosmeesters -+ bosmier -+ bosmieren -+ bosmiertje -+ bosmuis -+ bosmuizen -+ bosnegerdorp -+ bosonen -+ bospapaja -+ bospapaja's -+ bospenen -+ bosplan -+ bospolitie -+ bosrank -+ bossanova's -+ bosspin -+ bosspinnen -+ bossterfte -+ bosterreinen -+ bosviooltjes -+ boswachterijen -+ boswachtershuis -+ boswachtershuizen -+ boswandelingetje -+ bosyaws -+ botdichtheid -+ botel -+ botels -+ botenbouw -+ botenbouwer -+ botenbouwers -+ botenhuizen -+ botenterrein -+ boter-kaas-en-eieren -+ boterbergen -+ botergeel -+ botergele -+ boterhamtrommeltjes -+ boterhamzakje -+ boterhamzakjes -+ boterstaven -+ botervlinder -+ botervlinders -+ botervloten -+ botkanker -+ botontkalking -+ botox -+ botrest -+ botresten -+ botsauto -+ botsauto's -+ botsingsenergie -+ botsproef -+ botsproeven -+ botsveiligheid -+ botteling -+ bottellijn -+ bottellijnen -+ bottenkrakers -+ bottlenecks -+ bottom-up -+ bougainvilles -+ bougainvilletje -+ bougiesleutels -+ bouillabaisseje -+ bouillabaissetje -+ bouillontablet -+ bouillontabletten -+ boulanger -+ boulangers -+ boulevardje -+ bourbons -+ bourgondisch -+ bourgondische -+ bourgondiër -+ bourgondiërs -+ bourrees -+ bouviertje -+ bouw-cao -+ bouwaannemer -+ bouwaannemers -+ bouwafval -+ bouwcommissies -+ bouwconstructies -+ bouwcontingenten -+ bouwcontract -+ bouwcontracten -+ bouwde herop -+ bouwfase -+ bouwfasen -+ bouwfases -+ bouwfirma -+ bouwfirma's -+ bouwfondsen -+ bouwjaren -+ bouwkavel -+ bouwkavels -+ bouwkundestudent -+ bouwkundestudenten -+ bouwkunstterm -+ bouwlagen -+ bouwliften -+ bouwlocatie -+ bouwlocaties -+ bouwloods -+ bouwloodsen -+ bouwmaterialenhandel -+ bouwonderneming -+ bouwondernemingen -+ bouwpakketten -+ bouwpremies -+ bouwprijs -+ bouwprijzen -+ bouwpromotor -+ bouwpromotoren -+ bouwpromotors -+ bouwputten -+ bouwrecht -+ bouwsector -+ bouwsectoren -+ bouwsectors -+ bouwseltje -+ bouwsommen -+ bouwsteiger -+ bouwsteigers -+ bouwstops -+ bouwsubsidie -+ bouwsubsidies -+ bouwtechnisch -+ bouwtechnische -+ bouwverlof -+ bouwvoorschrift -+ bouwvoorschriften -+ bouwwerf -+ bouwwerven -+ bouwwijze -+ bouwwijzen -+ bouwwoede -+ uitkomend -+ bovenaanzichten -+ bovenbaas -+ bovenbazen -+ bovenbeenspier -+ bovenbeenspieren -+ bovenbewuste -+ bovenbuik -+ bovenbuurman -+ bovenbuurmannen -+ bovenbuurvrouw -+ bovenbuurvrouwen -+ bovendeks -+ bovendekse -+ bovendelen -+ bovendrempels -+ bovenetage -+ bovenetages -+ bovengalerij -+ bovengalerijen -+ bovengebitten -+ bovengemeentelijk -+ bovengemeentelijke -+ bovengemiddeld -+ bovengemiddelde -+ bovengeschetst -+ bovengeschetste -+ bovengistend -+ bovengistende -+ bovenkasten -+ bovenklederen -+ bovenkleding -+ bovenkruiers -+ bovenladers -+ bovenlangs -+ bovenleidingen -+ bovenlichamen -+ bovenlokaal -+ bovenlokale -+ bovenminimaal -+ bovenminimale -+ bovenmodaal -+ bovenmodale -+ bovennationaal -+ bovennationale -+ bovenomschreven -+ bovenpartijdig -+ bovenpartijdige -+ bovenpersoonlijk -+ bovenpersoonlijke -+ bovenranden -+ bovenschool -+ bovenstatelijk -+ bovenstatelijke -+ bovenstemmen -+ bovenstromen -+ bovenstroom -+ bovenstroomse -+ boventallige -+ boventitel -+ boventiteling -+ boventitels -+ bovenwereld -+ bovenwerk -+ bovenwettelijk -+ bovien -+ boviene -+ bowl-out -+ bowl-outs -+ bowlers -+ bowlingbal -+ bowlingballen -+ bowlingbanen -+ bowlings -+ boxermotor -+ boxermotoren -+ boxermotors -+ boxershort -+ boxershorts -+ boyband -+ boybands -+ boycotactie -+ boycotacties -+ boycotbeleid -+ boycotmaatregel -+ boycotmaatregelen -+ boycots -+ boycotwet -+ bozige -+ bpm -+ bps -+ braadjus -+ braadluchten -+ braadsledes -+ braafjes -+ braakbal -+ braakballen -+ braakgas -+ braakgassen -+ braamde af -+ braamsluiper -+ braamsluipers -+ brabo -+ brabo's -+ brachiale -+ bracht heruit -+ brainboxen -+ brainwash -+ brainwashen -+ brainwashings -+ brainwasht -+ brainwashte -+ brainwaves -+ brallerig -+ brallerige -+ brancardje -+ brancheverenigingen -+ brandgans -+ brandganzen -+ brandgat -+ brandgaten -+ brandgesticht -+ brandgevel -+ brandgevels -+ brandkluizen -+ brandmelding -+ brandmeldingen -+ brandmuren -+ brandname -+ brandnames -+ brandplek -+ brandplekken -+ brandraam -+ brandramen -+ brandstichten -+ brandstofaccijns -+ brandstofaccijnzen -+ brandstofcel -+ brandstofcellen -+ brandstofelementen -+ brandstofheffing -+ brandstofheffingen -+ brandstofslang -+ brandstoftoevoer -+ brandstofvoorziening -+ brandtoren -+ brandtorens -+ brandtrappen -+ brandveilige -+ brandveiligheidseis -+ brandveiligheidseisen -+ brandweerauto's -+ brandweercommandanten -+ brandweerpersoneel -+ brandweerrode -+ brandweerrood -+ brandweervrouw -+ brandweervrouwen -+ brandweerwagen -+ brandweerwagens -+ brandweg -+ brandwegen -+ brandwondencentra -+ brandwondencentrum -+ brandwondenziekenhuis -+ brandwondenziekenhuizen -+ brandzwam -+ brandzwammen -+ branieschoppers -+ branieschoppertje -+ brasa -+ brasa's -+ brassband -+ brassbands -+ brasser -+ brasseries -+ brassers -+ brassières -+ brave hendrik -+ brave hendriken -+ braverik -+ braveriken -+ break-evenpoints -+ breakdancen -+ breakdancet -+ breakdancete -+ breakdansen -+ breakdanste -+ breakdowns -+ breakpoints -+ breaks -+ breedbandig -+ breedbandige -+ breedbeeld-tv -+ breedbeeld-tv's -+ breedstralers -+ breedteniveau -+ breedtepass -+ breedtepasses -+ breedtesport -+ breekwerf -+ breekwerven -+ breezer -+ breezers -+ breinbrekers -+ breisel -+ breisels -+ breuklijnen -+ breukpunt -+ breukpunten -+ breukstrepen -+ breukvlakken -+ breukzone -+ breukzones -+ bric-à-brac -+ bricoleerde -+ bricoleren -+ bridgeclubje -+ bridgeclubs -+ bridger -+ bridgetafel -+ bridgetafels -+ bridgete -+ bridgeteam -+ bridgetitel -+ briefbommen -+ brieffragment -+ briefhoofding -+ briefhoofdingen -+ briefings -+ briefkaartactie -+ briefkaartenactie -+ briefkaartformaat -+ briefopeners -+ briefromans -+ brieft -+ briefwisselingen -+ briet -+ brievenactie -+ brievenbusfirma's -+ brievenbusmaatschappij -+ brievenhoofden -+ brievenschrijver -+ brievenschrijvers -+ brievenwegers -+ brigadegeneraals -+ brigadier-generaal -+ brigadiers-generaal -+ brildragend -+ brildragende -+ brildrager -+ brildragers -+ brilduiker -+ brilduikers -+ brillenglaasje -+ brillenjood -+ brillenkokers -+ brilscore -+ brique -+ brits -+ brocante -+ brocantes -+ brocanteur -+ brocanteurs -+ broddellappen -+ broederbanden -+ broederland -+ broederlanden -+ broederoorlog -+ broederoorlogen -+ broedervolk -+ broedervolken -+ broedervolkeren -+ broedkolonies -+ broedvogels -+ broedzorg -+ broeibedden -+ broeikasgas -+ broeikasgassen -+ broeikasprobleem -+ broekenmannen -+ broekenmannetje -+ broekhoest -+ broekjurk -+ broekjurken -+ broekklem -+ broekklemmen -+ broekkousen -+ broekpakken -+ broekriemen -+ broekrokken -+ broekventje -+ broekventjes -+ broge -+ brogues -+ brokers -+ brokkenpiloten -+ brol -+ bromelia's -+ bromeliaatje -+ bromfietshelm -+ bromfietshelmen -+ bromiden -+ brommertje -+ bromsnor -+ bromsnorren -+ bromstemmen -+ bronbelastingen -+ bronbemalingen -+ bronchiale -+ broncode-editor -+ broncode-editors -+ broncodes -+ bronheffing -+ bronnenpublicatie -+ bronnenstudies -+ bronsgieter -+ bronsgieters -+ bronsgroene -+ brontaal -+ brontalen -+ brontosaurussen -+ bronverwijzing -+ bronverwijzingen -+ brooche -+ brooches -+ broodbezorgers -+ broodcrouton -+ broodcroutons -+ brooddeeg -+ brooddoos -+ broodfietser -+ broodfietsers -+ broodheren -+ broodjeaapverhaal -+ broodjeaapverhalen -+ broodjeswinkels -+ broodjeszaken -+ broodmaaltijden -+ broodmachine -+ broodmachines -+ broodmix -+ broodmixen -+ broodnuchter -+ broodnuchtere -+ broodoorlogen -+ broodprijs -+ broodprijzen -+ broodsoort -+ broodsoorten -+ broodtrommeltje -+ broodvorm -+ broodwinkel -+ broodwinkels -+ broomdrankje -+ broomdrankjes -+ broomhoudend -+ broomhoudende -+ broomverbinding -+ broomverbindingen -+ broomzuur -+ brossers -+ broste -+ brouwerijconcern -+ brouwerijgroep -+ brouwerijindustrie -+ brouwproces -+ brownbeweging -+ browse -+ browsen -+ browsers -+ browset -+ browsete -+ brugdagen -+ brugfuncties -+ bruggenbouw -+ bruggenbouwers -+ bruggenhoofden -+ bruggenwachters -+ bruggepensioneerde -+ bruggepensioneerden -+ brugjaar -+ brugjaren -+ brugklassers -+ brugklassertje -+ brugkraan -+ brugkranen -+ brugpensioen -+ brugpensioenleeftijd -+ brugperiode -+ bruidsjurken -+ bruidsnachten -+ bruidssluiers -+ bruidssuikers -+ bruidsvluchten -+ bruikleengever -+ bruikleengevers -+ bruiklenen -+ bruikleningen -+ bruinbakken -+ bruinbroden -+ bruinbrood -+ bruinebonensoep -+ bruingebakken -+ bruingoed -+ bruingrijs -+ bruingrijze -+ bruingroen -+ bruingroene -+ bruinhart -+ bruinhemd -+ bruinhemden -+ bruinige -+ bruinkoolcentrale -+ bruinkoolcentrales -+ bruinkoolgroeve -+ bruinkoolgroeven -+ bruinkoolgroeves -+ bruinkoolindustrie -+ bruinkoolmijn -+ bruinkoolmijnen -+ bruinkoolwinning -+ bruinrode -+ bruinrood -+ bruintje -+ bruintjes -+ brunches -+ bruncht -+ brunchte -+ brunettetje -+ bruschetta -+ bruschetta's -+ brushes -+ brushleer -+ brutering -+ bruteringsoperatie -+ bruto-inkomen -+ bruto-inkomens -+ bruto-inkomsten -+ bruto-omzet -+ brutolonen -+ brutoloonstijging -+ brutominimumloon -+ btw -+ btw-heffing -+ btw-tarief -+ btw-tarieven -+ btw-verhoging -+ btw-verlaging -+ bubbelbaden -+ bubbelen -+ buddyseats -+ budgetcontrole -+ budgetcontroles -+ budgetonderzoek -+ budgetsysteem -+ budgettekort -+ bufen -+ bufferde -+ bufferwerkingen -+ buggy's -+ buggy'tje -+ buienlijn -+ buigspanning -+ buikdansen -+ buikdanseressen -+ buikjes -+ buikklacht -+ buikklachten -+ buiklandingen -+ buikoperatie -+ buikoperaties -+ buikorgels -+ buikspieroefening -+ buikspreekpop -+ buikte uit -+ buikvliezen -+ buikwanden -+ buikwind -+ buikwinden -+ buildings -+ buisklok -+ buisklokken -+ buisvak -+ buisvakken -+ buitenactiviteit -+ buitenactiviteiten -+ buitenbad -+ buitenbaden -+ buitenbeurshandel -+ buitenblad -+ buitenbochten -+ buitenboel -+ buitenbus -+ buitenbussen -+ buitendiameter -+ buitendijk -+ buitendijken -+ buitendruk -+ buitenfunctiestelling -+ buitengestaan -+ buitengevechtstelling -+ buitengewest -+ buitengewonelastenregeling -+ buitengewonelastenregelingen -+ buitengrens -+ buitengrenzen -+ buitengrond -+ buitenhuizen -+ buitenhuwelijks -+ buitenhuwelijkse -+ buitenkamer -+ buitenkamers -+ buitenlampen -+ buitenlanderangst -+ buitenlandexpert -+ buitenlandexperts -+ buitenlandpolitiek -+ buitenlandspecialisten -+ buitenlandwoordvoerder -+ buitenleden -+ buitenlicht -+ buitenlichten -+ buitenlid -+ buitenlijn -+ buitenlijnen -+ buitenliterair -+ buitenliteraire -+ buitenmaat -+ buitenmantel -+ buitenmeniscus -+ buitenmodellen -+ buitenmuseum -+ buitenmuzikaal -+ buitenmuzikale -+ buitennatuurlijke -+ buitenpodia -+ buitenpodium -+ buitenproportioneel -+ buitenproportionele -+ buitenraam -+ buitenramen -+ buitenrand -+ buitenranden -+ buitenring -+ buitenseizoen -+ buitenspelposities -+ buitenspelregel -+ buitenspiegels -+ buitenspiegeltje -+ buitensporten -+ buitenstaan -+ buitentemperaturen -+ buitenterrein -+ buitentijdse -+ buitentrap -+ buitenuniversitair -+ buitenuniversitaire -+ buitenvelder -+ buitenvelders -+ buitenvrouw -+ buitenvrouwen -+ buitenweg -+ buitenwegen -+ buitenwerkingstelling -+ buitenwerkse -+ buitenwettelijk -+ buitenwettelijke -+ buitenwipper -+ buitenwippers -+ buitenzintuiglijk -+ buitenzintuiglijke -+ buizenconstructie -+ buizenconstructies -+ buizennetten -+ buizenstelsel -+ buizer -+ buizers -+ bulderlach -+ bulderstemmen -+ buldogs -+ bulgur -+ bulkboek -+ bulkboeken -+ bulkcarrier -+ bulkcarriers -+ bulkchemicaliën -+ bulkchemie -+ bulkproduct -+ bulkproducten -+ bulktransport -+ bulkvaart -+ bulldozerde -+ bullenbijter -+ bullenbijters -+ bullenpees -+ bullenpezen -+ bultrug -+ bultruggen -+ bumperklever -+ bumperklevers -+ bumpersticker -+ bumperstickers -+ bundelingen -+ bunkerachtig -+ bunkerachtige -+ bunkermentaliteit -+ bunkerstation -+ bunkerstations -+ bunny's -+ bunraku -+ bunsenbrander -+ bunsenbranders -+ bureau-inhoud -+ bureauagenda -+ bureauagenda's -+ bureauagendaatje -+ bureaublad -+ bureaubladen -+ bureauchef -+ bureauchefs -+ bureaucratieën -+ bureaucratiseerde -+ bureaueigenaar -+ bureaueigenaars -+ bureaueigenaren -+ bureaujob -+ bureaujobs -+ bureaula's -+ bureaulaatje -+ bureaulandschappen -+ bureaupolitiek -+ bureaupolitieke -+ bureauredacteuren -+ bureauredacteurs -+ bureaux-ministres -+ burenoverlast -+ burenruzie -+ burenruzies -+ burgemeestersbenoeming -+ burgemeestersbenoemingen -+ burgemeesterskamer -+ burgemeesterssjerp -+ burgemeesterssjerpen -+ burgemeesterswoning -+ burgerdienstplicht -+ burgerdocenten -+ burgerdom -+ burgeres -+ burgeressen -+ burgerhuizen -+ burgerkleren -+ burgerleven -+ burgerlijk-liberaal -+ burgerlijk-liberale -+ burgermannen -+ burgermannetjes -+ burgermansbestaan -+ burgermansfatsoen -+ burgermansmoraal -+ burgerpak -+ burgerpakken -+ burgerpersoneel -+ burgerpolitie -+ burgerrechtenbeweging -+ burgerrechtenwetgeving -+ burgerregering -+ burgerregeringen -+ burgerslachtoffer -+ burgertrut -+ burgertrutten -+ burgerzalen -+ burgul -+ burlde -+ burlen -+ burn-out -+ burn-outs -+ burn-outsyndroom -+ burrito -+ burrito's -+ bursa-equivalent -+ busbanen -+ busbo -+ buschauffeurs -+ bushbush -+ bushmeat -+ businessclass -+ businessplan -+ businessplannen -+ businessschool -+ businessschools -+ businessunit -+ businessunits -+ buskaartjes -+ buslading -+ busladingen -+ buslijnen -+ busondernemingen -+ busreizen -+ busreiziger -+ busreizigers -+ busrit -+ busritten -+ bustaxi's -+ busterminal -+ busterminals -+ bustiers -+ bustochten -+ busverbindingen -+ busvervoer -+ buten -+ butskop -+ butskoppen -+ butste -+ butterflys -+ butterscotch -+ buuf -+ buureiland -+ buurhuis -+ buurmannen -+ buurstaat -+ buurstaten -+ buurtactiviteit -+ buurtactiviteiten -+ buurtagent -+ buurtagenten -+ buurtbezoek -+ buurtbezoeken -+ buurtbussen -+ buurtcafeetje -+ buurtcafés -+ buurtcentra -+ buurtcomité -+ buurtcomités -+ buurtgebonden -+ buurtkroeg -+ buurtkroegen -+ buurtpreventie -+ buurtscholen -+ buurtsuper -+ buurtsupers -+ buurttehuis -+ buurtwacht -+ buurtwachten -+ buurtwachter -+ buurtwachters -+ buurtweg -+ buurtwegen -+ buurtwinkels -+ buurtwinkeltje -+ buut -+ buutplaats -+ buutreedner -+ buutreedners -+ buutte -+ buxussen -+ buy-out -+ buy-outs -+ bv -+ bv's -+ bv. -+ bvba -+ bvba's -+ byebye -+ byes -+ bypasses -+ bypassoperatie -+ bypassoperaties -+ byzantijn -+ byzantijnen -+ bèta's -+ bètablokker -+ bètablokkers -+ bètadeeltje -+ bètadeeltjes -+ bètastralen -+ bètavak -+ bètavakken -+ bètaverval -+ bètawetenschap -+ bètawetenschappen -+ bühnen -+ bühnes -+ c's -+ c'tje -+ c-sleutel -+ c-sleutels -+ c.q. -+ ca. -+ cabaretduo -+ cabaretduo's -+ cabaretgezelschappen -+ cabaretgroep -+ cabaretgroepen -+ cabaretiertje -+ cabaretières -+ cabaretlied -+ cabarettekst -+ cabaretteksten -+ cabaretvoorstelling -+ cabaretvoorstellingen -+ cabernet -+ cabernets -+ cabrioletkap -+ cabrioletkappen -+ cabriolets -+ cacao-overeenkomst -+ cacaoboer -+ cacaoboeren -+ cacaobomen -+ cacaoboom -+ cache -+ cache-potje -+ caches -+ cachotje -+ caddies -+ cadeau-idee -+ cadeau-idees -+ cadeau-ideetje -+ cadeau-ideeën -+ cadeauabonnement -+ cadeauartikel -+ cadeauartikelen -+ cadeauboek -+ cadeauboeken -+ cadeaubonnen -+ cadeaubons -+ cadeauverpakking -+ cadeauwinkel -+ cadeauwinkels -+ cadensen -+ cadmiumgeel -+ cadmiumgele -+ cadmiumrode -+ cadmiumrood -+ caesars -+ cafetariahouders -+ café noir -+ café-brasserie -+ café-eigenaar -+ café-eigenaars -+ café-eigenaren -+ café-uitbater -+ café-uitbaters -+ cafébezoek -+ cafébezoeken -+ cafébezoeker -+ cafébezoekers -+ cafés noirs -+ cafés-brasseries -+ caféterrassen -+ cai -+ cajun -+ cajunkeuken -+ cajunkruiden -+ cajunmuziek -+ cakeblikken -+ cakeje -+ cakevorm -+ cakewalks -+ calamaris -+ calamarissen -+ calamiteitenhospitaal -+ calamiteitenverlof -+ calciumcarbonaat -+ calciumfosfaat -+ calciumgehalte -+ calciumhydroxide -+ calculators -+ calimerocomplex -+ callboy -+ callboys -+ callcenter -+ callcenters -+ callopties -+ calvarietocht -+ calypso's -+ calèches -+ camaieu -+ camarilla's -+ cambio -+ cambio's -+ cambiohouder -+ cambiohouders -+ cambrium -+ cameetje -+ camelia's -+ cameliaatje -+ camembertje -+ camemberts -+ camera-ervaring -+ camera-instelling -+ camera-instellingen -+ camerabewaking -+ cameralui -+ cameravoering -+ cameravrouw -+ cameravrouwen -+ camerawagens -+ camionetten -+ camionettes -+ camionetteverhuur -+ camouflagekleuren -+ camouflagenet -+ camouflagenetten -+ camouflagepak -+ camouflagepakken -+ camouflagestift -+ camouflagestiften -+ camouflagetechniek -+ camp -+ campagnecoördinator -+ campagneleiding -+ campagneorganisatie -+ campagnespot -+ campagnestrategie -+ campagnetoespraak -+ campagnetoespraken -+ campagnevoerder -+ campanula's -+ campingbeheerders -+ campinghouder -+ campinghouders -+ campingsmoking -+ campingsmokings -+ campingterrein -+ campingterreinen -+ campingvlucht -+ campingvluchten -+ campingwinkel -+ campingwinkels -+ campinkje -+ campionissimi -+ campionissimo's -+ campussen -+ canadagans -+ canadaganzen -+ canadapopulier -+ canadapopulieren -+ canadees -+ canadezen -+ canapépolitiek -+ cancans -+ cancel -+ cancelde -+ cancelen -+ cancelt -+ candlelight -+ cannabisgebruik -+ cannabisgebruiker -+ cannabisgebruikers -+ cannabisproduct -+ cannabisproducten -+ cannabisteelt -+ cannelloni -+ canonisering -+ cantabile's -+ cantabiles -+ cantatekoor -+ cantatekoren -+ canto's -+ cantorijen -+ canvaste -+ canzonetta's -+ cao -+ cao's -+ cao-akkoord -+ cao-bepaling -+ cao-bespreking -+ cao-eis -+ cao-onderhandelingen -+ cao-voorstel -+ cap -+ capabeler -+ capabelst -+ capaciteitsmanagement -+ capaciteitsprobleem -+ capaciteitstekort -+ capaciteitsuitbreiding -+ capaciteitsuitbreidingen -+ capaciteitsvergroting -+ capaciteitsvermindering -+ capeje -+ capillairen -+ capriccio's -+ caps -+ captains -+ capteerde -+ capteren -+ cara -+ caracal -+ caracals -+ carapatiënt -+ carapatiënten -+ caravanstalling -+ caravanstallingen -+ caravanterreinen -+ carbidschieten -+ carbonnetje -+ carboon -+ carbuur -+ carcinogene -+ carcinogenen -+ carcinomen -+ cardanische -+ cardiogeen -+ cardiogene -+ cardiografen -+ cardiologen -+ cardioscopie -+ cardiovasculaire -+ cargo's -+ cargorijst -+ carjacking -+ carjackings -+ carnavalsfeest -+ carnavalskrakers -+ carnavalsliederen -+ carnavalsoptochten -+ carnavalsvereniging -+ carnavalsverenigingen -+ carnavalsvierder -+ carnavalsvierders -+ carolina-eend -+ carolina-eenden -+ carolusgulden -+ carolusguldens -+ carotenoïden -+ carpaccio -+ carpaletunnelsyndroom -+ carpoolde -+ carpoolers -+ carpools -+ carpoolstroken -+ carpoolt -+ carpoolwisselstrook -+ carports -+ carrièrediplomaat -+ carrièregericht -+ carrièregerichte -+ carrièrejagers -+ carrièremakers -+ carrièreoverweging -+ carrièreoverwegingen -+ carrièrevrouw -+ carrièrevrouwen -+ carrièristen -+ carrosseriebouwers -+ cartesiaans -+ cartesiaanse -+ cartesianen -+ cartoonachtig -+ cartoonachtige -+ cartooneske -+ carwash -+ carwashes -+ casanova -+ casanova's -+ cascadeschakeling -+ cascadeschakelingen -+ cascoverzekeringen -+ cases -+ casestudy's -+ cash-and-carry's -+ cash-and-carryzaak -+ cash-and-carryzaken -+ casino-economie -+ casinobroden -+ casinobrood -+ casinohotel -+ casinohotels -+ casinokapitalisme -+ casinopersoneel -+ casinowezen -+ cassandravoorspelling -+ cassandravoorspellingen -+ cassata-ijs -+ cassavebrood -+ cassavechips -+ cassettedecks -+ cassettefilms -+ cassetten -+ cassettesysteem -+ cassettewisselaar -+ cassettewisselaars -+ cassoletje -+ cassolette -+ cassolettes -+ cassolettetje -+ cassoulet -+ cassouletje -+ cassoulets -+ castella -+ castellum -+ castingbureau -+ castingbureaus -+ castraten -+ casts -+ casu quo -+ casusposities -+ catalogeerde -+ catalogisering -+ catalogusprijs -+ cataloguswaarde -+ catamnese -+ catastrofistische -+ catechisaties -+ catechismusles -+ catechismuslessen -+ categoraal -+ categorieke -+ categoriseerde -+ cateringbedrijf -+ cateringservice -+ catwalk -+ catwalks -+ cauteriseerde -+ cauteriseren -+ cava -+ cava's -+ caviaatje -+ cayennepepertje -+ cd'tje -+ cd-box -+ cd-boxen -+ cd-brander -+ cd-branders -+ cd-hoes -+ cd-hoesje -+ cd-hoezen -+ cd-opname -+ cd-opnamen -+ cd-opnames -+ cd-release -+ cd-rewriter -+ cd-rewriters -+ cd-rom -+ cd-rommetje -+ cd-roms -+ cd-romspeler -+ cd-romspelers -+ cd-schijf -+ cd-single -+ cd-singles -+ cd-speler -+ cd-spelers -+ cd-writer -+ cd-writers -+ cecogrammen -+ cedeerde -+ celbiologie -+ celculturen -+ celcultures -+ celcultuur -+ celdeur -+ celdeuren -+ celdodend -+ celdodende -+ celdood -+ celebraties -+ celebratiën -+ celesta's -+ celestijnen -+ celgenoten -+ celibaatsverplichting -+ celibatairen -+ celibatairs -+ cellenblok -+ cellenblokken -+ cellenbouw -+ cellencomplex -+ cellenhuis -+ cellenhuizen -+ cellijn -+ cellijnen -+ celloconcert -+ celloconcerten -+ cellofaanpapier -+ cellosolo -+ cellosonate -+ cellosonaten -+ cellosonates -+ cellosuite -+ cellosuites -+ cellulairen -+ cellulairs -+ celmembraan -+ celmembranen -+ celorganel -+ celorganellen -+ celplasma -+ celplasma's -+ celstoffen -+ celstofwisseling -+ celtherapieën -+ celwanden -+ cembalisten -+ cembalo's -+ cementindustrie -+ cementlijm -+ cementmolens -+ cementmortels -+ cementvloer -+ cenozoïcum -+ centenbak -+ centenbakken -+ centenkwesties -+ centercourt -+ centercourts -+ centerfolds -+ centimetergolf -+ centimetergolven -+ centralebankpresident -+ centralebankpresidenten -+ centraleverwarmingsinstallatie -+ centraleverwarmingsinstallaties -+ centralisten -+ centrifugaalkoppeling -+ centrifugeonderdeel -+ centrifugeonderdelen -+ centristische -+ centromeren -+ centrumdemocraat -+ centrumdemocraten -+ centrumfuncties -+ centrumgemeente -+ centrumgemeenten -+ centrumlinks -+ centrumlinkse -+ centrumpartijen -+ centrumrechts -+ centrumrechtse -+ centrumspitsen -+ centsprent -+ centsprenten -+ centurie -+ centurio -+ centurio's -+ centuriones -+ centurions -+ centuriën -+ ceramisten -+ cerberus -+ cerberussen -+ cerises -+ certificaathouder -+ certificaathouders -+ certificering -+ cervela -+ cervela's -+ cervices -+ cervixen -+ ces -+ cesartherapie -+ cessen -+ ceteris paribus -+ ceylonthee -+ cfk -+ cfk's -+ chablistje -+ chachacha -+ chachacha's -+ chaconnes -+ chadors -+ chai -+ chaises longues -+ chalcedonen -+ chaletje -+ challe -+ challes -+ chambreerde -+ chambretje -+ chambrette -+ chambrettes -+ chambrettetje -+ champagnecoupeje -+ champagnecoupes -+ champagnefles -+ champagneflessen -+ champagneflûte -+ champagneflûteje -+ champagneflûtes -+ champagnekoelers -+ champagneontbijt -+ champagneontbijten -+ champagnestreek -+ champenoise -+ champenoises -+ champignonteelt -+ chance -+ changeerde -+ changementen -+ chanoekafeest -+ chanoekalamp -+ chansonniers -+ chantabele -+ chantagemiddel -+ chanteurs -+ chanteuses -+ chaostheorie -+ chaoten -+ chaotisering -+ chape -+ chapelure -+ chaperonnes -+ chaperons -+ chapes -+ chappe -+ chardonnay -+ chardonnays -+ chargede -+ chargen -+ charger -+ chargers -+ charget -+ charisma's -+ charivari's -+ charlestons -+ charlotte-russe -+ charmeoffensief -+ charmezanger -+ charmezangers -+ charta's -+ charterbedrijf -+ charterreis -+ charterreizen -+ charterschepen -+ charterschip -+ chartervliegtuigen -+ chartervluchten -+ chassidim -+ chassidische -+ chassied -+ chassieden -+ chat -+ chatbox -+ chatboxen -+ chateau -+ chateaubriands -+ chateaus -+ chatroom -+ chatrooms -+ chats -+ chatte -+ chatten -+ chatter -+ chatters -+ chauffage -+ chauffages -+ chazan -+ chazanoet -+ chazonim -+ checkbox -+ checkboxen -+ checkpoints -+ cheerleader -+ cheerleaders -+ cheeseburgers -+ chef d'équipe -+ chef-arts -+ chef-artsen -+ chef-d'oeuvre -+ chef-dirigent -+ chef-dirigenten -+ chef-redacteur -+ chef-redacteurs -+ chef-redactie -+ chef-sport -+ chef-staf -+ chefs d'équipe -+ chefs-d'oeuvre -+ chefs-redactie -+ chefs-sport -+ chefs-staf -+ cheider -+ cheiders -+ chelatietherapie -+ chemicaliëngebruik -+ chemicaliëntanker -+ chemicaliëntankers -+ chemie-industrie -+ chemieaandeel -+ chemiebranche -+ chemiereus -+ chemiereuzen -+ chemiesector -+ chemisier -+ chemisiers -+ chemisme -+ chemokar -+ chemokarren -+ chequeboekdiplomatie -+ chequeje -+ cherrytomaat -+ cherrytomaten -+ chesterfield -+ chesterfields -+ chicks -+ chihuahua -+ chihuahua's -+ chikwadraattoets -+ chikwadraattoetsen -+ chilipeper -+ chilipepers -+ chilipoeder -+ chilisaus -+ chimaera's -+ chimerisch -+ chimerische -+ chimp -+ chimps -+ chinaklei -+ chinchilla's -+ chinoiseries -+ chinoiserieën -+ chinooks -+ chipcard -+ chipcards -+ chipfabrikant -+ chipindustrie -+ chipkaart -+ chipkaarten -+ chipkaartje -+ chipknip -+ chipknippen -+ chipknips -+ chipmarkt -+ chipolata -+ chipolata's -+ chipolata-ijs -+ chipolatapuddingen -+ chipproducent -+ chipsfabriek -+ chipsfabrikant -+ chipsindustrie -+ chipsmarkt -+ chiptechnologie -+ chirografen -+ chiropodisten -+ chirurgieën -+ chirurgijns -+ chlamydia -+ chlooracne -+ chloorde -+ chloorecht -+ chloorfluorkoolstof -+ chloorfluorkoolstoffen -+ chloorfluorkoolstofverbinding -+ chloorfluorkoolstofverbindingen -+ chloorfluorkoolwaterstof -+ chloorfluorkoolwaterstoffen -+ chloorgas -+ chloorhoudend -+ chloorhoudende -+ chloortrein -+ chloortreinen -+ chloorvrij -+ chloorvrije -+ chloorwaterstof -+ chloreerde -+ chlorides -+ chlorieten -+ chloroplasten -+ chochme -+ chochmes -+ choco-ijs -+ chocolade-ijs -+ chocoladebruin -+ chocoladebruine -+ chocoladehagelslag -+ chocoladepuddingen -+ chocoladesaus -+ chocolaterieën -+ chocolatiers -+ chocopasta's -+ choepa -+ chokes -+ cholera-epidemies -+ cholerapatiënt -+ cholerapatiënten -+ cholesterolarm -+ cholesterolarme -+ cholesterolverlagend -+ cholesterolverlagende -+ cholesterolverlager -+ cholesterolverlagers -+ chook -+ chookt -+ chookte -+ choppers -+ choreografe -+ choreografeerde -+ choreografen -+ choreografes -+ choreografieopdracht -+ choreografieën -+ chorussen -+ choucroute -+ chowchows -+ christelijk-fundamentalistisch -+ christelijk-fundamentalistische -+ christelijk-gereformeerd -+ christelijk-gereformeerde -+ christelijk-historisch -+ christelijk-historische -+ christelijk-islamitisch -+ christelijk-islamitische -+ christelijk-nationaal -+ christelijk-nationale -+ christelijk-sociaal -+ christelijk-sociale -+ christen-sociaal -+ christen-sociale -+ christendemocraat -+ christendemocraten -+ christendemocratie -+ christendemocratisch -+ christendemocratische -+ christene zielen -+ christenfundamentalisme -+ christenfundamentalist -+ christenfundamentalisten -+ christengemeente -+ christengemeenten -+ christengemeentes -+ christenhond -+ christenhonden -+ christensocialisme -+ christensocialist -+ christensocialisten -+ christian-scientist -+ christian-scientists -+ christologische -+ christus -+ christusachtig -+ christusachtige -+ christusdoorn -+ christusdoorns -+ christusdoren -+ christusdorens -+ christussen -+ chroma's -+ chromo's -+ chromosfeer -+ chromosomale -+ chromosoomonderzoek -+ chromosoompje -+ chromotypie -+ chroniqueurs -+ chrono's -+ chronografen -+ chroomzuur -+ chutneys -+ ciabatta -+ ciabatta's -+ cicade -+ cicadeachtig -+ cicadeachtige -+ cicaden -+ cicades -+ cicero's -+ ciceroniaans -+ ciceroniaanse -+ cichlide -+ cichliden -+ cigarillo's -+ cijfercode -+ cijfercodes -+ cijferfetisjisme -+ cijfersloten -+ cijferwerk -+ cilinderblokken -+ cilinderglas -+ cilinderglazen -+ cilindersloten -+ cilindervlak -+ cilindervlakken -+ cilinderwand -+ cilinderwanden -+ cineastische -+ cineclubs -+ cinema's -+ cinemaprimeur -+ cinemascopeformaat -+ cinematheken -+ cineraria's -+ circonflexe -+ circuitje -+ circulatiestoornissen -+ circulatiesysteem -+ circumcisies -+ circusachtig -+ circusachtige -+ circusattractie -+ circusclown -+ circusdirecteur -+ circustent -+ circustenten -+ circustheater -+ circustheaters -+ circusvoorstelling -+ circusvoorstellingen -+ cirkelbaan -+ cirkelbeweging -+ cirkelboor -+ cirkelboren -+ cirkeldiagrammen -+ cirkelmaaiers -+ cirkelredeneringen -+ cirkelrond -+ cirkelronde -+ cirkelvorm -+ cirkelvormen -+ cirri -+ ciseleurs -+ cisterciënzer1 -+ cisterciënzer2 -+ cisternen -+ citatenboek -+ citatenboeken -+ citatie-index -+ citatie-indexen -+ citatie-indices -+ citaties -+ citeerdrift -+ citerne -+ citernes -+ cito -+ citohulp -+ citroengeranium -+ citroengeraniums -+ citroengras -+ citroenmelisse -+ citroenolie -+ citroensaus -+ citroensmaak -+ citroenthee -+ citruspersen -+ city's -+ citybags -+ citybike -+ citybikes -+ cityhoppers -+ cityvorming -+ cité -+ cités -+ civetten -+ civieltechnisch -+ civieltechnische -+ civilisatieproces -+ civilisaties -+ civilisatietheorie -+ ckv-docent -+ ckv-docenten -+ clafoutis -+ claimemissie -+ clairvoyants -+ clanleden -+ clanleider -+ clanleiders -+ clanlid -+ clanoudste -+ clanoudsten -+ claqueurs -+ clarisse -+ clark -+ clarks -+ classen -+ classeur -+ classeurs -+ classics -+ classificatiebureaus -+ classificatiesysteem -+ classificeerder -+ classificeerders -+ clausen -+ claustrofobische -+ claviaturen -+ claviculae -+ claxonnades -+ clementines -+ cliché-uitdrukking -+ cliché-uitdrukkingen -+ clichébeeld -+ clichébeelden -+ clichématige -+ clichématigheid -+ clickfonds -+ clicks -+ cliffhanger -+ cliffhangers -+ clignoteurs -+ clinic -+ clinici -+ clinics -+ clipart -+ clippers -+ clique -+ cliqueje -+ cliques -+ clitores -+ clitorissen -+ clivia's -+ cliviaatje -+ cliëntelistische -+ cloaca's -+ cloche -+ cloches -+ close harmony -+ close reading -+ close-upopname -+ close-upopnamen -+ close-upopnames -+ closeharmonykoor -+ closeharmonykoren -+ closetborstels -+ closetrolhouders -+ clous -+ clownerieën -+ clownsduo -+ clownspak -+ clubarts -+ clubbestuur -+ clubcard -+ clubcards -+ clubembleem -+ clubkaart -+ clubkaarten -+ clubkas -+ clubkleur -+ clubleider -+ clubleiding -+ clublied -+ clubliederen -+ clubsjaal -+ clubsjaals -+ clubsjaaltje -+ clubvolleybal -+ clubwedstrijd -+ clubwedstrijden -+ clusterbijeenkomst -+ clusterbijeenkomsten -+ clusterministers -+ clusterprijs -+ co-educatie -+ co-existeerde -+ co-existentie -+ co-existeren -+ co-ouder -+ co-ouders -+ coacht -+ coachte -+ coalitieakkoord -+ coalitiegenoot -+ coalitiegenoten -+ coalitiekabinetten -+ coalitiemeerderheid -+ coalitieoverleg -+ coalitiepartij -+ coalitiepartners -+ coassistenten -+ coassistentschappen -+ coasters -+ coatte -+ coauteur -+ coauteurs -+ coaxkabels -+ coca's -+ cocablad -+ cocabladeren -+ cocaboer -+ cocaboeren -+ cocaproducerend -+ cocaproducerende -+ cocateelt -+ cocaïneaffaire -+ cocaïnehandel -+ cocaïnemaffia -+ cocaïnesmokkel -+ cocaïnevangst -+ coccejaan -+ coccejanen -+ cocci -+ cockerspaniëls -+ cockneys -+ cockpitbemanning -+ cockpitvoicerecorder -+ cockpitvoicerecorders -+ cocktailbar -+ cocktailbars -+ cocktailjaponnen -+ cocktailjurk -+ cocktailjurken -+ cocktailparty's -+ cocktailprikkers -+ cocoon -+ cocoonde -+ cocoonen -+ cocooning -+ cocoont -+ cocottes -+ coda's -+ codecommissie -+ codenamen -+ coderingssysteem -+ codetaal -+ codeurs -+ codirecteuren -+ codirecteurs -+ cofferdammen -+ cofinanciering -+ cognacglas -+ cognacglazen -+ cohabitatie -+ cohabiteerde -+ cohesieland -+ cohesielanden -+ coiffeuseje -+ coiffeusetje -+ coiffures -+ cola light -+ cola-tic -+ cola-tics -+ colaatje -+ colablikje -+ colablikjes -+ colaflessen -+ colbertjassen -+ cold case -+ cold cases -+ cold turkey -+ coldcaseteam -+ coldcaseteams -+ coldturkeymethode -+ colibacterie -+ colibacteriën -+ collageachtig -+ collageachtige -+ collagetechniek -+ collect call -+ collect calls -+ collectezak -+ collectiecatalogi -+ collectiecatalogus -+ collectiecatalogussen -+ collectievelastendruk -+ collectievelastenpeil -+ collectioneerde -+ collectioneurs -+ collectiva -+ collectiviseerde -+ collectiviteiten -+ collector's item -+ collector's items -+ collectoren -+ collectors -+ collega-Kamerleden -+ collega-Kamerlid -+ collega-architect -+ collega-architecten -+ collega-curator -+ collega-hoogleraar -+ collega-hoogleraren -+ collega-onderzoeker -+ collega-onderzoekers -+ collega-onderzoekster -+ collega-wethouder -+ collega-wethouders -+ collegaatje -+ collegebank -+ collegebanken -+ collegekaarten -+ collegezalencomplex -+ colletje -+ colli's -+ collideerde -+ collisies -+ collocaties -+ collusies -+ coloratuursopraan -+ coloriet -+ coloristen -+ coloristische -+ colts -+ columnistenprijs -+ columnpje -+ colère -+ colères -+ coma's -+ comapatiënt -+ comapatiënten -+ combi's -+ combikaart -+ combinatiepil -+ combinatiepillen -+ combinatiesloten -+ combinatiespel -+ combinatievaccin -+ combineerbaar -+ combineerbare -+ combioven -+ combiovens -+ comebacks -+ comedy -+ comedy's -+ comedyserie -+ comedyseries -+ coming men -+ coming-out -+ coming-outs -+ comité-generaal -+ comitéleden -+ comitélid -+ commandantes -+ commanderijen -+ commando-eenheden -+ commando-eenheid -+ commando-overdracht -+ commandoactie -+ commandoacties -+ commandogroepen -+ commandoposten -+ commandostructuren -+ commandostructuur -+ commandotorens -+ commemorabele -+ commentaarloos -+ commentaarloze -+ commentaarschrijver -+ commentaarschrijvers -+ commerce -+ commercialiseerde -+ commercials -+ commerçant -+ commerçanten -+ commissarisfunctie -+ commissarisfuncties -+ commissarisplaats -+ commissarisplaatsen -+ commissariszetel -+ commissariszetels -+ commissiegeld -+ commissiegelden -+ commissiewerk -+ commissionairsbedrijf -+ commissionairshuis -+ commissionairshuizen -+ commodity -+ commodity's -+ commoties -+ communale -+ communautarisering -+ communauteiten -+ communicabele -+ communicatiebedrijf -+ communicatiecentra -+ communicatiefout -+ communicatiefouten -+ communicatiekloof -+ communicatiemedium -+ communiezieltje -+ communistenjacht -+ communistenjager -+ communistenjagers -+ communistenleider -+ community -+ community's -+ compact disc -+ compact discs -+ compactdiscspeler -+ compactdiscspelers -+ comparatisten -+ compartimentering -+ compatibele -+ compensabele -+ compensatiekas -+ compensatiekassen -+ compensatiepunt -+ compensatiepunten -+ compensatoire -+ competentieconflict -+ competentieconflicten -+ competentiekwestie -+ competentiekwesties -+ competentiestrijd -+ competentievraag -+ competentievragen -+ competitie-element -+ competitiedagen -+ competitieduel -+ competitieduels -+ competitieleider -+ competitieleiders -+ competitieprogramma -+ competitiestart -+ competitieve -+ competitieverband -+ competitievervalsing -+ compilatiewerken -+ complementeerde -+ complicen -+ complices -+ complotteerde -+ complotten -+ componistenbond -+ composers -+ composietmateriaal -+ composietmaterialen -+ compositiebal -+ compositieballen -+ compositiedocent -+ compositieles -+ compositielessen -+ compositietechniek -+ compositorische -+ compostbak -+ composteringsfabriek -+ composteurs -+ compostfabriek -+ composttoilet -+ composttoiletten -+ compounddynamo's -+ compressieslagen -+ comprimeerde -+ compromisformule -+ compromisloos -+ compromisloze -+ compromistje -+ comptabelen -+ comptabiliteitswetten -+ compulsieve -+ computeranimatie -+ computeranimaties -+ computerbedrijf -+ computerbeeld -+ computerbeelden -+ computerbeeldscherm -+ computerbestand -+ computerbestanden -+ computerchip -+ computerchips -+ computerdata -+ computerde -+ computerfreak -+ computerfreaks -+ computerinbraak -+ computerinbraken -+ computerindustrie -+ computeriseerde -+ computerkracht -+ computerkraken -+ computerkraker -+ computerkrakers -+ computerkunst -+ computermonitor -+ computermonitoren -+ computermuziek -+ computernetwerken -+ computerondersteund -+ computerondersteunde -+ computeronderwijs -+ computerschermen -+ computerschermpje -+ computersimulatie -+ computersimulaties -+ computerspel -+ computerspellen -+ computertechniek -+ computertijdperk -+ computertje -+ computertomografie -+ computerverslaafde -+ computerverslaafden -+ computervirus -+ computervirussen -+ computerwetenschap -+ computerwetenschappen -+ comédiennes -+ concelebranten -+ concelebraties -+ concelebreerde -+ concentraten -+ concentratiegebied -+ concentratiegebieden -+ concentratiekampsyndromen -+ concentratiescholen -+ concentratieschool -+ concentratiestoornis -+ concentratiestoornissen -+ conceptakkoord -+ conceptbegroting -+ conceptbeleidsplan -+ conceptcontract -+ conceptnotitie -+ conceptovereenkomst -+ conceptregeerakkoord -+ conceptual art -+ conceptualisering -+ conceptualiseringen -+ conceptversie -+ concernfinanciering -+ concernonderdeel -+ concernonderdelen -+ concernstrategie -+ concernwinst -+ concertante -+ concertbezoek -+ concertbezoeker -+ concertbezoekers -+ concertgangers -+ concertgebouwen -+ concerti -+ concertmuziek -+ concerto's -+ concertpianist -+ concertpianisten -+ concertpodia -+ concertpodiums -+ concertprogramma -+ concertprogramma's -+ concertpubliek -+ concertseizoen -+ concertstukken -+ concessiegebied -+ concessiegebieden -+ concessierechten -+ concessionele -+ conciliaire -+ concilieerde -+ concomitante -+ concordeerde -+ concours hippique -+ concoursje -+ concourstje -+ concretisering -+ concretiseringen -+ concubaan -+ concubanen -+ concurrentes -+ concurrentieanalyse -+ concurrentiebedingen -+ concurrentieel -+ concurrentiegevoelig -+ concurrentiegevoelige -+ concurrentiekracht -+ concurrentieposities -+ concurrentievermogen -+ concurrentiële -+ condensaten -+ condensatiestrepen -+ condensvorming -+ conditietest -+ conditietrainer -+ conditietrainers -+ conditioner -+ conditioneringsproces -+ conditioners -+ condoleancebezoeken -+ condoleancebrieven -+ condominiums -+ condoomautomaten -+ condoomcampagne -+ condoomgebruik -+ confectie-industrie -+ confectieatelier -+ confectieateliers -+ confectiebedrijf -+ confectionairs -+ confectioneerde -+ confederale -+ confederatieve -+ confedereerde -+ conferenciers -+ conferentieganger -+ conferentiegangers -+ conferentieoord -+ conferentieoorden -+ conferentietafels -+ conferentiezaaltje -+ confiscabele -+ confiseries -+ confiseurs -+ confituurtaart -+ confituurtaarten -+ conflicteerde -+ conflicthaard -+ conflicthaarden -+ conflictmodellen -+ conflictoplossing -+ conformeerde -+ conformering -+ conformistische -+ confrontatiemodel -+ confrontatiepolitiek -+ confréries -+ confrérieën -+ confuciaanse -+ confucianistische -+ conga's -+ congestieprobleem -+ congestieproblemen -+ conglomeraties -+ congresdeelnemer -+ congresdeelnemers -+ congresgebouwen -+ congresstukken -+ congresthema -+ congresthema's -+ congreszaal -+ congreszalen -+ conjecturen -+ conjugale -+ conjugeerde -+ conjuncte -+ conjunctivae -+ conjunctuurbewegingen -+ conjunctuurcycli -+ conjunctuurdal -+ conjunctuurgevoelige -+ conjunctuurschommeling -+ conjunctuurschommelingen -+ conjunctuurtest -+ conjunctuurverloop -+ conjunctuurvertraging -+ connaisseurs -+ conquistadores -+ conscripties -+ consecrators -+ consecutieve -+ consensusdemocratie -+ consensuseconomie -+ consensusmaatschappij -+ consenteerde -+ consequentheid -+ conservatief-democratisch -+ conservatief-democratische -+ conservatief-liberaal -+ conservatief-liberale -+ conservatief-nationalistisch -+ conservatief-nationalistische -+ conservatoriumopleiding -+ conservatoriumstudent -+ conservatoriumstudenten -+ conservatrices -+ conservenbedrijf -+ conservenindustrie -+ conserveringsmethode -+ conserveringsmethoden -+ conserveringsprobleem -+ conserveringsproblemen -+ consistenties -+ consistentvet -+ consistentvetten -+ consolbaken -+ consolbakens -+ consoletafel -+ consoletafels -+ consolidering -+ #consolsysteem fout volgens Van Dale -+ consolesysteem -+ conspiraties -+ conspireerde -+ constanties -+ constatatie -+ constataties -+ constateerbaar -+ constateerbare -+ constipaties -+ constituanten -+ constitutieve -+ constructen -+ constructie-ijzer -+ constructie-ijzers -+ constructiebankwerker -+ constructiebankwerkers -+ constructiebedrijf -+ constructiefst -+ constructieprobleem -+ constructieproblemen -+ constructiever -+ constructiewerk -+ constructiewerkplaatsen -+ constructivisten -+ constructivistische -+ consulaat-generaal -+ consulaten-generaal -+ consulentschap -+ consulentschappen -+ consultancybureau -+ consultancybureaus -+ consultantsbureau -+ consultatieve -+ consumabele -+ consumentenbonden -+ consumentengids -+ consumentenonderzoek -+ consumentenorganisatie -+ consumentensubsidie -+ consumentensubsidies -+ consumentenwinkels -+ consumentvriendelijk -+ consumentvriendelijke -+ consumptie-ijs -+ consumptiegoederenindustrie -+ consumptiemelk -+ consumptieprijs -+ consumptieprijzen -+ contactadressen -+ contactarm -+ contactarme -+ contactarmoede -+ contactcentrum -+ contactcommissie -+ contactcommissies -+ contacteerde -+ contactgeluiden -+ contactlenzenspecialist -+ contactlenzenspecialisten -+ contactmannen -+ contactmogelijkheden -+ contactmogelijkheid -+ contactpunt -+ containerhaven -+ containerhavens -+ containerlijnvaart -+ containeroverslagbedrijf -+ containerpark -+ containerparken -+ containerterminal -+ containerterminals -+ containerwagens -+ contamineerde -+ contest -+ contestanten -+ contestaties -+ contesteerde -+ contests -+ contigue -+ continentaal-Europees -+ continentaal-Europese -+ continenties -+ contingenties -+ contingentsberoep -+ contingentsperiode -+ contingentsverbruik -+ continuarbeid -+ continurooster -+ continuroosters -+ conto's -+ contourlijn -+ contourlijnen -+ contra-enquête -+ contra-enquêtes -+ contra-expert -+ contra-expertise -+ contra-expertisen -+ contra-expertises -+ contra-experts -+ contracepties -+ contraceptionele -+ contraceptiva -+ contractarbeider -+ contractarbeiders -+ contractbreuken -+ contracteerplicht -+ contractjaar -+ contractjaren -+ contractlonen -+ contractloon -+ contractloonstijging -+ contractonderwijs -+ contractonderzoek -+ contractprijs -+ contractspeler -+ contrafagot -+ contrafagotten -+ contragewichten -+ contraguerrilla -+ contraire -+ contramoeren -+ contraproductieve -+ contrarebel -+ contrarebellen -+ contrareformatie -+ contrareformatorisch -+ contrareformatorische -+ contraremonstrant -+ contraremonstranten -+ contraspionagedienst -+ contrastekkers -+ contrastieve -+ contrastregelaars -+ contrastwerking -+ contrastwerkingen -+ contratenor -+ contratenoren -+ contratenors -+ contraterreur -+ contributiegeld -+ contributiegelden -+ contributieverhoging -+ controle-instrument -+ controle-instrumenten -+ controleapparaat -+ controlebureau -+ controlecommissie -+ controleerbaarheid -+ controlegroepen -+ controlekamers -+ controlelampjes -+ controlemaatregel -+ controlemaatregelen -+ controlemechanisme -+ controlemechanismen -+ controleorgaan -+ controlestations -+ controlestrookjes -+ controletoren -+ controlfreak -+ controlfreaks -+ controltoets -+ convectiestromen -+ convectiestroom -+ convectors -+ convenabele -+ convenantcultuur -+ convenanten -+ convenants -+ convergentiecriteria -+ convergentiecriterium -+ convergentieprogramma -+ conversatiekunst -+ conversatiestuk -+ conversen -+ conversiekoers -+ conversierecht -+ convertibles -+ convicties -+ convocaten -+ convoluten -+ convulsieve -+ cooker -+ cookers -+ cookie -+ cookies -+ cool -+ coole -+ cooljazz -+ coopertests -+ copernicaans -+ copernicaanse -+ copiloten -+ coprocessors -+ coproduceerde -+ coproducties -+ copromotoren -+ copromotors -+ copycard -+ copycards -+ copyshop -+ copyshops -+ copywriters -+ coq-au-vin -+ coquilles -+ corbillard -+ corbillards -+ cordon bleus -+ cordon bleutje -+ corebusiness -+ coreferent -+ coreferenten -+ coregisseurs -+ corgi's -+ cornerspecialist -+ cornervlaggen -+ cornets -+ corniche -+ corniches -+ corona's -+ coronale -+ corporatistische -+ corpsballen -+ corpsstudenten -+ corpus delicti -+ correctiesleutels -+ correctietoetsen -+ correctievloeistof -+ correctionaliseerde -+ correctionaliseren -+ correlaten -+ correspondentes -+ correspondentiekaarten -+ correspondentievrienden -+ correspondentschap -+ corrigeerbaar -+ corrumpering -+ corruptieaffaire -+ corruptieaffaires -+ corruptief -+ corruptieonderzoek -+ corruptiepraktijk -+ corruptiepraktijken -+ corruptieschandaal -+ corruptieschandalen -+ corruptieve -+ corselets -+ corseletten -+ cortège -+ cortèges -+ corveede -+ corveet -+ corveeën -+ coscenaristen -+ coschap -+ coschappen -+ cosmetica-industrie -+ cosmeticabedrijf -+ cosmeticalijn -+ cosponsors -+ cotangens -+ cottages -+ couche -+ couches -+ coulisselandschap -+ coulombpje -+ counselde -+ countdowns -+ counterde -+ counters -+ countertenoren -+ countertenors -+ countervoetbal -+ countryachtige -+ countrydansen -+ countrydanste -+ countrynummer -+ countrynummers -+ countryrock -+ countryzanger -+ countryzangers -+ coupe soleil -+ coupeje -+ coupen -+ coupenaden -+ coupje -+ coupleider -+ couponknippers -+ couponrente -+ coupplan -+ coupplannen -+ couppleger -+ coupplegers -+ couppoging -+ couppogingen -+ coupt -+ coupte -+ courgettebloem -+ cours -+ courtages -+ couturiers -+ couvertures -+ couveusekinderen -+ coverband -+ coverbanden -+ coverbands -+ coverde -+ covers -+ coverversie -+ coverversies -+ covoorzitter -+ covoorzitters -+ cowboyfilms -+ cowboyhoed -+ cowboyhoeden -+ cowboykapitalisme -+ cowboylaars -+ cowboypak -+ cowgirls -+ cox -+ coxen -+ coyotes -+ coïtale -+ coïteerde -+ coöperant -+ coöperanten -+ coöperatief1 -+ coöperatief2 -+ coöperatieven -+ coöperatoren -+ coöperators -+ coöpereerde -+ coöptatiesysteem -+ coördinatiecentra -+ coördinatiecentrums -+ coördinatiecomité -+ coördinatiecomités -+ coördinatiecommissie -+ coördinatiecommissies -+ coördinatieorgaan -+ coördinatieteam -+ coördinators -+ crackdealer -+ crackdealers -+ crackers -+ crackertje -+ cranberry's -+ craniotomen -+ craniotoom -+ cranks -+ crapaudje -+ crashes -+ crasht -+ crashte -+ cravate -+ cravates -+ crawlde -+ crawlslagen -+ crawlt -+ creamcrackers -+ creationisten -+ creativiteitscentra -+ creativiteitscentrum -+ creditcardhouder -+ creditcardhouders -+ creditcardorganisatie -+ crediteurenbank -+ crediteurenbanken -+ crediteurenland -+ crediteurenlanden -+ creditkaart -+ creditkaarten -+ creditnota's -+ creditrente -+ crematieplechtigheid -+ creolistiek -+ creooltaal -+ creooltalen -+ crepeergevallen -+ crescendo's -+ creutzfeldt-jakobsyndroom -+ crews -+ cricketbond -+ cricketclub -+ cricketclubs -+ cricketveld -+ cricketvelden -+ cricketwedstrijd -+ cricketwedstrijden -+ crime passionnel -+ crimes passionnels -+ criminaliteitsbeheersing -+ criminaliteitsbeleid -+ criminaliteitsbestrijding -+ criminaliteitscijfer -+ criminaliteitscijfers -+ criminaliteitspreventie -+ criminaliteitsprobleem -+ criminaliteitsproblemen -+ crimineeltje -+ criminologes -+ criminologische -+ crisisachtig -+ crisisbeheersingsoperatie -+ crisisbeheersingsoperaties -+ crisisberaad -+ crisiscomité -+ crisiscomités -+ crisisinterventies -+ crisisjaar -+ crisisjaren -+ crisiskabinet -+ crisismanager -+ crisismanagers -+ crisisoverleg -+ crisisperiode -+ crisisplan -+ crisisplannen -+ crisisstaf -+ crisisteams -+ crisistoestand -+ crisisverschijnsel -+ crisisverschijnselen -+ critica's -+ cro-magnonmens -+ cro-magnonmensen -+ crochet -+ crochetje -+ croesus -+ croesussen -+ croissanteries -+ croissanterieën -+ croon -+ croonde -+ crooners -+ croont -+ croque-madame -+ croque-madames -+ croque-monsieurs -+ croquetwedstrijd -+ croquetwedstrijden -+ cros -+ cross-overmuziek -+ crosscountry's -+ crosscountryrace -+ crosscountryraces -+ crosscountryskiën -+ crosscousinhuwelijk -+ crosscousinhuwelijken -+ crossers -+ crosses -+ crost -+ crouton -+ croutons -+ crowdsurf -+ crowdsurfen -+ crowdsurft -+ crowdsurfte -+ cruces -+ cruisecontrol -+ cruisede -+ cruiseschepen -+ cruiseschip -+ cruiset -+ cruisete -+ cruzeiro's -+ cryptocommunisten -+ cryptofoons -+ crècheje -+ crème au beurre -+ crème brûlée -+ crème fraîche -+ crèmepje -+ crémant -+ crémants -+ crêpe2 -+ crêperies -+ crêpes -+ ctrl-toets -+ ctrl-toetsen -+ cubaan -+ cubanen -+ cube-ijs -+ cues -+ cuisines -+ cuisiniers -+ culpabiliseerde -+ culpabiliseren -+ cult -+ cultboek -+ cultboeken -+ cultfiguren -+ cultfiguur -+ cultfilm -+ cultfilmer -+ cultfilmers -+ cultfilms -+ cultische -+ cultivars -+ cultivering -+ cultivéparel -+ cultivéparels -+ cultregisseur -+ cultregisseurs -+ cultstatus -+ cultureel-historisch -+ cultureel-historische -+ cultureel-maatschappelijk -+ cultureel-maatschappelijke -+ cultureel-politiek -+ cultureel-politieke -+ cultussen -+ cultuuraanbod -+ cultuurbarbaren -+ cultuurbehoud -+ cultuurbepaald -+ cultuurbepaalde -+ cultuurbezit -+ cultuurcentra -+ cultuurcentrum -+ cultuurcritici -+ cultuurcriticus -+ cultuurfilosofen -+ cultuurgemeenschap -+ cultuurgemeenschappen -+ cultuurgoed -+ cultuurgoederen -+ cultuurgrond -+ cultuurgronden -+ cultuurhistorici -+ cultuurkritisch -+ cultuurkritische -+ cultuurloos -+ cultuurloze -+ cultuurminister -+ cultuurministers -+ cultuurpact -+ cultuurpaus -+ cultuurproducten -+ cultuurpsychologen -+ cultuurpsycholoog -+ cultuurraad -+ cultuurraden -+ cultuurschok -+ cultuurshock -+ cultuursociologie -+ cultuursocioloog -+ cultuurspreiding -+ cultuuruiting -+ cultuuruitingen -+ cultuurverschijnsel -+ cultuurverschijnselen -+ cultuurvolkeren -+ cultuurwetenschap -+ cultuurwetenschappen -+ cummerband -+ cummerbands -+ cumuli -+ cumuls -+ cupduel -+ cupduels -+ cupfinales -+ cupido's -+ cuptoernooi -+ cuptoernooien -+ cupwinnaar -+ cupwinnaars -+ curandi -+ curatoriums -+ curetteerde -+ curetten -+ curettes -+ curies -+ curiositeitsgehalte -+ curiositeitswaarde -+ curry -+ curry's -+ curryworst -+ curryworsten -+ cursiefjes -+ cursiefjesschrijvers -+ cursors -+ cursusboeken -+ cursusjaren -+ cursusleiders -+ cutters -+ cutterzuigers -+ cv -+ cv's -+ cv-ketel -+ cv-ketels -+ cyberpunk -+ cyberpunks -+ cyberspace -+ cyclamaten -+ cyclecros -+ cyclecross -+ cyclecrossen -+ cyclecrosses -+ cyclecrost -+ cyclecroste -+ cyclocros -+ cyclocrossen -+ cyclocrost -+ cyclocroste -+ cynischt -+ cysteaaltje -+ cysteaaltjes -+ cystenier -+ cystenieren -+ cystes -+ cytologische -+ d's -+ d'tje -+ d.d. -+ daalsnelheid -+ daarbovenuit -+ daardoorheen -+ daartegenin -+ dactyloscopeerde -+ dadeloze -+ dadergericht -+ dadergerichte -+ dadergroep -+ dadergroepen -+ daderschap -+ dag-en-nachtevening -+ dag-en-nachteveningen -+ dag-en-nachtritme -+ dagbladengroep -+ dagbladenmarkt -+ dagbladhandelaar -+ dagbladhandelaars -+ dagbladjournalistiek -+ dagbladmarkt -+ dagbladzegel -+ dagboekaantekening -+ dagboekaantekeningen -+ dagboekachtig -+ dagboekachtige -+ dagboekfragment -+ dagboekfragmenten -+ dagboeknotitie -+ dagcentra -+ dagcirkel -+ dagcirkels -+ dagcrèmes -+ dagdagelijks -+ dagdagelijkse -+ dagdromer -+ dagdromerij -+ dagdromerijen -+ dagdromers -+ dagdroomde -+ dagexcursies -+ daggeldrente -+ daggemiddelden -+ daggemiddeldes -+ daghitten -+ dagindelingen -+ dagkalenders -+ dagkoersen -+ daglengte -+ daglichtlampen -+ daglichtopnamen -+ daglichtopnames -+ dagmenu -+ dagmenu's -+ dagopeningen -+ dagpauwoog -+ dagschema's -+ dagschuwe -+ dagsluiter -+ dagsluiters -+ dagtekst -+ dagteksten -+ dagtekstenboekje -+ dagtekstenboekjes -+ dagteller -+ dagtellers -+ dagtoerisme -+ dagvergoeding -+ dagvergoedingen -+ dagverse -+ dagwaarde -+ dagzijde -+ dagzijden -+ dagzusters -+ dahlia's -+ dakappartement -+ dakappartementen -+ dakgebint -+ dakkamers -+ dakkapellen -+ dakladders -+ daklijn -+ daklijnen -+ daklijsten -+ dakloosheid -+ daklozenkrant -+ daklozenkranten -+ dakpansgewijze -+ daktuinen -+ dalai lama's -+ dalang -+ dalangs -+ daler -+ dalers -+ dalfde -+ dalkonschildje -+ dalkonschildjes -+ dallen -+ dalles -+ dalmatiërs -+ dalurenkaarten -+ dalven -+ dalver -+ dalvers -+ damboek -+ damboeken -+ damclubs -+ dame blanche -+ dames blanches -+ damesblaadje -+ damesdubbels -+ dameshoed -+ dameshoeden -+ dameskapsalon -+ dameskapsalons -+ dameskleding -+ damesmodes -+ damespaard -+ damespaarden -+ damesromans -+ damesschoen -+ damessjaal -+ damessjaals -+ damestas -+ damestasje -+ damestassen -+ damestoiletten -+ damesverbanden -+ damesvoetbal -+ damkampioenen -+ damkampioenschap -+ damkampioenschappen -+ damklokken -+ damlijn -+ damlijnen -+ dampartij -+ dampartijen -+ dampdichtheid -+ dampkappen -+ damslagen -+ damsport -+ damstenen -+ damwedstrijden -+ danaïden -+ danaïdenvat -+ dancehall -+ dancehallartiest -+ dancehallartiesten -+ dancehalls -+ danceparty -+ danceparty's -+ dandyachtige -+ dankredes -+ dankwoorden -+ dans-en-showorkest -+ dans-en-showorkesten -+ dansante -+ dansavond -+ dansavonden -+ danscarrière -+ danse macabre -+ danses macabres -+ danseurs -+ danseuseje -+ dansfestival -+ dansfestivals -+ dansfiguren -+ dansgelegenheden -+ dansgelegenheid -+ dansi -+ dansi's -+ danskunst -+ dansleraars -+ dansleraren -+ dansliedje -+ dansliedjes -+ dansmaat -+ dansmaten -+ dansmeestertje -+ dansmeestertjes -+ dansmeisje -+ dansmeisjes -+ dansnummer -+ dansnummers -+ dansorkesten -+ danspaar -+ dansparen -+ danspartners -+ dansrage -+ dansrages -+ dansritme -+ dansritmen -+ dansritmes -+ dansschoen -+ dansschoenen -+ dansscholen -+ dansstudio -+ dansstudio's -+ danstheaters -+ dantesk -+ danteske -+ darde -+ dark horse -+ darkroom -+ darkrooms -+ darmafsluiting -+ darmbacterie -+ darmbacteriën -+ darmbeen -+ darmbeenderen -+ darmbloedingen -+ darmcatarres -+ darmgassen -+ darminfecties -+ darmkanker -+ darmklacht -+ darmkoliek -+ darmkolieken -+ darmkramp -+ darmkrampen -+ darmontstekingen -+ darmoperatie -+ darmoperaties -+ darmparasiet -+ darmparasieten -+ darmprobleem -+ darmproblemen -+ darmwand -+ darmziekten -+ dartboard -+ dartboards -+ dartbord -+ dartborden -+ darten -+ dartsspel -+ dartte -+ darwinhybride -+ darwinhybriden -+ darwinvink -+ darwinvinken -+ dashboarden -+ dashboardkastjes -+ dassenburcht -+ dassenburchten -+ dassenpopulatie -+ dassenpopulaties -+ dassentunnel -+ dassentunnels -+ siberisch -+ data-analyse -+ data-analyses -+ data-encryptie -+ datalimiet -+ datalimieten -+ datamining -+ datanetwerken -+ datarecorder -+ datarecorders -+ datastromen -+ datastroom -+ datatransmissies -+ date -+ dateerbare -+ daten -+ dateringsmethode -+ dateringsmethoden -+ dates -+ datet -+ datete -+ dating -+ datingbureau -+ datingbureaus -+ datingprogramma -+ datingprogramma's -+ datings -+ datingshow -+ datingshows -+ datrecorder -+ datrecorders -+ datsja's -+ datumgrens -+ datumgrenzen -+ dauwwormen -+ davvende -+ davvenen -+ dawet -+ daze -+ dc -+ dc's -+ dd. -+ de bout hachelen -+ de r scherp uitspreken -+ de-escalatie -+ de-escalaties -+ de-escaleerde -+ de-escaleren -+ de-woord -+ de-woorden -+ deactiveerde -+ deactualiseerde -+ deactualiseren -+ dealde -+ dealerbedrijf -+ dealernet -+ dealernetten -+ dealernetwerk -+ deals -+ dealt -+ dealtje -+ debacletje -+ debardeur -+ debardeurs -+ debatingclubs -+ debetrente -+ debetsaldo's -+ debilisering -+ debiteurenportefeuille -+ debrailleerde -+ debrief -+ debriefde -+ debriefen -+ debriefing -+ debriefings -+ debrieft -+ debriefte -+ debugde -+ debutantenbal -+ debutantes -+ debuutalbum -+ debuutalbums -+ debuutbundel -+ debuutbundels -+ debuutromans -+ decalages -+ decanale -+ decanteerfles -+ decanteerflessen -+ decatlons -+ decemberdagen -+ decembernummer -+ decembernummers -+ decentralisatie-impuls -+ decentralisatiebeleid -+ decentralisaties -+ decentralisering -+ decharges -+ decibelgehalte -+ decibellen -+ decielen -+ decimering -+ decimeterhoge -+ decimeterhoog -+ decks -+ declamatorische -+ declaratieformulier -+ declaratieformulieren -+ declaratiegedrag -+ declaratiesysteem -+ declaratoire -+ decollectivisering -+ decolleteetje -+ decomposities -+ decomprimeerde -+ decomprimeren -+ deconfessionaliseerde -+ deconfitures -+ deconstructieve -+ deconstructivisten -+ deconstructivistische -+ deconstrueerde -+ decoratiestelsel -+ decoratieven -+ decorbouw -+ decorbouwers -+ decorelement -+ decorelementen -+ decorontwerp -+ decorontwerper -+ decorontwerpers -+ decortje -+ decorumverlies -+ decorwand -+ decorwanden -+ decorwisseling -+ decorwisselingen -+ decoupeerde -+ decoupeerzagen -+ decrescendo's -+ decretaal -+ decretale -+ decumul -+ decurio -+ decurio's -+ decurion -+ decuriones -+ decurions -+ dedaigneuze -+ dedain -+ deegballen -+ deegbodem -+ deegbodems -+ deeghaken -+ deegrol -+ deegrollen -+ deelakkoord -+ deelcertificaat -+ deelcontract -+ deelcontracten -+ deeldiscipline -+ deeldisciplines -+ deelgehad -+ deelgemeenteraad -+ deelgemeenteraden -+ deelgenotes -+ deellijn -+ deellijnen -+ deelnamebewijs -+ deelnamebewijzen -+ deelnamekosten -+ deelnemersveld -+ deelnemingenbeleid -+ deelnemingsvrijstelling -+ deelparlement -+ deelparlementen -+ deelraad -+ deelraadbestuur -+ deelraadbestuurder -+ deelraadbestuurders -+ deelraadsleden -+ deelraadslid -+ deelraadsverkiezing -+ deelraadsverkiezingen -+ deelraadswethouder -+ deelraadswethouders -+ deelraadvoorzitter -+ deelraadwethouder -+ deelraadwethouders -+ deelraden -+ deelradensysteem -+ deelregering -+ deelregeringen -+ deelrepubliek -+ deelrepublieken -+ deelstaatniveau -+ deelstaatparlement -+ deelstaatparlementen -+ deelstaatpremier -+ deelstaatpremiers -+ deelstaatregering -+ deelstaatregeringen -+ deelstaatverkiezingen -+ deeltijd-VUT -+ deeltijdberoepsonderwijs -+ deeltijder -+ deeltijders -+ deeltijdhoogleraar -+ deeltijdhoogleraren -+ deeltijds -+ deeltijdse -+ deeltijdstudent -+ deeltijdstudenten -+ deeltijdstudie -+ deeltijdstudies -+ deeltitel -+ deeltitels -+ deeltjesbundel -+ deeltjesbundels -+ deeltjesfysica -+ deeltjesfysici -+ deeltjesfysicus -+ deeltjesonderzoek -+ deelverkiezing -+ deelverkiezingen -+ deelwetenschappen -+ deemster -+ deemsterde weg -+ deemstere -+ deeplink -+ deeplinken -+ deeplinkt -+ deeplinkte -+ defensie-elektronica -+ defensie-expert -+ defensie-experts -+ defensie-industrie -+ defensie-uitgaven -+ defensieaankoop -+ defensieaankopen -+ defensieapparatuur -+ defensiearm -+ defensiebegroting -+ defensiebegrotingen -+ defensiebelasting -+ defensiebezuiniging -+ defensiebezuinigingen -+ defensiebudget -+ defensiebudgetten -+ defensiefunctionaris -+ defensiefunctionarissen -+ defensiekosten -+ defensiemacht -+ defensiemateriaal -+ defensiematerieel -+ defensieminister -+ defensieministers -+ defensieonderzoek -+ defensieorder -+ defensieorders -+ defensieovereenkomst -+ defensieplan -+ defensieplannen -+ defensieplanning -+ defensiepolitiek -+ defensieportefeuille -+ defensieprogramma -+ defensieraad -+ defensiesector -+ defensiespecialist -+ defensiespecialisten -+ defensiestaf -+ defensietechnologie -+ defensiewoordvoerder -+ defensiewoordvoerders -+ defensiezaken -+ defibrillatoren -+ defibrillators -+ defibrilleerde -+ deficitje -+ deficits -+ deficiëntieziekte -+ deficiëntieziekten -+ deficiëntieziektes -+ defileetje -+ definiëringen -+ deflecteerde -+ defloreerde -+ degeneratieziekte -+ degeneratieziekten -+ degeneratieziektes -+ degenslikkers -+ degradanten -+ degradatiekandidaat -+ degradatiekandidaten -+ degradatiewedstrijden -+ degradatiezone -+ degressieve -+ degustatie -+ degusteerde -+ degusteren -+ dehydraties -+ dehydreerde -+ dei ex machina -+ deiktische -+ dejeunertje -+ dekbedovertrekken -+ dekenale -+ dekenaten -+ dekenkisten -+ dekkingsfouten -+ dekkingspercentages -+ dekkingsplannen -+ dekladingen -+ deklat -+ deklatten -+ dekolonisatieproces -+ dekoloniseerde -+ dekolonisering -+ dekschuit -+ dekschuiten -+ dekstieren -+ dekzand -+ dekzeilen -+ dekzwabbers -+ delegatieleden -+ delegatieleiders -+ delegatielid -+ delete -+ deletet -+ deletetoets -+ deletetoetsen -+ delfstoffenwinning -+ delicatessenwinkels -+ delicatessenzaak -+ delicatessenzaken -+ delingsplan -+ delinquente -+ delinquentenzorg -+ delirante -+ deliria -+ deliriums -+ dellerig -+ dellerige -+ delta's -+ delta-eiland -+ delta-eilanden -+ deltagebieden -+ deltaplannen -+ deltavleugels -+ deltavliegers -+ demarrages -+ demarreerde -+ dematerialisaties -+ dementi's -+ demi's -+ demi-john -+ demi-johns -+ demi-mondaines -+ demi-monde -+ demineraliseerde -+ demo-opname -+ demo-opnamen -+ demo-opnames -+ democratisch-liberaal -+ democratisch-liberale -+ democratisch-socialistisch -+ democratisch-socialistische -+ democratiseringsbeweging -+ democratiseringsbewegingen -+ democratiseringsgolf -+ democratiseringsplan -+ democratiseringsplannen -+ democratiseringsprogramma -+ demografen -+ demoniseerde -+ demoniseren -+ demonisering -+ demonopolisering -+ demonstrateurs -+ demonstratiemodellen -+ demonstratiepartij -+ demonstratiepartijen -+ demonstratiesport -+ demonstratiesporten -+ demonstratietoernooi -+ demonstratieverbod -+ demonstratievluchten -+ demonstratiewedstrijd -+ demonstratiezaal -+ demonstreerbare -+ demontages -+ demootje -+ demotie -+ demystificaties -+ demystificeerde -+ denationalisering -+ denaturaliseerde -+ dendrochronologie -+ dendrochronologische -+ dengue -+ deniers -+ denigreerde -+ denivellering -+ denkertje -+ denkertjes -+ denkkader -+ denkkaders -+ denkpatronen -+ denkpatroon -+ denkpiste -+ denkpistes -+ denkpsychologie -+ denkramen -+ denkrimpel -+ denkrimpeltje -+ denksporten -+ denksysteem -+ denktanken -+ denktanks -+ denkwerelden -+ dennenappelen -+ dennengeur -+ dennengeuren -+ dennenhouten -+ dennenlucht -+ denominaties -+ denomineerde -+ denonceerde -+ denotaties -+ densimeters -+ denuclearisering -+ denunciaties -+ denuncieerde -+ deodoranten -+ deodoriseerde -+ deontologisch -+ deontologische -+ depannage -+ depanneerde -+ departementshoofd -+ departementsleiding -+ departementsleidingen -+ depenaliseerde -+ depenaliseren -+ dependanceje -+ depolariseerde -+ depolitisering -+ deposanten -+ deposities -+ depositiën -+ depositoboekje -+ depositoboekjes -+ depotje -+ depotruimte -+ depotruimten -+ depotruimtes -+ depressieactiviteit -+ depressiejaar -+ depressiejaren -+ depri -+ deprivatiseerde -+ depriveerde -+ deprogrammeerde -+ deputeerde -+ deputeetje -+ deputé -+ deputés -+ derailleurs -+ derboeka -+ derboeka's -+ derby's -+ derdebordspeler -+ derdebordspelers -+ derdedivisieclub -+ derdegeneratieallochtonen -+ derdegeneratieallochtoon -+ derdegraads -+ derdegraadsverbrandingen -+ derdegraadsverhoren -+ derdehandse -+ derdehonkman -+ derdehonkmannen -+ derdeklasser -+ derdeklassers -+ derdekwartaalcijfers -+ derdemacht -+ derdemachten -+ derdemachtsvergelijking -+ derdemachtsvergelijkingen -+ derderangspolitici -+ derderangspoliticus -+ derdewereldactivist -+ derdewereldactivisten -+ derdewereldland -+ derdewereldlanden -+ derdewereldstad -+ derdewereldsteden -+ dereguleringsoperatie -+ dereguleringsoperaties -+ dermatologen -+ dermatologische -+ derny's -+ derogeerde -+ derrières -+ dertiende-eeuws -+ dertiende-eeuwse -+ dertiendelig -+ dertiendelige -+ dertiental -+ dertigkilometerbord -+ dertigkilometerborden -+ dertigplusser -+ dertigplussers -+ dertigvoudig -+ dertigvoudige -+ derwisje -+ desa's -+ desacraliseerde -+ desambigueerde -+ desambigueren -+ desastreust -+ desastreuzer -+ desavoueerde -+ desavouering -+ descendanten -+ descripties -+ desdochter -+ desdochters -+ desensibiliseerde -+ desgevallend -+ deshormoon -+ designerdrug -+ designerdrugs -+ designers -+ designmeubel -+ designmeubelen -+ designmeubels -+ designprijs -+ designprijzen -+ designs -+ desinfectantia -+ desinformatiecampagne -+ desinformatiecampagnes -+ desintegratieproces -+ desintegratieverschijnsel -+ desintegratieverschijnselen -+ desinvesteerde -+ desinvesteringsprogramma -+ desks -+ desktop -+ desktopcomputer -+ desktopcomputers -+ desktoppublishing -+ desktops -+ deskundigencommissie -+ deskundologen -+ deskundoloog -+ desmoeder -+ desmoeders -+ desolaatheid -+ desoriënteerde -+ desoxyribonucleic acid -+ desperado's -+ dessertlepeltje -+ dessertwijnen -+ dessineerde -+ destabiliseerde -+ destabilisering -+ destaliniseerde -+ destinaties -+ destructiebedrijf -+ destructors -+ detailfoto's -+ detailhandels -+ detailhandelsactiviteit -+ detailhandelsschool -+ detailhandelsverkoop -+ detailhandelsverkopen -+ detailopnamen -+ detailopnames -+ detailpunt -+ detailpunten -+ detailrijk -+ detailrijke -+ detailstudies -+ detailtje -+ detectielus -+ detectielussen -+ detectieplaatje -+ detectieplaatjes -+ detectiepoortje -+ detectiepoortjes -+ detectiveachtig -+ detectiveachtige -+ detectivebureau -+ detectivebureaus -+ detectiveschrijver -+ detectiveschrijvers -+ detectivewerk -+ detectors -+ detentiecentra -+ detentiecentrum -+ detentiekamp -+ detentiekampen -+ detentieruimte -+ detentieruimten -+ detentieruimtes -+ detenties -+ detergentia -+ determinatiegraad -+ determineerklassen -+ detonaties -+ detonators -+ deugddoend -+ deugddoende -+ deuropeningen -+ deurpaneel -+ deurpanelen -+ deus ex machina's -+ deuteriumkern -+ deuteriumkernen -+ deux-chevauxgarage -+ deux-chevauxs -+ deux-chevauxtje -+ deux-piècesje -+ deverbatieve -+ deverbatieven -+ devieerde -+ deviezeninkomsten -+ deviezenreserves -+ deviezenverkeer -+ devonisch -+ devonische -+ devoon -+ devotionele -+ dia-avond -+ dia-avonden -+ diaboliseerde -+ diaboliseren -+ diagnosecentra -+ diagnosecentrum -+ diagnosticeerde -+ diagonaalband -+ diagonaalbanden -+ diagonaalsgewijs -+ diagonaalsgewijze -+ diagramstelling -+ diakenopleiding -+ diakritische -+ dialectismen -+ dialectsprekend -+ dialectsprekende -+ dialectvorm -+ dialectvormen -+ dialectwoord -+ dialectwoorden -+ dialogiseerde -+ dialoogvorm -+ dialoogvormen -+ dialyses -+ diamantbeurs -+ diamantbeurzen -+ diamanthandel -+ diamanthandelaar -+ diamantindustrie -+ diamantnaalden -+ diamantnijverheid -+ diana-aap -+ diana-apen -+ diapositieven -+ diaprogramma -+ diaprogramma's -+ diaprojectors -+ diascherm -+ diaschermen -+ diascopen -+ diaseries -+ diastolen -+ diastolische -+ diatheken -+ diaviewers -+ diavoorstellingen -+ dibbes -+ dibbesen -+ dibboek -+ dichloordifenyltrichloorethaan -+ dichotomieën -+ dichtbebouwd -+ dichtbebouwde -+ dichters-zangers -+ dichtgereden -+ dichtheden -+ dichtheidsverschil -+ dichtheidsverschillen -+ dichting -+ dichtingen -+ dichtrijden -+ dichtslibbing -+ dictaatcahiers -+ dictatoren -+ dicteerapparaten -+ didgeridoo -+ didgeridoos -+ dieetkeukens -+ dieetmargarine -+ dieetpatiënten -+ dieetproduct -+ dieetproducten -+ dieetvoeding -+ dieetvoorschriften -+ dieetwinkel -+ dieetwinkels -+ diefijzer -+ diefijzers -+ diefje-met-verlos -+ diefstalletje -+ diehards -+ dieken -+ diekte -+ dienblaadje -+ dienbladen -+ dienschaal -+ dienschalen -+ dienst-na-verkoop -+ dienstboeken -+ dienstenbalans -+ diensteneconomie -+ dienstenpakketten -+ dienstensectoren -+ dienstfietsen -+ dienstgeheimen -+ dienstgesprekken -+ dienstgeweigerd -+ diensthonden -+ dienstingangen -+ dienstleiding -+ dienstlift -+ dienstliften -+ dienstlijnen -+ dienstmededelingen -+ dienstmeiden -+ dienstneming -+ dienstpet -+ dienstpetten -+ dienstpistolen -+ dienstplichtigenleger -+ dienstplichtontduiker -+ dienstroosters -+ dienstverbanden -+ dienstverleningsbedrijf -+ dienstverleningssector -+ dienstwagen -+ dienstwagens -+ dienstweigeren -+ diepdroevig -+ diepdroevige -+ diepgelovig -+ diepgelovige -+ diepingrijpend -+ diepingrijpende -+ dieplink -+ dieplinken -+ dieplinkt -+ dieplinkte -+ diepte-interview -+ diepte-interviews -+ diepte-investering -+ diepte-investeringen -+ dieptemeters -+ dieptepasses -+ dieptescherpte -+ dieptestructuren -+ dieptestructuur -+ diepvrieskasten -+ diepvrieskisten -+ diepvriesmaaltijden -+ diepzeehaven -+ diepzeehavens -+ diepzeeën -+ dierenasielen -+ dierenasiels -+ dierenbeulen -+ dierenhandel -+ dierenhotel -+ dierenhotels -+ dierenklinieken -+ dierenliefde -+ dierennamen -+ dierenpension -+ dierenverhaal -+ dierenverhalen -+ diergedrag -+ diergeneeskundig -+ diergeneeskundige -+ dierkundigen -+ diernaam -+ diernamen -+ dieronvriendelijk -+ dieronvriendelijke -+ dierproef -+ dierproeven -+ dierpsychologen -+ dierpsychologie -+ dierpsycholoog -+ diervriendelijk -+ diervriendelijke -+ diervriendelijkheid -+ dierwaardig -+ dierwaardige -+ dieselde -+ dieselelektrisch -+ diesellocomotieven -+ dieseltje -+ diesredes -+ diesviering -+ diesvieringen -+ dievegges -+ dievenijzer -+ dievenijzers -+ diffameerde -+ differentiaaldiagnosen -+ differentiaaldiagnoses -+ differentialen -+ diffundeerde -+ diftongeerde -+ digestieve -+ digibeet -+ digibeten -+ digital versatile disk -+ digniteiten -+ dijbeenblessure -+ dijbeenblessuren -+ dijbeenblessures -+ dijenkletsers -+ dijkbewaking -+ dijkdorp -+ dijkdorpen -+ dijkheemraden -+ dijkhuis -+ dijkhuizen -+ dijklegers -+ dijkring -+ dijkringen -+ dijkvakken -+ dijkverzwaringsprogramma -+ dijkverzwaringsproject -+ dijkverzwaringsprojecten -+ dijkwerken -+ dijonmosterd -+ dijspieren -+ dijtje -+ dikbillen -+ dikdoeners -+ dikkerdje -+ dikkopje -+ dikkopjes -+ dilataties -+ dilateerde -+ dilettantes -+ dilettantische -+ dilettantistische -+ dillezaad -+ diluvium -+ dimensioneerde -+ dimlichten -+ dimschakelaars -+ dinarbiljet -+ dinarbiljetten -+ dinars -+ dinerpauze -+ dinertje -+ dingdong -+ dingdongs -+ dingo's -+ dino -+ dino's -+ dinosaurussen -+ dinosaurustijdperk -+ dinsdagmiddagen -+ dinsdagnachten -+ dinsdagochtenden -+ dioden -+ dionysisch -+ dionysische -+ diorieten -+ dioxine-uitstoot -+ dioxinegehalten -+ dioxinegehaltes -+ dioxines -+ dipje -+ diploma-eisen -+ diploma-inflatie -+ diploma-uitreiking -+ diploma-uitreikingen -+ diplomatenkoffer -+ diplomatenkoffers -+ diplomatentassen -+ diplomatenwijk -+ diplomatenwijken -+ diploïde -+ dips -+ dipsausen -+ directbetrokkene -+ directbetrokkenen -+ directeur-grootaandeelhouder -+ directeur-secretaris -+ directeuren-grootaandeelhouders -+ directeurschappen -+ directeurskamer -+ directeurskamers -+ directeurspost -+ directiecomité -+ directiecomités -+ directiekantoor -+ directiekantoren -+ directiesecretaresses -+ directiesecretariaten -+ directiesecretarissen -+ directiestoel -+ directievergaderingen -+ directmailcampagne -+ directmailcampagnes -+ directoiretje -+ directoraat-generaal -+ directoraten-generaal -+ dirigentenbok -+ dirigentenbokken -+ dirigentencursus -+ dirigentencursussen -+ dirigistische -+ dirk2 -+ dirndljurk -+ dirndljurken -+ disambigueerde -+ disambigueren -+ disclaimer -+ disclaimers -+ discman -+ discmans -+ discobars -+ discobus -+ discobussen -+ discoganger -+ discogangers -+ discografieën -+ discontinue -+ disconto's -+ discontorente -+ discontotarief -+ discontotarieven -+ discontoverhogingen -+ discontoverlagingen -+ discontovoeten -+ discotheekbezoeker -+ discotheekbezoekers -+ discounts -+ discountzaken -+ discrediteerde -+ discriminantanalyse -+ discriminaties -+ discriminatieverbod -+ discriminatiezaak -+ discriminatiezaken -+ discriminatoire -+ discursieve -+ discussiefora -+ discussieforum -+ discussieforums -+ discussiemethoden -+ discussiemethodes -+ discussieplatform -+ discussieplatforms -+ diskdrives -+ disketje -+ diskjockeys -+ dislocaties -+ dispensaria -+ dispensariums -+ dispensers -+ disproporties -+ dissidentenbeweging -+ dissidentengroep -+ dissidentes -+ dissidenties -+ dissocieerde -+ dissonanties -+ distantiëring -+ distantiëringen -+ diste op -+ distilleerders -+ distributieafdeling -+ distributiepunt -+ distributiepunten -+ distributiesector -+ districtbestuurder -+ districtbestuurders -+ districtchef -+ districtchefs -+ districtenstelsels -+ districtsbewoner -+ districtsbewoners -+ districtsbureaus -+ districtschef -+ districtschefs -+ districtsgenoot -+ districtsgenoten -+ districtshoofd -+ districtshoofden -+ districtskantoren -+ districtsraadsleden -+ districtsraadslid -+ districtsraden -+ districtssecretaris -+ districtssecretarissen -+ districtstoelage -+ districtstoelagen -+ districtstoelages -+ ditjes-en-datjes -+ dito's -+ diuretica -+ divalifeest -+ divalioptocht -+ divalioptochten -+ divanbedden -+ divergente -+ divergenties -+ diversificatiepolitiek -+ diversifieerde -+ diverteerde -+ divertimento's -+ dividendbetaling -+ dividendbetalingen -+ dividendloos -+ dividendloze -+ dividenduitkeringen -+ dividendvoorstel -+ dividivi -+ dividivi's -+ divisiehoofd -+ divisiehoofden -+ divisiestructuur -+ divisionisten -+ dixielandmuziek -+ dixit -+ diëtiek -+ dj -+ dj's -+ djahé -+ djak -+ djakken -+ djaks -+ djakte -+ djati's -+ djellaba's -+ djembé -+ djembés -+ djilbab -+ djinn -+ djinns -+ djogo -+ djogo's -+ djorken -+ djorkte -+ do's -+ dobbelsteentje -+ dobbelsteentjes -+ dobermann -+ dobermannpincher -+ dobermannpinchers -+ dobermanns -+ doceertoon -+ docentenagenda -+ docentenagenda's -+ docentenhandleiding -+ docentenkorpsen -+ docentes -+ docentschappen -+ dochterbank -+ dochterbanken -+ dochtervennootschap -+ dochtervennootschappen -+ docking station -+ docking stations -+ doctoraalbul -+ doctoraalbullen -+ doctoraaldiploma -+ doctoraaldiploma's -+ doctoraalexamens -+ doctoraalstudies -+ doctoraatsverhandeling -+ doctoraatsverhandelingen -+ doctoranda's -+ doctorandustitel -+ doctorsgraden -+ docu -+ docu's -+ docudrama -+ docudrama's -+ documentairefotografie -+ documentaireserie -+ documentaireseries -+ documentaristen -+ documentatieafdeling -+ documentatiecentra -+ documentatiepunt -+ docusoap -+ docusoaps -+ dodehoekspiegel -+ dodehoekspiegels -+ dodemansrit -+ dodenaantallen -+ dodenboek -+ dodencel -+ dodencellen -+ dodencijfers -+ dodenherdenkingen -+ dodenhuisje -+ dodenhuisjes -+ dodenlijst -+ dodenlijsten -+ dodenmars -+ dodenmarsen -+ dodenritten -+ dodensprongen -+ dodentol -+ dodo's -+ doe-het-zelfzaken -+ doe-het-zelven -+ doe-het-zelver -+ doe-het-zelvers -+ doeg -+ doei -+ doelbewustheid -+ doelgebieden -+ doelgemiddelden -+ doelgemiddeldes -+ doelgerichtheid -+ doelgroepenoverleg -+ doelgroepenzender -+ doelkans -+ doelkansen -+ doellatten -+ doelpoging -+ doelpogingen -+ doelpuntenfestijn -+ doelpuntenmachine -+ doelpuntenmaker -+ doelpuntenmakers -+ doelpuntloos -+ doelpuntloze -+ doelrijpe -+ doelsaldo's -+ doeltalen -+ doeltrappen -+ doeluitkering -+ doeluitkeringen -+ doelvrouwe -+ doelvrouwen -+ doemdenkers -+ doemscenario -+ doemscenario's -+ dogla -+ dogla's -+ dogmatiseerde -+ doka's -+ dokhavens -+ doks -+ doksen -+ doktersadviezen -+ doktersassistentes -+ doktershulp -+ doktersjassen -+ dokterspraktijken -+ doktersromannetje -+ doktersromans -+ doktersvoorschriften -+ doktersvrouw -+ doktersvrouwen -+ dolboorden -+ doldwaas -+ doldwaze -+ doleanties -+ dolenthousiast -+ dolenthousiaste -+ dolers -+ dolfijnvriendelijk -+ dolfijnvriendelijke -+ dolfinaria -+ dolfinariums -+ dollariseerde -+ dollariseren -+ dollarisering -+ dollarkoersstijging -+ dollarlening -+ dollarleningen -+ dollarobligatie -+ dollarobligaties -+ dollarstijging -+ dollartegoed -+ dollartegoeden -+ dolle mina -+ dolle mina's -+ dollekoeienziekte -+ dollemansritten -+ dolly's -+ domesticeerde -+ domiciliëring -+ domineesdochter -+ domineesdochters -+ domineeszonen -+ domino-effect -+ dominostekker -+ dominostekkers -+ dominotheorie -+ dominus -+ domme august -+ dommerd -+ dommerds -+ dommig -+ dommige -+ dompteurs -+ domsteden -+ donderbussen -+ donderdagavonden -+ donderdagmiddagen -+ donderdagnachten -+ donderdagochtenden -+ donderspeechen -+ donderspeeches -+ donderstemmen -+ donderstraalde -+ donjons -+ donjuan -+ donjuans -+ donken -+ donkergekleurd -+ donkergekleurde -+ donkergetint -+ donkergetinte -+ donkerharig -+ donkerharige -+ donkerhuidig -+ donkerhuidige -+ donkerkleurig -+ donkerkleurige -+ donkerpaars -+ donkerpaarse -+ donkerslag -+ donkerslagen -+ donna's -+ donorbloed -+ donorhart -+ donorharten -+ donorhuid -+ donorlanden -+ donormoeders -+ donornier -+ donornieren -+ donorschap -+ donquichot -+ donquichots -+ donsdekens -+ donsveer -+ donsveren -+ donuts -+ doodbraaf -+ doodbrave -+ doodconcurreren -+ doodenkel -+ doodenkele -+ doodfluiten -+ doodgeconcurreerd -+ doodgefloten -+ doodgelegd -+ doodgemoedereerde -+ doodgeschrokken -+ doodgetrapt -+ doodgoeie -+ doodgraag -+ doodgriezelig -+ doodgriezelige -+ doodleggen -+ doodmoeë -+ doodsbedreiging -+ doodsbedreigingen -+ doodschrik -+ doodschrikken -+ doodsdrift -+ doodserieus -+ doodserieuze -+ doodseskaders -+ doodsgedachtes -+ doodshoofdaapje -+ doodshoofdaapjes -+ doodsklap -+ doodsklappen -+ doodsklokken -+ doodskopaapje -+ doodskopaapjes -+ doodsmakken -+ doodspuiten -+ doodssteken -+ doodsvonnis -+ doodsvonnissen -+ doodswens -+ doodtrappen -+ doodverklaring -+ doodverklaringen -+ doodvermoeiend -+ doodvriezen -+ doodzenuwachtig -+ doodzenuwachtige -+ doopattestaties -+ doopkaars -+ doopkaarsen -+ doopmoeder -+ doopplechtigheden -+ doorademen -+ doorakkeren -+ doorbloede -+ doorbloedingen -+ doorbloedingsstoornis -+ doorbloedingsstoornissen -+ doorbrekingen -+ doorbrieven -+ doordachtheid -+ doordenkers -+ doordesemd -+ doordesemde -+ doordesemen -+ doordrammerige -+ doordrinken -+ doordrukstrips -+ doordrukverpakkingen -+ doorduwen -+ dooreengevlochten -+ doorfietsen -+ doorgangsfase -+ doorgangsfasen -+ doorgangsfases -+ doorgangsweg -+ doorgangswegen -+ doorgankelijke -+ doorgeademd -+ doorgeakkerd -+ doorgebloed -+ doorgebriefd -+ doorgedronken -+ doorgeduwd -+ doorgeefluiken -+ doorgegleden -+ doorgekacheld -+ doorgekamd -+ doorgekletst -+ doorgekopt -+ doorgekopte -+ doorgekozen -+ doorgekregen -+ doorgekropen -+ doorgekweekt -+ doorgeladen -+ doorgeleefd -+ doorgeleend -+ doorgepompt -+ doorgeprocedeerd -+ doorgerold -+ doorgerouteerd -+ doorgesmeuld -+ doorgespit -+ doorgestart -+ doorgetast -+ doorgeteld -+ doorgetikt -+ doorgevlogen -+ doorgewogen -+ doorgezopen -+ doorglijden -+ doorgroefd -+ doorgroefde -+ doorkachelen -+ doorkammen -+ doorkiesnummers -+ doorkijkblouses -+ doorkletsen -+ doorknoopjurken -+ doorkomsten -+ doorkruisingen -+ doorkweken -+ doorlaatposten -+ doorladen -+ doorlating -+ doorlenen -+ doorlevering -+ doorleveringen -+ doorlichtingen -+ doorlooptijden -+ doormeter -+ doormeters -+ doorpompen -+ doorprocederen -+ doorreisvisa -+ doorreisvisum -+ doorrijhoogten -+ doorrijhoogtes -+ doorrollen -+ doorrouteren -+ doorsmeerbeurten -+ doorsmeulen -+ doorsnedes -+ doorsnee-Belg -+ doorsnee-Nederlander -+ doorsnee-Surinamer -+ doorspitten -+ doorstarten -+ doorstarts -+ doorstraald -+ doorstraalde -+ doorstralen -+ doorstromer -+ doorstromingsafdeling -+ doorstroommogelijkheden -+ doorstroommogelijkheid -+ doortellen -+ doortikken -+ doorvergaderd -+ doorvergaderen -+ doorvliegen -+ doorvoeld -+ doorvoelde -+ doorvoelen -+ doorvoerhavens -+ doorwaakt -+ doorwaken -+ doorwegen -+ doorwerkprojecten -+ doorwinterd -+ doorwoekerd -+ doorwoekerde -+ doorzoeking -+ doorzoekingen -+ doorzonkamer -+ doorzonkamers -+ doorzuipen -+ doosvormig -+ doosvormige -+ doperse -+ doperwtje -+ dopes -+ dopgeld -+ dophoeden -+ dopingaffaire -+ dopingaffaires -+ dopingcontroles -+ dopinggebruik -+ dopingonderzoek -+ dopingtests -+ dopingzaak -+ dopingzaken -+ dopplereffect -+ dopsleutels -+ dorado's -+ dorpsbevolking -+ dorpsbevolkingen -+ dorpsburgemeester -+ dorpsburgemeesters -+ dorpscafeetje -+ dorpscafé -+ dorpscafés -+ dorpscentra -+ dorpsgekken -+ dorpsgemeente -+ dorpsgemeenten -+ dorpsgemeentes -+ dorpsgenoot -+ dorpsgenoten -+ dorpsgezichten -+ dorpshoofd -+ dorpshuizen -+ dorpsidioot -+ dorpsidioten -+ dorpsjongen -+ dorpsjongens -+ dorpskapitein -+ dorpskapiteins -+ dorpskommen -+ dorpskroeg -+ dorpskroegen -+ dorpsnotabele -+ dorpsnotabelen -+ dorpsonderwijzer -+ dorpsonderwijzers -+ dorpsoudste -+ dorpsoudsten -+ dorpspolitiek -+ dorpspomp -+ dorpsraad -+ dorpsraden -+ dorstlesser -+ dorstlessers -+ doseerunit -+ doseerunits -+ doseringen -+ dossierdiploma -+ dossierkennis -+ dossiermappen -+ dossiernummers -+ dotale -+ dots per inch -+ dotterbehandeling -+ dotterbehandelingen -+ dotterde -+ douane-expediteur -+ douane-expediteurs -+ douane-unie -+ douaneambtenaren -+ douanehuisje -+ douanepost -+ douaneposten -+ douanerecherche -+ douanerechten -+ douanes -+ douanetarief -+ douanetarieven -+ double-breasted -+ douch -+ douchecabines -+ douchegordijnen -+ doucheje -+ douchekop -+ douchekoppen -+ douchekraan -+ douchekranen -+ doucht -+ douchte -+ doveninstituten -+ dovenscholen -+ doventaal -+ dovig -+ dovige -+ downer -+ downers -+ downgrade -+ downgradede -+ downgraden -+ downgradet -+ downloadde -+ downloads -+ downloadt -+ downslag -+ downslagen -+ downstemmingen -+ downsyndroom -+ dozenopener -+ dozenopeners -+ dozerde -+ dozeren -+ doña's -+ dpi -+ dr. -+ draadbreuken -+ draadjesvlees -+ draadomroep -+ draadplastieken -+ draadspoelen -+ draadstrippers -+ draagas -+ draagassen -+ draagbaarheid -+ draagdoeken -+ draagkartons -+ draagkrachtverhoudingen -+ draaglast -+ draaglasten -+ draagmier -+ draagmieren -+ draagmoederschap -+ draagplicht -+ draagraketten -+ draagspelden -+ draagtijd -+ draagverbanden -+ draagvleugelboten -+ draagzakken -+ draaicirkels -+ draaidag -+ draaidagen -+ draaideurcrimineel -+ draaideurcriminelen -+ draaihals -+ draaihalzen -+ draaikont -+ draaikonten -+ draailichten -+ draaisnelheid -+ draaistel -+ draaistellen -+ draaitafels -+ draaitopstofzuigers -+ draaitrap -+ draaitrappen -+ draaiuren -+ drag-and-drop -+ dragelijker -+ dragelijkst -+ dragermateriaal -+ dragermaterialen -+ dragerschap -+ draglines -+ dragonazijn -+ dragqueen -+ dragqueens -+ drainagesysteem -+ drainwater -+ drakenvlieger -+ drakenvliegers -+ dramaproductie -+ dramaproducties -+ dramaschrijver -+ dramaschrijvers -+ dramaserie -+ dramaseries -+ dramatici -+ dramatologen -+ dramaturge -+ drammerigheid -+ drankfabrikant -+ drankhandelaar -+ drankkast -+ drankorgels -+ drankvergunningen -+ dreads -+ dreestrekker -+ dreestrekkers -+ dreigingsanalyse -+ dreigingsbeeld -+ dreinerig -+ dreinerige -+ drempelgeld -+ drempelkosten -+ drempelloos -+ drempelloze -+ drempelverlagingen -+ drempelwaarden -+ drentenierde -+ drentenieren -+ dressuurpaard -+ dressuurpaarden -+ dressuurproef -+ dressuurproeven -+ dressuurruiter -+ dressuurruiters -+ drie-eenheid -+ drie-enig -+ drie-enige -+ driebaanswegen -+ driebanden -+ driebandentoernooien -+ driegangenmenu -+ driegangenmenu's -+ driehoeksrelatie -+ driehoog -+ driehoog-achter -+ driejarigen -+ driekaart -+ driekamerflats -+ driekamerparlement -+ driekamerwoningen -+ driekanten -+ drieklapper -+ driekleurendrukken -+ driekwartsmaten -+ drielandenpunt -+ drielandenpunten -+ drieletterwoord -+ drieletterwoorden -+ driepunter -+ driepunters -+ driepuntsgordels -+ driesterrenhotel -+ driesterrenhotels -+ driesterrenkok -+ driesterrenkoks -+ driesterrenrestaurant -+ driesterrenrestaurants -+ driestuiverroman -+ driestuiverromans -+ drietalig -+ drietalige -+ drietonners -+ drietrapsraket -+ drietrapsraketten -+ drievierde -+ driewaardige -+ driewegbox -+ driewegboxen -+ driewegkatalysator -+ driewegkatalysatoren -+ driewegstekkers -+ driewegsysteem -+ driezitsbanken -+ drieëndertigjarig -+ drieëndertigjarige -+ drieëntwintigjarig -+ drieëntwintigjarige -+ driftkikkers -+ driftmatig -+ driftmatige -+ drijfgassen -+ drijfnetten -+ drijfnetvisserij -+ drijfnetvloot -+ drijfnetvloten -+ drijfstangen -+ drinkgewoonte -+ drinkgewoonten -+ drinkgewoontes -+ drinks -+ drinkwaterinstallatie -+ drinkwaterinstallaties -+ drinkwaterverbruik -+ drive-ins -+ drive-inwoning -+ drive-inwoningen -+ driver -+ droedelde -+ droedelen -+ drogeerde -+ drogeladingvaart -+ drogisterijketen -+ drogisterijketens -+ drogredenering -+ drogredeneringen -+ dromerigheid -+ dronkenlap -+ dronkenlappen -+ dronkenman -+ dronkenmannen -+ dronkenmanspraat -+ dronkenmanstaal -+ droogautomaten -+ droogbloem -+ droogbloemen -+ droogboeketten -+ drooggehouden -+ drooggekookt -+ drooggeschoren -+ drooggestapt -+ drooggezwierd -+ drooghouden -+ droogkappen -+ droogkast -+ droogkasten -+ droogkloot -+ droogkloten -+ droogkoken -+ droogkokend -+ droogkokende -+ droogkoker -+ droogkokers -+ droogkuis -+ droogmolens -+ droogneuken -+ droogscheurtje -+ droogshampoos -+ droogstappen -+ droogstoppelig -+ droogstoppelige -+ droogtegevoelig -+ droogtegevoelige -+ droogteperiode -+ droogteschade -+ droogtunnels -+ droogzwierder -+ droogzwierders -+ droogzwieren -+ droomkans -+ droomkansen -+ droomlanden -+ droomloos -+ droomloze -+ droomreizen -+ droomslaap -+ droomstertje -+ droomtoestanden -+ droomuitlegging -+ droomuitleggingen -+ droomwens -+ droomwerelden -+ drop-outs -+ dropdownmenu -+ dropdownmenu's -+ dropkick -+ dropkicks -+ droplul -+ droplullen -+ droppings -+ droste-effect -+ drs. -+ drs.-titel -+ drugbaron -+ drugbende -+ drugbendes -+ drugdealer -+ drugdealers -+ drughonden -+ drugkoerier -+ drugkoeriers -+ drugmaffia -+ drugoverlast -+ drugrunner -+ drugrunners -+ drugsbaron -+ drugsbaronnen -+ drugsbende -+ drugsbendes -+ drugscene -+ drugsdealer -+ drugsdealers -+ drugsdode -+ drugsdoden -+ drugsgerelateerd -+ drugsgerelateerde -+ drugshonden -+ drugskartel -+ drugskartels -+ drugsmaffia -+ drugsmisbruik -+ drugsmokkel -+ drugsoverlast -+ drugsproblemen -+ drugsrunner -+ drugsrunners -+ drugsscene -+ drugssmokkel -+ drugstoerisme -+ drugstoerist -+ drugstoeristen -+ drugstores -+ drugstrafiek -+ drugsverslaving -+ drugsvrij -+ drugsvrije -+ drugtoerisme -+ drugtoerist -+ drugtoeristen -+ druiloorde -+ druipkaarsen -+ druiprekken -+ drukbezocht -+ drukbezochte -+ drukcabines -+ drukdoend -+ drukdoende -+ drukgolf -+ drukgolven -+ drukkersvak -+ drukkingsgroep -+ drukkingsgroepen -+ drukkingsmiddel -+ drukkingsmiddelen -+ drukpan -+ drukpannen -+ drukpunt -+ drukpunten -+ drukring -+ drukringen -+ drukspiegels -+ druktechnisch -+ druktechnische -+ druktoestellen -+ drukvat -+ drukvaten -+ drukverbanden -+ drukverhoging -+ drukwaterreactor -+ drukwaterreactoren -+ drumbands -+ drumpodium -+ drumslag -+ drumslagen -+ drumsolo -+ drumsolo's -+ drumstellen -+ druppelaar -+ druppelaars -+ druppelvormig -+ druus -+ druzen -+ drycleaning -+ ds. -+ dtp -+ dtp-prik -+ dtp-prikken -+ dualiteiten -+ dubbelaar -+ dubbelaars -+ dubbelagent -+ dubbelagenten -+ dubbelalbum -+ dubbelalbums -+ dubbelbaans -+ dubbelbaanse -+ dubbelbeeld -+ dubbelbeelden -+ dubbelblind -+ dubbelblinde -+ dubbelbogey -+ dubbelbogeys -+ dubbelbol -+ dubbelbolle -+ dubbelcheck -+ dubbelchecken -+ dubbelcheckt -+ dubbelcheckte -+ dubbelconcert -+ dubbelconcerten -+ dubbeldekkers -+ dubbeldeksrijtuig -+ dubbeldeksrijtuigen -+ dubbeldekstrein -+ dubbeldekstreinen -+ dubbeldraadse -+ dubbelelpee -+ dubbelelpees -+ dubbelfocusbril -+ dubbelfocusbrillen -+ dubbelfout -+ dubbelfouten -+ dubbelgebeiden -+ dubbelhandig -+ dubbelhandige -+ dubbelheid -+ dubbelleven -+ dubbellevens -+ dubbelloop -+ dubbelloops -+ dubbelloopsgeweren -+ dubbellopen -+ dubbelmandaat -+ dubbelmandaten -+ dubbelnummers -+ dubbelop -+ dubbelparkeerders -+ dubbelrollen -+ dubbelrondig -+ dubbelrondige -+ dubbelslag -+ dubbelspelen -+ dubbelspeler -+ dubbelspelers -+ dubbelspelpartner -+ dubbelspelpartners -+ dubbelstad -+ dubbeltelling -+ dubbeltellingen -+ dubbeltwee -+ dubbeltweeën -+ dubbelwerkend -+ dubbelzout -+ dubbelzoute -+ due diligence -+ duediligenceonderzoek -+ duediligenceonderzoeken -+ duetfragment -+ duetfragmenten -+ duetvorm -+ duffelcoat -+ duffelcoats -+ dug-outs -+ duider -+ duiders -+ duidingen -+ duidingsmagazine -+ duidingsmagazines -+ duifachtig -+ duifachtige -+ duifgrijs -+ duifgrijze -+ duikadres -+ duikadressen -+ duikbootjagers -+ duikbrillen -+ duikersziekte -+ duikmaskers -+ duikplanken -+ duiksprongen -+ duiktoren -+ duiktorens -+ duikuitrustingen -+ duimnagel -+ duimnagels -+ duimzuigers -+ duingebied -+ duingebieden -+ duinlandschappen -+ duinovergangen -+ duinpad -+ duinpaden -+ duinplant -+ duinplanten -+ duinrand -+ duinreservaten -+ duintje -+ duinvallei -+ duinvalleien -+ duinvoet -+ duivel-doet-al -+ duivelinnetje -+ duivelsdrek -+ duivelskermis -+ duivelspact -+ duivelswerk -+ duivenbonen -+ duivenboon -+ duivenkervel -+ duivenklok -+ duivenklokken -+ duizeligmakend -+ duizeligmakende -+ duizendjes -+ duizendvouden -+ duizendwerf -+ dulcinea's -+ dumpingpraktijken -+ dumpplaats -+ dumpplaatsen -+ dumppraktijk -+ dumps -+ dumpschip -+ dundrukken -+ dungesneden -+ dunschillers -+ duobak -+ duobanen -+ duoblokken -+ duodecimo's -+ duopassagiers -+ duovoorzitterschap -+ duplexwoningen -+ duplicaties -+ duplicering -+ duplolampen -+ duppie -+ duppies -+ durfkapitaal -+ duro's -+ dusdoende -+ dutjes -+ duurbetaald -+ duurbetaalde -+ duurloop -+ duurlopen -+ duurrecords -+ duursport -+ duvelstoejagers -+ duwbakken -+ duwboten -+ duwstel -+ duwstellen -+ dvd -+ dvd's -+ dvd-speler -+ dvd-spelers -+ dwaaltochten -+ dwangarbeiderskamp -+ dwangarbeiderskampen -+ dwanggedachte -+ dwanggedachten -+ dwanggedachtes -+ dwangmatige -+ dwangmatigheden -+ dwangnagel -+ dwangnagels -+ dwangneurosen -+ dwangneuroses -+ dwangneurotisch -+ dwangneurotische -+ dwangsommen -+ dwarsdoorsneden -+ dwarsdoorsnedes -+ dwarsdoorsnee -+ dwarsgelegen -+ dwarsgestreept -+ dwarsgestreepte -+ dwarsgezeten -+ dwarshellingen -+ dwarsigheid -+ dwarskrachtcompensatie -+ dwarslaesies -+ dwarsliggerij -+ dwarsprofielen -+ dwarsverband -+ dwarsverbanden -+ dwarsweg -+ dwarswegen -+ dwarszitten -+ dweilorkest -+ dweilorkesten -+ dweilpauzes -+ dweilwagens -+ dwergberk -+ dwergberken -+ dwerggroei -+ dwergstaat -+ dwergstaatje -+ dwergstaten -+ dwergstern -+ dwergsterns -+ dwergvinvis -+ dwergvinvissen -+ dwergvolkeren -+ dwergwerpen -+ dynamischt -+ dynamiseerde -+ dynamometer -+ dynamometers -+ dysartrie -+ débouché -+ débouchés -+ décafeïné -+ déchéance -+ déchéances -+ dégénéreetje -+ dégénérée -+ dégénérées -+ dégénéréetje -+ dégénérés -+ déjà vu's -+ déjà vuutje -+ délégueetje -+ délégué -+ déléguée -+ déléguées -+ délégués -+ döner kebab -+ e's -+ e'tje -+ e-boek -+ e-boeken -+ e-book -+ e-books -+ e-card -+ e-cards -+ e-dentifier -+ e-dentifiers -+ e-handel -+ e-kaart -+ e-kaarten -+ e-mailaccount -+ e-mailaccounts -+ e-mailadres -+ e-mailadressen -+ e-mailde -+ e-mailen -+ e-mails -+ e-mailt -+ e-mailverkeer -+ e-zine -+ e-zines -+ earl grey -+ earlgreythee -+ easy listening -+ easy rider -+ easy riders -+ eau de toilette -+ eau de toiletteje -+ eaux de cologne -+ eaux de toilette -+ eblouissant -+ eblouissante -+ eblouissanter -+ eblouissantst -+ ebo -+ ebstromen -+ ebullioscoop -+ ebullioscopen -+ ecg -+ ecg's -+ echografieën -+ echografische -+ echoloden -+ echopeilingen -+ echoputten -+ echoscopieën -+ echtbreken -+ echtscheidingsproces -+ echtscheidingsrecht -+ echtscheidingszaak -+ echtscheidingszaken -+ ecloge -+ eclogen -+ ecloges -+ ecoaardappelen -+ ecobonus -+ ecobonussen -+ ecoducten -+ ecologisten -+ economenblad -+ economendebat -+ economenvakblad -+ economes -+ economiedebat -+ economiekatern -+ economieleraar -+ economieleraren -+ economiestudie -+ economisch-financieel -+ economisch-financiële -+ economisch-geografisch -+ economisch-geografische -+ economisch-historisch -+ economisch-historische -+ economisch-monetair -+ economisch-monetaire -+ economisch-politiek -+ economisch-politieke -+ economisch-statistisch -+ economisch-statistische -+ economiser -+ economisers -+ ecotoerist -+ ecotoeristen -+ ecrue -+ ecstasy'tje -+ ectoplastische -+ edelen -+ edelkitsch -+ edelmetaal -+ edelmetalen -+ edelstaal -+ ediacara -+ editoriaal -+ editorialen -+ edwardiaans -+ edwardiaanse -+ eedverbonden -+ eeg -+ eeg's -+ eekhoorntjesbrood -+ eemien -+ stief -+ gaans -+ een-na-laatst -+ een-na-laatste -+ een-op-een -+ een-twee-drie -+ een-tweetje -+ een-tweetjes -+ eenaprilgrap -+ eenaprilgrappen -+ eenbaanswegen -+ eendagskuikens -+ eendagstoerisme -+ eendagstoerist -+ eendagstoeristen -+ eendagsvlinder -+ eendagswedstrijd -+ eendagswedstrijden -+ eendelig -+ eendelige -+ eendenborst -+ eendenkroos -+ eendenmosselen -+ eendenmossels -+ eendimensionaal -+ eenendertigde -+ eenendertigen -+ eenentachtigste -+ eenentwintigjarig -+ eenentwintigjarige -+ eenenveertigste -+ eengezinshuis -+ eengezinshuizen -+ eenheidsbeweging -+ eenheidsfront -+ eenheidsgedachte -+ eenheidsklasse -+ eenheidsklassen -+ eenheidspartij -+ eenheidspartijen -+ eenheidspolitie -+ eenheidsstructuur -+ eenheidstaal -+ eenheidstaat -+ eenheidstaten -+ eenklank -+ eenklanken -+ eenkoppig -+ eenkoppige -+ eenmansactie -+ eenmansacties -+ eenmansfractie -+ eenmansfracties -+ eenmanstijdschrift -+ eenmanstijdschriften -+ eenmanszaken -+ eenmeifeest -+ eenmeifeesten -+ eenmotorig -+ eenmotorige -+ eenoudergezin -+ eenoudergezinnen -+ eenpansmaaltijd -+ eenpansmaaltijden -+ eenpartijstaat -+ eenpartijstelsel -+ eenpersoonshuishouden -+ eenpersoonshuishoudens -+ eenpersoonskamers -+ eenprocentsregeling -+ eenregelig -+ eenrichtingsweg -+ eenverdiener -+ eenverdieners -+ eenvrouwsactie -+ eenwordingsverdrag -+ eenzaat -+ eenzaten -+ eerbetuiging -+ eerbetuigingen -+ eerdergenoemd -+ eergisternacht -+ eerstaangewezen -+ eerstedagenvelop -+ eerstedagenveloppen -+ eerstedivisieclub -+ eerstedivisieclubs -+ eerstedivisionist -+ eerstedivisionisten -+ eerstegeneratieallochtonen -+ eerstegeneratieallochtoon -+ eerstegraads -+ eerstegraadsleraars -+ eerstegraadsleraren -+ eerstegrader -+ eerstegraders -+ eerstehulppost -+ eerstehulpposten -+ eersteklas -+ eersteklassertje -+ eerstelijns -+ eerstelijnszorg -+ eersteministerportefeuille -+ eersteprijswinnaar -+ eersteprijswinnaars -+ eerstverantwoordelijk -+ eerstverantwoordelijke -+ eerstverantwoordelijken -+ eerverleden -+ eerwaarden -+ eerwraak -+ eetappel -+ eetappelen -+ eetappels -+ eetcafeetje -+ eetcafé -+ eetcafés -+ eetculturen -+ eetcultuur -+ eetgedrag -+ eetgewoontes -+ eethoeken -+ eetketeltje -+ eetpauze -+ eetpauzes -+ eetpeer -+ eetperen -+ eettenten -+ eeuwhelft -+ eeuwigheidswaarde -+ eeuwwende -+ eeuwwenden -+ effectenkredietinstelling -+ effectentransactie -+ effectentransacties -+ effectmeting -+ effectvol -+ effectvolle -+ efficiencyonderzoek -+ efficiencyoperatie -+ efficiencyoverweging -+ efficiencyoverwegingen -+ efficiencyverbeteringen -+ efficiencywinst -+ efficiëntieverbetering -+ effluenten -+ egalisering -+ egenn. -+ eggheads -+ egodocument -+ egodocumenten -+ egomaniakaal -+ egomaniakale -+ egotrippen -+ egotripperij -+ egotrippers -+ egotrips -+ egoïstes -+ egyptologen -+ eibertje -+ eiceldonatie -+ eideling -+ eidelingen -+ eider -+ eiders -+ eidetische -+ eidooiers -+ eierlepeltjes -+ eiersnijders -+ eierstokkanker -+ eierveilingen -+ eierwarmers -+ eierwekkers -+ eigeel -+ eigele -+ eigenaar-bewoner -+ eigenaar-directeur -+ eigenaars-bewoners -+ eigenaarschap -+ eigenaren-bewoners -+ eigenaren-directeuren -+ eigenaresses -+ eigenbelangen -+ eigendomskwestie -+ eigendomskwesties -+ eigendomspapieren -+ eigendomsstructuur -+ eigengebouwd -+ eigengebouwde -+ eigengeldje -+ eigengereidheid -+ eigenrichting -+ eigenrisicodrager -+ eigenrisicodragers -+ eigensoortig -+ eigensoortige -+ eigenstandige -+ eigentijdsheid -+ eigenwoningbezit -+ eihoofd -+ eihoofden -+ eikeltjeskoffie -+ eikenbladen -+ eikenbladeren -+ eikenbladsla -+ eilandbestuur -+ eilandelijk -+ eilandelijke -+ eilandenstaat -+ eilandenstaten -+ eilandgebieden -+ eilandgevoel -+ eilandhopping -+ eilandrepubliek -+ eilandrepublieken -+ eilandsbestuur -+ eilandsraad -+ eilandstaat -+ eilandstaten -+ eindassemblage -+ eindbedragen -+ eindbestemming -+ eindbestemmingen -+ eindconclusies -+ einddatums -+ einddiploma's -+ einddoelen -+ eindejaar -+ eindejaarspremie -+ eindejaarspremies -+ eindejaarsuitkering -+ eindeloopbaan -+ eindeloopbaanregeling -+ eindeloopbaanregelingen -+ eindeloosheid -+ eindereeks -+ eindereeksen -+ eindes -+ eindexamenklachtenlijn -+ eindexamenklassen -+ eindexamenpakket -+ eindexamenpakketten -+ eindexamenvak -+ eindexamenvakken -+ eindfasen -+ eindfases -+ eindhalten -+ eindhaltes -+ eindheffing -+ eindindruk -+ eindindrukken -+ eindklassementen -+ eindmeet -+ eindmontage -+ eindmontages -+ eindnoteringen -+ eindonderwijs -+ eindoorzaken -+ eindoverwinningen -+ eindproducten -+ eindrangschikking -+ eindrapporten -+ eindredacteurs -+ eindregels -+ eindronden -+ eindrondes -+ eindschot -+ eindsignalen -+ eindsprinten -+ eindsprints -+ eindspurten -+ eindspurts -+ eindstadia -+ eindstrepen -+ eindtijd -+ eindtijden -+ eindtoetsen -+ eindtunes -+ eindtunetje -+ einduitkomsten -+ einduitslagen -+ eindverantwoordelijkheden -+ eindvoorstel -+ eindvoorstellen -+ eindwerk -+ eindzege -+ eindzeges -+ eipoeder -+ eipoeier -+ eischaal -+ eischalen -+ eisenbundel -+ eisenbundels -+ eivlies -+ eivliezen -+ eivorm -+ eiwitarme -+ eiwitgehalte -+ eiwitgehalten -+ eiwitgehaltes -+ eiwithoudend -+ eiwithoudende -+ eiwitsynthese -+ eiwitsynthesen -+ eiwitsyntheses -+ ejaculaten -+ ejectknop -+ ejectknoppen -+ eksternest -+ eksternesten -+ elandtest -+ elastomeren -+ eldorado's -+ elektriciens -+ elektriciteitsmaatschappij -+ elektriciteitsopwekking -+ elektriciteitspanne -+ elektriciteitspannes -+ elektriciteitsproductie -+ elektriciteitsvoorzieningen -+ elektro-encefalograaf -+ elektro-encefalografen -+ elektro-encefalogram -+ elektro-encefalogrammen -+ elektro-oven -+ elektro-ovens -+ elektrocardiografie -+ elektrocardiogrammen -+ elektrochemie -+ elektrochemische -+ elektrocuties -+ elektrofiets -+ elektrofietsen -+ elektrofysiologische -+ elektromonteurs -+ elektronenbundel -+ elektronenbundels -+ elektronenflitsers -+ elektronenkanon -+ elektronenkanonnen -+ elektronenmicroscopen -+ elektronenstroom -+ elektronica-industrie -+ elektronicabranche -+ elektronicasector -+ elektronicawinkel -+ elektronicawinkels -+ elektronici -+ elektroshock -+ elektroshocks -+ elektrostatisch -+ elektrostatische -+ elementairedeeltjesfysica -+ elevatiehoek -+ elevatiehoeken -+ elfde-eeuws -+ elfde-eeuwse -+ elfdelig -+ elfdelige -+ elfenbankje -+ elfenbankjes -+ elfjarig -+ elfjarige -+ elfjuliviering -+ elfjulivieringen -+ elfkoppig -+ elfkoppige -+ elfmaal -+ elfstedenstad -+ elftalbegeleider -+ elftalbegeleiders -+ elftalgenoot -+ elftalgenoten -+ elftalleider -+ elftalleiders -+ elftalspeler -+ elftalspelers -+ eliminering -+ elite-eenheden -+ elite-eenheid -+ elite-universiteit -+ elite-universiteiten -+ elitegroep -+ elitekorps -+ elitescholen -+ eliteschool -+ elitetroepen -+ elizabethaans -+ elizabethaanse -+ ellebogenwerk -+ elleboogblessure -+ elleboogblessuren -+ elleboogblessures -+ elleboogholte -+ elleboogholten -+ elleboogholtes -+ elleboogstoot -+ elleboogstoten -+ ellendes -+ elysisch -+ elysische -+ elzenprop -+ emailleeroven -+ emailleerovens -+ emancipatiebewegingen -+ emancipatiegedachte -+ emancipatiegolf -+ emancipatiestrijd -+ emaneerde -+ emballeerde -+ emblema's -+ emblematabundel -+ emblematabundels -+ embolieën -+ embonpoints -+ embryologen -+ embryologische -+ embryotransplantatie -+ embryotransplantaties -+ emigrantenfamilie -+ emigrantenfamilies -+ emigrantes -+ emigratiebeleid -+ emigratiegolven -+ emigratiepolitiek -+ emigraties -+ emigratieverdrag -+ emigratieverdragen -+ emissie-eis -+ emissie-eisen -+ emissiearm -+ emissiearme -+ emissiebedrijf -+ emissiekoersen -+ emissieleider -+ emissieleiders -+ emissienorm -+ emissienormen -+ emissieprijs -+ emissieprospectus -+ emissieprospectussen -+ emissierecht -+ emissierechten -+ emissiesyndicaat -+ emissiesyndicaten -+ emissietheorie -+ emmerde -+ emmeren -+ emmes -+ emmese -+ emoticon -+ emoticons -+ emotiecultuur -+ emotieloze -+ emotioneerde -+ empathisch -+ empathische -+ empiristische -+ employability -+ emptynestsyndroom -+ emulaties -+ emulgatoren -+ emulgators -+ emulgeerde -+ emulsielagen -+ en détail -+ en masse -+ enantiomorf -+ enantiomorfe -+ encefalogrammen -+ encefalopathie -+ enchilada -+ enchilada's -+ enclaafje -+ enclavetje -+ encyclieken -+ endocriene -+ endocrinologen -+ endogene -+ endoniem -+ endoniemen -+ endoparasiet -+ endoparasieten -+ endoscopen -+ endoscopieën -+ endotherme -+ energie-efficiency -+ energie-efficiënt -+ energie-efficiënte -+ energie-inhoud -+ energie-intensief -+ energie-intensieve -+ energiearm -+ energiebalansen -+ energiebehoefte -+ energiebehoeften -+ energiebehoeftes -+ energiebesparingen -+ energiecrises -+ energiecrisissen -+ energiedrager -+ energiedragers -+ energiekeling -+ energiekelingen -+ energieprijs -+ energieprijzen -+ energieprobleem -+ energieproblemen -+ energierijk -+ energierijke -+ energiesector -+ energiespectrum -+ energiestofwisseling -+ energietechniek -+ energietekort -+ energietekorten -+ energieverliezen -+ energieverslinder -+ energieverslinders -+ energieverspillend -+ energieverspillende -+ energievoorraad -+ energievoorraden -+ energiewetgeving -+ energiezuinig -+ enfants terribles -+ engelenhaar -+ engels -+ enigma's -+ enkelblessure -+ enkelblessuren -+ enkelblessures -+ enkelgewricht -+ enkelgewrichten -+ enkelkous -+ enkelkousen -+ enkellang -+ enkellange -+ enkeloperatie -+ enkeloperaties -+ enkelspelen -+ enkelspeler -+ enkelspelers -+ enkelspelpartij -+ enkelspelpartijen -+ enkelsporige -+ enkelwandige -+ enne -+ enquêtebureau -+ enquêtebureaus -+ enquêteresultaat -+ enquêteresultaten -+ enquêtering -+ enquêteurs -+ enquêtevraag -+ enquêtevragen -+ enquêtrices -+ ensemblecultuur -+ ensembleklank -+ ensemblespel -+ ensemblewerk -+ ententes -+ entertainmentindustrie -+ entertoets -+ enthousiasteling -+ entomologische -+ entr'acten -+ entr'actes -+ entre-deuxtje -+ entrecoteje -+ entreebewijzen -+ entreekaartje -+ entreeprijzen -+ entremetstje -+ entrepreneurs -+ enveloppenfinanciering -+ enveloppetje -+ environments -+ enzymatische -+ eoceen -+ eocene -+ epateerde -+ epauletje -+ epentheses -+ epicentra -+ epidemies -+ epidemiologen -+ epidemiologische -+ epidiascopen -+ epifyten -+ epigrammatische -+ epilepsiebestrijding -+ epilepsiepatiënt -+ epilepsiepatiënten -+ episcopaals -+ episcopaalse -+ epo -+ epochen -+ eponiemen -+ eponiemenwoordenboek -+ epoques -+ epoxyharsen -+ epsilons -+ equalizers -+ equivalenties -+ era's -+ erachteraan -+ erasmiaans -+ erasmiaanse -+ erbovenuit -+ erebaan -+ erecodes -+ erecties -+ eredivisieclub -+ eredivisieclubs -+ eredivisies -+ eredivisionisten -+ eregalerij -+ eregasten -+ erehaag -+ erehagen -+ ereloge -+ eremis -+ eremissen -+ ereorde -+ erepenningen -+ ereplak -+ ereplakken -+ erepodia -+ eresaluten -+ ereschavot -+ eretribunes -+ erezaken -+ erfbeplanting -+ erfbeplantingen -+ erfelijkheidsdrager -+ erfelijkheidsdragers -+ erfelijkheidsmateriaal -+ erfelijkheidsmolecule -+ erfelijkheidsmoleculen -+ erfelijkheidsmolecules -+ erfelijkheidswetten -+ erfenisrecht -+ erfenisrechten -+ erffactor -+ erffactoren -+ erfgenames -+ erfgronden -+ erfopvolgingen -+ erfpachtcontracten -+ erfvredebreuk -+ erfwoning -+ erfwoningen -+ ergerlijkheden -+ ergerniswekkend -+ ergerniswekkende -+ ergheid -+ ergometer -+ ergometers -+ ergonomen -+ ergotherapeuten -+ erkenningsregeling -+ erkertje -+ erogene -+ eros -+ eroscentra -+ eroscentrum -+ erosiebestrijding -+ erosiegevoelig -+ erosiegevoelige -+ erosiemateriaal -+ erotiseerde -+ erotogene -+ erotomanen -+ ertsoverslagbedrijf -+ eruitgezien -+ ervaarbare -+ ervaringsdeskundigen -+ ervaringsfeiten -+ ervaringsgegeven -+ ervaringsgegevens -+ ervaringskennis -+ ervaringsregel -+ ervaringsregels -+ ervaringswerelden -+ erving -+ erwtje -+ erytropoëtine -+ esc-toets -+ esc-toetsen -+ escalatieladder -+ escalaties -+ escalope -+ escalopes -+ escapetoets -+ escapisten -+ escargot -+ escortgirl -+ escortgirls -+ escorts -+ escudo's -+ eskimoteerde -+ eskimoteren -+ espada's -+ espadrilles -+ esplanaden -+ esplanades -+ espresso's -+ espressoapparaat -+ espressoapparaten -+ espressobar -+ espressobars -+ essaybundel -+ essaybundels -+ essayistische -+ essayprijs -+ essaytje -+ essaywedstrijd -+ essenen -+ essentialistische -+ estafetteactie -+ estafetteacties -+ estafettelopen -+ estafettestaking -+ estafettestakingen -+ estafettestokje -+ esters -+ esthetiseerde -+ esthetisering -+ estuaria -+ estuarien -+ estuariene -+ estuariën -+ et alii -+ et-teken -+ et-tekens -+ etagebos -+ etagebossen -+ etalagebenen -+ etalagist -+ etalagisten -+ etappekoers -+ etappekoersen -+ etappeplaats -+ etappeplaatsen -+ etappetje -+ etappewedstrijd -+ etappewedstrijden -+ etappewinst -+ etappezeges -+ etensbak -+ etensbakken -+ etensgeur -+ etensgeuren -+ etenslucht -+ etensluchten -+ etensrest -+ ethaan -+ ethergolf -+ ethernetkaart -+ ethernetkaarten -+ ethernetmodem -+ ethernetmodems -+ etheromroep -+ ethici -+ ethologen -+ ethologische -+ etikettering -+ etiketteringen -+ etiolement -+ etiquetteboek -+ etiquetteboeken -+ etnocentrische -+ eto -+ etsplaten -+ etstechniek -+ etters -+ eucalyptusolie -+ euforische -+ eukaryote -+ eukaryoten -+ euritmie -+ euro-enthousiasme -+ euro-obligatie -+ euro-obligatiemarkt -+ euro-obligaties -+ euroambtenaar -+ euroambtenaren -+ eurobiljet -+ eurobiljetten -+ eurocenten -+ eurocentrische -+ eurocheque -+ eurocheques -+ eurocommunisme -+ eurocraten -+ eurodollar -+ eurodollars -+ eurofles -+ euroflessen -+ eurolening -+ euroleningen -+ euroloodvrij -+ euroloodvrije -+ euromarkt -+ europeaniseerde -+ europeaniseren -+ europeanisering -+ europide -+ eurorente -+ euroscepsis -+ euroverpakking -+ euroverpakkingen -+ eurovignet -+ euthanaseerde -+ euthanaseren -+ euthanasiedebat -+ euthanasiedebatten -+ euthanasiediscussie -+ euthanasieregeling -+ euthanasieverklaring -+ euthanasieverklaringen -+ euthanasievraagstuk -+ euthanasiewet -+ eutrofiëring -+ eva's -+ evaatje -+ evacuatiebevel -+ evacuatiebevelen -+ evacuatieplan -+ evacuatieplannen -+ evacuaties -+ evaluatiemethode -+ evaluatiemethoden -+ evaluatiemethodes -+ evaluatienota -+ evaluatienota's -+ evaluatieve -+ evangeliaria -+ evangeliariums -+ evangeliebediening -+ evangeliebedieningen -+ evaporeerde -+ evenaring -+ evenementenhal -+ evenementenhallen -+ evenhoevig -+ evenhoevige -+ evenredigheidsbeginsel -+ evenwaardig -+ evenwichtsbalken -+ evenwichtsbemesting -+ evenwichtsgevoel -+ evenwichtskunst -+ evenwichtskunstenaar -+ evenwichtskunstenaars -+ evenwichtssituatie -+ evenwichtssituaties -+ evenwichtstoestand -+ evergreens -+ evidenties -+ evocaties -+ evolutiebiologen -+ evolutiebiologie -+ evolutiebioloog -+ evolutieproces -+ evolutietheorieën -+ evolutionisten -+ evolutionistische -+ evoqueerde -+ ex tempore -+ ex tempore's -+ ex voto's -+ ex votootje -+ ex-Kamerleden -+ ex-Kamerlid -+ ex-PTT'er -+ ex-agent -+ ex-agenten -+ ex-burgemeesters -+ ex-cathedraonderwijs -+ ex-collega's -+ ex-collegae -+ ex-echtgenoten -+ ex-echtgenotes -+ ex-gedetineerde -+ ex-internationals -+ ex-mannen -+ ex-ministers -+ ex-nazi -+ ex-nazi's -+ ex-partner -+ ex-partners -+ ex-premier -+ ex-premiers -+ ex-profs -+ ex-provo -+ ex-provo's -+ ex-soldaat -+ ex-soldaten -+ ex-staatssecretarissen -+ ex-vicepremier -+ ex-vicepremiers -+ ex-vrouw -+ ex-vrouwen -+ ex-wethouders -+ examencijfer -+ examencijfers -+ exameneis -+ exameneisen -+ examenkandidaat -+ examenkandidaten -+ examenpakketten -+ examenreglementen -+ examenvakken -+ examenvraag -+ examenwerk -+ examenzittijd -+ examenzittijden -+ examinanda's -+ examinering -+ excarnatie -+ excentriekelingen -+ excitaties -+ exciteerde -+ excreties -+ excusabele -+ excuusbrief -+ excuusbrieven -+ excuustruus -+ excuustruzen -+ executieplaats -+ executieplaatsen -+ executieven -+ executieverkopen -+ executieves -+ exegesen -+ exegeses -+ exen -+ exequaturs -+ exercitieterrein -+ exercitieterreinen -+ exhaustieve -+ exhibitionisten -+ exhumatie -+ exhumaties -+ existentialisten -+ existentiefilosofen -+ existentiefilosofie -+ existentiefilosoof -+ existenties -+ exitgesprek -+ exitgesprekken -+ exitinterview -+ exitinterviews -+ exitpoll -+ exitpolls -+ exodussen -+ exogene -+ exorcisten -+ exoten -+ exotherme -+ expansiebeleid -+ expansiedrang -+ expansiedrift -+ expansieplan -+ expansieplannen -+ expansionistische -+ expat -+ expatrieerde -+ expats -+ expeditiebedrijf -+ expeditieknooppunt -+ expeditieknooppunten -+ expeditieleger -+ expeditielegers -+ expeditieleider -+ expeditieleiders -+ expeditielid -+ expeditionaire -+ experimentalisten -+ experimentatoren -+ experimenteerdrift -+ experimenteerscholen -+ experimenteerschool -+ experten -+ expertisecentra -+ expertisecentrum -+ expertje -+ expiratiedata -+ expiratiedatum -+ expletieve -+ explicateurs -+ explicitering -+ expliciteringen -+ exploitabele -+ exploitatiebudget -+ exploitatiebudgetten -+ exploitatiemaatschappij -+ exploitatieopzet -+ exploitatieopzetten -+ exploitatierecht -+ exploitatierechten -+ exploitatietekorten -+ exploitatieverlies -+ exploitatieverliezen -+ exploitatiewinst -+ exploitatiewinsten -+ exploratieactiviteit -+ exploratieactiviteiten -+ exploratieboring -+ exploratieboringen -+ exploratiefase -+ exploratievergunning -+ exploratievergunningen -+ expo -+ expo's -+ exportbepaling -+ exportbepalingen -+ exportgerichte -+ exportkredietverzekering -+ exportkredietverzekeringen -+ exportmanager -+ exportmanagers -+ exportmarkt -+ exportmarkten -+ exportstop -+ exportvergunning -+ exportvergunningen -+ exportvolumes -+ expositieruimte -+ expositieruimten -+ expositieruimtes -+ expositieterrein -+ expositieterreinen -+ expressiemiddel -+ expressiemogelijkheden -+ expressiemogelijkheid -+ expressievorm -+ expressievormen -+ expresweg -+ expreswegen -+ exquise -+ extasen -+ extended family -+ extensiveerde -+ extensivering -+ extincties -+ extirpaties -+ extracellulaire -+ extranet -+ extrapolaties -+ extrasystolen -+ extrasystoles -+ extraterritoriale -+ exuberanties -+ eyeliners -+ eyeopener -+ eyeopeners -+ ezelkar -+ ezelkarren -+ ezelskar -+ ezelskarren -+ eïs -+ f'en -+ f'je -+ f's -+ fa's -+ fabeldieren -+ fabricaat -+ fabricagehal -+ fabricagehallen -+ fabricagemethode -+ fabricagemethoden -+ fabricagemethodes -+ fabricaten -+ fabrieksdirecteur -+ fabrieksdirecteuren -+ fabrieksfout -+ fabrieksfouten -+ fabriekshal -+ fabriekshallen -+ fabrieksloods -+ fabrieksloodsen -+ fabrieksmeisje -+ fabrieksmeisjes -+ fabriekspand -+ fabriekspanden -+ fabriekspersoneel -+ fabriekspoort -+ fabriekspoorten -+ fabrieksschouw -+ fabrieksschouwen -+ fabriekssluiting -+ fabriekssluitingen -+ fabrieksterrein -+ fabrieksterreinen -+ fabuleerde -+ face-offs -+ face-à-mains -+ faceliften -+ facelifts -+ faceliftte -+ facetbeleid -+ faciliteitengemeente -+ faciliteitengemeenten -+ faciliteitengemeentes -+ faciliteitenregeling -+ facits -+ facsimile-uitgave -+ facsimile-uitgaven -+ factieleider -+ factieleiders -+ factiestrijd -+ factoranalyses -+ factoringmaatschappij -+ factureermachines -+ factuurplicht -+ faculteitsbestuurder -+ faculteitsbestuurders -+ faculteitsgebouw -+ faculteitsgebouwen -+ faculteitskring -+ faculteitskringen -+ fade-outs -+ fadede uit -+ fadet uit -+ fado's -+ fadozangeres -+ fadozangeressen -+ fagocyten -+ faillissementscurator -+ faillissementscuratoren -+ faillissementsrechtbank -+ faillissementsrechtbanken -+ faillissementsrechter -+ faillissementsrechters -+ faillissementswetgeving -+ fairways -+ faket -+ fakete -+ fakkeloptochten -+ falafel -+ falafels -+ falangisten -+ faling -+ falingen -+ fallische -+ fallocratieën -+ fallussen -+ fallussymbolen -+ fallussymbool -+ falsificeerde -+ falsifieerbaar -+ falsifieerbare -+ falsifiëringen -+ familiaire -+ familiales -+ familie-uitje -+ familie-uitjes -+ familiealbum -+ familiealbums -+ familiebezit -+ familiebezoeken -+ familiebijbel -+ familiebijbels -+ familieblad -+ familiebladen -+ familieboekje -+ familieboekjes -+ familiefilms -+ familiegeschiedenissen -+ familiehulp -+ familiekroniek -+ familieportretten -+ familierechtelijk -+ familiereünies -+ familievermogen -+ familiezilver -+ fanaten -+ fanatisch -+ fanatische -+ fanclubs -+ fancy fair -+ fancy fairs -+ fancyartikelen -+ fancyartikels -+ fandango's -+ fanfaretje -+ fantasia's -+ fantasiedier -+ fantasiedieren -+ fantasiefiguren -+ fantasiefiguur -+ fantasieloosheid -+ fantasienamen -+ fantasierijker -+ fantasierijkst -+ fantasiestof -+ fantasiestoffen -+ fantasievol -+ fantasievolle -+ fantasiewereld -+ fantasiewerelden -+ fantasy -+ fantasyboek -+ fantasyboeken -+ fantoompijn -+ fantoompijnen -+ faraootje -+ farizeeën -+ farizeeërs -+ farizese -+ farmaciebedrijf -+ farmacologen -+ farootje -+ faryngalen -+ fascinaties -+ fasegewijs -+ fasegewijze -+ faseringen -+ fastbacks -+ fastfood -+ fastfoodketen -+ fastfoodketens -+ fastfoodrestaurant -+ fastfoodrestaurants -+ fata morgana's -+ fatsoensnorm -+ fatsoensnormen -+ fatsoensrakkerij -+ fauna's -+ faunabeheer -+ faunavervalsing -+ faustiaans -+ faustiaanse -+ fauvisten -+ fauvistische -+ favorabele -+ favorietenrol -+ favorietes -+ faxapparaat -+ faxapparaten -+ faxapparatuur -+ faxbericht -+ faxberichten -+ faxmachine -+ faxmachines -+ faxmodem -+ faxmodems -+ faxnummers -+ façadebouw -+ features -+ fecale -+ fedajien -+ federaliseerde -+ federalisering -+ federatieverdrag -+ federatieverdragen -+ federatievoorzitter -+ federatievoorzitters -+ federeerde -+ feelgoodfactor -+ feelgoodfilm -+ feelgoodfilms -+ feestartikel -+ feestartikelenwinkels -+ feestbundels -+ feestcommissies -+ feestdiners -+ feestjurk -+ feestjurken -+ feestkleding -+ feestneuzen -+ feeststemming -+ feesttenten -+ feestweken -+ feilloost -+ feillozer -+ felbegeerd -+ felbegeerde -+ felgeel -+ felgele -+ felicitatietelegram -+ felicitatietelegrammen -+ fellaga -+ fellaga's -+ fellahs -+ fellatio -+ felnationalistisch -+ felnationalistische -+ feloek -+ feloeka -+ feloeka's -+ feloeken -+ feloeks -+ felverlicht -+ felverlichte -+ femels -+ feminiene -+ feminisering -+ femmes fatales -+ fennek -+ fenneken -+ fenneks -+ fenoloplossing -+ fenoloplossingen -+ fenomenologen -+ fenotypen -+ fenotypes -+ fermetje -+ fermettes -+ fermheid -+ feromonen -+ ferrietantennes -+ ferromagnetische -+ ferry's -+ fertilisaties -+ ferventer -+ ferventst -+ festivalcatalogi -+ festivalcatalogus -+ festivalcatalogussen -+ festivalcircuit -+ festivalganger -+ festivalgangers -+ festivalkrant -+ festivalkranten -+ fetakaas -+ fetisje -+ fetisjisten -+ fetisjistische -+ feuilletonvorm -+ feuten -+ fiancee -+ fiancees -+ fianceetje -+ fiancé -+ fiancés -+ fibers -+ fibreuze -+ fibrillaties -+ fibrilleerde -+ fibrillen -+ fibromen -+ fibula's -+ fibulae -+ fichebak -+ fichebakken -+ fichedozen -+ fichier -+ fichiers -+ fichu's -+ fictionaliseerde -+ ficussen -+ fideï-commissen -+ fiduciaires -+ fieldde -+ fielder -+ fielders -+ fierljeppen -+ fierljepte -+ fietsafstand -+ fietsbroek -+ fietsbroeken -+ fietscros -+ fietscrossen -+ fietscrost -+ fietscroste -+ fietseling -+ fietselingen -+ fietsendieven -+ fietsenfabrikant -+ fietsenkelder -+ fietsenkelders -+ fietsenmakers -+ fietsenwinkel -+ fietsenwinkels -+ fietsersbond -+ fietsframe -+ fietsframes -+ fietshelm -+ fietshelmen -+ fietskamperen -+ fietskar -+ fietskarren -+ fietskettingen -+ fietsklemmen -+ fietsongeval -+ fietsongevallen -+ fietsplaat -+ fietsplaten -+ fietsrouten -+ fietsroutes -+ fietssleuteltje -+ fietssloten -+ fietsstroken -+ fietssturen -+ fietstassen -+ fietstunnel -+ fietstunnels -+ fietsvakantie -+ fietsvakanties -+ fietswielen -+ fietszoektocht -+ fietszoektochten -+ fifties -+ figaro's -+ fightingspirit -+ figurantenrol -+ figurantenrollen -+ figurantes -+ figuurdans -+ figuurdansen -+ figuurnaden -+ figuurstudies -+ figuurstuk -+ figuurstukken -+ figuurzaagde -+ fijnbankwerker -+ fijnbankwerkers -+ fijnbesneden -+ fijngesneden -+ fijngesnipperd -+ fijngesnipperde -+ fijngoed -+ fijnkorrelige -+ fijnkost -+ fijnpapier -+ fijnschilder -+ fijnschilders -+ fijnschrijver -+ fijnschrijvers -+ fijnsnijden -+ fijnspar -+ fijnsparren -+ fijnvoelend -+ fijnvoelende -+ fikfakkerijen -+ fikkies -+ fikste -+ filaria -+ filariasis -+ fileermes -+ fileermessen -+ filemelding -+ filemeldingen -+ fileparkeren -+ fileprobleem -+ fileproblemen -+ filet americain -+ filetje -+ filiaalchefs -+ filiaties -+ filibusters -+ filigrammen -+ filippica's -+ filisterdom -+ filmacademies -+ filmapparaat -+ filmapparaten -+ filmarchieven -+ filmbeeld -+ filmbewerkingen -+ filmblad -+ filmbladen -+ filmblik -+ filmblikken -+ filmbreedte -+ filmbreedten -+ filmbreedtes -+ filmcamera's -+ filmcarrière -+ filmcritici -+ filmcriticus -+ filmdebuut -+ filmdistributeur -+ filmdistributeurs -+ filmdiva's -+ filmdoeken -+ filmdruk -+ filmfan -+ filmfans -+ filmhistorici -+ filmhistoricus -+ filmjournaals -+ filmjournalisten -+ filmklassieker -+ filmklassiekers -+ filmkomiek -+ filmkomieken -+ filmkritieken -+ filmkunde -+ filmkunstenaar -+ filmkunstenaars -+ filmliefhebber -+ filmliefhebbers -+ filmliga's -+ filmmaatschappij -+ filmmusea -+ filmmuseum -+ filmografieën -+ filmopnames -+ filmpers -+ filmploegen -+ filmportret -+ filmportretten -+ filmproductie -+ filmproducties -+ filmprojectors -+ filmregisseurs -+ filmscenario's -+ filmscripts -+ filmserie -+ filmseries -+ filmset -+ filmsets -+ filmstroken -+ filmstrook -+ filmtaal -+ filmtechniek -+ filmtheaters -+ filmtijdschrift -+ filmtijdschriften -+ filmtitel -+ filmtitels -+ filmvertoning -+ filmvertoningen -+ filmvoorstellingen -+ filmzaaltje -+ filmzonnen -+ filosofe -+ filosofes -+ filosofiegeschiedenis -+ filosofiegeschiedenissen -+ filosofieles -+ filosofielessen -+ filosofiestudent -+ filosofiestudenten -+ filosofiestudie -+ filterinstallatie -+ filterinstallaties -+ filterzakjes -+ filtreerbaar -+ filtreerbare -+ finalematch -+ finalematchen -+ finalematches -+ finalen -+ finaleplaats -+ finaleplaatsen -+ finalepoule -+ finaleronde -+ finaleronden -+ finalerondes -+ finalewedstrijd -+ finalewedstrijden -+ finaliseerde -+ finaliseren -+ financieel-economisch -+ financieel-economische -+ financieel-monetair -+ financieel-monetaire -+ financieel-technisch -+ financieel-technische -+ financierbaar -+ financierbaarheid -+ financierbare -+ financieringsarrangement -+ financieringsarrangementen -+ financieringsbedrijf -+ financieringsinstelling -+ financieringsinstellingen -+ financieringsmodel -+ financieringsmodellen -+ financieringsovereenkomst -+ financieringsovereenkomsten -+ financieringsoverschot -+ financieringsplan -+ financieringsplannen -+ financieringsstelsel -+ financieringsstelsels -+ financieringstekort -+ financieringstekorten -+ financieringswijzen -+ fineerplaten -+ fineliners -+ finetune -+ finetunede -+ finetunen -+ finetunet -+ finetuning -+ fingerspitzengefühl -+ finishdoek -+ finishfoto's -+ finishlijn -+ finishplaats -+ finlandisering -+ finoegrist -+ finoegristen -+ finoegristiek -+ finummer -+ finummers -+ fiooltje -+ firewall -+ firewalls -+ firmanaam -+ firmanamen -+ firmawagen -+ firmawagens -+ first lady -+ first lady's -+ first out -+ fiscaal-economisch -+ fiscaal-economische -+ fiscaaltechnisch -+ fiscaaltechnische -+ fiscaliseerde -+ fiscalisering -+ fiscalisten -+ fistfuck -+ fistfucken -+ fistfuckt -+ fistfuckte -+ fit-o-meters -+ fitheid -+ fitnes -+ fitnessapparatuur -+ fitnesscentra -+ fitnessclub -+ fitnessclubs -+ fitnessen -+ fitnessrage -+ fitnessruimten -+ fitnessruimtes -+ fitnessstudio -+ fitnessstudio's -+ fitnesstraining -+ fitnest -+ fitneste -+ fitsen -+ fjordenpaard -+ fjordenpaarden -+ flageolets -+ flagstones -+ flakkering -+ flakkeringen -+ flambeerde -+ flamencogitaar -+ flamencogitaren -+ flamingo's -+ flamoes -+ flamoezen -+ flandrien -+ flandriens -+ flanelsteek -+ flanelsteken -+ flaneurs -+ flankerend -+ flankerende -+ flankspeler -+ flankspelers -+ flap-overs -+ flapdrol -+ flapdrollen -+ flaporen -+ flapperde -+ flapperen -+ flaptekst -+ flapteksten -+ flapuits -+ flashbacks -+ flashbericht -+ flashberichten -+ flashes -+ flashlight -+ flashlights -+ flat character -+ flatbewoner -+ flatbewoners -+ flatcomplex -+ flatcomplexen -+ flati -+ flatneurosen -+ flatneuroses -+ flatscreen -+ flatscreens -+ flatteuze -+ flatulenties -+ flatussen -+ fleece -+ fleeces -+ fleetrace -+ fleetracen -+ fleetracet -+ fleetracete -+ flensen -+ flenste -+ flesgroen -+ flesgroene -+ flesopeners -+ flessenbier -+ flessenborstel -+ flessenborstels -+ flessengas -+ flessengroen -+ flessengroene -+ flessenhalzen -+ flessenkinderen -+ flessenopener -+ flessenopeners -+ fleste -+ flexibiliseerde -+ flexibilisering -+ flexiemorfeem -+ flexiemorfemen -+ flexikoker -+ flexwerk -+ flexwerken -+ flexwerker -+ flexwerkers -+ flexwet -+ flierefluiten -+ flightrecorder -+ flightrecorders -+ flikflak -+ flikflakken -+ flikflaks -+ flinkerds -+ flinterig -+ flinterige -+ flip-overs -+ flipperautomaten -+ flipperde -+ flipperkasten -+ flippers -+ flirts -+ flitsapparaat -+ flitsapparaten -+ flitsblokjes -+ flitskapitaal -+ flitslamp -+ flitslampen -+ flitslichten -+ flitspaal -+ flitspalen -+ flitstijden -+ flitstrein -+ flitstreinen -+ flitte -+ flitten -+ flobertje -+ flodderjurken -+ floddertje -+ floodlights -+ floormanagers -+ floorshows -+ flopje -+ floppydisks -+ flops -+ flopte -+ flora's -+ florale -+ floraliën -+ floridawater -+ florist -+ floristen -+ floristische -+ floss -+ flost -+ flowcharts -+ fluctuatiemarge -+ fluctuatiemarges -+ fluisterstil -+ fluisterstille -+ fluistertoon -+ fluisterzacht -+ fluisterzachte -+ fluitconcerten -+ fluitjesbier -+ fluitjesmelk -+ fluitregisters -+ fluitsignaal -+ fluitsignalen -+ fluitsolo -+ fluitsolo's -+ flukse -+ fluorescentlamp -+ fluorescentlampen -+ fluorideerde -+ fluorwaterstof -+ fluviatiele -+ fly-drive -+ fly-drivevakantie -+ fly-drivevakanties -+ fly-overs -+ flûte -+ flûteje -+ flûtes -+ fnuikende -+ fobieën -+ foerageergebieden -+ foert -+ foetale -+ foetsies -+ foetushouding -+ foezelde -+ foezelen -+ foezelig -+ foezelige -+ fokhengsten -+ fokkenisten -+ fokkenmaats -+ fokkenmasten -+ fokkenmaten -+ fokmateriaal -+ fokpaarden -+ foksia's -+ fokverbod -+ fokzeug -+ fokzeugen -+ folio's -+ foliumzuur -+ folk -+ folkclub -+ folkclubs -+ folkgroep -+ folkgroepen -+ folkmuziek -+ folkrock -+ folkrockgroep -+ folksongs -+ folkzanger -+ folkzangeres -+ folkzangeressen -+ folkzangers -+ folliculaire -+ follikels -+ follow-ups -+ folterpraktijken -+ fondsbestuur -+ fondsbrillen -+ fondsenwerving -+ fondude -+ fondues -+ fondueset -+ fonduesets -+ fonduestel -+ fonduestellen -+ fonduevorken -+ fonetici -+ fonische -+ fonografische -+ fonotheken -+ foodprocessors -+ fooienpotten -+ footloose -+ fopduik -+ fopmiddel -+ fopper -+ foppers -+ fopsigaar -+ fopsigaren -+ force majeure -+ forechecking -+ forehands -+ forensengemeente -+ forensengemeenten -+ forensentrein -+ forensentreinen -+ forensenverkeer -+ forfaitcijfers -+ forfaitje -+ forfaits -+ forfaitscore -+ forfaitscores -+ forinten -+ form -+ formaliseringen -+ formanten -+ formatieberaad -+ formatiebudgetsysteem -+ formatieplaatsen -+ formatiepogingen -+ formatievliegen -+ formats -+ formeel-juridisch -+ formeel-juridische -+ formicatafel -+ formicatafels -+ formicatafeltje -+ formuleerbaar -+ formuleerbare -+ formulewagen -+ formulewagens -+ formuliergebeden -+ forst -+ fortepianisten -+ fortepiano -+ fortepiano's -+ forti -+ fortissimi -+ fortissimo's -+ fortnight -+ fortnights -+ forto's -+ fortuynisme -+ fortuynist -+ fortuynisten -+ forumdiscussies -+ forumleden -+ forumlid -+ fosburyflop -+ fosfaatgehalten -+ fosfaatlozing -+ fosfaatlozingen -+ fosfaatnorm -+ fosfaatnormen -+ fosfaatverzadigd -+ fosfaatverzadigde -+ fosfaatwinning -+ fosforbom -+ fosforbommen -+ fosforgranaat -+ fosforgranaten -+ fossa -+ fossa's -+ fossielenjager -+ fossielenjagers -+ foto-elektrisch -+ foto-elektrische -+ foto-impressie -+ foto-impressies -+ foto-onderschrift -+ foto-onderschriften -+ foto-opname -+ foto-opnamen -+ foto-opnames -+ fotoagentschap -+ fotoagentschappen -+ fotoarchieven -+ fotoboeken -+ fotobureaus -+ fotocamera -+ fotocamera's -+ fotocellen -+ fotochemische -+ fotoclubs -+ fotocollage -+ fotofinishes -+ fotofobie -+ fotofuck -+ fotofucken -+ fotofuckt -+ fotofuckte -+ fotografencollectief -+ fotografes -+ fotogrammen -+ fotohandels -+ fotohoekje -+ fotohoekjes -+ fotojournalistiek -+ fotokaart -+ fotokaarten -+ fotokopieerapparaten -+ fotolamp -+ fotolithografie -+ fotomateriaal -+ fotomechanische -+ fotonegatief -+ fotonegatieven -+ fotopagina -+ fotopagina's -+ fotopersbureaus -+ fotoredacteur -+ fotoredacteuren -+ fotoreportages -+ fotorolletje -+ fotorolletjes -+ fotoroman -+ fotoromans -+ fotosafari's -+ fotosessies -+ fotosfeer -+ fotoshop -+ fotoshoppen -+ fotoshopt -+ fotoshopte -+ fotosynthese -+ fotosynthetische -+ fototechnisch -+ fototechnische -+ fototherapie -+ fototrope -+ fotoverkenningen -+ fotoverkenningsvliegtuig -+ fotoverkenningsvliegtuigen -+ fotoverslag -+ fotoverslagen -+ fotowedstrijden -+ fotozaken -+ fotozetmachines -+ fotozetten -+ fouillering -+ fouilleringen -+ fouilleringsbevoegdheid -+ foundations -+ fourwheeldrive -+ fourwheeldrives -+ foutenpercentage -+ foutenpercentages -+ foutgeparkeerd -+ foutlijn -+ foutlijnen -+ foutmarge -+ foutmarges -+ foutparkeerder -+ foutparkeerders -+ foutparkeren -+ foutslag -+ foutslagen -+ fractiediscipline -+ fractiedwang -+ fractiegenote -+ fractiegenoten -+ fractiegenotes -+ fractiekamer -+ fractiekamers -+ fractieleidster -+ fractieleidsters -+ fractielid -+ fractiemedewerker -+ fractiemedewerkers -+ fractieoverleg -+ fractiespecialist -+ fractiespecialisten -+ fractievoorlichter -+ fractievoorlichters -+ fractievoorzitters -+ fractionering -+ fragmentariseerde -+ fragmentarisering -+ fragmentatiebommen -+ fragmentering -+ frambozenbier -+ franchisede -+ franchiseformule -+ franchiseketen -+ franchiseketens -+ franchisen -+ franchisenemer -+ franchisenemers -+ franchiseorganisatie -+ franchiset -+ franchisevestiging -+ franchisevestigingen -+ francje -+ francofiele -+ francofielen -+ francofone -+ francs-tireurs -+ frangipanes -+ franjeaap -+ franjeapen -+ franjeloos -+ franjeloze -+ frankeerwaarde -+ franken -+ fransmanbirambi -+ fransmanbirambi's -+ fransmans -+ fransoos -+ fransozen -+ frappen -+ fraseringen -+ fraudeaanpak -+ fraudebestendig -+ fraudebestendige -+ fraudebestrijding -+ fraudegevoelig -+ fraudegevoelige -+ fraudeofficier -+ fraudeofficieren -+ fraudeteam -+ fraudeteams -+ frazelde -+ frazelen -+ freakt -+ freakte -+ freatische -+ free kick -+ free kicks -+ freefight -+ freefighten -+ freejazz -+ freelancejournalist -+ freelancejournalisten -+ freelancen -+ freelancet -+ freelancete -+ freestyle -+ freestylede -+ freestylen -+ freestyleskiën -+ freestylet -+ freewheel -+ freewheelde -+ freewheelt -+ fregatkapitein -+ fregatkapiteins -+ freinetonderwijs -+ frenetieke -+ freonen -+ frequently asked question -+ fresco's -+ fresiaatje -+ fret3 -+ fretloos -+ fretloze -+ frets -+ fretzaag -+ fretzagen -+ freudiaan -+ freudianen -+ fricasseetje -+ fricatieven -+ frictieplaten -+ fries -+ frietketel -+ frietketels -+ frietkot -+ frietkoten -+ frietkotten -+ frietkraampje -+ frietkramen -+ friettenten -+ friezen -+ frigidaires -+ frigo -+ frigo's -+ frigobox -+ frigoboxen -+ frigoboxtoerist -+ frigoboxtoeristen -+ frikandel -+ frikandellen -+ frikandelletje -+ frikkerige -+ frisbeede -+ frisbees -+ frisbeet -+ frisbeeën -+ frisco's -+ frisgewassen -+ frisgroen -+ frisgroene -+ frisismen -+ frisisten -+ frisistiek -+ friteuses -+ frituurde -+ frituurinstallatie -+ frituurinstallaties -+ frituurpannen -+ frivolités -+ frommelig -+ frommelige -+ frontdesk -+ frontdesks -+ frontgebied -+ frontgebieden -+ frontlijnstaten -+ frontlinies -+ frontnieuws -+ frontpagina's -+ frontpassage -+ frontpassages -+ frontsoldaat -+ frontsoldaten -+ frontspoilers -+ frontvorming -+ frotteerde -+ froufroutje -+ fruit- en tuinafval -+ fruitafval -+ fruitautomaten -+ fruitcorso's -+ fruitige -+ fruitkorf -+ fruitkorven -+ fruitkwekers -+ fruitmachine -+ fruitmachines -+ fruitmanden -+ fruitmessen -+ fruitpap -+ fruits de mer -+ fruitsap -+ fruitteelt -+ fruitteler -+ fruittelers -+ fruitveiling -+ fruitveilingen -+ fruitvlieg -+ fruitvliegen -+ frul -+ frullen -+ frulletje -+ frummelde -+ frummelen -+ frunniken -+ frunnikte -+ frust -+ frusten -+ frustratietolerantie -+ frutseltje -+ frutti di mare -+ fröbelwerk -+ ftaalzuur -+ ftp -+ ftp'de -+ ftp'en -+ ftp't -+ fuchsia's -+ fugatische -+ fuikwerking -+ full colour -+ full house -+ full houses -+ fullcolourdruk -+ fulltimers -+ fulminante -+ functie-eis -+ functie-eisen -+ functieaanduiding -+ functieaanduidingen -+ functieanalyses -+ functiebeoordelingen -+ functieloos -+ functieonderzoeken -+ functiestoornis -+ functiestoornissen -+ functietheorie -+ functieverlies -+ functiewaarderingen -+ functiewaarderingsstelsel -+ functiewoord -+ functiewoorden -+ functionalisten -+ functionalistische -+ functionaliteiten -+ functionering -+ funderingsbalk -+ funderingsbalken -+ funderingsprobleem -+ funderingsproblemen -+ funderingsputten -+ funderingswerkzaamheden -+ fundi's -+ funeraire -+ funeraria -+ fungi -+ fungiciden -+ funkband -+ funkbands -+ funkbas -+ funkgroep -+ funkgroepen -+ funkmuziek -+ funkrock -+ funshop -+ funshoppen -+ funshopt -+ funshopte -+ fusees -+ fusie-energie -+ fusiebericht -+ fusieberichten -+ fusiegemeente -+ fusiegemeenten -+ fusieonderhandelingen -+ fusieplan -+ fusieplannen -+ fusiereactor -+ fusiereactoren -+ fusion -+ fusioneerde -+ fusionmuziek -+ fustages -+ futon -+ futons -+ futurologen -+ futurologische -+ fylogenetische -+ fysiognomieën -+ fysiotherapeutische -+ fysisch-chemisch -+ fysisch-chemische -+ fytoplankton -+ fytosanitaire -+ föhns -+ g's -+ g'tje -+ gaargekookt -+ gaargesmoord -+ gaarkoken -+ gaarsmoren -+ gaasdoek -+ gaasweefsel -+ gaasweefsels -+ gabarit -+ gabbers -+ gadgets -+ gadogado -+ gadverdamme -+ gaf heruit -+ gaffeltuig -+ gaffeltuigen -+ gaffes -+ gaines -+ gakken -+ gakte -+ gala's -+ galaconcert -+ galaconcerten -+ galactische -+ galadiners -+ galapagosschildpad -+ galapagosschildpadden -+ galappeltje -+ galapremière -+ galapremières -+ galblaasoperatie -+ galblaasoperaties -+ galeriebezoeker -+ galeriebezoekers -+ galeriecircuit -+ galeriehouders -+ galeriehoudster -+ galeriehoudsters -+ galeries -+ galerijwoning -+ galerijwoningen -+ galkoliek -+ galkolieken -+ gallisch -+ gallische -+ galloway -+ galloways -+ galoche -+ galoches -+ galoet -+ galoppas -+ galoppassen -+ galopperend -+ galopperende -+ galopsprong -+ galopsprongen -+ galwegen -+ galzucht -+ gamba's -+ gamede -+ gamelanorkest -+ gamelanorkesten -+ gamen -+ gamepje -+ gamer -+ gamers -+ gamet -+ gameten -+ gamma's -+ gamma-ijzer -+ gamma-uil -+ gamma-uilen -+ gamma-uiltje -+ gammaglobuline -+ gammaglobulinen -+ gammaglobulines -+ gammastraling -+ gammawetenschappen -+ gangbang -+ gangbangde -+ gangbangen -+ gangbangt -+ gangenstelsel -+ gangenstelsels -+ ganglichten -+ gangmaakster -+ gangmaaksters -+ gangsterbaas -+ gangsterbazen -+ gangwissel -+ gangwissels -+ ganzenbloem -+ ganzenbloemen -+ ganzendons -+ ganzenleverpastei -+ ganzenlevers -+ ganzenpastei -+ ganzenvet -+ garage-eigenaar -+ garage-eigenaren -+ garagebox -+ garageboxen -+ garagepoort -+ garagepoorten -+ garagerock -+ garagisten -+ garantie-uren -+ garantiefondsen -+ garantiekrediet -+ garantiekredieten -+ garantieprijs -+ garantieprijzen -+ garantiestellingen -+ garantievermogen -+ garantstellingen -+ gardenia's -+ garderobetje -+ gardiaans -+ gardisten -+ garennummer -+ garennummers -+ gargantuesk -+ gargantueske -+ garibaldi's -+ garimpeiro -+ garimpeiro's -+ garnalencocktail -+ garnalencocktails -+ garnalenkroket -+ garnalenkroketten -+ garnalenplant -+ garnalenplanten -+ garnalenvangsten -+ garnalenvisser -+ garnalenvisserij -+ garnalenvissers -+ garnalenvloot -+ garnalenvloten -+ garneerspuit -+ garneerspuiten -+ garnierder -+ garnierders -+ garnizoensstad -+ garnizoenssteden -+ garçon -+ garçons -+ gas- en lichtrekening -+ gas- en lichtrekeningen -+ gasballon -+ gasballons -+ gasbedrijf -+ gasbellen -+ gasbenzine -+ gasbol -+ gasbollen -+ gasbrandertje -+ gasbron -+ gasbronnen -+ gaschromatografie -+ gasdiffusie -+ gasdistributie -+ gasdistributiebedrijf -+ gasgestookt -+ gasgestookte -+ gashandel -+ gashandels -+ gashendel -+ gashendels -+ gasinstallatie -+ gasinstallaties -+ gaskomforen -+ gaslekken -+ gasmengsel -+ gasmengsels -+ gasmolecule -+ gasmoleculen -+ gasmolecules -+ gasnetten -+ gasoorlogen -+ gasopnemer -+ gasopnemers -+ gaspak -+ gaspakken -+ gaspistool -+ gaspistools -+ gasprijzen -+ gasrekening -+ gasrekeningen -+ gasreserves -+ gasstelletje -+ gastank -+ gastanker -+ gastankers -+ gastanks -+ gastarbeid -+ gastauteur -+ gastauteurs -+ gastcolleges -+ gastcolumn -+ gastcolumns -+ gastdirigent -+ gastdirigenten -+ gastenboek -+ gastenboeken -+ gastendoekje -+ gastendoekjes -+ gastenverblijven -+ gastheercel -+ gastheercellen -+ gastheerschap -+ gastheorie -+ gasthoogleraars -+ gasthoogleraren -+ gastland -+ gastlanden -+ gastmoeder -+ gastmoeders -+ gastoevoer -+ gastoptreden -+ gastoptredens -+ gastouder -+ gastoudergezin -+ gastoudergezinnen -+ gastouders -+ gastredacteur -+ gastredacteuren -+ gastredacteurs -+ gastregisseur -+ gastregisseurs -+ gastro-enterologen -+ gastrolletje -+ gastschrijver -+ gastschrijvers -+ gastspeler -+ gastspelers -+ gasturbines -+ gasveer -+ gasveld -+ gasvelden -+ gasveren -+ gasvering -+ gasvlammetje -+ gasvondsten -+ gasvoorraad -+ gasvoorraden -+ gasvoorziening -+ gasvulling -+ gaswolken -+ gatenkaas -+ gatenkazen -+ gatenplant -+ gatenplanten -+ gateway -+ gatlikken -+ gatlikte -+ gatsometer -+ gatsometers -+ gaucho's -+ gaullisten -+ gaullistische -+ gausscurve -+ gavialen -+ gayscene -+ gayscenes -+ gazelleogen -+ gazelleoog -+ gazelles -+ gazeuses -+ gazpacho -+ ge-e-maild -+ ge-ftp'd -+ ge-i-bankierd -+ ge-jeu-de-bould -+ ge-m-bankierd -+ ge-sms't -+ geaccelereerd -+ geacquireerd -+ geadoreerd -+ geadsorbeerd -+ geaerobict -+ geaffirmeerd -+ geafrikaniseerd -+ gealloceerd -+ gealludeerd -+ gealpineskied -+ gealtereerd -+ geamerikaniseerd -+ geamuseerdheid -+ geanonimiseerd -+ geapaiseerd -+ geapocopeerd -+ geappliqueerd -+ geaprès-skied -+ geaquarelleerd -+ gearabiseerd -+ geasemd -+ geatomiseerd -+ geattacheerd -+ geattaqueerd -+ geauditeerd -+ geautodatet -+ geautopet -+ gebaald -+ gebaanderd -+ gebabysit -+ geback-upt -+ gebackpackt -+ gebackt -+ gebadderd -+ gebadineerd -+ gebadmintond -+ gebakkelei -+ gebakschoteltjes -+ gebaksdoos -+ gebaksdozen -+ gebakst -+ gebal -+ gebalkaniseerd -+ gebaltst -+ gebamzaaid -+ gebankierd -+ gebannen -+ gebanvloekt -+ gebarbecued -+ gebarreerd -+ gebaseballd -+ gebased -+ gebasket -+ gebasketbald -+ gebat -+ gebed op Kol Nidrei -+ gebedsbijeenkomst -+ gebedsbijeenkomsten -+ gebedsdienst -+ gebedsgenezer -+ gebedsgenezers -+ gebedsgenezingen -+ gebedshouding -+ gebedshoudingen -+ gebedsleven -+ gebedsmolen -+ gebedsmolens -+ gebedsriem -+ gebedsriemen -+ gebedswake -+ gebedswaken -+ gebeest -+ gebekerd -+ gebekvecht -+ gebenchmarkt -+ gebensjt -+ gebetenheid -+ gebeuk -+ gebeuzel -+ gebiedsaanspraak -+ gebiedsaanspraken -+ gebiedsindeling -+ gebiedsindelingen -+ gebingood -+ gebist -+ gebitplaat -+ gebitplaten -+ gebitsbeschermer -+ gebitsbeschermers -+ gebitselement -+ gebitselementen -+ gebitsprothese -+ gebitsprothesen -+ gebitsprotheses -+ gebitsregulatie -+ gebitsziekte -+ gebitsziekten -+ gebitumineerd -+ geblancheerd -+ geblasfemeerd -+ geblerkt -+ gebliefd -+ gebliep -+ gebloemleesd -+ geblogd -+ geblokletterd -+ geblowd -+ geblubberd -+ geblunder -+ geblèt -+ gebobsleed -+ gebodsbepaling -+ gebodsbepalingen -+ gebodsbord -+ gebodsborden -+ gebodyboard -+ gebodybuild -+ geboeidheid -+ gebomcheckt -+ gebonk -+ gebons -+ geboorte-eiland -+ geboorteaangiften -+ geboorteaangiftes -+ geboorteafwijking -+ geboorteafwijkingen -+ geboortecontrole -+ geboortedaling -+ geboortedata -+ geboortedatums -+ geboortedorp -+ geboortedorpen -+ geboortegolven -+ geboortehuizen -+ geboortekrik -+ geboortekrikken -+ geboortelijst -+ geboortelijsten -+ geboortepremie -+ geboortepremies -+ geboorteregeling -+ geboorteregisters -+ geboortesteden -+ geboortestreken -+ geboortetegel -+ geboortetegels -+ geboortetrauma -+ geboortetrauma's -+ geboortetraumata -+ geborene -+ geborenen -+ geborneerdheid -+ gebouwencomplexen -+ gebrainstormd -+ gebrainwasht -+ gebreakdancet -+ gebreakdanst -+ gebreksziekte -+ gebreksziekten -+ gebricoleerd -+ gebridget -+ gebroederlijk -+ gebrokenheid -+ gebrost -+ gebrowset -+ gebruikersnamen -+ gebruikersonvriendelijk -+ gebruikersonvriendelijke -+ gebruikgemaakt -+ gebruiksklare -+ gebruiksmuziek -+ gebruiksonvriendelijk -+ gebruiksonvriendelijke -+ gebruiksrechten -+ gebruikssfeer -+ gebruikssferen -+ gebruiksvriendelijke -+ gebruiksvriendelijkheid -+ gebruikswaarden -+ gebruncht -+ gebubbeld -+ gebulldozerd -+ geburen -+ geburld -+ gebust -+ gebutst -+ gebuur -+ gebuurtes -+ gebuut -+ gecanceld -+ gecanvast -+ gecapteerd -+ gecarpoold -+ gecatalogeerd -+ gecategoriseerd -+ gecauteriseerd -+ gechambreerd -+ gechangeerd -+ gecharged -+ gechat -+ gechicaneer -+ gechineesd -+ gechloord -+ gechloreerd -+ gechookt -+ gechoreografeerd -+ gecijfer -+ geco -+ geco's -+ geco-existeerd -+ gecoacht -+ gecoat -+ gecocoond -+ gecohabiteerd -+ gecollectioneerd -+ gecollideerd -+ gecommercialiseerd -+ gecomplementeerd -+ gecompliceerdheid -+ gecomplotteerd -+ gecomputerd -+ gecomputeriseerd -+ geconcelebreerd -+ geconcilieerd -+ geconcordeerd -+ geconfectioneerd -+ geconfedereerd -+ geconflicteerd -+ gecongresseerd -+ geconsenteerd -+ geconspireerd -+ geconsumeerd -+ gecontacteerd -+ gecontamineerd -+ gecontesteerd -+ gecoproduceerd -+ gecorrectionaliseerd -+ gecorveed -+ gecounseld -+ gecounterd -+ gecountrydanst -+ gecoupt -+ gecoverd -+ gecoïteerd -+ gecoöpereerd -+ gecoöpteerde -+ gecrawld -+ gecroond -+ gecrowdsurft -+ gecruised -+ gecruiset -+ geculpabiliseerd -+ gecuretteerd -+ gecyclecrost -+ gecyclocrost -+ gedaantewisseling -+ gedaantewisselingen -+ gedachte-experimenten -+ gedachteassociaties -+ gedachtebepalingen -+ gedachteconstructie -+ gedachteconstructies -+ gedachteflarden -+ gedachtegoed -+ gedachtekronkels -+ gedachteleven -+ gedachtereeksen -+ gedachtes -+ gedachtespinsel -+ gedachtespinsels -+ gedachtevlucht -+ gedachtewerelden -+ gedachtewisselingen -+ gedactyloscopeerd -+ gedagdroomd -+ gedalfd -+ gedard -+ gedart -+ gedateerdheid -+ gedatet -+ gedaver -+ gedavvend -+ gede-escaleerd -+ gedeactiveerd -+ gedeactualiseerd -+ gedeald -+ gedebrailleerd -+ gedebriefd -+ gedebrieft -+ gedebugd -+ gedecomprimeerd -+ gedeconfessionaliseerd -+ gedeconstrueerd -+ gedecoupeerd -+ gedeeplinkt -+ gedefibrilleerd -+ gedeflecteerd -+ gedefloreerd -+ gedegenheid -+ gedegouteerd -+ gedegouteerde -+ gedegusteerd -+ gedehydreerd -+ gedeisd -+ gedekoloniseerd -+ gedeletet -+ gedelibereer -+ gedemineraliseerd -+ gedemoniseerd -+ gedemotiveerd -+ gedemotiveerde -+ gedemystificeerd -+ gedenaturaliseerd -+ gedender -+ gedenigreerd -+ gedenknaald -+ gedenknaalden -+ gedenomineerd -+ gedenonceerd -+ gedenuncieerd -+ gedeodoriseerd -+ gedepanneerd -+ gedepenaliseerd -+ gedeprivatiseerd -+ gedeprogrammeerd -+ gedeputeerd -+ gedesacraliseerd -+ gedesambigueerd -+ gedesensibiliseerd -+ gedesinteresseerde -+ gedesinvesteerd -+ gedestaliniseerd -+ gedetailleerdheid -+ gedevieerd -+ gediaboliseerd -+ gedialogiseerd -+ gedichtenbundels -+ gedichtenbundeltje -+ gedichtencycli -+ gedichtenwedstrijd -+ gedichtenwedstrijden -+ gediekt -+ gedieplinkt -+ gedieseld -+ gediffameerd -+ gediffundeerd -+ gediftongeerd -+ gedilateerd -+ gedipt -+ gedisambigueerd -+ gediscrediteerd -+ gediscussieer -+ gedissocieerd -+ gedivergeerd -+ gediversifieerd -+ gediverteerd -+ gedjakt -+ gedjorkt -+ gedogmatiseerd -+ gedollariseerd -+ gedomesticeerd -+ gedomicilieerde -+ gedonderstraald -+ gedoneerd -+ gedoogbeleid -+ gedoogdenstatus -+ gedoogplicht -+ gedoogsteun -+ gedoogzone -+ gedoogzones -+ gedotterd -+ gedoucht -+ gedowngraded -+ gedozerd -+ gedraaf -+ gedraal -+ gedragsdeskundige -+ gedragsdeskundigen -+ gedragsgestoord -+ gedragsgestoorde -+ gedragsgestoorden -+ gedragsleer -+ gedragsnorm -+ gedragsnormen -+ gedragsonderzoek -+ gedragspsychologie -+ gedragstherapie -+ gedragstherapieën -+ gedragswetenschap -+ gedragswetenschappelijk -+ gedragswetenschappelijke -+ gedram -+ gedramd -+ gedrein -+ gedrentel -+ gedrentenierd -+ gedroedeld -+ gedruiloord -+ gedrum -+ gedubbelcheckt -+ geduldwerkje -+ geduldwerkjes -+ geduw -+ gedweep -+ gedynamiseerd -+ geelfilter -+ geelfilters -+ geeloranje -+ geelverlicht -+ geelverlichte -+ geelwit -+ geelwitte -+ geeneens -+ geestesgesteldheden -+ geesteshoudingen -+ geesteskinderen -+ geesteskracht -+ geesteskrachten -+ geestesmerk -+ geestesproduct -+ geestesproducten -+ geestesvermogen -+ geestesvermogens -+ geesteswereld -+ geestloos -+ geestloost -+ geestloze -+ geestlozer -+ geestverwarring -+ gefabuleerd -+ gefacelift -+ gefaket -+ gefalsificeerd -+ gefalsifieerd -+ gefascineerdheid -+ gefederaliseerd -+ gefedereerd -+ gefemel -+ gefibrilleerd -+ gefictionaliseerd -+ gefield -+ gefierljept -+ gefietscrost -+ gefiguurzaagd -+ gefikst -+ gefilosofeer -+ gefilte fisj -+ gefinaliseerd -+ gefinetuned -+ gefinisht -+ gefiscaliseerd -+ gefistfuckt -+ gefit -+ gefitnest -+ gefladder -+ geflambeerd -+ geflapperd -+ gefleem -+ gefleetracet -+ geflenst -+ geflest -+ geflexibiliseerd -+ geflikker -+ geflipperd -+ geflit -+ geflits -+ gefoeter -+ gefoezeld -+ gefonduud -+ gefotofuckt -+ gefotoshopt -+ gefranchised -+ gefrazeld -+ gefreakt -+ gefreelancet -+ gefreestyled -+ gefreewheeld -+ gefriemel -+ gefrisbeed -+ gefrituurd -+ gefrons -+ gefrotteerd -+ gefrummeld -+ gefrunnik -+ gefrunnikt -+ gefumeerd -+ gefumeerde -+ gefunshopt -+ gefusioneerd -+ gegakt -+ gegamed -+ gegangbangd -+ gegatlikt -+ gegeeuw -+ gegeilbekt -+ gegeild -+ gegeit -+ gegevensopslag -+ gegevensstromen -+ gegevensstroom -+ gegevensuitwisseling -+ gegidst -+ gegiebel -+ gegiebeld -+ gegier -+ geglansde -+ geglasstraald -+ gegniffel -+ gegolft -+ gegoogeld -+ gegordeld -+ gegourmet -+ gegraaf -+ gegraai -+ gegrapjast -+ gegrapt -+ gegratieerd -+ gegratificeerd -+ gegriefdheid -+ gegrinnik -+ gegrossierd -+ gegumd -+ gehackt -+ gehakkel -+ gehakketak -+ gehaktballetje -+ gehaktdag -+ gehamer -+ gehandicaptenbeleid -+ gehandicaptensport -+ gehandicaptenzorg -+ gehang -+ gehangglided -+ geheadbangd -+ geheadhunt -+ geheimhouder -+ geheimhouders -+ geheimzinnigdoenerij -+ gehelleniseerd -+ geherdefinieerd -+ geherexamineerd -+ geherfinancierd -+ geherhuisvest -+ geherintroduceerd -+ geheroriënteerd -+ gehersenspoeld -+ geheugenchips -+ geheugenschijf -+ geheugenschijven -+ geheugenstoornis -+ geheugenstoornissen -+ geheugentraining -+ geheugenzwakte -+ geheupwiegd -+ gehint -+ gehistoriseerd -+ gehobbyd -+ gehockeyd -+ gehomogeniseerd -+ gehonkbald -+ gehoold -+ gehoorafstand -+ gehoorapparaten -+ gehoordrempel -+ gehoordrempels -+ gehoorgestoord -+ gehoorgrens -+ gehoorgrenzen -+ gehoormeting -+ gehoormetingen -+ gehoorsafstand -+ gehoorverlies -+ gehopst -+ gehosseld -+ gehoused -+ gehouset -+ gehupst -+ gehusseld -+ gehypet -+ gehypostaseerd -+ geijshockeyd -+ geijsracet -+ geilaard -+ geilaards -+ geilbekken -+ geilbekte -+ geilde -+ geilen -+ geiligheid -+ geinlijn -+ geinponem -+ geinponems -+ geisha's -+ geitenbreier -+ geitenbreiers -+ geitenhoeder -+ geitenhoeders -+ geitenkazen -+ geitenmelk -+ geitenmelker -+ geitenmelkers -+ geitenwol -+ geitenwollen -+ geitte -+ gejakker -+ gejamd -+ gejend -+ gejengel -+ gejeremieer -+ gejetskied -+ gejobd -+ gejobhopt -+ gejodel -+ gejogd -+ gejoind -+ gejojood -+ gejongleer -+ gejoud -+ gejureerd -+ gekaald -+ gekaand -+ gekaderd -+ gekafferd -+ gekallegaaid -+ gekannibaliseerd -+ gekaraookt -+ gekart -+ gekasjerd -+ gekatalyseerd -+ gekatapulteerd -+ gekerm -+ gekeutel -+ gekibbel -+ gekickbokst -+ gekickt -+ gekidnapt -+ gekijf -+ gekir -+ gekissebis -+ gekiteboard -+ gekiteskatet -+ gekitesurft -+ gekke henkie -+ gekke henkies -+ gekkerd -+ gekkerds -+ gekko's -+ geklauter -+ gekleid -+ geklepper -+ geklessebest -+ gekleund -+ geklieder -+ gekliederd -+ gekliekt -+ geklierd -+ geklik -+ gekloft -+ geklofte -+ gekloneerd -+ geklooi -+ geklooid -+ geklunsd -+ geklust -+ gekluund -+ gekmakend -+ gekmakende -+ geknal -+ geknerpt -+ geknerst -+ geknetter -+ geknisperd -+ geknobbeld -+ geknok -+ geknor -+ geknuffel -+ gekolonialiseerd -+ gekoprold -+ gekraak -+ gekrabbel -+ gekrachttraind -+ gekras -+ gekrasseld -+ gekrent -+ gekreupeld -+ gekroeld -+ gekrold -+ gekukeld -+ gekwartet -+ gekwebbel -+ gekweel -+ gekwek -+ gekweldheid -+ gekwetstheid -+ gekwinkeleer -+ gelaagdheden -+ gelaatstrek -+ gelaatszenuw -+ gelaatszenuwen -+ geladenheid -+ gelagzaal -+ gelagzalen -+ gelamineerd -+ gelanglauft -+ gelasergamed -+ gelay-out -+ gelazerstraald -+ geldbeugel -+ geldbeugels -+ geldeenheden -+ geldeenheid -+ geldgever -+ geldgevers -+ geldhervorming -+ geldhervormingen -+ geldhoeveelheid -+ geldingskracht -+ geldingszucht -+ geldinstelling -+ geldinstellingen -+ geldinzamelingen -+ geldkranen -+ geldkrapte -+ geldla's -+ geldlaatje -+ geldmarkttekort -+ geldmarktverruimend -+ geldmarktverruimende -+ geldomhaling -+ geldomhalingen -+ geldpers -+ geldpersen -+ geldprijs -+ geldprijzen -+ geldstandaard -+ geldstraf -+ geldstraffen -+ geldtas -+ geldtassen -+ gelduitgifteautomaat -+ geldvernietiging -+ geldverspillingen -+ geldvordering -+ geldvorderingen -+ geldwaarde -+ geldwagen -+ geldwagens -+ geldwisselkantoor -+ geldwisselkantoren -+ geleased -+ geleaset -+ gelebek -+ gelebekken -+ gelebeks -+ geleedpotigen -+ gelees -+ gelegenheidsaanbieding -+ gelegenheidsaanbiedingen -+ gelegenheidsargument -+ gelegenheidsargumenten -+ gelegenheidsdrinker -+ gelegenheidsdrinkers -+ gelegenheidszegel -+ gelegenheidszegels -+ geleidebrief -+ geleidebrieven -+ geleiderail -+ geleiderails -+ gelest -+ geletruidrager -+ gelieven -+ gelijkberechtigde -+ gelijkberechtigdheid -+ gelijkertijd -+ gelijkgeknipt -+ gelijkgekomen -+ gelijkgelegen -+ gelijkgelopen -+ gelijkgemaakt -+ gelijkgespeeld -+ gelijkgestaan -+ gelijkgestemdheid -+ gelijkgezinden -+ gelijkgezindheid -+ gelijkheidsideaal -+ gelijkheidsstreven -+ gelijkheidswaan -+ gelijkknippen -+ gelijkkomen -+ gelijkliggen -+ gelijklopen -+ gelijkrichten -+ gelijkspelen -+ gelijkstaan -+ gelijkstemmen -+ gelijktrekking -+ gelijkvormigheidsattest -+ gelik -+ gelinieerde -+ gelobby -+ gelobbyd -+ geloftedag -+ geloftes -+ gelonk -+ geloofsafval -+ geloofsbeleving -+ geloofsbelevingen -+ geloofscrises -+ geloofscrisissen -+ geloofsgeschil -+ geloofsgeschillen -+ geloofsinhoud -+ geloofskwestie -+ geloofskwesties -+ geloofsleven -+ geloofsovergang -+ geloofsverdeeldheid -+ geloofsverkondiging -+ geloofsvraag -+ geloofszekerheden -+ geloofszekerheid -+ gels -+ geluidarm -+ geluidarme -+ geluidbelasting -+ geluidbelastingen -+ geluidloost -+ geluidsarm -+ geluidsarme -+ geluidsbarrière -+ geluidsbarrières -+ geluidsbelasting -+ geluidsbelastingen -+ geluidsbox -+ geluidsboxen -+ geluidscapaciteit -+ geluidscassette -+ geluidscassettes -+ geluidsdragers -+ geluidsinstallaties -+ geluidskaarten -+ geluidskwaliteit -+ geluidsmuren -+ geluidsmuur -+ geluidsopname -+ geluidsopnameapparatuur -+ geluidsopnamen -+ geluidsopnames -+ geluidspoort -+ geluidspoorten -+ geluidsprikkel -+ geluidsprikkels -+ geluidssnelheid -+ geluidstechnici -+ geluidstechnicus -+ geluidstechnisch -+ geluidstechnische -+ geluidstorens -+ geluidstrechter -+ geluidstrechters -+ geluidswand -+ geluidswanden -+ geluidswerend -+ geluidswerende -+ geluidszone -+ geluidszones -+ geluidwerend -+ geluidwerende -+ geluidzone -+ geluidzones -+ gelukbrengend -+ gelukbrengende -+ gelukjes -+ geluksgetal -+ geluksgetallen -+ geluksgevoelens -+ geluksmoment -+ geluksroes -+ geluksspel -+ geluksspelen -+ geluksteken -+ gelukstekens -+ gelukstreffer -+ gelukstreffers -+ geluksverlangen -+ geluksverlangens -+ gelukswens -+ gelukswensen -+ gelukszoeker -+ gelukszoekers -+ gelule -+ gelulen -+ gelules -+ geluletje -+ gelumbeckt -+ geluultje -+ gemacrameed -+ gemaild -+ gemakkelijkheidsoplossing -+ gemaksvoeding -+ gemaksvoedsel -+ gemakzuchtigheid -+ gemalverseerd -+ gemanaged -+ gemanipuleer -+ gemanoeuvreer -+ gemanumitteerd -+ gemaquilleerd -+ gemarginaliseerde -+ gemarginaliseerden -+ gemassificeerd -+ gemasturbeerd -+ gemathematiseerd -+ gematria -+ gemaximeerd -+ gemberpoeder -+ gemberpot -+ gemberpotten -+ gembersiroop -+ gemberwortel -+ gemberwortels -+ gemeanderd -+ gemedicaliseerd -+ gemeenlijke -+ gemeenschappelijkheid -+ gemeenschapsaangelegenheden -+ gemeenschapsaangelegenheid -+ gemeenschapscentra -+ gemeenschapsexecutieve -+ gemeenschapsexecutieven -+ gemeenschapsgeld -+ gemeenschapsgelden -+ gemeenschapshuis -+ gemeenschapshuizen -+ gemeenschapsminister -+ gemeenschapsministers -+ gemeenschapsonderwijs -+ gemeenschapsraad -+ gemeenschapsraden -+ gemeenschapsrecht -+ gemeenschapsregering -+ gemeenschapsregeringen -+ gemeenschapsvorm -+ gemeenschapsvormen -+ gemeente-eigendom -+ gemeente-eigendommen -+ gemeente-instelling -+ gemeente-instellingen -+ gemeenteadministratie -+ gemeentebeleid -+ gemeentebibliotheek -+ gemeentebibliotheken -+ gemeentefinanciën -+ gemeentefondsen -+ gemeentelid -+ gemeentemandataris -+ gemeentemandatarissen -+ gemeentemusea -+ gemeentemuseum -+ gemeentemuseums -+ gemeentepolitiekorps -+ gemeentepolitiekorpsen -+ gemeenteraadsbesluit -+ gemeenteraadsbesluiten -+ gemeenteraadsverkiezing -+ gemeentesecretarie -+ gemeentesecretarieën -+ gemeenteverordening -+ gemeenteverordeningen -+ gemeentewetten -+ gemeier -+ gemeierd -+ gemenebestland -+ gemenebestlanden -+ gemenerik -+ gemeneriken -+ gemensendieckt -+ gemetastaseerd -+ gemeurd -+ gemicrofilmd -+ gemidgetgolfd -+ gemidgetgolft -+ gemiegeld -+ gemiept -+ gemieter -+ gemijmer -+ gemilderd -+ gemimed -+ geminiseerd -+ geminoriseerd -+ gemissioneerd -+ gemodeltekend -+ gemoeide -+ gemoireerd -+ gemonitord -+ gemonkel -+ gemonopolyd -+ gemontignact -+ gemoraliseer -+ gemorrel -+ gemountainbiket -+ gemoved -+ gemultipliceerd -+ gemythologiseerd -+ genadeklap -+ genadeleer -+ genadeloost -+ genaden -+ genades -+ genadeverbond -+ genadigheid -+ genadiglijk -+ genafwijking -+ genafwijkingen -+ genasjt -+ genast -+ geneesheren-directeuren -+ geneesheren-directeurs -+ geneesmethode -+ geneesmethoden -+ geneesmethodes -+ geneesmiddelenfabrikant -+ geneesmiddelenindustrie -+ geneesmiddelensector -+ geneesmiddelenvergoedingssysteem -+ genegotieerd -+ genenmateriaal -+ genenonderzoek -+ generaals-majoor -+ generaalsbewind -+ generaalsbewinden -+ generaliseerbaarheid -+ generaliseringen -+ generalissimi -+ generalistische -+ generatieconflicten -+ generatiegebonden -+ generatiegenoot -+ generatiegenoten -+ generatiestudent -+ generatiestudenten -+ generatietijd -+ generieken -+ generische -+ genetici -+ genetwerkt -+ geneugtes -+ geneuk -+ geneurie -+ geneurotiseerd -+ genezers -+ genezingskans -+ genezingskansen -+ genie-eenheden -+ genie-eenheid -+ genikst -+ genitief-s -+ genitief-s'en -+ geniza -+ genocidale -+ genocides -+ genocidewet -+ genopte -+ genormeerd -+ genotmiddelenindustrie -+ genotsmiddel -+ genotsmiddelenindustrie -+ genotteren -+ genotvol -+ genotvolle -+ genotypes -+ genotypische -+ genotzuchtig -+ genotzuchtige -+ genreaanduiding -+ genrefilm -+ genrefilms -+ genretafereel -+ genretaferelen -+ genrevoorstelling -+ genrevoorstellingen -+ gent -+ gentechnologie -+ gentherapie -+ gentleman's agreement -+ gentleman's agreements -+ gentleman-trainer -+ gentlemen's agreement -+ gentlemen's agreements -+ geo-etnisch -+ geo-etnische -+ geobjectiveerd -+ geobotanie -+ geobsedeerdheid -+ geodoriseerd -+ geofficialiseerd -+ geofysici -+ geofysische -+ geografe -+ geografes -+ geoha -+ geohaad -+ geologe -+ geologes -+ geometrisch-abstract -+ geometrisch-abstracte -+ geonaneerd -+ geoord -+ geoorde -+ geoorloofdheid -+ geopinieerd -+ geordineerd -+ georganiseerdheid -+ geornamenteerd -+ geostationaire -+ geostrategische -+ geothermische -+ geotterd -+ geouweneeld -+ geovuleerd -+ gepaaldanst -+ gepacet -+ gepacteerd -+ gepaintballd -+ gepalaver -+ gepalaverd -+ gepalpiteerd -+ gepamperd -+ gepanikeerd -+ geparset -+ gepartyd -+ gepassioneerdheid -+ gepasst -+ gepatroniseerd -+ gepeerd -+ gepelgrimeerd -+ gepenaliseerd -+ geperiodiseerd -+ geperkt -+ geperoreerd -+ gepersevereerd -+ gepetanquet -+ gepetst -+ gepiekt -+ gepield -+ gepiepeld -+ gepiercet -+ gepietepeuterd -+ gepiketteerd -+ gepild -+ gepimpampet -+ gepinaard -+ gepintelierd -+ gepitcht -+ gepivoteerd -+ geplaag -+ geplaasterd -+ geplagieerd -+ geplaybackt -+ geplensregend -+ gepleurd -+ geplogenheden -+ geplogenheid -+ geplot -+ geplugd -+ gepluk -+ geplust -+ gepoch -+ gepogood -+ gepolood -+ gepolsterd -+ gepolsterde -+ gepolymeriseerd -+ gepoold -+ gepreadviseerd -+ geprecipiteerd -+ geprediceerd -+ gepreek -+ geprefigeerd -+ geprevel -+ gepriegeld -+ geprikkeldheid -+ geprioriteerd -+ geprivatiseerd -+ geproblematiseerd -+ geproducet -+ geprofessionaliseerd -+ geprognosticeerd -+ gepromoot -+ gepronk -+ gepronostikeerd -+ gepsychologiseer -+ gepsychologiseerd -+ gepuberd -+ gepuf -+ gepulverd -+ gepureerde -+ gepusht -+ gequeruleerd -+ geraadzaam -+ geraadzame -+ geraaskal -+ geram -+ gerampetampt -+ gerandomiseerd -+ gerandomiseerde -+ geraniumpje -+ gerapt -+ gerasp -+ gerasterd -+ gerausd -+ gerauwdouwd -+ gerbera's -+ gerbil -+ gerbils -+ gere-integreerd -+ gereactiveerd -+ gereaffecteerd -+ gerebbeld -+ gereboot -+ gerecapt -+ gerechercheerd -+ gerechtigheden -+ gerechtsauditeur -+ gerechtsauditeurs -+ gerechtszaal -+ gerechtszalen -+ gerechtvaardigdheid -+ gerecirculeerd -+ gerecombineerd -+ gerecycleerd -+ geredekavel -+ geredelijke -+ gereedgehouden -+ gereedgelegd -+ gereedgestaan -+ gereedgezet -+ gereedhouden -+ gereedleggen -+ gereedschapskistje -+ gereedschapsstaal -+ gereedstaan -+ gereedzetten -+ gereformeerd-vrijgemaakt -+ gereformeerd-vrijgemaakte -+ gereformeerd-vrijgemaakten -+ geregionaliseerd -+ gereis -+ gerelaxte -+ geremdheden -+ geremdheid -+ geremedieerd -+ geremigreerd -+ geremiseerd -+ geremixt -+ geremplaceerd -+ gerenationaliseerd -+ gerenoek -+ gerenoeks -+ gerentabiliseerd -+ gereputeerd -+ gereputeerde -+ gereset -+ gerestyled -+ geretardeerd -+ gerevaccineerd -+ gerevalueerd -+ gerevancheerd -+ gereveleerd -+ gerevideerd -+ gerevitaliseerd -+ gereïncarneerd -+ geriaters -+ geridiculiseerd -+ geriedeld -+ gerijm -+ gerijmeld -+ gerikt -+ geript -+ geriskt -+ geritmeerd -+ geritualiseerd -+ gerobotiseerd -+ gerochel -+ gerock-'n-rold -+ gerockt -+ gerodeerd -+ geroefeld -+ geroer -+ geroerbakt -+ geroet -+ geroetsjt -+ geroffel -+ geromantiseerd -+ gerontologen -+ gerontologische -+ gerouwdouwd -+ geruchtencircuit -+ geruchtenmachine -+ geruchtenmolen -+ geruchtenvorming -+ geruft -+ gerugbyd -+ geruggensteunde -+ gerummikupt -+ gerundia -+ gerundiva -+ geruststellingen -+ gesampled -+ gesappel -+ gesappeld -+ gesar -+ gesauteerd -+ gesauteerde -+ gesaved -+ gescand -+ gescandeer -+ gescharnierd -+ gescheidenheid -+ gescheidsrechterd -+ geschenkbonnen -+ geschenkbons -+ geschenkenregeling -+ geschenkverpakking -+ geschenkverpakkingen -+ geschiedbeeld -+ geschiedbeoefening -+ geschiedenisfilosofie -+ geschiedenisonderwijs -+ geschiedenisstudie -+ geschiedeniswetenschap -+ geschiedfilosofie -+ geschiedfilosofisch -+ geschiedfilosofische -+ geschiedschrijven -+ geschiedwerk -+ geschiedwerken -+ geschiet -+ geschilder -+ geschillenbeslechting -+ geschimp -+ geschmier -+ geschmierd -+ geschnabbeld -+ geschoolmeesterd -+ geschraap -+ geschrok -+ geschroot -+ geschuddebuikt -+ geschutkoepel -+ geschutkoepels -+ geschutskoepel -+ geschutskoepels -+ geschutsopstelling -+ geschutsopstellingen -+ gesco -+ gesco's -+ gescratcht -+ gescrold -+ gescrubd -+ geseald -+ gesecondeerd -+ gesedenteerd -+ geseksualiseerd -+ geselslag -+ geselslagen -+ gesensibiliseerd -+ geserreerdheid -+ gesetteld -+ gesettelde -+ geshaket -+ geshimmyd -+ geshopt -+ geshorttrackt -+ geshot -+ geshowd -+ gesiepeld -+ gesimpt -+ gesjabloneerd -+ gesjanst -+ gesjochten -+ gesjoeld -+ gesjok -+ gesjor -+ geskateboard -+ geskatet -+ geskelterd -+ geskimd -+ geslachtloos -+ geslachtloze -+ geslachtsbepaling -+ geslachtscel -+ geslachtscellen -+ geslachtschromosomen -+ geslachtschromosoom -+ geslachtsgebonden -+ geslachtskenmerk -+ geslachtskenmerken -+ geslachtsklier -+ geslachtsklieren -+ geslachtskunde -+ geslachtsleven -+ geslachtsliefde -+ geslachtsloos -+ geslachtsloze -+ geslachtsomgang -+ geslachtsregister -+ geslachtsregisters -+ geslachtstest -+ geslachtstests -+ geslachtsverandering -+ geslachtsverhouding -+ geslachtsverhoudingen -+ geslachtsziektebestrijding -+ gesleep -+ gesleutel -+ geslijmd -+ gesluikstort -+ gesluip -+ gesmak -+ gesmasht -+ gesmeek -+ gesmiespeld -+ gesnabbeld -+ gesneerd -+ gesnerp -+ gesnierd -+ gesnift -+ gesnik -+ gesnookerd -+ gesnorkeld -+ gesnowboard -+ gesnuffel -+ gesnuif -+ gesoftbald -+ gesol -+ gesoleerd -+ gesolidariseerd -+ gesomberd -+ gesoundmixt -+ gesovjetiseerd -+ gespachtelputzt -+ gespannenheid -+ gespard -+ gespeculeer -+ gespeende -+ gespin -+ gespind -+ gespinsd -+ gespook -+ gesport -+ gesprayd -+ gespreksavond -+ gespreksavonden -+ gespreksbehandeling -+ gespreksbehandelingen -+ gesprekscentra -+ gesprekscentrum -+ gespreksgenoot -+ gespreksgenoten -+ gesprekskosten -+ gesprekspunt -+ gesprekspunten -+ gespreksrondes -+ gespreksthema's -+ gesprekstherapie -+ gesprekstherapieën -+ gespreksvormen -+ gespring -+ gespuug -+ gesquasht -+ gesse -+ gestaartdeeld -+ gestagedived -+ gestalkt -+ gestaltpsychologie -+ gestangd -+ gestanst -+ gestat -+ gestatust -+ gesteengrild -+ gesteentelaag -+ gesteentelagen -+ juratijdperk -+ gesteggeld -+ gestemdheid -+ gesteun -+ gestift -+ gestockeerd -+ gestofzuigerd -+ gestook -+ gestotter -+ gestraatracet -+ gestrategood -+ gestreakt -+ gestresseerd -+ gestretcht -+ gestructureerdheid -+ gestruind -+ gestuiptrekt -+ gestumper -+ gestumperd -+ gestuntel -+ gestuukt -+ gesuis -+ gesuperviseerd -+ gesupporterd -+ gesurft -+ gesurinamiseerd -+ gesurplacet -+ gesurvivald -+ geswitcht -+ gesyndiceerd -+ gesyndikeerde -+ gesyndikeerden -+ getafeltennist -+ getai-chied -+ getailleerd -+ getailleerde -+ getalsverhouding -+ getalsverhoudingen -+ getalswaarde -+ getandenknarst -+ getapet -+ getarifeerd -+ getater -+ getectyleerd -+ getelebankierd -+ getelefoneer -+ getelewerkt -+ getemperatuurd -+ getempt -+ getendeerd -+ getentamineerd -+ getermineerd -+ getetter -+ gethematiseerd -+ getijbeweging -+ getijbewegingen -+ getijdenbeweging -+ getijdenbewegingen -+ getijdencentrale -+ getijdencentrales -+ getijdengebied -+ getijdengebieden -+ getijdenstromen -+ getijdenwerking -+ getijverschil -+ getijverschillen -+ getiktheid -+ getimbreerd -+ getimbreerde -+ getimed -+ getimmer -+ getingel -+ getinkel -+ getintel -+ getjapt -+ getoept -+ getoeter -+ getokt -+ getolkt -+ getongd -+ getordeerd -+ getorteld -+ getoupeerd -+ getouwtrek -+ getover -+ getransfigureerd -+ getransplanteerd -+ getraumatiseerd -+ getreind -+ getreinsurft -+ getrek -+ getrieerd -+ getril -+ getrippel -+ getrist -+ getrivialiseerd -+ getrommel -+ getrompetter -+ getrompetterd -+ getrouwden -+ getrouwelijke -+ getrouwheidspremie -+ getrouwheidspremies -+ getrukeerd -+ gettoachtig -+ gettoachtige -+ gettoblasters -+ gettovorming -+ getuige-deskundige -+ getuigen-deskundigen -+ getuigenbank -+ getuigenbanken -+ getuigenispolitiek -+ getuigenverklaring -+ getuigenverslag -+ getuigenverslagen -+ getut -+ getverderrie -+ getypecast -+ geurloze -+ geurscheiding -+ geursporen -+ geurstof -+ geurstoffen -+ geurvlag -+ geurvlaggen -+ geuze -+ geuzennaam -+ geuzenverzet -+ gevaarloos -+ gevaarloze -+ gevaarsignalen -+ gevaarvol -+ gevaarvolle -+ gevalsbehandeling -+ gevalsbeschrijving -+ gevalsbeschrijvingen -+ gevalstudie -+ gevalstudies -+ gevangenenopstand -+ gevangenenopstanden -+ gevangenenruil -+ gevangengenomen -+ gevangengezet -+ gevangengezeten -+ gevangeniscel -+ gevangeniscellen -+ gevangeniscomplexen -+ gevangenisdirecteur -+ gevangenisdirecteuren -+ gevangenisdirecties -+ gevangenismuren -+ gevangenismuur -+ gevangenisopstand -+ gevangenisopstanden -+ gevangenispersoneel -+ gevangenispoort -+ gevangenispoorten -+ gevangenisstraffen -+ gevangennemen -+ gevangenpoort -+ gevangenpoorten -+ gevangenzetten -+ gevangenzitten -+ gevaporiseerd -+ gevarendriehoeken -+ gevarenpremie -+ gevarenpremies -+ gevarentoeslagen -+ gevarenzones -+ gevariabiliseerd -+ gevechtsactie -+ gevechtsacties -+ gevechtsafstand -+ gevechtsafstanden -+ gevechtservaring -+ gevechtservaringen -+ gevechtskracht -+ gevechtspak -+ gevechtspakken -+ gevechtspauzes -+ gevechtspiloot -+ gevechtspiloten -+ gevechtssterkte -+ gevechtstank -+ gevechtstanks -+ gevechtstas -+ gevechtstassen -+ gevechtstenue -+ gevechtstenues -+ gevechtsterreinen -+ gevechtstoestel -+ gevechtstoestellen -+ gevechtstroepen -+ gevechtsuitrusting -+ gevechtsuitrustingen -+ gevechtsvlieger -+ gevechtsvliegers -+ gevechtsvoertuig -+ gevechtsvoertuigen -+ gevechtszones -+ geveeg -+ geveeld -+ geveerde -+ gevelkachels -+ gevelornament -+ gevelornamenten -+ gevelpaneel -+ gevelpanelen -+ gevelreclame -+ gevelreclames -+ gevelrij -+ gevelrijen -+ gevelspits -+ gevelspitsen -+ gevelwanden -+ gevergeerde -+ geverseerdheid -+ gevetweid -+ gevieren -+ gevlag -+ gevleide -+ gevlieg -+ gevliegerd -+ gevlinderd -+ gevluggerd -+ gevoegelijk -+ gevoegelijke -+ gevoelsarmoede -+ gevoelsontlading -+ gevoelsontladingen -+ gevoelsreactie -+ gevoelsreacties -+ gevoelstemperatuur -+ gevoelstoestand -+ gevoelstoestanden -+ gevoelsuitbarsting -+ gevoelsuitbarstingen -+ gevoelsuiting -+ gevoelsuitingen -+ gevoelswaarden -+ gevolglijke -+ gevolksdanst -+ gevolleerd -+ gevolleybald -+ gevolleyd -+ gevoosd -+ gevraag -+ gevriesdroogd -+ gevut -+ gewafeld -+ gewafelde -+ gewapper -+ gewasbescherming -+ gewasbeschermingsmiddel -+ gewaterfietst -+ gewebsurft -+ geweersalvo -+ geweersalvo's -+ geweervet -+ gewelddelict -+ gewelddelicten -+ geweldexplosie -+ geweldexplosies -+ geweldigen -+ geweldinstructie -+ geweldinstructies -+ geweldmisdrijf -+ geweldmisdrijven -+ geweldsdaad -+ geweldsdaden -+ geweldsdelict -+ geweldsdelicten -+ geweldsexplosie -+ geweldsexplosies -+ geweldsgolf -+ geweldsinstructie -+ geweldsinstructies -+ geweldsmiddel -+ geweldsmisdrijf -+ geweldsmisdrijven -+ geweldspiraal -+ geweldsscène -+ geweldsscènes -+ geweldsspiraal -+ geweldsuitbarsting -+ geweldsuitbarstingen -+ gewenningsperiode -+ gewenningsproces -+ gewestexecutieve -+ gewestexecutieven -+ gewestminister -+ gewestministers -+ gewestplan -+ gewestplannen -+ gewestregering -+ gewestregeringen -+ gewestvorming -+ gewetensbezwaarde -+ gewetensconflicten -+ gewichtheffer -+ gewichtheffers -+ gewichtigdoener -+ gewichtigdoeners -+ gewichtsbesparing -+ gewichtsbesparingen -+ gewichtscoëfficiënt -+ gewichtscoëfficiënten -+ gewichtsklassen -+ gewiebel -+ gewieberd -+ gewildwaterkanood -+ gewimperd -+ gewimperde -+ gewirwar -+ gewokt -+ gewolmaniseerd -+ gewondentransporten -+ gewoontedier -+ gewoontedieren -+ gewoontedrinker -+ gewoontedrinkers -+ gewoontegebaar -+ gewoontegebaren -+ gewoontegetrouwe -+ gewoontemens -+ gewoontemensen -+ geworkshopt -+ gewrichtsklachten -+ gewrichtsknobbel -+ gewrichtsknobbels -+ gewrichtsontsteking -+ gewrichtsontstekingen -+ gewrichtsziekten -+ gewrichtsziektes -+ geyahtzeed -+ geyeld -+ gezaghebbendheid -+ gezagsapparaat -+ gezagshandhaving -+ gezagspositie -+ gezagsstructuren -+ gezagsstructuur -+ gezagsuitoefening -+ gezagsvacuüm -+ gezagsvol -+ gezagsvolle -+ gezagvol -+ gezagvolle -+ gezandstraald -+ gezangenbundels -+ gezeefdrukt -+ gezekerd -+ gezelligheidsdier -+ gezelligheidsdieren -+ gezelligheidsleven -+ gezelligheidsverenigingen -+ gezelschapsdier -+ gezelschapsdieren -+ gezelschapsspelletje -+ gezemel -+ gezichtloos -+ gezichtloze -+ gezichtsbepalend -+ gezichtsbepalende -+ gezichtscentra -+ gezichtscentrum -+ gezichtshaar -+ gezichtsharen -+ gezichtshuid -+ gezichtslijn -+ gezichtslijnen -+ gezichtsloos -+ gezichtsmasker -+ gezichtsmaskers -+ gezichtsscherpte -+ gezichtssluier -+ gezichtssluiers -+ gezichtsstoornis -+ gezichtsstoornissen -+ gezichtsuitdrukking -+ gezied -+ gezigzagd -+ gezinsauto's -+ gezinsbijslag -+ gezinsbudgets -+ gezinsbudgetten -+ gezinsfles -+ gezinsflessen -+ gezinshelpsters -+ gezinshereniging -+ gezinsherenigingen -+ gezinshulpen -+ gezinsinkomens -+ gezinskaarten -+ gezinssociologie -+ gezinstaak -+ gezinstaken -+ gezinstherapeut -+ gezinstherapie -+ gezinstherapieën -+ gezinstoelage -+ gezinstoelagen -+ gezinstoelages -+ gezinsverdunning -+ gezinsverpakkingen -+ gezinsvervangende -+ gezinsvorming -+ gezinswagens -+ gezinszorg -+ gezipt -+ gezoek -+ gezondheidsbril -+ gezondheidsbrillen -+ gezondheidscentra -+ gezondheidscertificaat -+ gezondheidscertificaten -+ gezondheidsindex -+ gezondheidsindexen -+ gezondheidsindices -+ gezondheidskunde -+ gezondheidsonderzoek -+ gezondheidsorganisatie -+ gezondheidspsychologie -+ gezondheidsraad -+ gezondheidsregel -+ gezondheidsregels -+ gezondheidsschade -+ gezondheidsvoorziening -+ gezondheidsvoorzieningen -+ gezondheidswerker -+ gezondheidswerkers -+ gezondheidswet -+ gezondheidswetenschappen -+ gezondheidswetten -+ gezondheidszaken -+ gezondheidszorgbeleid -+ gezondmakertje -+ gezondmakertjes -+ gezuig -+ gezwaai -+ gezwalk -+ gezwateld -+ gezweed -+ gezweemd -+ gezwem -+ gezwijmel -+ gezwoeg -+ geëenendertigd -+ geëmaneerd -+ geëmballeerd -+ geëmmerd -+ geëmulgeerd -+ geënquêteerden -+ geëntertaind -+ geëpateerd -+ geërotiseerd -+ geëskimoteerd -+ geësthetiseerd -+ geëuropeaniseerd -+ geëuthanaseerd -+ geëvaporeerd -+ geëvoceerd -+ geëvoqueerd -+ geëxciteerd -+ geëxecuteerden -+ geëxpatrieerd -+ geëxperimenteer -+ geëxtensiveerd -+ geïdeologiseerd -+ geïmkerd -+ geïmmatriculeerd -+ geïmmobiliseerd -+ geïmplanteerd -+ geïmplodeerd -+ geïnactiveerd -+ geïncrimineerd -+ geïncrimineerde -+ geïnfantiliseerd -+ geïnformatiseerd -+ geïnsemineerd -+ geïnstigeerd -+ geïntendeerd -+ geïntensifieerd -+ geïntercepteerd -+ geïnterlinieerd -+ geïnternaliseerd -+ geïnternationaliseerd -+ geïnterneerden -+ geïnternet -+ geïnternetbankierd -+ geïnvalideerd -+ geïnverteerden -+ geïnvolveerdheid -+ geïriseerd -+ geïrriteerder -+ geïrriteerdheid -+ geïslamiseerd -+ geïsoleerder -+ geïsomeriseerd -+ geïtalianiseerd -+ geünzipt -+ geüpload -+ gft -+ gft-afval -+ ghazel -+ ghazele -+ ghazelen -+ ghazidsja -+ ghi -+ ghibil -+ ghostwriters -+ gibbsenergie -+ gideonsbende -+ gidsfossiel -+ gidsfossielen -+ gidsfunctie -+ gidsland -+ gidslanden -+ gidsrol -+ gidste -+ giebelde -+ giebelen -+ giechelige -+ giechels -+ giecheltje -+ gierkar -+ gierkarren -+ gierkelder -+ gierkelders -+ gierkuil -+ gierkuilen -+ gierput -+ gierputten -+ giertanks -+ gierton -+ giertonnen -+ gietbeton -+ giethars -+ gifbelt -+ gifbelten -+ gifgasgranaat -+ gifgasgranaten -+ gifgroen -+ gifgroene -+ gifgronden -+ gifkikker -+ gifkikkers -+ gifpieper -+ gifpiepers -+ gifpijl -+ gifpijlen -+ gifpil -+ gifpillen -+ giframp -+ giframpen -+ gifschepen -+ gifschip -+ gifspuit -+ gifspuiten -+ giftshop -+ giftshops -+ gifvat -+ gifvaten -+ gifwijken -+ gifwolken -+ gigawatt -+ gigawatts -+ gigs -+ gigues -+ gijzelaarskamp -+ gijzelhouder -+ gijzelhouders -+ gijzelingen -+ gijzelingszaak -+ gijzelingszaken -+ gijzelnemer -+ gijzelnemers -+ gijzelneming -+ gijzelnemingen -+ gildeboek -+ gildeboeken -+ gildebroeder -+ gildebroeders -+ gildehuis -+ gildehuizen -+ gildekamer -+ gildekamers -+ gildekeur -+ gildekeuren -+ gildemeester -+ gildemeesters -+ gildeproef -+ gildeproeven -+ gilderecht -+ gilderechten -+ gildes -+ gildewezen -+ giller -+ gillerig -+ gillerige -+ gillers -+ gilles-de-la-tourettesyndroom -+ gin-tonic -+ ginderachter -+ ginter -+ gipsbenen -+ gipskamer -+ gipskamers -+ gipskruid -+ gipsmasker -+ gipsmaskers -+ gipsmodel -+ gipsmodellen -+ gipsvlucht -+ gipsvluchten -+ gipsy's -+ giraffenhals -+ giraffenhalzen -+ giraffennek -+ giraffennekken -+ giraffetje -+ girafje -+ girlpower -+ giro-envelop -+ giro-enveloppen -+ giro-overschrijving -+ giro-overschrijvingen -+ giroafrekening -+ giroafrekeningen -+ giroafschrift -+ girobetaling -+ girobetalingen -+ giroboekjes -+ girokaarten -+ girokantoren -+ giromaatpas -+ giromaatpassen -+ giromaten -+ girondijnen -+ girondijns -+ girondijnse -+ girootje -+ giropassen -+ gistcel -+ gistcellen -+ gister -+ gistingen -+ gistvlok -+ gitaarakkoord -+ gitaarmuziek -+ gitaaronderdeel -+ gitaarpop -+ gitaarrock -+ gitaarspel -+ glaceetje -+ glacialen -+ gladgekamd -+ gladgemaakt -+ gladgewreven -+ gladjakker -+ gladjakkers -+ gladkammen -+ gladslijpen -+ gladwrijven -+ glamourfoto -+ glamourfoto's -+ glamourwereld -+ glanspapier -+ glansrollen -+ glas-in-loodraam -+ glasaaltje -+ glasaaltjes -+ glasareaal -+ glasarealen -+ glasbreuken -+ glascultuur -+ glasdichte -+ glasfabricage -+ glasgordijn -+ glasgordijnen -+ glasharmonica's -+ glaskunstenaar -+ glaskunstenaars -+ glasserviezen -+ glassnijders -+ glasstraalde -+ glasstralen -+ glasteelt -+ glastuinbouwbedrijf -+ glastuinbouwer -+ glastuinbouwers -+ glasverf -+ glasverwerkend -+ glasverwerkende -+ glasverzekeringen -+ glaswanden -+ glazendoek -+ glazendoeken -+ glazenspoeler -+ glazenspoelers -+ glazuurlaag -+ glazuurlagen -+ gletsjerdal -+ gletsjerdalen -+ gleufhoed -+ gleufhoeden -+ glijbekisting -+ glijcontact -+ glijcontacten -+ glijder -+ glijders -+ glijgoten -+ glijijzer -+ glijijzers -+ glijmiddel -+ glijvlak -+ glijvlakken -+ glimpieper -+ glimpiepers -+ glitterjurk -+ glitterjurken -+ glitterkostuum -+ glitterkostuums -+ glitterpak -+ glitterpakken -+ glitterrock -+ glitters -+ glo -+ global positioning system -+ globalist -+ globalisten -+ globen -+ gloeikous -+ gloeikousen -+ gloeilichaam -+ gloeilichamen -+ gloria's -+ gloriejaren -+ glorietijden -+ gloscholen -+ gloschool -+ glossy's -+ glottisslag -+ glottisslagen -+ gloxinia's -+ glutenbroden -+ glycolen -+ glühwein -+ gnostische -+ go-getter -+ go-getters -+ goalgetters -+ goalies -+ goaltjesdieven -+ gocarts -+ godallemachtig -+ godbetert -+ goddomme -+ godenbeeld -+ godenbeelden -+ godenzonen -+ godenzoon -+ godgelijk -+ godgelijke -+ godsbeelden -+ godsbesef -+ godsbewijs -+ godsbewijzen -+ godsdienstfanaat -+ godsdienstfanaten -+ godsdienstgeschiedenis -+ godsdienstpsychologie -+ godsdienstsociologen -+ godsdienstsociologie -+ godsdienstsocioloog -+ godservaring -+ godservaringen -+ godsgemeenschap -+ godsgeschenk -+ godsgeschenken -+ godsgetuige -+ godsgetuigen -+ godslasterend -+ godslasterende -+ godsliederlijk -+ godsliederlijke -+ godsonmogelijke -+ godsopenbaring -+ godsopenbaringen -+ godsstad -+ godsvoorstelling -+ godsvoorstellingen -+ godswonder -+ godswonderen -+ godswoord -+ godswoorden -+ godtergend -+ godtergende -+ godver -+ goedachten -+ goedbedoeld -+ goedbedoelde -+ goedbetaald -+ goedbetaalde -+ goeddoen -+ goederenexport -+ goederenoverslag -+ goederentermijnhandel -+ goedgeacht -+ goedgebekt -+ goedgebekte -+ goedgedaan -+ goedgekozen -+ goedgelegd -+ goedgeluimd -+ goedgeluimde -+ goedgemutst -+ goedgemutste -+ goedgeschreven -+ goedgeïnformeerd -+ goedgeïnformeerde -+ goedkeuringstermijn -+ goedkeuringstermijnen -+ goedleggen -+ goednieuwsshow -+ goednieuwsshows -+ goedschrift -+ goedwillend -+ goedwillendheid -+ goeiige -+ goenagoena -+ gogen -+ gogme -+ gogogirls -+ goh -+ gojse -+ gokbaas -+ gokbazen -+ gokhuis -+ gokhuizen -+ gokkast -+ gokkasten -+ goklustigen -+ gokpaleis -+ gokpaleizen -+ gokspelletje -+ goksyndicaat -+ goktent -+ goktenten -+ gokverslaafde -+ gokverslaafden -+ golden delicious -+ golden retriever -+ golden retrievers -+ golfbad -+ golfbaden -+ golfbal -+ golfballen -+ golfballetje -+ golfbereik -+ golfcourses -+ golfer -+ golfers -+ golfkarton -+ golfpatronen -+ golfpatroon -+ golfplaat -+ golfplaten -+ golfslagbaden -+ golfstaat -+ golfstaten -+ golfstick -+ golfsticks -+ golfte -+ golfterrein -+ golfterreinen -+ golftheorie -+ golftoppen -+ golfvelden -+ goliaths -+ gomarist -+ gomaristen -+ gomharsen -+ gomma -+ gommakoekje -+ gommakoekjes -+ gonaden -+ gondellift -+ gondelliften -+ gondola's -+ goniometer -+ goniometers -+ goocheldoos -+ goocheldozen -+ goocheltrucs -+ goodwillambassadeur -+ goodwillambassadeurs -+ goodwillmissie -+ goodwillmissies -+ goodwillreis -+ goodwillreizen -+ googel -+ googelde -+ googelen -+ googelt -+ gooi-en-smijtfilm -+ gooi-en-smijtfilms -+ gooi-en-smijtwerk -+ gootlijst -+ gootsteenkastje -+ gootsteenkastjes -+ gordelde -+ gordelen -+ gordijnlat -+ gordijnlatten -+ gordijnrails -+ gordijnroedes -+ gortepap -+ gortpap -+ gospelachtig -+ gospelachtige -+ gospelmuziek -+ gospelsinger -+ gospelsingers -+ gospelsong -+ gospelsongs -+ gospelzang -+ gossie -+ goth -+ gothic novel -+ gothic novels -+ goths -+ gottegot -+ gouaches -+ goudwinkel -+ zilverwinkel -+ goudwinkels -+ zilverwinkels -+ goudachtig -+ goudachtige -+ goudborduursel -+ goudbronzen -+ goudenmedaillewinnaar -+ goudenmedaillewinnaars -+ goudgalon -+ goudgehalten -+ goudgehaltes -+ goudgerand -+ goudgerande -+ goudhaan -+ goudhamster -+ goudhamsters -+ goudhanen -+ goudkarper -+ goudkarpers -+ goudkorreltje -+ goudkusten -+ goudlaag -+ goudlagen -+ goudmarkt -+ goudmarkten -+ goudomrand -+ goudomrande -+ goudplevier -+ goudplevieren -+ goudprijs -+ goudprijzen -+ goudproductie -+ goudreserves -+ goudschaaltje -+ goudstaaf -+ goudstaven -+ goudverf -+ goudverkoop -+ goudverkopen -+ goudvissenkom -+ goudvissenkommen -+ goudvoorraden -+ goudwinning -+ gourmands -+ gourmetstel -+ gourmetstellen -+ gourmette -+ gps -+ graafarm -+ graafarmen -+ graafwerktuig -+ graafwerktuigen -+ graafwerkzaamheden -+ graaicultuur -+ graanboer -+ graanboeren -+ graanexport -+ graanexporteur -+ graanexporteurs -+ graanjenever -+ graanjenevers -+ graanmolen -+ graanmolens -+ graansilo's -+ graansilootje -+ graanveld -+ graanvelden -+ graatmager -+ graatmagere -+ grabbelaar -+ grabbelaars -+ grabbeltonnen -+ grachtenhuis -+ grachtenhuizen -+ grachtenwater -+ grachtwater -+ gradenbogen -+ gradenboog -+ gradering -+ graderingen -+ graduaten -+ grafdelvers -+ grafdicht -+ grafdichten -+ grafemen -+ graffitikunstenaar -+ graffitikunstenaars -+ graffitischrijver -+ graffitischrijvers -+ grafgedicht -+ grafgedichten -+ grafgift -+ grafiekblad -+ grafiekbladen -+ grafietreactor -+ grafietreactoren -+ graflucht -+ grafplaat -+ grafplaten -+ grafredes -+ grafsculpturen -+ grafsculptuur -+ grafstuk -+ grafstukken -+ graftempel -+ graftempels -+ grafvaas -+ grafvazen -+ gramequivalent -+ gramequivalenten -+ grammaire -+ grammaires -+ grammaticaliteit -+ grammaticaonderwijs -+ grammofoonnaald -+ grammofoonnaalden -+ grammoleculen -+ grammolecules -+ granaataanval -+ granaataanvallen -+ granaathuls -+ granaathulzen -+ granaatinslag -+ granaatinslagen -+ granaatsteen -+ granaatwerper -+ granaatwerpers -+ grand prix -+ grand slam -+ grand slams -+ grand-prixtoernooi -+ grand-prixtoernooien -+ grand-prixwedstrijd -+ grand-prixwedstrijden -+ grande's -+ grands prix -+ grandslamcup -+ grandslamevenement -+ grandslamfinale -+ grandslamfinales -+ grandslamtitel -+ grandslamtitels -+ grandslamtoernooien -+ grandslamzege -+ grandslamzeges -+ granietachtig -+ granietachtige -+ granman -+ granmans -+ granny smith -+ granny smiths -+ grannysmithappel -+ grannysmithappels -+ granulaten -+ grapdichtheid -+ grapefruits -+ grapjasserij -+ grapjaste -+ grasbaan -+ grasbaanrace -+ grasbaanraces -+ grasbanen -+ grasberm -+ grasbermen -+ grasgemaaid -+ grashalmpje -+ graskant -+ graskanten -+ graskarper -+ graskarpers -+ grasklokje -+ grasklokjes -+ grasluis -+ grasluizen -+ grasmaaien -+ grasmaaier -+ grasmaaiers -+ grasmaaimachine -+ grasmaaimachines -+ grasmatten -+ grasparkiet -+ grasparkieten -+ grasplant -+ grasplanten -+ graspol -+ graspollen -+ graspolletje -+ grassoort -+ grassteppe -+ grassteppen -+ grassteppes -+ grastennistoernooi -+ gratieerde -+ gratieverlening -+ gratieverzoeken -+ gratificeerde -+ gratineerde -+ gratiëring -+ grauwschimmel -+ grauwschimmels -+ grauwsluiers -+ grauwwit -+ grauwwitte -+ grauwzwart -+ grauwzwarte -+ gravelbaan -+ gravelbanen -+ gravelbijter -+ gravelbijters -+ gravelseizoen -+ gravelspecialist -+ gravelspecialisten -+ gravelspeler -+ gravelspelers -+ graveltoernooi -+ graveltoernooien -+ gravering -+ graveringen -+ gravitatielens -+ gravitatielenzen -+ gravitatieveld -+ gravitatievelden -+ grazer -+ grazers -+ greens -+ grensakkoord -+ grensbewaking -+ grenscontrole -+ grenscontroles -+ grensganger -+ grensgangers -+ grensgeschil -+ grensgeschillen -+ grenslaag -+ grensland -+ grenslanden -+ grensoorlog -+ grensoorlogen -+ grensoverschrijding -+ grenspolitie -+ grensprovincie -+ grensprovincies -+ grensregio's -+ grensschending -+ grensschendingen -+ grenssituatie -+ grenssituaties -+ grensstaat -+ grensstad -+ grensstaten -+ grenssteden -+ grensstreek -+ grensstreken -+ grenstroepen -+ grensverdrag -+ grensverdragen -+ grensvervaging -+ grensvervagingen -+ grensvlak -+ grensvlakken -+ grenswijziging -+ grenswijzigingen -+ grenswisselkantoor -+ grenswisselkantoren -+ griek -+ grieken -+ griendbos -+ griendbossen -+ griendland -+ griendlanden -+ griepaanval -+ griepaanvallen -+ griepachtig -+ griepachtige -+ griepepidemies -+ grieperige -+ griepprik -+ griepprikken -+ griepvaccinatie -+ griepvaccinaties -+ griepvaccins -+ griepvirus -+ griepvirussen -+ grietjebie -+ grietjebies -+ grietman -+ grietmannen -+ grieventrommel -+ griezeleffect -+ griezeleffecten -+ griezelkabinet -+ griezelroman -+ griezelromans -+ griffierecht -+ griffierechten -+ griffoen -+ griffoenen -+ grijparm -+ grijparmen -+ grijpbaar -+ grijpgraag -+ grijpgrage -+ grijpstaartaap -+ grijpstaartapen -+ grijs-wit -+ grijs-witte -+ grijs-zwart -+ grijs-zwarte -+ grijsgedraaid -+ grijsgedraaide -+ grijsrijden -+ grijsrijder -+ grijsrijders -+ grijszwart -+ grijszwarte -+ grilles -+ grillpan -+ grillpannen -+ grills -+ grimmigheden -+ grindgaten -+ grindpaden -+ grindwinning -+ grizzly -+ grizzly's -+ groei-explosie -+ groei-impuls -+ groei-impulsen -+ groei-industrie -+ groei-initiatief -+ groei-initiatieven -+ groei-jaar -+ groei-jaren -+ groeiachterstand -+ groeibon -+ groeibrief -+ groeicurven -+ groeicurves -+ groeiers -+ groeigebied -+ groeigebieden -+ groeigemeente -+ groeigemeenten -+ groeigemeentes -+ groeihypotheek -+ groeihypotheken -+ groeiplaats -+ groeiplaatsen -+ groeipolen -+ groeipool -+ groeipunt -+ groeipunten -+ groeischijf -+ groeischijven -+ groeisector -+ groeisnelheid -+ groeistad -+ groeisteden -+ groeistof -+ groeistoffen -+ groeistoornis -+ groeistoornissen -+ groeitempo -+ groeitijd -+ groeitijden -+ groeitop -+ groeitoppen -+ groeivertragend -+ groeivertragende -+ groenbeheer -+ groenbemestingen -+ groenetruidrager -+ groengebied -+ groengebieden -+ groengeel -+ groengele -+ groengordels -+ groenhart -+ groenpootruiter -+ groenpootruiters -+ groenstroken -+ groenstrook -+ groenteafval -+ groentebouillon -+ groenteburger -+ groenteburgers -+ groentehallen -+ groentehandelaar -+ groentekar -+ groentekarren -+ groentemannen -+ groentemarkt -+ groentemarkten -+ groentesap -+ groentesappen -+ groenteschotel -+ groenteschotels -+ groentesoepen -+ groenteteelt -+ groenteteler -+ groentetelers -+ groentetuin -+ groentetuinen -+ groentezaak -+ groenvoorziening -+ groenvoorzieningen -+ groenzone -+ groenzones -+ groepages -+ groepsactiviteit -+ groepscode -+ groepscodes -+ groepscommandant -+ groepscommandanten -+ groepsdans -+ groepsdansen -+ groepsdenken -+ groepsgevoelens -+ groepsleidster -+ groepsleidsters -+ groepsnormen -+ groepsportretten -+ groepspraktijken -+ groepsreizen -+ groepsseks -+ groepstaal -+ groepstalen -+ groepstarieven -+ groepsverbanden -+ groepsverkrachtingen -+ groeves -+ grofgebekt -+ grofgebekte -+ grofmazig -+ grofmazige -+ grofstoffelijk -+ grofstoffelijke -+ groftes -+ grondaanwinningen -+ grondbeleid -+ grondboor -+ grondboren -+ gronddoel -+ gronddoelen -+ gronddoelraket -+ gronddoelraketten -+ grondfout -+ grondfouten -+ grondgebieden -+ grondgevecht -+ grondgevechten -+ grondhuur -+ grondingen -+ grondkapitaal -+ grondlak -+ grondleggingen -+ grondlegsters -+ grondmonsters -+ grondoefening -+ grondoefeningen -+ grondoffensief -+ grondoffensieven -+ grondonderzoek -+ grondontsmetter -+ grondontsmetters -+ grondoorlog -+ grondoorlogen -+ grondoppervlak -+ grondpatronen -+ grondprobleem -+ grondproblemen -+ grondradar -+ grondradars -+ grondruil -+ grondslagverbreding -+ grondstem -+ grondstemmen -+ grondstewardess -+ grondstewardessen -+ grondstoffenprijs -+ grondstoffenprijzen -+ grondstoffenvoorraad -+ grondstoffenvoorraden -+ grondstrijdkrachten -+ grondstromen -+ grondstroom -+ grondstructuren -+ grondstructuur -+ grondvergadering -+ grondvergaderingen -+ grondverkoop -+ grondverkopen -+ grondverzet -+ grondverzetmachine -+ grondverzetmachines -+ grondvoorwaarde -+ grondvoorwaarden -+ grondwaarde -+ grondwaarden -+ grondwaterbeheer -+ grondwaterstanden -+ grondwaterstromen -+ grondwaterstroom -+ grondwatervervuiling -+ grondwaterwinning -+ grondwetgevend -+ grondwetgevende -+ grondwetshervorming -+ grondwetshervormingen -+ grondwettelijkheid -+ grondwind -+ grondwinden -+ grootayatollah -+ grootayatollahs -+ grootbladig -+ grootbladige -+ grootgebruiker -+ grootgebruikers -+ grootgehouden -+ groothandelsorganisatie -+ groothoeklens -+ groothoeklenzen -+ groothouden -+ grootlint -+ grootlinten -+ grootma's -+ grootmama's -+ grootmeestertitel -+ grootmetaal -+ grootmoedertje -+ grootoom -+ grootooms -+ grootopperhoofd -+ grootopperhoofden -+ grootordeteken -+ grootpa's -+ grootseminarie -+ grootseminaries -+ grootsprakerig -+ grootsprakerige -+ grootstad -+ grootstedelijk -+ grootstedelijke -+ grootsteden -+ groottante -+ groottantes -+ grootteorde -+ grootteorden -+ grootteordes -+ grootvadertje -+ grootvee -+ grootverdiener -+ grootverdieners -+ grootwarenhuis -+ grootwarenhuizen -+ grosprijs -+ grosprijzen -+ grossist -+ grossisten -+ grotbewoners -+ grotchampignon -+ grotchampignons -+ groteletterboeken -+ grotemensenwereld -+ grotestadsbewoner -+ grotestadsbewoners -+ grotestadsleven -+ grottekening -+ grottekeningen -+ grotwoning -+ grotwoningen -+ gruisdeeltje -+ gruisdeeltjes -+ grungegroep -+ grungegroepen -+ grutto's -+ gruwelbeeld -+ gruwelbeelden -+ gruwelkabinet -+ gsm's -+ gsm-nummer -+ gsm-nummers -+ guacamole -+ guave -+ guaven -+ guaves -+ guavesap -+ guerrilla-aanvallen -+ guerrilla-actie -+ guerrilla-acties -+ guerrilla-eenheden -+ guerrilla-eenheid -+ guerrillabeweging -+ guerrillabewegingen -+ guerrillagroep -+ guerrillaleger -+ guerrillalegers -+ guerrillaleider -+ guerrillaleiders -+ guerrillastrijd -+ guerrillastrijders -+ guesthouse -+ guesthouses -+ guipures -+ guldentekens -+ gummi-jassen -+ gunnera's -+ gunstprijs -+ gunstprijzen -+ gunsttarief -+ gunsttarieven -+ gunstvoorwaarden -+ guppen -+ gut -+ gymleraar -+ gymleraars -+ gymleraren -+ gymles -+ gymlessen -+ gymlokalen -+ gymnasiastes -+ gymnasiumdiploma -+ gymnasiumdiploma's -+ gymnasiumopleiding -+ gymnasiumopleidingen -+ gymnasiumtijd -+ gymnastiekleraar -+ gymnastiekleraars -+ gymnastiekleraren -+ gymnastiekoefening -+ gymnastiekoefeningen -+ gymnastiekzaal -+ gymnastiekzalen -+ gympen -+ gympje -+ gympjes -+ gymschoen -+ gymzalen -+ gynaecologes -+ gyrokompassen -+ gyros -+ götterdämmerung -+ h's -+ h'tje -+ haag -+ haaienbek -+ haaienbekken -+ haakbout -+ haakbouten -+ haaknagel -+ haaknagels -+ haakneuzen -+ haakpatronen -+ haaksluiting -+ haaksluitingen -+ haaksteek -+ haaksteken -+ haakster -+ haaksters -+ haantje-de-voorste -+ haantjes-de-voorste -+ haarbal -+ haarballen -+ haarcilinder -+ haarcilinders -+ haarcrème -+ haarcrèmes -+ haardossen -+ haardot -+ haardotten -+ haardstedengeld -+ haardvuren -+ haarföhn -+ haarföhns -+ haargrenzen -+ haarinplant -+ haarkleur -+ haarkleuren -+ haarkroon -+ haarkrul -+ haarkrullen -+ haarkrullers -+ haarlakken -+ haarlemmerolie -+ haarmode -+ haarmodes -+ haarscheiding -+ haarscheidingen -+ haarschimmel -+ haarsnit -+ haarsprays -+ haarstilist -+ haarstilisten -+ haarstukjes -+ haarvatennet -+ haarverf -+ haarverstevigers -+ haarvilt -+ haarzakje -+ haarzakjes -+ haarzuiver -+ haat-liefdeverhouding -+ haat-liefdeverhoudingen -+ haatcampagne -+ haatcampagnes -+ haatdragendheid -+ haatgevoelen -+ haatgevoelens -+ haatmail -+ haatmails -+ haciënda's -+ hack -+ hackt -+ hackte -+ hadeïcum -+ hadj -+ haflinger -+ haflingers -+ hagada -+ hageljachten -+ hagelpatronen -+ hagelpatroon -+ hagelstormen -+ hagenaar -+ hagenaars -+ hagiografieën -+ haiku's -+ hairsprays -+ hairstylisten -+ hakbal -+ hakballetje -+ hakbeschermer -+ hakbeschermers -+ hakbijlcomité -+ hakenkruisvlag -+ hakenkruisvlaggen -+ hakje -+ hakjes -+ hakkebord -+ hakkeborden -+ hakkenbars -+ hakketakte -+ hakstuk -+ hakstukken -+ halacha -+ halal -+ haldeuren -+ halfautomaat -+ halfautomaten -+ halfautomatisch -+ halfautomatische -+ halfbegrepen -+ halfbewust -+ halfbewuste -+ halfblind -+ halfblinde -+ halfbroertje -+ halfcirkelvormig -+ halfcirkelvormige -+ halfdode -+ halfdood -+ halfduistere -+ halfeen -+ halfezel -+ halfezels -+ halffabricaat -+ halffabricaten -+ halfgek -+ halfgekke -+ halfgeleider -+ halfgeleiderlaser -+ halfgeleiderlasers -+ halfgeleidermateriaal -+ halfgeleiders -+ halfgeopende -+ halfhoog -+ halflang -+ halflange -+ halfleren -+ halfluid -+ halfluide -+ halfnatuurlijk -+ halfnatuurlijke -+ halfpijler -+ halfpijlers -+ halfronde -+ halfslaap -+ halfspelers -+ halftijds -+ halftijdse -+ halftint -+ halftinten -+ halfuren -+ halfuurtje -+ halfvergeten -+ halfverheven -+ halfvet -+ halfvette -+ halfvocaal -+ halfvocalen -+ halfwollen -+ halfzeven -+ halfzus -+ halfzussen -+ halfzwaar -+ halfzwaargewicht -+ halfzwaargewichten -+ halfzware -+ halleluja's -+ hallucinante -+ hallucinanten -+ hallucinatoire -+ hallucinogene -+ hallucinogenen -+ halo's -+ halo-effecten -+ halogeenlicht -+ halogene -+ halsbandparkiet -+ halsbandparkieten -+ halsgewricht -+ halsgewrichten -+ halslijn -+ halslijnen -+ halsopening -+ halsopeningen -+ halsreikend -+ halssieraad -+ halssieraden -+ halsslagader -+ halsslagaderen -+ halsslagaders -+ halsuitsnijding -+ halsuitsnijdingen -+ halszenuw -+ halszenuwen -+ haltepaal -+ haltepalen -+ haltertruitje -+ haltertruitjes -+ halvaproduct -+ halvaproducten -+ halvefinaleplaats -+ halvefinalist -+ halvefinalisten -+ halvegaren -+ halveringstijden -+ hamam -+ hamams -+ hamansoren -+ hamas -+ hamburgerketen -+ hamburgerketens -+ hamburgerrestaurant -+ hamburgerrestaurants -+ hamburgertent -+ hamburgertenten -+ hamergooien -+ hamerhaai -+ hamerhaaien -+ hamerslingeren -+ hamertenen -+ hamertje-tik -+ hammondorgels -+ hamschijf -+ hamschijven -+ hamstervoorraden -+ hamsterwoede -+ hamstrings -+ hamvragen -+ hand-en-spandiensten -+ hand-outs -+ handalfabet -+ handarbeid -+ handarbeider -+ handbalcoach -+ handbalcoaches -+ handballer -+ handballers -+ handbalteam -+ handbalteams -+ handbeugel -+ handbeugels -+ handbezem -+ handbezems -+ handbibliotheek -+ handbijl -+ handbijlen -+ handbike -+ handbikes -+ handblusapparaten -+ handboogschieten -+ handcamera's -+ handcrème -+ handcrèmes -+ handdouches -+ handdroge -+ handdynamo's -+ handeldrijven -+ handelgedreven -+ handelingssnelheid -+ handelingsvermogen -+ handelingsvrijheid -+ handelsbalansoverschot -+ handelscompagnies -+ handelscompagnieën -+ handelsconcessie -+ handelsconcessies -+ handelsdoeleinden -+ handelsedities -+ handelsfoor -+ handelsgebied -+ handelsgebieden -+ handelsgewassen -+ handelshaven -+ handelshavens -+ handelsingenieur -+ handelsingenieurs -+ handelskapitalen -+ handelsroute -+ handelsrouten -+ handelsroutes -+ handelstekort -+ handelstekorten -+ handelsvaart -+ handelsverenigingen -+ handelsvertegenwoordiging -+ handenarbeidlokaal -+ handenarbeidlokalen -+ handenbinders -+ handenwrijvende -+ handenwringen -+ handenwringende -+ handexemplaar -+ handexemplaren -+ handgekleurd -+ handgekleurde -+ handgeknoopt -+ handgeknoopte -+ handgemaakt -+ handgemaakte -+ handgeschakeld -+ handgeschept -+ handgeschepte -+ handgevormde -+ handgewrichten -+ handhaafbaar -+ handhaafbaarheid -+ handhaafbare -+ handhavingsbeleid -+ handigheidjes -+ handklavier -+ handklavieren -+ handknie -+ handknieën -+ handlezers -+ handlijn -+ handlijnen -+ handmixer -+ handmixers -+ handoplegger -+ handopleggers -+ handrug -+ handruggen -+ handruiker -+ handruikers -+ hands -+ handsbal -+ handschoenenkastjes -+ handschoenkastjes -+ handschoentje -+ handsfree -+ handspel -+ handspiegels -+ handspiegeltje -+ handstanden -+ handtekeningenacties -+ handtekeningenjager -+ handtekeningenjagers -+ handtekeningenlijst -+ handtekeningenlijsten -+ handvaardige -+ handvaardigheden -+ handverzorging -+ handvuurwapen -+ handvuurwapens -+ handwapen -+ handwapens -+ handwas -+ handwerkjes -+ handwortelbeentjes -+ handzetten -+ hanenkammen -+ hanenpoot -+ hang-legkast -+ hang-legkasten -+ hangborst -+ hangborsten -+ hangbuikzwijn -+ hangbuikzwijnen -+ hangbuikzwijntje -+ hangglide -+ hangglidede -+ hanggliden -+ hanggliders -+ hangglidet -+ hanggliding -+ hangjongeren -+ hangplek -+ hangplekken -+ hangpunt -+ hangpunten -+ hangpuntenbrief -+ hangpuntennota -+ hangpuntennota's -+ hangsnorren -+ hanigheid -+ hanteerbaarheid -+ hapaxen -+ happenings -+ happy ends -+ happy hour -+ hapsnap -+ hapsnapbeleid -+ haptische -+ haptonomen -+ haram -+ hard-boiled -+ hardblauw -+ hardblauwe -+ hardcoreband -+ hardcorebands -+ hardcovers -+ harddisks -+ harddrugs -+ hardeschijfactiviteit -+ hardeschijfruimte -+ hardgekookte -+ hardgelopen -+ hardgemaakt -+ hardglas -+ hardgroen -+ hardgroene -+ hardheidsgraad -+ hardloopschoen -+ hardloopschoenen -+ hardloopwedstrijd -+ hardloopwedstrijden -+ hardmaken -+ hardrockband -+ hardrockbands -+ hardrockers -+ hardrood -+ hardvoer -+ hare -+ hare krisjna -+ hare krisjna's -+ harembroek -+ harembroeken -+ haricots verts -+ haringkar -+ haringkarren -+ haringsalades -+ haringscholen -+ harlekijnen -+ harlekijntje -+ harmonicaatje -+ harmonicabedden -+ harmonicabus -+ harmonicabussen -+ harmonicadeur -+ harmonicadeuren -+ harmonicaspelers -+ harmonicawanden -+ harmoniegezelschappen -+ harmoniekapellen -+ harmonisaties -+ harmoniseerde -+ harmonisering -+ harmoniseringen -+ harpconcerten -+ harpenistes -+ harpijarend -+ harpijarenden -+ harpistes -+ harpmuziek -+ harpoengeweer -+ harpoengeweren -+ harses -+ hart-longmachine -+ hart-longmachines -+ hartaanvallen -+ hartafwijkingen -+ hartchirurgen -+ hartchirurgisch -+ hartchirurgische -+ hartdood -+ hartenbeest -+ hartenbeesten -+ hartenjagen -+ hartenkloppen -+ hartenkreten -+ hartenlap -+ hartenlappen -+ hartenliefjes -+ hartenwensen -+ hartfunctie -+ harthout -+ hartigheden -+ hartinfarcten -+ hartjesdag -+ hartkatheterisatie -+ hartklacht -+ hartlijn -+ hartlijnen -+ hartmassages -+ hartneurose -+ hartneurosen -+ hartneuroses -+ hartoperaties -+ hartpatiënten -+ hartpunt -+ hartpunten -+ hartritmes -+ hartritmestoornis -+ hartritmestoornissen -+ hartscheur -+ hartscheuren -+ hartsgrondig -+ hartsgrondige -+ hartslagmeter -+ hartslagmeters -+ hartspecialisten -+ hartspier -+ hartspieren -+ hartstilstand -+ hartstilstanden -+ hartstimulator -+ hartstimulatoren -+ hartstimulators -+ hartstoornis -+ hartstoornissen -+ harttoon -+ harttransplantaties -+ hartvergrotingen -+ hartverlammingen -+ hartversterker -+ hartversterkers -+ hartvlies -+ hartvliezen -+ hartzakje -+ hartzakjes -+ hartzwakte -+ hasjrokers -+ hasjsmokkel -+ hasjsmokkelaar -+ hasjsmokkelaars -+ hateenheden -+ hateenheid -+ hatemail -+ hatemails -+ hatsiekadee -+ hausseperiode -+ haut-reliëfs -+ haute-couturewinkel -+ haute-couturewinkels -+ havanna's -+ havenaanleg -+ havenbekken -+ havenbekkens -+ havengebied -+ havengebieden -+ haveningang -+ haveningangen -+ havenkom -+ havenkroeg -+ havenkroegen -+ havenkwartier -+ havenkwartieren -+ havenloods -+ havenloodsen -+ havenmonden -+ havenot -+ havenots -+ havenplaatsen -+ havenrechten -+ havenschap -+ havenschepen -+ havensleepdienst -+ havensleper -+ havenslepers -+ havenslib -+ havenwethouder -+ havenwethouders -+ havenwijk -+ havenwijken -+ haverkorrel -+ haverkorrels -+ havermoutpap -+ haverveld -+ havervelden -+ havervlok -+ haviksogen -+ haviksoog -+ havist -+ havisten -+ havo's -+ havo-examen -+ havo-examens -+ havo-opleiding -+ havo-opleidingen -+ havoadvies -+ havoadviezen -+ havodiploma -+ havodiploma's -+ havoleerling -+ havoleerlingen -+ havoër -+ havoërs -+ hawaïburger -+ hawaïburgers -+ hawaïhemd -+ hawaïhemden -+ hawkingstraling -+ hazelhoenderen -+ hazelhoenen -+ hazelnootreep -+ hazelnootrepen -+ hazendistel -+ hazendistels -+ hazenlippen -+ hazenruggen -+ hazewindhonden -+ hbo -+ hbo'ers -+ hbo-instelling -+ hbo-instellingen -+ hbo-niveau -+ hbo-opleiding -+ hbo-opleidingen -+ hbo-student -+ hbo-studenten -+ he -+ he-men -+ headbang -+ headbangde -+ headbangen -+ headbangt -+ headhunt -+ headhunten -+ headhuntersbureau -+ headhuntersbureaus -+ headhuntte -+ headset -+ headsets -+ healer -+ healers -+ healing -+ heao -+ heao-opleiding -+ heao-opleidingen -+ hearings -+ heats -+ heavy metal -+ hebbedingen -+ hebber -+ hebe -+ hebi -+ hebi's -+ hebraïca -+ hebraïst -+ hebraïsten -+ hechtmateriaal -+ hechtmaterialen -+ heckrund -+ heckrunderen -+ hectares -+ hectaretoeslag -+ hectaretoeslagen -+ hectiek -+ hedgefonds -+ hedjra -+ heek -+ heelheid -+ heemkundigen -+ heemparken -+ heemtuinen -+ heen-en-weerdienst -+ heen-en-weertje -+ heen-en-weertjes -+ heenbrengen -+ heengebracht -+ heengeleid -+ heengestapt -+ heengetrokken -+ heengevoerd -+ heenleiden -+ heenmatch -+ heenmatchen -+ heenmatches -+ heenronde -+ heenronden -+ heenrondes -+ heentrekken -+ heenvoeren -+ heenwedstrijd -+ heenwedstrijden -+ heest -+ heesterachtig -+ heesterachtige -+ heetwaterbron -+ heetwaterbronnen -+ hefboomarm -+ hefboomarmen -+ hefboomeffect -+ hefboompje -+ hefboomwerking -+ heffingsgrondslagen -+ heffingskorting -+ heffingskortingen -+ heffingsvrij -+ heffingsvrije -+ hefschroef -+ hefschroeven -+ heftruckchauffeur -+ heftruckchauffeurs -+ heftrucks -+ hefwagen -+ hefwagens -+ hegeliaans -+ hegeliaanse -+ hegemoniale -+ heggenmus -+ heggenmussen -+ heidelandschap -+ heidelandschappen -+ heides -+ heidestruik -+ heidestruiken -+ heikele -+ heikraan -+ heikranen -+ heiland -+ heilanden -+ heilbrengend -+ heilbrengende -+ heiligdomsvaart -+ heiligdomsvaarten -+ heiligendag -+ heiligendagen -+ heiligennaam -+ heiligennamen -+ heilsgebeuren -+ heilsleger -+ heilsprofeet -+ heilssoldaat -+ heilssoldate -+ heilssoldaten -+ heilsstaat -+ heilsstaten -+ heilsverwachtingen -+ heimat -+ heintjedavidseffect -+ heiploeg -+ heiploegen -+ heirbaan -+ heirbanen -+ heirkracht -+ heken -+ hekkens -+ hekkensluiters -+ hekpaal -+ hekpalen -+ heksengeloof -+ heksenjachten -+ heksenkrans -+ heksenkransen -+ heksenkruid -+ heksenmelk -+ heksensabbats -+ hektrawler -+ hektrawlers -+ hektreiler -+ hektreilers -+ helblauw -+ helblauwe -+ helblond -+ helblonde -+ heldencultus -+ heldenepos -+ heldenepossen -+ heldenfeiten -+ heldenontvangst -+ heldenverering -+ heldenvereringen -+ helderblauw -+ helderheidsverandering -+ helderheidsveranderingen -+ helderrode -+ helderrood -+ helderwit -+ helderwitte -+ helgeel -+ helgele -+ heli's -+ helices -+ helihavens -+ helikopteraanval -+ helikopteraanvallen -+ helikopterdekken -+ helikopterpiloot -+ helikopterpiloten -+ helingsproces -+ heliografen -+ heliosis -+ heliports -+ heliumatomen -+ heliumatoom -+ heliumkern -+ heliumkernen -+ hellehonden -+ helleniseerde -+ hellepoort -+ helletocht -+ hellingbaan -+ hellingbanen -+ hellingbos -+ hellingbossen -+ hellingmeter -+ hellingmeters -+ hellingproeven -+ helmbeplantingen -+ helmplanten -+ helmplicht -+ helpdesks -+ helverlicht -+ helverlichte -+ helwit -+ helwitte -+ hematologen -+ hematologische -+ hematomen -+ hemdblouse -+ hemdblouses -+ hemdjurken -+ hemelbedden -+ hemelbestormend -+ hemelbestormende -+ hemelbewoner -+ hemelbewoners -+ hemelblauw -+ hemelblauwe -+ hemelgloben -+ hemelgod -+ hemelgoden -+ hemelkaart -+ hemelkaarten -+ hemelreis -+ hemelruim -+ hemelteken -+ hemeltekenen -+ hemeltekens -+ hemeltjelief -+ hemelvaart -+ hemelvaarten -+ hemelverschijnsel -+ hemelverschijnselen -+ hemodialyse -+ hemofilielijders -+ hemofiliepatiënt -+ hemofiliepatiënten -+ hemotoxine -+ hemotoxinen -+ hemotoxines -+ hemotoxisch -+ hemotoxische -+ hengelsportvereniging -+ hengelsportverenigingen -+ hengstig -+ hengstige -+ hennepplant -+ hennepplanten -+ hennepvezel -+ hennepvezels -+ hepatitis B-injectie -+ hepatitis B-injecties -+ heptaëder -+ heptäeders -+ heraanplant -+ herbebossingsprogramma -+ herbebossingsprogramma's -+ herbeboste -+ herbegrafenis -+ herbegrafenissen -+ herbegraven -+ herbeleefd -+ herbeleefde -+ herbeleven -+ herbeleving -+ herbelevingen -+ herbeoordeling -+ herbeoordelingen -+ herberekeningen -+ herbestemming -+ herbestrating -+ herbevestigen -+ herbevestiging -+ herbewerking -+ herbewerkingen -+ herbezien -+ herbezinnen -+ herbronning -+ herculessen -+ herdefinitie -+ herdefiniëring -+ herdenkingsactiviteit -+ herdenkingsactiviteiten -+ herdenkingsdagen -+ herdenkingsjaar -+ herdenkingsplechtigheden -+ herdenkingsplechtigheid -+ herdenkingsrede -+ herdenkingsredes -+ herdenkingssteen -+ herdenkingsstenen -+ herdenkingsteken -+ herdenkingstekens -+ herdersjongen -+ herdersjongens -+ herdersmat -+ herderspoëzie -+ herdersroman -+ herdersverhaal -+ herdersverhalen -+ herdersvolken -+ herdersvolkeren -+ heremetijd -+ heremietkreeft -+ heremietkreeften -+ heremijntijd -+ herendubbels -+ herenigingsproces -+ herenliefde -+ herenmodezaak -+ herenmodezaken -+ herenondergoed -+ herenrijwiel -+ herenrijwielen -+ herensalons -+ herentoiletten -+ herexamineerde -+ herexamineren -+ herfinancierde -+ herfinanciering -+ herfinancieringsplan -+ herformuleringen -+ herfstavond -+ herfstavonden -+ herfstblad -+ herfstbladen -+ herfstbladeren -+ herfstblaren -+ herfstbos -+ herfstbossen -+ herfstkampioen -+ herfstkampioenen -+ herfstkleurig -+ herfstkleurige -+ herfstlucht -+ herfstluchten -+ herfstmanoeuvre -+ herfstochtenden -+ herfststorm -+ herfststormen -+ herfsttij -+ herfsttitel -+ herfsttitels -+ herfstvakanties -+ herfstzon -+ hergeboorte -+ hergeboorten -+ hergeboortes -+ hergebruiken -+ hergebruikte -+ herhaalbare -+ herhalingsrecept -+ herhalingsrecepten -+ herhuisvesten -+ herhuisvestte -+ heriheri -+ heringetreden -+ herinneringsboek -+ herinneringsboeken -+ herinneringsmedaille -+ herinneringsmedailles -+ herinrichten -+ herinrichtingskosten -+ herinrichtingsplan -+ herinrichtingsplannen -+ herinrichtte -+ herinterpretaties -+ herintrede -+ herintreden -+ herintreder -+ herintreders -+ herintroduceerde -+ herintroduceren -+ herintroductie -+ herinvesteringen -+ herinvoeren -+ herkansingsrace -+ herkansingsraces -+ herkenningsmelodieën -+ herkenningspunt -+ herkerstening -+ herkomstland -+ herkomstlanden -+ herlaadde -+ herladen -+ herlancering -+ hermeneutische -+ hernationalisatie -+ hernhuttertje -+ hernhuttertjes -+ herniaoperatie -+ herniaoperaties -+ hernieuwbaar -+ hernieuwbare -+ heronderhandeld -+ heronderhandelde -+ heronderhandelen -+ heronderhandeling -+ heronderhandelingen -+ heronderzoek -+ herontdekken -+ herontdekkingen -+ herontdekte -+ herontwerp -+ herontwerpen -+ heropbloei -+ heropbouwen -+ heropflakkering -+ heropgebouwd -+ heropgericht -+ heropgevoed -+ heroplevend -+ heroplevende -+ heropleving -+ heropname -+ heropnamen -+ heropnames -+ heroprichten -+ heroprichtte -+ heroprichting -+ heropvoeden -+ heropvoedingskamp -+ heropvoedingskampen -+ heropvoering -+ heropvoeringen -+ herordend -+ herordende -+ herordening -+ heroriënteerde -+ heroriëntering -+ heroriënteringen -+ heroverwegingen -+ heroïnegebruik -+ heroïnegebruiker -+ heroïnegebruikers -+ heroïnehoer -+ heroïnehoeren -+ heroïnehoertje -+ heroïnehonden -+ heroïnelijn -+ heroïnespuit -+ heroïnespuiten -+ heroïnevangst -+ heroïneverslaafde -+ heroïneverslaafden -+ heroïsering -+ herplaatsbaar -+ herplaatsbare -+ herpositionering -+ herprofilering -+ herregistratie -+ herrenvolk -+ herroepelijke -+ herschikken -+ herschikkingen -+ herschikt -+ herschikte -+ herscholingsprogramma -+ herscholingsprogramma's -+ herschoold -+ herschoolde -+ herschrijver -+ herschrijvers -+ hersenaandoening -+ hersenaandoeningen -+ hersenaanhangsel -+ hersenaanhangsels -+ hersenactiviteit -+ hersenafwijking -+ hersenafwijkingen -+ hersenbalk -+ hersenbeschadigingen -+ hersenbloedingen -+ hersenbrekers -+ hersencel -+ hersencentra -+ hersencentrum -+ hersendode -+ hersendruk -+ hersengebieden -+ hersenhelften -+ hersenholte -+ hersenholten -+ hersenholtes -+ herseninfarct -+ herseninfarcten -+ hersenkamer -+ hersenkamers -+ hersenklier -+ hersenklieren -+ hersenkronkels -+ hersenkwabben -+ hersenletsel -+ hersenletsels -+ hersenoedeem -+ hersenomvang -+ hersenonderzoek -+ hersenonderzoeker -+ hersenonderzoekers -+ hersenspinsels -+ hersenspoelde -+ hersenspoelingen -+ hersenspoken -+ hersenspook -+ hersenstam -+ hersentumoren -+ hersentumors -+ hersenvlucht -+ hersenvolume -+ hersenvolumes -+ hersenweefsel -+ hersenweefsels -+ hersenwerk -+ hersenzenuw -+ hersenzenuwen -+ herstelbeleid -+ hersteldienst -+ herstellingsvermogen -+ hersteloperatie -+ hersteloperaties -+ herstelplannen -+ herstelprogramma -+ herstelprogramma's -+ herstelwet -+ herstelwetten -+ herstructureringen -+ herstructureringskosten -+ herstructureringsoperatie -+ herstructureringsoperaties -+ herstructureringsplan -+ herstructureringsplannen -+ herstructureringsproces -+ hertaald -+ hertaalde -+ hertalen -+ hertaling -+ hertalingen -+ hertaxaties -+ herteld -+ hertelde -+ hertellen -+ hertelling -+ hertellingen -+ hertenzwijn -+ hertenzwijnen -+ hertoetreding -+ hertoetsing -+ heruitbrengen -+ heruitgaven -+ heruitgebracht -+ heruitgeven -+ hervaccinaties -+ herverdelingen -+ herverkiezing -+ herverkiezingen -+ herverkiezingscampagne -+ herverkiezingscampagnes -+ herverwerking -+ herverzekeraar -+ herverzekeraars -+ herverzekeringscontract -+ herverzekeringscontracten -+ hervestiging -+ hervestigingsprogramma -+ hervestigingsprogramma's -+ hervormbaar -+ hervormbare -+ hervormingsbewegingen -+ hervormingsijver -+ hervormingspakket -+ hervormingspartij -+ hervormingspartijen -+ hervormingsstreven -+ hervormingswet -+ hervormingswetten -+ herwaarderingsgebied -+ herwaarderingsgebieden -+ herweging -+ herwerken -+ herwerkt -+ herwerkte -+ herwinning -+ herzieningsverzoek -+ herzieningsverzoeken -+ herzuiling -+ hespenspek -+ het wachthouden -+ het-woord -+ het-woorden -+ heteluchtballon -+ heteluchtballonnen -+ heteluchtballons -+ heteluchtkachel -+ heteluchtkachels -+ heterdaadje -+ heterdaadjes -+ heterofielen -+ heteromorfe -+ heteroniemen -+ heteronome -+ hetzes -+ heupbeweging -+ heupbewegingen -+ heupbroek -+ heupbroeken -+ heupflessen -+ heupgordels -+ heupoperatie -+ heupoperaties -+ heupwiegde -+ heupwijdte -+ heupzwaaien -+ heuselijke -+ heuvelafwaarts -+ heuvellandschap -+ heuvellandschappen -+ heuvelranden -+ hevea's -+ heven -+ hezbollah -+ hickory -+ hickory's -+ hidalgo's -+ hidjab -+ hidjabs -+ hidjra -+ hielenlikkers -+ hiep -+ hiervandaan -+ hifi-installatie -+ hifi-installaties -+ hifiapparatuur -+ hifiketen -+ hifitoren -+ hifitorens -+ higgsdeeltje -+ higgsdeeltjes -+ high five -+ high fives -+ highbrows -+ highriskvirus -+ highriskvirussen -+ hightechbedrijf -+ hightechbedrijven -+ hightechindustrie -+ hihat -+ hihats -+ hij-vorm -+ hijsbok -+ hijsbokken -+ hijscapaciteit -+ hijswerktuigen -+ hiking -+ hikkerig -+ hikkerige -+ hindekalf -+ hindekalveren -+ hindernisbanen -+ hindernislopen -+ hindes -+ hindoe -+ hindoefundamentalist -+ hindoefundamentalisten -+ hindoegod -+ hindoegoden -+ hindoeleider -+ hindoeleiders -+ hindoepartij -+ hindoepartijen -+ hindoes -+ hindoese -+ hindoetempel -+ hindoetempels -+ hineininterpretieren -+ hink-stap-springen -+ hink-stap-sprong -+ hink-stap-sprongen -+ hintte -+ hiphopcultuur -+ hiphoppers -+ hipper -+ hippie-ideaal -+ hippie-idealen -+ hippocampussen -+ hippocratische -+ hipst -+ hispanic -+ hispanics -+ hispanologen -+ histogrammen -+ histologische -+ historica's -+ historieschilderkunst -+ historieschilders -+ historiografische -+ historisch-cultureel -+ historisch-culturele -+ historisch-kritisch -+ historisch-kritische -+ historisch-sociologisch -+ historisch-sociologische -+ historiseerde -+ historistische -+ hitgevoelig -+ hitgevoelige -+ hitleriaans -+ hitleriaanse -+ hitlijsten -+ hitparades -+ hitsingle -+ hitsingles -+ hitste aan -+ hitste op -+ hittebestendigheid -+ hitteschilden -+ hittezoekend -+ hittezoekende -+ hitwezen -+ hiv -+ hiv-geïnfecteerde -+ hiv-geïnfecteerden -+ hiv-infectie -+ hiv-infecties -+ hiv-positief -+ hiv-positieve -+ hiv-virus -+ hivgeïnfecteerde -+ hivgeïnfecteerden -+ hivinfectie -+ hivinfecties -+ hivpositief -+ hivpositieve -+ hivvirus -+ ho -+ hobbelweg -+ hobbelwegen -+ hobby'tje -+ hobbybladen -+ hobbyclub -+ hobbyde -+ hobbyen -+ hobbyistische -+ hobbyruimten -+ hobbyruimtes -+ hobbyt -+ hobo's -+ hoboconcert -+ hoboconcerten -+ hobootje -+ hobu -+ hobuer -+ hockeybond -+ hockeyde -+ hockeyelftal -+ hockeyelftallen -+ hockeyploeg -+ hockeyploegen -+ hockeysport -+ hockeystadion -+ hockeystadions -+ hockeyt -+ hockeyveld -+ hockeyvelden -+ hocus pocus -+ hodgkin -+ hoedenpennen -+ hoedenplanken -+ hoederecht -+ hoedna -+ hoefijzervormig -+ hoefijzervormige -+ hoefmagneet -+ hoefmagneten -+ hoekbank -+ hoekbanken -+ hoekdeel -+ hoekdelen -+ hoekkamers -+ hoekkeper -+ hoekkepers -+ hoeklieden -+ hoekmeters -+ hoekmeting -+ hoekmetingen -+ hoekpaal -+ hoekpalen -+ hoekplaat -+ hoekplaats -+ hoekplaatsen -+ hoekplaten -+ hoekprofiel -+ hoekprofielen -+ hoekslag -+ hoekslagen -+ hoekstijlen -+ hoektafel -+ hoektafels -+ hoektafeltje -+ hoekverbinding -+ hoekverbindingen -+ hoekvlaggen -+ hoekwoning -+ hoekwoningen -+ hoela -+ hoela's -+ hoempa's -+ hoempamuziek -+ hoempapamuziek -+ hoendertje -+ hoenen -+ hoepelmakers -+ hoeraatjes -+ hoerageroep -+ hoerenbuurt -+ hoerenbuurten -+ hoerenkind -+ hoerenkinderen -+ hoerenlonen -+ hoerenloon -+ hoerenmadammen -+ hoerenmadams -+ hoerensjans -+ hoerenzonen -+ hoerenzoon -+ hoerenzoons -+ hoesfoto -+ hoesfoto's -+ hoesontwerp -+ hoesontwerpen -+ hoestballetje -+ hoestballetjes -+ hoestdranken -+ hoesteksten -+ hoestprikkel -+ hoestprikkels -+ hoestsiroop -+ hoestsiropen -+ hoesttablet -+ hoesttabletten -+ hoeveboter -+ hoeves -+ hofauto's -+ hofceremonieel -+ hofdichter -+ hofdichters -+ hofintrige -+ hofintriges -+ hofkringen -+ hofleven -+ hofmakerij -+ hofopera -+ hofopera's -+ hofstedes -+ hofstoeten -+ hoge-energiefysica -+ hogedrukgebieden -+ hogedrukpannen -+ hogedrukspuiten -+ hogepriesteres -+ hogepriesteressen -+ hogere-inkomensgroep -+ hogere-inkomensgroepen -+ hogergenoemd -+ hogergenoemde -+ hogergeplaatst -+ hogergeplaatste -+ hogeronderwijsbeleid -+ hogervermeld -+ hogervermelde -+ hogeschoolraden -+ hogeschoolrijden -+ hogesnelheidslijn -+ hogesnelheidslijnen -+ hogesnelheidsspoorlijn -+ hogesnelheidsspoorlijnen -+ hogesnelheidstrein -+ hogesnelheidstreinen -+ hokkig -+ hokkige -+ hold-ups -+ holdingconstructie -+ holdingconstructies -+ holdings -+ hole-in-one -+ holebi -+ holebi's -+ holenduif -+ holenduiven -+ holes -+ holisten -+ holklinkend -+ holklinkende -+ holocausten -+ holoceen -+ holocene -+ holoniem -+ holoniemen -+ holsteiner -+ holsteiners -+ holvast -+ holvaste -+ homecinema -+ homecinema's -+ homecomputers -+ homejacking -+ homejackings -+ homemade -+ homeostatische -+ homepage -+ homepages -+ homeruns -+ homes -+ homeshopping -+ hometrainers -+ hominide -+ hominiden -+ hommages -+ homo-echtpaar -+ homo-echtparen -+ homo-emancipatie -+ homo-erotiek -+ homo-erotisch -+ homo-erotische -+ homo-organisatie -+ homoactivist -+ homoactivisten -+ homoadoptie -+ homobar -+ homobars -+ homofobe -+ homofobie -+ homofonen -+ homogeniseerde -+ homogenisering -+ homografen -+ homohaat -+ homohuwelijk -+ homokinetische -+ homologatiecommissie -+ homologatiecommissies -+ homologieën -+ homopaar -+ homoparen -+ homoseks -+ homostudies -+ hondenbanen -+ hondenbeet -+ hondenbeten -+ hondendrol -+ hondendrollen -+ hondenfluitje -+ hondenfluitjes -+ hondenfokkers -+ hondengeleider -+ hondengeleiders -+ hondengevecht -+ hondenhokken -+ hondenliefhebbers -+ hondenlullen -+ hondenmanden -+ hondenogen -+ hondenoog -+ hondenpenningen -+ hondenrennen -+ hondentrimmers -+ hondenziekten -+ hondenziektes -+ honderdjarigen -+ hondsberoerd -+ hondsberoerde -+ hondsbrutale -+ hondsdolle -+ hondsmoeë -+ hondstrouw -+ hondstrouwe -+ hongerbaantjes -+ hongergeleden -+ hongergevoel -+ hongerlap -+ hongerlijden -+ hongermaal -+ hongeroproeren -+ hongerstaken -+ hongerstiller -+ hongerstillers -+ hongerwinters -+ honigheide -+ honingblond -+ honingblonde -+ honinggeel -+ honinggele -+ honingkelk -+ honingkelken -+ honingkleur -+ honingkleurig -+ honingkleurige -+ honingkoeken -+ honingpersen -+ honingpot -+ honingpotten -+ honingraatmotieven -+ honingvogel -+ honingvogels -+ honkbalde -+ honkbalknuppels -+ honkballen -+ honkbalpet -+ honkbalpetten -+ honkbalstadion -+ honkbalstadions -+ honklopers -+ honkmannen -+ honkslagen -+ honkvast -+ honkvaste -+ honkvastheid -+ honneponnetje -+ honoreringsregeling -+ honoreringsstructuur -+ honoreringssysteem -+ hoofdaandeelhouder -+ hoofdaandeelhouders -+ hoofdader -+ hoofdaderen -+ hoofdaders -+ hoofdas -+ hoofdassen -+ hoofdband -+ hoofdbanden -+ hoofdbedekking -+ hoofdbedrijfschap -+ hoofdbedrijfschappen -+ hoofdbetrachting -+ hoofdbetrachtingen -+ hoofdbrok -+ hoofdcommies -+ hoofdcommiezen -+ hoofdeindes -+ hoofdfilms -+ hoofding -+ hoofdingrediënt -+ hoofdingrediënten -+ hoofdkapitein -+ hoofdkapiteins -+ hoofdklasse -+ hoofdklassen -+ hoofdklassenspeler -+ hoofdklassenspelers -+ hoofdkussentje -+ hoofdlamp -+ hoofdlampen -+ hoofdletsel -+ hoofdluizen -+ hoofdmaaltijden -+ hoofdpijler -+ hoofdpijlers -+ hoofdpijnpoeders -+ hoofdpijnpoeiers -+ hoofdpijnwijn -+ hoofdpijnwijnen -+ hoofdprijzen -+ hoofdredactionele -+ hoofdredactrices -+ hoofdroos -+ hoofdschuddende -+ hoofdstedeling -+ hoofdstedelingen -+ hoofdsteuntje -+ hoofdstraf -+ hoofdstraten -+ hoofdtak -+ hoofdtakken -+ hoofdtelefoons -+ hoofdtooien -+ hoofdtornooi -+ hoofdverpleegkundigen -+ hoofdverpleegsters -+ hoofdverplegers -+ hoofdwonden -+ hoogactief -+ hoogactieve -+ hoogbegaafd -+ hoogbegaafde -+ hoogbejaarden -+ hoogconjuncturen -+ hoogdekker -+ hoogdekkers -+ hoogdringend -+ hoogdringende -+ hoogdringendheid -+ hoogedel -+ hoogfeest -+ hoogfeesten -+ hooggekwalificeerd -+ hooggeschoold -+ hooggestemd -+ hooggewaardeerd -+ hooggewaardeerde -+ hoogglans -+ hooglander -+ hooglanders -+ hooglands -+ hooglandse -+ hoogleraar-directeur -+ hoogleraren-directeuren -+ hoogmoedswaan -+ hoogmoleculair -+ hoogmoleculaire -+ hoogontwikkelde -+ hoogopgeleid -+ hoogopgelopen -+ hoogoplopend -+ hoogoplopende -+ hoogovenslakken -+ hoogpolige -+ hoogproductief -+ hoogproductieve -+ hoogradioactief -+ hoogradioactieve -+ hoogrendementsketel -+ hoogrendementsketels -+ hoogrentend -+ hoogrentende -+ hoogseizoenen -+ hoogspanningsleiding -+ hoogspanningsleidingen -+ hoogspringer -+ hoogspringers -+ hoogstamboomgaard -+ hoogstamboomgaarden -+ hoogstamfruit -+ hoogstgeplaatst -+ hoogstgeplaatste -+ hoogstnoodzakelijk -+ hoogstnoodzakelijke -+ hoogstonwaarschijnlijk -+ hoogstonwaarschijnlijke -+ hoogstpersoonlijke -+ hoogstzelden -+ hoogtechnologisch -+ hoogtechnologische -+ hoogtekaarten -+ hoogterecords -+ hoogtestage -+ hoogtestages -+ hoogtetraining -+ hoogtetrainingen -+ hoogteziekte -+ hoogtijperiode -+ hoogveengebied -+ hoogveengebieden -+ hoogveenreservaat -+ hoogverheven -+ hoogvliegend -+ hoogvliegende -+ hoogwerkers -+ hoogzomer -+ hooi-jaar -+ hooi-jaren -+ hooioogsten -+ hooipers -+ hooipersen -+ hooischudder -+ hooischudders -+ hooistapel -+ hool -+ hoolde -+ hoolt -+ hoorcommissie -+ hoorcommissies -+ hoornblad -+ hoornlaag -+ hoornlagen -+ hopje -+ hopjes -+ hopperzuiger -+ hopperzuigers -+ hopsasa -+ hopsen -+ hopste -+ hora -+ hordelopen -+ hordelopers -+ horeca-etablissement -+ horeca-etablissementen -+ horecazaak -+ horecazaken -+ horizonbepaling -+ horizonbepalingen -+ horizontalistische -+ horkerig -+ horkerige -+ horlepiepen -+ horlogerieën -+ hormonenhandel -+ hormonenmaffia -+ hormoonbehandeling -+ hormoonbehandelingen -+ hormooninjectie -+ hormooninjecties -+ hormoonpreparaat -+ hormoonpreparaten -+ hormoonspiegels -+ hormoonvlees -+ horribele -+ horrorfilms -+ horrorgenre -+ horrorscenario -+ hors-d'oeuvre -+ hors-d'oeuvres -+ horsmakreel -+ horsmakrelen -+ hortologen -+ hortologie -+ hortussen -+ horzelfunctie -+ horzelfuncties -+ hospice -+ hospices -+ hospitalisatieverzekering -+ hospitalisatieverzekeringen -+ hospitaliseerde -+ hossel -+ hosselaar -+ hosselaars -+ hosselde -+ hosselen -+ hostels -+ hostesses -+ hostie-ijzer -+ hostiliteiten -+ hosts -+ hostte -+ hotel-café-restaurant -+ hotel-café-restaurants -+ hotel-restaurant -+ hotel-restaurants -+ hotelaccommodatie -+ hotelappartement -+ hotelappartementen -+ hotelbedden -+ hotelbedienden -+ hotelbedrijf -+ hotelcapaciteit -+ hotelhoudsters -+ hoteliers -+ hotelkosten -+ hotellift -+ hotelliften -+ hotellobby's -+ hotelpersoneel -+ hotelregisters -+ hotelrekeningen -+ hotelreservering -+ hotelreserveringen -+ hotelschepen -+ hotelschip -+ hotelscholen -+ hotelschool -+ hotelsluiting -+ hotelsluitingen -+ hotelsuite -+ hotelsuites -+ hoteluitbater -+ hoteluitbaters -+ hotemetoot -+ hotemetoten -+ hotlines -+ hotsaus -+ hotsausen -+ hotsauzen -+ hotspot -+ hotspots -+ houdbaarheidsdata -+ houderschapsbelasting -+ houdkracht -+ houdsters -+ housebroek -+ housebroeken -+ housede -+ househit -+ househits -+ housescene -+ houset -+ housete -+ housewarmingparty -+ housewarmingparty's -+ houtafval -+ houtbewerken -+ houtbewerkingen -+ houtblazer -+ houtblazers -+ houtblok -+ houtblokken -+ houtboard -+ houtboren -+ houtcel -+ houtcellen -+ houtcellulose -+ houtconstructies -+ houtgehakt -+ houtgewassen -+ houtgraveur -+ houtgraveurs -+ houthakkershemd -+ houthakkershemden -+ houthaven -+ houthavens -+ houtje-touwtje -+ houtje-touwtjejas -+ houtje-touwtjejassen -+ houtje-touwtjes -+ houtkachel -+ houtkachels -+ houtkap -+ houtkapper -+ houtkappers -+ houtland -+ houtmaat -+ houtmaten -+ houtmeel -+ houtnerven -+ houtopbrengst -+ houtopbrengsten -+ houtprijs -+ houtprijzen -+ houtproductie -+ houtrasp -+ houtraspen -+ houtresten -+ houtskooltekening -+ houtskooltekeningen -+ houtsnedes -+ houtsnijden -+ houtsnipper -+ houtsnippers -+ houtspaan -+ houtspanen -+ houtsplinter -+ houtsplinters -+ houtsplintertje -+ houtstapel -+ houtstapels -+ houtveredeling -+ houtverwerkend -+ houtverwerkende -+ houtvezel -+ houtvezelplaat -+ houtvezelplaten -+ houtvezels -+ houtvuren -+ houtvuur -+ houtvuurtje -+ houtwal -+ houtwallen -+ houtweefsel -+ houtwerven -+ houweelslag -+ houweelslagen -+ hovercrafts -+ hr-ketel -+ hr-ketels -+ hsl -+ hso -+ hst -+ hst's -+ htm -+ html -+ hts -+ hts'er -+ hts'ers -+ http -+ hub -+ hubbleconstante -+ hubs -+ hudo -+ hudo's -+ hufter -+ hufters -+ huichelachtigheid -+ huidaandoeningen -+ huidcel -+ huidcellen -+ huidcrèmes -+ huidirritatie -+ huidirritaties -+ huidkleurig -+ huidkleurige -+ huidplaat -+ huidplaten -+ huidplooi -+ huidschilfer -+ huidschilfers -+ huidskleuren -+ huidspecialisten -+ huidtransplantatie -+ huidtransplantaties -+ huig-r -+ huilers -+ huilkramp -+ huilkrampen -+ huiltoontje -+ huis-aan-huisblad -+ huis-aan-huisbladen -+ huis-tuin-en-keukengebruik -+ huisadressen -+ huisaltaars -+ huisaltaren -+ huisarchieven -+ huisartsengroep -+ huisartsengroepen -+ huisartsenopleiding -+ huisartsenpraktijk -+ huisartsenpraktijken -+ huisartspraktijk -+ huisbank -+ huisbanken -+ huisbankiers -+ huisbarretje -+ huisbars -+ huisbewoner -+ huisbewoners -+ huisbioscoop -+ huisbioscopen -+ huisbladen -+ huisbranden -+ huisbrandolie -+ huischoreograaf -+ huischoreografen -+ huiscollecten -+ huiscollectes -+ huiscomponist -+ huiscomponisten -+ huisconcert -+ huisconcerten -+ huisdealers -+ huisgemaakt -+ huisgemaakte -+ huisgenotes -+ huishoudbeurzen -+ huishoudbrood -+ huishoudhulpen -+ huishoudinkomen -+ huishoudjams -+ huishoudkundigen -+ huishoudstroop -+ huishoudtrappen -+ huishoudweegschalen -+ huisje-boompje-beestje -+ huiskamerdeur -+ huiskamerdeuren -+ huiskamerdrama -+ huiskamerformaat -+ huiskamerproject -+ huiskamerprojecten -+ huiskraai -+ huiskraaien -+ huiskring -+ huisleraar -+ huisleraars -+ huisleraren -+ huismannen -+ huismijt -+ huismijten -+ huismoedertje -+ huismuziek -+ huisnijverheid -+ huisorgaan -+ huisorganen -+ huisorgels -+ huisorkesten -+ huispersoneel -+ huisrecht -+ huisslaaf -+ huisslaven -+ huisstof -+ huisstofmijt -+ huisstofmijten -+ huisuitzetting -+ huisuitzettingen -+ huisvadertje -+ huisvestingsbeleid -+ huisvestingsbureaus -+ huisvestingsinstantie -+ huisvestingsinstanties -+ huisvestingsmaatschappij -+ huisvestingsnood -+ huisvestingswet -+ huisvrouwschap -+ huisvrouwtje -+ huiswerkbegeleiding -+ huiswerkklas -+ huiswijn -+ huiswijnen -+ huiszoekingsbevel -+ huiszoekingsbevelen -+ huizenaanbod -+ huizenkanten -+ huizenrijen -+ hulpaanvraag -+ hulpaanvragen -+ hulpagent -+ hulpagenten -+ hulpaggregaten -+ hulpambulance -+ hulpambulances -+ hulpbisschoppen -+ hulpboek -+ hulpboeken -+ hulpbrug -+ hulpbruggen -+ hulpconstructie -+ hulpexpedities -+ hulpgoederen -+ hulpje -+ hulpkit -+ hulpkits -+ hulpkok -+ hulpkoks -+ hulpmiddeltje -+ hulpmotors -+ hulppakketten -+ hulppolitie -+ hulppredikant -+ hulppredikanten -+ hulpsinterklaas -+ hulpsinterklazen -+ hulpstelling -+ hulpstellingen -+ hulptrainer -+ hulptrainers -+ hulptransport -+ hulptransporten -+ hulpverleend -+ hulpverleningspakket -+ hulpverleningspakketten -+ hulpvraag -+ hulpvragen -+ human immunodeficiency virus -+ human resources -+ humaninterestverhaal -+ humanresourcesafdeling -+ humanresourcesafdelingen -+ humanresourcesmanagement -+ humboldtpinguïn -+ humboldtpinguïns -+ humiliaties -+ hummus -+ humorale -+ hunebedbouwers -+ huppeldepup -+ huppelpas -+ hupsen -+ hupste -+ hurksprong -+ hurksprongen -+ hurktoilet -+ hurktoiletten -+ hurkzit -+ hurling -+ husky's -+ husselde -+ husselen -+ hussiet -+ hussieten -+ hutjemutje -+ hutsekluts -+ huurachterstanden -+ huurauto's -+ huurbedingen -+ huurbeleid -+ huurcommissies -+ huurfiets -+ huurfietsen -+ huurgewenning -+ huurgewenningsbijdrage -+ huurgewenningsbijdragen -+ huurlasten -+ huurmoorden -+ huurmoordenaars -+ huurquote -+ huursubsidies -+ huurverlaging -+ huurverlagingen -+ huurvideo -+ huurvideo's -+ huurwaardeforfaits -+ huurwagen -+ huurwagens -+ huurwet -+ huurwetten -+ huwelijksaangiften -+ huwelijksaangiftes -+ huwelijksambtenaar -+ huwelijksambtenaren -+ huwelijksbedden -+ huwelijksbedrog -+ huwelijksbeletsel -+ huwelijksbeletselen -+ huwelijksbeletsels -+ huwelijksbemiddelingen -+ huwelijkscadeaus -+ huwelijkscrises -+ huwelijkscrisis -+ huwelijkscrisissen -+ huwelijksdagen -+ huwelijksgebruik -+ huwelijksgeluk -+ huwelijksgemeenschappen -+ huwelijksgoederengemeenschap -+ huwelijksgoederengemeenschappen -+ huwelijksinzegeningen -+ huwelijksjaar -+ huwelijksjaren -+ huwelijkskans -+ huwelijkskansen -+ huwelijksleeftijd -+ huwelijkslijst -+ huwelijkslijsten -+ huwelijksmarkt -+ huwelijksmis -+ huwelijksmissen -+ huwelijksnachten -+ huwelijksplechtigheden -+ huwelijksplechtigheid -+ huwelijksprobleem -+ huwelijksproblemen -+ huwelijksrecht -+ huwelijksrechten -+ huwelijksregisters -+ huwelijkssluiting -+ huwelijkssluitingen -+ huwelijksvoorwaarde -+ huwelijkswetgeving -+ huwelijkszwendelaars -+ huzarensalade -+ huzarenstuk -+ hybrides -+ hydra's -+ hydro-elektrische -+ hydrobiologie -+ hydrofobe -+ hydrofoons -+ hydromechanica -+ hydroxide-ion -+ hydroxiden -+ hydroxides -+ hyena's -+ hygroscopen -+ hymneboek -+ hymneboeken -+ hymnedichter -+ hymnedichters -+ hymnes -+ hymnische -+ hypen -+ hyper -+ hyperactieve -+ hypercorrecties -+ hyperkritische -+ hyperlink -+ hyperlinks -+ hypermarkt -+ hypermarkten -+ hyperoniemen -+ hyperrealistische -+ hypersnelle -+ hypersonische -+ hypertext transfer protocol -+ hypertrofische -+ hypes -+ hypet -+ hypete -+ hypnotherapeut -+ hypnotherapeuten -+ hypnotica -+ hypofysen -+ hypofyses -+ hyponiemen -+ hypostaseerde -+ hypostasen -+ hypotenusa's -+ hypotheekbedrag -+ hypotheekkrediet -+ hypotheekkredieten -+ hypotheeklasten -+ hypotheeklening -+ hypotheekleningen -+ hypotheekmarkt -+ hypotheekrenteaftrek -+ hypotheekrenten -+ hypotheekrentes -+ hypotheekschulden -+ hypotheekverstrekker -+ hypotheekverstrekkers -+ hypotheekverzekeringen -+ hystera protera -+ hysteron proteron -+ hysteron proterons -+ hèhè -+ hôtelier -+ hôteliers -+ hüttenkäse -+ i's -+ i'tje -+ i-bankierde -+ i-bankieren -+ i-grecs -+ i-mode -+ iatrogene -+ iatrosofen -+ iatrosofie -+ ic -+ ic's -+ ic-verpleegkundige -+ ic-verpleegkundigen -+ icetea -+ ichtyologen -+ ichtyoloog -+ icings -+ iconenschilder -+ iconenschilders -+ iconische -+ iconoclasten -+ iconografieën -+ iconografische -+ iconologische -+ id'er -+ id'ers -+ id-baan -+ id-banen -+ ideaalbeeld -+ ideaalbeelden -+ ideaaltype -+ ideaaltypen -+ ideaaltypes -+ ideaaltypisch -+ ideaaltypische -+ idealiseringen -+ ideeëloos -+ ideeëloze -+ ideeënbussen -+ ideeëngeschiedenis -+ ideeëngoed -+ ideeënleer -+ ideeënman -+ ideeënroman -+ ideeënromans -+ ideeënwereld -+ ideeënwerelden -+ identificatiebewijs -+ identificatiebewijzen -+ identificatieproces -+ identiteitscrises -+ identiteitscrisissen -+ identiteitsgebonden -+ ideogrammen -+ ideologieloos -+ ideologieloze -+ ideologiseerde -+ ideologisering -+ idiolecten -+ idioterieën -+ iezegrims -+ iglo's -+ ij's -+ ij'tje -+ ijkmerken -+ ijkprijs -+ ijkprijzen -+ ijkpunten -+ ijsachtig -+ ijsachtige -+ ijsafzettingen -+ ijsappel -+ ijsappels -+ ijsbal -+ ijsballen -+ ijsballet -+ ijsboer -+ ijsboeren -+ ijsbox -+ ijsboxen -+ ijscokarretje -+ ijsdansen -+ ijsemmers -+ ijshal -+ ijshallen -+ ijshockeyclub -+ ijshockeyclubs -+ ijshockeyde -+ ijshockeyer -+ ijshockeyers -+ ijshockeyfan -+ ijshockeyfans -+ ijshockeyspeler -+ ijshockeyt -+ ijshockeywedstrijd -+ ijshockeywedstrijden -+ ijshut -+ ijshutten -+ ijskappen -+ ijsklompen -+ ijskoningin -+ ijslaag -+ ijslagen -+ ijslander -+ ijslanders -+ ijslolly -+ ijslolly's -+ ijsmachine -+ ijsmachines -+ ijsmeester -+ ijsmeesters -+ ijsmutsen -+ ijsrace -+ ijsracen -+ ijsracet -+ ijsracete -+ ijsrevues -+ ijssalons -+ ijssla -+ ijsspeedway -+ ijsstadions -+ ijstaart -+ ijstaarten -+ ijstang -+ ijstangen -+ ijsthee -+ ijstijden -+ ijstijdvak -+ ijsvloer -+ ijsvogeltje -+ ijsvrije -+ ijswafeltje -+ ijswijn -+ ijswijnen -+ ijzerbeslag -+ ijzerchloride -+ ijzerconstructie -+ ijzerconstructies -+ ijzerenheinig -+ ijzerenheinige -+ ijzerhandel -+ ijzerhandels -+ ijzerindustrie -+ ijzermijnen -+ ijzerpreparaat -+ ijzerrijk -+ ijzerrijke -+ ijzersmaak -+ ijzertijd -+ ijzertijdperk -+ ijzervlechters -+ ijzerzagen -+ ijzerzout -+ ijzerzouten -+ ik-besef -+ ik-figuren -+ ik-figuur -+ ik-persoon -+ ik-roman -+ ik-romans -+ ik-tijdperk -+ ik-vorm -+ ik-zucht -+ ik-zuchtig -+ ik-zuchtige -+ ikke -+ illegalenkwestie -+ illegalenprobleem -+ illegalenvraagstuk -+ illegaliteiten -+ illegitieme -+ illusieloos -+ illusieloze -+ illusiepolitiek -+ illusionaire -+ illusionistische -+ illustrators -+ images -+ imago-onderzoek -+ imagologen -+ imagootje -+ imagoprobleem -+ imagoverbetering -+ imams -+ imitatieleer -+ imkerde -+ imkerij -+ imkerijen -+ immatriculeerde -+ immatriculeren -+ immigrantenbeleid -+ immigrantengroep -+ immigrantengroepen -+ immigrantenstroom -+ immigrantes -+ immigratieambtenaar -+ immigratieambtenaren -+ immigratiedienst -+ immigratiepolitiek -+ immigratiestop -+ immigratiestromen -+ immigratiestroom -+ immigratiewet -+ immigratiewetten -+ imminente -+ immobiele -+ immobiliseerde -+ immobiliënkantoor -+ immobiliënkantoren -+ immobiliënmaatschappij -+ immobiliënmarkt -+ immuniseerde -+ immuniteitsleer -+ immuniteitssysteem -+ immunogene -+ immunogenen -+ immunologe -+ immunologen -+ immunologische -+ immuunapparaat -+ immuunreactie -+ immuunsysteem -+ impacts -+ impactstudie -+ impala's -+ impedimenten -+ imperatoren -+ imperators -+ impermeabele -+ implantaten -+ implantaties -+ implanteerbaar -+ implanteerbare -+ implanteerde -+ implementering -+ implodeerde -+ implosies -+ imponeerhouding -+ importante -+ importartikel -+ importartikelen -+ importbier -+ importbieren -+ importmarkt -+ importproduct -+ importproducten -+ importstop -+ importvergunning -+ importvergunningen -+ impresariaten -+ impresario's -+ impressionant -+ impressionante -+ imprints -+ impromptu's -+ improvisatietalent -+ improvisatievermogen -+ improviserenderwijs -+ impulsaankoop -+ impulsaankopen -+ impulsgedrag -+ impulsmoment -+ in familiehanden -+ in privéhanden -+ in regeringshanden -+ in staatshanden -+ in z'n uppie -+ in- en ingemeen -+ in- en ingemene -+ in-situsanering -+ in-situsaneringen -+ in-vitrofertilisatie -+ inacceptabele -+ inactieven -+ inactiveerde -+ inaugurale -+ inbeeldingsvermogen -+ inbelnummer -+ inbelnummers -+ inbeuken -+ inbewaringstellingen -+ inboren -+ inbouwapparatuur -+ inbouwkast -+ inbouwkasten -+ inbraakalarmen -+ inbraakpoging -+ inbraakpogingen -+ inbraakpreventies -+ inbrekersgilde -+ inbrenghuls -+ inbrenghulzen -+ inburgering -+ inburgeringscontract -+ inburgeringscontracten -+ inburgeringstrajecten -+ incasseerbaar -+ incasseerbare -+ incasso's -+ incasso-endossement -+ incasso-opdracht -+ incasso-opdrachten -+ incasso-organisatie -+ incassobedrijf -+ incassobureaus -+ incestervaring -+ incestervaringen -+ incestpleger -+ incestplegers -+ incestslachtoffer -+ incestslachtoffers -+ incestzaak -+ incestzaken -+ incheckbalies -+ inchoatieven -+ incidenties -+ incivieke -+ incivieken -+ incoherenties -+ incompanytraining -+ incompatibele -+ incontinentiemateriaal -+ incriminerend -+ incriminerende -+ incrowds -+ incubators -+ indeclinabele -+ indekking -+ indeler -+ indelers -+ indelingscriteria -+ independente -+ inderminneregeling -+ inderminneregelingen -+ indexaanpassing -+ indexaanpassingen -+ indexaties -+ indexeringen -+ indexgerelateerd -+ indexgerelateerde -+ indexmanipulatie -+ indexmanipulaties -+ indexoptie -+ indexopties -+ indexsprong -+ indexsprongen -+ indiaansen -+ indianenboek -+ indianenboeken -+ indianencultuur -+ indianendorp -+ indianendorpen -+ indianenreservaat -+ indianenreservaten -+ indianenstam -+ indianenstammen -+ indianentaal -+ indianentalen -+ indianenvolk -+ indianenvolken -+ indianenvolkeren -+ indicatiegebied -+ indicatiestelling -+ indicators -+ indiceringen -+ indieners -+ indikking -+ indiscutabele -+ individu's -+ individualisaties -+ individualiseringsproces -+ individualiteiten -+ individuutje -+ indo -+ indo's -+ indoctrinaties -+ indom -+ indomme -+ indooratletiek -+ indoorbaan -+ indoorbanen -+ indoorkampioenschap -+ indoorkampioenschappen -+ indoorrecord -+ indoorseizoen -+ indoortennistoernooi -+ indoorwedstrijd -+ indoorwedstrijden -+ indroevige -+ inductielus -+ inductielussen -+ inductiemotoren -+ inductiemotors -+ inductiespoelen -+ industrialisatienota -+ industrialisatiepolitiek -+ industrialisatieproces -+ industrieaandeel -+ industrieaandelen -+ industriearbeider -+ industriearbeiders -+ industriecentra -+ industriecentrum -+ industriecomplexen -+ industriediamanten -+ industriefonds -+ industriefondsen -+ industrielanden -+ industrieparken -+ industriesector -+ industriesectoren -+ industrietak -+ industrietakken -+ industrievestiging -+ industriezone -+ industriezones -+ ineenduiken -+ ineengedrongen -+ ineengegrepen -+ ineengeschoven -+ ineengeschrompeld -+ ineengestrengeld -+ ineengevlochten -+ ineengevouwen -+ ineengrijpen -+ ineenschrompelen -+ ineenschuiven -+ ineenstrengelen -+ ineenvlechten -+ ineenvouwen -+ inentingsbewijzen -+ inentingsbriefjes -+ inentingscampagne -+ inentingscampagnes -+ infanterie-eenheden -+ infanterie-eenheid -+ infanterieaanval -+ infanteriebataljon -+ infanteriebataljons -+ infanteriedivisie -+ infanterieregiment -+ infanterieregimenten -+ infanteriesoldaat -+ infanteriesoldaten -+ infantiliseerde -+ infantilisering -+ infantiliteiten -+ infectiebestrijding -+ infectiedruk -+ infectiehaarden -+ infectiekans -+ infectieuze -+ infernale -+ infertiele -+ infiltraten -+ infiltratiepoging -+ infiltratiepogingen -+ inflatieangst -+ inflatiebestrijding -+ inflatiecijfers -+ inflatiegevaar -+ inflatiegolf -+ inflatiespiralen -+ inflatievrees -+ inflexibele -+ influisteringen -+ influx -+ influxen -+ info's -+ infoavond -+ infoavonden -+ infobalie -+ infobalies -+ infocentra -+ infocentrum -+ infolijn -+ infootje -+ informalisering -+ informaliteiten -+ informateurs -+ informatica-afdeling -+ informatica-afdelingen -+ communicatietechnologie -+ informatie-eenheden -+ informatie-eenheid -+ informatie-industrie -+ informatieavond -+ informatieavonden -+ informatiebalies -+ informatiebank -+ informatiebehoeften -+ informatiebehoeftes -+ informatiebladen -+ informatiecentra -+ informatiefolder -+ informatiefolders -+ informatiekanaal -+ informatiekanalen -+ informatielijn -+ informatielijnen -+ informatiemarkt -+ informatiemarkten -+ informatiemedia -+ informatienetwerk -+ informatietechnologisch -+ informatietechnologische -+ informatieverspreiding -+ informatieverstrekkingen -+ informatieverzorging -+ informatievoorzieningen -+ informatiseerde -+ informatricen -+ infostand -+ infostands -+ infotainment -+ infraroodbron -+ infraroodbronnen -+ infraroodcamera -+ infraroodcamera's -+ infraroodopname -+ infraroodopnamen -+ infraroodopnames -+ infraroodsatelliet -+ infraroodstraling -+ infrasone -+ infrastructuurbeleid -+ infrastructuurplan -+ infrastructuurproject -+ infusen -+ infusies -+ ing. -+ ingangsdata -+ ingangsdatums -+ ingangsdeur -+ ingangsdeuren -+ ingangsexamen -+ ingangsexamens -+ ingangsleeftijd -+ ingebeukt -+ ingeboord -+ ingebruiksstelling -+ ingecheckt -+ ingegraveerd -+ ingegroefd -+ ingekaderd -+ ingekakt -+ ingelokt -+ ingeloodst -+ ingemeen -+ ingemene -+ ingenieursbureaus -+ ingenieursdiploma's -+ ingenieursopleiding -+ ingenieursopleidingen -+ ingenieursstudie -+ ingenieurstitel -+ ingeoefend -+ ingeparkeerd -+ ingeponst -+ ingeraamd -+ ingeranseld -+ ingeroosterd -+ ingeschilderd -+ ingeslepen -+ ingesleten -+ ingesprekstoon -+ ingesteldheid -+ ingestraald -+ ingetapet -+ ingevlucht -+ ingewandsstoornissen -+ ingewandsworm -+ ingewandswormen -+ ingewikkeldheden -+ ingezijpeld -+ ingezongen -+ ingezwachteld -+ ingezworen -+ ingrediëntenlijst -+ ingveonisme -+ ingveonismen -+ inhaalmatch -+ inhaalmatchen -+ inhaalmatches -+ inhaaloperatie -+ inhaalpoging -+ inhaalstroken -+ inhaalvraag -+ inhaalwedstrijden -+ inhalator -+ inhalatoren -+ inhalators -+ inhammetje -+ inheemsen -+ inhibities -+ inhoudsbepalingen -+ inhumatie -+ inhumaties -+ initiaalwoord -+ initiaalwoorden -+ initiatiecursus -+ initiatiecursussen -+ initiatiefneemster -+ initiatiefneemsters -+ initiatiefontwerp -+ initiatiefrijk -+ initiatiefrijke -+ initiatiefvoorstellen -+ initiatiefwet -+ initiatiefwetsontwerp -+ initiatiefwetsvoorstel -+ initiatiefwetten -+ initiaties -+ initiators -+ initiëring -+ injectiemotor -+ injectiemotoren -+ injectiemotors -+ injectienaalden -+ inkaderen -+ inkadering -+ inkakken -+ inkapseling -+ inkapselingen -+ inkiesnummer -+ inkiesnummers -+ inklaarder -+ inklaarders -+ inklaptafel -+ inklaptafels -+ inklaringsactiviteit -+ inklaringsactiviteiten -+ inkleuringen -+ inkomensafhankelijke -+ inkomensbelasting -+ inkomensderving -+ inkomensgarantie -+ inkomensgaranties -+ inkomensherverdeling -+ inkomensklassen -+ inkomensplaatje -+ inkomensplaatjes -+ inkomenssfeer -+ inkomensstijging -+ inkomenstrekker -+ inkomenstrekkers -+ inkomensverlies -+ inkomensverliezen -+ inkomgeld -+ inkomgelden -+ inkomstenbelastingstarief -+ inkomstenbelastingstarieven -+ inkomstenbelastingtarief -+ inkomstenbelastingtarieven -+ inkomstenverlies -+ inkoopafdelingen -+ inkoopmanager -+ inkoopmanagers -+ inkoppen -+ inkrassen -+ inkrijgen -+ inktkoelie -+ inktkoelies -+ inktlijn -+ inktlijnen -+ inktmoppen -+ inktreservoir -+ inktreservoirs -+ inktvisring -+ inktvisringen -+ inktzwart -+ inlaatkleppen -+ inlauten -+ inleenkracht -+ inleenkrachten -+ inlegkunde -+ inlenen -+ inleverdata -+ inleving -+ inlichtingennummer -+ inlichtingenofficier -+ inlichtingenofficieren -+ inlineskaten -+ inlineskates -+ inlognaam -+ inlognamen -+ inlokken -+ inloodsen -+ inloopcentra -+ inloopcentrum -+ inloophuis -+ inloophuizen -+ inloopspreekuur -+ innamebeleid -+ innerlijkheid -+ innestelen -+ innovatiebeleid -+ innovatienota -+ innovatieproces -+ innovatieprojecten -+ inoefenen -+ inoperabele -+ inpakpapier -+ inpandige -+ inparkeren -+ inpasbaarheid -+ inpassingen -+ inplaatsingsbeleid -+ inplantingen -+ inpluggen -+ inprentingen -+ inramen -+ inranselen -+ inreisbeperking -+ inreisbeperkingen -+ inreisverbod -+ inreisvisa -+ inreisvisum -+ inrichtingseis -+ inrichtingseisen -+ inrichtingswerk -+ inrichtingswerkers -+ inroosteren -+ inruilauto's -+ inruilpremies -+ inruilprijzen -+ inruilwaarden -+ inruilwaardes -+ inruilwagens -+ inschilderen -+ inschrijftermijn -+ inschrijvingsbewijs -+ inschrijvingsrecht -+ inschrijvingsrechten -+ inschrijvingstermijn -+ insectenbeet -+ insectenbeten -+ insectenboek -+ insectenboeken -+ insectenetend -+ insectenetende -+ insectenkenners -+ insectenlarve -+ insectenlarven -+ insectenpoeders -+ insectenpoeier -+ insectenpoeiers -+ insectenspelden -+ insectenspray -+ insectensprays -+ insectenwereld -+ insecticiden -+ inseminaties -+ insjallah -+ inslagfrequentie -+ inslagkrater -+ inslagkraters -+ inslechte -+ inslijpen -+ inslijten -+ insluipsels -+ insluitsel -+ insluitsels -+ insluitsysteem -+ insmelten -+ insnoeren -+ inspanningsfysiologen -+ inspanningsfysioloog -+ inspanningsverplichting -+ inspanningsverplichtingen -+ inspecteur-generaal -+ inspecteurs-generaal -+ inspecteurtje -+ inspectiebezoek -+ inspectiecommissie -+ inspectieronde -+ inspectieronden -+ inspectierondes -+ inspectievlucht -+ inspectievluchten -+ inspiciënten -+ inspiratieloos -+ inspiratieloze -+ inspiratoren -+ inspirators -+ inspraakavond -+ inspraakavonden -+ inspraakorgaan -+ inspraakorganen -+ inspreker -+ insprekers -+ inspuitmoment -+ inspuitsysteem -+ installatiebedrijf -+ installatiebureaus -+ installatiemateriaal -+ installatiematerialen -+ installatiesoftware -+ installering -+ instantloterij -+ instantloterijen -+ instapkaarten -+ instapniveau -+ instapniveaus -+ instappers -+ instaptoets -+ instaptoetsen -+ instemmende -+ instigatoren -+ instinker -+ institutionaliseringen -+ instituutsbibliotheken -+ instore -+ instralen -+ instraling -+ instroming -+ instroom-doorstroombaan -+ instroom-doorstroombanen -+ instroombeperking -+ instructiebad -+ instructiebaden -+ instructietafel -+ instrumentaire -+ instrumentaria -+ instrumentariums -+ instrumentenmakers -+ instrumentenpaneel -+ instrumentenpanelen -+ instrumentmaker -+ instrumentmakers -+ instudering -+ instulping -+ instulpingen -+ insubordinaties -+ insulinepomp -+ insulten -+ intakes -+ integraalhelmen -+ integratiebeleid -+ integratiepolitiek -+ integratieproject -+ integratieprojecten -+ integratoren -+ integrators -+ integristen -+ intelligentieniveau -+ intelligentieniveaus -+ intelligenties -+ intelligentietesten -+ intelligentietests -+ intendeerde -+ intensifieerde -+ intensivecareafdeling -+ intensivecareafdelingen -+ intensivecareverpleegkundige -+ intensivecareverpleegkundigen -+ intensiveringen -+ intentieovereenkomst -+ intentieverklaringen -+ intentionele -+ inter-Afrikaans -+ inter-Afrikaanse -+ inter-Amerikaans -+ inter-Amerikaanse -+ inter-Europese -+ inter-Palestijns -+ inter-Palestijnse -+ interactiepatroon -+ interactieproces -+ interbellums -+ interbestuurlijk -+ interbestuurlijke -+ intercalaties -+ intercedent -+ intercedente -+ intercedenten -+ intercedentes -+ intercepteerde -+ intercepties -+ interceptoren -+ interceptors -+ intercitylijnen -+ intercitystation -+ intercitystations -+ intercitytreinen -+ intercommunales -+ intercommunie -+ interconfessionele -+ interdiocesane -+ interestlasten -+ interestresultaat -+ interestvoet -+ interglacialen -+ interieurarchitect -+ interieurarchitecten -+ interieurarchitectuur -+ interieurdecoratie -+ interieurproduct -+ interieurproducten -+ interim-adviezen -+ interim-akkoord -+ interim-dividenden -+ interim-kabinet -+ interim-manager -+ interim-managers -+ interim-oplossing -+ interim-rapporten -+ interim-uitkering -+ interimaire -+ interimaris -+ interimarissen -+ interimjob -+ interimjobs -+ interimkantoor -+ interimkantoren -+ interimwerk -+ interjecties -+ interlandcarrière -+ interlandloopbaan -+ interlands -+ interliner -+ interliners -+ interlinieerde -+ interludia -+ interludiums -+ intermedia -+ intermedium -+ interministeriële -+ internaliseerde -+ internalisering -+ internationaal-economisch -+ internationaal-economische -+ internationaal-politiek -+ internationaal-politieke -+ internationaalrechtelijk -+ internationaalrechtelijke -+ internationalisaties -+ internationaliseerde -+ internationaliseringen -+ internationalisten -+ internationals -+ internetaansluitingen -+ internetbankierde -+ internetbankieren -+ internetcafé -+ internetcafés -+ internetcafétje -+ internetprovider -+ internetproviders -+ internette -+ internettoegang -+ interparlementaire -+ interpellatiedebat -+ interpretatiefout -+ interpretatiefouten -+ interpretatiekader -+ interpretatiekaders -+ interpretatiemogelijkheden -+ interpretatoren -+ interpreten -+ interprovinciale -+ interregio's -+ interregionet -+ interregionetten -+ interregiotrein -+ interregiotreinen -+ interreligieuze -+ interruptiedebat -+ interruptiemicrofoons -+ intersectorale -+ interstatelijk -+ interstatelijke -+ intertekstuele -+ intervaltraining -+ intervaltrainingen -+ interventiekoers -+ interventiemacht -+ interventieprijzen -+ interventiepunt -+ interventieteam -+ interventionistische -+ interviewfragment -+ interviewfragmenten -+ interzonale -+ intestinale -+ intiemspray -+ intiemsprays -+ intifada's -+ intikkertje -+ intimidatiepoging -+ intimidatiepogingen -+ intimidatiepolitiek -+ intimidatiepraktijken -+ intimistische -+ intoming -+ intonatieprobleem -+ intonatieproblemen -+ intra-Europese -+ intra-uteriene -+ intracellulaire -+ intracommunautaire -+ intramusculaire -+ intranet -+ intransigente -+ intriest -+ intrieste -+ intro's -+ introducees -+ introductieabonnement -+ introductiebericht -+ introductiekoers -+ introductieprijs -+ introns -+ introspecties -+ intrusies -+ invalbaan -+ invalbanen -+ invalbeurt -+ invalbeurten -+ invalideerde -+ invalidentoilet -+ invalidentoiletten -+ invalidenwagens -+ invaliditeitspensioen -+ invaliditeitspensioenen -+ invaliditeitsuitkering -+ invaller-doelman -+ invallersrol -+ invariabele -+ invasieleger -+ invasielegers -+ invasiemacht -+ invasievloot -+ invectieven -+ inventarisatielijst -+ inventarisatielijsten -+ inventarisering -+ inverdiend -+ inverdieneffect -+ inverdieneffecten -+ inverdienen -+ inverte -+ investeerdersgroep -+ investeringsbijdragen -+ investeringsfonds -+ investeringsfondsen -+ investeringsgoederenindustrie -+ investeringsgroei -+ investeringspremie -+ investeringspremieregeling -+ investeringspremies -+ investeringsprogramma -+ investeringsprogramma's -+ investeringssubsidie -+ investeringssubsidies -+ investmentbank -+ investmentbanken -+ invitee -+ invitees -+ invites -+ invluchten -+ invoelbare -+ invoelingsvermogen -+ invoerbelastingen -+ invoerbeperking -+ invoerbeperkingen -+ invoerhavens -+ invoerheffing -+ invoerheffingen -+ invoeringsdata -+ invoeringsdatum -+ invoeringstermijn -+ invoerquota -+ invraagstelling -+ invrijheidsstelling -+ invrijheidsstellingen -+ invuller -+ invullers -+ inwerkingstelling -+ inwisselbaarheid -+ inwit -+ inwitte -+ Dominica -+ Dominicaanse Republiek -+ inwoneraantal -+ inwonertallen -+ inwonertje -+ inworpen -+ inzages -+ inzamelactie -+ inzamelacties -+ inzamelingsacties -+ inzijpelen -+ inzingen -+ inzweren -+ ionenbuis -+ ionenbuizen -+ ionenwisselaar -+ ionisch -+ ionische -+ ionosferisch -+ ionosferische -+ ippon -+ ippons -+ ir. -+ iriscoop -+ iriscopen -+ iriscopisten -+ iriseerde -+ irisscan -+ irisscans -+ ironieën -+ irrealistische -+ irreële -+ irrigatiekanaal -+ irrigatiekanalen -+ irrigatieproject -+ irrigatieprojecten -+ irrigatiesysteem -+ irrigatietechniek -+ irrigatiewater -+ irrigatoren -+ isgelijkteken -+ isgelijktekens -+ islamiseerde -+ islamisering -+ islamist -+ islamisten -+ islamistisch -+ islamistische -+ islamitisch-fundamentalistisch -+ islamitisch-fundamentalistische -+ islamologen -+ islamologisch -+ islamologische -+ isobare -+ isochrone -+ isolatielagen -+ isolatieschuim -+ isolationisten -+ isolationistische -+ isomeriseerde -+ isotherme -+ isotone -+ isotopenverhouding -+ italiaan -+ italianen -+ italianisanten -+ italianiseerde -+ ivf -+ ivf-behandeling -+ ivf-behandelingen -+ ivoorhandel -+ ivoorkleurige -+ ivoorwit -+ ivoorwitte -+ j's -+ j'tje -+ ja-neevraag -+ ja-neevragen -+ ja-stem -+ ja-stemmen -+ ja-stemmer -+ ja-stemmers -+ jaarafrekening -+ jaarafrekeningen -+ jaarclubs -+ jaardividend -+ jaargemiddelden -+ jaargemiddeldes -+ jaargenotes -+ jaarkaarten -+ jaarklas -+ jaarklasse -+ jaarklassen -+ jaarklassensysteem -+ jaarprijs -+ jaarproductie -+ jaarprogramma -+ jaarrede -+ jaarredes -+ jaarresultaat -+ jaarresultaten -+ jaartemperatuur -+ jaartotalen -+ jaarweddes -+ jabotje -+ jachtbouw -+ jachtbouwer -+ jachtbouwers -+ jachtbuit -+ jachtclub -+ jachtclubs -+ jachtdruk -+ jachtgebieden -+ jachtigheid -+ jachtinstinct -+ jachtlak -+ jachtlakken -+ jachtluipaard -+ jachtluipaarden -+ jachtsaus -+ jachtsausen -+ jachtsauzen -+ jachtspringen -+ jachttaferelen -+ jachttrofee -+ jachttrofeeën -+ jachtvergunning -+ jachtvergunningen -+ jachtwerf -+ jachtwerven -+ jack russell -+ jack russells -+ jacketkronen -+ jackpots -+ jackpotten -+ jackrussellterriër -+ jackrussellterriërs -+ jacuzzi -+ jacuzzi's -+ jaden -+ jagersgroen -+ jagersgroene -+ jagersjas -+ jagersjassen -+ jagerssaus -+ jagersvolkeren -+ jakamp -+ jaknikken -+ jakobakan -+ jakobiet -+ jakobieten -+ jakobskruiskruid -+ jaks -+ jaloersmakend -+ jaloersmakende -+ jambalaya -+ jamde -+ jammertonen -+ jammertoon -+ jammie -+ jamsessie -+ jamsessies -+ jan-van-genten -+ jandoedels -+ janet -+ janetten -+ jankerig -+ jankerige -+ janooms -+ jansenistisch -+ jansenistische -+ januskop -+ januskoppen -+ jap -+ japanner -+ japanners -+ japanologen -+ japanologisch -+ japanologische -+ japanoloog -+ jappen -+ jappenkamp -+ jappenkampen -+ japs -+ jarretelgordels -+ jarretelgordeltje -+ jarretellen -+ jarretellengordel -+ jarretellengordels -+ jarretellengordeltje -+ jarretelletje -+ jasbeschermers -+ jasje-dasje -+ jasmijnthee -+ jaspand -+ jaspanden -+ jasschorten -+ jasses -+ jatmozen -+ jatter -+ jatters -+ jatwerk -+ java-aap -+ java-apen -+ javamens -+ javamensen -+ javel -+ jazegger -+ jazeggers -+ jazzballetten -+ jazzcafeetje -+ jazzcafé -+ jazzcafés -+ jazzconcert -+ jazzconcerten -+ jazzfestivals -+ jazzorkest -+ jazzorkesten -+ jazzpianist -+ jazzpianisten -+ jazzplaat -+ jazzplaten -+ jazztrompettist -+ jazzzangeres -+ jazzzangeressen -+ jeansmerk -+ jeansmerken -+ jeansvest -+ jeansvesten -+ jee -+ jeepsafari -+ jeepsafari's -+ jeetje -+ jeetjemina -+ jehova's -+ jekkertje -+ jemig -+ jeminee -+ jenaplanscholen -+ jenaplanschool -+ jende -+ jeneverbesstruik -+ jeneverglaasje -+ jeneverglas -+ jeneverglazen -+ jeneverkruik -+ jeneverkruiken -+ jengels -+ jerrycans -+ jesjieve -+ jesjiva -+ jetlags -+ jeton -+ jetons -+ jets -+ jetskiede -+ jetskiet -+ jetskiën -+ jetskiër -+ jetskiërs -+ jetstream -+ jetstreams -+ jeu-de-boul -+ jeu-de-boulde -+ jeu-de-boulen -+ jeu-de-boult -+ jeugdarts -+ jeugdartsen -+ jeugdatelier -+ jeugdateliers -+ jeugdbenden -+ jeugdbescherming -+ jeugdblad -+ jeugdbladen -+ jeugdboeken -+ jeugdboekenschrijver -+ jeugdboekenschrijvers -+ jeugdcellenhuis -+ jeugdcellenhuizen -+ jeugdcentra -+ jeugdcommissie -+ jeugdcommissies -+ jeugdconcert -+ jeugdconcerten -+ jeugdcriminaliteit -+ jeugddromen -+ jeugddroom -+ jeugdelftallen -+ jeugdfilm -+ jeugdfilms -+ jeugdgevangenissen -+ jeugdhonken -+ jeugdhotel -+ jeugdhotels -+ jeugdhuis -+ jeugdhuizen -+ jeugdinrichtingen -+ jeugdinstelling -+ jeugdinstellingen -+ jeugdinternaat -+ jeugdinternaten -+ jeugdjournaals -+ jeugdjournalen -+ jeugdkampioen -+ jeugdkampioenen -+ jeugdkampioenschap -+ jeugdkampioenschappen -+ jeugdleden -+ jeugdlid -+ jeugdliefdes -+ jeugdorkest -+ jeugdorkesten -+ jeugdplan -+ jeugdplannen -+ jeugdploeg -+ jeugdploegen -+ jeugdpolitie -+ jeugdprogramma's -+ jeugdpsychiater -+ jeugdpsychiaters -+ jeugdpuistje -+ jeugdrechtbank -+ jeugdrechtbanken -+ jeugdrechter -+ jeugdrechters -+ jeugdrecord -+ jeugdrecords -+ jeugdsoos -+ jeugdsozen -+ jeugdspeler -+ jeugdspelers -+ jeugdstrafrecht -+ jeugdtaal -+ jeugdtandverzorger -+ jeugdtandverzorgers -+ jeugdtheater -+ jeugdtitel -+ jeugdtitels -+ jeugdtoernooi -+ jeugdtoernooien -+ jeugdtrainer -+ jeugdtrainers -+ jeugdtrauma -+ jeugdtrauma's -+ jeugdtraumata -+ jeugdvriendinnetje -+ jeugdwelzijnsbeleid -+ jeugdwerking -+ jeukbult -+ jeukbulten -+ jeunes premiers -+ jezusfreak -+ jezusfreaks -+ jezuïetenscholen -+ jezuïetenschool -+ jhr. -+ jid -+ jidden -+ jihad -+ jihadist -+ jihadisten -+ jihadistisch -+ jihadistische -+ jihads -+ jij-bak -+ jij-bakken -+ jij-vorm -+ jip-en-janneketaal -+ jippie -+ jobaanbieding -+ jobaanbiedingen -+ jobben -+ jobber -+ jobbers -+ jobbeurs -+ jobbeurzen -+ jobcenter -+ jobcenters -+ jobcreatie -+ jobde -+ jobdienst -+ jobhoppen -+ jobhopper -+ jobhoppers -+ jobhopte -+ jobkrant -+ jobkranten -+ jobs -+ jobstudent -+ jobstudente -+ jobstudenten -+ jobstudentes -+ jockeytje -+ jodelaars -+ jodenfooi -+ joego -+ joego's -+ joepie -+ joetjes -+ joffer -+ joffers -+ jogde -+ joggingbroeken -+ joggingpakken -+ join -+ joinde -+ joinen -+ joint ventures -+ joints -+ jojo's -+ jojo-effect -+ jojo-etappe -+ jojobeleid -+ jojode -+ jonagold -+ jonagolds -+ jonas -+ jonathan -+ jonathans -+ jongensband -+ jongensbands -+ jongensboekachtig -+ jongensboekachtige -+ jongensdromen -+ jongenshart -+ jongenskamers -+ jongensprostitutie -+ jongensscholen -+ jongensschool -+ jongenssopraan -+ jongenssopranen -+ jongensstem -+ jongensstemmen -+ jongenstijd -+ jongerenafdeling -+ jongerenbeweging -+ jongerencamping -+ jongerencampings -+ jongerencentra -+ jongerengroep -+ jongerenorganisatie -+ jongerenpaspoort -+ jongerenpaspoorten -+ jongerenprogramma -+ jongerenprogramma's -+ jongerenraad -+ jongerenraden -+ jongerensoos -+ jongerenvereniging -+ jongleerders -+ jongvolwassen -+ jongvolwassene -+ jongvolwassenen -+ jonkie -+ jonkies -+ joods-christelijk -+ joods-christelijke -+ jopper -+ joppers -+ jordaanlied -+ jordaanliederen -+ jordaanzanger -+ jordaanzangers -+ jota's -+ joude -+ jouen -+ jouker -+ joules -+ journaalbeeld -+ journaalbeelden -+ journaalfragment -+ journaalfragmenten -+ journaalpresentator -+ journaalpresentatoren -+ journaals -+ journaalteam -+ journaaluitzending -+ journaaluitzendingen -+ journaalverslaggever -+ journalistenbond -+ journalistencafé -+ journalistenvakbond -+ journalistenvereniging -+ joyrider -+ joyriders -+ jozefs -+ jubeltenen -+ jubileumbijeenkomst -+ jubileumboek -+ jubileumboeken -+ jubileumconcert -+ jubileumconcerten -+ jubileumcongres -+ jubileumcongressen -+ jubileumfeest -+ jubileumfeesten -+ jubileumnummer -+ jubileumnummers -+ jubileumtentoonstelling -+ jubileumtentoonstellingen -+ jubileumuitgaven -+ judaïca -+ judobanden -+ judobond -+ judode -+ judokampioenschap -+ judokampioenschappen -+ judomat -+ judosport -+ judotitel -+ judowedstrijd -+ judowedstrijden -+ juffertje-in-'t-groen -+ juffertjes-in-'t-groen -+ jugendstil -+ juichstemming -+ juichverhaal -+ juichverhalen -+ juinde op -+ jukeboxen -+ juliaans -+ juliaanse -+ jumbo's -+ jumbojets -+ jumelages -+ jump-'n-jive -+ jump-'n-jivemuziek -+ jumpertje -+ jumpsuits -+ junglemes -+ junglemessen -+ junidag -+ juniorenkampioen -+ juniorenkampioenen -+ juniorenselectie -+ juniorenselecties -+ juniorenteam -+ juniorenteams -+ juniorentijd -+ junken -+ junta's -+ juntaleider -+ jura -+ jurassisch -+ jurassische -+ jurering -+ jureringen -+ juridificering -+ juridisch-technisch -+ juridisch-technische -+ juridisering -+ juristenpartij -+ juristes -+ juryprijs -+ juryrapport -+ juryrapporten -+ juryuitspraak -+ juryverslag -+ jus d'orangeje -+ jusblokje -+ jusblokjes -+ juskommen -+ juslepels -+ justiniaans -+ justiniaanse -+ justitiabele -+ justitieapparaat -+ justitieassistent -+ justitieassistenten -+ justitiebegroting -+ justitiebeleid -+ justitiewoordvoerder -+ justitionele -+ juttepeer -+ jutteperen -+ juut -+ juvenielen -+ juweliersbranche -+ juweliersketen -+ k's -+ k'tje -+ kW -+ kWh -+ ka's -+ kaakchirurgen -+ kaakfracturen -+ kaakgewricht -+ kaakgewrichten -+ kaakholten -+ kaakholteontsteking -+ kaakholteontstekingen -+ kaakholtes -+ kaakklemmen -+ kaakontstekingen -+ kaakstomp -+ kaakstompen -+ kaakstoten -+ kaalde -+ kaalgegraasd -+ kaalgegraasde -+ kaalgeknipt -+ kaalgeplukt -+ kaalgeslagen -+ kaalgevreten -+ kaalplukken -+ kaalplukteam -+ kaalplukteams -+ kaalslaan -+ kaalvreten -+ kaande -+ kaarsenpitten -+ kaarsvlam -+ kaarsvlammen -+ kaarsvlammetje -+ kaartenkamers -+ kaartenmaker -+ kaartenmakers -+ kaartjescontroleur -+ kaartjesverkoper -+ kaartjesverkopers -+ kaartlegging -+ kaartleggingen -+ kaartlezers -+ kaartspelletje -+ kaarttelefoon -+ kaarttelefoons -+ kaasboerderij -+ kaasboerderijen -+ kaasboor -+ kaasboren -+ kaasbroodjes -+ kaasburger -+ kaasburgers -+ kaasexport -+ kaasfondues -+ kaaslinnen -+ kaasmaken -+ kaasmakerij -+ kaasmakers -+ kaasplanken -+ kaasplateaus -+ kaasprijs -+ kaasprijzen -+ kaasproductie -+ kaassausen -+ kaassauzen -+ kaasschaafmethode -+ kaassoort -+ kaassoorten -+ kaassouffleetje -+ kaassoufflés -+ kaastaart -+ kaastaarten -+ kaaswinkel -+ kaaswinkels -+ kaatsclubs -+ kaatstuig -+ kabaja's -+ kabbalisten -+ kabbeling -+ kabbelingen -+ kabbes -+ kabelabonnees -+ kabelabonnementen -+ kabelbanen -+ kabelbedrijf -+ kabelbrug -+ kabelbruggen -+ kabelexploitanten -+ kabeljauwfilet -+ kabeljauwfilets -+ kabeljauwstand -+ kabelkanaal -+ kabelkanalen -+ kabelkranten -+ kabelmaatschappij -+ kabelslot -+ kabelsloten -+ kabelsysteem -+ kabeltelevisie-exploitant -+ kabeltelevisiemaatschappij -+ kabeltelevisienet -+ kabeltelevisienetten -+ kabinetsattaché -+ kabinetsattachés -+ kabinetsbeslissingen -+ kabinetsbesluit -+ kabinetsbesluiten -+ kabinetschefs -+ kabinetsdecreet -+ kabinetsformaties -+ kabinetslid -+ kabinetsraden -+ kabinetswijziging -+ kabinetswijzigingen -+ kabinetswisseling -+ kabinetswisselingen -+ kabouterhuisje -+ kabouterhuisjes -+ kabouterland -+ kabuki -+ kachelde -+ kadasters -+ kadaverdisciplines -+ kadavertje -+ kaddisjen -+ kaderbrief -+ kaderde -+ kaderstelling -+ kadervorming -+ kaderwetten -+ kades -+ kadet -+ kadi's -+ kadrering -+ kaenozoïcum -+ kafferbuffel -+ kafferbuffels -+ kaffiya -+ kaffiya's -+ kafir -+ kafirs -+ kafka-achtig -+ kafka-achtige -+ kafkaiaans -+ kafkaiaanse -+ kafkaësk -+ kafkaëske -+ kaiserbroodje -+ kaiserbroodjes -+ kaiserbrötchen -+ kaisoi -+ kajotster -+ kajotsters -+ kajuitzeiljacht -+ kajuitzeiljachten -+ kakemono's -+ kaki's -+ kakker -+ kakkerij -+ kakkerlak -+ kakkerlakken -+ kakkers -+ kakkies -+ kakmadam -+ kakmadammen -+ kakmadams -+ kakofonische -+ kalasjnikov -+ kalasjnikovs -+ kalenderblaadje -+ kalenderblad -+ kalenderbladen -+ kalenderleeftijd -+ kalendermethode -+ kalendermethoden -+ kalendermethodes -+ kalenderspreuken -+ kalfsborsten -+ kalfslap -+ kalfslappen -+ kalfsoestertje -+ kalfsschenkel -+ kalfsschenkels -+ kali-industrie -+ kalimijn -+ kalkafzetting -+ kalkarm -+ kalkoenfilet -+ kalkoenfilets -+ kalkschaal -+ kalkschalen -+ kallegaaide -+ kallegaaien -+ kalletje -+ kalletjes -+ kalmering -+ kalmeringstablet -+ kalmeringstabletten -+ kalong -+ kalongs -+ kalverbox -+ kalverboxen -+ kalvermarkt -+ kalvermester -+ kalvermesters -+ kameelachtige -+ kameelachtigen -+ kamelendrijvers -+ kameraadschappelijkheid -+ kamerantennes -+ kamerensemble -+ kamerensembles -+ kamergenoot -+ kamergenote -+ kamergenoten -+ kamergenotes -+ kamerinrichtingen -+ kamerjassen -+ kamerkoren -+ kamermusici -+ kamermusicus -+ kamermuziekwerk -+ kamermuziekwerken -+ kameropera -+ kameropera's -+ kamerorgel -+ kamerorgels -+ kamerprijs -+ kamerprijzen -+ kamerschermen -+ kamerthermostaten -+ kamerverhuurbedrijf -+ kamerverhuurders -+ kamerwand -+ kamerwanden -+ kamferballetjes -+ kamferkisten -+ kamikazeachtig -+ kamikazeachtige -+ kamikazeactie -+ kamikazeacties -+ kamikazepiloten -+ kamikazes -+ kamilles -+ kamparts -+ kampartsen -+ kampbeheerders -+ kampbewoner -+ kampbewoners -+ kampeerauto's -+ kampeerbed -+ kampeerbedden -+ kampeerbussen -+ kampeerterreintje -+ kampeeruitrustingen -+ kampeerwagen -+ kampeerwagens -+ kampioenenmaker -+ kampioensbeker -+ kampioensbekers -+ kampioenscompetitie -+ kampioensgordel -+ kampioensploeg -+ kampioenspoule -+ kampioenspoules -+ kampioenstrui -+ kampioenswedstrijd -+ kampioenswedstrijden -+ kampkaart -+ kampkaarten -+ kampleven -+ kampsyndroom -+ kampwinkels -+ kamsin -+ kamsins -+ kanaalzwemmen -+ kanalenkiezers -+ kanalenstelsel -+ kanalenstelsels -+ kanalisering -+ kandidaat-Kamerlid -+ kandidaat-bestuursleden -+ kandidaat-bestuurslid -+ kandidaat-international -+ kandidaat-internationals -+ kandidaat-kanselier -+ kandidaat-lidstaat -+ kandidaat-lidstaten -+ kandidaat-plaatsvervanger -+ kandidaat-plaatsvervangers -+ kandidaatstellingsprocedure -+ kandidates -+ kandijstroop -+ kaneelstokjes -+ kangoeroeschepen -+ kangoeroeschip -+ kankantri -+ kankantri's -+ kankerbestrijding -+ kankercel -+ kankercellen -+ kankergenen -+ kankerlijers -+ kankeronderzoek -+ kankerpatiënten -+ kankerpitten -+ kankers -+ kankerstok -+ kankerstokken -+ kannibaliseerde -+ kannibalistisch -+ kannibalistische -+ kano's -+ kanobond -+ kanoeten -+ kanoetstrandloper -+ kanoetstrandlopers -+ kanonslag -+ kanonslagen -+ kansberekening -+ kansberekeningen -+ kanselarijminister -+ kanselierschap -+ kansspelautomaat -+ kansspelautomaten -+ kant-en-klaar -+ kant-en-klaargerecht -+ kant-en-klaargerechten -+ kant-en-klaarmaaltijd -+ kant-en-klaarmaaltijden -+ kant-en-klare -+ kantelbaar -+ kantelbare -+ kantelbedden -+ kanteldeuren -+ kantelramen -+ kantiaan -+ kantianen -+ kantinebaas -+ kantinebeheerder -+ kantinebeheerders -+ kantinebijeenkomst -+ kantinebijeenkomsten -+ kantjesharingen -+ kantooragenda's -+ kantoorarbeid -+ kantoorartikel -+ kantoorartikelen -+ kantoorcomplex -+ kantoorcomplexen -+ kantoorflat -+ kantoorflats -+ kantoorhouder -+ kantoorhouders -+ kantoorkast -+ kantoorkasten -+ kantoormeubel -+ kantoorsysteem -+ kantoortuinen -+ kantoorwijk -+ kantoorwijken -+ kantorencomplex -+ kantorencomplexen -+ kantorenpark -+ kantorenwijk -+ kaoline -+ kapbeweging -+ kapbewegingen -+ kapconstructies -+ kapersnesten -+ kaping -+ kapingen -+ kapitaalbasis -+ kapitaalbelasting -+ kapitaaldekkingsstelsel -+ kapitaalinjectie -+ kapitaalinjecties -+ kapitaallasten -+ kapitaalmarktrente -+ kapitaalmarktrentes -+ kapitaalrenten -+ kapitaalrentes -+ kapitaalsbasis -+ kapitaalsbelasting -+ kapitaalsinjectie -+ kapitaalsinjecties -+ kapitaalsintensief -+ kapitaalsintensieve -+ kapitaalsinvesteringen -+ kapitaalslasten -+ kapitaalsstromen -+ kapitaalsstroom -+ kapitaalstorting -+ kapitaalstromen -+ kapitaalwinst -+ kapitalisatiebon -+ kapitalisatiebonnen -+ kapitalisatiebons -+ kapitein-commandant -+ kapitein-generaal -+ kapitein-luitenant -+ kapitein-luitenants -+ kapitein-vlieger -+ kapiteins-commandanten -+ kapiteins-generaal -+ kapiteins-vliegers -+ kapiteinshut -+ kapiteinshutten -+ kapiteinspet -+ kapiteinspetten -+ kapmanteltje -+ kapotbijten -+ kapotgebeten -+ kapotgevroren -+ kapotvriezen -+ kappa's -+ kappersvakschool -+ kappertjessaus -+ kapseltje -+ kapvergunning -+ kapvergunningen -+ karakterbeschrijving -+ karakterbeschrijvingen -+ karakterfout -+ karakterfouten -+ karakteriseringen -+ karaktermoord -+ karaktermoorden -+ karakterologische -+ karaktertje -+ karaktervastheid -+ karakterzwakte -+ karamellenvers -+ karamellenverzen -+ karamelpuddingen -+ karaoke -+ karaokebar -+ karaokebars -+ karaoken -+ karaook -+ karaookt -+ karaookte -+ karateslag -+ karateslagen -+ karatetrap -+ karavaanroute -+ karavaanroutes -+ karavansera's -+ karbonadetje -+ kardinaalrode -+ kardinaalrood -+ karpatenklokje -+ karpatenklokjes -+ karrenpaarden -+ kartelachtig -+ kartelachtige -+ kartelbesluiten -+ kartelmessen -+ kartelscharen -+ kartelsneden -+ kartelverbod -+ karten -+ karteringen -+ karteringsvluchten -+ kartonfabriek -+ kartonnages -+ karts -+ kartte -+ karweiman -+ karweimannen -+ kasadministratie -+ kasba's -+ kasbiljet -+ kasbiljetten -+ kasbon -+ kasbonnen -+ kasbons -+ kascontroles -+ kaseko -+ kasekoband -+ kasekobands -+ kasfruit -+ kasgroente -+ kasgroenten -+ kasgroentes -+ kashba's -+ kasiri -+ kasjerde -+ kasjeren -+ kasjroet -+ kasmoni -+ kasreserves -+ kassa-inkomsten -+ kassabonnen -+ kassabons -+ kassaldo's -+ kasseienstroken -+ kasseienstrook -+ kasseienweg -+ kasseistroken -+ kasseistrook -+ kassencomplex -+ kassencomplexen -+ kassiersters -+ kassiewijle -+ kassière -+ kassières -+ kasstelsels -+ kasstromen -+ kassuccessen -+ kastanjechampignon -+ kastanjechampignons -+ kasteelgracht -+ kasteelgrachten -+ kasteelpark -+ kasteelroman -+ kasteelromannetje -+ kasteelromans -+ kasteeltuin -+ kasteeltuinen -+ kasteelwijn -+ kasteelwijnen -+ kastenwand -+ kastenwanden -+ kasticket -+ kastickets -+ kastruimte -+ kastuinder -+ kastuinders -+ kat-en-muisspel -+ kat-en-muisspelletje -+ kat-in-de-zak -+ katabole -+ katalyseerde -+ katapulteerde -+ katenspek -+ katerstemming -+ katheteriseerde -+ katheters -+ kathodestraalbuizen -+ katoendruk -+ katoengaren -+ katoenstof -+ katoenteelt -+ kattenbakgrit -+ kattenbakken -+ kattendarm -+ kattendarmen -+ kattendoorn -+ kattendoorns -+ kattendoren -+ kattendorens -+ kattengaten -+ kattengejank -+ kattenkoppen -+ kattenkruid -+ kattenluik -+ kattenluiken -+ kattenmeppers -+ kattenrug -+ kattenruggen -+ kattensnaar -+ kattensnaren -+ kattenstaarten -+ kattenwasje -+ kattenwasjes -+ kattenziekte -+ katvanger -+ katvangers -+ kauri's -+ kauwgombal -+ kauwgomballen -+ kauwtje -+ kawai -+ kawina -+ kawina's -+ kawinaband -+ kawinabands -+ kazakkendraaier -+ kazakkendraaiers -+ kazerneterrein -+ kaïnsmerk -+ kaïnsteken -+ keelholten -+ keelholtes -+ keeperstrainer -+ keeperstrainers -+ keeperstraining -+ keepersvak -+ keeperswerk -+ keepertrainer -+ keepertrainers -+ keepertraining -+ keepertrainingen -+ keepster -+ keepsters -+ keerboei -+ keerboeien -+ keerlus -+ keerlussen -+ keermuren -+ keerwoord -+ keerwoorden -+ keerzang -+ keerzangen -+ keesde -+ kegelvrucht -+ kegelvruchten -+ kehila -+ kehila's -+ kehille -+ kehilles -+ kei-interessant -+ kei-interessante -+ keigoed -+ keigoede -+ keiler -+ keilers -+ keinijg -+ keinijge -+ keitof -+ keitoffe -+ keizerin-moeder -+ keizersnedes -+ keldergewelf -+ keldergewelven -+ kelderruimte -+ kelderruimten -+ kelderruimtes -+ kelims -+ kelnertje -+ keltenkruis -+ keltenkruizen -+ keltistiek -+ keltologen -+ keltologie -+ keltoloog -+ kempenaar -+ kempenaars -+ kendo -+ kenleer -+ kennisbanken -+ kenniseconomie -+ kennisgebied -+ kennisgebieden -+ kennisgemaakt -+ kennisinfrastructuur -+ kennisintensief -+ kennisintensieve -+ kennismakingstijd -+ kennisniveaus -+ kennissenkringen -+ kennissociologie -+ kennistechnologie -+ kennistheoretisch -+ kennistheoretische -+ kenobject -+ kenobjecten -+ kentekenbewijzen -+ kentekennummer -+ kentekennummers -+ kentekenplaten -+ kentekenregistratie -+ kentekenregistraties -+ kentheoretisch -+ kentheoretische -+ kenvermogens -+ kenwijsje -+ kenwijsjes -+ keppeltje -+ keppeltjes -+ keramisten -+ kerkdeur -+ kerkdeuren -+ kerkenwerk -+ kerkgemeenschappen -+ kerkgemeente -+ kerkgemeenten -+ kerkgemeentes -+ kerkinterieur -+ kerkinterieurs -+ kerkkoren -+ kerkorden -+ kerkordes -+ kerkpleinen -+ kerkruimten -+ kerkruimtes -+ kerkschat -+ kerkschatten -+ kerkscheuringen -+ kerktijden -+ kerktorentje -+ kerkzilver -+ kermis -+ kermisbaas -+ kermisbazen -+ kermiskoers -+ kermiskoersen -+ kermissen -+ kermissfeer -+ kermisvermaak -+ kern-Europa -+ kernaanval -+ kernbewapening -+ kernbrandstoffen -+ kerndeeltje -+ kerndeeltjes -+ kerndelingen -+ kernenergiecentrale -+ kernenergiecentrales -+ kernenergiesector -+ kernexplosies -+ kernfuncties -+ kernfusies -+ kernfysici -+ kernfysisch -+ kernfysische -+ kerngemeente -+ kerngemeenten -+ kerngemeentes -+ kerngezin -+ kerngezinnen -+ kernhem -+ kernindustrie -+ kernkabinet -+ kernkracht -+ kernkrachten -+ kernleden -+ kernlid -+ kernloos -+ kernloze -+ kernonderzeeër -+ kernonderzeeërs -+ kernongeval -+ kernongevallen -+ kernoorlogen -+ kernploegen -+ kernploegleden -+ kernploeglid -+ kernprobleem -+ kernproblemen -+ kernproef -+ kernproeven -+ kernramp -+ kernrampen -+ kernreactoren -+ kernreactors -+ kernspinresonantie -+ kernsplijtingsafval -+ kernstop -+ kernstroom -+ kerntaken -+ kerntechniek -+ kernvergadering -+ kernvergaderingen -+ kernvrij -+ kernvrije -+ kernwapenarsenaal -+ kernwapenarsenalen -+ kernwapenmogendheid -+ kernwapentechnologie -+ kernwapenwedloop -+ kernwetenschap -+ kernwetenschappen -+ kerriepoeder -+ kersenbloesems -+ kersenbonbon -+ kersenbonbons -+ kersenontpitter -+ kersenpitten -+ kersenrode -+ kersenrood -+ kerstbals -+ kerstboomversiering -+ kerstcadeau -+ kerstcadeaus -+ kerstcadeautje -+ kerstconcert -+ kerstdrukte -+ kerstgedachte -+ kerstgratificaties -+ kerstkind -+ kerstkinderen -+ kerstklokken -+ kerstmaal -+ kerstmarkt -+ kerstmarkten -+ kerstmenu's -+ kerstmis -+ kerstnummers -+ kerstomaat -+ kerstomaten -+ kerstspelen -+ kerststallen -+ kerststaven -+ kerststerren -+ kerststol -+ kerststollen -+ kerststronk -+ kerststronken -+ kerststukjes -+ kersttoespraak -+ kersttoespraken -+ kerstverhalen -+ kerstverlichting -+ kerstverlof -+ kerstviering -+ kerstweekeinde -+ kerstwens -+ kerstwensen -+ kervelblad -+ ketelbink -+ ketelbinken -+ ketelbinkie -+ ketelbouw -+ ketelpak -+ ketelpakken -+ ketenbeheer -+ ketenbeheersing -+ kettingbedingen -+ kettingformulier -+ kettingroken -+ kettingslot -+ kettingsloten -+ kettingzagen -+ keukenblokken -+ keukendeuren -+ keukeneiland -+ keukeneilanden -+ keukengereedschappen -+ keukenhanddoek -+ keukenhanddoeken -+ keukenkruid -+ keukenmeester -+ keukenmeesters -+ keukenmeidenromannetje -+ keukenmeidenromans -+ keukenmeisje -+ keukenmeisjes -+ keukenpapier -+ keukenpersoneel -+ keukenrobot -+ keukenrobots -+ keukenstroop -+ keukentafels -+ keukentafeltje -+ keukentrappen -+ keukenvloeren -+ keurgroep -+ keurgroepen -+ keuringsarts -+ keuringsartsen -+ keuringsbureau -+ keuringsbureaus -+ keuringscommissies -+ keuringseis -+ keuringseisen -+ keurling -+ keurlingen -+ keuze-element -+ keuze-elementen -+ keuzeaanbod -+ keuzecommissies -+ keuzedividend -+ keuzeheer -+ keuzeheren -+ keuzepakket -+ keuzepakketten -+ keycard -+ keycards -+ keynesiaan -+ keynesiaans -+ keynesiaanse -+ keynesianen -+ kgm -+ khimar -+ khimars -+ ki -+ kick-and-rush -+ kick-and-rushvoetbal -+ kickboksers -+ kickboksgala -+ kickt -+ kickte -+ kidnap -+ kidnappers -+ kidnappings -+ kidnapt -+ kidnapte -+ kidneybonen -+ kidneyboon -+ kidoesj -+ kids -+ kiekenfretter -+ kiekenfretters -+ kielboot -+ kielboten -+ kielekiele -+ kiembaangentherapie -+ kiembak -+ kiembakken -+ kiendopje -+ kiendopjes -+ kiepauto's -+ kiepbak -+ kiepbakken -+ kiepkarren -+ kiepte -+ kiepwagen -+ kiepwagens -+ kiesarrondissement -+ kiesarrondissementen -+ kiesbevoegd -+ kiesbevoegde -+ kiesdrempels -+ kieskanton -+ kieskantons -+ kiesman -+ kiesmannen -+ kiesnummer -+ kiesnummers -+ kiesomschrijving -+ kiesomschrijvingen -+ kiesplatform -+ kiesplatforms -+ kiesregister -+ kiesregisters -+ kiesstrijd -+ kiestonen -+ kiezelgesteente -+ kiezelgesteenten -+ kiezelgesteentes -+ kiezelsteentje -+ kiezersaanhang -+ kijk- en luistergeld -+ kijkboek -+ kijkcijferkanon -+ kijkcijferkanonnen -+ kijkdozen -+ kijkersgunst -+ kijkersmarkt -+ kijkerspubliek -+ kijkgelden -+ kijkgenot -+ kijklustige -+ kijkonderzoek -+ kijkoperatie -+ kijkoperaties -+ kijksport -+ kijkwoning -+ kijkwoningen -+ kikkerbad -+ kikkerbaden -+ kikkerbilletje -+ kikkerbilletjes -+ kikkererwt -+ kikkererwten -+ kikkerproef -+ kikkerproeven -+ killers -+ killersinstinct -+ killersmentaliteit -+ kilohertz -+ kilojoules -+ kilometerprijzen -+ kilometerstanden -+ kilometertje -+ kilometrages -+ kiloprijzen -+ kiloton -+ kilts -+ kina-extract -+ kinderbaden -+ kinderbijslagregeling -+ kinderboekenschrijfster -+ kinderboekenschrijver -+ kinderboekenschrijvers -+ kinderboekenweekgeschenk -+ kinderboekwinkel -+ kinderboekwinkels -+ kinderboerderijen -+ kinderdag -+ kinderdorpen -+ kinderdromen -+ kinderdroom -+ kinderfietsen -+ kinderfilosofie -+ kinderfoto -+ kinderfoto's -+ kindergezicht -+ kindergezichten -+ kinderheil -+ kinderhuis -+ kinderkaarten -+ kinderkamertje -+ kinderkanker -+ kinderkleding -+ kinderkliniek -+ kinderkoortje -+ kinderkopje -+ kinderkopjes -+ kinderkranten -+ kinderledikanten -+ kinderleed -+ kinderlied -+ kinderliederen -+ kinderlijken -+ kindermenu's -+ kindermoordenaar -+ kindermoordenaars -+ kinderoppassen -+ kinderopvangcentra -+ kinderopvangcentrum -+ kinderopvoeding -+ kinderpornografie -+ kinderportret -+ kinderportretten -+ kinderprostitutie -+ kinderpsychiaters -+ kinderrecht -+ kinderrechten -+ kinderseries -+ kinderslot -+ kindersloten -+ kinderspeelplaats -+ kinderspeelplaatsen -+ kinderspelletje -+ kindersprookje -+ kindersprookjes -+ kinderstemmetje -+ kindertaaltje -+ kindertal -+ kindertoelages -+ kinderverhaal -+ kinderverhalen -+ kinderverkrachter -+ kinderverkrachters -+ kinderversje -+ kinderversjes -+ kinderverzorgsters -+ kindervoorstelling -+ kindervoorstellingen -+ kinderwagentje -+ kinderziekenhuis -+ kinderziekenhuizen -+ kindgericht -+ kindgerichte -+ kindje-op-moeders-schoot -+ kindlief -+ kindsterretje -+ kindsterretjes -+ kine -+ kine's -+ kinegram -+ kinema's -+ kinesionomie -+ kinesisten -+ kinesitherapeut -+ kinesitherapeuten -+ kinesitherapie -+ kinky -+ kioskhouder -+ kioskhouders -+ kipfilets -+ kipkerriesalade -+ kipkerriesalades -+ kippenborsten -+ kippenbout -+ kippenbouten -+ kippenkorf -+ kippenlever -+ kippenlevers -+ kippenmest -+ kippenpasteitje -+ kipper -+ kippers -+ kipschnitzel -+ kipschnitzels -+ kistkalf -+ kistkalveren -+ kitchenettes -+ kiteboard -+ kiteboardde -+ kiteboarden -+ kiteboards -+ kiteboardt -+ kiteskate -+ kiteskaten -+ kiteskatet -+ kiteskatete -+ kitesurf -+ kitesurfen -+ kitesurft -+ kitesurfte -+ kitscherige -+ kitscherigheid -+ kitschgehalte -+ kittens -+ kiwi-ijs -+ kiwiyoghurt -+ kiyu -+ klaagstem -+ klaagstemmen -+ klaar-over -+ klaar-overs -+ klaarblijkelijke -+ klaargelegen -+ klaargezeten -+ klaarliggen -+ klaarwakkere -+ klaarzitten -+ klachtenbureau -+ klachtenbureaus -+ klachtencommissies -+ klachtenlijn -+ klachtenlijnen -+ klachtenregen -+ kladblaadjes -+ kladblokken -+ kladjes -+ kladversie -+ kladversies -+ klagelijke -+ klagerigheid -+ klankassociaties -+ klankbeelden -+ klankgat -+ klankgaten -+ klankidioom -+ klankkasten -+ klankkleuren -+ klankspectrum -+ klanksymboliek -+ klanktrap -+ klanktrappen -+ klankvol -+ klankvolle -+ klankwaarde -+ klankwaarden -+ klantenpas -+ klantenpassen -+ klapbanden -+ klapdeksels -+ klapdeuren -+ klaplong -+ klapperpistolen -+ klapperpistooltje -+ klappertjespistool -+ klapraampje -+ klapschaats -+ klapschaatsen -+ klapvee -+ klaroenstoot -+ klaroenstoten -+ klasbak -+ klasbakken -+ klasgenotes -+ klassementsaanvoerder -+ klassementsleider -+ klassementsproef -+ klassementsproeven -+ klassementsrenner -+ klassementsrenners -+ klassementsrijder -+ klassementsrijders -+ klassenavonden -+ klassenbelang -+ klassenbelangen -+ klassenbewuste -+ klassenboeken -+ klassendeler -+ klassendelers -+ klassenleraars -+ klassenleraren -+ klassenorganisatie -+ klassenraad -+ klassenraden -+ klassenvertegenwoordigers -+ klassenvijand -+ klassenvijanden -+ klassespeler -+ klassespelers -+ klassiek-romantisch -+ klassiek-romantische -+ klastitularis -+ klastitularissen -+ klats -+ klauterwerk -+ klavarskribomethode -+ klaverkaart -+ klaverkaarten -+ klavertjesvieren -+ klaverwei -+ klaverweide -+ klaverweiden -+ klaverweides -+ klavierinstrumenten -+ klavierleeuw -+ kledingbedrijf -+ kledingbranche -+ kledingcollectie -+ kledingindustrie -+ kledingmagazijnen -+ kledingontwerper -+ kledingontwerpers -+ kledingtoelagen -+ kledingtoelages -+ kledingzaken -+ kleedlokaal -+ kleedlokalen -+ kleedsters -+ kleefkracht -+ kleefmijn -+ kleefmijnen -+ kleefpasta's -+ kleefrijst -+ kleermakerskrijt -+ kleideeltje -+ kleideeltjes -+ kleiduif -+ kleiduivenschieten -+ kleigebied -+ kleigebieden -+ kleinbeeldcamera's -+ kleinbehuisd -+ kleinbehuisde -+ kleinburger -+ kleinburgers -+ kleindochtertje -+ kleineringen -+ kleingekregen -+ kleinkunstacademie -+ kleinkunstenaar -+ kleinkunstenaars -+ kleinseminarie -+ kleinseminaries -+ kleinverbruik -+ kleinverbruiker -+ kleinverbruikers -+ kleinverlofganger -+ kleinverlofgangers -+ kleinzoontje -+ kleioven -+ kleiovens -+ kleiplastiek -+ kleiplastieken -+ kleiput -+ kleiputten -+ kleischalie -+ kleiterp -+ klembeugels -+ klemgereden -+ klemgezet -+ klemrijden -+ klemschroevendraaiers -+ klemtoonverschuiving -+ klemtoonverschuivingen -+ klemzetten -+ klepbruggen -+ klepdeuren -+ kleptomane -+ klepzeiker -+ klerelijers -+ klerenborstels -+ klerengek -+ klerengekken -+ klerenhangertje -+ klerevent -+ klereventen -+ klerewijven -+ klessebeste -+ kletsverhalen -+ kletteraars -+ kleuraccent -+ kleuraccenten -+ kleuradvies -+ kleuradviezen -+ kleurbaden -+ kleurcontrasten -+ kleuren-tv -+ kleuren-tv's -+ kleurenafdrukken -+ kleurenbeeldscherm -+ kleurenbeeldschermen -+ kleurencirkels -+ kleurencompositie -+ kleurencomposities -+ kleurencontrasten -+ kleurendriehoek -+ kleurendriehoeken -+ kleurenfilmpje -+ kleurengamma's -+ kleurenleer -+ kleurenlitho -+ kleurenlitho's -+ kleurenontvangers -+ kleurenpalet -+ kleurenreproducties -+ kleurenrijkdom -+ kleurenscala's -+ kleurenschema -+ kleurenschema's -+ kleurenschermen -+ kleurenschermpje -+ kleurentelevisies -+ kleurentoestellen -+ kleurfilter -+ kleurfilters -+ kleurgevoel -+ kleurgevoelige -+ kleurgevoeligheid -+ kleurintensiteit -+ kleurkaart -+ kleurkaarten -+ kleurkatern -+ kleurkaternen -+ kleurlingengemeenschap -+ kleurlingenwijk -+ kleurnaam -+ kleurnuance -+ kleurnuances -+ kleurpatronen -+ kleurpatroon -+ kleurpotloodtekening -+ kleurpotloodtekeningen -+ kleurspoelingen -+ kleurvariëteit -+ kleurvariëteiten -+ kleurvast -+ kleurvaste -+ kleurvernis -+ kleurverschillen -+ kleurversteviger -+ kleurverstevigers -+ kleurvlak -+ kleurvlakken -+ kleuterbaden -+ kleuterjaren -+ kleuteronderwijs -+ kleuterprogramma -+ kleutertuin -+ kleutertuinen -+ klezmer -+ kliederboel -+ kliederige -+ klieders -+ kliekvorming -+ klierde -+ klieving -+ klievingen -+ klimaatbeheersingssysteem -+ klimaatconferentie -+ klimaatkamers -+ klimaatregelaar -+ klimaatregelaars -+ klimaatschommeling -+ klimaatsverandering -+ klimaatsveranderingen -+ klimaatverandering -+ klimaatveranderingen -+ klimaatzone -+ klimaatzones -+ klimatologen -+ klimgordels -+ klimmetje -+ klimnet -+ klimnetten -+ klimoefeningen -+ klimrekken -+ klimschoen -+ klimschoenen -+ klimtijdrit -+ klimtijdritten -+ klimtocht -+ klinimobiel -+ klinimobielen -+ klinisch-wetenschappelijk -+ klinisch-wetenschappelijke -+ klinkerpaadje -+ klinkertje -+ klinkerwisseling -+ klinkerwisselingen -+ klip-en-klaar -+ klipspringer -+ klipspringers -+ klisteerspuiten -+ klitwortel -+ klitwortels -+ kloffie -+ kloffies -+ klojo -+ klojo's -+ klokbeker -+ klokbekers -+ klokgebeier -+ klokgevels -+ klokjesgentiaan -+ klokjesgentianen -+ klokkenluiders -+ klokkenstoelen -+ kloksnelheden -+ klokuren -+ klokuur -+ klokvast -+ klokvaste -+ klompachtig -+ kloneerde -+ klonering -+ klontering -+ klonteringen -+ klontjessuiker -+ klontjestang -+ klontjestangen -+ kloofvlakken -+ klooi -+ klooide -+ kloosterbibliotheken -+ kloostercongregatie -+ kloostercongregaties -+ kloostergemeenschappen -+ kloostergewelf -+ kloostergewelven -+ kloostermop -+ kloosterpoorten -+ kloostertafel -+ kloostertafels -+ kloothannesen -+ kloothommel -+ kloothommels -+ klopboren -+ kloris -+ klorissen -+ klote -+ klotefilms -+ kloterijen -+ kluizenaarschap -+ klungelaars -+ klungeltje -+ klunsde -+ klunzen -+ klunzige -+ kluste -+ kluten -+ kluunde -+ kluut -+ knaagtand -+ knaagtanden -+ knaapjes -+ knabbeltjes -+ knaleffecten -+ knalfeest -+ knalfeesten -+ knalfuiven -+ knalhard -+ knalharde -+ knalprijzen -+ knechtenrol -+ knechting -+ kneedbommen -+ kneippkuur -+ knekelveld -+ knelpuntennota -+ knelpuntennota's -+ knerpte -+ knersen -+ knerste -+ knettergekke -+ knetterhard -+ knetterharde -+ kneuterigheid -+ knickerbockers -+ knieaandoening -+ knieaandoeningen -+ kniediepe -+ kniehoge -+ kniehoogte -+ knielaars -+ knielaarzen -+ knielang -+ knielange -+ knielbankjes -+ knielbussen -+ knieletsel -+ knieoperatie -+ knieoperaties -+ kniepeesreflex -+ kniepeesreflexen -+ kniereflexen -+ kniewarmer -+ kniewarmers -+ kniewater -+ knijpflessen -+ knipkunst -+ knippa -+ knippa's -+ knipperbollen -+ knipselarchief -+ knipselarchieven -+ knipselkranten -+ knipselmappen -+ kniptangetje -+ kno-arts -+ kno-artsen -+ knobbelachtig -+ knobbelachtige -+ knobbelen -+ knobbelgans -+ knobbelganzen -+ knobbelzwanen -+ knock-outsysteem -+ knoeiboeltje -+ knoeiertje -+ knoert -+ knoerten -+ knoflookgeur -+ knoflookgeuren -+ knoflookpersen -+ knoflooksaus -+ knoflooksausen -+ knoflooksauzen -+ knoflookteen -+ knoflookteentje -+ knoflooktenen -+ knokker -+ knokkers -+ knolbegonia's -+ knoldragend -+ knoldragende -+ knolvenkel -+ knolvrucht -+ knolvruchten -+ knoopband -+ knoopsluitingen -+ knotjes -+ knotse -+ knotsoefening -+ knotsoefeningen -+ knowhowovereenkomst -+ knuddig -+ knuddige -+ knuffelaar -+ knuffelaars -+ knuffelbeer -+ knuffelberen -+ knuffeldieren -+ knuffelmuren -+ knuffelmuur -+ knuffels -+ knuffeltje -+ knurft -+ knurften -+ knust -+ knut -+ knutje -+ knutselruimte -+ knutselruimten -+ knutselruimtes -+ knutten -+ koala's -+ koalaberen -+ kobaltbom -+ kobaltbommen -+ koddigheden -+ koebel -+ koebellen -+ koefnoen -+ koeiendrek -+ koeienhuiden -+ koeienletter -+ koeienletters -+ koeienplak -+ koeienplakken -+ koeienstaarten -+ koeienstallen -+ koeienstront -+ koeienvlaaien -+ koek-en-zopie -+ koek-en-zopies -+ koekeboterham -+ koekeboterhammen -+ koekebroden -+ koekebrood -+ koekenpannen -+ koekjesfabriek -+ koekjesfabrikant -+ koekkruiden -+ koekplanken -+ koektrommeltje -+ koel-vriescombinatie -+ koel-vriescombinaties -+ koelakken -+ koelmantel -+ koelmantels -+ koelruimen -+ koelruimten -+ koeltanks -+ koeltas -+ koeltassen -+ koelvak -+ koelvakken -+ koelvitrines -+ koep -+ koepelgevangenis -+ koepelraam -+ koepelramen -+ koereiger -+ koereigers -+ koerierbedrijf -+ koerierbedrijven -+ koerierdienst -+ koerierdiensten -+ koeriertje -+ koersafwijking -+ koersafwijkingen -+ koersborden -+ koerscorrecties -+ koersdruk -+ koersenverloop -+ koersfiets -+ koersfietsen -+ koersgemiddelde -+ koersgemiddelden -+ koersindex -+ koerslijn -+ koerslijnen -+ koersoverzicht -+ koersval -+ koersvast -+ koersvaste -+ koerswaarden -+ koerswinsten -+ koeskoezen -+ koesteringen -+ koestraat -+ koestraten -+ koetsiertje -+ kofferbakken -+ kofferdekschepen -+ kofferdekschip -+ kofferdeksel -+ kofferdeksels -+ kofferruimten -+ kofferruimtes -+ kofferschrijfmachines -+ koffie-ijs -+ koffie-uren -+ koffie-uurtje -+ koffiearoma -+ koffiebars -+ koffiebeker -+ koffiebekers -+ koffiebekertje -+ koffiebes -+ koffiebessen -+ koffiebitter -+ koffiebladen -+ koffieboer -+ koffieboeren -+ koffiebonnen -+ koffiebons -+ koffiebuffetten -+ koffiegezet -+ koffiekannetje -+ koffiekoek -+ koffiekoeken -+ koffiekommen -+ koffiekommetje -+ koffieleuten -+ koffielikeur -+ koffielikeuren -+ koffiemarkt -+ koffiemeisjes -+ koffiemok -+ koffiemokken -+ koffieproductie -+ koffieprut -+ koffies verkeerd -+ koffiesoort -+ koffiesoorten -+ koffiestroop -+ koffiestruik -+ koffiestruiken -+ koffiesurrogaat -+ koffiesurrogaten -+ koffieteelt -+ koffietent -+ koffietenten -+ koffiezetmachines -+ koffiezetten -+ kogelafsluiters -+ kogelbiefstukken -+ kogelgat -+ kogelpen -+ kogelpennen -+ kogelscharnier -+ kogelscharnieren -+ kogelslingeraar -+ kogelslingeraars -+ kogelstoter -+ kogelstoters -+ kogelvormen -+ kohierbelastingen -+ kokerdenken -+ kokerpaal -+ kokerpalen -+ kokerrok -+ kokerrokken -+ kokkelbank -+ kokkelbanken -+ kokkelsector -+ kokkelvisser -+ kokken -+ kokosbrood -+ kokosdistrict -+ kokoskoek -+ kokoskoeken -+ kokosvruchten -+ koksscholen -+ koksschool -+ kol nidrei -+ kola's -+ kola-extract -+ kolchozen -+ kolenboeren -+ kolengas -+ kolengestookt -+ kolengestookte -+ kolensjouwer -+ kolensjouwers -+ kolenslakken -+ kolenstof -+ kolenstook -+ kolenveld -+ kolenvelden -+ kolenvergasser -+ kolenvergassers -+ kolenvergassing -+ kolenvergassingscentrale -+ kolenvoorraad -+ kolenvoorraden -+ kolenvuur -+ kolenwinning -+ kolere -+ koleriek -+ kolerieke -+ kolffles -+ kolfflessen -+ kolfplaat -+ kolfplaten -+ kolommenbalansen -+ kolonelsbewinden -+ kolonelscoup -+ kolonelsdictatuur -+ kolonelsjunta -+ kolonelsregime -+ kolonelsregimes -+ kolonialiseerde -+ kolonialisten -+ kolonialistische -+ kolonisatie-expeditie -+ kolonisatie-expedities -+ kolonisering -+ komediantes -+ komedianteske -+ komedieschrijver -+ komedieschrijvers -+ komeetfragment -+ komeetkern -+ komeetkernen -+ komijnpoeder -+ komkommersalades -+ kommaneuker -+ kommaneukers -+ komodovaraan -+ komodovaranen -+ kompasfouten -+ kompaskoers -+ kompaskoersen -+ kompasrichtingen -+ kongsi's -+ konijnenbont -+ konijnenhokken -+ konijnenholen -+ konijnenpluim -+ konijnenpluimen -+ koning-keizer -+ koning-stadhouder -+ koningin-regentes -+ koningin-regentessen -+ koningin-weduwe -+ koninginnenhapje -+ koninginnenhapjes -+ koninginnenkruid -+ koningsaanval -+ koningsappel -+ koningsappelen -+ koningsappels -+ koningsblauw -+ koningsblauwe -+ koningsdrama -+ koningsdrama's -+ koningshuizen -+ koningskaars -+ koningskaarsen -+ koningskleur -+ koningspaar -+ koningspalm -+ koningspalmen -+ koningsparen -+ koningspinguïn -+ koningspinguïns -+ koningsstelling -+ koningsvleugel -+ koninkrijksverband -+ koninkrijkszaken -+ kontlikken -+ kontlikker -+ kontlikkers -+ kontneuken -+ kooi-eend -+ kooi-eenden -+ kooi-ei -+ kooiconstructies -+ kooigevecht -+ kooigevechten -+ kooiverbinding -+ kooiverbindingen -+ kookaanwijzing -+ kookaanwijzingen -+ kookcursussen -+ kookdemonstratie -+ kookdemonstraties -+ kookfornuizen -+ kookles -+ kooklessen -+ kooknat -+ kooktijd -+ kooktijden -+ kookwas -+ kooldioxide-emissie -+ kooldioxide-emissies -+ kooldioxide-uitstoot -+ kooldioxidegehalte -+ koollong -+ koollongen -+ koolpot -+ koolpotten -+ koolsoort -+ koolsoorten -+ koolstofatomen -+ koolstofatoom -+ koolstofdioxide -+ koolstofdioxide-emissie -+ koolstofdioxide-emissies -+ koolstoffilter -+ koolstoffilters -+ koolzaadveld -+ koolzaadvelden -+ koolzuurassimilatie -+ koolzuursneeuw -+ koopflat -+ koopflats -+ koopjesjacht -+ koopkaart -+ koopkaarten -+ koopkrachtcijfer -+ koopkrachtcijfers -+ koopkrachteffect -+ koopkrachteffecten -+ koopkrachtplaatje -+ koopkrachtplaatjes -+ koopkrachtstijging -+ koopmansfamilie -+ koopmansfamilies -+ koopmansgebruiken -+ koopmanshuis -+ koopmanshuizen -+ koopopdracht -+ koopopdrachten -+ koopsompolis -+ koopsompolissen -+ koopvernietigingen -+ koopwaardig -+ koopwaardige -+ koopwoede -+ koopziekte -+ koopzondag -+ koordschrift -+ koordzeep -+ koordzepen -+ koorgebed -+ koorgebeden -+ koorleidster -+ koormantel -+ koormantels -+ koormonnik -+ koormonniken -+ koorpartij -+ koorpartijen -+ koorscholen -+ koorschool -+ koortsdromen -+ koortsdroom -+ koortsstuip -+ koortsstuipen -+ koosjere -+ koosnaam -+ koosnaampje -+ koosnamen -+ kop-en-schotel -+ kop-en-schotels -+ kop-en-schotelverzameling -+ kop-en-schotelverzamelingen -+ kop-hals-rompboerderij -+ kop-hals-rompboerderijen -+ kop-staartbotsing -+ kop-staartbotsingen -+ kop-van-jut -+ kopblad -+ kopbladen -+ kopduels -+ kopeken -+ koperblazer -+ koperdiepdrukken -+ koperindustrie -+ koperplaat -+ koperplaten -+ koperpoets -+ koperprijs -+ koperproducent -+ kopersstaking -+ kopersstakingen -+ kopersulfaat -+ kopersulfaten -+ kopgroepen -+ kophout -+ kophouten -+ kopieerapparaten -+ kopieerder -+ kopieerders -+ kopijvel -+ kopijvellen -+ kopiëring -+ kopjeduikelen -+ kopjegeduikeld -+ kopkleppen -+ kopmannen -+ kopmanschap -+ koppakkingen -+ koppelingspedalen -+ koppelingsplaat -+ koppelingsplaten -+ koppelingswet -+ koppelkoersen -+ koppelnetten -+ koppelsubsidie -+ koppelsubsidies -+ kopper -+ koppers -+ koppoter -+ koppoters -+ koprol -+ koprolde -+ koprollen -+ kopschudden -+ kopspiegellampen -+ kopspijkertje -+ kopstudie -+ kopstudies -+ koptische -+ koptologen -+ koptologie -+ koptoloog -+ kopvoorn -+ kopvoorns -+ kopvoren -+ kopvorens -+ kopziekte -+ koraalfuga -+ koraalfuga's -+ koraalslang -+ koraalslangen -+ koraalvis -+ koraalvissen -+ korans -+ korenakkers -+ korenwolf -+ korenwolven -+ korfbalbond -+ korfbalclub -+ korfbalclubs -+ korfbalselectie -+ korianderblaadje -+ korianderblad -+ korianderpoeder -+ kornets -+ korpsbeheerder -+ korpsbeheerders -+ korpsbeheerdersberaad -+ korpschefs -+ korpsleiding -+ korrelgrootte -+ korrelgrootten -+ korrelgroottes -+ korrelmais -+ kortdurend -+ kortdurende -+ kortedrachtwapen -+ kortedrachtwapens -+ kortetermijnbeleid -+ kortetermijndenken -+ kortetermijngeheugen -+ kortetermijnoplossing -+ kortetermijnoplossingen -+ kortetermijnrente -+ kortetermijnwinst -+ kortgeleden -+ kortgeschoren -+ kortgolvig -+ kortgolvige -+ kortingkaarten -+ kortingskaart -+ kortingskaarten -+ kortingsmaatregel -+ kortingsmaatregelen -+ kortverbanders -+ kortverbandvrijwilligers -+ kortverhaal -+ kortverhalen -+ kosmologische -+ kosten-batenanalyse -+ kosten-batenanalyses -+ kostenberekeningen -+ kostencurven -+ kostencurves -+ kostendrager -+ kosteneffectief -+ kosteneffectieve -+ kostenoverschrijding -+ kostenplaatjes -+ kostgelden -+ kostgrond -+ kostgronden -+ kostgrondje -+ kostumering -+ kostuumfilm -+ kostuumfilms -+ kostuumgeschiedenis -+ kostuummusea -+ kostuummuseum -+ kostuumontwerp -+ kostuumontwerpen -+ kostuumstuk -+ kostwinnersmodel -+ kotbaas -+ kotbazen -+ kotmadam -+ kotmadammen -+ koto -+ koto's -+ kotomisi -+ kotomisi's -+ kotstudent -+ kotstudenten -+ kottervloot -+ koudemiddel -+ koudgeperst -+ koudgeperste -+ koudwalserij -+ koudwaterkraan -+ koudwaterkranen -+ kougevat -+ kousenbanden -+ kousenbroek -+ kousenbroeken -+ koutje -+ koutjes -+ kraagloos -+ kraagloze -+ kraaiennesten -+ kraaienpoten -+ kraakacties -+ kraakbewegingen -+ kraakinstallaties -+ kraakster -+ kraaksters -+ kraakwacht -+ kraakwachten -+ kraakwagens -+ kraakwilg -+ kraakwilgen -+ kraamafdeling -+ kraambeen -+ kraambenen -+ kraamhok -+ kraamhokken -+ kraamhulpen -+ kraamklinieken -+ kraamverpleegsters -+ kraamverzorgsters -+ kraanarmen -+ kraanauto's -+ kraanbestuurders -+ kraandrijvers -+ kraanmachinist -+ kraanmachinisten -+ kraanschepen -+ kraanschip -+ kraantje-lek -+ kraantjeswater -+ krabbengang -+ krabbenmentaliteit -+ krabbenscheer -+ krabbenscheren -+ krabcocktails -+ krablot -+ krabloten -+ krabpaal -+ krabpalen -+ krabstick -+ krabsticks -+ krachtenvelden -+ krachtfiguren -+ krachthonk -+ krachthonken -+ krachtproeven -+ krachtsinspanningen -+ krachtstations -+ krachtsverhouding -+ krachttoeren -+ krachttrainde -+ krachttrainen -+ krachttraining -+ krachttrainingen -+ krakerproduct -+ krakerproducten -+ krakersbolwerk -+ krakersrel -+ krakersrellen -+ kralenketting -+ kralenkettingen -+ krampachtigheden -+ krampachtigheid -+ krankjorum -+ krankjorume -+ krankzinnigenwet -+ kransleggingen -+ kransslagader -+ kransslagaderen -+ kransslagaders -+ kransvat -+ kransvaten -+ krantenadvertentie -+ krantenadvertenties -+ krantenartikels -+ krantenbedrijf -+ krantenbijlage -+ krantenbijlagen -+ krantenkiosken -+ krantenknipseltje -+ krantenkolom -+ krantenkolommen -+ krantenmagnaat -+ krantenmagnaten -+ krantenuitgever -+ krantenuitgevers -+ krantenverkoper -+ krantenverkopers -+ krantenwijken -+ krapa -+ krapgeldbeleid -+ krapgeldpolitiek -+ kraslot -+ krasloten -+ krasloterij -+ krasselde -+ krasselen -+ krasserige -+ kraukrau -+ kredietgaranties -+ kredietkaart -+ kredietkaarten -+ kredietkranen -+ kredietlimieten -+ kredietopening -+ kredietopeningen -+ kredietplafonds -+ kredietpolitiek -+ kredietrente -+ kredieturen -+ kredietverlener -+ kredietverleners -+ kredietverliezen -+ kredietverschaffing -+ kredietverzekeringsmaatschappij -+ kredietwetten -+ kreeftachtige -+ kreeftensoepen -+ krengerige -+ krengig -+ krengige -+ krentenboompjes -+ krentenkakkers -+ krentenmikken -+ krentenpikker -+ krentenpikkers -+ krentte -+ kreukelzones -+ kreukherstellende -+ kreukloos -+ kreukloze -+ kreupelde -+ kreupelrijmen -+ kribbebijten -+ kribbebijter -+ kribbebijters -+ kribbes -+ kriebeltje -+ kriegelig -+ kriegelige -+ krielaardappel -+ krielaardappelen -+ krielaardappels -+ krielaardappeltje -+ krijg de klere -+ krijgsbedrijf -+ krijgsgevangenenkamp -+ krijgsgevangenkamp -+ krijgsgevangenkampen -+ krijgsheer -+ krijgshelden -+ krijgsheren -+ krijgskundig -+ krijgskundige -+ krijgskunst -+ krijgsmachtonderdeel -+ krijgsmachtonderdelen -+ krijgsmachtsonderdeel -+ krijgsmachtsonderdelen -+ krijgsmannen -+ krijgstonelen -+ krijtgrond -+ krijtgronden -+ krijtlijn -+ krijtlijnen -+ krimpnaden -+ krimpoperatie -+ krimpoperaties -+ kringbeweging -+ kringbewegingen -+ kringgesprekken -+ kringloopsysteem -+ kringloopwinkel -+ kringloopwinkels -+ kringspieren -+ kringwinkel -+ kringwinkels -+ kristallieten -+ kristallisatiepunt -+ kristalmicrofoons -+ kristalnaald -+ kristalnaalden -+ kristalontvangers -+ kristalrooster -+ kristalstructuren -+ kristalstructuur -+ kristalversterker -+ kristalversterkers -+ kritiekloosheid -+ kritiekpunt -+ krobia -+ krobia's -+ kroegbezoek -+ kroegentochten -+ kroelde -+ kroelen -+ kroi -+ krokante -+ krokanter -+ krokantst -+ krokodillenklem -+ krokodillenklemmen -+ krokusreces -+ krokusvakanties -+ krolde -+ kromgesloten -+ kromhoorn -+ kromhoorns -+ kromhoren -+ kromhorens -+ krompassers -+ kromsluiten -+ kromtecirkel -+ kromtecirkels -+ kronendak -+ kronendaken -+ kronkelachtig -+ kronkelachtige -+ kronkelredeneringen -+ kroonblad -+ kroonbladeren -+ kroonblaren -+ kroonde -+ kroondocenten -+ kroonjaar -+ kroonjaren -+ kroonkandelaar -+ kroonkandelaars -+ kroonkurken -+ kroonlamp -+ kroonlampen -+ kroonorde -+ kroonorden -+ kroonordes -+ kroonprinselijk -+ kroonprinselijke -+ kroonrand -+ kroonranden -+ kroonslagader -+ kroonslagaderen -+ kroonslagaders -+ kroonsteentjes -+ kroontjespennen -+ krotopruimingen -+ krottenbewoner -+ krottenbewoners -+ krottenbuurten -+ krottenkamp -+ krottenkampen -+ krottenwijk -+ krottenwijken -+ kruidenbad -+ kruidenbaden -+ kruidenbitter -+ kruidenboters -+ kruidendokters -+ kruidendrank -+ kruidengeneeskunde -+ kruidenierszaken -+ kruideniertje -+ kruidenkaas -+ kruidenkazen -+ kruidenkenner -+ kruidenkenners -+ kruidenmix -+ kruidenmixen -+ kruidenshampoos -+ kruidentuintje -+ kruidkers -+ kruidnagelsigaret -+ kruidnagelsigaretten -+ kruimeldiefstallen -+ kruimelfraude -+ kruimelfraudes -+ kruimelvegers -+ kruimelvlaai -+ kruimelvlaaien -+ kruip-door-sluip-door -+ kruippakje -+ kruippakjes -+ kruipruimten -+ kruipspoor -+ kruipsporen -+ kruisboogschieten -+ kruisfinale -+ kruisfinales -+ kruisingsproef -+ kruisingsproeven -+ kruisingsvrij -+ kruisingsvrije -+ kruiskop -+ kruiskoppelingen -+ kruiskoppen -+ kruislicht -+ kruislichten -+ kruispeilingen -+ kruisprocessie -+ kruisprocessies -+ kruisrak -+ kruisrakken -+ kruisschroevendraaier -+ kruisschroevendraaiers -+ kruissleutels -+ kruissnelheden -+ kruisstelling -+ kruisstellingen -+ kruiswerk -+ kruitlucht -+ kruitspoor -+ kruitsporen -+ kruiwagentje -+ kruldistel -+ kruldistels -+ krullenkoppen -+ kruller -+ krullerig -+ krullerige -+ krullers -+ krulpeterselie -+ krulset -+ krulsets -+ ktv -+ ktv's -+ kubusvormig -+ kubusvormige -+ kuierlatten -+ kuipstoel -+ kuipstoelen -+ kuipstoeltje -+ kuiptent -+ kuiptenten -+ kuisheidsgordels -+ kuitbeenspier -+ kuitbeenspieren -+ kuitblessure -+ kuitblessuren -+ kuitblessures -+ kuitlang -+ kuitspier -+ kuitspieren -+ kukeleku -+ kumquats -+ kunstaas -+ kunstacademies -+ kunstavonden -+ kunstbaan -+ kunstbanen -+ kunstbegrippen -+ kunstbeoefening -+ kunstbeschouwingen -+ kunstbezit -+ kunstboek -+ kunstboeken -+ kunstbont -+ kunstdiefstal -+ kunstdiefstallen -+ kunstdruk -+ kunstenaarscafé -+ kunstenaarscafés -+ kunstenaarscollectief -+ kunstenaarshanden -+ kunstenaarsinitiatief -+ kunstenaarsinitiatieven -+ kunstenaarskolonie -+ kunstenaarskring -+ kunstenaarsleven -+ kunstenaarsnaam -+ kunstenaarsnamen -+ kunstenaarssociëteit -+ kunstenbeleid -+ kunstenbond -+ kunstenbonden -+ kunstenfestival -+ kunstenmakerij -+ kunstenmakerijen -+ kunstenstad -+ kunstfestival -+ kunstfoto -+ kunstfoto's -+ kunstfotografie -+ kunstfout -+ kunstfouten -+ kunstgalerie -+ kunstgaleries -+ kunstgalerieën -+ kunstgenre -+ kunstgenres -+ kunstgevoelig -+ kunstgevoelige -+ kunstgras -+ kunstgrasveld -+ kunstgrasvelden -+ kunsthart -+ kunstharten -+ kunsthumaniora -+ kunsthumaniora's -+ kunstijsbanen -+ kunstkalenders -+ kunstkop -+ kunstkoppen -+ kunstlederen -+ kunstlong -+ kunstlongen -+ kunstmanen -+ kunstmanifestatie -+ kunstmanifestaties -+ kunstmarkt -+ kunstmarkten -+ kunstmateriaal -+ kunstmestindustrie -+ kunstmestproductie -+ kunstminnaars -+ kunstminnende -+ kunstmusea -+ kunstmuseum -+ kunstnier -+ kunstnieren -+ kunstnijverheidsscholen -+ kunstnijverheidsschool -+ kunstonderwijs -+ kunstopvattingen -+ kunstparel -+ kunstparels -+ kunstpatrimonia -+ kunstpatrimonium -+ kunstpenis -+ kunstpenissen -+ kunstprijs -+ kunstproducten -+ kunstraden -+ kunstredacteur -+ kunstredacteuren -+ kunstredacteurs -+ kunstredacties -+ kunstroven -+ kunstrubriek -+ kunstrubrieken -+ kunstschaatsster -+ kunstscholen -+ kunstschool -+ kunstskibaan -+ kunstsmeden -+ kunstsneeuw -+ kunststad -+ kunststofafval -+ kunststofbuis -+ kunststofbuizen -+ kunststoffenfabrikant -+ kunststofschuim -+ kunststofverwerkend -+ kunststofverwerkende -+ kunststoot -+ kunststoten -+ kunststromingen -+ kunsttaal -+ kunsttalen -+ kunsttand -+ kunsttanden -+ kunsttempel -+ kunsttempels -+ kunsttentoonstelling -+ kunsttentoonstellingen -+ kunsttheoretici -+ kunsttheoreticus -+ kunsttheoretisch -+ kunsttheoretische -+ kunsttheorie -+ kunsttijdschrift -+ kunsttijdschriften -+ kunstuitingen -+ kunstverlossing -+ kunstverlossingen -+ kunstverzamelaars -+ kunstvlees -+ kunstvoeding -+ kunstvoedingen -+ kunstvoortbrengsel -+ kunstvoortbrengselen -+ kunstvoortbrengsels -+ kunstvoorwerp -+ kunstvoorwerpen -+ kunstvriend -+ kunstvrienden -+ kunstwol -+ kunstzaak -+ kunstzaal -+ kunstzalen -+ kunstzinnigheden -+ kunstzinnigheid -+ kunstzwemmen -+ kurkentrekkers -+ kurkpapier -+ kursalen -+ kusjesdans -+ kusjesdansen -+ kussengevechten -+ kussenovertrekken -+ kussenovertreksel -+ kustafslagen -+ kustbevolking -+ kustbewaking -+ kustformatie -+ kustformaties -+ kustgebergten -+ kustgebergtes -+ kustplaats -+ kustprovincies -+ kuststaat -+ kuststad -+ kuststaten -+ kuststeden -+ kuststroken -+ kustvaartuig -+ kustvaartuigen -+ kustvlakte -+ kustvlakten -+ kustvlaktes -+ kustwater -+ kustwaters -+ kustzone -+ kustzones -+ kutsmoes -+ kutsmoezen -+ kuttenkoppen -+ kutwijf -+ kutwijven -+ kutzwager -+ kutzwagers -+ kuurbad -+ kuurhotel -+ kuurhotels -+ kuuroorden -+ kvv'er -+ kvv'ers -+ kwaadgezind -+ kwaadgezinde -+ kwaadsprekerij -+ kwaadsprekerijen -+ kwaadwillend -+ kwaadwillende -+ kwaaien -+ kwaaiig -+ kwaaiige -+ kwadraturen -+ kwajongenswerk -+ kwaker -+ kwakers -+ kwakertje -+ kwalificatie-eis -+ kwalificatie-eisen -+ kwalificatie-interland -+ kwalificatieduel -+ kwalificatieduels -+ kwalificatiepoule -+ kwalificatiepoules -+ kwalificatieronde -+ kwalificatieronden -+ kwalificatierondes -+ kwalificatietoernooi -+ kwalificatietoernooien -+ kwalificatiewedstrijd -+ kwalificatiewedstrijden -+ kwalificering -+ kwaliteitsaanduiding -+ kwaliteitsbewust -+ kwaliteitsbewuste -+ kwaliteitscertificaat -+ kwaliteitsimago -+ kwaliteitslabel -+ kwaliteitslabels -+ kwaliteitsoffer -+ kwaliteitspapier -+ kwaliteitsproduct -+ kwaliteitsproducten -+ kwaliteitsstandaard -+ kwaliteitsstempel -+ kwaliteitsverbeteringen -+ kwaliteitszorg -+ kwallig -+ kwallige -+ kwantumfysica -+ kwantummechanische -+ kwantums -+ kwantumtheorie -+ kwartaalbericht -+ kwartaalberichten -+ kwartaalblad -+ kwartaalbladen -+ kwartaalcijfer -+ kwartaalcijfers -+ kwartaaldividend -+ kwartaalomzet -+ kwartaalrapport -+ kwartaalrapporten -+ kwartaalschrift -+ kwartaalverslag -+ kwartaalverslagen -+ kwartcirkel -+ kwartcirkels -+ kwarteeuw -+ kwarteleieren -+ kwartetspelen -+ kwartetspellen -+ kwartette -+ kwartfinaleplaats -+ kwartfinales -+ kwartjesfilosofie -+ kwartliterklasse -+ kwarto's -+ kwartshorloge -+ kwartshorloges -+ kwartsklok -+ kwartsklokken -+ kwartszand -+ kwarttonen -+ kwarttoon -+ kwartviolen -+ kwartviool -+ kwasibita -+ kwatta-aap -+ kwatta-apen -+ kweekbak -+ kweekbakken -+ kweekje -+ kweekjes -+ kweekmantel -+ kweekproef -+ kweekproeven -+ kweekreactor -+ kweekreactoren -+ kweekreactors -+ kweeksel -+ kweeksels -+ kweekvijver -+ kweekvijvers -+ kwekersrecht -+ kwelderland -+ kwelderlanden -+ kwelduiveltje -+ kwezelig -+ kwezelige -+ kwijtgemaakt -+ kwijtgespeeld -+ kwijtmaken -+ kwijtscheldingsbeleid -+ kwijtspelen -+ kwikdamplamp -+ kwikdamplampen -+ kwikdruk -+ kwikwi -+ kwikwi's -+ kwikzilverachtig -+ kwikzilverachtige -+ kwikzilverig -+ kwikzilverige -+ küren -+ l'en -+ l'etje -+ l's -+ laadbruggen -+ laaddeur -+ laaddeuren -+ laadkisten -+ laadkleppen -+ laadperron -+ laadperrons -+ laadruimten -+ laadruimtes -+ laadspanning -+ laagbetaalden -+ laagcalorisch -+ laagcalorische -+ laagdrempelig -+ laagdrempelige -+ laaggelegen -+ laaggeletterd -+ laaggeletterde -+ laaggeletterden -+ laaggeplaatste -+ laaggeplaatsten -+ laaggeschoold -+ laaggeschoolde -+ laaggeschoolden -+ laaggevlogen -+ laaglandbaan -+ laaglands -+ laaglandse -+ laagopgeleid -+ laagopgeleide -+ laagproductief -+ laagproductieve -+ laagradioactief -+ laagradioactieve -+ laagrentend -+ laagrentende -+ laagseizoen -+ laagseizoenen -+ laagste-inkomensgroep -+ laagste-inkomensgroepen -+ laagtepunt -+ laagterecord -+ laagterecords -+ laagtij -+ laagvliegen -+ laagvliegend -+ laagvliegende -+ laarzenknechten -+ laarzenknechts -+ laatantiek -+ laatantieke -+ laatavondjournaal -+ laatglaciaal -+ laatglaciale -+ laatgotisch -+ laatgotische -+ laatnegentiende-eeuws -+ laatnegentiende-eeuwse -+ laatneolithisch -+ laatneolithische -+ laatpleistoceen -+ laatpleistocene -+ laatromantiek -+ laatromantisch -+ laatromantische -+ laatstverdiend -+ laatstverschenen -+ laattijdigheid -+ labaria -+ labaria's -+ labberdanen -+ labo's -+ laboratoriumachtig -+ laboratoriumachtige -+ laboratoriumdier -+ laboratoriumdieren -+ laboratoriumexperiment -+ laboratoriumexperimenten -+ laboratoriumproef -+ laboratoriumproeven -+ laboratoriumtesten -+ laboratoriumuitslagen -+ laboratoriumwerk -+ labourregeringen -+ labs -+ lach-of-ik-schietshow -+ lachaanval -+ lacherigheid -+ lachertjes -+ lachfilms -+ lachsalvo -+ lachsalvo's -+ lachsalvootje -+ lachziek -+ lachzieke -+ lactaten -+ lactatieperiode -+ lactogene -+ lactovegetariër -+ lactovegetariërs -+ ladderzat -+ ladderzatte -+ ladelichters -+ ladingcontroleurs -+ ladingscertificaat -+ ladingscertificaten -+ lady's -+ lady'tje -+ ladyboy -+ ladyboys -+ ladykillers -+ lagenhout -+ lagenmaat -+ lagenmaten -+ lagere-inkomensgroep -+ lagere-inkomensgroepen -+ lagereschoolleerling -+ lagereschoolleerlingen -+ lagergelegen -+ lagerhand -+ lagunekust -+ lagunekusten -+ laisser aller -+ lakbomen -+ lakboom -+ lakceinturen -+ lakceintuurs -+ lakenzakken -+ lakjas -+ lakjassen -+ lakleer -+ lakleren -+ lakmoesproef -+ lakmoestest -+ lakmoestinctuur -+ lakschoentje -+ lakstaven -+ lakstraten -+ lakvernissen -+ lamaatje -+ lambriseerde -+ lamelvloer -+ lamelvloeren -+ laminaatvloer -+ laminaatvloeren -+ laminaire -+ laminaten -+ lamineerde -+ lampenkatoen -+ lampenkousjes -+ lampenpitten -+ lampfittingen -+ lampionnen -+ lamsschouder -+ lamszadel -+ lanceerbases -+ lanceerbasissen -+ lanceerinstallatie -+ lanceerinstallaties -+ lanceerplaats -+ lanceerplaatsen -+ lanceerplatforms -+ lanceerprijs -+ lanceerprijzen -+ lanceerraket -+ lanceerraketten -+ lanceervensters -+ lanceringen -+ lancetblad -+ landbestuur -+ landbezit -+ landbouwareaal -+ landbouwarealen -+ landbouwbeurs -+ landbouwbeurzen -+ landbouwchemicaliën -+ landbouwcoöperaties -+ landbouwcrisissen -+ landbouwdeskundige -+ landbouwdeskundigen -+ landbouweconomen -+ landbouweconomisch -+ landbouweconoom -+ landbouwgebieden -+ landbouwgewas -+ landbouwgewassen -+ landbouwgronden -+ landbouwheffingen -+ landbouwhuisdieren -+ landbouwkredieten -+ landbouwmethode -+ landbouwoverschotten -+ landbouwplastic -+ landbouwprijzen -+ landbouwstation -+ landbouwstations -+ landbouwtechniek -+ landbouwtentoonstelling -+ landbouwuniversiteit -+ landbouwwetenschap -+ landbouwwetenschappen -+ landbouwzone -+ landbouwzones -+ landdier -+ landdieren -+ landennaam -+ landenpaviljoen -+ landenpaviljoens -+ landenploeg -+ landenploegen -+ landenprijs -+ landgebruik -+ landgenotes -+ landhervormingen -+ landingsbakens -+ landingsoperatie -+ landingsoperaties -+ landingsrecht -+ landingsschepen -+ landingsschip -+ landingsstroken -+ landingsstrook -+ landingstrappen -+ landinrichtingsproject -+ landinrichtingsprojecten -+ landinwaartse -+ landjepik -+ landleger -+ landlegers -+ landloos -+ landloze -+ landmachteenheden -+ landmachteenheid -+ landmachtgeneraal -+ landmachtstaf -+ landmeetkunde -+ landmeetkundige -+ landmeetkundigen -+ landnaam -+ landnamen -+ landnummer -+ landnummers -+ landonteigening -+ landonteigeningen -+ landoppervlak -+ landoppervlakken -+ landrug -+ landruggen -+ landsbelangen -+ landschapsarchitect -+ landschapsarchitecte -+ landschapsarchitecten -+ landschapschilderij -+ landschapschilderijen -+ landschapsonderhoud -+ landschapsschilder -+ landschapsschilders -+ landschapstuin -+ landschapstuinen -+ landschapsverzorging -+ landsdeel -+ landsdelen -+ landskampioenen -+ landslak -+ landslakken -+ landstitel -+ landstitels -+ landsverordening -+ landsvlag -+ landsvlaggen -+ landsvorst -+ landsvorsten -+ landvasten -+ landwacht -+ landwachten -+ langademige -+ langdurend -+ langdurende -+ langeafstandloper -+ langeafstandlopers -+ langeafstandsloper -+ langeafstandslopers -+ langeafstandspad -+ langeafstandspaden -+ langeafstandsraket -+ langeafstandsraketten -+ langebaanrijder -+ langebaanrijders -+ langebaanschaatsen -+ langebaanwedstrijd -+ langebaanwedstrijden -+ langetermijngeheugen -+ langetermijninvestering -+ langgolvig -+ langgolvige -+ langlaufer -+ langlaufers -+ langlaufte -+ langlevend -+ langlevende -+ langoer -+ langoeren -+ langoureuze -+ langsdoorsnedes -+ langsfietsen -+ langsgaan -+ langsgefietst -+ langsgegaan -+ langsgekomen -+ langsgelopen -+ langsgereden -+ langsgetrokken -+ langsgewipt -+ langspeelband -+ langspeelbanden -+ langspeelfilm -+ langspeelfilms -+ langspeler -+ langspelers -+ langsrazend -+ langsrazende -+ langsrijden -+ langsstromend -+ langsstromende -+ langstdurend -+ langstdurende -+ langstrekken -+ langstzittend -+ langstzittende -+ langsvarend -+ langsvarende -+ langsvoeg -+ langsvoegen -+ langswippen -+ langverbeid -+ langverbeide -+ langverwacht -+ lanolinezalf -+ lanspuntslang -+ lanspuntslangen -+ laos -+ laospoeder -+ lap -+ laparoscopen -+ laparoscopisch -+ laparoscopische -+ lapdance -+ lapjesdeken -+ lapjeswerk -+ laplanduil -+ laplanduilen -+ lapmiddeltje -+ lappen -+ lappenpoppen -+ lapzwans -+ lapzwansen -+ large -+ larghetto's -+ largo's -+ larvenstadia -+ larvenstadium -+ laryngalen -+ laryngoscopie -+ laryngoscopisch -+ laryngoscopische -+ lasbranders -+ lasbrillen -+ lascieve -+ lasdraad -+ laserapparatuur -+ laserbundel -+ laserbundels -+ laserdisk -+ laserdisks -+ lasergame -+ lasergamede -+ lasergamen -+ lasergames -+ lasergamet -+ lasergun -+ laserguns -+ lasergyroscoop -+ lasergyroscopen -+ laserkanonnen -+ lasershow -+ lasershows -+ lasersysteem -+ lasertechnologie -+ laserwapen -+ laserwapens -+ laspistolen -+ laspistool -+ last minute -+ lastarm -+ lastarmen -+ lastenboek -+ lastenboeken -+ lastenstijging -+ lastenstijgingen -+ lastenverlichtingen -+ lastenverzwaringen -+ lastigvallen -+ lastminuteaanbieding -+ lastminuteaanbiedingen -+ lastminutereis -+ lastminutereizen -+ latenightshow -+ latenightshows -+ lateriet -+ laterzaak -+ latijn -+ latin lover -+ latin lovers -+ latin rock -+ latinisering -+ latino's -+ latrelatie -+ latrelaties -+ lattenbodem -+ lattenbodems -+ laudaties -+ laudatio's -+ laurierblaadje -+ laurierolie -+ lavabo's -+ lavassen -+ lavasteen -+ lavendelheide -+ lavetten -+ lawaaibestrijding -+ lawaaierigheid -+ lawaaisausen -+ lawaaisauzen -+ lawaaisoep -+ lawinehonden -+ lawineweringen -+ laxeerpil -+ laxeerpillen -+ lay-outen -+ lay-outte -+ lazers -+ lazerstraal -+ lazerstraalde -+ lazerstralen -+ laïcisering -+ lbgo -+ lbo -+ lcd -+ lcd-scherm -+ lcd-schermen -+ lcd-schermpje -+ leader -+ leaders -+ leadzanger -+ leadzangeres -+ leadzangeressen -+ leadzangers -+ leaflet -+ leaflets -+ leagueduel -+ leaguefinale -+ leaguewedstrijd -+ leaguewedstrijden -+ leaseactiviteiten -+ leasede -+ leaset -+ leasete -+ leasings -+ leba -+ leba's -+ lechajim -+ lecithinen -+ lectori salutem -+ lectuurbakken -+ ledenaanwas -+ ledenbestanden -+ ledenbladen -+ ledenraden -+ ledenstops -+ ledenverliezen -+ ledenwervingen -+ leefeenheden -+ leefgebied -+ leefgebieden -+ leefgewoontes -+ leefgroep -+ leefgroepen -+ leefhoek -+ leefhoeken -+ leefhouding -+ leefhoudingen -+ leefkamer -+ leefkamers -+ leefkuilen -+ leefloon -+ leefmilieus -+ leefmilieuverordening -+ leefruimten -+ leefruimtes -+ leefsituaties -+ leefstijlen -+ leeftijdloos -+ leeftijdloze -+ leeftijdsgebonden -+ leeftijdsloos -+ leeftijdsloze -+ leeftijdsontslag -+ leeggeplukt -+ leeggeschoten -+ leeggestaan -+ leeggestroomd -+ leeggoed -+ leeghoofdig -+ leeghoofdige -+ leeghoofdigheid -+ leegloperij -+ leegplukken -+ leegschieten -+ leegstromen -+ leegtegevoel -+ leemglazuur -+ leemgrond -+ leemgronden -+ leemhoudend -+ leemlagen -+ leenmoeder -+ leenmoeders -+ leenrechtelijk -+ leenrechtelijke -+ leenrechtregeling -+ leenrechtvergoeding -+ leenvergoeding -+ leenvergoedingen -+ leenvertaling -+ leenvertalingen -+ leer-werktraject -+ leer-werktrajecten -+ leerachterstanden -+ leerbaar -+ leerbaarheid -+ leerbare -+ leerbewerking -+ leercontract -+ leercontracten -+ leerhoofd -+ leerhuizen -+ leerkring -+ leerkringen -+ leerling-kok -+ leerling-koks -+ leerling-verpleegkundige -+ leerling-verpleegkundigen -+ leerling-verpleegster -+ leerling-verpleegsters -+ leerlingaantal -+ leerlingaantallen -+ leerlingbegeleiding -+ leerlingenaantallen -+ leerlingenbestand -+ leerlingenraad -+ leerlingetje -+ leermateriaal -+ leermaterialen -+ leermethode -+ leermethoden -+ leermethodes -+ leernicht -+ leernichten -+ leeropdrachten -+ leerpakket -+ leerpakketten -+ leerplanontwikkeling -+ leerplanontwikkelingen -+ leerpsychologen -+ leerpsychologie -+ leerpsycholoog -+ leerrecht -+ leerregel -+ leerregels -+ leersecretariaat -+ leersecretariaten -+ leerstofgebied -+ leerstofgebieden -+ leerstofjaarklassensysteem -+ leerstofkeuze -+ leerstoornis -+ leerstoornissen -+ leervergunning -+ leervergunningen -+ leervermogen -+ leesapparaat -+ leesapparaten -+ leesdienst -+ leesdrama -+ leesdrama's -+ leesgewoonte -+ leesgewoontes -+ leesgraag -+ leesgrage -+ leeskoppen -+ leeslijst -+ leeslijsten -+ leesmachine -+ leesmachines -+ leesmap -+ leesmappen -+ leesplanken -+ leestafeltje -+ leestijden -+ leeswijzers -+ leeuwenaandelen -+ leeuwenkooien -+ leeuwenkuilen -+ leeuwenwelp -+ leeuwenwelpen -+ lefdoekjes -+ lefgozer -+ lefgozers -+ lefgozertje -+ lefschopper -+ lefschoppers -+ legalisering -+ legaliseringen -+ legalistische -+ legaliteitsbeginsel -+ legbatterijei -+ legbuis -+ legbuizen -+ legenda's -+ legerauto's -+ legerbarak -+ legerbarakken -+ legerbases -+ legerbasissen -+ legerbevelhebber -+ legerbevelhebbers -+ legercommuniqué -+ legercommuniqués -+ legerdienst -+ legereenheden -+ legerhelikopter -+ legerhelikopters -+ legerjeep -+ legerjeeps -+ legerkampen -+ legerkazerne -+ legerkazernes -+ legerkistjes -+ legerleiders -+ legermateriaal -+ legernummers -+ legeronderdelen -+ legerpatrouille -+ legerpatrouilles -+ legerstaf -+ legerstaven -+ legertruck -+ legertrucks -+ legervliegtuig -+ legervoorraad -+ legervoorraden -+ legerwoordvoerder -+ legerwoordvoerders -+ legging -+ leggingen -+ leggings -+ legionellabacteriën -+ legistiek -+ legitimarissen -+ legitimeringen -+ legitimiteitscrisis -+ legkip -+ legkippen -+ legplank -+ legplanken -+ leidersbeginsel -+ leiderschapscrisis -+ leiderschapspositie -+ leiderschapsrol -+ leidersplaats -+ leiderspositie -+ leidersposities -+ leidersstijl -+ leiderstricot -+ leidingennet -+ leidinggegeven -+ leidmotieven -+ leidsmannen -+ leigrijs -+ leigrijze -+ leiplaat -+ leiplaten -+ lekenbroeders -+ lekenkerken -+ lekenorde -+ lekenorden -+ lekenordes -+ lekenspelen -+ lekenstand -+ lekenzusters -+ lekgereden -+ lekgeschoten -+ lekgeslagen -+ lekrijden -+ lekschieten -+ lekverlies -+ lekvrije -+ lelieachtigen -+ lelietjes-van-dalen -+ lemma's -+ lemmetjebomen -+ lemmetjeboom -+ lemmings -+ lemuren -+ lemuur -+ lendenbiefstukken -+ lendenstukken -+ lendenwervels -+ lengtedraad -+ lengtedraden -+ lengteverschil -+ lengteverschillen -+ lenigingen -+ leningenportefeuille -+ leninglast -+ leninglasten -+ leningsfaciliteit -+ leningsvoorwaarde -+ leningsvoorwaarden -+ leninisten -+ lenskop -+ lenskoppen -+ lensopeningen -+ lente-uitje -+ lente-uitjes -+ lenteachtig -+ lenteachtige -+ lentebloesem -+ lentebloesems -+ lentegroen -+ lentejas -+ lentejassen -+ lenteklokje -+ lenteklokjes -+ lentenacht -+ lentenachten -+ lentepunt -+ lenzenstelsels -+ lepeldoosjes -+ lepelsgewijs -+ lepidopterist -+ lepidopteristen -+ lepidopterologie -+ lepidopterologisch -+ lepidopterologische -+ leporello's -+ lepreuze -+ leptonen -+ leptosomen -+ leraarsopleidingen -+ leraarsvak -+ lerarenkamers -+ lerarenkorpsen -+ lerarenvergaderingen -+ lesauto's -+ lesbevoegdheden -+ lesbevoegdheid -+ lesboek -+ lesboeken -+ lesboer -+ lesboeren -+ lesbrief -+ lesbrieven -+ lesgelden -+ lesmaterialen -+ lespakket -+ lespakketten -+ lessenaartje -+ lessenrooster -+ lessenroosters -+ lessentabel -+ lessentabellen -+ lestoestellen -+ lesvliegtuigen -+ lesvlucht -+ lesvluchten -+ letselschade-expert -+ letselschade-experten -+ letselschade-experts -+ letterbakken -+ letterbeeld -+ letterenfaculteit -+ letterenfaculteiten -+ letterenstudent -+ letterenstudenten -+ letterenstudie -+ letterenstudies -+ lettergreepraadsels -+ letterkorps -+ letterrijm -+ letterrijmen -+ lettertangen -+ lettervorm -+ lettervormen -+ lettervreter -+ lettervreters -+ letterziften -+ leugencampagnes -+ leugendetectoren -+ leugenontdekker -+ leugenontdekkers -+ leugenverklikker -+ leugenverklikkers -+ leukemiegeval -+ leukemiegevallen -+ leukigheid -+ leukjes -+ leukte -+ leurhandel -+ leuters -+ levendgeborene -+ levendgeborenen -+ levendmakend -+ levendmakende -+ levenhypotheek -+ levenloosheid -+ levensangst -+ levensbedreigend -+ levensbedreigende -+ levensbenodigdheden -+ levensbeëindiging -+ levensblijheid -+ levensbloed -+ levensbomen -+ levensdag -+ levensdelict -+ levensdelicten -+ levensdriften -+ levensduurte -+ levensector -+ levensfases -+ levensfilosofie -+ levensfunctie -+ levensfuncties -+ levensgang -+ levensgeheim -+ levensgeheimen -+ levensgenieters -+ levensgeschiedenissen -+ levensgevoel -+ levensgewoonte -+ levensgewoontes -+ levenshypotheek -+ levensles -+ levensliederen -+ levenslijnen -+ levensmaand -+ levensmaanden -+ levensmiddel -+ levensmiddelenzaak -+ levensmiddelenzaken -+ levensmoed -+ levensmotto -+ levensovertuigingen -+ levenspartners -+ levenspatronen -+ levenspatroon -+ levenspositie -+ levensposities -+ levensproces -+ levensregel -+ levensregels -+ levensritme -+ levensscholen -+ levensschool -+ levenssector -+ levenssferen -+ levensstijlen -+ levenstandaard -+ levenstekenen -+ levenstekens -+ levenstestament -+ levensverlangen -+ levensverschijnsel -+ levensverschijnselen -+ levensverwachtingen -+ levensvisie -+ levensvisies -+ levensvoldoening -+ levensvraagstuk -+ levensvraagstukken -+ levenswaarde -+ levenswaarden -+ levenswater -+ levenswil -+ levercarcinomen -+ levercarcinoom -+ leverfunctie -+ leverfuncties -+ leveringsverplichting -+ leverkaas -+ leverkanker -+ leverontsteking -+ leverontstekingen -+ leverpatiënt -+ leverpatiënten -+ leverstoornis -+ leverstoornissen -+ levertumor -+ levertumoren -+ levervlek -+ levervlekken -+ lezersbrief -+ lezersbrieven -+ lezerscategorie -+ lezersmarkt -+ lezersrubriek -+ lezersrubrieken -+ lezersservice -+ lezingencircuit -+ lezingencycli -+ lezingencyclus -+ lezingenserie -+ lezingentournee -+ lezingentournees -+ liaisonofficier -+ liaisonofficieren -+ lias -+ libelle -+ libellennet -+ libellennetten -+ liberaal-democraat -+ liberaal-democraten -+ liberaal-democratisch -+ liberaal-democratische -+ liberalisatie -+ liberaliseerde -+ liberaliseringen -+ liberaliseringsmaatregel -+ liberaliseringsmaatregelen -+ liberaliseringsprogramma -+ liberalistische -+ libero's -+ libertaire -+ libidineuze -+ libretto's -+ lic. -+ licentiaatsdiploma -+ licentiaatsdiploma's -+ licentiaatstheses -+ licentiaatsthesis -+ licentiaatsthesissen -+ licentiaatsverhandeling -+ licentiaatsverhandelingen -+ licentiate -+ licentiates -+ licentieovereenkomst -+ licentieovereenkomsten -+ licentierechten -+ lichaamscultuur -+ lichaamsgeur -+ lichaamsholte -+ lichaamsholten -+ lichaamsholtes -+ lichaamshoudingen -+ lichaamslengten -+ lichaamslengtes -+ lichaamsopening -+ lichaamsopeningen -+ lichaamsoppervlak -+ lichaamsslagader -+ lichaamsslagaderen -+ lichaamsslagaders -+ lichaamsverzorging -+ lichtbakens -+ lichtbeige -+ lichtbewapend -+ lichtbewapende -+ lichtblond -+ lichtblonde -+ lichtbogen -+ lichtboog -+ lichtdicht -+ lichtelijke -+ lichtfilters -+ lichtgekleurd -+ lichtgekleurde -+ lichtgolf -+ lichtgolven -+ lichtinstallaties -+ lichtjesfeest -+ lichtkabel -+ lichtkabels -+ lichtknop -+ lichtknoppen -+ lichtkracht -+ lichtkranten -+ lichtkringen -+ lichtkunstwerk -+ lichtleidingen -+ lichtmotor -+ lichtmotoren -+ lichtpaars -+ lichtpaarse -+ lichtpennen -+ lichtplan -+ lichtplannen -+ lichtschakelaar -+ lichtschakelaars -+ lichtschakering -+ lichtschakeringen -+ lichtschijnsel -+ lichtschijnsels -+ lichtshow -+ lichtshows -+ lichtspoor -+ lichtsporen -+ lichtsterkten -+ lichtsterktes -+ lichtstoet -+ lichtstoeten -+ lichtstreep -+ lichtstrepen -+ lichtstromen -+ lichtveld -+ lichtverschijnsel -+ lichtverschijnselen -+ lichtvervuiling -+ lichtvlek -+ lichtvlekken -+ lichtvoetige -+ lichtwaterreactor -+ lichtwaterreactoren -+ lichtwaterreactors -+ lichtzwakke -+ lichtzwart -+ Kozakkenvolk -+ Sherpavolk -+ lidbonden -+ lidcactus -+ lidcactussen -+ lidgeld -+ lidgelden -+ lidkaart -+ lidkaarten -+ lidland -+ lidlanden -+ lidmaatschapsaanvraag -+ lidmaatschapskaart -+ lidmaatschapskaarten -+ lidnummers -+ liederencycli -+ liederencyclus -+ liederenrecital -+ liederenrecitals -+ liedjesprogramma -+ liedjesprogramma's -+ liedjesschrijver -+ liedjesschrijvers -+ liedkunst -+ liefdadigheidsactie -+ liefdadigheidsacties -+ liefdadigheidsbal -+ liefdadigheidsbals -+ liefdadigheidsinstelling -+ liefdadigheidsinstellingen -+ liefdadigheidsmarkt -+ liefdadigheidsorganisatie -+ liefdedaad -+ liefdedaden -+ liefdesaffaire -+ liefdesaffaires -+ liefdesavontuurtje -+ liefdesband -+ liefdesdaad -+ liefdesdaden -+ liefdesdrank -+ liefdesdranken -+ liefdeservaring -+ liefdeservaringen -+ liefdesgedicht -+ liefdesgedichten -+ liefdesgeluk -+ liefdeskracht -+ liefdesleed -+ liefdesleven -+ liefdesliederen -+ liefdeslyriek -+ liefdesnacht -+ liefdesnachten -+ liefdesparen -+ liefdespartner -+ liefdespartners -+ liefdespoëzie -+ liefdesromannetje -+ liefdesromans -+ liefdesscènes -+ liefdessmart -+ liefdesspel -+ liefdesverhouding -+ liefdesverhoudingen -+ liefdesvuur -+ liegbeesten -+ liervogel -+ liervogels -+ liesblessure -+ liesblessuren -+ liesblessures -+ lieskanaal -+ lieskanalen -+ lieslaars -+ lieveheer -+ lievelingskleur -+ lievevrouw -+ lievige -+ lifestyle -+ liftboys -+ liftdeur -+ liftdeuren -+ liftenfabriek -+ liga's -+ ligbaden -+ ligbanken -+ ligbox -+ ligboxen -+ ligboxenstal -+ ligboxenstallen -+ ligboxstal -+ ligboxstallen -+ light verse -+ lightrail -+ lightrailverbinding -+ ligtaxi -+ ligtaxi's -+ ligusterhagen -+ ligwei -+ ligweide -+ ligweiden -+ ligweides -+ lijdensverhaal -+ lijfgardes -+ lijflied -+ lijfliederen -+ lijfrentepolis -+ lijfrentepolissen -+ lijfrentepremie -+ lijfrentepremies -+ lijfrenteverzekering -+ lijkauto's -+ lijkbezorging -+ lijkenhuizen -+ lijkenpikker -+ lijkenpikkers -+ lijkmis -+ lijkmissen -+ lijkstijfheid -+ lijkvlek -+ lijkvlekken -+ lijkwades -+ lijmnaden -+ lijmpersen -+ lijmsnuivend -+ lijmsnuivende -+ lijnbus -+ lijnbussen -+ lijncliché -+ lijnclichés -+ lijndienstmaatschappij -+ lijndienstvervoer -+ lijndienstvlucht -+ lijndienstvluchten -+ lijnennet -+ lijnenpatroon -+ lijngravures -+ lijnrechters -+ lijnschepen -+ lijnstoringen -+ lijntekeningen -+ lijnverbinding -+ lijnverbindingen -+ lijnvluchten -+ lijnwerkers -+ lijnzaadolie -+ lijp -+ lijpe -+ lijstaanvoerders -+ lijstduwer -+ lijstduwers -+ lijstkiesdeler -+ lijstkiesdelers -+ lijsttoneel -+ lijsttrekkerschap -+ lijsttrekkersdebat -+ lijsttrekster -+ lijstverbindingen -+ lijzigheid -+ lik-op-stukbeleid -+ limbo's -+ limiettijd -+ limitering -+ limo -+ limo's -+ limonadesiropen -+ limousin -+ limousins -+ lindebloesemthee -+ lindes -+ linearisering -+ linesman -+ linesmen -+ lingua franca -+ linkerborst -+ linkerborsten -+ linkerdijbeen -+ linkerenkel -+ linkerflank -+ linkerhelft -+ linkerhelften -+ linkermiddenvelder -+ linkeroevers -+ linkerschoen -+ linkerschoenen -+ linkerschouders -+ links-extremistisch -+ links-extremistische -+ links-liberaal -+ links-liberale -+ links-liberalen -+ links-radicaal -+ links-radicale -+ links-radicalen -+ linksachter -+ linksachters -+ linksbacks -+ linksbenig -+ linksbenige -+ linksdraaiend -+ linksgeoriënteerd -+ linksgeoriënteerde -+ linkshalf -+ linkshalfs -+ linkshandigheid -+ linksig -+ linksige -+ linksonder -+ linkspoot -+ linkspoten -+ linksrijdend -+ linksrijdende -+ linksvoetig -+ linksvoetige -+ linkt -+ linkte -+ linnaeusklokje -+ linnaeusklokjes -+ lino's -+ linoleumsneden -+ linoleumsnedes -+ linolzuren -+ linolzuur -+ linosnede -+ linosneden -+ linosnedes -+ lintcassettes -+ lintmacaroni -+ lintmeter -+ lintmeters -+ linzenmoes -+ lipide -+ lipiden -+ lipklank -+ lipogrammen -+ liposuctie -+ liposucties -+ lipssleutels -+ lipssloten -+ lipsticks -+ lipsynchrone -+ liquefied petroleum gas -+ liquid crystal display -+ liquidae -+ liquidatie-uitverkoop -+ liquiditeitengroeifonds -+ liquiditeitenmassa -+ liquiditeitsmoeilijkheden -+ liquiditeitspositie -+ liquiditeitssteun -+ liquiditeitstekort -+ lira's -+ lisdoddenfamilie -+ literair-historisch -+ literair-historische -+ literair-kritisch -+ literair-kritische -+ literarische -+ literaten -+ literatuurbeschouwingen -+ literatuurcritici -+ literatuurcriticus -+ literatuurhistorici -+ literatuurhistoricus -+ literatuurkritieken -+ literatuuropgaven -+ literatuuroverzichten -+ literatuurprijzen -+ literatuurstudies -+ literatuurwetenschappelijke -+ litermaat -+ litermaten -+ litho's -+ lits-jumeauxs -+ lits-jumeauxtje -+ littekenweefsel -+ littekenweefsels -+ live-tv-debat -+ live-uitzending -+ live-uitzendingen -+ liveoptreden -+ liveoptredens -+ liveshow -+ liveshows -+ living apart together -+ livings -+ lno -+ loafer -+ lobby's -+ lobby'tje -+ lobbyactiviteit -+ lobbyactiviteiten -+ lobbycircuit -+ lobbyde -+ lobbygroepen -+ lobbyorganisatie -+ lobbyt -+ lobbywerk -+ lobelia's -+ lobje -+ lobs -+ locatiekeuze -+ locatiesubsidie -+ locatiesubsidies -+ lockers -+ locoburgemeester -+ locoburgemeesters -+ locopreparaat -+ locopreparaten -+ locs -+ loeach -+ loedertje -+ loeier -+ loeiers -+ loeihard -+ loeiharde -+ loelav -+ loempiaatje -+ loepzuiver -+ loepzuivere -+ loerder -+ loerders -+ loerissen -+ lofbetuiging -+ lofprijzing -+ lofprijzingen -+ logaritmes -+ logaritmestelsels -+ logbestand -+ logbestanden -+ logeeradressen -+ logeerkamertje -+ logeerpartij -+ logeerpartijen -+ logeerpartijtje -+ loggia's -+ logici -+ logischerwijs -+ logischerwijze -+ logogrammen -+ logootje -+ logopedische -+ logopediste -+ logopedistes -+ loipen -+ loipes -+ lokaalvredebreuk -+ lokalisering -+ loketbediende -+ loketbedienden -+ loketbediendes -+ lokethandeling -+ lokethandelingen -+ lokettenhal -+ lokker -+ lokkers -+ lokkertje -+ lokkertjes -+ lokroep -+ lokroepen -+ lokstoffen -+ lokus -+ lolbroek -+ lolbroeken -+ lolbroekerij -+ lolita's -+ lolly'tje -+ lombardrente -+ lombardtarief -+ lomboks -+ lompenhandelaar -+ lompenpapier -+ lompenproletariaat -+ lomscholen -+ lomschool -+ lonend -+ lonende -+ long-playing record -+ longader -+ longaderen -+ longaders -+ longarts -+ longartsen -+ longbloeding -+ longbloedingen -+ longcarcinomen -+ longcarcinoom -+ longdrinkglas -+ longdrinkglazen -+ longembolie -+ longemfyseem -+ longfunctie -+ longgezwel -+ longgezwellen -+ longkanker -+ longkwaal -+ longkwab -+ longkwabben -+ longkwalen -+ longlist -+ longlists -+ longoedeem -+ longpatiënt -+ longpatiënten -+ longslagader -+ longslagaderen -+ longslagaders -+ longspecialist -+ longspecialisten -+ longstayafdeling -+ longstayafdelingen -+ longtop -+ longtoppen -+ longtransplantatie -+ longtransplantaties -+ longtrechter -+ longtrechters -+ longvaten -+ longvlies -+ longvliezen -+ loodacetaat -+ loodarm -+ loodarme -+ loodblauw -+ loodblauwe -+ loodcarbonaat -+ loodgehalten -+ loodgehaltes -+ loodgieterstas -+ loodgieterstassen -+ loodhagel -+ loodkoliek -+ loodkoord -+ loodmantel -+ loodmantels -+ loodmenie -+ loodsbriefje -+ loodsbriefjes -+ loodsdienst -+ loodsdwang -+ loodslieden -+ loodsman -+ loodsmannen -+ loodsvaartuig -+ loodsvaartuigen -+ loodverbinding -+ loodverbindingen -+ loodverf -+ loodvrije -+ loodzout -+ loodzouten -+ loofbos -+ loofbossen -+ look-zonder-look -+ lookalike -+ lookalikes -+ lookworst -+ lookworsten -+ loomte -+ loon-prijsspiraal -+ loonachterstand -+ loonadministraties -+ loonakkoord -+ loonbedrijf -+ loonbeheersing -+ loonbeleid -+ loonconflict -+ loonconflicten -+ loonderving -+ loondifferentiatie -+ loonevolutie -+ loonevoluties -+ loonexplosie -+ loonexplosies -+ loonfiche -+ loonfiches -+ loongeschil -+ loongeschillen -+ loongolf -+ loongrens -+ loongrenzen -+ loongroep -+ loongroepen -+ loonheffing -+ loonindexering -+ looninflatie -+ looningreep -+ loonklasse -+ loonklassen -+ loonkosten -+ loonkostenmatiging -+ loonkostenontwikkeling -+ loonkostenpeil -+ loonlasten -+ loonmaatregel -+ loonmaatregelen -+ loononderhandeling -+ loononderhandelingen -+ loonopslag -+ loonpauze -+ loonplafond -+ loonplafonds -+ loonpolitiek -+ loonregeling -+ loonslip -+ loonslips -+ loonsom -+ loonsommen -+ loonstijgingen -+ loonstrijd -+ loonstroken -+ loonstrook -+ loonsverbetering -+ loonsverbeteringen -+ loonsverlaging -+ loonsverlagingen -+ loontechnisch -+ loontechnische -+ loontoeslag -+ loontoeslagen -+ loontrekkenden -+ loonvoorschrift -+ loonvoorschriften -+ loonvorming -+ loonwerker -+ loonwerkers -+ loonwet -+ loonzakje -+ loop-in-'t-lijntje -+ loop-in-'t-lijntjes -+ loopafstanden -+ loopbaanbegeleiding -+ loopbaanonderbreking -+ loopbaanonderbrekingen -+ loopbaanplanning -+ loopfiets -+ loopfietsen -+ loopgips -+ loopgracht -+ loopgrachten -+ loopgravenstelsel -+ loopgravenstelsels -+ loopings -+ looplamp -+ looplampen -+ loopneus -+ loopneuzen -+ loopnummer -+ loopnummers -+ looppad -+ looppaden -+ looppop -+ looprail -+ looprails -+ looprek -+ looprekken -+ looprichting -+ looproute -+ looprouten -+ looproutes -+ loopschoen -+ loopschoenen -+ loopsnelheid -+ loopstoel -+ loopstoelen -+ looptechniek -+ looptraining -+ looptrainingen -+ loopvlak -+ loopvlakken -+ loopwerk -+ loostrens -+ loostrenzen -+ loperpaar -+ lori -+ lori's -+ lorrenkraampje -+ los-vast -+ los-vaste -+ losdraaien -+ loser -+ losers -+ losgedraaid -+ losgehaald -+ losgehangen -+ losgekregen -+ losgepeuterd -+ losgepraat -+ losgereden -+ losgeschoten -+ losgeschroefd -+ losgeschud -+ losgestaan -+ losgestormd -+ losgetornd -+ losgevezen -+ losgevlogen -+ losgeweekt -+ losgewerkt -+ losgewrongen -+ losgezeten -+ loshaken -+ loshalen -+ loshangen -+ losjesweg -+ loskoppeling -+ loskoppelingen -+ loskrijgen -+ loslating -+ losliggend -+ losliggende -+ loslopend -+ loslopende -+ losmaking -+ lospeuteren -+ lospraten -+ losrijden -+ losschieten -+ losschroeven -+ losschudden -+ lossebandstoot -+ lossebandstoten -+ losstaan -+ losstormen -+ lost generation -+ lost generations -+ lostornen -+ losvijzen -+ losvliegen -+ loswerken -+ loswoelen -+ loswringen -+ loszitten -+ lota -+ lota's -+ loterijspel -+ loterijspelen -+ loterijwet -+ lotgenotes -+ lotnummer -+ lotnummers -+ lotsbeschikking -+ lotsbeschikkingen -+ lotsbestemming -+ lotsbestemmingen -+ lotsgemeenschap -+ lotsverandering -+ lotsveranderingen -+ lotsverbonden -+ lotto's -+ lottokaart -+ lottokaarten -+ lotuseter -+ lotuseters -+ lotushouding -+ lou loene -+ loucher -+ louchest -+ lounges -+ louteringsberg -+ lovegames -+ lovehandles -+ lovenswaardig -+ lovenswaardige -+ loverboy -+ loverboys -+ low budget -+ low profile -+ lowbudgetfilm -+ lowbudgetfilms -+ lowbudgethotel -+ lowbudgethotels -+ loyalisten -+ loyalistische -+ loyaliteitsconflict -+ loyaliteitsprobleem -+ loyaliteitsproblemen -+ loyaliteitsprogramma -+ loyaliteitsprogramma's -+ loyaliteitsverklaring -+ loyaliteitsverklaringen -+ lozingseis -+ lozingseisen -+ lozingsnorm -+ lozingsnormen -+ lozingspijp -+ lozingspijpen -+ lozingspunt -+ lozingspunten -+ lozingsrecht -+ lozingsvergunning -+ lozingsvergunningen -+ lp -+ lp's -+ lp-verzameling -+ lp-verzamelingen -+ lpg -+ lpg-tank -+ lpg-tanks -+ lsd -+ lsd-verslaving -+ lso -+ lto -+ lts -+ lubberiaans -+ lubberiaanse -+ luchtacrobaat -+ luchtacrobaten -+ luchtafweerraket -+ luchtafweerraketten -+ luchtballonnen -+ luchtbed -+ luchtbedden -+ luchtbeleconomie -+ luchtbelletje -+ luchtbevochtiger -+ luchtbevochtigers -+ luchtbeweging -+ luchtbewegingen -+ luchtbezoedeling -+ luchtbuks -+ luchtbuksen -+ luchtbus -+ luchtbussen -+ luchtcirculatie -+ luchtcorridor -+ luchtcorridors -+ luchtdeeltje -+ luchtdeeltjes -+ luchtdekking -+ luchtdoelraket -+ luchtdoelraketten -+ luchtdoorlatend -+ luchtdoorlatende -+ luchtdrukpistool -+ luchtdrukverschil -+ luchtdrukverschillen -+ luchtfilter -+ luchtfilters -+ luchtfoto's -+ luchtgaatje -+ luchtgekoeld -+ luchtgekoelde -+ luchtgestelheid -+ luchtgitaar -+ luchtgolf -+ luchtgolven -+ luchthavenautoriteit -+ luchthavenautoriteiten -+ luchthavenbelasting -+ luchthavendirectie -+ luchthavendirecties -+ luchthavenpolitie -+ luchtkanaal -+ luchtkanalen -+ luchtkoeling -+ luchtkussenboot -+ luchtkussenboten -+ luchtkussenvaartuig -+ luchtkussenvaartuigen -+ luchtkwaliteit -+ luchtmachtbases -+ luchtmachtbasissen -+ luchtmachten -+ luchtmachtpersoneel -+ luchtmachtstaf -+ luchtmassa -+ luchtmassa's -+ luchtmatras -+ luchtmatrassen -+ luchtmeter -+ luchtmeters -+ luchtmobiel -+ luchtmobiele -+ luchtmonster -+ luchtmonsters -+ luchtoffensief -+ luchtoffensieven -+ luchtopname -+ luchtopnamen -+ luchtopnames -+ luchtpiraat -+ luchtpiraten -+ luchtplaats -+ luchtplaatsen -+ luchtpostbrief -+ luchtpostbrieven -+ luchtpostpapier -+ luchtreclames -+ luchtrooster -+ luchtroosters -+ luchtroute -+ luchtroutes -+ luchtslag -+ luchtslagen -+ luchtslang -+ luchtslangen -+ luchtsluis -+ luchtsluizen -+ luchtsnelheid -+ luchtsprong -+ luchtsprongen -+ luchtstroming -+ luchtstromingen -+ luchttemperatuur -+ luchttoevoer -+ luchttransport -+ luchttransporten -+ luchtvaartalliantie -+ luchtvaartdienst -+ luchtvaartgeschiedenis -+ luchtvaartinspectie -+ luchtvaartpionier -+ luchtvaartrecht -+ luchtvaartschool -+ luchtvaartshow -+ luchtvaarttechnologie -+ luchtvaartverkeer -+ luchtveersysteem -+ luchtverdedigingsraket -+ luchtverdedigingsraketten -+ luchtverfrisser -+ luchtverfrissers -+ luchtvering -+ luchtverkeersbegeleiding -+ luchtverkeersleider -+ luchtverkeersleiding -+ luchtverkenning -+ luchtverkenningen -+ luchtverplaatsing -+ luchtverplaatsingen -+ luchtververser -+ luchtverversers -+ luchtverversingssysteem -+ luchtverwarming -+ luchtvloot -+ luchtvochtigheid -+ luchtvochtigheidsgraad -+ luchtvracht -+ luchtvrachtexpediteur -+ luchtvrachtexpediteurs -+ luchtvrachtvervoer -+ luchtwaardigheid -+ luchtwapens -+ luchtwegaandoening -+ luchtwegaandoeningen -+ luchtweginfectie -+ luchtweginfecties -+ luchtwegvernauwing -+ luchtwortelbomen -+ luchtwortelboom -+ luciferdoosje -+ luciferdoosjes -+ luciferhoutje -+ luciferhoutjes -+ luidheid -+ luidkeelse -+ luidsprekend -+ luidsprekende -+ luidsprekerboxen -+ luidsprekertje -+ luiermarkt -+ luierwas -+ luik -+ luikgat -+ luikgaten -+ luilaknacht -+ luilakviering -+ luilakvieringen -+ luipaardvel -+ luisterbijdrage -+ luisterbijdragen -+ luistercel -+ luistercellen -+ luisterdichtheid -+ luisterdienst -+ luistergeld -+ luistergelden -+ luisterhouding -+ luisterlied -+ luisterliederen -+ luistertoets -+ luistertoetsen -+ luistervaardigheden -+ luistervaardigheid -+ luitenant-adjudant -+ luitenant-admiraal -+ luitenant-admiraals -+ luitenant-generaal -+ luitenant-generaals -+ luitenant-kolonels -+ luitenants-adjudanten -+ luitisten -+ luitspel -+ luizenbaantje -+ luizenei -+ luizeneieren -+ luizenleven -+ luizenleventje -+ luizenstreek -+ luizenstreken -+ lul-de-behanger -+ lulhannes -+ lulhannesen -+ lulkoek -+ lullepotten -+ lullige -+ lulligheden -+ lulligheid -+ lullo -+ lullo's -+ lumbaalpuncties -+ lumbale -+ lumbeckte -+ luminescente -+ lumpsumbekostiging -+ lumpsumfinanciering -+ lunchafspraak -+ lunchafspraken -+ lunchbespreking -+ lunchbesprekingen -+ lunchbijeenkomst -+ lunchbijeenkomsten -+ lunchconcert -+ lunchconcerten -+ lunchgerecht -+ lunchgerechten -+ lunchpauze -+ lunchpauzes -+ lunchpauzevoorstelling -+ lunchtijd -+ lunchtijden -+ lunchtrommeltje -+ lunchuur -+ lunchvoorstelling -+ lunchvoorstellingen -+ lupineveld -+ lupinevelden -+ lustbevrediging -+ lustgevoel -+ lustgevoelens -+ lustmoord -+ lustmoorden -+ lustmoordenaar -+ lustmoordenaars -+ lustobject -+ lustobjecten -+ lustrumjaar -+ lustrumjaren -+ lustslot -+ lustsloten -+ luxegoederen -+ luxeleventje -+ luxepositie -+ luxes -+ luxetelegram -+ luxetelegrammen -+ luxewagen -+ luxewagens -+ lychees -+ lymeziekte -+ lymfklierkanker -+ lymfocyten -+ lynchpartij -+ lynchpartijen -+ lyrici -+ lysergeenzuurdiëthylamide -+ m'en -+ m'etje -+ m's -+ m-bankierde -+ m-bankieren -+ m.m. -+ ma's -+ maag-darmcatarre -+ maag-darmkanaal -+ maag-darmkanalen -+ maag-darmklachten -+ maagaandoening -+ maagaandoeningen -+ maagbloedingen -+ maagdenroof -+ maagfistel -+ maagfistels -+ maaghevel -+ maaghevels -+ maagholte -+ maagholten -+ maagholtes -+ maagkatheter -+ maagkatheters -+ maagmond -+ maagmonden -+ maagonderzoek -+ maagontsteking -+ maagontstekingen -+ maagoperatie -+ maagoperaties -+ maagpatiënt -+ maagpatiënten -+ maagperforatie -+ maagperforaties -+ maagresectie -+ maagsappen -+ maagslang -+ maagslangen -+ maagslijmvlies -+ maagslijmvliezen -+ maagsonde -+ maagsondes -+ maagstoornissen -+ maagstoot -+ maagstoten -+ maagvulling -+ maagwand -+ maaidorser -+ maaidorsers -+ maaidorsmachine -+ maaidorsmachines -+ maaisel -+ maaitijden -+ maaiveldhoogte -+ maaiwerktuig -+ maakkans -+ maalsel -+ maalsels -+ maaltijdcheque -+ maaltijdcheques -+ maaltijdcomponent -+ maaltijdcomponenten -+ maaltijdsoepen -+ maaltijdverstrekking -+ maanbeving -+ maanbevingen -+ maandabonnementen -+ maandkaart -+ maandkaarten -+ maandkalender -+ maandkalenders -+ maandloner -+ maandnaam -+ maandnamen -+ maandverbanden -+ maandverslagen -+ maandwedde -+ maandwedden -+ maandweddes -+ maanfoto's -+ maankaarten -+ maankrater -+ maankraters -+ maanlander -+ maanlanders -+ maanlandingen -+ maanlandschappen -+ maanmannetje -+ maanmannetjes -+ maanmonster -+ maanoppervlak -+ maanraketten -+ maanreiziger -+ maanreizigers -+ maansatelliet -+ maansatellieten -+ maansikkels -+ maanstand -+ maanstanden -+ maanwandelingen -+ maanzaadbroden -+ maanzaadbrood -+ maashagedis -+ maashagedissen -+ maassteek -+ maassteken -+ maastrichtien -+ maaswijdtes -+ maatanalyse -+ maatanalyses -+ maatbekers -+ maatbekertje -+ maatcilinder -+ maatcilinders -+ maatdeel -+ maatdelen -+ maatdop -+ maatdoppen -+ maateenheden -+ maatkannen -+ maatkostuums -+ maatlat -+ maatlatten -+ maatpakken -+ maatschappijbeelden -+ maatschappijcritici -+ maatschappijcriticus -+ maatschappijhervormers -+ maatschappijopvatting -+ maatschappijopvattingen -+ maatschappijstructuren -+ maatschappijstructuur -+ maatschappijvisie -+ maatschappijvisies -+ maatschappijvormen -+ maatschappijwetenschap -+ maatschetsen -+ maatslaan -+ maatsoorten -+ maatvis -+ maatvissen -+ maatwisseling -+ maatwisselingen -+ macher -+ machers -+ machetes -+ machiavellisten -+ machine-industrie -+ machinebankwerkers -+ machinebouw -+ machinebouwer -+ machinebouwers -+ machinegeweervuur -+ machineonderdeel -+ machineonderdelen -+ machinestraat -+ machinestraten -+ machinetalen -+ machinevoerder -+ machinevoerders -+ machinezetsel -+ machistische -+ macho-uiterlijk -+ machocultuur -+ machtenscheiding -+ machthebbend -+ machthebbende -+ machtiginghouder -+ machtiginghouders -+ machtigingshouder -+ machtigingshouders -+ machtigingsnummer -+ machtigingsnummers -+ machtigingswetten -+ machtsaanvaarding -+ machtsbederf -+ machtsbehoud -+ machtsbelust -+ machtsbeluste -+ machtsblokken -+ machtsconcentraties -+ machtsgrepen -+ machtshonger -+ machtsinstrumenten -+ machtsmonopolie -+ machtsontplooiing -+ machtsposities -+ machtsstaat -+ machtsstaten -+ machtsstreven -+ machtsstructuren -+ machtsstructuur -+ machtstaat -+ machtstaten -+ machtsusurpatie -+ machtsvacuüm -+ machtsverschuiving -+ machtsverschuivingen -+ machtswellustelingen -+ machtswisselingen -+ machtswoord -+ machtswoorden -+ macrameede -+ macrameeën -+ macro-economen -+ macro-economisch -+ macro-economische -+ macro-econoom -+ macrobioten -+ macrofagen -+ macromoleculaire -+ macromoleculen -+ macromolecules -+ macroniveaus -+ macroscopische -+ macrostructuren -+ madames -+ mades -+ madeworm -+ madewormen -+ madonna's -+ madonna-achtig -+ madonna-achtige -+ maffia's -+ maffia-achtig -+ maffia-achtige -+ maffiabaas -+ maffiabazen -+ maffiabestrijder -+ maffiabestrijders -+ maffialeden -+ maffialeider -+ maffialid -+ maffiapraktijk -+ maffiapraktijken -+ maffiose -+ maffiosi -+ mafketels -+ magazijnadministratie -+ magazijnadministraties -+ magazijnbediende -+ magazijnbedienden -+ magazijnbediendes -+ magazines -+ magelhaengans -+ magelhaenganzen -+ maggiplant -+ magisch-realistisch -+ magisch-realistische -+ magistratelijk -+ magistratelijke -+ magmatisch -+ magmatische -+ magneetinductie -+ magneetschijfgeheugen -+ magneetschijfgeheugens -+ magneetschijven -+ magneetsluiting -+ magneetsluitingen -+ magneetspoel -+ magneetspoelen -+ magneetstaaf -+ magneetstaven -+ magneetstrippas -+ magneetstrippassen -+ magneetstrippen -+ magneetstrips -+ magneettrein -+ magneettreinen -+ magneetvelden -+ magnesiumoxide -+ magnetiet -+ magnetiseerder -+ magnetiseerders -+ magnetodynamisch -+ magnetodynamische -+ magnetometer -+ magnetometers -+ magnetronfolie -+ magnetronovens -+ magnetronschaal -+ magnetronschalen -+ magnolia's -+ magnoliaatje -+ magnums -+ magot -+ magots -+ magotten -+ maidenspeechen -+ maidenspeeches -+ maidentrips -+ mailbox -+ mailboxen -+ mailde -+ mailinglist -+ mailinglists -+ mailings -+ maillotje -+ maillots -+ mailserver -+ mailservers -+ mailt -+ mailverkeer -+ mainport -+ mainports -+ mainstream -+ mais -+ maisakker -+ maisakkers -+ maisbrood -+ maisgluten -+ maiskip -+ maiskippen -+ maiskolf -+ maiskolven -+ maismeel -+ maisolie -+ maisonnettes -+ maisoogst -+ maispap -+ maisplant -+ maisplanten -+ maisveld -+ maisvelden -+ maizena -+ majem -+ majestatisch -+ majestatische -+ majoor-generaal -+ major-minorsysteem -+ majoretje -+ majorettekorps -+ majorettekorpsen -+ majorettetje -+ majuskels -+ makam -+ makamen -+ makaperi -+ makaperi's -+ makaslang -+ makaslangen -+ make-over -+ make-overs -+ make-upremover -+ make-upremovers -+ makelaarsbedrijf -+ maki -+ maki's -+ makken -+ makkie -+ malachietgroen -+ malachietgroene -+ malaisegevoel -+ malaisestemming -+ malaria-epidemie -+ malaria-epidemieën -+ malariabestrijding -+ malariaonderzoek -+ malariaparasiet -+ malariaparasieten -+ malchance -+ mall -+ malls -+ malm -+ malta's -+ maltbier -+ maltezer -+ maltezers -+ malusregeling -+ malussen -+ malussysteem -+ malversatiën -+ malverseerde -+ mamma's -+ mamma-amputatie -+ mamma-amputaties -+ mammie -+ mammies -+ mammoetbedrijf -+ mammoetorder -+ mammoetscholen -+ mammoetschool -+ mammoettanker -+ mammografisch -+ mammografische -+ mampier -+ mampieren -+ man-vrouwverhouding -+ manage -+ managede -+ managementadviesbureau -+ managementadviesbureaus -+ managementbuy-out -+ managementbuy-outs -+ managementconsultant -+ managementconsultants -+ managementcursus -+ managementcursussen -+ managementopleiding -+ managementopleidingen -+ managementschool -+ managementteam -+ managementteams -+ managementtraining -+ managementtrainingen -+ managersopleiding -+ managersschool -+ managing director -+ managing directors -+ manchepoging -+ mancolijst -+ mancolijsten -+ mandala's -+ mandarijnendom -+ mandekker -+ mandekkers -+ mandir -+ mandirs -+ mandragora's -+ maneblusser -+ maneblussers -+ manga's -+ mangochutney -+ mangoest -+ mangoeste -+ mangoesten -+ mangrovebomen -+ mangroveboom -+ mangrovebos -+ mangrovebossen -+ mangroves -+ mani -+ mani's -+ manicureopleiding -+ manicures -+ manicuurster -+ manicuursters -+ manifestanten -+ manilla's -+ manillaatje -+ manisch-depressief -+ manisch-depressieve -+ manische -+ maniëristen -+ maniëristische -+ mankrachten -+ manmeersituatie -+ manmeersituaties -+ mannenblad -+ mannenbladen -+ mannenbroeders -+ mannencondoom -+ mannendubbelspel -+ mannengek -+ mannengekken -+ mannengemeenschappen -+ mannenhaatster -+ mannenhaatsters -+ mannenhockeyploeg -+ mannenhoofd -+ mannenkleding -+ mannenkleren -+ mannenrol -+ mannenrollen -+ mannenverslindster -+ mannenverslindsters -+ mannenziekte -+ mannetjeseend -+ mannetjeseenden -+ mannetjesmaker -+ mannetjesmakerij -+ mannetjesmakers -+ manoeuvreerruimte -+ manoeuvreerruimten -+ manoeuvreerruimtes -+ manse -+ manteldier -+ manteldieren -+ mantelkostuums -+ mantelzorg -+ mantelzorger -+ mantelzorgers -+ mantilla's -+ mantissen -+ mantouxtest -+ manumitteerde -+ manumitteren -+ manusjes-van-alles -+ manxkat -+ manxkatten -+ maoïsten -+ maoïstische -+ maquilleerde -+ maraan -+ maracuja -+ maracuja's -+ maranen -+ marathondebat -+ marathondebatten -+ marathonloopster -+ marathonloper -+ marathonlopers -+ marathons -+ marathonschaatsen -+ marathonschaatser -+ marathonschaatsers -+ marathonsessie -+ marathonvergadering -+ marathonvergaderingen -+ marathonwedstrijd -+ marathonwedstrijden -+ marathonzitting -+ marathonzittingen -+ marburgvirus -+ marc -+ marches -+ marcje -+ marctje -+ margarines -+ margay -+ margays -+ margedruk -+ margetheater -+ margeverkrapping -+ margeverlies -+ marginalisering -+ mariaal -+ mariadistel -+ mariakaakje -+ mariakaakjes -+ mariale -+ marien -+ mariene -+ marifoonkanaal -+ marifoonkanalen -+ marifoons -+ marimba's -+ marina -+ marina's -+ marinaatje -+ marinades -+ marine-eenheden -+ marine-eenheid -+ marineattaché -+ marineattachés -+ marinecommandant -+ marinehaven -+ marinehavens -+ marinejager -+ marinejagers -+ marineluchtvaartdienst -+ marinemannen -+ marinevaartuig -+ marinevaartuigen -+ mariniersbataljon -+ mariniersdivisie -+ marinierseenheden -+ marinierseenheid -+ marinierskapel -+ marinierskapellen -+ marinierskazerne -+ marionettenbewind -+ marionettenstaat -+ maripa -+ maripa's -+ markeringspunt -+ markeringspunten -+ markers -+ marketingafdeling -+ marketingjargon -+ marketingman -+ marketingmannen -+ marketingorganisatie -+ markieslinnen -+ markkoers -+ marktanalisten -+ marktanalysebureau -+ marktanalysebureaus -+ marktbeeld -+ marktbeleid -+ marktbewerking -+ markteconomieën -+ marktevenwicht -+ marktgebieden -+ marktgelden -+ marktgevoelig -+ marktgevoelige -+ marktgroei -+ marktintroductie -+ marktkoersen -+ marktkooplieden -+ marktkooplui -+ marktnoteringen -+ marktonderzoekbureau -+ marktonderzoekbureaus -+ marktonderzoeksbureaus -+ marktordening -+ marktoverzicht -+ marktprognoses -+ marktrentes -+ marktrijp -+ marktrijpe -+ marktsectoren -+ marktsectors -+ marktsegmentatie -+ marktsegmentaties -+ marktsituaties -+ marktstemming -+ marktstrategieën -+ marktstructuren -+ marktverdelingsafspraak -+ marktverdelingsafspraken -+ marktvergunningen -+ marktverkenningen -+ marktverstorend -+ marktverstorende -+ marktverzadiging -+ marktvrouwen -+ marmersoort -+ maronieten -+ maronitische -+ marquises -+ marrondorp -+ marrondorpen -+ marsala -+ marsfracturen -+ marsfractuur -+ marshallplan -+ marshallplannen -+ marslied -+ marsliederen -+ marsmannetje -+ marteko -+ marteko's -+ martekootje -+ martelaarsdood -+ martelaarsgezicht -+ martelaarsrol -+ martelkamer -+ martelkamers -+ martialartsfilm -+ martialartsfilms -+ martini's -+ marxisme-leninisme -+ marxist-leninist -+ marxisten-leninisten -+ marxistisch-leninistisch -+ marxistisch-leninistische -+ masala -+ mascotje -+ mascottetje -+ masculiene -+ masjallah -+ maskerachtig -+ maskerachtige -+ maskering -+ maskeringen -+ maskerspelen -+ masochisten -+ masoreten -+ massa-actie -+ massa-acties -+ massa-extinctie -+ massa-extincties -+ massa-immigratie -+ massa-uitwijzing -+ massabetoging -+ massabetogingen -+ massabijeenkomst -+ massabijeenkomsten -+ massablad -+ massabladen -+ massagesalon -+ massagesalons -+ massagetafel -+ massagoederen -+ massahysterie -+ massamarkt -+ massamarkten -+ massamensen -+ massamoord -+ massaontslag -+ massaontslagen -+ massapsychologisch -+ massapsychologische -+ massapsychose -+ massascènes -+ massaspectrometer -+ massaspectrometers -+ massasprinten -+ massasprints -+ massaspurten -+ massaspurts -+ massatoerisme -+ massaverkoop -+ massavermaak -+ massificeerde -+ masterclasses -+ masteropleiding -+ mastertape -+ mastertapes -+ mastiff -+ mastiffs -+ mastino -+ mastino napoletano -+ mastino napoletano's -+ mastino's -+ masttop -+ mastworpen -+ mata -+ mata's -+ matchpoints -+ matchpunt -+ matchpunten -+ matchwinnaar -+ matchwinnaars -+ mateloosheid -+ matelotje -+ matennaaien -+ matennaaier -+ matennaaiers -+ matenstelsel -+ materiaalfout -+ materiaalfouten -+ materiaalkennis -+ materiaalkunde -+ materiaalverzameling -+ materiaalwagens -+ materialisaties -+ materialiseerde -+ materieeltekort -+ materieelvoorziening -+ materniteit -+ materniteiten -+ mathematiseerde -+ mathematisering -+ matigjes -+ matineetje -+ matineevoorstelling -+ matrakken -+ matrasbeschermers -+ matrasdekken -+ matriarchale -+ matrijzenmakerij -+ matrikels -+ matrilineaire -+ matrixscherm -+ matrixschermen -+ mattenkloppers -+ maturiteitsdiploma -+ maturiteitsdiploma's -+ maturiteitsexamen -+ maturiteitsexamens -+ matzwart -+ matzwarte -+ maulana -+ maulana's -+ mauritiuspalm -+ mauritiuspalmen -+ mavo -+ mavo 4-leerling -+ mavo 4-leerlingen -+ mavo's -+ mavo-eindexamen -+ mavo-opleiding -+ mavodiploma -+ mavoleerling -+ mavoleerlingen -+ mavoniveau -+ mavoscholen -+ mavoschool -+ maximalisering -+ maximalisten -+ maximeerde -+ maximen -+ maximering -+ maximes -+ maximumbedragen -+ maximumgrens -+ maximumleeftijd -+ mayo -+ mazout -+ mazoutkachel -+ mazoutkachels -+ mazurka's -+ mazzelaar -+ mazzelaars -+ mazzeltof -+ maîtres -+ maîtres d'hôtel -+ maïsakker -+ maïsakkers -+ maïsbrood -+ maïsgluten -+ maïskip -+ maïskippen -+ maïsolie -+ maïspap -+ maïsplant -+ maïsplanten -+ maïsveld -+ mbo -+ mbo-opleiding -+ mbo-opleidingen -+ meanderde -+ meao -+ meccano's -+ meccanodoos -+ meccanodozen -+ mechanici -+ mechanismes -+ mechanistische -+ mechanotherapie -+ mecklenburger -+ mecklenburgers -+ medaillekandidaat -+ medaillekandidaten -+ medaillekans -+ medaillekansen -+ medailleklassement -+ medailleoogst -+ mede-Kamerleden -+ mede-Kamerlid -+ mede-eigenaren -+ mede-erfgenamen -+ mede-initiatiefnemer -+ mede-initiatiefnemers -+ mede-inzittenden -+ medeauteur -+ medeauteurs -+ medebeklaagde -+ medebeklaagden -+ medebepalende -+ medebestuursleden -+ medebestuurslid -+ mededeelbare -+ mededelingenblaadje -+ mededelingenbladen -+ mededelingenborden -+ mededingingsrecht -+ mededingingsregels -+ medefinancieringsorganisatie -+ medekandidaat -+ medekandidaten -+ medelanders -+ medemenselijke -+ meden -+ medepassagier -+ medepassagiers -+ medepastoor -+ medepastoors -+ medestrevers -+ medeverantwoordelijke -+ medeverantwoordelijkheden -+ medevluchter -+ medevluchters -+ medewerkerschap -+ medezeggenschapscommissie -+ medezeggenschapscommissies -+ medezeggenschapsorgaan -+ medezeggenschapsorganen -+ medezeggenschapsraden -+ media-aandacht -+ media-evenement -+ media-evenementen -+ media-imperium -+ mediaanlijn -+ mediaanlijnen -+ mediacampagne -+ mediacircus -+ mediadeskundige -+ mediadeskundigen -+ mediagigant -+ mediagiganten -+ mediahype -+ mediahypes -+ medialand -+ medialandschap -+ mediale -+ mediaorganisatie -+ mediaplanning -+ mediarecht -+ mediasociologen -+ mediasocioloog -+ mediaster -+ mediasterren -+ mediateur -+ mediateurs -+ mediatheken -+ mediator -+ mediatoren -+ mediators -+ mediawetgeving -+ medicaliseerde -+ medicalisering -+ medicatiebewaking -+ medicaties -+ medicijnkast -+ medicijnkasten -+ medicijnkist -+ medicijnknaak -+ medina's -+ medisch-administratief -+ medisch-administratieve -+ medisch-ethisch -+ medisch-ethische -+ medisch-juridisch -+ medisch-juridische -+ medisch-psychologisch -+ medisch-psychologische -+ medisch-technisch -+ medisch-technische -+ medisch-wetenschappelijk -+ medisch-wetenschappelijke -+ meditatietechniek -+ medocs -+ medresse -+ medressen -+ medusa's -+ medusahoofd -+ mee-eters -+ meebepaald -+ meebeslissingsrecht -+ meebetaald -+ meefinancieren -+ meegedacht -+ meegefinancierd -+ meegeklonken -+ meegekund -+ meegeleden -+ meegelezen -+ meegerookt -+ meegestemd -+ meegetraind -+ meegevaren -+ meegevierd -+ meegevochten -+ meegevoeld -+ meegezeild -+ meeklappen -+ meeklinken -+ meekunnen -+ meelbal -+ meelballen -+ meelezer -+ meelezers -+ meemoeder -+ meemoeders -+ meeneemprijs -+ meeneemrestaurant -+ meeneemrestaurants -+ meeouder -+ meeouders -+ meeraderig -+ meerderheidsaandeelhouders -+ meerderheidsbelangen -+ meerderheidsbeslissing -+ meerderheidsbeslissingen -+ meerderheidsbesluitvorming -+ meerderheidscoalitie -+ meerderheidscolleges -+ meerderheidskabinetten -+ meerderheidspartij -+ meerderwaardigheidsgevoelens -+ meergezinswoning -+ meergezinswoningen -+ meerijder -+ meerjarenafspraak -+ meerjarenafspraken -+ meerjarenbegroting -+ meerjarenbegrotingen -+ meerjarenplannen -+ meerjarenramingen -+ meerkabel -+ meerkabels -+ meerkamp -+ meerkampen -+ meerkeuzetoetsen -+ meerkeuzevragen -+ meerkoppig -+ meerkoppige -+ meerledig -+ meerledige -+ meerling -+ meerlingen -+ meerlingzwangerschap -+ meerlingzwangerschappen -+ meermanskaarten -+ meerpartijenstelsels -+ meerrompschepen -+ meerrompschip -+ meerslag -+ meersporenbeleid -+ meerstemmige -+ meertalige -+ meertrapsraketten -+ meertros -+ meertrossen -+ meervoudigheid -+ meervouds-s -+ meervouds-s'en -+ meeslependheid -+ meestamper -+ meestampers -+ meestemmen -+ meester-kok -+ meester-koks -+ meester-opzichter -+ meester-opzichters -+ meesterarrangeur -+ meesterbreinen -+ meestergraad -+ meesterhanden -+ meesterkoks -+ meesteroplichter -+ meesteroplichters -+ meesterplan -+ meesterproef -+ meesterspionnen -+ meetbruggen -+ meetbuis -+ meetbuizen -+ meetgegeven -+ meetlatten -+ meetloden -+ meetlood -+ meetnauwkeurigheid -+ meetnet -+ meetnetten -+ meetrainen -+ meetstations -+ meettafel -+ meettafels -+ meevader -+ meevaders -+ meeverdieners -+ meeverzekerd -+ meeverzekeren -+ meewinden -+ meezeilen -+ meezingers -+ mefisto's -+ megabioscopen -+ megabrein -+ megabytes -+ megachip -+ megachips -+ megadoses -+ megadosis -+ megadosissen -+ megafusie -+ megajoules -+ megalithische -+ megalomanen -+ megalopolissen -+ megamarkt -+ megapixel -+ megapixels -+ megaplan -+ megaproject -+ megaprojecten -+ megaster -+ megatentoonstelling -+ megatentoonstellingen -+ megatonnen -+ megawatts -+ mehari's -+ meibock -+ meiboter -+ meidengroepen -+ meidenwegloophuis -+ meidoornhaag -+ meidoornhagen -+ meierde -+ meieren -+ meiknol -+ meiknollen -+ meiknolletje -+ meikrans -+ meikransen -+ meiregen -+ meiregens -+ meiregentje -+ meisjesboeken -+ meisjesgroep -+ meisjesinternaat -+ meisjeskamer -+ meisjeskamers -+ meisjeskamertje -+ meisjeskoor -+ meisjeskoren -+ mekka -+ mekka's -+ meldingsformulier -+ meldingspunt -+ meldplicht -+ melissethee -+ melkauto's -+ melkcontroleurs -+ melkeiwit -+ melkertbaan -+ melkertbanen -+ melkertbaner -+ melkertbaners -+ melkgebitten -+ melkkiezen -+ melkkoelers -+ melkkrat -+ melkkratten -+ melklijst -+ melklijsten -+ melkmachines -+ melkmannen -+ melkoverschot -+ melkoverschotten -+ melkplassen -+ melkprijzen -+ melkproduct -+ melkquotering -+ melkreep -+ melkrepen -+ melkrobot -+ melkrobots -+ melkstal -+ melkstallen -+ melksteen -+ melktanks -+ melktijden -+ melkvat -+ melkveehouder -+ melkveehouderijen -+ melkveehouders -+ melkvet -+ melkvoorziening -+ melkwegstelsels -+ melkzeep -+ melkzuurbacterie -+ melkzuurbacteriën -+ melodielijn -+ melodielijnen -+ melodietje -+ membraanfilter -+ membraanfilters -+ memento's -+ memobedrijf -+ memoblokken -+ memoformaten -+ mendeliaans -+ mendeliaanse -+ mene tekel -+ mene tekels -+ menger -+ mengers -+ menginfectie -+ menginfecties -+ mengkleuren -+ mengkom -+ mengkommen -+ mengkranen -+ mengpanelen -+ mengproduct -+ mengproducten -+ mengtafel -+ mengtafels -+ mengverhoudingen -+ mengvoeder -+ mengvoer -+ meningsuitingen -+ meniscusoperatie -+ meniste -+ mennoniete -+ mennonitisch -+ mennonitische -+ mens-erger-je-niet -+ mens-zijn -+ mensbeschouwing -+ mensenbloed -+ mensendieck -+ mensendiecken -+ mensendieckte -+ mensendiecktherapie -+ mensengroep -+ mensengroepen -+ mensenhandel -+ mensenhart -+ mensenharten -+ mensenhoofd -+ mensenhoofden -+ mensenkluwen -+ mensenkluwens -+ mensenmenigte -+ mensenmenigten -+ mensenmenigtes -+ mensenrechtenactivist -+ mensenrechtenactivisten -+ mensenrechtenconferentie -+ mensenrechtenschending -+ mensenrechtenschendingen -+ mensenrechtenverdrag -+ mensenrechtenverdragen -+ mensenredder -+ mensenredders -+ mensenschedel -+ mensenschedels -+ mensenstem -+ mensenstemmen -+ mensenstromen -+ mensentalen -+ mensentypen -+ mensentypes -+ mensenvlo -+ mensenvlooien -+ mensenzeeën -+ mensenziel -+ mensenzielen -+ mensgericht -+ menshoge -+ menshoog -+ mensjewieken -+ mensjewistische -+ menskrachten -+ menstruale -+ menstruatiebloed -+ menstruatiecycli -+ menstruatiecyclussen -+ menstruatiepijnen -+ menstruatiestoornis -+ menstruatiestoornissen -+ menstruele -+ mensurale -+ mensuren -+ mensvormig -+ mensvormige -+ menswetenschap -+ mentaal-cultureel -+ mentaal-culturele -+ mentaliteitsgeschiedenis -+ mentaliteitsveranderingen -+ mentaliteitswijziging -+ mentsj -+ menuanimatie -+ menuanimaties -+ menukaarten -+ menulijst -+ mer à boire -+ mercantilistische -+ mercatores -+ merchandiseartikel -+ merchandiseartikelen -+ merchandisers -+ merengebied -+ mergelgrot -+ mergelgrotten -+ meridiaanshoogte -+ meridiaanshoogten -+ meridiaanshoogtes -+ meritocratische -+ merkenbureaus -+ merkengemachtigde -+ merkengemachtigden -+ merkenrecht -+ merkhouder -+ merkhouders -+ merkinbreuk -+ merkje -+ merkjes -+ merkkledij -+ merkloos -+ merkloze -+ merknamen -+ merkvaste -+ meroniem -+ meroniemen -+ merseybeat -+ mesdjid -+ mesdjids -+ mesjogge -+ mesolithicum -+ mesolithisch -+ mesolithische -+ mesonen -+ mesozoïcum -+ messchedes -+ messenleggers -+ messenschedes -+ messentrekkers -+ messenverbod -+ messiaans -+ messiaanse -+ messianistische -+ messias -+ messiassen -+ messieurs -+ messrooms -+ messteek -+ mestakkoord -+ mestbanken -+ mester -+ mesterij -+ mesterijen -+ mesters -+ mestfabriek -+ mestinjectie -+ mestnorm -+ mestnormen -+ mestoverschot -+ mestoverschotten -+ mestsilo -+ mestsilo's -+ mestverwerking -+ mestverwerkingsfabriek -+ mestvocht -+ sint-jutmis -+ metaalarbeiders -+ metaalbedrijf -+ metaalbewerking -+ metaaldetector -+ metaaldetectoren -+ metaaldetectors -+ metaalfabriek -+ metaalfolie -+ metaalkunde -+ metaalkundig -+ metaalkundige -+ metaalnijverheid -+ metaaloxiden -+ metaaloxides -+ metaalpoeder -+ metaalverf -+ metaalverwerkend -+ metaalverwerkende -+ metaalverwerkingsbedrijf -+ metaalzaagblad -+ metaalzaagbladen -+ metaalzout -+ metaalzouten -+ metabolieten -+ metabolische -+ metallische -+ metallurgen -+ metallurgische -+ metamorfe -+ metastaseerde -+ metastasen -+ metastases -+ metersbrede -+ metersbreed -+ metersdiep -+ metersdiepe -+ metersdik -+ metersdikke -+ metersgroot -+ metersgrote -+ metershoog -+ meterslang -+ meterslange -+ methaangas -+ methadonbussen -+ methadongebruiker -+ methadongebruikers -+ methadonprogramma -+ methadonprogramma's -+ methadonverstrekking -+ methodeonderzoek -+ methodestrijd -+ methodistische -+ methylbromide -+ methylchloride -+ methylchloroform -+ methyleenchloride -+ metiers -+ metrobaan -+ metrobuis -+ metrobuizen -+ metrohalte -+ metrohaltes -+ metrolijn -+ metrolijnen -+ metrolijntje -+ metroniem -+ metronomische -+ metronteken -+ metrontekens -+ metrotrein -+ metrotreinen -+ metrotunnel -+ metrotunnels -+ metroverbinding -+ meubelbeurzen -+ meubelboulevard -+ meubelboulevards -+ meubelfabrikant -+ meubelhout -+ meubelmakerij -+ meubelontwerpen -+ meubelontwerpers -+ meubelplaat -+ meubelplaten -+ meubelstoffeerders -+ meubelzaken -+ meurde -+ meuren -+ mezoeza -+ mezoeza's -+ mezomme -+ mezzo's -+ mi's -+ miasma's -+ mica's -+ micro's -+ micro-elektronica -+ micro-elektronische -+ micro-ondernemer -+ micro-ondernemers -+ micro-onderneming -+ micro-ondernemingen -+ microarchieven -+ microbes -+ microbesoort -+ microbesoorten -+ microbiologen -+ microbiologie -+ microbiële -+ microbursten -+ microchips -+ microfilmde -+ microfilmen -+ microfoonhengel -+ microfoonhengels -+ microfoonstandaard -+ microfoonstandaards -+ microfoontechniek -+ microfoontje -+ microfoonvrees -+ microfoto's -+ microgolf -+ microgolfoven -+ microgolfovens -+ microgolven -+ microgrammen -+ microkaart -+ microkaarten -+ microkopie -+ microkopieën -+ microkorfbal -+ microkrediet -+ micromorfologie -+ microniveaus -+ microotje -+ microsecondes -+ microsferen -+ microstructuren -+ microstructuur -+ microtechniek -+ microtoon -+ microwave -+ microwaves -+ midasoren -+ middaggebed -+ middagmaaltijden -+ middagpauzes -+ middagploegen -+ middagpost -+ middagrust -+ middagschaften -+ middagvoorstellingen -+ middagzonnetje -+ middelbareschooltijd -+ middeleeuwen -+ middelentoets -+ middelgewichten -+ middelhanden -+ middelhoge -+ middelhoog -+ middeling -+ middelingen -+ middelloodlijn -+ middelloodlijnen -+ middelzwaar -+ middelzware -+ middenafstand -+ middenas -+ middenassen -+ middenbanen -+ middenbedrijf -+ middenbermen -+ middenbladen -+ middencirkels -+ middengedeelte -+ middengedeelten -+ middengedeeltes -+ middengewichten -+ middengolfzender -+ middengolfzenders -+ middeninkomen -+ middeninkomens -+ middenkaderfunctie -+ middenkaderfuncties -+ middenklassen -+ middenklasser -+ middenklassers -+ middenlijn -+ middenlijnen -+ middenlinie -+ middenlinies -+ middenmoter -+ middenmoters -+ middenoorontsteking -+ middenoren -+ middenpaden -+ middenpaleolithicum -+ middenpaneel -+ middenpartij -+ middenpartijen -+ middenscholen -+ middenspelers -+ middenstandsexamens -+ middenstandsvereniging -+ middensteentijd -+ middenstrepen -+ middenterrein -+ middenvoetsbeentjes -+ middle class -+ middle-of-the-roadmuziek -+ midgetgolfde -+ midgetgolfen -+ midgetgolft -+ midgetgolfte -+ midhalf -+ midhalfs -+ midrasj -+ midweek -+ midweeks -+ midweekse -+ midweken -+ midwinterhoorns -+ midwinterhorens -+ midzwaard -+ miegelde -+ miegelen -+ miep -+ miepen -+ miepte -+ mierenneuker -+ mierenneukers -+ miese -+ mietjes -+ miezerigheid -+ migraineaanval -+ migraineaanvallen -+ migrainepatiënt -+ migrainepatiënten -+ migrantengemeenschap -+ migrantengemeenschappen -+ migrantenorganisatie -+ migrantenwijk -+ migratieattaché -+ migratiegolf -+ migratiegolven -+ migratieoverschotten -+ migratiesaldi -+ migratiesaldo -+ mihrab -+ mihrabs -+ mijlenverre -+ mijnbedrijf -+ mijnbouwactiviteiten -+ mijnbouwbedrijf -+ mijnbouwindustrie -+ mijnbouwkundigen -+ mijnbouwmaatschappij -+ mijnbouwonderneming -+ mijnbouwondernemingen -+ mijnbouwsector -+ mijndetectoren -+ mijndetectors -+ mijnenjager -+ mijnenjagers -+ mijnenruimer -+ mijnenruimers -+ mijnenvrij -+ mijnenvrije -+ mijngebied -+ mijngebieden -+ mijnrampen -+ mijnsluiting -+ mijnsluitingen -+ mijnstad -+ mijnstaking -+ mijnstakingen -+ mijnsteden -+ mijnwerkersbond -+ mijnwerkersbonden -+ mijnwerkersstaking -+ mijnwerkersvakbond -+ mikwa -+ mikwa's -+ mikwe -+ mikwes -+ mila -+ milderde -+ milderen -+ mildironisch -+ mildironische -+ milicien-korporaal -+ miliciens-korporaals -+ milieu-inspanning -+ milieu-inspanningen -+ milieu-invloed -+ milieu-invloeden -+ milieu-uitgaven -+ milieuactiegroep -+ milieuactivist -+ milieuactivisten -+ milieubelastend -+ milieubelastende -+ milieubelastingen -+ milieubeschermend -+ milieubeschermende -+ milieubewegingen -+ milieubox -+ milieuboxen -+ milieucrimineel -+ milieucriminelen -+ milieudelict -+ milieudelicten -+ milieueconomie -+ milieueducatie -+ milieueis -+ milieueisen -+ milieuerosie -+ milieufactor -+ milieufactoren -+ milieufraude -+ milieugebonden -+ milieuheffingen -+ milieukeur -+ milieukeuren -+ milieukundige -+ milieukundigen -+ milieulasten -+ milieumaatregel -+ milieunorm -+ milieunormen -+ milieuonvriendelijk -+ milieuonvriendelijke -+ milieuovertreding -+ milieuovertredingen -+ milieuplan -+ milieuproblemen -+ milieuschade -+ milieuschandaal -+ milieuschandalen -+ milieustraat -+ milieustraten -+ milieutelefoon -+ milieutoeslagen -+ milieuvergunning -+ milieuvergunningen -+ milieuverontreinigingen -+ milieuvervuiler -+ milieuvervuilers -+ milieuvreemd -+ milieuvreemde -+ milieuwet -+ milieuwetten -+ milieuzorg -+ militair-civiel -+ militair-civiele -+ militair-economisch -+ militair-economische -+ militair-industrieel -+ militair-industriële -+ militair-politiek -+ militair-politieke -+ militair-strategisch -+ militair-strategische -+ militair-technisch -+ militair-technische -+ militarisering -+ military's -+ militaryruiter -+ militaryruiters -+ militarysport -+ militie-eenheden -+ militie-eenheid -+ militieleden -+ militieleider -+ militieleiders -+ militielid -+ militievergoeding -+ militievergoedingen -+ miljardenclaim -+ miljardenclaims -+ miljardeninvestering -+ miljardeninvesteringen -+ miljardenlening -+ miljardenleningen -+ miljardennota's -+ miljardenorder -+ miljardenorders -+ miljardensteun -+ miljoenenerfenissen -+ miljoenenfraude -+ miljoenenleger -+ miljoenennota's -+ miljoenenoplage -+ miljoenenorder -+ miljoenenorders -+ miljoenenschuld -+ miljoenentransfer -+ miljoenentransfers -+ miljoenenwinst -+ miljoenenwinsten -+ miljoenenzaak -+ milkshakeje -+ milliampères -+ millisecondes -+ milliwatts -+ mimede -+ mimegezelschap -+ mimegroepen -+ mimekunstenaar -+ mimekunstenaars -+ mimers -+ mimeschool -+ mimespelers -+ mimi's -+ mimografen -+ mimosa's -+ min-maxcontract -+ min-maxcontracten -+ minarine -+ minderbedeeld -+ minderbedeelde -+ minderbedeelden -+ minderhedenakkoord -+ minderhedenprobleem -+ minderhedenvraagstukken -+ minderheidsaandeelhouders -+ minderheidsbelangen -+ minderheidskabinetten -+ minderheidspartij -+ minderheidspartijen -+ minderheidsposities -+ minderheidsregeringen -+ minderheidstaal -+ minderheidstalen -+ mindervalide -+ mindervaliden -+ mineraalrijk -+ mineraalrijke -+ mineraalwatermarkt -+ mineraalwatermerk -+ mineralenbalans -+ mineralenboekhouding -+ mineralenoverschot -+ mineraliseerde -+ mini-Europa -+ mini-enquête -+ mini-enquêtes -+ mini-essay -+ mini-essays -+ mini-ijstijd -+ mini-jurken -+ miniatuurlandschap -+ miniatuurtje -+ minibar -+ minibars -+ minibus -+ minibussen -+ minicrisis -+ minidisk -+ minidisks -+ miniemen -+ miniformaat -+ minikrach -+ minimal music -+ minimalisering -+ minimalistische -+ minimumaantal -+ minimumbedrag -+ minimumgrens -+ minimuminkomens -+ minimumjeugdlonen -+ minimumkapitaal -+ minimumloner -+ minimumloners -+ minimumloonkosten -+ minimumprogramma's -+ minimumtemperaturen -+ minimumtemperatuur -+ minimumuitkeringen -+ minimumvoorwaarde -+ minioorlog -+ minioorlogen -+ minipil -+ minipillen -+ minirokken -+ miniseerde -+ miniseries -+ ministeriabele -+ ministeriegebouw -+ ministersfunctie -+ ministersoverleg -+ ministersploeg -+ ministerstafel -+ ministerszetel -+ ministerszetels -+ minitop -+ minitrip -+ minitrips -+ miniuitrusting -+ minjan -+ minks -+ minkukels -+ minorieten -+ minoriseerde -+ minoriseren -+ minorisering -+ mintgroen -+ mintgroene -+ minuskels -+ minusteken -+ minustekens -+ minutenlange -+ minwaarde -+ minwaarden -+ mioceen -+ miocene -+ miradj -+ mirakelse -+ misbruikwetgeving -+ miscalculatie -+ miscalculaties -+ miscommunicatie -+ misdaadauteurs -+ misdaadbestrijding -+ misdaadfilm -+ misdaadorganisatie -+ misdaadpreventie -+ misdaadroman -+ misdaadromans -+ misdaadserie -+ misdaadseries -+ misdaadsyndicaat -+ misdaadsyndicaten -+ misdaadverhaal -+ misdaadverhalen -+ misdragingen -+ misdrijfzaken -+ mise-en-place -+ mises-en-scène -+ misgeboortes -+ misgegokt -+ misgeschoten -+ misgestapt -+ misgokken -+ misgooien -+ mishoord -+ mishoorde -+ mishoren -+ misintentie -+ misintenties -+ misjpooche -+ miskleden -+ miskleed -+ misogyne -+ miss-wet-T-shirtverkiezing -+ miss-wet-T-shirtverkiezingen -+ misschieten -+ misse -+ misselijkmakend -+ misselijkmakende -+ missertje -+ missie-ijver -+ missiegebied -+ missiegebieden -+ missieposten -+ missiezuster -+ missiezusters -+ missioneerde -+ missionering -+ missverkiezingen -+ mistbanken -+ mistevreden -+ mistflard -+ mistflarden -+ mistlichten -+ mistoestand -+ mistoestanden -+ mistongeluk -+ mistongelukken -+ mistralletje -+ mistsliert -+ mistslierten -+ misverstaan -+ miswijn -+ mitella's -+ mitrailleurkogel -+ mitrailleurkogels -+ mitrailleursalvo -+ mitrailleursalvo's -+ mixtures -+ mo A -+ mo A-akte -+ mo B -+ mo B-akte -+ mo-akte -+ mo-akten -+ mo-aktes -+ mobile's -+ mobiles -+ mobilhomepje -+ mobilhomes -+ mobilisabele -+ mobiliseerbare -+ mobiliseringen -+ mobiliteitsbeleid -+ mobiliteitsregeling -+ mobiliteitsschrift -+ mobilofoonnetten -+ mobilofoons -+ modderbrij -+ moddercampagne -+ moddercampagnes -+ moddergevecht -+ modderlaag -+ modderlagen -+ modderlawine -+ modderlawines -+ modderspat -+ modderspatten -+ modderstromen -+ modderstroom -+ moddervechten -+ mode-industrie -+ modeacademie -+ modeacademies -+ modeaccessoire -+ modeaccessoires -+ modebeeld -+ modeboek -+ modeboeken -+ modefotografie -+ modegevoelig -+ modegevoeligheid -+ modejournaals -+ modekoning -+ modekoningen -+ modekreten -+ modelacties -+ modelgetekend -+ modellenbureaus -+ modelmatig -+ modelmatige -+ modelspoorbanen -+ modelstad -+ modelsteden -+ modelstudie -+ modelstudies -+ modeltekende -+ modeltheorie -+ modeltheorieën -+ modelvliegtuig -+ modelvliegtuigen -+ modeontwerper -+ modeontwerpers -+ moderaties -+ moderato's -+ modern-klassiek -+ modern-klassieke -+ moderniseringsplan -+ moderniseringspolitiek -+ moderniseringsproces -+ moderniseringsprogramma -+ moderniseringsproject -+ modeste -+ modetijdschrift -+ modetijdschriften -+ modevakscholen -+ modeverschijnselen -+ modeweek -+ modieusheid -+ modinettes -+ modulatoren -+ modulators -+ moeder-dochterrelatie -+ moeder-dochterrelaties -+ moeder-kindrelatie -+ moeder-kindrelaties -+ moederbanden -+ moederbeeld -+ moederbeelden -+ moederblad -+ moederbladen -+ moederbuik -+ moedercel -+ moedercellen -+ moedercomplexen -+ moedercursussen -+ moederdieren -+ moederfiguren -+ moederfiguur -+ moedergodinnen -+ moederinstincten -+ moederkindje -+ moederkindjes -+ moederklokken -+ moederlanden -+ moederrol -+ moedersleutel -+ moedersleutels -+ moederstad -+ moedersteden -+ moedertaalonderwijs -+ moedertaalspreker -+ moedertaalsprekers -+ moedervel -+ moedervellen -+ moedgevend -+ moedgevende -+ moedjahedien -+ moegespeeld -+ moegespeelde -+ moegestreden -+ moeilijkheidsfactor -+ moeilijkheidsfactoren -+ moeilijkheidsgraden -+ moeizaamheid -+ moekim -+ moekims -+ moellah -+ moellahs -+ moerasbos -+ moerasbossen -+ moerasgebied -+ moerasgebieden -+ moerasland -+ moeraslanden -+ moerasschildpad -+ moerasschildpadden -+ moerasvergeet-mij-niet -+ moerasvergeet-mij-nietje -+ moerbeivlinder -+ moerbeivlinders -+ moermantherapie -+ moestuintje -+ moezelwijnen -+ moeë -+ mofokoranti -+ mohairen -+ moheel -+ moheels -+ mokka-ijs -+ mokkataarten -+ moksimeti -+ molaren -+ moleculairbiologisch -+ moleculairbiologische -+ molecules -+ moleculetje -+ molecuulmassa -+ molecuulstructuren -+ molecuulstructuur -+ molecuultje -+ molentochten -+ molenvliegtuig -+ molenvliegtuigen -+ molinologie -+ mollah -+ mollahs -+ mollengangen -+ mollusk -+ mollusken -+ molluskicide -+ molluskiciden -+ molotovcocktails -+ molrat -+ molratten -+ molukkenkreeft -+ molukkenkreeften -+ moment suprême -+ momentum -+ monastieke -+ mond-en-klauwzeer -+ mond-keelholte -+ mond-tot-mondreclame -+ mondbeschermers -+ monddode -+ monddouche -+ monddouches -+ mondharp -+ mondharpen -+ mondhygiënist -+ mondhygiënisten -+ mondhygiënistes -+ mondigheidsverklaring -+ mondigheidsverklaringen -+ mondmasker -+ mondmaskers -+ mondopeningen -+ mondorgel -+ mondorgels -+ mondreclame -+ mondvoorraden -+ monetaristische -+ moneybelt -+ moneybelts -+ moneymakers -+ mongolenvlek -+ mongooltje -+ monitoraten -+ monitorde -+ monitrices -+ monkimonki -+ monkimonki's -+ monnikendom -+ monniksrob -+ monniksrobben -+ monoculturen -+ monodieën -+ monodrama's -+ monogame -+ monografische -+ monokini's -+ monoklonaal -+ monoklonale -+ monolithische -+ monomeren -+ monopoliebedrijf -+ monopoliecommissie -+ monopolierechten -+ monopolievorming -+ monopolisering -+ monopoliseringen -+ monopolyde -+ monopolyen -+ monopolygeld -+ monorails -+ monsterboekjes -+ monsterfles -+ monsterflessen -+ monsteroverwinning -+ monsterproductie -+ monsterscores -+ monsterverbonden -+ monsterzeges -+ montage-instructie -+ montage-instructies -+ montagedraad -+ montagehal -+ montagehallen -+ montagetafel -+ montagetafels -+ montignaccen -+ montignacdieet -+ montignacte -+ monumentenbeleid -+ monumentencommissie -+ monumentenlijsten -+ monumentenwet -+ mooiklinkend -+ mooipraterij -+ moordbrigade -+ moordbrigades -+ moordcommando -+ moordcommando's -+ moordonderzoek -+ moordpartijen -+ moordpoging -+ moordpogingen -+ moordtonelen -+ moordwapens -+ mopperkont -+ mopperkonten -+ mopperpot -+ mopperpotten -+ moppie -+ moppies -+ mopsneuzen -+ mopé -+ mopés -+ mopéstroop -+ mora -+ moraalfilosoof -+ moraalridder -+ moraalridders -+ moraaltheologen -+ moraaltheoloog -+ moralisering -+ moraliteiten -+ moratoire -+ morbiditeiten -+ morenemateriaal -+ morfineverslaving -+ morfogenetische -+ morgengrauwen -+ morgennacht -+ morgenwijdingen -+ moriaan -+ morianen -+ mormonenkerk -+ mormonenkerken -+ morning-afterpil -+ morning-afterpillen -+ morsdoek -+ morsdoeken -+ morshandel -+ mortieraanval -+ mortieraanvallen -+ mortierbeschieting -+ mortierbeschietingen -+ mortiergeschut -+ mortiergeweer -+ mortiergeweren -+ mortiergranaten -+ mortiervuur -+ mortuaria -+ mosjav -+ moskeebestuur -+ moskeebezoeker -+ moskeebezoekers -+ moskeeganger -+ moskeegangers -+ moskeeorganisatie -+ moslagen -+ moslima -+ moslima's -+ moslimactivist -+ moslimactivisten -+ moslimbroederschap -+ moslimextremisme -+ moslimextremist -+ moslimextremisten -+ moslimextremistisch -+ moslimextremistische -+ moslimfundamentalisme -+ moslimfundamentalist -+ moslimfundamentalisten -+ moslimfundamentalistisch -+ moslimfundamentalistische -+ moslimgemeenschappen -+ moslimhulporganisatie -+ moslimorganisatie -+ moslimsen -+ moslimstaat -+ moslimstaten -+ moslimstrijdkrachten -+ mosselcultuur -+ mosselkwekers -+ mosselperceel -+ mosselpercelen -+ mosselvisserij -+ mosterdgele -+ mosterdpoeder -+ motard -+ motards -+ motecht -+ motiveringsplicht -+ moto's -+ motoragenten -+ motorblokken -+ motorbrandstof -+ motorbrandstoffen -+ motorclubs -+ motorcoureurs -+ motorcrossen -+ motorcrossers -+ motorcrosses -+ motordrive -+ motordrives -+ motorgeronk -+ motorhelmen -+ motorinhoud -+ motorkruiser -+ motorkruisers -+ motorlaars -+ motorlaarzen -+ motorlawaai -+ motoronderdeel -+ motoronderdelen -+ motorongelukken -+ motorophanging -+ motorpech -+ motorracen -+ motorraces -+ motorrijden -+ motorschepen -+ motorschip -+ motorsporten -+ motortje -+ motortoerental -+ motortoerentallen -+ motortractie -+ motorwedstrijden -+ motorzaag -+ motorzagen -+ mottekasteel -+ mottekastelen -+ motterig -+ motterige -+ mottes -+ mountainbiken -+ mountainbiker -+ mountainbikers -+ mountainbikes -+ mountainbiket -+ mountainbikete -+ mousseje -+ mousses -+ moussetje -+ moustache -+ moustaches -+ moutsuiker -+ mouvementen -+ mouwband -+ mouwbanden -+ mouwgat -+ mouwgaten -+ mouwloze -+ mouwplank -+ mouwplanken -+ mouwschorten -+ movede -+ moves -+ movet -+ mozetta's -+ mp -+ mp's -+ mr. -+ ms -+ mts -+ mu -+ muezzins -+ muggenbulten -+ muggenlarve -+ muggenlarven -+ muggenplaag -+ muggenplagen -+ muggenzifterig -+ muggenzifterige -+ muggenzifters -+ muggenziftte -+ muisarm -+ muismatten -+ muizenbeetje -+ muizenbeetjes -+ muizengaatje -+ muizengaten -+ muizengerst -+ muizenholen -+ muizenholletje -+ muizenkeutels -+ muizennesten -+ muizentarwe -+ muizenvalk -+ muizenvalken -+ muizenvallen -+ muleta's -+ mulo -+ muloscholen -+ muloschool -+ multatuliaans -+ multatuliaanse -+ multi-etnische -+ multi-interpretabele -+ multi-inzetbaar -+ multi-inzetbare -+ multiculti -+ multiculti's -+ multimedia-apparatuur -+ multimedia-pc -+ multimedia-pc's -+ multimediaal -+ multimediale -+ multimiljardairs -+ multipele -+ multiple choice -+ multiplechoicetest -+ multiplechoicetests -+ multiplechoicetoets -+ multiplechoicetoetsen -+ multiplechoicevraag -+ multiplechoicevragen -+ multipliceerde -+ multipliereffect -+ multipliers -+ multivariabel -+ multivariabele -+ mummelmonden -+ mungo -+ mungo's -+ municipale -+ munitiekist -+ munitiekisten -+ munitieopslagplaats -+ munitieopslagplaatsen -+ munitietrein -+ munitietreinen -+ munitievoorraad -+ munitievoorraden -+ munsterkerk -+ munsterkerken -+ muntjak -+ muntjaks -+ muntontwaarding -+ muntsoort -+ muntsoorten -+ muntstabiliteit -+ munttekens -+ muntthee -+ muntunie -+ musculaire -+ musettes -+ museumbezoek -+ museumbezoeken -+ museumbezoeker -+ museumbezoekers -+ museumcollectie -+ museumdirecteur -+ museumdirecties -+ museumjaarkaart -+ museumpersoneel -+ museumwinkel -+ museumwinkels -+ museumzaal -+ museumzaaltje -+ museumzalen -+ musicalmaker -+ musicalmakers -+ musicalproductie -+ musicalproducties -+ musichall -+ musichalls -+ musicologe -+ musicologes -+ musicologische -+ muskaatdruif -+ muskaatdruiven -+ muskietenkaars -+ muskietenkaarsen -+ muskusgeur -+ muskusossen -+ musts -+ mutagene -+ mutanten -+ mutatieven -+ mutilaties -+ mutileerde -+ muurhaak -+ muurhaken -+ muurkast -+ muurkasten -+ muurkluizen -+ muurlamp -+ muurlampen -+ muurpeper -+ muurreclames -+ muursafes -+ muurschilder -+ muurschilderen -+ muurschilders -+ muurvlakken -+ muzak -+ muziekafdeling -+ muziekarchief -+ muziekavonden -+ muziekband -+ muziekbands -+ muziekbehang -+ muziekbeoefening -+ muziekbibliotheken -+ muziekcompositie -+ muziekcritici -+ muziekdirecteur -+ muziekdirecteuren -+ muziekdirecteurs -+ muziekensemble -+ muziekensembles -+ muziekevenement -+ muziekevenementen -+ muziekfilm -+ muziekfilms -+ muziekhandel -+ muziekhistorisch -+ muziekhistorische -+ muziekjes -+ muziekkapellen -+ muziekkenner -+ muziekkenners -+ muziekkritiek -+ muziekkritieken -+ muziekminnaar -+ muziekminnaars -+ muzieknotatie -+ muzieknotaties -+ muziekonderwijs -+ muziekprogramma's -+ muziekrecensie -+ muzieksalon -+ muzieksalons -+ muziekstandaarden -+ muziekstandaards -+ muziekstudie -+ muziekstudies -+ muziekterm -+ muziektheaterproductie -+ muziektheoretici -+ muziektheoreticus -+ muziektheorie -+ muziektijdschrift -+ muziektijdschriften -+ muziekuitgever -+ muziekuitgevers -+ muziekvereniging -+ muziekverenigingen -+ muziekvermogen -+ muziekwereld -+ muziekwetenschap -+ muziekwinkel -+ muziekwinkels -+ muziekzaal -+ muziekzalen -+ muzikanteske -+ myalgische encefalomyelitis -+ myalgische encefalomyopathie -+ myomeer -+ myomeren -+ mythes -+ mythevorming -+ mythologiseerde -+ mythomanen -+ mytylscholen -+ mytylschool -+ ménière -+ n'en -+ n's -+ n.v.t. -+ na-aperijen -+ na-apers -+ na-ijleffect -+ na-ijleffecten -+ na-ijlen -+ na-ijling -+ na-ijver -+ na-ijverig -+ na-ijverige -+ naai-juf -+ naaiatelier -+ naaikransje -+ naaikransjes -+ naaktcultuur -+ naaktloperij -+ naaktmodel -+ naaktmodellen -+ naaktshow -+ naaktstudie -+ naaktstudies -+ naaldkunst -+ naaldwoud -+ naaldwouden -+ naamgenotes -+ naamloosheid -+ naamstem -+ naamstemmen -+ naamsvermelding -+ naamsvermeldingen -+ naamwoordelijk -+ naamwoordelijke -+ naan -+ naarlingen -+ naastgelegene -+ naastliggend -+ naastliggende -+ nabestaandenpensioen -+ nabestaandenuitkering -+ nabeurs -+ nabloeden -+ nabloedingen -+ nabouwen -+ nabranden -+ nabranders -+ nabuurland -+ nabuurlanden -+ nacalculaties -+ nachochips -+ nachtclubeigenaar -+ nachtclubportier -+ nachtcrèmes -+ nachtdier -+ nachtdieren -+ nachtenlang -+ nachtenlange -+ nachthemel -+ nachthokken -+ nachthoofden -+ nachtkijker -+ nachtkijkers -+ nachtkluizen -+ nachtkussen -+ nachtlawaai -+ nachtlogies -+ nachtluchten -+ nachtmens -+ nachtmensen -+ nachtmerrieachtig -+ nachtmerrieachtige -+ nachtopvang -+ nachtpauwogen -+ nachtpauwoog -+ nachtportiers -+ nachtschadefamilie -+ nachtschades -+ nachttafel -+ nachttafels -+ nachtverpleegsters -+ nachtvoorstellingen -+ nachtwachten -+ nachtwakersstaat -+ nachtwandelingen -+ nachtzichtkijker -+ nachtzichtkijkers -+ nachtzijde -+ nachtzijden -+ nachtzoenen -+ nachtzusters -+ nachtzwaluw -+ nachtzwaluwen -+ nacompetitie -+ nadar -+ nadarafsluiting -+ nadarafsluitingen -+ nadarhek -+ nadarhekken -+ nadars -+ nadienst -+ nadiensten -+ nadreunen -+ nadrukkelijkheid -+ naffer -+ naffers -+ naft -+ nagebloed -+ nageboortes -+ nagebrand -+ nagedreund -+ nagelknippers -+ nagelnieuw -+ nagelnieuwe -+ nageltang -+ nageltangen -+ nagerend -+ nagetrapt -+ nagetrild -+ nagevoeld -+ nagevraagd -+ nagevuld -+ nagezinderd -+ nagezongen -+ nagisting -+ naheffingsaanslag -+ nahosser -+ nahossers -+ najaarsbeurzen -+ najaarsoffensief -+ najaarsvergadering -+ nakend -+ nakende -+ nakie -+ nakies -+ naklinken -+ namaakleer -+ namedropping -+ namiddagzon -+ namiddagzonnetje -+ nanometers -+ nanoseconde -+ nanoseconden -+ nanosecondes -+ napi -+ napoleontische -+ napoleonvis -+ napoleonvissen -+ nappaleer -+ narcist -+ narcisten -+ narcistische -+ narcoanalyses -+ narcolepsie -+ narcosearts -+ narcoseartsen -+ narcotica-agent -+ narcotica-agenten -+ narcoticabrigades -+ narcotiseurs -+ narennen -+ nargileh -+ nargilehs -+ narrenschip -+ naschok -+ naschokken -+ nascholingscursus -+ nascholingscursussen -+ nascholingsprogramma -+ nascholingsprogramma's -+ naschools -+ naschoolse -+ nasi goreng -+ nasi rames -+ nasi-ingrediënten -+ nasiballen -+ nasischijf -+ nasischijven -+ nasjen -+ nasjte -+ nassen -+ naste -+ nastoten -+ natale -+ natgegooid -+ natgehouden -+ natgooien -+ nathouden -+ natievorming -+ nationaalcommunistisch -+ nationaalcommunistische -+ nationaaldemocratisch -+ nationaaldemocratische -+ nationaalsocialisme -+ nationaalsocialist -+ nationaalsocialisten -+ nationaalsocialistisch -+ nationaalsocialistische -+ nationaliteitenkwestie -+ nationaliteitenprobleem -+ nationaliteitsbesef -+ native speaker -+ native speakers -+ natrillen -+ natriumbicarbonaat -+ natriumchloride -+ natriumzwavel -+ nattevingerwerk -+ naturalisatieverzoek -+ naturalisatieverzoeken -+ naturalisatiewet -+ naturisten -+ naturistenverenigingen -+ natuurazijn -+ natuurbeschermers -+ natuurbeschermingsgebieden -+ natuurbeschermingsorganisatie -+ natuurbeschermingswet -+ natuurbossen -+ natuurbouw -+ natuurfilosofen -+ natuurfilosofie -+ natuurfilosofisch -+ natuurfilosofische -+ natuurfilosoof -+ natuurfotograaf -+ natuurfotografen -+ natuurgenezers -+ natuurgetrouwheid -+ natuurijs -+ natuurkenners -+ natuurkundeleraar -+ natuurkundeleraars -+ natuurkundeleraren -+ natuurleerpad -+ natuurleerpaden -+ natuurliefhebber -+ natuurliefhebbers -+ natuurminnaar -+ natuurminnaars -+ natuuronderwijs -+ natuurontwikkelingsgebied -+ natuurontwikkelingsgebieden -+ natuurpark -+ natuurparken -+ natuurtoerisme -+ natuurvoeding -+ natuurvoedingswinkel -+ natuurvoedingswinkels -+ natuurvorm -+ natuurvormen -+ natuurvorsers -+ natuurvriendelijk -+ natuurvriendelijke -+ natuurwetenschapper -+ natuurwetenschappers -+ natuurzij -+ navelbandjes -+ navelbreuken -+ navelpiercing -+ navelpiercings -+ navelsinaasappelen -+ navelsinaasappels -+ navelstreek -+ naveltruitje -+ naveltruitjes -+ naverbrander -+ naverbranders -+ naverkoopdienst -+ navigatie-instrument -+ navigatie-instrumenten -+ navigatieapparatuur -+ navigatiefout -+ navigatiefouten -+ navigatiemiddel -+ navigatiestructuur -+ navigatiesysteem -+ navigeerde -+ navoelbaar -+ navoelbare -+ navoelen -+ navullen -+ navylook -+ nawijsbaar -+ nawijsbare -+ nazi-Duitsland -+ nazi-ideologie -+ nazi-jager -+ nazi-jagers -+ naziagressie -+ nazicht -+ naziconcentratiekamp -+ nazidom -+ nazigroet -+ nazinderen -+ nazingen -+ nazioorlogsmisdadiger -+ nazioorlogsmisdadigers -+ nazipropaganda -+ naziskins -+ nazistische -+ nazivernietigingskamp -+ nazivernietigingskampen -+ neanderthaler -+ neanderthalers -+ nebbisj -+ nectarines -+ nedergezet -+ nederpop -+ nederzetten -+ nederzettingenbeleid -+ nederzettingsonderzoek -+ nee-uitslag -+ neecampagne -+ neekamp -+ neerbuigendheid -+ neergekwakt -+ neergestoten -+ neergezonken -+ neerkwakken -+ neerpoten -+ neerslaggebieden -+ neerslaghoeveelheden -+ neerslaghoeveelheid -+ neerstoten -+ neerzinken -+ neestem -+ neestemmen -+ neestemmer -+ neestemmers -+ neezegger -+ neezeggers -+ nefaste -+ negativisten -+ negativistische -+ negendaags -+ negendaagse -+ negende-eeuws -+ negende-eeuwse -+ negenentwintigjarig -+ negenentwintigjarige -+ negenhonderdste -+ negenkoppig -+ negenkoppige -+ negenmaal -+ negenponder -+ negenponders -+ negentiende-eeuwer -+ negentiende-eeuwers -+ negentienjarig -+ negentienjarige -+ negerbevolking -+ negerbloed -+ negerjongen -+ negerjongens -+ negerkind -+ negerkinderen -+ negerstam -+ negerstammen -+ negerwijk -+ negerwijken -+ negerzangers -+ negerzoen -+ negerzoenen -+ negotieerde -+ negrospirituals -+ nek-aan-nekrace -+ nek-aan-nekraces -+ nekharen -+ nekschoten -+ nekspier -+ nekspieren -+ nekstijfheid -+ nekstuk -+ nekstukken -+ nematoden -+ nemers -+ neming -+ nemingen -+ neo-international -+ neo-internationals -+ neocommunisten -+ neoconservatieven -+ neofascisten -+ neofascistische -+ neofielen -+ neofyt -+ neofyten -+ neogotische -+ neoklassieke -+ neoliberale -+ neolithicum -+ neolithisatie -+ neolithisering -+ neomarxistische -+ neonatale -+ neonatologen -+ neonatologisch -+ neonatologische -+ neonazistische -+ neonletter -+ neonletters -+ neonlichten -+ neonreclames -+ neopaganisme -+ neoplatoonse -+ neoprofs -+ neorealisten -+ neorealistische -+ neoromantische -+ neostijlen -+ nepagent -+ nepagenten -+ nepantiek -+ nepbom -+ nephuis-aan-huisblad -+ nepmiddel -+ nepopenhaard -+ nepstatuten -+ nepstatuut -+ neptweedestuurman -+ nerd -+ nerds -+ nero's -+ nertsmantels -+ nesjomme -+ nesjommes -+ nestbeschermer -+ nestbeschermers -+ nestbevuiler -+ nestbevuilers -+ nestgeur -+ nestgeuren -+ nestharen -+ nestkleed -+ nestoriaans -+ nestoriaanse -+ nestplaats -+ nestplaatsen -+ nestvaren -+ nestvarens -+ netbal -+ netelachtig -+ netelachtige -+ netetiquette -+ netkous -+ netkousen -+ netschakelaars -+ netsuke -+ netsukes -+ nettiquette -+ netto-inkomen -+ netto-inkomens -+ netto-netto -+ netto-omzet -+ netto-opbrengsten -+ netto-uitkering -+ nettobijdrage -+ nettorendement -+ nettoverlies -+ netvormig -+ netvormige -+ netwerkoptie -+ netwerkopties -+ netwerkte -+ neuralgische -+ neurochirurgen -+ neurologes -+ neuronale -+ neuropeptiden -+ neuroseleer -+ neuroten -+ neurotici -+ neurotiseerde -+ neus-keelholte -+ neusaap -+ neusademhaling -+ neusapen -+ neusbeentje -+ neusbeentjes -+ neusbeer -+ neusberen -+ neuscatarre -+ neusdruppel -+ neusgang -+ neusgangen -+ neushaai -+ neushaaien -+ neushaar -+ neusharen -+ neuskegels -+ neuslijn -+ neuspeuteren -+ neuspleister -+ neuspleisters -+ neuspoliep -+ neuspoliepen -+ neuspulker -+ neuspulkers -+ neusriem -+ neusriemen -+ neusrug -+ neusspiegel -+ neusspiegels -+ neusspray -+ neussprays -+ neustussenschotten -+ neusvocht -+ neuswiel -+ neutralistische -+ neutraliteitspolitiek -+ neutronenbommen -+ neutronenster -+ neutronensterren -+ neutronenstraal -+ neutronenstralen -+ nevelblussers -+ nevelflarden -+ nevelhypothese -+ nevelkamer -+ nevelkamers -+ nevelsluier -+ nevelsluiers -+ nevenbedoeling -+ nevenbedoelingen -+ nevenintrige -+ nevenintriges -+ nevenproduct -+ nevenproducten -+ nevenverdienste -+ nevenverdiensten -+ nevenvorm -+ nevenvormen -+ nevenwerking -+ nevenwerkingen -+ new age -+ new wave -+ newagebeweging -+ newtoniaans -+ newtoniaanse -+ newwaveband -+ newwavebands -+ newwavemuziek -+ ngo -+ ngo's -+ nicheje -+ nichemarkt -+ nichemarkten -+ nichtenbar -+ nichtenbars -+ nichterig -+ nichterige -+ nicotinearm -+ nicotinearme -+ nicotinezuur -+ nieges -+ niembomen -+ niemboom -+ nieraandoening -+ nieraandoeningen -+ nierbekkenontsteking -+ nierbekkenontstekingen -+ nierbroodje -+ nierbroodjes -+ nierdialyses -+ nierfunctie -+ nierfuncties -+ nierfunctiestoornis -+ nierfunctiestoornissen -+ niergordel -+ niergordels -+ niergruis -+ nierkoliek -+ nierkolieken -+ nierkwaal -+ nierontstekingen -+ nierpatiënten -+ niersteenverbrijzelaar -+ niersteenverbrijzelaars -+ niersteenvergruizers -+ niertransplantaties -+ niervergiftiging -+ nierziekte -+ nierziekten -+ nierziektes -+ niesziekte -+ niet-gouvernementele organisatie -+ non-gouvernementele organisatie -+ niet-Engelstalige -+ niet-Europese -+ niet-Joodverklaring -+ niet-Joodverklaringen -+ niet-aanvalsverdragen -+ niet-aflatende -+ niet-alledaagse -+ niet-ambtelijke -+ niet-arische -+ niet-begrijpende -+ niet-bestaande -+ niet-betalende -+ niet-beursgenoteerde -+ niet-bindende -+ niet-blanken -+ niet-commerciële -+ niet-confessionele -+ niet-dodelijke -+ niet-drinkende -+ niet-echte -+ niet-erkende -+ niet-euclidisch -+ niet-euclidische -+ niet-fundamentalistische -+ niet-gebruiker -+ niet-gebruikers -+ niet-gelovige -+ niet-geselecteerde -+ niet-gewenste -+ niet-godsdienstige -+ niet-idealiteit -+ niet-idealiteiten -+ niet-ijzerhoudende -+ niet-inflatoire -+ niet-ingewijden -+ niet-leden -+ niet-legitieme -+ niet-lidstaten -+ niet-lineaire -+ niet-officiële -+ niet-ontvankelijke -+ niet-optimale -+ niet-productieve -+ niet-radioactieve -+ niet-regeringspartijen -+ niet-rokencoupé -+ niet-rokencoupés -+ niet-specialisten -+ niet-strafbare -+ niet-toegestane -+ niet-verdienende -+ niet-werkenden -+ nieter -+ nieters -+ nietpistolen -+ nietsvermoedende -+ nietzscheaans -+ nietzscheaanse -+ nieuwbouwcomplex -+ nieuwbouwcomplexen -+ nieuwbouwplan -+ nieuwbouwplannen -+ nieuwbouwwoninkje -+ nieuwgeboren -+ nieuwgekozen -+ nieuwgevormd -+ nieuwgevormde -+ nieuwjaarsbijeenkomst -+ nieuwjaarsboodschappen -+ nieuwjaarsconcerten -+ nieuwjaarsfeest -+ nieuwjaarsfeesten -+ nieuwjaarsnacht -+ nieuwjaarsrecepties -+ nieuwjaarsrede -+ nieuwkuis -+ nieuwprijzen -+ nieuwrechts -+ nieuwrechtse -+ nieuwsfeit -+ nieuwsfeiten -+ nieuwsfoto -+ nieuwsfoto's -+ nieuwsgaarder -+ nieuwsgaarders -+ nieuwsjager -+ nieuwsjagers -+ nieuwslezeres -+ nieuwsoverzicht -+ nieuwsoverzichten -+ nieuwspraak -+ nieuwsrubrieken -+ nieuwsstop -+ nieuwsvoorzieningen -+ nieuwtestamentici -+ nieuwtestamenticus -+ nieuwvorming -+ nieuwvormingen -+ nihilbedingen -+ nijlbaars -+ nijlbaarzen -+ nijlgans -+ nijlganzen -+ nijlkrokodil -+ nijlkrokodillen -+ nikab -+ nikabs -+ nikkelbad -+ nikkelbaden -+ nikste -+ nipjes -+ nisskakam -+ nitraatfilm -+ nitrieten -+ nitroverbinding -+ nitroverbindingen -+ niveaudifferentiatie -+ niveauverschillen -+ nivelleringsmaatregel -+ nl. -+ no cure -+ no pay -+ no-claim -+ no-claimkortingen -+ no-flyzone -+ no-flyzones -+ no-goarea -+ no-goareas -+ no-nonsense -+ no-nonsensebeleid -+ no-nonsensepolitiek -+ no-showstudent -+ noachitisch -+ noachitische -+ nobelheid -+ noblesse oblige -+ nobody -+ nobody's -+ nodeloost -+ nokvol -+ nokvolle -+ nom de plume -+ nomadenbestaan -+ nomadencultuur -+ nomadenvolk -+ nomadenvolken -+ nomadenvolkeren -+ nominalist -+ nominalisten -+ nominalistisch -+ nominalistische -+ noms de plume -+ non-alcoholica -+ non-alcoholische -+ non-conformistisch -+ non-conformistische -+ non-descripte -+ non-events -+ non-fiction -+ non-figuratieve -+ non-foodafdeling -+ non-foodafdelingen -+ non-paper -+ non-verbale -+ nondedju -+ nonetten -+ noni -+ noodaggregaten -+ noodcel -+ noodcellen -+ noodfonds -+ noodfondsen -+ noodgebieden -+ noodgrepen -+ noodkabinet -+ noodkachel -+ noodkachels -+ noodkacheltje -+ noodplannen -+ noodrecht -+ noodreparaties -+ noodstoppen -+ noodstops -+ noodtempo -+ noodtoestanden -+ noodverbanden -+ noodverordening -+ noodverordeningen -+ noodweerexces -+ noord-zuidverbinding -+ noord-zuidverbindingen -+ noordeling -+ noordelingen -+ noorderburen -+ noorderbuur -+ noorderkwartier -+ noorderkwartieren -+ noorderlingen -+ noordgrenzen -+ noordkaper -+ noordkapers -+ noordoostenwinden -+ noordoostkust -+ noordpolen -+ noordpunt -+ noordwestenwinden -+ noordwesterstorm -+ noordwesterstormen -+ noordwestkust -+ noordzeegarnaal -+ noordzeegarnalen -+ noordzeekrab -+ noordzeekrabben -+ nootolie -+ noppenfolie -+ noren -+ noria's -+ normafwijkend -+ normafwijkende -+ normalerwijs -+ normalerwijze -+ normalisaties -+ normcommissie -+ normen-en-waardendebat -+ normenstelsels -+ normensysteem -+ normeringen -+ normgevend -+ normgevende -+ normhandhaving -+ normherstel -+ normuitkering -+ normuitkeringen -+ normverval -+ not amused -+ notaboek -+ notaboeken -+ notaboekje -+ notaboekjes -+ notariskosten -+ notariszoon -+ notatiebiljet -+ notatiebiljetten -+ notatieformulier -+ notawisselingen -+ notchback -+ notchbacks -+ notenbars -+ notendoppen -+ notenkrakers -+ notenleer -+ notenolie -+ noteringsovereenkomst -+ notitieboek -+ notitieboeken -+ notulanten -+ nougat -+ nouveaux riches -+ nova's -+ novae -+ novellebundels -+ novelles -+ novemberdag -+ novemberdagen -+ novembermiddag -+ nozempje -+ nozems -+ nuanceverschil -+ nuanceverschillen -+ nuchterlingen -+ nuclearisering -+ nuclei -+ nucleïnezuren -+ nucleïnezuur -+ nulhypothesen -+ nulhypotheses -+ nullijnen -+ nulnummer -+ nulnummers -+ nultarief -+ nultrap -+ numero's -+ numerootje -+ numerus clausus -+ numerus-fixusstudie -+ numismaat -+ numismaten -+ numismatici -+ numismaticus -+ nutriënten -+ nutstaken -+ nutsvoorziening -+ nutsvoorzieningen -+ nuttigheidsdenken -+ nv -+ nv's -+ nylongrondstof -+ nylonkoord -+ nylonkoorden -+ nymfomanen -+ o's -+ o'tje -+ o.a. -+ o.i. -+ o.m. -+ oasestad -+ obertje -+ obesitas -+ obia -+ obia's -+ obiaman -+ obiamannen -+ objectiveerde -+ objectiveringen -+ objectsubsidie -+ objectsubsidies -+ objecttaal -+ objecttalen -+ obligaatpartijen -+ obligatie-uitgifte -+ obligatie-uitgiften -+ obligatie-uitgiftes -+ obligatiegroeifonds -+ obligatiehandelaar -+ obligatiekoers -+ obligatiekoersen -+ obligatiemarkt -+ obligatiemarkten -+ obligatieomzet -+ obligatieportefeuille -+ obligo's -+ obs -+ obscurantisten -+ obscurantistische -+ observatie-eenheden -+ observatie-eenheid -+ observatiegraad -+ observatieonderzoek -+ observatievermogen -+ observatoren -+ obsessionele -+ obsolete -+ obstetrische -+ obstructieve -+ obussen -+ ocarina's -+ occidentalist -+ occidentalisten -+ occlusies -+ occlusieven -+ occultisten -+ oceaanbodem -+ oceaanbodems -+ oceaandepressies -+ oceaanfronten -+ oceaanstoring -+ oceaanstoringen -+ oceaanzeiler -+ oceaanzeilers -+ oceanografen -+ oceanografische -+ ocelot -+ ocelotten -+ ochtendappel -+ ochtenddauw -+ ochtendedities -+ ochtendjassen -+ ochtendlijk -+ ochtendlijke -+ ochtendlucht -+ ochtendmaaltijd -+ ochtendmaaltijden -+ ochtendnevels -+ ochtendploegen -+ ochtendpost -+ ochtendschemer -+ ochtenduur -+ ochtendwandeling -+ ochtendwandelingen -+ ochtendwandelingetje -+ ochtendzieke -+ ochtendzonnetje -+ octaangehalte -+ octavo's -+ octrooibescherming -+ octrooibureaus -+ octrooiraden -+ odieuze -+ odoriseerde -+ oedipale -+ oefenbaan -+ oefenbaantje -+ oefenballen -+ oefenbanen -+ oefenbom -+ oefenbommen -+ oefengranaat -+ oefengranaten -+ oefeninterland -+ oefeninterlands -+ oefenmatch -+ oefenmatchen -+ oefenmatches -+ oefenpop -+ oefenpoppen -+ oefenpotje -+ oefenpotjes -+ oefenschema's -+ oefensessie -+ oefensessies -+ oefentherapeuten -+ oefentijd -+ oefenvlucht -+ oefenvluchten -+ oelama -+ oelama's -+ oelema -+ oelema's -+ oelpan -+ oempa's -+ oenen -+ oenige -+ oenologen -+ oenologie -+ oenologisch -+ oenologische -+ oenoloog -+ oeps -+ oer-Engels -+ oer-Engelse -+ oer-Hollands -+ oer-Hollandse -+ oerbeginsel -+ oerbeginselen -+ oerconservatief -+ oerdom -+ oerdomme -+ oerdriften -+ oerelement -+ oerelementen -+ oerervaring -+ oergesteente -+ oergesteenten -+ oergesteentes -+ oerinstinct -+ oerinstincten -+ oerkrachten -+ oerkreet -+ oerkreten -+ oersaai -+ oerschreeuw -+ oerschreeuwen -+ oerstaat -+ oerstof -+ oerstoffen -+ oertype -+ oerwoudgeluid -+ oerwoudgeluiden -+ oerzonde -+ oesterbedden -+ oesterparels -+ oestersaus -+ oesterzwam -+ oesterzwammen -+ oestrogeensubstitutie -+ oetlul -+ oetlullen -+ oeverkruid -+ oeverloper -+ oeverlopers -+ oeverplant -+ oeververbindingen -+ oeverwal -+ oeverwallen -+ of all people -+ of all places -+ off the record -+ off-the-roadmotor -+ off-the-roadmotoren -+ off-the-roadmotors -+ offdays -+ offerbereidheid -+ offerfeest -+ offerfeesten -+ offerstenen -+ officemanager -+ officemanagers -+ officialiseerde -+ officialiseren -+ officiersclub -+ officiersopleiding -+ offline -+ offsetdrukkerij -+ offsetdrukkerijen -+ offsetdrukkers -+ offsetpersen -+ offsetprocedé -+ offshore-industrie -+ offshorebedrijf -+ offshoreoliewinning -+ ofiologie -+ ogelijk -+ ogelijke -+ ogenpotloden -+ ogenpotlood -+ ogenzwart -+ ohade -+ ohaën -+ oio -+ oio's -+ oioplaats -+ oioplaatsen -+ okapi's -+ okselfris -+ okselfrisse -+ okselstandig -+ okselstandige -+ okselstick -+ okselsticks -+ okseltruitje -+ oktoberdag -+ oktoberdagen -+ okétje -+ old boy network -+ old boys network -+ olewesjolem -+ olie-embargo's -+ olie-export -+ olie-import -+ olie-importen -+ olie-uitvoerend -+ olie-uitvoerende -+ oliebaden -+ oliebaron -+ oliebaronnen -+ oliebarons -+ oliebelang -+ oliebelangen -+ olieboeren -+ oliebrand -+ oliebranden -+ oliebranders -+ oliebrandstof -+ oliebrandstoffen -+ oliebronnen -+ oliecrises -+ oliecrisissen -+ oliedollar -+ oliedollars -+ oliedrum -+ oliedrums -+ oliefilms -+ oliefilters -+ oliegehalte -+ oliegehalten -+ oliegehaltes -+ oliegoed -+ oliehaarden -+ oliehandel -+ oliehaven -+ oliehavens -+ oliekachels -+ oliekranen -+ olielaag -+ olieland -+ olielanden -+ olielozing -+ olielozingen -+ oliemagnaat -+ oliemagnaten -+ oliemarkt -+ oliemarkten -+ oliemeters -+ olieopslagtank -+ olieopslagtanks -+ oliepak -+ oliepakken -+ olieplatform -+ olieplatforms -+ oliepomp -+ oliepompen -+ olieprijzen -+ olieproducerend -+ olieproducerende -+ olieproduct -+ olieput -+ olieputten -+ olieraffinaderijen -+ olieraffinage -+ olieramp -+ olierampen -+ oliereservoir -+ oliereservoirs -+ olieresidu -+ olieresiduen -+ olierijkdom -+ olierijkdommen -+ oliesardine -+ oliesardines -+ oliesjeiks -+ oliesoort -+ oliesoorten -+ oliespuiten -+ oliestaat -+ oliestaten -+ olietankers -+ olieterminal -+ olieterminals -+ olietoevoer -+ olietransport -+ olietransporten -+ olieverbruik -+ olieverfportret -+ olieverfschets -+ olieverfschetsen -+ olieverfschilderij -+ olieverfschilderijen -+ olieverontreiniging -+ olieverontreinigingen -+ olievlekwerking -+ olievogel -+ olievogels -+ oliewinning -+ oliezuur -+ olifantenhuid -+ olifantenpopulatie -+ olifantenpopulaties -+ olifantenverblijf -+ olifantsgras -+ olifantspoot -+ olifantspoten -+ oligarchen -+ oligocene -+ oligofrene -+ olijfboomgaard -+ olijfboomgaarden -+ ollekebolleke -+ ollekebollekes -+ olympiajollen -+ olympiër -+ olympiërs -+ omafiets -+ omafietsen -+ ombudsbureaus -+ ombuigingen -+ ombuigingsmaatregel -+ ombuigingsmaatregelen -+ ombuigingsoperatie -+ ombuigingsoperaties -+ ombuigingspakket -+ ombuigingsproblematiek -+ ombuigingsprogramma -+ omcirkeld -+ omcirkelde -+ omcirkelen -+ omdonderen -+ omdoping -+ omdwalen -+ omega's -+ omflikkeren -+ omgedonderd -+ omgedwaald -+ omgeflikkerd -+ omgekapt -+ omgekieperd -+ omgekiept -+ omgeklapt -+ omgekukeld -+ omgenaaid -+ omgeschreven -+ omgetrapt -+ omgevingsgeluid -+ omgevingsgeluiden -+ omgevingsinvloed -+ omgevingsinvloeden -+ omgevingskunst -+ omgevingslawaai -+ omgevlagd -+ omgrensde -+ omgrenzen -+ omgrenzing -+ omgrenzingen -+ omhooggaan -+ omhooggegaan -+ omhooggekeken -+ omhooggelopen -+ omhooggeslagen -+ omhooggewerkt -+ omhoogkijken -+ omhooglopen -+ omhoogslaan -+ omhoogvallen -+ omhoogvliegen -+ omhoogwerken -+ omhulling -+ omhullingen -+ omkaderd -+ omkaderde -+ omkaderen -+ omkadering -+ omkaderingsnorm -+ omkaderingsnormen -+ omkappen -+ omkeerbaarheid -+ omkeerschakelaar -+ omkeerschakelaars -+ omkiepen -+ omkieperen -+ omklappen -+ omknelling -+ omkoopaffaire -+ omkoopaffaires -+ omkooppraktijken -+ omkopingsaffaire -+ omkopingsaffaires -+ omkopingsschandaal -+ omkopingsschandalen -+ omkrullen -+ omkukelen -+ omlaaggaan -+ omlaaggegaan -+ omleggingen -+ omleidingen -+ omlijningen -+ omloopbanen -+ ommegaande -+ ommeland -+ ommelanden -+ ommelandse -+ omnaaien -+ omniumverzekering -+ omniumverzekeringen -+ omnummeren -+ omraming -+ omrekeningen -+ omrekentabel -+ omrekentabellen -+ omroepbericht -+ omroepberichten -+ omroepbijdragen -+ omroepcentra -+ omroepcentrum -+ omroepinstallaties -+ omroepkoren -+ omroepsatelliet -+ omroepsatellieten -+ omroepwetten -+ omroepzender -+ omroepzenders -+ omscholingsprogramma -+ omscholingsprogramma's -+ omsingelingspolitiek -+ omslagartikelen -+ omslagbelasting -+ omslagillustratie -+ omslagpunt -+ omslagtitels -+ omslagverhalen -+ omsnoeren -+ omspeelde -+ omspeling -+ omspelingen -+ omstaander -+ omstaanders -+ omstander -+ omtrappen -+ omtreklijn -+ omtreklijnen -+ omvademing -+ omvergeluld -+ omvergeschoten -+ omvergeslagen -+ omvergooien -+ omverlopen -+ omverlullen -+ omverschieten -+ omverslaan -+ omvlaggen -+ omvormingen -+ omwentelingskegel -+ omwentelingskegels -+ omwolken -+ omzeggens -+ omzeiling -+ omzetderving -+ omzetverhoging -+ omzetvermindering -+ omzetvolume -+ omzwaaier -+ omzwaaiers -+ on speaking terms -+ on the rocks -+ on-Amerikaans -+ on-Amerikaanse -+ on-Bijbels -+ on-Bijbelse -+ on-Duits -+ on-Duitse -+ on-Engels -+ on-Engelse -+ on-Europees -+ on-Europese -+ on-Frans -+ on-Franse -+ on-Hollands -+ on-Hollandse -+ on-Joods -+ on-Joodse -+ onaangebroken -+ onaangekondigde -+ onaangemelde -+ onaangepastheid -+ onaangevochten -+ onaanraakbaar -+ onaanraakbaarheid -+ onaanraakbare -+ onaantrekkelijkheid -+ onaanvaard -+ onaanvaardbaarheid -+ onaanvaarde -+ onaanvechtbaar -+ onaanvechtbare -+ onachterhaalbaar -+ onachterhaalbare -+ onafgebouwd -+ onafgebouwde -+ onafgedane -+ onafgedekt -+ onafgedekte -+ onafgewende -+ onafgezien -+ onafhankelijkheidsbewegingen -+ onafhankelijkheidsfeesten -+ onafhankelijkheidsstrijd -+ onafhankelijkheidsverdrag -+ onafheid -+ onaflosbaar -+ onaflosbare -+ onafweerbaar -+ onafweerbare -+ onafwendbaarheid -+ onaneerde -+ onanisten -+ onartistiek -+ onartistieke -+ onbaatzuchtigheid -+ onbalans -+ onbedenkelijk -+ onbedenkelijke -+ onbederfelijk -+ onbederfelijke -+ onbedrukt -+ onbedwongen -+ onbegaafd -+ onbegaafde -+ onbegaan -+ onbegeleide -+ onbegraven -+ onbegrijpelijkheden -+ onbegrijpend -+ onbegrijpende -+ onbegroeid -+ onbegroeide -+ onbehaarde -+ onbehagelijk -+ onbehagelijke -+ onbehandelbaar -+ onbehandelbare -+ onbehandeld -+ onbehandelde -+ onbeheersbaar -+ onbeheersbaarheid -+ onbeheersbare -+ onbeheerster -+ onbehoedzaam -+ onbehoedzame -+ onbekeerd -+ onbekeerde -+ onbekendheden -+ onbeklemtoond -+ onbeklemtoonde -+ onbeklimbaar -+ onbeklimbare -+ onbekommerdheid -+ onbekoorlijk -+ onbekoorlijke -+ onbeladen -+ onbelangrijkheden -+ onbeleefderik -+ onbeleefderiken -+ onbelicht -+ onbelichte -+ onbeloond -+ onbeloonde -+ onbemerkte -+ onbemiddelbaar -+ onbemiddelbare -+ onbeminde -+ onbenaderbaar -+ onbenaderbare -+ onbenoembaar -+ onbenoembare -+ onbeplant -+ onbeplante -+ onberedeneerbare -+ onbeschilderd -+ onbeschilderde -+ onbeschofterik -+ onbeschofteriken -+ onbeschrijfbare -+ onbeschutte -+ onbesneden -+ onbespeelbaar -+ onbespeelbare -+ onbespeeld -+ onbespeelde -+ onbespied -+ onbespiede -+ onbespreekbaar -+ onbespreekbare -+ onbestaand -+ onbestaande -+ onbestraft -+ onbestrafte -+ onbestrate -+ onbestuurbaarheid -+ onbetaalbaarheid -+ onbeteugeld -+ onbeteugelde -+ onbetrokkenheid -+ onbetrouwbaarder -+ onbetrouwbaarst -+ onbevestigd -+ onbewapend -+ onbewapende -+ onbewogenheid -+ onbewoonbaarheidsverklaringen -+ onbuigzaamheid -+ oncogen -+ oncogenen -+ oncologen -+ oncologische -+ onconstitutioneel -+ onconstitutionele -+ oncontroleerbaarheid -+ ondeelbaarheidsgedachte -+ ondenkbeeldig -+ ondenkbeeldige -+ onder ede -+ verwerpen -+ onderbed -+ onderbedden -+ onderbedeeld -+ onderbedeelde -+ onderbeet -+ onderbelichten -+ onderbenut -+ onderbenutte -+ onderbenutten -+ onderbesteding -+ onderbestedingen -+ onderbeten -+ onderbezette -+ onderblad -+ onderbladen -+ onderbreker -+ onderbrekers -+ onderbrenging -+ onderbuurmannen -+ onderbuurvrouwen -+ onderchef -+ onderchefs -+ ondercurateleplaatsing -+ ondercuratelestelling -+ onderdekse -+ onderdelenmagazijn -+ onderdelenpakket -+ onderdelenpakketten -+ onderdeurtjes -+ onderdirectoraat -+ onderdirectoraten -+ onderdrukkingsapparaat -+ onderdrukkingsinstrument -+ onderdrukkingsmechanisme -+ onderdrukkingsmechanismen -+ onderduikadressen -+ onderduikperiode -+ onderduiktijd -+ onderduimse -+ ondergebitten -+ ondergedeelten -+ ondergedeeltes -+ ondergekotst -+ ondergespoten -+ ondergevel -+ ondergevels -+ ondergewerkt -+ onderhaar -+ onderhandelbaar -+ onderhandelbare -+ onderhandelingsakkoord -+ onderhandelingsklimaat -+ onderhandelingspartner -+ onderhandelingspartners -+ onderhandelingsposities -+ onderhandelingsronde -+ onderhandelingsronden -+ onderhandelingsrondes -+ onderhandelingsstrategie -+ onderhandelingstafels -+ onderhandelingstechniek -+ onderhandelingsvoorstel -+ onderhorigheden -+ onderhouder -+ onderhouders -+ onderhoudsarm -+ onderhoudsarme -+ onderhoudsbedrijven -+ onderhoudsdoses -+ onderhoudsdosis -+ onderhoudsdosissen -+ onderhoudsplichten -+ onderhoudsplichtige -+ onderhoudsplichtigen -+ onderhoudsploeg -+ onderhoudsploegen -+ onderhoudstermijnen -+ onderhoudsvriendelijk -+ onderhoudsvriendelijke -+ onderhoudswerken -+ onderinspecteur -+ onderinspecteurs -+ onderkleden -+ onderkleed -+ onderknuppel -+ onderknuppels -+ onderkoeld -+ onderkoelen -+ onderkoelingsverschijnselen -+ onderkomens -+ onderkop -+ onderkoppen -+ onderkotsen -+ onderkruiers -+ onderlaatst -+ onderlakens -+ onderlichamen -+ onderlijntje -+ onderminister -+ onderministers -+ ondernemersgeest -+ ondernemersgewijs -+ ondernemersgewijze -+ ondernemersinitiatieven -+ ondernemerslobby -+ ondernemersrisico -+ ondernemerstalent -+ ondernemings-cao -+ ondernemings-cao's -+ ondernemingsgewijs -+ ondernemingsorganisatie -+ ondernemingsraadvergadering -+ ondernemingsraadvergaderingen -+ ondernemingsrecht -+ onderneminkje -+ onderpuien -+ onderscheidenlijke -+ onderschikken -+ onderschikt -+ onderschikte -+ onderschip -+ ondersecretaris -+ ondersecretaris-generaal -+ ondersecretarissen -+ ondershands -+ ondershandse -+ onderslagen -+ ondersoorten -+ onderspanning -+ onderspitten -+ onderspuiten -+ onderstam -+ onderstammen -+ onderstations -+ ondersteuningspunten -+ ondersteuningsteam -+ ondersteuningsteams -+ onderstuurde -+ ondertand -+ ondertanden -+ ondertapijten -+ ondertas -+ ondertassen -+ ondertekeningsceremonie -+ ondertiteld -+ ondertitelde -+ ondertitelen -+ ondertitelingen -+ ondertoezichtstellingen -+ ondertonen -+ ondertunneld -+ ondertunnelde -+ ondertunnelen -+ ondertunneling -+ onderuitgaan -+ onderuitgegleden -+ onderuitglijden -+ onderuithalen -+ onderuitzakken -+ onderverhuurders -+ onderverzekerde -+ ondervloeren -+ onderwaardeerde -+ onderwaterarcheologie -+ onderwatercamera's -+ onderwaterfoto -+ onderwaterfoto's -+ onderwatergedeelten -+ onderwatergedeeltes -+ onderwaterklokken -+ onderwatermicrofoon -+ onderwatermicrofoons -+ onderwaterschepen -+ onderwaterschip -+ onderwatertunnel -+ onderwatertunnels -+ onderwereldbaas -+ onderwereldfiguren -+ onderwereldkoning -+ onderwerk -+ onderwerken -+ onderwijsachterstandsbeleid -+ onderwijsadviescentra -+ onderwijsbegroting -+ onderwijsbestel -+ onderwijsbevoegdheden -+ onderwijsdeskundige -+ onderwijsdeskundigen -+ onderwijsinspecties -+ onderwijsinstellingen -+ onderwijsinstituten -+ onderwijsinstituut -+ onderwijsleerplan -+ onderwijsleerplannen -+ onderwijsnet -+ onderwijsondersteunend -+ onderwijspersoneel -+ onderwijspolitiek -+ onderwijsraad -+ onderwijsraden -+ onderwijsrecht -+ onderwijsschepen -+ onderwijsschepenen -+ onderwijssociologen -+ onderwijssocioloog -+ onderwijsstaking -+ onderwijsvakbond -+ onderwijsvakbonden -+ onderwijsvakorganisatie -+ onderwijsvoorrangsbeleid -+ onderwijsvoorziening -+ onderwijsvoorzieningen -+ onderwijswetgeving -+ onderwijswinkel -+ onderwijswinkels -+ onderwijzersdiploma's -+ onderzeebootjager -+ onderzeebootjagers -+ onderzetters -+ onderzoekbureau -+ onderzoekbureaus -+ onderzoekersopleiding -+ onderzoekgegeven -+ onderzoekgegevens -+ onderzoekkamer -+ onderzoekkamers -+ onderzoekresultaat -+ onderzoekresultaten -+ onderzoeksassistent -+ onderzoeksassistenten -+ onderzoekscholen -+ onderzoekschool -+ onderzoeksgegeven -+ onderzoeksgroep -+ onderzoeksgroepen -+ onderzoeksobjecten -+ onderzoeksopzetten -+ onderzoeksrapporten -+ onderzoeksschip -+ onderzoeksscholen -+ onderzoeksstation -+ onderzoeksstations -+ onderzoekstation -+ onderzoekstations -+ onderzoekstechniek -+ onderzoekverslag -+ onderzoekverslagen -+ ondeskundigheden -+ ondeugdzaam -+ ondeugdzame -+ ondoofbaar -+ ondoofbare -+ ondoorzichtigheden -+ ondramatisch -+ ondramatische -+ ondrinkbare -+ one-issuepartij -+ one-issuepartijen -+ oneconomischer -+ oneerbiedige -+ oneerbiedigheid -+ oneervolle -+ oneliners -+ onemanshows -+ onenightstand -+ onenightstands -+ onera -+ onethische -+ onetouchvoetbal -+ onevenredigheden -+ onevenredigheid -+ onevenwicht -+ onevenwichtigheden -+ onewayscreen -+ onewayscreens -+ onewomanshow -+ onewomanshows -+ onfair -+ onfaire -+ onfatsoen -+ onflatteus -+ onflatteuze -+ onfunctioneel -+ onfunctionele -+ ongaar -+ ongare -+ ongastvrije -+ ongeaccepteerd -+ ongeaccepteerde -+ ongeautoriseerd -+ ongeautoriseerde -+ ongebakken -+ ongebleekte -+ ongeblust -+ ongeboeid -+ ongeboeide -+ ongeborene -+ ongeborenen -+ ongebrand -+ ongebrande -+ ongebundeld -+ ongebundelde -+ ongeciviliseerd -+ ongeciviliseerde -+ ongeclausuleerd -+ ongeclausuleerde -+ ongecomplexeerd -+ ongecomplexeerde -+ ongecompliceerdheid -+ ongeconcentreerd -+ ongeconcentreerde -+ ongeconditioneerd -+ ongeconditioneerde -+ ongecultiveerd -+ ongecultiveerde -+ ongedacht -+ ongedeeldheid -+ ongedesemd -+ ongedesemde -+ ongediertebestrijder -+ ongediertebestrijding -+ ongedifferentieerd -+ ongedifferentieerde -+ ongedoopt -+ ongedoopte -+ ongedoubleerd -+ ongedoubleerde -+ ongedragen -+ ongeestig -+ ongeestige -+ ongefilterd -+ ongefilterde -+ ongeforceerd -+ ongeforceerde -+ ongefundeerd -+ ongefundeerde -+ ongegist -+ ongegiste -+ ongeglazuurd -+ ongehaast -+ ongehaaste -+ ongehavend -+ ongehavende -+ ongehonoreerd -+ ongehonoreerde -+ ongehuicheld -+ ongekamd -+ ongekerstend -+ ongekerstende -+ ongekozen -+ ongekroond -+ ongekwalificeerd -+ ongekwalificeerde -+ ongelaagd -+ ongelaagde -+ ongelakt -+ ongelakte -+ ongelede -+ ongeleed -+ ongeleid -+ ongeleide -+ ongeletterden -+ ongeletterdheid -+ ongeliefd -+ ongeliefde -+ ongelode -+ ongelood -+ ongelovige thomas -+ ongelukkigheid -+ ongeluksjaar -+ ongeluksjaren -+ ongelukstijding -+ ongelukstijdingen -+ ongemalen -+ ongematteerd -+ ongemeende -+ ongemonteerd -+ ongemonteerde -+ ongemotoriseerd -+ ongemotoriseerde -+ ongeneesljik -+ ongepaard -+ ongepaarde -+ ongepaneerd -+ ongepaneerde -+ ongepeld -+ ongepelde -+ ongeplaatst -+ ongeplaatste -+ ongepland -+ ongeplande -+ ongeplaveid -+ ongeplaveide -+ ongepolijst -+ ongepolijste -+ ongeprepareerd -+ ongeprepareerde -+ ongerealiseerd -+ ongerealiseerde -+ ongerechtvaardigde -+ ongeregistreerd -+ ongeregistreerde -+ ongereglementeerde -+ ongereguleerd -+ ongereguleerde -+ ongerekende -+ ongeroerde -+ ongesausd -+ ongesausde -+ ongesaust -+ ongesauste -+ ongescheiden -+ ongeschminkt -+ ongeschminkte -+ ongeslachtelijke -+ ongeslepen -+ ongesluierd -+ ongesluierde -+ ongestreken -+ ongestuurd -+ ongestuurde -+ ongetraind -+ ongetrainde -+ ongetrooste -+ ongeuit -+ ongeuite -+ ongevaccineerd -+ ongevaccineerde -+ ongevaccineerden -+ ongevallenpolissen -+ ongevallenraad -+ ongevallenraden -+ ongevallenrisico -+ ongevallenrisico's -+ ongevallenstatistiek -+ ongevallenstatistieken -+ ongewettigd -+ ongewettigde -+ ongezegd -+ ongezegde -+ ongeziene -+ ongezoet -+ ongezoete -+ ongeëmancipeerd -+ ongeëmancipeerde -+ ongeëmotioneerde -+ ongeïdentificeerd -+ ongeïdentificeerde -+ ongeïnformeerd -+ ongeïnformeerde -+ ongeïnspireerd -+ ongeïnspireerde -+ ongrijpbaarheid -+ ongrondwettelijk -+ ongrondwettelijke -+ onhaalbaarheid -+ onharmonisch -+ onharmonische -+ onheilsboodschap -+ onheilsboodschappen -+ onheilsprofeet -+ onheilsprofeten -+ onheilstijding -+ onheilstijdingen -+ onhelder -+ onheldere -+ onhelderheid -+ onherhaalbare -+ onhistorisch -+ onhistorische -+ onhoffelijke -+ oningewijd -+ oningewijde -+ onjoods -+ onjoodse -+ onkenbaar -+ onkenbare -+ onkerkelijkheid -+ onkerks -+ onkerkse -+ onkinderlijk -+ onkinderlijke -+ onklopbaar -+ onklopbare -+ onkostenregeling -+ onkritisch -+ onkritische -+ onkruidbestrijder -+ onkruidbestrijders -+ onkruidkunde -+ onkruidverdelger -+ onkruidverdelgers -+ onkruidzaad -+ onkruidzaden -+ onleuk -+ onleuke -+ onliberaal -+ onliberale -+ onlinecatalogi -+ onlinecatalogus -+ onlinecatalogussen -+ onlineshopping -+ onlineverbinding -+ onlineverbindingen -+ onliterair -+ onliteraire -+ onlogica -+ onlustgevoel -+ onlustgevoelens -+ onmannelijk -+ onmededeelbaar -+ onmededeelbare -+ onmodieus -+ onmodieuze -+ onmuzikale -+ onnadenkendheden -+ onnadrukkelijke -+ onnauwkeurigheidsmarge -+ onnuttig -+ onnuttige -+ onofficieel -+ onofficiële -+ onomkeerbaarheid -+ onontbindbaar -+ onontbindbare -+ onontdekt -+ onontdekte -+ onontkoombaarheid -+ onontploft -+ onontplofte -+ onontsloten -+ onontvreemdbare -+ onontwijkbare -+ onoorbare -+ onopgeleid -+ onopgeleide -+ onoplosbaarheid -+ onopmerkelijk -+ onopmerkelijke -+ onoprechter -+ onoprechtheden -+ onoprechtst -+ onopvallendheid -+ onopzegbaar -+ onopzegbare -+ onoverdekt -+ onoverdekte -+ onoverkoombaar -+ onoverkoombare -+ onovertrefbaar -+ onpatriottisch -+ onpatriottische -+ onpersonen -+ onpersoon -+ onpersoonlijkheid -+ onpolitiek -+ onpolitieke -+ onpopulair -+ onpopulaire -+ onpopulairst -+ onpopulariteit -+ onpretentieus -+ onpretentieuze -+ onrechtzinnig -+ onrechtzinnige -+ onregeerbaarheid -+ onregeerbare -+ onreglementair -+ onreglementaire -+ onrepresentatief -+ onrepresentatieve -+ onroerendgoedbelasting -+ onroerendgoedbezit -+ onroerendgoedmaatschappij -+ onroerendgoedonderneming -+ onroerendgoedtransactie -+ onroerendgoedtransacties -+ onromantische -+ onrustgebied -+ onrustgebieden -+ onrustwekkend -+ onrustwekkende -+ onsamendrukbaar -+ onsamendrukbare -+ onsamenhangendheid -+ onsentimenteel -+ onsentimentele -+ onserieus -+ onserieuze -+ onshore -+ onsolidair -+ onsolidaire -+ onspectaculair -+ onspectaculaire -+ onstabiliteit -+ onstilbaar -+ onsubtiel -+ onsubtiele -+ onsuccesvol -+ onsuccesvolle -+ onsympathieker -+ onsympathiekst -+ ontastbaar -+ ontastbare -+ ontbeend -+ ontbeende -+ ontbijtbuffet -+ ontbijtlakens -+ ontbijtshows -+ ontbijtspek -+ ontbijttelevisie -+ ontbijtzaal -+ ontbijtzalen -+ ontbindingsproces -+ ontbindingsverschijnselen -+ ontbindingsverzoeken -+ ontbrandingstemperaturen -+ ontcijferbaar -+ ontcijferbare -+ ontdekkingsreizigster -+ ontdubbeld -+ ontdubbelde -+ ontdubbelen -+ ontduikingsmogelijkheid -+ ontegenzeggelijke -+ onteigeningsprocedure -+ onteigeningsprocedures -+ onteigeningswet -+ onteigeningswetten -+ ontevredene -+ ontevredenen -+ ontgassing -+ ontgift -+ ontgiften -+ ontgiftte -+ ontgraat -+ ontgraatte -+ ontgraten -+ onthaalmoeder -+ onthaalmoeders -+ onthaalouder -+ onthaalouders -+ onthaalvader -+ onthaalvaders -+ onthaast -+ onthaasten -+ onthaastte -+ onthardde -+ ontharders -+ onthechtheid -+ onthechting -+ ontheemdendocument -+ ontheemdenpas -+ ontheemdenregeling -+ ontheemdenstatus -+ ontheemding -+ ontheffingsverzoek -+ ontheffingsverzoeken -+ onthoornd -+ onthoornde -+ onthoorningscampagne -+ onthuller -+ onthullers -+ onthutsing -+ ontideologisering -+ ontindividualisering -+ ontkalkingen -+ ontkenner -+ ontkenners -+ ontkerkelijkt -+ ontkerkelijkte -+ ontketening -+ ontkieming -+ ontkoppelingsbesluit -+ ontkroesd -+ ontkroesde -+ ontkroezen -+ ontluchtingspijp -+ ontluchtte -+ ontmaakt -+ ontmaakte -+ ontmaken -+ ontmengd -+ ontmengde -+ ontmengen -+ ontmenging -+ ontmenselijken -+ ontmenselijking -+ ontmenselijkt -+ ontmenselijkte -+ ontmijnd -+ ontmijnde -+ ontmijnen -+ ontmijningsdienst -+ ontmijningsdiensten -+ ontmoetingsavonden -+ ontmoetingscentra -+ ontmoetingsdag -+ ontmoetingsdagen -+ ontmoetingspunten -+ ontmythologiseerd -+ ontmythologiseerde -+ ontmythologiseren -+ ontmythologisering -+ ontneming -+ ontoepasselijk -+ ontoepasselijke -+ ontoerekeningsvatbaarheid -+ ontoeschietelijke -+ ontpitte -+ ontploffinkje -+ ontpolderen -+ ontregeling -+ ontremd -+ ontremde -+ ontroestte -+ ontronding -+ ontrondingen -+ ontruimingsalarm -+ ontruimingsplan -+ ontruimingsplannen -+ ontschotting -+ ontsiering -+ ontslagaanzegging -+ ontslagname -+ ontslagnemend -+ ontslagnemende -+ ontslagronde -+ ontslagronden -+ ontslagrondes -+ ontsluitingsweg -+ ontsluitingswegen -+ ontsnappingspogingen -+ ontsnappingsroute -+ ontsnappingsroutes -+ ontsnappingssnelheden -+ ontspannenheid -+ ontspanners -+ ontspanningscentra -+ ontspanningscentrum -+ ontspanningsliteratuur -+ ontstaanswijze -+ ontsteeg -+ ontstekers -+ ontstekingscel -+ ontstekingscellen -+ ontstekingsmechanismen -+ ontstekingsproces -+ ontstekingsreactie -+ ontstekingsreacties -+ ontstekingsverschijnselen -+ ontstekinkje -+ ontstemmingen -+ ontstijgen -+ ontstoppers -+ ontuchtzaak -+ ontvangkantoor -+ ontvangkantoren -+ ontvangstapparatuur -+ ontvangstbevestigingen -+ ontvangstcomité -+ ontvangstcomités -+ ontvangsthallen -+ ontvangststation -+ ontvangststations -+ ontvangstzaal -+ ontvangstzalen -+ ontvettingsmiddel -+ ontvlechten -+ ontvlechting -+ ontvlocht -+ ontvlochten -+ ontvloeid -+ ontvloeide -+ ontvloeien -+ ontvlokken -+ ontvlokt -+ ontvlokte -+ ontvoeringszaak -+ ontvoeringszaken -+ ontvoogdingsstrijd -+ ontvriezen -+ ontvroor -+ ontvroren -+ ontwapeningsakkoord -+ ontwapeningsonderhandeling -+ ontwapeningsonderhandelingen -+ ontwapeningsverdrag -+ ontwapeningsverdragen -+ ontwapeningswedloop -+ ontwenningsklinieken -+ ontwenningskuren -+ ontwerpdecreet -+ ontwerperscollectief -+ ontwerphandvest -+ ontwerplandbouwakkoord -+ ontwerplijst -+ ontwerpnota -+ ontwerpovereenkomst -+ ontwerpschets -+ ontwerpschetsen -+ ontwerptechnisch -+ ontwerptechnische -+ ontwerptekst -+ ontwerpteksten -+ ontwerpverdrag -+ ontwerpverdragen -+ ontwerpverklaring -+ ontwerpvoorstel -+ ontwerpvoorstellen -+ ontwerpwet -+ ontwijkingen -+ ontwikkelbak -+ ontwikkelbakken -+ ontwikkelingsachterstand -+ ontwikkelingsbanken -+ ontwikkelingsbiologie -+ ontwikkelingseconomen -+ ontwikkelingseconoom -+ ontwikkelingsfasen -+ ontwikkelingsfonds -+ ontwikkelingsgebied -+ ontwikkelingsgeld -+ ontwikkelingsgelden -+ ontwikkelingshulpbeleid -+ ontwikkelingsmogelijkheden -+ ontwikkelingsmogelijkheid -+ ontwikkelingspeil -+ ontwikkelingssteun -+ ontwikkelingsstoornis -+ ontwikkelingsstoornissen -+ ontwikkelingstheorie -+ ontwikkelingstheorieën -+ ontwikkelpapier -+ ontwikkeltanks -+ ontwormd -+ ontwormde -+ ontwormen -+ ontworteldheid -+ ontworteling -+ ontzanding -+ ontzeggingen -+ ontziltte -+ ontzippen -+ ontzipt -+ ontzipte -+ ontzuild -+ ontzuilde -+ ontzuilen -+ ontzwaveld -+ ontzwavelde -+ ontzwavelen -+ ontzwaveling -+ ontzwavelingsinstallatie -+ ontzwavelingsinstallaties -+ onuitgebracht -+ onuitgebrachte -+ onuitgenodigd -+ onuitgenodigde -+ onuitgepakt -+ onuitgepakte -+ onuitgeslapen -+ onus -+ onvaderlandslievend -+ onvaderlandslievende -+ onveiligheidsgevoelens -+ onverbindende -+ onverbrand -+ onverbrande -+ onverenigd -+ onverenigde -+ onverheeld -+ onverheelde -+ onverhoord -+ onverhuld -+ onverhulde -+ onverkrijgbaar -+ onverkrijgbare -+ onverrijkt -+ onverrijkte -+ onversierd -+ onversierde -+ onvertakt -+ onvertakte -+ onvervormd -+ onvervormde -+ onvervulbaar -+ onvervulbare -+ onvervuldheid -+ onverwarmd -+ onverwarmde -+ onverwerkbaar -+ onverwerkbare -+ onverwerkt -+ onverwerkte -+ onverwisselbaar -+ onverwisselbare -+ onverwoordbaar -+ onverwoordbare -+ onverzadigbaarheid -+ onverzadigde -+ onverzekerbaar -+ onverzekerbare -+ onverzoenbaar -+ onverzoenbare -+ onvolledigheden -+ onvoorstelbaarheid -+ onvoorzienbaar -+ onvrijheden -+ onvrolijk -+ onvrolijke -+ onweersachtige -+ onweersbeestjes -+ onwenselijkheid -+ onwerelds -+ onwereldse -+ onwerkbaarheid -+ onwerkelijkheid -+ onwetmatige -+ onzegbare -+ onzekerheidsfactor -+ onzekerheidsmarge -+ onzekerheidsmarges -+ onzelieveheersbeestjes -+ onzinverhaal -+ onzinverhalen -+ onzorgvuldigheden -+ oog-handcoördinatie -+ oogafwijkingen -+ oogappeltje -+ ooggetuigenverklaring -+ ooggetuigenverklaringen -+ ooggetuigenverslagen -+ oogkamer -+ oogkamers -+ oogkleur -+ ooglapje -+ ooglapjes -+ ooglens -+ ooglenzen -+ oogletsel -+ oogluikende -+ oogmeetkunde -+ oogmetingen -+ oogoperaties -+ oogprothese -+ oogprothesen -+ oogprotheses -+ oogstjaren -+ oogstmachine -+ oogstmachines -+ oogstraming -+ oogstramingen -+ oogstschade -+ oogstverloven -+ oogvocht -+ oogwimper -+ oogzalf -+ oogzalven -+ ooibos -+ ooibossen -+ oorbelletje -+ oorclip -+ oorclips -+ oordeelonthouding -+ oorgetuige -+ oorgetuigen -+ oorkondes -+ oorlogsbegraafplaats -+ oorlogsdaad -+ oorlogsdaden -+ oorlogsdoeleinden -+ oorlogseconomie -+ oorlogsellende -+ oorlogsfilms -+ oorlogsfotograaf -+ oorlogsfotografen -+ oorlogsgebied -+ oorlogsgebieden -+ oorlogsgeneratie -+ oorlogsgetroffene -+ oorlogsgetroffenen -+ oorlogsgraf -+ oorlogsgraven -+ oorlogsgruwelen -+ oorlogskerkhof -+ oorlogsmachine -+ oorlogsmachines -+ oorlogsmisdaad -+ oorlogsmisdrijf -+ oorlogsmisdrijven -+ oorlogsmoe -+ oorlogsmoeë -+ oorlogsmonumenten -+ oorlogsmuseum -+ oorlogsomstandigheden -+ oorlogspartij -+ oorlogspartijen -+ oorlogspensioen -+ oorlogspolitiek -+ oorlogspsychosen -+ oorlogspsychoses -+ oorlogsspelletje -+ oorlogsspelletjes -+ oorlogstribunalen -+ oorlogsverslaggeving -+ oorlogsveteraan -+ oorlogsveteranen -+ oorlogswinter -+ oorlogswinters -+ oorlogszucht -+ oorlogvoerend -+ oorlogvoerende -+ oorlogvoerenden -+ oorproppen -+ oorsprongsgebied -+ oortelefoon -+ oortelefoons -+ ooruil -+ ooruilen -+ oorzakelijkheden -+ oost -+ oost-westrichting -+ oost-westverbinding -+ oost-westverbindingen -+ oosterbuur -+ oosters-orthodox -+ oosters-orthodoxe -+ oostfrontstrijder -+ oostfrontstrijders -+ oostgrenzen -+ oostkanton -+ oostkantons -+ oostnoordoosten -+ oostzuidoosten -+ dievenpad -+ parttimebasis -+ uitleenbasis -+ wapengebied -+ janboerenfluitjes -+ op-en-neer -+ op-en-neren -+ opaalglas -+ opbeller -+ opbellers -+ opblaasboten -+ opbleken -+ opbollen -+ opbouwfase -+ opbouwfasen -+ opbouwfases -+ opbouworganen -+ opbouwsysteem -+ opbrengsthuis -+ opbrengsthuizen -+ opbrengstverlies -+ opdekken -+ opdelingen -+ opdienster -+ opdiensters -+ opdoffers -+ opdondertje -+ opdrachtfilm -+ opdrachthouder -+ opdrachthouders -+ opdrachtonderzoek -+ opdrachtwerk -+ opdreggen -+ opdroging -+ opduvel -+ opduvels -+ opduveltje -+ opdwarrelen -+ opeendringen -+ opeengedrongen -+ opeengeklemd -+ opeengevolgd -+ opeenklemmen -+ opeisbaarheid -+ openbaarvervoerkaart -+ openbaarvervoerkaarten -+ openbaarvervoermaatschappij -+ openbaarvervoerskaart -+ openbaarvervoerskaarten -+ openbaarvervoertarief -+ openbaarvervoertarieven -+ openboektentamen -+ openboektentamens -+ opendeurdagen -+ opendeurdienst -+ opendeurdiensten -+ openeinderegeling -+ openeindregeling -+ opengegooid -+ opengehangen -+ opengeschoten -+ opengesperd -+ opengespleten -+ opengeworpen -+ opengezwaaid -+ openhaardhout -+ openhangen -+ openhartchirurgie -+ openhartigheden -+ openhartoperatie -+ openhartoperaties -+ openingsconcert -+ openingsdata -+ openingsdatum -+ openingsdefilé -+ openingsgala -+ openingsgoal -+ openingskoersen -+ openingsnieuwtje -+ openingspartij -+ openingsrace -+ openingsraces -+ openingsscène -+ openingsspeechen -+ openingstijd -+ openingstoespraak -+ openingstoespraken -+ openingstreffer -+ openingsuur -+ openingsvoorstelling -+ openingswedstrijd -+ openingswedstrijden -+ openingswoorden -+ openingszetten -+ openingszitting -+ openlegging -+ openluchtbaden -+ openluchtconcert -+ openluchtconcerten -+ openluchtexpositie -+ openluchtfestival -+ openluchtfestivals -+ openluchtrecreatiebeleid -+ openluchtvoorstellingen -+ openluchtzwembaden -+ openschieten -+ opensperren -+ opensplijten -+ openwerken -+ openwerpen -+ openzwaaien -+ opera-aria -+ opera-aria's -+ opera-enscenering -+ opera-ensceneringen -+ opera-uitvoering -+ opera-uitvoeringen -+ operabele -+ operadebuut -+ operadirigent -+ operagezelschap -+ operagezelschappen -+ operahuis -+ operahuizen -+ operakoor -+ operakoren -+ operalibretto -+ operaorkest -+ operaorkesten -+ operaregie -+ operaregisseur -+ operaregisseurs -+ operarepertoire -+ operarol -+ operarollen -+ operaseizoen -+ operaster -+ operasterren -+ operateske -+ operatiegebied -+ operatiegebieden -+ operatiekamerpersoneel -+ operatiepatiënten -+ operatieplan -+ operatieplannen -+ operatietafels -+ operatiezaal -+ operatiezalen -+ operatiezusters -+ operavoorstelling -+ operavoorstellingen -+ operazaal -+ operazalen -+ operetteachtig -+ operetteachtige -+ operettefiguren -+ operettezanger -+ operettezangers -+ opflitsen -+ opfriscursus -+ opfriscursussen -+ opfrisverlof -+ opgavenformulier -+ opgavenformulieren -+ opgebleekt -+ opgebold -+ opgeboord -+ opgedekt -+ opgedregd -+ opgeflitst -+ opgegeild -+ opgegloeid -+ opgeilen -+ opgejuind -+ opgejut -+ opgeklonken -+ opgeknipt -+ opgekruld -+ opgeleukt -+ opgelierd -+ opgelierde -+ opgelikt -+ opgemieterd -+ opgenaaid -+ opgepiept -+ opgeschaald -+ opgeschoond -+ opgeschopt -+ opgeschoren -+ opgesodemieterd -+ opgestikt -+ opgestormd -+ opgestraald -+ opgestroomd -+ opgever -+ opgevlamd -+ opgevreeën -+ opgevroren -+ opgewipt -+ opgezuiverd -+ opgloeien -+ opgraver -+ opgravers -+ ophangslee -+ opheffingsnorm -+ opheffingsnormen -+ opheffingsuitverkopen -+ ophefmakend -+ ophefmakende -+ ophelderingspercentage -+ opinieartikel -+ opinieartikelen -+ opinieartikels -+ opiniecijfers -+ opinieleider -+ opinieleiders -+ opiniemaker -+ opiniemakers -+ opiniepeiler -+ opinieweekbladen -+ opjuinen -+ opkamertje -+ opkikkertjes -+ opklinken -+ opknapkosten -+ opknapper -+ opknappers -+ opknippen -+ opkomstcijfers -+ opkomstpercentage -+ opkomstpercentages -+ opkoopregeling -+ opkrullen -+ oplaadbaar -+ oplaadbare -+ oplaadtijd -+ oplagestijging -+ oplazer -+ oplazers -+ opleidingseis -+ opleidingspeil -+ opleuken -+ opleveringsdata -+ opleveringsdatums -+ oplevingen -+ oplikken -+ oplosser -+ oplossers -+ oplossingsgericht -+ oplossingsgerichte -+ oplossingspercentage -+ oplossingspercentages -+ oplossingsrichting -+ oplossinkje -+ opmaakredacteurs -+ opmaakredactie -+ opmaakredacties -+ opmaaksel -+ opmieter -+ opmieteren -+ opmieters -+ opnaaien -+ opname-unit -+ opname-units -+ opnameafdeling -+ opnameafdelingen -+ opnameapparatuur -+ opnamecapaciteit -+ opnameleider -+ opnameleiders -+ opnamestop -+ opnamestops -+ opnamestudio's -+ opneembaar -+ opneembare -+ opnemingsvermogen -+ opoefiets -+ opoefietsen -+ opofferingsgezindheid -+ opofferingsslagen -+ oponthouden -+ oppasmoeder -+ oppasmoeders -+ oppasprobleem -+ oppensioenstelling -+ oppepoperatie -+ oppeppakket -+ oppeppers -+ oppeppertje -+ opperbaas -+ oppergerechtshof -+ oppergod -+ opperherder -+ opperherders -+ opperkamerheer -+ opperkamerheren -+ opperkooplieden -+ opperkoopman -+ opperrabbinaat -+ opperrechters -+ opperstalmeester -+ opperstalmeesters -+ oppervlakte-eenheden -+ oppervlakte-eenheid -+ oppervlakte-infiltratie -+ oppervlaktebehandelingen -+ oppervlaktelaag -+ oppervlaktemaat -+ oppervlaktematen -+ oppervlaktestructuren -+ oppervlaktetemperatuur -+ oppervlaktewateren -+ opperwezen -+ opperwezens -+ oppiepen -+ oppositiebank -+ oppositiecoalitie -+ oppositiefractie -+ oppositiefracties -+ oppositiejaren -+ oppositiekamp -+ oppositiekringen -+ oppositiepers -+ oppuntstelling -+ oprekking -+ oprichtersfamilie -+ oprichtingsakte -+ oprichtingsakten -+ oprichtingsaktes -+ oprichtingsbijeenkomst -+ oprichtingsbijeenkomsten -+ oprichtingsverdrag -+ oprichtingsvergaderingen -+ oprichtsters -+ oproepkaart -+ oproepkaarten -+ oproepkracht -+ oproepkrachten -+ oprolbaar -+ oprolbare -+ oprotpremies -+ opruiend -+ opruimactie -+ opruimacties -+ opruimingscommando -+ opruimingsdienst -+ opruimploeg -+ opruimploegen -+ opruststelling -+ opruwen -+ opschalen -+ opschaling -+ opscheplepels -+ opscheren -+ opschoning -+ opschoppen -+ opslagbeurt -+ opslagbeurten -+ opslagmedia -+ opslagmogelijkheden -+ opslagmogelijkheid -+ opslagruimten -+ opslagsysteem -+ opslibbing -+ opslokking -+ opsodemieter -+ opsodemieteren -+ opsodemieters -+ opsommerig -+ opsommerige -+ opspatten -+ opsporingsactie -+ opsporingsacties -+ opsporingsambtenaren -+ opsporingsbeleid -+ opsporingsberichten -+ opsporingsbevoegdheden -+ opsporingsbevoegdheid -+ opsporingsbrigade -+ opsporingsbrigades -+ opsporingsmethode -+ opsporingsmethoden -+ opsporingsmethodes -+ opsporingsregister -+ opsporingsregisters -+ opsporingsteam -+ opsporingsteams -+ opsporingsvergunningen -+ opsporingswerk -+ opstaander -+ opstaanders -+ opstalverzekeringen -+ opstandelingenbeweging -+ opstandelingenleider -+ opstapper -+ opstappers -+ opstapplaats -+ opstapplaatsen -+ opstartdiskette -+ opstartdiskettes -+ opstartfase -+ opstartfasen -+ opstartfases -+ opstartprobleem -+ opstelletje -+ opstellingscommissie -+ opstellingscommissies -+ opstelwedstrijd -+ opstikken -+ opstormen -+ opstralen -+ opstromen -+ opstuiten -+ opstuwing -+ opstuwingen -+ optici -+ optie-index -+ optieaandeel -+ optieaandelen -+ optiepremie -+ optiepremies -+ optietransactie -+ optietransacties -+ optischevezelactiviteiten -+ optometristen -+ opulente -+ opvallenderwijs -+ opvanggezin -+ opvanggezinnen -+ opvangkamp -+ opvangkampen -+ opvangland -+ opvanglanden -+ opvangouder -+ opvangouders -+ opvangsysteem -+ opvangtehuis -+ opvangtehuizen -+ opvangvoorzieningen -+ opvlieger -+ opvliegerig -+ opvliegerige -+ opvliegers -+ opvliegingen -+ opvoedingsideaal -+ opvoedingsidealen -+ opvoedingsmethode -+ opvoedingsmethoden -+ opvoedingsmethodes -+ opvoedingsmoeilijkheden -+ opvoedingsmoeilijkheid -+ opvoedingspatroon -+ opvoedingsprobleem -+ opvoedingssysteem -+ opvolgersstaat -+ opvolgersstaten -+ opvolgerstaat -+ opvolgerstaten -+ opvolgingskwestie -+ opvolgingsprocedure -+ opvolgingsstrijd -+ opvolgmelk -+ opvriezen -+ opwaardeerkaart -+ opwaardeerkaarten -+ opwarmer -+ opwarmertje -+ opwarmertjes -+ opwarmronde -+ opwerkingsproces -+ opwindingen -+ opwippen -+ opzegger -+ opzeggers -+ opzetheling -+ opzichtertje -+ opzijgelegd -+ opzijgezet -+ opzijleggen -+ opzijschuiven -+ opzijzetten -+ opzoeking -+ opzoekingen -+ opzoekingswerk -+ opzwaaiend -+ opzwaaiende -+ or -+ or's -+ oral history -+ orang-oetangs -+ orangisme -+ oranje-blanje-bleu -+ oranjehemd -+ oranjehemden -+ oranjekleurig -+ oranjekleurige -+ oranjekoek -+ oranjekoeken -+ oranjerode -+ oranjerood -+ oratoren -+ oratorio's -+ orators -+ orchissen -+ ordebewaarders -+ ordehandhaver -+ ordehandhavers -+ ordehandhaving -+ ordeningsbeleid -+ ordeningsprincipe -+ orderontvangsten -+ orderpositie -+ orderstroom -+ orderverwerkingssysteem -+ ordetroepen -+ ordeverstoorder -+ ordeverstoringen -+ ordi -+ ordi's -+ ordinale -+ ordinanties -+ ordinantiën -+ ordinariaten -+ ordinarii -+ ordovicium -+ orenmaffia -+ orgaandonatie -+ orgaandonaties -+ orgaandonors -+ orgaanvlees -+ organel -+ organellen -+ organisatieadviseur -+ organisatieadviseurs -+ organisatiebureaus -+ organisatiecomité -+ organisatiecomités -+ organisatiedeskundige -+ organisatiedeskundigen -+ organisatiegraad -+ organisatieontwikkeling -+ organisatiepatronen -+ organisatiepatroon -+ organisatieschema's -+ organisatievermogens -+ organisatiewerk -+ organisatrices -+ organizer -+ organizers -+ orgasmes -+ orgastische -+ orgelbouw -+ orgelkasten -+ orgiastische -+ orgies -+ oribi -+ oribi's -+ oriëntaalse -+ oriëntale -+ oriëntalisme -+ oriëntalistische -+ oriëntatiebezoeken -+ oriëntatiecursus -+ oriëntatiecursussen -+ oriëntatiegraad -+ oriëntatieloop -+ oriëntatielopen -+ oriëntatienota -+ oriëntatievermogen -+ oriënteringen -+ orkaankracht -+ orkaansterkte -+ orkestbakken -+ orkestbegeleiding -+ orkestbezetting -+ orkestenplan -+ orkestklank -+ orkestklanken -+ orkestleden -+ orkestlid -+ orkestmuziek -+ orkestpartituren -+ orkestwerk -+ orkestwerken -+ ornamenteerde -+ orni -+ orni's -+ orpheusgrasmus -+ orpheusgrasmussen -+ orthodontisten -+ orthodox-christelijk -+ orthodox-christelijke -+ orthodox-communistisch -+ orthodox-communistische -+ orthodox-gereformeerd -+ orthodox-gereformeerde -+ orthodox-joods -+ orthodox-joodse -+ orthodox-protestants -+ orthodox-protestantse -+ orthodox-religieus -+ orthodox-religieuze -+ orthodoxt -+ orthomoleculaire -+ orthopedagogen -+ orthopedagoges -+ orthopedagogische -+ orthopeden -+ orthotheek -+ orthotheken -+ orwelliaans -+ orwelliaanse -+ oryxen -+ oscillografen -+ oscilloscopen -+ osloconfrontatie -+ ossenkar -+ ossenkopsturen -+ ossenkopstuur -+ ossentongen -+ ossenwagens -+ ossenworst -+ ossi -+ ossi's -+ ostensieve -+ ostentaties -+ osteoma -+ osteomata -+ otterde -+ otteren -+ oublie-ijzer -+ oublie-ijzers -+ oublies -+ oubolligheid -+ oud-Grieks -+ oud-Griekse -+ oud-Hollandse -+ oud-Indiëgangers -+ oud-Kamerleden -+ oud-Kamerlid -+ oud-Vlaams -+ oud-Vlaamse -+ oud-ambassadeurs -+ oud-bestuursleden -+ oud-collega's -+ oud-gevangenen -+ oud-griffiers -+ oud-kanseliers -+ oud-leden -+ oud-medewerkers -+ oud-medewerkster -+ oud-nazi's -+ oud-parlementariër -+ oud-parlementariërs -+ oud-politici -+ oud-staatssecretarissen -+ oud-verzetsstrijder -+ oud-verzetsstrijders -+ oud-wereldkampioenen -+ oudchristelijke -+ oudedagspensioen -+ oudedagsreserve -+ oudedagsreserves -+ oudedagsvoorzieningen -+ oudedagvoorzieningen -+ oudejaarsconference -+ oudejaarsdag -+ oudejaarsvereniging -+ ouder-kindrelatie -+ ouder-kindrelaties -+ ouderafhankelijkheid -+ ouderbijdrage -+ ouderbijdragen -+ ouderdagen -+ ouderdomsclausule -+ ouderdomsdeken -+ ouderdomsdekens -+ ouderdomsuitkeringen -+ ouderdomsverschijnselen -+ ouderdomswetten -+ ouderdomsziekte -+ ouderdomsziekten -+ ouderdomsziektes -+ ouderejaarsstudent -+ ouderejaarsstudenten -+ ouderenhuisvesting -+ ouderenorganisatie -+ ouderenregeling -+ ouderenwerk -+ ouderenzorg -+ oudergesprek -+ oudergesprekken -+ ouderorganisatie -+ ouderraad -+ ouderraden -+ ouderslaapkamer -+ ouderslaapkamers -+ oudervereniging -+ ouderverenigingen -+ oudewijvenknoop -+ oudewijvenknopen -+ oudewijvenkoek -+ oudgast -+ oudgasten -+ oudgereformeerd -+ oudgereformeerde -+ oudkatholicisme -+ oudkatholiek -+ oudkatholieke -+ oudkatholieken -+ oudkomer -+ oudkomers -+ oudmodisch -+ oudmodische -+ oudpapieractie -+ oudpapieracties -+ oudpapierprijs -+ oudpapierprijzen -+ oudroze -+ oudvaderlandse -+ out of the blue -+ outdoor -+ outdoorkledij -+ outdoorkleding -+ outdoortoernooi -+ outdoortoernooien -+ outdoortornooi -+ outdoortornooien -+ outdoorwedstrijd -+ outdoorwedstrijden -+ outlaws -+ outplacementbureau -+ outplacementbureaus -+ outplacementregeling -+ outputfinanciering -+ ouwe-jongens-krentenbrood -+ ouweheer -+ ouwehoerde -+ ouwelui -+ ouwelullendag -+ ouwelullendagen -+ ouweneelde -+ ouwenelen -+ ov -+ ov-jaarkaart -+ ov-jaarkaarten -+ ov-kaart -+ ov-kaarten -+ ov-studentenjaarkaart -+ ov-studentenjaarkaarten -+ ov-studentenkaart -+ ov-studentenkaarten -+ ovaalvormig -+ ovaalvormige -+ ovariums -+ ovationele -+ ovenhandschoen -+ ovenhandschoenen -+ ovenschoteltje -+ ovenvast -+ ovenvaste -+ ovenvers -+ ovenverse -+ ovenvisje -+ ovenvisjes -+ ovenwant -+ ovenwanten -+ overaanbod -+ overallconclusie -+ overallconclusies -+ overalldrager -+ overalldragers -+ overbeet -+ overbejaging -+ overbelastte -+ overbemesting -+ overbeten -+ overbewinkeling -+ overbezorgd -+ overbieden -+ overblijfkracht -+ overblijfkrachten -+ overblijflokalen -+ overblijfregeling -+ overblijfruimte -+ overblijfruimten -+ overblijfruimtes -+ overbloezend -+ overbloezende -+ overboden -+ overbood -+ overbruggingsfinanciering -+ overbruggingshulp -+ overbruggingstoelage -+ overbruggingstoelagen -+ overbruggingstoelages -+ overcompensaties -+ overcompenseerde -+ overcompenseren -+ overdoseringen -+ overdosissen -+ overdrachtsuitgaven -+ overdressed -+ overdrives -+ overdrukpapier -+ overeenkomstsluitend -+ overeenkomstsluitende -+ overenthousiast -+ overenthousiaste -+ overflows -+ overgangsfasen -+ overgangsfases -+ overgangsfiguren -+ overgangsfiguur -+ overgangsgebied -+ overgangsgebieden -+ overgangsrapporten -+ overgangsrechten -+ overgangsregering -+ overgangsrite -+ overgangsriten -+ overgangsrites -+ overgangsstadia -+ overgangsstadium -+ overgangstijdperk -+ overgeclassificeerd -+ overgeclassificeerde -+ overgecompenseerd -+ overgeconcentreerd -+ overgeconcentreerde -+ overgecultiveerd -+ overgecultiveerde -+ overgedienstig -+ overgedienstige -+ overgefinancierd -+ overgefinancierde -+ overgepend -+ overgereguleerd -+ overgereguleerde -+ overgeroeid -+ overgesneden -+ overgetikt -+ overgetrouwd -+ overgetypt -+ overgeverfd -+ overgevoeligheden -+ overgevoeligheidsreacties -+ overgewaardeerd -+ overgrootouder -+ overhandse -+ overheadprojectors -+ overheadsheets -+ overheidsaankoop -+ overheidsaankopen -+ overheidsbemoeienis -+ overheidsbemoeienissen -+ overheidsbesteding -+ overheidsbestedingen -+ overheidsbijdrage -+ overheidsbijdragen -+ overheidsbond -+ overheidsbonden -+ overheidsbureaucratie -+ overheidscontrole -+ overheidscontroles -+ overheidsfinanciering -+ overheidsfinanciën -+ overheidsgelden -+ overheidsgezag -+ overheidshuishouding -+ overheidsinstantie -+ overheidslichamen -+ overheidsschuld -+ overheidsschulden -+ overheidsschuldquote -+ overheidstekorten -+ overhemdblouse -+ overhemdblouses -+ overheveling -+ overhevelingstoeslag -+ overhoopgegooid -+ overhoopgehaald -+ overhoopgeschoten -+ overhoopgooien -+ overhoophalen -+ overhoopschieten -+ overhoopsteken -+ overinvestering -+ overinvesteringen -+ overklassen -+ overklast -+ overklaste -+ overlaadinrichting -+ overlasttaks -+ overlegcircuit -+ overlegcultuur -+ overlegeconomie -+ overlegger -+ overleggers -+ overlegplatform -+ overlegprocedure -+ overlegprocedures -+ overlevers -+ overlevingsdrang -+ overlevingsinstinct -+ overlevingspak -+ overlevingspakken -+ overlevingspakket -+ overlevingspakketten -+ overlevingspensioen -+ overlevingsstrijd -+ overlevingstocht -+ overlevingstochten -+ overlijdensadvertentie -+ overlijdensadvertenties -+ overlijdensakten -+ overlijdensannonce -+ overlijdensannonces -+ overlijdensberichten -+ overlijdensdatum -+ overlijdensverklaring -+ overlijdensverklaringen -+ overlijdensverzekeringen -+ overliquiditeit -+ overloopgebied -+ overluide -+ overmaats -+ overmaatse -+ overmachtsituatie -+ overmachtsituaties -+ overmachtssituaties -+ overnachtingsmogelijkheden -+ overnachtingsmogelijkheid -+ overnamebod -+ overnamegerucht -+ overnamegeruchten -+ overnameonderhandelingen -+ overnameprijs -+ overnamestrijd -+ overnemer -+ overnemers -+ overnemingsbod -+ overnemingsgevecht -+ overpennen -+ overreacties -+ overreageerd -+ overreageerde -+ overreageren -+ overriep -+ overroeien -+ overroepen -+ overrule -+ overruled -+ overrulede -+ overrulen -+ overrulet -+ overschakelingen -+ overscherend -+ overscherende -+ overschilderbaar -+ overschilderbare -+ overschildering -+ overschilderingen -+ overscholing -+ overschotprobleem -+ overschotproblemen -+ overschrijdingsregeling -+ oversekst -+ oversekste -+ oversized -+ overslagcapaciteit -+ overslagcentra -+ overslagcentrum -+ overslaghaven -+ overslaghavens -+ overslagstation -+ overslagstations -+ overslapen -+ oversliep -+ oversnijden -+ overspoot -+ overspoten -+ overstapmogelijkheden -+ overstapmogelijkheid -+ overstapper -+ overstappers -+ overstappunt -+ overstappunten -+ overstaptijd -+ overstaptijden -+ overstatements -+ oversteeg -+ overstegen -+ oversteker -+ overstekers -+ overstelpend -+ oversterfte -+ overstraalde -+ overstralen -+ overstromingsgebied -+ overstromingsgevaar -+ overstromingskans -+ overtal -+ overtalsituatie -+ overtalsituaties -+ overtijdpil -+ overtrekpapier -+ overtreksnelheid -+ overtrouwen -+ overvalcommando's -+ overvalwagens -+ oververven -+ overvette -+ overvliegrechten -+ overvloeden -+ overvloeiers -+ overvraging -+ overwaardering -+ overweldiging -+ overwerktheid -+ overwerktoeslag -+ overwerktoeslagen -+ overwerkuur -+ overwinningstekenen -+ overwinningstekens -+ overwinteringsgebied -+ overwinteringsgebieden -+ overzichtsartikels -+ overzichtsfoto -+ overzichtsfoto's -+ overzichtskaart -+ overzichtskaarten -+ overzichtspagina -+ overzichtspagina's -+ overzichtstentoonstelling -+ overzichtstentoonstellingen -+ ovulaties -+ ovuleerde -+ ovuleren -+ owngoal -+ owngoals -+ oxaalzuur -+ oxers -+ oxidaties -+ oxidatieve -+ oxides -+ ozonaantastend -+ ozonaantastende -+ ozonafbraak -+ ozonafbrekend -+ ozonafbrekende -+ ozonarm -+ ozonarme -+ ozonconcentratie -+ ozonconcentraties -+ ozongat -+ ozongehalte -+ ozonrijk -+ ozonrijke -+ p's -+ p'tje -+ p. -+ p.a. -+ pH -+ pH's -+ pH-neutraal -+ pH-neutrale -+ pH-waarde -+ pH-waarden -+ pH-waardes -+ pa's -+ paaigebied -+ paaigebieden -+ paaldansen -+ paaldanseres -+ paaldanseressen -+ paaldanste -+ paalfunderingen -+ paalgat -+ paalkrans -+ paalkransen -+ paalstand -+ paalsteek -+ paalsteken -+ paard-en-kar -+ paard-en-karren -+ paard-en-wagen -+ paard-en-wagens -+ paardenbekken -+ paardenbeslag -+ paardenbloem -+ paardenbloemen -+ paardendekens -+ paardendistel -+ paardendistels -+ paardendressuur -+ paardenhandelaar -+ paardenkastanje -+ paardenkastanjes -+ paardenliefhebbers -+ paardenlul -+ paardenprocessie -+ paardenprocessies -+ paardenrace -+ paardenraces -+ paardenrenbaan -+ paardenrennen -+ paardenschilder -+ paardenslagers -+ paardensportevenement -+ paardensprongen -+ paardenstaarten -+ paardenvijgen -+ paardjegereden -+ paardjerijden -+ paardrijbroek -+ paardrijbroeken -+ paardrijles -+ paardsprong -+ paardsprongen -+ paargedrag -+ paarrelatie -+ paarrelaties -+ paarrijden -+ paars-rode -+ paars-rood -+ paarsachtig -+ paarsachtige -+ paarsblauw -+ paarsblauwe -+ paarsig -+ paarsige -+ paarsrode -+ paarsrood -+ paasbeste -+ paasdienst -+ paashazen -+ paasklok -+ paasklokken -+ paasprocessie -+ paasprocessies -+ paasspel -+ paasspelen -+ paasstok -+ paaswaken -+ paasweekeinde -+ paasweekend -+ pabo -+ pabo's -+ pabostudent -+ pabostudenten -+ pace -+ pacen -+ pacet -+ pacete -+ pachtakten -+ pachtaktes -+ pachtboerderijen -+ pachtboeren -+ pachtcontracten -+ pachtgebied -+ pachtgebieden -+ pachtovereenkomsten -+ pacificatiedemocratie -+ pacificatiemodel -+ pacificatoren -+ pacificators -+ pacificering -+ packs -+ pacteerde -+ paddenstoel -+ paddenstoelen -+ paddenstoelvormig -+ paddenstoelvormige -+ paddenstoelwolk -+ paddenstoelwolken -+ paddo -+ paddo's -+ paddy -+ paddy's -+ padieboer -+ padieboeren -+ padisjah -+ padisjahs -+ padvinderachtig -+ padvinderachtige -+ padvindersgroet -+ pafpaal -+ pafpalen -+ pagadder -+ pagadders -+ pagara -+ pagara's -+ pagekapsel -+ pagina-indeling -+ paginabrede -+ paginabreed -+ paginacijfer -+ paginacijfers -+ paginagroot -+ paginalang -+ paginalange -+ pagodebomen -+ pagodeboom -+ paintball -+ paintballde -+ paintballen -+ paintballt -+ pakbaar -+ pakbare -+ pakbons -+ pakgoed -+ pakira -+ pakira's -+ pakistaan -+ pakistanen -+ pakkansen -+ pakketkeuze -+ pakketreis -+ pakketreizen -+ paktafels -+ palaverde -+ palaveren -+ paleisachtig -+ paleisachtige -+ paleiscomplex -+ paleismuren -+ paleismuur -+ paleistuin -+ paleistuinen -+ paleiswachten -+ paleiszalen -+ palenpest -+ paleoantropologen -+ paleoantropologisch -+ paleoantropologische -+ paleoantropoloog -+ paleobotanici -+ paleobotanicus -+ paleobotanie -+ paleoceen -+ paleocene -+ paleografisch -+ paleografische -+ paleolithicum -+ paleopathologie -+ paleozoïcum -+ palestijnensjaal -+ palestijnensjaals -+ palingboeren -+ palingworst -+ palissadeparenchym -+ palletten -+ pallieter -+ pallieters -+ palmaressen -+ palmentuin -+ palmpaas -+ palmprocessie -+ palmsuiker -+ palmtop -+ palmtops -+ palmwijding -+ palmzondag -+ palpabele -+ palpaties -+ palpiteerde -+ paltsen -+ palurken -+ pamflettistische -+ pampa's -+ pamper -+ pamperde -+ pamperen -+ pampers -+ pan-Afrikaans -+ pan-Afrikaanse -+ pan-Arabische -+ pan-Europese -+ pan-Turkse -+ panafrikanisme -+ panama's -+ panamaziekte -+ panamerikanisme -+ panarabisme -+ panarabist -+ panarabisten -+ pancetta -+ panda's -+ pandan -+ pandanen -+ pandanrijst -+ pandbelener -+ pandbeleners -+ pandgevers -+ pandit -+ pandita -+ pandita's -+ pandits -+ pandjesbazen -+ pandnemers -+ pandovereenkomsten -+ paneelwerk -+ paneelwerken -+ panelrapport -+ pangermanisme -+ pangi -+ pangi's -+ pangs -+ paniekachtige -+ paniekreactie -+ panieksluiting -+ panieksluitingen -+ paniektoestand -+ paniektoestanden -+ paniekzaaierij -+ panikeerde -+ panlikkers -+ panna -+ panna cotta -+ panna's -+ pannengrepen -+ pannenkoekenrestaurants -+ pannenkoekmessen -+ pannenlappen -+ pannenlikkers -+ pannensponsen -+ panoramakijker -+ panoramakijkers -+ panoramaopname -+ panoramaopnamen -+ panoramaopnames -+ panslavisme -+ panterhaai -+ panterhaaien -+ pantoffeldiertjes -+ pantserauto's -+ pantserdivisie -+ pantsereenheden -+ pantsereenheid -+ pantsergevechtsvoertuig -+ pantsergevechtsvoertuigen -+ pantsergranaten -+ pantserinfanteriebataljon -+ pantserkruiser -+ pantserkruisers -+ pantservoertuigen -+ pantservuist -+ pantservuisten -+ pantykous -+ pantykousen -+ papadum -+ papadums -+ papaja-ijs -+ papajaatje -+ papajayoghurt -+ papegaaiduiker -+ papegaaiduikers -+ papegaaienbekken -+ paperbackeditie -+ paperbackuitgave -+ paperbackuitgaven -+ papers -+ papfles -+ papflessen -+ papieractie -+ papieracties -+ papierafval -+ papierbakken -+ papierberg -+ papierbinder -+ papierbinders -+ papierdun -+ papierdunne -+ papierformaten -+ papiergebrek -+ papiergroothandel -+ papierindustrie -+ papiermachines -+ papiermarkt -+ papierprikker -+ papierprikkers -+ papierproductie -+ papierpulp -+ papierriet -+ papierrol -+ papierrollen -+ papierslag -+ papierslagen -+ papiersnijder -+ papiersnijders -+ papiersoorten -+ papierstroken -+ papierverbruik -+ papiervernietiger -+ papiervernietigers -+ papierversnipperaar -+ papierversnipperaars -+ papierwaren -+ papierwinkels -+ papje -+ papjes -+ pappa's -+ pappaatje -+ pappies -+ paprikaatje -+ paprikapoeder -+ para's -+ para-universitaire -+ paraattassen -+ parabellums -+ paraboolantenne -+ paraboolantennes -+ paracetamol -+ parachutetje -+ paraclub -+ paraclubs -+ paracommando's -+ parafencultuur -+ paraffineolie -+ parafiscaal -+ parafiscale -+ paragneis -+ parallactische -+ parallelcirkels -+ parallelmarkten -+ paramagnetische -+ paramedici -+ paranoïci -+ parapluantennes -+ paraplumoord -+ parapluorganisatie -+ parapluplant -+ parapluplanten -+ parapsychologen -+ parascolair -+ parascolaire -+ parasitologen -+ parasitologisch -+ parasitologische -+ parasitoloog -+ parastatalen -+ paratroepers -+ parcoursbouwer -+ pardessustje -+ parelachtig -+ parelachtige -+ parelkettingen -+ parelkettinkje -+ parelkoffie -+ parelkwekerij -+ parelkwekerijen -+ parelmosselen -+ parelvormig -+ parelvormige -+ parenbridge -+ parentoernooi -+ parenwedstrijd -+ parenwedstrijden -+ parfumeurs -+ parfumfles -+ parfummerk -+ parfummerken -+ paria's -+ pariaatje -+ pariastatus -+ paringsdaden -+ paringsdans -+ paringsdansen -+ parka's -+ parkbank -+ parkbanken -+ parkbos -+ parkeerbanen -+ parkeerbeugel -+ parkeerboetes -+ parkeerbonnen -+ parkeergelegenheden -+ parkeerkaart -+ parkeerkaarten -+ parkeerklemmen -+ parkeerlichten -+ parkeerovertreding -+ parkeerovertredingen -+ parkeerruimten -+ parkeerruimtes -+ parkeerschijven -+ parkeerwacht -+ parkeerwachten -+ parkeerzones -+ parketpolitie -+ parketwachten -+ parkings -+ Parkinson -+ parkwachters -+ parlementair-democratisch -+ parlementair-democratische -+ parlementair-politiek -+ parlementair-politieke -+ parlementsfractie -+ parlementsmeerderheid -+ parlementsverkiezing -+ parlementsvoorzitter -+ parlementsvoorzitters -+ parlofoons -+ parmaham -+ parnas -+ parnassia -+ parnassijn -+ parnassijnen -+ parochieblad -+ parochiehuizen -+ parochieraden -+ parochiescholen -+ parochiezaal -+ parochiezalen -+ parodietje -+ parodistische -+ parse -+ parsen -+ parset -+ parsete -+ parterreappartement -+ parterreappartementen -+ parterrewoning -+ parterrewoningen -+ participatieakkoord -+ participatiebeurs -+ participatiebewijzen -+ participatiemaatschappij -+ particularismen -+ partijachterban -+ partijapparaat -+ partijbureaus -+ partijcongressen -+ partijconvent -+ partijdagen -+ partijdemocratie -+ partijelite -+ partijenstelsel -+ partijfinanciering -+ partijfunctionarissen -+ partijgebonden -+ partijgeld -+ partijgelden -+ partijgenotes -+ partijgetrokken -+ partijideologen -+ partijinterne -+ partijkaart -+ partijkas -+ partijkassen -+ partijkrant -+ partijkranten -+ partijlidmaatschap -+ partijnaam -+ partijprogram -+ partijprogramma's -+ partijprograms -+ partijraden -+ partijsecretariaat -+ partijsecretariaten -+ partijsecretaris -+ partijsecretarissen -+ partijstandpunten -+ partijstrijd -+ partijtoppen -+ partijtopper -+ partijtoppers -+ partijtwist -+ partijtwisten -+ partijvoorzitter -+ partijvoorzitters -+ partijvoorzitterschap -+ partita's -+ partnerinkomen -+ partnerland -+ partnerlanden -+ partnerpensioen -+ partnerrelatie -+ partnerschap -+ partnerschapovereenkomst -+ partnerschappen -+ partnerschapsakkoord -+ partnerschapsovereenkomst -+ parttimejob -+ parttimejobs -+ parttimers -+ partussen -+ partycentra -+ partycentrum -+ partycentrums -+ partyde -+ partydier -+ partydieren -+ partydrug -+ partydrugs -+ partyen -+ partyservice -+ partyt -+ partytent -+ partytenten -+ parvenuutje -+ parwa -+ parwa's -+ pasbenoemd -+ pasbenoemde -+ pasgeleden -+ pasgetrouwd -+ pasja's -+ pasjesregeling -+ pasjessysteem -+ pasjeswetten -+ paso dobles -+ paspoortcontrole -+ paspoortcontroles -+ paspoorthuwelijk -+ paspoorthuwelijken -+ paspoortnummer -+ paspoortnummers -+ paspoppen -+ passagiersaccommodaties -+ passagierstreinen -+ passagiersverkeer -+ passagiersvervoer -+ passagiersvliegtuigen -+ passagiersvluchten -+ passantenhaven -+ passantenverblijf -+ passantenverblijven -+ passe -+ passe-vite -+ passe-vites -+ passeerbeweging -+ passeerbewegingen -+ passeerslagen -+ passencombinatie -+ passencombinaties -+ passerelles -+ passes -+ passieloze -+ passiemoord -+ passiemoorden -+ passiezondag -+ passionele -+ passpiegels -+ passt -+ passte -+ password -+ passwords -+ pasta's -+ pastagerecht -+ pastagerechten -+ pastasalade -+ pastasaus -+ pastasausen -+ pastasauzen -+ pastasoort -+ pastelkleurig -+ pastelkleurige -+ pastels -+ pasteltint -+ pastifi -+ pastoraten -+ pastorijen -+ paswoord -+ paswoorden -+ patatbakker -+ patatbakkers -+ patates-friteskraam -+ patates-friteskramen -+ patatgeneratie -+ patati patata -+ patatjes -+ patatsnijders -+ patch -+ patches -+ patchoeli -+ patelen -+ patentmeel -+ patentsteek -+ patentsteken -+ pater familias -+ paternosterliften -+ pathefoons -+ pathische -+ pathologen-anatomen -+ pathologisch-anatomisch -+ pathologisch-anatomische -+ patholoog-anatoom -+ patissiers -+ patiëntenbestand -+ patiëntenbestanden -+ patiëntendemonstratie -+ patiëntendemonstraties -+ patiëntendossier -+ patiëntendossiers -+ patiëntenorganisatie -+ patiëntenstops -+ patiëntenverenigingen -+ patiëntes -+ patiëntgebonden -+ patiëntgegevens -+ patiëntmateriaal -+ patjepeeër -+ patjepeeërs -+ patriciërsfamilie -+ patriciërsfamilies -+ patriciërshuizen -+ patriciërswoning -+ patrilineaire -+ patronaal -+ patronages -+ patronagesysteem -+ patronale -+ patroniem -+ patroniemen -+ patroonbanden -+ patroonpapier -+ patrouilleboot -+ patrouilleboten -+ patrouilleschepen -+ patrouilleschip -+ patrouillevliegtuig -+ patrouillevliegtuigen -+ patrouillevlucht -+ patrouillevluchten -+ patrouillewagen -+ patrouillewagens -+ patsituatie -+ patés -+ paukenslagen -+ paumelles -+ pausbezoek -+ pauwenogen -+ pauwenstaarten -+ pauzeconcerten -+ pauzenummer -+ pauzenummers -+ pauzetekens -+ pauzetoetsen -+ pavanes -+ pavloviaans -+ pavloviaanse -+ pavoiseerde -+ pavoiseren -+ pay-tv -+ pc'tje -+ pcb -+ pcb's -+ pdf-formaat -+ pechdienst -+ pechdiensten -+ pechstroken -+ pechstrook -+ peda -+ peda's -+ pedaalemmers -+ pedaalgebruik -+ pedagoges -+ pedagogisch-didactisch -+ pedagogisch-didactische -+ pedalo -+ pedalo's -+ pederastische -+ pediaters -+ pedo -+ pedo's -+ pedofielen -+ pedologische -+ peelings -+ peepshow -+ peepshows -+ peerde -+ peerdrops -+ peergroep -+ peergroepen -+ peergroup -+ peergroups -+ peeskamer -+ peeskamertje -+ peesontsteking -+ peesontstekingen -+ peesschedeontsteking -+ peesschedeontstekingen -+ peesschedes -+ peetdochters -+ peetmoeders -+ peetvaders -+ peetzonen -+ peetzoons -+ peies -+ peigerde af -+ peilantennes -+ peilballon -+ peilballons -+ peildata -+ peildatums -+ peilverlaging -+ peilverlagingen -+ peinzer -+ peinzers -+ pekingeend -+ pekingeenden -+ pekingmens -+ pekingmensen -+ pelagianen -+ pelgrimeerde -+ pelgrimpje -+ pelgrimshaven -+ pelgrimshavens -+ pelgrimshoeden -+ pelgrimsoord -+ pelikaanachtig -+ pelikaanachtige -+ pellers -+ pelotonscommandant -+ pelotonscommandanten -+ pelsen -+ pelsmantels -+ pelsmanteltje -+ pelsrob -+ pelsrobben -+ pen-en-gatverbinding -+ penaliseerde -+ penaliseren -+ penaltystippen -+ pendelaars -+ pendelbeweging -+ pendelbewegingen -+ pendelbussen -+ pendels -+ pendeltrein -+ pendeltreinen -+ pendrive -+ pendrives -+ penduultje -+ pengat -+ pengaten -+ penhoudergrepen -+ penibele -+ penicilline-injectie -+ penicilline-injecties -+ peniskoker -+ peniskokers -+ penissen -+ pennenhouders -+ pennenlikkers -+ pennenmessen -+ pennenschacht -+ pennenschachten -+ pennenstok -+ pennenstokken -+ pennenstreken -+ pennentrek -+ pennentrekken -+ pennenvoerder -+ pennenvoerders -+ pennenvruchten -+ pennenzak -+ pennenzakken -+ penningske -+ penningskes -+ penny's -+ penopauze -+ penopauzes -+ penseelvormig -+ penseelvormige -+ pensenkermis -+ pensenkermissen -+ pensioenbreuken -+ pensioengaten -+ pensioenleeftijd -+ pensioenrecht -+ pensioenreserves -+ pensioensparen -+ pensioentrekker -+ pensioentrekkers -+ pensioenuitkeringen -+ pensioenverzekeringsovereenkomst -+ pensionado -+ pensionado's -+ pensionhoudsters -+ pentagonale -+ pentagrammen -+ pentatonische -+ penthouse -+ penthouseje -+ penthouses -+ penvoerder -+ penvoerders -+ penwortel -+ penwortels -+ peper-en-zoutkleur -+ peper-en-zoutstel -+ peper-en-zoutstellen -+ peper-en-zoutstelletje -+ peperbolletje -+ peperbomen -+ peperboom -+ peperboompjes -+ pepermolens -+ pepermuntachtig -+ pepermuntachtige -+ pepermuntje -+ pepermuntjes -+ pepermuntsmaak -+ pepermuntthee -+ pepersausen -+ pepersauzen -+ pepperspray -+ pepte op -+ peptiden -+ perceelland -+ percentielscore -+ percentielscores -+ percentteken -+ percenttekens -+ perceptievermogen -+ percolators -+ percussie-instrument -+ percussie-instrumenten -+ percussiehamer -+ percussiehamers -+ percussionisten -+ perenbloesem -+ perenbloesems -+ perenhout -+ perenhouten -+ perequaties -+ perfectieve -+ perfectioneringen -+ performancekunstenaar -+ performancekunstenaars -+ performances -+ performers -+ perifrastische -+ perinatale -+ periodekampioenen -+ periodeoverzicht -+ periodeoverzichten -+ periodetitel -+ periodiseerde -+ periodisering -+ perkamentachtig -+ perm -+ permissieve -+ pernod -+ pernodje -+ peronisten -+ peronistische -+ peroreerde -+ peroxiden -+ peroxides -+ perpetua mobilia -+ perpetuum mobile's -+ perronchef -+ perronchefs -+ perronkap -+ perronkappen -+ perronopzichter -+ perronopzichters -+ perronoverkapping -+ perronwagens -+ persad -+ persagenten -+ persagentschappen -+ persbijeenkomsten -+ persbriefings -+ perscensuur -+ perscentra -+ perscommuniqués -+ perseveraties -+ persevereerde -+ persfoto's -+ persfotografie -+ persfusiecontrole -+ persfusiecontroleregeling -+ perskamers -+ persmappen -+ persmatrijzen -+ persmensen -+ persmuskieten -+ persofficieren -+ personal computer -+ personal computers -+ personeelsbladen -+ personeelsbond -+ personeelsbonden -+ personeelschefs -+ personeelsconsulent -+ personeelsconsulenten -+ personeelsfeest -+ personeelsgebrek -+ personeelskamer -+ personeelskantine -+ personeelskantines -+ personeelsprobleem -+ personeelsproblemen -+ personeelsstops -+ personeelsverenigingen -+ personeelsvergadering -+ personeelsvergaderingen -+ personeelsvoorziening -+ personenbelasting -+ personencultus -+ personenliften -+ personenmeerderheidsstelsel -+ personenregisters -+ personenstrijd -+ personenvennootschap -+ personenvennootschappen -+ personifiëring -+ Beotië -+ Bohemen -+ Bourgondië -+ Hindoestan -+ Voor-Indië -+ Sparta -+ persoonlijkheidskenmerk -+ persoonlijkheidskenmerken -+ persoonlijkheidsontwikkeling -+ persoonlijkheidspsychologie -+ persoonlijkheidsrecht -+ persoonlijkheidsstoornis -+ persoonlijkheidsstoornissen -+ persoonlijkheidsvorming -+ persoonsbeveiliging -+ persoonsdossier -+ persoonsdossiers -+ persoonsgegeven -+ persoonsnummers -+ persoonsregisters -+ persoonsregistraties -+ perspectiefloos -+ perspectiefloze -+ perspectiefrijk -+ perspectiefrijke -+ perspectieftekeningen -+ perspectiefwisseling -+ perspectiefwisselingen -+ persprijzen -+ persraad -+ persrechter -+ persrechters -+ perssinaasappelen -+ perstribunes -+ persverklaring -+ persverklaringen -+ persvertegenwoordiger -+ persvertegenwoordigers -+ persvoorlichters -+ persvoorstellingen -+ perswee -+ perswet -+ perswetten -+ perszaal -+ perszaaltje -+ perszalen -+ pertang -+ perversies -+ perverst -+ pervertering -+ perzen -+ perzikhuid -+ peso's -+ pessaria -+ pessariums -+ pestbuien -+ pestepidemies -+ pesthekel -+ pesthumeuren -+ pestilente -+ pesto -+ pestpokken -+ peststreken -+ pestvogel -+ pestvogels -+ petanque -+ petanquen -+ petanquet -+ petanquete -+ peterprinciple -+ peterseliesteeltje -+ peterseliesteeltjes -+ petfles -+ petflessen -+ petgat -+ petgaten -+ petit restaurant -+ petit restaurants -+ petrischaal -+ petrischaaltje -+ petrochemie -+ petrodollar -+ petrodollars -+ petroleumhoudend -+ petroleumhoudende -+ petroleumindustrie -+ petroleumtankers -+ petroleumvergassers -+ petsen -+ petsjorapieper -+ petsjorapiepers -+ petste -+ petticoats -+ petunia's -+ peulenschillen -+ peuterklassen -+ peuterleidsters -+ peuterscholen -+ peuterschool -+ peuterspeelzalen -+ peutertuin -+ peutertuinen -+ pezeweefde -+ pg -+ pg's -+ philibertspant -+ philibertspanten -+ pi's -+ pi'tje -+ piai -+ piais -+ pianist-componist -+ pianisten-componisten -+ pianobar -+ pianobars -+ pianobouwer -+ pianobouwers -+ pianoduo -+ pianoduo's -+ pianoforte's -+ pianokwartetten -+ pianokwintet -+ pianola's -+ pianorecital -+ pianosolo -+ pianosonate -+ pianosonaten -+ pianosonates -+ pianotoets -+ pianotoetsen -+ pianotrio's -+ pianovirtuozen -+ piasserij -+ piasserijen -+ pica's -+ picassovis -+ piccolo's -+ pick-uptruck -+ pick-uptrucks -+ picknickplaats -+ picknickplaatsen -+ pickwicksyndroom -+ picoseconden -+ picosecondes -+ pidgins -+ pied-à-terres -+ piefen -+ piekautomaat -+ piekautomaten -+ piekdag -+ piekdagen -+ piekerig -+ piekerige -+ piekperiode -+ piekte -+ pielde -+ pielepoten -+ piemelnaakt -+ piemelnaakte -+ piemels -+ piemeltje -+ piepbeest -+ piepbeesten -+ piepel -+ piepelde -+ piepelen -+ piepels -+ piepeltje -+ piepplastic -+ piepschuimen -+ pieptonen -+ pieptoontje -+ pierce -+ piercen -+ piercet -+ piercete -+ pierenbad -+ pierenbaden -+ pierrotje -+ piesbak -+ piesbakken -+ piespotten -+ pietepeuterde -+ pietepeuteren -+ pietje-precies -+ pietjes-precies -+ pigmentpapier -+ pijl-en-boog -+ pijlpunten -+ pijlstaartrog -+ pijlstaartroggen -+ pijlstaartvlinder -+ pijlstaartvlinders -+ pijnappelklier -+ pijnappelklieren -+ pijngevoel -+ pijngevoelens -+ pijngrenzen -+ pijnpit -+ pijnpitten -+ pijpbreuk -+ pijpendoppen -+ pijpenkabinet -+ pijpenkoppen -+ pijpenla's -+ pijpenlaatje -+ pijpenplank -+ pijpenplanken -+ pijpenragers -+ pijpfitters -+ pijpjes -+ pijpleidingennet -+ pijproken -+ pijprokers -+ pijpsleutels -+ pijptabak -+ piketpaaltje -+ piketteerde -+ pikkerig -+ pikkerige -+ pikketanissen -+ pikolet -+ pikolets -+ pilaarvoetstuk -+ pilav -+ pilcontrole -+ pilcontroles -+ pilde -+ pilgebruikster -+ pilgebruiksters -+ pilipili -+ pillendeeg -+ pillenslikkers -+ pilootaflevering -+ pilootafleveringen -+ pilotstudy's -+ pimentbomen -+ pimentboom -+ pimpampette -+ pimpampetten -+ pin-upgirls -+ pin-ups -+ pina -+ pinaarde -+ pinaren -+ pince-nezs -+ pince-neztje -+ pinchhitter -+ pinchhitters -+ pindarisch -+ pindarische -+ pindarotsje -+ pindasambal -+ pindasambel -+ pindasaus -+ pindasausen -+ pindasauzen -+ pindasoep -+ ping -+ pingels -+ pingo -+ pingo's -+ pingping -+ pingpongbal -+ pingpongballen -+ pingpongballetje -+ pingponger -+ pingpongers -+ pinguïnnetje -+ pinguïntje -+ pinknagel -+ pinkster -+ pinkstergemeenten -+ pinkstergemeentes -+ pinksterroos -+ pinksterrozen -+ pins -+ pintelierde -+ pintelieren -+ pinteriaans -+ pinteriaanse -+ pioniersarbeid -+ pioniersfunctie -+ pioniersrol -+ pioniersters -+ pionneneindspel -+ pionnenstelling -+ pionnenstructuur -+ pionoffer -+ pionoffers -+ pionwinst -+ piratenedities -+ piratennesten -+ piratenzenders -+ pireng -+ pirengs -+ piripiri -+ pisang goreng -+ pisglas -+ pisglazen -+ pislucht -+ pispaal -+ pispaaltje -+ pissige -+ pissoirs -+ pistache-ijs -+ pistiers -+ pistonpen -+ pistonpennen -+ pistoolgreep -+ pistoolgrepen -+ pistoolholsters -+ pistoolschieten -+ pistoolschilder -+ pistoolschilders -+ pistousaus -+ pitabroodjes -+ pitbulleigenaren -+ pitbulletje -+ pitbulltje -+ pitch -+ pitchen -+ pitcht -+ pitchte -+ pitloos -+ pitloze -+ pitsstop -+ pitsstoppen -+ pitsstops -+ pitstoppen -+ pitvis -+ pitvissen -+ pivoteerde -+ pivoteren -+ pizzabakker -+ pizzabakkers -+ pizzakoerier -+ pizzakoeriers -+ pizzicato's -+ pièce de résistance -+ piëta's -+ piëteitsvol -+ piëteitsvolle -+ piëtisten -+ piëtistische -+ piëzometer -+ piëzometers -+ pk -+ pk's -+ plaagstoten -+ plaaster -+ plaasterde -+ plaasteren -+ plaasters -+ plaatdrukker -+ plaatdrukkers -+ plaatfrezer -+ plaatfrezers -+ plaathaak -+ plaathaken -+ plaatijzeren -+ plaatjesalbums -+ plaatjesboek -+ plaatjesboeken -+ plaatkieuwig -+ plaatkieuwige -+ plaatmateriaal -+ plaatopnamen -+ plaatpers -+ plaatpersen -+ plaatradiators -+ plaatsbiljet -+ plaatsbiljetten -+ plaatsgenomen -+ plaatsingscommissies -+ plaatsingsmogelijkheden -+ plaatsingsmogelijkheid -+ plaatskaarten -+ plaatsmaken -+ plaatsnaambord -+ plaatsnaamborden -+ plaatspanning -+ plaatspanningen -+ plaattektoniek -+ plaatwals -+ plaatwalsen -+ plaatwerkerijen -+ plaatzwam -+ plaatzwammen -+ placebo-effect -+ placebogroep -+ placemats -+ placets -+ plafondhanger -+ plafondmortel -+ plafondschildering -+ plafondschilderingen -+ plafondschroot -+ plafondschroten -+ plafondtegel -+ plafondtegels -+ plafonneurs -+ plagieerde -+ plakalbums -+ plaksels -+ plaktafels -+ planbureaus -+ planchets -+ plande -+ plane -+ planeerder -+ planeerders -+ planeetoppervlak -+ planes -+ planetenbanen -+ planetoïden -+ planimeters -+ planisferisch -+ planisferische -+ plankenbeschotten -+ plankenvloeren -+ plankharde -+ plankiers -+ plankschaatsen -+ planloos -+ planloze -+ plano's -+ planologen -+ planologische -+ planometers -+ planprocedures -+ planschade -+ plantaardappel -+ plantaardappelen -+ plantaardappels -+ plantage-eigenaar -+ plantage-eigenaars -+ plantage-eigenaren -+ plantagehuis -+ plantagehuizen -+ plantageslaaf -+ plantageslaven -+ plantenbiotechnologie -+ plantendeel -+ plantenfamilie -+ plantenfamilies -+ plantengeslacht -+ plantengeslachten -+ plantenkas -+ plantenkassen -+ plantenkleed -+ plantenkwekers -+ plantenziekten -+ plantenziektes -+ planterszoon -+ plantkoord -+ plantkoorden -+ plantkundigen -+ plantrekker -+ plantrekkers -+ plaques -+ plasma's -+ plasma-eiwit -+ plasma-eiwitten -+ plasmabanken -+ plasmacel -+ plasmacellen -+ plasmiden -+ plasmolen -+ plasmolens -+ plaspauze -+ plaspauzes -+ plaspil -+ plasseks -+ plassengebied -+ plassengebieden -+ plasser -+ plassers -+ plasticbommen -+ plasticfolie -+ plasticindustrie -+ plasticsoort -+ plasticsoorten -+ plastificeerde -+ platbodems -+ platbombarderen -+ plateauzolen -+ plateauzool -+ plateelschilders -+ plateelwerk -+ platenbaas -+ platenbazen -+ platenbijbel -+ platenbijbels -+ platenboeken -+ platenbonnen -+ platenbons -+ platencontract -+ platencontracten -+ platendraaier -+ platendraaiers -+ platenhoezen -+ platenlabels -+ platenplugger -+ platenpluggers -+ platenreiniger -+ platenreinigers -+ platenrekken -+ platenspelers -+ platenstudio -+ platenstudio's -+ platentektoniek -+ platenwinkel -+ platenwinkels -+ platgebombardeerd -+ platgegooid -+ platgelegen -+ platgemaakt -+ platgeperst -+ platgereden -+ platgeschoten -+ platgespoten -+ platgestreken -+ platgetrapt -+ platgooien -+ platina-ertsen -+ platinahoudend -+ platinahoudende -+ platinakleurig -+ platinakleurige -+ platinazwart -+ platinazwarte -+ platitudes -+ platliggen -+ platmaken -+ platrijden -+ plats du jour -+ platschieten -+ platspuiten -+ platstrijken -+ plattekaas -+ plattelandsarts -+ plattelandsbewoner -+ plattelandsbewoners -+ plattelandsdistrict -+ plattelandsdistricten -+ plattelandsdokter -+ plattelandsdokters -+ plattelandsgemeenschap -+ plattelandsgemeenschappen -+ plattelandsleven -+ plattelandsontwikkeling -+ plattelandsscholen -+ plattelandsschool -+ plattelandsvrouw -+ plattelandsvrouwen -+ plattrappen -+ plattreden -+ platvloerser -+ platvloersheden -+ platvloerst -+ platworm -+ platwormen -+ play-off -+ play-offs -+ play-offsysteem -+ play-offwedstrijd -+ play-offwedstrijden -+ playbackshows -+ playbackt -+ playbackte -+ playstation -+ playstations -+ pleeborstels -+ pleeboy -+ pleeboys -+ pleegzorg -+ plegers -+ pleier -+ pleiner -+ pleiners -+ pleintjesbasketbal -+ pleisterlagen -+ pleistermortel -+ pleisterpil -+ pleistoceen -+ pleistocene -+ pleitbaar -+ pleitbare -+ pleitbezorgster -+ pleite -+ plensregende -+ plensregenen -+ plensregens -+ pletbaar -+ pletbare -+ pleurde -+ pleuren -+ pleziervaartuigenbelasting -+ plichtbewust -+ plichtbewuste -+ plichtmatigheden -+ plichtmatigheid -+ plioceen -+ pliocene -+ plissérok -+ plissérokken -+ plistoceen -+ ploegarts -+ ploegartsen -+ ploegentijdritten -+ ploeggang -+ ploeggangen -+ ploeggenoot -+ ploeggenoten -+ ploegleider -+ ploegleiders -+ ploegmachine -+ ploegmachines -+ ploegschaaf -+ ploegschaven -+ ploffer -+ ploffers -+ plofklank -+ plofklanken -+ plombière-ijs -+ plombières -+ plonsbad -+ plonsbaden -+ plooi-ijzer -+ plooi-ijzers -+ ploppen -+ plopper -+ ploppers -+ plotte -+ plotters -+ plu's -+ plug-and-play -+ plug-in -+ plug-ins -+ plugde -+ pluimgewicht -+ pluimveebedrijf -+ pluimveeslachterij -+ pluimveeslachterijen -+ pluimveestapel -+ pluisachtig -+ pluisachtige -+ pluk-ze-wet -+ plukbaar -+ plukbare -+ pluksgewijs -+ pluksgewijze -+ plurk -+ plurken -+ pluspolen -+ plusser -+ plussers -+ plusstroken -+ plusstrook -+ pluste -+ plutoniumschip -+ plutoniumtransport -+ plutoniumtransporten -+ plutoniumvoorraad -+ plutoniumvoorraden -+ po's -+ pocherig -+ pocherige -+ pocketboeken -+ pocketcamera's -+ pocketcomputer -+ pocketcomputers -+ pocketformaat -+ pocketuitgave -+ pocketuitgaven -+ podiumervaring -+ podiuminstelling -+ podiuminstellingen -+ podiumkunst -+ podiumkunsten -+ podiumkunstinstelling -+ podiumkunstinstellingen -+ podiumpersoonlijkheid -+ podiumpje -+ podiumpresentatie -+ poederig -+ poederige -+ poederkool -+ poederzeep -+ poefen -+ poeh -+ poelslak -+ poelslakken -+ poema's -+ poencontract -+ poencontracten -+ poenerige -+ poepbruin -+ poepbruine -+ poepdoos -+ poepdozen -+ poepgaatje -+ poepgat -+ poepgaten -+ poesta's -+ poetsdozen -+ poetsers -+ poetsextract -+ poetsextracten -+ poetsvrouw -+ poetsvrouwen -+ poezig -+ poezige -+ pofmais -+ pofmaïs -+ pogode -+ poinsettia's -+ pointeloos -+ pointeloze -+ pointillistische -+ pokeraar -+ pokeraars -+ pokerbekers -+ pokerface -+ pokerfaces -+ pokergezichten -+ pokerspelletje -+ pokkenlijders -+ pokkenprikken -+ polarisatiefilters -+ polarisatiespanningen -+ polarisatiestrategie -+ polarisatievlakken -+ polarisraketten -+ polariteiten -+ polaroidcamera -+ polaroidcamera's -+ polaroidfoto -+ polaroidfoto's -+ polderblindheid -+ polderboezems -+ poldercultuur -+ poldergebieden -+ poldersloot -+ poldersloten -+ polderweg -+ polderweggetje -+ polemologen -+ polen -+ poleposition -+ polijstkoppen -+ polijstschijven -+ polio-epidemie -+ poliopatiënt -+ poliopatiënten -+ polioprik -+ poliovaccin -+ poliovaccinatie -+ poliovaccins -+ poliovirus -+ polishouders -+ polismantels -+ polisvoorwaarde -+ politbureauleden -+ politbureaulid -+ politbureaus -+ politica's -+ politicologe -+ politicologes -+ politicologische -+ politie-eenheden -+ politie-eenheid -+ politie-escorte -+ politie-informatie -+ politie-ingrijpen -+ politie-inval -+ politie-invallen -+ politie-uniform -+ politie-uniforms -+ politieacademie -+ politieacademies -+ politieafzettingen -+ politieapparaat -+ politiearts -+ politieautootje -+ politiebeambte -+ politiebeambten -+ politiebond -+ politiebonden -+ politieboot -+ politieboten -+ politiebus -+ politiebussen -+ politiefilm -+ politiefilms -+ politiehandvest -+ politiehelikopter -+ politiehelikopters -+ politiehoofdkwartier -+ politiek-bureaucratisch -+ politiek-bureaucratische -+ politiek-economisch -+ politiek-economische -+ politiek-financieel -+ politiek-financiële -+ politiek-ideologisch -+ politiek-ideologische -+ politiek-juridisch -+ politiek-juridische -+ politiek-maatschappelijk -+ politiek-maatschappelijke -+ politiekaart -+ politiekaarten -+ politiekantoor -+ politiekorps -+ politiekorpsen -+ politiemachten -+ politiemannen -+ politieonderzoek -+ politieoptreden -+ politieoptredens -+ politiepaard -+ politiepaarden -+ politiepatrouille -+ politiepatrouilles -+ politiepenningen -+ politieradio -+ politierapporten -+ politierecht -+ politierechtbank -+ politierechtbanken -+ politiescholen -+ politieschool -+ politieserie -+ politieseries -+ politieverhoor -+ politieverhoren -+ politievrouwen -+ politiewacht -+ politiewachten -+ politiewagens -+ politiewet -+ politiewetten -+ politiewoordvoerster -+ polka's -+ polluties -+ polo's -+ polode -+ poloshirts -+ polsaderen -+ polsbeschermers -+ polsblessure -+ polsblessuren -+ polsblessures -+ polsdruk -+ polsgewricht -+ polsgewrichten -+ polsslagaderen -+ polsstokhoogspringer -+ polsstokhoogspringers -+ polsstokspringer -+ polsstokspringers -+ polstasjes -+ polster -+ polsters -+ polswijdte -+ polyamiden -+ polyamides -+ polychloorbifenyl -+ polychromatische -+ polycyclische -+ polyesterhars -+ polyesterharsen -+ polyethyleenereftalaat -+ polyinterpretabele -+ polymeerketen -+ polymeerketens -+ polymerisaties -+ polymeriseerde -+ polysemantische -+ polysyndetons -+ polyvalente -+ pom -+ pommerak -+ pommeraks -+ pomparm -+ pomparmen -+ pomperij -+ pompgemalen -+ pomphouders -+ pompinstallatie -+ pompinstallaties -+ pompschroevendraaiers -+ pompstang -+ pompstangen -+ pompstationhouder -+ pompstationhouders -+ pompsysteem -+ ponchootje -+ pondteken -+ pondtekens -+ ponems -+ ponsstroken -+ ponsstrook -+ ponstypist -+ ponstypisten -+ ponstypistes -+ pontificalen -+ pontificaten -+ ponywagen -+ ponywagens -+ poolbiljart -+ poolde -+ poolers -+ pooling -+ poolkappen -+ poolkring -+ poolkringen -+ pools -+ poolweefsels -+ poolwinden -+ poortdeuren -+ poorterrecht -+ poorterrechten -+ poortgebouwen -+ poortwachtersfunctie -+ pootafdruk -+ pootafdrukken -+ pootui -+ pootuien -+ pop-up -+ pop-upkaart -+ pop-upkaarten -+ pop-upreclame -+ pop-upreclames -+ pop-ups -+ popachtig -+ popachtige -+ popband -+ popbands -+ popconcerten -+ popcultuur -+ popencyclopedie -+ popfestivals -+ popgroepen -+ popiejopie -+ popiejopies -+ popkunstenaar -+ popkunstenaars -+ poppedein -+ poppedeine -+ poppedeinen -+ poppenkastpersonage -+ poppenkastvoorstelling -+ poppenkastvoorstellingen -+ poppenkleertjes -+ poppenmaker -+ poppenmakers -+ poppenmethode -+ poppenmoeder -+ poppenmoeders -+ poppenspelers -+ poppentheaters -+ poppenwagens -+ poppenwagentje -+ popscene -+ popsong -+ popsongs -+ popstations -+ popsterren -+ populairwetenschappelijk -+ populairwetenschappelijke -+ popularisatoren -+ popularisators -+ popularisering -+ populariteitscijfer -+ populariteitscijfers -+ populariteitspoll -+ populariteitspolls -+ populariteitsscore -+ populariteitsscores -+ populatie-ecologie -+ populatiedichtheden -+ populatiedichtheid -+ populisten -+ populistische -+ popzangeressen -+ popzangers -+ popzenders -+ porknokker -+ porknokkers -+ porno's -+ porno-industrie -+ pornoactrice -+ pornoactrices -+ pornobioscoop -+ pornobioscopen -+ pornoblaadje -+ pornoblad -+ pornobladen -+ pornoshow -+ pornoshows -+ pornoster -+ pornosterren -+ pornosterretje -+ pornotheken -+ porseleinhoen -+ porseleinhoenders -+ porseleinhoenen -+ porseleinhoentje -+ portaalkranen -+ portables -+ portakabin -+ portakabins -+ portal -+ portals -+ portatieven -+ portefeuillehouder -+ portefeuillehouders -+ portefeuilleverdeling -+ portfolio's -+ portiekgesprek -+ portiekgesprekken -+ portierramen -+ porto's -+ portretfotograaf -+ portretfotografen -+ portretgalerijen -+ portretrecht -+ portretrechten -+ portretschilderen -+ portretstudies -+ portrettengalerij -+ portrettering -+ positiebepaling -+ positiebepalingen -+ positiejurken -+ positiespelletje -+ positieverbetering -+ positieverbeteringen -+ positiewisseling -+ positiewisselingen -+ positivo's -+ positronen -+ possessieve -+ possessieven -+ postacademische -+ postauto's -+ postautootje -+ postbesteller -+ postbestellers -+ postbestellingen -+ postbezorging -+ postbox -+ postboxen -+ postbusnummers -+ postcheque-en-girodienst -+ postchequerekening -+ postcodeboeken -+ postcommunistische -+ postdata -+ postdatums -+ postdocs -+ postelectorale -+ posterieure -+ postgraduaat -+ postgraduate -+ postgraduaten -+ postideologische -+ postimpressionist -+ postimpressionisten -+ postincunabelen -+ postjes -+ postkamers -+ postkoetsen -+ postkoloniale -+ postloketten -+ postmandaat -+ postmandaten -+ postmodernen -+ postmortale -+ postnummers -+ postogrammen -+ postolympische -+ postontvanger -+ postontvangers -+ postoperatieve -+ postorderactiviteiten -+ postordercatalogi -+ postordercatalogus -+ postordercatalogussen -+ postpositie -+ postpostscriptum -+ posttraumatische -+ postvakken -+ postvatten -+ postverbindingen -+ postvirale -+ postzegelbeurzen -+ postzegelcatalogi -+ postzegelcatalogussen -+ postzending -+ pot-au-feu -+ potdorie -+ potemkinfaçade -+ potenrammen -+ potenrammer -+ potenrammers -+ potentiaalfunctie -+ potentiaalfuncties -+ potentiaalverschillen -+ potentieprobleem -+ potentieproblemen -+ pothelm -+ pothelmen -+ pothoeden -+ potjandorie -+ potlatch -+ potlatches -+ potloodhouders -+ potloodlijn -+ potloodlijnen -+ potloodlijntje -+ potloodschets -+ potloodschetsen -+ potloodstreep -+ potloodstrepen -+ potloodventers -+ potmeter -+ potmeters -+ potpolder -+ potpoldergebied -+ potpoldergebieden -+ potpolders -+ potpoldertje -+ potpourri's -+ potstal -+ potstallen -+ pottenbakkersovens -+ pottenbakkersschijven -+ pottenschuur -+ potteuze -+ potverdikke -+ potverdomme -+ potverteerd -+ potverteerde -+ poulain -+ poulains -+ poule-indeling -+ poulewedstrijd -+ poulewedstrijden -+ poulewinnaar -+ poulewinnaars -+ powerlifters -+ powertennis -+ powisi -+ poëma's -+ poësisleraar -+ poësisleraars -+ poësisleraren -+ poëtica's -+ poëticale -+ poëzieavond -+ poëziedebuut -+ poëziefestival -+ poëziefestivals -+ poëzieopvatting -+ poëzieprijs -+ pr -+ pr-bureau -+ pr-bureaus -+ pr-medewerker -+ pr-medewerkers -+ praalbogen -+ praalboog -+ praatavonden -+ praatbarak -+ praatbarakken -+ praatgroepen -+ praatpalen -+ praatpapier -+ praatpapieren -+ praats -+ praatshows -+ praatstukken -+ prachtdag -+ prachtdagen -+ prachtkleden -+ prachtkleur -+ prachtkleuren -+ prachtvol -+ prachtvolle -+ prachtvrouw -+ prachtvrouwen -+ practical jokes -+ practical-joker -+ practical-jokers -+ pragmatisten -+ pragmatistische -+ prairiepaard -+ prairiepaarden -+ praktijkdiploma's -+ praktijkexamens -+ praktijkjaar -+ praktijkjaren -+ praktijkleraar -+ praktijkleraars -+ praktijkleraren -+ praktijkles -+ praktijklessen -+ praktijklokalen -+ praktijkproef -+ praktijkproeven -+ praktijkruimten -+ praktijkruimtes -+ pralerig -+ pralerige -+ prangend -+ prangende -+ pre's -+ pre-embryo -+ pre-embryo's -+ pre-emeritaat -+ pre-existent -+ pre-existente -+ pre-industrieel -+ pre-industriële -+ pre-islamitisch -+ pre-islamitische -+ preadviseerde -+ preambules -+ prebiotische -+ preboreaal -+ preboreale -+ precambrium -+ precario's -+ preciezen -+ precipiteerde -+ preciseringen -+ precisieaanval -+ precisieaanvallen -+ precisiebombardement -+ precisiebombardementen -+ precisiewapen -+ precisiewapens -+ precolumbiaans -+ precolumbiaanse -+ precommunistische -+ predatiedruk -+ predatoren -+ predators -+ predestinatieleer -+ predicaat -+ predicaten -+ predicatie -+ predicaties -+ predicatieve -+ predicatiën -+ prediceerde -+ preekgestoelte -+ preekverbod -+ pref -+ prefabhuis -+ prefabhuizen -+ prefabwoning -+ prefabwoningen -+ preferentiële -+ prefigeerde -+ prefiguraties -+ prehistorici -+ preiring -+ preiringen -+ prejudiciële -+ prekerigheid -+ preklinische -+ premenstruele -+ premetro's -+ premie A-woning -+ premie A-woningen -+ premie-inkomen -+ premie-inkomens -+ premie-inkomsten -+ premieafdracht -+ premieafdrachten -+ premiebedragen -+ premiebijdrage -+ premiegeld -+ premiegelden -+ premiegrenzen -+ premieheffingen -+ premiejagers -+ premiekoopwoning -+ premiekoopwoningen -+ premiekorting -+ premielast -+ premielonen -+ premieobligaties -+ premieomzet -+ premiepercentages -+ premiertje -+ premiespaarplannen -+ premiesparen -+ premiestelling -+ premietarief -+ premietarieven -+ premievrijstelling -+ premiewoningen -+ premiums -+ premièredag -+ premièrepubliek -+ premièrevoorstelling -+ premièrevoorstellingen -+ premoderne -+ premolaren -+ prentenatlassen -+ preoccupeerde -+ preolympische -+ prepaidkaart -+ prepaidkaarten -+ preparateurs -+ preparaties -+ preparé -+ prepaykaart -+ prepaykaarten -+ prepensioenen -+ prequel -+ prequels -+ prerevolutionaire -+ presentatieruimten -+ presentators -+ presentatrices -+ presenteerbladen -+ presessen -+ president-commissaris -+ president-commissarissen -+ president-curator -+ president-curatoren -+ president-curators -+ president-diaken -+ president-diakens -+ president-directeur -+ president-directeuren -+ president-directeurs -+ presidentsverkiezing -+ presidentsvrouwe -+ presidentsvrouwen -+ presidentverkiezing -+ presidentverkiezingen -+ presides -+ pressievoetbal -+ pressing -+ pressurecookers -+ prestatie-eis -+ prestatie-eisen -+ prestatiebeurs -+ prestatiebeurzen -+ prestatiedruk -+ prestatiegericht -+ prestatiegerichte -+ prestatielonen -+ prestatielopen -+ prestatiemoraal -+ prestatieve -+ prestatievermogens -+ presteerder -+ presteerders -+ prestigekwesties -+ prestigeobject -+ prestigeobjecten -+ prestigeproject -+ prestigeprojecten -+ prestigeslag -+ prestigeverlies -+ prestigezaak -+ prestrategische -+ pretentieloosheid -+ pretexten -+ pretlichtje -+ pretlichtjes -+ pretnet -+ pretnetten -+ pretoogjes -+ pretparken -+ prevelementen -+ preventiebeleid -+ preventiemaatregel -+ preventiemaatregelen -+ preventiemedewerker -+ preventiemedewerkers -+ preventiemogelijkheden -+ preventieproject -+ preventieprojecten -+ preventiezorg -+ preëminent -+ preëminente -+ preëminentie -+ priemvormig -+ priemvormige -+ priesterfeesten -+ priesterjubilea -+ priesterjubileums -+ priesteropleiding -+ priesteropleidingen -+ priestertekort -+ priestertje -+ prijs-kwaliteitverhouding -+ prijs-loonspiraal -+ prijsaanpassing -+ prijsaanpassingen -+ prijsbepalingen -+ prijsberekeningen -+ prijsconcessie -+ prijsconcessies -+ prijscontroles -+ prijsdrukkend -+ prijsdrukkende -+ prijsfluctuatie -+ prijsfluctuaties -+ prijsherstel -+ prijsindexcijfer -+ prijsindexcijfers -+ prijsindexen -+ prijsindexering -+ prijsindices -+ prijsinflatie -+ prijskaarten -+ prijskartels -+ prijskraker -+ prijskrakers -+ prijsoorlogen -+ prijsslag -+ prijsslagen -+ prijsspiralen -+ prijsstops -+ prijsvechter -+ prijsvechters -+ prijzenkasten -+ prijzenpot -+ prijzenregen -+ prijzenslagen -+ prijzenstops -+ prikkaarten -+ prikkeldraadhek -+ prikkeldraadhekken -+ prikkelende -+ prikkeloverdracht -+ priklimonades -+ prikpillen -+ prikstokken -+ prikwater -+ prima's -+ primatologen -+ primatologie -+ primatoloog -+ primauteit -+ primetime -+ primitivistische -+ primula's -+ primus inter pares -+ principe-uitspraak -+ principe-uitspraken -+ principeakkoord -+ principebeslissing -+ principebeslissingen -+ principeloos -+ principeloze -+ principeovereenkomst -+ principeverklaring -+ principeverklaringen -+ prins-bisschop -+ prins-bisschoppen -+ prins-gemaal -+ prins-regenten -+ prinsenhoven -+ prinsenkind -+ prinsenkinderen -+ prinses-gemalin -+ print-outs -+ printerdriver -+ printerdrivers -+ prints -+ prinzipienreiterei -+ priorin -+ priorinnen -+ prioritaire -+ prioriteerde -+ prioriteitenlijst -+ prioriteitenlijsten -+ prioriteitenprogramma -+ prioriteitenstelling -+ prioriteitenstellingen -+ prioriteitstelling -+ prioriteitstellingen -+ prioriteren -+ privaatdocentschap -+ privaatweg -+ privaatwegen -+ privacyaspecten -+ privacybescherming -+ privacyeis -+ privacyeisen -+ privacyreglement -+ privacyreglementen -+ privacywet -+ privacywetten -+ privatiseringen -+ privatiseringsoperatie -+ privatiseringsoperaties -+ privatiseringsproject -+ privatiseringsronde -+ privatiseringsronden -+ privatiseringsrondes -+ privé-initiatief -+ privé-initiatieven -+ privé-uitgave -+ privé-uitgaven -+ privéaangelegenheden -+ privéaangelegenheid -+ privéauto -+ privéauto's -+ privébank -+ privébanken -+ privébedrijf -+ privébelegging -+ privébeleggingen -+ privébezit -+ privéchauffeur -+ privéchauffeurs -+ privédetective -+ privédetectives -+ privégebruik -+ privégesprek -+ privégesprekken -+ privéjet -+ privéjets -+ privékarakter -+ privéleger -+ privélegers -+ privélegertje -+ privéonderwijs -+ privépersonen -+ privépersoon -+ privéreis -+ privéreizen -+ privérekening -+ privérekeningen -+ privéscholen -+ privéschool -+ privésecretaris -+ privésecretarissen -+ privésector -+ privésfeer -+ privévermogen -+ privévermogens -+ privéverzameling -+ privéverzamelingen -+ privézaak -+ privézaken -+ pro-Amerikaanse -+ pro-Deoadvocaat -+ pro-Deoadvocaten -+ pro-Duitse -+ pro-Europees -+ pro-Europese -+ pro-Iraaks -+ pro-Iraakse -+ pro-Iraans -+ pro-Iraanse -+ pro-Israëlisch -+ pro-Israëlische -+ pro-Koerdische -+ pro-Russische -+ pro-Servisch -+ pro-Servische -+ pro-Syrische -+ pro-formazittingen -+ proactief -+ proactieve -+ probatie -+ probleemdrinkers -+ probleemgerichte -+ problematiseerde -+ problematisering -+ procedeetje -+ procedureafspraak -+ procedureafspraken -+ procedureregels -+ procedurevoorschrift -+ procedurevoorschriften -+ procedé -+ procedés -+ procentnorm -+ procenttekens -+ procesgangen -+ procesoperators -+ procesrechtelijk -+ processierups -+ processierupsen -+ procestechniek -+ proceswater -+ procommunistisch -+ procommunistische -+ procope's -+ procopes -+ procrustesbed -+ procyclische -+ prodecaan -+ prodecanen -+ prodemocratisch -+ prodemocratische -+ produce -+ producen -+ producentenlanden -+ producentenprijs -+ producentenprijzen -+ producers -+ producet -+ producete -+ productassortiment -+ productenaanbod -+ productie-eenheden -+ productie-eenheid -+ productie-installatie -+ productie-installaties -+ productie-uitbreiding -+ productieassistent -+ productieassistenten -+ productiebeperking -+ productiebeperkingen -+ productiebossen -+ productiechefs -+ productiecijfer -+ productiecycli -+ productiedaling -+ productiedalingen -+ productiefasen -+ productiefases -+ productiefout -+ productiefouten -+ productiefst -+ productiegebied -+ productiegebieden -+ productiegoederen -+ productiehallen -+ productiehuishoudingen -+ productieketens -+ productieleiders -+ productielijnen -+ productiemethodes -+ productiemodel -+ productiemodellen -+ productieniveaus -+ productienorm -+ productienormen -+ productieomzet -+ productiepeil -+ productieplan -+ productieplannen -+ productieprijs -+ productieprijzen -+ productieprogramma's -+ productierijp -+ productierijpe -+ productieschema's -+ productiestatistiek -+ productiestatistieken -+ productiestop -+ productiestops -+ productiestrategie -+ productiestrategieën -+ productietechniek -+ productietempo -+ productievergroting -+ productievermindering -+ productievermogen -+ productiewijzen -+ productinnovatie -+ productionele -+ productiviteitsgroei -+ productiviteitsontwikkeling -+ productiviteitsstijging -+ productiviteitsstijgingen -+ productiviteitsverbeteringen -+ productiviteitsverlies -+ productmanager -+ productschappen -+ productsector -+ productsectoren -+ proefabonnementen -+ proefballonnen -+ proefboerderijen -+ proefbuisbaby -+ proefbuisbaby's -+ proefdieronderzoek -+ proefdraaide -+ proefexemplaar -+ proefexemplaren -+ proefexplosie -+ proefexplosies -+ proeffabriek -+ proefgereden -+ proefinstallaties -+ proefmetingen -+ proefmodel -+ proefmodellen -+ proefplaat -+ proefplaten -+ proefprocedure -+ proefprocedures -+ proefprojecten -+ proefreactor -+ proefrijden -+ proefseries -+ proefspel -+ proefstadia -+ proefstroken -+ proefterrein -+ proefterreinen -+ proefuitzending -+ proefuitzendingen -+ proefvaarde -+ proefvakken -+ proefverloven -+ proefvertaling -+ proefvertalingen -+ proefvoorstelling -+ proefvoorstellingen -+ proefwerkblaadje -+ proefwerkweek -+ proestbuien -+ proeverij -+ profafdeling -+ profbasketbal -+ profboksen -+ profbokser -+ profboksers -+ profcarrière -+ profcircuit -+ profclubs -+ profcontract -+ profcontracten -+ profdebuut -+ professionaliseerde -+ professorentoga -+ professorentoga's -+ profhonkbal -+ profieldeel -+ profielwerkstuk -+ profielwerkstukken -+ profielzolen -+ profijtig -+ profijtige -+ profileerdrang -+ profiler -+ profileringsdrift -+ profilers -+ profitabele -+ profje -+ proflicentie -+ proflicenties -+ profliga -+ profpartij -+ profploegen -+ profrenner -+ profrenners -+ profspelers -+ profsport -+ profsporten -+ profteams -+ proftennis -+ profvoetballer -+ profvoetballers -+ profwielrenner -+ profwielrenners -+ progestagenen -+ progestatieve -+ prognosticeerde -+ prognostische -+ programakkoord -+ programcolleges -+ programcommissie -+ programma-aanbod -+ programma-akkoord -+ programmabladen -+ programmaboek -+ programmaboeken -+ programmadirecteur -+ programmaoverzicht -+ programmaschijven -+ programmeringen -+ progressief-liberaal -+ progressief-liberale -+ projectaanvraag -+ projectaanvragen -+ projectbureaus -+ projectdrager -+ projectdragers -+ projectfinanciering -+ projectgebonden -+ projectiedoek -+ projectiedoeken -+ projectieschermen -+ projectieve -+ projectmanagers -+ projectmedewerker -+ projectonderzoek -+ projectontwikkelaars -+ projectontwikkelingsmaatschappij -+ proleptische -+ promenadeconcert -+ promenadeconcerten -+ promilitaire -+ promillages -+ promo's -+ promofilm -+ promofilms -+ promootte -+ promotiecampagnes -+ promotiecommissie -+ promotiecommissies -+ promotieklassen -+ promotieonderzoek -+ promotieplaats -+ promotieplaatsen -+ promotieplechtigheid -+ promotiereglement -+ promotiereglementen -+ promotiereis -+ promotieverloven -+ pronkzuchtig -+ pronkzuchtige -+ prooidier -+ prooidieren -+ propaganda-afdeling -+ propaganda-instrument -+ propaganda-instrumenten -+ propaganda-uitzending -+ propaganda-uitzendingen -+ propagandachef -+ propagandachefs -+ propagandaoorlog -+ propagandastunt -+ propedeuses -+ propedeutische -+ propositielogica -+ proppenschieters -+ propperig -+ propperige -+ prostaatkanker -+ prostaatklier -+ prostaatklieren -+ prostaatoperatie -+ prostaatoperaties -+ prostaatvergroting -+ prostituanten -+ prostitueetje -+ prostitutiebedrijf -+ prostitutiebeleid -+ prostitutiewereld -+ prostitués -+ protegee -+ protegeetje -+ protegé -+ protegés -+ proterozoïcum -+ protestacties -+ protestantes -+ protestantisering -+ protestants-christelijk -+ protestants-christelijke -+ protestbewegingen -+ protestbijeenkomst -+ protestbijeenkomsten -+ protestdag -+ protestdagen -+ protestmanifestatie -+ protestmanifestaties -+ protestmarsen -+ protestnota's -+ protestoptochten -+ protestsongs -+ proteststem -+ proteststemmen -+ protestzangers -+ proteïnerijk -+ proteïnerijke -+ proteïnes -+ prothesemaker -+ prothesemakers -+ prothesissen -+ protocols -+ protonen -+ protonkaart -+ protonkaarten -+ protonraket -+ prototypische -+ protserigheid -+ provenu's -+ provinciaals -+ provinciaalse -+ provincialistische -+ provincieambtenaar -+ provincieambtenaren -+ provinciebestuur -+ provinciegouverneur -+ provinciegouverneurs -+ provinciehoofdplaats -+ provinciehuizen -+ provisie-inkomsten -+ provisiekosten -+ provisiestructuur -+ provisoria -+ provo's -+ provocatieve -+ provotijd -+ prowesters -+ prowesterse -+ proxyservers -+ prozabundel -+ prozadebuut -+ prozagedicht -+ prozagedichten -+ prozaroman -+ prozaromans -+ prozastuk -+ prozastukken -+ prozatekst -+ prozateksten -+ prozavertaling -+ prudente -+ pruikenkop -+ pruikenkoppen -+ pruillippen -+ pruimbaar -+ pruimbare -+ pruimenmonden -+ pruimenpitten -+ pruimtomaat -+ pruimtomaten -+ prulachtig -+ prulachtige -+ prunussen -+ prutsdingen -+ prutserig -+ prutserige -+ psalmbord -+ psalmborden -+ psalmverzen -+ pseudo-intellectuelen -+ pseudo-isidorisch -+ pseudo-isidorische -+ pseudo-islamitische -+ pseudoconsensus -+ pseudofilosofisch -+ pseudofilosofische -+ pseudoklassiek -+ pseudoklassieke -+ pseudokoop -+ pseudokoopteam -+ pseudokoper -+ pseudokopers -+ pseudologieën -+ pseudovogelpest -+ pseudowetenschap -+ pseudowetenschappelijk -+ pseudowetenschappelijke -+ psychiater-seksuoloog -+ psychiaters-seksuologen -+ psychoactieve -+ psychoanalytici -+ psychobabbel -+ psychodrama's -+ psychodynamische -+ psychofarmacon -+ psychofysische -+ psychogene -+ psychogeriatrische -+ psychogrammen -+ psychohygiënische -+ psycholinguïsten -+ psychologes -+ psychologiestudie -+ psychologiseerde -+ psychometrische -+ psychometristen -+ psychoneurosen -+ psychoneuroses -+ psychopathieën -+ psychopathische -+ psychopathologische -+ psychoseaanval -+ psychoseaanvallen -+ psychosomatosen -+ psychotechnici -+ psychoten -+ psychotherapieën -+ psychotraumata -+ psychotrope -+ puberachtig -+ puberachtige -+ puberde -+ puberen -+ puberleeftijd -+ pubermeisje -+ pubermeisjes -+ puberteitscrises -+ puberteitscrisissen -+ puberteitsfasen -+ puberteitsfases -+ pubertijd -+ publicabele -+ publicatieblad -+ publicatiedata -+ publicatiedatum -+ publicatieplicht -+ publicdomainsoftware -+ publicistische -+ publiciteitsagent -+ publiciteitsagenten -+ publiciteitsbewust -+ publiciteitsbewuste -+ publiciteitsbureaus -+ publiciteitschef -+ publiciteitschefs -+ publiciteitsgeil -+ publiciteitsgeile -+ publiciteitsman -+ publiciteitsmedia -+ publiciteitsorganen -+ publiciteitsschuw -+ publiciteitsschuwe -+ publiciteitsstunts -+ publiciteitsvrouw -+ publicrelationsbureau -+ publicrelationsbureaus -+ publicrelationsmedewerker -+ publicrelationsmedewerkers -+ publieksactie -+ publieksacties -+ publieksboek -+ publieksboeken -+ publieksenquête -+ publieksenquêtes -+ publieksfilm -+ publieksfilms -+ publieksgerichte -+ publieksinformatie -+ publieksjury -+ publieksjury's -+ publieksomroep -+ publieksomroepen -+ publieksopkomst -+ publieksprijzen -+ publiekstijdschrift -+ publiekstijdschriften -+ publiekstrekkend -+ publiekstrekkende -+ publieksvoorlichting -+ publieksvriendelijk -+ publieksvriendelijke -+ pubs -+ pucks -+ puddingbroodje -+ puddingbroodjes -+ puddinglepel -+ puddinglepels -+ puddingmengsel -+ puddingsaus -+ puddingsausen -+ puddingsauzen -+ pueblo's -+ pugilisten -+ puibalk -+ puibalken -+ puinbrok -+ puinbrokken -+ puinfunderingen -+ puingeruimd -+ puingesteenten -+ puingesteentes -+ puinkegel -+ puinkegels -+ puinruimers -+ puissances -+ puissante -+ pukcode -+ pullover -+ pullovers -+ pulls -+ pulmonale -+ pulpblad -+ pulpbladen -+ pulpboek -+ pulpboeken -+ pulpindustrie -+ pulproman -+ pulpromans -+ pulsars -+ pulverde -+ pulveren -+ punkband -+ punkbands -+ punkers -+ punkgroep -+ punkgroepen -+ punkkapsels -+ punkrock -+ punktijd -+ puntbogen -+ puntboog -+ puntbroodje -+ puntbroodjes -+ puntbuik -+ puntbuiken -+ puntdaken -+ puntenaantal -+ puntenklassement -+ puntenkoers -+ puntenkoersen -+ puntenslijpers -+ puntenstelsels -+ puntentotaal -+ puntenwaarderingen -+ punterjachten -+ punthamer -+ punthamers -+ punthoeden -+ punthoofden -+ puntlipneushoorn -+ puntlipneushoorns -+ puntloos -+ puntloze -+ puntmutsen -+ puntneus -+ puntneuzen -+ puntvijlen -+ puntvormig -+ pupillenvoetbal -+ pupilreflex -+ pupilreflexen -+ pur -+ purperhart -+ purperverf -+ purschuim -+ push-up -+ push-up-bh -+ push-up-bh's -+ push-up-bh'tje -+ push-upbeha -+ push-upbeha's -+ push-upbehaatje -+ push-ups -+ pusher -+ pushers -+ pusht -+ pushte -+ putdeksels -+ putjesscheppers -+ putoptie -+ putopties -+ putranden -+ putschisten -+ putt -+ puttenzuigers -+ putti -+ putts -+ puzzelkubussen -+ puzzelstukje -+ puzzelstukjes -+ puzzeltochten -+ puzzelwerk -+ puzzelwoordenboek -+ puzzelwoordenboeken -+ pvc -+ pvc-buis -+ pvc-buizen -+ pyrimidine -+ pyrimidinen -+ pyrimidines -+ pyroclastisch -+ pyroclastische -+ pyromanen -+ pyrrusoverwinning -+ pyrrusoverwinningen -+ q's -+ q'tje -+ q.q. -+ quadrafonische -+ quadragesima -+ quaestrices -+ qualitate-quafunctie -+ qualitate-quafuncties -+ quarantainepolitiek -+ quarterback -+ quarterbacks -+ quartés -+ quasars -+ quasi-intellectueel -+ quasi-intellectuelen -+ quasiauthentiek -+ quasiauthentieke -+ quasimodo -+ quasinonchalant -+ quasionschuldig -+ quasionschuldige -+ quasiwetenschappelijk -+ quasiwetenschappelijke -+ queesten -+ queruleerde -+ queueën -+ quiches -+ quinquagesima -+ quislings -+ quizleiders -+ quizmasters -+ quotaregeling -+ quotastelsel -+ quotasysteem -+ quoteje -+ quoteringen -+ quoteringsregeling -+ quoteringssysteem -+ quotes -+ quotumregeling -+ qwertyklavier -+ qwertyklavieren -+ r'en -+ r'etje -+ r's -+ r.-k. -+ ra's -+ raadsadviseur -+ raadsadviseurs -+ raadscommissies -+ raadsdebat -+ raadsdebatten -+ raadsfracties -+ raadskelder -+ raadskelders -+ raadslidmaatschap -+ raadspensionaris -+ raadspensionarissen -+ raadsstukken -+ raadsvoorzitterschap -+ raakheid -+ raambekleding -+ raambekledingsfabrikant -+ raambekledingsproduct -+ raambekledingsproducten -+ raamcontract -+ raamkant -+ raamkanten -+ raamkoord -+ raamloos -+ raamloze -+ raamopeningen -+ raamovereenkomst -+ raampost -+ raamposten -+ raamprofiel -+ raamprofielen -+ raamprostitutie -+ raamsponningen -+ raamverdrag -+ raamvertellingen -+ raamwetten -+ rabbinica -+ rabiate -+ raceauto's -+ raceboten -+ racecircuits -+ racekak -+ racerij -+ racesturen -+ raceteam -+ rachitische -+ rachmones -+ racismebestrijding -+ racketeers -+ racketmateriaal -+ radarantennes -+ radarbeeld -+ radarbeelden -+ radardetector -+ radardetectoren -+ radardetectors -+ radarecho -+ radarecho's -+ radargolf -+ radargolven -+ radarpost -+ radarposten -+ radarreflector -+ radarreflectoren -+ radarreflectors -+ radarsignaal -+ radarsignalen -+ radarstraling -+ radartje -+ radartorens -+ radarwaarnemers -+ radeernaald -+ radeernaalden -+ radeerstiften -+ radencommunisme -+ raderwerken -+ raderwieltjes -+ radiaalband -+ radicaal-links -+ radicaal-linkse -+ radicaaldemocratisch -+ radicaaldemocratische -+ radicaalfeministisch -+ radicaalfeministische -+ radicaalislamitisch -+ radicaalislamitische -+ radicaalnationalistisch -+ radicaalnationalistische -+ radicaliseerde -+ radicaliseringen -+ radices -+ radikalinski's -+ radio-interview -+ radio-interviews -+ radio-isotoop -+ radio-isotopen -+ radio-ontvanger -+ radio-ontvangers -+ radio-opname -+ radio-opnamen -+ radio-opnames -+ radio-orkest -+ radio-orkesten -+ radioamateurs -+ radioantenne -+ radioantennen -+ radioantennes -+ radiobesturing -+ radiobiologie -+ radiobiologische -+ radiobodes -+ radioboodschap -+ radioboodschappen -+ radiobron -+ radiobronnen -+ radiobuis -+ radiobuizen -+ radiocassetterecorders -+ radiocommentatoren -+ radiocommentators -+ radiocommercial -+ radiocommercials -+ radiocontact -+ radiodiagnost -+ radiogesprek -+ radiogesprekken -+ radiogidsen -+ radiogolf -+ radiogolven -+ radiojournaals -+ radiokamer -+ radiokamers -+ radiolyse -+ radiometrische -+ radiomeubel -+ radiomeubelen -+ radiomeubels -+ radiomuziek -+ radionet -+ radionetten -+ radiopeiler -+ radiopeilers -+ radiopeiltoestel -+ radiopeiltoestellen -+ radiopiraat -+ radiopiraten -+ radioreclame -+ radioreporters -+ radiorubriek -+ radiosignaal -+ radiosignalen -+ radiosondes -+ radiospot -+ radiospots -+ radioster -+ radiosterrenkunde -+ radiosterrenwacht -+ radiostilte -+ radiostoringen -+ radiostudio -+ radiotaks -+ radiotalkshow -+ radiotalkshows -+ radiotelefoon -+ radiotelefoons -+ radiotelegrafisten -+ radiotoespraak -+ radiotoespraken -+ radioverbinding -+ radioverslaggever -+ radioverslaggevers -+ radiovraaggesprek -+ radiowekker -+ radiowekkers -+ radiozendinstallatie -+ radiozendinstallaties -+ radiumzout -+ radiumzouten -+ radslag -+ radslagen -+ rafelrand -+ raffinage-industrie -+ raffinagecapaciteit -+ raffinageproduct -+ raffinageproducten -+ raffinagesector -+ ragoutje -+ rai -+ raider -+ raiders -+ railauto's -+ railinfrastructuur -+ railkanon -+ railkanonnen -+ railnet -+ railtraject -+ railverbinding -+ railverbindingen -+ railverkeer -+ railvervoer -+ railvoertuig -+ railvoertuigen -+ raio's -+ raketaanval -+ raketaanvallen -+ raketafweer -+ raketbases -+ raketbasissen -+ raketgranaat -+ raketgranaten -+ raketmotors -+ raketsilo -+ raketsilo's -+ rakettencrisis -+ rakettendebat -+ rakettenproductie -+ rakettrappen -+ raketwerpers -+ raku -+ rallycross -+ rallycrossen -+ rallycrosses -+ rallyrijder -+ rallyrijders -+ ramadanfeest -+ ramadanfeesten -+ rambo -+ rambo's -+ ramboetan -+ ramboetans -+ ramin -+ ramkoers -+ ramkraak -+ ramkraken -+ rampenbestrijding -+ rampenbestrijdingsplan -+ rampenbestrijdingsplannen -+ rampenfilm -+ rampenfilms -+ rampenfondsen -+ rampenplannen -+ rampetampte -+ rampjaren -+ rampsituaties -+ ramptoerisme -+ ramptoerist -+ ramptoeristen -+ rampvlucht -+ rancho's -+ randbemerking -+ randbemerkingen -+ randfiguren -+ randfunctie -+ randfuncties -+ randgebieden -+ randgroepen -+ randgroepjongere -+ randkerkelijk -+ randkerkelijke -+ random -+ random access memory -+ randpion -+ randpionnen -+ randprobleem -+ randproblemen -+ randschijf -+ randschijven -+ randstedeling -+ randstedelingen -+ randsteden -+ randstoringen -+ randwegen -+ rangeeremplacement -+ rangeeremplacementen -+ rangeerheuvels -+ rangeerlocomotieven -+ rangenstelsels -+ ranges -+ ranglijstaanvoerder -+ rangorden -+ rantsoenbon -+ rantsoenbons -+ rapaillepolitici -+ rapaillepoliticus -+ rapcrew -+ rapcrews -+ rapgroep -+ rapgroepen -+ rapmuziek -+ rapnummer -+ rappers -+ rapplaat -+ rapplaten -+ rapportageplicht -+ rapportageverplichting -+ raps -+ rapsodische -+ rapstijl -+ rapte -+ raptekst -+ rapteksten -+ rarae aves -+ rasartiest -+ rasartiesten -+ rasegoïst -+ rasegoïsten -+ rasgenoot -+ rasgenoten -+ raspaardjes -+ rasperig -+ rasperige -+ raspsel -+ rassenkunde -+ rassenkwesties -+ rassenleer -+ rassenlijst -+ rassenonderzoek -+ rassenproblemen -+ rassenscheidingen -+ rassenwet -+ rassenwetten -+ rasta's -+ rastafari -+ rastafari's -+ rastakapsel -+ rastercliché -+ rasterclichés -+ rasterpatroon -+ rasvereniging -+ rasverenigingen -+ ratelboor -+ ratelboren -+ ratelschroevendraaier -+ ratelschroevendraaiers -+ ratificatieprocedure -+ ratificatieprocedures -+ ratificatieproces -+ ratificering -+ ratingpunt -+ ratingpunten -+ ratsmodee -+ rattenkop -+ rattenkoppen -+ rattenkruid -+ rattenplagen -+ rattenvallen -+ rausde -+ rauwdouwde -+ rauwdouwen -+ rauwdouwers -+ rauwelijkse -+ ravigotesaus -+ ravissante -+ rawlpluggen -+ rawlplugs -+ razzia-achtig -+ razzia-achtige -+ re's -+ re-integratie -+ re-integratieproject -+ re-integratieprojecten -+ re-integreerde -+ re-integreren -+ re-interpretatie -+ re-interpretaties -+ reactievat -+ reactievaten -+ reactievermogens -+ reactiveerde -+ reactivering -+ reactiveringen -+ reactorbrandstof -+ reactorcentrales -+ reactoren -+ reactorgebouw -+ reactorkern -+ reactors -+ reactorvat -+ reactorvaten -+ reactorwand -+ readers -+ readymades -+ reaffectaties -+ reaffecteerde -+ reaffecteren -+ reageerbuisbevruchting -+ reageerbuisbevruchtingen -+ realisatoren -+ realisators -+ realiteitsbesef -+ realiteitsgehalte -+ realiteitswaarde -+ reality-tv -+ realitysoap -+ realitysoaps -+ reallifesoap -+ reallifesoaps -+ realo's -+ realtimeonderzoek -+ reanimeerde -+ rebbelde -+ rebbelen -+ rebbes -+ rebellenbewegingen -+ rebellenclub -+ rebellenleger -+ rebellenleider -+ rebellenleiders -+ rebellenregering -+ reboot -+ rebooten -+ rebootte -+ recappen -+ recapte -+ receiver -+ receivers -+ recentst -+ receptenbundel -+ receptenschrijver -+ receptenschrijvers -+ receptformulieren -+ receptieboeken -+ receptiegeschiedenis -+ receptionist-telefonist -+ receptioniste-telefoniste -+ receptionisten-telefonisten -+ receptionistes-telefonistes -+ receptvrij -+ receptvrije -+ recessen -+ recessieachtig -+ recessiejaar -+ recessieve -+ recessieverschijnsel -+ recessieverschijnselen -+ rechaudje -+ recherchebijstandsteam -+ recherchebureau -+ recherchebureaus -+ recherchedienst -+ rechercheerde -+ rechercheonderzoek -+ recherches -+ rechercheteams -+ recherchewerk -+ rechtbankjury -+ rechtbankjury's -+ rechtbankthriller -+ rechtbankverslag -+ rechtbankverslagen -+ rechtenfaculteit -+ rechtenstudente -+ rechtenstudentes -+ rechtenstudies -+ rechter-plaatsvervanger -+ rechterbovenbeen -+ rechterdijbeen -+ rechterenkel -+ rechterflank -+ rechterhelften -+ rechtermiddenvelder -+ rechtermondhoek -+ rechteronderbeen -+ rechterschoen -+ rechterspits -+ rechtersrecht -+ rechterwang -+ rechterwijsvinger -+ rechterwijsvingers -+ rechtgehouden -+ rechtgemaakt -+ rechtgezeten -+ rechthouden -+ rechtmaken -+ rechtovereind -+ rechts-conservatief -+ rechts-conservatieve -+ rechts-extremistisch -+ rechts-extremistische -+ rechts-liberaal -+ rechts-liberale -+ rechts-populistisch -+ rechts-populistische -+ rechts-radicaal -+ rechts-radicale -+ rechts-radicalen -+ rechtsachter -+ rechtsachters -+ rechtsback -+ rechtsbacks -+ rechtsbeginselen -+ rechtsbeginsels -+ rechtsbenige -+ rechtsbetrekking -+ rechtsbevoegd -+ rechtsbevoegde -+ rechtschapene -+ rechtsdraaiend -+ rechtser -+ rechtsfaculteit -+ rechtsfaculteiten -+ rechtsfeit -+ rechtsfeiten -+ rechtsgebouwen -+ rechtsgelijkheid -+ rechtsgeschillen -+ rechtsgevoelens -+ rechtsgoed -+ rechtshalf -+ rechtshalfs -+ rechtshistorici -+ rechtshistoricus -+ rechtshistorie -+ rechtshistorisch -+ rechtshistorische -+ rechtsinstelling -+ rechtsinstellingen -+ rechtsinstituten -+ rechtskundigen -+ rechtsongelijkheden -+ rechtsopvatting -+ rechtsopvolger -+ rechtsopvolgers -+ rechtsorden -+ rechtsordes -+ rechtsorgaan -+ rechtsplichten -+ rechtspraktijken -+ rechtspsychologen -+ rechtspsycholoog -+ rechtsregelen -+ rechtssociologie -+ rechtsstudent -+ rechtsstudenten -+ rechtst -+ rechtstaten -+ rechtstradities -+ rechtsveiligheid -+ rechtsvergelijking -+ rechtvaardigheidsgevoelens -+ rechtvaardigheidsoverweging -+ rechtvaardigheidsoverwegingen -+ rechtvaardigingen -+ rechtzitten -+ rechute -+ rechutes -+ rechutetje -+ rechuutje -+ recidieven -+ recidivegevaar -+ recidivekans -+ recidivekansen -+ recidiven -+ recirculaties -+ recirculeerde -+ reclame-inkomsten -+ reclame-uitgaven -+ reclameaanbieding -+ reclameaanbiedingen -+ reclameachtig -+ reclameachtige -+ reclameadviesbureau -+ reclameadviesbureaus -+ reclameadviseurs -+ reclameaffiche -+ reclameaffiches -+ reclameblad -+ reclamebladen -+ reclameblok -+ reclameblokken -+ reclamechef -+ reclamechefs -+ reclamecodecommissies -+ reclamecodes -+ reclamedoeleinden -+ reclamefilm -+ reclamefilmpje -+ reclamejongen -+ reclamejongens -+ reclamekaravaan -+ reclamemaker -+ reclamemakers -+ reclameman -+ reclamemateriaal -+ reclamemedium -+ reclameomzet -+ reclameraden -+ reclamerecht -+ reclameschilder -+ reclamespots -+ reclamestunts -+ reclametechniek -+ reclametijd -+ reclamevakblad -+ reclamevliegtuigen -+ reclamewezen -+ reclamezendtijd -+ reclamezuilen -+ reclasseringsraad -+ reclasseringsrapport -+ reclasseringswerk -+ recombinant-DNA -+ recombinanten -+ recombineerde -+ reconciliaties -+ reconversies -+ recordaantallen -+ recordbedrag -+ recorddieptepunt -+ recorderdecks -+ recorders -+ recordhoogten -+ recordhoogtes -+ recordjaar -+ recordje -+ recordomzetten -+ recordopbrengst -+ recordpogingen -+ recordsprong -+ recordstand -+ recordtijden -+ recordwinst -+ recordwinsten -+ recreatiebedrijf -+ recreatiebungalow -+ recreatiebungalows -+ recreatiecentra -+ recreatiecentrum -+ recreatiedruk -+ recreatieoord -+ recreatieoorden -+ recreatieschap -+ recreatieschappen -+ recreatiesector -+ recreatiesporten -+ recreatieterreinen -+ recreatieverkeer -+ recreatievoorziening -+ recreatievoorzieningen -+ recreëerde -+ rectores magnifici -+ rectoscopen -+ rectrices -+ rectrixen -+ recuperaties -+ recycle -+ recyclebare -+ recyclede -+ recycleerde -+ recyclet -+ redacteurschap -+ redacteurtje -+ redactieadres -+ redactiebureel -+ redactieburelen -+ redactiechef -+ redactiechefs -+ redactielokaal -+ redactielokalen -+ reddingsbrigades -+ reddingshelikopter -+ reddingshelikopters -+ reddingsploeg -+ reddingspoging -+ reddingspogingen -+ reddingsvlotten -+ reddingswerker -+ redenaarskunst -+ redenaarstalenten -+ redeneerfout -+ redeneerfouten -+ redeneerkunst -+ redersvereniging -+ redoubletten -+ redplank -+ redplanken -+ reductiedeling -+ reductionistische -+ redundante -+ redzaamheid -+ reebruin -+ reebruine -+ reekshoofd -+ reekshoofden -+ reeë -+ referendumcampagne -+ referendumcommissie -+ referendumuitslag -+ referendumwet -+ referentiegroepen -+ referentiejaar -+ referentiepunten -+ referentiewaarde -+ referte-eis -+ reflectiecoëfficiënt -+ reflectieschermen -+ reflectieve -+ reflectorische -+ reflexcamera's -+ reflexhamers -+ refo -+ refo's -+ reformateurs -+ reformhuizen -+ reformwinkels -+ reformzaak -+ reformzaken -+ refractometers -+ refutaties -+ regeerambt -+ regeerbaar -+ regeerbaarheid -+ regeerbare -+ regeermacht -+ regeerprogramma -+ regeerstijl -+ regeldrukkers -+ regelgen -+ regelgenen -+ regelgevingen -+ regelingslonen -+ regelingsloon -+ regelkamers -+ regelneef -+ regelneven -+ regelstaaf -+ regeltechnici -+ regeltechnicus -+ regeltransformatoren -+ regeltransformators -+ regelverdichting -+ regelweerstanden -+ regelwijzers -+ regelzucht -+ regenboogcoalitie -+ regenboogforel -+ regenboogforellen -+ regenboogjacht -+ regenboogjachten -+ regenboogklasse -+ regenboogtruien -+ regenbroeken -+ regendans -+ regeneraten -+ regeneratieve -+ regeneratievermogen -+ regenfronten -+ regengod -+ regengoden -+ regengordijnen -+ regeninstallaties -+ regenjacks -+ regenluchten -+ regenmachines -+ regenrijk -+ regentaten -+ regentendom -+ regentenscholen -+ regentenschool -+ regenteske -+ regentschapsraad -+ regentschapsraden -+ regenwulp -+ regenwulpen -+ regenzones -+ regeringsambtenaar -+ regeringsambtenaren -+ regeringsbeslissing -+ regeringsbesluit -+ regeringscolleges -+ regeringscrises -+ regeringscrisissen -+ regeringsfractie -+ regeringsfracties -+ regeringsfunctionarissen -+ regeringsjaar -+ regeringsjaren -+ regeringsjubilea -+ regeringsjubileums -+ regeringsleger -+ regeringsmededeling -+ regeringsonderhandelaar -+ regeringsraad -+ regeringsrapport -+ regeringsstandpunten -+ regeringsstuk -+ regeringsstukken -+ regeringstermijn -+ regeringstopper -+ regeringstoppers -+ regeringsvertegenwoordiger -+ regeringsvertegenwoordigers -+ regeringsvoorlichtingsdienst -+ regeringsvoorstel -+ regeringsvoorstellen -+ regeringswisseling -+ regeringswisselingen -+ regeringswoordvoerder -+ regeringswoordvoerders -+ regeringszetels -+ reggaenummer -+ reggaezanger -+ regieaanwijzing -+ regieaanwijzingen -+ regiekamers -+ regiempje -+ regieopleiding -+ regieprijs -+ regiezitting -+ regiezittingen -+ regimetje -+ regio-indeling -+ regio-indelingen -+ regiokorting -+ regiokortingen -+ regiolecten -+ regiomanager -+ regionaliseerde -+ regionalisering -+ regiotaxi -+ regiotaxi's -+ regiotrein -+ regiotreinen -+ regisseur-scenarist -+ regisseursduo -+ regisseurstheater -+ regisseurstoneel -+ registerwisseling -+ registerwisselingen -+ registratiebewijs -+ registratiebewijzen -+ registratiebureau -+ registratiebureaus -+ registratieve -+ reglementeringen -+ regularisatiewet -+ regularisatiewetten -+ reguleringen -+ reigerkolonie -+ reigerkolonies -+ reiki -+ reikimeester -+ reikimeesters -+ reinette -+ reiniger -+ reinigers -+ reinigingsbedrijf -+ reinigingscrèmes -+ reinigingspolitie -+ reinigingsrechten -+ reinigingsritueel -+ reisadvies -+ reisadviezen -+ reisagenten -+ reisbeperking -+ reisbeperkingen -+ reisbestemming -+ reisbijstandsverzekering -+ reisbrochure -+ reisbrochures -+ reisbussen -+ reischaaf -+ reischaven -+ reisdeclaraties -+ reisduur -+ reisfolder -+ reisfolders -+ reisgenotes -+ reisjournaal -+ reiskoorts -+ reiskostenforfait -+ reisleidsters -+ reisliteratuur -+ reissom -+ reissommen -+ reistijden -+ reisverslagen -+ reisverzekeringen -+ reiswekkers -+ reiswekkertje -+ reiswiegen -+ reizigersaanbod -+ reizigersdiarree -+ reizigerskilometer -+ reizigerstrein -+ reizigerstreinen -+ rekbanden -+ rekenapparaat -+ rekeneenheden -+ rekening-courantkrediet -+ rekening-courantkredieten -+ rekeningetje -+ rekeningrijden -+ rekeninguittreksel -+ rekeninguittreksels -+ rekenmachientje -+ rekenmachinetje -+ rekenopgaven -+ rekenplichtigen -+ rekenplichtigheid -+ rekensnelheid -+ rekentaak -+ rekentaken -+ rekentechniek -+ rekentruc -+ rekentrucs -+ rekenvergoeding -+ rekenvergoedingen -+ rekenvoorschrift -+ rekenvoorschriften -+ rekenwonders -+ rekoefening -+ rekoefeningen -+ rekruteringsbasis -+ rekverbanden -+ relaistje -+ relances -+ relatering -+ relateringen -+ relatiebemiddeling -+ relatiebureau -+ relatiebureaus -+ relatiestoornis -+ relatiestoornissen -+ relatietherapie -+ relatietherapieën -+ relatietraining -+ relatietrainingen -+ relativa -+ relativeringen -+ relativeringsvermogen -+ relaxatieoefening -+ relaxatieoefeningen -+ relaxaties -+ relaxt -+ reliekhouders -+ reliëfstip -+ reliëfstippen -+ rellerig -+ rellerige -+ relmaker -+ relmakers -+ relnicht -+ relnichten -+ relocatie -+ relocaties -+ relschopper -+ reltrapper -+ reltrappers -+ remafstanden -+ remakes -+ remaster -+ remastering -+ remasters -+ rembrandtesk -+ rembrandteske -+ remcilinder -+ remcilinders -+ remedial teachers -+ remedieerde -+ remenergie -+ remgeld -+ remigratiebeleid -+ remigreerde -+ reminder -+ reminders -+ remise-eindspel -+ remiseaanbod -+ remiseerde -+ remisepartij -+ remisestelling -+ remisevoorstel -+ remix -+ remixes -+ remixt -+ remixte -+ remkabels -+ remmingswerk -+ remnaven -+ remote sensing -+ remotesensingtechniek -+ remotesensingtechnieken -+ removers -+ remparachutes -+ remplaceerde -+ remproeven -+ remschijven -+ remslaap -+ remsporen -+ remsysteem -+ renaissance -+ renaissancekasteel -+ renaissancekastelen -+ renaissancescenario -+ renaissanceschilder -+ renaissancisten -+ renationaliseerde -+ renationalisering -+ rencontres -+ rendementseis -+ rendementseisen -+ rendementsniveau -+ rendementsverbetering -+ rendementsverwachting -+ rendierjager -+ rendierjagers -+ rennersvakbond -+ renstal -+ renstallen -+ rentabiliseerde -+ rentabiliseren -+ rente-effect -+ rente-inkomsten -+ rente-uitgaven -+ renteaanpassing -+ renteaanpassingen -+ rentebaten -+ rentedalingen -+ rentefonds -+ rentegever -+ rentegevers -+ rentegevoelig -+ rentegevoelige -+ rentegroeifonds -+ rentegroeifondsen -+ rentemarges -+ renteopbrengsten -+ rentestijgingen -+ rentesubsidieregeling -+ rentesubsidies -+ rentevast -+ rentevaste -+ rentevergoedingen -+ renteverhogingen -+ renteverlagingen -+ renteverschillen -+ rentevrijstelling -+ rentrees -+ renversalen -+ reorganisatiebureau -+ reorganisatiebureaus -+ reorganisatievoorziening -+ reorganisatievoorzieningen -+ reparabele -+ reparatiebedrijf -+ reparatiewerf -+ reparatiewerk -+ reparatiewerven -+ repartities -+ repatrianten -+ repatriaties -+ repertoiregezelschap -+ repertoiregezelschappen -+ repertoirekennis -+ repertoirekeus -+ repertoiretje -+ repertoiretoneel -+ repeteerwekkers -+ repetitielokaal -+ repetitieperiode -+ repetitieproces -+ repetitieruimten -+ repetitieruimtes -+ repetitietijd -+ repetitieve -+ replica's -+ replicaatje -+ reportageachtig -+ reportageachtige -+ reportageteam -+ reports -+ reprints -+ repro's -+ reproduceerbaarheid -+ reproductieonderzoek -+ reprorecht -+ reptielenhandelaar -+ republiek van de Zuid-Afrikaanse Boeren -+ republiekvlucht -+ reputatiemoord -+ researchcentra -+ researchcentrum -+ researchgroep -+ researchinstituut -+ researchprogramma -+ researchproject -+ researchprojecten -+ researchreactor -+ researchreactoren -+ researchteam -+ researchteams -+ reseda's -+ reservaatvorming -+ reservaties -+ reserve-eenheden -+ reserve-eenheid -+ reserveaanvoerder -+ reserveaanvoerders -+ reservebanken -+ reservekapitein -+ reservekapiteins -+ reservepot -+ reserveringsnummer -+ reserveringsnummers -+ reserveringssysteem -+ reservesleutel -+ reservesleutels -+ reservesleuteltje -+ reservetanks -+ resetknop -+ resetknoppen -+ resette -+ resetten -+ residuwaarden -+ resigneerde -+ resocialiseerde -+ resonansbodem -+ resonansbodems -+ resort -+ resorts -+ respectering -+ respectloos -+ respectloze -+ respectueuze -+ respectvol -+ respiratoire -+ respiratorische -+ responsabilisering -+ responsieve -+ ressorten -+ ressortraad -+ ressortraadsleden -+ ressortraadslid -+ ressortraden -+ restaurantgids -+ restauranthouder -+ restaurantje -+ restaurantketen -+ restaurantkeuken -+ restauratie-ethiek -+ restauratieatelier -+ restauratieateliers -+ restauratiebudget -+ restauratiekosten -+ restauratieplan -+ restauratieplannen -+ restauratieve -+ restauratiewerkzaamheden -+ restauratoren -+ restcategorieën -+ restgetallen -+ restgroepen -+ restmateriaal -+ restore-update -+ restorno's -+ reststof -+ reststoffen -+ restwarmte -+ restyle -+ resultaatgerichte -+ resultaatgerichtheid -+ resultaatsverbetering -+ resultaatsverbeteringen -+ resultaatverbetering -+ resultaatverbeteringen -+ resultaatvoetbal -+ resultatenontwikkeling -+ resultatenverbetering -+ resultatieve -+ resusapen -+ resusnegatieve -+ resuspositieve -+ retailbank -+ retardaties -+ retardeerde -+ retegoed -+ retegoede -+ reteslim -+ reteslimme -+ reticulaire -+ reticuultje -+ retina's -+ retorica's -+ retortenkool -+ retourlading -+ retourticket -+ retourtickets -+ retourvlucht -+ retourvluchten -+ retro -+ retroflexie -+ retroflexies -+ retromode -+ retropop -+ retropoppen -+ retrospectieven -+ rettichs -+ returns -+ reukstof -+ reukstoffen -+ reukvermogen -+ reukwerken -+ reumapatiënt -+ reumapatiënten -+ reumatologen -+ reuring -+ reut -+ reutemeteut -+ reuzegezellig -+ reuzegezellige -+ reuzegroot -+ reuzegrote -+ reuzeklein -+ reuzekleine -+ reuzemooi -+ reuzemooie -+ reuzemop -+ reuzemoppen -+ reuzenformaat -+ reuzengestalte -+ reuzengestalten -+ reuzengestaltes -+ reuzengroei -+ reuzenmiereneter -+ reuzenmiereneters -+ reuzenommegang -+ reuzenpanda -+ reuzenraden -+ reuzenraderen -+ reuzenscherm -+ reuzenslalom -+ reuzenstoet -+ revaccineerde -+ revalidatieartsen -+ revalidatiecentra -+ revalidatieproces -+ revalidatieprogramma -+ revalidatieprogramma's -+ revalueerde -+ revancheerde -+ revanchegevoel -+ revanchegevoelens -+ revanchematch -+ revanchematchen -+ revanchematches -+ revanchisten -+ revanchistische -+ reveillist -+ reveillisten -+ reveleerde -+ reverence -+ reverences -+ reversibele -+ reviaan -+ reviaans -+ reviaanse -+ revianen -+ revideerde -+ revisiecommissie -+ revitaliseerde -+ revitalisering -+ revivals -+ revolten -+ revoltes -+ revolutiejaren -+ revolverhelden -+ revolvertang -+ revolvertangen -+ revueartiest -+ revueartiesten -+ rexisme -+ rexist -+ rexisten -+ rez-de-chaussees -+ reçu's -+ reïncarneerde -+ rhythm-and-blues -+ rhythm-and-bluesmuziek -+ rial -+ rials -+ ribbroeken -+ ribgewelf -+ ribgewelven -+ ribkarbonaden -+ ribonucleïnezuren -+ ribosomen -+ ribstoffen -+ ribtricot -+ ricecooker -+ ricecookers -+ richtbaar -+ richtbare -+ richtgetallen -+ richtig -+ richtige -+ richtiger -+ richtigst -+ richtingbord -+ richtingborden -+ richtingenstrijd -+ richtingloze -+ richtingsgevoel -+ richtingsroer -+ richtingsroeren -+ richtingzoekers -+ richtmicrofoon -+ richtmicrofoons -+ richtmiddel -+ richtprijzen -+ richtte herop -+ richttijd -+ ridiculiseerde -+ ridiculisering -+ riedel -+ riedelde -+ riedelen -+ riedels -+ riedeltje -+ rietblazer -+ rietblazers -+ riethalm -+ rietkragen -+ rietmoeras -+ rietmoerassen -+ rietpluim -+ rietpluimen -+ rietstengels -+ rietvoorn -+ rietvoorns -+ rietvoren -+ rietvorens -+ rigider -+ rigiedst -+ rij-op-rij-afschepen -+ rij-op-rij-afschip -+ rijbevoegdheid -+ rijbewijstoerisme -+ rijer -+ rijers -+ rijfde binnen -+ rijgnaad -+ rijgnaden -+ rijhoogte -+ rijhoogten -+ rijhoogtes -+ rijhuis -+ rijhuizen -+ rijijzer -+ rijijzers -+ rijkgeschakeerd -+ rijkgeschakeerde -+ rijklaar -+ rijklare -+ rijksappel -+ rijksappels -+ rijksarbeidsbureaus -+ rijksbestuur -+ rijksbijdrage -+ rijksbijdragen -+ rijksbijdrageregeling -+ rijksbijdrages -+ rijkscommissarissen -+ rijksfinanciën -+ rijksgebieden -+ rijksgenoot -+ rijksinrichting -+ rijksinstituten -+ rijkskas -+ rijkskeurmeester -+ rijkslening -+ rijksleningen -+ rijksmark -+ rijksmarken -+ rijksmiddelenbegroting -+ rijksmonumenten -+ rijksmusea -+ rijksmuseums -+ rijksonderwijs -+ rijksoverheden -+ rijkspersoneel -+ rijkspolitiegroep -+ rijkspolitiekorps -+ rijkspolitiekorpsen -+ rijksrecherche -+ rijksregering -+ rijksregister -+ rijksscholen -+ rijksschool -+ rijkssubsidieregeling -+ rijkstaal -+ rijksverkeersinspectie -+ rijksvorst -+ rijksvorsten -+ rijkswegennet -+ rijmdwang -+ rijmelde -+ rijmelen -+ rijmer -+ rijmerij -+ rijmerijen -+ rijmers -+ rijmschema's -+ rijnzand -+ rijontzegging -+ rijontzeggingen -+ rijopleiding -+ rijschoolhouder -+ rijschoolhouders -+ rijsmiddel -+ rijspoor -+ rijsporen -+ rijstbuik -+ rijstbuiken -+ rijstenat -+ rijstevla's -+ rijstgerecht -+ rijstijlen -+ rijstimport -+ rijstkom -+ rijstmarkt -+ rijstproductie -+ rijststro -+ rijstteelt -+ rijstvla's -+ rijstvogeltje -+ rijstwijn -+ rijtaks -+ rijtijden -+ rijtjeshuizen -+ rijtjeswoning -+ rijtjeswoningen -+ rijvak -+ rijvakken -+ rijverbod -+ rijvereniging -+ rijverenigingen -+ rijweerstand -+ rijweerstanden -+ rijwielbergingen -+ rijwind -+ rijzing -+ riksja's -+ rikte -+ rild -+ rillettes -+ ringagenda's -+ ringarts -+ ringeling -+ ringscheur -+ ringscheuren -+ ringsleutels -+ ringwegen -+ rinst -+ rioja -+ rioleringsbuis -+ rioleringsbuizen -+ rioleringsstelsel -+ rioleringsstelsels -+ rioleringssysteem -+ rioolbelasting -+ rioolgas -+ rioolgassen -+ rioolput -+ rioolrat -+ rioolrechten -+ rioolwaterzuivering -+ rioolwaterzuiveringsinstallatie -+ rioolwaterzuiveringsinstallaties -+ rioolzuiveringsinstallatie -+ rioolzuiveringsinstallaties -+ riotguns -+ ripdeal -+ ripdeals -+ rippen -+ rippers -+ ripte -+ risico-opslag -+ risicoanalyse -+ risicoanalyses -+ risicoberekening -+ risicoberekeningen -+ risicodragende -+ risicofactoren -+ risicogroepen -+ risicokapitaal -+ risicomijdend -+ risicomijdende -+ risicopatiënt -+ risicopatiënten -+ risicospreiding -+ risicowedstrijd -+ risken -+ riskte -+ rissglaciaal -+ ristorno -+ ristorno's -+ ritme-instrument -+ ritme-instrumenten -+ ritmebox -+ ritmeboxen -+ ritmeerde -+ ritmegevoel -+ ritmesectie -+ ritoverwinning -+ ritprijzen -+ ritselaars -+ rittenkoers -+ rittenkoersen -+ ritualiseerde -+ ritualisering -+ ritualistische -+ ritwinnaar -+ ritwinst -+ ritzeges -+ rivaliteiten -+ rivierarmen -+ rivierbocht -+ rivierbochten -+ rivierbodem -+ rivierdelta -+ rivierenland -+ rivierenlandschap -+ riviergezicht -+ riviergezichten -+ riviergoden -+ rivierkrib -+ rivierkribben -+ rivierloop -+ riviermondingen -+ rivierstelsel -+ rivierstelsels -+ riyal -+ riyals -+ roadblock -+ roadblocks -+ roadmanager -+ roadmanagers -+ roadmovie -+ roadmovies -+ roadshow -+ roadshows -+ roaring twenties -+ robijnlasers -+ robijnrode -+ robijnrood -+ robotachtig -+ robotachtige -+ robotarm -+ robotfoto -+ robotfoto's -+ robotiseerde -+ rock-'n-rol -+ rock-'n-rolde -+ rock-'n-rollen -+ rock-'n-rollers -+ rock-'n-rollmuziek -+ rock-'n-rolt -+ rockband -+ rockbands -+ rockconcert -+ rockers -+ rockfan -+ rockfans -+ rockfilm -+ rockfilms -+ rockgitaar -+ rockgroep -+ rockgroepen -+ rockidool -+ rockmusical -+ rockmusicals -+ rockmuziek -+ rockopera's -+ rocksong -+ rocksongs -+ rockster -+ rocksterren -+ rockte -+ rockzangers -+ roddelcircuit -+ roddelrubriek -+ roddelrubrieken -+ roddelzucht -+ rodeerde -+ rodekolen -+ rodekoolsalade -+ rodekoorts -+ rodeo's -+ roderen -+ roebelbiljet -+ roebelbiljetten -+ roebelkoers -+ roebelzone -+ roedelbaan -+ roedelbanen -+ roedels -+ roedes -+ roefelde -+ roefelen -+ roei-equipe -+ roei-equipes -+ roeibanen -+ roeibond -+ roeiclub -+ roekeloost -+ roemloost -+ roemloze -+ roemlozer -+ roepzaal -+ roepzalen -+ roerbakgroente -+ roerbakgroenten -+ roerbakgroentes -+ roerbakte -+ roerblad -+ roerijzer -+ roerijzers -+ roerketting -+ roerkettingen -+ roerstok -+ roerstokken -+ roesmiddel -+ roestbak -+ roestbakken -+ roestkleur -+ roestkleuren -+ roestmiddel -+ roestplek -+ roestplekken -+ roestvaste -+ roetdeeltje -+ roetdeeltjes -+ roeten -+ roetsjte -+ roette -+ roggemikken -+ rohypnolletje -+ rokhangers -+ rokjas -+ rokjassen -+ rokkenjagen -+ rokkenjagerij -+ rokkenjagers -+ roksplit -+ rokvest -+ rokvesten -+ rokzadel -+ rokzadels -+ rolbevestigend -+ rolbevestigende -+ rolcentimeters -+ roldoorbrekende -+ roldoorbreking -+ rolfilms -+ rolkragen -+ roll-on-roll-offschepen -+ roll-on-roll-offschip -+ rollager -+ rollagers -+ rollator -+ rollators -+ rollenpatronen -+ rollenpatroon -+ rollenspelen -+ rollerskater -+ rollerskaters -+ rollertje -+ rolmaten -+ rolroer -+ rolroeren -+ rolschaatsers -+ rolschaatsplank -+ rolschaatsplanken -+ rolschildering -+ rolschilderingen -+ rolsprong -+ rolsprongen -+ rolstempel -+ rolstempels -+ rolstoelbasketbal -+ rolstoelgebruiker -+ rolstoelgebruikers -+ rolstoeltennis -+ roltafel -+ roltafels -+ roltafeltje -+ rolverwisseling -+ rolvorm -+ rolwisseling -+ rolwisselingen -+ rolzomen -+ rolzoom -+ romaans -+ romaanse -+ romancycli -+ romanfiguren -+ romanfragment -+ romanfragmenten -+ romanliteratuur -+ romanpersonage -+ romanpersonages -+ romantechnisch -+ romantechnische -+ romantisch-klassiek -+ romantisch-klassieke -+ romantiseerde -+ romantisering -+ romantrilogie -+ romanvorm -+ rommelhokken -+ rommelkamertje -+ rompdeel -+ rompdelen -+ rompgebergte -+ rompgebergten -+ rompgebergtes -+ rompkabinetten -+ rompparlementen -+ rompstaat -+ rompvorm -+ romusha -+ romusha's -+ rondbogig -+ rondbogige -+ rondbreien -+ rondbreipen -+ rondbreipennen -+ rondcirkelen -+ ronddarren -+ ronddartelen -+ ronddienen -+ ronddobberen -+ ronddollen -+ ronddrijven -+ ronderenner -+ rondetijd -+ rondetijden -+ rondgebanjerd -+ rondgecirkeld -+ rondgedard -+ rondgedarteld -+ rondgediend -+ rondgedold -+ rondgedreven -+ rondgehold -+ rondgehuppeld -+ rondgekropen -+ rondgeslagen -+ rondgeslopen -+ rondgespeeld -+ rondgestraald -+ rondgetoerd -+ rondgetold -+ rondgevraagd -+ rondgewenteld -+ rondgezoemd -+ rondgezwaaid -+ rondgezwermd -+ rondgezwierd -+ rondgezwommen -+ rondhollen -+ rondhuppelen -+ rondkruipen -+ rondo's -+ rondslaan -+ rondsluipen -+ rondspelen -+ rondstralen -+ rondvaartbedrijf -+ rondvaartboten -+ rondvis -+ rondwandeling -+ rondwentelen -+ rondzendbrieven -+ rondzoemen -+ rondzwaaien -+ rondzwemmen -+ rondzwermen -+ rondzwieren -+ rood-groen -+ rood-groene -+ rood-wit-blauw -+ roodborst -+ roodborsten -+ roodborsttapuit -+ roodborsttapuiten -+ roodfluwelen -+ roodgeel -+ roodgekleurd -+ roodgekleurde -+ roodgelakt -+ roodgelakte -+ roodgele -+ roodkapje -+ roodkapjes -+ roodkop -+ roodkoppen -+ roodpluchen -+ roodstand -+ roodverbrand -+ roodverbrande -+ roodverschuivingen -+ roodwild -+ roofing -+ roofkunst -+ roofovervaller -+ roofovervallers -+ roofstaat -+ roofvis -+ roofvissen -+ roofvogeltje -+ rooilat -+ rooilatten -+ rookbaar -+ rookbare -+ rookbommetje -+ rookdetectoren -+ rookdetectors -+ rookgas -+ rookgasontzwaveling -+ rookgasontzwavelingsinstallatie -+ rookgasreiniger -+ rookgasreiniging -+ rookgassen -+ rookgat -+ rookgaten -+ rookgewoonten -+ rookgewoontes -+ rookglas -+ rookgranaat -+ rookholen -+ rookkasten -+ rookkwarts -+ rookmachine -+ rookmachines -+ rookmaskers -+ rookmelders -+ rookpaal -+ rookpalen -+ rookschade -+ rooksignaal -+ rooksliert -+ rookslierten -+ rookstoel -+ rookstoelen -+ rookvergiftiging -+ rookvrij -+ rookvrije -+ roomblank -+ roomblanke -+ roomkleur -+ roommeter -+ roommeters -+ rooms-katholicisme -+ rooms-koning -+ rooms-koningen -+ rooms-rode -+ rooms-rood -+ roomservice -+ roomstel -+ roomstelletje -+ roomwit -+ roomwitte -+ roostervloer -+ roroschepen -+ roroschip -+ rorschachtest -+ rorschachtests -+ rotanmeubel -+ rotanmeubels -+ rotanschild -+ rotanschilden -+ rotatiedruk -+ rotatiedrukken -+ rotatiemotor -+ rotatiemotoren -+ rotatiemotors -+ rotatieprincipe -+ rotatiesnelheid -+ rotators -+ rotdag -+ rotding -+ rotdingen -+ rotgang -+ rothumeur -+ roti's -+ rotishop -+ rotishops -+ rotisserieën -+ rotisseur -+ rotisseurs -+ rotjong -+ rotkop -+ rotleven -+ rotmof -+ rotmoffen -+ rotogravures -+ rotopmerking -+ rotopmerkingen -+ rotorblad -+ rotorbladen -+ rotsbeen -+ rotsbeenderen -+ rotsbodems -+ rotseiland -+ rotseilanden -+ rotsgronden -+ rotshaan -+ rotshanen -+ rotsig -+ rotskust -+ rotsmoes -+ rotsmoezen -+ rotsplant -+ rotsplateau -+ rotsschildering -+ rotsschilderingen -+ rotssteen -+ rotsstenen -+ rotstekening -+ rotstraal -+ rotstreek -+ rotstreken -+ rotstuinen -+ rotstuintje -+ rotswol -+ rotterdammertje -+ rottweilers -+ roulatiesysteem -+ routebeschrijvingen -+ routeboek -+ routeerde -+ routekaarten -+ routenet -+ routenetwerk -+ routenetwerken -+ routeplanners -+ routeschema -+ routeschema's -+ routiers -+ routineklus -+ routinezaak -+ rouwadvertentie -+ rouwadvertenties -+ rouwbetoon -+ rouwcentra -+ rouwdouwde -+ rouwdouwen -+ rouwdouwers -+ rouwkrans -+ rouwkransen -+ rouwplechtigheden -+ rouwplechtigheid -+ rouwstoeten -+ rouwverwerking -+ rouxs -+ royaltyjournalist -+ royaltyjournalisten -+ royeerbaar -+ royeerbare -+ rozengeuren -+ rozenkruiser -+ rozenkruisers -+ rozenkweker -+ rozenstruiken -+ rubberachtig -+ rubberachtige -+ rubberbal -+ rubberballen -+ rubberband -+ rubberbanden -+ rubberboten -+ rubberhandschoen -+ rubberhandschoenen -+ rubberkogel -+ rubberkogels -+ rubberlaag -+ rubberlaars -+ rubberlaarzen -+ rubberlagen -+ rubberpakkingen -+ rubberplant -+ rubberplanten -+ rubbertapper -+ rubbertappers -+ rubensfiguren -+ rubensfiguur -+ rubricatoren -+ rubricators -+ rubriekschrijver -+ rubriekschrijvers -+ rubrieksnaam -+ rucola -+ rucola's -+ ruften -+ ruftte -+ rugbyclub -+ rugbyde -+ rugbyer -+ rugbyers -+ rugbyploeg -+ rugbyspeler -+ rugbyspelers -+ rugbyt -+ rugbyteam -+ rugbyteams -+ rugbyveld -+ rugdecolletés -+ ruggelingse -+ ruggengraatloos -+ ruggengraatloze -+ ruggengraatsverkromming -+ ruggengraatsverkrommingen -+ ruggenmergpunctie -+ ruggenmergpuncties -+ ruggenmergsvocht -+ ruggenmergszenuw -+ ruggenmergszenuwen -+ ruggenmergtering -+ ruggensteunde -+ ruggensteunen -+ ruggenwervels -+ rugkanten -+ rugkrabbers -+ rugpand -+ rugschild -+ rugschilden -+ rugsproeier -+ rugsproeiers -+ rugspuit -+ rugspuiten -+ rugstreeppad -+ rugwind -+ rugzaktoerist -+ rugzaktoeristen -+ rugzijden -+ ruigpoot -+ ruigpoten -+ ruigtekruiden -+ ruilbeurzen -+ ruilharten -+ ruilobjecten -+ ruiltje -+ ruilverhoudingen -+ ruimdenkendheid -+ ruimhartigheid -+ ruimijzer -+ ruimijzers -+ ruimte-experiment -+ ruimte-experimenten -+ ruimtebeslag -+ ruimtebiologie -+ ruimtecapsules -+ ruimtedekking -+ ruimtekromme -+ ruimtekrommen -+ ruimtelaboratoria -+ ruimtelaboratoriums -+ ruimtelijkeordeningsbeleid -+ ruimtenood -+ ruimtepakken -+ ruimtependels -+ ruimteplatform -+ ruimterecht -+ ruimtereizen -+ ruimteschepen -+ ruimteschild -+ ruimteschroot -+ ruimtesondes -+ ruimtestations -+ ruimtetelescoop -+ ruimtevaarders -+ ruimtevaartindustrie -+ ruimtevaartprogramma's -+ ruimtevaarttechniek -+ ruimtevaartuigen -+ ruimteveer -+ ruimtevliegtuig -+ ruimtevliegtuigen -+ ruimtevluchten -+ ruimtewagen -+ ruimtewagens -+ ruimtewandelingen -+ ruimtewapens -+ ruimvallend -+ ruimvallende -+ ruisfilters -+ ruitensproeiers -+ ruitentikken -+ ruitenwasser -+ ruitenwassers -+ ruiterequipe -+ ruiterequipes -+ ruiterstukje -+ ruiterstukjes -+ ruitervolk -+ ruitervolken -+ ruitervolkeren -+ ruitjespapier -+ ruitjespatroon -+ ruitvorm -+ rukkers -+ rulings -+ rum-cola -+ rumba's -+ rumcocktail -+ rumcocktails -+ rummikub -+ rummikuppen -+ rummikupte -+ runderbouillon -+ runderrolladen -+ runderrollades -+ rundveehouder -+ rundveehouderij -+ rundveehouderijen -+ rundveehouders -+ rundveestapel -+ rundvleesproductie -+ runentekens -+ runkleurig -+ runkleurige -+ runner-ups -+ running gag -+ running gags -+ running mate -+ running mates -+ rupsauto's -+ rupsje-nooit-genoeg -+ rupsjes-nooit-genoeg -+ rupturen -+ rus -+ russen -+ russofiel -+ russofiele -+ russofielen -+ russofilie -+ rustgebied -+ rustgebieden -+ rustkamers -+ rustpauze -+ rustpensioen -+ rustpensioenen -+ rustsignaal -+ ruwheden -+ ruwstaal -+ ruwvoer -+ ruziegemaakt -+ ruziemaken -+ ruzietoontje -+ ruziezoekend -+ ruziezoekende -+ ruïnering -+ rvs -+ rvs-wasbak -+ rvs-wasbakken -+ référé -+ référés -+ réussite -+ réussites -+ röntgenapparaten -+ röntgendiffractie -+ röntgenfilm -+ röntgenkamer -+ röntgenlaborant -+ röntgenlaboranten -+ röntgenologische -+ röntgenspectra -+ röntgenspectrum -+ röntgenstraal -+ s'en -+ s'il vous plaît -+ s'je -+ s's -+ saalien -+ saamhorige -+ saamhorigheidsgevoelens -+ sabbatical -+ sabbatical year -+ sabbatical years -+ sabbaticals -+ sabeldans -+ sabelkwast -+ sabelsprinkhaan -+ sabelsprinkhanen -+ sabotageactie -+ sabotageacties -+ sabotagedaad -+ sabotagedaden -+ sabotagepoging -+ sabotagepogingen -+ sabra -+ sabra's -+ sacharosen -+ sacherijnige -+ sachertaart -+ sachertaarten -+ sacoche -+ sacochen -+ sacramentsaltaar -+ sacramentsaltaren -+ sacrosancte -+ sadduceeën -+ sadduceeër -+ sadduceeërs -+ sado's -+ sadomasochisten -+ safari's -+ safe sex -+ safeje -+ safer -+ safest -+ saffie -+ saffies -+ saffraandraadje -+ saffraandraadjes -+ saffraanpoeder -+ sagomeel -+ saguaro -+ saguaro's -+ sakkerloot -+ saladbar -+ saladbars -+ salade niçoise -+ saladeschaal -+ saladeschalen -+ salam -+ salam aleikum -+ salamanderkachel -+ salamanderkachels -+ salami's -+ salamipolitiek -+ salamkramp -+ salarisontwikkeling -+ salarisslip -+ salarisslips -+ salarisverlagingen -+ saldo's -+ salesianer -+ salespromotor -+ salespromotors -+ salkvaccin -+ salmonella's -+ salmonellabacterie -+ salmonellabesmetting -+ saloeki -+ saloeki's -+ salomonsoordeel -+ salomonsoordelen -+ saloncommunist -+ saloncommunisten -+ salonfähige -+ salonorkest -+ salonsocialist -+ salonsocialisten -+ salontafelboek -+ saloondeur -+ saloondeuren -+ saloons -+ salpeterzout -+ salsamuziek -+ salto mortale -+ salto mortale's -+ salto mortales -+ salto's -+ salvia's -+ salviaatje -+ salvo's -+ samaritaan -+ samaritanen -+ samba's -+ sambabal -+ sambaballen -+ sambel -+ sambels -+ samenballing -+ samenballingen -+ samenbundelen -+ samenbundelingen -+ samendrijven -+ samendrukking -+ samengeklonken -+ samengekrompen -+ samengerold -+ samengesmeed -+ samengesnoerd -+ samengespeeld -+ samengevlochten -+ samenklanken -+ samenklinken -+ samenklonteren -+ samenlevingscontract -+ samenlevingscontracten -+ samenlevingsmodel -+ samenlevingsmodellen -+ samenlevingsopbouw -+ samenlevingsstructuren -+ samenlevingsstructuur -+ samenlevingsverbanden -+ samenrapen -+ samenrollen -+ samenscholingsverbod -+ samensmeden -+ samensnoeren -+ samenspelen -+ samenstand -+ samenstanden -+ samenvlechten -+ samenwerkingsakkoord -+ samenwerkingsovereenkomst -+ samenwerkingsovereenkomsten -+ samenwerkingsproject -+ samenwerkingsprojecten -+ samenwerkingsscholen -+ samenwerkingsvoorwaarde -+ samenwerkingsvoorwaarden -+ samenzweringstheorie -+ samoems -+ sampans -+ samplede -+ samplers -+ samples -+ samplet -+ sanctiebeleid -+ sanctiecomité -+ sanctiecomités -+ sanctiemaatregel -+ sanctiemaatregelen -+ sanctiemiddel -+ sanctiewapen -+ sanctionering -+ sanctioneringen -+ sandelolie -+ sandinisten -+ sandinistische -+ sandwichborden -+ sandwichformule -+ sandwichkind -+ sandwichkinderen -+ sandwichspread -+ saneerder -+ saneerders -+ saneringsbeleid -+ saneringsbevel -+ saneringskaarten -+ saneringsoperatie -+ saneringsoperaties -+ saneringsplan -+ saneringsplannen -+ saneringspolitiek -+ sannyasins -+ sans-papiers -+ sanseveria's -+ sansevieria's -+ saoto -+ saoto's -+ sapcentrifuges -+ sappelaars -+ sappelde -+ sapperloot -+ sapstromen -+ sapstroom -+ sara -+ sara's -+ sarcasten -+ sari's -+ satansgebroed -+ satanskerk -+ satellietbeeld -+ satellietbeelden -+ satellietcommunicaties -+ satellietland -+ satellietlanden -+ satellietontvangst -+ satellietschotel -+ satellietschotels -+ satellietstaten -+ satellietsteden -+ satelliettelevisie -+ satellietuitzending -+ satellietuitzendingen -+ satellietzenders -+ satijnbinding -+ satijnbindingen -+ satijnzacht -+ satijnzachte -+ satiredichter -+ satiredichters -+ satsuma -+ saturatie -+ satéstokjes -+ saurussen -+ sausde -+ sauteerde -+ sauteren -+ sauve-qui-peut -+ savannebos -+ savannebossen -+ savannehert -+ savanneherten -+ savannehond -+ savannehonden -+ savannevos -+ savannevossen -+ save -+ savede -+ savet -+ savoir-faire -+ sawa's -+ saxhoorn -+ saxhoorns -+ saxofoonkwartet -+ scala's -+ scampi's -+ scande -+ scandinavist -+ scandinavisten -+ scandinavistiek -+ scans -+ scatologische -+ scenaristen -+ scene -+ scenes -+ scenetje -+ schaafijs -+ schaafijzer -+ schaafijzers -+ schaafkrul -+ schaakblinde -+ schaakboek -+ schaakboeken -+ schaakbond -+ schaakbonden -+ schaakclubs -+ schaakcomputers -+ schaakevenement -+ schaakevenementen -+ schaakgespeeld -+ schaakgrootmeester -+ schaakgrootmeesters -+ schaakjournalist -+ schaakjournalisten -+ schaakkampioen -+ schaakkampioenschap -+ schaakklokken -+ schaakliteratuur -+ schaakmatch -+ schaakmatchen -+ schaakmatches -+ schaakolympiade -+ schaakrubrieken -+ schaakster -+ schaaksters -+ schaalmodellen -+ schaalvergrotingsoperatie -+ schaalvlies -+ schaalvliezen -+ schaalvormig -+ schaalvormige -+ schaalvrucht -+ schaalvruchten -+ schaambeharing -+ schaamharen -+ schaamlap -+ schaamlip -+ schaamluis -+ schaamluizen -+ schaamschot -+ schaamschotten -+ schaamspleet -+ schaamteloosheden -+ schaamtevolle -+ schaarbewegingen -+ schaarlamp -+ schaarlampen -+ schaarste-economie -+ schaartrap -+ schaartrappen -+ schaatsafstand -+ schaatsenslijpers -+ schaatsevenement -+ schaatsevenementen -+ schaatshal -+ schaatskampioenschap -+ schaatskampioenschappen -+ schaatsmarathon -+ schaatspak -+ schaatspakken -+ schaatspiste -+ schaatspistes -+ schaatsplank -+ schaatsplanken -+ schaatsseizoen -+ schaatstocht -+ schaatstop -+ schaatswedstrijd -+ schaatswedstrijden -+ schabben -+ schabouwelijk -+ schabouwelijke -+ schachtendoop -+ schachtenmeester -+ schade-expert -+ schade-experts -+ schade-uitkering -+ schade-uitkeringen -+ schadeclaims -+ schadecorrespondent -+ schadecorrespondenten -+ schadeplichtige -+ schadestatistieken -+ schadevergoedingsprocedure -+ schadevrije -+ schaduwarchieven -+ schaduwboekhoudingen -+ schaduwboksen -+ schaduwfiguren -+ schaduwfiguur -+ schaduwkabinetten -+ schaduwkandidaat -+ schaduwkandidaten -+ schaduwkegels -+ schaduwloos -+ schaduwloze -+ schaduwminister -+ schaduwpartijen -+ schaduwplant -+ schaduwplanten -+ schaduwplek -+ schaduwplekken -+ schaduwregeringen -+ schaduwspel -+ schaduwspelen -+ schaduwspits -+ schaduwwerking -+ schaftketen -+ schaftlokalen -+ schakelarmbanden -+ schakelbaar -+ schakelbare -+ schakelbungalows -+ schakelcursus -+ schakelcursussen -+ schakelklassen -+ schakelklokken -+ schakelknoppen -+ schakelmechanismen -+ schakelpanelen -+ schakelstation -+ schakelwagen -+ schakelwagens -+ schakelwoning -+ schandaalbladen -+ schandhout -+ schandknaap -+ schandknapen -+ schandpaaleffect -+ schansspringer -+ schapenfokkerij -+ schapenfokkerijen -+ schapengras -+ schapenhouder -+ schapenhouderij -+ schapenhouders -+ schapenkeutel -+ schapenvachten -+ schapenwolken -+ schapenwollen -+ schapenzuring -+ scharnierblad -+ scharnierbladen -+ scharnierpunten -+ scharrelkip -+ scharrelvarken -+ scharrelvarkens -+ schartong -+ schartongen -+ schatbewaarders -+ schatkistbewaarder -+ schatkistbewaarders -+ schatkistcertificaat -+ schatkistcertificaten -+ schatmeesters -+ schatplichtigheid -+ schattigheid -+ schedekramp -+ schedekrampen -+ schedelbasis -+ schedelbasisfracturen -+ schedeldeformatie -+ schedeldeformaties -+ schedelgeboorte -+ schedelgeboorten -+ schedelgeboortes -+ schedelholte -+ schedelholten -+ schedelholtes -+ schedelhuid -+ schedelletsels -+ schedelligging -+ schedes -+ schedetje -+ scheed uit -+ scheefgegroeid -+ scheefgelopen -+ scheefgeslagen -+ scheefgroei -+ scheefgroeien -+ scheeflopen -+ scheefslaan -+ scheefstaand -+ scheefstaande -+ scheefwonen -+ scheelgezien -+ scheenbeschermer -+ scheendekker -+ scheendekkers -+ scheepmakers -+ scheepsarcheologie -+ scheepsartsen -+ scheepsbel -+ scheepsboord -+ scheepsboorden -+ scheepsbouwindustrie -+ scheepsdiesel -+ scheepseigenaar -+ scheepseigenaars -+ scheepseigenaren -+ scheepsgezel -+ scheepsgezellen -+ scheepshellingen -+ scheepshoorn -+ scheepshoorns -+ scheepshuiden -+ scheepsjournaals -+ scheepskeuken -+ scheepskeukens -+ scheepskiel -+ scheepskielen -+ scheepskisten -+ scheepslift -+ scheepsliften -+ scheepsmaten -+ scheepsofficier -+ scheepsofficieren -+ scheepsradio -+ scheepsramp -+ scheepsrampen -+ scheepsrompen -+ scheepsschroef -+ scheepsschroeven -+ scheepstoeter -+ scheepstoeters -+ scheepsverkeer -+ scheepsvracht -+ scheepsvrachten -+ scheepswand -+ scheepswanden -+ scheepswerktuigbouwkundige -+ scheepswrak -+ scheepswrakken -+ scheepvaartbedrijf -+ scheepvaartbericht -+ scheepvaartroute -+ scheepvaartroutes -+ scheepvaartsector -+ scheerkop -+ scheerkoppen -+ scheerschuim -+ scheerstaven -+ scheidbrieven -+ scheidingsmuren -+ scheidingsmuur -+ scheidingsprocedures -+ scheidingsproces -+ scheids -+ scheidsen -+ scheidsmannen -+ scheidsrechterde -+ scheidsrechteren -+ scheidsrechtersbal -+ scheidsrechtersballen -+ scheidsrechterscommissie -+ scheidsrechterskorps -+ scheldbrief -+ scheldbrieven -+ schelder -+ scheldwoordenboek -+ schelp- of zandrug -+ schelpdiertje -+ schelpdiervisserij -+ schelpenverzameling -+ schelpenzand -+ schelprits -+ schelpritsen -+ schelvispekel -+ schematiseringen -+ schemeltje -+ schemertoestanden -+ schemerwereld -+ schemerzone -+ schemerzones -+ schenkelbeen -+ schenkelbeenderen -+ schenkingsrecht -+ schenkingsrechten -+ schenkmandjes -+ schenktuiten -+ scheppende -+ scheppingsdaden -+ scheppingsdrift -+ scheppingsproces -+ scheppingstheorie -+ scheppingstheorieën -+ scheppingswoord -+ scheppingswoorden -+ scherfgranaat -+ scherfgranaten -+ scherfwerend -+ scherfwerende -+ scherfwerking -+ scheringdraad -+ scheringdraden -+ schermbloem -+ schermbloemen -+ schermclub -+ schermclubs -+ schermdragend -+ schermdragende -+ schermsport -+ schermsters -+ scherpgras -+ scherpstelling -+ schertsfiguren -+ schertsfiguur -+ scherzo's -+ schetskaart -+ schetskaarten -+ schetsplan -+ schetsplannen -+ scheurbanen -+ scheurijzer -+ scheurijzers -+ scheurlijst -+ scheurlijsten -+ scheurpartij -+ scheurpartijen -+ scheurpartijtje -+ scheursterkte -+ schiervlakte -+ schiervlakten -+ schiervlaktes -+ schietbenodigdheden -+ schietgraag -+ schietijzer -+ schietijzers -+ schietincident -+ schietincidenten -+ schietinstructie -+ schietinstructies -+ schietklaar -+ schietklare -+ schietmot -+ schietmotten -+ schietproef -+ schietproeven -+ schietschijfcel -+ schietschijfcellen -+ schietsport -+ schietstoel -+ schietstoelen -+ schietvaardig -+ schietvaardige -+ schietvaardigheid -+ schietvereniging -+ schietverenigingen -+ schietvoorraad -+ schietvoorraden -+ schietwapen -+ schijfgeheugen -+ schijfgeschoten -+ schijfkoppeling -+ schijfkoppelingen -+ schijfkwal -+ schijfkwallen -+ schijfrem -+ schijfschoot -+ schijnhandeling -+ schijnhandelingen -+ schijnhuwelijk -+ schijnhuwelijken -+ schijnkoning -+ schijnkoningen -+ schijnmanoeuvre -+ schijnmanoeuvres -+ schijnoplossing -+ schijnoplossingen -+ schijnpapaver -+ schijnpapavers -+ schijnproces -+ schijnvertoningen -+ schijnvrede -+ schijnzwangerschappen -+ schijtebroek -+ schijtebroeken -+ schijterig -+ schijterige -+ schijtgeld -+ schijtlaarzen -+ schijtlijster -+ schijtlijsters -+ schijvengeheugens -+ schijventarieven -+ schikkingsbedrag -+ schikkingsbedragen -+ schikkingsvoorstel -+ schilderatelier -+ schilderateliers -+ schilderbeurt -+ schildergerei -+ schilderijencollectie -+ schilderijenkabinet -+ schilderijenkabinetten -+ schilderijenmuseum -+ schilderkunstig -+ schilderkunstige -+ schilderles -+ schilderlessen -+ schildersatelier -+ schildersateliers -+ schilderslinnen -+ schildersmodel -+ schildersmodellen -+ schildersoog -+ schildertechniek -+ schildertrant -+ schilderwijze -+ schildpadachtig -+ schildpadachtige -+ schildpaddensoep -+ schildpadeieren -+ schiller -+ schillers -+ schillingen -+ schilmesje -+ schilmesjes -+ schimmelachtig -+ schimmelachtige -+ schimmeldodend -+ schimmeldodende -+ schimmelgroei -+ schimmelinfectie -+ schimmelinfecties -+ schimmelkaas -+ schimmelwerend -+ schimmelwerende -+ schimmengevecht -+ schimmenwereld -+ schimmig -+ schimpschrift -+ schimpschriften -+ schippersbeurzen -+ schippersbomen -+ schippersboom -+ schippersgemeente -+ schippersgemeenten -+ schippersgemeentes -+ schipperskind -+ schipperskinderen -+ schippersknoop -+ schippersknopen -+ schippersleven -+ schippersorganisatie -+ schipperstrui -+ schitterglans -+ schitterglansen -+ schitterglanzen -+ schlemielen -+ schluss -+ schmierde -+ schnabbelaars -+ schnabbelcircuit -+ schnabbelde -+ schnabbels -+ schnauzer -+ schnauzers -+ schoencrèmes -+ schoenenzaken -+ schoenleer -+ schoenmaat -+ schoenmakerijen -+ schoenmakertje -+ schoenontwerper -+ schoenpoets -+ schoenpoetsen -+ schoenpoetsertje -+ schoenveters -+ schoepenrad -+ schoepenraderen -+ schoftenstreek -+ schoftenstreken -+ schofthoogte -+ schofthoogten -+ schofthoogtes -+ schokbehandeling -+ schokbehandelingen -+ schokbestendig -+ schokbestendige -+ schokdemper -+ schokdempers -+ schokeffect -+ schokeffecten -+ schokkerig -+ schokkerige -+ schokproef -+ schokproeven -+ schokstaking -+ schokstakingen -+ schoktherapie -+ schoktherapieën -+ schokvast -+ schokvaste -+ schokvrij -+ schokvrije -+ schokwerking -+ scholastische -+ scholenbouw -+ scholencomplex -+ scholencomplexen -+ scholenraad -+ scholenstrijd -+ scholfilet -+ scholfilets -+ scholiere -+ scholierenopstand -+ scholieres -+ scholingsgraad -+ scholingsinstituut -+ scholingsniveau -+ scholingsverlof -+ schommelbanken -+ schommelbewegingen -+ schonegrondverklaring -+ schooiertje -+ schoolagenda's -+ schoolbegeleider -+ schoolbegeleiders -+ schoolbegeleidingsdienst -+ schoolbellen -+ schoolbladen -+ schoolbus -+ schoolbussen -+ schoolclub -+ schoolclubs -+ schooldecaan -+ schooldecanaat -+ schooldecanaten -+ schooldecanen -+ schooldistrict -+ schooldistricten -+ schooleditie -+ schooledities -+ schoolengels -+ schoolfrans -+ schoolfrik -+ schoolfrikken -+ schoolgang -+ schoolgangen -+ schoolgebruik -+ schoolgebruiken -+ schoolgelopen -+ schoolgemeenschap -+ schoolgemeenschappen -+ schoolinspecteur -+ schoolinspecteurs -+ schooljuf -+ schooljuffen -+ schoolkameraads -+ schoolleider -+ schoolleiders -+ schoolleven -+ schoolloopbaan -+ schoollopen -+ schoolmaatschappelijk -+ schoolmaatschappelijke -+ schoolmeesterde -+ schoolmeestertje -+ schoolmuren -+ schoolmuur -+ schoolmuziek -+ schoolnet -+ schoolnetten -+ schoolpact -+ schoolpacten -+ schoolperiode -+ schoolplaat -+ schoolplaten -+ schoolpleinen -+ schoolpleintje -+ schoolpolitiek -+ schoolprogramma -+ schoolprogramma's -+ schoolraad -+ schoolraden -+ schoolrapport -+ schoolrapporten -+ schoolrijp -+ schoolrijpe -+ schoolschrift -+ schoolschriften -+ schoolslagzwemmer -+ schoolsoort -+ schoolsoorten -+ schooltaal -+ schooltandarts -+ schooltandartsen -+ schoolteam -+ schoolteams -+ schooltelevisie -+ schooltoetsen -+ schooltoneel -+ schooltype -+ schooltypen -+ schooltypes -+ schooluitvoeringen -+ schooluniformen -+ schoolvak -+ schoolvakanties -+ schoolvakken -+ schoolverband -+ schoolvorming -+ schoolvrij -+ schoolvrije -+ schoolwandeling -+ schoolwandelingen -+ schoolwerkplan -+ schoolwerkplannen -+ schoolwet -+ schoolwetten -+ schoolwezen -+ schoolwoning -+ schoolwoningen -+ schoolzwemmen -+ schoonfamilie -+ schoongelikt -+ schoongepoetst -+ schoongespoeld -+ schoongeveegd -+ schoongewassen -+ schoonheidsbehandelingen -+ schoonheidsbeleving -+ schoonheidscommissies -+ schoonheidservaring -+ schoonheidservaringen -+ schoonheidsfout -+ schoonheidsfouten -+ schoonheidsfoutje -+ schoonheidsideaal -+ schoonheidsidealen -+ schoonheidsmasker -+ schoonheidsmaskers -+ schoonheidsprijzen -+ schoonheidsproduct -+ schoonheidsproducten -+ schoonheidssalon -+ schoonheidssalons -+ schoonheidsslaapje -+ schoonheidsslaapjes -+ schoonheidsverzorging -+ schoonheidsvlekje -+ schoonheidsvlekjes -+ schoonlikken -+ schoonmaakartikel -+ schoonmaakbeurten -+ schoonmaakmiddel -+ schoonmaakoperatie -+ schoonmaakoperaties -+ schoonmaaksector -+ schoonmama -+ schoonmama's -+ schoonouder -+ schoonpapa's -+ schoonspoelen -+ schoonzussen -+ schoonzwemmen -+ schoorsteengat -+ schoorsteengaten -+ schoppenkleur -+ schoppenslem -+ schopschijf -+ schopschijven -+ schorsingsverzoek -+ schortje -+ schotelantenne -+ schotelantennes -+ schotelvormig -+ schotelvormige -+ schotelwarmer -+ schotelwarmers -+ schotenwisseling -+ schotenwisselingen -+ schotjesgeest -+ schots -+ schotse -+ schotst -+ schotten -+ schotvaardig -+ schotvaardige -+ schouderbeweging -+ schouderbewegingen -+ schouderduw -+ schouderduwen -+ schoudergewrichten -+ schouderhammen -+ schouderholster -+ schouderholsters -+ schouderklopjes -+ schouderriemen -+ schouderworpen -+ schout-bij-nachts -+ schouwburgbezoek -+ schouwburgdirecteur -+ schouwburgdirecteuren -+ schouwburgdirectie -+ schouwburgdirecties -+ schouwingsbewijs -+ schouwmantel -+ schouwmantels -+ schraagtafel -+ schraagtafels -+ schraapstaal -+ schraapstalen -+ schranspartij -+ schranspartijen -+ schredenteller -+ schredentellers -+ schreefloos -+ schreefloze -+ schreeuwlelijkerd -+ schreeuwpartij -+ schrieperig -+ schrieperige -+ schriftbeelden -+ schriftcultuur -+ schriftexpertise -+ schriftexpertisen -+ schriftexpertises -+ schriftloos -+ schriftloze -+ schrijfangst -+ schrijfarbeid -+ schrijfbladen -+ schrijfbureautje -+ schrijfgemak -+ schrijfhouding -+ schrijfhoudingen -+ schrijfhulp -+ schrijfkamer -+ schrijfmachientje -+ schrijfmachinelinten -+ schrijfmachinetje -+ schrijfoefening -+ schrijfoefeningen -+ schrijfsel -+ schrijfsels -+ schrijftafeltje -+ schrijftalent -+ schrijfvlak -+ schrijfvlakken -+ schrijfwijzes -+ schrijlingse -+ schrijnwerk -+ schrijnwerken -+ schrijver-dichter -+ schrijversblok -+ schrijversgeneratie -+ schrijversloopbaan -+ schrijversnaam -+ schrijversnamen -+ schrijversorganisatie -+ schrikneurose -+ schrikneurosen -+ schrikneuroses -+ schrikstroom -+ schrilheid -+ schroefbacterie -+ schroefbacteriën -+ schroefkop -+ schroefkoppen -+ schroefloos -+ schroefloze -+ schroefplug -+ schroefpluggen -+ schroefsteven -+ schroefstevens -+ schroeftang -+ schroeftangen -+ schroefturbine -+ schroefturbines -+ schroefveer -+ schroefveren -+ schroefwiel -+ schroefwielen -+ schroefwinding -+ schroefwindingen -+ schroei-ijzer -+ schroei-ijzers -+ schroeierig -+ schroeierige -+ schroeilucht -+ schroeiplek -+ schroeiplekken -+ schrokhans -+ schrokhanzen -+ schroothandel -+ schroothandelaar -+ schroothandels -+ schrootprijs -+ schrootte -+ schrootverwerker -+ schubachtig -+ schubachtige -+ schubhuid -+ schubvormig -+ schubvormige -+ schuddebuiken -+ schuddebuikte -+ schuifaf -+ schuifaffen -+ schuifafs -+ schuifbaar -+ schuifbare -+ schuifdoos -+ schuifgordijn -+ schuifgordijnen -+ schuifladen -+ schuiflades -+ schuifloden -+ schuiflood -+ schuifpaneel -+ schuifpanelen -+ schuifpuzzel -+ schuifregelaar -+ schuifregelaars -+ schuifspanning -+ schuifspanningen -+ schuifwanden -+ schuifweerstand -+ schuifweerstanden -+ schuiladres -+ schuiladressen -+ schuilden -+ schuilhutten -+ schuiloord -+ schuiloorden -+ schuimbad -+ schuimbaden -+ schuimblusapparaat -+ schuimblusapparaten -+ schuimblusser -+ schuimblussers -+ schuimgebakje -+ schuimgebakjes -+ schuimkraag -+ schuimkragen -+ schuimlaag -+ schuimlagen -+ schuimtablet -+ schuimtabletten -+ schuimvlok -+ schuimvorming -+ schuimwijn -+ schuingedrukt -+ schuingedrukte -+ schuinstaand -+ schuinstaande -+ schuldaflossing -+ schuldaflossingen -+ schuldbetaling -+ schuldbetalingen -+ schuldcomplexen -+ schuldeisend -+ schuldeisende -+ schuldenaflossing -+ schuldenberg -+ schuldencrisis -+ schuldenland -+ schuldenprobleem -+ schuldenregeling -+ schuldenvrij -+ schuldenvrije -+ schuldigheid -+ schuldloos -+ schuldloze -+ schuldovereenkomst -+ schuldovereenkomsten -+ schulduitsluitingsgrond -+ schuldvermenging -+ schuldverplichting -+ schuldverplichtingen -+ schuringsklank -+ schuringsklanken -+ schurkenrol -+ schutgelden -+ schuthoogte -+ schuthoogten -+ schuttersdoek -+ schuttersdoeken -+ schuttersgildes -+ schutterslijst -+ schuttersput -+ schuttersputje -+ schuttersputten -+ schuurkurk -+ schuurkurken -+ schuurmiddel -+ schuurpapiertje -+ schuurpoeder -+ schuurschijf -+ schuurschijven -+ schuursponsen -+ schuursponzen -+ schuursteen -+ schuurstenen -+ schwalbe -+ schwalbes -+ schwarzwalderkirsch -+ sciencefictionfilm -+ sciencefictionfilms -+ sciencefictionroman -+ sciencefictionromans -+ sciencefictionschrijver -+ sciencefictionschrijvers -+ sciencepark -+ scienceparken -+ scienceparks -+ scone -+ scoops -+ scootmobiel -+ scootmobielen -+ scootmobiels -+ scopes -+ scorekaart -+ scoringsdrift -+ scoringskans -+ scoringsmogelijkheden -+ scoringsmogelijkheid -+ scoringspercentage -+ scoringspositie -+ scrabbelaars -+ scrambler -+ scramblers -+ scrapie -+ scratch -+ scratcht -+ scratchte -+ screende -+ screensaver -+ screensavers -+ screentests -+ scriba's -+ scrimmages -+ scriptgirls -+ scriptoria -+ scriptoriums -+ scriptschrijver -+ scrol -+ scrolde -+ scrollen -+ scrolt -+ scrub -+ scrubben -+ scrubde -+ scrubs -+ scrubt -+ sculpturale -+ sculptuurtje -+ scènefoto -+ scènefoto's -+ scènetje -+ scènewisseling -+ scènewisselingen -+ seal -+ sealde -+ sealen -+ sealt -+ secce -+ second opinion -+ second opinions -+ secondantschap -+ secondeerde -+ secondegrens -+ secondelang -+ secondelijm -+ secondespel -+ secondopinionarts -+ secondopinionartsen -+ secondopiniononderzoek -+ secondopiniononderzoeken -+ secretaressecongres -+ secretaressecongressen -+ secretariaat-generaal -+ secretariaatskosten -+ secretaris-penningmeester -+ secreten -+ sectiebestuur -+ sectiebestuursleden -+ sectiebestuurslid -+ sectierapport -+ sectievoorzitter -+ sectio's -+ sectorbeleid -+ sectorhoofd -+ secularisatieproces -+ secularisering -+ sedans -+ sedatieve -+ sedekah -+ sedekahs -+ sedenteerde -+ sedenteren -+ seder -+ seders -+ sedimentaties -+ segmentale -+ segmentering -+ segmenteringen -+ segregaties -+ seibel -+ seil ab -+ seilde ab -+ seilt ab -+ seincodes -+ seinlampen -+ seismologen -+ seismometers -+ seizoengebonden -+ seizoenkaarthouder -+ seizoenkaarthouders -+ seizoensarbeid -+ seizoenshelft -+ seizoensmatig -+ seizoensmatige -+ seizoenstart -+ seizoenwerk -+ seksbaas -+ seksbazen -+ seksbioscoop -+ seksbioscopen -+ seksblad -+ seksbladen -+ seksboek -+ seksboerderij -+ seksboerderijen -+ seksboetiek -+ seksbom -+ seksbommen -+ seksbusiness -+ seksclub -+ seksclubs -+ seksediscriminatie -+ seksegenotes -+ sekseneutraal -+ sekseneutrale -+ seksers -+ seksetest -+ sekseverschillen -+ seksfilm -+ seksfilms -+ seksindustrie -+ seksismen -+ seksismes -+ seksisten -+ sekslijn -+ sekslijnen -+ sekslingerie -+ seksmaniak -+ seksmaniakken -+ seksobject -+ seksschandaal -+ seksscène -+ seksscènes -+ seksshops -+ sekssite -+ sekssites -+ sekssymbool -+ sekstheater -+ sekstheaters -+ sekstherapeut -+ sekstoerist -+ sekstoeristen -+ seksualiseerde -+ seksualisering -+ seksualiteitsbeleving -+ seksuologen -+ seksuologische -+ sekswerker -+ sekswerkers -+ sekswinkel -+ sekswinkels -+ sekteleden -+ sektelid -+ sektes -+ sektevorming -+ sela's -+ selderiezout -+ selderijstengel -+ selderijstengels -+ selecteurs -+ selectiedruk -+ selectiemethoden -+ selectienorm -+ selectienormen -+ selectiespeler -+ selectiespelers -+ selectiewedstrijd -+ selectiewedstrijden -+ seleenzuur -+ selffulfilling -+ selffulfilling prophecy -+ selffulfilling prophecy's -+ semantemen -+ semantici -+ semi-intellectuelen -+ semiambtelijk -+ semiambtelijke -+ semiautomatisch -+ semiautomatische -+ semiautonome -+ semiautonoom -+ semibungalow -+ semibungalows -+ semicollectief -+ semicollectieve -+ semicrimineel -+ semidemocratisch -+ semidemocratische -+ semigeprivatiseerd -+ semigeprivatiseerde -+ semilegaal -+ semilegale -+ semimilitair -+ semimilitaire -+ semimuraal -+ semimurale -+ seminaars -+ seminariums -+ semiofficieel -+ semiofficiële -+ semionafhankelijk -+ semionafhankelijke -+ semiopenbaar -+ semiopenbare -+ semiotici -+ semiotische -+ semioverheid -+ semioverheidsbedrijf -+ semioverheidsinstantie -+ semioverheidsinstanties -+ semioverheidsinstelling -+ semioverheidsinstellingen -+ semipermanent -+ semipermanente -+ semipermeabel -+ semipermeabele -+ semipolitici -+ semipoliticus -+ semipolitiek -+ semipolitieke -+ semiprof -+ semiprofessionalisme -+ semiprofessioneel -+ semiprofessionele -+ semiprofs -+ semipubliek -+ semipublieke -+ semiscenisch -+ semiscenische -+ semitistiek -+ semiwetenschappelijk -+ semiwetenschappelijke -+ semtex -+ seniore -+ seniorenbeleid -+ seniorenburger -+ seniorenburgers -+ seniorenconvent -+ seniorenkaart -+ seniorenkaarten -+ seniorenmarkt -+ seniorenregeling -+ seniorieën -+ sennhutten -+ sensatiebelust -+ sensatieblad -+ sensatiebladen -+ sensatiekrant -+ sensatieverhalen -+ sensatiezucht -+ sensibiliseerde -+ sensitivitytrainingen -+ sensomotorische -+ sensorische -+ sensors -+ sepotbeleid -+ sepots -+ septemberdag -+ septemberdagen -+ septic tanks -+ septiemakkoord -+ septuagesima -+ sequel -+ sequelen -+ sequels -+ sequoia's -+ sergeant-majoor -+ sergeant-majoor-vlieger -+ sergeant-majoor-vliegers -+ sergeant-majoors -+ sergeanten-majoor -+ serie-inbreker -+ serie-inbrekers -+ seriebouw -+ seriematig -+ seriematige -+ seriemoordenaars -+ serieproducten -+ serieproducties -+ serieusheid -+ seriewedstrijd -+ seriewedstrijden -+ serologische -+ seronegatieve -+ serranoham -+ serval -+ servals -+ serveerder -+ serveerders -+ serveerstertje -+ serveuses -+ service-volley -+ service-volleyspel -+ serviceapparaat -+ servicebreak -+ servicebreaks -+ servicebureaus -+ servicecentra -+ servicecentrum -+ servicegame -+ servicegames -+ serviceorganisatie -+ serviceprovider -+ serviceproviders -+ servicereturn -+ services -+ servicesector -+ servicestation -+ servicestations -+ servicevak -+ servobesturing -+ servomechanisme -+ servomechanismen -+ servomotors -+ sesambroden -+ sesambrood -+ sesampasta -+ sesampasta's -+ sesamzaad -+ sesamzaadje -+ sesamzaadjes -+ sessiemuzikant -+ sessiemuzikanten -+ set-ups -+ setpoints -+ setpunt -+ setpunten -+ setstanden -+ setsysteem -+ settelde -+ setwinst -+ sexagesima -+ sexappeal -+ sexyer -+ sexyst -+ señora's -+ señores -+ señorita's -+ sfeerbeeld -+ sfeerbeschrijving -+ sfeerbeschrijvingen -+ sfeergevoelig -+ sfeergevoelige -+ sfeerimpressie -+ sfeerimpressies -+ sfeermuziek -+ sfeerrijk -+ sfeerrijke -+ shabushabu -+ shagje -+ shagjes -+ shagroker -+ shagrokers -+ shake -+ shake-out -+ shakers -+ shakespeareaans -+ shakespeareaanse -+ shaket -+ shakete -+ shanty -+ shanty's -+ shantykoor -+ shantykoren -+ sharia -+ shawltje -+ sheetfeeder -+ sheetfeeders -+ shellshock -+ shelters -+ sheltertje -+ sherpa's -+ sherry'tje -+ shetlander -+ shetlanders -+ shiatsu -+ shifttoetsen -+ shiitake -+ shiitakes -+ shimmy's -+ shimmyde -+ shimmyen -+ shimmyt -+ shintoïst -+ shintoïsten -+ shirtsponsor -+ shirtsponsoring -+ shish kebab -+ shoarmaburger -+ shoarmaburgers -+ shoarmakruiden -+ shoarmazaak -+ shoarmazaken -+ shockbehandelingen -+ shockeffecten -+ shocks -+ shogi -+ shogun -+ shoguns -+ shops -+ shopt -+ shopte -+ short story's -+ shortlist -+ shortlists -+ shorttracken -+ shorttrackers -+ shorttrackster -+ shorttracksters -+ shorttrackt -+ shorttrackte -+ shots -+ shotte -+ shovels -+ showband -+ showbands -+ showbink -+ showbinken -+ showcase -+ showcases -+ showde -+ showman -+ showmannen -+ showmasters -+ showmusical -+ showmusicals -+ showorkest -+ showorkesten -+ showroommodel -+ showroommodellen -+ showt -+ shoyu -+ shredder -+ shredderbedrijf -+ shredders -+ shuffle -+ shuffles -+ shutter -+ shutterbomen -+ shutterboom -+ shutters -+ shuttlebus -+ shuttlebussen -+ shuttles -+ shuttletrein -+ shuttletreinen -+ si's -+ siamang -+ siamangs -+ siamees -+ siamezen -+ sibbenkunde -+ sicav -+ sicavs -+ sickbuildingsyndroom -+ sicksinussyndroom -+ side-out -+ side-outs -+ sidekick -+ sidekicks -+ sidewinder -+ sidewinders -+ siepelde -+ siepelen -+ sieraadontwerper -+ sieraadontwerpers -+ sierasperge -+ sierasperges -+ sierbestratingen -+ siergras -+ siergrassen -+ sierkers -+ sierkersen -+ sierletter -+ sierletters -+ sierlijkheden -+ sierlijst -+ sierlijsten -+ sierschrift -+ sierspeld -+ sierspelden -+ siersteek -+ siersteen -+ siersteken -+ sierstenen -+ sierstrip -+ sierteelt -+ siertegel -+ siertegels -+ siertuin -+ siertuinen -+ siervis -+ siervissen -+ siervogel -+ siervogels -+ sifaka -+ sifaka's -+ sigaarvormig -+ sigaarvormige -+ sigarenkist -+ sigarenkisten -+ sigarenroker -+ sigarettenaansteker -+ sigarettenaanstekers -+ sigarettenautomaat -+ sigarettenautomaten -+ sigarettenpijpjes -+ sigarettensmokkel -+ sigarettenvloei -+ sigarettenvloeitje -+ sigma's -+ signa -+ signaalfuncties -+ signaalkleur -+ signaalkleuren -+ signaaloverdracht -+ signaalstof -+ signaalstoffen -+ signaaltje -+ signaalwaarde -+ signaalwerking -+ signaleringssysteem -+ signalisaties -+ signeersessie -+ signeersessies -+ significanties -+ significaties -+ sijsjes -+ sijsjeslijmer -+ sijsjeslijmers -+ sikahert -+ sikaherten -+ sikhs -+ sikkelcelanemie -+ silicaten -+ siliconen -+ siliconenborsten -+ silicoselijder -+ silicoselijders -+ silurisch -+ silurische -+ siluur -+ simkaart -+ simkaarten -+ simlock -+ simlockvrij -+ simlockvrije -+ simpen -+ simplificaties -+ simplificering -+ simplismen -+ simpte -+ simulatieprogramma -+ simulatieprogramma's -+ simulatoren -+ simulators -+ simultaangever -+ simultaanschaken -+ simultaanseance -+ sinaasappelbomen -+ sinaasappelboom -+ sinaasappelkist -+ sinaasappelkisten -+ sinaasappellikeur -+ sinaasappelplantage -+ sinaasappelplantages -+ sinaasappelschil -+ sinaasappelschillen -+ singer-songwriter -+ singer-songwriters -+ singlets -+ sinjorenstad -+ sinologische -+ sint-bernards -+ sint-jakobsschelp -+ sint-jakobsschelpen -+ sint-jansvlinder -+ sinterklaasinkopen -+ sinterklaasliedje -+ sinterklaasliedjes -+ sinterklaasviering -+ sirocco's -+ sirtaki's -+ sisters -+ sisyfusarbeid -+ sitars -+ sitarspeler -+ sitatoenga -+ sitatoenga's -+ sitcom -+ sitcoms -+ sitdownstakingen -+ situatieanalyse -+ situatieanalyses -+ situatieplan -+ situatieplannen -+ situatieve -+ sixpack -+ sixpacks -+ sixtijns -+ sixtijnse -+ siërra's -+ sjabbat -+ sjabbatten -+ sjabloneerde -+ sjabloonachtig -+ sjabloonachtige -+ sjabloonpen -+ sjako's -+ sjalom -+ sjamanistisch -+ sjamanistische -+ sjammes -+ sjampie -+ sjampies -+ sjankers -+ sjanste -+ sjaslieks -+ sjaslik -+ sjasliks -+ sjeikdom -+ sjekel -+ sjekkies -+ sjia -+ sjia-islam -+ sjiitisch -+ sjiitische -+ sjikse -+ sjikses -+ sjoelde -+ sjoels -+ sjoelschijf -+ sjoelschijven -+ sjoemelaar -+ sjoemelaars -+ sjoemelde -+ sjofar -+ sjofars -+ sjonge -+ sjorder -+ sjorders -+ sjtetl -+ sjwa's -+ sjwas -+ skaldengedicht -+ skaldengedichten -+ skate -+ skateboardde -+ skateboards -+ skateboardt -+ skatet -+ skatete -+ skeelerwedstrijd -+ skeelerwedstrijden -+ skeletdeel -+ skeletdelen -+ skeletresten -+ skelterbaan -+ skelterbanen -+ skelterde -+ skelters -+ ski-instructeur -+ ski-instructeurs -+ ski-internaat -+ ski-jack -+ ski-jacks -+ skiavonturen -+ skiavontuur -+ skigebied -+ skigebieden -+ skigelopen -+ skihut -+ skihutten -+ skilift -+ skiliften -+ skim -+ skimde -+ skimmen -+ skimonitor -+ skimonitoren -+ skimt -+ skinheads -+ skins -+ skiongeluk -+ skioord -+ skipak -+ skipakken -+ skipiste -+ skipisten -+ skipistes -+ skipper -+ skippybal -+ skippyballen -+ skischans -+ skischansen -+ skischoen -+ skischoenen -+ skisport -+ skispringen -+ skiuitrusting -+ skivakantie -+ skivakanties -+ skiwas -+ skyboxen -+ skylabs -+ skylines -+ slaaf -+ slaapbus -+ slaapbussen -+ slaapcentra -+ slaapcentrum -+ slaapgebrek -+ slaapgelegenheden -+ slaapgemeente -+ slaapgemeenten -+ slaapgemeentes -+ slaapgewoonte -+ slaapgewoonten -+ slaapgewoontes -+ slaaphuis -+ slaaphuizen -+ slaapjurk -+ slaapkameraads -+ slaapkamerdeuren -+ slaapkamergeluk -+ slaapkleed -+ slaapkleedje -+ slaapkuren -+ slaapkuur -+ slaapmat -+ slaapmatten -+ slaaprijtuig -+ slaaprijtuigen -+ slaapruimte -+ slaapstad -+ slaapstoel -+ slaapstoelen -+ slaapstoornis -+ slaapstoornissen -+ slaaptablet -+ slaaptabletten -+ slaaptrein -+ slaaptreinen -+ slaapwagon -+ slaapwagons -+ slablad -+ slabladen -+ slabladeren -+ slacentrifuge -+ slacentrifuges -+ slachtkuiken -+ slachtkuikens -+ slachtofferenquête -+ slachtofferhulp -+ slachtofferrol -+ slachtofferschap -+ slachtoffertaks -+ slachtoffertje -+ slachtprijs -+ slachtprijzen -+ slachtrijp -+ slachtrijpe -+ slacouvert -+ slacouverts -+ slagbeurt -+ slagbeurten -+ slagboormachines -+ slagcirkel -+ slagcirkels -+ slagenarsenaal -+ slagenverkaveling -+ slagenwisseling -+ slagenwisselingen -+ slagerswinkel -+ slagerswinkels -+ slagerszoon -+ slaggitaar -+ slaggitaren -+ slagingskans -+ slagingspercentage -+ slagkracht -+ slagkrachtig -+ slagkrachtige -+ slagman -+ slagmannen -+ slagpartij -+ slagperk -+ slagperken -+ slagpin -+ slagpinnen -+ slagplank -+ slagplanken -+ slagroeier -+ slagroompunt -+ slagroompunten -+ slagroomtaarten -+ slagtechniek -+ slagvolume -+ slagvolumen -+ slagvolumes -+ slagwerker -+ slagwerkers -+ slagwerkgroep -+ slagwerkmuziek -+ slagwoord -+ slagwoorden -+ slakachtig -+ slakachtige -+ slakkenbestrijdingsmiddel -+ slakkenbestrijdingsmiddelen -+ slakkengangetje -+ slakkenwouw -+ slakkenwouwen -+ slakom -+ slakommen -+ slakrop -+ slakroppen -+ slametan -+ slametans -+ slamix -+ slamixen -+ slangenarend -+ slangenarenden -+ slangeneieren -+ slangenhout -+ slangenkruid -+ slangenkuil -+ slangenkuilen -+ slangentongen -+ slangenwortel -+ slangenwortels -+ slankte af -+ slapengaan -+ slaphangend -+ slaphangende -+ slapie -+ slapies -+ slapjanus -+ slapjanussen -+ slapstickachtig -+ slapstickachtige -+ slapstickfilm -+ slapstickfilms -+ slapsticks -+ slasausen -+ slasauzen -+ slash -+ slashes -+ slaven -+ slavenarmband -+ slavenarmbanden -+ slavenbestaan -+ slavenmoraal -+ slavenopstand -+ slavenopstanden -+ slavink -+ slavinken -+ slechtgeluimd -+ slechtgeluimde -+ slechtgemanierd -+ slechtgemanierde -+ slechtgemutst -+ slechtgemutste -+ slechthorend -+ slechthorende -+ slechthorenden -+ slechtnieuwsgesprek -+ slechtnieuwsgesprekken -+ slechtziend -+ slechtziende -+ slechtzienden -+ slechtziendheid -+ sledehond -+ sledehonden -+ sledes -+ sleep-ins -+ sleepaak -+ sleepaken -+ sleepauto -+ sleepauto's -+ sleepbootkapitein -+ sleepcontacten -+ sleephaak -+ sleephaken -+ sleephengel -+ sleephengels -+ sleephopperzuiger -+ sleeplift -+ sleeptonen -+ sleeptoon -+ sleepwagen -+ sleepwagens -+ slentergangetje -+ sleutelaar -+ sleutelaars -+ sleutelbeenbreuk -+ sleutelclub -+ sleutelclubs -+ sleutelkind -+ sleutelkinderen -+ sleutelmacht -+ sleutelpassage -+ sleutelpassages -+ sleutelpersonen -+ sleutelpersoon -+ sleutelpost -+ sleutelposten -+ sleutelvaluta -+ slibzuiger -+ slibzuigers -+ slidegitaar -+ slidegitaren -+ slideguitar -+ slideguitars -+ sliertig -+ sliertige -+ slijmafscheiding -+ slijmbal -+ slijmballen -+ slijmbeurs -+ slijmbeurzen -+ slijmerds -+ slijmjurk -+ slijmjurken -+ slijmlaag -+ slijmlagen -+ slijmproppen -+ slijmzwam -+ slijmzwammen -+ slijpmeel -+ slijpmiddel -+ slijpplaatje -+ slijpplaatjes -+ slijpschijf -+ slijpschijven -+ slijpstof -+ slijtageverschijnsel -+ slijtageverschijnselen -+ slijtlaag -+ slijtlagen -+ slijtplek -+ slijtplekken -+ slijtvast -+ slijtvaste -+ slijtvergunning -+ slijtvergunningen -+ slikker -+ slikkers -+ slikprobleem -+ slikproblemen -+ slingerbeweging -+ slingerbewegingen -+ slingermachine -+ slingermachines -+ slinkst -+ slipcursussen -+ slippartij -+ slippartijen -+ slips -+ slipscholen -+ slipschool -+ slipsteek -+ slipsteken -+ sliptong -+ sliptongen -+ slivovitsje -+ slobberbroek -+ slobbertrui -+ slobbertruien -+ sloef -+ sloeven -+ slokdarmspraak -+ slonzigheid -+ sloophamer -+ sloophamers -+ sloophout -+ sloopkogel -+ sloopkogels -+ slooponderdeel -+ slooponderdelen -+ slooppand -+ slooppanden -+ slooppremie -+ slooppremies -+ sloopregeling -+ sloopvergunning -+ sloopvergunningen -+ sloopwagen -+ sloopwagens -+ sloopwerkzaamheden -+ slopershanden -+ slotaflevering -+ slotakte -+ slotbeschouwingen -+ slotbijeenkomst -+ slotceremonie -+ slotcommuniqués -+ slotetappe -+ slotfasen -+ slotfases -+ slotfeesten -+ slotformule -+ slotformules -+ slothoofdstuk -+ slothoofdstukken -+ slotklooster -+ slotkloosters -+ slotmedeklinker -+ slotmedeklinkers -+ slotnotering -+ slotnoteringen -+ slotoffensief -+ slotpleidooi -+ slotrede -+ slotredes -+ slotresolutie -+ slotscène -+ slotscènes -+ slotstuk -+ slotstukken -+ slotverklaring -+ slotverklaringen -+ slotweekeinde -+ slotweekend -+ slotzin -+ slotzinnen -+ slotzuster -+ slotzusters -+ sloverig -+ sloverige -+ slow motion -+ slowfoxen -+ slufters -+ sluierbewolking -+ sluiereffect -+ sluikblad -+ sluikbladen -+ sluikinvoer -+ sluikreclames -+ sluikse -+ sluikstokerij -+ sluikstokerijen -+ sluikstort -+ sluikstorten -+ sluikstorter -+ sluikstorters -+ sluikstortte -+ sluikweg -+ sluikwegen -+ sluikwerk -+ sluimerig -+ sluimerige -+ sluimertoestand -+ sluipenderwijs -+ sluipgang -+ sluipgangen -+ sluiprouten -+ sluiproutes -+ sluipschutterkogel -+ sluipschutterkogels -+ sluipschutters -+ sluipschuttersvuur -+ sluipschuttervuur -+ sluipverkeer -+ sluipweggetje -+ sluitdop -+ sluitdoppen -+ sluitertijd -+ sluitertijden -+ sluitingsceremonie -+ sluitingsdata -+ sluitingsdatums -+ sluitketting -+ sluitkettingen -+ sluitklep -+ sluitkleppen -+ sluitplaat -+ sluitplaten -+ slums -+ slurfachtig -+ slurfachtige -+ sm -+ smaakcel -+ smaakcellen -+ smaakmakend -+ smaakmakende -+ smaakmakers -+ smaakpapil -+ smaakpapillen -+ smaakstoffen -+ smaakverschil -+ smaakverschillen -+ smaakzenuw -+ smaakzenuwen -+ smaakzin -+ smakker -+ smakkers -+ small -+ smalsporen -+ smartcards -+ smartdrug -+ smartdrugs -+ smartlap -+ smartlappen -+ smashen -+ smashes -+ smasht -+ smashte -+ smeedstalen -+ smeekbedes -+ smeekbrief -+ smeekbrieven -+ smeerbare -+ smeerkees -+ smeerklier -+ smeerklieren -+ smeerleverworst -+ smeernippel -+ smeernippels -+ smeerpijp -+ smeerpijpen -+ smeerpoezen -+ smeertroep -+ smeerzeep -+ smelleken -+ smellekens -+ smeltdraad -+ smeltkroesmuziek -+ smeltmiddel -+ smeltproces -+ smeltwarmte -+ smetvrij -+ smetvrije -+ smiespelde -+ smiespelen -+ smikkelaar -+ smikkelaars -+ smogvorming -+ smokkelroute -+ smokkelroutes -+ smoorspoel -+ smoorspoelen -+ smos -+ smossen -+ sms -+ sms't -+ sms'te -+ smurf -+ smurfen -+ smurrie -+ snabbel -+ snabbelaar -+ snabbelaars -+ snabbelcircuit -+ snabbelde -+ snabbelen -+ snabbels -+ snabbeltje -+ snackcar -+ snackcars -+ snaredrum -+ snaredrums -+ sneakers -+ sneakpreview -+ sneakpreviews -+ sneerde -+ sneeuwbloem -+ sneeuwbloemen -+ sneeuwdek -+ sneeuwgors -+ sneeuwgorzen -+ sneeuwhut -+ sneeuwhutten -+ sneeuwjachten -+ sneeuwklas -+ sneeuwklassen -+ sneeuwkristal -+ sneeuwkristallen -+ sneeuwlaag -+ sneeuwlagen -+ sneeuwlandschappen -+ sneeuwluchten -+ sneeuwmachine -+ sneeuwmachines -+ sneeuwruimen -+ sneeuwschuiver -+ sneeuwschuivers -+ sneeuwscooters -+ sneeuwtop -+ sneeuwtoppen -+ sneeuwuil -+ sneeuwuilen -+ sneeuwveld -+ sneeuwvelden -+ sneeuwvrij -+ sneeuwvrije -+ sneeuwwitjes -+ sneeuwwolk -+ sneeuwwolken -+ snelblusser -+ snelblussers -+ snelbus -+ snelbusnet -+ snelbussen -+ sneldichter -+ sneldichters -+ snelgroeiend -+ snelgroeiende -+ snelheidsbegrenzer -+ snelheidsbegrenzers -+ snelheidsduivel -+ snelheidsduivels -+ snelheidslimiet -+ snelheidslimieten -+ snelheidsmaniak -+ snelheidsmaniakken -+ snelheidsovertreder -+ snelheidsovertreders -+ snelheidsovertredingen -+ snelheidsrecord -+ snelheidsrecords -+ snelheidswedstrijd -+ snelkookpannen -+ snelle-interventiemacht -+ snellekweekreactor -+ snellekweekreactoren -+ snellekweekreactors -+ snelletreinverbinding -+ snelrechtprocedures -+ snelrekenaar -+ snelrekenaars -+ snelschaken -+ snelstromend -+ sneltekenaar -+ sneltekenaars -+ sneltramlijn -+ sneltrams -+ sneltramverbinding -+ snelverkeer -+ snelvuurgeweer -+ snelvuurgeweren -+ snelvuurwapen -+ snelvuurwapens -+ snelwandelaar -+ snelwandelaars -+ snelwandelen -+ snelwegvignet -+ snelwerkend -+ snelwerkende -+ sneren -+ sneuveltekst -+ snierde -+ snieren -+ sniffen -+ snifte -+ snijapparaat -+ snijapparaten -+ snijbranders -+ snijdbaar -+ snijdbare -+ snijkant -+ snijkanten -+ snijkoek -+ snijkoeken -+ snijmais -+ snijmaïs -+ snijpeterselie -+ snijtang -+ snijtangen -+ snijzaal -+ snijzalen -+ snikkels -+ snoeihard -+ snoeiharde -+ snoeiheet -+ snoeioperatie -+ snoekduiken -+ snoepgraag -+ snoepgrage -+ snoepjesfabrikant -+ snoepkraam -+ snoepkramen -+ snoeplustig -+ snoeplustige -+ snoepwinkeltje -+ snoerloos -+ snoeverig -+ snoeverige -+ snoezepoezen -+ snoge -+ snoges -+ snooker -+ snookercentra -+ snookercentrum -+ snookerde -+ snookers -+ snookersport -+ snookertafel -+ snookertafels -+ snookertoernooi -+ snookertoernooien -+ snookerzaal -+ snookerzalen -+ snorfiets -+ snorfietsen -+ snorfietser -+ snorfietsers -+ snorhaar -+ snorkelde -+ snorkels -+ snotlap -+ snotlappen -+ snotters -+ snotvalling -+ snotvallingen -+ snowboard -+ snowboardde -+ snowboarden -+ snowboarder -+ snowboarders -+ snowboards -+ snowboardt -+ snuffelpalen -+ snuffelvliegtuig -+ snuffelvliegtuigen -+ snuffelziekte -+ snuffmovie -+ snuffmovies -+ snurker -+ snurkers -+ soa -+ soa's -+ soaps -+ soapserie -+ soapseries -+ sociaal-cultureel -+ sociaal-culturele -+ sociaal-realistisch -+ sociaal-realistische -+ sociaaldemocraat -+ sociaaldemocraten -+ sociaaldemocratie -+ sociaaldemocratisch -+ sociaaldemocratische -+ sociaaleconomisch -+ sociaaleconomische -+ sociaalgeografisch -+ sociaalgeografische -+ sociaalkritisch -+ sociaalkritische -+ sociaalliberalisme -+ sociaalpsychologisch -+ sociaalpsychologische -+ sociaalwetenschappelijk -+ sociaalwetenschappelijke -+ socialezekerheidsregeling -+ socialezekerheidswet -+ socialezekerheidswetten -+ socialistenleider -+ socialistisch-realistisch -+ socialistisch-realistische -+ societyleven -+ sociniaan -+ socio-economische -+ sociocratische -+ sociocultureel -+ socioculturele -+ sociodrama's -+ sociografen -+ sociografische -+ sociogrammen -+ sociolecten -+ sociologes -+ sociometrische -+ sociotherapie -+ sociotherapieën -+ sodeflikker -+ sodeflikkers -+ sodeju -+ sodoku -+ soefi -+ soenna -+ soennitische -+ soepkommetje -+ soepkop -+ soeppan -+ soepstengel -+ soepstengels -+ soepzootje -+ soepzootjes -+ soevereiniteitsverklaring -+ soevereiniteitsverlies -+ sofa's -+ sofinummer -+ sofinummers -+ softbal -+ softbalde -+ softdrink -+ softdrinks -+ softdrug -+ softdrugsbeleid -+ softheid -+ softies -+ softporno -+ softs -+ softwareapplicatie -+ softwareapplicaties -+ softwareindustrie -+ softwareonderneming -+ softwarespecialist -+ softwarespecialisten -+ soigneurs -+ soja-extract -+ soja-extracten -+ sojameel -+ sojamelk -+ sojaschroot -+ sojavlees -+ solaria -+ solariums -+ soldatenkerkhof -+ soldatenlaars -+ soldatenlaarzen -+ soldatenuniform -+ soldatenvolk -+ soldeerdraad -+ soldeerpistolen -+ soldeerpistool -+ soldeerwater -+ soldijverhoging -+ solexen -+ solidariseerde -+ solidaristische -+ solidariteitsactie -+ solidariteitsbeginsel -+ solidariteitsbijdrage -+ solidariteitsbijdragen -+ solidariteitsbijeenkomst -+ solidariteitsheffing -+ solidariteitsstakingen -+ solistenkwartet -+ sollicitatiecommissies -+ sollicitatieformulieren -+ sollicitatieplicht -+ sollicitatietraining -+ solo's -+ solo-elpee -+ solo-elpees -+ solo-instrumenten -+ solo-optreden -+ solo-optredens -+ solo-oven -+ solo-ovens -+ soloactie -+ soloacties -+ solocarrière -+ soloplaat -+ soloplaten -+ soloseks -+ solotoer -+ solvabiliteitseis -+ solvabiliteitseisen -+ solvabiliteitspositie -+ solvayprocedé -+ somberde -+ somberen -+ somberman -+ sombermannen -+ somberte -+ sombrero's -+ sommelier -+ sommeliers -+ sommeringen -+ sonarinstallaties -+ sonarsysteem -+ sondeerballon -+ sondeerballonnen -+ sondeerballons -+ sondevoeding -+ songfestival -+ songfestivals -+ songs -+ songschrijversduo -+ songtekst -+ songteksten -+ songwriters -+ sonnetvorm -+ soortbescherming -+ soorteigen -+ soortement -+ soortenarm -+ soortenarme -+ soortenrijk -+ soortenrijkdom -+ soortenrijke -+ soortensamenstelling -+ soortsvorming -+ soortvorming -+ sopraansax -+ sopraansaxen -+ sopraansaxofoon -+ sopraansaxofoons -+ sopraansleutel -+ sopraansleutels -+ sopraansolo -+ sopropo -+ sopropo's -+ sorbetijs -+ sorrycultuur -+ sorteercentra -+ sorteercentrum -+ sorteermachine -+ sorteermachines -+ sorteersysteem -+ souffleetje -+ souffleurshokje -+ souffleurshokjes -+ soufflébakje -+ soufflébakjes -+ soufflémengsel -+ soulband -+ soulbands -+ soulinvloed -+ soulinvloeden -+ soulmate -+ soulmates -+ soulmuziek -+ soulnummer -+ soulnummers -+ soulsong -+ soulsongs -+ soulstem -+ soulzanger -+ soulzangeres -+ soulzangers -+ soundbite -+ soundbites -+ soundblaster -+ soundblasters -+ soundcheck -+ soundchecks -+ soundmachine -+ soundmachines -+ soundmix -+ soundmixen -+ soundmixer -+ soundmixers -+ soundmixshow -+ soundmixshows -+ soundmixt -+ soundmixte -+ sounds -+ soupertje -+ souspiedje -+ souteneurschap -+ souvenirjager -+ souvenirjagers -+ souvenirshop -+ souvenirtje -+ souvenirwinkel -+ souvenirwinkels -+ souvenirwinkeltje -+ souvlaki -+ souvlaki's -+ sovjetcommunisme -+ sovjetiseerde -+ sovjetologen -+ sozen -+ spaakwiel -+ spaakwielen -+ spaanhout -+ spaanplaatgas -+ spaanplaatgassen -+ spaanplaten -+ spaarbanktegoed -+ spaarbanktegoeden -+ spaarbekken -+ spaarbekkens -+ spaarbewijs -+ spaarbewijzen -+ spaarbiljet -+ spaarbon -+ spaarbonnen -+ spaarbons -+ spaardeposito -+ spaardeposito's -+ spaardersmarkt -+ spaarfonds -+ spaarhypotheek -+ spaarhypotheken -+ spaarkaart -+ spaarkaarten -+ spaaroverschot -+ spaaroverschotten -+ spaarplannen -+ spaarpremie -+ spaarpremies -+ spaarquote -+ spaarrekeningen -+ spaarrente -+ spaarsaldo -+ spaarsysteem -+ spaarvarkens -+ spaarvarkentje -+ spaarvlammen -+ spaarzin -+ spacecake -+ spacecakes -+ spacelabs -+ spacewagon -+ spacewagons -+ spachtelputz -+ spachtelputzen -+ spachtelputzt -+ spachtelputzte -+ spades -+ spadesteek -+ spadesteel -+ spadesteken -+ spadestelen -+ spagaathouding -+ spaghettivreter -+ spaghettivreters -+ spaghettiwestern -+ spaghettiwesterns -+ spam -+ spamfilter -+ spamfilters -+ spandraad -+ spandraden -+ spanfiets -+ spanjolen -+ spanjool -+ spanlaken -+ spanlakens -+ spanningsbogen -+ spanningsboog -+ spanningscoëfficiënt -+ spanningscoëfficiënten -+ spanningshaard -+ spanningshaarden -+ spanningsloos -+ spanningsloze -+ spanningsmeter -+ spanningsmeters -+ spanningsrail -+ spanningsrails -+ spanningsregelaar -+ spanningsregelaars -+ spanningsverliezen -+ spanningzoekers -+ spanplaten -+ sparde -+ sparerib -+ spareribs -+ sparringpartner -+ sparringpartners -+ spartaan -+ spartaans -+ spartaanse -+ spartanen -+ spasmeaanval -+ spasmeaanvallen -+ spatgelijk -+ spatgelijke -+ spatiebalken -+ spatietoets -+ spatietoetsen -+ spatiewoord -+ spatiewoorden -+ spawater -+ specialisatiejaar -+ specialisatiejaren -+ specialisteninkomen -+ specialisteninkomens -+ specialistenopleiding -+ specialistenplaats -+ specialistenplaatsen -+ specialistentarief -+ specialistentarieven -+ specialiteitenrestaurant -+ specialiteitenrestaurants -+ specials -+ speciemolen -+ speciemolens -+ spectaculairder -+ spectaculairst -+ spectraalanalyse -+ spectrografen -+ spectrogrammen -+ spectroscopische -+ speculaaskruiden -+ speculaasplank -+ speculaasplanken -+ speculaaspop -+ speculaaspoppen -+ speculatiedrift -+ speculatiegolf -+ speculatieobject -+ speechschrijver -+ speedbootrace -+ speedbootracen -+ speedbootraces -+ speedmetal -+ speelautomaat -+ speelbaar -+ speelbare -+ speelbeurt -+ speelbeurten -+ speelborden -+ speeldag -+ speeldagen -+ speelduur -+ speelfilmdebuut -+ speelfilmindustrie -+ speelfilmlang -+ speelfilmlange -+ speelfilmmaker -+ speelfilmmakers -+ speelfilmproductie -+ speelgelegenheden -+ speelgelegenheid -+ speelgerechtigd -+ speelgerechtigde -+ speelgoedafdeling -+ speelgoedauto -+ speelgoedauto's -+ speelgoedautootje -+ speelgoedbeer -+ speelgoedbeest -+ speelgoedbeesten -+ speelgoedberen -+ speelgoedbranche -+ speelgoeddier -+ speelgoeddieren -+ speelgoedhuisje -+ speelgoedhuisjes -+ speelgoedmuseum -+ speelgoedtrein -+ speelgoedtreinen -+ speelgoedzaak -+ speelgoedzaken -+ speelhallen -+ speelklaar -+ speelklare -+ speelklok -+ speelleerklas -+ speelleerklassen -+ speelmakkertje -+ speelplan -+ speelplannen -+ speelsgewijs -+ speelst -+ speelstijl -+ speelstijlen -+ speeltuinwerk -+ speelvelden -+ speelverbod -+ speelwei -+ speelweiden -+ speelweides -+ speelwijze -+ speerpuntindustrie -+ speerwerper -+ speerwerpers -+ spekkie -+ spekkies -+ speklappen -+ spekpannenkoeken -+ spekzolen -+ spekzool -+ spelbeeld -+ spelbepaler -+ spelbepalers -+ spelcomputer -+ spelcomputers -+ speldje -+ speldjes -+ spelelement -+ spelelementen -+ speleologen -+ speleologische -+ speler-coach -+ spelersaankoop -+ spelersaankopen -+ spelersbank -+ spelershome -+ spelershomes -+ spelersingang -+ spelerslounge -+ spelersselectie -+ spelerstunnel -+ spelertje -+ spelinzicht -+ speller -+ spelletjesprogramma -+ spelletjesprogramma's -+ spelletjesshow -+ spellingbeelden -+ spellingchecker -+ spellingcommissies -+ spellinggids -+ spellinggidsen -+ spellinghervorming -+ spellinghervormingen -+ spellingherziening -+ spellingshervormingen -+ spellingsysteem -+ spellinguitspraak -+ spelmaker -+ spelonderbreking -+ spelonderbrekingen -+ spelonkachtig -+ spelonkachtige -+ spelotheek -+ spelotheken -+ spelpeil -+ spelregelcommissie -+ spelregelwijziging -+ spelregie -+ speltechnische -+ speltempo -+ speltempo's -+ speltherapeut -+ speltherapeuten -+ spelvariant -+ spelvarianten -+ spelverdelers -+ spelverloop -+ spelverruwing -+ spelvorm -+ speractie -+ speracties -+ spergebied -+ spermabanken -+ spermacel -+ spermacellen -+ spermadonor -+ spermadonors -+ spermaspoor -+ spermasporen -+ spermatozoa -+ spertijd -+ spertijden -+ sperzieboontje -+ spetters -+ speuractie -+ speurneuzen -+ spic en span -+ spichten -+ spiegelaflezing -+ spiegelaflezingen -+ spiegeldeuren -+ spiegelkabinet -+ spiegellamp -+ spiegellampen -+ spiegeloptiek -+ spiegeloptieken -+ spiegelzolen -+ spiegelzool -+ spiekbriefje -+ spiekbriefjes -+ spieraam -+ spieratrofieën -+ spierballen -+ spierballenpolitiek -+ spierballentaal -+ spierballenvertoon -+ spierballenwetgeving -+ spierbeweging -+ spierbewegingen -+ spierblessure -+ spierblessures -+ spierbundels -+ spiercel -+ spiercellen -+ spiercontractie -+ spiercontracties -+ spierdystrofie -+ spiermassa -+ spiermassa's -+ spierpees -+ spierpezen -+ spierscheuring -+ spierspanning -+ spierspanningen -+ spierstijfheid -+ spierstuk -+ spierstukken -+ spiersuiker -+ spiertrekking -+ spiertrekkingen -+ spierverrekking -+ spierverslappend -+ spierverslappende -+ spierversterkend -+ spiervezel -+ spiervezels -+ spierzwakte -+ spiesbok -+ spiesbokken -+ spijbelbus -+ spijbelbussen -+ spijkerband -+ spijkerbed -+ spijkerbroekenmerk -+ spijkergoed -+ spijkerjack -+ spijkerjacks -+ spijkerpak -+ spijkerpakken -+ spijkerschoen -+ spijkerschoenen -+ spijsolie -+ spijsverteringsorgaan -+ spijsverteringsorganen -+ spijsverteringsstoornis -+ spijsverteringsstoornissen -+ spijsvet -+ spijsvetten -+ spijtbetuiging -+ spijtbetuigingen -+ spikes -+ spilfiguren -+ spilfiguur -+ spilfunctie -+ spilfuncties -+ spilgemeente -+ spilgemeenten -+ spilgemeentes -+ spilindex -+ spilkoers -+ spilkoersen -+ spilpositie -+ spiltrap -+ spiltrappen -+ spin-offs -+ spinazieblad -+ spindel -+ spindels -+ spindoctor -+ spindoctors -+ spindraad -+ spinnakers -+ spinnenkoppen -+ spinning -+ spinozist -+ spinozisten -+ spinsde -+ spinstok -+ spinstokken -+ spinzen -+ spionageactiviteit -+ spionageactiviteiten -+ spionagefilm -+ spionagenet -+ spionagenetwerk -+ spionageroman -+ spionageromans -+ spionagesatelliet -+ spionagesatellieten -+ spionageverhaal -+ spionageverhalen -+ spionagevliegtuig -+ spionagevliegtuigen -+ spionagewerk -+ spionagezaak -+ spionkop -+ spionkoppen -+ spionnes -+ spiraalboor -+ spiraalboren -+ spiraalnevel -+ spiraalnevels -+ spiraalstelsel -+ spiritualistische -+ spiritusstellen -+ spirocheten -+ spitant -+ spitante -+ spitsbus -+ spitsbussen -+ spitsenduo -+ spitsenprobleem -+ spitskolen -+ spitskool -+ spitsspeler -+ spitsspelers -+ spitsstroken -+ spitsstrook -+ spitstechnologie -+ spitstechnologieën -+ spitstrein -+ spitstreinen -+ spitsvignet -+ spitwerk -+ splijtingsproces -+ splijtingsproduct -+ splijtingsproducten -+ splijtstaaf -+ splijtstaven -+ splijtstofcycli -+ splijtstofcyclus -+ splijtstofelement -+ splijtstofelementen -+ splijtstofstaaf -+ splijtstofstaven -+ splinterbom -+ splinterbommen -+ splintergroep -+ splintergroepen -+ splintergroepering -+ splintergroeperingen -+ splinterpartij -+ splinterpartijen -+ splinterpartijtje -+ splitgevaar -+ splitrok -+ splitrokken -+ spoedbehandelingen -+ spoedberaad -+ spoedbijeenkomst -+ spoeddebat -+ spoedoperatie -+ spoedoperaties -+ spoedopnamen -+ spoedopnames -+ spoedprocedure -+ spoedprocedures -+ spoedshalve -+ spoedzitting -+ spoedzittingen -+ spoelkeuken -+ spoelkeukens -+ spoelmachines -+ spondei -+ spongiform -+ spongiforme -+ sponshanddoek -+ sponshanddoeken -+ sponsorbijdrage -+ sponsorbijdragen -+ sponsorinkomsten -+ sponsornaam -+ sponsornamen -+ sponsorovereenkomst -+ sponsorschap -+ sponsorschenking -+ sponsorschenkingen -+ sponsorwerving -+ sponsrubber -+ spookrijders -+ spookverhalen -+ spoorbiels -+ spoorbus -+ spoorbussen -+ spooremplacement -+ spoorinfrastructuur -+ spoorlijntje -+ spoornet -+ spoorstaking -+ spoortracé -+ spoorvorming -+ spoorwagon -+ spoorwagons -+ spoorwegarbeider -+ spoorwegarbeiders -+ spoorwegbouw -+ spoorwegbrug -+ spoorwegemplacement -+ spoorwegennet -+ spoorwegknooppunt -+ spoorwegman -+ spoorwegmannen -+ spoorwegmaterieel -+ spoorwegonderneming -+ spoorwegondernemingen -+ spoorwegstakingen -+ spoorwegtechniek -+ spoorwegtunnel -+ spoorwegtunnels -+ spoorwegverbinding -+ spoorwegverbindingen -+ spoorwegwissel -+ spoorzoekertje -+ sporenkievit -+ sporenkieviten -+ sport-bh -+ sport-bh's -+ sport-bh'tje -+ sportacademie -+ sportartikelenfabrikant -+ sportartsen -+ sportbeha -+ sportbeha's -+ sportbehaatje -+ sportbeoefenaarster -+ sportbeoefening -+ sportblessure -+ sportblessures -+ sportbulletin -+ sportdag -+ sportdagen -+ sportdirecteur -+ sportdirecteuren -+ sportdirecteurs -+ sportdrank -+ sportdranken -+ sportduiker -+ sportduikers -+ sporters -+ sportfiets -+ sportfietsen -+ sporthallen -+ sporthygiëne -+ sportieveling -+ sportievelingen -+ sportinstructeur -+ sportjournaal -+ sportjournalistiek -+ sportklimmen -+ sportkrant -+ sportkranten -+ sportleraars -+ sportlieden -+ sportlievend -+ sportlievende -+ sportlui -+ sportmanifestatie -+ sportmodel -+ sportmodellen -+ sportofficial -+ sportofficials -+ sportorganisatie -+ sportpagina -+ sportpagina's -+ sportpaleis -+ sportpaleizen -+ sportpark -+ sportparken -+ sportprestatie -+ sportprestaties -+ sportpsycholoog -+ sportraad -+ sportredactie -+ sportschoolhouder -+ sportschoolhouders -+ sportsponsoring -+ sportstadion -+ sportstadions -+ sportsterren -+ sportsters -+ sportsturen -+ sportstuur -+ sporttaal -+ sporttak -+ sporttakken -+ sporttassen -+ sportte -+ sporttechnisch -+ sporttechnische -+ sporttenue -+ sporttenues -+ sporttoto -+ sportuitzendingen -+ sportverenigingen -+ sportverslaggever -+ sportverslaggevers -+ sportverslaggeving -+ sportvissen -+ sportvisser -+ sportvisserij -+ sportvissers -+ sportvriend -+ sportvrienden -+ sportvrouwen -+ sportwagentje -+ sportzaak -+ sportzak -+ sportzaken -+ sportzakken -+ spotblad -+ spotbladen -+ spotlijster -+ spotlijsters -+ spotmarkt -+ spotmarkten -+ spots -+ spraakcentra -+ spraakcentrum -+ spraakchip -+ spraakchips -+ spraakherkenning -+ spraakles -+ spraaklessen -+ spraaksynthese -+ spraaktechnologie -+ spraaktechnologisch -+ spraaktechnologische -+ spraakwatervallen -+ sprakeloost -+ sprankeling -+ sprankjes -+ sprayde -+ sprayt -+ spreads -+ spreekstalmeester -+ spreekstalmeesters -+ spreekstem -+ spreekstemmen -+ spreekstijl -+ spreektalig -+ spreektalige -+ spreidingsplan -+ spreidlicht -+ spreidlichten -+ spreidvoet -+ spreidvoeten -+ spreidzit -+ sprekerslijst -+ sprekerstafel -+ sprietantenne -+ sprietantennes -+ spring-in-'t-velden -+ spring-in-'t-velds -+ springbak -+ springbakken -+ springbalk -+ springbalsemien -+ springbalsemienen -+ springconcoursen -+ springerig -+ springerige -+ springfout -+ springfouten -+ springkikker -+ springkikkers -+ springladingen -+ springlat -+ springlatten -+ springparcours -+ springruiterteam -+ springspin -+ springspinnen -+ springsport -+ springtuig -+ springuren -+ springuur -+ springvorm -+ springvormen -+ springvrucht -+ springvruchten -+ sprinkhaanrietzanger -+ sprinkhaanrietzangers -+ sprintafstand -+ sprintduel -+ sprintkernploeg -+ sprintnummer -+ sprintnummers -+ sprintster -+ sprintsters -+ sprinttitel -+ sproei-installatie -+ sproei-installaties -+ sproeidop -+ sproeidoppen -+ sproeiflacon -+ sproeiflacons -+ sproeikop -+ sproeikoppen -+ sproeistof -+ sproeistoffen -+ sproeivliegtuigen -+ sprongbeen -+ sprongbeenderen -+ sprongbenen -+ sprongkracht -+ sprongservice -+ sprookjesboek -+ sprookjesboeken -+ sprookjesfiguren -+ sprookjesfiguur -+ sprookjeskasteel -+ sprookjeskastelen -+ sprookjesland -+ sprookjeslanden -+ sprookjespaleis -+ sprookjesprins -+ sprookjesprinsen -+ sprookjeswerelden -+ spruitje -+ spruitjesgeur -+ spruitjeslucht -+ spruitstukken -+ spuitbeton -+ spuitmasker -+ spuitmaskers -+ spuitmiddel -+ spuitpistolen -+ spuitpistool -+ spuitpoep -+ spuitzak -+ spurter -+ spuugbak -+ spuugbakken -+ spuuglelijk -+ spuuglelijke -+ spuuglok -+ spuuglokken -+ spyware -+ spécialité -+ spécialités -+ squareback -+ squarebacks -+ squashbaan -+ squashbanen -+ squashbond -+ squashers -+ squashsport -+ squashte -+ staafbatterijen -+ staafdiagrammen -+ staafmixer -+ staafvorm -+ staafvormen -+ staakmolen -+ staakmolens -+ staakt-het-vuren -+ staalarbeider -+ staalarbeiders -+ staalbedrijf -+ staalbouw -+ staalconstructiebedrijf -+ staalconstructies -+ staalexport -+ staalfabrikant -+ staalindustrie -+ staalkabelactiviteiten -+ staalmagnaat -+ staalproductie -+ staalsanering -+ staalskelet -+ staalskeletten -+ staalsoorten -+ staangelden -+ staantribune -+ staantribunes -+ staarlijder -+ staarlijders -+ staaroperatie -+ staartdeelde -+ staartdelen -+ staartdelingen -+ staartgeboorte -+ staartgeboorten -+ staartgeboortes -+ staartparachutes -+ staartpen -+ staartpennen -+ staartpeper -+ staartwortel -+ staartwortels -+ staatkundigen -+ staatsaangelegenheden -+ staatsaangelegenheid -+ staatsamateur -+ staatsamateurs -+ staatsarchief -+ staatsarchieven -+ staatsbanken -+ staatsbankroet -+ staatsbegrafenis -+ staatsbegrafenissen -+ staatsbesluit -+ staatsbesluiten -+ staatsbezoek -+ staatsbezoeken -+ staatsbon -+ staatsbonnen -+ staatsbons -+ staatschef -+ staatschefs -+ staatscircus -+ staatscircussen -+ staatseigendom -+ staatseigendommen -+ staatsfinanciën -+ staatsgezondheidszorg -+ staatsgrens -+ staatsgrenzen -+ staatshervorming -+ staatshervormingen -+ staatshuishouding -+ staatsideologie -+ staatsiebezoeken -+ staatsindustrie -+ staatsindustrieën -+ staatsinvesteringsmaatschappij -+ staatskapitalisme -+ staatsluchtvaartmaatschappij -+ staatslui -+ staatsmannen -+ staatsminister -+ staatsministers -+ staatsobligatie -+ staatsomroep -+ staatsondermijnend -+ staatsondermijnende -+ staatsonderneming -+ staatsondernemingen -+ staatsonderwijs -+ staatsorde -+ staatsorden -+ staatsordes -+ staatspensioen -+ staatspensioenen -+ staatsprijs -+ staatsprijzen -+ staatsraison -+ staatsrechtgeleerde -+ staatsrechtgeleerden -+ staatsrechtsgeleerde -+ staatsrechtsgeleerden -+ staatsscholen -+ staatsschool -+ staatssecretariaten -+ staatsspoorwegmaatschappij -+ staatsstructuren -+ staatsstructuur -+ staatstelevisie -+ staatsterrorisme -+ staatsuitgeverijen -+ staatsveiligheid -+ staatsvijand -+ staatsvijanden -+ staatswaarborg -+ staatswinkel -+ staatswinkels -+ staatsziekenhuis -+ staatsziekenhuizen -+ stabilisatieprogramma -+ stabilisering -+ stabiliseringen -+ stabiliseringsprogramma -+ stabiliteitspolitiek -+ staccatocultuur -+ staccatostijl -+ stadgenotes -+ stadhouder-koning -+ stadhuiscomplex -+ stadionbezoek -+ stadionbezoeker -+ stadiondirectie -+ stadionspeaker -+ stadionterrein -+ stadsarcheoloog -+ stadsarchivaris -+ stadsarchivarissen -+ stadsauto -+ stadsauto's -+ stadsautootje -+ stadsbeelden -+ stadsbeiaardier -+ stadsbevolking -+ stadscreolen -+ stadscreool -+ stadscultuur -+ stadsdeelkantoor -+ stadsdeelkantoren -+ stadsdeelraden -+ stadsdienst -+ stadsduif -+ stadsduiven -+ stadsfiets -+ stadsgas -+ stadsgemeente -+ stadsgemeenten -+ stadsgemeentes -+ stadsgenotes -+ stadsgewest -+ stadsgewesten -+ stadsguerrilla -+ stadsguerrillaorganisatie -+ stadskaart -+ stadskern -+ stadskernen -+ stadskeur -+ stadskledij -+ stadsleven -+ stadsnomade -+ stadsnomaden -+ stadspas -+ stadsplan -+ stadsplannen -+ stadsplans -+ stadsplein -+ stadspoort -+ stadspoorten -+ stadsprovincie -+ stadsprovincies -+ stadsrit -+ stadsritten -+ stadsschoon -+ stadstaat -+ stadstaten -+ stadstuin -+ stadstuinen -+ stadsvernieuwingswijk -+ stadsvernieuwingswijken -+ stadsvervoer -+ stadsvervoersbedrijf -+ stadswacht -+ stadswachten -+ stafbesprekingen -+ stafchefs -+ stafmedewerkster -+ stafpersoneel -+ stafvergadering -+ stage-ervaring -+ stage-ervaringen -+ stageactiviteit -+ stageactiviteiten -+ stagebegeleiding -+ stagedive -+ stagedivede -+ stagediven -+ stagediver -+ stagedivers -+ stagedivet -+ stagejaar -+ stageld -+ stageopdracht -+ stageopdrachten -+ stagerapport -+ stagerapporten -+ stagetijd -+ stagfok -+ stagfokken -+ stagnering -+ stahoogte -+ stakeholder -+ stakeholders -+ stakenas -+ stakerig -+ stakerige -+ stakingsactie -+ stakingsacties -+ stakingsbrekers -+ stakingscomité -+ stakingscomités -+ stakingsdag -+ stakingsdagen -+ stakingsgolf -+ stakingsgolven -+ stakingsleiders -+ stakingspiket -+ stakingspiketten -+ stakingspost -+ stakingsposten -+ stakingsverbod -+ stakingswet -+ stakingswetten -+ stakkerig -+ stakkerige -+ stalbaas -+ stalgenoot -+ stalinisten -+ stalinistische -+ stalinorgel -+ stalinorgels -+ stalk -+ stalken -+ stalkers -+ stalkt -+ stalkte -+ stallencomplex -+ stallucht -+ stamboekpaard -+ stamboekpaarden -+ stamcafés -+ stamgebied -+ stamgebieden -+ stamineetje -+ stamleden -+ stamlid -+ stamlokaal -+ stamlokalen -+ stammorfeem -+ stammorfemen -+ stamouder -+ stamoudste -+ stamoudsten -+ stampij -+ stampvat -+ stamtaal -+ stamtalen -+ stamtijd -+ stamtijden -+ stamverband -+ stamverbanden -+ stamvorm -+ stamvormen -+ stamwapen -+ stamwapens -+ stand-upcomedian -+ stand-upcomedians -+ stand-upcomedy -+ stand-upcomedy's -+ standaardafmetingen -+ standaardformulier -+ standaardformulieren -+ standaardgezin -+ standaardgezinnen -+ standaardiseringen -+ standaardmeter -+ standaardmolens -+ standaardoplossing -+ standaardoplossingen -+ standaardpakketpolis -+ standaardpakketpolissen -+ standaarduitdrukking -+ standaarduitvoering -+ standaardvoorbeeld -+ standaardvoorbeelden -+ standbeen -+ standgenoot -+ standgenoten -+ standhouder -+ standhouders -+ standingvol -+ standingvolle -+ standlicht -+ standlichten -+ standpuntbepalingen -+ standruimte -+ standsbewustzijn -+ standsuitgave -+ standsuitgaven -+ standyoghurt -+ stangde -+ stankgolf -+ stankhinder -+ stankprobleem -+ stanste -+ stanza's -+ stapelverliefd -+ stapelverliefde -+ stappertje -+ starfruit -+ starfruits -+ startakkoord -+ startbewijs -+ startbewijzen -+ startblok -+ startbox -+ startboxen -+ startensklaar -+ startensklare -+ startgeld -+ startgelden -+ startklare -+ startlijn -+ startlijnen -+ startmotors -+ startpagina's -+ startpistolen -+ startplaats -+ startplaatsen -+ startseinen -+ startstipendium -+ startsubsidies -+ startverbod -+ startvergunning -+ startvergunningen -+ state of the art -+ state-of-the-artartikel -+ statensysteem -+ statiegeldregeling -+ statiegeldsysteem -+ stationcars -+ stationcartje -+ stationsemplacements -+ stationshallen -+ stationskap -+ stationskiosk -+ stationsoverkapping -+ stationsoverkappingen -+ stationsroman -+ stationsromannetje -+ stationsromans -+ statistiekbureau -+ statte -+ statten -+ statueske -+ statusladder -+ statusobject -+ statuste -+ statusverhogend -+ statusverhogende -+ statusverlies -+ steakhouse -+ steakhouses -+ stearinezuur -+ stedenbouwkundigen -+ steekneus -+ steekneuzen -+ steekpartijen -+ steekpass -+ steekpassers -+ steekpasses -+ steekpenningenaffaire -+ steekpenningenrekening -+ steeksleutel -+ steeksleutels -+ steekspelletje -+ steekwagentje -+ steekwoord -+ steekwoorden -+ steekzak -+ steelaanzet -+ steelbands -+ steelgitaar -+ steelguitars -+ steelguitartje -+ steelpannetje -+ steenbeitel -+ steenbeitels -+ steenberg -+ steenbergen -+ steenblok -+ steenblokken -+ steenboor -+ steenboren -+ steendrukkunst -+ steenformatie -+ steenformaties -+ steengoede -+ steengravure -+ steengravures -+ steengril -+ steengrilde -+ steengrill -+ steengrillen -+ steengrills -+ steengrilt -+ steenhoop -+ steenhopen -+ steenkolenengels -+ steenkolenwinning -+ steenkoolproductie -+ steenkoolwinning -+ steenkring -+ steenkringen -+ steenloper -+ steenlopers -+ steenmassa -+ steenmassa's -+ steenuiltje -+ steenwoestijnen -+ steeplechasers -+ steeplechases -+ steeplers -+ stefanotis -+ steggelde -+ steggelen -+ stegosaurus -+ stegosaurussen -+ steigerplank -+ steilewandrijder -+ steilewandrijders -+ steilstarter -+ steilstarters -+ steilwandig -+ steilwandige -+ stekeltjeshaar -+ stekkerdoos -+ stekkerdozen -+ stekkies -+ tewerk -+ stellende -+ stellingenoorlog -+ stellingmolen -+ stellingmolens -+ stellingsgevoel -+ stelmoer -+ stelmoeren -+ stelphoeve -+ stelphoeven -+ stelselwijziging -+ stelselwijzigingen -+ steltlopen -+ steltlopertje -+ stemadviescommissie -+ stemadviezen -+ stembereik -+ stembusafspraak -+ stembusafspraken -+ stembusgang -+ stembusstrijd -+ stemcijfer -+ stemfluitje -+ stemfluitjes -+ stemformulier -+ stemgebruik -+ stemhokjes -+ stemkunstenaar -+ stemma's -+ stemmachines -+ stemmata -+ stemmingmakerij -+ stemmingsindex -+ stemmingsronde -+ stemmingsronden -+ stemmingsrondes -+ stemmingsverbetering -+ stemmingsvol -+ stemmingsvolle -+ stemmingswisseling -+ stemmingswisselingen -+ stemonthoudingen -+ stempelautomaten -+ stempelgeld -+ stempelkaarten -+ stempelmerk -+ stempelmerken -+ stempelvorm -+ stemrechtbeperking -+ stemrechtbeperkingen -+ stemsleutel -+ stemsleutels -+ stemtest -+ stemtests -+ stemvastheid -+ stemverklaringen -+ stenengooier -+ stenengooiers -+ stengelvezel -+ stengelvezels -+ stens -+ step-ins -+ steppekiekendief -+ steppekiekendieven -+ steppekievit -+ steppekieviten -+ steppes -+ steppingstone -+ steppingstones -+ steppingstonetheorie -+ ster-van-bethlehem -+ sterachtig -+ sterachtige -+ stereo-installatie -+ stereo-installaties -+ stereo-opname -+ stereo-opnamen -+ stereo-opnames -+ stereo-uitzending -+ stereo-uitzendingen -+ stereofoto -+ stereofoto's -+ stereoplaat -+ stereoplaten -+ stereotorens -+ stereotypes -+ sterexplosie -+ sterfdata -+ sterfdatum -+ sterfdatums -+ sterfhuisconstructies -+ sterfkamers -+ sterflat -+ sterflats -+ sterfput -+ sterfputten -+ sterfscène -+ sterfscènes -+ sterftekansen -+ sterftepercentage -+ sterilisaties -+ steriliseerpot -+ steriliseerpotten -+ sterkhouder -+ sterkhouders -+ sterkte-zwakteanalyse -+ sterlicht -+ sterns -+ sterrenkundig -+ sterspeelster -+ sterspeler -+ sterspelers -+ stervensbegeleiders -+ stervensfase -+ stervensfasen -+ stervensfases -+ steunaankoop -+ steunaankopen -+ steunbedrag -+ steunbedragen -+ steunbetuiging -+ steunbetuigingen -+ steunfraudes -+ steunkous -+ steunkousen -+ steunmaatregel -+ steunmaatregelen -+ steunoperatie -+ steunoperaties -+ steunprogramma -+ steunregeling -+ steunschoen -+ steunschoenen -+ steunweefsel -+ steunweefsels -+ steunzenders -+ stewardessje -+ stichtingsakten -+ stichtingsaktes -+ stichtingsnorm -+ stichtingsnormen -+ stickertje -+ stickies -+ sticks -+ stiefbroers -+ stiefelde -+ stiefelen -+ stiefgezin -+ stiefgezinnen -+ stiekempjes -+ stielkennis -+ stielvaardig -+ stielvaardige -+ stiftbal -+ stiftballetje -+ stiftte -+ stigma's -+ stigmatisering -+ stijfgeklopt -+ stijfgeklopte -+ stijfgevloekt -+ stijfkramp -+ stijfvloeken -+ stijgingspercentage -+ stijgingspercentages -+ stijgingstempo -+ stijgsnelheid -+ stijlbesef -+ stijlbreuk -+ stijlbreuken -+ stijldans -+ stijldansen -+ stijlelement -+ stijlelementen -+ stijlfout -+ stijlkamer -+ stijlkamers -+ stijlkenmerk -+ stijlkenmerken -+ stijlkritiek -+ stijllabel -+ stijllabels -+ stijlloosheid -+ stijlniveau -+ stijlniveaus -+ stijlperiode -+ stijlvast -+ stijlvaste -+ stijlverschil -+ stijlverschillen -+ stikstofbinding -+ stikstofdioxide -+ stikstofgas -+ stikstofoxide -+ stikstofoxiden -+ stilering -+ stileringen -+ stille willie -+ stille willies -+ stillegging -+ stiltecentra -+ stiltecentrum -+ stiltegebied -+ stiltegebieden -+ stimulatoren -+ stimulators -+ stimuleringen -+ stimuleringsgebied -+ stimuleringsgebieden -+ stinkkaas -+ stinkvogel -+ stinkvogels -+ stinkzwam -+ stinkzwammen -+ stins -+ stinsen -+ stinsenflora -+ stinsenplant -+ stinsenplanten -+ stirlingmotor -+ stirlingmotoren -+ stirlingmotors -+ stockcarrace -+ stockcarraces -+ stockcars -+ stockdividenden -+ stockeerde -+ stockholmsyndroom -+ stoefen -+ stoefte -+ stoeipoezen -+ stoelleuning -+ stoelleuningen -+ stoelpoot -+ stoelpoten -+ stoelzittingen -+ stoepa's -+ stoepenzout -+ stoepparkeren -+ stoeptegel -+ stoeptegels -+ stoepzout -+ stofboel -+ stofdicht -+ stofdichte -+ stofgehalte -+ stofhoes -+ stofhoezen -+ stofkammen -+ stofkap -+ stofkappen -+ stofknoop -+ stofknopen -+ stoflong -+ stoflongen -+ stofmasker -+ stofmaskers -+ stofstorm -+ stofstormen -+ stofuitdrukking -+ stofwisselingsproces -+ stofwisselingsstoornis -+ stofwisselingsstoornissen -+ stofwisselingsziektes -+ stofzuigerde -+ stofzuigeren -+ stofzuigerslang -+ stofzuigerslangen -+ stokbonen -+ stokboon -+ stokbroden -+ stokmaat -+ stokmaten -+ stokmeter -+ stokmeters -+ stokpop -+ stokpoppen -+ stola's -+ stollingen -+ stollingsfactor -+ stollingsfactoren -+ stolpboerderijen -+ stolpnaad -+ stolpnaden -+ stoma's -+ stomtoevallig -+ stomtoevallige -+ stoneleek -+ stoneleeks -+ stonewashed -+ stooflap -+ stooflappen -+ stoofvlees -+ stookgas -+ stookkanalen -+ stookkosten -+ stookplaat -+ stookplaten -+ stoomstrijkijzer -+ stoomstrijkijzers -+ stoomtrammetje -+ stoomwolk -+ stoomwolken -+ stootbanden -+ stootbeitel -+ stootbeitels -+ stootrand -+ stootranden -+ stootsgewijs -+ stootsgewijze -+ stoottonen -+ stoottoon -+ stootvogel -+ stootvogels -+ stootwapen -+ stootwapens -+ stootzak -+ stootzakken -+ stopbussen -+ stopkogel -+ stopkogels -+ stopsignalen -+ stopwatches -+ stopzettingen -+ stormbaan -+ stormbanen -+ stormdepressies -+ stormfok -+ stormfokken -+ stormgebieden -+ stormlamp -+ stormlampen -+ stormlantaarns -+ stormlantaren -+ stormlantarens -+ stormrampen -+ stormrijp -+ stormrijpe -+ stormvast -+ stormvaste -+ stormvloedkering -+ stormvloedkeringen -+ stormwaarschuwing -+ stormwaarschuwingen -+ storno's -+ stortgas -+ stortgeld -+ stortgoedtechnologie -+ stortgoot -+ stortgoten -+ stortingsbulletin -+ stortingsbulletins -+ stortingsdata -+ stortingsdatum -+ stortingskaarten -+ stortklep -+ stortkleppen -+ straalbezopen -+ straalbuismotor -+ straalbuismotoren -+ straalbuismotors -+ straalgewelf -+ straalgewelven -+ straaljagerpiloot -+ straaljagerpiloten -+ straalkacheltje -+ straalstroom -+ straalturbine -+ straalturbines -+ straalverkeersvliegtuig -+ straalverkeersvliegtuigen -+ straalzenders -+ straatactie -+ straatacties -+ straatartiest -+ straatartiesten -+ straatbeelden -+ straatbende -+ straatbendes -+ straatblok -+ straatblokken -+ straatcollecte -+ straatcollecten -+ straatcollectes -+ straatcriminaliteit -+ straatdeur -+ straatdeuren -+ straatdienst -+ straatfiguren -+ straatfiguur -+ straatfotograaf -+ straatfotografen -+ straatgeluid -+ straatgeluiden -+ straatgeweld -+ straatgras -+ straathandelaar -+ straathoekwerker -+ straathoekwerkers -+ straatinterview -+ straatinterviews -+ straatjongetje -+ straatjunkenproject -+ straatkanten -+ straatkat -+ straatkatten -+ straatkind -+ straatkolk -+ straatkolken -+ straatlengten -+ straatlengtes -+ straatleven -+ straatnaamgeving -+ straatnamenboek -+ straatnamencommissie -+ straatniveau -+ straatprostituee -+ straatprostituees -+ straatprostitutie -+ straatrace -+ straatracen -+ straatracer -+ straatracers -+ straatraces -+ straatracet -+ straatracete -+ straatroof -+ straatschoffie -+ straatschoffies -+ straattheater -+ straatvechter -+ straatvechterij -+ straatvechters -+ straatvechtersmentaliteit -+ straatvegen -+ straatventer -+ straatventers -+ straatverkoop -+ straatverkoper -+ straatverkopers -+ straatvoetbal -+ straatwaarde -+ straddles -+ strafactie -+ strafacties -+ strafbal -+ strafballen -+ strafballenserie -+ strafbank -+ strafbladen -+ strafcel -+ strafcellen -+ strafcorner -+ strafcorners -+ strafcornerspecialist -+ strafdossier -+ strafdossiers -+ strafgriffie -+ strafheffing -+ strafheffingen -+ strafinrichting -+ strafinrichtingen -+ strafkamp -+ strafkampen -+ strafklas -+ straflijst -+ straflokaal -+ strafontslag -+ strafopleggingen -+ strafpleiters -+ strafprocedures -+ strafprocesrecht -+ strafrechtadvocaat -+ strafrechtadvocaten -+ strafrechthervorming -+ strafrechtpleging -+ strafrechtplegingen -+ strafrechtshervorming -+ strafrechtsketen -+ strafrechtspleging -+ strafrechtsplegingen -+ strafrechtspraak -+ strafrechtwetenschap -+ strafrechtwetenschappen -+ strafrede -+ strafschoppenreeks -+ strafschoppenserie -+ strafschopstip -+ strafschopstippen -+ strafseconde -+ strafseconden -+ strafstudie -+ strafstudies -+ strafsysteem -+ straftoemeting -+ straftoemetingsbeleid -+ strafuitsluitingsgrond -+ strafverlichting -+ strafvermindering -+ strafverminderingen -+ strafvonnissen -+ strafvorderlijk -+ strafvorderlijke -+ strafwaardigheid -+ strafworp -+ strafworpen -+ strakblauw -+ strakblauwe -+ strakgespannen -+ strakgetrokken -+ straktrekken -+ stralingsbelasting -+ stralingsbescherming -+ stralingsbron -+ stralingsdoses -+ stralingsdosissen -+ stralingsdruk -+ stralingsenergie -+ stralingsgenetica -+ stralingsgevaar -+ stralingsgordel -+ stralingsgordels -+ stralingsintensiteit -+ stralingsmeter -+ stralingsmeters -+ stralingsschade -+ stralingsveld -+ stralingsziekte -+ strandbaden -+ strandballen -+ strandboulevard -+ strandganger -+ strandgangers -+ strandhotel -+ strandhotels -+ strandhuisjes -+ strandjurk -+ strandjurken -+ strandleven -+ strandloop -+ strandlopen -+ strandpaal -+ strandpalen -+ strandpaviljoen -+ strandpaviljoenen -+ strandpaviljoens -+ strandtas -+ strandtassen -+ strandtenthouder -+ strandtenthouders -+ strandvogel -+ strandvogels -+ strandvolleybal -+ strandwandeling -+ strandwandelingen -+ strandweer -+ strandzand -+ strategiebepaling -+ stratego -+ strategode -+ strategoën -+ stratosferische -+ streak -+ streakt -+ streakte -+ streefdata -+ streefdatums -+ streefdoel -+ streefdoelen -+ streefgetallen -+ streefgewicht -+ streefpercentage -+ streekblad -+ streekbladen -+ streekbussen -+ streekcentra -+ streekdialect -+ streekgebonden -+ streekgenoot -+ streekgenoten -+ streekgerecht -+ streekgerechten -+ streekmusea -+ streekmuseums -+ streekplannen -+ streekplans -+ streekraden -+ streekschool -+ streeksgewijs -+ streeksgewijze -+ streekvervoerbedrijf -+ streekvervoersbedrijf -+ streekziekenhuis -+ streekziekenhuizen -+ streepdessins -+ streepjesbroek -+ streepjesbroeken -+ streepjescodes -+ streepjesoverhemd -+ streepjesoverhemden -+ streepjespak -+ streepjespakken -+ streeppatronen -+ streeppatroon -+ streetdance -+ streetwise -+ strekoefening -+ strekoefeningen -+ strenggelovig -+ strenggelovige -+ stres -+ stressbestendige -+ stresseerde -+ stresseren -+ stresserend -+ stresserende -+ stressfractuur -+ stressgevoelig -+ stressgevoelige -+ stresskonijn -+ stresskonijnen -+ stressreactie -+ stressreacties -+ stresssituatie -+ stresssituaties -+ stressverschijnsel -+ stressverschijnselen -+ strest -+ streste -+ stretchers -+ stretcht -+ stretchte -+ streving -+ strevingen -+ strijdgas -+ strijdgassen -+ strijdgewoel -+ strijdgroep -+ strijdgroepen -+ strijdkrachtonderdeel -+ strijdkrachtonderdelen -+ strijdmachten -+ strijdmethode -+ strijdmethodes -+ strijdpunten -+ strijdtuig -+ strijdwagen -+ strijdwagens -+ strijk-en-zet -+ strijkconcert -+ strijkconcerten -+ strijkecht -+ strijkechte -+ strijkersarrangement -+ strijkersarrangementen -+ strijkersgroep -+ strijkersklank -+ strijkkwintet -+ strijkkwintetten -+ strijklicht -+ strijktrio -+ strijkvrij -+ strijkvrije -+ strikes -+ stringentst -+ stripalbum -+ stripalbums -+ stripblad -+ stripbladen -+ stripfiguur -+ stripfiguurtje -+ stripheld -+ striphelden -+ stripmaker -+ stripmakers -+ striptang -+ striptangen -+ stripteasedanseres -+ stripteasedanseressen -+ stripteaseshow -+ stripteaseshows -+ stripteasetent -+ striptekenaars -+ stripverhaaltje -+ stripverpakking -+ stripverpakkingen -+ stripwinkel -+ stripwinkels -+ strobaal -+ strobalen -+ stroblond -+ stroblonde -+ stroboscopische -+ strofebouw -+ strofes -+ stroganoffsaus -+ strohalmpje -+ strokartonfabriek -+ strokenparket -+ strokleur -+ stromingsbron -+ stromingsbronnen -+ stromingspatronen -+ stromingsweerstand -+ strominkje -+ strompelaars -+ strontvervelend -+ strontvervelende -+ strooi-jonker -+ strooi-jonkers -+ strooibrief -+ strooibrieven -+ strooidop -+ strooidoppen -+ strooiwei -+ strooiweide -+ strooiweiden -+ strooiweides -+ stroombaan -+ stroombanen -+ stroomdal -+ stroomdalflora -+ stroomgeul -+ stroomgeulen -+ stroomkringen -+ stroomloze -+ stroommeter -+ stroommeters -+ stroommeting -+ stroommetingen -+ stroomnet -+ stroomnetten -+ stroomonderbrekingen -+ stroomopwekking -+ stroomprijs -+ stroomprijzen -+ stroomproductie -+ stroomregelaar -+ stroomregelaars -+ stroomstoot -+ stroomstoringen -+ stroomtoevoer -+ stroomverbruiker -+ stroomverbruikers -+ stroomvreter -+ stroomvreters -+ stroopsmeerders -+ stroopsmeren -+ stroperigheid -+ stroppenpotten -+ strottenhoofden -+ strovezelplaat -+ strovezelplaten -+ structuralisten -+ structuralistische -+ structurenvergadering -+ structurenvergaderingen -+ structureringen -+ structuurloos -+ structuurloze -+ structuurplan -+ structuurplannen -+ structuurschema's -+ structuurschets -+ structuurvennootschap -+ structuurvennootschappen -+ structuurwijzigingen -+ struikachtig -+ struikachtige -+ struikelpunt -+ struikelpunten -+ struinde -+ stucwerker -+ stucwerkers -+ studeerbaar -+ studeerbaarheid -+ studeerbare -+ student-assistent -+ studenten-assistenten -+ studenten-leden -+ studentenartsen -+ studentenbevolking -+ studentendecanen -+ studentendemonstratie -+ studentendemonstraties -+ studentenflats -+ studentengeneratie -+ studentenjargon -+ studentenkot -+ studentenkoten -+ studentenleider -+ studentenleiders -+ studentenpastor -+ studentenpastores -+ studentenpastors -+ studentenpredikant -+ studentenprotest -+ studentenprotesten -+ studentenraden -+ studentenrebellie -+ studentenrevolte -+ studentenrevolutie -+ studentenstad -+ studentensteden -+ studentenstops -+ studententoneel -+ studentenvakbonden -+ studentenverzet -+ studentenvoorziening -+ studentenweerbaarheden -+ studentenweerbaarheid -+ studentenzwangerschap -+ studie-ijver -+ studieadres -+ studieadressen -+ studieadvies -+ studiebegeleider -+ studiebegeleiders -+ studiebeurzenstelsel -+ studiebijeenkomst -+ studiebijeenkomsten -+ studiebureau -+ studiebureaus -+ studiecentra -+ studieclub -+ studiecommissie -+ studiecommissies -+ studiedoeleinden -+ studiedruk -+ studieduurverkorting -+ studiefinancieringsstelsel -+ studiegenoot -+ studiegidsen -+ studiehoofden -+ studiehuis -+ studiehuizen -+ studiekeuze -+ studiekeuzen -+ studiekeuzes -+ studieleider -+ studieles -+ studielessen -+ studiemeester -+ studiemeesters -+ studieobject -+ studieobjecten -+ studieplan -+ studieprefect -+ studieprefecten -+ studieprogramma's -+ studiepunt -+ studiepunten -+ studierendement -+ studierichtingsleider -+ studieschuld -+ studiestof -+ studieterrein -+ studieterreinen -+ studietijden -+ studietoelage -+ studietoelagen -+ studietoelages -+ studievereniging -+ studievoortgangscontrole -+ studievriend -+ studievrienden -+ studio-opname -+ studio-opnamen -+ studio-opnames -+ studiochef -+ studiochefs -+ studiocomplex -+ studiogast -+ studiogasten -+ studiopubliek -+ studioruimte -+ studiosessie -+ studiosessies -+ studiovloer -+ stuifgaten -+ stuifmeelkorrel -+ stuifmeelkorrels -+ stuiptrekte -+ stuitgeboorten -+ stuitgeboortes -+ stuiversromannetje -+ stukbijten -+ stuken -+ stukgebeten -+ stukgelopen -+ stukgescheurd -+ stukgoedbedrijf -+ stukjesschrijver -+ stukjesschrijvers -+ stukke -+ stuklopen -+ stukoffer -+ stukoffers -+ stukscheuren -+ stumperde -+ stumperen -+ stuntelaar -+ stuntels -+ stuntmannen -+ stuntteam -+ stuntwerk -+ stuudje -+ stuukte -+ stuurautomaat -+ stuurautomaten -+ stuurbaar -+ stuurbare -+ stuurbekrachtigingen -+ stuurcabines -+ stuurcomité -+ stuurcomités -+ stuurfout -+ stuurgedrag -+ stuurhoes -+ stuurhoezen -+ stuurknuppel -+ stuurknuppels -+ stuurkolommen -+ stuurkunde -+ stuurraket -+ stuurraketten -+ stuurschakeling -+ stuursloten -+ stuwadoorsbedrijf -+ stuwdamproject -+ stuwkrachten -+ stuwmeren -+ stuwraket -+ stuwraketten -+ stuwstraalmotor -+ stuwstraalmotoren -+ stuwstraalmotors -+ stuwwal -+ stuwwallen -+ styliste -+ stylisten -+ stylistes -+ stylo -+ stylo's -+ subatlanticum -+ subatomaire -+ subboreaal -+ subboreale -+ subcontinenten -+ subculturele -+ subculturen -+ subjectivistische -+ subjunctieven -+ sublimaties -+ sublimering -+ submicroscopisch -+ submicroscopische -+ subplots -+ subsidiariteitsbeginsel -+ subsidiebudget -+ subsidiegever -+ subsidieloos -+ subsidieloze -+ subsidieontvanger -+ subsidiepolitiek -+ subsidiestop -+ subsidiesysteem -+ subsidieverdeling -+ subsidieverzoek -+ subsidieverzoeken -+ subsidievoorwaarde -+ subsidievoorwaarden -+ subsidiologen -+ subsidiëringen -+ subsonische -+ substituut-griffiers -+ substituut-officieren -+ substituut-procureurs -+ substraattaal -+ substraattalen -+ substraatteelt -+ substructuren -+ substructuur -+ subtop -+ subtopper -+ subtoppers -+ subtractieve -+ subtropen -+ subversieve -+ succesboek -+ succesboeken -+ succesrijk -+ succesrijke -+ successchrijver -+ successievelijke -+ succubi -+ succubus -+ sudden death -+ sudderlap -+ sudderlappen -+ sudderplaat -+ sudderplaten -+ sufficiënte -+ sufkees -+ sufkezen -+ sufkop -+ sufkoppen -+ sugarsnap -+ sugarsnaps -+ suggestibel -+ suggestibele -+ suggestibiliteit -+ suggestiviteit -+ suikerbeestje -+ suikerbus -+ suikerbussen -+ suikerhart -+ suikerharten -+ suikerhoudend -+ suikerhoudende -+ suikerindustrie -+ suikerkorrel -+ suikerkorrels -+ suikermeloen -+ suikermeloenen -+ suikeroogst -+ suikeroompje -+ suikerpatiënt -+ suikerpatiënten -+ suikerprijs -+ suikerproductie -+ suikerrietplantage -+ suikerrietplantages -+ suikerrietveld -+ suikerrietvelden -+ suikerspiegel -+ suikerstroop -+ suikertaart -+ suikertaarten -+ suikerverwerkend -+ suikerverwerkende -+ suikerziek -+ suikerzieke -+ suikerzieken -+ suitedeur -+ suitedeuren -+ sukkeldrafje -+ sulfamiden -+ sulfanilamiden -+ sulfiden -+ sulky's -+ sultanarozijn -+ sultanarozijnen -+ summa's -+ summerschool -+ summerschools -+ sumo -+ sumoworstelaar -+ sumoworstelaars -+ sumoworstelen -+ sunroof -+ sunroofs -+ superclub -+ supercup -+ superdeeltjesversneller -+ superdoe-het-zelfzaak -+ superdun -+ superdunne -+ superetten -+ superettes -+ supergeleidend -+ supergeleidende -+ supergeleider -+ supergeleiders -+ supergezond -+ supergezonde -+ superhighway -+ superintelligente -+ superioriteitsgevoelens -+ superjumbo -+ superjumbo's -+ superklasse -+ superkritisch -+ superkritische -+ superman -+ supermannen -+ supermarktbranche -+ supermarktgigant -+ supermarktkarretje -+ supermarktkarretjes -+ supermarktketen -+ supermarktketens -+ supermarktpersoneel -+ supermens -+ supermensen -+ superministerraad -+ supermogendheden -+ supermogendheid -+ supernova -+ supernova's -+ supernovae -+ superoxiden -+ superoxides -+ superprestigeklassement -+ supers -+ superslim -+ superslimme -+ superstar -+ superstars -+ supersterren -+ superstructuren -+ superstructuur -+ supersub -+ supersubs -+ supertanker -+ supertankers -+ supertrio -+ supertrio's -+ supervedergewicht -+ supervetcool -+ superviseerde -+ superwinst -+ superwinsten -+ superzwaargewicht -+ supportact -+ supportacts -+ supporterde -+ supportersclub -+ supportersclubs -+ supporterslegioenen -+ supportersschare -+ supporterstrein -+ supporterstreinen -+ supportersvereniging -+ supports -+ suppositoire -+ suppositoires -+ supranationaal -+ supranaturalisme -+ suprematistische -+ surah -+ surfgedrag -+ surfsport -+ surimi -+ surimono -+ surimono's -+ surinamiseerde -+ surinamisme -+ surinamismen -+ surinamist -+ surinamisten -+ surinamistiek -+ suripop -+ surplace -+ surplacen -+ surplaces -+ surplacet -+ surplacete -+ surplustje -+ surpriseparty -+ surpriseparty's -+ surreële -+ surrogaatkoffie -+ surrogaatmoeder -+ surseanceaanvraag -+ surveillanceauto -+ surveillancedienst -+ surveillancewagen -+ surveillancewagens -+ survivalde -+ survivallen -+ survivalt -+ survivaltocht -+ survivaltochten -+ sushi's -+ sushibar -+ sushibars -+ suzanne-met-de-mooie-ogen -+ swami's -+ swaps -+ swastika's -+ sweeping statement -+ sweeping statements -+ swipi -+ swipi's -+ switcht -+ switchte -+ syllabes -+ syllabeschrift -+ symbolentaal -+ symbolieken -+ symbolisaties -+ symbolisering -+ symboliseringen -+ symbolistische -+ symboolfiguur -+ symboolfunctie -+ symboolpolitiek -+ symbooltje -+ symboolwaarde -+ symboolwerking -+ symmetrieas -+ symmetrieassen -+ sympathiebetuiging -+ sympathiebetuigingen -+ symposiums -+ synagoges -+ synchroonzwemmen -+ syncretische -+ syndicaatsleider -+ syndicale -+ syndiceerde -+ syndiceren -+ syndroom van Asperger -+ synecdoche's -+ synecdoches -+ synergetische -+ synergie-effect -+ synergie-effecten -+ synergievoordeel -+ synergievoordelen -+ synergisme -+ synodeleden -+ synodelid -+ synodevergadering -+ synoniemenwoordenboeken -+ synontologie -+ syntagma's -+ syntagmata -+ syntagmatische -+ syntheseroute -+ syntheseroutes -+ synthesizerklank -+ synthesizerklanken -+ synthesizermuziek -+ synthetiseerde -+ syrah -+ syrahs -+ syrahtje -+ systeemanalyses -+ systeembeheerder -+ systeembouwer -+ systeembouwers -+ systeemdenken -+ systeemdwang -+ systeemherstel -+ systeemkaarten -+ systeemontwerpers -+ systeemontwikkelingen -+ systeemtheorieën -+ systematiseringen -+ t's -+ t'tje -+ t-groep -+ t-groepen -+ t.a.v. -+ t.g.v. -+ taaide -+ taakafbakeningen -+ taakanalyses -+ taakbelasting -+ taakgroepen -+ taakleerkracht -+ taakleerkrachten -+ taakleraar -+ taakleraars -+ taakleraren -+ taakopvattingen -+ taakuitoefening -+ taakuren -+ taakuur -+ taakverdelingsoperatie -+ taalaanbod -+ taalachterstanden -+ taaladvies -+ taaladviseurs -+ taalarm -+ taalarme -+ taalbarrières -+ taalbehoud -+ taalbeleid -+ taalconsulent -+ taalconsulenten -+ taaldaad -+ taaldaden -+ taalgebonden -+ taalgeschiedenis -+ taalgevoelig -+ taalgevoelige -+ taalgidsen -+ taalkader -+ taalkamp -+ taalkampen -+ taalklank -+ taalklanken -+ taallabo -+ taallabo's -+ taalnorm -+ taalnormen -+ taalpariteit -+ taalpathologie -+ taalpurisme -+ taalpurist -+ taalpuristen -+ taalrol -+ taalrollen -+ taalrubriek -+ taalspel -+ taalspelen -+ taalspelletje -+ taalsysteem -+ taaltechnologie -+ taaltechnologisch -+ taaltechnologische -+ taalteken -+ taaltekens -+ taaltuinier -+ taaltuiniers -+ taalvaardigheden -+ taalvariatie -+ taalvergelijking -+ taalverloedering -+ taalverwerving -+ taalzorg -+ taartbodem -+ taartbodems -+ taartjeswinkel -+ taartjeswinkels -+ tabaksaccijns -+ tabaksaccijnzen -+ tabaksartikel -+ tabaksartikelen -+ tabaksfabrikant -+ tabaksreclame -+ tabakssap -+ tabakssappen -+ tabaksvergunning -+ tabaksvergunningen -+ tabakswaar -+ tabakswinkel -+ tabakswinkels -+ tabakswinkeltje -+ tabbetje -+ tabbetjes -+ tabkaarten -+ tabloids -+ taboedoorbrekend -+ taboedoorbrekende -+ taboeloos -+ taboeloze -+ taboeonderwerp -+ taboeonderwerpen -+ taboesfeer -+ taboulé -+ tabtoets -+ tabtoetsen -+ tabula rasa -+ tachografen -+ tachtigvoud -+ tachtigvouden -+ tachtigvoudig -+ tachtigvoudige -+ tachyonen -+ tackel -+ taco's -+ tacootje -+ tafelberg -+ tafelbergen -+ tafelbiljart -+ tafelbiljarten -+ tafelbiljarts -+ tafeldekken -+ tafeldoek -+ tafeldoeken -+ tafeleend -+ tafeleenden -+ tafelgarnituren -+ tafelgarnituur -+ tafelmodel -+ tafelschikkingen -+ tafelservies -+ tafelserviezen -+ tafelspringer -+ tafelspringers -+ tafeltennisbond -+ tafeltennisser -+ tafeltennissers -+ tafeltennissport -+ tafeltennisster -+ tafeltennistafel -+ tafeltennistafels -+ tafeltenniste -+ tafeltje-dek-je -+ tafelvoetbal -+ tafelvoetbalspel -+ tafelvoetbalspellen -+ tafelzeil -+ tafelzeilen -+ tag -+ tagger -+ taggers -+ tags -+ tahin -+ tai chi -+ tai-chi -+ tai-chiede -+ tai-chiet -+ tai-chiën -+ taiga's -+ taikoen -+ taikoens -+ tailleband -+ taillebanden -+ tailleerde -+ tajineschaal -+ takehometentamen -+ takehometentamens -+ takelauto's -+ takelbalk -+ takelbalken -+ takelinstallatie -+ takenpakketten -+ taksvrij -+ taksvrije -+ talencursus -+ talencursussen -+ taleninstituut -+ talenknobbels -+ talenlaboratoria -+ talenlaboratorium -+ talenlaboratoriums -+ talenonderwijs -+ talenpracticums -+ talenschool -+ talentenbank -+ talentenjachten -+ talentenjager -+ talentenjagers -+ talentloos -+ talentloze -+ talenwonder -+ talenwonders -+ talgklier -+ talgklieren -+ talgkliertje -+ taliban -+ talige -+ talkklier -+ talkklieren -+ talkkliertje -+ talkshowcircuit -+ talkshows -+ tallegio -+ talliet -+ tallship -+ tallships -+ tallshipsrace -+ tallshipsraces -+ taludje -+ tamagotchi -+ tamagotchi's -+ tamboerkorps -+ tamboerkorpsen -+ tamboers-majoor -+ tambour-maître -+ tambour-maîtres -+ tambour-maîtretje -+ tamponziekte -+ tandaanslag -+ tandartsassistente -+ tandartsassistenten -+ tandartsassistentes -+ tandartsboor -+ tandengepoetst -+ tandenknarsen -+ tandenknarste -+ tandenpoetsen -+ tandenstokertje -+ tandhals -+ tandhalzen -+ tandmedeklinker -+ tandmedeklinkers -+ tandoori -+ tandoori's -+ tandoorikip -+ tandoorikruiden -+ tandpasta's -+ tandplaque -+ tandplaques -+ tandprothesen -+ tandprotheses -+ tandtechnisch -+ tandtechnische -+ tandvleesontsteking -+ tandvleesontstekingen -+ tandwalvis -+ tandwalvissen -+ tandwolf -+ tangaslip -+ tangaslips -+ tangbeweging -+ tangbewegingen -+ tango's -+ tankauto's -+ tankbataljon -+ tankbataljons -+ tankdivisie -+ tankdivisies -+ tankeenheden -+ tankeenheid -+ tankercapaciteit -+ tankgeschut -+ tankopslag -+ tankopslagbedrijf -+ tankslag -+ tankslagen -+ tankvliegtuig -+ tankvliegtuigen -+ tankvloot -+ tankvloten -+ tankwagon -+ tankwagons -+ tantalusbeker -+ tantalusbekers -+ tantaluskwelling -+ tantaluskwellingen -+ tanteagaathregeling -+ tantebetjestijl -+ taoïstische -+ tapasbar -+ tapasbars -+ tapbier -+ tapbieren -+ tapedecks -+ tapenade -+ tapenades -+ taperecorder -+ taperecorders -+ tapet -+ tapete -+ tapijtfabrikant -+ tapijtgaren -+ tapijtgarens -+ tapijtindustrie -+ tapijtkever -+ tapijtkevers -+ tapijtslang -+ tapijtslangen -+ tapis-plain -+ tapis-plains -+ tapkraan -+ tapkranen -+ tapplaats -+ tapplaatsen -+ tappunt -+ tappunten -+ tarantella's -+ tarantula's -+ tarboesj -+ tarboesjen -+ targets -+ targoem -+ targoems -+ tariefafspraak -+ tariefafspraken -+ tariefgroepindeling -+ tariefschijf -+ tariefschijven -+ tariefstelsel -+ tariefstijging -+ tariefstijgingen -+ tariefsverhogingen -+ tariefsverlaging -+ tariefsverlagingen -+ tariefverhoging -+ tariefverhogingen -+ tariefverlaging -+ tariefverlagingen -+ tarievenslag -+ tarievenstrijd -+ tarifaire -+ tarmac -+ tarokkaart -+ tarokkaarten -+ tarots -+ tarpan -+ tarpans -+ tartaartje -+ tartaartjes -+ tarwezemelen -+ tasjesrover -+ taskforce -+ tatami -+ tatami's -+ taveernes -+ tavernes -+ taxa -+ taxatierapporten -+ taxatiewaarde -+ taxibaan -+ taxioorlog -+ taxipost -+ taxiritten -+ taxistop -+ taxonomen -+ taxonomieën -+ taxonomische -+ taylorstelsel -+ tb -+ tbs -+ tbs-kliniek -+ tbs-klinieken -+ tbs-patiënt -+ tbs-patiënten -+ teach-in -+ teach-ins -+ teakdek -+ teakdekken -+ teakolie -+ teambuilding -+ teamchef -+ teamchefs -+ teamgenoten -+ teamleider -+ teamleiders -+ teammanager -+ teamspirit -+ teamsport -+ teamsporten -+ teamwedstrijd -+ teamwedstrijden -+ techina -+ techniekgeschiedenis -+ technieklokaal -+ technisch-economisch -+ technisch-economische -+ technisch-juridisch -+ technisch-wetenschappelijk -+ technisch-wetenschappelijke -+ technocratisering -+ technokeuringen -+ technologieakkoord -+ technologiebeleid -+ technologieoverdracht -+ technologieprogramma -+ technologieprogramma's -+ technologierace -+ teckels -+ teckeltje -+ tectyleerde -+ teddy's -+ teeg aan -+ teeltmethode -+ teeltmethoden -+ teeltmethodes -+ teeltwijze -+ teenagers -+ teenkootjes -+ teennagel -+ teennagels -+ teenslipper -+ teenslippers -+ teerbemind -+ teerfeest -+ teerfeesten -+ teevees -+ teeveetje -+ teeveetoestellen -+ tefilin -+ tefille -+ tegelkachel -+ tegelkachels -+ tegeltableau -+ tegeltableaus -+ tegeltjeswijsheden -+ tegeltjeswijsheid -+ tegelwanden -+ tegelzetten -+ tegelzetter -+ tegelzetters -+ tegemoetgezien -+ tegemoetzien -+ tegenacties -+ tegenbetoging -+ tegenbeweging -+ tegenbewegingen -+ tegencoup -+ tegencoups -+ tegenculturen -+ tegendemonstratie -+ tegendemonstraties -+ tegendoelpunt -+ tegendoelpunten -+ tegendraadsheid -+ tegeneen -+ tegeneffect -+ tegeneffecten -+ tegengestuurd -+ tegengoal -+ tegengoals -+ tegenkant -+ tegenlichtopnames -+ tegenpleiters -+ tegenreactie -+ tegenregering -+ tegenstroming -+ tegenstromingen -+ tegensturen -+ tegentreffer -+ tegentreffers -+ tegenvoets -+ tegenvoetse -+ tegenvragen -+ tegenvuren -+ tegenvuur -+ tegoedbonnen -+ tegoedbons -+ tehuiskind -+ tehuiskinderen -+ tekenakte -+ tekenakten -+ tekenaktes -+ tekenares -+ tekenaressen -+ tekenblokken -+ tekendriehoeken -+ tekenfilmpje -+ tekenfilmserie -+ tekenfilmstudio -+ tekeningencollectie -+ tekeningententoonstelling -+ tekenkamers -+ tekenleer -+ tekenleraars -+ tekenleraren -+ tekenlinialen -+ tekenstijl -+ tekentafels -+ tekortdoen -+ tekortfinanciering -+ tekortgedaan -+ tekortgeschoten -+ tekortkomen -+ tekortnorm -+ tekortvermindering -+ tekstballon -+ tekstballonnen -+ tekstbegrip -+ tekstbezorger -+ tekstboekjes -+ tekstbord -+ tekstborden -+ tekstbordje -+ tekstdichter -+ tekstdichters -+ tekstflard -+ tekstflarden -+ tekstgedeeltes -+ tekstkritisch -+ tekstkritische -+ tekstloos -+ teksttelefoons -+ tekstverwerkingsprogramma's -+ tekstwetenschappen -+ tekstwolkje -+ tekstwolkjes -+ tekstzet -+ telboek -+ tele-informatie -+ telebankierde -+ telebankieren -+ telecard -+ telecards -+ telecommunicatie-industrie -+ telecommunicatie-infrastructuur -+ telecommunicatieapparatuur -+ telecommunicatiemaatschappij -+ telecommunicatienet -+ telecommunicatietechniek -+ teleconferentie -+ teledienst -+ telediensten -+ teledistributie -+ telefoonabonnee -+ telefoonbotje -+ telefoonbotjes -+ telefooncabine -+ telefooncabines -+ telefooncirkel -+ telefooncirkels -+ telefoonkaart -+ telefoonkaarten -+ telefoonkabel -+ telefoonkabels -+ telefoonklapper -+ telefoonklappers -+ telefoonmaatschappij -+ telefoonrekeningen -+ telefoonseks -+ telefoonstem -+ telefoonsysteem -+ telefoontarief -+ telefoontarieven -+ telefoto's -+ telekaart -+ telekaarten -+ telekranten -+ telematica-infrastructuur -+ telematische -+ teleobjectieven -+ teleonomie -+ telerecorder -+ telerecorders -+ telescoophengels -+ telescoopvoorvork -+ teleshoppers -+ teleurgang -+ televisie-inkomsten -+ televisieantenne -+ televisieantennes -+ televisieavond -+ televisiebeeld -+ televisiebeelden -+ televisiecommercial -+ televisiedebatten -+ televisiedominee -+ televisiedominees -+ televisiefilm -+ televisiegekeken -+ televisiegeniek -+ televisiegenieke -+ televisiegids -+ televisiejournalen -+ televisiekanaal -+ televisiekanalen -+ televisiekijker -+ televisiekijkers -+ televisiemagazine -+ televisiemakers -+ televisiemasten -+ televisienetten -+ televisienieuws -+ televisieomroep -+ televisieomroepen -+ televisieoptreden -+ televisieoptredens -+ televisiepersoonlijkheid -+ televisiepresentatoren -+ televisieproductiemaatschappij -+ televisierechten -+ televisiereclame -+ televisiereclames -+ televisiereportages -+ televisieschermen -+ televisieserie -+ televisieshow -+ televisieshows -+ televisiespelen -+ televisiespelletje -+ televisiester -+ televisiesterren -+ televisietaks -+ televisietalkshow -+ televisietalkshows -+ televisietijdperk -+ televisieverslaggeving -+ televisievraaggesprek -+ televisiezendtijd -+ telewerker -+ telewerkers -+ telewerkte -+ telexapparaat -+ telexapparaten -+ telexisten -+ telexverbinding -+ teloh -+ telraampje -+ telrijmpje -+ telrijmpjes -+ tels -+ telstroken -+ temeie -+ temeier -+ tempelachtig -+ tempelachtige -+ tempelcomplex -+ tempelcomplexen -+ tempen -+ temperatuurde -+ temperatuurgevoelig -+ temperatuurgevoelige -+ temperatuurgradiënt -+ temperatuurmetingen -+ temperatuursverandering -+ temperatuursveranderingen -+ temperatuurveranderingen -+ temperatuurwisseling -+ temperatuurwisselingen -+ template -+ templates -+ tempo's -+ tempoaanduiding -+ tempoaanduidingen -+ tempobeul -+ tempobeurs -+ tempobeurzen -+ tempomaker -+ tempora -+ temporaalkwab -+ temporale -+ temporisaties -+ temporisering -+ temporiseringen -+ tempoversnelling -+ tempoversnellingen -+ tempte -+ tenderbod -+ tenderlocomotief -+ tenderlocomotieven -+ tenenkaas -+ tenenkrommend -+ tenenkrommende -+ tenhemelschreiend -+ tenhemelschreiende -+ tenhemelstijging -+ tenietdoen -+ tenietgegaan -+ tenniscoach -+ tenniscoaches -+ tennisellebogen -+ tennishal -+ tennishallen -+ tenniskampioenschap -+ tenniskampioenschappen -+ tenniskleding -+ tennisles -+ tennisnatie -+ tennispartij -+ tennisploeg -+ tennisprof -+ tennisprofessional -+ tennisprofessionals -+ tennisprofs -+ tennisschool -+ tennistitel -+ tennistop -+ tenorsax -+ tenorsaxen -+ tenorsaxofonist -+ tenorsaxofoons -+ tenorsleutel -+ tenorsleutels -+ tentamenbriefjes -+ tentamenzaal -+ tentamenzalen -+ tentamineerde -+ tentendorp -+ tentharing -+ tentharingen -+ tentoonstellingsbezoeker -+ tentoonstellingsbezoekers -+ tentoonstellingscatalogi -+ tentoonstellingscatalogus -+ tentoonstellingscatalogussen -+ tentoonstellingsinstituut -+ tentoonstellingspaviljoen -+ tentoonstellingsruimten -+ tentoonstellingszaal -+ tentoonstellingszalen -+ tenues -+ tenuetje -+ tepelhoven -+ terechtgekund -+ terechtkunnen -+ terekruiter -+ terekruiters -+ teringherrie -+ teringzooi -+ teringzootje -+ terloopsheid -+ termijnbeurs -+ termijncontract -+ termijncontracten -+ termijnlevering -+ termijnleveringen -+ termijntransactie -+ termijntransacties -+ termineerde -+ termineren -+ terneergelegen -+ terneergevallen -+ terpeen -+ terpentijnhars -+ terra nigra -+ terra sigillata -+ terra-sigillata-aardewerk -+ terra-sigillataschaal -+ terra-sigillataschalen -+ terracotta's -+ terracottakleurig -+ terracottakleurige -+ terrasstoel -+ terrasstoelen -+ terrasstoeltje -+ terraszitter -+ terraszitters -+ terreinafbakening -+ terreinafbakeningen -+ terreinauto -+ terreinauto's -+ terreinfiets -+ terreinknechten -+ terreinmeesters -+ terreinopzichters -+ terreinrit -+ terreinritten -+ terreinverkenningen -+ terreinvoertuig -+ terreinwagen -+ terreinwagens -+ terrestrisch -+ terrestrische -+ terreuraanslag -+ terreuracties -+ terreurbestrijding -+ terreurbewind -+ terreurgroepen -+ terrinetje -+ territorialiteitsbeginsel -+ terrorismebestrijding -+ terroristenbende -+ terroristenbenden -+ terroristenbendes -+ tersluikse -+ terugbetalingstarief -+ terugbetalingstarieven -+ terugbladeren -+ terugboeking -+ terugdraaiing -+ teruggavenbiljet -+ teruggavenbiljetten -+ teruggebladerd -+ teruggegooid -+ teruggehangen -+ teruggeleid -+ teruggeluisterd -+ teruggeplooid -+ teruggerekend -+ teruggesluisd -+ teruggesnoeid -+ teruggestoken -+ teruggestroomd -+ teruggevaren -+ teruggeveerd -+ teruggevloeid -+ teruggevochten -+ teruggevuurd -+ teruggewenst -+ teruggezocht -+ teruggezonken -+ teruggooien -+ teruggroeten -+ terughangen -+ terugkeergarantie -+ terugkeerplan -+ terugkeerplannen -+ terugkeerproject -+ terugkeerprojecten -+ terugkeerregeling -+ terugkomer -+ terugkomers -+ terugleggen -+ terugleiden -+ terugluisteren -+ terugnameplicht -+ terugploegproject -+ terugploegprojecten -+ terugplooien -+ terugrekenen -+ terugritten -+ terugroeprecht -+ terugronde -+ terugronden -+ terugrondes -+ terugsnoeien -+ terugspeelballen -+ terugspeelregel -+ terugspelen -+ terugsteken -+ terugstootloos -+ terugstootloze -+ terugstorten -+ terugtrappen -+ terugtrekkingen -+ terugtrekkingsschema -+ terugtrekkingsschema's -+ terugvaren -+ terugvechten -+ terugveren -+ terugverlangd -+ terugverlangen -+ terugvertaald -+ terugverwacht -+ terugverwachten -+ terugvloeien -+ terugvoeren -+ terugvuren -+ terugwedstrijd -+ terugwedstrijden -+ terugwegen -+ terugwensen -+ terugwerpen -+ terugwinning -+ terugzendingsrecht -+ terugzendrecht -+ terugzinken -+ testbanen -+ testbatterij -+ testbeelden -+ testcase -+ testcases -+ testers -+ testes -+ testexplosie -+ testgebied -+ testgebieden -+ testgroep -+ testmatch -+ testmatchen -+ testmatches -+ testosteronspiegel -+ testpiloten -+ testresultaat -+ testuitslag -+ testuitslagen -+ testvlucht -+ testvluchten -+ tet -+ tetanusserum -+ tetra's -+ tetten -+ tevredene -+ tevredenen -+ tewerkgesteld -+ tewerkstellingsdienst -+ tewerkstellingsvergunning -+ tewerkstellingsvergunningen -+ tex-mex -+ texelaar -+ texelaars -+ textielbranche -+ textielfabrikant -+ textielkunst -+ textielonderneming -+ textielproductie -+ textielscholen -+ textielschool -+ textielveredelingsbedrijf -+ textielvezel -+ textielvezels -+ texturen -+ tezelfdertijd -+ tgv -+ tgv's -+ thaiboksen -+ theateraffiche -+ theateraffiches -+ theaterbezoeker -+ theaterbezoekers -+ theatercafé -+ theatercritici -+ theatercriticus -+ theaterdecor -+ theaterdecors -+ theaterdirectie -+ theaterdirecties -+ theatergeschiedenis -+ theatergezelschap -+ theatergezelschappen -+ theatergroepen -+ theaterkostuum -+ theaterkostuums -+ theaterleven -+ theateropleiding -+ theateropleidingen -+ theaterproducent -+ theaterproducenten -+ theaterprogrammering -+ theaterpubliek -+ theaterscholen -+ theaterschool -+ theaterspektakel -+ theatertechniek -+ theaterwetenschap -+ theeautomaat -+ theeautomaten -+ theebeschuitjes -+ theeblaadje -+ theebuiltjes -+ theeceremonie -+ theeceremonies -+ theedrinken -+ theegedronken -+ theekransjes -+ theepakker -+ theepakkers -+ theetafeltje -+ theewagen -+ theewagens -+ theewagentje -+ theeworstje -+ theeworstjes -+ thema-avond -+ thema-avonden -+ themabijeenkomst -+ themabijeenkomsten -+ themagedeelte -+ themaonderwijs -+ themapark -+ themaparken -+ thematieken -+ thematiseerde -+ themavocaal -+ themavocalen -+ theologe -+ theologes -+ theorema's -+ theorie-examen -+ theoriegedeelte -+ theorietje -+ therapeute -+ therapeutes -+ therapieresistent -+ therapieresistente -+ therapietrouw -+ therapievorm -+ therapievormen -+ thermo-elektrische -+ thermobarometer -+ thermobarometers -+ thermodiffusie -+ thermodynamische -+ thermofiele -+ thermoharder -+ thermoharders -+ thermokoppel -+ thermokoppels -+ thermonucleair -+ thermonucleaire -+ thermoplasten -+ thermossen -+ thesauri -+ thesaurier-generaal -+ thesauriers-generaal -+ thesisjaar -+ thinners -+ thiofeen -+ thiofenen -+ thomaschristenen -+ thrillerachtig -+ thrillerachtige -+ thrillerschrijver -+ thuisbankieren -+ thuisbasissen -+ thuisblijfmoeder -+ thuisblijfmoeders -+ thuisclubs -+ thuisfluiter -+ thuisfluiters -+ thuisgebleven -+ thuisgehaald -+ thuisgehouden -+ thuisgewerkt -+ thuisgezeten -+ thuishalen -+ thuislandensysteem -+ thuislevering -+ thuismarkten -+ thuismatch -+ thuismatchen -+ thuismatches -+ thuisnaaister -+ thuisnederlaag -+ thuisoverwinning -+ thuisplaat -+ thuisploeg -+ thuisspelend -+ thuisspelende -+ thuistaal -+ thuisvluchten -+ thuiszege -+ tiara's -+ tiaraatje -+ ticketprijs -+ ticketprijzen -+ tiebreaks -+ tiende-eeuws -+ tiende-eeuwse -+ tienerjaren -+ tienerkamer -+ tienermoeder -+ tienermoeders -+ tienertoerkaarten -+ tienerzwangerschap -+ tienerzwangerschappen -+ tienjarenprogramma -+ tienkamper -+ tienkoppig -+ tienkoppige -+ tienpuntenplan -+ tiens -+ tientjesleden -+ tientjeslid -+ tientonners -+ tienuurjournaal -+ tienvingersysteem -+ tiercés -+ tijdbeelden -+ tijdbestedingen -+ tijdcontrole -+ tijdeloosheid -+ tijdenlang -+ tijdgenotes -+ tijdgerekt -+ tijdgrenzen -+ tijdklokken -+ tijdkrediet -+ tijdlimieten -+ tijdloost -+ tijdlozer -+ tijdmachines -+ tijdmechanisme -+ tijdmeldingen -+ tijdmetingen -+ tijdopnames -+ tijdrijden -+ tijdrijders -+ tijdritspecialist -+ tijdritten -+ tijdsaanduidingen -+ tijdsafstand -+ tijdsafstanden -+ tijdsbeelden -+ tijdsbestedingen -+ tijdschaal -+ tijdschakelaar -+ tijdschakelklokken -+ tijdschalen -+ tijdschriftengroep -+ tijdschriftenuitgever -+ tijdschriftenuitgevers -+ tijdschriftenwinkel -+ tijdschriftenwinkels -+ tijdschriftredactie -+ tijdschriftuitgever -+ tijdschriftuitgevers -+ tijdseenheden -+ tijdsgrenzen -+ tijdsindelingen -+ tijdslimieten -+ tijdsloten -+ tijdsoverschrijding -+ tijdspasseringen -+ tijdspiegel -+ tijdspiegels -+ tijdsschaal -+ tijdsschalen -+ tijdsschema's -+ tijdsverlies -+ tijdsverschijnselen -+ tijdsverspilling -+ tijdverslindend -+ tijdverslindende -+ tijdwaarneming -+ tijgerbalsem -+ tijgerbroden -+ tijgerde -+ tijgeren -+ tijgerhaai -+ tijgerhaaien -+ tijgerkooi -+ tijgerkooien -+ tijgerleliën -+ tijgersluipgang -+ tijgersprong -+ tijmblaadje -+ tijmblaadjes -+ tikmachientje -+ tikmachine -+ tikmachines -+ tikmachinetje -+ tikwerk -+ tilbury's -+ tilbury'tje -+ tilwerk -+ timbaal -+ timbalen -+ time-outs -+ timede -+ timemanagement -+ timers -+ timet -+ timmermannen -+ timmermansogen -+ timmermanspotloden -+ timmermanspotlood -+ timmermanszoon -+ timmerwerkplaats -+ tinfolie -+ tipi -+ tipi's -+ tipparade -+ tippelprostitutie -+ tippelzone -+ tippelzones -+ tiptoetsen -+ tiramisu -+ tiramisu'tje -+ tirette -+ tirettes -+ titaantje -+ titanengevecht -+ titelapparaat -+ titelapparaten -+ titelaspiraties -+ titelcatalogi -+ titelcatalogussen -+ titeldebat -+ titelgedicht -+ titelgevechten -+ titelheld -+ titellied -+ titelloos -+ titelloze -+ titelnummer -+ titelnummers -+ titelrolvertolker -+ titelsong -+ titelsongs -+ titeltoernooi -+ titeltoernooien -+ titelverdedigers -+ titelverhaal -+ titelverhalen -+ titelwedstrijden -+ titelwoord -+ titelwoorden -+ titi -+ titi's -+ titiaap -+ titiapen -+ tjabé -+ tjabés -+ tjap -+ tjappen -+ tjapte -+ tjauwmin -+ tjiftjafs -+ tjitjaks -+ tl-armaturen -+ tl-armatuur -+ tl-buizen -+ tl-licht -+ tl-lichten -+ toasters -+ tobbedansen -+ toccata's -+ tochtgenotes -+ tochthond -+ tochthonden -+ toe-eigeningen -+ toebrullen -+ toebuigen -+ toeclips -+ toedieningen -+ toedieningsvorm -+ toedieningsvormen -+ toegangscodes -+ toegangsgeld -+ toegangspas -+ toegangsprijzen -+ toegangstijd -+ toegebogen -+ toegebruld -+ toegekund -+ toegespeeld -+ toegespitster -+ toegestormd -+ toegewaaid -+ toegewenkt -+ toekenningscommissie -+ toekenningscommissies -+ toekomstmogelijkheid -+ toekomststaat -+ toekomstverkenningen -+ toekomstvisies -+ toekomstvisioen -+ toekomstvisioenen -+ toekomstwaarde -+ toekunnen -+ toelages -+ toelatingscriteria -+ toelatingscriterium -+ toelatingsprocedures -+ toelatingsregeling -+ toelatingsstop -+ toeleveraar -+ toeleveraars -+ toeleverancier -+ toeleveringsindustrie -+ toenaderingspolitiek -+ toenaderingsproces -+ toendra's -+ toepassingsgericht -+ toepassingsgerichte -+ toepassingsgerichtheid -+ toepassingsmogelijkheid -+ toepen -+ toepte -+ toerauto's -+ toerbeurtsysteem -+ toercaravans -+ toerfietsen -+ toerismebranche -+ toerismebureau -+ toerismebureaus -+ toeristenbelasting -+ toeristenbureau -+ toeristenbureaus -+ toeristenbus -+ toeristenbussen -+ toeristenhotel -+ toeristenhotels -+ toeristenmenu's -+ toeristenoord -+ toeristenoorden -+ toeristenseizoen -+ toeristenseizoenen -+ toeristenstroom -+ toeristenvisa -+ toeristenvisum -+ toeristisch-recreatief -+ toeristisch-recreatieve -+ toernooiarts -+ toernooiboek -+ toernooiencircuit -+ toernooiopzet -+ toernooiorganisatie -+ toernooioverwinning -+ toernooioverwinningen -+ toernooispeler -+ toernooiwinst -+ toernooizege -+ toernooizeges -+ toerrijder -+ toerrijders -+ toervaartnet -+ toerwagen -+ toerwagens -+ toeschouwersaantal -+ toeschouwersaantallen -+ toeschouwerscapaciteit -+ toeschrijving -+ toeschrijvingen -+ toeslagregeling -+ toesnijden -+ toestelfinale -+ toestelfinales -+ toesteloefeningen -+ toestemmingsvereiste -+ toestormen -+ toeterzat -+ toeterzatte -+ toetoep -+ toetredingscriteria -+ toetredingseis -+ toetredingseisen -+ toetredingsonderhandelingen -+ toetredingsverdrag -+ toetredingsvoorwaarde -+ toetredingsvoorwaarden -+ toetseninstrument -+ toetseninstrumenten -+ toetsenist -+ toetsenisten -+ toetsenman -+ toetsenspeler -+ toetsingsconferentie -+ toetsingskader -+ toetsingssysteem -+ toevalsfactor -+ toevalsfactoren -+ toevalstreffers -+ toevoerleidingen -+ toewaaien -+ toewenken -+ toewijsbaar -+ toewijsbare -+ toezichter -+ toezichters -+ toezichtkamer -+ tofoe -+ togati -+ togatus -+ toges -+ toiletblok -+ toiletblokken -+ toiletbril -+ toiletgarnituren -+ toiletpot -+ toiletpotten -+ toilettassen -+ tok -+ tokken -+ toko's -+ tokte -+ toldienst -+ tolerantiedrempel -+ tolerantiegraad -+ tolheffing -+ tolheffingen -+ tolk-vertaler -+ tolken-vertalers -+ tolkte -+ tolstation -+ tolstojaan -+ tolstojaans -+ tolstojaanse -+ tolstojanen -+ tolweg -+ tolwegen -+ tomatensalade -+ tomatensappen -+ tomatensardine -+ tomatensardines -+ tomatenteelt -+ tombola's -+ tomboy -+ tomboys -+ tommy's -+ tomtom -+ toneelavond -+ toneelavonden -+ toneelbewerkingen -+ toneelclub -+ toneelclubs -+ toneeldecor -+ toneeldecors -+ toneelervaring -+ toneelfiguur -+ toneelgeschiedenis -+ toneelgespeeld -+ toneelgroepen -+ toneelhuis -+ toneelknechten -+ toneelknechts -+ toneelkostuum -+ toneelkostuums -+ toneelkritieken -+ toneelleider -+ toneellicht -+ toneelliefhebbers -+ toneelliteratuur -+ toneelloopbaan -+ toneelmaker -+ toneelmakers -+ toneelmuseum -+ toneelmuziek -+ toneeloeuvre -+ toneelopleiding -+ toneelpraktijk -+ toneelprijs -+ toneelprijzen -+ toneelrecensent -+ toneelrecensenten -+ toneelregie -+ toneelregisseurs -+ toneelrepetitie -+ toneelrepetities -+ toneelrol -+ toneelruimte -+ toneelschoolleerling -+ toneelschoolleerlingen -+ toneelschrijfkunst -+ toneelscène -+ toneelscènes -+ toneelseizoenen -+ toneelspelersgezelschap -+ toneeltaal -+ toneeltoren -+ toneeltraditie -+ toneeluitvoeringen -+ toneelwerk -+ tongbreker -+ tongbrekers -+ tongde -+ tongfilet -+ tongfilets -+ tongkussen -+ tongstrelend -+ tongstrelende -+ tongue in cheek -+ tonics -+ tonijnvangst -+ tonijnvisser -+ tonijnvisserij -+ tonijnvissers -+ tooghanger -+ tooghangers -+ toogpraat -+ tool -+ tools -+ toonbanklening -+ toonbanksysteem -+ toonbankuitgifte -+ toonderpapieren -+ toonduur -+ toongaatje -+ toongat -+ toongaten -+ toongeneratoren -+ toongenerators -+ toongeving -+ toonhoogteverschil -+ toonhoogteverschillen -+ toonkunstenaarsbond -+ toonomvang -+ toonsleutel -+ toonsleutels -+ toonstelsel -+ toonstelsels -+ toonsysteem -+ toontaal -+ toontalen -+ toonval -+ toonvorming -+ toosters -+ top-down -+ top-downbenadering -+ topadviseur -+ topadviseurs -+ topambtenaars -+ topatlete -+ topatletes -+ topattractie -+ topberaad -+ topbijeenkomst -+ topbridge -+ topclub -+ topclubs -+ topcompetitie -+ topcricket -+ topdag -+ topdagen -+ topduel -+ topduels -+ topevenement -+ topfavoriet -+ topfavorieten -+ topfiguren -+ topfiguur -+ topfit -+ topfitte -+ topfunctie -+ topfuncties -+ topfunctionaris -+ topfunctionarissen -+ topgeheim -+ topgeheimen -+ topgesprek -+ tophockey -+ topics -+ topinkomen -+ topinkomens -+ topjaren -+ topjes -+ topjudo -+ topmodel -+ topmodellen -+ topoi -+ topontmoetingen -+ topping -+ toppings -+ topposities -+ topprioriteiten -+ toprestaurant -+ toprestaurants -+ topschutter -+ topscoorder -+ topscorerslijst -+ topse -+ topspeelster -+ topspeelsters -+ topspeler -+ topspelers -+ topsporter -+ topsporters -+ topsportliga -+ topstuk -+ toptennis -+ toptienspeler -+ toptienspelers -+ toptijd -+ toptijden -+ toptijdschrift -+ topuniversiteit -+ topuniversiteiten -+ topverkoper -+ topvoetbal -+ topvoetballer -+ topvoetballers -+ topvolleybal -+ topwedstrijd -+ topwedstrijden -+ topweek -+ tordeerde -+ torengebouw -+ torengebouwen -+ torenkamer -+ torenkamers -+ torenoffer -+ torenoffers -+ torentjesoverleg -+ tori -+ tori's -+ torinstinct -+ tornado's -+ torpedering -+ torpedo's -+ torpedobootjagers -+ torpedovormig -+ torpedovormige -+ torsiestijfheid -+ torso's -+ tortelde -+ tortelen -+ tortilla's -+ tortillachips -+ tosses -+ tosti's -+ tosti-ijzer -+ tosti-ijzers -+ tostiapparaten -+ totaalakkoord -+ totaalgewicht -+ totaalindruk -+ totaalkolommen -+ totaaloplossing -+ totaalpakketten -+ totaalprogramma's -+ totaalscore -+ totaaltheater -+ totaalweigeraars -+ totallossverklaring -+ totallossverklaringen -+ totemistische -+ toto's -+ touchpad -+ touchpads -+ touchscreen -+ touchscreens -+ toupeerde -+ toupetje -+ tourdirectie -+ touretappe -+ touringcarbedrijf -+ tourkaravaan -+ tournedostje -+ tourniquetdeur -+ tourniquetdeuren -+ touroperator -+ touroverwinning -+ tourradio -+ tours -+ tourwinnaar -+ touwklimmen -+ touwtrekker -+ touwtrekkerijen -+ touwtrekkers -+ tovenaarsleerling -+ tovenaarsleerlingen -+ toverballen -+ toverfee -+ toverfeeën -+ toverkijker -+ toverkijkers -+ toxicologen -+ toxicologische -+ toxinegehalte -+ toxinegehalten -+ toxinegehaltes -+ tra's -+ traangasgranaat -+ traangasgranaten -+ traankanaal -+ traankanalen -+ traanvocht -+ traanzak -+ traanzakken -+ traceetje -+ tracering -+ trachea's -+ tracheale -+ tracks -+ tractorbestuurder -+ tractorbestuurders -+ tracékeuze -+ trad herin -+ traditiegetrouw -+ traditiegetrouwe -+ traditierijk -+ traditierijke -+ traditionalistische -+ traditionals -+ tragischt -+ tragédiennes -+ train à grande vitesse -+ trainees -+ trainer-coach -+ trainer-speler -+ trainerscarrière -+ trainerschap -+ trainerscursus -+ trainerscursussen -+ trainersdiploma -+ trainersdiploma's -+ trainersopleiding -+ trainerswissel -+ training on the job -+ trainingsachterstand -+ trainingsbroek -+ trainingsbroeken -+ trainingscentra -+ trainingscursus -+ trainingscursussen -+ trainingsfaciliteiten -+ trainingsgroep -+ trainingsgroepen -+ trainingsijver -+ trainingsjack -+ trainingsjacks -+ trainingskamp -+ trainingskampen -+ trainingsmethode -+ trainingsmethoden -+ trainingsmethodes -+ trainingsopbouw -+ trainingsschema -+ trainingsschema's -+ trainingsstage -+ trainingsstages -+ trajectbegeleiding -+ trajectplan -+ tralala -+ traliehek -+ traliehekken -+ trammaatschappij -+ trampolines -+ tramremise -+ tramstel -+ tramstellen -+ tramwegmaatschappij -+ tramwegwezen -+ tranceachtig -+ tranceachtige -+ tranentrekker -+ tranentrekkers -+ trans-Alpijns -+ trans-Alpijnse -+ trans-Atlantisch -+ trans-Atlantische -+ trans-Europees -+ trans-Europese -+ transactiewinst -+ transactiewinsten -+ transcribeerde -+ transcultureel -+ transculturele -+ transfer-RNA -+ transferbureaus -+ transferia -+ transfermarkt -+ transferpunt -+ transferpunten -+ transfersommen -+ transfersysteem -+ transfervrij -+ transfervrije -+ transferwaarde -+ transfigureerde -+ transfigureren -+ transformatieproces -+ transformationeel-generatief -+ transformationeel-generatieve -+ transgene -+ transistorradiootje -+ transithal -+ transitland -+ transitohavens -+ transitoria -+ transitoriums -+ transitruimte -+ transitverkeer -+ transitvisa -+ transitvisum -+ translitteratie -+ transmigranten -+ transmissieapparatuur -+ transmissiekosten -+ transmissiesysteem -+ transnationale -+ transoceanische -+ transparantje -+ transparantjes -+ transpiratiegeuren -+ transplantaten -+ transplantatiecentra -+ transplantatiecentrum -+ transplantatiedoeleinden -+ transplantatiegeneeskunde -+ transplanteerde -+ transponder -+ transponders -+ transportactiviteiten -+ transportbanen -+ transporteenheden -+ transporteenheid -+ transporteiwit -+ transporteiwitten -+ transportfirma -+ transportfirma's -+ transporthelikopter -+ transporthelikopters -+ transportindustrie -+ transportkist -+ transportkisten -+ transportmiddelenindustrie -+ transportnetwerk -+ transportondernemer -+ transportondernemers -+ transportprobleem -+ transportproblemen -+ transporttoestellen -+ transporttroepen -+ transportwezen -+ transseksuele -+ transseksuelen -+ trapauto's -+ trapbeweging -+ trapezeartiest -+ trapezewerker -+ trapezewerkers -+ trapkast -+ trapkasten -+ trapkruk -+ trapkrukken -+ trapleren -+ traplift -+ traplopen -+ trappelzakken -+ trappenlopen -+ trappetje -+ trappistenklooster -+ trapsgewijze -+ traptechniek -+ traptrees -+ traptreeën -+ trapveldje -+ trapveldjes -+ trapzaal -+ trapzalen -+ trashmetal -+ trauma-arts -+ trauma-artsen -+ traumacentra -+ traumacentrum -+ traumahelikopter -+ traumahelikopters -+ traumateam -+ traumateams -+ traumatisering -+ traumatologen -+ traumatologische -+ traveeën -+ travestierol -+ trawlnet -+ trawlnetten -+ tray -+ trays -+ traytje -+ trechterbeker -+ trechterbekercultuur -+ trechterbekers -+ trechtermond -+ trechtermonden -+ trechterwerking -+ trefbal -+ trefcentra -+ trefwoordencatalogi -+ trefwoordencatalogus -+ trefwoordencatalogussen -+ trefwoordenregisters -+ treife -+ trein-tram-busdag -+ trein-tram-busdagen -+ treinabonnement -+ treincoupé -+ treincoupés -+ treinde -+ treinenhal -+ treinenhallen -+ treinkapingen -+ treinmachinist -+ treinmachinisten -+ treinmaterieel -+ treinongelukken -+ treinongeval -+ treinpassagier -+ treinpassagiers -+ treinrail -+ treinrails -+ treinrampen -+ treinretour -+ treinrit -+ treinroof -+ treinstations -+ treinsurf -+ treinsurfen -+ treinsurft -+ treinsurfte -+ treinverbinding -+ treinwachter -+ treinwachters -+ treiterig -+ treiterige -+ trekbel -+ trekbellen -+ trekhaken -+ trekkingsdata -+ trekkingsdatum -+ trekkingsdatums -+ trekkingsrecht -+ trekkingsrechten -+ trekkoffie -+ trekpop -+ trekrichting -+ trekschakelaars -+ trekstoot -+ trekstoten -+ trekveren -+ trekwerk -+ trekzalf -+ tremolo's -+ trenchcoats -+ trendanalyse -+ trendbreuk -+ trendbreuken -+ trendgevoelige -+ trendsettende -+ trendwatcher -+ trendwatchers -+ trepanaties -+ trepanen -+ treurbuis -+ treurdichter -+ treurdichters -+ treurigmakend -+ treurigmakende -+ treurigstemmend -+ treurigstemmende -+ treurniet -+ treurnieten -+ trial-and-error -+ trial-and-errormethode -+ trials -+ triangulaire -+ trias -+ triatleten -+ triatlons -+ tribale -+ tribuneklant -+ tribuneklanten -+ tribuneplaats -+ tricotages -+ tricotje -+ triestigheid -+ trilaterale -+ triljarden -+ trillerige -+ trillertje -+ trilobiet -+ trilobieten -+ trilvrije -+ trimarans -+ trimbaan -+ trimbanen -+ trimestrieel -+ trimestriële -+ trimloop -+ trimlopen -+ trimschoen -+ trimtoestel -+ trimtoestellen -+ trio's -+ triobezetting -+ triomfale -+ triomfalistische -+ triomfantelijkheid -+ triomfkreten -+ triomfmars -+ triomfpoorten -+ tripartisering -+ tripartiteoverleg -+ tripartites -+ tripels -+ tripletten -+ tripmadam -+ trippelpas -+ trissen -+ triste -+ triviaalliteratuur -+ trivialiseerde -+ trivialisering -+ troefboer -+ troefheer -+ troefkleur -+ troefslag -+ troefslagen -+ troefvrouw -+ troel -+ troelen -+ troepenbeweging -+ troepenbewegingen -+ troepenconcentraties -+ troepencontingent -+ troepencontingenten -+ troepeneenheden -+ troepenschouw -+ troepensterkte -+ troepenverplaatsing -+ troepenverplaatsingen -+ troepiaal -+ troepialen -+ trofeetje -+ trogvormig -+ trogvormige -+ trol -+ trollen -+ trommelvliesontsteking -+ trompetnarcis -+ trompetnarcissen -+ trompetsolo -+ trompettisten -+ troonpretendent -+ troonpretendenten -+ troonswisselingen -+ troostfinale -+ troosting -+ troostvol -+ troostvolle -+ tropenarts -+ tropengordel -+ tropennacht -+ tropenpak -+ tropenpakken -+ tropenroosters -+ tropenwoud -+ trotskisme -+ trotskisten -+ trottinette -+ trottinettes -+ trottoirrand -+ trottoirranden -+ troubleshooters -+ trouwbijbel -+ trouwbijbels -+ trouwboek -+ trouwboeken -+ trouwboeket -+ trouwboeketten -+ trouwjurken -+ trouwkaart -+ trouwkaarten -+ trouwregister -+ trouwregisters -+ trouwstoet -+ trouwstoeten -+ trucages -+ trucfoto's -+ truckchauffeur -+ trucopname -+ trucopnamen -+ trucopnames -+ truggelde af -+ trukeerde -+ trustcompagnie -+ trustkantoor -+ trustkantoren -+ trutten -+ truttigheid -+ try-outs -+ try-outvoorstelling -+ try-outvoorstellingen -+ tsarenfamilie -+ tsarenrijk -+ tsarentijd -+ tsarevitsje -+ tsarina's -+ tsuba -+ tsuba's -+ tsunami -+ tsunami's -+ tuba's -+ tubelijm -+ tuberculosebestrijding -+ tubifex -+ tuchtcommissie -+ tuchtcommissies -+ tuchtprefect -+ tuchtprefecten -+ tuchtraden -+ tuchtrechtelijk -+ tuchtrechtelijke -+ tuchtrechters -+ tuchtschoolstraf -+ tuchtwet -+ tuchtwetten -+ tuchtzaken -+ tuftuf -+ tuftufs -+ tuimelblad -+ tuimelbladen -+ tuinafval -+ tuinbed -+ tuinboek -+ tuinboeken -+ tuinbouwbedrijf -+ tuinbouwer -+ tuinbouwers -+ tuinbouwgebied -+ tuinbouwgebieden -+ tuinbouwgewas -+ tuinbouwgewassen -+ tuinbouwgrond -+ tuinbouwkunde -+ tuinbouwproduct -+ tuinbouwproducten -+ tuinbouwveilingen -+ tuinbroek -+ tuinbroeken -+ tuinhekken -+ tuinkaboutertje -+ tuinkruid -+ tuinmannen -+ tuinmeubel -+ tuinmuren -+ tuinmuur -+ tuinonderhoud -+ tuinontwerp -+ tuinontwerpen -+ tuinontwerper -+ tuinontwerpers -+ tuinplanten -+ tuinpoort -+ tuinpoorten -+ tuinstoeltje -+ tukkers -+ tulpenfestival -+ tulpenveld -+ tulpenvelden -+ tulpglaasje -+ tulpglas -+ tulpglazen -+ tulpvormig -+ tulpvormige -+ tumorcel -+ tumorcellen -+ tuner-versterker -+ tuner-versterkers -+ tuners -+ tunes -+ tunetje -+ tunica's -+ tuniekpak -+ tuniekpakken -+ tunnelaanleg -+ tunnelbuis -+ tunnelbuizen -+ tunnelelement -+ tunnelelementen -+ tunnelsegment -+ tunnelsegmenten -+ tunnelvisie -+ turbocompressoren -+ turbocompressors -+ turbodiesel -+ turbodiesels -+ turbojets -+ turboprop -+ turboprops -+ turboproptoestel -+ turboproptoestellen -+ turbopropvliegtuig -+ turbopropvliegtuigen -+ turbotaal -+ turbulenties -+ turfsteken -+ turkenbak -+ turkenbakken -+ turkenvriend -+ turkologen -+ turkologie -+ turkoloog -+ turn-over -+ turn-overs -+ turncoach -+ turncoaches -+ turninternaat -+ turnsloef -+ turnsloefen -+ turntoernooi -+ turnzaal -+ turnzalen -+ turtleneck -+ turtlenecks -+ tussen-s -+ tussen-s'en -+ tussenberm -+ tussenbermen -+ tussenbestuur -+ tussencategorie -+ tussendeel -+ tussengebieden -+ tussengekomen -+ tussengezang -+ tussengezangen -+ tussenhersenen -+ tussenhuis -+ tussenhuizen -+ tussenkamer -+ tussenklassement -+ tussenkomen -+ tussenmenselijk -+ tussenmenselijke -+ tussenposities -+ tussenrapport -+ tussenrapporten -+ tussensprint -+ tussensprints -+ tussenstadia -+ tussenstadium -+ tussentint -+ tussentinten -+ tussenwervelschijf -+ tussenwervelschijven -+ tussenwoning -+ tussenwoningen -+ tussenzinnetje -+ tuten -+ tutte -+ tuttebellen -+ tutten -+ tutter -+ tutters -+ tuttigheid -+ tuttipassage -+ tuttipassages -+ tuttut -+ tutu's -+ tutuutje -+ tuut -+ tv'loos -+ tv'loze -+ tv-camera -+ tv-camera's -+ tv-commercial -+ tv-commercials -+ tv-debat -+ tv-debatten -+ tv-gekeken -+ tv-interview -+ tv-interviews -+ tv-journaal -+ tv-journaals -+ tv-journalen -+ tv-kanaal -+ tv-kanalen -+ tv-kijker -+ tv-kijkers -+ tv-optreden -+ tv-programma's -+ tv-reclame -+ tv-reclames -+ tv-scherm -+ tv-schermen -+ tv-show -+ tv-toestel -+ tv-toestellen -+ tv-zender -+ tv-zenders -+ tw. -+ twaalfdaags -+ twaalfdaagse -+ twaalfde-eeuws -+ twaalfde-eeuwse -+ twaalfdelig -+ twaalfdelige -+ twaalfeneenhalfjarig -+ twaalfkoppig -+ twaalfkoppige -+ twaalfmaal -+ twaalfmaandsperiode -+ twaalfmijlsgrens -+ twaalfmijlsgrenzen -+ twaalfmijlszone -+ twaalfmijlszones -+ twaalftoonsmuziek -+ twaalftoonstechniek -+ twaalfvoud -+ twaalfvouden -+ twaalfvoudig -+ twaalfvoudige -+ twatwa -+ twatwa's -+ twee-eiig -+ twee-eiige -+ twee-eurostuk -+ twee-eurostukken -+ twee-onder-een-kapwoning -+ twee-onder-een-kapwoningen -+ tweebaansweg -+ tweebaanswegen -+ tweecilinder -+ tweecilinders -+ tweededivisieclub -+ tweedegeneratieallochtonen -+ tweedegeneratieallochtoon -+ tweedegraads -+ tweedehandsje -+ tweedehandsjes -+ tweedehandskleding -+ tweedekansonderwijs -+ tweedeklas -+ tweedeklascoupé -+ tweedeklascoupés -+ tweedekwartaalcijfers -+ tweedelijns -+ tweedelingen -+ tweederangsburger -+ tweederangsburgers -+ tweederdemeerderheid -+ tweedeursautootje -+ tweedjas -+ tweedranken -+ tweefasestructuren -+ tweeheid -+ tweejaarlijks -+ tweejaarlijkse -+ tweekamerflat -+ tweekamerparlement -+ tweekamerwoning -+ tweekamerwoningen -+ tweekleppig -+ tweekleppige -+ tweekwartsmaat -+ tweekwartsmaten -+ tweelingstad -+ tweelingzus -+ tweelingzussen -+ tweemansbob -+ tweemanschap -+ tweemansfractie -+ tweepartijensysteem -+ tweepersoonsbedden -+ tweepersoonskamer -+ tweepersoonskamers -+ tweepitter -+ tweepitters -+ tweeploegendienst -+ tweepoot -+ tweepoten -+ tweerelatie -+ tweerelaties -+ tweeslag -+ tweesporenbeleid -+ tweesporig -+ tweesporige -+ tweestemmigheid -+ tweetakt -+ tweeters -+ tweetonig -+ tweetrapsraketten -+ tweevoeter -+ tweevoeters -+ tweeweeks -+ tweeweekse -+ tweewielerbedrijf -+ tweewielerbedrijven -+ tweezaadlobbigen -+ tweezits -+ tweezitter -+ tweeëndertigjarig -+ tweeëndertigjarige -+ tweeëntwintigjarig -+ tweeëntwintigjarige -+ twens -+ twijfelkont -+ twinsets -+ twintigkoppig -+ twintigkoppige -+ twintigste-eeuwer -+ twintigste-eeuws -+ twintigste-eeuwse -+ twintigvoud -+ twintigvouden -+ twintigvoudige -+ twk -+ twoseater -+ twoseaters -+ twoseatertje -+ twostep -+ tycoons -+ type-eenonderwijs -+ typeaanduiding -+ typecast -+ typecasten -+ typecastte -+ typediploma's -+ typekamers -+ typemachientje -+ typemachinetje -+ typescript -+ typetweeonderwijs -+ typevaardigheden -+ typoscripten -+ tyrannosaurus -+ tyrannosaurussen -+ tzatziki -+ u's -+ u'tje -+ ub -+ ub's -+ ud -+ ud's -+ ufo -+ ufo's -+ ufootje -+ ugli's -+ uhd -+ uhd's -+ uienmengsel -+ uienplanten -+ uiensnijder -+ uiensnijders -+ uierontsteking -+ uierzalf -+ uilenballen -+ uilskuikentje -+ uisnipper -+ uisnippers -+ uit kostenoogpunt -+ uit milieuoogpunt -+ uit-en-te-na -+ uit-en-ter-na -+ uitbal -+ uitballen -+ uitbaters -+ uitbatingsvergunning -+ uitbatingsvergunningen -+ uitbehandeld -+ uitbehandelde -+ uitblutsen -+ uitbollen -+ uitbraakpoging -+ uitbraakpogingen -+ uitbreidingsmogelijkheden -+ uitbreidingsmogelijkheid -+ uitbreidingswerkzaamheden -+ uitbreidingswijk -+ uitbreidingswijken -+ uitbreker -+ uitbrekers -+ uitbuiken -+ uitdagerslijst -+ uitdiepingen -+ uitdrogingsverschijnsel -+ uitdrogingsverschijnselen -+ uitdrukkingloos -+ uitdrukkingloze -+ uitdrukkingsmogelijkheid -+ uitdrukkingsvaardigheden -+ uitdrukkingsvormen -+ uiteengegroeid -+ uiteengelegd -+ uiteengroeien -+ uiteenleggen -+ uiteenrukken -+ uiteindes -+ uitfloepen -+ uitgaansbuurt -+ uitgaanscentra -+ uitgaansgelegenheden -+ uitgaanskleding -+ uitgaansleven -+ uitgaansverbod -+ uitgangsbuurt -+ uitgangsbuurten -+ uitgangsmateriaal -+ uitgangssituatie -+ uitgangssituaties -+ uitgangsverbod -+ uitgangsvermogen -+ uitgavenbeperking -+ uitgavenoverschrijding -+ uitgavenpatroon -+ uitgavenquote -+ uitgavenvermindering -+ uitgeblutst -+ uitgebold -+ uitgebuikt -+ uitgedokterd -+ uitgeefactiviteiten -+ uitgeefbeleid -+ uitgefaded -+ uitgefloept -+ uitgeglipt -+ uitgehoest -+ uitgejoeld -+ uitgejubeld -+ uitgekakt -+ uitgeklapt -+ uitgeklonken -+ uitgekookter -+ uitgekooktst -+ uitgekregen -+ uitgelepeld -+ uitgeluisterd -+ uitgeplaatst -+ uitgepoept -+ uitgeprocedeerd -+ uitgepuurd -+ uitgerend -+ uitgerezen -+ uitgeruild -+ uitgeselecteerd -+ uitgeslepen -+ uitgespit -+ uitgetikt -+ uitgevangen -+ uitgeverijtje -+ uitgeversfirma's -+ uitgeversfondsen -+ uitgeversimperium -+ uitgeverssector -+ uitgeverswereld -+ uitgevlagd -+ uitgevloerd -+ uitgevloerde -+ uitgevoegd -+ uitgewandeld -+ uitgewuifd -+ uitgiftekoers -+ uitgiftes -+ uitglijder -+ uitglijders -+ uitglijer -+ uitglijers -+ uitglijertje -+ uitglippen -+ uitgroeibaan -+ uitgroeibanen -+ uithoesten -+ uithof -+ uithoudingsproef -+ uithoven -+ uithuisplaatsingen -+ uitingsvormen -+ uitingsvrijheid -+ uitjoelen -+ uitjubelen -+ uitkakken -+ uitkeringsaanvraag -+ uitkeringsaanvragen -+ uitkeringsgeld -+ uitkeringsgelden -+ uitkeringsgerechtigd -+ uitkeringsperiode -+ uitkeringsregeling -+ uitkeringsstelsel -+ uitkeringstrekkers -+ uitkeringswet -+ uitklappen -+ uitklinken -+ uitkomstprobleem -+ uitkoopregeling -+ uitkoopsom -+ uitlaatcenter -+ uitlaatcenters -+ uitlandig -+ uitlandige -+ uitlandigheid -+ uitleenbalies -+ uitleendiscotheek -+ uitleendiscotheken -+ uitleggerig -+ uitleggerige -+ uitlener -+ uitleners -+ uitleveringsprocedures -+ uitleveringsverzoeken -+ uitloopmogelijkheden -+ uitloopstroken -+ uitluisteren -+ uitnodigingsbeleid -+ uitnodigingskaart -+ uitoefenprijs -+ uitoefenprijzen -+ uitplaatsen -+ uitplaatsing -+ uitpoepen -+ uitpuren -+ uitputtingsslagen -+ uitputtingsverschijnsel -+ uitputtingsverschijnselen -+ uitreispapieren -+ uitreisverbod -+ uitreisvisums -+ uitrijverbod -+ uitrijzen -+ uitruil -+ uitruilen -+ uitrukdienst -+ uitscheidingsorganen -+ uitscheidingsproduct -+ uitscheidingsproducten -+ uitschuifbare -+ uitschuiver -+ uitschuivers -+ uitselecteren -+ uitslagenlijst -+ uitslagenlijsten -+ uitsloverij -+ uitslovers -+ uitsluitingsmechanisme -+ uitsluitingsmechanismen -+ uitsnede -+ uitspitten -+ uitspraakregel -+ uitspringers -+ uitstapclausule -+ uitstapclausules -+ uitstapregeling -+ uitsterving -+ uitstervingen -+ uitstralingseffecten -+ uitstroombeleid -+ uitstroomopening -+ uittrede -+ uittredingsrecht -+ uitvaartcentra -+ uitvaartcentrum -+ uitvaartleider -+ uitvaartleiders -+ uitvaartonderneming -+ uitvaartondernemingen -+ uitvaartplechtigheden -+ uitvaartstoeten -+ uitvaartvereniging -+ uitvaartverzorger -+ uitvalbases -+ uitvalbasis -+ uitvalpercentage -+ uitvalsbases -+ uitvalspercentage -+ uitvalsweg -+ uitvalswegen -+ uitvangen -+ uitverkiezen -+ uitvindersbeurs -+ uitvlaggen -+ uitvlagoperatie -+ uitvlagoperaties -+ uitvliegroute -+ uitvliegroutes -+ uitvoegen -+ uitvoegstroken -+ uitvoerdocument -+ uitvoerdocumenten -+ uitvoeringskosten -+ uitvoeringsovereenkomst -+ uitvoeringspraktijk -+ uitvoeringsstructuur -+ uitvoeringstechnisch -+ uitvoeringswijze -+ uitvoeroverschotten -+ uitvoerproducten -+ uitvoerwaarde -+ uitwaaiering -+ uitwandelen -+ uitwijkhavens -+ uitwijkmanoeuvre -+ uitwijkmanoeuvres -+ uitwijkplaats -+ uitwijzingsbesluit -+ uitwijzingsbevelen -+ uitwijzingspolitiek -+ uitwijzingsprocedure -+ uitwijzingsprocedures -+ uitwisbaar -+ uitwisbare -+ uitwisselingsproces -+ uitwisselingsproject -+ uitworpen -+ uitwuiven -+ uitzeges -+ uitzendmarkt -+ uitzendschema -+ uitzendschema's -+ uitzendwerk -+ uitzettingsbeleid -+ uitzettingsprocedure -+ uitzettingsprocedures -+ uitzichtloosheid -+ uitzichtlozer -+ uitzichtsloost -+ uitzonderingsbepaling -+ uitzonderingsbepalingen -+ uitzonderingsclausule -+ uitzonderingssituaties -+ uiver -+ uivers -+ uivormig -+ uivormige -+ ukkepukken -+ ulo -+ ultra's -+ ultracentrifuges -+ ultraconservatief -+ ultraconservatieve -+ ultradun -+ ultradunne -+ ultrageluid -+ ultralicht -+ ultralichte -+ ultramicroscoop -+ ultramicroscopen -+ ultranationalistisch -+ ultranationalistische -+ ultraorthodox -+ ultraorthodoxe -+ ultrasnel -+ ultrasnelle -+ ultrasonisch -+ ultrasonische -+ ultrastructuren -+ ultrastructuur -+ umlautteken -+ umlauttekens -+ unanimiteitsregel -+ undercoveractie -+ undercoveragenten -+ undercoveroperatie -+ underdogpositie -+ undergroundmuziek -+ underperformer -+ underperformers -+ understatements -+ unheimische -+ unidentified flying object -+ unieerde -+ unief -+ uniefs -+ unieverdrag -+ unieverdragen -+ uniformblouse -+ uniformblouses -+ uniformbroek -+ uniformbroeken -+ uniformdrager -+ uniformdragers -+ uniformeringen -+ unionistische -+ unitaire -+ unitaristen -+ universalistische -+ universaliteitsbeginsel -+ universiteitsbestuur -+ universiteitsblad -+ universiteitsbladen -+ universiteitscampus -+ universiteitsdocent -+ universiteitsdocenten -+ universiteitsgidsen -+ universiteitsklinieken -+ universiteitsmuseum -+ universiteitsstudent -+ universiteitsstudenten -+ universiteitsziekenhuis -+ unplugged -+ unzip -+ unzippen -+ unzipt -+ unzipte -+ updatefunctie -+ updatet -+ upgrade -+ uploadde -+ uploads -+ uploadt -+ upmarket -+ upper -+ upper class -+ uppercuts -+ uppers -+ ups en downs -+ ups-and-downs -+ uptempo -+ uraniumoxide -+ uraniumverrijking -+ uraniumverrijkingsfabriek -+ uraniumverwerkend -+ uraniumverwerkende -+ uraniumwinning -+ urbaniseerde -+ urbanistische -+ urbi et orbi -+ ureters -+ urethra's -+ urethrae -+ urgentielijsten -+ urgentieprogramma's -+ urgentiepunt -+ urgentiepunten -+ urgentierecht -+ urgentieverklaring -+ urgentieverklaringen -+ urineblazen -+ urinebuizen -+ urinemonster -+ urinemonsters -+ urinestaal -+ urinestalen -+ urineweg -+ urologen -+ urologische -+ username -+ usernames -+ utilistische -+ utiliteiten -+ utiliteitsbouwer -+ utopismen -+ utopistische -+ uurgemiddelden -+ uurgemiddeldes -+ uurregeling -+ v's -+ v'tje -+ v.C. -+ v.Chr. -+ v.d. -+ v.h. -+ v.l.n.r. -+ v.r.n.l. -+ vaagdoenerij -+ vaagjes -+ vaagweg -+ vaalgrijs -+ vaalgrijze -+ vaalwit -+ vaalwitte -+ vaandelvlucht -+ vaandelvluchten -+ vaarbelasting -+ vaarbewijzen -+ vaardag -+ vaardagen -+ vaardiepten -+ vaargeld -+ vaargelden -+ vaarreglementen -+ vaarschema -+ vaarschema's -+ vaarseizoen -+ vaartijd -+ vaartijden -+ vaartocht -+ vaartochten -+ vaartuigenbelasting -+ vaasvorm -+ vaasvormen -+ vaatgezwel -+ vaatgezwellen -+ vaatkrampen -+ vaatplant -+ vaatplanten -+ vaatstelsels -+ vaatvernauwing -+ vaatverwijdend -+ vaatverwijdende -+ vaatverwijding -+ vaatwanden -+ vaatwas -+ vaatwassen -+ vaatwassers -+ vaatziekte -+ vaatziekten -+ vaatziektes -+ vacaturebanken -+ vacaturestops -+ vaccinatiecampagne -+ vaccinatiegraad -+ vaccinatieplicht -+ vacuole -+ vacuolen -+ vacuümbuis -+ vacuümbuizen -+ vacuümglas -+ vacuümglazen -+ vacuümkamer -+ vacuümkamers -+ vacuümpan -+ vacuümpannen -+ vacuümpompen -+ vacuüms -+ vacuümverpakkingen -+ vacuümverpakt -+ vacuümverpakte -+ vader-zoonrelatie -+ vader-zoonrelaties -+ vaderbeeld -+ vaderbeelden -+ vaderfiguren -+ vaderlandsloos -+ vaderlandsloze -+ vaderrol -+ vaderrollen -+ vaderschapsverloven -+ vaderskind -+ vaderskinderen -+ vaderskindje -+ vadersnaam -+ vadersnamen -+ vakantie-eiland -+ vakantie-uitkering -+ vakantie-uittocht -+ vakantiebeurs -+ vakantieboerderijen -+ vakantiebungalow -+ vakantiebungalows -+ vakantiedia -+ vakantiedia's -+ vakantiedorp -+ vakantiedorpen -+ vakantiegebied -+ vakantiegebieden -+ vakantieherinnering -+ vakantieherinneringen -+ vakantiejob -+ vakantiejobs -+ vakantiekaart -+ vakantiekaarten -+ vakantiekampen -+ vakantielectuur -+ vakantieliefde -+ vakantieparadijs -+ vakantieresort -+ vakantieresorts -+ vakantiestemming -+ vakantiestemmingen -+ vakantietrip -+ vakantieverblijf -+ vakantieverblijven -+ vakantieweek -+ vakantieweken -+ vakbeurs -+ vakbibliotheken -+ vakbondsactie -+ vakbondsacties -+ vakbondsafgevaardigde -+ vakbondsafgevaardigden -+ vakbondscentrale -+ vakbondsdelegatie -+ vakbondseis -+ vakbondseisen -+ vakbondsfront -+ vakbondsleden -+ vakbondsleiders -+ vakbondslidmaatschap -+ vakbondsorganisatie -+ vakbroeder -+ vakbroeders -+ vakcongressen -+ vakdepartement -+ vakdepartementen -+ vakdocenten -+ vakfederaties -+ vakgenotes -+ vakhistorici -+ vakhistoricus -+ vakinhoudelijk -+ vakinhoudelijke -+ vakkencombinatie -+ vakkencombinaties -+ vakkenpakketten -+ vakkenvuller -+ vakkenvullers -+ vakkundigheden -+ vakkundigheid -+ vakleerkracht -+ vakleerkrachten -+ vaklokalen -+ vakministers -+ vakonderwijzers -+ vakorganen -+ vakoverstijgend -+ vakoverstijgende -+ vakspecifiek -+ vakspecifieke -+ vaktalen -+ vakverbonden -+ vakverdeling -+ vakverdelingen -+ vakvrouwen -+ vakwetenschap -+ vakwetenschappen -+ valabel -+ valabele -+ valbeweging -+ valbewegingen -+ valentijnskaart -+ valentijnskaarten -+ valgewicht -+ validering -+ valkhof -+ valkhoven -+ valschermspringen -+ valsnelheden -+ valsspeler -+ valsspelers -+ valuta-analist -+ valuta-analisten -+ valuta-effect -+ valuta-effecten -+ valuta-inkomsten -+ valutabeurzen -+ valutacrises -+ valutacrisis -+ valutagebied -+ valutahandelaar -+ valutaire -+ valutamarkt -+ valutamarktinterventie -+ valutamarktinterventies -+ valutaoorlog -+ valutaoptie -+ valutaopties -+ valutarisico -+ valutarisico's -+ valutaspeculant -+ valutaspeculanten -+ valutaspeculatie -+ valutaspeculaties -+ valutateken -+ valutatekens -+ valutatransactie -+ valutatransacties -+ valutaverkeer -+ valutaverlies -+ valutaverliezen -+ valutawijziging -+ valutawijzigingen -+ valutawinst -+ valutawinsten -+ valversnelling -+ vampiersmentaliteit -+ vampierverhaal -+ vampierverhalen -+ vampirella -+ vampirella's -+ van bondswege -+ van dattum -+ van krommenaas gebaren -+ van likmevestje -+ van overheidszijde -+ vandaalbestendig -+ vandaalbestendige -+ vandalismebestendig -+ vandalismebestendige -+ vandalismebestrijding -+ vandalistisch -+ vanderwaalskracht -+ vandoen -+ vanghek -+ vanghekken -+ vangrails -+ vangstlimiet -+ vangstlimieten -+ vangstverbod -+ vanille-essence -+ vanillepudding -+ vanillevla -+ vanilleyoghurt -+ vanityfair -+ vanityfairs -+ vanjewelste -+ vaporiseerde -+ varaan -+ varanen -+ varenachtig -+ varenachtige -+ variabiliseerde -+ variabiliseren -+ variatiemogelijkheden -+ variatiemogelijkheid -+ variéteetje -+ variéténummers -+ varkenscycli -+ varkenscyclus -+ varkensdrijfmest -+ varkenshoeder -+ varkenshouder -+ varkenshouderij -+ varkenshouderijen -+ varkenshouders -+ varkenslapje -+ varkensleren -+ varkensmest -+ varkensmester -+ varkensmesterij -+ varkensmesters -+ varkensrollade -+ varkensslachterij -+ varkensslachterijen -+ varsity's -+ vasculaire -+ vastbenoemd -+ vastbenoemde -+ vastbeslotenheid -+ vastelander -+ vastelanders -+ vastenmaand -+ vastenperiode -+ vastentrommel -+ vastentrommels -+ vastentrommeltje -+ vastgehad -+ vastgeklikt -+ vastgeklonken -+ vastgekoppeld -+ vastgeniet -+ vastgepend -+ vastgepind -+ vastgeraakt -+ vastgesnoerd -+ vastgoedafdeling -+ vastgoedbeleggingsmaatschappij -+ vastgoedhandelaar -+ vastgoedinvesteerder -+ vastgoedmaatschappij -+ vastgoedmarkten -+ vastgoedportefeuille -+ vastgoedsector -+ vasthebben -+ vastklikken -+ vastkokend -+ vastkokende -+ vastkoppelen -+ vastomlijnd -+ vastpennen -+ vastraken -+ vastslaan -+ vastsnoeren -+ vastzuigen -+ vbo -+ vechteconomie -+ vechtersmentaliteit -+ vechtfilm -+ vechtfilms -+ vechthond -+ vechthonden -+ vechtlustig -+ vechtlustige -+ vechtmachine -+ vechtmachines -+ vechtpet -+ vechtpetten -+ vechtsport -+ vechttechniek -+ vechtvoetbal -+ vedergewichten -+ veebedrijf -+ veebezetting -+ veedief -+ veedieven -+ veedrijver -+ veedrijvers -+ veefokkerij -+ veefokkerijen -+ veegactie -+ veegacties -+ veegdienst -+ veegploeg -+ veegploegen -+ veehandelaar -+ veehouderij -+ veehouderijbedrijf -+ veehouderijen -+ veejay -+ veejays -+ veekoopman -+ veekoopmannen -+ veekraal -+ veekralen -+ veelbeduidend -+ veelbeduidende -+ veelbeluisterd -+ veelbeluisterde -+ veelde -+ veelgehoorde -+ veelgelezen -+ veelgeroemd -+ veelgeroemde -+ veelkoppige -+ veellezer -+ veellezers -+ veelpleger -+ veelplegers -+ veelverdiener -+ veelverdieners -+ veemarkthal -+ veemarkthallen -+ veenarbeider -+ veenbodem -+ veengebied -+ veengebieden -+ veenkoloniaal -+ veenkoloniale -+ veenlaag -+ veenlijk -+ veenlijken -+ veenmoeras -+ veenmoerassen -+ veenmos -+ veenmossen -+ veersysteem -+ veertiende-eeuws -+ veertiende-eeuwse -+ veertienjarig -+ veertiental -+ veertigdagentijd -+ veertigplusser -+ veertigplussers -+ veertigurenweek -+ veertigurenweken -+ veertigurig -+ veertigurige -+ veerverbindingen -+ veestapels -+ veeteeltbedrijf -+ veeteeltkundig -+ veeteeltkundige -+ veeteler -+ veetelers -+ veetransporten -+ veevoederbedrijf -+ veevoederfabriek -+ vegaburger -+ vegaburgers -+ veganisten -+ veganistisch -+ veganistische -+ vegetatiekunde -+ vegetatiekundige -+ vegetatiekundigen -+ veiliggesteld -+ veiligheidsadviseurs -+ veiligheidsapparaat -+ veiligheidsbeambte -+ veiligheidsbeambten -+ veiligheidsbrillen -+ veiligheidsconferentie -+ veiligheidscontrole -+ veiligheidscontroles -+ veiligheidsexpert -+ veiligheidsexperts -+ veiligheidsgordels -+ veiligheidshelm -+ veiligheidshelmen -+ veiligheidsinstructie -+ veiligheidsinstructies -+ veiligheidskooi -+ veiligheidskooien -+ veiligheidsmarges -+ veiligheidsnorm -+ veiligheidsnormen -+ veiligheidsoverweging -+ veiligheidspact -+ veiligheidspal -+ veiligheidspallen -+ veiligheidspin -+ veiligheidspinnen -+ veiligheidspolitie -+ veiligheidsrol -+ veiligheidsschepen -+ veiligheidsschepenen -+ veiligheidsschoen -+ veiligheidsschoenen -+ veiligheidssysteem -+ veiligheidsverdrag -+ veiligheidsvoorschrift -+ veiligheidswetten -+ veiligheidszone -+ veiligheidszones -+ veiligheidszorg -+ veiligstellen -+ veilingcatalogi -+ veilingcatalogussen -+ veilinggebouwen -+ veilinghouder -+ veilinghuizen -+ velaren -+ veldbezetting -+ veldbiologen -+ veldbioloog -+ veldgrijs -+ veldgrijze -+ veldhockey -+ veldkei -+ veldkeien -+ veldkorfbal -+ veldlaboratorium -+ veldlijn -+ veldloper -+ veldlopers -+ veldnaam -+ veldoverwicht -+ veldpolitie -+ veldproef -+ veldproeven -+ veldrat -+ veldratten -+ veldrijden -+ veldrijder -+ veldrijders -+ veldritten -+ veldspel -+ veldspeler -+ veldspelers -+ veldsport -+ veldsporten -+ veldtelefoon -+ veldtelefoons -+ veldtrainer -+ veldwerkster -+ veldwesp -+ veldwespen -+ velo's -+ velodromen -+ velomaker -+ velomakers -+ vendelzwaaier -+ vendelzwaaiers -+ vendetta's -+ vendu's -+ veneuze -+ venkelgroen -+ venkelknol -+ venkelknollen -+ venkelsalade -+ vennootschapsbelastingen -+ vennootschapsrechten -+ vensterdorpel -+ vensterdorpels -+ venstergat -+ venstergaten -+ vensterkozijn -+ vensterkozijnen -+ vensterrichel -+ vensterrichels -+ ventieldop -+ ventilatieopening -+ ventilatieopeningen -+ ventilatorkachels -+ ventilatortje -+ ventriculaire -+ ventrikelfibrilleren -+ ventrikels -+ ventvergunning -+ ventvergunningen -+ ventwegen -+ venusheuvels -+ ver-van-mijn-bedshow -+ verabsolutering -+ verabsoluteringen -+ verachtvoudigd -+ verachtvoudigde -+ verachtvoudigen -+ veralgemenisering -+ veralgemeniseringen -+ verambtelijking -+ veranda's -+ veranderaar -+ veranderaars -+ veranderbaar -+ veranderbare -+ veranderingsgezind -+ veranderingsgezinde -+ veranderingsgezindheid -+ verantwoordelijkheidsstructuur -+ verantwoordelijkheidsverdeling -+ verantwoordelijkheidsvraag -+ verantwoordelijkheidszin -+ verantwoordingsplicht -+ verbanddozen -+ verbandmiddel -+ verbandtrommels -+ verbeeldingswereld -+ verbeeldingswerelden -+ verbena's -+ verbeterbaar -+ verbeterbare -+ verbeurdverklaard -+ verbeurdverklaren -+ verbijzonderd -+ verbijzonderen -+ verbijzonderingen -+ verbindings-n -+ verbindings-n'en -+ verbindings-s -+ verbindings-s'en -+ verbindingsdeur -+ verbindingsdeuren -+ verbindingseenheden -+ verbindingseenheid -+ verbindingsgroep -+ verbindingskanaal -+ verbindingsmannen -+ verbindingsmiddel -+ verbindingsschakel -+ verbindingsstreepje -+ verbindingstroepen -+ verblijfsduur -+ verblijfsinrichting -+ verblijfsinrichtingen -+ verblijfskostenvergoeding -+ verblijfskostenvergoedingen -+ verblijfspapieren -+ verblijfsrecht -+ verblijfstijd -+ verblijfstitel -+ verblijftijd -+ verbodsbord -+ verbodswetgeving -+ verbouwer -+ verbouwers -+ verbouwingswerk -+ verbouwingswerkzaamheden -+ verbrander -+ verbrandingscapaciteit -+ verbrandingsinstallatie -+ verbrandingsinstallaties -+ verbrandingskamer -+ verbrandingsproducten -+ verbrandingsruimte -+ verbrandingstemperatuur -+ verbruikersbelasting -+ verbruikersunie -+ verbruikersunies -+ verbruikszaal -+ verbruikszalen -+ vercommercialiseerd -+ vercommercialiseren -+ vercommercialisering -+ verdachtenbank -+ verdachtenkooi -+ verdachtenlijst -+ verdampers -+ verdedigingsfout -+ verdedigingsmechanisme -+ verdedigingsmechanismen -+ verdedigingsmuur -+ verdedigingspact -+ verdedigingsplan -+ verdedigingsrede -+ verdedigingssysteem -+ verdedigingstactiek -+ verdeel-en-heersstrategie -+ verdeelpunt -+ verdeelsleutels -+ verdeelstekkers -+ verdeler -+ verdelger -+ verdelgers -+ verdelgingsmiddel -+ verdelingsplan -+ verdelingsvraagstuk -+ verdelingsvraagstukken -+ verderaf -+ verdergezet -+ verderstrekkend -+ verderstrekkende -+ verderzetten -+ verdicten -+ verdiencapaciteit -+ verdiener -+ verdieners -+ verdikkingsmiddel -+ verdiscontering -+ verdoezeling -+ verdommeling -+ verdommelingen -+ verdonkeremaning -+ verdovingsspuit -+ verdovingsspuiten -+ verdragsartikel -+ verdragsartikelen -+ verdragsgebied -+ verdragspartij -+ verdragspartner -+ verdragspartners -+ verdragsrecht -+ verdragsrechtelijk -+ verdragsrechtelijke -+ verdragstekst -+ verdragsteksten -+ verdragsverplichting -+ verdragsverplichtingen -+ verdriedubbeling -+ verdrietigheden -+ verdrietigheid -+ verdrievoudiging -+ verdringingen -+ verdringingseffect -+ verdringingsmarkt -+ verduisteringsgordijnen -+ verduisteringspapier -+ verdulleme -+ verdunner -+ verdunners -+ verdwijningszaak -+ verdwijningszaken -+ verdwijnpunten -+ verdwijntruc -+ veredelaar -+ veredelaars -+ veredelingsproducten -+ verengelsing -+ verenigbaarheid -+ verenigingsbestuur -+ verenigingsgebouwen -+ verenigingsorgaan -+ verenigingsraad -+ verenigingsraden -+ verenigingsstructuur -+ verenpak -+ verentooi -+ vereveningsbijdrage -+ vereveningsbijdragen -+ verfbommen -+ verfbommetje -+ verffabrikant -+ verfilmer -+ verfkrabbers -+ verfmassa -+ verfmes -+ verfmessen -+ verfoppervlak -+ verfrest -+ verfrol -+ verfrollen -+ verfrollers -+ verfrommeling -+ verfschrapers -+ verfstreep -+ verfstrepen -+ verfverdunners -+ vergaderaar -+ vergaderaars -+ vergadertafels -+ vergadertechniek -+ vergadertijger -+ vergadertijgers -+ vergassingstechniek -+ vergeefsheid -+ vergeet-mij-nietje -+ vergeldingsaanvallen -+ vergeldingsactie -+ vergeldingsacties -+ vergeldingsbombardement -+ vergeldingsbombardementen -+ vergelijkingsmaatstaf -+ vergeling -+ vergissinkje -+ vergistte -+ vergletsjering -+ vergoedingslimiet -+ vergoedingslimieten -+ vergoedingsprijs -+ vergoedingssom -+ vergoedingssysteem -+ vergrauwd -+ vergrauwde -+ vergrauwen -+ vergrendeld -+ vergrendelde -+ vergrotingsapparaat -+ vergrotingsapparaten -+ vergroving -+ vergunningaanvraag -+ vergunningaanvragen -+ vergunningenbeleid -+ vergunningenstelsel -+ vergunningenstelsels -+ vergunningensysteem -+ vergunningplicht -+ vergunningprocedure -+ vergunningprocedures -+ vergunningsaanvraag -+ vergunningsaanvragen -+ vergunningsprocedure -+ vergunningsprocedures -+ vergunningsstelsel -+ vergunningstelsel -+ vergunningsvoorwaarde -+ vergunningsvoorwaarden -+ vergunningverlenend -+ vergunningverlenende -+ vergunningverlener -+ vergunningverleners -+ vergunningverlening -+ verhaalbelasting -+ verhaalbelastingen -+ verhaalelement -+ verhaalelementen -+ verhaallijn -+ verhaallijnen -+ verhaalplicht -+ verhaalsactie -+ verhaalsacties -+ verhaalsplicht -+ verhaalsrecht -+ verhaalstructuur -+ verhaaltechnisch -+ verhaaltechnische -+ verhaalverloop -+ verhaalvorm -+ verhaalvormen -+ verhakseld -+ verhakselde -+ verhakselen -+ verhalenboek -+ verhalencycli -+ verhalencyclus -+ verhalenschrijver -+ verhalenschrijvers -+ verhalenverteller -+ verhalenvertellers -+ verhalenwedstrijd -+ verhandelbaarheid -+ verheffende -+ verheviging -+ verhevigingen -+ verhoorders -+ verhoorkamers -+ verhoorkamertje -+ verhuisberichten -+ verhuisdoos -+ verhuisdozen -+ verhuiskaarten -+ verhuispremie -+ verhuurbedrijf -+ verhuurkantoren -+ verhuurmaatschappij -+ verificatieonderzoek -+ verifieerbare -+ verinnerlijking -+ verjaardagscadeaus -+ verjaardagscadeautje -+ verjaardagsfeesten -+ verjaardagsgast -+ verjaardagsgasten -+ verjaardagspartij -+ verjaardagstaart -+ verjaardagstaarten -+ verjaardagsvisite -+ verjaardagsvisites -+ verjaarscadeaus -+ verjaarscadeautje -+ verjaarspartijen -+ verkaasd -+ verkaasde -+ verkazen -+ verkeersacademies -+ verkeersbeweging -+ verkeersbewegingen -+ verkeersboete -+ verkeersboetes -+ verkeersbrigadier -+ verkeerscommissie -+ verkeerscongestie -+ verkeerscongesties -+ verkeerscontroles -+ verkeersdeelnemer -+ verkeersdeelnemers -+ verkeersdelicten -+ verkeersdeskundige -+ verkeersdeskundigen -+ verkeersdichtheid -+ verkeersdienst -+ verkeersdiploma's -+ verkeersdrempel -+ verkeersinformatie -+ verkeersinfrastructuur -+ verkeersinspecties -+ verkeersintensiteit -+ verkeersknooppunt -+ verkeersknooppunten -+ verkeerskunde -+ verkeerslawaai -+ verkeersmaatregel -+ verkeersmaatregelen -+ verkeersongelukken -+ verkeersopstopping -+ verkeersopstoppingen -+ verkeersovertreder -+ verkeersovertreders -+ verkeersovertreding -+ verkeersovertredingen -+ verkeersplan -+ verkeersplannen -+ verkeerspleinen -+ verkeersprobleem -+ verkeerspunt -+ verkeerspunten -+ verkeerssituaties -+ verkeerssysteem -+ verkeerstechniek -+ verkeerstechnisch -+ verkeerstechnische -+ verkeersteken -+ verkeerstunnel -+ verkeerstunnels -+ verkeersvlieger -+ verkeersvliegers -+ verkeersvrij -+ verkeersvrije -+ verkeerswaarde -+ verkeerswet -+ verkeerswisselaar -+ verkeerswisselaars -+ verkeerszuilen -+ verkennerij -+ verkenningseenheden -+ verkenningseenheid -+ verkenningsteam -+ verkenningstoestel -+ verkenningstoestellen -+ verkiezingsaffiches -+ verkiezingsbeloften -+ verkiezingsbijeenkomsten -+ verkiezingsbiljetten -+ verkiezingsdebat -+ verkiezingsdebatten -+ verkiezingsfraude -+ verkiezingsinkt -+ verkiezingsissue -+ verkiezingskandidaat -+ verkiezingskandidaten -+ verkiezingslijsten -+ verkiezingsmanifest -+ verkiezingsmeeting -+ verkiezingsmeetings -+ verkiezingsnederlaag -+ verkiezingsnederlagen -+ verkiezingsonderzoek -+ verkiezingsoverwinningen -+ verkiezingspamflet -+ verkiezingspamfletten -+ verkiezingsretoriek -+ verkiezingsslogan -+ verkiezingsslogans -+ verkiezingsstunt -+ verkiezingsstunts -+ verkiezingstoespraken -+ verkiezingstournees -+ verkiezingsuitslagen -+ verklaarbaarheid -+ verklaringsgrond -+ verklaringsgronden -+ verklaringsmodel -+ verklaringsmodellen -+ verkleedkist -+ verkleedpartijtje -+ verkleiningsfactoren -+ verkleinvorm -+ verkletsen -+ verkletst -+ verkletste -+ verkleuringen -+ verklinken -+ verklonk -+ verklonken -+ verkloot -+ verklootte -+ verkloten -+ verknalde -+ verkniptheid -+ verknooptheid -+ verknoping -+ verkoeverkamer -+ verkoeverkamers -+ verkokerd -+ verkokerde -+ verkokeren -+ verkokering -+ verkoopadres -+ verkoopadressen -+ verkoopbedrijf -+ verkoopbureau -+ verkoopcontract -+ verkoopcoöperatie -+ verkoopdatums -+ verkoopkanaal -+ verkoopkantoor -+ verkoopkantoren -+ verkoopmethode -+ verkoopnet -+ verkoopopbrengst -+ verkoopopbrengsten -+ verkoopopdrachten -+ verkooporder -+ verkooporders -+ verkoopovereenkomst -+ verkooppersoneel -+ verkooppunten -+ verkooprecht -+ verkoopsom -+ verkoopsprijzen -+ verkooptentoonstelling -+ verkoopvoorwaarden -+ verkorreld -+ verkorrelde -+ verkorrelen -+ verkrachtingskamp -+ verkrachtingskampen -+ verkrachtingsscène -+ verkramping -+ verkrampingen -+ verkramptheid -+ verkrapt -+ verkrapte -+ verkrijger -+ verkrotte -+ verkrotten -+ verkruimeling -+ verlader -+ verladers -+ verladersorganisatie -+ verlammingsverschijnsel -+ verlammingsverschijnselen -+ verlangzaming -+ verlatingsangst -+ verlegenheidsoplossing -+ verleidingskunst -+ verleidingskunsten -+ verleidingsscène -+ verleidingsscènes -+ verleidingstheorie -+ verlengsnoer -+ verlengsnoertje -+ verlichtingsdenken -+ verlichtingsideaal -+ verlichtingsinstallaties -+ verlichtingspaal -+ verlichtingspalen -+ verlies-en-winstrekening -+ verlieslatend -+ verlieslatende -+ verlieslijdend -+ verlieslijdende -+ verliesmakend -+ verliesmakende -+ verliespunt -+ verliespunten -+ verlijmen -+ verlijming -+ verlinksen -+ verlinkst -+ verlinkste -+ verlinkte -+ verliteratuurd -+ verliteratuurde -+ verloederde -+ verloederingsverschijnsel -+ verloederingsverschijnselen -+ verlofperiode -+ verlokkend -+ verlokkende -+ verlonen -+ verloning -+ verloningen -+ verloofdes -+ verloond -+ verloonde -+ verloopstekkers -+ verloopstukken -+ verlorenheid -+ verloskamers -+ verlovingskaarten -+ verlummelde -+ vermaakscentra -+ vermaaksindustrie -+ vermageringsdiëten -+ vermaling -+ vermannelijken -+ vermannelijking -+ vermannelijkt -+ vermannelijkte -+ vermarkt -+ vermarkte -+ vermarkten -+ vermassacreerd -+ vermassacreerde -+ vermassacreren -+ vermeerderingsbedrijf -+ vermesting -+ vermijdingsgedrag -+ verminderingskaart -+ verminderingskaarten -+ vermissingen -+ vermoeidheidssyndroom -+ vermoeidheidsverschijnsel -+ vermoeidheidsverschijnselen -+ vermogensbeheer -+ vermogensbeheerder -+ vermogensbeheerders -+ vermogensbezitter -+ vermogensbezitters -+ vermogensgroeifonds -+ vermogensheffingen -+ vermogensrecht -+ vermogensrechten -+ vermogensrendementsheffing -+ vermogensstructuur -+ vermogenstoets -+ vermogensvergelijking -+ vermogensverlies -+ vermogenswinst -+ vermogenswinsten -+ vernacheld -+ vernachelde -+ vernachelen -+ vernatting -+ verneukeratief -+ verneukeratieve -+ vernevelaar -+ vernevelaars -+ verneveling -+ vernieler -+ vernielers -+ vernietigingsdrang -+ vernietigingsdrift -+ vernietigingskamp -+ vernietigingskampen -+ vernietigingsoorlog -+ vernietigingswapen -+ vernietigingswapens -+ vernieuwbaar -+ vernieuwbare -+ vernieuwingsbeweging -+ vernieuwingsgedachten -+ vernieuwingsgezind -+ vernieuwingsgezinde -+ vernieuwingsoperatie -+ vernieuwingsoperaties -+ vernislagen -+ vernummerde -+ verongelijktheid -+ verouderingsonderzoek -+ verouderingsproces -+ verouderingsziekte -+ verouderingsziekten -+ veroveringsdrang -+ veroveringsdrift -+ veroveringstocht -+ veroveringstochten -+ verpakkingsafval -+ verpakkingsbedrijf -+ verpakkingsconvenant -+ verpakkingsindustrie -+ verpakkingskarton -+ verpakkingsmachine -+ verpakkingsmachines -+ verpakkingsstaal -+ verpappen -+ verpapt -+ verpapte -+ verpinken -+ verpinkt -+ verpinkte -+ verplatting -+ verpleegafdeling -+ verpleegassistent -+ verpleegassistenten -+ verpleeghuisbed -+ verpleeghuisbedden -+ verpleeghuiszorg -+ verpleeghuizen -+ verpompt -+ verpompte -+ verrassingsaanvallen -+ verrassingsactie -+ verrassingsacties -+ verrassingseffecten -+ verrassingselement -+ verrassingselementen -+ verrassingsfeest -+ verrassingsfeesten -+ verrassingsfilm -+ verrassingspakket -+ verrechtsen -+ verrechtste -+ verrechtvaardigd -+ verrechtvaardigde -+ verrechtvaardigen -+ verrekenkas -+ verrekkeling -+ verrekkelingen -+ verrichtingsleer -+ verrijkingsarbeid -+ verrijkingscapaciteit -+ verrijkingsfabriek -+ verrijkingsmarkt -+ verrijkingsstof -+ verruigd -+ verruigde -+ verruigen -+ verruiging -+ verruimingskandidaat -+ verruimingskandidaten -+ verruwd -+ verruwde -+ verruwen -+ versafdeling -+ versafdelingen -+ verscheuring -+ verschijningsdatums -+ verschijningsplicht -+ verschoolsing -+ verschoppelingetje -+ verschrikker -+ verschrikkers -+ verschroot -+ verschrootte -+ verschut -+ versgebakken -+ versgemalen -+ versgeperst -+ versgeperste -+ versgeraspt -+ versgeraspte -+ versierders -+ versjteerd -+ versjteerde -+ verslaafdenzorg -+ verslaggeverij -+ verslagperiode -+ verslagweek -+ verslavingen -+ verslavingsonderzoek -+ verslavingsprobleem -+ verslavingsproblematiek -+ verslavingsproblemen -+ verslavingsziekten -+ verslavingsziektes -+ verslechteringen -+ versleuteld -+ versleutelde -+ versleutelen -+ versleuteling -+ verslonzing -+ versluiering -+ versnellers -+ versnellingsmeter -+ versnellingsmeters -+ versnellingspoken -+ versnipperaar -+ versnipperaars -+ versoberingspolitiek -+ verspaande -+ verspijkerd -+ verspijkerde -+ verspijkeren -+ verspringbak -+ verspringer -+ verspringers -+ verssoort -+ verssoorten -+ verstaatsing -+ verstaging -+ verstandshuwelijken -+ verstandsmensen -+ verstappen -+ verstapte -+ verstatelijking -+ verstatelijkt -+ verstatelijkte -+ verstedelijken -+ verstedelijkt -+ verstedelijkte -+ verstekbakken -+ verstekblokken -+ verstekvonnis -+ versterkend -+ verstevigers -+ verstierd -+ verstierde -+ verstieren -+ verstilling -+ verstoffing -+ verstoft -+ verstofte -+ verstrakking -+ verstralers -+ verstrekker -+ verstrekkingenpakket -+ versuikering -+ versvorm -+ versvormen -+ vertaalcomputers -+ vertaalkosten -+ vertaalmachine -+ vertaalmachines -+ vertaaloefeningen -+ vertaalprogramma's -+ vertaalwetenschap -+ vertaalwoordenboek -+ vertaalwoordenboeken -+ vertaler-tolk -+ vertalers-tolken -+ vertechnisering -+ vertederend -+ vertellersstem -+ vertelperspectief -+ vertelstem -+ verteltalent -+ verteltechniek -+ vertepunt -+ vertepunten -+ verteringsproces -+ vertienvoudiging -+ vertoningsverbod -+ vertragingsactie -+ vertragingsacties -+ vertrekdata -+ vertrekdatum -+ vertrekhallen -+ vertrekkensklaar -+ vertrekkensklare -+ vertrekker -+ vertrekkers -+ vertrekklaar -+ vertrekklare -+ vertrekpremies -+ vertrekstation -+ vertrekstations -+ vertrektijden -+ vertroebelingen -+ vertrouwelinges -+ vertrouwenscommissie -+ vertrouwenscommissies -+ vertrouwenscrisissen -+ vertrouwensfiguur -+ vertrouwensposities -+ vertrouwensstemming -+ vertrouwensvotum -+ vertrutting -+ veruiterlijking -+ vervaald -+ vervaalde -+ vervaldatums -+ vervalen -+ vervallenverklaringen -+ vervalmaand -+ vervaltermijn -+ vervangingsinkomen -+ vervangingsinkomens -+ vervangingsinvesteringen -+ vervangingskosten -+ vervangsters -+ vervangstuk -+ vervangstukken -+ verveeldheid -+ verviervoudiging -+ vervijfvoudiging -+ vervlechting -+ vervlechtingen -+ vervoerbeleid -+ vervoerdersoverleg -+ vervoerinfrastructuur -+ vervoerkosten -+ vervoermaatschappij -+ vervoerplan -+ vervoerplannen -+ vervoersbeleid -+ vervoersbewijs -+ vervoersbewijzen -+ vervoerscontract -+ vervoerscontracten -+ vervoersdocument -+ vervoersector -+ vervoersinfrastructuur -+ vervoerskaart -+ vervoersmaatschappij -+ vervoersorganisatie -+ vervoersplan -+ vervoersplannen -+ vervoerssector -+ vervoersstaking -+ vervoerssysteem -+ vervoerstak -+ vervoerstakken -+ vervoerstoelage -+ vervoerstoelagen -+ vervoerstoelages -+ vervoersverbod -+ vervoersysteem -+ vervolgactie -+ vervolgafspraak -+ vervolgafspraken -+ vervolgboek -+ vervolgconferentie -+ vervolgfilm -+ vervolgfilms -+ vervolggesprek -+ vervolggesprekken -+ vervolgingsapparaat -+ vervolgingsbeleid -+ vervolgingsslachtoffer -+ vervolgingsslachtoffers -+ vervolgingswaan -+ vervolgopdracht -+ vervolgopleidingen -+ vervolgorder -+ vervolgorders -+ vervolgrapportage -+ vervolgserie -+ vervolgstudies -+ vervolguitgifte -+ vervolledigd -+ vervolledigde -+ vervolledigen -+ vervolmakingscursus -+ vervolmakingscursussen -+ vervolmakingsjaar -+ vervuilen -+ vervuilers -+ vervuilingsbron -+ vervuilingsbronnen -+ vervuilingsgraad -+ vervuilingsrechten -+ vervulbare -+ verwachtbaar -+ verwachtbare -+ verwachtingspatronen -+ verwantes -+ verwantschapsbetrekking -+ verwantschapsbetrekkingen -+ verwantschapsnaam -+ verwantschapsnamen -+ verwarmingsinstallateurs -+ verwarmingsketels -+ verwarmingsmonteurs -+ verweduwd -+ verweduwde -+ verwekkingen -+ verwennerijen -+ verwenning -+ verwerkingsbedrijf -+ verwerkingscapaciteit -+ verwerkingseenheden -+ verwerkingsmethoden -+ verwerkingssnelheid -+ verwerkingstijden -+ verwesterde -+ verwesteren -+ verwesterlijking -+ verwestersing -+ verwetenschappelijken -+ verwetenschappelijking -+ verwetenschappelijkt -+ verwetenschappelijkte -+ verweving -+ verwevingen -+ verwijderingsbijdrage -+ verwijsbriefjes -+ verwijsfunctie -+ verwijsindex -+ verwijskaarten -+ verwijtbaar -+ verwijtbaarheid -+ verwijtbaarheidscriterium -+ verwijtbare -+ verwikte -+ verwilderingen -+ verwoestijning -+ very important person -+ verzakelijken -+ verzakelijkt -+ verzakelijkte -+ verzaligd -+ verzaligde -+ verzamel-cd -+ verzamel-cd's -+ verzamelbanden -+ verzamelbegrippen -+ verzamelbekken -+ verzameldrift -+ verzamelelpees -+ verzamelhandschrift -+ verzamelobjecten -+ verzamelplaten -+ verzamelpunten -+ verzamelwoord -+ verzekerbank -+ verzekerbanken -+ verzekerbare -+ verzekerdenbestand -+ verzekeringmaatschappij -+ verzekeringnemers -+ verzekeringsadviseurs -+ verzekeringsgeld -+ verzekeringsgelden -+ verzekeringsgeneeskunde -+ verzekeringsinstelling -+ verzekeringsinstellingen -+ verzekeringsman -+ verzekeringsnemers -+ verzekeringspakketten -+ verzekeringsplaat -+ verzekeringsplaatje -+ verzekeringsplaten -+ verzekeringsraden -+ verzekeringsrisico -+ verzekeringsrisico's -+ verzekeringsstelsel -+ verzekeringsstelsels -+ verzekeringswaarde -+ verzekeringswaarden -+ verzekeringswiskundige -+ verzekeringswiskundigen -+ verzekeringszaken -+ verzelfstandigingsproces -+ verzenbundeltje -+ verzendklare -+ verzenuwd -+ verzenuwde -+ verzesvoudigd -+ verzesvoudigde -+ verzesvoudigen -+ verzesvoudiging -+ verzetsdaad -+ verzetsdaden -+ verzetshaard -+ verzetshaarden -+ verzetshelden -+ verzetshouding -+ verzetsleger -+ verzetsmannen -+ verzetsmensen -+ verzetsmonumenten -+ verzetsorganisatie -+ verzetsstrijders -+ verzetswerk -+ verzettelijke -+ verzevenvoudiging -+ verzieking -+ verzilt -+ verzilten -+ verziltte -+ verzinkboortje -+ verzinkboren -+ verzinklijn -+ verzinnebeeld -+ verzinnebeeldde -+ verzoekplaten -+ verzoekplatenprogramma's -+ verzoekprogramma's -+ verzoeningsbijeenkomst -+ verzoeningscommissie -+ verzoeningscommissies -+ verzoeningsconferentie -+ verzoeningsgebaar -+ verzoeningsgebaren -+ verzoeningsgesprek -+ verzoeningspoging -+ verzoeningspogingen -+ verzorgingsflats -+ verzorgingsgebied -+ verzorgingsgebieden -+ verzorgingsproduct -+ verzorgingsproducten -+ verzorgingstehuizen -+ verzuildheid -+ verzuilen -+ verzuilingsmodel -+ verzuimbegeleiding -+ verzuimbeleid -+ verzuimbestrijding -+ verzuimprikkels -+ verzuringsgraad -+ verzusteringen -+ vestaals -+ vestaalse -+ vestibulaire -+ vestigingsklimaat -+ vestigingspremies -+ vestigingsvoorwaarde -+ vestigingswetten -+ vestingmuren -+ vestingmuur -+ vestingsteden -+ vestingstelsel -+ vestingwal -+ vetbol -+ vetbollen -+ vetbult -+ vetbulten -+ veterane -+ veteranenbeleid -+ veteranenorganisatie -+ veteranes -+ veterdrop -+ veterschoen -+ veterschoenen -+ vetersluiting -+ vethuishoudingen -+ vetklier -+ vetklieren -+ vetkrijtje -+ vetkrijtjes -+ vetkuiven -+ vetkussens -+ vetkussentje -+ veto's -+ vetpuistje -+ vetpuistjes -+ vetrand -+ vetranden -+ vetrijk -+ vetrol -+ vetrollen -+ vetstof -+ vetstoffen -+ vetweefsels -+ vetweidde -+ vezelgroep -+ vezelmarkt -+ vezelplaten -+ vezelproductie -+ vezelrijk -+ vezelrijke -+ vezelsgroep -+ vezelvlies -+ vezelvliezen -+ vibrafonisten -+ vibrafoons -+ vibratoloos -+ vibratoloze -+ vicaris-generaal -+ vicarissen-generaal -+ vice-eersteminister -+ vice-eersteministers -+ viceadmiraal -+ viceadmiraals -+ viceconsul -+ viceconsuls -+ vicedirecteur -+ vicekanselier -+ vicekanselierschap -+ viceminister -+ viceminister-president -+ viceminister-presidenten -+ vicepremier -+ vicepremiers -+ vicepremierschap -+ vicepresident -+ vicepresidenten -+ vicepresidentieel -+ vicepresidentiële -+ vicepresidentschap -+ vicepresidentskandidaat -+ vicevoorzitter -+ vicevoorzitters -+ vicevoorzitterschap -+ vicevoorzitterschappen -+ vicewereldkampioen -+ victoriaans -+ victoriaanse -+ victoriabaars -+ victoriabaarzen -+ video-editor -+ video-editors -+ video-installatie -+ video-installaties -+ video-opname -+ video-opnamen -+ video-opnames -+ videoaanbod -+ videoapparaat -+ videoapparatuur -+ videobeeld -+ videocassette -+ videocassetterecorders -+ videocassettes -+ videoclipachtig -+ videoclipachtige -+ videoclips -+ videofoons -+ videofragment -+ videofragmenten -+ videogame -+ videogames -+ videojockey -+ videojockeys -+ videokaart -+ videokaarten -+ videoketen -+ videokunst -+ videokunstenaar -+ videokunstenaars -+ videoplaten -+ videopresentatie -+ videopresentaties -+ videorecorders -+ videoregistratie -+ videoregistraties -+ videoscherm -+ videospel -+ videospelen -+ videospelletje -+ videotapes -+ videotechniek -+ videotheekhouder -+ videotheekhouders -+ videoverhuur -+ videoverhuurder -+ videoverhuurketen -+ videowinkel -+ videowinkels -+ videozaak -+ videozaken -+ vides -+ vidé -+ vidés -+ vierbaanswegen -+ viercilinder -+ viercilinders -+ vierdaagsen -+ vierdagenweek -+ vierdeklasser -+ vierdeklassers -+ vierdubbel -+ vierentwintigjarig -+ vierentwintigjarige -+ vierentwintiguursdienst -+ vierentwintiguurseconomie -+ vierentwintiguursservice -+ vierenveertigjarig -+ vierenveertigjarige -+ viergangenmenu -+ viergangenmenu's -+ vierhoog -+ vierjaarlijks -+ vierjaarlijkse -+ vierjarenplan -+ vierjarenplannen -+ vierkaart -+ vierkamp -+ vierkantemeterprijs -+ vierklauwens -+ vierkwartsmaten -+ vierluik -+ viermaal -+ viermansbob -+ viermotorig -+ viermotorige -+ vierpartijencoalitie -+ vierpersoonskamer -+ vierpersoonskamers -+ viersterrenhotel -+ viersterrenrestaurant -+ viertakt -+ vieruurtje -+ vieruurtjes -+ viervlak -+ viervlakken -+ vierweeks -+ vierwielaandrijving -+ vierwieler -+ vierwielers -+ viespeuk -+ viespeuken -+ viespeukerij -+ vietnamees -+ vietnamezen -+ viewers -+ views -+ viezerd -+ viezerds -+ viezig -+ viezige -+ vijandbeeld -+ vijandbeelden -+ vijanddenken -+ vijandsbeeld -+ vijandsbeelden -+ vijfachtste -+ vijfcilinder -+ vijfcilinders -+ vijfdagenweek -+ vijfdagenweken -+ vijfdejaars -+ vijfentwintigduizend -+ vijfentwintigjarig -+ vijfenveertigjarig -+ vijfenveertigjarige -+ vijfenveertigjarigen -+ vijfenzestig -+ vijfenzestigpluskaart -+ vijfenzestigplusser -+ vijfenzestigplussers -+ vijfenzestigste -+ vijfenzeventigjarig -+ vijfenzeventigjarige -+ vijfgangendiner -+ vijfgangendiners -+ vijfjaarlijks -+ vijfjaarlijkse -+ vijfjarenplan -+ vijfjarenplannen -+ vijfkaart -+ vijfkamerwoning -+ vijfkoppig -+ vijfkoppige -+ vijflandentoernooi -+ vijfling -+ vijflingen -+ vijfmaal -+ vijfpartijenakkoord -+ vijfploegendienst -+ vijfpuntig -+ vijfpuntige -+ vijfsetter -+ vijfsetters -+ vijfsterrenhotels -+ vijftiende-eeuws -+ vijftiende-eeuwse -+ vijftienkoppig -+ vijftienkoppige -+ vijftiental -+ vijftigeurobiljet -+ vijftigeurobiljetten -+ vijftigmaal -+ vijftigplusser -+ vijftigplussers -+ vilbeluik -+ vilbeluiken -+ vileine -+ villabewoner -+ villabewoners -+ villadorp -+ villadorpen -+ villagrond -+ viltpennen -+ vinaigrettes -+ vindersloon -+ vingerafdrukkensysteem -+ vingerkleuren -+ vingerlang -+ vingerlange -+ vingernagel -+ vingernagels -+ vingerplant -+ vingerplanten -+ vingerspel -+ vingertaal -+ vingervaardigheden -+ vingervaardigheid -+ vingerverf -+ vingerwerk -+ vinkenier -+ vinkeniers -+ vinnigheden -+ vintages -+ vinylgroep -+ vinylgroepen -+ vinylplaat -+ vinylplaten -+ violaties -+ violistes -+ violistische -+ vioolbouwers -+ vioolgespeeld -+ vioolklank -+ vioolpartij -+ vioolpedagoog -+ vioolsolo -+ vioolsonate -+ vioolsonates -+ vioolspelen -+ viooltoon -+ vipbehandeling -+ vipdorp -+ vipdorpen -+ vipje -+ vipplaats -+ vipplaatsen -+ viproom -+ viprooms -+ vipruimte -+ vipruimten -+ vipruimtes -+ viptribune -+ viptribunes -+ virago's -+ virale -+ virologen -+ virtual reality -+ virusdrager -+ virusdragers -+ virusepidemie -+ virusinfecties -+ virusscanners -+ virusstam -+ virusstammen -+ virusvariant -+ virusziekten -+ virusziektes -+ visaanvoer -+ visafoons -+ visafslagen -+ visafval -+ visagiste -+ visagisten -+ visagistes -+ visbouillon -+ visburger -+ visburgers -+ viscerale -+ visdiefje -+ visdiefjes -+ visetend -+ visetende -+ visfilets -+ visgat -+ visgaten -+ visgebied -+ visgebieden -+ visgerecht -+ visgerechten -+ visgerei -+ visgraatdessin -+ visgraatdessins -+ visgraatpatronen -+ visgraatpatroon -+ vishandel -+ visieloze -+ visitatiecommissie -+ visitatiecommissies -+ visitatierapport -+ visitatierapporten -+ visitatoren -+ visitators -+ viskom -+ viskommen -+ viskotter -+ viskotters -+ viskraam -+ viskruiden -+ viskwekerij -+ viskwekerijen -+ visliefhebbers -+ vismandje -+ vismoot -+ vismoten -+ visolie -+ visooglens -+ visooglenzen -+ visrestaurant -+ visrestaurants -+ vissaus -+ vissausen -+ vissauzen -+ visseizoenen -+ vissenhuid -+ vissenhuiden -+ vissenkom -+ vissenkommen -+ vissenkoppen -+ vissenleer -+ vissenogen -+ visserijband -+ visserijbanden -+ visserijbiologen -+ visserijbioloog -+ visserijinspectie -+ visserijinspecties -+ visserijonderzoek -+ visserijoorlog -+ visserijproduct -+ visserijproducten -+ visserijuitrusting -+ visserlieden -+ visserlui -+ visserman -+ vissersbevolking -+ vissersgaren -+ vissersscheepje -+ vissersschepen -+ vissersvaartuig -+ vissersvaartuigen -+ vissersvloot -+ vissersvloten -+ vissoep -+ vissoepen -+ vissterfte -+ visstick -+ vissticks -+ visstoeltje -+ visstoeltjes -+ vistrap -+ vistrappen -+ visualisaties -+ visualisering -+ visumaanvraag -+ visumaanvragen -+ visumbeleid -+ visumweigering -+ visvergunningen -+ visverwerkend -+ visverwerkende -+ visverwerkingsbedrijf -+ visvlees -+ viswedstrijden -+ vitalisering -+ vitalistische -+ vitamine B12 -+ vitaminepilletje -+ vitaminestoot -+ vitaminestoten -+ vitaminetekort -+ vitaminetekorten -+ vitrocultuur -+ vivisecties -+ vj -+ vj's -+ vla's -+ vlaggenbrief -+ vlaggenbrieven -+ vlaggenist -+ vlaggenmasten -+ vlakaf -+ vlakgum -+ vlakliggend -+ vlakschaaf -+ vlakschaven -+ vlakschuurmachines -+ vlaktemeting -+ vlaktemetingen -+ vlakvijl -+ vlakvijlen -+ vlakvulling -+ vlammenzeeën -+ vlampunten -+ vlamverdelers -+ vlaskam -+ vlaskammen -+ vlasleeuwenbek -+ vlasleeuwenbekken -+ vlasvezel -+ vlasvezels -+ vlechthout -+ vleesafval -+ vleesberg -+ vleesbergen -+ vleesfabriek -+ vleesfondue -+ vleesfondues -+ vleesgroente -+ vleeshuis -+ vleeshuizen -+ vleesindustrie -+ vleeskant -+ vleeskanten -+ vleeskoe -+ vleeskoeien -+ vleesmachine -+ vleesmachines -+ vleesmarkt -+ vleesprijs -+ vleesprijzen -+ vleesproduct -+ vleesproducten -+ vleesproductie -+ vleessnijmachine -+ vleessnijmachines -+ vleessoort -+ vleessoorten -+ vleesstier -+ vleesstieren -+ vleestomaat -+ vleestomaten -+ vleesvarken -+ vleesvarkens -+ vleesverwerkend -+ vleesverwerkende -+ vleesverwerkingsbedrijf -+ vleeswarenfabriek -+ vleeszijde -+ vleierig -+ vleierige -+ vlekkenziekte -+ vlekkenziekten -+ vlekkenziektes -+ vlekvrij -+ vlekvrije -+ vlerkerig -+ vlerkerige -+ vleugelboten -+ vleugelloos -+ vleugelloze -+ vleugeloppervlak -+ vleugelpiano's -+ vleugelprofiel -+ vleugelslagen -+ vleugelspanwijdte -+ vleugelspeler -+ vleugelspelers -+ vleugelspits -+ vleugelspitsen -+ vleugeltip -+ vleugeltippen -+ vleugelverdedigers -+ vleugelwijdte -+ vleugjes -+ vliegbedrijf -+ vliegbereik -+ vliegbeweging -+ vliegbewegingen -+ vliegbiljetten -+ vliegclub -+ vliegdekken -+ vliegden -+ vliegdennen -+ vliegeigenschappen -+ vliegengaas -+ vliegengordijn -+ vliegenklapper -+ vliegenklappers -+ vliegenmeppers -+ vliegenplagen -+ vliegenraam -+ vliegenramen -+ vliegenzwam -+ vliegenzwammen -+ vliegerde -+ vliegerfeest -+ vlieggewichten -+ vlieghelm -+ vlieghoogte -+ vlieginstructeur -+ vliegkamp -+ vliegkampschepen -+ vliegoefening -+ vliegoefeningen -+ vliegopleiding -+ vliegreizen -+ vliegsnelheden -+ vliegstoel -+ vliegstoelen -+ vliegticket -+ vliegtickets -+ vliegtuigbouw -+ vliegtuigbouwconsortium -+ vliegtuigbouwer -+ vliegtuigbouwers -+ vliegtuigbouwkunde -+ vliegtuigbouwkundig -+ vliegtuigbouwkundige -+ vliegtuigbrandstof -+ vliegtuigenfabriek -+ vliegtuigfabriek -+ vliegtuighangar -+ vliegtuighangars -+ vliegtuigkaper -+ vliegtuigkaping -+ vliegtuigkapingen -+ vliegtuigongeval -+ vliegtuigongevallen -+ vliegtuigproductie -+ vliegtuigramp -+ vliegtuigrampen -+ vliegtuigshow -+ vliegtuigstoel -+ vliegtuigstoelen -+ vliegtuigticket -+ vliegtuigtickets -+ vliegtuigtype -+ vliegtuigtypen -+ vliegtuigtypes -+ vliegtuigvleugel -+ vliegtuigvleugels -+ vliegtuigwrak -+ vliegvakanties -+ vliegvermogen -+ vliegvissen -+ vlierbes -+ vlierbessen -+ vliesachtig -+ vliesachtige -+ vliesdun -+ vliesgevel -+ vliesgevels -+ vliespinda's -+ vliesvleugeligen -+ vlijtige liesjes -+ vlinderbril -+ vlinderdas -+ vlinderdassen -+ vlinderde -+ vlinderen -+ vlinderlicht -+ vlinderlichte -+ vlindermes -+ vlindersoort -+ vlinderstrikje -+ vlinderstrikjes -+ vlizotrap -+ vlizotrappen -+ vloedbos -+ vloedbossen -+ vloedlijnen -+ vloedstroom -+ vloeistofdicht -+ vloeistofdichte -+ vloeistofoppervlak -+ vloeistofstroming -+ vloeistofstroom -+ vloeiwei -+ vloekverbod -+ vloerbedekkingen -+ vloerbekleding -+ vloerbroden -+ vloerbrood -+ vloerdeel -+ vloerdelen -+ vloeroefening -+ vloeroefeningen -+ vloertapijt -+ vloertapijten -+ vloerverwarmingen -+ vlokkerig -+ vlokkerige -+ vlooienmarkten -+ vlooienpoeder -+ vlooienpoeier -+ vlootbases -+ vlooteenheden -+ vlooteenheid -+ vlooteskaders -+ vlootverdrag -+ vlootverdragen -+ vlossig -+ vlossige -+ vlotjes -+ vluchtauto -+ vluchtbermen -+ vluchtbeweging -+ vluchtbewegingen -+ vluchtelingenbureau -+ vluchtelingenconventie -+ vluchtelingenorganisatie -+ vluchtelingenprobleem -+ vluchtelingenproblematiek -+ vluchtelingenproblemen -+ vluchtelingenstatus -+ vluchtelingenstromen -+ vluchtelingenstroom -+ vluchtelingenverdrag -+ vluchtelingenverdragen -+ vluchtelingenvraagstuk -+ vluchter -+ vluchters -+ vluchtgedrag -+ vluchtgevaar -+ vluchtgevaarlijk -+ vluchtgevaarlijke -+ vluchtheuveltje -+ vluchthuis -+ vluchthuizen -+ vluchtkapitaal -+ vluchtleidingen -+ vluchtleidingscentra -+ vluchtleidingscentrum -+ vluchtmisdrijf -+ vluchtmisdrijven -+ vluchtnummer -+ vluchtnummers -+ vluchtoord -+ vluchtoorden -+ vluchtplaats -+ vluchtplaatsen -+ vluchtplan -+ vluchtplannen -+ vluchtpoging -+ vluchtpogingen -+ vluchtreactie -+ vluchtreacties -+ vluchtroute -+ vluchtrouten -+ vluchtschot -+ vluchtschoten -+ vluchtsimulator -+ vluchtstroken -+ vluggerd -+ vluggerde -+ vluggerds -+ vluggeren -+ vmbo -+ vmbo-leerling -+ vmbo-leerlingen -+ vnl. -+ vocabularia -+ vocabulariums -+ vocalistenconcours -+ vochtgehalten -+ vochtgehaltes -+ vochthoudend -+ vochthoudende -+ vochtkring -+ vochtkringen -+ vochtmeters -+ vochtminnend -+ vochtminnende -+ vochtvlek -+ vochtvlekken -+ voddenbalen -+ voddenvent -+ voddenventen -+ vodderig -+ vodderige -+ voedde herop -+ voederplaats -+ voederplaatsen -+ voedingsartikel -+ voedingsartikelen -+ voedingsbestanddeel -+ voedingsbestanddelen -+ voedingscrème -+ voedingscrèmes -+ voedingsdeskundige -+ voedingsdeskundigen -+ voedingsgewoonten -+ voedingsgewoontes -+ voedingsindustrie -+ voedingsleer -+ voedingsmiddelenindustrie -+ voedingsonderzoek -+ voedingspatronen -+ voedingsprobleem -+ voedingsproblemen -+ voedingssupplement -+ voedingssupplementen -+ voedingstof -+ voedingstoffen -+ voedselallergie -+ voedselarm -+ voedselarme -+ voedselbehoefte -+ voedselbehoeften -+ voedseldistributie -+ voedseldropping -+ voedseldroppings -+ voedselgebrek -+ voedselimport -+ voedselimporten -+ voedselketens -+ voedselkonvooi -+ voedselkonvooien -+ voedselnood -+ voedseloverschot -+ voedseloverschotten -+ voedselpakketten -+ voedselpiramide -+ voedselprijs -+ voedselprijzen -+ voedselrest -+ voedselresten -+ voedselrijk -+ voedselrijke -+ voedseltekort -+ voedseltekorten -+ voedseltransporten -+ voedselveiligheid -+ voedselverwerkend -+ voedselverwerkende -+ voedselvlucht -+ voedselvluchten -+ voedselvoorraden -+ voegers -+ voeglijn -+ voeglijnen -+ voegsel -+ voermannen -+ voetbalavond -+ voetbalbeker -+ voetbalbond -+ voetbalbonden -+ voetbalelftal -+ voetbalelftallen -+ voetbalgeweld -+ voetbalinterland -+ voetbalinternational -+ voetbalknie -+ voetbalknietje -+ voetbalknieën -+ voetballerij -+ voetballers -+ voetballertje -+ voetballiga -+ voetbalmakelaar -+ voetbalmiljonair -+ voetbalpas -+ voetbalploeg -+ voetbalploegen -+ voetbalpools -+ voetbalprof -+ voetbalprofs -+ voetbalpronostiek -+ voetbalpronostieken -+ voetbalsport -+ voetbalstadions -+ voetbalsterren -+ voetbalsupporter -+ voetbaltas -+ voetbalterm -+ voetbaltermen -+ voetbaltoernooi -+ voetbaltoernooien -+ voetbaltoto -+ voetbalvandaal -+ voetbalverenigingen -+ voetbed -+ voetbedden -+ voetbeentje -+ voetbeentjes -+ voetbesturing -+ voetbewegingen -+ voetenbad -+ voetenbaden -+ voeteneindes -+ voetenwerk -+ voetfout -+ voetfouten -+ voetgangersbrug -+ voetgangersbruggen -+ voetgangersdomein -+ voetgangerslicht -+ voetgangerslichten -+ voetgangerstunnel -+ voetgangerstunnels -+ voetgangerstunneltje -+ voetiaan -+ voetianen -+ voetjegevrijd -+ voetjevrijen -+ voetmassage -+ voetoverheveling -+ voetpedaal -+ voetstand -+ voetstanden -+ voetsteun -+ voetsteunen -+ voettitel -+ voettitels -+ voettochten -+ voetveer -+ voetveren -+ vof -+ vogelaarsstok -+ vogelasiel -+ vogelasielen -+ vogelbekken -+ vogelbeschermer -+ vogelbeschermers -+ vogelei -+ vogeleieren -+ vogelgekwetter -+ vogelgeluid -+ vogelgeluiden -+ vogelgezang -+ vogelhandelaar -+ vogelkenner -+ vogelkenners -+ vogelkooitje -+ vogelkoppen -+ vogelliefhebber -+ vogelliefhebbers -+ vogelmuur -+ vogelpak -+ vogelpark -+ vogelpest -+ vogelpoel -+ vogelreservaat -+ vogelrijk -+ vogelrijke -+ vogelsoort -+ vogelsoorten -+ vogelsterfte -+ vogeltjesmarkt -+ vogeltjesmarkten -+ vogelveer -+ vogelveren -+ vogelvluchtperspectief -+ vogelwacht -+ vogelwachter -+ vogelwachters -+ voice-over -+ voice-overs -+ voicemail -+ voiture -+ voitures -+ voituurtje -+ voj -+ voj-scholen -+ voj-school -+ voldoeningen -+ volgapparatuur -+ volgbod -+ volgboten -+ volgebouwde -+ volgegeten -+ volgeluld -+ volgepompt -+ volgepraat -+ volgestroomd -+ volgetankt -+ volgevreten -+ volgezogen -+ volgordebepaling -+ volgstations -+ volhardend -+ volhouders -+ volièrevogels -+ volkenmoorden -+ volkenrechtgeleerde -+ volkerengemeenschap -+ volkerenmoorden -+ volkerenorganisatie -+ volkoren -+ volkorenbroden -+ volksaandeel -+ volksaandelen -+ volksarmee -+ volksballade -+ volksballaden -+ volksballades -+ volksbedrog -+ volkscommune -+ volkscommunes -+ volkscongres -+ volkscongressen -+ volksdansfeest -+ volksdansgroep -+ volksdanste -+ volksdemocratisch -+ volksdemocratische -+ volkseigen -+ volksgemeenschap -+ volksgemeenschappen -+ volksgericht -+ volksgerichte -+ volksgerichten -+ volksgevoel -+ volksgezondheidsbelang -+ volksgezondheidsbeleid -+ volksheerschappij -+ volksheld -+ volkshelden -+ volkshuishouding -+ volkshuisvester -+ volkshuisvesters -+ volkshuisvestingsbeleid -+ volkshuisvestingsplan -+ volksinitiatief -+ volksinvloed -+ volkskerk -+ volkskracht -+ volkskredietbanken -+ volksliteratuur -+ volksmacht -+ volksmassa's -+ volksmennerij -+ volksmilities -+ volksoorlog -+ volksopvoeding -+ volkspark -+ volkspetitionnement -+ volksraad -+ volksraadpleging -+ volksraadplegingen -+ volksraden -+ volksrechtbank -+ volksreferendum -+ volksrepubliek -+ volksrepublieken -+ volksschrijver -+ volksschrijvers -+ volkssoevereiniteit -+ volkssport -+ volkssporten -+ volkssprookjes -+ volkstribunaal -+ volkstuincomplex -+ volkstuinder -+ volkstuinders -+ volkstuinen -+ volksuniversiteiten -+ volksverbeelding -+ volksverhuizingstijd -+ volksverrader -+ volksverraders -+ volksvertegenwoordigster -+ volksvertelling -+ volksvertellingen -+ volksvijandig -+ volksvijandige -+ volksvlijt -+ volksvoorlichting -+ volksvreemd -+ volksvreemde -+ volksvrouwen -+ volkswijk -+ volkswijken -+ volkswijsheden -+ volkswoning -+ volkswoningbouw -+ volkswoningen -+ volkszangers -+ volladen -+ volledigheidsdrang -+ volleybalbond -+ volleybalcoach -+ volleybalcoaches -+ volleybalcompetitie -+ volleybalfinale -+ volleybalinternational -+ volleybalinternationals -+ volleyballer -+ volleyballers -+ volleybalploeg -+ volleybalploegen -+ volleybalster -+ volleybalsters -+ volleybalt -+ volleybalteam -+ volleybalteams -+ volleyde -+ volleyt -+ vollullen -+ volmatroos -+ volmatrozen -+ volpension -+ volpraten -+ volschrijven -+ volslank -+ volslanke -+ volstromen -+ volta's -+ voltanken -+ voltapijt -+ voltiges -+ voltijdbaan -+ voltijdbanen -+ voltijder -+ voltijders -+ voltijds -+ voltijdse -+ voltijdstudent -+ voltijdstudenten -+ voltijdwerker -+ voltijdwerkers -+ volumebeleid -+ volumebeperkend -+ volumebeperkende -+ volumebeperking -+ volumebeperkingen -+ volumeknoppen -+ volumevermindering -+ voluntaire -+ voluntariaat -+ voluntaristische -+ volvoering -+ volvreten -+ volwassenendoop -+ volwassenwording -+ volzet -+ volzette -+ volzuigen -+ vonkenregens -+ voodoo-economie -+ voogdijinstantie -+ voogdijinstanties -+ voogdijinstellingen -+ voogdijminister -+ voogdijoverheid -+ voogdijverenigingen -+ voor-Grieks -+ voor-Griekse -+ vooraangemeld -+ vooraankondiging -+ vooraankondigingen -+ vooraanmelden -+ vooraanmelding -+ vooraanmeldingen -+ voorafgaandelijk -+ voorafjes -+ voorafschaduwing -+ voorafschaduwingen -+ vooraftrek -+ vooraleerst -+ voorbakken -+ voorbank -+ voorbanken -+ voorbeden -+ voorbedes -+ voorbeeldproject -+ voorbeeldprojecten -+ voorbeeldrol -+ voorbeeldwerking -+ voorbeeldzinnetje -+ voorbehandelingen -+ voorbereider -+ voorbereiders -+ voorbereidingsfasen -+ voorbereidingsfases -+ voorbereidingsperiode -+ voorbeschouwingen -+ voorbespeeld -+ voorbeurs -+ voorbezichtiging -+ voorbijflitsen -+ voorbijgeflitst -+ voorbijgestoken -+ voorbijsteken -+ voorblad -+ voorboren -+ voorbumpers -+ voorcalculaties -+ voordeelurenkaart -+ voordeelurenkaarten -+ voordeurbel -+ voordeurbellen -+ voordeursleutel -+ voordoek -+ voordrachtskunst -+ voordrachtwedstrijd -+ voordrachtwedstrijden -+ voordrukken -+ voorexamen -+ voorexamens -+ voorfase -+ voorfilm -+ voorfilms -+ voorflap -+ voorflappen -+ voorgebakken -+ voorgefabriceerd -+ voorgefabriceerde -+ voorgeselecteerd -+ voorgesprek -+ voorgezuiverd -+ voorhechtenis -+ voorhoedefunctie -+ voorhoedepositie -+ voorhoederol -+ voorhoofdsholten -+ voorhoofdsholtes -+ voorhuwelijks -+ voorhuwelijkse -+ voorhuwelijkssparen -+ voorjaarsachtig -+ voorjaarsachtige -+ voorjaarsklassieker -+ voorjaarsklassiekers -+ voorjaarsnota's -+ voorjaarsoverleg -+ voorjaarsschoonmaak -+ voorjaarszon -+ voorjaarszonnetje -+ voorkamertje -+ voorkeursbehandelingen -+ voorkeurspellingen -+ voorkeurspositie -+ voorkeurtoetsen -+ voorkoken -+ voorkwalificatie -+ voorkwalificaties -+ voorleesavond -+ voorleesavonden -+ voorleesdag -+ voorleven -+ voorlichtingsambtenaar -+ voorlichtingsambtenaren -+ voorlichtingsapparaat -+ voorlichtingsboek -+ voorlichtingsboekje -+ voorlichtingsbrochure -+ voorlichtingsbureaus -+ voorlichtingscampagne -+ voorlichtingscampagnes -+ voorlichtingsfilmpje -+ voorlichtingsfolder -+ voorlichtingsfolders -+ voorloopster -+ voorloopsters -+ voorlopigheid -+ vooronderzoeker -+ voorontstekingen -+ vooropening -+ vooropeningen -+ vooropgestaan -+ vooropstaan -+ vooropstellingen -+ vooropzeg -+ vooropzegging -+ voorouderbeeld -+ voorouderbeelden -+ vooroudergeest -+ vooroudergeesten -+ voorouderverering -+ voorpagina's -+ voorpagina-artikel -+ voorpaginabericht -+ voorplan -+ voorplannen -+ voorplat -+ voorpremières -+ voorprogramma's -+ voorprogrammeren -+ voorpubliciteit -+ voorraadkasten -+ voorraadkelder -+ voorraadkelders -+ voorraadwinst -+ voorraadwinsten -+ voorrangskruisingen -+ voorrangsregeling -+ voorrangsregels -+ voorrevolutionair -+ voorrevolutionaire -+ voorrijkosten -+ voorronden -+ voorschools -+ voorschoolse -+ voorschotfaciliteit -+ voorschotrente -+ voorschrijfgedrag -+ voorschrijver -+ voorschrijvers -+ voorselecteren -+ voorselecties -+ voorsluitingen -+ voorsmaakje -+ voorsorteerstroken -+ voorspanning -+ voorstadia -+ voorstedelijk -+ voorstedelijke -+ voorstellingswereld -+ voorstellingswerelden -+ voorstoppers -+ voortboeren -+ voortentamens -+ voortentamina -+ voortgangsrapportages -+ voortgeboerd -+ voortgebouwd -+ voortgegleden -+ voortgehold -+ voortgeijld -+ voortgejaagd -+ voortgejakkerd -+ voortgekabbeld -+ voortgemodderd -+ voortgeraasd -+ voortgeredeneerd -+ voortgerold -+ voortgesneld -+ voortgestapt -+ voortgesudderd -+ voortgewoed -+ voortgezeuld -+ voortglijden -+ voorthollen -+ voortijlen -+ voortjagen -+ voortjakkeren -+ voortkabbelen -+ voortmodderen -+ voortplantingscel -+ voortplantingssnelheid -+ voortplantingstechniek -+ voortplantingsvermogen -+ voortrazen -+ voortredeneren -+ voortreffelijkheden -+ voortrekkersfunctie -+ voortrollen -+ voortsnellen -+ voortstappen -+ voortsudderen -+ voortverkocht -+ voortverkopen -+ voortvloeisels -+ voortvluchtigheid -+ voortwoeden -+ voortzeulen -+ vooruitbetaald -+ vooruitgangsdenken -+ vooruitgangsgeloof -+ vooruitgangsideaal -+ vooruitgangsideologie -+ vooruitgangsoptimisme -+ vooruitgangspartij -+ vooruitgeblikt -+ vooruitgedacht -+ vooruitgekeken -+ vooruitgeschoven -+ vooruitgeworpen -+ vooruitstrevendheid -+ vooruitwerpen -+ vooruitwijzing -+ vooruitziendheid -+ voorvak -+ voorvakken -+ voorverkiezingen -+ voorverkocht -+ voorvertonen -+ voorvertoning -+ voorvertoond -+ voorverwarmd -+ voorvrouw -+ voorvrouwen -+ voorwaardenscheppend -+ voorwaardenscheppende -+ voorwas -+ voorwerpglaasje -+ voorwerpglas -+ voorwerpglazen -+ voorwetenschap -+ voorzetselbepaling -+ voorzetselbepalingen -+ voorzetselvoorwerp -+ voorzetselvoorwerpen -+ voorzieningenniveau -+ voorzieningenpakket -+ voorzieningenpakketten -+ voorzieningszekerheid -+ voorzitter-directeur -+ voorzitters-directeuren -+ voorzittersduo -+ voorzorgprincipe -+ voorzorgsprincipe -+ voorzuiveren -+ voosde -+ vopo's -+ vormbeheersing -+ vormbehoud -+ vormcrisis -+ vormeis -+ vormeisen -+ vormgeheugen -+ vormgevingsbeleid -+ vormgevoel -+ vormingsactiviteit -+ vormingsactiviteiten -+ vormingscursussen -+ vormingsinstituten -+ vormingsklas -+ vormingsklassen -+ vormingsproces -+ vormingstoneel -+ vormvariant -+ vormvarianten -+ vormvaste -+ vormverscheidenheid -+ vorser -+ vorsers -+ vorstenpaar -+ vorstgevoelig -+ vorstgevoelige -+ vorstkam -+ vorstkammen -+ vos-cursus -+ vos-cursussen -+ vos-scholen -+ vos-school -+ voscursus -+ voscursussen -+ vosscholen -+ vosschool -+ vossenbes -+ vossenbessen -+ vossenjachten -+ vouchers -+ vouchersysteem -+ vouwcaravan -+ vouwcaravans -+ vouwdaken -+ vouwfietsen -+ vouwkano -+ vouwmeter -+ vouwmeters -+ vouwstoeltje -+ vouwwagen -+ vouwwagens -+ vouwwand -+ vouwwanden -+ voyeuristische -+ voyeurs -+ voyeurtje -+ vp -+ vp's -+ vraag-en-antwoordspel -+ vraagcurven -+ vraagcurves -+ vraagpuntennota -+ vraaguitval -+ vraatziekte -+ vrachtautochauffeur -+ vrachtautochauffeurs -+ vrachtovereenkomsten -+ vrachtruimte -+ vrachttarieven -+ vrachtvervoerder -+ vrachtvervoerders -+ vrachtvliegtuigen -+ vrachtvluchten -+ vrachtwagenonderdeel -+ vrachtwagenonderdelen -+ vrachtwagenrijbewijs -+ vrachtwagenrijbewijzen -+ vrachtwagenverkeer -+ vrachtwagenvignet -+ vragenrubriek -+ vragensteller -+ vredehandhaving -+ vredesactie -+ vredesactivist -+ vredesactivisten -+ vredesafdwingend -+ vredesafdwingende -+ vredesakkoord -+ vredesberaad -+ vredesbespreking -+ vredesbewegingen -+ vredesdemonstraties -+ vredesdividend -+ vredeshandhavend -+ vredeshandhavende -+ vredeshandhaving -+ vredesinitiatief -+ vredesinitiatieven -+ vredesinspanning -+ vredesinspanningen -+ vredeskamp -+ vredesmachten -+ vredesoffensief -+ vredesoffensieven -+ vredesoperatie -+ vredesoperaties -+ vredesoverleg -+ vredespact -+ vredespartij -+ vredesplan -+ vredesplannen -+ vredespoging -+ vredespogingen -+ vredespolitiek -+ vredesprijs -+ vredesprijzen -+ vredesregeling -+ vredesteken -+ vredestekenen -+ vredestekens -+ vredestraktaten -+ vredeswil -+ vredevorst -+ vredevorsten -+ vredigheid -+ vreemdelingenangst -+ vreemdelingenbegeleider -+ vreemdelingenbegeleiders -+ vreemdelingenbureau -+ vreemdelingenbureaus -+ vreemdelingenheerschappij -+ vreemdelingenrecht -+ vreemdelingenregister -+ vreemdelingenregisters -+ vreemdelingenwetten -+ vreemdelingschap -+ vreemdetalenonderwijs -+ vreemdgaan -+ vreemdgegaan -+ vreemdtalig -+ vreemdtalige -+ vreetzakken -+ vreugd -+ vreugdedans -+ vreugdedansen -+ vreugdes -+ vriendenclub -+ vriendenmatch -+ vriendenmatchen -+ vriendenpaar -+ vriendenparen -+ vriendenploeg -+ vriendenprijsjes -+ vriendschappelijkheden -+ vriendschapsverdrag -+ vriendschapsverdragen -+ vriesdroogde -+ vrieslucht -+ vriesnacht -+ vriesnachten -+ vriesruimten -+ vriesvakken -+ vrijblijvendheden -+ vrijdaggebed -+ vrijdaggebeden -+ vrijdagmiddagen -+ vrijdagsgebed -+ vrijdagsgebeden -+ vrijden -+ vrijdenkend -+ vrijdenkende -+ vrijekeuzeruimte -+ vrijeluchtinspectie -+ vrijemarktkapitalisme -+ vrijemarktprincipe -+ vrijemarktsector -+ vrijerig -+ vrijerige -+ vrijetijdsactiviteit -+ vrijetijdsactiviteiten -+ vrijetijdsbestedingen -+ vrijetijdsgedrag -+ vrijetijdsindustrie -+ vrijetijdskleding -+ vrijetijdswetenschappen -+ vrijetrappenspecialist -+ vrijgeborenen -+ vrijgevochtenheid -+ vrijgezellenavonden -+ vrijgezellenbestaan -+ vrijgezellenflats -+ vrijhandelsassociatie -+ vrijhandelsassociaties -+ vrijhandelsgebieden -+ vrijhandelsovereenkomst -+ vrijhandelsverdrag -+ vrijhandelszones -+ vrijheidsbeginsel -+ vrijheidsbeweging -+ vrijheidsbewegingen -+ vrijheidsdrang -+ vrijheidsheld -+ vrijheidshelden -+ vrijheidsideaal -+ vrijheidsidealen -+ vrijheidslievend -+ vrijheidslievende -+ vrijheidsstreven -+ vrijheidsstrijd -+ vrijkous -+ vrijkousen -+ vrijpartij -+ vrijpartijen -+ vrijpartijtje -+ vrijpion -+ vrijpionnen -+ vrijpostigheden -+ vrijschop -+ vrijschoppen -+ vrijscène -+ vrijstellingsregeling -+ vrijthoven -+ vrijwilligerskrijgsmacht -+ vrijwilligersorganisatie -+ vrijzinnig-democratisch -+ vrijzinnig-democratische -+ vroegchristelijk -+ vroegchristelijke -+ vroeggeboorte -+ vroegmiddeleeuws -+ vroegmiddeleeuwse -+ vroegneolithisch -+ vroegneolithische -+ vroegrenaissance -+ vrolijke frans -+ vrouw-zijn -+ vrouwbeeld -+ vrouwen-wc -+ vrouwen-wc's -+ vrouwenberoep -+ vrouwenberoepen -+ vrouwenbesnijdenis -+ vrouwenblad -+ vrouwenbladen -+ vrouwenboek -+ vrouwenboeken -+ vrouwenborst -+ vrouwenborsten -+ vrouwencafé -+ vrouwencafés -+ vrouwencondoom -+ vrouwendiscriminatie -+ vrouwendubbel -+ vrouwendubbelspel -+ vrouwenenkelspel -+ vrouwengeschiedenis -+ vrouwengeschiedenissen -+ vrouwengevangenis -+ vrouwengroep -+ vrouwenhart -+ vrouwenharten -+ vrouwenhockeyploeg -+ vrouwenhockeyteam -+ vrouwenhuizen -+ vrouwenjagers -+ vrouwenkamp -+ vrouwenkampen -+ vrouwenkliniek -+ vrouwenkoor -+ vrouwenkoren -+ vrouwenkwaal -+ vrouwenkwalen -+ vrouwenkwestie -+ vrouwenliteratuur -+ vrouwenmantel -+ vrouwenmishandeling -+ vrouwenogen -+ vrouwenonderdrukking -+ vrouwenoog -+ vrouwenorganisatie -+ vrouwenpaar -+ vrouwenpagina -+ vrouwenpagina's -+ vrouwenportret -+ vrouwenportretten -+ vrouwenpraatgroep -+ vrouwenpraatgroepen -+ vrouwensport -+ vrouwenstrijd -+ vrouwenstudie -+ vrouwentaal -+ vrouwenvakscholen -+ vrouwenvakschool -+ vrouwenverleider -+ vrouwenverslinder -+ vrouwenverslinders -+ vrouwenvlees -+ vrouwenvoetbal -+ vrouwenvolleybalploeg -+ vrouwenvolleybalteam -+ vrouwtjesdier -+ vrouwtjesdieren -+ vrouwvijandig -+ vrouwvijandige -+ vruchtafdrijvend -+ vruchtafdrijvende -+ vruchtbaarheidsbehandeling -+ vruchtbaarheidsbehandelingen -+ vruchtbaarheidscijfer -+ vruchtbaarheidscijfers -+ vruchtbaarheidsculten -+ vruchtbaarheidscultus -+ vruchtbaarheidsgodin -+ vruchtbaarheidsgodinnen -+ vruchtbaarheidskliniek -+ vruchtbaarheidsrite -+ vruchtbaarheidsriten -+ vruchtbaarheidsrites -+ vruchtboompje -+ vruchtenbrandewijn -+ vruchtendranken -+ vruchtenpersen -+ vruchtensalade -+ vruchtensuiker -+ vruchtgebruikregeling -+ vruchtlichaam -+ vruchtvlies -+ vruchtvliezen -+ vruchtwand -+ vruchtwanden -+ vruchtwaterpuncties -+ vruchtzetting -+ vuilafvoer -+ vuilcontainer -+ vuilcontainers -+ vuilnisauto's -+ vuilnisdienst -+ vuilnisemmers -+ vuilniskoker -+ vuilniskokers -+ vuilnisstort -+ vuilnisstorten -+ vuilnisvat -+ vuilnisvaten -+ vuilophaal -+ vuilophaler -+ vuilophalers -+ vuilschrijverij -+ vuilspuiter -+ vuilspuiterij -+ vuilspuiters -+ vuilstort -+ vuilstortplaats -+ vuilstortplaatsen -+ vuilverbrandingsinstallatie -+ vuilverbrandingsinstallaties -+ vuilverbrandingsovens -+ vuilverwerkingsbedrijf -+ vuilwaterpomp -+ vuilwaterpompen -+ vuilwit -+ vuilwitte -+ vuilzak -+ vuilzakken -+ vuistbijl -+ vuistbijlen -+ vuistgroot -+ vuistgrote -+ vuisthamer -+ vuisthamers -+ vuldoppen -+ vuldruk -+ vulgarisering -+ vulgarismen -+ vulkaanas -+ vulkaaneiland -+ vulkaankrater -+ vulkaanlandschap -+ vulkaanlandschappen -+ vulkaanuitbarsting -+ vulkaanuitbarstingen -+ vulkanologen -+ vulkanologie -+ vulkanologische -+ vullichaam -+ vullichamen -+ vulmateriaal -+ vulopening -+ vulopeningen -+ vulpasta's -+ vulva's -+ vuriglijke -+ vutte -+ vutten -+ vuurballen -+ vuurcontacten -+ vuurdekking -+ vuurdoorns -+ vuurdoren -+ vuurdorens -+ vuurgeest -+ vuurgeesten -+ vuurgeleidingssysteem -+ vuurgevaarlijk -+ vuurgevaarlijke -+ vuurkorf -+ vuurkorven -+ vuurkruis -+ vuurkruiser -+ vuurkruisers -+ vuurmuren -+ vuurmuur -+ vuurpelotons -+ vuursalamander -+ vuursalamanders -+ vuursein -+ vuurseinen -+ vuurspuwer -+ vuurspuwers -+ vuurstoot -+ vuurstoten -+ vuurtang -+ vuurtangen -+ vuurtorentje -+ vuurvliegje -+ vuurvliegjes -+ vuurwapenbezit -+ vuurwapengebruik -+ vuurwapengevaarlijk -+ vuurwapengevaarlijke -+ vuurwapenopleiding -+ vuurwapenwet -+ vuurwapenwetten -+ vuurwerkbom -+ vuurwerkbommen -+ vuurwerkfabriek -+ vwo'er -+ vwo-diploma -+ vwo-leerling -+ vwo-leerlingen -+ vwo-opleiding -+ vwo-school -+ vzw -+ w's -+ w'tje -+ w.v.t.t.k. -+ wa-aleikum as-salam -+ waaiergewelf -+ waaiergewelven -+ waaierigheid -+ waaierrijden -+ waakhondfunctie -+ waaktoestand -+ waal -+ waanbeelden -+ waanidee -+ waanideeën -+ waanwereld -+ waanwerelden -+ waanzinscène -+ waarborgmaatschappij -+ waarborgstaat -+ waardebons -+ waardecoupon -+ waardecoupons -+ waardeklasse -+ waardeklassen -+ waarderingsgrondslag -+ waarderingsgrondslagen -+ waarderingsverschil -+ waarderingsverschillen -+ waardeverandering -+ waardeveranderingen -+ waardeverlies -+ waardevolst -+ waardplant -+ waarheidscommissie -+ waarheidscommissies -+ waarnemersgroep -+ waarnemersmacht -+ waarnemersmissie -+ waarnemersmissies -+ waarnemersstatus -+ waarnemersteam -+ waarnemingsmateriaal -+ waarnemingsomstandigheden -+ waarnemingsreeks -+ waarnemingsreeksen -+ waarnemingsscherpte -+ waarnemingstechniek -+ waarnemingstijd -+ waarnemingsveld -+ waarnemingsvelden -+ waaromvraag -+ waaromvragen -+ waarschuwingscommando's -+ waarschuwingslamp -+ waarschuwingssignalen -+ waarschuwingsstaking -+ waarschuwingsstakingen -+ waarschuwingsteken -+ waarschuwingstekens -+ wablief -+ wachtcommandanten -+ wachtgelduitgaven -+ wachtgelduitkering -+ wachtgeldverzekering -+ wachthokjes -+ wachtkamertje -+ wachtlokalen -+ wachtstand -+ wachtverbod -+ wachtzaal -+ wachtzalen -+ waddengebied -+ waddengebieden -+ wadi's -+ wadlopen -+ wadloper -+ wadlopers -+ wadplaat -+ wadplaten -+ wadvaarder -+ wadvaarders -+ wadvogel -+ wadvogels -+ waf -+ wafelijzerpolitiek -+ waffels -+ wagenbakken -+ wagenbegeleider -+ wagenbegeleiders -+ wagenloodsen -+ wagenmakerijen -+ wagenspel -+ wagenspelen -+ wagenveer -+ wagenveren -+ wagenwiel -+ wagenwielen -+ wagneriaans -+ wagneriaanse -+ wahabiet -+ wahabieten -+ wahabisme -+ wahabitisch -+ wahabitische -+ wakaman -+ wakamans -+ waldkornbrood -+ waldorfsalade -+ waldorfsalades -+ walen -+ walhalla's -+ walk-overs -+ walpersoneel -+ walrecht -+ walsmuziek -+ walvisjacht -+ wandbeen -+ wandbeenderen -+ wandbeentje -+ wandbenen -+ wandborden -+ wanddecoratie -+ wandelmarsen -+ wandelpark -+ wandelpassen -+ wandelwagens -+ wandkluizen -+ wandlampen -+ wandmodel -+ wandmodellen -+ wandschroot -+ wandschroten -+ wandsculpturen -+ wandsculptuur -+ wanhoopsactie -+ wanhoopsgebaar -+ wanhoopsgebaren -+ wanhoopsoffensief -+ wankelmotor -+ wankelmotoren -+ wankelmotors -+ wanmand -+ wanpraktijken -+ wapenbeheersingsbespreking -+ wapenbeheersingsbesprekingen -+ wapenboycot -+ wapendracht -+ wapenembargo's -+ wapenexportbeleid -+ wapenfiguren -+ wapenfiguur -+ wapenhuis -+ wapenhuizen -+ wapenhulp -+ wapenindustrie -+ wapenleverantie -+ wapenleveranties -+ wapenopslagplaats -+ wapenopslagplaatsen -+ wapenorder -+ wapenorders -+ wapenschouw -+ wapensmokkel -+ wapenstilstandsakkoord -+ wapenstilstandsovereenkomst -+ wapentje -+ wapenuitrusting -+ wapenvergunningen -+ wapenvermindering -+ wapenvernietiging -+ wapenwedlopen -+ wapenwinkel -+ wapenwinkels -+ warandaatje -+ warenhuisdochter -+ warenhuisketen -+ warenhuisketens -+ warenmerken -+ warenwetten -+ warhoofdig -+ warhoofdige -+ warimbo -+ warmers -+ warmhartig -+ warmhartige -+ warmhouder -+ warmhouders -+ warming-ups -+ warmte-isolatie -+ warmte-isolerend -+ warmte-isolerende -+ warmtefronten -+ warmtegeleidingen -+ warmtekrachtcentrale -+ warmtekrachtcentrales -+ warmtekrachtinstallatie -+ warmtekrachtinstallaties -+ warmtekrachtkoppeling -+ warmtepompen -+ warmteproductie -+ warmtestralers -+ warmtestraling -+ warmtestroom -+ warmtetransport -+ warmvoelend -+ warmvoelende -+ warmwalserij -+ warmwaterbron -+ warmwaterbronnen -+ warmwaterbuis -+ warmwaterbuizen -+ warmwaterkruik -+ warmwaterkruiken -+ warmwatertoestellen -+ warmwaterzak -+ warmwaterzakken -+ warongs -+ warrelige -+ wasabi -+ wasbeertje -+ wasbeitsen -+ wasbloem -+ wasbloemen -+ wascombinatie -+ wascombinaties -+ wasdraad -+ wasdraden -+ wasdrogers -+ wasemig -+ wasemige -+ wasemkappen -+ wasgelegenheden -+ washi -+ washipapier -+ wasi -+ wasi's -+ waskrijt -+ waskrijtje -+ waskrijtjes -+ waslaag -+ waslagen -+ waslappen -+ waslokaal -+ waslokalen -+ wasmachineaansluiting -+ wasmerken -+ waspapier -+ waspeen -+ waspenen -+ waspit -+ waspitten -+ wasplaats -+ wasplaatsen -+ wasprogramma's -+ wasrol -+ wasrollen -+ wasruimte -+ wasruimten -+ wasruimtes -+ wassalon -+ wassalons -+ wasseretje -+ wasserettetje -+ wassoort -+ wassoorten -+ wasspeld -+ wasspelden -+ wasstift -+ wasstiften -+ wasteilen -+ wastrommels -+ wasvoorschriften -+ waszak -+ waszakken -+ wateraanvoer -+ waterarm -+ waterarme -+ waterbaars -+ waterbaarzen -+ waterbaden -+ waterballast -+ waterballetten -+ waterbassin -+ waterbassins -+ waterbedeling -+ waterbedrijf -+ waterbekkens -+ waterbellen -+ waterbesparend -+ waterbesparende -+ waterbezoedeling -+ waterblaas -+ waterblazen -+ waterbouw -+ waterbouwer -+ waterbouwers -+ waterbron -+ waterbuffel -+ waterbuffels -+ watercooker -+ watercookers -+ waterdiepte -+ waterdiepten -+ waterdieptes -+ waterdiertje -+ waterdroppeltje -+ waterdruppeltje -+ waterfietste -+ watergangen -+ watergebied -+ watergebieden -+ watergebruik -+ watergehalte -+ watergladheid -+ waterglijbaan -+ waterglijbanen -+ watergraaf -+ waterhoenen -+ waterhoentje -+ waterhoogten -+ waterhoogtes -+ waterinsecten -+ waterkaart -+ waterkaarten -+ waterkans -+ waterkansen -+ waterkever -+ waterkevers -+ waterklerk -+ waterklerken -+ waterkoker -+ waterkokers -+ waterkraantje -+ waterkwaliteit -+ waterkwaliteitsbeheerder -+ waterlaag -+ waterlagen -+ waterleidingduinen -+ waterleidingnet -+ waterleidingsbedrijf -+ waterleidingsysteem -+ waterleven -+ waterloo -+ waterloopkundige -+ watermanagement -+ watermassa -+ watermassa's -+ watermeter -+ watermeters -+ watermonsters -+ waternet -+ waternevels -+ waternimf -+ waternimfen -+ waterniveau -+ waterontharding -+ wateroppervlakken -+ wateroppervlakten -+ wateroppervlaktes -+ waterorgel -+ waterorgels -+ waterpistolen -+ waterpoelen -+ waterpoloploeg -+ waterpoloster -+ waterpolosters -+ waterpoloteam -+ waterpoloër -+ waterpoloërs -+ waterpomptangen -+ waterpret -+ waterral -+ waterrallen -+ waterranonkel -+ waterrecreatie -+ watersalamander -+ watersalamanders -+ waterschildpad -+ waterschildpadden -+ waterscooter -+ waterscooters -+ waterskiede -+ waterskieden -+ waterskiet -+ waterskiërs -+ waterslak -+ waterslakken -+ waterspoor -+ watersportcentrum -+ watersporten -+ watersportgebied -+ watersportgebieden -+ watersportvereniging -+ watersportverenigingen -+ waterspuiten -+ waterstaatkundig -+ waterstaatkundige -+ waterstofatomen -+ waterstofatoom -+ waterstofkern -+ waterstofkernen -+ waterstofsulfide -+ waterstofsuperoxide -+ waterstromen -+ waterstroompje -+ watertaxi's -+ watertekort -+ watertekorten -+ watertemperaturen -+ watertoerist -+ watertoeristen -+ watertoevoer -+ watertransportmaatschappij -+ watertrappelen -+ watertrappen -+ watervalletje -+ waterverfschilderijen -+ waterverftekeningen -+ watervlakken -+ watervlakte -+ watervlakten -+ watervlaktes -+ watervlekken -+ watervlug -+ watervlugge -+ watervoorraad -+ watervoorraden -+ waterwerpers -+ waterwilg -+ waterwilgen -+ waterwinbedrijf -+ waterwingebieden -+ waterwinning -+ waterwinningbedrijf -+ waterwinningsbedrijf -+ waterwinplaatsen -+ waterzuivering -+ waterzuiveringsstation -+ waterzuiveringsstations -+ waterzuiveringstablet -+ waterzuiveringstabletten -+ wattenstaafjes -+ wattseconde -+ wattseconden -+ wave -+ waves -+ waxcoat -+ waxcoats -+ waxine -+ waxinelichtjes -+ wc-borstel -+ wc-borstels -+ wc-bril -+ wc-brillen -+ wc-deur -+ wc-deuren -+ wc-papier -+ wc-pot -+ wc-potten -+ wc-rol -+ wc-rollen -+ webbrowsers -+ webcam -+ webcams -+ webdesign -+ webdesigner -+ webdesigners -+ webfora -+ webforum -+ webforums -+ weblog -+ weblogs -+ webmagazine -+ webmagazines -+ webmail -+ webmarketeer -+ webmarketeers -+ webmasters -+ webserver -+ webservers -+ websitebouwer -+ websitebouwers -+ webstek -+ webstekken -+ websteks -+ websurfen -+ websurfte -+ webzine -+ webzines -+ weckflessen -+ weckpotten -+ weddes -+ weddeschaal -+ weddeschalen -+ weddetrekkende -+ weddetrekkenden -+ wederga -+ wedergeboortes -+ wederinvoering -+ wederkerigheidsbeginsel -+ wederopbloei -+ wederopbouwperiode -+ wederopleving -+ wederoproeping -+ wederoptreden -+ wederoptredens -+ wedersamenstelling -+ wederuitgave -+ wederuitzending -+ wedkantoor -+ wedkantoren -+ wedstrijdbaan -+ wedstrijdbanen -+ wedstrijdbeker -+ wedstrijdbekers -+ wedstrijdcommissaris -+ wedstrijdcommissarissen -+ wedstrijdenreeks -+ wedstrijdervaring -+ wedstrijdkalender -+ wedstrijdleider -+ wedstrijdleiding -+ wedstrijdloper -+ wedstrijdlopers -+ wedstrijdmakelaar -+ wedstrijdorganisatie -+ wedstrijdpaard -+ wedstrijdpaarden -+ wedstrijdprogramma -+ wedstrijdpunt -+ wedstrijdpunten -+ wedstrijdreglement -+ wedstrijdrijder -+ wedstrijdrijders -+ wedstrijdritme -+ wedstrijdroeien -+ wedstrijdschema -+ wedstrijdschema's -+ wedstrijdsecretaris -+ wedstrijdspeler -+ wedstrijdspelers -+ wedstrijdsporten -+ wedstrijdvaren -+ wedstrijdverslag -+ wedstrijdzeilen -+ wedstrijdzwemmer -+ wedstrijdzwemmers -+ weduwefondsen -+ weduwepensioenen -+ weduwes -+ weduwnaarspensioen -+ weduwnaarspensioenen -+ weeffout -+ weeffouten -+ weeflijn -+ weefselkenmerk -+ weefselkenmerken -+ weefselstructuren -+ weefselstructuur -+ weefselvocht -+ weefspoelen -+ weegapparatuur -+ weegbaar -+ weegbare -+ weekbladpers -+ weekeindes -+ weekenders -+ weekendhuwelijken -+ weekendtassen -+ weekendverblijf -+ weekendverlof -+ weekijzer -+ weekkalender -+ weekkalenders -+ weekmaker -+ weekmakers -+ weektaak -+ weekwater -+ weemakend -+ weemakende -+ weeral -+ weerballonnen -+ weerballons -+ weerbestendige -+ weergod -+ weergoden -+ weerkorpsen -+ weerlegbare -+ weermannen -+ weerpraatjes -+ weerrapporten -+ weersatellieten -+ weersinformatie -+ weerstandsbeweging -+ weerstandsgrens -+ weerstandsniveau -+ weerstandspunt -+ weerstandspunten -+ weersvoorspellingen -+ weersvooruitzichten -+ weertype -+ weertypen -+ weertypes -+ weervinden -+ weerzinwekkendheid -+ weeë -+ wegaanduidingen -+ wegaanleg -+ wegaansluitingen -+ wegbarricade -+ wegbarricades -+ wegbebakening -+ wegbeheerders -+ wegbezuinigd -+ wegbezuinigen -+ wegblokkade -+ wegblokkades -+ wegbombarderen -+ wegcode -+ wegcodes -+ wegconcurreren -+ wegdeemsteren -+ wegdistel -+ wegdistels -+ wegdrummen -+ wegenbouwbedrijf -+ wegenbouwer -+ wegenbouwers -+ wegenbouwkundige -+ wegenbouwmachine -+ wegenbouwmachines -+ wegenbouwpoot -+ wegenbouwproject -+ wegenbouwprojecten -+ wegenhulp -+ wegenkaarten -+ wegenplan -+ wegenplannen -+ wegenplans -+ wegfrommelen -+ weggebombardeerd -+ weggeconcurreerd -+ weggedeeltes -+ weggedeemsterd -+ weggedrag -+ weggedroomd -+ weggedrumd -+ weggeefprijs -+ weggeefprijzen -+ weggefrommeld -+ weggeglipt -+ weggegomd -+ weggehoond -+ weggekaapt -+ weggekapt -+ weggelachen -+ weggeritst -+ weggesaneerd -+ weggescheurd -+ weggesijpeld -+ weggeslonken -+ weggestoven -+ weggeteerd -+ weggetikt -+ weggetoverd -+ weggevertje -+ weggevertjes -+ weggevreten -+ weggewassen -+ weggewimpeld -+ weggezapt -+ weggezuiverd -+ wegglippen -+ weggommen -+ weggooiartikel -+ weggooiartikelen -+ weghakken -+ weghonen -+ wegingen -+ wegkampioenen -+ wegkapitein -+ wegkappen -+ weglachen -+ wegloophuizen -+ wegmarkeringen -+ wegrace -+ wegraces -+ wegrestaurants -+ wegreus -+ wegreuzen -+ wegritsen -+ wegsaneren -+ wegscheuren -+ wegseizoenen -+ wegsijpelen -+ wegslinken -+ wegsplitsingen -+ wegstuiven -+ wegteren -+ wegtikken -+ wegtoveren -+ wegverbinding -+ wegversmallingen -+ wegvervoerder -+ wegvervoerders -+ wegvreten -+ wegwassen -+ wegwerkzaamheden -+ wegwerpaanstekers -+ wegwerpbarbecue -+ wegwerpbarbecues -+ wegwerpbatterij -+ wegwerpbatterijen -+ wegwerpcultuur -+ wegwerpflessen -+ wegwerpgebaar -+ wegwerpgebaren -+ wegwerpluier -+ wegwerpluiers -+ wegwerpverpakkingen -+ wegwimpelen -+ wegzappen -+ wegzendofficier -+ wegzuiveren -+ weichselien -+ weides -+ weidevogelgebied -+ weidevogelstand -+ weidsheid -+ weifelachtigheid -+ weigelia's -+ wekkerradio's -+ wektonen -+ welbehaaglijke -+ welbepaald -+ welbepaalde -+ welbeschouwde -+ weldenkendheid -+ weldoortimmerde -+ weledelgeleerd -+ welfarewerk -+ welgevuld -+ welgevulde -+ welkomstdrankje -+ welkomstgeschenk -+ welkomstwoorden -+ welles-nietesspel -+ welles-nietesspelletje -+ wellingtons -+ welomlijnd -+ welomlijnde -+ welstandsbepaling -+ welstandsbepalingen -+ welstandscommissies -+ welstandsklasse -+ welstandsklassen -+ welstandstoezicht -+ welstellend -+ welstellende -+ welteverstaan -+ welvaartsgroei -+ welvaartsstijging -+ welvaartsstijgingen -+ welvaartstheorie -+ welvaartsverschijnselen -+ welvaartsziekte -+ welvaartsziekten -+ welvaartsziektes -+ welverzorgd -+ welverzorgde -+ welzeker -+ welzijnsinstelling -+ welzijnskoepel -+ welzijnskoepels -+ welzijnsorganisatie -+ welzijnssectoren -+ welzijnssectors -+ wendbaarder -+ wendbaarst -+ wener -+ wenkbrauwpotloden -+ wenkbrauwpotlood -+ wensdenken -+ wenselijkheden -+ wensenlijst -+ wenskaart -+ wensouder -+ wensouders -+ wensvoorstelling -+ wensvoorstellingen -+ wentelwieken -+ wereldatlas -+ wereldatlassen -+ wereldbeelden -+ wereldbehoefte -+ wereldbekendheid -+ wereldbeker -+ wereldbekerfinale -+ wereldbekerklassement -+ wereldbekers -+ wereldbekertoernooi -+ wereldbewoner -+ wereldbewoners -+ wereldboom -+ wereldcentrum -+ wereldcongres -+ wereldcrisis -+ wereldcup -+ wereldcups -+ wereldeconomisch -+ wereldeconomische -+ wereldfaam -+ wereldfederatie -+ wereldgebeuren -+ wereldgeest -+ wereldhandelsakkoord -+ wereldhandelsconferentie -+ wereldhavens -+ wereldhervormer -+ wereldhervormers -+ wereldhit -+ wereldhits -+ wereldhuishouding -+ wereldindex -+ wereldinkomen -+ wereldkampioenschapsmatch -+ wereldkampioenskandidaat -+ wereldkerk -+ wereldklimaat -+ wereldklimaatverdrag -+ wereldleiderschap -+ wereldluchtvaartmarkt -+ wereldmachten -+ wereldmarktleider -+ wereldmarktniveau -+ wereldmarktprijs -+ wereldmarktprijzen -+ wereldmilieuconferentie -+ wereldmilieutop -+ wereldomspannend -+ wereldomspannende -+ wereldontvanger -+ wereldopinie -+ wereldorde -+ wereldoriëntatie -+ wereldpremières -+ wereldprimeurs -+ wereldprobleem -+ wereldproblemen -+ wereldproductie -+ wereldraadsel -+ wereldranglijsten -+ wereldrecordhouder -+ wereldrecordhouders -+ wereldrecordhoudster -+ wereldrecordtijd -+ wereldreputatie -+ wereldrijk -+ wereldrijken -+ wereldseizoentijd -+ wereldsituatie -+ wereldsnelheidsrecord -+ wereldspelen -+ wereldster -+ wereldsterren -+ wereldsuccessen -+ wereldtitelgevecht -+ wereldtitelstrijd -+ wereldtop -+ wereldtopspeler -+ wereldtopspelers -+ wereldtournee -+ wereldtournees -+ werelduurrecords -+ wereldverbeteraar -+ wereldverkenning -+ wereldvermaard -+ wereldvermaarde -+ wereldvlak -+ wereldvoedselproductie -+ wereldvoedselsituatie -+ wereldvoedselvoorziening -+ wereldvoorraad -+ wereldvoorraden -+ wereldvreemdheid -+ wereldwijsheid -+ werfleider -+ werfleiders -+ werfreserve -+ werkaanbieding -+ werkafspraak -+ werkafspraken -+ werkbeurs -+ werkbeurzen -+ werkbladen -+ werkbriefjes -+ werkbroek -+ werkbroeken -+ werkcoupés -+ werkdiner -+ werkdiscipline -+ werkdocument -+ werkdocumenten -+ werkdrift -+ werkeenheid -+ werkelijkheidsbesef -+ werkelijkheidsgehalte -+ werkelijkheidswaarde -+ werkeloosheidsverzekeringen -+ werkervaringsplaats -+ werkervaringsplaatsen -+ werkervaringsproject -+ werkervaringsprojecten -+ werkgeefsters -+ werkgeheugens -+ werkgelegenheidsafspraak -+ werkgelegenheidsafspraken -+ werkgelegenheidsbevorderend -+ werkgelegenheidsbevorderende -+ werkgelegenheidsgarantie -+ werkgelegenheidsgaranties -+ werkgelegenheidsplannen -+ werkgelegenheidsprogramma's -+ werkgelegenheidsproject -+ werkgelegenheidsprojecten -+ werkgeversbijdragen -+ werkgeverslasten -+ werkgeversverbond -+ werkgeversverbonden -+ werkgeversverenigingen -+ werkgeversverklaringen -+ werkhoogte -+ werkindelingen -+ werkingskosten -+ werkingskrediet -+ werkingsnaam -+ werkingstoelage -+ werkingstoelagen -+ werkkamertje -+ werkkampen -+ werkkapitalen -+ werkkledij -+ werkleider -+ werkleiders -+ werklijn -+ werklijnen -+ werkloosheidcijfer -+ werkloosheidcijfers -+ werkloosheidscijfers -+ werkloosheidsfonds -+ werkloosheidspercentage -+ werkloosheidspercentages -+ werkloosheidsproblemen -+ werkloosheidsvergoeding -+ werkloosheidsvergoedingen -+ werkloosheidsvoorzieningen -+ werkloosheidswetten -+ werklozenbestand -+ werklozencontrole -+ werklozencontroles -+ werklozenproject -+ werklozenprojecten -+ werklunch -+ werklustig -+ werklustige -+ werkmeesters -+ werkmilieu -+ werkmilieus -+ werknemersaandelen -+ werknemersbijdragen -+ werknemerspremie -+ werknemerspremies -+ werknemersvertegenwoordiger -+ werknemersvertegenwoordigers -+ werknemersvertegenwoordiging -+ werknemersvertegenwoordigingen -+ werknemersverzekering -+ werknemersverzekeringen -+ werkobjecten -+ werkonbekwaam -+ werkonbekwaamheid -+ werkonbekwame -+ werkonderbrekingen -+ werkongeval -+ werkongevallen -+ werkontbijt -+ werkonwillige -+ werkonwilligen -+ werkopdrachten -+ werkpauzes -+ werkprestatie -+ werkprogramma's -+ werkputten -+ werkritme -+ werkruimten -+ werkschuwe -+ werkslaaf -+ werkslaven -+ werkstad -+ werkstraf -+ werkstress -+ werktaal -+ werktafeltje -+ werktalen -+ werktemperatuur -+ werktitels -+ werktuigbouwkunde -+ werktuigbouwkundig -+ werktuigbouwkundige -+ werktuigbouwkundigen -+ werktuigelijk -+ werktuigelijke -+ werkvelden -+ werkverband -+ werkvergadering -+ werkverhouding -+ werkverhoudingen -+ werkverlet -+ werkverschaffingen -+ werkverschaffingsproject -+ werkverschaffingsprojecten -+ werkverslaafde -+ werkvertrek -+ werkvertrekken -+ werkvoetbal -+ werkvoorbereider -+ werkweigeraars -+ werkweken -+ werkwoordstam -+ werkwoordstammen -+ werper -+ werpers -+ werphengels -+ werpheuvel -+ werpheuvels -+ werpkracht -+ werplans -+ werplansen -+ werploden -+ werpmolen -+ werpmolens -+ werpnummer -+ werpnummers -+ werpplaat -+ werpplaten -+ werpster -+ werpsterren -+ werpsters -+ werst -+ wersten -+ wervelend -+ wervelgewricht -+ wervelgewrichten -+ wervelholte -+ wervelholten -+ wervelholtes -+ wervelingen -+ wervelstromen -+ wervingsactie -+ wervingsacties -+ wervingsreserve -+ wervingsreserves -+ wervingssecretariaat -+ wervingsstop -+ wessi -+ wessi's -+ westerstormen -+ westoever -+ wetenschappelijk-technisch -+ wetenschappelijk-technische -+ wetenschapsbeoefenaar -+ wetenschapsbeoefenaars -+ wetenschapsbeoefening -+ wetenschapsdynamica -+ wetenschapsgebied -+ wetenschapsgebieden -+ wetenschapsgeschiedenis -+ wetenschapshistorisch -+ wetenschapshistorische -+ wetenschapsjournalist -+ wetenschapsjournalisten -+ wetenschapsjournalistiek -+ wetenschapsleer -+ wetenschapsman -+ wetenschapsmannen -+ wetenschapsopvatting -+ wetenschapsopvattingen -+ wetenschapspolitiek -+ wetenschapster -+ wetenschapstheoretisch -+ wetenschapstheoretische -+ wetenschapstheorie -+ wetenschapsvoorlichting -+ wetenschapswinkels -+ wetgevingsafdeling -+ wetgevingsjurist -+ wetgevingsjuristen -+ wetgevingsoperatie -+ wetgevingsoperaties -+ wethouderspost -+ wethoudersposten -+ wethouderszetel -+ wethouderszetels -+ wetland -+ wetlands -+ wetlook -+ wetsdienaar -+ wetsdienaars -+ wetsdienaren -+ wetsdokter -+ wetsdokters -+ wetskennis -+ wetstechnisch -+ wetstechnische -+ wetsvoorschrift -+ wetsvoorschriften -+ wezenskenmerk -+ wezenskenmerken -+ wezenskern -+ wezensvraag -+ wezensvragen -+ wezensvreemd -+ wezensvreemde -+ what you see is what you get -+ wherry's -+ whiplashes -+ whisky-soda -+ whiskyfles -+ whiskyflessen -+ whiskyglazen -+ whiskygrog -+ whiskygrogs -+ whizzkids -+ whodunits -+ wicketkeepers -+ wiebelig -+ wiebelige -+ wiebeltaks -+ wiebeltaksen -+ wieberde -+ wieberen -+ wiegenkinderen -+ wiegetouw -+ wiegetouwen -+ wiekgeklap -+ wiekslag -+ wiekslagen -+ wiekte -+ wielas -+ wielassen -+ wielerclubs -+ wielerevenement -+ wielerevenementen -+ wielerkampioen -+ wielerkampioenen -+ wielerkaravaan -+ wielerklassieker -+ wielerklassiekers -+ wielerleven -+ wielerpeloton -+ wielerploegen -+ wielerronde -+ wielerseizoen -+ wielertoerist -+ wielertoeristen -+ wielkast -+ wielkasten -+ wielklem -+ wielklemmen -+ wielrenbroek -+ wielrenunie -+ wielvlucht -+ wienerschnitzel -+ wienerschnitzels -+ wierookbrander -+ wierookbranders -+ wierookstokje -+ wierookstokjes -+ wiggenbeen -+ wiggenbeenderen -+ wiggenbenen -+ wij-gevoel -+ wij-vorm -+ wij-zijgevoel -+ wijdbal -+ wijdballen -+ wijdheid -+ wijduitstaand -+ wijduitstaande -+ wijdvallend -+ wijdvallende -+ wijdverspreid -+ wijdverspreide -+ wijdvertakt -+ wijfie -+ wijfies -+ wijfjesdier -+ wijfjesdieren -+ wijfjesree -+ wijkbewoner -+ wijkbewoners -+ wijkbladen -+ wijkbus -+ wijkcomité -+ wijkcomités -+ wijkdiploma -+ wijkdiploma's -+ wijkgemeenten -+ wijkgemeentes -+ wijking -+ wijkingen -+ wijkkrant -+ wijkkranten -+ wijkpolitie -+ wijkpredikanten -+ wijkraden -+ wijkteam -+ wijkteams -+ wijkvergadering -+ wijkvergaderingen -+ wijkwinkels -+ wijnbal -+ wijnballen -+ wijnboerderij -+ wijnboerderijen -+ wijndistrict -+ wijndistricten -+ wijnfeest -+ wijnfeesten -+ wijngebied -+ wijngebieden -+ wijngod -+ wijngoden -+ wijnkleur -+ wijnkoop -+ wijnkopen -+ wijnkristal -+ wijnkristallen -+ wijnmarkt -+ wijnmerk -+ wijnpokken -+ wijnproductie -+ wijnrekken -+ wijnsoort -+ wijnsoorten -+ wijnstreek -+ wijnstreken -+ wijnzak -+ wijnzakken -+ wijzigingsbesluit -+ wijzigingsplan -+ wijzigingsplannen -+ wijzing -+ wikkeljurk -+ wikkeljurken -+ wikkelrokken -+ wildbeheer -+ wildcards -+ wildebeesten -+ wildkamperen -+ wildpark -+ wildparken -+ wildplasser -+ wildreservaten -+ wildschaar -+ wildscharen -+ wildschotel -+ wildschotels -+ wildschut -+ wildschutten -+ wildtunnel -+ wildtunnels -+ wildviaduct -+ wildwaterbanen -+ wildwaterkanode -+ wildwaterkanoën -+ wildwatervaren -+ wilgachtig -+ wilgachtige -+ wilgenroosjes -+ wilsbesluit -+ wilsbesluiten -+ wilsovereenstemming -+ wilsverklaringen -+ wilsvorming -+ win-winsituatie -+ win-winsituaties -+ winbaar -+ winbare -+ winchen -+ winches -+ winchester -+ winchesters -+ winddicht -+ winddichte -+ windefamilie -+ windenergieproject -+ windenergieprojecten -+ winderosie -+ windgenerator -+ windgeneratoren -+ windgenerators -+ windgevoelige -+ windhondenrennen -+ windjack -+ windjacks -+ windjammer -+ windjammers -+ windjes -+ windmachine -+ windmolenpark -+ windorgel -+ windorgels -+ windowdressing -+ windpark -+ windschoor -+ windschoren -+ windsnelheidsmeter -+ windsnelheidsmeters -+ windturbine -+ windturbines -+ windvaantje -+ windveer -+ windveren -+ winegum -+ winegums -+ wingebieden -+ winkel-wandelstraat -+ winkel-wandelstraten -+ winkelaanbod -+ winkelbel -+ winkelbellen -+ winkeldieven -+ winkeliertje -+ winkelkar -+ winkelkarren -+ winkelkarretje -+ winkelketens -+ winkella's -+ winkellades -+ winkelomzet -+ winkelpassage -+ winkelpromenade -+ winkelpromenades -+ winkelpui -+ winkelsluitingswet -+ winkelwaarde -+ winkelwagen -+ winkelwagens -+ winkelwagentje -+ winnersmentaliteit -+ winningmood -+ winningsgebied -+ winningsgebieden -+ winstafhankelijk -+ winstafhankelijke -+ winstbelastingen -+ winstdalingen -+ winstdelingen -+ winstexplosie -+ winstexplosies -+ winstgroei -+ winstmakend -+ winstmakende -+ winstmogelijkheden -+ winstmogelijkheid -+ winstobject -+ winstobjecten -+ winstoogmerken -+ winstpremie -+ winstpremies -+ winstprognose -+ winstrekeningen -+ winstsaldi -+ winstsaldo's -+ winstwaarschuwing -+ winstwaarschuwingen -+ winterappel -+ winterappelen -+ winterappels -+ winterband -+ winterbanden -+ winterbeddingen -+ winterberging -+ winterbergingen -+ winterboek -+ winterboeken -+ winterdepressie -+ winterdienstregeling -+ wintereik -+ winterjasmijn -+ winterjasmijnen -+ winterkleding -+ winterkleed -+ winterkoning -+ winterkoningen -+ winteroffensief -+ winterpaleis -+ winterpaleizen -+ winterreis -+ winterschilders -+ wintersportcentra -+ wintersporter -+ wintersporters -+ wintersportgebied -+ wintersportgebieden -+ wintersportmode -+ wintersportoord -+ wintersportplaats -+ wintersportplaatsen -+ wintersportvakanties -+ winterstallingen -+ winterstops -+ winterstorm -+ winterstormen -+ wintertemperaturen -+ wintertemperatuur -+ winteruur -+ wintervakantie -+ wintervakanties -+ wintervast -+ wintervaste -+ wintervogel -+ wintervogels -+ winterwortel -+ winterwortelen -+ winterwortels -+ winterzonnestilstand -+ winterzonnetje -+ winti-ensemble -+ winti-ensembles -+ wintiritueel -+ wintirituelen -+ wipschieting -+ wipschietingen -+ wireless -+ wisbaar -+ wisbare -+ wisecracks -+ wisi -+ wiskop -+ wiskoppen -+ wiskundeboek -+ wiskundelerares -+ wiskundeonderwijs -+ wispelturigheden -+ wisselaren -+ wisselautomaten -+ wisselbad -+ wisselbaden -+ wisseldienst -+ wisselkantoortje -+ wisselkoersaanpassing -+ wisselkoersaanpassingen -+ wisselkoersstelsel -+ wisselkoersverhouding -+ wisselkoersverhoudingen -+ wissellaadbak -+ wissellaadbakken -+ wisselleerstoel -+ wisselleerstoelen -+ wissellijsten -+ wisselmeerderheden -+ wisselmeerderheid -+ wisseloplossing -+ wisseloplossingen -+ wisselplicht -+ wisselspelers -+ wisselstrook -+ wisseltentoonstelling -+ wisseltentoonstellingen -+ wisseltransactie -+ wisseltransacties -+ wisseltrofeeën -+ wisselwoning -+ wisselwoningen -+ witbestoven -+ witbiertje -+ witbiertjes -+ witbloedig -+ witbloedige -+ witblond -+ witblonde -+ witbol -+ witbollen -+ witgeel -+ witgehandschoend -+ witgehandschoende -+ witgelakt -+ witgelakte -+ witgele -+ witgeverfd -+ witgeverfde -+ witgewassen -+ witgoedsector -+ witgouden -+ witkarren -+ witkopaap -+ witkopapen -+ witlippekari -+ witlippekari's -+ witmaker -+ witmakers -+ witmarmeren -+ witmetaal -+ witogen -+ witoog -+ witspeler -+ witspelers -+ witteboordencrimineel -+ witteboordencriminelen -+ witteke -+ wittekes -+ wittetruidrager -+ wittig -+ wittige -+ witwaspraktijken -+ witwassen -+ witwasser -+ witwassers -+ witz -+ witzen -+ wodanseik -+ wodka's -+ woede-uitbarstingen -+ woede-uitval -+ woedes -+ woef -+ woelmuis -+ woelmuizen -+ woelrat -+ woelratten -+ woensdagmiddagen -+ woensdagochtenden -+ woestijngebied -+ woestijngebieden -+ woestijnlandschap -+ woestijnrat -+ woestijnratten -+ woestijnvorming -+ woestijnzon -+ wokkel -+ wokkels -+ wokken -+ wokte -+ wolboer -+ wolboeren -+ wolfsmelk -+ wolfsmelkachtig -+ wolfsmelkachtige -+ wolkachtig -+ wolkachtige -+ wolkenformatie -+ wolkenformaties -+ wolkenhemel -+ wolkenlucht -+ wolkenluchten -+ wolkenmassa -+ wolkenmassa's -+ wolkenpartij -+ wolkenveld -+ wolluis -+ wolluizen -+ wolmaniseerde -+ wolmaniseren -+ wolprijs -+ wolvengehuil -+ wolvenklemmen -+ wolvenkuilen -+ wolventanden -+ wolvet -+ womanizers -+ wombat -+ wombats -+ wonderblad -+ wonderbladen -+ wondertje -+ wondinfecties -+ woningbedrijf -+ woningbeheer -+ woningbehoefte -+ woningbestanden -+ woningblok -+ woningblokken -+ woningbouwcomplex -+ woningbouwer -+ woningbouwmarkt -+ woningbouwplan -+ woningbouwplannen -+ woningbouwprogramma -+ woningbouwproject -+ woningbouwprojecten -+ woningbouwsubsidie -+ woningbouwsubsidies -+ woningdeler -+ woningdelers -+ woningdelersnorm -+ woningdelersregeling -+ woninginrichter -+ woninginrichtingen -+ woningmarkten -+ woningprobleem -+ woningproductie -+ woningsector -+ woningtekort -+ woningtekorten -+ woningtoewijzing -+ woningtoewijzingsbeleid -+ woningvoorraad -+ woningvoorraden -+ woningwetbouw -+ woningwetlening -+ woningwetleningen -+ woon-werkproject -+ woon-werkprojecten -+ woon-zorgcomplex -+ woon-zorgcomplexen -+ woonboerderijen -+ woonbuurt -+ woonbuurten -+ wooncentra -+ wooncontainer -+ wooncontainers -+ wooncultuur -+ wooneenheden -+ woonerven -+ woonfunctie -+ woongebouwen -+ woongedeelten -+ woongedeeltes -+ woongemeenschappen -+ woonkazerne -+ woonkazernen -+ woonkazernes -+ woonkeukens -+ woonklimaat -+ woonkosten -+ woonkostentoeslag -+ woonkuil -+ woonkuilen -+ woonlaag -+ woonlagen -+ woonlandbeginsel -+ woonmilieu -+ woonmilieus -+ woonomgevingen -+ woonoorden -+ woonrecht -+ woonruimteverdeling -+ woonsparen -+ woonstedes -+ woonstraat -+ woonstraten -+ woontorens -+ woonvergunningen -+ woonvorm -+ woonvormen -+ woonwagenbewoner -+ woonwagenbewoners -+ woonwagencentra -+ woonwagencentrum -+ woonwagenwerk -+ woordbeelden -+ woordblinde -+ woorddienst -+ woordenboekmaker -+ woordfrequenties -+ woordgeslachten -+ woordloze -+ woordspel -+ woordspelig -+ woordspelige -+ woordveld -+ woordvelden -+ woordvoerderschap -+ woordvolgorden -+ woordvolgordes -+ woordvormingen -+ wordingsproces -+ wordprocessors -+ worggreep -+ worggrepen -+ workaholics -+ workshoppen -+ workshopt -+ workshopte -+ workstation -+ workstations -+ world wide web -+ wormgat -+ wormgaten -+ wormschroef -+ wormschroeven -+ wormziekten -+ wormziektes -+ worstcasescenario -+ worstcasescenario's -+ wortelaanzet -+ worteling -+ wortelkanaalbehandeling -+ wortelkluit -+ wortelsap -+ wortelsappen -+ wortelsoep -+ wortelstelsel -+ wortelstelsels -+ wortelvormig -+ wortelvormige -+ woudaap -+ woudaapje -+ woudapen -+ would-beactrice -+ would-beschrijver -+ wraakacties -+ wraaklustig -+ wraaklustige -+ wrakkig -+ wrakkige -+ wrattenzwijn -+ wrattenzwijnen -+ wrevels -+ wrijvingsloos -+ wrijvingspunt -+ wrijvingspunten -+ wrijvingsvlak -+ wrijvingsvlakken -+ writer's block -+ wurgcontract -+ wurgcontracten -+ wurger -+ wurgers -+ wurggrepen -+ wurgseks -+ wurgstokje -+ wurgstokjes -+ www -+ wysiwyg -+ x'en -+ x'je -+ x-aantal -+ x-aantallen -+ xenofiele -+ xenofoben -+ xeroxapparaat -+ xeroxapparaten -+ xeroxt -+ xeroxte -+ xtc-pil -+ xtc-pillen -+ y's -+ y'tje -+ yahtzeede -+ yahtzeet -+ yahtzeeën -+ yankee-Engels -+ yanks -+ yaws -+ yel -+ yelde -+ yelt -+ yencrisis -+ yenkoers -+ yogaoefening -+ yogaoefeningen -+ yoghurtbeker -+ yoghurtbekers -+ yoghurtijs -+ yoghurtplant -+ young urban professional -+ ypresien -+ yuans -+ yucca's -+ yuppieachtige -+ z'en -+ z'je -+ z's -+ z.i. -+ z.s.m. -+ zaadbank -+ zaadbanken -+ zaadbed -+ zaadbedden -+ zaadbol -+ zaadbollen -+ zaaddodend -+ zaaddodende -+ zaaddonor -+ zaaddonoren -+ zaaddonors -+ zaaddoos -+ zaaddozen -+ zaaddrager -+ zaaddragers -+ zaadhandelaar -+ zaadkiem -+ zaadkiemen -+ zaadknop -+ zaadknoppen -+ zaadkorreltje -+ zaadkwekerij -+ zaadkwekerijen -+ zaadlijst -+ zaadlijsten -+ zaadlozing -+ zaadlozingen -+ zaadstorting -+ zaadstortingen -+ zaadstreng -+ zaadstrengen -+ zaaduitstorting -+ zaadval -+ zaadveredeling -+ zaadveredelingsbedrijf -+ zaagraam -+ zaagramen -+ zaagsnede -+ zaagsneden -+ zaaizaadbedrijf -+ zaakvorming -+ zaakwaarneemster -+ zaakwaarneming -+ zaakwaarnemingen -+ zaalkorfbal -+ zaalsport -+ zaalsporten -+ zaalvoetbaltoernooi -+ zaalwachten -+ zabaione -+ zachtgeel -+ zachtgekookt -+ zachtgekookte -+ zachtgele -+ zachtgroen -+ zachtgroene -+ zachtroze -+ zadeldaktoren -+ zadelrob -+ zadelrobben -+ zadeltas -+ zadeltassen -+ zagemeel -+ zagerijtje -+ zagevent -+ zageventen -+ zakagenda's -+ zakbijbeltje -+ zakcomputers -+ zakencentra -+ zakencentrum -+ zakencijfer -+ zakengedaan -+ zakenkantoor -+ zakenkantoren -+ zakenlunchen -+ zakenmannetje -+ zakenmens -+ zakenmilieu -+ zakenpand -+ zakenpanden -+ zakenvliegtuig -+ zakenvliegtuigen -+ zakenwijk -+ zaketui -+ zakflaconnetje -+ zakflacons -+ zakjapanner -+ zakker -+ zakkerig -+ zakkerige -+ zakkers -+ zakkig -+ zakkige -+ zakpijp -+ zakpijpen -+ zakrekenmachinetje -+ zakschaakspellen -+ zakspiegeltje -+ zaktelefoon -+ zaktelefoons -+ zalencomplex -+ zalfachtig -+ zalfachtige -+ zalmmousse -+ zalmroze -+ zalmsalades -+ zambo's -+ zandafgravingen -+ zandauto's -+ zandbodem -+ zandbodems -+ zandduin -+ zandgebak -+ zandgebied -+ zandgebieden -+ zandgraverijen -+ zandheuveltje -+ zandkorreltje -+ zandlopermodel -+ zandopspuiting -+ zandopspuitingen -+ zandrits -+ zandritsen -+ zandrug -+ zandruggen -+ zandschilderen -+ zandsculpturen -+ zandsculptuur -+ zandspiering -+ zandsteenlaag -+ zandsteenlagen -+ zandstenen -+ zandstormen -+ zandstraalde -+ zandsuppletie -+ zandsuppleties -+ zandwinning -+ zandwinplas -+ zandwinplassen -+ zandwinput -+ zangcarrière -+ zangconcours -+ zanger-componist -+ zanger-gitarist -+ zanger-songwriter -+ zangers-songwriters -+ zangerscast -+ zangleraars -+ zangleraren -+ zangpartij -+ zangpartijen -+ zangpedagoge -+ zangpedagogen -+ zangpedagoges -+ zangpedagoog -+ zangstijl -+ zangvogeltje -+ zap -+ zapcultuur -+ zapper -+ zapt -+ zaterdagamateur -+ zaterdagamateurs -+ zaterdageditie -+ zaterdagmiddagen -+ zaterdagnachten -+ zaterdagochtenden -+ zaterdagsavonds -+ zaterdagvoetbal -+ zatladders -+ zatterik -+ zatteriken -+ zebra's -+ zebra-effect -+ zebracodes -+ zebrastrepen -+ zedelijkheidswetgeving -+ zee-engten -+ zee-engtes -+ zeeafzetting -+ zeeafzettingen -+ zeebaars -+ zeebaarzen -+ zeebewoner -+ zeebewoners -+ zeebiologen -+ zeebioloog -+ zeeblauw -+ zeeblauwe -+ zeebodems -+ zeebrasem -+ zeebries -+ zeedag -+ zeedagen -+ zeedagenregeling -+ zeefdrukken -+ zeefdrukte -+ zeeforel -+ zeegaand -+ zeegaande -+ zeegeschiedenis -+ zeegolf -+ zeegolven -+ zeegrasveld -+ zeegrasvelden -+ zeekant -+ zeeklei -+ zeekleigebied -+ zeemachtbases -+ zeemachtbasis -+ zeemachtbasissen -+ zeemannen -+ zeemansgraven -+ zeemansknoop -+ zeemansknopen -+ zeemanslied -+ zeemansliederen -+ zeemvel -+ zeemvellen -+ zeemzoet -+ zeemzoete -+ zeepbeleconomie -+ zeephouders -+ zeepje -+ zeepjes -+ zeepkistenrace -+ zeepkistenraces -+ zeeprovincie -+ zeeprovincies -+ zeepschuim -+ zeereep -+ zeeroutes -+ zeeslak -+ zeesleepvaart -+ zeeslepers -+ zeesoldaat -+ zeesoldaten -+ zeespiegelrijzing -+ zeespiegelstijging -+ zeestrijdkrachten -+ zeestromen -+ zeetankvaart -+ zeetong -+ zeetongen -+ zeetransport -+ zeevaartpolitie -+ zeevakantie -+ zeevakanties -+ zeeverbranding -+ zeevervoer -+ zeevervuiling -+ zeevrucht -+ zeevruchten -+ zeewaardigheid -+ zeewatertemperatuur -+ zeewolf -+ zeewolven -+ zeezeilers -+ zeezijde -+ zeezoogdier -+ zeezoogdieren -+ zegekar -+ zegekarren -+ zegenbedes -+ zegerijk -+ zegerijke -+ zeggenmoeras -+ zeggenschapsrechten -+ zeggenschapsverhouding -+ zeggenschapsverhoudingen -+ zeggenveen -+ zegsmens -+ zegsvrouwe -+ zeiker -+ zeikerds -+ zeikerig -+ zeikerige -+ zeikers -+ zeikstraal -+ zeikstralen -+ zeikwijf -+ zeikwijven -+ zeilaanwijzing -+ zeilaanwijzingen -+ zeilclubs -+ zeildoeken -+ zeildoeks -+ zeilervaring -+ zeilkampen -+ zeillat -+ zeillatten -+ zeiloppervlak -+ zeiloppervlakken -+ zeilscheepje -+ zeilscholen -+ zeilsters -+ zeilvaart -+ zeilvloot -+ zeilwinden -+ zekerheidsrecht -+ zekerheidsregeling -+ zekerheidsstelsel -+ zekerheidstelsel -+ zekerheidsuitgaven -+ zekerheidswetgeving -+ zekers -+ zekerstelling -+ zeldzaamheidswaarde -+ zelfachting -+ zelfbedacht -+ zelfbedieningsgroothandel -+ zelfbedieningspomp -+ zelfbedieningsrestaurants -+ zelfbeeld -+ zelfbeelden -+ zelfbeoordeling -+ zelfbescherming -+ zelfbeschouwing -+ zelfbesef -+ zelfbespiegeling -+ zelfbespiegelingen -+ zelfbesturend -+ zelfbesturende -+ zelfbevestiging -+ zelfbewoning -+ zelfbouw -+ zelfbouwer -+ zelfbouwers -+ zelfcensuur -+ zelfcorrectie -+ zelfdenkend -+ zelfdestructief -+ zelfdestructieve -+ zelfdodingen -+ zelfdoener -+ zelfdoeners -+ zelfexpressie -+ zelfgebakken -+ zelfgeschreven -+ zelfhaat -+ zelfhulpboek -+ zelfhulpboeken -+ zelfhulpgroepen -+ zelfingenomenheid -+ zelfironie -+ zelfklevend -+ zelfklevende -+ zelfklever -+ zelfklevers -+ zelfmedicatie -+ zelfmoordaanval -+ zelfmoordaanvallen -+ zelfmoordgedachte -+ zelfmoordgedachten -+ zelfmoordgedachtes -+ zelfmoordneiging -+ zelfmoordpiloot -+ zelfmoordpiloten -+ zelfmoordplan -+ zelfontleding -+ zelfontledingen -+ zelfontspanners -+ zelfontwikkeling -+ zelfopblaasbaar -+ zelfopblaasbare -+ zelfredzaam -+ zelfredzaamheid -+ zelfredzame -+ zelfregulering -+ zelfreiniging -+ zelfstandigenaftrek -+ zelfstandigheidsstreven -+ zelfstrijkend -+ zelfstrijkende -+ zelfsuggestie -+ zelfsuggesties -+ zelftankstation -+ zelftankstations -+ zelfverachting -+ zelfverbrandingen -+ zelfverdedigingscursus -+ zelfverdedigingscursussen -+ zelfverdedigingssport -+ zelfverdedigingssporten -+ zelfvergoding -+ zelfverklaard -+ zelfverklaarde -+ zelfverminking -+ zelfverminkingen -+ zelfvernietiging -+ zelfvervreemding -+ zelfverwijten -+ zelfverzonnen -+ zelfvoorzienend -+ zelfvoorzienende -+ zelfvoorziening -+ zelfvoorzieningsgraad -+ zelfwaarneming -+ zelfwording -+ zelfzeker -+ zelfzekere -+ zelfzekerheid -+ zelfzorg -+ zelfzuchtigheid -+ zemels -+ zenboeddhist -+ zenboeddhisten -+ zendamateurs -+ zendercoördinator -+ zenderindeling -+ zendernet -+ zenderredactie -+ zendingsartsen -+ zendingsdrang -+ zendingsijver -+ zendingsposten -+ zendmachtigingen -+ zendpiraten -+ zendpost -+ zendposten -+ zendschepen -+ zendschip -+ zendtijdverdeling -+ zenduur -+ zenmeditatie -+ zenmeester -+ zenuwaanval -+ zenuwaanvallen -+ zenuwbehandelingen -+ zenuwcentra -+ zenuwcentrum -+ zenuwcrises -+ zenuwcrisissen -+ zenuwgassen -+ zenuwinstorting -+ zenuwinstortingen -+ zenuwinzinking -+ zenuwinzinkingen -+ zenuwontstekingen -+ zenuwpil -+ zenuwpillen -+ zenuwstillend -+ zenuwstillende -+ zenuwstoornis -+ zenuwstoornissen -+ zenuwtablet -+ zenuwtrek -+ zenuwtrekken -+ zenuwuitloper -+ zenuwuitlopers -+ zenuwvezel -+ zenuwvlecht -+ zenuwvlechten -+ zenuwweefsel -+ zeolieten -+ zeper -+ zeperds -+ zepers -+ zero tolerance -+ zero's -+ zerootje -+ zerotolerancebeleid -+ zescilinder -+ zesdaagses -+ zesde-eeuws -+ zesde-eeuwse -+ zesdejaars -+ zesdeklasser -+ zesdeklassers -+ zesdelig -+ zesdelige -+ zesendertigurenweek -+ zesentwintigjarig -+ zesentwintigjarige -+ zesjarenplan -+ zeskaart -+ zeslandentoernooi -+ zesmaal -+ zesmiljoenste -+ zesponder -+ zesponders -+ zestiende-eeuwer -+ zestiende-eeuwse -+ zestienjarig -+ zestienjarigen -+ zestienkoppig -+ zestienkoppige -+ zestienmetergebied -+ zestiental -+ zestigpluskaart -+ zestigpluskaarten -+ zestigplusser -+ zestigplussers -+ zetbreedte -+ zetdwang -+ zetelmeerderheid -+ zetelverlies -+ zetinstructies -+ zetselproeven -+ zetstuk -+ zetstukken -+ zettenreeks -+ zettenreeksen -+ zeugenhouderij -+ zeugma's -+ zeugmata -+ zeurderig -+ zeurderige -+ zeurderigheid -+ zeurprobleem -+ zeurproblemen -+ zevendaags -+ zevendaagse -+ zevendelig -+ zevendelige -+ zevenenveertigste -+ zevenenzeventigste -+ zevenkaart -+ zevenkamp -+ zeventiende-eeuwer -+ zeventiende-eeuwers -+ zeventiende-eeuws -+ zeventiende-eeuwse -+ zeventienjarig -+ zeventienjarige -+ zevenuurjournaal -+ rambam -+ schompes -+ zichtlijn -+ zichtlijnen -+ zichtrekening -+ zichtrekeningen -+ ziedende -+ ziekenappel -+ ziekendag -+ ziekendagen -+ ziekenfondsbril -+ ziekenfondsbrillen -+ ziekenfondsbrilletje -+ ziekenfondspremies -+ ziekenfondsverzekerde -+ ziekenhuisafval -+ ziekenhuisapotheek -+ ziekenhuisapotheken -+ ziekenhuisbal -+ ziekenhuisballen -+ ziekenhuisbed -+ ziekenhuisbedden -+ ziekenhuisinfectie -+ ziekenhuisinfecties -+ ziekenhuislaboratorium -+ ziekenhuisopnames -+ ziekenhuispersoneel -+ ziekenhuissector -+ ziekenhuisverpleging -+ ziekenverzorgsters -+ ziekjes -+ ziekmakend -+ ziekmakende -+ ziekmeldingen -+ ziekte van Ménière -+ ziekte van Weil -+ ziekte-uitkering -+ ziekte-uitkeringen -+ ziektebeloop -+ ziektecijfer -+ ziektecijfers -+ ziektegelden -+ ziektegevoelig -+ ziektegevoelige -+ ziektekostenpolis -+ ziektekostenstelsel -+ ziektemelding -+ ziektemeldingen -+ ziekteoorzaak -+ ziekteoorzaken -+ ziektepatronen -+ ziektepatroon -+ ziektesymptomen -+ ziektesymptoom -+ ziektetoestand -+ ziektetoestanden -+ ziekteverwekkend -+ ziekteverwekkende -+ ziekteverzuimbeleid -+ ziektewetmaatregel -+ ziektewetmaatregelen -+ ziektewetplan -+ ziektewetplannen -+ ziektewetpremie -+ ziektewetpremies -+ ziektewetten -+ ziektewetuitkeringen -+ ziektewetvoorstel -+ ziektewetvoorstellen -+ zielenknijper -+ zielenknijpers -+ zieligjes -+ zielknijper -+ zielknijpers -+ zielsalleen -+ zielsgraag -+ zieltjeswinnerij -+ zieltogende -+ zienden -+ zigeunerinnetje -+ zigeunermeisje -+ zigeunerorkest -+ zigeunerorkesten -+ zigeunertaal -+ zigeunertalen -+ zigeunervolken -+ zigeunervolkeren -+ zigeunervrouw -+ zigeunervrouwen -+ zigzagde -+ zigzagkoers -+ zigzagmachine -+ zigzagmachines -+ zigzagnaaimachine -+ zigzagnaaimachines -+ zigzagsteken -+ zijaanrijding -+ zijdeaapje -+ zijdeaapjes -+ zijdens -+ zijderoute -+ zijdes -+ zijdezacht -+ zijdezachte -+ zijgalerijen -+ zijingangen -+ zijinstromer -+ zijinstromers -+ zijinstroom -+ zijkapellen -+ zijklep -+ zijkleppen -+ zijligging -+ zijloges -+ zijluik -+ zijluiken -+ zijnetten -+ zijnsleer -+ zijpaneel -+ zijportalen -+ zijraam -+ zijramen -+ zijruit -+ zijsluiting -+ zijsluitingen -+ zijspancross -+ zijspanklasse -+ zijspanrace -+ zijspanraces -+ zijspanrijder -+ zijspanrijders -+ zijspiegels -+ zijstap -+ zijuitgang -+ zijuitgangen -+ zijvak -+ zijvakken -+ zijvertrekken -+ zijvleugels -+ zijweggetje -+ zijwiel -+ zijwielen -+ zijwind -+ zijwinden -+ zilverberk -+ zilverberken -+ zilverbeslag -+ zilverbromide -+ zilverfolie -+ zilverhoudend -+ zilverhoudende -+ zilverpopulier -+ zilverpopulieren -+ zilverstift -+ zilvervisje -+ zilvervisjes -+ zilvervliesrijst -+ zilverzout -+ zilverzouten -+ zindelijkheidstraining -+ zindelijkheidstrainingen -+ zingevend -+ zingevende -+ zingeving -+ zingevingen -+ zingevingsdeskundige -+ zingevingsdeskundigen -+ zingevingsvraag -+ zingevingsvragen -+ zinkafval -+ zinkbedekkingen -+ zinkgravure -+ zinkgravures -+ zinkhoudend -+ zinkhoudende -+ zinledigheid -+ zinnenstrelende -+ zinnespel -+ zinnespelen -+ zinnia's -+ zinsritme -+ zinsstructuren -+ zinsstructuur -+ zinstructuren -+ zinstructuur -+ zinsvervoering -+ zintuigfysiologie -+ zintuiglijkheid -+ zip -+ zipdrive -+ zipdrives -+ zipfile -+ zipfiles -+ zippen -+ zipt -+ zipte -+ zit-slaapbank -+ zit-slaapbanken -+ zitcomfort -+ zitelement -+ zitelementen -+ zitgelegenheid -+ zithoeken -+ zithoogte -+ zitkamerameublementen -+ zitkubus -+ zitkubussen -+ zitkuilen -+ zitkussen -+ zitkussens -+ zitmeubel -+ zitmeubelen -+ zitmeubels -+ zitstaking -+ zittenblijven -+ zittingsdagen -+ zittingstermijn -+ zittingstermijnen -+ zittingszaal -+ zittribune -+ zitvolleybal -+ zitzak -+ zitzakken -+ zmlk -+ zmlk-scholen -+ zmlk-school -+ Methusalem -+ zodenbemester -+ zodenbemesters -+ zoekgemaakt -+ zoekmaken -+ zoekmogelijkheden -+ zoekplaatjes -+ zoekprocedures -+ zoekprogramma -+ zoekprogramma's -+ zoekraken -+ zoekterm -+ zoektermen -+ zoektochten -+ zoektool -+ zoektools -+ zoetelijkheid -+ zoeterig -+ zoeterige -+ zoethoudertjes -+ zoetklinkend -+ zoetklinkende -+ zoetwaren -+ zoetwaterbeheer -+ zoetwaterbron -+ zoetwatervoorraad -+ zoetwatervoorraden -+ zoeven -+ zolderbalk -+ zolderbalken -+ zolderruimte -+ zolderruimten -+ zolderruimtes -+ zoldervloer -+ zomercursussen -+ zomereik -+ zomergriep -+ zomerhausse -+ zomerjurken -+ zomerkades -+ zomerkamp -+ zomerkampen -+ zomerlucht -+ zomerluchten -+ zomermiddagen -+ zomeroffensief -+ zomerpak -+ zomerpakken -+ zomerpaleis -+ zomerpaleizen -+ zomerpostzegel -+ zomerregen -+ zomerregens -+ zomerresidentie -+ zomerresidenties -+ zomerschoen -+ zomerschoenen -+ zomerslaap -+ zomertaling -+ zomertemperaturen -+ zomertemperatuur -+ zomertortel -+ zomertortels -+ zomeruniversiteit -+ zomeruur -+ zomerwind -+ zomerzotheid -+ zonale -+ zonbeschenen -+ zond heruit -+ zondagamateurs -+ zondagbijlage -+ zondagdienst -+ zondagdiensten -+ zondagkrant -+ zondagkranten -+ zondagochtenden -+ zondagsavonds -+ zondagseditie -+ zondagskrant -+ zondagskranten -+ zondagsmiddags -+ zondagsmis -+ zondagsmissen -+ zondagsmorgens -+ zondagsplicht -+ zondagsplichten -+ zondagsrijders -+ zondagsschilders -+ zondagvoetbal -+ zondebesef -+ zondes -+ zonedekking -+ zonegrenzen -+ zonering -+ zonetijd -+ zonetijden -+ zonetoernooien -+ zoneverdediging -+ zonevreemd -+ zonevreemde -+ zongebruind -+ zongebruinde -+ zongedroogd -+ zongedroogde -+ zonne-uitslag -+ zonneactiviteit -+ zonneallergie -+ zonneauto -+ zonnebanken -+ zonnebloemolie -+ zonnebloempit -+ zonnebloempitten -+ zonnebrandcrèmes -+ zonnecel -+ zonnecellen -+ zonnecollectoren -+ zonnecollectors -+ zonnecycli -+ zonnedaken -+ zonneglans -+ zonnegodin -+ zonnejurken -+ zonnekanon -+ zonnekanonnen -+ zonneklep -+ zonnekleppen -+ zonnekoning -+ zonnekoningen -+ zonnepit -+ zonnepitten -+ zonneslag -+ zonnestraaltje -+ zonnestraling -+ zonnetempel -+ zonnetempels -+ zonneterrassen -+ zonnevlecht -+ zonnevlechten -+ zonnewei -+ zonneweide -+ zonneweiden -+ zonneweides -+ zonnewind -+ zonovergoten -+ zonsopkomst -+ zonuren -+ zonvakantie -+ zonvakanties -+ zonverbrand -+ zonverbrande -+ zonweringen -+ zood -+ zoogdiersoort -+ zoogdiersoorten -+ zoogkoe -+ zoogkoeien -+ zoomlenzen -+ zoomobjectief -+ zoomobjectieven -+ zoos -+ zorgaanbod -+ zorgarbeid -+ zorgbehoevend -+ zorgbehoevende -+ zorgbreedte -+ zorgbreedten -+ zorgbreedtes -+ zorgelijkheid -+ zorgenverstrekker -+ zorgenverstrekkers -+ zorghuis -+ zorghuizen -+ zorginstelling -+ zorginstellingen -+ zorgkas -+ zorgleerling -+ zorgleerlingen -+ zorgsectoren -+ zorgtaak -+ zorgtaken -+ zorgverbreding -+ zorgverlof -+ zorgverzekering -+ zorgverzekeringen -+ zorgvoorziening -+ zorgvuldigheidsbeginsel -+ zorgvuldigheidseisen -+ zorgvuldigheidsregels -+ zorgvuldigheidsvereisten -+ zottinnetje -+ zoutafzettingen -+ zoutarme -+ zouthoudend -+ zouthoudende -+ zoutkoepel -+ zoutkoepels -+ zoutkristal -+ zoutkristallen -+ zoutlozing -+ zoutlozingen -+ zoutminnend -+ zoutminnende -+ zoutontginning -+ zoutoplossingen -+ zoutvlees -+ zoutwateraquaria -+ zoutwateraquarium -+ zoutwateraquariums -+ zoveeljarig -+ zoveeljarige -+ zoögamie -+ zuchtjes -+ zuiderburen -+ zuiderbuur -+ zuiders -+ zuiderse -+ zuidgrenzen -+ zuidingang -+ zuidoosthoek -+ zuidoostkant -+ zuidoostkust -+ zuidoostwaarts -+ zuidpolen -+ zuidwesterstorm -+ zuidwesterstormen -+ zuidwesthoek -+ zuidwestkant -+ zuidwestkust -+ zuidwestpunt -+ zuidzuidwesten -+ zuigingen -+ zuignapje -+ zuignapjes -+ zuigtablet -+ zuigtabletten -+ zuilenstelsel -+ zuilenzaal -+ zuilvormig -+ zuilvormige -+ zuipfeest -+ zuipfeesten -+ zuipschuiten -+ zuivelbedrijf -+ zuiveldrank -+ zuiveldranken -+ zuivelhandel -+ zuivelmarkt -+ zuivelorganisatie -+ zuivelproducent -+ zuivelproducenten -+ zuiveringscommissie -+ zuiveringsmaatregel -+ zuiveringsmaatregelen -+ zuiveringsmethode -+ zuiveringsmethoden -+ zuiveringsmiddel -+ zuiveringsoperatie -+ zuiveringsoperaties -+ zuiveringsproces -+ zuiveringsschap -+ zuiveringsschappen -+ zuiveringsslib -+ zuiveringsstation -+ zuiveringsstations -+ zulle -+ zusterinstelling -+ zusterschepen -+ zusterschip -+ zustersscholen -+ zustersschool -+ zusterstad -+ zustersteden -+ zuurbal -+ zuurballen -+ zuurdesembrood -+ zuurgehalten -+ zuurgehaltes -+ zuurgoed -+ zuurgraden -+ zuurhoudend -+ zuurhoudende -+ zuurrest -+ zuurresten -+ zuursel -+ zuurstofarm -+ zuurstofarme -+ zuurstofcilinders -+ zuurstofflessen -+ zuurstofgehalte -+ zuurstofgehalten -+ zuurstofgehaltes -+ zuurstofloos -+ zuurstofloze -+ zuurstofrijk -+ zuurstofrijke -+ zuurstoftank -+ zuurstoftanks -+ zuurstoftekorten -+ zuurstoftenten -+ zuurstofverbruik -+ zuurstok -+ zuurstokken -+ zuurstokkleur -+ zuurstokkleuren -+ zuurstokkleurig -+ zuurstokkleurige -+ zuurstokroze -+ zuurtegraad -+ zuurverdiend -+ zwaaibeweging -+ zwaarbeproefd -+ zwaarbeproefde -+ zwaarbeveiligd -+ zwaarbeveiligde -+ zwaarbevochten -+ zwaarbewapend -+ zwaarbewolkt -+ zwaarbewolkte -+ zwaardvechten -+ zwaardwalvis -+ zwaardwalvissen -+ zwaargeschapen -+ zwaarstwegend -+ zwaarstwegende -+ zwaartekrachtsveld -+ zwaartelijnen -+ zwaarwaterreactoren -+ zwaarwaterreactors -+ zwaarwegende -+ zwaarweltergewicht -+ zwabberaar -+ zwabberaars -+ zwageres -+ zwageressen -+ zwakbegaafdheid -+ zwakteanalyse -+ zwakzinnigeninrichting -+ zwakzinnigeninrichtingen -+ zwammer -+ zwanenbloem -+ zwanenbloemen -+ zwangerschapsafbreking -+ zwangerschapsafbrekingen -+ zwangerschapsmasker -+ zwangerschapsonderbrekingen -+ zwangerschapstests -+ zwangerschapsvergiftigingen -+ zwart-Amerikaans -+ zwart-Amerikaanse -+ zwart-op-wit -+ zwart-wit -+ zwart-witbeeld -+ zwart-witbeelden -+ zwart-witfilm -+ zwart-witfilms -+ zwart-witfoto -+ zwart-witfoto's -+ zwart-witprinter -+ zwart-witprinters -+ zwart-witte -+ zwart-wittegenstelling -+ zwart-wittegenstellingen -+ zwart-wittoestel -+ zwart-wittoestellen -+ zwartboek -+ zwartboeken -+ zwartdruk -+ zwartekousenkerk -+ zwartekousenkerken -+ zwartewoudham -+ zwartgeblakerde -+ zwartgekeken -+ zwartgeklede -+ zwartgekleed -+ zwartgelakt -+ zwartgelakte -+ zwartgeldaffaire -+ zwartgeldcircuit -+ zwartgeldpraktijken -+ zwartgemaakt -+ zwartgereden -+ zwartgerokt -+ zwartgerokte -+ zwartgewerkt -+ zwartgrijs -+ zwartgrijze -+ zwartig -+ zwartige -+ zwartkijken -+ zwartleren -+ zwartmaken -+ zwartmakerij -+ zwartrijden -+ zwartrijder -+ zwartspeler -+ zwartspelers -+ zwartwerken -+ zwatelde -+ zwatelen -+ zwavelarm -+ zwavelarme -+ zwavelkop -+ zwavelkoppen -+ zwavelstokje -+ zwavelstokjes -+ zwaveluitstoot -+ zwavelverbinding -+ zwavelverbindingen -+ zweden -+ zweetgeur -+ zweetgeuren -+ zweetkakkies -+ zweetkamertjes -+ zweetparel -+ zweetparels -+ zweetpareltje -+ zweetplek -+ zweetplekken -+ zweetspoor -+ zwelkasten -+ zwellichaampje -+ zwellichamen -+ zwemabonnementen -+ zwembadpas -+ zwembadwater -+ zwemband -+ zwembanden -+ zwembandjes -+ zwembeweging -+ zwembewegingen -+ zwembond -+ zwemclub -+ zwemdiploma's -+ zwemdok -+ zwemdokken -+ zweminstructeurs -+ zwemkaarten -+ zwemkampioen -+ zwemploeg -+ zwemrecord -+ zwemslag -+ zwemslagen -+ zwemtalent -+ zwemvereniging -+ zwemvierdaagse -+ zwemwateren -+ zwemwaterkwaliteit -+ zwenkwielen -+ zwerfafval -+ zwerfauto -+ zwerfauto's -+ zwerfhond -+ zwerfhonden -+ zwerfjongere -+ zwerfjongeren -+ zwerfkeien -+ zwerfkind -+ zwerflandbouw -+ zwerflust -+ zwerfvuil -+ zwerversbestaan -+ zwervertje -+ zwever -+ zweverigheid -+ zwevers -+ zwiepers -+ zwijgverbod -+ zwingliaan -+ zwinglianen -+ zwoord -+ à -+ à la carte -+ à la minute -+ à-la-carterestaurant -+ à-la-carterestaurants -+ échéance -+ échéances -+ écriture automatique -+ élégance -+ öres -+ über-ich -+ übermensch -+ übermenschen -+ # groene boekje schrijft Majorca, Van Dale Mallorca -+ Mallorca -+ # woorden uit de 2007 versie van opentaal.nl -+ 's Gravenbrakel -+ 's Gravenvoeren -+ 's Gravenwezel -+ 's Herenelderen -+ 's nachts -+ 's-Gravenhaags -+ 's-Gravenhagenaar -+ 's-Gravenzander -+ 's-Gravenzands -+ 06-nummer -+ 1 aprilgek -+ 1 aprilgrap -+ 1 aprilmop -+ 11 septemberaanslagen -+ 16's -+ 3-cijferige -+ 5 meiherdenking -+ 5 meiviering -+ 80-jarige -+ A-kant -+ A-nummer -+ A.D. -+ AAW -+ ABC -+ ABN -+ AD -+ AIVD -+ ANP -+ ANSI -+ ANVR -+ ANW -+ ANWB -+ AOb -+ API -+ APV -+ ASCII -+ ASIC -+ AWACS -+ AWBZ -+ AWW -+ Aa -+ Aa en Hunze -+ Aad -+ Aafje -+ Aafke -+ Aaigem -+ Aaks -+ Aalbeke -+ Aalsmeerder -+ Aalsmeers -+ Aalst -+ Aalstenaar -+ Aalsters -+ Aaltenaar -+ Aaltens -+ Aalter -+ Aalteraar -+ Aalters -+ Aaltje -+ Aantjes -+ Aar -+ Aardenburg -+ Aarle -+ Aarschot -+ Aarschots -+ Aarschottenaar -+ Aarsele -+ Aart -+ Aartrijke -+ Aartselaar -+ Aartselaars -+ Aartselarenaar -+ Aat -+ Aats -+ Ab -+ Abbas -+ Abchazië -+ Abebaër -+ Abebiet -+ Abebitisch -+ Abel -+ Abel Tasman -+ Aboe -+ Aboe Simbel -+ Aboriginal -+ Aborigines -+ Abraham Kuyper -+ Abraham Lincoln -+ Abruzzees -+ Abruzzen -+ Abu -+ Abu Dhabi -+ Accra -+ Accraas -+ Accraër -+ Aceh -+ Achel -+ Achter -+ Achter-Indië -+ Achter-Rijn -+ Achterhoeker -+ Achterhoeks -+ Achterhuis -+ Acker -+ Ad -+ Adams -+ Adamstown -+ Addis Abeba -+ Addis Abebaër -+ Addis Abebiet -+ Addis Abebitisch -+ Adegem -+ Adelheid -+ Aden -+ Adeniet -+ Adenitisch -+ Adinda -+ Adinkerke -+ Adolf -+ Adolf Hitler -+ Adri -+ Adriaan -+ Adriaenszoon -+ Adriana -+ Adrianus -+ Adriatische -+ Adriatische Zee -+ Adrie -+ Adventurebank -+ Advertentieblad -+ Advocatenwet -+ Adzjarië -+ Aerts -+ Affligem -+ Afghaan -+ Afghaans -+ Afke -+ Afrikaans Schild -+ Afro -+ Afsluitdijk -+ Afsnee -+ Agana -+ Agatha -+ Agatha Christie -+ Agnes -+ Agneta -+ Agnus -+ Agnus Dei -+ Agt -+ Airees -+ Aires -+ Ajaccio -+ Ajax -+ Akaba -+ Akenaar -+ Akens -+ Akihito -+ Akren -+ Alain -+ Albanese Alpen -+ Albert -+ Albert Einstein -+ Albert Schweitzer -+ Albertina -+ Albertine -+ Albertmeer -+ Albestuurder -+ Alblasserdammer -+ Alblasserdams -+ Aleida -+ Aleijadinho -+ Aleoeten -+ Aleoetenbekken -+ Aleoetentrog -+ Aleppo -+ Aletta -+ Aletta Jacobs -+ Alex -+ Alexander -+ Alexander de Grote -+ Alexandra -+ Alexandrijn -+ Alexandrijns -+ Alexandrië -+ Alfons -+ Alfred -+ Alfred Nobel -+ Algiers -+ Algierser -+ Ali -+ Alice -+ Alida -+ Alighieri -+ Alissa -+ Alken -+ Alkmaar -+ Alkmaarder -+ Alkmaars -+ Allan -+ Allende -+ Allerheiligenbaai -+ Allerkinderen -+ Alma -+ Alma-Ata -+ Almachtig -+ Almachtige -+ Almaty -+ Almeerder -+ Almeers -+ Almeloos -+ Almeloër -+ Almogende -+ Alofi -+ Aloysius -+ Alpenetappe -+ Alpenetappes -+ Alpenland -+ Alpenrit -+ Alpenritten -+ Alphen aan den Rijn -+ Alphen-Chaam -+ Alphenaar -+ Alphens -+ Alpijns -+ Alsemberg -+ Altaj -+ Alva -+ Alvader -+ Alveringem -+ Alwetende -+ Alwijze -+ Alziende -+ Amadeus -+ Amalia -+ Amalie -+ Amanda -+ Amands -+ Amandsberg -+ Amandsbergenaar -+ Amandsbergs -+ Amati -+ Amazone -+ Amazonebekken -+ Amazonen -+ Ambacht -+ Ambachter -+ Amber -+ Ambon -+ Ambt -+ Ambt Montfort -+ Amel -+ Amelander -+ Amelands -+ American -+ Amerikaans-Samoa -+ Amerikaans-Samoaan -+ Amerikaans-Samoaans -+ Amerikaanse Maagdeneilanden -+ Amerikatrog -+ Amersfoorder -+ Amersfoorter -+ Amersfoorts -+ Amin -+ Amman -+ Ammaniet -+ Ammanitisch -+ Amoer -+ Amstel -+ Amstelgebied -+ Amstelveens -+ Amstelvener -+ Amsterdam-Centrum -+ Amsterdam-Noord -+ Amsterdam-Oud-Zuid -+ Amu -+ Amu Darja -+ Amélie -+ An -+ Anadyr -+ Anastacia -+ Anatolisch -+ Anatolisch Hoogland -+ Anatolië -+ Anatoliër -+ Andalusisch -+ Andalusië -+ Andalusiër -+ Andamanen -+ Andamanse -+ Andamanse Zee -+ Anderlecht -+ Anderlechts -+ Andes -+ Andijn -+ Andijns -+ Andikithira -+ Andisch -+ Andorra la Vella -+ Andorraan -+ Andorraans -+ Andrea -+ Andreas -+ Andrei -+ Andries -+ Andriezenaar -+ André -+ Andy -+ Angela -+ Angelica -+ Angelique -+ Anglo -+ Anguilla -+ Anguillaan -+ Anguillaans -+ Anhalt -+ Anika -+ Anja -+ Ank -+ Ankarioot -+ Ankariotisch -+ Anke -+ Ann -+ Anna Paulowna -+ Annabel -+ Annam -+ Annamaria -+ Anne -+ Anne Frank -+ Anne-Sophie -+ Anne-Wil -+ Annebeth -+ Annechien -+ Anneke -+ Anneleen -+ Annelies -+ Anneloes -+ Annemarie -+ Annemarieke -+ Annemiek -+ Annemieke -+ Annet -+ Annette -+ Annick -+ Annie -+ Annie M.G. Schmidt -+ Anny -+ Anouk -+ Anouschka -+ Ans -+ Antananarivo -+ Antarctisch -+ Antarctisch Schiereiland -+ Antarctische -+ Antarctiër -+ Antelinks -+ Anti -+ Anti-Balkan -+ Anti-Libanon -+ Anti-Taurus -+ Antigua -+ Antigua en Barbuda -+ Antillenbekken -+ Antiochië -+ Antipodeneilanden -+ Antje -+ Antoine -+ Antoinet -+ Antoinette -+ Anton -+ Anton Pieck -+ Antonius -+ Anzegem -+ Apache -+ Apachedans -+ Apachedansen -+ Apachen -+ Apeldoornaar -+ Apeldoorner -+ Apeldoorns -+ Apeldorenaar -+ Apennijn -+ Apennijnen -+ Apennijner -+ Apennijns -+ Apennijns Schiereiland -+ Apia -+ Appalachen -+ Appel -+ Appels -+ Appelterre -+ Appelterre-Eichem -+ Appingedammer -+ Appingedams -+ Apulisch -+ Apulië -+ Apuliër -+ Aquitaan -+ Aquitaans -+ Aquitaanse -+ Aquitaanse Poort -+ Aquitanië -+ Arabisch Bekken -+ Arabische Woestijn -+ Arabische Zee -+ Arabië -+ Arafat -+ Arafurazee -+ Aragon -+ Aralmeer -+ Arameeër -+ Arameeërs -+ Ararat -+ Arcen en Velden -+ Archimedes -+ Archipel -+ Arco -+ Arctisch -+ Arctische -+ Ard -+ Arda -+ Ardenner -+ Ardens -+ Ardooie -+ Arend -+ Arendonk -+ Arendonkenaar -+ Arendonks -+ Argentijns Bekken -+ Argolis -+ Arie -+ Arisch -+ Arische -+ Aristoteles -+ Arjan -+ Arjen -+ Arkansas -+ Armada -+ Armageddon -+ Armande -+ Armenië -+ Armentiers -+ Armentiersenaar -+ Armoricaans -+ Armoricaans Massief -+ Armstrong -+ Arne -+ Arno -+ Arnold -+ Arnoud -+ Arnout -+ Aron -+ Arron -+ Arteser -+ Artesisch -+ Artesië -+ Artesiër -+ Arthur -+ Arthur Conan Doyle -+ Arwin -+ As -+ Ashwin -+ Asjchabad -+ Asmara -+ Aspelare -+ Asper -+ Asse -+ Assebroek -+ Assebroekenaar -+ Assebroeks -+ Assen -+ Assenede -+ Assent -+ Assepoester -+ Asses -+ Assisi -+ Astana -+ Asten -+ Astenaar -+ Astene -+ Astens -+ Astrid -+ Asturisch -+ Asturisch-Cantabrisch Gebergte -+ Asturië -+ Asuncionees -+ Asunción -+ Ata -+ Atalantikanaal -+ Atenaar -+ Atheens -+ Athener -+ Atlanteeër -+ Atlanteïsch -+ Atlantisch-Indisch-Antarctisch Bekken -+ Atlantisch-Indische Rug -+ Atlantische Kustvlakte -+ Atlantische Oceaan -+ Atlas -+ Atlasgebergte -+ Attenhoven -+ Attenrode -+ Attika -+ Attiër -+ Audrey -+ Audrie -+ Auguste -+ Auguste Rodin -+ Augustus -+ Auke -+ Aukje -+ Aurelie -+ Australische Alpen -+ Auvergne -+ Avarua -+ Avekapelle -+ Avelgem -+ Averbode -+ Avondland -+ Avondster -+ Axel -+ Axelaar -+ Axels -+ Ayaan -+ Ayaan Hirsi Ali -+ Ayatollah -+ Ayatollah Khomeini -+ Ayers -+ Ayers Rock -+ Azerbeidzjaan -+ Azerbeidzjaans -+ Azerbeidzjan -+ Azeri -+ Azoriaan -+ Azoriaans -+ Azorisch -+ Azov -+ Azteek -+ Azteken -+ Aäron -+ BA -+ BBC -+ BBE -+ BG -+ BID -+ BIOS -+ BKR -+ BOB -+ BSE-geval -+ BSE-koe -+ BSN -+ BSN's -+ BSN-stelsel -+ BSc -+ BW -+ Baafs -+ Baai -+ Baai van Kotor -+ Baai van Mont-Saint-Michel -+ Baai van Peter de Grote -+ Baai van Sint-Michiel -+ Baaigem -+ Baal -+ Baalbek -+ Baalhoek -+ Baardegem -+ Baarle -+ Baarle-Hertog -+ Baarn -+ Baarnaar -+ Baarns -+ Baarsjes -+ Baasrode -+ Bab -+ Bab el Mandeb -+ Babette -+ Bach -+ Bachte -+ Bachte-Maria-Leerne -+ Backer -+ Baert -+ Bagdadder -+ Bagdads -+ Bahama -+ Bahama's -+ Bahamaan -+ Bahamaans -+ Bahrein -+ Bahreiner -+ Bahreini -+ Bahreins -+ Bairiki -+ Bakker -+ Bakoe -+ Bakoes -+ Bakoeër -+ Baleaar -+ Baleaars -+ Balearen -+ Balegem -+ Balen -+ Balenaar -+ Balens -+ Baliemvallei -+ Balkanees -+ Balkanschiereiland -+ Balkarië -+ Balkasjmeer -+ Balkenende -+ Balt -+ Balthasar -+ Balthasar Gerards -+ Balticum -+ Baltisch -+ Baltische -+ Bamako -+ Bambrugge -+ Banaat -+ Banater -+ Banater Gebergte -+ Banda -+ Banda Aceh -+ Bandar -+ Bandar Abbas -+ Bandar Seri Begawan -+ Bangkokker -+ Bangkoks -+ Bangui -+ Banjul -+ Banka -+ Bantam -+ Banten -+ Bantoe -+ Baragansteppe -+ Barbadaan -+ Barbadaans -+ Barbadiaan -+ Barbadiaans -+ Barbados -+ Barbara -+ Barbarijse -+ Barbarijse Hoogvlakte -+ Barbuda -+ Barenaar -+ Barendrechter -+ Barendrechts -+ Barentsz -+ Barentszburg -+ Barentszeiland -+ Barnevelder -+ Barnevelds -+ Barrièrerif -+ Bart -+ Bartina -+ Bartolomeüs -+ Baruch -+ Baruch de Spinoza -+ Bas -+ Bas-Congo -+ Base -+ Basel -+ Basic -+ Basisengels -+ Basjkirostan -+ Baskische Provincies -+ Bass -+ Basse -+ Basse-Terre -+ Basseterre -+ Bassevelde -+ Bassin -+ Bassin du Congo -+ Bastenaaks -+ Bastenaken -+ Bastenakenaar -+ Bastiaan -+ Bataafse Republiek -+ Batavia -+ Batavier -+ Batoemi -+ Batsheers -+ Bauke -+ Baukje -+ Bauwens -+ Bavegem -+ Bavikhove -+ Bavo -+ Bazel -+ Beatles -+ Beatrix -+ Beaufortzee -+ Beauvoorde -+ Becky -+ Beek -+ Beeks -+ Beeldenstorm -+ Beerlegem -+ Beernem -+ Beerse -+ Beersel -+ Beersenaar -+ Beerses -+ Beerst -+ Beert -+ Beervelde -+ Beerzel -+ Beesels -+ Beethoven -+ Beets -+ Begakanaal -+ Begawan -+ Begijnendijk -+ Beierin -+ Beierse Alpen -+ Beierse Hoogvlakte -+ Beierse Woud -+ Beigem -+ Beijerland -+ Beijerlander -+ Beijerlands -+ Beilenaar -+ Beilens -+ Beiler -+ Beiroet -+ Beiroeter -+ Beiroeti -+ Beiroets -+ Beisem -+ Bekavallei -+ Bekegem -+ Bekenaar -+ Bekken -+ Bekken van Parijs -+ Bekkerzeel -+ Bekkevoort -+ Belau -+ Belauer -+ Belaus -+ Belgicus -+ Belgisch-Lotharingen -+ Belgiës -+ Belgrado -+ Belgradoos -+ Belgradoër -+ Belinda -+ Belizaan -+ Belizaans -+ Belize -+ Belle -+ Bellegem -+ Bellem -+ Bellenaar -+ Bellingen -+ Belmopan -+ Beloetsjistan -+ Bels -+ Belsele -+ Belsen -+ Belt -+ Bemmelaar -+ Bemmeler -+ Bemmels -+ Ben -+ Benares -+ Beneden -+ Beneden-Donauvlakte -+ Benedenwinden -+ Benedenwinder -+ Benedenwinds -+ Benedenwindse -+ Benedenwindse Eilanden -+ Benedictus -+ Benedictus de Spinoza -+ Bengalees -+ Bengalen -+ Benghazi -+ Benin -+ Beniner -+ Benins -+ Benito -+ Benito Mussolini -+ Benjamin -+ Bep -+ Berber -+ Berberstam -+ Berberstammen -+ Berbroek -+ Berchem -+ Berchemmenaar -+ Berchems -+ Berdien -+ Berend -+ Berendrecht -+ Bereneiland -+ Berg -+ Bergeijk -+ Bergen -+ Bergen op Zoom -+ Bergen-Belsen -+ Bergland -+ Beringen -+ Beringstraat -+ Beringzee -+ Berkel en Rodenrijs -+ Berkelland -+ Berlaar -+ Berlare -+ Berlijnerin -+ Berlingen -+ Bermudaan -+ Bermudaans -+ Bern -+ Bernadette -+ Bernadette Soubirous -+ Bernard -+ Berner -+ Bernerin -+ Bernhard -+ Bernhardpas -+ Bernheze -+ Bernice -+ Berns -+ Bert -+ Bertem -+ Bertha -+ Bertram -+ Bertrand -+ Beselare -+ Beskiden -+ Bessarabië -+ Best -+ Bestandstwisten -+ Bestenaar -+ Bester -+ Bests -+ Betekom -+ Bethlehem -+ Bettenhoven -+ Bettina -+ Betty -+ Betuwe -+ Betuwenaar -+ Betuwer -+ Betuws -+ Beuninger -+ Beunings -+ Bevekom -+ Bevel -+ Beveland -+ Bevelander -+ Bevelands -+ Bever -+ Beveraar -+ Bevere -+ Beveren -+ Beveren-Waas -+ Beveren-aan-den-IJzer -+ Beverlo -+ Bevernaar -+ Bevers -+ Beverst -+ Beverwijker -+ Beverwijks -+ Bevrijdingsdag -+ Bhutaan -+ Bhutaans -+ Bhutan -+ Bianca -+ Bibi -+ Bibianne -+ Bierbeek -+ Bierk -+ Bihorgebergte -+ Bijbel -+ Bijbelbeschouwing -+ Bijbelboek -+ Bijbelboeken -+ Bijbelcommissie -+ Bijbelexegese -+ Bijbelgedeelte -+ Bijbelgenootschap -+ Bijbelgenootschappen -+ Bijbelkennis -+ Bijbelkring -+ Bijbelkringen -+ Bijbelkritiek -+ Bijbelles -+ Bijbellessen -+ Bijbellezing -+ Bijbellezingen -+ Bijbelonderzoek -+ Bijbelplaats -+ Bijbels -+ Bijbelse -+ Bijbelser -+ Bijbelspreuk -+ Bijbeltaal -+ Bijbeltekst -+ Bijbelteksten -+ Bijbeltheologen -+ Bijbeltheoloog -+ Bijbeluitleg -+ Bijbelvast -+ Bijbelvaste -+ Bijbelvaster -+ Bijbelverhaal -+ Bijbelverhalen -+ Bijbelvers -+ Bijbelvertaling -+ Bijbelvertalingen -+ Bijbelwetenschappen -+ Bijbelwoord -+ Bijbelwoorden -+ Bijgaarden -+ Bikschote -+ Bilbao -+ Bildt -+ Bill -+ Bill Clinton -+ Bill Gates -+ Billiton -+ Bilt -+ Biltenaar -+ Bilts -+ Bilzen -+ Bin -+ Binderveld -+ Binkom -+ Binnen -+ Binnen-Hebriden -+ Binnen-Mongolië -+ Binnenhof -+ Binnenzee -+ Birgit -+ Bisjkek -+ Biskaje -+ Bissau -+ Bissauer -+ Bissaus -+ Bissegem -+ Bitsingen -+ Björn -+ Blaasveld -+ Blaeu -+ Blair -+ Blanc -+ Blanden -+ Blankenberge -+ Blankenbergenaar -+ Blankenbergs -+ Blaricums -+ Blasius -+ Blauwe -+ Blauwe Nijl -+ Blauwe Rivier -+ Blieberg -+ Bloedprocessie -+ Bloedraad -+ Bloemendaals -+ Bloemendaler -+ Blom -+ Bo -+ Bob -+ Bocholt -+ Bocht -+ Bocht van Gdansk -+ Bocht van Helgoland -+ Bodegem -+ Bodegravenaar -+ Bodegravens -+ Bodenmeer -+ Bodensee -+ Boechout -+ Boedapester -+ Boedapests -+ Boeddha -+ Boeddhabeeld -+ Boeing -+ Boekarest -+ Boekarester -+ Boekarests -+ Boekenweek -+ Boekhout -+ Boekhoute -+ Boekje -+ Boekovina -+ Boeotië -+ Boer -+ Boerenoorlog -+ Boergas -+ Boergondisch -+ Boergondisch Kanaal -+ Boergondische -+ Boergondische Poort -+ Boergondië -+ Boerjatië -+ Boezinge -+ Bogaarden -+ Bogaert -+ Bogaerts -+ Bogota -+ Bogotaan -+ Bogotaans -+ Boheems-Moravische Hoogten -+ Bohemer Woud -+ Bohemerin -+ Boksers -+ Bolbeek -+ Bolder -+ Bollenstreek -+ Bomans -+ Bombay -+ Bomenaar -+ Bommershoven -+ Bonaparte -+ Bondsdag -+ Bondsrepubliek -+ Bone -+ Bonheiden -+ Boni -+ Bonifacio -+ Bonifatius -+ Boogschutter -+ Booienhoven -+ Booischot -+ Booitshoeke -+ Boom -+ Booms -+ Boon -+ Boorsem -+ Boortmeerbeek -+ Borchtlombeek -+ Borculoos -+ Borgenaar -+ Borger-Odoorn -+ Borgerder -+ Borgerhout -+ Borgerhoutenaar -+ Borgerhouts -+ Borgers -+ Borgloon -+ Borgworm -+ Borgworms -+ Boris -+ Borjan -+ Borlo -+ Born -+ Bornaar -+ Bornem -+ Bornemmenaar -+ Bornems -+ Borneo -+ Borner -+ Borns -+ Borrenaar -+ Borromeus -+ Borsbeek -+ Borsbeke -+ Borsselaar -+ Borssele -+ Borssels -+ Bos -+ Bos en Lommer -+ Bosjesman -+ Bosjesmannen -+ Boskoops -+ Boskopenaar -+ Boskoper -+ Bosmans -+ Bosnisch-Servische -+ Bosnië en Herzegovina -+ Bosporus -+ Bossuit -+ Bost -+ Bosvoorde -+ Bosvoordenaar -+ Bosvoords -+ Botlek -+ Botnische -+ Botswaan -+ Botswaans -+ Botswana -+ Bottelare -+ Bouke -+ Boukje -+ Bourgogne -+ Bourgondisch Kanaal -+ Bourgondische Poort -+ Bouterse -+ Boutersem -+ Bouwel -+ Bovag -+ Bovekerke -+ Bovelingen -+ Boven -+ Boven-Rijnse Laagvlakte -+ Bovenmeer -+ Bovenwinder -+ Bovenwinds -+ Bovenwindse -+ Bovenwindse Eilanden -+ Boxelaar -+ Boxmeerder -+ Boxmeers -+ Boxtelaar -+ Boxtels -+ Boze -+ Bradbury -+ Brahma -+ Brakelaar -+ Brakels -+ Brandt -+ Brasschaat -+ Brasschaats -+ Brasschatenaar -+ Bratislava -+ Braun -+ Braziliaans Bekken -+ Brazzaviller -+ Brazzavils -+ Brecht -+ Bredaas -+ Bredanaar -+ Bredaënaar -+ Bredaër -+ Bredenaar -+ Bredene -+ Bredens -+ Bree -+ Breendonk -+ Brees -+ Breeveertien -+ Breezand -+ Breeënaar -+ Breeërnaar -+ Brenda -+ Brennerpas -+ Brest -+ Breukelaar -+ Breukels -+ Brian -+ Bridget -+ Bridgetown -+ Briel -+ Brielen -+ Briellenaar -+ Briels -+ Brigade -+ Brigit -+ Brigitte -+ Brink -+ Brioni -+ Bristol -+ Brits-Columbia -+ Britse Eilanden -+ Britse Maagdeneilanden -+ Britt -+ Broechem -+ Broeck -+ Broek -+ Broekom -+ Brogel -+ Bronckhorst -+ Brouwer -+ Brouwers -+ Bruin -+ Brummenaar -+ Brummens -+ Brummer -+ Bruna -+ Brunei -+ Bruneier -+ Bruneis -+ Bruno -+ Brunssumer -+ Brunssums -+ Brussegem -+ Brustem -+ Bruyn -+ BuZa -+ Buchara -+ Buddingh' -+ Budels -+ Budingen -+ Buenos -+ Buenos Airees -+ Buenos Aires -+ Buggenhout -+ Buggenhoutenaar -+ Buggenhouts -+ Buiten -+ Buiten-Hebriden -+ Buitengewesten -+ Buizingen -+ Bujumbura -+ Buken -+ Bulskamp -+ Buma -+ Bunniker -+ Bunniks -+ Bunsbeek -+ Bunschotens -+ Bunschoter -+ Burcht -+ Buren -+ Burkina -+ Burkina Faso -+ Burkinees -+ Burst -+ Burundees -+ Burundi -+ Bush -+ Bussums -+ Buvingen -+ Byzantijns -+ Byzantium -+ C++ -+ C14 -+ CAT -+ CBS -+ CDA -+ CIA -+ CT -+ CV -+ CWI -+ Caesar -+ Caicoseilanden -+ Calabrees -+ Calabrisch -+ Calabrië -+ Calabriër -+ Calais -+ Calc -+ Calcutta -+ Caledonisch -+ Caledonië -+ Caledoniër -+ Calvarie -+ Calvarieberg -+ Cambodja -+ Cambodjaan -+ Cambodjaans -+ Camile -+ Campanische -+ Campanische Archipel -+ Campert -+ Canada -+ Canadees Bekken -+ Canadees Schild -+ Cananefaten -+ Canarisch -+ Canarische -+ Canariër -+ Canberra -+ Cantaber -+ Cantabrisch -+ Cantabrisch Gebergte -+ Cantabrië -+ Cantabriër -+ Capelle aan den IJssel -+ Capellenaar -+ Capels -+ Cappadocië -+ Caracas -+ Caraceen -+ Caraceens -+ Caraïbische -+ Caraïbische Zee -+ Caren -+ Cariben -+ Caribisch -+ Caribische -+ Caribische Zee -+ Carieb -+ Carin -+ Carina -+ Carine -+ Carl -+ Carla -+ Carlijn -+ Carlo -+ Carlos -+ Carmen -+ Carol -+ Carola -+ Carolien -+ Caroline -+ Carolinen -+ Carolus -+ Carolus Borromeus -+ Carroll -+ Cas -+ Casablanca -+ Caspar -+ Casper -+ Castilië -+ Castricummer -+ Castricums -+ Castries -+ Castro -+ Catalonië -+ Catharina -+ Catherine -+ Cathy -+ Cathérine -+ Cavourkanaal -+ Cayenne -+ Caymaneilanden -+ Caymaneilander -+ Caymaneilands -+ Caïro -+ Caïroot -+ Caïrotisch -+ Ceausescu -+ Cees -+ Cees Buddingh' -+ Celebes -+ Celebeszee -+ Cendrawasih -+ Centraal -+ Centraal Massief -+ Centraal-Afrikaan -+ Centraal-Afrikaans -+ Centraal-Afrikaanse Meren -+ Centraal-Afrikaanse Republiek -+ Centraal-Azië -+ Centraal-Indische Rug -+ Centraal-Pacifisch Bekken -+ Centraal-Pacifische Rug -+ Centrale -+ Centrale Cordillera -+ Centrum -+ Centrumraad -+ Centrumraad Rotterdam -+ Ceram -+ Ceramzee -+ Ceulemans -+ Cevennen -+ Cevenner -+ Cevennool -+ Cevennools -+ Cevens -+ Ceylon -+ Ceylonees -+ Ceylonner -+ Ceylons -+ Chaam -+ Chakassië -+ Chalcidice -+ Chantal -+ Chaplin -+ Charkov -+ Charles -+ Charles Darwin -+ Charles Dickens -+ Charles Lindbergh -+ Charles de Gaulle -+ Charlie -+ Charlie Chaplin -+ Charlois -+ Charlotte -+ Charlotte Amalie -+ Che -+ Che Guevara -+ Chi -+ Chiinau -+ Chileens Lengtedal -+ Chili -+ Chinees Laagland -+ Chinezenbuurt -+ Chisinau -+ Chongqing -+ Chris -+ Christa -+ Christel -+ ChristenUnie -+ ChristenUnie-leden -+ ChristenUnielid -+ Christiaan Huygens -+ Christiaens -+ Christian -+ Christiana -+ Christiane -+ Christie -+ Christina -+ Christine -+ Christmaseiland -+ Christmaseilander -+ Christmaseilands -+ Christoffel -+ Christoffel Columbus -+ Christoffel Plantijn -+ Christophe -+ Churchill -+ Cicero -+ Ciel -+ Cindy -+ Cis -+ Cis-Kaukasië -+ Ciska -+ Civilis -+ Claes -+ Claes Janszoon Visscher -+ Claessens -+ Claeys -+ Clara -+ Claudia -+ Claus -+ Clement -+ Cleopatra -+ Clercq -+ Clinton -+ Cobra -+ Coburg -+ Coby -+ Cock -+ Cockburn -+ Cockburn Town -+ Cockerill -+ Cockney -+ Coen -+ Coevordenaar -+ Coevorder -+ Coevords -+ Colette -+ Colijn -+ Colombees -+ Colombo -+ Columbia -+ Columbus -+ Comomeer -+ Comorees -+ Comoren -+ Compagnie -+ Compostela -+ Compostella -+ Conakry -+ Conan -+ Confucius -+ Congo -+ Congobekken -+ Congresverkiezingen -+ Coninck -+ Conny -+ Constantijn -+ Constantijn Huygens -+ Constantinus -+ Cook -+ Cookeilanden -+ Cookeilander -+ Cookeilands -+ Cools -+ Coppens -+ Cor -+ Corantijn -+ Cordillera -+ Cordillera de los Andes -+ Corfu -+ Cornelia -+ Cornelis -+ Corné -+ Corrie -+ Corry -+ Corsica -+ Corsicaan -+ Corsicaans -+ Corstius -+ Costa -+ Coster -+ Cotonou -+ Cottische -+ Cottische Alpen -+ Couperus -+ Cousteau -+ Cove -+ Cranendonck -+ Cremer -+ Cris -+ Cromwell -+ Crooswijk -+ Cubapolitiek -+ Cuijk -+ Cuijkenaar -+ Cuijks -+ Culemborger -+ Culemborgs -+ Curaçaoër -+ Curriculum -+ Curriculum Vitae -+ Curt -+ Cycladen -+ Cyrenaica -+ Cécile -+ D.V. -+ D66 -+ D66'er -+ D66'ers -+ D66-leden -+ D66-lid -+ DNA-materiaal -+ DNA-profiel -+ Daan -+ Dadizele -+ Daems -+ Daisy -+ Dakar -+ Daknam -+ Dale -+ Dalfsenaar -+ Dalfsens -+ Dalfser -+ Dalmatische -+ Dalmatische Eilanden -+ Dalmatië -+ Dam -+ Damasceen -+ Damasceens -+ Damascener -+ Damascus -+ Damiaan -+ Damme -+ Damslaper -+ Dana -+ Danakildepressie -+ Daniel -+ Daniël -+ Daniëlle -+ Danny -+ Dante -+ Dante Alighieri -+ Daphne -+ Dardanellen -+ Darja -+ Darwin -+ Dave -+ David -+ David Livingstone -+ Davis -+ Davy -+ Dawhah -+ De -+ De Baarsjes -+ De Backer -+ De Bilt -+ De Bruyn -+ De Clercq -+ De Cock -+ De Coninck -+ De Groot -+ De Groote -+ De Haan -+ De Klinge -+ De Meern -+ De Meyer -+ De Moeren -+ De Morgen -+ De Panne -+ De Pauw -+ De Pinte -+ De Ridder -+ De Ronde Venen -+ De Smedt -+ De Smet -+ De Standaard -+ De Stijl -+ De Telegraaf -+ De Tijd -+ De Vos -+ De Wilde -+ De Winter -+ De Wolden -+ Deaan -+ Debbie -+ Deborah -+ Decima -+ Declercq -+ Deerlijk -+ Deerlijkaan -+ Deerlijkaans -+ Deerlijkenaar -+ Deerlijks -+ Deftinge -+ Dehaene -+ Dei -+ Deins -+ Deinze -+ Deinzenaar -+ Deinzes -+ Dekan -+ Dekker -+ Delfland -+ Delfshaven -+ Delft -+ Delftenaar -+ Delfts -+ Delftse -+ Delfzijler -+ Delfzijls -+ Delhisch -+ Delhiër -+ Delila -+ Delos -+ Delphi -+ Deltawerken -+ Delvenaar -+ Demi -+ Den -+ Den Bosch -+ Den Briel -+ Den Haag -+ Den Ham -+ Den Helder -+ Den Uyl -+ Denderbelle -+ Denderhoutem -+ Denderleeuw -+ Denderleeuwenaar -+ Denderleeuws -+ Dendermonde -+ Dendermondenaar -+ Dendermonds -+ Denderwindeke -+ Denekamper -+ Denekamps -+ Deng -+ Deng Xiaoping -+ Denijs -+ Denis -+ Denise -+ Dennis -+ Dentergem -+ Deo volente -+ Deozaak -+ Deozaken -+ Derk -+ Descartes -+ Desi -+ Desi Bouterse -+ Desiderius -+ Desiderius Erasmus -+ Desirée -+ Desmet -+ Dessel -+ Desselgem -+ Destelbergen -+ Desteldonk -+ Deule -+ Deulemonde -+ Deum -+ Deums -+ Deurenaar -+ Deurens -+ Deurle -+ Deurnaar -+ Deurnenaar -+ Deurns -+ Deventenaar -+ Deventers -+ Devos -+ Dewi -+ Dhabi -+ Dharaan -+ Diana -+ Diane -+ Dianne -+ Dick -+ Dick Bruna -+ Dickens -+ Didammer -+ Didams -+ Diederick -+ Diederik -+ Diegem -+ Diemenaar -+ Diemens -+ Diemer -+ Dieneke -+ Diep -+ Diepenbeek -+ Diepenbeeks -+ Diepenbekenaar -+ Diepenveens -+ Diepenvener -+ Dierckx -+ Diest -+ Diestenaar -+ Diesters -+ Diests -+ Dieter -+ Diets-Heur -+ DigiD -+ Dijk -+ Dijkstra -+ Dijle -+ Dikkebus -+ Dikkele -+ Dikkelvenne -+ Diksmuide -+ Dilbeek -+ Dilbeeks -+ Dilbekenaar -+ Dili -+ Dillenburg -+ Dilsen -+ Dilsen-Stokkem -+ Dimitri -+ Dinand -+ Dinant -+ Dinantees -+ Dinantenaar -+ Dinanter -+ Dinants -+ Dinarische -+ Dinarische Alpen -+ Dineke -+ Dinkelland -+ Dirk -+ Djedda -+ Djibouti -+ Djiboutiaan -+ Djiboutiaans -+ Dnjepr -+ Dnjepropetrovsk -+ Dobroedzja -+ Dode -+ Dode Zee -+ Dodekanesos -+ Dodoma -+ Doel -+ Doesburger -+ Doesburgs -+ Doesjanbe -+ Doetinchemmer -+ Doetinchems -+ Doggersbank -+ Doha -+ Dokkum -+ Dokkums -+ Dolf -+ Dolly -+ Dolomieten -+ Dolomieter -+ Dolomiets -+ Domela -+ Domela Nieuwenhuis -+ Domingo -+ Dominicaan -+ Dominicaans -+ Dominicaanse -+ Dominique -+ Don -+ Donald -+ Donar -+ Donaudelta -+ Donauvlakte -+ Donetsbekken -+ Donetsplateau -+ Dongen -+ Dongenaar -+ Dongens -+ Donk -+ Door -+ Doorn -+ Doornaar -+ Doornik -+ Doornikenaar -+ Doorniks -+ Doorns -+ Doorvaart -+ Doper -+ Dora -+ Dordrechtenaar -+ Dordrechts -+ Dordt -+ Dordtenaar -+ Dordts -+ Dorenaar -+ Dorestad -+ Dorien -+ Doris -+ Dormaal -+ Dortmund-Eemskanaal -+ Dorus -+ Dottenijs -+ Douglas -+ Douglas Adams -+ Douwes -+ Dow -+ Dowaai -+ Doyle -+ Drachten -+ Drachtens -+ Drachter -+ Drachtster -+ Dracula -+ Dragomanpas -+ Drake -+ Drakensbergen -+ Dranouter -+ Draw -+ Drees -+ Drempel -+ Drewes -+ Driebergen -+ Driebergenaar -+ Driebergs -+ Driekapellen -+ Dries -+ Dries van Agt -+ Drieslinter -+ Drievuldigheid -+ Drin -+ Drogenbos -+ Drongen -+ Drongenaar -+ Drongens -+ Drontenaar -+ Drontens -+ Dronter -+ Drunens -+ Drutens -+ Dubai -+ Dublinner -+ Dublins -+ Dudzele -+ Duffel -+ Duffelaar -+ Duimpje -+ Duina -+ Duinkerke -+ Duinkerken -+ Duinkerkenaar -+ Duinkerkens -+ Duinkerker -+ Duinkerks -+ Duitse Bocht -+ Duivelander -+ Duivelands -+ Duivelseiland -+ Duiven -+ Duivens -+ Duizend -+ Duizend-en-een-nacht -+ Duras -+ Dusjanbe -+ Dutchbat -+ Dutsel -+ Duyfken -+ Dvina -+ Dwight -+ Dwight Eisenhower -+ Dworp -+ Dyck -+ Dylan -+ Dymfna -+ Dymphna -+ Dzjoengaarse -+ Dzjoengaarse Poort -+ Dzjoengarije -+ E. coli -+ EG -+ EGA -+ EUR -+ EVA -+ Echt -+ Echt-Susteren -+ Echtenaar -+ Echter -+ Echts -+ Ed -+ Edam -+ Edammer -+ Edammers -+ Edams -+ Eddie -+ Eddy -+ Eddy Merckx -+ Edegem -+ Edegemmenaar -+ Edegems -+ Edelare -+ Eden -+ Edenaar -+ Eder -+ Edes -+ Edgar -+ Edgar Allan Poe -+ Edingen -+ Edison -+ Edith -+ Eduard -+ Eduard Douwes Dekker -+ Edward -+ Edwardeiland -+ Edwardmeer -+ Eefje -+ Eeklo -+ Eeklonaar -+ Eekloos -+ Eelco -+ Eems -+ Eems-Jadekanaal -+ Eems-Vechtkanaal -+ Eemshaven -+ Eemskanaal -+ Eenheidsvakcentrale -+ Eerken -+ Eernegem -+ Eerselaar -+ Eersels -+ Eerste -+ Eerste Kamer -+ Eerste Kamerleden -+ Eeuwout -+ Effendi -+ Egadische -+ Egadische Eilanden -+ Egbert -+ Egem -+ Eger -+ Egeïsche -+ Egeïsche Zee -+ Eggewaartskapelle -+ Egina -+ Egmonder -+ Egmonds -+ Eibergenaar -+ Eiberger -+ Eibergs -+ Eichem -+ Eigenbilzen -+ Eigenbrakel -+ Eigenbrakelaar -+ Eigenbrakels -+ Eiger -+ Eijsdenaar -+ Eijsdens -+ Eilanden -+ Eilanden beneden de wind -+ Eilanden boven de wind -+ Eilandenrivier -+ Eindhout -+ Eindhovenaar -+ Eindhovens -+ Eine -+ Einstein -+ Eisden -+ Eise -+ Eise Eisinga -+ Eisenhower -+ Eisinga -+ Eke -+ Ekeraar -+ Ekeren -+ Ekers -+ Eksaarde -+ Eksel -+ El -+ El Obeid -+ Elba -+ Elbe -+ Elbert -+ Elboers -+ Elbroes -+ Elburger -+ Elburgs -+ Elch -+ Elco -+ Eldorado -+ Elektriciteitswet -+ Elen -+ Elena -+ Elena Ceausescu -+ Elene -+ Eleonora -+ Elewijt -+ Elfstedentocht -+ Elia -+ Elianne -+ Eliksem -+ Eline -+ Elingen -+ Elisabeth -+ Elise -+ Elizabetheilanden -+ Ella -+ Elle -+ Elleke -+ Ellen -+ Elles -+ Ellikom -+ Elly -+ Eloois -+ Els -+ Elsbeth -+ Elsegem -+ Elsenaar -+ Elsene -+ Elsens -+ Elske -+ Elsschot -+ Elst -+ Elstenaar -+ Elster -+ Elsts -+ Elton -+ Elverdinge -+ Elversele -+ Elvira -+ Elwin -+ Elza -+ Elzas -+ Elzaskanaal -+ Elzasser -+ Elzasserin -+ Elzassisch -+ Elzele -+ Elzevier -+ Emanuelle -+ Emblem -+ Emder -+ Emelgem -+ Emiel -+ Emile -+ Emile Zola -+ Emilie -+ Emma -+ Emmanuel -+ Emmelie -+ Emmenaar -+ Emmens -+ Emmer -+ Emmerich -+ Emmerik -+ Emmeriker -+ Emmeriks -+ Emmy -+ Ename -+ Ende -+ Engelmanshoven -+ Engelstaligen -+ Eniac -+ Enkhuizens -+ Enkhuizer -+ Enschedees -+ Enschedeër -+ Enschot -+ Enzo -+ Enzo Ferrari -+ Eolische -+ Eolische Eilanden -+ Epe -+ Epenaar -+ Eper -+ Epes -+ Epirus -+ Eppegem -+ Equatoriaal -+ Equatoriaal-Guinea -+ Equatoriaal-Guinees -+ Equatoriaal-Guineeër -+ Equatoriale -+ Erasmus -+ Erben -+ Erembodegem -+ Erembodegemmenaar -+ Erembodegems -+ Eremo -+ Erevan -+ Erg -+ Eric -+ Erica -+ Erich -+ Erich Honecker -+ Erik -+ Erika -+ Eritrea -+ Eritrees -+ Eritreeër -+ Ermeloos -+ Ermeloër -+ Ernest -+ Ernest Hemingway -+ Erondegem -+ Erpe -+ Erpe-Mere -+ Erps -+ Erps-Kwerps -+ Ertvelde -+ Erwetegem -+ Esau -+ Esen -+ Eskimo -+ Eskimo's -+ Esmée -+ Esse -+ Essen -+ Essenaar -+ Essene -+ Essens -+ Estelle -+ Ester -+ Esther -+ Ethiopisch Hoogland -+ Etienne -+ Etikhove -+ Etna -+ Etruskische -+ Etruskische Apennijnen -+ Ettelgem -+ Etten -+ Etterbeek -+ Etterbeeks -+ Etterbekenaar -+ Euboea -+ Euclides -+ Eufraat -+ Eupen -+ Eupenaar -+ Eupener -+ Eupens -+ Euriposkanaal -+ Europarlement -+ Europarlementariër -+ Europeaans -+ Eustachius -+ Eustatius -+ Eva -+ Eva Braun -+ Evelien -+ Eveline -+ Evenaarsprovincie -+ Everaar -+ Everbeek -+ Everberg -+ Evere -+ Everest -+ Evergem -+ Evergemmenaar -+ Evergems -+ Evernijs -+ Evers -+ Evert -+ Ewoud -+ Ewout -+ Exodus -+ Explorer -+ Ezemaal -+ FORA -+ Fabiola -+ Fabrice -+ Fakaofo -+ Falasha -+ Falasha's -+ Fale -+ Falklandeilanden -+ Falklandeilander -+ Falklandeilands -+ Famke -+ Faso -+ Fatima -+ Fatra -+ Federatie -+ Fehmarn -+ Fehmarn Belt -+ Feijenoord -+ Felicia -+ Felix -+ Femke -+ Ferdinand -+ Ferdinand Domela Nieuwenhuis -+ Ferdy -+ Fergana -+ Fernand -+ Ferrari -+ Ferro -+ Ferry -+ Ferwerderadiel -+ Fez -+ Fezzan -+ Fidel -+ Fidel Castro -+ Fien -+ Fiji -+ Fijisch -+ Fijiër -+ Fijnaart -+ Filip -+ Filipijn -+ Filipijnen -+ Filipijnenbekken -+ Filipijnentrog -+ Filipijnenzee -+ Filipijns -+ Filippus -+ Filips -+ Filips II -+ Filips de Goede -+ Filips de Schone -+ Filistijnen -+ Finn -+ Finse Golf -+ Finse Merenvlakte -+ Fiona -+ Firefox -+ Fish -+ Flakkeeënaar -+ Fleur -+ Flevopolders -+ Floor -+ Florence -+ Florentijn -+ Florentine -+ Florian -+ Florida -+ Floris -+ Floris V -+ Floyd -+ Flying -+ Flying Fish Cove -+ Foeke -+ Folkert -+ Folkerts -+ Fons -+ Foppe -+ Ford -+ Fords -+ Formosa -+ Fort -+ Fort-de-France -+ Fortuyn -+ France -+ Francine -+ Franciscus -+ Franciscus van Assisi -+ Franeker -+ Franekers -+ Frank -+ Frank Zappa -+ Franka -+ Frans Hals -+ Frans-Komen -+ Frans-Polynesisch -+ Frans-Polynesiër -+ Fransdol -+ Fransdolle -+ Fransdolst -+ Franse Alpen -+ Franz -+ Franz Joseph Strauss -+ François -+ Freddy -+ Frederik -+ Frederik Hendrik -+ Frederika -+ Frederique -+ Freek -+ Freekje -+ Freetown -+ Freud -+ Friedrich -+ Friedrich Nietzsche -+ Frits -+ Frouke -+ Froukje -+ Fundybaai -+ Funen -+ Futuna -+ GB -+ GBA -+ GPL -+ GPRS -+ Gaasbeek -+ Gaasterlân -+ Gabon -+ Gabonees -+ Gaborone -+ Gabriël -+ Gaby -+ Gabès -+ Gaelic -+ Gagaoezië -+ Gagarin -+ Galicië -+ Galilea -+ Galilei -+ Galileo -+ Galileo Galilei -+ Gallo -+ Galmaarden -+ Galápagoseilanden -+ Gambia -+ Gambiaan -+ Gambiaans -+ Gandhi -+ Ganges -+ Ganshoren -+ Ganshorenaar -+ Ganshorens -+ Garapan -+ Gardameer -+ Gaswet -+ Gates -+ Gauguin -+ Gaulle -+ Gautama -+ Gautama Boeddha -+ Gavere -+ Gaza -+ Gazet -+ Gazet van Antwerpen -+ Gbit -+ Gdansk -+ Gea -+ Gebergte -+ Geel -+ Geels -+ Geelvinkbaai -+ Geerke -+ Geert -+ Geertje -+ Geertrui -+ Geertruida -+ Geerts -+ Geesje -+ Geeske -+ Geest -+ Geetbets -+ Geldenaken -+ Geldermalsens -+ Gelderslui -+ Geldroppenaar -+ Geldropper -+ Geldrops -+ Gele -+ Gele Rivier -+ Gele Zee -+ Geleender -+ Geleens -+ Gelenaar -+ Gelener -+ Gelinden -+ Gellik -+ Gellingen -+ Gelmen -+ Gelre -+ Gelrode -+ Geluveld -+ Geluwe -+ Gembloers -+ Gembloersenaar -+ Gemertenaar -+ Gemerts -+ Gendringer -+ Gendrings -+ Genepiën -+ Generaal -+ Generaliteitsland -+ Genesis -+ Genesius -+ Genk -+ Genkenaar -+ Genker -+ Genkers -+ Genks -+ Gennepenaar -+ Genneper -+ Genneps -+ Genoelselderen -+ Genootschapseilanden -+ Gentbrugge -+ Gentbruggenaar -+ Gentbrugs -+ Genua -+ Genuees -+ Genève -+ George -+ George Orwell -+ George W. Bush -+ George's -+ Georgekanaal -+ Georges -+ Georgetown -+ Georgette -+ Georgisch -+ Georgië -+ Georgiër -+ Ger -+ Geraamtekust -+ Geraardsbergen -+ Geraardsbergenaar -+ Geraardsbergs -+ Gerald -+ Geraldine -+ Gerard Reve -+ Gerard van Velzen -+ Gerards -+ Gerardus -+ Gerben -+ Gerbrand -+ Gerda -+ Gerdingen -+ Germaine -+ Gerona -+ Gerrie -+ Gerrit -+ Gerrit Jan van Heuven Goedhart -+ Gerrit Krol -+ Gerrit Rietveld -+ Gerry -+ Gerry Adams -+ Gert-Jan -+ Gertjan -+ Gertje -+ Gertrude -+ Gerwin -+ Gestel -+ Geten -+ Geul -+ Geuzenveld -+ Geuzenveld-Slotermeer -+ Gezelle -+ Gezondheidsraad -+ Ghats -+ Gideon -+ Gierle -+ Giessendam -+ Gieten -+ Gijs -+ Gijsbert -+ Gijsbrecht -+ Gijsbrecht van Amstel -+ Gijverinkhove -+ Gijzegem -+ Gijzelbrechtegem -+ Gijzenzele -+ Gilbert -+ Gillenaar -+ Gilles -+ Gillis -+ Gils -+ Gilze en Rijen -+ Gilzenaar -+ Gingelom -+ Ginneken -+ Giovanni -+ Gistel -+ Githion -+ Gits -+ Gizeh -+ Glaaien -+ Glabbeek -+ Glabbeek-Zuurbemde -+ Glenn -+ Glossa -+ Gnome -+ Gobi -+ Gobiwoestijn -+ Godart -+ Godelieve -+ Godfried -+ Godfried Bomans -+ Godsman -+ Godszoon -+ Godveerdegem -+ Goede -+ Goedele -+ Goedhart -+ Goeferdinge -+ Goerees -+ Goereese -+ Goereeër -+ Goes -+ Goesenaar -+ Goethals -+ Goetsenhoven -+ Gogh -+ Goirlenaar -+ Goirles -+ Golanhoogten -+ Golf -+ Golf van Aden -+ Golf van Ajaccio -+ Golf van Akaba -+ Golf van Anadyr -+ Golf van Argolis -+ Golf van Bengalen -+ Golf van Boergas -+ Golf van Bone -+ Golf van Californië -+ Golf van Egina -+ Golf van Gabès -+ Golf van Genua -+ Golf van Guinee -+ Golf van Kiparissia -+ Golf van Korinthe -+ Golf van Martaban -+ Golf van Messina -+ Golf van Mexico -+ Golf van Napels -+ Golf van Oman -+ Golf van Patras -+ Golf van Petalia -+ Golf van Riga -+ Golf van Rijeka -+ Golf van Sidra -+ Golf van Strimon -+ Golf van Suez -+ Golf van Tarente -+ Golf van Thailand -+ Golf van Thessaloniki -+ Golf van Tolo -+ Golf van Tomini -+ Golf van Tonkin -+ Golf van Triëst -+ Golf van Venetië -+ Golf van Volos -+ Golfkustvlakte -+ Goliath -+ Gonneke -+ Gonnie -+ Gontrode -+ Gooi -+ Gooier -+ Gooik -+ Gooiland -+ Gooilander -+ Gooilands -+ Goois -+ Goor -+ Goors -+ Goossens -+ Goran -+ Gorbatsjov -+ Goriks -+ Gorkumer -+ Gorkums -+ Gors -+ Gors-Opleeuw -+ Gorsem -+ Gorsselaar -+ Gorssels -+ Gorter -+ Gotem -+ Goten -+ Gotenburg -+ Gotenburger -+ Gotenburgs -+ Gottem -+ Gotthard -+ Gouden -+ Gouden Hoorn -+ Goudkust -+ Govert -+ Graadkanaal -+ Graaf -+ Graft -+ Graft-De Rijp -+ Grajische -+ Grajische Alpen -+ Grammene -+ Grammy -+ Grande -+ Graveland -+ Graven -+ Gravenbrakel -+ Gravendeel -+ Gravenhaags -+ Gravenhage -+ Gravenhagenaar -+ Gravenmoer -+ Gravenvoeren -+ Gravenwezel -+ Gravenzande -+ Gravenzander -+ Gravenzands -+ Grazen -+ Grebbeberg -+ Greet -+ Greet Hofmans -+ Greet Hofmansaffaire -+ Greetje -+ Grembergen -+ Grenada -+ Grenadaan -+ Grenadaans -+ Grenadiaan -+ Grenadiaans -+ Grenadines -+ Greta -+ Gretha -+ Gretta -+ Griekin -+ Grietje -+ Grimbergen -+ Grimbergenaar -+ Grimbergs -+ Grimm -+ Grimminge -+ Grobbendonk -+ GroenLinks-leden -+ GroenLinkslid -+ Groene -+ Groene Boekje -+ Groenland -+ Groenlander -+ Groenlandzee -+ Groenlo-Lichtenvoorde -+ Groesbeeks -+ Groesbekenaar -+ Groesbeker -+ Groot -+ Groot Artesisch Bekken -+ Groot Australisch Scheidingsgebergte -+ Groot Barrièrerif -+ Groot-Bijgaarden -+ Groot-Gelmen -+ Groot-Loon -+ Groote -+ Grote -+ Grote Antillen -+ Grote Arabische Woestijn -+ Grote Australische Bocht -+ Grote Bekken -+ Grote Belt -+ Grote Fatra -+ Grote Hongaarse Laagvlakte -+ Grote Kanaal -+ Grote Kapela -+ Grote Meren -+ Grote Oceaan -+ Grote Pier -+ Grote Sint-Bernhardpas -+ Grote Slenk -+ Grote Soenda-eilanden -+ Grote Van Dale -+ Grote Victoriawoestijn -+ Grote Visbaai -+ Grote Vissersbank -+ Grote Zandwoestijn -+ Grote Zoutwoestijn -+ Grote-Brogel -+ Grote-Spouwen -+ Grotenberge -+ Gruitrode -+ Guadeloupe -+ Guadelouper -+ Guadeloups -+ Guam -+ Guamees -+ Guangzhou -+ Guatemala-stad -+ Guernica -+ Guevara -+ Guido -+ Guido Gezelle -+ Guigoven -+ Guinea -+ Guinee -+ Guinee-Bissau -+ Guinee-Bissauer -+ Guinee-Bissaus -+ Guinees -+ Guineese -+ Guineeër -+ Gulke -+ Gullegem -+ Gulpen -+ Gulpen-Wittem -+ Gumbinnen -+ Gussenhoven -+ Gustaaf -+ Gutenberg -+ Gutenbergbijbel -+ Gutschoven -+ Guus -+ Guusje -+ Guy -+ Gwen -+ Gé -+ Götakanaal -+ H.M. -+ Haacht -+ Haaksbergenaar -+ Haaksberger -+ Haaksbergs -+ Haaltert -+ Haan -+ Haaren -+ Haarlemmerliede en Spaarnwoude -+ Haarlemmermeerder -+ Haarlemmermeers -+ Haasdonk -+ Haasrode -+ Haasse -+ Habsburgse -+ Hadith -+ Hadjememaar -+ Hadramaut -+ Haf -+ Hageland -+ Hagelander -+ Hagelands -+ Hagiostrati -+ Hagiostrati-eiland -+ Haiderabad -+ Haifa -+ Haije -+ Hakan -+ Hakendover -+ Halderberge -+ Halen -+ Hallaar -+ Halle -+ Halle-Booienhoven -+ Hallenaar -+ Halloween -+ Halmaal -+ Halmahera -+ Hals -+ Halsteren -+ Halternaar -+ Halters -+ Ham -+ Hamburger -+ Hamburgs -+ Hamilton -+ Hamme -+ Hammenaar -+ Hammer -+ Hamont -+ Hamont-Achel -+ Hams -+ Han -+ Handzame -+ Hanja -+ Hanka -+ Hanna -+ Hannah -+ Hanneke -+ Hannes -+ Hannibal -+ Hannuit -+ Hannuitenaar -+ Hannuits -+ Hanoi -+ Hanoier -+ Hanois -+ Hans -+ Hansbeke -+ Hansje -+ Hanzenetwerk -+ Hanzestadjes -+ Hanzeverbond -+ Harald -+ Harare -+ Harco -+ Hardenberger -+ Hardenbergs -+ Harderwijker -+ Harderwijks -+ Hardinxveld -+ Hardinxvelder -+ Hardinxvelds -+ Hare -+ Hare Majesteit -+ Hare Majesteit de Koningin -+ Harelbeeks -+ Harelbekaan -+ Harelbeke -+ Harelbekenaar -+ Haren -+ Harenaar -+ Harender -+ Harener -+ Harens -+ Harer -+ Harer Majesteits -+ Haringe -+ Hariët -+ Hariëtte -+ Harlinger -+ Harlings -+ Harm -+ Harmen -+ Harold -+ Harrald -+ Harrie -+ Harrold -+ Harry -+ Harry Houdini -+ Hartstichting -+ Harvey -+ Haspengouw -+ Haspengouwer -+ Haspengouws -+ Hattemer -+ Hattems -+ Haut -+ Haut-Congo -+ Havana -+ Havanees -+ Havelaar -+ Haydn -+ Hayo -+ Hazerswoude -+ Hazerswoudenaar -+ Hazerswouds -+ Haïti -+ Haïtiaan -+ Haïtiaans -+ Hebriden -+ Hebridenzee -+ Hebridiaan -+ Hebridiaans -+ Hebron -+ Hechtel -+ Hechtel-Eksel -+ Hecke -+ Hedie -+ Hedwig -+ Hedy -+ Heel -+ Heembeek -+ Heemskerker -+ Heemskerks -+ Heemstedenaar -+ Heemsteder -+ Heemsteeds -+ Heer -+ Heerdenaar -+ Heerder -+ Heerds -+ Heerenveens -+ Heerenvener -+ Heerhugowaarder -+ Heerhugowaards -+ Heerlenaar -+ Heerlens -+ Heerler -+ Heers -+ Hees -+ Heestert -+ Heeze-Leende -+ Heffen -+ Heidi -+ Heike -+ Heikruis -+ Heilige -+ Heilige Stoel -+ Heiloo -+ Heiloos -+ Heilooënaar -+ Heilooër -+ Heindonk -+ Heineken -+ Heist -+ Heist-aan-Zee -+ Heist-op-den-Berg -+ Heistenaar -+ Heists -+ Hekelgem -+ Heks -+ Helchteren -+ Helden -+ Heldenaar -+ Heldens -+ Helder -+ Heldergem -+ Helders -+ Heleen -+ Heleens -+ Helen -+ Helen-Bos -+ Helena -+ Helener -+ Helga -+ Helgoland -+ Helikon -+ Helkijn -+ Hella -+ Hella Haasse -+ Helleen -+ Hellehond -+ Hellendoornaar -+ Hellendoorner -+ Hellendoorns -+ Hellendorenaar -+ Hellenen -+ Hellepoorten -+ Heller -+ Helmondenaar -+ Helmonder -+ Helmonds -+ Helmonter -+ Helmut -+ Helsinkisch -+ Helsinkiër -+ Helvoeter -+ Helène -+ Hema -+ Hemelvaartsdag -+ Hemelveerdegem -+ Hemiksem -+ Hemiksemmenaar -+ Hemiksems -+ Hemingway -+ Henck -+ Henck Arron -+ Hendrickx -+ Hendrieken -+ Hendrik-Kapelle -+ Hendrika -+ Hendriks -+ Hendrikus -+ Hendrikus Colijn -+ Hengeloos -+ Hengeloër -+ Henis -+ Henjo -+ Henk -+ Henk-Jan -+ Henna -+ Hennie -+ Henny -+ Henri -+ Henri Matisse -+ Henriët -+ Henriëtte -+ Henry -+ Henry Ford -+ Heppen -+ Herbert -+ Hercules -+ Herdenkingsdag -+ Herderen -+ Herdersem -+ Heren -+ Heren XVII -+ Herenelderen -+ Herent -+ Herentals -+ Herentalsenaar -+ Herentenaar -+ Herenthout -+ Herents -+ Herfelingen -+ Herk -+ Herk-de-Stad -+ Herko -+ Herman -+ Herman Gorter -+ Herman Melville -+ Herman van Woerden -+ Hermans -+ Hermelgem -+ Hermen -+ Hermien -+ Hern -+ Herne -+ Hernekanaal -+ Herselt -+ Herstappe -+ Hertog -+ Hertogenbosch -+ Hertsberge -+ Herve -+ Hervormingsdag -+ Herzeeuw -+ Herzele -+ Hessel -+ Hester -+ Het -+ Het Laatste Nieuws -+ Het Parool -+ Heule -+ Heumenaar -+ Heumens -+ Heur -+ Heurne -+ Heusden-Zolder -+ Heusdenaar -+ Heusdens -+ Heuvel -+ Heuvelland -+ Heuvelrug -+ Heuven -+ Hever -+ Heverlee -+ Heverlees -+ Heverleese -+ Heverleeënaar -+ Heylen -+ Hichtum -+ Hidjaz -+ Hilda -+ Hilde -+ Hillegem -+ Hillegersberg -+ Hillegersberg-Schiebroek -+ Hillegommer -+ Hillegoms -+ Hilversums -+ Himalaya -+ Himalayaan -+ Himalayaans -+ Hinderwet -+ Hindoekoesj -+ Hingene -+ Hinlopen -+ Hirohito -+ Hiroshima -+ Hirsi -+ Hirsi Ali -+ Hitler -+ Hiëronymus -+ Ho -+ Ho Chi Minhstad -+ Hoangho -+ Hoboken -+ Hobokenaar -+ Hobokens -+ Hoegaarden -+ Hoei -+ Hoeienaar -+ Hoeilaart -+ Hoeis -+ Hoek -+ Hoek van Holland -+ Hoeke -+ Hoelbeek -+ Hoeleden -+ Hoensbroek -+ Hoensbroeker -+ Hoensbroeks -+ Hoepertingen -+ Hoeselt -+ Hoeven -+ Hoevenen -+ Hof -+ Hof van Twente -+ Hofmans -+ Hofmansaffaire -+ Hofstade -+ Hoge -+ Hoge Atlas -+ Hoge Raad -+ Hoge Tatra -+ Hoge Venen -+ Hollandia -+ Hollandser -+ Hollebeke -+ Holocaust -+ Holocaustoverlevenden -+ Holsbeek -+ Holstein -+ Holten -+ Hombeek -+ Homburg -+ Hondsrug -+ Hondsster -+ Honduras -+ Hondurees -+ Honecker -+ Hongersteppe -+ Hongerwinter -+ Honiara -+ Hoof -+ Hoofddorp -+ Hoofddorper -+ Hoofddorps -+ Hooge Zwaluwe -+ Hoogeveens -+ Hoogevener -+ Hoogezand -+ Hoogezander -+ Hoogezands -+ Hoogezandster -+ Hoogland -+ Hoogland van Auvergne -+ Hoogland van Bolivia -+ Hoogland van Brazilië -+ Hoogland van Dekan -+ Hoogland van Guyana -+ Hoogland van Iran -+ Hoogland van Mexico -+ Hoogland van Shaba -+ Hooglanden -+ Hooglede -+ Hoogstade -+ Hoogstraten -+ Hoogten -+ Hoogvlakte -+ Hoogvlakte van Nieuw-Kastilië -+ Hoogvlakte van Oud-Kastilië -+ Hoogvliet -+ Hoogwoud -+ Hoop -+ Hoorn -+ Hoorn van Afrika -+ Hoorns -+ Horebeke -+ Horenaar -+ Hormuz -+ Horpmaal -+ Horst -+ Horst aan de Maas -+ Horstenaar -+ Horster -+ Horsts -+ Houdini -+ Houtave -+ Houtem -+ Houten -+ Houthalen -+ Houthalen-Helchteren -+ Houthalenaar -+ Houthalens -+ Houthulst -+ Houtvenne -+ Houwaart -+ Hove -+ Hudson -+ Hugo -+ Hugo Brandt Corstius -+ Hugo Claus -+ Hugo de Groot -+ Huibrechts -+ Huis -+ Huise -+ Huissenaar -+ Huissens -+ Huizen -+ Huizenaar -+ Huizens -+ Huizer -+ Huizinga -+ Huizingen -+ Huldenberg -+ Hulshout -+ Hulst -+ Hulste -+ Hulstenaar -+ Hulster -+ Hulsters -+ Hulsts -+ Humbeek -+ Hun -+ Hundelgem -+ Hunnen -+ Hunspell -+ Hunze -+ Huub -+ Huygens -+ Hylke -+ Hymettos -+ Hz -+ ID -+ II -+ IJ -+ IJdel -+ IJdele -+ IJdeler -+ IJdelheden -+ IJdelheid -+ IJdellijk -+ IJdelst -+ IJdelste -+ IJdeltuit -+ IJdeltuiten -+ IJdeltuiterij -+ IJk -+ IJken -+ IJker -+ IJkers -+ IJkfunctie -+ IJking -+ IJkingen -+ IJkkantoor -+ IJkkantoren -+ IJkmaat -+ IJkmaten -+ IJkmeester -+ IJkmeesters -+ IJkmerk -+ IJkprijs -+ IJkpunt -+ IJkt -+ IJkte -+ IJkten -+ IJkwezen -+ IJl -+ IJlbode -+ IJlboden -+ IJlbodes -+ IJlde -+ IJlden -+ IJle -+ IJlen -+ IJler -+ IJlere -+ IJlgoed -+ IJlgoederen -+ IJlheid -+ IJlhoofden -+ IJlhoofdig -+ IJlhoofdige -+ IJlhoofdigheid -+ IJlhoofdigste -+ IJlings -+ IJlkoorts -+ IJlkoortsen -+ IJlst -+ IJlste -+ IJlt -+ IJltempo -+ IJmuiden -+ IJmuidenaar -+ IJmuidens -+ IJs -+ IJsafzetting -+ IJsafzettingen -+ IJsautomaat -+ IJsbaan -+ IJsbal -+ IJsballen -+ IJsbanen -+ IJsbeen -+ IJsbeer -+ IJsbeerde -+ IJsbeerden -+ IJsbeert -+ IJsbenen -+ IJsbereider -+ IJsbereiders -+ IJsberen -+ IJsberend -+ IJsberg -+ IJsbergen -+ IJsbergsla -+ IJsberichten -+ IJsbloemen -+ IJsblokje -+ IJsblokjes -+ IJsblokken -+ IJsbrand -+ IJsbreker -+ IJsbrekers -+ IJsclub -+ IJsclubs -+ IJsco -+ IJsco's -+ IJscokar -+ IJscokarren -+ IJscoman -+ IJscomannen -+ IJsdagen -+ IJsdansen -+ IJsde -+ IJsden -+ IJsdwergen -+ IJselijk -+ IJselijke -+ IJselijker -+ IJselijkheden -+ IJselijkheid -+ IJselijkst -+ IJselijkste -+ IJsemmer -+ IJsfabriek -+ IJsfabrikant -+ IJsgang -+ IJshal -+ IJsheilige -+ IJsheiligen -+ IJshockey -+ IJshockeyclub -+ IJshockeyen -+ IJshockeyer -+ IJshockeyspeler -+ IJshockeyteam -+ IJshockeywedstrijd -+ IJshut -+ IJsje -+ IJsjes -+ IJskanaal -+ IJskap -+ IJskast -+ IJskasten -+ IJskegel -+ IJskegels -+ IJskelder -+ IJskelders -+ IJskernen -+ IJsklomp -+ IJsklontje -+ IJsklontjes -+ IJskonijn -+ IJskoningin -+ IJskorst -+ IJskoud -+ IJskoude -+ IJskrabber -+ IJskristal -+ IJskristallen -+ IJslaag -+ IJslandrug -+ IJslolly -+ IJslolly's -+ IJsmachine -+ IJsman -+ IJsmassa -+ IJsmassa's -+ IJsmeester -+ IJsmerk -+ IJsmuts -+ IJspaleis -+ IJspegel -+ IJspegels -+ IJspiste -+ IJsploeg -+ IJsploegen -+ IJspret -+ IJspriem -+ IJsrace -+ IJsrevue -+ IJssalon -+ IJsschol -+ IJsschollen -+ IJsschots -+ IJsschotsen -+ IJsschuit -+ IJsschuiten -+ IJssculpturen -+ IJssculptuur -+ IJsselmonde -+ IJsselmuidenaar -+ IJsselmuidens -+ IJsselmuider -+ IJsselsteden -+ IJsselsteiner -+ IJsselsteins -+ IJsselstreek -+ IJsshow -+ IJsshows -+ IJssla -+ IJssoorten -+ IJssport -+ IJsstadion -+ IJsstoel -+ IJsstoelen -+ IJst -+ IJstaart -+ IJstang -+ IJsthee -+ IJstijd -+ IJstijden -+ IJsveld -+ IJsvelden -+ IJsventer -+ IJsventers -+ IJsvereniging -+ IJsverenigingen -+ IJsverkoper -+ IJsverkopers -+ IJsvermaak -+ IJsvlakte -+ IJsvlakten -+ IJsvlaktes -+ IJsvloer -+ IJsvogel -+ IJsvogels -+ IJsvorming -+ IJsvrij -+ IJswafel -+ IJswafels -+ IJswater -+ IJswinter -+ IJswolken -+ IJszak -+ IJszakken -+ IJszee -+ IJszeeën -+ IJszeilen -+ IJver -+ IJveraar -+ IJveraars -+ IJveraarster -+ IJveraarsters -+ IJverde -+ IJverden -+ IJveren -+ IJverig -+ IJverige -+ IJveriger -+ IJverigere -+ IJverigst -+ IJverigste -+ IJvert -+ IJverzucht -+ IJverzuchtig -+ IJverzuchtige -+ IJzel -+ IJzelde -+ IJzelen -+ IJzelt -+ IJzen -+ IJzer -+ IJzeraarde -+ IJzerachtig -+ IJzerachtige -+ IJzerbeslag -+ IJzerbijter -+ IJzerboor -+ IJzerboren -+ IJzerchloride -+ IJzerconstructie -+ IJzerdraad -+ IJzerdraden -+ IJzeren -+ IJzeren Poort -+ IJzerenheinig -+ IJzererts -+ IJzerertsen -+ IJzergaas -+ IJzergaren -+ IJzergebrek -+ IJzergehalte -+ IJzergieter -+ IJzergieterij -+ IJzergieterijen -+ IJzergieters -+ IJzerglans -+ IJzerhandel -+ IJzerhard -+ IJzerharde -+ IJzerhoudend -+ IJzerhoudende -+ IJzerhout -+ IJzerindustrie -+ IJzerkern -+ IJzermaal -+ IJzermijn -+ IJzeroer -+ IJzeroxide -+ IJzerpreparaat -+ IJzerpreparaten -+ IJzerroest -+ IJzers -+ IJzersmelterij -+ IJzersmelterijen -+ IJzerspaat -+ IJzersteen -+ IJzersterk -+ IJzersterke -+ IJzertabletten -+ IJzertekort -+ IJzertijd -+ IJzertje -+ IJzertjes -+ IJzervijl -+ IJzervijlen -+ IJzervijlsel -+ IJzervlechter -+ IJzervoorraad -+ IJzervreter -+ IJzervreters -+ IJzerwaren -+ IJzerwarenwinkel -+ IJzerwerk -+ IJzerwinkel -+ IJzerwinkels -+ IJzerzaag -+ IJzerzout -+ IJzig -+ IJzige -+ IJziger -+ IJzigere -+ IJzigheid -+ IJzigst -+ IJzigste -+ IJzing -+ IJzingen -+ IJzingwekkend -+ IJzingwekkende -+ IJzingwekkender -+ IJzingwekkendste -+ IMEI -+ IMF -+ IND -+ INL -+ IP -+ IP-adres -+ IR -+ ISDN -+ ISO -+ ISO 8859-1 -+ IT-bedrijf -+ ITU -+ Iberisch Randgebergte -+ Iberisch Schiereiland -+ Ibiza -+ Ibrahim -+ Ichtegem -+ Ida -+ Iddergem -+ Idegem -+ Idhra -+ Idi -+ Idi Amin -+ Ido -+ Ids -+ Ieper -+ Ieperaar -+ Ieperling -+ Iepers -+ Ierse Zee -+ Igoemenitsa -+ Igor -+ Iguaçu -+ Ilja -+ Ilona -+ Ilonka -+ Ilse -+ Impe -+ Impress -+ Ina -+ Inca -+ Indiaans -+ Indian -+ Indisch-Antarctisch Bekken -+ Indische Archipel -+ Indische Oceaan -+ Indischman -+ Indischmannen -+ Indië -+ Indiëganger -+ Indiëvaarder -+ Indiëvaarders -+ Indus -+ Ine -+ Ineke -+ Inge -+ Ingeborg -+ Ingelmunstenaar -+ Ingelmunster -+ Ingelmunsteraar -+ Ingelmunsters -+ Ingoesjetië -+ Ingooigem -+ Ingrid -+ Insterburg -+ Instituten -+ Instrumentum -+ Internationaal -+ Internationaal Strafhof -+ Internet -+ Internet Explorer -+ Ionische Eilanden -+ Ionische Zee -+ Iraki -+ Iraklion -+ Iranees -+ Irene -+ Iris -+ Irish -+ Irkoetsk -+ Irma -+ Irène -+ Isa -+ Isaac -+ Isaac Newton -+ Isaak -+ Isabel -+ Isabella -+ Isabelle -+ Ischa -+ Iseomeer -+ Isfahan -+ Iskariot -+ Ismailia -+ Ismaël -+ Istrië -+ Italiaans Schiereiland -+ Itegem -+ Ithaka -+ Itter -+ Itterbeek -+ Ivan -+ Ivan Pavlov -+ Ivan de Verschrikkelijke -+ Ivar -+ Ivo -+ Ivonne -+ Ivoorkust -+ Ivoriaan -+ Ivoriaans -+ Iwan -+ Izaäk -+ Izegem -+ Izegemmenaar -+ Izegems -+ Izenberge -+ J.R.R. -+ J.R.R. Tolkien -+ Jaap -+ Jabbeke -+ Jacco -+ Jachthonden -+ Jack -+ Jack Kerouac -+ Jackson -+ Jacob -+ Jacoba -+ Jacobien -+ Jacobs -+ Jacobus -+ Jacqueline -+ Jacques -+ Jacques-Yves Cousteau -+ Jadeboezem -+ Jadekanaal -+ Jagernath -+ Jagernath Lachmon -+ Jakartaan -+ Jakartaans -+ Jakartaas -+ Jakartaër -+ Jakob -+ Jakoetië -+ Jamai -+ Jamaica -+ Jamaicaan -+ Jamaicaans -+ James -+ James Joyce -+ James Watt -+ Jamestown -+ Jammerbocht -+ Jan -+ Jan Adriaenszoon Leeghwater -+ Jan Campert -+ Jan Cremer -+ Jan Harm -+ Jan Peter Balkenende -+ Jan Pieterszoon Coen -+ Jan Steen -+ Jana -+ Janabaai -+ Janet -+ Jangtse -+ Jangtsekiang -+ Janne -+ Janneke -+ Jannie -+ Jans -+ Janssens -+ Janszoon -+ Jantine -+ Japanse Binnenzee -+ Japanse Zee -+ Jarko -+ Jarkon -+ Jarno -+ Jasmijn -+ Jason -+ Jasper -+ Java -+ Javatrog -+ Javazee -+ Jean -+ Jean Jacques Rousseau -+ Jean-Luc Dehaene -+ Jean-Paul -+ Jean-Paul Sartre -+ Jeanet -+ Jeanette -+ Jeanine -+ Jeanne -+ Jeanne d'Arc -+ Jeannine -+ Jef -+ Jeff -+ Jefferson -+ Jeffrey -+ Jeker -+ Jelle -+ Jelles -+ Jelmar -+ Jelte -+ Jeltje -+ Jemeniet -+ Jemenitisch -+ Jennie -+ Jennifer -+ Jenny -+ Jens -+ Jeremy -+ Jericho -+ Jeroen Bosch -+ Jeroen Brouwers -+ Jerome -+ Jeruzalemmer -+ Jeruzalemmers -+ Jeruzalems -+ Jesaja -+ Jesse -+ Jesseren -+ Jessica -+ Jet -+ Jets -+ Jette -+ Jetteke -+ Jettenaar -+ Jeugdwerkgarantieplan -+ Jeuk -+ Jezus Christus -+ Jielis -+ Jillis -+ Jim -+ Jimmy -+ Jip -+ Jip en Janneke -+ Jizreël -+ Jo -+ Joachim -+ Joanna -+ Joannes -+ Jochem -+ Joden -+ Jodenbuurt -+ Jodenbuurten -+ Jodendom -+ Jodenhater -+ Jodenhaters -+ Jodenkerkhof -+ Jodenkerkhoven -+ Jodenmoord -+ Jodenpaasbroden -+ Jodenpaasbrood -+ Jodentaal -+ Jodenvernietiging -+ Jodin -+ Jodinnen -+ Jodinnetje -+ Jodinnetjes -+ Joegor -+ Joegoslavisch -+ Joegoslaviër -+ Joep -+ Joeri -+ Joeri Gagarin -+ Joes -+ Joffrey -+ Jogjakarta -+ Johan -+ Johan Huizinga -+ Johan van Oldenbarnevelt -+ Johann -+ Johann Sebastian Bach -+ Johanna -+ Johannes -+ Johannes Calvijn -+ Johannes Gutenberg -+ Johannes Paulus II -+ Johannes Vermeer -+ Johannes de Doper -+ John -+ John Cockerill -+ John F. Kennedy -+ John Lennon -+ John's -+ Jojanneke -+ Joke -+ Jola -+ Jolanda -+ Jolien -+ Joline -+ Jomanda -+ Jonathan -+ Jones -+ Jonesindex -+ Jong -+ Jonneke -+ Jonny -+ Jood -+ Joods -+ Joodse -+ Joodverklaring -+ Joop -+ Joop den Uyl -+ Joop van den Ende -+ Joost van den Vondel -+ Joost-ten-Nodenaar -+ Joostenaar -+ Joosts -+ Jordi -+ Jordy -+ Jorien -+ Jorinda -+ Jorinde -+ Joris -+ Jorrit -+ Jort -+ Joseph -+ Joseph Haydn -+ Joseph Heller -+ Joseph Luns -+ Josephina -+ Josephine -+ Josephus -+ Joshua -+ Josien -+ Josje -+ José -+ Jouke -+ Joyce -+ Jozef -+ Jozef Stalin -+ Jozefland -+ Jozias -+ Joël -+ Jr. -+ Juan -+ Juda -+ Judas -+ Judas Iskariot -+ Judas Taddeüs -+ Judea -+ Judith -+ Jules -+ Jules Verne -+ Julia -+ Juliana -+ Julie -+ Julien -+ Juliet -+ Juliette -+ Julische -+ Julische Alpen -+ Julius -+ Julius Caesar -+ Julius Civilis -+ Jur -+ Jurbeke -+ Jurgen -+ Justin -+ Justine -+ Jut -+ Jutland -+ Jutlander -+ Jutlands -+ Juts -+ K'ai -+ KDE -+ KI -+ KL -+ KLM -+ KLPD -+ KNIL -+ KNMI -+ KNVB -+ Kaap -+ Kaap Glossa -+ Kaap Hoorn -+ Kaap Matapan -+ Kaap Sideros -+ Kaap Sint-Vincent -+ Kaap Soenion -+ Kaap Verdebekken -+ Kaap de Goede Hoop -+ Kaapbekken -+ Kaapprovincie -+ Kaapstad -+ Kaapstads -+ Kaapstatter -+ Kaapvaarders -+ Kaaskerke -+ Kaat -+ Kabardië -+ Kabardië-Balkarië -+ Kaboel -+ Kaboeler -+ Kaboels -+ Kabylië -+ Kachtem -+ Kaffer -+ Kaffers -+ Kagerapark -+ Kaggevinne -+ Kalahari -+ Kales -+ Kaleziaan -+ Kaleziaans -+ Kalken -+ Kallo -+ Kalmoekië -+ Kalmthout -+ Kalmthoutenaar -+ Kalmthouts -+ Kalmukkië -+ Kamer -+ Kameroen -+ Kameroener -+ Kameroens -+ Kamervraag -+ Kamiel -+ Kampala -+ Kampen -+ Kampenaar -+ Kampenhout -+ Kampens -+ Kamper -+ Kampf -+ Kamtsjatka -+ Kan -+ Kanaal -+ Kanaal van Bristol -+ Kanaal van Malta -+ Kanaal van Otranto -+ Kanaal van Sicilië -+ Kanaaleilander -+ Kanaaleilands -+ Kanaalster -+ Kanaalzwemmen -+ Kanaalzwemster -+ Kanaäns -+ Kanegem -+ Kanne -+ Kanton -+ Kantonees -+ Kapela -+ Kapelle-op-den-Bos -+ Kapellen -+ Kapellenaar -+ Kapels -+ Kapenaar -+ Kaprijke -+ Karabach -+ Karakalpakië -+ Karakum -+ Karatsjaj -+ Karatsjaj-Tsjerkessië -+ Karawanken -+ Karazee -+ Karel -+ Karel Appel -+ Karel V -+ Karel de Grote -+ Karel de Stoute -+ Karelië -+ Karen -+ Karimata -+ Karin -+ Karina -+ Karinthisch -+ Karinthië -+ Karinthiër -+ Karische -+ Karische Poort -+ Karl -+ Karl Marx -+ Karlsbad -+ Karnische -+ Karnische Alpen -+ Karpaten -+ Karpater -+ Karpatisch -+ Karst -+ Karstplateau -+ Kasaï -+ Kasjmir -+ Kasper -+ Kaspische -+ Kaspische Laagte -+ Kaspische Zee -+ Kasteelbrakel -+ Kaster -+ Kasterlee -+ Kastiliaan -+ Kastiliaans -+ Kastiliaans Scheidingsgebergte -+ Kastilië -+ Katelijne -+ Katelijnenaar -+ Katelijns -+ Katharen -+ Katherina -+ Kathleen -+ Kathmandu -+ Katie -+ Katlijn -+ Katrien -+ Katrijn -+ Katwijker -+ Katwijks -+ Kaukasisch -+ Kaukasië -+ Kaukasiër -+ Kaukasus -+ Kaulille -+ Kazach -+ Kazachensteppe -+ Kazachs -+ Kazachse -+ Kazachse Bocht -+ Kazachse Rug -+ Kazachstan -+ Kazak -+ Kazakkensteppe -+ Kazaks -+ Kazakse -+ Kazakse Bocht -+ Kazakse Rug -+ Kazanlik -+ Kaïn -+ Kaïro -+ Kaïroot -+ Kaïrotisch -+ Keerbergen -+ Kees -+ Kefalonia -+ Keiem -+ Kelly -+ Kelmis -+ Kelt -+ Kelten -+ Keltische Zee -+ Kelvin -+ Kemmel -+ Kempen -+ Kempisch -+ Kemzeke -+ Kenitra -+ Kennedy -+ Kennemerland -+ Kennemers -+ Kenya -+ Kenyaan -+ Kenyaans -+ Kerkem -+ Kerkhove -+ Kerklatijn -+ Kerkom -+ Kerkom-bij-Sint-Truiden -+ Kerkraads -+ Kerkradenaar -+ Kerksken -+ Kermt -+ Kerniel -+ Kerouac -+ Kersbeek -+ Kersbeek-Miskom -+ Kerstman -+ Kessel-Lo -+ Kesselaar -+ Kessels -+ Kessenich -+ Kester -+ Kevin -+ Khartoem -+ Khartoemer -+ Khartoems -+ Khmer -+ Khomeini -+ Kieldrecht -+ Kieler -+ Kieler Bocht -+ Kiev -+ Kiezegem -+ Kigali -+ Kilimanjaro -+ Kim -+ Kimberly -+ Kinderboekenweek -+ Kinderkruistocht -+ King -+ Kingston -+ Kingstown -+ Kinrooi -+ Kinshasa -+ Kinshasaas -+ Kioto -+ Kiparissia -+ Kirgies -+ Kirgizisch -+ Kirgizië -+ Kirgizstan -+ Kiribati -+ Kiribatisch -+ Kiribatiër -+ Kirsten -+ Kisjon -+ Kitts -+ Kitty -+ Klaagmuur -+ Klaartje -+ Klaas -+ Klaasje -+ Klaassen -+ Klabbeek -+ Kleef -+ Kleefs -+ Klein -+ Klein Duimpje -+ Klein-Gelmen -+ Kleine -+ Kleine Antillen -+ Kleine Atlas -+ Kleine Balkan -+ Kleine Belt -+ Kleine Fatra -+ Kleine Kapela -+ Kleine Karpaten -+ Kleine Sint-Bernhardpas -+ Kleine Soenda-eilanden -+ Kleine-Brogel -+ Kleine-Spouwen -+ Klemskerke -+ Klerken -+ Klevenaar -+ Klever -+ Klinge -+ Kloosterlatijn -+ Kluisbergen -+ Kluizen -+ Knack -+ Knesselare -+ Knokke -+ Knokke-Heist -+ Knokkenaar -+ Knoks -+ Knut -+ Knut Folkerts -+ Ko -+ Kobbegem -+ Kobus -+ Koekelare -+ Koekelberg -+ Koekelbergenaar -+ Koekelbergs -+ Koen -+ Koerdistan -+ Koerilen -+ Koerilentrog -+ Koerland -+ Koerse -+ Koerse Haf -+ Koerse Schoorwal -+ Koersel -+ Koerselaar -+ Koersels -+ Koert -+ Koeweiter -+ Koeweiti -+ Koeweits -+ Koggenland -+ Kok -+ Koksijde -+ Kola -+ Kollumerland en Nieuwkruisland -+ Kolmont -+ Koloniën -+ Komen -+ Komen-Waasten -+ Komenaar -+ Komens -+ Koning -+ Koningin -+ Koningin Charlotte-eilanden -+ Koningin Elizabetheilanden -+ Koningshooikt -+ Koninklijk -+ Koninklijk Huis -+ Koninklijke -+ Koninkrijk -+ Koninksem -+ Kontich -+ Kontichenaar -+ Kontichs -+ Kooigem -+ Koolkerke -+ Koolskamp -+ Koos -+ Kopenhaags -+ Kopenhagenaar -+ Koraalzee -+ Koramshar -+ Koramsjar -+ Koran -+ Koranles -+ Korbeek -+ Korbeek-Dijle -+ Korbeek-Lo -+ Koreaan -+ Koreaans -+ Koreabaai -+ Koreanen -+ Korfoe -+ Korinthe -+ Korinthiër -+ Korjakië -+ Kornelis -+ Koror -+ Kortemark -+ Kortenaken -+ Kortenberg -+ Kortessem -+ Kortijs -+ Kortrijk -+ Kortrijk-Dutsel -+ Kortrijkenaar -+ Kortrijks -+ Kortrijkzaan -+ Kosovaren -+ Kosovo -+ Koster -+ Kota -+ Kota Radja -+ Kotor -+ Kowloon -+ Kozak -+ Kozakken -+ Kozen -+ Kra -+ Kraainem -+ Kraainemmenaar -+ Kraainems -+ Krakatau -+ Kralingen -+ Kralingen-Crooswijk -+ Kreeft -+ Kreeftskeerkring -+ Krenwik -+ Kreta -+ Kretenzisch -+ Krim -+ Krimgebergte -+ Krimmer -+ Krimpen -+ Krimpen aan den IJssel -+ Krimpenaar -+ Krimpener -+ Krimpens -+ Krims -+ Kris -+ Kristel -+ Kristen -+ Kristien -+ Kristof -+ Krol -+ Krombeke -+ Kruibeke -+ Kruis -+ Kruisauto -+ Kruishoutem -+ Kruispost -+ Kruisverheffing -+ Kruisvinding -+ Kruizenaar -+ Kuala -+ Kuala Lumpur -+ Kumtich -+ Kurenaar -+ Kurens -+ Kuringen -+ Kurt -+ Kustgebergte -+ Kustgebergte van Andalusië -+ Kustvlakte -+ Kuttekoven -+ Kuurnaar -+ Kuurne -+ Kuurns -+ Kuyper -+ KvK -+ Kwaadmechelen -+ Kwaremont -+ Kwerps -+ Kwintens -+ Kyzylkum -+ Körös -+ L.B. -+ LGPL -+ LTO -+ La -+ La Paz -+ Laagland -+ Laagland van Turan -+ Laagte -+ Laagvlakte -+ Laakdal -+ Laar -+ Laarbeek -+ Laarder -+ Laarne -+ Laatste -+ Laccadiven -+ Lachmon -+ Laconische -+ Laconische Golf -+ Laconië -+ Laden -+ Ladogameer -+ Laetitia -+ Lage -+ Lage Tatra -+ Lage Zwaluwe -+ Lagos -+ Lagosser -+ Laken -+ Lambrechtenaar -+ Lambrechts -+ Lammert -+ Lampernisse -+ Lanaken -+ Lancelot -+ Land -+ Land van Herve -+ Land van Waas -+ Landegem -+ Landen -+ Landengte -+ Landengte van Kra -+ Landengte van Panama -+ Landgraaf -+ Landskouter -+ Landstorm -+ Langdorp -+ Langemark -+ Langemark-Poelkapelle -+ Lanka -+ Lankaan -+ Lankaans -+ Lanklaar -+ Laos -+ Laotiaan -+ Laotiaans -+ Lapaceen -+ Lapaceens -+ Lapscheure -+ Laptevzee -+ Lara -+ Laren -+ Larenaar -+ Larens -+ Lars -+ Latakia -+ Latem -+ Laura -+ Laureins -+ Lauren -+ Laurens Janszoon Coster -+ Laurent -+ Laurentien -+ Lauw -+ Lauwe -+ Lauwers -+ Lawrencebaai -+ Lazarus -+ Lea -+ Lebbeeks -+ Lebbeke -+ Lebbekenaar -+ Lede -+ Ledeberg -+ Ledegem -+ Ledenaar -+ Ledes -+ Lee -+ Lee Harvey Oswald -+ Leeds -+ Leefdaal -+ Leeghwater -+ Leek -+ Leeks -+ Leekster -+ Leen -+ Leende -+ Leendert -+ Leentje -+ Leerbeek -+ Leerdammer -+ Leerdams -+ Leerne -+ Leest -+ Leeuw -+ Leeuwen -+ Leeuwenaar -+ Leeuwenhart -+ Leeuwergem -+ Leeuws -+ Leffinge -+ Leida -+ Leiden -+ Leidenaar -+ Leiderdorper -+ Leiderdorps -+ Leids -+ Leidsche -+ Leidsche Rijn -+ Leidschendammer -+ Leidschendams -+ Leidse -+ Leie -+ Leisele -+ Leisteenplateau -+ Lejzer -+ Lejzer Zamenhof -+ Leke -+ Leker -+ Lekkerland -+ Lembeek -+ Lembeke -+ Lemberge -+ Lemmens -+ Lena -+ Lenaarts -+ Lenaerts -+ Lendelede -+ Lengtedal -+ Lenin -+ Lenka -+ Lennart -+ Lennert -+ Lennik -+ Lennon -+ Leo -+ Leo Belgicus -+ Leonard -+ Leonardo -+ Leonardo da Vinci -+ Leone -+ Leoner -+ Leonie -+ Leontine -+ Leoons -+ Leopold -+ Leopoldsburg -+ Lerida -+ Lesbos -+ Lesothaan -+ Lesothaans -+ Lesotho -+ Lessen -+ Lessenaar -+ Lessenbos -+ Lessens -+ Letitia -+ Letland -+ Letse -+ Lettelingen -+ Letterhoutem -+ Leupegem -+ Leur -+ Leusdenaar -+ Leusdens -+ Leusder -+ Leut -+ Levi -+ Lewis -+ Lewis Carroll -+ Lex -+ Liam -+ Libanees -+ Libanon -+ Liberia -+ Liberiaan -+ Liberiaans -+ Libisch Plateau -+ Libische Woestijn -+ Libreville -+ Libreviller -+ Librevils -+ Lichtaart -+ Lichtenvoorder -+ Lichtenvoords -+ Lichtervelde -+ Lichtmis -+ Lidia -+ Lidwien -+ Liedeke -+ Liedekerke -+ Liedekerkenaar -+ Liedekerks -+ Lieferinge -+ Liek -+ Lieke -+ Lien -+ Lieneke -+ Lier -+ Lierde -+ Lierenaar -+ Liers -+ Lies -+ Liesa -+ Liesbet -+ Liesbeth -+ Lieselot -+ Lieve -+ Lieve-Vrouwebeeld -+ Lieve-Vrouwekerk -+ Lievens -+ Lieze -+ Liezele -+ Ligurisch -+ Ligurische -+ Ligurische Alpen -+ Ligurische Apennijnen -+ Ligurische Zee -+ Ligurië -+ Liguriër -+ Lijfland -+ Lijsem -+ Liliane -+ Lille -+ Lillo -+ Lilongwe -+ Lima -+ Limaas -+ Limasol -+ Limaër -+ Limeen -+ Limeens -+ Limes -+ Lincoln -+ Lindbergh -+ Linden -+ Lindsey -+ Linge -+ Lingewaard -+ Linkebeek -+ Linkhout -+ Linsmeel -+ Lint -+ Linter -+ Linus -+ Linus Torvalds -+ Linux-distributie -+ Liparische -+ Liparische Eilanden -+ Lippelo -+ Lisa -+ Lisbeth -+ Liset -+ Lisette -+ Lisp -+ Lissabonner -+ Lissabons -+ Lissenaar -+ Lisser -+ Lisses -+ Lissewege -+ Lister -+ Lister Diep -+ Lith -+ Liv -+ Livingstone -+ Lize -+ Ljubljana -+ Lo -+ Lo-Reninge -+ Lochemer -+ Lochems -+ Lochristi -+ Lode -+ Lodewijk -+ Lodewijk Napoleon -+ Loe -+ Loe de Jong -+ Loenhout -+ Loes -+ Loesje -+ Loevestein -+ Loiblpas -+ Loire -+ Loker -+ Lokeraar -+ Lokeren -+ Lokers -+ Loksbergen -+ Lombard -+ Lombardije -+ Lombardijer -+ Lombardiër -+ Lombardsijde -+ Lombeek -+ Lommel -+ Lommelaar -+ Lommels -+ Lommer -+ Lomonosovrug -+ Lomé -+ Londenaar -+ Londens -+ Londerzeel -+ Londerzeels -+ Londerzelenaar -+ Lonenaar -+ Long -+ Lonneke -+ Loon -+ Loon op Zand -+ Loonbeek -+ Loons -+ Loppem -+ Lossenaar -+ Losser -+ Lossernaar -+ Lossers -+ Lot -+ Lotenhulle -+ Lotharingen -+ Lotharinger -+ Lotharings -+ Lotte -+ Lou -+ Louis -+ Louis Couperus -+ Louis Pasteur -+ Louis Paul Boon -+ Louisa -+ Louise -+ Lourdes -+ Lousewies -+ Lovendegem -+ Lovenjoel -+ Luanda -+ Luandees -+ Lubbeek -+ Lubbers -+ Luca -+ Lucas -+ Luchtmobiele -+ Luchtmobiele Brigade -+ Lucia -+ Luciaan -+ Luciaans -+ Lucie -+ Lucien -+ Lucienne -+ Lucy -+ Ludo -+ Ludovicus -+ Ludwig -+ Ludwig van Beethoven -+ Lugano -+ Luilekkerland -+ Lummen -+ Lumpur -+ Luns -+ Lusaka -+ Lutgarde -+ Luther -+ Luthervertaling -+ Luxor -+ Luyten -+ Lydia -+ Lysanne -+ Lössplateau -+ Lübeck -+ Lübecker -+ Lübecker Bocht -+ M.G. -+ MA -+ MB -+ MBA -+ ME -+ MEK -+ MKZ-epidemie -+ MKZ-uitbraak -+ MKZ-virus -+ MOSFET -+ MRI -+ MSc -+ MW -+ Maagd -+ Maaike -+ Maarit -+ Maarke -+ Maarke-Kerkem -+ Maarkedal -+ Maarssenaar -+ Maarssens -+ Maarten -+ Maarten Luther -+ Maartenaar -+ Maartens -+ Maartje -+ Maas -+ Maasbrees -+ Maasbreese -+ Maaseik -+ Maasmechelen -+ Maassluizenaar -+ Maassluizer -+ Maasvlakte -+ Mabel -+ Macau -+ Macauer -+ Macaus -+ Machatsjkala -+ Machelen -+ Machiel -+ Madagaskar -+ Madagaskarbekken -+ Made -+ Madeleine -+ Madelene -+ Madoera -+ Madonna -+ Madonnabeeld -+ Madonnabeelden -+ Madras -+ Madre -+ Madrids -+ Madrileen -+ Madrileens -+ Madura -+ Maes -+ Magallanes -+ Magda -+ Magdalena -+ Magellaan -+ Magere -+ Magere Hein -+ Maghreb -+ Magnificat -+ Mahatma -+ Mahatma Gandhi -+ Mainz -+ Maja -+ Majesteit -+ Majesteits -+ Majuro -+ Makassar -+ Malabo -+ Malagassisch -+ Malagassiër -+ Malakka -+ Malawi -+ Malawimeer -+ Malawisch -+ Malawiër -+ Maldegem -+ Maldegemmenaar -+ Maldegems -+ Malderen -+ Maldiven -+ Maldivisch -+ Maldiviër -+ Malen -+ Mali -+ Malinees -+ Malle -+ Malta -+ Maltezer -+ Malé -+ Managua -+ Manamah -+ Mandeb -+ Mandela -+ Mandy -+ Manilla -+ Manilleen -+ Manilleens -+ Manita -+ Manja -+ Mannekensvere -+ Manon -+ Mantsjoerije -+ Mantsjoerijer -+ Mantsjoerijs -+ Mantua -+ Manuel -+ Mao -+ Mao Zedong -+ Maputo -+ Maracaibo -+ Marc -+ Marcel -+ Marcella -+ Marcia -+ Marco -+ Marco Polo -+ Marcus -+ Marcus Cicero -+ Margaretha -+ Margaretha van Parma -+ Margje -+ Margo -+ Margratenaar -+ Margratens -+ Margreet -+ Margriet -+ Margriete -+ Maria Magdalena -+ Mariaan -+ Mariaans -+ Mariakerke -+ Marian -+ Marianen -+ Marianentrog -+ Marianne -+ Marie -+ Marieke -+ Mariette -+ Marije -+ Marijke -+ Marijn -+ Marilyn -+ Marilyn Monroe -+ Marilène -+ Marinees -+ Marino -+ Marinus -+ Mario -+ Mariska -+ Marit -+ Maritsa -+ Marius -+ Mariënbad -+ Mariëtte -+ Marja -+ Marjan -+ Marjo -+ Marjolein -+ Marjolijn -+ Mark -+ Mark Twain -+ Marke -+ Markegem -+ Marken -+ Marker -+ Marko -+ Marleen -+ Marloes -+ Marmara -+ Marne-Rijnkanaal -+ Marnix -+ Marquesaseilanden -+ Marrakesh -+ Marrie -+ Mars -+ Marshalleilanden -+ Marshalleilander -+ Marshalleilands -+ Mart -+ Martaban -+ Marten -+ Marten Toonder -+ Martens -+ Martenslinde -+ Martha -+ Marthe -+ Martien -+ Martijn -+ Martin -+ Martin Luther King Jr. -+ Martina -+ Martine -+ Martinikaan -+ Martinikaans -+ Martinique -+ Martinus -+ Marum -+ Marx -+ Maseru -+ Maskarenenrug -+ Masqat -+ Massemen -+ Massenhoven -+ Massief -+ Matapan -+ Mater -+ Mathias -+ Mathieu -+ Mathijs -+ Mathilde -+ Matisse -+ Matterhorn -+ Matteüs -+ Mattheus -+ Mattheüs -+ Matthias -+ Matthys -+ Matty -+ Matâ'utu -+ Maud -+ Maurice -+ Mauritaans -+ Mauritanië -+ Mauritaniër -+ Mauritiaan -+ Mauritiaans -+ Mauritius -+ Maurits -+ Max -+ Max Havelaar -+ Maxim -+ Maxima -+ Maximiliaan -+ Maya -+ Mazenzele -+ Mazurisch -+ Mazurisch Merenplateau -+ Mb -+ Mbabane -+ Mbps -+ Meander -+ Mechelaar -+ Mechelen -+ Mechelen-Bovelingen -+ Mechelen-aan-de-Maas -+ Mechels -+ Mecklenburg -+ Mecklenburg-Voor-Pommeren -+ Mecklenburg-Vorpommern -+ Medy -+ Meens -+ Meensel -+ Meensel-Kiezegem -+ Meer -+ Meer van Genève -+ Meer van Lugano -+ Meer van Maracaibo -+ Meer van Ohrid -+ Meer van Shkodër -+ Meer van Tiberias -+ Meerbeek -+ Meerbeke -+ Meerdonk -+ Meerhout -+ Meerle -+ Meerlo -+ Meerssenaar -+ Meerssens -+ Mees -+ Meeswijk -+ Meetjesland -+ Meetjeslander -+ Meetjeslands -+ Meetkerke -+ Meeuwen -+ Meeuwen-Gruitrode -+ Mefisto -+ Meigem -+ Meijer -+ Meike -+ Meilegem -+ Mein -+ Mein Kampf -+ Meise -+ Mekkaan -+ Mekkaans -+ Mekkiet -+ Mekkitisch -+ Meknes -+ Mekong -+ Melanesisch -+ Melanesië -+ Melanesiër -+ Melanie -+ Melden -+ Meldert -+ Melissa -+ Melkweg -+ Melkwezer -+ Melle -+ Melos -+ Melsbroek -+ Melsele -+ Melsen -+ Melville -+ Membruggen -+ Memel -+ Menam -+ Mendonk -+ Menen -+ Menenaar -+ Meppelaar -+ Meppelder -+ Meppeler -+ Meppels -+ Merabelubaai -+ Merchtem -+ Merckx -+ Mercurius -+ Mere -+ Merelbeeks -+ Merelbeke -+ Merelbekenaar -+ Meren -+ Merendree -+ Merenplateau -+ Merenvlakte -+ Merkem -+ Merksem -+ Merksemmenaar -+ Merksems -+ Merksplas -+ Mertens -+ Mesen -+ Mespelare -+ Messelbroek -+ Messina -+ Meta -+ Mettekoven -+ Meulebeeks -+ Meulebeke -+ Meulebekenaar -+ Mexico-stad -+ Meyer -+ Meyerode -+ Micha -+ Michael -+ Michael Jackson -+ Michaël -+ Michel -+ Michelangelo -+ Michelbeke -+ Michelle -+ Michiel -+ Michiel Adriaenszoon de Ruyter -+ Michiel de Ruyter -+ Michiels -+ Michielsgestel -+ Michielsgestels -+ Mick -+ Mickey -+ Micronesia -+ Micronesisch -+ Micronesië -+ Micronesiër -+ Middelaar -+ Middelkerke -+ Middellandse -+ Middellandse Zee -+ Midden -+ Midden-Amerikatrog -+ Midden-Atlantische Rug -+ Midden-Atlas -+ Midden-Delfland -+ Midden-Drenthe -+ Midden-Siberisch Bergland -+ Midwesten -+ Mieke -+ Mielen -+ Mielen-boven-Aalst -+ Miep -+ Mijdrecht -+ Mijdrechter -+ Mijdrechts -+ Mijndert -+ Mike -+ Mikhail -+ Mikhail Gorbatsjov -+ Mikonos -+ Milaan -+ Milan -+ Milanees -+ Mill -+ Mill en Sint Hubert -+ Millen -+ Milou -+ Mimi -+ Minderhout -+ Minhstad -+ Mink -+ Minke -+ Minorca -+ Minsk -+ Miquelon -+ Miranda -+ Mirjam -+ Mirte -+ Misha -+ Misja -+ Miskom -+ Mississippi -+ Missouri -+ Mitch -+ Mitchel -+ Mladic -+ Moeder -+ Moeder Theresa -+ Moederdag -+ Moelingen -+ Moen -+ Moens -+ Moerbeke -+ Moerbeke-Waas -+ Moerdijk -+ Moere -+ Moeren -+ Moerkerke -+ Moermankust -+ Moermansk -+ Moerzeke -+ Moeskroen -+ Moeskroenenaar -+ Moeskroens -+ Moezel -+ Mogadishu -+ Mohamed -+ Mohammed Ali -+ Mohikaan -+ Mohikanen -+ Mol -+ Moldau -+ Moldavisch -+ Moldavië -+ Moldaviër -+ Molenbeek -+ Molenbeek-Wersbeek -+ Molenbeeks -+ Molenbeersel -+ Molenbekenaar -+ Molenstede -+ Mollem -+ Mollenaar -+ Mols -+ Molukse Zee -+ Mona -+ Mona Lisa -+ Monaco -+ Monapassage -+ Mondriaan -+ Monegask -+ Monegaskisch -+ Mongoolse Altaj -+ Monica -+ Moniek -+ Monique -+ Monroe -+ Monrovia -+ Monroviaan -+ Monroviaans -+ Monster -+ Monsteraar -+ Mont -+ Mont Blanc -+ Mont Ventoux -+ Montenaken -+ Montenegrijn -+ Montenegrijns -+ Montenegro -+ Montevideaan -+ Montevideaans -+ Montevideo -+ Montferland -+ Montserrat -+ Montserrataan -+ Montserrataans -+ Mook -+ Mook en Middelaar -+ Moor -+ Moors -+ Moorse -+ Moorsel -+ Moorsele -+ Moorslede -+ Moortsele -+ Mopertingen -+ Morava -+ Moravische Poort -+ Moravië -+ Moraviër -+ Mordovië -+ Moregem -+ Moren -+ Moresby -+ Morgen -+ Morgenland -+ Morkhoven -+ Moroni -+ Mortsel -+ Mortselaar -+ Mortsels -+ Moskouer -+ Moskous -+ Moskovitisch -+ Moslim -+ Moslim-Kroatische Federatie -+ Mostar -+ Mounir -+ Mount -+ Mount Everest -+ Mozambikaan -+ Mozambikaans -+ Mozambique -+ Mozart -+ Mozes -+ Mozilla -+ Muiderslot -+ Muizen -+ Mulder -+ Mullem -+ Multatuli -+ Munkzwalm -+ Munsteraar -+ Munsterbilzen -+ Munte -+ Mussolini -+ Mustafa -+ MySQL -+ MySpell -+ Mycene -+ Mykene -+ Myriam -+ Máxima -+ Máxima Zorreguieta -+ Mälarmeer -+ N.B. -+ N.H. -+ N.N. -+ N.O. -+ N.V. -+ N.W. -+ NAM -+ NAP -+ NASA -+ NLNet -+ NOS -+ NRC -+ NSB -+ NSDAP -+ NTG -+ NTU -+ Naaldwijker -+ Naaldwijks -+ Naardenaar -+ Naardens -+ Naarder -+ Nabije -+ Nabije Oosten -+ Nablus -+ Nachitsjevan -+ Nadette -+ Nadia -+ Nadine -+ Nadjd -+ Nagasaki -+ Nagorno -+ Nagorno-Karabach -+ Nairobi -+ Nairobisch -+ Namibisch -+ Namibië -+ Namibiër -+ Nancy -+ Nanda -+ Nanjing -+ Nanking -+ Nankinger -+ Nankings -+ Naomi -+ Napels -+ Napoleon -+ Napoleon Bonaparte -+ Napolitaan -+ Napolitaans -+ Nares -+ Nassau -+ Nassauer -+ Nassaus -+ Natasja -+ Nathalie -+ Nationaal -+ Nationaal Volkscongres -+ Naturalisatiedag -+ Nauplion -+ Nauru -+ Nauruaan -+ Nauruaans -+ Nauw -+ Navajo -+ Nazareth -+ Ndjamena -+ Ned. -+ Neder -+ Neder-Betuwe -+ Neder-Californië -+ Neder-Congo -+ Neder-Guinee -+ Neder-Oostenrijk -+ Neder-over-Heembeek -+ Nederboelare -+ Nederbrakel -+ Nederename -+ Nederhasselt -+ Nederlands Antilliaan -+ Nederlands Antilliaans -+ Nederlandse Antillen -+ Nederlandse Hartstichting -+ Nederlandse Taalunie -+ Nederokkerzeel -+ Nederweerter -+ Nederweerts -+ Nederzwalm -+ Nederzwalm-Hermelgem -+ Neelie -+ Neeltje -+ Neer -+ Neerglabbeek -+ Neerharen -+ Neerhespen -+ Neerijnens -+ Neerijse -+ Neerlanden -+ Neerlinter -+ Neeroeteren -+ Neerpelt -+ Neerrepen -+ Neervelp -+ Neerwaasten -+ Neerwinden -+ Neigem -+ Neil -+ Neil Armstrong -+ Neisse -+ Neissegrens -+ Nele -+ Nelis -+ Nellie -+ Nelly -+ Nelson -+ Nelson Mandela -+ Neptunus -+ Nerem -+ Nero -+ Neurenberger -+ Neurenbergs -+ Neusiedler -+ Neusiedler Meer -+ Nevele -+ Nevis -+ New -+ New Delhi -+ New Delhisch -+ New Delhiër -+ New York Times -+ Newfoundlander -+ Newton -+ NiCd -+ NiMH -+ Niagara -+ Niamey -+ Nicaragua -+ Nicaraguaan -+ Nicaraguaans -+ Nicaraguaanse -+ Nick -+ Nicky -+ Nico -+ Nicobaren -+ Nicolaas -+ Nicolaas Beets -+ Nicolas -+ Nicole -+ Nicosia -+ Niederösterreich -+ Niek -+ Niel -+ Niel-bij-As -+ Niel-bij-Sint-Truiden -+ Nielke -+ Niels -+ Nienke -+ Nienke van Hichtum -+ Nietzsche -+ Nieuw -+ Nieuw-Caledonisch -+ Nieuw-Caledonië -+ Nieuw-Caledoniër -+ Nieuw-Guinea -+ Nieuw-Kastilië -+ Nieuw-Siberische Eilanden -+ Nieuw-Zeelandse Alpen -+ Nieuw-Zuid-Wales -+ Nieuwe -+ Nieuwe Pekela -+ Nieuwegeiner -+ Nieuwegeins -+ Nieuwenhove -+ Nieuwenhuis -+ Nieuwenrode -+ Nieuwerkerk aan den IJssel -+ Nieuwerkerken -+ Nieuwerkerker -+ Nieuwerkerks -+ Nieuwjaar -+ Nieuwkapelle -+ Nieuwkerke -+ Nieuwkerken -+ Nieuwkerken-Waas -+ Nieuwkoop -+ Nieuwkruisland -+ Nieuwmunster -+ Nieuwpoort -+ Nieuwrode -+ Nieuws -+ Niger -+ Nigerees -+ Nijkerker -+ Nijkerks -+ Nijl -+ Nijldal -+ Nijlen -+ Nijlenaar -+ Nijlens -+ Nijmeegs -+ Nijmegenaar -+ Nijntje -+ Nijs -+ Nijvel -+ Nijvelaar -+ Nijvels -+ Niklaas -+ Niklazenaar -+ Niko -+ Nikolaas -+ Nina -+ Ninoofs -+ Ninove -+ Ninovenaar -+ Ninovieter -+ Niue -+ Noa -+ Noach -+ Nobel -+ Node -+ Nodenaar -+ Nokere -+ Noods -+ Noord -+ Noord-Amerika -+ Noord-Amerikaans Bekken -+ Noord-Bevelander -+ Noord-Bevelands -+ Noord-Chinees Bergland -+ Noord-Duitse Laagvlakte -+ Noord-Equatoriale Rug -+ Noord-Friese Waddeneilanden -+ Noord-Friesland -+ Noord-Koreaan -+ Noord-Koreaans -+ Noord-Oostzeekanaal -+ Noord-Ossetië -+ Noord-Russische Rug -+ Noord-Tiroler Alpen -+ Noordelijk -+ Noordelijk Territorium -+ Noordelijke -+ Noordelijke IJszee -+ Noordelijke Marianen -+ Noordenveld -+ Noorder -+ Noordereiland -+ Noorderkanaal -+ Noorderwijk -+ Noordkaap -+ Noordland -+ Noordoostelijke -+ Noordoostelijke Doorvaart -+ Noordoostpolders -+ Noordpool -+ Noordpoolexpeditie -+ Noordpoolexpedities -+ Noordschote -+ Noordster -+ Noordwestelijke -+ Noordwestelijke Doorvaart -+ Noordwestkaap -+ Noordwijker -+ Noordwijkerhouter -+ Noordwijkerhouts -+ Noordwijks -+ Noordzeebekken -+ Noorman -+ Noormannen -+ Noorse Bekken -+ Noorse Zee -+ Noortje -+ Nora -+ Norbert -+ Nordrhein -+ Nordrhein-Westfalen -+ Norfolk -+ Norfolkeilander -+ Norfolkeilands -+ Normandisch -+ Normandië -+ Normandiër -+ Northumbrië -+ Norwin -+ Nossegem -+ Nostradamus -+ Nouakchott -+ Noud -+ Nouméa -+ Nova -+ Novo -+ Novum -+ Novum Instrumentum -+ Nubische -+ Nubische Woestijn -+ Nubië -+ Nudorp -+ Nukerke -+ Nuku'alofa -+ Nunspeets -+ Nunspeter -+ Nuth -+ Nuts -+ Nutter -+ Nuuk -+ Nynke -+ Nürnberg -+ O-benen -+ O.L.V. -+ OHM -+ OKAN -+ OPEC -+ Obboezem -+ Obeid -+ Oberösterreich -+ Oceaan -+ Oceanisch -+ Oceanië -+ Oceaniër -+ Ochotsk -+ Oder -+ Oderhaf -+ Odessa -+ Odette -+ Odoorn -+ Odoornaar -+ Odoorner -+ Odoorns -+ Odorenaar -+ Oedelem -+ Oedenrode -+ Oedenrodenaar -+ Oedenroods -+ Oedipus -+ Oedmoertië -+ Oeganda -+ Oegandees -+ Oegrisch -+ Oegrische -+ Oegstgeestenaar -+ Oegstgeester -+ Oegstgeests -+ Oekene -+ Oekraïner -+ Oelegem -+ Oeral -+ Oeraller -+ Oeren -+ Oerle -+ Oeselgem -+ Oetingen -+ Oevel -+ Oezbeek -+ Oezbeeks -+ Oezbeekse -+ Oezbekistan -+ Officepakket -+ Ohrid -+ Oirschot -+ Oirschots -+ Oirschottenaar -+ Oisterwijker -+ Oisterwijks -+ Okegem -+ Olaf -+ Olav -+ Oldebroeker -+ Oldebroeks -+ Oldenbarnevelt -+ Oldenzaals -+ Oldenzaler -+ Oleg -+ Olen -+ Olga -+ Oliver -+ Oliver Cromwell -+ Olivia -+ Olivier -+ Olmen -+ Olsene -+ Olst -+ Olst-Wijhe -+ Olympisch -+ Omaans -+ Omaars -+ Omani -+ Omdurman -+ Ommelanden -+ Ommelander -+ Ommenaar -+ Ommens -+ Ommer -+ Onderwijsbond -+ Onderwijsbond CNV -+ Onegameer -+ Onkerzele -+ Onstwedde -+ Onstwedder -+ Onstweds -+ Onze -+ Onze-Lieve-Vrouw-Lombeek -+ Onze-Lieve-Vrouw-Waver -+ Onzevader -+ Onzevaders -+ Onzienlijke -+ Ooigem -+ Ooike -+ Oombergen -+ Oorbeek -+ Oordegem -+ Oost-Afrikaans Hoogland -+ Oost-Chinese Zee -+ Oost-Friese Waddeneilanden -+ Oost-Friesland -+ Oost-Ghats -+ Oost-Indisch doof -+ Oost-Karpaten -+ Oost-Kasaï -+ Oost-Pacifische Rug -+ Oost-Pruisen -+ Oost-Siberische Zee -+ Oost-Timor -+ Oost-Timorees -+ Oost-Tirol -+ Oostakker -+ Oostburgenaar -+ Oostburger -+ Oostburgs -+ Oostduinkerke -+ Oosteeklo -+ Oostelijke -+ Oostelijke Cordillera -+ Oostelijke Grote Erg -+ Oostelijke Sierra Madre -+ Oosten -+ Oostenbeleid -+ Oostende -+ Oostendenaar -+ Oostends -+ Oostenrijkse Alpen -+ Oostenrijkse Hoogvlakte -+ Oosterhouter -+ Oosterhouts -+ Oosters -+ Oosterschelde -+ Oosterzele -+ Oostham -+ Oostkaap -+ Oostkamp -+ Oostkampenaar -+ Oostkamps -+ Oostkerk -+ Oostkerke -+ Oostmalle -+ Oostnieuwkerke -+ Oostrozebeke -+ Oostvleteren -+ Oostwinkel -+ Oostzeekanaal -+ Opbrakel -+ Opdorp -+ OpenDocument -+ OpenTaal -+ Opgeldenaken -+ Opglabbeek -+ Opgrimbie -+ Ophasselt -+ Opheers -+ Ophoven -+ Opitter -+ Opleeuw -+ Oplinter -+ Opmeer -+ Opmeerder -+ Opmeers -+ Opoeteren -+ Oppem -+ Oppems -+ Opper -+ Opper-Congo -+ Opper-Guinee -+ Opper-Karabach -+ Opper-Oostenrijk -+ Oppuurs -+ Opvelp -+ Opwijk -+ Opzullik -+ Oracle -+ Oran -+ Oranje -+ Oranje Vrijstaat -+ Oranje-Nassau -+ Oranjegevoel -+ Oranjeklant -+ Oranjestads -+ Oranjestatter -+ Ordingen -+ Oriënt -+ Orontes -+ Orsmaal -+ Orsmaal-Gussenhoven -+ Ortlergroep -+ Orwell -+ Osama -+ Osama Bin Laden -+ Oscar -+ Oscar Wilde -+ Osdorp -+ Oskar -+ Osloos -+ Osloër -+ Osmaan -+ Osmaans -+ Osmanen -+ Osogovgebergte -+ Oss -+ Ossenaar -+ Ossetië -+ Ossip -+ Ossip Zadkine -+ Ostaijen -+ Oswald -+ Otegem -+ Otranto -+ Ottawa -+ Ottawaan -+ Ottawaans -+ Ottawaas -+ Ottawaër -+ Ottenburg -+ Ottergem -+ Ottomaan -+ Ottomaans -+ Ottomaanse -+ Ottomanen -+ Ouagadougou -+ Oud -+ Oud-Beijerlander -+ Oud-Beijerlands -+ Oud-Castilië -+ Oud-Heverlee -+ Oud-Turnhout -+ Oud-West -+ Oud-Zuid -+ Oude -+ Oude IJssel -+ Oude IJsselstreek -+ Oude Pekela -+ Oudegem -+ Oudekapelle -+ Oudeman -+ Oudenaarde -+ Oudenaardenaar -+ Oudenaardist -+ Oudenaards -+ Oudenaken -+ Oudenbossche -+ Oudenbosschenaar -+ Oudenburg -+ Oudengelse -+ Oudenhove -+ Ouder -+ Oudergem -+ Oudergemmenaar -+ Oudergems -+ Oudeschip -+ Outer -+ Outgaarden -+ Outrijve -+ Ouwegem -+ Over -+ Over-Betuwe -+ Overbetuwe -+ Overboelare -+ Overflakkee -+ Overflakkees -+ Overflakkeeër -+ Overhespen -+ Overijse -+ Overijsenaar -+ Overijses -+ Overmazer -+ Overmere -+ Overpelt -+ Overpeltenaar -+ Overpelts -+ Overrepen -+ Overschie -+ Overwinden -+ PDF -+ PEMBA -+ PEN -+ PET -+ PHP -+ Paal -+ Paaseiland -+ Pablo -+ Pablo Picasso -+ Pacifisch -+ Pacifisch-Antarctisch Bekken -+ Pacifische -+ Padua -+ Paduaan -+ Paduaans -+ Pago -+ Pago Pago -+ Pajot -+ Pajots -+ Pajottenland -+ Pajottenlander -+ Pajottenlands -+ Palau -+ Palembang -+ Palestijn -+ Palestijnen -+ Palikir -+ Palk -+ Palmoliekust -+ Paltisch -+ Palts -+ Paltser -+ Paltserin -+ Paltsisch -+ Pam -+ Pamel -+ Pamela -+ Pampus -+ Panama -+ Panama-stad -+ Panamakanaal -+ Pandora -+ Panne -+ Paola -+ Papeete -+ Papegem -+ Papendrechter -+ Papendrechts -+ Papoea's -+ Papoea-Nieuw-Guinea -+ Para -+ Paraguay -+ Paraguayaan -+ Paraguayaans -+ Paraguees -+ Paralympics -+ Paraná -+ Parelrivier -+ Parike -+ Parma -+ Parmezaans -+ Parmezaanse -+ Parmezanen -+ Parnassus -+ Parool -+ Parwijs -+ Pascal -+ Pascalle -+ Passage -+ Passendale -+ Pasteur -+ Patagonisch -+ Patagonië -+ Patagoniër -+ Paternoster -+ Paternosters -+ Patras -+ Patricia -+ Patrick -+ Patty -+ Paul Gauguin -+ Paul Verhoeven -+ Paul van Ostaijen -+ Paula -+ Paulatem -+ Paulette -+ Paulien -+ Pauline -+ Paulus -+ Pauw -+ Pauwel -+ Pauwels -+ Pavel -+ Pavlov -+ Paz -+ Peels -+ Peer -+ Peeters -+ Peipusmeer -+ Peking -+ Pekingees -+ Pekinger -+ Pekings -+ Pelagische -+ Pelagische Eilanden -+ Pelenaar -+ Pellen -+ Pellenberg -+ Peloponnesisch -+ Peloponnesiër -+ Peloponnesos -+ Peloponnesus -+ Pelé -+ Penghueilanden -+ Penninisch -+ Penninisch Gebergte -+ Peperkust -+ Pepingen -+ Perk -+ Perl -+ Pernilla -+ Pernille -+ Pernis -+ Pers -+ Pervijze -+ Perwijs -+ Perzische Golf -+ Pescadores -+ Peshawar -+ Pesjawar -+ Petalia -+ Petegem -+ Petegem-aan-de-Leie -+ Petegem-aan-de-Schelde -+ Peter -+ Peters -+ Petersburg -+ Petertje -+ Petra -+ Petrem -+ Petronella -+ Petrus -+ Petsjorabaai -+ Peutie -+ Pfalz -+ PhD -+ Philip -+ Philippe -+ Phnom-Penh -+ Pia -+ Picardisch -+ Picardië -+ Picardiër -+ Pieck -+ Pier -+ Pierre -+ Piet -+ Piet Mondriaan -+ Pieter -+ Pieter Jelles Troelstra -+ Pieter Pauwel Rubens -+ Pieteraar -+ Pieternel -+ Pieters -+ Pietersberg -+ Pieterszoon -+ Pijnackenaar -+ Pijnackeraar -+ Pijnackers -+ Pilatus -+ Pilsen -+ Pim -+ Pim Fortuyn -+ Pinatubo -+ Pindosgebergte -+ Pink -+ Pink Floyd -+ Pinte -+ Piraeus -+ Piringen -+ Pitcairneilanden -+ Pitcairneilander -+ Pitcairneilands -+ Pittem -+ Pityusen -+ Pjotr -+ Plakkaat -+ Plakkaat van Verlatinghe -+ Plantijn -+ Platamsterdams -+ Plateau -+ Plateau van Lotharingen -+ Plato -+ Plejaden -+ Pleun -+ Pleunie -+ Pluto -+ Plymouth -+ Po -+ Pocahontas -+ Podgorica -+ Podolisch -+ Podolië -+ Poe -+ Poederlee -+ Poeke -+ Poelkapelle -+ Poesele -+ Poetin -+ Polesië -+ Pollare -+ Pollinkhove -+ Polo -+ Pommeren -+ Pommers -+ Pommers Merenplateau -+ Pommerse -+ Pommerse Bocht -+ Pompeii -+ Pontisch -+ Pontisch Gebergte -+ Pontius -+ Pontius Pilatus -+ Pools Laagland -+ Poona -+ Poopomeer -+ Poort -+ Poort van Trajanus -+ Poortugaal -+ Poortugaals -+ Poortugaler -+ Poperinge -+ Poperingenaar -+ Poperings -+ Poppel -+ Port -+ Port Louis -+ Port Moresby -+ Port Said -+ Port Sudan -+ Port Vila -+ Port of Spain -+ Port-au-Prince -+ Porto -+ Porto-Novo -+ Portugeestalige -+ Postbank -+ Povlakte -+ Praia -+ Prakrit -+ Preanger -+ Predilpas -+ Prespameer -+ Pretoria -+ Pretoriaans -+ Prince -+ Principe -+ Prins -+ Prins Alexander -+ Prins Edwardeiland -+ Prinsjesdag -+ Prinsjesdagen -+ Pripjatmoerassen -+ Pristina -+ Proet -+ Profeet -+ Proven -+ Provincies -+ Puerto -+ Pulderbos -+ Pulle -+ Punios -+ Purmerender -+ Purmerends -+ Putte -+ Putten -+ Puttenaar -+ Puttens -+ Puurs -+ PvdD -+ PvdD'er -+ PvdD'ers -+ PvdD-leden -+ PvdD-lid -+ PvdV -+ PvdV'er -+ PvdV'ers -+ PvdV-leden -+ PvdV-lid -+ Pyinmana -+ Pyongyang -+ Pyreneeër -+ Pythagoras -+ Python -+ Pérouse -+ Qatarees -+ Qatari -+ Quirina -+ Quirine -+ Quiteen -+ Quiteens -+ Quito -+ Quitoos -+ Quitoër -+ R.I.P. -+ RAM -+ RDW -+ RFID -+ RGB -+ RIVM -+ RNA -+ RSI -+ Raad -+ Raaltenaar -+ Raalter -+ Raalts -+ Raamsdonkenaar -+ Raamsdonks -+ Raatshoven -+ Rabat -+ Rachel -+ Radja -+ Raes -+ Raf -+ Rafael -+ Rafaël -+ Ralf -+ Ram -+ Ramallah -+ Ramon -+ Ramona -+ Ramsdonk -+ Ramsel -+ Ramses -+ Ramskapelle -+ Randgebergte -+ Randstad -+ Randstadbundel -+ Randstedelijk -+ Rangoon -+ Rangooner -+ Rangoons -+ Ransberg -+ Ranst -+ Raph -+ Ravels -+ Ray -+ Ray Bradbury -+ Raymond -+ Rebekka -+ Rechtseenheidskamer -+ Rede -+ Rede van Brest -+ Reest -+ Reet -+ Reeuwijk -+ Regge -+ Reimert -+ Rein -+ Reindert -+ Reinhard -+ Reinier -+ Reinout -+ Rekem -+ Rekenhof -+ Rekkem -+ Relegem -+ Rembrandt van Rijn -+ Remco -+ Remersdaal -+ Remigius -+ Remon -+ Renelde -+ Reninge -+ Reningelst -+ Renkumer -+ Renkums -+ Rens -+ Renske -+ Renze -+ René Descartes -+ Reppel -+ Republiek -+ Republiek Sacha -+ Ressegem -+ Rethimnon -+ Retie -+ Reuters -+ Reuzengebergte -+ Reve -+ Reykjaviker -+ Reykjaviks -+ Rhedenaar -+ Rhedens -+ Rheinland -+ Rheinland-Pfalz -+ Rhenenaar -+ Rhenens -+ Rhône -+ Rhône-Rijnkanaal -+ Ria -+ Rianne -+ Rica -+ Ricaan -+ Ricaans -+ Ricardo -+ Richard -+ Richard Leeuwenhart -+ Richard M. Stallman -+ Rick -+ Ricky -+ Rico -+ Ridder -+ Ridderkerker -+ Ridderkerks -+ Riemer -+ Riemst -+ Rien -+ Rieneke -+ Rienk -+ Ries -+ Riet -+ Rietveld -+ Rifgebergte -+ Riga -+ Rijeka -+ Rijen -+ Rijenaar -+ Rijens -+ Rijk -+ Rijkel -+ Rijkers -+ Rijkevorsel -+ Rijkhoven -+ Rijksgebouwendienst -+ Rijksluchtvaartdienst -+ Rijkspostspaarbank -+ Rijksverzekeringsbank -+ Rijksvoorlichtingsdienst -+ Rijkswaterstaat -+ Rijmenam -+ Rijn -+ Rijn-Hernekanaal -+ Rijnkanaal -+ Rijnland -+ Rijnland-Palts -+ Rijnsburger -+ Rijnsburgs -+ Rijnse -+ Rijnvaartakte -+ Rijp -+ Rijsel -+ Rijselaar -+ Rijselnaar -+ Rijsels -+ Rijsenburg -+ Rijssenaar -+ Rijssender -+ Rijssens -+ Rijswijker -+ Rijswijks -+ Rik -+ Riksingen -+ Rillaar -+ Rineke -+ Rinus -+ Rinze -+ Rio Grande -+ Rio de Janeiro -+ Riouwarchipel -+ Rita -+ Riukiueilanden -+ Rivier -+ Rixtel -+ Riyad -+ Road -+ Road Town -+ Rob -+ Robaais -+ Robbert -+ Robert -+ Robert Jan -+ Robin -+ Roborst -+ Rock -+ Rode -+ Rode Bekken -+ Rode Kruisauto -+ Rode Kruispost -+ Rode Rivier -+ Rode Torenpas -+ Rode Zee -+ Roden -+ Rodenaar -+ Rodener -+ Rodens -+ Roder -+ Roderick -+ Rodin -+ Rodopegebergte -+ Roel -+ Roeland -+ Roelof -+ Roels -+ Roer -+ Roermondenaar -+ Roermonder -+ Roermonds -+ Roesbrugge -+ Roesbrugge-Haringe -+ Roeselaars -+ Roeselare -+ Roeselarenaar -+ Roger -+ Roggel en Neer -+ Rogier -+ Roksem -+ Roland -+ Rolde -+ Rolf -+ Rollegem -+ Rollegem-Kapelle -+ Rolling -+ Romandië -+ Romanen -+ Romeo -+ Romeo en Julia -+ Romershoven -+ Romy -+ Ron -+ Ronald -+ Ronaldo -+ Ronde -+ Ronny -+ Ronse -+ Ronsele -+ Ronsenaar -+ Ronses -+ Roods -+ Rooms -+ Roos -+ Roosbeek -+ Roosdaal -+ Roosendaalder -+ Roosendaals -+ Roosendaler -+ Roosevelt -+ Roosmarijn -+ Roost -+ Roost-Krenwik -+ Rosa -+ Rosan -+ Rosanna -+ Roseau -+ Rosie -+ Rosita -+ Rosmalenaar -+ Rosmalens -+ Rosmeer -+ Rota -+ Rotarian -+ Rotary -+ Rotaryclub -+ Rotaryclubs -+ Rotem -+ Rotselaar -+ Rousseau -+ Roxanne -+ Roy -+ Rozebeke -+ Rozenaken -+ Rozenburger -+ Rozenburgs -+ Ruben -+ Rubens -+ Rucphenaar -+ Rucphens -+ Ruddershove -+ Ruddervoorde -+ Rudi -+ Rudolf -+ Rudolf Steiner -+ Rudy -+ Rug -+ Ruhrgebied -+ Ruien -+ Ruisbroek -+ Ruiselede -+ Ruiter -+ Rukkelingen -+ Rukkelingen-Loon -+ Rukkelingen-aan-de-Jeker -+ Rumbeeks -+ Rumbeke -+ Rumbekenaar -+ Rummen -+ Rumsdorp -+ Rumst -+ Runkelen -+ Rupelmonde -+ Rushdie -+ Russisch Laagland -+ Rutger -+ Ruth -+ Rutten -+ Ruud -+ Ruud Lubbers -+ Ruyter -+ Rwanda -+ Rwandees -+ Réunion -+ Réunions -+ SGP -+ SGP'er -+ SGP'ers -+ SGP-leden -+ SGP-lid -+ SIS -+ SP -+ SP'er -+ SP'ers -+ SP-leden -+ SP-lid -+ STER -+ Saar -+ Sabina -+ Sabine -+ Sabrina -+ Sacha -+ Sachsen -+ Sachsen-Anhalt -+ Sagunto -+ Sahara-Atlas -+ Sahoelplat -+ Said -+ Saimaakanaal -+ Saint -+ Saint George's -+ Saint John's -+ Saint Kitts en Nevis -+ Saint Lawrencebaai -+ Saint Lucia -+ Saint Luciaan -+ Saint Luciaans -+ Saint Vincent en de Grenadines -+ Saint-Denis -+ Saint-Pierre -+ Saint-Pierre en Miquelon -+ Saksen-Anhalt -+ Sakser -+ Salima -+ Salland -+ Sallander -+ Sallands -+ Salman -+ Salman Rushdie -+ Salomonseilanden -+ Salvador -+ Salvador Allende -+ Salween -+ Sam -+ Samantha -+ Samaria -+ Samarkand -+ Samber -+ Samoa -+ Samoaan -+ Samoaans -+ Samothrake -+ Samuel -+ San -+ San José -+ San Juan -+ San Salvador -+ San Sebastian -+ Sanaa -+ Sander -+ Sandra -+ Sandrine -+ Sandwichtrog -+ Sankt -+ Sankt Vith -+ Sanna -+ Sanne -+ Santiago -+ Santiago de Compostela -+ Santiago de Compostella -+ Santiagoos -+ Santiagoër -+ Santo -+ Santo Domingo -+ Santomees -+ Sao -+ Sao Tomé -+ Sao Tomé en Principe -+ Sappemeer -+ Sappemeerder -+ Sappemeers -+ Sara -+ Sarah -+ Sarajevo -+ Sard -+ Sardinisch -+ Sardinië -+ Sardiniër -+ Sardisch -+ Sargassozee -+ Sartre -+ Saskia -+ Sassenheimer -+ Sassenheims -+ Saturnus -+ Saul -+ Savoyse -+ Savoyse Alpen -+ Saïdjah -+ Saïdjah en Adinda -+ Saône -+ Scandinaaf -+ Scandinaafs -+ Scandinavisch Hoogland -+ Scandinaviër -+ Schaarbeek -+ Schaarbeeks -+ Schaarbekenaar -+ Schaesberg -+ Schaesberger -+ Schaesbergs -+ Schaffen -+ Schagenaar -+ Schagens -+ Schager -+ Schalafie -+ Schalkhoven -+ Scheidingsgebergte -+ Schelde -+ Schelderode -+ Scheldewindeke -+ Schelle -+ Schellebelle -+ Schendelbeke -+ Schepdaal -+ Schepper -+ Schermer -+ Scherpenheuvel -+ Scherpenheuvel-Zichem -+ Schiebroek -+ Schiedams -+ Schiereiland -+ Schiermonnikoger -+ Schiermonnikoogs -+ Schijndelaar -+ Schijndels -+ Schild -+ Schilde -+ Schildenaar -+ Schildes -+ Schins -+ Schleswig -+ Schleswig-Holstein -+ Schmidt -+ Schone -+ Schoonaarde -+ Schoonhovenaar -+ Schoonhovens -+ Schoorwal -+ Schore -+ Schorisse -+ Schorpioen -+ Schorselwoensdag -+ Schorselwoensdagen -+ Schoten -+ Schotenaar -+ Schotens -+ Schotse Hooglanden -+ Schotse Laagvlakte -+ Schouten -+ Schouwen -+ Schouwenaar -+ Schouws -+ Schriek -+ Schriftgeleerde -+ Schriftgeleerden -+ Schriftkenner -+ Schriftkenners -+ Schriftlezing -+ Schriftuitlegging -+ Schriftuurlijk -+ Schriftuurlijke -+ Schriftvertolking -+ Schriftwoord -+ Schuiferskapelle -+ Schulen -+ Schweitzer -+ Sdu -+ Sebastiaan -+ Sebastian -+ Sebastopol -+ Seeland -+ Seelander -+ Seelands -+ Sefarden -+ Sefardisch -+ Segers -+ Seine -+ Seinebaai -+ Selma -+ Sem -+ Semiet -+ Semieten -+ Semmerzake -+ Senaat -+ Senaatsleden -+ Senaatslijst -+ Senaatsvergadering -+ Senaatsvergaderingen -+ Seoel -+ Seoeler -+ Seoels -+ Seoul -+ Seouler -+ Seouls -+ Serf -+ Serge -+ Seri -+ Serskamp -+ Servische Republiek -+ Severine -+ Seychellen -+ Seycheller -+ Seychels -+ Sfakia -+ Shaba -+ Shakespeare -+ Shanna -+ Sharjah -+ Sharon -+ Sheila -+ Sherpa -+ Shkodër -+ Shoah -+ Siberiër -+ Siciliaan -+ Siciliaans -+ Sicilië -+ Sideros -+ Sidon -+ Sidra -+ Siebren -+ Siegfried -+ Sien -+ Siep -+ Sierra -+ Sierra Leone -+ Sierra Leoner -+ Sierra Leoons -+ Sietse -+ Sietske -+ Sigmund -+ Sigmund Freud -+ Sigrid -+ Sijsele -+ Silezisch -+ Silezië -+ Sileziër -+ Simbel -+ Simon -+ Simon Petrus -+ Simon Stevin -+ Simon Vestdijk -+ Simone -+ Simonne -+ Simons -+ Simpelvelder -+ Simpelvelds -+ Simpelvelter -+ Simson -+ Sinaai -+ Sinaai-Waas -+ Sinaï -+ Singapore -+ Singaporees -+ Sinkiang -+ Sint -+ Sint Anthonis -+ Sint-Agatha-Berchem -+ Sint-Agatha-Berchemmenaar -+ Sint-Agatha-Berchems -+ Sint-Agatha-Rode -+ Sint-Amands -+ Sint-Amandsberg -+ Sint-Amandsbergenaar -+ Sint-Amandsbergs -+ Sint-Andries -+ Sint-Andriezenaar -+ Sint-Antelinks -+ Sint-Baafs-Vijve -+ Sint-Blasius-Boekel -+ Sint-Denijs -+ Sint-Denijs-Boekel -+ Sint-Denijs-Westrem -+ Sint-Eloois-Vijve -+ Sint-Eloois-Winkel -+ Sint-Eustatius -+ Sint-Genesius-Rode -+ Sint-Genesius-Rodenaar -+ Sint-Genesius-Roods -+ Sint-Georgekanaal -+ Sint-Gillenaar -+ Sint-Gillis -+ Sint-Gillis-Waas -+ Sint-Gillis-bij-Dendermonde -+ Sint-Goriks-Oudenhove -+ Sint-Gotthard -+ Sint-Heleens -+ Sint-Helena -+ Sint-Helener -+ Sint-Huibrechts-Hern -+ Sint-Huibrechts-Lille -+ Sint-Jacobs-Kapelle -+ Sint-Jan -+ Sint-Jan-in-Eremo -+ Sint-Jans-Geest -+ Sint-Jans-Molenbeek -+ Sint-Jans-Molenbeeks -+ Sint-Jans-Molenbekenaar -+ Sint-Job-in-'t-Goor -+ Sint-Joost-ten-Node -+ Sint-Joost-ten-Noods -+ Sint-Joostenaar -+ Sint-Joosts -+ Sint-Joris -+ Sint-Joris-Weert -+ Sint-Joris-Winge -+ Sint-Katelijne-Waver -+ Sint-Katelijne-Waveraar -+ Sint-Katelijne-Wavers -+ Sint-Katelijnenaar -+ Sint-Katelijns -+ Sint-Katherina-Lombeek -+ Sint-Kornelis-Horebeke -+ Sint-Kruis -+ Sint-Kruis-Winkel -+ Sint-Kruizenaar -+ Sint-Kwintens-Lennik -+ Sint-Lambrechtenaar -+ Sint-Lambrechts -+ Sint-Lambrechts-Herk -+ Sint-Lambrechts-Woluwe -+ Sint-Laureins -+ Sint-Laureins-Berchem -+ Sint-Lenaarts -+ Sint-Lievens-Esse -+ Sint-Lievens-Houtem -+ Sint-Margriete -+ Sint-Margriete-Houtem -+ Sint-Maria-Horebeke -+ Sint-Maria-Latem -+ Sint-Maria-Lierde -+ Sint-Maria-Oudenhove -+ Sint-Martens-Bodegem -+ Sint-Martens-Latem -+ Sint-Martens-Leerne -+ Sint-Martens-Lennik -+ Sint-Martens-Lierde -+ Sint-Martens-Voeren -+ Sint-Michiels -+ Sint-Michielsgestels -+ Sint-Niklaas -+ Sint-Niklazenaar -+ Sint-Oedenrodenaar -+ Sint-Oedenroods -+ Sint-Omaars -+ Sint-Pauwels -+ Sint-Petersburg -+ Sint-Pieteraar -+ Sint-Pieters -+ Sint-Pieters-Kapelle -+ Sint-Pieters-Leeuw -+ Sint-Pieters-Leeuwenaar -+ Sint-Pieters-Leeuws -+ Sint-Pieters-Rode -+ Sint-Pieters-Voeren -+ Sint-Pieters-Woluwe -+ Sint-Pietersberg -+ Sint-Remigius-Geest -+ Sint-Renelde -+ Sint-Rijkers -+ Sint-Stevens-Woluwe -+ Sint-Truiden -+ Sint-Truidenaar -+ Sint-Truidens -+ Sint-Ulriks-Kapelle -+ Sinterklaas -+ Siska -+ Sittardenaar -+ Sittarder -+ Sittards -+ Sittarnaar -+ Sjaak -+ Sjanghai -+ Sjef -+ Sjek -+ Sjelichovbaai -+ Sjeng -+ Sjoerd -+ Sjors -+ Sjoukje -+ Skopje -+ Slavonië -+ Sleat -+ Sleeswijk -+ Sleeswijker -+ Sleeswijks -+ Sleidinge -+ Slenk -+ Sliedrecht -+ Sliedrechtenaar -+ Sliedrechter -+ Sliedrechts -+ Slijpe -+ Slochtenaar -+ Slochterenveld -+ Slochters -+ Slot -+ Slot Loevestein -+ Slotermeer -+ Slotervaart -+ Slovaaks Ertsgebergte -+ Slowaaks Ertsgebergte -+ Sluis -+ Smedt -+ Smeerebbe -+ Smeerebbe-Vloerzegem -+ Smet -+ Smetlede -+ Smets -+ Smit -+ Smits -+ Snaaskerke -+ Sneek -+ Sneeks -+ Sneker -+ Snelle -+ Snelle Cris -+ Snelle Körös -+ Snellegem -+ Socrates -+ Soechoemi -+ Soedan -+ Soeharto -+ Soekarno -+ Soemba -+ Soembawa -+ Soenda -+ Soendaplat -+ Soenion -+ Soerabaja -+ Soesder -+ Soest -+ Soestenaar -+ Soester -+ Soests -+ Sofia -+ Sofie -+ Sofioot -+ Sofiotisch -+ Somaliland -+ Somalisch Hoogland -+ Somalisch Schiereiland -+ Someraar -+ Somers -+ Son -+ Son en Breugel -+ Sonja -+ Sont -+ Sophia -+ Sophie -+ Soubirous -+ Sovjet -+ Sovjetleider -+ Sovjetrepubliek -+ Sovjetrepublieken -+ Sovjetrijk -+ Sovjettijd -+ Spaanse Hoogvlakte -+ Spain -+ Spalbeek -+ Spartacus -+ Spermalie -+ Spiere -+ Spiere-Helkijn -+ Spijkenissenaar -+ Spijkenisses -+ Spinoza -+ Splügenpas -+ Sporaden -+ Spouwen -+ Sprang -+ Srebrenica -+ Sri -+ St. -+ St.-Eustatius -+ St.-Maarten -+ Staatsbosbeheer -+ Staatscourant -+ Staatscouranten -+ Stabroek -+ Stad -+ Staden -+ Stadskanaals -+ Stalhille -+ Stalin -+ Stalingrad -+ Stallman -+ Stampersgat -+ Stan -+ Standaard -+ Stanley -+ Staphorstenaar -+ Staphorster -+ Staten -+ Statencommissie -+ Stateneiland -+ Statenfractie -+ Statiaans -+ Stavele -+ Stct. -+ Stede -+ Stede Broec -+ Steen -+ Steenbergenaar -+ Steenbergs -+ Steenbok -+ Steenbokskeerkring -+ Steendorp -+ Steenhuffel -+ Steenhuize -+ Steenhuize-Wijnhuize -+ Steenkerke -+ Steenokkerzeel -+ Steenput -+ Steenvoorde -+ Steenwijker -+ Steenwijkerland -+ Steenwijks -+ Stef -+ Stefaan -+ Stefan -+ Stefanie -+ Steffen -+ Steffi -+ Stein -+ Steindenaar -+ Steinder -+ Steiner -+ Steins -+ Stekene -+ Stella -+ Stellingswerfs -+ Stellingwerf -+ Stellingwerver -+ Stene -+ Stephan -+ Stephanie -+ Sterrebeek -+ Steve -+ Steven -+ Stevens -+ Stevin -+ Stevoort -+ Stien -+ Stier -+ Stiermarken -+ Stiermarker -+ Stiermarks -+ Stijl -+ Stijn -+ Stille -+ Stille Oceaan -+ Stille Zuidzee -+ Stockholmer -+ Stockholms -+ Stoel -+ Stokkem -+ Stokrooie -+ Stones -+ Stoute -+ Straat -+ Straat Bass -+ Straat Cook -+ Straat Davis -+ Straat De Long -+ Straat Denemarken -+ Straat Drake -+ Straat Florida -+ Straat Formosa -+ Straat Hinlopen -+ Straat Hudson -+ Straat Joegor -+ Straat Karimata -+ Straat Koerilen -+ Straat Koningin Charlotte -+ Straat Korea -+ Straat La Pérouse -+ Straat Madoera -+ Straat Magallanes -+ Straat Magellaan -+ Straat Makassar -+ Straat Malakka -+ Straat Mozambique -+ Straat Nares -+ Straat Palk -+ Straat Singapore -+ Straat Soemba -+ Straat Soenda -+ Straat Torres -+ Straat Tsugaru -+ Straat Yucatan -+ Straat van Bonifacio -+ Straat van Corsica -+ Straat van Gibraltar -+ Straat van Hormuz -+ Straat van Messina -+ Straat van Otranto -+ Straat van Taiwan -+ Straatsburger -+ Straatsburgs -+ Stradivarius -+ Stradivariussen -+ Strauss -+ Strijpen -+ Strijtem -+ Strimon -+ Strombeek -+ Strombeek-Bever -+ Stromboli -+ Stuivekenskerke -+ Sucre -+ Sudan -+ Sudanees -+ Sudeten -+ Suez -+ Suezkanaal -+ Sulawesi -+ Sumba -+ Sumbawa -+ Surabaya -+ Susan -+ Susanne -+ Susterenaar -+ Susterens -+ Suva -+ Suzan -+ Suzanne -+ Sven -+ Swalm -+ Swazi -+ Swaziland -+ Swazisch -+ Swaziër -+ Syb -+ Sybe -+ Sydney -+ Sylvester -+ Sylvia -+ Sylvie -+ Syr -+ Syr Darja -+ Syracusaan -+ Syracusaans -+ Syracuse -+ Syracuser -+ Syracusisch -+ Syrische Woestijn -+ Sytske -+ TB -+ THz -+ TNO -+ Taag -+ Taalunie -+ Tachtiger -+ Tachtigers -+ Taco -+ Taddeüs -+ Tadzjiek -+ Tadzjieks -+ Tadzjiekse -+ Tadzjikistan -+ Taigetos -+ Taipei -+ Taiwan -+ Taiwanees -+ Taiwanese -+ Tallinn -+ Talmoed -+ Talmoedisch -+ Talmoedist -+ Talmoedisten -+ Tamara -+ Tamil -+ Tanger -+ Tanja -+ Tarawa -+ Tarente -+ Tarentijn -+ Tarentijns -+ Tarimbekken -+ Tarkan -+ Tartaar -+ Tartaars -+ Tartaarse -+ Tartaren -+ Tartarije -+ Tasjkent -+ Tasman -+ Tasmanië -+ Tasmanzee -+ Tataar -+ Tataars -+ Tataarse -+ Tataren -+ Tatarensont -+ Tatarije -+ Tatra -+ Taurus -+ Tbilisi -+ Te -+ Te Deum -+ TeX -+ Ted -+ Tegelaar -+ Tegeler -+ Tegels -+ Tegucigalpa -+ Teheraans -+ Teheraner -+ Tekla -+ Telegraaf -+ Tell -+ Tell-Atlas -+ Tempedal -+ Tems -+ Temse -+ Temsenaar -+ Temses -+ Ten -+ Ten Boer -+ Ter -+ Ter Aar -+ Teralfene -+ Terhagen -+ Terhulpen -+ Terhulpenaar -+ Terhulpens -+ Ternaaien -+ Ternat -+ Ternate -+ Terneus -+ Terneuzenaar -+ Terrasland -+ Terre -+ Territorium -+ Terschellinger -+ Terschellings -+ Tervuren -+ Tessa -+ Tessel -+ Tesselaar -+ Tessels -+ Tessenderlo -+ Testelt -+ Teun -+ Teuven -+ Texel -+ Texels -+ Teylingen -+ The -+ The Beatles -+ The Rolling Stones -+ The Valley -+ Thea -+ Thebe -+ Theo -+ Theo van Gogh -+ Theodoor -+ Theodora -+ Theodore -+ Theodore Roosevelt -+ Theodorus -+ Thera -+ Theresa -+ Theresienstadt -+ Thermopylae -+ Thermopylen -+ Thessalië -+ Thessaloniki -+ Thieu -+ Thijs -+ Thimphu -+ Tholenaar -+ Thomas Alva Edison -+ Thomas Jefferson -+ Thools -+ Thora -+ Thorbecke -+ Thorn -+ Thracië -+ Thunderbird -+ Thys -+ Thérèse -+ Tiber -+ Tiberias -+ Tibet -+ Tibetaan -+ Tibetaans -+ Tibetaans Hoogland -+ Tiegem -+ Tiel -+ Tielen -+ Tielenaar -+ Tieler -+ Tielrode -+ Tiels -+ Tielt -+ Tielt-Winge -+ Tieltenaar -+ Tielts -+ Tien -+ Tien-Graadkanaal -+ Tieneke -+ Tienen -+ Tienenaar -+ Tiens -+ Tiensjan -+ Tigris -+ Tijd -+ Tijmen -+ Tilburger -+ Tilburgs -+ Tildonk -+ Tilly -+ Tim -+ Timanrug -+ Timboektoe -+ Times -+ Timmermans -+ Timo -+ Timor -+ Timorees -+ Timothy -+ Tina -+ Tine -+ Tineke -+ Tinus -+ Tiny -+ Tirana -+ Tiranees -+ Tirol -+ Tiroler -+ Tisselt -+ Titicacameer -+ Tjalling -+ Tjeerd -+ Tjerk -+ Tobago -+ Toby -+ Toerkonje -+ Toetankhamon -+ Toeva -+ Togo -+ Togolees -+ Togoos -+ Togoër -+ Toine -+ Tokelaueilanden -+ Tokelaueilander -+ Tokelaueilands -+ Tokioos -+ Tokioër -+ Tokyo -+ Tolkien -+ Tollembeek -+ Tolo -+ Tom -+ Tomini -+ Tommy -+ Tomé -+ Ton -+ Tonga -+ Tongaan -+ Tongaans -+ Tongenaar -+ Tongeraar -+ Tongeren -+ Tongerlo -+ Tongers -+ Tonia -+ Tonkin -+ Tonnie -+ Tony -+ Tony Blair -+ Toon -+ Toonder -+ Toos -+ Tooske -+ Torenpas -+ Torhout -+ Torhoutenaar -+ Torhouts -+ Torres -+ Torvalds -+ Tosca -+ Toscaan -+ Toscaans -+ Toscaanse -+ Toscaanse Archipel -+ Toscane -+ Tour -+ Town -+ Tractatenblad -+ Trajanus -+ Trans -+ Trans-Kaukasië -+ Transhimalaya -+ Transkarpatië -+ Transnistrië -+ Transsylvanische -+ Transsylvanische Alpen -+ Transsylvanië -+ Transvaal -+ Transvaler -+ Transvalers -+ Trasimeense -+ Trasimeense Meer -+ Trees -+ Tremelo -+ Trijntje -+ Trinidad -+ Trinidad en Tobago -+ Trio -+ Tripoli -+ Tripolitaan -+ Tripolitaans -+ Tripolitanië -+ Tristan -+ Trivandrum -+ Triëst -+ Triëster -+ Triësts -+ Troelstra -+ Trouw -+ Trudi -+ Trudie -+ Trudy -+ Truiden -+ Truidenaar -+ Truidens -+ Truielingen -+ Truus -+ Tsaidam -+ Tsjaad -+ Tsjaadbekken -+ Tsjaadmeer -+ Tsjadisch -+ Tsjadiër -+ Tsjang -+ Tsjang K'ai-Sjek -+ Tsjchinvali -+ Tsjecho -+ Tsjecho-Slowakije -+ Tsjerkessië -+ Tsjetsjenië -+ Tsjoektsjenschiereiland -+ Tsjoektsjenzee -+ Tsjoengking -+ Tsjoevasjië -+ Tsugaru -+ Tubbergenaar -+ Tubberger -+ Tubbergs -+ Tubeeks -+ Tubeke -+ Tubekenaar -+ Tunesiër -+ Tunis -+ Turan -+ Turijn -+ Turijner -+ Turijns -+ Turkestan -+ Turkije -+ Turkin -+ Turkmeen -+ Turkmeens -+ Turkmeense -+ Turkmenistan -+ Turks- en Caicoseilanden -+ Turnhout -+ Turnhoutenaar -+ Turnhouts -+ Tuva -+ Tuvalu -+ Tuvaluaan -+ Tuvaluaans -+ Twain -+ Twee -+ Twee-Akren -+ Tweede -+ Tweede Kamer -+ Tweede Kamercommissie -+ Tweede Kamerfractie -+ Tweede Kamerfracties -+ Tweede Kamerleden -+ Tweede Kamerlid -+ Tweede Kamerverkiezingen -+ Tweelingen -+ Twent -+ Twenterand -+ Tycho -+ Tynaarlo -+ Tyrreense -+ Tyrreense Zee -+ Tyrus -+ Tytsjerksteradiel -+ Tórshavn -+ UEFA -+ UEFA-cup -+ UMTS -+ US -+ UTF -+ UTF-8 -+ UWV -+ Ubach -+ Ubach over Worms -+ Ubacher -+ Ubachs -+ Ubberger -+ Ubbergs -+ Ubuntu -+ Uden -+ Udenaar -+ Udens -+ Udo -+ Uganda -+ Ugandees -+ Uikhoven -+ Uitbergen -+ Uithoornaar -+ Uithoorns -+ Uithorenaar -+ Uitkerke -+ Ukkel -+ Ukkelaar -+ Ukkels -+ Ulaanbaatar -+ Ulbeek -+ Uli -+ Uliga -+ Ulke -+ Ulrich -+ Ulrike -+ Ulriks -+ Umbrisch -+ Umbrië -+ Umbriër -+ Unie -+ Upembapark -+ Uranus -+ Urbanus -+ Urk -+ Urker -+ Urks -+ Ursel -+ Ursul -+ Ursula -+ Ustjurtplateau -+ Utrechtse Heuvelrug -+ Uyl -+ V-raad -+ VS -+ VUT -+ VVD -+ VVD-leden -+ VVD-lid -+ Vaalbeek -+ Vaals -+ Vaalserberg -+ Vaalzer -+ Vader -+ Vader des Vaderlands -+ Vaderdag -+ Vaderlands -+ Vaduz -+ Vaiaku -+ Val -+ Val-Meer -+ Valburg -+ Valburger -+ Valburgs -+ Valerie -+ Valkenburg aan de Geul -+ Valkenburger -+ Valkenburgs -+ Valkenswaarder -+ Valkenswaards -+ Vallei -+ Vallei van Fergana -+ Valletta -+ Valley -+ Van -+ Van Acker -+ Van Agt -+ Van Dale -+ Van Damme -+ Van Dyck -+ Van Hecke -+ Van Heuven Goedhart -+ Van Hoof -+ Van de Velde -+ Van den Bossche -+ Van den Broeck -+ Vandalen -+ Vandenberghe -+ Vanessa -+ Vanuatu -+ Vanuatuaan -+ Vanuatuaans -+ Varendonk -+ Varkensbaai -+ Varsenare -+ Vastenavond -+ Vastenavonden -+ Vechmaal -+ Vecht -+ Vechtkanaal -+ Veda -+ Veda's -+ Vedisch -+ Vedische -+ Veelerveen -+ Veen -+ Veendammer -+ Veendams -+ Veenendaals -+ Veenendaler -+ Veens -+ Veerle -+ Veghelaar -+ Veghels -+ Veiligheidsraad -+ Velde -+ Veldegem -+ Velden -+ Veldhovenaar -+ Veldhovens -+ Veldwezelt -+ Vella -+ Velm -+ Velsenaar -+ Velsens -+ Velser -+ Veltem -+ Veltem-Beisem -+ Veluwenaar -+ Veluwer -+ Veluws -+ Velzeke -+ Velzeke-Ruddershove -+ Velzen -+ Ven -+ Venen -+ Venetiaan -+ Venetiaans -+ Venetiaanse -+ Venetiaanse Alpen -+ Venetië -+ Venezolaan -+ Venezolaans -+ Venezolaanse -+ Venezolanen -+ Venlonaar -+ Venloos -+ Venloënaar -+ Venloër -+ Venrayenaar -+ Venrayer -+ Venrays -+ Ventoux -+ Vera -+ Verbeeck -+ Verbeke -+ Verbruggen -+ Vercammen -+ Verdebekken -+ Vereenigde -+ Vereenigde Oost-Indische Compagnie -+ Verenigd -+ Verenigd Koninkrijk -+ Verhaegen -+ Verhaeghe -+ Verhelst -+ Verheyen -+ Verhoeven -+ Verlatinghe -+ Verlinden -+ Verlosser -+ Vermeer -+ Vermeersch -+ Vermeiren -+ Vermeulen -+ Verne -+ Veronica -+ Veronique -+ Veroveraar -+ Verre -+ Verre Oosten -+ Verrebroek -+ Verschrikkelijke -+ Verschueren -+ VersieOpenTaalMajB -+ VersieOpenTaalMinA -+ VersieOpenTaalVarG -+ Verstraete -+ Verstraeten -+ Vertrijk -+ Verviersenaar -+ Vervoort -+ Vestdijk -+ Vesuvius -+ Veulen -+ Veurenaar -+ Veurens -+ Veurnaar -+ Veurne -+ Veurns -+ Viane -+ Vianens -+ Vichte -+ Vicky -+ Victor -+ Victoria -+ Victoriavallen -+ Victoriawoestijn -+ Vientiane -+ Viersel -+ Vijftigers -+ Vijve -+ Viking -+ Vikingboot -+ Vikingboten -+ Vikingen -+ Vikings -+ Vikingschepen -+ Vikingschip -+ Vila -+ Vilnius -+ Vilvoorde -+ Vilvoordenaar -+ Vilvoords -+ Vincent -+ Vincent van Gogh -+ Vinci -+ Vinderhoute -+ Vinex-locatie -+ Vink -+ Vinkem -+ Vinkt -+ Virginia -+ Visbaai -+ Visscher -+ Vissen -+ Vissenaken -+ Visser -+ Vissersbank -+ Vitae -+ Vith -+ Vivian -+ Viviane -+ Vlaardinger -+ Vlaardings -+ Vladimir -+ Vladimir Lenin -+ Vladimir Poetin -+ Vladslo -+ Vlagtwedder -+ Vlagtweds -+ Vlakte -+ Vlakte van Jizreël -+ Vlamertinge -+ Vlaminge -+ Vlekkem -+ Vleteren -+ Vleuten -+ Vleuten-De Meern -+ Vlezenbeek -+ Vlielander -+ Vlielands -+ Vliermaal -+ Vliermaalroot -+ Vlierzele -+ Vliet -+ Vlijmen -+ Vlijmenaar -+ Vlijmens -+ Vlijtingen -+ Vlimmeren -+ Vlissegem -+ Vlissinger -+ Vlissings -+ Vlist -+ Vloerzegem -+ Vloesberg -+ Vloesbergenaar -+ Vloesbergs -+ Voeren -+ Voerenaar -+ Voerendaals -+ Voerendaler -+ Voerens -+ Voerstreek -+ Vogelkop -+ Vogezen -+ Vogezisch -+ Vogeziër -+ Volendam -+ Volendammer -+ Volendams -+ Volkegem -+ Volkenbond -+ Volkerenbond -+ Volkert -+ Volksrepubliek -+ Volksrepubliek China -+ Vollezele -+ Volos -+ Volta -+ Voltaire -+ Vondel -+ Voor -+ Voor-Rijn -+ Voorburger -+ Voorburgs -+ Voorde -+ Voorhout -+ Voormezele -+ Voorschoten -+ Voorschotenaar -+ Voorschotens -+ Voorstenaar -+ Voorster -+ Voorsts -+ Voort -+ Vorpommern -+ Vorselaar -+ Vorsen -+ Vorst -+ Vorstenaar -+ Vorsts -+ Vos -+ Vosselaar -+ Vosselare -+ Vossem -+ Vossemeer -+ Vrasene -+ Vredespaleis -+ Vremde -+ Vreren -+ Vries -+ Vriezenveens -+ Vriezenvener -+ Vrijstaat -+ Vroenhoven -+ Vrouw -+ Vrouwe -+ Vrouwe Justitia -+ Vrouwebeeld -+ Vrouwekerk -+ Vucht -+ Vught -+ Vughtenaar -+ Vughts -+ Vulkaanpas -+ Vurste -+ Vuurland -+ Vuurlander -+ Vuurlands -+ Vänermeer -+ Vättermeer -+ W.F. -+ W.F. Hermans -+ W.G. -+ W.G. van de Hulst -+ WAO -+ WAO-ers -+ WAO-premie -+ WOZ -+ WOZ-beschikking -+ WW -+ WW-premie -+ Waalrenaar -+ Waalres -+ Waalwijker -+ Waalwijks -+ Waanrode -+ Waarbeke -+ Waardamme -+ Waarloos -+ Waarmaarde -+ Waarschoot -+ Waas -+ Waasland -+ Waaslander -+ Waaslands -+ Waasmont -+ Waasmunster -+ Waasten -+ Waastenaar -+ Waastens -+ Wachtebeke -+ Wadden -+ Waddeneiland -+ Waddeneilanden -+ Waddeneilander -+ Waddeneilands -+ Waddengas -+ Waddenvereniging -+ Waddinxveens -+ Waddinxvener -+ Wageninger -+ Wagenings -+ Wagenmakers -+ Wajong -+ Wakken -+ Wal -+ Walach -+ Walachije -+ Walachijer -+ Walachijs -+ Walachs -+ Walcheren -+ Walchers -+ Waldajhoogte -+ Walem -+ Walenland -+ Walhalla -+ Walkure -+ Walkuren -+ Wallis -+ Wallis en Futuna -+ Walsbets -+ Walshoutem -+ Waltwilder -+ Walvisbaai -+ Walvisrug -+ Wambeek -+ Wanda -+ Wange -+ Wannegem -+ Wannegem-Lede -+ Wanssum -+ Wanzele -+ Waregem -+ Waregemmenaar -+ Waregems -+ Warschau -+ Warschauer -+ Warschaus -+ Washingtonner -+ Washingtons -+ Wassenaar -+ Wassenaarder -+ Watergraafsmeer -+ Wateringen -+ Wateringer -+ Waterings -+ Waterland -+ Waterland-Oudeman -+ Waterlander -+ Waterlands -+ Watermaal -+ Watermaal-Bosvoorde -+ Watermaal-Bosvoordenaar -+ Watermaal-Bosvoords -+ Watervliet -+ Watou -+ Watt -+ Wauters -+ Waveraar -+ Wavers -+ Wazenaar -+ Webbekom -+ Wechelderzande -+ Weddellzee -+ Weegschaal -+ Weelde -+ Weens -+ Weerde -+ Weerst -+ Weert -+ Weertenaar -+ Weerter -+ Weerts -+ Weesgegroet -+ Weesgegroeten -+ Weesp -+ Weesper -+ Weesps -+ Weismes -+ Welden -+ Welle -+ Wellen -+ Wellington -+ Wellingtonner -+ Wellingtons -+ Wels -+ Welse -+ Wemmel -+ Wemmelaar -+ Wemmels -+ Wenden -+ Wenduine -+ Wendy -+ Wenen -+ Wenerin -+ Werchter -+ Wereldbibliotheek -+ Wereldgebedsdag -+ Wereldomroep -+ Wereldschaakbond -+ Wereldvoedselorganisatie -+ Wereldvoedselprogramma -+ Wereldvrouwenconferentie -+ Wereldzwembond -+ Werken -+ Werkendammer -+ Werkendams -+ Werm -+ Werner -+ Wersbeek -+ Wervik -+ Wervikaan -+ Wervikenaar -+ Werviks -+ Weser -+ Wesley -+ Wespelaar -+ Wessel -+ West -+ West Maas en Waal -+ West-Australië -+ West-Duitsland -+ West-Europees Bekken -+ West-Ghats -+ West-Kaap -+ West-Kasaï -+ West-Siberisch Laagland -+ Westelaar -+ Westelijk -+ Westelijk Nieuw-Guinea -+ Westelijke -+ Westelijke Balkan -+ Westelijke Cordillera -+ Westelijke Duina -+ Westelijke Dvina -+ Westelijke Grote Erg -+ Westelijke Jordaanoever -+ Westelijke Morava -+ Westelijke Sierra Madre -+ Westen -+ Westende -+ Wester -+ Westerlo -+ Westerloos -+ Westerpark -+ Westerschelde -+ Westerveld -+ Westfalen -+ Westhoek -+ Westhoekenaar -+ Westhoeks -+ Westkerke -+ Westland -+ Westlander -+ Westlands -+ Westmalle -+ Westmeerbeek -+ Westouter -+ Westpoort -+ Westrem -+ Westrozebeke -+ Westvleteren -+ Wetteraar -+ Wetteren -+ Wetters -+ Wevelgem -+ Wevelgemmenaar -+ Wevelgems -+ Wezemaal -+ Wezembeek -+ Wezembeek-Oppem -+ Wezembeek-Oppems -+ Wezembeeks -+ Wezembekenaar -+ Wezer -+ Wezeren -+ Wezet -+ Wichelen -+ Widooie -+ Wiebe -+ Wiek -+ Wiekevorst -+ Wielsbeke -+ Wierdenaar -+ Wierdens -+ Wierder -+ Wieringer -+ Wieringermeerder -+ Wieringermeers -+ Wierings -+ Wies -+ Wietske -+ Wieze -+ Wijchenaar -+ Wijchens -+ Wijchmaal -+ Wijdemeren -+ Wijdenes -+ Wijer -+ Wijgmaal -+ Wijk -+ Wijk bij Duurstede -+ Wijkenaar -+ Wijnegem -+ Wijnhuize -+ Wijnie -+ Wijshagen -+ Wijtschate -+ Wikipedia -+ Wil -+ Wilbert -+ Wilde -+ Wilderen -+ Wilfred -+ Wilfried -+ Wilhelm -+ Wilhelmina -+ Wilko -+ Willebringen -+ Willebroek -+ Willebroekenaar -+ Willebroeks -+ Willeke -+ Willem -+ Willem Aantjes -+ Willem Barentsz -+ Willem Drees -+ Willem Elsschot -+ Willem Frederik Hermans -+ Willem Janszoon Blaeu -+ Willem V -+ Willem de Veroveraar -+ Willem de Zwijger -+ Willem van Oranje -+ Willem-Alexander -+ Willemien -+ Willemijn -+ Willems -+ Willemstads -+ Willemstatter -+ William -+ William Shakespeare -+ Willibrord -+ Willie -+ Willy -+ Wilma -+ Wilrijk -+ Wilrijkenaar -+ Wilrijks -+ Wilsele -+ Wilskerke -+ Wim -+ Wim Kan -+ Wim Kok -+ Wimmertingen -+ Wina -+ Windhoek -+ Windhoeker -+ Windhoeks -+ Windward -+ Windward Passage -+ Winge -+ Wingene -+ Winkel -+ Winksele -+ Winny -+ Winschotenaar -+ Winschotens -+ Winschoter -+ Winston -+ Winston Churchill -+ Winter -+ Wintershoven -+ Winterswijker -+ Winterswijks -+ Wislahaf -+ Wislaschoorwal -+ Wit -+ Witte -+ Witte Boekje -+ Witte Cris -+ Witte Drin -+ Witte Karpaten -+ Witte Nijl -+ Witte Volta -+ Witte Zee -+ Wodan -+ Woelingen -+ Woensdrecht -+ Woerden -+ Woerdenaar -+ Woerdens -+ Woesten -+ Woestijn -+ Wolden -+ Wolfgang -+ Wolfgang Amadeus Mozart -+ Wolga -+ Wolgaplateau -+ Wolgograd -+ Woluwe -+ Woluwenaar -+ Woluws -+ Wolvertem -+ Wolynisch -+ Wolynisch-Podolisch Plateau -+ Wolynië -+ Wommelgem -+ Wommersom -+ Wondelgem -+ Wondelgemmenaar -+ Wondelgems -+ Wontergem -+ Worm -+ Wormer -+ Wormers -+ Wormerveer -+ Wormerveerder -+ Wormerveers -+ Worms -+ Wortegem -+ Wortegem-Petegem -+ Wortel -+ Woubrechtegem -+ Woud -+ Woudkarpaten -+ Woudrichemmer -+ Woudrichems -+ Woumen -+ Wout -+ Wouter -+ Wouteringen -+ Wouters -+ Woutersbrakel -+ Writer -+ Wulpen -+ Wulvergem -+ Wulveringem -+ Wuustwezel -+ Wuyts -+ Wyandottes -+ Wybe -+ X-benen -+ XIV -+ XML -+ XVII -+ Xander -+ Xandra -+ Xantippe -+ Xavier -+ Xaviera -+ Xiaoping -+ Xinjiang -+ Yael -+ Yamoussoukro -+ Yannick -+ Yanniek -+ Yaoundé -+ Yaren -+ Yasser -+ Yasser Arafat -+ Yellowstone -+ Ylona -+ Yogyakarta -+ Yorick -+ York -+ Youri -+ Yucatan -+ Yukon -+ Yves -+ Yvette -+ Yvon -+ Yvonne -+ Z.H. -+ Z.K.H. -+ Zaan -+ Zaandam -+ Zaandammer -+ Zaandams -+ Zaankant -+ Zaankanter -+ Zaans -+ Zacharias -+ Zadkine -+ Zaffelare -+ Zagreb -+ Zagrebber -+ Zagrebs -+ Zambezi -+ Zambia -+ Zambiaan -+ Zambiaans -+ Zamenhof -+ Zand -+ Zandbergen -+ Zande -+ Zandhoven -+ Zandvliet -+ Zandvoorde -+ Zandvoorter -+ Zandvoorts -+ Zandwoestijn -+ Zappa -+ Zarlardinge -+ Zarren -+ Zaventem -+ Zaventemmenaar -+ Zaventems -+ Zaïre -+ Zaïrees -+ Zedelgem -+ Zedong -+ Zee -+ Zee van Azov -+ Zee van Halmahera -+ Zee van Marmara -+ Zee van Ochotsk -+ Zee-Alpen -+ Zeebrugge -+ Zeeburg -+ Zeegebied -+ Zeelander -+ Zeelands -+ Zeelandse -+ Zeels -+ Zegelsem -+ Zeist -+ Zeistenaar -+ Zeister -+ Zeists -+ Zele -+ Zelem -+ Zelenaar -+ Zelhemmer -+ Zelhems -+ Zellik -+ Zelzaats -+ Zelzate -+ Zelzatenaar -+ Zembla -+ Zemst -+ Zend -+ Zepperen -+ Zerkegem -+ Zevekote -+ Zevenaarder -+ Zevenaars -+ Zevenbergenaar -+ Zevenbergens -+ Zevenberger -+ Zevenbergs -+ Zevenburgen -+ Zeveneken -+ Zevengebergte -+ Zevengesternte -+ Zeveren -+ Zevergem -+ Zichem -+ Zichen -+ Zichen-Zussen-Bolder -+ Zijpe -+ Zillebeke -+ Zimbabwaan -+ Zimbabwaans -+ Zingem -+ Zinnik -+ Zinnikenaar -+ Zinniks -+ Zittert -+ Zittert-Lummen -+ Zoeloe -+ Zoeloes -+ Zoerle -+ Zoerle-Parwijs -+ Zoersel -+ Zoetermeerder -+ Zoetermeers -+ Zola -+ Zolder -+ Zomergem -+ Zondagswet -+ Zonhoven -+ Zonhovenaar -+ Zonhovens -+ Zonnebeke -+ Zonnegem -+ Zoom -+ Zorreguieta -+ Zottegem -+ Zottegemmenaar -+ Zottegems -+ Zoutenaaie -+ Zoutleeuw -+ Zoutwoestijn -+ Zuid -+ Zuid-Antillenbekken -+ Zuid-Australisch Bekken -+ Zuid-Australië -+ Zuid-Beveland -+ Zuid-Bevelander -+ Zuid-Bevelands -+ Zuid-Chinees Bergland -+ Zuid-Chinese Zee -+ Zuid-Equatoriale Rug -+ Zuid-Ossetië -+ Zuid-Pacifisch Bekken -+ Zuid-Pacifische Drempel -+ Zuid-Sandwichtrog -+ Zuid-Schots Bergland -+ Zuid-Tirol -+ Zuidelijke -+ Zuidelijke IJszee -+ Zuidelijke Karpaten -+ Zuidelijke Oceaan -+ Zuidelijke Sierra Madre -+ Zuideramstel -+ Zuidereiland -+ Zuiderkroon -+ Zuiderkruis -+ Zuidoost -+ Zuidoost-Azië -+ Zuidoostkaap -+ Zuidpool -+ Zuidpoolexpeditie -+ Zuidpoolexpedities -+ Zuidschote -+ Zuidwestkaap -+ Zuienkerke -+ Zullik -+ Zulte -+ Zulzeke -+ Zundernaar -+ Zundertenaar -+ Zunderts -+ Zussen -+ Zutendaal -+ Zutphenaar -+ Zutphens -+ Zuurbemde -+ Zwaanridder -+ Zwaantje -+ Zwalm -+ Zwaluwe -+ Zwarte -+ Zwarte Cris -+ Zwarte Drin -+ Zwarte Volta -+ Zwarte Woud -+ Zwarte Zee -+ Zwartewaterland -+ Zweeds Terrasland -+ Zwevegem -+ Zwevegemmenaar -+ Zwevegems -+ Zwevezele -+ Zwijger -+ Zwijnaarde -+ Zwijndrechtenaar -+ Zwijndrechts -+ Zwitserse Hoogvlakte -+ a posteriori -+ a prima vista -+ a'tjes -+ a-pion -+ a.h.w. -+ a.j.b. -+ aaibaarheid -+ aanbestedingsvoorwaarde -+ aanbestedingsvoorwaarden -+ aanbodgericht -+ aanbodgerichte -+ aanbodoverschot -+ aandachtsgroep -+ aandachtsgroepen -+ aandeelhoudersbelang -+ aandeelhoudersbelangen -+ aandeelhoudersovereenkomst -+ aandeelhoudersstructuur -+ aandelenadvies -+ aandelenadviezen -+ aandelenbelang -+ aandelenbelangen -+ aandelenbelegger -+ aandelenbeleggers -+ aandelenbelegging -+ aandelenbeleggingen -+ aandelenfonds -+ aandelenhandelaren -+ aandelenindex -+ aandelenindexen -+ aandelenindices -+ aandeleninkoop -+ aandelenkoop -+ aandelenkorf -+ aandelenomzet -+ aandelenoptieplan -+ aandelenoptieregeling -+ aandelenoverdracht -+ aandelenparticipaties -+ aandelenplan -+ aandelenpositie -+ aandelenprijzen -+ aandelenregelingen -+ aandelenruil -+ aandelenselectie -+ aandelensplitsing -+ aandelenuitgifte -+ aandelenvennootschappen -+ aandelenverhouding -+ aandrijflijn -+ aangebodene -+ aangekomenen -+ aangeslotene -+ aangeslotenen -+ aangevinkt -+ aangifteverplichting -+ aangroeipremie -+ aangroeiwerend -+ aangroeiwerende -+ aanhoudingsbevel -+ aanhoudingsbevelen -+ aanhoudingseenheid -+ aanklikbaar -+ aankoopakte -+ aankoopbeslissingen -+ aankoopbon -+ aankoopcentrale -+ aankoopdirecteur -+ aankoopfonds -+ aankoopgedrag -+ aankoopkosten -+ aankoopkracht -+ aankooplimiet -+ aankoopoptie -+ aankooporders -+ aankoopwaarde -+ aankoper -+ aankopers -+ aanloggen -+ aanloopmoeilijkheden -+ aanlooproute -+ aanmeldcentra -+ aanmeldcentrum -+ aanmeldingsprocedure -+ aanmoesten -+ aanmoet -+ aanmoeten -+ aannemend -+ aanpasbare -+ aanpassingskosten -+ aanpassingsprogramma -+ aanpassingswerken -+ aanpassingswerkzaamheden -+ aanrijroute -+ aanrijtijd -+ aanrijtijden -+ aanschaffingsprijs -+ aanschijns -+ aanschurken -+ aanslagjaar -+ aanslagjaren -+ aanslagplegers -+ aanslagtermijn -+ aansluitbogen -+ aansluitingenregister -+ aansluitkosten -+ aansluitnet -+ aansluitwaarde -+ aansprakelijkheidsbeperkend -+ aansprakelijkheidsbeperkende -+ aansprakelijkheidsrisico -+ aansprakelijkheidsrisico's -+ aansprakelijkheidsschades -+ aansprakelijkheidsstelling -+ aansprakelijkheidsuitsluiting -+ aansprekender -+ aanstaat -+ aantrekkelijkheidsfactor -+ aantrekkelijkheidsindex -+ aanvaardingsplicht -+ aanvalsdrang -+ aanvalsduo -+ aanvalshelikopters -+ aanvalskoppel -+ aanvalslust -+ aanvalslustige -+ aanvalsopbouw -+ aanvalsopzet -+ aanvalspact -+ aanvalspatronen -+ aanvalstrio -+ aanvalsverdrag -+ aanvalsvliegtuigen -+ aanvangsfase -+ aanvinken -+ aanvraagtermijn -+ aanw. -+ aanw. vnw. -+ aanwinstenbeleid -+ aanzwengelt -+ aardappelmeelfabriek -+ aardappelpootgoed -+ aardappelproducten -+ aardappelsla -+ aardappeltelers -+ aardbeientelers -+ aardbevingsramp -+ aardgasbedrijf -+ aardgasinkomsten -+ aardgasmarkt -+ aardgasopbrengsten -+ aardgasverbruik -+ aardgasvondst -+ aardkleuren -+ aardklimaat -+ aartsconservatieve -+ aartsmoeilijk -+ aartsschurk -+ aarzelender -+ abacadabra -+ abat -+ abc-boek -+ abc-boeken -+ aberrant -+ abeundi -+ abonnee-tv -+ abonneegegevens -+ abonnementsvormen -+ aboriginals -+ abortus provocatus -+ abortusarts -+ abortusartsen -+ abortusbeleid -+ abortusboot -+ abortuscijfer -+ abortuspraktijk -+ abstract-expressionistische -+ abstracto -+ absurdum -+ accent aigu -+ accent circonflexe -+ accijnsheffing -+ accijnsverlaging -+ accompli -+ accordeoniste -+ accordeonvereniging -+ accountantsbureau -+ accountantsbureaus -+ accountantsfirma -+ accountantsorganisatie -+ accountantsorganisaties -+ accreditering -+ acetylcholine -+ acetylsalicylzuur -+ achtcilinder -+ achtennegentig -+ achtentachtig -+ achtenveertig -+ achtenvijftig -+ achtenzestig -+ achtenzeventig -+ achterafkamertjes -+ achtergekomen -+ achtergestelden -+ achtergrondgesprekken -+ achtergrondkoortjes -+ achtergrondlawaai -+ achtergrondverlichting -+ achtergrondzang -+ achtergrondzangeres -+ achtergrondzangeressen -+ achtergrondzangers -+ achterhaven -+ achterkomt -+ achterkwam -+ achterkwamen -+ achterpaden -+ achterpassagiers -+ achterrem -+ achterstandenbeleid -+ achterstandsbeleid -+ achterstandsbestrijding -+ achterstandsgroepen -+ achterstandskinderen -+ achterstandsleerlingen -+ achterstandsscholen -+ achterstandwijken -+ achterterrein -+ achtervang -+ achtervering -+ achtig -+ achtige -+ acid house -+ acrogym -+ acteercarrière -+ acteerdebuut -+ acteerervaring -+ acteerkunst -+ acteerkwaliteiten -+ acteerlessen -+ acteursechtpaar -+ acteursopleiding -+ acteursprijs -+ acteursregie -+ actiedag -+ actiedagen -+ actieheld -+ actieheldin -+ actiekamp -+ actiemiddel -+ actiemiddelen -+ actiescènes -+ actieserie -+ actiesite -+ actiespel -+ actieterrein -+ actievere -+ activabeheer -+ activatie -+ activiteitenkalender -+ activiteitsgraad -+ ad fundum -+ ad hoc -+ ad interim -+ ad rem -+ ad remme -+ ad-hocbeleid -+ adelaarsnest -+ adellijken -+ adembescherming -+ adembeschermingsfilters -+ ademhalingsspieren -+ adenovirus -+ adjunct-algemeendirecteur -+ adjunct-directeur-generaal -+ adjunct-hoofdredacteuren -+ adjunct-kabinetschef -+ adjunct-secretaris-generaal -+ administrateur-generaal -+ administratieconsulent -+ adopters -+ adoptiemoeder -+ adoptieouder -+ adoptieplan -+ adoptievader -+ adoptieverlof -+ adresbestanden -+ adresetiketten -+ adv -+ adv-dagen -+ adv-uren -+ adverteerdersmarkt -+ advertentiebedrijf -+ advertentiebeleid -+ advertentiegelden -+ advertentieverkoop -+ advertentiewerving -+ advertorials -+ adviesbedrijf -+ adviescomité -+ adviesdiensten -+ adviesdocument -+ adviesdocumenten -+ adviesgroepen -+ advieskantoor -+ advieskantoren -+ adviesorganisatie -+ adviesrapport -+ adviesrol -+ adviesronde -+ adviestak -+ adviestarieven -+ adviesverhoging -+ adviesverlaging -+ adviesverlening -+ advieswereld -+ adviseursrol -+ advocaatkosten -+ advocaatskosten -+ advocatenbureau -+ advocatenkosten -+ advocatenteam -+ aeronautisch -+ aerosolen -+ af te zonderen -+ afbeeldingenregister -+ afbouwperiode -+ afbraakbeleid -+ afbreekpatronen -+ afbreekpatroon -+ afcentiemen -+ afd. -+ afdalend -+ afdalende -+ afdelingsdirecteur -+ afdelingsleider -+ afdelingsmanager -+ afdrachtskorting -+ afdwingbaarheid -+ affichecampagne -+ afgekaart -+ afgekeurden -+ afgemest -+ afgetest -+ afgeveerd -+ afgrondelijke -+ afhaalpunten -+ afhandelaar -+ afhandelaars -+ afhankelijken -+ afkoersen -+ afkoerst -+ afkoerste -+ afkoopverbod -+ afkoopwaarde -+ aflatoxine -+ aflossingsverplichtingen -+ afluisternetwerk -+ afluistersysteem -+ afnamecontract -+ afnameplicht -+ afnameverplichting -+ afpersingszaak -+ afscheidnemende -+ afscheidsceremonie -+ afscheidsconcert -+ afscheidsdienst -+ afscheidsduel -+ afscheidsinterview -+ afscheidsspeech -+ afscheidstoernee -+ afscheidstoespraak -+ afscheidswedstrijd -+ afschrijfbaar -+ afschrijvingstermijnen -+ afslagplaats -+ afslankingskuur -+ afslankmiddelen -+ afsluitformulier -+ afspeelbaar -+ afstandbediening -+ afstandschoten -+ afstandseis -+ afstandsraketten -+ afstandsverbindingen -+ afstuderenden -+ aftapapparatuur -+ aftapbaar -+ aftrekbedrag -+ aftrekbeperking -+ afvalaanbod -+ afvalbedrijf -+ afvalbedrijven -+ afvalbeheer -+ afvalbeleid -+ afvalberging -+ afvalbranche -+ afvaldepot -+ afvalheffing -+ afvalinzameling -+ afvaller -+ afvalmakelaars -+ afvalmarkt -+ afvalolie -+ afvalplan -+ afvalpreventie -+ afvalproblematiek -+ afvalproductie -+ afvalput -+ afvalresten -+ afvalsector -+ afvalstoffenplan -+ afvaltransport -+ afvalzak -+ afvoercapaciteit -+ afvoerroute -+ afvoersysteem -+ afwateringssysteem -+ afwil -+ afz. -+ afzegenen -+ afzetcontracten -+ afzetgroei -+ afzetvolume -+ afzuiginstallatie -+ agaathfonds -+ agaathlening -+ age -+ agoeti -+ agreement -+ agressiedelicten -+ agressietest -+ agressievere -+ agribulk -+ agribusiness -+ agro -+ agrobusiness -+ agrotoerisme -+ ahistorisch -+ aide -+ aidsbeleid -+ aidsbestrijding -+ aidsconferentie -+ aidsdoden -+ aidsgevallen -+ aidskind -+ aidsmedicijn -+ aidsmedicijnen -+ aidsonderzoek -+ aidspreventie -+ aidsprobleem -+ aidsproblematiek -+ aidsprogramma -+ aigu -+ ajam -+ ajam pangang -+ akkerrandbeheer -+ akkerteelt -+ akkoordenschema -+ al. -+ alarmdienst -+ alarmknop -+ alarmmelding -+ alarmmeldingen -+ albumdebuut -+ albumlijsten -+ albumtitel -+ alcantara -+ alcoholbeleid -+ alcoholbranche -+ alcoholconsumptie -+ alcoholgebruikers -+ alcoholgrens -+ alcoholiste -+ alcoholmatigingsbeleid -+ alcoholreclame -+ alcoholreclames -+ alcoholverbruik -+ alcoholverkoop -+ alcoholverslaafde -+ alcoholverslaving -+ alcopops -+ aleikum -+ alfaglucosidase -+ algemeen directeur -+ algemeen secretaris -+ algemeendirecteur -+ algemene gaswet -+ algemenen -+ aliens -+ alii -+ alineaprofiel -+ alkalinebatterijen -+ alla -+ alle drie -+ alleenvertegenwoordiger -+ allemáál -+ allerberoerdst -+ allergene -+ allergeschikste -+ allergiepatiënten -+ allerjongsten -+ allerkleinsten -+ allerleukste -+ allermoeilijkste -+ allernoodzakelijkste -+ allerprilste -+ allerzwaarste -+ allesbedekkende -+ allesbeslissende -+ allesvernietigende -+ allesverslindende -+ alliantiepartners -+ alliantievorming -+ alliëren -+ allroundkampioene -+ allroundkampioenschappen -+ allroundschaatsen -+ allroundtitel -+ allroundtoernooi -+ allroundtoernooien -+ alopecia -+ alpineskiër -+ alpineskiërs -+ als de wiedeweerga -+ alter ego -+ altvioliste -+ aluminiumactiviteiten -+ aluminiumbedrijf -+ aluminiumconcern -+ aluminiumdivisie -+ aluminiumfabriek -+ aluminiumfabrikant -+ aluminiumprijs -+ aluminiumprijzen -+ aluminiumproducent -+ aluminiumproducenten -+ aluminiumsector -+ aluminiumsmelter -+ amalgaamvullingen -+ amandelschaafsel -+ amaretto -+ amateurastronomen -+ amateurastronoom -+ amateurclub -+ amateurclubs -+ amateurdichters -+ amateurelftal -+ amateurfilmpje -+ amateurfilms -+ amateurfotograaf -+ amateurfotografen -+ amateurgezelschappen -+ amateurkoor -+ amateurkunst -+ amateurkunstenaars -+ amateurmusici -+ amateurschilder -+ amateursport -+ amateursporter -+ amateursporters -+ amateurstatus -+ amateurtoneelgezelschap -+ amateurvoetbalclub -+ amateurwedstrijd -+ amateurwedstrijden -+ ambachtsactiviteit -+ ambachtsactiviteiten -+ ambachtschool -+ ambachtswerk -+ ambassademedewerker -+ ambassademedewerkers -+ ambassadeterrein -+ ambassadeursrol -+ ambassadeursvrouw -+ ambassadeurswoning -+ ambtenaren-cao -+ ambtenarenkorps -+ ambtenarenpensioenfonds -+ ambtenarenrechter -+ ambtenarenstaking -+ ambtenarenstatuut -+ ambtenarenvakbond -+ ambtenarenvakbonden -+ ambtsbericht -+ ambtsberichten -+ ambtsedig -+ ambtsgenoot -+ ambtsgenoten -+ ambtsketting -+ ambtskostuum -+ ambtsmisdrijf -+ ambtstijd -+ ambtsuitoefening -+ ambtswege -+ ambulancehulpverlening -+ ambulancepost -+ ambulanceverpleegkundige -+ ambulanceverpleegkundigen -+ ambulancezorg -+ americain -+ ammoniakbeleid -+ ammoniakreductieplan -+ ammoniumnitraat -+ amnestiemaatregel -+ amnestieverlening -+ amused -+ amusementscentrum -+ amusementsconcern -+ amusementspark -+ amuzikaal -+ amygdala -+ amylose -+ an -+ anabolica -+ analistenbijeenkomst -+ analistenmeeting -+ analistenrapport -+ analistenrapporten -+ analistenteam -+ analyseresultaten -+ and -+ anderhalfverdieners -+ andersgelovigen -+ anderssoortige -+ androïde -+ aneurysma -+ angina pectoris -+ angio -+ angio-oedeem -+ angsthazerij -+ angststoornis -+ angststoornissen -+ animateur -+ animateurs -+ animatieserie -+ animatiestudio -+ anime -+ animisten -+ annuleringskosten -+ annuïteitenhypotheek -+ antennebeleid -+ anti-establishment -+ anti-intellectualisme -+ antiabortus -+ antiabortusbeweging -+ antiapartheidsactivist -+ antiautobeleid -+ antibioticakuur -+ antiblokkeersysteem -+ antichristelijke -+ anticiperend -+ antidiscriminatie -+ antidopingbeleid -+ antidopingbureau -+ antidopingcommissie -+ antidrugs -+ antidumpingmaatregelen -+ antiekmarkt -+ antifileplan -+ antifouling -+ antiglobaliseringsbeweging -+ antiglobalisme -+ antiglobalistische -+ antigodsdienstige -+ antijudaïsme -+ antikatholieke -+ antikernenergiebeweging -+ antikoloniale -+ antiliberale -+ antimisbruikbepaling -+ antimonarchistische -+ antioorlogsfilm -+ antioxidant -+ antipasti -+ antipersoonsmijnen -+ antipolitiek -+ antipsychotica -+ antipsychoticum -+ antiquark -+ antiraketschild -+ antiraketsystemen -+ antirakettenschild -+ antireligieuze -+ antirookbeleid -+ antirookpil -+ antischimmelmiddel -+ antispeculatiebeding -+ antistollingsmiddelen -+ antitankmijn -+ antitankmijnen -+ antitankwapen -+ antiterreurmaatregelen -+ antiterreurwet -+ antiterrorismewet -+ antitrustproces -+ antitrustwetgeving -+ antitrustzaak -+ antivertragingsplan -+ antivirusbedrijven -+ antivirussoftware -+ antraxsporen -+ antwoordbrief -+ antwoordformulier -+ antwoordformulieren -+ antwoordpakket -+ antwoordpakketten -+ antwoordspel -+ antwoordzending -+ antwoordzendingen -+ anw -+ apartheidsbeleid -+ apartheidsregering -+ apartheidswetten -+ apenland -+ apennoot -+ apennoten -+ apensoort -+ aper -+ apk -+ apneu -+ apoptose -+ apparatenbouw -+ apparatsjiks -+ appartementengebouw -+ appartementseigenaren -+ appartementsrecht -+ appelboomgaard -+ appelgroen -+ appelgroene -+ appelrassen -+ applausmeter -+ applets -+ aprilnummer -+ aquatische -+ aquifer -+ aquifers -+ arbeidersfamilie -+ arbeidershuisje -+ arbeidersopstand -+ arbeidersscholen -+ arbeidersstaat -+ arbeiderszoon -+ arbeidsbevolking -+ arbeidscircuit -+ arbeidscultuur -+ arbeidsdeelname -+ arbeidsdeskundigen -+ arbeidsdruk -+ arbeidsduurverlenging -+ arbeidsduurvermindering -+ arbeidservaring -+ arbeidsflexibiliteit -+ arbeidsgehandicapte -+ arbeidsgehandicapten -+ arbeidsgerelateerde -+ arbeidsgeschikt -+ arbeidsgeschikte -+ arbeidsgeschikten -+ arbeidshandicap -+ arbeidsimmigratie -+ arbeidsjaar -+ arbeidskorting -+ arbeidskrapte -+ arbeidslust -+ arbeidsmarktbeleid -+ arbeidsmarktcommunicatie -+ arbeidsmarktperspectief -+ arbeidsmarktpositie -+ arbeidsmarktprobleem -+ arbeidsmarktproblemen -+ arbeidsmigranten -+ arbeidsnormen -+ arbeidsongeschikten -+ arbeidsongeschiktheidsrisico -+ arbeidsparticipatie -+ arbeidsplaatsvoorziening -+ arbeidsplek -+ arbeidsre -+ arbeidsre-integratie -+ arbeidsrechter -+ arbeidsrelatie -+ arbeidsrelaties -+ arbeidsreservoir -+ arbeidsstandaarden -+ arbeidstekorten -+ arbeidstijdenwet -+ arbeidstoeleiding -+ arbeidsveiligheid -+ arbeidsvormen -+ arbeidsvraag -+ arbitragepanel -+ arbo -+ arbodiensten -+ arbodienstverlening -+ arbozorg -+ archiefbestanden -+ archiefdienst -+ archiefdiensten -+ archiefmedewerker -+ archiefwerk -+ architectengroep -+ architectenkeuze -+ architectuurbeleid -+ architectuurbeschrijving -+ architectuurbeschrijvingen -+ architectuurbiënnale -+ architectuurbureau -+ architectuurcentrum -+ architectuurhistorische -+ architectuurliefhebbers -+ architectuurnota -+ architectuurprojecten -+ architectuurschets -+ architectuurstijl -+ architectuurtijdschriften -+ architectuurwedstrijd -+ architectuurwereld -+ armbreuk -+ armenwijk -+ armoededebat -+ armoedenorm -+ armoedenota -+ armoedevermindering -+ armsteunen -+ aromatherapie -+ arr. -+ arrestatiepoging -+ arrestatieverzoek -+ arrondissementele -+ art-nouveaustijl -+ artiestenbestaan -+ artiestenbureau -+ artiestenregeling -+ artilleriebeschieting -+ artilleriebeschietingen -+ artilleriegranaten -+ artistiek-inhoudelijke -+ arts-onderzoeker -+ arts-patiënt -+ artsendiploma -+ artsenstudie -+ artsenteam -+ artsentekort -+ asbestcement -+ asbestclaim -+ asbestclaims -+ asbestdeeltjes -+ asbestvervuiling -+ asbestverwijdering -+ asfaltbaan -+ asfaltcentrale -+ asfaltering -+ asfaltlaag -+ ashkenazische -+ asielaanvrager -+ asielaanvragers -+ asieladvocaat -+ asieladvocaten -+ asielcentrum -+ asieldebat -+ asieldossier -+ asieldossiers -+ asielkinderen -+ asielkwestie -+ asielland -+ asielopvang -+ asielpolitiek -+ asielprobleem -+ asielproblematiek -+ asielprocedure -+ asielrelaas -+ asielstatus -+ asielstroom -+ asielsysteem -+ asieltoerisme -+ asielverhaal -+ asielverzoek -+ asielvraagstuk -+ asielzaken -+ asielzoekersbeleid -+ asielzoekerskinderen -+ asielzoekersproblematiek -+ aspartaam -+ aspergesteken -+ aspergesteker -+ aspergestekers -+ aspirant-agenten -+ aspirant-lidstaten -+ aspirant-omroep -+ aspirant-ouders -+ assimilatielampen -+ assisenproces -+ assistent in opleiding -+ assistent-coach -+ assistent-directeur -+ assistent-ploegleider -+ assistent-regisseur -+ assistent-trainer -+ assistent-trainers -+ astrofotografie -+ asverstrooiing -+ aswolk -+ atb -+ atherosclerose -+ atletencommissie -+ atletiekbaan -+ atletiekbond -+ atletiekcarrière -+ atletiekcoach -+ atletiekevenement -+ atletiekfederatie -+ atletiekloopbaan -+ atletiektrainer -+ atletiekvereniging -+ atletiekwereld -+ atoomagentschap -+ atoommacht -+ atoompolitiek -+ atoomprogramma -+ atoomtests -+ atoomtransport -+ attractiebeginsel -+ attractiewaarde -+ au pair -+ au pairs -+ audiologische -+ auditbureau -+ auditkantoor -+ australopithecus -+ auteursrechtaanduiding -+ auteursrechtaanduidingen -+ auteursrechthebbende -+ auteursrechthebbenden -+ authenticatie -+ authentificatie -+ auto van de zaak -+ autobedrijf -+ autobeleid -+ autoblad -+ autobouwer -+ autobouwers -+ autobrand -+ autobranden -+ autobrandstof -+ autobrandstoffen -+ autoconcern -+ autoconstructeur -+ autoconstructeurs -+ autocorrectie -+ autocriminaliteit -+ autodak -+ autodek -+ autodelen -+ autodelers -+ autodeuren -+ autodistributie -+ autodivisie -+ autofinanciering -+ autogebruik -+ autogebruiker -+ autogebruikers -+ autogek -+ autogeschiedenis -+ autogigant -+ autogroep -+ autoinbraken -+ autojournalisten -+ autokilometers -+ autokoper -+ autokopers -+ autokostenforfait -+ autoland -+ autoleasing -+ autoliefhebber -+ autoliefhebbers -+ autologe -+ automaker -+ automakers -+ automatenbranche -+ automatiseringsbranche -+ automatiseringsdiensten -+ automatiseringskosten -+ automatiseringspersoneel -+ automatiseringsproblemen -+ automatiseringssystemen -+ automobiele -+ automobielfabriek -+ automobielfabrieken -+ automobielfabrikant -+ automobielfabrikanten -+ automobielfederatie -+ automobielmarkt -+ automobielnijverheid -+ automobilistenclub -+ automobilistenvereniging -+ automuseum -+ autonavigatie -+ autonavigatiesystemen -+ autonijverheid -+ autonomiestatuut -+ autopech -+ autoprijzen -+ autoproducent -+ autopsierapport -+ autoreclame -+ autoreus -+ autosector -+ autovakantie -+ autovakanties -+ autoveren -+ autoverkoper -+ autoverkopers -+ autoverzekeraar -+ autoverzekeraars -+ autowegennet -+ autowereld -+ autozwendel -+ avantgardistische -+ avondconcerten -+ avondenlang -+ avondhandel -+ avondnieuws -+ avondopenstelling -+ avondprogrammering -+ avondretour -+ avondstudie -+ avondtarief -+ avondwake -+ avondwerk -+ avonturenkomedie -+ avonturenpark -+ axiologische -+ b'tjes -+ b-kantje -+ b-kantjes -+ baangarantie -+ baangaranties -+ baangebruik -+ baanverlenging -+ baanwerkers -+ baanwielrennen -+ baanwielrenner -+ baanwinkels -+ baanzekerheid -+ baardloos -+ baardschrapper -+ baatbelasting -+ baboesjka -+ babyfoto's -+ babylijkje -+ babymelkpoeder -+ babymoord -+ babyroof -+ babytijd -+ babyvoedsel -+ bachelor-masterstructuur -+ bachelordiploma -+ bachelorfase -+ bachelorgraad -+ backbone -+ backups -+ bacteriegroei -+ bacterieziekte -+ badcultuur -+ badlijn -+ badmintonvereniging -+ bagagecontrole -+ bagatelliserend -+ bagatellisering -+ baggeractiviteiten -+ baggerconcern -+ baggerdepot -+ baggerfusie -+ baggergroep -+ baggerindustrie -+ baggeroorlog -+ baggerpoot -+ baggersector -+ baggervloot -+ baggy -+ baht -+ bain -+ baissemarkt -+ bakboter -+ bakkerijproducten -+ bakkerszoon -+ bakolie -+ bakpapier -+ bakproces -+ baksteenfabricage -+ baksteenindustrie -+ baksteenproducent -+ baktijd -+ balanshandhaving -+ balansstructuur -+ balansverhoudingen -+ balcontact -+ balend -+ balende -+ balgstuw -+ ballad -+ ballastwater -+ ballenbad -+ balletles -+ balletlessen -+ balletopleiding -+ ballettechniek -+ balletvoorstellingen -+ ballonvlucht -+ balsamico -+ balsport -+ balsporten -+ balvast -+ bamboebos -+ bamboefluit -+ bamboescheuten -+ bamboetuin -+ banaliseert -+ banaliseren -+ bananenconflict -+ bananenoorlog -+ bananenproducenten -+ bananenregime -+ bandenconcern -+ bandenfabrikant -+ bandenfabrikanten -+ bandenindustrie -+ bandenmaker -+ bandenproducent -+ bandgeluid -+ bandnaam -+ bandoneonspeler -+ bandparodist -+ bandwerk -+ banenbeleid -+ banenbeurs -+ banencijfers -+ banencreatie -+ banenmachine -+ banenmotor -+ banenoverleg -+ banenreductie -+ banensite -+ banenstelsel -+ banenverlies -+ banenwinkel -+ bank-verzekeraar -+ bankafschrift -+ bankanalisten -+ bankautoriteiten -+ bankcliënten -+ bankcombinatie -+ bankconcern -+ bankdivisie -+ bankdochter -+ bankdocumenten -+ bankenfusie -+ bankenlandschap -+ bankenstrijd -+ bankentoezicht -+ bankfraude -+ bankfusie -+ bankgift -+ bankgigant -+ bankgroep -+ bankiersgeslacht -+ bankierszoon -+ banking -+ bankklanten -+ bankleningen -+ bankmedewerker -+ bankmedewerkers -+ bankoverschrijving -+ bankoverschrijvingen -+ bankpoot -+ bankpresident -+ bankpresidenten -+ bankproduct -+ bankrover -+ bankschandaal -+ bankschulden -+ banksector -+ bankstelsel -+ banksysteem -+ banksystemen -+ banktarieven -+ bankvergunning -+ bankverzekeraar -+ bankverzekeringen -+ bankverzekeringsgroep -+ bankwereld -+ bankwetgeving -+ banque -+ baptistische -+ barbecuesaus -+ barcodeapparatuur -+ barcodelezer -+ barcodescanner -+ barcodescanners -+ barnen -+ barokcello -+ barokcomponisten -+ barokhobo -+ barokopera -+ barokviool -+ barvrouw -+ basisadministratie -+ basisaftrek -+ basisbezetting -+ basisboek -+ basiscommandant -+ basiscomponenten -+ basisconcept -+ basisconditie -+ basiscontract -+ basisdemocratie -+ basisdiensten -+ basisdienstverlening -+ basiseenheid -+ basiself -+ basiselftal -+ basisformatie -+ basisformule -+ basisgedachte -+ basisgoederen -+ basisgrondstoffen -+ basisherfinancieringstransactie -+ basishouding -+ basisindeling -+ basisindelingen -+ basisinfrastructuur -+ basisinvestering -+ basiskaart -+ basiskapitaal -+ basiskleur -+ basiskrachten -+ basiskwaliteit -+ basislijn -+ basismaterialen -+ basismotor -+ basisniveau -+ basisnorm -+ basisnormen -+ basisonderzoek -+ basisorganisaties -+ basispensioen -+ basisplaats -+ basisplan -+ basispolis -+ basispolitiezorg -+ basisprobleem -+ basisprofiel -+ basisrecht -+ basisrechten -+ basisregeling -+ basisregistratie -+ basisregistraties -+ basisruimte -+ basisscenario -+ basisscholieren -+ basisschooldirecteur -+ basisschooljeugd -+ basisschoolleeftijd -+ basissnelheid -+ basisstation -+ basisstations -+ basisstelling -+ basisstelsel -+ basisstipendium -+ basisstoffen -+ basisstructuur -+ basisstukken -+ basistaken -+ basisteam -+ basistechnologie -+ basistraining -+ basisuitkering -+ basisuitvoering -+ basisvariant -+ basisverdrag -+ basisvergoeding -+ basisversie -+ basisvertrouwen -+ basisverzekering -+ basisvoedsel -+ basisvormen -+ basisvraag -+ basisvragen -+ basiswaarde -+ basiswerkwijze -+ basiswet -+ basiswetten -+ basiswoord -+ basisziekenhuis -+ basketbalbond -+ basketbalclub -+ basketbalclubs -+ basketbalcoach -+ basketbalploeg -+ basketbalster -+ basketbalsters -+ basketbaltalent -+ basketbalteam -+ basketbaltitel -+ basketbaltoernooi -+ basketbalwereld -+ baslijn -+ baslijnen -+ bassiste -+ basso -+ basspel -+ bataljonsleiding -+ baten-lastenstelsel -+ batenanalyse -+ bbp-groei -+ be -+ beachvolley -+ beatjuggelen -+ beau monde -+ beaufort -+ beautycentrum -+ beautysalon -+ bebording -+ bebouwingsdichtheid -+ bedbodem -+ beddencapaciteit -+ beddenhuis -+ beddentekort -+ bedelnap -+ bedeltocht -+ bedieden -+ bediendebond -+ bediendekamer -+ bedieningsorganen -+ bedlegerigen -+ bedlinnen -+ bedrijfs -+ bedrijfsafval -+ bedrijfsbebouwing -+ bedrijfsbeheer -+ bedrijfsbelang -+ bedrijfsbelangen -+ bedrijfsbestemming -+ bedrijfsbeëindiging -+ bedrijfsbladen -+ bedrijfscashflow -+ bedrijfscijfers -+ bedrijfscode -+ bedrijfscollecties -+ bedrijfscomplex -+ bedrijfsconstructies -+ bedrijfscontactfunctionaris -+ bedrijfscontinuïteit -+ bedrijfsdirectie -+ bedrijfsdocumenten -+ bedrijfsdoeleinden -+ bedrijfseconomen -+ bedrijfseconoom -+ bedrijfseenheden -+ bedrijfseenheid -+ bedrijfservaring -+ bedrijfsevenementen -+ bedrijfsfaillissementen -+ bedrijfsfeest -+ bedrijfsfeestje -+ bedrijfsfilm -+ bedrijfsfinanciering -+ bedrijfsfitness -+ bedrijfsfonds -+ bedrijfsfusies -+ bedrijfsgeheim -+ bedrijfsgeschiedenis -+ bedrijfsgezondheidsdienst -+ bedrijfsgrond -+ bedrijfshal -+ bedrijfshuisvesting -+ bedrijfshulpverlening -+ bedrijfsinkomen -+ bedrijfsjurist -+ bedrijfsjuristen -+ bedrijfskas -+ bedrijfskolom -+ bedrijfskritisch -+ bedrijfskritische -+ bedrijfsleidersverzekering -+ bedrijfslocaties -+ bedrijfsmanagement -+ bedrijfsmarge -+ bedrijfsmarkt -+ bedrijfsmatig -+ bedrijfsmatige -+ bedrijfsmatiger -+ bedrijfsmodellen -+ bedrijfsmuren -+ bedrijfsnaam -+ bedrijfsnamen -+ bedrijfsnetwerk -+ bedrijfsnetwerken -+ bedrijfsnieuws -+ bedrijfsobligaties -+ bedrijfsomgeving -+ bedrijfsomzet -+ bedrijfsontwikkeling -+ bedrijfsopbrengsten -+ bedrijfsopleiding -+ bedrijfsopvolger -+ bedrijfsopvolging -+ bedrijfspark -+ bedrijfsparken -+ bedrijfspensioen -+ bedrijfspensioenen -+ bedrijfsplaatsen -+ bedrijfspraktijk -+ bedrijfspresentatie -+ bedrijfsprestaties -+ bedrijfsprofielen -+ bedrijfsreferentie -+ bedrijfsreserve -+ bedrijfsschool -+ bedrijfssite -+ bedrijfssoftware -+ bedrijfsspaarregeling -+ bedrijfsspaarregelingen -+ bedrijfssparen -+ bedrijfssteun -+ bedrijfsstrategie -+ bedrijfsstrategieën -+ bedrijfsstructuur -+ bedrijfstakonderzoek -+ bedrijfstakpensioenfondsen -+ bedrijfstemperatuur -+ bedrijfstoepassingen -+ bedrijfstop -+ bedrijfsuitbreiding -+ bedrijfsuitvoering -+ bedrijfsverlies -+ bedrijfsverplaatsing -+ bedrijfsverplaatsingen -+ bedrijfsvervoer -+ bedrijfsverzamelgebouw -+ bedrijfsverzamelgebouwen -+ bedrijfsvestiging -+ bedrijfsvoeringsystemen -+ bedrijfsvoertuigen -+ bedrijfsvoorraden -+ bedrijfsvorm -+ bedrijfswaarde -+ bedrijfswereld -+ bedrijfswoning -+ bedrijfswoningen -+ bedrijvenbeurs -+ bedrijvendokter -+ bedrijvengroep -+ bedrijvenmarkt -+ bedrijvennummer -+ bedrijvensector -+ bedshow -+ beeldbepalend -+ beeldbepalende -+ beeldelementen -+ beeldencollectie -+ beeldenmakers -+ beeldenreeksen -+ beeldentaal -+ beeldentuin -+ beeldformaten -+ beeldfragmenten -+ beeldgedichten -+ beeldindustrie -+ beeldinformatie -+ beeldinstituut -+ beeldkwaliteitsplan -+ beeldmakers -+ beeldmerken -+ beeldredacteur -+ beeldschermergonomie -+ beeldschermwerkers -+ beeldtaal -+ beeldtechnieken -+ beeldtelefonie -+ beeldverhalen -+ beeldvormende -+ beenham -+ beenprothese -+ beenwond -+ beerenburg -+ begeleidingsinstrument -+ begeleidingsplan -+ begeleidingsprogramma -+ begeleidingstraject -+ begindagen -+ begininvestering -+ beglaasde -+ begrafenisceremonie -+ begrafenisdienst -+ begrafenismuziek -+ begrafenisverzekering -+ begrazing -+ begrotingsafspraken -+ begrotingsbehandeling -+ begrotingsbehandelingen -+ begrotingsbeleid -+ begrotingscommissie -+ begrotingsconclaaf -+ begrotingscontrole -+ begrotingsdirecteur -+ begrotingsevenwicht -+ begrotingsgat -+ begrotingsgeld -+ begrotingskader -+ begrotingsmaatregelen -+ begrotingsmeevallers -+ begrotingsminister -+ begrotingsnorm -+ begrotingsnormen -+ begrotingsonderhandelingen -+ begrotingsopmaak -+ begrotingsoverleg -+ begrotingsplan -+ begrotingsplannen -+ begrotingspolitiek -+ begrotingsproblemen -+ begrotingsraad -+ begrotingsregels -+ begrotingsronde -+ begrotingssaldo -+ begrotingssanering -+ begrotingssituatie -+ begrotingssteun -+ begrotingssysteem -+ begrotingssystematiek -+ begrotingsuitgaven -+ begrotingsvoorbereiding -+ begrotingszaken -+ behandelcapaciteit -+ behandelduur -+ behandelingsovereenkomst -+ behandelinrichting -+ behandelmethodes -+ behandelplaatsen -+ behandelplan -+ behandelprogramma -+ behandelprotocollen -+ behandeltijd -+ behandelwijze -+ behandelwijzen -+ behartenswaardige -+ beheerfunctie -+ beheerorganisatie -+ beheerorganisaties -+ beheerprocedure -+ beheerprocedures -+ beheerrol -+ beheerrollen -+ beheerscomité -+ beheerscontract -+ beheerscontracten -+ beheersingsmaatregel -+ beheersingsmaatregelen -+ beheersinstrument -+ beheersmaatregelen -+ beheersplan -+ beheersplannen -+ beheersproblemen -+ beheersstichting -+ beheersstructuur -+ beheersvergoeding -+ bejaardensoos -+ bekaaider -+ bekabelingsysteem -+ bekabelingsystemen -+ bekendsten -+ bekeravontuur -+ bekeringsdrang -+ bekernederlaag -+ bekerprogramma -+ bekerronde -+ bekerstrijd -+ bekerstunt -+ bekertreffen -+ bekerwinst -+ bekerzege -+ bekkenbodemspieren -+ bekkenbreuk -+ bekkeninstabiliteit -+ bekkentrekker -+ belangengroepering -+ belangengroeperingen -+ belangenverdediging -+ belangrijksten -+ belastender -+ belastingadministratie -+ belastingadministraties -+ belastingadvies -+ belastingadviesbureau -+ belastingadvieskantoor -+ belastingakkoord -+ belastingbasis -+ belastingbedrag -+ belastingbeleid -+ belastingbesparing -+ belastingbetalende -+ belastingbetaling -+ belastingcapaciteit -+ belastingclaim -+ belastingconcurrentie -+ belastingconstructies -+ belastingcontrole -+ belastingcoördinatie -+ belastingdebat -+ belastingderving -+ belastingdeskundigen -+ belastingdiskette -+ belastingdossier -+ belastingfactuur -+ belastinggebied -+ belastinggegevens -+ belastinggrondslag -+ belastingguldens -+ belastingharmonisatie -+ belastinghervorming -+ belastinghervormingen -+ belastingherziening -+ belastinginners -+ belastingkorting -+ belastingkrediet -+ belastingkwestie -+ belastingmeevaller -+ belastingmeevallers -+ belastingmiddelen -+ belastingniveau -+ belastingontvangst -+ belastingontwijking -+ belastingoperatie -+ belastingpakket -+ belastingpapieren -+ belastingpercentage -+ belastingplan -+ belastingplicht -+ belastingpolitiek -+ belastingrechter -+ belastingregel -+ belastingregels -+ belastingregime -+ belastingregimes -+ belastingschaal -+ belastingschalen -+ belastingschuld -+ belastingsdienst -+ belastingsignalen -+ belastingstructuur -+ belastingsysteem -+ belastingsystemen -+ belastingtegenvaller -+ belastingtegenvallers -+ belastingteruggaaf -+ belastingteruggave -+ belastinguitgaven -+ belastingverdrag -+ belastingvereenvoudiging -+ belastingverlichting -+ belastingvermeerdering -+ belastingvermindering -+ belastingverminderingen -+ belastingverplichtingen -+ belastingvoet -+ belastingvoorstel -+ belastingvoorstellen -+ belastingvrijdom -+ belastingzaak -+ belbedrijf -+ belbedrijven -+ belcentrum -+ beleggersblad -+ beleggersclub -+ beleggersvertrouwen -+ beleggerswereld -+ beleggingsactiviteiten -+ beleggingsbeleid -+ beleggingsbeslissingen -+ beleggingsblad -+ beleggingsbladen -+ beleggingscategorie -+ beleggingsconstructie -+ beleggingsconstructies -+ beleggingsdeskundigen -+ beleggingsgedrag -+ beleggingshorizon -+ beleggingshypotheek -+ beleggingshypotheken -+ beleggingsinstellingen -+ beleggingsinstrument -+ beleggingsinstrumenten -+ beleggingsjaar -+ beleggingskapitaal -+ beleggingsmix -+ beleggingsopbrengst -+ beleggingsopbrengsten -+ beleggingspolitiek -+ beleggingsprestaties -+ beleggingsproduct -+ beleggingsproducten -+ beleggingsregels -+ beleggingsrisico -+ beleggingstransacties -+ beleggingsvennootschap -+ beleggingsvorm -+ beleggingsvormen -+ beleggingsvrijheid -+ beleggingswereld -+ beleggingswinst -+ beleggingswinsten -+ beleidsaanbevelingen -+ beleidsaanpassingen -+ beleidsadvisering -+ beleidsagenda -+ beleidsalternatieven -+ beleidsbepaling -+ beleidsbrief -+ beleidscomité -+ beleidsconclusies -+ beleidsconcurrentie -+ beleidscoördinatie -+ beleidscoördinator -+ beleidsdomeinen -+ beleidsinstantie -+ beleidsinstanties -+ beleidsintensiveringen -+ beleidskader -+ beleidskaders -+ beleidskeuzen -+ beleidsmix -+ beleidsonderwerpen -+ beleidsonderzoek -+ beleidsoptie -+ beleidsopties -+ beleidsopvattingen -+ beleidsorganen -+ beleidsoverleg -+ beleidspakket -+ beleidspartij -+ beleidsprioriteit -+ beleidsprioriteiten -+ beleidsproblemen -+ beleidsproces -+ beleidsprogramma -+ beleidsregels -+ beleidsstandpunt -+ beleidsstandpunten -+ beleidsverandering -+ beleidsveranderingen -+ beleidsverantwoordelijken -+ beleidsverklaring -+ beleidsvisie -+ beleidsvraagstukken -+ beleidsvrijheid -+ beleidswetenschap -+ beleverd -+ beleveren -+ belgedrag -+ belgitude -+ belhuis -+ belichtingscompensatie -+ belkosten -+ belletjeswijn -+ belligerent -+ belope -+ belronde -+ belspelletjes -+ belster -+ beltaxi -+ belverkeer -+ belwaarde -+ bemestingsnormen -+ bemiddelbaren -+ bemiddelingsactiviteiten -+ bemiddelingsbedrijf -+ bemiddelingsbedrijven -+ bemiddelingsdienst -+ bemiddelingskosten -+ bemiddelingsprocedure -+ bemiddelingsprocedures -+ bemoeizorg -+ benaamd -+ benefietavond -+ benefit -+ benoemingsrecht -+ bentazon -+ bentoniet -+ benuttingsgraad -+ benzinedepots -+ benzinekartel -+ benzinekosten -+ benzinemaatschappij -+ benzinemarkt -+ benzinemerk -+ benzinemerken -+ benzineversie -+ benzinevoorraden -+ benzodiazepinen -+ benzodiazepines -+ beoordelingsexemplaar -+ beoordelingsexemplaren -+ beprijzing -+ berechte -+ berechtiging -+ beredderingskosten -+ bereidingstijd -+ bereikbaarheidsdiensten -+ bereikbaarheidsgids -+ bereikbaarheidsgidsen -+ bereikbaarheidsoffensief -+ bereikbaarheidsplan -+ berekeningsbasis -+ berenjacht -+ bergbezinkbassin -+ bergboeren -+ bergingscapaciteit -+ bergpaadjes -+ bergstaat -+ bergstaatje -+ bergstation -+ bergtrui -+ bergvakjes -+ bergvakken -+ berichtenservice -+ berichtjes -+ berlines -+ bernard -+ bernardshond -+ bernardshonden -+ beroepsaansprakelijkheid -+ beroepsactieve -+ beroepsactiviteit -+ beroepsactiviteiten -+ beroepsbekwaamheid -+ beroepsbokser -+ beroepscarrière -+ beroepscategorie -+ beroepscategorieën -+ beroepschauffeur -+ beroepschauffeurs -+ beroepscommissie -+ beroepscrimineel -+ beroepsdoeleinden -+ beroepsernst -+ beroepsfederatie -+ beroepsfederaties -+ beroepsfout -+ beroepsfouten -+ beroepsgebonden -+ beroepsgebruik -+ beroepsgenoten -+ beroepshouding -+ beroepsinkomen -+ beroepsinkomsten -+ beroepskamer -+ beroepskeuzetest -+ beroepskost -+ beroepskwalificatie -+ beroepsloopbaan -+ beroepsmensen -+ beroepsmilitairen -+ beroepsmuzikant -+ beroepsopvatting -+ beroepspersoneel -+ beroepsperspectief -+ beroepspolitici -+ beroepspoliticus -+ beroepsrechters -+ beroepsschriften -+ beroepssector -+ beroepssoldaat -+ beroepssoldaten -+ beroepssporter -+ beroepssporters -+ beroepsvisser -+ beroepsvisserij -+ beroepsvissers -+ beroepswereld -+ berovers -+ beschavingsideaal -+ beschavingsniveau -+ beschavingsoffensief -+ beschermhoes -+ beschermingsconstructie -+ beschermingsconstructies -+ beschermingsduur -+ beschermingslaag -+ beschermingsmechanisme -+ beschermingsmiddelen -+ beschermingsniveau -+ beschermingsplan -+ beschermingsplicht -+ beschermingsplichten -+ beschermingsprogramma -+ beschermingssysteem -+ beschermingstermijn -+ beschermingstermijnen -+ beschermingsvoorziening -+ beschermingsvoorzieningen -+ beschermingswal -+ beschikkingsbevoegdheid -+ beschrijfbaar -+ beschrijfbare -+ beseffend -+ beseffende -+ beslissingsduel -+ beslissingsmacht -+ beslissingsprocedures -+ besluite -+ besmettingsgraad -+ besparingsmogelijkheden -+ besparingspotentieel -+ besparingsronde -+ bestaansminimumtrekkers -+ bestaansniveau -+ bestedingsgedrag -+ bestedingsgroei -+ bestedingsniveau -+ bestedingsplan -+ bestedingsruimte -+ bestedingsvrijheid -+ bestektekening -+ bestektekeningen -+ bestemder -+ bestemmingplan -+ bestemmingsplanwijziging -+ bestemmingsverkeer -+ bestemmingswijziging -+ bestralingscentra -+ bestrijdingsplan -+ bestrijdingsprogramma -+ besturenfusie -+ bestuurdersaansprakelijkheid -+ bestuursacademies -+ bestuursadviseur -+ bestuursakkoord -+ bestuursbeleid -+ bestuurscommissie -+ bestuurscrisis -+ bestuurscultuur -+ bestuursdaden -+ bestuursdecreet -+ bestuursdwang -+ bestuurselite -+ bestuursfunctionarissen -+ bestuursinstellingen -+ bestuurskosten -+ bestuursmaatregel -+ bestuursniveaus -+ bestuursoverdracht -+ bestuursovereenkomst -+ bestuursperiode -+ bestuursposten -+ bestuurspraktijk -+ bestuursproblemen -+ bestuursrechter -+ bestuursrechters -+ bestuursrechtspraak -+ bestuursstijl -+ bestuurssysteem -+ bestuurstop -+ bestuurswerk -+ betaalbewijs -+ betaaldatum -+ betaaldiensten -+ betaalfunctie -+ betaalgedrag -+ betaalgemak -+ betaalkanaal -+ betaalkanalen -+ betaalmogelijkheden -+ betaalopdrachten -+ betaalstroken -+ betaalstrook -+ betaalverkeer -+ betaalwijze -+ betaalzender -+ betaalzenders -+ betalingscapaciteit -+ betalingsmogelijkheden -+ betalingsmoraal -+ betalingsproblemen -+ betalingsregeling -+ betalingsregelingen -+ betalingssystemen -+ betalingstransacties -+ betalingsuitstel -+ betegeling -+ betonindustrie -+ betonkolos -+ betonlaag -+ betonpalen -+ betrouwbaardere -+ beursbedrijf -+ beursbestuur -+ beursbrief -+ beurscommissie -+ beurscorrectie -+ beursdaling -+ beursdebuut -+ beursevolutie -+ beursfraude -+ beursfraudezaak -+ beursfusie -+ beursgemiddelde -+ beursgerelateerde -+ beursgeschiedenis -+ beursgraadmeter -+ beursgraadmeters -+ beurshal -+ beursherstel -+ beurshuis -+ beurshuizen -+ beurshype -+ beursinformatie -+ beursjaar -+ beursjaren -+ beursjongens -+ beurskapitalisatie -+ beurskapitalisaties -+ beurskrant -+ beursmaand -+ beursnieuweling -+ beursnieuws -+ beursomgeving -+ beursorder -+ beursorders -+ beursorganisatie -+ beursorganisaties -+ beurspagina -+ beurspagina's -+ beursplannen -+ beurspromovendi -+ beursrecords -+ beursregels -+ beursstemming -+ beurssysteem -+ beurstaks -+ beurstaksen -+ beurstoezicht -+ beurstoezichthouder -+ beursvennootschap -+ beursvennootschappen -+ beursweek -+ beurswereld -+ beurswijsheden -+ beurzenfusie -+ bevak -+ beveiligingsbranche -+ beveiligingsbureau -+ beveiligingsdienst -+ beveiligingsexpert -+ beveiligingsfirma -+ beveiligingsfirma's -+ beveiligingsinstallatie -+ beveiligingskenmerken -+ beveiligingslek -+ beveiligingslekken -+ beveiligingsmarkt -+ beveiligingsmechanisme -+ beveiligingsmechanismen -+ beveiligingsmedewerker -+ beveiligingsmedewerkers -+ beveiligingsmensen -+ beveiligingsmethoden -+ beveiligingsniveau -+ beveiligingsnorm -+ beveiligingsnormen -+ beveiligingspersoneel -+ beveiligingsplan -+ beveiligingsproblemen -+ beveiligingsproject -+ beveiligingssector -+ beveiligingssoftware -+ beveiligingstechnieken -+ bevelstructuur -+ bevoegdheidsconflicten -+ bevoegdheidsverdeling -+ bevolkingsaangroei -+ bevolkingsaantal -+ bevolkingsafname -+ bevolkingsdaling -+ bevolkingsdeel -+ bevolkingsfonds -+ bevolkingsgegevens -+ bevolkingsgrootte -+ bevolkingsontwikkeling -+ bevolkingsprobleem -+ bevolkingsproblematiek -+ bevolkingsregistratie -+ bevolkingsrijke -+ bevolkingssamenstelling -+ bevolkingstal -+ bevoorradingsketen -+ bevoorradingslijnen -+ bevorderend -+ bevorderende -+ bevraging -+ bevriezingsverschijnselen -+ bevrijdingsdagen -+ bevrijdingsfestivals -+ bevrijdingsjaar -+ bevrijdingsorganisatie -+ bevrijdingspoging -+ bevruchtingstechnieken -+ bewaarkosten -+ bewaarservice -+ bewaartemperatuur -+ bewaartermijn -+ bewakingsagent -+ bewakingsbedrijf -+ bewakingsbedrijven -+ bewegingsarmoede -+ bewegingsonderwijs -+ bewegingspatroon -+ bewegingsvormen -+ bewegingswetenschapper -+ bewener -+ bewijsvermoeden -+ bewijsvermoedens -+ bewijze -+ bewindsperiode -+ bewonersavond -+ bewonersgroep -+ bewonersorganisaties -+ bewonersplatform -+ bewonersraad -+ bewonersvereniging -+ bewonersverenigingen -+ bewonerszaken -+ bewustwordingscampagne -+ bez. -+ bez. vnw. -+ bezakt en bepakt -+ bezettende -+ bezettingspolitiek -+ bezinestations -+ bezinningsdagen -+ bezoekadres -+ bezoekerscijfers -+ bezoekersrecord -+ bezorgkosten -+ bezorgservice -+ bezuinigingsbedrag -+ bezuinigingsmogelijkheden -+ bezuinigingsopdracht -+ bezuinigingspakket -+ bezwaarfase -+ bezwaarmakende -+ bezwaarsysteem -+ bezwaartermijn -+ bezwarentermijn -+ beïnkten -+ bibliometrische -+ bibliotheekbeleid -+ bibliotheekgebouw -+ bibliotheekjes -+ bibliotheeknetwerk -+ bibliotheeksector -+ bibliotheekwereld -+ bibliotheekwetenschap -+ biculturele -+ biecht horen -+ biedgedrag -+ biedingsoorlog -+ biedingsproces -+ biedingsstrijd -+ biedkoers -+ biedoorlog -+ biedplicht -+ biedronde -+ bierbrouwen -+ biercultuur -+ bierdrinkende -+ bierfeest -+ biergebruik -+ biergigant -+ biergroep -+ bierhandelaars -+ bierliefhebber -+ biermagnaat -+ biermerk -+ biermerken -+ bieromzet -+ bierprijs -+ bierproducent -+ bierreclame -+ biersector -+ bierverkoop -+ biervoorraad -+ bietenpulp -+ bifida -+ big bang -+ bij machte -+ bij nachte -+ bijeengespaard -+ bijenhouderij -+ bijenhuis -+ bijenhuizen -+ bijenschuur -+ bijgebeend -+ bijgedaan -+ bijgeroepen -+ bijgeschoolde -+ bijgezegd -+ bijhangen -+ bijhorende -+ bijkletsen -+ bijlenen -+ bijlmerramp -+ bijna-faillissement -+ bijna-ongevallen -+ bijrijdersstoel -+ bijschrifttekst -+ bijstandgerechtigden -+ bijstandontvangers -+ bijstandsbeleid -+ bijstandscliënten -+ bijstandsfraude -+ bijstandsgeld -+ bijstandsgezinnen -+ bijstandsklanten -+ bijstandskosten -+ bijstandsniveau -+ bijstandsouders -+ bijstandsteam -+ bijstandsverplichting -+ bijstanduitkering -+ bijstoken -+ bijterig -+ bijtincidenten -+ bijtwonden -+ bijzienden -+ bijzijnde -+ bilateralisme -+ biljartvereniging -+ biloba -+ bindingsangst -+ bindingseisen -+ bindweefselvorming -+ bindwijze -+ binnendrijven -+ binnengebied -+ binnengluren -+ binneninrichting -+ binnenkijken -+ binnenlandpagina -+ binnenlands-politieke -+ binnenlandspolitiek -+ binnenlucht -+ binnenmilieu -+ binnensijpelen -+ binnensijpelt -+ binnenvaarttanker -+ binnenvoer -+ binnenzwembad -+ bio-ecologisch -+ bio-ethanol -+ bio-informatica -+ bioboer -+ bioboeren -+ biobrandstoffen -+ biofarmaceutische -+ biofilm -+ biogarantie -+ biogenetica -+ biolandbouw -+ biologieleraar -+ biologieleraren -+ biomassaproductie -+ biomateriaal -+ biomaterialen -+ biometrie -+ bioplastic -+ bioplastics -+ bioproducten -+ biopsie -+ biopten -+ bioscoopcomplexen -+ bioscoopconcern -+ bioscoopdebuut -+ bioscoopgangers -+ bioscoopgroep -+ bioscooproulement -+ bioscoopversie -+ biosector -+ biotech -+ biotechbedrijf -+ biotechbedrijven -+ biotechnologiesector -+ biotechnologisch -+ bioterroristische -+ biowapens -+ black -+ bladenmaker -+ bladenmakers -+ bladenman -+ bladerprogramma -+ blanche -+ blanje -+ blauw-gele -+ blauw-groen -+ blauw-groene -+ blauw-rode -+ blauw-wit -+ blauw-witte -+ blauw-zwart -+ blauw-zwarte -+ blauwalg -+ blauwalgen -+ blauwmaanzaad -+ blauwschokker -+ blauwschokkers -+ blauwtinten -+ blauwtong -+ bleekneuzige -+ blessurebehandeling -+ blessuregevallen -+ blessurepreventie -+ bliksemonderzoek -+ blind date -+ blind vlieg -+ blind vliegen -+ blind vliegt -+ blind vlogen -+ blind vloog -+ blingbling -+ blitzbezoek -+ blitzcarrière -+ blitzkrieg -+ bloed-hersenbarrière -+ bloedafname -+ bloedcontact -+ bloedcontrole -+ bloedcontroles -+ bloeddiamant -+ bloeddiamanten -+ bloeddoorstroming -+ bloede -+ bloedens -+ bloedklonters -+ bloedproducten -+ bloedschandaal -+ bloedspetters -+ bloedstaal -+ bloedverdunnend -+ bloedverdunnende -+ bloedverdunner -+ bloedverdunners -+ bloedvoorziening -+ bloedwaarden -+ bloemenkwekerij -+ bloemennaam -+ bloementapijt -+ bloemenveld -+ bloemenverkoopster -+ bloemenzaak -+ bloemhoofdjes -+ bloemsierkunst -+ bloemsoorten -+ blokdag -+ blokdagen -+ blokkensysteem -+ blokkeringsminderheid -+ bloody -+ blousejes -+ bluesgevoel -+ blueslegende -+ bluesman -+ bluesmuzikant -+ bluesnummer -+ bluesy -+ blusapparatuur -+ blusvliegtuig -+ blusvoertuigen -+ bluswagen -+ blèt -+ boa constrictor -+ bodemas -+ bodembedrag -+ bodembeheer -+ bodembeleid -+ bodembewegingen -+ bodemgebruik -+ bodemkwaliteit -+ bodemleven -+ bodemsamenstelling -+ bodemsaneringsdecreet -+ bodemsaneringsprojecten -+ bodemsoorten -+ bodemtarief -+ bodemverbeteraar -+ bodemvissen -+ bodemvrijheid -+ bodemvruchtbaarheid -+ bodhisattva -+ bodylotion -+ boede -+ boegdeur -+ boegdeuren -+ boekbedrijf -+ boekel -+ boekenbedrijf -+ boekenbijlage -+ boekenbranche -+ boekendorp -+ boekengeld -+ boekenketen -+ boekenkisten -+ boekenkoper -+ boekenkopers -+ boekenpakket -+ boekenprijs -+ boekenprijzen -+ boekenprogramma -+ boekensector -+ boekenserie -+ boekenstad -+ boekentoptien -+ boekenuitgever -+ boekenuitgeverij -+ boekenverkoop -+ boekenwereld -+ boekenwinkel -+ boekenwinkels -+ boekers -+ boekgeschiedenis -+ boekhoudnormen -+ boekhoudregels -+ boekhoudsoftware -+ boekpresentatie -+ boekverfilming -+ boekverlies -+ boekverliezen -+ boerderettes -+ boerencoöperaties -+ boerengat -+ boerengehucht -+ boerengemeenschap -+ boereninkomen -+ boerenkeuken -+ boerenleider -+ boerenlobby -+ boerenorganisatie -+ boerenpartij -+ boerenschuren -+ boerensector -+ boerenwijsheid -+ boerkaverbod -+ boetebepaling -+ boeterente -+ boiled -+ bokscarrière -+ boksfilm -+ bokslegende -+ boksmatch -+ bolakker -+ bolakkers -+ bollenboer -+ bollentelers -+ bolling -+ bollingen -+ bolsjevistische -+ bombardementspauze -+ bomenkap -+ bomentuin -+ bomexpert -+ bommelder -+ bommenlegger -+ bommenleggers -+ bommenmaker -+ bompakket -+ bon mot -+ bon mots -+ bon ton -+ bonders -+ bondsblad -+ bondsdagverkiezingen -+ bondsminister -+ bondsregering -+ bonesteak -+ bonesteaks -+ bonnenboekje -+ bonnensysteem -+ bono -+ bonus-cd -+ bonus-malus -+ bonus-malussysteem -+ bonuskaart -+ boodschappenkarretje -+ boodschappenmand -+ book -+ booming -+ boomkorvissers -+ boomteelt -+ boorbedrijf -+ boordkanon -+ boordkanonnen -+ boordpersoneel -+ boormethode -+ boorproces -+ boorspoeling -+ boortechniek -+ boortechnieken -+ boortunnel -+ boorvergunning -+ bootsmansjongen -+ bootverbinding -+ bootverbindingen -+ borderline -+ borger -+ borging -+ borgsteller -+ borreltafelpraat -+ borreltijd -+ borstelsnor -+ borstelwerk -+ borstelwerken -+ borstfoto's -+ borstimplantaten -+ borstkankergen -+ borstkankeronderzoek -+ borstkankerpatiënten -+ borstkankerscreening -+ borstoperatie -+ borstsparende -+ borststreek -+ borsttumor -+ borstvergroting -+ borstverkleining -+ borstweefsel -+ bosarbeid -+ bosarbeider -+ bosarbeiders -+ bosareaal -+ bosbeleid -+ bosbezit -+ boscertificaten -+ bosdieren -+ boseigenaar -+ boseigenaren -+ bosgebied -+ bosland -+ bosnegergemeenschappen -+ bosperceel -+ bosspeurtocht -+ bosui -+ bosvogels -+ bosvruchten -+ bosweg -+ botenparade -+ boterfraude -+ botfragmenten -+ botmassa -+ botmateriaal -+ botonderzoek -+ botstructuur -+ bottom -+ botuline -+ botverlies -+ bougainvillea -+ boule -+ boulen -+ boulimia nervosa -+ bouquet -+ bouwaanvraag -+ bouwactiviteit -+ bouwbeperkingen -+ bouwbesluit -+ bouwbeurs -+ bouwbranche -+ bouwbudget -+ bouwbureau -+ bouwcapaciteit -+ bouwcombinaties -+ bouwconcerns -+ bouwconsortium -+ bouwcoördinator -+ bouwdivisie -+ bouwdrift -+ bouwenquête -+ bouwfraudes -+ bouwfraudezaak -+ bouwgeschiedenis -+ bouwgigant -+ bouwgolf -+ bouwgroep -+ bouwhekken -+ bouwhistoricus -+ bouwhistorisch -+ bouwhoogte -+ bouwindustrie -+ bouwlampen -+ bouwleges -+ bouwlieden -+ bouwlustige -+ bouwmachines -+ bouwmagnaat -+ bouwmassa -+ bouwmaterialengroep -+ bouwmethoden -+ bouwmethodes -+ bouwmogelijkheden -+ bouwondernemer -+ bouwondernemers -+ bouwopdracht -+ bouwopgave -+ bouwpastoor -+ bouwperceel -+ bouwpercelen -+ bouwperiode -+ bouwplek -+ bouwploeg -+ bouwpoot -+ bouwproducten -+ bouwproductie -+ bouwregels -+ bouwschema -+ bouwspeelplaats -+ bouwstaking -+ bouwstroom -+ bouwsysteem -+ bouwteam -+ bouwtechniek -+ bouwtechnieken -+ bouwtempo -+ bouwtype -+ bouwvakantie -+ bouwverkeer -+ bouwzaken -+ bovenbouwleerling -+ bovenbouwleerlingen -+ bovenklasse -+ bovenlood -+ bovenlucht -+ bovenschoolse -+ boventalligen -+ bovenwaarde -+ bovenwijkse -+ boxjes -+ boxspring -+ boysband -+ braadboter -+ braadkip -+ braadvocht -+ braadzak -+ braak leggen -+ braaklegging -+ braaksporen -+ brac -+ brachytherapie -+ braillezendingen -+ brainstormsessie -+ brainstormsessies -+ bramenstruiken -+ brancheorganisaties -+ brandaanslag -+ brandaanslagen -+ branddetectie -+ brandgeur -+ brandoefening -+ brandrisico -+ brandsporen -+ brandstofcrisis -+ brandstofgebrek -+ brandstofgebruik -+ brandstofprijs -+ brandstofrekening -+ brandstofstaven -+ brandstofvoorraad -+ brandveiligheidsvoorschriften -+ brandvertragers -+ brandweerinspectie -+ brandweerofficier -+ brandweerorganisatie -+ brandweerploeg -+ brandweerploegen -+ brandweerpost -+ brandweertaken -+ brandweerteam -+ brandweervoertuigen -+ brandweerzorg -+ brandwondenpatiënten -+ brandwondenslachtoffers -+ break-evenpunt -+ breakbeat -+ breakdancer -+ breasted -+ breed lachend -+ breedbanddiensten -+ breedbandnetwerk -+ breedbandnetwerken -+ breedbandtechnologie -+ breedbandverbinding -+ breedbandverbindingen -+ breedbeeldscherm -+ breedgedragen -+ brengservice -+ bric -+ briefschrijfster -+ brievenbundel -+ brievenbuspost -+ brievenroman -+ brinkdorp -+ brode -+ broedpaar -+ broedparen -+ broedplek -+ broedseizoen -+ broedsucces -+ broekband -+ broeksriem -+ bromfietscertificaat -+ bromfietsster -+ brommobiel -+ brommobielen -+ bromscooter -+ bromscooters -+ bronbescherming -+ bronbestand -+ bronbestanden -+ bronmateriaal -+ broodbakken -+ broodfabrieken -+ broodje aap -+ broodjeslunch -+ broodjesmaaltijd -+ broodspeler -+ brugconstructie -+ brugdeel -+ brugdelen -+ brugklasleerlingen -+ brugpensionering -+ bruidskleding -+ bruin-zwarte -+ bruinrot -+ bruintinten -+ brutalen -+ brutobedrag -+ brutodividend -+ brutolast -+ brutoloonkosten -+ brutorendement -+ brutowinstmarge -+ brûlée -+ btw-constructie -+ btw-inkomsten -+ buckskin -+ budgetbeheer -+ budgetdiscipline -+ budgetneutraal -+ budgetoverschrijding -+ budgetoverschrijdingen -+ budgetproblemen -+ budgetsubsidie -+ budgetverhoging -+ bufferfunctie -+ buffermacht -+ buidelwolf -+ buikgevoel -+ buikligging -+ buikspierblessure -+ buikstreek -+ buitenaardsen -+ buitencategorie -+ buitendienststelling -+ buitendorpen -+ buitengegooid -+ buitengewerkt -+ buitenijs -+ buitenkraan -+ buitenlandbeleid -+ buitenlandcommissie -+ buitenlandministers -+ buitenlandpagina -+ buitenlandredacteur -+ buitenlandrubriek -+ buitenlands-politieke -+ buitenlandspolitiek -+ buitenlandspolitieke -+ buitenlocaties -+ buitenspeelplaats -+ buitenstond -+ buitenzwembad -+ buizenframe -+ buizensysteem -+ bulkproductie -+ bulkvervoer -+ bullet -+ bullets -+ bumperkleven -+ bunkerboot -+ bunkerolie -+ bunkerschip -+ bupropion -+ bureauhoofd -+ bureautafel -+ burenlawaai -+ burenrecht -+ burenrelatie -+ burenrelaties -+ burgemeesterscommissie -+ burgemeestersfunctie -+ burgemeesterskandidaat -+ burgemeesterskandidaten -+ burgemeesterspost -+ burgemeestersposten -+ burgemeestersreferendum -+ burgemeestersverkiezing -+ burgemeestersvrouw -+ burgemeesterszetel -+ burgerbestuur -+ burgerbeweging -+ burgerdemocratie -+ burgerdoden -+ burgerdoelen -+ burgergroepen -+ burgerinfiltrant -+ burgerinfiltranten -+ burgerinitiatief -+ burgerinitiatieven -+ burgerkampen -+ burgerluchthaven -+ burgermilities -+ burgermoed -+ burgerorganisatie -+ burgerorganisaties -+ burgerparticipatie -+ burgerpolitici -+ burgerpresident -+ burgerrechtenactivist -+ burgerrechtenorganisatie -+ burgerrechter -+ burgerservicenummer -+ burgerservicenummers -+ burgervliegtuig -+ burgervliegtuigen -+ burgervliegveld -+ burgervluchten -+ burgerwoning -+ burgerwoningen -+ burgerzaken -+ burn -+ busabonnement -+ busbedrijf -+ busbedrijven -+ busbouwer -+ busdag -+ business-to-business -+ businessboeken -+ businessclub -+ businessmodel -+ businessmodellen -+ buskaping -+ busmaatschappij -+ busmaatschappijen -+ busnet -+ busongeluk -+ busongeval -+ buspakjes -+ busramp -+ busroute -+ bussluis -+ busstroken -+ busstrook -+ bussysteem -+ busverkeer -+ busvervoerders -+ buurdorp -+ buurprovincie -+ buurrepublieken -+ buurstad -+ buurtbeheer -+ buurtbemiddeling -+ buurtclub -+ buurtconciërge -+ buurtgenoot -+ buurtgenoten -+ buurtinformatienetwerken -+ buurtkrant -+ buurtmoeders -+ buurtniveau -+ buurtoverlast -+ buurtpark -+ buurtpreventieproject -+ buurtpreventieprojecten -+ buurtproblemen -+ buurtregisseur -+ buurtregisseurs -+ buurtvader -+ buurtvaders -+ buurvolkeren -+ buxushaagjes -+ buy -+ buzzers -+ bv'tjes -+ bw. -+ by -+ bètastudenten -+ bètastudies -+ bètaversie -+ béide -+ béste -+ béter -+ bóven -+ búiten -+ c'tjes -+ c-pion -+ c.s. -+ cabaretfestival -+ cabaretshow -+ cabrio -+ cadeaupapier -+ cafetariaplan -+ café chantant -+ café chantants -+ cafébaas -+ cafébazen -+ cafébazin -+ cafébedrijf -+ cafébrand -+ cafégangers -+ cafégedeelte -+ caféleven -+ caféstoelen -+ cafétafels -+ cafétafeltje -+ caipirinha -+ cakejes -+ calamiteitenfonds -+ calamiteitenplan -+ calamiteitenpolder -+ calamiteitenpolders -+ calamiteitenteam -+ calamiteitenzender -+ calendula -+ call -+ callcentra -+ calorierijk -+ calvarie -+ cameo -+ camera obscura -+ cameraatjes -+ camerabeelden -+ cameralens -+ camerariem -+ camerasysteem -+ camerawerk -+ campagnebudget -+ campagnebureau -+ campagnebus -+ campagnedag -+ campagnefinanciering -+ campagnegelden -+ campagnekas -+ campagnekosten -+ campagneleider -+ campagnemateriaal -+ campagnemedewerker -+ campagnemedewerkers -+ campagneteam -+ campagneteams -+ campagnethema -+ campagnetijd -+ campagnevoeren -+ campagnevoering -+ campagneweek -+ campingbaas -+ campuscontract -+ campy -+ campylobacter -+ can -+ cannabis sativa -+ canyon -+ canyons -+ cao-afspraak -+ cao-afspraken -+ cao-beleid -+ cao-bod -+ cao-conflict -+ cao-lonen -+ cao-loon -+ cao-onderhandelaars -+ cao-overleg -+ cao-partijen -+ cao-schalen -+ capaciteitsbeleid -+ capaciteitsbenutting -+ capaciteitsbezetting -+ capaciteitsgebrek -+ capaciteitsgroei -+ capaciteitsreductie -+ capellakoor -+ capoeira -+ capsaïcine -+ caravanbrand -+ card -+ cardigan -+ cardigans -+ cardiologe -+ carjackers -+ carkit -+ carkits -+ carnavalist -+ carnavalsactiviteiten -+ carnavalsavond -+ carnavalsdinsdag -+ carnavalsgroep -+ carnavalsmaandag -+ carnavalsmuziek -+ carnavalsprins -+ carnavalsseizoen -+ carnavalsstichting -+ carnavalstijd -+ carnavalsviering -+ carnavalswagen -+ carnavalswagens -+ carnavalvierders -+ carne -+ carpoolplaats -+ carpoolplaatsen -+ carrièrekansen -+ carrièreladder -+ carrièreperspectief -+ carrièreperspectieven -+ carrièresite -+ carrièrestap -+ carrièreverloop -+ carrosseriekleur -+ carrosserievorm -+ carry -+ cartoonfiguur -+ cartridge -+ cartridges -+ carve -+ carven -+ carveski's -+ cashen -+ cashpositie -+ casht -+ casino-eigenaar -+ casinospelen -+ cassatieverzoek -+ castraatzanger -+ catalografie -+ catalogusnummer -+ catalogusnummers -+ cataloguswoningen -+ catch -+ catchy -+ categorisering -+ cathedra -+ cathedraonderwijs -+ cauda -+ caudillo -+ cayenne -+ cc -+ cd-boekje -+ cd-bon -+ cd-handel -+ cd-i -+ cd-markt -+ cd-piraterij -+ cd-presentatie -+ cd-prijs -+ cd-prijzen -+ cd-reeks -+ cd-uitgave -+ cd-verkoop -+ cd-verkopen -+ cd-winkel -+ cd-winkels -+ celbeveiliging -+ celcapaciteit -+ celebrity -+ celinhoud -+ celinhouden -+ celkweken -+ cellenbroer -+ cellenbroers -+ cellenoverschot -+ celliste -+ celreferenties -+ celruimte -+ celtype -+ celtypes -+ cementgroep -+ cementovens -+ cementproducent -+ centrale-bankpresidenten -+ centrumgebied -+ centrummanagement -+ centrummanager -+ centrumontwikkeling -+ centrumplan -+ centrumplannen -+ centrumpositie -+ centrumstad -+ centrumverdediger -+ centrumvoorzieningen -+ certificatie-instellingen -+ certificatiesysteem -+ ceteris -+ ceylon -+ cg -+ chaise -+ challengers -+ champagnehuis -+ champagnehuizen -+ champagnemerk -+ champignonbedrijf -+ champignonkwekerij -+ champignonkwekers -+ chant -+ chartaal -+ chartale -+ charteractiviteiten -+ charterdochter -+ chartermarkt -+ charterverkeer -+ chateau migraine -+ chatsessie -+ chatsessies -+ chauffeurspas -+ chaussee -+ check-up -+ cheek -+ chef de cuisine -+ chef-defensiestaf -+ chef-econoom -+ chef-onderhandelaar -+ chefschap -+ chemieactiviteiten -+ chemiebedrijf -+ chemiecomplex -+ chemieconcern -+ chemiedivisie -+ chemiegigant -+ chemiegroep -+ chemiepoot -+ chemietak -+ chemo -+ chemokuren -+ chemokuur -+ chevaux -+ chi -+ chiefs -+ chili con carne -+ chillen -+ chipfabriek -+ chipgigant -+ chipmachinefabrikant -+ chipmachinemaker -+ chipmachines -+ chipper -+ chipproductie -+ chipsector -+ chipset -+ chipverpakker -+ chiquere -+ chiropraxie -+ chiën -+ chloorbleekloog -+ chloorfabriek -+ chloortransport -+ chloortransporten -+ chloraat -+ chloroquine -+ chocoladecake -+ chocoladefabriek -+ chocoladefabrikant -+ chocoladekoekjes -+ chocolademarkt -+ chocolademousse -+ chocoladepasta -+ chocoladeproducten -+ chocoladesigaretten -+ chocoladewinkel -+ chocomelk -+ choice -+ christelijken -+ chronischevermoeidheidssyndroom -+ cijferbrij -+ cijfercombinaties -+ cijfergegevens -+ cijfertabel -+ cijfervoorbeeld -+ cilinderkoppen -+ cinemacomplex -+ cinemazalen -+ circusact -+ circusacts -+ circusartieste -+ circusdieren -+ circusleven -+ circusmensen -+ circusprogramma -+ circusterrein -+ circuswereld -+ cire -+ cire perdue -+ cirkelspeelster -+ citaatrecht -+ citroenijs -+ citroenrasp -+ citroentaart -+ citrus -+ citrusbomen -+ citruspulp -+ citytrip -+ citytrips -+ civiel ingenieur -+ civiel ingenieurs -+ cl -+ claimanten -+ claimbeoordeling -+ claimcultuur -+ claiming -+ claimkorting -+ clair -+ class -+ claude -+ claudes -+ clausus -+ clenbuterol -+ clevere -+ cliniclowns -+ cliëntelisme -+ cliëntenorganisaties -+ cliëntenraad -+ cliëntenraden -+ cliëntenstop -+ cliëntvolgsysteem -+ clubbelang -+ clubcircuit -+ clubcompetities -+ clubcultuur -+ clubdag -+ clubgebonden -+ clubgenote -+ clubgeschiedenis -+ clubgevoel -+ clubhistorie -+ clubhit -+ clubkampioen -+ clubliefde -+ clublokaal -+ clubnaam -+ clubniveau -+ clubrecord -+ clubsandwich -+ clubscene -+ clubspeler -+ clubteam -+ clubteams -+ clubtenue -+ clubtopscorer -+ clubtrainer -+ clubtrainers -+ clubvoetbal -+ clubvoorzitter -+ clubvoorzitters -+ clusterbeleid -+ clusterbom -+ clustergemeenten -+ clusterwapens -+ co -+ co-commentator -+ co-existent -+ co-existente -+ co-presentator -+ co-president -+ coalitiebelang -+ coalitiebelangen -+ coalitieberaad -+ coalitiefractie -+ coalitiegesprekken -+ coalitiemogelijkheden -+ coalitieonderhandelingen -+ coalitiepolitiek -+ coalitieverband -+ coalitieverhoudingen -+ coalitievorming -+ coalitiewissel -+ cocaplanten -+ cocavelden -+ cocaïnebende -+ cocaïnegebruikers -+ cocaïnekartel -+ cocaïnetransporten -+ cocaïneverslaafden -+ cockpitdeuren -+ cocktailsaus -+ codebericht -+ codeberichten -+ codec -+ coderekening -+ coderekeningen -+ coelacanthen -+ coeliakie -+ coffee -+ coffeeshopbeleid -+ coffeeshophouder -+ coffeeshophouders -+ cohesiefondsen -+ cokegebruik -+ cokesmokkel -+ colamarkt -+ colchicine -+ cold -+ coli -+ collect -+ collectiebeleid -+ collectiecentrum -+ collectivisering -+ collega-acteur -+ collega-artsen -+ collega-bedrijven -+ collega-bestuurders -+ collega-bewindslieden -+ collega-dichter -+ collega-dichters -+ collega-directeur -+ collega-directeuren -+ collega-fractievoorzitters -+ collega-huisartsen -+ collega-instellingen -+ collega-international -+ collega-internationals -+ collega-minister -+ collega-muzikanten -+ collega-officieren -+ collega-ondernemers -+ collega-organisaties -+ collega-parlementariërs -+ collega-politici -+ collega-raadsleden -+ collega-raadslid -+ collega-schrijver -+ collegebeleid -+ collegebesluit -+ collegebesluiten -+ collegegelddifferentiatie -+ collegegeldverhoging -+ collegeleden -+ collegelid -+ collegeonderhandelingen -+ collegepartij -+ collegepartijen -+ collegepartners -+ collegeperiode -+ collegeprogramma -+ collegevergadering -+ collegevergaderingen -+ collegevoorstel -+ collegevoorzitter -+ collegevorming -+ colour -+ coltan -+ combinatiekorting -+ combinatieticket -+ combinatievoetbal -+ combiregeling -+ combobox -+ coming -+ commandocentrale -+ commandovoering -+ comme -+ commedia -+ commercebedrijf -+ commercebedrijven -+ commercialisatie -+ commerciëlen -+ commis -+ commissie-inkomsten -+ commissiekamer -+ commissieverband -+ commissievoorstel -+ commissievoorstellen -+ commissievoorzitters -+ common -+ common rail -+ communicatie-infrastructuur -+ communicatieadviseur -+ communicatiebeheersing -+ communicatiebureau -+ communicatiecampagne -+ communicatiecultuur -+ communicatiediensten -+ communicatiegroep -+ communicatiekosten -+ communicatiemanagers -+ communicatiemarkt -+ communicatienet -+ communicatieplan -+ communicatieplatform -+ communicatiepolitiek -+ communicatiesector -+ communicatiespecialisten -+ communicatiestrategie -+ communicatietechnologieën -+ communicatieverantwoordelijke -+ communicatieverkeer -+ communicatievermogen -+ communicatievorm -+ communicatievormen -+ communicatiewetenschapper -+ communicator -+ communiefeest -+ communistenvreter -+ communitaristische -+ compact camera -+ compact cassette -+ comparatieve -+ compensatiebedrag -+ compensatiebetalingen -+ compensatiedagen -+ compensatiefonds -+ compensatiegelden -+ compensatiemaatregel -+ competentiebeloning -+ competentiecentrum -+ competitie-indeling -+ competitiedebuut -+ competitiedoelpunt -+ competitiedoelpunten -+ competitiefilm -+ competitiefilms -+ competitiehelft -+ competitienederlaag -+ competitieronde -+ competitieschema -+ competitieslot -+ competitiesport -+ competitiestrijd -+ competitietreffen -+ competitietreffer -+ competitietreffers -+ competitieverloop -+ competitievoetbal -+ competitiezege -+ compilatie-cd -+ complexloos -+ complotdenken -+ compositiewedstrijd -+ composteerbare -+ composteerbedrijf -+ compressietechniek -+ compromiskandidaat -+ compromistekst -+ computeraars -+ computeralgebra -+ computeraritmetiek -+ computerbeurs -+ computerbezit -+ computerbezitters -+ computerclub -+ computercluster -+ computerclusters -+ computercodes -+ computerconcern -+ computercursussen -+ computerfout -+ computergame -+ computergerelateerde -+ computergigant -+ computerhardware -+ computerintensief -+ computerintensieve -+ computerkeyboard -+ computerkunstenaars -+ computerland -+ computerles -+ computerlessen -+ computerlokaal -+ computerlokalen -+ computermaker -+ computerman -+ computermarkt -+ computermateriaal -+ computermuis -+ computermuizen -+ computernerds -+ computerpark -+ computerplatform -+ computerprobleem -+ computerproducent -+ computerprogrammatuur -+ computerreus -+ computerrevolutie -+ computersector -+ computerspecialist -+ computerspelletjes -+ computerstem -+ computerstoring -+ computerstoringen -+ computertekening -+ computertermen -+ computertijdschrift -+ computeruitval -+ computervaardigheden -+ computerverbinding -+ computerverbindingen -+ computerverkeer -+ computervertaling -+ computervertalingen -+ concateneren -+ concentratiebeweging -+ concentratiegolf -+ concentratieproces -+ concentratiepunt -+ concentratietendens -+ conceptadvies -+ conceptalbum -+ conceptlijst -+ conceptplan -+ conceptrapport -+ concepttekst -+ conceptual -+ conceptverkiezingsprogramma -+ conceptvoorstel -+ concerndirectie -+ concernleiding -+ concernomzet -+ concerntop -+ concertagenda -+ concertbeelden -+ concertenreeks -+ concertkaartjes -+ concertorganisator -+ concertpianiste -+ concertpromotor -+ concertreeks -+ concertregistratie -+ concertreis -+ concertseries -+ concerttournee -+ concertvorm -+ concessieperiode -+ concessiestelsel -+ concessiewet -+ concordantiebestand -+ concurrentieautoriteiten -+ concurrentiebeleid -+ concurrentiebeperkende -+ concurrentiehandicap -+ concurrentiemiddel -+ concurrentiemogelijkheden -+ concurrentienadeel -+ concurrentieoverwegingen -+ concurrentieregels -+ concurrentievervalsend -+ concurrentievervalsende -+ concurrentiewaakhond -+ concurrentiezaken -+ conditio sine qua non -+ condition -+ condition humaine -+ condoomfabrikant -+ confectiesector -+ conferentiebezoek -+ conferentiecentrum -+ conferentiedeelnemers -+ conferentieruimte -+ configuratiebestand -+ configuratiebestanden -+ configuratiegegevens -+ conflictbeheersing -+ conflictbemiddelaar -+ conflictbemiddeling -+ conflictdiamanten -+ conflicteert -+ conflictpartijen -+ conflictpreventie -+ conflictpunt -+ confrontatiekoers -+ confronterende -+ congresbesluit -+ congrescommissie -+ congresdag -+ congreshal -+ congresruimte -+ congresstad -+ congresvoorzitter -+ conjunctuurbarometer -+ conjunctuurgevoeligheid -+ conjunctuurgolven -+ conjunctuurherstel -+ conjunctuurindicator -+ conjunctuurindicatoren -+ conjunctuuromslag -+ connectiviteit -+ consanguiniteit -+ consensuscultuur -+ consensusmodel -+ consensuspolitiek -+ consensusverwachting -+ consensusvorming -+ conservatief-katholieke -+ conservenfabriek -+ consilium -+ consolidatiebeweging -+ consolidatiefase -+ consolidatiegolf -+ consolidatieslag -+ constrictor -+ constructiemateriaal -+ consultancybedrijf -+ consultancybedrijven -+ consultantbureau -+ consultatiedocument -+ consultatieronde -+ consultatieteams -+ consultingbedrijf -+ consultingbureau -+ consumentenbelang -+ consumentenbelangen -+ consumentenbestedingen -+ consumentendivisie -+ consumentenelektronica -+ consumentengroepen -+ consumenteninformatie -+ consumentenpakketten -+ consumentenpanel -+ consumentenpanels -+ consumentenprijsindex -+ consumentenproduct -+ consumentenprogramma -+ consumentenrecht -+ consumentenuitgaven -+ consumentenvereniging -+ consumentenverpakkingen -+ consumentenvoorlichting -+ consumentenvraag -+ consumentenvuurwerk -+ consumentenzaken -+ consuminderen -+ consumptiebonnen -+ consumptiecultuur -+ consumptiedrift -+ consumptiegedrag -+ consumptiegoed -+ consumptiegroei -+ consumptieniveau -+ consumptieprijsindex -+ consumptievis -+ contactambtenaar -+ contactambtenaren -+ contactbedrijven -+ contactdag -+ contactdagen -+ contactloze -+ contactonderzoek -+ contactslot -+ contacttijd -+ containerbedrijf -+ containerbedrijven -+ containerbegrip -+ containerkranen -+ containeroverslag -+ containerrederijen -+ containerscan -+ containersector -+ containertransport -+ containervaart -+ contextmenu -+ continumarkt -+ continuïteitsoverweging -+ continuïteitsoverwegingen -+ contractactiviteiten -+ contractduur -+ contractmanagement -+ contractonderhandelingen -+ contractpartij -+ contractperiode -+ contractsduur -+ contractsvoorwaarde -+ contractsvoorwaarden -+ contractwaarde -+ contradictio in terminis -+ contradictorisch -+ contrastmiddel -+ contrastmiddelen -+ contrecoeur -+ controle-instanties -+ controle-instituut -+ controleactie -+ controleapparatuur -+ controlebeleid -+ controlebevoegdheden -+ controlebevoegdheid -+ controlecentra -+ controlecomité -+ controledienst -+ controlediensten -+ controlefunctie -+ controlefuncties -+ controlemethoden -+ controlemogelijkheden -+ controleorganen -+ controlepersonen -+ controleploegen -+ controleprocedures -+ controleprogramma -+ controlepunt -+ controlepunten -+ controleronde -+ controletaken -+ controleteam -+ controleteams -+ controleverlies -+ controlewerk -+ conversatieanalyse -+ conversiefactor -+ conversiekosten -+ conversieprijs -+ convolueren -+ coproducenten -+ cordon bleu -+ cordon sanitaire -+ corporatiewoningen -+ corps diplomatique -+ correctiemechanisme -+ correctiemechanismen -+ correspondentennet -+ corruptiebestrijder -+ corruptiebestrijding -+ corruptiegevallen -+ corruptieproces -+ corruptiezaak -+ corruptiezaken -+ corticoïde -+ corticoïden -+ cortisone -+ cosmeticaconcern -+ cosmeticamerk -+ cosmeticasector -+ cost -+ costa's -+ coulantie -+ couleur -+ counterploeg -+ countryster -+ countryzangeres -+ county -+ coupondatum -+ courantkrediet -+ court -+ coöperatiever -+ coördinatensysteem -+ coördinatensystemen -+ coördinatiepunt -+ coûte -+ crackkelders -+ cranberrysap -+ crapaudjes -+ crashtest -+ crashtests -+ creatieveling -+ creatieven -+ creatine -+ creationistische -+ creditcardbetaling -+ creditcardbetalingen -+ creditcardfraude -+ creditcardgegevens -+ creditcardmaatschappij -+ creditcardmaatschappijen -+ crewleden -+ crimefighter -+ crisisbedden -+ crisisbeheer -+ crisisbeheersing -+ crisisbelasting -+ crisisbestendig -+ crisisbestrijding -+ crisisbijdrage -+ crisiscommunicatie -+ crisisdienst -+ crisisdiensten -+ crisisdreiging -+ crisisgebied -+ crisisgevallen -+ crisisgevoel -+ crisishaarden -+ crisislanden -+ crisisoperaties -+ crisisopvang -+ crisisvergadering -+ croque -+ crosscircuit -+ crossmotor -+ cruiseboot -+ cruiser -+ cruiseterminal -+ cryptografische -+ crècheplaatsen -+ crème de la crème -+ culpa -+ cultband -+ cultgroep -+ cultheld -+ cultklassieker -+ cultschrijver -+ cultserie -+ cultusplaats -+ cultuurambtenaar -+ cultuurambtenaren -+ cultuurbegrip -+ cultuurbegroting -+ cultuurbeleid -+ cultuurbeleidsplan -+ cultuurbeleving -+ cultuurbezoek -+ cultuurbreuk -+ cultuurbudget -+ cultuurclash -+ cultuurcommissie -+ cultuurcomplex -+ cultuurdebat -+ cultuureducatie -+ cultuurfestival -+ cultuurfonds -+ cultuurfondsen -+ cultuurgebied -+ cultuurhuis -+ cultuurhuizen -+ cultuurjaar -+ cultuurkanaal -+ cultuurkring -+ cultuurland -+ cultuurleven -+ cultuurliefhebber -+ cultuurmanagement -+ cultuurminnend -+ cultuurnatie -+ cultuurnota -+ cultuurpaleis -+ cultuurparticipatie -+ cultuurpatrimonium -+ cultuurpessimisme -+ cultuurpessimistisch -+ cultuurpessimistische -+ cultuurprijs -+ cultuurprijzen -+ cultuurprogramma -+ cultuurprogramma's -+ cultuurrelativisme -+ cultuurschat -+ cultuurschatten -+ cultuursector -+ cultuursponsoring -+ cultuurstad -+ cultuursteden -+ cultuurstelsel -+ cultuurstrijd -+ cultuursubsidies -+ cultuurtempel -+ cultuurtheater -+ cultuurtoerisme -+ cultuurtypes -+ cultuurverandering -+ cultuurveranderingen -+ cultuurverschil -+ cultuurvormen -+ cultuurwaarden -+ cultuurwereld -+ cultuurwetenschapper -+ cultuurwethouder -+ cultuurzender -+ cum laude -+ cum suis -+ cupmaat -+ curiekardinaal -+ curriculum vitae -+ currysaus -+ cursusgelden -+ cv-installatie -+ cyberbabe -+ cybercafé -+ cybercafés -+ cybercriminaliteit -+ cybercultuur -+ cyberterrorisme -+ cyberwereld -+ cyborg -+ cyborgs -+ cyclisme -+ cycloopoog -+ cyclosporine -+ cymbalen -+ cystische -+ cytosine -+ d'Arc -+ d'oeuvre -+ d'tjes -+ d-pion -+ d.i. -+ d.w.z. -+ dB -+ da -+ daarbij behorend -+ daarnaartoe -+ daarná -+ daarrond -+ daarvóór -+ dadeloosheid -+ daderprofiel -+ dagactiviteiten -+ dagactiviteitencentrum -+ dagarrangement -+ dagarrangementen -+ dagattracties -+ dagbesteding -+ dagbladjournalist -+ dagbladjournalisten -+ dagbladsector -+ dagbladtitels -+ dagbladuitgever -+ dagbladuitgevers -+ dagbladwereld -+ dagboekbladen -+ dagboekvorm -+ daghandelaar -+ dagjesmens -+ dagomzet -+ dagrecord -+ dagritme -+ dagsucces -+ dagtelevisie -+ dagtemperatuur -+ dagverzorging -+ dagvoorzitter -+ dagwandeling -+ dagwandelingen -+ dagwinkels -+ dagwinst -+ dagzege -+ dagzeges -+ dakdekkersbedrijf -+ dakfonds -+ dakfondsen -+ daklozenopvang -+ daklozenprobleem -+ dakplaten -+ dakrails -+ dakvorm -+ dalai -+ dambreuk -+ damcombinatie -+ damcompetitie -+ dameruil -+ damescollectie -+ damescoupé -+ damesgroep -+ dameskleren -+ dameskoor -+ damesondergoed -+ damesslipjes -+ damesstem -+ damestrio -+ damevleugel -+ damtoernooi -+ damvereniging -+ dance -+ dance-evenement -+ dance-evenementen -+ danceacts -+ dancebeats -+ dancefeest -+ dancefestival -+ dancemuziek -+ dancescene -+ dankbrief -+ dansbaar -+ dansbaarheid -+ dansbeweging -+ dansbewegingen -+ danscafé -+ danscentrum -+ danscultuur -+ danse -+ dansfilm -+ dansgezelschap -+ dansje -+ danslustige -+ dansmarathon -+ dansmarietjes -+ dansopleiding -+ dansorgel -+ danspaleis -+ dansplaat -+ dansproductie -+ dansprogramma -+ dansscènes -+ danssector -+ dansshow -+ danssport -+ dansstijl -+ dansstijlen -+ danstaal -+ danstalent -+ danstechnieken -+ danstechnische -+ danstempel -+ dansvoorstelling -+ dansvoorstellingen -+ dansvorm -+ dansvormen -+ danswereld -+ danswerk -+ darter -+ darters -+ dartstoernooi -+ dasje -+ databasegegevens -+ databasesoftware -+ databasetabel -+ databasetabellen -+ databaseveld -+ databasevelden -+ databeheer -+ datadiensten -+ datahandel -+ datalogger -+ dataopslag -+ dataverbindingen -+ dataverkeer -+ datumnotatie -+ day -+ de Caraïben -+ de Falklandeilanden -+ de Gaulle -+ de Here -+ de Kaap -+ de Kaukasus -+ de dato -+ de facto -+ de hele bubs -+ de hemel in prijzen -+ death -+ deathmetal -+ debatcultuur -+ debatprogramma -+ debetkaart -+ debiteurenbeheer -+ debiteurenrisico -+ debriefingsrapport -+ debuut-cd -+ debuutjaar -+ debuutseizoen -+ debuutsingle -+ decemberavond -+ decembermoorden -+ decenniaoude -+ declaratieregels -+ declassering -+ deco -+ decompilatie -+ decompilaties -+ decostijl -+ decriminaliseren -+ decubitus -+ deelauto -+ deelbewijs -+ deelcollectie -+ deelcollecties -+ deelgroepen -+ deelnemersaantal -+ deelnemersraad -+ deelnemersraden -+ deelonderzoek -+ deelorganisaties -+ deelperiode -+ deelredacties -+ deelregio -+ deelscore -+ deelsector -+ deelsectoren -+ deelsegmenten -+ deelstaatminister -+ deelstaatministers -+ deelstaatsverkiezingen -+ deeltaxi -+ deeltijdbehandeling -+ deeltijdontslag -+ deeltijdpensioen -+ deeltijdwet -+ deen -+ defederalisering -+ defensie-inspanning -+ defensie-inspanningen -+ defensiebedrijf -+ defensiebedrijven -+ defensiecapaciteit -+ defensiegebied -+ defensiegeheimen -+ defensiekringen -+ defensiemarkt -+ defensienota -+ defensieorganisatie -+ defensiepersoneel -+ defensieprojecten -+ defensiesamenwerking -+ defensiestrategie -+ defensiesystemen -+ defensietaken -+ defensieterrein -+ defensietop -+ defensieverdrag -+ deficitair -+ degradatieduel -+ degradatiegevaar -+ degradatieplaats -+ degradatiespook -+ degradatiestrijd -+ degradatievoetbal -+ degradatiezorgen -+ degustatiemenu -+ dejeunertjes -+ dekkingsgraad -+ dekolonisatiegeschiedenis -+ dektijd -+ delicious -+ delicti -+ delisting -+ dell'arte -+ delokalisatie -+ delokaliseren -+ deltametropool -+ demand -+ dementen -+ dementerend -+ dementerende -+ dementia -+ dementia praecox -+ democrate -+ demonstratiebord -+ demonstratievrijheid -+ demontagebedrijven -+ denarius -+ denkgroep -+ denkmodel -+ denkniveau -+ denkoefening -+ denkoefeningen -+ denkspoor -+ denksporen -+ denktijd -+ dennengroen -+ dente -+ deponie -+ depositofaciliteit -+ depotjes -+ depressieven -+ der keerlen god -+ derdegeneratiepil -+ derdeklassenreizigers -+ derdekwartaalresultaten -+ derdenbeslag -+ dergelijken -+ derivatenhandel -+ derivatenmarkt -+ dertienvoudig -+ des onheils -+ descript -+ desgevallende -+ designafdeling -+ designcentrum -+ designerkleding -+ designhotel -+ designhotels -+ designklassiekers -+ designmeubilair -+ designobjecten -+ designproducten -+ designwereld -+ designwinkel -+ designwinkels -+ desinfectiemiddel -+ desktop-pc -+ desktoppublishingprogramma -+ deskundigenrapport -+ destructiecapaciteit -+ deszelfs -+ detachementscommandant -+ detacheringsbedrijf -+ detacheringsbureau -+ detailhandelconcern -+ detailhandelsbedrijf -+ detailhandelsbedrijven -+ detailhandelsketen -+ detailhandelsonderneming -+ detailkaarten -+ detailkennis -+ detailvragen -+ detectieapparatuur -+ detectiemethode -+ detectiepoort -+ detectiepoorten -+ detectiesystemen -+ detectiveserie -+ detectivespel -+ detergent -+ determinator -+ deugdelijkheidseisen -+ deurenfabriek -+ deurgrepen -+ deurvergrendeling -+ deus -+ deux -+ deuxtje -+ deviezentekort -+ deviezenvoorraad -+ dhr. -+ diabeet -+ diabetes mellitus -+ diabetespatiënt -+ diabetespatiënten -+ diabolisering -+ diagnostica -+ diagnosticeer -+ diagnosticeerden -+ diagnosticeert -+ dialogeren -+ dialysecentrum -+ dialysepatiënten -+ diamantbedrijf -+ diamantgebieden -+ diamantrijke -+ diamantroof -+ diamantsector -+ diamantsmokkel -+ diamantwereld -+ diamantwijk -+ diashow -+ diazepam -+ dichtbeboste -+ dichtersfestival -+ dichtgemetselde -+ dichtgesnoerd -+ dichtklikken -+ dichtschroeien -+ dichtstbevolkt -+ dichtstbevolkte -+ dichtstbij -+ dichtstbijgelegen -+ dicteewoord -+ dicteewoorden -+ die en die -+ dieetkosten -+ dieetpillen -+ diefstalbeveiliging -+ diene -+ dienstenaanbieder -+ dienstenaanbieders -+ dienstenaanbod -+ dienstenbedrijf -+ dienstenbedrijven -+ dienstencheque -+ dienstencheques -+ dienstengamma -+ dienstengroep -+ dienstenleverancier -+ dienstenstructuur -+ dienstkleding -+ dienstopdracht -+ dienstperiode -+ diepdonkere -+ diepergaande -+ dieperliggende -+ diepgevoelde -+ diepmenselijke -+ diepterecord -+ dieptreurig -+ diepvriesbedrijf -+ diepvriespizza -+ diepzeeduiken -+ diepzeevis -+ diepzeevissen -+ dierenactivisten -+ dierenartsenpraktijk -+ dierenbeschermingsorganisaties -+ dierenlijken -+ dierenmeel -+ dierenopvang -+ dierenrechtenactivisten -+ dierenrechtenorganisatie -+ dierenschilder -+ dierensoorten -+ dierentuindieren -+ dierenverblijf -+ dierenverblijven -+ dierenverzorger -+ dierenverzorgers -+ dierenvoer -+ dierenwelzijn -+ diergeneesmiddelen -+ diergezondheid -+ diergroep -+ dierhouderij -+ diermeel -+ dieronderzoek -+ diertransporten -+ dierverzorging -+ diervoeder -+ diervoeders -+ diervoeding -+ diervoer -+ dierwelzijn -+ dierziekte -+ dies natalis -+ dieselaccijns -+ dieselbrandstof -+ dieselgemalen -+ diesellucht -+ dieselprijs -+ dieselrijder -+ dieselrijders -+ dieseltank -+ dieseltechniek -+ dieselversie -+ dieselversies -+ dieselwagens -+ diftar -+ dijklichamen -+ dijktalud -+ dijkverbetering -+ dijkverbeteringen -+ dijkverbeteringsplan -+ dijkverhoging -+ dijkverhogingen -+ dijkverzwaring -+ dijkverzwaringen -+ dijkweg -+ dijkwoning -+ dikbetaalde -+ dikkedarmkanker -+ dikmakend -+ dikste -+ dikverdiende -+ dinertjes -+ dinsdagnamiddag -+ dioxineaffaire -+ dioxinebesmetting -+ dioxinecommissie -+ dioxinecrisis -+ dioxinekip -+ dioxinekippen -+ dioxinenorm -+ dioxineramp -+ dioxineschandaal -+ dioxinevervuiling -+ dioxinezaak -+ diplomatique -+ direct mail -+ direct marketing -+ directeur-eigenaar -+ directeur-hoofdredacteur -+ directeursfunctie -+ directeursfuncties -+ directiefunctie -+ directieraad -+ directiesalarissen -+ directiestructuur -+ directietafel -+ directievoorzitter -+ directievoorzitters -+ directiewisselingen -+ directiezetel -+ directoiretjes -+ director -+ dirigente -+ disc -+ disco-eigenaar -+ discobal -+ discobezoekers -+ discotheekeigenaren -+ discounter -+ discounters -+ discountketen -+ discretieplicht -+ discretionair -+ discretionaire -+ discs -+ discussiedag -+ discussielijst -+ discussielijsten -+ discussiemiddag -+ discussiemogelijkheden -+ discussiemogelijkheid -+ discussiepartner -+ discussiepartners -+ discussieronde -+ discussiesite -+ discussiestof -+ discussiethema -+ disfuncties -+ dispensatieregeling -+ dist -+ distributieactiviteiten -+ distributiecontract -+ distributiefunctie -+ distributiegroep -+ distributiegroepen -+ distributieketen -+ distributieketens -+ distributieland -+ distributiemarkt -+ distributiemogelijkheden -+ distributienetwerken -+ distributieovereenkomst -+ distributieproblemen -+ distributierechten -+ distributiesystemen -+ distributietak -+ districtsbeker -+ districtsbestuur -+ districtsdirecteur -+ districtsrechtbank -+ ditje? -+ ditjes en datjes -+ div. -+ diversificeren -+ diversifiëring -+ diversiteitsbeleid -+ dividendbeleid -+ dividendinkomsten -+ dividendpolitiek -+ dividendrendement -+ dividendverhoging -+ divisieclub -+ divisiedirecteur -+ divisiemanager -+ dié -+ dj-duo -+ dj-sets -+ dl -+ dm -+ doble -+ docentencorps -+ docentenopleiding -+ dochterrelatie -+ docking -+ doctoraalopleiding -+ documentairefilm -+ documentaireprogramma -+ documentaliste -+ documentatiemap -+ documentbeheer -+ documentbestand -+ documentenbeheer -+ documentje -+ documentverkeer -+ doddengras -+ dodenkamp -+ doders -+ doe-het-zelfketen -+ doe-het-zelfsector -+ doedelzakmuziek -+ doelgevaar -+ doelgroepstroken -+ doeloe -+ doelpubliek -+ doelpuntmaker -+ doelpuntrijke -+ doelvrouw -+ doemberichten -+ doemdenkerij -+ doktersassistent -+ doktersattest -+ dokterskabinet -+ doktersrecept -+ dokterstas -+ dollarbananen -+ dollarcrisis -+ dollardaling -+ dollarisatie -+ dollarprijs -+ dollarrisico -+ dolmes -+ domeinkapers -+ domeinregistratie -+ domo -+ domotica -+ donatiefunctionarissen -+ donderdagnamiddag -+ donorconferentie -+ donorformulier -+ donorgeld -+ donorgelden -+ donorgemeenschap -+ donorhulp -+ donorlever -+ donorlevers -+ donororgaan -+ donororganisaties -+ donorregister -+ donorzaad -+ dood gewaand -+ dood gewaande -+ dood wanen -+ doodervaring -+ doodknuffelen -+ doodordinaire -+ doodsimpele -+ doof-blinde -+ doofblinde -+ doofblinden -+ doofpotaffaire -+ doofpotoperatie -+ dooltocht -+ door en door -+ door-de-weekse -+ doorbehandelen -+ doordenking -+ doorgangskamp -+ doorgangsland -+ doorgave -+ doorgebouwd -+ doorgeklikt -+ doorgeleid -+ doorgeleverd -+ doorgeplaatst -+ doorgevlooid -+ doorgifte -+ doorglippen -+ doorgroeimogelijkheden -+ doorgroeimogelijkheid -+ doorklikken -+ doorklikmogelijkheden -+ doorleveren -+ doorontwikkelen -+ doorontwikkeling -+ doorontwikkelingen -+ doorpakken -+ doorplaatsen -+ doorploeteren -+ doorregeren -+ doorrekening -+ doorrekeningen -+ doorrijders -+ doorschakeling -+ doorstarters -+ doorstorten -+ doorstroomroute -+ doortrekking -+ doorverkochte -+ doorverkopers -+ doorvertalen -+ doorvoerland -+ doorvoerlanden -+ doorzendservice -+ dopamine -+ dopegebruik -+ dopingbeleid -+ dopingbestrijding -+ dopingcommissie -+ dopinggebruikers -+ dopinggeduide -+ dopinggeruchten -+ dopinggeval -+ dopinghandel -+ dopingjacht -+ dopinglaboratorium -+ dopinglijst -+ dopingmiddelen -+ dopingnetwerk -+ dopingpraktijken -+ dopingprobleem -+ dopingproces -+ dopingproducten -+ dopingregels -+ dopingreglement -+ dopingreglementen -+ dopingschandaal -+ dopingschorsing -+ dopingvraagstuk -+ dopingvrij -+ dopingvrije -+ dopingwet -+ dopingzondaar -+ dorpsagent -+ dorpsarts -+ dorpsfeest -+ dorpsfeesten -+ dorpsgrenzen -+ dorpshart -+ dorpsniveau -+ dorpsomroeper -+ dorpsoverleg -+ dorpsvernieuwing -+ dossierkosten -+ dossieronderzoek -+ dossierstukken -+ dossiertje -+ dotcom -+ dotcombedrijf -+ dotcombedrijven -+ dotcoms -+ douanecontrole -+ douanecontroles -+ douanemensen -+ douanepersoneel -+ double -+ doubt -+ douchewater -+ douchten -+ dovemansgesprek -+ dovenonderwijs -+ downbenadering -+ downgrading -+ downs -+ doxycycline -+ dra. -+ draagcomfort -+ draaibeweging -+ draaibewegingen -+ draaiknop -+ draaikonterij -+ draailier -+ draaiplateau -+ dragonsaus -+ drainagebuizen -+ dramareeks -+ dramatis -+ drankblikjes -+ drankenconcern -+ drankendivisie -+ drankengigant -+ drankengroep -+ drankenhandel -+ drankenindustrie -+ drankenkaart -+ drankenmarkt -+ drankenproducent -+ drankensector -+ drankhandel -+ drankkartons -+ dranklokalen -+ drankprobleem -+ drankreclame -+ drankverkoop -+ dreamteam -+ dreigtelefoontje -+ drempelbedrag -+ drempelbedragen -+ drempelverhogend -+ dresscode -+ dresseur -+ dressuuramazone -+ drie tiende -+ drie vierde -+ drie vijfde -+ driecilinder -+ driefasesysteem -+ driefasesystemen -+ driegangendiner -+ driehoeksborden -+ driehonderdtal -+ driejarenplan -+ drieletterige -+ driemaandsperiode -+ drietraps -+ drieweekse -+ drieënhalf -+ drieënhalve -+ drieënnegentig -+ drieëntachtig -+ drieënveertig -+ drieënvijftig -+ drieënzestig -+ drilsergeant -+ drinkende -+ drinkgelegenheden -+ drinkpoel -+ drinkpoelen -+ drinkwaren -+ drinkwaterbedrijf -+ drinkwaterbedrijven -+ drinkwaternorm -+ drinkwaterwinning -+ drinkyoghurt -+ droedels -+ dronkenmansgebed -+ dronkenmansgebeden -+ dronkenmansgelal -+ droogkomisch -+ droogkomische -+ droogskiën -+ droomauto -+ droomclub -+ droomdebuut -+ droomfinale -+ droomjob -+ droomkeuken -+ droompaar -+ droompaleis -+ droomproject -+ droomscenario -+ droomstad -+ droomstart -+ droomtijd -+ dropouts -+ drughandel -+ drugnota -+ drugproblematiek -+ drugsaanpak -+ drugsactie -+ drugsactiviteiten -+ drugsbazen -+ drugsbestrijding -+ drugsbrigade -+ drugsbureau -+ drugscircuit -+ drugsconsumptie -+ drugscriminaliteit -+ drugscrimineel -+ drugscriminelen -+ drugsdeal -+ drugsdeals -+ drugsdebat -+ drugsdeskundige -+ drugsdossier -+ drugsexperts -+ drugsgeld -+ drugshandelaar -+ drugshandelaars -+ drugshulpverlening -+ drugskoerier -+ drugslaboratoria -+ drugslijn -+ drugslijnen -+ drugsmarkt -+ drugsmilieu -+ drugsmisdrijven -+ drugsnetwerk -+ drugsonderzoek -+ drugsonderzoeker -+ drugsoorlog -+ drugsopvang -+ drugsorganisaties -+ drugspand -+ drugspanden -+ drugsproblematiek -+ drugsproces -+ drugsproductie -+ drugsruzie -+ drugssmokkelaars -+ drugsstaat -+ drugssyndicaat -+ drugstest -+ drugstransactie -+ drugstransacties -+ drugstransport -+ drugsvangst -+ drugsvangsten -+ drugsverbod -+ drugsverkoop -+ drugsverleden -+ drugsverslaafd -+ drugsverstrekking -+ drugsvoorlichting -+ drugswereld -+ drugswet -+ drugswetgeving -+ drugswinsten -+ drugszaak -+ drugszaken -+ druivenras -+ druivenrassen -+ druivensoort -+ druivenstokken -+ druiventeelt -+ drukbereden -+ drukbevaren -+ drukbevolkte -+ drukgebied -+ drukjacht -+ drukkersbedrijven -+ drukorder -+ drukorders -+ drukproces -+ drukriolering -+ druksystemen -+ drukverdeling -+ drukvoorbereiding -+ drukwerkzendingen -+ drumcomputer -+ drumcomputers -+ drumpartijen -+ drumster -+ drumstokjes -+ drumstokken -+ drumwerk -+ druïdetempel -+ du -+ dualisering -+ dubbel-cd -+ dubbelbelastingverdrag -+ dubbelbelastingverdragen -+ dubbelcijferige -+ dubbeldeks -+ dubbeldeksbus -+ dubbeldekswegen -+ dubbele axel -+ dubbelfinale -+ dubbelingen -+ dubbelinterview -+ dubbelklik -+ dubbelklikken -+ dubbelklikt -+ dubbelpartner -+ dubbelprijzen -+ dubbelspecialist -+ dubbelspecialiste -+ dubbelsporige -+ dubbeltalent -+ dubbeltitel -+ dubbeltitels -+ dubbeltjeswerk -+ dubbelvier -+ duevekaterse? -+ dug -+ duikeenden -+ duikklok -+ duikpak -+ duikpakken -+ duikploeg -+ duikschool -+ duikteam -+ duinengebied -+ duiveluitdrijvers -+ duiveluitdrijving -+ duivenhouders -+ duivenliefhebber -+ duizend-en-een -+ duizendsten -+ dumpingprijzen -+ dunwandige -+ duopartner -+ duopolie -+ duopresentatie -+ durfinvesteerder -+ durfinvesteerders -+ durfkapitaalfonds -+ durfkapitaalfondsen -+ durfkapitalist -+ durfkapitalisten -+ duurtijd -+ duurvermogen -+ duwers -+ dvd-films -+ dvd-recorder -+ dvd-rom -+ dwangburchten -+ dwangmedicatie -+ dwangsombeschikking -+ dynamisering -+ dáárdoor -+ dáárover -+ dáárvoor -+ dé -+ déjà vu -+ déjà-vugevoel -+ détail -+ déze -+ díe -+ dóórgaan -+ e'tjes -+ e-banking -+ e-business -+ e-commerce -+ e-commercebedrijf -+ e-commercebedrijven -+ e-government -+ e-learning -+ e-mailbericht -+ e-mailberichten -+ e-mailbox -+ e-maildienst -+ e-maildiensten -+ e-mailkranten -+ e-mailprogramma -+ e-mailprogramma's -+ e-mailservice -+ e-mailsysteem -+ e-pion -+ e.a. -+ e.e.a. -+ e.o. -+ e.v. -+ e.v.a. -+ earl -+ earnings -+ easy -+ eau de cologne -+ ebitda -+ echtheidskenmerken -+ echtscheidingsbemiddeling -+ echtscheidingsperikelen -+ eclipsbrilletjes -+ ecodrugs -+ ecologisering -+ economieminister -+ economiepagina -+ economieprofessor -+ economisering -+ ecostroom -+ ecozone -+ ede -+ edelmannen -+ edelsmeedwerk -+ educatiecentrum -+ educatiever -+ een derde -+ een tiende -+ een vierde -+ een zesde -+ eencilinder -+ eendenlever -+ eenentachtig -+ eenenveertig -+ eenenvijftig -+ eenenzestig -+ eenenzeventig -+ eenheidsinterval -+ eenheidslijst -+ eenheidsmarkt -+ eenheidsmunt -+ eenheidsregering -+ eenheidsstatuut -+ eenhoog -+ eenieders -+ eenmansorkest -+ eenwieler -+ eerste-elftalspeler -+ eerstens -+ eersterangsrol -+ eerstewereldlanden -+ eerstgenoemden -+ eertijdse -+ eetfestijn -+ eetgedeelte -+ eetgids -+ eetmomenten -+ eetproblemen -+ eetstoornis -+ eetverslaving -+ eeuweling -+ eeuwer -+ eeuwers -+ effectenbemiddelaar -+ effectenbemiddelaars -+ effectenbemiddeling -+ effectenbranche -+ effectendepot -+ effectendiensten -+ effectenhandelaren -+ effectenhuis -+ effectenhuizen -+ effecteninstelling -+ effecteninstellingen -+ effectenorders -+ effectenrecht -+ effectenwereld -+ effectisering -+ effectrapportage -+ effendi's -+ efficiencymaatregelen -+ eiersector -+ eierstokweefsel -+ eierzoekers -+ eigenaar-verhuurder -+ eigenarenheffing -+ eigenbouw -+ eigendomsvoorbehoud -+ eigening -+ eigenstandigheid -+ eigenwoningforfait -+ eiig -+ eilaci -+ eilanddeel -+ eimengsel -+ eindbalans -+ eindbeeld -+ eindbeoordeling -+ eindberging -+ eindbod -+ eindconsument -+ eindejaarsfeesten -+ eindejaarsgeschenk -+ eindejaarsperiode -+ eindejaarsrally -+ eindevaluatie -+ eindevaluaties -+ eindexamencijfer -+ eindexamencijfers -+ eindexamenjaar -+ eindexamenleerlingen -+ eindexamenproject -+ eindexamenresultaten -+ eindkapitaal -+ eindklassering -+ eindlijn -+ eindloon -+ eindloonregeling -+ eindloonstelsel -+ eindloonsysteem -+ eindrapportage -+ eindregie -+ eindrekening -+ eindscène -+ eindselectie -+ eindtekst -+ eindtoernooi -+ eindverantwoordelijk -+ eindverbruiker -+ eindverbruikers -+ eindvervaldag -+ eindvoorraad -+ eindweegs -+ eindwinnaar -+ eiproducten -+ eiwithormoon -+ elektriciteitsbeurs -+ elektriciteitsbuis -+ elektriciteitsconcern -+ elektriciteitscrisis -+ elektriciteitsdistributeurs -+ elektriciteitsdistributie -+ elektriciteitsleidingen -+ elektriciteitsleverancier -+ elektriciteitsmarkt -+ elektriciteitsplan -+ elektriciteitsprijzen -+ elektriciteitsproducent -+ elektriciteitsproducenten -+ elektriciteitssector -+ elektriciteitswereld -+ elektriciteitswet -+ elektroakoestische -+ elektroconcern -+ elektromechanica -+ elektronicabeurs -+ elektronicaconcern -+ elektronicafabrikant -+ elektronicagigant -+ elektronicagroep -+ elektronicaketen -+ elektronicaproducent -+ elektronicaproducenten -+ elektronicareus -+ elektronicareuzen -+ elektronvolt -+ elektrozaak -+ elfdaagse -+ elfder -+ elfjarigen -+ elftalfoto -+ elitesoldaten -+ elitesport -+ elitevorming -+ emancipatieproces -+ embargo's -+ embedded -+ embryo-onderzoek -+ embryocellen -+ embryowet -+ emeritus-hoogleraar -+ emigratieland -+ emigratielanden -+ emigratieplannen -+ emigratiestroom -+ emissiehandel -+ emissienevel -+ emissiereductie -+ emissiereducties -+ emotie-tv -+ emotievolle -+ en bloc -+ en en -+ en face -+ enantiomeer -+ enantiomeren -+ encefalograaf -+ encrypteren -+ ende -+ endoscopische -+ enduro -+ energetica -+ energie-efficiëntie -+ energie-intensiteit -+ energiebeheer -+ energiebelasting -+ energiebranche -+ energieconcern -+ energieconcerns -+ energieconsumptie -+ energiecontracten -+ energiedeskundigen -+ energiedistributeur -+ energiedistributie -+ energiedistributiebedrijf -+ energiedistributiebedrijven -+ energiedrank -+ energiefactuur -+ energiefysica -+ energiegebied -+ energiegigant -+ energiegroep -+ energieheffing -+ energieheffingen -+ energiehuishouding -+ energielabel -+ energielasten -+ energieleverancier -+ energieleveranciers -+ energielevering -+ energieliberalisering -+ energiemaatschappij -+ energienet -+ energieplan -+ energiepoot -+ energiepremie -+ energieproducent -+ energieproducenten -+ energieproductie -+ energieproject -+ energieprojecten -+ energierekeningen -+ energiereus -+ energiestoot -+ energiestromen -+ energiesubsidies -+ energietaks -+ energietarieven -+ energietechnologie -+ energietoevoer -+ energieveld -+ energieverbruikers -+ energievormen -+ energievraag -+ energiewaarde -+ energiewereld -+ energiewinning -+ energiezuinigheid -+ enfant -+ enfants -+ engineeringbedrijf -+ engineeringgroep -+ enkelbreuk -+ enkelpartij -+ enquête-uitslag -+ enquêterapport -+ ensemblestuk -+ enteritis -+ enteroloog -+ entertainmentbedrijf -+ entertainmentconcern -+ enthousiasmerend -+ entre -+ entreegebouw -+ entreehal -+ entreekosten -+ entreeticket -+ enzoverder -+ epidurale -+ epotest -+ er bij zeggen -+ eraan toe -+ erbij horen -+ erbij krijgen -+ erbij roepen -+ erdoorheen krijgen -+ ere-escorte -+ erebegraafplaats -+ ereconsul -+ erectiepil -+ erectiestoornissen -+ erectus -+ eredivisieduels -+ eredivisieteam -+ eredivisievoetbal -+ eredivisiewedstrijden -+ erefunctie -+ eregaste -+ erejury -+ ereklasse -+ erekwestie -+ erelijst -+ erelijstje -+ eremedaille -+ eremedailles -+ eremoorden -+ ereplicht -+ ererondje -+ ererondjes -+ ereterras -+ ereveld -+ erevelden -+ erewraak -+ erfpachtovereenkomst -+ erfscheiding -+ ergens achter komen -+ ergens heen kijken -+ ergens over praten -+ ergens tegenover staan -+ ergens vanaf willen -+ erkenningsprocedure -+ erkenningsvoorwaarde -+ erkenningsvoorwaarden -+ erlebnis -+ ernstigers -+ error -+ eruit liggen -+ eruitgehaald -+ eruitzag -+ escortbedrijven -+ escortbranche -+ esdorp -+ espressomachine -+ et cetera -+ etatistische -+ ethernet -+ etherruimte -+ ethylalcohol -+ etmaalgemiddelde -+ etnisch-culturele -+ etnisch-religieuze -+ etnomusicoloog -+ ette -+ euregio -+ euro-dollarkoers -+ eurobankbiljetten -+ eurobedrag -+ eurobedragen -+ eurobonds -+ eurocampagne -+ eurocommissaris -+ eurocommissarissen -+ euroconversie -+ eurofiel -+ euroforie -+ eurofraude -+ eurogebied -+ eurogeld -+ eurogroep -+ eurokit -+ eurokoers -+ euroland -+ euromuntjes -+ euromuntstukken -+ europrijs -+ europrijzen -+ europroject -+ europroof -+ euroreferendum -+ eurosceptici -+ euroscepticus -+ eurosceptisch -+ eurosceptische -+ eurostuk -+ euroteken -+ eurotekens -+ eurotijdperk -+ eurotop -+ eurowisselgeld -+ euthanasiebeleid -+ euthanasiekwestie -+ euthanasieverzoek -+ euthanasieverzoeken -+ euthanasievoorstel -+ euthanasievraag -+ euthanasiewens -+ euthanasiezaak -+ euthanasiezaken -+ evacuatiekosten -+ evaluatiecriteria -+ evaluatiecriterium -+ evaluatieformule -+ evaluatieformules -+ evaluatiemoment -+ evaluatiemomenten -+ evaluatiesysteem -+ evaluatievorm -+ evangelisatiewerk -+ evangelisch-lutherse -+ evangeliste -+ even groot -+ even lang -+ evenementenbeleid -+ evenementenbureau -+ evenementenbureaus -+ evenementencomplex -+ evenementenkalender -+ evenementenlijst -+ evenementenplein -+ evenemententerrein -+ evenementenvuurwerk -+ evengrote -+ evenhoevigen -+ evenpoint -+ evenpunt -+ evenredigheidsregel -+ event -+ evoluerend -+ evoluerende -+ ex aequo -+ ex cathedra -+ ex dividend -+ ex libris -+ ex librissen -+ ex temporeetje -+ ex voto -+ ex-advocaat -+ ex-ambtenaren -+ ex-baas -+ ex-bankier -+ ex-bestuurders -+ ex-bevelhebber -+ ex-bewoner -+ ex-bondskanselier -+ ex-chef -+ ex-commandant -+ ex-communist -+ ex-crimineel -+ ex-criminelen -+ ex-danser -+ ex-delinquent -+ ex-delinquenten -+ ex-dictators -+ ex-dienstplichtigen -+ ex-diplomaat -+ ex-directeur -+ ex-directeuren -+ ex-dochter -+ ex-doelman -+ ex-dominee -+ ex-drugsverslaafden -+ ex-dwangarbeider -+ ex-eigenaar -+ ex-filmster -+ ex-geliefde -+ ex-generaal -+ ex-gijzelaar -+ ex-gijzelaars -+ ex-gouverneur -+ ex-hongerstakers -+ ex-journalist -+ ex-junk -+ ex-kankerpatiënt -+ ex-kanselier -+ ex-keeper -+ ex-keizer -+ ex-kolonel -+ ex-kolonisator -+ ex-korpschef -+ ex-krakers -+ ex-landgenoten -+ ex-legerleider -+ ex-leider -+ ex-leraar -+ ex-lid -+ ex-manager -+ ex-marinier -+ ex-medewerkers -+ ex-mijnwerkers -+ ex-minnares -+ ex-model -+ ex-monopolist -+ ex-officieren -+ ex-ondernemer -+ ex-patiënt -+ ex-patiënte -+ ex-patiënten -+ ex-politici -+ ex-politicus -+ ex-politiechef -+ ex-politieke -+ ex-politieman -+ ex-politiemensen -+ ex-prostituee -+ ex-psychiatrische -+ ex-raadslid -+ ex-rebellen -+ ex-rebellenleider -+ ex-rechercheur -+ ex-renner -+ ex-rijkswachter -+ ex-roker -+ ex-rokers -+ ex-schrijver -+ ex-senator -+ ex-slaven -+ ex-spelers -+ ex-spion -+ ex-staatshoofd -+ ex-strijders -+ ex-student -+ ex-terrorist -+ ex-topman -+ ex-trainer -+ ex-verdachte -+ ex-verdachten -+ ex-verloofde -+ ex-verslaafde -+ ex-verslaafden -+ ex-vicepresident -+ ex-voetballer -+ ex-voorzitter -+ ex-vriend -+ ex-vriendin -+ ex-vriendje -+ ex-werkgever -+ ex-werknemer -+ ex-wielrenner -+ ex-winnaar -+ examendag -+ exameninstituut -+ examenjaar -+ examenklas -+ examenklassen -+ examenlokaal -+ examenmakers -+ examenperiode -+ examenzaal -+ excl. -+ exclusiviteitscontract -+ excuuscultuur -+ existent -+ existente -+ exitstrategie -+ exoneratiebeding -+ exoniem -+ exoniemen -+ exoplaneten -+ exotiek -+ expansiefase -+ expansiesteun -+ experimenteerfase -+ experimenteerzucht -+ explicite -+ exploitatiebijdrage -+ exploitatiehandeling -+ exploitatiehandelingen -+ exploitatielasten -+ exploitatieovereenkomst -+ exploitatieovereenkomsten -+ exploitatiesubsidie -+ exploitatievergunning -+ exploitatievergunningen -+ explosievenopruimingsdienst -+ exportaandeel -+ exportactiviteiten -+ exportbelangen -+ exportbeperking -+ exportbeperkingen -+ exportbevordering -+ exportcontracten -+ exportdiensten -+ exporteerbaar -+ exportfinanciering -+ exportgoederen -+ exportgroei -+ exportheffingen -+ exportkansen -+ exportkrediet -+ exportkredieten -+ exportmogelijkheden -+ exportopbrengst -+ exportopbrengsten -+ exportoverschot -+ exportpakket -+ exportprestaties -+ exportprijs -+ exportproblemen -+ exportpromotie -+ exportquota -+ exportregels -+ exportsector -+ exportsectoren -+ exportsteun -+ exportstrategie -+ exportsucces -+ exporttransacties -+ exportverbod -+ exportverzamelplaatsen -+ extenso -+ externaliseren -+ extralegaal -+ extreem-nationalisten -+ extreem-nationalistische -+ extreemlinks -+ extreemlinkse -+ extreemrechts -+ extremis -+ extrusie -+ extrême -+ f'jes -+ fa. -+ fabriekseigenaren -+ fabrieksgarantie -+ fabrieksgegevens -+ fabrieksijs -+ fabrieksmatig -+ fabrieksorders -+ fabriekspijpen -+ fabrieksruimte -+ facilitator -+ faciliterend -+ faciës -+ facturatie -+ faillissementsrecht -+ fair play -+ fait -+ falangistische -+ fall -+ falsificaten -+ fam. -+ familias -+ familie-eer -+ familie-epos -+ familieberaad -+ familiebijeenkomst -+ familieboerderij -+ familieclan -+ familieconflict -+ familiedag -+ familiefortuin -+ familiegebeuren -+ familiegeheim -+ familiegevoel -+ familiegroep -+ familiehereniging -+ familiehoofd -+ familiehuis -+ familiejuwelen -+ familiekapitaal -+ familiekasteel -+ familiekomedie -+ familielijn -+ familieman -+ familiemusical -+ familieonderneming -+ familiepark -+ familiepraktijk -+ familierechter -+ familierestaurant -+ familieruzie -+ familieruzies -+ familiesaga -+ familiesage -+ familiesfeer -+ familiespel -+ familiesport -+ familiestichting -+ familiestructuur -+ familietak -+ familietherapeute -+ familietragedie -+ familieverband -+ familieverbanden -+ familieverhaal -+ familievriend -+ familiewagen -+ familiezender -+ fanclubdag -+ fancy -+ fanfaremuziek -+ fansite -+ fansites -+ fantasieverhalen -+ fantasme -+ fantastica -+ fantasyfilm -+ farma -+ farma-afdeling -+ farmabedrijf -+ farmabedrijven -+ farmaciebedrijven -+ farmacieconcern -+ farmaciedivisie -+ farmaciegigant -+ farmaciereus -+ farmaciesector -+ farmaconcern -+ farmadivisie -+ farmagroep -+ farmagroepen -+ farmareus -+ farmasector -+ farmatak -+ fascistenleider -+ fata morgana -+ faunabeheerder -+ faunapassages -+ faunawet -+ faut -+ faux -+ favela -+ favorietenlijstje -+ faxtoestel -+ faxverkeer -+ februarinummer -+ federatieraad -+ feestband -+ feestbeesten -+ feestgevoel -+ feestjaar -+ feestmaand -+ feestmenu -+ feestmiddag -+ feestmuziek -+ feestperiode -+ feestsfeer -+ feesttafel -+ feestweekeinde -+ feestweekend -+ feestwinkel -+ feitencomplex -+ feitenonderzoek -+ feitenoverzicht -+ feitenrelaas -+ felbetwist -+ felbevochten -+ felgroene -+ fellow -+ fellows -+ feloranje -+ femme -+ feng -+ feng shui -+ fermionen -+ ferro -+ ferrobedrijven -+ ferroviaire -+ ferrymaatschappijen -+ ferryschepen -+ festivalcentrum -+ festivaldag -+ festivaldirecteur -+ festivaldirecteuren -+ festivaldirectie -+ festivalfilms -+ festivallocatie -+ festivalorganisatie -+ festivalorganisator -+ festivalorganisatoren -+ festivalprogramma -+ festivalpubliek -+ festivalseizoen -+ festivalstad -+ festivalweek -+ festivalweide -+ feu -+ few -+ feërieke -+ fibromyalgie -+ fibrose -+ fictieboek -+ fictiefilm -+ fictiefilms -+ fiction -+ fictionboek -+ fideï -+ fieltig -+ fietsaccessoires -+ fietsaftrek -+ fietsbeleid -+ fietsbrug -+ fietsdag -+ fietsdiefstal -+ fietsendiefstal -+ fietsendiefstallen -+ fietsenfabriek -+ fietsenplan -+ fietsenzaak -+ fietsfabriek -+ fietsfabrikanten -+ fietsgebruik -+ fietsindustrie -+ fietskilometers -+ fietskoerier -+ fietslengte -+ fietslicht -+ fietsliefhebbers -+ fietsnetwerk -+ fietsonderdelen -+ fietspadennet -+ fietsparcours -+ fietsplan -+ fietsplezier -+ fietsreis -+ fietsreizen -+ fietsroutenetwerk -+ fietssnelweg -+ fietsstallingen -+ fietssuggestiestroken -+ fietstest -+ fietstoerist -+ fietstoeristen -+ fietsverbinding -+ fietsverbindingen -+ fietsverkeer -+ fietsverlichting -+ fietsvoorzieningen -+ fietswrakken -+ fig. -+ fijnbladig -+ fijnbladige -+ fijngebouwd -+ fijngebouwde -+ fijngeslepen -+ fijnmazigheid -+ fijnmechanische -+ fileberichten -+ filebestrijding -+ filegevoelige -+ filekaart -+ fileplan -+ fileproblematiek -+ filerijder -+ fileverkeer -+ filiaalleider -+ filiaalmanager -+ filialisering -+ filmaanbod -+ filmactiviteiten -+ filmauteurs -+ filmavonden -+ filmavontuur -+ filmbeleid -+ filmbezoek -+ filmbiografie -+ filmbranche -+ filmbusiness -+ filmcontract -+ filmcrew -+ filmcultuur -+ filmdecor -+ filmdistributie -+ filmdivisie -+ filmdocumentaire -+ filmdrama -+ filmepos -+ filmervaring -+ filmevenement -+ filmfabriek -+ filmfeest -+ filmfinanciering -+ filmfonds -+ filmfragmenten -+ filmfreak -+ filmgenre -+ filmgenres -+ filmgeschiedenis -+ filmhit -+ filminstituut -+ filmjaar -+ filmkanalen -+ filmkijker -+ filmklimaat -+ filmkopie -+ filmkopieën -+ filmland -+ filmlegende -+ filmlocatie -+ filmlocaties -+ filmmaatschappijen -+ filmmagazine -+ filmmaken -+ filmmarkt -+ filmmensen -+ filmonderscheiding -+ filmpersonage -+ filmpersonages -+ filmpionier -+ filmplan -+ filmplannen -+ filmposters -+ filmpremière -+ filmprijs -+ filmproducer -+ filmproductiebedrijf -+ filmprofessionals -+ filmprogramma -+ filmproject -+ filmprojecten -+ filmprojectie -+ filmpubliek -+ filmrecensent -+ filmrecensies -+ filmredacteur -+ filmreportage -+ filmreportages -+ filmrubriek -+ filmscholen -+ filmschool -+ filmscène -+ filmsector -+ filmstad -+ filmstijl -+ filmsucces -+ filmtalent -+ filmweek -+ filmwerk -+ filmwerken -+ filodeeg -+ filterprogramma's -+ filtersoftware -+ filtersystemen -+ fin -+ finalepartij -+ finaliste -+ financieel directeur -+ financieel-administratief -+ financieel-administratieve -+ financierder -+ financierders -+ financieringsbehoefte -+ financieringsbehoeften -+ financieringsbron -+ financieringsbronnen -+ financieringsconstructie -+ financieringsconstructies -+ financieringsfonds -+ financieringsinstrument -+ financieringsmiddelen -+ financieringsprogramma -+ financieringsregelingen -+ financieringsrente -+ financieringsronde -+ financieringsstromen -+ financieringsstructuur -+ financieringssysteem -+ financieringsvoorwaarden -+ financieringsvorm -+ financiëledienstengroep -+ finasteride -+ firmware -+ first -+ fiscaal jurist -+ fiscaalvriendelijk -+ fiscaalvriendelijke -+ fitnesszaal -+ five -+ fixe -+ fixen -+ fiësta -+ flamencodans -+ flamencodanser -+ flamencogitarist -+ flamencojurk -+ flamencozanger -+ flamingantische -+ flaneerboulevard -+ flappentap -+ flashy -+ flatbedscanner -+ flatwachten -+ flavonoïden -+ fleetmarkt -+ fleetowner -+ flessenwater -+ flexievorm -+ flexievormen -+ flexkrachten -+ flippo -+ flippo's -+ flitsbereik -+ flitsscheiding -+ fluoxetine -+ flutprogramma -+ flutprogramma's -+ fly -+ flyeren -+ flyzone -+ focaccia -+ focusgroepen -+ fokbedrijf -+ fokbedrijven -+ fokkenhals -+ fokkenra -+ fokkenwant -+ fokprogramma -+ fokvarkens -+ folioformaat -+ folkfestival -+ folky -+ follow -+ fondsbeheer -+ fondsbeheerder -+ fondsbeheerders -+ fondsenbeheer -+ fondsenbeheerder -+ fondsenbeheerders -+ fondsenmarkt -+ fondsenwervende -+ fondsenwerver -+ fondsenwervers -+ fondsmanager -+ fondsverzekerden -+ fondswerving -+ food -+ foodsector -+ football -+ footballclub -+ footballspeler -+ force -+ formatiegesprekken -+ formatieopdracht -+ formatieperiode -+ formatieproces -+ formatieronde -+ formazitting -+ formularium -+ formulefilm -+ formulevak -+ formulierveld -+ forteiland -+ forumavond -+ fosforverbindingen -+ fotoblad -+ fotocollectie -+ fotocollecties -+ fotofestival -+ fotogalerie -+ fotogalerij -+ fotogeschiedenis -+ fotografieconcern -+ fotografiemuseum -+ fotogroep -+ fotokwaliteit -+ fotolab -+ fotolijstjes -+ fotometrisch -+ fotometrische -+ fotomuseum -+ fotoportret -+ fotoportretten -+ fotoprijs -+ fotoprints -+ fotoproject -+ fotoredactie -+ fotoreeksen -+ fototentoonstelling -+ fototentoonstellingen -+ fotoverkenners -+ fotoverzameling -+ fotovoltaïsche -+ fouilleringsactie -+ fourageren -+ fout-negatief -+ fout-positief -+ fout-positieve -+ foutenfestival -+ foutenlast -+ foutenmarge -+ foutenmarges -+ foutherstel -+ foutverbetering -+ foutverbeteringen -+ fr. -+ fraais -+ fractieassistent -+ fractiebestuur -+ fractiecommissie -+ fractieleiderschap -+ fractiesecretaris -+ fractiestandpunt -+ fractietop -+ fractievoorzitterschap -+ fractiewoordvoerder -+ fractiewoordvoerders -+ frambozencoulis -+ framenummer -+ franca -+ franchisegever -+ franchisegevers -+ franchisehouders -+ franchisers -+ franchisesysteem -+ franchising -+ franciscanenorde -+ frankeeraanduiding -+ fransijn -+ fraudebedrag -+ fraudebedragen -+ fraudebeleid -+ fraudebestendigheid -+ fraudebestrijders -+ fraudebureau -+ fraudedossier -+ fraudedossiers -+ fraudegeval -+ fraudegevoeligheid -+ fraudemogelijkheden -+ fraudeonderzoek -+ fraudepraktijken -+ fraudepreventie -+ fraudeproces -+ fraudeschandaal -+ fraudeschandalen -+ fraudevrij -+ fraîche -+ freakshow -+ free -+ freestylers -+ frequentiebereik -+ frequentieblokken -+ frequentieomzetter -+ frequentieomzetters -+ frequentiepakketten -+ frequentieplan -+ frequentieregelaar -+ frequentieruimte -+ frequentieveiling -+ frietvet -+ frisdrankconcern -+ frisdrankengigant -+ frisdrankenindustrie -+ frisdrankfabrikant -+ frisdrankgigant -+ frisdrankindustrie -+ frisdrankproducent -+ friszure -+ frontdienst -+ frontensysteem -+ frontman -+ fruitbedrijven -+ fruitconsumptie -+ fruithandel -+ fruitmarkt -+ fruitpluk -+ fruitplukkers -+ fruitras -+ fruitrassen -+ fruitsector -+ fruitsoorten -+ fruitterminal -+ frustrerender -+ ftalaten -+ fte's -+ full -+ functiebalk -+ functiebeperking -+ functiedifferentiatie -+ functienaam -+ functieprofiel -+ functieroulatie -+ functiescheiding -+ functieverandering -+ fundamentalistisch-islamitische -+ fundraiser -+ fundum -+ funshopper -+ fusiebedrijf -+ fusiebesluit -+ fusiebeurs -+ fusiebeweging -+ fusiebewegingen -+ fusieclub -+ fusieconcern -+ fusiedatum -+ fusiegeruchten -+ fusiegesprek -+ fusiegolf -+ fusiegolven -+ fusiegroep -+ fusiekoorts -+ fusiekosten -+ fusiekrant -+ fusiemaatschappij -+ fusienieuws -+ fusieonderzoek -+ fusieoperatie -+ fusieovereenkomst -+ fusieoverleg -+ fusiepartner -+ fusiepartners -+ fusieploeg -+ fusiepoging -+ fusieproject -+ fusieregels -+ fusieschool -+ fusievennootschap -+ fusieverbod -+ fusievoornemen -+ fusievoorstel -+ fusievoorstellen -+ futures -+ futuresbeurs -+ fytotherapie -+ g'tjes -+ g.g.d. -+ galeristen -+ galgje -+ galliumarsenide -+ gamepad -+ gammaflitsen -+ gangbaardere -+ gangstarapper -+ gangsterrap -+ ganzenleverterrine -+ ganzenpad -+ garantiebedrag -+ garantiesubsidie -+ garantieverplichting -+ garantieverplichtingen -+ gardetoneel -+ gardisme -+ gardistisch -+ garnaalkroketten -+ gas geven -+ gasactiviteiten -+ gasafzet -+ gasbaten -+ gasboring -+ gascentrale -+ gascentrales -+ gasconcern -+ gascontract -+ gasexport -+ gasfabriekterrein -+ gasgebruik -+ gasgevulde -+ gasgigant -+ gashandelaar -+ gashydraten -+ gasindustrie -+ gasinkomsten -+ gasleverancier -+ gasleveranciers -+ gasleveranties -+ gaslevering -+ gasmaatschappij -+ gasmaatschappijen -+ gasmarkt -+ gasopslag -+ gaspijp -+ gaspijpleiding -+ gaspijplijn -+ gasproducent -+ gasproducenten -+ gasproductie -+ gasproject -+ gasprojecten -+ gassector -+ gastacteur -+ gastacteurs -+ gastconservator -+ gastcurator -+ gastenhuis -+ gastenlijst -+ gastles -+ gastlessen -+ gastmusici -+ gastmuzikant -+ gastmuzikanten -+ gastouderopvang -+ gastouderschap -+ gastpresentator -+ gastprofessor -+ gastransport -+ gastregie -+ gastro -+ gaststad -+ gaststeden -+ gaswet -+ gate -+ geanonimiseerde -+ geaprès -+ gebedsruimte -+ gebedsruimtes -+ gebel -+ gebiedsagent -+ gebiedsgebonden -+ gebiedsgericht -+ gebiedsgerichte -+ gebitsproblemen -+ geboortekanaal -+ geboortemaand -+ gebouwbeheer -+ gebouwenbeheer -+ gebroeders Grimm -+ gebruikelijkheid -+ gebruikergedefinieerd -+ gebruikersgegevens -+ gebruikersgericht -+ gebruikersheffing -+ gebruikersmarkt -+ gebruikersopleiding -+ gebruikersorganisaties -+ gebruikersovereenkomst -+ gebruikersraad -+ gebruikersrecht -+ gebruikersrechten -+ gebruikersruimte -+ gebruikersruimten -+ gebruikersruimtes -+ gebruiksdoel -+ gebruiksduur -+ gebruiksfunctie -+ gebruiksfuncties -+ gebruiksgoed -+ gebruikshandeling -+ gebruikshandelingen -+ gebruiksovereenkomst -+ gebruiksovereenkomsten -+ gebruiksplan -+ gebruikstermijn -+ gebruiksvergunning -+ gebruiksvergunningen -+ gebruiksvoorwaarden -+ gecommercialiseerde -+ gecommiteerd -+ geconcenteerd -+ geconcipieerde -+ gedachtekring -+ gedachtespoor -+ gedachtestap -+ gedans -+ gedefiniëerd -+ gedeklasseerd -+ gediagnostiseerd -+ gedichtendag -+ gediversifieerde -+ gedoogbeschikking -+ gedoogbesluit -+ gedoogcultuur -+ gedoogsituatie -+ gedoogstatus -+ gedoogvergunning -+ gedownloade -+ gedragenheid -+ gedragsbeïnvloeding -+ gedragskenmerken -+ gedragskundigen -+ gedragsmoeilijkheden -+ gedragstherapeut -+ gedragsverandering -+ gedragsveranderingen -+ gedragsvoorschriften -+ geefgedrag -+ geeks -+ geel-blauwe -+ geel-bruine -+ geel-oranje -+ geel-rode -+ geel-zwart -+ geel-zwarte -+ geenbezwaarsysteem -+ geesteswetenschappen -+ geflyerd -+ gefoezel -+ gefortuneerden -+ gefrutsel -+ gegevensstructuur -+ gegevensverkeer -+ gegevensverstrekking -+ gegevensverzameling -+ geglobaliseerd -+ gegoeden -+ gehaktballetjes -+ gehandicaptenraad -+ gehandicaptensector -+ gehandicaptenvervoer -+ gehandicaptenvoorzieningen -+ geheimagent -+ geheimdoenerij -+ geheimhoudingsverklaring -+ geherkwalificeerd -+ gehobbel -+ gehol -+ gehoorbeentjes -+ gehoorbeschermers -+ gehoorbescherming -+ gehoorschade -+ gehoorstoornis -+ gehydrateerd -+ geilt -+ geitenboerderij -+ geitenhouderij -+ geitenhouders -+ gejaag -+ gejojo -+ gekef -+ gekkere -+ geklimatiseerde -+ geknaag -+ geknipper -+ gekraai -+ gekronkel -+ gelambrizeerde -+ geldbeheer -+ geldbeleid -+ geldbeluste -+ geldbesparende -+ geldbron -+ geldbronnen -+ geldcircuit -+ geldcirculatie -+ gelde -+ geldgewin -+ geldgroei -+ geldhandelingen -+ geldinjectie -+ geldinjecties -+ geldkoffer -+ geldmachine -+ geldmachines -+ geldmaker -+ geldmarktrente -+ geldmarkttarieven -+ geldopname -+ geldopnames -+ geldoverdracht -+ geldpotje -+ geldpotten -+ geldprobleem -+ geldroof -+ geldschepping -+ geldstelsel -+ geldsysteem -+ geldtekort -+ geldtransactie -+ geldtransacties -+ geldtransfers -+ geldtransportbedrijf -+ geldtransporteur -+ geldverkwisting -+ geldverstrekker -+ geldverstrekkers -+ geldvoorraad -+ gelegenheidsaanvoerder -+ gelegenheidsband -+ gelegenheidscoalitie -+ gelegenheidscoalities -+ gelegenheidscombinatie -+ gelegenheidsformatie -+ gelegenheidsspits -+ gelegenheidstrio -+ gelegenheidswerk -+ gelegenheidswetgeving -+ geleidingssysteem -+ gelezene -+ gelieg -+ gelijk op -+ gelijkaardigs -+ gelijkgebleven -+ gelijkgeslachtelijke -+ gelijkhebberige -+ gelijkheidsdenken -+ gelijkheidsprincipe -+ gelijkopgaande -+ gelijkstaat -+ gelinkte -+ geloer -+ geloofsgroep -+ geloofsgroepen -+ geloofsrichting -+ geloofsstrijd -+ geloofstraditie -+ geloofsuitingen -+ geloofswereld -+ geloofwaardigheidsprobleem -+ geluidmetingen -+ geluidoverlast -+ geluidsarchief -+ geluidsbeeld -+ geluidsbehang -+ geluidsbron -+ geluidsbronnen -+ geluidscherm -+ geluidschermen -+ geluidscontouren -+ geluidsdecor -+ geluidsdempers -+ geluidsdichte -+ geluidseffect -+ geluidseisen -+ geluidsgrens -+ geluidsgrenzen -+ geluidsisolerende -+ geluidskunst -+ geluidsmaatregelen -+ geluidsmateriaal -+ geluidsmeter -+ geluidsmeters -+ geluidsmix -+ geluidsnorm -+ geluidsonderzoek -+ geluidsproblemen -+ geluidsproductie -+ geluidsreductie -+ geluidsregels -+ geluidsruimte -+ geluidsscherm -+ geluidsstudio -+ geluidssysteem -+ geluidsverbinding -+ geluidsversterking -+ geluidsvoorschriften -+ geluidswagen -+ geluidswagens -+ geluidswal -+ geluidsweergave -+ geluidswering -+ geluidszonering -+ geluksfactor -+ gem. -+ gemakkelijkheidshalve -+ gemaksproducten -+ gemakswinkels -+ gemeenschapsbelang -+ gemeenschapsdenken -+ gemeenschapsinformatie -+ gemeenschapsleven -+ gemeenschapsvorming -+ gemeentebestuurder -+ gemeentebestuurders -+ gemeentegeld -+ gemeentegelden -+ gemeentegrens -+ gemeentehuize -+ gemeentekantoor -+ gemeentenaam -+ gemeentenamen -+ gemeenteniveau -+ gemeentepolitiek -+ gemeenteraadscommissie -+ gemeentesubsidie -+ gemeenteverkiezing -+ gemeenteverkiezingen -+ gemeentevervoerbedrijf -+ gemeentevlag -+ gemeentevoorlichtster -+ gemeentewerf -+ gemeentewerkers -+ gemeentewoning -+ gemeentewoningen -+ gemeentewoordvoerder -+ gemeentewoordvoerster -+ gemeenteziekenhuis -+ gemeentezijde -+ gemenerd -+ gemengd dubbel -+ gemiauw -+ gemillimeter -+ gemondialiseerd -+ gendefect -+ geneesmiddelenbudget -+ geneesmiddelengebruik -+ geneesmiddelenmarkt -+ geneesmiddelenonderzoek -+ geneesmiddelenpakket -+ geneesmiddelenprijzen -+ geneesmiddelenvoorziening -+ genenbank -+ genenbanken -+ genenkaart -+ generaalsregime -+ generatiegenote -+ generica -+ generis -+ genezingsverhaal -+ gengewassen -+ geniehulpbataljon -+ genieofficier -+ genoomonderzoek -+ genoomproject -+ genotsrecht -+ gentech -+ gentechnieken -+ gentechvrije -+ gentleman's -+ gents -+ genua -+ genvoedsel -+ gepersonaliseerd -+ gepersonifieerde -+ gepiercete -+ gepingel -+ geplagieerde -+ gepokt en gemazeld -+ gepolijster -+ geprivatiseerde -+ geprivilegieerden -+ gepromote -+ gerechtsdossier -+ gerechtstolk -+ gerechtstolken -+ gerecyclede -+ gerepatrieerde -+ gerepatrieerden -+ gerichtere -+ gerook -+ geruchtvorming -+ geruime tijd -+ gesalarieerde -+ gesamplede -+ geschenkartikelen -+ geschenkboekje -+ geschenke -+ geschiedenisboekjes -+ geschiedenisdocent -+ geschiedenisprogramma -+ geschiedenisstudent -+ geschiedsvervalsing -+ geschiedwetenschap -+ geschriftenbescherming -+ gescout -+ gesedeerd -+ geslachtskeuze -+ gesneefde -+ gespreksdeelnemers -+ gespreksleidster -+ gesprekstafel -+ gespreksverslagen -+ gespreksvoering -+ gesprokene -+ gestand blijven -+ gestand doen -+ gestolene -+ gestyleerde -+ get. -+ getalenteerden -+ getalnotatie -+ getaltheorie -+ getijdenverschil -+ getimede -+ getraumatiseerden -+ getrest -+ getrouwheidskaart -+ getrouwheidskaarten -+ getrouwheidsprogramma's -+ getrouwtrek -+ getuige à decharge -+ getuigeverklaringen -+ getuur -+ getwijfel -+ geureenheden -+ geurhinder -+ geurlijn -+ geurnorm -+ geuronderzoek -+ geuroverlast -+ gevaarscriterium -+ gevandaliseerd -+ gevandaliseerde -+ gevangenisautoriteiten -+ gevangenisbeleid -+ gevangenisbevolking -+ gevangenisbewaarder -+ gevangenisbrieven -+ gevangeniscapaciteit -+ gevangenisdrama -+ gevangeniseiland -+ gevangenisoproer -+ gevangenispopulatie -+ gevangenisregime -+ gevangenissysteem -+ gevangenname -+ gevechtsfuncties -+ gevechtshelikopter -+ gevechtsrantsoenen -+ gevechtstaken -+ gevelbekleding -+ gevelplaten -+ gevelversiering -+ gevoelswereld -+ geweldgebruik -+ geweldpleger -+ geweldplegers -+ geweldsdreiging -+ geweldsescalatie -+ geweldsexcessen -+ geweldsfilms -+ geweldsgebruik -+ geweldsincidenten -+ geweldsmonopolie -+ geweldszaken -+ gewestplanwijziging -+ gewestwegen -+ gewichtdeel -+ gewichtseis -+ gewichtstrap -+ gewichtstrappen -+ gewichtsverdeling -+ gezangenboek -+ gezelligheidsspelletjes -+ gezichtsherkenning -+ gezichtverlies -+ gezinden -+ gezinsbestedingen -+ gezinsfinanciën -+ gezinsgeluk -+ gezinsherenigers -+ gezinsonderzoek -+ gezinspartij -+ gezinspatroon -+ gezinspolitiek -+ gezinssocioloog -+ gezinsuitje -+ gezinsvermogen -+ gezinsvormen -+ gezinsvriendelijk -+ gezinsvriendelijke -+ gezinswoning -+ gezinswoningen -+ gezinszaken -+ gezondheidsbelangen -+ gezondheidsbeleid -+ gezondheidsbescherming -+ gezondheidsbevordering -+ gezondheidsbudget -+ gezondheidsclaim -+ gezondheidsclaims -+ gezondheidscontrole -+ gezondheidseffect -+ gezondheidseffecten -+ gezondheidseisen -+ gezondheidsenquête -+ gezondheidsinformatie -+ gezondheidsinspectie -+ gezondheidsinstellingen -+ gezondheidskosten -+ gezondheidskundige -+ gezondheidsmarkt -+ gezondheidsprobleem -+ gezondheidsproducten -+ gezondheidsprogramma -+ gezondheidssituatie -+ gezondheidssysteem -+ gezondheidstest -+ gezondheidstesten -+ gezondheidsverschillen -+ gezondheidsverzekering -+ gezondheidsvoorlichters -+ gezondheidsvoorlichting -+ gezondheidsvraagstukken -+ gezondheidswaarschuwing -+ gezondheidswaarschuwingen -+ gezondheidswinst -+ gezondheidszorgsysteem -+ gezondsheidszorg -+ gezuip -+ gezwabber -+ gezweef -+ geëncrypteerd -+ geëncrypteerde -+ geëxtrudeerde -+ geïntrigeer -+ geïsoleerdheid -+ geörienteerd -+ geörienteerde -+ geüploade -+ gietermodus -+ gifgasaanslag -+ gifgasaanval -+ gifstof -+ giftenaftrek -+ gifzakjes -+ giga -+ gigabit -+ gigabyte -+ gigajoule -+ gigawattuur -+ gijzelaarscrisis -+ gijzeldrama -+ gijzelingsaffaire -+ gijzelingscrisis -+ gildebrief -+ gildebrieven -+ gildedeken -+ gildedekens -+ gildepatroon -+ gildepatroons -+ gildepenning -+ gildepenningen -+ gilles -+ ginkgo biloba -+ girogluren -+ gitaarband -+ gitaarbands -+ gitaarduo -+ gitaargeluid -+ gitaargeweld -+ gitaargroepen -+ gitaarheld -+ gitaarlessen -+ gitaarpartijen -+ gitaarplaat -+ gitaarriff -+ gitaarriffs -+ gitaarsolo -+ gitaarsolo's -+ gitaarspelende -+ gitaarstijl -+ gitaarvirtuoos -+ gitaarwerk -+ gitariste -+ gladheidsbestrijding -+ glamoureus -+ glamoureuze -+ glamrock -+ glanzender -+ glas in lood -+ glasbedrijf -+ glasfabrikant -+ glasgroep -+ glasindustrie -+ glaskunst -+ glasoppervlak -+ glaspaleis -+ glaspartijen -+ glastuinbouwgebied -+ glasvezelnetwerk -+ glasvezelnetwerken -+ glasvezelverbindingen -+ glasvezelversterkte -+ glaszetter -+ glaszetters -+ glijpartij -+ glittert -+ globaliseren -+ globaliseringsproces -+ globalisme -+ globaliteit -+ gloeiendhete -+ gloeilampenfabriek -+ gloeilamplicht -+ glucosegehalte -+ gluonen -+ glutenvrij -+ glutenvrije -+ glycoproteïne -+ glyfosaat -+ goarea -+ godfather -+ godfathers -+ godsdienstonderricht -+ godsdienststrijd -+ godsdienstwaanzinnige -+ godsdienstwetenschapper -+ goed komen -+ goedbekeken -+ goedbeschouwd -+ goedbetalende -+ goedbewaarde -+ goedbezochte -+ goededoelenloterijen -+ goededoelenorganisaties -+ goederenbedrijf -+ goederenbehandelaar -+ goederenlijn -+ goederenspoor -+ goederenspoorlijn -+ goederenuitvoer -+ goederenvervoerders -+ goedgekomen -+ goedgelovigen -+ goedgemikte -+ goedgeorganiseerde -+ goedgeplaatste -+ goedgetrainde -+ goedgevigheid -+ goedgevuld -+ goedingelichte -+ goedkeuringsprocedure -+ goedkeuringsprocedures -+ goedkeuringsstempel -+ goedkeuringswet -+ goedkomt -+ goedmaker -+ goedmakertje -+ goedmarkt -+ goedmenende -+ goedopgeleide -+ goedverdienende -+ goedverkopende -+ goedwerkende -+ goelag -+ goeroeachtig -+ goeroeachtige -+ gokactiviteiten -+ gokbedrijf -+ gokcircuit -+ gokgedrag -+ gokindustrie -+ gokkantoren -+ gokmachines -+ gokmarkt -+ gokparadijs -+ gokpraktijken -+ gokproblemen -+ goksite -+ goksites -+ gokstad -+ gokverslaving -+ gokwereld -+ gokwerk -+ gokwezen -+ goldrush -+ golfenergie -+ golfhoogte -+ golfkampioen -+ golfkarretje -+ golfkarretjes -+ golfliefhebber -+ golfliefhebbers -+ golfpark -+ golftas -+ golftoernooi -+ golftoernooien -+ goors -+ gootsteenontstopper -+ goreng -+ gospelkoor -+ gospelzanger -+ gothic -+ goud smeden -+ gouda -+ gouden eeuw -+ goudfolie -+ goudjacht -+ goudkoers -+ goudmijnaandelen -+ goudschat -+ goudstandaard -+ goulashsoep -+ gouverneursverkiezingen -+ gouverneurszetel -+ government -+ graaiers -+ graansector -+ graanteelt -+ graanvoorraden -+ graffitikunst -+ graffitispuiters -+ grafgeschenken -+ grafkisten -+ grafrechten -+ grafrust -+ grammaticacontrole -+ granaataanslag -+ grand café -+ grand seigneur -+ granny -+ grappa -+ grasgroei -+ grasmachine -+ grasstroken -+ grata -+ gratiebeleid -+ gratin -+ grave -+ grec -+ gremium -+ grensarbeidersregeling -+ grenseffecten -+ grensformaliteiten -+ grenshospitium -+ grenspassage -+ grenspatrouilles -+ grensproblemen -+ grenssoldaten -+ grensverkenning -+ grensverlegging -+ grenszone -+ grenzeloosheid -+ grey -+ griepgolf -+ griepseizoen -+ grietfilet -+ griezeligs -+ griffiegeld -+ grijs-blauwe -+ grijs-groene -+ grindproducenten -+ gringo's -+ griot -+ griots -+ groede -+ groeibedrijf -+ groeibevorderaar -+ groeibevorderaars -+ groeibevorderende -+ groeibriljant -+ groeicapaciteit -+ groeidoelstellingen -+ groeidynamiek -+ groeifinanciering -+ groeiherstel -+ groeikapitaal -+ groeilampen -+ groeilanden -+ groeimachine -+ groeimotor -+ groeiniveau -+ groeipad -+ groeipatroon -+ groeiperspectief -+ groeiperspectieven -+ groeipijn -+ groeipijnen -+ groeiplan -+ groeiplannen -+ groeipotentieel -+ groeiprestaties -+ groeiprognose -+ groeiprognoses -+ groeiraming -+ groeiramingen -+ groeiritme -+ groeiruimte -+ groeiscenario -+ groeisegment -+ groeiseizoen -+ groeispurt -+ groeistrategie -+ groeitrend -+ groeiverhaal -+ groeiverschil -+ groeiversnelling -+ groeiverwachting -+ groeiverwachtingen -+ groeivoet -+ groeivoeten -+ groeivoorspelling -+ groen geverfd -+ groen-blauwe -+ groen-wit -+ groenafval -+ groenarm -+ groenbeleid -+ groenbeleidsplan -+ groenbemesters -+ groenbestemming -+ groenboek -+ groencertificaat -+ groencertificaten -+ groendienst -+ groendomein -+ groendomeinen -+ groenelement -+ groenelementen -+ groenfonds -+ groenfondsen -+ groenlof -+ groenonderhoud -+ groenopleiding -+ groenopleidingen -+ groenplan -+ groenprogramma -+ groenproject -+ groenregeling -+ groensingel -+ groenstructuren -+ groenstructuur -+ groenstructuurplan -+ groentegerecht -+ groentekraam -+ groentesoort -+ groentesoorten -+ groepsbezoeken -+ groepsdirecteur -+ groepsdirectie -+ groepsdruk -+ groepsduels -+ groepsexpositie -+ groepsgebonden -+ groepsgeluid -+ groepsgenoten -+ groepsgerichte -+ groepsgeweld -+ groepshoofden -+ groepshuisvesting -+ groepskeuze -+ groepsleerkracht -+ groepsleerkrachten -+ groepsleiding -+ groepsmaatschappijen -+ groepsniveau -+ groepsomzet -+ groepsresultaat -+ groepsrisico -+ groepsruimte -+ groepsruimten -+ groepssessies -+ groepstentoonstelling -+ groepstraining -+ groepstrainingen -+ groepsverschillen -+ groepsvervoer -+ groepsverzekering -+ groepsverzekeringen -+ groepsverzorging -+ groepswedstrijd -+ groepswinnaar -+ groepswinst -+ groepswonen -+ groepswoningen -+ groezeligheid -+ grondaanval -+ grondacties -+ grondaffaire -+ grondafhandeling -+ grondbank -+ grondbewerking -+ gronddepot -+ grondeekhoorn -+ grondeekhoorns -+ grondgebonden -+ grondkosten -+ grondleger -+ grondmarkt -+ grondontsmettingsmiddelen -+ grondoperaties -+ grondreiniging -+ grondsanering -+ grondse -+ grondser -+ grondstoffenfonds -+ grondstoffenleveranciers -+ grondstoffenmarkt -+ grondstoffenmarkten -+ grondstofkosten -+ grondstuk -+ grondtransactie -+ grondtransacties -+ gronduitgifte -+ grondvervuiling -+ grondverwerving -+ grondwaterbeschermingsgebied -+ grondwerktuigkundige -+ grondwerktuigkundigen -+ grondwerkzaamheden -+ grondwetsbepaling -+ grondwetspecialist -+ grondwetsvoorstel -+ grondwetszaken -+ grootafnemer -+ grootbank -+ grootbloemig -+ grootbloemige -+ grootdistributie -+ grootgemaakt -+ groothandelsactiviteiten -+ groothandelsbedrijf -+ groothandelsmarkt -+ grootkeuken -+ grootkeukens -+ groovy -+ grosso modo -+ groteren -+ grotestadsproblemen -+ grotestedenbeleid -+ grottencomplex -+ grottenstelsel -+ groupware -+ growshop -+ growshops -+ grungy -+ gróte -+ gsm-antennes -+ gsm-bedrijf -+ gsm-bedrijven -+ gsm-fabrikanten -+ gsm-gebruik -+ gsm-gebruiker -+ gsm-gebruikers -+ gsm-markt -+ gsm-mast -+ gsm-masten -+ gsm-net -+ gsm-netwerk -+ gsm-operator -+ gsm-operatoren -+ gsm-producenten -+ gsm-tarieven -+ gsm-technologie -+ gsm-telefoons -+ gsm-toestel -+ gsm-toestellen -+ gsm-verkeer -+ guerre -+ guerrillagroepen -+ guerrillagroepering -+ guerrillagroeperingen -+ gueule -+ guldenbiljetten -+ guldenmunten -+ gunstmaatregelen -+ gunstregime -+ gunstregimes -+ gymjuf -+ gymnaste -+ gymnastiekvereniging -+ h'tjes -+ h-pion -+ haalservice -+ haargel -+ haaronderzoek -+ haartransplantatie -+ haarverlies -+ haastje -+ habilis -+ hacking -+ haggis -+ haha -+ halachische -+ half-Jood -+ halfacht -+ halfbevroren -+ halfblote -+ halfdroge -+ halfgeleiderdivisie -+ halfgeleiderfabriek -+ halfgeleiderfabrikant -+ halfgeleiderindustrie -+ halfgeleiderproducent -+ halfgeleidersector -+ halfhartigheid -+ halfjaarrekening -+ halfjaarresultaat -+ halfjaarresultaten -+ halfjaarverlies -+ halfjaarverslag -+ halfjaarwinst -+ halfkoers -+ halfpipe -+ halfpipes -+ halfslaperig -+ halfuursdienst -+ halfvergane -+ halfverharde -+ halfvier -+ halfvijf -+ halfvrijstaande -+ halfwees -+ halfwezenuitkering -+ halfwilde -+ halfzijdig -+ halonen -+ halt houden -+ hamsterburchten -+ hamstringblessure -+ hand in hand -+ handafdrukken -+ handbalinternational -+ handbalploeg -+ handbalsters -+ handblessure -+ handcomputer -+ handcomputers -+ handcoördinatie -+ handelbaarheid -+ handeloos -+ handelsafspraken -+ handelsbeperkingen -+ handelsblok -+ handelsblokken -+ handelsboycot -+ handelscijfers -+ handelsconcern -+ handelsconflict -+ handelsconflicten -+ handelscontacten -+ handelscontracten -+ handelsdag -+ handelsdagen -+ handelsgeschil -+ handelsgeschillen -+ handelsgezant -+ handelsimperium -+ handelskwesties -+ handelsland -+ handelsliberalisatie -+ handelsliberalisering -+ handelsmaatregelen -+ handelsmarkt -+ handelsmetropool -+ handelsministers -+ handelsmogelijkheden -+ handelsnatie -+ handelsnederzetting -+ handelsoverleg -+ handelsplatform -+ handelspositie -+ handelspost -+ handelsposten -+ handelspraktijken -+ handelspreferenties -+ handelsrechter -+ handelsregels -+ handelsronde -+ handelsrondes -+ handelssancties -+ handelssessie -+ handelsstatus -+ handelsstromen -+ handelsstroom -+ handelssysteem -+ handelssystemen -+ handelstarieven -+ handelsuren -+ handelsvolume -+ handelsvolumes -+ handelsvoordeel -+ handelsvoordelen -+ handelsvoorraad -+ handelsvoorwaarden -+ handelsweek -+ handelswetten -+ handelszone -+ handenschuddend -+ handenvrij -+ handenvrije -+ handgesmede -+ handheld -+ handhelds -+ handpop -+ handsets -+ hanggroepjongeren -+ hangjeugd -+ hangjongere -+ happy end -+ harddiskruimte -+ harddrugsgebruik -+ harddrugsverslaafden -+ hardliner -+ hardliners -+ hardrockfestival -+ hardrockgroep -+ hardtop -+ hardwareleverancier -+ hardwareleveranciers -+ haring kaak -+ haring kaakt -+ haring kaken -+ haring speten -+ haringvissers -+ harmelen -+ harmony -+ harrypotterbrilletje -+ hartafdeling -+ hartfalen -+ hartfilmpje -+ hartland -+ hartonderzoek -+ hartpatiënte -+ hartspiercellen -+ hartsterfte -+ hartvorm -+ hasjhandelaar -+ hasjhandelaren -+ haut -+ haute couture -+ haute cuisine -+ havenactiviteiten -+ havenakkoord -+ havenbeleid -+ havenbesturen -+ havenbestuur -+ havenbuurt -+ havencomplex -+ havenfront -+ havengebonden -+ havengeul -+ haveninfrastructuur -+ haveninstallaties -+ havenkantoor -+ havenontvangstinstallatie -+ havenontvangstinstallaties -+ havenpersoneel -+ havenpool -+ havenproject -+ havenprojecten -+ havensector -+ haventarieven -+ haventerrein -+ haventerreinen -+ havenuitbreiding -+ havenwerknemers -+ havo-vwo -+ hbo-diploma -+ hbo-raad -+ hbo-studie -+ hbo-v -+ hbo-verpleegkunde -+ hbs -+ headliner -+ heao-student -+ heavymetalband -+ heden ten dage -+ hedging -+ heemkundekring -+ heengetild -+ heengezet -+ heenkijkt -+ heenwerken -+ heenzending -+ heenzendingen -+ heenzetten -+ heer des huizes -+ hefboomfonds -+ hefboomfondsen -+ heffingensysteem -+ heffingsrente -+ heffingstarief -+ heg noch steg -+ heid -+ heidegebied -+ heidegebieden -+ heilig verklaard -+ heiligenverering -+ heiwerkzaamheden -+ heksenvervolgingen -+ heldenstatus -+ heldenverhaal -+ heldergroen -+ helderheidsverloop -+ helderste -+ helemáál -+ helgekleurde -+ helikopterbasis -+ helikopterongeluk -+ helikopterplatform -+ helikoptervlucht -+ helikoptervluchten -+ heliumballon -+ heliumgas -+ helpe -+ hematocriet -+ hematocrietwaarde -+ hemochromatose -+ hendrik -+ hendriken -+ hennepkwekerij -+ hennepkwekerijen -+ hennepkwekers -+ henry -+ heraanleg -+ herbekijken -+ herbevoorrading -+ herbezet -+ herbronnen -+ hercontrole -+ hercontroles -+ herdenkingsboek -+ herdenkingscentrum -+ herdenkingsconcert -+ herdenkingsmonument -+ herdenkingsmunten -+ herdenkingsplaat -+ herdenkingsplaquette -+ herdenkingstentoonstelling -+ herderskinderen -+ herenleed -+ herevaluatie -+ herfinancieringsrente -+ herfstseizoen -+ herhaalbaarheid -+ herijkingsnota -+ herijkingsoperatie -+ herindelingsplan -+ herindelingsplannen -+ herindelingsprocedure -+ herindelingsvoorstel -+ herindelingsvoorstellen -+ herintreedster -+ herintreedsters -+ herkenner -+ herkomstbenaming -+ herlocatie -+ hernationalisering -+ hernummering -+ herontwikkeling -+ heropgestart -+ heropleven -+ heropstanding -+ heropstart -+ heropstarten -+ heroptreden -+ herorganiseren -+ heroriënteringsgesprekken -+ heroïne-experiment -+ heroïneprostituees -+ heroïneverstrekking -+ herpesvirus -+ herplant -+ herplanten -+ herplantplicht -+ herpositioneren -+ herschatting -+ herschrijfbare -+ hersenbarrière -+ hersencapaciteit -+ hersenchirurg -+ hersenchirurgie -+ hersengolven -+ hersenkanker -+ hersenkneuzing -+ hersenkracht -+ hersenkraker -+ hersenmassa -+ hersenoperatie -+ hersenscan -+ hersenschade -+ hersenvocht -+ hersenzones -+ herstart -+ herstelbemiddeling -+ herstelkansen -+ herstelmaatregelen -+ herstelpotentieel -+ herstelproces -+ herstelrecht -+ hersteltijd -+ hersteltrainer -+ herstraten -+ herstructureringslasten -+ herstructureringsmaatregelen -+ herstructureringsprogramma -+ herstructureringswet -+ hertekend -+ hertekende -+ hertekenen -+ hertekening -+ hertog van Alva -+ heruitvinden -+ herverkiesbaar -+ herverkiezen -+ herverkozen -+ hervertelling -+ hervestigen -+ hervormingsbeleid -+ hervormingsgezinden -+ hervormingsgezindheid -+ hervormingskoers -+ hervormingsproces -+ hervormingsproject -+ hervormingsvoorstel -+ hervulbare -+ herwerking -+ het Bildt -+ het Breezand -+ het is menens -+ heteromannen -+ heupblessure -+ heupdysplasie -+ heupfracturen -+ heupklachten -+ heuptasje -+ hg -+ hielprik -+ hieperdepiep -+ hiervóór -+ high society -+ high-end -+ highteade -+ highteaden -+ highteaën -+ hightechsector -+ hijsinstallatie -+ hinderwetvergunningen -+ hindoe-nationalisten -+ hiphopband -+ hiphopbeat -+ hiphopgroep -+ hiphopnummer -+ hiphopnummers -+ hiphopplaten -+ hiphopscene -+ hiphopwereld -+ hippietijd -+ hippique -+ hitfabriek -+ hitfilm -+ hitlist -+ hitmachine -+ hitmusical -+ hitnotering -+ hitpotentie -+ hitsen -+ hitsucces -+ hiv-besmetting -+ hiv-besmettingen -+ hiv-patiënten -+ hiv-test -+ hiv-tests -+ hivbesmettingen -+ hivpatiënten -+ hivtest -+ hivtests -+ hl -+ hobbyboer -+ hobbyboeren -+ hobbydieren -+ hobbykoks -+ hocbasis -+ hocbeleid -+ hocbeslissing -+ hocbeslissingen -+ hockeybondscoach -+ hockeycarrière -+ hockeycoach -+ hockeycompetitie -+ hockeyfederatie -+ hockeyfinale -+ hockeyinternational -+ hockeyloopbaan -+ hockeyteam -+ hockeyvereniging -+ hockeyvrouwen -+ hocus -+ hoevetoerisme -+ hoevéél -+ hofcultuur -+ hoffotograaf -+ hofjacht -+ hofpersoneel -+ hofschilder -+ hoger-onderwijsinstellingen -+ hogergeplaatsten -+ hogergeschoolden -+ hogeropgeleide -+ hogesnelheidsnet -+ hokjesdenken -+ hold -+ holdingmaatschappij -+ holdingstructuur -+ hollandaisesaus -+ holocaustmuseum -+ homepagina -+ homevideo -+ homevideo's -+ homo australopithecus -+ homo erectus -+ homo habilis -+ homo sapiens -+ homo universalis -+ homojongeren -+ homomonument -+ homoparade -+ homorelatie -+ homorelaties -+ homostel -+ homovijandige -+ homowereld -+ hondenclub -+ hondeneigenaren -+ hondengeblaf -+ hondenkennel -+ hondenslee -+ hondenuitlaatplaats -+ honderddertig -+ honderdnegentig -+ honderdsten -+ honderdtachtig -+ honderdtien -+ honderdtwintig -+ honderdtwintigduizend -+ honderdveertig -+ honderdveertigduizend -+ honderdvijfentwintig -+ honderdvijftien -+ honderdvijftigduizend -+ honderdzestig -+ honderdzeventig -+ hongerbuikje -+ hongerprobleem -+ honkbalcoach -+ honkbalploeg -+ honkbalseizoen -+ honkbalteam -+ honkbalveld -+ honkbalwereld -+ honoris causa -+ hoofdaanklaagster -+ hoofdaannemers -+ hoofdacteur -+ hoofdadvocaat -+ hoofdadvocaat-generaal -+ hoofdanalist -+ hoofdarchitectuur -+ hoofdargument -+ hoofdattractie -+ hoofdbaan -+ hoofdbedoeling -+ hoofdbestuurslid -+ hoofdbewaker -+ hoofdbezigheid -+ hoofdbezwaar -+ hoofdboekhouder -+ hoofdcategorie -+ hoofdcategorieën -+ hoofdcoach -+ hoofdcommentaar -+ hoofdconservator -+ hoofdconstructeur -+ hoofddirecteur -+ hoofddocument -+ hoofdeconoom -+ hoofdeiland -+ hoofdelementen -+ hoofdfonds -+ hoofdfondsen -+ hoofdgast -+ hoofdgetuige -+ hoofdhuis -+ hoofdindex -+ hoofdingenieur-directeur -+ hoofdinkomen -+ hoofditem -+ hoofdjournaal -+ hoofdkern -+ hoofdklasser -+ hoofdklemtoon -+ hoofdleverancier -+ hoofdlijnennotitie -+ hoofdlocatie -+ hoofdloze -+ hoofdnet -+ hoofdnummer -+ hoofdonderhandelaar -+ hoofdonderzoeker -+ hoofdontwerper -+ hoofdopdracht -+ hoofdorgel -+ hoofdpodium -+ hoofdpoort -+ hoofdproblemen -+ hoofdproduct -+ hoofdredacteur-directeur -+ hoofdredacteurschap -+ hoofdreden -+ hoofdredenen -+ hoofdrijbaan -+ hoofdriool -+ hoofdroute -+ hoofdrubrieken -+ hoofdscheidsrechter -+ hoofdscherm -+ hoofdscout -+ hoofdstroming -+ hoofdstromingen -+ hoofdstuknummer -+ hoofdstuknummering -+ hoofdtoernooi -+ hoofdtrainer -+ hoofdtribune -+ hoofduitvoerder -+ hoofdvakdocent -+ hoofdverantwoordelijk -+ hoofdverantwoordelijke -+ hoofdverantwoordelijkheid -+ hoofdverblijf -+ hoofdverblijfplaats -+ hoofdverhaal -+ hoofdverkeersader -+ hoofdverzekerde -+ hoofdvestigingen -+ hoofdvoedsel -+ hoofdvogel -+ hoofdvoorstelling -+ hoofdvoorstellingen -+ hoofdwegennet -+ hoofdwoning -+ hoogbegaafdheid -+ hoogdrempelig -+ hoogdrempelige -+ hoogenergetisch -+ hoogenergetische -+ hooggegrepen -+ hooggeleerden -+ hooggeplaatsten -+ hooggespecialiseerde -+ hoogglanzend -+ hoogglanzende -+ hoogleraarschappen -+ hoogrenderende -+ hoogspanningslijn -+ hoogspanningslijnen -+ hoogstgelegen -+ hoogstverantwoordelijke -+ hoogverrijkt -+ hoogwaterbescherming -+ hoogwatergolf -+ hoogwaterkering -+ hooibalen -+ hoorspelacteur -+ hopeloosheid -+ hopscheuten -+ horeca-activiteiten -+ horecabazen -+ horecabeheer -+ horecabeleid -+ horecabestemming -+ horecabeurs -+ horecabezoekers -+ horecabond -+ horecaboot -+ horecabranche -+ horecafaciliteiten -+ horecafunctie -+ horecagebied -+ horecagedeelte -+ horecagroothandel -+ horecamedewerkers -+ horecaondernemer -+ horecapanden -+ horecaprijzen -+ horecavereniging -+ horecavergunning -+ horecavoorziening -+ horecavoorzieningen -+ horecawet -+ horenden -+ horizontalisering -+ horlogemerk -+ hormonengebruik -+ hormoongebruik -+ hormoonontregelaars -+ hormoonstimulatie -+ hormoonverstorend -+ hormoonverstorende -+ hormoonvrij -+ horrorkomedie -+ hospitalisering -+ hostellerie -+ hosting -+ hotelarrangementen -+ hotelboekingen -+ hotelbusiness -+ hoteldirecteur -+ hoteleigenaar -+ hoteleigenaren -+ hotelindustrie -+ hotelmanagement -+ hotelovernachting -+ hotelverblijf -+ hotelwezen -+ houdbaarheidstermijn -+ houderij -+ hour -+ house-dj -+ houtbedrijf -+ houtbedrijven -+ houtbewerkingsmachines -+ houtbond -+ houtkrullen -+ houtlagering -+ houtproducenten -+ houtproducten -+ houtsculpturen -+ houtsector -+ houtsingel -+ houtskeletbouw -+ houtskoolschets -+ houtvoorraad -+ hoveniersbedrijf -+ hr -+ hsl-oost -+ https -+ hubertusbrood -+ hufterigheid -+ huidafwijkingen -+ huidbleekmiddelen -+ huidklachten -+ huidtherapie -+ huidverzorgingsproducten -+ huidweefsel -+ huilbaby -+ huis aan huis -+ huis van Oranje -+ huis van Oranje-Nassau -+ huis van Saksen-Coburg -+ huisadvocaat -+ huisartsbezoek -+ huisartsenhulp -+ huisartsenpost -+ huisartsentekort -+ huisartsenvak -+ huisartsenvereniging -+ huisartsenzorg -+ huisartsgeneeskunde -+ huisband -+ huisbezitters -+ huisdrukkerij -+ huisgezelschap -+ huishond -+ huishoudartikelen -+ huishoudlinnen -+ huishoudproducten -+ huishoudtextiel -+ huishoudwater -+ huiskamerrestaurant -+ huiskamersfeer -+ huisleverancier -+ huisschrijver -+ huisteelt -+ huistheater -+ huisvestingscomplex -+ huisvestingsmogelijkheden -+ huisvestingsplan -+ huisvestingsproblematiek -+ huisvestingsprojecten -+ huisvestingsverordening -+ huisvuilbelasting -+ huisvuilinzameling -+ huisvuilophaling -+ huiswerkopdracht -+ huiswerkopdrachten -+ huizenbestand -+ huizenbezitter -+ huizenbezitters -+ huizenjacht -+ huizenkopers -+ huizenprijs -+ huizenverkopen -+ hulpaanbod -+ hulpbedrag -+ hulpbeleid -+ hulpbudget -+ hulpgeld -+ hulpgelden -+ hulpgevers -+ hulphond -+ hulpinspanningen -+ hulpinstantie -+ hulpinstelling -+ hulpinstellingen -+ hulpkonvooi -+ hulpmaatregelen -+ hulpontvangende -+ hulpoperatie -+ hulpplan -+ hulpploegen -+ hulpregel -+ hulpsheriff -+ hulpstroom -+ hulpteam -+ hulpverlenersjargon -+ hulpverleningscircuit -+ hulpverleningsdiensten -+ hulpverleningsvoertuig -+ hulpverleningsvoertuigen -+ hulpverleningswerkzaamheden -+ hulpverzoek -+ hulpverzoeken -+ hulpvlucht -+ hulpvluchten -+ hulpzendingen -+ hulpzoekenden -+ humaine -+ human -+ humanere -+ humorvol -+ humorvolle -+ huns weegs -+ hunzelf -+ hutongs -+ huuraanbod -+ huurappartementen -+ huurbaas -+ huurbasis -+ huurdersorganisatie -+ huurdersorganisaties -+ huurdersraad -+ huurdersraden -+ huurgeld -+ huurinkomsten -+ huurlijn -+ huurmarkt -+ huurmoordenares -+ huursector -+ huursubsidieregeling -+ huursubsidiewet -+ huurtarieven -+ huurteams -+ huurvoorwaarden -+ huurwaarborg -+ huwelijksceremonie -+ huwelijksdatum -+ huwelijkskandidate -+ huwelijkspolitiek -+ huwelijksquotiënt -+ huwelijksrelatie -+ huwelijksstelsel -+ huwelijksvermogensstelsel -+ huwelijkswet -+ hydro -+ hygiëne-eisen -+ hygiënecode -+ hygiënemaatregelen -+ hygiëneregels -+ hygiënevoorschriften -+ hypercholesterolemie -+ hyperintelligente -+ hyperkinetische -+ hypermacht -+ hypermarktketen -+ hypertekst -+ hypotheekaanbieders -+ hypotheekadvies -+ hypotheekadviseurs -+ hypotheekaftrek -+ hypotheekbemiddelaars -+ hypotheekconstructie -+ hypotheekfraude -+ hypotheekgarantie -+ hypotheekgegevens -+ hypotheeklast -+ hypotheekportefeuille -+ hypotheekverstrekking -+ hypotheekvormen -+ héle -+ híer -+ hóe -+ hóeven -+ i'tjes -+ i.c. -+ i.e. -+ i.h.a. -+ i.h.b. -+ i.m. -+ i.o. -+ i.o.v. -+ i.p.v. -+ i.s.m. -+ i.t.t. -+ i.v.m. -+ i.z.g.st. -+ ibuprofen -+ ict -+ ict-bedrijven -+ id -+ ideale gaswet -+ ideeënvorming -+ identificatiemogelijkheden -+ identificatieteam -+ identiteitscontrole -+ identiteitsdocumenten -+ identiteitsfraude -+ identiteitsgegevens -+ identiteitsgevoel -+ identiteitsgevoelige -+ identiteitspapieren -+ identiteitsprobleem -+ identiteitsproblemen -+ identiteitsvorming -+ idiot -+ idiot savant -+ iedereens -+ iederéén -+ ietsiepietsie -+ ijleffect -+ ijling -+ ijsdagen -+ ijsdwergen -+ ijsfabriek -+ ijsfabrikant -+ ijshockeyteam -+ ijskanaal -+ ijskernen -+ ijskonijn -+ ijskorst -+ ijsman -+ ijsmassa -+ ijsmassa's -+ ijsmerk -+ ijspaleis -+ ijspiste -+ ijspriem -+ ijssculpturen -+ ijsshow -+ ijsshows -+ ijssoorten -+ ijsvereniging -+ ijsverenigingen -+ ijswolken -+ ijzergebrek -+ ijzergehalte -+ ijzerwarenwinkel -+ ik-cultuur -+ ik-heid -+ ik-verteller -+ ik-zuchtiger -+ ik-zuchtigere -+ ik-zuchtigst -+ ik-zuchtigste -+ il -+ illegalenbeleid -+ illegalenregeling -+ imagobeschadiging -+ imagocampagne -+ imagocampagnes -+ imagoschade -+ imagoverandering -+ imagoverlies -+ imagovorming -+ imamopleiding -+ imitatiedrang -+ imitatiegedrag -+ immigrantengezin -+ immigrantenpartij -+ immigrantenzoon -+ immigratiebeleid -+ immigratiedebat -+ immigratiegolf -+ immigratieprobleem -+ immigratieregels -+ immigratiesamenleving -+ immigratievraagstuk -+ immigratiewetgeving -+ immobilisatie -+ immobiliën -+ immobiliënsector -+ immunotherapie -+ immuunziekte -+ impeachmentprocedure -+ implementatiemacht -+ implementatiepartner -+ implementatiepartners -+ importbarrières -+ importbelasting -+ importbeperkende -+ importbeperking -+ importbeperkingen -+ importcapaciteit -+ importcontracten -+ importgoederen -+ importlanden -+ importprijzen -+ importquota -+ importregime -+ importstroom -+ importsubstitutie -+ importtarief -+ importtarieven -+ importverbod -+ improvisatietheater -+ in casu -+ in concreto -+ in de lorum -+ in defensiekringen -+ in den beginne -+ in den lande -+ in den vreemde -+ in dier voege -+ in dubio -+ in duplo -+ in dusverre -+ in een mum van tijd -+ in extremis -+ in feite -+ in gebreke -+ in gebruik nemen -+ in gebruik stellen -+ in godsnaam -+ in groten getale -+ in hemelsnaam -+ in het zweet zijns aanschijns -+ in modekringen -+ in natura -+ in optima forma -+ in petto -+ in spe -+ in stand gehouden -+ in stand houden -+ in stand houdend -+ in stand houdende -+ in studentenkringen -+ in vivo -+ in voege -+ in vredesnaam -+ in werking treden -+ in zoverre -+ inauguratierede -+ inboedelschade -+ inboedelverzekeringen -+ inbraakrisico -+ inbraakwerend -+ inbreiding -+ inbreidingslocaties -+ inburgeringsbeleid -+ inburgeringsplicht -+ inburgeringsproces -+ incassobeleid -+ incestverleden -+ incidentenpolitiek -+ incidentrijke -+ incl. -+ incognita -+ incontinentieluiers -+ inculturatie -+ inden -+ indexfonds -+ indexfondsen -+ indexitem -+ indexpagina -+ indexstijging -+ indianenbevolking -+ indianenwet -+ indicatiecommissie -+ indicatiecommissies -+ indicatieorgaan -+ indium -+ individuelen -+ indoor -+ indoortoernooi -+ industriebouw -+ industrieconcern -+ industrieconcerns -+ industrieconglomeraat -+ industriegebouwen -+ industriegrond -+ industriestaat -+ industriestaten -+ industriewater -+ industriezand -+ ineenvloeien -+ inentingsprogramma -+ infanteriebrigade -+ infectiepreventie -+ infiltratieteam -+ inflatiedaling -+ inflatiedoelstelling -+ inflatiedruk -+ inflatiepeil -+ inflatiepercentage -+ inflatiepercentages -+ inflatierisico -+ inflatiestijging -+ inflatietempo -+ inflatieverschillen -+ inflatieverwachting -+ inflatieverwachtingen -+ influenzavirus -+ infobord -+ infographic -+ infonummer -+ infopakket -+ informaticabedrijf -+ informaticabedrijven -+ informaticadiensten -+ informaticadochter -+ informaticagroep -+ informaticarecht -+ informaticasector -+ informaticastudent -+ informaticasysteem -+ informatie-infrastructuur -+ informatieaanbod -+ informatieachterstand -+ informatiebeheer -+ informatieberoep -+ informatieberoepen -+ informatiebestanden -+ informatiebeveiliging -+ informatiebijeenkomst -+ informatiecampagne -+ informatiecampagnes -+ informatieconcern -+ informatiegaring -+ informatiegids -+ informatiehonger -+ informatiekantoor -+ informatieleverancier -+ informatiemakelaar -+ informatiemanagement -+ informatiemap -+ informatiemiddag -+ informatienummers -+ informatiepakketten -+ informatiepaneel -+ informatiepanelen -+ informatiepositie -+ informatieproduct -+ informatieproducten -+ informatieprogramma's -+ informatiepunt -+ informatiepunten -+ informatierevolutie -+ informatieronde -+ informatiesamenleving -+ informatiesector -+ informatiesessie -+ informatiesessies -+ informatiesnelwegen -+ informatiestand -+ informatiestands -+ informatietechnologen -+ informatietelefoon -+ informatievergadering -+ informatieverschaffing -+ informatieverzameling -+ informatievoorsprong -+ informatievrijheid -+ informatiezuil -+ informatiezuilen -+ information -+ informule -+ infraheffing -+ infrastructuurfonds -+ infrastructuurkosten -+ infrastructuurwerken -+ infuusvloeistof -+ ingangspartij -+ ingangspoort -+ ingebruikname -+ ingekaderde -+ ingekohierd -+ ingelepeld -+ ingenieur-architect -+ ingenomen met -+ ingenomen tegen -+ ingeprezen -+ ingescand -+ ingesleept -+ ingesukkeld -+ ingezetenenomslag -+ inging -+ inhaalactie -+ inhaalbeweging -+ inhaaleffect -+ inhaalprogramma -+ inhaalrace -+ inhaalslag -+ inhameren -+ inhoudsvolle -+ inkijkoperatie -+ inkijkoperaties -+ inknippen -+ inkomensachteruitgang -+ inkomensbescherming -+ inkomensbestanddelen -+ inkomensbron -+ inkomensbronnen -+ inkomenscategorieën -+ inkomenscompensatie -+ inkomenseffect -+ inkomenseis -+ inkomenseisen -+ inkomensgebouw -+ inkomensgevolgen -+ inkomensgroei -+ inkomenskloof -+ inkomensmatiging -+ inkomensniveau -+ inkomensonafhankelijke -+ inkomensondersteunende -+ inkomensondersteuning -+ inkomensongelijkheid -+ inkomensontwikkeling -+ inkomensoverdracht -+ inkomensoverdrachten -+ inkomensregeling -+ inkomensreparatie -+ inkomensschade -+ inkomensschijf -+ inkomenssituatie -+ inkomenssolidariteit -+ inkomenssteun -+ inkomensstroom -+ inkomenssubsidies -+ inkomenstekort -+ inkomenstoeslagen -+ inkomensverbetering -+ inkomensverbeteringen -+ inkomensverhoudingen -+ inkomenszekerheid -+ inkomhal -+ inkomstenbriefje -+ inkomstendaling -+ inkomstenjaar -+ inkomstenkant -+ inkomstenmeevaller -+ inkomstenmeevallers -+ inkomstenpost -+ inkoopkortingen -+ inkoopkosten -+ inkoopkracht -+ inkoopmacht -+ inkoopmanagersindex -+ inkoopprogramma -+ inkoopvoordelen -+ inkttekeningen -+ inlegboekje -+ inlener -+ inleveractie -+ inlichtingenbronnen -+ inlichtingenchef -+ inlichtingenwerk -+ inline -+ inloggegevens -+ inlogt -+ inloopavond -+ inloopperiode -+ inningskosten -+ innovatiecentra -+ innovatiecentrum -+ innovatiekracht -+ innovatieprijs -+ innovatievermogen -+ innovator -+ innovators -+ inprijs -+ inregelen -+ inrichtingselement -+ inrichtingselementen -+ inrichtingsproject -+ inrichtingsprojecten -+ inrijverbod -+ inroeien -+ inroostering -+ ins en outs -+ inscannen -+ inschakelbare -+ inschattingsvermogen -+ inschrijfdatum -+ inschrijfduur -+ inschrijfkosten -+ inschrijvingsduur -+ inschrijvingsprijs -+ inschrijvingsprocedure -+ insectenplagen -+ insectensoorten -+ insekticiden -+ inserviceonderwijs -+ inside -+ inside-informatie -+ inslaand -+ inslaande -+ inslagbekken -+ inslagbekkens -+ inslaggebied -+ inspanningsastma -+ inspectierapport -+ inspectierapporten -+ inspectiesysteem -+ inspectiesystemen -+ inspectieteam -+ inspectieteams -+ inspelende -+ inspraakbijeenkomst -+ inspraakmogelijkheden -+ inspraakreactie -+ inspraakreacties -+ inspraakrecht -+ inspraakronde -+ inspraakrondes -+ inspraaktermijn -+ inspringing -+ inspringingen -+ installatiebestand -+ installatiebestanden -+ installatiebranche -+ installatietechnisch -+ installatietechnische -+ instandhoudingsverklaring -+ instandhoudingsverklaringen -+ instapdrempel -+ instapkosten -+ instapmodel -+ instapmoment -+ instapprijs -+ instapversie -+ institutionelen -+ instroomcijfers -+ instructiefilm -+ instrumentenbouwer -+ insulineproductie -+ integratiebedrijf -+ integratiedebat -+ integratiegedachte -+ integratiegedeelte -+ integratiekosten -+ integratiemodel -+ integriteitsbeleid -+ integriteitsonderzoek -+ intekenperiode -+ intellectualis -+ intensive care -+ intensivisten -+ inter -+ interconnectie -+ interconnectietarieven -+ intercooler -+ interestaftrek -+ interferentiepatroon -+ interferometer -+ intergenerationele -+ intergouvermentele -+ interieurbekleding -+ interieurdesign -+ interieurfoto's -+ interieurruimte -+ interieurstukken -+ interieurtextiel -+ interim-bestuurders -+ interim-bondscoach -+ interim-burgemeester -+ interim-coach -+ interim-directeur -+ interim-directie -+ interim-grondwet -+ interim-management -+ interim-parlement -+ interim-periode -+ interim-premier -+ interim-president -+ interim-trainer -+ interim-voorzitter -+ interim-wet -+ interimarbeid -+ interimsector -+ interlandverplichtingen -+ interlandvoetbal -+ interlocuteur -+ intermodaal -+ internaut -+ internauten -+ internet-tv -+ internetaanbieder -+ internetaandeel -+ internetaandelen -+ internetaankopen -+ internetachtige -+ internetactiviteiten -+ internetadres -+ internetadressen -+ internetambitie -+ internetavontuur -+ internetbank -+ internetbedrijf -+ internetbetaling -+ internetbeveiliger -+ internetbeveiliging -+ internetbezoekers -+ internetboekhandel -+ internetboekhandels -+ internetbranche -+ internetbroker -+ internetbrowser -+ internetbureau -+ internetcommunicatie -+ internetcomputer -+ internetdivisie -+ internetdochter -+ interneteconomie -+ internetfaciliteiten -+ internetfonds -+ internetgebied -+ internetgebruik -+ internetgemeenschap -+ internetgeneratie -+ internetgerelateerde -+ internetgoeroe -+ internetgroep -+ internethandel -+ internethype -+ internetindustrie -+ internetinfrastructuur -+ internetinitiatieven -+ internetinvesteringen -+ internetjournalist -+ internetjournalistiek -+ internetklanten -+ internetkrant -+ internetkunst -+ internetlocatie -+ internetmagazine -+ internetmarkt -+ internetmuziek -+ internetnamen -+ internetnieuws -+ internetondernemer -+ internetondernemers -+ internetonderneming -+ internetpagina -+ internetpionier -+ internetpioniers -+ internetplannen -+ internetplatform -+ internetpoot -+ internetportaal -+ internetproducten -+ internetproject -+ internetprotocol -+ internetradio -+ internetreclame -+ internetrevolutie -+ internetsector -+ internetsites -+ internetsoftware -+ internetspel -+ internetspelers -+ internetstrategie -+ internetsurfers -+ internettaal -+ internettarieven -+ internettechnologie -+ internettelefonie -+ internettelefoon -+ internettelefoons -+ internettijdperk -+ internettoepassingen -+ internettransacties -+ internetveiling -+ internetverbindingen -+ internetverkoop -+ internetverkopen -+ internetversie -+ internetverslaving -+ internetwereld -+ internetwinkel -+ internetwinkels -+ internetzeepbel -+ internetzoekmachine -+ interoperabel -+ interoperabele -+ interprofessioneel -+ interprofessionele -+ interventiebeginsel -+ interventiepolitiek -+ interviewboek -+ interviewprogramma -+ interviewserie -+ intikker -+ intra -+ intreders -+ intrestaftrek -+ intrestvoet -+ intrestvoeten -+ intrigerender -+ introductiedag -+ introductiedatum -+ introductieperiode -+ introductieweek -+ introductieweken -+ intuïtionisme -+ invalidenparkeerplaats -+ invaliditeitsverzekering -+ invalwerk -+ invasieplannen -+ invasieve -+ inventariswaarde -+ investeringsalternatief -+ investeringsalternatieven -+ investeringsbedrag -+ investeringsbedragen -+ investeringsbedrijf -+ investeringsbedrijven -+ investeringsbereidheid -+ investeringsbeslissing -+ investeringsbudget -+ investeringscriteria -+ investeringscriterium -+ investeringsdossiers -+ investeringsfirma -+ investeringsgedrag -+ investeringsgeld -+ investeringsgelden -+ investeringsgoederen -+ investeringsgroep -+ investeringsimpuls -+ investeringskapitaal -+ investeringsland -+ investeringslasten -+ investeringsmanager -+ investeringsmiddelen -+ investeringsmogelijkheden -+ investeringsniveau -+ investeringspeil -+ investeringsportefeuille -+ investeringsregeling -+ investeringsregels -+ investeringsritme -+ investeringssom -+ investeringssteun -+ investeringsstop -+ investeringsstrategie -+ investeringsstromen -+ investeringsstroom -+ investeringsuitgaven -+ investeringsvehikel -+ investeringsvolume -+ invoegbedrijf -+ invoeringskosten -+ invoeringsproblemen -+ invoerprijzen -+ invoerregeling -+ invoervak -+ invoerverbod -+ invoervergunning -+ invulflitsen -+ invulveld -+ invulvelden -+ inzamelpunt -+ inzamelpunten -+ inzamelsysteem -+ inzendtermijn -+ inzonden -+ inzoomfactor -+ inéén -+ ipso -+ iron -+ ironicus -+ irritatiefactor -+ islamkenner -+ islamofobie -+ islamwereld -+ isolatiekosten -+ isolatiewaarde -+ issuepartij -+ ivf-klinieken -+ j'tjes -+ jaar in jaar uit -+ jaar op jaar -+ jaaranalyse -+ jaaranalyses -+ jaarbedrag -+ jaarbegin -+ jaarbegroting -+ jaarcapaciteit -+ jaarcongres -+ jaarhelft -+ jaarhuur -+ jaarkoers -+ jaarlast -+ jaarlasten -+ jaaropbrengst -+ jaarplanning -+ jaarprestatie -+ jaarrapportage -+ jaarrecord -+ jaarrendement -+ jaarrond -+ jaarruimte -+ jaarstijging -+ jaarthema -+ jaartrajectkaart -+ jaarverbruik -+ jaarverlies -+ jaarverslaggeving -+ jaarvolume -+ jaarwende -+ jabotjes -+ jachtongeluk -+ jachttechnieken -+ jachtverbod -+ jagersvereniging -+ janneketaal -+ jansvlinder -+ januaridag -+ januarinummer -+ jarenoude -+ jarosiet -+ java -+ jazzbassist -+ jazzcentrum -+ jazzclub -+ jazzclubs -+ jazzcombo -+ jazzgeschiedenis -+ jazzgitaar -+ jazzgitarist -+ jazzkringen -+ jazzkwartet -+ jazzlegende -+ jazzliefhebber -+ jazzliefhebbers -+ jazzmusicus -+ jazzmuzikant -+ jazzpodia -+ jazzpubliek -+ jazzsaxofonist -+ jazzscene -+ jazzstandards -+ jazztrio -+ jazzwereld -+ jazzzanger -+ jeansbroek -+ jeanslijn -+ jeansrok -+ jetsetters -+ jeu de boules -+ jeu-de-boule -+ jeugd-tbs -+ jeugdafdelingen -+ jeugdauteur -+ jeugdbeleidsplan -+ jeugdblok -+ jeugdboekenschrijfster -+ jeugdbrandweer -+ jeugdbrigade -+ jeugdclub -+ jeugdclubs -+ jeugdcoach -+ jeugdcomplex -+ jeugdcoördinator -+ jeugdcriminelen -+ jeugdculturen -+ jeugdcultuur -+ jeugddebat -+ jeugddelinquenten -+ jeugddelinquentie -+ jeugddetentie -+ jeugddienst -+ jeugddrama -+ jeugdervaringen -+ jeugdfoto -+ jeugdfoto's -+ jeugdgeweld -+ jeugdgroep -+ jeugdhulp -+ jeugdhulpverlening -+ jeugdidolen -+ jeugdidool -+ jeugdinternational -+ jeugdkamp -+ jeugdkampen -+ jeugdmagistraten -+ jeugdopera -+ jeugdopleiding -+ jeugdopleidingen -+ jeugdparticipatie -+ jeugdprins -+ jeugdproblematiek -+ jeugdproject -+ jeugdprostitutie -+ jeugdpsychiatrie -+ jeugdreclassering -+ jeugdroman -+ jeugdromans -+ jeugdschaak -+ jeugdselectie -+ jeugdserie -+ jeugdsport -+ jeugdteam -+ jeugdteams -+ jeugdtheatergezelschappen -+ jeugdvoetbal -+ jeugdvoetballers -+ jeugdwedstrijd -+ jeugdwedstrijden -+ jeugdwereldkampioen -+ jeugdwerkplan -+ jeune -+ jihadstrijders -+ jip -+ jkvr. -+ jl. -+ jobaanbod -+ jobsite -+ jobsites -+ jobverlies -+ john -+ jollenman -+ jongenskoor -+ jongerenactiviteiten -+ jongerenbeleid -+ jongerenblad -+ jongerenbladen -+ jongerenclub -+ jongerenculturen -+ jongerencultuur -+ jongerendag -+ jongerendrama -+ jongerenfestival -+ jongerenjury -+ jongerenklassement -+ jongerenkrant -+ jongerenmagazine -+ jongerenomroep -+ jongerenpanel -+ jongerenpartij -+ jongerenpartijen -+ jongerenproblematiek -+ jongerenproject -+ jongerenzender -+ jonggehandicapten -+ jonggehandicaptenkorting -+ jonkvrouwe -+ joods-zijn -+ journaallezer -+ journalistenopleiding -+ jr. -+ jubileumbundel -+ jubileumeditie -+ jubileumjaar -+ jubileumuitzending -+ judocarrière -+ judocoach -+ judofederatie -+ judoselectie -+ judotrainer -+ julinummer -+ jumeaux -+ jumeleren -+ jumpen -+ juniorentoernooi -+ junkmail -+ juntaleden -+ jurakalk -+ jure -+ jurisdictioneel -+ juryberaad -+ jurysysteem -+ juryvoorzitter -+ just -+ just in time -+ justitieambtenaren -+ justitiedossier -+ justitiefunctionarissen -+ justitiehuizen -+ justitiemensen -+ justitieminister -+ justitiepaleis -+ justitiesamenwerking -+ juwelenroof -+ járen -+ júist -+ k'tjes -+ k.k. -+ kB -+ kHz -+ kJ -+ kaaklijn -+ kaarsenmakerij -+ kaartautomaat -+ kaartautomaten -+ kaartbeeld -+ kaartcontrole -+ kaartcontroles -+ kaartcontroleurs -+ kaartenverkoop -+ kaartjesverkoop -+ kaartmateriaal -+ kaartnummer -+ kaartnummers -+ kaartverdeling -+ kaartverkoopsysteem -+ kaasfabriek -+ kaasfabrieken -+ kaasmeisje -+ kaaspakhuis -+ kabel-tv -+ kabelaanbieder -+ kabelaanbieders -+ kabelaanbod -+ kabelaansluiting -+ kabelaansluitingen -+ kabelaar -+ kabelaars -+ kabelactiviteit -+ kabelactiviteiten -+ kabelbedrijven -+ kabelbelangen -+ kabelbranche -+ kabelconcern -+ kabeldiensten -+ kabeldistributie -+ kabeldivisie -+ kabelexploitatie -+ kabelfabrikant -+ kabelinfrastructuur -+ kabelintercommunales -+ kabellegger -+ kabellift -+ kabelmaatschappijen -+ kabelmarkt -+ kabelmodem -+ kabelmodems -+ kabelmodemtechnologie -+ kabeloperator -+ kabelplan -+ kabelsector -+ kabeltarief -+ kabeltarieven -+ kabeltram -+ kabeltrein -+ kabeltrui -+ kabelzender -+ kabelzenders -+ kabinetchef -+ kabinetsdeelname -+ kabinetsdelegatie -+ kabinetsdiscussie -+ kabinetsinformateur -+ kabinetsinformateurs -+ kabinetsmaatregelen -+ kabinetsmedewerker -+ kabinetsnota -+ kabinetsploeg -+ kabinetssecretaris -+ kabinetsstandpunt -+ kabinetsvoornemen -+ kabinetsvoornemens -+ kabinetsvoorstel -+ kabinetsvoorstellen -+ kabinetszaken -+ kabinetszittingen -+ kaderakkoord -+ kadernota -+ kaderopleiding -+ kaderovereenkomst -+ kaderprogramma -+ kaderstukje -+ kafka -+ kajakkers -+ kalashnikovs -+ kalendersysteem -+ kalkgebrek -+ kalmeringspillen -+ kalverhouderij -+ kalvermesterij -+ kalvermesterijen -+ kalversector -+ kameraanbod -+ kamerbewoning -+ kamerbureau -+ kamerbureaus -+ kamerlidmaatschap -+ kamermarkt -+ kamermuziekfestival -+ kamermuzikale -+ kamernood -+ kamerverhuur -+ kampeerboeren -+ kampeermiddelen -+ kampeervakanties -+ kampioenenbal -+ kampioensfeest -+ kampioensjaar -+ kampioensschaal -+ kamsalamander -+ kamsalamanders -+ kanaalwater -+ kanaalzone -+ kanariepiet -+ kandidaat-bewindslieden -+ kandidaat-bouwers -+ kandidaat-burgemeester -+ kandidaat-burgemeesters -+ kandidaat-commissaris -+ kandidaat-deelnemers -+ kandidaat-huurders -+ kandidaat-koper -+ kandidaat-kopers -+ kandidaat-leden -+ kandidaat-lid -+ kandidaat-lidmaatschap -+ kandidaat-lijsttrekker -+ kandidaat-minister -+ kandidaat-ministers -+ kandidaat-opvolger -+ kandidaat-opvolgers -+ kandidaat-overnemer -+ kandidaat-premier -+ kandidaat-president -+ kandidaat-raadsleden -+ kandidaat-raadslid -+ kandidaat-stad -+ kandidaat-steden -+ kandidaat-toetreders -+ kandidaat-voorzitter -+ kandidaat-voorzitters -+ kandidaat-wethouder -+ kandidaatlanden -+ kandidatencommissie -+ kandidatenmatches -+ kaneelijs -+ kangoeroevlees -+ kankerbehandeling -+ kankercentra -+ kankerfonds -+ kankermedicijn -+ kankerpatiënte -+ kankerrisico -+ kankersoorten -+ kankerspecialist -+ kankersterfte -+ kankertherapie -+ kanoroutes -+ kanovereniging -+ kansarmoede -+ kanshebster -+ kanslozen -+ kansrijken -+ kansspelbeleid -+ kansspelmarkt -+ kantonrechtersformule -+ kantoorbouw -+ kantoordirecteur -+ kantoorfuncties -+ kantoorgenoot -+ kantoorgenoten -+ kantoorhumor -+ kantoorkolossen -+ kantoormarkt -+ kantoormedewerkers -+ kantoormensen -+ kantoormuren -+ kantooroppervlak -+ kantoorpakket -+ kantoorpakketten -+ kantoorsoftware -+ kantoorstad -+ kantoortoren -+ kantoortorens -+ kantoorvilla -+ kantorengebied -+ kantorengebouw -+ kantorenmarkt -+ kantorenvoorraad -+ kapitaalaflossing -+ kapitaalaflossingen -+ kapitaalbescherming -+ kapitaalbeslag -+ kapitaalcontroles -+ kapitaaldekking -+ kapitaalinbreng -+ kapitaalinkomen -+ kapitaalinvoer -+ kapitaalkosten -+ kapitaalronde -+ kapitaalstructuur -+ kapitaalsverhoging -+ kapitaaluitgaven -+ kapitaalvennootschappen -+ kapitaalvergroting -+ kapitaalverschaffers -+ kapitaalverstrekkers -+ kapotgereden -+ kappersbranche -+ kappersketen -+ kappersopleiding -+ kappersschool -+ kapperszoon -+ kapwoning -+ kapwoningen -+ karakterstructuur -+ karakterverschillen -+ karnemelkse -+ karnemelkse pap -+ karst -+ kartelautoriteit -+ kartelautoriteiten -+ kartelbureau -+ kartelparadijs -+ kartelwaakhond -+ kartelwetgeving -+ karting -+ kartonbedrijf -+ kartrekker -+ kartuizerklooster -+ kasbeheerder -+ kasgeldbeheer -+ kaskraker -+ kaskrediet -+ kasoverschotten -+ kassalade -+ kasschuiven -+ kassenbouw -+ kassenbouwers -+ kassengebied -+ kasteelboerderij -+ kasteelmuur -+ kasteelterrein -+ kasteeltoren -+ kasteelvrouwe -+ kastelenstichting -+ kastelozen -+ kastensysteem -+ katachtigen -+ kathodische -+ katoenboeren -+ katoenvelden -+ kattenbezitters -+ kattenbrokjes -+ kattenliefhebber -+ kavelprijs -+ kavelruil -+ kazernecomplex -+ kazernepoort -+ kca -+ kcal -+ keelamandelen -+ keepersprobleem -+ keerlen -+ keigaaf -+ keizerspinguïns -+ kelderbox -+ kelderboxen -+ keldervloer -+ kelvin -+ kennisborging -+ kennisdebat -+ kennisindustrie -+ kennisinstellingen -+ kennisinstituten -+ kennisinstituut -+ kennisintensiteit -+ kenniskloof -+ kennisland -+ kennismaatschappij -+ kennismakingsronde -+ kennismakingstournee -+ kennismanagement -+ kennismanager -+ kennismanagers -+ kennisnet -+ kennisontwikkeling -+ kennissamenleving -+ kennisuitwisseling -+ kennisvoorsprong -+ kennisvragen -+ kenniswerker -+ kenniswerkers -+ kenniswijk -+ kentekenhouder -+ kentekenregister -+ keppel -+ keramiste -+ keratitis -+ kerkasiel -+ kerkbelasting -+ kerkdak -+ kerke -+ kerkfusie -+ kerkjurist -+ kerkleider -+ kerklidmaatschap -+ kerkmensen -+ kerkpolitiek -+ kerkpolitieke -+ kerktelefonie -+ kerktelefoon -+ kerkverband -+ kerkvloer -+ kermisgangers -+ kermismolen -+ kermisterrein -+ kernactiviteit -+ kernarsenaal -+ kernarsenalen -+ kernbedrijf -+ kernbeslissing -+ kernbeslissingen -+ kernboodschap -+ kerncijfers -+ kerncompetentie -+ kerncompetenties -+ kerndepartement -+ kerndoelen -+ kerndoelgroep -+ kernelement -+ kernenergieprogramma -+ kernidee -+ kernideeën -+ kerninflatie -+ kerninstallaties -+ kernland -+ kernlanden -+ kernmateriaal -+ kernnet -+ kernprogramma -+ kernredactie -+ kernstad -+ kernstopverdrag -+ kernstuk -+ kerntakendiscussie -+ kernteams -+ kerntechnologie -+ kerntemperatuur -+ kerntransplantatie -+ kerntransport -+ kerntransporten -+ kernvaardigheden -+ kernvakken -+ kernwaarden -+ kernwapenlanden -+ kernwapenprogramma -+ kernwapenstaten -+ kerosineprijs -+ kerst-cd -+ kerstbestand -+ kerstbonus -+ kerstbrood -+ kerstcircus -+ kerstdis -+ kerstfilm -+ kerstgevoel -+ kersthit -+ kerstinkopen -+ kerstkalkoen -+ kerstkindje -+ kerstmannen -+ kerstmusical -+ kerstmuts -+ kerstmuziek -+ kerstoffensief -+ kerstpost -+ kerstpreek -+ kerstrede -+ kerstshow -+ kersttafel -+ ketamine -+ ketelbouwer -+ ketenbewaking -+ ketenkaart -+ ketenvorming -+ ketterplakkaten -+ keukenapparatuur -+ keukenchef -+ keukeninrichting -+ keukenla -+ keukenprins -+ keukenschort -+ keuringsinstantie -+ keuringsinstanties -+ keuringsinstituut -+ keuringspraktijk -+ keuringsregels -+ keuringsstation -+ keuringsstations -+ keuringssysteem -+ keuze-uren -+ keuze-uur -+ keuzegids -+ keuzeprobleem -+ keuzeproces -+ keuzeprocessen -+ keuzevakje -+ kiemgetal -+ kiemgroente -+ kiemgroenten -+ kiemplasma -+ kiemtemperatuur -+ kienavonden -+ kiesbureau -+ kiescampagne -+ kiescommissie -+ kiesgedrag -+ kieslijst -+ kieslokaal -+ kiesvolk -+ kievitsbloem -+ kiezersgroep -+ kiezersgroepen -+ kiezersgunst -+ kiezersmandaat -+ kiezersmarkt -+ kiezersonderzoek -+ kiezersonderzoeken -+ kiezerspotentieel -+ kiezersregistratie -+ kiezersuitspraak -+ kijkcijfersucces -+ kijkersaantal -+ kijkhoek -+ kijkplezier -+ kijktijd -+ kijkwijzer -+ kilo-ohm -+ kilobit -+ kilobits -+ kilometeradministratie -+ kilometerheffing -+ kilometerpunt -+ kilometerslang -+ kilometerslange -+ kilometertarief -+ kilometerzone -+ kinderactiviteiten -+ kinderanimatie -+ kinderattracties -+ kinderboekenauteur -+ kinderboekenserie -+ kinderburcht -+ kindercentra -+ kindercentrum -+ kindercollectie -+ kinderconcert -+ kinderconcerten -+ kindercrèche -+ kindercrèches -+ kinderdagopvang -+ kinderdisco -+ kinderfantasie -+ kinderfeestje -+ kinderfilm -+ kinderfilmfestival -+ kindergedichten -+ kinderhandel -+ kinderhoekje -+ kinderhulporganisatie -+ kinderjury -+ kinderleven -+ kinderlevens -+ kinderlichaam -+ kinderlijn -+ kinderlozen -+ kindermarkt -+ kindermiddag -+ kindermisbruik -+ kindermuseum -+ kindermusical -+ kinderneuroloog -+ kindernevendienst -+ kinderombudsman -+ kinderoncologie -+ kinderoptocht -+ kinderpagina -+ kinderpartijtje -+ kinderpornografische -+ kinderpornozaak -+ kinderpsychiatrie -+ kinderpsychologe -+ kinderrechtenfestival -+ kinderreclame -+ kinderschare -+ kindersekstoerisme -+ kindershow -+ kinderslavernij -+ kindersmokkel -+ kindertelevisie -+ kindertheater -+ kindertop -+ kindervakantiewerk -+ kindervingers -+ kindervoeten -+ kinderzaken -+ kinderzender -+ kinderziel -+ kindonvriendelijke -+ kindrelatie -+ kinds zijn -+ kindslaven -+ kindsoldaat -+ kindzorg -+ kinkhoestvaccin -+ kipgerecht -+ kippenbedrijf -+ kippenbedrijven -+ kippenboerderij -+ kippencrisis -+ kippenhouder -+ kippenhouderij -+ kippenhouders -+ kippenveren -+ kippenvet -+ kipsaté -+ klaargerecht -+ klaarhebben -+ klaarmaaltijd -+ klachtenbrief -+ klachtenformulier -+ klachtenfunctionaris -+ klachtengeld -+ klachtenlijst -+ klachtenloket -+ klachtennummer -+ klachtenprocedures -+ klachtenstroom -+ klachtenvrij -+ klachtvereiste -+ klamaai-ijzer -+ klamaai-ijzers -+ klankbordgroep -+ klankbordgroepen -+ klankgedichten -+ klanklandschappen -+ klankreeks -+ klankschalen -+ klankvelden -+ klankwereld -+ klantenbasis -+ klantengegevens -+ klantengroep -+ klantengroepen -+ klantenpanels -+ klantenportefeuille -+ klantenraad -+ klantenrelaties -+ klantentevredenheid -+ klantentrouw -+ klantenverlies -+ klantgegevens -+ klantgerichter -+ klantinformatie -+ klantonvriendelijk -+ klantonvriendelijke -+ klantspecifieke -+ klanttevredenheid -+ klantvriendelijkheid -+ klapbessenstruik -+ klapmechanisme -+ klassenassistenten -+ klassengrootte -+ klassenindeling -+ klassenverkleining -+ klassiekerkoning -+ klauwzeercrisis -+ klauwzeerepidemie -+ klauwzeervirus -+ klaveciniste -+ klaverendrie -+ klavierwerken -+ kledingcode -+ kledingfabrikant -+ kledinginzameling -+ kledingketen -+ kledingketens -+ kledingkeuze -+ kledinglijn -+ kledingmerk -+ kledingmerken -+ kledingontwerpen -+ kledingpakket -+ kledingregels -+ kledingrekken -+ kledingsector -+ kledingsstuk -+ kledingstijl -+ kledingverkoop -+ kledingverkoper -+ kledingvoorschrift -+ kleedhok -+ kleedruimten -+ kleiduivenschutter -+ klein houden -+ kleinbloemig -+ kleinbloemige -+ kleinburgerlijkheid -+ kleinstedelijke -+ kleinverbruikersheffing -+ kleinwild -+ kleisoort -+ kleiwinning -+ klembord -+ kleptocratie -+ kletsende -+ kleurbalans -+ kleurbanen -+ kleurcorrectie -+ kleurcorrecties -+ kleureffecten -+ kleurenmagazine -+ kleurenprinter -+ kleurenverloop -+ kleurgebruik -+ kleurkeuze -+ kleurprincipes -+ kleuterboekje -+ kleuterboekjes -+ kleutergroep -+ kleutergroepen -+ klikfonds -+ klikfondsen -+ kliklijn -+ kliko's -+ klimaatafspraken -+ klimaatakkoord -+ klimaatbeleid -+ klimaatcommissie -+ klimaatdeskundigen -+ klimaatnota -+ klimaatonderzoek -+ klimaatoverleg -+ klimaatprobleem -+ klimaatproblemen -+ klimaatsysteem -+ klimgeit -+ klimhal -+ klimhallen -+ klimmend -+ klimmende -+ klimrots -+ klimsport -+ klimtalent -+ klimtoestellen -+ klimwand -+ klimwanden -+ klimwerk -+ klinkerbestrating -+ klinkerbotsing -+ klokkijken -+ kloosterboek -+ kloostercomplex -+ kloostergebouw -+ kloosteromgeving -+ kluisruimte -+ klusjesdienst -+ kmo -+ kmo'er -+ kmo's -+ kmo-markt -+ kmo-zone -+ knaagkever -+ knalblauwe -+ knalgroene -+ knaloranje -+ knalvuurwerk -+ knapenkoor -+ knelgevallen -+ knellender -+ knelpuntenpot -+ knieblessure -+ knieklachten -+ kniekwetsuur -+ knipbeurt -+ kno -+ knock -+ knoflookpad -+ knokfilm -+ knuffelbare -+ knulligheid -+ koeiengriep -+ koeienvlees -+ koeienziekte -+ koekfabrikant -+ koelcapaciteit -+ koelcontainer -+ koelvers -+ koelverse -+ koepelzaal -+ koersbepaling -+ koersbroek -+ koersdag -+ koersdirecteur -+ koersdoel -+ koersdoelen -+ koersenbord -+ koersevolutie -+ koersexplosie -+ koersgegevens -+ koersgevoelig -+ koersgevoelige -+ koersgevoeligheid -+ koersgrafiek -+ koersgrafieken -+ koersinformatie -+ koersklim -+ koersmanipulatie -+ koersopstoot -+ koerspiek -+ koersprestatie -+ koerssprong -+ koersuitslagen -+ koersvastheid -+ koersverhouding -+ koersverhoudingen -+ koersverlegging -+ koerswending -+ koerswinstverhouding -+ koetswerkkleur -+ koffieapparaat -+ koffiedames -+ koffiehoek -+ koffiemerk -+ koffieoogst -+ koffieproducent -+ koffieproducenten -+ koffieproducerende -+ koffieruimte -+ koffieshophouder -+ koffieshophouders -+ koggeschepen -+ kokkelschelpen -+ kokschool -+ koksmes -+ kolenindustrie -+ kollenbloem -+ kollenbloemen -+ kolombreedten -+ kolombreedtes -+ kolomkop -+ kolomkoppen -+ kolonel-generaal -+ koloniserende -+ koloniste -+ kolonistenbeweging -+ komgrens -+ komt-ie -+ kond doen -+ konijnenmelk -+ konikpaarden -+ koning Arthur -+ koning Willem I -+ koning Willem II -+ koningin Beatrix -+ koningin Juliana -+ koningin Wilhelmina -+ koninginnenharing -+ koninginnenstuk -+ koningsgezinden -+ koningsklasse -+ koningskoppel -+ koningsnummer -+ koningsstad -+ koninklijken -+ koninkrijksdeel -+ koninkrijksrelaties -+ kookeiland -+ kookproces -+ kookprogramma's -+ kookrubriek -+ kooktechniek -+ kooktechnieken -+ kookwater -+ kookwinkel -+ kookwinkels -+ kooldioxidegas -+ koolstofhoudende -+ koolstofmonoxide -+ koopadvies -+ koopadviezen -+ koopappartementen -+ koopbereidheid -+ koopbijdrage -+ koopcentrum -+ koopdrift -+ koopinteresse -+ koopjesperiode -+ koopkrachtbeeld -+ koopkrachtdaling -+ koopkrachtreparatie -+ koopkrachtverhoging -+ koopkrachtverlies -+ kooplustigen -+ koopmarkt -+ koopmoment -+ koopplicht -+ koopprijsgrens -+ kooprecht -+ koopsector -+ koopsignaal -+ koopsubsidie -+ koopverplichting -+ koopwoningenmarkt -+ koopwoningmarkt -+ koordirectie -+ koorklank -+ kopallak -+ kopersectie -+ koperverbindingen -+ kopieerapparatuur -+ kopieergedrag -+ kopieervergoeding -+ koppelbazerij -+ koppelgenoot -+ koppeltijdrit -+ koppelvlak -+ koppelvlakken -+ koppositie -+ kopsterke -+ kopvrouw -+ koranscholen -+ korfbalveld -+ korfbalvereniging -+ kornellen -+ korpsleden -+ kort geding -+ korte golf -+ kortetermijnbelangen -+ kortetermijnvisie -+ kortfilms -+ kortgestraften -+ kortingbonnen -+ kortingsbon -+ kortingsbonnen -+ kortingspas -+ kortingsregeling -+ kortingsregelingen -+ kortlevende -+ kosmoloog -+ kostenaftrek -+ kostenanalyse -+ kostenargument -+ kostenargumenten -+ kostenbasis -+ kostenbesparingsprogramma -+ kostenbewustzijn -+ kostencontrole -+ kostendaling -+ kostendekkingsgraad -+ kosteneffect -+ kosteneffecten -+ kosteneffectiviteit -+ kostenefficiënt -+ kostenefficiëntie -+ kostenexplosie -+ kostenforfait -+ kostenkant -+ kostenmatiging -+ kostenneutraal -+ kostenonderzoek -+ kostenonderzoeken -+ kostenoogpunt -+ kostenoverwegingen -+ kostenpercentage -+ kostenprobleem -+ kostenreductie -+ kostenverdeling -+ kostenverhoging -+ kostenverhogingen -+ kostenverlagingen -+ kostenvermindering -+ kostenverschillen -+ kostprijsverhogende -+ kostprijsverlaging -+ kostuumontwerper -+ kostwinnaar -+ kostwinnersvoordeel -+ kotsbeu -+ kouderecord -+ kraaiachtigen -+ kraakverse -+ kraakwereld -+ kraamverlof -+ kraamverzorgenden -+ krabvlees -+ krachtinspanning -+ krachtkoppeling -+ krachtpatserij -+ krachtsexplosie -+ krachttennis -+ krachtverhoudingen -+ krachtvoetbal -+ krakerswereld -+ kranenbouwer -+ krantenarchieven -+ krantenboer -+ krantenconcerns -+ krantenfusie -+ krantengroep -+ kranteninterview -+ krantenjournalisten -+ krantenland -+ krantenmarkt -+ krantenpublicaties -+ krantenredactie -+ krantensite -+ krantensites -+ krantenstrip -+ krantenstrips -+ krantenstuk -+ krantenstukjes -+ krantentitels -+ krantenverkoop -+ krantenverslagen -+ krantenwereld -+ krantenwinkel -+ krantenwinkels -+ kraterveld -+ kredietbedrag -+ kredietbedrijf -+ kredietbeleid -+ kredietbeoordeling -+ kredietcentrale -+ kredietfaciliteit -+ kredietfaciliteiten -+ kredietlijn -+ kredietmaatschappij -+ kredietmogelijkheden -+ kredietovereenkomsten -+ kredietportefeuille -+ kredietrating -+ kredietrisico's -+ kredietruimte -+ kredietschaarste -+ kredietverlenende -+ kredietverschaffer -+ kredietverzekeraar -+ kredietverzekeraars -+ kredietvoorwaarden -+ kredietvorm -+ kredietvraag -+ kreeftachtigen -+ kreeftensaus -+ krensen -+ krijgshandelingen -+ krijgslustige -+ krijgsmachtdeel -+ krijgsmachtdelen -+ kringloopbedrijf -+ kringloopbedrijven -+ kringloopcentra -+ kringloopcentrum -+ krisjna -+ kronkellijntje -+ kronkellijntjes -+ kroonbenoeming -+ krotbewoners -+ krottenwijkbewoners -+ kruideniersbedrijf -+ kruidenmengsel -+ kruidenpreparaten -+ kruidenvrouwtje -+ kruiding -+ kruisbesmetting -+ kruisbloemigen -+ kruishoogte -+ kruisparticipatie -+ kruisparticipaties -+ kruissubsidies -+ kruissubsidiëring -+ kruisvorm -+ kuikenseksster -+ kuitenbijter -+ kunst- en vliegwerk -+ kunstaanbod -+ kunstaankopen -+ kunstbegroting -+ kunstbeurs -+ kunstbeurzen -+ kunstbeweging -+ kunstbomen -+ kunstboom -+ kunstbudget -+ kunstcentra -+ kunstcentrum -+ kunstcircuit -+ kunstcommissie -+ kunstdiscipline -+ kunsteducatie -+ kunstenaarsateliers -+ kunstenaarsgroep -+ kunstenaarsorganisaties -+ kunstenaarsvereniging -+ kunstenaarsverenigingen -+ kunstencentra -+ kunstencentrum -+ kunstenplan -+ kunstenplanperiode -+ kunstensector -+ kunstenveld -+ kunstenwereld -+ kunstexpert -+ kunstfilms -+ kunstfotograaf -+ kunstgrasmat -+ kunstgrind -+ kunsthal -+ kunstheup -+ kunstheupen -+ kunstkanaal -+ kunstkerstboom -+ kunstklep -+ kunstklimaat -+ kunstkoe -+ kunstlens -+ kunstleven -+ kunstlever -+ kunstmagazine -+ kunstmatigs -+ kunstmestfabriek -+ kunstmuziek -+ kunstpagina -+ kunstproductie -+ kunstrovers -+ kunstschaatser -+ kunstscène -+ kunstsector -+ kunststeen -+ kunststofindustrie -+ kunststofonderdelen -+ kunststofproducent -+ kunststofproducten -+ kunststofverpakkingen -+ kunststofverwerking -+ kunststudenten -+ kunstuitlenen -+ kunstvak -+ kunstvakonderwijs -+ kunstzwendel -+ kustdorp -+ kustgemeente -+ kustgemeenten -+ kustlocatie -+ kustscheepjes -+ kusttoerisme -+ kusttram -+ kustversteviging -+ kustzonebeheer -+ kwaadwillenden -+ kwaadwilligen -+ kwalificatiekans -+ kwalificatiereeks -+ kwalificatiesysteem -+ kwaliteitsarme -+ kwaliteitsassistent -+ kwaliteitsbeheer -+ kwaliteitsbesef -+ kwaliteitsbewustzijn -+ kwaliteitsbladen -+ kwaliteitsborging -+ kwaliteitscommissie -+ kwaliteitscontroleur -+ kwaliteitscriteria -+ kwaliteitscriterium -+ kwaliteitsdenken -+ kwaliteitsdienst -+ kwaliteitsfilm -+ kwaliteitsfilms -+ kwaliteitsfunctie -+ kwaliteitshandboek -+ kwaliteitsimpuls -+ kwaliteitsinjectie -+ kwaliteitsjournalistiek -+ kwaliteitskaart -+ kwaliteitskenmerken -+ kwaliteitskeurmerk -+ kwaliteitskring -+ kwaliteitsmanagement -+ kwaliteitsmanager -+ kwaliteitsmedia -+ kwaliteitsmeting -+ kwaliteitsmuziek -+ kwaliteitsonderzoek -+ kwaliteitsoordeel -+ kwaliteitsoordelen -+ kwaliteitspers -+ kwaliteitsprijs -+ kwaliteitsprobleem -+ kwaliteitsproblemen -+ kwaliteitsslag -+ kwaliteitssprong -+ kwaliteitssystemen -+ kwaliteitstoets -+ kwaliteitsverhogend -+ kwaliteitsverhoging -+ kwaliteitsverhouding -+ kwaliteitsverlies -+ kwaliteitsvermindering -+ kwaliteitsvol -+ kwaliteitsvolle -+ kwaliteitswerk -+ kwaliteitswinst -+ kwaliteitszender -+ kwaliteitverhouding -+ kwantumsprong -+ kwartaalgroei -+ kwartaalrapportering -+ kwartaalresultaat -+ kwartaalresultaten -+ kwartaalverlies -+ kwartaalwinst -+ kwartfinaleduel -+ kwartfinalewedstrijd -+ kwarttriatlon -+ kwaststreken -+ kweekvis -+ kweekzalm -+ kwetsbaarheden -+ kwetsend -+ kwetsender -+ kwijtscheldingsnorm -+ kwijtscheldingsregeling -+ l'etjes -+ l'oeil -+ laadschop -+ laadvolume -+ laagblijvend -+ laagblijvende -+ laagbouwwoningen -+ laagdrempeligheid -+ laaggeklasseerde -+ laaggekwalificeerde -+ laagliggende -+ laagrenderende -+ laagvlieger -+ laagvliegers -+ laagvliegoefeningen -+ laanbeplanting -+ laanbomen -+ laatnegentiende -+ laatstejaarsstudent -+ laborante -+ ladingpakketten -+ ladingpapieren -+ ladingspapieren -+ ladingstromen -+ laetare -+ lage-inkomensgroepen -+ lage-lonenlanden -+ lagerbetaalden -+ lagergeschoolden -+ lageropgeleiden -+ lagevloerbussen -+ laisser -+ laissez -+ lampenfabrikant -+ lampionnenoptocht -+ lampionoptocht -+ lamsfilet -+ lamsschenkel -+ land- en volkenkunde -+ landbezetters -+ landbezettingen -+ landbouwakkoord -+ landbouwattaché -+ landbouwbedrijfsleven -+ landbouwbegroting -+ landbouwbelangen -+ landbouwbestrijdingsmiddelen -+ landbouwbudget -+ landbouwcommissie -+ landbouwdieren -+ landbouwdossier -+ landbouwexpert -+ landbouwexport -+ landbouwgif -+ landbouwhervorming -+ landbouwhervormingen -+ landbouwindustrie -+ landbouwkundig -+ landbouwland -+ landbouwlobby -+ landbouwmarkt -+ landbouwminister -+ landbouwministerie -+ landbouwmodel -+ landbouwonderzoek -+ landbouwopbrengsten -+ landbouworganisatie -+ landbouworganisaties -+ landbouwpercelen -+ landbouwraad -+ landbouwsector -+ landbouwsectoren -+ landbouwspecialist -+ landbouwsteun -+ landbouwsysteem -+ landbouwtechnologie -+ landbouwtrekkers -+ landbouwuitgaven -+ landbouwverkeer -+ landbouwwoordvoerders -+ landeigendom -+ landenbeleid -+ landencompetitie -+ landenfondsen -+ landeninformatie -+ landenkampioenschap -+ landenlijst -+ landenorganisaties -+ landenrapport -+ landenrisico -+ landenstrijd -+ lander -+ landgoedeigenaar -+ landgoedeigenaren -+ landingsgebied -+ landingsgelden -+ landingsplek -+ landingspoging -+ landingsverbod -+ landinrichtingscommissie -+ landinrichtingsplan -+ landkwestie -+ landlozen -+ landmachtbevelhebber -+ landmachttop -+ landmassa -+ landoppervlakte -+ landschapformaat -+ landschapjes -+ landschapsarchitectuur -+ landschapsbeeld -+ landschapsbeelden -+ landschapschilderkunst -+ landschapsfoto's -+ landschapsfotografie -+ landschapsontwikkeling -+ landschapsplan -+ landschapsschilderijen -+ landschapsschilderkunst -+ landschapsstijl -+ landschapstypen -+ landschapswaarden -+ landsgedeelte -+ landskampioenschap -+ landsnaam -+ landspolitiek -+ landstrook -+ landverdeling -+ landwet -+ langarmaap -+ langarmapen -+ lange-afstandsraketten -+ lange-afstandsverbindingen -+ langeafstandsschot -+ langeafstandsvervoer -+ langeafstandswedstrijd -+ langebaanploeg -+ langebaanschaatser -+ langetermijnbelegging -+ langetermijndenken -+ langetermijnonderzoek -+ langetermijnperspectief -+ langetermijnplannen -+ langetermijnrelatie -+ langetermijnsparen -+ langetermijntrend -+ langetermijnverhuur -+ langgekoesterde -+ langgestrafte -+ langgestraften -+ langkampeerders -+ langlaufski's -+ langslepend -+ langslepende -+ langsom -+ langsrazen -+ langsstromen -+ langstlopende -+ langwerkende -+ langzichtwissel -+ lapis -+ laserbehandeling -+ lasergeleide -+ lasergestuurde -+ laserpen -+ laserpuls -+ lasertechniek -+ lasertherapie -+ lastenoverzicht -+ lastenstelsel -+ lastenverdeling -+ lastenverhoging -+ lastenverhogingen -+ lastenverlaging -+ lastenverlagingen -+ lastenvermindering -+ lastenverschuiving -+ laswerkzaamheden -+ latin -+ latin jazz -+ lavendelplant -+ lavendelplanten -+ lawaaihinder -+ lawinepijlen -+ lay -+ lazuli -+ leadgitarist -+ leao -+ learning -+ leasebak -+ leasebakken -+ leaseconstructie -+ leaseconstructies -+ leaseprijs -+ leasewagen -+ leasewagens -+ leasingmaatschappij -+ leasingmaatschappijen -+ lectine -+ ledenaantallen -+ ledenbijdragen -+ ledencongres -+ ledengebonden -+ ledengroei -+ ledenorganisatie -+ ledenorganisaties -+ ledenraadpleging -+ ledenraadplegingen -+ ledenreferendum -+ ledenwervingspagina -+ lederhuid -+ leds -+ leefbaarheidsstudie -+ leefgenot -+ leefkwaliteit -+ leeflaag -+ leefomgeving -+ leefomgevingen -+ leeftijdgebonden -+ leeftijdgenote -+ leeftijdsaanduiding -+ leeftijdsaanduidingen -+ leeftijdsbewust -+ leeftijdscriterium -+ leeftijdsfase -+ leeftijdslimiet -+ leeftijdsonderzoek -+ leefvorm -+ leefvormen -+ leeg raken -+ leeggeroofd -+ leeggeroofde -+ leeggespoten -+ leegroven -+ leegruimen -+ leenbedrag -+ leencapaciteit -+ leerbedrijf -+ leercentra -+ leercentrum -+ leercurve -+ leereffect -+ leerfabriek -+ leergebied -+ leergedrag -+ leerindustrie -+ leerling-journalist -+ leerlingenbegeleiding -+ leerlingenpopulatie -+ leerlingenstop -+ leerlingental -+ leerlingenvervoer -+ leerlingplaatsen -+ leerlingverpleegkundigen -+ leerlingzaken -+ leermodel -+ leermoment -+ leermomenten -+ leeromgeving -+ leeromgevingen -+ leerperiode -+ leerplichtambtenaar -+ leerplichtigen -+ leerprocessen -+ leerproject -+ leerprojecten -+ leerresultaten -+ leerroute -+ leers -+ leerstandaarden -+ leerstoelgroep -+ leerweg -+ leesbevordering -+ leescafé -+ leesclub -+ leescultuur -+ leesgedrag -+ leeslint -+ leespauze -+ leesproblemen -+ leestip -+ leet -+ leeuwenmest -+ legalen -+ legatiesecretaris -+ legeraankopen -+ legerarts -+ legerchef -+ legerhervorming -+ legerhospitaal -+ legerkolonel -+ legerkonvooi -+ legermaterieel -+ legermuseum -+ legeroefening -+ legeroffensief -+ legerpost -+ legerstafchef -+ legertop -+ legeskosten -+ legionellabesmettingen -+ legionellavrij -+ legionellose -+ leiderschapsstijl -+ leiderschapsverkiezing -+ leidersrol -+ leiderstype -+ leilinden -+ leitmotiv -+ lekenrechters -+ lekenstaat -+ lengtegroei -+ leningenpakket -+ leningkapitaal -+ lente-ui -+ lenteuitjes -+ leptospirose -+ lerarensalarissen -+ lerarenteam -+ lerarentekort -+ lerarentekorten -+ lesaanbod -+ lesdag -+ lesdagen -+ lesgebouw -+ leskisten -+ lespraktijk -+ lesruimte -+ lessencyclus -+ lessenpakket -+ lessenreeks -+ lestijd -+ lestijden -+ lesuitval -+ lesvrije -+ lesweek -+ lesweken -+ letselongevallen -+ letselschadeadvocaten -+ letterattributen -+ lettre -+ levenbeschouwelijke -+ levensadem -+ levensbelangrijk -+ levensbelangrijke -+ levensberoving -+ levensbesef -+ levensbeëindigende -+ levensdoelen -+ levensdroom -+ levensenergie -+ levensgebieden -+ levensinstelling -+ levensinvulling -+ levenskwaliteit -+ levensloopregeling -+ levensmiddelengroothandel -+ levensmiddelenmarkt -+ levensmiddelentechnologen -+ levensmiddelentechnoloog -+ levensniveau -+ levensnoodzakelijke -+ levensoriëntatie -+ levensperspectief -+ levensproblemen -+ levensreis -+ levensverbintenissen -+ levensverlengend -+ levensverlengende -+ levensverlenging -+ levensverzekeraar -+ levensverzekeraars -+ levensverzekeringspolissen -+ levensverzekeringsproducten -+ levensvreugd -+ levenswetenschappen -+ leveranciersafhankelijkheid -+ leveranciersonafhankelijkheid -+ leveranciersoverleg -+ leveranciersstandaard -+ leveranciersstandaarden -+ leverbeschadiging -+ leverbetrouwbaarheid -+ levercellen -+ levercirrose -+ leveringskosten -+ leveringsproblemen -+ leveringsprogramma -+ leveringsvergunning -+ leveringszekerheid -+ levertermijnen -+ leverweefsel -+ levulose -+ lezersbereik -+ lezerspanel -+ lezersvragen -+ liberaal-economische -+ liberaliseringsbeleid -+ liberaliseringsproces -+ libertarische -+ librettoschrijver -+ licentiebeheer -+ licentiecommissie -+ licentiecontracten -+ licentiegever -+ licentiekosten -+ licentiemodel -+ licentiemodellen -+ licentienemers -+ licentiestructuren -+ licentiestructuur -+ licentiesysteem -+ lichaamsbeheersing -+ lichaamscel -+ lichaamshaar -+ lichaamskenmerken -+ lichaamsmateriaal -+ lichaamsschema -+ lichaamsvet -+ lichaamsvocht -+ lichaamsvorm -+ lichaamsvreemde -+ licht verteerbaar -+ licht-donker -+ lichtarmaturen -+ lichtbalk -+ lichtblokken -+ lichtdivisie -+ lichtenergie -+ lichtfeest -+ lichtgebogen -+ lichthinder -+ lichtman -+ lichtnetadapter -+ lichtpuls -+ lichtroze -+ lichtspel -+ lichtstraat -+ lidmaatschapsbewijs -+ lidocaïne -+ liedbundel -+ liedcyclus -+ liedjesfestival -+ liedjeswedstrijd -+ liedrepertoire -+ liedzanger -+ liefdadigheidsconcert -+ liefdadigheidsprojecten -+ liefdadigheidswerk -+ liefdesgodin -+ liefdeskoppel -+ liefdesnest -+ liefdesnestje -+ liefdespad -+ liefdesrelatie -+ liefdesrelaties -+ liefdesversje -+ liefdeverhouding -+ liesklachten -+ liesoperatie -+ lievelingsfilm -+ lievelingshond -+ lievelingszoon -+ lifestyleblad -+ liftinstallaties -+ liftmonteur -+ liftmuziek -+ ligbed -+ light -+ lignine -+ lijdensdruk -+ lijfgeur -+ lijfhuis -+ lijfhuizen -+ lijfrente-uitkering -+ lijfrente-uitkeringen -+ lijfrenteaftrek -+ lijfrentekapitaal -+ lijkenpikkerij -+ lijkenzakken -+ lijkredenen -+ lijkzakken -+ lijmpoging -+ lijmsoorten -+ lijndikte -+ lijndiktes -+ lijnstijl -+ lijnstijlen -+ lijnvoering -+ lijstenmakerij -+ lijststem -+ lijstvolgorde -+ lijstvorming -+ lik op stuk -+ likkebaardend -+ limes -+ limoenschil -+ limonadefabrikant -+ line -+ line-up -+ linea recta -+ lineariseren -+ lingeriefabrikant -+ lingerielijn -+ lingua -+ liniaalbalk -+ linkeraanvaller -+ linkerbaan -+ linkerduim -+ linkerheup -+ linkerkantlijn -+ linkerknie -+ linkerkolom -+ linkerkuit -+ linkermarge -+ linkermuisknop -+ linkerpagina's -+ linkerpink -+ linkerrijstrook -+ linkerrijtje -+ linkerspits -+ linkervleugelverdediger -+ linkerwang -+ linkje -+ links-liberalisme -+ linksradicale -+ lintdorp -+ liposomen -+ liquidatiewaarde -+ liquiditeitsprobleem -+ listening -+ listeria -+ listing -+ literatuurfestival -+ literatuurliefhebbers -+ literatuurprofessor -+ literatuurwetenschappen -+ literatuurwetenschapper -+ literatuurwetenschappers -+ literprijs -+ lits -+ littekenvorming -+ live-cd -+ live-uitvoering -+ liveact -+ liveacts -+ livealbum -+ liveband -+ liveconcert -+ livetelevisie -+ lobbyclubs -+ lobbying -+ locatiebalk -+ locatiedirecteur -+ locatiemanager -+ locatietheater -+ locatiewijzer -+ locosecretaris -+ locus -+ loenen -+ lofredenen -+ logeerhuis -+ logementhouder -+ loggegevens -+ loggere -+ lonenlanden -+ longcapaciteit -+ longinfecties -+ longmachine -+ longonderzoek -+ longtumor -+ longue -+ longweefsel -+ loodraam -+ loodramen -+ loodvervanger -+ loonafspraken -+ loonbelastingverklaring -+ loonberekening -+ loonbeslag -+ loonblokkering -+ loonbod -+ looncompensatie -+ loonconcurrentie -+ loondaling -+ loondoorbetaling -+ loondruk -+ loonfront -+ loongebouw -+ loongroei -+ loonhandicap -+ looninkomen -+ looninlevering -+ loonkloof -+ loonkost -+ loonkostenhandicap -+ loonkostenstijging -+ loonkostenverlaging -+ loonlastenverlaging -+ loonmassa -+ loonniveau -+ loonniveaus -+ loonnorm -+ loonoffers -+ loonontwikkeling -+ loonontwikkelingen -+ loonoverleg -+ loonruimte -+ loonstructuur -+ loonsubsidie -+ loonverlies -+ loonverschil -+ loonverschillen -+ loonwerk -+ loonwerkersbedrijf -+ loonwig -+ loopbaanadvies -+ loopbaanadviseur -+ loopbaanbeleid -+ loopbaanenquête -+ loopbaanontwikkeling -+ loopband -+ loopgroep -+ loopgroepen -+ loopstal -+ loopvermogen -+ loopwagen -+ lorkenbomen -+ lorkenboom -+ losgesneden -+ loss -+ losstaande -+ loswal -+ loterijmarkt -+ lotgenotencontact -+ loungemuziek -+ loungen -+ low -+ low cost -+ lowbudgetproductie -+ luchtacrobatiek -+ luchtactie -+ luchtacties -+ luchtafvoer -+ luchtafweersystemen -+ luchtbehandeling -+ luchtbehandelingsinstallatie -+ luchtcampagne -+ luchtduel -+ luchtfietser -+ luchtfietserij -+ luchtfoto’s -+ luchthappers -+ luchthavenbedrijf -+ luchthavenexploitant -+ luchthavengebouw -+ luchthavenpersoneel -+ luchthaventerrein -+ luchthavenuitbater -+ luchtlandingsdivisie -+ luchtmachtbevelhebber -+ luchtmachtchef -+ luchtmachteenheden -+ luchtmachtgeneraal -+ luchtmachtmilitairen -+ luchtmachtofficier -+ luchtmachtofficieren -+ luchtmetingen -+ luchtmoleculen -+ luchtoperatie -+ luchtoperaties -+ luchtoverwicht -+ luchtpassagiers -+ luchtramp -+ luchtreus -+ luchtreuzen -+ luchtshow -+ luchtshows -+ luchtsteun -+ luchtvaartaandelen -+ luchtvaartactiviteiten -+ luchtvaartakkoord -+ luchtvaartautoriteit -+ luchtvaartautoriteiten -+ luchtvaartbedrijven -+ luchtvaartbeleid -+ luchtvaartbeurs -+ luchtvaartbranche -+ luchtvaartcluster -+ luchtvaartconcern -+ luchtvaartcrisis -+ luchtvaartgebied -+ luchtvaartgroep -+ luchtvaarthistorie -+ luchtvaartlobby -+ luchtvaartmarkt -+ luchtvaartmuseum -+ luchtvaartondernemingen -+ luchtvaartongevallen -+ luchtvaartorganisatie -+ luchtvaartovereenkomst -+ luchtvaartpersoneel -+ luchtvaartpolitie -+ luchtvaartpolitiek -+ luchtvaartpolitieke -+ luchtvaartsector -+ luchtvaarttarieven -+ luchtvaarttechniek -+ luchtvaartverdrag -+ luchtvaartverdragen -+ luchtvaartwereld -+ luchtvaartwet -+ luchtverdedigingssysteem -+ luchtverdedigingssystemen -+ luchtverkeersbeveiliging -+ luchtverkeerscontrole -+ luchtwaardigheidsbewijs -+ luchtwegklachten -+ luchtwervelingen -+ luidklok -+ luidsprekersysteem -+ luistercijfers -+ luisterervaring -+ luistergedrag -+ luistergenot -+ luistermuziek -+ luisteronderzoek -+ luisterplezier -+ luisterpubliek -+ luistertest -+ luistertijd -+ luitenant-admiraalschap -+ luizenplaag -+ lulverhaal -+ luministische -+ lunchkaart -+ lustopwekkende -+ luxehuis -+ luxelingerie -+ luxemerk -+ luxemerken -+ luxeproduct -+ luxeproducten -+ luxer -+ luxewoningen -+ lycopeen -+ lymfedrainage -+ m'etjes -+ m.i. -+ m.i.v. -+ m.u.v. -+ mA -+ mHz -+ mW -+ maag-darmstelsel -+ maagzuurremmer -+ maagzuurremmers -+ maaiveldniveau -+ maakindustrie -+ maakproces -+ maaltijdsalade -+ maaltijdvoorziening -+ maandagnamiddag -+ maandbedragen -+ maandbudget -+ maandgemiddelde -+ maandlast -+ maandpremie -+ maandtarief -+ maandtotaal -+ maanreizen -+ maanstof -+ maartnummer -+ maatregelenpakket -+ maatschappijmodel -+ maatschappijpolis -+ maatschoenen -+ maatwerkanalyse -+ maatwerkanalyses -+ maatwerkprogrammatuur -+ maatwerksoftware -+ macabre -+ machina -+ machinefabrikant -+ machtsbalans -+ machtsbolwerk -+ machtsdeling -+ machtselite -+ machtsfactor -+ machtsongelijkheid -+ machtsoverdracht -+ machtspartij -+ machtsrelaties -+ machtsspel -+ machtsuitbreiding -+ machtsverdeling -+ machtsverlies -+ machtsverschillen -+ machtsvraag -+ machtswissel -+ macrocijfers -+ maculadegeneratie -+ madrassa's -+ maffiabende -+ maffiageld -+ mafia -+ mafia-achtige -+ magazijnmedewerker -+ magerzucht -+ magisch realisme -+ magistrate -+ magneetbaan -+ magneetwerking -+ magneetzweefbaan -+ magneetzweeftrein -+ magnetronmaaltijd -+ magnetronmaaltijden -+ magnificus -+ mailaccount -+ mailbericht -+ mailberichten -+ maildienst -+ maildiensten -+ mailinglijst -+ mailinglijsten -+ mailkranten -+ mailprogramma -+ mailprogramma's -+ mailservice -+ mailsysteem -+ main -+ mains -+ mainsspeler -+ makelaarskosten -+ makelaarsorganisatie -+ makerschap -+ makroon -+ malariagevallen -+ malariapatiënten -+ malathion -+ male -+ mamba -+ mammoetbotten -+ man-vrouwrollen -+ managementboek -+ managementboeken -+ managementbuy -+ managementcapaciteiten -+ managementcontract -+ managementcontracten -+ managementcultuur -+ managementervaring -+ managementjargon -+ managementlagen -+ managementondersteuning -+ managementproblemen -+ managementsactiviteiten -+ managementsteam -+ managementstructuur -+ managementsysteem -+ managementsystemen -+ managementtalent -+ managementtheorie -+ managementtheorieën -+ managementtijd -+ managementvaardigheden -+ managing -+ mangoboom -+ mannenbastion -+ mannenberoepen -+ mannenbolwerk -+ mannenbondscoach -+ mannenbroeder -+ mannenclub -+ mannenfinale -+ mannengeur -+ mannengroep -+ mannenhaat -+ mannenhanden -+ mannenkiesrecht -+ mannenlichaam -+ mannenliefde -+ mannenmode -+ mannenploeg -+ mannentennis -+ mannentorso -+ mannenvriendschap -+ maquis -+ marathondebuut -+ marathonkampioene -+ marathonpartij -+ marathontitel -+ marathonvoorstelling -+ margeverbetering -+ marginalen -+ marie -+ marinebouw -+ marinehelikopter -+ marinemensen -+ marinepersoneel -+ marineschepen -+ marineschip -+ marinestad -+ marinetop -+ marinevliegkamp -+ marionettenregime -+ markeerstift -+ markervaccin -+ marketeer -+ marketen -+ marketingacties -+ marketingadviseur -+ marketingbedrijf -+ marketingbedrijven -+ marketingbeleid -+ marketingbudget -+ marketingcampagne -+ marketingcampagnes -+ marketingcommunicatie -+ marketingdiensten -+ marketingdoeleinden -+ marketingfunctie -+ marketinginformatie -+ marketinginspanningen -+ marketinginstrument -+ marketinginstrumenten -+ marketingjongens -+ marketingkosten -+ marketingmachine -+ marketingmedewerker -+ marketingmensen -+ marketingmiddel -+ marketingmix -+ marketingoffensief -+ marketingonderzoek -+ marketingpolitiek -+ marketingstrategie -+ marketingstrategieën -+ marketingstunt -+ marketingsucces -+ marketingtruc -+ marketingtrucs -+ marketinguitgaven -+ marketingverantwoordelijke -+ marketingwereld -+ marketmaker -+ marketplace -+ marktactiviteiten -+ marktafspraken -+ marktbezoekers -+ marktcommentaar -+ marktcondities -+ marktconform -+ marktconforme -+ marktdenken -+ marktdominantie -+ marktdynamiek -+ markteconomische -+ markterkenning -+ marktevolutie -+ marktfalen -+ marktfundamentalisme -+ marktgebonden -+ marktgedreven -+ marktgegevens -+ marktgemiddelde -+ marktgeoriënteerde -+ markthandelaar -+ marktherstel -+ markthervormingen -+ marktkansen -+ marktkapitalisatie -+ marktkennis -+ marktkrachten -+ marktleiderschap -+ marktliberalisering -+ marktmacht -+ marktmaker -+ marktmodel -+ marktniche -+ marktniches -+ marktomgeving -+ marktomstandigheden -+ marktomvang -+ marktopening -+ marktpenetratie -+ marktpositionering -+ marktprikkels -+ marktprincipe -+ marktprincipes -+ marktspeler -+ marktsucces -+ marktsysteem -+ markttarieven -+ markttechnisch -+ markttendens -+ markttoegang -+ marktverdeling -+ marktverordening -+ marktverstoring -+ marktvooruitzichten -+ marktvoorwaarden -+ marktvorsers -+ marsrichting -+ marsseizoen -+ marterachtigen -+ mary -+ masculine -+ masqué -+ massa-arrestaties -+ massa-executie -+ massademonstratie -+ massademonstraties -+ massakrant -+ massaproducent -+ massaprotest -+ massaprotesten -+ massaslachting -+ massaslachtingen -+ massaspectrometrie -+ massasport -+ massaverkrachting -+ massaverkrachtingen -+ massavervoer -+ masse -+ masterfase -+ masterplan -+ mastersopleiding -+ mastersopleidingen -+ masterstructuur -+ mastertitel -+ matchpartij -+ matchplay -+ matchwinner -+ materiaalgebruik -+ materiaalman -+ materiaalpech -+ materiaalverlies -+ materialiteit -+ materiedeeltjes -+ matpartij -+ matrassenfabriek -+ matriarch -+ matrixborden -+ matrixstructuur -+ mavoadvies -+ max. -+ maxcontract -+ maximumaantal -+ maximumcapaciteit -+ maximumduur -+ maximumfactuur -+ maximumformaat -+ maximumgewicht -+ maximumkoppel -+ maximumnorm -+ maximumpercentage -+ maximumsalaris -+ mazelenepidemie -+ maïsland -+ maïsteelt -+ maïszetmeel -+ mbo'ers -+ mbo-diploma -+ mbo-instellingen -+ mbo-leerlingen -+ mbo-niveau -+ mbo-scholen -+ mbo-studenten -+ mea -+ mea culpa -+ medaillekandidate -+ medailleregen -+ medaillespiegel -+ medaillewinnaar -+ medaillewinnaars -+ medaillewinnares -+ medeaandeelhouder -+ medeaandeelhouders -+ medeactievoerders -+ medebestuur -+ medebezoekers -+ medecursisten -+ mededingingsautoriteit -+ mededingingsautoriteiten -+ mededingingsbeleid -+ mededingingswetgeving -+ mededingingswetten -+ mededingingszaken -+ medefinancier -+ medefinanciering -+ medefinancieringsprogramma -+ medegebruikers -+ medegedetineerden -+ medegefinancierd -+ medehoofdredacteur -+ medeontwerper -+ medeopsteller -+ medeorganisator -+ medepatiënte -+ medepatiënten -+ medeplegen -+ medepleger -+ medepresentator -+ medescholier -+ medescholieren -+ medeschuld -+ medesponsor -+ medestichter -+ medevennoot -+ medewerkenden -+ medewetgever -+ media-aanbod -+ media-activiteiten -+ media-adviseur -+ mediabaas -+ mediabelangen -+ mediabelangstelling -+ mediaberichten -+ mediabestedingen -+ mediabudget -+ mediabureau -+ mediacentrale -+ mediacentrum -+ mediaconcentratie -+ mediaconcentraties -+ mediaconglomeraat -+ mediaconglomeraten -+ mediaconsument -+ mediacratie -+ mediacultuur -+ mediadebat -+ mediadiensten -+ mediadirecteur -+ mediafiguren -+ mediagebied -+ mediageil -+ mediagekte -+ mediageweld -+ mediagroep -+ mediagroepen -+ mediakritiek -+ mediamaatschappij -+ mediamacht -+ mediamagnaat -+ mediamarkt -+ mediaminister -+ mediamix -+ mediaoffensief -+ mediaoorlog -+ mediaoptreden -+ mediaoptredens -+ mediapark -+ mediapolitiek -+ mediaproducten -+ mediaprogramma -+ mediaredactie -+ mediareus -+ mediaruimte -+ mediasector -+ mediashow -+ mediaspecialist -+ mediaspektakel -+ mediaspeler -+ mediastilte -+ mediastorm -+ mediastrateeg -+ mediastrategie -+ mediatechnologie -+ mediatieke -+ mediatijdperk -+ mediatisering -+ mediatrainer -+ mediatrainers -+ mediatraining -+ mediatrainingen -+ mediatycoon -+ mediavertegenwoordigers -+ mediawoordvoerder -+ mediazaken -+ medica -+ medicijnbeleid -+ medicijnengebruik -+ medicijnengroothandel -+ medicijnenstudent -+ medicijnkosten -+ medicijnverslaving -+ medicijnverstrekking -+ medisch-biologisch -+ medisch-biologische -+ medisch-professionele -+ medisch-sociale -+ medisch-specialistische -+ meditatieruimte -+ mee-installeren -+ meebeslist -+ meebesturen -+ meebeweegt -+ meebewegen -+ meebieden -+ meebiedt -+ meebouwen -+ meebrullen -+ meebuigen -+ meediscussiëren -+ meefietsen -+ meefluiten -+ meegebouwd -+ meegekookt -+ meegesmokkeld -+ meegevlogen -+ meegeïnstalleerd -+ meegroeien -+ meegroeit -+ meehobbelen -+ meehuilen -+ meekeek -+ meekoken -+ meeleest -+ meelevendheid -+ meeleveren -+ meelift -+ meeloten -+ meenste -+ meerderheidsaandeel -+ meerderheidsopvatting -+ meerderheidsparticipatie -+ meerderheidsregering -+ meerderheidsstelsel -+ meerinkomsten -+ meerjarenbeleid -+ meerjarenperspectief -+ meerkamper -+ meerkleurig -+ meerkost -+ meerlagige -+ meerpartijensysteem -+ meerpersoons -+ meerpersoonshuishouden -+ meerpersoonshuishoudens -+ meeruitgaven -+ meerverbruik -+ meerwaardebelasting -+ meerwerk -+ meeschreef -+ meeschrijven -+ meesmokkelen -+ meestappen -+ meestbelovende -+ meester-schilder -+ meestergitarist -+ meesterkraker -+ meesterpianist -+ meesterverteller -+ meesterzet -+ meestgelezen -+ meestgezochte -+ meestijgen -+ meestverdienende -+ meestverkochte -+ meestvoorkomende -+ meetcode -+ meetopstelling -+ meetpalen -+ meetperiode -+ meetploeg -+ meetprogramma -+ meetreeks -+ meetsysteem -+ meetsystemen -+ meettijd -+ meetwerk -+ meeverhuisd -+ meeverhuizen -+ meeverkocht -+ meevliegen -+ meevliegt -+ meevoetballen -+ meevoetballende -+ meewerkaftrek -+ meezingbare -+ meg -+ mega -+ mega-evenement -+ megabanenmarkt -+ megabedrijf -+ megabedrijven -+ megaconcert -+ megaconcerten -+ megacontract -+ megadancing -+ megadancings -+ megadeal -+ megadiscotheek -+ megainvesteringen -+ megalomane -+ megaohm -+ megaoperatie -+ megaorder -+ megaovername -+ megaproces -+ megastad -+ megasteden -+ megastore -+ megastores -+ megasucces -+ megawinkels -+ megazaak -+ megazaken -+ meidenblad -+ meidenclub -+ meiherdenking -+ meikoningin -+ meinummer -+ meivakantie -+ meiviering -+ melamine -+ melatonine -+ meldingsbereidheid -+ meldingssysteem -+ meldlijn -+ meldpost -+ meldsysteem -+ melkaanvoer -+ melkconsumptie -+ melkgeiten -+ melkproducenten -+ melkquota -+ melkquotum -+ melkrechten -+ melkveebedrijf -+ mellitus -+ memoriam -+ mengvoederbedrijf -+ mengvoederbedrijven -+ mengvoederindustrie -+ meningokok -+ meningokokbacterie -+ meningokokkenziekte -+ meningspeiling -+ mensachtigen -+ mensenetende -+ mensenhaar -+ mensenhandelaars -+ mensenhandelaren -+ mensenmaat -+ mensenpark -+ mensenrechtenactiviste -+ mensenrechtenadvocaat -+ mensenrechtenambassadeur -+ mensenrechtenbeleid -+ mensenrechtenbeweging -+ mensenrechtencomité -+ mensenrechtencommissie -+ mensenrechtengroep -+ mensenrechtengroepen -+ mensenrechtengroepering -+ mensenrechtengroeperingen -+ mensenrechtenkwesties -+ mensenrechtenrapport -+ mensenrechtenschenders -+ mensenrechtensituatie -+ mensenrechtenspecialist -+ mensensmokkelaar -+ mensensmokkelbende -+ mensensmokkelorganisaties -+ mensensmokkelzaak -+ mensensoorten -+ mensfiguren -+ mensgeworden -+ menstype -+ mensualiteiten -+ menswaardigheid -+ mentaliteitsomslag -+ merchandise -+ mergelwinning -+ merkafhankelijk -+ merkafhankelijke -+ merkbekendheid -+ merkdealers -+ merkenbeleid -+ merkendorp -+ merkenportefeuille -+ merkgebonden -+ merkgeneesmiddelen -+ merkidentiteit -+ merkproducenten -+ merkproduct -+ merkrecht -+ merkrechten -+ merksteen -+ merktrouw -+ mesothelioom -+ mestactieplan -+ mestafzet -+ mestafzetcontracten -+ mestbassins -+ mestbedrijf -+ mestbeleid -+ mestboekhouding -+ mestboycot -+ mestheffing -+ mestkorrels -+ mestmaatregelen -+ mestopslag -+ mestplannen -+ mestprobleem -+ mestproblematiek -+ mestproductie -+ mestproductierechten -+ mestquota -+ mestrechten -+ meststoffenwet -+ mestverwerkende -+ mestverwerker -+ mestverwerkingsbedrijf -+ mestwet -+ mestwetgeving -+ met dien verstande -+ met veel verve -+ met verve -+ met voorbedachten rade -+ meta -+ meta-analyse -+ metaalatomen -+ metaalbewerkingsbedrijf -+ metaalconstructiebedrijf -+ metaaldeeltjes -+ metaalhydride -+ metaalhydridebatterij -+ metaalhydridebatterijen -+ metaalionen -+ metaalkleur -+ metaalplaten -+ metaalprijzen -+ metaalproducten -+ metaalsector -+ metaalsoort -+ metaaltechniek -+ metaalvakbond -+ metaalverwerking -+ metagegeven -+ metagegevens -+ metal -+ metalbands -+ metalektro -+ metalfestival -+ metalgroep -+ meteorietenregen -+ meteorietinslag -+ metermarkt -+ meterprijs -+ methionine -+ methotrexaat -+ metrobedrijf -+ metrobestuurder -+ metrokaartje -+ metronet -+ metronetwerk -+ metropolitane -+ metrostel -+ metrosysteem -+ meubelbedrijf -+ meubelcollectie -+ meubeldesign -+ meubelgigant -+ meubelmaken -+ meubelplein -+ meubelsector -+ meubelwinkel -+ mevr. -+ mex -+ micro-economische -+ microbiologe -+ microbiologische -+ microfonist -+ microhenry -+ microprocessorsysteem -+ microprocessorsystemen -+ microtonale -+ microtubuli -+ middagappel -+ middagconcert -+ middagsessie -+ middagtemperatuur -+ middagzitting -+ middeldure -+ middelengebruik -+ middelloon -+ middelloonstelsel -+ middelloonsysteem -+ middenbouw -+ middencategorie -+ middenconsole -+ middendeel -+ middengebied -+ middengeleider -+ middenlaag -+ middenmanagement -+ middenmotor -+ middenplein -+ middenstijl -+ middenwesten -+ middenzaal -+ middle -+ midwinterhoornblazen -+ mierenkolonie -+ mierikswortelsaus -+ mifepriston -+ migrantenbeleid -+ migrantengroepen -+ migrantenproblematiek -+ migrantenrellen -+ migrantenstemrecht -+ migrantenstromen -+ migrantenstroom -+ migratiebeleid -+ migratiekosten -+ migratiepolitiek -+ migratierecht -+ migratiestop -+ mijn en dijn -+ mijnbouwers -+ mijncomplex -+ mijnenbestrijdingsvaartuig -+ mijnengevaar -+ mijngroep -+ mijnonderneming -+ mijnongeluk -+ mijns inziens -+ mijnsector -+ mijnsite -+ mijnterrein -+ mijnterreinen -+ milaan -+ milieu-informatie -+ milieu-inspecteur -+ milieu-inspecteurs -+ milieuactiviste -+ milieuadvies -+ milieuadviesbureau -+ milieuadviseur -+ milieuafdeling -+ milieuambtenaar -+ milieuambtenaren -+ milieuaspect -+ milieubalans -+ milieubedrijf -+ milieubegroting -+ milieubelang -+ milieubelangen -+ milieubeleidsplan -+ milieubepalingen -+ milieubesef -+ milieubesparende -+ milieubewustzijn -+ milieubezwaren -+ milieubureau -+ milieucentrum -+ milieucijfers -+ milieuclub -+ milieucommissie -+ milieuconferentie -+ milieuconvenant -+ milieuconvenanten -+ milieucoöperaties -+ milieucoördinator -+ milieucriminaliteit -+ milieucrisis -+ milieucriteria -+ milieudebat -+ milieudenken -+ milieudoelen -+ milieudoelstelling -+ milieudruk -+ milieueffect -+ milieueffectrapport -+ milieueffectrapportage -+ milieufederatie -+ milieufederaties -+ milieufonds -+ milieugebied -+ milieugedrag -+ milieugerichte -+ milieugevaarlijke -+ milieugevolgen -+ milieugrenzen -+ milieuhandhaving -+ milieuhinder -+ milieuhinderlijke -+ milieuhygiënisch -+ milieuhygiënische -+ milieujaarverslag -+ milieukeuring -+ milieukeurmerk -+ milieuklachten -+ milieukosten -+ milieukunde -+ milieukundig -+ milieukwaliteit -+ milieukwesties -+ milieuleges -+ milieulobby -+ milieumanagement -+ milieumarkt -+ milieuministerie -+ milieuministers -+ milieumisdrijven -+ milieuomstandigheden -+ milieuonderzoek -+ milieuonderzoeken -+ milieuoogpunt -+ milieuorganisaties -+ milieuoverwegingen -+ milieuparagraaf -+ milieupartijen -+ milieuprijs -+ milieuproblematiek -+ milieuraad -+ milieurapport -+ milieurapportage -+ milieurapporten -+ milieuredenen -+ milieuregelgeving -+ milieurendement -+ milieurichtlijnen -+ milieurisico -+ milieurisico's -+ milieuschadelijke -+ milieuschets -+ milieuschuld -+ milieusector -+ milieusituatie -+ milieusparende -+ milieuspecialist -+ milieuspecialisten -+ milieustudie -+ milieutaken -+ milieuteam -+ milieutechniek -+ milieutechnisch -+ milieutechnische -+ milieutechnologie -+ milieutop -+ milieuverantwoord -+ milieuverantwoorde -+ milieuverbeteringen -+ milieuverdrag -+ milieuvereniging -+ milieuverontreinigende -+ milieuverplichtingen -+ milieuverslag -+ milieuverslagen -+ milieuvervuilend -+ milieuvervuilende -+ milieuvoordeel -+ milieuvoordelen -+ milieuvoorwaarden -+ milieuvoorzieningen -+ milieuvraagstuk -+ milieuvraagstukken -+ milieuvriendelijker -+ milieuvriendelijkheid -+ milieuvriendelijkste -+ milieuwachter -+ milieuwereld -+ milieuwerkgroep -+ milieuwetgeving -+ milieuwethouder -+ milieuwinst -+ milieuzaak -+ milieuzorgsysteem -+ milieuzorgsystemen -+ militair-operationele -+ miljardenaankoop -+ miljardenbedragen -+ miljardenbod -+ miljardenbusiness -+ miljardencontract -+ miljardendans -+ miljardendeal -+ miljardenmarkt -+ miljardenmeevallers -+ miljardenomzet -+ miljardenovername -+ miljardenovernames -+ miljardenplan -+ miljardenproject -+ miljardenschuld -+ miljardenstroom -+ miljardenstrop -+ miljardentransacties -+ miljardenwinst -+ miljardenwinsten -+ miljardenzaak -+ miljoenenbedragen -+ miljoenenboete -+ miljoenenbonus -+ miljoenenclaim -+ miljoenenclaims -+ miljoenencontract -+ miljoenendeal -+ miljoeneninvestering -+ miljoeneninvesteringen -+ miljoenenomzet -+ miljoenenpubliek -+ miljoenenroof -+ miljoenenstrop -+ miljoenentekort -+ miljonairsdochter -+ millenniumbestendig -+ millenniumbestendigheid -+ millenniumbom -+ millenniumbug -+ millenniumjaar -+ millenniumnacht -+ millenniumovergang -+ millenniumplatform -+ millenniumprobleem -+ millenniumproblematiek -+ millenniumproject -+ millenniumproof -+ millenniumtest -+ millenniumviering -+ millenniumwisseling -+ millihenry -+ millihertz -+ miltvuurbacteriën -+ miltvuurbrief -+ miltvuurbrieven -+ min. -+ minder-validen -+ minderhedenorganisaties -+ minderheidsaandelen -+ minderheidsdeelnemingen -+ minderheidsparticipatie -+ minderheidsparticipaties -+ minderheidsregime -+ mini-cd -+ miniatuurstad -+ miniatuurversie -+ minicamping -+ miniconcert -+ miniconferentie -+ minicontainers -+ minifestival -+ minimal -+ minimumaantallen -+ minimumduur -+ minimumformaat -+ minimumlengte -+ minimumniveau -+ minimumorder -+ minimumpakket -+ minimumpensioen -+ minimumpercentage -+ minimumrendement -+ minimumsalaris -+ minimumvereiste -+ minimumvereisten -+ minionderneming -+ minirotondes -+ ministaat -+ ministaatje -+ ministadion -+ ministelsel -+ minister-presidentschap -+ ministerconferentie -+ ministerpost -+ ministerposten -+ ministerraadsvergadering -+ ministersbijeenkomst -+ ministersconferentie -+ ministerscrisis -+ ministerskamer -+ ministersniveau -+ ministerssalaris -+ ministre -+ minorsysteem -+ minstverdienende -+ minute -+ mirakeloplossing -+ mirrors -+ mis poes -+ misbegrepen -+ misbruiker -+ misbruikers -+ miscommunicaties -+ misdaadanalyse -+ misdaadbende -+ misdaadbendes -+ misdaadboeken -+ misdaadcijfer -+ misdaadcijfers -+ misdaadgeld -+ misdaadgenre -+ misdaadgeschiedenis -+ misdaadjournalist -+ misdaadkomedie -+ misdaadliteratuur -+ misdaadmilieu -+ misdaadschrijver -+ misdaadthriller -+ misdaadverslaggever -+ misdaadwereld -+ mise -+ misinformatie -+ misinterpretatie -+ missende -+ mistgordijn -+ misviering -+ mitochondriaal -+ mitochondriale -+ mitochondriën -+ mitswa -+ mix-cd -+ mixdranken -+ mixed grill -+ mixed pickles -+ mkb -+ ml -+ mld. -+ mlk -+ mlk-school -+ mln. -+ mobbing -+ mobieletelefoniebedrijf -+ mobilisatiecomplex -+ mobiliteitscentrum -+ mobiliteitsfonds -+ mobiliteitsgroei -+ mobiliteitsplan -+ mobiliteitsplannen -+ mobiliteitsprobleem -+ mobiliteitsproblematiek -+ mobiliteitsproblemen -+ mobiliteitsvraagstuk -+ mobilofoonoperator -+ mobimeter -+ moddergooien -+ mode-evenement -+ mode-imperium -+ modeafdeling -+ modebedrijf -+ modebewustzijn -+ modeduo -+ modefoto -+ modefotograaf -+ modegebied -+ modeketen -+ modeketens -+ modekringen -+ modelabel -+ modeland -+ modelbouwers -+ modelcode -+ modelcontract -+ modeldorp -+ modelijn -+ modeljaar -+ modellenpolitiek -+ modellenreeks -+ modellenwedstrijd -+ modellenwerk -+ modelportefeuille -+ modelproject -+ modelstaat -+ modeltrein -+ modeltreintjes -+ modeltuinen -+ modelwijk -+ modemakers -+ modemerk -+ modemkaart -+ modemuseum -+ modemverbinding -+ modeontwerpster -+ modeopleiding -+ modepers -+ modeprijs -+ moderedactrice -+ moderniseringsoperatie -+ modeschool -+ modestad -+ modestudenten -+ modetalent -+ modevormgeving -+ modewereld -+ modulariteit -+ modulatietechniek -+ modulatietechnieken -+ moduleerbaar -+ moederbank -+ moederbord -+ moederholding -+ moederkloek -+ moederonderneming -+ moederpartij -+ moedervennootschap -+ moegetergde -+ moerasdelta -+ moeraseiken -+ moerdijk -+ molenaarszoon -+ molenbouwer -+ molengang -+ molengangen -+ monarchvlinders -+ mond op mond -+ mond-en-klauwzeercrisis -+ mondbeademing -+ monddeel -+ monddelen -+ mondgevoel -+ mondgezondheid -+ mondharmonicaspeler -+ mondkanker -+ mondkapje -+ mondkapjes -+ mondverzorging -+ mondzorg -+ monitoringscommissie -+ monnikenbestaan -+ mono-etnische -+ monocultureel -+ monolitisch -+ monolitische -+ monopoliemacht -+ monopoliewinsten -+ monsterfusie -+ monsterhit -+ monsterproject -+ monsterverlies -+ monsterwinsten -+ montageafdeling -+ montageatelier -+ montagekamer -+ montageleider -+ montagetechnieken -+ montagevoorstellingen -+ montessori -+ monumentenverordening -+ monumentenwacht -+ mooifilmerij -+ moordcomplot -+ moordmachine -+ moordmachines -+ moordmysterie -+ moordzucht -+ moreel-ethische -+ morning -+ mortale -+ mortales -+ mortierbommen -+ mortierinslagen -+ mortis -+ moskeevereniging -+ moslim-fundamentalistische -+ moslimbeweging -+ moslimcultuur -+ moslimfamilies -+ moslimgebied -+ moslimgeestelijken -+ moslimgeleerde -+ moslimgeleerden -+ moslimgroep -+ moslimgroepen -+ moslimgroepering -+ moslimgroeperingen -+ moslimhaat -+ moslimjongens -+ moslimkinderen -+ moslimkringen -+ moslimland -+ moslimleerlingen -+ moslimleger -+ moslimleider -+ moslimman -+ moslimmeerderheid -+ moslimmeisje -+ moslimmilitanten -+ moslimminderheid -+ moslimpartij -+ moslimpartijen -+ moslimraad -+ moslimstad -+ moslimterrorisme -+ moslimvluchtelingen -+ moslimvrouw -+ moslimwereld -+ moslimzijde -+ motion -+ motivatieproblemen -+ motivatierichting -+ motivator -+ motorbende -+ motorbendes -+ motorfabrikant -+ motorfabrikanten -+ motorgeluid -+ motorindustrie -+ motorjack -+ motorliefhebbers -+ motormaaier -+ motormanagement -+ motormarkt -+ motorongeval -+ motorpak -+ motorprestaties -+ motorproblemen -+ motorrijtuigenverzekeringen -+ motorscooter -+ motortechniek -+ motorversies -+ motorzaak -+ mousselinesaus -+ moéten -+ mp3 -+ mp3-formaat -+ mp3-spelers -+ mucoviscidose -+ muggenzifterij -+ muisklikken -+ muisknop -+ muisspel -+ muiswijzer -+ muizenplaag -+ muizige -+ multi -+ multi's -+ multi-etniciteit -+ multiculturaliteit -+ multimediabedrijf -+ multimediacomputer -+ multimediaconcern -+ multimediadiensten -+ multimediaproducten -+ multimediatoepassingen -+ multimodaal -+ multimodale -+ multiplatform -+ multiple sclerose -+ multipolaire -+ multiresistente -+ multitasking -+ munitieopslag -+ muntautomaten -+ muntbeleid -+ munthuizen -+ muntrisico -+ muntschat -+ museumarchitectuur -+ museumbeleid -+ museumcafé -+ museumdepots -+ museumfunctie -+ museumgebouw -+ museumgebouwen -+ museumgids -+ museumkunst -+ museumkwartier -+ museummedewerkers -+ museumpubliek -+ museumschip -+ museumspoorlijn -+ museumstaf -+ museumsuppoost -+ museumtram -+ museumtuin -+ museumwereld -+ music -+ musicalfilm -+ musicalnummers -+ musicalster -+ musicalsterren -+ musicalversie -+ musicalwereld -+ musk -+ mutatis mutandis -+ muurbekleding -+ muziek-cd -+ muziek-cd's -+ muziekaanbod -+ muziekacademie -+ muziekactiviteiten -+ muziekbeleid -+ muziekbeleving -+ muziekbestanden -+ muziekbusiness -+ muziekcafé -+ muziekcarrière -+ muziekcentrum -+ muziekcollectie -+ muziekconcern -+ muziekconcours -+ muziekcultuur -+ muziekdienst -+ muziekdivisie -+ muziekdocent -+ muziekdocenten -+ muziekdocumentaire -+ muziekfiles -+ muziekgebied -+ muziekgenre -+ muziekgroep -+ muziekinstallatie -+ muziekjournalist -+ muziekjournalisten -+ muziekkanaal -+ muziekkanalen -+ muziekkeus -+ muziekkeuze -+ muziekkiosk -+ muziekklimaat -+ muzieklabel -+ muzieklerares -+ muziekliteratuur -+ muziekmaken -+ muziekmarkt -+ muziekmuseum -+ muzieknummer -+ muziekopleiding -+ muziekopleidingen -+ muziekpers -+ muziekpiraterij -+ muziekpodia -+ muziekpodium -+ muziekpraktijk -+ muziekprijs -+ muziekprijzen -+ muziekproducent -+ muziekproducenten -+ muziekproducties -+ muziekproject -+ muziekprojecten -+ muziekrecensent -+ muziekrechten -+ muziekscene -+ muzieksector -+ muzieksite -+ muzieksites -+ muzieksmaak -+ muzieksoort -+ muziekspektakel -+ muziekstad -+ muziekstijl -+ muziekstroming -+ muziekstromingen -+ muziekstudenten -+ muziekstudio -+ muziektaal -+ muziektalent -+ muziektempel -+ muziektheatrale -+ muziektherapeut -+ muziektraditie -+ muziektradities -+ muziekuitgeverij -+ muziekuitgeverijen -+ muziekvakonderwijs -+ muziekvideo -+ muziekvideo's -+ muziekvoorstelling -+ muziekvorm -+ muziekvormen -+ muziekwedstrijd -+ muziekwerk -+ muziekwerken -+ muziekzenders -+ muzikante -+ mw -+ mw. -+ mycoplasma -+ mémoire -+ móest -+ móet -+ móeten -+ mógen -+ n'etjes -+ n.a.v. -+ n.o.t.k. -+ na-ijl -+ na-ijlde -+ na-ijlden -+ na-ijlt -+ na-ijveriger -+ na-ijverigere -+ na-ijverigst -+ na-ijverigste -+ naaktscène -+ naaktslak -+ naaktslakken -+ naamgeefster -+ naamgever -+ naamgevers -+ naamkeuze -+ naar binnen -+ naar de barbiesjes -+ naar de barrebiesjes -+ naar hartenlust -+ nachtburgemeester -+ nachtbus -+ nachtbussen -+ nachtclubdanseres -+ nachtclubzangeres -+ nachte -+ nachtkleding -+ nachtmerriescenario -+ nachtnorm -+ nachtprogramma -+ nachtradio -+ nachtregime -+ nachtritme -+ nachtritten -+ nachtscène -+ nachtsluiting -+ nachttemperatuur -+ nachturen -+ nachtwinkel -+ nachtzichtapparatuur -+ nacontrole -+ nadeelcompensatie -+ naijlend -+ naijlende -+ najaarsdag -+ najaarsnota -+ najaarsoverleg -+ nakijkwerk -+ nakomer -+ nalatigheidsinteresten -+ naltrexon -+ namaakartikelen -+ namelijke -+ namenlijsten -+ nanobuisjes -+ nanogram -+ nanovolt -+ napoletano -+ narcostaat -+ narcoticahandel -+ narrowcasting -+ nascendi -+ nastrevenswaardig -+ natalis -+ natiestaat -+ natiestaten -+ nationaliste -+ native -+ natransport -+ natté -+ naturalisatiedienst -+ naturalisatieprocedure -+ natuuraankopen -+ natuurbeeld -+ natuurbeheerder -+ natuurbeheerders -+ natuurbelang -+ natuurbelangen -+ natuurbeleid -+ natuurbeleving -+ natuurbestemming -+ natuurbeweging -+ natuurcentrum -+ natuurcompensatie -+ natuurdocumentaires -+ natuurdoelen -+ natuureducatie -+ natuurfenomeen -+ natuurgeluiden -+ natuurgeneeskundige -+ natuurgeweld -+ natuurgidsen -+ natuurgras -+ natuurgrond -+ natuurherstel -+ natuurijsbaan -+ natuurlandschap -+ natuurlyriek -+ natuurminnende -+ natuurontwikkelaars -+ natuurontwikkeling -+ natuurontwikkelingsproject -+ natuurontwikkelingsprojecten -+ natuurorganisatie -+ natuurpad -+ natuurpracht -+ natuurproject -+ natuurreligie -+ natuurrijke -+ natuurschade -+ natuurtaferelen -+ natuurtochten -+ natuurtuin -+ natuurvereniging -+ natuurwaarde -+ natuurwandeling -+ natuurwandelingen -+ navelstaarderige -+ navelstaarderij -+ navelstrengbloed -+ navigatieknop -+ navigatieknoppen -+ navigatiemiddelen -+ navigeer -+ navorderingsaanslag -+ naw -+ naw-gegevens -+ nazibeweging -+ nazibewind -+ nazileider -+ nazimisdaad -+ nazipartij -+ nazipraktijken -+ naziregime -+ nazislachtoffer -+ nazisympathieën -+ nazitijd -+ naziverleden -+ nazivlag -+ nazomeravond -+ nazomerweer -+ naäpers -+ necrofiele -+ nederzettingenblokken -+ nederzettingenpolitiek -+ nee-stem -+ neergeklapt -+ neergemaaid -+ neerklapbare -+ neerslagkansen -+ negationisme -+ negationisten -+ negationistische -+ negativiteit -+ negendelige -+ negenennegentig -+ negenentachtig -+ negenenveertig -+ negenenvijftig -+ negenenzestig -+ negentienjarigen -+ nek aan nek -+ nekklachten -+ nekletsel -+ nekrace -+ nekwervel -+ neo -+ neoclassicistische -+ neoconservatieve -+ neokoloniale -+ neomodernisme -+ nepbloed -+ nepper -+ neppil -+ neppillen -+ nepwapens -+ nertsenfokker -+ nertsenfokkerij -+ nertsenfokkerijen -+ nertsenfokkers -+ nertsenhouderij -+ nertsenhouders -+ nervosa -+ nestgelegenheid -+ nestkast -+ nestkasten -+ nestmateriaal -+ netbeheer -+ netbeheerders -+ netbesturen -+ netbestuur -+ netcoördinator -+ netcoördinatoren -+ netgebruikers -+ netmanager -+ netmanagers -+ netoverschrijdend -+ netoverschrijdende -+ netpartners -+ netprofielen -+ netprofilering -+ netstatuut -+ nettere -+ netto-effect -+ netto-ontvanger -+ netto-uitvoer -+ nettobankproduct -+ nettobetaler -+ nettocashpositie -+ nettodividend -+ nettogroepswinst -+ nettohuur -+ nettolast -+ nettoschuld -+ nettovermogen -+ nettowinstgroei -+ nettowinstmarge -+ netwerkaanbieder -+ netwerkaanbieders -+ netwerkapparatuur -+ netwerkarchitectuur -+ netwerkbedrijf -+ netwerkbedrijven -+ netwerkbeheer -+ netwerkbeheerder -+ netwerkbeveiliging -+ netwerkcapaciteit -+ netwerkcomputer -+ netwerkdiensten -+ netwerkeconomie -+ netwerker -+ netwerkers -+ netwerkgesprek -+ netwerkgigant -+ netwerkinfrastructuur -+ netwerkintegrator -+ netwerkkaarten -+ netwerkmaatschappij -+ netwerkorganisatie -+ netwerkorganisaties -+ netwerksamenleving -+ netwerkstad -+ netwerksteden -+ netwerkstructuur -+ netwerksystemen -+ netwerktechniek -+ netwerktechnieken -+ netwerktechnologie -+ netwerktechnologieën -+ netwerkverbindingen -+ netwerkvorming -+ network -+ neurobiologen -+ neurobiologische -+ neurochirurgische -+ neurotoxine -+ neurotoxines -+ neurotoxische -+ neutraals -+ neutralen -+ neuzelig -+ nevenbedrijf -+ nevenbedrijven -+ nevendossiers -+ nevengeul -+ nevenpersonages -+ nevenprojecten -+ nevenschade -+ neventaken -+ nevenverschijnsel -+ nevenverschijnselen -+ new -+ newageachtig -+ newageachtige -+ newagealbum -+ newagedrama -+ newagegeluidsbehang -+ nez -+ nichepubliek -+ nick -+ niercellen -+ nierdonoren -+ nierfalen -+ nierkanker -+ nieroperatie -+ nierschade -+ niet-Jood -+ niet-Joods -+ niet-Joodse -+ niet-Nederlands -+ niet-aanvalspact -+ niet-aanwezige -+ niet-abonnees -+ niet-academische -+ niet-achtergestelde -+ niet-acute -+ niet-aftrekbare -+ niet-agrarische -+ niet-alcoholische -+ niet-artsen -+ niet-bancaire -+ niet-begeleide -+ niet-behandelde -+ niet-beschermde -+ niet-besmette -+ niet-betaalde -+ niet-betalers -+ niet-betaling -+ niet-bijbelse -+ niet-communistische -+ niet-competitieve -+ niet-conventionele -+ niet-corrupte -+ niet-criminele -+ niet-deelnemende -+ niet-democratische -+ niet-duurzame -+ niet-economische -+ niet-erfelijke -+ niet-essentiële -+ niet-eurolanden -+ niet-exclusieve -+ niet-familieleden -+ niet-financiële -+ niet-fiscale -+ niet-functionele -+ niet-functionerende -+ niet-fysieke -+ niet-geautoriseerde -+ niet-gebruikte -+ niet-gehandicapte -+ niet-gehandicapten -+ niet-gekwalificeerde -+ niet-gemanipuleerde -+ niet-gemodificeerde -+ niet-genoteerde -+ niet-georganiseerde -+ niet-geplande -+ niet-gepubliceerde -+ niet-gerealiseerde -+ niet-geregistreerde -+ niet-geringe -+ niet-gespecialiseerde -+ niet-gesubsidieerde -+ niet-gevaccineerde -+ niet-gewelddadige -+ niet-geïdentificeerde -+ niet-giftige -+ niet-gouvernementele -+ niet-huwelijkse -+ niet-industriële -+ niet-ingezetenen -+ niet-inheemse -+ niet-integer -+ niet-inwoners -+ niet-islamieten -+ niet-islamitische -+ niet-journalistieke -+ niet-juridische -+ niet-juristen -+ niet-kenners -+ niet-kerkelijke -+ niet-kerkelijken -+ niet-kernactiviteiten -+ niet-klanten -+ niet-klassieke -+ niet-leven -+ niet-levende -+ niet-lezers -+ niet-literaire -+ niet-marktconforme -+ niet-materiële -+ niet-medici -+ niet-menselijke -+ niet-moslims -+ niet-nationalistische -+ niet-natuurlijke -+ niet-noodzakelijke -+ niet-nucleaire -+ niet-ontplofte -+ niet-openbare -+ niet-operationele -+ niet-orthodoxe -+ niet-permanente -+ niet-personele -+ niet-politieke -+ niet-professionele -+ niet-publieke -+ niet-rationele -+ niet-realistische -+ niet-reguliere -+ niet-relevante -+ niet-religieuze -+ niet-rendabele -+ niet-renderende -+ niet-representatieve -+ niet-rijksmusea -+ niet-rokende -+ niet-royeerbare -+ niet-specifieke -+ niet-spoedeisende -+ niet-sporters -+ niet-sportieve -+ niet-stedelijke -+ niet-stemgerechtigde -+ niet-stemmers -+ niet-strategische -+ niet-structurele -+ niet-traditionele -+ niet-transgene -+ niet-universitaire -+ niet-verslaafde -+ niet-vervolging -+ niet-verwante -+ niet-verzekerde -+ niet-werknemers -+ niet-wetenschappelijke -+ niet-winstgevende -+ niet-woningen -+ niet-zakelijke -+ nietesspel -+ nietsverhullende -+ nietszeggendheid -+ nieuwbenoemde -+ nieuwbouwgebied -+ nieuwbouwmarkt -+ nieuwbouwprogramma -+ nieuwbouwproject -+ nieuwen -+ nieuwgeborenen -+ nieuwgebouwde -+ nieuwjaarsartikel -+ nieuwjaarsbrand -+ nieuwjaarsduik -+ nieuwjaarsperiode -+ nieuwjaarsramp -+ nieuwjaarstoespraak -+ nieuwjaarstoespraken -+ nieuwjaarsviering -+ nieuwkomersbeleid -+ nieuwsaanbod -+ nieuwsarme -+ nieuwsartikelen -+ nieuwsfotograaf -+ nieuwsitem -+ nieuwsjaarsdag -+ nieuwskrant -+ nieuwsmakers -+ nieuwsnet -+ nieuwsonderwerpen -+ nieuwsontwikkelingen -+ nieuwsorganisatie -+ nieuwsorganisaties -+ nieuwspagina -+ nieuwsprogramma's -+ nieuwsquiz -+ nieuwsredactie -+ nieuwsredacties -+ nieuwsselectie -+ nieuwsshow -+ nieuwssite -+ nieuwssites -+ nieuwsstation -+ nieuwsticker -+ nieuwswaardig -+ nightclubs -+ nikkel-cadmium -+ nikkel-cadmiumbatterij -+ nikkel-cadmiumbatterijen -+ nikkel-metaalhydride -+ nikkel-metaalhydridebatterij -+ nikkel-metaalhydridebatterijen -+ nikkelallergie -+ nikkelprijs -+ nikkelproducent -+ nimby -+ ninja -+ ninja's -+ nipkowschijf -+ nitraatgehalte -+ nitraatnorm -+ nitraatrichtlijn -+ niçoise -+ niét -+ njet -+ nl.openoffice.org -+ nm -+ no -+ nogal wiedes -+ nolens -+ nolens volens -+ nom -+ nom de guerre -+ nomadentent -+ non-beleid -+ non-commerciële -+ non-discriminatie -+ non-discussie -+ non-ferrobedrijven -+ non-ferrometalen -+ non-fictionboek -+ non-informatie -+ non-issue -+ non-profitinstellingen -+ non-profitsector -+ non-respons -+ non-vaccinatie -+ non-vaccinatiebeleid -+ noodbedden -+ noodbevel -+ noodbevoegdheden -+ noodbouw -+ nooddecreet -+ nooddiensten -+ noodenting -+ noodentingen -+ noodgebouwen -+ noodhospitaal -+ noodhuisvesting -+ noodknop -+ noodkrediet -+ noodleverancier -+ noodleveranciers -+ noodlokaal -+ noodnet -+ noodnummer -+ noodopvang -+ noodoverloopgebied -+ noodoverloopgebieden -+ noodpakket -+ noodpompen -+ noodprocedure -+ noodprocedures -+ noodprogramma -+ noodregeling -+ noodremprocedure -+ noodstroom -+ noodstroomvoorziening -+ noodvaart -+ noodvaccinatie -+ noodvaccinaties -+ noodweg -+ noodwoningen -+ noodzaakdiscussie -+ nooit ofte nimmer -+ noord-oostelijke -+ noord-westelijke -+ noord-zuidroute -+ noordoever -+ noordrand -+ noordtak -+ noordwesthoek -+ norminkomen -+ norminkomens -+ normloos -+ normloze -+ normoverschrijdend -+ normpraktijk -+ nostalgici -+ not -+ nota bene -+ notaristarieven -+ notariswet -+ nous -+ nouveau -+ nouveaustijl -+ nouveaux -+ novembernummer -+ nr. -+ nucleotiden -+ nulcoupon -+ nulde -+ nulmeting -+ nultolerantie -+ numerus fixus -+ nummerformaat -+ nummeringstekens -+ nummeroverdraagbaarheid -+ nummerplan -+ nummerportabiliteit -+ nummerrekeningen -+ nutsdiensten -+ nutsgroep -+ nutssector -+ nutssectoren -+ nádat -+ o jee -+ o'tjes -+ o.i.d. -+ o.l.v. -+ o.t.t. -+ o.v.t. -+ o.v.v. -+ objectbalk -+ objectcode -+ objectgeoriënteerde -+ obligatiebeleggers -+ obligatiefonds -+ obligatiefondsen -+ obligatierendementen -+ oblige -+ obscur -+ obscura -+ observatiecentrum -+ observatiehut -+ observatiekliniek -+ observatieteam -+ observatieteams -+ obsessief-compulsieve -+ ochtendappels -+ ochtendetappe -+ ochtendfile -+ ochtendfiles -+ ochtendhandel -+ ochtendkoffie -+ ochtendritueel -+ ochtendsessie -+ ochtendshow -+ ochtendtraining -+ ochtendvergadering -+ ochtendzitting -+ octrooieerbaar -+ octrooieerbaarheid -+ octrooieerbare -+ octrooisysteem -+ octrooiwetgeving -+ oefencampagne -+ oefencentrum -+ oefendorp -+ oefenduel -+ oefengebied -+ oefenpartij -+ oefenpartijen -+ oefenpartner -+ oefenperiode -+ oefenprogramma -+ oefenruimte -+ oefenstage -+ oefenvormen -+ oercontinent -+ oergeweld -+ oerlandschap -+ oerlelijk -+ oerlelijke -+ oermodel -+ oermoeder -+ oernatuur -+ oersimpele -+ oerversie -+ oervogel -+ oesterbar -+ oesterkwekers -+ oetan -+ oetang -+ oetans -+ oeuvrecatalogus -+ oeuvreprijs -+ oeuvreprijzen -+ of zo -+ off -+ offerplaats -+ offerteaanvraag -+ offertetrajecten -+ officepakket -+ offrerend -+ offrerende -+ offschepen -+ offschip -+ offshore-installaties -+ offsysteem -+ offwedstrijd -+ okra -+ okra's -+ old -+ olie voor voedsel -+ olie-exporterend -+ olie-exporteurs -+ olie-installatie -+ olie-voor-voedselprogramma -+ olieaanvoer -+ oliebehoefte -+ oliebevoorrading -+ oliebranche -+ olieconsumptie -+ oliecontracten -+ oliefirma -+ oliefirma's -+ oliefonds -+ oliefraude -+ oliegeld -+ oliegestookte -+ oliegigant -+ oliegiganten -+ oliegroep -+ oliehandelaar -+ oliehandelaren -+ olieindustrie -+ olielek -+ olielekkage -+ olielekkages -+ olieleverancier -+ olieleveranties -+ olieminister -+ olieopbrengsten -+ olieopslag -+ olieopslagplaats -+ olieopslagplaatsen -+ oliepalmplantages -+ oliepeil -+ oliepijp -+ oliepijplijn -+ olieprijsdaling -+ olieprijsstijging -+ olieproductie -+ olieproject -+ olierekening -+ oliereserve -+ olieresten -+ oliereus -+ oliereuzen -+ olieschaarste -+ olieschok -+ olieschokken -+ oliesector -+ oliesmokkel -+ oliespoor -+ oliestad -+ oliestroom -+ olietekort -+ olieverkoop -+ olievervuiling -+ olievondst -+ olievondsten -+ olievoorraad -+ olievoorziening -+ olievrije -+ oliewaarden -+ oliewerkers -+ olifantenpoep -+ oligopolistische -+ olijfgaarden -+ om 's hemelswil -+ om en om -+ ombouwoperatie -+ ombudscommissie -+ ombudsdienst -+ ombudsdiensten -+ ombudsfunctie -+ ombudswerk -+ omdát -+ omerta -+ omgangshuis -+ omgangshuizen -+ omgevingskenmerk -+ omgevingskenmerken -+ omgevingslucht -+ omkatten -+ omkeerprocedé -+ omkoopzaak -+ omkopingspraktijken -+ omkopingszaak -+ omleidingsroute -+ ommanteling -+ omnummering -+ omranding -+ omrekeningskoers -+ omrekenkoers -+ omroepbeleid -+ omroepbesturen -+ omroepbestuurders -+ omroepdirecteuren -+ omroepgeld -+ omroepgelden -+ omroepinstelling -+ omroepjournalisten -+ omroepmaatschappij -+ omroepman -+ omroepmiddelen -+ omroeppersoneel -+ omroeppolitiek -+ omroeppolitieke -+ omroepprogrammagegevens -+ omroepreserve -+ omroepreserves -+ omroepstichting -+ omroeptientje -+ omroepverkiezingen -+ omroepzaken -+ omroepzuilen -+ omruilbod -+ omslagfoto -+ omslagsysteem -+ omvattender -+ omwisselbaar -+ omwisselbare -+ omzetdoelstelling -+ omzetdrempel -+ omzetgerelateerde -+ omzetrecord -+ omzetschade -+ omzetsprong -+ omzetstijgingen -+ omzettoename -+ omzetverdubbeling -+ omzetverliezen -+ omzetverwachting -+ omzetverwachtingen -+ omzetwaarschuwing -+ on-Hollandser -+ onaangelijnd -+ onaanraakbaren -+ onafhankelijkheidsleider -+ onafhankelijkheidsstrijder -+ onbeschikbaar -+ onbetekenends -+ onder meer -+ onderaanneming -+ onderbemanning -+ onderbenutting -+ onderbetaling -+ onderbord -+ onderborden -+ onderbuikgevoel -+ ondercapaciteit -+ ondercommandant -+ onderduikster -+ ondergeschoffeld -+ onderhandelingsfase -+ onderhandelingsmacht -+ onderhandelingsmandaat -+ onderhandelingspartijen -+ onderhandelingsperiode -+ onderhandelingspunten -+ onderhandelingsresultaten -+ onderhandelingsspel -+ onderhandelingstactiek -+ onderhandelingsteam -+ onderhoudsafdeling -+ onderhoudsbijdrage -+ onderhoudsbudget -+ onderhoudsfonds -+ onderhoudsgeld -+ onderhoudsgevoelig -+ onderhoudsklachten -+ onderhoudstechnicus -+ onderhoudstoestand -+ onderhoudsuitkeringen -+ onderlingen -+ ondernemerscultuur -+ ondernemersklimaat -+ ondernemerskringen -+ ondernemersprijs -+ ondernemersvereniging -+ ondernemersverenigingen -+ ondernemersvertrouwen -+ ondernemersvrijheid -+ ondernemings -+ ondernemingsbestuur -+ ondernemingscultuur -+ ondernemingspensioenfonds -+ ondernemingspensioenfondsen -+ ondernemingsrisico -+ ondernemingsstructuur -+ ondernemingsvermogen -+ ondernemingswereld -+ ondernemingswinsten -+ onderpresteren -+ onderraad -+ onderrapportage -+ onderrug -+ onderschepping -+ onderscheppingen -+ onderscheppingsraketten -+ onderschrijvers -+ onderschrijving -+ onderstaatssecretaris -+ ondersteuner -+ onderverhuring -+ onderverzekering -+ ondervoeden -+ onderwaarde -+ onderwater -+ onderwaterbodems -+ onderwaterleven -+ onderwerpregel -+ onderwijs-cao -+ onderwijsachterstand -+ onderwijsachterstanden -+ onderwijsachterstandenbeleid -+ onderwijsakkoord -+ onderwijsautoriteiten -+ onderwijsbegeleidingsdienst -+ onderwijsbond -+ onderwijsbudget -+ onderwijscarrière -+ onderwijscentrum -+ onderwijsconcept -+ onderwijscultuur -+ onderwijsdebat -+ onderwijsdeelname -+ onderwijsdoeleinden -+ onderwijsdoelen -+ onderwijsfonds -+ onderwijsgebied -+ onderwijsgebouw -+ onderwijsgebouwen -+ onderwijsgeld -+ onderwijsgelden -+ onderwijshervorming -+ onderwijshervormingen -+ onderwijshuisvesting -+ onderwijsinhoudelijke -+ onderwijsinspecteur -+ onderwijsinspecteurs -+ onderwijsinstanties -+ onderwijsinvesteringen -+ onderwijsklimaat -+ onderwijskoepels -+ onderwijskosten -+ onderwijskwaliteit -+ onderwijsland -+ onderwijslandschap -+ onderwijsloopbaan -+ onderwijsmarkt -+ onderwijsmateriaal -+ onderwijsminister -+ onderwijsmodel -+ onderwijsmogelijkheden -+ onderwijsnetwerk -+ onderwijsniveau -+ onderwijsniveaus -+ onderwijsnummer -+ onderwijsplan -+ onderwijsplannen -+ onderwijsprestaties -+ onderwijsprijs -+ onderwijsproces -+ onderwijsresultaten -+ onderwijssalarissen -+ onderwijssector -+ onderwijssoftware -+ onderwijssoort -+ onderwijssoorten -+ onderwijsstelsel -+ onderwijstaal -+ onderwijsteam -+ onderwijstijd -+ onderwijstype -+ onderwijsuitgaven -+ onderwijsvernieuwing -+ onderwijsvrijheid -+ onderwijswereld -+ onderwijswethouder -+ onderwijswoordvoerder -+ onderzeedienst -+ onderzoekcentrum -+ onderzoekcommissie -+ onderzoekinstituten -+ onderzoekinstituut -+ onderzoeksafdeling -+ onderzoeksafdelingen -+ onderzoeksapparatuur -+ onderzoeksbedrijf -+ onderzoeksbelang -+ onderzoeksbeleid -+ onderzoeksbevoegdheden -+ onderzoeksbevoegdheid -+ onderzoeksbudgetten -+ onderzoekscapaciteit -+ onderzoekscel -+ onderzoekscijfers -+ onderzoekscoördinator -+ onderzoeksdaden -+ onderzoeksdirecteur -+ onderzoeksdoeleinden -+ onderzoeksdomein -+ onderzoeksdomeinen -+ onderzoeksdossier -+ onderzoeksdossiers -+ onderzoekseenheid -+ onderzoekservaring -+ onderzoeksfase -+ onderzoeksgeld -+ onderzoekshandelingen -+ onderzoeksinspanningen -+ onderzoeksinstanties -+ onderzoeksjournalist -+ onderzoeksjournalistiek -+ onderzoekslab -+ onderzoekslaboratorium -+ onderzoeksleider -+ onderzoekslijn -+ onderzoekslijnen -+ onderzoeksmateriaal -+ onderzoeksmatig -+ onderzoeksmissie -+ onderzoeksmogelijkheden -+ onderzoeksonderwerp -+ onderzoeksopdracht -+ onderzoeksorganisatie -+ onderzoeksorganisaties -+ onderzoeksperiode -+ onderzoeksplan -+ onderzoeksplannen -+ onderzoeksplicht -+ onderzoekspraktijk -+ onderzoeksprotocol -+ onderzoeksraad -+ onderzoeksreactor -+ onderzoeksreactoren -+ onderzoeksruimte -+ onderzoekssubsidies -+ onderzoekstafel -+ onderzoeksterreinen -+ onderzoeksuitkomsten -+ onderzoeksvaardigheden -+ onderzoeksvaardigheid -+ onderzoeksvoorstel -+ onderzoeksvoorstellen -+ onderzoekswereld -+ onderzoekswerk -+ ondeskundigen -+ ondode -+ ondoenbaar -+ ondragelijk -+ one -+ ong. -+ ongeadresseerde -+ ongebondenen -+ ongediplomeerden -+ ongedocumenteerde -+ ongedocumenteerden -+ ongekeurde -+ ongeldigverklaring -+ ongemakkentoeslag -+ ongemodereerd -+ ongepantserde -+ ongerechtigde -+ ongeschoolden -+ ongeteste -+ ongevallencijfers -+ ongewervelden -+ onheilsberichten -+ onheilsplek -+ onheilszwangere -+ onintuïtief -+ onintuïtieve -+ onislamitisch -+ onkraakbaar -+ onkraakbare -+ onleefbaarheid -+ onlineversie -+ onmiddellijkheid -+ onnozelen -+ ononderhandelbaar -+ ononderhandelbare -+ onov. -+ onov. ww. -+ onoverdraagbaarheid -+ onroerendezaakbelastingen -+ onroerendgoedfondsen -+ onsterfelijken -+ ontbijtgranen -+ ontbijtkamer -+ ontbijtprogramma -+ ontbindingsprocedure -+ ontbolstering -+ ontbundeling -+ ontdubbeling -+ ontelbaren -+ ontgifting -+ ontgrinding -+ ontgroeningsceremonie -+ ontgronder -+ ontgrondingsvergunning -+ onthaasting -+ ontheffingsregeling -+ onthutsender -+ ontkrachting -+ ontlezing -+ ontluisterender -+ ontmijning -+ ontnemingsvordering -+ ontnemingsvorderingen -+ ontnemingszaken -+ ontoegeeflijk -+ ontploffende -+ ontpoldering -+ ontraceerbaar -+ ontradend -+ ontradende -+ ontremming -+ ontslagbesluit -+ ontslagcommissie -+ ontslagdreiging -+ ontslagleeftijd -+ ontslagpremie -+ ontslagtoets -+ ontslagvergoeding -+ ontslagvergoedingen -+ ontslagverzoek -+ ontslakken -+ ontsluitingsroute -+ ontsluitingstechniek -+ ontsluitingstechnieken -+ ontsmettingsbak -+ ontsmettingsbakken -+ ontsmettingsmatten -+ ontsnappingskunstenaar -+ ontspannender -+ ontspanningsactiviteit -+ ontstekingsremmend -+ ontstekingsremmende -+ onttovering -+ ontuchtplegers -+ ontvangstcentrum -+ ontvangstkamer -+ ontvangstruimten -+ ontwapeningsbesprekingen -+ ontwapeningscommissie -+ ontwapeningsplan -+ ontwapeningsproces -+ ontwerpbeschikking -+ ontwerpbestemmingsplan -+ ontwerpbureaus -+ ontwerpersduo -+ ontwerpgrondwet -+ ontwerpkosten -+ ontwerpprogramma -+ ontwerprapport -+ ontwerpregeerakkoord -+ ontwerprichtlijn -+ ontwerpslotverklaring -+ ontwerpstrategie -+ ontwerpstreekplan -+ ontwerpstudio -+ ontwerpteam -+ ontwerpteams -+ ontwerptracébesluit -+ ontwerpwedstrijd -+ ontwijkgedrag -+ ontwikkelingsafdelingen -+ ontwikkelingsamenwerking -+ ontwikkelingsbedrijf -+ ontwikkelingsbudget -+ ontwikkelingscentrum -+ ontwikkelingscombinatie -+ ontwikkelingsdoeleinden -+ ontwikkelingsinspanningen -+ ontwikkelingskrediet -+ ontwikkelingskredieten -+ ontwikkelingsmaatschappijen -+ ontwikkelingsmodel -+ ontwikkelingspotentieel -+ ontwikkelingsproblematiek -+ ontwikkelingsproblemen -+ ontwikkelingsprogramma -+ ontwikkelingsrelatie -+ ontwikkelingsroman -+ ontwikkelingssteden -+ ontwikkelingsstrategie -+ ontwikkelingsstudies -+ ontwikkelingstijd -+ ontwikkelingstraject -+ ontwikkelingsverdrag -+ ontwikkelingsvisie -+ ontwikkelingsvraagstukken -+ ontwikkelkosten -+ ontwikkelmethode -+ ontwikkelmethoden -+ ontwikkelmethodes -+ ontwikkelmodel -+ ontwikkelmodellen -+ ontwikkelteam -+ ontwikkelteams -+ ontzanden -+ ontzander -+ ontzilting -+ ontziltingsinstallaties -+ onveiligheidsgevoel -+ onverplichtende -+ onverrichter zake -+ onverschilligen -+ onvertraagd -+ onverzoenlijken -+ onvoorwaardelijkheid -+ onwilligen -+ onzes inziens -+ onzinkbare -+ oogaandoening -+ oogaandoeningen -+ oogbewegingen -+ oogkliniek -+ oogkwaal -+ oogonderzoek -+ oogproblemen -+ oogstperiode -+ oogstverwachtingen -+ oogstwoord -+ oogstwoorden -+ oorflappen -+ oorlog voeren -+ oorlogsacties -+ oorlogsarchieven -+ oorlogsbeelden -+ oorlogsclaims -+ oorlogscriminelen -+ oorlogsdag -+ oorlogsdoden -+ oorlogsdoelen -+ oorlogsdrama -+ oorlogsepos -+ oorlogservaring -+ oorlogsfront -+ oorlogsgeschiedenis -+ oorlogshitser -+ oorlogshitsers -+ oorlogsinspanning -+ oorlogsinspanningen -+ oorlogsjournalistiek -+ oorlogskabinet -+ oorlogskind -+ oorlogskunst -+ oorlogsleed -+ oorlogsleider -+ oorlogsmunitie -+ oorlogsnieuws -+ oorlogsperiode -+ oorlogspremier -+ oorlogssfeer -+ oorlogssituatie -+ oorlogssituaties -+ oorlogsspel -+ oorlogsstemming -+ oorlogsstrategie -+ oorlogstrofeeën -+ oorlogsverhalen -+ oorlogsverslaggever -+ oorlogsvrijwilliger -+ oorlogswonden -+ oorlogszone -+ oorlogszones -+ oorstrelend -+ oorstukjes -+ oorsuizen -+ oorthermometer -+ oost-west -+ oost-westbaan -+ oostbloklanden -+ oostflank -+ oostoever -+ oosttangent -+ oostvleugel -+ op ad-hocbasis -+ op de bonnefooi -+ op ooghoogte -+ op uitleenbasis -+ op zichzelf -+ opbergvakken -+ opbotst -+ opbouwjaren -+ opbouwperiode -+ opbrekingen -+ opdrachtenbeleid -+ opdrachtgevende -+ opdrachtgeverschap -+ opdrachtnemer -+ opdrachtverklaring -+ opeengepropt -+ open source -+ openbaar maken -+ openbaargemaakt -+ openbaarvervoerbedrijf -+ openbaarvervoerbedrijven -+ openbloeien -+ opendeurbeleid -+ openingsact -+ openingsartikel -+ openingsavond -+ openingsdoelpunt -+ openingsduel -+ openingsetappe -+ openingsfeest -+ openingsfestiviteiten -+ openingsfilm -+ openingsgedicht -+ openingshandeling -+ openingshoofdstuk -+ openingsklassieker -+ openingslied -+ openingsmanifestatie -+ openingsmatch -+ openingsnummer -+ openingspagina -+ openingsprogramma -+ openingsrit -+ openingsronde -+ openingssessie -+ openingstheorie -+ openingsvarianten -+ openingsverhaal -+ openingsvoorbereiding -+ openingsweekeinde -+ openingsweekend -+ openklappen -+ openluchttentoonstelling -+ opensourcelicentie -+ opensourceprogramma -+ opensourceprogramma's -+ opensourceproject -+ opensourceprojecten -+ opensourcesoftware -+ openstellingstijden -+ operadiva -+ operafestival -+ operafragmenten -+ operaklas -+ operakostuums -+ operaliefhebbers -+ operaproductie -+ operatheater -+ operatieassistenten -+ operatiecapaciteit -+ operatietechniek -+ operatietechnieken -+ operatieterrein -+ operawereld -+ opfrisbeurt -+ opgavenverplichting -+ opgaveverplichtingen -+ opgemelde -+ opgeroepenen -+ ophaalsysteem -+ ophaling -+ ophoogzand -+ ophouding -+ opiniestukken -+ opinio -+ opinion -+ opiumproductie -+ opiumteelt -+ opkan -+ opkomstdrempel -+ oplaadpunten -+ oplaaiend -+ oplagedaling -+ opleidingsbedrijf -+ opleidingscapaciteit -+ opleidingscoördinator -+ opleidingsfonds -+ opleidingsgraad -+ opleidingskamp -+ opleidingsploeg -+ opleidingsprojecten -+ opleidingsrichting -+ opleidingssysteem -+ opleidingstraject -+ opleidingstrajecten -+ opleverdatum -+ oplichtingspraktijk -+ oplichtingszaak -+ opmaakprofiel -+ opmaakprofielen -+ opnamecriteria -+ opnamecriterium -+ opnamedag -+ opnamefuncties -+ opnamekwaliteit -+ opnameperiode -+ opnamesessies -+ oppervlakteschepen -+ opponente -+ opportuniteiten -+ opportuniteitsbeginsel -+ oppositiebeweging -+ oppositiebewegingen -+ oppositiefiguren -+ oppositiegroep -+ oppositiegroepen -+ oppositiegroeperingen -+ oppositiekandidaat -+ oppositiekandidaten -+ oppositiekrant -+ oppositiekuur -+ oppositieleden -+ oppositielid -+ oppositierol -+ oprichter-directeur -+ oprichtingsdatum -+ oproepcontract -+ oproepcontracten -+ oproepnummer -+ opruimingskosten -+ opruimplicht -+ opruimwerk -+ opslagdepot -+ opslagsystemen -+ opslagvat -+ opsommingstekens -+ opspoorbaar -+ opsporingsactiviteiten -+ opsporingsbelang -+ opsporingsbevel -+ opsporingscapaciteit -+ opsporingseenheid -+ opsporingshandelingen -+ opsporingsinstantie -+ opsporingsmogelijkheden -+ opsporingsprogramma -+ opsporingssysteem -+ opsporingsverzoek -+ opstapcursus -+ opstappunt -+ opstartend -+ opstartende -+ opstartkosten -+ opstelplaatsen -+ opt -+ opt-in -+ opt-out -+ optieconstructies -+ optiehouder -+ optiepakket -+ optiepakketten -+ optieplan -+ optieplannen -+ optieprijs -+ optieprogramma -+ optieprogramma's -+ optieregeling -+ optieregelingen -+ optieseries -+ optrekking -+ opvangadres -+ opvangbekkens -+ opvangbeleid -+ opvangcapaciteit -+ opvangfaciliteiten -+ opvangfunctie -+ opvanginstellingen -+ opvangkosten -+ opvangmodel -+ opvangmoeder -+ opvangorganisatie -+ opvangplaats -+ opvangplek -+ opvangplekken -+ opvangproblemen -+ opvangprogramma -+ opvangproject -+ opvangprojecten -+ opvangregeling -+ opvangruimte -+ opvangvoorziening -+ opvoedcursus -+ opvoedcursussen -+ opvoedingsondersteuning -+ opvoedingssituatie -+ opvoedingsstijl -+ opvoedingstaak -+ opvulteken -+ opvultekens -+ opwekkingsbron -+ opwekkingsliederen -+ opwerkingscontracten -+ opwerkingsfabrieken -+ opzeggingstermijn -+ opzeggingsvergoeding -+ orang -+ oranje-bruin -+ oranje-gele -+ oranjebruin -+ oranjebruine -+ oranjegeel -+ oranjegele -+ oranjetruidrager -+ oratio -+ orbi -+ ordemaatregelen -+ ordergedreven -+ orgaanhandel -+ orgaanuitname -+ organisatieafhankelijk -+ organisatieafhankelijke -+ organisatiecultuur -+ organisatiegrens -+ organisatiegrenzen -+ organisatiekosten -+ organisatienaam -+ organisatienamen -+ organochloorverbindingen -+ orgelklanken -+ orgelwerken -+ oriëntatiejaar -+ orkaanseizoen -+ orkaanwinden -+ orkestenbestel -+ orkestmusici -+ orkestrepertoire -+ orthodox-islamitisch -+ orthodox-islamitische -+ osteopaten -+ oud-ambtenaren -+ oud-atleet -+ oud-bestuurders -+ oud-bewindslieden -+ oud-bewoners -+ oud-communistische -+ oud-dictator -+ oud-directeuren -+ oud-eurocommissaris -+ oud-hoofdcommissaris -+ oud-informateur -+ oud-inspecteur -+ oud-inwoners -+ oud-kampioene -+ oud-koloniën -+ oud-korpschef -+ oud-leerkrachten -+ oud-linkse -+ oud-marineman -+ oud-mijnwerkers -+ oud-minister-president -+ oud-ministers -+ oud-monopolist -+ oud-notaris -+ oud-ondernemer -+ oud-regeringsleider -+ oud-renners -+ oud-schaatser -+ oud-secretaris-generaal -+ oud-sporters -+ oud-staatshoofd -+ oud-testamentische -+ oud-vakbondsbestuurder -+ oud-vicepremier -+ oud-vicepresident -+ oud-voetballers -+ oud-voorzitters -+ oud-werkgever -+ oud-werknemers -+ oud-wethouders -+ oud-zwemster -+ ouder gewoonte -+ oudercomité -+ ouderdieren -+ ouderdomsdiabetes -+ ouderdomsgebrek -+ ouderdomsgebreken -+ ouderdomssuikerziekte -+ ouderenadviseur -+ ouderenadviseurs -+ ouderenaftrek -+ ouderenbeleid -+ ouderenkoor -+ ouderenkorting -+ ouderenmishandeling -+ ouderenpartijen -+ ouderenpsychiatrie -+ ouderenraad -+ ouderenvoorzieningen -+ ouderenwoningen -+ oudervogels -+ oudjaarsdag -+ outen -+ outs -+ outsiderkunst -+ outsourcen -+ outsourcing -+ outsyndroom -+ outsysteem -+ ov-bedrijven -+ ovariumkanker -+ over the counter -+ overambitieuze -+ overbedeeld -+ overbegrazing -+ overbehandeling -+ overbeharing -+ overbelading -+ overbemande -+ overbetaald -+ overbetaalde -+ overbezorgdheid -+ overboord gooien -+ overbruggingsuitkering -+ overconsumptie -+ overeenstemmend -+ overerfbaar -+ overexploitatie -+ overexposure -+ overgangsbestuur -+ overgangsbewind -+ overgangscontract -+ overgangsjaar -+ overgangskabinet -+ overgangsklasse -+ overgangsparlement -+ overgangsproblemen -+ overgangsproces -+ overgangsraad -+ overgangsregel -+ overgangsregels -+ overgangssituatie -+ overgangstermijn -+ overgangstermijnen -+ overgangszone -+ overgekocht -+ overgekochte -+ overgeplakt -+ overgeproduceerde -+ overgetypte -+ overgronden -+ overgrondt -+ overheidsaanbestedingen -+ overheidsaandeel -+ overheidsaandelen -+ overheidsactiviteiten -+ overheidsagentschap -+ overheidsbaan -+ overheidsbanen -+ overheidsbanken -+ overheidsbegroting -+ overheidsbegrotingen -+ overheidsbelang -+ overheidsbescherming -+ overheidsbeslissingen -+ overheidsbesluit -+ overheidsbesluiten -+ overheidsbestellingen -+ overheidsbestuur -+ overheidsbezit -+ overheidsbezuinigingen -+ overheidsbudget -+ overheidsbudgetten -+ overheidsbureau -+ overheidscampagne -+ overheidscommissaris -+ overheidscommissarissen -+ overheidscommissie -+ overheidscommunicatie -+ overheidsconsumptie -+ overheidscontracten -+ overheidsdotatie -+ overheidsdwang -+ overheidseigendom -+ overheidseisen -+ overheidsfonds -+ overheidsfunctie -+ overheidsfuncties -+ overheidsfunctionaris -+ overheidsgarantie -+ overheidsgebouw -+ overheidshandelen -+ overheidsholding -+ overheidshulp -+ overheidsinformatie -+ overheidsinitiatief -+ overheidsinmenging -+ overheidsinstituut -+ overheidsinterventie -+ overheidsinterventies -+ overheidsinvestering -+ overheidskantoren -+ overheidskas -+ overheidskosten -+ overheidskredieten -+ overheidsleningen -+ overheidsmacht -+ overheidsmanagement -+ overheidsmiddelen -+ overheidsmonopolie -+ overheidsniveau -+ overheidsniveaus -+ overheidsobligatie -+ overheidsobligaties -+ overheidsonderneming -+ overheidsondernemingen -+ overheidsonderzoek -+ overheidsopdracht -+ overheidsoptreden -+ overheidsorganisatie -+ overheidspapier -+ overheidsplannen -+ overheidsprogramma -+ overheidsprogramma's -+ overheidsproject -+ overheidsprojecten -+ overheidspropaganda -+ overheidspublicatie -+ overheidspublicaties -+ overheidsrapport -+ overheidsregulering -+ overheidsrol -+ overheidssalarissen -+ overheidsstukken -+ overheidssturing -+ overheidstaak -+ overheidstaken -+ overheidsvertegenwoordigers -+ overheidswerkgevers -+ overheidszijde -+ overhoekjes -+ overingetekend -+ overkluizing -+ overkoepeling -+ overkomstduur -+ overkopen -+ overlastbestrijding -+ overlastgevende -+ overlastveroorzakers -+ overlegcomité -+ overlegforum -+ overleggroep -+ overlegronde -+ overlegronden -+ overlegrondes -+ overlegstelsel -+ overlegtafel -+ overlevingskracht -+ overlevingskunst -+ overlevingsstrategie -+ overlevingsstrategieën -+ overlijdensdekking -+ overlijdensgevallen -+ overlijdensrisico -+ overlijdensrisicoverzekering -+ overnamebedrag -+ overnamebeleid -+ overnamebiedingen -+ overnamedoelwit -+ overnamegesprekken -+ overnamegevecht -+ overnamegolf -+ overnamekandidaat -+ overnamekandidaten -+ overnamekansen -+ overnamekoorts -+ overnamemarkt -+ overnamenieuws -+ overnamepad -+ overnamepartner -+ overnameplan -+ overnameplannen -+ overnamepoging -+ overnamepogingen -+ overnamepolitiek -+ overnamepremie -+ overnamepremies -+ overnameproces -+ overnameprooi -+ overnameprooien -+ overnameregels -+ overnameslag -+ overnamespeculatie -+ overnamespeculaties -+ overnamestrategie -+ overnamevoorstel -+ overnamewetgeving -+ overpopulatie -+ overreserves -+ overrijpheid -+ overrompelingstactiek -+ overschrijvingskaart -+ overslagplaats -+ overslagplaatsen -+ overslagpunt -+ overslagterminal -+ overslagterminals -+ oversluiten -+ oversluitingen -+ overspeligen -+ overstapplaats -+ overstorten -+ overstromingsrisico -+ overtekening -+ overtolligen -+ overvaltactiek -+ overvaltechniek -+ oververkocht -+ overwinningspremie -+ overzichtslijst -+ overzichtsniveau -+ overzichtstekening -+ overzichtstekeningen -+ oxytocine -+ ozb -+ ozb-aanslag -+ ozb-belasting -+ ozb-opbrengst -+ ozb-tarief -+ ozb-tarieven -+ p'tjes -+ p.m. -+ p.o. -+ p.p. -+ p.w. -+ paaigronden -+ paardenhoofd -+ paardenhouderij -+ paardenkarren -+ paardenkoers -+ paardenkoets -+ paardenpoep -+ paardenwereld -+ paars-groen -+ paars-wit -+ paars-witte -+ paasbestand -+ paasboodschap -+ paasdatum -+ paasreces -+ pachtprijs -+ pachtprijzen -+ pachtsysteem -+ paddenpoel -+ paddenpoelen -+ paddenstoelenzoeker -+ paddenstoeltjes -+ pag. -+ pager -+ pagers -+ pagina-einde -+ paginabreedte -+ paginaformaat -+ paginaformaten -+ paginagrootte -+ paginamarges -+ pakjesbezorger -+ pakjesdienst -+ pakkender -+ pakketpolis -+ pakketzegel -+ pakketzegels -+ pakkie-an -+ paleize -+ palfium -+ palingkwekerij -+ palingrokerij -+ palingsound -+ palingstand -+ palingvissers -+ paneuropese -+ pangang -+ paniekaanval -+ paniekaanvallen -+ panieksituaties -+ paniekverhalen -+ paniekverkopen -+ pantserinfanterie -+ papaverteelt -+ papavervelden -+ papierbedrijf -+ papierloos -+ papierloze -+ papiermaker -+ papiermakers -+ papierprijs -+ papierproducent -+ papierproducenten -+ papiersector -+ papierslib -+ papierstroom -+ papierverlies -+ papierwerk -+ para-tbc -+ paracommercie -+ paraglider -+ parallelbanen -+ paramilitairen -+ parenclub -+ parfumeriezaak -+ parfumeriezaken -+ parfumindustrie -+ parfumlijn -+ paribus -+ paringsritueel -+ parkeerbedrijf -+ parkeerbelasting -+ parkeerbeleid -+ parkeercontrole -+ parkeerdak -+ parkeerfaciliteiten -+ parkeerfonds -+ parkeergedrag -+ parkeerkosten -+ parkeerlaag -+ parkeermaatregelen -+ parkeermogelijkheden -+ parkeernorm -+ parkeernormen -+ parkeernota -+ parkeeroverlast -+ parkeerplan -+ parkeerplek -+ parkeerplekken -+ parkeerproblematiek -+ parkeerregeling -+ parkeerrem -+ parkeersituatie -+ parkeertarief -+ parkeertijd -+ parkeervoorziening -+ parket-generaal -+ parketmagistraat -+ parketmagistraten -+ parketsecretaris -+ parketwoordvoerder -+ parkgebied -+ parkinson -+ parkjes -+ parlementaire-enquêtecommissie -+ parlementscommissie -+ parlementscommissies -+ parlementskandidaat -+ parlementskandidaten -+ parlementszetel -+ parmezaankaas -+ parochiecentrum -+ pars pro toto -+ parti -+ participatiebedrijf -+ participatiefonds -+ participation -+ particratie -+ partij kiezen -+ partijafdeling -+ partijafdelingen -+ partijbaronnen -+ partijbasis -+ partijencoalitie -+ partijenovereenkomst -+ partijenpost -+ partijfuncties -+ partijgebouw -+ partijgelederen -+ partijgeledingen -+ partijgeschiedenis -+ partijhoofdkwartier -+ partijkantoor -+ partijkantoren -+ partijkeuze -+ partijkoers -+ partijkopstukken -+ partijleiderschap -+ partijlijn -+ partijlijnen -+ partijlijsten -+ partijmachine -+ partijmensen -+ partijpoliticus -+ partijprominenten -+ partijstatuten -+ partijstelling -+ partijstrategen -+ partijstructuren -+ partijstructuur -+ partijtijgers -+ partijtrouw -+ partijverbod -+ partijvergadering -+ partijverkiezingen -+ partijvernieuwing -+ partijvertegenwoordigers -+ partijvlag -+ partijvlaggen -+ partijvoorzitster -+ partijwezen -+ partnerbedrijf -+ partnerregistratie -+ partnerschapsregistratie -+ partnerstad -+ partnertoeslag -+ partout -+ partoutje -+ partouts -+ partyschepen -+ pas op de plaats -+ pascal -+ pasgebouwde -+ pashouder -+ paso -+ paspoortaffaire -+ paspoortfraude -+ paspoortgegevens -+ paspoortproject -+ paspoortsysteem -+ paspoortwet -+ passagiere -+ passagiersaantal -+ passagiersafhandeling -+ passagiersbus -+ passagiersgroei -+ passagiersruimte -+ passagiersstoel -+ passagiersstromen -+ passagiersterminal -+ passantenonderzoek -+ passiefzijde -+ passieverhaal -+ passievol -+ passionnel -+ pastafabrikant -+ pasteuze -+ pastorietuin -+ pasverworven -+ patates -+ patentaanvraag -+ patenteerbaar -+ patentering -+ pater Damiaan -+ pater Eustachius -+ patience spelen -+ patiencespel -+ patisson -+ patiëntengegevens -+ patiëntengroep -+ patiëntengroepen -+ patiëntenrecht -+ patiëntenrechten -+ patiëntenwet -+ patiëntvriendelijker -+ patrimoniumvennootschap -+ pats-boem -+ pausreis -+ pauzeknop -+ pavlovreactie -+ pay -+ pay-per-view -+ pc-afdeling -+ pc-divisie -+ pc-fabrikant -+ pc-gebruik -+ pc-gebruiker -+ pc-gebruikers -+ pc-industrie -+ pc-kaart -+ pc-makers -+ pc-markt -+ pc-privéproject -+ pc-scherm -+ pc-verkoop -+ pc-verkoper -+ pdf -+ peacekeeping -+ peau -+ pecannoten -+ pechgevallen -+ pechverhelping -+ pectoris -+ pedofilienetwerk -+ pedofilienetwerken -+ pedofiliezaak -+ pedofiliezaken -+ pedoseksualiteit -+ pedoseksueel -+ pedoseksuele -+ pedoseksuelen -+ peer-to-peernetwerk -+ peernetwerk -+ peilbuizen -+ peilzender -+ peilzenders -+ pennenproef -+ pensioenadviseurs -+ pensioenafspraken -+ pensioenbedrag -+ pensioenbedragen -+ pensioenberekening -+ pensioenbesparingen -+ pensioenbetalingen -+ pensioendeskundige -+ pensioendossier -+ pensioengebied -+ pensioengeld -+ pensioengerechtigden -+ pensioenhervorming -+ pensioenhervormingen -+ pensioeninkomen -+ pensioeninstelling -+ pensioenjaren -+ pensioenkapitaal -+ pensioenkapitalen -+ pensioenkosten -+ pensioenland -+ pensioenlast -+ pensioenlasten -+ pensioenmarkt -+ pensioenpijler -+ pensioenplan -+ pensioenplicht -+ pensioenpot -+ pensioenprobleem -+ pensioenproblematiek -+ pensioenproducten -+ pensioenreparatie -+ pensioensector -+ pensioenspaarfonds -+ pensioenspaarfondsen -+ pensioenstelsel -+ pensioensysteem -+ pensioensystemen -+ pensioentekort -+ pensioentekorten -+ pensioentoezegging -+ pensioentoezeggingen -+ pensioenuitgaven -+ pensioenuitvoerder -+ pensioenuitvoerders -+ pensioenverlies -+ pensioenvermogen -+ pensioenverplichtingen -+ pensioenverzekeraar -+ pensioenverzekeraars -+ pensioenwereld -+ pensioenwetgeving -+ penster -+ pentiti -+ people -+ peperspray -+ pept -+ per capita -+ per se -+ perceelsgrenzen -+ perchloorethyleen -+ percussief -+ percussiemuziek -+ percussieve -+ perdue -+ performant -+ performante -+ performantie -+ performen -+ periodekampioenschap -+ permetrine -+ perpetuum -+ persartikelen -+ persbeleid -+ persboycot -+ perscontacten -+ perscorps -+ persdag -+ perserij -+ persgroep -+ persjury -+ persleger -+ perslekken -+ persluchtapparatuur -+ persluchtmaskers -+ perslunch -+ persmagnaat -+ persmededeling -+ persona -+ persona non grata -+ personae -+ personal -+ personaliseren -+ personalisering -+ personeelsaantal -+ personeelsaantallen -+ personeelsbijeenkomsten -+ personeelsdirecteur -+ personeelsgebied -+ personeelsgroei -+ personeelsinzet -+ personeelskrapte -+ personeelsomvang -+ personeelsopties -+ personeelsreductie -+ personeelsreducties -+ personeelsruimte -+ personeelsstatuut -+ personeelsuitgaven -+ personeelswisselingen -+ personenalarmering -+ personencontrole -+ personencontroles -+ persontmoeting -+ persoonlijkheidsonderzoek -+ persoonlijkheidsrechten -+ persoonlijkheidstest -+ persoonscontrole -+ persoonsgericht -+ persoonsgerichte -+ persoonslijst -+ perspresentatie -+ persreis -+ persruimte -+ persverantwoordelijke -+ persvereniging -+ pesocrisis -+ pester -+ pesters -+ pestgebieden -+ pestgedrag -+ pestgevallen -+ pestvirus -+ petfood -+ petit -+ petroleumprijzen -+ petroleumsector -+ peuterleeftijd -+ peuteropvang -+ peuterspeelzaalwerk -+ peutertijd -+ peyote -+ pfff -+ pianoconcerto -+ pianoklank -+ pianopartijen -+ pianostukken -+ pianowerk -+ pianowerken -+ pick -+ pico bello -+ picogram -+ pied -+ piekarbeid -+ piekjaar -+ piekniveau -+ piekvraag -+ piercers -+ pierenbadje -+ pierrotjes -+ pijnbehandeling -+ pijnboompitten -+ pijncentrum -+ pijnkliniek -+ pijnlijders -+ pijnpuntje -+ pijnstilling -+ pijnvrij -+ pilootproject -+ pilootprojecten -+ pilootwinkel -+ pilot -+ pilotenstaking -+ pilotenvakbond -+ pilotenvereniging -+ pilotproject -+ pilotprojecten -+ pilots -+ pinbetalingen -+ pince -+ pintransacties -+ pionierend -+ pionierende -+ pioniersgroep -+ pionierstijd -+ piramidefondsen -+ piramidespelen -+ piratenfilm -+ pizzabezorgers -+ pièce -+ pièces -+ plaagdieren -+ plaaginsecten -+ plaatdelen -+ plaats delict -+ plaatsaanduiding -+ plaatser -+ plaatsingsbesluit -+ plaatsingslijst -+ plaatsingswedstrijden -+ plaatsten -+ place -+ places -+ plafondhoogte -+ plain -+ plan de campagne -+ plangebied -+ plankaart -+ planmatigheid -+ planontwikkeling -+ planperiode -+ planschadevergoeding -+ plantafstand -+ plantafstanden -+ plantageholding -+ plantagehouders -+ plantencollectie -+ plantengenetica -+ plantenmateriaal -+ plantenresten -+ plantenwortels -+ plantgoedbehandeling -+ plantmateriaal -+ planvoorbereiding -+ planvorming -+ plasbuis -+ plasmascherm -+ plasmaschermen -+ plastuit -+ plateauschoenen -+ platenbonzen -+ platencollectie -+ platenfirma -+ platenkast -+ platenkopers -+ platenproducenten -+ platenproducer -+ platenverkoop -+ platenwereld -+ plattelandsbeleid -+ plattelandsdorp -+ plattelandseconomie -+ plattelandsgebied -+ plattelandstoerisme -+ plattelandsvernieuwing -+ plattelandswegen -+ plattere -+ platvorm -+ play -+ plaît -+ plejade -+ pletwals -+ plezierjagers -+ pleziervaarders -+ plm. -+ ploegbelang -+ ploegdokter -+ ploegenachtervolging -+ ploegenklassement -+ ploegenspel -+ ploegensysteem -+ ploeggenote -+ ploegkoers -+ ploegleden -+ ploegleiderswagen -+ ploegleiding -+ ploegmanager -+ ploegpresentatie -+ plotlijnen -+ plotwending -+ plotwendingen -+ pluimveemest -+ pluimveesector -+ pluimveevlees -+ pluk-ze-wetgeving -+ plume -+ plurale -+ pluspakket -+ pluspakketten -+ pluspion -+ plv. -+ pocketreeks -+ pocketreeksen -+ pocus -+ podiumact -+ podiumbeest -+ podiumdebuut -+ podiumkunstenaar -+ podiumplaats -+ podiumplaatsen -+ podotherapeut -+ poederbrief -+ poederbrieven -+ pofferd -+ pokerspeler -+ pokkenvaccin -+ polderbewoners -+ polderdorp -+ polderdorpen -+ polderhuis -+ polderoverleg -+ polderstad -+ poliswaarde -+ politie-cao -+ politie-infiltrant -+ politie-informant -+ politie-inzet -+ politieactie -+ politieafdelingen -+ politieambtenaar -+ politieambtenaren -+ politieautoriteiten -+ politiebegroting -+ politiebeleid -+ politiebestanden -+ politiebestel -+ politiebevoegdheden -+ politiebezoek -+ politiebron -+ politiebronnen -+ politiebudget -+ politiecapaciteit -+ politiechef -+ politiecommandant -+ politiecommissariaat -+ politiecontacten -+ politiecontrole -+ politiecordon -+ politiecultuur -+ politiedeskundigen -+ politiedetective -+ politiedossier -+ politiedossiers -+ politieduo -+ politiedwang -+ politiefunctionaris -+ politiegebouw -+ politiegeweld -+ politiehervorming -+ politiehulp -+ politiek-bestuurlijk -+ politiek-bestuurlijke -+ politiek-correcte -+ politiek-cultureel -+ politiek-culturele -+ politiek-diplomatieke -+ politiek-filosofische -+ politiek-historische -+ politiek-inhoudelijk -+ politiek-inhoudelijke -+ politiek-militair -+ politiek-militaire -+ politiek-morele -+ politiek-psychologisch -+ politiek-psychologische -+ politiek-religieuze -+ politiek-sociale -+ politiek-strategisch -+ politiek-strategische -+ politiekapel -+ politiekazerne -+ politiekeurmerk -+ politiekolonel -+ politiekorpschef -+ politiekosten -+ politieland -+ politieleiding -+ politielint -+ politiemedewerker -+ politiemedewerkers -+ politiemeldkamer -+ politieminister -+ politieministers -+ politiemonitor -+ politienummer -+ politieofficier -+ politieofficieren -+ politieonderwijs -+ politieoorlog -+ politieoperatie -+ politieopleiding -+ politieorganisatie -+ politieorganisaties -+ politiepak -+ politieperskaart -+ politiepraktijk -+ politieprefect -+ politierechercheurs -+ politieregisters -+ politiereorganisatie -+ politiesamenwerking -+ politiescanner -+ politiestation -+ politiestatistieken -+ politiesterkte -+ politiestructuur -+ politiesurveillance -+ politiesurveillant -+ politiesurveillanten -+ politiesysteem -+ politietaak -+ politieteam -+ politieteams -+ politiethriller -+ politietop -+ politievak -+ politievakbond -+ politievakbonden -+ politieversterking -+ politievoertuigen -+ politievoorlichter -+ politiewereld -+ politiewerk -+ politiezone -+ politiezorg -+ polsbanden -+ polsbandje -+ polycarbonaat -+ polyfenolen -+ polyglotbijbel -+ polymorfismen -+ polypropeen -+ polyurethaanschuim -+ polyvalentie -+ pompoenlampion -+ pompoenlampionnen -+ pompoenpitten -+ pompoensoep -+ ponymarkt -+ poolcentrum -+ pop-cd -+ pop-lp -+ popact -+ popalbum -+ popblad -+ popcentrum -+ popdeuntjes -+ popdiva -+ popduo -+ popelpee -+ popfans -+ popformatie -+ popgeschiedenis -+ pophit -+ pophits -+ popijopies -+ popindustrie -+ popjournalist -+ popjournalistiek -+ popklassiekers -+ poplegende -+ poplied -+ popliefhebber -+ popnummer -+ popnummers -+ poppenfilm -+ poppenkastfiguren -+ poppenkastfiguur -+ poppenserie -+ poppers -+ popplaat -+ popplaten -+ poppodia -+ poppodium -+ popprijs -+ popquiz -+ poprock -+ poptempel -+ poptijdschrift -+ populariteitstest -+ populierenbos -+ popwereld -+ pornobaas -+ pornobedrijf -+ pornokoning -+ pornosite -+ pornowereld -+ porseleinfabriek -+ portaalsite -+ portaalsites -+ portalsite -+ portefeuillebeheer -+ portefeuillesamenstelling -+ portiekflat -+ portiekflats -+ portretformaat -+ portretfoto -+ positief-kritisch -+ positiviteit -+ postagenten -+ postbedeling -+ postbedrijf -+ postbedrijven -+ postbusadres -+ postcodegebied -+ postcodegebieden -+ postcodeloterij -+ postcommunisten -+ poste -+ posteriori -+ postfascisten -+ postgebouw -+ postmarkt -+ postorderaar -+ postorderservice -+ postorderverkoop -+ postpakken -+ postpunk -+ postsector -+ postsorteercentra -+ postsorteercentrum -+ poststemmen -+ poststroom -+ posttraumatisch stresssyndroom -+ postverwerking -+ pottenbakken -+ poulesysteem -+ power -+ powerhouse -+ powerpop -+ poëziekritiek -+ poëzieliefhebber -+ poëzieliefhebbers -+ poëzietijdschrift -+ poëziewedstrijd -+ poëziezomer -+ pr-activiteiten -+ pr-adviseur -+ pr-bedrijf -+ pr-beleid -+ pr-functionaris -+ pr-machine -+ pr-man -+ pr-verantwoordelijke -+ praatclub -+ praatcultuur -+ praathuis -+ prachtfilm -+ prachtprestatie -+ praecox -+ praktijkdag -+ praktijkkennis -+ praktijkkosten -+ praktijkkostenvergoeding -+ praktijkman -+ praktijkmensen -+ praktijkondersteuning -+ praktijkonderwijs -+ praktijkopdrachten -+ praktijkopleiding -+ praktijktest -+ praktijkverhandeling -+ praktijkverpleegkundige -+ praktijkverpleegkundigen -+ praktijkvoering -+ praktisch-politieke -+ pre-electorale -+ preciezere -+ precisie-uurwerk -+ precisiebommen -+ predikante -+ predikantenopleiding -+ predikantschap -+ prelatuur -+ prematuren -+ premiebetalende -+ premiebetaler -+ premiebetalers -+ premiedaling -+ premiedifferentiatie -+ premiefraude -+ premiegrondslag -+ premiekosten -+ premieplicht -+ premierskandidaat -+ premiestijging -+ premiestijgingen -+ premiestortingen -+ premiesysteem -+ premieverschillen -+ premievoordeel -+ premixen -+ prepaid -+ prepress -+ preselectie -+ presentatieprogramma -+ presentatietechnieken -+ presentatievorm -+ presentatievormen -+ presentatiewerk -+ preservering -+ presidentsambt -+ presidentscampagne -+ presidentskandidate -+ presidentskandidatuur -+ presidentsrace -+ presidentsschap -+ presidentsvrouw -+ presse -+ prestatie-indicatoren -+ prestatiebevorderend -+ prestatiebevorderende -+ prestatiecontract -+ prestatiecontracten -+ prestatiecurve -+ prestatiegegevens -+ prestatienorm -+ prestatienormen -+ prestatieverbetering -+ presterend -+ prestigeduel -+ prestigemerk -+ prestigeoverwegingen -+ prestigestrijd -+ preventiecampagne -+ preventieplan -+ preventieteam -+ preventiewerkers -+ preëmptieve -+ priester-dichter -+ priesterkaste -+ prijs-kwaliteitsverhouding -+ prijsaanduiding -+ prijscategorie -+ prijsconcurrentie -+ prijsdier -+ prijsdifferentiatie -+ prijsdruk -+ prijsdumping -+ prijseffect -+ prijseffecten -+ prijserosie -+ prijsevolutie -+ prijsgevoelige -+ prijsgevoeligheid -+ prijsinformatie -+ prijskortingen -+ prijslimiet -+ prijsmarge -+ prijsofferte -+ prijsoffertes -+ prijsonderhandelingen -+ prijsondersteuning -+ prijsopdrijvende -+ prijsprikkels -+ prijsrange -+ prijsrisico's -+ prijssegment -+ prijsstabiliteit -+ prijssteun -+ prijsstructuur -+ prijsstunter -+ prijsstunters -+ prijssubsidies -+ prijssysteem -+ prijstransparantie -+ prijsverhouding -+ prijsvoorstellen -+ prijsvork -+ prijswijzigingen -+ prijswinnende -+ prijzenbedrag -+ prijzendruk -+ prijzenfestival -+ prijzengala -+ prijzenpakket -+ prijzenpolitiek -+ prijzenwet -+ prima donna -+ primatencentrum -+ princeps -+ principekwestie -+ principezaak -+ prinsenpaar -+ prinsenwagen -+ prinses Máxima -+ printerdivisie -+ printerfabrikant -+ prion -+ prionen -+ prionziekte -+ prionziekten -+ priorisch -+ prioristisch -+ prioristische -+ prioriteitsstelling -+ pris -+ privacybeleid -+ privacygevoelig -+ privacygevoelige -+ privacyregels -+ privatisatie -+ privatiseringsbeleid -+ privatiseringsplannen -+ privatiseringsproces -+ privatiseringsprogramma -+ privatiseringswet -+ privé-eigendom -+ privé-informatie -+ privéadres -+ privéarchief -+ privébelangen -+ privébibliotheek -+ privécollectie -+ privécollecties -+ privédoeleinden -+ privédomein -+ privégegevens -+ privéhanden -+ privéhuizen -+ privékilometers -+ privéklanten -+ privékliniek -+ privéklinieken -+ privéles -+ privélessen -+ privémilitie -+ privémuseum -+ privéomstandigheden -+ privéondernemer -+ privéonderneming -+ privéorganisaties -+ privépartners -+ privéprobleem -+ privéproblemen -+ privéproject -+ privéredenen -+ privésecretaresse -+ privésecretaresses -+ privésituatie -+ privéterrein -+ privétrainer -+ privévertrekken -+ privéverzamelaar -+ privévliegtuig -+ privéwoning -+ privéziekenhuizen -+ prix -+ prixtoernooi -+ prixtoernooien -+ prixwedstrijd -+ pro Deo -+ pro bono -+ pro forma -+ pro memorie -+ pro's -+ pro-Deaan -+ probleembedrijven -+ probleembuurt -+ probleembuurten -+ probleemjeugd -+ probleemjongeren -+ probleemkredieten -+ probleemland -+ probleemlanden -+ probleemleerlingen -+ probleempunt -+ probleempunten -+ probleemscholen -+ probleemwijk -+ probleemwijken -+ procedeetjes -+ procedurekosten -+ procedureslag -+ procedurevergadering -+ procesbegeleider -+ procescontrole -+ procesdag -+ procesdossier -+ procesinnovatie -+ procesmanagement -+ procesmanager -+ procesorde -+ procespartijen -+ procesvereenvoudiging -+ procesvertegenwoordiging -+ producentenvertrouwen -+ producersduo -+ productcategorie -+ productcategorieën -+ productengamma -+ productenpakket -+ productgamma -+ productieactiviteiten -+ productieafspraken -+ productieband -+ productiefaciliteit -+ productiegroei -+ productiehuis -+ productiehuizen -+ productiekantoor -+ productiekern -+ productieland -+ productielanden -+ productielocatie -+ productiemachines -+ productiemanager -+ productiemanagers -+ productieomstandigheden -+ productieplaatsen -+ productieplafond -+ productieplatform -+ productieproblemen -+ productiequota -+ productieruimte -+ productiestructuur -+ productieteam -+ productietechnisch -+ productietoename -+ productieverhoging -+ productieverlaging -+ productieverlies -+ productievestiging -+ productievestigingen -+ productievolume -+ productievolumes -+ productiewaarde -+ productiewerk -+ productiviteitsderving -+ productiviteitstoename -+ productiviteitswinst -+ productiviteitswinsten -+ productkwaliteit -+ productleverancier -+ productleveranciers -+ productlijnen -+ productmarkten -+ productmix -+ productnaam -+ productnamen -+ productnummer -+ productnummers -+ productontwikkelaar -+ productontwikkelaars -+ productportfolio -+ productvernieuwing -+ productwijziging -+ productwijzigingen -+ proefboren -+ proefbuis -+ proefcentrum -+ proefdiercentrum -+ proefexamen -+ proeffase -+ proefgebieden -+ proefgemeenten -+ proeflancering -+ proeflanceringen -+ proefnotities -+ proefonderzoek -+ proefpakket -+ proefpanel -+ proefprogramma -+ proefrijbewijs -+ proeftafel -+ proefteam -+ proeftraject -+ proefwinkel -+ prof. -+ profavontuur -+ profbestaan -+ profbond -+ profcompetitie -+ professionelen -+ professionelere -+ profhonkballer -+ profile -+ profileringsdrang -+ profit -+ profitariaat -+ profitinstellingen -+ profitorganisatie -+ profitsector -+ profjaar -+ profloopbaan -+ profpeloton -+ profronde -+ proftennisser -+ proftennissers -+ proftoernooi -+ proftoernooien -+ profvoetbalclub -+ profzege -+ programma-aanbieders -+ programma-informatie -+ programmabeleid -+ programmabrochure -+ programmabudget -+ programmabureau -+ programmacoördinator -+ programmaformule -+ programmaformules -+ programmagenres -+ programmagids -+ programmagidsen -+ programmahulp -+ programmakeuze -+ programmakosten -+ programmamanager -+ programmaonderdeel -+ programmaonderdelen -+ programmaraad -+ programmaraden -+ programmareeks -+ programmaschema -+ programmaserie -+ programmaverantwoordelijkheid -+ programmavoorschriften -+ programmavoorstel -+ programmavoorstellen -+ programmawet -+ programmawijzigingen -+ progressievoorbehoud -+ projectbegeleider -+ projectbeheer -+ projectbeschrijving -+ projectdirecteur -+ projectenlijst -+ projectkosten -+ projectleiding -+ projectplan -+ projectreferentie -+ projectsubsidie -+ projectteams -+ projectverantwoordelijke -+ projectwerk -+ projectwethouder -+ proliferatieverdrag -+ prominenten -+ prominentie -+ promotieactie -+ promotieacties -+ promotieactiviteiten -+ promotiebudget -+ promotiemiddel -+ promotieplan -+ promotietoer -+ promotietour -+ pronazi -+ pronkzitting -+ pronkzittingen -+ propagandadoeleinden -+ propagandamiddel -+ propagandaminister -+ propagandaslag -+ prophecy -+ prostitutiebranche -+ prostitutiecircuit -+ prostitutiegebied -+ prostitutiemilieu -+ prostitutienetwerk -+ prostitutiepanden -+ protagoniste -+ protestbord -+ protestborden -+ protesterenden -+ protestpartij -+ prothesedragers -+ protocolakkoord -+ protontherapie -+ provinciebestuurder -+ provinciebestuurders -+ provincieclub -+ provinciegenoten -+ provinciegrens -+ provinciehoofdstad -+ provinciewet -+ provocatus -+ proxy -+ prozabewerkingen -+ prudentiële -+ pseudointellectuele -+ pseudologia -+ pseudologia fantastica -+ pseudonimiteit -+ psilocine -+ psoriasispatiënten -+ psychogeriatrie -+ psychopate -+ psychotici -+ puberzoon -+ public -+ publicatielijst -+ publicatiemethode -+ publicatiemethodes -+ publiciteitsgevoelige -+ publiciteitsgolf -+ publiciteitsmachine -+ publiciteitsmateriaal -+ publiciteitsoffensief -+ publiek-privaat -+ publieksactiviteiten -+ publieksbalie -+ publieksbereik -+ publiekscampagne -+ publiekscampagnes -+ publieksdebat -+ publieksevenementen -+ publieksfavorieten -+ publieksfunctie -+ publieksfuncties -+ publiekslieveling -+ publieksonvriendelijk -+ publieksonvriendelijke -+ publieksparticipatie -+ publieksreacties -+ publieksreclame -+ publieksruimte -+ publieksruimten -+ publiekssucces -+ publiekstaak -+ publiekstaken -+ publieksvoorzieningen -+ publieksvriendelijkheid -+ publiekswissel -+ puinbreker -+ punkbeweging -+ punkmuziek -+ punkrocker -+ punkscene -+ punksongs -+ puntenaftrek -+ puntengrens -+ puntenrecord -+ puntenrijbewijs -+ puntentrui -+ puntenverlies -+ puntenvoorsprong -+ puntgrootte -+ puntverlies -+ puzzelspel -+ pvc-prijzen -+ pyknisch -+ pyknische -+ pyrolyse -+ pyromane -+ pêche -+ q'tjes -+ q.e.d. -+ quad -+ qualitate -+ quasi-diepzinnige -+ quasi-intellectuele -+ quasibestraffend -+ quasidiepzinnig -+ quasidocumentair -+ quasifilosofisch -+ quasimonopolie -+ quasionverschillig -+ quasireligieus -+ quasislordig -+ quasistaat -+ quatre -+ que -+ query -+ query's -+ qui -+ qui pro quo -+ quinoa -+ quizprogramma -+ quizvraag -+ quo -+ r'etjes -+ raadpleegbaar -+ raadsagenda -+ raadsbreed -+ raadsmedewerkers -+ raadsmeerderheid -+ raadsnestor -+ raadsperiode -+ raadsvergoeding -+ raadsvoordracht -+ raadsvoorstel -+ raadsvoorstellen -+ raadsvoorzitter -+ raadszaal -+ raambekleder -+ raampartijen -+ raamprostituees -+ raamprostitutiegebied -+ raapsteel -+ racespel -+ racespellen -+ racesport -+ raciste -+ radargeleide -+ radarverklikkers -+ radarvliegtuigen -+ radarwaarnemingen -+ radiatorrooster -+ radio-cassetterecorder -+ radio-dj -+ radio-optredens -+ radiocampagne -+ radiocolumn -+ radiocommunicatie -+ radiodirecteur -+ radiodocumentaires -+ radiohit -+ radiohoorspel -+ radiojournaliste -+ radiokanalen -+ radiolandschap -+ radiomaken -+ radiomakers -+ radioman -+ radiomarkt -+ radiomicrofoon -+ radionetwerk -+ radionieuws -+ radiopresentator -+ radiopresentatrice -+ radioschotels -+ radioshow -+ radioshows -+ radiospectrum -+ radiotherapeut -+ radiotherapeuten -+ radiouitzendingen -+ radiovriendelijke -+ radiozendtijd -+ raften -+ raga -+ raga's -+ railterminal -+ raketafweersysteem -+ raketbeschietingen -+ raketbrandstof -+ raketdreiging -+ raketkop -+ raketlancering -+ raketlanceringen -+ raketonderdelen -+ raketproef -+ raketproeven -+ raketprogramma -+ raketschild -+ raketsla -+ raketsysteem -+ raketsystemen -+ rakettechnologie -+ rakettenarsenaal -+ rakettenfabriek -+ rakettenschild -+ rakettest -+ raketverdediging -+ raketverdedigingssysteem -+ rallyrijden -+ rallywagen -+ rames -+ ramkrakers -+ rampbestrijding -+ rampbestrijdingsplan -+ rampcafé -+ rampdag -+ rampenbestrijders -+ rampenoefening -+ rampenoefeningen -+ rampenstaf -+ rampenteam -+ rampenverzekering -+ rampenzender -+ rampnacht -+ rampoefening -+ rampplaats -+ rampplek -+ ramptoestel -+ ramptrein -+ randactiviteiten -+ randapparaat -+ randapparaten -+ randbeplanting -+ randdebiel -+ randstedelijke -+ ranking -+ rapact -+ rapformatie -+ rapidpartijen -+ rapidschaak -+ rapscene -+ rapster -+ rasa -+ rasbestuurder -+ rassenoorlog -+ rassenrellen -+ rassprinter -+ rassé -+ rasterlijn -+ rasterlijnen -+ rasverteller -+ ratingbureau -+ rauwmelkse -+ rave -+ ravers -+ rayonkantoor -+ razendknap -+ re-educatie -+ re-integratiebedrijf -+ re-integratiebeleid -+ re-integratiegedeelte -+ reactiemacht -+ reactiepatronen -+ reactiepatroon -+ reading -+ real -+ real time -+ reality -+ realityprogramma -+ realpolitik -+ realtime -+ reanimatiepogingen -+ rebellengebied -+ rebellengroepen -+ rebellengroepering -+ rebellenkamp -+ rebellenorganisatie -+ recentere -+ receptgeneesmiddelen -+ receptiebalie -+ receptiekosten -+ recessiebestendig -+ recherche-eenheid -+ recherchecapaciteit -+ recherchechef -+ recherchechefs -+ recherchetechnieken -+ recherchezaken -+ recht voor z'n raap -+ rechtbankvonnis -+ rechtbankvoorzitter -+ rechtbreien -+ rechterbenedenhoek -+ rechterborst -+ rechterhersenhelft -+ rechterheup -+ rechterkantlijn -+ rechterknie -+ rechterkolom -+ rechtermarge -+ rechtermuisknop -+ rechterpagina's -+ rechterportier -+ rechterrijstrook -+ rechts-extremisme -+ rechts-nationalistische -+ rechtsbasis -+ rechtsbedrijf -+ rechtsbestel -+ rechtsbijstandverzekeraar -+ rechtsbijstandverzekeraars -+ rechtscultuur -+ rechtsen -+ rechtsfilosoof -+ rechtsgemeenschap -+ rechtsgrondslag -+ rechtshandigen -+ rechtshulpverdrag -+ rechtshulpverleners -+ rechtshulpverzoek -+ rechtshulpverzoeken -+ rechtsinstantie -+ rechtsinstanties -+ rechtsleer -+ rechtsontwikkeling -+ rechtspositieregelingen -+ rechtsprincipe -+ rechtsprincipes -+ rechtsprocedure -+ rechtsprocedures -+ rechtspsychologie -+ rechtsspraak -+ rechtsstatelijk -+ rechtsstatelijke -+ rechtstoepassing -+ rechtstoepassingen -+ rechtsverwerking -+ rechtswaarborgen -+ rechttoe rechtaan -+ rechtzoekende -+ rechtzoekenden -+ recidivisme -+ reclame-industrie -+ reclame-inspanningen -+ reclame-uiting -+ reclame-uitingen -+ reclameactie -+ reclameactiviteiten -+ reclamebedrijf -+ reclamebedrijven -+ reclamebeelden -+ reclamebeleid -+ reclamebesluit -+ reclamebestedingen -+ reclamebranche -+ reclamebudget -+ reclamebudgetten -+ reclameconcern -+ reclamecontract -+ reclamefestival -+ reclamefotografie -+ reclamegeld -+ reclamegelden -+ reclamekosten -+ reclamekreet -+ reclameleus -+ reclamemaken -+ reclamemarkt -+ reclamemiddel -+ reclamemonopolie -+ reclamemuziek -+ reclameprijs -+ reclameregie -+ reclameruimte -+ reclamesector -+ reclameslogan -+ reclametaal -+ reclametarieven -+ reclameteam -+ reclameuitingen -+ reclamevrij -+ reclamevrije -+ reclamewereld -+ reclasseringscontact -+ reclasseringsmedewerker -+ reclasseringstoezicht -+ reconquista -+ reconstructieplan -+ reconstructieplannen -+ reconstructietekening -+ reconstructiewerkzaamheden -+ recordboeken -+ recordbrekende -+ recordgroei -+ recordhoeveelheid -+ recordinternational -+ recordjacht -+ recordkampioen -+ recordkoers -+ recordlaagte -+ recordniveau -+ recordoplage -+ recordpeil -+ recordprijs -+ recordprijzen -+ recordrace -+ recordreeks -+ recordresultaat -+ recordresultaten -+ recordscore -+ recordvangst -+ recordverbetering -+ recordverkoop -+ recordverkopen -+ recordverlies -+ recordverliezen -+ recordvlucht -+ recreatiebad -+ recreatiebos -+ recreatiecomplex -+ recreatieondernemers -+ recreatieplas -+ recreatieplassen -+ recreatieproject -+ recreatieprojecten -+ recreatieroute -+ recruiters -+ recruteerde -+ recruteert -+ recruten -+ recurrent -+ recurrente -+ recyclagebedrijf -+ recycleerbaar -+ red. -+ redactiekantoor -+ redactiesecretariaat -+ redactiestatuten -+ redactiestatuut -+ redactieteam -+ redactiezaal -+ reddingsdienst -+ reddingsmiddelen -+ reddingspakket -+ reddingsplan -+ reddingsteam -+ reddingsvaartuig -+ reddingswerkzaamheden -+ reddingwerkers -+ redelijkheidsbeginsel -+ redelijkheidstoets -+ redelijkheidstoetsen -+ redersfamilie -+ reductiedoelstelling -+ reductiedoelstellingen -+ reductieplan -+ reductieregeling -+ reductio -+ reductio ad absurdum -+ reewild -+ referendabel -+ referendumverordening -+ referendumverzoek -+ referendumvoorstel -+ referentieaandeelhouder -+ referentieaandeelhouders -+ referentiekoers -+ referentielening -+ referentielijst -+ referentieprijs -+ referentierente -+ reflexwerking -+ regeerploeg -+ regelafbreking -+ regelbegin -+ regeldrift -+ regeleinde -+ regeleinden -+ regelgevend -+ regelgevende -+ regelgever -+ regelgevers -+ regelneverij -+ regelniveau -+ regelniveaus -+ regelwijziging -+ regenbanden -+ regenboognatie -+ regenpauze -+ regering-in-ballingschap -+ regeringleiders -+ regeringsadviseur -+ regeringsakkoord -+ regeringsapparaat -+ regeringsautoriteiten -+ regeringsbronnen -+ regeringsbureau -+ regeringscijfers -+ regeringscombinatie -+ regeringsconferentie -+ regeringscontrole -+ regeringsdeelname -+ regeringsdelegatie -+ regeringsdelegaties -+ regeringsdocumenten -+ regeringsformatie -+ regeringsgebied -+ regeringsgetrouwe -+ regeringsgezinde -+ regeringshoofden -+ regeringshulp -+ regeringsinstanties -+ regeringskamp -+ regeringskandidaat -+ regeringskrant -+ regeringsleidster -+ regeringslid -+ regeringsmaatregel -+ regeringsmaatregelen -+ regeringsmacht -+ regeringsmilitairen -+ regeringsonderzoek -+ regeringsorgaan -+ regeringspolitiek -+ regeringspost -+ regeringsstad -+ regeringssysteem -+ regeringstoestel -+ regeringstop -+ regeringsvliegtuig -+ regeringsvoornemen -+ regeringsvorming -+ regeringswerk -+ regeringswijk -+ regeringswissel -+ regiefout -+ regiefunctie -+ regiegroep -+ regieopvatting -+ regierol -+ regiobestuurder -+ regiocode -+ regiocodes -+ regiodirecteur -+ regiodirecteuren -+ regiofunctie -+ regiogemeenten -+ regiogrenzen -+ regiokantoor -+ regiokantoren -+ regiokorps -+ regionalen -+ regionalismen -+ regionieuws -+ regiopolitie -+ regioraad -+ regioteam -+ regioverkiezingen -+ regiovisie -+ regiovoorzitter -+ regiovorming -+ registratiecommissie -+ registratieformulier -+ registratieformulieren -+ registratiemethode -+ registratieprocedure -+ registratiesystemen -+ regularisatiecampagne -+ regularisatiecommissie -+ regularisatieprocedure -+ regularisering -+ rehabilitatieprogramma -+ reinigingsheffing -+ reinigingsinstallatie -+ reinigingskosten -+ reinigingsproces -+ reinigingsproducten -+ reisafstand -+ reisafstanden -+ reisbagage -+ reisbedrijf -+ reisbijstand -+ reisblad -+ reisboekhandel -+ reisbrieven -+ reisbudget -+ reisconcern -+ reisdag -+ reisdocument -+ reisdoelen -+ reisgedrag -+ reisgemak -+ reisgezel -+ reisgroep -+ reishandboek -+ reisindustrie -+ reisinformatie -+ reiskostenaftrek -+ reiskostenregeling -+ reislustigen -+ reismagazine -+ reismarkt -+ reismogelijkheden -+ reisonderneming -+ reisplanner -+ reisroute -+ reisroutes -+ reisschrijver -+ reissector -+ reissites -+ reisuren -+ reisverbod -+ reisvergunning -+ reisvoorwaarden -+ reiswagen -+ reisweg -+ reisziekte -+ reizigersaantallen -+ reizigersbedrijf -+ reizigersgroei -+ reizigersinformatie -+ reizigersorganisatie -+ reizigersstromen -+ reizigersstroom -+ rekenblad -+ rekenbladen -+ rekenboekjes -+ rekeningafschriften -+ rekeningoverzicht -+ rekeningsaldo -+ rekenkracht -+ rekenonderwijs -+ rekentabel -+ rekentabellen -+ rekenvaardigheden -+ rekenvaardigheid -+ rekenvermogen -+ rekkertje -+ relatiebeheer -+ relatiebeheerder -+ relatiekomedie -+ relatiemanagement -+ relatiemarkt -+ relatienetwerk -+ relatieprobleem -+ relatiesfeer -+ relatievorming -+ relations -+ relaxruimte -+ relen -+ religieus-culturele -+ religieus-politieke -+ rellerigheid -+ relschoppende -+ remedial -+ remigratieproject -+ remkracht -+ remkrachtverdeler -+ remme -+ remote -+ remvermogen -+ remwerking -+ renaissancemuziek -+ rendabiliseren -+ rendang -+ rendementscurve -+ rendementsheffing -+ rendementsverhoging -+ rendementsverlies -+ rendementsverschil -+ rendez -+ rendiervlees -+ reng -+ renovatiemarkt -+ renprijs -+ rensters -+ rente-evolutie -+ renteangst -+ rentebeleid -+ rentebeslissing -+ rentebesluit -+ rentebesluiten -+ rentebewegingen -+ rentecurve -+ rentedruk -+ rentegevoeligheid -+ rentehobbel -+ rentemaatregel -+ rentemarkt -+ renteniveau -+ renteniveaus -+ renteontwikkeling -+ rentepolitiek -+ rentepremie -+ renteresultaat -+ renterisico -+ renteschommelingen -+ renteverplichtingen -+ renteverwachtingen -+ rentevooruitzichten -+ rentevrees -+ rentevrij -+ rentevrije -+ rentewapen -+ rentewijziging -+ rentewijzigingen -+ reorganisatiekosten -+ reorganisatielast -+ reorganisatielasten -+ reorganisatieproces -+ reorganisatieprocessen -+ reorganisatieronde -+ reparatiemaatregelen -+ reparatiewet -+ repertoirekeuze -+ repje -+ reporente -+ reportageprogramma -+ reportagereeks -+ reportageserie -+ reproductierecht -+ reprograferen -+ reptielenhuis -+ reputatieschade -+ rerelease -+ researchpark -+ researchwerk -+ resellers -+ reservaatsgebied -+ reservataire -+ reservatiesysteem -+ reservecapaciteit -+ reservedelen -+ reservedoelman -+ reservekopie -+ reservekopieën -+ reservelijst -+ reserveperiode -+ reservepolitie -+ reserverekening -+ reserveringskosten -+ reserveringsruimte -+ reserverol -+ resocialisering -+ resp. -+ responsabiliseren -+ responstijd -+ restafval -+ restante -+ restaurant-hotel -+ restaurantbezoek -+ restaurantbezoeker -+ restaurantformule -+ restaurantgedeelte -+ restaurantkosten -+ restaurantmanager -+ restaurantpersoneel -+ restaurantwezen -+ restauratiebeurt -+ restauratiefonds -+ restauratieproject -+ restauratieprojecten -+ restauratiesubsidie -+ restauratiewerk -+ restbedrag -+ restfractie -+ restpartijen -+ restpost -+ restproduct -+ restproducten -+ restrictievere -+ restruimte -+ restschuld -+ reststemmen -+ restverschijnselen -+ resultaatafhankelijke -+ resultaatbeloning -+ resultaatgebied -+ resultaatgebieden -+ resultaatsverbintenis -+ resultaatsverplichting -+ resultaatverantwoordelijk -+ resultatenseizoen -+ retailer -+ retailers -+ retailing -+ retailsector -+ retinol -+ retouren -+ retourpremie -+ retourprovisie -+ retourrecht -+ retourservice -+ retourtarief -+ retriever -+ retrospectie -+ retrotrend -+ retsina -+ reuzeblij -+ reuzenblad -+ reuzenpinguïn -+ revalidatieperiode -+ revisievergunning -+ rez -+ reëlere -+ rhythm -+ ribblessure -+ riches -+ richtingloosheid -+ ricine -+ ricotta -+ ridderideaal -+ ridderverhaal -+ ridderverhalen -+ rider -+ rietgedekte -+ rietsnijders -+ rietsuikerplantages -+ riff -+ right -+ rigor -+ rij-instructeurs -+ rijgenot -+ rijinstructrice -+ rijkbloeiend -+ rijkbloeiende -+ rijkgevulde -+ rijkop -+ rijksbeleid -+ rijkscollectie -+ rijksconsulent -+ rijksgeld -+ rijksgelden -+ rijksinspecteur -+ rijksinspectie -+ rijksinspecties -+ rijksmaarschalk -+ rijksministerraad -+ rijksmonumentenlijst -+ rijksniveau -+ rijksrechercheonderzoek -+ rijksrechercherapport -+ rijksrechercheur -+ rijksrechercheurs -+ rijksregels -+ rijksstenden -+ rijkssteun -+ rijkstaken -+ rijkstoelage -+ rijksvergoeding -+ rijkswachtkazerne -+ rijkwaliteiten -+ rijprestaties -+ rijstboer -+ rijstevlaai -+ rijstterrassen -+ rijtest -+ rijtijdenwet -+ rijvaardigheidstest -+ rijveiligheid -+ rijwoning -+ rijwoningen -+ ringleiding -+ ringslot -+ ringvaccinatie -+ rio -+ rioleringsnet -+ rioleringsplan -+ rioleringsplannen -+ rioleringswerkzaamheden -+ rioolaansluiting -+ rioolafvoerrecht -+ rioollucht -+ riooloverstort -+ riooloverstorten -+ rioolpijp -+ rioolsysteem -+ riposten -+ ripostes -+ risico-inventarisatie -+ risico-organen -+ risicobedrijven -+ risicobeheer -+ risicobeheersing -+ risicobeoordeling -+ risicobeperkend -+ risicobeperkende -+ risicodekking -+ risicodieren -+ risicodragers -+ risicoduel -+ risicofonds -+ risicogebied -+ risicogebieden -+ risicogedrag -+ risicogehalte -+ risicograad -+ risicojongeren -+ risicokapitaalfonds -+ risicokapitaalfondsen -+ risicokapitaalverschaffers -+ risicokinderen -+ risicolanden -+ risicoleerlingen -+ risicomaatschappij -+ risicomanagement -+ risicomateriaal -+ risicoperceptie -+ risicoprofiel -+ risicoprofielen -+ risicoschuwe -+ risicoselectie -+ risicosupporters -+ risicotreinen -+ risicovrij -+ risicovrije -+ ritalin -+ rittenadministratie -+ rittenwedstrijd -+ rivierblindheid -+ rivierboten -+ riviercruises -+ rivierlandschap -+ rivierlandschappen -+ rivierzijde -+ roadmuziek -+ roadster -+ roaring -+ roc's -+ rockartiest -+ rockcultuur -+ rockfestival -+ rockformatie -+ rockgeluid -+ rockgitarist -+ rockheld -+ rocklegende -+ rockmusicus -+ rockmuzikant -+ rocknummer -+ rocknummers -+ rockplaat -+ rockplaten -+ rockpubliek -+ rockscene -+ rockshow -+ roddeljournalistiek -+ roddeltante -+ roddelverhalen -+ rodelaar -+ rodetruidrager -+ roebelcrisis -+ roeicoach -+ roeiseizoen -+ roeiwereld -+ roependen -+ roestvrij staal -+ roetfilter -+ roetfilters -+ roetschade -+ roetuitstoot -+ roggeaar -+ rogvleugel -+ rolbeugels -+ rolcontainer -+ rolcontainers -+ rolkraagtrui -+ roll -+ rollenbank -+ rollercoaster -+ rollmuziek -+ rolschaatsster -+ rolstoelbus -+ rolstoelvervoer -+ rom -+ rommetje -+ rompboerderij -+ roms -+ romspeler -+ rond krijgen -+ rondbellen -+ rondemiss -+ rondewerk -+ rondgepompt -+ rondgezeuld -+ rondpompen -+ rondpompt -+ rondrennen -+ rondschuiven -+ rondsmijten -+ rondstruinen -+ rondtocht -+ rondwegen -+ rood-geel -+ rood-gele -+ rood-oranje -+ rood-wit -+ rood-witten -+ rood-zwart -+ rood-zwarte -+ roodbaars -+ roodgeschilderde -+ roodgeverfde -+ roodloof -+ roodoranje -+ roodstenen -+ roofbank -+ roofmijten -+ rookbeleid -+ rookpauze -+ rookpauzes -+ rookruimte -+ rooksmaak -+ rookverslaving -+ roomsen -+ rootsmuziek -+ roro -+ rotatiesysteem -+ rotcenten -+ rotgeschrokken -+ rotgevoel -+ rotperiode -+ rotschop -+ rotsformatie -+ rotslandschap -+ rotvaart -+ rotweer -+ rotwoord -+ route-informatie -+ routeboekje -+ routeplanning -+ routers -+ routinecontrole -+ routinecontroles -+ rouwbezoek -+ rouwkaarten -+ rouwrituelen -+ rouwstemming -+ rouwverlof -+ royaltyverslaggever -+ rozetruidrager -+ rsi -+ rsi-klachten -+ rubidium -+ rubrieksadvertenties -+ rugletsel -+ rugoperatie -+ rugtas -+ ruilbod -+ ruilsysteem -+ ruim bemeten -+ ruimbemeten -+ ruimingsbeleid -+ ruimte-tijd -+ ruimtebasis -+ ruimtebehoefte -+ ruimtebesparende -+ ruimteclaims -+ ruimtegebruik -+ ruimtegevoel -+ ruimtelijk-economische -+ ruimtemissie -+ ruimtemissies -+ ruimteprogramma -+ ruimtepuin -+ ruimterace -+ ruimtetechnologie -+ ruimtetekort -+ ruimtetijd -+ ruimtetoerisme -+ ruimtetoerist -+ ruimtetuig -+ ruimtetuigen -+ ruimtevaartactiviteiten -+ ruimtevaartbureau -+ ruimtevaartconcern -+ ruimtevaartorganisatie -+ ruimtevaartorganisaties -+ ruimtevaartproject -+ ruimtevaartprojecten -+ ruimtevaarttechnologie -+ ruimtevretende -+ ruimtewezen -+ ruimtewinst -+ ruitpatroon -+ runderfilet -+ rundermest -+ runderslachterijen -+ rundersperma -+ rundervet -+ rundveebedrijf -+ rundveebedrijven -+ rundveesector -+ rundvleesconsumptie -+ rundvleesmarkt -+ rundvleesproducten -+ running -+ rustmoment -+ rustmomenten -+ rustzoekers -+ ruweolieprijs -+ ruziënd -+ ruïnestad -+ résistance -+ röntgenbeelden -+ röntgenopname -+ röntgenopnamen -+ röntgensatelliet -+ s'il -+ s'jes -+ s.j. -+ sabbatsverlof -+ saison -+ salarisachterstand -+ salarisgegevens -+ salarisgroei -+ salarisniveau -+ salarisonderhandelingen -+ salarisplafond -+ salarisstijging -+ salarisstijgingen -+ salarisverbetering -+ salarisvergelijking -+ salarisverschil -+ salarisverschillen -+ salbutamol -+ salmonellavergiftiging -+ salsaband -+ samenlevingsproblemen -+ samenlevingsregister -+ samenwerkingsafspraken -+ samenwerkingscontract -+ samenwerkingscontracten -+ samenwerkingsgesprekken -+ samenwerkingsmodel -+ samenwerkingsorganisatie -+ samenwerkingspartner -+ samenwerkingspartners -+ samenwerkingsplan -+ samenwerkingsprogramma -+ samenwerkingsverdrag -+ samenwerkingsverdragen -+ samenwerkingverband -+ samenzitten -+ sanctiepakket -+ sanctiepolitiek -+ sanctieregime -+ sanctiewet -+ saneringsfonds -+ saneringskosten -+ saneringsmaatregel -+ saneringsonderzoek -+ saneringsprogramma -+ saneringsproject -+ saneringsprojecten -+ saneringsregeling -+ saneringsronde -+ saneringswerk -+ saneringswerkzaamheden -+ sang -+ sans -+ sapiens -+ sarcoïdose -+ sarin -+ sashimi -+ satanistische -+ satellietbedrijf -+ satellietgestuurde -+ satellietkanalen -+ satellietmetingen -+ satellietnavigatie -+ satellietnavigatiesysteem -+ satellietnetwerk -+ satellietontvanger -+ satellietontvangers -+ satellietproject -+ satellietsignalen -+ satellietsysteem -+ satellietsystemen -+ satelliettelefoon -+ satelliettelefoons -+ satellietwaarneming -+ satellietwaarnemingen -+ satellietwagens -+ sativa -+ savant -+ savoir -+ saxofoniste -+ saxofoonspel -+ scanapparaat -+ scanapparatuur -+ scenarioschrijven -+ scenarist-regisseur -+ scenariste -+ scenograaf -+ schaakleven -+ schaakliefhebber -+ schaakmedewerker -+ schaaksport -+ schaalbaar -+ schaalbaarheid -+ schaalbare -+ schaaleffecten -+ schaalvoordeel -+ schaalvoordelen -+ schaamtegevoelens -+ schaapsherder -+ schaatsbelg -+ schaatsbond -+ schaatscarrière -+ schaatsclub -+ schaatsfabrikant -+ schaatskampioen -+ schaatskampioene -+ schaatskampioenen -+ schaatsland -+ schaatslanden -+ schaatsleven -+ schaatsliefhebber -+ schaatsmijl -+ schaatspeloton -+ schaatsploeg -+ schaatsschool -+ schaatssport -+ schaatstalent -+ schaatstitel -+ schaatstoernooi -+ schaatstoernooien -+ schaatstoppers -+ schaatstrainer -+ schaatsunie -+ schaatswereld -+ schadebeperking -+ schadeherstel -+ schadelast -+ schadelijder -+ schademeldingen -+ schadeprocedure -+ schadeprocedures -+ schadevergoedingsplicht -+ schadevergoedingsplichten -+ schadevergoedingsregeling -+ schaduwbestaan -+ schaduweconomie -+ schaduwverkiezingen -+ schakelband -+ schakelend -+ schakelende -+ schandaalsfeer -+ schapenhoeder -+ schapenhoeders -+ schapenziekte -+ schapruimte -+ scharnierfunctie -+ scharnierjaar -+ scharniermoment -+ scharrelvlees -+ schatkaart -+ schatkistsaldo -+ schatkisttekort -+ schatzoeker -+ scheefstand -+ scheeftrekking -+ scheeftrekkingen -+ scheepsafval -+ scheepsagent -+ scheepsbewegingen -+ scheepslui -+ scheepsnieuwbouw -+ scheepsongeluk -+ scheepsreparatie -+ scheepstypen -+ scheepvaartgroep -+ scheepvaartindustrie -+ scheepvaartongevallen -+ scheepvaartverbindingen -+ scheidingsbemiddelaar -+ scheidingsbemiddeling -+ scheidingsinstallatie -+ scheidingsteken -+ scheidsrechtersfluit -+ scheikundedoos -+ scheikundeles -+ schemergebied -+ schermafdruk -+ schermenbeurs -+ schermenhandel -+ scherpstellen -+ schetsje -+ schietclub -+ schietclubs -+ schietkans -+ schietshow -+ schietspel -+ schietspellen -+ schijfruimte -+ schijnconstructies -+ schijndemocratie -+ schijnheiligen -+ schijntegenstelling -+ schijnveiligheid -+ schijnwerkelijkheid -+ schijnzekerheden -+ schijnzekerheid -+ schildersbranche -+ schildersgroep -+ schildersschool -+ schilderstijl -+ schildklierhormoon -+ schimmelsporen -+ schimmigheid -+ schippersinternaten -+ schizofrenen -+ schlagerzanger -+ schoenenfabrikant -+ schoenenmarkt -+ schoenverkoper -+ schokbestendigheid -+ schokdemping -+ scholenbestand -+ scholenfusie -+ scholengroep -+ scholenproject -+ scholierenstaking -+ scholingsaftrek -+ scholingskosten -+ scholingsplan -+ scholingsproject -+ scholingsprojecten -+ schommelingsmarge -+ schoolactiviteiten -+ schooladvies -+ schoolagent -+ schoolartikelen -+ schoolbataljon -+ schoolbeleid -+ schoolbestuurder -+ schoolbestuurders -+ schoolbudget -+ schoolbudgetten -+ schoolcarrière -+ schoolcijfers -+ schoolcomplex -+ schoolcomputer -+ schoolcomputers -+ schoolcultuur -+ schooldeur -+ schooldeuren -+ schooldirecteur -+ schooldirecteuren -+ schooldirectie -+ schoolfruit -+ schoolgeweld -+ schoolgids -+ schoolgidsen -+ schoolgrootte -+ schoolinternaat -+ schoolkamp -+ schoolkantines -+ schoolklimaat -+ schoolkosten -+ schoolleeftijd -+ schoolleiding -+ schoolleidingen -+ schoolmanagement -+ schoolmateriaal -+ schoolniveau -+ schoolorganisatie -+ schoolpoort -+ schoolpopulatie -+ schoolprestaties -+ schoolproject -+ schoolprojecten -+ schoolpsycholoog -+ schoolregels -+ schoolresultaten -+ schoolroute -+ schoolseizoen -+ schoolsport -+ schoolsucces -+ schoolsysteem -+ schooltuinproject -+ schooltuinprojecten -+ schooluitval -+ schoolverlaten -+ schoolvervoer -+ schoolvoetbal -+ schoolweek -+ schoolweken -+ schoonheidsoperaties -+ schoonmaakactie -+ schoonmaakactiviteiten -+ schoonmaakbranche -+ schoonmaakpersoneel -+ schoothond -+ schorsingsprocedure -+ schouderblessure -+ schouderklop -+ schraallanden -+ schrifteffect -+ schrifteffecten -+ schrijfcursus -+ schrijfcursussen -+ schrijfkop -+ schrijfmateriaal -+ schrijfplezier -+ schrijfproblemen -+ schrijfrechten -+ schrijfwedstrijd -+ schrijve -+ schrijver-journalist -+ schrijverscarrière -+ schrijversduo -+ schrijversechtpaar -+ schrijversleven -+ schrijversportretten -+ schrijversteam -+ schrooi-ijzer -+ schrooi-ijzers -+ schuifknop -+ schuifknoppen -+ schuifpui -+ schuldafbouw -+ schuldbedrag -+ schuldbeheer -+ schuldbemiddeling -+ schuldenakkoord -+ schuldenbeleid -+ schuldenkwestie -+ schuldenkwijtschelding -+ schuldenlastverlichting -+ schuldenplan -+ schuldenproblematiek -+ schuldenverlichting -+ schuldfinanciering -+ schuldgraad -+ schuldherschikking -+ schuldhulpverlening -+ schuldkwijtschelding -+ schuldpositie -+ schuldprobleem -+ schuldproblemen -+ schuldquote -+ schuldratio -+ schuldreductie -+ schuldregeling -+ schuldsaldo -+ schuldsaldoverzekering -+ schuldtitels -+ schuldverlichting -+ schuldvermindering -+ schurkenstaat -+ schutskring -+ schuttersfeest -+ schuurfeesten -+ sciencefictionserie -+ scientologen -+ scoringsdrang -+ scoutingclub -+ scoutinggroep -+ scoutingsapparaat -+ scramjet -+ screenings -+ screeningsprogramma -+ screenshots -+ scudraketten -+ scullen -+ second -+ secret -+ sectoranalyse -+ sectorcommissies -+ sectordirecteur -+ sectorfonds -+ sectorfondsen -+ sectorgemiddelde -+ sectorgenoot -+ sectorgenoten -+ sectorieel -+ sectorindices -+ sectoriële -+ sectornieuws -+ sectorniveau -+ sectorraad -+ sectorraden -+ sectorwoningen -+ secularisten -+ sedatie -+ seitan -+ seizoengroenten -+ seizoenkaart -+ seizoenprestatie -+ seizoensarbeiders -+ seizoenskaarten -+ seizoensstart -+ seizoenswerk -+ seizoenszege -+ seizoenwerkers -+ seizoenzege -+ seksadvertentie -+ seksadvertenties -+ seksaffaire -+ seksbedrijven -+ seksbranche -+ seksegebonden -+ seksegelijkheid -+ seksespecifieke -+ seksfeesten -+ seksfuiven -+ sekshuizen -+ seksinrichting -+ sekspartners -+ seksuologe -+ seksverslaving -+ selecta -+ selectiebeleid -+ selectiebureau -+ selectiebureaus -+ selectielijst -+ selectiemodus -+ selectieprocessen -+ selectieregels -+ selectieronde -+ selectiesysteem -+ selectieteam -+ semi-illegale -+ semi-industrieel -+ semi-industriële -+ semiarts -+ semiartsen -+ semiautobiografisch -+ semiautobiografische -+ semidocumentaire -+ semifinale -+ semiklassieker -+ semiklassiekers -+ seminomadisch -+ semireligieuze -+ senior partner -+ seniorenlabel -+ seniorenraad -+ seniorenwoning -+ sensatielust -+ sensatiezoeker -+ sensibilisering -+ sensibiliseringscampagne -+ sensing -+ separeercel -+ seponering -+ septemberaanslagen -+ septic -+ serafineorgel -+ seriemoorden -+ serieverkrachter -+ serversoftware -+ service-instituut -+ servicebedrijf -+ servicegeweld -+ servicekanon -+ servicelijn -+ servicemedewerkers -+ servicemonteur -+ servicemonteurs -+ servicenummer -+ settopbox -+ settopboxen -+ setverlies -+ seventies -+ sex -+ sf -+ sf-film -+ sfeermaker -+ sfeerschepping -+ sfeerschetsen -+ shagindustrie -+ shell -+ shooters -+ shopper -+ shopping -+ shoppingcenter -+ shoppingcentra -+ shoppingcentrum -+ shoppingmall -+ shoppingmalls -+ shortpositie -+ shotgun -+ showdans -+ showelement -+ shownieuws -+ showprogramma -+ showtime -+ shui -+ siertabak -+ siertelers -+ siertorens -+ siervoorwerpen -+ siervuurwerk -+ sierwaarde -+ sigaarrokende -+ sigarenboer -+ sigarendoos -+ sigarenhandel -+ sigarenindustrie -+ sigarettenfabriek -+ sigarettenindustrie -+ sigarettenmarkt -+ sigarettenpakje -+ sigarettenpakjes -+ sigarettenproducenten -+ sigarettenverkoop -+ signaalsterkte -+ sikhtempel -+ sileen -+ silica -+ siliconenimplantaten -+ silicose -+ simsonsverzuchting -+ sinds mensenheugenis -+ sine -+ singer -+ sit -+ sit-in -+ sitebezoekers -+ situsanering -+ siècle -+ sjabloonbestand -+ sjabloonbestanden -+ sjeu -+ sjouwwerk -+ skate-off -+ skatebaan -+ skatebanen -+ skatepark -+ skeeleraar -+ skibaan -+ skibus -+ skidorp -+ skidorpen -+ skied -+ skifederatie -+ skikampioen -+ skilatten -+ skiles -+ skiloopster -+ skimateriaal -+ skimmia -+ skipas -+ skischolen -+ skiseizoen -+ skispringer -+ skistation -+ skistations -+ skitrein -+ slaagcijfers -+ slaagkans -+ slaagpercentage -+ slaapapneu -+ slaapcabine -+ slaapcomfort -+ slaaphouding -+ slaapkamergeheimen -+ slaappatroon -+ slaapplek -+ slaapprobleem -+ slaapwandeling -+ slachtcapaciteit -+ slachtfeest -+ slachtgewicht -+ slachtkoeien -+ slachtlijn -+ slachtofferzorg -+ slachtrunderen -+ slachtvarkens -+ slachtveld -+ slachtverbod -+ slagersvrouw -+ slagwerkster -+ slam -+ slams -+ slankheidsideaal -+ slaventijd -+ slavenverzet -+ slavernijmonument -+ slavernijverleden -+ slecht verlicht -+ slechthorendheid -+ slechtzittende -+ sleepbedrijf -+ sleepmodus -+ sleutel-op-de-deur -+ sleutelduel -+ sleutelelement -+ sleutelelementen -+ sleutelfactor -+ sleutelfactoren -+ sleuteljaar -+ sleutelmoment -+ sleutelmomenten -+ sleutelproject -+ sleutelprojecten -+ sleutelsectoren -+ slibdepot -+ slibstort -+ slijptol -+ slijptollen -+ slijtersziekte -+ slijtvastheid -+ slimmen -+ slimsten -+ slingerklok -+ slingerweg -+ sloopafval -+ sloopkosten -+ sloopmateriaal -+ sloopplannen -+ slopersbal -+ slotact -+ slotafstand -+ slotapplaus -+ slotavond -+ slotbeeld -+ slotbetoog -+ slotconcert -+ slotcoördinator -+ slotdag -+ slotdebat -+ slotdeel -+ slotdividend -+ slotdocument -+ slotfilm -+ slotkilometer -+ slotklim -+ slotkwartier -+ slotmaten -+ slotminuten -+ slotminuut -+ slotnoot -+ slotonderhandelingen -+ slotpartij -+ slotpassage -+ slotrecord -+ slotrit -+ slotronde -+ slotseconde -+ slotserie -+ slotstand -+ slottoespraak -+ slotverhaal -+ slotvraag -+ slotweek -+ slotzwemmer -+ slow -+ sluitergordijn -+ sluitingsbevel -+ sluitingsplan -+ sluitingsplannen -+ sluitingstermijn -+ sluitreden -+ sluizencomplex -+ smaadproces -+ smaadreden -+ smaakgevoel -+ smaakpalet -+ smaakprofiel -+ smaaksensatie -+ smaakvervlakking -+ smartenkind -+ smartshop -+ smartshops -+ smeergeldaffaire -+ smeergeldaffaires -+ smeergeldschandaal -+ smeltkaas -+ smeuïgheid -+ smijtfilm -+ smijtwerk -+ smiley -+ smith -+ smokkelnetwerken -+ smokkelorganisaties -+ smokkelzaak -+ sms-bericht -+ sms-berichten -+ sms-berichtje -+ sms-berichtjes -+ sms-dienst -+ sms-verkeer -+ snackbarhouder -+ snarentheorie -+ sneeuwcondities -+ sneeuwgebieden -+ sneeuwmassa -+ sneeuwpret -+ sneeuwrijke -+ sneeuwtapijt -+ sneeuwzeker -+ snelcursus -+ sneldienst -+ snelheidsafhankelijke -+ snelheidsbegrenzing -+ snelheidsboetes -+ snelheidslijn -+ snelheidsmonster -+ snelheidsregelaar -+ snelheidsvermindering -+ snelkraak -+ snelkraken -+ snellereactiemacht -+ snellezen -+ snelmenu -+ snelsnel -+ snelsten -+ snelstgroeiende -+ sneltempo -+ sneltoets -+ sneltoetscombinatie -+ sneltoetsen -+ sneltreinverbinding -+ snelwegennet -+ sneuvelbereidheid -+ snijkopzuiger -+ snipers -+ snoeiafval -+ snoeibeurt -+ snoepautomaat -+ snoepfabrikanten -+ snoepreis -+ snoezelen -+ snookerspeler -+ snuffelstage -+ soapachtige -+ soapopera -+ soapster -+ sociaal geneeskundige -+ sociaal geograaf -+ sociaal psychologen -+ sociaal psycholoog -+ sociaal verpleegkundige -+ sociaal-emotioneel -+ sociaal-ethisch -+ sociaal-maatschappelijk -+ sociaal-religieuze -+ sociaaldemocrate -+ sociaaldemocratischer -+ sociaalethische -+ sociaalliberaal -+ sociaalmaatschappelijke -+ sociaalmedische -+ sociaalpedagogisch -+ sociaalpedagogische -+ sociaalpolitiek -+ sociaalpolitieke -+ sociaalpsychiatrisch -+ sociaalpsychiatrische -+ sociaalpsychische -+ sociaalrealisme -+ sociaalrealistisch -+ socialezekerheidsbijdragen -+ socialiste -+ socialistisch realisme -+ socio -+ sociobiologische -+ sociopaat -+ sociopolitieke -+ sociowoningen -+ soepblikken -+ softdrugsgebruik -+ software-industrie -+ softwarecode -+ softwarecomponent -+ softwarecomponenten -+ softwareconcern -+ softwarecontract -+ softwarecontracten -+ softwaredistributeur -+ softwaredistributeurs -+ softwarefabrikant -+ softwarefabrikanten -+ softwaregroep -+ softwarekosten -+ softwareleverancier -+ softwarelicenties -+ softwaremakers -+ softwarematig -+ softwarematige -+ softwareontwikkelaar -+ softwareproblemen -+ softwareproducent -+ softwareproduct -+ softwareproducten -+ softwaresector -+ softwaresysteem -+ softwaresystemen -+ softwaretoepassingen -+ soja-eiwit -+ soja-eiwitten -+ soldatenmoeders -+ soleil -+ solidariteitsfonds -+ solidariteitsprincipe -+ solidariteitstoeslag -+ solidere -+ sollicitatiecursus -+ sollicitatieronde -+ solo-cd -+ soloalbum -+ soloconcerten -+ solodebuut -+ sologitarist -+ soloproject -+ solotentoonstelling -+ solovoorstelling -+ solowerk -+ solozeiler -+ solvabiliteitsratio -+ solventen -+ somfunctie -+ sommig -+ sonarapparatuur -+ songmateriaal -+ songschrijven -+ songschrijver -+ songschrijvers -+ songstructuren -+ songtitel -+ songtitels -+ soortenbeschrijving -+ soortenbeschrijvingen -+ sopraansaxofonist -+ sorbenkruid -+ sorrydemocratie -+ sorteerbedrijven -+ sorteercriteria -+ sorteerproef -+ sorteervolgorde -+ sotto -+ souljazz -+ soulplaat -+ soulvolle -+ soupertjes -+ source -+ souvenirtjes -+ spaarbedrag -+ spaarcentje -+ spaarfondsenwet -+ spaarformule -+ spaargedrag -+ spaarinspanning -+ spaarloonregeling -+ spaarloonregelingen -+ spaarmarkt -+ spaarmogelijkheden -+ spaarproduct -+ spaarproducten -+ spaarprogramma -+ spaarpunten -+ spaartekort -+ spaarverzekering -+ spaarvolume -+ spammers -+ spanningsgebied -+ spanningsgebieden -+ spanningshoofdpijn -+ spanningsomzetter -+ spanningsopbouw -+ sparring -+ speaking -+ specerijenhandel -+ speciaalbieren -+ speculatiewinst -+ speculatiewinsten -+ speelautomatenhal -+ speelbos -+ speeldata -+ speelfilmlengte -+ speelfilmregisseur -+ speelgedrag -+ speelgoedfabrikant -+ speelgoedindustrie -+ speelgoedketen -+ speelgoedpistool -+ speelgoedpop -+ speelgoedsector -+ speelgoedwapens -+ speelhoek -+ speelkansen -+ speellijst -+ speellokaal -+ speelomgeving -+ speelparadijs -+ speelperiode -+ speelplek -+ speelplekken -+ speelronde -+ speelronden -+ speelschema -+ speelstad -+ speeltechniek -+ speeltempo -+ speeltoestel -+ speeltoestellen -+ speelvlak -+ speelvloer -+ speelvoorzieningen -+ speelweek -+ speerwerpster -+ spekreepjes -+ spektakelshow -+ spektakelwaarde -+ spelbord -+ spelconcept -+ spelconsole -+ spelconsoles -+ speldeel -+ speler-trainer -+ spelergroep -+ spelerscarrière -+ spelerscontracten -+ spelersgroep -+ spelerslijst -+ spelersloopbaan -+ spelersmakelaar -+ spelersmakelaars -+ spelersmarkt -+ spelersmateriaal -+ spelersraad -+ spelersvakbond -+ spelersveld -+ spelersvrouwen -+ spelervaring -+ spelgedrag -+ spelletjesfabrikant -+ spelletjesmakers -+ spelletjesmarkt -+ spellingbestand -+ spellingbestanden -+ spellingscontrole -+ spellingsuggestie -+ spellingvoorschrift -+ spellingvoorschriften -+ spellingwet -+ spelmateriaal -+ spelmogelijkheden -+ spelniveau -+ spelontwikkelaars -+ spelopvatting -+ spelpatronen -+ spelplezier -+ spelprogramma -+ spelronde -+ spelshow -+ spelshows -+ spelsoort -+ spelsoorten -+ spelsystemen -+ speltype -+ speltypes -+ spelvreugde -+ sperperiode -+ speurdersroman -+ spiegeleffect -+ spiegelpaleis -+ spiegeltent -+ spiergroep -+ spierverslapper -+ spierverslapping -+ spiervlees -+ spierziekte -+ spierziekten -+ spijbelgedrag -+ spijkerbom -+ spijsverteringsstelsel -+ spilholding -+ spina -+ spina bifida -+ spionageaffaire -+ spionageschandaal -+ spionagesysteem -+ spionagethriller -+ spionagetoestel -+ spitsenkoppel -+ spitsentrainer -+ spitsheffing -+ spitspositie -+ spitsreizigers -+ spitstarief -+ spitstarieven -+ spitstoeslag -+ spoedadvies -+ spoedhulp -+ spoedoverleg -+ spoedritten -+ spoelvloeistof -+ sponseren -+ sponsoractie -+ sponsoractiviteiten -+ sponsorbedrag -+ sponsorbedragen -+ sponsorbeleid -+ sponsorcode -+ sponsorcontract -+ sponsorcontracten -+ sponsorgeld -+ sponsormogelijkheden -+ sponsorploegen -+ spookdorp -+ spookdorpen -+ spookfirma's -+ spookslot -+ spooktrein -+ spoorbedrijven -+ spoorbond -+ spoorcapaciteit -+ spoorkuil -+ spoormaatschappij -+ spoormarkt -+ spoormaterieel -+ spoornetwerk -+ spoorovergang -+ spoorstation -+ spoortraject -+ spoortrajecten -+ spoortunnel -+ spoortunnels -+ spoorverdubbeling -+ spoorverkeer -+ spoorvervoer -+ spoorvervoerders -+ spoorweginfrastructuur -+ spoorweglawaai -+ spoorwegnetwerk -+ spoorwegongevallen -+ spoorwegtraject -+ spoorwegvakbond -+ spoorwegvakbonden -+ sporenmateriaal -+ sportaanbod -+ sportactiviteit -+ sportarena -+ sportattributen -+ sportautoriteiten -+ sportbegroting -+ sportbeleid -+ sportbestuurder -+ sportbestuurders -+ sportbond -+ sportboycot -+ sportbudget -+ sportcarrière -+ sportcommentator -+ sportcommentatoren -+ sportcontacten -+ sportcoupé -+ sportcultuur -+ sportdeelname -+ sportdisciplines -+ sportdocent -+ sportdrama -+ sportfaciliteit -+ sportfaciliteiten -+ sportfans -+ sportfederatie -+ sportfilm -+ sportgala -+ sportgebeurtenissen -+ sportgebied -+ sportgekke -+ sportgeschiedenis -+ sportheld -+ sporthelden -+ sporthistoricus -+ sportinfrastructuur -+ sportjaar -+ sportkanaal -+ sportkantine -+ sportkantines -+ sportkatern -+ sportkledij -+ sportkledingfabrikant -+ sportklimaat -+ sportkoepel -+ sportland -+ sportlanden -+ sportleiders -+ sportles -+ sportlessen -+ sportletsel -+ sportleven -+ sportmarketing -+ sportmarkt -+ sportmateriaal -+ sportmedisch -+ sportmedische -+ sportmerk -+ sportministers -+ sportmogelijkheden -+ sportmoment -+ sportmomenten -+ sportmuseum -+ sportnatie -+ sportnet -+ sportnota -+ sportopleiding -+ sportploeg -+ sportploegen -+ sportpresentator -+ sportprojecten -+ sportruimte -+ sportschoenenfabrikant -+ sportsector -+ sportsite -+ sportsites -+ sportstad -+ sportstimulering -+ sportstoelen -+ sporttalent -+ sportteam -+ sportteams -+ sporttoernooi -+ sporttoernooien -+ sporttribunaal -+ sportvoeding -+ sportvrijwilliger -+ sportwagenmerk -+ sportwet -+ sportzender -+ sportzenders -+ spraakgestuurd -+ spraakmaker -+ spraakproblemen -+ spraaktechnologiebedrijf -+ spraakverkeer -+ spreektempo -+ sprekenden -+ springkasteel -+ springputten -+ sprintelite -+ sprintkampioen -+ sprintkampioene -+ sprintkanon -+ sprintkoning -+ sprintsnelheid -+ sprintwerk -+ sprintzege -+ sproeiwater -+ sprookjesschrijver -+ sprookjesverhalen -+ spuiterij -+ spuitgietmachines -+ spuitomruil -+ spuittechnieken -+ spuitwerk -+ sr. -+ staafbommen -+ staalaandelen -+ staalconcern -+ staalcrisis -+ staaldivisie -+ staaldraadproducent -+ staalfusie -+ staalgigant -+ staalgroep -+ staalkoord -+ staalmarkt -+ staalprijs -+ staalprijzen -+ staalproducent -+ staalproducenten -+ staalproducten -+ staalreus -+ staalsector -+ staalstad -+ staartbotsing -+ staartbotsingen -+ staats-tv -+ staatsaandeel -+ staatsaandelen -+ staatsbalans -+ staatsbanket -+ staatsbezit -+ staatsboerderijen -+ staatsbudget -+ staatscomité -+ staatscommissies -+ staatsdeelnemingen -+ staatsenergiebedrijf -+ staatsfabriek -+ staatsfuncties -+ staatsgarantie -+ staatsgaranties -+ staatsgasbedrijf -+ staatsgeld -+ staatsgevangenis -+ staatsgeweld -+ staatsgrond -+ staatshanden -+ staatsholding -+ staatshuishoudkunde -+ staatshulp -+ staatsinkomen -+ staatsinterventie -+ staatsinvloed -+ staatskranten -+ staatskunst -+ staatsleider -+ staatsleiders -+ staatslot -+ staatsmaatschappijen -+ staatsmanschap -+ staatsmedia -+ staatsmonopolist -+ staatsniveau -+ staatsoliebedrijf -+ staatsorganisatie -+ staatspersbureau -+ staatspolitie -+ staatspropaganda -+ staatsreligie -+ staatsschuldquote -+ staatsschuldreductie -+ staatssubsidie -+ staatssubsidies -+ staatssysteem -+ staatstaal -+ staatstelecombedrijf -+ staatsterreur -+ staatstoelage -+ staatsuitgaven -+ staatsverband -+ staatsverdrag -+ staatsvorming -+ staatsvrouw -+ staatszenders -+ stabilisatiebeleid -+ stabiliteitscontrole -+ stabiliteitspact -+ stabiliteitsproblemen -+ stabiliteitsprogramma -+ stadhuize -+ stadinwaarts -+ stadionconcerten -+ stadionramp -+ stadsarchitectuur -+ stadsas -+ stadsbestuurders -+ stadsbezoek -+ stadsboerderij -+ stadsbouwmeester -+ stadsbrand -+ stadsbrug -+ stadsdebatten -+ stadsdeelbestuur -+ stadsdeelcommissie -+ stadsdeelcommissies -+ stadsdeelplan -+ stadsdeelplannen -+ stadsdeelvoorzitter -+ stadsdeelvoorzitters -+ stadsdeelwethouder -+ stadsdeelwethouders -+ stadsderby -+ stadsdichter -+ stadseconomie -+ stadsetiquette -+ stadsfront -+ stadsgebied -+ stadsgebieden -+ stadsgedeelte -+ stadsgeschiedenis -+ stadsgesprekken -+ stadsgevangenis -+ stadsgewestelijk -+ stadsgewestelijke -+ stadsgids -+ stadsgroen -+ stadsjongen -+ stadsjungle -+ stadskantoor -+ stadskantoren -+ stadskas -+ stadskerk -+ stadslandschap -+ stadslandschappen -+ stadsmus -+ stadsmuseum -+ stadsnatuur -+ stadsnet -+ stadsnetten -+ stadsontwikkeling -+ stadspaleis -+ stadspartij -+ stadspersoneel -+ stadsplanning -+ stadsprins -+ stadsproblemen -+ stadspromotie -+ stadsraad -+ stadsrand -+ stadsranden -+ stadsregering -+ stadsregio -+ stadsring -+ stadsrondrit -+ stadsrumoer -+ stadssecretaris -+ stadstheater -+ stadstimmerman -+ stadstoezicht -+ stadsuitbreiding -+ stadsuitleg -+ stadsvernieuwingsfonds -+ stadsvernieuwingsgebieden -+ stadsvernieuwingsproject -+ stadsvernieuwingsprojecten -+ stadsvervoerbedrijven -+ stadsverwarmingsprojecten -+ stadsvilla's -+ stadsvisie -+ stadsvlucht -+ stadswachters -+ stadsweg -+ stadswoning -+ stadswoningen -+ stadsziekenhuis -+ stafbestuur -+ stafbureau -+ stage lopen -+ stage-adres -+ stagebegeleider -+ stageplek -+ stageproject -+ stakingsmiddel -+ stakingswapen -+ stakingswinst -+ stalking -+ stallingsruimte -+ stalruimte -+ stamcel -+ stamcellijnen -+ stamcelonderzoek -+ stamceltherapie -+ stamleider -+ standaardantwoord -+ standaardbedrag -+ standaardbehandeling -+ standaardgedrag -+ standaardisatieorgaan -+ standaardkenmerken -+ standaardmethode -+ standaardnormen -+ standaardopties -+ standaardpolis -+ standaardreactie -+ standaardregeling -+ standaardrepertoire -+ standaardsituaties -+ standaardsjabloon -+ standaardtaalinstelling -+ standaardtoets -+ standaardvergoeding -+ standaardversie -+ standaardzin -+ standalone -+ standenonderwijs -+ stankbeleid -+ stankcirkel -+ stankcirkels -+ stanknormen -+ stante pede -+ stap voor stap -+ stapavond -+ start-ups -+ startbaanovereenkomst -+ startbedrag -+ startersmarkt -+ starterspakket -+ startfase -+ startinvestering -+ startjaar -+ startkosten -+ startkwalificatie -+ startloon -+ startniveau -+ startnota -+ startnotitie -+ startnotities -+ startonderbreker -+ startpakket -+ startperiode -+ startplek -+ startpremie -+ startpremies -+ startprijs -+ startrecht -+ startrij -+ startsalaris -+ starttarief -+ starttijd -+ startveld -+ startzwemmer -+ stateloosheid -+ statengemeenschap -+ statiegeldflessen -+ stationsbuurt -+ stationseiland -+ stationsgebied -+ stationsgebieden -+ stationslocaties -+ stationsomgeving -+ stationswinkels -+ stationwagen -+ stationwagon -+ statu -+ statusbalk -+ statushouders -+ statusinformatie -+ statusverhoging -+ statusverschillen -+ statuswet -+ stealth -+ stedelijkheid -+ stedenbeleid -+ stedendriehoek -+ stedenreizen -+ stedentrip -+ stedenverbond -+ steekproefgewijs -+ steekproefonderzoek -+ steenfabriek -+ steenfragmenten -+ steigermateriaal -+ stellingnamen -+ stelopdracht -+ stelplicht -+ stelplichten -+ stembeheersing -+ stembusfraude -+ stembusnederlaag -+ stembusronde -+ stembusslag -+ stembuszege -+ stemcomputer -+ stemcomputers -+ stemgewicht -+ stemherkenning -+ stemmengewicht -+ stemmentellers -+ stemmenverdeling -+ stemmenverhouding -+ stemmenweging -+ stemmingsstoornissen -+ stempelcontrole -+ stempelpost -+ stemronde -+ stemsysteem -+ stemtechniek -+ stemverdeling -+ stemverhouding -+ stemverhoudingen -+ stenen gooien -+ stenengooiende -+ stents -+ steppegordel -+ steraandeel -+ steraandelen -+ steraanvaller -+ steracteur -+ steracteurs -+ steranijs -+ sterarchitect -+ sterauteur -+ stereotypering -+ sterfproces -+ sterftegevallen -+ sterfterisico -+ sterkeren -+ sterkteverdeling -+ sterolen -+ sterproduct -+ sterrencast -+ sterrendag -+ sterrenensemble -+ sterrenet -+ sterrenformatie -+ sterrenhotel -+ sterrenkok -+ sterrenmix -+ sterrennet -+ sterrenparade -+ sterrenstatus -+ sterrenstof -+ sterrol -+ sterstatus -+ stervenskoud -+ stervenswens -+ sterverslaggever -+ stervoetballer -+ stervoetballers -+ stervorm -+ sterwaarden -+ steunaanvraag -+ steunbeleid -+ steunbewijs -+ steunfunctie -+ steungrens -+ steungroep -+ steunlijn -+ steunniveau -+ steunniveaus -+ steunpakket -+ steunverklaring -+ stichtingsvoorzitter -+ stichtingsvorm -+ stijfbevroren -+ stijger -+ stijgijzers -+ stijlbijbel -+ stijlboek -+ stikjaloers -+ stikstofatomen -+ stikstofrijke -+ stiliste -+ stimulerender -+ stimuleringspakket -+ stimuleringspremie -+ stimuleringsprijs -+ stimuleringsproject -+ stoelbekleding -+ stoelnummer -+ stoemelings -+ stoerdere -+ stoerdoenerij -+ stofexplosie -+ stofexplosies -+ stofschijf -+ stofvorming -+ stokstaartje -+ stonerrock -+ stookgedrag -+ stookhout -+ stookinstallaties -+ stookverbod -+ stoomhoutzagerij -+ stoommandje -+ stoppoging -+ storingsmeldingen -+ storingsmonteurs -+ stortcapaciteit -+ stortverbod -+ storyboard -+ storyboards -+ stotterend -+ straatadvocaat -+ straatagenten -+ straatcultuur -+ straatdealers -+ straatfeest -+ straatgenoten -+ straathoekwerk -+ straatjongeren -+ straatlampen -+ straatprijs -+ straatprotest -+ straatprotesten -+ straatrellen -+ straattheaterfestival -+ straatwand -+ straatwerk -+ strafbeleid -+ strafcornerkanon -+ strafeis -+ strafeisen -+ straffere -+ strafklacht -+ strafklachten -+ strafklimaat -+ strafmaximum -+ strafminuten -+ strafonderzoek -+ strafpuntensysteem -+ strafrechtbank -+ strafrechtdeskundige -+ strafrechtdeskundigen -+ strafrechtgeleerde -+ strafrechtjuristen -+ strafrechtspecialist -+ strafrechtsysteem -+ strafsancties -+ strafsector -+ strafstelsel -+ straftraining -+ strafuitvoering -+ strafverhoging -+ strafverzwaring -+ stralingsdeskundige -+ stralingsdeskundigen -+ stralingsniveau -+ stralingsnormen -+ stranddag -+ strandopgang -+ strandvoetbal -+ strandwacht -+ strategienota -+ strategiespel -+ strategievorming -+ strategiewijziging -+ strategist -+ stratenboek -+ stratenboekje -+ streamers -+ streberig -+ streekarchief -+ streekarchivaris -+ streekbewoners -+ streekderby -+ streekgewest -+ streekkeuken -+ streekmanager -+ streekpost -+ streekproducten -+ streekspecialiteiten -+ streekvervoerder -+ streekvervoerders -+ streetwear -+ strenggereformeerde -+ stressfactor -+ stressfactoren -+ stressklachten -+ stresspreventie -+ stressstoornis -+ stresssyndroom -+ stressvol -+ strijdplan -+ strijdwijze -+ strijkwerk -+ stripachtige -+ stripauteurs -+ stripclub -+ stripfestival -+ stripgeschiedenis -+ stripmuseum -+ stripreeks -+ stripserie -+ striptekenen -+ striptekeningen -+ striptijdschrift -+ stripvorm -+ stripwereld -+ strooifolder -+ strooisellaag -+ strooiveld -+ strooiwagen -+ strooiwagens -+ stroomaf- en stroomopwaarts -+ stroombeurs -+ stroomcentrales -+ stroomcontracten -+ stroomcrisis -+ stroometikettering -+ stroomgebruik -+ stroomgigant -+ stroomimport -+ stroomkabel -+ stroomkabels -+ stroomkosten -+ stroomleverancier -+ stroomleveranciers -+ stroommarkt -+ stroomop- en stroomafwaarts -+ stroomproducent -+ stroomproducenten -+ stroomrekening -+ stroomrug -+ stroomruggen -+ stroomsector -+ stroomtarieven -+ structuurbeleid -+ structuurdrager -+ structuurdragers -+ structuurfonds -+ structuurgelden -+ structuurregime -+ structuurversterking -+ structuurvisie -+ struikelpartijen -+ struikjes -+ struisvogelvlees -+ studentenaantal -+ studentenarbeid -+ studentenbetogingen -+ studentenchipkaart -+ studentencomplex -+ studentenkerk -+ studentenkringen -+ studentenorkest -+ studentenpopulatie -+ studentenrellen -+ studentenroeivereniging -+ studentenwereld -+ studentenwoning -+ studentenwoningen -+ studentenzaken -+ studiebelasting -+ studiebezoek -+ studiebol -+ studiefase -+ studiehouding -+ studielening -+ studieleningen -+ studiemiddag -+ studiemodel -+ studiemodellen -+ studieopdracht -+ studieperiode -+ studieplaatsen -+ studieplanning -+ studieplein -+ studieprestaties -+ studieproject -+ studierapport -+ studiesucces -+ studietempo -+ studietraject -+ studieverblijf -+ studieverenigingen -+ studievoortgang -+ studievriendin -+ studieweek -+ studiewerk -+ studioalbum -+ studiobazen -+ studiomuzikant -+ studioplaat -+ studioplaten -+ studium generale -+ stuk voor stuk -+ stukadoorsbedrijf -+ stukbeleid -+ stuklijst -+ stuklijsten -+ stuntaanbiedingen -+ stuntploeg -+ sturingsmechanisme -+ stuwstof -+ stylen -+ subdocument -+ subdraad -+ subgenre -+ subgenres -+ subindex -+ sublicentie -+ sublicenties -+ subliminale -+ subniveau -+ subregionale -+ subsector -+ subsectoren -+ subsidieaanvragers -+ subsidiebijdrage -+ subsidiefonds -+ subsidiefraude -+ subsidiekorting -+ subsidiepotje -+ subsidiepotjes -+ subsidiepotten -+ subsidieprogramma -+ subsidieronde -+ subsidiestelsel -+ subsidiestromen -+ subsidiestroom -+ subsidieverhoging -+ subsidieverordening -+ subsidieverstrekkers -+ subsidieverstrekking -+ subsidievoorstel -+ substantiëlere -+ subsystemen -+ subtopic -+ subtypen -+ suburbaan -+ suburbane -+ suburbia -+ subwoofer -+ succesauteur -+ succesjaar -+ succespercentage -+ succespercentages -+ succesperiode -+ succesprogramma -+ succesrecept -+ succesreeks -+ succesroman -+ successerie -+ successieplanning -+ successiewet -+ succestrainer -+ succesvolste -+ sudden -+ sui -+ sui generis -+ suikermais -+ suikerproducent -+ suikerproducenten -+ suikerregime -+ summer -+ super-de-luxe -+ super-pg -+ superband -+ superbelegger -+ superblij -+ superboeren -+ supercool -+ superdag -+ supergemotiveerd -+ supergroep -+ superheld -+ superhelden -+ superhit -+ superkanon -+ superknecht -+ superkrachten -+ superlicentie -+ supermarktbedrijf -+ supermarktbedrijven -+ supermarktconcern -+ supermarktformule -+ supermarktformules -+ supermarktgroep -+ supermarktonderneming -+ supermarktorganisatie -+ supermarktreus -+ supermarktsector -+ supermarktwereld -+ superminister -+ superministerie -+ supermodel -+ supermodellen -+ superproductie -+ superrace -+ superrijk -+ superrijken -+ supersnelrecht -+ superspannend -+ superspion -+ supersportieve -+ superstaat -+ supersterk -+ superstrak -+ superstrakke -+ supertalent -+ supertrendy -+ supervloeibaar -+ supervorm -+ superzuinige -+ superzware -+ supportersbegeleiders -+ supportersbegeleiding -+ supportersbeleid -+ supportersbus -+ supportersgedrag -+ supportersgroep -+ supportersgroepen -+ supportershome -+ supporterskern -+ suprême -+ surfboard -+ surround -+ suïcidepoging -+ suïcidepogingen -+ swingender -+ swingendste -+ symboolwetgeving -+ symfonicus -+ symphatisanten -+ synchroonspringen -+ synergiemogelijkheden -+ synoniemenbestand -+ synoniemenbestanden -+ synthesizerpop -+ synthipop -+ systeemeisen -+ systeemgericht -+ systeemgerichte -+ systeemintegratie -+ systeemleverancier -+ systeemrisico -+ sámen -+ t'tjes -+ t.b.v. -+ t.h.t. -+ t.o.v. -+ t.w. -+ t.w.v. -+ t.z.t. -+ taakgestraften -+ taakomvang -+ taakorganisaties -+ taakspecialisatie -+ taakstraf -+ taakuitbreiding -+ taakverlichting -+ taaladviesdienst -+ taaladviesdiensten -+ taaladviezen -+ taalbad -+ taalcentrum -+ taalcongres -+ taaldocenten -+ taalfaciliteiten -+ taalfilosoof -+ taalgevoeligheid -+ taalhulpbestand -+ taalhulpbestanden -+ taalhulpen -+ taalkeuze -+ taalmethode -+ taalmethodes -+ taalontwikkeling -+ taalpakket -+ taalpakketten -+ taalproject -+ taalstandaard -+ taalstoornissen -+ taaltechnologiebedrijf -+ taaltelefoon -+ taaltest -+ taaltoets -+ taalvaardig -+ taalvaardige -+ taalvariant -+ taalvarianten -+ taalvernieuwing -+ taalverschil -+ taalvirtuoos -+ taalwetenschappers -+ taalwetgeving -+ tabaksbedrijf -+ tabaksbedrijven -+ tabaksbeleid -+ tabaksboeren -+ tabaksconsumptie -+ tabaksfirma's -+ tabaksgebruik -+ tabakslobby -+ tabaksontmoedigingsbeleid -+ tabaksproducten -+ tabaksrichtlijn -+ tabakssector -+ tabakstelers -+ tabaksverkoop -+ tabaksverslaving -+ tabakswinkelier -+ tabblad -+ tabbladen -+ tabeleigenschappen -+ tabelkop -+ tabelkoppen -+ tabellenregister -+ tabletteermachines -+ tabloidkrant -+ tabloidpers -+ tabpagina -+ tabula -+ tachtigplussers -+ taekwondoka -+ tafelrand -+ tafeltennisfederatie -+ tafeltennisteam -+ tai -+ takelbedrijf -+ tale -+ tale Kanaäns -+ talentontwikkeling -+ taligheid -+ talkshowhost -+ talkshowpresentator -+ tamarindebos -+ tamarindebossen -+ tambour -+ tandartsbezoek -+ tandartsenopleiding -+ tandartshulp -+ tandartspraktijk -+ tandartspraktijken -+ tandzorg -+ tankbeurt -+ tankbeurten -+ tankcommandant -+ tankervliegtuigen -+ tankkaart -+ tapas -+ tapijtsector -+ tapis -+ tapwater -+ tariefdaling -+ tariefdalingen -+ tariefdifferentiatie -+ tariefmaatregelen -+ tariefschaal -+ tariefstructuur -+ tariefswijziging -+ tariefverschillen -+ tariefzone -+ tariefzones -+ tarievenbeleid -+ tarievenstelsel -+ tarievenstructuur -+ tarievensysteem -+ tarieventabel -+ tarieventabellen -+ tarievenwijzer -+ tarificatie -+ tarweaar -+ tarweprijs -+ tarwezetmeel -+ taurine -+ taxatiebureau -+ taxatiekosten -+ taxatieronde -+ taxatieverslag -+ taxatieverslagen -+ taxibeleid -+ taxibranche -+ taxibusjes -+ taxiconflict -+ taxidiensten -+ taxikosten -+ taximarkt -+ taxinummer -+ taxiondernemer -+ taxiondernemers -+ taxirijders -+ taxitarieven -+ taxivergunning -+ taxivergunningen -+ taxiwereld -+ taxiwet -+ taxizaken -+ tbc-bacillen -+ tbc-bestrijding -+ tbc-gevallen -+ tbc-onderzoek -+ tbc-test -+ tbs'er -+ tbs-behandeling -+ tbs-gestelden -+ tbs-inrichting -+ tbs-inrichtingen -+ tbs-instellingen -+ tbs-maatregel -+ tbs-plaatsen -+ te berde brengen -+ te midden -+ te midden van -+ te moede -+ te pas en te onpas -+ te stade -+ te werk gaan -+ teach -+ teacher -+ teaching -+ teambegeleider -+ teambuildingsactiviteit -+ teambuildingsactiviteiten -+ teamcaptain -+ teamdokter -+ teamgenote -+ teamgenotes -+ teamleiding -+ teamleidster -+ teamprestatie -+ teamspel -+ teamspeler -+ teamsporters -+ techfondsen -+ techniciteit -+ technicolor -+ technolease -+ technologie-index -+ technologieaandelen -+ technologiebedrijf -+ technologiebedrijven -+ technologiebeurs -+ technologiebeurzen -+ technologiecentrum -+ technologieconcern -+ technologiefonds -+ technologiefondsen -+ technologiegebieden -+ technologiegedreven -+ technologiegroep -+ technologiehoek -+ technologiemarkt -+ technologieprojecten -+ technologiesector -+ technologiesubsidies -+ technologietransfer -+ technologiewaarden -+ technologisering -+ technomuziek -+ teelbalkanker -+ tegelen -+ tegenbegroting -+ tegendemonstranten -+ tegengebaar -+ tegengeluid -+ tegengeluiden -+ tegenonderzoek -+ tegenstelbaar -+ tegenvordering -+ tekenbevoegd -+ tekenbevoegdheid -+ tekenfilmfiguur -+ tekenfilmfiguurtje -+ tekenfilmheld -+ tekenfunctie -+ tekenfuncties -+ tekengereedschappen -+ tekenkleur -+ tekenmateriaal -+ tekenopmaakprofiel -+ tekenprofiel -+ tekensets -+ tekenwedstrijd -+ tekortreductie -+ tekstbereik -+ tekstbericht -+ tekstberichten -+ tekstberichtjes -+ tekstbijdragen -+ tekstcursor -+ tekstdocument -+ teksteffecten -+ tekstkaders -+ tekstkleur -+ tekstlaag -+ tekstobject -+ tekstobjecten -+ tekstopmaakprofiel -+ tekstopmaakprofielen -+ tekstoptie -+ tekstopties -+ tekstrichting -+ tekstselectie -+ tekstvak -+ tekstverloop -+ telco -+ telco's -+ teldatum -+ telecomaanbieder -+ telecomaanbieders -+ telecomaandeel -+ telecomactiviteiten -+ telecomanalist -+ telecomapparatuur -+ telecombranche -+ telecomdiensten -+ telecomdochter -+ telecomfabrikant -+ telecomfusie -+ telecomgebruikers -+ telecomgigant -+ telecomgroep -+ telecominfrastructuur -+ telecomkabels -+ telecommaatschappij -+ telecommarkt -+ telecommarkten -+ telecommunicatiediensten -+ telecommunicatiegroep -+ telecommunicatiekosten -+ telecommunicatiemarkt -+ telecommunicatiemiddelen -+ telecommunicatiesector -+ telecommunicatievoorzieningen -+ telecommunicatiewet -+ telecomnet -+ telecomnetwerk -+ telecomnetwerken -+ telecomoperator -+ telecomoperatoren -+ telecomoperators -+ telecomproducten -+ telecomreus -+ telecomsector -+ telecomspelers -+ telecomtoezichthouder -+ telecomverbindingen -+ telecomverkeer -+ telecomwaakhond -+ telecomwaarden -+ telecomwereld -+ telecomwet -+ telecomwetgeving -+ telefilm -+ telefilms -+ telefoniebedrijf -+ telefoniediensten -+ telefoniedochter -+ telefoniemarkt -+ telefonienetwerk -+ telefonieplatform -+ telefonieplatformen -+ telefoonaanbieders -+ telefoongebruikers -+ telefoongeheim -+ telefoonnetwerken -+ telefoonoperator -+ telefoonservice -+ telefoonsnoer -+ telefoonspelletje -+ telefoonspelletjes -+ telefoonteam -+ telefoontikken -+ telemetrie -+ telethuiswerk -+ teletijdmachine -+ televisie-interview -+ televisieaanbod -+ televisiebaas -+ televisiebedrijven -+ televisiecampagne -+ televisiecarrière -+ televisiecontracten -+ televisiecursus -+ televisiedienst -+ televisiediensten -+ televisiefabriek -+ televisiefestival -+ televisiefeuilleton -+ televisiegebied -+ televisiegeschiedenis -+ televisiegesprek -+ televisiegroep -+ televisieheld -+ televisiejournalist -+ televisiejournalistiek -+ televisiekok -+ televisiekomiek -+ televisielampen -+ televisieland -+ televisiemaatschappijen -+ televisieman -+ televisiemarkt -+ televisiemedewerkers -+ televisienetwerk -+ televisienetwerken -+ televisieopnamen -+ televisieopnames -+ televisiepresentatrice -+ televisieprijzen -+ televisieproducent -+ televisieproducenten -+ televisieprogrammering -+ televisieproject -+ televisiepubliek -+ televisiequiz -+ televisierecensent -+ televisierede -+ televisiereeks -+ televisieregisseur -+ televisieregistratie -+ televisierol -+ televisieseizoen -+ televisiesignaal -+ televisiesignalen -+ televisiesoap -+ televisietoespraak -+ televisietoren -+ televisieverslaggever -+ televisiewereld -+ televisiewerk -+ telomerase -+ telsysteem -+ temperatuursverhoging -+ temperatuursverschillen -+ temperend -+ temperende -+ tempo doeloe -+ temponorm -+ tempore -+ tempore's -+ temporeetje -+ tempoverschillen -+ ten aanschouwen van -+ ten bate van -+ ten bedrage van -+ ten behoeve van -+ ten belope van -+ ten bewijze van -+ ten burele -+ ten dele -+ ten derden male -+ ten dienste -+ ten enenmale -+ ten faveure van -+ ten gehore -+ ten gemeentehuize -+ ten geschenke -+ ten gevolge van -+ ten grave dragen -+ ten huize van -+ ten kantore -+ ten laste gelegde -+ ten laste leggen -+ ten onrechte -+ ten overstaan van -+ ten overvloede -+ ten paleize -+ ten stadhuize -+ ten tonele -+ ten vierden male -+ ten voordele van -+ tennisbond -+ tenniscarrière -+ tenniscircuit -+ tenniscomplex -+ tennisfans -+ tennisfenomeen -+ tennisgeschiedenis -+ tennisjaar -+ tenniskampioenen -+ tennisland -+ tennisleraar -+ tennisliefhebber -+ tennisloopbaan -+ tennispark -+ tennisraket -+ tennisraketten -+ tennisseizoen -+ tennissport -+ tennissucces -+ tennistalent -+ tennistoppers -+ tennisvedette -+ tennisvereniging -+ tennisvrouwen -+ tenniswereld -+ tentamenopdracht -+ tentamenopdrachten -+ tentoonstellingsbeleid -+ tentoonstellingshal -+ tentoonstellingsmaker -+ tentoonstellingsmakers -+ tentoonstellingspark -+ ter kerke gaan -+ ter perse -+ ter plaatse -+ ter plekke -+ ter stede -+ ter wille -+ ter zake -+ ter ziele -+ tera -+ terabyte -+ terbeschikkinggestelden -+ terdoodveroordeelde -+ terdoodveroordeelden -+ termijnvisie -+ terms -+ terra incognita -+ terrassenbeleid -+ terre -+ terreinbeheer -+ terreinbeheerder -+ terreinbeheerders -+ terreuraanval -+ terreurbestrijders -+ terreurbeweging -+ terreurcampagne -+ terreurcellen -+ terreurdreiging -+ terreurnetwerk -+ terreurnetwerken -+ terreurregime -+ terrible -+ terribles -+ terrorisme-expert -+ terrorisme-experts -+ terroristengroep -+ terroristennetwerk -+ terroristenorganisatie -+ terug geweest -+ terug kunnen -+ terug moeten -+ terug willen -+ terug zijn -+ terugbetaalbaar -+ terugbetalingsprijs -+ terugbetalingsvoorwaarden -+ terugbouwen -+ terugdringing -+ teruggavebeleid -+ teruggehoord -+ teruggekeerden -+ teruggemeld -+ teruggeschoven -+ teruggestopt -+ teruggeweest -+ terughoudenheid -+ terugkeerbeleid -+ terugkeerders -+ terugkijkend -+ terugmelden -+ terugplaatsing -+ terugroepactie -+ terugroepbevel -+ terugtreding -+ terugverdieneffect -+ terugverdieneffecten -+ terugverkocht -+ terugveroverd -+ terugveroveren -+ terzelfder tijd -+ testamentische -+ testapparatuur -+ testauto -+ testbank -+ testbeleid -+ testcentra -+ testcentrum -+ testfaciliteiten -+ testgegevens -+ testjes -+ testmarkt -+ testmodel -+ testpanel -+ testperiode -+ testpersonen -+ testpersoon -+ testpubliek -+ testrit -+ testsystemen -+ testteam -+ testversie -+ testversies -+ testwedstrijd -+ testwedstrijden -+ tevergeefse -+ tevredenheidsonderzoek -+ tewerkstellingsbeleid -+ tex -+ textielexport -+ textielfamilie -+ textielgroep -+ textielhandel -+ textielhandelaar -+ textielmarkt -+ textielmuseum -+ textielproducent -+ textielproducenten -+ textielsector -+ textielstad -+ textielsupers -+ textielwinkels -+ thalassotherapie -+ the -+ theateracteur -+ theateragenda -+ theaterbedrijf -+ theaterbewerking -+ theatercarrière -+ theaterconcert -+ theaterdebuut -+ theaterfeest -+ theatergebouw -+ theaterland -+ theaterlicht -+ theaterliefhebber -+ theatermaken -+ theaterman -+ theatermarathon -+ theatermuziek -+ theateroptreden -+ theateroptredens -+ theaterpodium -+ theaterpraktijk -+ theaterprijs -+ theaterproductie -+ theaterprogramma -+ theaterproject -+ theaterregisseur -+ theatershow -+ theatersolo -+ theatertalent -+ theatertechnici -+ theatertekst -+ theaterteksten -+ theatertour -+ theatertournee -+ theatertraditie -+ theatervak -+ theatervernieuwer -+ theatervorm -+ theatervormen -+ theaterwereld -+ theaterwerk -+ theaterwerkplaats -+ theaterzaal -+ theatraliteit -+ theekoepels -+ themabijlage -+ themakanaal -+ themakanalen -+ themakeuze -+ themamiddag -+ themapagina -+ themapakket -+ themaprogramma -+ themasites -+ themaweken -+ themazender -+ themazenders -+ theologieopleidingen -+ theologiestudie -+ therapiesessies -+ theremin -+ thermo -+ thermostatische -+ thesauriefondsen -+ thinking -+ thomas -+ thrillerauteur -+ thrillerauteurs -+ thuis voelen -+ thuisadres -+ thuisarbeid -+ thuisbaan -+ thuisbehandeling -+ thuisbevallen -+ thuisbioscoop -+ thuisduel -+ thuisduels -+ thuisgebruikers -+ thuisgevoel -+ thuiskok -+ thuiskopie -+ thuiskopieën -+ thuiskopiëren -+ thuiskwekers -+ thuisnet -+ thuispagina -+ thuispubliek -+ thuisrijder -+ thuisservice -+ thuissituatie -+ thuisspeler -+ thuisstaat -+ thuisstad -+ thuisteelt -+ thuistelers -+ thuistest -+ thuisverzorging -+ thuisvoordeel -+ thuiswonen -+ thuiswonenden -+ thuiszorgbureaus -+ thuiszorgers -+ thuiszorginstelling -+ thuiszorginstellingen -+ thuiszorgmedewerkers -+ thymine -+ tickertape -+ ticketbureau -+ ticketverkoop -+ tienerblad -+ tienerdisco -+ tienerjongen -+ tienerjongens -+ tienerleeftijd -+ tienermeisje -+ tieneropvang -+ tienersterren -+ tienersterretje -+ tienjaars -+ tienjaarsrente -+ tienjarenplan -+ tijdcapsule -+ tijdregistratie -+ tijdreis -+ tijdreizen -+ tijdritfiets -+ tijdsbalk -+ tijdsbeleving -+ tijdsbeslag -+ tijdscapsule -+ tijdschriftenmarkt -+ tijdsdimensie -+ tijdsduren -+ tijdsgebrek -+ tijdsgeest -+ tijdshorizon -+ tijdskader -+ tijdsklem -+ tijdslijn -+ tijdspad -+ tijdsperiode -+ tijdsperspectief -+ tijdstabel -+ tijdstraf -+ tijdswaarde -+ tijdswinst -+ tijgerprint -+ tikkend -+ tikkende -+ tilapia -+ tillift -+ tiplijn -+ tireur -+ titelbalk -+ titelbescherming -+ titelfavoriet -+ titelfeest -+ titelkandidaat -+ titelkandidaten -+ titelpretendent -+ titelprolongatie -+ titelrace -+ titelstuk -+ tl -+ tl-balk -+ tl-lampen -+ tl-verlichting -+ to -+ toebemeten -+ toegangsdrempel -+ toegangseisen -+ toegangspunten -+ toegangsticket -+ toegangstickets -+ toegangsverbod -+ toegefaxt -+ toegeleid -+ toekomstgerichtheid -+ toekomstkansen -+ toekomstplaatje -+ toekomstproject -+ toekomstroman -+ toekomstschets -+ toekomststrategie -+ toekomstvastheid -+ toekomstvoorspellingen -+ toelatingscommissie -+ toelatingsproef -+ toelatingsregels -+ toelatingsvoorwaarden -+ toeleiden -+ toepassingssoftware -+ toerbus -+ toerbussen -+ toerisme-industrie -+ toerismesector -+ toeristenbranche -+ toeristeneiland -+ toeristenfuik -+ toeristenmarkt -+ toeristenmentaliteit -+ toeristenorganisatie -+ toeristenplaats -+ toeristenplaatsen -+ toeristenstad -+ toeristentrekker -+ toeristenval -+ toerit -+ toeritdosering -+ toeritten -+ toermotor -+ toernooidirecteur -+ toernooileiding -+ toernooischema -+ toernooizaal -+ toespitsing -+ toestemmingswet -+ toetreders -+ toetredingsdatum -+ toetredingsdrempel -+ toetredingsdrempels -+ toetredingslanden -+ toetredingsproces -+ toetscombinatie -+ toetsenbordje -+ toetseniste -+ toetsingsprocedure -+ toetsje -+ toetsresultaten -+ toevalsgetallen -+ toevoerlijnen -+ toewijzingsprocedure -+ toewijzingssysteem -+ toezicht houden -+ toezichtorgaan -+ toezichtsgebied -+ toezichtsgebieden -+ toezichtsorgaan -+ toiletbezoek -+ toiletdeur -+ toiletgang -+ toiletspoeling -+ toilette -+ toiletteje -+ toiletwagen -+ toiletwagens -+ token -+ tolerance -+ tolplan -+ tolpleinen -+ tolpoort -+ tolpoortjes -+ tolsysteem -+ tomatenkwekers -+ tomatenplanten -+ toneelacteurs -+ toneelauteur -+ toneelbestel -+ toneeldebuut -+ toneellessen -+ toneelmonoloog -+ toneeltekst -+ toneelversie -+ toneelwereld -+ toneelwerken -+ tongpiercing -+ tongue -+ tongwerken -+ tonijnsalade -+ tonnagegrondslag -+ top acht -+ top drie -+ top honderd -+ top tien -+ top twaalf -+ top twintig -+ top veertig -+ top vier -+ top vijf -+ top vijftien -+ top zes -+ topaandelen -+ topaankoop -+ topacteurs -+ topacts -+ topadvocaat -+ topamusement -+ toparchitecten -+ topauteurs -+ topbaan -+ topbands -+ topbanken -+ topbankier -+ topbankiers -+ topbasketbal -+ topbedrijf -+ topbedrijven -+ topbenoemingen -+ topbestemming -+ topbezetting -+ topcapaciteit -+ topcoach -+ topcrimineel -+ topdiplomaat -+ topduo -+ topeconomen -+ topfavoriete -+ topfilms -+ topformatie -+ topgroep -+ topholding -+ tophotels -+ topindustrieel -+ topindustriëlen -+ topinstituten -+ topinstituut -+ topjob -+ topjuristen -+ topkader -+ topkaderleden -+ topkaders -+ topkandidaat -+ topkantoren -+ topkeeper -+ topklinische -+ topkoers -+ topkoersen -+ topkok -+ topkunst -+ toplanden -+ topleiders -+ topliga -+ toplijst -+ toplocatie -+ toplokaties -+ toplopers -+ topmaand -+ topmedewerker -+ topmedewerkers -+ topmerk -+ topmilitair -+ topmilitairen -+ topmusea -+ topmusici -+ topmuzikanten -+ topnoten -+ topografieën -+ toponderhandelaar -+ toponderhandelaars -+ toponderzoek -+ toponderzoekers -+ topontwerper -+ topontwerpers -+ topopleiding -+ toporkest -+ toppaarden -+ topplaats -+ topplaatsen -+ topploeg -+ topploegen -+ toppolitici -+ toppoliticus -+ topprijs -+ topprijzen -+ topproduct -+ topproducten -+ topregisseur -+ toprenner -+ toprenners -+ toprijders -+ toproeien -+ toproeiers -+ topschaak -+ topschaatsen -+ topschaatser -+ topschaatsers -+ topschakers -+ topsegment -+ topseizoen -+ topspits -+ topspitsen -+ topsportbeleid -+ topsportbeleidsplan -+ topsportcarrière -+ topsportcoördinator -+ topsportevenementen -+ topsportgeneeskunde -+ topsporthal -+ topsportklimaat -+ topsportland -+ topsportmanager -+ topsportnota -+ topsportster -+ topsprinter -+ toptalent -+ toptalenten -+ toptarief -+ toptarieven -+ topteam -+ topteams -+ toptennisser -+ toptennissers -+ toptoernooi -+ toptoernooien -+ toptrainer -+ toptrainers -+ toptransfer -+ toptrio -+ topturnen -+ topversie -+ topvrouwen -+ topweekeinde -+ topwerk -+ topwerken -+ topwijn -+ topzwemmen -+ topzwemmer -+ topzwemster -+ torpedobuizen -+ tot dusver -+ tot dusverre -+ tot stand gekomen -+ tot stand komen -+ tot stikkens toe -+ tot vervelens toe -+ totaalaanpak -+ totaalervaring -+ totaalgeluid -+ totaalklank -+ totaalproduct -+ totaalproject -+ totaalrendement -+ totaalshots -+ totaalspektakel -+ totaalstand -+ totaalverbod -+ totaalvisie -+ total -+ tourbussen -+ tourettesyndroom -+ tourmanager -+ tourschema -+ tout -+ tout court -+ townships -+ traceerbaarheid -+ trackrecord -+ tractiecontrole -+ tracébesluit -+ tracédeel -+ tracédelen -+ tragédien -+ trainersbank -+ trainerslicentie -+ trainersloopbaan -+ trainersstaf -+ trainersvak -+ trainingsaanpak -+ trainingsarbeid -+ trainingsavond -+ trainingsavonden -+ trainingsbaan -+ trainingsdier -+ trainingskosten -+ trainingsmaatje -+ trainingsmogelijkheden -+ trainingsoord -+ trainingspartners -+ trainingsperiode -+ trainingsrit -+ trainingsritten -+ trainingssessie -+ trainingssessies -+ trainingstocht -+ trainingsuren -+ trainingsvlucht -+ trainingswerk -+ trajectbegeleider -+ trajectcontrole -+ trajectnota -+ trambedrijf -+ tramtunnel -+ tramverbod -+ trancemuziek -+ tranentrekkende -+ transactiebedrag -+ transactionele -+ transfergeld -+ transfergelden -+ transferpassagiers -+ transferperikelen -+ transferprijs -+ transferrechten -+ transformatorolie -+ transfusiebloed -+ transgenese -+ transmigratiebeleid -+ transmissiecapaciteit -+ transmissiesnelheid -+ transmurale -+ transponeringstabel -+ transponeringstabellen -+ transportassen -+ transportbataljon -+ transportbeleid -+ transportbranche -+ transportcentrum -+ transportgroep -+ transportinfrastructuur -+ transportland -+ transportleiding -+ transportlijn -+ transportmarkt -+ transportministers -+ transportnet -+ transportorganisatie -+ transportorganisaties -+ transportroute -+ transportroutes -+ transporttarieven -+ transportverbindingen -+ transportverbod -+ transportvergunning -+ transportverpakking -+ transportverpakkingen -+ transportwereld -+ transvetzuren -+ trapezenummer -+ trapezewerk -+ trappenhal -+ trapveld -+ trash -+ traumaheli -+ traumaverwerking -+ travertijn -+ treinbeïnvloeding -+ treindienstleider -+ treindienstleiders -+ treinenbouwer -+ treinladingen -+ treinmaatschappij -+ treinrover -+ treinseries -+ treinspoor -+ treinsporen -+ treinstaking -+ treinstakingen -+ treinstoring -+ treinstoringen -+ treinsurveillanten -+ treintarief -+ treintarieven -+ treinticket -+ treintraject -+ treintrajecten -+ treintransport -+ treintunnel -+ treinvertragingen -+ treinwagon -+ trekgedrag -+ trekkershutten -+ trekzak -+ trendgevoeligheid -+ trendkanaal -+ trendlijn -+ trendlijnen -+ trendvolgend -+ triatlete -+ tribal -+ tributyltin -+ tricotjes -+ triggerhappy -+ triglyceriden -+ trillingshinder -+ trillingsvrij -+ trilplaat -+ trilveen -+ trilvenen -+ triphop -+ troepeneenheid -+ troepenleverancier -+ troepenleveranciers -+ troepenleverende -+ troepenopbouw -+ troepenreductie -+ troepenschip -+ troepenterugtrekking -+ troepenvermindering -+ troepenversterking -+ troepenzending -+ trombosebeen -+ trompe -+ trompetspel -+ troonsopvolging -+ troostreden -+ tropischeplantenkas -+ trostomaat -+ trostomaten -+ trouwambtenaren -+ trouwdatum -+ trouwdiensten -+ trouwlocatie -+ truckdivisie -+ truckfabrikanten -+ truckmarkt -+ try -+ tryptofaan -+ tuberculosepatiënten -+ tuchtonderzoek -+ tuchtprocedure -+ tuchtprocedures -+ tuchtreglement -+ tuibrug -+ tuinartikelen -+ tuinbezitters -+ tuinbouwkas -+ tuinbouwkassen -+ tuinbouworganisatie -+ tuinbouworganisaties -+ tuinbouwsector -+ tuindersbedrijf -+ tuindersbedrijven -+ tuinhout -+ tuinpaviljoen -+ tuinschuurtje -+ tuinterras -+ tuinvijver -+ tumorgroei -+ tumorweefsel -+ tunnelbak -+ tunnelboor -+ tunnelboormachine -+ tunnelbouwers -+ tunnelbrand -+ tunnelbranden -+ tunneldeel -+ tunnelproject -+ tunnelramp -+ tunnelvariant -+ tunnelverbinding -+ turbinehal -+ turbodieselmotor -+ turbomotor -+ turfwinning -+ turkey -+ turnhal -+ tussen zitten -+ tussen-n -+ tussenafstand -+ tussenarrest -+ tussengastheer -+ tussengeneratie -+ tussenholding -+ tussenjaar -+ tussenkoeler -+ tussenniveau -+ tussenrapportage -+ tussenronde -+ tussenschoolse -+ tussentaal -+ tussentitels -+ tussenvariant -+ tv-aanbod -+ tv-acteur -+ tv-actie -+ tv-baas -+ tv-bazen -+ tv-bedrijf -+ tv-beelden -+ tv-blad -+ tv-campagne -+ tv-carrière -+ tv-circuit -+ tv-comedy -+ tv-commentator -+ tv-commentatoren -+ tv-contract -+ tv-contracten -+ tv-critici -+ tv-criticus -+ tv-diensten -+ tv-directeur -+ tv-documentaire -+ tv-documentaires -+ tv-dominee -+ tv-dominees -+ tv-drama -+ tv-ervaring -+ tv-film -+ tv-films -+ tv-fragmenten -+ tv-gebied -+ tv-geld -+ tv-gelden -+ tv-geschiedenis -+ tv-gesprek -+ tv-geweld -+ tv-gids -+ tv-hit -+ tv-interviewer -+ tv-journalist -+ tv-journalisten -+ tv-journalistiek -+ tv-kabel -+ tv-kok -+ tv-komiek -+ tv-komieken -+ tv-kritiek -+ tv-landschap -+ tv-magazine -+ tv-maker -+ tv-makers -+ tv-marathon -+ tv-markt -+ tv-medewerkers -+ tv-net -+ tv-netten -+ tv-netwerk -+ tv-netwerken -+ tv-nieuws -+ tv-omroepen -+ tv-oorlog -+ tv-opname -+ tv-opnamen -+ tv-opnames -+ tv-persoonlijkheden -+ tv-persoonlijkheid -+ tv-ploeg -+ tv-ploegen -+ tv-presentator -+ tv-presentatrice -+ tv-prijzen -+ tv-producent -+ tv-producente -+ tv-producenten -+ tv-producer -+ tv-productie -+ tv-producties -+ tv-project -+ tv-publiek -+ tv-quiz -+ tv-recensent -+ tv-reeks -+ tv-regisseur -+ tv-reportage -+ tv-seizoen -+ tv-serie -+ tv-series -+ tv-signaal -+ tv-soap -+ tv-special -+ tv-spel -+ tv-spelletje -+ tv-spelletjes -+ tv-sport -+ tv-spot -+ tv-spotje -+ tv-spotjes -+ tv-spots -+ tv-station -+ tv-stations -+ tv-ster -+ tv-sterren -+ tv-studio's -+ tv-systeem -+ tv-toespraak -+ tv-toren -+ tv-uitzending -+ tv-uitzendingen -+ tv-versie -+ tv-verslaggeefster -+ tv-verslaggever -+ tv-voetbal -+ tv-wereld -+ tv-zendtijd -+ twee derde -+ twee tiende -+ twee vijfde -+ tweedehandsauto's -+ tweedehandsboeken -+ tweedehandsmarkt -+ tweedehandswinkels -+ tweedehandszaak -+ tweedeklassenreiziger -+ tweedeklassenreizigers -+ tweedens -+ tweederangsrol -+ tweehonderddertig -+ tweehonderdjarig -+ tweehonderdtal -+ tweehonderdtwintig -+ tweehonderdveertig -+ tweehonderdvijftig -+ tweekappers -+ tweeledigheid -+ tweelingdorp -+ tweeliter -+ tweesterrenrestaurant -+ tweetaligen -+ tweeverdienende -+ tweeënnegentig -+ tweeëntachtig -+ tweeënveertig -+ tweeënveertigste -+ tweeënvijftig -+ tweeënzestig -+ tweeënzeventig -+ twenties -+ twintigjarigen -+ typeaanduidingen -+ typefoutje -+ typevoorbeeld -+ tégen -+ tête -+ têtes -+ u'tjes -+ uiercel -+ uit eten -+ uit jagen -+ uit kunnen -+ uit willen -+ uitbesteder -+ uitbesteders -+ uitbodeming -+ uitbreidingsgebied -+ uitbreidingsgebieden -+ uitbreidingsinvesteringen -+ uitbreidingslocaties -+ uitbreidingsonderhandelingen -+ uitbreidingsproces -+ uitbreidingsprojecten -+ uitbreidingsronde -+ uitbreidingsvergunning -+ uitchecken -+ uitdijende -+ uitduel -+ uitduels -+ uiteenliggende -+ uiteenspatte -+ uitfadede -+ uitgaanscircuit -+ uitgaansgebied -+ uitgaansgebieden -+ uitgaansgeweld -+ uitgaanspubliek -+ uitgaansstraat -+ uitgaanstenue -+ uitgaanswijk -+ uitgavenbeheersing -+ uitgavengroei -+ uitgavenkader -+ uitgavenkant -+ uitgavenmeevallers -+ uitgavenniveau -+ uitgavennorm -+ uitgavenplafond -+ uitgavenpost -+ uitgavenposten -+ uitgavenstijging -+ uitgediscussieerd -+ uitgeefconcern -+ uitgefaseerd -+ uitgefaseerde -+ uitgekieperd -+ uitgeprocedeerden -+ uitgeregeerd -+ uitgerijpt -+ uitgestotenen -+ uitgeversbranche -+ uitgeversconcern -+ uitgeversgroep -+ uitgevershuis -+ uitgeversland -+ uitgeversparadijs -+ uitgiftebedrag -+ uitgifteprospectus -+ uithouding -+ uithuiszetting -+ uitjoeg -+ uitkan -+ uitkeringsbedrag -+ uitkeringsfabriek -+ uitkeringsfraude -+ uitkeringshoogte -+ uitkeringsinstantie -+ uitkeringsinstellingen -+ uitkeringslasten -+ uitkeringsniveau -+ uitkeringsontvanger -+ uitkeringsontvangers -+ uitkeringsorganisatie -+ uitkeringssituatie -+ uitkeringssysteem -+ uitkeringsverhouding -+ uitkijkpunt -+ uitkoopbod -+ uitkragende -+ uitlaatsysteem -+ uitlaatsystemen -+ uitleenpost -+ uitleenrecht -+ uitleenrechten -+ uitleveringsbevel -+ uitleveringswet -+ uitloopgebied -+ uitname -+ uitnodigender -+ uitoefenbaar -+ uitoefenkoers -+ uitonderhandelen -+ uitontwikkeld -+ uitponden -+ uitputtender -+ uitrustingsgoederen -+ uitrustingsniveau -+ uitschakelbare -+ uitschrijver -+ uitschrijvers -+ uitsnijderijen -+ uitsprakenlijst -+ uitspringing -+ uitstaans -+ uitstaans hebben met -+ uitstapkosten -+ uitstapleeftijd -+ uitstappers -+ uitstelgedrag -+ uitsterfbeleid -+ uitstroompremie -+ uittredingsvergoeding -+ uitvaartbranche -+ uitvaartondernemer -+ uitvaartondernemers -+ uitvaartverzekeraar -+ uitvaartverzekeringen -+ uitvaartverzorging -+ uitvaartwezen -+ uitvaartwinkel -+ uitvlagging -+ uitvoeringsinstantie -+ uitvoeringsinstelling -+ uitvoeringsinstellingen -+ uitvoeringsorganisaties -+ uitvoeringsplannen -+ uitvoeringsproblemen -+ uitvoeringsprogramma -+ uitvoeringsregeling -+ uitvoeringsregels -+ uitvoeringstaken -+ uitvoeringswet -+ uitvoerprijzen -+ uitwerkingsplan -+ uitwisselingsstudent -+ uitwonenden -+ uitzend-cao -+ uitzendactiviteiten -+ uitzendbaan -+ uitzendbaar -+ uitzendbanen -+ uitzendbasis -+ uitzendbedrijf -+ uitzendbedrijven -+ uitzendconcern -+ uitzenddag -+ uitzenddiensten -+ uitzender -+ uitzenders -+ uitzendformule -+ uitzendfrequentie -+ uitzendgebied -+ uitzendgroep -+ uitzendkantoor -+ uitzendkantoren -+ uitzendketen -+ uitzendlicentie -+ uitzendonderneming -+ uitzendondernemingen -+ uitzendpersoneel -+ uitzendsector -+ uitzendtijd -+ uitzendtijdstip -+ uitzenduren -+ uitzenduur -+ uitzendvergunning -+ uitzendwerkers -+ uitzichtpunt -+ uitzoekwerk -+ uitzonden -+ uitzonderingsgrond -+ uitzonderingsgronden -+ uitzonderingsregels -+ uitzoomen -+ uloscholen -+ uloschool -+ ultrageheime -+ ultraliberalisme -+ ultranationalist -+ ultraorthodoxen -+ underscore -+ unitaristisch -+ unithoofd -+ unitmanager -+ universa -+ universalis -+ universiteitsbestuurders -+ universiteitscomplex -+ universiteitsmedewerker -+ universiteitsmedewerkster -+ universiteitspersoneel -+ universiteitsprofessor -+ universiteitsprofessoren -+ universiteitsterrein -+ up -+ upcomedian -+ upcomedy -+ upgirl -+ upgrades -+ uppen -+ uptruck -+ urbi -+ urine-incontinentie -+ urinecontrole -+ urinecontroles -+ urineonderzoek -+ urinetest -+ urinetesten -+ urinetests -+ urineverlies -+ urnenmuur -+ uterien -+ uurbedrag -+ uurjournaal -+ uurvergoeding -+ uv -+ v'tjes -+ v.t.t. -+ v.v. -+ v.v.t. -+ vaandeldraagster -+ vaarvakanties -+ vaarverbinding -+ vaatafwijkingen -+ vaatchirurg -+ vaatproblemen -+ vaatwasmiddel -+ vacaturesite -+ vaccinatiebeleid -+ vaccinatieverbod -+ vakantiebaantjes -+ vakantieboek -+ vakantiebudget -+ vakantiecentra -+ vakantiecentrum -+ vakantiecharters -+ vakantiefiles -+ vakantiefolders -+ vakantiefoto -+ vakantiegedrag -+ vakantiegids -+ vakantiekracht -+ vakantiekrachten -+ vakantiepark -+ vakantieparken -+ vakantiepatroon -+ vakantieplaats -+ vakantiepret -+ vakantiereizigers -+ vakantiesfeer -+ vakantieverkeer -+ vakantievierders -+ vakantievluchten -+ vakantiewoning -+ vakbondsactivisten -+ vakbondscongres -+ vakbondsfederatie -+ vakbondslui -+ vakbondsmacht -+ vakbondsman -+ vakbondsmannen -+ vakbondsmensen -+ vakbondsonderhandelaars -+ vakbondstop -+ vakbondstraditie -+ vakbondsverleden -+ vakbondsvertegenwoordiger -+ vakbondsvleugel -+ vakbondsvoorman -+ vakbondsvrouw -+ vakbondswoordvoerder -+ vakinformatie -+ vakjury -+ vakkrachten -+ vakmatig -+ vakmatige -+ vakterrein -+ vakwereld -+ vakwerkhuis -+ vakwerkhuizen -+ validen -+ vals spelen -+ valsheid in geschrifte -+ valutadagen -+ valutaproblemen -+ vampierfilm -+ van ambtswege -+ van binnenuit -+ van buiten uit -+ van dien -+ van gemeentezijde -+ van goeden huize -+ van goeden wille -+ van heinde en verre -+ van iets af moeten -+ van jongs af -+ van moslimzijde -+ van nature -+ van onzentwege -+ van oudsher -+ van overheidswege -+ van stadswege -+ van stavast -+ van tevoren -+ van zins zijn -+ vancomycine -+ vangkooien -+ vangstcapaciteit -+ vangstcijfers -+ vangsthoeveelheden -+ vangsthoeveelheid -+ vangstquota -+ vangstquotum -+ vanillesaus -+ variabilisatie -+ varkenpest -+ varkensbedrijf -+ varkensbloed -+ varkensboer -+ varkensboerderij -+ varkenscellen -+ varkenscrisis -+ varkensdebat -+ varkensflats -+ varkenshart -+ varkenslever -+ varkensoren -+ varkensorganen -+ varkenspestcrisis -+ varkenspestepidemie -+ varkenspestgebied -+ varkenspestvirus -+ varkensplan -+ varkensprijzen -+ varkenssector -+ varkenssperma -+ varkensstapel -+ varkensteelt -+ varkenstransporten -+ varkensvrije -+ varkenswet -+ vastgebouwd -+ vastgekluisterd -+ vastgetimmerd -+ vastgoedaandelen -+ vastgoedactiviteiten -+ vastgoedadviseur -+ vastgoedbedrijf -+ vastgoedbeheer -+ vastgoedbeheerder -+ vastgoedbelangen -+ vastgoedbelegger -+ vastgoedbelegging -+ vastgoedbeleggingen -+ vastgoedbeleggingsfonds -+ vastgoedbevak -+ vastgoedbevaks -+ vastgoedbezit -+ vastgoedcertificaat -+ vastgoedcertificaten -+ vastgoeddochter -+ vastgoedfiscaliteit -+ vastgoedfonds -+ vastgoedfondsen -+ vastgoedgroep -+ vastgoedkantoor -+ vastgoedmagnaat -+ vastgoedmakelaar -+ vastgoedonderneming -+ vastgoedontwikkelaar -+ vastgoedontwikkelaars -+ vastgoedontwikkeling -+ vastgoedpapier -+ vastgoedpatrimonium -+ vastgoedprijzen -+ vastgoedproject -+ vastgoedprojecten -+ vastgoedspecialist -+ vastgoedwaarden -+ vastgoedwereld -+ vasthaken -+ vasthouding -+ vastrentende -+ vbo-afdelingen -+ vbo-leerlingen -+ vbo-scholen -+ vbo-school -+ vechtkunst -+ vechtmarkt -+ vechtsporter -+ vectorafbeelding -+ vectorafbeeldingen -+ vectortekening -+ vectortekeningen -+ veediefstal -+ veegwet -+ veelbekritiseerde -+ veelbezochte -+ veelbezongen -+ veelgeciteerde -+ veelgelaagde -+ veelgemaakt -+ veelgemaakte -+ veelgenoemde -+ veelgestelde -+ veelkantige -+ veelluik -+ veelrijders -+ veeltaligheid -+ veenpluis -+ veenweidegebied -+ veenweidegebieden -+ veerbootramp -+ veercomfort -+ veerhaven -+ veerhavens -+ veerstoepen -+ veertienjarigen -+ veesector -+ veeteeltsector -+ veetransporteurs -+ veevervoerders -+ veevoederfabrikanten -+ veevoederindustrie -+ veevoedersector -+ veevoerfabrikanten -+ veevoerproducenten -+ vegetaal -+ veiligheidlekken -+ veiligheidsaangelegenheden -+ veiligheidsafspraken -+ veiligheidsambtenaren -+ veiligheidsanalyse -+ veiligheidsapparatuur -+ veiligheidsarchitectuur -+ veiligheidsaspecten -+ veiligheidsbelang -+ veiligheidsbelangen -+ veiligheidsbeleving -+ veiligheidsbronnen -+ veiligheidscamera's -+ veiligheidscertificaat -+ veiligheidschef -+ veiligheidsconcept -+ veiligheidscontracten -+ veiligheidscoördinator -+ veiligheidscriteria -+ veiligheidsdenken -+ veiligheidsdeskundigen -+ veiligheidsdoctrine -+ veiligheidsgarantie -+ veiligheidsgaranties -+ veiligheidsgebied -+ veiligheidsgevoel -+ veiligheidsgrens -+ veiligheidsinspectie -+ veiligheidsinspecties -+ veiligheidsinstanties -+ veiligheidskabinet -+ veiligheidskenmerken -+ veiligheidskordon -+ veiligheidskwesties -+ veiligheidslek -+ veiligheidslekken -+ veiligheidsmacht -+ veiligheidsnet -+ veiligheidsniveau -+ veiligheidsofficier -+ veiligheidsonderzoek -+ veiligheidsonderzoeken -+ veiligheidsoogpunt -+ veiligheidsoperatie -+ veiligheidsorganisatie -+ veiligheidsoverleg -+ veiligheidspakket -+ veiligheidspersoneel -+ veiligheidspolitiek -+ veiligheidspolitieke -+ veiligheidsprobleem -+ veiligheidsproblematiek -+ veiligheidsprocedures -+ veiligheidsrapport -+ veiligheidsrapporten -+ veiligheidsregelingen -+ veiligheidsregime -+ veiligheidssamenwerking -+ veiligheidssituatie -+ veiligheidsstelsel -+ veiligheidsstructuren -+ veiligheidsstructuur -+ veiligheidsstudie -+ veiligheidsstudies -+ veiligheidstaken -+ veiligheidsuitrusting -+ veiligheidsvacuüm -+ veiligheidsvest -+ veiligheidsvesten -+ veiligheidsvoorwaarden -+ veiligheidsvraagstuk -+ veiligheidsvraagstukken -+ veiligheidszaken -+ veilingcomplex -+ veilingdag -+ veilingdagen -+ veilinghamer -+ veilingkosten -+ veilingomzet -+ veilingontwerp -+ veilingopbrengst -+ veilingopzet -+ veilingprijs -+ veilingprijzen -+ veilingprocedure -+ veilingregels -+ veilingreglement -+ veilingresultaten -+ veilingsite -+ veilingsites -+ veilingsysteem -+ veilingwaarde -+ veilingwereld -+ veilplicht -+ veldcompetitie -+ velddoelpunt -+ veldopnamen -+ velkant -+ vennengebied -+ vennootschapsrechtelijke -+ vennootschapsstructuur -+ vennootschapsvorm -+ vennootschapsvormen -+ vennootschapswet -+ vennootschapswetgeving -+ vensterbreedte -+ vensterhoogte -+ vensterprogrammering -+ vensterschool -+ venstertijden -+ venture -+ ventures -+ veranderingsmanagement -+ veranderingsmanager -+ verbeteringsplan -+ verbeteringsplannen -+ verbeteringsvoorstellen -+ verbeteringswerken -+ verbeterplan -+ verbeterprojecten -+ verbindings -+ verbindingsapparatuur -+ verbindingsas -+ verbindingsgang -+ verbindingskantoren -+ verbindingsroute -+ verbindingszone -+ verbindingszones -+ verblijfsaccommodatie -+ verblijfsarrangementen -+ verblijfsdocumenten -+ verblijfsgebied -+ verblijfsgebieden -+ verblijfsklimaat -+ verblijfsplaats -+ verblijfsrecreatie -+ verblijfsruimte -+ verblijfsruimten -+ verblijfsstatus -+ verblijfstatus -+ verblijfstoerisme -+ verblijfsverbod -+ verblijvingsbeding -+ verbodsrecht -+ verbouwplannen -+ verbrandingsresten -+ verbrekingsvergoeding -+ verbruikersorganisatie -+ verdedigingscentrum -+ verdedigingsduo -+ verdedigingslijn -+ verdedigingsstrategie -+ verdedigingstaak -+ verdedigingsteam -+ verdedigingswal -+ verdeelstation -+ verdeelstations -+ verdelingsmechanisme -+ verdelingssysteem -+ verdergaand -+ verdienend -+ verdovingsgeweer -+ verdragsherziening -+ verdragsmiddelen -+ verdragsregels -+ verdragsstaten -+ verdragswijziging -+ verdragswijzigingen -+ verendek -+ verenigingscultuur -+ verenigingsleden -+ verenigingslid -+ verfbehandeling -+ verfblik -+ verfoliën -+ verfspatten -+ verfstreek -+ verg. -+ vergadercircuit -+ vergadercircuits -+ vergadercultuur -+ vergaderdag -+ vergaderdagen -+ vergaderjaar -+ vergaderjaren -+ vergaderkamer -+ vergaderkamers -+ vergaderorde -+ vergaderweek -+ vergelijkingsbasis -+ vergelijkingssite -+ vergelijkingssites -+ vergoedingenstelsel -+ vergoedingspakket -+ vergroenen -+ vergroening -+ vergunningplichtig -+ vergunningsplicht -+ vergunningsvoorschriften -+ verhaalkunst -+ verhaalopbouw -+ verhaalsmogelijkheden -+ verhaalwendingen -+ verhoordag -+ verhoormethode -+ verhoormethoden -+ verhoortechniek -+ verhuiskostenvergoeding -+ verhuisoperatie -+ verhuisplan -+ verhuisplannen -+ verhuisplicht -+ verhuurmarkt -+ verhuurrecht -+ verificatiecommissie -+ verificatiesysteem -+ verifieerbaarheid -+ verjaardagsgeschenk -+ verjubelen -+ verkeersafwikkeling -+ verkeersagressie -+ verkeersambtenaar -+ verkeersassen -+ verkeersbeeld -+ verkeersbegeleiding -+ verkeersbegeleidingssysteem -+ verkeersbelasting -+ verkeersbesluit -+ verkeersbrug -+ verkeerscentrum -+ verkeerscirculatie -+ verkeerscirculatieplan -+ verkeersdeelname -+ verkeersdoorstroming -+ verkeersdruk -+ verkeerseducatie -+ verkeersellende -+ verkeersexamen -+ verkeersgegevens -+ verkeersgeleiding -+ verkeersgroei -+ verkeersgroep -+ verkeershandhaving -+ verkeershinder -+ verkeersinfarct -+ verkeersinzicht -+ verkeersjournaal -+ verkeersknelpunten -+ verkeersknoop -+ verkeerskundig -+ verkeerskundige -+ verkeersles -+ verkeerslessen -+ verkeersluw -+ verkeersluwe -+ verkeersmanagement -+ verkeersminister -+ verkeersministers -+ verkeersmisdrijven -+ verkeersomstandigheden -+ verkeersonderzoek -+ verkeersonveilig -+ verkeersonveilige -+ verkeersoverlast -+ verkeersproblematiek -+ verkeersproject -+ verkeersprojecten -+ verkeersregelaar -+ verkeersregeling -+ verkeersremmende -+ verkeersrotonde -+ verkeersroute -+ verkeersroutes -+ verkeerssignalering -+ verkeersspecialist -+ verkeersstructuur -+ verkeerstellingen -+ verkeerstoename -+ verkeerstoezicht -+ verkeersveilig -+ verkeersveilige -+ verkeersveiliger -+ verkeersveiligheidsactie -+ verkeersveiligheidsbeleid -+ verkeersveiligheidsplan -+ verkeersverbindingen -+ verkeerswetgeving -+ verkeerswethouder -+ verkeerszaken -+ verkenningsmissie -+ verkenningsmissies -+ verkenningsvoertuig -+ verkenningsvoertuigen -+ verkiezingsavond -+ verkiezingsborden -+ verkiezingsboycot -+ verkiezingscomité -+ verkiezingscongres -+ verkiezingsfolders -+ verkiezingsfondsen -+ verkiezingsfunctionarissen -+ verkiezingsgeweld -+ verkiezingsitem -+ verkiezingsjaar -+ verkiezingskoorts -+ verkiezingsnieuws -+ verkiezingspad -+ verkiezingsperiode -+ verkiezingsposter -+ verkiezingsposters -+ verkiezingsprocedure -+ verkiezingsproces -+ verkiezingsraad -+ verkiezingsronde -+ verkiezingsronden -+ verkiezingsslag -+ verkiezingsspot -+ verkiezingssucces -+ verkiezingswaarnemer -+ verkiezingswaarnemers -+ verkiezingswet -+ verkiezingszege -+ verkleutering -+ verkommering -+ verkoopaantallen -+ verkoopactie -+ verkoopacties -+ verkoopactiviteiten -+ verkoopadvies -+ verkoopadviezen -+ verkoopautomaten -+ verkoopbedrag -+ verkoopcatalogi -+ verkoopcatalogus -+ verkoopdivisie -+ verkoopdruk -+ verkoopgolf -+ verkoopinformatie -+ verkoopkoers -+ verkoopkoersen -+ verkooplijst -+ verkoopmaatschappij -+ verkoopmarges -+ verkoopmedewerker -+ verkoopnetwerk -+ verkoopplicht -+ verkooppraktijken -+ verkoopprocedure -+ verkoopproces -+ verkooprecord -+ verkoopruimte -+ verkoopsignaal -+ verkoopsignalen -+ verkoopstijging -+ verkoopstop -+ verkooptalent -+ verkooptijd -+ verkooptransactie -+ verkooptransacties -+ verkoopverbod -+ verkoopvolume -+ verkoopvolumes -+ verkoopwinst -+ verkoopzijde -+ verkozene -+ verkrapping -+ verlanding -+ verlichtingsarmaturen -+ verliesjaar -+ verliesjaren -+ verlieskansen -+ verliesnorm -+ verliesnormen -+ verliespartij -+ verliespartijen -+ verliessituatie -+ verlofspaarregeling -+ verlofsparen -+ verlofuren -+ verlofvormen -+ verloningssysteem -+ verloningssystemen -+ verlovingsaankondiging -+ vermaakcentra -+ vermarkting -+ vermenigvuldigingsteken -+ vermogenscriminaliteit -+ vermogenseffect -+ vermogenseffecten -+ vermogensgroei -+ vermogensmarkt -+ vermogensmisdrijven -+ vermogensopbouw -+ vermogensoverschot -+ vermogensschade -+ vermogenstekort -+ vermogensversterking -+ vermogensvorming -+ vernageling -+ vernaggelen -+ vernieuwender -+ vernieuwingsbeleid -+ vernieuwingsdrift -+ vernieuwingsgezindheid -+ vernieuwingsplan -+ vernieuwingsplannen -+ vernieuwingsprogramma -+ vernieuwingsprojecten -+ vernieuwingsscholen -+ vernieuwingsvoorstellen -+ veroorzakend -+ verouderingsaftrek -+ verpakker -+ verpakkers -+ verpakkingsafdeling -+ verpakkingsgroep -+ verpleegbedden -+ verpleegduur -+ verpleeghuisarts -+ verpleeghuisartsen -+ verpleeghuisbewoners -+ verpleeghuisindicatie -+ verpleeghuispatiënten -+ verpleegzorg -+ verpulpte -+ verrassingsmenu -+ verrevelder -+ verschillenden -+ versheidsdatum -+ versiebeheersysteem -+ versiebeheersystemen -+ verslavingsdeskundigen -+ verslavingsgedrag -+ verslavingskliniek -+ verslavingsklinieken -+ verslavingsreclassering -+ versmarkt -+ verspreidingskaart -+ verspreidingskaarten -+ verstandigen -+ verstoffen -+ verstoppertjes -+ verstotene -+ vertaalproblemen -+ vertaalproject -+ vertaalsoftware -+ vertelfestival -+ vertelplezier -+ vertelstijl -+ vertelstructuur -+ verteltempo -+ vertelvoorstelling -+ vertelvorm -+ verticalisering -+ vertragingsmanoeuvre -+ vertragingsmanoeuvres -+ vertrekbasis -+ vertrekcentrum -+ vertrekoverschot -+ vertrouwder -+ vertrouwensband -+ vertrouwensbreuk -+ vertrouwensherstel -+ vertrouwensindex -+ vertrouwensregel -+ vertrouwensverlies -+ vertrouwensvraag -+ vertwintigvoudigd -+ vervangingsinkomsten -+ vervangingsplicht -+ vervangingspool -+ vervangingspools -+ vervangingsregeling -+ vervangingstabel -+ vervangingsvraag -+ vervangmiddel -+ vervangwagen -+ verveelvoudiging -+ vervoermarkt -+ vervoersaanbod -+ vervoersassen -+ vervoersbehoefte -+ vervoersbonden -+ vervoerscijfers -+ vervoersdeskundigen -+ vervoersdienst -+ vervoersdiensten -+ vervoersgebied -+ vervoersgebieden -+ vervoersgroei -+ vervoersknooppunt -+ vervoersknooppunten -+ vervoerskostenvergoeding -+ vervoersmanagement -+ vervoersmarkt -+ vervoersmiddel -+ vervoersmiddelen -+ vervoersnet -+ vervoersnetwerk -+ vervoersprestatie -+ vervoersprobleem -+ vervoersproblemen -+ vervoersprognoses -+ vervoersproject -+ vervoersprojecten -+ vervoersregeling -+ vervoersstromen -+ vervoersstroom -+ vervoerstromen -+ vervoersvergoeding -+ vervoersvoorwaarden -+ vervoersvoorziening -+ vervoersvoorzieningen -+ vervoersvorm -+ vervoersvormen -+ vervoersvraag -+ vervoerswereld -+ vervoerswijze -+ vervoerswijzen -+ vervoerverbod -+ vervolge -+ vervolgoverleg -+ vervolgpagina -+ vervolgprocedure -+ vervolgproject -+ vervolgrapport -+ vervolgroman -+ vervolgschade -+ vervolgstap -+ vervolgstappen -+ vervolguitkering -+ vervolgvragen -+ vervollediging -+ vervormbaar -+ vervuilden -+ vervuilingseenheid -+ verwachtingswaarde -+ verwarmingsapparatuur -+ verwerkingsindustrie -+ verwerkingsinstallaties -+ verwerkingsmogelijkheden -+ verwerkingsproblemen -+ verwerkingssysteem -+ verwerkingstechnieken -+ verwijderbaar -+ verwijderbare -+ verwijdercentrum -+ verwijderingsbeleid -+ verwijsbrief -+ verwijzers -+ verwijzingscommissies -+ verzamelbeurs -+ verzamelbox -+ verzamelgebied -+ verzamelgebouw -+ verzamelinkomen -+ verzamelplek -+ verzamelterm -+ verzameltitel -+ verzamelwaarde -+ verzekerbaarheid -+ verzekeringsactiviteiten -+ verzekeringsbon -+ verzekeringsbranche -+ verzekeringsclaims -+ verzekeringsconcern -+ verzekeringsdekking -+ verzekeringsdochter -+ verzekeringsexperts -+ verzekeringsformule -+ verzekeringsgroep -+ verzekeringskamer -+ verzekeringsmakelaar -+ verzekeringsmarkt -+ verzekeringsonderneming -+ verzekeringsondernemingen -+ verzekeringspapieren -+ verzekeringspenningen -+ verzekeringspoot -+ verzekeringsproduct -+ verzekeringsproducten -+ verzekeringsreus -+ verzekeringssector -+ verzekeringssysteem -+ verzekeringstak -+ verzekeringstussenpersonen -+ verzekeringstussenpersoon -+ verzekeringswereld -+ verzendknop -+ verzetsactiviteiten -+ verzetsblad -+ verzetsdeelnemers -+ verzetsheldin -+ verzetskrant -+ verzetsleider -+ verzetsmuseum -+ verzinkerij -+ verzoenbaar -+ verzoeningsproces -+ verzorgingsinstellingen -+ verzorgingssector -+ verzuimcontrole -+ verzuimdagen -+ verzuringsgevoelig -+ vessem -+ vestigingsdirecteur -+ vestigingsland -+ vestigingslocatie -+ vestigingsmanager -+ vestigingsmogelijkheden -+ vestigingsplek -+ vestigingsrecht -+ vestigingsregels -+ vestzak-broekzak -+ vetconsumptie -+ veteranenleider -+ vetmester -+ vetmesters -+ vetoën -+ vetpercentage -+ vetsmelter -+ vetsmelterij -+ vetsmelterijen -+ vettere -+ vetverdeling -+ vezelactiviteiten -+ vgl. -+ via via -+ viagra -+ vice versa -+ viceaanvoerder -+ viceburgemeester -+ vicecommandant -+ vicefractieleider -+ vicefractievoorzitter -+ vicegouverneur -+ vicekoning -+ viceministers -+ vicepartijvoorzitter -+ vicepresidente -+ vicerector -+ vicesecretaris -+ vicesecretaris-generaal -+ video on demand -+ videobestanden -+ videobranche -+ videobrief -+ videobril -+ videoconferencing -+ videoconferentie -+ videoconferenties -+ videodocumentaire -+ videokunstenares -+ videomarkt -+ videomonitoren -+ videomontage -+ videomuur -+ videoprojecties -+ videoreportage -+ videoreportages -+ videospeler -+ videosysteem -+ videoverbinding -+ videowerk -+ videowerken -+ vient -+ vier tiende -+ vier vijfde -+ vier-zonder-stuurman -+ viercijferige -+ vierenhalf -+ vierenhalve -+ vierennegentig -+ vierentachtig -+ vierenveertig -+ vierenvijftig -+ vierenzestig -+ vierenzeventig -+ vierhonderdtal -+ vierhonderdvijftig -+ vierkoppig -+ vierkoppige -+ vierlandentoernooi -+ viermaandelijkse -+ viermanschap -+ vierpitter -+ viersporig -+ viersporige -+ viersterrengeneraal -+ viertonners -+ viertrapsautomaat -+ vierwielaangedreven -+ vierzitter -+ vieste -+ viewing -+ vijfbak -+ vijfendertigduizend -+ vijfenhalf -+ vijfenhalve -+ vijfennegentig -+ vijfentachtig -+ vijfentachtigste -+ vijfentwintighonderd -+ vijfenveertig -+ vijfenveertigduizend -+ vijfenveertigste -+ vijfenvijftig -+ vijfenvijftigste -+ vijfenzeventig -+ vijfhonderdvijftig -+ vijfjarenprogramma -+ vijfjarigen -+ vijfkruidenpoeder -+ vijftienen -+ vijftrapsautomaat -+ vijfversnellingsbak -+ vinkje -+ vinylchloride -+ viola -+ violoncello -+ violoncels -+ vioolconcerto -+ vioolvirtuoos -+ virtual -+ virtualisatie -+ virtualisaties -+ virtualiteit -+ virusbestrijder -+ virusbestrijders -+ virusscan -+ virusscans -+ virusschrijvers -+ visbedrijf -+ visbedrijven -+ visbereidingen -+ visbestand -+ visconsumptie -+ visfraude -+ visibiliteit -+ viskoekjes -+ viskweek -+ viskwekers -+ vismethoden -+ vispopulaties -+ visproducten -+ visquota -+ vissector -+ visserijakkoord -+ visserijbeleid -+ visserijministers -+ visserijrechten -+ visserijsector -+ visserijvloot -+ visserijwereld -+ visserschip -+ vissersgemeenschap -+ vissersleven -+ vissoort -+ visstek -+ visumaanvragers -+ visumkantoor -+ visumverlening -+ visverbod -+ visvoer -+ vitamineproducent -+ vitiligo -+ vitrofertilisatie -+ vivant -+ vivants -+ vive -+ vivo -+ vivre -+ vlagsignaal -+ vlakglas -+ vlaktaks -+ vlamvertrager -+ vlamvertragers -+ vlechtheg -+ vlechtheggen -+ vledder -+ vleermuisman -+ vleermuizengrot -+ vleesbedrijf -+ vleesbranche -+ vleescrisis -+ vleesexport -+ vleesexporteurs -+ vleesfraude -+ vleeshandel -+ vleeshandelaren -+ vleeskalveren -+ vleeskeurder -+ vleeskuikens -+ vleesproducenten -+ vleesresten -+ vleessector -+ vleesvee -+ vleesverwerker -+ vleesverwerking -+ vleeswarenindustrie -+ vlekkenpatroon -+ vleugelaanvaller -+ vleze -+ vliegervaring -+ vlieggedrag -+ vliegkosten -+ vlieglawaai -+ vliegmaatschappij -+ vliegmarkt -+ vliegprijzen -+ vliegschema -+ vliegstrip -+ vliegtarieven -+ vliegtijd -+ vliegtuigbemanningen -+ vliegtuigbenzine -+ vliegtuigbewegingen -+ vliegtuigdeur -+ vliegtuigfabrikant -+ vliegtuiglawaai -+ vliegtuigmaatschappij -+ vliegtuigmonteur -+ vliegtuigonderhoud -+ vliegtuigpassagier -+ vliegtuigreis -+ vliegtuigspotter -+ vliegtuigspotters -+ vliegtuigtechniek -+ vliegtuigtrap -+ vliegtuigtrombose -+ vliegveiligheid -+ vlinderstrik -+ vlindertuin -+ vlindervriendelijk -+ vlindervriendelijke -+ vloeistofpeil -+ vloerelementen -+ vlootdagen -+ vlootvernieuwing -+ vlot trekken -+ vlotgetrokken -+ vlottere -+ vluchtdeuren -+ vluchtelingenbeleid -+ vluchtelingencentrum -+ vluchtelingencrisis -+ vluchtelingendrama -+ vluchtelingenkinderen -+ vluchtelingenopvang -+ vluchtelingenpolitiek -+ vluchtelingenschip -+ vluchtelingenvrouwen -+ vluchtelingenwerk -+ vluchtelingschap -+ vluchtenden -+ vluchtgang -+ vluchtinformatie -+ vluchtingen -+ vluchtmogelijkheden -+ vluchtwagen -+ vmbo'ers -+ vmbo-scholen -+ vmbo-school -+ vnw. -+ vocaliste -+ voce -+ vochtbalans -+ vodje -+ vodjes -+ voedingsaandelen -+ voedingsadvies -+ voedingsbedrijf -+ voedingsbedrijven -+ voedingsconcern -+ voedingsdistributie -+ voedingsfabrikant -+ voedingsfabrikanten -+ voedingsfonds -+ voedingsgebied -+ voedingsgigant -+ voedingsgroep -+ voedingsingrediënten -+ voedingsmarkt -+ voedingsmiddelenbedrijf -+ voedingsmiddelenconcern -+ voedingsmiddelenproducent -+ voedingsnijverheid -+ voedingspakket -+ voedingsproducenten -+ voedingsreus -+ voedingssector -+ voedingsupplementen -+ voedingswaren -+ voedingswinkels -+ voedselaanbod -+ voedselagentschap -+ voedselautoriteit -+ voedselbonnen -+ voedselbron -+ voedselbureau -+ voedselconcern -+ voedselconsumptie -+ voedselcontrole -+ voedselcrises -+ voedseldeskundige -+ voedseldeskundigen -+ voedselgebied -+ voedselgebieden -+ voedselgewassen -+ voedselindustrie -+ voedselinfecties -+ voedselkwaliteit -+ voedselleveranties -+ voedselmarkt -+ voedselpatroon -+ voedselproblemen -+ voedselproducent -+ voedselproducenten -+ voedselproductie -+ voedselprogramma -+ voedselrantsoenen -+ voedselrellen -+ voedselschandaal -+ voedselschandalen -+ voedselsector -+ voedselsituatie -+ voedselverstrekking -+ voedselzekerheid -+ voedselzendingen -+ voegovergangen -+ voetbalacademie -+ voetbalafdeling -+ voetbalanalist -+ voetbalavontuur -+ voetbalbedrijf -+ voetbalbestuurder -+ voetbalbestuurders -+ voetbalboek -+ voetbalbolwerk -+ voetbalcarrière -+ voetbalcoach -+ voetbalcommentator -+ voetbalcontract -+ voetbalcultuur -+ voetbaldagen -+ voetbalderby -+ voetbaldeskundigen -+ voetbalevenement -+ voetbalevenementen -+ voetbalfan -+ voetbalfederatie -+ voetbalfestijn -+ voetbalfilm -+ voetbalgala -+ voetbalgek -+ voetbalgekte -+ voetbalgeluk -+ voetbalgeschiedenis -+ voetbalgevecht -+ voetbalgod -+ voetbalgras -+ voetbalgrootmacht -+ voetbalhistorie -+ voetbalintelligentie -+ voetbaljaar -+ voetbaljaargang -+ voetbaljournalist -+ voetbalkaarten -+ voetbalkaartje -+ voetbalkaartjes -+ voetbalkalender -+ voetbalkampioen -+ voetbalkampioenschap -+ voetbalkantine -+ voetbalkantines -+ voetbalkeeper -+ voetbalkenner -+ voetbalklasse -+ voetbalklassieker -+ voetbalkoning -+ voetbalkwaliteiten -+ voetballand -+ voetballanden -+ voetballegende -+ voetballeven -+ voetballied -+ voetballiefhebber -+ voetballoopbaan -+ voetbalmanager -+ voetbalmarkt -+ voetbalnatie -+ voetbalnaties -+ voetbaloorlog -+ voetbalopleiding -+ voetbalorganisatie -+ voetbalorganisaties -+ voetbalplaatjes -+ voetbalplezier -+ voetbalprogramma -+ voetbalpubliek -+ voetbalquiz -+ voetbalrechten -+ voetbalscheidsrechter -+ voetbalscheidsrechters -+ voetbalschool -+ voetbalselectie -+ voetbalshow -+ voetbalstad -+ voetbalsteden -+ voetbaltaal -+ voetbaltalenten -+ voetbalteam -+ voetbalteams -+ voetbaltechnische -+ voetbaltempel -+ voetbaltenue -+ voetbalterrein -+ voetbaltijdschrift -+ voetbaltop -+ voetbaltopper -+ voetbaltrainer -+ voetbaltrainers -+ voetbaltraining -+ voetbaltransfers -+ voetbaltrots -+ voetbaluitzendingen -+ voetbalverstand -+ voetbalvoorzitter -+ voetbalwereld -+ voetbalwet -+ voetbalzaken -+ voetbalzender -+ voetblessure -+ voetensteun -+ voetgangersverkeer -+ voetklachten -+ voetvolley -+ vogelaanvaringen -+ vogelboek -+ vogeleiland -+ vogelgebied -+ vogelgriep -+ vogelnamen -+ vogelnestkastje -+ vogelnestkastjes -+ vogelopvang -+ vogelopvangcentrum -+ vogelpoep -+ vogelpopulatie -+ vogelrichtlijn -+ vogeltellingen -+ vogelvoer -+ vogelwereld -+ vogelwerkgroep -+ voice -+ vol raken -+ vol zetten -+ vol zitten -+ volcontinu -+ volens -+ volente -+ volgepland -+ volgeplant -+ volgezet -+ volgrecht -+ volgsysteem -+ volhangen -+ volkenrechtdeskundige -+ volkerenrecht -+ volkscultuur -+ volksdrama -+ volksheilige -+ volksjury -+ volkskapitalisme -+ volksreligie -+ volkssterrenwacht -+ volkstoeloop -+ volkstuinencomplex -+ volkstuinvereniging -+ volksverheffing -+ volksvreugde -+ volleybalclub -+ volleybalvereniging -+ volmachtstemmen -+ volplempen -+ voltijdsbanen -+ volumedaling -+ volumegroei -+ volumeprocent -+ volumestijging -+ volwassenenstrafrecht -+ vondeliaans -+ vonkvorming -+ voogdijregeling -+ voor de hand liggend -+ voor pampus liggen -+ voor zover -+ vooraanstaanden -+ vooradvies -+ voorafbepaalde -+ voorafbetaalde -+ voorafspiegeling -+ voorakkoord -+ voorbeeldbrieven -+ voorbeeldgedrag -+ voorbeeldvenster -+ voorbeeldweergave -+ voorbelasting -+ voorbereidingsbesluit -+ voorbereidingshandeling -+ voorbereidingshandelingen -+ voorbereidingskamer -+ voorbereidingskosten -+ voorbereidingskrediet -+ voorbereidingsprogramma -+ voorbijdrijvende -+ voorbijrazend -+ voorbijrazende -+ voorbijrijdende -+ voorbijschuivende -+ voorbijvaren -+ voorburcht -+ voorcontract -+ voordeeltarief -+ voordele -+ voorfront -+ voorgedefinieerd -+ voorgedefinieerde -+ voorgestanst -+ voorgestanste -+ voorhoedescholen -+ voorinschrijving -+ voorinschrijvingen -+ voorinzage -+ voorjaarsdag -+ voorjaarsvakantie -+ voorjaarsvergadering -+ voorkenniszaak -+ voorkenniszaken -+ voorkeursactie -+ voorkeursacties -+ voorkeursbeleid -+ voorkeurskandidaat -+ voorkeurslijst -+ voorkeursregeling -+ voorkeursrichting -+ voorkeursstemmen -+ voorkeurstracé -+ voorkeursvariant -+ voorkooprecht -+ voorkruipen -+ voorkómen -+ voorleeskampioen -+ voorleessessies -+ voorleeswedstrijd -+ voorlichtingsactie -+ voorlichtingsactiviteiten -+ voorlichtingsafdeling -+ voorlichtingsmiddag -+ voorlichtingsprogramma -+ voorlichtingsproject -+ voorlichtingsprojecten -+ voorloopnullen -+ voorlopercellen -+ voornamelijke -+ vooropgeplaatst -+ vooropgeplaatste -+ voorplanting -+ voorrangsbeleid -+ voorrangspositie -+ voorrangszorg -+ voors -+ voors en tegens -+ voorschool -+ voorschrijfsysteem -+ voorstellingenreeks -+ voorstoelen -+ voortdenderende -+ voortgangsgesprek -+ voortgangsgesprekken -+ voortgewerkt -+ voortplantingsgedrag -+ voortrekkerij -+ voortvluchtigen -+ voortwerken -+ vooruitgangsgedachte -+ vooruitgestuurd -+ voorvleugel -+ voorvleugels -+ voorwielaandrijver -+ voorwielaangedreven -+ voorz. -+ voorzittersschap -+ voorzittersverkiezing -+ voorzittersverkiezingen -+ voorzitterszetel -+ voorzorgbeginsel -+ vorderingsrecht -+ vorigen -+ vormexperiment -+ vormexperimenten -+ vormgebrek -+ vormgevingsinstituut -+ vormingsonderwijs -+ vormprincipes -+ vormstukken -+ vormtaal -+ vormvereisten -+ vormverlies -+ vorstenhoven -+ vorstenspiegels -+ vossenlintworm -+ vossenpopulatie -+ vossenstand -+ voto's -+ votootje -+ vous -+ voustje -+ voyageurs -+ vraagafhankelijk -+ vraaggericht -+ vraaggerichte -+ vraaggestuurd -+ vraaggestuurde -+ vraagkant -+ vraagsturing -+ vraagzijde -+ vrachtactiviteiten -+ vrachtdivisie -+ vrachtdocumentatie -+ vrachtdocumenten -+ vrachtpapieren -+ vrachtruim -+ vrachttransport -+ vrachttrein -+ vrachtvliegveld -+ vrachtwagenbanden -+ vrachtwagenbedrijf -+ vrachtwagenbestuurder -+ vrachtwagenbouwer -+ vrachtwagenfabriek -+ vrachtwagenmarkt -+ vrachtwagenproducent -+ vragenronde -+ vragenrondje -+ vragenstelster -+ vragenvuur -+ vredebewarende -+ vredesactiviste -+ vredesakkoorden -+ vredesbeleid -+ vredesbewarende -+ vredesboodschap -+ vredesdialoog -+ vredesgebaar -+ vredesgroep -+ vredeshandhaver -+ vredeshandhavers -+ vredeskans -+ vredeslied -+ vredesmars -+ vredesmilitairen -+ vredesmonument -+ vredesonderhandelaar -+ vredesonderhandelaars -+ vredesopbouw -+ vredesoplossing -+ vredesoproep -+ vredesorganisatie -+ vredesovereenkomst -+ vredesovereenkomsten -+ vredespad -+ vredespartner -+ vredesproces -+ vredesprocessen -+ vredessoldaat -+ vredessoldaten -+ vredesstrategie -+ vredestaak -+ vredestaken -+ vredestichtende -+ vredestop -+ vredesverklaring -+ vredesvraagstukken -+ vredeswens -+ vreemdelingenbewaring -+ vreemdelingenkamer -+ vreemdelingenkamers -+ vreemdelingenrechter -+ vreemdelingenrechters -+ vreemdelingentoezicht -+ vreemdelingenvraagstuk -+ vreemdelingenwetgeving -+ vreemdetalenkennis -+ vreugdeschoten -+ vreugdesprong -+ vriendengroep -+ vriendengroepen -+ vriendschapsrelatie -+ vriescombinatie -+ vrij gevestigde -+ vrijdagnamiddag -+ vrijemarktwerking -+ vrijetijdsauto -+ vrijetijdscentrum -+ vrijetijdskunde -+ vrijetijdsmarkt -+ vrijetijdssector -+ vrijgespeeld -+ vrijgevestigd -+ vrijhandelsakkoord -+ vrijhandelsakkoorden -+ vrijheid-blijheid -+ vrijheidsbeperkende -+ vrijheidsgevoel -+ vrijlatingsregeling -+ vrijliggend -+ vrijliggende -+ vrijspelen -+ vrijvallende -+ vrijwaringsbewijs -+ vrijwilligersbeleid -+ vrijwilligersdag -+ vrijwilligersgroep -+ vrijwilligersorganisaties -+ vrijwilligersproject -+ vrijwilligersprojecten -+ vrijwilligersvergoeding -+ vroeggeboren -+ vroeggeborenen -+ vroeggestorven -+ vroegmoderne -+ vroegwijze -+ vrolijken -+ vrouw des huizes -+ vrouwenbasketbal -+ vrouwenbeen -+ vrouwencentrum -+ vrouwencircuit -+ vrouwenclubs -+ vrouwencollectie -+ vrouwenelftal -+ vrouwenfiguur -+ vrouwenfinale -+ vrouwenhockey -+ vrouwenhulpverlening -+ vrouwenkleren -+ vrouwenkwartet -+ vrouwenlevens -+ vrouwenlijf -+ vrouwennetwerk -+ vrouwenopvang -+ vrouwenorkest -+ vrouwenploeg -+ vrouwenproblemen -+ vrouwenrollen -+ vrouwenschaatsen -+ vrouwentennis -+ vrouwenvereniging -+ vrouwenvleugel -+ vrouwenwielrennen -+ vrouwenzaak -+ vrouwenzender -+ vrouwlief -+ vrouwverhouding -+ vs. -+ vu's -+ vugevoel -+ vuilbroed -+ vuildeeltjes -+ vuilnisberg -+ vuilniscontainer -+ vuilnisophaler -+ vuilnisophalers -+ vuilverbrander -+ vuilverbranders -+ vuilverwerker -+ vuistvuurwapens -+ vuur spuwen -+ vuursteun -+ vuurstorm -+ vuurvlinder -+ vuurvogel -+ vuurwapengeweld -+ vuurwapenlobby -+ vuurwerkbedrijf -+ vuurwerkbedrijven -+ vuurwerkbesluit -+ vuurwerkbranche -+ vuurwerkcampagne -+ vuurwerkexplosie -+ vuurwerkfestival -+ vuurwerkhandel -+ vuurwerkopslag -+ vuurwerkopslagplaats -+ vuurwerkopslagplaatsen -+ vuurwerkramp -+ vuurwerkresten -+ vuurwerkshow -+ vuurwerkshows -+ vuurwerkslachtoffers -+ vuurwerkspektakel -+ vuurwerkteam -+ vuutje -+ vwo -+ vwo-eindexamen -+ vwo-examen -+ vwo-examens -+ vwo-niveau -+ vwo-scholiere -+ vérgaand -+ vérgaande -+ vérstrekkende -+ vólgende -+ vóóruit -+ w'tjes -+ w.o. -+ waarborging -+ waardecreatie -+ waardedaling -+ waardedalingen -+ waardegroei -+ waardeketen -+ waardendebat -+ waardeoverdracht -+ waarderingsmethode -+ waarderingsmethoden -+ waarderingsregels -+ waarderingssubsidie -+ waarderingssysteem -+ waardestelsels -+ waardestijgingen -+ waardesysteem -+ waardesystemen -+ waardetransport -+ waardetransporten -+ waardetransporteurs -+ waardevernietiging -+ waardeverschil -+ waargebeurd -+ waarheidsbegrip -+ waarnaartoe -+ waarneemgroep -+ waarnemerschap -+ waarnemingscentrum -+ waarnemingssysteem -+ waaroverheen -+ waarrond -+ waarschuwingsactie -+ waarschuwingsfase -+ waarschuwingstijd -+ waarvóór -+ wachtgeldfondsen -+ wachtgeldverplichtingen -+ wachtlijstbemiddeling -+ wachtlijstbrigade -+ wachtlijstfonds -+ wachtlijstgegevens -+ wachtlijstgeld -+ wachtlijstgelden -+ wachtlijstproblematiek -+ wachtlijstproblemen -+ wachtperiode -+ wachtruimte -+ wachtruimten -+ wachtruimtes -+ wachttermijn -+ wagenberg -+ wagenbouwers -+ wagenparkbeheer -+ wagenparkbeheerders -+ wagenrennen -+ wakkergeschud -+ wakkerschudden -+ wallengebied -+ walvisachtigen -+ walvisvlees -+ walwoningen -+ wandelafstand -+ wandelarrangementen -+ wandelboekje -+ wandeldag -+ wandelgebied -+ wandelgids -+ wandelmogelijkheden -+ wandelpromenade -+ wandelreizen -+ wandelsportvereniging -+ wandelvakantie -+ wandelvereniging -+ wandelvierdaagse -+ wandpanelen -+ wangslijm -+ wanhopigen -+ wapenaankoop -+ wapenaankopen -+ wapenakkoord -+ wapenbedrijf -+ wapenbeheersingsverdragen -+ wapenbestand -+ wapenbeurs -+ wapenbezitters -+ wapencontracten -+ wapencontrole -+ wapencontroles -+ wapendeal -+ wapenexpert -+ wapenexperts -+ wapenexport -+ wapenexporteur -+ wapenexporteurs -+ wapengebruik -+ wapeninspectie -+ wapenleverancier -+ wapenlevering -+ wapenlobby -+ wapenmarkt -+ wapenmateriaal -+ wapenopslag -+ wapenoverleg -+ wapenproducenten -+ wapenprogramma -+ wapenreducties -+ wapensysteem -+ wapentechnologie -+ wapentransacties -+ wapentransport -+ wapentransporten -+ wapenveld -+ wapenverbod -+ wapenverdrag -+ wapenverkoop -+ wapenverkopen -+ wapenvondst -+ wapenvondsten -+ wapenvoorraden -+ wapenwet -+ wapenwetgeving -+ wapenwetten -+ wapenzending -+ wapenzendingen -+ warenmarkt -+ warlord -+ warlords -+ warmbloedigheid -+ warmte-kracht -+ warmte-krachtkoppeling -+ warmtekracht -+ warmterecord -+ warmtewerend -+ warmwaterinstallaties -+ wasinstallatie -+ wasmiddelenconcern -+ wasmiddelenreclame -+ wateractiviteiten -+ waterbasis -+ waterbeheerders -+ waterbehoefte -+ waterbeleid -+ waterbergend -+ waterberging -+ waterbesparing -+ waterbodem -+ waterbodems -+ waterbus -+ waterconferentie -+ waterdeeltjes -+ waterdistributie -+ waterfabriek -+ watergebonden -+ waterhyacint -+ waterinstallatie -+ waterinstallaties -+ waterleverancier -+ watermaatschappij -+ watermarkt -+ waterminnende -+ watermoleculen -+ watermolecuul -+ watermunt -+ waternavel -+ wateroorlog -+ wateropname -+ wateropslag -+ wateropvang -+ waterplan -+ waterpoloclub -+ waterpolocoach -+ waterpolovereniging -+ waterpolovrouwen -+ waterprijs -+ waterprobleem -+ waterproblematiek -+ waterproblemen -+ waterproject -+ waterprojecten -+ waterramp -+ waterrechten -+ waterrecreanten -+ waterrekening -+ waterreserves -+ waterschapsbelasting -+ waterschapslasten -+ waterschapsverkiezingen -+ watersector -+ waterskiester -+ waterspektakel -+ waterstad -+ waterstofbruggen -+ waterstoffluoride -+ watersysteem -+ watersystemen -+ watertoets -+ watertuin -+ waterverbinding -+ waterverdeling -+ waterverdrag -+ waterverdragen -+ waterwereld -+ waterwinputten -+ waterwolf -+ waterwoningen -+ web-tv -+ webadres -+ webapplicatie -+ webapplicaties -+ webcamera -+ webdienst -+ webgebaseerde -+ webhandel -+ webhosting -+ webkoppeling -+ webkoppelingen -+ webshop -+ websurfers -+ webvertising -+ webwinkel -+ webwinkelen -+ weddesupplementen -+ wederopbouwhulp -+ wederopbouwprogramma -+ wederopbouwprojecten -+ wedstrijdbeeld -+ wedstrijdcircuit -+ wedstrijddag -+ wedstrijdduiven -+ wedstrijdfit -+ wedstrijdpremies -+ wedstrijdseizoen -+ wedstrijdsporters -+ wedstrijdterrein -+ wedstrijdverband -+ wedstrijdverloop -+ wedstrijdvoorbereiding -+ wedstrijdzaken -+ weduwe-uitkering -+ weduwekas -+ weduwerente -+ weduwerenten -+ weefseldonatie -+ weefseldonoren -+ weefselmonsters -+ weefselonderzoek -+ weefselschade -+ weegsensor -+ weegsensoren -+ weekbasis -+ weekboek -+ weekeinddiensten -+ weekendbijlage -+ weekendkaart -+ weekendwerk -+ weekkrant -+ weeksalaris -+ weekse -+ weeralarm -+ weerbaarheidstraining -+ weerbaarheidstrainingen -+ weerbureau -+ weerdeskundigen -+ weerhielden -+ weerinformatie -+ weerinstituut -+ weerlozen -+ weermodellen -+ weerstandslijn -+ weervrouw -+ wegafsluitingen -+ wegafzetting -+ wegafzettingen -+ wegbedekking -+ wegbeheer -+ wegcontroles -+ wegdeel -+ wegdelen -+ wegeninfrastructuur -+ wegenonderhoud -+ wegenstelsel -+ wegenstructuur -+ wegenwerken -+ wegenzout -+ weggebruik -+ weggeefwinkel -+ weggegraven -+ weggeklapt -+ weggemasseerd -+ weggeroofd -+ weggesleten -+ weggesleurd -+ weggesluisd -+ weggevangen -+ weggezaagd -+ weggraven -+ weghebben -+ wegheeft -+ weginfrastructuur -+ wegkant -+ wegklapbare -+ wegkrijgen -+ weglezende -+ wegonderhoud -+ wegopbrekingen -+ wegpiraterij -+ wegplukken -+ wegplukte -+ wegracer -+ wegreconstructie -+ wegsleepregeling -+ wegsluizen -+ wegtransporteurs -+ wegvangen -+ wegverbreding -+ wegverharding -+ wegverlichting -+ wegwerpproducten -+ wegzwijmelen -+ weidegang -+ weideland -+ weidevogelbeheer -+ weidevogelbescherming -+ weifelende -+ weigeringsgrond -+ weigeringsgronden -+ welgemikte -+ welgestelden -+ welkomstceremonie -+ welkomstpremie -+ welks -+ welles-nietes -+ welstandcommissie -+ welstandige -+ welstandseisen -+ welvaartseffect -+ welvaartskloof -+ welvaartsontwikkeling -+ welvaartsverbetering -+ welvaartsverdeling -+ welvaartsverlies -+ welvaartsverschillen -+ welvaartswinst -+ welzijnsbeleid -+ welzijnseisen -+ welzijnsfuncties -+ welzijnswet -+ welzijnswethouder -+ wenkend -+ wenkende -+ wensmoeder -+ wereldbedrijf -+ wereldbefaamde -+ wereldbekend -+ wereldbekende -+ wereldbekercircuit -+ wereldbekercyclus -+ wereldbekerstand -+ wereldbekerstrijd -+ wereldbekerwedstrijd -+ wereldbekerwinnaar -+ wereldbekerzeges -+ wereldcinema -+ wereldconflict -+ wereldelftal -+ werelderfgoed -+ werelderfgoedlijst -+ wereldexpo -+ wereldexport -+ wereldfietsers -+ wereldformaat -+ wereldforum -+ wereldgemeenschap -+ wereldgemiddelde -+ wereldgroei -+ wereldgroep -+ wereldhandelsbesprekingen -+ wereldhandelsronde -+ wereldhandelssysteem -+ wereldhegemonie -+ wereldkampioene -+ wereldklimaatconferentie -+ wereldleed -+ wereldlijst -+ wereldmarktaandeel -+ wereldmerk -+ wereldmerken -+ wereldmuziekfestival -+ wereldniveau -+ wereldoliemarkt -+ wereldorganisatie -+ wereldpodia -+ wereldpodium -+ wereldpolitieke -+ wereldprestatie -+ wereldprijzen -+ wereldproblematiek -+ wereldproducent -+ wereldrecessie -+ wereldrecordpoging -+ wereldrecordrace -+ wereldreligie -+ wereldreserves -+ wereldroem -+ wereldsamenleving -+ wereldsheid -+ wereldspeler -+ wereldsport -+ wereldstandaard -+ wereldsysteem -+ wereldterrorisme -+ wereldtopper -+ wereldtoppers -+ wereldvoetbal -+ wereldvoetballer -+ wereldvraag -+ werkachterstanden -+ werkbaarheid -+ werkbalk -+ werkconferentie -+ werkconferenties -+ werkcultuur -+ werkduur -+ werkethiek -+ werkgarantie -+ werkgelegenheidsakkoord -+ werkgelegenheidscijfers -+ werkgelegenheidscreatie -+ werkgelegenheidsfonds -+ werkgelegenheidsgraad -+ werkgelegenheidsgroei -+ werkgelegenheidsmaatregelen -+ werkgelegenheidsontwikkeling -+ werkgelegenheidspact -+ werkgelegenheidsprobleem -+ werkgelegenheidsproblemen -+ werkgelegenheidssubsidies -+ werkgelegenheidstop -+ werkgerelateerde -+ werkgever-werknemer -+ werkgeverschap -+ werkgeversclub -+ werkgeversclubs -+ werkgeversdeel -+ werkgeversdelegatie -+ werkgeversfederatie -+ werkgeversfront -+ werkgeverskoepel -+ werkgeverskring -+ werkgeverskringen -+ werkgeversorganisaties -+ werkgeverspremie -+ werkgeverspremies -+ werkgeversvertegenwoordiger -+ werkgeversvertegenwoordigers -+ werkgeversvoorzitter -+ werkgroepleden -+ werkgroeplid -+ werkhandschoenen -+ werkingsmechanisme -+ werkingsmiddelen -+ werkingsplan -+ werkingsplannen -+ werkingssubsidies -+ werkingsverslag -+ werkinstrument -+ werkinstrumenten -+ werkjaar -+ werkjaren -+ werkkilometers -+ werklocaties -+ werkloosheidsdaling -+ werkloosheidsduur -+ werkloosheidsgraad -+ werkloosheidsniveau -+ werkloosheidsproblematiek -+ werkloosheidsval -+ werkmansbroek -+ werkmap -+ werkmens -+ werkmethodiek -+ werknaam -+ werknemersbelang -+ werknemersbelangen -+ werknemersbestand -+ werknemersparticipatie -+ werknemersparticipaties -+ werknemersrechten -+ werkpakket -+ werkpaleis -+ werkperiode -+ werkplanning -+ werkplezier -+ werkplicht -+ werkposten -+ werkproject -+ werkprojecten -+ werkrelatie -+ werkrelaties -+ werkschepen -+ werkstaat -+ werkstijl -+ werkstroom -+ werktijdverlenging -+ werktraject -+ werktuigbalk -+ werkvakantie -+ werkverschaffer -+ werkverschaffers -+ werkvlak -+ werkvolume -+ werkvoorraad -+ werkvoorraden -+ werkvoorzieningschap -+ werkvoorzieningsschap -+ werkvreugde -+ wervender -+ wervingsactiviteiten -+ wervingsadvertenties -+ wervingsbeleid -+ wervingsbureau -+ wervingsbureaus -+ wervingskosten -+ wervingskracht -+ wervingsmethoden -+ wervingsproblemen -+ westbaan -+ westernklassieker -+ westgevel -+ westrichting -+ westverbinding -+ wetenschapsbedrijf -+ wetenschapsblad -+ wetenschapscentrum -+ wetenschapsfilosoof -+ wetenschapshistorici -+ wetenschapsmuseum -+ wetenschapspark -+ wetenschapsquiz -+ wetenschapsstudies -+ weter -+ wetgevingsproces -+ wetgevingsreferendum -+ wetgevingsvraagstukken -+ wethouderskandidaat -+ wethouderskandidaten -+ wethoudster -+ wetsaanpassing -+ wetsgrond -+ wetshandhavers -+ wetshandhaving -+ wetsregels -+ whiskey -+ white -+ wide -+ wielerarts -+ wielerbond -+ wielercarrière -+ wielerfederatie -+ wielerformatie -+ wielergek -+ wielergeschiedenis -+ wielerheld -+ wielerjournalist -+ wielerkalender -+ wielerkoers -+ wielerkoersen -+ wielerland -+ wielerlanden -+ wielerliefhebber -+ wielerliefhebbers -+ wielerloopbaan -+ wielermilieu -+ wielerpers -+ wielersponsor -+ wielersponsoring -+ wielerteam -+ wielerverslaggever -+ wielerwereld -+ wierde -+ wierden -+ wietplantage -+ wietplantages -+ wietplanten -+ wietplantjes -+ wietteelt -+ wiettelers -+ wieven -+ wijkaanpak -+ wijkbeheer -+ wijkbureau -+ wijkbureaus -+ wijkcoördinator -+ wijkers -+ wijkgebonden -+ wijkgericht -+ wijkgerichte -+ wijkkantoor -+ wijkkantoren -+ wijkniveau -+ wijkorganisaties -+ wijkoverstijgend -+ wijkpark -+ wijkplan -+ wijkplatform -+ wijkpost -+ wijkschool -+ wijkverpleegkundige -+ wijkverpleegkundigen -+ wijnaanbod -+ wijnadvies -+ wijnarrangement -+ wijnbar -+ wijnbedrijf -+ wijnbedrijven -+ wijnbeurs -+ wijnbladeren -+ wijnboek -+ wijnboeken -+ wijncultuur -+ wijndomein -+ wijndomeinen -+ wijndrinker -+ wijngids -+ wijngoed -+ wijnindustrie -+ wijnkasteel -+ wijnkennis -+ wijnkeuze -+ wijnliefhebber -+ wijnliefhebbers -+ wijnmaker -+ wijnmakerij -+ wijnmakers -+ wijnmuseum -+ wijnproducent -+ wijnproeverij -+ wijnproeverijen -+ wijnschandaal -+ wijnschrijver -+ wijnschrijvers -+ wijnsector -+ wijnstad -+ wijntest -+ wijnveiling -+ wijnvelden -+ wijnvoorraad -+ wijnwereld -+ wijnwinkel -+ wijnwinkels -+ wijzigingsbevoegdheid -+ wildbeheereenheden -+ wildbeheereenheid -+ wildgerechten -+ wildkampeerders -+ wildklem -+ wildklemmen -+ wildplakkers -+ wildschade -+ wildseizoen -+ wildsoorten -+ wilgentenenhut -+ willekeurigen -+ wilsbekwaam -+ wilsbekwame -+ wilsonbekwaam -+ wilsonbekwaamheid -+ wilsonbekwamen -+ win-win -+ windrijke -+ winkelaars -+ winkelapparaat -+ winkelbestemming -+ winkelbuurt -+ winkelcomplex -+ winkelcomplexen -+ winkelconcept -+ winkelconcern -+ winkelcriminaliteit -+ winkeldag -+ winkeldeuren -+ winkeleigenaar -+ winkeletalages -+ winkelformule -+ winkelformules -+ winkelfunctie -+ winkelgebied -+ winkelgebieden -+ winkelgedeelte -+ winkelgedrag -+ winkelhart -+ winkelmarkt -+ winkelopening -+ winkelopeningstijden -+ winkelopenstelling -+ winkelparadijs -+ winkelplein -+ winkelrekken -+ winkelschap -+ winkelschappen -+ winkelsluitingstijden -+ winkelstad -+ winkeltijden -+ winkeltijdenwet -+ winkeluren -+ winkelvastgoed -+ winkelvestigingen -+ winkelvloer -+ winkelwijk -+ winkelzondagen -+ winnaarsmentaliteit -+ winputten -+ winsituatie -+ winstafdracht -+ winstafdrachten -+ winstbasis -+ winstbron -+ winstdeelname -+ winstdoel -+ winstdoelstelling -+ winstdoelstellingen -+ winstevolutie -+ winstherstel -+ winstmachine -+ winstmakers -+ winstmaximalisatie -+ winstnames -+ winstniveau -+ winstontwikkeling -+ winstparticipatie -+ winstpartij -+ winstpartijen -+ winstperspectieven -+ winstpositie -+ winstpotentie -+ winstpotentieel -+ winstraming -+ winstschatting -+ winstsprong -+ winststijging -+ winststreven -+ winststroom -+ winsttoename -+ winstverbetering -+ winstverdubbeling -+ winstverhouding -+ winstverwatering -+ winstvoorspelling -+ winterblues -+ wintercircus -+ wintereditie -+ winterjack -+ winterkampioen -+ winterlicht -+ winterlucht -+ winterochtend -+ winterpauze -+ winterperiode -+ winterprogramma -+ winterrust -+ wintersportbestemming -+ wintersportland -+ wintersportlanden -+ wintertruffel -+ wintervacht -+ winterwandeling -+ wishful -+ wiskundedocent -+ wisselexposities -+ wisselkoersbeleid -+ wisselkoersbewegingen -+ wisselkoerseffecten -+ wisselkoersmechanisme -+ wisselkoersrisico -+ wisselkoersschommelingen -+ wisselkoersstabiliteit -+ wisselkoerssysteem -+ wisselkoersverschillen -+ wisselkosten -+ wisselmogelijkheden -+ wisseloperaties -+ wit-blauw -+ wit-zwart -+ witbalans -+ witbeeld -+ witbrood -+ witfilm -+ witfoto -+ witfoto's -+ witfotografie -+ witgeschilderde -+ witgoedfabrikant -+ witgrijs -+ witgrijze -+ witman -+ witruimte -+ witte wieven -+ witte-illegalenregeling -+ wittegenstelling -+ wittelevisie -+ wittere -+ witwasactiviteiten -+ witwasserij -+ witwaswet -+ witwaswetgeving -+ woensdagnamiddag -+ woestijnland -+ woestijnrally -+ woestijnstad -+ wolmanzouten -+ wonderformule -+ wonderformules -+ wonderjaar -+ wonderpil -+ wondersloffen -+ wondertrainer -+ wondverzorging -+ woningaanpassing -+ woningaanpassingen -+ woningbeleid -+ woningbezetting -+ woningbezitter -+ woningbezitters -+ woningbouwbeleid -+ woningbouwcontingent -+ woningbouwlocatie -+ woningbouwproductie -+ woningbouwstichting -+ woningbranden -+ woningcomplex -+ woningcomplexen -+ woningcoöperaties -+ woningeigenaar -+ woningeigenaren -+ woningencomplex -+ woninginbraak -+ woninginbraken -+ woningisolatie -+ woningmarktonderzoek -+ woningonderhoud -+ woningprijs -+ woningprijzen -+ woningprojecten -+ woningsplitsing -+ woningstichtingen -+ woningtype -+ woningtypen -+ woningtypes -+ woningvereniging -+ woningwaarde -+ woon-werkkilometers -+ woon-zorgcentrum -+ woonadres -+ woonadressen -+ woonbebouwing -+ woonbeleid -+ woonbestemming -+ woonbeurs -+ woonbootbewoners -+ wooncarrière -+ wooncomplexen -+ woonconsument -+ woonconsumenten -+ wooncorporaties -+ woondiensten -+ woonduur -+ wooneisen -+ woonflat -+ woongedrag -+ woonketen -+ woonkrant -+ woonkrediet -+ woonkredieten -+ woonkwaliteit -+ woonland -+ woonlocatie -+ woonmogelijkheden -+ woonoppervlak -+ woonpark -+ woonplek -+ woonplezier -+ woonproject -+ woonprojecten -+ woonstaat -+ woonstichting -+ woonverblijf -+ woonwagenbeleid -+ woonwagenstandplaats -+ woonwagenstandplaatsen -+ woonwagenterrein -+ woonwarenhuis -+ woonwensen -+ woonwinkel -+ woonwinkels -+ woonzone -+ woonzorgcentra -+ woordafbreekpatronen -+ woordgrap -+ woordgrapje -+ woordgrapjes -+ woordgrappen -+ woordinvulling -+ woordlengte -+ woordparen -+ workflow -+ world -+ wormvirus -+ worship -+ worstsoorten -+ wortelgestel -+ would -+ wout -+ woutermans -+ wrakingskamer -+ wrakingsverzoek -+ wraps -+ writer -+ wurgtouw -+ ww. -+ wyandotte -+ wélke -+ wérkelijk -+ wíe -+ x'jes -+ xenofobe -+ xenotransplantatie -+ xenotransplantaties -+ xtc-bende -+ xtc-gebruik -+ xtc-handel -+ xtc-laboratoria -+ xtc-productie -+ xtc-smokkel -+ xtc-tabletten -+ xtc-zaak -+ xylitol -+ y'tjes -+ year -+ yes -+ yieldcurve -+ yoghurtdrank -+ yuppenstel -+ z'tje -+ z'tjes -+ z.g. -+ z.g.a.n. -+ zaadbalkanker -+ zaadproductie -+ zaakbelasting -+ zaaksgevolg -+ zaaksofficier -+ zaakvoerster -+ zaalarts -+ zaalcompetitie -+ zaaleigenaar -+ zaalgeluid -+ zaalhouder -+ zaalvoetbalclub -+ zachtglooiende -+ zakenauto -+ zakenauto's -+ zakenbankactiviteiten -+ zakenbankier -+ zakenbankiers -+ zakenblad -+ zakenhotel -+ zakenjet -+ zakenjets -+ zakenklimaat -+ zakenluchthaven -+ zakenmagazine -+ zakenmarkt -+ zakenpartner -+ zakenpartners -+ zakenreiziger -+ zakenstad -+ zakensteden -+ zakentijdschrift -+ zakentycoons -+ zakenvluchten -+ zakenzender -+ zakkenvullen -+ zakkenvullerij -+ zalencircuit -+ zalmfilet -+ zalmkweker -+ zalmsnip -+ zandbed -+ zanddepot -+ zandgat -+ zandlichaam -+ zandpakket -+ zandput -+ zandtransport -+ zandwagens -+ zandwallen -+ zandwinbedrijven -+ zandwinlocatie -+ zandwinners -+ zanggroepen -+ zanglijn -+ zanglijnen -+ zangtalent -+ zapatista's -+ zapatisten -+ zaterdagkrant -+ zaterdagmarkt -+ zaterdagnamiddag -+ zaterdagvoormiddag -+ zedendeliquenten -+ zedenfeiten -+ zedenkomedie -+ zedenrechercheurs -+ zeeaquarium -+ zeecontainer -+ zeecontainers -+ zeegrens -+ zeehondenpopulatie -+ zeekool -+ zeemilieu -+ zeereservaat -+ zeevarenden -+ zeevissers -+ zeevracht -+ zeezender -+ zeezenders -+ zegebulletins -+ zegereeks -+ zegge en schrijve -+ zeilrace -+ zeilteam -+ zeisenman -+ zekergesteld -+ zekerheidsbijdragen -+ zekerheidssysteem -+ zelfacceptatie -+ zelfbeheer -+ zelfbenoemde -+ zelfbereide -+ zelfbevrijding -+ zelfcorrigerend -+ zelfdoders -+ zelfevaluatie -+ zelfevaluatiemodel -+ zelfgebouwd -+ zelfgebouwde -+ zelfgecreëerde -+ zelfgedraaide -+ zelfgefabriceerde -+ zelfgegraven -+ zelfgeproclameerde -+ zelfgeproduceerde -+ zelfgeschapen -+ zelfgestookte -+ zelfhandhaving -+ zelfhypnose -+ zelfinzicht -+ zelfketen -+ zelfkritisch -+ zelfkritische -+ zelflerende -+ zelfmoordbriefje -+ zelfmoordcijfers -+ zelfmoordpil -+ zelfmoordterrorist -+ zelfmoordterroristen -+ zelfontwikkelde -+ zelfontworpen -+ zelfopgelegde -+ zelforganisatie -+ zelfpromotie -+ zelfrealisatie -+ zelfreflectie -+ zelfregulatie -+ zelfregulerend -+ zelfregulerende -+ zelfrelativering -+ zelfscheppende -+ zelfsector -+ zelfselectie -+ zelfstandigenorganisatie -+ zelfstandigenstatuut -+ zelfsturend -+ zelfsturende -+ zelfsturing -+ zelftests -+ zelftwijfel -+ zelfvergroting -+ zelfverkozen -+ zelfvernietigende -+ zelfverrijking -+ zelfverwezenlijking -+ zelfverwonding -+ zelfwerkzaamheden -+ zelfzaak -+ zelfzaken -+ zelfzorggeneesmiddelen -+ zelfzorgmedicijnen -+ zelfzorgmiddelen -+ zelven -+ zelver -+ zenderaanbod -+ zenderpakket -+ zenderprofiel -+ zenderprofilering -+ zendfrequenties -+ zendgebied -+ zendingsdrift -+ zendingsorganisatie -+ zenuwverbindingen -+ zes-en-een-half -+ zesbaans -+ zesbak -+ zesenhalf -+ zesennegentig -+ zesentachtig -+ zesenveertig -+ zesenvijftig -+ zesenzestig -+ zesenzeventig -+ zeshonderdvijftig -+ zeskamp -+ zeskoppig -+ zeskoppige -+ zespersoons -+ zetelroof -+ zetherhaling -+ zeven-en-een-half -+ zevenenhalf -+ zevenentachtig -+ zevenenveertig -+ zevenenvijftig -+ zevenenzestig -+ zevenenzeventig -+ zevenhonderdvijftig -+ zevenjarigen -+ zevenkoppig -+ zevenkoppige -+ zeventienjarigen -+ zevenzitter -+ zgn. -+ zichtas -+ zichthouders -+ zichtlocatie -+ zichtlocaties -+ ziek melden -+ ziek-zijn -+ ziekenfondskas -+ ziekenfondsverzekerd -+ ziekenhuisapotheker -+ ziekenhuisapothekers -+ ziekenhuisarts -+ ziekenhuisartsen -+ ziekenhuisbacterie -+ ziekenhuisbehandeling -+ ziekenhuisbestuur -+ ziekenhuisbezoek -+ ziekenhuisbudget -+ ziekenhuiscomplex -+ ziekenhuisdirecteur -+ ziekenhuisdirecteuren -+ ziekenhuisdirectie -+ ziekenhuisdirecties -+ ziekenhuiskamer -+ ziekenhuiskosten -+ ziekenhuismedewerkers -+ ziekenhuisorganisatie -+ ziekenhuispredikant -+ ziekenhuisscholen -+ ziekenhuisschool -+ ziekenhuisserie -+ ziekenhuisverblijf -+ ziekenhuisvoorzieningen -+ ziekenhuiswereld -+ ziekenhuiswezen -+ ziekenhuiszorg -+ ziekenverzorgende -+ ziekte-inzicht -+ ziektebestrijding -+ ziektejaar -+ ziektekostenregeling -+ ziektenkostenregelingen -+ ziektepercentage -+ ziekterisico -+ zieleroerselen -+ zigzagbeleid -+ zij aan zij -+ zijairbags -+ zijgevoel -+ zijn pappenheimers kennen -+ zijnd -+ zijns inziens -+ zijzaaltje -+ zilverschat -+ zine -+ zinkend -+ zinkende -+ zinkfabriek -+ zinkmijn -+ zinkprijs -+ zinkproducent -+ zinnens -+ zinnens zijn -+ zit-slaapkamer -+ zit-slaapkamers -+ zithouding -+ zitpositie -+ zitruimte -+ zitter -+ zitters -+ zitting hebbend -+ zitting hebbende -+ zittingsavonden -+ zittingsdatum -+ zittingsruimte -+ zo langzamerhand -+ zo nodig -+ zo waarlijk helpe mij God Almachtig -+ zoab -+ zodiac -+ zoekdienst -+ zoekenden -+ zoekfuncties -+ zoekgebied -+ zoekmotor -+ zoekresultaten -+ zoekrobot -+ zoekrobots -+ zoeksite -+ zoeksites -+ zoeksoftware -+ zoekvraag -+ zoekwerk -+ zoekwoord -+ zoekwoorden -+ zoet water -+ zoetgehouden -+ zomerdienstregeling -+ zomerfestival -+ zomerfestivals -+ zomerhit -+ zomermode -+ zomerpolder -+ zomerprogramma -+ zomerprogramma's -+ zomerprogrammering -+ zomerrally -+ zomerreeks -+ zomerschool -+ zomerserie -+ zomersmog -+ zomersport -+ zomerstop -+ zomertentoonstelling -+ zomertournee -+ zomertruffel -+ zomerweken -+ zomerzonnewende -+ zonbestemmingen -+ zondagnamiddag -+ zondagopenstelling -+ zondagsopening -+ zondagsopenstelling -+ zondagsschot -+ zondagvoormiddag -+ zonderen -+ zonkracht -+ zonne -+ zonnecrème -+ zonnecrèmes -+ zonnehemel -+ zonnestroom -+ zonwerende -+ zoogdiercellen -+ zoonrelatie -+ zorg dragen -+ zorg gedragen -+ zorgaanbieder -+ zorgbehoefte -+ zorgbeleid -+ zorgboerderij -+ zorgboerderijen -+ zorgbudget -+ zorgcentra -+ zorgcentrum -+ zorgcircuit -+ zorgcomplex -+ zorgcomplexen -+ zorgcoördinator -+ zorgcoördinatoren -+ zorgfunctie -+ zorghotel -+ zorgkantoor -+ zorgkantoren -+ zorgketen -+ zorgkosten -+ zorgloket -+ zorgloon -+ zorgmanager -+ zorgmarkt -+ zorgnummer -+ zorgorganisatie -+ zorgorganisaties -+ zorgpakket -+ zorgpas -+ zorgpersoneel -+ zorgplan -+ zorgstelsel -+ zorgsysteem -+ zorgtoeslag -+ zorguitgaven -+ zorgverlener -+ zorgvernieuwing -+ zorgverplichting -+ zorgverstrekkers -+ zorgverstrekking -+ zorgverzekeraar -+ zorgverzekeraars -+ zorgvraag -+ zorgvrager -+ zorgvragers -+ zorgwoningen -+ zorgzwaarte -+ zoutkleur -+ zoutlagen -+ zoutstel -+ zoutvijvers -+ zovelen -+ zuidas -+ zuidgevel -+ zuidoever -+ zuidrand -+ zuidroute -+ zuidtak -+ zuidverbinding -+ zuidvleugel -+ zuidzuidoosten -+ zuivelboeren -+ zuivelconcern -+ zuivelondernemingen -+ zuivelproductie -+ zuivelsector -+ zuiverheidsgraad -+ zuiveringslasten -+ zuiveringssysteem -+ zuiveringstechnieken -+ zuster-overste -+ zusterbedrijf -+ zusterbedrijven -+ zusteronderneming -+ zusterpartij -+ zusterpartijen -+ zusterzender -+ zuurbrand -+ zuurbranden -+ zuurremmers -+ zuurstofatoom -+ zuurstofconcentratie -+ zuurstofmoleculen -+ zuurstoftoevoer -+ zwaarbeschadigde -+ zwaardhouwen -+ zwaarlijvigen -+ zwaarverslaafden -+ zwakalcoholisch -+ zwakalcoholische -+ zwangeren -+ zwangerschapsduur -+ zwart geld -+ zwart-gele -+ zwart-romantische -+ zwart-wittelevisie -+ zwartepietenspel -+ zwartgeverfde -+ zwarthandel -+ zwartkijkerij -+ zwartomrande -+ zwartvissers -+ zwavelgehalte -+ zweefbaan -+ zweeppartij -+ zwembadpersoneel -+ zwemcarrière -+ zwemcoach -+ zwemfederatie -+ zwemkampioene -+ zwemkampioenschappen -+ zwemonderwijs -+ zwemonderwijzer -+ zwempartij -+ zwemselectie -+ zwemstadion -+ zwemtoernooi -+ zwemtop -+ zwemtrainer -+ zwemverbod -+ zwemwereld -+ zèta -+ zéker -+ zó -+ zómaar -+ zóveel -+ zóver -+ zúlke -+ Ålandseilanden -+ à charge -+ à contrecoeur -+ álle -+ álles -+ ánder -+ ánderen -+ échte -+ élke -+ éminence grise -+ éminences grises -+ éne -+ énig -+ époque -+ één duizendste -+ één tiende -+ één vijfde -+ éénjarig -+ éénmaal -+ ééntje -+ íemand -+ íets -+ ófwel -+ ónder -+ ónze -+ óver -+ ú diff --git a/share/vim/vim72/spell/nn/main.aap b/share/vim/vim72/spell/nn/main.aap deleted file mode 100644 index da71b209a9..0000000000 --- a/share/vim/vim72/spell/nn/main.aap +++ /dev/null @@ -1,78 +0,0 @@ -# Aap recipe for Dutch Vim spell files. - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = nn_NO.aff nn_NO.dic - -all: $SPELLDIR/nn.latin1.spl $SPELLDIR/nn.utf-8.spl ../README_nn.txt - -$SPELLDIR/nn.latin1.spl : $FILES - :sys env LANG=no_NO.ISO8859-1 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/nn nn_NO" -c q - -$SPELLDIR/nn.utf-8.spl : $FILES - :sys env LANG=no_NO.UTF-8 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/nn nn_NO" -c q - -../README_nn.txt : README_nn_NO.txt - :copy $source $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} nn_NO.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -nn_NO.aff nn_NO.dic: {buildcheck=} - :assertpkg unzip patch - :fetch nn_NO.zip - :sys $UNZIP nn_NO.zip - :delete nn_NO.zip - @if not os.path.exists('nn_NO.orig.aff'): - :copy nn_NO.aff nn_NO.orig.aff - @if not os.path.exists('nn_NO.orig.dic'): - :copy nn_NO.dic nn_NO.orig.dic - @if os.path.exists('nn_NO.diff'): - :sys patch <nn_NO.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 nn_NO.orig.aff nn_NO.aff >nn_NO.diff - :sys {force} diff -a -C 1 nn_NO.orig.dic nn_NO.dic >>nn_NO.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch nn_NO.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../nn_NO.zip - :sys {force} diff ../nn_NO.orig.aff nn_NO.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy nn_NO.aff ../nn_NO.new.aff - :sys {force} diff ../nn_NO.orig.dic nn_NO.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy nn_NO.dic ../nn_NO.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete nn_NO.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/pt/main.aap b/share/vim/vim72/spell/pt/main.aap deleted file mode 100644 index b2ad65bf6e..0000000000 --- a/share/vim/vim72/spell/pt/main.aap +++ /dev/null @@ -1,140 +0,0 @@ -# Aap recipe for Portuguese Vim spell files. -# See ftp://ftp.vim.org/pub/vim/runtime/spell/README.txt - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = pt_PT.aff pt_PT.dic - pt_BR.aff pt_BR.dic - -# -# Fetching the pt_PT files from the Natura project. -# -PT_DIR = http://natura.di.uminho.pt/download/sources/Dictionaries/myspell -PT_FNAME = myspell.pt-latest.zip -:attr {fetch = $PT_DIR/%file%} $PT_FNAME - -# -# Fetching the pt_BR files from BrOffice.org (Brazilian OOo). -# -BR_FNAME = pt_BR-V.zip -BR_DIR = http://www.deso-se.com.br/downloads/broffice.org/$(BR_FNAME) -:attr {fetch = $BR_DIR} $BR_FNAME - -all: $SPELLDIR/pt.latin1.spl $SPELLDIR/pt.utf-8.spl \ - ../README_pt.txt - -$SPELLDIR/pt.latin1.spl : $FILES - :sys env LANG=pt_PT.ISO8859-1 LC_ALL=pt_PT.ISO8859-1 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/pt pt_PT pt_BR" -c q - -$SPELLDIR/pt.utf-8.spl : $FILES - :sys env LANG=pt_PT.UTF-8 LC_ALL=pt_PT.UTF-8 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/pt pt_PT pt_BR" -c q - -../README_pt.txt: README_pt_PT.txt README_pt_BR.txt - :print pt_PT >!$target - :cat README_pt_PT.txt | :eval re.sub('\r', '', stdin) >>$target - :print =================================================== >>$target - :print pt_BR: >>$target - :cat README_pt_BR.txt | :eval re.sub('\r', '', stdin) >>$target - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -pt_PT.aff pt_PT.dic: {buildcheck=} - :assertpkg unzip patch - :fetch $PT_FNAME - :sys $UNZIP $PT_FNAME - :delete $PT_FNAME - :move myspell.pt-*/pt_PT.dic . - :move myspell.pt-*/pt_PT.aff . - :move myspell.pt-*/README_pt_PT.txt . - :move myspell.pt-*/COPYING COPYING_pt_PT.txt - :deldir myspell.pt-* - @if not os.path.exists('pt_PT.orig.aff'): - :copy pt_PT.aff pt_PT.orig.aff - @if not os.path.exists('pt_PT.orig.dic'): - :copy pt_PT.dic pt_PT.orig.dic - @if os.path.exists('pt_PT.diff'): - :sys patch <pt_PT.diff - -pt_BR.aff pt_BR.dic: {buildcheck=} - :assertpkg unzip patch - :fetch $BR_FNAME - :sys $UNZIP $BR_FNAME - :delete $BR_FNAME - :sys $VIM README_pt_BR.TXT -e -c "set ff=unix" -c update -c q - :move README_pt_BR.TXT README_pt_BR.txt - -# Vim seems to ignore the dots from the word list. -# Removing words with dot to avoid misbehaviour. - :sys $VIM pt_BR.dic -e -c "set ff=unix" -c "/\./d" -c update -c q - :sys $VIM pt_BR.aff -e -c "set ff=unix" -c update -c q - @if not os.path.exists('pt_BR.orig.aff'): - :copy pt_BR.aff pt_BR.orig.aff - @if not os.path.exists('pt_BR.orig.dic'): - :copy pt_BR.dic pt_BR.orig.dic - @if os.path.exists('pt_BR.diff'): - :sys patch <pt_BR.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 pt_PT.orig.aff pt_PT.aff >pt_PT.diff - :sys {force} diff -a -C 1 pt_PT.orig.dic pt_PT.dic >>pt_PT.diff - :sys {force} diff -a -C 1 pt_BR.orig.aff pt_BR.aff >pt_BR.diff - :sys {force} diff -a -C 1 pt_BR.orig.dic pt_BR.dic >>pt_BR.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. -# TO BE IMPLEMENTED - -check: check-pt check-br - -check-pt: - :assertpkg unzip diff - :fetch $PT_FNAME - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../$PT_FNAME - :sys {force} diff ../pt_PT.orig.aff pt_PT.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy pt_PT.aff ../pt_PT.new.aff - :sys {force} diff ../pt_PT.orig.dic pt_PT.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy pt_PT.dic ../pt_PT.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete $PT_FNAME - -check-br: - :assertpkg unzip diff - :fetch $BR_FNAME - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../$BR_FNAME - :sys {force} diff ../pt_BR.orig.aff pt_BR.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy pt_BR.aff ../pt_BR.new.aff - :sys {force} diff ../pt_BR.orig.dic pt_BR.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy pt_BR.dic ../pt_BR.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete $BR_FNAME - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/pt/pt_BR.diff b/share/vim/vim72/spell/pt/pt_BR.diff deleted file mode 100644 index f4814af11f..0000000000 --- a/share/vim/vim72/spell/pt/pt_BR.diff +++ /dev/null @@ -1,34 +0,0 @@ -*** pt_BR.orig.aff 2008-02-21 19:41:04.000000000 -0300 ---- pt_BR.aff 2008-02-24 11:08:15.000000000 -0300 -*************** -*** 1,3 **** - SET ISO8859-1 -! TRY áàãâéêíóõôúüçesianrtolcdugmphbyfvkwjqxz - ---- 1,3 ---- - SET ISO8859-1 -! - -*************** -*** 13,14 **** ---- 13,32 ---- - -+ NAME Brazilian Portuguese -+ VERSION 2008-07-07V -+ HOME http://www.broffice.org/verortografico -+ AUTHOR Raimundo Santos Moura -+ EMAIL raimundomoura AT openoffice DOT org -+ AUTHOR Leonardo Ferreira Fontenelle -+ EMAIL leo DOT fontenelle AT gmail DOT org -+ COPYRIGHT LGPL -+ -+ -+ FOL ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ -+ LOW ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ -+ UPP ßÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞÿ -+ -+ -+ MIDWORD '-. -+ -+ - MAP 6 diff --git a/share/vim/vim72/spell/pt/pt_PT.diff b/share/vim/vim72/spell/pt/pt_PT.diff deleted file mode 100644 index 36a12aced3..0000000000 --- a/share/vim/vim72/spell/pt/pt_PT.diff +++ /dev/null @@ -1,58 +0,0 @@ -*** pt_PT.orig.aff 2008-02-21 19:40:49.000000000 -0300 ---- pt_PT.aff 2008-02-24 11:14:39.000000000 -0300 -*************** -*** 1,4 **** - SET ISO8859-1 -- TRY aerisontcdmlupvgbfzáhçqjíxãóéêâúõACMPSBTELGRIFVDkHJONôywUKXZWQÁYÍÉàÓèÂÚ - - ---- 1,17 ---- - SET ISO8859-1 - -+ NAME European Portuguese -+ VERSION 2008-07-05 -+ HOME http://natura.di.uminho.pt/ -+ AUTHOR Rui Vilela -+ EMAIL ruivilela AT di DOT uminho DOT pt -+ AUTHOR José João de Almeira -+ EMAIL jj AT di DOT uminho DOT pt -+ AUTHOR Alberto Simões -+ EMAIL ambs AT di DOT uminho DOT pt -+ COPYRIGHT GPL, LGPL, MPL -+ -+ FOL ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ -+ LOW ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ -+ UPP ßÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞÿ - -*************** -*** 1047,1048 **** ---- 1060,1063 ---- - SFX J e ódromo e -+ -+ - REP 24 -*************** -*** 1073,1086 **** - -! MAP 11 -! MAP aá -! MAP aã -! MAP aâ -! MAP eé -! MAP eê -! MAP ií - MAP cç -! MAP oó -! MAP oô -! MAP oõ -! MAP uú -! ---- 1088,1095 ---- - -! MAP 6 -! MAP aáãâAÁà-! MAP eéêEÉÊ -! MAP iíIÍ - MAP cç -! MAP oóõôOÓÕÔ -! MAP uúüUÚÜ diff --git a/share/vim/vim72/spell/sv/main.aap b/share/vim/vim72/spell/sv/main.aap deleted file mode 100644 index 5634711aff..0000000000 --- a/share/vim/vim72/spell/sv/main.aap +++ /dev/null @@ -1,81 +0,0 @@ -# Aap recipe for Swedish Vim spell files. -# -# Maintainer: Stefan Karlsson <stefan.74@comhem.se> - -# Use a freshly compiled Vim if it exists. -@if os.path.exists('../../../src/vim'): - VIM = ../../../src/vim -@else: - :progsearch VIM vim - -SPELLDIR = .. -FILES = sv_SE.aff sv_SE.dic - -all: $SPELLDIR/sv.latin1.spl $SPELLDIR/sv.utf-8.spl ../README_sv.txt - -$SPELLDIR/sv.latin1.spl : $FILES - :sys env LANG=sv_SE.ISO8859-1 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/sv sv_SE" -c q - -$SPELLDIR/sv.utf-8.spl : $FILES - :sys env LANG=sv_SE.UTF-8 - $VIM -u NONE -e -c "mkspell! $SPELLDIR/sv sv_SE" -c q - -../README_sv.txt : README_sv_SE.txt - :copy $source $target - -# -# Fetching the files from OpenOffice.org. -# -OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries -:attr {fetch = $OODIR/%file%} sv_SE.zip - -# The files don't depend on the .zip file so that we can delete it. -# Only download the zip file if the targets don't exist. -sv_SE.aff sv_SE.dic: {buildcheck=} - :assertpkg unzip patch - :fetch sv_SE.zip - :sys $UNZIP sv_SE.zip - :delete sv_SE.zip - :delete hyph_sv_SE.dic - @if not os.path.exists('sv_SE.orig.aff'): - :copy sv_SE.aff sv_SE.orig.aff - @if not os.path.exists('sv_SE.orig.dic'): - :copy sv_SE.dic sv_SE.orig.dic - @if os.path.exists('sv_SE.diff'): - :sys patch <sv_SE.diff - - -# Generate diff files, so that others can get the OpenOffice files and apply -# the diffs to get the Vim versions. - -diff: - :assertpkg diff - :sys {force} diff -a -C 1 sv_SE.orig.aff sv_SE.aff >sv_SE.diff - :sys {force} diff -a -C 1 sv_SE.orig.dic sv_SE.dic >>sv_SE.diff - - -# Check for updated OpenOffice spell files. When there are changes the -# ".new.aff" and ".new.dic" files are left behind for manual inspection. - -check: - :assertpkg unzip diff - :fetch sv_SE.zip - :mkdir tmp - :cd tmp - @try: - @import stat - :sys $UNZIP ../sv_SE.zip - :sys {force} diff ../sv_SE.orig.aff sv_SE.aff >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy sv_SE.aff ../sv_SE.new.aff - :sys {force} diff ../sv_SE.orig.dic sv_SE.dic >d - @if os.stat('d')[stat.ST_SIZE] > 0: - :copy sv_SE.dic ../sv_SE.new.dic - @finally: - :cd .. - :delete {r}{f}{q} tmp - :delete sv_SE.zip - - -# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/sv/sv_SE.diff b/share/vim/vim72/spell/sv/sv_SE.diff deleted file mode 100644 index 73ed14b3c8..0000000000 --- a/share/vim/vim72/spell/sv/sv_SE.diff +++ /dev/null @@ -1,220 +0,0 @@ -*** sv_SE.orig.aff Thu Feb 23 20:02:32 2006 ---- sv_SE.aff Thu Feb 23 20:02:32 2006 -*************** -*** 6,7 **** ---- 6,22 ---- - -+ FOL ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ -+ LOW ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ -+ UPP ßÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞÿ -+ -+ MAP 9 -+ MAP aàáâãäå -+ MAP eèéêë -+ MAP iìíîï -+ MAP oòóôõö -+ MAP uùúûü -+ MAP nñ -+ MAP cç -+ MAP yÿý -+ MAP sß -+ - SFX A Y 1 -*************** -*** 15,17 **** - -! SFX C Y 16 - SFX C 0 t [aeiouyåäöé] ---- 30,32 ---- - -! SFX C Y 15 - SFX C 0 t [aeiouyåäöé] -*************** -*** 30,32 **** - SFX C en nets en -- SFX C 0 net nets [^e]n - SFX C 0 nets [^e]n ---- 45,46 ---- -*************** -*** 427 **** ---- 441,541 ---- - SFX T el la el -+ -+ # soundslike mapping from Aspell -+ # swedish_phonet.dat - Swedish phonetic transformation rules for aspell -+ # Copyright (C) 2000 Martin Norbäck <d95mback@dtek.chalmers.se> -+ # distributed under GNU GPL -+ # version 0.2 -+ -+ SAL & & -+ SAL @ @ -+ SAL ANG(EIYÄÖ)-^ ANI # förledet an- ska inte bli @-ljud -+ SAL AGNO6 AKNO # agnostiker osv. -+ SAL AG(IE)-6 AK # vokal+g(ie) ger ej j-ljud -+ SAL A A -+ SAL BB-< _ -+ SAL B P -+ SAL CCO- K # broccoli, piccolo -+ SAL CC KS # successiv, access, succé -+ SAL CH & # choklad osv. -+ SAL CK K # ck -> k som vanligt -+ SAL C(EIYÄÖ)-< S # c + mjuk vokal -> s -+ SAL C K # c + annat -> k -+ SAL DJ(UÄÖ)- I # djungel, djävel, adjö -+ SAL DD- _ -+ SAL D T -+ SAL EG(IE)-6 EK # vokal+g(ie) ger ej j-ljud -+ SAL E E -+ SAL É E -+ SAL FF F -+ SAL F F -+ SAL G(EIYÄÖ)-3 I # g+mjuk vokal ger j-ljud -+ SAL GG6 K -+ SAL GN @N # ugn, lugn... -+ SAL G K -+ SAL H(AOUÅEIYÄÖ)-^ H # h i början av ord hörs -+ SAL H(AUOÅEIYÄÖ)- _ # annars stumt framför vokal -+ SAL HJ I # hj->j (hjärta osv.) -+ SAL H H -+ SAL IG(IE)-6 IK # vokal+g(ie) ger ej j-ljud -+ SAL I I -+ SAL J I -+ SAL K(EIYÄÖ)-^ & # k+mjuk vokal ger sje-ljud -+ SAL KJ & # kjol -+ SAL K K -+ SAL LJU- I # ljuga, ljus -+ SAL LL- _ -+ SAL L L -+ SAL MM- _ -+ SAL M M -+ SAL NG6 @ -+ SAL NN- _ -+ SAL N N -+ SAL ORIGI8 ORKI # specialfall -+ SAL OG(IE)-6 OK # vokal+g(ie) ger ej j-ljud -+ SAL O O -+ SAL PROJEKT PRO&EKT # specialfall -+ SAL PSALT< SALT # specialfall -+ SAL PSALM< SALM # specialfall -+ SAL PP- _ -+ SAL P P -+ SAL Q K -+ SAL RGI$6 RGI # inget j i slutet -+ SAL RGA$6 RIA # här är det däremot j (arga,färga) -+ SAL RGE$6 RIE # här också (Norge, överge) -+ SAL RGS$ RIS # rgs i slutet -+ SAL RG$ RI # rg i slutet -+ SAL RD T # "blött" d -+ SAL RN N # "blött" n -+ SAL RT T # "blött" t -+ SAL RLD T # värld -+ SAL RL L # "blött" l -+ SAL RS & # sje-ljud (fars, gärsgård) -+ SAL RR- _ -+ SAL R R -+ SAL SS- _ -+ SAL SCHIZ6 SKITS # specialfall -+ SAL SCH6 & -+ SAL SKJ & # skjorta, skjuta -+ SAL SJ & # sje-ljud -+ SAL S S -+ SAL TION9^ TION # tionde -+ SAL TION6 &ON # station osv. -+ SAL TT- _ -+ SAL T T -+ SAL UG(IE)-6 UK # vokal+g(ie) ger ej j-ljud -+ SAL U U -+ SAL V F -+ SAL W F -+ SAL X9 KS -+ SAL YG(IE)-6 YK # vokal+g(ie) ger ej j-ljud -+ SAL Y I -+ SAL ZZ TS -+ SAL Z S -+ SAL ÅTTIO9 OTIO # specialfall (ej sje-ljud) -+ SAL ÅRTION9 ORTION # specialfall (r hörs) -+ SAL ÅG(IE)-6 OK # vokal+g(ie) ger ej j-ljud -+ SAL Å O -+ SAL ÄG(IE)-6 EK # vokal+g(ie) ger ej j-ljud -+ SAL Ä E -+ SAL ÖG(IE)-6 ÖK # vokal+g(ie) ger ej j-ljud -+ SAL Ö Ö -*** sv_SE.orig.dic Thu Feb 23 20:02:32 2006 ---- sv_SE.dic Thu Feb 23 20:02:32 2006 -*************** -*** 4317,4319 **** - dvaldes/S -! dvs - dväljas/S ---- 4317,4319 ---- - dvaldes/S -! #dvs Removed by Stefan. - dväljas/S -*************** -*** 24490 **** ---- 24490,24554 ---- - åvila/MS -+ -+ # Additions by Stefan: -+ SEK -+ adr. -+ anm. -+ art. -+ aug. -+ bl.a. -+ d.v.s. -+ dec. -+ dr -+ dvs. -+ e.Kr. -+ e.d. -+ enl. -+ etc. -+ f.Kr. -+ f.d. -+ f.n. -+ f.ö. -+ febr. -+ fig. -+ fil.kand. -+ fil.lic. -+ forts. -+ fr.o.m. -+ fre. -+ jan. -+ jfr -+ kap. -+ kl. -+ lör. -+ m.fl. -+ m.m. -+ max. -+ min. -+ mån. -+ ngn -+ ngt -+ nov. -+ nr. -+ o.s.v. -+ obs. -+ okt. -+ ons. -+ osv. -+ p.g.a. -+ resp. -+ s.k. -+ sept. -+ sön. -+ t.ex. -+ t.o.m. -+ tab. -+ tis. -+ tors. -+ u.a. -+ uppl. -+ utg. -+ v.g. -+ v.g.v. -+ vard. -+ vd -+ vol. diff --git a/share/vim/vim72/synmenu.vim b/share/vim/vim72/synmenu.vim deleted file mode 100644 index c2159771e4..0000000000 --- a/share/vim/vim72/synmenu.vim +++ /dev/null @@ -1,572 +0,0 @@ -" Vim support file to define the syntax selection menu -" This file is normally sourced from menu.vim. -" -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2006 Apr 27 - -" Define the SetSyn function, used for the Syntax menu entries. -" Set 'filetype' and also 'syntax' if it is manually selected. -fun! SetSyn(name) - if a:name == "fvwm1" - let use_fvwm_1 = 1 - let use_fvwm_2 = 0 - let name = "fvwm" - elseif a:name == "fvwm2" - let use_fvwm_2 = 1 - let use_fvwm_1 = 0 - let name = "fvwm" - else - let name = a:name - endif - if !exists("s:syntax_menu_synonly") - exe "set ft=" . name - if exists("g:syntax_manual") - exe "set syn=" . name - endif - else - exe "set syn=" . name - endif -endfun - -" <> notation is used here, remove '<' from 'cpoptions' -let s:cpo_save = &cpo -set cpo&vim - -" The following menu items are generated by makemenu.vim. -" The Start Of The Syntax Menu - -an 50.10.100 &Syntax.AB.A2ps\ config :cal SetSyn("a2ps")<CR> -an 50.10.110 &Syntax.AB.Aap :cal SetSyn("aap")<CR> -an 50.10.120 &Syntax.AB.ABAP/4 :cal SetSyn("abap")<CR> -an 50.10.130 &Syntax.AB.Abaqus :cal SetSyn("abaqus")<CR> -an 50.10.140 &Syntax.AB.ABC\ music\ notation :cal SetSyn("abc")<CR> -an 50.10.150 &Syntax.AB.ABEL :cal SetSyn("abel")<CR> -an 50.10.160 &Syntax.AB.AceDB\ model :cal SetSyn("acedb")<CR> -an 50.10.170 &Syntax.AB.Ada :cal SetSyn("ada")<CR> -an 50.10.180 &Syntax.AB.AfLex :cal SetSyn("aflex")<CR> -an 50.10.190 &Syntax.AB.ALSA\ config :cal SetSyn("alsaconf")<CR> -an 50.10.200 &Syntax.AB.Altera\ AHDL :cal SetSyn("ahdl")<CR> -an 50.10.210 &Syntax.AB.Amiga\ DOS :cal SetSyn("amiga")<CR> -an 50.10.220 &Syntax.AB.AMPL :cal SetSyn("ampl")<CR> -an 50.10.230 &Syntax.AB.Ant\ build\ file :cal SetSyn("ant")<CR> -an 50.10.240 &Syntax.AB.ANTLR :cal SetSyn("antlr")<CR> -an 50.10.250 &Syntax.AB.Apache\ config :cal SetSyn("apache")<CR> -an 50.10.260 &Syntax.AB.Apache-style\ config :cal SetSyn("apachestyle")<CR> -an 50.10.270 &Syntax.AB.Applix\ ELF :cal SetSyn("elf")<CR> -an 50.10.280 &Syntax.AB.Arc\ Macro\ Language :cal SetSyn("aml")<CR> -an 50.10.290 &Syntax.AB.Arch\ inventory :cal SetSyn("arch")<CR> -an 50.10.300 &Syntax.AB.ART :cal SetSyn("art")<CR> -an 50.10.310 &Syntax.AB.ASP\ with\ VBScript :cal SetSyn("aspvbs")<CR> -an 50.10.320 &Syntax.AB.ASP\ with\ Perl :cal SetSyn("aspperl")<CR> -an 50.10.330 &Syntax.AB.Assembly.680x0 :cal SetSyn("asm68k")<CR> -an 50.10.340 &Syntax.AB.Assembly.Flat :cal SetSyn("fasm")<CR> -an 50.10.350 &Syntax.AB.Assembly.GNU :cal SetSyn("asm")<CR> -an 50.10.360 &Syntax.AB.Assembly.GNU\ H-8300 :cal SetSyn("asmh8300")<CR> -an 50.10.370 &Syntax.AB.Assembly.Intel\ IA-64 :cal SetSyn("ia64")<CR> -an 50.10.380 &Syntax.AB.Assembly.Microsoft :cal SetSyn("masm")<CR> -an 50.10.390 &Syntax.AB.Assembly.Netwide :cal SetSyn("nasm")<CR> -an 50.10.400 &Syntax.AB.Assembly.PIC :cal SetSyn("pic")<CR> -an 50.10.410 &Syntax.AB.Assembly.Turbo :cal SetSyn("tasm")<CR> -an 50.10.420 &Syntax.AB.Assembly.VAX\ Macro\ Assembly :cal SetSyn("vmasm")<CR> -an 50.10.430 &Syntax.AB.Assembly.Z-80 :cal SetSyn("z8a")<CR> -an 50.10.440 &Syntax.AB.Assembly.xa\ 6502\ cross\ assember :cal SetSyn("a65")<CR> -an 50.10.450 &Syntax.AB.ASN\.1 :cal SetSyn("asn")<CR> -an 50.10.460 &Syntax.AB.Asterisk\ config :cal SetSyn("asterisk")<CR> -an 50.10.470 &Syntax.AB.Asterisk\ voicemail\ config :cal SetSyn("asteriskvm")<CR> -an 50.10.480 &Syntax.AB.Atlas :cal SetSyn("atlas")<CR> -an 50.10.490 &Syntax.AB.AutoHotKey :cal SetSyn("autohotkey")<CR> -an 50.10.500 &Syntax.AB.AutoIt :cal SetSyn("autoit")<CR> -an 50.10.510 &Syntax.AB.Automake :cal SetSyn("automake")<CR> -an 50.10.520 &Syntax.AB.Avenue :cal SetSyn("ave")<CR> -an 50.10.530 &Syntax.AB.Awk :cal SetSyn("awk")<CR> -an 50.10.540 &Syntax.AB.AYacc :cal SetSyn("ayacc")<CR> -an 50.10.560 &Syntax.AB.B :cal SetSyn("b")<CR> -an 50.10.570 &Syntax.AB.Baan :cal SetSyn("baan")<CR> -an 50.10.580 &Syntax.AB.Basic.FreeBasic :cal SetSyn("freebasic")<CR> -an 50.10.590 &Syntax.AB.Basic.IBasic :cal SetSyn("ibasic")<CR> -an 50.10.600 &Syntax.AB.Basic.QBasic :cal SetSyn("basic")<CR> -an 50.10.610 &Syntax.AB.Basic.Visual\ Basic :cal SetSyn("vb")<CR> -an 50.10.620 &Syntax.AB.Bazaar\ commit\ file :cal SetSyn("bzr")<CR> -an 50.10.630 &Syntax.AB.BC\ calculator :cal SetSyn("bc")<CR> -an 50.10.640 &Syntax.AB.BDF\ font :cal SetSyn("bdf")<CR> -an 50.10.650 &Syntax.AB.BibTeX.Bibliography\ database :cal SetSyn("bib")<CR> -an 50.10.660 &Syntax.AB.BibTeX.Bibliography\ Style :cal SetSyn("bst")<CR> -an 50.10.670 &Syntax.AB.BIND.BIND\ config :cal SetSyn("named")<CR> -an 50.10.680 &Syntax.AB.BIND.BIND\ zone :cal SetSyn("bindzone")<CR> -an 50.10.690 &Syntax.AB.Blank :cal SetSyn("blank")<CR> -an 50.20.100 &Syntax.C.C :cal SetSyn("c")<CR> -an 50.20.110 &Syntax.C.C++ :cal SetSyn("cpp")<CR> -an 50.20.120 &Syntax.C.C# :cal SetSyn("cs")<CR> -an 50.20.130 &Syntax.C.Calendar :cal SetSyn("calendar")<CR> -an 50.20.140 &Syntax.C.Cascading\ Style\ Sheets :cal SetSyn("css")<CR> -an 50.20.150 &Syntax.C.CDL :cal SetSyn("cdl")<CR> -an 50.20.160 &Syntax.C.Cdrdao\ TOC :cal SetSyn("cdrtoc")<CR> -an 50.20.170 &Syntax.C.Cdrdao\ config :cal SetSyn("cdrdaoconf")<CR> -an 50.20.180 &Syntax.C.Century\ Term :cal SetSyn("cterm")<CR> -an 50.20.190 &Syntax.C.CH\ script :cal SetSyn("ch")<CR> -an 50.20.200 &Syntax.C.ChangeLog :cal SetSyn("changelog")<CR> -an 50.20.210 &Syntax.C.Cheetah\ template :cal SetSyn("cheetah")<CR> -an 50.20.220 &Syntax.C.CHILL :cal SetSyn("chill")<CR> -an 50.20.230 &Syntax.C.ChordPro :cal SetSyn("chordpro")<CR> -an 50.20.240 &Syntax.C.Clean :cal SetSyn("clean")<CR> -an 50.20.250 &Syntax.C.Clever :cal SetSyn("cl")<CR> -an 50.20.260 &Syntax.C.Clipper :cal SetSyn("clipper")<CR> -an 50.20.270 &Syntax.C.Cmake :cal SetSyn("cmake")<CR> -an 50.20.280 &Syntax.C.Cmusrc :cal SetSyn("cmusrc")<CR> -an 50.20.290 &Syntax.C.Cobol :cal SetSyn("cobol")<CR> -an 50.20.300 &Syntax.C.Coco/R :cal SetSyn("coco")<CR> -an 50.20.310 &Syntax.C.Cold\ Fusion :cal SetSyn("cf")<CR> -an 50.20.320 &Syntax.C.Conary\ Recipe :cal SetSyn("conaryrecipe")<CR> -an 50.20.330 &Syntax.C.Config.Cfg\ Config\ file :cal SetSyn("cfg")<CR> -an 50.20.340 &Syntax.C.Config.Configure\.in :cal SetSyn("config")<CR> -an 50.20.350 &Syntax.C.Config.Generic\ Config\ file :cal SetSyn("conf")<CR> -an 50.20.360 &Syntax.C.CRM114 :cal SetSyn("crm")<CR> -an 50.20.370 &Syntax.C.Crontab :cal SetSyn("crontab")<CR> -an 50.20.380 &Syntax.C.CSP :cal SetSyn("csp")<CR> -an 50.20.390 &Syntax.C.Ctrl-H :cal SetSyn("ctrlh")<CR> -an 50.20.400 &Syntax.C.CUDA :cal SetSyn("cuda")<CR> -an 50.20.410 &Syntax.C.CUPL.CUPL :cal SetSyn("cupl")<CR> -an 50.20.420 &Syntax.C.CUPL.Simulation :cal SetSyn("cuplsim")<CR> -an 50.20.430 &Syntax.C.CVS.commit\ file :cal SetSyn("cvs")<CR> -an 50.20.440 &Syntax.C.CVS.cvsrc :cal SetSyn("cvsrc")<CR> -an 50.20.450 &Syntax.C.Cyn++ :cal SetSyn("cynpp")<CR> -an 50.20.460 &Syntax.C.Cynlib :cal SetSyn("cynlib")<CR> -an 50.30.100 &Syntax.DE.D :cal SetSyn("d")<CR> -an 50.30.110 &Syntax.DE.Debian.Debian\ ChangeLog :cal SetSyn("debchangelog")<CR> -an 50.30.120 &Syntax.DE.Debian.Debian\ Control :cal SetSyn("debcontrol")<CR> -an 50.30.130 &Syntax.DE.Debian.Debian\ Sources\.list :cal SetSyn("debsources")<CR> -an 50.30.140 &Syntax.DE.Denyhosts :cal SetSyn("denyhosts")<CR> -an 50.30.150 &Syntax.DE.Desktop :cal SetSyn("desktop")<CR> -an 50.30.160 &Syntax.DE.Dict\ config :cal SetSyn("dictconf")<CR> -an 50.30.170 &Syntax.DE.Dictd\ config :cal SetSyn("dictdconf")<CR> -an 50.30.180 &Syntax.DE.Diff :cal SetSyn("diff")<CR> -an 50.30.190 &Syntax.DE.Digital\ Command\ Lang :cal SetSyn("dcl")<CR> -an 50.30.200 &Syntax.DE.Dircolors :cal SetSyn("dircolors")<CR> -an 50.30.210 &Syntax.DE.Django\ template :cal SetSyn("django")<CR> -an 50.30.220 &Syntax.DE.DNS/BIND\ zone :cal SetSyn("bindzone")<CR> -an 50.30.230 &Syntax.DE.DocBook.auto-detect :cal SetSyn("docbk")<CR> -an 50.30.240 &Syntax.DE.DocBook.SGML :cal SetSyn("docbksgml")<CR> -an 50.30.250 &Syntax.DE.DocBook.XML :cal SetSyn("docbkxml")<CR> -an 50.30.260 &Syntax.DE.Dot :cal SetSyn("dot")<CR> -an 50.30.270 &Syntax.DE.Doxygen.C\ with\ doxygen :cal SetSyn("c.doxygen")<CR> -an 50.30.280 &Syntax.DE.Doxygen.C++\ with\ doxygen :cal SetSyn("cpp.doxygen")<CR> -an 50.30.290 &Syntax.DE.Doxygen.IDL\ with\ doxygen :cal SetSyn("idl.doxygen")<CR> -an 50.30.300 &Syntax.DE.Doxygen.Java\ with\ doxygen :cal SetSyn("java.doxygen")<CR> -an 50.30.310 &Syntax.DE.Dracula :cal SetSyn("dracula")<CR> -an 50.30.320 &Syntax.DE.DSSSL :cal SetSyn("dsl")<CR> -an 50.30.330 &Syntax.DE.DTD :cal SetSyn("dtd")<CR> -an 50.30.340 &Syntax.DE.DTML\ (Zope) :cal SetSyn("dtml")<CR> -an 50.30.350 &Syntax.DE.DTrace :cal SetSyn("dtrace")<CR> -an 50.30.360 &Syntax.DE.Dylan.Dylan :cal SetSyn("dylan")<CR> -an 50.30.370 &Syntax.DE.Dylan.Dylan\ interface :cal SetSyn("dylanintr")<CR> -an 50.30.380 &Syntax.DE.Dylan.Dylan\ lid :cal SetSyn("dylanlid")<CR> -an 50.30.400 &Syntax.DE.EDIF :cal SetSyn("edif")<CR> -an 50.30.410 &Syntax.DE.Eiffel :cal SetSyn("eiffel")<CR> -an 50.30.420 &Syntax.DE.Elinks\ config :cal SetSyn("elinks")<CR> -an 50.30.430 &Syntax.DE.Elm\ filter\ rules :cal SetSyn("elmfilt")<CR> -an 50.30.440 &Syntax.DE.Embedix\ Component\ Description :cal SetSyn("ecd")<CR> -an 50.30.450 &Syntax.DE.ERicsson\ LANGuage :cal SetSyn("erlang")<CR> -an 50.30.460 &Syntax.DE.ESMTP\ rc :cal SetSyn("esmtprc")<CR> -an 50.30.470 &Syntax.DE.ESQL-C :cal SetSyn("esqlc")<CR> -an 50.30.480 &Syntax.DE.Essbase\ script :cal SetSyn("csc")<CR> -an 50.30.490 &Syntax.DE.Esterel :cal SetSyn("esterel")<CR> -an 50.30.500 &Syntax.DE.Eterm\ config :cal SetSyn("eterm")<CR> -an 50.30.510 &Syntax.DE.Eviews :cal SetSyn("eviews")<CR> -an 50.30.520 &Syntax.DE.Exim\ conf :cal SetSyn("exim")<CR> -an 50.30.530 &Syntax.DE.Expect :cal SetSyn("expect")<CR> -an 50.30.540 &Syntax.DE.Exports :cal SetSyn("exports")<CR> -an 50.40.100 &Syntax.FG.Fetchmail :cal SetSyn("fetchmail")<CR> -an 50.40.110 &Syntax.FG.FlexWiki :cal SetSyn("flexwiki")<CR> -an 50.40.120 &Syntax.FG.Focus\ Executable :cal SetSyn("focexec")<CR> -an 50.40.130 &Syntax.FG.Focus\ Master :cal SetSyn("master")<CR> -an 50.40.140 &Syntax.FG.FORM :cal SetSyn("form")<CR> -an 50.40.150 &Syntax.FG.Forth :cal SetSyn("forth")<CR> -an 50.40.160 &Syntax.FG.Fortran :cal SetSyn("fortran")<CR> -an 50.40.170 &Syntax.FG.FoxPro :cal SetSyn("foxpro")<CR> -an 50.40.180 &Syntax.FG.FrameScript :cal SetSyn("framescript")<CR> -an 50.40.190 &Syntax.FG.Fstab :cal SetSyn("fstab")<CR> -an 50.40.200 &Syntax.FG.Fvwm.Fvwm\ configuration :cal SetSyn("fvwm1")<CR> -an 50.40.210 &Syntax.FG.Fvwm.Fvwm2\ configuration :cal SetSyn("fvwm2")<CR> -an 50.40.220 &Syntax.FG.Fvwm.Fvwm2\ configuration\ with\ M4 :cal SetSyn("fvwm2m4")<CR> -an 50.40.240 &Syntax.FG.GDB\ command\ file :cal SetSyn("gdb")<CR> -an 50.40.250 &Syntax.FG.GDMO :cal SetSyn("gdmo")<CR> -an 50.40.260 &Syntax.FG.Gedcom :cal SetSyn("gedcom")<CR> -an 50.40.270 &Syntax.FG.Git.Output :cal SetSyn("git")<CR> -an 50.40.280 &Syntax.FG.Git.Commit :cal SetSyn("gitcommit")<CR> -an 50.40.290 &Syntax.FG.Git.Config :cal SetSyn("gitconfig")<CR> -an 50.40.300 &Syntax.FG.Git.Rebase :cal SetSyn("gitrebase")<CR> -an 50.40.310 &Syntax.FG.Git.Send\ Email :cal SetSyn("gitsendemail")<CR> -an 50.40.320 &Syntax.FG.Gkrellmrc :cal SetSyn("gkrellmrc")<CR> -an 50.40.330 &Syntax.FG.GP :cal SetSyn("gp")<CR> -an 50.40.340 &Syntax.FG.GPG :cal SetSyn("gpg")<CR> -an 50.40.350 &Syntax.FG.Group\ file :cal SetSyn("group")<CR> -an 50.40.360 &Syntax.FG.Grub :cal SetSyn("grub")<CR> -an 50.40.370 &Syntax.FG.GNU\ Server\ Pages :cal SetSyn("gsp")<CR> -an 50.40.380 &Syntax.FG.GNUplot :cal SetSyn("gnuplot")<CR> -an 50.40.390 &Syntax.FG.GrADS\ scripts :cal SetSyn("grads")<CR> -an 50.40.400 &Syntax.FG.Gretl :cal SetSyn("gretl")<CR> -an 50.40.410 &Syntax.FG.Groff :cal SetSyn("groff")<CR> -an 50.40.420 &Syntax.FG.Groovy :cal SetSyn("groovy")<CR> -an 50.40.430 &Syntax.FG.GTKrc :cal SetSyn("gtkrc")<CR> -an 50.50.100 &Syntax.HIJK.Haml :cal SetSyn("haml")<CR> -an 50.50.110 &Syntax.HIJK.Hamster :cal SetSyn("hamster")<CR> -an 50.50.120 &Syntax.HIJK.Haskell.Haskell :cal SetSyn("haskell")<CR> -an 50.50.130 &Syntax.HIJK.Haskell.Haskell-c2hs :cal SetSyn("chaskell")<CR> -an 50.50.140 &Syntax.HIJK.Haskell.Haskell-literate :cal SetSyn("lhaskell")<CR> -an 50.50.150 &Syntax.HIJK.HASTE :cal SetSyn("haste")<CR> -an 50.50.160 &Syntax.HIJK.HASTE\ preproc :cal SetSyn("hastepreproc")<CR> -an 50.50.170 &Syntax.HIJK.Hercules :cal SetSyn("hercules")<CR> -an 50.50.180 &Syntax.HIJK.Hex\ dump.XXD :cal SetSyn("xxd")<CR> -an 50.50.190 &Syntax.HIJK.Hex\ dump.Intel\ MCS51 :cal SetSyn("hex")<CR> -an 50.50.200 &Syntax.HIJK.HTML.HTML :cal SetSyn("html")<CR> -an 50.50.210 &Syntax.HIJK.HTML.HTML\ with\ M4 :cal SetSyn("htmlm4")<CR> -an 50.50.220 &Syntax.HIJK.HTML.HTML\ with\ Ruby\ (eRuby) :cal SetSyn("eruby")<CR> -an 50.50.230 &Syntax.HIJK.HTML.Cheetah\ HTML\ template :cal SetSyn("htmlcheetah")<CR> -an 50.50.240 &Syntax.HIJK.HTML.Django\ HTML\ template :cal SetSyn("htmldjango")<CR> -an 50.50.250 &Syntax.HIJK.HTML.HTML/OS :cal SetSyn("htmlos")<CR> -an 50.50.260 &Syntax.HIJK.HTML.XHTML :cal SetSyn("xhtml")<CR> -an 50.50.270 &Syntax.HIJK.Host\.conf :cal SetSyn("hostconf")<CR> -an 50.50.280 &Syntax.HIJK.Hyper\ Builder :cal SetSyn("hb")<CR> -an 50.50.300 &Syntax.HIJK.Icewm\ menu :cal SetSyn("icemenu")<CR> -an 50.50.310 &Syntax.HIJK.Icon :cal SetSyn("icon")<CR> -an 50.50.320 &Syntax.HIJK.IDL\Generic\ IDL :cal SetSyn("idl")<CR> -an 50.50.330 &Syntax.HIJK.IDL\Microsoft\ IDL :cal SetSyn("msidl")<CR> -an 50.50.340 &Syntax.HIJK.Indent\ profile :cal SetSyn("indent")<CR> -an 50.50.350 &Syntax.HIJK.Inform :cal SetSyn("inform")<CR> -an 50.50.360 &Syntax.HIJK.Informix\ 4GL :cal SetSyn("fgl")<CR> -an 50.50.370 &Syntax.HIJK.Initng :cal SetSyn("initng")<CR> -an 50.50.380 &Syntax.HIJK.Inittab :cal SetSyn("inittab")<CR> -an 50.50.390 &Syntax.HIJK.Inno\ setup :cal SetSyn("iss")<CR> -an 50.50.400 &Syntax.HIJK.InstallShield\ script :cal SetSyn("ishd")<CR> -an 50.50.410 &Syntax.HIJK.Interactive\ Data\ Lang :cal SetSyn("idlang")<CR> -an 50.50.420 &Syntax.HIJK.IPfilter :cal SetSyn("ipfilter")<CR> -an 50.50.440 &Syntax.HIJK.JAL :cal SetSyn("jal")<CR> -an 50.50.450 &Syntax.HIJK.JAM :cal SetSyn("jam")<CR> -an 50.50.460 &Syntax.HIJK.Jargon :cal SetSyn("jargon")<CR> -an 50.50.470 &Syntax.HIJK.Java.Java :cal SetSyn("java")<CR> -an 50.50.480 &Syntax.HIJK.Java.JavaCC :cal SetSyn("javacc")<CR> -an 50.50.490 &Syntax.HIJK.Java.Java\ Server\ Pages :cal SetSyn("jsp")<CR> -an 50.50.500 &Syntax.HIJK.Java.Java\ Properties :cal SetSyn("jproperties")<CR> -an 50.50.510 &Syntax.HIJK.JavaScript :cal SetSyn("javascript")<CR> -an 50.50.520 &Syntax.HIJK.Jess :cal SetSyn("jess")<CR> -an 50.50.530 &Syntax.HIJK.Jgraph :cal SetSyn("jgraph")<CR> -an 50.50.550 &Syntax.HIJK.Kconfig :cal SetSyn("kconfig")<CR> -an 50.50.560 &Syntax.HIJK.KDE\ script :cal SetSyn("kscript")<CR> -an 50.50.570 &Syntax.HIJK.Kimwitu++ :cal SetSyn("kwt")<CR> -an 50.50.580 &Syntax.HIJK.KixTart :cal SetSyn("kix")<CR> -an 50.60.100 &Syntax.L-Ma.Lace :cal SetSyn("lace")<CR> -an 50.60.110 &Syntax.L-Ma.LamdaProlog :cal SetSyn("lprolog")<CR> -an 50.60.120 &Syntax.L-Ma.Latte :cal SetSyn("latte")<CR> -an 50.60.130 &Syntax.L-Ma.Ld\ script :cal SetSyn("ld")<CR> -an 50.60.140 &Syntax.L-Ma.LDAP.LDIF :cal SetSyn("ldif")<CR> -an 50.60.150 &Syntax.L-Ma.LDAP.Configuration :cal SetSyn("ldapconf")<CR> -an 50.60.160 &Syntax.L-Ma.Lex :cal SetSyn("lex")<CR> -an 50.60.170 &Syntax.L-Ma.LFTP\ config :cal SetSyn("lftp")<CR> -an 50.60.180 &Syntax.L-Ma.Libao :cal SetSyn("libao")<CR> -an 50.60.190 &Syntax.L-Ma.LifeLines\ script :cal SetSyn("lifelines")<CR> -an 50.60.200 &Syntax.L-Ma.Lilo :cal SetSyn("lilo")<CR> -an 50.60.210 &Syntax.L-Ma.Limits\ config :cal SetSyn("limits")<CR> -an 50.60.220 &Syntax.L-Ma.Linden\ scripting :cal SetSyn("lsl")<CR> -an 50.60.230 &Syntax.L-Ma.Lisp :cal SetSyn("lisp")<CR> -an 50.60.240 &Syntax.L-Ma.Lite :cal SetSyn("lite")<CR> -an 50.60.250 &Syntax.L-Ma.LiteStep\ RC :cal SetSyn("litestep")<CR> -an 50.60.260 &Syntax.L-Ma.Locale\ Input :cal SetSyn("fdcc")<CR> -an 50.60.270 &Syntax.L-Ma.Login\.access :cal SetSyn("loginaccess")<CR> -an 50.60.280 &Syntax.L-Ma.Login\.defs :cal SetSyn("logindefs")<CR> -an 50.60.290 &Syntax.L-Ma.Logtalk :cal SetSyn("logtalk")<CR> -an 50.60.300 &Syntax.L-Ma.LOTOS :cal SetSyn("lotos")<CR> -an 50.60.310 &Syntax.L-Ma.LotusScript :cal SetSyn("lscript")<CR> -an 50.60.320 &Syntax.L-Ma.Lout :cal SetSyn("lout")<CR> -an 50.60.330 &Syntax.L-Ma.LPC :cal SetSyn("lpc")<CR> -an 50.60.340 &Syntax.L-Ma.Lua :cal SetSyn("lua")<CR> -an 50.60.350 &Syntax.L-Ma.Lynx\ Style :cal SetSyn("lss")<CR> -an 50.60.360 &Syntax.L-Ma.Lynx\ config :cal SetSyn("lynx")<CR> -an 50.60.380 &Syntax.L-Ma.M4 :cal SetSyn("m4")<CR> -an 50.60.390 &Syntax.L-Ma.MaGic\ Point :cal SetSyn("mgp")<CR> -an 50.60.400 &Syntax.L-Ma.Mail :cal SetSyn("mail")<CR> -an 50.60.410 &Syntax.L-Ma.Mail\ aliases :cal SetSyn("mailaliases")<CR> -an 50.60.420 &Syntax.L-Ma.Mailcap :cal SetSyn("mailcap")<CR> -an 50.60.430 &Syntax.L-Ma.Makefile :cal SetSyn("make")<CR> -an 50.60.440 &Syntax.L-Ma.MakeIndex :cal SetSyn("ist")<CR> -an 50.60.450 &Syntax.L-Ma.Man\ page :cal SetSyn("man")<CR> -an 50.60.460 &Syntax.L-Ma.Man\.conf :cal SetSyn("manconf")<CR> -an 50.60.470 &Syntax.L-Ma.Maple\ V :cal SetSyn("maple")<CR> -an 50.60.480 &Syntax.L-Ma.Mason :cal SetSyn("mason")<CR> -an 50.60.490 &Syntax.L-Ma.Mathematica :cal SetSyn("mma")<CR> -an 50.60.500 &Syntax.L-Ma.Matlab :cal SetSyn("matlab")<CR> -an 50.60.510 &Syntax.L-Ma.Maxima :cal SetSyn("maxima")<CR> -an 50.70.100 &Syntax.Me-NO.MEL\ (for\ Maya) :cal SetSyn("mel")<CR> -an 50.70.110 &Syntax.Me-NO.Messages\ (/var/log) :cal SetSyn("messages")<CR> -an 50.70.120 &Syntax.Me-NO.Metafont :cal SetSyn("mf")<CR> -an 50.70.130 &Syntax.Me-NO.MetaPost :cal SetSyn("mp")<CR> -an 50.70.140 &Syntax.Me-NO.MGL :cal SetSyn("mgl")<CR> -an 50.70.150 &Syntax.Me-NO.MMIX :cal SetSyn("mmix")<CR> -an 50.70.160 &Syntax.Me-NO.Modconf :cal SetSyn("modconf")<CR> -an 50.70.170 &Syntax.Me-NO.Model :cal SetSyn("model")<CR> -an 50.70.180 &Syntax.Me-NO.Modsim\ III :cal SetSyn("modsim3")<CR> -an 50.70.190 &Syntax.Me-NO.Modula\ 2 :cal SetSyn("modula2")<CR> -an 50.70.200 &Syntax.Me-NO.Modula\ 3 :cal SetSyn("modula3")<CR> -an 50.70.210 &Syntax.Me-NO.Monk :cal SetSyn("monk")<CR> -an 50.70.220 &Syntax.Me-NO.Mplayer\ config :cal SetSyn("mplayerconf")<CR> -an 50.70.230 &Syntax.Me-NO.MOO :cal SetSyn("moo")<CR> -an 50.70.240 &Syntax.Me-NO.Mrxvtrc :cal SetSyn("mrxvtrc")<CR> -an 50.70.250 &Syntax.Me-NO.MS-DOS/Windows.4DOS\ \.bat\ file :cal SetSyn("btm")<CR> -an 50.70.260 &Syntax.Me-NO.MS-DOS/Windows.\.bat\/\.cmd\ file :cal SetSyn("dosbatch")<CR> -an 50.70.270 &Syntax.Me-NO.MS-DOS/Windows.\.ini\ file :cal SetSyn("dosini")<CR> -an 50.70.280 &Syntax.Me-NO.MS-DOS/Windows.Message\ text :cal SetSyn("msmessages")<CR> -an 50.70.290 &Syntax.Me-NO.MS-DOS/Windows.Module\ Definition :cal SetSyn("def")<CR> -an 50.70.300 &Syntax.Me-NO.MS-DOS/Windows.Registry :cal SetSyn("registry")<CR> -an 50.70.310 &Syntax.Me-NO.MS-DOS/Windows.Resource\ file :cal SetSyn("rc")<CR> -an 50.70.320 &Syntax.Me-NO.Msql :cal SetSyn("msql")<CR> -an 50.70.330 &Syntax.Me-NO.MuPAD :cal SetSyn("mupad")<CR> -an 50.70.340 &Syntax.Me-NO.MUSHcode :cal SetSyn("mush")<CR> -an 50.70.350 &Syntax.Me-NO.Muttrc :cal SetSyn("muttrc")<CR> -an 50.70.370 &Syntax.Me-NO.Nanorc :cal SetSyn("nanorc")<CR> -an 50.70.380 &Syntax.Me-NO.Nastran\ input/DMAP :cal SetSyn("nastran")<CR> -an 50.70.390 &Syntax.Me-NO.Natural :cal SetSyn("natural")<CR> -an 50.70.400 &Syntax.Me-NO.Netrc :cal SetSyn("netrc")<CR> -an 50.70.410 &Syntax.Me-NO.Novell\ NCF\ batch :cal SetSyn("ncf")<CR> -an 50.70.420 &Syntax.Me-NO.Not\ Quite\ C\ (LEGO) :cal SetSyn("nqc")<CR> -an 50.70.430 &Syntax.Me-NO.Nroff :cal SetSyn("nroff")<CR> -an 50.70.440 &Syntax.Me-NO.NSIS\ script :cal SetSyn("nsis")<CR> -an 50.70.460 &Syntax.Me-NO.Objective\ C :cal SetSyn("objc")<CR> -an 50.70.470 &Syntax.Me-NO.Objective\ C++ :cal SetSyn("objcpp")<CR> -an 50.70.480 &Syntax.Me-NO.OCAML :cal SetSyn("ocaml")<CR> -an 50.70.490 &Syntax.Me-NO.Occam :cal SetSyn("occam")<CR> -an 50.70.500 &Syntax.Me-NO.Omnimark :cal SetSyn("omnimark")<CR> -an 50.70.510 &Syntax.Me-NO.OpenROAD :cal SetSyn("openroad")<CR> -an 50.70.520 &Syntax.Me-NO.Open\ Psion\ Lang :cal SetSyn("opl")<CR> -an 50.70.530 &Syntax.Me-NO.Oracle\ config :cal SetSyn("ora")<CR> -an 50.80.100 &Syntax.PQ.Packet\ filter\ conf :cal SetSyn("pf")<CR> -an 50.80.110 &Syntax.PQ.Palm\ resource\ compiler :cal SetSyn("pilrc")<CR> -an 50.80.120 &Syntax.PQ.Pam\ config :cal SetSyn("pamconf")<CR> -an 50.80.130 &Syntax.PQ.PApp :cal SetSyn("papp")<CR> -an 50.80.140 &Syntax.PQ.Pascal :cal SetSyn("pascal")<CR> -an 50.80.150 &Syntax.PQ.Password\ file :cal SetSyn("passwd")<CR> -an 50.80.160 &Syntax.PQ.PCCTS :cal SetSyn("pccts")<CR> -an 50.80.170 &Syntax.PQ.PDF :cal SetSyn("pdf")<CR> -an 50.80.180 &Syntax.PQ.Perl.Perl :cal SetSyn("perl")<CR> -an 50.80.190 &Syntax.PQ.Perl.Perl\ POD :cal SetSyn("pod")<CR> -an 50.80.200 &Syntax.PQ.Perl.Perl\ XS :cal SetSyn("xs")<CR> -an 50.80.210 &Syntax.PQ.PHP.PHP\ 3-4 :cal SetSyn("php")<CR> -an 50.80.220 &Syntax.PQ.PHP.Phtml\ (PHP\ 2) :cal SetSyn("phtml")<CR> -an 50.80.230 &Syntax.PQ.Pike :cal SetSyn("pike")<CR> -an 50.80.240 &Syntax.PQ.Pine\ RC :cal SetSyn("pine")<CR> -an 50.80.250 &Syntax.PQ.Pinfo\ RC :cal SetSyn("pinfo")<CR> -an 50.80.260 &Syntax.PQ.PL/M :cal SetSyn("plm")<CR> -an 50.80.270 &Syntax.PQ.PL/SQL :cal SetSyn("plsql")<CR> -an 50.80.280 &Syntax.PQ.PLP :cal SetSyn("plp")<CR> -an 50.80.290 &Syntax.PQ.PO\ (GNU\ gettext) :cal SetSyn("po")<CR> -an 50.80.300 &Syntax.PQ.Postfix\ main\ config :cal SetSyn("pfmain")<CR> -an 50.80.310 &Syntax.PQ.PostScript.PostScript :cal SetSyn("postscr")<CR> -an 50.80.320 &Syntax.PQ.PostScript.PostScript\ Printer\ Description :cal SetSyn("ppd")<CR> -an 50.80.330 &Syntax.PQ.Povray.Povray\ scene\ descr :cal SetSyn("pov")<CR> -an 50.80.340 &Syntax.PQ.Povray.Povray\ configuration :cal SetSyn("povini")<CR> -an 50.80.350 &Syntax.PQ.PPWizard :cal SetSyn("ppwiz")<CR> -an 50.80.360 &Syntax.PQ.Prescribe\ (Kyocera) :cal SetSyn("prescribe")<CR> -an 50.80.370 &Syntax.PQ.Printcap :cal SetSyn("pcap")<CR> -an 50.80.380 &Syntax.PQ.Privoxy :cal SetSyn("privoxy")<CR> -an 50.80.390 &Syntax.PQ.Procmail :cal SetSyn("procmail")<CR> -an 50.80.400 &Syntax.PQ.Product\ Spec\ File :cal SetSyn("psf")<CR> -an 50.80.410 &Syntax.PQ.Progress :cal SetSyn("progress")<CR> -an 50.80.420 &Syntax.PQ.Prolog :cal SetSyn("prolog")<CR> -an 50.80.430 &Syntax.PQ.ProMeLa :cal SetSyn("promela")<CR> -an 50.80.440 &Syntax.PQ.Protocols :cal SetSyn("protocols")<CR> -an 50.80.450 &Syntax.PQ.Purify\ log :cal SetSyn("purifylog")<CR> -an 50.80.460 &Syntax.PQ.Pyrex :cal SetSyn("pyrex")<CR> -an 50.80.470 &Syntax.PQ.Python :cal SetSyn("python")<CR> -an 50.80.490 &Syntax.PQ.Quake :cal SetSyn("quake")<CR> -an 50.80.500 &Syntax.PQ.Quickfix\ window :cal SetSyn("qf")<CR> -an 50.90.100 &Syntax.R-Sg.R.R :cal SetSyn("r")<CR> -an 50.90.110 &Syntax.R-Sg.R.R\ help :cal SetSyn("rhelp")<CR> -an 50.90.120 &Syntax.R-Sg.R.R\ noweb :cal SetSyn("rnoweb")<CR> -an 50.90.130 &Syntax.R-Sg.Racc\ input :cal SetSyn("racc")<CR> -an 50.90.140 &Syntax.R-Sg.Radiance :cal SetSyn("radiance")<CR> -an 50.90.150 &Syntax.R-Sg.Ratpoison :cal SetSyn("ratpoison")<CR> -an 50.90.160 &Syntax.R-Sg.RCS.RCS\ log\ output :cal SetSyn("rcslog")<CR> -an 50.90.170 &Syntax.R-Sg.RCS.RCS\ file :cal SetSyn("rcs")<CR> -an 50.90.180 &Syntax.R-Sg.Readline\ config :cal SetSyn("readline")<CR> -an 50.90.190 &Syntax.R-Sg.Rebol :cal SetSyn("rebol")<CR> -an 50.90.200 &Syntax.R-Sg.Remind :cal SetSyn("remind")<CR> -an 50.90.210 &Syntax.R-Sg.Relax\ NG\ compact :cal SetSyn("rnc")<CR> -an 50.90.220 &Syntax.R-Sg.Renderman.Renderman\ Shader\ Lang :cal SetSyn("sl")<CR> -an 50.90.230 &Syntax.R-Sg.Renderman.Renderman\ Interface\ Bytestream :cal SetSyn("rib")<CR> -an 50.90.240 &Syntax.R-Sg.Resolv\.conf :cal SetSyn("resolv")<CR> -an 50.90.250 &Syntax.R-Sg.Reva\ Forth :cal SetSyn("reva")<CR> -an 50.90.260 &Syntax.R-Sg.Rexx :cal SetSyn("rexx")<CR> -an 50.90.270 &Syntax.R-Sg.Robots\.txt :cal SetSyn("robots")<CR> -an 50.90.280 &Syntax.R-Sg.RockLinux\ package\ desc\. :cal SetSyn("desc")<CR> -an 50.90.290 &Syntax.R-Sg.Rpcgen :cal SetSyn("rpcgen")<CR> -an 50.90.300 &Syntax.R-Sg.RPL/2 :cal SetSyn("rpl")<CR> -an 50.90.310 &Syntax.R-Sg.ReStructuredText :cal SetSyn("rst")<CR> -an 50.90.320 &Syntax.R-Sg.RTF :cal SetSyn("rtf")<CR> -an 50.90.330 &Syntax.R-Sg.Ruby :cal SetSyn("ruby")<CR> -an 50.90.350 &Syntax.R-Sg.S-Lang :cal SetSyn("slang")<CR> -an 50.90.360 &Syntax.R-Sg.Samba\ config :cal SetSyn("samba")<CR> -an 50.90.370 &Syntax.R-Sg.SAS :cal SetSyn("sas")<CR> -an 50.90.380 &Syntax.R-Sg.Sass :cal SetSyn("sass")<CR> -an 50.90.390 &Syntax.R-Sg.Sather :cal SetSyn("sather")<CR> -an 50.90.400 &Syntax.R-Sg.Scheme :cal SetSyn("scheme")<CR> -an 50.90.410 &Syntax.R-Sg.Scilab :cal SetSyn("scilab")<CR> -an 50.90.420 &Syntax.R-Sg.Screen\ RC :cal SetSyn("screen")<CR> -an 50.90.430 &Syntax.R-Sg.SDL :cal SetSyn("sdl")<CR> -an 50.90.440 &Syntax.R-Sg.Sed :cal SetSyn("sed")<CR> -an 50.90.450 &Syntax.R-Sg.Sendmail\.cf :cal SetSyn("sm")<CR> -an 50.90.460 &Syntax.R-Sg.Send-pr :cal SetSyn("sendpr")<CR> -an 50.90.470 &Syntax.R-Sg.Sensors\.conf :cal SetSyn("sensors")<CR> -an 50.90.480 &Syntax.R-Sg.Service\ Location\ config :cal SetSyn("slpconf")<CR> -an 50.90.490 &Syntax.R-Sg.Service\ Location\ registration :cal SetSyn("slpreg")<CR> -an 50.90.500 &Syntax.R-Sg.Service\ Location\ SPI :cal SetSyn("slpspi")<CR> -an 50.90.510 &Syntax.R-Sg.Services :cal SetSyn("services")<CR> -an 50.90.520 &Syntax.R-Sg.Setserial\ config :cal SetSyn("setserial")<CR> -an 50.90.530 &Syntax.R-Sg.SGML.SGML\ catalog :cal SetSyn("catalog")<CR> -an 50.90.540 &Syntax.R-Sg.SGML.SGML\ DTD :cal SetSyn("sgml")<CR> -an 50.90.550 &Syntax.R-Sg.SGML.SGML\ Declaration :cal SetSyn("sgmldecl")<CR> -an 50.90.560 &Syntax.R-Sg.SGML.SGML-linuxdoc :cal SetSyn("sgmllnx")<CR> -an 50.100.100 &Syntax.Sh-S.Shell\ script.sh\ and\ ksh :cal SetSyn("sh")<CR> -an 50.100.110 &Syntax.Sh-S.Shell\ script.csh :cal SetSyn("csh")<CR> -an 50.100.120 &Syntax.Sh-S.Shell\ script.tcsh :cal SetSyn("tcsh")<CR> -an 50.100.130 &Syntax.Sh-S.Shell\ script.zsh :cal SetSyn("zsh")<CR> -an 50.100.140 &Syntax.Sh-S.SiCAD :cal SetSyn("sicad")<CR> -an 50.100.150 &Syntax.Sh-S.Sieve :cal SetSyn("sieve")<CR> -an 50.100.160 &Syntax.Sh-S.Simula :cal SetSyn("simula")<CR> -an 50.100.170 &Syntax.Sh-S.Sinda.Sinda\ compare :cal SetSyn("sindacmp")<CR> -an 50.100.180 &Syntax.Sh-S.Sinda.Sinda\ input :cal SetSyn("sinda")<CR> -an 50.100.190 &Syntax.Sh-S.Sinda.Sinda\ output :cal SetSyn("sindaout")<CR> -an 50.100.200 &Syntax.Sh-S.SiSU :cal SetSyn("sisu")<CR> -an 50.100.210 &Syntax.Sh-S.SKILL.SKILL :cal SetSyn("skill")<CR> -an 50.100.220 &Syntax.Sh-S.SKILL.SKILL\ for\ Diva :cal SetSyn("diva")<CR> -an 50.100.230 &Syntax.Sh-S.Slice :cal SetSyn("slice")<CR> -an 50.100.240 &Syntax.Sh-S.SLRN.Slrn\ rc :cal SetSyn("slrnrc")<CR> -an 50.100.250 &Syntax.Sh-S.SLRN.Slrn\ score :cal SetSyn("slrnsc")<CR> -an 50.100.260 &Syntax.Sh-S.SmallTalk :cal SetSyn("st")<CR> -an 50.100.270 &Syntax.Sh-S.Smarty\ Templates :cal SetSyn("smarty")<CR> -an 50.100.280 &Syntax.Sh-S.SMIL :cal SetSyn("smil")<CR> -an 50.100.290 &Syntax.Sh-S.SMITH :cal SetSyn("smith")<CR> -an 50.100.300 &Syntax.Sh-S.SNMP\ MIB :cal SetSyn("mib")<CR> -an 50.100.310 &Syntax.Sh-S.SNNS.SNNS\ network :cal SetSyn("snnsnet")<CR> -an 50.100.320 &Syntax.Sh-S.SNNS.SNNS\ pattern :cal SetSyn("snnspat")<CR> -an 50.100.330 &Syntax.Sh-S.SNNS.SNNS\ result :cal SetSyn("snnsres")<CR> -an 50.100.340 &Syntax.Sh-S.Snobol4 :cal SetSyn("snobol4")<CR> -an 50.100.350 &Syntax.Sh-S.Snort\ Configuration :cal SetSyn("hog")<CR> -an 50.100.360 &Syntax.Sh-S.SPEC\ (Linux\ RPM) :cal SetSyn("spec")<CR> -an 50.100.370 &Syntax.Sh-S.Specman :cal SetSyn("specman")<CR> -an 50.100.380 &Syntax.Sh-S.Spice :cal SetSyn("spice")<CR> -an 50.100.390 &Syntax.Sh-S.Spyce :cal SetSyn("spyce")<CR> -an 50.100.400 &Syntax.Sh-S.Speedup :cal SetSyn("spup")<CR> -an 50.100.410 &Syntax.Sh-S.Splint :cal SetSyn("splint")<CR> -an 50.100.420 &Syntax.Sh-S.Squid\ config :cal SetSyn("squid")<CR> -an 50.100.430 &Syntax.Sh-S.SQL.ESQL-C :cal SetSyn("esqlc")<CR> -an 50.100.440 &Syntax.Sh-S.SQL.MySQL :cal SetSyn("mysql")<CR> -an 50.100.450 &Syntax.Sh-S.SQL.PL/SQL :cal SetSyn("plsql")<CR> -an 50.100.460 &Syntax.Sh-S.SQL.SQL\ Anywhere :cal SetSyn("sqlanywhere")<CR> -an 50.100.470 &Syntax.Sh-S.SQL.SQL\ (automatic) :cal SetSyn("sql")<CR> -an 50.100.480 &Syntax.Sh-S.SQL.SQL\ (Oracle) :cal SetSyn("sqloracle")<CR> -an 50.100.490 &Syntax.Sh-S.SQL.SQL\ Forms :cal SetSyn("sqlforms")<CR> -an 50.100.500 &Syntax.Sh-S.SQL.SQLJ :cal SetSyn("sqlj")<CR> -an 50.100.510 &Syntax.Sh-S.SQL.SQL-Informix :cal SetSyn("sqlinformix")<CR> -an 50.100.520 &Syntax.Sh-S.SQR :cal SetSyn("sqr")<CR> -an 50.100.530 &Syntax.Sh-S.Ssh.ssh_config :cal SetSyn("sshconfig")<CR> -an 50.100.540 &Syntax.Sh-S.Ssh.sshd_config :cal SetSyn("sshdconfig")<CR> -an 50.100.550 &Syntax.Sh-S.Standard\ ML :cal SetSyn("sml")<CR> -an 50.100.560 &Syntax.Sh-S.Stata.SMCL :cal SetSyn("smcl")<CR> -an 50.100.570 &Syntax.Sh-S.Stata.Stata :cal SetSyn("stata")<CR> -an 50.100.580 &Syntax.Sh-S.Stored\ Procedures :cal SetSyn("stp")<CR> -an 50.100.590 &Syntax.Sh-S.Strace :cal SetSyn("strace")<CR> -an 50.100.600 &Syntax.Sh-S.Streaming\ descriptor\ file :cal SetSyn("sd")<CR> -an 50.100.610 &Syntax.Sh-S.Subversion\ commit :cal SetSyn("svn")<CR> -an 50.100.620 &Syntax.Sh-S.Sudoers :cal SetSyn("sudoers")<CR> -an 50.100.630 &Syntax.Sh-S.Symbian\ meta-makefile :cal SetSyn("mmp")<CR> -an 50.100.640 &Syntax.Sh-S.Sysctl\.conf :cal SetSyn("sysctl")<CR> -an 50.110.100 &Syntax.TUV.TADS :cal SetSyn("tads")<CR> -an 50.110.110 &Syntax.TUV.Tags :cal SetSyn("tags")<CR> -an 50.110.120 &Syntax.TUV.TAK.TAK\ compare :cal SetSyn("takcmp")<CR> -an 50.110.130 &Syntax.TUV.TAK.TAK\ input :cal SetSyn("tak")<CR> -an 50.110.140 &Syntax.TUV.TAK.TAK\ output :cal SetSyn("takout")<CR> -an 50.110.150 &Syntax.TUV.Tcl/Tk :cal SetSyn("tcl")<CR> -an 50.110.160 &Syntax.TUV.TealInfo :cal SetSyn("tli")<CR> -an 50.110.170 &Syntax.TUV.Telix\ Salt :cal SetSyn("tsalt")<CR> -an 50.110.180 &Syntax.TUV.Termcap/Printcap :cal SetSyn("ptcap")<CR> -an 50.110.190 &Syntax.TUV.Terminfo :cal SetSyn("terminfo")<CR> -an 50.110.200 &Syntax.TUV.TeX.TeX/LaTeX :cal SetSyn("tex")<CR> -an 50.110.210 &Syntax.TUV.TeX.plain\ TeX :cal SetSyn("plaintex")<CR> -an 50.110.220 &Syntax.TUV.TeX.ConTeXt :cal SetSyn("context")<CR> -an 50.110.230 &Syntax.TUV.TeX.TeX\ configuration :cal SetSyn("texmf")<CR> -an 50.110.240 &Syntax.TUV.TeX.Texinfo :cal SetSyn("texinfo")<CR> -an 50.110.250 &Syntax.TUV.TF\ mud\ client :cal SetSyn("tf")<CR> -an 50.110.260 &Syntax.TUV.Tidy\ configuration :cal SetSyn("tidy")<CR> -an 50.110.270 &Syntax.TUV.Tilde :cal SetSyn("tilde")<CR> -an 50.110.280 &Syntax.TUV.TPP :cal SetSyn("tpp")<CR> -an 50.110.290 &Syntax.TUV.Trasys\ input :cal SetSyn("trasys")<CR> -an 50.110.300 &Syntax.TUV.Trustees :cal SetSyn("trustees")<CR> -an 50.110.310 &Syntax.TUV.TSS.Command\ Line :cal SetSyn("tsscl")<CR> -an 50.110.320 &Syntax.TUV.TSS.Geometry :cal SetSyn("tssgm")<CR> -an 50.110.330 &Syntax.TUV.TSS.Optics :cal SetSyn("tssop")<CR> -an 50.110.350 &Syntax.TUV.Udev\ config :cal SetSyn("udevconf")<CR> -an 50.110.360 &Syntax.TUV.Udev\ permissions :cal SetSyn("udevperm")<CR> -an 50.110.370 &Syntax.TUV.Udev\ rules :cal SetSyn("udevrules")<CR> -an 50.110.380 &Syntax.TUV.UIT/UIL :cal SetSyn("uil")<CR> -an 50.110.390 &Syntax.TUV.UnrealScript :cal SetSyn("uc")<CR> -an 50.110.400 &Syntax.TUV.Updatedb\.conf :cal SetSyn("updatedb")<CR> -an 50.110.420 &Syntax.TUV.Valgrind :cal SetSyn("valgrind")<CR> -an 50.110.430 &Syntax.TUV.Vera :cal SetSyn("vera")<CR> -an 50.110.440 &Syntax.TUV.Verilog-AMS\ HDL :cal SetSyn("verilogams")<CR> -an 50.110.450 &Syntax.TUV.Verilog\ HDL :cal SetSyn("verilog")<CR> -an 50.110.460 &Syntax.TUV.Vgrindefs :cal SetSyn("vgrindefs")<CR> -an 50.110.470 &Syntax.TUV.VHDL :cal SetSyn("vhdl")<CR> -an 50.110.480 &Syntax.TUV.Vim.Vim\ help\ file :cal SetSyn("help")<CR> -an 50.110.490 &Syntax.TUV.Vim.Vim\ script :cal SetSyn("vim")<CR> -an 50.110.500 &Syntax.TUV.Vim.Viminfo\ file :cal SetSyn("viminfo")<CR> -an 50.110.510 &Syntax.TUV.Virata\ config :cal SetSyn("virata")<CR> -an 50.110.520 &Syntax.TUV.Visual\ Basic :cal SetSyn("vb")<CR> -an 50.110.530 &Syntax.TUV.VOS\ CM\ macro :cal SetSyn("voscm")<CR> -an 50.110.540 &Syntax.TUV.VRML :cal SetSyn("vrml")<CR> -an 50.110.550 &Syntax.TUV.VSE\ JCL :cal SetSyn("vsejcl")<CR> -an 50.120.100 &Syntax.WXYZ.WEB.CWEB :cal SetSyn("cweb")<CR> -an 50.120.110 &Syntax.WXYZ.WEB.WEB :cal SetSyn("web")<CR> -an 50.120.120 &Syntax.WXYZ.WEB.WEB\ Changes :cal SetSyn("change")<CR> -an 50.120.130 &Syntax.WXYZ.Webmacro :cal SetSyn("webmacro")<CR> -an 50.120.140 &Syntax.WXYZ.Website\ MetaLanguage :cal SetSyn("wml")<CR> -an 50.120.160 &Syntax.WXYZ.wDiff :cal SetSyn("wdiff")<CR> -an 50.120.180 &Syntax.WXYZ.Wget\ config :cal SetSyn("wget")<CR> -an 50.120.190 &Syntax.WXYZ.Whitespace\ (add) :cal SetSyn("whitespace")<CR> -an 50.120.200 &Syntax.WXYZ.WildPackets\ EtherPeek\ Decoder :cal SetSyn("dcd")<CR> -an 50.120.210 &Syntax.WXYZ.WinBatch/Webbatch :cal SetSyn("winbatch")<CR> -an 50.120.220 &Syntax.WXYZ.Windows\ Scripting\ Host :cal SetSyn("wsh")<CR> -an 50.120.230 &Syntax.WXYZ.WSML :cal SetSyn("wsml")<CR> -an 50.120.240 &Syntax.WXYZ.WvDial :cal SetSyn("wvdial")<CR> -an 50.120.260 &Syntax.WXYZ.X\ Keyboard\ Extension :cal SetSyn("xkb")<CR> -an 50.120.270 &Syntax.WXYZ.X\ Pixmap :cal SetSyn("xpm")<CR> -an 50.120.280 &Syntax.WXYZ.X\ Pixmap\ (2) :cal SetSyn("xpm2")<CR> -an 50.120.290 &Syntax.WXYZ.X\ resources :cal SetSyn("xdefaults")<CR> -an 50.120.300 &Syntax.WXYZ.XBL :cal SetSyn("xbl")<CR> -an 50.120.310 &Syntax.WXYZ.Xinetd\.conf :cal SetSyn("xinetd")<CR> -an 50.120.320 &Syntax.WXYZ.Xmodmap :cal SetSyn("xmodmap")<CR> -an 50.120.330 &Syntax.WXYZ.Xmath :cal SetSyn("xmath")<CR> -an 50.120.340 &Syntax.WXYZ.XML :cal SetSyn("xml")<CR> -an 50.120.350 &Syntax.WXYZ.XML\ Schema\ (XSD) :cal SetSyn("xsd")<CR> -an 50.120.360 &Syntax.WXYZ.XQuery :cal SetSyn("xquery")<CR> -an 50.120.370 &Syntax.WXYZ.Xslt :cal SetSyn("xslt")<CR> -an 50.120.380 &Syntax.WXYZ.XFree86\ Config :cal SetSyn("xf86conf")<CR> -an 50.120.400 &Syntax.WXYZ.YAML :cal SetSyn("yaml")<CR> -an 50.120.410 &Syntax.WXYZ.Yacc :cal SetSyn("yacc")<CR> - -" The End Of The Syntax Menu - - -an 50.195 &Syntax.-SEP1- <Nop> - -an <silent> 50.200 &Syntax.Set\ '&syntax'\ only :call <SID>Setsynonly()<CR> -fun! s:Setsynonly() - let s:syntax_menu_synonly = 1 -endfun -an <silent> 50.202 &Syntax.Set\ '&filetype'\ too :call <SID>Nosynonly()<CR> -fun! s:Nosynonly() - if exists("s:syntax_menu_synonly") - unlet s:syntax_menu_synonly - endif -endfun - -" Restore 'cpoptions' -let &cpo = s:cpo_save -unlet s:cpo_save diff --git a/share/vim/vim72/syntax/2html.vim b/share/vim/vim72/syntax/2html.vim deleted file mode 100644 index ee66bf644d..0000000000 --- a/share/vim/vim72/syntax/2html.vim +++ /dev/null @@ -1,546 +0,0 @@ -" Vim syntax support file -" Maintainer: Bram Moolenaar <Bram@vim.org> -" Last Change: 2008 Jul 17 -" (modified by David Ne\v{c}as (Yeti) <yeti@physics.muni.cz>) -" (XHTML support by Panagiotis Issaris <takis@lumumba.luc.ac.be>) -" (made w3 compliant by Edd Barrett <vext01@gmail.com>) -" (added html_font. Edd Barrett <vext01@gmail.com>) - -" Transform a file into HTML, using the current syntax highlighting. - -" Number lines when explicitely requested or when `number' is set -if exists("html_number_lines") - let s:numblines = html_number_lines -else - let s:numblines = &number -endif - -" Font -if exists("html_font") - let s:htmlfont = html_font . ", monospace" -else - let s:htmlfont = "monospace" -endif - -" When not in gui we can only guess the colors. -if has("gui_running") - let s:whatterm = "gui" -else - let s:whatterm = "cterm" - if &t_Co == 8 - let s:cterm_color = {0: "#808080", 1: "#ff6060", 2: "#00ff00", 3: "#ffff00", 4: "#8080ff", 5: "#ff40ff", 6: "#00ffff", 7: "#ffffff"} - else - let s:cterm_color = {0: "#000000", 1: "#c00000", 2: "#008000", 3: "#804000", 4: "#0000c0", 5: "#c000c0", 6: "#008080", 7: "#c0c0c0", 8: "#808080", 9: "#ff6060", 10: "#00ff00", 11: "#ffff00", 12: "#8080ff", 13: "#ff40ff", 14: "#00ffff", 15: "#ffffff"} - - " Colors for 88 and 256 come from xterm. - if &t_Co == 88 - call extend(s:cterm_color, {16: "#000000", 17: "#00008b", 18: "#0000cd", 19: "#0000ff", 20: "#008b00", 21: "#008b8b", 22: "#008bcd", 23: "#008bff", 24: "#00cd00", 25: "#00cd8b", 26: "#00cdcd", 27: "#00cdff", 28: "#00ff00", 29: "#00ff8b", 30: "#00ffcd", 31: "#00ffff", 32: "#8b0000", 33: "#8b008b", 34: "#8b00cd", 35: "#8b00ff", 36: "#8b8b00", 37: "#8b8b8b", 38: "#8b8bcd", 39: "#8b8bff", 40: "#8bcd00", 41: "#8bcd8b", 42: "#8bcdcd", 43: "#8bcdff", 44: "#8bff00", 45: "#8bff8b", 46: "#8bffcd", 47: "#8bffff", 48: "#cd0000", 49: "#cd008b", 50: "#cd00cd", 51: "#cd00ff", 52: "#cd8b00", 53: "#cd8b8b", 54: "#cd8bcd", 55: "#cd8bff", 56: "#cdcd00", 57: "#cdcd8b", 58: "#cdcdcd", 59: "#cdcdff", 60: "#cdff00", 61: "#cdff8b", 62: "#cdffcd", 63: "#cdffff", 64: "#ff0000"}) - call extend(s:cterm_color, {65: "#ff008b", 66: "#ff00cd", 67: "#ff00ff", 68: "#ff8b00", 69: "#ff8b8b", 70: "#ff8bcd", 71: "#ff8bff", 72: "#ffcd00", 73: "#ffcd8b", 74: "#ffcdcd", 75: "#ffcdff", 76: "#ffff00", 77: "#ffff8b", 78: "#ffffcd", 79: "#ffffff", 80: "#2e2e2e", 81: "#5c5c5c", 82: "#737373", 83: "#8b8b8b", 84: "#a2a2a2", 85: "#b9b9b9", 86: "#d0d0d0", 87: "#e7e7e7"}) - elseif &t_Co == 256 - call extend(s:cterm_color, {16: "#000000", 17: "#00005f", 18: "#000087", 19: "#0000af", 20: "#0000d7", 21: "#0000ff", 22: "#005f00", 23: "#005f5f", 24: "#005f87", 25: "#005faf", 26: "#005fd7", 27: "#005fff", 28: "#008700", 29: "#00875f", 30: "#008787", 31: "#0087af", 32: "#0087d7", 33: "#0087ff", 34: "#00af00", 35: "#00af5f", 36: "#00af87", 37: "#00afaf", 38: "#00afd7", 39: "#00afff", 40: "#00d700", 41: "#00d75f", 42: "#00d787", 43: "#00d7af", 44: "#00d7d7", 45: "#00d7ff", 46: "#00ff00", 47: "#00ff5f", 48: "#00ff87", 49: "#00ffaf", 50: "#00ffd7", 51: "#00ffff", 52: "#5f0000", 53: "#5f005f", 54: "#5f0087", 55: "#5f00af", 56: "#5f00d7", 57: "#5f00ff", 58: "#5f5f00", 59: "#5f5f5f", 60: "#5f5f87", 61: "#5f5faf", 62: "#5f5fd7", 63: "#5f5fff", 64: "#5f8700"}) - call extend(s:cterm_color, {65: "#5f875f", 66: "#5f8787", 67: "#5f87af", 68: "#5f87d7", 69: "#5f87ff", 70: "#5faf00", 71: "#5faf5f", 72: "#5faf87", 73: "#5fafaf", 74: "#5fafd7", 75: "#5fafff", 76: "#5fd700", 77: "#5fd75f", 78: "#5fd787", 79: "#5fd7af", 80: "#5fd7d7", 81: "#5fd7ff", 82: "#5fff00", 83: "#5fff5f", 84: "#5fff87", 85: "#5fffaf", 86: "#5fffd7", 87: "#5fffff", 88: "#870000", 89: "#87005f", 90: "#870087", 91: "#8700af", 92: "#8700d7", 93: "#8700ff", 94: "#875f00", 95: "#875f5f", 96: "#875f87", 97: "#875faf", 98: "#875fd7", 99: "#875fff", 100: "#878700", 101: "#87875f", 102: "#878787", 103: "#8787af", 104: "#8787d7", 105: "#8787ff", 106: "#87af00", 107: "#87af5f", 108: "#87af87", 109: "#87afaf", 110: "#87afd7", 111: "#87afff", 112: "#87d700"}) - call extend(s:cterm_color, {113: "#87d75f", 114: "#87d787", 115: "#87d7af", 116: "#87d7d7", 117: "#87d7ff", 118: "#87ff00", 119: "#87ff5f", 120: "#87ff87", 121: "#87ffaf", 122: "#87ffd7", 123: "#87ffff", 124: "#af0000", 125: "#af005f", 126: "#af0087", 127: "#af00af", 128: "#af00d7", 129: "#af00ff", 130: "#af5f00", 131: "#af5f5f", 132: "#af5f87", 133: "#af5faf", 134: "#af5fd7", 135: "#af5fff", 136: "#af8700", 137: "#af875f", 138: "#af8787", 139: "#af87af", 140: "#af87d7", 141: "#af87ff", 142: "#afaf00", 143: "#afaf5f", 144: "#afaf87", 145: "#afafaf", 146: "#afafd7", 147: "#afafff", 148: "#afd700", 149: "#afd75f", 150: "#afd787", 151: "#afd7af", 152: "#afd7d7", 153: "#afd7ff", 154: "#afff00", 155: "#afff5f", 156: "#afff87", 157: "#afffaf", 158: "#afffd7"}) - call extend(s:cterm_color, {159: "#afffff", 160: "#d70000", 161: "#d7005f", 162: "#d70087", 163: "#d700af", 164: "#d700d7", 165: "#d700ff", 166: "#d75f00", 167: "#d75f5f", 168: "#d75f87", 169: "#d75faf", 170: "#d75fd7", 171: "#d75fff", 172: "#d78700", 173: "#d7875f", 174: "#d78787", 175: "#d787af", 176: "#d787d7", 177: "#d787ff", 178: "#d7af00", 179: "#d7af5f", 180: "#d7af87", 181: "#d7afaf", 182: "#d7afd7", 183: "#d7afff", 184: "#d7d700", 185: "#d7d75f", 186: "#d7d787", 187: "#d7d7af", 188: "#d7d7d7", 189: "#d7d7ff", 190: "#d7ff00", 191: "#d7ff5f", 192: "#d7ff87", 193: "#d7ffaf", 194: "#d7ffd7", 195: "#d7ffff", 196: "#ff0000", 197: "#ff005f", 198: "#ff0087", 199: "#ff00af", 200: "#ff00d7", 201: "#ff00ff", 202: "#ff5f00", 203: "#ff5f5f", 204: "#ff5f87"}) - call extend(s:cterm_color, {205: "#ff5faf", 206: "#ff5fd7", 207: "#ff5fff", 208: "#ff8700", 209: "#ff875f", 210: "#ff8787", 211: "#ff87af", 212: "#ff87d7", 213: "#ff87ff", 214: "#ffaf00", 215: "#ffaf5f", 216: "#ffaf87", 217: "#ffafaf", 218: "#ffafd7", 219: "#ffafff", 220: "#ffd700", 221: "#ffd75f", 222: "#ffd787", 223: "#ffd7af", 224: "#ffd7d7", 225: "#ffd7ff", 226: "#ffff00", 227: "#ffff5f", 228: "#ffff87", 229: "#ffffaf", 230: "#ffffd7", 231: "#ffffff", 232: "#080808", 233: "#121212", 234: "#1c1c1c", 235: "#262626", 236: "#303030", 237: "#3a3a3a", 238: "#444444", 239: "#4e4e4e", 240: "#585858", 241: "#626262", 242: "#6c6c6c", 243: "#767676", 244: "#808080", 245: "#8a8a8a", 246: "#949494", 247: "#9e9e9e", 248: "#a8a8a8", 249: "#b2b2b2", 250: "#bcbcbc", 251: "#c6c6c6", 252: "#d0d0d0", 253: "#dadada", 254: "#e4e4e4", 255: "#eeeeee"}) - endif - endif -endif - -" Return good color specification: in GUI no transformation is done, in -" terminal return RGB values of known colors and empty string for unknown -if s:whatterm == "gui" - function! s:HtmlColor(color) - return a:color - endfun -else - function! s:HtmlColor(color) - if has_key(s:cterm_color, a:color) - return s:cterm_color[a:color] - else - return "" - endif - endfun -endif - -if !exists("html_use_css") - " Return opening HTML tag for given highlight id - function! s:HtmlOpening(id) - let a = "" - if synIDattr(a:id, "inverse") - " For inverse, we always must set both colors (and exchange them) - let x = s:HtmlColor(synIDattr(a:id, "fg#", s:whatterm)) - let a = a . '<span style="background-color: ' . ( x != "" ? x : s:fgc ) . '">' - let x = s:HtmlColor(synIDattr(a:id, "bg#", s:whatterm)) - let a = a . '<font color="' . ( x != "" ? x : s:bgc ) . '">' - else - let x = s:HtmlColor(synIDattr(a:id, "bg#", s:whatterm)) - if x != "" | let a = a . '<span style="background-color: ' . x . '">' | endif - let x = s:HtmlColor(synIDattr(a:id, "fg#", s:whatterm)) - if x != "" | let a = a . '<font color="' . x . '">' | endif - endif - if synIDattr(a:id, "bold") | let a = a . "<b>" | endif - if synIDattr(a:id, "italic") | let a = a . "<i>" | endif - if synIDattr(a:id, "underline") | let a = a . "<u>" | endif - return a - endfun - - " Return closing HTML tag for given highlight id - function s:HtmlClosing(id) - let a = "" - if synIDattr(a:id, "underline") | let a = a . "</u>" | endif - if synIDattr(a:id, "italic") | let a = a . "</i>" | endif - if synIDattr(a:id, "bold") | let a = a . "</b>" | endif - if synIDattr(a:id, "inverse") - let a = a . '</font></span>' - else - let x = s:HtmlColor(synIDattr(a:id, "fg#", s:whatterm)) - if x != "" | let a = a . '</font>' | endif - let x = s:HtmlColor(synIDattr(a:id, "bg#", s:whatterm)) - if x != "" | let a = a . '</span>' | endif - endif - return a - endfun -endif - -" Return HTML valid characters enclosed in a span of class style_name with -" unprintable characters expanded and double spaces replaced as necessary. -function! s:HtmlFormat(text, style_name) - " Replace unprintable characters - let formatted = strtrans(a:text) - - " Replace the reserved html characters - let formatted = substitute(substitute(substitute(substitute(substitute(formatted, '&', '\&', 'g'), '<', '\<', 'g'), '>', '\>', 'g'), '"', '\"', 'g'), "\x0c", '<hr class="PAGE-BREAK">', 'g') - - " Replace double spaces and leading spaces - if ' ' != s:HtmlSpace - let formatted = substitute(formatted, ' ', s:HtmlSpace . s:HtmlSpace, 'g') - let formatted = substitute(formatted, '^ ', s:HtmlSpace, 'g') - endif - - " Enclose in a span of class style_name - let formatted = '<span class="' . a:style_name . '">' . formatted . '</span>' - - " Add the class to class list if it's not there yet - let s:id = hlID(a:style_name) - if stridx(s:idlist, "," . s:id . ",") == -1 - let s:idlist = s:idlist . s:id . "," - endif - - return formatted -endfun - -" Return CSS style describing given highlight id (can be empty) -function! s:CSS1(id) - let a = "" - if synIDattr(a:id, "inverse") - " For inverse, we always must set both colors (and exchange them) - let x = s:HtmlColor(synIDattr(a:id, "bg#", s:whatterm)) - let a = a . "color: " . ( x != "" ? x : s:bgc ) . "; " - let x = s:HtmlColor(synIDattr(a:id, "fg#", s:whatterm)) - let a = a . "background-color: " . ( x != "" ? x : s:fgc ) . "; " - else - let x = s:HtmlColor(synIDattr(a:id, "fg#", s:whatterm)) - if x != "" | let a = a . "color: " . x . "; " | endif - let x = s:HtmlColor(synIDattr(a:id, "bg#", s:whatterm)) - if x != "" | let a = a . "background-color: " . x . "; " | endif - endif - if synIDattr(a:id, "bold") | let a = a . "font-weight: bold; " | endif - if synIDattr(a:id, "italic") | let a = a . "font-style: italic; " | endif - if synIDattr(a:id, "underline") | let a = a . "text-decoration: underline; " | endif - return a -endfun - -" Figure out proper MIME charset from the 'encoding' option. -if exists("html_use_encoding") - let s:html_encoding = html_use_encoding -else - let s:vim_encoding = &encoding - if s:vim_encoding =~ '^8bit\|^2byte' - let s:vim_encoding = substitute(s:vim_encoding, '^8bit-\|^2byte-', '', '') - endif - if s:vim_encoding == 'latin1' - let s:html_encoding = 'iso-8859-1' - elseif s:vim_encoding =~ "^cp12" - let s:html_encoding = substitute(s:vim_encoding, 'cp', 'windows-', '') - elseif s:vim_encoding == 'sjis' || s:vim_encoding == 'cp932' - let s:html_encoding = 'Shift_JIS' - elseif s:vim_encoding == 'big5' || s:vim_encoding == 'cp950' - let s:html_encoding = "Big5" - elseif s:vim_encoding == 'euc-cn' - let s:html_encoding = 'GB_2312-80' - elseif s:vim_encoding == 'euc-tw' - let s:html_encoding = "" - elseif s:vim_encoding =~ '^euc\|^iso\|^koi' - let s:html_encoding = substitute(s:vim_encoding, '.*', '\U\0', '') - elseif s:vim_encoding == 'cp949' - let s:html_encoding = 'KS_C_5601-1987' - elseif s:vim_encoding == 'cp936' - let s:html_encoding = 'GBK' - elseif s:vim_encoding =~ '^ucs\|^utf' - let s:html_encoding = 'UTF-8' - else - let s:html_encoding = "" - endif -endif - - -" Set some options to make it work faster. -" Don't report changes for :substitute, there will be many of them. -let s:old_title = &title -let s:old_icon = &icon -let s:old_et = &l:et -let s:old_report = &report -let s:old_search = @/ -set notitle noicon -setlocal et -set report=1000000 - -" Split window to create a buffer with the HTML file. -let s:orgbufnr = winbufnr(0) -if expand("%") == "" - new Untitled.html -else - new %.html -endif -let s:newwin = winnr() -let s:orgwin = bufwinnr(s:orgbufnr) - -set modifiable -%d -let s:old_paste = &paste -set paste -let s:old_magic = &magic -set magic - -if exists("use_xhtml") - if s:html_encoding != "" - exe "normal! a<?xml version=\"1.0\" encoding=\"" . s:html_encoding . "\"?>\n\e" - else - exe "normal! a<?xml version=\"1.0\"?>\n\e" - endif - let s:tag_close = ' />' -else - let s:tag_close = '>' -endif - -" Cache html_no_pre incase we have to turn it on for non-css mode -if exists("html_no_pre") - let s:old_html_no_pre = html_no_pre -endif - -if !exists("html_use_css") - " Cant put font tags in <pre> - let html_no_pre=1 -endif - -let s:HtmlSpace = ' ' -let s:LeadingSpace = ' ' -let s:HtmlEndline = '' -if exists("html_no_pre") - let s:HtmlEndline = '<br' . s:tag_close - let s:LeadingSpace = ' ' - let s:HtmlSpace = '\' . s:LeadingSpace -endif - -" HTML header, with the title and generator ;-). Left free space for the CSS, -" to be filled at the end. -exe "normal! a<html>\n\e" -exe "normal! a<head>\n<title>" . expand("%:p:~") . "\n\e" -exe "normal! a\n\n\n\e" -endif -if exists("html_no_pre") - exe "normal! a\n\n\e" -else - exe "normal! a\n\n
\n\e"
-endif
-
-exe s:orgwin . "wincmd w"
-
-" List of all id's
-let s:idlist = ","
-
-" Loop over all lines in the original text.
-" Use html_start_line and html_end_line if they are set.
-if exists("html_start_line")
-  let s:lnum = html_start_line
-  if s:lnum < 1 || s:lnum > line("$")
-    let s:lnum = 1
-  endif
-else
-  let s:lnum = 1
-endif
-if exists("html_end_line")
-  let s:end = html_end_line
-  if s:end < s:lnum || s:end > line("$")
-    let s:end = line("$")
-  endif
-else
-  let s:end = line("$")
-endif
-
-if has('folding') && !exists('html_ignore_folding')
-  let s:foldfillchar = &fillchars[matchend(&fillchars, 'fold:')]
-  if s:foldfillchar == ''
-    let s:foldfillchar = '-'
-  endif
-endif
-let s:difffillchar = &fillchars[matchend(&fillchars, 'diff:')]
-if s:difffillchar == ''
-  let s:difffillchar = '-'
-endif
-
-
-while s:lnum <= s:end
-
-  " If there are filler lines for diff mode, show these above the line.
-  let s:filler = diff_filler(s:lnum)
-  if s:filler > 0
-    let s:n = s:filler
-    while s:n > 0
-      if s:numblines
-	" Indent if line numbering is on
-	let s:new = repeat(s:LeadingSpace, strlen(s:end) + 1) . repeat(s:difffillchar, 3)
-      else
-	let s:new = repeat(s:difffillchar, 3)
-      endif
-
-      if s:n > 2 && s:n < s:filler && !exists("html_whole_filler")
-	let s:new = s:new . " " . s:filler . " inserted lines "
-	let s:n = 2
-      endif
-
-      if !exists("html_no_pre")
-	" HTML line wrapping is off--go ahead and fill to the margin
-	let s:new = s:new . repeat(s:difffillchar, &columns - strlen(s:new))
-      endif
-
-      let s:new = s:HtmlFormat(s:new, "DiffDelete")
-      exe s:newwin . "wincmd w"
-      exe "normal! a" . s:new . s:HtmlEndline . "\n\e"
-      exe s:orgwin . "wincmd w"
-
-      let s:n = s:n - 1
-    endwhile
-    unlet s:n
-  endif
-  unlet s:filler
-
-  " Start the line with the line number.
-  if s:numblines
-    let s:new = repeat(' ', strlen(s:end) - strlen(s:lnum)) . s:lnum . ' '
-  else
-    let s:new = ""
-  endif
-
-  if has('folding') && !exists('html_ignore_folding') && foldclosed(s:lnum) > -1
-    "
-    " This is the beginning of a folded block
-    "
-    let s:new = s:new . foldtextresult(s:lnum)
-    if !exists("html_no_pre")
-      " HTML line wrapping is off--go ahead and fill to the margin
-      let s:new = s:new . repeat(s:foldfillchar, &columns - strlen(s:new))
-    endif
-
-    let s:new = s:HtmlFormat(s:new, "Folded")
-
-    " Skip to the end of the fold
-    let s:lnum = foldclosedend(s:lnum)
-
-  else
-    "
-    " A line that is not folded.
-    "
-    let s:line = getline(s:lnum)
-
-    let s:len = strlen(s:line)
-
-    if s:numblines
-      let s:new = s:HtmlFormat(s:new, "lnr")
-    endif
-
-    " Get the diff attribute, if any.
-    let s:diffattr = diff_hlID(s:lnum, 1)
-
-    " Loop over each character in the line
-    let s:col = 1
-    while s:col <= s:len || (s:col == 1 && s:diffattr)
-      let s:startcol = s:col " The start column for processing text
-      if s:diffattr
-	let s:id = diff_hlID(s:lnum, s:col)
-	let s:col = s:col + 1
-	" Speed loop (it's small - that's the trick)
-	" Go along till we find a change in hlID
-	while s:col <= s:len && s:id == diff_hlID(s:lnum, s:col) | let s:col = s:col + 1 | endwhile
-	if s:len < &columns && !exists("html_no_pre")
-	  " Add spaces at the end to mark the changed line.
-	  let s:line = s:line . repeat(' ', &columns - s:len)
-	  let s:len = &columns
-	endif
-      else
-	let s:id = synID(s:lnum, s:col, 1)
-	let s:col = s:col + 1
-	" Speed loop (it's small - that's the trick)
-	" Go along till we find a change in synID
-	while s:col <= s:len && s:id == synID(s:lnum, s:col, 1) | let s:col = s:col + 1 | endwhile
-      endif
-
-      " Expand tabs
-      let s:expandedtab = strpart(s:line, s:startcol - 1, s:col - s:startcol)
-      let idx = stridx(s:expandedtab, "\t")
-      while idx >= 0
-	let i = &ts - ((idx + s:startcol - 1) % &ts)
-	let s:expandedtab = substitute(s:expandedtab, '\t', repeat(' ', i), '')
-	let idx = stridx(s:expandedtab, "\t")
-      endwhile
-
-      " Output the text with the same synID, with class set to {s:id_name}
-      let s:id = synIDtrans(s:id)
-      let s:id_name = synIDattr(s:id, "name", s:whatterm)
-      let s:new = s:new . s:HtmlFormat(s:expandedtab,  s:id_name)
-    endwhile
-  endif
-
-  exe s:newwin . "wincmd w"
-  exe "normal! a" . s:new . s:HtmlEndline . "\n\e"
-  exe s:orgwin . "wincmd w"
-  let s:lnum = s:lnum + 1
-endwhile
-" Finish with the last line
-exe s:newwin . "wincmd w"
-
-" Close off the font tag that encapsulates the whole 
-if !exists("html_use_css")
-  exe "normal! a\e"
-endif
-
-if exists("html_no_pre")
-  exe "normal! a\n\e"
-else
-  exe "normal! a
\n\n\e" -endif - - -" Now, when we finally know which, we define the colors and styles -if exists("html_use_css") - 1;/') + if style_start > 0 && style_end > 0 + let buf_styles = getline(style_start + 1, style_end - 1) + for a_style in buf_styles + if index(style, a_style) == -1 + if diff_style_start == 0 + if a_style =~ '\?,$d_ + let temp = getline(1,'$') + " undo deletion of start and end part + " so we can later save the file as valid html + " TODO: restore using grabbed lines if undolevel is 1? + normal 2u + if s:settings.use_css + call add(html, '
') + elseif s:settings.use_xhtml + call add(html, '
') + else + call add(html, '
') + endif + let html += temp + call add(html, '
') + + " Close this buffer + " TODO: the comment above says we're going to allow saving the file + " later...but here we discard it? + quit! + endfor + + let html[body_line_num] = body_line + + call add(html, '') + call add(html, '') + call add(html, s:body_end_line) + call add(html, '') + + let i = 1 + let name = "Diff" . (s:settings.use_xhtml ? ".xhtml" : ".html") + " Find an unused file name if current file name is already in use + while filereadable(name) + let name = substitute(name, '\d*\.x\?html$', '', '') . i . '.' . fnamemodify(copy(name), ":t:e") + let i += 1 + endwhile + exe "topleft new " . name + setlocal modifiable + + " just in case some user autocmd creates content in the new buffer, make sure + " it is empty before proceeding + %d + call append(0, html) + + if len(style) > 0 + 1 + let style_start = search('^')-1 + + " Insert javascript to toggle matching folds open and closed in all windows, + " if dynamic folding is active. + if s:settings.dynamic_folds + call append(style_start, [ + \ "" + \ ]) + endif + + " Insert styles from all the generated html documents and additional styles + " for the table-based layout of the side-by-side diff. The diff should take + " up the full browser window (but not more), and be static in size, + " horizontally scrollable when the lines are too long. Otherwise, the diff + " is pretty useless for really long lines. + if s:settings.use_css + call append(style_start, + \ ['' + \ ]) + endif + endif + + let &paste = s:old_paste + let &magic = s:old_magic +endfunc + +" Gets a single user option and sets it in the passed-in Dict, or gives it the +" default value if the option doesn't actually exist. +func! tohtml#GetOption(settings, option, default) + if exists('g:html_'.a:option) + let a:settings[a:option] = g:html_{a:option} + else + let a:settings[a:option] = a:default + endif +endfunc + +" returns a Dict containing the values of all user options for 2html, including +" default values for those not given an explicit value by the user. Discards the +" html_ prefix of the option for nicer looking code. +func! tohtml#GetUserSettings() + if exists('s:settings') + " just restore the known options if we've already retrieved them + return s:settings + else + " otherwise figure out which options are set + let user_settings = {} + + " Define the correct option if the old option name exists and we haven't + " already defined the correct one. Maybe I'll put out a warnig message about + " this sometime and remove the old option entirely at some even later time, + " but for now just silently accept the old option. + if exists('g:use_xhtml') && !exists("g:html_use_xhtml") + let g:html_use_xhtml = g:use_xhtml + endif + + " get current option settings with appropriate defaults + call tohtml#GetOption(user_settings, 'no_progress', !has("statusline") ) + call tohtml#GetOption(user_settings, 'diff_one_file', 0 ) + call tohtml#GetOption(user_settings, 'number_lines', &number ) + call tohtml#GetOption(user_settings, 'use_css', 1 ) + call tohtml#GetOption(user_settings, 'ignore_conceal', 0 ) + call tohtml#GetOption(user_settings, 'ignore_folding', 0 ) + call tohtml#GetOption(user_settings, 'dynamic_folds', 0 ) + call tohtml#GetOption(user_settings, 'no_foldcolumn', 0 ) + call tohtml#GetOption(user_settings, 'hover_unfold', 0 ) + call tohtml#GetOption(user_settings, 'no_pre', 0 ) + call tohtml#GetOption(user_settings, 'whole_filler', 0 ) + call tohtml#GetOption(user_settings, 'use_xhtml', 0 ) + + " override those settings that need it + + " hover opening implies dynamic folding + if user_settings.hover_unfold + let user_settings.dynamic_folds = 1 + endif + + " ignore folding overrides dynamic folding + if user_settings.ignore_folding && user_settings.dynamic_folds + let user_settings.dynamic_folds = 0 + let user_settings.hover_unfold = 0 + endif + + " dynamic folding with no foldcolumn implies hover opens + if user_settings.dynamic_folds && user_settings.no_foldcolumn + let user_settings.hover_unfold = 1 + endif + + " dynamic folding implies css + if user_settings.dynamic_folds + let user_settings.use_css = 1 + endif + + " if we're not using CSS we cannot use a pre section because tags + " aren't allowed inside a
 block
+    if !user_settings.use_css
+      let user_settings.no_pre = 1
+    endif
+
+    " Figure out proper MIME charset from the 'encoding' option.
+    if exists("g:html_use_encoding")
+      let user_settings.encoding = g:html_use_encoding
+    else
+      let vim_encoding = &encoding
+      if vim_encoding =~ '^8bit\|^2byte'
+	let vim_encoding = substitute(vim_encoding, '^8bit-\|^2byte-', '', '')
+      endif
+      if vim_encoding == 'latin1'
+	let user_settings.encoding = 'iso-8859-1'
+      elseif vim_encoding =~ "^cp12"
+	let user_settings.encoding = substitute(vim_encoding, 'cp', 'windows-', '')
+      elseif vim_encoding == 'sjis' || vim_encoding == 'cp932'
+	let user_settings.encoding = 'Shift_JIS'
+      elseif vim_encoding == 'big5' || vim_encoding == 'cp950'
+	let user_settings.encoding = "Big5"
+      elseif vim_encoding == 'euc-cn'
+	let user_settings.encoding = 'GB_2312-80'
+      elseif vim_encoding == 'euc-tw'
+	let user_settings.encoding = ""
+      elseif vim_encoding =~ '^euc\|^iso\|^koi'
+	let user_settings.encoding = substitute(vim_encoding, '.*', '\U\0', '')
+      elseif vim_encoding == 'cp949'
+	let user_settings.encoding = 'KS_C_5601-1987'
+      elseif vim_encoding == 'cp936'
+	let user_settings.encoding = 'GBK'
+      elseif vim_encoding =~ '^ucs\|^utf'
+	let user_settings.encoding = 'UTF-8'
+      else
+	let user_settings.encoding = ""
+      endif
+    endif
+
+    " TODO: font
+
+    return user_settings
+  endif
+endfunc
+
+let &cpo = s:cpo_sav
+unlet s:cpo_sav
+
+" Make sure any patches will probably use consistent indent
+"   vim: ts=8 sw=2 sts=2 noet
diff --git a/share/vim/vim73/autoload/vimball.vim b/share/vim/vim73/autoload/vimball.vim
new file mode 100644
index 0000000000..13e82ac49f
--- /dev/null
+++ b/share/vim/vim73/autoload/vimball.vim
@@ -0,0 +1,737 @@
+" vimball.vim : construct a file containing both paths and files
+" Author:	Charles E. Campbell, Jr.
+" Date:		Apr 12, 2010
+" Version:	31
+" GetLatestVimScripts: 1502 1 :AutoInstall: vimball.vim
+" Copyright: (c) 2004-2009 by Charles E. Campbell, Jr.
+"            The VIM LICENSE applies to Vimball.vim, and Vimball.txt
+"            (see |copyright|) except use "Vimball" instead of "Vim".
+"            No warranty, express or implied.
+"  *** ***   Use At-Your-Own-Risk!   *** ***
+
+" ---------------------------------------------------------------------
+"  Load Once: {{{1
+if &cp || exists("g:loaded_vimball")
+ finish
+endif
+let g:loaded_vimball = "v31"
+if v:version < 702
+ echohl WarningMsg
+ echo "***warning*** this version of vimball needs vim 7.2"
+ echohl Normal
+ finish
+endif
+let s:keepcpo= &cpo
+set cpo&vim
+"DechoTabOn
+
+" =====================================================================
+" Constants: {{{1
+if !exists("s:USAGE")
+ let s:USAGE   = 0
+ let s:WARNING = 1
+ let s:ERROR   = 2
+
+ " determine if cygwin is in use or not
+ if !exists("g:netrw_cygwin")
+  if has("win32") || has("win95") || has("win64") || has("win16")
+   if &shell =~ '\%(\\|\\)\%(\.exe\)\=$'
+    let g:netrw_cygwin= 1
+   else
+    let g:netrw_cygwin= 0
+   endif
+  else
+   let g:netrw_cygwin= 0
+  endif
+ endif
+
+ " set up g:vimball_mkdir if the mkdir() call isn't defined
+ if !exists("*mkdir")
+  if exists("g:netrw_local_mkdir")
+   let g:vimball_mkdir= g:netrw_local_mkdir
+  elseif executable("mkdir")
+   let g:vimball_mkdir= "mkdir"
+  elseif executable("makedir")
+   let g:vimball_mkdir= "makedir"
+  endif
+  if !exists(g:vimball_mkdir)
+   call vimball#ShowMesg(s:WARNING,"(vimball) g:vimball_mkdir undefined")
+  endif
+ endif
+endif
+
+" =====================================================================
+"  Functions: {{{1
+
+" ---------------------------------------------------------------------
+" vimball#MkVimball: creates a vimball given a list of paths to files {{{2
+" Input:
+"     line1,line2: a range of lines containing paths to files to be included in the vimball
+"     writelevel : if true, force a write to filename.vba, even if it exists
+"                  (usually accomplished with :MkVimball! ...
+"     filename   : base name of file to be created (ie. filename.vba)
+" Output: a filename.vba using vimball format:
+"     path
+"     filesize
+"     [file]
+"     path
+"     filesize
+"     [file]
+fun! vimball#MkVimball(line1,line2,writelevel,...) range
+"  call Dfunc("MkVimball(line1=".a:line1." line2=".a:line2." writelevel=".a:writelevel." vimballname<".a:1.">) a:0=".a:0)
+  if a:1 =~ '\.vim$' || a:1 =~ '\.txt$'
+   let vbname= substitute(a:1,'\.\a\{3}$','.vba','')
+  else
+   let vbname= a:1
+  endif
+  if vbname !~ '\.vba$'
+   let vbname= vbname.'.vba'
+  endif
+"  call Decho("vbname<".vbname.">")
+  if !a:writelevel && a:1 =~ '[\/]'
+   call vimball#ShowMesg(s:ERROR,"(MkVimball) vimball name<".a:1."> should not include slashes; use ! to insist")
+"   call Dret("MkVimball : vimball name<".a:1."> should not include slashes")
+   return
+  endif
+  if !a:writelevel && filereadable(vbname)
+   call vimball#ShowMesg(s:ERROR,"(MkVimball) file<".vbname."> exists; use ! to insist")
+"   call Dret("MkVimball : file<".vbname."> already exists; use ! to insist")
+   return
+  endif
+
+  " user option bypass
+  call vimball#SaveSettings()
+
+  if a:0 >= 2
+   " allow user to specify where to get the files
+   let home= expand(a:2)
+  else
+   " use first existing directory from rtp
+   let home= vimball#VimballHome()
+  endif
+
+  " save current directory
+  let curdir = getcwd()
+  call s:ChgDir(home)
+
+  " record current tab, initialize while loop index
+  let curtabnr = tabpagenr()
+  let linenr   = a:line1
+"  call Decho("curtabnr=".curtabnr)
+
+  while linenr <= a:line2
+   let svfile  = getline(linenr)
+"   call Decho("svfile<".svfile.">")
+ 
+   if !filereadable(svfile)
+    call vimball#ShowMesg(s:ERROR,"unable to read file<".svfile.">")
+	call s:ChgDir(curdir)
+	call vimball#RestoreSettings()
+"    call Dret("MkVimball")
+    return
+   endif
+ 
+   " create/switch to mkvimball tab
+   if !exists("vbtabnr")
+    tabnew
+    silent! file Vimball
+    let vbtabnr= tabpagenr()
+   else
+    exe "tabn ".vbtabnr
+   endif
+ 
+   let lastline= line("$") + 1
+   if lastline == 2 && getline("$") == ""
+	call setline(1,'" Vimball Archiver by Charles E. Campbell, Jr., Ph.D.')
+	call setline(2,'UseVimball')
+	call setline(3,'finish')
+	let lastline= line("$") + 1
+   endif
+   call setline(lastline  ,substitute(svfile,'$','	[[[1',''))
+   call setline(lastline+1,0)
+
+   " write the file from the tab
+"   call Decho("exe $r ".fnameescape(svfile))
+   exe "$r ".fnameescape(svfile)
+
+   call setline(lastline+1,line("$") - lastline - 1)
+"   call Decho("lastline=".lastline." line$=".line("$"))
+
+  " restore to normal tab
+   exe "tabn ".curtabnr
+   let linenr= linenr + 1
+  endwhile
+
+  " write the vimball
+  exe "tabn ".vbtabnr
+  call s:ChgDir(curdir)
+  setlocal ff=unix
+  if a:writelevel
+"   call Decho("exe w! ".fnameescape(vbname))
+   exe "w! ".fnameescape(vbname)
+  else
+"   call Decho("exe w ".fnameescape(vbname))
+   exe "w ".fnameescape(vbname)
+  endif
+"  call Decho("Vimball<".vbname."> created")
+  echo "Vimball<".vbname."> created"
+
+  " remove the evidence
+  setlocal nomod bh=wipe
+  exe "tabn ".curtabnr
+  exe "tabc ".vbtabnr
+
+  " restore options
+  call vimball#RestoreSettings()
+
+"  call Dret("MkVimball")
+endfun
+
+" ---------------------------------------------------------------------
+" vimball#Vimball: extract and distribute contents from a vimball {{{2
+"                  (invoked the the UseVimball command embedded in 
+"                  vimballs' prologue)
+fun! vimball#Vimball(really,...)
+"  call Dfunc("vimball#Vimball(really=".a:really.") a:0=".a:0)
+
+  if v:version < 701 || (v:version == 701 && !exists('*fnameescape'))
+   echoerr "your vim is missing the fnameescape() function"
+"   call Dret("vimball#Vimball : needs 7.1 with patch 299")
+   return
+  endif
+
+  if getline(1) !~ '^" Vimball Archiver'
+   echoerr "(Vimball) The current file does not appear to be a Vimball!"
+"   call Dret("vimball#Vimball")
+   return
+  endif
+
+  " set up standard settings
+  call vimball#SaveSettings()
+  let curtabnr    = tabpagenr()
+  let vimballfile = expand("%:tr")
+
+  " set up vimball tab
+"  call Decho("setting up vimball tab")
+  tabnew
+  silent! file Vimball
+  let vbtabnr= tabpagenr()
+  let didhelp= ""
+
+  " go to vim plugin home
+  if a:0 > 0
+   let home= expand(a:1)
+  else
+   let home= vimball#VimballHome()
+  endif
+"  call Decho("home<".home.">")
+
+  " save current directory and remove older same-named vimball, if any
+  let curdir = getcwd()
+"  call Decho("home<".home.">")
+"  call Decho("curdir<".curdir.">")
+
+  call s:ChgDir(home)
+  let s:ok_unablefind= 1
+  call vimball#RmVimball(vimballfile)
+  unlet s:ok_unablefind
+
+  let linenr  = 4
+  let filecnt = 0
+
+  " give title to listing of (extracted) files from Vimball Archive
+  if a:really
+   echohl Title     | echomsg "Vimball Archive"         | echohl None
+  else             
+   echohl Title     | echomsg "Vimball Archive Listing" | echohl None
+   echohl Statement | echomsg "files would be placed under: ".home | echohl None
+  endif
+
+  " apportion vimball contents to various files
+"  call Decho("exe tabn ".curtabnr)
+  exe "tabn ".curtabnr
+"  call Decho("linenr=".linenr." line$=".line("$"))
+  while 1 < linenr && linenr < line("$")
+   let fname   = substitute(getline(linenr),'\t\[\[\[1$','','')
+   let fname   = substitute(fname,'\\','/','g')
+"   let fsize   = getline(linenr+1)+0
+   let fsize   = substitute(getline(linenr+1),'^\(\d\+\).\{-}$','\1','')+0
+   let fenc    = substitute(getline(linenr+1),'^\d\+\s*\(\S\+\)$','\1','')
+   let filecnt = filecnt + 1
+"   call Decho("fname<".fname."> fsize=".fsize." filecnt=".filecnt)
+
+   if a:really
+    echomsg "extracted <".fname.">: ".fsize." lines"
+   else
+    echomsg "would extract <".fname.">: ".fsize." lines"
+   endif
+"   call Decho("using L#".linenr.": will extract file<".fname.">")
+"   call Decho("using L#".(linenr+1).": fsize=".fsize)
+
+   " Allow AsNeeded/ directory to take place of plugin/ directory
+   " when AsNeeded/filename is filereadable or was present in VimballRecord
+   if fname =~ '\ instead of <".fname.">")
+	 let fname= anfname
+	endif
+   endif
+
+   " make directories if they don't exist yet
+   if a:really
+"    call Decho("making directories if they don't exist yet (fname<".fname.">)")
+    let fnamebuf= substitute(fname,'\\','/','g')
+	let dirpath = substitute(home,'\\','/','g')
+    while fnamebuf =~ '/'
+     let dirname  = dirpath."/".substitute(fnamebuf,'/.*$','','')
+	 let dirpath  = dirname
+     let fnamebuf = substitute(fnamebuf,'^.\{-}/\(.*\)$','\1','')
+"	 call Decho("dirname<".dirname.">")
+     if !isdirectory(dirname)
+"      call Decho("making <".dirname.">")
+      if exists("g:vimball_mkdir")
+	   call system(g:vimball_mkdir." ".shellescape(dirname))
+      else
+       call mkdir(dirname)
+      endif
+	  call s:RecordInVar(home,"rmdir('".dirname."')")
+     endif
+    endwhile
+   endif
+   call s:ChgDir(home)
+
+   " grab specified qty of lines and place into "a" buffer
+   " (skip over path/filename and qty-lines)
+   let linenr   = linenr + 2
+   let lastline = linenr + fsize - 1
+"   call Decho("exe ".linenr.",".lastline."yank a")
+   exe "silent ".linenr.",".lastline."yank a"
+
+   " copy "a" buffer into tab
+"   call Decho('copy "a buffer into tab#'.vbtabnr)
+   exe "tabn ".vbtabnr
+   setlocal ma
+   silent! %d
+   silent put a
+   1
+   silent d
+
+   " write tab to file
+   if a:really
+    let fnamepath= home."/".fname
+"    call Decho("exe w! ".fnameescape(fnamepath))
+	if fenc != ""
+	 exe "silent w! ++enc=".fnameescape(fenc)." ".fnameescape(fnamepath)
+	else
+	 exe "silent w! ".fnameescape(fnamepath)
+	endif
+	echo "wrote ".fnameescape(fnamepath)
+	call s:RecordInVar(home,"call delete('".fnamepath."')")
+   endif
+
+   " return to tab with vimball
+"   call Decho("exe tabn ".curtabnr)
+   exe "tabn ".curtabnr
+
+   " set up help if its a doc/*.txt file
+"   call Decho("didhelp<".didhelp."> fname<".fname.">")
+   if a:really && didhelp == "" && fname =~ 'doc/[^/]\+\.\(txt\|..x\)$'
+   	let didhelp= substitute(fname,'^\(.*\")
+   endif
+
+   " update for next file
+"   call Decho("update linenr= [linenr=".linenr."] + [fsize=".fsize."] = ".(linenr+fsize))
+   let linenr= linenr + fsize
+  endwhile
+
+  " set up help
+"  call Decho("about to set up help: didhelp<".didhelp.">")
+  if didhelp != ""
+   let htpath= home."/".didhelp
+"   call Decho("exe helptags ".htpath)
+   exe "helptags ".fnameescape(htpath)
+   echo "did helptags"
+  endif
+
+  " make sure a "Press ENTER..." prompt appears to keep the messages showing!
+  while filecnt <= &ch
+   echomsg " "
+   let filecnt= filecnt + 1
+  endwhile
+
+  " record actions in <.VimballRecord>
+  call s:RecordInFile(home)
+
+  " restore events, delete tab and buffer
+  exe "tabn ".vbtabnr
+  setlocal nomod bh=wipe
+  exe "tabn ".curtabnr
+  exe "tabc ".vbtabnr
+  call vimball#RestoreSettings()
+  call s:ChgDir(curdir)
+
+"  call Dret("vimball#Vimball")
+endfun
+
+" ---------------------------------------------------------------------
+" vimball#RmVimball: remove any files, remove any directories made by any {{{2
+"               previous vimball extraction based on a file of the current
+"               name.
+"  Usage:  RmVimball  (assume current file is a vimball; remove)
+"          RmVimball vimballname
+fun! vimball#RmVimball(...)
+"  call Dfunc("vimball#RmVimball() a:0=".a:0)
+  if exists("g:vimball_norecord")
+"   call Dret("vimball#RmVimball : (g:vimball_norecord)")
+   return
+  endif
+
+  if a:0 == 0
+   let curfile= expand("%:tr")
+"   call Decho("case a:0=0: curfile<".curfile."> (used expand(%:tr))")
+  else
+   if a:1 =~ '[\/]'
+    call vimball#ShowMesg(s:USAGE,"RmVimball vimballname [path]")
+"    call Dret("vimball#RmVimball : suspect a:1<".a:1.">")
+    return
+   endif
+   let curfile= a:1
+"   call Decho("case a:0=".a:0.": curfile<".curfile.">")
+  endif
+  if curfile =~ '\.vba$'
+   let curfile= substitute(curfile,'\.vba','','')
+  endif
+  if a:0 >= 2
+   let home= expand(a:2)
+  else
+   let home= vimball#VimballHome()
+  endif
+  let curdir = getcwd()
+"  call Decho("home   <".home.">")
+"  call Decho("curfile<".curfile.">")
+"  call Decho("curdir <".curdir.">")
+
+  call s:ChgDir(home)
+  if filereadable(".VimballRecord")
+"   call Decho(".VimballRecord is readable")
+"   call Decho("curfile<".curfile.">")
+   keepalt keepjumps 1split 
+   silent! keepalt keepjumps e .VimballRecord
+   let keepsrch= @/
+"   call Decho('search for ^\M'.curfile.'.\m: ')
+"   call Decho('search for ^\M'.curfile.'.\mvba: ')
+"   call Decho('search for ^\M'.curfile.'\m[-0-9.]*\.vba: ')
+   if search('^\M'.curfile."\m: ".'cw')
+	let foundit= 1
+   elseif search('^\M'.curfile.".\mvba: ",'cw')
+	let foundit= 1
+   elseif search('^\M'.curfile.'\m[-0-9.]*\.vba: ','cw')
+	let foundit= 1
+   else
+    let foundit = 0
+   endif
+   if foundit
+	let exestring  = substitute(getline("."),'^\M'.curfile.'\m\S\{-}\.vba: ','','')
+    let s:VBRstring= substitute(exestring,'call delete(','','g')
+    let s:VBRstring= substitute(s:VBRstring,"[')]",'','g')
+"	call Decho("exe ".exestring)
+	silent! keepalt keepjumps exe exestring
+	silent! keepalt keepjumps d
+	let exestring= strlen(substitute(exestring,'call delete(.\{-})|\=',"D","g"))
+"	call Decho("exestring<".exestring.">")
+	echomsg "removed ".exestring." files"
+   else
+    let s:VBRstring= ''
+	let curfile    = substitute(curfile,'\.vba','','')
+"    call Decho("unable to find <".curfile."> in .VimballRecord")
+	if !exists("s:ok_unablefind")
+     call vimball#ShowMesg(s:WARNING,"(RmVimball) unable to find <".curfile."> in .VimballRecord")
+	endif
+   endif
+   silent! keepalt keepjumps g/^\s*$/d
+   silent! keepalt keepjumps wq!
+   let @/= keepsrch
+  endif
+  call s:ChgDir(curdir)
+
+"  call Dret("vimball#RmVimball")
+endfun
+
+" ---------------------------------------------------------------------
+" vimball#Decompress: attempts to automatically decompress vimballs {{{2
+fun! vimball#Decompress(fname,...)
+"  call Dfunc("Decompress(fname<".a:fname.">) a:0=".a:0)
+
+  " decompression:
+  if     expand("%") =~ '.*\.gz'  && executable("gunzip")
+   " handle *.gz with gunzip
+   silent exe "!gunzip ".shellescape(a:fname)
+   if v:shell_error != 0
+	call vimball#ShowMesg(s:WARNING,"(vimball#Decompress) gunzip may have failed with <".a:fname.">")
+   endif
+   let fname= substitute(a:fname,'\.gz$','','')
+   exe "e ".escape(fname,' \')
+   if a:0 == 0| call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") | endif
+
+  elseif expand("%") =~ '.*\.gz' && executable("gzip")
+   " handle *.gz with gzip -d
+   silent exe "!gzip -d ".shellescape(a:fname)
+   if v:shell_error != 0
+	call vimball#ShowMesg(s:WARNING,'(vimball#Decompress) "gzip -d" may have failed with <'.a:fname.">")
+   endif
+   let fname= substitute(a:fname,'\.gz$','','')
+   exe "e ".escape(fname,' \')
+   if a:0 == 0| call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") | endif
+
+  elseif expand("%") =~ '.*\.bz2' && executable("bunzip2")
+   " handle *.bz2 with bunzip2
+   silent exe "!bunzip2 ".shellescape(a:fname)
+   if v:shell_error != 0
+	call vimball#ShowMesg(s:WARNING,"(vimball#Decompress) bunzip2 may have failed with <".a:fname.">")
+   endif
+   let fname= substitute(a:fname,'\.bz2$','','')
+   exe "e ".escape(fname,' \')
+   if a:0 == 0| call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") | endif
+
+  elseif expand("%") =~ '.*\.bz2' && executable("bzip2")
+   " handle *.bz2 with bzip2 -d
+   silent exe "!bzip2 -d ".shellescape(a:fname)
+   if v:shell_error != 0
+	call vimball#ShowMesg(s:WARNING,'(vimball#Decompress) "bzip2 -d" may have failed with <'.a:fname.">")
+   endif
+   let fname= substitute(a:fname,'\.bz2$','','')
+   exe "e ".escape(fname,' \')
+   if a:0 == 0| call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") | endif
+
+  elseif expand("%") =~ '.*\.zip' && executable("unzip")
+   " handle *.zip with unzip
+   silent exe "!unzip ".shellescape(a:fname)
+   if v:shell_error != 0
+	call vimball#ShowMesg(s:WARNING,"(vimball#Decompress) unzip may have failed with <".a:fname.">")
+   endif
+   let fname= substitute(a:fname,'\.zip$','','')
+   exe "e ".escape(fname,' \')
+   if a:0 == 0| call vimball#ShowMesg(s:USAGE,"Source this file to extract it! (:so %)") | endif
+  endif
+
+  if a:0 == 0| setlocal noma bt=nofile fmr=[[[,]]] fdm=marker | endif
+
+"  call Dret("Decompress")
+endfun
+
+" ---------------------------------------------------------------------
+" vimball#ShowMesg: {{{2
+fun! vimball#ShowMesg(level,msg)
+"  call Dfunc("vimball#ShowMesg(level=".a:level." msg<".a:msg.">)")
+
+  let rulerkeep   = &ruler
+  let showcmdkeep = &showcmd
+  set noruler noshowcmd
+  redraw!
+
+  if &fo =~ '[ta]'
+   echomsg "***vimball*** ".a:msg
+  else
+   if a:level == s:WARNING || a:level == s:USAGE
+    echohl WarningMsg
+   elseif a:level == s:ERROR
+    echohl Error
+   endif
+   echomsg "***vimball*** ".a:msg
+   echohl None
+  endif
+
+  if a:level != s:USAGE
+   call inputsave()|let ok= input("Press  to continue")|call inputrestore()
+  endif
+
+  let &ruler   = rulerkeep
+  let &showcmd = showcmdkeep
+
+"  call Dret("vimball#ShowMesg")
+endfun
+" =====================================================================
+" s:ChgDir: change directory (in spite of Windoze) {{{2
+fun! s:ChgDir(newdir)
+"  call Dfunc("ChgDir(newdir<".a:newdir.">)")
+  if (has("win32") || has("win95") || has("win64") || has("win16"))
+   exe 'silent cd '.fnameescape(substitute(a:newdir,'/','\\','g'))
+  else
+   exe 'silent cd '.fnameescape(a:newdir)
+  endif
+"  call Dret("ChgDir : curdir<".getcwd().">")
+endfun
+
+" ---------------------------------------------------------------------
+" s:RecordInVar: record a un-vimball command in the .VimballRecord file {{{2
+fun! s:RecordInVar(home,cmd)
+"  call Dfunc("RecordInVar(home<".a:home."> cmd<".a:cmd.">)")
+  if a:cmd =~ '^rmdir'
+"   if !exists("s:recorddir")
+"    let s:recorddir= substitute(a:cmd,'^rmdir',"call s:Rmdir",'')
+"   else
+"    let s:recorddir= s:recorddir."|".substitute(a:cmd,'^rmdir',"call s:Rmdir",'')
+"   endif
+  elseif !exists("s:recordfile")
+   let s:recordfile= a:cmd
+  else
+   let s:recordfile= s:recordfile."|".a:cmd
+  endif
+"  call Dret("RecordInVar : s:recordfile<".(exists("s:recordfile")? s:recordfile : "")."> s:recorddir<".(exists("s:recorddir")? s:recorddir : "").">")
+endfun
+
+" ---------------------------------------------------------------------
+" s:RecordInFile: {{{2
+fun! s:RecordInFile(home)
+"  call Dfunc("s:RecordInFile()")
+  if exists("g:vimball_norecord")
+"   call Dret("s:RecordInFile : g:vimball_norecord")
+   return
+  endif
+
+  if exists("s:recordfile") || exists("s:recorddir")
+   let curdir= getcwd()
+   call s:ChgDir(a:home)
+   keepalt keepjumps 1split 
+
+   let cmd= expand("%:tr").": "
+"   call Decho("cmd<".cmd.">")
+
+   silent! keepalt keepjumps e .VimballRecord
+   setlocal ma
+   $
+   if exists("s:recordfile") && exists("s:recorddir")
+   	let cmd= cmd.s:recordfile."|".s:recorddir
+   elseif exists("s:recorddir")
+   	let cmd= cmd.s:recorddir
+   elseif exists("s:recordfile")
+   	let cmd= cmd.s:recordfile
+   else
+"    call Dret("s:RecordInFile : neither recordfile nor recorddir exist")
+	return
+   endif
+"   call Decho("cmd<".cmd.">")
+
+   " put command into buffer, write .VimballRecord `file
+   keepalt keepjumps put=cmd
+   silent! keepalt keepjumps g/^\s*$/d
+   silent! keepalt keepjumps wq!
+   call s:ChgDir(curdir)
+
+   if exists("s:recorddir")
+"	call Decho("unlet s:recorddir<".s:recorddir.">")
+   	unlet s:recorddir
+   endif
+   if exists("s:recordfile")
+"	call Decho("unlet s:recordfile<".s:recordfile.">")
+   	unlet s:recordfile
+   endif
+  else
+"   call Decho("s:record[file|dir] doesn't exist")
+  endif
+
+"  call Dret("s:RecordInFile")
+endfun
+
+" ---------------------------------------------------------------------
+" vimball#VimballHome: determine/get home directory path (usually from rtp) {{{2
+fun! vimball#VimballHome()
+"  call Dfunc("vimball#VimballHome()")
+  if exists("g:vimball_home")
+   let home= g:vimball_home
+  else
+   " go to vim plugin home
+   for home in split(&rtp,',') + ['']
+    if isdirectory(home) && filewritable(home) | break | endif
+	let basehome= substitute(home,'[/\\]\.vim$','','')
+    if isdirectory(basehome) && filewritable(basehome)
+	 let home= basehome."/.vim"
+	 break
+	endif
+   endfor
+   if home == ""
+    " just pick the first directory
+    let home= substitute(&rtp,',.*$','','')
+   endif
+   if (has("win32") || has("win95") || has("win64") || has("win16"))
+    let home= substitute(home,'/','\\','g')
+   endif
+  endif
+  " insure that the home directory exists
+"  call Decho("picked home<".home.">")
+  if !isdirectory(home)
+   if exists("g:vimball_mkdir")
+"	call Decho("home<".home."> isn't a directory -- making it now with g:vimball_mkdir<".g:vimball_mkdir.">")
+"    call Decho("system(".g:vimball_mkdir." ".shellescape(home).")")
+    call system(g:vimball_mkdir." ".shellescape(home))
+   else
+"	call Decho("home<".home."> isn't a directory -- making it now with mkdir()")
+    call mkdir(home)
+   endif
+  endif
+"  call Dret("vimball#VimballHome <".home.">")
+  return home
+endfun
+
+" ---------------------------------------------------------------------
+" vimball#SaveSettings: {{{2
+fun! vimball#SaveSettings()
+"  call Dfunc("SaveSettings()")
+  let s:makeep  = getpos("'a")
+  let s:regakeep= @a
+  if exists("&acd")
+   let s:acdkeep = &acd
+  endif
+  let s:eikeep  = &ei
+  let s:fenkeep = &l:fen
+  let s:hidkeep = &hidden
+  let s:ickeep  = &ic
+  let s:lzkeep  = &lz
+  let s:pmkeep  = &pm
+  let s:repkeep = &report
+  let s:vekeep  = &ve
+  let s:ffkeep  = &l:ff
+  if exists("&acd")
+   setlocal ei=all ve=all noacd nofen noic report=999 nohid bt= ma lz pm= ff=unix
+  else
+   setlocal ei=all ve=all       nofen noic report=999 nohid bt= ma lz pm= ff=unix
+  endif
+  " vimballs should be in unix format
+  setlocal ff=unix
+"  call Dret("SaveSettings")
+endfun
+
+" ---------------------------------------------------------------------
+" vimball#RestoreSettings: {{{2
+fun! vimball#RestoreSettings()
+"  call Dfunc("RestoreSettings()")
+  let @a      = s:regakeep
+  if exists("&acd")
+   let &acd   = s:acdkeep
+  endif
+  let &l:fen  = s:fenkeep
+  let &hidden = s:hidkeep
+  let &ic     = s:ickeep
+  let &lz     = s:lzkeep
+  let &pm     = s:pmkeep
+  let &report = s:repkeep
+  let &ve     = s:vekeep
+  let &ei     = s:eikeep
+  let &l:ff   = s:ffkeep
+  if s:makeep[0] != 0
+   " restore mark a
+"   call Decho("restore mark-a: makeep=".string(makeep))
+   call setpos("'a",s:makeep)
+  endif
+  if exists("&acd")
+   unlet s:acdkeep
+  endif
+  unlet s:regakeep s:eikeep s:fenkeep s:hidkeep s:ickeep s:repkeep s:vekeep s:makeep s:lzkeep s:pmkeep s:ffkeep
+"  call Dret("RestoreSettings")
+endfun
+
+" ---------------------------------------------------------------------
+" Modelines: {{{1
+" vim: fdm=marker
diff --git a/share/vim/vim72/autoload/xml/html32.vim b/share/vim/vim73/autoload/xml/html32.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/html32.vim
rename to share/vim/vim73/autoload/xml/html32.vim
diff --git a/share/vim/vim72/autoload/xml/html401f.vim b/share/vim/vim73/autoload/xml/html401f.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/html401f.vim
rename to share/vim/vim73/autoload/xml/html401f.vim
diff --git a/share/vim/vim72/autoload/xml/html401s.vim b/share/vim/vim73/autoload/xml/html401s.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/html401s.vim
rename to share/vim/vim73/autoload/xml/html401s.vim
diff --git a/share/vim/vim72/autoload/xml/html401t.vim b/share/vim/vim73/autoload/xml/html401t.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/html401t.vim
rename to share/vim/vim73/autoload/xml/html401t.vim
diff --git a/share/vim/vim72/autoload/xml/html40f.vim b/share/vim/vim73/autoload/xml/html40f.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/html40f.vim
rename to share/vim/vim73/autoload/xml/html40f.vim
diff --git a/share/vim/vim72/autoload/xml/html40s.vim b/share/vim/vim73/autoload/xml/html40s.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/html40s.vim
rename to share/vim/vim73/autoload/xml/html40s.vim
diff --git a/share/vim/vim72/autoload/xml/html40t.vim b/share/vim/vim73/autoload/xml/html40t.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/html40t.vim
rename to share/vim/vim73/autoload/xml/html40t.vim
diff --git a/share/vim/vim72/autoload/xml/xhtml10f.vim b/share/vim/vim73/autoload/xml/xhtml10f.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/xhtml10f.vim
rename to share/vim/vim73/autoload/xml/xhtml10f.vim
diff --git a/share/vim/vim72/autoload/xml/xhtml10s.vim b/share/vim/vim73/autoload/xml/xhtml10s.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/xhtml10s.vim
rename to share/vim/vim73/autoload/xml/xhtml10s.vim
diff --git a/share/vim/vim72/autoload/xml/xhtml10t.vim b/share/vim/vim73/autoload/xml/xhtml10t.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/xhtml10t.vim
rename to share/vim/vim73/autoload/xml/xhtml10t.vim
diff --git a/share/vim/vim72/autoload/xml/xhtml11.vim b/share/vim/vim73/autoload/xml/xhtml11.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/xhtml11.vim
rename to share/vim/vim73/autoload/xml/xhtml11.vim
diff --git a/share/vim/vim72/autoload/xml/xsd.vim b/share/vim/vim73/autoload/xml/xsd.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/xsd.vim
rename to share/vim/vim73/autoload/xml/xsd.vim
diff --git a/share/vim/vim72/autoload/xml/xsl.vim b/share/vim/vim73/autoload/xml/xsl.vim
similarity index 100%
rename from share/vim/vim72/autoload/xml/xsl.vim
rename to share/vim/vim73/autoload/xml/xsl.vim
diff --git a/share/vim/vim72/autoload/xmlcomplete.vim b/share/vim/vim73/autoload/xmlcomplete.vim
similarity index 100%
rename from share/vim/vim72/autoload/xmlcomplete.vim
rename to share/vim/vim73/autoload/xmlcomplete.vim
diff --git a/share/vim/vim73/autoload/zip.vim b/share/vim/vim73/autoload/zip.vim
new file mode 100644
index 0000000000..a55f1dccd3
--- /dev/null
+++ b/share/vim/vim73/autoload/zip.vim
@@ -0,0 +1,393 @@
+" zip.vim: Handles browsing zipfiles
+"            AUTOLOAD PORTION
+" Date:		Apr 12, 2010
+" Version:	23
+" Maintainer:	Charles E Campbell, Jr 
+" License:	Vim License  (see vim's :help license)
+" Copyright:    Copyright (C) 2005-2008 Charles E. Campbell, Jr. {{{1
+"               Permission is hereby granted to use and distribute this code,
+"               with or without modifications, provided that this copyright
+"               notice is copied with it. Like anything else that's free,
+"               zip.vim and zipPlugin.vim are provided *as is* and comes with
+"               no warranty of any kind, either expressed or implied. By using
+"               this plugin, you agree that in no event will the copyright
+"               holder be liable for any damages resulting from the use
+"               of this software.
+
+" ---------------------------------------------------------------------
+" Load Once: {{{1
+if &cp || exists("g:loaded_zip")
+ finish
+endif
+let g:loaded_zip= "v23"
+if v:version < 702
+ echohl WarningMsg
+ echo "***warning*** this version of zip needs vim 7.2"
+ echohl Normal
+ finish
+endif
+let s:keepcpo= &cpo
+set cpo&vim
+
+let s:zipfile_escape = ' ?&;\'
+let s:ERROR          = 2
+let s:WARNING        = 1
+let s:NOTE           = 0
+
+" ---------------------------------------------------------------------
+"  Global Values: {{{1
+if !exists("g:zip_shq")
+ if &shq != ""
+  let g:zip_shq= &shq
+ elseif has("unix")
+  let g:zip_shq= "'"
+ else
+  let g:zip_shq= '"'
+ endif
+endif
+if !exists("g:zip_zipcmd")
+ let g:zip_zipcmd= "zip"
+endif
+if !exists("g:zip_unzipcmd")
+ let g:zip_unzipcmd= "unzip"
+endif
+
+" ----------------
+"  Functions: {{{1
+" ----------------
+
+" ---------------------------------------------------------------------
+" zip#Browse: {{{2
+fun! zip#Browse(zipfile)
+"  call Dfunc("zip#Browse(zipfile<".a:zipfile.">)")
+  let repkeep= &report
+  set report=10
+
+  " sanity checks
+  if !exists("*fnameescape")
+   if &verbose > 1
+    echoerr "the zip plugin is not available (your vim doens't support fnameescape())"
+   endif
+   return
+  endif
+  if !executable(g:zip_unzipcmd)
+   redraw!
+   echohl Error | echo "***error*** (zip#Browse) unzip not available on your system"
+"   call inputsave()|call input("Press  to continue")|call inputrestore()
+   let &report= repkeep
+"   call Dret("zip#Browse")
+   return
+  endif
+  if !filereadable(a:zipfile)
+   if a:zipfile !~# '^\a\+://'
+    " if its an url, don't complain, let url-handlers such as vim do its thing
+    redraw!
+    echohl Error | echo "***error*** (zip#Browse) File not readable<".a:zipfile.">" | echohl None
+"    call inputsave()|call input("Press  to continue")|call inputrestore()
+   endif
+   let &report= repkeep
+"   call Dret("zip#Browse : file<".a:zipfile."> not readable")
+   return
+  endif
+"  call Decho("passed sanity checks")
+  if &ma != 1
+   set ma
+  endif
+  let b:zipfile= a:zipfile
+
+  setlocal noswapfile
+  setlocal buftype=nofile
+  setlocal bufhidden=hide
+  setlocal nobuflisted
+  setlocal nowrap
+  set ft=tar
+
+  " give header
+  let lastline= line("$")
+  call setline(lastline+1,'" zip.vim version '.g:loaded_zip)
+  call setline(lastline+2,'" Browsing zipfile '.a:zipfile)
+  call setline(lastline+3,'" Select a file with cursor and press ENTER')
+  $put =''
+  0d
+  $
+
+"  call Decho("exe silent r! ".g:zip_unzipcmd." -l -- ".s:Escape(a:zipfile,1))
+  exe "silent r! ".g:zip_unzipcmd." -l -- ".s:Escape(a:zipfile,1)
+  if v:shell_error != 0
+   redraw!
+   echohl WarningMsg | echo "***warning*** (zip#Browse) ".fnameescape(a:zipfile)." is not a zip file" | echohl None
+"   call inputsave()|call input("Press  to continue")|call inputrestore()
+   silent %d
+   let eikeep= &ei
+   set ei=BufReadCmd,FileReadCmd
+   exe "r ".fnameescape(a:zipfile)
+   let &ei= eikeep
+   1d
+"   call Dret("zip#Browse")
+   return
+  endif
+"  call Decho("line 6: ".getline(6))
+  let namecol= stridx(getline(6),'Name') + 1
+"  call Decho("namecol=".namecol)
+  4,$g/^\s*----/d
+  4,$g/^\s*\a/d
+  $d
+  if namecol > 0
+   exe 'silent 4,$s/^.*\%'.namecol.'c//'
+  endif
+
+  setlocal noma nomod ro
+  noremap    :call ZipBrowseSelect()
+
+  let &report= repkeep
+"  call Dret("zip#Browse")
+endfun
+
+" ---------------------------------------------------------------------
+" ZipBrowseSelect: {{{2
+fun! s:ZipBrowseSelect()
+"  call Dfunc("ZipBrowseSelect() zipfile<".b:zipfile."> curfile<".expand("%").">")
+  let repkeep= &report
+  set report=10
+  let fname= getline(".")
+
+  " sanity check
+  if fname =~ '^"'
+   let &report= repkeep
+"   call Dret("ZipBrowseSelect")
+   return
+  endif
+  if fname =~ '/$'
+   redraw!
+   echohl Error | echo "***error*** (zip#Browse) Please specify a file, not a directory" | echohl None
+"   call inputsave()|call input("Press  to continue")|call inputrestore()
+   let &report= repkeep
+"   call Dret("ZipBrowseSelect")
+   return
+  endif
+
+"  call Decho("fname<".fname.">")
+
+  " get zipfile to the new-window
+  let zipfile = b:zipfile
+  let curfile= expand("%")
+"  call Decho("zipfile<".zipfile.">")
+"  call Decho("curfile<".curfile.">")
+
+  new
+  if !exists("g:zip_nomax") || g:zip_nomax == 0
+   wincmd _
+  endif
+  let s:zipfile_{winnr()}= curfile
+"  call Decho("exe e ".fnameescape("zipfile:".zipfile.'::'.fname))
+  exe "e ".fnameescape("zipfile:".zipfile.'::'.fname)
+  filetype detect
+
+  let &report= repkeep
+"  call Dret("ZipBrowseSelect : s:zipfile_".winnr()."<".s:zipfile_{winnr()}.">")
+endfun
+
+" ---------------------------------------------------------------------
+" zip#Read: {{{2
+fun! zip#Read(fname,mode)
+"  call Dfunc("zip#Read(fname<".a:fname.">,mode=".a:mode.")")
+  let repkeep= &report
+  set report=10
+
+  if has("unix")
+   let zipfile = substitute(a:fname,'zipfile:\(.\{-}\)::[^\\].*$','\1','')
+   let fname   = substitute(a:fname,'zipfile:.\{-}::\([^\\].*\)$','\1','')
+  else
+   let zipfile = substitute(a:fname,'^.\{-}zipfile:\(.\{-}\)::[^\\].*$','\1','')
+   let fname   = substitute(a:fname,'^.\{-}zipfile:.\{-}::\([^\\].*\)$','\1','')
+   let fname = substitute(fname, '[', '[[]', 'g')
+  endif
+"  call Decho("zipfile<".zipfile.">")
+"  call Decho("fname  <".fname.">")
+
+"  call Decho("exe r! ".g:zip_unzipcmd." -p -- ".s:Escape(zipfile,1)." ".s:Escape(fname,1))
+  exe "silent r! ".g:zip_unzipcmd." -p -- ".s:Escape(zipfile,1)." ".s:Escape(fname,1)
+
+  " cleanup
+  0d
+  set nomod
+
+  let &report= repkeep
+"  call Dret("zip#Read")
+endfun
+
+" ---------------------------------------------------------------------
+" zip#Write: {{{2
+fun! zip#Write(fname)
+"  call Dfunc("zip#Write(fname<".a:fname.">) zipfile_".winnr()."<".s:zipfile_{winnr()}.">")
+  let repkeep= &report
+  set report=10
+
+  " sanity checks
+  if !executable(g:zip_zipcmd)
+   redraw!
+   echohl Error | echo "***error*** (zip#Write) sorry, your system doesn't appear to have the zip pgm" | echohl None
+"   call inputsave()|call input("Press  to continue")|call inputrestore()
+   let &report= repkeep
+"   call Dret("zip#Write")
+   return
+  endif
+  if !exists("*mkdir")
+   redraw!
+   echohl Error | echo "***error*** (zip#Write) sorry, mkdir() doesn't work on your system" | echohl None
+"   call inputsave()|call input("Press  to continue")|call inputrestore()
+   let &report= repkeep
+"   call Dret("zip#Write")
+   return
+  endif
+
+  let curdir= getcwd()
+  let tmpdir= tempname()
+"  call Decho("orig tempname<".tmpdir.">")
+  if tmpdir =~ '\.'
+   let tmpdir= substitute(tmpdir,'\.[^.]*$','','e')
+  endif
+"  call Decho("tmpdir<".tmpdir.">")
+  call mkdir(tmpdir,"p")
+
+  " attempt to change to the indicated directory
+  if s:ChgDir(tmpdir,s:ERROR,"(zip#Write) cannot cd to temporary directory")
+   let &report= repkeep
+"   call Dret("zip#Write")
+   return
+  endif
+"  call Decho("current directory now: ".getcwd())
+
+  " place temporary files under .../_ZIPVIM_/
+  if isdirectory("_ZIPVIM_")
+   call s:Rmdir("_ZIPVIM_")
+  endif
+  call mkdir("_ZIPVIM_")
+  cd _ZIPVIM_
+"  call Decho("current directory now: ".getcwd())
+
+  if has("unix")
+   let zipfile = substitute(a:fname,'zipfile:\(.\{-}\)::[^\\].*$','\1','')
+   let fname   = substitute(a:fname,'zipfile:.\{-}::\([^\\].*\)$','\1','')
+  else
+   let zipfile = substitute(a:fname,'^.\{-}zipfile:\(.\{-}\)::[^\\].*$','\1','')
+   let fname   = substitute(a:fname,'^.\{-}zipfile:.\{-}::\([^\\].*\)$','\1','')
+  endif
+"  call Decho("zipfile<".zipfile.">")
+"  call Decho("fname  <".fname.">")
+
+  if fname =~ '/'
+   let dirpath = substitute(fname,'/[^/]\+$','','e')
+   if executable("cygpath")
+    let dirpath = substitute(system("cygpath ".s:Escape(dirpath,0)),'\n','','e')
+   endif
+"   call Decho("mkdir(dirpath<".dirpath.">,p)")
+   call mkdir(dirpath,"p")
+  endif
+  if zipfile !~ '/'
+   let zipfile= curdir.'/'.zipfile
+  endif
+"  call Decho("zipfile<".zipfile."> fname<".fname.">")
+
+  exe "w! ".fnameescape(fname)
+  if executable("cygpath")
+   let zipfile = substitute(system("cygpath ".s:Escape(zipfile,0)),'\n','','e')
+  endif
+
+  if (has("win32") || has("win95") || has("win64") || has("win16")) && &shell !~? 'sh$'
+    let fname = substitute(fname, '[', '[[]', 'g')
+  endif
+
+"  call Decho(g:zip_zipcmd." -u ".s:Escape(fnamemodify(zipfile,":p"),0)." ".s:Escape(fname,0))
+  call system(g:zip_zipcmd." -u ".s:Escape(fnamemodify(zipfile,":p"),0)." ".s:Escape(fname,0))
+  if v:shell_error != 0
+   redraw!
+   echohl Error | echo "***error*** (zip#Write) sorry, unable to update ".zipfile." with ".fname | echohl None
+"   call inputsave()|call input("Press  to continue")|call inputrestore()
+
+  elseif s:zipfile_{winnr()} =~ '^\a\+://'
+   " support writing zipfiles across a network
+   let netzipfile= s:zipfile_{winnr()}
+"   call Decho("handle writing <".zipfile."> across network as <".netzipfile.">")
+   1split|enew
+   let binkeep= &binary
+   let eikeep = &ei
+   set binary ei=all
+   exe "e! ".fnameescape(zipfile)
+   call netrw#NetWrite(netzipfile)
+   let &ei     = eikeep
+   let &binary = binkeep
+   q!
+   unlet s:zipfile_{winnr()}
+  endif
+  
+  " cleanup and restore current directory
+  cd ..
+  call s:Rmdir("_ZIPVIM_")
+  call s:ChgDir(curdir,s:WARNING,"(zip#Write) unable to return to ".curdir."!")
+  call s:Rmdir(tmpdir)
+  setlocal nomod
+
+  let &report= repkeep
+"  call Dret("zip#Write")
+endfun
+
+" ---------------------------------------------------------------------
+" s:Escape: {{{2
+fun! s:Escape(fname,isfilt)
+"  call Dfunc("QuoteFileDir(fname<".a:fname."> isfilt=".a:isfilt.")")
+  if exists("*shellescape")
+   if a:isfilt
+    let qnameq= shellescape(a:fname,1)
+   else
+    let qnameq= shellescape(a:fname)
+   endif
+  else
+   let qnameq= g:zip_shq.escape(a:fname,g:zip_shq).g:zip_shq
+  endif
+"  call Dret("QuoteFileDir <".qnameq.">")
+  return qnameq
+endfun
+
+" ---------------------------------------------------------------------
+" ChgDir: {{{2
+fun! s:ChgDir(newdir,errlvl,errmsg)
+"  call Dfunc("ChgDir(newdir<".a:newdir."> errlvl=".a:errlvl."  errmsg<".a:errmsg.">)")
+
+  try
+   exe "cd ".fnameescape(a:newdir)
+  catch /^Vim\%((\a\+)\)\=:E344/
+   redraw!
+   if a:errlvl == s:NOTE
+    echo "***note*** ".a:errmsg
+   elseif a:errlvl == s:WARNING
+    echohl WarningMsg | echo "***warning*** ".a:errmsg | echohl NONE
+   elseif a:errlvl == s:ERROR
+    echohl Error | echo "***error*** ".a:errmsg | echohl NONE
+   endif
+"   call inputsave()|call input("Press  to continue")|call inputrestore()
+"   call Dret("ChgDir 1")
+   return 1
+  endtry
+
+"  call Dret("ChgDir 0")
+  return 0
+endfun
+
+" ---------------------------------------------------------------------
+" s:Rmdir: {{{2
+fun! s:Rmdir(fname)
+"  call Dfunc("Rmdir(fname<".a:fname.">)")
+  if (has("win32") || has("win95") || has("win64") || has("win16")) && &shell !~? 'sh$'
+   call system("rmdir /S/Q ".s:Escape(a:fname,0))
+  else
+   call system("/bin/rm -rf ".s:Escape(a:fname,0))
+  endif
+"  call Dret("Rmdir")
+endfun
+
+" ------------------------------------------------------------------------
+" Modelines And Restoration: {{{1
+let &cpo= s:keepcpo
+unlet s:keepcpo
+" vim:ts=8 fdm=marker
diff --git a/share/vim/vim72/bugreport.vim b/share/vim/vim73/bugreport.vim
similarity index 100%
rename from share/vim/vim72/bugreport.vim
rename to share/vim/vim73/bugreport.vim
diff --git a/share/vim/vim72/colors/README.txt b/share/vim/vim73/colors/README.txt
similarity index 100%
rename from share/vim/vim72/colors/README.txt
rename to share/vim/vim73/colors/README.txt
diff --git a/share/vim/vim72/colors/blue.vim b/share/vim/vim73/colors/blue.vim
similarity index 100%
rename from share/vim/vim72/colors/blue.vim
rename to share/vim/vim73/colors/blue.vim
diff --git a/share/vim/vim72/colors/darkblue.vim b/share/vim/vim73/colors/darkblue.vim
similarity index 100%
rename from share/vim/vim72/colors/darkblue.vim
rename to share/vim/vim73/colors/darkblue.vim
diff --git a/share/vim/vim72/colors/default.vim b/share/vim/vim73/colors/default.vim
similarity index 100%
rename from share/vim/vim72/colors/default.vim
rename to share/vim/vim73/colors/default.vim
diff --git a/share/vim/vim72/colors/delek.vim b/share/vim/vim73/colors/delek.vim
similarity index 100%
rename from share/vim/vim72/colors/delek.vim
rename to share/vim/vim73/colors/delek.vim
diff --git a/share/vim/vim72/colors/desert.vim b/share/vim/vim73/colors/desert.vim
similarity index 100%
rename from share/vim/vim72/colors/desert.vim
rename to share/vim/vim73/colors/desert.vim
diff --git a/share/vim/vim72/colors/elflord.vim b/share/vim/vim73/colors/elflord.vim
similarity index 100%
rename from share/vim/vim72/colors/elflord.vim
rename to share/vim/vim73/colors/elflord.vim
diff --git a/share/vim/vim72/colors/evening.vim b/share/vim/vim73/colors/evening.vim
similarity index 100%
rename from share/vim/vim72/colors/evening.vim
rename to share/vim/vim73/colors/evening.vim
diff --git a/share/vim/vim72/colors/koehler.vim b/share/vim/vim73/colors/koehler.vim
similarity index 100%
rename from share/vim/vim72/colors/koehler.vim
rename to share/vim/vim73/colors/koehler.vim
diff --git a/share/vim/vim72/colors/morning.vim b/share/vim/vim73/colors/morning.vim
similarity index 100%
rename from share/vim/vim72/colors/morning.vim
rename to share/vim/vim73/colors/morning.vim
diff --git a/share/vim/vim72/colors/murphy.vim b/share/vim/vim73/colors/murphy.vim
similarity index 100%
rename from share/vim/vim72/colors/murphy.vim
rename to share/vim/vim73/colors/murphy.vim
diff --git a/share/vim/vim72/colors/pablo.vim b/share/vim/vim73/colors/pablo.vim
similarity index 100%
rename from share/vim/vim72/colors/pablo.vim
rename to share/vim/vim73/colors/pablo.vim
diff --git a/share/vim/vim72/colors/peachpuff.vim b/share/vim/vim73/colors/peachpuff.vim
similarity index 100%
rename from share/vim/vim72/colors/peachpuff.vim
rename to share/vim/vim73/colors/peachpuff.vim
diff --git a/share/vim/vim72/colors/ron.vim b/share/vim/vim73/colors/ron.vim
similarity index 100%
rename from share/vim/vim72/colors/ron.vim
rename to share/vim/vim73/colors/ron.vim
diff --git a/share/vim/vim72/colors/shine.vim b/share/vim/vim73/colors/shine.vim
similarity index 100%
rename from share/vim/vim72/colors/shine.vim
rename to share/vim/vim73/colors/shine.vim
diff --git a/share/vim/vim72/colors/slate.vim b/share/vim/vim73/colors/slate.vim
similarity index 100%
rename from share/vim/vim72/colors/slate.vim
rename to share/vim/vim73/colors/slate.vim
diff --git a/share/vim/vim72/colors/torte.vim b/share/vim/vim73/colors/torte.vim
similarity index 100%
rename from share/vim/vim72/colors/torte.vim
rename to share/vim/vim73/colors/torte.vim
diff --git a/share/vim/vim72/colors/zellner.vim b/share/vim/vim73/colors/zellner.vim
similarity index 100%
rename from share/vim/vim72/colors/zellner.vim
rename to share/vim/vim73/colors/zellner.vim
diff --git a/share/vim/vim72/compiler/README.txt b/share/vim/vim73/compiler/README.txt
similarity index 100%
rename from share/vim/vim72/compiler/README.txt
rename to share/vim/vim73/compiler/README.txt
diff --git a/share/vim/vim72/compiler/ant.vim b/share/vim/vim73/compiler/ant.vim
similarity index 100%
rename from share/vim/vim72/compiler/ant.vim
rename to share/vim/vim73/compiler/ant.vim
diff --git a/share/vim/vim72/compiler/bcc.vim b/share/vim/vim73/compiler/bcc.vim
similarity index 100%
rename from share/vim/vim72/compiler/bcc.vim
rename to share/vim/vim73/compiler/bcc.vim
diff --git a/share/vim/vim72/compiler/bdf.vim b/share/vim/vim73/compiler/bdf.vim
similarity index 100%
rename from share/vim/vim72/compiler/bdf.vim
rename to share/vim/vim73/compiler/bdf.vim
diff --git a/share/vim/vim72/compiler/checkstyle.vim b/share/vim/vim73/compiler/checkstyle.vim
similarity index 100%
rename from share/vim/vim72/compiler/checkstyle.vim
rename to share/vim/vim73/compiler/checkstyle.vim
diff --git a/share/vim/vim72/compiler/cs.vim b/share/vim/vim73/compiler/cs.vim
similarity index 100%
rename from share/vim/vim72/compiler/cs.vim
rename to share/vim/vim73/compiler/cs.vim
diff --git a/share/vim/vim73/compiler/cucumber.vim b/share/vim/vim73/compiler/cucumber.vim
new file mode 100644
index 0000000000..c020be6e3b
--- /dev/null
+++ b/share/vim/vim73/compiler/cucumber.vim
@@ -0,0 +1,29 @@
+" Vim compiler file
+" Compiler:	Cucumber
+" Maintainer:	Tim Pope 
+" Last Change:	2010 Aug 09
+
+if exists("current_compiler")
+  finish
+endif
+let current_compiler = "cucumber"
+
+if exists(":CompilerSet") != 2		" older Vim always used :setlocal
+  command -nargs=* CompilerSet setlocal 
+endif
+
+let s:cpo_save = &cpo
+set cpo-=C
+
+CompilerSet makeprg=cucumber
+
+CompilerSet errorformat=
+      \%W%m\ (Cucumber::Undefined),
+      \%E%m\ (%.%#),
+      \%Z%f:%l,
+      \%Z%f:%l:%.%#
+
+let &cpo = s:cpo_save
+unlet s:cpo_save
+
+" vim:set sw=2 sts=2:
diff --git a/share/vim/vim72/compiler/decada.vim b/share/vim/vim73/compiler/decada.vim
similarity index 100%
rename from share/vim/vim72/compiler/decada.vim
rename to share/vim/vim73/compiler/decada.vim
diff --git a/share/vim/vim72/compiler/dot.vim b/share/vim/vim73/compiler/dot.vim
similarity index 100%
rename from share/vim/vim72/compiler/dot.vim
rename to share/vim/vim73/compiler/dot.vim
diff --git a/share/vim/vim73/compiler/eruby.vim b/share/vim/vim73/compiler/eruby.vim
new file mode 100644
index 0000000000..614fc17f6f
--- /dev/null
+++ b/share/vim/vim73/compiler/eruby.vim
@@ -0,0 +1,41 @@
+" Vim compiler file
+" Language:		eRuby
+" Maintainer:		Doug Kearns 
+" Last Change:		2008 Aug 1
+" URL:			http://vim-ruby.rubyforge.org
+" Anon CVS:		See above site
+" Release Coordinator:	Doug Kearns 
+
+if exists("current_compiler")
+  finish
+endif
+let current_compiler = "eruby"
+
+if exists(":CompilerSet") != 2		" older Vim always used :setlocal
+  command -nargs=* CompilerSet setlocal 
+endif
+
+let s:cpo_save = &cpo
+set cpo-=C
+
+if exists("eruby_compiler") && eruby_compiler == "eruby"
+  CompilerSet makeprg=eruby
+else
+  CompilerSet makeprg=erb
+endif
+
+CompilerSet errorformat=
+    \eruby:\ %f:%l:%m,
+    \%+E%f:%l:\ parse\ error,
+    \%W%f:%l:\ warning:\ %m,
+    \%E%f:%l:in\ %*[^:]:\ %m,
+    \%E%f:%l:\ %m,
+    \%-C%\tfrom\ %f:%l:in\ %.%#,
+    \%-Z%\tfrom\ %f:%l,
+    \%-Z%p^,
+    \%-G%.%#
+
+let &cpo = s:cpo_save
+unlet s:cpo_save
+
+" vim: nowrap sw=2 sts=2 ts=8:
diff --git a/share/vim/vim72/compiler/fortran_F.vim b/share/vim/vim73/compiler/fortran_F.vim
similarity index 100%
rename from share/vim/vim72/compiler/fortran_F.vim
rename to share/vim/vim73/compiler/fortran_F.vim
diff --git a/share/vim/vim72/compiler/fortran_cv.vim b/share/vim/vim73/compiler/fortran_cv.vim
similarity index 100%
rename from share/vim/vim72/compiler/fortran_cv.vim
rename to share/vim/vim73/compiler/fortran_cv.vim
diff --git a/share/vim/vim72/compiler/fortran_elf90.vim b/share/vim/vim73/compiler/fortran_elf90.vim
similarity index 100%
rename from share/vim/vim72/compiler/fortran_elf90.vim
rename to share/vim/vim73/compiler/fortran_elf90.vim
diff --git a/share/vim/vim72/compiler/fortran_g77.vim b/share/vim/vim73/compiler/fortran_g77.vim
similarity index 100%
rename from share/vim/vim72/compiler/fortran_g77.vim
rename to share/vim/vim73/compiler/fortran_g77.vim
diff --git a/share/vim/vim72/compiler/fortran_lf95.vim b/share/vim/vim73/compiler/fortran_lf95.vim
similarity index 100%
rename from share/vim/vim72/compiler/fortran_lf95.vim
rename to share/vim/vim73/compiler/fortran_lf95.vim
diff --git a/share/vim/vim72/compiler/fpc.vim b/share/vim/vim73/compiler/fpc.vim
similarity index 100%
rename from share/vim/vim72/compiler/fpc.vim
rename to share/vim/vim73/compiler/fpc.vim
diff --git a/share/vim/vim73/compiler/gcc.vim b/share/vim/vim73/compiler/gcc.vim
new file mode 100644
index 0000000000..776bdee292
--- /dev/null
+++ b/share/vim/vim73/compiler/gcc.vim
@@ -0,0 +1,39 @@
+" Vim compiler file
+" Compiler:         GNU C Compiler
+" Maintainer:       Nikolai Weibull 
+" Latest Revision:  2010-05-30
+
+if exists("current_compiler")
+  finish
+endif
+let current_compiler = "gcc"
+
+let s:cpo_save = &cpo
+set cpo-=C
+
+CompilerSet errorformat=
+      \%*[^\"]\"%f\"%*\\D%l:%c:\ %m,
+      \%*[^\"]\"%f\"%*\\D%l:\ %m,
+      \\"%f\"%*\\D%l:%c:\ %m,
+      \\"%f\"%*\\D%l:\ %m,
+      \%-G%f:%l:\ %trror:\ (Each\ undeclared\ identifier\ is\ reported\ only\ once,
+      \%-G%f:%l:\ %trror:\ for\ each\ function\ it\ appears\ in.),
+      \%f:%l:%c:\ %terror:\ %m,
+      \%f:%l:%c:\ %tarning:\ %m,
+      \%f:%l:%c:\ %m,
+      \%f:%l:\ %terror:\ %m,
+      \%f:%l:\ %tarning:\ %m,
+      \%f:%l:\ %m,
+      \\"%f\"\\,\ line\ %l%*\\D%c%*[^\ ]\ %m,
+      \%D%*\\a[%*\\d]:\ Entering\ directory\ `%f',
+      \%X%*\\a[%*\\d]:\ Leaving\ directory\ `%f',
+      \%D%*\\a:\ Entering\ directory\ `%f',
+      \%X%*\\a:\ Leaving\ directory\ `%f',
+      \%DMaking\ %*\\a\ in\ %f
+
+if exists('g:compiler_gcc_ignore_unmatched_lines')
+  CompilerSet errorformat+=%-G%.%#
+endif
+
+let &cpo = s:cpo_save
+unlet s:cpo_save
diff --git a/share/vim/vim72/compiler/gnat.vim b/share/vim/vim73/compiler/gnat.vim
similarity index 100%
rename from share/vim/vim72/compiler/gnat.vim
rename to share/vim/vim73/compiler/gnat.vim
diff --git a/share/vim/vim72/compiler/hp_acc.vim b/share/vim/vim73/compiler/hp_acc.vim
similarity index 100%
rename from share/vim/vim72/compiler/hp_acc.vim
rename to share/vim/vim73/compiler/hp_acc.vim
diff --git a/share/vim/vim72/compiler/icc.vim b/share/vim/vim73/compiler/icc.vim
similarity index 100%
rename from share/vim/vim72/compiler/icc.vim
rename to share/vim/vim73/compiler/icc.vim
diff --git a/share/vim/vim72/compiler/intel.vim b/share/vim/vim73/compiler/intel.vim
similarity index 100%
rename from share/vim/vim72/compiler/intel.vim
rename to share/vim/vim73/compiler/intel.vim
diff --git a/share/vim/vim72/compiler/irix5_c.vim b/share/vim/vim73/compiler/irix5_c.vim
similarity index 100%
rename from share/vim/vim72/compiler/irix5_c.vim
rename to share/vim/vim73/compiler/irix5_c.vim
diff --git a/share/vim/vim72/compiler/irix5_cpp.vim b/share/vim/vim73/compiler/irix5_cpp.vim
similarity index 100%
rename from share/vim/vim72/compiler/irix5_cpp.vim
rename to share/vim/vim73/compiler/irix5_cpp.vim
diff --git a/share/vim/vim72/compiler/javac.vim b/share/vim/vim73/compiler/javac.vim
similarity index 100%
rename from share/vim/vim72/compiler/javac.vim
rename to share/vim/vim73/compiler/javac.vim
diff --git a/share/vim/vim73/compiler/jikes.vim b/share/vim/vim73/compiler/jikes.vim
new file mode 100644
index 0000000000..5125128535
--- /dev/null
+++ b/share/vim/vim73/compiler/jikes.vim
@@ -0,0 +1,18 @@
+" Vim Compiler File
+" Compiler:	Jikes
+" Maintainer:	Dan Sharp 
+" Last Change:	20 Jan 2009
+" URL:		http://dwsharp.users.sourceforge.net/vim/compiler
+
+if exists("current_compiler")
+  finish
+endif
+let current_compiler = "jikes"
+
+if exists(":CompilerSet") != 2		" older Vim always used :setlocal
+  command -nargs=* CompilerSet setlocal 
+endif
+
+" Jikes defaults to printing output on stderr
+CompilerSet makeprg=jikes\ -Xstdout\ +E\ \"%\"
+CompilerSet errorformat=%f:%l:%v:%*\\d:%*\\d:%*\\s%m
diff --git a/share/vim/vim72/compiler/mcs.vim b/share/vim/vim73/compiler/mcs.vim
similarity index 100%
rename from share/vim/vim72/compiler/mcs.vim
rename to share/vim/vim73/compiler/mcs.vim
diff --git a/share/vim/vim72/compiler/mips_c.vim b/share/vim/vim73/compiler/mips_c.vim
similarity index 100%
rename from share/vim/vim72/compiler/mips_c.vim
rename to share/vim/vim73/compiler/mips_c.vim
diff --git a/share/vim/vim72/compiler/mipspro_c89.vim b/share/vim/vim73/compiler/mipspro_c89.vim
similarity index 100%
rename from share/vim/vim72/compiler/mipspro_c89.vim
rename to share/vim/vim73/compiler/mipspro_c89.vim
diff --git a/share/vim/vim72/compiler/mipspro_cpp.vim b/share/vim/vim73/compiler/mipspro_cpp.vim
similarity index 100%
rename from share/vim/vim72/compiler/mipspro_cpp.vim
rename to share/vim/vim73/compiler/mipspro_cpp.vim
diff --git a/share/vim/vim72/compiler/modelsim_vcom.vim b/share/vim/vim73/compiler/modelsim_vcom.vim
similarity index 100%
rename from share/vim/vim72/compiler/modelsim_vcom.vim
rename to share/vim/vim73/compiler/modelsim_vcom.vim
diff --git a/share/vim/vim72/compiler/msvc.vim b/share/vim/vim73/compiler/msvc.vim
similarity index 100%
rename from share/vim/vim72/compiler/msvc.vim
rename to share/vim/vim73/compiler/msvc.vim
diff --git a/share/vim/vim72/compiler/neato.vim b/share/vim/vim73/compiler/neato.vim
similarity index 100%
rename from share/vim/vim72/compiler/neato.vim
rename to share/vim/vim73/compiler/neato.vim
diff --git a/share/vim/vim72/compiler/onsgmls.vim b/share/vim/vim73/compiler/onsgmls.vim
similarity index 100%
rename from share/vim/vim72/compiler/onsgmls.vim
rename to share/vim/vim73/compiler/onsgmls.vim
diff --git a/share/vim/vim72/compiler/pbx.vim b/share/vim/vim73/compiler/pbx.vim
similarity index 100%
rename from share/vim/vim72/compiler/pbx.vim
rename to share/vim/vim73/compiler/pbx.vim
diff --git a/share/vim/vim73/compiler/perl.vim b/share/vim/vim73/compiler/perl.vim
new file mode 100644
index 0000000000..583c6c3787
--- /dev/null
+++ b/share/vim/vim73/compiler/perl.vim
@@ -0,0 +1,47 @@
+" Vim Compiler File
+" Compiler:     Perl syntax checks (perl -Wc)
+" Maintainer:   Christian J. Robinson 
+" Last Change:  2006 Aug 13
+
+if exists("current_compiler")
+  finish
+endif
+let current_compiler = "perl"
+
+if exists(":CompilerSet") != 2		" older Vim always used :setlocal
+  command -nargs=* CompilerSet setlocal 
+endif
+
+let s:savecpo = &cpo
+set cpo&vim
+
+if exists('g:perl_compiler_force_warnings') && g:perl_compiler_force_warnings == 0
+	let s:warnopt = 'w'
+else
+	let s:warnopt = 'W'
+endif
+
+if getline(1) =~# '-[^ ]*T'
+	let s:taintopt = 'T'
+else
+	let s:taintopt = ''
+endif
+
+exe 'CompilerSet makeprg=perl\ -' . s:warnopt . s:taintopt . 'c\ %'
+
+CompilerSet errorformat=
+	\%-G%.%#had\ compilation\ errors.,
+	\%-G%.%#syntax\ OK,
+	\%m\ at\ %f\ line\ %l.,
+	\%+A%.%#\ at\ %f\ line\ %l\\,%.%#,
+	\%+C%.%#
+
+" Explanation:
+" %-G%.%#had\ compilation\ errors.,  - Ignore the obvious.
+" %-G%.%#syntax\ OK,                 - Don't include the 'a-okay' message.
+" %m\ at\ %f\ line\ %l.,             - Most errors...
+" %+A%.%#\ at\ %f\ line\ %l\\,%.%#,  - As above, including ', near ...'
+" %+C%.%#                            -   ... Which can be multi-line.
+
+let &cpo = s:savecpo
+unlet s:savecpo
diff --git a/share/vim/vim72/compiler/php.vim b/share/vim/vim73/compiler/php.vim
similarity index 100%
rename from share/vim/vim72/compiler/php.vim
rename to share/vim/vim73/compiler/php.vim
diff --git a/share/vim/vim72/compiler/pyunit.vim b/share/vim/vim73/compiler/pyunit.vim
similarity index 100%
rename from share/vim/vim72/compiler/pyunit.vim
rename to share/vim/vim73/compiler/pyunit.vim
diff --git a/share/vim/vim73/compiler/rspec.vim b/share/vim/vim73/compiler/rspec.vim
new file mode 100644
index 0000000000..f46527ef1c
--- /dev/null
+++ b/share/vim/vim73/compiler/rspec.vim
@@ -0,0 +1,41 @@
+" Vim compiler file
+" Language:		RSpec
+" Maintainer:		Tim Pope 
+" Last Change:		2009 Dec 22
+" URL:			http://vim-ruby.rubyforge.org
+" Anon CVS:		See above site
+" Release Coordinator:	Doug Kearns 
+
+if exists("current_compiler")
+  finish
+endif
+let current_compiler = "rspec"
+
+if exists(":CompilerSet") != 2		" older Vim always used :setlocal
+  command -nargs=* CompilerSet setlocal 
+endif
+
+let s:cpo_save = &cpo
+set cpo-=C
+
+CompilerSet makeprg=spec
+
+CompilerSet errorformat=
+    \%+W'%.%#'\ FAILED,
+    \%+I'%.%#'\ FIXED,
+    \%-Cexpected:%.%#,
+    \%-C\ \ \ \ \ got:%.%#,
+    \%E%.%#:in\ `load':\ %f:%l:%m,
+    \%C%f:%l:,
+    \%W%f:%l:\ warning:\ %m,
+    \%E%f:%l:in\ %*[^:]:\ %m,
+    \%E%f:%l:\ %m,
+    \%-Z%\tfrom\ %f:%l,
+    \%-Z%p^%.%#,
+    \%-C%.%#,
+    \%-G%.%#
+
+let &cpo = s:cpo_save
+unlet s:cpo_save
+
+" vim: nowrap sw=2 sts=2 ts=8:
diff --git a/share/vim/vim72/compiler/rst.vim b/share/vim/vim73/compiler/rst.vim
similarity index 100%
rename from share/vim/vim72/compiler/rst.vim
rename to share/vim/vim73/compiler/rst.vim
diff --git a/share/vim/vim73/compiler/ruby.vim b/share/vim/vim73/compiler/ruby.vim
new file mode 100644
index 0000000000..9499ce1897
--- /dev/null
+++ b/share/vim/vim73/compiler/ruby.vim
@@ -0,0 +1,68 @@
+" Vim compiler file
+" Language:		Ruby
+" Function:		Syntax check and/or error reporting
+" Maintainer:		Tim Hammerquist 
+" Last Change:		2008 Aug 1
+" URL:			http://vim-ruby.rubyforge.org
+" Anon CVS:		See above site
+" Release Coordinator:	Doug Kearns 
+" ----------------------------------------------------------------------------
+"
+" Changelog:
+" 0.2:	script saves and restores 'cpoptions' value to prevent problems with
+"	line continuations
+" 0.1:	initial release
+"
+" Contributors:
+"   Hugh Sasse 
+"   Doug Kearns 
+"
+" Todo:
+"   match error type %m
+"
+" Comments:
+"   I know this file isn't perfect.  If you have any questions, suggestions,
+"   patches, etc., please don't hesitate to let me know.
+"
+"   This is my first experience with 'errorformat' and compiler plugins and
+"   I welcome any input from more experienced (or clearer-thinking)
+"   individuals.
+" ----------------------------------------------------------------------------
+
+if exists("current_compiler")
+  finish
+endif
+let current_compiler = "ruby"
+
+if exists(":CompilerSet") != 2		" older Vim always used :setlocal
+  command -nargs=* CompilerSet setlocal 
+endif
+
+let s:cpo_save = &cpo
+set cpo-=C
+
+" default settings runs script normally
+" add '-c' switch to run syntax check only:
+"
+"   CompilerSet makeprg=ruby\ -wc\ $*
+"
+" or add '-c' at :make command line:
+"
+"   :make -c %
+"
+CompilerSet makeprg=ruby\ -w\ $*
+
+CompilerSet errorformat=
+    \%+E%f:%l:\ parse\ error,
+    \%W%f:%l:\ warning:\ %m,
+    \%E%f:%l:in\ %*[^:]:\ %m,
+    \%E%f:%l:\ %m,
+    \%-C%\tfrom\ %f:%l:in\ %.%#,
+    \%-Z%\tfrom\ %f:%l,
+    \%-Z%p^,
+    \%-G%.%#
+
+let &cpo = s:cpo_save
+unlet s:cpo_save
+
+" vim: nowrap sw=2 sts=2 ts=8:
diff --git a/share/vim/vim73/compiler/rubyunit.vim b/share/vim/vim73/compiler/rubyunit.vim
new file mode 100644
index 0000000000..524c205f8a
--- /dev/null
+++ b/share/vim/vim73/compiler/rubyunit.vim
@@ -0,0 +1,35 @@
+" Vim compiler file
+" Language:		Test::Unit - Ruby Unit Testing Framework
+" Maintainer:		Doug Kearns 
+" Last Change:		2008 Aug 1
+" URL:			http://vim-ruby.rubyforge.org
+" Anon CVS:		See above site
+" Release Coordinator:	Doug Kearns 
+
+if exists("current_compiler")
+  finish
+endif
+let current_compiler = "rubyunit"
+
+if exists(":CompilerSet") != 2		" older Vim always used :setlocal
+  command -nargs=* CompilerSet setlocal 
+endif
+
+let s:cpo_save = &cpo
+set cpo-=C
+
+CompilerSet makeprg=testrb
+
+CompilerSet errorformat=\%W\ %\\+%\\d%\\+)\ Failure:,
+			\%C%m\ [%f:%l]:,
+			\%E\ %\\+%\\d%\\+)\ Error:,
+			\%C%m:,
+			\%C\ \ \ \ %f:%l:%.%#,
+			\%C%m,
+			\%Z\ %#,
+			\%-G%.%#
+
+let &cpo = s:cpo_save
+unlet s:cpo_save
+
+" vim: nowrap sw=2 sts=2 ts=8:
diff --git a/share/vim/vim72/compiler/se.vim b/share/vim/vim73/compiler/se.vim
similarity index 100%
rename from share/vim/vim72/compiler/se.vim
rename to share/vim/vim73/compiler/se.vim
diff --git a/share/vim/vim72/compiler/splint.vim b/share/vim/vim73/compiler/splint.vim
similarity index 100%
rename from share/vim/vim72/compiler/splint.vim
rename to share/vim/vim73/compiler/splint.vim
diff --git a/share/vim/vim72/compiler/tcl.vim b/share/vim/vim73/compiler/tcl.vim
similarity index 100%
rename from share/vim/vim72/compiler/tcl.vim
rename to share/vim/vim73/compiler/tcl.vim
diff --git a/share/vim/vim72/compiler/tex.vim b/share/vim/vim73/compiler/tex.vim
similarity index 100%
rename from share/vim/vim72/compiler/tex.vim
rename to share/vim/vim73/compiler/tex.vim
diff --git a/share/vim/vim72/compiler/tidy.vim b/share/vim/vim73/compiler/tidy.vim
similarity index 100%
rename from share/vim/vim72/compiler/tidy.vim
rename to share/vim/vim73/compiler/tidy.vim
diff --git a/share/vim/vim72/compiler/xmllint.vim b/share/vim/vim73/compiler/xmllint.vim
similarity index 100%
rename from share/vim/vim72/compiler/xmllint.vim
rename to share/vim/vim73/compiler/xmllint.vim
diff --git a/share/vim/vim72/compiler/xmlwf.vim b/share/vim/vim73/compiler/xmlwf.vim
similarity index 100%
rename from share/vim/vim72/compiler/xmlwf.vim
rename to share/vim/vim73/compiler/xmlwf.vim
diff --git a/share/vim/vim72/delmenu.vim b/share/vim/vim73/delmenu.vim
similarity index 100%
rename from share/vim/vim72/delmenu.vim
rename to share/vim/vim73/delmenu.vim
diff --git a/share/vim/vim72/doc.info b/share/vim/vim73/doc.info
similarity index 100%
rename from share/vim/vim72/doc.info
rename to share/vim/vim73/doc.info
diff --git a/share/vim/vim73/doc/Makefile b/share/vim/vim73/doc/Makefile
new file mode 100644
index 0000000000..a6610a937a
--- /dev/null
+++ b/share/vim/vim73/doc/Makefile
@@ -0,0 +1,490 @@
+#
+# Makefile for the Vim documentation on Unix
+#
+# If you get "don't know how to make scratch", first run make in the source
+# directory.  Or remove the include below.
+
+AWK = awk
+
+# Set to $(VIMTARGET) when executed from src/Makefile.
+VIMEXE = vim
+
+# include the config.mk from the source directory.  It's only needed to set
+# AWK, used for "make html".  Comment this out if the include gives problems.
+include ../../src/auto/config.mk
+
+DOCS = \
+	arabic.txt \
+	autocmd.txt \
+	change.txt \
+	cmdline.txt \
+	debug.txt \
+	debugger.txt \
+	develop.txt \
+	diff.txt \
+	digraph.txt \
+	editing.txt \
+	eval.txt \
+	farsi.txt \
+	filetype.txt \
+	fold.txt \
+	ft_ada.txt \
+	ft_sql.txt \
+	gui.txt \
+	gui_w16.txt \
+	gui_w32.txt \
+	gui_x11.txt \
+	hangulin.txt \
+	hebrew.txt \
+	help.txt \
+	helphelp.txt \
+	howto.txt \
+	if_cscop.txt \
+	if_lua.txt \
+	if_mzsch.txt \
+	if_ole.txt \
+	if_perl.txt \
+	if_pyth.txt \
+	if_ruby.txt \
+	if_sniff.txt \
+	if_tcl.txt \
+	indent.txt \
+	index.txt \
+	insert.txt \
+	intro.txt \
+	map.txt \
+	mbyte.txt \
+	message.txt \
+	mlang.txt \
+	motion.txt \
+	netbeans.txt \
+	options.txt \
+	os_390.txt \
+	os_amiga.txt \
+	os_beos.txt \
+	os_dos.txt \
+	os_mac.txt \
+	os_mint.txt \
+	os_msdos.txt \
+	os_os2.txt \
+	os_qnx.txt \
+	os_risc.txt \
+	os_unix.txt \
+	os_vms.txt \
+	os_win32.txt \
+	pattern.txt \
+	pi_getscript.txt \
+	pi_gzip.txt \
+	pi_netrw.txt \
+	pi_paren.txt \
+	pi_spec.txt \
+	pi_tar.txt \
+	pi_vimball.txt \
+	pi_zip.txt \
+	print.txt \
+	quickfix.txt \
+	quickref.txt \
+	quotes.txt \
+	recover.txt \
+	remote.txt \
+	repeat.txt \
+	rileft.txt \
+	russian.txt \
+	scroll.txt \
+	sign.txt \
+	spell.txt \
+	sponsor.txt \
+	starting.txt \
+	syntax.txt \
+	tabpage.txt \
+	tagsrch.txt \
+	term.txt \
+	tips.txt \
+	todo.txt \
+	uganda.txt \
+	undo.txt \
+	usr_01.txt \
+	usr_02.txt \
+	usr_03.txt \
+	usr_04.txt \
+	usr_05.txt \
+	usr_06.txt \
+	usr_07.txt \
+	usr_08.txt \
+	usr_09.txt \
+	usr_10.txt \
+	usr_11.txt \
+	usr_12.txt \
+	usr_20.txt \
+	usr_21.txt \
+	usr_22.txt \
+	usr_23.txt \
+	usr_24.txt \
+	usr_25.txt \
+	usr_26.txt \
+	usr_27.txt \
+	usr_28.txt \
+	usr_29.txt \
+	usr_30.txt \
+	usr_31.txt \
+	usr_32.txt \
+	usr_40.txt \
+	usr_41.txt \
+	usr_42.txt \
+	usr_43.txt \
+	usr_44.txt \
+	usr_45.txt \
+	usr_90.txt \
+	usr_toc.txt \
+	various.txt \
+	version4.txt \
+	version5.txt \
+	version6.txt \
+	version7.txt \
+	vi_diff.txt \
+	visual.txt \
+	windows.txt \
+	workshop.txt
+
+HTMLS = \
+	arabic.html \
+	autocmd.html \
+	change.html \
+	cmdline.html \
+	debug.html \
+	debugger.html \
+	develop.html \
+	diff.html \
+	digraph.html \
+	editing.html \
+	eval.html \
+	farsi.html \
+	filetype.html \
+	fold.html \
+	ft_ada.html \
+	ft_sql.html \
+	gui.html \
+	gui_w16.html \
+	gui_w32.html \
+	gui_x11.html \
+	hangulin.html \
+	hebrew.html \
+	helphelp.html \
+	howto.html \
+	if_cscop.html \
+	if_lua.html \
+	if_mzsch.html \
+	if_ole.html \
+	if_perl.html \
+	if_pyth.html \
+	if_ruby.html \
+	if_sniff.html \
+	if_tcl.html \
+	indent.html \
+	index.html \
+	insert.html \
+	intro.html \
+	map.html \
+	mbyte.html \
+	message.html \
+	mlang.html \
+	motion.html \
+	netbeans.html \
+	options.html \
+	os_390.html \
+	os_amiga.html \
+	os_beos.html \
+	os_dos.html \
+	os_mac.html \
+	os_mint.html \
+	os_msdos.html \
+	os_os2.html \
+	os_qnx.html \
+	os_risc.html \
+	os_unix.html \
+	os_vms.html \
+	os_win32.html \
+	pattern.html \
+	pi_getscript.html \
+	pi_gzip.html \
+	pi_netrw.html \
+	pi_paren.html \
+	pi_spec.html \
+	pi_tar.html \
+	pi_vimball.html \
+	pi_zip.html \
+	print.html \
+	quickfix.html \
+	quickref.html \
+	quotes.html \
+	recover.html \
+	remote.html \
+	repeat.html \
+	rileft.html \
+	russian.html \
+	scroll.html \
+	sign.html \
+	spell.html \
+	sponsor.html \
+	starting.html \
+	syntax.html \
+	tabpage.html \
+	tags.html \
+	tagsrch.html \
+	term.html \
+	tips.html \
+	todo.html \
+	uganda.html \
+	undo.html \
+	usr_01.html \
+	usr_02.html \
+	usr_03.html \
+	usr_04.html \
+	usr_05.html \
+	usr_06.html \
+	usr_07.html \
+	usr_08.html \
+	usr_09.html \
+	usr_10.html \
+	usr_11.html \
+	usr_12.html \
+	usr_20.html \
+	usr_21.html \
+	usr_22.html \
+	usr_23.html \
+	usr_24.html \
+	usr_25.html \
+	usr_26.html \
+	usr_27.html \
+	usr_28.html \
+	usr_29.html \
+	usr_30.html \
+	usr_31.html \
+	usr_32.html \
+	usr_40.html \
+	usr_41.html \
+	usr_42.html \
+	usr_43.html \
+	usr_44.html \
+	usr_45.html \
+	usr_90.html \
+	usr_toc.html \
+	various.html \
+	version4.html \
+	version5.html \
+	version6.html \
+	version7.html \
+	vi_diff.html \
+	vimindex.html \
+	visual.html \
+	windows.html \
+	workshop.html
+
+CONVERTED = \
+	vim-fr.UTF-8.1 \
+	evim-fr.UTF-8.1 \
+	vimdiff-fr.UTF-8.1 \
+	vimtutor-fr.UTF-8.1 \
+	xxd-fr.UTF-8.1 \
+	vim-it.UTF-8.1 \
+	evim-it.UTF-8.1 \
+	vimdiff-it.UTF-8.1 \
+	vimtutor-it.UTF-8.1 \
+	xxd-it.UTF-8.1 \
+	vim-pl.UTF-8.1 \
+	evim-pl.UTF-8.1 \
+	vimdiff-pl.UTF-8.1 \
+	vimtutor-pl.UTF-8.1 \
+	xxd-pl.UTF-8.1 \
+	vim-ru.UTF-8.1 \
+	evim-ru.UTF-8.1 \
+	vimdiff-ru.UTF-8.1 \
+	vimtutor-ru.UTF-8.1 \
+	xxd-ru.UTF-8.1
+
+.SUFFIXES:
+.SUFFIXES: .c .o .txt .html
+
+all: tags vim.man evim.man vimdiff.man vimtutor.man xxd.man $(CONVERTED)
+
+# Use Vim to generate the tags file.  Can only be used when Vim has been
+# compiled and installed.  Supports multiple languages.
+vimtags: $(DOCS)
+	$(VIMEXE) -u NONE -esX -c "helptags ++t ." -c quit
+
+# Use "doctags" to generate the tags file.  Only works for English!
+tags: doctags $(DOCS)
+	./doctags $(DOCS) | LANG=C LC_ALL=C sort >tags
+	uniq -d -2 tags
+
+doctags: doctags.c
+	$(CC) doctags.c -o doctags
+
+vim.man: vim.1
+	nroff -man vim.1 | sed -e s/.//g > vim.man
+
+evim.man: evim.1
+	nroff -man evim.1 | sed -e s/.//g > evim.man
+
+vimdiff.man: vimdiff.1
+	nroff -man vimdiff.1 | sed -e s/.//g > vimdiff.man
+
+vimtutor.man: vimtutor.1
+	nroff -man vimtutor.1 | sed -e s/.//g > vimtutor.man
+
+xxd.man: xxd.1
+	nroff -man xxd.1 | sed -e s/.//g > xxd.man
+
+uganda.nsis.txt: uganda.txt
+	sed -e 's/[ 	]*\*[-a-zA-Z0-9.]*\*//g' -e 's/vim:tw=78://' \
+		uganda.txt | uniq >uganda.nsis.txt
+
+# Awk version of .txt to .html conversion.
+html: noerrors tags $(HTMLS)
+	@if test -f errors.log; then more errors.log; fi
+
+noerrors:
+	-rm -f errors.log
+
+$(HTMLS): tags.ref
+
+.txt.html:
+	$(AWK) -f makehtml.awk $< >$@
+
+# index.html is the starting point for HTML, but for the help files it is
+# help.txt.  Therefore use vimindex.html for index.txt.
+index.html: help.txt
+	$(AWK) -f makehtml.awk help.txt >index.html
+
+vimindex.html: index.txt
+	$(AWK) -f makehtml.awk index.txt >vimindex.html
+
+tags.ref tags.html: tags
+	$(AWK) -f maketags.awk tags >tags.html
+
+# Perl version of .txt to .html conversion.
+# There can't be two rules to produce a .html from a .txt file.
+# Just run over all .txt files each time one changes.  It's fast anyway.
+perlhtml: tags $(DOCS)
+	./vim2html.pl tags $(DOCS)
+
+clean:
+	-rm doctags *.html tags.ref
+
+# These files are in the extra archive, skip if not present
+
+arabic.txt:
+	touch arabic.txt
+
+farsi.txt:
+	touch farsi.txt
+
+hebrew.txt:
+	touch hebrew.txt
+
+russian.txt:
+	touch russian.txt
+
+gui_w16.txt:
+	touch gui_w16.txt
+
+gui_w32.txt:
+	touch gui_w32.txt
+
+if_ole.txt:
+	touch if_ole.txt
+
+os_390.txt:
+	touch os_390.txt
+
+os_amiga.txt:
+	touch os_amiga.txt
+
+os_beos.txt:
+	touch os_beos.txt
+
+os_dos.txt:
+	touch os_dos.txt
+
+os_mac.txt:
+	touch os_mac.txt
+
+os_mint.txt:
+	touch os_mint.txt
+
+os_msdos.txt:
+	touch os_msdos.txt
+
+os_os2.txt:
+	touch os_os2.txt
+
+os_qnx.txt:
+	touch os_qnx.txt
+
+os_risc.txt:
+	touch os_risc.txt
+
+os_win32.txt:
+	touch os_win32.txt
+
+# Note that $< works with GNU make while $> works for BSD make.
+# Is there a solution that works for both??
+vim-fr.UTF-8.1: vim-fr.1
+	iconv -f latin1 -t utf-8 $< >$@
+
+evim-fr.UTF-8.1: evim-fr.1
+	iconv -f latin1 -t utf-8 $< >$@
+
+vimdiff-fr.UTF-8.1: vimdiff-fr.1
+	iconv -f latin1 -t utf-8 $< >$@
+
+vimtutor-fr.UTF-8.1: vimtutor-fr.1
+	iconv -f latin1 -t utf-8 $< >$@
+
+xxd-fr.UTF-8.1: xxd-fr.1
+	iconv -f latin1 -t utf-8 $< >$@
+
+vim-it.UTF-8.1: vim-it.1
+	iconv -f latin1 -t utf-8 $< >$@
+
+evim-it.UTF-8.1: evim-it.1
+	iconv -f latin1 -t utf-8 $< >$@
+
+vimdiff-it.UTF-8.1: vimdiff-it.1
+	iconv -f latin1 -t utf-8 $< >$@
+
+vimtutor-it.UTF-8.1: vimtutor-it.1
+	iconv -f latin1 -t utf-8 $< >$@
+
+xxd-it.UTF-8.1: xxd-it.1
+	iconv -f latin1 -t utf-8 $< >$@
+
+vim-pl.UTF-8.1: vim-pl.1
+	iconv -f latin2 -t utf-8 $< >$@
+
+evim-pl.UTF-8.1: evim-pl.1
+	iconv -f latin2 -t utf-8 $< >$@
+
+vimdiff-pl.UTF-8.1: vimdiff-pl.1
+	iconv -f latin2 -t utf-8 $< >$@
+
+vimtutor-pl.UTF-8.1: vimtutor-pl.1
+	iconv -f latin2 -t utf-8 $< >$@
+
+xxd-pl.UTF-8.1: xxd-pl.1
+	iconv -f latin2 -t utf-8 $< >$@
+
+vim-ru.UTF-8.1: vim-ru.1
+	iconv -f KOI8-R -t utf-8 $< >$@
+
+evim-ru.UTF-8.1: evim-ru.1
+	iconv -f KOI8-R -t utf-8 $< >$@
+
+vimdiff-ru.UTF-8.1: vimdiff-ru.1
+	iconv -f KOI8-R -t utf-8 $< >$@
+
+vimtutor-ru.UTF-8.1: vimtutor-ru.1
+	iconv -f KOI8-R -t utf-8 $< >$@
+
+xxd-ru.UTF-8.1: xxd-ru.1
+	iconv -f KOI8-R -t utf-8 $< >$@
diff --git a/share/vim/vim73/doc/arabic.txt b/share/vim/vim73/doc/arabic.txt
new file mode 100644
index 0000000000..7a4bfaaa80
--- /dev/null
+++ b/share/vim/vim73/doc/arabic.txt
@@ -0,0 +1,322 @@
+*arabic.txt*	For Vim version 7.3.  Last change: 2005 Mar 29
+
+
+		  VIM REFERENCE MANUAL	  by Nadim Shaikli
+
+
+Arabic Language support (options & mappings) for Vim		*Arabic*
+
+{Vi does not have any of these commands}
+
+								*E800*
+In order to use right-to-left and Arabic mapping support, it is
+necessary to compile VIM with the |+arabic| feature.
+
+These functions have been created by Nadim Shaikli 
+
+It is best to view this file with these settings within VIM's GUI: >
+
+	:set encoding=utf-8
+	:set arabicshape
+
+
+Introduction
+------------
+Arabic is a rather demanding language in which a number of special
+features are required.	Characters are right-to-left oriented and
+ought to appear as such on the screen (i.e. from right to left).
+Arabic also requires shaping of its characters, meaning the same
+character has a different visual form based on its relative location
+within a word (initial, medial, final or stand-alone).	Arabic also
+requires two different forms of combining and the ability, in
+certain instances, to either superimpose up to two characters on top
+of another (composing) or the actual substitution of two characters
+into one (combining).  Lastly, to display Arabic properly one will
+require not only ISO-8859-6 (U+0600-U+06FF) fonts, but will also
+require Presentation Form-B (U+FE70-U+FEFF) fonts both of which are
+subsets within a so-called ISO-10646-1 font.
+
+The commands, prompts and help files are not in Arabic, therefore
+the user interface remains the standard Vi interface.
+
+
+Highlights
+----------
+o  Editing left-to-right files as in the original VIM hasn't changed.
+
+o  Viewing and editing files in right-to-left windows.	 File
+   orientation is per window, so it is possible to view the same
+   file in right-to-left and left-to-right modes, simultaneously.
+
+o  No special terminal with right-to-left capabilities is required.
+   The right-to-left changes are completely hardware independent.
+   Only Arabic fonts are necessary.
+
+o  Compatible with the original VIM.   Almost all features work in
+   right-to-left mode (there are liable to be bugs).
+
+o  Changing keyboard mapping and reverse insert modes using a single
+   command.
+
+o  Toggling complete Arabic support via a single command.
+
+o  While in Arabic mode, numbers are entered from left to right.  Upon
+   entering a none number character, that character will be inserted
+   just into the left of the last number.
+
+o  Arabic keymapping on the command line in reverse insert mode.
+
+o  Proper Bidirectional functionality is possible given VIM is
+   started within a Bidi capable terminal emulator.
+
+
+Arabic Fonts						*arabicfonts*
+------------
+
+VIM requires monospaced fonts of which there are many out there.
+Arabic requires ISO-8859-6 as well as Presentation Form-B fonts
+(without Form-B, Arabic will _NOT_ be usable).	It is highly
+recommended that users search for so-called 'ISO-10646-1' fonts.
+Do an Internet search or check www.arabeyes.org for further
+info on where to attain the necessary Arabic fonts.
+
+
+Font Installation
+-----------------
+
+o  Installation of fonts for X Window systems (Unix/Linux)
+
+   Depending on your system, copy your_ARABIC_FONT file into a
+   directory of your choice.  Change to the directory containing
+   the Arabic fonts and execute the following commands:
+
+     %	mkfontdir
+     %	xset +fp path_name_of_arabic_fonts_directory
+
+
+Usage
+-----
+Prior to the actual usage of Arabic within VIM, a number of settings
+need to be accounted for and invoked.
+
+o  Setting the Arabic fonts
+
+   +  For VIM GUI set the 'guifont' to your_ARABIC_FONT.  This is done
+      by entering the following command in the VIM window.
+>
+		:set guifont=your_ARABIC_FONT
+<
+      NOTE: the string 'your_ARABIC_FONT' is used to denote a complete
+	    font name akin to that used in Linux/Unix systems.
+	    (e.g. -misc-fixed-medium-r-normal--20-200-75-75-c-100-iso10646-1)
+
+      You can append the 'guifont' set command to your .vimrc file
+      in order to get the same above noted results.  In other words,
+      you can include ':set guifont=your_ARABIC_FONT' to your .vimrc
+      file.
+
+   +  Under the X Window environment, you can also start VIM with
+      '-fn your_ARABIC_FONT' option.
+
+o  Setting the appropriate character Encoding
+   To enable the correct Arabic encoding the following command needs
+   to be appended,
+>
+		:set encoding=utf-8
+<
+   to your .vimrc file (entering the command manually into you VIM
+   window is highly discouraged).  In short, include ':set
+   encoding=utf-8' to your .vimrc file.
+
+   Attempts to use Arabic without UTF-8 will result the following
+   warning message,
+
+								*W17*  >
+     Arabic requires UTF-8, do ':set encoding=utf-8'
+
+o  Enable Arabic settings [short-cut]
+
+   In order to simplify and streamline things, you can either invoke
+   VIM with the command-line option,
+
+     % vim -A my_utf8_arabic_file ...
+
+   or enable 'arabic' via the following command within VIM
+>
+		:set arabic
+<
+   The two above noted possible invocations are the preferred manner
+   in which users are instructed to proceed.  Baring an enabled 'termbidi'
+   setting, both command options:
+
+     1. set the appropriate keymap
+     2. enable the deletion of a single combined pair character
+     3. enable rightleft    mode
+     4. enable rightleftcmd mode (affecting the command-line)
+     5. enable arabicshape  mode (do visual character alterations)
+
+   You may also append the command to your .vimrc file and simply
+   include ':set arabic' to it.
+
+   You are also capable of disabling Arabic support via
+>
+		:set noarabic
+<
+   which resets everything that the command had enabled without touching
+   the global settings as they could affect other possible open buffers.
+   In short the 'noarabic' command,
+
+     1. resets to the alternate keymap
+     2. disables the deletion of a single combined pair character
+     3. disables rightleft mode
+
+   NOTE: the 'arabic' command takes into consideration 'termbidi' for
+	 possible external bi-directional (bidi) support from the
+	 terminal ("mlterm" for instance offers such support).
+	 'termbidi', if available, is superior to rightleft support
+	 and its support is preferred due to its level of offerings.
+	 'arabic' when 'termbidi' is enabled only sets the keymap.
+
+   If, on the other hand, you'd like to be verbose and explicit and
+   are opting not to use the 'arabic' short-cut command, here's what
+   is needed (i.e. if you use ':set arabic' you can skip this section) -
+
+   +  Arabic Keymapping Activation
+
+      To activate the Arabic keymap (i.e. to remap your English/Latin
+      keyboard to look-n-feel like a standard Arabic one), set the
+      'keymap' command to "arabic".  This is done by entering
+>
+		:set keymap=arabic
+<
+      in your VIM window.  You can also append the 'keymap' set command to
+      your .vimrc file.  In other words, you can include ':set keymap=arabic'
+      to your .vimrc file.
+
+      To turn toggle (or switch) your keymapping between Arabic and the
+      default mapping (English), it is advised that users use the 'CTRL-^'
+      key press while in insert (or add/replace) mode.	The command-line
+      will display your current mapping by displaying an "Arabic" string
+      next to your insertion mode (e.g. -- INSERT Arabic --) indicating
+      your current keymap.
+
+   +  Arabic deletion of a combined pair character
+
+      By default VIM has the 'delcombine' option disabled.  This option
+      allows the deletion of ALEF in a LAM_ALEF (LAA) combined character
+      and still retain the LAM (i.e. it reverts to treating the combined
+      character as its natural two characters form -- this also pertains
+      to harakat and their combined forms).  You can enable this option
+      by entering
+>
+		:set delcombine
+<
+      in our VIM window.  You can also append the 'delcombine' set command
+      to your .vimrc file.  In other words, you can include ':set delcombine'
+      to your .vimrc file.
+
+   +  Arabic right-to-left Mode
+
+      By default VIM starts in Left-to-right mode.  'rightleft' is the
+      command that allows one to alter a window's orientation - that can
+      be accomplished via,
+
+      - Toggling between left-to-right and right-to-left modes is
+	accomplished through ':set rightleft' and ':set norightleft'.
+
+      - While in Left-to-right mode, enter ':set rl' in the command line
+	('rl' is the abbreviation for rightleft).
+
+      - Put the ':set rl' line in your '.vimrc' file to start Vim in
+	right-to-left mode permanently.
+
+   +  Arabic right-to-left command-line Mode
+
+      For certain commands the editing can be done in right-to-left mode.
+      Currently this is only applicable to search commands.
+
+      This is controlled with the 'rightleftcmd' option.  The default is
+      "search", which means that windows in which 'rightleft' is set will
+      edit search commands in right-left mode.	To disable this behavior,
+>
+		:set rightleftcmd=
+<
+      To enable right-left editing of search commands again,
+>
+		:set rightleftcmd&
+<
+   +  Arabic Shaping Mode
+
+      To activate the required visual characters alterations (shaping,
+      composing, combining) which the Arabic language requires, enable
+      the 'arabicshape' command.  This is done by entering
+>
+		:set arabicshape
+<
+      in our VIM window.  You can also append the 'arabicshape' set
+      command to your .vimrc file.  In other words, you can include
+      ':set arabicshape' to your .vimrc file.
+
+
+Keymap/Keyboard						*arabickeymap*
+---------------
+
+The character/letter encoding used in VIM is the standard UTF-8.
+It is widely discouraged that any other encoding be used or even
+attempted.
+
+Note: UTF-8 is an all encompassing encoding and as such is
+      the only supported (and encouraged) encoding with
+      regard to Arabic (all other proprietary encodings
+      should be discouraged and frowned upon).
+
+o  Keyboard
+
+   +  CTRL-^ in insert/replace mode toggles between Arabic/Latin mode
+
+   +  Keyboard mapping is based on the Microsoft's Arabic keymap (the
+      de facto standard in the Arab world):
+
+  +---------------------------------------------------------------------+
+  |!   |@   |#   |$   |%   |^   |&   |*   |(   |)   |_   |+   ||   |~  ّ |
+  |1 ١ |2 ٢ |3 ٣ |4 ٤ |5 ٥ |6 ٦ |7 ٧ |8 ٨ |9 ٩ |0 ٠ |-   |=   |\   |` ذ |
+  +---------------------------------------------------------------------+
+       |Q  َ |W  ً |E  ُ |R  ٌ |T لإ |Y إ |U ` |I ÷ |O x |P ؛ |{ < |} > |
+       |q ض |w ص |e ث |r ق |t ف |y غ |u ع |i ه |o خ |p ح |[ ج |] د |
+       +-----------------------------------------------------------+
+	 |A  ِ |S  ٍ |D [ |F ] |G لأ |H أ |J ـ |K ، |L / |:   |"   |
+	 |a ش |s س |d ي |f ب |g ل |h ا |j ت |k ن |l م |; ك |' ط |
+	 +------------------------------------------------------+
+	   |Z ~ |X  ْ |C { |V } |B لآ |N آ |M ' |< , |> . |? ؟ |
+	   |z ئ |x ء |c ؤ |v ر |b لا |n ى |m ة |, و |. ز |/ ظ |
+	   +-------------------------------------------------+
+
+Restrictions
+------------
+
+o  VIM in its GUI form does not currently support Bi-directionality
+   (i.e. the ability to see both Arabic and Latin intermixed within
+   the same line).
+
+
+Known Bugs
+----------
+
+There is one known minor bug,
+
+ 1. If you insert a haraka (e.g. Fatha (U+064E)) after a LAM (U+0644)
+    and then insert an ALEF (U+0627), the appropriate combining will
+    not happen due to the sandwiched haraka resulting in something
+    that will NOT be displayed correctly.
+
+    WORK-AROUND: Don't include harakats between LAM and ALEF combos.
+		 In general, don't anticipate to see correct visual
+		 representation with regard to harakats and LAM+ALEF
+		 combined characters (even those entered after both
+		 characters).  The problem noted is strictly a visual
+		 one, meaning saving such a file will contain all the
+		 appropriate info/encodings - nothing is lost.
+
+No other bugs are known to exist.
+
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/autocmd.txt b/share/vim/vim73/doc/autocmd.txt
new file mode 100644
index 0000000000..c129e3fc83
--- /dev/null
+++ b/share/vim/vim73/doc/autocmd.txt
@@ -0,0 +1,1303 @@
+*autocmd.txt*   For Vim version 7.3.  Last change: 2010 Jul 22
+
+
+		  VIM REFERENCE MANUAL    by Bram Moolenaar
+
+
+Automatic commands					*autocommand*
+
+For a basic explanation, see section |40.3| in the user manual.
+
+1.  Introduction		|autocmd-intro|
+2.  Defining autocommands	|autocmd-define|
+3.  Removing autocommands	|autocmd-remove|
+4.  Listing autocommands	|autocmd-list|
+5.  Events			|autocmd-events|
+6.  Patterns			|autocmd-patterns|
+7.  Buffer-local autocommands	|autocmd-buflocal|
+8.  Groups			|autocmd-groups|
+9.  Executing autocommands	|autocmd-execute|
+10. Using autocommands		|autocmd-use|
+11. Disabling autocommands	|autocmd-disable|
+
+{Vi does not have any of these commands}
+{only when the |+autocmd| feature has not been disabled at compile time}
+
+==============================================================================
+1. Introduction						*autocmd-intro*
+
+You can specify commands to be executed automatically when reading or writing
+a file, when entering or leaving a buffer or window, and when exiting Vim.
+For example, you can create an autocommand to set the 'cindent' option for
+files matching *.c.  You can also use autocommands to implement advanced
+features, such as editing compressed files (see |gzip-example|).  The usual
+place to put autocommands is in your .vimrc or .exrc file.
+
+							*E203* *E204* *E143*
+WARNING: Using autocommands is very powerful, and may lead to unexpected side
+effects.  Be careful not to destroy your text.
+- It's a good idea to do some testing on an expendable copy of a file first.
+  For example: If you use autocommands to decompress a file when starting to
+  edit it, make sure that the autocommands for compressing when writing work
+  correctly.
+- Be prepared for an error halfway through (e.g., disk full).  Vim will mostly
+  be able to undo the changes to the buffer, but you may have to clean up the
+  changes to other files by hand (e.g., compress a file that has been
+  decompressed).
+- If the BufRead* events allow you to edit a compressed file, the FileRead*
+  events should do the same (this makes recovery possible in some rare cases).
+  It's a good idea to use the same autocommands for the File* and Buf* events
+  when possible.
+
+==============================================================================
+2. Defining autocommands				*autocmd-define*
+
+Note: The ":autocmd" command cannot be followed by another command, since any
+'|' is considered part of the command.
+
+							*:au* *:autocmd*
+:au[tocmd] [group] {event} {pat} [nested] {cmd}
+			Add {cmd} to the list of commands that Vim will
+			execute automatically on {event} for a file matching
+			{pat} |autocmd-patterns|.
+			Vim always adds the {cmd} after existing autocommands,
+			so that the autocommands execute in the order in which
+			they were given.  See |autocmd-nested| for [nested].
+
+The special pattern  or  defines a buffer-local autocommand.
+See |autocmd-buflocal|.
+
+Note that special characters (e.g., "%", "") in the ":autocmd"
+arguments are not expanded when the autocommand is defined.  These will be
+expanded when the Event is recognized, and the {cmd} is executed.  The only
+exception is that "" is expanded when the autocmd is defined.  Example:
+>
+	:au BufNewFile,BufRead *.html so :h/html.vim
+
+Here Vim expands  to the name of the file containing this line.
+
+When your .vimrc file is sourced twice, the autocommands will appear twice.
+To avoid this, put this command in your .vimrc file, before defining
+autocommands: >
+
+	:autocmd!	" Remove ALL autocommands for the current group.
+
+If you don't want to remove all autocommands, you can instead use a variable
+to ensure that Vim includes the autocommands only once: >
+
+	:if !exists("autocommands_loaded")
+	:  let autocommands_loaded = 1
+	:  au ...
+	:endif
+
+When the [group] argument is not given, Vim uses the current group (as defined
+with ":augroup"); otherwise, Vim uses the group defined with [group].  Note
+that [group] must have been defined before.  You cannot define a new group
+with ":au group ..."; use ":augroup" for that.
+
+While testing autocommands, you might find the 'verbose' option to be useful: >
+	:set verbose=9
+This setting makes Vim echo the autocommands as it executes them.
+
+When defining an autocommand in a script, it will be able to call functions
+local to the script and use mappings local to the script.  When the event is
+triggered and the command executed, it will run in the context of the script
+it was defined in.  This matters if || is used in a command.
+
+When executing the commands, the message from one command overwrites a
+previous message.  This is different from when executing the commands
+manually.  Mostly the screen will not scroll up, thus there is no hit-enter
+prompt.  When one command outputs two messages this can happen anyway.
+
+==============================================================================
+3. Removing autocommands				*autocmd-remove*
+
+:au[tocmd]! [group] {event} {pat} [nested] {cmd}
+			Remove all autocommands associated with {event} and
+			{pat}, and add the command {cmd}.  See
+			|autocmd-nested| for [nested].
+
+:au[tocmd]! [group] {event} {pat}
+			Remove all autocommands associated with {event} and
+			{pat}.
+
+:au[tocmd]! [group] * {pat}
+			Remove all autocommands associated with {pat} for all
+			events.
+
+:au[tocmd]! [group] {event}
+			Remove ALL autocommands for {event}.
+
+:au[tocmd]! [group]	Remove ALL autocommands.
+
+When the [group] argument is not given, Vim uses the current group (as defined
+with ":augroup"); otherwise, Vim uses the group defined with [group].
+
+==============================================================================
+4. Listing autocommands					*autocmd-list*
+
+:au[tocmd] [group] {event} {pat}
+			Show the autocommands associated with {event} and
+			{pat}.
+
+:au[tocmd] [group] * {pat}
+			Show the autocommands associated with {pat} for all
+			events.
+
+:au[tocmd] [group] {event}
+			Show all autocommands for {event}.
+
+:au[tocmd] [group]	Show all autocommands.
+
+If you provide the [group] argument, Vim lists only the autocommands for
+[group]; otherwise, Vim lists the autocommands for ALL groups.  Note that this
+argument behavior differs from that for defining and removing autocommands.
+
+In order to list buffer-local autocommands, use a pattern in the form 
+or .  See |autocmd-buflocal|.
+
+							*:autocmd-verbose*
+When 'verbose' is non-zero, listing an autocommand will also display where it
+was last defined. Example: >
+
+    :verbose autocmd BufEnter
+    FileExplorer  BufEnter
+	*	  call s:LocalBrowse(expand(""))
+	    Last set from /usr/share/vim/vim-7.0/plugin/NetrwPlugin.vim
+<
+See |:verbose-cmd| for more information.
+
+==============================================================================
+5. Events					*autocmd-events* *E215* *E216*
+
+You can specify a comma-separated list of event names.  No white space can be
+used in this list.  The command applies to all the events in the list.
+
+For READING FILES there are four kinds of events possible:
+	BufNewFile			starting to edit a non-existent file
+	BufReadPre	BufReadPost	starting to edit an existing file
+	FilterReadPre	FilterReadPost	read the temp file with filter output
+	FileReadPre	FileReadPost	any other file read
+Vim uses only one of these four kinds when reading a file.  The "Pre" and
+"Post" events are both triggered, before and after reading the file.
+
+Note that the autocommands for the *ReadPre events and all the Filter events
+are not allowed to change the current buffer (you will get an error message if
+this happens).  This is to prevent the file to be read into the wrong buffer.
+
+Note that the 'modified' flag is reset AFTER executing the BufReadPost
+and BufNewFile autocommands.  But when the 'modified' option was set by the
+autocommands, this doesn't happen.
+
+You can use the 'eventignore' option to ignore a number of events or all
+events.
+					*autocommand-events* *{event}*
+Vim recognizes the following events.  Vim ignores the case of event names
+(e.g., you can use "BUFread" or "bufread" instead of "BufRead").
+
+First an overview by function with a short explanation.  Then the list
+alphabetically with full explanations |autocmd-events-abc|.
+
+Name			triggered by ~
+
+	Reading
+|BufNewFile|		starting to edit a file that doesn't exist
+|BufReadPre|		starting to edit a new buffer, before reading the file
+|BufRead|		starting to edit a new buffer, after reading the file
+|BufReadPost|		starting to edit a new buffer, after reading the file
+|BufReadCmd|		before starting to edit a new buffer |Cmd-event|
+
+|FileReadPre|		before reading a file with a ":read" command
+|FileReadPost|		after reading a file with a ":read" command
+|FileReadCmd|		before reading a file with a ":read" command |Cmd-event|
+
+|FilterReadPre|		before reading a file from a filter command
+|FilterReadPost|	after reading a file from a filter command
+
+|StdinReadPre|		before reading from stdin into the buffer
+|StdinReadPost|		After reading from the stdin into the buffer
+
+	Writing
+|BufWrite|		starting to write the whole buffer to a file
+|BufWritePre|		starting to write the whole buffer to a file
+|BufWritePost|		after writing the whole buffer to a file
+|BufWriteCmd|		before writing the whole buffer to a file |Cmd-event|
+
+|FileWritePre|		starting to write part of a buffer to a file
+|FileWritePost|		after writing part of a buffer to a file
+|FileWriteCmd|		before writing part of a buffer to a file |Cmd-event|
+
+|FileAppendPre|		starting to append to a file
+|FileAppendPost|	after appending to a file
+|FileAppendCmd|		before appending to a file |Cmd-event|
+
+|FilterWritePre|	starting to write a file for a filter command or diff
+|FilterWritePost|	after writing a file for a filter command or diff
+
+	Buffers
+|BufAdd|		just after adding a buffer to the buffer list
+|BufCreate|		just after adding a buffer to the buffer list
+|BufDelete|		before deleting a buffer from the buffer list
+|BufWipeout|		before completely deleting a buffer
+
+|BufFilePre|		before changing the name of the current buffer
+|BufFilePost|		after changing the name of the current buffer
+
+|BufEnter|		after entering a buffer
+|BufLeave|		before leaving to another buffer
+|BufWinEnter|		after a buffer is displayed in a window
+|BufWinLeave|		before a buffer is removed from a window
+
+|BufUnload|		before unloading a buffer
+|BufHidden|		just after a buffer has become hidden
+|BufNew|		just after creating a new buffer
+
+|SwapExists|		detected an existing swap file
+
+	Options
+|FileType|		when the 'filetype' option has been set
+|Syntax|		when the 'syntax' option has been set
+|EncodingChanged|	after the 'encoding' option has been changed
+|TermChanged|		after the value of 'term' has changed
+
+	Startup and exit
+|VimEnter|		after doing all the startup stuff
+|GUIEnter|		after starting the GUI successfully
+|TermResponse|		after the terminal response to |t_RV| is received
+
+|VimLeavePre|		before exiting Vim, before writing the viminfo file
+|VimLeave|		before exiting Vim, after writing the viminfo file
+
+	Various
+|FileChangedShell|	Vim notices that a file changed since editing started
+|FileChangedShellPost|	After handling a file changed since editing started
+|FileChangedRO|		before making the first change to a read-only file
+
+|ShellCmdPost|		after executing a shell command
+|ShellFilterPost|	after filtering with a shell command
+
+|FuncUndefined|		a user function is used but it isn't defined
+|SpellFileMissing|	a spell file is used but it can't be found
+|SourcePre|		before sourcing a Vim script
+|SourceCmd|		before sourcing a Vim script |Cmd-event|
+
+|VimResized|		after the Vim window size changed
+|FocusGained|		Vim got input focus
+|FocusLost|		Vim lost input focus
+|CursorHold|		the user doesn't press a key for a while
+|CursorHoldI|		the user doesn't press a key for a while in Insert mode
+|CursorMoved|		the cursor was moved in Normal mode
+|CursorMovedI|		the cursor was moved in Insert mode
+
+|WinEnter|		after entering another window
+|WinLeave|		before leaving a window
+|TabEnter|		after entering another tab page
+|TabLeave|		before leaving a tab page
+|CmdwinEnter|		after entering the command-line window
+|CmdwinLeave|		before leaving the command-line window
+
+|InsertEnter|		starting Insert mode
+|InsertChange|		when typing  while in Insert or Replace mode
+|InsertLeave|		when leaving Insert mode
+
+|ColorScheme|		after loading a color scheme
+
+|RemoteReply|		a reply from a server Vim was received
+
+|QuickFixCmdPre|	before a quickfix command is run
+|QuickFixCmdPost|	after a quickfix command is run
+
+|SessionLoadPost|	after loading a session file
+
+|MenuPopup|		just before showing the popup menu
+
+|User|			to be used in combination with ":doautocmd"
+
+
+The alphabetical list of autocommand events:		*autocmd-events-abc*
+
+							*BufCreate* *BufAdd*
+BufAdd or BufCreate		Just after creating a new buffer which is
+				added to the buffer list, or adding a buffer
+				to the buffer list.
+				Also used just after a buffer in the buffer
+				list has been renamed.
+				The BufCreate event is for historic reasons.
+				NOTE: When this autocommand is executed, the
+				current buffer "%" may be different from the
+				buffer being created "".
+							*BufDelete*
+BufDelete			Before deleting a buffer from the buffer list.
+				The BufUnload may be called first (if the
+				buffer was loaded).
+				Also used just before a buffer in the buffer
+				list is renamed.
+				NOTE: When this autocommand is executed, the
+				current buffer "%" may be different from the
+				buffer being deleted "" and "".
+				Don't change to another buffer, it will cause
+				problems.
+							*BufEnter*
+BufEnter			After entering a buffer.  Useful for setting
+				options for a file type.  Also executed when
+				starting to edit a buffer, after the
+				BufReadPost autocommands.
+							*BufFilePost*
+BufFilePost			After changing the name of the current buffer
+				with the ":file" or ":saveas" command.
+							*BufFilePre*
+BufFilePre			Before changing the name of the current buffer
+				with the ":file" or ":saveas" command.
+							*BufHidden*
+BufHidden			Just after a buffer has become hidden.  That
+				is, when there are no longer windows that show
+				the buffer, but the buffer is not unloaded or
+				deleted.  Not used for ":qa" or ":q" when
+				exiting Vim.
+				NOTE: When this autocommand is executed, the
+				current buffer "%" may be different from the
+				buffer being unloaded "".
+							*BufLeave*
+BufLeave			Before leaving to another buffer.  Also when
+				leaving or closing the current window and the
+				new current window is not for the same buffer.
+				Not used for ":qa" or ":q" when exiting Vim.
+							*BufNew*
+BufNew				Just after creating a new buffer.  Also used
+				just after a buffer has been renamed.  When
+				the buffer is added to the buffer list BufAdd
+				will be triggered too.
+				NOTE: When this autocommand is executed, the
+				current buffer "%" may be different from the
+				buffer being created "".
+							*BufNewFile*
+BufNewFile			When starting to edit a file that doesn't
+				exist.  Can be used to read in a skeleton
+				file.
+						*BufRead* *BufReadPost*
+BufRead or BufReadPost		When starting to edit a new buffer, after
+				reading the file into the buffer, before
+				executing the modelines.  See |BufWinEnter|
+				for when you need to do something after
+				processing the modelines.
+				This does NOT work for ":r file".  Not used
+				when the file doesn't exist.  Also used after
+				successfully recovering a file.
+							*BufReadCmd*
+BufReadCmd			Before starting to edit a new buffer.  Should
+				read the file into the buffer. |Cmd-event|
+						*BufReadPre* *E200* *E201*
+BufReadPre			When starting to edit a new buffer, before
+				reading the file into the buffer.  Not used
+				if the file doesn't exist.
+							*BufUnload*
+BufUnload			Before unloading a buffer.  This is when the
+				text in the buffer is going to be freed.  This
+				may be after a BufWritePost and before a
+				BufDelete.  Also used for all buffers that are
+				loaded when Vim is going to exit.
+				NOTE: When this autocommand is executed, the
+				current buffer "%" may be different from the
+				buffer being unloaded "".
+				Don't change to another buffer, it will cause
+				problems.
+				When exiting and v:dying is 2 or more this
+				event is not triggered.
+							*BufWinEnter*
+BufWinEnter			After a buffer is displayed in a window.  This
+				can be when the buffer is loaded (after
+				processing the modelines) or when a hidden
+				buffer is displayed in a window (and is no
+				longer hidden).
+				Does not happen for |:split| without
+				arguments, since you keep editing the same
+				buffer, or ":split" with a file that's already
+				open in a window, because it re-uses an
+				existing buffer.  But it does happen for a
+				":split" with the name of the current buffer,
+				since it reloads that buffer.
+							*BufWinLeave*
+BufWinLeave			Before a buffer is removed from a window.
+				Not when it's still visible in another window.
+				Also triggered when exiting.  It's triggered
+				before BufUnload or BufHidden.
+				NOTE: When this autocommand is executed, the
+				current buffer "%" may be different from the
+				buffer being unloaded "".
+				When exiting and v:dying is 2 or more this
+				event is not triggered.
+							*BufWipeout*
+BufWipeout			Before completely deleting a buffer.  The
+				BufUnload and BufDelete events may be called
+				first (if the buffer was loaded and was in the
+				buffer list).  Also used just before a buffer
+				is renamed (also when it's not in the buffer
+				list).
+				NOTE: When this autocommand is executed, the
+				current buffer "%" may be different from the
+				buffer being deleted "".
+				Don't change to another buffer, it will cause
+				problems.
+						*BufWrite* *BufWritePre*
+BufWrite or BufWritePre		Before writing the whole buffer to a file.
+							*BufWriteCmd*
+BufWriteCmd			Before writing the whole buffer to a file.
+				Should do the writing of the file and reset
+				'modified' if successful, unless '+' is in
+				'cpo' and writing to another file |cpo-+|.
+				The buffer contents should not be changed.
+				|Cmd-event|
+							*BufWritePost*
+BufWritePost			After writing the whole buffer to a file
+				(should undo the commands for BufWritePre).
+							*CmdwinEnter*
+CmdwinEnter			After entering the command-line window.
+				Useful for setting options specifically for
+				this special type of window.  This is
+				triggered _instead_ of BufEnter and WinEnter.
+				 is set to a single character,
+				indicating the type of command-line.
+				|cmdwin-char|
+							*CmdwinLeave*
+CmdwinLeave			Before leaving the command-line window.
+				Useful to clean up any global setting done
+				with CmdwinEnter.  This is triggered _instead_
+				of BufLeave and WinLeave.
+				 is set to a single character,
+				indicating the type of command-line.
+				|cmdwin-char|
+							*ColorScheme*
+ColorScheme			After loading a color scheme. |:colorscheme|
+
+							*CursorHold*
+CursorHold			When the user doesn't press a key for the time
+				specified with 'updatetime'.  Not re-triggered
+				until the user has pressed a key (i.e. doesn't
+				fire every 'updatetime' ms if you leave Vim to
+				make some coffee. :)  See |CursorHold-example|
+				for previewing tags.
+				This event is only triggered in Normal mode.
+				It is not triggered when waiting for a command
+				argument to be typed, or a movement after an
+				operator.
+				While recording the CursorHold event is not
+				triggered. |q|
+				Note: Interactive commands cannot be used for
+				this event.  There is no hit-enter prompt,
+				the screen is updated directly (when needed).
+				Note: In the future there will probably be
+				another option to set the time.
+				Hint: to force an update of the status lines
+				use: >
+					:let &ro = &ro
+<				{only on Amiga, Unix, Win32, MSDOS and all GUI
+				versions}
+							*CursorHoldI*
+CursorHoldI			Just like CursorHold, but in Insert mode.
+
+							*CursorMoved*
+CursorMoved			After the cursor was moved in Normal mode.
+				Also when the text of the cursor line has been
+				changed, e.g., with "x", "rx" or "p".
+				Not triggered when there is typeahead or when
+				an operator is pending.
+				For an example see |match-parens|.
+				Careful: Don't do anything that the user does
+				not expect or that is slow.
+							*CursorMovedI*
+CursorMovedI			After the cursor was moved in Insert mode.
+				Otherwise the same as CursorMoved.
+							*EncodingChanged*
+EncodingChanged			Fires off after the 'encoding' option has been
+				changed.  Useful to set up fonts, for example.
+							*FileAppendCmd*
+FileAppendCmd			Before appending to a file.  Should do the
+				appending to the file.  Use the '[ and ']
+				marks for the range of lines.|Cmd-event|
+							*FileAppendPost*
+FileAppendPost			After appending to a file.
+							*FileAppendPre*
+FileAppendPre			Before appending to a file.  Use the '[ and ']
+				marks for the range of lines.
+							*FileChangedRO*
+FileChangedRO			Before making the first change to a read-only
+				file.  Can be used to check-out the file from
+				a source control system.  Not triggered when
+				the change was caused by an autocommand.
+				This event is triggered when making the first
+				change in a buffer or the first change after
+				'readonly' was set, just before the change is
+				applied to the text.
+				WARNING: If the autocommand moves the cursor
+				the effect of the change is undefined.
+							*E788*
+				It is not allowed to change to another buffer
+				here.  You can reload the buffer but not edit
+				another one.
+							*FileChangedShell*
+FileChangedShell		When Vim notices that the modification time of
+				a file has changed since editing started.
+				Also when the file attributes of the file
+				change. |timestamp|
+				Mostly triggered after executing a shell
+				command, but also with a |:checktime| command
+				or when Gvim regains input focus.
+				This autocommand is triggered for each changed
+				file.  It is not used when 'autoread' is set
+				and the buffer was not changed.  If a
+				FileChangedShell autocommand is present the
+				warning message and prompt is not given.
+				The |v:fcs_reason| variable is set to indicate
+				what happened and |v:fcs_choice| can be used
+				to tell Vim what to do next.
+				NOTE: When this autocommand is executed, the
+				current buffer "%" may be different from the
+				buffer that was changed "".
+				NOTE: The commands must not change the current
+				buffer, jump to another buffer or delete a
+				buffer.  *E246* *E811*
+				NOTE: This event never nests, to avoid an
+				endless loop.  This means that while executing
+				commands for the FileChangedShell event no
+				other FileChangedShell event will be
+				triggered.
+							*FileChangedShellPost*
+FileChangedShellPost		After handling a file that was changed outside
+				of Vim.  Can be used to update the statusline.
+							*FileEncoding*
+FileEncoding			Obsolete.  It still works and is equivalent
+				to |EncodingChanged|.
+							*FileReadCmd*
+FileReadCmd			Before reading a file with a ":read" command.
+				Should do the reading of the file. |Cmd-event|
+							*FileReadPost*
+FileReadPost			After reading a file with a ":read" command.
+				Note that Vim sets the '[ and '] marks to the
+				first and last line of the read.  This can be
+				used to operate on the lines just read.
+							*FileReadPre*
+FileReadPre			Before reading a file with a ":read" command.
+							*FileType*
+FileType			When the 'filetype' option has been set.  The
+				pattern is matched against the filetype.
+				 can be used for the name of the file
+				where this option was set, and  for
+				the new value of 'filetype'.
+				See |filetypes|.
+							*FileWriteCmd*
+FileWriteCmd			Before writing to a file, when not writing the
+				whole buffer.  Should do the writing to the
+				file.  Should not change the buffer.  Use the
+				'[ and '] marks for the range of lines.
+				|Cmd-event|
+							*FileWritePost*
+FileWritePost			After writing to a file, when not writing the
+				whole buffer.
+							*FileWritePre*
+FileWritePre			Before writing to a file, when not writing the
+				whole buffer.  Use the '[ and '] marks for the
+				range of lines.
+							*FilterReadPost*
+FilterReadPost			After reading a file from a filter command.
+				Vim checks the pattern against the name of
+				the current buffer as with FilterReadPre.
+				Not triggered when 'shelltemp' is off.
+							*FilterReadPre* *E135*
+FilterReadPre			Before reading a file from a filter command.
+				Vim checks the pattern against the name of
+				the current buffer, not the name of the
+				temporary file that is the output of the
+				filter command.
+				Not triggered when 'shelltemp' is off.
+							*FilterWritePost*
+FilterWritePost			After writing a file for a filter command or
+				making a diff.
+				Vim checks the pattern against the name of
+				the current buffer as with FilterWritePre.
+				Not triggered when 'shelltemp' is off.
+							*FilterWritePre*
+FilterWritePre			Before writing a file for a filter command or
+				making a diff.
+				Vim checks the pattern against the name of
+				the current buffer, not the name of the
+				temporary file that is the output of the
+				filter command.
+				Not triggered when 'shelltemp' is off.
+							*FocusGained*
+FocusGained			When Vim got input focus.  Only for the GUI
+				version and a few console versions where this
+				can be detected.
+							*FocusLost*
+FocusLost			When Vim lost input focus.  Only for the GUI
+				version and a few console versions where this
+				can be detected.  May also happen when a
+				dialog pops up.
+							*FuncUndefined*
+FuncUndefined			When a user function is used but it isn't
+				defined.  Useful for defining a function only
+				when it's used.  The pattern is matched
+				against the function name.  Both  and
+				 are set to the name of the function.
+				See |autoload-functions|.
+							*GUIEnter*
+GUIEnter			After starting the GUI successfully, and after
+				opening the window.  It is triggered before
+				VimEnter when using gvim.  Can be used to
+				position the window from a .gvimrc file: >
+	:autocmd GUIEnter * winpos 100 50
+<							*GUIFailed*
+GUIFailed			After starting the GUI failed.  Vim may
+				continue to run in the terminal, if possible
+				(only on Unix and alikes, when connecting the
+				X server fails).  You may want to quit Vim: >
+	:autocmd GUIFailed * qall
+<							*InsertChange*
+InsertChange			When typing  while in Insert or
+				Replace mode.  The |v:insertmode| variable
+				indicates the new mode.
+				Be careful not to move the cursor or do
+				anything else that the user does not expect.
+							*InsertEnter*
+InsertEnter			Just before starting Insert mode.  Also for
+				Replace mode and Virtual Replace mode.  The
+				|v:insertmode| variable indicates the mode.
+				Be careful not to move the cursor or do
+				anything else that the user does not expect.
+							*InsertLeave*
+InsertLeave			When leaving Insert mode.  Also when using
+				CTRL-O |i_CTRL-O|.  But not for |i_CTRL-C|.
+							*MenuPopup*
+MenuPopup			Just before showing the popup menu (under the
+				right mouse button).  Useful for adjusting the
+				menu for what is under the cursor or mouse
+				pointer.
+				The pattern is matched against a single
+				character representing the mode:
+					n	Normal
+					v	Visual
+					o	Operator-pending
+					i	Insert
+					c	Command line
+							*QuickFixCmdPre*
+QuickFixCmdPre			Before a quickfix command is run (|:make|,
+				|:lmake|, |:grep|, |:lgrep|, |:grepadd|,
+				|:lgrepadd|, |:vimgrep|, |:lvimgrep|,
+				|:vimgrepadd|, |:lvimgrepadd|, |:cscope|).
+				The pattern is matched against the command
+				being run.  When |:grep| is used but 'grepprg'
+				is set to "internal" it still matches "grep".
+				This command cannot be used to set the
+				'makeprg' and 'grepprg' variables.
+				If this command causes an error, the quickfix
+				command is not executed.
+							*QuickFixCmdPost*
+QuickFixCmdPost			Like QuickFixCmdPre, but after a quickfix
+				command is run, before jumping to the first
+				location.  See |QuickFixCmdPost-example|.
+							*RemoteReply*
+RemoteReply			When a reply from a Vim that functions as
+				server was received |server2client()|.  The
+				pattern is matched against the {serverid}.
+				 is equal to the {serverid} from which
+				the reply was sent, and  is the actual
+				reply string.
+				Note that even if an autocommand is defined,
+				the reply should be read with |remote_read()|
+				to consume it.
+							*SessionLoadPost*
+SessionLoadPost			After loading the session file created using
+				the |:mksession| command.
+							*ShellCmdPost*
+ShellCmdPost			After executing a shell command with |:!cmd|,
+				|:shell|, |:make| and |:grep|.  Can be used to
+				check for any changed files.
+							*ShellFilterPost*
+ShellFilterPost			After executing a shell command with
+				":{range}!cmd", ":w !cmd" or ":r !cmd".
+				Can be used to check for any changed files.
+							*SourcePre*
+SourcePre			Before sourcing a Vim script. |:source|
+				 is the name of the file being sourced.
+							*SourceCmd*
+SourceCmd			When sourcing a Vim script. |:source|
+				 is the name of the file being sourced.
+				The autocommand must source this file.
+				|Cmd-event|
+							*SpellFileMissing*
+SpellFileMissing		When trying to load a spell checking file and
+				it can't be found.  The pattern is matched
+				against the language.   is the
+				language, 'encoding' also matters.  See
+				|spell-SpellFileMissing|.
+							*StdinReadPost*
+StdinReadPost			After reading from the stdin into the buffer,
+				before executing the modelines.  Only used
+				when the "-" argument was used when Vim was
+				started |--|.
+							*StdinReadPre*
+StdinReadPre			Before reading from stdin into the buffer.
+				Only used when the "-" argument was used when
+				Vim was started |--|.
+							*SwapExists*
+SwapExists			Detected an existing swap file when starting
+				to edit a file.  Only when it is possible to
+				select a way to handle the situation, when Vim
+				would ask the user what to do.
+				The |v:swapname| variable holds the name of
+				the swap file found,  the file being
+				edited.  |v:swapcommand| may contain a command
+				to be executed in the opened file.
+				The commands should set the |v:swapchoice|
+				variable to a string with one character to
+				tell Vim what should be done next:
+					'o'	open read-only
+					'e'	edit the file anyway
+					'r'	recover
+					'd'	delete the swap file
+					'q'	quit, don't edit the file
+					'a'	abort, like hitting CTRL-C
+				When set to an empty string the user will be
+				asked, as if there was no SwapExists autocmd.
+							*E812*
+				It is not allowed to change to another buffer,
+				change a buffer name or change directory
+				here.
+							*Syntax*
+Syntax				When the 'syntax' option has been set.  The
+				pattern is matched against the syntax name.
+				 can be used for the name of the file
+				where this option was set, and  for
+				the new value of 'syntax'.
+				See |:syn-on|.
+							*TabEnter*
+TabEnter			Just after entering a tab page. |tab-page|
+				After triggering the WinEnter and before
+				triggering the BufEnter event.
+							*TabLeave*
+TabLeave			Just before leaving a tab page. |tab-page|
+				A WinLeave event will have been triggered
+				first.
+							*TermChanged*
+TermChanged			After the value of 'term' has changed.  Useful
+				for re-loading the syntax file to update the
+				colors, fonts and other terminal-dependent
+				settings.  Executed for all loaded buffers.
+							*TermResponse*
+TermResponse			After the response to |t_RV| is received from
+				the terminal.  The value of |v:termresponse|
+				can be used to do things depending on the
+				terminal version.
+							*User*
+User				Never executed automatically.  To be used for
+				autocommands that are only executed with
+				":doautocmd".
+							*UserGettingBored*
+UserGettingBored		When the user hits CTRL-C.  Just kidding! :-)
+							*VimEnter*
+VimEnter			After doing all the startup stuff, including
+				loading .vimrc files, executing the "-c cmd"
+				arguments, creating all windows and loading
+				the buffers in them.
+							*VimLeave*
+VimLeave			Before exiting Vim, just after writing the
+				.viminfo file.  Executed only once, like
+				VimLeavePre.
+				To detect an abnormal exit use |v:dying|.
+				When v:dying is 2 or more this event is not
+				triggered.
+							*VimLeavePre*
+VimLeavePre			Before exiting Vim, just before writing the
+				.viminfo file.  This is executed only once,
+				if there is a match with the name of what
+				happens to be the current buffer when exiting.
+				Mostly useful with a "*" pattern. >
+	:autocmd VimLeavePre * call CleanupStuff()
+<				To detect an abnormal exit use |v:dying|.
+				When v:dying is 2 or more this event is not
+				triggered.
+							*VimResized*
+VimResized			After the Vim window was resized, thus 'lines'
+				and/or 'columns' changed.  Not when starting
+				up though.
+							*WinEnter*
+WinEnter			After entering another window.  Not done for
+				the first window, when Vim has just started.
+				Useful for setting the window height.
+				If the window is for another buffer, Vim
+				executes the BufEnter autocommands after the
+				WinEnter autocommands.
+				Note: When using ":split fname" the WinEnter
+				event is triggered after the split but before
+				the file "fname" is loaded.
+							*WinLeave*
+WinLeave			Before leaving a window.  If the window to be
+				entered next is for a different buffer, Vim
+				executes the BufLeave autocommands before the
+				WinLeave autocommands (but not for ":new").
+				Not used for ":qa" or ":q" when exiting Vim.
+
+==============================================================================
+6. Patterns					*autocmd-patterns* *{pat}*
+
+The file pattern {pat} is tested for a match against the file name in one of
+two ways:
+1. When there is no '/' in the pattern, Vim checks for a match against only
+   the tail part of the file name (without its leading directory path).
+2. When there is a '/' in the pattern, Vim checks for a match against both the
+   short file name (as you typed it) and the full file name (after expanding
+   it to a full path and resolving symbolic links).
+
+The special pattern  or  is used for buffer-local
+autocommands |autocmd-buflocal|.  This pattern is not matched against the name
+of a buffer.
+
+Examples: >
+	:autocmd BufRead *.txt		set et
+Set the 'et' option for all text files. >
+
+	:autocmd BufRead /vim/src/*.c	set cindent
+Set the 'cindent' option for C files in the /vim/src directory. >
+
+	:autocmd BufRead /tmp/*.c	set ts=5
+If you have a link from "/tmp/test.c" to "/home/nobody/vim/src/test.c", and
+you start editing "/tmp/test.c", this autocommand will match.
+
+Note:  To match part of a path, but not from the root directory, use a '*' as
+the first character.  Example: >
+	:autocmd BufRead */doc/*.txt	set tw=78
+This autocommand will for example be executed for "/tmp/doc/xx.txt" and
+"/usr/home/piet/doc/yy.txt".  The number of directories does not matter here.
+
+
+The file name that the pattern is matched against is after expanding
+wildcards.  Thus if you issue this command: >
+	:e $ROOTDIR/main.$EXT
+The argument is first expanded to: >
+	/usr/root/main.py
+Before it's matched with the pattern of the autocommand.  Careful with this
+when using events like FileReadCmd, the value of  may not be what you
+expect.
+
+
+Environment variables can be used in a pattern: >
+	:autocmd BufRead $VIMRUNTIME/doc/*.txt  set expandtab
+And ~ can be used for the home directory (if $HOME is defined): >
+	:autocmd BufWritePost ~/.vimrc   so ~/.vimrc
+	:autocmd BufRead ~archive/*      set readonly
+The environment variable is expanded when the autocommand is defined, not when
+the autocommand is executed.  This is different from the command!
+
+							*file-pattern*
+The pattern is interpreted like mostly used in file names:
+	*	matches any sequence of characters
+	?	matches any single character
+	\?	matches a '?'
+	.	matches a '.'
+	~	matches a '~'
+	,	separates patterns
+	\,	matches a ','
+	{ }	like \( \) in a |pattern|
+	,	inside { }: like \| in a |pattern|
+	\	special meaning like in a |pattern|
+	[ch]	matches 'c' or 'h'
+	[^ch]   match any character but 'c' and 'h'
+
+Note that for all systems the '/' character is used for path separator (even
+MS-DOS and OS/2).  This was done because the backslash is difficult to use
+in a pattern and to make the autocommands portable across different systems.
+
+							*autocmd-changes*
+Matching with the pattern is done when an event is triggered.  Changing the
+buffer name in one of the autocommands, or even deleting the buffer, does not
+change which autocommands will be executed.  Example: >
+
+	au BufEnter *.foo  bdel
+	au BufEnter *.foo  set modified
+
+This will delete the current buffer and then set 'modified' in what has become
+the current buffer instead.  Vim doesn't take into account that "*.foo"
+doesn't match with that buffer name.  It matches "*.foo" with the name of the
+buffer at the moment the event was triggered.
+
+However, buffer-local autocommands will not be executed for a buffer that has
+been wiped out with |:bwipe|.  After deleting the buffer with |:bdel| the
+buffer actually still exists (it becomes unlisted), thus the autocommands are
+still executed.
+
+==============================================================================
+7. Buffer-local autocommands	*autocmd-buflocal* *autocmd-buffer-local*
+					** ** *E680*
+
+Buffer-local autocommands are attached to a specific buffer.  They are useful
+if the buffer does not have a name and when the name does not match a specific
+pattern.  But it also means they must be explicitly added to each buffer.
+
+Instead of a pattern buffer-local autocommands use one of these forms:
+		current buffer
+		buffer number 99
+		using  (only when executing autocommands)
+			||
+
+Examples: >
+    :au CursorHold   echo 'hold'
+    :au CursorHold   echo 'hold'
+    :au CursorHold   echo 'hold'
+
+All the commands for autocommands also work with buffer-local autocommands,
+simply use the special string instead of the pattern.  Examples: >
+    :au! * 		     " remove buffer-local autocommands for
+				     " current buffer
+    :au! * 		     " remove buffer-local autocommands for
+				     " buffer #33
+    :bufdo :au! CursorHold   " remove autocmd for given event for all
+				     " buffers
+    :au * 		     " list buffer-local autocommands for
+				     " current buffer
+
+Note that when an autocommand is defined for the current buffer, it is stored
+with the buffer number.  Thus it uses the form "", where 12 is the
+number of the current buffer.  You will see this when listing autocommands,
+for example.
+
+To test for presence of buffer-local autocommands use the |exists()| function
+as follows: >
+    :if exists("#CursorHold#") | ... | endif
+    :if exists("#CursorHold#") | ... | endif    " for current buffer
+
+When a buffer is wiped out its buffer-local autocommands are also gone, of
+course.  Note that when deleting a buffer, e.g., with ":bdel", it is only
+unlisted, the autocommands are still present.  In order to see the removal of
+buffer-local autocommands: >
+    :set verbose=6
+
+It is not possible to define buffer-local autocommands for a non-existent
+buffer.
+
+==============================================================================
+8. Groups						*autocmd-groups*
+
+Autocommands can be put together in a group.  This is useful for removing or
+executing a group of autocommands.  For example, all the autocommands for
+syntax highlighting are put in the "highlight" group, to be able to execute
+":doautoall highlight BufRead" when the GUI starts.
+
+When no specific group is selected, Vim uses the default group.  The default
+group does not have a name.  You cannot execute the autocommands from the
+default group separately; you can execute them only by executing autocommands
+for all groups.
+
+Normally, when executing autocommands automatically, Vim uses the autocommands
+for all groups.  The group only matters when executing autocommands with
+":doautocmd" or ":doautoall", or when defining or deleting autocommands.
+
+The group name can contain any characters except white space.  The group name
+"end" is reserved (also in uppercase).
+
+The group name is case sensitive.  Note that this is different from the event
+name!
+
+							*:aug* *:augroup*
+:aug[roup] {name}		Define the autocmd group name for the
+				following ":autocmd" commands.  The name "end"
+				or "END" selects the default group.
+
+						*:augroup-delete* *E367*
+:aug[roup]! {name}		Delete the autocmd group {name}.  Don't use
+				this if there is still an autocommand using
+				this group!  This is not checked.
+
+To enter autocommands for a specific group, use this method:
+1. Select the group with ":augroup {name}".
+2. Delete any old autocommands with ":au!".
+3. Define the autocommands.
+4. Go back to the default group with "augroup END".
+
+Example: >
+	:augroup uncompress
+	:  au!
+	:  au BufEnter *.gz	%!gunzip
+	:augroup END
+
+This prevents having the autocommands defined twice (e.g., after sourcing the
+.vimrc file again).
+
+==============================================================================
+9. Executing autocommands				*autocmd-execute*
+
+Vim can also execute Autocommands non-automatically.  This is useful if you
+have changed autocommands, or when Vim has executed the wrong autocommands
+(e.g., the file pattern match was wrong).
+
+Note that the 'eventignore' option applies here too.  Events listed in this
+option will not cause any commands to be executed.
+
+					*:do* *:doau* *:doautocmd* *E217*
+:do[autocmd] [group] {event} [fname]
+			Apply the autocommands matching [fname] (default:
+			current file name) for {event} to the current buffer.
+			You can use this when the current file name does not
+			match the right pattern, after changing settings, or
+			to execute autocommands for a certain event.
+			It's possible to use this inside an autocommand too,
+			so you can base the autocommands for one extension on
+			another extension.  Example: >
+				:au Bufenter *.cpp so ~/.vimrc_cpp
+				:au Bufenter *.cpp doau BufEnter x.c
+<			Be careful to avoid endless loops.  See
+			|autocmd-nested|.
+
+			When the [group] argument is not given, Vim executes
+			the autocommands for all groups.  When the [group]
+			argument is included, Vim executes only the matching
+			autocommands for that group.  Note: if you use an
+			undefined group name, Vim gives you an error message.
+
+			After applying the autocommands the modelines are
+			processed, so that their settings overrule the
+			settings from autocommands, like what happens when
+			editing a file.
+
+						*:doautoa* *:doautoall*
+:doautoa[ll] [group] {event} [fname]
+			Like ":doautocmd", but apply the autocommands to each
+			loaded buffer.  Note that [fname] is used to select
+			the autocommands, not the buffers to which they are
+			applied.
+			Careful: Don't use this for autocommands that delete a
+			buffer, change to another buffer or change the
+			contents of a buffer; the result is unpredictable.
+			This command is intended for autocommands that set
+			options, change highlighting, and things like that.
+
+==============================================================================
+10. Using autocommands					*autocmd-use*
+
+For WRITING FILES there are four possible sets of events.  Vim uses only one
+of these sets for a write command:
+
+BufWriteCmd	BufWritePre	BufWritePost	writing the whole buffer
+		FilterWritePre	FilterWritePost	writing to filter temp file
+FileAppendCmd	FileAppendPre	FileAppendPost	appending to a file
+FileWriteCmd	FileWritePre	FileWritePost	any other file write
+
+When there is a matching "*Cmd" autocommand, it is assumed it will do the
+writing.  No further writing is done and the other events are not triggered.
+|Cmd-event|
+
+Note that the *WritePost commands should undo any changes to the buffer that
+were caused by the *WritePre commands; otherwise, writing the file will have
+the side effect of changing the buffer.
+
+Before executing the autocommands, the buffer from which the lines are to be
+written temporarily becomes the current buffer.  Unless the autocommands
+change the current buffer or delete the previously current buffer, the
+previously current buffer is made the current buffer again.
+
+The *WritePre and *AppendPre autocommands must not delete the buffer from
+which the lines are to be written.
+
+The '[ and '] marks have a special position:
+- Before the *ReadPre event the '[ mark is set to the line just above where
+  the new lines will be inserted.
+- Before the *ReadPost event the '[ mark is set to the first line that was
+  just read, the '] mark to the last line.
+- Before executing the *WriteCmd, *WritePre and *AppendPre autocommands the '[
+  mark is set to the first line that will be written, the '] mark to the last
+  line.
+Careful: '[ and '] change when using commands that change the buffer.
+
+In commands which expect a file name, you can use "" for the file name
+that is being read |:| (you can also use "%" for the current file
+name).  "" can be used for the buffer number of the currently effective
+buffer.  This also works for buffers that doesn't have a name.  But it doesn't
+work for files without a buffer (e.g., with ":r file").
+
+							*gzip-example*
+Examples for reading and writing compressed files: >
+  :augroup gzip
+  :  autocmd!
+  :  autocmd BufReadPre,FileReadPre	*.gz set bin
+  :  autocmd BufReadPost,FileReadPost	*.gz '[,']!gunzip
+  :  autocmd BufReadPost,FileReadPost	*.gz set nobin
+  :  autocmd BufReadPost,FileReadPost	*.gz execute ":doautocmd BufReadPost " . expand("%:r")
+  :  autocmd BufWritePost,FileWritePost	*.gz !mv  :r
+  :  autocmd BufWritePost,FileWritePost	*.gz !gzip :r
+
+  :  autocmd FileAppendPre		*.gz !gunzip 
+  :  autocmd FileAppendPre		*.gz !mv :r 
+  :  autocmd FileAppendPost		*.gz !mv  :r
+  :  autocmd FileAppendPost		*.gz !gzip :r
+  :augroup END
+
+The "gzip" group is used to be able to delete any existing autocommands with
+":autocmd!", for when the file is sourced twice.
+
+(":r" is the file name without the extension, see |:_%:|)
+
+The commands executed for the BufNewFile, BufRead/BufReadPost, BufWritePost,
+FileAppendPost and VimLeave events do not set or reset the changed flag of the
+buffer.  When you decompress the buffer with the BufReadPost autocommands, you
+can still exit with ":q".  When you use ":undo" in BufWritePost to undo the
+changes made by BufWritePre commands, you can still do ":q" (this also makes
+"ZZ" work).  If you do want the buffer to be marked as modified, set the
+'modified' option.
+
+To execute Normal mode commands from an autocommand, use the ":normal"
+command.  Use with care!  If the Normal mode command is not finished, the user
+needs to type characters (e.g., after ":normal m" you need to type a mark
+name).
+
+If you want the buffer to be unmodified after changing it, reset the
+'modified' option.  This makes it possible to exit the buffer with ":q"
+instead of ":q!".
+
+							*autocmd-nested* *E218*
+By default, autocommands do not nest.  If you use ":e" or ":w" in an
+autocommand, Vim does not execute the BufRead and BufWrite autocommands for
+those commands.  If you do want this, use the "nested" flag for those commands
+in which you want nesting.  For example: >
+  :autocmd FileChangedShell *.c nested e!
+The nesting is limited to 10 levels to get out of recursive loops.
+
+It's possible to use the ":au" command in an autocommand.  This can be a
+self-modifying command!  This can be useful for an autocommand that should
+execute only once.
+
+If you want to skip autocommands for one command, use the |:noautocmd| command
+modifier or the 'eventignore' option.
+
+Note: When reading a file (with ":read file" or with a filter command) and the
+last line in the file does not have an , Vim remembers this.  At the next
+write (with ":write file" or with a filter command), if the same line is
+written again as the last line in a file AND 'binary' is set, Vim does not
+supply an .  This makes a filter command on the just read lines write the
+same file as was read, and makes a write command on just filtered lines write
+the same file as was read from the filter.  For example, another way to write
+a compressed file: >
+
+  :autocmd FileWritePre *.gz   set bin|'[,']!gzip
+  :autocmd FileWritePost *.gz  undo|set nobin
+<
+							*autocommand-pattern*
+You can specify multiple patterns, separated by commas.  Here are some
+examples: >
+
+  :autocmd BufRead   *		set tw=79 nocin ic infercase fo=2croq
+  :autocmd BufRead   .letter	set tw=72 fo=2tcrq
+  :autocmd BufEnter  .letter	set dict=/usr/lib/dict/words
+  :autocmd BufLeave  .letter	set dict=
+  :autocmd BufRead,BufNewFile   *.c,*.h	set tw=0 cin noic
+  :autocmd BufEnter  *.c,*.h	abbr FOR for (i = 0; i < 3; ++i){}O
+  :autocmd BufLeave  *.c,*.h	unabbr FOR
+
+For makefiles (makefile, Makefile, imakefile, makefile.unix, etc.): >
+
+  :autocmd BufEnter  ?akefile*	set include=^s\=include
+  :autocmd BufLeave  ?akefile*	set include&
+
+To always start editing C files at the first function: >
+
+  :autocmd BufRead   *.c,*.h	1;/^{
+
+Without the "1;" above, the search would start from wherever the file was
+entered, rather than from the start of the file.
+
+						*skeleton* *template*
+To read a skeleton (template) file when opening a new file: >
+
+  :autocmd BufNewFile  *.c	0r ~/vim/skeleton.c
+  :autocmd BufNewFile  *.h	0r ~/vim/skeleton.h
+  :autocmd BufNewFile  *.java	0r ~/vim/skeleton.java
+
+To insert the current date and time in a *.html file when writing it: >
+
+  :autocmd BufWritePre,FileWritePre *.html   ks|call LastMod()|'s
+  :fun LastMod()
+  :  if line("$") > 20
+  :    let l = 20
+  :  else
+  :    let l = line("$")
+  :  endif
+  :  exe "1," . l . "g/Last modified: /s/Last modified: .*/Last modified: " .
+  :  \ strftime("%Y %b %d")
+  :endfun
+
+You need to have a line "Last modified: " in the first 20 lines
+of the file for this to work.  Vim replaces  (and anything in the
+same line after it) with the current date and time.  Explanation:
+	ks		mark current position with mark 's'
+	call LastMod()  call the LastMod() function to do the work
+	's		return the cursor to the old position
+The LastMod() function checks if the file is shorter than 20 lines, and then
+uses the ":g" command to find lines that contain "Last modified: ".  For those
+lines the ":s" command is executed to replace the existing date with the
+current one.  The ":execute" command is used to be able to use an expression
+for the ":g" and ":s" commands.  The date is obtained with the strftime()
+function.  You can change its argument to get another date string.
+
+When entering :autocmd on the command-line, completion of events and command
+names may be done (with , CTRL-D, etc.) where appropriate.
+
+Vim executes all matching autocommands in the order that you specify them.
+It is recommended that your first autocommand be used for all files by using
+"*" as the file pattern.  This means that you can define defaults you like
+here for any settings, and if there is another matching autocommand it will
+override these.  But if there is no other matching autocommand, then at least
+your default settings are recovered (if entering this file from another for
+which autocommands did match).  Note that "*" will also match files starting
+with ".", unlike Unix shells.
+
+						    *autocmd-searchpat*
+Autocommands do not change the current search patterns.  Vim saves the current
+search patterns before executing autocommands then restores them after the
+autocommands finish.  This means that autocommands do not affect the strings
+highlighted with the 'hlsearch' option.  Within autocommands, you can still
+use search patterns normally, e.g., with the "n" command.
+If you want an autocommand to set the search pattern, such that it is used
+after the autocommand finishes, use the ":let @/ =" command.
+The search-highlighting cannot be switched off with ":nohlsearch" in an
+autocommand.  Use the 'h' flag in the 'viminfo' option to disable search-
+highlighting when starting Vim.
+
+							*Cmd-event*
+When using one of the "*Cmd" events, the matching autocommands are expected to
+do the file reading, writing or sourcing.  This can be used when working with
+a special kind of file, for example on a remote system.
+CAREFUL: If you use these events in a wrong way, it may have the effect of
+making it impossible to read or write the matching files!  Make sure you test
+your autocommands properly.  Best is to use a pattern that will never match a
+normal file name, for example "ftp://*".
+
+When defining a BufReadCmd it will be difficult for Vim to recover a crashed
+editing session.  When recovering from the original file, Vim reads only those
+parts of a file that are not found in the swap file.  Since that is not
+possible with a BufReadCmd, use the |:preserve| command to make sure the
+original file isn't needed for recovery.  You might want to do this only when
+you expect the file to be modified.
+
+For file read and write commands the |v:cmdarg| variable holds the "++enc="
+and "++ff=" argument that are effective.  These should be used for the command
+that reads/writes the file.  The |v:cmdbang| variable is one when "!" was
+used, zero otherwise.
+
+See the $VIMRUNTIME/plugin/netrwPlugin.vim for examples.
+
+==============================================================================
+11. Disabling autocommands				*autocmd-disable*
+
+To disable autocommands for some time use the 'eventignore' option.  Note that
+this may cause unexpected behavior, make sure you restore 'eventignore'
+afterwards, using a |:try| block with |:finally|.
+
+							*:noautocmd* *:noa*
+To disable autocommands for just one command use the ":noautocmd" command
+modifier.  This will set 'eventignore' to "all" for the duration of the
+following command.  Example: >
+
+	:noautocmd w fname.gz
+
+This will write the file without triggering the autocommands defined by the
+gzip plugin.
+
+
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/change.txt b/share/vim/vim73/doc/change.txt
new file mode 100644
index 0000000000..19528edc19
--- /dev/null
+++ b/share/vim/vim73/doc/change.txt
@@ -0,0 +1,1659 @@
+*change.txt*    For Vim version 7.3.  Last change: 2010 Jul 29
+
+
+		  VIM REFERENCE MANUAL    by Bram Moolenaar
+
+
+This file describes commands that delete or change text.  In this context,
+changing text means deleting the text and replacing it with other text using
+one command.  You can undo all of these commands.  You can repeat the non-Ex
+commands with the "." command.
+
+1. Deleting text		|deleting|
+2. Delete and insert		|delete-insert|
+3. Simple changes		|simple-change|		*changing*
+4. Complex changes		|complex-change|
+   4.1 Filter commands		   |filter|
+   4.2 Substitute		   |:substitute|
+   4.3 Search and replace	   |search-replace|
+   4.4 Changing tabs		   |change-tabs|
+5. Copying and moving text	|copy-move|
+6. Formatting text		|formatting|
+7. Sorting text			|sorting|
+
+For inserting text see |insert.txt|.
+
+==============================================================================
+1. Deleting text					*deleting* *E470*
+
+["x]	or					** *x* *dl*
+["x]x			Delete [count] characters under and after the cursor
+			[into register x] (not |linewise|).  Does the same as
+			"dl".
+			The  key does not take a [count].  Instead, it
+			deletes the last character of the count.
+			See |:fixdel| if the  key does not do what you
+			want.  See |'whichwrap'| for deleting a line break
+			(join lines).  {Vi does not support }
+
+							*X* *dh*
+["x]X			Delete [count] characters before the cursor [into
+			register x] (not |linewise|).  Does the same as "dh".
+			Also see |'whichwrap'|.
+
+							*d*
+["x]d{motion}		Delete text that {motion} moves over [into register
+			x].  See below for exceptions.
+
+							*dd*
+["x]dd			Delete [count] lines [into register x] |linewise|.
+
+							*D*
+["x]D			Delete the characters under the cursor until the end
+			of the line and [count]-1 more lines [into register
+			x]; synonym for "d$".
+			(not |linewise|)
+			When the '#' flag is in 'cpoptions' the count is
+			ignored.
+
+{Visual}["x]x	or					*v_x* *v_d* *v_*
+{Visual}["x]d   or
+{Visual}["x]	Delete the highlighted text [into register x] (for
+			{Visual} see |Visual-mode|).  {not in Vi}
+
+{Visual}["x]CTRL-H   or					*v_CTRL-H* *v_*
+{Visual}["x]	When in Select mode: Delete the highlighted text [into
+			register x].
+
+{Visual}["x]X	or					*v_X* *v_D* *v_b_D*
+{Visual}["x]D		Delete the highlighted lines [into register x] (for
+			{Visual} see |Visual-mode|).  In Visual block mode,
+			"D" deletes the highlighted text plus all text until
+			the end of the line.  {not in Vi}
+
+						*:d* *:de* *:del* *:delete*
+:[range]d[elete] [x]	Delete [range] lines (default: current line) [into
+			register x].
+
+:[range]d[elete] [x] {count}
+			Delete {count} lines, starting with [range]
+			(default: current line |cmdline-ranges|) [into
+			register x].
+
+These commands delete text.  You can repeat them with the "." command
+(except ":d") and undo them.  Use Visual mode to delete blocks of text.  See
+|registers| for an explanation of registers.
+
+An exception for the d{motion} command: If the motion is not linewise, the
+start and end of the motion are not in the same line, and there are only
+blanks before the start and after the end of the motion, the delete becomes
+linewise.  This means that the delete also removes the line of blanks that you
+might expect to remain.
+
+Trying to delete an empty region of text (e.g., "d0" in the first column)
+is an error when 'cpoptions' includes the 'E' flag.
+
+							*J*
+J			Join [count] lines, with a minimum of two lines.
+			Remove the indent and insert up to two spaces (see
+			below).
+
+							*v_J*
+{Visual}J		Join the highlighted lines, with a minimum of two
+			lines.  Remove the indent and insert up to two spaces
+			(see below).  {not in Vi}
+
+							*gJ*
+gJ			Join [count] lines, with a minimum of two lines.
+			Don't insert or remove any spaces.  {not in Vi}
+
+							*v_gJ*
+{Visual}gJ		Join the highlighted lines, with a minimum of two
+			lines.  Don't insert or remove any spaces.  {not in
+			Vi}
+
+							*:j* *:join*
+:[range]j[oin][!] [flags]
+			Join [range] lines.  Same as "J", except with [!]
+			the join does not insert or delete any spaces.
+			If a [range] has equal start and end values, this
+			command does nothing.  The default behavior is to
+			join the current line with the line below it.
+			{not in Vi: !}
+			See |ex-flags| for [flags].
+
+:[range]j[oin][!] {count} [flags]
+			Join {count} lines, starting with [range] (default:
+			current line |cmdline-ranges|).  Same as "J", except
+			with [!] the join does not insert or delete any
+			spaces.
+			{not in Vi: !}
+			See |ex-flags| for [flags].
+
+These commands delete the  between lines.  This has the effect of joining
+multiple lines into one line.  You can repeat these commands (except ":j") and
+undo them.
+
+These commands, except "gJ", insert one space in place of the  unless
+there is trailing white space or the next line starts with a ')'.  These
+commands, except "gJ", delete any leading white space on the next line.  If
+the 'joinspaces' option is on, these commands insert two spaces after a '.',
+'!' or '?' (but if 'cpoptions' includes the 'j' flag, they insert two spaces
+only after a '.').
+The 'B' and 'M' flags in 'formatoptions' change the behavior for inserting
+spaces before and after a multi-byte character |fo-table|.
+
+
+==============================================================================
+2. Delete and insert				*delete-insert* *replacing*
+
+							*R*
+R			Enter Replace mode: Each character you type replaces
+			an existing character, starting with the character
+			under the cursor.  Repeat the entered text [count]-1
+			times.  See |Replace-mode| for more details.
+
+							*gR*
+gR			Enter Virtual Replace mode: Each character you type
+			replaces existing characters in screen space.  So a
+			 may replace several characters at once.
+			Repeat the entered text [count]-1 times.  See
+			|Virtual-Replace-mode| for more details.
+			{not available when compiled without the |+vreplace|
+			feature}
+
+							*c*
+["x]c{motion}		Delete {motion} text [into register x] and start
+			insert.  When  'cpoptions' includes the 'E' flag and
+			there is no text to delete (e.g., with "cTx" when the
+			cursor is just after an 'x'), an error occurs and
+			insert mode does not start (this is Vi compatible).
+			When  'cpoptions' does not include the 'E' flag, the
+			"c" command always starts insert mode, even if there
+			is no text to delete.
+
+							*cc*
+["x]cc			Delete [count] lines [into register x] and start
+			insert |linewise|.  If 'autoindent' is on, preserve
+			the indent of the first line.
+
+							*C*
+["x]C			Delete from the cursor position to the end of the
+			line and [count]-1 more lines [into register x], and
+			start insert.  Synonym for c$ (not |linewise|).
+
+							*s*
+["x]s			Delete [count] characters [into register x] and start
+			insert (s stands for Substitute).  Synonym for "cl"
+			(not |linewise|).
+
+							*S*
+["x]S			Delete [count] lines [into register x] and start
+			insert.  Synonym for "cc" |linewise|.
+
+{Visual}["x]c	or					*v_c* *v_s*
+{Visual}["x]s		Delete the highlighted text [into register x] and
+			start insert (for {Visual} see |Visual-mode|).  {not
+			in Vi}
+
+							*v_r*
+{Visual}["x]r{char}	Replace all selected characters by {char}.
+
+							*v_C*
+{Visual}["x]C		Delete the highlighted lines [into register x] and
+			start insert.  In Visual block mode it works
+			differently |v_b_C|.  {not in Vi}
+							*v_S*
+{Visual}["x]S		Delete the highlighted lines [into register x] and
+			start insert (for {Visual} see |Visual-mode|).  {not
+			in Vi}
+							*v_R*
+{Visual}["x]R		Currently just like {Visual}["x]S.  In a next version
+			it might work differently. {not in Vi}
+
+Notes:
+- You can end Insert and Replace mode with .
+- See the section "Insert and Replace mode" |mode-ins-repl| for the other
+  special characters in these modes.
+- The effect of [count] takes place after Vim exits Insert or Replace mode.
+- When the 'cpoptions' option contains '$' and the change is within one line,
+  Vim continues to show the text to be deleted and puts a '$' at the last
+  deleted character.
+
+See |registers| for an explanation of registers.
+
+Replace mode is just like Insert mode, except that every character you enter
+deletes one character.  If you reach the end of a line, Vim appends any
+further characters (just like Insert mode).  In Replace mode, the backspace
+key restores the original text (if there was any).  (See section "Insert and
+Replace mode" |mode-ins-repl|).
+
+						*cw* *cW*
+Special case: When the cursor is in a word, "cw" and "cW" do not include the
+white space after a word, they only change up to the end of the word.  This is
+because Vim interprets "cw" as change-word, and a word does not include the
+following white space.
+{Vi: "cw" when on a blank followed by other blanks changes only the first
+blank; this is probably a bug, because "dw" deletes all the blanks; use the
+'w' flag in 'cpoptions' to make it work like Vi anyway}
+
+If you prefer "cw" to include the space after a word, use this mapping: >
+	:map cw dwi
+Or use "caw" (see |aw|).
+
+							*:c* *:ch* *:change*
+:{range}c[hange][!]	Replace lines of text with some different text.
+			Type a line containing only "." to stop replacing.
+			Without {range}, this command changes only the current
+			line.
+			Adding [!] toggles 'autoindent' for the time this
+			command is executed.
+
+==============================================================================
+3. Simple changes					*simple-change*
+
+							*r*
+r{char}			Replace the character under the cursor with {char}.
+			If {char} is a  or , a line break replaces the
+			character.  To replace with a real , use CTRL-V
+			.  CTRL-V  replaces with a .
+			{Vi: CTRL-V  still replaces with a line break,
+			cannot replace something with a }
+			If you give a [count], Vim replaces [count] characters
+			with [count] {char}s.  When {char} is a  or ,
+			however, Vim inserts only one : "5r" replaces
+			five characters with a single line break.
+			When {char} is a  or , Vim performs
+			autoindenting.  This works just like deleting the
+			characters that are replaced and then doing
+			"i".
+			{char} can be entered as a digraph |digraph-arg|.
+			|:lmap| mappings apply to {char}.  The CTRL-^ command
+			in Insert mode can be used to switch this on/off
+			|i_CTRL-^|.  See |utf-8-char-arg| about using
+			composing characters when 'encoding' is Unicode.
+
+							*gr*
+gr{char}		Replace the virtual characters under the cursor with
+			{char}.  This replaces in screen space, not file
+			space.  See |gR| and |Virtual-Replace-mode| for more
+			details.  As with |r| a count may be given.
+			{char} can be entered like with |r|.
+			{not available when compiled without the |+vreplace|
+			feature}
+
+						*digraph-arg*
+The argument for Normal mode commands like |r| and |t| is a single character.
+When 'cpo' doesn't contain the 'D' flag, this character can also be entered
+like |digraphs|.  First type CTRL-K and then the two digraph characters.
+{not available when compiled without the |+digraphs| feature}
+
+						*case*
+The following commands change the case of letters.  The currently active
+|locale| is used.  See |:language|.  The LC_CTYPE value matters here.
+
+							*~*
+~			'notildeop' option: Switch case of the character
+			under the cursor and move the cursor to the right.
+			If a [count] is given, do that many characters. {Vi:
+			no count}
+
+~{motion}		'tildeop' option: switch case of {motion} text. {Vi:
+			tilde cannot be used as an operator}
+
+							*g~*
+g~{motion}		Switch case of {motion} text. {not in Vi}
+
+g~g~							*g~g~* *g~~*
+g~~			Switch case of current line. {not in Vi}.
+
+							*v_~*
+{Visual}~		Switch case of highlighted text (for {Visual} see
+			|Visual-mode|). {not in Vi}
+
+							*v_U*
+{Visual}U		Make highlighted text uppercase (for {Visual} see
+			|Visual-mode|). {not in Vi}
+
+							*gU* *uppercase*
+gU{motion}		Make {motion} text uppercase. {not in Vi}
+			Example: >
+				:map!  gUiw`]a
+<			This works in Insert mode: press CTRL-F to make the
+			word before the cursor uppercase.  Handy to type
+			words in lowercase and then make them uppercase.
+
+
+gUgU							*gUgU* *gUU*
+gUU			Make current line uppercase. {not in Vi}.
+
+							*v_u*
+{Visual}u		Make highlighted text lowercase (for {Visual} see
+			|Visual-mode|).  {not in Vi}
+
+							*gu* *lowercase*
+gu{motion}		Make {motion} text lowercase. {not in Vi}
+
+gugu							*gugu* *guu*
+guu			Make current line lowercase. {not in Vi}.
+
+							*g?* *rot13*
+g?{motion}		Rot13 encode {motion} text. {not in Vi}
+
+							*v_g?*
+{Visual}g?		Rot13 encode the highlighted text (for {Visual} see
+			|Visual-mode|).  {not in Vi}
+
+g?g?							*g?g?* *g??*
+g??			Rot13 encode current line. {not in Vi}.
+
+To turn one line into title caps, make every first letter of a word
+uppercase: >
+	:s/\v<(.)(\w*)/\u\1\L\2/g
+
+
+Adding and subtracting ~
+							*CTRL-A*
+CTRL-A			Add [count] to the number or alphabetic character at
+			or after the cursor.  {not in Vi}
+
+							*CTRL-X*
+CTRL-X			Subtract [count] from the number or alphabetic
+			character at or after the cursor.  {not in Vi}
+
+The CTRL-A and CTRL-X commands work for (signed) decimal numbers, unsigned
+octal and hexadecimal numbers and alphabetic characters.  This depends on the
+'nrformats' option.
+- When 'nrformats' includes "octal", Vim considers numbers starting with a '0'
+  to be octal, unless the number includes a '8' or '9'.  Other numbers are
+  decimal and may have a preceding minus sign.
+  If the cursor is on a number, the commands apply to that number; otherwise
+  Vim uses the number to the right of the cursor.
+- When 'nrformats' includes "hex", Vim assumes numbers starting with '0x' or
+  '0X' are hexadecimal.  The case of the rightmost letter in the number
+  determines the case of the resulting hexadecimal number.  If there is no
+  letter in the current number, Vim uses the previously detected case.
+- When 'nrformats' includes "alpha", Vim will change the alphabetic character
+  under or after the cursor.  This is useful to make lists with an alphabetic
+  index.
+
+For numbers with leading zeros (including all octal and hexadecimal numbers),
+Vim preserves the number of characters in the number when possible.  CTRL-A on
+"0077" results in "0100", CTRL-X on "0x100" results in "0x0ff".
+There is one exception: When a number that starts with a zero is found not to
+be octal (it contains a '8' or '9'), but 'nrformats' does include "octal",
+leading zeros are removed to avoid that the result may be recognized as an
+octal number.
+
+Note that when 'nrformats' includes "octal", decimal numbers with leading
+zeros cause mistakes, because they can be confused with octal numbers.
+
+The CTRL-A command is very useful in a macro.  Example: Use the following
+steps to make a numbered list.
+
+1. Create the first list entry, make sure it starts with a number.
+2. qa	     - start recording into register 'a'
+3. Y	     - yank the entry
+4. p	     - put a copy of the entry below the first one
+5. CTRL-A    - increment the number
+6. q	     - stop recording
+7. @a - repeat the yank, put and increment  times
+
+
+SHIFTING LINES LEFT OR RIGHT				*shift-left-right*
+
+							*<*
+<{motion}		Shift {motion} lines one 'shiftwidth' leftwards.
+
+							*<<*
+<<			Shift [count] lines one 'shiftwidth' leftwards.
+
+							*v_<*
+{Visual}[count]<	Shift the highlighted lines [count] 'shiftwidth'
+			leftwards (for {Visual} see |Visual-mode|).  {not in
+			Vi}
+
+							*>*
+ >{motion}		Shift {motion} lines one 'shiftwidth' rightwards.
+
+							*>>*
+ >>			Shift [count] lines one 'shiftwidth' rightwards.
+
+							*v_>*
+{Visual}[count]>	Shift the highlighted lines [count] 'shiftwidth'
+			rightwards (for {Visual} see |Visual-mode|).  {not in
+			Vi}
+
+							*:<*
+:[range]<		Shift [range] lines one 'shiftwidth' left.  Repeat '<'
+			for shifting multiple 'shiftwidth's.
+
+:[range]< {count}	Shift {count} lines one 'shiftwidth' left, starting
+			with [range] (default current line |cmdline-ranges|).
+			Repeat '<' for shifting multiple 'shiftwidth's.
+
+:[range]le[ft] [indent]	left align lines in [range].  Sets the indent in the
+			lines to [indent] (default 0).  {not in Vi}
+
+							*:>*
+:[range]> [flags]	Shift {count} [range] lines one 'shiftwidth' right.
+			Repeat '>' for shifting multiple 'shiftwidth's.
+			See |ex-flags| for [flags].
+
+:[range]> {count} [flags]
+			Shift {count} lines one 'shiftwidth' right, starting
+			with [range] (default current line |cmdline-ranges|).
+			Repeat '>' for shifting multiple 'shiftwidth's.
+			See |ex-flags| for [flags].
+
+The ">" and "<" commands are handy for changing the indentation within
+programs.  Use the 'shiftwidth' option to set the size of the white space
+which these commands insert or delete.  Normally the 'shiftwidth' option is 8,
+but you can set it to, say, 3 to make smaller indents.  The shift leftwards
+stops when there is no indent.  The shift right does not affect empty lines.
+
+If the 'shiftround' option is on, the indent is rounded to a multiple of
+'shiftwidth'.
+
+If the 'smartindent' option is on, or 'cindent' is on and 'cinkeys' contains
+'#', shift right does not affect lines starting with '#' (these are supposed
+to be C preprocessor lines that must stay in column 1).
+
+When the 'expandtab' option is off (this is the default) Vim uses s as
+much as possible to make the indent.  You can use ">><<" to replace an indent
+made out of spaces with the same indent made out of s (and a few spaces
+if necessary).  If the 'expandtab' option is on, Vim uses only spaces.  Then
+you can use ">><<" to replace s in the indent by spaces (or use
+":retab!").
+
+To move a line several 'shiftwidth's, use Visual mode or the ":" commands.
+For example: >
+	Vjj4>		move three lines 4 indents to the right
+	:<<<		move current line 3 indents to the left
+	:>> 5		move 5 lines 2 indents to the right
+	:5>>		move line 5 2 indents to the right
+
+==============================================================================
+4. Complex changes					*complex-change*
+
+4.1 Filter commands					*filter*
+
+A filter is a program that accepts text at standard input, changes it in some
+way, and sends it to standard output.  You can use the commands below to send
+some text through a filter, so that it is replaced by the filter output.
+Examples of filters are "sort", which sorts lines alphabetically, and
+"indent", which formats C program files (you need a version of indent that
+works like a filter; not all versions do).  The 'shell' option specifies the
+shell Vim uses to execute the filter command (See also the 'shelltype'
+option).  You can repeat filter commands with ".".  Vim does not recognize a
+comment (starting with '"') after the ":!" command.
+
+							*!*
+!{motion}{filter}	Filter {motion} text lines through the external
+			program {filter}.
+
+							*!!*
+!!{filter}		Filter [count] lines through the external program
+			{filter}.
+
+							*v_!*
+{Visual}!{filter}	Filter the highlighted lines through the external
+			program {filter} (for {Visual} see |Visual-mode|).
+			{not in Vi}
+
+:{range}![!]{filter} [!][arg]				*:range!*
+			Filter {range} lines through the external program
+			{filter}.  Vim replaces the optional bangs with the
+			latest given command and appends the optional [arg].
+			Vim saves the output of the filter command in a
+			temporary file and then reads the file into the buffer
+			|tempfile|.  Vim uses the 'shellredir' option to
+			redirect the filter output to the temporary file.
+			However, if the 'shelltemp' option is off then pipes
+			are used when possible (on Unix).
+			When the 'R' flag is included in 'cpoptions' marks in
+			the filtered lines are deleted, unless the
+			|:keepmarks| command is used.  Example: >
+				:keepmarks '<,'>!sort
+<			When the number of lines after filtering is less than
+			before, marks in the missing lines are deleted anyway.
+
+							*=*
+={motion}		Filter {motion} lines through the external program
+			given with the 'equalprg' option.  When the 'equalprg'
+			option is empty (this is the default), use the
+			internal formatting function |C-indenting|.  But when
+			'indentexpr' is not empty, it will be used instead
+			|indent-expression|.  When Vim was compiled without
+			internal formatting then the "indent" program is used
+			as a last resort.
+
+							*==*
+==			Filter [count] lines like with ={motion}.
+
+							*v_=*
+{Visual}=		Filter the highlighted lines like with ={motion}.
+			{not in Vi}
+
+
+						*tempfile* *setuid*
+Vim uses temporary files for filtering, generating diffs and also for
+tempname().  For Unix, the file will be in a private directory (only
+accessible by the current user) to avoid security problems (e.g., a symlink
+attack or other people reading your file).  When Vim exits the directory and
+all files in it are deleted.  When Vim has the setuid bit set this may cause
+problems, the temp file is owned by the setuid user but the filter command
+probably runs as the original user.
+On MS-DOS and OS/2 the first of these directories that works is used: $TMP,
+$TEMP, c:\TMP, c:\TEMP.
+For Unix the list of directories is: $TMPDIR, /tmp, current-dir, $HOME.
+For MS-Windows the GetTempFileName() system function is used.
+For other systems the tmpnam() library function is used.
+
+
+
+4.2 Substitute						*:substitute*
+							*:s* *:su*
+:[range]s[ubstitute]/{pattern}/{string}/[flags] [count]
+			For each line in [range] replace a match of {pattern}
+			with {string}.
+			For the {pattern} see |pattern|.
+			{string} can be a literal string, or something
+			special; see |sub-replace-special|.
+			When [range] and [count] are omitted, replace in the
+			current line only.
+			When [count] is given, replace in [count] lines,
+			starting with the last line in [range].  When [range]
+			is omitted start in the current line.
+			Also see |cmdline-ranges|.
+			See |:s_flags| for [flags].
+
+:[range]s[ubstitute] [flags] [count]
+:[range]&[&][flags] [count]					*:&*
+			Repeat last :substitute with same search pattern and
+			substitute string, but without the same flags.  You
+			may add [flags], see |:s_flags|.
+			Note that after ":substitute" the '&' flag can't be
+			used, it's recognized as a pattern separator.
+			The space between ":substitute" and the 'c', 'g' and
+			'r' flags isn't required, but in scripts it's a good
+			idea to keep it to avoid confusion.
+
+:[range]~[&][flags] [count]					*:~*
+			Repeat last substitute with same substitute string
+			but with last used search pattern.  This is like
+			":&r".  See |:s_flags| for [flags].
+
+								*&*
+&			Synonym for ":s" (repeat last substitute).  Note
+			that the flags are not remembered, thus it might
+			actually work differently.  You can use ":&&" to keep
+			the flags.
+
+								*g&*
+g&			Synonym for ":%s//~/&" (repeat last substitute on all
+			lines with the same flags).
+			Mnemonic: global substitute. {not in Vi}
+
+						*:snomagic* *:sno*
+:[range]sno[magic] ...	Same as ":substitute", but always use 'nomagic'.
+			{not in Vi}
+
+						*:smagic* *:sm*
+:[range]sm[agic] ...	Same as ":substitute", but always use 'magic'.
+			{not in Vi}
+
+							*:s_flags*
+The flags that you can use for the substitute commands:
+
+[&]	Must be the first one: Keep the flags from the previous substitute
+	command.  Examples: >
+		:&&
+		:s/this/that/&
+<	Note that ":s" and ":&" don't keep the flags.
+	{not in Vi}
+
+[c]	Confirm each substitution.  Vim highlights the matching string (with
+	|hl-IncSearch|).  You can type:				*:s_c*
+	    'y'	    to substitute this match
+	    'l'	    to substitute this match and then quit ("last")
+	    'n'	    to skip this match
+	       to quit substituting
+	    'a'	    to substitute this and all remaining matches {not in Vi}
+	    'q'	    to quit substituting {not in Vi}
+	    CTRL-E  to scroll the screen up {not in Vi, not available when
+			compiled without the |+insert_expand| feature}
+	    CTRL-Y  to scroll the screen down {not in Vi, not available when
+			compiled without the |+insert_expand| feature}
+	If the 'edcompatible' option is on, Vim remembers the [c] flag and
+	toggles it each time you use it, but resets it when you give a new
+	search pattern.
+	{not in Vi: highlighting of the match, other responses than 'y' or 'n'}
+
+[e]     When the search pattern fails, do not issue an error message and, in
+	particular, continue in maps as if no error occurred.  This is most
+	useful to prevent the "No match" error from breaking a mapping.  Vim
+	does not suppress the following error messages, however:
+		Regular expressions can't be delimited by letters
+		\ should be followed by /, ? or &
+		No previous substitute regular expression
+		Trailing characters
+		Interrupted
+	{not in Vi}
+
+[g]	Replace all occurrences in the line.  Without this argument,
+	replacement occurs only for the first occurrence in each line.  If
+	the 'edcompatible' option is on, Vim remembers this flag and toggles
+	it each time you use it, but resets it when you give a new search
+	pattern.  If the 'gdefault' option is on, this flag is on by default
+	and the [g] argument switches it off.
+
+[i]	Ignore case for the pattern.  The 'ignorecase' and 'smartcase' options
+	are not used.
+	{not in Vi}
+
+[I]	Don't ignore case for the pattern.  The 'ignorecase' and 'smartcase'
+	options are not used.
+	{not in Vi}
+
+[n]	Report the number of matches, do not actually substitute.  The [c]
+	flag is ignored.  The matches are reported as if 'report' is zero.
+	Useful to |count-items|.
+
+[p]	Print the line containing the last substitute.
+
+[#]	Like [p] and prepend the line number.
+
+[l]	Like [p] but print the text like |:list|.
+
+[r]	Only useful in combination with ":&" or ":s" without arguments.  ":&r"
+	works the same way as ":~":  When the search pattern is empty, use the
+	previously used search pattern instead of the search pattern from the
+	last substitute or ":global".  If the last command that did a search
+	was a substitute or ":global", there is no effect.  If the last
+	command was a search command such as "/", use the pattern from that
+	command.
+	For ":s" with an argument this already happens: >
+		:s/blue/red/
+		/green
+		:s//red/   or  :~   or  :&r
+<	The last commands will replace "green" with "red". >
+		:s/blue/red/
+		/green
+		:&
+<	The last command will replace "blue" with "red".
+	{not in Vi}
+
+Note that there is no flag to change the "magicness" of the pattern.  A
+different command is used instead, or you can use |/\v| and friends.  The
+reason is that the flags can only be found by skipping the pattern, and in
+order to skip the pattern the "magicness" must be known.  Catch 22!
+
+If the {pattern} for the substitute command is empty, the command uses the
+pattern from the last substitute or ":global" command.  With the [r] flag, the
+command uses the pattern from the last substitute, ":global", or search
+command.
+
+If the {string} is omitted the substitute is done as if it's empty.  Thus the
+matched pattern is deleted.  The separator after {pattern} can also be left
+out then.  Example: >
+	:%s/TESTING
+This deletes "TESTING" from all lines, but only one per line.
+
+For compatibility with Vi these two exceptions are allowed:
+"\/{string}/" and "\?{string}?" do the same as "//{string}/r".
+"\&{string}&" does the same as "//{string}/".
+							*E146*
+Instead of the '/' which surrounds the pattern and replacement string, you
+can use any other single-byte character, but not an alphanumeric character,
+'\', '"' or '|'.  This is useful if you want to include a '/' in the search
+pattern or replacement string.  Example: >
+	:s+/+//+
+
+For the definition of a pattern, see |pattern|.  In Visual block mode, use
+|/\%V| in the pattern to have the substitute work in the block only.
+Otherwise it works on whole lines anyway.
+
+					*sub-replace-special* *:s\=*
+When the {string} starts with "\=" it is evaluated as an expression, see
+|sub-replace-expression|.  You can use that for any special characters.
+Otherwise these characters in {string} have a special meaning:
+								*:s%*
+When {string} is equal to "%" and '/' is included with the 'cpoptions' option,
+then the {string} of the previous substitute command is used. |cpo-/|
+
+magic	nomagic	  action    ~
+  &	  \&	  replaced with the whole matched pattern	     *s/\&*
+ \&	   &	  replaced with &
+      \0	  replaced with the whole matched pattern	   *\0* *s/\0*
+      \1	  replaced with the matched pattern in the first
+		  pair of ()					     *s/\1*
+      \2	  replaced with the matched pattern in the second
+		  pair of ()					     *s/\2*
+      ..	  ..						     *s/\3*
+      \9	  replaced with the matched pattern in the ninth
+		  pair of ()					     *s/\9*
+  ~	  \~	  replaced with the {string} of the previous
+		  substitute					     *s~*
+ \~	   ~	  replaced with ~				     *s/\~*
+      \u	  next character made uppercase			     *s/\u*
+      \U	  following characters made uppercase, until \E      *s/\U*
+      \l	  next character made lowercase			     *s/\l*
+      \L	  following characters made lowercase, until \E      *s/\L*
+      \e	  end of \u, \U, \l and \L (NOTE: not !)	     *s/\e*
+      \E	  end of \u, \U, \l and \L			     *s/\E*
+      	  split line in two at this point
+		  (Type the  as CTRL-V )		     *s*
+      \r	  idem						     *s/\r*
+      \	  insert a carriage-return (CTRL-M)
+		  (Type the  as CTRL-V )		     *s/\*
+      \n	  insert a  ( in the file)
+		  (does NOT break the line)			     *s/\n*
+      \b	  insert a 					     *s/\b*
+      \t	  insert a 				     *s/\t*
+      \\	  insert a single backslash			     *s/\\*
+      \x	  where x is any character not mentioned above:
+		  Reserved for future expansion
+
+Examples: >
+  :s/a\|b/xxx\0xxx/g		 modifies "a b"	     to "xxxaxxx xxxbxxx"
+  :s/\([abc]\)\([efg]\)/\2\1/g	 modifies "af fa bg" to "fa fa gb"
+  :s/abcde/abc^Mde/		 modifies "abcde"    to "abc", "de" (two lines)
+  :s/$/\^M/			 modifies "abcde"    to "abcde^M"
+  :s/\w\+/\u\0/g		 modifies "bla bla"  to "Bla Bla"
+
+Note: In previous versions CTRL-V was handled in a special way.  Since this is
+not Vi compatible, this was removed.  Use a backslash instead.
+
+command		text	result ~
+:s/aa/a^Ma/	aa	aa
+:s/aa/a\^Ma/	aa	a^Ma
+:s/aa/a\\^Ma/	aa	a\a
+
+(you need to type CTRL-V  to get a ^M here)
+
+The numbering of "\1", "\2" etc. is done based on which "\(" comes first in
+the pattern (going left to right).  When a parentheses group matches several
+times, the last one will be used for "\1", "\2", etc.  Example: >
+  :s/\(\(a[a-d] \)*\)/\2/      modifies "aa ab x" to "ab x"
+
+When using parentheses in combination with '|', like in \([ab]\)\|\([cd]\),
+either the first or second pattern in parentheses did not match, so either
+\1 or \2 is empty.  Example: >
+  :s/\([ab]\)\|\([cd]\)/\1x/g   modifies "a b c d"  to "ax bx x x"
+<
+
+Substitute with an expression			*sub-replace-expression*
+						*sub-replace-\=*
+When the substitute string starts with "\=" the remainder is interpreted as an
+expression.  This does not work recursively: a substitute() function inside
+the expression cannot use "\=" for the substitute string.
+
+The special meaning for characters as mentioned at |sub-replace-special| does
+not apply except for "", "\" and "\\".  Thus in the result of the
+expression you need to use two backslashes to get one, put a backslash before a
+ you want to insert, and use a  without a backslash where you want to
+break the line.
+
+For convenience a  character is also used as a line break.  Prepend a
+backslash to get a real  character (which will be a NUL in the file).
+
+When the result is a |List| then the items are joined with separating line
+breaks.  Thus each item becomes a line, except that they can contain line
+breaks themselves.
+
+The whole matched text can be accessed with "submatch(0)".  The text matched
+with the first pair of () with "submatch(1)".  Likewise for further
+sub-matches in ().
+
+Be careful: The separation character must not appear in the expression!
+Consider using a character like "@" or ":".  There is no problem if the result
+of the expression contains the separation character.
+
+Examples: >
+	:s@\n@\="\r" . expand("$HOME") . "\r"@
+This replaces an end-of-line with a new line containing the value of $HOME. >
+
+	s/E/\="\"/g
+This replaces each 'E' character with a euro sign.  Read more in ||.
+
+
+4.3 Search and replace					*search-replace*
+
+							*:pro* *:promptfind*
+:promptf[ind] [string]
+			Put up a Search dialog.  When [string] is given, it is
+			used as the initial search string.
+			{only for Win32, Motif and GTK GUI}
+
+						*:promptr* *:promptrepl*
+:promptr[epl] [string]
+			Put up a Search/Replace dialog.  When [string] is
+			given, it is used as the initial search string.
+			{only for Win32, Motif and GTK GUI}
+
+
+4.4 Changing tabs					*change-tabs*
+							*:ret* *:retab*
+:[range]ret[ab][!] [new_tabstop]
+			Replace all sequences of white-space containing a
+			 with new strings of white-space using the new
+			tabstop value given.  If you do not specify a new
+			tabstop size or it is zero, Vim uses the current value
+			of 'tabstop'.
+			The current value of 'tabstop' is always used to
+			compute the width of existing tabs.
+			With !, Vim also replaces strings of only normal
+			spaces with tabs where appropriate.
+			With 'expandtab' on, Vim replaces all tabs with the
+			appropriate number of spaces.
+			This command sets 'tabstop' to the new value given,
+			and if performed on the whole file, which is default,
+			should not make any visible change.
+			Careful: This command modifies any  characters
+			inside of strings in a C program.  Use "\t" to avoid
+			this (that's a good habit anyway).
+			":retab!" may also change a sequence of spaces by
+			 characters, which can mess up a printf().
+			{not in Vi}
+			Not available when |+ex_extra| feature was disabled at
+			compile time.
+
+							*retab-example*
+Example for using autocommands and ":retab" to edit a file which is stored
+with tabstops at 8 but edited with tabstops set at 4.  Warning: white space
+inside of strings can change!  Also see 'softtabstop' option. >
+
+  :auto BufReadPost	*.xx	retab! 4
+  :auto BufWritePre	*.xx	retab! 8
+  :auto BufWritePost	*.xx	retab! 4
+  :auto BufNewFile	*.xx	set ts=4
+
+==============================================================================
+5. Copying and moving text				*copy-move*
+
+							*quote*
+"{a-zA-Z0-9.%#:-"}	Use register {a-zA-Z0-9.%#:-"} for next delete, yank
+			or put (use uppercase character to append with
+			delete and yank) ({.%#:} only work with put).
+
+							*:reg* *:registers*
+:reg[isters]		Display the contents of all numbered and named
+			registers.  If a register is written to for |:redir|
+			it will not be listed.
+			{not in Vi}
+
+
+:reg[isters] {arg}	Display the contents of the numbered and named
+			registers that are mentioned in {arg}.  For example: >
+				:dis 1a
+<			to display registers '1' and 'a'.  Spaces are allowed
+			in {arg}.  {not in Vi}
+
+							*:di* *:display*
+:di[splay] [arg]	Same as :registers.  {not in Vi}
+
+							*y* *yank*
+["x]y{motion}		Yank {motion} text [into register x].  When no
+			characters are to be yanked (e.g., "y0" in column 1),
+			this is an error when 'cpoptions' includes the 'E'
+			flag.
+
+							*yy*
+["x]yy			Yank [count] lines [into register x] |linewise|.
+
+							*Y*
+["x]Y			yank [count] lines [into register x] (synonym for
+			yy, |linewise|).  If you like "Y" to work from the
+			cursor to the end of line (which is more logical,
+			but not Vi-compatible) use ":map Y y$".
+
+							*v_y*
+{Visual}["x]y		Yank the highlighted text [into register x] (for
+			{Visual} see |Visual-mode|).  {not in Vi}
+
+							*v_Y*
+{Visual}["x]Y		Yank the highlighted lines [into register x] (for
+			{Visual} see |Visual-mode|).  {not in Vi}
+
+							*:y* *:yank*
+:[range]y[ank] [x]	Yank [range] lines [into register x].
+
+:[range]y[ank] [x] {count}
+			Yank {count} lines, starting with last line number
+			in [range] (default: current line |cmdline-ranges|),
+			[into register x].
+
+							*p* *put* *E353*
+["x]p			Put the text [from register x] after the cursor
+			[count] times.  {Vi: no count}
+
+							*P*
+["x]P			Put the text [from register x] before the cursor
+			[count] times.  {Vi: no count}
+
+							**
+["x]	Put the text from a register before the cursor [count]
+			times.  Uses the "* register, unless another is
+			specified.
+			Leaves the cursor at the end of the new text.
+			Using the mouse only works when 'mouse' contains 'n'
+			or 'a'.
+			{not in Vi}
+			If you have a scrollwheel and often accidentally paste
+			text, you can use these mappings to disable the
+			pasting with the middle mouse button: >
+				:map  
+				:imap  
+<			You might want to disable the multi-click versions
+			too, see |double-click|.
+
+							*gp*
+["x]gp			Just like "p", but leave the cursor just after the new
+			text.  {not in Vi}
+
+							*gP*
+["x]gP			Just like "P", but leave the cursor just after the new
+			text.  {not in Vi}
+
+							*:pu* *:put*
+:[line]pu[t] [x]	Put the text [from register x] after [line] (default
+			current line).  This always works |linewise|, thus
+			this command can be used to put a yanked block as new
+			lines.
+			The cursor is left on the first non-blank in the last
+			new line.
+			The register can also be '=' followed by an optional
+			expression.  The expression continues until the end of
+			the command.  You need to escape the '|' and '"'
+			characters to prevent them from terminating the
+			command.  Example: >
+				:put ='path' . \",/test\"
+<			If there is no expression after '=', Vim uses the
+			previous expression.  You can see it with ":dis =".
+
+:[line]pu[t]! [x]	Put the text [from register x] before [line] (default
+			current line).
+
+["x]]p		    or					*]p* *]*
+["x]]	Like "p", but adjust the indent to the current line.
+			Using the mouse only works when 'mouse' contains 'n'
+			or 'a'.  {not in Vi}
+
+["x][P		    or					*[P*
+["x]]P		    or					*]P*
+["x][p		    or					*[p* *[*
+["x][	Like "P", but adjust the indent to the current line.
+			Using the mouse only works when 'mouse' contains 'n'
+			or 'a'.  {not in Vi}
+
+You can use these commands to copy text from one place to another.  Do this
+by first getting the text into a register with a yank, delete or change
+command, then inserting the register contents with a put command.  You can
+also use these commands to move text from one file to another, because Vim
+preserves all registers when changing buffers (the CTRL-^ command is a quick
+way to toggle between two files).
+
+				*linewise-register* *characterwise-register*
+You can repeat the put commands with "." (except for :put) and undo them.  If
+the command that was used to get the text into the register was |linewise|,
+Vim inserts the text below ("p") or above ("P") the line where the cursor is.
+Otherwise Vim inserts the text after ("p") or before ("P") the cursor.  With
+the ":put" command, Vim always inserts the text in the next line.  You can
+exchange two characters with the command sequence "xp".  You can exchange two
+lines with the command sequence "ddp".  You can exchange two words with the
+command sequence "deep" (start with the cursor in the blank space before the
+first word).  You can use the "']" or "`]" command after the put command to
+move the cursor to the end of the inserted text, or use "'[" or "`[" to move
+the cursor to the start.
+
+						*put-Visual-mode* *v_p* *v_P*
+When using a put command like |p| or |P| in Visual mode, Vim will try to
+replace the selected text with the contents of the register.  Whether this
+works well depends on the type of selection and the type of the text in the
+register.  With blockwise selection it also depends on the size of the block
+and whether the corners are on an existing character.  (Implementation detail:
+it actually works by first putting the register after the selection and then
+deleting the selection.)
+The previously selected text is put in the unnamed register.  If you want to
+put the same text into a Visual selection several times you need to use
+another register.  E.g., yank the text to copy, Visually select the text to
+replace and use "0p .  You can repeat this as many times as you like, the
+unnamed register will be changed each time.
+
+							*blockwise-register*
+If you use a blockwise Visual mode command to get the text into the register,
+the block of text will be inserted before ("P") or after ("p") the cursor
+column in the current and next lines.  Vim makes the whole block of text start
+in the same column.  Thus the inserted text looks the same as when it was
+yanked or deleted.  Vim may replace some  characters with spaces to make
+this happen.  However, if the width of the block is not a multiple of a 
+width and the text after the inserted block contains s, that text may be
+misaligned.
+
+Note that after a characterwise yank command, Vim leaves the cursor on the
+first yanked character that is closest to the start of the buffer.  This means
+that "yl" doesn't move the cursor, but "yh" moves the cursor one character
+left.
+Rationale:	In Vi the "y" command followed by a backwards motion would
+		sometimes not move the cursor to the first yanked character,
+		because redisplaying was skipped.  In Vim it always moves to
+		the first character, as specified by Posix.
+With a linewise yank command the cursor is put in the first line, but the
+column is unmodified, thus it may not be on the first yanked character.
+
+There are nine types of registers:			*registers* *E354*
+1. The unnamed register ""
+2. 10 numbered registers "0 to "9
+3. The small delete register "-
+4. 26 named registers "a to "z or "A to "Z
+5. four read-only registers ":, "., "% and "#
+6. the expression register "=
+7. The selection and drop registers "*, "+ and "~ 
+8. The black hole register "_
+9. Last search pattern register "/
+
+1. Unnamed register ""				*quote_quote* *quotequote*
+Vim fills this register with text deleted with the "d", "c", "s", "x" commands
+or copied with the yank "y" command, regardless of whether or not a specific
+register was used (e.g.  "xdd).  This is like the unnamed register is pointing
+to the last used register.  Thus when appending using an uppercase register
+name, the unnamed register contains the same text as the named register.
+An exception is the '_' register: "_dd does not store the deleted text in any
+register.
+Vim uses the contents of the unnamed register for any put command (p or P)
+which does not specify a register.  Additionally you can access it with the
+name '"'.  This means you have to type two double quotes.  Writing to the ""
+register writes to register "0.
+{Vi: register contents are lost when changing files, no '"'}
+
+2. Numbered registers "0 to "9		*quote_number* *quote0*	*quote1*
+					*quote2* *quote3* *quote4* *quote9*
+Vim fills these registers with text from yank and delete commands.
+   Numbered register 0 contains the text from the most recent yank command,
+unless the command specified another register with ["x].
+   Numbered register 1 contains the text deleted by the most recent delete or
+change command, unless the command specified another register or the text is
+less than one line (the small delete register is used then).  An exception is
+made for the delete operator with these movement commands: |%|, |(|, |)|, |`|,
+|/|, |?|, |n|, |N|, |{| and |}|.  Register "1 is always used then (this is Vi
+compatible).  The "- register is used as well if the delete is within a line.
+   With each successive deletion or change, Vim shifts the previous contents
+of register 1 into register 2, 2 into 3, and so forth, losing the previous
+contents of register 9.
+{Vi: numbered register contents are lost when changing files; register 0 does
+not exist}
+
+3. Small delete register "-				*quote_-* *quote-*
+This register contains text from commands that delete less than one line,
+except when the command specifies a register with ["x].
+{not in Vi}
+
+4. Named registers "a to "z or "A to "Z			*quote_alpha* *quotea*
+Vim fills these registers only when you say so.  Specify them as lowercase
+letters to replace their previous contents or as uppercase letters to append
+to their previous contents.  When the '>' flag is present in 'cpoptions' then
+a line break is inserted before the appended text.
+
+5. Read-only registers ":, "., "% and "#
+These are '%', '#', ':' and '.'.  You can use them only with the "p", "P",
+and ":put" commands and with CTRL-R.  {not in Vi}
+						*quote_.* *quote.* *E29*
+	".	Contains the last inserted text (the same as what is inserted
+		with the insert mode commands CTRL-A and CTRL-@).  Note: this
+		doesn't work with CTRL-R on the command-line.  It works a bit
+		differently, like inserting the text instead of putting it
+		('textwidth' and other options affect what is inserted).
+							*quote_%* *quote%*
+	"%	Contains the name of the current file.
+							*quote_#* *quote#*
+	"#	Contains the name of the alternate file.
+						*quote_:* *quote:* *E30*
+	":	Contains the most recent executed command-line.  Example: Use
+		"@:" to repeat the previous command-line command.
+		The command-line is only stored in this register when at least
+		one character of it was typed.  Thus it remains unchanged if
+		the command was completely from a mapping.
+		{not available when compiled without the |+cmdline_hist|
+		feature}
+
+6. Expression register "=			*quote_=* *quote=* *@=*
+This is not really a register that stores text, but is a way to use an
+expression in commands which use a register.  The expression register is
+read-only; you cannot put text into it.  After the '=', the cursor moves to
+the command-line, where you can enter any expression (see |expression|).  All
+normal command-line editing commands are available, including a special
+history for expressions.  When you end the command-line by typing , Vim
+computes the result of the expression.  If you end it with , Vim abandons
+the expression.  If you do not enter an expression, Vim uses the previous
+expression (like with the "/" command).
+
+The expression must evaluate to a String.  A Number is always automatically
+converted to a String.  For the "p" and ":put" command, if the result is a
+Float it's converted into a String.  If the result is a List each element is
+turned into a String and used as a line.  A Dictionary or FuncRef results in
+an error message (use string() to convert).
+
+If the "= register is used for the "p" command, the String is split up at 
+characters.  If the String ends in a , it is regarded as a linewise
+register.  {not in Vi}
+
+7. Selection and drop registers "*, "+ and "~ 
+Use these registers for storing and retrieving the selected text for the GUI.
+See |quotestar| and |quoteplus|.  When the clipboard is not available or not
+working, the unnamed register is used instead.  For Unix systems the clipboard
+is only available when the |+xterm_clipboard| feature is present.  {not in Vi}
+
+Note that there is only a distinction between "* and "+ for X11 systems.  For
+an explanation of the difference, see |x11-selection|.  Under MS-Windows, use
+of "* and "+ is actually synonymous and refers to the |gui-clipboard|.
+
+						*quote_~* *quote~* **
+The read-only "~ register stores the dropped text from the last drag'n'drop
+operation.  When something has been dropped onto Vim, the "~ register is
+filled in and the  pseudo key is sent for notification.  You can remap
+this key if you want; the default action (for all modes) is to insert the
+contents of the "~ register at the cursor position.  {not in Vi}
+{only available when compiled with the |+dnd| feature, currently only with the
+GTK GUI}
+
+Note: The "~ register is only used when dropping plain text onto Vim.
+Drag'n'drop of URI lists is handled internally.
+
+8. Black hole register "_				*quote_*
+When writing to this register, nothing happens.  This can be used to delete
+text without affecting the normal registers.  When reading from this register,
+nothing is returned.  {not in Vi}
+
+9. Last search pattern register	"/			*quote_/* *quote/*
+Contains the most recent search-pattern.  This is used for "n" and 'hlsearch'.
+It is writable with ":let", you can change it to have 'hlsearch' highlight
+other matches without actually searching.  You can't yank or delete into this
+register.  The search direction is available in |v:searchforward|.
+Note that the valued is restored when returning from a function
+|function-search-undo|.
+{not in Vi}
+
+							*@/*
+You can write to a register with a ":let" command |:let-@|.  Example: >
+	:let @/ = "the"
+
+If you use a put command without specifying a register, Vim uses the register
+that was last filled (this is also the contents of the unnamed register).  If
+you are confused, use the ":dis" command to find out what Vim will put (this
+command displays all named and numbered registers; the unnamed register is
+labelled '"').
+
+The next three commands always work on whole lines.
+
+:[range]co[py] {address}				*:co* *:copy*
+			Copy the lines given by [range] to below the line
+			given by {address}.
+
+							*:t*
+:t			Synonym for copy.
+
+:[range]m[ove] {address}			*:m* *:mo* *:move* *E134*
+			Move the lines given by [range] to below the line
+			given by {address}.
+
+==============================================================================
+6. Formatting text					*formatting*
+
+:[range]ce[nter] [width]				*:ce* *:center*
+			Center lines in [range] between [width] columns
+			(default 'textwidth' or 80 when 'textwidth' is 0).
+			{not in Vi}
+			Not available when |+ex_extra| feature was disabled at
+			compile time.
+
+:[range]ri[ght] [width]					*:ri* *:right*
+			Right-align lines in [range] at [width] columns
+			(default 'textwidth' or 80 when 'textwidth' is 0).
+			{not in Vi}
+			Not available when |+ex_extra| feature was disabled at
+			compile time.
+
+							*:le* *:left*
+:[range]le[ft] [indent]
+			Left-align lines in [range].  Sets the indent in the
+			lines to [indent] (default 0).  {not in Vi}
+			Not available when |+ex_extra| feature was disabled at
+			compile time.
+
+							*gq*
+gq{motion}		Format the lines that {motion} moves over.
+			Formatting is done with one of three methods:
+			1. If 'formatexpr' is not empty the expression is
+			   evaluated.  This can differ for each buffer.
+			2. If 'formatprg' is not empty an external program
+			   is used.
+			3. Otherwise formatting is done internally.
+
+			In the third case the 'textwidth' option controls the
+			length of each formatted line (see below).
+			If the 'textwidth' option is 0, the formatted line
+			length is the screen width (with a maximum width of
+			79).
+			The 'formatoptions' option controls the type of
+			formatting |fo-table|.
+			The cursor is left on the first non-blank of the last
+			formatted line.
+			NOTE: The "Q" command formerly performed this
+			function.  If you still want to use "Q" for
+			formatting, use this mapping: >
+				:nnoremap Q gq
+
+gqgq							*gqgq* *gqq*
+gqq			Format the current line.  With a count format that
+			many lines.  {not in Vi}
+
+							*v_gq*
+{Visual}gq		Format the highlighted text.  (for {Visual} see
+			|Visual-mode|).  {not in Vi}
+
+							*gw*
+gw{motion}		Format the lines that {motion} moves over.  Similar to
+			|gq| but puts the cursor back at the same position in
+			the text.  However, 'formatprg' and 'formatexpr' are
+			not used.  {not in Vi}
+
+gwgw							*gwgw* *gww*
+gww			Format the current line as with "gw".  {not in Vi}
+
+							*v_gw*
+{Visual}gw		Format the highlighted text as with "gw".  (for
+			{Visual} see |Visual-mode|).  {not in Vi}
+
+Example: To format the current paragraph use:			*gqap*  >
+	gqap
+
+The "gq" command leaves the cursor in the line where the motion command takes
+the cursor.  This allows you to repeat formatting repeated with ".".  This
+works well with "gqj" (format current and next line) and "gq}" (format until
+end of paragraph).  Note: When 'formatprg' is set, "gq" leaves the cursor on
+the first formatted line (as with using a filter command).
+
+If you want to format the current paragraph and continue where you were, use: >
+	gwap
+If you always want to keep paragraphs formatted you may want to add the 'a'
+flag to 'formatoptions'.  See |auto-format|.
+
+If the 'autoindent' option is on, Vim uses the indent of the first line for
+the following lines.
+
+Formatting does not change empty lines (but it does change lines with only
+white space!).
+
+The 'joinspaces' option is used when lines are joined together.
+
+You can set the 'formatexpr' option to an expression or the 'formatprg' option
+to the name of an external program for Vim to use for text formatting.  The
+'textwidth' and other options have no effect on formatting by an external
+program.
+
+							*right-justify*
+There is no command in Vim to right justify text.  You can do it with
+an external command, like "par" (e.g.: "!}par" to format until the end of the
+paragraph) or set 'formatprg' to "par".
+
+							*format-comments*
+An overview of comment formatting is in section |30.6| of the user manual.
+
+Vim can automatically insert and format comments in a special way.  Vim
+recognizes a comment by a specific string at the start of the line (ignoring
+white space).  Three types of comments can be used:
+
+- A comment string that repeats at the start of each line.  An example is the
+  type of comment used in shell scripts, starting with "#".
+- A comment string that occurs only in the first line, not in the following
+  lines.  An example is this list with dashes.
+- Three-piece comments that have a start string, an end string, and optional
+  lines in between.  The strings for the start, middle and end are different.
+  An example is the C style comment:
+	/*
+	 * this is a C comment
+	 */
+
+The 'comments' option is a comma-separated list of parts.  Each part defines a
+type of comment string.  A part consists of:
+	{flags}:{string}
+
+{string} is the literal text that must appear.
+
+{flags}:
+  n	Nested comment.  Nesting with mixed parts is allowed.  If 'comments'
+	is "n:),n:>" a line starting with "> ) >" is a comment.
+
+  b	Blank (,  or ) required after {string}.
+
+  f	Only the first line has the comment string.  Do not repeat comment on
+	the next line, but preserve indentation (e.g., a bullet-list).
+
+  s	Start of three-piece comment
+
+  m	Middle of a three-piece comment
+
+  e	End of a three-piece comment
+
+  l	Left align. Used together with 's' or 'e', the leftmost character of
+	start or end will line up with the leftmost character from the middle.
+	This is the default and can be omitted. See below for more details.
+
+  r	Right align. Same as above but rightmost instead of leftmost. See
+	below for more details.
+
+  O	Don't consider this comment for the "O" command.
+
+  x	Allows three-piece comments to be ended by just typing the last
+	character of the end-comment string as the first action on a new
+	line when the middle-comment string has been inserted automatically.
+	See below for more details.
+
+  {digits}
+	When together with 's' or 'e': add {digit} amount of offset to an
+	automatically inserted middle or end comment leader. The offset begins
+	from a left alignment. See below for more details.
+
+  -{digits}
+	Like {digits} but reduce the indent.  This only works when there is
+	some indent for the start or end part that can be removed.
+
+When a string has none of the 'f', 's', 'm' or 'e' flags, Vim assumes the
+comment string repeats at the start of each line.  The flags field may be
+empty.
+
+Any blank space in the text before and after the {string} is part of the
+{string}, so do not include leading or trailing blanks unless the blanks are a
+required part of the comment string.
+
+When one comment leader is part of another, specify the part after the whole.
+For example, to include both "-" and "->", use >
+	:set comments=f:->,f:-
+
+A three-piece comment must always be given as start,middle,end, with no other
+parts in between.  An example of a three-piece comment is >
+	sr:/*,mb:*,ex:*/
+for C-comments.  To avoid recognizing "*ptr" as a comment, the middle string
+includes the 'b' flag.  For three-piece comments, Vim checks the text after
+the start and middle strings for the end string.  If Vim finds the end string,
+the comment does not continue on the next line.  Three-piece comments must
+have a middle string because otherwise Vim can't recognize the middle lines.
+
+Notice the use of the "x" flag in the above three-piece comment definition.
+When you hit Return in a C-comment, Vim will insert the middle comment leader
+for the new line: " * ".  To close this comment you just have to type "/"
+before typing anything else on the new line.  This will replace the
+middle-comment leader with the end-comment leader and apply any specified
+alignment, leaving just " */".  There is no need to hit BackSpace first.
+
+
+Here is an example of alignment flags at work to make a comment stand out
+(kind of looks like a 1 too). Consider comment string >
+	sr:/***,m:**,ex2:******/
+
+                                   /***
+                                     **<--right aligned from "r" flag
+                                     **
+offset 2 spaces from the "2" flag--->**
+                                   ******/
+In this case, the first comment was typed, then return was pressed 4 times,
+then "/" was pressed to end the comment.
+
+Here are some finer points of three part comments. There are three times when
+alignment and offset flags are taken into consideration: opening a new line
+after a start-comment, opening a new line before an end-comment, and
+automatically ending a three-piece comment.  The end alignment flag has a
+backwards perspective; the result is that the same alignment flag used with
+"s" and "e" will result in the same indent for the starting and ending pieces.
+Only one alignment per comment part is meant to be used, but an offset number
+will override the "r" and "l" flag.
+
+Enabling 'cindent' will override the alignment flags in many cases.
+Reindenting using a different method like |gq| or |=| will not consult
+alignment flags either. The same behaviour can be defined in those other
+formatting options. One consideration is that 'cindent' has additional options
+for context based indenting of comments but cannot replicate many three piece
+indent alignments.  However, 'indentexpr' is has the ability to work better
+with three piece comments.
+
+Other examples: >
+   "b:*"	Includes lines starting with "*", but not if the "*" is
+		followed by a non-blank.  This avoids a pointer dereference
+		like "*str" to be recognized as a comment.
+   "n:>"	Includes a line starting with ">", ">>", ">>>", etc.
+   "fb:-"	Format a list that starts with "- ".
+
+By default, "b:#" is included.  This means that a line that starts with
+"#include" is not recognized as a comment line.  But a line that starts with
+"# define" is recognized.  This is a compromise.
+
+{not available when compiled without the |+comments| feature}
+
+							*fo-table*
+You can use the 'formatoptions' option  to influence how Vim formats text.
+'formatoptions' is a string that can contain any of the letters below.  The
+default setting is "tcq".  You can separate the option letters with commas for
+readability.
+
+letter	 meaning when present in 'formatoptions'    ~
+
+t	Auto-wrap text using textwidth
+c	Auto-wrap comments using textwidth, inserting the current comment
+	leader automatically.
+r	Automatically insert the current comment leader after hitting
+	 in Insert mode.
+o	Automatically insert the current comment leader after hitting 'o' or
+	'O' in Normal mode.
+q	Allow formatting of comments with "gq".
+	Note that formatting will not change blank lines or lines containing
+	only the comment leader.  A new paragraph starts after such a line,
+	or when the comment leader changes.
+w	Trailing white space indicates a paragraph continues in the next line.
+	A line that ends in a non-white character ends a paragraph.
+a	Automatic formatting of paragraphs.  Every time text is inserted or
+	deleted the paragraph will be reformatted.  See |auto-format|.
+	When the 'c' flag is present this only happens for recognized
+	comments.
+n	When formatting text, recognize numbered lists.  This actually uses
+	the 'formatlistpat' option, thus any kind of list can be used.  The
+	indent of the text after the number is used for the next line.  The
+	default is to find a number, optionally followed by '.', ':', ')',
+	']' or '}'.  Note that 'autoindent' must be set too.  Doesn't work
+	well together with "2".
+	Example: >
+		1. the first item
+		   wraps
+		2. the second item
+2	When formatting text, use the indent of the second line of a paragraph
+	for the rest of the paragraph, instead of the indent of the first
+	line.  This supports paragraphs in which the first line has a
+	different indent than the rest.  Note that 'autoindent' must be set
+	too.  Example: >
+			first line of a paragraph
+		second line of the same paragraph
+		third line.
+v	Vi-compatible auto-wrapping in insert mode: Only break a line at a
+	blank that you have entered during the current insert command.  (Note:
+	this is not 100% Vi compatible.  Vi has some "unexpected features" or
+	bugs in this area.  It uses the screen column instead of the line
+	column.)
+b	Like 'v', but only auto-wrap if you enter a blank at or before
+	the wrap margin.  If the line was longer than 'textwidth' when you
+	started the insert, or you do not enter a blank in the insert before
+	reaching 'textwidth', Vim does not perform auto-wrapping.
+l	Long lines are not broken in insert mode: When a line was longer than
+	'textwidth' when the insert command started, Vim does not
+	automatically format it.
+m	Also break at a multi-byte character above 255.  This is useful for
+	Asian text where every character is a word on its own.
+M	When joining lines, don't insert a space before or after a multi-byte
+	character.  Overrules the 'B' flag.
+B	When joining lines, don't insert a space between two multi-byte
+	characters.  Overruled by the 'M' flag.
+1	Don't break a line after a one-letter word.  It's broken before it
+	instead (if possible).
+
+
+With 't' and 'c' you can specify when Vim performs auto-wrapping:
+value	action	~
+""	no automatic formatting (you can use "gq" for manual formatting)
+"t"	automatic formatting of text, but not comments
+"c"	automatic formatting for comments, but not text (good for C code)
+"tc"	automatic formatting for text and comments
+
+Note that when 'textwidth' is 0, Vim does no automatic formatting anyway (but
+does insert comment leaders according to the 'comments' option).  An exception
+is when the 'a' flag is present. |auto-format|
+
+Note that when 'paste' is on, Vim does no formatting at all.
+
+Note that 'textwidth' can be non-zero even if Vim never performs auto-wrapping;
+'textwidth' is still useful for formatting with "gq".
+
+If the 'comments' option includes "/*", "*" and/or "*/", then Vim has some
+built in stuff to treat these types of comments a bit more cleverly.
+Opening a new line before or after "/*" or "*/" (with 'r' or 'o' present in
+'formatoptions') gives the correct start of the line automatically.  The same
+happens with formatting and auto-wrapping.  Opening a line after a line
+starting with "/*" or "*" and containing "*/", will cause no comment leader to
+be inserted, and the indent of the new line is taken from the line containing
+the start of the comment.
+E.g.:
+    /* ~
+     * Your typical comment. ~
+     */ ~
+    The indent on this line is the same as the start of the above
+    comment.
+
+All of this should be really cool, especially in conjunction with the new
+:autocmd command to prepare different settings for different types of file.
+
+Some examples:
+  for C code (only format comments): >
+	:set fo=croq
+< for Mail/news	(format all, don't start comment with "o" command): >
+	:set fo=tcrq
+<
+
+Automatic formatting					*auto-format*
+
+When the 'a' flag is present in 'formatoptions' text is formatted
+automatically when inserting text or deleting text.  This works nice for
+editing text paragraphs.  A few hints on how to use this:
+
+- You need to properly define paragraphs.  The simplest is paragraphs that are
+  separated by a blank line.  When there is no separating blank line, consider
+  using the 'w' flag and adding a space at the end of each line in the
+  paragraphs except the last one.
+
+- You can set the 'formatoptions' based on the type of file |filetype| or
+  specifically for one file with a |modeline|.
+
+- Set 'formatoptions' to "aw2tq" to make text with indents like this:
+
+	    bla bla foobar bla 
+	bla foobar bla foobar bla
+	    bla bla foobar bla 
+	bla foobar bla bla foobar
+
+- Add the 'c' flag to only auto-format comments.  Useful in source code.
+
+- Set 'textwidth' to the desired width.  If it is zero then 79 is used, or the
+  width of the screen if this is smaller.
+
+And a few warnings:
+
+- When part of the text is not properly separated in paragraphs, making
+  changes in this text will cause it to be formatted anyway.  Consider doing >
+
+	:set fo-=a
+
+- When using the 'w' flag (trailing space means paragraph continues) and
+  deleting the last line of a paragraph with |dd|, the paragraph will be
+  joined with the next one.
+
+- Changed text is saved for undo.  Formatting is also a change.  Thus each
+  format action saves text for undo.  This may consume quite a lot of memory.
+
+- Formatting a long paragraph and/or with complicated indenting may be slow.
+
+==============================================================================
+7. Sorting text						*sorting*
+
+Vim has a sorting function and a sorting command.  The sorting function can be
+found here: |sort()|.
+
+							*:sor* *:sort*
+:[range]sor[t][!] [i][u][r][n][x][o] [/{pattern}/]
+			Sort lines in [range].  When no range is given all
+			lines are sorted.
+
+			With [!] the order is reversed.
+
+			With [i] case is ignored.
+
+			With [n] sorting is done on the first decimal number
+			in the line (after or inside a {pattern} match).
+			One leading '-' is included in the number.
+
+			With [x] sorting is done on the first hexadecimal
+			number in the line (after or inside a {pattern}
+			match).  A leading "0x" or "0X" is ignored.
+			One leading '-' is included in the number.
+
+			With [o] sorting is done on the first octal number in
+			the line (after or inside a {pattern} match).
+
+			With [u] only keep the first of a sequence of
+			identical lines (ignoring case when [i] is used).
+			Without this flag, a sequence of identical lines
+			will be kept in their original order.
+			Note that leading and trailing white space may cause
+			lines to be different.
+
+			When /{pattern}/ is specified and there is no [r] flag
+			the text matched with {pattern} is skipped, so that
+			you sort on what comes after the match.
+			Instead of the slash any non-letter can be used.
+			For example, to sort on the second comma-separated
+			field: >
+				:sort /[^,]*,/
+<			To sort on the text at virtual column 10 (thus
+			ignoring the difference between tabs and spaces): >
+				:sort /.*\%10v/
+<			To sort on the first number in the line, no matter
+			what is in front of it: >
+				:sort /.\{-}\ze\d/
+<			(Explanation: ".\{-}" matches any text, "\ze" sets the
+			end of the match and \d matches a digit.)
+			With [r] sorting is done on the matching {pattern}
+			instead of skipping past it as described above.
+			For example, to sort on only the first three letters
+			of each line: >
+				:sort /\a\a\a/ r
+
+<			If a {pattern} is used, any lines which don't have a
+			match for {pattern} are kept in their current order,
+			but separate from the lines which do match {pattern}.
+			If you sorted in reverse, they will be in reverse
+			order after the sorted lines, otherwise they will be
+			in their original order, right before the sorted
+			lines.
+
+			If {pattern} is empty (e.g. // is specified), the
+			last search pattern is used.  This allows trying out
+			a pattern first.
+
+Note that using ":sort" with ":global" doesn't sort the matching lines, it's
+quite useless.
+
+The details about sorting depend on the library function used.  There is no
+guarantee that sorting is "stable" or obeys the current locale.  You will have
+to try it out.
+
+The sorting can be interrupted, but if you interrupt it too late in the
+process you may end up with duplicated lines.  This also depends on the system
+library function used.
+
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/cmdline.txt b/share/vim/vim73/doc/cmdline.txt
new file mode 100644
index 0000000000..a072c6cdab
--- /dev/null
+++ b/share/vim/vim73/doc/cmdline.txt
@@ -0,0 +1,1091 @@
+*cmdline.txt*   For Vim version 7.3.  Last change: 2010 May 07
+
+
+		  VIM REFERENCE MANUAL    by Bram Moolenaar
+
+
+				*Cmdline-mode* *Command-line-mode*
+Command-line mode		*Cmdline* *Command-line* *mode-cmdline* *:*
+
+Command-line mode is used to enter Ex commands (":"), search patterns
+("/" and "?"), and filter commands ("!").
+
+Basic command line editing is explained in chapter 20 of the user manual
+|usr_20.txt|.
+
+1. Command-line editing		|cmdline-editing|
+2. Command-line completion	|cmdline-completion|
+3. Ex command-lines		|cmdline-lines|
+4. Ex command-line ranges	|cmdline-ranges|
+5. Ex command-line flags	|ex-flags|
+6. Ex special characters	|cmdline-special|
+7. Command-line window		|cmdline-window|
+
+==============================================================================
+1. Command-line editing					*cmdline-editing*
+
+Normally characters are inserted in front of the cursor position.  You can
+move around in the command-line with the left and right cursor keys.  With the
+ key, you can toggle between inserting and overstriking characters.
+{Vi: can only alter the last character in the line}
+
+Note that if your keyboard does not have working cursor keys or any of the
+other special keys, you can use ":cnoremap" to define another key for them.
+For example, to define tcsh style editing keys:		*tcsh-style*  >
+	:cnoremap  
+	:cnoremap  
+	:cnoremap  
+	:cnoremap b 
+	:cnoremap f 
+(<> notation |<>|; type all this literally)
+
+							*cmdline-too-long*
+When the command line is getting longer than what fits on the screen, only the
+part that fits will be shown.  The cursor can only move in this visible part,
+thus you cannot edit beyond that.
+
+						*cmdline-history* *history*
+The command-lines that you enter are remembered in a history table.  You can
+recall them with the up and down cursor keys.  There are actually five
+history tables:
+- one for ':' commands
+- one for search strings
+- one for expressions
+- one for input lines, typed for the |input()| function.
+- one for debug mode commands
+These are completely separate.  Each history can only be accessed when
+entering the same type of line.
+Use the 'history' option to set the number of lines that are remembered
+(default: 20).
+Notes:
+- When you enter a command-line that is exactly the same as an older one, the
+  old one is removed (to avoid repeated commands moving older commands out of
+  the history).
+- Only commands that are typed are remembered.  Ones that completely come from
+  mappings are not put in the history.
+- All searches are put in the search history, including the ones that come
+  from commands like "*" and "#".  But for a mapping, only the last search is
+  remembered (to avoid that long mappings trash the history).
+{Vi: no history}
+{not available when compiled without the |+cmdline_hist| feature}
+
+There is an automatic completion of names on the command-line; see
+|cmdline-completion|.
+
+							*c_CTRL-V*
+CTRL-V		Insert next non-digit literally.  Up to three digits form the
+		decimal value of a single byte.  The non-digit and the three
+		digits are not considered for mapping.  This works the same
+		way as in Insert mode (see above, |i_CTRL-V|).
+		Note: Under Windows CTRL-V is often mapped to paste text.
+		Use CTRL-Q instead then.
+							*c_CTRL-Q*
+CTRL-Q		Same as CTRL-V.  But with some terminals it is used for
+		control flow, it doesn't work then.
+
+							*c_*
+		cursor left
+							*c_*
+		cursor right
+							*c_*
+ or 					*c_*
+		cursor one WORD left
+							*c_*
+ or 					*c_*
+		cursor one WORD right
+CTRL-B or 					*c_CTRL-B* *c_*
+		cursor to beginning of command-line
+CTRL-E or 						*c_CTRL-E* *c_*
+		cursor to end of command-line
+
+							*c_*
+	Move the cursor to the position of the mouse click.
+
+CTRL-H							*c_* *c_CTRL-H*
+		Delete the character in front of the cursor (see |:fixdel| if
+		your  key does not do what you want).
+							*c_*
+		Delete the character under the cursor (at end of line:
+		character before the cursor) (see |:fixdel| if your 
+		key does not do what you want).
+							*c_CTRL-W*
+CTRL-W		Delete the |word| before the cursor.  This depends on the
+		'iskeyword' option.
+							*c_CTRL-U*
+CTRL-U		Remove all characters between the cursor position and
+		the beginning of the line.  Previous versions of vim
+		deleted all characters on the line.  If that is the
+		preferred behavior, add the following to your .vimrc: >
+			:cnoremap  
+<
+							*c_*
+	Toggle between insert and overstrike.  {not in Vi}
+
+{char1}  {char2}	or				*c_digraph*
+CTRL-K {char1} {char2}					*c_CTRL-K*
+		enter digraph (see |digraphs|).  When {char1} is a special
+		key, the code for that key is inserted in <> form.  {not in Vi}
+
+CTRL-R {0-9a-z"%#:-=.}					*c_CTRL-R* *c_*
+		Insert the contents of a numbered or named register.  Between
+		typing CTRL-R and the second character '"' will be displayed
+		to indicate that you are expected to enter the name of a
+		register.
+		The text is inserted as if you typed it, but mappings and
+		abbreviations are not used.  Command-line completion through
+		'wildchar' is not triggered though.  And characters that end
+		the command line are inserted literally (, , ,
+		).  A  or CTRL-W could still end the command line
+		though, and remaining characters will then be interpreted in
+		another mode, which might not be what you intended.
+		Special registers:
+			'"'	the unnamed register, containing the text of
+				the last delete or yank
+			'%'	the current file name
+			'#'	the alternate file name
+			'*'	the clipboard contents (X11: primary selection)
+			'+'	the clipboard contents
+			'/'	the last search pattern
+			':'	the last command-line
+			'-'	the last small (less than a line) delete
+			'.'	the last inserted text
+							*c_CTRL-R_=*
+			'='	the expression register: you are prompted to
+				enter an expression (see |expression|)
+				(doesn't work at the expression prompt; some
+				things such as changing the buffer or current
+				window are not allowed to avoid side effects)
+				When the result is a |List| the items are used
+				as lines.  They can have line breaks inside
+				too.
+				When the result is a Float it's automatically
+				converted to a String.
+		See |registers| about registers.  {not in Vi}
+		Implementation detail: When using the |expression| register
+		and invoking setcmdpos(), this sets the position before
+		inserting the resulting string.  Use CTRL-R CTRL-R to set the
+		position afterwards.
+
+CTRL-R CTRL-F				*c_CTRL-R_CTRL-F* *c__*
+CTRL-R CTRL-P				*c_CTRL-R_CTRL-P* *c__*
+CTRL-R CTRL-W				*c_CTRL-R_CTRL-W* *c__*
+CTRL-R CTRL-A				*c_CTRL-R_CTRL-A* *c__*
+		Insert the object under the cursor:
+			CTRL-F	the Filename under the cursor
+			CTRL-P	the Filename under the cursor, expanded with
+				'path' as in |gf|
+			CTRL-W	the Word under the cursor
+			CTRL-A	the WORD under the cursor; see |WORD|
+
+		When 'incsearch' is set the cursor position at the end of the
+		currently displayed match is used.  With CTRL-W the part of
+		the word that was already typed is not inserted again.
+
+		{not in Vi}
+		CTRL-F and CTRL-P: {only when |+file_in_path| feature is
+		included}
+
+					*c_CTRL-R_CTRL-R* *c__*
+					*c_CTRL-R_CTRL-O* *c__*
+CTRL-R CTRL-R {0-9a-z"%#:-=. CTRL-F CTRL-P CTRL-W CTRL-A}
+CTRL-R CTRL-O {0-9a-z"%#:-=. CTRL-F CTRL-P CTRL-W CTRL-A}
+		Insert register or object under the cursor.  Works like
+		|c_CTRL-R| but inserts the text literally.  For example, if
+		register a contains "xy^Hz" (where ^H is a backspace),
+		"CTRL-R a" will insert "xz" while "CTRL-R CTRL-R a" will
+		insert "xy^Hz".
+
+CTRL-\ e {expr}						*c_CTRL-\_e*
+		Evaluate {expr} and replace the whole command line with the
+		result.  You will be prompted for the expression, type 
+		to finish it.  It's most useful in mappings though.  See
+		|expression|.
+		See |c_CTRL-R_=| for inserting the result of an expression.
+		Useful functions are |getcmdtype()|, |getcmdline()| and
+		|getcmdpos()|.
+		The cursor position is unchanged, except when the cursor was
+		at the end of the line, then it stays at the end.
+		|setcmdpos()| can be used to set the cursor position.
+		The |sandbox| is used for evaluating the expression to avoid
+		nasty side effects.
+		Example: >
+			:cmap  eAppendSome()
+			:func AppendSome()
+			   :let cmd = getcmdline() . " Some()"
+			   :" place the cursor on the )
+			   :call setcmdpos(strlen(cmd))
+			   :return cmd
+			:endfunc
+<		This doesn't work recursively, thus not when already editing
+		an expression.
+
+							*c_CTRL-Y*
+CTRL-Y		When there is a modeless selection, copy the selection into
+		the clipboard. |modeless-selection|
+		If there is no selection CTRL-Y is inserted as a character.
+
+CTRL-J						*c_CTRL-J* *c_* *c_*
+ or 	start entered command
+							*c_*
+		When typed and 'x' not present in 'cpoptions', quit
+		Command-line mode without executing.  In macros or when 'x'
+		present in 'cpoptions', start entered command.
+		Note: If your  key is hard to hit on your keyboard, train
+		yourself to use CTRL-[.
+							*c_CTRL-C*
+CTRL-C		quit command-line without executing
+
+							*c_*
+		recall older command-line from history, whose beginning
+		matches the current command-line (see below).
+		{not available when compiled without the |+cmdline_hist|
+		feature}
+							*c_*
+		recall more recent command-line from history, whose beginning
+		matches the current command-line (see below).
+		{not available when compiled without the |+cmdline_hist|
+		feature}
+
+							*c_* *c_*
+ or 
+		recall older command-line from history
+		{not available when compiled without the |+cmdline_hist|
+		feature}
+						*c_* *c_*
+ or 
+		recall more recent command-line from history
+		{not available when compiled without the |+cmdline_hist|
+		feature}
+
+CTRL-D		command-line completion (see |cmdline-completion|)
+'wildchar' option
+		command-line completion (see |cmdline-completion|)
+CTRL-N		command-line completion (see |cmdline-completion|)
+CTRL-P		command-line completion (see |cmdline-completion|)
+CTRL-A		command-line completion (see |cmdline-completion|)
+CTRL-L		command-line completion (see |cmdline-completion|)
+
+							*c_CTRL-_*
+CTRL-_		a - switch between Hebrew and English keyboard mode, which is
+		private to the command-line and not related to hkmap.
+		This is useful when Hebrew text entry is required in the
+		command-line, searches, abbreviations, etc.  Applies only if
+		Vim is compiled with the |+rightleft| feature and the
+		'allowrevins' option is set.
+		See |rileft.txt|.
+
+		b - switch between Farsi and English keyboard mode, which is
+		private to the command-line and not related to fkmap.  In
+		Farsi keyboard mode the characters are inserted in reverse
+		insert manner.  This is useful when Farsi text entry is
+		required in the command-line, searches, abbreviations, etc.
+		Applies only if Vim is compiled with the |+farsi| feature.
+		See |farsi.txt|.
+
+							*c_CTRL-^*
+CTRL-^		Toggle the use of language |:lmap| mappings and/or Input
+		Method.
+		When typing a pattern for a search command and 'imsearch' is
+		not -1, VAL is the value of 'imsearch', otherwise VAL is the
+		value of 'iminsert'.
+		When language mappings are defined:
+		- If VAL is 1 (langmap mappings used) it becomes 0 (no langmap
+		  mappings used).
+		- If VAL was not 1 it becomes 1, thus langmap mappings are
+		  enabled.
+		When no language mappings are defined:
+		- If VAL is 2 (Input Method is used) it becomes 0 (no input
+		  method used)
+		- If VAL has another value it becomes 2, thus the Input Method
+		  is enabled.
+		These language mappings are normally used to type characters
+		that are different from what the keyboard produces.  The
+		'keymap' option can be used to install a whole number of them.
+		When entering a command line, langmap mappings are switched
+		off, since you are expected to type a command.  After
+		switching it on with CTRL-^, the new state is not used again
+		for the next command or Search pattern.
+		{not in Vi}
+
+						*c_CTRL-]*
+CTRL-]		Trigger abbreviation, without inserting a character.  {not in
+		Vi}
+
+For Emacs-style editing on the command-line see |emacs-keys|.
+
+The  and  keys take the current command-line as a search string.
+The beginning of the next/previous command-lines are compared with this
+string.  The first line that matches is the new command-line.  When typing
+these two keys repeatedly, the same string is used again.  For example, this
+can be used to find the previous substitute command: Type ":s" and then .
+The same could be done by typing  a number of times until the desired
+command-line is shown.  (Note: the shifted arrow keys do not work on all
+terminals)
+
+							*:his* *:history*
+:his[tory]	Print the history of last entered commands.
+		{not in Vi}
+		{not available when compiled without the |+cmdline_hist|
+		feature}
+
+:his[tory] [{name}] [{first}][, [{last}]]
+		List the contents of history {name} which can be:
+		c[md]	 or :	command-line history
+		s[earch] or /	search string history
+		e[xpr]	 or =	expression register history
+		i[nput]	 or @	input line history
+		d[ebug]	 or >	debug command history
+		a[ll]		all of the above
+		{not in Vi}
+
+		If the numbers {first} and/or {last} are given, the respective
+		range of entries from a history is listed.  These numbers can
+		be specified in the following form:
+							*:history-indexing*
+		A positive number represents the absolute index of an entry
+		as it is given in the first column of a :history listing.
+		This number remains fixed even if other entries are deleted.
+
+		A negative number means the relative position of an entry,
+		counted from the newest entry (which has index -1) backwards.
+
+		Examples:
+		List entries 6 to 12 from the search history: >
+			:history / 6,12
+<
+		List the recent five entries from all histories: >
+			:history all -5,
+
+==============================================================================
+2. Command-line completion				*cmdline-completion*
+
+When editing the command-line, a few commands can be used to complete the
+word before the cursor.  This is available for:
+
+- Command names: At the start of the command-line.
+- Tags: Only after the ":tag" command.
+- File names: Only after a command that accepts a file name or a setting for
+  an option that can be set to a file name.  This is called file name
+  completion.
+- Shell command names: After ":!cmd", ":r !cmd" and ":w !cmd".  $PATH is used.
+- Options: Only after the ":set" command.
+- Mappings: Only after a ":map" or similar command.
+- Variable and function names: Only after a ":if", ":call" or similar command.
+
+When Vim was compiled with the |+cmdline_compl| feature disabled, only file
+names, directories and help items can be completed.  The number of help item
+matches is limited (currently to 300) to avoid a long delay when there are
+very many matches.
+
+These are the commands that can be used:
+
+							*c_CTRL-D*
+CTRL-D		List names that match the pattern in front of the cursor.
+		When showing file names, directories are highlighted (see
+		'highlight' option).  Names where 'suffixes' matches are moved
+		to the end.
+		The 'wildoptions' option can be set to "tagfile" to list the
+		file of matching tags.
+					*c_CTRL-I* *c_wildchar* *c_*
+'wildchar' option
+		A match is done on the pattern in front of the cursor.  The
+		match (if there are several, the first match) is inserted
+		in place of the pattern.  (Note: does not work inside a
+		macro, because  or  are mostly used as 'wildchar',
+		and these have a special meaning in some macros.) When typed
+		again and there were multiple matches, the next
+		match is inserted.  After the last match, the first is used
+		again (wrap around).
+		The behavior can be changed with the 'wildmode' option.
+							*c_CTRL-N*
+CTRL-N		After using 'wildchar' which got multiple matches, go to next
+		match.  Otherwise recall more recent command-line from history.
+							*c_CTRL-P* *c_*
+CTRL-P		After using 'wildchar' which got multiple matches, go to
+		previous match.  Otherwise recall older command-line from
+		history.   only works with the GUI, on the Amiga and
+		with MS-DOS.
+							*c_CTRL-A*
+CTRL-A		All names that match the pattern in front of the cursor are
+		inserted.
+							*c_CTRL-L*
+CTRL-L		A match is done on the pattern in front of the cursor.  If
+		there is one match, it is inserted in place of the pattern.
+		If there are multiple matches the longest common part is
+		inserted in place of the pattern.  If the result is shorter
+		than the pattern, no completion is done.
+		When 'incsearch' is set, entering a search pattern for "/" or
+		"?" and the current match is displayed then CTRL-L will add
+		one character from the end of the current match.  If
+		'ignorecase' and 'smartcase' are set and the command line has
+		no uppercase characters, the added character is converted to
+		lowercase.
+
+The 'wildchar' option defaults to  (CTRL-E when in Vi compatible mode; in
+a previous version  was used).  In the pattern standard wildcards '*' and
+'?' are accepted.  '*' matches any string, '?' matches exactly one character.
+
+If you like tcsh's autolist completion, you can use this mapping:
+	:cnoremap X 
+(Where X is the command key to use,  is CTRL-L and  is CTRL-D)
+This will find the longest match and then list all matching files.
+
+If you like tcsh's autolist completion, you can use the 'wildmode' option to
+emulate it.  For example, this mimics autolist=ambiguous:
+	:set wildmode=longest,list
+This will find the longest match with the first 'wildchar', then list all
+matching files with the next.
+
+							*suffixes*
+For file name completion you can use the 'suffixes' option to set a priority
+between files with almost the same name.  If there are multiple matches,
+those files with an extension that is in the 'suffixes' option are ignored.
+The default is ".bak,~,.o,.h,.info,.swp,.obj", which means that files ending
+in ".bak", "~", ".o", ".h", ".info", ".swp" and ".obj" are sometimes ignored.
+
+An empty entry, two consecutive commas, match a file name that does not
+contain a ".", thus has no suffix.  This is useful to ignore "prog" and prefer
+"prog.c".
+
+Examples:
+
+  pattern:	files:				match:	~
+   test*	test.c test.h test.o		test.c
+   test*	test.h test.o			test.h and test.o
+   test*	test.i test.h test.c		test.i and test.c
+
+It is impossible to ignore suffixes with two dots.
+
+If there is more than one matching file (after ignoring the ones matching
+the 'suffixes' option) the first file name is inserted.  You can see that
+there is only one match when you type 'wildchar' twice and the completed
+match stays the same.  You can get to the other matches by entering
+'wildchar', CTRL-N or CTRL-P.  All files are included, also the ones with
+extensions matching the 'suffixes' option.
+
+To completely ignore files with some extension use 'wildignore'.
+
+To match only files that end at the end of the typed text append a "$".  For
+example, to match only files that end in ".c": >
+	:e *.c$
+This will not match a file ending in ".cpp".  Without the "$" it does match.
+
+The old value of an option can be obtained by hitting 'wildchar' just after
+the '='.  For example, typing 'wildchar' after ":set dir=" will insert the
+current value of 'dir'.  This overrules file name completion for the options
+that take a file name.
+
+If you would like using  for CTRL-P in an xterm, put this command in
+your .cshrc: >
+	xmodmap -e "keysym Tab = Tab Find"
+And this in your .vimrc: >
+	:cmap [1~ 
+
+==============================================================================
+3. Ex command-lines					*cmdline-lines*
+
+The Ex commands have a few specialties:
+
+							*:quote* *:comment*
+'"' at the start of a line causes the whole line to be ignored.  '"'
+after a command causes the rest of the line to be ignored.  This can be used
+to add comments.  Example: >
+	:set ai		"set 'autoindent' option
+It is not possible to add a comment to a shell command ":!cmd" or to the
+":map" command and a few others, because they see the '"' as part of their
+argument.  This is mentioned where the command is explained.
+
+							*:bar* *:\bar*
+'|' can be used to separate commands, so you can give multiple commands in one
+line.  If you want to use '|' in an argument, precede it with '\'.
+
+These commands see the '|' as their argument, and can therefore not be
+followed by another Vim command:
+    :argdo
+    :autocmd
+    :bufdo
+    :command
+    :cscope
+    :debug
+    :folddoopen
+    :folddoclosed
+    :function
+    :global
+    :help
+    :helpfind
+    :lcscope
+    :make
+    :normal
+    :perl
+    :perldo
+    :promptfind
+    :promptrepl
+    :pyfile
+    :python
+    :registers
+    :read !
+    :scscope
+    :sign
+    :tcl
+    :tcldo
+    :tclfile
+    :vglobal
+    :windo
+    :write !
+    :[range]!
+    a user defined command without the "-bar" argument |:command|
+
+Note that this is confusing (inherited from Vi): With ":g" the '|' is included
+in the command, with ":s" it is not.
+
+To be able to use another command anyway, use the ":execute" command.
+Example (append the output of "ls" and jump to the first line): >
+	:execute 'r !ls' | '[
+
+There is one exception: When the 'b' flag is present in 'cpoptions', with the
+":map" and ":abbr" commands and friends CTRL-V needs to be used instead of
+'\'.  You can also use "" instead.  See also |map_bar|.
+
+Examples: >
+	:!ls | wc		view the output of two commands
+	:r !ls | wc		insert the same output in the text
+	:%g/foo/p|>		moves all matching lines one shiftwidth
+	:%s/foo/bar/|>		moves one line one shiftwidth
+	:map q 10^V|		map "q" to "10|"
+	:map q 10\| map \ l	map "q" to "10\" and map "\" to "l"
+					(when 'b' is present in 'cpoptions')
+
+You can also use  to separate commands in the same way as with '|'.  To
+insert a  use CTRL-V CTRL-J.  "^@" will be shown.  Using '|' is the
+preferred method.  But for external commands a  must be used, because a
+'|' is included in the external command.  To avoid the special meaning of 
+it must be preceded with a backslash.  Example: >
+	:r !date-join
+This reads the current date into the file and joins it with the previous line.
+
+Note that when the command before the '|' generates an error, the following
+commands will not be executed.
+
+
+Because of Vi compatibility the following strange commands are supported: >
+	:|			print current line (like ":p")
+	:3|			print line 3 (like ":3p")
+	:3			goto line 3
+
+A colon is allowed between the range and the command name.  It is ignored
+(this is Vi compatible).  For example: >
+	:1,$:s/pat/string
+
+When the character '%' or '#' is used where a file name is expected, they are
+expanded to the current and alternate file name (see the chapter "editing
+files" |:_%| |:_#|).
+
+Embedded spaces in file names are allowed on the Amiga if one file name is
+expected as argument.  Trailing spaces will be ignored, unless escaped with a
+backslash or CTRL-V.  Note that the ":next" command uses spaces to separate
+file names.  Escape the spaces to include them in a file name.  Example: >
+	:next foo\ bar goes\ to school\
+starts editing the three files "foo bar", "goes to" and "school ".
+
+When you want to use the special characters '"' or '|' in a command, or want
+to use '%' or '#' in a file name, precede them with a backslash.  The
+backslash is not required in a range and in the ":substitute" command.
+
+							*:_!*
+The '!' (bang) character after an Ex command makes the command behave in a
+different way.  The '!' should be placed immediately after the command, without
+any blanks in between.  If you insert blanks the '!' will be seen as an
+argument for the command, which has a different meaning.  For example:
+	:w! name	write the current buffer to file "name", overwriting
+			any existing file
+	:w !name	send the current buffer as standard input to command
+			"name"
+
+==============================================================================
+4. Ex command-line ranges	*cmdline-ranges* *[range]* *E16*
+
+Some Ex commands accept a line range in front of them.  This is noted as
+[range].  It consists of one or more line specifiers, separated with ',' or
+';'.
+
+The basics are explained in section |10.3| of the user manual.
+
+						*:,* *:;*
+When separated with ';' the cursor position will be set to that line
+before interpreting the next line specifier.  This doesn't happen for ','.
+Examples: >
+   4,/this line/
+<	from line 4 till match with "this line" after the cursor line. >
+   5;/that line/
+<	from line 5 till match with "that line" after line 5.
+
+The default line specifier for most commands is the cursor position, but the
+commands ":write" and ":global" have the whole file (1,$) as default.
+
+If more line specifiers are given than required for the command, the first
+one(s) will be ignored.
+
+Line numbers may be specified with:		*:range* *E14* *{address}*
+	{number}	an absolute line number
+	.		the current line			  *:.*
+	$		the last line in the file		  *:$*
+	%		equal to 1,$ (the entire file)		  *:%*
+	't		position of mark t (lowercase)		  *:'*
+	'T		position of mark T (uppercase); when the mark is in
+			another file it cannot be used in a range
+	/{pattern}[/]	the next line where {pattern} matches	  *:/*
+	?{pattern}[?]	the previous line where {pattern} matches *:?*
+	\/		the next line where the previously used search
+			pattern matches
+	\?		the previous line where the previously used search
+			pattern matches
+	\&		the next line where the previously used substitute
+			pattern matches
+
+Each may be followed (several times) by '+' or '-' and an optional number.
+This number is added or subtracted from the preceding line number.  If the
+number is omitted, 1 is used.
+
+The "/" and "?" after {pattern} are required to separate the pattern from
+anything that follows.
+
+The "/" and "?" may be preceded with another address.  The search starts from
+there.  The difference from using ';' is that the cursor isn't moved.
+Examples: >
+	/pat1//pat2/	Find line containing "pat2" after line containing
+			"pat1", without moving the cursor.
+	7;/pat2/	Find line containing "pat2", after line 7, leaving
+			the cursor in line 7.
+
+The {number} must be between 0 and the number of lines in the file.  When
+using a 0 (zero) this is interpreted as a 1 by most commands.  Commands that
+use it as a count do use it as a zero (|:tag|, |:pop|, etc).  Some commands
+interpret the zero as "before the first line" (|:read|, search pattern, etc).
+
+Examples: >
+	.+3		three lines below the cursor
+	/that/+1	the line below the next line containing "that"
+	.,$		from current line until end of file
+	0;/that		the first line containing "that", also matches in the
+			first line.
+	1;/that		the first line after line 1 containing "that"
+
+Some commands allow for a count after the command.  This count is used as the
+number of lines to be used, starting with the line given in the last line
+specifier (the default is the cursor line).  The commands that accept a count
+are the ones that use a range but do not have a file name argument (because
+a file name can also be a number).
+
+Examples: >
+	:s/x/X/g 5	substitute 'x' by 'X' in the current line and four
+			following lines
+	:23d 4		delete lines 23, 24, 25 and 26
+
+
+Folds and Range
+
+When folds are active the line numbers are rounded off to include the whole
+closed fold.  See |fold-behavior|.
+
+
+Reverse Range						*E493*
+
+A range should have the lower line number first.  If this is not the case, Vim
+will ask you if it should swap the line numbers.
+	Backwards range given, OK to swap ~
+This is not done within the global command ":g".
+
+You can use ":silent" before a command to avoid the question, the range will
+always be swapped then.
+
+
+Count and Range						*N:*
+
+When giving a count before entering ":", this is translated into:
+		:.,.+(count - 1)
+In words: The 'count' lines at and after the cursor.  Example: To delete
+three lines: >
+		3:d		is translated into: .,.+2d
+<
+
+Visual Mode and Range					*v_:*
+
+{Visual}:	Starts a command-line with the Visual selected lines as a
+		range.  The code ":'<,'>" is used for this range, which makes
+		it possible to select a similar line from the command-line
+		history for repeating a command on different Visually selected
+		lines.
+
+==============================================================================
+5. Ex command-line flags				*ex-flags*
+
+These flags are supported by a selection of Ex commands.  They print the line
+that the cursor ends up after executing the command:
+
+	l	output like for |:list|
+	#	add line number
+	p	output like for |:print|
+
+The flags can be combined, thus "l#" uses both a line number and |:list| style
+output.
+
+==============================================================================
+6. Ex special characters				*cmdline-special*
+
+Note: These are special characters in the executed command line.  If you want
+to insert special things while typing you can use the CTRL-R command.  For
+example, "%" stands for the current file name, while CTRL-R % inserts the
+current file name right away.  See |c_CTRL-R|.
+
+Note: If you want to avoid the special characters in a Vim script you may want
+to use |fnameescape()|.
+
+
+In Ex commands, at places where a file name can be used, the following
+characters have a special meaning.  These can also be used in the expression
+function expand() |expand()|.
+	%	Is replaced with the current file name.		  *:_%* *c_%*
+	#	Is replaced with the alternate file name.	  *:_#* *c_#*
+	#n	(where n is a number) is replaced with		  *:_#0* *:_#n*
+		the file name of buffer n.  "#0" is the same as "#".     *c_#n*
+	##	Is replaced with all names in the argument list	  *:_##* *c_##*
+		concatenated, separated by spaces.  Each space in a name
+		is preceded with a backslash.
+	# 0) is replaced with old	  *:_#<* *c_#<*
+		file name n.  See |:oldfiles| or |v:oldfiles| to get the
+		number.							*E809*
+		{only when compiled with the |+eval| and |+viminfo| features}
+
+Note that these, except "#
+	:!ls "%"
+	:r !spell "%"
+
+To avoid the special meaning of '%' and '#' insert a backslash before it.
+Detail: The special meaning is always escaped when there is a backslash before
+it, no matter how many backslashes.
+	you type:		result	~
+	   #			alternate.file
+	   \#			#
+	   \\#			\#
+
+			       *:* *:* *:* **
+			       *:* ** *:* **
+			       *:* ** *:* **
+			       *E495* *E496* *E497* *E498* *E499* *E500*
+Note: these are typed literally, they are not special keys!
+	    is replaced with the word under the cursor (like |star|)
+	    is replaced with the WORD under the cursor (see |WORD|)
+	    is replaced with the path name under the cursor (like what
+		   |gf| uses)
+	    when executing autocommands, is replaced with the file name
+		   for a file read or write
+	     when executing autocommands, is replaced with the currently
+		   effective buffer number (for ":r file" and ":so file" it is
+		   the current buffer, the file being read/sourced is not in a
+		   buffer).
+	   when executing autocommands, is replaced with the match for
+		   which this autocommand was executed.  It differs from
+		    only when the file name isn't used to match with
+		   (for FileType, Syntax and SpellFileMissing events).
+	    when executing a ":source" command, is replaced with the
+		   file name of the sourced file;
+		   when executing a function, is replaced with
+		   "function {function-name}"; function call nesting is
+		   indicated like this:
+		   "function {function-name1}..{function-name2}".  Note that
+		   filename-modifiers are useless when  is used inside
+		   a function.
+
+							 *filename-modifiers*
+	 *:_%:* *::8* *::p* *::.* *::~* *::h* *::t* *::r* *::e* *::s* *::gs*
+	        *%:8* *%:p* *%:.* *%:~* *%:h* *%:t* *%:r* *%:e* *%:s* *%:gs*
+The file name modifiers can be used after "%", "#", "#n", "", "",
+"" or "".  They are also used with the |fnamemodify()| function.
+These are not available when Vim has been compiled without the |+modify_fname|
+feature.
+These modifiers can be given, in this order:
+	:p	Make file name a full path.  Must be the first modifier.  Also
+		changes "~/" (and "~user/" for Unix and VMS) to the path for
+		the home directory.  If the name is a directory a path
+		separator is added at the end.  For a file name that does not
+		exist and does not have an absolute path the result is
+		unpredictable.
+	:8	Converts the path to 8.3 short format (currently only on
+		win32).  Will act on as much of a path that is an existing
+		path.
+	:~	Reduce file name to be relative to the home directory, if
+		possible.  File name is unmodified if it is not below the home
+		directory.
+	:.	Reduce file name to be relative to current directory, if
+		possible.  File name is unmodified if it is not below the
+		current directory.
+		For maximum shortness, use ":~:.".
+	:h	Head of the file name (the last component and any separators
+		removed).  Cannot be used with :e, :r or :t.
+		Can be repeated to remove several components at the end.
+		When the file name ends in a path separator, only the path
+		separator is removed.  Thus ":p:h" on a directory name results
+		on the directory name itself (without trailing slash).
+		When the file name is an absolute path (starts with "/" for
+		Unix; "x:\" for MS-DOS, WIN32, OS/2; "drive:" for Amiga), that
+		part is not removed.  When there is no head (path is relative
+		to current directory) the result is empty.
+	:t	Tail of the file name (last component of the name).  Must
+		precede any :r or :e.
+	:r	Root of the file name (the last extension removed).  When
+		there is only an extension (file name that starts with '.',
+		e.g., ".vimrc"), it is not removed.  Can be repeated to remove
+		several extensions (last one first).
+	:e	Extension of the file name.  Only makes sense when used alone.
+		When there is no extension the result is empty.
+		When there is only an extension (file name that starts with
+		'.'), the result is empty.  Can be repeated to include more
+		extensions.  If there are not enough extensions (but at least
+		one) as much as possible are included.
+	:s?pat?sub?
+		Substitute the first occurrence of "pat" with "sub".  This
+		works like the |:s| command.  "pat" is a regular expression.
+		Any character can be used for '?', but it must not occur in
+		"pat" or "sub".
+		After this, the previous modifiers can be used again.  For
+		example ":p", to make a full path after the substitution.
+	:gs?pat?sub?
+		Substitute all occurrences of "path" with "sub".  Otherwise
+		this works like ":s".
+
+Examples, when the file name is "src/version.c", current dir
+"/home/mool/vim": >
+  :p			/home/mool/vim/src/version.c
+  :p:.				       src/version.c
+  :p:~				 ~/vim/src/version.c
+  :h				       src
+  :p:h			/home/mool/vim/src
+  :p:h:h		/home/mool/vim
+  :t					   version.c
+  :p:t					   version.c
+  :r				       src/version
+  :p:r			/home/mool/vim/src/version
+  :t:r					   version
+  :e						   c
+  :s?version?main?		       src/main.c
+  :s?version?main?:p	/home/mool/vim/src/main.c
+  :p:gs?/?\\?		\home\mool\vim\src\version.c
+
+Examples, when the file name is "src/version.c.gz": >
+  :p			/home/mool/vim/src/version.c.gz
+  :e						     gz
+  :e:e						   c.gz
+  :e:e:e					   c.gz
+  :e:e:r					   c
+  :r				       src/version.c
+  :r:e						   c
+  :r:r				       src/version
+  :r:r:r			       src/version
+<
+					*extension-removal* *:_%<*
+If a "<" is appended to "%", "#", "#n" or "CTRL-V p" the extension of the file
+name is removed (everything after and including the last '.' in the file
+name).  This is included for backwards compatibility with version 3.0, the
+":r" form is preferred.  Examples: >
+
+	%		current file name
+	%<		current file name without extension
+	#		alternate file name for current window
+	#<		idem, without extension
+	#31		alternate file number 31
+	#31<		idem, without extension
+			word under the cursor
+			WORD under the cursor (see |WORD|)
+			path name under the cursor
+	<	idem, without extension
+
+Note: Where a file name is expected wildcards expansion is done.  On Unix the
+shell is used for this, unless it can be done internally (for speed).
+Backticks also work, like in >
+	:n `echo *.c`
+(backtick expansion is not possible in |restricted-mode|)
+But expansion is only done if there are any wildcards before expanding the
+'%', '#', etc..  This avoids expanding wildcards inside a file name.  If you
+want to expand the result of , add a wildcard character to it.
+Examples: (alternate file name is "?readme?")
+	command		expands to  ~
+	:e #		:e ?readme?
+	:e `ls #`	:e {files matching "?readme?"}
+	:e #.*		:e {files matching "?readme?.*"}
+	:cd 	:cd {file name under cursor}
+	:cd *	:cd {file name under cursor plus "*" and then expanded}
+
+When the expanded argument contains a "!" and it is used for a shell command
+(":!cmd", ":r !cmd" or ":w !cmd"), the "!" is escaped with a backslash to
+avoid it being expanded into a previously used command.  When the 'shell'
+option contains "sh", this is done twice, to avoid the shell trying to expand
+the "!".
+
+							*filename-backslash*
+For filesystems that use a backslash as directory separator (MS-DOS, Windows,
+OS/2), it's a bit difficult to recognize a backslash that is used to escape
+the special meaning of the next character.  The general rule is: If the
+backslash is followed by a normal file name character, it does not have a
+special meaning.  Therefore "\file\foo" is a valid file name, you don't have
+to type the backslash twice.
+
+An exception is the '$' sign.  It is a valid character in a file name.  But
+to avoid a file name like "$home" to be interpreted as an environment variable,
+it needs to be preceded by a backslash.  Therefore you need to use "/\$home"
+for the file "$home" in the root directory.  A few examples:
+
+	FILE NAME	INTERPRETED AS	~
+	$home		expanded to value of environment var $home
+	\$home		file "$home" in current directory
+	/\$home		file "$home" in root directory
+	\\$home		file "\\", followed by expanded $home
+
+==============================================================================
+6. Command-line window				*cmdline-window* *cmdwin*
+							*command-line-window*
+In the command-line window the command line can be edited just like editing
+text in any window.  It is a special kind of window, because you cannot leave
+it in a normal way.
+{not available when compiled without the |+cmdline_hist| or |+vertsplit|
+feature}
+
+
+OPEN						*c_CTRL-F* *q:* *q/* *q?*
+
+There are two ways to open the command-line window:
+1. From Command-line mode, use the key specified with the 'cedit' option.
+   The default is CTRL-F when 'compatible' is not set.
+2. From Normal mode, use the "q:", "q/" or "q?" command.
+   This starts editing an Ex command-line ("q:") or search string ("q/" or
+   "q?").  Note that this is not possible while recording is in progress (the
+   "q" stops recording then).
+
+When the window opens it is filled with the command-line history.  The last
+line contains the command as typed so far.  The left column will show a
+character that indicates the type of command-line being edited, see
+|cmdwin-char|.
+
+Vim will be in Normal mode when the editor is opened, except when 'insertmode'
+is set.
+
+The height of the window is specified with 'cmdwinheight' (or smaller if there
+is no room).  The window is always full width and is positioned just above the
+command-line.
+
+
+EDIT
+
+You can now use commands to move around and edit the text in the window.  Both
+in Normal mode and Insert mode.
+
+It is possible to use ":", "/" and other commands that use the command-line,
+but it's not possible to open another command-line window then.  There is no
+nesting.
+							*E11*
+The command-line window is not a normal window.  It is not possible to move to
+another window or edit another buffer.  All commands that would do this are
+disabled in the command-line window.  Of course it _is_ possible to execute
+any command that you entered in the command-line window.  Other text edits are
+discarded when closing the window.
+
+
+CLOSE							*E199*
+
+There are several ways to leave the command-line window:
+
+		Execute the command-line under the cursor.  Works both in
+		Insert and in Normal mode.
+CTRL-C		Continue in Command-line mode.  The command-line under the
+		cursor is used as the command-line.  Works both in Insert and
+		in Normal mode.  ":close" also works.  There is no redraw,
+		thus the window will remain visible.
+:quit		Discard the command line and go back to Normal mode.
+		":exit", ":xit" and CTRL-\ CTRL-N also work.
+:qall		Quit Vim, unless there are changes in some buffer.
+:qall!		Quit Vim, discarding changes to any buffer.
+
+Once the command-line window is closed the old window sizes are restored.  The
+executed command applies to the window and buffer where the command-line was
+started from.  This works as if the command-line window was not there, except
+that there will be an extra screen redraw.
+The buffer used for the command-line window is deleted.  Any changes to lines
+other than the one that is executed with  are lost.
+
+If you would like to execute the command under the cursor and then have the
+command-line window open again, you may find this mapping useful: >
+
+	:autocmd CmdwinEnter * map   q:
+
+
+VARIOUS
+
+The command-line window cannot be used:
+- when there already is a command-line window (no nesting)
+- for entering an encryption key or when using inputsecret()
+- when Vim was not compiled with the |+vertsplit| feature
+
+Some options are set when the command-line window is opened:
+'filetype'	"vim", when editing an Ex command-line; this starts Vim syntax
+		highlighting if it was enabled
+'rightleft'	off
+'modifiable'	on
+'buftype'	"nofile"
+'swapfile'	off
+
+It is allowed to write the buffer contents to a file.  This is an easy way to
+save the command-line history and read it back later.
+
+If the 'wildchar' option is set to , and the command-line window is used
+for an Ex command, then two mappings will be added to use  for completion
+in the command-line window, like this: >
+	:imap   
+	:nmap   a
+Note that hitting  in Normal mode will do completion on the next
+character.  That way it works at the end of the line.
+If you don't want these mappings, disable them with: >
+	au CmdwinEnter [:>] iunmap 
+	au CmdwinEnter [:>] nunmap 
+You could put these lines in your vimrc file.
+
+While in the command-line window you cannot use the mouse to put the cursor in
+another window, or drag statuslines of other windows.  You can drag the
+statusline of the command-line window itself and the statusline above it.
+Thus you can resize the command-line window, but not others.
+
+
+AUTOCOMMANDS
+
+Two autocommand events are used: |CmdwinEnter| and |CmdwinLeave|.  Since this
+window is of a special type, the WinEnter, WinLeave, BufEnter and BufLeave
+events are not triggered.  You can use the Cmdwin events to do settings
+specifically for the command-line window.  Be careful not to cause side
+effects!
+Example: >
+	:au CmdwinEnter :  let b:cpt_save = &cpt | set cpt=.
+	:au CmdwinLeave :  let &cpt = b:cpt_save
+This sets 'complete' to use completion in the current window for |i_CTRL-N|.
+Another example: >
+	:au CmdwinEnter [/?]  startinsert
+This will make Vim start in Insert mode in the command-line window.
+
+						*cmdwin-char*
+The character used for the pattern indicates the type of command-line:
+	:	normal Ex command
+	>	debug mode command |debug-mode|
+	/	forward search string
+	?	backward search string
+	=	expression for "= |expr-register|
+	@	string for |input()|
+	-	text for |:insert| or |:append|
+
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/debug.txt b/share/vim/vim73/doc/debug.txt
new file mode 100644
index 0000000000..015c4e730d
--- /dev/null
+++ b/share/vim/vim73/doc/debug.txt
@@ -0,0 +1,174 @@
+*debug.txt*     For Vim version 7.3.  Last change: 2010 Jul 20
+
+
+		  VIM REFERENCE MANUAL    by Bram Moolenaar
+
+
+Debugging Vim						*debug-vim*
+
+This is for debugging Vim itself, when it doesn't work properly.
+For debugging Vim scripts, functions, etc. see |debug-scripts|
+
+1. Location of a crash, using gcc and gdb	|debug-gcc|
+2. Locating memory leaks			|debug-leaks|
+3. Windows Bug Reporting			|debug-win32|
+
+==============================================================================
+
+1. Location of a crash, using gcc and gdb		*debug-gcc*
+
+When Vim crashes in one of the test files, and you are using gcc for
+compilation, here is what you can do to find out exactly where Vim crashes.
+This also applies when using the MingW tools.
+
+1. Compile Vim with the "-g" option (there is a line in the Makefile for this,
+   which you can uncomment).
+
+2. Execute these commands (replace "11" with the test that fails): >
+	cd testdir
+	gdb ../vim
+	run -u unix.vim -U NONE -s dotest.in test11.in
+
+3. Check where Vim crashes, gdb should give a message for this.
+
+4. Get a stack trace from gdb with this command: >
+	where
+<  You can check out different places in the stack trace with: >
+	frame 3
+<  Replace "3" with one of the numbers in the stack trace.
+
+==============================================================================
+
+2. Locating memory leaks			*debug-leaks* *valgrind*
+
+If you suspect Vim is leaking memory and you are using Linux, the valgrind
+tool is very useful to pinpoint memory leaks.
+
+First of all, build Vim with EXITFREE defined.  Search for this in MAKEFILE
+and uncomment the line.
+
+Use this command to start Vim:
+>
+	valgrind --log-file=valgrind.log --leak-check=full ./vim
+
+Note: Vim will run much slower.  If your .vimrc is big or you have several
+plugins you need to be patient for startup, or run with the "-u NONE"
+argument.
+
+There are often a few leaks from libraries, such as getpwuid() and
+XtVaAppCreateShell().  Those are unavoidable.  The number of bytes should be
+very small a Kbyte or less.
+
+==============================================================================
+
+3. Windows Bug Reporting				*debug-win32*
+
+If the Windows version of Vim crashes in a reproducible manner, you can take
+some steps to provide a useful bug report.
+
+
+GENERIC ~
+
+You must obtain the debugger symbols (PDB) file for your executable: gvim.pdb
+for gvim.exe, or vim.pdb for vim.exe. The PDB should be available from the
+same place that you obtained the executable. Be sure to use the PDB that
+matches the EXE (same date).
+
+If you built the executable yourself with the Microsoft Visual C++ compiler,
+then the PDB was built with the EXE.
+
+Alternatively, if you have the source files, you can import Make_ivc.mak into
+Visual Studio as a workspace.  Then select a debug configuration, build and
+you can do all kinds of debugging (set breakpoints, watch variables, etc.).
+
+If you have Visual Studio, use that instead of the VC Toolkit and WinDbg.
+
+For other compilers, you should always use the corresponding debugger: TD for
+a Vim executable compiled with the Borland compiler; gdb (see above
+|debug-gcc|) for the Cygwin and MinGW compilers.
+
+
+								*debug-vs2005*
+2.2 Debugging Vim crashes with Visual Studio 2005/Visual C++ 2005 Express ~
+
+First launch vim.exe or gvim.exe and then launch Visual Studio.  (If you don't
+have Visual Studio, follow the instructions at |get-ms-debuggers| to obtain a
+free copy of Visual C++ 2005 Express Edition.)
+
+On the Tools menu, click Attach to Process.  Choose the Vim process.
+
+In Vim, reproduce the crash.  A dialog will appear in Visual Studio, telling
+you about the unhandled exception in the Vim process.  Click Break to break
+into the process.
+
+Visual Studio will pop up another dialog, telling you that no symbols are
+loaded and that the source code cannot be displayed.  Click OK.
+
+Several windows will open.  Right-click in the Call Stack window.  Choose Load
+Symbols.  The Find Symbols dialog will open, looking for (g)vim.pdb.  Navigate
+to the directory where you have the PDB file and click Open.
+
+At this point, you should have a full call stack with vim function names and
+line numbers.  Double-click one of the lines and the Find Source dialog will
+appear.  Navigate to the directory where the Vim source is (if you have it.)
+
+If you don't know how to debug this any further, follow the instructions
+at ":help bug-reports".  Paste the call stack into the bug report.
+
+If you have a non-free version of Visual Studio, you can save a minidump via
+the Debug menu and send it with the bug report.  A minidump is a small file
+(<100KB), which contains information about the state of your process.
+Visual C++ 2005 Express Edition cannot save minidumps and it cannot be
+installed as a just-in-time debugger. Use WinDbg, |debug-windbg|, if you
+need to save minidumps or you want a just-in-time (postmortem) debugger.
+
+								*debug-windbg*
+2.3 Debugging Vim crashes with WinDbg ~
+
+See |get-ms-debuggers| to obtain a copy of WinDbg.
+
+As with the Visual Studio IDE, you can attach WinDbg to a running Vim process.
+You can also have your system automatically invoke WinDbg as a postmortem
+debugger. To set WinDbg as your postmortem debugger, run "windbg -I".
+
+To attach WinDbg to a running Vim process, launch WinDbg. On the File menu,
+choose Attach to a Process. Select the Vim process and click OK.
+
+At this point, choose Symbol File Path on the File menu, and add the folder
+containing your Vim PDB to the sympath. If you have Vim source available,
+use Source File Path on the File menu. You can now open source files in WinDbg
+and set breakpoints, if you like. Reproduce your crash. WinDbg should open the
+source file at the point of the crash. Using the View menu, you can examine
+the call stack, local variables, watch windows, and so on.
+
+If WinDbg is your postmortem debugger, you do not need to attach WinDbg to
+your Vim process. Simply reproduce the crash and WinDbg will launch
+automatically. As above, set the Symbol File Path and the Source File Path.
+
+To save a minidump, type the following at the WinDbg command line: >
+        .dump vim.dmp
+<
+							*debug-minidump*
+2.4 Opening a Minidump ~
+
+If you have a minidump file, you can open it in Visual Studio or in WinDbg.
+
+In Visual Studio 2005: on the File menu, choose Open, then Project/Solution.
+Navigate to the .dmp file and open it. Now press F5 to invoke the debugger.
+Follow the instructions in |debug-vs2005| to set the Symbol File Path.
+
+In WinDbg: choose Open Crash Dump on the File menu. Follow the instructions in
+|debug-windbg| to set the Symbol File Path.
+
+							*get-ms-debuggers*
+2.5 Obtaining Microsoft Debugging Tools ~
+
+The Debugging Tools for Windows (including WinDbg) can be downloaded from
+    http://www.microsoft.com/whdc/devtools/debugging/default.mspx
+This includes the WinDbg debugger.
+
+Visual C++ 2005 Express Edition can be downloaded for free from:
+    http://msdn.microsoft.com/vstudio/express/visualC/default.aspx
+
+=========================================================================
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/debugger.txt b/share/vim/vim73/doc/debugger.txt
new file mode 100644
index 0000000000..d80eee6b6d
--- /dev/null
+++ b/share/vim/vim73/doc/debugger.txt
@@ -0,0 +1,140 @@
+*debugger.txt*  For Vim version 7.3.  Last change: 2005 Mar 29
+
+
+		  VIM REFERENCE MANUAL    by Gordon Prieur
+
+
+Debugger Support Features				*debugger-support*
+
+1. Debugger Features		|debugger-features|
+2. Vim Compile Options		|debugger-compilation|
+3. Integrated Debuggers		|debugger-integration|
+
+{Vi does not have any of these features}
+
+==============================================================================
+1. Debugger Features					*debugger-features*
+
+The following features are available for an integration with a debugger or
+an Integrated Programming Environment (IPE) or Integrated Development
+Environment (IDE):
+
+	Alternate Command Input				|alt-input|
+	Debug Signs					|debug-signs|
+	Debug Source Highlight				|debug-highlight|
+	Message Footer					|gui-footer|
+	Balloon Evaluation				|balloon-eval|
+
+These features were added specifically for use in the Motif version of gvim.
+However, the |alt-input| and |debug-highlight| were written to be usable in
+both vim and gvim.  Some of the other features could be used in the non-GUI
+vim with slight modifications.  However, I did not do this nor did I test the
+reliability of building for vim or non Motif GUI versions.
+
+
+1.1 Alternate Command Input				*alt-input*
+
+For Vim to work with a debugger there must be at least an input connection
+with a debugger or external tool.  In many cases there will also be an output
+connection but this isn't absolutely necessary.
+
+The purpose of the input connection is to let the external debugger send
+commands to Vim.  The commands sent by the debugger should give the debugger
+enough control to display the current debug environment and state.
+
+The current implementation is based on the X Toolkit dispatch loop and the
+XtAddInput() function call.
+
+
+1.2 Debug Signs						*debug-signs*
+
+Many debuggers mark specific lines by placing a small sign or color highlight
+on the line.  The |:sign| command lets the debugger set this graphic mark.  Some
+examples where this feature would be used would be a debugger showing an arrow
+representing the Program Counter (PC) of the program being debugged.  Another
+example would be a small stop sign for a line with a breakpoint.  These visible
+highlights let the user keep track of certain parts of the state of the
+debugger.
+
+This feature can be used with more than debuggers, too.  An IPE can use a sign
+to highlight build errors, searched text, or other things.  The sign feature
+can also work together with the |debug-highlight| to ensure the mark is
+highly visible.
+
+Debug signs are defined and placed using the |:sign| command.
+
+
+1.3 Debug Source Highlight				*debug-highlight*
+
+This feature allows a line to have a predominant highlight.  The highlight is
+intended to make a specific line stand out.  The highlight could be made to
+work for both vim and gvim, whereas the debug sign is, in most cases, limited
+to gvim.  The one exception to this is Sun Microsystem's dtterm.  The dtterm
+from Sun has a "sign gutter" for showing signs.
+
+
+1.4 Message Footer					*gui-footer*
+
+The message footer can be used to display messages from a debugger or IPE.  It
+can also be used to display menu and toolbar tips.  The footer area is at the
+bottom of the GUI window, below the line used to display colon commands.
+
+The display of the footer is controlled by the 'guioptions' letter 'F'.
+
+
+1.5 Balloon Evaluation					*balloon-eval*
+
+This feature allows a debugger, or other external tool, to display dynamic
+information based on where the mouse is pointing.  The purpose of this feature
+was to allow Sun's Visual WorkShop debugger to display expression evaluations.
+However, the feature was implemented in as general a manner as possible and
+could be used for displaying other information as well.
+
+The Balloon Evaluation has some settable parameters too.  For Motif the font
+list and colors can be set via X resources (XmNballoonEvalFontList,
+XmNballoonEvalBackground, and XmNballoonEvalForeground).
+The 'balloondelay' option sets the delay before an attempt is made to show a
+balloon.
+The 'ballooneval' option needs to be set to switch it on.
+
+Balloon evaluation is only available when compiled with the |+balloon_eval|
+feature.
+
+The Balloon evaluation functions are also used to show a tooltip for the
+toolbar.  The 'ballooneval' option does not need to be set for this.  But the
+other settings apply.
+
+Another way to use the balloon is with the 'balloonexpr' option.  This is
+completely user definable.
+
+==============================================================================
+2. Vim Compile Options					*debugger-compilation*
+
+The debugger features were added explicitly for use with Sun's Visual
+WorkShop Integrated Programming Environment (ipe).  However, they were done
+in as generic a manner as possible so that integration with other debuggers
+could also use some or all of the tools used with Sun's ipe.
+
+The following compile time preprocessor variables control the features:
+
+    Alternate Command Input			ALT_X_INPUT
+    Debug Glyphs				FEAT_SIGNS
+    Debug Highlights				FEAT_SIGNS
+    Message Footer				FEAT_FOOTER
+    Balloon Evaluation				FEAT_BEVAL
+
+The first integration with a full IPE/IDE was with Sun Visual WorkShop.  To
+compile a gvim which interfaces with VWS set the following flag, which sets
+all the above flags:
+
+    Sun Visual WorkShop				FEAT_SUN_WORKSHOP
+
+==============================================================================
+3. Integrated Debuggers					*debugger-integration*
+
+One fully integrated debugger/IPE/IDE is Sun's Visual WorkShop Integrated
+Programming Environment.
+
+For Sun NetBeans support see |netbeans|.
+
+ vim:tw=78:sw=4:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/develop.txt b/share/vim/vim73/doc/develop.txt
new file mode 100644
index 0000000000..7cfdd5b221
--- /dev/null
+++ b/share/vim/vim73/doc/develop.txt
@@ -0,0 +1,490 @@
+*develop.txt*   For Vim version 7.3.  Last change: 2008 Dec 17
+
+
+		  VIM REFERENCE MANUAL    by Bram Moolenaar
+
+
+Development of Vim.					*development*
+
+This text is important for those who want to be involved in further developing
+Vim.
+
+1. Design goals		|design-goals|
+2. Coding style		|coding-style|
+3. Design decisions	|design-decisions|
+4. Assumptions		|design-assumptions|
+
+See the file README.txt in the "src" directory for an overview of the source
+code.
+
+Vim is open source software.  Everybody is encouraged to contribute to help
+improving Vim.  For sending patches a context diff "diff -c" is preferred.
+Also see http://www.vim.org/tips/tip.php?tip_id=618.
+
+==============================================================================
+1. Design goals						*design-goals*
+
+Most important things come first (roughly).
+
+Note that quite a few items are contradicting.  This is intentional.  A
+balance must be found between them.
+
+
+VIM IS... VI COMPATIBLE					*design-compatible*
+
+First of all, it should be possible to use Vim as a drop-in replacement for
+Vi.  When the user wants to, he can use Vim in compatible mode and hardly
+notice any difference with the original Vi.
+
+Exceptions:
+- We don't reproduce obvious Vi bugs in Vim.
+- There are different versions of Vi.  I am using Version 3.7 (6/7/85) as a
+  reference.  But support for other versions is also included when possible.
+  The Vi part of POSIX is not considered a definitive source.
+- Vim adds new commands, you cannot rely on some command to fail because it
+  didn't exist in Vi.
+- Vim will have a lot of features that Vi doesn't have.  Going back from Vim
+  to Vi will be a problem, this cannot be avoided.
+- Some things are hardly ever used (open mode, sending an e-mail when
+  crashing, etc.).  Those will only be included when someone has a good reason
+  why it should be included and it's not too much work.
+- For some items it is debatable whether Vi compatibility should be
+  maintained.  There will be an option flag for these.
+
+
+VIM IS... IMPROVED					*design-improved*
+
+The IMproved bits of Vim should make it a better Vi, without becoming a
+completely different editor.  Extensions are done with a "Vi spirit".
+- Use the keyboard as much as feasible.  The mouse requires a third hand,
+  which we don't have.  Many terminals don't have a mouse.
+- When the mouse is used anyway, avoid the need to switch back to the
+  keyboard.  Avoid mixing mouse and keyboard handling.
+- Add commands and options in a consistent way.  Otherwise people will have a
+  hard time finding and remembering them.  Keep in mind that more commands and
+  options will be added later.
+- A feature that people do not know about is a useless feature.  Don't add
+  obscure features, or at least add hints in documentation that they exist.
+- Minimize using CTRL and other modifiers, they are more difficult to type.
+- There are many first-time and inexperienced Vim users.  Make it easy for
+  them to start using Vim and learn more over time.
+- There is no limit to the features that can be added.  Selecting new features
+  is one based on (1) what users ask for, (2) how much effort it takes to
+  implement and (3) someone actually implementing it.
+
+
+VIM IS... MULTI PLATFORM				*design-multi-platform*
+
+Vim tries to help as many users on as many platforms as possible.
+- Support many kinds of terminals.  The minimal demands are cursor positioning
+  and clear-screen.  Commands should only use key strokes that most keyboards
+  have.  Support all the keys on the keyboard for mapping.
+- Support many platforms.  A condition is that there is someone willing to do
+  Vim development on that platform, and it doesn't mean messing up the code.
+- Support many compilers and libraries.  Not everybody is able or allowed to
+  install another compiler or GUI library.
+- People switch from one platform to another, and from GUI to terminal
+  version.  Features should be present in all versions, or at least in as many
+  as possible with a reasonable effort.  Try to avoid that users must switch
+  between platforms to accomplish their work efficiently.
+- That a feature is not possible on some platforms, or only possible on one
+  platform, does not mean it cannot be implemented.  [This intentionally
+  contradicts the previous item, these two must be balanced.]
+
+
+VIM IS... WELL DOCUMENTED				*design-documented*
+
+- A feature that isn't documented is a useless feature.  A patch for a new
+  feature must include the documentation.
+- Documentation should be comprehensive and understandable.  Using examples is
+  recommended.
+- Don't make the text unnecessarily long.  Less documentation means that an
+  item is easier to find.
+
+
+VIM IS... HIGH SPEED AND SMALL IN SIZE			*design-speed-size*
+
+Using Vim must not be a big attack on system resources.  Keep it small and
+fast.
+- Computers are becoming faster and bigger each year.  Vim can grow too, but
+  no faster than computers are growing.  Keep Vim usable on older systems.
+- Many users start Vim from a shell very often.  Startup time must be short.
+- Commands must work efficiently.  The time they consume must be as small as
+  possible.  Useful commands may take longer.
+- Don't forget that some people use Vim over a slow connection.  Minimize the
+  communication overhead.
+- Items that add considerably to the size and are not used by many people
+  should be a feature that can be disabled.
+- Vim is a component among other components.  Don't turn it into a massive
+  application, but have it work well together with other programs.
+
+
+VIM IS... MAINTAINABLE					*design-maintain*
+
+- The source code should not become a mess.  It should be reliable code.
+- Use the same layout in all files to make it easy to read |coding-style|.
+- Use comments in a useful way!  Quoting the function name and argument names
+  is NOT useful.  Do explain what they are for.
+- Porting to another platform should be made easy, without having to change
+  too much platform-independent code.
+- Use the object-oriented spirit: Put data and code together.  Minimize the
+  knowledge spread to other parts of the code.
+
+
+VIM IS... FLEXIBLE					*design-flexible*
+
+Vim should make it easy for users to work in their preferred styles rather
+than coercing its users into particular patterns of work.  This can be for
+items with a large impact (e.g., the 'compatible' option) or for details.  The
+defaults are carefully chosen such that most users will enjoy using Vim as it
+is.  Commands and options can be used to adjust Vim to the desire of the user
+and its environment.
+
+
+VIM IS... NOT						*design-not*
+
+- Vim is not a shell or an Operating System.  You will not be able to run a
+  shell inside Vim or use it to control a debugger.  This should work the
+  other way around: Use Vim as a component from a shell or in an IDE.
+  A satirical way to say this: "Unlike Emacs, Vim does not attempt to include
+  everything but the kitchen sink, but some people say that you can clean one
+  with it.  ;-)"
+  To use Vim with gdb see: http://www.agide.org and http://clewn.sf.net.
+- Vim is not a fancy GUI editor that tries to look nice at the cost of
+  being less consistent over all platforms.  But functional GUI features are
+  welcomed.
+
+==============================================================================
+2. Coding style						*coding-style*
+
+These are the rules to use when making changes to the Vim source code.  Please
+stick to these rules, to keep the sources readable and maintainable.
+
+This list is not complete.  Look in the source code for more examples.
+
+
+MAKING CHANGES						*style-changes*
+
+The basic steps to make changes to the code:
+1. Adjust the documentation.  Doing this first gives you an impression of how
+   your changes affect the user.
+2. Make the source code changes.
+3. Check ../doc/todo.txt if the change affects any listed item.
+4. Make a patch with "diff -c" against the unmodified code and docs.
+5. Make a note about what changed and include it with the patch.
+
+
+USE OF COMMON FUNCTIONS					*style-functions*
+
+Some functions that are common to use, have a special Vim version.  Always
+consider using the Vim version, because they were introduced with a reason.
+
+NORMAL NAME	VIM NAME	DIFFERENCE OF VIM VERSION
+free()		vim_free()	Checks for freeing NULL
+malloc()	alloc()		Checks for out of memory situation
+malloc()	lalloc()	Like alloc(), but has long argument
+strcpy()	STRCPY()	Includes cast to (char *), for char_u * args
+strchr()	vim_strchr()	Accepts special characters
+strrchr()	vim_strrchr()	Accepts special characters
+isspace()	vim_isspace()	Can handle characters > 128
+iswhite()	vim_iswhite()	Only TRUE for tab and space
+memcpy()	mch_memmove()	Handles overlapped copies
+bcopy()		mch_memmove()	Handles overlapped copies
+memset()	vim_memset()	Uniform for all systems
+
+
+NAMES							*style-names*
+
+Function names can not be more than 31 characters long (because of VMS).
+
+Don't use "delete" as a variable name, C++ doesn't like it.
+
+Because of the requirement that Vim runs on as many systems as possible, we
+need to avoid using names that are already defined by the system.  This is a
+list of names that are known to cause trouble.  The name is given as a regexp
+pattern.
+
+is.*()		POSIX, ctype.h
+to.*()		POSIX, ctype.h
+
+d_.*		POSIX, dirent.h
+l_.*		POSIX, fcntl.h
+gr_.*		POSIX, grp.h
+pw_.*		POSIX, pwd.h
+sa_.*		POSIX, signal.h
+mem.*		POSIX, string.h
+str.*		POSIX, string.h
+wcs.*		POSIX, string.h
+st_.*		POSIX, stat.h
+tms_.*		POSIX, times.h
+tm_.*		POSIX, time.h
+c_.*		POSIX, termios.h
+MAX.*		POSIX, limits.h
+__.*		POSIX, system
+_[A-Z].*	POSIX, system
+E[A-Z0-9]*	POSIX, errno.h
+
+.*_t		POSIX, for typedefs.  Use .*_T instead.
+
+wait		don't use as argument to a function, conflicts with types.h
+index		shadows global declaration
+time		shadows global declaration
+new		C++ reserved keyword
+try		Borland C++ doesn't like it to be used as a variable.
+
+basename()	GNU string function
+dirname()	GNU string function
+get_env_value()	Linux system function
+
+
+VARIOUS							*style-various*
+
+Typedef'ed names should end in "_T": >
+    typedef int some_T;
+Define'ed names should be uppercase: >
+    #define SOME_THING
+Features always start with "FEAT_": >
+    #define FEAT_FOO
+
+Don't use '\"', some compilers can't handle it.  '"' works fine.
+
+Don't use:
+    #if HAVE_SOME
+Some compilers can't handle that and complain that "HAVE_SOME" is not defined.
+Use
+    #ifdef HAVE_SOME
+or
+    #if defined(HAVE_SOME)
+
+
+STYLE							*style-examples*
+
+General rule: One statement per line.
+
+Wrong:	    if (cond) a = 1;
+
+OK:	    if (cond)
+		a = 1;
+
+Wrong:	    while (cond);
+
+OK:	    while (cond)
+		;
+
+Wrong:	    do a = 1; while (cond);
+
+OK:	    do
+		a = 1;
+	    while (cond);
+
+
+Functions start with:
+
+Wrong:	int function_name(int arg1, int arg2)
+
+OK:	/*
+	 * Explanation of what this function is used for.
+	 *
+	 * Return value explanation.
+	 */
+	    int
+	function_name(arg1, arg2)
+	    int		arg1;		/* short comment about arg1 */
+	    int		arg2;		/* short comment about arg2 */
+	{
+	    int		local;		/* comment about local */
+
+	    local = arg1 * arg2;
+
+NOTE: Don't use ANSI style function declarations.  A few people still have to
+use a compiler that doesn't support it.
+
+
+SPACES AND PUNCTUATION					*style-spaces*
+
+No space between a function name and the bracket:
+
+Wrong:  func (arg);
+OK:	func(arg);
+
+Do use a space after if, while, switch, etc.
+
+Wrong:	if(arg)		for(;;)
+OK:	if (arg)	for (;;)
+
+Use a space after a comma and semicolon:
+
+Wrong:  func(arg1,arg2);	for (i = 0;i < 2;++i)
+OK:	func(arg1, arg2);	for (i = 0; i < 2; ++i)
+
+Use a space before and after '=', '+', '/', etc.
+
+Wrong:	var=a*5;
+OK:	var = a * 5;
+
+In general: Use empty lines to group lines of code together.  Put a comment
+just above the group of lines.  This makes it easier to quickly see what is
+being done.
+
+OK:	/* Prepare for building the table. */
+	get_first_item();
+	table_idx = 0;
+
+	/* Build the table */
+	while (has_item())
+	    table[table_idx++] = next_item();
+
+	/* Finish up. */
+	cleanup_items();
+	generate_hash(table);
+
+==============================================================================
+3. Design decisions					*design-decisions*
+
+Folding
+
+Several forms of folding should be possible for the same buffer.  For example,
+have one window that shows the text with function bodies folded, another
+window that shows a function body.
+
+Folding is a way to display the text.  It should not change the text itself.
+Therefore the folding has been implemented as a filter between the text stored
+in a buffer (buffer lines) and the text displayed in a window (logical lines).
+
+
+Naming the window
+
+The word "window" is commonly used for several things: A window on the screen,
+the xterm window, a window inside Vim to view a buffer.
+To avoid confusion, other items that are sometimes called window have been
+given another name.  Here is an overview of the related items:
+
+screen		The whole display.  For the GUI it's something like 1024x768
+		pixels.  The Vim shell can use the whole screen or part of it.
+shell		The Vim application.  This can cover the whole screen (e.g.,
+		when running in a console) or part of it (xterm or GUI).
+window		View on a buffer.  There can be several windows in Vim,
+		together with the command line, menubar, toolbar, etc. they
+		fit in the shell.
+
+
+Spell checking						*develop-spell*
+
+When spell checking was going to be added to Vim a survey was done over the
+available spell checking libraries and programs.  Unfortunately, the result
+was that none of them provided sufficient capabilities to be used as the spell
+checking engine in Vim, for various reasons:
+
+- Missing support for multi-byte encodings.  At least UTF-8 must be supported,
+  so that more than one language can be used in the same file.
+  Doing on-the-fly conversion is not always possible (would require iconv
+  support).
+- For the programs and libraries: Using them as-is would require installing
+  them separately from Vim.  That's mostly not impossible, but a drawback.
+- Performance: A few tests showed that it's possible to check spelling on the
+  fly (while redrawing), just like syntax highlighting.  But the mechanisms
+  used by other code are much slower.  Myspell uses a hashtable, for example.
+  The affix compression that most spell checkers use makes it slower too.
+- For using an external program like aspell a communication mechanism would
+  have to be setup.  That's complicated to do in a portable way (Unix-only
+  would be relatively simple, but that's not good enough).  And performance
+  will become a problem (lots of process switching involved).
+- Missing support for words with non-word characters, such as "Etten-Leur" and
+  "et al.", would require marking the pieces of them OK, lowering the
+  reliability.
+- Missing support for regions or dialects.  Makes it difficult to accept
+  all English words and highlight non-Canadian words differently.
+- Missing support for rare words.  Many words are correct but hardly ever used
+  and could be a misspelled often-used word.
+- For making suggestions the speed is less important and requiring to install
+  another program or library would be acceptable.  But the word lists probably
+  differ, the suggestions may be wrong words.
+
+
+Spelling suggestions				*develop-spell-suggestions*
+
+For making suggestions there are two basic mechanisms:
+1. Try changing the bad word a little bit and check for a match with a good
+   word.  Or go through the list of good words, change them a little bit and
+   check for a match with the bad word.  The changes are deleting a character,
+   inserting a character, swapping two characters, etc.
+2. Perform soundfolding on both the bad word and the good words and then find
+   matches, possibly with a few changes like with the first mechanism.
+
+The first is good for finding typing mistakes.  After experimenting with
+hashtables and looking at solutions from other spell checkers the conclusion
+was that a trie (a kind of tree structure) is ideal for this.  Both for
+reducing memory use and being able to try sensible changes.  For example, when
+inserting a character only characters that lead to good words need to be
+tried.  Other mechanisms (with hashtables) need to try all possible letters at
+every position in the word.  Also, a hashtable has the requirement that word
+boundaries are identified separately, while a trie does not require this.
+That makes the mechanism a lot simpler.
+
+Soundfolding is useful when someone knows how the words sounds but doesn't
+know how it is spelled.  For example, the word "dictionary" might be written
+as "daktonerie".  The number of changes that the first method would need to
+try is very big, it's hard to find the good word that way.  After soundfolding
+the words become "tktnr" and "tkxnry", these differ by only two letters.
+
+To find words by their soundfolded equivalent (soundalike word) we need a list
+of all soundfolded words.  A few experiments have been done to find out what
+the best method is.  Alternatives:
+1. Do the sound folding on the fly when looking for suggestions.  This means
+   walking through the trie of good words, soundfolding each word and
+   checking how different it is from the bad word.  This is very efficient for
+   memory use, but takes a long time.  On a fast PC it takes a couple of
+   seconds for English, which can be acceptable for interactive use.  But for
+   some languages it takes more than ten seconds (e.g., German, Catalan),
+   which is unacceptable slow.  For batch processing (automatic corrections)
+   it's too slow for all languages.
+2. Use a trie for the soundfolded words, so that searching can be done just
+   like how it works without soundfolding.  This requires remembering a list
+   of good words for each soundfolded word.  This makes finding matches very
+   fast but requires quite a lot of memory, in the order of 1 to 10 Mbyte.
+   For some languages more than the original word list.
+3. Like the second alternative, but reduce the amount of memory by using affix
+   compression and store only the soundfolded basic word.  This is what Aspell
+   does.  Disadvantage is that affixes need to be stripped from the bad word
+   before soundfolding it, which means that mistakes at the start and/or end
+   of the word will cause the mechanism to fail.  Also, this becomes slow when
+   the bad word is quite different from the good word.
+
+The choice made is to use the second mechanism and use a separate file.  This
+way a user with sufficient memory can get very good suggestions while a user
+who is short of memory or just wants the spell checking and no suggestions
+doesn't use so much memory.
+
+
+Word frequency
+
+For sorting suggestions it helps to know which words are common.  In theory we
+could store a word frequency with the word in the dictionary.  However, this
+requires storing a count per word.  That degrades word tree compression a lot.
+And maintaining the word frequency for all languages will be a heavy task.
+Also, it would be nice to prefer words that are already in the text.  This way
+the words that appear in the specific text are preferred for suggestions.
+
+What has been implemented is to count words that have been seen during
+displaying.  A hashtable is used to quickly find the word count.  The count is
+initialized from words listed in COMMON items in the affix file, so that it
+also works when starting a new file.
+
+This isn't ideal, because the longer Vim is running the higher the counts
+become.  But in practice it is a noticeable improvement over not using the word
+count.
+
+==============================================================================
+4. Assumptions						*design-assumptions*
+
+Size of variables:
+char	    8 bit signed
+char_u	    8 bit unsigned
+int	    32 or 64 bit signed (16 might be possible with limited features)
+unsigned    32 or 64 bit unsigned (16 as with ints)
+long	    32 or 64 bit signed, can hold a pointer
+
+Note that some compilers cannot handle long lines or strings.  The C89
+standard specifies a limit of 509 characters.
+
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/diff.txt b/share/vim/vim73/doc/diff.txt
new file mode 100644
index 0000000000..1d62e545c4
--- /dev/null
+++ b/share/vim/vim73/doc/diff.txt
@@ -0,0 +1,414 @@
+*diff.txt*      For Vim version 7.3.  Last change: 2010 Jul 31
+
+
+		  VIM REFERENCE MANUAL    by Bram Moolenaar
+
+
+				*diff* *vimdiff* *gvimdiff* *diff-mode*
+This file describes the |+diff| feature: Showing differences between two,
+three or four versions of the same file.
+
+The basics are explained in section |08.7| of the user manual.
+
+1. Starting diff mode		|vimdiff|
+2. Viewing diffs		|view-diffs|
+3. Jumping to diffs		|jumpto-diffs|
+4. Copying diffs		|copy-diffs|
+5. Diff options			|diff-options|
+
+{not in Vi}
+
+==============================================================================
+1. Starting diff mode
+
+The easiest way to start editing in diff mode is with the "vimdiff" command.
+This starts Vim as usual, and additionally sets up for viewing the differences
+between the arguments. >
+
+	vimdiff file1 file2 [file3 [file4]]
+
+This is equivalent to: >
+
+	vim -d file1 file2 [file3 [file4]]
+
+You may also use "gvimdiff" or "vim -d -g".  The GUI is started then.
+You may also use "viewdiff" or "gviewdiff".  Vim starts in readonly mode then.
+"r" may be prepended for restricted mode (see |-Z|).
+
+The second and following arguments may also be a directory name.  Vim will
+then append the file name of the first argument to the directory name to find
+the file.
+
+This only works when a standard "diff" command is available.  See 'diffexpr'.
+
+Diffs are local to the current tab page |tab-page|.  You can't see diffs with
+a window in another tab page.  This does make it possible to have several
+diffs at the same time, each in their own tab page.
+
+What happens is that Vim opens a window for each of the files.  This is like
+using the |-O| argument.  This uses vertical splits.  If you prefer horizontal
+splits add the |-o| argument: >
+
+	vimdiff -o file1 file2 [file3 [file4]]
+
+If you always prefer horizontal splits include "horizontal" in 'diffopt'.
+
+In each of the edited files these options are set:
+
+	'diff'		on
+	'scrollbind'	on
+	'cursorbind'	on
+	'scrollopt'	includes "hor"
+	'wrap'		off
+	'foldmethod'	"diff"
+	'foldcolumn'	value from 'diffopt', default is 2
+
+These options are set local to the window.  When editing another file they are
+reset to the global value.
+The options can still be overruled from a modeline when re-editing the file.
+However, 'foldmethod' and 'wrap' won't be set from a modeline when 'diff' is
+set.
+
+The differences shown are actually the differences in the buffer.  Thus if you
+make changes after loading a file, these will be included in the displayed
+diffs.  You might have to do ":diffupdate" now and then, not all changes are
+immediately taken into account.
+
+In your .vimrc file you could do something special when Vim was started in
+diff mode.  You could use a construct like this: >
+
+	if &diff
+	   setup for diff mode
+	else
+	   setup for non-diff mode
+	endif
+
+While already in Vim you can start diff mode in three ways.
+
+							*E98*
+:diffsplit {filename}					*:diffs* *:diffsplit*
+		Open a new window on the file {filename}.  The options are set
+		as for "vimdiff" for the current and the newly opened window.
+		Also see 'diffexpr'.
+
+							*:difft* *:diffthis*
+:diffthis	Make the current window part of the diff windows.  This sets
+		the options like for "vimdiff".
+
+:diffpatch {patchfile}				 *E816* *:diffp* *:diffpatch*
+		Use the current buffer, patch it with the diff found in
+		{patchfile} and open a buffer on the result.  The options are
+		set as for "vimdiff".
+		{patchfile} can be in any format that the "patch" program
+		understands or 'patchexpr' can handle.
+		Note that {patchfile} should only contain a diff for one file,
+		the current file.  If {patchfile} contains diffs for other
+		files as well, the results are unpredictable.  Vim changes
+		directory to /tmp to avoid files in the current directory
+		accidentally being patched.  But it may still result in
+		various ".rej" files to be created.  And when absolute path
+		names are present these files may get patched anyway.
+
+To make these commands use a vertical split, prepend |:vertical|.  Examples: >
+
+	:vert diffsplit main.c~
+	:vert diffpatch /tmp/diff
+
+If you always prefer a vertical split include "vertical" in 'diffopt'.
+
+							*E96*
+There can be up to four buffers with 'diff' set.
+
+Since the option values are remembered with the buffer, you can edit another
+file for a moment and come back to the same file and be in diff mode again.
+
+							*:diffo* *:diffoff*
+:diffoff	Switch off diff mode for the current window.
+
+:diffoff!	Switch off diff mode for the current window and in all windows
+		in the current tab page where 'diff' is set.
+
+The ":diffoff" command resets the relevant options to their default value.
+This may be different from what the values were before diff mode was started,
+the old values are not remembered.
+
+	'diff'		off
+	'scrollbind'	off
+	'cursorbind'	off
+	'scrollopt'	without "hor"
+	'wrap'		on
+	'foldmethod'	"manual"
+	'foldcolumn'	0
+
+==============================================================================
+2. Viewing diffs						*view-diffs*
+
+The effect is that the diff windows show the same text, with the differences
+highlighted.  When scrolling the text, the 'scrollbind' option will make the
+text in other windows to be scrolled as well.  With vertical splits the text
+should be aligned properly.
+
+The alignment of text will go wrong when:
+- 'wrap' is on, some lines will be wrapped and occupy two or more screen
+  lines
+- folds are open in one window but not another
+- 'scrollbind' is off
+- changes have been made to the text
+- "filler" is not present in 'diffopt', deleted/inserted lines makes the
+  alignment go wrong
+
+All the buffers edited in a window where the 'diff' option is set will join in
+the diff.  This is also possible for hidden buffers.  They must have been
+edited in a window first for this to be possible.
+
+					*:DiffOrig* *diff-original-file*
+Since 'diff' is a window-local option, it's possible to view the same buffer
+in diff mode in one window and "normal" in another window.  It is also
+possible to view the changes you have made to a buffer since the file was
+loaded.  Since Vim doesn't allow having two buffers for the same file, you
+need another buffer.  This command is useful: >
+	 command DiffOrig vert new | set bt=nofile | r # | 0d_ | diffthis
+	 	\ | wincmd p | diffthis
+(this is in |vimrc_example.vim|).  Use ":DiffOrig" to see the differences
+between the current buffer and the file it was loaded from.
+
+A buffer that is unloaded cannot be used for the diff.  But it does work for
+hidden buffers.  You can use ":hide" to close a window without unloading the
+buffer.  If you don't want a buffer to remain used for the diff do ":set
+nodiff" before hiding it.
+
+							*:diffu* *:diffupdate*
+:diffu[pdate]			Update the diff highlighting and folds.
+
+Vim attempts to keep the differences updated when you make changes to the
+text.  This mostly takes care of inserted and deleted lines.  Changes within a
+line and more complicated changes do not cause the differences to be updated.
+To force the differences to be updated use: >
+
+	:diffupdate
+
+
+Vim will show filler lines for lines that are missing in one window but are
+present in another.  These lines were inserted in another file or deleted in
+this file.  Removing "filler" from the 'diffopt' option will make Vim not
+display these filler lines.
+
+
+Folds are used to hide the text that wasn't changed.  See |folding| for all
+the commands that can be used with folds.
+
+The context of lines above a difference that are not included in the fold can
+be set with the 'diffopt' option.  For example, to set the context to three
+lines: >
+
+	:set diffopt=filler,context:3
+
+
+The diffs are highlighted with these groups:
+
+|hl-DiffAdd|	DiffAdd		Added (inserted) lines.  These lines exist in
+				this buffer but not in another.
+|hl-DiffChange|	DiffChange	Changed lines.
+|hl-DiffText|	DiffText	Changed text inside a Changed line.  Vim
+				finds the first character that is different,
+				and the last character that is different
+				(searching from the end of the line).  The
+				text in between is highlighted.  This means
+				that parts in the middle that are still the
+				same are highlighted anyway.  Only "iwhite" of
+				'diffopt' is used here.
+|hl-DiffDelete| DiffDelete	Deleted lines.  Also called filler lines,
+				because they don't really exist in this
+				buffer.
+
+==============================================================================
+3. Jumping to diffs					*jumpto-diffs*
+
+Two commands can be used to jump to diffs:
+								*[c*
+	[c		Jump backwards to the previous start of a change.
+			When a count is used, do it that many times.
+								*]c*
+	]c		Jump forwards to the next start of a change.
+			When a count is used, do it that many times.
+
+It is an error if there is no change for the cursor to move to.
+
+==============================================================================
+4. Diff copying			*copy-diffs* *E99* *E100* *E101* *E102* *E103*
+								*merge*
+There are two commands to copy text from one buffer to another.  The result is
+that the buffers will be equal within the specified range.
+
+							*:diffg* *:diffget*
+:[range]diffg[et] [bufspec]
+		Modify the current buffer to undo difference with another
+		buffer.  If [bufspec] is given, that buffer is used.  If
+		[bufspec] refers to the current buffer then nothing happens.
+		Otherwise this only works if there is one other buffer in diff
+		mode.
+		See below for [range].
+
+						*:diffpu* *:diffput* *E793*
+:[range]diffpu[t] [bufspec]
+		Modify another buffer to undo difference with the current
+		buffer.  Just like ":diffget" but the other buffer is modified
+		instead of the current one.
+		When [bufspec] is omitted and there is more than one other
+		buffer in diff mode where 'modifiable' is set this fails.
+		See below for [range].
+
+							*do*
+do		Same as ":diffget" without argument or range.  The "o" stands
+		for "obtain" ("dg" can't be used, it could be the start of
+		"dgg"!).
+
+							*dp*
+dp		Same as ":diffput" without argument or range.
+
+When no [range] is given, the diff at the cursor position or just above it is
+affected.  When [range] is used, Vim tries to only put or get the specified
+lines.  When there are deleted lines, this may not always be possible.
+
+There can be deleted lines below the last line of the buffer.  When the cursor
+is on the last line in the buffer and there is no diff above this line, the
+":diffget" and "do" commands will obtain lines from the other buffer.
+
+To be able to get those lines from another buffer in a [range] it's allowed to
+use the last line number plus one.  This command gets all diffs from the other
+buffer: >
+
+	:1,$+1diffget
+
+Note that deleted lines are displayed, but not counted as text lines.  You
+can't move the cursor into them.  To fill the deleted lines with the lines
+from another buffer use ":diffget" on the line below them.
+								*E787*
+When the buffer that is about to be modified is read-only and the autocommand
+that is triggered by |FileChangedRO| changes buffers the command will fail.
+The autocommand must not change buffers.
+
+The [bufspec] argument above can be a buffer number, a pattern for a buffer
+name or a part of a buffer name.  Examples:
+
+	:diffget		Use the other buffer which is in diff mode
+	:diffget 3		Use buffer 3
+	:diffget v2		Use the buffer which matches "v2" and is in
+				diff mode (e.g., "file.c.v2")
+
+==============================================================================
+5. Diff options						*diff-options*
+
+Also see |'diffopt'| and the "diff" item of |'fillchars'|.
+
+
+FINDING THE DIFFERENCES					*diff-diffexpr*
+
+The 'diffexpr' option can be set to use something else than the standard
+"diff" program to compare two files and find the differences.
+
+When 'diffexpr' is empty, Vim uses this command to find the differences
+between file1 and file2: >
+
+	diff file1 file2 > outfile
+
+The ">" is replaced with the value of 'shellredir'.
+
+The output of "diff" must be a normal "ed" style diff.  Do NOT use a context
+diff.  This example explains the format that Vim expects: >
+
+	1a2
+	> bbb
+	4d4
+	< 111
+	7c7
+	< GGG
+	---
+	> ggg
+
+The "1a2" item appends the line "bbb".
+The "4d4" item deletes the line "111".
+The '7c7" item replaces the line "GGG" with "ggg".
+
+When 'diffexpr' is not empty, Vim evaluates it to obtain a diff file in the
+format mentioned.  These variables are set to the file names used:
+
+	v:fname_in		original file
+	v:fname_new		new version of the same file
+	v:fname_out		resulting diff file
+
+Additionally, 'diffexpr' should take care of "icase" and "iwhite" in the
+'diffopt' option.  'diffexpr' cannot change the value of 'lines' and
+'columns'.
+
+Example (this does almost the same as 'diffexpr' being empty): >
+
+	set diffexpr=MyDiff()
+	function MyDiff()
+	   let opt = ""
+	   if &diffopt =~ "icase"
+	     let opt = opt . "-i "
+	   endif
+	   if &diffopt =~ "iwhite"
+	     let opt = opt . "-b "
+	   endif
+	   silent execute "!diff -a --binary " . opt . v:fname_in . " " . v:fname_new .
+		\  " > " . v:fname_out
+	endfunction
+
+The "-a" argument is used to force comparing the files as text, comparing as
+binaries isn't useful.  The "--binary" argument makes the files read in binary
+mode, so that a CTRL-Z doesn't end the text on DOS.
+
+						*E810* *E97*
+Vim will do a test if the diff output looks alright.  If it doesn't, you will
+get an error message.  Possible causes:
+-  The "diff" program cannot be executed.
+-  The "diff" program doesn't produce normal "ed" style diffs (see above).
+-  The 'shell' and associated options are not set correctly.  Try if filtering
+   works with a command like ":!sort".
+-  You are using 'diffexpr' and it doesn't work.
+If it's not clear what the problem is set the 'verbose' option to one or more
+to see more messages.
+
+The self-installing Vim includes a diff program.  If you don't have it you
+might want to download a diff.exe.  For example from
+http://jlb.twu.net/code/unixkit.php.
+
+
+USING PATCHES					*diff-patchexpr*
+
+The 'patchexpr' option can be set to use something else than the standard
+"patch" program.
+
+When 'patchexpr' is empty, Vim will call the "patch" program like this: >
+
+	patch -o outfile origfile < patchfile
+
+This should work fine with most versions of the "patch" program.  Note that a
+CR in the middle of a line may cause problems, it is seen as a line break.
+
+If the default doesn't work for you, set the 'patchexpr' to an expression that
+will have the same effect.  These variables are set to the file names used:
+
+	v:fname_in		original file
+	v:fname_diff		patch file
+	v:fname_out		resulting patched file
+
+Example (this does the same as 'patchexpr' being empty): >
+
+	set patchexpr=MyPatch()
+	function MyPatch()
+	   :call system("patch -o " . v:fname_out . " " . v:fname_in .
+	   \  " < " . v:fname_diff)
+	endfunction
+
+Make sure that using the "patch" program doesn't have unwanted side effects.
+For example, watch out for additionally generated files, which should be
+deleted.  It should just patch the file and nothing else.
+   Vim will change directory to "/tmp" or another temp directory before
+evaluating 'patchexpr'.  This hopefully avoids that files in the current
+directory are accidentally patched.  Vim will also delete files starting with
+v:fname_in and ending in ".rej" and ".orig".
+
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/digraph.txt b/share/vim/vim73/doc/digraph.txt
new file mode 100644
index 0000000000..9faeceebc3
--- /dev/null
+++ b/share/vim/vim73/doc/digraph.txt
@@ -0,0 +1,350 @@
+*digraph.txt*   For Vim version 7.3.  Last change: 2010 Apr 11
+
+
+		  VIM REFERENCE MANUAL    by Bram Moolenaar
+
+
+Digraphs					*digraph* *digraphs* *Digraphs*
+
+Digraphs are used to enter characters that normally cannot be entered by
+an ordinary keyboard.  These are mostly printable non-ASCII characters.  The
+digraphs are easier to remember than the decimal number that can be entered
+with CTRL-V (see |i_CTRL-V|).
+
+There is a brief introduction on digraphs in the user manual: |24.9|
+An alternative is using the 'keymap' option.
+
+1. Defining digraphs	|digraphs-define|
+2. Using digraphs	|digraphs-use|
+3. Default digraphs	|digraphs-default|
+
+{Vi does not have any of these commands}
+
+==============================================================================
+1. Defining digraphs					*digraphs-define*
+
+						*:dig* *:digraphs*
+:dig[raphs]		show currently defined digraphs.
+							*E104* *E39*
+:dig[raphs] {char1}{char2} {number} ...
+			Add digraph {char1}{char2} to the list.  {number} is
+			the decimal representation of the character.  Normally
+			it is the Unicode character, see |digraph-encoding|.
+			Example: >
+	:digr e: 235 a: 228
+<			Avoid defining a digraph with '_' (underscore) as the
+			first character, it has a special meaning in the
+			future.
+
+Vim is normally compiled with the |+digraphs| feature.  If the feature is
+disabled, the ":digraph" command will display an error message.
+
+Example of the output of ":digraphs": >
+ TH Þ  222  ss ß  223  a! à  224  a' á  225  a> â  226  a? ã  227  a: ä  228
+
+The first two characters in each column are the characters you have to type to
+enter the digraph.
+
+In the middle of each column is the resulting character.  This may be mangled
+if you look at it on a system that does not support digraphs or if you print
+this file.
+
+							*digraph-encoding*
+The decimal number normally is the Unicode number of the character.  Note that
+the meaning doesn't change when 'encoding' changes.  The character will be
+converted from Unicode to 'encoding' when needed.  This does require the
+conversion to be available, it might fail.  For the NUL character you will see
+"10".  That's because NUL characters are internally represented with a NL
+character.  When you write the file it will become a NUL character.
+
+When Vim was compiled without the |+multi_byte| feature, you need to specify
+the character in the encoding given with 'encoding'.  You might want to use
+something like this: >
+
+	if has("multi_byte")
+		digraph oe 339
+	elseif &encoding == "iso-8859-15"
+		digraph oe 189
+	endif
+
+This defines the "oe" digraph for a character that is number 339 in Unicode
+and 189 in latin9 (iso-8859-15).
+
+==============================================================================
+2. Using digraphs					*digraphs-use*
+
+There are two methods to enter digraphs:			*i_digraph*
+	CTRL-K {char1} {char2}		or
+	{char1}  {char2}
+The first is always available; the second only when the 'digraph' option is
+set.
+
+If a digraph with {char1}{char2} does not exist, Vim searches for a digraph
+{char2}{char1}.  This helps when you don't remember which character comes
+first.
+
+Note that when you enter CTRL-K {char1}, where {char1} is a special key, Vim
+enters the code for that special key.  This is not a digraph.
+
+Once you have entered the digraph, Vim treats the character like a normal
+character that occupies only one character in the file and on the screen.
+Example: >
+	'B'  'B'	will enter the broken '|' character (166)
+	'a'  '>'	will enter an 'a' with a circumflex (226)
+	CTRL-K '-' '-'	will enter a soft hyphen (173)
+
+The current digraphs are listed with the ":digraphs" command.  Some of the
+default ones are listed below |digraph-table|.
+
+For CTRL-K, there is one general digraph: CTRL-K  {char} will enter
+{char} with the highest bit set.  You can use this to enter meta-characters.
+
+The  character cannot be part of a digraph.  When hitting , Vim
+stops digraph entry and ends Insert mode or Command-line mode, just like
+hitting an  out of digraph context.  Use CTRL-V 155 to enter meta-ESC
+(CSI).
+
+If you accidentally typed an 'a' that should be an 'e', you will type 'a' 
+'e'.  But that is a digraph, so you will not get what you want.  To correct
+this, you will have to type  e again.  To avoid this don't set the
+'digraph' option and use CTRL-K to enter digraphs.
+
+You may have problems using Vim with characters which have a value above 128.
+For example: You insert ue (u-umlaut) and the editor echoes \334 in Insert
+mode.  After leaving the Insert mode everything is fine.  Note that fmt
+removes all characters with a value above 128 from the text being formatted.
+On some Unix systems this means you have to define the environment-variable
+LC_CTYPE.  If you are using csh, then put the following line in your .cshrc: >
+	setenv LC_CTYPE iso_8859_1
+
+==============================================================================
+3. Default digraphs					*digraphs-default*
+
+Vim comes with a set of default digraphs.  Check the output of ":digraphs" to
+see them.
+
+On most systems Vim uses the same digraphs.  They work for the Unicode and
+ISO-8859-1 character sets.  These default digraphs are taken from the RFC1345
+mnemonics.  To make it easy to remember the mnemonic, the second character has
+a standard meaning:
+
+	char name		char	meaning ~
+	Exclamation mark	!	Grave
+	Apostrophe		'	Acute accent
+	Greater-Than sign	>	Circumflex accent
+	Question mark		?	Tilde
+	Hyphen-Minus		-	Macron
+	Left parenthesis	(	Breve
+	Full stop		.	Dot above
+	Colon			:	Diaeresis
+	Comma			,	Cedilla
+	Underline		_	Underline
+	Solidus			/	Stroke
+	Quotation mark		"	Double acute accent
+	Semicolon		;	Ogonek
+	Less-Than sign		<	Caron
+	Zero			0	Ring above
+	Two			2	Hook
+	Nine			9	Horn
+
+	Equals			=	Cyrillic
+	Asterisk		*	Greek
+	Percent sign		%	Greek/Cyrillic special
+	Plus			+	smalls: Arabic, capitals: Hebrew
+	Three			3	some Latin/Greek/Cyrillic letters
+	Four			4	Bopomofo
+	Five			5	Hiragana
+	Six			6	Katakana
+
+Example: a: is ä  and o: is ö
+
+These are the RFC1345 digraphs for the one-byte characters.  See the output of
+":digraphs" for the others.  The characters above 255 are only available when
+Vim was compiled with the |+multi_byte| feature.
+
+EURO
+
+Exception: RFC1345 doesn't specify the euro sign.  In Vim the digraph =e was
+added for this.  Note the difference between latin1, where the digraph Cu is
+used for the currency sign, and latin9 (iso-8859-15), where the digraph =e is
+used for the euro sign, while both of them are the character 164, 0xa4.  For
+compatibility with zsh Eu can also be used for the euro sign.
+
+							*digraph-table*
+char  digraph	hex	dec	official name ~
+^@	NU	0x00	  0	NULL (NUL)
+^A	SH	0x01	  1	START OF HEADING (SOH)
+^B	SX	0x02	  2	START OF TEXT (STX)
+^C	EX	0x03	  3	END OF TEXT (ETX)
+^D	ET	0x04	  4	END OF TRANSMISSION (EOT)
+^E	EQ	0x05	  5	ENQUIRY (ENQ)
+^F	AK	0x06	  6	ACKNOWLEDGE (ACK)
+^G	BL	0x07	  7	BELL (BEL)
+^H	BS	0x08	  8	BACKSPACE (BS)
+^I	HT	0x09	  9	CHARACTER TABULATION (HT)
+^@	LF	0x0a	 10	LINE FEED (LF)
+^K	VT	0x0b	 11	LINE TABULATION (VT)
+^L	FF	0x0c	 12	FORM FEED (FF)
+^M	CR	0x0d	 13	CARRIAGE RETURN (CR)
+^N	SO	0x0e	 14	SHIFT OUT (SO)
+^O	SI	0x0f	 15	SHIFT IN (SI)
+^P	DL	0x10	 16	DATALINK ESCAPE (DLE)
+^Q	D1	0x11	 17	DEVICE CONTROL ONE (DC1)
+^R	D2	0x12	 18	DEVICE CONTROL TWO (DC2)
+^S	D3	0x13	 19	DEVICE CONTROL THREE (DC3)
+^T	D4	0x14	 20	DEVICE CONTROL FOUR (DC4)
+^U	NK	0x15	 21	NEGATIVE ACKNOWLEDGE (NAK)
+^V	SY	0x16	 22	SYNCHRONOUS IDLE (SYN)
+^W	EB	0x17	 23	END OF TRANSMISSION BLOCK (ETB)
+^X	CN	0x18	 24	CANCEL (CAN)
+^Y	EM	0x19	 25	END OF MEDIUM (EM)
+^Z	SB	0x1a	 26	SUBSTITUTE (SUB)
+^[	EC	0x1b	 27	ESCAPE (ESC)
+^\	FS	0x1c	 28	FILE SEPARATOR (IS4)
+^]	GS	0x1d	 29	GROUP SEPARATOR (IS3)
+^^	RS	0x1e	 30	RECORD SEPARATOR (IS2)
+^_	US	0x1f	 31	UNIT SEPARATOR (IS1)
+	SP	0x20	 32	SPACE
+#	Nb	0x23	 35	NUMBER SIGN
+$	DO	0x24	 36	DOLLAR SIGN
+@	At	0x40	 64	COMMERCIAL AT
+[	<(	0x5b	 91	LEFT SQUARE BRACKET
+\	//	0x5c	 92	REVERSE SOLIDUS
+]	)>	0x5d	 93	RIGHT SQUARE BRACKET
+^	'>	0x5e	 94	CIRCUMFLEX ACCENT
+`	'!	0x60	 96	GRAVE ACCENT
+{	(!	0x7b	123	LEFT CURLY BRACKET
+|	!!	0x7c	124	VERTICAL LINE
+}	!)	0x7d	125	RIGHT CURLY BRACKET
+~	'?	0x7e	126	TILDE
+^?	DT	0x7f	127	DELETE (DEL)
+~@	PA	0x80	128	PADDING CHARACTER (PAD)
+~A	HO	0x81	129	HIGH OCTET PRESET (HOP)
+~B	BH	0x82	130	BREAK PERMITTED HERE (BPH)
+~C	NH	0x83	131	NO BREAK HERE (NBH)
+~D	IN	0x84	132	INDEX (IND)
+~E	NL	0x85	133	NEXT LINE (NEL)
+~F	SA	0x86	134	START OF SELECTED AREA (SSA)
+~G	ES	0x87	135	END OF SELECTED AREA (ESA)
+~H	HS	0x88	136	CHARACTER TABULATION SET (HTS)
+~I	HJ	0x89	137	CHARACTER TABULATION WITH JUSTIFICATION (HTJ)
+~J	VS	0x8a	138	LINE TABULATION SET (VTS)
+~K	PD	0x8b	139	PARTIAL LINE FORWARD (PLD)
+~L	PU	0x8c	140	PARTIAL LINE BACKWARD (PLU)
+~M	RI	0x8d	141	REVERSE LINE FEED (RI)
+~N	S2	0x8e	142	SINGLE-SHIFT TWO (SS2)
+~O	S3	0x8f	143	SINGLE-SHIFT THREE (SS3)
+~P	DC	0x90	144	DEVICE CONTROL STRING (DCS)
+~Q	P1	0x91	145	PRIVATE USE ONE (PU1)
+~R	P2	0x92	146	PRIVATE USE TWO (PU2)
+~S	TS	0x93	147	SET TRANSMIT STATE (STS)
+~T	CC	0x94	148	CANCEL CHARACTER (CCH)
+~U	MW	0x95	149	MESSAGE WAITING (MW)
+~V	SG	0x96	150	START OF GUARDED AREA (SPA)
+~W	EG	0x97	151	END OF GUARDED AREA (EPA)
+~X	SS	0x98	152	START OF STRING (SOS)
+~Y	GC	0x99	153	SINGLE GRAPHIC CHARACTER INTRODUCER (SGCI)
+~Z	SC	0x9a	154	SINGLE CHARACTER INTRODUCER (SCI)
+~[	CI	0x9b	155	CONTROL SEQUENCE INTRODUCER (CSI)
+~\	ST	0x9c	156	STRING TERMINATOR (ST)
+~]	OC	0x9d	157	OPERATING SYSTEM COMMAND (OSC)
+~^	PM	0x9e	158	PRIVACY MESSAGE (PM)
+~_	AC	0x9f	159	APPLICATION PROGRAM COMMAND (APC)
+|	NS	0xa0	160	NO-BREAK SPACE
+¡	!I	0xa1	161	INVERTED EXCLAMATION MARK
+¢	Ct	0xa2	162	CENT SIGN
+£	Pd	0xa3	163	POUND SIGN
+¤	Cu	0xa4	164	CURRENCY SIGN
+¥	Ye	0xa5	165	YEN SIGN
+¦	BB	0xa6	166	BROKEN BAR
+§	SE	0xa7	167	SECTION SIGN
+¨	':	0xa8	168	DIAERESIS
+©	Co	0xa9	169	COPYRIGHT SIGN
+ª	-a	0xaa	170	FEMININE ORDINAL INDICATOR
+«	<<	0xab	171	LEFT-POINTING DOUBLE ANGLE QUOTATION MARK
+¬	NO	0xac	172	NOT SIGN
+­	--	0xad	173	SOFT HYPHEN
+®	Rg	0xae	174	REGISTERED SIGN
+¯	'm	0xaf	175	MACRON
+°	DG	0xb0	176	DEGREE SIGN
+±	+-	0xb1	177	PLUS-MINUS SIGN
+²	2S	0xb2	178	SUPERSCRIPT TWO
+³	3S	0xb3	179	SUPERSCRIPT THREE
+´	''	0xb4	180	ACUTE ACCENT
+µ	My	0xb5	181	MICRO SIGN
+¶	PI	0xb6	182	PILCROW SIGN
+·	.M	0xb7	183	MIDDLE DOT
+¸	',	0xb8	184	CEDILLA
+¹	1S	0xb9	185	SUPERSCRIPT ONE
+º	-o	0xba	186	MASCULINE ORDINAL INDICATOR
+»	>>	0xbb	187	RIGHT-POINTING DOUBLE ANGLE QUOTATION MARK
+¼	14	0xbc	188	VULGAR FRACTION ONE QUARTER
+½	12	0xbd	189	VULGAR FRACTION ONE HALF
+¾	34	0xbe	190	VULGAR FRACTION THREE QUARTERS
+¿	?I	0xbf	191	INVERTED QUESTION MARK
+À	A!	0xc0	192	LATIN CAPITAL LETTER A WITH GRAVE
+Á	A'	0xc1	193	LATIN CAPITAL LETTER A WITH ACUTE
+Â	A>	0xc2	194	LATIN CAPITAL LETTER A WITH CIRCUMFLEX
+Ã	A?	0xc3	195	LATIN CAPITAL LETTER A WITH TILDE
+Ä	A:	0xc4	196	LATIN CAPITAL LETTER A WITH DIAERESIS
+Å	AA	0xc5	197	LATIN CAPITAL LETTER A WITH RING ABOVE
+Æ	AE	0xc6	198	LATIN CAPITAL LETTER AE
+Ç	C,	0xc7	199	LATIN CAPITAL LETTER C WITH CEDILLA
+È	E!	0xc8	200	LATIN CAPITAL LETTER E WITH GRAVE
+É	E'	0xc9	201	LATIN CAPITAL LETTER E WITH ACUTE
+Ê	E>	0xca	202	LATIN CAPITAL LETTER E WITH CIRCUMFLEX
+Ë	E:	0xcb	203	LATIN CAPITAL LETTER E WITH DIAERESIS
+Ì	I!	0xcc	204	LATIN CAPITAL LETTER I WITH GRAVE
+Í	I'	0xcd	205	LATIN CAPITAL LETTER I WITH ACUTE
+Î	I>	0xce	206	LATIN CAPITAL LETTER I WITH CIRCUMFLEX
+Ï	I:	0xcf	207	LATIN CAPITAL LETTER I WITH DIAERESIS
+Ð	D-	0xd0	208	LATIN CAPITAL LETTER ETH (Icelandic)
+Ñ	N?	0xd1	209	LATIN CAPITAL LETTER N WITH TILDE
+Ò	O!	0xd2	210	LATIN CAPITAL LETTER O WITH GRAVE
+Ó	O'	0xd3	211	LATIN CAPITAL LETTER O WITH ACUTE
+Ô	O>	0xd4	212	LATIN CAPITAL LETTER O WITH CIRCUMFLEX
+Õ	O?	0xd5	213	LATIN CAPITAL LETTER O WITH TILDE
+Ö	O:	0xd6	214	LATIN CAPITAL LETTER O WITH DIAERESIS
+×	*X	0xd7	215	MULTIPLICATION SIGN
+Ø	O/	0xd8	216	LATIN CAPITAL LETTER O WITH STROKE
+Ù	U!	0xd9	217	LATIN CAPITAL LETTER U WITH GRAVE
+Ú	U'	0xda	218	LATIN CAPITAL LETTER U WITH ACUTE
+Û	U>	0xdb	219	LATIN CAPITAL LETTER U WITH CIRCUMFLEX
+Ü	U:	0xdc	220	LATIN CAPITAL LETTER U WITH DIAERESIS
+Ý	Y'	0xdd	221	LATIN CAPITAL LETTER Y WITH ACUTE
+Þ	TH	0xde	222	LATIN CAPITAL LETTER THORN (Icelandic)
+ß	ss	0xdf	223	LATIN SMALL LETTER SHARP S (German)
+à	a!	0xe0	224	LATIN SMALL LETTER A WITH GRAVE
+á	a'	0xe1	225	LATIN SMALL LETTER A WITH ACUTE
+â	a>	0xe2	226	LATIN SMALL LETTER A WITH CIRCUMFLEX
+ã	a?	0xe3	227	LATIN SMALL LETTER A WITH TILDE
+ä	a:	0xe4	228	LATIN SMALL LETTER A WITH DIAERESIS
+å	aa	0xe5	229	LATIN SMALL LETTER A WITH RING ABOVE
+æ	ae	0xe6	230	LATIN SMALL LETTER AE
+ç	c,	0xe7	231	LATIN SMALL LETTER C WITH CEDILLA
+è	e!	0xe8	232	LATIN SMALL LETTER E WITH GRAVE
+é	e'	0xe9	233	LATIN SMALL LETTER E WITH ACUTE
+ê	e>	0xea	234	LATIN SMALL LETTER E WITH CIRCUMFLEX
+ë	e:	0xeb	235	LATIN SMALL LETTER E WITH DIAERESIS
+ì	i!	0xec	236	LATIN SMALL LETTER I WITH GRAVE
+í	i'	0xed	237	LATIN SMALL LETTER I WITH ACUTE
+î	i>	0xee	238	LATIN SMALL LETTER I WITH CIRCUMFLEX
+ï	i:	0xef	239	LATIN SMALL LETTER I WITH DIAERESIS
+ð	d-	0xf0	240	LATIN SMALL LETTER ETH (Icelandic)
+ñ	n?	0xf1	241	LATIN SMALL LETTER N WITH TILDE
+ò	o!	0xf2	242	LATIN SMALL LETTER O WITH GRAVE
+ó	o'	0xf3	243	LATIN SMALL LETTER O WITH ACUTE
+ô	o>	0xf4	244	LATIN SMALL LETTER O WITH CIRCUMFLEX
+õ	o?	0xf5	245	LATIN SMALL LETTER O WITH TILDE
+ö	o:	0xf6	246	LATIN SMALL LETTER O WITH DIAERESIS
+÷	-:	0xf7	247	DIVISION SIGN
+ø	o/	0xf8	248	LATIN SMALL LETTER O WITH STROKE
+ù	u!	0xf9	249	LATIN SMALL LETTER U WITH GRAVE
+ú	u'	0xfa	250	LATIN SMALL LETTER U WITH ACUTE
+û	u>	0xfb	251	LATIN SMALL LETTER U WITH CIRCUMFLEX
+ü	u:	0xfc	252	LATIN SMALL LETTER U WITH DIAERESIS
+ý	y'	0xfd	253	LATIN SMALL LETTER Y WITH ACUTE
+þ	th	0xfe	254	LATIN SMALL LETTER THORN (Icelandic)
+ÿ	y:	0xff	255	LATIN SMALL LETTER Y WITH DIAERESIS
+
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim72/doc/doctags.c b/share/vim/vim73/doc/doctags.c
similarity index 100%
rename from share/vim/vim72/doc/doctags.c
rename to share/vim/vim73/doc/doctags.c
diff --git a/share/vim/vim73/doc/editing.txt b/share/vim/vim73/doc/editing.txt
new file mode 100644
index 0000000000..84800aa789
--- /dev/null
+++ b/share/vim/vim73/doc/editing.txt
@@ -0,0 +1,1634 @@
+*editing.txt*   For Vim version 7.3.  Last change: 2010 Jul 28
+
+
+		  VIM REFERENCE MANUAL    by Bram Moolenaar
+
+
+Editing files						*edit-files*
+
+1.  Introduction		|edit-intro|
+2.  Editing a file		|edit-a-file|
+3.  The argument list		|argument-list|
+4.  Writing			|writing|
+5.  Writing and quitting	|write-quit|
+6.  Dialogs			|edit-dialogs|
+7.  The current directory	|current-directory|
+8.  Editing binary files	|edit-binary|
+9.  Encryption			|encryption|
+10. Timestamps			|timestamps|
+11. File Searching		|file-searching|
+
+==============================================================================
+1. Introduction						*edit-intro*
+
+Editing a file with Vim means:
+
+1. reading the file into a buffer
+2. changing the buffer with editor commands
+3. writing the buffer into a file
+
+							*current-file*
+As long as you don't write the buffer, the original file remains unchanged.
+If you start editing a file (read a file into the buffer), the file name is
+remembered as the "current file name".  This is also known as the name of the
+current buffer.  It can be used with "%" on the command line |:_%|.
+
+							*alternate-file*
+If there already was a current file name, then that one becomes the alternate
+file name.  It can be used with "#" on the command line |:_#| and you can use
+the |CTRL-^| command to toggle between the current and the alternate file.
+However, the alternate file name is not changed when |:keepalt| is used.
+
+							*:keepalt* *:keepa*
+:keepalt {cmd}		Execute {cmd} while keeping the current alternate file
+			name.  Note that commands invoked indirectly (e.g.,
+			with a function) may still set the alternate file
+			name.  {not in Vi}
+
+All file names are remembered in the buffer list.  When you enter a file name,
+for editing (e.g., with ":e filename") or writing (e.g., with ":w filename"),
+the file name is added to the list.  You can use the buffer list to remember
+which files you edited and to quickly switch from one file to another (e.g.,
+to copy text) with the |CTRL-^| command.  First type the number of the file
+and then hit CTRL-^.  {Vi: only one alternate file name is remembered}
+
+
+CTRL-G		or				*CTRL-G* *:f* *:fi* *:file*
+:f[ile]			Prints the current file name (as typed, unless ":cd"
+			was used), the cursor position (unless the 'ruler'
+			option is set), and the file status (readonly,
+			modified, read errors, new file).  See the 'shortmess'
+			option about how to make this message shorter.
+			{Vi does not include column number}
+
+:f[ile]!		like |:file|, but don't truncate the name even when
+			'shortmess' indicates this.
+
+{count}CTRL-G		Like CTRL-G, but prints the current file name with
+			full path.  If the count is higher than 1 the current
+			buffer number is also given.  {not in Vi}
+
+					*g_CTRL-G* *word-count* *byte-count*
+g CTRL-G		Prints the current position of the cursor in five
+			ways: Column, Line, Word, Character and Byte.  If the
+			number of Characters and Bytes is the same then the
+			Character position is omitted.
+			If there are characters in the line that take more
+			than one position on the screen ( or special
+			character), both the "real" column and the screen
+			column are shown, separated with a dash.
+			See also 'ruler' option.  {not in Vi}
+
+							*v_g_CTRL-G*
+{Visual}g CTRL-G	Similar to "g CTRL-G", but Word, Character, Line, and
+			Byte counts for the visually selected region are
+			displayed.
+			In Blockwise mode, Column count is also shown.  (For
+			{Visual} see |Visual-mode|.)
+			{not in VI}
+
+							*:file_f*
+:f[ile][!] {name}	Sets the current file name to {name}.  The optional !
+			avoids truncating the message, as with |:file|.
+			If the buffer did have a name, that name becomes the
+			|alternate-file| name.  An unlisted buffer is created
+			to hold the old name.
+							*:0file*
+:0f[ile][!]		Remove the name of the current buffer.  The optional !
+			avoids truncating the message, as with |:file|.  {not
+			in Vi}
+
+:buffers
+:files
+:ls			List all the currently known file names.  See
+			'windows.txt' |:files| |:buffers| |:ls|.  {not in
+			Vi}
+
+Vim will remember the full path name of a file name that you enter.  In most
+cases when the file name is displayed only the name you typed is shown, but
+the full path name is being used if you used the ":cd" command |:cd|.
+
+							*home-replace*
+If the environment variable $HOME is set, and the file name starts with that
+string, it is often displayed with HOME replaced with "~".  This was done to
+keep file names short.  When reading or writing files the full name is still
+used, the "~" is only used when displaying file names.  When replacing the
+file name would result in just "~", "~/" is used instead (to avoid confusion
+between options set to $HOME with 'backupext' set to "~").
+
+When writing the buffer, the default is to use the current file name.  Thus
+when you give the "ZZ" or ":wq" command, the original file will be
+overwritten.  If you do not want this, the buffer can be written into another
+file by giving a file name argument to the ":write" command.  For example: >
+
+	vim testfile
+	[change the buffer with editor commands]
+	:w newfile
+	:q
+
+This will create a file "newfile", that is a modified copy of "testfile".
+The file "testfile" will remain unchanged.  Anyway, if the 'backup' option is
+set, Vim renames or copies the original file before it will be overwritten.
+You can use this file if you discover that you need the original file.  See
+also the 'patchmode' option.  The name of the backup file is normally the same
+as the original file with 'backupext' appended.  The default "~" is a bit
+strange to avoid accidentally overwriting existing files.  If you prefer ".bak"
+change the 'backupext' option.  Extra dots are replaced with '_' on MS-DOS
+machines, when Vim has detected that an MS-DOS-like filesystem is being used
+(e.g., messydos or crossdos) or when the 'shortname' option is on.  The
+backup file can be placed in another directory by setting 'backupdir'.
+
+							*auto-shortname*
+Technical: On the Amiga you can use 30 characters for a file name.  But on an
+	   MS-DOS-compatible filesystem only 8 plus 3 characters are
+	   available.  Vim tries to detect the type of filesystem when it is
+	   creating the .swp file.  If an MS-DOS-like filesystem is suspected,
+	   a flag is set that has the same effect as setting the 'shortname'
+	   option.  This flag will be reset as soon as you start editing a
+	   new file.  The flag will be used when making the file name for the
+	   ".swp" and ".~" files for the current file.  But when you are
+	   editing a file in a normal filesystem and write to an MS-DOS-like
+	   filesystem the flag will not have been set.  In that case the
+	   creation of the ".~" file may fail and you will get an error
+	   message.  Use the 'shortname' option in this case.
+
+When you started editing without giving a file name, "No File" is displayed in
+messages.  If the ":write" command is used with a file name argument, the file
+name for the current file is set to that file name.  This only happens when
+the 'F' flag is included in 'cpoptions' (by default it is included) |cpo-F|.
+This is useful when entering text in an empty buffer and then writing it to a
+file.  If 'cpoptions' contains the 'f' flag (by default it is NOT included)
+|cpo-f| the file name is set for the ":read file" command.  This is useful
+when starting Vim without an argument and then doing ":read file" to start
+editing a file.
+When the file name was set and 'filetype' is empty the filetype detection
+autocommands will be triggered.
+							*not-edited*
+Because the file name was set without really starting to edit that file, you
+are protected from overwriting that file.  This is done by setting the
+"notedited" flag.  You can see if this flag is set with the CTRL-G or ":file"
+command.  It will include "[Not edited]" when the "notedited" flag is set.
+When writing the buffer to the current file name (with ":w!"), the "notedited"
+flag is reset.
+
+							*abandon*
+Vim remembers whether you have changed the buffer.  You are protected from
+losing the changes you made.  If you try to quit without writing, or want to
+start editing another file, Vim will refuse this.  In order to overrule this
+protection, add a '!' to the command.  The changes will then be lost.  For
+example: ":q" will not work if the buffer was changed, but ":q!" will.  To see
+whether the buffer was changed use the "CTRL-G" command.  The message includes
+the string "[Modified]" if the buffer has been changed.
+
+If you want to automatically save the changes without asking, switch on the
+'autowriteall' option.  'autowrite' is the associated Vi-compatible option
+that does not work for all commands.
+
+If you want to keep the changed buffer without saving it, switch on the
+'hidden' option.  See |hidden-buffer|.
+
+==============================================================================
+2. Editing a file					*edit-a-file*
+
+							*:e* *:edit*
+:e[dit] [++opt] [+cmd]	Edit the current file.  This is useful to re-edit the
+			current file, when it has been changed outside of Vim.
+			This fails when changes have been made to the current
+			buffer and 'autowriteall' isn't set or the file can't
+			be written.
+			Also see |++opt| and |+cmd|.
+			{Vi: no ++opt}
+
+							*:edit!*
+:e[dit]! [++opt] [+cmd]
+			Edit the current file always.  Discard any changes to
+			the current buffer.  This is useful if you want to
+			start all over again.
+			Also see |++opt| and |+cmd|.
+			{Vi: no ++opt}
+
+							*:edit_f*
+:e[dit] [++opt] [+cmd] {file}
+			Edit {file}.
+			This fails when changes have been made to the current
+			buffer, unless 'hidden' is set or 'autowriteall' is
+			set and the file can be written.
+			Also see |++opt| and |+cmd|.
+			{Vi: no ++opt}
+
+							*:edit!_f*
+:e[dit]! [++opt] [+cmd] {file}
+			Edit {file} always.  Discard any changes to the
+			current buffer.
+			Also see |++opt| and |+cmd|.
+			{Vi: no ++opt}
+
+:e[dit] [++opt] [+cmd] #[count]
+			Edit the [count]th buffer (as shown by |:files|).
+			This command does the same as [count] CTRL-^.  But ":e
+			#" doesn't work if the alternate buffer doesn't have a
+			file name, while CTRL-^ still works then.
+			Also see |++opt| and |+cmd|.
+			{Vi: no ++opt}
+
+							*:ene* *:enew*
+:ene[w]			Edit a new, unnamed buffer.  This fails when changes
+			have been made to the current buffer, unless 'hidden'
+			is set or 'autowriteall' is set and the file can be
+			written.
+			If 'fileformats' is not empty, the first format given
+			will be used for the new buffer.  If 'fileformats' is
+			empty, the 'fileformat' of the current buffer is used.
+			{not in Vi}
+
+							*:ene!* *:enew!*
+:ene[w]!		Edit a new, unnamed buffer.  Discard any changes to
+			the current buffer.
+			Set 'fileformat' like |:enew|.
+			{not in Vi}
+
+							*:fin* *:find*
+:fin[d][!] [++opt] [+cmd] {file}
+			Find {file} in 'path' and then |:edit| it.
+			{not in Vi} {not available when the |+file_in_path|
+			feature was disabled at compile time}
+
+:{count}fin[d][!] [++opt] [+cmd] {file}
+			Just like ":find", but use the {count} match in
+			'path'.  Thus ":2find file" will find the second
+			"file" found in 'path'.  When there are fewer matches
+			for the file in 'path' than asked for, you get an
+			error message.
+
+							*:ex*
+:ex [++opt] [+cmd] [file]
+			Same as |:edit|.
+
+							*:vi* *:visual*
+:vi[sual][!] [++opt] [+cmd] [file]
+			When used in Ex mode: Leave |Ex-mode|, go back to
+			Normal mode.  Otherwise same as |:edit|.
+
+							*:vie* *:view*
+:vie[w][!] [++opt] [+cmd] file
+			When used in Ex mode: Leave |Ex mode|, go back to
+			Normal mode.  Otherwise same as |:edit|, but set
+			'readonly' option for this buffer.  {not in Vi}
+
+							*CTRL-^* *CTRL-6*
+CTRL-^			Edit the alternate file (equivalent to ":e #").
+			Mostly the alternate file is the previously edited
+			file.  This is a quick way to toggle between two
+			files.
+			If the 'autowrite' or 'autowriteall' option is on and
+			the buffer was changed, write it.
+			Mostly the ^ character is positioned on the 6 key,
+			pressing CTRL and 6 then gets you what we call CTRL-^.
+			But on some non-US keyboards CTRL-^ is produced in
+			another way.
+
+{count}CTRL-^		Edit [count]th file in the buffer list (equivalent to
+			":e #[count]").  This is a quick way to switch between
+			files.
+			See |CTRL-^| above for further details.
+			{not in Vi}
+
+[count]]f						*]f* *[f*
+[count][f		Same as "gf".  Deprecated.
+
+							*gf* *E446* *E447*
+[count]gf		Edit the file whose name is under or after the cursor.
+			Mnemonic: "goto file".
+			Uses the 'isfname' option to find out which characters
+			are supposed to be in a file name.  Trailing
+			punctuation characters ".,:;!" are ignored.
+			Uses the 'path' option as a list of directory names to
+			look for the file.  See the 'path' option for details
+			about relative directories and wildcards.
+			Uses the 'suffixesadd' option to check for file names
+			with a suffix added.
+			If the file can't be found, 'includeexpr' is used to
+			modify the name and another attempt is done.
+			If a [count] is given, the count'th file that is found
+			in the 'path' is edited.
+			This command fails if Vim refuses to |abandon| the
+			current file.
+			If you want to edit the file in a new window use
+			|CTRL-W_CTRL-F|.
+			If you do want to edit a new file, use: >
+				:e 
+<			To make gf always work like that: >
+				:map gf :e 
+<			If the name is a hypertext link, that looks like
+			"type://machine/path", you need the |netrw| plugin.
+			For Unix the '~' character is expanded, like in
+			"~user/file".  Environment variables are expanded too
+			|expand-env|.
+			{not in Vi}
+			{not available when the |+file_in_path| feature was
+			disabled at compile time}
+
+							*v_gf*
+{Visual}[count]gf	Same as "gf", but the highlighted text is used as the
+			name of the file to edit.  'isfname' is ignored.
+			Leading blanks are skipped, otherwise all blanks and
+			special characters are included in the file name.
+			(For {Visual} see |Visual-mode|.)
+			{not in VI}
+
+							*gF*
+[count]gF		Same as "gf", except if a number follows the file
+			name, then the cursor is positioned on that line in
+			the file. The file name and the number must be
+			separated by a non-filename (see 'isfname') and
+			non-numeric character. White space between the
+			filename, the separator and the number are ignored.
+			Examples:
+				eval.c:10 ~
+				eval.c @ 20 ~
+				eval.c (30) ~
+				eval.c 40 ~
+
+							*v_gF*
+{Visual}[count]gF	Same as "v_gf".
+
+These commands are used to start editing a single file.  This means that the
+file is read into the buffer and the current file name is set.  The file that
+is opened depends on the current directory, see |:cd|.
+
+See |read-messages| for an explanation of the message that is given after the
+file has been read.
+
+You can use the ":e!" command if you messed up the buffer and want to start
+all over again.  The ":e" command is only useful if you have changed the
+current file name.
+
+							*:filename* *{file}*
+Besides the things mentioned here, more special items for where a filename is
+expected are mentioned at |cmdline-special|.
+
+Note for systems other than Unix: When using a command that accepts a single
+file name (like ":edit file") spaces in the file name are allowed, but
+trailing spaces are ignored.  This is useful on systems that regularly embed
+spaces in file names (like MS-Windows and the Amiga).  Example: The command
+":e   Long File Name " will edit the file "Long File Name".  When using a
+command that accepts more than one file name (like ":next file1 file2")
+embedded spaces must be escaped with a backslash.
+
+						*wildcard* *wildcards*
+Wildcards in {file} are expanded.  Which wildcards are supported depends on
+the system.  These are the common ones:
+	?	matches one character
+	*	matches anything, including nothing
+	**	matches anything, including nothing, recurses into directories
+	[abc]	match 'a', 'b' or 'c'
+
+To avoid the special meaning of the wildcards prepend a backslash.  However,
+on MS-Windows the backslash is a path separator and "path\[abc]" is still seen
+as a wildcard when "[" is in the 'isfname' option.  A simple way to avoid this
+is to use "path\[[]abc]".  Then the file "path[abc]" literally.
+
+					*starstar-wildcard*
+Expanding "**" is possible on Unix, Win32, Mac OS/X and a few other systems.
+This allows searching a directory tree.  This goes up to 100 directories deep.
+Note there are some commands where this works slightly different, see
+|file-searching|.
+Example: >
+	:n **/*.txt
+Finds files:
+	ttt.txt
+	subdir/ttt.txt
+	a/b/c/d/ttt.txt
+When non-wildcard characters are used these are only matched in the first
+directory.  Example: >
+	:n /usr/inc**/*.h
+Finds files:
+	/usr/include/types.h
+	/usr/include/sys/types.h
+	/usr/inc_old/types.h
+					*backtick-expansion* *`-expansion*
+On Unix and a few other systems you can also use backticks in the file name,
+for example: >
+	:e `find . -name ver\\*.c -print`
+The backslashes before the star are required to prevent "ver*.c" to be
+expanded by the shell before executing the find program.
+This also works for most other systems, with the restriction that the
+backticks must be around the whole item.  It is not possible to have text
+directly before the first or just after the last backtick.
+
+							*`=*
+You can have the backticks expanded as a Vim expression, instead of an
+external command, by using the syntax `={expr}` e.g.: >
+	:e `=tempname()`
+The expression can contain just about anything, thus this can also be used to
+avoid the special meaning of '"', '|', '%' and '#'.  Names are to be separated
+with line breaks.  When the result is a |List| then each item is used as a
+name.  Line breaks also separate names.
+
+							*++opt* *[++opt]*
+The [++opt] argument can be used to force the value of 'fileformat',
+'fileencoding' or 'binary' to a value for one command, and to specify the
+behavior for bad characters.  The form is: >
+	++{optname}
+Or: >
+	++{optname}={value}
+
+Where {optname} is one of:	    *++ff* *++enc* *++bin* *++nobin* *++edit*
+    ff     or  fileformat   overrides 'fileformat'
+    enc    or  encoding	    overrides 'fileencoding'
+    bin    or  binary	    sets 'binary'
+    nobin  or  nobinary	    resets 'binary'
+    bad			    specifies behavior for bad characters
+    edit		    for |:read| only: keep option values as if editing
+			    a file
+
+{value} cannot contain white space.  It can be any valid value for these
+options.  Examples: >
+	:e ++ff=unix
+This edits the same file again with 'fileformat' set to "unix". >
+
+	:w ++enc=latin1 newfile
+This writes the current buffer to "newfile" in latin1 format.
+
+There may be several ++opt arguments, separated by white space.  They must all
+appear before any |+cmd| argument.
+
+								*++bad*
+The argument of "++bad=" specifies what happens with characters that can't be
+converted and illegal bytes.  It can be one of three things:
+    ++bad=X      A single-byte character that replaces each bad character.
+    ++bad=keep   Keep bad characters without conversion.  Note that this may
+		 result in illegal bytes in your text!
+    ++bad=drop   Remove the bad characters.
+
+The default is like "++bad=?": Replace each bad character with a question
+mark.  In some places an inverted question mark is used (0xBF).
+
+Note that not all commands use the ++bad argument, even though they do not
+give an error when you add it.  E.g. |:write|.
+
+Note that when reading, the 'fileformat' and 'fileencoding' options will be
+set to the used format.  When writing this doesn't happen, thus a next write
+will use the old value of the option.  Same for the 'binary' option.
+
+
+							*+cmd* *[+cmd]*
+The [+cmd] argument can be used to position the cursor in the newly opened
+file, or execute any other command:
+	+		Start at the last line.
+	+{num}		Start at line {num}.
+	+/{pat}		Start at first line containing {pat}.
+	+{command}	Execute {command} after opening the new file.
+			{command} is any Ex command.
+To include a white space in the {pat} or {command}, precede it with a
+backslash.  Double the number of backslashes. >
+	:edit  +/The\ book	     file
+	:edit  +/dir\ dirname\\      file
+	:edit  +set\ dir=c:\\\\temp  file
+Note that in the last example the number of backslashes is halved twice: Once
+for the "+cmd" argument and once for the ":set" command.
+
+							*file-formats*
+The 'fileformat' option sets the  style for a file:
+'fileformat'    characters	   name				~
+  "dos"		 or    DOS format		*DOS-format*
+  "unix"			   Unix format		*Unix-format*
+  "mac"				   Mac format		*Mac-format*
+Previously 'textmode' was used.  It is obsolete now.
+
+When reading a file, the mentioned characters are interpreted as the .
+In DOS format (default for MS-DOS, OS/2 and Win32),  and  are both
+interpreted as the .  Note that when writing the file in DOS format,
+ characters will be added for each single .  Also see |file-read|.
+
+When writing a file, the mentioned characters are used for .  For DOS
+format  is used.  Also see |DOS-format-write|.
+
+You can read a file in DOS format and write it in Unix format.  This will
+replace all  pairs by  (assuming 'fileformats' includes "dos"): >
+	:e file
+	:set fileformat=unix
+	:w
+If you read a file in Unix format and write with DOS format, all 
+characters will be replaced with  (assuming 'fileformats' includes
+"unix"): >
+	:e file
+	:set fileformat=dos
+	:w
+
+If you start editing a new file and the 'fileformats' option is not empty
+(which is the default), Vim will try to detect whether the lines in the file
+are separated by the specified formats.  When set to "unix,dos", Vim will
+check for lines with a single  (as used on Unix and Amiga) or by a 
+ pair (MS-DOS).  Only when ALL lines end in , 'fileformat' is set
+to "dos", otherwise it is set to "unix".  When 'fileformats' includes "mac",
+and no  characters are found in the file, 'fileformat' is set to "mac".
+
+If the 'fileformat' option is set to "dos" on non-MS-DOS systems the message
+"[dos format]" is shown to remind you that something unusual is happening.  On
+MS-DOS systems you get the message "[unix format]" if 'fileformat' is set to
+"unix".  On all systems but the Macintosh you get the message "[mac format]"
+if 'fileformat' is set to "mac".
+
+If the 'fileformats' option is empty and DOS format is used, but while reading
+a file some lines did not end in , "[CR missing]" will be included in
+the file message.
+If the 'fileformats' option is empty and Mac format is used, but while reading
+a file a  was found, "[NL missing]" will be included in the file message.
+
+If the new file does not exist, the 'fileformat' of the current buffer is used
+when 'fileformats' is empty.  Otherwise the first format from 'fileformats' is
+used for the new file.
+
+Before editing binary, executable or Vim script files you should set the
+'binary' option.  A simple way to do this is by starting Vim with the "-b"
+option.  This will avoid the use of 'fileformat'.  Without this you risk that
+single  characters are unexpectedly replaced with .
+
+You can encrypt files that are written by setting the 'key' option.  This
+provides some security against others reading your files. |encryption|
+
+
+==============================================================================
+3. The argument list				*argument-list* *arglist*
+
+If you give more than one file name when starting Vim, this list is remembered
+as the argument list.  You can jump to each file in this list.
+
+Do not confuse this with the buffer list, which you can see with the
+|:buffers| command.  The argument list was already present in Vi, the buffer
+list is new in Vim.  Every file name in the argument list will also be present
+in the buffer list (unless it was deleted with |:bdel| or |:bwipe|).  But it's
+common that names in the buffer list are not in the argument list.
+
+This subject is introduced in section |07.2| of the user manual.
+
+There is one global argument list, which is used for all windows by default.
+It is possible to create a new argument list local to a window, see
+|:arglocal|.
+
+You can use the argument list with the following commands, and with the
+expression functions |argc()| and |argv()|.  These all work on the argument
+list of the current window.
+
+							*:ar* *:args*
+:ar[gs]			Print the argument list, with the current file in
+			square brackets.
+
+:ar[gs] [++opt] [+cmd] {arglist}			*:args_f*
+			Define {arglist} as the new argument list and edit
+			the first one.  This fails when changes have been made
+			and Vim does not want to |abandon| the current buffer.
+			Also see |++opt| and |+cmd|.
+			{Vi: no ++opt}
+
+:ar[gs]! [++opt] [+cmd] {arglist}			*:args_f!*
+			Define {arglist} as the new argument list and edit
+			the first one.  Discard any changes to the current
+			buffer.
+			Also see |++opt| and |+cmd|.
+			{Vi: no ++opt}
+
+:[count]arge[dit][!] [++opt] [+cmd] {name}		*:arge* *:argedit*
+			Add {name} to the argument list and edit it.
+			When {name} already exists in the argument list, this
+			entry is edited.
+			This is like using |:argadd| and then |:edit|.
+			Note that only one file name is allowed, and spaces
+			inside the file name are allowed, like with |:edit|.
+			[count] is used like with |:argadd|.
+			[!] is required if the current file cannot be
+			|abandon|ed.
+			Also see |++opt| and |+cmd|.
+			{not in Vi}
+
+:[count]arga[dd] {name} ..			*:arga* *:argadd* *E479*
+			Add the {name}s to the argument list.
+			If [count] is omitted, the {name}s are added just
+			after the current entry in the argument list.
+			Otherwise they are added after the [count]'th file.
+			If the argument list is "a b c", and "b" is the
+			current argument, then these commands result in:
+				command		new argument list ~
+				:argadd x	a b x c
+				:0argadd x	x a b c
+				:1argadd x	a x b c
+				:99argadd x	a b c x
+			There is no check for duplicates, it is possible to
+			add a file to the argument list twice.
+			The currently edited file is not changed.
+			{not in Vi} {not available when compiled without the
+			|+listcmds| feature}
+			Note: you can also use this method: >
+				:args ## x
+<			This will add the "x" item and sort the new list.
+
+:argd[elete] {pattern} ..			*:argd* *:argdelete* *E480*
+			Delete files from the argument list that match the
+			{pattern}s.  {pattern} is used like a file pattern,
+			see |file-pattern|.  "%" can be used to delete the
+			current entry.
+			This command keeps the currently edited file, also
+			when it's deleted from the argument list.
+			Example: >
+				:argdel *.obj
+<			{not in Vi} {not available when compiled without the
+			|+listcmds| feature}
+
+:{range}argd[elete]	Delete the {range} files from the argument list.
+			When the last number in the range is too high, up to
+			the last argument is deleted.  Example: >
+				:10,1000argdel
+<			Deletes arguments 10 and further, keeping 1-9.
+			{not in Vi} {not available when compiled without the
+			|+listcmds| feature}
+
+							*:argu* *:argument*
+:[count]argu[ment] [count] [++opt] [+cmd]
+			Edit file [count] in the argument list.  When [count]
+			is omitted the current entry is used.  This fails
+			when changes have been made and Vim does not want to
+			|abandon| the current buffer.
+			Also see |++opt| and |+cmd|.
+			{not in Vi} {not available when compiled without the
+			|+listcmds| feature}
+
+:[count]argu[ment]! [count] [++opt] [+cmd]
+			Edit file [count] in the argument list, discard any
+			changes to the current buffer.  When [count] is
+			omitted the current entry is used.
+			Also see |++opt| and |+cmd|.
+			{not in Vi} {not available when compiled without the
+			|+listcmds| feature}
+
+:[count]n[ext] [++opt] [+cmd]			*:n* *:ne* *:next* *E165* *E163*
+			Edit [count] next file.  This fails when changes have
+			been made and Vim does not want to |abandon| the
+			current buffer.  Also see |++opt| and |+cmd|.  {Vi: no
+			count or ++opt}.
+
+:[count]n[ext]! [++opt] [+cmd]
+			Edit [count] next file, discard any changes to the
+			buffer.  Also see |++opt| and |+cmd|.  {Vi: no count
+			or ++opt}.
+
+:n[ext] [++opt] [+cmd] {arglist}			*:next_f*
+			Same as |:args_f|.
+
+:n[ext]! [++opt] [+cmd] {arglist}
+			Same as |:args_f!|.
+
+:[count]N[ext] [count] [++opt] [+cmd]			*:Next* *:N* *E164*
+			Edit [count] previous file in argument list.  This
+			fails when changes have been made and Vim does not
+			want to |abandon| the current buffer.
+			Also see |++opt| and |+cmd|.  {Vi: no count or ++opt}.
+
+:[count]N[ext]! [count] [++opt] [+cmd]
+			Edit [count] previous file in argument list.  Discard
+			any changes to the buffer.  Also see |++opt| and
+			|+cmd|.  {Vi: no count or ++opt}.
+
+:[count]prev[ious] [count] [++opt] [+cmd]		*:prev* *:previous*
+			Same as :Next.  Also see |++opt| and |+cmd|.  {Vi:
+			only in some versions}
+
+							*:rew* *:rewind*
+:rew[ind] [++opt] [+cmd]
+			Start editing the first file in the argument list.
+			This fails when changes have been made and Vim does
+			not want to |abandon| the current buffer.
+			Also see |++opt| and |+cmd|. {Vi: no ++opt}
+
+:rew[ind]! [++opt] [+cmd]
+			Start editing the first file in the argument list.
+			Discard any changes to the buffer.  Also see |++opt|
+			and |+cmd|. {Vi: no ++opt}
+
+							*:fir* *:first*
+:fir[st][!] [++opt] [+cmd]
+			Other name for ":rewind". {not in Vi}
+
+							*:la* *:last*
+:la[st] [++opt] [+cmd]
+			Start editing the last file in the argument list.
+			This fails when changes have been made and Vim does
+			not want to |abandon| the current buffer.
+			Also see |++opt| and |+cmd|.  {not in Vi}
+
+:la[st]! [++opt] [+cmd]
+			Start editing the last file in the argument list.
+			Discard any changes to the buffer.  Also see |++opt|
+			and |+cmd|.  {not in Vi}
+
+							*:wn* *:wnext*
+:[count]wn[ext] [++opt]
+			Write current file and start editing the [count]
+			next file.  Also see |++opt| and |+cmd|.  {not in Vi}
+
+:[count]wn[ext] [++opt] {file}
+			Write current file to {file} and start editing the
+			[count] next file, unless {file} already exists and
+			the 'writeany' option is off.  Also see |++opt| and
+			|+cmd|.  {not in Vi}
+
+:[count]wn[ext]! [++opt] {file}
+			Write current file to {file} and start editing the
+			[count] next file.  Also see |++opt| and |+cmd|.  {not
+			in Vi}
+
+:[count]wN[ext][!] [++opt] [file]		*:wN* *:wNext*
+:[count]wp[revious][!] [++opt] [file]		*:wp* *:wprevious*
+			Same as :wnext, but go to previous file instead of
+			next.  {not in Vi}
+
+The [count] in the commands above defaults to one.  For some commands it is
+possible to use two counts.  The last one (rightmost one) is used.
+
+If no [+cmd] argument is present, the cursor is positioned at the last known
+cursor position for the file.  If 'startofline' is set, the cursor will be
+positioned at the first non-blank in the line, otherwise the last know column
+is used.  If there is no last known cursor position the cursor will be in the
+first line (the last line in Ex mode).
+
+							*{arglist}*
+The wildcards in the argument list are expanded and the file names are sorted.
+Thus you can use the command "vim *.c" to edit all the C files.  From within
+Vim the command ":n *.c" does the same.
+
+White space is used to separate file names.  Put a backslash before a space or
+tab to include it in a file name.  E.g., to edit the single file "foo bar": >
+	:next foo\ bar
+
+On Unix and a few other systems you can also use backticks, for example: >
+	:next `find . -name \\*.c -print`
+The backslashes before the star are required to prevent "*.c" to be expanded
+by the shell before executing the find program.
+
+							*arglist-position*
+When there is an argument list you can see which file you are editing in the
+title of the window (if there is one and 'title' is on) and with the file
+message you get with the "CTRL-G" command.  You will see something like
+	(file 4 of 11)
+If 'shortmess' contains 'f' it will be
+	(4 of 11)
+If you are not really editing the file at the current position in the argument
+list it will be
+	(file (4) of 11)
+This means that you are position 4 in the argument list, but not editing the
+fourth file in the argument list.  This happens when you do ":e file".
+
+
+LOCAL ARGUMENT LIST
+
+{not in Vi}
+{not available when compiled without the |+windows| or |+listcmds| features}
+
+							*:arglocal*
+:argl[ocal]		Make a local copy of the global argument list.
+			Doesn't start editing another file.
+
+:argl[ocal][!] [++opt] [+cmd] {arglist}
+			Define a new argument list, which is local to the
+			current window.  Works like |:args_f| otherwise.
+
+							*:argglobal*
+:argg[lobal]		Use the global argument list for the current window.
+			Doesn't start editing another file.
+
+:argg[lobal][!] [++opt] [+cmd] {arglist}
+			Use the global argument list for the current window.
+			Define a new global argument list like |:args_f|.
+			All windows using the global argument list will see
+			this new list.
+
+There can be several argument lists.  They can be shared between windows.
+When they are shared, changing the argument list in one window will also
+change it in the other window.
+
+When a window is split the new window inherits the argument list from the
+current window.  The two windows then share this list, until one of them uses
+|:arglocal| or |:argglobal| to use another argument list.
+
+
+USING THE ARGUMENT LIST
+
+						*:argdo*
+:argdo[!] {cmd}		Execute {cmd} for each file in the argument list.
+			It works like doing this: >
+				:rewind
+				:{cmd}
+				:next
+				:{cmd}
+				etc.
+<			When the current file can't be |abandon|ed and the [!]
+			is not present, the command fails.
+			When an error is detected on one file, further files
+			in the argument list will not be visited.
+			The last file in the argument list (or where an error
+			occurred) becomes the current file.
+			{cmd} can contain '|' to concatenate several commands.
+			{cmd} must not change the argument list.
+			Note: While this command is executing, the Syntax
+			autocommand event is disabled by adding it to
+			'eventignore'.  This considerably speeds up editing
+			each file.
+			{not in Vi} {not available when compiled without the
+			|+listcmds| feature}
+			Also see |:windo|, |:tabdo| and |:bufdo|.
+
+Example: >
+	:args *.c
+	:argdo set ff=unix | update
+This sets the 'fileformat' option to "unix" and writes the file if it is now
+changed.  This is done for all *.c files.
+
+Example: >
+	:args *.[ch]
+	:argdo %s/\/My_Foo/ge | update
+This changes the word "my_foo" to "My_Foo" in all *.c and *.h files.  The "e"
+flag is used for the ":substitute" command to avoid an error for files where
+"my_foo" isn't used.  ":update" writes the file only if changes were made.
+
+==============================================================================
+4. Writing					*writing* *save-file*
+
+Note: When the 'write' option is off, you are not able to write any file.
+
+							*:w* *:write*
+						*E502* *E503* *E504* *E505*
+						*E512* *E514* *E667* *E796*
+:w[rite] [++opt]	Write the whole buffer to the current file.  This is
+			the normal way to save changes to a file.  It fails
+			when the 'readonly' option is set or when there is
+			another reason why the file can't be written.
+			For ++opt see |++opt|, but only ++bin, ++nobin, ++ff
+			and ++enc are effective.
+
+:w[rite]! [++opt]	Like ":write", but forcefully write when 'readonly' is
+			set or there is another reason why writing was
+			refused.
+			Note: This may change the permission and ownership of
+			the file and break (symbolic) links.  Add the 'W' flag
+			to 'cpoptions' to avoid this.
+
+:[range]w[rite][!] [++opt]
+			Write the specified lines to the current file.  This
+			is unusual, because the file will not contain all
+			lines in the buffer.
+
+							*:w_f* *:write_f*
+:[range]w[rite] [++opt]	{file}
+			Write the specified lines to {file}, unless it
+			already exists and the 'writeany' option is off.
+
+							*:w!*
+:[range]w[rite]! [++opt] {file}
+			Write the specified lines to {file}.  Overwrite an
+			existing file.
+
+						*:w_a* *:write_a* *E494*
+:[range]w[rite][!] [++opt] >>
+			Append the specified lines to the current file.
+
+:[range]w[rite][!] [++opt] >> {file}
+			Append the specified lines to {file}.  '!' forces the
+			write even if file does not exist.
+
+							*:w_c* *:write_c*
+:[range]w[rite] [++opt] !{cmd}
+			Execute {cmd} with [range] lines as standard input
+			(note the space in front of the '!').  {cmd} is
+			executed like with ":!{cmd}", any '!' is replaced with
+			the previous command |:!|.
+
+The default [range] for the ":w" command is the whole buffer (1,$).  If you
+write the whole buffer, it is no longer considered changed.  When you
+write it to a different file with ":w somefile" it depends on the "+" flag in
+'cpoptions'.  When included, the write command will reset the 'modified' flag,
+even though the buffer itself may still be different from its file.
+
+If a file name is given with ":w" it becomes the alternate file.  This can be
+used, for example, when the write fails and you want to try again later with
+":w #".  This can be switched off by removing the 'A' flag from the
+'cpoptions' option.
+
+							*:sav* *:saveas*
+:sav[eas][!] [++opt] {file}
+			Save the current buffer under the name {file} and set
+			the filename of the current buffer to {file}.  The
+			previous name is used for the alternate file name.
+			The [!] is needed to overwrite an existing file.
+			When 'filetype' is empty filetype detection is done
+			with the new name, before the file is written.
+			When the write was successful 'readonly' is reset.
+			{not in Vi}
+
+							*:up* *:update*
+:[range]up[date][!] [++opt] [>>] [file]
+			Like ":write", but only write when the buffer has been
+			modified.  {not in Vi}
+
+
+WRITING WITH MULTIPLE BUFFERS				*buffer-write*
+
+							*:wa* *:wall*
+:wa[ll]			Write all changed buffers.  Buffers without a file
+			name or which are readonly are not written. {not in
+			Vi}
+
+:wa[ll]!		Write all changed buffers, even the ones that are
+			readonly.  Buffers without a file name are not
+			written. {not in Vi}
+
+
+Vim will warn you if you try to overwrite a file that has been changed
+elsewhere.  See |timestamp|.
+
+			    *backup* *E207* *E506* *E507* *E508* *E509* *E510*
+If you write to an existing file (but do not append) while the 'backup',
+'writebackup' or 'patchmode' option is on, a backup of the original file is
+made.  The file is either copied or renamed (see 'backupcopy').  After the
+file has been successfully written and when the 'writebackup' option is on and
+the 'backup' option is off, the backup file is deleted.  When the 'patchmode'
+option is on the backup file may be renamed.
+
+							*backup-table*
+'backup' 'writebackup'	action	~
+   off	     off	no backup made
+   off	     on		backup current file, deleted afterwards (default)
+   on	     off	delete old backup, backup current file
+   on	     on		delete old backup, backup current file
+
+When the 'backupskip' pattern matches with the name of the file which is
+written, no backup file is made.  The values of 'backup' and 'writebackup' are
+ignored then.
+
+When the 'backup' option is on, an old backup file (with the same name as the
+new backup file) will be deleted.  If 'backup' is not set, but 'writebackup'
+is set, an existing backup file will not be deleted.  The backup file that is
+made while the file is being written will have a different name.
+
+On some filesystems it's possible that in a crash you lose both the backup and
+the newly written file (it might be there but contain bogus data).  In that
+case try recovery, because the swap file is synced to disk and might still be
+there. |:recover|
+
+The directories given with the 'backupdir' option is used to put the backup
+file in.  (default: same directory as the written file).
+
+Whether the backup is a new file, which is a copy of the original file, or the
+original file renamed depends on the 'backupcopy' option.  See there for an
+explanation of when the copy is made and when the file is renamed.
+
+If the creation of a backup file fails, the write is not done.  If you want
+to write anyway add a '!' to the command.
+
+							*write-readonly*
+When the 'cpoptions' option contains 'W', Vim will refuse to overwrite a
+readonly file.  When 'W' is not present, ":w!" will overwrite a readonly file,
+if the system allows it (the directory must be writable).
+
+							*write-fail*
+If the writing of the new file fails, you have to be careful not to lose
+your changes AND the original file.  If there is no backup file and writing
+the new file failed, you have already lost the original file!  DON'T EXIT VIM
+UNTIL YOU WRITE OUT THE FILE!  If a backup was made, it is put back in place
+of the original file (if possible).  If you exit Vim, and lose the changes
+you made, the original file will mostly still be there.  If putting back the
+original file fails, there will be an error message telling you that you
+lost the original file.
+
+						*DOS-format-write*
+If the 'fileformat' is "dos",   is used for .  This is default
+for MS-DOS, Win32 and OS/2.  On other systems the message "[dos format]" is
+shown to remind you that an unusual  was used.
+						*Unix-format-write*
+If the 'fileformat' is "unix",  is used for .  On MS-DOS, Win32 and
+OS/2 the message "[unix format]" is shown.
+						*Mac-format-write*
+If the 'fileformat' is "mac",  is used for .  On non-Mac systems the
+message "[mac format]" is shown.
+
+See also |file-formats| and the 'fileformat' and 'fileformats' options.
+
+						*ACL*
+ACL stands for Access Control List.  It is an advanced way to control access
+rights for a file.  It is used on new MS-Windows and Unix systems, but only
+when the filesystem supports it.
+   Vim attempts to preserve the ACL info when writing a file.  The backup file
+will get the ACL info of the original file.
+   The ACL info is also used to check if a file is read-only (when opening the
+file).
+
+						*read-only-share*
+When MS-Windows shares a drive on the network it can be marked as read-only.
+This means that even if the file read-only attribute is absent, and the ACL
+settings on NT network shared drives allow writing to the file, you can still
+not write to the file.  Vim on Win32 platforms will detect read-only network
+drives and will mark the file as read-only.  You will not be able to override
+it with |:write|.
+
+						*write-device*
+When the file name is actually a device name, Vim will not make a backup (that
+would be impossible).  You need to use "!", since the device already exists.
+Example for Unix: >
+	:w! /dev/lpt0
+and for MS-DOS or MS-Windows: >
+	:w! lpt0
+For Unix a device is detected when the name doesn't refer to a normal file or
+a directory.  A fifo or named pipe also looks like a device to Vim.
+For MS-DOS and MS-Windows the device is detected by its name:
+	AUX
+	CON
+	CLOCK$
+	NUL
+	PRN
+	COMn	n=1,2,3... etc
+	LPTn	n=1,2,3... etc
+The names can be in upper- or lowercase.
+
+==============================================================================
+5. Writing and quitting					*write-quit*
+
+							*:q* *:quit*
+:q[uit]			Quit the current window.  Quit Vim if this is the last
+			window.  This fails when changes have been made and
+			Vim refuses to |abandon| the current buffer, and when
+			the last file in the argument list has not been
+			edited.
+			If there are other tab pages and quitting the last
+			window in the current tab page the current tab page is
+			closed |tab-page|.
+
+:conf[irm] q[uit]	Quit, but give prompt when changes have been made, or
+			the last file in the argument list has not been
+			edited.  See |:confirm| and 'confirm'.  {not in Vi}
+
+:q[uit]!		Quit without writing, also when visible buffers have
+			changes.  Does not exit when there are changed hidden
+			buffers.  Use ":qall!" to exit always.
+
+:cq[uit]		Quit always, without writing, and return an error
+			code.  See |:cq|.  Used for Manx's QuickFix mode (see
+			|quickfix|).  {not in Vi}
+
+							*:wq*
+:wq [++opt]		Write the current file and quit.  Writing fails when
+			the file is read-only or the buffer does not have a
+			name.  Quitting fails when the last file in the
+			argument list has not been edited.
+
+:wq! [++opt]		Write the current file and quit.  Writing fails when
+			the current buffer does not have a name.
+
+:wq [++opt] {file}	Write to {file} and quit.  Quitting fails when the
+			last file in the argument list has not been edited.
+
+:wq! [++opt] {file}	Write to {file} and quit.
+
+:[range]wq[!] [++opt] [file]
+			Same as above, but only write the lines in [range].
+
+							*:x* *:xit*
+:[range]x[it][!] [++opt] [file]
+			Like ":wq", but write only when changes have been
+			made.
+			When 'hidden' is set and there are more windows, the
+			current buffer becomes hidden, after writing the file.
+
+							*:exi* *:exit*
+:[range]exi[t][!] [++opt] [file]
+			Same as :xit.
+
+							*ZZ*
+ZZ			Write current file, if modified, and quit (same as
+			":x").  (Note: If there are several windows for the
+			current file, the file is written if it was modified
+			and the window is closed).
+
+							*ZQ*
+ZQ			Quit without checking for changes (same as ":q!").
+			{not in Vi}
+
+MULTIPLE WINDOWS AND BUFFERS				*window-exit*
+
+							*:qa* *:qall*
+:qa[ll]		Exit Vim, unless there are some buffers which have been
+		changed.  (Use ":bmod" to go to the next modified buffer).
+		When 'autowriteall' is set all changed buffers will be
+		written, like |:wqall|. {not in Vi}
+
+:conf[irm] qa[ll]
+		Exit Vim.  Bring up a prompt when some buffers have been
+		changed.  See |:confirm|. {not in Vi}
+
+:qa[ll]!	Exit Vim.  Any changes to buffers are lost. {not in Vi}
+		Also see |:cquit|, it does the same but exits with a non-zero
+		value.
+
+							*:quita* *:quitall*
+:quita[ll][!]	Same as ":qall". {not in Vi}
+
+:wqa[ll] [++opt]				*:wqa* *:wqall* *:xa* *:xall*
+:xa[ll]		Write all changed buffers and exit Vim.  If there are buffers
+		without a file name, which are readonly or which cannot be
+		written for another reason, Vim will not quit. {not in Vi}
+
+:conf[irm] wqa[ll] [++opt]
+:conf[irm] xa[ll]
+		Write all changed buffers and exit Vim.  Bring up a prompt
+		when some buffers are readonly or cannot be written for
+		another reason.  See |:confirm|. {not in Vi}
+
+:wqa[ll]! [++opt]
+:xa[ll]!	Write all changed buffers, even the ones that are readonly,
+		and exit Vim.  If there are buffers without a file name or
+		which cannot be written for another reason, Vim will not quit.
+		{not in Vi}
+
+==============================================================================
+6. Dialogs						*edit-dialogs*
+
+							*:confirm* *:conf*
+:conf[irm] {command}	Execute {command}, and use a dialog when an
+			operation has to be confirmed.  Can be used on the
+			":q", ":qa" and ":w" commands (the latter to over-ride
+			a read-only setting).
+
+Examples: >
+  :confirm w foo
+<	Will ask for confirmation when "foo" already exists. >
+  :confirm q
+<	Will ask for confirmation when there are changes. >
+  :confirm qa
+<	If any modified, unsaved buffers exist, you will be prompted to save
+	or abandon each one.  There are also choices to "save all" or "abandon
+	all".
+
+If you want to always use ":confirm", set the 'confirm' option.
+
+			*:browse* *:bro* *E338* *E614* *E615* *E616* *E578*
+:bro[wse] {command}	Open a file selection dialog for an argument to
+			{command}.  At present this works for |:e|, |:w|,
+			|:wall|, |:wq|, |:wqall|, |:x|, |:xall|, |:exit|,
+			|:view|, |:sview|, |:r|, |:saveas|, |:sp|, |:mkexrc|,
+			|:mkvimrc|, |:mksession|, |:mkview|, |:split|,
+			|:vsplit|, |:tabe|, |:tabnew|, |:cfile|, |:cgetfile|,
+			|:caddfile|, |:lfile|, |:lgetfile|, |:laddfile|,
+			|:diffsplit|, |:diffpatch|, |:open|, |:pedit|,
+			|:redir|, |:source|, |:update|, |:visual|, |:vsplit|,
+			and |:qall| if 'confirm' is set.
+			{only in Win32, Athena, Motif, GTK and Mac GUI}
+			When ":browse" is not possible you get an error
+			message.  If the |+browse| feature is missing or the
+			{command} doesn't support browsing, the {command} is
+			executed without a dialog.
+			":browse set" works like |:options|.
+			See also |:oldfiles| for ":browse oldfiles".
+
+The syntax is best shown via some examples: >
+	:browse e $vim/foo
+<		Open the browser in the $vim/foo directory, and edit the
+		file chosen. >
+	:browse e
+<		Open the browser in the directory specified with 'browsedir',
+		and edit the file chosen. >
+	:browse w
+<		Open the browser in the directory of the current buffer,
+		with the current buffer filename as default, and save the
+		buffer under the filename chosen. >
+	:browse w C:/bar
+<		Open the browser in the C:/bar directory, with the current
+		buffer filename as default, and save the buffer under the
+		filename chosen.
+Also see the |'browsedir'| option.
+For versions of Vim where browsing is not supported, the command is executed
+unmodified.
+
+							*browsefilter*
+For MS Windows, you can modify the filters that are used in the browse dialog.
+By setting the g:browsefilter or b:browsefilter variables, you can change the
+filters globally or locally to the buffer.  The variable is set to a string in
+the format "{filter label}\t{pattern};{pattern}\n" where {filter label} is the
+text that appears in the "Files of Type" comboBox, and {pattern} is the
+pattern which filters the filenames.  Several patterns can be given, separated
+by ';'.
+
+For Motif the same format is used, but only the very first pattern is actually
+used (Motif only offers one pattern, but you can edit it).
+
+For example, to have only Vim files in the dialog, you could use the following
+command: >
+
+     let g:browsefilter="Vim Scripts\t*.vim\nVim Startup Files\t*vimrc\n"
+
+You can override the filter setting on a per-buffer basis by setting the
+b:browsefilter variable.  You would most likely set b:browsefilter in a
+filetype plugin, so that the browse dialog would contain entries related to
+the type of file you are currently editing.  Disadvantage: This makes it
+difficult to start editing a file of a different type.  To overcome this, you
+may want to add "All Files\t*.*\n" as the final filter, so that the user can
+still access any desired file.
+
+==============================================================================
+7. The current directory				*current-directory*
+
+You may use the |:cd| and |:lcd| commands to change to another directory, so
+you will not have to type that directory name in front of the file names.  It
+also makes a difference for executing external commands, e.g. ":!ls".
+
+Changing directory fails when the current buffer is modified, the '.' flag is
+present in 'cpoptions' and "!" is not used in the command.
+
+							*:cd* *E747* *E472*
+:cd[!]			On non-Unix systems: Print the current directory
+			name.  On Unix systems: Change the current directory
+			to the home directory.  Use |:pwd| to print the
+			current directory on all systems.
+
+:cd[!] {path}		Change the current directory to {path}.
+			If {path} is relative, it is searched for in the
+			directories listed in |'cdpath'|.
+			Does not change the meaning of an already opened file,
+			because its full path name is remembered.  Files from
+			the |arglist| may change though!
+			On MS-DOS this also changes the active drive.
+			To change to the directory of the current file: >
+				:cd %:h
+<
+							*:cd-* *E186*
+:cd[!] -		Change to the previous current directory (before the
+			previous ":cd {path}" command). {not in Vi}
+
+							*:chd* *:chdir*
+:chd[ir][!] [path]	Same as |:cd|.
+
+							*:lc* *:lcd*
+:lc[d][!] {path}	Like |:cd|, but only set the current directory for the
+			current window.  The current directory for other
+			windows is not changed. {not in Vi}
+
+							*:lch* *:lchdir*
+:lch[dir][!]		Same as |:lcd|. {not in Vi}
+
+							*:pw* *:pwd* *E187*
+:pw[d]			Print the current directory name.  {Vi: no pwd}
+			Also see |getcwd()|.
+
+So long as no |:lcd| command has been used, all windows share the same current
+directory.  Using a command to jump to another window doesn't change anything
+for the current directory.
+When a |:lcd| command has been used for a window, the specified directory
+becomes the current directory for that window.  Windows where the |:lcd|
+command has not been used stick to the global current directory.  When jumping
+to another window the current directory will become the last specified local
+current directory.  If none was specified, the global current directory is
+used.
+When a |:cd| command is used, the current window will lose his local current
+directory and will use the global current directory from now on.
+
+After using |:cd| the full path name will be used for reading and writing
+files.  On some networked file systems this may cause problems.  The result of
+using the full path name is that the file names currently in use will remain
+referring to the same file.  Example: If you have a file a:test and a
+directory a:vim the commands ":e test" ":cd vim" ":w" will overwrite the file
+a:test and not write a:vim/test.  But if you do ":w test" the file a:vim/test
+will be written, because you gave a new file name and did not refer to a
+filename before the ":cd".
+
+==============================================================================
+8. Editing binary files					*edit-binary*
+
+Although Vim was made to edit text files, it is possible to edit binary
+files.  The |-b| Vim argument (b for binary) makes Vim do file I/O in binary
+mode, and sets some options for editing binary files ('binary' on, 'textwidth'
+to 0, 'modeline' off, 'expandtab' off).  Setting the 'binary' option has the
+same effect.  Don't forget to do this before reading the file.
+
+There are a few things to remember when editing binary files:
+- When editing executable files the number of characters must not change.
+  Use only the "R" or "r" command to change text.  Do not delete characters
+  with "x" or by backspacing.
+- Set the 'textwidth' option to 0.  Otherwise lines will unexpectedly be
+  split in two.
+- When there are not many s, the lines will become very long.  If you
+  want to edit a line that does not fit on the screen reset the 'wrap' option.
+  Horizontal scrolling is used then.  If a line becomes too long (more than
+  about 32767 characters on the Amiga, much more on 32-bit systems, see
+  |limits|) you cannot edit that line.  The line will be split when reading
+  the file.  It is also possible that you get an "out of memory" error when
+  reading the file.
+- Make sure the 'binary' option is set BEFORE loading the
+  file.  Otherwise both   and  are considered to end a line
+  and when the file is written the  will be replaced with  .
+-  characters are shown on the screen as ^@.  You can enter them with
+  "CTRL-V CTRL-@" or "CTRL-V 000" {Vi cannot handle  characters in the
+  file}
+- To insert a  character in the file split up a line.  When writing the
+  buffer to a file a  will be written for the .
+- Vim normally appends an  at the end of the file if there is none.
+  Setting the 'binary' option prevents this.  If you want to add the final
+  , set the 'endofline' option.  You can also read the value of this
+  option to see if there was an  for the last line (you cannot see this
+  in the text).
+
+==============================================================================
+9. Encryption						*encryption*
+
+Vim is able to write files encrypted, and read them back.  The encrypted text
+cannot be read without the right key.
+{only available when compiled with the |+cryptv| feature}  *E833*
+
+The text in the swap file and the undo file is also encrypted.
+
+Note: The text in memory is not encrypted.  A system administrator may be able
+to see your text while you are editing it.  When filtering text with
+":!filter" or using ":w !command" the text is not encrypted, this may reveal
+it to others.  The 'viminfo' file is not encrypted.
+
+WARNING: If you make a typo when entering the key and then write the file and
+exit, the text will be lost!
+
+The normal way to work with encryption, is to use the ":X" command, which will
+ask you to enter a key.  A following write command will use that key to
+encrypt the file.  If you later edit the same file, Vim will ask you to enter
+a key.  If you type the same key as that was used for writing, the text will
+be readable again.  If you use a wrong key, it will be a mess.
+
+							*:X*
+:X	Prompt for an encryption key.  The typing is done without showing the
+	actual text, so that someone looking at the display won't see it.
+	The typed key is stored in the 'key' option, which is used to encrypt
+	the file when it is written.  The file will remain unchanged until you
+	write it.  See also |-x|.
+
+The value of the 'key' options is used when text is written.  When the option
+is not empty, the written file will be encrypted, using the value as the
+encryption key.  A magic number is prepended, so that Vim can recognize that
+the file is encrypted.
+
+To disable the encryption, reset the 'key' option to an empty value: >
+	:set key=
+
+You can use the 'cryptmethod' option to select the type of encryption, use one
+of these two: >
+	:setlocal cm=zip       " weak method, backwards compatible
+	:setlocal cm=blowfish  " strong method
+Do this before writing the file.  When reading an encrypted file it will be
+set automatically to the method used when that file was written.  You can
+change 'cryptmethod' before writing that file to change the method.
+To set the default method, used for new files, use one of these in your
+|vimrc| file: >
+	set cm=zip
+	set cm=blowfish
+
+When writing an undo file, the same key and method will be used for the text
+in the undo file. |persistent-undo|.
+
+						*E817* *E818* *E819* *E820*
+When encryption does not work properly, you would be able to write your text
+to a file and never be able to read it back.  Therefore a test is performed to
+check if the encryption works as expected.  If you get one of these errors
+don't write the file encrypted!  You need to rebuild the Vim binary to fix
+this.
+
+*E831* This is an internal error, "cannot happen".  If you can reproduce it,
+please report to the developers.
+
+When reading a file that has been encrypted and the 'key' option is not empty,
+it will be used for decryption.  If the value is empty, you will be prompted
+to enter the key.  If you don't enter a key, or you enter the wrong key, the
+file is edited without being decrypted.  There is no warning about using the
+wrong key (this makes brute force methods to find the key more difficult).
+
+If want to start reading a file that uses a different key, set the 'key'
+option to an empty string, so that Vim will prompt for a new one.  Don't use
+the ":set" command to enter the value, other people can read the command over
+your shoulder.
+
+Since the value of the 'key' option is supposed to be a secret, its value can
+never be viewed.  You should not set this option in a vimrc file.
+
+An encrypted file can be recognized by the "file" command, if you add these
+lines to "/etc/magic", "/usr/share/misc/magic" or wherever your system has the
+"magic" file: >
+     0	string	VimCrypt~	Vim encrypted file
+     >9	string	01	- "zip" cryptmethod
+     >9	string	02	- "blowfish" cryptmethod
+
+
+Notes:
+- Encryption is not possible when doing conversion with 'charconvert'.
+- Text you copy or delete goes to the numbered registers.  The registers can
+  be saved in the .viminfo file, where they could be read.  Change your
+  'viminfo' option to be safe.
+- Someone can type commands in Vim when you walk away for a moment, he should
+  not be able to get the key.
+- If you make a typing mistake when entering the key, you might not be able to
+  get your text back!
+- If you type the key with a ":set key=value" command, it can be kept in the
+  history, showing the 'key' value in a viminfo file.
+- There is never 100% safety.  The encryption in Vim has not been tested for
+  robustness.
+- The algorithm used is breakable.  A 4 character key in about one hour, a 6
+  character key in one day (on a Pentium 133 PC).  This requires that you know
+  some text that must appear in the file.  An expert can break it for any key.
+  When the text has been decrypted, this also means that the key can be
+  revealed, and other files encrypted with the same key can be decrypted.
+- Pkzip uses the same encryption, and US Govt has no objection to its export.
+  Pkzip's public file APPNOTE.TXT describes this algorithm in detail.
+- Vim originates from the Netherlands.  That is where the sources come from.
+  Thus the encryption code is not exported from the USA.
+
+==============================================================================
+10. Timestamps					*timestamp* *timestamps*
+
+Vim remembers the modification timestamp of a file when you begin editing it.
+This is used to avoid that you have two different versions of the same file
+(without you knowing this).
+
+After a shell command is run (|:!cmd| |suspend| |:read!| |K|) timestamps are
+compared for all buffers in a window.   Vim will run any associated
+|FileChangedShell| autocommands or display a warning for any files that have
+changed.  In the GUI this happens when Vim regains input focus.
+
+							*E321* *E462*
+If you want to automatically reload a file when it has been changed outside of
+Vim, set the 'autoread' option.  This doesn't work at the moment you write the
+file though, only when the file wasn't changed inside of Vim.
+
+Note that if a FileChangedShell autocommand is defined you will not get a
+warning message or prompt.  The autocommand is expected to handle this.
+
+There is no warning for a directory (e.g., with |netrw-browse|).  But you do
+get warned if you started editing a new file and it was created as a directory
+later.
+
+When Vim notices the timestamp of a file has changed, and the file is being
+edited in a buffer but has not changed, Vim checks if the contents of the file
+is equal.  This is done by reading the file again (into a hidden buffer, which
+is immediately deleted again) and comparing the text.  If the text is equal,
+you will get no warning.
+
+If you don't get warned often enough you can use the following command.
+
+							*:checkt* *:checktime*
+:checkt[ime]		Check if any buffers were changed outside of Vim.
+			This checks and warns you if you would end up with two
+			versions of a file.
+			If this is called from an autocommand, a ":global"
+			command or is not typed the actual check is postponed
+			until a moment the side effects (reloading the file)
+			would be harmless.
+			Each loaded buffer is checked for its associated file
+			being changed.  If the file was changed Vim will take
+			action.  If there are no changes in the buffer and
+			'autoread' is set, the buffer is reloaded.  Otherwise,
+			you are offered the choice of reloading the file.  If
+			the file was deleted you get an error message.
+			If the file previously didn't exist you get a warning
+			if it exists now.
+			Once a file has been checked the timestamp is reset,
+			you will not be warned again.
+
+:[N]checkt[ime] {filename}
+:[N]checkt[ime] [N]
+			Check the timestamp of a specific buffer.  The buffer
+			may be specified by name, number or with a pattern.
+
+
+							*E813* *E814*
+Vim will reload the buffer if you chose to.  If a window is visible that
+contains this buffer, the reloading will happen in the context of this window.
+Otherwise a special window is used, so that most autocommands will work.  You
+can't close this window.  A few other restrictions apply.  Best is to make
+sure nothing happens outside of the current buffer.  E.g., setting
+window-local options may end up in the wrong window.  Splitting the window,
+doing something there and closing it should be OK (if there are no side
+effects from other autocommands).  Closing unrelated windows and buffers will
+get you into trouble.
+
+Before writing a file the timestamp is checked.  If it has changed, Vim will
+ask if you really want to overwrite the file:
+
+	WARNING: The file has been changed since reading it!!!
+	Do you really want to write to it (y/n)?
+
+If you hit 'y' Vim will continue writing the file.  If you hit 'n' the write is
+aborted.  If you used ":wq" or "ZZ" Vim will not exit, you will get another
+chance to write the file.
+
+The message would normally mean that somebody has written to the file after
+the edit session started.  This could be another person, in which case you
+probably want to check if your changes to the file and the changes from the
+other person should be merged.  Write the file under another name and check for
+differences (the "diff" program can be used for this).
+
+It is also possible that you modified the file yourself, from another edit
+session or with another command (e.g., a filter command).  Then you will know
+which version of the file you want to keep.
+
+There is one situation where you get the message while there is nothing wrong:
+On a Win32 system on the day daylight saving time starts.  There is something
+in the Win32 libraries that confuses Vim about the hour time difference.  The
+problem goes away the next day.
+
+==============================================================================
+11. File Searching					*file-searching*
+
+{not available when compiled without the |+path_extra| feature}
+
+The file searching is currently used for the 'path', 'cdpath' and 'tags'
+options, for |finddir()| and |findfile()|.  Other commands use |wildcards|
+which is slightly different.
+
+There are three different types of searching:
+
+1) Downward search:					*starstar*
+   Downward search uses the wildcards '*', '**' and possibly others
+   supported by your operating system.  '*' and '**' are handled inside Vim,
+   so they work on all operating systems.  Note that "**" only acts as a
+   special wildcard when it is at the start of a name.
+
+   The usage of '*' is quite simple: It matches 0 or more characters.  In a
+   search pattern this would be ".*".  Note that the "." is not used for file
+   searching.
+
+   '**' is more sophisticated:
+      - It ONLY matches directories.
+      - It matches up to 30 directories deep by default, so you can use it to
+	search an entire directory tree
+      - The maximum number of levels matched can be given by appending a number
+	to '**'.
+	Thus '/usr/**2' can match: >
+		/usr
+		/usr/include
+		/usr/include/sys
+		/usr/include/g++
+		/usr/lib
+		/usr/lib/X11
+		....
+<	It does NOT match '/usr/include/g++/std' as this would be three
+	levels.
+	The allowed number range is 0 ('**0' is removed) to 100
+	If the given number is smaller than 0 it defaults to 30, if it's
+	bigger than 100 then 100 is used.  The system also has a limit on the
+	path length, usually 256 or 1024 bytes.
+      - '**' can only be at the end of the path or be followed by a path
+	separator or by a number and a path separator.
+
+   You can combine '*' and '**' in any order: >
+	/usr/**/sys/*
+	/usr/*tory/sys/**
+	/usr/**2/sys/*
+
+2) Upward search:
+   Here you can give a directory and then search the directory tree upward for
+   a file.  You could give stop-directories to limit the upward search.  The
+   stop-directories are appended to the path (for the 'path' option) or to
+   the filename (for the 'tags' option) with a ';'.  If you want several
+   stop-directories separate them with ';'.  If you want no stop-directory
+   ("search upward till the root directory) just use ';'. >
+	/usr/include/sys;/usr
+<   will search in: >
+	   /usr/include/sys
+	   /usr/include
+	   /usr
+<
+   If you use a relative path the upward search is started in Vim's current
+   directory or in the directory of the current file (if the relative path
+   starts with './' and 'd' is not included in 'cpoptions').
+
+   If Vim's current path is /u/user_x/work/release and you do >
+	:set path=include;/u/user_x
+<  and then search for a file with |gf| the file is searched in: >
+	/u/user_x/work/release/include
+	/u/user_x/work/include
+	/u/user_x/include
+
+3) Combined up/downward search:
+   If Vim's current path is /u/user_x/work/release and you do >
+	set path=**;/u/user_x
+<  and then search for a file with |gf| the file is searched in: >
+	/u/user_x/work/release/**
+	/u/user_x/work/**
+	/u/user_x/**
+<
+   BE CAREFUL!  This might consume a lot of time, as the search of
+   '/u/user_x/**' includes '/u/user_x/work/**' and
+   '/u/user_x/work/release/**'.  So '/u/user_x/work/release/**' is searched
+   three times and '/u/user_x/work/**' is searched twice.
+
+   In the above example you might want to set path to: >
+	:set path=**,/u/user_x/**
+<  This searches:
+	/u/user_x/work/release/** ~
+	/u/user_x/** ~
+   This searches the same directories, but in a different order.
+
+   Note that completion for ":find", ":sfind", and ":tabfind" commands do not
+   currently work with 'path' items that contain a url or use the double star
+   (/usr/**2) or upward search (;) notations. >
+
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/eval.txt b/share/vim/vim73/doc/eval.txt
new file mode 100644
index 0000000000..54035519e2
--- /dev/null
+++ b/share/vim/vim73/doc/eval.txt
@@ -0,0 +1,8324 @@
+*eval.txt*	For Vim version 7.3.  Last change: 2010 Aug 15
+
+
+		  VIM REFERENCE MANUAL	  by Bram Moolenaar
+
+
+Expression evaluation			*expression* *expr* *E15* *eval*
+
+Using expressions is introduced in chapter 41 of the user manual |usr_41.txt|.
+
+Note: Expression evaluation can be disabled at compile time.  If this has been
+done, the features in this document are not available.	See |+eval| and
+|no-eval-feature|.
+
+1.  Variables			|variables|
+    1.1 Variable types
+    1.2 Function references		|Funcref|
+    1.3 Lists				|Lists|
+    1.4 Dictionaries			|Dictionaries|
+    1.5 More about variables		|more-variables|
+2.  Expression syntax		|expression-syntax|
+3.  Internal variable		|internal-variables|
+4.  Builtin Functions		|functions|
+5.  Defining functions		|user-functions|
+6.  Curly braces names		|curly-braces-names|
+7.  Commands			|expression-commands|
+8.  Exception handling		|exception-handling|
+9.  Examples			|eval-examples|
+10. No +eval feature		|no-eval-feature|
+11. The sandbox			|eval-sandbox|
+12. Textlock			|textlock|
+
+{Vi does not have any of these commands}
+
+==============================================================================
+1. Variables						*variables*
+
+1.1 Variable types ~
+							*E712*
+There are six types of variables:
+
+Number		A 32 bit signed number.  |expr-number| *Number*
+		Examples:  -123  0x10  0177
+
+Float		A floating point number. |floating-point-format| *Float*
+		{only when compiled with the |+float| feature}
+		Examples: 123.456  1.15e-6  -1.1e3
+
+String		A NUL terminated string of 8-bit unsigned characters (bytes).
+		|expr-string| Examples: "ab\txx\"--"  'x-z''a,c'
+
+Funcref		A reference to a function |Funcref|.
+		Example: function("strlen")
+
+List		An ordered sequence of items |List|.
+		Example: [1, 2, ['a', 'b']]
+
+Dictionary	An associative, unordered array: Each entry has a key and a
+		value. |Dictionary|
+		Example: {'blue': "#0000ff", 'red': "#ff0000"}
+
+The Number and String types are converted automatically, depending on how they
+are used.
+
+Conversion from a Number to a String is by making the ASCII representation of
+the Number.  Examples: >
+	Number 123	-->	String "123"
+	Number 0	-->	String "0"
+	Number -1	-->	String "-1"
+							*octal*
+Conversion from a String to a Number is done by converting the first digits
+to a number.  Hexadecimal "0xf9" and Octal "017" numbers are recognized.  If
+the String doesn't start with digits, the result is zero.  Examples: >
+	String "456"	-->	Number 456
+	String "6bar"	-->	Number 6
+	String "foo"	-->	Number 0
+	String "0xf1"	-->	Number 241
+	String "0100"	-->	Number 64
+	String "-8"	-->	Number -8
+	String "+8"	-->	Number 0
+
+To force conversion from String to Number, add zero to it: >
+	:echo "0100" + 0
+<	64 ~
+
+To avoid a leading zero to cause octal conversion, or for using a different
+base, use |str2nr()|.
+
+For boolean operators Numbers are used.  Zero is FALSE, non-zero is TRUE.
+
+Note that in the command >
+	:if "foo"
+"foo" is converted to 0, which means FALSE.  To test for a non-empty string,
+use strlen(): >
+	:if strlen("foo")
+<				*E745* *E728* *E703* *E729* *E730* *E731*
+List, Dictionary and Funcref types are not automatically converted.
+
+							*E805* *E806* *E808*
+When mixing Number and Float the Number is converted to Float.	Otherwise
+there is no automatic conversion of Float.  You can use str2float() for String
+to Float, printf() for Float to String and float2nr() for Float to Number.
+
+						*E706* *sticky-type-checking*
+You will get an error if you try to change the type of a variable.  You need
+to |:unlet| it first to avoid this error.  String and Number are considered
+equivalent though, as well are Float and Number.  Consider this sequence of
+commands: >
+	:let l = "string"
+	:let l = 44		" changes type from String to Number
+	:let l = [1, 2, 3]	" error!  l is still a Number
+	:let l = 4.4		" changes type from Number to Float
+	:let l = "string"	" error!
+
+
+1.2 Function references ~
+					*Funcref* *E695* *E718*
+A Funcref variable is obtained with the |function()| function.	It can be used
+in an expression in the place of a function name, before the parenthesis
+around the arguments, to invoke the function it refers to.  Example: >
+
+	:let Fn = function("MyFunc")
+	:echo Fn()
+<							*E704* *E705* *E707*
+A Funcref variable must start with a capital, "s:", "w:", "t:" or "b:".  You
+cannot have both a Funcref variable and a function with the same name.
+
+A special case is defining a function and directly assigning its Funcref to a
+Dictionary entry.  Example: >
+	:function dict.init() dict
+	:   let self.val = 0
+	:endfunction
+
+The key of the Dictionary can start with a lower case letter.  The actual
+function name is not used here.  Also see |numbered-function|.
+
+A Funcref can also be used with the |:call| command: >
+	:call Fn()
+	:call dict.init()
+
+The name of the referenced function can be obtained with |string()|. >
+	:let func = string(Fn)
+
+You can use |call()| to invoke a Funcref and use a list variable for the
+arguments: >
+	:let r = call(Fn, mylist)
+
+
+1.3 Lists ~
+							*List* *Lists* *E686*
+A List is an ordered sequence of items.  An item can be of any type.  Items
+can be accessed by their index number.	Items can be added and removed at any
+position in the sequence.
+
+
+List creation ~
+							*E696* *E697*
+A List is created with a comma separated list of items in square brackets.
+Examples: >
+	:let mylist = [1, two, 3, "four"]
+	:let emptylist = []
+
+An item can be any expression.	Using a List for an item creates a
+List of Lists: >
+	:let nestlist = [[11, 12], [21, 22], [31, 32]]
+
+An extra comma after the last item is ignored.
+
+
+List index ~
+							*list-index* *E684*
+An item in the List can be accessed by putting the index in square brackets
+after the List.  Indexes are zero-based, thus the first item has index zero. >
+	:let item = mylist[0]		" get the first item: 1
+	:let item = mylist[2]		" get the third item: 3
+
+When the resulting item is a list this can be repeated: >
+	:let item = nestlist[0][1]	" get the first list, second item: 12
+<
+A negative index is counted from the end.  Index -1 refers to the last item in
+the List, -2 to the last but one item, etc. >
+	:let last = mylist[-1]		" get the last item: "four"
+
+To avoid an error for an invalid index use the |get()| function.  When an item
+is not available it returns zero or the default value you specify: >
+	:echo get(mylist, idx)
+	:echo get(mylist, idx, "NONE")
+
+
+List concatenation ~
+
+Two lists can be concatenated with the "+" operator: >
+	:let longlist = mylist + [5, 6]
+	:let mylist += [7, 8]
+
+To prepend or append an item turn the item into a list by putting [] around
+it.  To change a list in-place see |list-modification| below.
+
+
+Sublist ~
+
+A part of the List can be obtained by specifying the first and last index,
+separated by a colon in square brackets: >
+	:let shortlist = mylist[2:-1]	" get List [3, "four"]
+
+Omitting the first index is similar to zero.  Omitting the last index is
+similar to -1. >
+	:let endlist = mylist[2:]	" from item 2 to the end: [3, "four"]
+	:let shortlist = mylist[2:2]	" List with one item: [3]
+	:let otherlist = mylist[:]	" make a copy of the List
+
+If the first index is beyond the last item of the List or the second item is
+before the first item, the result is an empty list.  There is no error
+message.
+
+If the second index is equal to or greater than the length of the list the
+length minus one is used: >
+	:let mylist = [0, 1, 2, 3]
+	:echo mylist[2:8]		" result: [2, 3]
+
+NOTE: mylist[s:e] means using the variable "s:e" as index.  Watch out for
+using a single letter variable before the ":".	Insert a space when needed:
+mylist[s : e].
+
+
+List identity ~
+							*list-identity*
+When variable "aa" is a list and you assign it to another variable "bb", both
+variables refer to the same list.  Thus changing the list "aa" will also
+change "bb": >
+	:let aa = [1, 2, 3]
+	:let bb = aa
+	:call add(aa, 4)
+	:echo bb
+<	[1, 2, 3, 4]
+
+Making a copy of a list is done with the |copy()| function.  Using [:] also
+works, as explained above.  This creates a shallow copy of the list: Changing
+a list item in the list will also change the item in the copied list: >
+	:let aa = [[1, 'a'], 2, 3]
+	:let bb = copy(aa)
+	:call add(aa, 4)
+	:let aa[0][1] = 'aaa'
+	:echo aa
+<	[[1, aaa], 2, 3, 4] >
+	:echo bb
+<	[[1, aaa], 2, 3]
+
+To make a completely independent list use |deepcopy()|.  This also makes a
+copy of the values in the list, recursively.  Up to a hundred levels deep.
+
+The operator "is" can be used to check if two variables refer to the same
+List.  "isnot" does the opposite.  In contrast "==" compares if two lists have
+the same value. >
+	:let alist = [1, 2, 3]
+	:let blist = [1, 2, 3]
+	:echo alist is blist
+<	0 >
+	:echo alist == blist
+<	1
+
+Note about comparing lists: Two lists are considered equal if they have the
+same length and all items compare equal, as with using "==".  There is one
+exception: When comparing a number with a string they are considered
+different.  There is no automatic type conversion, as with using "==" on
+variables.  Example: >
+	echo 4 == "4"
+<	1 >
+	echo [4] == ["4"]
+<	0
+
+Thus comparing Lists is more strict than comparing numbers and strings.  You
+can compare simple values this way too by putting them in a list: >
+
+	:let a = 5
+	:let b = "5"
+	:echo a == b
+<	1 >
+	:echo [a] == [b]
+<	0
+
+
+List unpack ~
+
+To unpack the items in a list to individual variables, put the variables in
+square brackets, like list items: >
+	:let [var1, var2] = mylist
+
+When the number of variables does not match the number of items in the list
+this produces an error.  To handle any extra items from the list append ";"
+and a variable name: >
+	:let [var1, var2; rest] = mylist
+
+This works like: >
+	:let var1 = mylist[0]
+	:let var2 = mylist[1]
+	:let rest = mylist[2:]
+
+Except that there is no error if there are only two items.  "rest" will be an
+empty list then.
+
+
+List modification ~
+							*list-modification*
+To change a specific item of a list use |:let| this way: >
+	:let list[4] = "four"
+	:let listlist[0][3] = item
+
+To change part of a list you can specify the first and last item to be
+modified.  The value must at least have the number of items in the range: >
+	:let list[3:5] = [3, 4, 5]
+
+Adding and removing items from a list is done with functions.  Here are a few
+examples: >
+	:call insert(list, 'a')		" prepend item 'a'
+	:call insert(list, 'a', 3)	" insert item 'a' before list[3]
+	:call add(list, "new")		" append String item
+	:call add(list, [1, 2])		" append a List as one new item
+	:call extend(list, [1, 2])	" extend the list with two more items
+	:let i = remove(list, 3)	" remove item 3
+	:unlet list[3]			" idem
+	:let l = remove(list, 3, -1)	" remove items 3 to last item
+	:unlet list[3 : ]		" idem
+	:call filter(list, 'v:val !~ "x"')  " remove items with an 'x'
+
+Changing the order of items in a list: >
+	:call sort(list)		" sort a list alphabetically
+	:call reverse(list)		" reverse the order of items
+
+
+For loop ~
+
+The |:for| loop executes commands for each item in a list.  A variable is set
+to each item in the list in sequence.  Example: >
+	:for item in mylist
+	:   call Doit(item)
+	:endfor
+
+This works like: >
+	:let index = 0
+	:while index < len(mylist)
+	:   let item = mylist[index]
+	:   :call Doit(item)
+	:   let index = index + 1
+	:endwhile
+
+Note that all items in the list should be of the same type, otherwise this
+results in error |E706|.  To avoid this |:unlet| the variable at the end of
+the loop.
+
+If all you want to do is modify each item in the list then the |map()|
+function will be a simpler method than a for loop.
+
+Just like the |:let| command, |:for| also accepts a list of variables.	This
+requires the argument to be a list of lists. >
+	:for [lnum, col] in [[1, 3], [2, 8], [3, 0]]
+	:   call Doit(lnum, col)
+	:endfor
+
+This works like a |:let| command is done for each list item.  Again, the types
+must remain the same to avoid an error.
+
+It is also possible to put remaining items in a List variable: >
+	:for [i, j; rest] in listlist
+	:   call Doit(i, j)
+	:   if !empty(rest)
+	:      echo "remainder: " . string(rest)
+	:   endif
+	:endfor
+
+
+List functions ~
+						*E714*
+Functions that are useful with a List: >
+	:let r = call(funcname, list)	" call a function with an argument list
+	:if empty(list)			" check if list is empty
+	:let l = len(list)		" number of items in list
+	:let big = max(list)		" maximum value in list
+	:let small = min(list)		" minimum value in list
+	:let xs = count(list, 'x')	" count nr of times 'x' appears in list
+	:let i = index(list, 'x')	" index of first 'x' in list
+	:let lines = getline(1, 10)	" get ten text lines from buffer
+	:call append('$', lines)	" append text lines in buffer
+	:let list = split("a b c")	" create list from items in a string
+	:let string = join(list, ', ')	" create string from list items
+	:let s = string(list)		" String representation of list
+	:call map(list, '">> " . v:val')  " prepend ">> " to each item
+
+Don't forget that a combination of features can make things simple.  For
+example, to add up all the numbers in a list: >
+	:exe 'let sum = ' . join(nrlist, '+')
+
+
+1.4 Dictionaries ~
+						*Dictionaries* *Dictionary*
+A Dictionary is an associative array: Each entry has a key and a value.  The
+entry can be located with the key.  The entries are stored without a specific
+ordering.
+
+
+Dictionary creation ~
+						*E720* *E721* *E722* *E723*
+A Dictionary is created with a comma separated list of entries in curly
+braces.  Each entry has a key and a value, separated by a colon.  Each key can
+only appear once.  Examples: >
+	:let mydict = {1: 'one', 2: 'two', 3: 'three'}
+	:let emptydict = {}
+<							*E713* *E716* *E717*
+A key is always a String.  You can use a Number, it will be converted to a
+String automatically.  Thus the String '4' and the number 4 will find the same
+entry.	Note that the String '04' and the Number 04 are different, since the
+Number will be converted to the String '4'.
+
+A value can be any expression.	Using a Dictionary for a value creates a
+nested Dictionary: >
+	:let nestdict = {1: {11: 'a', 12: 'b'}, 2: {21: 'c'}}
+
+An extra comma after the last entry is ignored.
+
+
+Accessing entries ~
+
+The normal way to access an entry is by putting the key in square brackets: >
+	:let val = mydict["one"]
+	:let mydict["four"] = 4
+
+You can add new entries to an existing Dictionary this way, unlike Lists.
+
+For keys that consist entirely of letters, digits and underscore the following
+form can be used |expr-entry|: >
+	:let val = mydict.one
+	:let mydict.four = 4
+
+Since an entry can be any type, also a List and a Dictionary, the indexing and
+key lookup can be repeated: >
+	:echo dict.key[idx].key
+
+
+Dictionary to List conversion ~
+
+You may want to loop over the entries in a dictionary.	For this you need to
+turn the Dictionary into a List and pass it to |:for|.
+
+Most often you want to loop over the keys, using the |keys()| function: >
+	:for key in keys(mydict)
+	:   echo key . ': ' . mydict[key]
+	:endfor
+
+The List of keys is unsorted.  You may want to sort them first: >
+	:for key in sort(keys(mydict))
+
+To loop over the values use the |values()| function:  >
+	:for v in values(mydict)
+	:   echo "value: " . v
+	:endfor
+
+If you want both the key and the value use the |items()| function.  It returns
+a List in which each item is a	List with two items, the key and the value: >
+	:for [key, value] in items(mydict)
+	:   echo key . ': ' . value
+	:endfor
+
+
+Dictionary identity ~
+							*dict-identity*
+Just like Lists you need to use |copy()| and |deepcopy()| to make a copy of a
+Dictionary.  Otherwise, assignment results in referring to the same
+Dictionary: >
+	:let onedict = {'a': 1, 'b': 2}
+	:let adict = onedict
+	:let adict['a'] = 11
+	:echo onedict['a']
+	11
+
+Two Dictionaries compare equal if all the key-value pairs compare equal.  For
+more info see |list-identity|.
+
+
+Dictionary modification ~
+							*dict-modification*
+To change an already existing entry of a Dictionary, or to add a new entry,
+use |:let| this way: >
+	:let dict[4] = "four"
+	:let dict['one'] = item
+
+Removing an entry from a Dictionary is done with |remove()| or |:unlet|.
+Three ways to remove the entry with key "aaa" from dict: >
+	:let i = remove(dict, 'aaa')
+	:unlet dict.aaa
+	:unlet dict['aaa']
+
+Merging a Dictionary with another is done with |extend()|: >
+	:call extend(adict, bdict)
+This extends adict with all entries from bdict.  Duplicate keys cause entries
+in adict to be overwritten.  An optional third argument can change this.
+Note that the order of entries in a Dictionary is irrelevant, thus don't
+expect ":echo adict" to show the items from bdict after the older entries in
+adict.
+
+Weeding out entries from a Dictionary can be done with |filter()|: >
+	:call filter(dict, 'v:val =~ "x"')
+This removes all entries from "dict" with a value not matching 'x'.
+
+
+Dictionary function ~
+					*Dictionary-function* *self* *E725*
+When a function is defined with the "dict" attribute it can be used in a
+special way with a dictionary.	Example: >
+	:function Mylen() dict
+	:   return len(self.data)
+	:endfunction
+	:let mydict = {'data': [0, 1, 2, 3], 'len': function("Mylen")}
+	:echo mydict.len()
+
+This is like a method in object oriented programming.  The entry in the
+Dictionary is a |Funcref|.  The local variable "self" refers to the dictionary
+the function was invoked from.
+
+It is also possible to add a function without the "dict" attribute as a
+Funcref to a Dictionary, but the "self" variable is not available then.
+
+				*numbered-function* *anonymous-function*
+To avoid the extra name for the function it can be defined and directly
+assigned to a Dictionary in this way: >
+	:let mydict = {'data': [0, 1, 2, 3]}
+	:function mydict.len() dict
+	:   return len(self.data)
+	:endfunction
+	:echo mydict.len()
+
+The function will then get a number and the value of dict.len is a |Funcref|
+that references this function.	The function can only be used through a
+|Funcref|.  It will automatically be deleted when there is no |Funcref|
+remaining that refers to it.
+
+It is not necessary to use the "dict" attribute for a numbered function.
+
+If you get an error for a numbered function, you can find out what it is with
+a trick.  Assuming the function is 42, the command is: >
+	:function {42}
+
+
+Functions for Dictionaries ~
+							*E715*
+Functions that can be used with a Dictionary: >
+	:if has_key(dict, 'foo')	" TRUE if dict has entry with key "foo"
+	:if empty(dict)			" TRUE if dict is empty
+	:let l = len(dict)		" number of items in dict
+	:let big = max(dict)		" maximum value in dict
+	:let small = min(dict)		" minimum value in dict
+	:let xs = count(dict, 'x')	" count nr of times 'x' appears in dict
+	:let s = string(dict)		" String representation of dict
+	:call map(dict, '">> " . v:val')  " prepend ">> " to each item
+
+
+1.5 More about variables ~
+							*more-variables*
+If you need to know the type of a variable or expression, use the |type()|
+function.
+
+When the '!' flag is included in the 'viminfo' option, global variables that
+start with an uppercase letter, and don't contain a lowercase letter, are
+stored in the viminfo file |viminfo-file|.
+
+When the 'sessionoptions' option contains "global", global variables that
+start with an uppercase letter and contain at least one lowercase letter are
+stored in the session file |session-file|.
+
+variable name		can be stored where ~
+my_var_6		not
+My_Var_6		session file
+MY_VAR_6		viminfo file
+
+
+It's possible to form a variable name with curly braces, see
+|curly-braces-names|.
+
+==============================================================================
+2. Expression syntax					*expression-syntax*
+
+Expression syntax summary, from least to most significant:
+
+|expr1| expr2 ? expr1 : expr1	if-then-else
+
+|expr2|	expr3 || expr3 ..	logical OR
+
+|expr3|	expr4 && expr4 ..	logical AND
+
+|expr4|	expr5 == expr5		equal
+	expr5 != expr5		not equal
+	expr5 >	 expr5		greater than
+	expr5 >= expr5		greater than or equal
+	expr5 <	 expr5		smaller than
+	expr5 <= expr5		smaller than or equal
+	expr5 =~ expr5		regexp matches
+	expr5 !~ expr5		regexp doesn't match
+
+	expr5 ==? expr5		equal, ignoring case
+	expr5 ==# expr5		equal, match case
+	etc.			As above, append ? for ignoring case, # for
+				matching case
+
+	expr5 is expr5		same |List| instance
+	expr5 isnot expr5	different |List| instance
+
+|expr5|	expr6 +	 expr6 ..	number addition or list concatenation
+	expr6 -	 expr6 ..	number subtraction
+	expr6 .	 expr6 ..	string concatenation
+
+|expr6|	expr7 *	 expr7 ..	number multiplication
+	expr7 /	 expr7 ..	number division
+	expr7 %	 expr7 ..	number modulo
+
+|expr7|	! expr7			logical NOT
+	- expr7			unary minus
+	+ expr7			unary plus
+
+
+|expr8|	expr8[expr1]		byte of a String or item of a |List|
+	expr8[expr1 : expr1]	substring of a String or sublist of a |List|
+	expr8.name		entry in a |Dictionary|
+	expr8(expr1, ...)	function call with |Funcref| variable
+
+|expr9| number			number constant
+	"string"		string constant, backslash is special
+	'string'		string constant, ' is doubled
+	[expr1, ...]		|List|
+	{expr1: expr1, ...}	|Dictionary|
+	&option			option value
+	(expr1)			nested expression
+	variable		internal variable
+	va{ria}ble		internal variable with curly braces
+	$VAR			environment variable
+	@r			contents of register 'r'
+	function(expr1, ...)	function call
+	func{ti}on(expr1, ...)	function call with curly braces
+
+
+".." indicates that the operations in this level can be concatenated.
+Example: >
+	&nu || &list && &shell == "csh"
+
+All expressions within one level are parsed from left to right.
+
+
+expr1							*expr1* *E109*
+-----
+
+expr2 ? expr1 : expr1
+
+The expression before the '?' is evaluated to a number.  If it evaluates to
+non-zero, the result is the value of the expression between the '?' and ':',
+otherwise the result is the value of the expression after the ':'.
+Example: >
+	:echo lnum == 1 ? "top" : lnum
+
+Since the first expression is an "expr2", it cannot contain another ?:.  The
+other two expressions can, thus allow for recursive use of ?:.
+Example: >
+	:echo lnum == 1 ? "top" : lnum == 1000 ? "last" : lnum
+
+To keep this readable, using |line-continuation| is suggested: >
+	:echo lnum == 1
+	:\	? "top"
+	:\	: lnum == 1000
+	:\		? "last"
+	:\		: lnum
+
+You should always put a space before the ':', otherwise it can be mistaken for
+use in a variable such as "a:1".
+
+
+expr2 and expr3						*expr2* *expr3*
+---------------
+
+					*expr-barbar* *expr-&&*
+The "||" and "&&" operators take one argument on each side.  The arguments
+are (converted to) Numbers.  The result is:
+
+	 input				 output ~
+n1		n2		n1 || n2	n1 && n2 ~
+zero		zero		zero		zero
+zero		non-zero	non-zero	zero
+non-zero	zero		non-zero	zero
+non-zero	non-zero	non-zero	non-zero
+
+The operators can be concatenated, for example: >
+
+	&nu || &list && &shell == "csh"
+
+Note that "&&" takes precedence over "||", so this has the meaning of: >
+
+	&nu || (&list && &shell == "csh")
+
+Once the result is known, the expression "short-circuits", that is, further
+arguments are not evaluated.  This is like what happens in C.  For example: >
+
+	let a = 1
+	echo a || b
+
+This is valid even if there is no variable called "b" because "a" is non-zero,
+so the result must be non-zero.  Similarly below: >
+
+	echo exists("b") && b == "yes"
+
+This is valid whether "b" has been defined or not.  The second clause will
+only be evaluated if "b" has been defined.
+
+
+expr4							*expr4*
+-----
+
+expr5 {cmp} expr5
+
+Compare two expr5 expressions, resulting in a 0 if it evaluates to false, or 1
+if it evaluates to true.
+
+			*expr-==*  *expr-!=*  *expr->*	 *expr->=*
+			*expr-<*   *expr-<=*  *expr-=~*  *expr-!~*
+			*expr-==#* *expr-!=#* *expr->#*  *expr->=#*
+			*expr-<#*  *expr-<=#* *expr-=~#* *expr-!~#*
+			*expr-==?* *expr-!=?* *expr->?*  *expr->=?*
+			*expr-		>#		>?
+greater than or equal	>=		>=#		>=?
+smaller than		<		<#		
+	1 . 90 + 90.0
+As: >
+	(1 . 90) + 90.0
+That works, since the String "190" is automatically converted to the Number
+190, which can be added to the Float 90.0.  However: >
+	1 . 90 * 90.0
+Should be read as: >
+	1 . (90 * 90.0)
+Since '.' has lower precedence than '*'.  This does NOT work, since this
+attempts to concatenate a Float and a String.
+
+When dividing a Number by zero the result depends on the value:
+	  0 / 0  = -0x80000000	(like NaN for Float)
+	 >0 / 0  =  0x7fffffff	(like positive infinity)
+	 <0 / 0  = -0x7fffffff	(like negative infinity)
+	(before Vim 7.2 it was always 0x7fffffff)
+
+When the righthand side of '%' is zero, the result is 0.
+
+None of these work for |Funcref|s.
+
+. and % do not work for Float. *E804*
+
+
+expr7							*expr7*
+-----
+! expr7			logical NOT		*expr-!*
+- expr7			unary minus		*expr-unary--*
++ expr7			unary plus		*expr-unary-+*
+
+For '!' non-zero becomes zero, zero becomes one.
+For '-' the sign of the number is changed.
+For '+' the number is unchanged.
+
+A String will be converted to a Number first.
+
+These three can be repeated and mixed.	Examples:
+	!-1	    == 0
+	!!8	    == 1
+	--9	    == 9
+
+
+expr8							*expr8*
+-----
+expr8[expr1]		item of String or |List|	*expr-[]* *E111*
+
+If expr8 is a Number or String this results in a String that contains the
+expr1'th single byte from expr8.  expr8 is used as a String, expr1 as a
+Number.  This doesn't recognize multi-byte encodings, see |byteidx()| for
+an alternative.
+
+Index zero gives the first character.  This is like it works in C.  Careful:
+text column numbers start with one!  Example, to get the character under the
+cursor: >
+	:let c = getline(".")[col(".") - 1]
+
+If the length of the String is less than the index, the result is an empty
+String.  A negative index always results in an empty string (reason: backwards
+compatibility).  Use [-1:] to get the last byte.
+
+If expr8 is a |List| then it results the item at index expr1.  See |list-index|
+for possible index values.  If the index is out of range this results in an
+error.	Example: >
+	:let item = mylist[-1]		" get last item
+
+Generally, if a |List| index is equal to or higher than the length of the
+|List|, or more negative than the length of the |List|, this results in an
+error.
+
+
+expr8[expr1a : expr1b]	substring or sublist		*expr-[:]*
+
+If expr8 is a Number or String this results in the substring with the bytes
+from expr1a to and including expr1b.  expr8 is used as a String, expr1a and
+expr1b are used as a Number.  This doesn't recognize multi-byte encodings, see
+|byteidx()| for computing the indexes.
+
+If expr1a is omitted zero is used.  If expr1b is omitted the length of the
+string minus one is used.
+
+A negative number can be used to measure from the end of the string.  -1 is
+the last character, -2 the last but one, etc.
+
+If an index goes out of range for the string characters are omitted.  If
+expr1b is smaller than expr1a the result is an empty string.
+
+Examples: >
+	:let c = name[-1:]		" last byte of a string
+	:let c = name[-2:-2]		" last but one byte of a string
+	:let s = line(".")[4:]		" from the fifth byte to the end
+	:let s = s[:-3]			" remove last two bytes
+<
+							*sublist* *slice*
+If expr8 is a |List| this results in a new |List| with the items indicated by
+the indexes expr1a and expr1b.	This works like with a String, as explained
+just above, except that indexes out of range cause an error.  Examples: >
+	:let l = mylist[:3]		" first four items
+	:let l = mylist[4:4]		" List with one item
+	:let l = mylist[:]		" shallow copy of a List
+
+Using expr8[expr1] or expr8[expr1a : expr1b] on a |Funcref| results in an
+error.
+
+
+expr8.name		entry in a |Dictionary|		*expr-entry*
+
+If expr8 is a |Dictionary| and it is followed by a dot, then the following
+name will be used as a key in the |Dictionary|.  This is just like:
+expr8[name].
+
+The name must consist of alphanumeric characters, just like a variable name,
+but it may start with a number.  Curly braces cannot be used.
+
+There must not be white space before or after the dot.
+
+Examples: >
+	:let dict = {"one": 1, 2: "two"}
+	:echo dict.one
+	:echo dict .2
+
+Note that the dot is also used for String concatenation.  To avoid confusion
+always put spaces around the dot for String concatenation.
+
+
+expr8(expr1, ...)	|Funcref| function call
+
+When expr8 is a |Funcref| type variable, invoke the function it refers to.
+
+
+
+							*expr9*
+number
+------
+number			number constant		*expr-number*
+
+Decimal, Hexadecimal (starting with 0x or 0X), or Octal (starting with 0).
+
+						*floating-point-format*
+Floating point numbers can be written in two forms:
+
+	[-+]{N}.{M}
+	[-+]{N}.{M}e[-+]{exp}
+
+{N} and {M} are numbers.  Both {N} and {M} must be present and can only
+contain digits.
+[-+] means there is an optional plus or minus sign.
+{exp} is the exponent, power of 10.
+Only a decimal point is accepted, not a comma.	No matter what the current
+locale is.
+{only when compiled with the |+float| feature}
+
+Examples:
+	123.456
+	+0.0001
+	55.0
+	-0.123
+	1.234e03
+	1.0E-6
+	-3.1416e+88
+
+These are INVALID:
+	3.		empty {M}
+	1e40		missing .{M}
+
+							*float-pi* *float-e*
+A few useful values to copy&paste: >
+	:let pi = 3.14159265359
+	:let e  = 2.71828182846
+
+Rationale:
+Before floating point was introduced, the text "123.456" was interpreted as
+the two numbers "123" and "456", both converted to a string and concatenated,
+resulting in the string "123456".  Since this was considered pointless, and we
+could not find it intentionally being used in Vim scripts, this backwards
+incompatibility was accepted in favor of being able to use the normal notation
+for floating point numbers.
+
+						*floating-point-precision*
+The precision and range of floating points numbers depends on what "double"
+means in the library Vim was compiled with.  There is no way to change this at
+runtime.
+
+The default for displaying a |Float| is to use 6 decimal places, like using
+printf("%g", f).  You can select something else when using the |printf()|
+function.  Example: >
+	:echo printf('%.15e', atan(1))
+<	7.853981633974483e-01
+
+
+
+string							*expr-string* *E114*
+------
+"string"		string constant		*expr-quote*
+
+Note that double quotes are used.
+
+A string constant accepts these special characters:
+\...	three-digit octal number (e.g., "\316")
+\..	two-digit octal number (must be followed by non-digit)
+\.	one-digit octal number (must be followed by non-digit)
+\x..	byte specified with two hex numbers (e.g., "\x1f")
+\x.	byte specified with one hex number (must be followed by non-hex char)
+\X..	same as \x..
+\X.	same as \x.
+\u....	character specified with up to 4 hex numbers, stored according to the
+	current value of 'encoding' (e.g., "\u02a4")
+\U....	same as \u....
+\b	backspace 
+\e	escape 
+\f	formfeed 
+\n	newline 
+\r	return 
+\t	tab 
+\\	backslash
+\"	double quote
+\	Special key named "xxx".  e.g. "\" for CTRL-W.  This is for use
+	in mappings, the 0x80 byte is escaped.  Don't use  to get a
+	utf-8 character, use \uxxxx as mentioned above.
+
+Note that "\xff" is stored as the byte 255, which may be invalid in some
+encodings.  Use "\u00ff" to store character 255 according to the current value
+of 'encoding'.
+
+Note that "\000" and "\x00" force the end of the string.
+
+
+literal-string						*literal-string* *E115*
+---------------
+'string'		string constant			*expr-'*
+
+Note that single quotes are used.
+
+This string is taken as it is.	No backslashes are removed or have a special
+meaning.  The only exception is that two quotes stand for one quote.
+
+Single quoted strings are useful for patterns, so that backslashes do not need
+to be doubled.	These two commands are equivalent: >
+	if a =~ "\\s*"
+	if a =~ '\s*'
+
+
+option						*expr-option* *E112* *E113*
+------
+&option			option value, local value if possible
+&g:option		global option value
+&l:option		local option value
+
+Examples: >
+	echo "tabstop is " . &tabstop
+	if &insertmode
+
+Any option name can be used here.  See |options|.  When using the local value
+and there is no buffer-local or window-local value, the global value is used
+anyway.
+
+
+register						*expr-register* *@r*
+--------
+@r			contents of register 'r'
+
+The result is the contents of the named register, as a single string.
+Newlines are inserted where required.  To get the contents of the unnamed
+register use @" or @@.	See |registers| for an explanation of the available
+registers.
+
+When using the '=' register you get the expression itself, not what it
+evaluates to.  Use |eval()| to evaluate it.
+
+
+nesting							*expr-nesting* *E110*
+-------
+(expr1)			nested expression
+
+
+environment variable					*expr-env*
+--------------------
+$VAR			environment variable
+
+The String value of any environment variable.  When it is not defined, the
+result is an empty string.
+						*expr-env-expand*
+Note that there is a difference between using $VAR directly and using
+expand("$VAR").  Using it directly will only expand environment variables that
+are known inside the current Vim session.  Using expand() will first try using
+the environment variables known inside the current Vim session.  If that
+fails, a shell will be used to expand the variable.  This can be slow, but it
+does expand all variables that the shell knows about.  Example: >
+	:echo $version
+	:echo expand("$version")
+The first one probably doesn't echo anything, the second echoes the $version
+variable (if your shell supports it).
+
+
+internal variable					*expr-variable*
+-----------------
+variable		internal variable
+See below |internal-variables|.
+
+
+function call		*expr-function* *E116* *E118* *E119* *E120*
+-------------
+function(expr1, ...)	function call
+See below |functions|.
+
+
+==============================================================================
+3. Internal variable				*internal-variables* *E121*
+									*E461*
+An internal variable name can be made up of letters, digits and '_'.  But it
+cannot start with a digit.  It's also possible to use curly braces, see
+|curly-braces-names|.
+
+An internal variable is created with the ":let" command |:let|.
+An internal variable is explicitly destroyed with the ":unlet" command
+|:unlet|.
+Using a name that is not an internal variable or refers to a variable that has
+been destroyed results in an error.
+
+There are several name spaces for variables.  Which one is to be used is
+specified by what is prepended:
+
+		(nothing) In a function: local to a function; otherwise: global
+|buffer-variable|    b:	  Local to the current buffer.
+|window-variable|    w:	  Local to the current window.
+|tabpage-variable|   t:	  Local to the current tab page.
+|global-variable|    g:	  Global.
+|local-variable|     l:	  Local to a function.
+|script-variable|    s:	  Local to a |:source|'ed Vim script.
+|function-argument|  a:	  Function argument (only inside a function).
+|vim-variable|	     v:	  Global, predefined by Vim.
+
+The scope name by itself can be used as a |Dictionary|.  For example, to
+delete all script-local variables: >
+	:for k in keys(s:)
+	:    unlet s:[k]
+	:endfor
+<
+						*buffer-variable* *b:var*
+A variable name that is preceded with "b:" is local to the current buffer.
+Thus you can have several "b:foo" variables, one for each buffer.
+This kind of variable is deleted when the buffer is wiped out or deleted with
+|:bdelete|.
+
+One local buffer variable is predefined:
+					*b:changedtick-variable* *changetick*
+b:changedtick	The total number of changes to the current buffer.  It is
+		incremented for each change.  An undo command is also a change
+		in this case.  This can be used to perform an action only when
+		the buffer has changed.  Example: >
+		    :if my_changedtick != b:changedtick
+		    :	let my_changedtick = b:changedtick
+		    :	call My_Update()
+		    :endif
+<
+						*window-variable* *w:var*
+A variable name that is preceded with "w:" is local to the current window.  It
+is deleted when the window is closed.
+
+						*tabpage-variable* *t:var*
+A variable name that is preceded with "t:" is local to the current tab page,
+It is deleted when the tab page is closed. {not available when compiled
+without the |+windows| feature}
+
+						*global-variable* *g:var*
+Inside functions global variables are accessed with "g:".  Omitting this will
+access a variable local to a function.	But "g:" can also be used in any other
+place if you like.
+
+						*local-variable* *l:var*
+Inside functions local variables are accessed without prepending anything.
+But you can also prepend "l:" if you like.  However, without prepending "l:"
+you may run into reserved variable names.  For example "count".  By itself it
+refers to "v:count".  Using "l:count" you can have a local variable with the
+same name.
+
+						*script-variable* *s:var*
+In a Vim script variables starting with "s:" can be used.  They cannot be
+accessed from outside of the scripts, thus are local to the script.
+
+They can be used in:
+- commands executed while the script is sourced
+- functions defined in the script
+- autocommands defined in the script
+- functions and autocommands defined in functions and autocommands which were
+  defined in the script (recursively)
+- user defined commands defined in the script
+Thus not in:
+- other scripts sourced from this one
+- mappings
+- menus
+- etc.
+
+Script variables can be used to avoid conflicts with global variable names.
+Take this example: >
+
+	let s:counter = 0
+	function MyCounter()
+	  let s:counter = s:counter + 1
+	  echo s:counter
+	endfunction
+	command Tick call MyCounter()
+
+You can now invoke "Tick" from any script, and the "s:counter" variable in
+that script will not be changed, only the "s:counter" in the script where
+"Tick" was defined is used.
+
+Another example that does the same: >
+
+	let s:counter = 0
+	command Tick let s:counter = s:counter + 1 | echo s:counter
+
+When calling a function and invoking a user-defined command, the context for
+script variables is set to the script where the function or command was
+defined.
+
+The script variables are also available when a function is defined inside a
+function that is defined in a script.  Example: >
+
+	let s:counter = 0
+	function StartCounting(incr)
+	  if a:incr
+	    function MyCounter()
+	      let s:counter = s:counter + 1
+	    endfunction
+	  else
+	    function MyCounter()
+	      let s:counter = s:counter - 1
+	    endfunction
+	  endif
+	endfunction
+
+This defines the MyCounter() function either for counting up or counting down
+when calling StartCounting().  It doesn't matter from where StartCounting() is
+called, the s:counter variable will be accessible in MyCounter().
+
+When the same script is sourced again it will use the same script variables.
+They will remain valid as long as Vim is running.  This can be used to
+maintain a counter: >
+
+	if !exists("s:counter")
+	  let s:counter = 1
+	  echo "script executed for the first time"
+	else
+	  let s:counter = s:counter + 1
+	  echo "script executed " . s:counter . " times now"
+	endif
+
+Note that this means that filetype plugins don't get a different set of script
+variables for each buffer.  Use local buffer variables instead |b:var|.
+
+
+Predefined Vim variables:			*vim-variable* *v:var*
+
+					*v:beval_col* *beval_col-variable*
+v:beval_col	The number of the column, over which the mouse pointer is.
+		This is the byte index in the |v:beval_lnum| line.
+		Only valid while evaluating the 'balloonexpr' option.
+
+					*v:beval_bufnr* *beval_bufnr-variable*
+v:beval_bufnr	The number of the buffer, over which the mouse pointer is. Only
+		valid while evaluating the 'balloonexpr' option.
+
+					*v:beval_lnum* *beval_lnum-variable*
+v:beval_lnum	The number of the line, over which the mouse pointer is. Only
+		valid while evaluating the 'balloonexpr' option.
+
+					*v:beval_text* *beval_text-variable*
+v:beval_text	The text under or after the mouse pointer.  Usually a word as
+		it is useful for debugging a C program.  'iskeyword' applies,
+		but a dot and "->" before the position is included.  When on a
+		']' the text before it is used, including the matching '[' and
+		word before it.  When on a Visual area within one line the
+		highlighted text is used.
+		Only valid while evaluating the 'balloonexpr' option.
+
+					*v:beval_winnr* *beval_winnr-variable*
+v:beval_winnr	The number of the window, over which the mouse pointer is. Only
+		valid while evaluating the 'balloonexpr' option.
+
+					*v:char* *char-variable*
+v:char		Argument for evaluating 'formatexpr' and used for the typed
+		character when using  in an abbreviation |:map-|.
+
+			*v:charconvert_from* *charconvert_from-variable*
+v:charconvert_from
+		The name of the character encoding of a file to be converted.
+		Only valid while evaluating the 'charconvert' option.
+
+			*v:charconvert_to* *charconvert_to-variable*
+v:charconvert_to
+		The name of the character encoding of a file after conversion.
+		Only valid while evaluating the 'charconvert' option.
+
+					*v:cmdarg* *cmdarg-variable*
+v:cmdarg	This variable is used for two purposes:
+		1. The extra arguments given to a file read/write command.
+		   Currently these are "++enc=" and "++ff=".  This variable is
+		   set before an autocommand event for a file read/write
+		   command is triggered.  There is a leading space to make it
+		   possible to append this variable directly after the
+		   read/write command.	Note: The "+cmd" argument isn't
+		   included here, because it will be executed anyway.
+		2. When printing a PostScript file with ":hardcopy" this is
+		   the argument for the ":hardcopy" command.  This can be used
+		   in 'printexpr'.
+
+					*v:cmdbang* *cmdbang-variable*
+v:cmdbang	Set like v:cmdarg for a file read/write command.  When a "!"
+		was used the value is 1, otherwise it is 0.  Note that this
+		can only be used in autocommands.  For user commands ||
+		can be used.
+
+					*v:count* *count-variable*
+v:count		The count given for the last Normal mode command.  Can be used
+		to get the count before a mapping.  Read-only.	Example: >
+	:map _x :echo "the count is " . v:count
+<		Note: The  is required to remove the line range that you
+		get when typing ':' after a count.
+		When there are two counts, as in "3d2w", they are multiplied,
+		just like what happens in the command, "d6w" for the example.
+		Also used for evaluating the 'formatexpr' option.
+		"count" also works, for backwards compatibility.
+
+					*v:count1* *count1-variable*
+v:count1	Just like "v:count", but defaults to one when no count is
+		used.
+
+						*v:ctype* *ctype-variable*
+v:ctype		The current locale setting for characters of the runtime
+		environment.  This allows Vim scripts to be aware of the
+		current locale encoding.  Technical: it's the value of
+		LC_CTYPE.  When not using a locale the value is "C".
+		This variable can not be set directly, use the |:language|
+		command.
+		See |multi-lang|.
+
+					*v:dying* *dying-variable*
+v:dying		Normally zero.	When a deadly signal is caught it's set to
+		one.  When multiple signals are caught the number increases.
+		Can be used in an autocommand to check if Vim didn't
+		terminate normally. {only works on Unix}
+		Example: >
+	:au VimLeave * if v:dying | echo "\nAAAAaaaarrrggghhhh!!!\n" | endif
+<		Note: if another deadly signal is caught when v:dying is one,
+		VimLeave autocommands will not be executed.
+
+					*v:errmsg* *errmsg-variable*
+v:errmsg	Last given error message.  It's allowed to set this variable.
+		Example: >
+	:let v:errmsg = ""
+	:silent! next
+	:if v:errmsg != ""
+	:  ... handle error
+<		"errmsg" also works, for backwards compatibility.
+
+					*v:exception* *exception-variable*
+v:exception	The value of the exception most recently caught and not
+		finished.  See also |v:throwpoint| and |throw-variables|.
+		Example: >
+	:try
+	:  throw "oops"
+	:catch /.*/
+	:  echo "caught" v:exception
+	:endtry
+<		Output: "caught oops".
+
+					*v:fcs_reason* *fcs_reason-variable*
+v:fcs_reason	The reason why the |FileChangedShell| event was triggered.
+		Can be used in an autocommand to decide what to do and/or what
+		to set v:fcs_choice to.  Possible values:
+			deleted		file no longer exists
+			conflict	file contents, mode or timestamp was
+					changed and buffer is modified
+			changed		file contents has changed
+			mode		mode of file changed
+			time		only file timestamp changed
+
+					*v:fcs_choice* *fcs_choice-variable*
+v:fcs_choice	What should happen after a |FileChangedShell| event was
+		triggered.  Can be used in an autocommand to tell Vim what to
+		do with the affected buffer:
+			reload		Reload the buffer (does not work if
+					the file was deleted).
+			ask		Ask the user what to do, as if there
+					was no autocommand.  Except that when
+					only the timestamp changed nothing
+					will happen.
+					Nothing, the autocommand should do
+					everything that needs to be done.
+		The default is empty.  If another (invalid) value is used then
+		Vim behaves like it is empty, there is no warning message.
+
+					*v:fname_in* *fname_in-variable*
+v:fname_in	The name of the input file.  Valid while evaluating:
+			option		used for ~
+			'charconvert'	file to be converted
+			'diffexpr'	original file
+			'patchexpr'	original file
+			'printexpr'	file to be printed
+		And set to the swap file name for |SwapExists|.
+
+					*v:fname_out* *fname_out-variable*
+v:fname_out	The name of the output file.  Only valid while
+		evaluating:
+			option		used for ~
+			'charconvert'	resulting converted file (*)
+			'diffexpr'	output of diff
+			'patchexpr'	resulting patched file
+		(*) When doing conversion for a write command (e.g., ":w
+		file") it will be equal to v:fname_in.	When doing conversion
+		for a read command (e.g., ":e file") it will be a temporary
+		file and different from v:fname_in.
+
+					*v:fname_new* *fname_new-variable*
+v:fname_new	The name of the new version of the file.  Only valid while
+		evaluating 'diffexpr'.
+
+					*v:fname_diff* *fname_diff-variable*
+v:fname_diff	The name of the diff (patch) file.  Only valid while
+		evaluating 'patchexpr'.
+
+					*v:folddashes* *folddashes-variable*
+v:folddashes	Used for 'foldtext': dashes representing foldlevel of a closed
+		fold.
+		Read-only in the |sandbox|. |fold-foldtext|
+
+					*v:foldlevel* *foldlevel-variable*
+v:foldlevel	Used for 'foldtext': foldlevel of closed fold.
+		Read-only in the |sandbox|. |fold-foldtext|
+
+					*v:foldend* *foldend-variable*
+v:foldend	Used for 'foldtext': last line of closed fold.
+		Read-only in the |sandbox|. |fold-foldtext|
+
+					*v:foldstart* *foldstart-variable*
+v:foldstart	Used for 'foldtext': first line of closed fold.
+		Read-only in the |sandbox|. |fold-foldtext|
+
+					*v:insertmode* *insertmode-variable*
+v:insertmode	Used for the |InsertEnter| and |InsertChange| autocommand
+		events.  Values:
+			i	Insert mode
+			r	Replace mode
+			v	Virtual Replace mode
+
+						*v:key* *key-variable*
+v:key		Key of the current item of a |Dictionary|.  Only valid while
+		evaluating the expression used with |map()| and |filter()|.
+		Read-only.
+
+						*v:lang* *lang-variable*
+v:lang		The current locale setting for messages of the runtime
+		environment.  This allows Vim scripts to be aware of the
+		current language.  Technical: it's the value of LC_MESSAGES.
+		The value is system dependent.
+		This variable can not be set directly, use the |:language|
+		command.
+		It can be different from |v:ctype| when messages are desired
+		in a different language than what is used for character
+		encoding.  See |multi-lang|.
+
+						*v:lc_time* *lc_time-variable*
+v:lc_time	The current locale setting for time messages of the runtime
+		environment.  This allows Vim scripts to be aware of the
+		current language.  Technical: it's the value of LC_TIME.
+		This variable can not be set directly, use the |:language|
+		command.  See |multi-lang|.
+
+						*v:lnum* *lnum-variable*
+v:lnum		Line number for the 'foldexpr' |fold-expr|, 'formatexpr' and
+		'indentexpr' expressions, tab page number for 'guitablabel'
+		and 'guitabtooltip'.  Only valid while one of these
+		expressions is being evaluated.  Read-only when in the
+		|sandbox|.
+
+					*v:mouse_win* *mouse_win-variable*
+v:mouse_win	Window number for a mouse click obtained with |getchar()|.
+		First window has number 1, like with |winnr()|.  The value is
+		zero when there was no mouse button click.
+
+					*v:mouse_lnum* *mouse_lnum-variable*
+v:mouse_lnum	Line number for a mouse click obtained with |getchar()|.
+		This is the text line number, not the screen line number.  The
+		value is zero when there was no mouse button click.
+
+					*v:mouse_col* *mouse_col-variable*
+v:mouse_col	Column number for a mouse click obtained with |getchar()|.
+		This is the screen column number, like with |virtcol()|.  The
+		value is zero when there was no mouse button click.
+
+					*v:oldfiles* *oldfiles-variable*
+v:oldfiles	List of file names that is loaded from the |viminfo| file on
+		startup.  These are the files that Vim remembers marks for.
+		The length of the List is limited by the ' argument of the
+		'viminfo' option (default is 100).
+		Also see |:oldfiles| and |c_#<|.
+		The List can be modified, but this has no effect on what is
+		stored in the |viminfo| file later.  If you use values other
+		than String this will cause trouble.
+		{only when compiled with the |+viminfo| feature}
+
+					*v:operator* *operator-variable*
+v:operator	The last operator given in Normal mode.  This is a single
+		character except for commands starting with  or ,
+		in which case it is two characters.  Best used alongside
+		|v:prevcount| and |v:register|.  Useful if you want to cancel
+		Operator-pending mode and then use the operator, e.g.: >
+			:omap O :call MyMotion(v:operator)
+<		The value remains set until another operator is entered, thus
+		don't expect it to be empty.
+		v:operator is not set for |:delete|, |:yank| or other Ex
+		commands.
+		Read-only.
+
+					*v:prevcount* *prevcount-variable*
+v:prevcount	The count given for the last but one Normal mode command.
+		This is the v:count value of the previous command.  Useful if
+		you want to cancel Visual or Operator-pending mode and then
+		use the count, e.g.: >
+			:vmap % :call MyFilter(v:prevcount)
+<		Read-only.
+
+					*v:profiling* *profiling-variable*
+v:profiling	Normally zero.	Set to one after using ":profile start".
+		See |profiling|.
+
+					*v:progname* *progname-variable*
+v:progname	Contains the name (with path removed) with which Vim was
+		invoked.  Allows you to do special initialisations for "view",
+		"evim" etc., or any other name you might symlink to Vim.
+		Read-only.
+
+					*v:register* *register-variable*
+v:register	The name of the register supplied to the last normal mode
+		command.  Empty if none were supplied. |getreg()| |setreg()|
+
+					*v:scrollstart* *scrollstart-variable*
+v:scrollstart	String describing the script or function that caused the
+		screen to scroll up.  It's only set when it is empty, thus the
+		first reason is remembered.  It is set to "Unknown" for a
+		typed command.
+		This can be used to find out why your script causes the
+		hit-enter prompt.
+
+					*v:servername* *servername-variable*
+v:servername	The resulting registered |x11-clientserver| name if any.
+		Read-only.
+
+		
+v:searchforward			*v:searchforward* *searchforward-variable*
+		Search direction:  1 after a forward search, 0 after a
+		backward search.  It is reset to forward when directly setting
+		the last search pattern, see |quote/|.
+		Note that the value is restored when returning from a
+		function. |function-search-undo|.
+		Read-write.
+
+					*v:shell_error* *shell_error-variable*
+v:shell_error	Result of the last shell command.  When non-zero, the last
+		shell command had an error.  When zero, there was no problem.
+		This only works when the shell returns the error code to Vim.
+		The value -1 is often used when the command could not be
+		executed.  Read-only.
+		Example: >
+	:!mv foo bar
+	:if v:shell_error
+	:  echo 'could not rename "foo" to "bar"!'
+	:endif
+<		"shell_error" also works, for backwards compatibility.
+
+					*v:statusmsg* *statusmsg-variable*
+v:statusmsg	Last given status message.  It's allowed to set this variable.
+
+					*v:swapname* *swapname-variable*
+v:swapname	Only valid when executing |SwapExists| autocommands: Name of
+		the swap file found.  Read-only.
+
+					*v:swapchoice* *swapchoice-variable*
+v:swapchoice	|SwapExists| autocommands can set this to the selected choice
+		for handling an existing swap file:
+			'o'	Open read-only
+			'e'	Edit anyway
+			'r'	Recover
+			'd'	Delete swapfile
+			'q'	Quit
+			'a'	Abort
+		The value should be a single-character string.	An empty value
+		results in the user being asked, as would happen when there is
+		no SwapExists autocommand.  The default is empty.
+
+					*v:swapcommand* *swapcommand-variable*
+v:swapcommand	Normal mode command to be executed after a file has been
+		opened.  Can be used for a |SwapExists| autocommand to have
+		another Vim open the file and jump to the right place.	For
+		example, when jumping to a tag the value is ":tag tagname\r".
+		For ":edit +cmd file" the value is ":cmd\r".
+
+				*v:termresponse* *termresponse-variable*
+v:termresponse	The escape sequence returned by the terminal for the |t_RV|
+		termcap entry.	It is set when Vim receives an escape sequence
+		that starts with ESC [ or CSI and ends in a 'c', with only
+		digits, ';' and '.' in between.
+		When this option is set, the TermResponse autocommand event is
+		fired, so that you can react to the response from the
+		terminal.
+		The response from a new xterm is: "[ Pp ; Pv ; Pc c".  Pp
+		is the terminal type: 0 for vt100 and 1 for vt220.  Pv is the
+		patch level (since this was introduced in patch 95, it's
+		always 95 or bigger).  Pc is always zero.
+		{only when compiled with |+termresponse| feature}
+
+				*v:this_session* *this_session-variable*
+v:this_session	Full filename of the last loaded or saved session file.  See
+		|:mksession|.  It is allowed to set this variable.  When no
+		session file has been saved, this variable is empty.
+		"this_session" also works, for backwards compatibility.
+
+					*v:throwpoint* *throwpoint-variable*
+v:throwpoint	The point where the exception most recently caught and not
+		finished was thrown.  Not set when commands are typed.	See
+		also |v:exception| and |throw-variables|.
+		Example: >
+	:try
+	:  throw "oops"
+	:catch /.*/
+	:  echo "Exception from" v:throwpoint
+	:endtry
+<		Output: "Exception from test.vim, line 2"
+
+						*v:val* *val-variable*
+v:val		Value of the current item of a |List| or |Dictionary|.	Only
+		valid while evaluating the expression used with |map()| and
+		|filter()|.  Read-only.
+
+					*v:version* *version-variable*
+v:version	Version number of Vim: Major version number times 100 plus
+		minor version number.  Version 5.0 is 500.  Version 5.1 (5.01)
+		is 501.  Read-only.  "version" also works, for backwards
+		compatibility.
+		Use |has()| to check if a certain patch was included, e.g.: >
+			if has("patch123")
+<		Note that patch numbers are specific to the version, thus both
+		version 5.0 and 5.1 may have a patch 123, but these are
+		completely different.
+
+					*v:warningmsg* *warningmsg-variable*
+v:warningmsg	Last given warning message.  It's allowed to set this variable.
+
+==============================================================================
+4. Builtin Functions					*functions*
+
+See |function-list| for a list grouped by what the function is used for.
+
+(Use CTRL-] on the function name to jump to the full explanation.)
+
+USAGE				RESULT	DESCRIPTION	~
+
+abs( {expr})			Float or Number  absolute value of {expr}
+acos( {expr})			Float	arc cosine of {expr}
+add( {list}, {item})		List	append {item} to |List| {list}
+append( {lnum}, {string})	Number	append {string} below line {lnum}
+append( {lnum}, {list})		Number	append lines {list} below line {lnum}
+argc()				Number	number of files in the argument list
+argidx()			Number	current index in the argument list
+argv( {nr})			String	{nr} entry of the argument list
+argv( )				List	the argument list
+asin( {expr})			Float	arc sine of {expr}
+atan( {expr})			Float	arc tangent of {expr}
+atan2( {expr}, {expr})		Float   arc tangent of {expr1} / {expr2}
+browse( {save}, {title}, {initdir}, {default})
+				String	put up a file requester
+browsedir( {title}, {initdir})	String	put up a directory requester
+bufexists( {expr})		Number	TRUE if buffer {expr} exists
+buflisted( {expr})		Number	TRUE if buffer {expr} is listed
+bufloaded( {expr})		Number	TRUE if buffer {expr} is loaded
+bufname( {expr})		String	Name of the buffer {expr}
+bufnr( {expr})			Number	Number of the buffer {expr}
+bufwinnr( {expr})		Number	window number of buffer {expr}
+byte2line( {byte})		Number	line number at byte count {byte}
+byteidx( {expr}, {nr})		Number	byte index of {nr}'th char in {expr}
+call( {func}, {arglist} [, {dict}])
+				any	call {func} with arguments {arglist}
+ceil( {expr})			Float	round {expr} up
+changenr()			Number	current change number
+char2nr( {expr})		Number	ASCII value of first char in {expr}
+cindent( {lnum})		Number	C indent for line {lnum}
+clearmatches()			none	clear all matches
+col( {expr})			Number	column nr of cursor or mark
+complete( {startcol}, {matches}) none	set Insert mode completion
+complete_add( {expr})		Number	add completion match
+complete_check()		Number	check for key typed during completion
+confirm( {msg} [, {choices} [, {default} [, {type}]]])
+				Number	number of choice picked by user
+copy( {expr})			any	make a shallow copy of {expr}
+cos( {expr})			Float	cosine of {expr}
+cosh( {expr})			Float	hyperbolic cosine of {expr}
+count( {list}, {expr} [, {start} [, {ic}]])
+				Number	 count how many {expr} are in {list}
+cscope_connection( [{num} , {dbpath} [, {prepend}]])
+				Number	checks existence of cscope connection
+cursor( {lnum}, {col} [, {coladd}])
+				Number	move cursor to {lnum}, {col}, {coladd}
+cursor( {list})			Number	move cursor to position in {list}
+deepcopy( {expr})		any	make a full copy of {expr}
+delete( {fname})		Number	delete file {fname}
+did_filetype()			Number	TRUE if FileType autocommand event used
+diff_filler( {lnum})		Number	diff filler lines about {lnum}
+diff_hlID( {lnum}, {col})	Number	diff highlighting at {lnum}/{col}
+empty( {expr})			Number	TRUE if {expr} is empty
+escape( {string}, {chars})	String	escape {chars} in {string} with '\'
+eval( {string})			any	evaluate {string} into its value
+eventhandler( )			Number	TRUE if inside an event handler
+executable( {expr})		Number	1 if executable {expr} exists
+exists( {expr})			Number	TRUE if {expr} exists
+extend( {expr1}, {expr2} [, {expr3}])
+				List/Dict insert items of {expr2} into {expr1}
+exp( {expr})			Float	exponential of {expr}
+expand( {expr} [, {flag}])	String	expand special keywords in {expr}
+feedkeys( {string} [, {mode}])	Number	add key sequence to typeahead buffer
+filereadable( {file})		Number	TRUE if {file} is a readable file
+filewritable( {file})		Number	TRUE if {file} is a writable file
+filter( {expr}, {string})	List/Dict  remove items from {expr} where
+					{string} is 0
+finddir( {name}[, {path}[, {count}]])
+				String	find directory {name} in {path}
+findfile( {name}[, {path}[, {count}]])
+				String	find file {name} in {path}
+float2nr( {expr})		Number	convert Float {expr} to a Number
+floor( {expr})			Float	round {expr} down
+fmod( {expr1}, {expr2})		Float	remainder of {expr1} / {expr2}
+fnameescape( {fname})		String	escape special characters in {fname}
+fnamemodify( {fname}, {mods})	String	modify file name
+foldclosed( {lnum})		Number	first line of fold at {lnum} if closed
+foldclosedend( {lnum})		Number	last line of fold at {lnum} if closed
+foldlevel( {lnum})		Number	fold level at {lnum}
+foldtext( )			String	line displayed for closed fold
+foldtextresult( {lnum})		String	text for closed fold at {lnum}
+foreground( )			Number	bring the Vim window to the foreground
+function( {name})		Funcref reference to function {name}
+garbagecollect( [at_exit])	none	free memory, breaking cyclic references
+get( {list}, {idx} [, {def}])	any	get item {idx} from {list} or {def}
+get( {dict}, {key} [, {def}])	any	get item {key} from {dict} or {def}
+getbufline( {expr}, {lnum} [, {end}])
+				List	lines {lnum} to {end} of buffer {expr}
+getbufvar( {expr}, {varname})	any	variable {varname} in buffer {expr}
+getchar( [expr])		Number	get one character from the user
+getcharmod( )			Number	modifiers for the last typed character
+getcmdline()			String	return the current command-line
+getcmdpos()			Number	return cursor position in command-line
+getcmdtype()			String	return the current command-line type
+getcwd()			String	the current working directory
+getfperm( {fname})		String	file permissions of file {fname}
+getfsize( {fname})		Number	size in bytes of file {fname}
+getfontname( [{name}])		String	name of font being used
+getftime( {fname})		Number	last modification time of file
+getftype( {fname})		String	description of type of file {fname}
+getline( {lnum})		String	line {lnum} of current buffer
+getline( {lnum}, {end})		List	lines {lnum} to {end} of current buffer
+getloclist( {nr})		List	list of location list items
+getmatches()			List	list of current matches
+getpid()			Number	process ID of Vim
+getpos( {expr})			List	position of cursor, mark, etc.
+getqflist()			List	list of quickfix items
+getreg( [{regname} [, 1]])	String	contents of register
+getregtype( [{regname}])	String	type of register
+gettabvar( {nr}, {varname})	any	variable {varname} in tab {nr}
+gettabwinvar( {tabnr}, {winnr}, {name})
+				any	{name} in {winnr} in tab page {tabnr}
+getwinposx()			Number	X coord in pixels of GUI Vim window
+getwinposy()			Number	Y coord in pixels of GUI Vim window
+getwinvar( {nr}, {varname})	any	variable {varname} in window {nr}
+glob( {expr} [, {flag}])	String	expand file wildcards in {expr}
+globpath( {path}, {expr} [, {flag}])
+				String	do glob({expr}) for all dirs in {path}
+has( {feature})			Number	TRUE if feature {feature} supported
+has_key( {dict}, {key})		Number	TRUE if {dict} has entry {key}
+haslocaldir()			Number	TRUE if current window executed |:lcd|
+hasmapto( {what} [, {mode} [, {abbr}]])
+				Number	TRUE if mapping to {what} exists
+histadd( {history},{item})	String	add an item to a history
+histdel( {history} [, {item}])	String	remove an item from a history
+histget( {history} [, {index}])	String	get the item {index} from a history
+histnr( {history})		Number	highest index of a history
+hlexists( {name})		Number	TRUE if highlight group {name} exists
+hlID( {name})			Number	syntax ID of highlight group {name}
+hostname()			String	name of the machine Vim is running on
+iconv( {expr}, {from}, {to})	String	convert encoding of {expr}
+indent( {lnum})			Number	indent of line {lnum}
+index( {list}, {expr} [, {start} [, {ic}]])
+				Number	index in {list} where {expr} appears
+input( {prompt} [, {text} [, {completion}]])
+				String	get input from the user
+inputdialog( {p} [, {t} [, {c}]]) String  like input() but in a GUI dialog
+inputlist( {textlist})		Number	let the user pick from a choice list
+inputrestore()			Number	restore typeahead
+inputsave()			Number	save and clear typeahead
+inputsecret( {prompt} [, {text}]) String  like input() but hiding the text
+insert( {list}, {item} [, {idx}]) List	insert {item} in {list} [before {idx}]
+isdirectory( {directory})	Number	TRUE if {directory} is a directory
+islocked( {expr})		Number	TRUE if {expr} is locked
+items( {dict})			List	key-value pairs in {dict}
+join( {list} [, {sep}])		String	join {list} items into one String
+keys( {dict})			List	keys in {dict}
+len( {expr})			Number	the length of {expr}
+libcall( {lib}, {func}, {arg})	String	call {func} in library {lib} with {arg}
+libcallnr( {lib}, {func}, {arg})  Number  idem, but return a Number
+line( {expr})			Number	line nr of cursor, last line or mark
+line2byte( {lnum})		Number	byte count of line {lnum}
+lispindent( {lnum})		Number	Lisp indent for line {lnum}
+localtime()			Number	current time
+log( {expr})			Float	natural logarithm (base e) of {expr}
+log10( {expr})			Float	logarithm of Float {expr} to base 10
+map( {expr}, {string})		List/Dict  change each item in {expr} to {expr}
+maparg( {name}[, {mode} [, {abbr}]])
+				String	rhs of mapping {name} in mode {mode}
+mapcheck( {name}[, {mode} [, {abbr}]])
+				String	check for mappings matching {name}
+match( {expr}, {pat}[, {start}[, {count}]])
+				Number	position where {pat} matches in {expr}
+matchadd( {group}, {pattern}[, {priority}[, {id}]])
+				Number	highlight {pattern} with {group}
+matcharg( {nr})			List	arguments of |:match|
+matchdelete( {id})		Number	delete match identified by {id}
+matchend( {expr}, {pat}[, {start}[, {count}]])
+				Number	position where {pat} ends in {expr}
+matchlist( {expr}, {pat}[, {start}[, {count}]])
+				List	match and submatches of {pat} in {expr}
+matchstr( {expr}, {pat}[, {start}[, {count}]])
+				String	{count}'th match of {pat} in {expr}
+max( {list})			Number	maximum value of items in {list}
+min( {list})			Number	minimum value of items in {list}
+mkdir( {name} [, {path} [, {prot}]])
+				Number	create directory {name}
+mode( [expr])			String	current editing mode
+mzeval( {expr})			any	evaluate |MzScheme| expression
+nextnonblank( {lnum})		Number	line nr of non-blank line >= {lnum}
+nr2char( {expr})		String	single char with ASCII value {expr}
+pathshorten( {expr})		String	shorten directory names in a path
+pow( {x}, {y})			Float	{x} to the power of {y}
+prevnonblank( {lnum})		Number	line nr of non-blank line <= {lnum}
+printf( {fmt}, {expr1}...)	String	format text
+pumvisible()			Number	whether popup menu is visible
+range( {expr} [, {max} [, {stride}]])
+				List	items from {expr} to {max}
+readfile( {fname} [, {binary} [, {max}]])
+				List	get list of lines from file {fname}
+reltime( [{start} [, {end}]])	List	get time value
+reltimestr( {time})		String	turn time value into a String
+remote_expr( {server}, {string} [, {idvar}])
+				String	send expression
+remote_foreground( {server})	Number	bring Vim server to the foreground
+remote_peek( {serverid} [, {retvar}])
+				Number	check for reply string
+remote_read( {serverid})	String	read reply string
+remote_send( {server}, {string} [, {idvar}])
+				String	send key sequence
+remove( {list}, {idx} [, {end}])  any	remove items {idx}-{end} from {list}
+remove( {dict}, {key})		any	remove entry {key} from {dict}
+rename( {from}, {to})		Number	rename (move) file from {from} to {to}
+repeat( {expr}, {count})	String	repeat {expr} {count} times
+resolve( {filename})		String	get filename a shortcut points to
+reverse( {list})		List	reverse {list} in-place
+round( {expr})			Float	round off {expr}
+search( {pattern} [, {flags} [, {stopline} [, {timeout}]]])
+				Number	search for {pattern}
+searchdecl( {name} [, {global} [, {thisblock}]])
+				Number	search for variable declaration
+searchpair( {start}, {middle}, {end} [, {flags} [, {skip} [...]]])
+				Number	search for other end of start/end pair
+searchpairpos( {start}, {middle}, {end} [, {flags} [, {skip} [...]]])
+				List	search for other end of start/end pair
+searchpos( {pattern} [, {flags} [, {stopline} [, {timeout}]]])
+				List	search for {pattern}
+server2client( {clientid}, {string})
+				Number	send reply string
+serverlist()			String	get a list of available servers
+setbufvar( {expr}, {varname}, {val})	set {varname} in buffer {expr} to {val}
+setcmdpos( {pos})		Number	set cursor position in command-line
+setline( {lnum}, {line})	Number	set line {lnum} to {line}
+setloclist( {nr}, {list}[, {action}])
+				Number	modify location list using {list}
+setmatches( {list})		Number	restore a list of matches
+setpos( {expr}, {list})		Number	set the {expr} position to {list}
+setqflist( {list}[, {action}])	Number	modify quickfix list using {list}
+setreg( {n}, {v}[, {opt}])	Number	set register to value and type
+settabvar( {nr}, {varname}, {val})	set {varname} in tab page {nr} to {val}
+settabwinvar( {tabnr}, {winnr}, {varname}, {val})    set {varname} in window
+					{winnr} in tab page {tabnr} to {val}
+setwinvar( {nr}, {varname}, {val})	set {varname} in window {nr} to {val}
+shellescape( {string} [, {special}])
+				String	escape {string} for use as shell
+					command argument
+simplify( {filename})		String	simplify filename as much as possible
+sin( {expr})			Float	sine of {expr}
+sinh( {expr})			Float	hyperbolic sine of {expr}
+sort( {list} [, {func}])	List	sort {list}, using {func} to compare
+soundfold( {word})		String	sound-fold {word}
+spellbadword()			String	badly spelled word at cursor
+spellsuggest( {word} [, {max} [, {capital}]])
+				List	spelling suggestions
+split( {expr} [, {pat} [, {keepempty}]])
+				List	make |List| from {pat} separated {expr}
+sqrt( {expr}			Float	squar root of {expr}
+str2float( {expr})		Float	convert String to Float
+str2nr( {expr} [, {base}])	Number	convert String to Number
+strchars( {expr})		Number	character length of the String {expr}
+strdisplaywidth( {expr} [, {col}]) Number display length of the String {expr}
+strftime( {format}[, {time}])	String	time in specified format
+stridx( {haystack}, {needle}[, {start}])
+				Number	index of {needle} in {haystack}
+string( {expr})			String	String representation of {expr} value
+strlen( {expr})			Number	length of the String {expr}
+strpart( {src}, {start}[, {len}])
+				String	{len} characters of {src} at {start}
+strridx( {haystack}, {needle} [, {start}])
+				Number	last index of {needle} in {haystack}
+strtrans( {expr})		String	translate string to make it printable
+strwidth( {expr})		Number	display cell length of the String {expr}
+submatch( {nr})			String	specific match in ":substitute"
+substitute( {expr}, {pat}, {sub}, {flags})
+				String	all {pat} in {expr} replaced with {sub}
+synID( {lnum}, {col}, {trans})	Number	syntax ID at {lnum} and {col}
+synIDattr( {synID}, {what} [, {mode}])
+				String	attribute {what} of syntax ID {synID}
+synIDtrans( {synID})		Number	translated syntax ID of {synID}
+synstack( {lnum}, {col})	List	stack of syntax IDs at {lnum} and {col}
+system( {expr} [, {input}])	String	output of shell command/filter {expr}
+tabpagebuflist( [{arg}])	List	list of buffer numbers in tab page
+tabpagenr( [{arg}])		Number	number of current or last tab page
+tabpagewinnr( {tabarg}[, {arg}])
+				Number	number of current window in tab page
+taglist( {expr})		List	list of tags matching {expr}
+tagfiles()			List	tags files used
+tempname()			String	name for a temporary file
+tan( {expr})			Float	tangent of {expr}
+tanh( {expr})			Float	hyperbolic tangent of {expr}
+tolower( {expr})		String	the String {expr} switched to lowercase
+toupper( {expr})		String	the String {expr} switched to uppercase
+tr( {src}, {fromstr}, {tostr})	String	translate chars of {src} in {fromstr}
+					to chars in {tostr}
+trunc( {expr}			Float	truncate Float {expr}
+type( {name})			Number	type of variable {name}
+undofile( {name})		String	undo file name for {name}
+undotree()			List	undo file tree
+values( {dict})			List	values in {dict}
+virtcol( {expr})		Number	screen column of cursor or mark
+visualmode( [expr])		String	last visual mode used
+winbufnr( {nr})			Number	buffer number of window {nr}
+wincol()			Number	window column of the cursor
+winheight( {nr})		Number	height of window {nr}
+winline()			Number	window line of the cursor
+winnr( [{expr}])		Number	number of current window
+winrestcmd()			String	returns command to restore window sizes
+winrestview( {dict})		none	restore view of current window
+winsaveview()			Dict	save view of current window
+winwidth( {nr})			Number	width of window {nr}
+writefile( {list}, {fname} [, {binary}])
+				Number	write list of lines to file {fname}
+
+abs({expr})							*abs()*
+		Return the absolute value of {expr}.  When {expr} evaluates to
+		a |Float| abs() returns a |Float|.  When {expr} can be
+		converted to a |Number| abs() returns a |Number|.  Otherwise
+		abs() gives an error message and returns -1.
+		Examples: >
+			echo abs(1.456)
+<			1.456  >
+			echo abs(-5.456)
+<			5.456  >
+			echo abs(-4)
+<			4
+		{only available when compiled with the |+float| feature}
+
+
+acos({expr})							*acos()*
+		Return the arc cosine of {expr} measured in radians, as a
+		|Float| in the range of [0, pi].
+		{expr} must evaluate to a |Float| or a |Number| in the range
+		[-1, 1].
+		Examples: >
+			:echo acos(0)
+<			1.570796 >
+			:echo acos(-0.5)
+<			2.094395
+		{only available when compiled with the |+float| feature}
+
+
+add({list}, {expr})					*add()*
+		Append the item {expr} to |List| {list}.  Returns the
+		resulting |List|.  Examples: >
+			:let alist = add([1, 2, 3], item)
+			:call add(mylist, "woodstock")
+<		Note that when {expr} is a |List| it is appended as a single
+		item.  Use |extend()| to concatenate |Lists|.
+		Use |insert()| to add an item at another position.
+
+
+append({lnum}, {expr})					*append()*
+		When {expr} is a |List|: Append each item of the |List| as a
+		text line below line {lnum} in the current buffer.
+		Otherwise append {expr} as one text line below line {lnum} in
+		the current buffer.
+		{lnum} can be zero to insert a line before the first one.
+		Returns 1 for failure ({lnum} out of range or out of memory),
+		0 for success.	Example: >
+			:let failed = append(line('$'), "# THE END")
+			:let failed = append(0, ["Chapter 1", "the beginning"])
+<
+							*argc()*
+argc()		The result is the number of files in the argument list of the
+		current window.  See |arglist|.
+
+							*argidx()*
+argidx()	The result is the current index in the argument list.  0 is
+		the first file.  argc() - 1 is the last one.  See |arglist|.
+
+							*argv()*
+argv([{nr}])	The result is the {nr}th file in the argument list of the
+		current window.  See |arglist|.  "argv(0)" is the first one.
+		Example: >
+	:let i = 0
+	:while i < argc()
+	:  let f = escape(fnameescape(argv(i)), '.')
+	:  exe 'amenu Arg.' . f . ' :e ' . f . ''
+	:  let i = i + 1
+	:endwhile
+<		Without the {nr} argument a |List| with the whole |arglist| is
+		returned.
+
+asin({expr})						*asin()*
+		Return the arc sine of {expr} measured in radians, as a |Float|
+		in the range of [-pi/2, pi/2].
+		{expr} must evaluate to a |Float| or a |Number| in the range
+		[-1, 1].
+		Examples: >
+			:echo asin(0.8)
+<			0.927295 >
+			:echo asin(-0.5)
+<			-0.523599
+		{only available when compiled with the |+float| feature}
+
+
+atan({expr})						*atan()*
+		Return the principal value of the arc tangent of {expr}, in
+		the range [-pi/2, +pi/2] radians, as a |Float|.
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo atan(100)
+<			1.560797 >
+			:echo atan(-4.01)
+<			-1.326405
+		{only available when compiled with the |+float| feature}
+
+
+atan2({expr1}, {expr2})					*atan2()*
+		Return the arc tangent of {expr1} / {expr2}, measured in
+		radians, as a |Float| in the range [-pi, pi].
+		{expr1} and {expr2} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo atan2(-1, 1)
+<			-0.785398 >
+			:echo atan2(1, -1)
+<			2.356194
+		{only available when compiled with the |+float| feature}
+
+
+							*browse()*
+browse({save}, {title}, {initdir}, {default})
+		Put up a file requester.  This only works when "has("browse")"
+		returns non-zero (only in some GUI versions).
+		The input fields are:
+		    {save}	when non-zero, select file to write
+		    {title}	title for the requester
+		    {initdir}	directory to start browsing in
+		    {default}	default file name
+		When the "Cancel" button is hit, something went wrong, or
+		browsing is not possible, an empty string is returned.
+
+							*browsedir()*
+browsedir({title}, {initdir})
+		Put up a directory requester.  This only works when
+		"has("browse")" returns non-zero (only in some GUI versions).
+		On systems where a directory browser is not supported a file
+		browser is used.  In that case: select a file in the directory
+		to be used.
+		The input fields are:
+		    {title}	title for the requester
+		    {initdir}	directory to start browsing in
+		When the "Cancel" button is hit, something went wrong, or
+		browsing is not possible, an empty string is returned.
+
+bufexists({expr})					*bufexists()*
+		The result is a Number, which is non-zero if a buffer called
+		{expr} exists.
+		If the {expr} argument is a number, buffer numbers are used.
+		If the {expr} argument is a string it must match a buffer name
+		exactly.  The name can be:
+		- Relative to the current directory.
+		- A full path.
+		- The name of a buffer with 'buftype' set to "nofile".
+		- A URL name.
+		Unlisted buffers will be found.
+		Note that help files are listed by their short name in the
+		output of |:buffers|, but bufexists() requires using their
+		long name to be able to find them.
+		bufexists() may report a buffer exists, but to use the name
+		with a |:buffer| command you may need to use |expand()|.  Esp
+		for MS-Windows 8.3 names in the form "c:\DOCUME~1"
+		Use "bufexists(0)" to test for the existence of an alternate
+		file name.
+							*buffer_exists()*
+		Obsolete name: buffer_exists().
+
+buflisted({expr})					*buflisted()*
+		The result is a Number, which is non-zero if a buffer called
+		{expr} exists and is listed (has the 'buflisted' option set).
+		The {expr} argument is used like with |bufexists()|.
+
+bufloaded({expr})					*bufloaded()*
+		The result is a Number, which is non-zero if a buffer called
+		{expr} exists and is loaded (shown in a window or hidden).
+		The {expr} argument is used like with |bufexists()|.
+
+bufname({expr})						*bufname()*
+		The result is the name of a buffer, as it is displayed by the
+		":ls" command.
+		If {expr} is a Number, that buffer number's name is given.
+		Number zero is the alternate buffer for the current window.
+		If {expr} is a String, it is used as a |file-pattern| to match
+		with the buffer names.	This is always done like 'magic' is
+		set and 'cpoptions' is empty.  When there is more than one
+		match an empty string is returned.
+		"" or "%" can be used for the current buffer, "#" for the
+		alternate buffer.
+		A full match is preferred, otherwise a match at the start, end
+		or middle of the buffer name is accepted.  If you only want a
+		full match then put "^" at the start and "$" at the end of the
+		pattern.
+		Listed buffers are found first.  If there is a single match
+		with a listed buffer, that one is returned.  Next unlisted
+		buffers are searched for.
+		If the {expr} is a String, but you want to use it as a buffer
+		number, force it to be a Number by adding zero to it: >
+			:echo bufname("3" + 0)
+<		If the buffer doesn't exist, or doesn't have a name, an empty
+		string is returned. >
+	bufname("#")		alternate buffer name
+	bufname(3)		name of buffer 3
+	bufname("%")		name of current buffer
+	bufname("file2")	name of buffer where "file2" matches.
+<							*buffer_name()*
+		Obsolete name: buffer_name().
+
+							*bufnr()*
+bufnr({expr} [, {create}])
+		The result is the number of a buffer, as it is displayed by
+		the ":ls" command.  For the use of {expr}, see |bufname()|
+		above.
+		If the buffer doesn't exist, -1 is returned.  Or, if the
+		{create} argument is present and not zero, a new, unlisted,
+		buffer is created and its number is returned.
+		bufnr("$") is the last buffer: >
+	:let last_buffer = bufnr("$")
+<		The result is a Number, which is the highest buffer number
+		of existing buffers.  Note that not all buffers with a smaller
+		number necessarily exist, because ":bwipeout" may have removed
+		them.  Use bufexists() to test for the existence of a buffer.
+							*buffer_number()*
+		Obsolete name: buffer_number().
+							*last_buffer_nr()*
+		Obsolete name for bufnr("$"): last_buffer_nr().
+
+bufwinnr({expr})					*bufwinnr()*
+		The result is a Number, which is the number of the first
+		window associated with buffer {expr}.  For the use of {expr},
+		see |bufname()| above.	If buffer {expr} doesn't exist or
+		there is no such window, -1 is returned.  Example: >
+
+	echo "A window containing buffer 1 is " . (bufwinnr(1))
+
+<		The number can be used with |CTRL-W_w| and ":wincmd w"
+		|:wincmd|.
+		Only deals with the current tab page.
+
+
+byte2line({byte})					*byte2line()*
+		Return the line number that contains the character at byte
+		count {byte} in the current buffer.  This includes the
+		end-of-line character, depending on the 'fileformat' option
+		for the current buffer.  The first character has byte count
+		one.
+		Also see |line2byte()|, |go| and |:goto|.
+		{not available when compiled without the |+byte_offset|
+		feature}
+
+byteidx({expr}, {nr})					*byteidx()*
+		Return byte index of the {nr}'th character in the string
+		{expr}.  Use zero for the first character, it returns zero.
+		This function is only useful when there are multibyte
+		characters, otherwise the returned value is equal to {nr}.
+		Composing characters are counted as a separate character.
+		Example : >
+			echo matchstr(str, ".", byteidx(str, 3))
+<		will display the fourth character.  Another way to do the
+		same: >
+			let s = strpart(str, byteidx(str, 3))
+			echo strpart(s, 0, byteidx(s, 1))
+<		If there are less than {nr} characters -1 is returned.
+		If there are exactly {nr} characters the length of the string
+		is returned.
+
+call({func}, {arglist} [, {dict}])			*call()* *E699*
+		Call function {func} with the items in |List| {arglist} as
+		arguments.
+		{func} can either be a |Funcref| or the name of a function.
+		a:firstline and a:lastline are set to the cursor line.
+		Returns the return value of the called function.
+		{dict} is for functions with the "dict" attribute.  It will be
+		used to set the local variable "self". |Dictionary-function|
+
+ceil({expr})							*ceil()*
+		Return the smallest integral value greater than or equal to
+		{expr} as a |Float| (round up).
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			echo ceil(1.456)
+<			2.0  >
+			echo ceil(-5.456)
+<			-5.0  >
+			echo ceil(4.0)
+<			4.0
+		{only available when compiled with the |+float| feature}
+
+changenr()						*changenr()*
+		Return the number of the most recent change.  This is the same
+		number as what is displayed with |:undolist| and can be used
+		with the |:undo| command.
+		When a change was made it is the number of that change.  After
+		redo it is the number of the redone change.  After undo it is
+		one less than the number of the undone change.
+
+char2nr({expr})						*char2nr()*
+		Return number value of the first char in {expr}.  Examples: >
+			char2nr(" ")		returns 32
+			char2nr("ABC")		returns 65
+<		The current 'encoding' is used.  Example for "utf-8": >
+			char2nr("á")		returns 225
+			char2nr("á"[0])		returns 195
+<		|nr2char()| does the opposite.
+
+cindent({lnum})						*cindent()*
+		Get the amount of indent for line {lnum} according the C
+		indenting rules, as with 'cindent'.
+		The indent is counted in spaces, the value of 'tabstop' is
+		relevant.  {lnum} is used just like in |getline()|.
+		When {lnum} is invalid or Vim was not compiled the |+cindent|
+		feature, -1 is returned.
+		See |C-indenting|.
+
+clearmatches()						*clearmatches()*
+		Clears all matches previously defined by |matchadd()| and the
+		|:match| commands.
+
+							*col()*
+col({expr})	The result is a Number, which is the byte index of the column
+		position given with {expr}.  The accepted positions are:
+		    .	    the cursor position
+		    $	    the end of the cursor line (the result is the
+			    number of characters in the cursor line plus one)
+		    'x	    position of mark x (if the mark is not set, 0 is
+			    returned)
+		Additionally {expr} can be [lnum, col]: a |List| with the line
+		and column number. Most useful when the column is "$", to get
+		the last column of a specific line.  When "lnum" or "col" is
+		out of range then col() returns zero.
+		To get the line number use |line()|.  To get both use
+		|getpos()|.
+		For the screen column position use |virtcol()|.
+		Note that only marks in the current file can be used.
+		Examples: >
+			col(".")		column of cursor
+			col("$")		length of cursor line plus one
+			col("'t")		column of mark t
+			col("'" . markname)	column of mark markname
+<		The first column is 1.	0 is returned for an error.
+		For an uppercase mark the column may actually be in another
+		buffer.
+		For the cursor position, when 'virtualedit' is active, the
+		column is one higher if the cursor is after the end of the
+		line.  This can be used to obtain the column in Insert mode: >
+			:imap  :let save_ve = &ve
+				\:set ve=all
+				\:echo col(".") . "\n" 
+				\let &ve = save_ve
+<
+
+complete({startcol}, {matches})			*complete()* *E785*
+		Set the matches for Insert mode completion.
+		Can only be used in Insert mode.  You need to use a mapping
+		with CTRL-R = |i_CTRL-R|.  It does not work after CTRL-O or
+		with an expression mapping.
+		{startcol} is the byte offset in the line where the completed
+		text start.  The text up to the cursor is the original text
+		that will be replaced by the matches.  Use col('.') for an
+		empty string.  "col('.') - 1" will replace one character by a
+		match.
+		{matches} must be a |List|.  Each |List| item is one match.
+		See |complete-items| for the kind of items that are possible.
+		Note that the after calling this function you need to avoid
+		inserting anything that would cause completion to stop.
+		The match can be selected with CTRL-N and CTRL-P as usual with
+		Insert mode completion.  The popup menu will appear if
+		specified, see |ins-completion-menu|.
+		Example: >
+	inoremap  =ListMonths()
+
+	func! ListMonths()
+	  call complete(col('.'), ['January', 'February', 'March',
+		\ 'April', 'May', 'June', 'July', 'August', 'September',
+		\ 'October', 'November', 'December'])
+	  return ''
+	endfunc
+<		This isn't very useful, but it shows how it works.  Note that
+		an empty string is returned to avoid a zero being inserted.
+
+complete_add({expr})				*complete_add()*
+		Add {expr} to the list of matches.  Only to be used by the
+		function specified with the 'completefunc' option.
+		Returns 0 for failure (empty string or out of memory),
+		1 when the match was added, 2 when the match was already in
+		the list.
+		See |complete-functions| for an explanation of {expr}.	It is
+		the same as one item in the list that 'omnifunc' would return.
+
+complete_check()				*complete_check()*
+		Check for a key typed while looking for completion matches.
+		This is to be used when looking for matches takes some time.
+		Returns non-zero when searching for matches is to be aborted,
+		zero otherwise.
+		Only to be used by the function specified with the
+		'completefunc' option.
+
+						*confirm()*
+confirm({msg} [, {choices} [, {default} [, {type}]]])
+		Confirm() offers the user a dialog, from which a choice can be
+		made.  It returns the number of the choice.  For the first
+		choice this is 1.
+		Note: confirm() is only supported when compiled with dialog
+		support, see |+dialog_con| and |+dialog_gui|.
+
+		{msg} is displayed in a |dialog| with {choices} as the
+		alternatives.  When {choices} is missing or empty, "&OK" is
+		used (and translated).
+		{msg} is a String, use '\n' to include a newline.  Only on
+		some systems the string is wrapped when it doesn't fit.
+
+		{choices} is a String, with the individual choices separated
+		by '\n', e.g. >
+			confirm("Save changes?", "&Yes\n&No\n&Cancel")
+<		The letter after the '&' is the shortcut key for that choice.
+		Thus you can type 'c' to select "Cancel".  The shortcut does
+		not need to be the first letter: >
+			confirm("file has been modified", "&Save\nSave &All")
+<		For the console, the first letter of each choice is used as
+		the default shortcut key.
+
+		The optional {default} argument is the number of the choice
+		that is made if the user hits .  Use 1 to make the first
+		choice the default one.  Use 0 to not set a default.  If
+		{default} is omitted, 1 is used.
+
+		The optional {type} argument gives the type of dialog.  This
+		is only used for the icon of the GTK, Mac, Motif and Win32
+		GUI.  It can be one of these values: "Error", "Question",
+		"Info", "Warning" or "Generic".  Only the first character is
+		relevant.  When {type} is omitted, "Generic" is used.
+
+		If the user aborts the dialog by pressing , CTRL-C,
+		or another valid interrupt key, confirm() returns 0.
+
+		An example: >
+   :let choice = confirm("What do you want?", "&Apples\n&Oranges\n&Bananas", 2)
+   :if choice == 0
+   :	echo "make up your mind!"
+   :elseif choice == 3
+   :	echo "tasteful"
+   :else
+   :	echo "I prefer bananas myself."
+   :endif
+<		In a GUI dialog, buttons are used.  The layout of the buttons
+		depends on the 'v' flag in 'guioptions'.  If it is included,
+		the buttons are always put vertically.	Otherwise,  confirm()
+		tries to put the buttons in one horizontal line.  If they
+		don't fit, a vertical layout is used anyway.  For some systems
+		the horizontal layout is always used.
+
+							*copy()*
+copy({expr})	Make a copy of {expr}.	For Numbers and Strings this isn't
+		different from using {expr} directly.
+		When {expr} is a |List| a shallow copy is created.  This means
+		that the original |List| can be changed without changing the
+		copy, and vice versa.  But the items are identical, thus
+		changing an item changes the contents of both |Lists|.	Also
+		see |deepcopy()|.
+
+cos({expr})						*cos()*
+		Return the cosine of {expr}, measured in radians, as a |Float|.
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo cos(100)
+<			0.862319 >
+			:echo cos(-4.01)
+<			-0.646043
+		{only available when compiled with the |+float| feature}
+
+
+cosh({expr})						*cosh()*
+		Return the hyperbolic cosine of {expr} as a |Float| in the range
+		[1, inf].
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo cosh(0.5)
+<			1.127626 >
+			:echo cosh(-0.5)
+<			-1.127626
+		{only available when compiled with the |+float| feature}
+
+		
+count({comp}, {expr} [, {ic} [, {start}]])			*count()*
+		Return the number of times an item with value {expr} appears
+		in |List| or |Dictionary| {comp}.
+		If {start} is given then start with the item with this index.
+		{start} can only be used with a |List|.
+		When {ic} is given and it's non-zero then case is ignored.
+
+
+							*cscope_connection()*
+cscope_connection([{num} , {dbpath} [, {prepend}]])
+		Checks for the existence of a |cscope| connection.  If no
+		parameters are specified, then the function returns:
+			0, if cscope was not available (not compiled in), or
+			   if there are no cscope connections;
+			1, if there is at least one cscope connection.
+
+		If parameters are specified, then the value of {num}
+		determines how existence of a cscope connection is checked:
+
+		{num}	Description of existence check
+		-----	------------------------------
+		0	Same as no parameters (e.g., "cscope_connection()").
+		1	Ignore {prepend}, and use partial string matches for
+			{dbpath}.
+		2	Ignore {prepend}, and use exact string matches for
+			{dbpath}.
+		3	Use {prepend}, use partial string matches for both
+			{dbpath} and {prepend}.
+		4	Use {prepend}, use exact string matches for both
+			{dbpath} and {prepend}.
+
+		Note: All string comparisons are case sensitive!
+
+		Examples.  Suppose we had the following (from ":cs show"): >
+
+  # pid    database name			prepend path
+  0 27664  cscope.out				/usr/local
+<
+		Invocation					Return Val ~
+		----------					---------- >
+		cscope_connection()					1
+		cscope_connection(1, "out")				1
+		cscope_connection(2, "out")				0
+		cscope_connection(3, "out")				0
+		cscope_connection(3, "out", "local")			1
+		cscope_connection(4, "out")				0
+		cscope_connection(4, "out", "local")			0
+		cscope_connection(4, "cscope.out", "/usr/local")	1
+<
+cursor({lnum}, {col} [, {off}])				*cursor()*
+cursor({list})
+		Positions the cursor at the column (byte count) {col} in the
+		line {lnum}.  The first column is one.
+		When there is one argument {list} this is used as a |List|
+		with two or three items {lnum}, {col} and {off}.  This is like
+		the return value of |getpos()|, but without the first item.
+		Does not change the jumplist.
+		If {lnum} is greater than the number of lines in the buffer,
+		the cursor will be positioned at the last line in the buffer.
+		If {lnum} is zero, the cursor will stay in the current line.
+		If {col} is greater than the number of bytes in the line,
+		the cursor will be positioned at the last character in the
+		line.
+		If {col} is zero, the cursor will stay in the current column.
+		When 'virtualedit' is used {off} specifies the offset in
+		screen columns from the start of the character.  E.g., a
+		position within a  or after the last character.
+		Returns 0 when the position could be set, -1 otherwise.
+
+
+deepcopy({expr}[, {noref}])				*deepcopy()* *E698*
+		Make a copy of {expr}.	For Numbers and Strings this isn't
+		different from using {expr} directly.
+		When {expr} is a |List| a full copy is created.  This means
+		that the original |List| can be changed without changing the
+		copy, and vice versa.  When an item is a |List|, a copy for it
+		is made, recursively.  Thus changing an item in the copy does
+		not change the contents of the original |List|.
+		When {noref} is omitted or zero a contained |List| or
+		|Dictionary| is only copied once.  All references point to
+		this single copy.  With {noref} set to 1 every occurrence of a
+		|List| or |Dictionary| results in a new copy.  This also means
+		that a cyclic reference causes deepcopy() to fail.
+								*E724*
+		Nesting is possible up to 100 levels.  When there is an item
+		that refers back to a higher level making a deep copy with
+		{noref} set to 1 will fail.
+		Also see |copy()|.
+
+delete({fname})							*delete()*
+		Deletes the file by the name {fname}.  The result is a Number,
+		which is 0 if the file was deleted successfully, and non-zero
+		when the deletion failed.
+		Use |remove()| to delete an item from a |List|.
+
+							*did_filetype()*
+did_filetype()	Returns non-zero when autocommands are being executed and the
+		FileType event has been triggered at least once.  Can be used
+		to avoid triggering the FileType event again in the scripts
+		that detect the file type. |FileType|
+		When editing another file, the counter is reset, thus this
+		really checks if the FileType event has been triggered for the
+		current buffer.  This allows an autocommand that starts
+		editing another buffer to set 'filetype' and load a syntax
+		file.
+
+diff_filler({lnum})					*diff_filler()*
+		Returns the number of filler lines above line {lnum}.
+		These are the lines that were inserted at this point in
+		another diff'ed window.  These filler lines are shown in the
+		display but don't exist in the buffer.
+		{lnum} is used like with |getline()|.  Thus "." is the current
+		line, "'m" mark m, etc.
+		Returns 0 if the current window is not in diff mode.
+
+diff_hlID({lnum}, {col})				*diff_hlID()*
+		Returns the highlight ID for diff mode at line {lnum} column
+		{col} (byte index).  When the current line does not have a
+		diff change zero is returned.
+		{lnum} is used like with |getline()|.  Thus "." is the current
+		line, "'m" mark m, etc.
+		{col} is 1 for the leftmost column, {lnum} is 1 for the first
+		line.
+		The highlight ID can be used with |synIDattr()| to obtain
+		syntax information about the highlighting.
+
+empty({expr})						*empty()*
+		Return the Number 1 if {expr} is empty, zero otherwise.
+		A |List| or |Dictionary| is empty when it does not have any
+		items.	A Number is empty when its value is zero.
+		For a long |List| this is much faster than comparing the
+		length with zero.
+
+escape({string}, {chars})				*escape()*
+		Escape the characters in {chars} that occur in {string} with a
+		backslash.  Example: >
+			:echo escape('c:\program files\vim', ' \')
+<		results in: >
+			c:\\program\ files\\vim
+<		Also see |shellescape()|.
+
+							*eval()*
+eval({string})	Evaluate {string} and return the result.  Especially useful to
+		turn the result of |string()| back into the original value.
+		This works for Numbers, Floats, Strings and composites of
+		them.  Also works for |Funcref|s that refer to existing
+		functions.
+
+eventhandler()						*eventhandler()*
+		Returns 1 when inside an event handler.  That is that Vim got
+		interrupted while waiting for the user to type a character,
+		e.g., when dropping a file on Vim.  This means interactive
+		commands cannot be used.  Otherwise zero is returned.
+
+executable({expr})					*executable()*
+		This function checks if an executable with the name {expr}
+		exists.  {expr} must be the name of the program without any
+		arguments.
+		executable() uses the value of $PATH and/or the normal
+		searchpath for programs.		*PATHEXT*
+		On MS-DOS and MS-Windows the ".exe", ".bat", etc. can
+		optionally be included.  Then the extensions in $PATHEXT are
+		tried.	Thus if "foo.exe" does not exist, "foo.exe.bat" can be
+		found.	If $PATHEXT is not set then ".exe;.com;.bat;.cmd" is
+		used.  A dot by itself can be used in $PATHEXT to try using
+		the name without an extension.	When 'shell' looks like a
+		Unix shell, then the name is also tried without adding an
+		extension.
+		On MS-DOS and MS-Windows it only checks if the file exists and
+		is not a directory, not if it's really executable.
+		On MS-Windows an executable in the same directory as Vim is
+		always found.  Since this directory is added to $PATH it
+		should also work to execute it |win32-PATH|.
+		The result is a Number:
+			1	exists
+			0	does not exist
+			-1	not implemented on this system
+
+							*exists()*
+exists({expr})	The result is a Number, which is non-zero if {expr} is
+		defined, zero otherwise.  The {expr} argument is a string,
+		which contains one of these:
+			&option-name	Vim option (only checks if it exists,
+					not if it really works)
+			+option-name	Vim option that works.
+			$ENVNAME	environment variable (could also be
+					done by comparing with an empty
+					string)
+			*funcname	built-in function (see |functions|)
+					or user defined function (see
+					|user-functions|).
+			varname		internal variable (see
+					|internal-variables|).	Also works
+					for |curly-braces-names|, |Dictionary|
+					entries, |List| items, etc.  Beware
+					that evaluating an index may cause an
+					error message for an invalid
+					expression.  E.g.: >
+					   :let l = [1, 2, 3]
+					   :echo exists("l[5]")
+<					   0 >
+					   :echo exists("l[xx]")
+<					   E121: Undefined variable: xx
+					   0
+			:cmdname	Ex command: built-in command, user
+					command or command modifier |:command|.
+					Returns:
+					1  for match with start of a command
+					2  full match with a command
+					3  matches several user commands
+					To check for a supported command
+					always check the return value to be 2.
+			:2match		The |:2match| command.
+			:3match		The |:3match| command.
+			#event		autocommand defined for this event
+			#event#pattern	autocommand defined for this event and
+					pattern (the pattern is taken
+					literally and compared to the
+					autocommand patterns character by
+					character)
+			#group		autocommand group exists
+			#group#event	autocommand defined for this group and
+					event.
+			#group#event#pattern
+					autocommand defined for this group,
+					event and pattern.
+			##event		autocommand for this event is
+					supported.
+		For checking for a supported feature use |has()|.
+
+		Examples: >
+			exists("&shortname")
+			exists("$HOSTNAME")
+			exists("*strftime")
+			exists("*s:MyFunc")
+			exists("bufcount")
+			exists(":Make")
+			exists("#CursorHold")
+			exists("#BufReadPre#*.gz")
+			exists("#filetypeindent")
+			exists("#filetypeindent#FileType")
+			exists("#filetypeindent#FileType#*")
+			exists("##ColorScheme")
+<		There must be no space between the symbol (&/$/*/#) and the
+		name.
+		There must be no extra characters after the name, although in
+		a few cases this is ignored.  That may become more strict in
+		the future, thus don't count on it!
+		Working example: >
+			exists(":make")
+<		NOT working example: >
+			exists(":make install")
+
+<		Note that the argument must be a string, not the name of the
+		variable itself.  For example: >
+			exists(bufcount)
+<		This doesn't check for existence of the "bufcount" variable,
+		but gets the value of "bufcount", and checks if that exists.
+
+exp({expr})						*exp()*
+		Return the exponential of {expr} as a |Float| in the range
+		[0, inf].
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo exp(2)
+<			7.389056 >
+			:echo exp(-1)
+<			0.367879
+		{only available when compiled with the |+float| feature}
+
+
+expand({expr} [, {flag}])				*expand()*
+		Expand wildcards and the following special keywords in {expr}.
+		The result is a String.
+
+		When there are several matches, they are separated by 
+		characters.  [Note: in version 5.0 a space was used, which
+		caused problems when a file name contains a space]
+
+		If the expansion fails, the result is an empty string.	A name
+		for a non-existing file is not included.
+
+		When {expr} starts with '%', '#' or '<', the expansion is done
+		like for the |cmdline-special| variables with their associated
+		modifiers.  Here is a short overview:
+
+			%		current file name
+			#		alternate file name
+			#n		alternate file name n
+					file name under the cursor
+					autocmd file name
+					autocmd buffer number (as a String!)
+				autocmd matched name
+					sourced script file name
+					word under the cursor
+					WORD under the cursor
+				the {clientid} of the last received
+					message |server2client()|
+		Modifiers:
+			:p		expand to full path
+			:h		head (last path component removed)
+			:t		tail (last path component only)
+			:r		root (one extension removed)
+			:e		extension only
+
+		Example: >
+			:let &tags = expand("%:p:h") . "/tags"
+<		Note that when expanding a string that starts with '%', '#' or
+		'<', any following text is ignored.  This does NOT work: >
+			:let doesntwork = expand("%:h.bak")
+<		Use this: >
+			:let doeswork = expand("%:h") . ".bak"
+<		Also note that expanding "" and others only returns the
+		referenced file name without further expansion.  If ""
+		is "~/.cshrc", you need to do another expand() to have the
+		"~/" expanded into the path of the home directory: >
+			:echo expand(expand(""))
+<
+		There cannot be white space between the variables and the
+		following modifier.  The |fnamemodify()| function can be used
+		to modify normal file names.
+
+		When using '%' or '#', and the current or alternate file name
+		is not defined, an empty string is used.  Using "%:p" in a
+		buffer with no name, results in the current directory, with a
+		'/' added.
+
+		When {expr} does not start with '%', '#' or '<', it is
+		expanded like a file name is expanded on the command line.
+		'suffixes' and 'wildignore' are used, unless the optional
+		{flag} argument is given and it is non-zero.  Names for
+		non-existing files are included.  The "**" item can be used to
+		search in a directory tree.  For example, to find all "README"
+		files in the current directory and below: >
+			:echo expand("**/README")
+<
+		Expand() can also be used to expand variables and environment
+		variables that are only known in a shell.  But this can be
+		slow, because a shell must be started.	See |expr-env-expand|.
+		The expanded variable is still handled like a list of file
+		names.	When an environment variable cannot be expanded, it is
+		left unchanged.  Thus ":echo expand('$FOOBAR')" results in
+		"$FOOBAR".
+
+		See |glob()| for finding existing files.  See |system()| for
+		getting the raw output of an external command.
+
+extend({expr1}, {expr2} [, {expr3}])			*extend()*
+		{expr1} and {expr2} must be both |Lists| or both
+		|Dictionaries|.
+
+		If they are |Lists|: Append {expr2} to {expr1}.
+		If {expr3} is given insert the items of {expr2} before item
+		{expr3} in {expr1}.  When {expr3} is zero insert before the
+		first item.  When {expr3} is equal to len({expr1}) then
+		{expr2} is appended.
+		Examples: >
+			:echo sort(extend(mylist, [7, 5]))
+			:call extend(mylist, [2, 3], 1)
+<		When {expr1} is the same List as {expr2} then the number of
+		items copied is equal to the original length of the List.
+		E.g., when {expr3} is 1 you get N new copies of the first item
+		(where N is the original length of the List).
+		Use |add()| to concatenate one item to a list.	To concatenate
+		two lists into a new list use the + operator: >
+			:let newlist = [1, 2, 3] + [4, 5]
+<
+		If they are |Dictionaries|:
+		Add all entries from {expr2} to {expr1}.
+		If a key exists in both {expr1} and {expr2} then {expr3} is
+		used to decide what to do:
+		{expr3} = "keep": keep the value of {expr1}
+		{expr3} = "force": use the value of {expr2}
+		{expr3} = "error": give an error message		*E737*
+		When {expr3} is omitted then "force" is assumed.
+
+		{expr1} is changed when {expr2} is not empty.  If necessary
+		make a copy of {expr1} first.
+		{expr2} remains unchanged.
+		Returns {expr1}.
+
+
+feedkeys({string} [, {mode}])				*feedkeys()*
+		Characters in {string} are queued for processing as if they
+		come from a mapping or were typed by the user.	They are added
+		to the end of the typeahead buffer, thus if a mapping is still
+		being executed these characters come after them.
+		The function does not wait for processing of keys contained in
+		{string}.
+		To include special keys into {string}, use double-quotes
+		and "\..." notation |expr-quote|. For example,
+		feedkeys("\") simulates pressing of the  key. But
+		feedkeys('\') pushes 5 characters.
+		If {mode} is absent, keys are remapped.
+		{mode} is a String, which can contain these character flags:
+		'm'	Remap keys. This is default.
+		'n'	Do not remap keys.
+		't'	Handle keys as if typed; otherwise they are handled as
+			if coming from a mapping.  This matters for undo,
+			opening folds, etc.
+		Return value is always 0.
+
+filereadable({file})					*filereadable()*
+		The result is a Number, which is TRUE when a file with the
+		name {file} exists, and can be read.  If {file} doesn't exist,
+		or is a directory, the result is FALSE.  {file} is any
+		expression, which is used as a String.
+		If you don't care about the file being readable you can use
+		|glob()|.
+							*file_readable()*
+		Obsolete name: file_readable().
+
+
+filewritable({file})					*filewritable()*
+		The result is a Number, which is 1 when a file with the
+		name {file} exists, and can be written.  If {file} doesn't
+		exist, or is not writable, the result is 0.  If {file} is a
+		directory, and we can write to it, the result is 2.
+
+
+filter({expr}, {string})					*filter()*
+		{expr} must be a |List| or a |Dictionary|.
+		For each item in {expr} evaluate {string} and when the result
+		is zero remove the item from the |List| or |Dictionary|.
+		Inside {string} |v:val| has the value of the current item.
+		For a |Dictionary| |v:key| has the key of the current item.
+		Examples: >
+			:call filter(mylist, 'v:val !~ "OLD"')
+<		Removes the items where "OLD" appears. >
+			:call filter(mydict, 'v:key >= 8')
+<		Removes the items with a key below 8. >
+			:call filter(var, 0)
+<		Removes all the items, thus clears the |List| or |Dictionary|.
+
+		Note that {string} is the result of expression and is then
+		used as an expression again.  Often it is good to use a
+		|literal-string| to avoid having to double backslashes.
+
+		The operation is done in-place.  If you want a |List| or
+		|Dictionary| to remain unmodified make a copy first: >
+			:let l = filter(copy(mylist), 'v:val =~ "KEEP"')
+
+<		Returns {expr}, the |List| or |Dictionary| that was filtered.
+		When an error is encountered while evaluating {string} no
+		further items in {expr} are processed.
+
+
+finddir({name}[, {path}[, {count}]])				*finddir()*
+		Find directory {name} in {path}.  Supports both downwards and
+		upwards recursive directory searches.  See |file-searching|
+		for the syntax of {path}.
+		Returns the path of the first found match.  When the found
+		directory is below the current directory a relative path is
+		returned.  Otherwise a full path is returned.
+		If {path} is omitted or empty then 'path' is used.
+		If the optional {count} is given, find {count}'s occurrence of
+		{name} in {path} instead of the first one.
+		When {count} is negative return all the matches in a |List|.
+		This is quite similar to the ex-command |:find|.
+		{only available when compiled with the |+file_in_path|
+		feature}
+
+findfile({name}[, {path}[, {count}]])				*findfile()*
+		Just like |finddir()|, but find a file instead of a directory.
+		Uses 'suffixesadd'.
+		Example: >
+			:echo findfile("tags.vim", ".;")
+<		Searches from the directory of the current file upwards until
+		it finds the file "tags.vim".
+
+float2nr({expr})					*float2nr()*
+		Convert {expr} to a Number by omitting the part after the
+		decimal point.
+		{expr} must evaluate to a |Float| or a Number.
+		When the value of {expr} is out of range for a |Number| the
+		result is truncated to 0x7fffffff or -0x7fffffff.  NaN results
+		in -0x80000000.
+		Examples: >
+			echo float2nr(3.95)
+<			3  >
+			echo float2nr(-23.45)
+<			-23  >
+			echo float2nr(1.0e100)
+<			2147483647  >
+			echo float2nr(-1.0e150)
+<			-2147483647  >
+			echo float2nr(1.0e-100)
+<			0
+		{only available when compiled with the |+float| feature}
+
+
+floor({expr})							*floor()*
+		Return the largest integral value less than or equal to
+		{expr} as a |Float| (round down).
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			echo floor(1.856)
+<			1.0  >
+			echo floor(-5.456)
+<			-6.0  >
+			echo floor(4.0)
+<			4.0
+		{only available when compiled with the |+float| feature}
+		
+
+fmod({expr1}, {expr2})					*fmod()*
+		Return the remainder of {expr1} / {expr2}, even if the
+		division is not representable.  Returns {expr1} - i * {expr2}
+		for some integer i such that if {expr2} is non-zero, the
+		result has the same sign as {expr1} and magnitude less than
+		the magnitude of {expr2}.  If {expr2} is zero, the value
+		returned is zero.  The value returned is a |Float|.
+		{expr1} and {expr2} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo fmod(12.33, 1.22)
+<			0.13 >
+			:echo fmod(-12.33, 1.22)
+<			-0.13
+		{only available when compiled with |+float| feature}
+
+
+fnameescape({string})					*fnameescape()*
+		Escape {string} for use as file name command argument.	All
+		characters that have a special meaning, such as '%' and '|'
+		are escaped with a backslash.
+		For most systems the characters escaped are
+		" \t\n*?[{`$\\%#'\"|!<".  For systems where a backslash
+		appears in a filename, it depends on the value of 'isfname'.
+		A leading '+' and '>' is also escaped (special after |:edit|
+		and |:write|).  And a "-" by itself (special after |:cd|).
+		Example: >
+			:let fname = '+some str%nge|name'
+			:exe "edit " . fnameescape(fname)
+<		results in executing: >
+			edit \+some\ str\%nge\|name
+
+fnamemodify({fname}, {mods})				*fnamemodify()*
+		Modify file name {fname} according to {mods}.  {mods} is a
+		string of characters like it is used for file names on the
+		command line.  See |filename-modifiers|.
+		Example: >
+			:echo fnamemodify("main.c", ":p:h")
+<		results in: >
+			/home/mool/vim/vim/src
+<		Note: Environment variables don't work in {fname}, use
+		|expand()| first then.
+
+foldclosed({lnum})					*foldclosed()*
+		The result is a Number.  If the line {lnum} is in a closed
+		fold, the result is the number of the first line in that fold.
+		If the line {lnum} is not in a closed fold, -1 is returned.
+
+foldclosedend({lnum})					*foldclosedend()*
+		The result is a Number.  If the line {lnum} is in a closed
+		fold, the result is the number of the last line in that fold.
+		If the line {lnum} is not in a closed fold, -1 is returned.
+
+foldlevel({lnum})					*foldlevel()*
+		The result is a Number, which is the foldlevel of line {lnum}
+		in the current buffer.	For nested folds the deepest level is
+		returned.  If there is no fold at line {lnum}, zero is
+		returned.  It doesn't matter if the folds are open or closed.
+		When used while updating folds (from 'foldexpr') -1 is
+		returned for lines where folds are still to be updated and the
+		foldlevel is unknown.  As a special case the level of the
+		previous line is usually available.
+
+							*foldtext()*
+foldtext()	Returns a String, to be displayed for a closed fold.  This is
+		the default function used for the 'foldtext' option and should
+		only be called from evaluating 'foldtext'.  It uses the
+		|v:foldstart|, |v:foldend| and |v:folddashes| variables.
+		The returned string looks like this: >
+			+-- 45 lines: abcdef
+<		The number of dashes depends on the foldlevel.	The "45" is
+		the number of lines in the fold.  "abcdef" is the text in the
+		first non-blank line of the fold.  Leading white space, "//"
+		or "/*" and the text from the 'foldmarker' and 'commentstring'
+		options is removed.
+		{not available when compiled without the |+folding| feature}
+
+foldtextresult({lnum})					*foldtextresult()*
+		Returns the text that is displayed for the closed fold at line
+		{lnum}.  Evaluates 'foldtext' in the appropriate context.
+		When there is no closed fold at {lnum} an empty string is
+		returned.
+		{lnum} is used like with |getline()|.  Thus "." is the current
+		line, "'m" mark m, etc.
+		Useful when exporting folded text, e.g., to HTML.
+		{not available when compiled without the |+folding| feature}
+
+							*foreground()*
+foreground()	Move the Vim window to the foreground.	Useful when sent from
+		a client to a Vim server. |remote_send()|
+		On Win32 systems this might not work, the OS does not always
+		allow a window to bring itself to the foreground.  Use
+		|remote_foreground()| instead.
+		{only in the Win32, Athena, Motif and GTK GUI versions and the
+		Win32 console version}
+
+
+function({name})					*function()* *E700*
+		Return a |Funcref| variable that refers to function {name}.
+		{name} can be a user defined function or an internal function.
+
+
+garbagecollect([at_exit])				*garbagecollect()*
+		Cleanup unused |Lists| and |Dictionaries| that have circular
+		references.  There is hardly ever a need to invoke this
+		function, as it is automatically done when Vim runs out of
+		memory or is waiting for the user to press a key after
+		'updatetime'.  Items without circular references are always
+		freed when they become unused.
+		This is useful if you have deleted a very big |List| and/or
+		|Dictionary| with circular references in a script that runs
+		for a long time.
+		When the optional "at_exit" argument is one, garbage
+		collection will also be done when exiting Vim, if it wasn't
+		done before.  This is useful when checking for memory leaks.
+
+get({list}, {idx} [, {default}])			*get()*
+		Get item {idx} from |List| {list}.  When this item is not
+		available return {default}.  Return zero when {default} is
+		omitted.
+get({dict}, {key} [, {default}])
+		Get item with key {key} from |Dictionary| {dict}.  When this
+		item is not available return {default}.  Return zero when
+		{default} is omitted.
+
+							*getbufline()*
+getbufline({expr}, {lnum} [, {end}])
+		Return a |List| with the lines starting from {lnum} to {end}
+		(inclusive) in the buffer {expr}.  If {end} is omitted, a
+		|List| with only the line {lnum} is returned.
+
+		For the use of {expr}, see |bufname()| above.
+
+		For {lnum} and {end} "$" can be used for the last line of the
+		buffer.  Otherwise a number must be used.
+
+		When {lnum} is smaller than 1 or bigger than the number of
+		lines in the buffer, an empty |List| is returned.
+
+		When {end} is greater than the number of lines in the buffer,
+		it is treated as {end} is set to the number of lines in the
+		buffer.  When {end} is before {lnum} an empty |List| is
+		returned.
+
+		This function works only for loaded buffers.  For unloaded and
+		non-existing buffers, an empty |List| is returned.
+
+		Example: >
+			:let lines = getbufline(bufnr("myfile"), 1, "$")
+
+getbufvar({expr}, {varname})				*getbufvar()*
+		The result is the value of option or local buffer variable
+		{varname} in buffer {expr}.  Note that the name without "b:"
+		must be used.
+		When {varname} is empty returns a dictionary with all the
+		buffer-local variables.
+		This also works for a global or buffer-local option, but it
+		doesn't work for a global variable, window-local variable or
+		window-local option.
+		For the use of {expr}, see |bufname()| above.
+		When the buffer or variable doesn't exist an empty string is
+		returned, there is no error message.
+		Examples: >
+			:let bufmodified = getbufvar(1, "&mod")
+			:echo "todo myvar = " . getbufvar("todo", "myvar")
+<
+getchar([expr])						*getchar()*
+		Get a single character from the user or input stream.
+		If [expr] is omitted, wait until a character is available.
+		If [expr] is 0, only get a character when one is available.
+			Return zero otherwise.
+		If [expr] is 1, only check if a character is available, it is
+			not consumed.  Return zero if no character available.
+
+		Without {expr} and when {expr} is 0 a whole character or
+		special key is returned.  If it is an 8-bit character, the
+		result is a number.  Use nr2char() to convert it to a String.
+		Otherwise a String is returned with the encoded character.
+		For a special key it's a sequence of bytes starting with 0x80
+		(decimal: 128).  This is the same value as the string
+		"\", e.g., "\".  The returned value is also a
+		String when a modifier (shift, control, alt) was used that is
+		not included in the character.
+
+		When {expr} is 1 only the first byte is returned.  For a
+		one-byte character it is the character itself as a number.
+		Use nr2char() to convert it to a String.
+
+		When the user clicks a mouse button, the mouse event will be
+		returned.  The position can then be found in |v:mouse_col|,
+		|v:mouse_lnum| and |v:mouse_win|.  This example positions the
+		mouse as it would normally happen: >
+			let c = getchar()
+			if c == "\" && v:mouse_win > 0
+			  exe v:mouse_win . "wincmd w"
+			  exe v:mouse_lnum
+			  exe "normal " . v:mouse_col . "|"
+			endif
+<
+		There is no prompt, you will somehow have to make clear to the
+		user that a character has to be typed.
+		There is no mapping for the character.
+		Key codes are replaced, thus when the user presses the 
+		key you get the code for the  key, not the raw character
+		sequence.  Examples: >
+			getchar() == "\"
+			getchar() == "\"
+<		This example redefines "f" to ignore case: >
+			:nmap f :call FindChar()
+			:function FindChar()
+			:  let c = nr2char(getchar())
+			:  while col('.') < col('$') - 1
+			:    normal l
+			:    if getline('.')[col('.') - 1] ==? c
+			:      break
+			:    endif
+			:  endwhile
+			:endfunction
+
+getcharmod()						*getcharmod()*
+		The result is a Number which is the state of the modifiers for
+		the last obtained character with getchar() or in another way.
+		These values are added together:
+			2	shift
+			4	control
+			8	alt (meta)
+			16	mouse double click
+			32	mouse triple click
+			64	mouse quadruple click
+			128	Macintosh only: command
+		Only the modifiers that have not been included in the
+		character itself are obtained.	Thus Shift-a results in "A"
+		without a modifier.
+
+getcmdline()						*getcmdline()*
+		Return the current command-line.  Only works when the command
+		line is being edited, thus requires use of |c_CTRL-\_e| or
+		|c_CTRL-R_=|.
+		Example: >
+			:cmap  eescape(getcmdline(), ' \')
+<		Also see |getcmdtype()|, |getcmdpos()| and |setcmdpos()|.
+
+getcmdpos()						*getcmdpos()*
+		Return the position of the cursor in the command line as a
+		byte count.  The first column is 1.
+		Only works when editing the command line, thus requires use of
+		|c_CTRL-\_e| or |c_CTRL-R_=|.  Returns 0 otherwise.
+		Also see |getcmdtype()|, |setcmdpos()| and |getcmdline()|.
+
+getcmdtype()						*getcmdtype()*
+		Return the current command-line type. Possible return values
+		are:
+		    :	normal Ex command
+		    >	debug mode command |debug-mode|
+		    /	forward search command
+		    ?	backward search command
+		    @	|input()| command
+		    -	|:insert| or |:append| command
+		Only works when editing the command line, thus requires use of
+		|c_CTRL-\_e| or |c_CTRL-R_=|.  Returns an empty string
+		otherwise.
+		Also see |getcmdpos()|, |setcmdpos()| and |getcmdline()|.
+
+							*getcwd()*
+getcwd()	The result is a String, which is the name of the current
+		working directory.
+
+getfsize({fname})					*getfsize()*
+		The result is a Number, which is the size in bytes of the
+		given file {fname}.
+		If {fname} is a directory, 0 is returned.
+		If the file {fname} can't be found, -1 is returned.
+		If the size of {fname} is too big to fit in a Number then -2
+		is returned.
+
+getfontname([{name}])					*getfontname()*
+		Without an argument returns the name of the normal font being
+		used.  Like what is used for the Normal highlight group
+		|hl-Normal|.
+		With an argument a check is done whether {name} is a valid
+		font name.  If not then an empty string is returned.
+		Otherwise the actual font name is returned, or {name} if the
+		GUI does not support obtaining the real name.
+		Only works when the GUI is running, thus not in your vimrc or
+		gvimrc file.  Use the |GUIEnter| autocommand to use this
+		function just after the GUI has started.
+		Note that the GTK 2 GUI accepts any font name, thus checking
+		for a valid name does not work.
+
+getfperm({fname})					*getfperm()*
+		The result is a String, which is the read, write, and execute
+		permissions of the given file {fname}.
+		If {fname} does not exist or its directory cannot be read, an
+		empty string is returned.
+		The result is of the form "rwxrwxrwx", where each group of
+		"rwx" flags represent, in turn, the permissions of the owner
+		of the file, the group the file belongs to, and other users.
+		If a user does not have a given permission the flag for this
+		is replaced with the string "-".  Example: >
+			:echo getfperm("/etc/passwd")
+<		This will hopefully (from a security point of view) display
+		the string "rw-r--r--" or even "rw-------".
+
+getftime({fname})					*getftime()*
+		The result is a Number, which is the last modification time of
+		the given file {fname}.  The value is measured as seconds
+		since 1st Jan 1970, and may be passed to strftime().  See also
+		|localtime()| and |strftime()|.
+		If the file {fname} can't be found -1 is returned.
+
+getftype({fname})					*getftype()*
+		The result is a String, which is a description of the kind of
+		file of the given file {fname}.
+		If {fname} does not exist an empty string is returned.
+		Here is a table over different kinds of files and their
+		results:
+			Normal file		"file"
+			Directory		"dir"
+			Symbolic link		"link"
+			Block device		"bdev"
+			Character device	"cdev"
+			Socket			"socket"
+			FIFO			"fifo"
+			All other		"other"
+		Example: >
+			getftype("/home")
+<		Note that a type such as "link" will only be returned on
+		systems that support it.  On some systems only "dir" and
+		"file" are returned.
+
+							*getline()*
+getline({lnum} [, {end}])
+		Without {end} the result is a String, which is line {lnum}
+		from the current buffer.  Example: >
+			getline(1)
+<		When {lnum} is a String that doesn't start with a
+		digit, line() is called to translate the String into a Number.
+		To get the line under the cursor: >
+			getline(".")
+<		When {lnum} is smaller than 1 or bigger than the number of
+		lines in the buffer, an empty string is returned.
+
+		When {end} is given the result is a |List| where each item is
+		a line from the current buffer in the range {lnum} to {end},
+		including line {end}.
+		{end} is used in the same way as {lnum}.
+		Non-existing lines are silently omitted.
+		When {end} is before {lnum} an empty |List| is returned.
+		Example: >
+			:let start = line('.')
+			:let end = search("^$") - 1
+			:let lines = getline(start, end)
+
+<		To get lines from another buffer see |getbufline()|
+
+getloclist({nr})					*getloclist()*
+		Returns a list with all the entries in the location list for
+		window {nr}. When {nr} is zero the current window is used.
+		For a location list window, the displayed location list is
+		returned.  For an invalid window number {nr}, an empty list is
+		returned. Otherwise, same as |getqflist()|.
+
+getmatches()						*getmatches()*
+		Returns a |List| with all matches previously defined by
+		|matchadd()| and the |:match| commands.  |getmatches()| is
+		useful in combination with |setmatches()|, as |setmatches()|
+		can restore a list of matches saved by |getmatches()|.
+		Example: >
+			:echo getmatches()
+<			[{'group': 'MyGroup1', 'pattern': 'TODO',
+			'priority': 10, 'id': 1}, {'group': 'MyGroup2',
+			'pattern': 'FIXME', 'priority': 10, 'id': 2}] >
+			:let m = getmatches()
+			:call clearmatches()
+			:echo getmatches()
+<			[] >
+			:call setmatches(m)
+			:echo getmatches()
+<			[{'group': 'MyGroup1', 'pattern': 'TODO',
+			'priority': 10, 'id': 1}, {'group': 'MyGroup2',
+			'pattern': 'FIXME', 'priority': 10, 'id': 2}] >
+			:unlet m
+<
+
+getqflist()						*getqflist()*
+		Returns a list with all the current quickfix errors.  Each
+		list item is a dictionary with these entries:
+			bufnr	number of buffer that has the file name, use
+				bufname() to get the name
+			lnum	line number in the buffer (first line is 1)
+			col	column number (first column is 1)
+			vcol	non-zero: "col" is visual column
+				zero: "col" is byte index
+			nr	error number
+			pattern	search pattern used to locate the error
+			text	description of the error
+			type	type of the error, 'E', '1', etc.
+			valid	non-zero: recognized error message
+
+		When there is no error list or it's empty an empty list is
+		returned. Quickfix list entries with non-existing buffer
+		number are returned with "bufnr" set to zero.
+
+		Useful application: Find pattern matches in multiple files and
+		do something with them: >
+			:vimgrep /theword/jg *.c
+			:for d in getqflist()
+			:   echo bufname(d.bufnr) ':' d.lnum '=' d.text
+			:endfor
+
+
+getreg([{regname} [, 1]])				*getreg()*
+		The result is a String, which is the contents of register
+		{regname}.  Example: >
+			:let cliptext = getreg('*')
+<		getreg('=') returns the last evaluated value of the expression
+		register.  (For use in maps.)
+		getreg('=', 1) returns the expression itself, so that it can
+		be restored with |setreg()|.  For other registers the extra
+		argument is ignored, thus you can always give it.
+		If {regname} is not specified, |v:register| is used.
+
+
+getregtype([{regname}])					*getregtype()*
+		The result is a String, which is type of register {regname}.
+		The value will be one of:
+		    "v"			for |characterwise| text
+		    "V"			for |linewise| text
+		    "{width}"	for |blockwise-visual| text
+		    0			for an empty or unknown register
+		 is one character with value 0x16.
+		If {regname} is not specified, |v:register| is used.
+
+gettabvar({tabnr}, {varname})				*gettabvar()*
+		Get the value of a tab-local variable {varname} in tab page
+		{tabnr}. |t:var|
+		Tabs are numbered starting with one.
+		Note that the name without "t:" must be used.
+
+gettabwinvar({tabnr}, {winnr}, {varname})		*gettabwinvar()*
+		Get the value of window-local variable {varname} in window
+		{winnr} in tab page {tabnr}.
+		When {varname} starts with "&" get the value of a window-local
+		option.
+		Tabs are numbered starting with one.  For the current tabpage
+		use |getwinvar()|.
+		When {winnr} is zero the current window is used.
+		This also works for a global option, buffer-local option and
+		window-local option, but it doesn't work for a global variable
+		or buffer-local variable.
+		When {varname} is empty a dictionary with all window-local
+		variables is returned.
+		Note that {varname} must be the name without "w:".
+		Examples: >
+			:let list_is_on = gettabwinvar(1, 2, '&list')
+			:echo "myvar = " . gettabwinvar(3, 1, 'myvar')
+<
+							*getwinposx()*
+getwinposx()	The result is a Number, which is the X coordinate in pixels of
+		the left hand side of the GUI Vim window.  The result will be
+		-1 if the information is not available.
+
+							*getwinposy()*
+getwinposy()	The result is a Number, which is the Y coordinate in pixels of
+		the top of the GUI Vim window.	The result will be -1 if the
+		information is not available.
+
+getwinvar({winnr}, {varname})				*getwinvar()*
+		Like |gettabwinvar()| for the current tabpage.
+		Examples: >
+			:let list_is_on = getwinvar(2, '&list')
+			:echo "myvar = " . getwinvar(1, 'myvar')
+<
+glob({expr} [, {flag}])					*glob()*
+		Expand the file wildcards in {expr}.  See |wildcards| for the
+		use of special characters.
+		The result is a String.
+		When there are several matches, they are separated by 
+		characters.
+		Unless the optional {flag} argument is given and is non-zero,
+		the 'suffixes' and 'wildignore' options apply: Names matching
+		one of the patterns in 'wildignore' will be skipped and
+		'suffixes' affect the ordering of matches.
+		If the expansion fails, the result is an empty string.
+		A name for a non-existing file is not included.
+
+		For most systems backticks can be used to get files names from
+		any external command.  Example: >
+			:let tagfiles = glob("`find . -name tags -print`")
+			:let &tags = substitute(tagfiles, "\n", ",", "g")
+<		The result of the program inside the backticks should be one
+		item per line.	Spaces inside an item are allowed.
+
+		See |expand()| for expanding special Vim variables.  See
+		|system()| for getting the raw output of an external command.
+
+globpath({path}, {expr} [, {flag}])			*globpath()*
+		Perform glob() on all directories in {path} and concatenate
+		the results.  Example: >
+			:echo globpath(&rtp, "syntax/c.vim")
+<		{path} is a comma-separated list of directory names.  Each
+		directory name is prepended to {expr} and expanded like with
+		|glob()|.  A path separator is inserted when needed.
+		To add a comma inside a directory name escape it with a
+		backslash.  Note that on MS-Windows a directory may have a
+		trailing backslash, remove it if you put a comma after it.
+		If the expansion fails for one of the directories, there is no
+		error message.
+		Unless the optional {flag} argument is given and is non-zero,
+		the 'suffixes' and 'wildignore' options apply: Names matching
+		one of the patterns in 'wildignore' will be skipped and
+		'suffixes' affect the ordering of matches.
+
+		The "**" item can be used to search in a directory tree.
+		For example, to find all "README.txt" files in the directories
+		in 'runtimepath' and below: >
+			:echo globpath(&rtp, "**/README.txt")
+<		Upwards search and limiting the depth of "**" is not
+		supported, thus using 'path' will not always work properly.
+
+							*has()*
+has({feature})	The result is a Number, which is 1 if the feature {feature} is
+		supported, zero otherwise.  The {feature} argument is a
+		string.  See |feature-list| below.
+		Also see |exists()|.
+
+
+has_key({dict}, {key})					*has_key()*
+		The result is a Number, which is 1 if |Dictionary| {dict} has
+		an entry with key {key}.  Zero otherwise.
+
+haslocaldir()						*haslocaldir()*
+		The result is a Number, which is 1 when the current
+		window has set a local path via |:lcd|, and 0 otherwise.
+
+hasmapto({what} [, {mode} [, {abbr}]])			*hasmapto()*
+		The result is a Number, which is 1 if there is a mapping that
+		contains {what} in somewhere in the rhs (what it is mapped to)
+		and this mapping exists in one of the modes indicated by
+		{mode}.
+		When {abbr} is there and it is non-zero use abbreviations
+		instead of mappings.  Don't forget to specify Insert and/or
+		Command-line mode.
+		Both the global mappings and the mappings local to the current
+		buffer are checked for a match.
+		If no matching mapping is found 0 is returned.
+		The following characters are recognized in {mode}:
+			n	Normal mode
+			v	Visual mode
+			o	Operator-pending mode
+			i	Insert mode
+			l	Language-Argument ("r", "f", "t", etc.)
+			c	Command-line mode
+		When {mode} is omitted, "nvo" is used.
+
+		This function is useful to check if a mapping already exists
+		to a function in a Vim script.	Example: >
+			:if !hasmapto('\ABCdoit')
+			:   map d \ABCdoit
+			:endif
+<		This installs the mapping to "\ABCdoit" only if there isn't
+		already a mapping to "\ABCdoit".
+
+histadd({history}, {item})				*histadd()*
+		Add the String {item} to the history {history} which can be
+		one of:					*hist-names*
+			"cmd"	 or ":"	  command line history
+			"search" or "/"   search pattern history
+			"expr"	 or "="   typed expression history
+			"input"  or "@"	  input line history
+		If {item} does already exist in the history, it will be
+		shifted to become the newest entry.
+		The result is a Number: 1 if the operation was successful,
+		otherwise 0 is returned.
+
+		Example: >
+			:call histadd("input", strftime("%Y %b %d"))
+			:let date=input("Enter date: ")
+<		This function is not available in the |sandbox|.
+
+histdel({history} [, {item}])				*histdel()*
+		Clear {history}, i.e. delete all its entries.  See |hist-names|
+		for the possible values of {history}.
+
+		If the parameter {item} evaluates to a String, it is used as a
+		regular expression.  All entries matching that expression will
+		be removed from the history (if there are any).
+		Upper/lowercase must match, unless "\c" is used |/\c|.
+		If {item} evaluates to a Number, it will be interpreted as
+		an index, see |:history-indexing|.  The respective entry will
+		be removed if it exists.
+
+		The result is a Number: 1 for a successful operation,
+		otherwise 0 is returned.
+
+		Examples:
+		Clear expression register history: >
+			:call histdel("expr")
+<
+		Remove all entries starting with "*" from the search history: >
+			:call histdel("/", '^\*')
+<
+		The following three are equivalent: >
+			:call histdel("search", histnr("search"))
+			:call histdel("search", -1)
+			:call histdel("search", '^'.histget("search", -1).'$')
+<
+		To delete the last search pattern and use the last-but-one for
+		the "n" command and 'hlsearch': >
+			:call histdel("search", -1)
+			:let @/ = histget("search", -1)
+
+histget({history} [, {index}])				*histget()*
+		The result is a String, the entry with Number {index} from
+		{history}.  See |hist-names| for the possible values of
+		{history}, and |:history-indexing| for {index}.  If there is
+		no such entry, an empty String is returned.  When {index} is
+		omitted, the most recent item from the history is used.
+
+		Examples:
+		Redo the second last search from history. >
+			:execute '/' . histget("search", -2)
+
+<		Define an Ex command ":H {num}" that supports re-execution of
+		the {num}th entry from the output of |:history|. >
+			:command -nargs=1 H execute histget("cmd", 0+)
+<
+histnr({history})					*histnr()*
+		The result is the Number of the current entry in {history}.
+		See |hist-names| for the possible values of {history}.
+		If an error occurred, -1 is returned.
+
+		Example: >
+			:let inp_index = histnr("expr")
+<
+hlexists({name})					*hlexists()*
+		The result is a Number, which is non-zero if a highlight group
+		called {name} exists.  This is when the group has been
+		defined in some way.  Not necessarily when highlighting has
+		been defined for it, it may also have been used for a syntax
+		item.
+							*highlight_exists()*
+		Obsolete name: highlight_exists().
+
+							*hlID()*
+hlID({name})	The result is a Number, which is the ID of the highlight group
+		with name {name}.  When the highlight group doesn't exist,
+		zero is returned.
+		This can be used to retrieve information about the highlight
+		group.	For example, to get the background color of the
+		"Comment" group: >
+	:echo synIDattr(synIDtrans(hlID("Comment")), "bg")
+<							*highlightID()*
+		Obsolete name: highlightID().
+
+hostname()						*hostname()*
+		The result is a String, which is the name of the machine on
+		which Vim is currently running.  Machine names greater than
+		256 characters long are truncated.
+
+iconv({expr}, {from}, {to})				*iconv()*
+		The result is a String, which is the text {expr} converted
+		from encoding {from} to encoding {to}.
+		When the conversion completely fails an empty string is
+		returned.  When some characters could not be converted they
+		are replaced with "?".
+		The encoding names are whatever the iconv() library function
+		can accept, see ":!man 3 iconv".
+		Most conversions require Vim to be compiled with the |+iconv|
+		feature.  Otherwise only UTF-8 to latin1 conversion and back
+		can be done.
+		This can be used to display messages with special characters,
+		no matter what 'encoding' is set to.  Write the message in
+		UTF-8 and use: >
+			echo iconv(utf8_str, "utf-8", &enc)
+<		Note that Vim uses UTF-8 for all Unicode encodings, conversion
+		from/to UCS-2 is automatically changed to use UTF-8.  You
+		cannot use UCS-2 in a string anyway, because of the NUL bytes.
+		{only available when compiled with the |+multi_byte| feature}
+
+							*indent()*
+indent({lnum})	The result is a Number, which is indent of line {lnum} in the
+		current buffer.  The indent is counted in spaces, the value
+		of 'tabstop' is relevant.  {lnum} is used just like in
+		|getline()|.
+		When {lnum} is invalid -1 is returned.
+
+
+index({list}, {expr} [, {start} [, {ic}]])			*index()*
+		Return the lowest index in |List| {list} where the item has a
+		value equal to {expr}.  There is no automatic conversion, so
+		the String "4" is different from the Number 4.  And the number
+		4 is different from the Float 4.0.  The value of 'ignorecase'
+		is not used here, case always matters.
+		If {start} is given then start looking at the item with index
+		{start} (may be negative for an item relative to the end).
+		When {ic} is given and it is non-zero, ignore case.  Otherwise
+		case must match.
+		-1 is returned when {expr} is not found in {list}.
+		Example: >
+			:let idx = index(words, "the")
+			:if index(numbers, 123) >= 0
+
+
+input({prompt} [, {text} [, {completion}]])		*input()*
+		The result is a String, which is whatever the user typed on
+		the command-line.  The {prompt} argument is either a prompt
+		string, or a blank string (for no prompt).  A '\n' can be used
+		in the prompt to start a new line.
+		The highlighting set with |:echohl| is used for the prompt.
+		The input is entered just like a command-line, with the same
+		editing commands and mappings.	There is a separate history
+		for lines typed for input().
+		Example: >
+			:if input("Coffee or beer? ") == "beer"
+			:  echo "Cheers!"
+			:endif
+<
+		If the optional {text} argument is present and not empty, this
+		is used for the default reply, as if the user typed this.
+		Example: >
+			:let color = input("Color? ", "white")
+
+<		The optional {completion} argument specifies the type of
+		completion supported for the input.  Without it completion is
+		not performed.	The supported completion types are the same as
+		that can be supplied to a user-defined command using the
+		"-complete=" argument.	Refer to |:command-completion| for
+		more information.  Example: >
+			let fname = input("File: ", "", "file")
+<
+		NOTE: This function must not be used in a startup file, for
+		the versions that only run in GUI mode (e.g., the Win32 GUI).
+		Note: When input() is called from within a mapping it will
+		consume remaining characters from that mapping, because a
+		mapping is handled like the characters were typed.
+		Use |inputsave()| before input() and |inputrestore()|
+		after input() to avoid that.  Another solution is to avoid
+		that further characters follow in the mapping, e.g., by using
+		|:execute| or |:normal|.
+
+		Example with a mapping: >
+			:nmap \x :call GetFoo():exe "/" . Foo
+			:function GetFoo()
+			:  call inputsave()
+			:  let g:Foo = input("enter search pattern: ")
+			:  call inputrestore()
+			:endfunction
+
+inputdialog({prompt} [, {text} [, {cancelreturn}]])		*inputdialog()*
+		Like |input()|, but when the GUI is running and text dialogs
+		are supported, a dialog window pops up to input the text.
+		Example: >
+			:let n = inputdialog("value for shiftwidth", &sw)
+			:if n != ""
+			:  let &sw = n
+			:endif
+<		When the dialog is cancelled {cancelreturn} is returned.  When
+		omitted an empty string is returned.
+		Hitting  works like pressing the OK button.  Hitting
+		 works like pressing the Cancel button.
+		NOTE: Command-line completion is not supported.
+
+inputlist({textlist})					*inputlist()*
+		{textlist} must be a |List| of strings.  This |List| is
+		displayed, one string per line.  The user will be prompted to
+		enter a number, which is returned.
+		The user can also select an item by clicking on it with the
+		mouse.	For the first string 0 is returned.  When clicking
+		above the first item a negative number is returned.  When
+		clicking on the prompt one more than the length of {textlist}
+		is returned.
+		Make sure {textlist} has less than 'lines' entries, otherwise
+		it won't work.	It's a good idea to put the entry number at
+		the start of the string.  And put a prompt in the first item.
+		Example: >
+			let color = inputlist(['Select color:', '1. red',
+				\ '2. green', '3. blue'])
+
+inputrestore()						*inputrestore()*
+		Restore typeahead that was saved with a previous |inputsave()|.
+		Should be called the same number of times inputsave() is
+		called.  Calling it more often is harmless though.
+		Returns 1 when there is nothing to restore, 0 otherwise.
+
+inputsave()						*inputsave()*
+		Preserve typeahead (also from mappings) and clear it, so that
+		a following prompt gets input from the user.  Should be
+		followed by a matching inputrestore() after the prompt.  Can
+		be used several times, in which case there must be just as
+		many inputrestore() calls.
+		Returns 1 when out of memory, 0 otherwise.
+
+inputsecret({prompt} [, {text}])			*inputsecret()*
+		This function acts much like the |input()| function with but
+		two exceptions:
+		a) the user's response will be displayed as a sequence of
+		asterisks ("*") thereby keeping the entry secret, and
+		b) the user's response will not be recorded on the input
+		|history| stack.
+		The result is a String, which is whatever the user actually
+		typed on the command-line in response to the issued prompt.
+		NOTE: Command-line completion is not supported.
+
+insert({list}, {item} [, {idx}])			*insert()*
+		Insert {item} at the start of |List| {list}.
+		If {idx} is specified insert {item} before the item with index
+		{idx}.	If {idx} is zero it goes before the first item, just
+		like omitting {idx}.  A negative {idx} is also possible, see
+		|list-index|.  -1 inserts just before the last item.
+		Returns the resulting |List|.  Examples: >
+			:let mylist = insert([2, 3, 5], 1)
+			:call insert(mylist, 4, -1)
+			:call insert(mylist, 6, len(mylist))
+<		The last example can be done simpler with |add()|.
+		Note that when {item} is a |List| it is inserted as a single
+		item.  Use |extend()| to concatenate |Lists|.
+
+isdirectory({directory})				*isdirectory()*
+		The result is a Number, which is non-zero when a directory
+		with the name {directory} exists.  If {directory} doesn't
+		exist, or isn't a directory, the result is FALSE.  {directory}
+		is any expression, which is used as a String.
+
+islocked({expr})					*islocked()* *E786*
+		The result is a Number, which is non-zero when {expr} is the
+		name of a locked variable.
+		{expr} must be the name of a variable, |List| item or
+		|Dictionary| entry, not the variable itself!  Example: >
+			:let alist = [0, ['a', 'b'], 2, 3]
+			:lockvar 1 alist
+			:echo islocked('alist')		" 1
+			:echo islocked('alist[1]')	" 0
+
+<		When {expr} is a variable that does not exist you get an error
+		message.  Use |exists()| to check for existence.
+
+items({dict})						*items()*
+		Return a |List| with all the key-value pairs of {dict}.  Each
+		|List| item is a list with two items: the key of a {dict}
+		entry and the value of this entry.  The |List| is in arbitrary
+		order.
+
+
+join({list} [, {sep}])					*join()*
+		Join the items in {list} together into one String.
+		When {sep} is specified it is put in between the items.  If
+		{sep} is omitted a single space is used.
+		Note that {sep} is not added at the end.  You might want to
+		add it there too: >
+			let lines = join(mylist, "\n") . "\n"
+<		String items are used as-is.  |Lists| and |Dictionaries| are
+		converted into a string like with |string()|.
+		The opposite function is |split()|.
+
+keys({dict})						*keys()*
+		Return a |List| with all the keys of {dict}.  The |List| is in
+		arbitrary order.
+
+							*len()* *E701*
+len({expr})	The result is a Number, which is the length of the argument.
+		When {expr} is a String or a Number the length in bytes is
+		used, as with |strlen()|.
+		When {expr} is a |List| the number of items in the |List| is
+		returned.
+		When {expr} is a |Dictionary| the number of entries in the
+		|Dictionary| is returned.
+		Otherwise an error is given.
+
+						*libcall()* *E364* *E368*
+libcall({libname}, {funcname}, {argument})
+		Call function {funcname} in the run-time library {libname}
+		with single argument {argument}.
+		This is useful to call functions in a library that you
+		especially made to be used with Vim.  Since only one argument
+		is possible, calling standard library functions is rather
+		limited.
+		The result is the String returned by the function.  If the
+		function returns NULL, this will appear as an empty string ""
+		to Vim.
+		If the function returns a number, use libcallnr()!
+		If {argument} is a number, it is passed to the function as an
+		int; if {argument} is a string, it is passed as a
+		null-terminated string.
+		This function will fail in |restricted-mode|.
+
+		libcall() allows you to write your own 'plug-in' extensions to
+		Vim without having to recompile the program.  It is NOT a
+		means to call system functions!  If you try to do so Vim will
+		very probably crash.
+
+		For Win32, the functions you write must be placed in a DLL
+		and use the normal C calling convention (NOT Pascal which is
+		used in Windows System DLLs).  The function must take exactly
+		one parameter, either a character pointer or a long integer,
+		and must return a character pointer or NULL.  The character
+		pointer returned must point to memory that will remain valid
+		after the function has returned (e.g. in static data in the
+		DLL).  If it points to allocated memory, that memory will
+		leak away.  Using a static buffer in the function should work,
+		it's then freed when the DLL is unloaded.
+
+		WARNING: If the function returns a non-valid pointer, Vim may
+		crash!	This also happens if the function returns a number,
+		because Vim thinks it's a pointer.
+		For Win32 systems, {libname} should be the filename of the DLL
+		without the ".DLL" suffix.  A full path is only required if
+		the DLL is not in the usual places.
+		For Unix: When compiling your own plugins, remember that the
+		object code must be compiled as position-independent ('PIC').
+		{only in Win32 and some Unix versions, when the |+libcall|
+		feature is present}
+		Examples: >
+			:echo libcall("libc.so", "getenv", "HOME")
+<
+							*libcallnr()*
+libcallnr({libname}, {funcname}, {argument})
+		Just like |libcall()|, but used for a function that returns an
+		int instead of a string.
+		{only in Win32 on some Unix versions, when the |+libcall|
+		feature is present}
+		Examples: >
+			:echo libcallnr("/usr/lib/libc.so", "getpid", "")
+			:call libcallnr("libc.so", "printf", "Hello World!\n")
+			:call libcallnr("libc.so", "sleep", 10)
+<
+							*line()*
+line({expr})	The result is a Number, which is the line number of the file
+		position given with {expr}.  The accepted positions are:
+		    .	    the cursor position
+		    $	    the last line in the current buffer
+		    'x	    position of mark x (if the mark is not set, 0 is
+			    returned)
+		    w0	    first line visible in current window
+		    w$	    last line visible in current window
+		    v	    In Visual mode: the start of the Visual area (the
+			    cursor is the end).  When not in Visual mode
+			    returns the cursor position.  Differs from |'<| in
+			    that it's updated right away.
+		Note that a mark in another file can be used.  The line number
+		then applies to another buffer.
+		To get the column number use |col()|.  To get both use
+		|getpos()|.
+		Examples: >
+			line(".")		line number of the cursor
+			line("'t")		line number of mark t
+			line("'" . marker)	line number of mark marker
+<							*last-position-jump*
+		This autocommand jumps to the last known position in a file
+		just after opening it, if the '" mark is set: >
+	:au BufReadPost * if line("'\"") > 1 && line("'\"") <= line("$") | exe "normal! g`\"" | endif
+
+line2byte({lnum})					*line2byte()*
+		Return the byte count from the start of the buffer for line
+		{lnum}.  This includes the end-of-line character, depending on
+		the 'fileformat' option for the current buffer.  The first
+		line returns 1.
+		This can also be used to get the byte count for the line just
+		below the last line: >
+			line2byte(line("$") + 1)
+<		This is the file size plus one.
+		When {lnum} is invalid, or the |+byte_offset| feature has been
+		disabled at compile time, -1 is returned.
+		Also see |byte2line()|, |go| and |:goto|.
+
+lispindent({lnum})					*lispindent()*
+		Get the amount of indent for line {lnum} according the lisp
+		indenting rules, as with 'lisp'.
+		The indent is counted in spaces, the value of 'tabstop' is
+		relevant.  {lnum} is used just like in |getline()|.
+		When {lnum} is invalid or Vim was not compiled the
+		|+lispindent| feature, -1 is returned.
+
+localtime()						*localtime()*
+		Return the current time, measured as seconds since 1st Jan
+		1970.  See also |strftime()| and |getftime()|.
+
+
+log({expr})						*log()*
+		Return the natural logarithm (base e) of {expr} as a |Float|.
+		{expr} must evaluate to a |Float| or a |Number| in the range
+		(0, inf].
+		Examples: >
+			:echo log(10)
+<			2.302585 >
+			:echo log(exp(5))
+<			5.0
+		{only available when compiled with the |+float| feature}
+
+
+log10({expr})						*log10()*
+		Return the logarithm of Float {expr} to base 10 as a |Float|.
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo log10(1000)
+<			3.0 >
+			:echo log10(0.01)
+<			-2.0
+		{only available when compiled with the |+float| feature}
+		
+map({expr}, {string})					*map()*
+		{expr} must be a |List| or a |Dictionary|.
+		Replace each item in {expr} with the result of evaluating
+		{string}.
+		Inside {string} |v:val| has the value of the current item.
+		For a |Dictionary| |v:key| has the key of the current item
+		and for a |List| |v:key| has the index of the current item.
+		Example: >
+			:call map(mylist, '"> " . v:val . " <"')
+<		This puts "> " before and " <" after each item in "mylist".
+
+		Note that {string} is the result of an expression and is then
+		used as an expression again.  Often it is good to use a
+		|literal-string| to avoid having to double backslashes.  You
+		still have to double ' quotes
+
+		The operation is done in-place.  If you want a |List| or
+		|Dictionary| to remain unmodified make a copy first: >
+			:let tlist = map(copy(mylist), ' & . "\t"')
+
+<		Returns {expr}, the |List| or |Dictionary| that was filtered.
+		When an error is encountered while evaluating {string} no
+		further items in {expr} are processed.
+
+
+maparg({name}[, {mode} [, {abbr}]])			*maparg()*
+		Return the rhs of mapping {name} in mode {mode}.  When there
+		is no mapping for {name}, an empty String is returned.
+		{mode} can be one of these strings:
+			"n"	Normal
+			"v"	Visual
+			"o"	Operator-pending
+			"i"	Insert
+			"c"	Cmd-line
+			"l"	langmap |language-mapping|
+			""	Normal, Visual and Operator-pending
+		When {mode} is omitted, the modes for "" are used.
+		When {abbr} is there and it is non-zero use abbreviations
+		instead of mappings.
+		The {name} can have special key names, like in the ":map"
+		command.  The returned String has special characters
+		translated like in the output of the ":map" command listing.
+		The mappings local to the current buffer are checked first,
+		then the global mappings.
+		This function can be used to map a key even when it's already
+		mapped, and have it do the original mapping too.  Sketch: >
+			exe 'nnoremap  ==' . maparg('', 'n')
+
+
+mapcheck({name}[, {mode} [, {abbr}]])			*mapcheck()*
+		Check if there is a mapping that matches with {name} in mode
+		{mode}.  See |maparg()| for {mode} and special names in
+		{name}.
+		When {abbr} is there and it is non-zero use abbreviations
+		instead of mappings.
+		A match happens with a mapping that starts with {name} and
+		with a mapping which is equal to the start of {name}.
+
+			matches mapping "a"	"ab"	"abc" ~
+		   mapcheck("a")	yes	yes	 yes
+		   mapcheck("abc")	yes	yes	 yes
+		   mapcheck("ax")	yes	no	 no
+		   mapcheck("b")	no	no	 no
+
+		The difference with maparg() is that mapcheck() finds a
+		mapping that matches with {name}, while maparg() only finds a
+		mapping for {name} exactly.
+		When there is no mapping that starts with {name}, an empty
+		String is returned.  If there is one, the rhs of that mapping
+		is returned.  If there are several mappings that start with
+		{name}, the rhs of one of them is returned.
+		The mappings local to the current buffer are checked first,
+		then the global mappings.
+		This function can be used to check if a mapping can be added
+		without being ambiguous.  Example: >
+	:if mapcheck("_vv") == ""
+	:   map _vv :set guifont=7x13
+	:endif
+<		This avoids adding the "_vv" mapping when there already is a
+		mapping for "_v" or for "_vvv".
+
+match({expr}, {pat}[, {start}[, {count}]])			*match()*
+		When {expr} is a |List| then this returns the index of the
+		first item where {pat} matches.  Each item is used as a
+		String, |Lists| and |Dictionaries| are used as echoed.
+		Otherwise, {expr} is used as a String.	The result is a
+		Number, which gives the index (byte offset) in {expr} where
+		{pat} matches.
+		A match at the first character or |List| item returns zero.
+		If there is no match -1 is returned.
+		Example: >
+			:echo match("testing", "ing")	" results in 4
+			:echo match([1, 'x'], '\a')	" results in 1
+<		See |string-match| for how {pat} is used.
+								*strpbrk()*
+		Vim doesn't have a strpbrk() function.	But you can do: >
+			:let sepidx = match(line, '[.,;: \t]')
+<								*strcasestr()*
+		Vim doesn't have a strcasestr() function.  But you can add
+		"\c" to the pattern to ignore case: >
+			:let idx = match(haystack, '\cneedle')
+<
+		If {start} is given, the search starts from byte index
+		{start} in a String or item {start} in a |List|.
+		The result, however, is still the index counted from the
+		first character/item.  Example: >
+			:echo match("testing", "ing", 2)
+<		result is again "4". >
+			:echo match("testing", "ing", 4)
+<		result is again "4". >
+			:echo match("testing", "t", 2)
+<		result is "3".
+		For a String, if {start} > 0 then it is like the string starts
+		{start} bytes later, thus "^" will match at {start}.  Except
+		when {count} is given, then it's like matches before the
+		{start} byte are ignored (this is a bit complicated to keep it
+		backwards compatible).
+		For a String, if {start} < 0, it will be set to 0.  For a list
+		the index is counted from the end.
+		If {start} is out of range ({start} > strlen({expr}) for a
+		String or {start} > len({expr}) for a |List|) -1 is returned.
+
+		When {count} is given use the {count}'th match.  When a match
+		is found in a String the search for the next one starts one
+		character further.  Thus this example results in 1: >
+			echo match("testing", "..", 0, 2)
+<		In a |List| the search continues in the next item.
+		Note that when {count} is added the way {start} works changes,
+		see above.
+
+		See |pattern| for the patterns that are accepted.
+		The 'ignorecase' option is used to set the ignore-caseness of
+		the pattern.  'smartcase' is NOT used.	The matching is always
+		done like 'magic' is set and 'cpoptions' is empty.
+
+					*matchadd()* *E798* *E799* *E801*
+matchadd({group}, {pattern}[, {priority}[, {id}]])
+		Defines a pattern to be highlighted in the current window (a
+		"match").  It will be highlighted with {group}.  Returns an
+		identification number (ID), which can be used to delete the
+		match using |matchdelete()|.
+
+		The optional {priority} argument assigns a priority to the
+		match.	A match with a high priority will have its
+		highlighting overrule that of a match with a lower priority.
+		A priority is specified as an integer (negative numbers are no
+		exception).  If the {priority} argument is not specified, the
+		default priority is 10.  The priority of 'hlsearch' is zero,
+		hence all matches with a priority greater than zero will
+		overrule it.  Syntax highlighting (see 'syntax') is a separate
+		mechanism, and regardless of the chosen priority a match will
+		always overrule syntax highlighting.
+
+		The optional {id} argument allows the request for a specific
+		match ID.  If a specified ID is already taken, an error
+		message will appear and the match will not be added.  An ID
+		is specified as a positive integer (zero excluded).  IDs 1, 2
+		and 3 are reserved for |:match|, |:2match| and |:3match|,
+		respectively.  If the {id} argument is not specified,
+		|matchadd()| automatically chooses a free ID.
+
+		The number of matches is not limited, as it is the case with
+		the |:match| commands.
+
+		Example: >
+			:highlight MyGroup ctermbg=green guibg=green
+			:let m = matchadd("MyGroup", "TODO")
+<		Deletion of the pattern: >
+			:call matchdelete(m)
+
+<		A list of matches defined by |matchadd()| and |:match| are
+		available from |getmatches()|.	All matches can be deleted in
+		one operation by |clearmatches()|.
+
+matcharg({nr})							*matcharg()*
+		Selects the {nr} match item, as set with a |:match|,
+		|:2match| or |:3match| command.
+		Return a |List| with two elements:
+			The name of the highlight group used
+			The pattern used.
+		When {nr} is not 1, 2 or 3 returns an empty |List|.
+		When there is no match item set returns ['', ''].
+		This is useful to save and restore a |:match|.
+		Highlighting matches using the |:match| commands are limited
+		to three matches. |matchadd()| does not have this limitation.
+
+matchdelete({id})			       *matchdelete()* *E802* *E803*
+		Deletes a match with ID {id} previously defined by |matchadd()|
+		or one of the |:match| commands.  Returns 0 if successful,
+		otherwise -1.  See example for |matchadd()|.  All matches can
+		be deleted in one operation by |clearmatches()|.
+
+matchend({expr}, {pat}[, {start}[, {count}]])			*matchend()*
+		Same as |match()|, but return the index of first character
+		after the match.  Example: >
+			:echo matchend("testing", "ing")
+<		results in "7".
+							*strspn()* *strcspn()*
+		Vim doesn't have a strspn() or strcspn() function, but you can
+		do it with matchend(): >
+			:let span = matchend(line, '[a-zA-Z]')
+			:let span = matchend(line, '[^a-zA-Z]')
+<		Except that -1 is returned when there are no matches.
+
+		The {start}, if given, has the same meaning as for |match()|. >
+			:echo matchend("testing", "ing", 2)
+<		results in "7". >
+			:echo matchend("testing", "ing", 5)
+<		result is "-1".
+		When {expr} is a |List| the result is equal to |match()|.
+
+matchlist({expr}, {pat}[, {start}[, {count}]])			*matchlist()*
+		Same as |match()|, but return a |List|.  The first item in the
+		list is the matched string, same as what matchstr() would
+		return.  Following items are submatches, like "\1", "\2", etc.
+		in |:substitute|.  When an optional submatch didn't match an
+		empty string is used.  Example: >
+			echo matchlist('acd', '\(a\)\?\(b\)\?\(c\)\?\(.*\)')
+<		Results in: ['acd', 'a', '', 'c', 'd', '', '', '', '', '']
+		When there is no match an empty list is returned.
+
+matchstr({expr}, {pat}[, {start}[, {count}]])			*matchstr()*
+		Same as |match()|, but return the matched string.  Example: >
+			:echo matchstr("testing", "ing")
+<		results in "ing".
+		When there is no match "" is returned.
+		The {start}, if given, has the same meaning as for |match()|. >
+			:echo matchstr("testing", "ing", 2)
+<		results in "ing". >
+			:echo matchstr("testing", "ing", 5)
+<		result is "".
+		When {expr} is a |List| then the matching item is returned.
+		The type isn't changed, it's not necessarily a String.
+
+							*max()*
+max({list})	Return the maximum value of all items in {list}.
+		If {list} is not a list or one of the items in {list} cannot
+		be used as a Number this results in an error.
+		An empty |List| results in zero.
+
+							*min()*
+min({list})	Return the minimum value of all items in {list}.
+		If {list} is not a list or one of the items in {list} cannot
+		be used as a Number this results in an error.
+		An empty |List| results in zero.
+
+							*mkdir()* *E739*
+mkdir({name} [, {path} [, {prot}]])
+		Create directory {name}.
+		If {path} is "p" then intermediate directories are created as
+		necessary.  Otherwise it must be "".
+		If {prot} is given it is used to set the protection bits of
+		the new directory.  The default is 0755 (rwxr-xr-x: r/w for
+		the user readable for others).	Use 0700 to make it unreadable
+		for others.  This is only used for the last part of {name}.
+		Thus if you create /tmp/foo/bar then /tmp/foo will be created
+		with 0755.
+		Example: >
+			:call mkdir($HOME . "/tmp/foo/bar", "p", 0700)
+<		This function is not available in the |sandbox|.
+		Not available on all systems.  To check use: >
+			:if exists("*mkdir")
+<
+							*mode()*
+mode([expr])	Return a string that indicates the current mode.
+		If [expr] is supplied and it evaluates to a non-zero Number or
+		a non-empty String (|non-zero-arg|), then the full mode is
+		returned, otherwise only the first letter is returned.  Note
+		that " " and "0" are also non-empty strings.
+
+			n	Normal
+			no	Operator-pending
+			v	Visual by character
+			V	Visual by line
+			CTRL-V	Visual blockwise
+			s	Select by character
+			S	Select by line
+			CTRL-S	Select blockwise
+			i	Insert
+			R	Replace |R|
+			Rv	Virtual Replace |gR|
+			c	Command-line
+			cv	Vim Ex mode |gQ|
+			ce	Normal Ex mode |Q|
+			r	Hit-enter prompt
+			rm	The -- more -- prompt
+			r?	A |:confirm| query of some sort
+			!	Shell or external command is executing
+		This is useful in the 'statusline' option or when used
+		with |remote_expr()| In most other places it always returns
+		"c" or "n".
+		Also see |visualmode()|.
+
+mzeval({expr})							*mzeval()*
+		Evaluate MzScheme expression {expr} and return its result
+		convert to Vim data structures.
+		Numbers and strings are returned as they are.
+		Pairs (including lists and improper lists) and vectors are
+		returned as Vim |Lists|.
+		Hash tables are represented as Vim |Dictionary| type with keys
+		converted to strings.
+		All other types are converted to string with display function.
+		Examples: >
+		    :mz (define l (list 1 2 3))
+		    :mz (define h (make-hash)) (hash-set! h "list" l)
+		    :echo mzeval("l")
+		    :echo mzeval("h")
+<
+		{only available when compiled with the |+mzscheme| feature}
+
+nextnonblank({lnum})					*nextnonblank()*
+		Return the line number of the first line at or below {lnum}
+		that is not blank.  Example: >
+			if getline(nextnonblank(1)) =~ "Java"
+<		When {lnum} is invalid or there is no non-blank line at or
+		below it, zero is returned.
+		See also |prevnonblank()|.
+
+nr2char({expr})						*nr2char()*
+		Return a string with a single character, which has the number
+		value {expr}.  Examples: >
+			nr2char(64)		returns "@"
+			nr2char(32)		returns " "
+<		The current 'encoding' is used.  Example for "utf-8": >
+			nr2char(300)		returns I with bow character
+<		Note that a NUL character in the file is specified with
+		nr2char(10), because NULs are represented with newline
+		characters.  nr2char(0) is a real NUL and terminates the
+		string, thus results in an empty string.
+
+							*getpid()*
+getpid()	Return a Number which is the process ID of the Vim process.
+		On Unix and MS-Windows this is a unique number, until Vim
+		exits.	On MS-DOS it's always zero.
+
+							*getpos()*
+getpos({expr})	Get the position for {expr}.  For possible values of {expr}
+		see |line()|.
+		The result is a |List| with four numbers:
+		    [bufnum, lnum, col, off]
+		"bufnum" is zero, unless a mark like '0 or 'A is used, then it
+		is the buffer number of the mark.
+		"lnum" and "col" are the position in the buffer.  The first
+		column is 1.
+		The "off" number is zero, unless 'virtualedit' is used.  Then
+		it is the offset in screen columns from the start of the
+		character.  E.g., a position within a  or after the last
+		character.
+		This can be used to save and restore the cursor position: >
+			let save_cursor = getpos(".")
+			MoveTheCursorAround
+			call setpos('.', save_cursor)
+<		Also see |setpos()|.
+
+pathshorten({expr})					*pathshorten()*
+		Shorten directory names in the path {expr} and return the
+		result.  The tail, the file name, is kept as-is.  The other
+		components in the path are reduced to single letters.  Leading
+		'~' and '.' characters are kept.  Example: >
+			:echo pathshorten('~/.vim/autoload/myfile.vim')
+<			~/.v/a/myfile.vim ~
+		It doesn't matter if the path exists or not.
+
+pow({x}, {y})						*pow()*
+		Return the power of {x} to the exponent {y} as a |Float|.
+		{x} and {y} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo pow(3, 3)
+<			27.0 >
+			:echo pow(2, 16)
+<			65536.0 >
+			:echo pow(32, 0.20)
+<			2.0
+		{only available when compiled with the |+float| feature}
+		
+prevnonblank({lnum})					*prevnonblank()*
+		Return the line number of the first line at or above {lnum}
+		that is not blank.  Example: >
+			let ind = indent(prevnonblank(v:lnum - 1))
+<		When {lnum} is invalid or there is no non-blank line at or
+		above it, zero is returned.
+		Also see |nextnonblank()|.
+
+
+printf({fmt}, {expr1} ...)				*printf()*
+		Return a String with {fmt}, where "%" items are replaced by
+		the formatted form of their respective arguments.  Example: >
+			printf("%4d: E%d %.30s", lnum, errno, msg)
+<		May result in:
+			"  99: E42 asdfasdfasdfasdfasdfasdfasdfas" ~
+
+		Often used items are:
+		  %s	string
+		  %6s	string right-aligned in 6 bytes
+		  %.9s	string truncated to 9 bytes
+		  %c	single byte
+		  %d	decimal number
+		  %5d	decimal number padded with spaces to 5 characters
+		  %x	hex number
+		  %04x	hex number padded with zeros to at least 4 characters
+		  %X	hex number using upper case letters
+		  %o	octal number
+		  %f	floating point number in the form 123.456
+		  %e	floating point number in the form 1.234e3
+		  %E	floating point number in the form 1.234E3
+		  %g	floating point number, as %f or %e depending on value
+		  %G	floating point number, as %f or %E depending on value
+		  %%	the % character itself
+
+		Conversion specifications start with '%' and end with the
+		conversion type.  All other characters are copied unchanged to
+		the result.
+
+		The "%" starts a conversion specification.  The following
+		arguments appear in sequence:
+
+			%  [flags]  [field-width]  [.precision]  type
+
+		flags
+			Zero or more of the following flags:
+
+		    #	      The value should be converted to an "alternate
+			      form".  For c, d, and s conversions, this option
+			      has no effect.  For o conversions, the precision
+			      of the number is increased to force the first
+			      character of the output string to a zero (except
+			      if a zero value is printed with an explicit
+			      precision of zero).
+			      For x and X conversions, a non-zero result has
+			      the string "0x" (or "0X" for X conversions)
+			      prepended to it.
+
+		    0 (zero)  Zero padding.  For all conversions the converted
+			      value is padded on the left with zeros rather
+			      than blanks.  If a precision is given with a
+			      numeric conversion (d, o, x, and X), the 0 flag
+			      is ignored.
+
+		    -	      A negative field width flag; the converted value
+			      is to be left adjusted on the field boundary.
+			      The converted value is padded on the right with
+			      blanks, rather than on the left with blanks or
+			      zeros.  A - overrides a 0 if both are given.
+
+		    ' ' (space)  A blank should be left before a positive
+			      number produced by a signed conversion (d).
+
+		    +	      A sign must always be placed before a number
+			      produced by a signed conversion.	A + overrides
+			      a space if both are used.
+
+		field-width
+			An optional decimal digit string specifying a minimum
+			field width.  If the converted value has fewer bytes
+			than the field width, it will be padded with spaces on
+			the left (or right, if the left-adjustment flag has
+			been given) to fill out the field width.
+
+		.precision
+			An optional precision, in the form of a period '.'
+			followed by an optional digit string.  If the digit
+			string is omitted, the precision is taken as zero.
+			This gives the minimum number of digits to appear for
+			d, o, x, and X conversions, or the maximum number of
+			bytes to be printed from a string for s conversions.
+			For floating point it is the number of digits after
+			the decimal point.
+
+		type
+			A character that specifies the type of conversion to
+			be applied, see below.
+
+		A field width or precision, or both, may be indicated by an
+		asterisk '*' instead of a digit string.  In this case, a
+		Number argument supplies the field width or precision.	A
+		negative field width is treated as a left adjustment flag
+		followed by a positive field width; a negative precision is
+		treated as though it were missing.  Example: >
+			:echo printf("%d: %.*s", nr, width, line)
+<		This limits the length of the text used from "line" to
+		"width" bytes.
+
+		The conversion specifiers and their meanings are:
+
+				*printf-d* *printf-o* *printf-x* *printf-X*
+		doxX	The Number argument is converted to signed decimal
+			(d), unsigned octal (o), or unsigned hexadecimal (x
+			and X) notation.  The letters "abcdef" are used for
+			x conversions; the letters "ABCDEF" are used for X
+			conversions.
+			The precision, if any, gives the minimum number of
+			digits that must appear; if the converted value
+			requires fewer digits, it is padded on the left with
+			zeros.
+			In no case does a non-existent or small field width
+			cause truncation of a numeric field; if the result of
+			a conversion is wider than the field width, the field
+			is expanded to contain the conversion result.
+
+							*printf-c*
+		c	The Number argument is converted to a byte, and the
+			resulting character is written.
+
+							*printf-s*
+		s	The text of the String argument is used.  If a
+			precision is specified, no more bytes than the number
+			specified are used.
+
+							*printf-f* *E807*
+		f	The Float argument is converted into a string of the 
+			form 123.456.  The precision specifies the number of
+			digits after the decimal point.  When the precision is
+			zero the decimal point is omitted.  When the precision
+			is not specified 6 is used.  A really big number
+			(out of range or dividing by zero) results in "inf".
+			"0.0 / 0.0" results in "nan".
+			Example: >
+				echo printf("%.2f", 12.115)
+<				12.12
+			Note that roundoff depends on the system libraries.
+			Use |round()| when in doubt.
+
+							*printf-e* *printf-E*
+		e E	The Float argument is converted into a string of the
+			form 1.234e+03 or 1.234E+03 when using 'E'.  The
+			precision specifies the number of digits after the
+			decimal point, like with 'f'.
+
+							*printf-g* *printf-G*
+		g G	The Float argument is converted like with 'f' if the
+			value is between 0.001 (inclusive) and 10000000.0
+			(exclusive).  Otherwise 'e' is used for 'g' and 'E'
+			for 'G'.  When no precision is specified superfluous
+			zeroes and '+' signs are removed, except for the zero
+			immediately after the decimal point.  Thus 10000000.0
+			results in 1.0e7.
+
+							*printf-%*
+		%	A '%' is written.  No argument is converted.  The
+			complete conversion specification is "%%".
+
+		When a Number argument is expected a String argument is also
+		accepted and automatically converted.
+		When a Float or String argument is expected a Number argument
+		is also accepted and automatically converted.
+		Any other argument type results in an error message.
+
+							*E766* *E767*
+		The number of {exprN} arguments must exactly match the number
+		of "%" items.  If there are not sufficient or too many
+		arguments an error is given.  Up to 18 arguments can be used.
+
+
+pumvisible()						*pumvisible()*
+		Returns non-zero when the popup menu is visible, zero
+		otherwise.  See |ins-completion-menu|.
+		This can be used to avoid some things that would remove the
+		popup menu.
+
+							*E726* *E727*
+range({expr} [, {max} [, {stride}]])				*range()*
+		Returns a |List| with Numbers:
+		- If only {expr} is specified: [0, 1, ..., {expr} - 1]
+		- If {max} is specified: [{expr}, {expr} + 1, ..., {max}]
+		- If {stride} is specified: [{expr}, {expr} + {stride}, ...,
+		  {max}] (increasing {expr} with {stride} each time, not
+		  producing a value past {max}).
+		When the maximum is one before the start the result is an
+		empty list.  When the maximum is more than one before the
+		start this is an error.
+		Examples: >
+			range(4)		" [0, 1, 2, 3]
+			range(2, 4)		" [2, 3, 4]
+			range(2, 9, 3)		" [2, 5, 8]
+			range(2, -2, -1)	" [2, 1, 0, -1, -2]
+			range(0)		" []
+			range(2, 0)		" error!
+<
+							*readfile()*
+readfile({fname} [, {binary} [, {max}]])
+		Read file {fname} and return a |List|, each line of the file
+		as an item.  Lines broken at NL characters.  Macintosh files
+		separated with CR will result in a single long line (unless a
+		NL appears somewhere).
+		All NUL characters are replaced with a NL character.
+		When {binary} is equal to "b" binary mode is used:
+		- When the last line ends in a NL an extra empty list item is
+		  added.
+		- No CR characters are removed.
+		Otherwise:
+		- CR characters that appear before a NL are removed.
+		- Whether the last line ends in a NL or not does not matter.
+		- When 'encoding' is Unicode any UTF-8 byte order mark is
+		  removed from the text.
+		When {max} is given this specifies the maximum number of lines
+		to be read.  Useful if you only want to check the first ten
+		lines of a file: >
+			:for line in readfile(fname, '', 10)
+			:  if line =~ 'Date' | echo line | endif
+			:endfor
+<		When {max} is negative -{max} lines from the end of the file
+		are returned, or as many as there are.
+		When {max} is zero the result is an empty list.
+		Note that without {max} the whole file is read into memory.
+		Also note that there is no recognition of encoding.  Read a
+		file into a buffer if you need to.
+		When the file can't be opened an error message is given and
+		the result is an empty list.
+		Also see |writefile()|.
+
+reltime([{start} [, {end}]])				*reltime()*
+		Return an item that represents a time value.  The format of
+		the item depends on the system.  It can be passed to
+		|reltimestr()| to convert it to a string.
+		Without an argument it returns the current time.
+		With one argument is returns the time passed since the time
+		specified in the argument.
+		With two arguments it returns the time passed between {start}
+		and {end}.
+		The {start} and {end} arguments must be values returned by
+		reltime().
+		{only available when compiled with the |+reltime| feature}
+
+reltimestr({time})				*reltimestr()*
+		Return a String that represents the time value of {time}.
+		This is the number of seconds, a dot and the number of
+		microseconds.  Example: >
+			let start = reltime()
+			call MyFunction()
+			echo reltimestr(reltime(start))
+<		Note that overhead for the commands will be added to the time.
+		The accuracy depends on the system.
+		Leading spaces are used to make the string align nicely.  You
+		can use split() to remove it. >
+			echo split(reltimestr(reltime(start)))[0]
+<		Also see |profiling|.
+		{only available when compiled with the |+reltime| feature}
+
+							*remote_expr()* *E449*
+remote_expr({server}, {string} [, {idvar}])
+		Send the {string} to {server}.	The string is sent as an
+		expression and the result is returned after evaluation.
+		The result must be a String or a |List|.  A |List| is turned
+		into a String by joining the items with a line break in
+		between (not at the end), like with join(expr, "\n").
+		If {idvar} is present, it is taken as the name of a
+		variable and a {serverid} for later use with
+		remote_read() is stored there.
+		See also |clientserver| |RemoteReply|.
+		This function is not available in the |sandbox|.
+		{only available when compiled with the |+clientserver| feature}
+		Note: Any errors will cause a local error message to be issued
+		and the result will be the empty string.
+		Examples: >
+			:echo remote_expr("gvim", "2+2")
+			:echo remote_expr("gvim1", "b:current_syntax")
+<
+
+remote_foreground({server})				*remote_foreground()*
+		Move the Vim server with the name {server} to the foreground.
+		This works like: >
+			remote_expr({server}, "foreground()")
+<		Except that on Win32 systems the client does the work, to work
+		around the problem that the OS doesn't always allow the server
+		to bring itself to the foreground.
+		Note: This does not restore the window if it was minimized,
+		like foreground() does.
+		This function is not available in the |sandbox|.
+		{only in the Win32, Athena, Motif and GTK GUI versions and the
+		Win32 console version}
+
+
+remote_peek({serverid} [, {retvar}])		*remote_peek()*
+		Returns a positive number if there are available strings
+		from {serverid}.  Copies any reply string into the variable
+		{retvar} if specified.	{retvar} must be a string with the
+		name of a variable.
+		Returns zero if none are available.
+		Returns -1 if something is wrong.
+		See also |clientserver|.
+		This function is not available in the |sandbox|.
+		{only available when compiled with the |+clientserver| feature}
+		Examples: >
+			:let repl = ""
+			:echo "PEEK: ".remote_peek(id, "repl").": ".repl
+
+remote_read({serverid})				*remote_read()*
+		Return the oldest available reply from {serverid} and consume
+		it.  It blocks until a reply is available.
+		See also |clientserver|.
+		This function is not available in the |sandbox|.
+		{only available when compiled with the |+clientserver| feature}
+		Example: >
+			:echo remote_read(id)
+<
+							*remote_send()* *E241*
+remote_send({server}, {string} [, {idvar}])
+		Send the {string} to {server}.	The string is sent as input
+		keys and the function returns immediately.  At the Vim server
+		the keys are not mapped |:map|.
+		If {idvar} is present, it is taken as the name of a variable
+		and a {serverid} for later use with remote_read() is stored
+		there.
+		See also |clientserver| |RemoteReply|.
+		This function is not available in the |sandbox|.
+		{only available when compiled with the |+clientserver| feature}
+		Note: Any errors will be reported in the server and may mess
+		up the display.
+		Examples: >
+		:echo remote_send("gvim", ":DropAndReply ".file, "serverid").
+		 \ remote_read(serverid)
+
+		:autocmd NONE RemoteReply *
+		 \ echo remote_read(expand(""))
+		:echo remote_send("gvim", ":sleep 10 | echo ".
+		 \ 'server2client(expand(""), "HELLO")')
+<
+remove({list}, {idx} [, {end}])				*remove()*
+		Without {end}: Remove the item at {idx} from |List| {list} and
+		return the item.
+		With {end}: Remove items from {idx} to {end} (inclusive) and
+		return a List with these items.  When {idx} points to the same
+		item as {end} a list with one item is returned.  When {end}
+		points to an item before {idx} this is an error.
+		See |list-index| for possible values of {idx} and {end}.
+		Example: >
+			:echo "last item: " . remove(mylist, -1)
+			:call remove(mylist, 0, 9)
+remove({dict}, {key})
+		Remove the entry from {dict} with key {key}.  Example: >
+			:echo "removed " . remove(dict, "one")
+<		If there is no {key} in {dict} this is an error.
+
+		Use |delete()| to remove a file.
+
+rename({from}, {to})					*rename()*
+		Rename the file by the name {from} to the name {to}.  This
+		should also work to move files across file systems.  The
+		result is a Number, which is 0 if the file was renamed
+		successfully, and non-zero when the renaming failed.
+		NOTE: If {to} exists it is overwritten without warning.
+		This function is not available in the |sandbox|.
+
+repeat({expr}, {count})					*repeat()*
+		Repeat {expr} {count} times and return the concatenated
+		result.  Example: >
+			:let separator = repeat('-', 80)
+<		When {count} is zero or negative the result is empty.
+		When {expr} is a |List| the result is {expr} concatenated
+		{count} times.	Example: >
+			:let longlist = repeat(['a', 'b'], 3)
+<		Results in ['a', 'b', 'a', 'b', 'a', 'b'].
+
+
+resolve({filename})					*resolve()* *E655*
+		On MS-Windows, when {filename} is a shortcut (a .lnk file),
+		returns the path the shortcut points to in a simplified form.
+		On Unix, repeat resolving symbolic links in all path
+		components of {filename} and return the simplified result.
+		To cope with link cycles, resolving of symbolic links is
+		stopped after 100 iterations.
+		On other systems, return the simplified {filename}.
+		The simplification step is done as by |simplify()|.
+		resolve() keeps a leading path component specifying the
+		current directory (provided the result is still a relative
+		path name) and also keeps a trailing path separator.
+
+							*reverse()*
+reverse({list})	Reverse the order of items in {list} in-place.	Returns
+		{list}.
+		If you want a list to remain unmodified make a copy first: >
+			:let revlist = reverse(copy(mylist))
+
+round({expr})							*round()*
+		Round off {expr} to the nearest integral value and return it
+		as a |Float|.  If {expr} lies halfway between two integral
+		values, then use the larger one (away from zero).
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			echo round(0.456)
+<			0.0  >
+			echo round(4.5)
+<			5.0 >
+			echo round(-4.5)
+<			-5.0
+		{only available when compiled with the |+float| feature}
+		
+		
+search({pattern} [, {flags} [, {stopline} [, {timeout}]]])	*search()*
+		Search for regexp pattern {pattern}.  The search starts at the
+		cursor position (you can use |cursor()| to set it).
+
+		{flags} is a String, which can contain these character flags:
+		'b'	search backward instead of forward
+		'c'	accept a match at the cursor position
+		'e'	move to the End of the match
+		'n'	do Not move the cursor
+		'p'	return number of matching sub-pattern (see below)
+		's'	set the ' mark at the previous location of the cursor
+		'w'	wrap around the end of the file
+		'W'	don't wrap around the end of the file
+		If neither 'w' or 'W' is given, the 'wrapscan' option applies.
+
+		If the 's' flag is supplied, the ' mark is set, only if the
+		cursor is moved. The 's' flag cannot be combined with the 'n'
+		flag.
+
+		'ignorecase', 'smartcase' and 'magic' are used.
+
+		When the {stopline} argument is given then the search stops
+		after searching this line.  This is useful to restrict the
+		search to a range of lines.  Examples: >
+			let match = search('(', 'b', line("w0"))
+			let end = search('END', '', line("w$"))
+<		When {stopline} is used and it is not zero this also implies
+		that the search does not wrap around the end of the file.
+		A zero value is equal to not giving the argument.
+
+		When the {timeout} argument is given the search stops when
+		more than this many milli seconds have passed.	Thus when
+		{timeout} is 500 the search stops after half a second.
+		The value must not be negative.  A zero value is like not
+		giving the argument.
+		{only available when compiled with the |+reltime| feature}
+
+		If there is no match a 0 is returned and the cursor doesn't
+		move.  No error message is given.
+		When a match has been found its line number is returned.
+							*search()-sub-match*
+		With the 'p' flag the returned value is one more than the
+		first sub-match in \(\).  One if none of them matched but the
+		whole pattern did match.
+		To get the column number too use |searchpos()|.
+
+		The cursor will be positioned at the match, unless the 'n'
+		flag is used.
+
+		Example (goes over all files in the argument list): >
+		    :let n = 1
+		    :while n <= argc()	    " loop over all files in arglist
+		    :  exe "argument " . n
+		    :  " start at the last char in the file and wrap for the
+		    :  " first search to find match at start of file
+		    :  normal G$
+		    :  let flags = "w"
+		    :  while search("foo", flags) > 0
+		    :	 s/foo/bar/g
+		    :	 let flags = "W"
+		    :  endwhile
+		    :  update		    " write the file if modified
+		    :  let n = n + 1
+		    :endwhile
+<
+		Example for using some flags: >
+		    :echo search('\
+			if searchdecl('myvar') == 0
+			   echo getline('.')
+			endif
+<
+							*searchpair()*
+searchpair({start}, {middle}, {end} [, {flags} [, {skip}
+				[, {stopline} [, {timeout}]]]])
+		Search for the match of a nested start-end pair.  This can be
+		used to find the "endif" that matches an "if", while other
+		if/endif pairs in between are ignored.
+		The search starts at the cursor.  The default is to search
+		forward, include 'b' in {flags} to search backward.
+		If a match is found, the cursor is positioned at it and the
+		line number is returned.  If no match is found 0 or -1 is
+		returned and the cursor doesn't move.  No error message is
+		given.
+
+		{start}, {middle} and {end} are patterns, see |pattern|.  They
+		must not contain \( \) pairs.  Use of \%( \) is allowed.  When
+		{middle} is not empty, it is found when searching from either
+		direction, but only when not in a nested start-end pair.  A
+		typical use is: >
+			searchpair('\', '\', '\')
+<		By leaving {middle} empty the "else" is skipped.
+
+		{flags} 'b', 'c', 'n', 's', 'w' and 'W' are used like with
+		|search()|.  Additionally:
+		'r'	Repeat until no more matches found; will find the
+			outer pair.  Implies the 'W' flag.
+		'm'	Return number of matches instead of line number with
+			the match; will be > 1 when 'r' is used.
+		Note: it's nearly always a good idea to use the 'W' flag, to
+		avoid wrapping around the end of the file.
+
+		When a match for {start}, {middle} or {end} is found, the
+		{skip} expression is evaluated with the cursor positioned on
+		the start of the match.  It should return non-zero if this
+		match is to be skipped.  E.g., because it is inside a comment
+		or a string.
+		When {skip} is omitted or empty, every match is accepted.
+		When evaluating {skip} causes an error the search is aborted
+		and -1 returned.
+
+		For {stopline} and {timeout} see |search()|.
+
+		The value of 'ignorecase' is used.  'magic' is ignored, the
+		patterns are used like it's on.
+
+		The search starts exactly at the cursor.  A match with
+		{start}, {middle} or {end} at the next character, in the
+		direction of searching, is the first one found.  Example: >
+			if 1
+			  if 2
+			  endif 2
+			endif 1
+<		When starting at the "if 2", with the cursor on the "i", and
+		searching forwards, the "endif 2" is found.  When starting on
+		the character just before the "if 2", the "endif 1" will be
+		found.	That's because the "if 2" will be found first, and
+		then this is considered to be a nested if/endif from "if 2" to
+		"endif 2".
+		When searching backwards and {end} is more than one character,
+		it may be useful to put "\zs" at the end of the pattern, so
+		that when the cursor is inside a match with the end it finds
+		the matching start.
+
+		Example, to find the "endif" command in a Vim script: >
+
+	:echo searchpair('\', '\', '\', 'W',
+			\ 'getline(".") =~ "^\\s*\""')
+
+<		The cursor must be at or after the "if" for which a match is
+		to be found.  Note that single-quote strings are used to avoid
+		having to double the backslashes.  The skip expression only
+		catches comments at the start of a line, not after a command.
+		Also, a word "en" or "if" halfway a line is considered a
+		match.
+		Another example, to search for the matching "{" of a "}": >
+
+	:echo searchpair('{', '', '}', 'bW')
+
+<		This works when the cursor is at or before the "}" for which a
+		match is to be found.  To reject matches that syntax
+		highlighting recognized as strings: >
+
+	:echo searchpair('{', '', '}', 'bW',
+	     \ 'synIDattr(synID(line("."), col("."), 0), "name") =~? "string"')
+<
+							*searchpairpos()*
+searchpairpos({start}, {middle}, {end} [, {flags} [, {skip}
+				[, {stopline} [, {timeout}]]]])
+		Same as |searchpair()|, but returns a |List| with the line and
+		column position of the match. The first element of the |List|
+		is the line number and the second element is the byte index of
+		the column position of the match.  If no match is found,
+		returns [0, 0]. >
+
+			:let [lnum,col] = searchpairpos('{', '', '}', 'n')
+<
+		See |match-parens| for a bigger and more useful example.
+
+searchpos({pattern} [, {flags} [, {stopline} [, {timeout}]]])	*searchpos()*
+		Same as |search()|, but returns a |List| with the line and
+		column position of the match. The first element of the |List|
+		is the line number and the second element is the byte index of
+		the column position of the match. If no match is found,
+		returns [0, 0].
+		Example: >
+	:let [lnum, col] = searchpos('mypattern', 'n')
+
+<		When the 'p' flag is given then there is an extra item with
+		the sub-pattern match number |search()-sub-match|.  Example: >
+	:let [lnum, col, submatch] = searchpos('\(\l\)\|\(\u\)', 'np')
+<		In this example "submatch" is 2 when a lowercase letter is
+		found |/\l|, 3 when an uppercase letter is found |/\u|.
+
+server2client( {clientid}, {string})			*server2client()*
+		Send a reply string to {clientid}.  The most recent {clientid}
+		that sent a string can be retrieved with expand("").
+		{only available when compiled with the |+clientserver| feature}
+		Note:
+		This id has to be stored before the next command can be
+		received.  I.e. before returning from the received command and
+		before calling any commands that waits for input.
+		See also |clientserver|.
+		Example: >
+			:echo server2client(expand(""), "HELLO")
+<
+serverlist()					*serverlist()*
+		Return a list of available server names, one per line.
+		When there are no servers or the information is not available
+		an empty string is returned.  See also |clientserver|.
+		{only available when compiled with the |+clientserver| feature}
+		Example: >
+			:echo serverlist()
+<
+setbufvar({expr}, {varname}, {val})			*setbufvar()*
+		Set option or local variable {varname} in buffer {expr} to
+		{val}.
+		This also works for a global or local window option, but it
+		doesn't work for a global or local window variable.
+		For a local window option the global value is unchanged.
+		For the use of {expr}, see |bufname()| above.
+		Note that the variable name without "b:" must be used.
+		Examples: >
+			:call setbufvar(1, "&mod", 1)
+			:call setbufvar("todo", "myvar", "foobar")
+<		This function is not available in the |sandbox|.
+
+setcmdpos({pos})					*setcmdpos()*
+		Set the cursor position in the command line to byte position
+		{pos}.	The first position is 1.
+		Use |getcmdpos()| to obtain the current position.
+		Only works while editing the command line, thus you must use
+		|c_CTRL-\_e|, |c_CTRL-R_=| or |c_CTRL-R_CTRL-R| with '='.  For
+		|c_CTRL-\_e| and |c_CTRL-R_CTRL-R| with '=' the position is
+		set after the command line is set to the expression.  For
+		|c_CTRL-R_=| it is set after evaluating the expression but
+		before inserting the resulting text.
+		When the number is too big the cursor is put at the end of the
+		line.  A number smaller than one has undefined results.
+		Returns 0 when successful, 1 when not editing the command
+		line.
+
+setline({lnum}, {text})					*setline()*
+		Set line {lnum} of the current buffer to {text}.
+		{lnum} is used like with |getline()|.
+		When {lnum} is just below the last line the {text} will be
+		added as a new line.
+		If this succeeds, 0 is returned.  If this fails (most likely
+		because {lnum} is invalid) 1 is returned.  Example: >
+			:call setline(5, strftime("%c"))
+<		When {text} is a |List| then line {lnum} and following lines
+		will be set to the items in the list.  Example: >
+			:call setline(5, ['aaa', 'bbb', 'ccc'])
+<		This is equivalent to: >
+			:for [n, l] in [[5, 6, 7], ['aaa', 'bbb', 'ccc']]
+			:  call setline(n, l)
+			:endfor
+<		Note: The '[ and '] marks are not set.
+
+setloclist({nr}, {list} [, {action}])			*setloclist()*
+		Create or replace or add to the location list for window {nr}.
+		When {nr} is zero the current window is used. For a location
+		list window, the displayed location list is modified.  For an
+		invalid window number {nr}, -1 is returned.
+		Otherwise, same as |setqflist()|.
+		Also see |location-list|.
+
+setmatches({list})					*setmatches()*
+		Restores a list of matches saved by |getmatches()|.  Returns 0
+		if successful, otherwise -1.  All current matches are cleared
+		before the list is restored.  See example for |getmatches()|.
+
+							*setpos()*
+setpos({expr}, {list})
+		Set the position for {expr}.  Possible values:
+			.	the cursor
+			'x	mark x
+
+		{list} must be a |List| with four numbers:
+		    [bufnum, lnum, col, off]
+
+		"bufnum" is the buffer number.	Zero can be used for the
+		current buffer.  Setting the cursor is only possible for
+		the current buffer.  To set a mark in another buffer you can
+		use the |bufnr()| function to turn a file name into a buffer
+		number.
+		Does not change the jumplist.
+
+		"lnum" and "col" are the position in the buffer.  The first
+		column is 1.  Use a zero "lnum" to delete a mark.  If "col" is
+		smaller than 1 then 1 is used.
+
+		The "off" number is only used when 'virtualedit' is set. Then
+		it is the offset in screen columns from the start of the
+		character.  E.g., a position within a  or after the last
+		character.
+
+		Returns 0 when the position could be set, -1 otherwise.
+		An error message is given if {expr} is invalid.
+
+		Also see |getpos()|
+
+		This does not restore the preferred column for moving
+		vertically.  See |winrestview()| for that.
+
+
+setqflist({list} [, {action}])				*setqflist()*
+		Create or replace or add to the quickfix list using the items
+		in {list}.  Each item in {list} is a dictionary.
+		Non-dictionary items in {list} are ignored.  Each dictionary
+		item can contain the following entries:
+
+		    bufnr	buffer number; must be the number of a valid
+				buffer
+		    filename	name of a file; only used when "bufnr" is not
+				present or it is invalid.
+		    lnum	line number in the file
+		    pattern	search pattern used to locate the error
+		    col		column number
+		    vcol	when non-zero: "col" is visual column
+				when zero: "col" is byte index
+		    nr		error number
+		    text	description of the error
+		    type	single-character error type, 'E', 'W', etc.
+
+		The "col", "vcol", "nr", "type" and "text" entries are
+		optional.  Either "lnum" or "pattern" entry can be used to
+		locate a matching error line.
+		If the "filename" and "bufnr" entries are not present or
+		neither the "lnum" or "pattern" entries are present, then the
+		item will not be handled as an error line.
+		If both "pattern" and "lnum" are present then "pattern" will
+		be used.
+		If you supply an empty {list}, the quickfix list will be
+		cleared.
+		Note that the list is not exactly the same as what
+		|getqflist()| returns.
+
+		If {action} is set to 'a', then the items from {list} are
+		added to the existing quickfix list. If there is no existing
+		list, then a new list is created. If {action} is set to 'r',
+		then the items from the current quickfix list are replaced
+		with the items from {list}. If {action} is not present or is
+		set to ' ', then a new list is created.
+
+		Returns zero for success, -1 for failure.
+
+		This function can be used to create a quickfix list
+		independent of the 'errorformat' setting.  Use a command like
+		":cc 1" to jump to the first position.
+
+
+							*setreg()*
+setreg({regname}, {value} [,{options}])
+		Set the register {regname} to {value}.
+		If {options} contains "a" or {regname} is upper case,
+		then the value is appended.
+		{options} can also contain a register type specification:
+		    "c" or "v"	      |characterwise| mode
+		    "l" or "V"	      |linewise| mode
+		    "b" or "" |blockwise-visual| mode
+		If a number immediately follows "b" or "" then this is
+		used as the width of the selection - if it is not specified
+		then the width of the block is set to the number of characters
+		in the longest line (counting a  as 1 character).
+
+		If {options} contains no register settings, then the default
+		is to use character mode unless {value} ends in a .
+		Setting the '=' register is not possible.
+		Returns zero for success, non-zero for failure.
+
+		Examples: >
+			:call setreg(v:register, @*)
+			:call setreg('*', @%, 'ac')
+			:call setreg('a', "1\n2\n3", 'b5')
+
+<		This example shows using the functions to save and restore a
+		register. >
+			:let var_a = getreg('a', 1)
+			:let var_amode = getregtype('a')
+			    ....
+			:call setreg('a', var_a, var_amode)
+
+<		You can also change the type of a register by appending
+		nothing: >
+			:call setreg('a', '', 'al')
+
+settabvar({tabnr}, {varname}, {val})			*settabvar()*
+		Set tab-local variable {varname} to {val} in tab page {tabnr}.
+		|t:var|
+		Note that the variable name without "t:" must be used.
+		Tabs are numbered starting with one.
+		Vim briefly goes to the tab page {tabnr}, this may trigger
+		TabLeave and TabEnter autocommands.
+		This function is not available in the |sandbox|.
+
+settabwinvar({tabnr}, {winnr}, {varname}, {val})	*settabwinvar()*
+		Set option or local variable {varname} in window {winnr} to
+		{val}.
+		Tabs are numbered starting with one.  For the current tabpage
+		use |setwinvar()|.
+		When {winnr} is zero the current window is used.
+		This also works for a global or local buffer option, but it
+		doesn't work for a global or local buffer variable.
+		For a local buffer option the global value is unchanged.
+		Note that the variable name without "w:" must be used.
+		Vim briefly goes to the tab page {tabnr}, this may trigger
+		TabLeave and TabEnter autocommands.
+		Examples: >
+			:call settabwinvar(1, 1, "&list", 0)
+			:call settabwinvar(3, 2, "myvar", "foobar")
+<		This function is not available in the |sandbox|.
+
+setwinvar({nr}, {varname}, {val})			*setwinvar()*
+		Like |settabwinvar()| for the current tab page.
+		Examples: >
+			:call setwinvar(1, "&list", 0)
+			:call setwinvar(2, "myvar", "foobar")
+
+shellescape({string} [, {special}])			*shellescape()*
+		Escape {string} for use as a shell command argument.
+		On MS-Windows and MS-DOS, when 'shellslash' is not set, it
+		will enclose {string} in double quotes and double all double
+		quotes within {string}.
+		For other systems, it will enclose {string} in single quotes
+		and replace all "'" with "'\''".
+		When the {special} argument is present and it's a non-zero
+		Number or a non-empty String (|non-zero-arg|), then special
+		items such as "!", "%", "#" and "" will be preceded by
+		a backslash.  This backslash will be removed again by the |:!|
+		command.
+		The "!" character will be escaped (again with a |non-zero-arg|
+		{special}) when 'shell' contains "csh" in the tail.  That is
+		because for csh and tcsh "!" is used for history replacement
+		even when inside single quotes.
+		The  character is also escaped.  With a |non-zero-arg|
+		{special} and 'shell' containing "csh" in the tail it's
+		escaped a second time.
+		Example of use with a |:!| command: >
+		    :exe '!dir ' . shellescape(expand(''), 1)
+<		This results in a directory listing for the file under the
+		cursor.  Example of use with |system()|: >
+		    :call system("chmod +w -- " . shellescape(expand("%")))
+
+
+simplify({filename})					*simplify()*
+		Simplify the file name as much as possible without changing
+		the meaning.  Shortcuts (on MS-Windows) or symbolic links (on
+		Unix) are not resolved.  If the first path component in
+		{filename} designates the current directory, this will be
+		valid for the result as well.  A trailing path separator is
+		not removed either.
+		Example: >
+			simplify("./dir/.././/file/") == "./file/"
+<		Note: The combination "dir/.." is only removed if "dir" is
+		a searchable directory or does not exist.  On Unix, it is also
+		removed when "dir" is a symbolic link within the same
+		directory.  In order to resolve all the involved symbolic
+		links before simplifying the path name, use |resolve()|.
+
+
+sin({expr})						*sin()*
+		Return the sine of {expr}, measured in radians, as a |Float|.
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo sin(100)
+<			-0.506366 >
+			:echo sin(-4.01)
+<			0.763301
+		{only available when compiled with the |+float| feature}
+		
+
+sinh({expr})						*sinh()*
+		Return the hyperbolic sine of {expr} as a |Float| in the range
+		[-inf, inf].
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo sinh(0.5)
+<			0.521095 >
+			:echo sinh(-0.9)
+<			-1.026517
+		{only available when compiled with the |+float| feature}
+
+
+sort({list} [, {func}])					*sort()* *E702*
+		Sort the items in {list} in-place.  Returns {list}.  If you
+		want a list to remain unmodified make a copy first: >
+			:let sortedlist = sort(copy(mylist))
+<		Uses the string representation of each item to sort on.
+		Numbers sort after Strings, |Lists| after Numbers.
+		For sorting text in the current buffer use |:sort|.
+		When {func} is given and it is one then case is ignored.
+		When {func} is a |Funcref| or a function name, this function
+		is called to compare items.  The function is invoked with two
+		items as argument and must return zero if they are equal, 1 or
+		bigger if the first one sorts after the second one, -1 or
+		smaller if the first one sorts before the second one.
+		Example: >
+			func MyCompare(i1, i2)
+			   return a:i1 == a:i2 ? 0 : a:i1 > a:i2 ? 1 : -1
+			endfunc
+			let sortedlist = sort(mylist, "MyCompare")
+<		A shorter compare version for this specific simple case, which
+		ignores overflow: >
+			func MyCompare(i1, i2)
+			   return a:i1 - a:i2
+			endfunc
+<
+							*soundfold()*
+soundfold({word})
+		Return the sound-folded equivalent of {word}.  Uses the first
+		language in 'spelllang' for the current window that supports
+		soundfolding.  'spell' must be set.  When no sound folding is
+		possible the {word} is returned unmodified.
+		This can be used for making spelling suggestions.  Note that
+		the method can be quite slow.
+
+							*spellbadword()*
+spellbadword([{sentence}])
+		Without argument: The result is the badly spelled word under
+		or after the cursor.  The cursor is moved to the start of the
+		bad word.  When no bad word is found in the cursor line the
+		result is an empty string and the cursor doesn't move.
+
+		With argument: The result is the first word in {sentence} that
+		is badly spelled.  If there are no spelling mistakes the
+		result is an empty string.
+
+		The return value is a list with two items:
+		- The badly spelled word or an empty string.
+		- The type of the spelling error:
+			"bad"		spelling mistake
+			"rare"		rare word
+			"local"		word only valid in another region
+			"caps"		word should start with Capital
+		Example: >
+			echo spellbadword("the quik brown fox")
+<			['quik', 'bad'] ~
+
+		The spelling information for the current window is used.  The
+		'spell' option must be set and the value of 'spelllang' is
+		used.
+
+							*spellsuggest()*
+spellsuggest({word} [, {max} [, {capital}]])
+		Return a |List| with spelling suggestions to replace {word}.
+		When {max} is given up to this number of suggestions are
+		returned.  Otherwise up to 25 suggestions are returned.
+
+		When the {capital} argument is given and it's non-zero only
+		suggestions with a leading capital will be given.  Use this
+		after a match with 'spellcapcheck'.
+
+		{word} can be a badly spelled word followed by other text.
+		This allows for joining two words that were split.  The
+		suggestions also include the following text, thus you can
+		replace a line.
+
+		{word} may also be a good word.  Similar words will then be
+		returned.  {word} itself is not included in the suggestions,
+		although it may appear capitalized.
+
+		The spelling information for the current window is used.  The
+		'spell' option must be set and the values of 'spelllang' and
+		'spellsuggest' are used.
+
+
+split({expr} [, {pattern} [, {keepempty}]])			*split()*
+		Make a |List| out of {expr}.  When {pattern} is omitted or
+		empty each white-separated sequence of characters becomes an
+		item.
+		Otherwise the string is split where {pattern} matches,
+		removing the matched characters.
+		When the first or last item is empty it is omitted, unless the
+		{keepempty} argument is given and it's non-zero.
+		Other empty items are kept when {pattern} matches at least one
+		character or when {keepempty} is non-zero.
+		Example: >
+			:let words = split(getline('.'), '\W\+')
+<		To split a string in individual characters: >
+			:for c in split(mystring, '\zs')
+<		If you want to keep the separator you can also use '\zs': >
+			:echo split('abc:def:ghi', ':\zs')
+<			['abc:', 'def:', 'ghi'] ~
+		Splitting a table where the first element can be empty: >
+			:let items = split(line, ':', 1)
+<		The opposite function is |join()|.
+
+
+sqrt({expr})						*sqrt()*
+		Return the non-negative square root of Float {expr} as a
+		|Float|.
+		{expr} must evaluate to a |Float| or a |Number|.  When {expr}
+		is negative the result is NaN (Not a Number).
+		Examples: >
+			:echo sqrt(100)
+<			10.0 >
+			:echo sqrt(-4.01)
+<			nan
+		"nan" may be different, it depends on system libraries.
+		{only available when compiled with the |+float| feature}
+		
+
+str2float( {expr})					*str2float()*
+		Convert String {expr} to a Float.  This mostly works the same
+		as when using a floating point number in an expression, see
+		|floating-point-format|.  But it's a bit more permissive.
+		E.g., "1e40" is accepted, while in an expression you need to
+		write "1.0e40".
+		Text after the number is silently ignored.
+		The decimal point is always '.', no matter what the locale is
+		set to.  A comma ends the number: "12,345.67" is converted to
+		12.0.  You can strip out thousands separators with
+		|substitute()|: >
+			let f = str2float(substitute(text, ',', '', 'g'))
+<		{only available when compiled with the |+float| feature}
+
+
+str2nr( {expr} [, {base}])				*str2nr()*
+		Convert string {expr} to a number.
+		{base} is the conversion base, it can be 8, 10 or 16.
+		When {base} is omitted base 10 is used.  This also means that
+		a leading zero doesn't cause octal conversion to be used, as
+		with the default String to Number conversion.
+		When {base} is 16 a leading "0x" or "0X" is ignored.  With a
+		different base the result will be zero.
+		Text after the number is silently ignored.
+
+
+strchars({expr})					*strchars()*
+		The result is a Number, which is the number of characters
+		String {expr} occupies.  Composing characters are counted
+		separately.
+		Also see |strlen()|, |strdisplaywidth()| and |strwidth()|.
+
+strdisplaywidth({expr}[, {col}])			*strdisplaywidth()*
+		The result is a Number, which is the number of display cells
+		String {expr} occupies on the screen.
+		When {col} is omitted zero is used.  Otherwise it is the
+		screen column where to start.  This matters for Tab
+		characters.
+		The option settings of the current window are used.  This
+		matters for anything that's displayed differently, such as
+		'tabstop' and 'display'.
+		When {expr} contains characters with East Asian Width Class
+		Ambiguous, this function's return value depends on 'ambiwidth'.
+		Also see |strlen()|, |strwidth()| and |strchars()|.
+
+strftime({format} [, {time}])				*strftime()*
+		The result is a String, which is a formatted date and time, as
+		specified by the {format} string.  The given {time} is used,
+		or the current time if no time is given.  The accepted
+		{format} depends on your system, thus this is not portable!
+		See the manual page of the C function strftime() for the
+		format.  The maximum length of the result is 80 characters.
+		See also |localtime()| and |getftime()|.
+		The language can be changed with the |:language| command.
+		Examples: >
+		  :echo strftime("%c")		   Sun Apr 27 11:49:23 1997
+		  :echo strftime("%Y %b %d %X")	   1997 Apr 27 11:53:25
+		  :echo strftime("%y%m%d %T")	   970427 11:53:55
+		  :echo strftime("%H:%M")	   11:55
+		  :echo strftime("%c", getftime("file.c"))
+						   Show mod time of file.c.
+<		Not available on all systems.  To check use: >
+			:if exists("*strftime")
+
+stridx({haystack}, {needle} [, {start}])		*stridx()*
+		The result is a Number, which gives the byte index in
+		{haystack} of the first occurrence of the String {needle}.
+		If {start} is specified, the search starts at index {start}.
+		This can be used to find a second match: >
+			:let comma1 = stridx(line, ",")
+			:let comma2 = stridx(line, ",", comma1 + 1)
+<		The search is done case-sensitive.
+		For pattern searches use |match()|.
+		-1 is returned if the {needle} does not occur in {haystack}.
+		See also |strridx()|.
+		Examples: >
+		  :echo stridx("An Example", "Example")	     3
+		  :echo stridx("Starting point", "Start")    0
+		  :echo stridx("Starting point", "start")   -1
+<						*strstr()* *strchr()*
+		stridx() works similar to the C function strstr().  When used
+		with a single character it works similar to strchr().
+
+							*string()*
+string({expr})	Return {expr} converted to a String.  If {expr} is a Number,
+		Float, String or a composition of them, then the result can be
+		parsed back with |eval()|.
+			{expr} type	result ~
+			String		'string'
+			Number		123
+			Float		123.123456 or 1.123456e8
+			Funcref		function('name')
+			List		[item, item]
+			Dictionary	{key: value, key: value}
+		Note that in String values the ' character is doubled.
+		Also see |strtrans()|.
+
+							*strlen()*
+strlen({expr})	The result is a Number, which is the length of the String
+		{expr} in bytes.
+		If you want to count the number of multi-byte characters (not
+		counting composing characters) use something like this: >
+
+			:let len = strlen(substitute(str, ".", "x", "g"))
+<
+		If the argument is a Number it is first converted to a String.
+		For other types an error is given.
+		Also see |len()|, |strchars()|, |strdisplaywidth()| and
+		|strwidth()|.
+
+strpart({src}, {start}[, {len}])			*strpart()*
+		The result is a String, which is part of {src}, starting from
+		byte {start}, with the byte length {len}.
+		When non-existing bytes are included, this doesn't result in
+		an error, the bytes are simply omitted.
+		If {len} is missing, the copy continues from {start} till the
+		end of the {src}. >
+			strpart("abcdefg", 3, 2)    == "de"
+			strpart("abcdefg", -2, 4)   == "ab"
+			strpart("abcdefg", 5, 4)    == "fg"
+			strpart("abcdefg", 3)	    == "defg"
+<		Note: To get the first character, {start} must be 0.  For
+		example, to get three bytes under and after the cursor: >
+			strpart(getline("."), col(".") - 1, 3)
+<
+strridx({haystack}, {needle} [, {start}])			*strridx()*
+		The result is a Number, which gives the byte index in
+		{haystack} of the last occurrence of the String {needle}.
+		When {start} is specified, matches beyond this index are
+		ignored.  This can be used to find a match before a previous
+		match: >
+			:let lastcomma = strridx(line, ",")
+			:let comma2 = strridx(line, ",", lastcomma - 1)
+<		The search is done case-sensitive.
+		For pattern searches use |match()|.
+		-1 is returned if the {needle} does not occur in {haystack}.
+		If the {needle} is empty the length of {haystack} is returned.
+		See also |stridx()|.  Examples: >
+		  :echo strridx("an angry armadillo", "an")	     3
+<							*strrchr()*
+		When used with a single character it works similar to the C
+		function strrchr().
+
+strtrans({expr})					*strtrans()*
+		The result is a String, which is {expr} with all unprintable
+		characters translated into printable characters |'isprint'|.
+		Like they are shown in a window.  Example: >
+			echo strtrans(@a)
+<		This displays a newline in register a as "^@" instead of
+		starting a new line.
+
+strwidth({expr})					*strwidth()*
+		The result is a Number, which is the number of display cells
+		String {expr} occupies.  A Tab character is counted as one
+		cell, alternatively use |strdisplaywidth()|.
+		When {expr} contains characters with East Asian Width Class
+		Ambiguous, this function's return value depends on 'ambiwidth'.
+		Also see |strlen()|, |strdisplaywidth()| and |strchars()|.
+
+submatch({nr})						*submatch()*
+		Only for an expression in a |:substitute| command.  Returns
+		the {nr}'th submatch of the matched text.  When {nr} is 0
+		the whole matched text is returned.
+		Example: >
+			:s/\d\+/\=submatch(0) + 1/
+<		This finds the first number in the line and adds one to it.
+		A line break is included as a newline character.
+
+substitute({expr}, {pat}, {sub}, {flags})		*substitute()*
+		The result is a String, which is a copy of {expr}, in which
+		the first match of {pat} is replaced with {sub}.  This works
+		like the ":substitute" command (without any flags).  But the
+		matching with {pat} is always done like the 'magic' option is
+		set and 'cpoptions' is empty (to make scripts portable).
+		'ignorecase' is still relevant.  'smartcase' is not used.
+		See |string-match| for how {pat} is used.
+		And a "~" in {sub} is not replaced with the previous {sub}.
+		Note that some codes in {sub} have a special meaning
+		|sub-replace-special|.	For example, to replace something with
+		"\n" (two characters), use "\\\\n" or '\\n'.
+		When {pat} does not match in {expr}, {expr} is returned
+		unmodified.
+		When {flags} is "g", all matches of {pat} in {expr} are
+		replaced.  Otherwise {flags} should be "".
+		Example: >
+			:let &path = substitute(&path, ",\\=[^,]*$", "", "")
+<		This removes the last component of the 'path' option. >
+			:echo substitute("testing", ".*", "\\U\\0", "")
+<		results in "TESTING".
+
+synID({lnum}, {col}, {trans})				*synID()*
+		The result is a Number, which is the syntax ID at the position
+		{lnum} and {col} in the current window.
+		The syntax ID can be used with |synIDattr()| and
+		|synIDtrans()| to obtain syntax information about text.
+
+		{col} is 1 for the leftmost column, {lnum} is 1 for the first
+		line.  'synmaxcol' applies, in a longer line zero is returned.
+
+		When {trans} is non-zero, transparent items are reduced to the
+		item that they reveal.	This is useful when wanting to know
+		the effective color.  When {trans} is zero, the transparent
+		item is returned.  This is useful when wanting to know which
+		syntax item is effective (e.g. inside parens).
+		Warning: This function can be very slow.  Best speed is
+		obtained by going through the file in forward direction.
+
+		Example (echoes the name of the syntax item under the cursor): >
+			:echo synIDattr(synID(line("."), col("."), 1), "name")
+<
+
+synconcealed({lnum}, {col})				*synconcealed()*
+		The result is a List. The first item in the list is 0 if the
+		character at the position {lnum} and {col} is not part of a
+		concealable region, 1 if it is. The second item in the list is
+		a string. If the first item is 1, the second item contains the
+		text which will be displayed in place of the concealed text,
+		depending on the current setting of 'conceallevel'. The third
+		and final item in the list is a unique number representing the
+		specific syntax region matched. This allows detection of the
+		beginning of a new concealable region if there are two
+		consecutive regions with the same replacement character.
+		For an example use see $VIMRUNTIME/syntax/2html.vim .
+
+
+synIDattr({synID}, {what} [, {mode}])			*synIDattr()*
+		The result is a String, which is the {what} attribute of
+		syntax ID {synID}.  This can be used to obtain information
+		about a syntax item.
+		{mode} can be "gui", "cterm" or "term", to get the attributes
+		for that mode.	When {mode} is omitted, or an invalid value is
+		used, the attributes for the currently active highlighting are
+		used (GUI, cterm or term).
+		Use synIDtrans() to follow linked highlight groups.
+		{what}		result
+		"name"		the name of the syntax item
+		"fg"		foreground color (GUI: color name used to set
+				the color, cterm: color number as a string,
+				term: empty string)
+		"bg"		background color (as with "fg")
+		"font"		font name (only available in the GUI)
+				|highlight-font|
+		"sp"		special color (as with "fg") |highlight-guisp|
+		"fg#"		like "fg", but for the GUI and the GUI is
+				running the name in "#RRGGBB" form
+		"bg#"		like "fg#" for "bg"
+		"sp#"		like "fg#" for "sp"
+		"bold"		"1" if bold
+		"italic"	"1" if italic
+		"reverse"	"1" if reverse
+		"inverse"	"1" if inverse (= reverse)
+		"standout"	"1" if standout
+		"underline"	"1" if underlined
+		"undercurl"	"1" if undercurled
+
+		Example (echoes the color of the syntax item under the
+		cursor): >
+	:echo synIDattr(synIDtrans(synID(line("."), col("."), 1)), "fg")
+<
+synIDtrans({synID})					*synIDtrans()*
+		The result is a Number, which is the translated syntax ID of
+		{synID}.  This is the syntax group ID of what is being used to
+		highlight the character.  Highlight links given with
+		":highlight link" are followed.
+
+synstack({lnum}, {col})					*synstack()*
+		Return a |List|, which is the stack of syntax items at the
+		position {lnum} and {col} in the current window.  Each item in
+		the List is an ID like what |synID()| returns.
+		The first item in the List is the outer region, following are
+		items contained in that one.  The last one is what |synID()|
+		returns, unless not the whole item is highlighted or it is a
+		transparent item.
+		This function is useful for debugging a syntax file.
+		Example that shows the syntax stack under the cursor: >
+			for id in synstack(line("."), col("."))
+			   echo synIDattr(id, "name")
+			endfor
+<		When the position specified with {lnum} and {col} is invalid
+		nothing is returned.  The position just after the last
+		character in a line and the first column in an empty line are
+		valid positions.
+
+system({expr} [, {input}])				*system()* *E677*
+		Get the output of the shell command {expr}.
+		When {input} is given, this string is written to a file and
+		passed as stdin to the command.  The string is written as-is,
+		you need to take care of using the correct line separators
+		yourself.  Pipes are not used.
+		Note: Use |shellescape()| to escape special characters in a
+		command argument.  Newlines in {expr} may cause the command to
+		fail.  The characters in 'shellquote' and 'shellxquote' may
+		also cause trouble.
+		This is not to be used for interactive commands.
+
+		The result is a String.  Example: >
+		    :let files = system("ls " .  shellescape(expand('%:h')))
+
+<		To make the result more system-independent, the shell output
+		is filtered to replace  with  for Macintosh, and
+		 with  for DOS-like systems.
+		The command executed is constructed using several options:
+	'shell' 'shellcmdflag' 'shellxquote' {expr} 'shellredir' {tmp} 'shellxquote'
+		({tmp} is an automatically generated file name).
+		For Unix and OS/2 braces are put around {expr} to allow for
+		concatenated commands.
+
+		The command will be executed in "cooked" mode, so that a
+		CTRL-C will interrupt the command (on Unix at least).
+
+		The resulting error code can be found in |v:shell_error|.
+		This function will fail in |restricted-mode|.
+
+		Note that any wrong value in the options mentioned above may
+		make the function fail.  It has also been reported to fail
+		when using a security agent application.
+		Unlike ":!cmd" there is no automatic check for changed files.
+		Use |:checktime| to force a check.
+
+
+tabpagebuflist([{arg}])					*tabpagebuflist()*
+		The result is a |List|, where each item is the number of the
+		buffer associated with each window in the current tab page.
+		{arg} specifies the number of tab page to be used.  When
+		omitted the current tab page is used.
+		When {arg} is invalid the number zero is returned.
+		To get a list of all buffers in all tabs use this: >
+			tablist = []
+			for i in range(tabpagenr('$'))
+			   call extend(tablist, tabpagebuflist(i + 1))
+			endfor
+<		Note that a buffer may appear in more than one window.
+
+
+tabpagenr([{arg}])					*tabpagenr()*
+		The result is a Number, which is the number of the current
+		tab page.  The first tab page has number 1.
+		When the optional argument is "$", the number of the last tab
+		page is returned (the tab page count).
+		The number can be used with the |:tab| command.
+
+
+tabpagewinnr({tabarg}, [{arg}])				*tabpagewinnr()*
+		Like |winnr()| but for tab page {tabarg}.
+		{tabarg} specifies the number of tab page to be used.
+		{arg} is used like with |winnr()|:
+		- When omitted the current window number is returned.  This is
+		  the window which will be used when going to this tab page.
+		- When "$" the number of windows is returned.
+		- When "#" the previous window nr is returned.
+		Useful examples: >
+		    tabpagewinnr(1)	    " current window of tab page 1
+		    tabpagewinnr(4, '$')    " number of windows in tab page 4
+<		When {tabarg} is invalid zero is returned.
+
+							*tagfiles()*
+tagfiles()	Returns a |List| with the file names used to search for tags
+		for the current buffer.  This is the 'tags' option expanded.
+
+
+taglist({expr})							*taglist()*
+		Returns a list of tags matching the regular expression {expr}.
+		Each list item is a dictionary with at least the following
+		entries:
+			name		Name of the tag.
+			filename	Name of the file where the tag is
+					defined.  It is either relative to the
+					current directory or a full path.
+			cmd		Ex command used to locate the tag in
+					the file.
+			kind		Type of the tag.  The value for this
+					entry depends on the language specific
+					kind values.  Only available when
+					using a tags file generated by
+					Exuberant ctags or hdrtag.
+			static		A file specific tag.  Refer to
+					|static-tag| for more information.
+		More entries may be present, depending on the content of the
+		tags file: access, implementation, inherits and signature.
+		Refer to the ctags documentation for information about these
+		fields.  For C code the fields "struct", "class" and "enum"
+		may appear, they give the name of the entity the tag is
+		contained in.
+
+		The ex-command 'cmd' can be either an ex search pattern, a
+		line number or a line number followed by a byte number.
+
+		If there are no matching tags, then an empty list is returned.
+
+		To get an exact tag match, the anchors '^' and '$' should be
+		used in {expr}.  Refer to |tag-regexp| for more information
+		about the tag search regular expression pattern.
+
+		Refer to |'tags'| for information about how the tags file is
+		located by Vim. Refer to |tags-file-format| for the format of
+		the tags file generated by the different ctags tools.
+
+tempname()					*tempname()* *temp-file-name*
+		The result is a String, which is the name of a file that
+		doesn't exist.	It can be used for a temporary file.  The name
+		is different for at least 26 consecutive calls.  Example: >
+			:let tmpfile = tempname()
+			:exe "redir > " . tmpfile
+<		For Unix, the file will be in a private directory |tempfile|.
+		For MS-Windows forward slashes are used when the 'shellslash'
+		option is set or when 'shellcmdflag' starts with '-'.
+
+
+tan({expr})						*tan()*
+		Return the tangent of {expr}, measured in radians, as a |Float|
+		in the range [-inf, inf].
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo tan(10)
+<			0.648361 >
+			:echo tan(-4.01)
+<			-1.181502
+		{only available when compiled with the |+float| feature}
+
+
+tanh({expr})						*tanh()*
+		Return the hyperbolic tangent of {expr} as a |Float| in the
+		range [-1, 1].
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			:echo tanh(0.5)
+<			0.462117 >
+			:echo tanh(-1)
+<			-0.761594
+		{only available when compiled with the |+float| feature}
+
+
+tolower({expr})						*tolower()*
+		The result is a copy of the String given, with all uppercase
+		characters turned into lowercase (just like applying |gu| to
+		the string).
+
+toupper({expr})						*toupper()*
+		The result is a copy of the String given, with all lowercase
+		characters turned into uppercase (just like applying |gU| to
+		the string).
+
+tr({src}, {fromstr}, {tostr})				*tr()*
+		The result is a copy of the {src} string with all characters
+		which appear in {fromstr} replaced by the character in that
+		position in the {tostr} string.  Thus the first character in
+		{fromstr} is translated into the first character in {tostr}
+		and so on.  Exactly like the unix "tr" command.
+		This code also deals with multibyte characters properly.
+
+		Examples: >
+			echo tr("hello there", "ht", "HT")
+<		returns "Hello THere" >
+			echo tr("", "<>", "{}")
+<		returns "{blob}"
+
+trunc({expr})							*trunc()*
+		Return the largest integral value with magnitude less than or
+		equal to {expr} as a |Float| (truncate towards zero).
+		{expr} must evaluate to a |Float| or a |Number|.
+		Examples: >
+			echo trunc(1.456)
+<			1.0  >
+			echo trunc(-5.456)
+<			-5.0  >
+			echo trunc(4.0)
+<			4.0
+		{only available when compiled with the |+float| feature}
+		
+							*type()*
+type({expr})	The result is a Number, depending on the type of {expr}:
+			Number:	    0
+			String:	    1
+			Funcref:    2
+			List:	    3
+			Dictionary: 4
+			Float:	    5
+		To avoid the magic numbers it should be used this way: >
+			:if type(myvar) == type(0)
+			:if type(myvar) == type("")
+			:if type(myvar) == type(function("tr"))
+			:if type(myvar) == type([])
+			:if type(myvar) == type({})
+			:if type(myvar) == type(0.0)
+
+undofile({name})					*undofile()*
+		Return the name of the undo file that would be used for a file
+		with name {name} when writing.  This uses the 'undodir'
+		option, finding directories that exist.  It does not check if
+		the undo file exists.
+		{name} is always expanded to the full path, since that is what
+		is used internally.
+		Useful in combination with |:wundo| and |:rundo|.
+		When compiled without the +persistent_undo option this always
+		returns an empty string.
+
+undotree()						*undotree()*
+		Return the current state of the undo tree in a dictionary with
+		the following items:
+		  "seq_last"	The highest undo sequence number used.
+		  "seq_cur"	The sequence number of the current position in
+				the undo tree.  This differs from "seq_last"
+				when some changes were undone.
+		  "time_cur"	Time last used for |:earlier| and related
+				commands.  Use |strftime()| to convert to
+				something readable.
+		  "save_last"	Number of the last file write.  Zero when no
+				write yet.
+		  "save_cur"	Number of the current position in the undo
+				tree.  
+		  "synced"	Non-zero when the last undo block was synced.
+				This happens when waiting from input from the
+				user.  See |undo-blocks|.
+		  "entries"	A list of dictionaries with information about
+				undo blocks.
+
+		The first item in the "entries" list is the oldest undo item.
+		Each List item is a Dictionary with these items:
+		  "seq"		Undo sequence number.  Same as what appears in
+				|:undolist|.
+		  "time"	Timestamp when the change happened.  Use
+				|strftime()| to convert to something readable.
+		  "newhead"	Only appears in the item that is the last one
+				that was added.  This marks the last change
+				and where further changes will be added.
+		  "curhead"	Only appears in the item that is the last one
+				that was undone.  This marks the current
+				position in the undo tree, the block that will
+				be used by a redo command.  When nothing was
+				undone after the last change this item will
+				not appear anywhere.
+		  "save"	Only appears on the last block before a file
+				write.  The number is the write count.  The
+				first write has number 1, the last one the
+				"save_last" mentioned above.
+		  "alt"		Alternate entry.  This is again a List of undo
+				blocks.  Each item may again have an "alt"
+				item.
+
+values({dict})						*values()*
+		Return a |List| with all the values of {dict}.	The |List| is
+		in arbitrary order.
+
+
+virtcol({expr})						*virtcol()*
+		The result is a Number, which is the screen column of the file
+		position given with {expr}.  That is, the last screen position
+		occupied by the character at that position, when the screen
+		would be of unlimited width.  When there is a  at the
+		position, the returned Number will be the column at the end of
+		the .  For example, for a  in column 1, with 'ts'
+		set to 8, it returns 8.
+		For the byte position use |col()|.
+		For the use of {expr} see |col()|.
+		When 'virtualedit' is used {expr} can be [lnum, col, off], where
+		"off" is the offset in screen columns from the start of the
+		character.  E.g., a position within a  or after the last
+		character.
+		When Virtual editing is active in the current mode, a position
+		beyond the end of the line can be returned. |'virtualedit'|
+		The accepted positions are:
+		    .	    the cursor position
+		    $	    the end of the cursor line (the result is the
+			    number of displayed characters in the cursor line
+			    plus one)
+		    'x	    position of mark x (if the mark is not set, 0 is
+			    returned)
+		Note that only marks in the current file can be used.
+		Examples: >
+  virtcol(".")	   with text "foo^Lbar", with cursor on the "^L", returns 5
+  virtcol("$")	   with text "foo^Lbar", returns 9
+  virtcol("'t")    with text "	  there", with 't at 'h', returns 6
+<		The first column is 1.	0 is returned for an error.
+		A more advanced example that echoes the maximum length of
+		all lines: >
+		    echo max(map(range(1, line('$')), "virtcol([v:val, '$'])"))
+
+
+visualmode([expr])						*visualmode()*
+		The result is a String, which describes the last Visual mode
+		used in the current buffer.  Initially it returns an empty
+		string, but once Visual mode has been used, it returns "v",
+		"V", or "" (a single CTRL-V character) for
+		character-wise, line-wise, or block-wise Visual mode
+		respectively.
+		Example: >
+			:exe "normal " . visualmode()
+<		This enters the same Visual mode as before.  It is also useful
+		in scripts if you wish to act differently depending on the
+		Visual mode that was used.
+		If Visual mode is active, use |mode()| to get the Visual mode
+		(e.g., in a |:vmap|).
+							*non-zero-arg*
+		If [expr] is supplied and it evaluates to a non-zero Number or
+		a non-empty String, then the Visual mode will be cleared and
+		the old value is returned.  Note that " " and "0" are also
+		non-empty strings, thus cause the mode to be cleared.  A List,
+		Dictionary or Float is not a Number or String, thus does not
+		cause the mode to be cleared.
+
+							*winbufnr()*
+winbufnr({nr})	The result is a Number, which is the number of the buffer
+		associated with window {nr}.  When {nr} is zero, the number of
+		the buffer in the current window is returned.  When window
+		{nr} doesn't exist, -1 is returned.
+		Example: >
+  :echo "The file in the current window is " . bufname(winbufnr(0))
+<
+							*wincol()*
+wincol()	The result is a Number, which is the virtual column of the
+		cursor in the window.  This is counting screen cells from the
+		left side of the window.  The leftmost column is one.
+
+winheight({nr})						*winheight()*
+		The result is a Number, which is the height of window {nr}.
+		When {nr} is zero, the height of the current window is
+		returned.  When window {nr} doesn't exist, -1 is returned.
+		An existing window always has a height of zero or more.
+		Examples: >
+  :echo "The current window has " . winheight(0) . " lines."
+<
+							*winline()*
+winline()	The result is a Number, which is the screen line of the cursor
+		in the window.	This is counting screen lines from the top of
+		the window.  The first line is one.
+		If the cursor was moved the view on the file will be updated
+		first, this may cause a scroll.
+
+							*winnr()*
+winnr([{arg}])	The result is a Number, which is the number of the current
+		window.  The top window has number 1.
+		When the optional argument is "$", the number of the
+		last window is returned (the window count).
+		When the optional argument is "#", the number of the last
+		accessed window is returned (where |CTRL-W_p| goes to).
+		If there is no previous window or it is in another tab page 0
+		is returned.
+		The number can be used with |CTRL-W_w| and ":wincmd w"
+		|:wincmd|.
+		Also see |tabpagewinnr()|.
+
+							*winrestcmd()*
+winrestcmd()	Returns a sequence of |:resize| commands that should restore
+		the current window sizes.  Only works properly when no windows
+		are opened or closed and the current window and tab page is
+		unchanged.
+		Example: >
+			:let cmd = winrestcmd()
+			:call MessWithWindowSizes()
+			:exe cmd
+<
+							*winrestview()*
+winrestview({dict})
+		Uses the |Dictionary| returned by |winsaveview()| to restore
+		the view of the current window.
+		If you have changed the values the result is unpredictable.
+		If the window size changed the result won't be the same.
+
+							*winsaveview()*
+winsaveview()	Returns a |Dictionary| that contains information to restore
+		the view of the current window.  Use |winrestview()| to
+		restore the view.
+		This is useful if you have a mapping that jumps around in the
+		buffer and you want to go back to the original view.
+		This does not save fold information.  Use the 'foldenable'
+		option to temporarily switch off folding, so that folds are
+		not opened when moving around.
+		The return value includes:
+			lnum		cursor line number
+			col		cursor column
+			coladd		cursor column offset for 'virtualedit'
+			curswant	column for vertical movement
+			topline		first line in the window
+			topfill		filler lines, only in diff mode
+			leftcol		first column displayed
+			skipcol		columns skipped
+		Note that no option values are saved.
+
+
+winwidth({nr})						*winwidth()*
+		The result is a Number, which is the width of window {nr}.
+		When {nr} is zero, the width of the current window is
+		returned.  When window {nr} doesn't exist, -1 is returned.
+		An existing window always has a width of zero or more.
+		Examples: >
+  :echo "The current window has " . winwidth(0) . " columns."
+  :if winwidth(0) <= 50
+  :  exe "normal 50\|"
+  :endif
+<
+							*writefile()*
+writefile({list}, {fname} [, {binary}])
+		Write |List| {list} to file {fname}.  Each list item is
+		separated with a NL.  Each list item must be a String or
+		Number.
+		When {binary} is equal to "b" binary mode is used: There will
+		not be a NL after the last list item.  An empty item at the
+		end does cause the last line in the file to end in a NL.
+		All NL characters are replaced with a NUL character.
+		Inserting CR characters needs to be done before passing {list}
+		to writefile().
+		An existing file is overwritten, if possible.
+		When the write fails -1 is returned, otherwise 0.  There is an
+		error message if the file can't be created or when writing
+		fails.
+		Also see |readfile()|.
+		To copy a file byte for byte: >
+			:let fl = readfile("foo", "b")
+			:call writefile(fl, "foocopy", "b")
+<
+
+							*feature-list*
+There are three types of features:
+1.  Features that are only supported when they have been enabled when Vim
+    was compiled |+feature-list|.  Example: >
+	:if has("cindent")
+2.  Features that are only supported when certain conditions have been met.
+    Example: >
+	:if has("gui_running")
+<							*has-patch*
+3.  Included patches.  First check |v:version| for the version of Vim.
+    Then the "patch123" feature means that patch 123 has been included for
+    this version.  Example (checking version 6.2.148 or later): >
+	:if v:version > 602 || v:version == 602 && has("patch148")
+<   Note that it's possible for patch 147 to be omitted even though 148 is
+    included.
+
+all_builtin_terms	Compiled with all builtin terminals enabled.
+amiga			Amiga version of Vim.
+arabic			Compiled with Arabic support |Arabic|.
+arp			Compiled with ARP support (Amiga).
+autocmd			Compiled with autocommand support. |autocommand|
+balloon_eval		Compiled with |balloon-eval| support.
+balloon_multiline	GUI supports multiline balloons.
+beos			BeOS version of Vim.
+browse			Compiled with |:browse| support, and browse() will
+			work.
+builtin_terms		Compiled with some builtin terminals.
+byte_offset		Compiled with support for 'o' in 'statusline'
+cindent			Compiled with 'cindent' support.
+clientserver		Compiled with remote invocation support |clientserver|.
+clipboard		Compiled with 'clipboard' support.
+cmdline_compl		Compiled with |cmdline-completion| support.
+cmdline_hist		Compiled with |cmdline-history| support.
+cmdline_info		Compiled with 'showcmd' and 'ruler' support.
+comments		Compiled with |'comments'| support.
+cryptv			Compiled with encryption support |encryption|.
+cscope			Compiled with |cscope| support.
+compatible		Compiled to be very Vi compatible.
+debug			Compiled with "DEBUG" defined.
+dialog_con		Compiled with console dialog support.
+dialog_gui		Compiled with GUI dialog support.
+diff			Compiled with |vimdiff| and 'diff' support.
+digraphs		Compiled with support for digraphs.
+dnd			Compiled with support for the "~ register |quote_~|.
+dos32			32 bits DOS (DJGPP) version of Vim.
+dos16			16 bits DOS version of Vim.
+ebcdic			Compiled on a machine with ebcdic character set.
+emacs_tags		Compiled with support for Emacs tags.
+eval			Compiled with expression evaluation support.  Always
+			true, of course!
+ex_extra		Compiled with extra Ex commands |+ex_extra|.
+extra_search		Compiled with support for |'incsearch'| and
+			|'hlsearch'|
+farsi			Compiled with Farsi support |farsi|.
+file_in_path		Compiled with support for |gf| and ||
+filterpipe		When 'shelltemp' is off pipes are used for shell
+			read/write/filter commands
+find_in_path		Compiled with support for include file searches
+			|+find_in_path|.
+float			Compiled with support for |Float|.
+fname_case		Case in file names matters (for Amiga, MS-DOS, and
+			Windows this is not present).
+folding			Compiled with |folding| support.
+footer			Compiled with GUI footer support. |gui-footer|
+fork			Compiled to use fork()/exec() instead of system().
+gettext			Compiled with message translation |multi-lang|
+gui			Compiled with GUI enabled.
+gui_athena		Compiled with Athena GUI.
+gui_gtk			Compiled with GTK+ GUI (any version).
+gui_gtk2		Compiled with GTK+ 2 GUI (gui_gtk is also defined).
+gui_gnome		Compiled with Gnome support (gui_gtk is also defined).
+gui_mac			Compiled with Macintosh GUI.
+gui_motif		Compiled with Motif GUI.
+gui_photon		Compiled with Photon GUI.
+gui_win32		Compiled with MS Windows Win32 GUI.
+gui_win32s		idem, and Win32s system being used (Windows 3.1)
+gui_running		Vim is running in the GUI, or it will start soon.
+hangul_input		Compiled with Hangul input support. |hangul|
+iconv			Can use iconv() for conversion.
+insert_expand		Compiled with support for CTRL-X expansion commands in
+			Insert mode.
+jumplist		Compiled with |jumplist| support.
+keymap			Compiled with 'keymap' support.
+langmap			Compiled with 'langmap' support.
+libcall			Compiled with |libcall()| support.
+linebreak		Compiled with 'linebreak', 'breakat' and 'showbreak'
+			support.
+lispindent		Compiled with support for lisp indenting.
+listcmds		Compiled with commands for the buffer list |:files|
+			and the argument list |arglist|.
+localmap		Compiled with local mappings and abbr. |:map-local|
+lua			Compiled with Lua interface |Lua|.
+mac			Macintosh version of Vim.
+macunix			Macintosh version of Vim, using Unix files (OS-X).
+menu			Compiled with support for |:menu|.
+mksession		Compiled with support for |:mksession|.
+modify_fname		Compiled with file name modifiers. |filename-modifiers|
+mouse			Compiled with support mouse.
+mouseshape		Compiled with support for 'mouseshape'.
+mouse_dec		Compiled with support for Dec terminal mouse.
+mouse_gpm		Compiled with support for gpm (Linux console mouse)
+mouse_netterm		Compiled with support for netterm mouse.
+mouse_pterm		Compiled with support for qnx pterm mouse.
+mouse_sysmouse		Compiled with support for sysmouse (*BSD console mouse)
+mouse_xterm		Compiled with support for xterm mouse.
+multi_byte		Compiled with support for 'encoding'
+multi_byte_encoding	'encoding' is set to a multi-byte encoding.
+multi_byte_ime		Compiled with support for IME input method.
+multi_lang		Compiled with support for multiple languages.
+mzscheme		Compiled with MzScheme interface |mzscheme|.
+netbeans_intg		Compiled with support for |netbeans|.
+netbeans_enabled	Compiled with support for |netbeans| and connected.
+ole			Compiled with OLE automation support for Win32.
+os2			OS/2 version of Vim.
+osfiletype		Compiled with support for osfiletypes |+osfiletype|
+path_extra		Compiled with up/downwards search in 'path' and 'tags'
+perl			Compiled with Perl interface.
+persistent_undo		Compiled with support for persistent undo history.
+postscript		Compiled with PostScript file printing.
+printer			Compiled with |:hardcopy| support.
+profile			Compiled with |:profile| support.
+python			Compiled with Python interface.
+qnx			QNX version of Vim.
+quickfix		Compiled with |quickfix| support.
+reltime			Compiled with |reltime()| support.
+rightleft		Compiled with 'rightleft' support.
+ruby			Compiled with Ruby interface |ruby|.
+scrollbind		Compiled with 'scrollbind' support.
+showcmd			Compiled with 'showcmd' support.
+signs			Compiled with |:sign| support.
+smartindent		Compiled with 'smartindent' support.
+sniff			Compiled with SNiFF interface support.
+startuptime		Compiled with |--startuptime| support.
+statusline		Compiled with support for 'statusline', 'rulerformat'
+			and special formats of 'titlestring' and 'iconstring'.
+sun_workshop		Compiled with support for Sun |workshop|.
+spell			Compiled with spell checking support |spell|.
+syntax			Compiled with syntax highlighting support |syntax|.
+syntax_items		There are active syntax highlighting items for the
+			current buffer.
+system			Compiled to use system() instead of fork()/exec().
+tag_binary		Compiled with binary searching in tags files
+			|tag-binary-search|.
+tag_old_static		Compiled with support for old static tags
+			|tag-old-static|.
+tag_any_white		Compiled with support for any white characters in tags
+			files |tag-any-white|.
+tcl			Compiled with Tcl interface.
+terminfo		Compiled with terminfo instead of termcap.
+termresponse		Compiled with support for |t_RV| and |v:termresponse|.
+textobjects		Compiled with support for |text-objects|.
+tgetent			Compiled with tgetent support, able to use a termcap
+			or terminfo file.
+title			Compiled with window title support |'title'|.
+toolbar			Compiled with support for |gui-toolbar|.
+unix			Unix version of Vim.
+user_commands		User-defined commands.
+viminfo			Compiled with viminfo support.
+vim_starting		True while initial source'ing takes place.
+vertsplit		Compiled with vertically split windows |:vsplit|.
+virtualedit		Compiled with 'virtualedit' option.
+visual			Compiled with Visual mode.
+visualextra		Compiled with extra Visual mode commands.
+			|blockwise-operators|.
+vms			VMS version of Vim.
+vreplace		Compiled with |gR| and |gr| commands.
+wildignore		Compiled with 'wildignore' option.
+wildmenu		Compiled with 'wildmenu' option.
+windows			Compiled with support for more than one window.
+winaltkeys		Compiled with 'winaltkeys' option.
+win16			Win16 version of Vim (MS-Windows 3.1).
+win32			Win32 version of Vim (MS-Windows 95/98/ME/NT/2000/XP).
+win64			Win64 version of Vim (MS-Windows 64 bit).
+win32unix		Win32 version of Vim, using Unix files (Cygwin)
+win95			Win32 version for MS-Windows 95/98/ME.
+writebackup		Compiled with 'writebackup' default on.
+xfontset		Compiled with X fontset support |xfontset|.
+xim			Compiled with X input method support |xim|.
+xsmp			Compiled with X session management support.
+xsmp_interact		Compiled with interactive X session management support.
+xterm_clipboard		Compiled with support for xterm clipboard.
+xterm_save		Compiled with support for saving and restoring the
+			xterm screen.
+x11			Compiled with X11 support.
+
+							*string-match*
+Matching a pattern in a String
+
+A regexp pattern as explained at |pattern| is normally used to find a match in
+the buffer lines.  When a pattern is used to find a match in a String, almost
+everything works in the same way.  The difference is that a String is handled
+like it is one line.  When it contains a "\n" character, this is not seen as a
+line break for the pattern.  It can be matched with a "\n" in the pattern, or
+with ".".  Example: >
+	:let a = "aaaa\nxxxx"
+	:echo matchstr(a, "..\n..")
+	aa
+	xx
+	:echo matchstr(a, "a.x")
+	a
+	x
+
+Don't forget that "^" will only match at the first character of the String and
+"$" at the last character of the string.  They don't match after or before a
+"\n".
+
+==============================================================================
+5. Defining functions					*user-functions*
+
+New functions can be defined.  These can be called just like builtin
+functions.  The function executes a sequence of Ex commands.  Normal mode
+commands can be executed with the |:normal| command.
+
+The function name must start with an uppercase letter, to avoid confusion with
+builtin functions.  To prevent from using the same name in different scripts
+avoid obvious, short names.  A good habit is to start the function name with
+the name of the script, e.g., "HTMLcolor()".
+
+It's also possible to use curly braces, see |curly-braces-names|.  And the
+|autoload| facility is useful to define a function only when it's called.
+
+							*local-function*
+A function local to a script must start with "s:".  A local script function
+can only be called from within the script and from functions, user commands
+and autocommands defined in the script.  It is also possible to call the
+function from a mapping defined in the script, but then || must be used
+instead of "s:" when the mapping is expanded outside of the script.
+
+					*:fu* *:function* *E128* *E129* *E123*
+:fu[nction]		List all functions and their arguments.
+
+:fu[nction] {name}	List function {name}.
+			{name} can also be a |Dictionary| entry that is a
+			|Funcref|: >
+				:function dict.init
+
+:fu[nction] /{pattern}	List functions with a name matching {pattern}.
+			Example that lists all functions ending with "File": >
+				:function /File$
+<
+							*:function-verbose*
+When 'verbose' is non-zero, listing a function will also display where it was
+last defined. Example: >
+
+    :verbose function SetFileTypeSH
+	function SetFileTypeSH(name)
+	    Last set from /usr/share/vim/vim-7.0/filetype.vim
+<
+See |:verbose-cmd| for more information.
+
+							*E124* *E125*
+:fu[nction][!] {name}([arguments]) [range] [abort] [dict]
+			Define a new function by the name {name}.  The name
+			must be made of alphanumeric characters and '_', and
+			must start with a capital or "s:" (see above).
+
+			{name} can also be a |Dictionary| entry that is a
+			|Funcref|: >
+				:function dict.init(arg)
+<			"dict" must be an existing dictionary.	The entry
+			"init" is added if it didn't exist yet.  Otherwise [!]
+			is required to overwrite an existing function.	The
+			result is a |Funcref| to a numbered function.  The
+			function can only be used with a |Funcref| and will be
+			deleted if there are no more references to it.
+								*E127* *E122*
+			When a function by this name already exists and [!] is
+			not used an error message is given.  When [!] is used,
+			an existing function is silently replaced.  Unless it
+			is currently being executed, that is an error.
+
+			For the {arguments} see |function-argument|.
+
+						*a:firstline* *a:lastline*
+			When the [range] argument is added, the function is
+			expected to take care of a range itself.  The range is
+			passed as "a:firstline" and "a:lastline".  If [range]
+			is excluded, ":{range}call" will call the function for
+			each line in the range, with the cursor on the start
+			of each line.  See |function-range-example|.
+
+			When the [abort] argument is added, the function will
+			abort as soon as an error is detected.
+
+			When the [dict] argument is added, the function must
+			be invoked through an entry in a |Dictionary|.	The
+			local variable "self" will then be set to the
+			dictionary.  See |Dictionary-function|.
+
+						*function-search-undo*
+			The last used search pattern and the redo command "."
+			will not be changed by the function.  This also
+			implies that the effect of |:nohlsearch| is undone
+			when the function returns.
+
+					*:endf* *:endfunction* *E126* *E193*
+:endf[unction]		The end of a function definition.  Must be on a line
+			by its own, without other commands.
+
+					*:delf* *:delfunction* *E130* *E131*
+:delf[unction] {name}	Delete function {name}.
+			{name} can also be a |Dictionary| entry that is a
+			|Funcref|: >
+				:delfunc dict.init
+<			This will remove the "init" entry from "dict".	The
+			function is deleted if there are no more references to
+			it.
+							*:retu* *:return* *E133*
+:retu[rn] [expr]	Return from a function.  When "[expr]" is given, it is
+			evaluated and returned as the result of the function.
+			If "[expr]" is not given, the number 0 is returned.
+			When a function ends without an explicit ":return",
+			the number 0 is returned.
+			Note that there is no check for unreachable lines,
+			thus there is no warning if commands follow ":return".
+
+			If the ":return" is used after a |:try| but before the
+			matching |:finally| (if present), the commands
+			following the ":finally" up to the matching |:endtry|
+			are executed first.  This process applies to all
+			nested ":try"s inside the function.  The function
+			returns at the outermost ":endtry".
+
+						*function-argument* *a:var*
+An argument can be defined by giving its name.	In the function this can then
+be used as "a:name" ("a:" for argument).
+					*a:0* *a:1* *a:000* *E740* *...*
+Up to 20 arguments can be given, separated by commas.  After the named
+arguments an argument "..." can be specified, which means that more arguments
+may optionally be following.  In the function the extra arguments can be used
+as "a:1", "a:2", etc.  "a:0" is set to the number of extra arguments (which
+can be 0).  "a:000" is set to a |List| that contains these arguments.  Note
+that "a:1" is the same as "a:000[0]".
+								*E742*
+The a: scope and the variables in it cannot be changed, they are fixed.
+However, if a |List| or |Dictionary| is used, you can change their contents.
+Thus you can pass a |List| to a function and have the function add an item to
+it.  If you want to make sure the function cannot change a |List| or
+|Dictionary| use |:lockvar|.
+
+When not using "...", the number of arguments in a function call must be equal
+to the number of named arguments.  When using "...", the number of arguments
+may be larger.
+
+It is also possible to define a function without any arguments.  You must
+still supply the () then.  The body of the function follows in the next lines,
+until the matching |:endfunction|.  It is allowed to define another function
+inside a function body.
+
+							*local-variables*
+Inside a function variables can be used.  These are local variables, which
+will disappear when the function returns.  Global variables need to be
+accessed with "g:".
+
+Example: >
+  :function Table(title, ...)
+  :  echohl Title
+  :  echo a:title
+  :  echohl None
+  :  echo a:0 . " items:"
+  :  for s in a:000
+  :    echon ' ' . s
+  :  endfor
+  :endfunction
+
+This function can then be called with: >
+  call Table("Table", "line1", "line2")
+  call Table("Empty Table")
+
+To return more than one value, return a |List|: >
+  :function Compute(n1, n2)
+  :  if a:n2 == 0
+  :    return ["fail", 0]
+  :  endif
+  :  return ["ok", a:n1 / a:n2]
+  :endfunction
+
+This function can then be called with: >
+  :let [success, div] = Compute(102, 6)
+  :if success == "ok"
+  :  echo div
+  :endif
+<
+						*:cal* *:call* *E107* *E117*
+:[range]cal[l] {name}([arguments])
+		Call a function.  The name of the function and its arguments
+		are as specified with |:function|.  Up to 20 arguments can be
+		used.  The returned value is discarded.
+		Without a range and for functions that accept a range, the
+		function is called once.  When a range is given the cursor is
+		positioned at the start of the first line before executing the
+		function.
+		When a range is given and the function doesn't handle it
+		itself, the function is executed for each line in the range,
+		with the cursor in the first column of that line.  The cursor
+		is left at the last line (possibly moved by the last function
+		call).	The arguments are re-evaluated for each line.  Thus
+		this works:
+						*function-range-example*  >
+	:function Mynumber(arg)
+	:  echo line(".") . " " . a:arg
+	:endfunction
+	:1,5call Mynumber(getline("."))
+<
+		The "a:firstline" and "a:lastline" are defined anyway, they
+		can be used to do something different at the start or end of
+		the range.
+
+		Example of a function that handles the range itself: >
+
+	:function Cont() range
+	:  execute (a:firstline + 1) . "," . a:lastline . 's/^/\t\\ '
+	:endfunction
+	:4,8call Cont()
+<
+		This function inserts the continuation character "\" in front
+		of all the lines in the range, except the first one.
+
+		When the function returns a composite value it can be further
+		dereferenced, but the range will not be used then.  Example: >
+	:4,8call GetDict().method()
+<		Here GetDict() gets the range but method() does not.
+
+								*E132*
+The recursiveness of user functions is restricted with the |'maxfuncdepth'|
+option.
+
+
+AUTOMATICALLY LOADING FUNCTIONS ~
+							*autoload-functions*
+When using many or large functions, it's possible to automatically define them
+only when they are used.  There are two methods: with an autocommand and with
+the "autoload" directory in 'runtimepath'.
+
+
+Using an autocommand ~
+
+This is introduced in the user manual, section |41.14|.
+
+The autocommand is useful if you have a plugin that is a long Vim script file.
+You can define the autocommand and quickly quit the script with |:finish|.
+That makes Vim startup faster.	The autocommand should then load the same file
+again, setting a variable to skip the |:finish| command.
+
+Use the FuncUndefined autocommand event with a pattern that matches the
+function(s) to be defined.  Example: >
+
+	:au FuncUndefined BufNet* source ~/vim/bufnetfuncs.vim
+
+The file "~/vim/bufnetfuncs.vim" should then define functions that start with
+"BufNet".  Also see |FuncUndefined|.
+
+
+Using an autoload script ~
+							*autoload* *E746*
+This is introduced in the user manual, section |41.15|.
+
+Using a script in the "autoload" directory is simpler, but requires using
+exactly the right file name.  A function that can be autoloaded has a name
+like this: >
+
+	:call filename#funcname()
+
+When such a function is called, and it is not defined yet, Vim will search the
+"autoload" directories in 'runtimepath' for a script file called
+"filename.vim".  For example "~/.vim/autoload/filename.vim".  That file should
+then define the function like this: >
+
+	function filename#funcname()
+	   echo "Done!"
+	endfunction
+
+The file name and the name used before the # in the function must match
+exactly, and the defined function must have the name exactly as it will be
+called.
+
+It is possible to use subdirectories.  Every # in the function name works like
+a path separator.  Thus when calling a function: >
+
+	:call foo#bar#func()
+
+Vim will look for the file "autoload/foo/bar.vim" in 'runtimepath'.
+
+This also works when reading a variable that has not been set yet: >
+
+	:let l = foo#bar#lvar
+
+However, when the autoload script was already loaded it won't be loaded again
+for an unknown variable.
+
+When assigning a value to such a variable nothing special happens.  This can
+be used to pass settings to the autoload script before it's loaded: >
+
+	:let foo#bar#toggle = 1
+	:call foo#bar#func()
+
+Note that when you make a mistake and call a function that is supposed to be
+defined in an autoload script, but the script doesn't actually define the
+function, the script will be sourced every time you try to call the function.
+And you will get an error message every time.
+
+Also note that if you have two script files, and one calls a function in the
+other and vice versa, before the used function is defined, it won't work.
+Avoid using the autoload functionality at the toplevel.
+
+Hint: If you distribute a bunch of scripts you can pack them together with the
+|vimball| utility.  Also read the user manual |distribute-script|.
+
+==============================================================================
+6. Curly braces names					*curly-braces-names*
+
+Wherever you can use a variable, you can use a "curly braces name" variable.
+This is a regular variable name with one or more expressions wrapped in braces
+{} like this: >
+	my_{adjective}_variable
+
+When Vim encounters this, it evaluates the expression inside the braces, puts
+that in place of the expression, and re-interprets the whole as a variable
+name.  So in the above example, if the variable "adjective" was set to
+"noisy", then the reference would be to "my_noisy_variable", whereas if
+"adjective" was set to "quiet", then it would be to "my_quiet_variable".
+
+One application for this is to create a set of variables governed by an option
+value.	For example, the statement >
+	echo my_{&background}_message
+
+would output the contents of "my_dark_message" or "my_light_message" depending
+on the current value of 'background'.
+
+You can use multiple brace pairs: >
+	echo my_{adverb}_{adjective}_message
+..or even nest them: >
+	echo my_{ad{end_of_word}}_message
+where "end_of_word" is either "verb" or "jective".
+
+However, the expression inside the braces must evaluate to a valid single
+variable name, e.g. this is invalid: >
+	:let foo='a + b'
+	:echo c{foo}d
+.. since the result of expansion is "ca + bd", which is not a variable name.
+
+						*curly-braces-function-names*
+You can call and define functions by an evaluated name in a similar way.
+Example: >
+	:let func_end='whizz'
+	:call my_func_{func_end}(parameter)
+
+This would call the function "my_func_whizz(parameter)".
+
+==============================================================================
+7. Commands						*expression-commands*
+
+:let {var-name} = {expr1}				*:let* *E18*
+			Set internal variable {var-name} to the result of the
+			expression {expr1}.  The variable will get the type
+			from the {expr}.  If {var-name} didn't exist yet, it
+			is created.
+
+:let {var-name}[{idx}] = {expr1}			*E689*
+			Set a list item to the result of the expression
+			{expr1}.  {var-name} must refer to a list and {idx}
+			must be a valid index in that list.  For nested list
+			the index can be repeated.
+			This cannot be used to add an item to a |List|.
+			This cannot be used to set a byte in a String.	You
+			can do that like this: >
+				:let var = var[0:2] . 'X' . var[4:]
+<
+							*E711* *E719*
+:let {var-name}[{idx1}:{idx2}] = {expr1}		*E708* *E709* *E710*
+			Set a sequence of items in a |List| to the result of
+			the expression {expr1}, which must be a list with the
+			correct number of items.
+			{idx1} can be omitted, zero is used instead.
+			{idx2} can be omitted, meaning the end of the list.
+			When the selected range of items is partly past the
+			end of the list, items will be added.
+
+					*:let+=* *:let-=* *:let.=* *E734*
+:let {var} += {expr1}	Like ":let {var} = {var} + {expr1}".
+:let {var} -= {expr1}	Like ":let {var} = {var} - {expr1}".
+:let {var} .= {expr1}	Like ":let {var} = {var} . {expr1}".
+			These fail if {var} was not set yet and when the type
+			of {var} and {expr1} don't fit the operator.
+
+
+:let ${env-name} = {expr1}			*:let-environment* *:let-$*
+			Set environment variable {env-name} to the result of
+			the expression {expr1}.  The type is always String.
+:let ${env-name} .= {expr1}
+			Append {expr1} to the environment variable {env-name}.
+			If the environment variable didn't exist yet this
+			works like "=".
+
+:let @{reg-name} = {expr1}			*:let-register* *:let-@*
+			Write the result of the expression {expr1} in register
+			{reg-name}.  {reg-name} must be a single letter, and
+			must be the name of a writable register (see
+			|registers|).  "@@" can be used for the unnamed
+			register, "@/" for the search pattern.
+			If the result of {expr1} ends in a  or , the
+			register will be linewise, otherwise it will be set to
+			characterwise.
+			This can be used to clear the last search pattern: >
+				:let @/ = ""
+<			This is different from searching for an empty string,
+			that would match everywhere.
+
+:let @{reg-name} .= {expr1}
+			Append {expr1} to register {reg-name}.	If the
+			register was empty it's like setting it to {expr1}.
+
+:let &{option-name} = {expr1}			*:let-option* *:let-&*
+			Set option {option-name} to the result of the
+			expression {expr1}.  A String or Number value is
+			always converted to the type of the option.
+			For an option local to a window or buffer the effect
+			is just like using the |:set| command: both the local
+			value and the global value are changed.
+			Example: >
+				:let &path = &path . ',/usr/local/include'
+
+:let &{option-name} .= {expr1}
+			For a string option: Append {expr1} to the value.
+			Does not insert a comma like |:set+=|.
+
+:let &{option-name} += {expr1}
+:let &{option-name} -= {expr1}
+			For a number or boolean option: Add or subtract
+			{expr1}.
+
+:let &l:{option-name} = {expr1}
+:let &l:{option-name} .= {expr1}
+:let &l:{option-name} += {expr1}
+:let &l:{option-name} -= {expr1}
+			Like above, but only set the local value of an option
+			(if there is one).  Works like |:setlocal|.
+
+:let &g:{option-name} = {expr1}
+:let &g:{option-name} .= {expr1}
+:let &g:{option-name} += {expr1}
+:let &g:{option-name} -= {expr1}
+			Like above, but only set the global value of an option
+			(if there is one).  Works like |:setglobal|.
+
+:let [{name1}, {name2}, ...] = {expr1}		*:let-unpack* *E687* *E688*
+			{expr1} must evaluate to a |List|.  The first item in
+			the list is assigned to {name1}, the second item to
+			{name2}, etc.
+			The number of names must match the number of items in
+			the |List|.
+			Each name can be one of the items of the ":let"
+			command as mentioned above.
+			Example: >
+				:let [s, item] = GetItem(s)
+<			Detail: {expr1} is evaluated first, then the
+			assignments are done in sequence.  This matters if
+			{name2} depends on {name1}.  Example: >
+				:let x = [0, 1]
+				:let i = 0
+				:let [i, x[i]] = [1, 2]
+				:echo x
+<			The result is [0, 2].
+
+:let [{name1}, {name2}, ...] .= {expr1}
+:let [{name1}, {name2}, ...] += {expr1}
+:let [{name1}, {name2}, ...] -= {expr1}
+			Like above, but append/add/subtract the value for each
+			|List| item.
+
+:let [{name}, ..., ; {lastname}] = {expr1}
+			Like |:let-unpack| above, but the |List| may have more
+			items than there are names.  A list of the remaining
+			items is assigned to {lastname}.  If there are no
+			remaining items {lastname} is set to an empty list.
+			Example: >
+				:let [a, b; rest] = ["aval", "bval", 3, 4]
+<
+:let [{name}, ..., ; {lastname}] .= {expr1}
+:let [{name}, ..., ; {lastname}] += {expr1}
+:let [{name}, ..., ; {lastname}] -= {expr1}
+			Like above, but append/add/subtract the value for each
+			|List| item.
+							*E106*
+:let {var-name}	..	List the value of variable {var-name}.	Multiple
+			variable names may be given.  Special names recognized
+			here:				*E738*
+			  g:	global variables
+			  b:	local buffer variables
+			  w:	local window variables
+			  t:	local tab page variables
+			  s:	script-local variables
+			  l:	local function variables
+			  v:	Vim variables.
+
+:let			List the values of all variables.  The type of the
+			variable is indicated before the value:
+			    	String
+				#	Number
+				*	Funcref
+
+
+:unl[et][!] {name} ...				*:unlet* *:unl* *E108* *E795*
+			Remove the internal variable {name}.  Several variable
+			names can be given, they are all removed.  The name
+			may also be a |List| or |Dictionary| item.
+			With [!] no error message is given for non-existing
+			variables.
+			One or more items from a |List| can be removed: >
+				:unlet list[3]	  " remove fourth item
+				:unlet list[3:]   " remove fourth item to last
+<			One item from a |Dictionary| can be removed at a time: >
+				:unlet dict['two']
+				:unlet dict.two
+<			This is especially useful to clean up used global
+			variables and script-local variables (these are not
+			deleted when the script ends).  Function-local
+			variables are automatically deleted when the function
+			ends.
+
+:lockv[ar][!] [depth] {name} ...			*:lockvar* *:lockv*
+			Lock the internal variable {name}.  Locking means that
+			it can no longer be changed (until it is unlocked).
+			A locked variable can be deleted: >
+				:lockvar v
+				:let v = 'asdf'		" fails!
+				:unlet v
+<							*E741*
+			If you try to change a locked variable you get an
+			error message: "E741: Value of {name} is locked"
+
+			[depth] is relevant when locking a |List| or
+			|Dictionary|.  It specifies how deep the locking goes:
+				1	Lock the |List| or |Dictionary| itself,
+					cannot add or remove items, but can
+					still change their values.
+				2	Also lock the values, cannot change
+					the items.  If an item is a |List| or
+					|Dictionary|, cannot add or remove
+					items, but can still change the
+					values.
+				3	Like 2 but for the |List| /
+					|Dictionary| in the |List| /
+					|Dictionary|, one level deeper.
+			The default [depth] is 2, thus when {name} is a |List|
+			or |Dictionary| the values cannot be changed.
+								*E743*
+			For unlimited depth use [!] and omit [depth].
+			However, there is a maximum depth of 100 to catch
+			loops.
+
+			Note that when two variables refer to the same |List|
+			and you lock one of them, the |List| will also be
+			locked when used through the other variable.
+			Example: >
+				:let l = [0, 1, 2, 3]
+				:let cl = l
+				:lockvar l
+				:let cl[1] = 99		" won't work!
+<			You may want to make a copy of a list to avoid this.
+			See |deepcopy()|.
+
+
+:unlo[ckvar][!] [depth] {name} ...			*:unlockvar* *:unlo*
+			Unlock the internal variable {name}.  Does the
+			opposite of |:lockvar|.
+
+
+:if {expr1}			*:if* *:endif* *:en* *E171* *E579* *E580*
+:en[dif]		Execute the commands until the next matching ":else"
+			or ":endif" if {expr1} evaluates to non-zero.
+
+			From Vim version 4.5 until 5.0, every Ex command in
+			between the ":if" and ":endif" is ignored.  These two
+			commands were just to allow for future expansions in a
+			backwards compatible way.  Nesting was allowed.  Note
+			that any ":else" or ":elseif" was ignored, the "else"
+			part was not executed either.
+
+			You can use this to remain compatible with older
+			versions: >
+				:if version >= 500
+				:  version-5-specific-commands
+				:endif
+<			The commands still need to be parsed to find the
+			"endif".  Sometimes an older Vim has a problem with a
+			new command.  For example, ":silent" is recognized as
+			a ":substitute" command.  In that case ":execute" can
+			avoid problems: >
+				:if version >= 600
+				:  execute "silent 1,$delete"
+				:endif
+<
+			NOTE: The ":append" and ":insert" commands don't work
+			properly in between ":if" and ":endif".
+
+						*:else* *:el* *E581* *E583*
+:el[se]			Execute the commands until the next matching ":else"
+			or ":endif" if they previously were not being
+			executed.
+
+					*:elseif* *:elsei* *E582* *E584*
+:elsei[f] {expr1}	Short for ":else" ":if", with the addition that there
+			is no extra ":endif".
+
+:wh[ile] {expr1}			*:while* *:endwhile* *:wh* *:endw*
+						*E170* *E585* *E588* *E733*
+:endw[hile]		Repeat the commands between ":while" and ":endwhile",
+			as long as {expr1} evaluates to non-zero.
+			When an error is detected from a command inside the
+			loop, execution continues after the "endwhile".
+			Example: >
+				:let lnum = 1
+				:while lnum <= line("$")
+				   :call FixLine(lnum)
+				   :let lnum = lnum + 1
+				:endwhile
+<
+			NOTE: The ":append" and ":insert" commands don't work
+			properly inside a ":while" and ":for" loop.
+
+:for {var} in {list}					*:for* *E690* *E732*
+:endfo[r]						*:endfo* *:endfor*
+			Repeat the commands between ":for" and ":endfor" for
+			each item in {list}.  Variable {var} is set to the
+			value of each item.
+			When an error is detected for a command inside the
+			loop, execution continues after the "endfor".
+			Changing {list} inside the loop affects what items are
+			used.  Make a copy if this is unwanted: >
+				:for item in copy(mylist)
+<			When not making a copy, Vim stores a reference to the
+			next item in the list, before executing the commands
+			with the current item.	Thus the current item can be
+			removed without effect.  Removing any later item means
+			it will not be found.  Thus the following example
+			works (an inefficient way to make a list empty): >
+				for item in mylist
+				   call remove(mylist, 0)
+				endfor
+<			Note that reordering the list (e.g., with sort() or
+			reverse()) may have unexpected effects.
+			Note that the type of each list item should be
+			identical to avoid errors for the type of {var}
+			changing.  Unlet the variable at the end of the loop
+			to allow multiple item types: >
+				for item in ["foo", ["bar"]]
+				   echo item
+				   unlet item  " E706 without this
+				endfor
+
+:for [{var1}, {var2}, ...] in {listlist}
+:endfo[r]
+			Like ":for" above, but each item in {listlist} must be
+			a list, of which each item is assigned to {var1},
+			{var2}, etc.  Example: >
+				:for [lnum, col] in [[1, 3], [2, 5], [3, 8]]
+				   :echo getline(lnum)[col]
+				:endfor
+<
+						*:continue* *:con* *E586*
+:con[tinue]		When used inside a ":while" or ":for" loop, jumps back
+			to the start of the loop.
+			If it is used after a |:try| inside the loop but
+			before the matching |:finally| (if present), the
+			commands following the ":finally" up to the matching
+			|:endtry| are executed first.  This process applies to
+			all nested ":try"s inside the loop.  The outermost
+			":endtry" then jumps back to the start of the loop.
+
+						*:break* *:brea* *E587*
+:brea[k]		When used inside a ":while" or ":for" loop, skips to
+			the command after the matching ":endwhile" or
+			":endfor".
+			If it is used after a |:try| inside the loop but
+			before the matching |:finally| (if present), the
+			commands following the ":finally" up to the matching
+			|:endtry| are executed first.  This process applies to
+			all nested ":try"s inside the loop.  The outermost
+			":endtry" then jumps to the command after the loop.
+
+:try				*:try* *:endt* *:endtry* *E600* *E601* *E602*
+:endt[ry]		Change the error handling for the commands between
+			":try" and ":endtry" including everything being
+			executed across ":source" commands, function calls,
+			or autocommand invocations.
+
+			When an error or interrupt is detected and there is
+			a |:finally| command following, execution continues
+			after the ":finally".  Otherwise, or when the
+			":endtry" is reached thereafter, the next
+			(dynamically) surrounding ":try" is checked for
+			a corresponding ":finally" etc.  Then the script
+			processing is terminated.  (Whether a function
+			definition has an "abort" argument does not matter.)
+			Example: >
+		:try | edit too much | finally | echo "cleanup" | endtry
+		:echo "impossible"	" not reached, script terminated above
+<
+			Moreover, an error or interrupt (dynamically) inside
+			":try" and ":endtry" is converted to an exception.  It
+			can be caught as if it were thrown by a |:throw|
+			command (see |:catch|).  In this case, the script
+			processing is not terminated.
+
+			The value "Vim:Interrupt" is used for an interrupt
+			exception.  An error in a Vim command is converted
+			to a value of the form "Vim({command}):{errmsg}",
+			other errors are converted to a value of the form
+			"Vim:{errmsg}".  {command} is the full command name,
+			and {errmsg} is the message that is displayed if the
+			error exception is not caught, always beginning with
+			the error number.
+			Examples: >
+		:try | sleep 100 | catch /^Vim:Interrupt$/ | endtry
+		:try | edit | catch /^Vim(edit):E\d\+/ | echo "error" | endtry
+<
+					*:cat* *:catch* *E603* *E604* *E605*
+:cat[ch] /{pattern}/	The following commands until the next |:catch|,
+			|:finally|, or |:endtry| that belongs to the same
+			|:try| as the ":catch" are executed when an exception
+			matching {pattern} is being thrown and has not yet
+			been caught by a previous ":catch".  Otherwise, these
+			commands are skipped.
+			When {pattern} is omitted all errors are caught.
+			Examples: >
+		:catch /^Vim:Interrupt$/	" catch interrupts (CTRL-C)
+		:catch /^Vim\%((\a\+)\)\=:E/	" catch all Vim errors
+		:catch /^Vim\%((\a\+)\)\=:/	" catch errors and interrupts
+		:catch /^Vim(write):/		" catch all errors in :write
+		:catch /^Vim\%((\a\+)\)\=:E123/	" catch error E123
+		:catch /my-exception/		" catch user exception
+		:catch /.*/			" catch everything
+		:catch				" same as /.*/
+<
+			Another character can be used instead of / around the
+			{pattern}, so long as it does not have a special
+			meaning (e.g., '|' or '"') and doesn't occur inside
+			{pattern}.
+			NOTE: It is not reliable to ":catch" the TEXT of
+			an error message because it may vary in different
+			locales.
+
+					*:fina* *:finally* *E606* *E607*
+:fina[lly]		The following commands until the matching |:endtry|
+			are executed whenever the part between the matching
+			|:try| and the ":finally" is left:  either by falling
+			through to the ":finally" or by a |:continue|,
+			|:break|, |:finish|, or |:return|, or by an error or
+			interrupt or exception (see |:throw|).
+
+							*:th* *:throw* *E608*
+:th[row] {expr1}	The {expr1} is evaluated and thrown as an exception.
+			If the ":throw" is used after a |:try| but before the
+			first corresponding |:catch|, commands are skipped
+			until the first ":catch" matching {expr1} is reached.
+			If there is no such ":catch" or if the ":throw" is
+			used after a ":catch" but before the |:finally|, the
+			commands following the ":finally" (if present) up to
+			the matching |:endtry| are executed.  If the ":throw"
+			is after the ":finally", commands up to the ":endtry"
+			are skipped.  At the ":endtry", this process applies
+			again for the next dynamically surrounding ":try"
+			(which may be found in a calling function or sourcing
+			script), until a matching ":catch" has been found.
+			If the exception is not caught, the command processing
+			is terminated.
+			Example: >
+		:try | throw "oops" | catch /^oo/ | echo "caught" | endtry
+<
+
+							*:ec* *:echo*
+:ec[ho] {expr1} ..	Echoes each {expr1}, with a space in between.  The
+			first {expr1} starts on a new line.
+			Also see |:comment|.
+			Use "\n" to start a new line.  Use "\r" to move the
+			cursor to the first column.
+			Uses the highlighting set by the |:echohl| command.
+			Cannot be followed by a comment.
+			Example: >
+		:echo "the value of 'shell' is" &shell
+<							*:echo-redraw*
+			A later redraw may make the message disappear again.
+			And since Vim mostly postpones redrawing until it's
+			finished with a sequence of commands this happens
+			quite often.  To avoid that a command from before the
+			":echo" causes a redraw afterwards (redraws are often
+			postponed until you type something), force a redraw
+			with the |:redraw| command.  Example: >
+		:new | redraw | echo "there is a new window"
+<
+							*:echon*
+:echon {expr1} ..	Echoes each {expr1}, without anything added.  Also see
+			|:comment|.
+			Uses the highlighting set by the |:echohl| command.
+			Cannot be followed by a comment.
+			Example: >
+				:echon "the value of 'shell' is " &shell
+<
+			Note the difference between using ":echo", which is a
+			Vim command, and ":!echo", which is an external shell
+			command: >
+		:!echo %		--> filename
+<			The arguments of ":!" are expanded, see |:_%|. >
+		:!echo "%"		--> filename or "filename"
+<			Like the previous example.  Whether you see the double
+			quotes or not depends on your 'shell'. >
+		:echo %			--> nothing
+<			The '%' is an illegal character in an expression. >
+		:echo "%"		--> %
+<			This just echoes the '%' character. >
+		:echo expand("%")	--> filename
+<			This calls the expand() function to expand the '%'.
+
+							*:echoh* *:echohl*
+:echoh[l] {name}	Use the highlight group {name} for the following
+			|:echo|, |:echon| and |:echomsg| commands.  Also used
+			for the |input()| prompt.  Example: >
+		:echohl WarningMsg | echo "Don't panic!" | echohl None
+<			Don't forget to set the group back to "None",
+			otherwise all following echo's will be highlighted.
+
+							*:echom* *:echomsg*
+:echom[sg] {expr1} ..	Echo the expression(s) as a true message, saving the
+			message in the |message-history|.
+			Spaces are placed between the arguments as with the
+			|:echo| command.  But unprintable characters are
+			displayed, not interpreted.
+			The parsing works slightly different from |:echo|,
+			more like |:execute|.  All the expressions are first
+			evaluated and concatenated before echoing anything.
+			The expressions must evaluate to a Number or String, a
+			Dictionary or List causes an error.
+			Uses the highlighting set by the |:echohl| command.
+			Example: >
+		:echomsg "It's a Zizzer Zazzer Zuzz, as you can plainly see."
+<			See |:echo-redraw| to avoid the message disappearing
+			when the screen is redrawn.
+							*:echoe* *:echoerr*
+:echoe[rr] {expr1} ..	Echo the expression(s) as an error message, saving the
+			message in the |message-history|.  When used in a
+			script or function the line number will be added.
+			Spaces are placed between the arguments as with the
+			:echo command.	When used inside a try conditional,
+			the message is raised as an error exception instead
+			(see |try-echoerr|).
+			Example: >
+		:echoerr "This script just failed!"
+<			If you just want a highlighted message use |:echohl|.
+			And to get a beep: >
+		:exe "normal \"
+<
+							*:exe* *:execute*
+:exe[cute] {expr1} ..	Executes the string that results from the evaluation
+			of {expr1} as an Ex command.
+			Multiple arguments are concatenated, with a space in
+			between.  To avoid the extra space use the "."
+			operator to concatenate strings into one argument.
+			{expr1} is used as the processed command, command line
+			editing keys are not recognized.
+			Cannot be followed by a comment.
+			Examples: >
+		:execute "buffer" nextbuf
+		:execute "normal" count . "w"
+<
+			":execute" can be used to append a command to commands
+			that don't accept a '|'.  Example: >
+		:execute '!ls' | echo "theend"
+
+<			":execute" is also a nice way to avoid having to type
+			control characters in a Vim script for a ":normal"
+			command: >
+		:execute "normal ixxx\"
+<			This has an  character, see |expr-string|.
+
+			Be careful to correctly escape special characters in
+			file names.  The |fnameescape()| function can be used
+			for Vim commands, |shellescape()| for |:!| commands.
+			Examples: >
+		:execute "e " . fnameescape(filename)
+		:execute "!ls " . shellescape(expand('%:h'), 1)
+<
+			Note: The executed string may be any command-line, but
+			you cannot start or end a "while", "for" or "if"
+			command.  Thus this is illegal: >
+		:execute 'while i > 5'
+		:execute 'echo "test" | break'
+<
+			It is allowed to have a "while" or "if" command
+			completely in the executed string: >
+		:execute 'while i < 5 | echo i | let i = i + 1 | endwhile'
+<
+
+							*:exe-comment*
+			":execute", ":echo" and ":echon" cannot be followed by
+			a comment directly, because they see the '"' as the
+			start of a string.  But, you can use '|' followed by a
+			comment.  Example: >
+		:echo "foo" | "this is a comment
+
+==============================================================================
+8. Exception handling					*exception-handling*
+
+The Vim script language comprises an exception handling feature.  This section
+explains how it can be used in a Vim script.
+
+Exceptions may be raised by Vim on an error or on interrupt, see
+|catch-errors| and |catch-interrupt|.  You can also explicitly throw an
+exception by using the ":throw" command, see |throw-catch|.
+
+
+TRY CONDITIONALS					*try-conditionals*
+
+Exceptions can be caught or can cause cleanup code to be executed.  You can
+use a try conditional to specify catch clauses (that catch exceptions) and/or
+a finally clause (to be executed for cleanup).
+   A try conditional begins with a |:try| command and ends at the matching
+|:endtry| command.  In between, you can use a |:catch| command to start
+a catch clause, or a |:finally| command to start a finally clause.  There may
+be none or multiple catch clauses, but there is at most one finally clause,
+which must not be followed by any catch clauses.  The lines before the catch
+clauses and the finally clause is called a try block. >
+
+     :try
+     :	...
+     :	...				TRY BLOCK
+     :	...
+     :catch /{pattern}/
+     :	...
+     :	...				CATCH CLAUSE
+     :	...
+     :catch /{pattern}/
+     :	...
+     :	...				CATCH CLAUSE
+     :	...
+     :finally
+     :	...
+     :	...				FINALLY CLAUSE
+     :	...
+     :endtry
+
+The try conditional allows to watch code for exceptions and to take the
+appropriate actions.  Exceptions from the try block may be caught.  Exceptions
+from the try block and also the catch clauses may cause cleanup actions.
+   When no exception is thrown during execution of the try block, the control
+is transferred to the finally clause, if present.  After its execution, the
+script continues with the line following the ":endtry".
+   When an exception occurs during execution of the try block, the remaining
+lines in the try block are skipped.  The exception is matched against the
+patterns specified as arguments to the ":catch" commands.  The catch clause
+after the first matching ":catch" is taken, other catch clauses are not
+executed.  The catch clause ends when the next ":catch", ":finally", or
+":endtry" command is reached - whatever is first.  Then, the finally clause
+(if present) is executed.  When the ":endtry" is reached, the script execution
+continues in the following line as usual.
+   When an exception that does not match any of the patterns specified by the
+":catch" commands is thrown in the try block, the exception is not caught by
+that try conditional and none of the catch clauses is executed.  Only the
+finally clause, if present, is taken.  The exception pends during execution of
+the finally clause.  It is resumed at the ":endtry", so that commands after
+the ":endtry" are not executed and the exception might be caught elsewhere,
+see |try-nesting|.
+   When during execution of a catch clause another exception is thrown, the
+remaining lines in that catch clause are not executed.	The new exception is
+not matched against the patterns in any of the ":catch" commands of the same
+try conditional and none of its catch clauses is taken.  If there is, however,
+a finally clause, it is executed, and the exception pends during its
+execution.  The commands following the ":endtry" are not executed.  The new
+exception might, however, be caught elsewhere, see |try-nesting|.
+   When during execution of the finally clause (if present) an exception is
+thrown, the remaining lines in the finally clause are skipped.	If the finally
+clause has been taken because of an exception from the try block or one of the
+catch clauses, the original (pending) exception is discarded.  The commands
+following the ":endtry" are not executed, and the exception from the finally
+clause is propagated and can be caught elsewhere, see |try-nesting|.
+
+The finally clause is also executed, when a ":break" or ":continue" for
+a ":while" loop enclosing the complete try conditional is executed from the
+try block or a catch clause.  Or when a ":return" or ":finish" is executed
+from the try block or a catch clause of a try conditional in a function or
+sourced script, respectively.  The ":break", ":continue", ":return", or
+":finish" pends during execution of the finally clause and is resumed when the
+":endtry" is reached.  It is, however, discarded when an exception is thrown
+from the finally clause.
+   When a ":break" or ":continue" for a ":while" loop enclosing the complete
+try conditional or when a ":return" or ":finish" is encountered in the finally
+clause, the rest of the finally clause is skipped, and the ":break",
+":continue", ":return" or ":finish" is executed as usual.  If the finally
+clause has been taken because of an exception or an earlier ":break",
+":continue", ":return", or ":finish" from the try block or a catch clause,
+this pending exception or command is discarded.
+
+For examples see |throw-catch| and |try-finally|.
+
+
+NESTING	OF TRY CONDITIONALS				*try-nesting*
+
+Try conditionals can be nested arbitrarily.  That is, a complete try
+conditional can be put into the try block, a catch clause, or the finally
+clause of another try conditional.  If the inner try conditional does not
+catch an exception thrown in its try block or throws a new exception from one
+of its catch clauses or its finally clause, the outer try conditional is
+checked according to the rules above.  If the inner try conditional is in the
+try block of the outer try conditional, its catch clauses are checked, but
+otherwise only the finally clause is executed.	It does not matter for
+nesting, whether the inner try conditional is directly contained in the outer
+one, or whether the outer one sources a script or calls a function containing
+the inner try conditional.
+
+When none of the active try conditionals catches an exception, just their
+finally clauses are executed.  Thereafter, the script processing terminates.
+An error message is displayed in case of an uncaught exception explicitly
+thrown by a ":throw" command.  For uncaught error and interrupt exceptions
+implicitly raised by Vim, the error message(s) or interrupt message are shown
+as usual.
+
+For examples see |throw-catch|.
+
+
+EXAMINING EXCEPTION HANDLING CODE			*except-examine*
+
+Exception handling code can get tricky.  If you are in doubt what happens, set
+'verbose' to 13 or use the ":13verbose" command modifier when sourcing your
+script file.  Then you see when an exception is thrown, discarded, caught, or
+finished.  When using a verbosity level of at least 14, things pending in
+a finally clause are also shown.  This information is also given in debug mode
+(see |debug-scripts|).
+
+
+THROWING AND CATCHING EXCEPTIONS			*throw-catch*
+
+You can throw any number or string as an exception.  Use the |:throw| command
+and pass the value to be thrown as argument: >
+	:throw 4711
+	:throw "string"
+<							*throw-expression*
+You can also specify an expression argument.  The expression is then evaluated
+first, and the result is thrown: >
+	:throw 4705 + strlen("string")
+	:throw strpart("strings", 0, 6)
+
+An exception might be thrown during evaluation of the argument of the ":throw"
+command.  Unless it is caught there, the expression evaluation is abandoned.
+The ":throw" command then does not throw a new exception.
+   Example: >
+
+	:function! Foo(arg)
+	:  try
+	:    throw a:arg
+	:  catch /foo/
+	:  endtry
+	:  return 1
+	:endfunction
+	:
+	:function! Bar()
+	:  echo "in Bar"
+	:  return 4710
+	:endfunction
+	:
+	:throw Foo("arrgh") + Bar()
+
+This throws "arrgh", and "in Bar" is not displayed since Bar() is not
+executed. >
+	:throw Foo("foo") + Bar()
+however displays "in Bar" and throws 4711.
+
+Any other command that takes an expression as argument might also be
+abandoned by an (uncaught) exception during the expression evaluation.	The
+exception is then propagated to the caller of the command.
+   Example: >
+
+	:if Foo("arrgh")
+	:  echo "then"
+	:else
+	:  echo "else"
+	:endif
+
+Here neither of "then" or "else" is displayed.
+
+							*catch-order*
+Exceptions can be caught by a try conditional with one or more |:catch|
+commands, see |try-conditionals|.   The values to be caught by each ":catch"
+command can be specified as a pattern argument.  The subsequent catch clause
+gets executed when a matching exception is caught.
+   Example: >
+
+	:function! Foo(value)
+	:  try
+	:    throw a:value
+	:  catch /^\d\+$/
+	:    echo "Number thrown"
+	:  catch /.*/
+	:    echo "String thrown"
+	:  endtry
+	:endfunction
+	:
+	:call Foo(0x1267)
+	:call Foo('string')
+
+The first call to Foo() displays "Number thrown", the second "String thrown".
+An exception is matched against the ":catch" commands in the order they are
+specified.  Only the first match counts.  So you should place the more
+specific ":catch" first.  The following order does not make sense: >
+
+	:  catch /.*/
+	:    echo "String thrown"
+	:  catch /^\d\+$/
+	:    echo "Number thrown"
+
+The first ":catch" here matches always, so that the second catch clause is
+never taken.
+
+							*throw-variables*
+If you catch an exception by a general pattern, you may access the exact value
+in the variable |v:exception|: >
+
+	:  catch /^\d\+$/
+	:    echo "Number thrown.  Value is" v:exception
+
+You may also be interested where an exception was thrown.  This is stored in
+|v:throwpoint|.  Note that "v:exception" and "v:throwpoint" are valid for the
+exception most recently caught as long it is not finished.
+   Example: >
+
+	:function! Caught()
+	:  if v:exception != ""
+	:    echo 'Caught "' . v:exception . '" in ' . v:throwpoint
+	:  else
+	:    echo 'Nothing caught'
+	:  endif
+	:endfunction
+	:
+	:function! Foo()
+	:  try
+	:    try
+	:      try
+	:	 throw 4711
+	:      finally
+	:	 call Caught()
+	:      endtry
+	:    catch /.*/
+	:      call Caught()
+	:      throw "oops"
+	:    endtry
+	:  catch /.*/
+	:    call Caught()
+	:  finally
+	:    call Caught()
+	:  endtry
+	:endfunction
+	:
+	:call Foo()
+
+This displays >
+
+	Nothing caught
+	Caught "4711" in function Foo, line 4
+	Caught "oops" in function Foo, line 10
+	Nothing caught
+
+A practical example:  The following command ":LineNumber" displays the line
+number in the script or function where it has been used: >
+
+	:function! LineNumber()
+	:    return substitute(v:throwpoint, '.*\D\(\d\+\).*', '\1', "")
+	:endfunction
+	:command! LineNumber try | throw "" | catch | echo LineNumber() | endtry
+<
+							*try-nested*
+An exception that is not caught by a try conditional can be caught by
+a surrounding try conditional: >
+
+	:try
+	:  try
+	:    throw "foo"
+	:  catch /foobar/
+	:    echo "foobar"
+	:  finally
+	:    echo "inner finally"
+	:  endtry
+	:catch /foo/
+	:  echo "foo"
+	:endtry
+
+The inner try conditional does not catch the exception, just its finally
+clause is executed.  The exception is then caught by the outer try
+conditional.  The example displays "inner finally" and then "foo".
+
+							*throw-from-catch*
+You can catch an exception and throw a new one to be caught elsewhere from the
+catch clause: >
+
+	:function! Foo()
+	:  throw "foo"
+	:endfunction
+	:
+	:function! Bar()
+	:  try
+	:    call Foo()
+	:  catch /foo/
+	:    echo "Caught foo, throw bar"
+	:    throw "bar"
+	:  endtry
+	:endfunction
+	:
+	:try
+	:  call Bar()
+	:catch /.*/
+	:  echo "Caught" v:exception
+	:endtry
+
+This displays "Caught foo, throw bar" and then "Caught bar".
+
+							*rethrow*
+There is no real rethrow in the Vim script language, but you may throw
+"v:exception" instead: >
+
+	:function! Bar()
+	:  try
+	:    call Foo()
+	:  catch /.*/
+	:    echo "Rethrow" v:exception
+	:    throw v:exception
+	:  endtry
+	:endfunction
+<							*try-echoerr*
+Note that this method cannot be used to "rethrow" Vim error or interrupt
+exceptions, because it is not possible to fake Vim internal exceptions.
+Trying so causes an error exception.  You should throw your own exception
+denoting the situation.  If you want to cause a Vim error exception containing
+the original error exception value, you can use the |:echoerr| command: >
+
+	:try
+	:  try
+	:    asdf
+	:  catch /.*/
+	:    echoerr v:exception
+	:  endtry
+	:catch /.*/
+	:  echo v:exception
+	:endtry
+
+This code displays
+
+	Vim(echoerr):Vim:E492: Not an editor command:	asdf ~
+
+
+CLEANUP CODE						*try-finally*
+
+Scripts often change global settings and restore them at their end.  If the
+user however interrupts the script by pressing CTRL-C, the settings remain in
+an inconsistent state.	The same may happen to you in the development phase of
+a script when an error occurs or you explicitly throw an exception without
+catching it.  You can solve these problems by using a try conditional with
+a finally clause for restoring the settings.  Its execution is guaranteed on
+normal control flow, on error, on an explicit ":throw", and on interrupt.
+(Note that errors and interrupts from inside the try conditional are converted
+to exceptions.	When not caught, they terminate the script after the finally
+clause has been executed.)
+Example: >
+
+	:try
+	:  let s:saved_ts = &ts
+	:  set ts=17
+	:
+	:  " Do the hard work here.
+	:
+	:finally
+	:  let &ts = s:saved_ts
+	:  unlet s:saved_ts
+	:endtry
+
+This method should be used locally whenever a function or part of a script
+changes global settings which need to be restored on failure or normal exit of
+that function or script part.
+
+							*break-finally*
+Cleanup code works also when the try block or a catch clause is left by
+a ":continue", ":break", ":return", or ":finish".
+   Example: >
+
+	:let first = 1
+	:while 1
+	:  try
+	:    if first
+	:      echo "first"
+	:      let first = 0
+	:      continue
+	:    else
+	:      throw "second"
+	:    endif
+	:  catch /.*/
+	:    echo v:exception
+	:    break
+	:  finally
+	:    echo "cleanup"
+	:  endtry
+	:  echo "still in while"
+	:endwhile
+	:echo "end"
+
+This displays "first", "cleanup", "second", "cleanup", and "end". >
+
+	:function! Foo()
+	:  try
+	:    return 4711
+	:  finally
+	:    echo "cleanup\n"
+	:  endtry
+	:  echo "Foo still active"
+	:endfunction
+	:
+	:echo Foo() "returned by Foo"
+
+This displays "cleanup" and "4711 returned by Foo".  You don't need to add an
+extra ":return" in the finally clause.	(Above all, this would override the
+return value.)
+
+							*except-from-finally*
+Using either of ":continue", ":break", ":return", ":finish", or ":throw" in
+a finally clause is possible, but not recommended since it abandons the
+cleanup actions for the try conditional.  But, of course, interrupt and error
+exceptions might get raised from a finally clause.
+   Example where an error in the finally clause stops an interrupt from
+working correctly: >
+
+	:try
+	:  try
+	:    echo "Press CTRL-C for interrupt"
+	:    while 1
+	:    endwhile
+	:  finally
+	:    unlet novar
+	:  endtry
+	:catch /novar/
+	:endtry
+	:echo "Script still running"
+	:sleep 1
+
+If you need to put commands that could fail into a finally clause, you should
+think about catching or ignoring the errors in these commands, see
+|catch-errors| and |ignore-errors|.
+
+
+CATCHING ERRORS						*catch-errors*
+
+If you want to catch specific errors, you just have to put the code to be
+watched in a try block and add a catch clause for the error message.  The
+presence of the try conditional causes all errors to be converted to an
+exception.  No message is displayed and |v:errmsg| is not set then.  To find
+the right pattern for the ":catch" command, you have to know how the format of
+the error exception is.
+   Error exceptions have the following format: >
+
+	Vim({cmdname}):{errmsg}
+or >
+	Vim:{errmsg}
+
+{cmdname} is the name of the command that failed; the second form is used when
+the command name is not known.	{errmsg} is the error message usually produced
+when the error occurs outside try conditionals.  It always begins with
+a capital "E", followed by a two or three-digit error number, a colon, and
+a space.
+
+Examples:
+
+The command >
+	:unlet novar
+normally produces the error message >
+	E108: No such variable: "novar"
+which is converted inside try conditionals to an exception >
+	Vim(unlet):E108: No such variable: "novar"
+
+The command >
+	:dwim
+normally produces the error message >
+	E492: Not an editor command: dwim
+which is converted inside try conditionals to an exception >
+	Vim:E492: Not an editor command: dwim
+
+You can catch all ":unlet" errors by a >
+	:catch /^Vim(unlet):/
+or all errors for misspelled command names by a >
+	:catch /^Vim:E492:/
+
+Some error messages may be produced by different commands: >
+	:function nofunc
+and >
+	:delfunction nofunc
+both produce the error message >
+	E128: Function name must start with a capital: nofunc
+which is converted inside try conditionals to an exception >
+	Vim(function):E128: Function name must start with a capital: nofunc
+or >
+	Vim(delfunction):E128: Function name must start with a capital: nofunc
+respectively.  You can catch the error by its number independently on the
+command that caused it if you use the following pattern: >
+	:catch /^Vim(\a\+):E128:/
+
+Some commands like >
+	:let x = novar
+produce multiple error messages, here: >
+	E121: Undefined variable: novar
+	E15: Invalid expression:  novar
+Only the first is used for the exception value, since it is the most specific
+one (see |except-several-errors|).  So you can catch it by >
+	:catch /^Vim(\a\+):E121:/
+
+You can catch all errors related to the name "nofunc" by >
+	:catch /\/
+
+You can catch all Vim errors in the ":write" and ":read" commands by >
+	:catch /^Vim(\(write\|read\)):E\d\+:/
+
+You can catch all Vim errors by the pattern >
+	:catch /^Vim\((\a\+)\)\=:E\d\+:/
+<
+							*catch-text*
+NOTE: You should never catch the error message text itself: >
+	:catch /No such variable/
+only works in the english locale, but not when the user has selected
+a different language by the |:language| command.  It is however helpful to
+cite the message text in a comment: >
+	:catch /^Vim(\a\+):E108:/   " No such variable
+
+
+IGNORING ERRORS						*ignore-errors*
+
+You can ignore errors in a specific Vim command by catching them locally: >
+
+	:try
+	:  write
+	:catch
+	:endtry
+
+But you are strongly recommended NOT to use this simple form, since it could
+catch more than you want.  With the ":write" command, some autocommands could
+be executed and cause errors not related to writing, for instance: >
+
+	:au BufWritePre * unlet novar
+
+There could even be such errors you are not responsible for as a script
+writer: a user of your script might have defined such autocommands.  You would
+then hide the error from the user.
+   It is much better to use >
+
+	:try
+	:  write
+	:catch /^Vim(write):/
+	:endtry
+
+which only catches real write errors.  So catch only what you'd like to ignore
+intentionally.
+
+For a single command that does not cause execution of autocommands, you could
+even suppress the conversion of errors to exceptions by the ":silent!"
+command: >
+	:silent! nunmap k
+This works also when a try conditional is active.
+
+
+CATCHING INTERRUPTS					*catch-interrupt*
+
+When there are active try conditionals, an interrupt (CTRL-C) is converted to
+the exception "Vim:Interrupt".	You can catch it like every exception.	The
+script is not terminated, then.
+   Example: >
+
+	:function! TASK1()
+	:  sleep 10
+	:endfunction
+
+	:function! TASK2()
+	:  sleep 20
+	:endfunction
+
+	:while 1
+	:  let command = input("Type a command: ")
+	:  try
+	:    if command == ""
+	:      continue
+	:    elseif command == "END"
+	:      break
+	:    elseif command == "TASK1"
+	:      call TASK1()
+	:    elseif command == "TASK2"
+	:      call TASK2()
+	:    else
+	:      echo "\nIllegal command:" command
+	:      continue
+	:    endif
+	:  catch /^Vim:Interrupt$/
+	:    echo "\nCommand interrupted"
+	:    " Caught the interrupt.  Continue with next prompt.
+	:  endtry
+	:endwhile
+
+You can interrupt a task here by pressing CTRL-C; the script then asks for
+a new command.	If you press CTRL-C at the prompt, the script is terminated.
+
+For testing what happens when CTRL-C would be pressed on a specific line in
+your script, use the debug mode and execute the |>quit| or |>interrupt|
+command on that line.  See |debug-scripts|.
+
+
+CATCHING ALL						*catch-all*
+
+The commands >
+
+	:catch /.*/
+	:catch //
+	:catch
+
+catch everything, error exceptions, interrupt exceptions and exceptions
+explicitly thrown by the |:throw| command.  This is useful at the top level of
+a script in order to catch unexpected things.
+   Example: >
+
+	:try
+	:
+	:  " do the hard work here
+	:
+	:catch /MyException/
+	:
+	:  " handle known problem
+	:
+	:catch /^Vim:Interrupt$/
+	:    echo "Script interrupted"
+	:catch /.*/
+	:  echo "Internal error (" . v:exception . ")"
+	:  echo " - occurred at " . v:throwpoint
+	:endtry
+	:" end of script
+
+Note: Catching all might catch more things than you want.  Thus, you are
+strongly encouraged to catch only for problems that you can really handle by
+specifying a pattern argument to the ":catch".
+   Example: Catching all could make it nearly impossible to interrupt a script
+by pressing CTRL-C: >
+
+	:while 1
+	:  try
+	:    sleep 1
+	:  catch
+	:  endtry
+	:endwhile
+
+
+EXCEPTIONS AND AUTOCOMMANDS				*except-autocmd*
+
+Exceptions may be used during execution of autocommands.  Example: >
+
+	:autocmd User x try
+	:autocmd User x   throw "Oops!"
+	:autocmd User x catch
+	:autocmd User x   echo v:exception
+	:autocmd User x endtry
+	:autocmd User x throw "Arrgh!"
+	:autocmd User x echo "Should not be displayed"
+	:
+	:try
+	:  doautocmd User x
+	:catch
+	:  echo v:exception
+	:endtry
+
+This displays "Oops!" and "Arrgh!".
+
+							*except-autocmd-Pre*
+For some commands, autocommands get executed before the main action of the
+command takes place.  If an exception is thrown and not caught in the sequence
+of autocommands, the sequence and the command that caused its execution are
+abandoned and the exception is propagated to the caller of the command.
+   Example: >
+
+	:autocmd BufWritePre * throw "FAIL"
+	:autocmd BufWritePre * echo "Should not be displayed"
+	:
+	:try
+	:  write
+	:catch
+	:  echo "Caught:" v:exception "from" v:throwpoint
+	:endtry
+
+Here, the ":write" command does not write the file currently being edited (as
+you can see by checking 'modified'), since the exception from the BufWritePre
+autocommand abandons the ":write".  The exception is then caught and the
+script displays: >
+
+	Caught: FAIL from BufWrite Auto commands for "*"
+<
+							*except-autocmd-Post*
+For some commands, autocommands get executed after the main action of the
+command has taken place.  If this main action fails and the command is inside
+an active try conditional, the autocommands are skipped and an error exception
+is thrown that can be caught by the caller of the command.
+   Example: >
+
+	:autocmd BufWritePost * echo "File successfully written!"
+	:
+	:try
+	:  write /i/m/p/o/s/s/i/b/l/e
+	:catch
+	:  echo v:exception
+	:endtry
+
+This just displays: >
+
+	Vim(write):E212: Can't open file for writing (/i/m/p/o/s/s/i/b/l/e)
+
+If you really need to execute the autocommands even when the main action
+fails, trigger the event from the catch clause.
+   Example: >
+
+	:autocmd BufWritePre  * set noreadonly
+	:autocmd BufWritePost * set readonly
+	:
+	:try
+	:  write /i/m/p/o/s/s/i/b/l/e
+	:catch
+	:  doautocmd BufWritePost /i/m/p/o/s/s/i/b/l/e
+	:endtry
+<
+You can also use ":silent!": >
+
+	:let x = "ok"
+	:let v:errmsg = ""
+	:autocmd BufWritePost * if v:errmsg != ""
+	:autocmd BufWritePost *   let x = "after fail"
+	:autocmd BufWritePost * endif
+	:try
+	:  silent! write /i/m/p/o/s/s/i/b/l/e
+	:catch
+	:endtry
+	:echo x
+
+This displays "after fail".
+
+If the main action of the command does not fail, exceptions from the
+autocommands will be catchable by the caller of the command:  >
+
+	:autocmd BufWritePost * throw ":-("
+	:autocmd BufWritePost * echo "Should not be displayed"
+	:
+	:try
+	:  write
+	:catch
+	:  echo v:exception
+	:endtry
+<
+							*except-autocmd-Cmd*
+For some commands, the normal action can be replaced by a sequence of
+autocommands.  Exceptions from that sequence will be catchable by the caller
+of the command.
+   Example:  For the ":write" command, the caller cannot know whether the file
+had actually been written when the exception occurred.	You need to tell it in
+some way. >
+
+	:if !exists("cnt")
+	:  let cnt = 0
+	:
+	:  autocmd BufWriteCmd * if &modified
+	:  autocmd BufWriteCmd *   let cnt = cnt + 1
+	:  autocmd BufWriteCmd *   if cnt % 3 == 2
+	:  autocmd BufWriteCmd *     throw "BufWriteCmdError"
+	:  autocmd BufWriteCmd *   endif
+	:  autocmd BufWriteCmd *   write | set nomodified
+	:  autocmd BufWriteCmd *   if cnt % 3 == 0
+	:  autocmd BufWriteCmd *     throw "BufWriteCmdError"
+	:  autocmd BufWriteCmd *   endif
+	:  autocmd BufWriteCmd *   echo "File successfully written!"
+	:  autocmd BufWriteCmd * endif
+	:endif
+	:
+	:try
+	:	write
+	:catch /^BufWriteCmdError$/
+	:  if &modified
+	:    echo "Error on writing (file contents not changed)"
+	:  else
+	:    echo "Error after writing"
+	:  endif
+	:catch /^Vim(write):/
+	:    echo "Error on writing"
+	:endtry
+
+When this script is sourced several times after making changes, it displays
+first >
+	File successfully written!
+then >
+	Error on writing (file contents not changed)
+then >
+	Error after writing
+etc.
+
+							*except-autocmd-ill*
+You cannot spread a try conditional over autocommands for different events.
+The following code is ill-formed: >
+
+	:autocmd BufWritePre  * try
+	:
+	:autocmd BufWritePost * catch
+	:autocmd BufWritePost *   echo v:exception
+	:autocmd BufWritePost * endtry
+	:
+	:write
+
+
+EXCEPTION HIERARCHIES AND PARAMETERIZED EXCEPTIONS	*except-hier-param*
+
+Some programming languages allow to use hierarchies of exception classes or to
+pass additional information with the object of an exception class.  You can do
+similar things in Vim.
+   In order to throw an exception from a hierarchy, just throw the complete
+class name with the components separated by a colon, for instance throw the
+string "EXCEPT:MATHERR:OVERFLOW" for an overflow in a mathematical library.
+   When you want to pass additional information with your exception class, add
+it in parentheses, for instance throw the string "EXCEPT:IO:WRITEERR(myfile)"
+for an error when writing "myfile".
+   With the appropriate patterns in the ":catch" command, you can catch for
+base classes or derived classes of your hierarchy.  Additional information in
+parentheses can be cut out from |v:exception| with the ":substitute" command.
+   Example: >
+
+	:function! CheckRange(a, func)
+	:  if a:a < 0
+	:    throw "EXCEPT:MATHERR:RANGE(" . a:func . ")"
+	:  endif
+	:endfunction
+	:
+	:function! Add(a, b)
+	:  call CheckRange(a:a, "Add")
+	:  call CheckRange(a:b, "Add")
+	:  let c = a:a + a:b
+	:  if c < 0
+	:    throw "EXCEPT:MATHERR:OVERFLOW"
+	:  endif
+	:  return c
+	:endfunction
+	:
+	:function! Div(a, b)
+	:  call CheckRange(a:a, "Div")
+	:  call CheckRange(a:b, "Div")
+	:  if (a:b == 0)
+	:    throw "EXCEPT:MATHERR:ZERODIV"
+	:  endif
+	:  return a:a / a:b
+	:endfunction
+	:
+	:function! Write(file)
+	:  try
+	:    execute "write" fnameescape(a:file)
+	:  catch /^Vim(write):/
+	:    throw "EXCEPT:IO(" . getcwd() . ", " . a:file . "):WRITEERR"
+	:  endtry
+	:endfunction
+	:
+	:try
+	:
+	:  " something with arithmetics and I/O
+	:
+	:catch /^EXCEPT:MATHERR:RANGE/
+	:  let function = substitute(v:exception, '.*(\(\a\+\)).*', '\1', "")
+	:  echo "Range error in" function
+	:
+	:catch /^EXCEPT:MATHERR/	" catches OVERFLOW and ZERODIV
+	:  echo "Math error"
+	:
+	:catch /^EXCEPT:IO/
+	:  let dir = substitute(v:exception, '.*(\(.\+\),\s*.\+).*', '\1', "")
+	:  let file = substitute(v:exception, '.*(.\+,\s*\(.\+\)).*', '\1', "")
+	:  if file !~ '^/'
+	:    let file = dir . "/" . file
+	:  endif
+	:  echo 'I/O error for "' . file . '"'
+	:
+	:catch /^EXCEPT/
+	:  echo "Unspecified error"
+	:
+	:endtry
+
+The exceptions raised by Vim itself (on error or when pressing CTRL-C) use
+a flat hierarchy:  they are all in the "Vim" class.  You cannot throw yourself
+exceptions with the "Vim" prefix; they are reserved for Vim.
+   Vim error exceptions are parameterized with the name of the command that
+failed, if known.  See |catch-errors|.
+
+
+PECULIARITIES
+							*except-compat*
+The exception handling concept requires that the command sequence causing the
+exception is aborted immediately and control is transferred to finally clauses
+and/or a catch clause.
+
+In the Vim script language there are cases where scripts and functions
+continue after an error: in functions without the "abort" flag or in a command
+after ":silent!", control flow goes to the following line, and outside
+functions, control flow goes to the line following the outermost ":endwhile"
+or ":endif".  On the other hand, errors should be catchable as exceptions
+(thus, requiring the immediate abortion).
+
+This problem has been solved by converting errors to exceptions and using
+immediate abortion (if not suppressed by ":silent!") only when a try
+conditional is active.	This is no restriction since an (error) exception can
+be caught only from an active try conditional.	If you want an immediate
+termination without catching the error, just use a try conditional without
+catch clause.  (You can cause cleanup code being executed before termination
+by specifying a finally clause.)
+
+When no try conditional is active, the usual abortion and continuation
+behavior is used instead of immediate abortion.  This ensures compatibility of
+scripts written for Vim 6.1 and earlier.
+
+However, when sourcing an existing script that does not use exception handling
+commands (or when calling one of its functions) from inside an active try
+conditional of a new script, you might change the control flow of the existing
+script on error.  You get the immediate abortion on error and can catch the
+error in the new script.  If however the sourced script suppresses error
+messages by using the ":silent!" command (checking for errors by testing
+|v:errmsg| if appropriate), its execution path is not changed.	The error is
+not converted to an exception.	(See |:silent|.)  So the only remaining cause
+where this happens is for scripts that don't care about errors and produce
+error messages.  You probably won't want to use such code from your new
+scripts.
+
+							*except-syntax-err*
+Syntax errors in the exception handling commands are never caught by any of
+the ":catch" commands of the try conditional they belong to.  Its finally
+clauses, however, is executed.
+   Example: >
+
+	:try
+	:  try
+	:    throw 4711
+	:  catch /\(/
+	:    echo "in catch with syntax error"
+	:  catch
+	:    echo "inner catch-all"
+	:  finally
+	:    echo "inner finally"
+	:  endtry
+	:catch
+	:  echo 'outer catch-all caught "' . v:exception . '"'
+	:  finally
+	:    echo "outer finally"
+	:endtry
+
+This displays: >
+    inner finally
+    outer catch-all caught "Vim(catch):E54: Unmatched \("
+    outer finally
+The original exception is discarded and an error exception is raised, instead.
+
+							*except-single-line*
+The ":try", ":catch", ":finally", and ":endtry" commands can be put on
+a single line, but then syntax errors may make it difficult to recognize the
+"catch" line, thus you better avoid this.
+   Example: >
+	:try | unlet! foo # | catch | endtry
+raises an error exception for the trailing characters after the ":unlet!"
+argument, but does not see the ":catch" and ":endtry" commands, so that the
+error exception is discarded and the "E488: Trailing characters" message gets
+displayed.
+
+							*except-several-errors*
+When several errors appear in a single command, the first error message is
+usually the most specific one and therefor converted to the error exception.
+   Example: >
+	echo novar
+causes >
+	E121: Undefined variable: novar
+	E15: Invalid expression: novar
+The value of the error exception inside try conditionals is: >
+	Vim(echo):E121: Undefined variable: novar
+<							*except-syntax-error*
+But when a syntax error is detected after a normal error in the same command,
+the syntax error is used for the exception being thrown.
+   Example: >
+	unlet novar #
+causes >
+	E108: No such variable: "novar"
+	E488: Trailing characters
+The value of the error exception inside try conditionals is: >
+	Vim(unlet):E488: Trailing characters
+This is done because the syntax error might change the execution path in a way
+not intended by the user.  Example: >
+	try
+	    try | unlet novar # | catch | echo v:exception | endtry
+	catch /.*/
+	    echo "outer catch:" v:exception
+	endtry
+This displays "outer catch: Vim(unlet):E488: Trailing characters", and then
+a "E600: Missing :endtry" error message is given, see |except-single-line|.
+
+==============================================================================
+9. Examples						*eval-examples*
+
+Printing in Binary ~
+>
+  :" The function Nr2Bin() returns the binary string representation of a number.
+  :func Nr2Bin(nr)
+  :  let n = a:nr
+  :  let r = ""
+  :  while n
+  :    let r = '01'[n % 2] . r
+  :    let n = n / 2
+  :  endwhile
+  :  return r
+  :endfunc
+
+  :" The function String2Bin() converts each character in a string to a
+  :" binary string, separated with dashes.
+  :func String2Bin(str)
+  :  let out = ''
+  :  for ix in range(strlen(a:str))
+  :    let out = out . '-' . Nr2Bin(char2nr(a:str[ix]))
+  :  endfor
+  :  return out[1:]
+  :endfunc
+
+Example of its use: >
+  :echo Nr2Bin(32)
+result: "100000" >
+  :echo String2Bin("32")
+result: "110011-110010"
+
+
+Sorting lines ~
+
+This example sorts lines with a specific compare function. >
+
+  :func SortBuffer()
+  :  let lines = getline(1, '$')
+  :  call sort(lines, function("Strcmp"))
+  :  call setline(1, lines)
+  :endfunction
+
+As a one-liner: >
+  :call setline(1, sort(getline(1, '$'), function("Strcmp")))
+
+
+scanf() replacement ~
+							*sscanf*
+There is no sscanf() function in Vim.  If you need to extract parts from a
+line, you can use matchstr() and substitute() to do it.  This example shows
+how to get the file name, line number and column number out of a line like
+"foobar.txt, 123, 45". >
+   :" Set up the match bit
+   :let mx='\(\f\+\),\s*\(\d\+\),\s*\(\d\+\)'
+   :"get the part matching the whole expression
+   :let l = matchstr(line, mx)
+   :"get each item out of the match
+   :let file = substitute(l, mx, '\1', '')
+   :let lnum = substitute(l, mx, '\2', '')
+   :let col = substitute(l, mx, '\3', '')
+
+The input is in the variable "line", the results in the variables "file",
+"lnum" and "col". (idea from Michael Geddes)
+
+
+getting the scriptnames in a Dictionary ~
+						*scriptnames-dictionary*
+The |:scriptnames| command can be used to get a list of all script files that
+have been sourced.  There is no equivalent function or variable for this
+(because it's rarely needed).  In case you need to manipulate the list this
+code can be used: >
+    " Get the output of ":scriptnames" in the scriptnames_output variable.
+    let scriptnames_output = ''
+    redir => scriptnames_output
+    silent scriptnames
+    redir END
+    
+    " Split the output into lines and parse each line.	Add an entry to the
+    " "scripts" dictionary.
+    let scripts = {}
+    for line in split(scriptnames_output, "\n")
+      " Only do non-blank lines.
+      if line =~ '\S'
+	" Get the first number in the line.
+	let nr = matchstr(line, '\d\+')
+	" Get the file name, remove the script number " 123: ".
+	let name = substitute(line, '.\+:\s*', '', '')
+	" Add an item to the Dictionary
+	let scripts[nr] = name
+      endif
+    endfor
+    unlet scriptnames_output
+
+==============================================================================
+10. No +eval feature				*no-eval-feature*
+
+When the |+eval| feature was disabled at compile time, none of the expression
+evaluation commands are available.  To prevent this from causing Vim scripts
+to generate all kinds of errors, the ":if" and ":endif" commands are still
+recognized, though the argument of the ":if" and everything between the ":if"
+and the matching ":endif" is ignored.  Nesting of ":if" blocks is allowed, but
+only if the commands are at the start of the line.  The ":else" command is not
+recognized.
+
+Example of how to avoid executing commands when the |+eval| feature is
+missing: >
+
+	:if 1
+	:  echo "Expression evaluation is compiled in"
+	:else
+	:  echo "You will _never_ see this message"
+	:endif
+
+==============================================================================
+11. The sandbox					*eval-sandbox* *sandbox* *E48*
+
+The 'foldexpr', 'formatexpr', 'includeexpr', 'indentexpr', 'statusline' and
+'foldtext' options may be evaluated in a sandbox.  This means that you are
+protected from these expressions having nasty side effects.  This gives some
+safety for when these options are set from a modeline.  It is also used when
+the command from a tags file is executed and for CTRL-R = in the command line.
+The sandbox is also used for the |:sandbox| command.
+
+These items are not allowed in the sandbox:
+	- changing the buffer text
+	- defining or changing mapping, autocommands, functions, user commands
+	- setting certain options (see |option-summary|)
+	- setting certain v: variables (see |v:var|)  *E794*
+	- executing a shell command
+	- reading or writing a file
+	- jumping to another buffer or editing a file
+	- executing Python, Perl, etc. commands
+This is not guaranteed 100% secure, but it should block most attacks.
+
+							*:san* *:sandbox*
+:san[dbox] {cmd}	Execute {cmd} in the sandbox.  Useful to evaluate an
+			option that may have been set from a modeline, e.g.
+			'foldexpr'.
+
+							*sandbox-option*
+A few options contain an expression.  When this expression is evaluated it may
+have to be done in the sandbox to avoid a security risk.  But the sandbox is
+restrictive, thus this only happens when the option was set from an insecure
+location.  Insecure in this context are:
+- sourcing a .vimrc or .exrc in the current directory
+- while executing in the sandbox
+- value coming from a modeline
+
+Note that when in the sandbox and saving an option value and restoring it, the
+option will still be marked as it was set in the sandbox.
+
+==============================================================================
+12. Textlock							*textlock*
+
+In a few situations it is not allowed to change the text in the buffer, jump
+to another window and some other things that might confuse or break what Vim
+is currently doing.  This mostly applies to things that happen when Vim is
+actually doing something else.	For example, evaluating the 'balloonexpr' may
+happen any moment the mouse cursor is resting at some position.
+
+This is not allowed when the textlock is active:
+	- changing the buffer text
+	- jumping to another buffer or window
+	- editing another file
+	- closing a window or quitting Vim
+	- etc.
+
+
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim72/doc/evim-fr.1 b/share/vim/vim73/doc/evim-fr.1
similarity index 100%
rename from share/vim/vim72/doc/evim-fr.1
rename to share/vim/vim73/doc/evim-fr.1
diff --git a/share/vim/vim72/doc/evim-fr.UTF-8.1 b/share/vim/vim73/doc/evim-fr.UTF-8.1
similarity index 100%
rename from share/vim/vim72/doc/evim-fr.UTF-8.1
rename to share/vim/vim73/doc/evim-fr.UTF-8.1
diff --git a/share/vim/vim73/doc/evim-it.1 b/share/vim/vim73/doc/evim-it.1
new file mode 100644
index 0000000000..1e98a2d3f7
--- /dev/null
+++ b/share/vim/vim73/doc/evim-it.1
@@ -0,0 +1,54 @@
+.TH EVIM 1 "16 febbraio 2002 "
+.SH NOME
+evim \- Vim "facile", Vim impostato in modo da poter essere usato
+facilmente per modificare file, anche da chi non abbia familiarità
+con i comandi.
+.SH SINTASSI
+.br
+.B evim
+[opzioni] [file ..]
+.br
+.B eview
+.SH DESCRIZIONE
+.B evim
+Inizia
+.B Vim
+e imposta le opzioni per farlo comportare come un editore "modeless".
+State sempre usando Vim, ma come un editore "posizionati-e-clicca".
+Simile all'uso di Notepad in MS-Windows.
+.B evim
+richiede la presenza della GUI, per avere a disposizione menù e barra
+strumenti.
+.PP
+Da usarsi soltanto se non si è in grado di lavorare con Vim nella
+maniera usuale.
+La modifica file sarà molto meno efficiente.
+.PP
+.B eview
+come sopra, ma parte in modalità "Sola Lettura".  Funziona come evim \-R.
+.PP
+Vedere vim(1) per dettagli riguardo a Vim, opzioni, etc.
+.PP
+L'opzione 'insertmode' è impostata per poter immettere del testo direttamente.
+.br
+Sono definite delle mappature che consentono di usare COPIA e INCOLLA con i
+familiari tasti usati sotto MS-Windows.
+CTRL-X taglia testo, CTRL-C copia testo e CTRL-V incolla testo.
+Usate CTRL-Q per ottenere quello che si otterrebbe con CTRL-V in Vim nativo.
+.SH OPZIONI
+Vedere vim(1).
+.SH FILE
+.TP 15
+/usr/local/lib/vim/evim.vim
+Lo script caricato per inizializzare eVim.
+.SH NAC [NOTO ANCHE COME]
+Noto Anche Come "Vim per semplici".
+Quando usate evim si suppone che prendiate un fazzoletto,
+facciate un nodo ad ogni angolo e ve lo mettiate in testa.
+.SH VEDERE ANCHE
+vim(1)
+.SH AUTORE
+Buona parte di
+.B Vim
+è stato scritto da Bram Moolenaar, con molto aiuto da altri.
+Vedere il menù "Aiuto/Crediti".
diff --git a/share/vim/vim73/doc/evim-it.UTF-8.1 b/share/vim/vim73/doc/evim-it.UTF-8.1
new file mode 100644
index 0000000000..f96d0cb42c
--- /dev/null
+++ b/share/vim/vim73/doc/evim-it.UTF-8.1
@@ -0,0 +1,54 @@
+.TH EVIM 1 "16 febbraio 2002 "
+.SH NOME
+evim \- Vim "facile", Vim impostato in modo da poter essere usato
+facilmente per modificare file, anche da chi non abbia familiarità
+con i comandi.
+.SH SINTASSI
+.br
+.B evim
+[opzioni] [file ..]
+.br
+.B eview
+.SH DESCRIZIONE
+.B evim
+Inizia
+.B Vim
+e imposta le opzioni per farlo comportare come un editore "modeless".
+State sempre usando Vim, ma come un editore "posizionati-e-clicca".
+Simile all'uso di Notepad in MS-Windows.
+.B evim
+richiede la presenza della GUI, per avere a disposizione menù e barra
+strumenti.
+.PP
+Da usarsi soltanto se non si è in grado di lavorare con Vim nella
+maniera usuale.
+La modifica file sarà molto meno efficiente.
+.PP
+.B eview
+come sopra, ma parte in modalità "Sola Lettura".  Funziona come evim \-R.
+.PP
+Vedere vim(1) per dettagli riguardo a Vim, opzioni, etc.
+.PP
+L'opzione 'insertmode' è impostata per poter immettere del testo direttamente.
+.br
+Sono definite delle mappature che consentono di usare COPIA e INCOLLA con i
+familiari tasti usati sotto MS-Windows.
+CTRL-X taglia testo, CTRL-C copia testo e CTRL-V incolla testo.
+Usate CTRL-Q per ottenere quello che si otterrebbe con CTRL-V in Vim nativo.
+.SH OPZIONI
+Vedere vim(1).
+.SH FILE
+.TP 15
+/usr/local/lib/vim/evim.vim
+Lo script caricato per inizializzare eVim.
+.SH NAC [NOTO ANCHE COME]
+Noto Anche Come "Vim per semplici".
+Quando usate evim si suppone che prendiate un fazzoletto,
+facciate un nodo ad ogni angolo e ve lo mettiate in testa.
+.SH VEDERE ANCHE
+vim(1)
+.SH AUTORE
+Buona parte di
+.B Vim
+è stato scritto da Bram Moolenaar, con molto aiuto da altri.
+Vedere il menù "Aiuto/Crediti".
diff --git a/share/vim/vim73/doc/evim-pl.1 b/share/vim/vim73/doc/evim-pl.1
new file mode 100644
index 0000000000..490ee3a7ce
--- /dev/null
+++ b/share/vim/vim73/doc/evim-pl.1
@@ -0,0 +1,53 @@
+.TH EVIM 1 "2002 Lut 16"
+.SH NAZWA
+evim \- ³atwy Vim, edytuj plik w Vimie z ustawieniami dla edycji bez
+trybów
+.SH SYNOPSIS
+.br
+.B evim
+[opcje] [plik ...]
+.br
+.B eview
+.SH OPIS
+.B eVim
+uruchamia
+.B Vima
+i ustawia opcje tak by zachowywa³ siê jak edytor bez trybów.
+To jest ca³y czas Vim ale u¿ywany jako edytor wska¿-i-kliknij.
+Zachowanie w stylu Notepada dla MS-Windows.
+.B eVim
+bêdzie zawsze uruchomiony w GUI by w³±czyæ menu i pasek narzêdzi.
+.PP
+Przeznaczony tylko dla ludzi, którzy naprawdê nie mog± pracowaæ
+z Vimem w normalny sposób. Edycja bêdzie o wiele mniej efektywna.
+.PP
+.B eview
+dzia³a tak samo, ale zaczyna w trybie tylko do odczytu. Dzia³a tak
+samo jak evim \-R.
+.PP
+Zobacz vim(1) by poznaæ wiêcej szczegó³ów o Vimie, opcjach, itd.
+.PP
+Opcja 'insertmode' jest ustawiona by mo¿na by³o od razu wpisywaæ
+tekst.
+.br
+Mapowania s± ustawione tak by Kopiowanie i Wklejanie dzia³a³o
+z klawiszami MS-Windows. CTRL-X wycina, CTRL-C kopiuje a CTRL-V 
+wkleja tekst. U¿yj CTRL-Q by uzyskaæ oryginalne przeznaczenie
+CTRL-V.
+.SH OPCJE
+Zobacz vim(1).
+.SH PLIKI
+.TP 15
+/usr/local/lib/vim/evim.vim
+Skrypt uruchamiania dla eVima.
+.SH ZNANY JAKO
+Znany jako "Vim dla frajerów".
+Je¶li u¿ywasz eVima oczekuje siê, ¿e wyjmiesz chusteczkê do nosa,
+zrobisz wêzê³ w ka¿dym rogu i bêdziesz to nosi³ na g³owie.
+.SH ZOBACZ TAK¯E
+vim(1)
+.SH AUTOR
+Wiêkszo¶æ 
+.B Vima
+zosta³a napisana przez Brama Moolenaara z du¿± pomoc± innych osób.
+Zobacz menu Help/Credits.
diff --git a/share/vim/vim73/doc/evim-pl.UTF-8.1 b/share/vim/vim73/doc/evim-pl.UTF-8.1
new file mode 100644
index 0000000000..096a12add2
--- /dev/null
+++ b/share/vim/vim73/doc/evim-pl.UTF-8.1
@@ -0,0 +1,53 @@
+.TH EVIM 1 "2002 Lut 16"
+.SH NAZWA
+evim \- łatwy Vim, edytuj plik w Vimie z ustawieniami dla edycji bez
+trybów
+.SH SYNOPSIS
+.br
+.B evim
+[opcje] [plik ...]
+.br
+.B eview
+.SH OPIS
+.B eVim
+uruchamia
+.B Vima
+i ustawia opcje tak by zachowywał się jak edytor bez trybów.
+To jest cały czas Vim ale używany jako edytor wskaż-i-kliknij.
+Zachowanie w stylu Notepada dla MS-Windows.
+.B eVim
+będzie zawsze uruchomiony w GUI by włączyć menu i pasek narzędzi.
+.PP
+Przeznaczony tylko dla ludzi, którzy naprawdę nie mogą pracować
+z Vimem w normalny sposób. Edycja będzie o wiele mniej efektywna.
+.PP
+.B eview
+działa tak samo, ale zaczyna w trybie tylko do odczytu. Działa tak
+samo jak evim \-R.
+.PP
+Zobacz vim(1) by poznać więcej szczegółów o Vimie, opcjach, itd.
+.PP
+Opcja 'insertmode' jest ustawiona by można było od razu wpisywać
+tekst.
+.br
+Mapowania są ustawione tak by Kopiowanie i Wklejanie działało
+z klawiszami MS-Windows. CTRL-X wycina, CTRL-C kopiuje a CTRL-V 
+wkleja tekst. Użyj CTRL-Q by uzyskać oryginalne przeznaczenie
+CTRL-V.
+.SH OPCJE
+Zobacz vim(1).
+.SH PLIKI
+.TP 15
+/usr/local/lib/vim/evim.vim
+Skrypt uruchamiania dla eVima.
+.SH ZNANY JAKO
+Znany jako "Vim dla frajerów".
+Jeśli używasz eVima oczekuje się, że wyjmiesz chusteczkę do nosa,
+zrobisz węzęł w każdym rogu i będziesz to nosił na głowie.
+.SH ZOBACZ TAKŻE
+vim(1)
+.SH AUTOR
+Większość 
+.B Vima
+została napisana przez Brama Moolenaara z dużą pomocą innych osób.
+Zobacz menu Help/Credits.
diff --git a/share/vim/vim72/doc/evim-ru.1 b/share/vim/vim73/doc/evim-ru.1
similarity index 100%
rename from share/vim/vim72/doc/evim-ru.1
rename to share/vim/vim73/doc/evim-ru.1
diff --git a/share/vim/vim72/doc/evim-ru.UTF-8.1 b/share/vim/vim73/doc/evim-ru.UTF-8.1
similarity index 100%
rename from share/vim/vim72/doc/evim-ru.UTF-8.1
rename to share/vim/vim73/doc/evim-ru.UTF-8.1
diff --git a/share/vim/vim72/doc/evim.1 b/share/vim/vim73/doc/evim.1
similarity index 100%
rename from share/vim/vim72/doc/evim.1
rename to share/vim/vim73/doc/evim.1
diff --git a/share/vim/vim73/doc/farsi.txt b/share/vim/vim73/doc/farsi.txt
new file mode 100644
index 0000000000..a24a2dc246
--- /dev/null
+++ b/share/vim/vim73/doc/farsi.txt
@@ -0,0 +1,269 @@
+*farsi.txt*     For Vim version 7.3.  Last change: 2010 Aug 07
+
+
+		  VIM REFERENCE MANUAL    by Mortaza Ghassab Shiran
+
+
+Right to Left and Farsi Mapping for Vim		*farsi* *Farsi*
+
+{Vi does not have any of these commands}
+
+						*E27*
+In order to use right-to-left and Farsi mapping support, it is necessary to
+compile Vim with the |+farsi| feature.
+
+These functions have been made by Mortaza G. Shiran 
+
+
+Introduction
+------------
+In right-to-left oriented files the characters appear on the screen from right
+to left.  This kind of file is most useful when writing Farsi documents,
+composing faxes or writing Farsi memos.
+
+The commands, prompts and help files are not in Farsi, therefore the user
+interface remains the standard Vi interface.
+
+
+Highlights
+----------
+o  Editing left-to-right files as in the original Vim, no change.
+
+o  Viewing and editing files in right-to-left windows.   File orientation is
+   per window, so it is possible to view the same file in right-to-left and
+   left-to-right modes, simultaneously.
+
+o  Compatibility to the original Vim.   Almost all features work in
+   right-to-left mode (see bugs below).
+
+o  Changing keyboard mapping and reverse insert modes using a single
+   command.
+
+o  Backing from reverse insert mode to the correct place in the file
+   (if possible).
+
+o  While in Farsi mode, numbers are entered from left to right.  Upon entering
+   a none number character, that character will be inserted just into the
+   left of the last number.
+
+o  No special terminal with right-to-left capabilities is required.  The
+   right-to-left changes are completely hardware independent.  Only
+   Farsi font is necessary.
+
+o  Farsi keymapping on the command line in reverse insert mode.
+
+o  Toggling between left-to-right and right-to-left via F8 function key.
+
+o  Toggling between Farsi ISIR-3342 standard encoding and Vim Farsi via F9
+   function key.  Since this makes sense only for the text written in
+   right-to-left mode, this function is also supported only in right-to-left
+   mode.
+
+Farsi Fonts					*farsi fonts*
+-----------
+
+The following files are found in the subdirectories of the '$VIM/farsi/fonts'
+directory:
+
+   +  far-a01.pcf    X Windows fonts for Unix including Linux systems
+   +  far-a01.bf     X Windows fonts for SunOS
+   +  far-a01.f16    a screen fonts for Unix including Linux systems
+   +  far-a01.fon    a monospaced fonts for Windows NT/95/98
+   +  far-a01.com    a screen fonts for DOS
+
+
+Font Installation
+-----------------
+
+o  Installation of fonts for MS Window systems (NT/95/98)
+
+   From 'Control Panel' folder, start the 'Fonts' program.  Then from 'file'
+   menu item select 'Install New Fonts ...'.  Browse and select the
+   'far-a01.fon', then follow the installation guide.
+   NOTE: several people have reported that this does not work.  The solution
+   is unknown.
+
+o  Installation of fonts for X Window systems (Unix/Linux)
+
+   Depending on your system, copy far-a01.pcf.Z or far-a01.pcf.gz into a
+   directory of your choice.  Change to the directory containing the Farsi
+   fonts and execute the following commands:
+
+   >  mkfontdir
+   >  xset +fp path_name_of_farsi_fonts_directory
+
+o  Installation of fonts for X Window systems (SunOS)
+
+   Copy far-a01.bf font into a directory of your choice.
+   Change to the directory containing the far-a01.fb fonts and
+   execute the following commands:
+
+   >  fldfamily
+   >  xset +fp path_name_of_fonts_directory
+
+o  Installation of ASCII screen fonts (Unix/Linux)
+
+   For Linux system, copy the far-a01.f16 fonts into /usr/lib/kbd/consolefonts
+   directory and execute the setfont program as "setfont far-a01.f16".  For
+   other systems (e.g. SCO Unix), please refer to the fonts installation
+   section of your system administration manuals.
+
+o  Installation of ASCII screen fonts (DOS)
+
+   After system power on, prior to the first use of Vim, upload the Farsi
+   fonts by executing the far-a01.com font uploading program.
+
+
+Usage
+-----
+Prior to starting Vim, the environment in which Vim can run in Farsi mode,
+must be set.  In addition to installation of Farsi fonts, following points
+refer to some of the system environments, which you may need to set:
+Key code mapping, loading graphic card in ASCII screen mode, setting the IO
+driver in 8 bit clean mode ... .
+
+o  Setting the Farsi fonts
+
+   +  For Vim GUI set the 'guifont' to far-a01.  This is done by entering
+      ':set guifont=far-a01' in the Vim window.
+
+      You can have 'guifont' set to far-a01 by Vim during the Vim startup
+      by appending the ':set guifont=far-a01' into your .vimrc file
+      (in case of NT/95/98 platforms _vimrc).
+
+      Under the X Window environment, you can also start Vim with the
+      '-fn far-a01' option.
+
+   +  For Vim within a xterm, start a xterm with the Farsi fonts (e.g.
+      kterm -fn far-a01).  Then start Vim inside the kterm.
+
+   +  For Vim under DOS, prior to the first usage of Vim, upload the Farsi
+      fonts by executing the far-a01.com fonts uploading program.
+
+o  Farsi Keymapping Activation
+
+   To activate the Farsi keymapping, set either 'altkeymap' or 'fkmap'.
+   This is done by entering ':set akm' or ':set fk' in the Vim window.
+   You can have 'altkeymap' or 'fkmap' set as default by appending ':set akm'
+   or ':set fk' in your .vimrc file or _vimrc in case of NT/95/98 platforms.
+
+   To turn off the Farsi keymapping as a default second language keymapping,
+   reset the 'altkeymap' by entering ':set noakm'.
+
+o  right-to-left Farsi Mode
+
+   By default Vim starts in Left-to-right mode.  Following are ways to change
+   the window orientation:
+
+   + Start Vim with the -F option (e.g. vim -F ...).
+
+   + Use the F8 function key to toggle between left-to-right and right-to-left.
+
+   + While in Left-to-right mode, enter 'set rl' in the command line ('rl' is
+     the abbreviation for rightleft).
+
+   + Put the 'set rl' line in your '.vimrc' file to start Vim in
+     right-to-left mode permanently.
+
+Encoding
+--------
+
+The letter encoding used is the Vim extended ISIR-3342 standard with a built
+in function to convert between Vim extended ISIR-3342 and ISIR-3342 standard.
+
+For document portability reasons, the letter encoding is kept the same across
+different platforms (i.e. UNIX's, NT/95/98, MS DOS, ...).
+
+
+o  Keyboard
+
+   +  CTRL-_ in insert/replace modes toggles between Farsi(akm)/Latin
+      mode as follows:
+
+   +  CTRL-_ moves the cursor to the end of the typed text in edit mode.
+
+   +  CTRL-_ in command mode only toggles keyboard mapping between Farsi(akm)/
+      Latin.  The Farsi text is then entered in reverse insert mode.
+
+   +  F8 - Toggles between left-to-right and right-to-left.
+
+   +  F9 - Toggles the encoding between ISIR-3342 standard and Vim extended
+      ISIR-3342 (supported only in right-to-left mode).
+
+   +  Keyboard mapping is based on the Iranian ISIRI-2901 standard.
+      Following table shows the keyboard mapping while Farsi(akm) mode set:
+
+	-------------------------------------
+	`  1  2  3  4  5  6  7  8  9  0  -  =
+	¢  ±  ²  ³  ´  µ  ¶  ·  ¸  ¹  °  ­  ½
+	-------------------------------------
+	~  !  @  #  $  %  ^  &  *  (  )  _  +
+	~  £  §  ®  ¤  ¥  ª  ¬  è  ¨  ©  é  «
+	-------------------------------------
+	q  w  e  r  t  z  u  i  o  p  [  ]
+	Ó  Ò  Æ  Ù  Ø  Õ  Ö  à  Ê  É  Ç  ˆ
+	-------------------------------------
+	Q  W  E  R  T  Z  U  I  O  P  {  }
+	÷  õ  ô  ó  ò  ý  ð  ö  [  ]  {  }
+	-------------------------------------
+	a  s  d  f  g  h  j  k  l  ;  '  \
+	Ñ  Ð  á  Ã  Ü  Á  Å  Þ  Ý  Ú  Û  ë
+	-------------------------------------
+	A  S  D  F  G  H  J  K  L  :  "  |
+	ù  û  þ  ú  ø  À  ü  æ  ç  º  »  ê
+	-------------------------------------
+	<  y  x  c  v  b  n  m  ,  .  /
+	¾  ×  Ô  Î  Í  Ì  Ë  Ä  ß  ¦  ¯
+	-------------------------------------
+	>  Y  X  C  V  B  N  M  <  >  ?
+	¼  ñ  Ô  Ï  Í  ¡  Ë  Â  ¾  ¼  ¿
+	-------------------------------------
+
+Note:
+	¡  stands for Farsi PSP (break without space)
+
+	¢  stands for Farsi PCN (for HAMZE attribute )
+
+Restrictions
+------------
+
+o  In insert/replace mode and fkmap (Farsi mode) set, CTRL-B is not
+   supported.
+
+o  If you change the character mapping between Latin/Farsi, the redo buffer
+   will be reset (emptied).  That is, redo is valid and will function (using
+   '.') only within the mode you are in.
+
+o  While numbers are entered in Farsi mode, the redo buffer will be reset
+   (emptied).  That is, you cannot redo the last changes (using '.') after
+   entering numbers.
+
+o  While in left-to-right mode and Farsi mode set, CTRL-R is not supported.
+
+o  While in right-to-left mode, the search on 'Latin' pattern does not work,
+   except if you enter the Latin search pattern in reverse.
+
+o  In command mode there is no support for entering numbers from left
+   to right and also for the sake of flexibility the keymapping logic is
+   restricted.
+
+o  Under the X Window environment, if you want to run Vim within a xterm
+   terminal emulator and Farsi mode set, you need to have an ANSI compatible
+   xterm terminal emulator.  This is because the letter codes above 128 decimal
+   have certain meanings in the standard xterm terminal emulator.
+
+   Note: Under X Window environment, Vim GUI works fine in Farsi mode.
+	 This eliminates the need of any xterm terminal emulator.
+
+
+Bugs
+----
+While in insert/replace and Farsi mode set, if you repeatedly change the
+cursor position (via cursor movement) and enter new text and then try to undo
+the last change, the undo will lag one change behind.  But as you continue to
+undo, you will reach the original line of text.  You can also use U to undo all
+changes made in the current line.
+
+For more information about the bugs refer to rileft.txt.
+
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/filetype.txt b/share/vim/vim73/doc/filetype.txt
new file mode 100644
index 0000000000..c76adfc77e
--- /dev/null
+++ b/share/vim/vim73/doc/filetype.txt
@@ -0,0 +1,620 @@
+*filetype.txt*  For Vim version 7.3.  Last change: 2008 Jul 15
+
+
+		  VIM REFERENCE MANUAL    by Bram Moolenaar
+
+
+Filetypes						*filetype* *file-type*
+
+1. Filetypes					|filetypes|
+2. Filetype plugin				|filetype-plugins|
+3. Docs for the default filetype plugins.	|ftplugin-docs|
+
+Also see |autocmd.txt|.
+
+{Vi does not have any of these commands}
+
+==============================================================================
+1. Filetypes					*filetypes* *file-types*
+
+Vim can detect the type of file that is edited.  This is done by checking the
+file name and sometimes by inspecting the contents of the file for specific
+text.
+
+							*:filetype* *:filet*
+To enable file type detection, use this command in your vimrc: >
+	:filetype on
+Each time a new or existing file is edited, Vim will try to recognize the type
+of the file and set the 'filetype' option.  This will trigger the FileType
+event, which can be used to set the syntax highlighting, set options, etc.
+
+NOTE: Filetypes and 'compatible' don't work together well, since being Vi
+compatible means options are global.  Resetting 'compatible' is recommended,
+if you didn't do that already.
+
+Detail: The ":filetype on" command will load one of these files:
+		Amiga	    $VIMRUNTIME/filetype.vim
+		Mac	    $VIMRUNTIME:filetype.vim
+		MS-DOS	    $VIMRUNTIME\filetype.vim
+		RiscOS	    Vim:Filetype
+		Unix	    $VIMRUNTIME/filetype.vim
+		VMS	    $VIMRUNTIME/filetype.vim
+	This file is a Vim script that defines autocommands for the
+	BufNewFile and BufRead events.  If the file type is not found by the
+	name, the file $VIMRUNTIME/scripts.vim is used to detect it from the
+	contents of the file.
+	When the GUI is running or will start soon, the menu.vim script is
+	also sourced.  See |'go-M'| about avoiding that.
+
+To add your own file types, see |new-filetype| below.  To search for help on a
+filetype prepend "ft-" and optionally append "-syntax", "-indent" or
+"-plugin".  For example: >
+	:help ft-vim-indent
+	:help ft-vim-syntax
+	:help ft-man-plugin
+
+If the file type is not detected automatically, or it finds the wrong type,
+you can either set the 'filetype' option manually, or add a modeline to your
+file.  Example, for an IDL file use the command: >
+	:set filetype=idl
+
+or add this |modeline| to the file:
+	/* vim: set filetype=idl : */ ~
+
+						*:filetype-plugin-on*
+You can enable loading the plugin files for specific file types with: >
+	:filetype plugin on
+If filetype detection was not switched on yet, it will be as well.
+This actually loads the file "ftplugin.vim" in 'runtimepath'.
+The result is that when a file is edited its plugin file is loaded (if there
+is one for the detected filetype). |filetype-plugin|
+
+						*:filetype-plugin-off*
+You can disable it again with: >
+	:filetype plugin off
+The filetype detection is not switched off then.  But if you do switch off
+filetype detection, the plugins will not be loaded either.
+This actually loads the file "ftplugof.vim" in 'runtimepath'.
+
+						*:filetype-indent-on*
+You can enable loading the indent file for specific file types with: >
+	:filetype indent on
+If filetype detection was not switched on yet, it will be as well.
+This actually loads the file "indent.vim" in 'runtimepath'.
+The result is that when a file is edited its indent file is loaded (if there
+is one for the detected filetype). |indent-expression|
+
+						*:filetype-indent-off*
+You can disable it again with: >
+	:filetype indent off
+The filetype detection is not switched off then.  But if you do switch off
+filetype detection, the indent files will not be loaded either.
+This actually loads the file "indoff.vim" in 'runtimepath'.
+This disables auto-indenting for files you will open.  It will keep working in
+already opened files.  Reset 'autoindent', 'cindent', 'smartindent' and/or
+'indentexpr' to disable indenting in an opened file.
+
+						*:filetype-off*
+To disable file type detection, use this command: >
+	:filetype off
+This will keep the flags for "plugin" and "indent", but since no file types
+are being detected, they won't work until the next ":filetype on".
+
+
+Overview:					*:filetype-overview*
+
+command				detection	plugin		indent ~
+:filetype on			on		unchanged	unchanged
+:filetype off			off		unchanged	unchanged
+:filetype plugin on		on		on		unchanged
+:filetype plugin off		unchanged	off		unchanged
+:filetype indent on		on		unchanged	on
+:filetype indent off		unchanged	unchanged	off
+:filetype plugin indent on	on		on		on
+:filetype plugin indent off	unchanged	off		off
+
+To see the current status, type: >
+	:filetype
+The output looks something like this: >
+	filetype detection:ON  plugin:ON  indent:OFF
+
+The file types are also used for syntax highlighting.  If the ":syntax on"
+command is used, the file type detection is installed too.  There is no need
+to do ":filetype on" after ":syntax on".
+
+To disable one of the file types, add a line in your filetype file, see
+|remove-filetype|.
+
+							*filetype-detect*
+To detect the file type again: >
+	:filetype detect
+Use this if you started with an empty file and typed text that makes it
+possible to detect the file type.  For example, when you entered this in a
+shell script: "#!/bin/csh".
+   When filetype detection was off, it will be enabled first, like the "on"
+argument was used.
+
+							*filetype-overrule*
+When the same extension is used for two filetypes, Vim tries to guess what
+kind of file it is.  This doesn't always work.  A number of global variables
+can be used to overrule the filetype used for certain extensions:
+
+	file name	variable ~
+	*.asa		g:filetype_asa	|ft-aspvbs-syntax| |ft-aspperl-syntax|
+	*.asp		g:filetype_asp	|ft-aspvbs-syntax| |ft-aspperl-syntax|
+	*.asm		g:asmsyntax	|ft-asm-syntax|
+	*.prg		g:filetype_prg
+	*.pl		g:filetype_pl
+	*.inc		g:filetype_inc
+	*.w		g:filetype_w	|ft-cweb-syntax|
+	*.i		g:filetype_i	|ft-progress-syntax|
+	*.p		g:filetype_p	|ft-pascal-syntax|
+	*.sh		g:bash_is_sh	|ft-sh-syntax|
+	*.tex		g:tex_flavor	|ft-tex-plugin|
+
+							*filetype-ignore*
+To avoid that certain files are being inspected, the g:ft_ignore_pat variable
+is used.  The default value is set like this: >
+	:let g:ft_ignore_pat = '\.\(Z\|gz\|bz2\|zip\|tgz\)$'
+This means that the contents of compressed files are not inspected.
+
+							*new-filetype*
+If a file type that you want to use is not detected yet, there are four ways
+to add it.  In any way, it's better not to modify the $VIMRUNTIME/filetype.vim
+file.  It will be overwritten when installing a new version of Vim.
+
+A. If you want to overrule all default file type checks.
+   This works by writing one file for each filetype.  The disadvantage is that
+   means there can be many files.  The advantage is that you can simply drop
+   this file in the right directory to make it work.
+							*ftdetect*
+   1. Create your user runtime directory.  You would normally use the first
+      item of the 'runtimepath' option.  Then create the directory "ftdetect"
+      inside it.  Example for Unix: >
+	:!mkdir ~/.vim
+	:!mkdir ~/.vim/ftdetect
+<
+   2. Create a file that contains an autocommand to detect the file type.
+      Example: >
+	au BufRead,BufNewFile *.mine		set filetype=mine
+<     Note that there is no "augroup" command, this has already been done
+      when sourcing your file.  You could also use the pattern "*" and then
+      check the contents of the file to recognize it.
+      Write this file as "mine.vim" in the "ftdetect" directory in your user
+      runtime directory.  For example, for Unix: >
+	:w ~/.vim/ftdetect/mine.vim
+
+<  3. To use the new filetype detection you must restart Vim.
+
+   The files in the "ftdetect" directory are used after all the default
+   checks, thus they can overrule a previously detected file type.  But you
+   can also use |:setfiletype| to keep a previously detected filetype.
+
+B. If you want to detect your file after the default file type checks.
+
+   This works like A above, but instead of setting 'filetype' unconditionally
+   use ":setfiletype".  This will only set 'filetype' if no file type was
+   detected yet.  Example: >
+	au BufRead,BufNewFile *.txt		setfiletype text
+<
+   You can also use the already detected file type in your command.  For
+   example, to use the file type "mypascal" when "pascal" has been detected: >
+	au BufRead,BufNewFile *		if &ft == 'pascal' | set ft=mypascal
+								       | endif
+
+C. If your file type can be detected by the file name.
+   1. Create your user runtime directory.  You would normally use the first
+      item of the 'runtimepath' option.  Example for Unix: >
+	:!mkdir ~/.vim
+<
+   2. Create a file that contains autocommands to detect the file type.
+      Example: >
+	" my filetype file
+	if exists("did_load_filetypes")
+	  finish
+	endif
+	augroup filetypedetect
+	  au! BufRead,BufNewFile *.mine		setfiletype mine
+	  au! BufRead,BufNewFile *.xyz		setfiletype drawing
+	augroup END
+<     Write this file as "filetype.vim" in your user runtime directory.  For
+      example, for Unix: >
+	:w ~/.vim/filetype.vim
+
+<  3. To use the new filetype detection you must restart Vim.
+
+   Your filetype.vim will be sourced before the default FileType autocommands
+   have been installed.  Your autocommands will match first, and the
+   ":setfiletype" command will make sure that no other autocommands will set
+   'filetype' after this.
+							*new-filetype-scripts*
+D. If your filetype can only be detected by inspecting the contents of the
+   file.
+
+   1. Create your user runtime directory.  You would normally use the first
+      item of the 'runtimepath' option.  Example for Unix: >
+	:!mkdir ~/.vim
+<
+   2. Create a vim script file for doing this.  Example: >
+	if did_filetype()	" filetype already set..
+	  finish		" ..don't do these checks
+	endif
+	if getline(1) =~ '^#!.*\'
+	  setfiletype mine
+	elseif getline(1) =~? '\'
+	  setfiletype drawing
+	endif
+<     See $VIMRUNTIME/scripts.vim for more examples.
+      Write this file as "scripts.vim" in your user runtime directory.  For
+      example, for Unix: >
+	:w ~/.vim/scripts.vim
+<
+   3. The detection will work right away, no need to restart Vim.
+
+   Your scripts.vim is loaded before the default checks for file types, which
+   means that your rules override the default rules in
+   $VIMRUNTIME/scripts.vim.
+
+						*remove-filetype*
+If a file type is detected that is wrong for you, install a filetype.vim or
+scripts.vim to catch it (see above).  You can set 'filetype' to a non-existing
+name to avoid that it will be set later anyway: >
+	:set filetype=ignored
+
+If you are setting up a system with many users, and you don't want each user
+to add/remove the same filetypes, consider writing the filetype.vim and
+scripts.vim files in a runtime directory that is used for everybody.  Check
+the 'runtimepath' for a directory to use.  If there isn't one, set
+'runtimepath' in the |system-vimrc|.  Be careful to keep the default
+directories!
+
+
+						*autocmd-osfiletypes*
+On operating systems which support storing a file type with the file, you can
+specify that an autocommand should only be executed if the file is of a
+certain type.
+
+The actual type checking depends on which platform you are running Vim
+on; see your system's documentation for details.
+
+To use osfiletype checking in an autocommand you should put a list of types to
+match in angle brackets in place of a pattern, like this: >
+
+	:au BufRead *.html,<&faf;HTML>  runtime! syntax/html.vim
+
+This will match:
+
+- Any file whose name ends in ".html"
+- Any file whose type is "&faf" or "HTML", where the meaning of these types
+  depends on which version of Vim you are using.
+  Unknown types are considered NOT to match.
+
+You can also specify a type and a pattern at the same time (in which case they
+must both match): >
+
+	:au BufRead <&fff>diff*
+
+This will match files of type "&fff" whose names start with "diff".
+
+Note that osfiletype checking is skipped if Vim is compiled without the
+|+osfiletype| feature.
+
+							*plugin-details*
+The "plugin" directory can be in any of the directories in the 'runtimepath'
+option.  All of these directories will be searched for plugins and they are
+all loaded.  For example, if this command: >
+
+	set runtimepath
+
+produces this output:
+
+	runtimepath=/etc/vim,~/.vim,/usr/local/share/vim/vim60 ~
+
+then Vim will load all plugins in these directories and below:
+
+	/etc/vim/plugin/  ~
+	~/.vim/plugin/  ~
+	/usr/local/share/vim/vim60/plugin/  ~
+
+Note that the last one is the value of $VIMRUNTIME which has been expanded.
+
+What if it looks like your plugin is not being loaded?  You can find out what
+happens when Vim starts up by using the |-V| argument: >
+
+	vim -V2
+
+You will see a lot of messages, in between them is a remark about loading the
+plugins.  It starts with:
+
+	Searching for "plugin/**/*.vim" in ~
+
+There you can see where Vim looks for your plugin scripts.
+
+==============================================================================
+2. Filetype plugin					*filetype-plugins*
+
+When loading filetype plugins has been enabled |:filetype-plugin-on|, options
+will be set and mappings defined.  These are all local to the buffer, they
+will not be used for other files.
+
+Defining mappings for a filetype may get in the way of the mappings you
+define yourself.  There are a few ways to avoid this:
+1. Set the "maplocalleader" variable to the key sequence you want the mappings
+   to start with.  Example: >
+	:let maplocalleader = ","
+<  All mappings will then start with a comma instead of the default, which
+   is a backslash.  Also see ||.
+
+2. Define your own mapping.  Example: >
+	:map ,p MailQuote
+<  You need to check the description of the plugin file below for the
+   functionality it offers and the string to map to.
+   You need to define your own mapping before the plugin is loaded (before
+   editing a file of that type).  The plugin will then skip installing the
+   default mapping.
+
+3. Disable defining mappings for a specific filetype by setting a variable,
+   which contains the name of the filetype.  For the "mail" filetype this
+   would be: >
+	:let no_mail_maps = 1
+
+4. Disable defining mappings for all filetypes by setting a variable: >
+	:let no_plugin_maps = 1
+<
+
+							*ftplugin-overrule*
+If a global filetype plugin does not do exactly what you want, there are three
+ways to change this:
+
+1. Add a few settings.
+   You must create a new filetype plugin in a directory early in
+   'runtimepath'.  For Unix, for example you could use this file: >
+	vim ~/.vim/ftplugin/fortran.vim
+<  You can set those settings and mappings that you would like to add.  Note
+   that the global plugin will be loaded after this, it may overrule the
+   settings that you do here.  If this is the case, you need to use one of the
+   following two methods.
+
+2. Make a copy of the plugin and change it.
+   You must put the copy in a directory early in 'runtimepath'.  For Unix, for
+   example, you could do this: >
+	cp $VIMRUNTIME/ftplugin/fortran.vim ~/.vim/ftplugin/fortran.vim
+<  Then you can edit the copied file to your liking.  Since the b:did_ftplugin
+   variable will be set, the global plugin will not be loaded.
+   A disadvantage of this method is that when the distributed plugin gets
+   improved, you will have to copy and modify it again.
+
+3. Overrule the settings after loading the global plugin.
+   You must create a new filetype plugin in a directory from the end of
+   'runtimepath'.  For Unix, for example, you could use this file: >
+	vim ~/.vim/after/ftplugin/fortran.vim
+<  In this file you can change just those settings that you want to change.
+
+==============================================================================
+3.  Docs for the default filetype plugins.		*ftplugin-docs*
+
+
+CHANGELOG						*ft-changelog-plugin*
+
+Allows for easy entrance of Changelog entries in Changelog files.  There are
+some commands, mappings, and variables worth exploring:
+
+Options:
+'comments'		is made empty to not mess up formatting.
+'textwidth'		is set to 78, which is standard.
+'formatoptions'		the 't' flag is added to wrap when inserting text.
+
+Commands:
+NewChangelogEntry	Adds a new Changelog entry in an intelligent fashion
+			(see below).
+
+Local mappings:
+o		Starts a new Changelog entry in an equally intelligent
+			fashion (see below).
+
+Global mappings:
+			NOTE: The global mappings are accessed by sourcing the
+			ftplugin/changelog.vim file first, e.g. with >
+				runtime ftplugin/changelog.vim
+<			in your |.vimrc|.
+o		Switches to the ChangeLog buffer opened for the
+			current directory, or opens it in a new buffer if it
+			exists in the current directory.  Then it does the
+			same as the local o described above.
+
+Variables:
+g:changelog_timeformat  Deprecated; use g:changelog_dateformat instead.
+g:changelog_dateformat	The date (and time) format used in ChangeLog entries.
+			The format accepted is the same as for the
+			|strftime()| function.
+			The default is "%Y-%m-%d" which is the standard format
+			for many ChangeLog layouts.
+g:changelog_username	The name and email address of the user.
+			The default is deduced from environment variables and
+			system files.  It searches /etc/passwd for the comment
+			part of the current user, which informally contains
+			the real name of the user up to the first separating
+			comma.  then it checks the $NAME environment variable
+			and finally runs `whoami` and `hostname` to build an
+			email address.  The final form is >
+				Full Name  
+<
+g:changelog_new_date_format
+			The format to use when creating a new date-entry.
+			The following table describes special tokens in the
+			string:
+				%%	insert a single '%' character
+				%d	insert the date from above
+				%u	insert the user from above
+				%c	where to position cursor when done
+			The default is "%d  %u\n\n\t* %c\n\n", which produces
+			something like (| is where cursor will be, unless at
+			the start of the line where it denotes the beginning
+			of the line) >
+				|2003-01-14  Full Name  
+				|
+				|        * |
+<
+g:changelog_new_entry_format
+			The format used when creating a new entry.
+			The following table describes special tokens in the
+			string:
+				%c	where to position cursor when done
+			The default is "\t*%c", which produces something
+			similar to >
+				|        * |
+<
+g:changelog_date_entry_search
+			The search pattern to use when searching for a
+			date-entry.
+			The same tokens that can be used for
+			g:changelog_new_date_format can be used here as well.
+			The default is '^\s*%d\_s*%u' which finds lines
+			matching the form >
+				|2003-01-14  Full Name  
+<			and some similar formats.
+
+g:changelog_date_end_entry_search
+			The search pattern to use when searching for the end
+			of a date-entry.
+			The same tokens that can be used for
+			g:changelog_new_date_format can be used here as well.
+			The default is '^\s*$' which finds lines that contain
+			only whitespace or are completely empty.
+
+b:changelog_name					*b:changelog_name*
+			Name of the ChangeLog file to look for.
+			The default is 'ChangeLog'.
+
+b:changelog_path
+			Path of the ChangeLog to use for the current buffer.
+			The default is empty, thus looking for a file named
+			|b:changelog_name| in the same directory as the
+			current buffer.  If not found, the parent directory of
+			the current buffer is searched.  This continues
+			recursively until a file is found or there are no more
+			parent directories to search.
+
+b:changelog_entry_prefix
+			Name of a function to call to generate a prefix to a
+			new entry.  This function takes no arguments and
+			should return a string containing the prefix.
+			Returning an empty prefix is fine.
+			The default generates the shortest path between the
+			ChangeLog's pathname and the current buffers pathname.
+			In the future, it will also be possible to use other
+			variable contexts for this variable, for example, g:.
+
+The Changelog entries are inserted where they add the least amount of text.
+After figuring out the current date and user, the file is searched for an
+entry beginning with the current date and user and if found adds another item
+under it.  If not found, a new entry and item is prepended to the beginning of
+the Changelog.
+
+
+FORTRAN							*ft-fortran-plugin*
+
+Options:
+'expandtab'	is switched on to avoid tabs as required by the Fortran
+		standards unless the user has set fortran_have_tabs in .vimrc.
+'textwidth'	is set to 72 for fixed source format as required by the
+		Fortran standards and to 80 for free source format.
+'formatoptions' is set to break code and comment lines and to preserve long
+		lines.  You can format comments with |gq|.
+For further discussion of fortran_have_tabs and the method used for the
+detection of source format see |ft-fortran-syntax|.
+
+
+GIT COMMIT                                              *ft-gitcommit-plugin*
+
+One command, :DiffGitCached, is provided to show a diff of the current commit
+in the preview window.  It is equivalent to calling "git diff --cached" plus
+any arguments given to the command.
+
+
+MAIL							*ft-mail-plugin*
+
+Options:
+'modeline'	is switched off to avoid the danger of trojan horses, and to
+		avoid that a Subject line with "Vim:" in it will cause an
+		error message.
+'textwidth'	is set to 72.  This is often recommended for e-mail.
+'formatoptions'  is set to break text lines and to repeat the comment leader
+		in new lines, so that a leading ">" for quotes is repeated.
+		You can also format quoted text with |gq|.
+
+Local mappings:
+q   or   \\MailQuote
+	Quotes the text selected in Visual mode, or from the cursor position
+	to the end of the file in Normal mode.  This means "> " is inserted in
+	each line.
+
+MAN							*ft-man-plugin* *:Man*
+
+Displays a manual page in a nice way.  Also see the user manual
+|find-manpage|.
+
+To start using the ":Man" command before any manual page was loaded, source
+this script from your startup vimrc file: >
+
+	runtime ftplugin/man.vim
+
+Options:
+'iskeyword'	the '.' character is added to be able to use CTRL-] on the
+		manual page name.
+
+Commands:
+Man {name}	Display the manual page for {name} in a window.
+Man {number} {name}
+		Display the manual page for {name} in a section {number}.
+
+Global mapping:
+K	Displays the manual page for the word under the cursor.
+
+Local mappings:
+CTRL-]		Jump to the manual page for the word under the cursor.
+CTRL-T		Jump back to the previous manual page.
+
+
+PDF							*ft-pdf-plugin*
+
+Two maps,  and , are provided to simulate a tag stack for navigating
+the PDF.  The following are treated as tags:
+
+- The byte offset after "startxref" to the xref table
+- The byte offset after the /Prev key in the trailer to an earlier xref table
+- A line of the form "0123456789 00000 n" in the xref table
+- An object reference like "1 0 R" anywhere in the PDF
+
+These maps can be disabled with >
+	:let g:no_pdf_maps = 1
+<
+
+RPM SPEC						*ft-spec-plugin*
+
+Since the text for this plugin is rather long it has been put in a separate
+file: |pi_spec.txt|.
+
+
+SQL							*ft-sql*
+
+Since the text for this plugin is rather long it has been put in a separate
+file: |ft_sql.txt|.
+
+
+TEX							*ft-tex-plugin*
+
+If the first line of a *.tex file has the form >
+	%&
+then this determined the file type:  plaintex (for plain TeX), context (for
+ConTeXt), or tex (for LaTeX).  Otherwise, the file is searched for keywords to
+choose context or tex.  If no keywords are found, it defaults to plaintex.
+You can change the default by defining the variable g:tex_flavor to the format
+(not the file type) you use most.  Use one of these: >
+	let g:tex_flavor = "plain"
+	let g:tex_flavor = "context"
+	let g:tex_flavor = "latex"
+Currently no other formats are recognized.
+
+
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/fold.txt b/share/vim/vim73/doc/fold.txt
new file mode 100644
index 0000000000..24a8dcb617
--- /dev/null
+++ b/share/vim/vim73/doc/fold.txt
@@ -0,0 +1,590 @@
+*fold.txt*      For Vim version 7.3.  Last change: 2010 May 13
+
+
+		  VIM REFERENCE MANUAL    by Bram Moolenaar
+
+
+Folding						*Folding* *folding* *folds*
+
+You can find an introduction on folding in chapter 28 of the user manual.
+|usr_28.txt|
+
+1. Fold methods		|fold-methods|
+2. Fold commands	|fold-commands|
+3. Fold options		|fold-options|
+4. Behavior of folds	|fold-behavior|
+
+{Vi has no Folding}
+{not available when compiled without the |+folding| feature}
+
+==============================================================================
+1. Fold methods					*fold-methods*
+
+The folding method can be set with the 'foldmethod' option.
+
+When setting 'foldmethod' to a value other than "manual", all folds are
+deleted and new ones created.  Switching to the "manual" method doesn't remove
+the existing folds.  This can be used to first define the folds automatically
+and then change them manually.
+
+There are six methods to select folds:
+	manual		manually define folds
+	indent		more indent means a higher fold level
+	expr		specify an expression to define folds
+	syntax		folds defined by syntax highlighting
+	diff		folds for unchanged text
+	marker		folds defined by markers in the text
+
+
+MANUAL						*fold-manual*
+
+Use commands to manually define the fold regions.  This can also be used by a
+script that parses text to find folds.
+
+The level of a fold is only defined by its nesting.  To increase the fold
+level of a fold for a range of lines, define a fold inside it that has the
+same lines.
+
+The manual folds are lost when you abandon the file.  To save the folds use
+the |:mkview| command.  The view can be restored later with |:loadview|.
+
+
+INDENT						*fold-indent*
+
+The folds are automatically defined by the indent of the lines.
+
+The foldlevel is computed from the indent of the line, divided by the
+'shiftwidth' (rounded down).  A sequence of lines with the same or higher fold
+level form a fold, with the lines with a higher level forming a nested fold.
+
+The nesting of folds is limited with 'foldnestmax'.
+
+Some lines are ignored and get the fold level of the line above or below it,
+whatever is the lowest.  These are empty or white lines and lines starting
+with a character in 'foldignore'.  White space is skipped before checking for
+characters in 'foldignore'.  For C use "#" to ignore preprocessor lines.
+
+When you want to ignore lines in another way, use the 'expr' method.  The
+|indent()| function can be used in 'foldexpr' to get the indent of a line.
+
+
+EXPR						*fold-expr*
+
+The folds are automatically defined by their foldlevel, like with the "indent"
+method.  The value of the 'foldexpr' option is evaluated to get the foldlevel
+of a line.  Examples:
+This will create a fold for all consecutive lines that start with a tab: >
+	:set foldexpr=getline(v:lnum)[0]==\"\\t\"
+This will call a function to compute the fold level: >
+	:set foldexpr=MyFoldLevel(v:lnum)
+This will make a fold out of paragraphs separated by blank lines: >
+	:set foldexpr=getline(v:lnum)=~'^\\s*$'&&getline(v:lnum+1)=~'\\S'?'<1':1
+this does the same: >
+	:set foldexpr=getline(v:lnum-1)=~'^\\s*$'&&getline(v:lnum)=~'\\S'?'>1':1
+
+Note that backslashes must be used to escape characters that ":set" handles
+differently (space, backslash, double quote, etc., see |option-backslash|).
+
+These are the conditions with which the expression is evaluated:
+- The current buffer and window are set for the line.
+- The variable "v:lnum" is set to the line number.
+- The result is used for the fold level in this way:
+  value			meaning ~
+  0			the line is not in a fold
+  1, 2, ..		the line is in a fold with this level
+  -1			the fold level is undefined, use the fold level of a
+			line before or after this line, whichever is the
+			lowest.
+  "="			use fold level from the previous line
+  "a1", "a2", ..	add one, two, .. to the fold level of the previous
+			line
+  "s1", "s2", ..	subtract one, two, .. from the fold level of the
+			previous line
+  "<1", "<2", ..	a fold with this level ends at this line
+  ">1", ">2", ..	a fold with this level starts at this line
+
+It is not required to mark the start (end) of a fold with ">1" ("<1"), a fold
+will also start (end) when the fold level is higher (lower) than the fold
+level of the previous line.
+
+There must be no side effects from the expression.  The text in the buffer,
+cursor position, the search patterns, options etc. must not be changed.
+You can change and restore them if you are careful.
+
+If there is some error in the expression, or the resulting value isn't
+recognized, there is no error message and the fold level will be zero.
+For debugging the 'debug' option can be set to "msg", the error messages will
+be visible then.
+
+Note: Since the expression has to be evaluated for every line, this fold
+method can be very slow!
+
+Try to avoid the "=", "a" and "s" return values, since Vim often has to search
+backwards for a line for which the fold level is defined.  This can be slow.
+
+|foldlevel()| can be useful to compute a fold level relative to a previous
+fold level.  But note that foldlevel() may return -1 if the level is not known
+yet.  And it returns the level at the start of the line, while a fold might
+end in that line.
+
+It may happened that folds are not updated properly.  You can use |zx| or |zX|
+to force updating folds.
+
+
+SYNTAX						*fold-syntax*
+
+A fold is defined by syntax items that have the "fold" argument. |:syn-fold|
+
+The fold level is defined by nesting folds.  The nesting of folds is limited
+with 'foldnestmax'.
+
+Be careful to specify proper syntax syncing.  If this is not done right, folds
+may differ from the displayed highlighting.  This is especially relevant when
+using patterns that match more than one line.  In case of doubt, try using
+brute-force syncing: >
+	:syn sync fromstart
+
+
+DIFF						*fold-diff*
+
+The folds are automatically defined for text that is not part of a change or
+close to a change.
+
+This method only works properly when the 'diff' option is set for the current
+window and changes are being displayed.  Otherwise the whole buffer will be
+one big fold.
+
+The 'diffopt' option can be used to specify the context.  That is, the number
+of lines between the fold and a change that are not included in the fold.  For
+example, to use a context of 8 lines: >
+	:set diffopt=filler,context:8
+The default context is six lines.
+
+When 'scrollbind' is also set, Vim will attempt to keep the same folds open in
+other diff windows, so that the same text is visible.
+
+
+MARKER						*fold-marker*
+
+Markers in the text tell where folds start and end.  This allows you to
+precisely specify the folds.  This will allow deleting and putting a fold,
+without the risk of including the wrong lines.  The 'foldtext' option is
+normally set such that the text before the marker shows up in the folded line.
+This makes it possible to give a name to the fold.
+
+Markers can have a level included, or can use matching pairs.  Including a
+level is easier, you don't have to add end markers and avoid problems with
+non-matching marker pairs.  Example: >
+	/* global variables {{{1 */
+	int varA, varB;
+
+	/* functions {{{1 */
+	/* funcA() {{{2 */
+	void funcA() {}
+
+	/* funcB() {{{2 */
+	void funcB() {}
+
+A fold starts at a "{{{" marker.  The following number specifies the fold
+level.  What happens depends on the difference between the current fold level
+and the level given by the marker:
+1. If a marker with the same fold level is encountered, the previous fold
+   ends and another fold with the same level starts.
+2. If a marker with a higher fold level is found, a nested fold is started.
+3. if a marker with a lower fold level is found, all folds up to and including
+   this level end and a fold with the specified level starts.
+
+The number indicates the fold level.  A zero cannot be used (a marker with
+level zero is ignored).  You can use "}}}" with a digit to indicate the level
+of the fold that ends.  The fold level of the following line will be one less
+than the indicated level.  Note that Vim doesn't look back to the level of the
+matching marker (that would take too much time).  Example: >
+
+	{{{1
+	fold level here is 1
+	{{{3
+	fold level here is 3
+	}}}3
+	fold level here is 2
+
+You can also use matching pairs of "{{{" and "}}}" markers to define folds.
+Each "{{{" increases the fold level by one, each "}}}" decreases the fold
+level by one.  Be careful to keep the markers matching!  Example: >
+
+	{{{
+	fold level here is 1
+	{{{
+	fold level here is 2
+	}}}
+	fold level here is 1
+
+You can mix using markers with a number and without a number.  A useful way of
+doing this is to use numbered markers for large folds, and unnumbered markers
+locally in a function.  For example use level one folds for the sections of
+your file like "structure definitions", "local variables" and "functions".
+Use level 2 markers for each definition and function,  Use unnumbered markers
+inside functions.  When you make changes in a function to split up folds, you
+don't have to renumber the markers.
+
+The markers can be set with the 'foldmarker' option.  It is recommended to
+keep this at the default value of "{{{,}}}", so that files can be exchanged
+between Vim users.  Only change it when it is required for the file (e.g., it
+contains markers from another folding editor, or the default markers cause
+trouble for the language of the file).
+
+							*fold-create-marker*
+"zf" can be used to create a fold defined by markers.  Vim will insert the
+markers for you.  Vim will append the start and end marker, as specified with
+'foldmarker'.  The markers are appended to the end of the line.
+'commentstring' is used if it isn't empty.
+This does not work properly when:
+- The line already contains a marker with a level number.  Vim then doesn't
+  know what to do.
+- Folds nearby use a level number in their marker which gets in the way.
+- The line is inside a comment, 'commentstring' isn't empty and nested
+  comments don't work.  For example with C: adding /* {{{ */ inside a comment
+  will truncate the existing comment.  Either put the marker before or after
+  the comment, or add the marker manually.
+Generally it's not a good idea to let Vim create markers when you already have
+markers with a level number.
+
+							*fold-delete-marker*
+"zd" can be used to delete a fold defined by markers.  Vim will delete the
+markers for you.  Vim will search for the start and end markers, as specified
+with 'foldmarker', at the start and end of the fold.  When the text around the
+marker matches with 'commentstring', that text is deleted as well.
+This does not work properly when:
+- A line contains more than one marker and one of them specifies a level.
+  Only the first one is removed, without checking if this will have the
+  desired effect of deleting the fold.
+- The marker contains a level number and is used to start or end several folds
+  at the same time.
+
+==============================================================================
+2. Fold commands				*fold-commands* *E490*
+
+All folding commands start with "z".  Hint: the "z" looks like a folded piece
+of paper, if you look at it from the side.
+
+
+CREATING AND DELETING FOLDS ~
+							*zf* *E350*
+zf{motion}  or
+{Visual}zf	Operator to create a fold.
+		This only works when 'foldmethod' is "manual" or "marker".
+		The new fold will be closed for the "manual" method.
+		'foldenable' will be set.
+		Also see |fold-create-marker|.
+
+							*zF*
+zF		Create a fold for [count] lines.  Works like "zf".
+
+:{range}fo[ld]						*:fold* *:fo*
+		Create a fold for the lines in {range}.  Works like "zf".
+
+							*zd* *E351*
+zd		Delete one fold at the cursor.  When the cursor is on a folded
+		line, that fold is deleted.  Nested folds are moved one level
+		up.  In Visual mode all folds (partially) in the selected area
+		are deleted.  Careful: This easily deletes more folds than you
+		expect and there is no undo.
+		This only works when 'foldmethod' is "manual" or "marker".
+		Also see |fold-delete-marker|.
+
+							*zD*
+zD		Delete folds recursively at the cursor.  In Visual mode all
+		folds (partially) in the selected area and all nested folds in
+		them are deleted.
+		This only works when 'foldmethod' is "manual" or "marker".
+		Also see |fold-delete-marker|.
+
+							*zE* *E352*
+zE		Eliminate all folds in the window.
+		This only works when 'foldmethod' is "manual" or "marker".
+		Also see |fold-delete-marker|.
+
+
+OPENING AND CLOSING FOLDS ~
+
+A fold smaller than 'foldminlines' will always be displayed like it was open.
+Therefore the commands below may work differently on small folds.
+
+							*zo*
+zo		Open one fold under the cursor.  When a count is given, that
+		many folds deep will be opened.  In Visual mode one level of
+		folds is opened for all lines in the selected area.
+
+							*zO*
+zO		Open all folds under the cursor recursively.  Folds that don't
+		contain the cursor line are unchanged.
+		In Visual mode it opens all folds that are in the selected
+		area, also those that are only partly selected.
+
+							*zc*
+zc		Close one fold under the cursor.  When a count is given, that
+		many folds deep are closed.  In Visual mode one level of folds
+		is closed for all lines in the selected area.
+		'foldenable' will be set.
+
+							*zC*
+zC		Close all folds under the cursor recursively.  Folds that
+		don't contain the cursor line are unchanged.
+		In Visual mode it closes all folds that are in the selected
+		area, also those that are only partly selected.
+		'foldenable' will be set.
+
+							*za*
+za		When on a closed fold: open it.  When folds are nested, you
+		may have to use "za" several times.  When a count is given,
+		that many closed folds are opened.
+		When on an open fold: close it and set 'foldenable'.  This
+		will only close one level, since using "za" again will open
+		the fold.  When a count is given that many folds will be
+		closed (that's not the same as repeating "za" that many
+		times).
+
+							*zA*
+zA		When on a closed fold: open it recursively.
+		When on an open fold: close it recursively and set
+		'foldenable'.
+
+							*zv*
+zv		View cursor line: Open just enough folds to make the line in
+		which the cursor is located not folded.
+
+							*zx*
+zx		Update folds: Undo manually opened and closed folds: re-apply
+		'foldlevel', then do "zv": View cursor line.
+		Also forces recomputing folds.  This is useful when using
+		'foldexpr' and the buffer is changed in a way that results in
+		folds not to be updated properly.
+
+							*zX*
+zX		Undo manually opened and closed folds: re-apply 'foldlevel'.
+		Also forces recomputing folds, like |zx|.
+
+							*zm*
+zm		Fold more: Subtract one from 'foldlevel'.  If 'foldlevel' was
+		already zero nothing happens.
+		'foldenable' will be set.
+
+							*zM*
+zM		Close all folds: set 'foldlevel' to 0.
+		'foldenable' will be set.
+
+							*zr*
+zr		Reduce folding: Add one to 'foldlevel'.
+
+							*zR*
+zR		Open all folds.  This sets 'foldlevel' to highest fold level.
+
+							*:foldo* *:foldopen*
+:{range}foldo[pen][!]
+		Open folds in {range}.  When [!] is added all folds are
+		opened.  Useful to see all the text in {range}.  Without [!]
+		one level of folds is opened.
+
+							*:foldc* *:foldclose*
+:{range}foldc[lose][!]
+		Close folds in {range}.  When [!] is added all folds are
+		closed.  Useful to hide all the text in {range}.  Without [!]
+		one level of folds is closed.
+
+							*zn*
+zn		Fold none: reset 'foldenable'.  All folds will be open.
+
+							*zN*
+zN		Fold normal: set 'foldenable'.  All folds will be as they
+		were before.
+
+							*zi*
+zi		Invert 'foldenable'.
+
+
+MOVING OVER FOLDS ~
+							*[z*
+[z		Move to the start of the current open fold.  If already at the
+		start, move to the start of the fold that contains it.  If
+		there is no containing fold, the command fails.
+		When a count is used, repeats the command [count] times.
+
+							*]z*
+]z		Move to the end of the current open fold.  If already at the
+		end, move to the end of the fold that contains it.  If there
+		is no containing fold, the command fails.
+		When a count is used, repeats the command [count] times.
+
+							*zj*
+zj		Move downwards to the start of the next fold.  A closed fold
+		is counted as one fold.
+		When a count is used, repeats the command [count] times.
+		This command can be used after an |operator|.
+
+							*zk*
+zk		Move upwards to the end of the previous fold.  A closed fold
+		is counted as one fold.
+		When a count is used, repeats the command [count] times.
+		This command can be used after an |operator|.
+
+
+EXECUTING COMMANDS ON FOLDS ~
+
+:[range]foldd[oopen] {cmd}			*:foldd* *:folddoopen*
+		Execute {cmd} on all lines that are not in a closed fold.
+		When [range] is given, only these lines are used.
+		Each time {cmd} is executed the cursor is positioned on the
+		line it is executed for.
+		This works like the ":global" command: First all lines that
+		are not in a closed fold are marked.  Then the {cmd} is
+		executed for all marked lines.  Thus when {cmd} changes the
+		folds, this has no influence on where it is executed (except
+		when lines are deleted, of course).
+		Example: >
+			:folddoopen s/end/loop_end/ge
+<		Note the use of the "e" flag to avoid getting an error message
+		where "end" doesn't match.
+
+:[range]folddoc[losed] {cmd}			*:folddoc* *:folddoclosed*
+		Execute {cmd} on all lines that are in a closed fold.
+		Otherwise like ":folddoopen".
+
+==============================================================================
+3. Fold options					*fold-options*
+
+COLORS							*fold-colors*
+
+The colors of a closed fold are set with the Folded group |hl-Folded|.  The
+colors of the fold column are set with the FoldColumn group |hl-FoldColumn|.
+Example to set the colors: >
+
+	:highlight Folded guibg=grey guifg=blue
+	:highlight FoldColumn guibg=darkgrey guifg=white
+
+
+FOLDLEVEL						*fold-foldlevel*
+
+'foldlevel' is a number option: The higher the more folded regions are open.
+When 'foldlevel' is 0, all folds are closed.
+When 'foldlevel' is positive, some folds are closed.
+When 'foldlevel' is very high, all folds are open.
+'foldlevel' is applied when it is changed.  After that manually folds can be
+opened and closed.
+When increased, folds above the new level are opened.  No manually opened
+folds will be closed.
+When decreased, folds above the new level are closed.  No manually closed
+folds will be opened.
+
+
+FOLDTEXT						*fold-foldtext*
+
+'foldtext' is a string option that specifies an expression.  This expression
+is evaluated to obtain the text displayed for a closed fold.  Example: >
+
+    :set foldtext=v:folddashes.substitute(getline(v:foldstart),'/\\*\\\|\\*/\\\|{{{\\d\\=','','g')
+
+This shows the first line of the fold, with "/*", "*/" and "{{{" removed.
+Note the use of backslashes to avoid some characters to be interpreted by the
+":set" command.  It's simpler to define a function and call that: >
+
+    :set foldtext=MyFoldText()
+    :function MyFoldText()
+    :  let line = getline(v:foldstart)
+    :  let sub = substitute(line, '/\*\|\*/\|{{{\d\=', '', 'g')
+    :  return v:folddashes . sub
+    :endfunction
+
+Evaluating 'foldtext' is done in the |sandbox|.  The current window is set to
+the window that displays the line.  Errors are ignored.
+
+The default value is |foldtext()|.  This returns a reasonable text for most
+types of folding.  If you don't like it, you can specify your own 'foldtext'
+expression.  It can use these special Vim variables:
+	v:foldstart	line number of first line in the fold
+	v:foldend	line number of last line in the fold
+	v:folddashes	a string that contains dashes to represent the
+			foldlevel.
+	v:foldlevel	the foldlevel of the fold
+
+In the result a TAB is replaced with a space and unprintable characters are
+made into printable characters.
+
+The resulting line is truncated to fit in the window, it never wraps.
+When there is room after the text, it is filled with the character specified
+by 'fillchars'.
+
+Note that backslashes need to be used for characters that the ":set" command
+handles differently: Space, backslash and double-quote. |option-backslash|
+
+
+FOLDCOLUMN						*fold-foldcolumn*
+
+'foldcolumn' is a number, which sets the width for a column on the side of the
+window to indicate folds.  When it is zero, there is no foldcolumn.  A normal
+value is 4 or 5.  The minimal useful value is 2, although 1 still provides
+some information.  The maximum is 12.
+
+An open fold is indicated with a column that has a '-' at the top and '|'
+characters below it.  This column stops where the open fold stops.  When folds
+nest, the nested fold is one character right of the fold it's contained in.
+
+A closed fold is indicated with a '+'.
+
+Where the fold column is too narrow to display all nested folds, digits are
+shown to indicate the nesting level.
+
+The mouse can also be used to open and close folds by clicking in the
+fold column:
+- Click on a '+' to open the closed fold at this row.
+- Click on any other non-blank character to close the open fold at this row.
+
+
+OTHER OPTIONS
+
+'foldenable'  'fen':	Open all folds while not set.
+'foldexpr'    'fde':	Expression used for "expr" folding.
+'foldignore'  'fdi':	Characters used for "indent" folding.
+'foldmarker'  'fmr':	Defined markers used for "marker" folding.
+'foldmethod'  'fdm':	Name of the current folding method.
+'foldminlines' 'fml':	Minimum number of screen lines for a fold to be
+			displayed closed.
+'foldnestmax' 'fdn':	Maximum nesting for "indent" and "syntax" folding.
+'foldopen'    'fdo':	Which kinds of commands open closed folds.
+'foldclose'   'fcl':	When the folds not under the cursor are closed.
+
+==============================================================================
+4. Behavior of folds					*fold-behavior*
+
+When moving the cursor upwards or downwards and when scrolling, the cursor
+will move to the first line of a sequence of folded lines.  When the cursor is
+already on a folded line, it moves to the next unfolded line or the next
+closed fold.
+
+While the cursor is on folded lines, the cursor is always displayed in the
+first column.  The ruler does show the actual cursor position, but since the
+line is folded, it cannot be displayed there.
+
+Many movement commands handle a sequence of folded lines like an empty line.
+For example, the "w" command stops once in the first column.
+
+When in Insert mode, the cursor line is never folded.  That allows you to see
+what you type!
+
+When using an operator, a closed fold is included as a whole.  Thus "dl"
+deletes the whole closed fold under the cursor.
+
+For Ex commands the range is adjusted to always start at the first line of a
+closed fold and end at the last line of a closed fold.  Thus this command: >
+	:s/foo/bar/g
+when used with the cursor on a closed fold, will replace "foo" with "bar" in
+all lines of the fold.
+This does not happen for |:folddoopen| and |:folddoclosed|.
+
+When editing a buffer that has been edited before, the last used folding
+settings are used again.  For manual folding the defined folds are restored.
+For all folding methods the manually opened and closed folds are restored.
+If this buffer has been edited in this window, the values from back then are
+used.  Otherwise the values from the window where the buffer was edited last
+are used.
+
+==============================================================================
+ vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/ft_ada.txt b/share/vim/vim73/doc/ft_ada.txt
new file mode 100644
index 0000000000..54c6b3f57e
--- /dev/null
+++ b/share/vim/vim73/doc/ft_ada.txt
@@ -0,0 +1,515 @@
+*ft_ada.txt*	For Vim version 7.3.  Last change: 2010 Jul 20
+
+
+		    ADA FILE TYPE PLUG-INS REFERENCE MANUAL~
+
+ADA								      *ada.vim*
+
+1.  Syntax Highlighting			    |ft-ada-syntax|
+2.  Plug-in				    |ft-ada-plugin|
+3.  Omni Completion			    |ft-ada-omni|
+    3.1 Omni Completion with "gnat xref"	|gnat-xref|
+    3.2 Omni Completion with "ctags"		|ada-ctags|
+4.  Compiler Support			    |ada-compiler|
+    4.1 GNAT					|compiler-gnat|
+    4.1 Dec Ada					|compiler-decada|
+5.  References				    |ada-reference|
+    5.1 Options					|ft-ada-options|
+    5.2 Functions				|ft-ada-functions|
+    5.3 Commands				|ft-ada-commands|
+    5.4 Variables				|ft-ada-variables|
+    5.5 Constants				|ft-ada-constants|
+8.  Extra Plug-ins			    |ada-extra-plugins|
+
+==============================================================================
+1. Syntax Highlighting ~
+							       *ft-ada-syntax*
+
+This mode is designed for the 2005 edition of Ada ("Ada 2005"), which includes
+support for objected-programming, protected types, and so on.  It handles code
+written for the original Ada language ("Ada83", "Ada87", "Ada95") as well,
+though code which uses Ada 2005-only keywords will be wrongly colored (such
+code should be fixed anyway).  For more information about Ada, see
+http://www.adapower.com.
+
+The Ada mode handles a number of situations cleanly.
+
+For example, it knows that the "-" in "-5" is a number, but the same character
+in "A-5" is an operator.  Normally, a "with" or "use" clause referencing
+another compilation unit is coloured the same way as C's "#include" is coloured.
+If you have "Conditional" or "Repeat" groups coloured differently, then "end
+if" and "end loop" will be coloured as part of those respective groups.
+
+You can set these to different colours using vim's "highlight" command (e.g.,
+to change how loops are displayed, enter the command ":hi Repeat" followed by
+the colour specification; on simple terminals the colour specification
+ctermfg=White often shows well).
+
+There are several options you can select in this Ada mode. See |ft-ada-options|
+for a complete list.
+
+To enable them, assign a value to the option.  For example, to turn one on:
+ >
+    > let g:ada_standard_types = 1
+>
+To disable them use ":unlet".  Example:
+>
+    > unlet g:ada_standard_types
+
+You can just use ":" and type these into the command line to set these
+temporarily before loading an Ada file.  You can make these option settings
+permanent by adding the "let" command(s), without a colon, to your "~/.vimrc"
+file.
+
+Even on a slow (90Mhz) PC this mode works quickly, but if you find the
+performance unacceptable, turn on |g:ada_withuse_ordinary|.
+
+Syntax folding instructions (|fold-syntax|) are added when |g:ada_folding| is
+set.
+
+==============================================================================
+2. File type Plug-in ~
+					       *ft-ada-indent* *ft-ada-plugin*
+
+The Ada plug-in provides support for:
+
+ - auto indenting	(|indent.txt|)
+ - insert completion	(|i_CTRL-N|)
+ - user completion	(|i_CTRL-X_CTRL-U|)
+ - tag searches		(|tagsrch.txt|)
+ - Quick Fix		(|quickfix.txt|)
+ - backspace handling	(|'backspace'|)
+ - comment handling	(|'comments'|, |'commentstring'|)
+
+The plug-in only activates the features of the Ada mode whenever an Ada
+file is opened and adds Ada related entries to the main and pop-up menu.
+
+==============================================================================
+3. Omni Completion ~
+								 *ft-ada-omni*
+
+The Ada omni-completions (|i_CTRL-X_CTRL-O|) uses tags database created either
+by "gnat xref -v" or the "exuberant Ctags (http://ctags.sourceforge.net).  The
+complete function will automatically detect which tool was used to create the
+tags file.
+
+------------------------------------------------------------------------------
+3.1 Omni Completion with "gnat xref" ~
+								   *gnat-xref*
+
+GNAT XREF uses the compiler internal information (ali-files) to produce the
+tags file. This has the advantage to be 100% correct and the option of deep
+nested analysis. However the code must compile, the generator is quite
+slow and the created tags file contains only the basic Ctags information for
+each entry - not enough for some of the more advanced Vim code browser
+plug-ins.
+
+NOTE: "gnat xref -v" is very tricky to use as it has almost no diagnostic
+       output - If nothing is printed then usually the parameters are wrong.
+       Here some important tips:
+
+1)  You need to compile your code first and use the "-aO" option to point to
+    your .ali files.
+2)  "gnat xref -v ../Include/adacl.ads" won't work - use  the "gnat xref -v
+    -aI../Include adacl.ads" instead.
+3)  "gnat xref -v -aI../Include *.ad?" won't work - use "cd ../Include" and
+    then "gnat xref -v *.ad?"
+4)  Project manager support is completely broken - don't even try "gnat xref
+    -Padacl.gpr".
+5)  VIM is faster when the tags file is sorted - use "sort --unique
+    --ignore-case --output=tags tags" .
+6)  Remember to insert "!_TAG_FILE_SORTED 2 %sort ui" as first line to mark
+    the file assorted.
+
+------------------------------------------------------------------------------
+3.2 Omni Completion with "ctags"~
+								   *ada-ctags*
+
+Exuberant Ctags uses its own multi-language code parser. The parser is quite
+fast, produces a lot of extra information (hence the name "Exuberant Ctags")
+and can run on files which currently do not compile.
+
+There are also lots of other Vim-tools which use exuberant Ctags.
+
+You will need to install a version of the Exuberant Ctags which has Ada
+support patched in. Such a version is available from the GNU Ada Project
+(http://gnuada.sourceforge.net).
+
+The Ada parser for Exuberant Ctags is fairly new - don't expect complete
+support yet.
+
+==============================================================================
+4.  Compiler Support ~
+								*ada-compiler*
+
+The Ada mode supports more than one Ada compiler and will automatically load the
+compiler set in |g:ada_default_compiler| whenever an Ada source is opened. The
+provided compiler plug-ins are split into the actual compiler plug-in and a
+collection of support functions and variables. This allows the easy
+development of specialized compiler plug-ins fine tuned to your development
+environment.
+
+------------------------------------------------------------------------------
+4.1 GNAT ~
+							       *compiler-gnat*
+
+GNAT is the only free (beer and speech) Ada compiler available. There are
+several versions available which differ in the licence terms used.
+
+The GNAT compiler plug-in will perform a compile on pressing  and then
+immediately shows the result. You can set the project file to be used by
+setting:
+ >
+ > call g:gnat.Set_Project_File ('my_project.gpr')
+
+Setting a project file will also create a Vim session (|views-sessions|) so -
+like with the GPS - opened files, window positions etc. will be remembered
+separately for all projects.
+
+								*gnat_members*
+GNAT OBJECT ~
+
+							       *g:gnat.Make()*
+g:gnat.Make()
+		Calls |g:gnat.Make_Command| and displays the result inside a
+               |quickfix| window.
+
+							     *g:gnat.Pretty()*
+g:gnat.Pretty()
+		Calls |g:gnat.Pretty_Program|
+
+							       *g:gnat.Find()*
+g:gnat.Find()
+		Calls |g:gnat.Find_Program|
+
+							       *g:gnat.Tags()*
+g:gnat.Tags()
+		Calls |g:gnat.Tags_Command|
+
+						   *g:gnat.Set_Project_File()*
+g:gnat.Set_Project_File([{file}])
+		Set gnat project file and load associated session.  An open
+		project will be closed and the session written.  If called
+		without file name the file selector opens for selection of a
+		project file. If called with an empty string then the project
+		and associated session are closed.
+
+							 *g:gnat.Project_File*
+g:gnat.Project_File	string
+		Current project file.
+
+							 *g:gnat.Make_Command*
+g:gnat.Make_Command	string
+		External command used for |g:gnat.Make()| (|'makeprg'|).
+
+						       *g:gnat.Pretty_Program*
+g:gnat.Pretty_Program	string
+		External command used for |g:gnat.Pretty()|
+
+							 *g:gnat.Find_Program*
+g:gnat.Find_Program	string
+		External command used for |g:gnat.Find()|
+
+							 *g:gnat.Tags_Command*
+g:gnat.Tags_Command	string
+		External command used for |g:gnat.Tags()|
+
+							 *g:gnat.Error_Format*
+g:gnat.Error_Format	string
+		Error format (|'errorformat'|)
+
+------------------------------------------------------------------------------
+4.2 Dec Ada ~
+					    *compiler-hpada* *compiler-decada*
+					*compiler-vaxada* *compiler-compaqada*
+
+Dec Ada (also known by - in chronological order - VAX Ada, Dec Ada, Compaq Ada
+and HP Ada) is a fairly dated Ada 83 compiler. Support is basic:  will
+compile the current unit.
+
+The Dec Ada compiler expects the package name and not the file name to be
+passed as a parameter. The compiler plug-in supports the usual file name
+convention to convert the file into a unit name. Both '-' and '__' are allowed
+as separators.
+
+							      *decada_members*
+DEC ADA OBJECT ~
+
+							     *g:decada.Make()*
+g:decada.Make()		function
+		Calls |g:decada.Make_Command| and displays the result inside a
+		|quickfix| window.
+
+							*g:decada.Unit_Name()*
+g:decada.Unit_Name()	function
+		Get the Unit name for the current file.
+
+						       *g:decada.Make_Command*
+g:decada.Make_Command	string
+		External command used for |g:decada.Make()| (|'makeprg'|).
+
+						       *g:decada.Error_Format*
+g:decada.Error_Format|	string
+		Error format (|'errorformat'|).
+
+==============================================================================
+5. References ~
+							       *ada-reference*
+
+------------------------------------------------------------------------------
+5.1 Options ~
+							      *ft-ada-options*
+
+							*g:ada_standard_types*
+g:ada_standard_types	bool (true when exists)
+		Highlight types in package Standard (e.g., "Float").
+
+							  *g:ada_space_errors*
+						  *g:ada_no_trail_space_error*
+						    *g:ada_no_tab_space_error*
+							 *g:ada_all_tab_usage*
+g:ada_space_errors	 bool (true when exists)
+		Highlight extraneous errors in spaces ...
+		g:ada_no_trail_space_error
+		    - but ignore trailing spaces at the end of a line
+		g:ada_no_tab_space_error
+		    - but ignore tabs after spaces
+		g:ada_all_tab_usage
+		    - highlight all tab use
+
+							   *g:ada_line_errors*
+g:ada_line_errors	  bool (true when exists)
+		Highlight lines which are too long. Note: This highlighting
+		option is quite CPU intensive.
+
+							 *g:ada_rainbow_color*
+g:ada_rainbow_color	  bool (true when exists)
+		Use rainbow colours for '(' and ')'. You need the
+		rainbow_parenthesis for this to work.
+
+							       *g:ada_folding*
+g:ada_folding		  set ('sigpft')
+		Use folding for Ada sources.
+		    's':    activate syntax folding on load
+			'p':    fold packages
+			'f':    fold functions and procedures
+			't':    fold types
+			'c':    fold conditionals
+		    'g':    activate gnat pretty print folding on load
+			'i':    lone 'is' folded with line above
+			'b':	lone 'begin' folded with line above
+			'p':	lone 'private' folded with line above
+			'x':	lone 'exception' folded with line above
+		    'i':    activate indent folding on load
+
+		Note: Syntax folding is in an early (unusable) stage and
+		      indent or gnat pretty folding is suggested.
+
+		For gnat pretty folding to work the following settings are
+		suggested: -cl3 -M79 -c2 -c3 -c4 -A1 -A2 -A3 -A4 -A5
+
+		For indent folding to work the following settings are
+		suggested: shiftwidth=3 softtabstop=3
+
+								*g:ada_abbrev*
+g:ada_abbrev		  bool (true when exists)
+		Add some abbreviations. This feature is more or less superseded
+		by the various completion methods.
+
+						      *g:ada_withuse_ordinary*
+g:ada_withuse_ordinary	  bool (true when exists)
+		Show "with" and "use" as ordinary keywords (when used to
+		reference other compilation units they're normally highlighted
+		specially).
+
+							 *g:ada_begin_preproc*
+g:ada_begin_preproc	  bool (true when exists)
+		Show all begin-like keywords using the colouring of C
+		preprocessor commands.
+
+						    *g:ada_omni_with_keywords*
+g:ada_omni_with_keywords
+		Add Keywords, Pragmas, Attributes to omni-completions
+		(|compl-omni|). Note: You can always complete then with user
+		completion (|i_CTRL-X_CTRL-U|).
+
+						      *g:ada_extended_tagging*
+g:ada_extended_tagging	  enum ('jump', 'list')
+		use extended tagging, two options are available
+		    'jump': use tjump to jump.
+		    'list': add tags quick fix list.
+		Normal tagging does not support function or operator
+		overloading as these features are not available in C and
+		tagging was originally developed for C.
+
+						   *g:ada_extended_completion*
+g:ada_extended_completion
+		Uses extended completion for  and  completions
+		(|i_CTRL-N|). In this mode the '.' is used as part of the
+		identifier so that 'Object.Method' or 'Package.Procedure' are
+		completed together.
+
+						       *g:ada_gnat_extensions*
+g:ada_gnat_extensions	  bool (true when exists)
+		 Support GNAT extensions.
+
+					       *g:ada_with_gnat_project_files*
+g:ada_with_gnat_project_files	 bool (true when exists)
+		 Add gnat project file keywords and Attributes.
+
+						      *g:ada_default_compiler*
+g:ada_default_compiler	  string
+		set default compiler. Currently supported are 'gnat' and
+		'decada'.
+
+An "exists" type is a boolean considered true when the variable is defined and
+false when the variable is undefined. The value to which the variable is set
+makes no difference.
+
+------------------------------------------------------------------------------
+5.3 Commands ~
+							     *ft-ada-commands*
+
+:AdaRainbow							 *:AdaRainbow*
+		Toggles rainbow colour (|g:ada_rainbow_color|) mode for
+		'(' and ')'.
+
+:AdaLines							   *:AdaLines*
+		Toggles line error (|g:ada_line_errors|) display.
+
+:AdaSpaces							  *:AdaSpaces*
+		Toggles space error (|g:ada_space_errors|) display.
+
+:AdaTagDir							  *:AdaTagDir*
+		Creates tags file for the directory of the current file.
+
+:AdaTagFile							 *:AdaTagFile*
+		Creates tags file for the current file.
+
+:AdaTypes							   *:AdaTypes*
+		Toggles standard types (|g:ada_standard_types|) colour.
+
+:GnatFind							   *:GnatFind*
+		Calls |g:gnat.Find()|
+
+:GnatPretty							 *:GnatPretty*
+		Calls |g:gnat.Pretty()|
+
+:GnatTags							   *:GnatTags*
+		Calls |g:gnat.Tags()|
+
+------------------------------------------------------------------------------
+5.3 Variables ~
+							    *ft-ada-variables*
+
+								      *g:gnat*
+g:gnat			    object
+		Control object which manages GNAT compiles.  The object
+		is created when the first Ada source code is loaded provided
+		that |g:ada_default_compiler| is set to 'gnat'. See
+		|gnat_members| for details.
+
+								    *g:decada*
+g:decada		      object
+		Control object which manages Dec Ada compiles.	The object
+		is created when the first Ada source code is loaded provided
+		that |g:ada_default_compiler| is set to 'decada'. See
+		|decada_members| for details.
+
+------------------------------------------------------------------------------
+5.4 Constants ~
+							    *ft-ada-constants*
+
+All constants are locked. See |:lockvar| for details.
+
+							     *g:ada#WordRegex*
+g:ada#WordRegex		string
+		Regular expression to search for Ada words.
+
+							  *g:ada#DotWordRegex*
+g:ada#DotWordRegex	string
+		Regular expression to search for Ada words separated by dots.
+
+							       *g:ada#Comment*
+g:ada#Comment		string
+		Regular expression to search for Ada comments.
+
+							      *g:ada#Keywords*
+g:ada#Keywords		list of dictionaries
+		List of keywords, attributes etc. pp. in the format used by
+		omni completion. See |complete-items| for details.
+
+							   *g:ada#Ctags_Kinds*
+g:ada#Ctags_Kinds	dictionary of lists
+		Dictionary of the various kinds of items which the Ada support
+		for Ctags generates.
+
+------------------------------------------------------------------------------
+5.2 Functions ~
+							    *ft-ada-functions*
+
+ada#Word([{line}, {col}])					  *ada#Word()*
+		Return full name of Ada entity under the cursor (or at given
+		line/column), stripping white space/newlines as necessary.
+
+ada#List_Tag([{line}, {col}])				      *ada#Listtags()*
+		List all occurrences of the Ada entity under the cursor (or at
+		given line/column) inside the quick-fix window.
+
+ada#Jump_Tag ({ident}, {mode})				      *ada#Jump_Tag()*
+		List all occurrences of the Ada entity under the cursor (or at
+		given line/column) in the tag jump list. Mode can either be
+		'tjump' or 'stjump'.
+
+ada#Create_Tags ({option})				   *ada#Create_Tags()*
+		Creates tag file using Ctags. The option can either be 'file'
+		for the current file, 'dir' for the directory of the current
+		file or a file name.
+
+gnat#Insert_Tags_Header()			   *gnat#Insert_Tags_Header()*
+		Adds the tag file header (!_TAG_) information to the current
+		file which are missing from the GNAT XREF output.
+
+ada#Switch_Syntax_Option ({option})		  *ada#Switch_Syntax_Option()*
+		Toggles highlighting options on or off. Used for the Ada menu.
+
+								  *gnat#New()*
+gnat#New ()
+		Create a new gnat object. See |g:gnat| for details.
+
+
+==============================================================================
+8. Extra Plugins ~
+							   *ada-extra-plugins*
+
+You can optionally install the following extra plug-ins. They work well with
+Ada and enhance the ability of the Ada mode:
+
+backup.vim
+	http://www.vim.org/scripts/script.php?script_id=1537
+	Keeps as many backups as you like so you don't have to.
+
+rainbow_parenthsis.vim
+	http://www.vim.org/scripts/script.php?script_id=1561
+	Very helpful since Ada uses only '(' and ')'.
+
+nerd_comments.vim
+	http://www.vim.org/scripts/script.php?script_id=1218
+	Excellent commenting and uncommenting support for almost any
+	programming language.
+
+matchit.vim
+	http://www.vim.org/scripts/script.php?script_id=39
+	'%' jumping for any language. The normal '%' jump only works for '{}'
+	style languages. The Ada mode will set the needed search patterns.
+
+taglist.vim
+	http://www.vim.org/scripts/script.php?script_id=273
+	Source code explorer sidebar. There is a patch for Ada available.
+
+The GNU Ada Project distribution (http://gnuada.sourceforge.net) of Vim
+contains all of the above.
+
+==============================================================================
+vim: textwidth=78 nowrap tabstop=8 shiftwidth=4 softtabstop=4 noexpandtab
+vim: filetype=help
diff --git a/share/vim/vim73/doc/ft_sql.txt b/share/vim/vim73/doc/ft_sql.txt
new file mode 100644
index 0000000000..1360a03794
--- /dev/null
+++ b/share/vim/vim73/doc/ft_sql.txt
@@ -0,0 +1,776 @@
+*ft_sql.txt*	For Vim version 7.3.  Last change: 2010 Jul 20
+
+by David Fishburn
+
+This is a filetype plugin to work with SQL files.
+
+The Structured Query Language (SQL) is a standard which specifies statements
+that allow a user to interact with a relational database.  Vim includes
+features for navigation, indentation and syntax highlighting.
+
+1. Navigation					|sql-navigation|
+    1.1 Matchit					|sql-matchit|
+    1.2 Text Object Motions			|sql-object-motions|
+    1.3 Predefined Object Motions		|sql-predefined-objects|
+    1.4 Macros					|sql-macros|
+2. SQL Dialects					|sql-dialects|
+    2.1 SQLSetType				|SQLSetType|
+    2.2 SQLGetType				|SQLGetType|
+    2.3 SQL Dialect Default			|sql-type-default|
+3. Adding new SQL Dialects			|sql-adding-dialects|
+4. OMNI SQL Completion				|sql-completion|
+    4.1 Static mode				|sql-completion-static|
+    4.2 Dynamic mode				|sql-completion-dynamic|
+    4.3 Tutorial				|sql-completion-tutorial|
+	4.3.1 Complete Tables			|sql-completion-tables|
+	4.3.2 Complete Columns			|sql-completion-columns|
+	4.3.3 Complete Procedures		|sql-completion-procedures|
+	4.3.4 Complete Views			|sql-completion-views|
+    4.4 Completion Customization		|sql-completion-customization|
+    4.5 SQL Maps				|sql-completion-maps|
+    4.6 Using with other filetypes		|sql-completion-filetypes|
+
+==============================================================================
+1. Navigation					*sql-navigation*
+
+The SQL ftplugin provides a number of options to assist with file
+navigation.
+
+
+1.1 Matchit					*sql-matchit*
+-----------
+The matchit plugin (http://www.vim.org/scripts/script.php?script_id=39)
+provides many additional features and can be customized for different
+languages.  The matchit plugin is configured by defining a local
+buffer variable, b:match_words.  Pressing the % key while on various
+keywords will move the cursor to its match.  For example, if the cursor
+is on an "if", pressing % will cycle between the "else", "elseif" and
+"end if" keywords.
+
+The following keywords are supported: >
+    if
+    elseif | elsif
+    else [if]
+    end if
+
+    [while condition] loop
+	leave
+	break
+	continue
+	exit
+    end loop
+
+    for
+	leave
+	break
+	continue
+	exit
+    end loop
+
+    do
+	statements
+    doend
+
+    case
+    when
+    when
+    default
+    end case
+
+    merge
+    when not matched
+    when matched
+
+    create[ or replace] procedure|function|event
+    returns
+
+
+1.2 Text Object Motions				*sql-object-motions*
+-----------------------
+Vim has a number of predefined keys for working with text |object-motions|.
+This filetype plugin attempts to translate these keys to maps which make sense
+for the SQL language.
+
+The following |Normal| mode and |Visual| mode maps exist (when you edit a SQL
+file): >
+    ]]		    move forward to the next 'begin'
+    [[		    move backwards to the previous 'begin'
+    ][		    move forward to the next 'end'
+    []		    move backwards to the previous 'end'
+
+
+1.3 Predefined Object Motions			*sql-predefined-objects*
+-----------------------------
+Most relational databases support various standard features, tables, indices,
+triggers and stored procedures.  Each vendor also has a variety of proprietary
+objects.  The next set of maps have been created to help move between these
+objects.  Depends on which database vendor you are using, the list of objects
+must be configurable.  The filetype plugin attempts to define many of the
+standard objects, plus many additional ones.  In order to make this as
+flexible as possible, you can override the list of objects from within your
+|vimrc| with the following: >
+    let g:ftplugin_sql_objects = 'function,procedure,event,table,trigger' .
+		\ ',schema,service,publication,database,datatype,domain' .
+		\ ',index,subscription,synchronization,view,variable'
+
+The following |Normal| mode and |Visual| mode maps have been created which use
+the above list: >
+    ]}		    move forward to the next 'create '
+    [{		    move backward to the previous 'create '
+
+Repeatedly pressing ]} will cycle through each of these create statements: >
+    create table t1 (
+	...
+    );
+
+    create procedure p1
+    begin
+	...
+    end;
+
+    create index i1 on t1 (c1);
+
+The default setting for g:ftplugin_sql_objects is: >
+    let g:ftplugin_sql_objects = 'function,procedure,event,' .
+		\ '\\(existing\\\\|global\\s\\+temporary\\s\\+\\)\\\{,1}' .
+		\ 'table,trigger' .
+		\ ',schema,service,publication,database,datatype,domain' .
+		\ ',index,subscription,synchronization,view,variable'
+
+The above will also handle these cases: >
+    create table t1 (
+	...
+    );
+    create existing table t2 (
+	...
+    );
+    create global temporary table t3 (
+	...
+    );
+
+By default, the ftplugin only searches for CREATE statements.  You can also
+override this via your |vimrc| with the following: >
+    let g:ftplugin_sql_statements = 'create,alter'
+
+The filetype plugin defines three types of comments: >
+    1.  --
+    2.  //
+    3.  /*
+	 *
+	 */
+
+The following |Normal| mode and |Visual| mode maps have been created to work
+with comments: >
+    ]"		    move forward to the beginning of a comment
+    ["		    move forward to the end of a comment
+
+
+
+1.4 Macros					   *sql-macros*
+----------
+Vim's feature to find macro definitions, |'define'|, is supported using this
+regular expression: >
+    \c\<\(VARIABLE\|DECLARE\|IN\|OUT\|INOUT\)\>
+
+This addresses the following code: >
+    CREATE VARIABLE myVar1 INTEGER;
+
+    CREATE PROCEDURE sp_test(
+	IN myVar2 INTEGER,
+	OUT myVar3 CHAR(30),
+	INOUT myVar4 NUMERIC(20,0)
+    )
+    BEGIN
+	DECLARE myVar5 INTEGER;
+
+	SELECT c1, c2, c3
+	  INTO myVar2, myVar3, myVar4
+	  FROM T1
+	 WHERE c4 = myVar1;
+    END;
+
+Place your cursor on "myVar1" on this line: >
+	 WHERE c4 = myVar1;
+		     ^
+
+Press any of the following keys: >
+    [d
+    [D
+    [CTRL-D
+
+
+==============================================================================
+2. SQL Dialects					*sql-dialects* *sql-types*
+						*sybase* *TSQL* *Transact-SQL*
+						*sqlanywhere*
+						*oracle* *plsql* *sqlj*
+						*sqlserver*
+						*mysql* *postgresql* *psql*
+						*informix*
+
+All relational databases support SQL.  There is a portion of SQL that is
+portable across vendors (ex. CREATE TABLE, CREATE INDEX), but there is a
+great deal of vendor specific extensions to SQL.  Oracle supports the
+"CREATE OR REPLACE" syntax, column defaults specified in the CREATE TABLE
+statement and the procedural language (for stored procedures and triggers).
+
+The default Vim distribution ships with syntax highlighting based on Oracle's
+PL/SQL.  The default SQL indent script works for Oracle and SQL Anywhere.
+The default filetype plugin works for all vendors and should remain vendor
+neutral, but extendable.
+
+Vim currently has support for a variety of different vendors, currently this
+is via syntax scripts. Unfortunately, to flip between different syntax rules
+you must either create:
+    1.  New filetypes
+    2.  Custom autocmds
+    3.  Manual steps / commands
+
+The majority of people work with only one vendor's database product, it would
+be nice to specify a default in your |vimrc|.
+
+
+2.1 SQLSetType					*sqlsettype* *SQLSetType*
+--------------
+For the people that work with many different databases, it is nice to be
+able to flip between the various vendors rules (indent, syntax) on a per
+buffer basis, at any time.  The ftplugin/sql.vim file defines this function: >
+    SQLSetType
+
+Executing this function without any parameters will set the indent and syntax
+scripts back to their defaults, see |sql-type-default|.  If you have turned
+off Vi's compatibility mode, |'compatible'|, you can use the  key to
+complete the optional parameter.
+
+After typing the function name and a space, you can use the completion to
+supply a parameter.  The function takes the name of the Vim script you want to
+source.  Using the |cmdline-completion| feature, the SQLSetType function will
+search the |'runtimepath'| for all Vim scripts with a name containing 'sql'.
+This takes the guess work out of the spelling of the names.  The following are
+examples: >
+    :SQLSetType
+    :SQLSetType sqloracle
+    :SQLSetType sqlanywhere
+    :SQLSetType sqlinformix
+    :SQLSetType mysql
+
+The easiest approach is to the use  character which will first complete
+the command name (SQLSetType), after a space and another , display a list
+of available Vim script names: >
+    :SQL
+
+
+2.2 SQLGetType					*sqlgettype* *SQLGetType*
+--------------
+At anytime you can determine which SQL dialect you are using by calling the
+SQLGetType command.  The ftplugin/sql.vim file defines this function: >
+    SQLGetType
+
+This will echo: >
+    Current SQL dialect in use:sqlanywhere
+
+
+2.3 SQL Dialect Default				*sql-type-default*
+-----------------------
+As mentioned earlier, the default syntax rules for Vim is based on Oracle
+(PL/SQL).  You can override this default by placing one of the following in
+your |vimrc|: >
+    let g:sql_type_default = 'sqlanywhere'
+    let g:sql_type_default = 'sqlinformix'
+    let g:sql_type_default = 'mysql'
+
+If you added the following to your |vimrc|: >
+    let g:sql_type_default = 'sqlinformix'
+
+The next time edit a SQL file the following scripts will be automatically
+loaded by Vim: >
+    ftplugin/sql.vim
+    syntax/sqlinformix.vim
+    indent/sql.vim
+>
+Notice indent/sqlinformix.sql was not loaded.  There is no indent file
+for Informix, Vim loads the default files if the specified files does not
+exist.
+
+
+==============================================================================
+3. Adding new SQL Dialects			*sql-adding-dialects*
+
+If you begin working with a SQL dialect which does not have any customizations
+available with the default Vim distribution you can check http://www.vim.org
+to see if any customization currently exist.  If not, you can begin by cloning
+an existing script.  Read |filetype-plugins| for more details.
+
+To help identify these scripts, try to create the files with a "sql" prefix.
+If you decide you wish to create customizations for the SQLite database, you
+can create any of the following: >
+    Unix
+	~/.vim/syntax/sqlite.vim
+	~/.vim/indent/sqlite.vim
+    Windows
+	$VIM/vimfiles/syntax/sqlite.vim
+	$VIM/vimfiles/indent/sqlite.vim
+
+No changes are necessary to the SQLSetType function.  It will automatically
+pickup the new SQL files and load them when you issue the SQLSetType command.
+
+
+==============================================================================
+4. OMNI SQL Completion				*sql-completion*
+						*omni-sql-completion*
+
+Vim 7 includes a code completion interface and functions which allows plugin
+developers to build in code completion for any language.  Vim 7 includes
+code completion for the SQL language.
+
+There are two modes to the SQL completion plugin, static and dynamic.  The
+static mode populates the popups with the data generated from current syntax
+highlight rules.  The dynamic mode populates the popups with data retrieved
+directly from a database.  This includes, table lists, column lists,
+procedures names and more.
+
+4.1 Static Mode					*sql-completion-static*
+---------------
+The static popups created contain items defined by the active syntax rules
+while editing a file with a filetype of SQL.  The plugin defines (by default)
+various maps to help the user refine the list of items to be displayed.
+The defaults static maps are: >
+    imap  a :call sqlcomplete#Map('syntax')
+    imap  k :call sqlcomplete#Map('sqlKeyword')
+    imap  f :call sqlcomplete#Map('sqlFunction')
+    imap  o :call sqlcomplete#Map('sqlOption')
+    imap  T :call sqlcomplete#Map('sqlType')
+    imap  s :call sqlcomplete#Map('sqlStatement')
+
+The use of "" can be user chosen by using the following in your |.vimrc| as it 
+may not work properly on all platforms: >
+    let g:ftplugin_sql_omni_key = ''
+>
+The static maps (which are based on the syntax highlight groups) follow this
+format: >
+    imap  k :call sqlcomplete#Map('sqlKeyword')
+
+This command breaks down as: >
+    imap		   - Create an insert map
+    		   - Only for this buffer
+    k		   - Your choice of key map
+    		   - Execute one command, return to Insert mode
+    :call sqlcomplete#Map( - Allows the SQL completion plugin to perform some
+			     housekeeping functions to allow it to be used in
+			     conjunction with other completion plugins.
+			     Indicate which item you want the SQL completion
+			     plugin to complete.
+			     In this case we are asking the plugin to display
+			     items from the syntax highlight group
+			     'sqlKeyword'.
+			     You can view a list of highlight group names to
+			     choose from by executing the
+				 :syntax list
+			     command while editing a SQL file.
+    'sqlKeyword'	   - Display the items for the sqlKeyword highlight
+			     group
+    )		   - Execute the :let command
+    		   - Trigger the standard omni completion key stroke.
+			     Passing in 'sqlKeyword' instructs the SQL
+			     completion plugin to populate the popup with
+			     items from the sqlKeyword highlight group.  The
+			     plugin will also cache this result until Vim is
+			     restarted.  The syntax list is retrieved using
+			     the syntaxcomplete plugin.
+
+Using the 'syntax' keyword is a special case.  This instructs the
+syntaxcomplete plugin to retrieve all syntax items.  So this will effectively
+work for any of Vim's SQL syntax files.  At the time of writing this includes
+10 different syntax files for the different dialects of SQL (see section 3
+above, |sql-dialects|).
+
+Here are some examples of the entries which are pulled from the syntax files: >
+     All
+	 - Contains the contents of all syntax highlight groups
+     Statements
+	 - Select, Insert, Update, Delete, Create, Alter, ...
+     Functions
+	 - Min, Max, Trim, Round, Date, ...
+     Keywords
+	 - Index, Database, Having, Group, With
+     Options
+	 - Isolation_level, On_error, Qualify_owners, Fire_triggers, ...
+     Types
+	 - Integer, Char, Varchar, Date, DateTime, Timestamp, ...
+
+
+4.2 Dynamic Mode				*sql-completion-dynamic*
+----------------
+Dynamic mode populates the popups with data directly from a database.  In
+order for the dynamic feature to be enabled you must have the dbext.vim
+plugin installed, (http://vim.sourceforge.net/script.php?script_id=356).
+
+Dynamic mode is used by several features of the SQL completion plugin.
+After installing the dbext plugin see the dbext-tutorial for additional
+configuration and usage.  The dbext plugin allows the SQL completion plugin
+to display a list of tables, procedures, views and columns. >
+     Table List
+	 - All tables for all schema owners
+     Procedure List
+	 - All stored procedures for all schema owners
+     View List
+	 - All stored procedures for all schema owners
+     Column List
+	 - For the selected table, the columns that are part of the table
+
+To enable the popup, while in INSERT mode, use the following key combinations
+for each group (where  means hold the CTRL key down while pressing
+the space bar):
+     Table List		   - t
+			   -  (the default map assumes tables)
+     Stored Procedure List - p
+     View List		   - v
+     Column List	   - c
+
+     Drilling In / Out     - When viewing a popup window displaying the list
+			     of tables, you can press , this will
+			     replace the table currently highlighted with
+			     the column list for that table.
+			   - When viewing a popup window displaying the list
+			     of columns, you can press , this will
+			     replace the column list with the list of tables.
+			   - This allows you to quickly drill down into a
+			     table to view it's columns and back again.
+			   -  and  can be also be chosen via
+			     your |.vimrc| >
+                                let g:ftplugin_sql_omni_key_right = ''
+                                let g:ftplugin_sql_omni_key_left  = ''
+
+The SQL completion plugin caches various lists that are displayed in
+the popup window.  This makes the re-displaying of these lists very
+fast.  If new tables or columns are added to the database it may become
+necessary to clear the plugins cache.  The default map for this is: >
+    imap  R :call sqlcomplete#Map('ResetCache')
+
+
+4.3 SQL Tutorial				*sql-completion-tutorial*
+----------------
+
+This tutorial is designed to take you through the common features of the SQL
+completion plugin so that: >
+     a) You gain familiarity with the plugin
+     b) You are introduced to some of the more common features
+     c) Show how to customize it to your preferences
+     d) Demonstrate "Best of Use" of the plugin (easiest way to configure).
+
+First, create a new buffer: >
+     :e tutorial.sql
+
+
+Static features
+---------------
+To take you through the various lists, simply enter insert mode, hit:
+    s   (show SQL statements)
+At this point, you can page down through the list until you find "select".
+If you are familiar with the item you are looking for, for example you know
+the statement begins with the letter "s".  You can type ahead (without the
+quotes) "se" then press:
+    t
+Assuming "select" is highlighted in the popup list press  to choose
+the entry.  Now type:
+    * fra (show all syntax items)
+choose "from" from the popup list.
+
+When writing stored procedures using the "type" list is useful.  It contains
+a list of all the database supported types.  This may or may not be true
+depending on the syntax file you are using.  The SQL Anywhere syntax file
+(sqlanywhere.vim) has support for this: >
+     BEGIN
+	DECLARE customer_id T <-- Choose a type from the list
+
+
+Dynamic features
+----------------
+To take advantage of the dynamic features you must first install the
+dbext.vim plugin (http://vim.sourceforge.net/script.php?script_id=356).  It
+also comes with a tutorial.  From the SQL completion plugin's perspective,
+the main feature dbext provides is a connection to a database.  dbext
+connection profiles are the most efficient mechanism to define connection
+information.  Once connections have been setup, the SQL completion plugin
+uses the features of dbext in the background to populate the popups.
+
+What follows assumes dbext.vim has been correctly configured, a simple test
+is to run the command, :DBListTable.  If a list of tables is shown, you know
+dbext.vim is working as expected.  If not, please consult the dbext.txt
+documentation.
+
+Assuming you have followed the dbext-tutorial you can press t to
+display a list of tables.  There is a delay while dbext is creating the table
+list.  After the list is displayed press .  This will remove both the
+popup window and the table name already chosen when the list became active. >
+
+ 4.3.1 Table Completion:			*sql-completion-tables*
+
+Press t to display a list of tables from within the database you
+have connected via the dbext plugin.
+NOTE: All of the SQL completion popups support typing a prefix before pressing
+the key map.  This will limit the contents of the popup window to just items
+beginning with those characters.  >
+
+ 4.3.2 Column Completion:			*sql-completion-columns*
+
+The SQL completion plugin can also display a list of columns for particular
+tables.  The column completion is trigger via c.
+
+NOTE: The following example uses  to trigger a column list while
+      the popup window is active.  
+
+Example of using column completion:
+     - Press t again to display the list of tables.
+     - When the list is displayed in the completion window, press ,
+       this will replace the list of tables, with a list of columns for the
+       table highlighted (after the same short delay).
+     - If you press , this will again replace the column list with the
+       list of tables.  This allows you to drill into tables and column lists
+       very quickly.
+     - Press  again while the same table is highlighted.  You will
+       notice there is no delay since the column list has been cached.  If you
+       change the schema of a cached table you can press R, which
+       clears the SQL completion cache.
+     - NOTE:  and  have been designed to work while the
+       completion window is active.  If the completion popup window is
+       not active, a normal  or  will be executed.
+
+Let's look at how we can build a SQL statement dynamically.  A select statement
+requires a list of columns.  There are two ways to build a column list using
+the SQL completion plugin. >
+    One column at a time:
+<       1. After typing SELECT press t to display a list of tables.
+	2. Choose a table from the list.
+	3. Press  to display a list of columns.
+	4. Choose the column from the list and press enter.
+	5. Enter a "," and press c.  Generating a column list
+	   generally requires having the cursor on a table name.  The plugin
+	   uses this name to determine what table to retrieve the column list.
+	   In this step, since we are pressing c without the cursor
+	   on a table name the column list displayed will be for the previous
+	   table.  Choose a different column and move on.
+	6. Repeat step 5 as often as necessary. >
+    All columns for a table:
+<	1. After typing SELECT press t to display a list of tables.
+	2. Highlight the table you need the column list for.
+	3. Press  to choose the table from the list.
+	4. Press l to request a comma separated list of all columns
+	   for this table.
+	5. Based on the table name chosen in step 3, the plugin attempts to
+	   decide on a reasonable table alias.	You are then prompted to
+	   either accept of change the alias.  Press OK.
+	6. The table name is replaced with the column list of the table is
+	   replaced with the comma separate list of columns with the alias
+	   prepended to each of the columns.
+	7. Step 3 and 4 can be replaced by pressing L, which has
+	   a  embedded in the map to choose the currently highlighted
+	   table in the list.
+
+There is a special provision when writing select statements.  Consider the
+following statement: >
+     select *
+       from customer c,
+	    contact cn,
+	    department as dp,
+	    employee e,
+	    site_options so
+      where c.
+
+In INSERT mode after typing the final "c." which is an alias for the
+"customer" table, you can press either c or .  This will
+popup a list of columns for the customer table.  It does this by looking back
+to the beginning of the select statement and finding a list of the tables
+specified in the FROM clause.  In this case it notes that in the string
+"customer c", "c" is an alias for the customer table.  The optional "AS"
+keyword is also supported, "customer AS c". >
+
+
+ 4.3.3 Procedure Completion:			*sql-completion-procedures*
+
+Similar to the table list, p, will display a list of stored
+procedures stored within the database. >
+
+ 4.3.4 View Completion:				*sql-completion-views*
+
+Similar to the table list, v, will display a list of views in the
+database.
+
+
+4.4 Completion Customization			*sql-completion-customization*
+----------------------------
+
+The SQL completion plugin can be customized through various options set in
+your |vimrc|: >
+    omni_sql_no_default_maps
+<       - Default: This variable is not defined
+	- If this variable is defined, no maps are created for OMNI
+	  completion.  See |sql-completion-maps| for further discussion.
+>
+    omni_sql_use_tbl_alias
+<	- Default: a
+	- This setting is only used when generating a comma separated
+	  column list.	By default the map is l.  When generating
+	  a column list, an alias can be prepended to the beginning of each
+	  column, for example:	e.emp_id, e.emp_name.  This option has three
+	  settings: >
+		n - do not use an alias
+		d - use the default (calculated) alias
+		a - ask to confirm the alias name
+<
+	  An alias is determined following a few rules:
+	       1.  If the table name has an '_', then use it as a separator: >
+		   MY_TABLE_NAME --> MTN
+		   my_table_name --> mtn
+		   My_table_NAME --> MtN
+<	       2.  If the table name does NOT contain an '_', but DOES use
+		   mixed case then the case is used as a separator: >
+		   MyTableName --> MTN
+<	       3.  If the table name does NOT contain an '_', and does NOT
+		   use mixed case then the first letter of the table is used: >
+		   mytablename --> m
+		   MYTABLENAME --> M
+
+    omni_sql_ignorecase
+<	- Default: Current setting for 'ignorecase'
+	- Valid settings are 0 or 1.
+	- When entering a few letters before initiating completion, the list
+	  will be filtered to display only the entries which begin with the
+	  list of characters.  When this option is set to 0, the list will be
+	  filtered using case sensitivity. >
+
+    omni_sql_include_owner
+<	- Default: 0, unless dbext.vim 3.00 has been installed
+	- Valid settings are 0 or 1.
+	- When completing tables, procedure or views and using dbext.vim 3.00
+	  or higher the list of objects will also include the owner name.
+	  When completing these objects and omni_sql_include_owner is enabled
+	  the owner name will be be replaced. >
+
+    omni_sql_precache_syntax_groups
+<	- Default:
+	  ['syntax','sqlKeyword','sqlFunction','sqlOption','sqlType','sqlStatement']
+	- sqlcomplete can be used in conjunction with other completion
+	  plugins.  This is outlined at |sql-completion-filetypes|.  When the
+	  filetype is changed temporarily to SQL, the sqlcompletion plugin
+	  will cache the syntax groups listed in the List specified in this
+	  option.
+>
+
+4.5 SQL Maps					*sql-completion-maps*
+------------
+
+The default SQL maps have been described in other sections of this document in
+greater detail.  Here is a list of the maps with a brief description of each.
+
+Static Maps
+-----------
+These are maps which use populate the completion list using Vim's syntax
+highlighting rules. >
+    a
+<       - Displays all SQL syntax items. >
+    k
+<       - Displays all SQL syntax items defined as 'sqlKeyword'. >
+    f
+<       - Displays all SQL syntax items defined as 'sqlFunction. >
+    o
+<       - Displays all SQL syntax items defined as 'sqlOption'. >
+    T
+<       - Displays all SQL syntax items defined as 'sqlType'. >
+    s
+<       - Displays all SQL syntax items defined as 'sqlStatement'. >
+
+Dynamic Maps
+------------
+These are maps which use populate the completion list using the dbext.vim
+plugin. >
+    t
+<       - Displays a list of tables. >
+    p
+<       - Displays a list of procedures. >
+    v
+<       - Displays a list of views. >
+    c
+<       - Displays a list of columns for a specific table. >
+    l
+<       - Displays a comma separated list of columns for a specific table. >
+    L
+<       - Displays a comma separated list of columns for a specific table.
+	  This should only be used when the completion window is active. >
+    
+<	- Displays a list of columns for the table currently highlighted in
+	  the completion window.   is not recognized on most Unix
+	  systems, so this maps is only created on the Windows platform.
+	  If you would like the same feature on Unix, choose a different key
+	  and make the same map in your vimrc. >
+    
+<	- Displays the list of tables.
+	   is not recognized on most Unix systems, so this maps is
+	  only created on the Windows platform.  If you would like the same
+	  feature on Unix, choose a different key and make the same map in
+	  your vimrc. >
+    R
+<	- This maps removes all cached items and forces the SQL completion
+	  to regenerate the list of items.
+
+Customizing Maps
+----------------
+You can create as many additional key maps as you like.  Generally, the maps
+will be specifying different syntax highlight groups.
+
+If you do not wish the default maps created or the key choices do not work on
+your platform (often a case on *nix) you define the following variable in
+your |vimrc|: >
+    let g:omni_sql_no_default_maps = 1
+
+Do no edit ftplugin/sql.vim directly!  If you change this file your changes
+will be over written on future updates.  Vim has a special directory structure
+which allows you to make customizations without changing the files that are
+included with the Vim distribution.  If you wish to customize the maps
+create an after/ftplugin/sql.vim (see |after-directory|) and place the same
+maps from the ftplugin/sql.vim in it using your own key strokes.   was
+chosen since it will work on both Windows and *nix platforms.  On the windows
+platform you can also use  or ALT keys.
+
+
+4.6 Using with other filetypes			*sql-completion-filetypes*
+------------------------------
+
+Many times SQL can be used with different filetypes.  For example Perl, Java,
+PHP, Javascript can all interact with a database.  Often you need both the SQL
+completion and the completion capabilities for the current language you are
+editing.
+
+This can be enabled easily with the following steps (assuming a Perl file): >
+    1.  :e test.pl
+    2.  :set filetype=sql
+    3.  :set ft=perl
+
+Step 1
+------
+Begins by editing a Perl file.  Vim automatically sets the filetype to
+"perl".  By default, Vim runs the appropriate filetype file
+ftplugin/perl.vim.  If you are using the syntax completion plugin by following
+the directions at |ft-syntax-omni| then the |'omnifunc'| option has been set to
+"syntax#Complete".  Pressing  will display the omni popup containing
+the syntax items for Perl.
+
+Step 2
+------
+Manually setting the filetype to 'sql' will also fire the appropriate filetype
+files ftplugin/sql.vim.  This file will define a number of buffer specific
+maps for SQL completion, see |sql-completion-maps|.  Now these maps have
+been created and the SQL completion plugin has been initialized.  All SQL
+syntax items have been cached in preparation.  The SQL filetype script detects
+we are attempting to use two different completion plugins.  Since the SQL maps
+begin with , the maps will toggle the |'omnifunc'| when in use.  So you
+can use  to continue using the completion for Perl (using the syntax
+completion plugin) and  to use the SQL completion features.
+
+Step 3
+------
+Setting the filetype back to Perl sets all the usual "perl" related items back
+as they were.
+
+
+vim:tw=78:ts=8:ft=help:norl:
diff --git a/share/vim/vim73/doc/gui.txt b/share/vim/vim73/doc/gui.txt
new file mode 100644
index 0000000000..f9bbf78d2a
--- /dev/null
+++ b/share/vim/vim73/doc/gui.txt
@@ -0,0 +1,1001 @@
+*gui.txt*       For Vim version 7.3.  Last change: 2010 May 14
+
+
+		  VIM REFERENCE MANUAL    by Bram Moolenaar
+
+
+Vim's Graphical User Interface				*gui* *GUI*
+
+1. Starting the GUI		|gui-start|
+2. Scrollbars			|gui-scrollbars|
+3. Mouse Control		|gui-mouse|
+4. Making GUI Selections	|gui-selections|
+5. Menus			|menus|
+6. Extras			|gui-extras|
+7. Shell Commands		|gui-shell|
+
+Other GUI documentation:
+|gui_x11.txt|	For specific items of the X11 GUI.
+|gui_w32.txt|	For specific items of the Win32 GUI.
+
+{Vi does not have any of these commands}
+
+==============================================================================
+1. Starting the GUI				*gui-start* *E229* *E233*
+
+First you must make sure you actually have a version of Vim with the GUI code
+included.  You can check this with the ":version" command, it says "with xxx
+GUI", where "xxx" is X11-Motif, X11-Athena, Photon, GTK, GTK2, etc., or
+"MS-Windows 32 bit GUI version".
+
+How to start the GUI depends on the system used.  Mostly you can run the
+GUI version of Vim with:
+    gvim [options] [files...]
+
+The X11 version of Vim can run both in GUI and in non-GUI mode.  See
+|gui-x11-start|.
+
+			*gui-init* *gvimrc* *.gvimrc* *_gvimrc* *$MYGVIMRC*
+The gvimrc file is where GUI-specific startup commands should be placed.  It
+is always sourced after the |vimrc| file.  If you have one then the $MYGVIMRC
+environment variable has its name.
+
+When the GUI starts up initializations are carried out, in this order:
+- The 'term' option is set to "builtin_gui" and terminal options are reset to
+  their default value for the GUI |terminal-options|.
+- If the system menu file exists, it is sourced.  The name of this file is
+  normally "$VIMRUNTIME/menu.vim".  You can check this with ":version".  Also
+  see |$VIMRUNTIME|.  To skip loading the system menu include 'M' in
+  'guioptions'.				*buffers-menu* *no_buffers_menu*
+  The system menu file includes a "Buffers" menu.  If you don't want this, set
+  the "no_buffers_menu" variable in your .vimrc (not .gvimrc!): >
+	:let no_buffers_menu = 1
+< NOTE: Switching on syntax highlighting also loads the menu file, thus
+  disabling the Buffers menu must be done before ":syntax on".
+  The path names are truncated to 35 characters.  You can truncate them at a
+  different length, for example 50, like this: >
+	:let bmenu_max_pathlen = 50
+- If the "-U {gvimrc}" command-line option has been used when starting Vim,
+  the {gvimrc} file will be read for initializations.  The following
+  initializations are skipped.  When {gvimrc} is "NONE" no file will be read
+  for initializations.
+- For Unix and MS-Windows, if the system gvimrc exists, it is sourced.  The
+  name of this file is normally "$VIM/gvimrc".  You can check this with
+  ":version".  Also see |$VIM|.
+- The following are tried, and only the first one that exists is used:
+  - If the GVIMINIT environment variable exists and is not empty, it is
+    executed as an Ex command.
+  - If the user gvimrc file exists, it is sourced.  The name of this file is
+    normally "$HOME/.gvimrc".  You can check this with ":version".
+  - For Win32, when $HOME is not set, "$VIM\_gvimrc" is used.
+  - When a "_gvimrc" file is not found, ".gvimrc" is tried too.  And vice
+    versa.
+  The name of the first file found is stored in $MYGVIMRC, unless it was
+  already set.
+- If the 'exrc' option is set (which is NOT the default) the file ./.gvimrc
+  is sourced, if it exists and isn't the same file as the system or user
+  gvimrc file.  If this file is not owned by you, some security restrictions
+  apply.  When ".gvimrc" is not found, "_gvimrc" is tried too.  For Macintosh
+  and DOS/Win32 "_gvimrc" is tried first.
+
+NOTE: All but the first one are not carried out if Vim was started with
+"-u NONE" and no "-U" argument was given, or when started with "-U NONE".
+
+All this happens AFTER the normal Vim initializations, like reading your
+.vimrc file.  See |initialization|.
+But the GUI window is only opened after all the initializations have been
+carried out.  If you want some commands to be executed just after opening the
+GUI window, use the |GUIEnter| autocommand event.  Example: >
+	:autocmd GUIEnter * winpos 100 50
+
+You can use the gvimrc files to set up your own customized menus (see |:menu|)
+and initialize other things that you may want to set up differently from the
+terminal version.
+
+Recommended place for your personal GUI initializations:
+	Unix		    $HOME/.gvimrc
+	OS/2		    $HOME/.gvimrc or $VIM/.gvimrc
+	MS-DOS and Win32    $HOME/_gvimrc or $VIM/_gvimrc
+	Amiga		    s:.gvimrc or $VIM/.gvimrc
+
+There are a number of options which only have meaning in the GUI version of
+Vim.  These are 'guicursor', 'guifont', 'guipty' and 'guioptions'.  They are
+documented in |options.txt| with all the other options.
+
+If using the Motif or Athena version of the GUI (but not for the GTK+ or
+Win32 version), a number of X resources are available.  See |gui-resources|.
+
+Another way to set the colors for different occasions is with highlight
+groups.  The "Normal" group is used to set the background and foreground
+colors.  Example (which looks nice): >
+
+	:highlight Normal guibg=grey90
+
+The "guibg" and "guifg" settings override the normal background and
+foreground settings.  The other settings for the Normal highlight group are
+not used.  Use the 'guifont' option to set the font.
+
+Also check out the 'guicursor' option, to set the colors for the cursor in
+various modes.
+
+Vim tries to make the window fit on the screen when it starts up.  This avoids
+that you can't see part of it.  On the X Window System this requires a bit of
+guesswork.  You can change the height that is used for the window title and a
+task bar with the 'guiheadroom' option.
+
+						*:winp* *:winpos* *E188*
+:winp[os]
+		Display current position of the top left corner of the GUI vim
+		window in pixels.  Does not work in all versions.
+
+:winp[os] {X} {Y}							*E466*
+		Put the GUI vim window at the given {X} and {Y} coordinates.
+		The coordinates should specify the position in pixels of the
+		top left corner of the window.  Does not work in all versions.
+		Does work in an (new) xterm |xterm-color|.
+		When the GUI window has not been opened yet, the values are
+		remembered until the window is opened.  The position is
+		adjusted to make the window fit on the screen (if possible).
+
+						    *:win* *:winsize* *E465*
+:win[size] {width} {height}
+		Set the window height to {width} by {height} characters.
+		Obsolete, use ":set lines=11 columns=22".
+		If you get less lines than expected, check the 'guiheadroom'
+		option.
+
+If you are running the X Window System, you can get information about the
+window Vim is running in with this command: >
+	:!xwininfo -id $WINDOWID
+
+==============================================================================
+2. Scrollbars						*gui-scrollbars*
+
+There are vertical scrollbars and a horizontal scrollbar.  You may
+configure which ones appear with the 'guioptions' option.
+
+The interface looks like this (with ":set guioptions=mlrb"):
+
+		       +------------------------------+
+		       | File  Edit		 Help | <- Menu bar (m)
+		       +-+--------------------------+-+
+		       |^|			    |^|
+		       |#| Text area.		    |#|
+		       | |			    | |
+		       |v|__________________________|v|
+ Normal status line -> |-+ File.c	       5,2  +-|
+ between Vim windows   |^|""""""""""""""""""""""""""|^|
+		       | |			    | |
+		       | | Another file buffer.     | |
+		       | |			    | |
+		       |#|			    |#|
+ Left scrollbar (l) -> |#|			    |#| <- Right
+		       |#|			    |#|    scrollbar (r)
+		       | |			    | |
+		       |v|			    |v|
+		       +-+--------------------------+-+
+		       | |< ####		   >| | <- Bottom
+		       +-+--------------------------+-+    scrollbar (b)
+
+Any of the scrollbar or menu components may be turned off by not putting the
+appropriate letter in the 'guioptions' string.  The bottom scrollbar is
+only useful when 'nowrap' is set.
+
+
+VERTICAL SCROLLBARS					*gui-vert-scroll*
+
+Each Vim window has a scrollbar next to it which may be scrolled up and down
+to move through the text in that buffer.  The size of the scrollbar-thumb
+indicates the fraction of the buffer which can be seen in the window.
+When the scrollbar is dragged all the way down, the last line of the file
+will appear in the top of the window.
+
+If a window is shrunk to zero height (by the growth of another window) its
+scrollbar disappears.  It reappears when the window is restored.
+
+If a window is vertically split, it will get a scrollbar when it is the
+current window and when, taking the middle of the current window and drawing a
+vertical line, this line goes through the window.
+When there are scrollbars on both sides, and the middle of the current window
+is on the left half, the right scrollbar column will contain scrollbars for
+the rightmost windows.  The same happens on the other side.
+
+
+HORIZONTAL SCROLLBARS					*gui-horiz-scroll*
+
+The horizontal scrollbar (at the bottom of the Vim GUI) may be used to
+scroll text sideways when the 'wrap' option is turned off.  The
+scrollbar-thumb size is such that the text of the longest visible line may be
+scrolled as far as possible left and right.  The cursor is moved when
+necessary, it must remain on a visible character (unless 'virtualedit' is
+set).
+
+Computing the length of the longest visible line takes quite a bit of
+computation, and it has to be done every time something changes.  If this
+takes too much time or you don't like the cursor jumping to another line,
+include the 'h' flag in 'guioptions'.  Then the scrolling is limited by the
+text of the current cursor line.
+
+							*athena-intellimouse*
+If you have an Intellimouse and an X server that supports using the wheel,
+then you can use the wheel to scroll the text up and down in gvim.  This works
+with XFree86 4.0 and later, and with some older versions when you add patches.
+See |scroll-mouse-wheel|.
+
+For older versions of XFree86 you must patch your X server.  The following
+page has a bit of information about using the Intellimouse on Linux as well as
+links to the patches and X server binaries (may not have the one you need
+though):
+    http://www.inria.fr/koala/colas/mouse-wheel-scroll/
+
+==============================================================================
+3. Mouse Control					*gui-mouse*
+
+The mouse only works if the appropriate flag in the 'mouse' option is set.
+When the GUI is switched on, and 'mouse' wasn't set yet, the 'mouse' option is
+automatically set to "a", enabling it for all modes except for the
+|hit-enter| prompt.  If you don't want this, a good place to change the
+'mouse' option is the "gvimrc" file.
+
+Other options that are relevant:
+'mousefocus'	window focus follows mouse pointer |gui-mouse-focus|
+'mousemodel'	what mouse button does which action
+'mousehide'	hide mouse pointer while typing text
+'selectmode'	whether to start Select mode or Visual mode
+
+A quick way to set these is with the ":behave" command.
+							*:behave* *:be*
+:be[have] {model}	Set behavior for mouse and selection.  Valid
+			arguments are:
+			   mswin	MS-Windows behavior
+			   xterm	Xterm behavior
+
+			Using ":behave" changes these options:
+			option		mswin			xterm	~
+			'selectmode'	"mouse,key"		""
+			'mousemodel'	"popup"			"extend"
+			'keymodel'	"startsel,stopsel"	""
+			'selection'	"exclusive"		"inclusive"
+
+In the $VIMRUNTIME directory, there is a script called |mswin.vim|, which will
+also map a few keys to the MS-Windows cut/copy/paste commands.  This is NOT
+compatible, since it uses the CTRL-V, CTRL-X and CTRL-C keys.  If you don't
+mind, use this command: >
+	:so $VIMRUNTIME/mswin.vim
+
+For scrolling with a wheel on a mouse, see |scroll-mouse-wheel|.
+
+
+3.1 Moving Cursor with Mouse				*gui-mouse-move*
+
+Click the left mouse button somewhere in a text buffer where you want the
+cursor to go, and it does!
+This works in	    when 'mouse' contains ~
+Normal mode	    'n' or 'a'
+Visual mode	    'v' or 'a'
+Insert mode	    'i' or 'a'
+
+Select mode is handled like Visual mode.
+
+You may use this with an operator such as 'd' to delete text from the current
+cursor position to the position you point to with the mouse.  That is, you hit
+'d' and then click the mouse somewhere.
+
+							*gui-mouse-focus*
+The 'mousefocus' option can be set to make the keyboard focus follow the
+mouse pointer.  This means that the window where the mouse pointer is, is the
+active window.  Warning: this doesn't work very well when using a menu,
+because the menu command will always be applied to the top window.
+
+If you are on the ':' line (or '/' or '?'), then clicking the left or right
+mouse button will position the cursor on the ':' line (if 'mouse' contains
+'c', 'a' or 'A').
+
+In any situation the middle mouse button may be clicked to paste the current
+selection.
+
+
+3.2 Selection with Mouse				*gui-mouse-select*
+
+The mouse can be used to start a selection.  How depends on the 'mousemodel'
+option:
+'mousemodel' is "extend": use the right mouse button
+'mousemodel' is "popup":  use the left mouse button, while keeping the Shift
+key pressed.
+
+If there was no selection yet, this starts a selection from the old cursor
+position to the position pointed to with the mouse.  If there already is a
+selection then the closest end will be extended.
+
+If 'selectmode' contains "mouse", then the selection will be in Select mode.
+This means that typing normal text will replace the selection.  See
+|Select-mode|.  Otherwise, the selection will be in Visual mode.
+
+Double clicking may be done to make the selection word-wise, triple clicking
+makes it line-wise, and quadruple clicking makes it rectangular block-wise.
+
+See |gui-selections| on how the selection is used.
+
+
+3.3 Other Text Selection with Mouse		*gui-mouse-modeless*
+						*modeless-selection*
+A different kind of selection is used when:
+- in Command-line mode
+- in the Command-line window and pointing in another window
+- at the |hit-enter| prompt
+- whenever the current mode is not in the 'mouse' option
+- when holding the CTRL and SHIFT keys in the GUI
+
+Since Vim continues like the selection isn't there, and there is no mode
+associated with the selection, this is called modeless selection.  Any text in
+the Vim window can be selected.  Select the text by pressing the left mouse
+button at the start, drag to the end and release.  To extend the selection,
+use the right mouse button when 'mousemodel' is "extend", or the left mouse
+button with the shift key pressed when 'mousemodel' is "popup".
+The selection is removed when the selected text is scrolled or changed.
+
+On the command line CTRL-Y can be used to copy the selection into the
+clipboard.  To do this from Insert mode, use CTRL-O : CTRL-Y .  When
+'guioptions' contains a or A (default on X11), the selection is automatically
+copied to the "* register.
+
+The middle mouse button can then paste the text.  On non-X11 systems, you can
+use CTRL-R +.
+
+
+3.4 Using Mouse on Status Lines				*gui-mouse-status*
+
+Clicking the left or right mouse button on the status line below a Vim
+window makes that window the current window.  This actually happens on button
+release (to be able to distinguish a click from a drag action).
+
+With the left mouse button a status line can be dragged up and down, thus
+resizing the windows above and below it.  This does not change window focus.
+
+The same can be used on the vertical separator: click to give the window left
+of it focus, drag left and right to make windows wider and narrower.
+
+
+3.5 Various Mouse Clicks				*gui-mouse-various*
+
+    	Search forward for the word under the mouse click.
+			When 'mousemodel' is "popup" this starts or extends a
+			selection.
+    	Search backward for the word under the mouse click.
+    	Jump to the tag name under the mouse click.
+    	Jump back to position before the previous tag jump
+			(same as "CTRL-T")
+
+
+3.6 Mouse Mappings					*gui-mouse-mapping*
+
+The mouse events, complete with modifiers, may be mapped.  Eg: >
+   :map      
+   :map       
+   :map    
+   :map <2-S-LeftMouse>   <2-RightMouse>
+   :map <2-S-LeftDrag>    <2-RightDrag>
+   :map <2-S-LeftRelease> <2-RightRelease>
+   :map <3-S-LeftMouse>   <3-RightMouse>
+   :map <3-S-LeftDrag>    <3-RightDrag>
+   :map <3-S-LeftRelease> <3-RightRelease>
+   :map <4-S-LeftMouse>   <4-RightMouse>
+   :map <4-S-LeftDrag>    <4-RightDrag>
+   :map <4-S-LeftRelease> <4-RightRelease>
+These mappings make selection work the way it probably should in a Motif
+application, with shift-left mouse allowing for extending the visual area
+rather than the right mouse button.
+
+Mouse mapping with modifiers does not work for modeless selection.
+
+
+3.7 Drag and drop						*drag-n-drop*
+
+You can drag and drop one or more files into the Vim window, where they will
+be opened as if a |:drop| command was used.
+
+If you hold down Shift while doing this, Vim changes to the first dropped
+file's directory.  If you hold Ctrl Vim will always split a new window for the
+file.  Otherwise it's only done if the current buffer has been changed.
+
+You can also drop a directory on Vim.  This starts the explorer plugin for
+that directory (assuming it was enabled, otherwise you'll get an error
+message).  Keep Shift pressed to change to the directory instead.
+
+If Vim happens to be editing a command line, the names of the dropped files
+and directories will be inserted at the cursor.  This allows you to use these
+names with any Ex command.  Special characters (space, tab, double quote and
+'|'; backslash on non-MS-Windows systems) will be escaped.
+
+==============================================================================
+4. Making GUI Selections				*gui-selections*
+
+							*quotestar*
+You may make selections with the mouse (see |gui-mouse-select|), or by using
+Vim's Visual mode (see |v|).  If 'a' is present in 'guioptions', then
+whenever a selection is started (Visual or Select mode), or when the selection
+is changed, Vim becomes the owner of the windowing system's primary selection
+(on MS-Windows the |gui-clipboard| is used; under X11, the |x11-selection| is
+used - you should read whichever of these is appropriate now).
+
+							*clipboard*
+There is a special register for storing this selection, it is the "*
+register.  Nothing is put in here unless the information about what text is
+selected is about to change (e.g. with a left mouse click somewhere), or when
+another application wants to paste the selected text.  Then the text is put
+in the "* register.  For example, to cut a line and make it the current
+selection/put it on the clipboard: >
+
+	"*dd
+
+Similarly, when you want to paste a selection from another application, e.g.,
+by clicking the middle mouse button, the selection is put in the "* register
+first, and then 'put' like any other register.  For example, to put the
+selection (contents of the clipboard): >
+
+	"*p
+
+When using this register under X11, also see |x11-selection|.  This also
+explains the related "+ register.
+
+Note that when pasting text from one Vim into another separate Vim, the type
+of selection (character, line, or block) will also be copied.  For other
+applications the type is always character.  However, if the text gets
+transferred via the |x11-cut-buffer|, the selection type is ALWAYS lost.
+
+When the "unnamed" string is included in the 'clipboard' option, the unnamed
+register is the same as the "* register.  Thus you can yank to and paste the
+selection without prepending "* to commands.
+
+==============================================================================
+5. Menus						*menus*
+
+For an introduction see |usr_42.txt| in the user manual.
+
+
+5.1 Using Menus						*using-menus*
+
+Basically, menus can be used just like mappings.  You can define your own
+menus, as many as you like.
+Long-time Vim users won't use menus much.  But the power is in adding your own
+menus and menu items.  They are most useful for things that you can't remember
+what the key sequence was.
+
+For creating menus in a different language, see |:menutrans|.
+
+							*menu.vim*
+The default menus are read from the file "$VIMRUNTIME/menu.vim".  See
+|$VIMRUNTIME| for where the path comes from.  You can set up your own menus.
+Starting off with the default set is a good idea.  You can add more items, or,
+if you don't like the defaults at all, start with removing all menus
+|:unmenu-all|.  You can also avoid the default menus being loaded by adding
+this line to your .vimrc file (NOT your .gvimrc file!): >
+	:let did_install_default_menus = 1
+If you also want to avoid the Syntax menu: >
+	:let did_install_syntax_menu = 1
+The first item in the Syntax menu can be used to show all available filetypes
+in the menu (which can take a bit of time to load).  If you want to have all
+filetypes already present at startup, add: >
+	:let do_syntax_sel_menu = 1
+
+<
+							*console-menus*
+Although this documentation is in the GUI section, you can actually use menus
+in console mode too.  You will have to load |menu.vim| explicitly then, it is
+not done by default.  You can use the |:emenu| command and command-line
+completion with 'wildmenu' to access the menu entries almost like a real menu
+system.  To do this, put these commands in your .vimrc file: >
+	:source $VIMRUNTIME/menu.vim
+	:set wildmenu
+	:set cpo-=<
+	:set wcm=
+	:map  :emenu 
+Pressing  will start the menu.  You can now use the cursor keys to select
+a menu entry.  Hit  to execute it.  Hit  if you want to cancel.
+This does require the |+menu| feature enabled at compile time.
+
+							*tear-off-menus*
+GTK+ and Motif support Tear-off menus.  These are sort of sticky menus or
+pop-up menus that are present all the time.  If the resizing does not work
+correctly, this may be caused by using something like "Vim*geometry" in the
+defaults.  Use "Vim.geometry" instead.
+
+The Win32 GUI version emulates Motif's tear-off menus.  Actually, a Motif user
+will spot the differences easily, but hopefully they're just as useful.  You
+can also use the |:tearoff| command together with |hidden-menus| to create
+floating menus that do not appear on the main menu bar.
+
+
+5.2 Creating New Menus					*creating-menus*
+
+				*:me*  *:menu*  *:noreme*  *:noremenu*
+				*:am*  *:amenu* *:an*      *:anoremenu*
+				*:nme* *:nmenu* *:nnoreme* *:nnoremenu*
+				*:ome* *:omenu* *:onoreme* *:onoremenu*
+				*:vme* *:vmenu* *:vnoreme* *:vnoremenu*
+				*:xme* *:xmenu* *:xnoreme* *:xnoremenu*
+				*:sme* *:smenu* *:snoreme* *:snoremenu*
+				*:ime* *:imenu* *:inoreme* *:inoremenu*
+				*:cme* *:cmenu* *:cnoreme* *:cnoremenu*
+				*E330* *E327* *E331* *E336* *E333*
+				*E328* *E329* *E337* *E792*
+To create a new menu item, use the ":menu" commands.  They are mostly like
+the ":map" set of commands but the first argument is a menu item name, given
+as a path of menus and submenus with a '.' between them, e.g.: >
+
+   :menu File.Save  :w
+   :inoremenu File.Save  :w
+   :menu Edit.Big\ Changes.Delete\ All\ Spaces  :%s/[ ^I]//g
+
+This last one will create a new item in the menu bar called "Edit", holding
+the mouse button down on this will pop up a menu containing the item
+"Big Changes", which is a sub-menu containing the item "Delete All Spaces",
+which when selected, performs the operation.
+
+Special characters in a menu name:
+
+	&	The next character is the shortcut key.  Make sure each
+		shortcut key is only used once in a (sub)menu.  If you want to
+		insert a literal "&" in the menu name use "&&".
+		Separates the menu name from right-aligned text.  This can be
+		used to show the equivalent typed command.  The text ""
+		can be used here for convenience.  If you are using a real
+		tab, don't forget to put a backslash before it!
+Example: >
+
+   :amenu &File.&Open:e  :browse e
+
+[typed literally]
+With the shortcut "F" (while keeping the  key pressed), and then "O",
+this menu can be used.  The second part is shown as "Open     :e".  The ":e"
+is right aligned, and the "O" is underlined, to indicate it is the shortcut.
+
+The ":amenu" command can be used to define menu entries for all modes at once.
+To make the command work correctly, a character is automatically inserted for
+some modes:
+	mode		inserted	appended	~
+	Normal		nothing		nothing
+	Visual				
+	Insert		
+	Cmdline				
+	Op-pending			
+
+Appending CTRL-\ CTRL-G is for going back to insert mode when 'insertmode' is
+set. |CTRL-\_CTRL-G|
+
+Example: >
+
+   :amenu File.Next	:next^M
+
+is equal to: >
+
+   :nmenu File.Next	:next^M
+   :vmenu File.Next	^C:next^M^\^G
+   :imenu File.Next	^\^O:next^M
+   :cmenu File.Next	^C:next^M^\^G
+   :omenu File.Next	^C:next^M^\^G
+
+Careful: In Insert mode this only works for a SINGLE Normal mode command,
+because of the CTRL-O.  If you have two or more commands, you will need to use
+the ":imenu" command.  For inserting text in any mode, you can use the
+expression register: >
+
+   :amenu Insert.foobar   "='foobar'P
+
+Note that the '<' and 'k' flags in 'cpoptions' also apply here (when
+included they make the <> form and raw key codes not being recognized).
+
+Note that  in Cmdline mode executes the command, like in a mapping.  This
+is Vi compatible.  Use CTRL-C to quit Cmdline mode.
+
+						*:menu-* *:menu-silent*
+To define a menu which will not be echoed on the command line, add
+"" as the first argument.  Example: >
+	:menu  Settings.Ignore\ case  :set ic
+The ":set ic" will not be echoed when using this menu.  Messages from the
+executed command are still given though.  To shut them up too, add a ":silent"
+in the executed command: >
+	:menu  Search.Header :exe ":silent normal /Header\r"
+"" may also appear just after "" or "
+
+See |mysyntaxfile-add| for installing script languages permanently.
+
+
+APACHE						*apache.vim* *ft-apache-syntax*
+
+The apache syntax file provides syntax highlighting depending on Apache HTTP
+server version, by default for 1.3.x.  Set "apache_version" to Apache version
+(as a string) to get highlighting for another version.	Example: >
+
+	:let apache_version = "2.0"
+<
+
+		*asm.vim* *asmh8300.vim* *nasm.vim* *masm.vim* *asm68k*
+ASSEMBLY	*ft-asm-syntax* *ft-asmh8300-syntax* *ft-nasm-syntax*
+		*ft-masm-syntax* *ft-asm68k-syntax* *fasm.vim*
+
+Files matching "*.i" could be Progress or Assembly.  If the automatic detection
+doesn't work for you, or you don't edit Progress at all, use this in your
+startup vimrc: >
+   :let filetype_i = "asm"
+Replace "asm" with the type of assembly you use.
+
+There are many types of assembly languages that all use the same file name
+extensions.  Therefore you will have to select the type yourself, or add a
+line in the assembly file that Vim will recognize.  Currently these syntax
+files are included:
+	asm		GNU assembly (the default)
+	asm68k		Motorola 680x0 assembly
+	asmh8300	Hitachi H-8300 version of GNU assembly
+	ia64		Intel Itanium 64
+	fasm		Flat assembly (http://flatassembler.net)
+	masm		Microsoft assembly (probably works for any 80x86)
+	nasm		Netwide assembly
+	tasm		Turbo Assembly (with opcodes 80x86 up to Pentium, and
+			MMX)
+	pic		PIC assembly (currently for PIC16F84)
+
+The most flexible is to add a line in your assembly file containing: >
+	asmsyntax=nasm
+Replace "nasm" with the name of the real assembly syntax.  This line must be
+one of the first five lines in the file.  No non-white text must be
+immediately before or after this text.
+
+The syntax type can always be overruled for a specific buffer by setting the
+b:asmsyntax variable: >
+	:let b:asmsyntax = "nasm"
+
+If b:asmsyntax is not set, either automatically or by hand, then the value of
+the global variable asmsyntax is used.	This can be seen as a default assembly
+language: >
+	:let asmsyntax = "nasm"
+
+As a last resort, if nothing is defined, the "asm" syntax is used.
+
+
+Netwide assembler (nasm.vim) optional highlighting ~
+
+To enable a feature: >
+	:let   {variable}=1|set syntax=nasm
+To disable a feature: >
+	:unlet {variable}  |set syntax=nasm
+
+Variable		Highlight ~
+nasm_loose_syntax	unofficial parser allowed syntax not as Error
+			  (parser dependent; not recommended)
+nasm_ctx_outside_macro	contexts outside macro not as Error
+nasm_no_warn		potentially risky syntax not as ToDo
+
+
+ASPPERL and ASPVBS			*ft-aspperl-syntax* *ft-aspvbs-syntax*
+
+*.asp and *.asa files could be either Perl or Visual Basic script.  Since it's
+hard to detect this you can set two global variables to tell Vim what you are
+using.	For Perl script use: >
+	:let g:filetype_asa = "aspperl"
+	:let g:filetype_asp = "aspperl"
+For Visual Basic use: >
+	:let g:filetype_asa = "aspvbs"
+	:let g:filetype_asp = "aspvbs"
+
+
+BAAN						    *baan.vim* *baan-syntax*
+
+The baan.vim gives syntax support for BaanC of release BaanIV upto SSA ERP LN
+for both 3 GL and 4 GL programming. Large number of standard defines/constants
+are supported.
+
+Some special violation of coding standards will be signalled when one specify
+in ones |.vimrc|: >
+	let baan_code_stds=1
+
+*baan-folding*
+
+Syntax folding can be enabled at various levels through the variables
+mentioned below (Set those in your |.vimrc|). The more complex folding on
+source blocks and SQL can be CPU intensive.
+
+To allow any folding and enable folding at function level use: >
+	let baan_fold=1
+Folding can be enabled at source block level as if, while, for ,... The
+indentation preceding the begin/end keywords has to match (spaces are not
+considered equal to a tab). >
+	let baan_fold_block=1
+Folding can be enabled for embedded SQL blocks as SELECT, SELECTDO,
+SELECTEMPTY, ... The indentation preceding the begin/end keywords has to
+match (spaces are not considered equal to a tab). >
+	let baan_fold_sql=1
+Note: Block folding can result in many small folds. It is suggested to |:set|
+the options 'foldminlines' and 'foldnestmax' in |.vimrc| or use |:setlocal| in
+.../after/syntax/baan.vim (see |after-directory|). Eg: >
+	set foldminlines=5
+	set foldnestmax=6
+
+
+BASIC			*basic.vim* *vb.vim* *ft-basic-syntax* *ft-vb-syntax*
+
+Both Visual Basic and "normal" basic use the extension ".bas".	To detect
+which one should be used, Vim checks for the string "VB_Name" in the first
+five lines of the file.  If it is not found, filetype will be "basic",
+otherwise "vb".  Files with the ".frm" extension will always be seen as Visual
+Basic.
+
+
+C							*c.vim* *ft-c-syntax*
+
+A few things in C highlighting are optional.  To enable them assign any value
+to the respective variable.  Example: >
+	:let c_comment_strings = 1
+To disable them use ":unlet".  Example: >
+	:unlet c_comment_strings
+
+Variable		Highlight ~
+c_gnu			GNU gcc specific items
+c_comment_strings	strings and numbers inside a comment
+c_space_errors		trailing white space and spaces before a 
+c_no_trail_space_error	 ... but no trailing spaces
+c_no_tab_space_error	 ... but no spaces before a 
+c_no_bracket_error	don't highlight {}; inside [] as errors
+c_no_curly_error	don't highlight {}; inside [] and () as errors;
+				except { and } in first column
+c_curly_error		highlight a missing }; this forces syncing from the
+			start of the file, can be slow
+c_no_ansi		don't do standard ANSI types and constants
+c_ansi_typedefs		 ... but do standard ANSI types
+c_ansi_constants	 ... but do standard ANSI constants
+c_no_utf		don't highlight \u and \U in strings
+c_syntax_for_h		use C syntax for *.h files, instead of C++
+c_no_if0		don't highlight "#if 0" blocks as comments
+c_no_cformat		don't highlight %-formats in strings
+c_no_c99		don't highlight C99 standard items
+
+When 'foldmethod' is set to "syntax" then /* */ comments and { } blocks will
+become a fold.  If you don't want comments to become a fold use: >
+	:let c_no_comment_fold = 1
+"#if 0" blocks are also folded, unless: >
+	:let c_no_if0_fold = 1
+
+If you notice highlighting errors while scrolling backwards, which are fixed
+when redrawing with CTRL-L, try setting the "c_minlines" internal variable
+to a larger number: >
+	:let c_minlines = 100
+This will make the syntax synchronization start 100 lines before the first
+displayed line.  The default value is 50 (15 when c_no_if0 is set).  The
+disadvantage of using a larger number is that redrawing can become slow.
+
+When using the "#if 0" / "#endif" comment highlighting, notice that this only
+works when the "#if 0" is within "c_minlines" from the top of the window.  If
+you have a long "#if 0" construct it will not be highlighted correctly.
+
+To match extra items in comments, use the cCommentGroup cluster.
+Example: >
+   :au Syntax c call MyCadd()
+   :function MyCadd()
+   :  syn keyword cMyItem contained Ni
+   :  syn cluster cCommentGroup add=cMyItem
+   :  hi link cMyItem Title
+   :endfun
+
+ANSI constants will be highlighted with the "cConstant" group.	This includes
+"NULL", "SIG_IGN" and others.  But not "TRUE", for example, because this is
+not in the ANSI standard.  If you find this confusing, remove the cConstant
+highlighting: >
+	:hi link cConstant NONE
+
+If you see '{' and '}' highlighted as an error where they are OK, reset the
+highlighting for cErrInParen and cErrInBracket.
+
+If you want to use folding in your C files, you can add these lines in a file
+in the "after" directory in 'runtimepath'.  For Unix this would be
+~/.vim/after/syntax/c.vim. >
+    syn sync fromstart
+    set foldmethod=syntax
+
+CH						*ch.vim* *ft-ch-syntax*
+
+C/C++ interpreter.  Ch has similar syntax highlighting to C and builds upon
+the C syntax file.  See |c.vim| for all the settings that are available for C.
+
+By setting a variable you can tell Vim to use Ch syntax for *.h files, instead
+of C or C++: >
+	:let ch_syntax_for_h = 1
+
+
+CHILL						*chill.vim* *ft-chill-syntax*
+
+Chill syntax highlighting is similar to C.  See |c.vim| for all the settings
+that are available.  Additionally there is:
+
+chill_space_errors	like c_space_errors
+chill_comment_string	like c_comment_strings
+chill_minlines		like c_minlines
+
+
+CHANGELOG				*changelog.vim* *ft-changelog-syntax*
+
+ChangeLog supports highlighting spaces at the start of a line.
+If you do not like this, add following line to your .vimrc: >
+	let g:changelog_spacing_errors = 0
+This works the next time you edit a changelog file.  You can also use
+"b:changelog_spacing_errors" to set this per buffer (before loading the syntax
+file).
+
+You can change the highlighting used, e.g., to flag the spaces as an error: >
+	:hi link ChangelogError Error
+Or to avoid the highlighting: >
+	:hi link ChangelogError NONE
+This works immediately.
+
+
+COBOL						*cobol.vim* *ft-cobol-syntax*
+
+COBOL highlighting has different needs for legacy code than it does for fresh
+development.  This is due to differences in what is being done (maintenance
+versus development) and other factors.	To enable legacy code highlighting,
+add this line to your .vimrc: >
+	:let cobol_legacy_code = 1
+To disable it again, use this: >
+	:unlet cobol_legacy_code
+
+
+COLD FUSION			*coldfusion.vim* *ft-coldfusion-syntax*
+
+The ColdFusion has its own version of HTML comments.  To turn on ColdFusion
+comment highlighting, add the following line to your startup file: >
+
+	:let html_wrong_comments = 1
+
+The ColdFusion syntax file is based on the HTML syntax file.
+
+
+CSH						*csh.vim* *ft-csh-syntax*
+
+This covers the shell named "csh".  Note that on some systems tcsh is actually
+used.
+
+Detecting whether a file is csh or tcsh is notoriously hard.  Some systems
+symlink /bin/csh to /bin/tcsh, making it almost impossible to distinguish
+between csh and tcsh.  In case VIM guesses wrong you can set the
+"filetype_csh" variable.  For using csh: >
+
+	:let filetype_csh = "csh"
+
+For using tcsh: >
+
+	:let filetype_csh = "tcsh"
+
+Any script with a tcsh extension or a standard tcsh filename (.tcshrc,
+tcsh.tcshrc, tcsh.login) will have filetype tcsh.  All other tcsh/csh scripts
+will be classified as tcsh, UNLESS the "filetype_csh" variable exists.  If the
+"filetype_csh" variable exists, the filetype will be set to the value of the
+variable.
+
+
+CYNLIB						*cynlib.vim* *ft-cynlib-syntax*
+
+Cynlib files are C++ files that use the Cynlib class library to enable
+hardware modelling and simulation using C++.  Typically Cynlib files have a .cc
+or a .cpp extension, which makes it very difficult to distinguish them from a
+normal C++ file.  Thus, to enable Cynlib highlighting for .cc files, add this
+line to your .vimrc file: >
+
+	:let cynlib_cyntax_for_cc=1
+
+Similarly for cpp files (this extension is only usually used in Windows) >
+
+	:let cynlib_cyntax_for_cpp=1
+
+To disable these again, use this: >
+
+	:unlet cynlib_cyntax_for_cc
+	:unlet cynlib_cyntax_for_cpp
+<
+
+CWEB						*cweb.vim* *ft-cweb-syntax*
+
+Files matching "*.w" could be Progress or cweb.  If the automatic detection
+doesn't work for you, or you don't edit Progress at all, use this in your
+startup vimrc: >
+   :let filetype_w = "cweb"
+
+
+DESKTOP					   *desktop.vim* *ft-desktop-syntax*
+
+Primary goal of this syntax file is to highlight .desktop and .directory files
+according to freedesktop.org standard:
+http://standards.freedesktop.org/desktop-entry-spec/latest/
+But actually almost none implements this standard fully.  Thus it will
+highlight all Unix ini files.  But you can force strict highlighting according
+to standard by placing this in your vimrc file: >
+	:let enforce_freedesktop_standard = 1
+
+
+DIRCOLORS			       *dircolors.vim* *ft-dircolors-syntax*
+
+The dircolors utility highlighting definition has one option.  It exists to
+provide compatibility with the Slackware GNU/Linux distributions version of
+the command.  It adds a few keywords that are generally ignored by most
+versions.  On Slackware systems, however, the utility accepts the keywords and
+uses them for processing.  To enable the Slackware keywords add the following
+line to your startup file: >
+	let dircolors_is_slackware = 1
+
+
+DOCBOOK					*docbk.vim* *ft-docbk-syntax* *docbook*
+DOCBOOK	XML				*docbkxml.vim* *ft-docbkxml-syntax*
+DOCBOOK	SGML				*docbksgml.vim* *ft-docbksgml-syntax*
+
+There are two types of DocBook files: SGML and XML.  To specify what type you
+are using the "b:docbk_type" variable should be set.  Vim does this for you
+automatically if it can recognize the type.  When Vim can't guess it the type
+defaults to XML.
+You can set the type manually: >
+	:let docbk_type = "sgml"
+or: >
+	:let docbk_type = "xml"
+You need to do this before loading the syntax file, which is complicated.
+Simpler is setting the filetype to "docbkxml" or "docbksgml": >
+	:set filetype=docbksgml
+or: >
+	:set filetype=docbkxml
+
+
+DOSBATCH				*dosbatch.vim* *ft-dosbatch-syntax*
+
+There is one option with highlighting DOS batch files.	This covers new
+extensions to the Command Interpreter introduced with Windows 2000 and
+is controlled by the variable dosbatch_cmdextversion.  For Windows NT
+this should have the value 1, and for Windows 2000 it should be 2.
+Select the version you want with the following line: >
+
+   :let dosbatch_cmdextversion = 1
+
+If this variable is not defined it defaults to a value of 2 to support
+Windows 2000.
+
+A second option covers whether *.btm files should be detected as type
+"dosbatch" (MS-DOS batch files) or type "btm" (4DOS batch files).  The latter
+is used by default.  You may select the former with the following line: >
+
+   :let g:dosbatch_syntax_for_btm = 1
+
+If this variable is undefined or zero, btm syntax is selected.
+
+
+DOXYGEN						*doxygen.vim* *doxygen-syntax*
+
+Doxygen generates code documentation using a special documentation format
+(similar to Javadoc).  This syntax script adds doxygen highlighting to c, cpp,
+idl and php files, and should also work with java.
+
+There are a few of ways to turn on doxygen formatting. It can be done
+explicitly or in a modeline by appending '.doxygen' to the syntax of the file.
+Example: >
+	:set syntax=c.doxygen
+or >
+	// vim:syntax=c.doxygen
+
+It can also be done automatically for C, C++, C# and IDL files by setting the
+global or buffer-local variable load_doxygen_syntax.  This is done by adding
+the following to your .vimrc. >
+	:let g:load_doxygen_syntax=1
+
+There are a couple of variables that have an effect on syntax highlighting, and
+are to do with non-standard highlighting options.
+
+Variable			Default	Effect ~
+g:doxygen_enhanced_color
+g:doxygen_enhanced_colour	0	Use non-standard highlighting for
+					doxygen comments.
+
+doxygen_my_rendering		0	Disable rendering of HTML bold, italic
+					and html_my_rendering underline.
+
+doxygen_javadoc_autobrief	1	Set to 0 to disable javadoc autobrief
+					colour highlighting.
+
+doxygen_end_punctuation		'[.]'	Set to regexp match for the ending
+					punctuation of brief
+
+There are also some hilight groups worth mentioning as they can be useful in
+configuration.
+
+Highlight			Effect ~
+doxygenErrorComment		The colour of an end-comment when missing
+				punctuation in a code, verbatim or dot section
+doxygenLinkError		The colour of an end-comment when missing the
+				\endlink from a \link section.
+
+
+DTD						*dtd.vim* *ft-dtd-syntax*
+
+The DTD syntax highlighting is case sensitive by default.  To disable
+case-sensitive highlighting, add the following line to your startup file: >
+
+	:let dtd_ignore_case=1
+
+The DTD syntax file will highlight unknown tags as errors.  If
+this is annoying, it can be turned off by setting: >
+
+	:let dtd_no_tag_errors=1
+
+before sourcing the dtd.vim syntax file.
+Parameter entity names are highlighted in the definition using the
+'Type' highlighting group and 'Comment' for punctuation and '%'.
+Parameter entity instances are highlighted using the 'Constant'
+highlighting group and the 'Type' highlighting group for the
+delimiters % and ;.  This can be turned off by setting: >
+
+	:let dtd_no_param_entities=1
+
+The DTD syntax file is also included by xml.vim to highlight included dtd's.
+
+
+EIFFEL					*eiffel.vim* *ft-eiffel-syntax*
+
+While Eiffel is not case-sensitive, its style guidelines are, and the
+syntax highlighting file encourages their use.  This also allows to
+highlight class names differently.  If you want to disable case-sensitive
+highlighting, add the following line to your startup file: >
+
+	:let eiffel_ignore_case=1
+
+Case still matters for class names and TODO marks in comments.
+
+Conversely, for even stricter checks, add one of the following lines: >
+
+	:let eiffel_strict=1
+	:let eiffel_pedantic=1
+
+Setting eiffel_strict will only catch improper capitalization for the
+five predefined words "Current", "Void", "Result", "Precursor", and
+"NONE", to warn against their accidental use as feature or class names.
+
+Setting eiffel_pedantic will enforce adherence to the Eiffel style
+guidelines fairly rigorously (like arbitrary mixes of upper- and
+lowercase letters as well as outdated ways to capitalize keywords).
+
+If you want to use the lower-case version of "Current", "Void",
+"Result", and "Precursor", you can use >
+
+	:let eiffel_lower_case_predef=1
+
+instead of completely turning case-sensitive highlighting off.
+
+Support for ISE's proposed new creation syntax that is already
+experimentally handled by some compilers can be enabled by: >
+
+	:let eiffel_ise=1
+
+Finally, some vendors support hexadecimal constants.  To handle them, add >
+
+	:let eiffel_hex_constants=1
+
+to your startup file.
+
+
+ERLANG						*erlang.vim* *ft-erlang-syntax*
+
+The erlang highlighting supports Erlang (ERicsson LANGuage).
+Erlang is case sensitive and default extension is ".erl".
+
+If you want to disable keywords highlighting, put in your .vimrc: >
+	:let erlang_keywords = 1
+If you want to disable built-in-functions highlighting, put in your
+.vimrc file: >
+	:let erlang_functions = 1
+If you want to disable special characters highlighting, put in
+your .vimrc: >
+	:let erlang_characters = 1
+
+
+FLEXWIKI				*flexwiki.vim* *ft-flexwiki-syntax*
+
+FlexWiki is an ASP.NET-based wiki package available at http://www.flexwiki.com
+
+Syntax highlighting is available for the most common elements of FlexWiki
+syntax. The associated ftplugin script sets some buffer-local options to make
+editing FlexWiki pages more convenient. FlexWiki considers a newline as the
+start of a new paragraph, so the ftplugin sets 'tw'=0 (unlimited line length),
+'wrap' (wrap long lines instead of using horizontal scrolling), 'linebreak'
+(to wrap at a character in 'breakat' instead of at the last char on screen),
+and so on. It also includes some keymaps that are disabled by default.
+
+If you want to enable the keymaps that make "j" and "k" and the cursor keys
+move up and down by display lines, add this to your .vimrc: >
+	:let flexwiki_maps = 1
+
+
+FORM						*form.vim* *ft-form-syntax*
+
+The coloring scheme for syntax elements in the FORM file uses the default
+modes Conditional, Number, Statement, Comment, PreProc, Type, and String,
+following the language specifications in 'Symbolic Manipulation with FORM' by
+J.A.M. Vermaseren, CAN, Netherlands, 1991.
+
+If you want include your own changes to the default colors, you have to
+redefine the following syntax groups:
+
+    - formConditional
+    - formNumber
+    - formStatement
+    - formHeaderStatement
+    - formComment
+    - formPreProc
+    - formDirective
+    - formType
+    - formString
+
+Note that the form.vim syntax file implements FORM preprocessor commands and
+directives per default in the same syntax group.
+
+A predefined enhanced color mode for FORM is available to distinguish between
+header statements and statements in the body of a FORM program.  To activate
+this mode define the following variable in your vimrc file >
+
+	:let form_enhanced_color=1
+
+The enhanced mode also takes advantage of additional color features for a dark
+gvim display.  Here, statements are colored LightYellow instead of Yellow, and
+conditionals are LightBlue for better distinction.
+
+
+FORTRAN					*fortran.vim* *ft-fortran-syntax*
+
+Default highlighting and dialect ~
+Highlighting appropriate for f95 (Fortran 95) is used by default.  This choice
+should be appropriate for most users most of the time because Fortran 95 is a
+superset of Fortran 90 and almost a superset of Fortran 77. Support for 
+Fortran 2003 and Fortran 2008 features has been introduced and is
+automatically available in the default (f95) highlighting.
+
+Fortran source code form ~
+Fortran 9x code can be in either fixed or free source form.  Note that the
+syntax highlighting will not be correct if the form is incorrectly set.
+
+When you create a new fortran file, the syntax script assumes fixed source
+form.  If you always use free source form, then >
+    :let fortran_free_source=1
+in your .vimrc prior to the :syntax on command.  If you always use fixed source
+form, then >
+    :let fortran_fixed_source=1
+in your .vimrc prior to the :syntax on command.
+
+If the form of the source code depends upon the file extension, then it is
+most convenient to set fortran_free_source in a ftplugin file.  For more
+information on ftplugin files, see |ftplugin|.  For example, if all your
+fortran files with an .f90 extension are written in free source form and the
+rest in fixed source form, add the following code to your ftplugin file >
+    let s:extfname = expand("%:e")
+    if s:extfname ==? "f90"
+	let fortran_free_source=1
+	unlet! fortran_fixed_source
+    else
+	let fortran_fixed_source=1
+	unlet! fortran_free_source
+    endif
+Note that this will work only if the "filetype plugin indent on" command
+precedes the "syntax on" command in your .vimrc file.
+
+When you edit an existing fortran file, the syntax script will assume free
+source form if the fortran_free_source variable has been set, and assumes
+fixed source form if the fortran_fixed_source variable has been set.  If
+neither of these variables have been set, the syntax script attempts to
+determine which source form has been used by examining the first five columns
+of the first 250 lines of your file.  If no signs of free source form are
+detected, then the file is assumed to be in fixed source form.  The algorithm
+should work in the vast majority of cases.  In some cases, such as a file that
+begins with 250 or more full-line comments, the script may incorrectly decide
+that the fortran code is in fixed form.  If that happens, just add a
+non-comment statement beginning anywhere in the first five columns of the
+first twenty five lines, save (:w) and then reload (:e!) the file.
+
+Tabs in fortran files ~
+Tabs are not recognized by the Fortran standards.  Tabs are not a good idea in
+fixed format fortran source code which requires fixed column boundaries.
+Therefore, tabs are marked as errors.  Nevertheless, some programmers like
+using tabs.  If your fortran files contain tabs, then you should set the
+variable fortran_have_tabs in your .vimrc with a command such as >
+    :let fortran_have_tabs=1
+placed prior to the :syntax on command.  Unfortunately, the use of tabs will
+mean that the syntax file will not be able to detect incorrect margins.
+
+Syntax folding of fortran files ~
+If you wish to use foldmethod=syntax, then you must first set the variable
+fortran_fold with a command such as >
+    :let fortran_fold=1
+to instruct the syntax script to define fold regions for program units, that
+is main programs starting with a program statement, subroutines, function
+subprograms, block data subprograms, interface blocks, and modules.  If you
+also set the variable fortran_fold_conditionals with a command such as >
+    :let fortran_fold_conditionals=1
+then fold regions will also be defined for do loops, if blocks, and select
+case constructs.  If you also set the variable
+fortran_fold_multilinecomments with a command such as >
+    :let fortran_fold_multilinecomments=1
+then fold regions will also be defined for three or more consecutive comment
+lines.  Note that defining fold regions can be slow for large files.
+
+If fortran_fold, and possibly fortran_fold_conditionals and/or
+fortran_fold_multilinecomments, have been set, then vim will fold your file if
+you set foldmethod=syntax.  Comments or blank lines placed between two program
+units are not folded because they are seen as not belonging to any program
+unit.
+
+More precise fortran syntax ~
+If you set the variable fortran_more_precise with a command such as >
+    :let fortran_more_precise=1
+then the syntax coloring will be more precise but slower.  In particular,
+statement labels used in do, goto and arithmetic if statements will be
+recognized, as will construct names at the end of a do, if, select or forall
+construct.
+
+Non-default fortran dialects ~
+The syntax script supports five Fortran dialects: f95, f90, f77, the Lahey
+subset elf90, and the Imagine1 subset F.
+
+If you use f77 with extensions, even common ones like do/enddo loops, do/while
+loops and free source form that are supported by most f77 compilers including
+g77 (GNU Fortran), then you will probably find the default highlighting
+satisfactory.  However, if you use strict f77 with no extensions, not even free
+source form or the MIL STD 1753 extensions, then the advantages of setting the
+dialect to f77 are that names such as SUM are recognized as user variable
+names and not highlighted as f9x intrinsic functions, that obsolete constructs
+such as ASSIGN statements are not highlighted as todo items, and that fixed
+source form will be assumed.
+
+If you use elf90 or F, the advantage of setting the dialect appropriately is
+that f90 features excluded from these dialects will be highlighted as todo
+items and that free source form will be assumed as required for these
+dialects.
+
+The dialect can be selected by setting the variable fortran_dialect.  The
+permissible values of fortran_dialect are case-sensitive and must be "f95",
+"f90", "f77", "elf" or "F".  Invalid values of fortran_dialect are ignored.
+
+If all your fortran files use the same dialect, set fortran_dialect in your
+.vimrc prior to your syntax on statement.  If the dialect depends upon the file
+extension, then it is most convenient to set it in a ftplugin file.  For more
+information on ftplugin files, see |ftplugin|.  For example, if all your
+fortran files with an .f90 extension are written in the elf subset, your
+ftplugin file should contain the code >
+    let s:extfname = expand("%:e")
+    if s:extfname ==? "f90"
+	let fortran_dialect="elf"
+    else
+	unlet! fortran_dialect
+    endif
+Note that this will work only if the "filetype plugin indent on" command
+precedes the "syntax on" command in your .vimrc file.
+
+Finer control is necessary if the file extension does not uniquely identify
+the dialect.  You can override the default dialect, on a file-by-file basis, by
+including a comment with the directive "fortran_dialect=xx" (where xx=f77 or
+elf or F or f90 or f95) in one of the first three lines in your file.  For
+example, your older .f files may be written in extended f77 but your newer
+ones may be F codes, and you would identify the latter by including in the
+first three lines of those files a Fortran comment of the form >
+  ! fortran_dialect=F
+F overrides elf if both directives are present.
+
+Limitations ~
+Parenthesis checking does not catch too few closing parentheses.  Hollerith
+strings are not recognized.  Some keywords may be highlighted incorrectly
+because Fortran90 has no reserved words.
+
+For further information related to fortran, see |ft-fortran-indent| and
+|ft-fortran-plugin|.
+
+
+FVWM CONFIGURATION FILES			*fvwm.vim* *ft-fvwm-syntax*
+
+In order for Vim to recognize Fvwm configuration files that do not match
+the patterns *fvwmrc* or *fvwm2rc* , you must put additional patterns
+appropriate to your system in your myfiletypes.vim file.  For these
+patterns, you must set the variable "b:fvwm_version" to the major version
+number of Fvwm, and the 'filetype' option to fvwm.
+
+For example, to make Vim identify all files in /etc/X11/fvwm2/
+as Fvwm2 configuration files, add the following: >
+
+  :au! BufNewFile,BufRead /etc/X11/fvwm2/*  let b:fvwm_version = 2 |
+					 \ set filetype=fvwm
+
+If you'd like Vim to highlight all valid color names, tell it where to
+find the color database (rgb.txt) on your system.  Do this by setting
+"rgb_file" to its location.  Assuming your color database is located
+in /usr/X11/lib/X11/, you should add the line >
+
+	:let rgb_file = "/usr/X11/lib/X11/rgb.txt"
+
+to your .vimrc file.
+
+
+GSP						*gsp.vim* *ft-gsp-syntax*
+
+The default coloring style for GSP pages is defined by |html.vim|, and
+the coloring for java code (within java tags or inline between backticks)
+is defined by |java.vim|.  The following HTML groups defined in |html.vim|
+are redefined to incorporate and highlight inline java code:
+
+    htmlString
+    htmlValue
+    htmlEndTag
+    htmlTag
+    htmlTagN
+
+Highlighting should look fine most of the places where you'd see inline
+java code, but in some special cases it may not.  To add another HTML
+group where you will have inline java code where it does not highlight
+correctly, just copy the line you want from |html.vim| and add gspJava
+to the contains clause.
+
+The backticks for inline java are highlighted according to the htmlError
+group to make them easier to see.
+
+
+GROFF						*groff.vim* *ft-groff-syntax*
+
+The groff syntax file is a wrapper for |nroff.vim|, see the notes
+under that heading for examples of use and configuration.  The purpose
+of this wrapper is to set up groff syntax extensions by setting the
+filetype from a |modeline| or in a personal filetype definitions file
+(see |filetype.txt|).
+
+
+HASKELL			     *haskell.vim* *lhaskell.vim* *ft-haskell-syntax*
+
+The Haskell syntax files support plain Haskell code as well as literate
+Haskell code, the latter in both Bird style and TeX style.  The Haskell
+syntax highlighting will also highlight C preprocessor directives.
+
+If you want to highlight delimiter characters (useful if you have a
+light-coloured background), add to your .vimrc: >
+	:let hs_highlight_delimiters = 1
+To treat True and False as keywords as opposed to ordinary identifiers,
+add: >
+	:let hs_highlight_boolean = 1
+To also treat the names of primitive types as keywords: >
+	:let hs_highlight_types = 1
+And to treat the names of even more relatively common types as keywords: >
+	:let hs_highlight_more_types = 1
+If you want to highlight the names of debugging functions, put in
+your .vimrc: >
+	:let hs_highlight_debug = 1
+
+The Haskell syntax highlighting also highlights C preprocessor
+directives, and flags lines that start with # but are not valid
+directives as erroneous.  This interferes with Haskell's syntax for
+operators, as they may start with #.  If you want to highlight those
+as operators as opposed to errors, put in your .vimrc: >
+	:let hs_allow_hash_operator = 1
+
+The syntax highlighting for literate Haskell code will try to
+automatically guess whether your literate Haskell code contains
+TeX markup or not, and correspondingly highlight TeX constructs
+or nothing at all.  You can override this globally by putting
+in your .vimrc >
+	:let lhs_markup = none
+for no highlighting at all, or >
+	:let lhs_markup = tex
+to force the highlighting to always try to highlight TeX markup.
+For more flexibility, you may also use buffer local versions of
+this variable, so e.g. >
+	:let b:lhs_markup = tex
+will force TeX highlighting for a particular buffer.  It has to be
+set before turning syntax highlighting on for the buffer or
+loading a file.
+
+
+HTML						*html.vim* *ft-html-syntax*
+
+The coloring scheme for tags in the HTML file works as follows.
+
+The  <> of opening tags are colored differently than the  of a closing tag.
+This is on purpose! For opening tags the 'Function' color is used, while for
+closing tags the 'Type' color is used (See syntax.vim to check how those are
+defined for you)
+
+Known tag names are colored the same way as statements in C.  Unknown tag
+names are colored with the same color as the <> or  respectively which
+makes it easy to spot errors
+
+Note that the same is true for argument (or attribute) names.  Known attribute
+names are colored differently than unknown ones.
+
+Some HTML tags are used to change the rendering of text.  The following tags
+are recognized by the html.vim syntax coloring file and change the way normal
+text is shown:      ( is used as an alias for ,
+while  as an alias for ), 

-

, , and <A>, but +only if used as a link (that is, it must include a href as in +<A href="somefile.html">). + +If you want to change how such text is rendered, you must redefine the +following syntax groups: + + - htmlBold + - htmlBoldUnderline + - htmlBoldUnderlineItalic + - htmlUnderline + - htmlUnderlineItalic + - htmlItalic + - htmlTitle for titles + - htmlH1 - htmlH6 for headings + +To make this redefinition work you must redefine them all with the exception +of the last two (htmlTitle and htmlH[1-6], which are optional) and define the +following variable in your vimrc (this is due to the order in which the files +are read during initialization) > + :let html_my_rendering=1 + +If you'd like to see an example download mysyntax.vim at +http://www.fleiner.com/vim/download.html + +You can also disable this rendering by adding the following line to your +vimrc file: > + :let html_no_rendering=1 + +HTML comments are rather special (see an HTML reference document for the +details), and the syntax coloring scheme will highlight all errors. +However, if you prefer to use the wrong style (starts with <!-- and +ends with --!>) you can define > + :let html_wrong_comments=1 + +JavaScript and Visual Basic embedded inside HTML documents are highlighted as +'Special' with statements, comments, strings and so on colored as in standard +programming languages. Note that only JavaScript and Visual Basic are currently +supported, no other scripting language has been added yet. + +Embedded and inlined cascading style sheets (CSS) are highlighted too. + +There are several html preprocessor languages out there. html.vim has been +written such that it should be trivial to include it. To do so add the +following two lines to the syntax coloring file for that language +(the example comes from the asp.vim file): + + runtime! syntax/html.vim + syn cluster htmlPreproc add=asp + +Now you just need to make sure that you add all regions that contain +the preprocessor language to the cluster htmlPreproc. + + +HTML/OS (by Aestiva) *htmlos.vim* *ft-htmlos-syntax* + +The coloring scheme for HTML/OS works as follows: + +Functions and variable names are the same color by default, because VIM +doesn't specify different colors for Functions and Identifiers. To change +this (which is recommended if you want function names to be recognizable in a +different color) you need to add the following line to either your ~/.vimrc: > + :hi Function term=underline cterm=bold ctermfg=LightGray + +Of course, the ctermfg can be a different color if you choose. + +Another issues that HTML/OS runs into is that there is no special filetype to +signify that it is a file with HTML/OS coding. You can change this by opening +a file and turning on HTML/OS syntax by doing the following: > + :set syntax=htmlos + +Lastly, it should be noted that the opening and closing characters to begin a +block of HTML/OS code can either be << or [[ and >> or ]], respectively. + + +IA64 *ia64.vim* *intel-itanium* *ft-ia64-syntax* + +Highlighting for the Intel Itanium 64 assembly language. See |asm.vim| for +how to recognize this filetype. + +To have *.inc files be recognized as IA64, add this to your .vimrc file: > + :let g:filetype_inc = "ia64" + + +INFORM *inform.vim* *ft-inform-syntax* + +Inform highlighting includes symbols provided by the Inform Library, as +most programs make extensive use of it. If do not wish Library symbols +to be highlighted add this to your vim startup: > + :let inform_highlight_simple=1 + +By default it is assumed that Inform programs are Z-machine targeted, +and highlights Z-machine assembly language symbols appropriately. If +you intend your program to be targeted to a Glulx/Glk environment you +need to add this to your startup sequence: > + :let inform_highlight_glulx=1 + +This will highlight Glulx opcodes instead, and also adds glk() to the +set of highlighted system functions. + +The Inform compiler will flag certain obsolete keywords as errors when +it encounters them. These keywords are normally highlighted as errors +by Vim. To prevent such error highlighting, you must add this to your +startup sequence: > + :let inform_suppress_obsolete=1 + +By default, the language features highlighted conform to Compiler +version 6.30 and Library version 6.11. If you are using an older +Inform development environment, you may with to add this to your +startup sequence: > + :let inform_highlight_old=1 + +IDL *idl.vim* *idl-syntax* + +IDL (Interface Definition Language) files are used to define RPC calls. In +Microsoft land, this is also used for defining COM interfaces and calls. + +IDL's structure is simple enough to permit a full grammar based approach to +rather than using a few heuristics. The result is large and somewhat +repetitive but seems to work. + +There are some Microsoft extensions to idl files that are here. Some of them +are disabled by defining idl_no_ms_extensions. + +The more complex of the extensions are disabled by defining idl_no_extensions. + +Variable Effect ~ + +idl_no_ms_extensions Disable some of the Microsoft specific + extensions +idl_no_extensions Disable complex extensions +idlsyntax_showerror Show IDL errors (can be rather intrusive, but + quite helpful) +idlsyntax_showerror_soft Use softer colours by default for errors + + +JAVA *java.vim* *ft-java-syntax* + +The java.vim syntax highlighting file offers several options: + +In Java 1.0.2 it was never possible to have braces inside parens, so this was +flagged as an error. Since Java 1.1 this is possible (with anonymous +classes), and therefore is no longer marked as an error. If you prefer the old +way, put the following line into your vim startup file: > + :let java_mark_braces_in_parens_as_errors=1 + +All identifiers in java.lang.* are always visible in all classes. To +highlight them use: > + :let java_highlight_java_lang_ids=1 + +You can also highlight identifiers of most standard Java packages if you +download the javaid.vim script at http://www.fleiner.com/vim/download.html. +If you prefer to only highlight identifiers of a certain package, say java.io +use the following: > + :let java_highlight_java_io=1 +Check the javaid.vim file for a list of all the packages that are supported. + +Function names are not highlighted, as the way to find functions depends on +how you write Java code. The syntax file knows two possible ways to highlight +functions: + +If you write function declarations that are always indented by either +a tab, 8 spaces or 2 spaces you may want to set > + :let java_highlight_functions="indent" +However, if you follow the Java guidelines about how functions and classes are +supposed to be named (with respect to upper and lowercase), use > + :let java_highlight_functions="style" +If both options do not work for you, but you would still want function +declarations to be highlighted create your own definitions by changing the +definitions in java.vim or by creating your own java.vim which includes the +original one and then adds the code to highlight functions. + +In Java 1.1 the functions System.out.println() and System.err.println() should +only be used for debugging. Therefore it is possible to highlight debugging +statements differently. To do this you must add the following definition in +your startup file: > + :let java_highlight_debug=1 +The result will be that those statements are highlighted as 'Special' +characters. If you prefer to have them highlighted differently you must define +new highlightings for the following groups.: + Debug, DebugSpecial, DebugString, DebugBoolean, DebugType +which are used for the statement itself, special characters used in debug +strings, strings, boolean constants and types (this, super) respectively. I +have opted to chose another background for those statements. + +In order to help you write code that can be easily ported between Java and +C++, all C++ keywords can be marked as an error in a Java program. To +have this add this line in your .vimrc file: > + :let java_allow_cpp_keywords = 0 + +Javadoc is a program that takes special comments out of Java program files and +creates HTML pages. The standard configuration will highlight this HTML code +similarly to HTML files (see |html.vim|). You can even add Javascript +and CSS inside this code (see below). There are four differences however: + 1. The title (all characters up to the first '.' which is followed by + some white space or up to the first '@') is colored differently (to change + the color change the group CommentTitle). + 2. The text is colored as 'Comment'. + 3. HTML comments are colored as 'Special' + 4. The special Javadoc tags (@see, @param, ...) are highlighted as specials + and the argument (for @see, @param, @exception) as Function. +To turn this feature off add the following line to your startup file: > + :let java_ignore_javadoc=1 + +If you use the special Javadoc comment highlighting described above you +can also turn on special highlighting for Javascript, visual basic +scripts and embedded CSS (stylesheets). This makes only sense if you +actually have Javadoc comments that include either Javascript or embedded +CSS. The options to use are > + :let java_javascript=1 + :let java_css=1 + :let java_vb=1 + +In order to highlight nested parens with different colors define colors +for javaParen, javaParen1 and javaParen2, for example with > + :hi link javaParen Comment +or > + :hi javaParen ctermfg=blue guifg=#0000ff + +If you notice highlighting errors while scrolling backwards, which are fixed +when redrawing with CTRL-L, try setting the "java_minlines" internal variable +to a larger number: > + :let java_minlines = 50 +This will make the syntax synchronization start 50 lines before the first +displayed line. The default value is 10. The disadvantage of using a larger +number is that redrawing can become slow. + + +LACE *lace.vim* *ft-lace-syntax* + +Lace (Language for Assembly of Classes in Eiffel) is case insensitive, but the +style guide lines are not. If you prefer case insensitive highlighting, just +define the vim variable 'lace_case_insensitive' in your startup file: > + :let lace_case_insensitive=1 + + +LEX *lex.vim* *ft-lex-syntax* + +Lex uses brute-force synchronizing as the "^%%$" section delimiter +gives no clue as to what section follows. Consequently, the value for > + :syn sync minlines=300 +may be changed by the user if s/he is experiencing synchronization +difficulties (such as may happen with large lex files). + + +LIFELINES *lifelines.vim* *ft-lifelines-syntax* + +To highlight deprecated functions as errors, add in your .vimrc: > + + :let g:lifelines_deprecated = 1 +< + +LISP *lisp.vim* *ft-lisp-syntax* + +The lisp syntax highlighting provides two options: > + + g:lisp_instring : if it exists, then "(...)" strings are highlighted + as if the contents of the string were lisp. + Useful for AutoLisp. + g:lisp_rainbow : if it exists and is nonzero, then differing levels + of parenthesization will receive different + highlighting. +< +The g:lisp_rainbow option provides 10 levels of individual colorization for +the parentheses and backquoted parentheses. Because of the quantity of +colorization levels, unlike non-rainbow highlighting, the rainbow mode +specifies its highlighting using ctermfg and guifg, thereby bypassing the +usual colorscheme control using standard highlighting groups. The actual +highlighting used depends on the dark/bright setting (see |'bg'|). + + +LITE *lite.vim* *ft-lite-syntax* + +There are two options for the lite syntax highlighting. + +If you like SQL syntax highlighting inside Strings, use this: > + + :let lite_sql_query = 1 + +For syncing, minlines defaults to 100. If you prefer another value, you can +set "lite_minlines" to the value you desire. Example: > + + :let lite_minlines = 200 + + +LPC *lpc.vim* *ft-lpc-syntax* + +LPC stands for a simple, memory-efficient language: Lars Pensj| C. The +file name of LPC is usually *.c. Recognizing these files as LPC would bother +users writing only C programs. If you want to use LPC syntax in Vim, you +should set a variable in your .vimrc file: > + + :let lpc_syntax_for_c = 1 + +If it doesn't work properly for some particular C or LPC files, use a +modeline. For a LPC file: + + // vim:set ft=lpc: + +For a C file that is recognized as LPC: + + // vim:set ft=c: + +If you don't want to set the variable, use the modeline in EVERY LPC file. + +There are several implementations for LPC, we intend to support most widely +used ones. Here the default LPC syntax is for MudOS series, for MudOS v22 +and before, you should turn off the sensible modifiers, and this will also +asserts the new efuns after v22 to be invalid, don't set this variable when +you are using the latest version of MudOS: > + + :let lpc_pre_v22 = 1 + +For LpMud 3.2 series of LPC: > + + :let lpc_compat_32 = 1 + +For LPC4 series of LPC: > + + :let lpc_use_lpc4_syntax = 1 + +For uLPC series of LPC: +uLPC has been developed to Pike, so you should use Pike syntax +instead, and the name of your source file should be *.pike + + +LUA *lua.vim* *ft-lua-syntax* + +This syntax file may be used for Lua 4.0, Lua 5.0 or Lua 5.1 (the latter is +the default). You can select one of these versions using the global variables +lua_version and lua_subversion. For example, to activate Lua +4.0 syntax highlighting, use this command: > + + :let lua_version = 4 + +If you are using Lua 5.0, use these commands: > + + :let lua_version = 5 + :let lua_subversion = 0 + +To restore highlighting for Lua 5.1: > + + :let lua_version = 5 + :let lua_subversion = 1 + + +MAIL *mail.vim* *ft-mail.vim* + +Vim highlights all the standard elements of an email (headers, signatures, +quoted text and URLs / email addresses). In keeping with standard conventions, +signatures begin in a line containing only "--" followed optionally by +whitespaces and end with a newline. + +Vim treats lines beginning with ']', '}', '|', '>' or a word followed by '>' +as quoted text. However Vim highlights headers and signatures in quoted text +only if the text is quoted with '>' (optionally followed by one space). + +By default mail.vim synchronises syntax to 100 lines before the first +displayed line. If you have a slow machine, and generally deal with emails +with short headers, you can change this to a smaller value: > + + :let mail_minlines = 30 + + +MAKE *make.vim* *ft-make-syntax* + +In makefiles, commands are usually highlighted to make it easy for you to spot +errors. However, this may be too much coloring for you. You can turn this +feature off by using: > + + :let make_no_commands = 1 + + +MAPLE *maple.vim* *ft-maple-syntax* + +Maple V, by Waterloo Maple Inc, supports symbolic algebra. The language +supports many packages of functions which are selectively loaded by the user. +The standard set of packages' functions as supplied in Maple V release 4 may be +highlighted at the user's discretion. Users may place in their .vimrc file: > + + :let mvpkg_all= 1 + +to get all package functions highlighted, or users may select any subset by +choosing a variable/package from the table below and setting that variable to +1, also in their .vimrc file (prior to sourcing +$VIMRUNTIME/syntax/syntax.vim). + + Table of Maple V Package Function Selectors > + mv_DEtools mv_genfunc mv_networks mv_process + mv_Galois mv_geometry mv_numapprox mv_simplex + mv_GaussInt mv_grobner mv_numtheory mv_stats + mv_LREtools mv_group mv_orthopoly mv_student + mv_combinat mv_inttrans mv_padic mv_sumtools + mv_combstruct mv_liesymm mv_plots mv_tensor + mv_difforms mv_linalg mv_plottools mv_totorder + mv_finance mv_logic mv_powseries + + +MATHEMATICA *mma.vim* *ft-mma-syntax* *ft-mathematica-syntax* + +Empty *.m files will automatically be presumed to be Matlab files unless you +have the following in your .vimrc: > + + let filetype_m = "mma" + + +MOO *moo.vim* *ft-moo-syntax* + +If you use C-style comments inside expressions and find it mangles your +highlighting, you may want to use extended (slow!) matches for C-style +comments: > + + :let moo_extended_cstyle_comments = 1 + +To disable highlighting of pronoun substitution patterns inside strings: > + + :let moo_no_pronoun_sub = 1 + +To disable highlighting of the regular expression operator '%|', and matching +'%(' and '%)' inside strings: > + + :let moo_no_regexp = 1 + +Unmatched double quotes can be recognized and highlighted as errors: > + + :let moo_unmatched_quotes = 1 + +To highlight builtin properties (.name, .location, .programmer etc.): > + + :let moo_builtin_properties = 1 + +Unknown builtin functions can be recognized and highlighted as errors. If you +use this option, add your own extensions to the mooKnownBuiltinFunction group. +To enable this option: > + + :let moo_unknown_builtin_functions = 1 + +An example of adding sprintf() to the list of known builtin functions: > + + :syn keyword mooKnownBuiltinFunction sprintf contained + + +MSQL *msql.vim* *ft-msql-syntax* + +There are two options for the msql syntax highlighting. + +If you like SQL syntax highlighting inside Strings, use this: > + + :let msql_sql_query = 1 + +For syncing, minlines defaults to 100. If you prefer another value, you can +set "msql_minlines" to the value you desire. Example: > + + :let msql_minlines = 200 + + +NCF *ncf.vim* *ft-ncf-syntax* + +There is one option for NCF syntax highlighting. + +If you want to have unrecognized (by ncf.vim) statements highlighted as +errors, use this: > + + :let ncf_highlight_unknowns = 1 + +If you don't want to highlight these errors, leave it unset. + + +NROFF *nroff.vim* *ft-nroff-syntax* + +The nroff syntax file works with AT&T n/troff out of the box. You need to +activate the GNU groff extra features included in the syntax file before you +can use them. + +For example, Linux and BSD distributions use groff as their default text +processing package. In order to activate the extra syntax highlighting +features for groff, add the following option to your start-up files: > + + :let b:nroff_is_groff = 1 + +Groff is different from the old AT&T n/troff that you may still find in +Solaris. Groff macro and request names can be longer than 2 characters and +there are extensions to the language primitives. For example, in AT&T troff +you access the year as a 2-digit number with the request \(yr. In groff you +can use the same request, recognized for compatibility, or you can use groff's +native syntax, \[yr]. Furthermore, you can use a 4-digit year directly: +\[year]. Macro requests can be longer than 2 characters, for example, GNU mm +accepts the requests ".VERBON" and ".VERBOFF" for creating verbatim +environments. + +In order to obtain the best formatted output g/troff can give you, you should +follow a few simple rules about spacing and punctuation. + +1. Do not leave empty spaces at the end of lines. + +2. Leave one space and one space only after an end-of-sentence period, + exclamation mark, etc. + +3. For reasons stated below, it is best to follow all period marks with a + carriage return. + +The reason behind these unusual tips is that g/n/troff have a line breaking +algorithm that can be easily upset if you don't follow the rules given above. + +Unlike TeX, troff fills text line-by-line, not paragraph-by-paragraph and, +furthermore, it does not have a concept of glue or stretch, all horizontal and +vertical space input will be output as is. + +Therefore, you should be careful about not using more space between sentences +than you intend to have in your final document. For this reason, the common +practice is to insert a carriage return immediately after all punctuation +marks. If you want to have "even" text in your final processed output, you +need to maintaining regular spacing in the input text. To mark both trailing +spaces and two or more spaces after a punctuation as an error, use: > + + :let nroff_space_errors = 1 + +Another technique to detect extra spacing and other errors that will interfere +with the correct typesetting of your file, is to define an eye-catching +highlighting definition for the syntax groups "nroffDefinition" and +"nroffDefSpecial" in your configuration files. For example: > + + hi def nroffDefinition term=italic cterm=italic gui=reverse + hi def nroffDefSpecial term=italic,bold cterm=italic,bold + \ gui=reverse,bold + +If you want to navigate preprocessor entries in your source file as easily as +with section markers, you can activate the following option in your .vimrc +file: > + + let b:preprocs_as_sections = 1 + +As well, the syntax file adds an extra paragraph marker for the extended +paragraph macro (.XP) in the ms package. + +Finally, there is a |groff.vim| syntax file that can be used for enabling +groff syntax highlighting either on a file basis or globally by default. + + +OCAML *ocaml.vim* *ft-ocaml-syntax* + +The OCaml syntax file handles files having the following prefixes: .ml, +.mli, .mll and .mly. By setting the following variable > + + :let ocaml_revised = 1 + +you can switch from standard OCaml-syntax to revised syntax as supported +by the camlp4 preprocessor. Setting the variable > + + :let ocaml_noend_error = 1 + +prevents highlighting of "end" as error, which is useful when sources +contain very long structures that Vim does not synchronize anymore. + + +PAPP *papp.vim* *ft-papp-syntax* + +The PApp syntax file handles .papp files and, to a lesser extend, .pxml +and .pxsl files which are all a mixture of perl/xml/html/other using xml +as the top-level file format. By default everything inside phtml or pxml +sections is treated as a string with embedded preprocessor commands. If +you set the variable: > + + :let papp_include_html=1 + +in your startup file it will try to syntax-hilight html code inside phtml +sections, but this is relatively slow and much too colourful to be able to +edit sensibly. ;) + +The newest version of the papp.vim syntax file can usually be found at +http://papp.plan9.de. + + +PASCAL *pascal.vim* *ft-pascal-syntax* + +Files matching "*.p" could be Progress or Pascal. If the automatic detection +doesn't work for you, or you don't edit Progress at all, use this in your +startup vimrc: > + + :let filetype_p = "pascal" + +The Pascal syntax file has been extended to take into account some extensions +provided by Turbo Pascal, Free Pascal Compiler and GNU Pascal Compiler. +Delphi keywords are also supported. By default, Turbo Pascal 7.0 features are +enabled. If you prefer to stick with the standard Pascal keywords, add the +following line to your startup file: > + + :let pascal_traditional=1 + +To switch on Delphi specific constructions (such as one-line comments, +keywords, etc): > + + :let pascal_delphi=1 + + +The option pascal_symbol_operator controls whether symbol operators such as +, +*, .., etc. are displayed using the Operator color or not. To colorize symbol +operators, add the following line to your startup file: > + + :let pascal_symbol_operator=1 + +Some functions are highlighted by default. To switch it off: > + + :let pascal_no_functions=1 + +Furthermore, there are specific variables for some compilers. Besides +pascal_delphi, there are pascal_gpc and pascal_fpc. Default extensions try to +match Turbo Pascal. > + + :let pascal_gpc=1 + +or > + + :let pascal_fpc=1 + +To ensure that strings are defined on a single line, you can define the +pascal_one_line_string variable. > + + :let pascal_one_line_string=1 + +If you dislike <Tab> chars, you can set the pascal_no_tabs variable. Tabs +will be highlighted as Error. > + + :let pascal_no_tabs=1 + + + +PERL *perl.vim* *ft-perl-syntax* + +There are a number of possible options to the perl syntax highlighting. + +If you use POD files or POD segments, you might: > + + :let perl_include_pod = 1 + +The reduce the complexity of parsing (and increase performance) you can switch +off two elements in the parsing of variable names and contents. > + +To handle package references in variable and function names not differently +from the rest of the name (like 'PkgName::' in '$PkgName::VarName'): > + + :let perl_no_scope_in_variables = 1 + +(In Vim 6.x it was the other way around: "perl_want_scope_in_variables" +enabled it.) + +If you do not want complex things like '@{${"foo"}}' to be parsed: > + + :let perl_no_extended_vars = 1 + +(In Vim 6.x it was the other way around: "perl_extended_vars" enabled it.) + +The coloring strings can be changed. By default strings and qq friends will be +highlighted like the first line. If you set the variable +perl_string_as_statement, it will be highlighted as in the second line. + + "hello world!"; qq|hello world|; + ^^^^^^^^^^^^^^NN^^^^^^^^^^^^^^^N (unlet perl_string_as_statement) + S^^^^^^^^^^^^SNNSSS^^^^^^^^^^^SN (let perl_string_as_statement) + +(^ = perlString, S = perlStatement, N = None at all) + +The syncing has 3 options. The first two switch off some triggering of +synchronization and should only be needed in case it fails to work properly. +If while scrolling all of a sudden the whole screen changes color completely +then you should try and switch off one of those. Let me know if you can figure +out the line that causes the mistake. + +One triggers on "^\s*sub\s*" and the other on "^[$@%]" more or less. > + + :let perl_no_sync_on_sub + :let perl_no_sync_on_global_var + +Below you can set the maximum distance VIM should look for starting points for +its attempts in syntax highlighting. > + + :let perl_sync_dist = 100 + +If you want to use folding with perl, set perl_fold: > + + :let perl_fold = 1 + +If you want to fold blocks in if statements, etc. as well set the following: > + + :let perl_fold_blocks = 1 + +To avoid folding packages or subs when perl_fold is let, let the appropriate +variable(s): > + + :unlet perl_nofold_packages + :unlet perl_nofold_subs + + + +PHP3 and PHP4 *php.vim* *php3.vim* *ft-php-syntax* *ft-php3-syntax* + +[note: previously this was called "php3", but since it now also supports php4 +it has been renamed to "php"] + +There are the following options for the php syntax highlighting. + +If you like SQL syntax highlighting inside Strings: > + + let php_sql_query = 1 + +For highlighting the Baselib methods: > + + let php_baselib = 1 + +Enable HTML syntax highlighting inside strings: > + + let php_htmlInStrings = 1 + +Using the old colorstyle: > + + let php_oldStyle = 1 + +Enable highlighting ASP-style short tags: > + + let php_asp_tags = 1 + +Disable short tags: > + + let php_noShortTags = 1 + +For highlighting parent error ] or ): > + + let php_parent_error_close = 1 + +For skipping an php end tag, if there exists an open ( or [ without a closing +one: > + + let php_parent_error_open = 1 + +Enable folding for classes and functions: > + + let php_folding = 1 + +Selecting syncing method: > + + let php_sync_method = x + +x = -1 to sync by search (default), +x > 0 to sync at least x lines backwards, +x = 0 to sync from start. + + +PLAINTEX *plaintex.vim* *ft-plaintex-syntax* + +TeX is a typesetting language, and plaintex is the file type for the "plain" +variant of TeX. If you never want your *.tex files recognized as plain TeX, +see |ft-tex-plugin|. + +This syntax file has the option > + + let g:plaintex_delimiters = 1 + +if you want to highlight brackets "[]" and braces "{}". + + +PPWIZARD *ppwiz.vim* *ft-ppwiz-syntax* + +PPWizard is a preprocessor for HTML and OS/2 INF files + +This syntax file has the options: + +- ppwiz_highlight_defs : determines highlighting mode for PPWizard's + definitions. Possible values are + + ppwiz_highlight_defs = 1 : PPWizard #define statements retain the + colors of their contents (e.g. PPWizard macros and variables) + + ppwiz_highlight_defs = 2 : preprocessor #define and #evaluate + statements are shown in a single color with the exception of line + continuation symbols + + The default setting for ppwiz_highlight_defs is 1. + +- ppwiz_with_html : If the value is 1 (the default), highlight literal + HTML code; if 0, treat HTML code like ordinary text. + + +PHTML *phtml.vim* *ft-phtml-syntax* + +There are two options for the phtml syntax highlighting. + +If you like SQL syntax highlighting inside Strings, use this: > + + :let phtml_sql_query = 1 + +For syncing, minlines defaults to 100. If you prefer another value, you can +set "phtml_minlines" to the value you desire. Example: > + + :let phtml_minlines = 200 + + +POSTSCRIPT *postscr.vim* *ft-postscr-syntax* + +There are several options when it comes to highlighting PostScript. + +First which version of the PostScript language to highlight. There are +currently three defined language versions, or levels. Level 1 is the original +and base version, and includes all extensions prior to the release of level 2. +Level 2 is the most common version around, and includes its own set of +extensions prior to the release of level 3. Level 3 is currently the highest +level supported. You select which level of the PostScript language you want +highlighted by defining the postscr_level variable as follows: > + + :let postscr_level=2 + +If this variable is not defined it defaults to 2 (level 2) since this is +the most prevalent version currently. + +Note, not all PS interpreters will support all language features for a +particular language level. In particular the %!PS-Adobe-3.0 at the start of +PS files does NOT mean the PostScript present is level 3 PostScript! + +If you are working with Display PostScript, you can include highlighting of +Display PS language features by defining the postscr_display variable as +follows: > + + :let postscr_display=1 + +If you are working with Ghostscript, you can include highlighting of +Ghostscript specific language features by defining the variable +postscr_ghostscript as follows: > + + :let postscr_ghostscript=1 + +PostScript is a large language, with many predefined elements. While it +useful to have all these elements highlighted, on slower machines this can +cause Vim to slow down. In an attempt to be machine friendly font names and +character encodings are not highlighted by default. Unless you are working +explicitly with either of these this should be ok. If you want them to be +highlighted you should set one or both of the following variables: > + + :let postscr_fonts=1 + :let postscr_encodings=1 + +There is a stylistic option to the highlighting of and, or, and not. In +PostScript the function of these operators depends on the types of their +operands - if the operands are booleans then they are the logical operators, +if they are integers then they are binary operators. As binary and logical +operators can be highlighted differently they have to be highlighted one way +or the other. By default they are treated as logical operators. They can be +highlighted as binary operators by defining the variable +postscr_andornot_binary as follows: > + + :let postscr_andornot_binary=1 +< + + *ptcap.vim* *ft-printcap-syntax* +PRINTCAP + TERMCAP *ft-ptcap-syntax* *ft-termcap-syntax* + +This syntax file applies to the printcap and termcap databases. + +In order for Vim to recognize printcap/termcap files that do not match +the patterns *printcap*, or *termcap*, you must put additional patterns +appropriate to your system in your |myfiletypefile| file. For these +patterns, you must set the variable "b:ptcap_type" to either "print" or +"term", and then the 'filetype' option to ptcap. + +For example, to make Vim identify all files in /etc/termcaps/ as termcap +files, add the following: > + + :au BufNewFile,BufRead /etc/termcaps/* let b:ptcap_type = "term" | + \ set filetype=ptcap + +If you notice highlighting errors while scrolling backwards, which +are fixed when redrawing with CTRL-L, try setting the "ptcap_minlines" +internal variable to a larger number: > + + :let ptcap_minlines = 50 + +(The default is 20 lines.) + + +PROGRESS *progress.vim* *ft-progress-syntax* + +Files matching "*.w" could be Progress or cweb. If the automatic detection +doesn't work for you, or you don't edit cweb at all, use this in your +startup vimrc: > + :let filetype_w = "progress" +The same happens for "*.i", which could be assembly, and "*.p", which could be +Pascal. Use this if you don't use assembly and Pascal: > + :let filetype_i = "progress" + :let filetype_p = "progress" + + +PYTHON *python.vim* *ft-python-syntax* + +There are four options to control Python syntax highlighting. + +For highlighted numbers: > + :let python_highlight_numbers = 1 + +For highlighted builtin functions: > + :let python_highlight_builtins = 1 + +For highlighted standard exceptions: > + :let python_highlight_exceptions = 1 + +For highlighted trailing whitespace and mix of spaces and tabs: + :let python_highlight_space_errors = 1 + +If you want all possible Python highlighting (the same as setting the +preceding three options): > + :let python_highlight_all = 1 + + +QUAKE *quake.vim* *ft-quake-syntax* + +The Quake syntax definition should work for most any FPS (First Person +Shooter) based on one of the Quake engines. However, the command names vary +a bit between the three games (Quake, Quake 2, and Quake 3 Arena) so the +syntax definition checks for the existence of three global variables to allow +users to specify what commands are legal in their files. The three variables +can be set for the following effects: + +set to highlight commands only available in Quake: > + :let quake_is_quake1 = 1 + +set to highlight commands only available in Quake 2: > + :let quake_is_quake2 = 1 + +set to highlight commands only available in Quake 3 Arena: > + :let quake_is_quake3 = 1 + +Any combination of these three variables is legal, but might highlight more +commands than are actually available to you by the game. + + +READLINE *readline.vim* *ft-readline-syntax* + +The readline library is primarily used by the BASH shell, which adds quite a +few commands and options to the ones already available. To highlight these +items as well you can add the following to your |vimrc| or just type it in the +command line before loading a file with the readline syntax: > + let readline_has_bash = 1 + +This will add highlighting for the commands that BASH (version 2.05a and +later, and part earlier) adds. + + +REXX *rexx.vim* *ft-rexx-syntax* + +If you notice highlighting errors while scrolling backwards, which are fixed +when redrawing with CTRL-L, try setting the "rexx_minlines" internal variable +to a larger number: > + :let rexx_minlines = 50 +This will make the syntax synchronization start 50 lines before the first +displayed line. The default value is 10. The disadvantage of using a larger +number is that redrawing can become slow. + + +RUBY *ruby.vim* *ft-ruby-syntax* + +There are a number of options to the Ruby syntax highlighting. + +By default, the "end" keyword is colorized according to the opening statement +of the block it closes. While useful, this feature can be expensive; if you +experience slow redrawing (or you are on a terminal with poor color support) +you may want to turn it off by defining the "ruby_no_expensive" variable: > + + :let ruby_no_expensive = 1 +< +In this case the same color will be used for all control keywords. + +If you do want this feature enabled, but notice highlighting errors while +scrolling backwards, which are fixed when redrawing with CTRL-L, try setting +the "ruby_minlines" variable to a value larger than 50: > + + :let ruby_minlines = 100 +< +Ideally, this value should be a number of lines large enough to embrace your +largest class or module. + +Highlighting of special identifiers can be disabled by removing the +rubyIdentifier highlighting: > + + :hi link rubyIdentifier NONE +< +This will prevent highlighting of special identifiers like "ConstantName", +"$global_var", "@@class_var", "@instance_var", "| block_param |", and +":symbol". + +Significant methods of Kernel, Module and Object are highlighted by default. +This can be disabled by defining "ruby_no_special_methods": > + + :let ruby_no_special_methods = 1 +< +This will prevent highlighting of important methods such as "require", "attr", +"private", "raise" and "proc". + +Ruby operators can be highlighted. This is enabled by defining +"ruby_operators": > + + :let ruby_operators = 1 +< +Whitespace errors can be highlighted by defining "ruby_space_errors": > + + :let ruby_space_errors = 1 +< +This will highlight trailing whitespace and tabs preceded by a space character +as errors. This can be refined by defining "ruby_no_trail_space_error" and +"ruby_no_tab_space_error" which will ignore trailing whitespace and tabs after +spaces respectively. + +Folding can be enabled by defining "ruby_fold": > + + :let ruby_fold = 1 +< +This will set the 'foldmethod' option to "syntax" and allow folding of +classes, modules, methods, code blocks, heredocs and comments. + +Folding of multiline comments can be disabled by defining +"ruby_no_comment_fold": > + + :let ruby_no_comment_fold = 1 +< + +SCHEME *scheme.vim* *ft-scheme-syntax* + +By default only R5RS keywords are highlighted and properly indented. + +MzScheme-specific stuff will be used if b:is_mzscheme or g:is_mzscheme +variables are defined. + +Also scheme.vim supports keywords of the Chicken Scheme->C compiler. Define +b:is_chicken or g:is_chicken, if you need them. + + +SDL *sdl.vim* *ft-sdl-syntax* + +The SDL highlighting probably misses a few keywords, but SDL has so many +of them it's almost impossibly to cope. + +The new standard, SDL-2000, specifies that all identifiers are +case-sensitive (which was not so before), and that all keywords can be +used either completely lowercase or completely uppercase. To have the +highlighting reflect this, you can set the following variable: > + :let sdl_2000=1 + +This also sets many new keywords. If you want to disable the old +keywords, which is probably a good idea, use: > + :let SDL_no_96=1 + + +The indentation is probably also incomplete, but right now I am very +satisfied with it for my own projects. + + +SED *sed.vim* *ft-sed-syntax* + +To make tabs stand out from regular blanks (accomplished by using Todo +highlighting on the tabs), define "highlight_sedtabs" by putting > + + :let highlight_sedtabs = 1 + +in the vimrc file. (This special highlighting only applies for tabs +inside search patterns, replacement texts, addresses or text included +by an Append/Change/Insert command.) If you enable this option, it is +also a good idea to set the tab width to one character; by doing that, +you can easily count the number of tabs in a string. + +Bugs: + + The transform command (y) is treated exactly like the substitute + command. This means that, as far as this syntax file is concerned, + transform accepts the same flags as substitute, which is wrong. + (Transform accepts no flags.) I tolerate this bug because the + involved commands need very complex treatment (95 patterns, one for + each plausible pattern delimiter). + + +SGML *sgml.vim* *ft-sgml-syntax* + +The coloring scheme for tags in the SGML file works as follows. + +The <> of opening tags are colored differently than the </> of a closing tag. +This is on purpose! For opening tags the 'Function' color is used, while for +closing tags the 'Type' color is used (See syntax.vim to check how those are +defined for you) + +Known tag names are colored the same way as statements in C. Unknown tag +names are not colored which makes it easy to spot errors. + +Note that the same is true for argument (or attribute) names. Known attribute +names are colored differently than unknown ones. + +Some SGML tags are used to change the rendering of text. The following tags +are recognized by the sgml.vim syntax coloring file and change the way normal +text is shown: <varname> <emphasis> <command> <function> <literal> +<replaceable> <ulink> and <link>. + +If you want to change how such text is rendered, you must redefine the +following syntax groups: + + - sgmlBold + - sgmlBoldItalic + - sgmlUnderline + - sgmlItalic + - sgmlLink for links + +To make this redefinition work you must redefine them all and define the +following variable in your vimrc (this is due to the order in which the files +are read during initialization) > + let sgml_my_rendering=1 + +You can also disable this rendering by adding the following line to your +vimrc file: > + let sgml_no_rendering=1 + +(Adapted from the html.vim help text by Claudio Fleiner <claudio@fleiner.com>) + + +SH *sh.vim* *ft-sh-syntax* *ft-bash-syntax* *ft-ksh-syntax* + +This covers the "normal" Unix (Bourne) sh, bash and the Korn shell. + +Vim attempts to determine which shell type is in use by specifying that +various filenames are of specific types: > + + ksh : .kshrc* *.ksh + bash: .bashrc* bashrc bash.bashrc .bash_profile* *.bash +< +If none of these cases pertain, then the first line of the file is examined +(ex. /bin/sh /bin/ksh /bin/bash). If the first line specifies a shelltype, +then that shelltype is used. However some files (ex. .profile) are known to +be shell files but the type is not apparent. Furthermore, on many systems +sh is symbolically linked to "bash" (Linux, Windows+cygwin) or "ksh" (Posix). + +One may specify a global default by instantiating one of the following three +variables in your <.vimrc>: + + ksh: > + let g:is_kornshell = 1 +< posix: (using this is the same as setting is_kornshell to 1) > + let g:is_posix = 1 +< bash: > + let g:is_bash = 1 +< sh: (default) Bourne shell > + let g:is_sh = 1 + +If there's no "#! ..." line, and the user hasn't availed himself/herself of a +default sh.vim syntax setting as just shown, then syntax/sh.vim will assume +the Bourne shell syntax. No need to quote RFCs or market penetration +statistics in error reports, please -- just select the default version of the +sh your system uses in your <.vimrc>. + +The syntax/sh.vim file provides several levels of syntax-based folding: > + + let g:sh_fold_enabled= 0 (default, no syntax folding) + let g:sh_fold_enabled= 1 (enable function folding) + let g:sh_fold_enabled= 2 (enable heredoc folding) + let g:sh_fold_enabled= 4 (enable if/do/for folding) +> +then various syntax items (HereDocuments and function bodies) become +syntax-foldable (see |:syn-fold|). You also may add these together +to get multiple types of folding: > + + let g:sh_fold_enabled= 3 (enables function and heredoc folding) + +If you notice highlighting errors while scrolling backwards which are fixed +when one redraws with CTRL-L, try setting the "sh_minlines" internal variable +to a larger number. Example: > + + let sh_minlines = 500 + +This will make syntax synchronization start 500 lines before the first +displayed line. The default value is 200. The disadvantage of using a larger +number is that redrawing can become slow. + +If you don't have much to synchronize on, displaying can be very slow. To +reduce this, the "sh_maxlines" internal variable can be set. Example: > + + let sh_maxlines = 100 +< +The default is to use the twice sh_minlines. Set it to a smaller number to +speed up displaying. The disadvantage is that highlight errors may appear. + + +SPEEDUP (AspenTech plant simulator) *spup.vim* *ft-spup-syntax* + +The Speedup syntax file has some options: + +- strict_subsections : If this variable is defined, only keywords for + sections and subsections will be highlighted as statements but not + other keywords (like WITHIN in the OPERATION section). + +- highlight_types : Definition of this variable causes stream types + like temperature or pressure to be highlighted as Type, not as a + plain Identifier. Included are the types that are usually found in + the DECLARE section; if you defined own types, you have to include + them in the syntax file. + +- oneline_comments : this value ranges from 1 to 3 and determines the + highlighting of # style comments. + + oneline_comments = 1 : allow normal Speedup code after an even + number of #s. + + oneline_comments = 2 : show code starting with the second # as + error. This is the default setting. + + oneline_comments = 3 : show the whole line as error if it contains + more than one #. + +Since especially OPERATION sections tend to become very large due to +PRESETting variables, syncing may be critical. If your computer is +fast enough, you can increase minlines and/or maxlines near the end of +the syntax file. + + +SQL *sql.vim* *ft-sql-syntax* + *sqlinformix.vim* *ft-sqlinformix-syntax* + *sqlanywhere.vim* *ft-sqlanywhere-syntax* + +While there is an ANSI standard for SQL, most database engines add their own +custom extensions. Vim currently supports the Oracle and Informix dialects of +SQL. Vim assumes "*.sql" files are Oracle SQL by default. + +Vim currently has SQL support for a variety of different vendors via syntax +scripts. You can change Vim's default from Oracle to any of the current SQL +supported types. You can also easily alter the SQL dialect being used on a +buffer by buffer basis. + +For more detailed instructions see |ft_sql.txt|. + + +TCSH *tcsh.vim* *ft-tcsh-syntax* + +This covers the shell named "tcsh". It is a superset of csh. See |csh.vim| +for how the filetype is detected. + +Tcsh does not allow \" in strings unless the "backslash_quote" shell variable +is set. If you want VIM to assume that no backslash quote constructs exist add +this line to your .vimrc: > + + :let tcsh_backslash_quote = 0 + +If you notice highlighting errors while scrolling backwards, which are fixed +when redrawing with CTRL-L, try setting the "tcsh_minlines" internal variable +to a larger number: > + + :let tcsh_minlines = 1000 + +This will make the syntax synchronization start 1000 lines before the first +displayed line. If you set "tcsh_minlines" to "fromstart", then +synchronization is done from the start of the file. The default value for +tcsh_minlines is 100. The disadvantage of using a larger number is that +redrawing can become slow. + + +TEX *tex.vim* *ft-tex-syntax* + + *tex-folding* + Tex: Want Syntax Folding? ~ + +As of version 28 of <syntax/tex.vim>, syntax-based folding of parts, chapters, +sections, subsections, etc are supported. Put > + let g:tex_fold_enabled=1 +in your <.vimrc>, and :set fdm=syntax. I suggest doing the latter via a +modeline at the end of your LaTeX file: > + % vim: fdm=syntax +< + *tex-nospell* + Tex: Don't Want Spell Checking In Comments? ~ + +Some folks like to include things like source code in comments and so would +prefer that spell checking be disabled in comments in LaTeX files. To do +this, put the following in your <.vimrc>: > + let g:tex_comment_nospell= 1 +< + *tex-verb* + Tex: Want Spell Checking in Verbatim Zones?~ + +Often verbatim regions are used for things like source code; seldom does +one want source code spell-checked. However, for those of you who do +want your verbatim zones spell-checked, put the following in your <.vimrc>: > + let g:tex_verbspell= 1 +< + *tex-runon* + Tex: Run-on Comments or MathZones ~ + +The <syntax/tex.vim> highlighting supports TeX, LaTeX, and some AmsTeX. The +highlighting supports three primary zones/regions: normal, texZone, and +texMathZone. Although considerable effort has been made to have these zones +terminate properly, zones delineated by $..$ and $$..$$ cannot be synchronized +as there's no difference between start and end patterns. Consequently, a +special "TeX comment" has been provided > + %stopzone +which will forcibly terminate the highlighting of either a texZone or a +texMathZone. + + *tex-slow* + Tex: Slow Syntax Highlighting? ~ + +If you have a slow computer, you may wish to reduce the values for > + :syn sync maxlines=200 + :syn sync minlines=50 +(especially the latter). If your computer is fast, you may wish to +increase them. This primarily affects synchronizing (i.e. just what group, +if any, is the text at the top of the screen supposed to be in?). + + *tex-morecommands* *tex-package* + Tex: Want To Highlight More Commands? ~ + +LaTeX is a programmable language, and so there are thousands of packages full +of specialized LaTeX commands, syntax, and fonts. If you're using such a +package you'll often wish that the distributed syntax/tex.vim would support +it. However, clearly this is impractical. So please consider using the +techniques in |mysyntaxfile-add| to extend or modify the highlighting provided +by syntax/tex.vim. + + *tex-error* + Tex: Excessive Error Highlighting? ~ + +The <tex.vim> supports lexical error checking of various sorts. Thus, +although the error checking is ofttimes very useful, it can indicate +errors where none actually are. If this proves to be a problem for you, +you may put in your <.vimrc> the following statement: > + let tex_no_error=1 +and all error checking by <syntax/tex.vim> will be suppressed. + + *tex-math* + Tex: Need a new Math Group? ~ + +If you want to include a new math group in your LaTeX, the following +code shows you an example as to how you might do so: > + call TexNewMathZone(sfx,mathzone,starform) +You'll want to provide the new math group with a unique suffix +(currently, A-L and V-Z are taken by <syntax/tex.vim> itself). +As an example, consider how eqnarray is set up by <syntax/tex.vim>: > + call TexNewMathZone("D","eqnarray",1) +You'll need to change "mathzone" to the name of your new math group, +and then to the call to it in .vim/after/syntax/tex.vim. +The "starform" variable, if true, implies that your new math group +has a starred form (ie. eqnarray*). + + *tex-style* + Tex: Starting a New Style? ~ + +One may use "\makeatletter" in *.tex files, thereby making the use of "@" in +commands available. However, since the *.tex file doesn't have one of the +following suffices: sty cls clo dtx ltx, the syntax highlighting will flag +such use of @ as an error. To solve this: > + + :let b:tex_stylish = 1 + :set ft=tex + +Putting "let g:tex_stylish=1" into your <.vimrc> will make <syntax/tex.vim> +always accept such use of @. + + *tex-cchar* *tex-cole* *tex-conceal* + Tex: Taking Advantage of Conceal Mode~ + +If you have |'conceallevel'| set to 2 and if your encoding is utf-8, then a +number of character sequences can be translated into appropriate utf-8 glyphs, +including various accented characters, Greek characters in MathZones, and +superscripts and subscripts in MathZones. Not all characters can be made into +superscripts or subscripts; the constraint is due to what utf-8 supports. +In fact, only a few characters are supported as subscripts. + +One way to use this is to have vertically split windows (see |CTRL-W_v|); one +with |'conceallevel'| at 0 and the other at 2; and both using |'scrollbind'|. + + *g:tex_conceal* + Tex: Selective Conceal Mode~ + +You may selectively use conceal mode by setting g:tex_conceal in your +<.vimrc>. By default it is set to "admgs" to enable conceal for the +following sets of characters: > + + a = accents/ligatures + d = delimiters + m = math symbols + g = Greek + s = superscripts/subscripts +< +By leaving one or more of these out, the associated conceal-character +substitution will not be made. + + +TF *tf.vim* *ft-tf-syntax* + +There is one option for the tf syntax highlighting. + +For syncing, minlines defaults to 100. If you prefer another value, you can +set "tf_minlines" to the value you desire. Example: > + + :let tf_minlines = your choice + + +VIM *vim.vim* *ft-vim-syntax* + *g:vimsyn_minlines* *g:vimsyn_maxlines* +There is a trade-off between more accurate syntax highlighting versus screen +updating speed. To improve accuracy, you may wish to increase the +g:vimsyn_minlines variable. The g:vimsyn_maxlines variable may be used to +improve screen updating rates (see |:syn-sync| for more on this). > + + g:vimsyn_minlines : used to set synchronization minlines + g:vimsyn_maxlines : used to set synchronization maxlines +< + (g:vim_minlines and g:vim_maxlines are deprecated variants of + these two options) + + *g:vimsyn_embed* +The g:vimsyn_embed option allows users to select what, if any, types of +embedded script highlighting they wish to have. > + + g:vimsyn_embed == 0 : don't embed any scripts + g:vimsyn_embed =~ 'm' : embed mzscheme (but only if vim supports it) + g:vimsyn_embed =~ 'p' : embed perl (but only if vim supports it) + g:vimsyn_embed =~ 'P' : embed python (but only if vim supports it) + g:vimsyn_embed =~ 'r' : embed ruby (but only if vim supports it) + g:vimsyn_embed =~ 't' : embed tcl (but only if vim supports it) +< +By default, g:vimsyn_embed is "mpPr"; ie. syntax/vim.vim will support +highlighting mzscheme, perl, python, and ruby by default. Vim's has("tcl") +test appears to hang vim when tcl is not truly available. Thus, by default, +tcl is not supported for embedding (but those of you who like tcl embedded in +their vim syntax highlighting can simply include it in the g:vimembedscript +option). + *g:vimsyn_folding* + +Some folding is now supported with syntax/vim.vim: > + + g:vimsyn_folding == 0 or doesn't exist: no syntax-based folding + g:vimsyn_folding =~ 'a' : augroups + g:vimsyn_folding =~ 'f' : fold functions + g:vimsyn_folding =~ 'm' : fold mzscheme script + g:vimsyn_folding =~ 'p' : fold perl script + g:vimsyn_folding =~ 'P' : fold python script + g:vimsyn_folding =~ 'r' : fold ruby script + g:vimsyn_folding =~ 't' : fold tcl script + + *g:vimsyn_noerror* +Not all error highlighting that syntax/vim.vim does may be correct; VimL is a +difficult language to highlight correctly. A way to suppress error +highlighting is to put the following line in your |vimrc|: > + + let g:vimsyn_noerror = 1 +< + + +XF86CONFIG *xf86conf.vim* *ft-xf86conf-syntax* + +The syntax of XF86Config file differs in XFree86 v3.x and v4.x. Both +variants are supported. Automatic detection is used, but is far from perfect. +You may need to specify the version manually. Set the variable +xf86conf_xfree86_version to 3 or 4 according to your XFree86 version in +your .vimrc. Example: > + :let xf86conf_xfree86_version=3 +When using a mix of versions, set the b:xf86conf_xfree86_version variable. + +Note that spaces and underscores in option names are not supported. Use +"SyncOnGreen" instead of "__s yn con gr_e_e_n" if you want the option name +highlighted. + + +XML *xml.vim* *ft-xml-syntax* + +Xml namespaces are highlighted by default. This can be inhibited by +setting a global variable: > + + :let g:xml_namespace_transparent=1 +< + *xml-folding* +The xml syntax file provides syntax |folding| (see |:syn-fold|) between +start and end tags. This can be turned on by > + + :let g:xml_syntax_folding = 1 + :set foldmethod=syntax + +Note: syntax folding might slow down syntax highlighting significantly, +especially for large files. + + +X Pixmaps (XPM) *xpm.vim* *ft-xpm-syntax* + +xpm.vim creates its syntax items dynamically based upon the contents of the +XPM file. Thus if you make changes e.g. in the color specification strings, +you have to source it again e.g. with ":set syn=xpm". + +To copy a pixel with one of the colors, yank a "pixel" with "yl" and insert it +somewhere else with "P". + +Do you want to draw with the mouse? Try the following: > + :function! GetPixel() + : let c = getline(".")[col(".") - 1] + : echo c + : exe "noremap <LeftMouse> <LeftMouse>r".c + : exe "noremap <LeftDrag> <LeftMouse>r".c + :endfunction + :noremap <RightMouse> <LeftMouse>:call GetPixel()<CR> + :set guicursor=n:hor20 " to see the color beneath the cursor +This turns the right button into a pipette and the left button into a pen. +It will work with XPM files that have one character per pixel only and you +must not click outside of the pixel strings, but feel free to improve it. + +It will look much better with a font in a quadratic cell size, e.g. for X: > + :set guifont=-*-clean-medium-r-*-*-8-*-*-*-*-80-* + +============================================================================== +5. Defining a syntax *:syn-define* *E410* + +Vim understands three types of syntax items: + +1. Keyword + It can only contain keyword characters, according to the 'iskeyword' + option. It cannot contain other syntax items. It will only match with a + complete word (there are no keyword characters before or after the match). + The keyword "if" would match in "if(a=b)", but not in "ifdef x", because + "(" is not a keyword character and "d" is. + +2. Match + This is a match with a single regexp pattern. + +3. Region + This starts at a match of the "start" regexp pattern and ends with a match + with the "end" regexp pattern. Any other text can appear in between. A + "skip" regexp pattern can be used to avoid matching the "end" pattern. + +Several syntax ITEMs can be put into one syntax GROUP. For a syntax group +you can give highlighting attributes. For example, you could have an item +to define a "/* .. */" comment and another one that defines a "// .." comment, +and put them both in the "Comment" group. You can then specify that a +"Comment" will be in bold font and have a blue color. You are free to make +one highlight group for one syntax item, or put all items into one group. +This depends on how you want to specify your highlighting attributes. Putting +each item in its own group results in having to specify the highlighting +for a lot of groups. + +Note that a syntax group and a highlight group are similar. For a highlight +group you will have given highlight attributes. These attributes will be used +for the syntax group with the same name. + +In case more than one item matches at the same position, the one that was +defined LAST wins. Thus you can override previously defined syntax items by +using an item that matches the same text. But a keyword always goes before a +match or region. And a keyword with matching case always goes before a +keyword with ignoring case. + + +PRIORITY *:syn-priority* + +When several syntax items may match, these rules are used: + +1. When multiple Match or Region items start in the same position, the item + defined last has priority. +2. A Keyword has priority over Match and Region items. +3. An item that starts in an earlier position has priority over items that + start in later positions. + + +DEFINING CASE *:syn-case* *E390* + +:sy[ntax] case [match | ignore] + This defines if the following ":syntax" commands will work with + matching case, when using "match", or with ignoring case, when using + "ignore". Note that any items before this are not affected, and all + items until the next ":syntax case" command are affected. + + +SPELL CHECKING *:syn-spell* + +:sy[ntax] spell [toplevel | notoplevel | default] + This defines where spell checking is to be done for text that is not + in a syntax item: + + toplevel: Text is spell checked. + notoplevel: Text is not spell checked. + default: When there is a @Spell cluster no spell checking. + + For text in syntax items use the @Spell and @NoSpell clusters + |spell-syntax|. When there is no @Spell and no @NoSpell cluster then + spell checking is done for "default" and "toplevel". + + To activate spell checking the 'spell' option must be set. + + +DEFINING KEYWORDS *:syn-keyword* + +:sy[ntax] keyword {group-name} [{options}] {keyword} .. [{options}] + + This defines a number of keywords. + + {group-name} Is a syntax group name such as "Comment". + [{options}] See |:syn-arguments| below. + {keyword} .. Is a list of keywords which are part of this group. + + Example: > + :syntax keyword Type int long char +< + The {options} can be given anywhere in the line. They will apply to + all keywords given, also for options that come after a keyword. + These examples do exactly the same: > + :syntax keyword Type contained int long char + :syntax keyword Type int long contained char + :syntax keyword Type int long char contained +< *E789* + When you have a keyword with an optional tail, like Ex commands in + Vim, you can put the optional characters inside [], to define all the + variations at once: > + :syntax keyword vimCommand ab[breviate] n[ext] +< + Don't forget that a keyword can only be recognized if all the + characters are included in the 'iskeyword' option. If one character + isn't, the keyword will never be recognized. + Multi-byte characters can also be used. These do not have to be in + 'iskeyword'. + + A keyword always has higher priority than a match or region, the + keyword is used if more than one item matches. Keywords do not nest + and a keyword can't contain anything else. + + Note that when you have a keyword that is the same as an option (even + one that isn't allowed here), you can not use it. Use a match + instead. + + The maximum length of a keyword is 80 characters. + + The same keyword can be defined multiple times, when its containment + differs. For example, you can define the keyword once not contained + and use one highlight group, and once contained, and use a different + highlight group. Example: > + :syn keyword vimCommand tag + :syn keyword vimSetting contained tag +< When finding "tag" outside of any syntax item, the "vimCommand" + highlight group is used. When finding "tag" in a syntax item that + contains "vimSetting", the "vimSetting" group is used. + + +DEFINING MATCHES *:syn-match* + +:sy[ntax] match {group-name} [{options}] [excludenl] {pattern} [{options}] + + This defines one match. + + {group-name} A syntax group name such as "Comment". + [{options}] See |:syn-arguments| below. + [excludenl] Don't make a pattern with the end-of-line "$" + extend a containing match or region. Must be + given before the pattern. |:syn-excludenl| + {pattern} The search pattern that defines the match. + See |:syn-pattern| below. + Note that the pattern may match more than one + line, which makes the match depend on where + Vim starts searching for the pattern. You + need to make sure syncing takes care of this. + + Example (match a character constant): > + :syntax match Character /'.'/hs=s+1,he=e-1 +< + +DEFINING REGIONS *:syn-region* *:syn-start* *:syn-skip* *:syn-end* + *E398* *E399* +:sy[ntax] region {group-name} [{options}] + [matchgroup={group-name}] + [keepend] + [extend] + [excludenl] + start={start_pattern} .. + [skip={skip_pattern}] + end={end_pattern} .. + [{options}] + + This defines one region. It may span several lines. + + {group-name} A syntax group name such as "Comment". + [{options}] See |:syn-arguments| below. + [matchgroup={group-name}] The syntax group to use for the following + start or end pattern matches only. Not used + for the text in between the matched start and + end patterns. Use NONE to reset to not using + a different group for the start or end match. + See |:syn-matchgroup|. + keepend Don't allow contained matches to go past a + match with the end pattern. See + |:syn-keepend|. + extend Override a "keepend" for an item this region + is contained in. See |:syn-extend|. + excludenl Don't make a pattern with the end-of-line "$" + extend a containing match or item. Only + useful for end patterns. Must be given before + the patterns it applies to. |:syn-excludenl| + start={start_pattern} The search pattern that defines the start of + the region. See |:syn-pattern| below. + skip={skip_pattern} The search pattern that defines text inside + the region where not to look for the end + pattern. See |:syn-pattern| below. + end={end_pattern} The search pattern that defines the end of + the region. See |:syn-pattern| below. + + Example: > + :syntax region String start=+"+ skip=+\\"+ end=+"+ +< + The start/skip/end patterns and the options can be given in any order. + There can be zero or one skip pattern. There must be one or more + start and end patterns. This means that you can omit the skip + pattern, but you must give at least one start and one end pattern. It + is allowed to have white space before and after the equal sign + (although it mostly looks better without white space). + + When more than one start pattern is given, a match with one of these + is sufficient. This means there is an OR relation between the start + patterns. The last one that matches is used. The same is true for + the end patterns. + + The search for the end pattern starts right after the start pattern. + Offsets are not used for this. This implies that the match for the + end pattern will never overlap with the start pattern. + + The skip and end pattern can match across line breaks, but since the + search for the pattern can start in any line it often does not do what + you want. The skip pattern doesn't avoid a match of an end pattern in + the next line. Use single-line patterns to avoid trouble. + + Note: The decision to start a region is only based on a matching start + pattern. There is no check for a matching end pattern. This does NOT + work: > + :syn region First start="(" end=":" + :syn region Second start="(" end=";" +< The Second always matches before the First (last defined pattern has + higher priority). The Second region then continues until the next + ';', no matter if there is a ':' before it. Using a match does work: > + :syn match First "(\_.\{-}:" + :syn match Second "(\_.\{-};" +< This pattern matches any character or line break with "\_." and + repeats that with "\{-}" (repeat as few as possible). + + *:syn-keepend* + By default, a contained match can obscure a match for the end pattern. + This is useful for nesting. For example, a region that starts with + "{" and ends with "}", can contain another region. An encountered "}" + will then end the contained region, but not the outer region: + { starts outer "{}" region + { starts contained "{}" region + } ends contained "{}" region + } ends outer "{} region + If you don't want this, the "keepend" argument will make the matching + of an end pattern of the outer region also end any contained item. + This makes it impossible to nest the same region, but allows for + contained items to highlight parts of the end pattern, without causing + that to skip the match with the end pattern. Example: > + :syn match vimComment +"[^"]\+$+ + :syn region vimCommand start="set" end="$" contains=vimComment keepend +< The "keepend" makes the vimCommand always end at the end of the line, + even though the contained vimComment includes a match with the <EOL>. + + When "keepend" is not used, a match with an end pattern is retried + after each contained match. When "keepend" is included, the first + encountered match with an end pattern is used, truncating any + contained matches. + *:syn-extend* + The "keepend" behavior can be changed by using the "extend" argument. + When an item with "extend" is contained in an item that uses + "keepend", the "keepend" is ignored and the containing region will be + extended. + This can be used to have some contained items extend a region while + others don't. Example: > + + :syn region htmlRef start=+<a>+ end=+</a>+ keepend contains=htmlItem,htmlScript + :syn match htmlItem +<[^>]*>+ contained + :syn region htmlScript start=+<script+ end=+</script[^>]*>+ contained extend + +< Here the htmlItem item does not make the htmlRef item continue + further, it is only used to highlight the <> items. The htmlScript + item does extend the htmlRef item. + + Another example: > + :syn region xmlFold start="<a>" end="</a>" fold transparent keepend extend +< This defines a region with "keepend", so that its end cannot be + changed by contained items, like when the "</a>" is matched to + highlight it differently. But when the xmlFold region is nested (it + includes itself), the "extend" applies, so that the "</a>" of a nested + region only ends that region, and not the one it is contained in. + + *:syn-excludenl* + When a pattern for a match or end pattern of a region includes a '$' + to match the end-of-line, it will make a region item that it is + contained in continue on the next line. For example, a match with + "\\$" (backslash at the end of the line) can make a region continue + that would normally stop at the end of the line. This is the default + behavior. If this is not wanted, there are two ways to avoid it: + 1. Use "keepend" for the containing item. This will keep all + contained matches from extending the match or region. It can be + used when all contained items must not extend the containing item. + 2. Use "excludenl" in the contained item. This will keep that match + from extending the containing match or region. It can be used if + only some contained items must not extend the containing item. + "excludenl" must be given before the pattern it applies to. + + *:syn-matchgroup* + "matchgroup" can be used to highlight the start and/or end pattern + differently than the body of the region. Example: > + :syntax region String matchgroup=Quote start=+"+ skip=+\\"+ end=+"+ +< This will highlight the quotes with the "Quote" group, and the text in + between with the "String" group. + The "matchgroup" is used for all start and end patterns that follow, + until the next "matchgroup". Use "matchgroup=NONE" to go back to not + using a matchgroup. + + In a start or end pattern that is highlighted with "matchgroup" the + contained items of the region are not used. This can be used to avoid + that a contained item matches in the start or end pattern match. When + using "transparent", this does not apply to a start or end pattern + match that is highlighted with "matchgroup". + + Here is an example, which highlights three levels of parentheses in + different colors: > + :sy region par1 matchgroup=par1 start=/(/ end=/)/ contains=par2 + :sy region par2 matchgroup=par2 start=/(/ end=/)/ contains=par3 contained + :sy region par3 matchgroup=par3 start=/(/ end=/)/ contains=par1 contained + :hi par1 ctermfg=red guifg=red + :hi par2 ctermfg=blue guifg=blue + :hi par3 ctermfg=darkgreen guifg=darkgreen + +============================================================================== +6. :syntax arguments *:syn-arguments* + +The :syntax commands that define syntax items take a number of arguments. +The common ones are explained here. The arguments may be given in any order +and may be mixed with patterns. + +Not all commands accept all arguments. This table shows which arguments +can not be used for all commands: + *E395* + contains oneline fold display extend concealends~ +:syntax keyword - - - - - - +:syntax match yes - yes yes yes - +:syntax region yes yes yes yes yes yes + +These arguments can be used for all three commands: + conceal + cchar + contained + containedin + nextgroup + transparent + skipwhite + skipnl + skipempty + +conceal *conceal* *:syn-conceal* + +When the "conceal" argument is given, the item is marked as concealable. +Whether or not it is actually concealed depends on the value of the +'conceallevel' option. The 'concealcursor' option is used to decide whether +concealable items in the current line are displayed unconcealed to be able to +edit the line. + +concealends *:syn-concealends* + +When the "concealends" argument is given, the start and end matches of +the region, but not the contents of the region, are marked as concealable. +Whether or not they are actually concealed depends on the setting on the +'conceallevel' option. The ends of a region can only be concealed separately +in this way when they have their own highlighting via "matchgroup" + +cchar *:syn-cchar* + +The "cchar" argument defines the character shown in place of the item +when it is concealed (setting "cchar" only makes sense when the conceal +argument is given.) If "cchar" is not set then the default conceal +character defined in the 'listchars' option is used. Example: > + :syntax match Entity "&" conceal cchar=& +See |hl-Conceal| for highlighting. + +contained *:syn-contained* + +When the "contained" argument is given, this item will not be recognized at +the top level, but only when it is mentioned in the "contains" field of +another match. Example: > + :syntax keyword Todo TODO contained + :syntax match Comment "//.*" contains=Todo + + +display *:syn-display* + +If the "display" argument is given, this item will be skipped when the +detected highlighting will not be displayed. This will speed up highlighting, +by skipping this item when only finding the syntax state for the text that is +to be displayed. + +Generally, you can use "display" for match and region items that meet these +conditions: +- The item does not continue past the end of a line. Example for C: A region + for a "/*" comment can't contain "display", because it continues on the next + line. +- The item does not contain items that continue past the end of the line or + make it continue on the next line. +- The item does not change the size of any item it is contained in. Example + for C: A match with "\\$" in a preprocessor match can't have "display", + because it may make that preprocessor match shorter. +- The item does not allow other items to match that didn't match otherwise, + and that item may extend the match too far. Example for C: A match for a + "//" comment can't use "display", because a "/*" inside that comment would + match then and start a comment which extends past the end of the line. + +Examples, for the C language, where "display" can be used: +- match with a number +- match with a label + + +transparent *:syn-transparent* + +If the "transparent" argument is given, this item will not be highlighted +itself, but will take the highlighting of the item it is contained in. This +is useful for syntax items that don't need any highlighting but are used +only to skip over a part of the text. + +The "contains=" argument is also inherited from the item it is contained in, +unless a "contains" argument is given for the transparent item itself. To +avoid that unwanted items are contained, use "contains=NONE". Example, which +highlights words in strings, but makes an exception for "vim": > + :syn match myString /'[^']*'/ contains=myWord,myVim + :syn match myWord /\<[a-z]*\>/ contained + :syn match myVim /\<vim\>/ transparent contained contains=NONE + :hi link myString String + :hi link myWord Comment +Since the "myVim" match comes after "myWord" it is the preferred match (last +match in the same position overrules an earlier one). The "transparent" +argument makes the "myVim" match use the same highlighting as "myString". But +it does not contain anything. If the "contains=NONE" argument would be left +out, then "myVim" would use the contains argument from myString and allow +"myWord" to be contained, which will be highlighted as a Constant. This +happens because a contained match doesn't match inside itself in the same +position, thus the "myVim" match doesn't overrule the "myWord" match here. + +When you look at the colored text, it is like looking at layers of contained +items. The contained item is on top of the item it is contained in, thus you +see the contained item. When a contained item is transparent, you can look +through, thus you see the item it is contained in. In a picture: + + look from here + + | | | | | | + V V V V V V + + xxxx yyy more contained items + .................... contained item (transparent) + ============================= first item + +The 'x', 'y' and '=' represent a highlighted syntax item. The '.' represent a +transparent group. + +What you see is: + + =======xxxx=======yyy======== + +Thus you look through the transparent "....". + + +oneline *:syn-oneline* + +The "oneline" argument indicates that the region does not cross a line +boundary. It must match completely in the current line. However, when the +region has a contained item that does cross a line boundary, it continues on +the next line anyway. A contained item can be used to recognize a line +continuation pattern. But the "end" pattern must still match in the first +line, otherwise the region doesn't even start. + +When the start pattern includes a "\n" to match an end-of-line, the end +pattern must be found in the same line as where the start pattern ends. The +end pattern may also include an end-of-line. Thus the "oneline" argument +means that the end of the start pattern and the start of the end pattern must +be within one line. This can't be changed by a skip pattern that matches a +line break. + + +fold *:syn-fold* + +The "fold" argument makes the fold level increase by one for this item. +Example: > + :syn region myFold start="{" end="}" transparent fold + :syn sync fromstart + :set foldmethod=syntax +This will make each {} block form one fold. + +The fold will start on the line where the item starts, and end where the item +ends. If the start and end are within the same line, there is no fold. +The 'foldnestmax' option limits the nesting of syntax folds. +{not available when Vim was compiled without |+folding| feature} + + + *:syn-contains* *E405* *E406* *E407* *E408* *E409* +contains={groupname},.. + +The "contains" argument is followed by a list of syntax group names. These +groups will be allowed to begin inside the item (they may extend past the +containing group's end). This allows for recursive nesting of matches and +regions. If there is no "contains" argument, no groups will be contained in +this item. The group names do not need to be defined before they can be used +here. + +contains=ALL + If the only item in the contains list is "ALL", then all + groups will be accepted inside the item. + +contains=ALLBUT,{group-name},.. + If the first item in the contains list is "ALLBUT", then all + groups will be accepted inside the item, except the ones that + are listed. Example: > + :syntax region Block start="{" end="}" ... contains=ALLBUT,Function + +contains=TOP + If the first item in the contains list is "TOP", then all + groups will be accepted that don't have the "contained" + argument. +contains=TOP,{group-name},.. + Like "TOP", but excluding the groups that are listed. + +contains=CONTAINED + If the first item in the contains list is "CONTAINED", then + all groups will be accepted that have the "contained" + argument. +contains=CONTAINED,{group-name},.. + Like "CONTAINED", but excluding the groups that are + listed. + + +The {group-name} in the "contains" list can be a pattern. All group names +that match the pattern will be included (or excluded, if "ALLBUT" is used). +The pattern cannot contain white space or a ','. Example: > + ... contains=Comment.*,Keyw[0-3] +The matching will be done at moment the syntax command is executed. Groups +that are defined later will not be matched. Also, if the current syntax +command defines a new group, it is not matched. Be careful: When putting +syntax commands in a file you can't rely on groups NOT being defined, because +the file may have been sourced before, and ":syn clear" doesn't remove the +group names. + +The contained groups will also match in the start and end patterns of a +region. If this is not wanted, the "matchgroup" argument can be used +|:syn-matchgroup|. The "ms=" and "me=" offsets can be used to change the +region where contained items do match. Note that this may also limit the +area that is highlighted + + +containedin={groupname}... *:syn-containedin* + +The "containedin" argument is followed by a list of syntax group names. The +item will be allowed to begin inside these groups. This works as if the +containing item has a "contains=" argument that includes this item. + +The {groupname}... can be used just like for "contains", as explained above. + +This is useful when adding a syntax item afterwards. An item can be told to +be included inside an already existing item, without changing the definition +of that item. For example, to highlight a word in a C comment after loading +the C syntax: > + :syn keyword myword HELP containedin=cComment contained +Note that "contained" is also used, to avoid that the item matches at the top +level. + +Matches for "containedin" are added to the other places where the item can +appear. A "contains" argument may also be added as usual. Don't forget that +keywords never contain another item, thus adding them to "containedin" won't +work. + + +nextgroup={groupname},.. *:syn-nextgroup* + +The "nextgroup" argument is followed by a list of syntax group names, +separated by commas (just like with "contains", so you can also use patterns). + +If the "nextgroup" argument is given, the mentioned syntax groups will be +tried for a match, after the match or region ends. If none of the groups have +a match, highlighting continues normally. If there is a match, this group +will be used, even when it is not mentioned in the "contains" field of the +current group. This is like giving the mentioned group priority over all +other groups. Example: > + :syntax match ccFoobar "Foo.\{-}Bar" contains=ccFoo + :syntax match ccFoo "Foo" contained nextgroup=ccFiller + :syntax region ccFiller start="." matchgroup=ccBar end="Bar" contained + +This will highlight "Foo" and "Bar" differently, and only when there is a +"Bar" after "Foo". In the text line below, "f" shows where ccFoo is used for +highlighting, and "bbb" where ccBar is used. > + + Foo asdfasd Bar asdf Foo asdf Bar asdf + fff bbb fff bbb + +Note the use of ".\{-}" to skip as little as possible until the next Bar. +when ".*" would be used, the "asdf" in between "Bar" and "Foo" would be +highlighted according to the "ccFoobar" group, because the ccFooBar match +would include the first "Foo" and the last "Bar" in the line (see |pattern|). + + +skipwhite *:syn-skipwhite* +skipnl *:syn-skipnl* +skipempty *:syn-skipempty* + +These arguments are only used in combination with "nextgroup". They can be +used to allow the next group to match after skipping some text: + skipwhite skip over space and tab characters + skipnl skip over the end of a line + skipempty skip over empty lines (implies a "skipnl") + +When "skipwhite" is present, the white space is only skipped if there is no +next group that matches the white space. + +When "skipnl" is present, the match with nextgroup may be found in the next +line. This only happens when the current item ends at the end of the current +line! When "skipnl" is not present, the nextgroup will only be found after +the current item in the same line. + +When skipping text while looking for a next group, the matches for other +groups are ignored. Only when no next group matches, other items are tried +for a match again. This means that matching a next group and skipping white +space and <EOL>s has a higher priority than other items. + +Example: > + :syn match ifstart "\<if.*" nextgroup=ifline skipwhite skipempty + :syn match ifline "[^ \t].*" nextgroup=ifline skipwhite skipempty contained + :syn match ifline "endif" contained +Note that the "[^ \t].*" match matches all non-white text. Thus it would also +match "endif". Therefore the "endif" match is put last, so that it takes +precedence. +Note that this example doesn't work for nested "if"s. You need to add +"contains" arguments to make that work (omitted for simplicity of the +example). + +IMPLICIT CONCEAL *:syn-conceal-implicit* + +:sy[ntax] conceal [on|off] + This defines if the following ":syntax" commands will define keywords, + matches or regions with the "conceal" flag set. After ":syn conceal + on", all subsequent ":syn keyword", ":syn match" or ":syn region" + defined will have the "conceal" flag set implicitly. ":syn conceal + off" returns to the normal state where the "conceal" flag must be + given explicitly. + +============================================================================== +7. Syntax patterns *:syn-pattern* *E401* *E402* + +In the syntax commands, a pattern must be surrounded by two identical +characters. This is like it works for the ":s" command. The most common to +use is the double quote. But if the pattern contains a double quote, you can +use another character that is not used in the pattern. Examples: > + :syntax region Comment start="/\*" end="\*/" + :syntax region String start=+"+ end=+"+ skip=+\\"+ + +See |pattern| for the explanation of what a pattern is. Syntax patterns are +always interpreted like the 'magic' option is set, no matter what the actual +value of 'magic' is. And the patterns are interpreted like the 'l' flag is +not included in 'cpoptions'. This was done to make syntax files portable and +independent of 'compatible' and 'magic' settings. + +Try to avoid patterns that can match an empty string, such as "[a-z]*". +This slows down the highlighting a lot, because it matches everywhere. + + *:syn-pattern-offset* +The pattern can be followed by a character offset. This can be used to +change the highlighted part, and to change the text area included in the +match or region (which only matters when trying to match other items). Both +are relative to the matched pattern. The character offset for a skip +pattern can be used to tell where to continue looking for an end pattern. + +The offset takes the form of "{what}={offset}" +The {what} can be one of seven strings: + +ms Match Start offset for the start of the matched text +me Match End offset for the end of the matched text +hs Highlight Start offset for where the highlighting starts +he Highlight End offset for where the highlighting ends +rs Region Start offset for where the body of a region starts +re Region End offset for where the body of a region ends +lc Leading Context offset past "leading context" of pattern + +The {offset} can be: + +s start of the matched pattern +s+{nr} start of the matched pattern plus {nr} chars to the right +s-{nr} start of the matched pattern plus {nr} chars to the left +e end of the matched pattern +e+{nr} end of the matched pattern plus {nr} chars to the right +e-{nr} end of the matched pattern plus {nr} chars to the left +{nr} (for "lc" only): start matching {nr} chars to the left + +Examples: "ms=s+1", "hs=e-2", "lc=3". + +Although all offsets are accepted after any pattern, they are not always +meaningful. This table shows which offsets are actually used: + + ms me hs he rs re lc ~ +match item yes yes yes yes - - yes +region item start yes - yes - yes - yes +region item skip - yes - - - - yes +region item end - yes - yes - yes yes + +Offsets can be concatenated, with a ',' in between. Example: > + :syn match String /"[^"]*"/hs=s+1,he=e-1 +< + some "string" text + ^^^^^^ highlighted + +Notes: +- There must be no white space between the pattern and the character + offset(s). +- The highlighted area will never be outside of the matched text. +- A negative offset for an end pattern may not always work, because the end + pattern may be detected when the highlighting should already have stopped. +- Before Vim 7.2 the offsets were counted in bytes instead of characters. + This didn't work well for multi-byte characters, so it was changed with the + Vim 7.2 release. +- The start of a match cannot be in a line other than where the pattern + matched. This doesn't work: "a\nb"ms=e. You can make the highlighting + start in another line, this does work: "a\nb"hs=e. + +Example (match a comment but don't highlight the /* and */): > + :syntax region Comment start="/\*"hs=e+1 end="\*/"he=s-1 +< + /* this is a comment */ + ^^^^^^^^^^^^^^^^^^^ highlighted + +A more complicated Example: > + :syn region Exa matchgroup=Foo start="foo"hs=s+2,rs=e+2 matchgroup=Bar end="bar"me=e-1,he=e-1,re=s-1 +< + abcfoostringbarabc + mmmmmmmmmmm match + sssrrreee highlight start/region/end ("Foo", "Exa" and "Bar") + +Leading context *:syn-lc* *:syn-leading* *:syn-context* + +Note: This is an obsolete feature, only included for backwards compatibility +with previous Vim versions. It's now recommended to use the |/\@<=| construct +in the pattern. + +The "lc" offset specifies leading context -- a part of the pattern that must +be present, but is not considered part of the match. An offset of "lc=n" will +cause Vim to step back n columns before attempting the pattern match, allowing +characters which have already been matched in previous patterns to also be +used as leading context for this match. This can be used, for instance, to +specify that an "escaping" character must not precede the match: > + + :syn match ZNoBackslash "[^\\]z"ms=s+1 + :syn match WNoBackslash "[^\\]w"lc=1 + :syn match Underline "_\+" +< + ___zzzz ___wwww + ^^^ ^^^ matches Underline + ^ ^ matches ZNoBackslash + ^^^^ matches WNoBackslash + +The "ms" offset is automatically set to the same value as the "lc" offset, +unless you set "ms" explicitly. + + +Multi-line patterns *:syn-multi-line* + +The patterns can include "\n" to match an end-of-line. Mostly this works as +expected, but there are a few exceptions. + +When using a start pattern with an offset, the start of the match is not +allowed to start in a following line. The highlighting can start in a +following line though. Using the "\zs" item also requires that the start of +the match doesn't move to another line. + +The skip pattern can include the "\n", but the search for an end pattern will +continue in the first character of the next line, also when that character is +matched by the skip pattern. This is because redrawing may start in any line +halfway a region and there is no check if the skip pattern started in a +previous line. For example, if the skip pattern is "a\nb" and an end pattern +is "b", the end pattern does match in the second line of this: > + x x a + b x x +Generally this means that the skip pattern should not match any characters +after the "\n". + + +External matches *:syn-ext-match* + +These extra regular expression items are available in region patterns: + + */\z(* */\z(\)* *E50* *E52* + \z(\) Marks the sub-expression as "external", meaning that it is can + be accessed from another pattern match. Currently only usable + in defining a syntax region start pattern. + + */\z1* */\z2* */\z3* */\z4* */\z5* + \z1 ... \z9 */\z6* */\z7* */\z8* */\z9* *E66* *E67* + Matches the same string that was matched by the corresponding + sub-expression in a previous start pattern match. + +Sometimes the start and end patterns of a region need to share a common +sub-expression. A common example is the "here" document in Perl and many Unix +shells. This effect can be achieved with the "\z" special regular expression +items, which marks a sub-expression as "external", in the sense that it can be +referenced from outside the pattern in which it is defined. The here-document +example, for instance, can be done like this: > + :syn region hereDoc start="<<\z(\I\i*\)" end="^\z1$" + +As can be seen here, the \z actually does double duty. In the start pattern, +it marks the "\(\I\i*\)" sub-expression as external; in the end pattern, it +changes the \1 back-reference into an external reference referring to the +first external sub-expression in the start pattern. External references can +also be used in skip patterns: > + :syn region foo start="start \(\I\i*\)" skip="not end \z1" end="end \z1" + +Note that normal and external sub-expressions are completely orthogonal and +indexed separately; for instance, if the pattern "\z(..\)\(..\)" is applied +to the string "aabb", then \1 will refer to "bb" and \z1 will refer to "aa". +Note also that external sub-expressions cannot be accessed as back-references +within the same pattern like normal sub-expressions. If you want to use one +sub-expression as both a normal and an external sub-expression, you can nest +the two, as in "\(\z(...\)\)". + +Note that only matches within a single line can be used. Multi-line matches +cannot be referred to. + +============================================================================== +8. Syntax clusters *:syn-cluster* *E400* + +:sy[ntax] cluster {cluster-name} [contains={group-name}..] + [add={group-name}..] + [remove={group-name}..] + +This command allows you to cluster a list of syntax groups together under a +single name. + + contains={group-name}.. + The cluster is set to the specified list of groups. + add={group-name}.. + The specified groups are added to the cluster. + remove={group-name}.. + The specified groups are removed from the cluster. + +A cluster so defined may be referred to in a contains=.., containedin=.., +nextgroup=.., add=.. or remove=.. list with a "@" prefix. You can also use +this notation to implicitly declare a cluster before specifying its contents. + +Example: > + :syntax match Thing "# [^#]\+ #" contains=@ThingMembers + :syntax cluster ThingMembers contains=ThingMember1,ThingMember2 + +As the previous example suggests, modifications to a cluster are effectively +retroactive; the membership of the cluster is checked at the last minute, so +to speak: > + :syntax keyword A aaa + :syntax keyword B bbb + :syntax cluster AandB contains=A + :syntax match Stuff "( aaa bbb )" contains=@AandB + :syntax cluster AandB add=B " now both keywords are matched in Stuff + +This also has implications for nested clusters: > + :syntax keyword A aaa + :syntax keyword B bbb + :syntax cluster SmallGroup contains=B + :syntax cluster BigGroup contains=A,@SmallGroup + :syntax match Stuff "( aaa bbb )" contains=@BigGroup + :syntax cluster BigGroup remove=B " no effect, since B isn't in BigGroup + :syntax cluster SmallGroup remove=B " now bbb isn't matched within Stuff + +============================================================================== +9. Including syntax files *:syn-include* *E397* + +It is often useful for one language's syntax file to include a syntax file for +a related language. Depending on the exact relationship, this can be done in +two different ways: + + - If top-level syntax items in the included syntax file are to be + allowed at the top level in the including syntax, you can simply use + the |:runtime| command: > + + " In cpp.vim: + :runtime! syntax/c.vim + :unlet b:current_syntax + +< - If top-level syntax items in the included syntax file are to be + contained within a region in the including syntax, you can use the + ":syntax include" command: + +:sy[ntax] include [@{grouplist-name}] {file-name} + + All syntax items declared in the included file will have the + "contained" flag added. In addition, if a group list is specified, + all top-level syntax items in the included file will be added to + that list. > + + " In perl.vim: + :syntax include @Pod <sfile>:p:h/pod.vim + :syntax region perlPOD start="^=head" end="^=cut" contains=@Pod +< + When {file-name} is an absolute path (starts with "/", "c:", "$VAR" + or "<sfile>") that file is sourced. When it is a relative path + (e.g., "syntax/pod.vim") the file is searched for in 'runtimepath'. + All matching files are loaded. Using a relative path is + recommended, because it allows a user to replace the included file + with his own version, without replacing the file that does the ":syn + include". + +============================================================================== +10. Synchronizing *:syn-sync* *E403* *E404* + +Vim wants to be able to start redrawing in any position in the document. To +make this possible it needs to know the syntax state at the position where +redrawing starts. + +:sy[ntax] sync [ccomment [group-name] | minlines={N} | ...] + +There are four ways to synchronize: +1. Always parse from the start of the file. + |:syn-sync-first| +2. Based on C-style comments. Vim understands how C-comments work and can + figure out if the current line starts inside or outside a comment. + |:syn-sync-second| +3. Jumping back a certain number of lines and start parsing there. + |:syn-sync-third| +4. Searching backwards in the text for a pattern to sync on. + |:syn-sync-fourth| + + *:syn-sync-maxlines* *:syn-sync-minlines* +For the last three methods, the line range where the parsing can start is +limited by "minlines" and "maxlines". + +If the "minlines={N}" argument is given, the parsing always starts at least +that many lines backwards. This can be used if the parsing may take a few +lines before it's correct, or when it's not possible to use syncing. + +If the "maxlines={N}" argument is given, the number of lines that are searched +for a comment or syncing pattern is restricted to N lines backwards (after +adding "minlines"). This is useful if you have few things to sync on and a +slow machine. Example: > + :syntax sync ccomment maxlines=500 +< + *:syn-sync-linebreaks* +When using a pattern that matches multiple lines, a change in one line may +cause a pattern to no longer match in a previous line. This means has to +start above where the change was made. How many lines can be specified with +the "linebreaks" argument. For example, when a pattern may include one line +break use this: > + :syntax sync linebreaks=1 +The result is that redrawing always starts at least one line before where a +change was made. The default value for "linebreaks" is zero. Usually the +value for "minlines" is bigger than "linebreaks". + + +First syncing method: *:syn-sync-first* +> + :syntax sync fromstart + +The file will be parsed from the start. This makes syntax highlighting +accurate, but can be slow for long files. Vim caches previously parsed text, +so that it's only slow when parsing the text for the first time. However, +when making changes some part of the next needs to be parsed again (worst +case: to the end of the file). + +Using "fromstart" is equivalent to using "minlines" with a very large number. + + +Second syncing method: *:syn-sync-second* *:syn-sync-ccomment* + +For the second method, only the "ccomment" argument needs to be given. +Example: > + :syntax sync ccomment + +When Vim finds that the line where displaying starts is inside a C-style +comment, the last region syntax item with the group-name "Comment" will be +used. This requires that there is a region with the group-name "Comment"! +An alternate group name can be specified, for example: > + :syntax sync ccomment javaComment +This means that the last item specified with "syn region javaComment" will be +used for the detected C comment region. This only works properly if that +region does have a start pattern "\/*" and an end pattern "*\/". + +The "maxlines" argument can be used to restrict the search to a number of +lines. The "minlines" argument can be used to at least start a number of +lines back (e.g., for when there is some construct that only takes a few +lines, but it hard to sync on). + +Note: Syncing on a C comment doesn't work properly when strings are used +that cross a line and contain a "*/". Since letting strings cross a line +is a bad programming habit (many compilers give a warning message), and the +chance of a "*/" appearing inside a comment is very small, this restriction +is hardly ever noticed. + + +Third syncing method: *:syn-sync-third* + +For the third method, only the "minlines={N}" argument needs to be given. +Vim will subtract {N} from the line number and start parsing there. This +means {N} extra lines need to be parsed, which makes this method a bit slower. +Example: > + :syntax sync minlines=50 + +"lines" is equivalent to "minlines" (used by older versions). + + +Fourth syncing method: *:syn-sync-fourth* + +The idea is to synchronize on the end of a few specific regions, called a +sync pattern. Only regions can cross lines, so when we find the end of some +region, we might be able to know in which syntax item we are. The search +starts in the line just above the one where redrawing starts. From there +the search continues backwards in the file. + +This works just like the non-syncing syntax items. You can use contained +matches, nextgroup, etc. But there are a few differences: +- Keywords cannot be used. +- The syntax items with the "sync" keyword form a completely separated group + of syntax items. You can't mix syncing groups and non-syncing groups. +- The matching works backwards in the buffer (line by line), instead of + forwards. +- A line continuation pattern can be given. It is used to decide which group + of lines need to be searched like they were one line. This means that the + search for a match with the specified items starts in the first of the + consecutive that contain the continuation pattern. +- When using "nextgroup" or "contains", this only works within one line (or + group of continued lines). +- When using a region, it must start and end in the same line (or group of + continued lines). Otherwise the end is assumed to be at the end of the + line (or group of continued lines). +- When a match with a sync pattern is found, the rest of the line (or group of + continued lines) is searched for another match. The last match is used. + This is used when a line can contain both the start end the end of a region + (e.g., in a C-comment like /* this */, the last "*/" is used). + +There are two ways how a match with a sync pattern can be used: +1. Parsing for highlighting starts where redrawing starts (and where the + search for the sync pattern started). The syntax group that is expected + to be valid there must be specified. This works well when the regions + that cross lines cannot contain other regions. +2. Parsing for highlighting continues just after the match. The syntax group + that is expected to be present just after the match must be specified. + This can be used when the previous method doesn't work well. It's much + slower, because more text needs to be parsed. +Both types of sync patterns can be used at the same time. + +Besides the sync patterns, other matches and regions can be specified, to +avoid finding unwanted matches. + +[The reason that the sync patterns are given separately, is that mostly the +search for the sync point can be much simpler than figuring out the +highlighting. The reduced number of patterns means it will go (much) +faster.] + + *syn-sync-grouphere* *E393* *E394* + :syntax sync match {sync-group-name} grouphere {group-name} "pattern" .. + + Define a match that is used for syncing. {group-name} is the + name of a syntax group that follows just after the match. Parsing + of the text for highlighting starts just after the match. A region + must exist for this {group-name}. The first one defined will be used. + "NONE" can be used for when there is no syntax group after the match. + + *syn-sync-groupthere* + :syntax sync match {sync-group-name} groupthere {group-name} "pattern" .. + + Like "grouphere", but {group-name} is the name of a syntax group that + is to be used at the start of the line where searching for the sync + point started. The text between the match and the start of the sync + pattern searching is assumed not to change the syntax highlighting. + For example, in C you could search backwards for "/*" and "*/". If + "/*" is found first, you know that you are inside a comment, so the + "groupthere" is "cComment". If "*/" is found first, you know that you + are not in a comment, so the "groupthere" is "NONE". (in practice + it's a bit more complicated, because the "/*" and "*/" could appear + inside a string. That's left as an exercise to the reader...). + + :syntax sync match .. + :syntax sync region .. + + Without a "groupthere" argument. Define a region or match that is + skipped while searching for a sync point. + + *syn-sync-linecont* + :syntax sync linecont {pattern} + + When {pattern} matches in a line, it is considered to continue in + the next line. This means that the search for a sync point will + consider the lines to be concatenated. + +If the "maxlines={N}" argument is given too, the number of lines that are +searched for a match is restricted to N. This is useful if you have very +few things to sync on and a slow machine. Example: > + :syntax sync maxlines=100 + +You can clear all sync settings with: > + :syntax sync clear + +You can clear specific sync patterns with: > + :syntax sync clear {sync-group-name} .. + +============================================================================== +11. Listing syntax items *:syntax* *:sy* *:syn* *:syn-list* + +This command lists all the syntax items: > + + :sy[ntax] [list] + +To show the syntax items for one syntax group: > + + :sy[ntax] list {group-name} + +To list the syntax groups in one cluster: *E392* > + + :sy[ntax] list @{cluster-name} + +See above for other arguments for the ":syntax" command. + +Note that the ":syntax" command can be abbreviated to ":sy", although ":syn" +is mostly used, because it looks better. + +============================================================================== +12. Highlight command *:highlight* *:hi* *E28* *E411* *E415* + +There are three types of highlight groups: +- The ones used for specific languages. For these the name starts with the + name of the language. Many of these don't have any attributes, but are + linked to a group of the second type. +- The ones used for all syntax languages. +- The ones used for the 'highlight' option. + *hitest.vim* +You can see all the groups currently active with this command: > + :so $VIMRUNTIME/syntax/hitest.vim +This will open a new window containing all highlight group names, displayed +in their own color. + + *:colo* *:colorscheme* *E185* +:colo[rscheme] Output the name of the currently active color scheme. + This is basically the same as > + :echo g:colors_name +< In case g:colors_name has not been defined :colo will + output "default". When compiled without the |+eval| + feature it will output "unknown". + +:colo[rscheme] {name} Load color scheme {name}. This searches 'runtimepath' + for the file "colors/{name}.vim. The first one that + is found is loaded. + To see the name of the currently active color scheme: > + :colo +< The name is also stored in the g:colors_name variable. + Doesn't work recursively, thus you can't use + ":colorscheme" in a color scheme script. + After the color scheme has been loaded the + |ColorScheme| autocommand event is triggered. + For info about writing a colorscheme file: > + :edit $VIMRUNTIME/colors/README.txt + +:hi[ghlight] List all the current highlight groups that have + attributes set. + +:hi[ghlight] {group-name} + List one highlight group. + +:hi[ghlight] clear Reset all highlighting to the defaults. Removes all + highlighting for groups added by the user! + Uses the current value of 'background' to decide which + default colors to use. + +:hi[ghlight] clear {group-name} +:hi[ghlight] {group-name} NONE + Disable the highlighting for one highlight group. It + is _not_ set back to the default colors. + +:hi[ghlight] [default] {group-name} {key}={arg} .. + Add a highlight group, or change the highlighting for + an existing group. + See |highlight-args| for the {key}={arg} arguments. + See |:highlight-default| for the optional [default] + argument. + +Normally a highlight group is added once when starting up. This sets the +default values for the highlighting. After that, you can use additional +highlight commands to change the arguments that you want to set to non-default +values. The value "NONE" can be used to switch the value off or go back to +the default value. + +A simple way to change colors is with the |:colorscheme| command. This loads +a file with ":highlight" commands such as this: > + + :hi Comment gui=bold + +Note that all settings that are not included remain the same, only the +specified field is used, and settings are merged with previous ones. So, the +result is like this single command has been used: > + :hi Comment term=bold ctermfg=Cyan guifg=#80a0ff gui=bold +< + *:highlight-verbose* +When listing a highlight group and 'verbose' is non-zero, the listing will +also tell where it was last set. Example: > + :verbose hi Comment +< Comment xxx term=bold ctermfg=4 guifg=Blue ~ + Last set from /home/mool/vim/vim7/runtime/syntax/syncolor.vim ~ + +When ":hi clear" is used then the script where this command is used will be +mentioned for the default values. See |:verbose-cmd| for more information. + + *highlight-args* *E416* *E417* *E423* +There are three types of terminals for highlighting: +term a normal terminal (vt100, xterm) +cterm a color terminal (MS-DOS console, color-xterm, these have the "Co" + termcap entry) +gui the GUI + +For each type the highlighting can be given. This makes it possible to use +the same syntax file on all terminals, and use the optimal highlighting. + +1. highlight arguments for normal terminals + + *bold* *underline* *undercurl* + *inverse* *italic* *standout* +term={attr-list} *attr-list* *highlight-term* *E418* + attr-list is a comma separated list (without spaces) of the + following items (in any order): + bold + underline + undercurl not always available + reverse + inverse same as reverse + italic + standout + NONE no attributes used (used to reset it) + + Note that "bold" can be used here and by using a bold font. They + have the same effect. + "undercurl" is a curly underline. When "undercurl" is not possible + then "underline" is used. In general "undercurl" is only available in + the GUI. The color is set with |highlight-guisp|. + +start={term-list} *highlight-start* *E422* +stop={term-list} *term-list* *highlight-stop* + These lists of terminal codes can be used to get + non-standard attributes on a terminal. + + The escape sequence specified with the "start" argument + is written before the characters in the highlighted + area. It can be anything that you want to send to the + terminal to highlight this area. The escape sequence + specified with the "stop" argument is written after the + highlighted area. This should undo the "start" argument. + Otherwise the screen will look messed up. + + The {term-list} can have two forms: + + 1. A string with escape sequences. + This is any string of characters, except that it can't start with + "t_" and blanks are not allowed. The <> notation is recognized + here, so you can use things like "<Esc>" and "<Space>". Example: + start=<Esc>[27h;<Esc>[<Space>r; + + 2. A list of terminal codes. + Each terminal code has the form "t_xx", where "xx" is the name of + the termcap entry. The codes have to be separated with commas. + White space is not allowed. Example: + start=t_C1,t_BL + The terminal codes must exist for this to work. + + +2. highlight arguments for color terminals + +cterm={attr-list} *highlight-cterm* + See above for the description of {attr-list} |attr-list|. + The "cterm" argument is likely to be different from "term", when + colors are used. For example, in a normal terminal comments could + be underlined, in a color terminal they can be made Blue. + Note: Many terminals (e.g., DOS console) can't mix these attributes + with coloring. Use only one of "cterm=" OR "ctermfg=" OR "ctermbg=". + +ctermfg={color-nr} *highlight-ctermfg* *E421* +ctermbg={color-nr} *highlight-ctermbg* + The {color-nr} argument is a color number. Its range is zero to + (not including) the number given by the termcap entry "Co". + The actual color with this number depends on the type of terminal + and its settings. Sometimes the color also depends on the settings of + "cterm". For example, on some systems "cterm=bold ctermfg=3" gives + another color, on others you just get color 3. + + For an xterm this depends on your resources, and is a bit + unpredictable. See your xterm documentation for the defaults. The + colors for a color-xterm can be changed from the .Xdefaults file. + Unfortunately this means that it's not possible to get the same colors + for each user. See |xterm-color| for info about color xterms. + + The MSDOS standard colors are fixed (in a console window), so these + have been used for the names. But the meaning of color names in X11 + are fixed, so these color settings have been used, to make the + highlighting settings portable (complicated, isn't it?). The + following names are recognized, with the color number used: + + *cterm-colors* + NR-16 NR-8 COLOR NAME ~ + 0 0 Black + 1 4 DarkBlue + 2 2 DarkGreen + 3 6 DarkCyan + 4 1 DarkRed + 5 5 DarkMagenta + 6 3 Brown, DarkYellow + 7 7 LightGray, LightGrey, Gray, Grey + 8 0* DarkGray, DarkGrey + 9 4* Blue, LightBlue + 10 2* Green, LightGreen + 11 6* Cyan, LightCyan + 12 1* Red, LightRed + 13 5* Magenta, LightMagenta + 14 3* Yellow, LightYellow + 15 7* White + + The number under "NR-16" is used for 16-color terminals ('t_Co' + greater than or equal to 16). The number under "NR-8" is used for + 8-color terminals ('t_Co' less than 16). The '*' indicates that the + bold attribute is set for ctermfg. In many 8-color terminals (e.g., + "linux"), this causes the bright colors to appear. This doesn't work + for background colors! Without the '*' the bold attribute is removed. + If you want to set the bold attribute in a different way, put a + "cterm=" argument AFTER the "ctermfg=" or "ctermbg=" argument. Or use + a number instead of a color name. + + The case of the color names is ignored. + Note that for 16 color ansi style terminals (including xterms), the + numbers in the NR-8 column is used. Here '*' means 'add 8' so that Blue + is 12, DarkGray is 8 etc. + + Note that for some color terminals these names may result in the wrong + colors! + + *:hi-normal-cterm* + When setting the "ctermfg" or "ctermbg" colors for the Normal group, + these will become the colors used for the non-highlighted text. + Example: > + :highlight Normal ctermfg=grey ctermbg=darkblue +< When setting the "ctermbg" color for the Normal group, the + 'background' option will be adjusted automatically. This causes the + highlight groups that depend on 'background' to change! This means + you should set the colors for Normal first, before setting other + colors. + When a colorscheme is being used, changing 'background' causes it to + be reloaded, which may reset all colors (including Normal). First + delete the "g:colors_name" variable when you don't want this. + + When you have set "ctermfg" or "ctermbg" for the Normal group, Vim + needs to reset the color when exiting. This is done with the "op" + termcap entry |t_op|. If this doesn't work correctly, try setting the + 't_op' option in your .vimrc. + *E419* *E420* + When Vim knows the normal foreground and background colors, "fg" and + "bg" can be used as color names. This only works after setting the + colors for the Normal group and for the MS-DOS console. Example, for + reverse video: > + :highlight Visual ctermfg=bg ctermbg=fg +< Note that the colors are used that are valid at the moment this + command are given. If the Normal group colors are changed later, the + "fg" and "bg" colors will not be adjusted. + + +3. highlight arguments for the GUI + +gui={attr-list} *highlight-gui* + These give the attributes to use in the GUI mode. + See |attr-list| for a description. + Note that "bold" can be used here and by using a bold font. They + have the same effect. + Note that the attributes are ignored for the "Normal" group. + +font={font-name} *highlight-font* + font-name is the name of a font, as it is used on the system Vim + runs on. For X11 this is a complicated name, for example: > + font=-misc-fixed-bold-r-normal--14-130-75-75-c-70-iso8859-1 +< + The font-name "NONE" can be used to revert to the default font. + When setting the font for the "Normal" group, this becomes the default + font (until the 'guifont' option is changed; the last one set is + used). + The following only works with Motif and Athena, not with other GUIs: + When setting the font for the "Menu" group, the menus will be changed. + When setting the font for the "Tooltip" group, the tooltips will be + changed. + All fonts used, except for Menu and Tooltip, should be of the same + character size as the default font! Otherwise redrawing problems will + occur. + +guifg={color-name} *highlight-guifg* +guibg={color-name} *highlight-guibg* +guisp={color-name} *highlight-guisp* + These give the foreground (guifg), background (guibg) and special + (guisp) color to use in the GUI. "guisp" is used for undercurl. + There are a few special names: + NONE no color (transparent) + bg use normal background color + background use normal background color + fg use normal foreground color + foreground use normal foreground color + To use a color name with an embedded space or other special character, + put it in single quotes. The single quote cannot be used then. + Example: > + :hi comment guifg='salmon pink' +< + *gui-colors* + Suggested color names (these are available on most systems): + Red LightRed DarkRed + Green LightGreen DarkGreen SeaGreen + Blue LightBlue DarkBlue SlateBlue + Cyan LightCyan DarkCyan + Magenta LightMagenta DarkMagenta + Yellow LightYellow Brown DarkYellow + Gray LightGray DarkGray + Black White + Orange Purple Violet + + In the Win32 GUI version, additional system colors are available. See + |win32-colors|. + + You can also specify a color by its Red, Green and Blue values. + The format is "#rrggbb", where + "rr" is the Red value + "gg" is the Green value + "bb" is the Blue value + All values are hexadecimal, range from "00" to "ff". Examples: > + :highlight Comment guifg=#11f0c3 guibg=#ff00ff +< + *highlight-groups* *highlight-default* +These are the default highlighting groups. These groups are used by the +'highlight' option default. Note that the highlighting depends on the value +of 'background'. You can see the current settings with the ":highlight" +command. + *hl-ColorColumn* +ColorColumn used for the columns set with 'colorcolumn' + *hl-Conceal* +Conceal placeholder characters substituted for concealed + text (see 'conceallevel') + *hl-Cursor* +Cursor the character under the cursor + *hl-CursorIM* +CursorIM like Cursor, but used when in IME mode |CursorIM| + *hl-CursorColumn* +CursorColumn the screen column that the cursor is in when 'cursorcolumn' is + set + *hl-CursorLine* +CursorLine the screen line that the cursor is in when 'cursorline' is + set + *hl-Directory* +Directory directory names (and other special names in listings) + *hl-DiffAdd* +DiffAdd diff mode: Added line |diff.txt| + *hl-DiffChange* +DiffChange diff mode: Changed line |diff.txt| + *hl-DiffDelete* +DiffDelete diff mode: Deleted line |diff.txt| + *hl-DiffText* +DiffText diff mode: Changed text within a changed line |diff.txt| + *hl-ErrorMsg* +ErrorMsg error messages on the command line + *hl-VertSplit* +VertSplit the column separating vertically split windows + *hl-Folded* +Folded line used for closed folds + *hl-FoldColumn* +FoldColumn 'foldcolumn' + *hl-SignColumn* +SignColumn column where |signs| are displayed + *hl-IncSearch* +IncSearch 'incsearch' highlighting; also used for the text replaced with + ":s///c" + *hl-LineNr* +LineNr Line number for ":number" and ":#" commands, and when 'number' + or 'relativenumber' option is set. + *hl-MatchParen* +MatchParen The character under the cursor or just before it, if it + is a paired bracket, and its match. |pi_paren.txt| + + *hl-ModeMsg* +ModeMsg 'showmode' message (e.g., "-- INSERT --") + *hl-MoreMsg* +MoreMsg |more-prompt| + *hl-NonText* +NonText '~' and '@' at the end of the window, characters from + 'showbreak' and other characters that do not really exist in + the text (e.g., ">" displayed when a double-wide character + doesn't fit at the end of the line). + *hl-Normal* +Normal normal text + *hl-Pmenu* +Pmenu Popup menu: normal item. + *hl-PmenuSel* +PmenuSel Popup menu: selected item. + *hl-PmenuSbar* +PmenuSbar Popup menu: scrollbar. + *hl-PmenuThumb* +PmenuThumb Popup menu: Thumb of the scrollbar. + *hl-Question* +Question |hit-enter| prompt and yes/no questions + *hl-Search* +Search Last search pattern highlighting (see 'hlsearch'). + Also used for highlighting the current line in the quickfix + window and similar items that need to stand out. + *hl-SpecialKey* +SpecialKey Meta and special keys listed with ":map", also for text used + to show unprintable characters in the text, 'listchars'. + Generally: text that is displayed differently from what it + really is. + *hl-SpellBad* +SpellBad Word that is not recognized by the spellchecker. |spell| + This will be combined with the highlighting used otherwise. + *hl-SpellCap* +SpellCap Word that should start with a capital. |spell| + This will be combined with the highlighting used otherwise. + *hl-SpellLocal* +SpellLocal Word that is recognized by the spellchecker as one that is + used in another region. |spell| + This will be combined with the highlighting used otherwise. + *hl-SpellRare* +SpellRare Word that is recognized by the spellchecker as one that is + hardly ever used. |spell| + This will be combined with the highlighting used otherwise. + *hl-StatusLine* +StatusLine status line of current window + *hl-StatusLineNC* +StatusLineNC status lines of not-current windows + Note: if this is equal to "StatusLine" Vim will use "^^^" in + the status line of the current window. + *hl-TabLine* +TabLine tab pages line, not active tab page label + *hl-TabLineFill* +TabLineFill tab pages line, where there are no labels + *hl-TabLineSel* +TabLineSel tab pages line, active tab page label + *hl-Title* +Title titles for output from ":set all", ":autocmd" etc. + *hl-Visual* +Visual Visual mode selection + *hl-VisualNOS* +VisualNOS Visual mode selection when vim is "Not Owning the Selection". + Only X11 Gui's |gui-x11| and |xterm-clipboard| supports this. + *hl-WarningMsg* +WarningMsg warning messages + *hl-WildMenu* +WildMenu current match in 'wildmenu' completion + + *hl-User1* *hl-User1..9* *hl-User9* +The 'statusline' syntax allows the use of 9 different highlights in the +statusline and ruler (via 'rulerformat'). The names are User1 to User9. + +For the GUI you can use the following groups to set the colors for the menu, +scrollbars and tooltips. They don't have defaults. This doesn't work for the +Win32 GUI. Only three highlight arguments have any effect here: font, guibg, +and guifg. + + *hl-Menu* +Menu Current font, background and foreground colors of the menus. + Also used for the toolbar. + Applicable highlight arguments: font, guibg, guifg. + + NOTE: For Motif and Athena the font argument actually + specifies a fontset at all times, no matter if 'guifontset' is + empty, and as such it is tied to the current |:language| when + set. + + *hl-Scrollbar* +Scrollbar Current background and foreground of the main window's + scrollbars. + Applicable highlight arguments: guibg, guifg. + + *hl-Tooltip* +Tooltip Current font, background and foreground of the tooltips. + Applicable highlight arguments: font, guibg, guifg. + + NOTE: For Motif and Athena the font argument actually + specifies a fontset at all times, no matter if 'guifontset' is + empty, and as such it is tied to the current |:language| when + set. + +============================================================================== +13. Linking groups *:hi-link* *:highlight-link* *E412* *E413* + +When you want to use the same highlighting for several syntax groups, you +can do this more easily by linking the groups into one common highlight +group, and give the color attributes only for that group. + +To set a link: + + :hi[ghlight][!] [default] link {from-group} {to-group} + +To remove a link: + + :hi[ghlight][!] [default] link {from-group} NONE + +Notes: *E414* +- If the {from-group} and/or {to-group} doesn't exist, it is created. You + don't get an error message for a non-existing group. +- As soon as you use a ":highlight" command for a linked group, the link is + removed. +- If there are already highlight settings for the {from-group}, the link is + not made, unless the '!' is given. For a ":highlight link" command in a + sourced file, you don't get an error message. This can be used to skip + links for groups that already have settings. + + *:hi-default* *:highlight-default* +The [default] argument is used for setting the default highlighting for a +group. If highlighting has already been specified for the group the command +will be ignored. Also when there is an existing link. + +Using [default] is especially useful to overrule the highlighting of a +specific syntax file. For example, the C syntax file contains: > + :highlight default link cComment Comment +If you like Question highlighting for C comments, put this in your vimrc file: > + :highlight link cComment Question +Without the "default" in the C syntax file, the highlighting would be +overruled when the syntax file is loaded. + +============================================================================== +14. Cleaning up *:syn-clear* *E391* + +If you want to clear the syntax stuff for the current buffer, you can use this +command: > + :syntax clear + +This command should be used when you want to switch off syntax highlighting, +or when you want to switch to using another syntax. It's normally not needed +in a syntax file itself, because syntax is cleared by the autocommands that +load the syntax file. +The command also deletes the "b:current_syntax" variable, since no syntax is +loaded after this command. + +If you want to disable syntax highlighting for all buffers, you need to remove +the autocommands that load the syntax files: > + :syntax off + +What this command actually does, is executing the command > + :source $VIMRUNTIME/syntax/nosyntax.vim +See the "nosyntax.vim" file for details. Note that for this to work +$VIMRUNTIME must be valid. See |$VIMRUNTIME|. + +To clean up specific syntax groups for the current buffer: > + :syntax clear {group-name} .. +This removes all patterns and keywords for {group-name}. + +To clean up specific syntax group lists for the current buffer: > + :syntax clear @{grouplist-name} .. +This sets {grouplist-name}'s contents to an empty list. + + *:syntax-reset* *:syn-reset* +If you have changed the colors and messed them up, use this command to get the +defaults back: > + + :syntax reset + +This doesn't change the colors for the 'highlight' option. + +Note that the syntax colors that you set in your vimrc file will also be reset +back to their Vim default. +Note that if you are using a color scheme, the colors defined by the color +scheme for syntax highlighting will be lost. + +What this actually does is: > + + let g:syntax_cmd = "reset" + runtime! syntax/syncolor.vim + +Note that this uses the 'runtimepath' option. + + *syncolor* +If you want to use different colors for syntax highlighting, you can add a Vim +script file to set these colors. Put this file in a directory in +'runtimepath' which comes after $VIMRUNTIME, so that your settings overrule +the default colors. This way these colors will be used after the ":syntax +reset" command. + +For Unix you can use the file ~/.vim/after/syntax/syncolor.vim. Example: > + + if &background == "light" + highlight comment ctermfg=darkgreen guifg=darkgreen + else + highlight comment ctermfg=green guifg=green + endif + + *E679* +Do make sure this syncolor.vim script does not use a "syntax on", set the +'background' option or uses a "colorscheme" command, because it results in an +endless loop. + +Note that when a color scheme is used, there might be some confusion whether +your defined colors are to be used or the colors from the scheme. This +depends on the color scheme file. See |:colorscheme|. + + *syntax_cmd* +The "syntax_cmd" variable is set to one of these values when the +syntax/syncolor.vim files are loaded: + "on" ":syntax on" command. Highlight colors are overruled but + links are kept + "enable" ":syntax enable" command. Only define colors for groups that + don't have highlighting yet. Use ":syntax default". + "reset" ":syntax reset" command or loading a color scheme. Define all + the colors. + "skip" Don't define colors. Used to skip the default settings when a + syncolor.vim file earlier in 'runtimepath' has already set + them. + +============================================================================== +15. Highlighting tags *tag-highlight* + +If you want to highlight all the tags in your file, you can use the following +mappings. + + <F11> -- Generate tags.vim file, and highlight tags. + <F12> -- Just highlight tags based on existing tags.vim file. +> + :map <F11> :sp tags<CR>:%s/^\([^ :]*:\)\=\([^ ]*\).*/syntax keyword Tag \2/<CR>:wq! tags.vim<CR>/^<CR><F12> + :map <F12> :so tags.vim<CR> + +WARNING: The longer the tags file, the slower this will be, and the more +memory Vim will consume. + +Only highlighting typedefs, unions and structs can be done too. For this you +must use Exuberant ctags (found at http://ctags.sf.net). + +Put these lines in your Makefile: + +# Make a highlight file for types. Requires Exuberant ctags and awk +types: types.vim +types.vim: *.[ch] + ctags --c-kinds=gstu -o- *.[ch] |\ + awk 'BEGIN{printf("syntax keyword Type\t")}\ + {printf("%s ", $$1)}END{print ""}' > $@ + +And put these lines in your .vimrc: > + + " load the types.vim highlighting file, if it exists + autocmd BufRead,BufNewFile *.[ch] let fname = expand('<afile>:p:h') . '/types.vim' + autocmd BufRead,BufNewFile *.[ch] if filereadable(fname) + autocmd BufRead,BufNewFile *.[ch] exe 'so ' . fname + autocmd BufRead,BufNewFile *.[ch] endif + +============================================================================== +16. Window-local syntax *:ownsyntax* + +Normally all windows on a buffer share the same syntax settings. It is +possible, however, to set a particular window on a file to have its own +private syntax setting. A possible example would be to edit LaTeX source +with conventional highlighting in one window, while seeing the same source +highlighted differently (so as to hide control sequences and indicate bold, +italic etc regions) in another. The 'scrollbind' option is useful here. + +To set the current window to have the syntax "foo", separately from all other +windows on the buffer: > + :ownsyntax foo +< *w:current_syntax* +This will set the "w:current_syntax" variable to "foo". The value of +"b:current_syntax" does not change. This is implemented by saving and +restoring "b:current_syntax", since the syntax files do set +"b:current_syntax". The value set by the syntax file is assigned to +"w:current_syntax". + +Once a window has its own syntax, syntax commands executed from other windows +on the same buffer (including :syntax clear) have no effect. Conversely, +syntax commands executed from that window do not effect other windows on the +same buffer. + +A window with its own syntax reverts to normal behavior when another buffer +is loaded into that window or the file is reloaded. +When splitting the window, the new window will use the original syntax. + +============================================================================== +16. Color xterms *xterm-color* *color-xterm* + +Most color xterms have only eight colors. If you don't get colors with the +default setup, it should work with these lines in your .vimrc: > + :if &term =~ "xterm" + : if has("terminfo") + : set t_Co=8 + : set t_Sf=<Esc>[3%p1%dm + : set t_Sb=<Esc>[4%p1%dm + : else + : set t_Co=8 + : set t_Sf=<Esc>[3%dm + : set t_Sb=<Esc>[4%dm + : endif + :endif +< [<Esc> is a real escape, type CTRL-V <Esc>] + +You might want to change the first "if" to match the name of your terminal, +e.g. "dtterm" instead of "xterm". + +Note: Do these settings BEFORE doing ":syntax on". Otherwise the colors may +be wrong. + *xiterm* *rxvt* +The above settings have been mentioned to work for xiterm and rxvt too. +But for using 16 colors in an rxvt these should work with terminfo: > + :set t_AB=<Esc>[%?%p1%{8}%<%t25;%p1%{40}%+%e5;%p1%{32}%+%;%dm + :set t_AF=<Esc>[%?%p1%{8}%<%t22;%p1%{30}%+%e1;%p1%{22}%+%;%dm +< + *colortest.vim* +To test your color setup, a file has been included in the Vim distribution. +To use it, execute this command: > + :runtime syntax/colortest.vim + +Some versions of xterm (and other terminals, like the Linux console) can +output lighter foreground colors, even though the number of colors is defined +at 8. Therefore Vim sets the "cterm=bold" attribute for light foreground +colors, when 't_Co' is 8. + + *xfree-xterm* +To get 16 colors or more, get the newest xterm version (which should be +included with XFree86 3.3 and later). You can also find the latest version +at: > + http://invisible-island.net/xterm/xterm.html +Here is a good way to configure it. This uses 88 colors and enables the +termcap-query feature, which allows Vim to ask the xterm how many colors it +supports. > + ./configure --disable-bold-color --enable-88-color --enable-tcap-query +If you only get 8 colors, check the xterm compilation settings. +(Also see |UTF8-xterm| for using this xterm with UTF-8 character encoding). + +This xterm should work with these lines in your .vimrc (for 16 colors): > + :if has("terminfo") + : set t_Co=16 + : set t_AB=<Esc>[%?%p1%{8}%<%t%p1%{40}%+%e%p1%{92}%+%;%dm + : set t_AF=<Esc>[%?%p1%{8}%<%t%p1%{30}%+%e%p1%{82}%+%;%dm + :else + : set t_Co=16 + : set t_Sf=<Esc>[3%dm + : set t_Sb=<Esc>[4%dm + :endif +< [<Esc> is a real escape, type CTRL-V <Esc>] + +Without |+terminfo|, Vim will recognize these settings, and automatically +translate cterm colors of 8 and above to "<Esc>[9%dm" and "<Esc>[10%dm". +Colors above 16 are also translated automatically. + +For 256 colors this has been reported to work: > + + :set t_AB=<Esc>[48;5;%dm + :set t_AF=<Esc>[38;5;%dm + +Or just set the TERM environment variable to "xterm-color" or "xterm-16color" +and try if that works. + +You probably want to use these X resources (in your ~/.Xdefaults file): + XTerm*color0: #000000 + XTerm*color1: #c00000 + XTerm*color2: #008000 + XTerm*color3: #808000 + XTerm*color4: #0000c0 + XTerm*color5: #c000c0 + XTerm*color6: #008080 + XTerm*color7: #c0c0c0 + XTerm*color8: #808080 + XTerm*color9: #ff6060 + XTerm*color10: #00ff00 + XTerm*color11: #ffff00 + XTerm*color12: #8080ff + XTerm*color13: #ff40ff + XTerm*color14: #00ffff + XTerm*color15: #ffffff + Xterm*cursorColor: Black + +[Note: The cursorColor is required to work around a bug, which changes the +cursor color to the color of the last drawn text. This has been fixed by a +newer version of xterm, but not everybody is using it yet.] + +To get these right away, reload the .Xdefaults file to the X Option database +Manager (you only need to do this when you just changed the .Xdefaults file): > + xrdb -merge ~/.Xdefaults +< + *xterm-blink* *xterm-blinking-cursor* +To make the cursor blink in an xterm, see tools/blink.c. Or use Thomas +Dickey's xterm above patchlevel 107 (see above for where to get it), with +these resources: + XTerm*cursorBlink: on + XTerm*cursorOnTime: 400 + XTerm*cursorOffTime: 250 + XTerm*cursorColor: White + + *hpterm-color* +These settings work (more or less) for an hpterm, which only supports 8 +foreground colors: > + :if has("terminfo") + : set t_Co=8 + : set t_Sf=<Esc>[&v%p1%dS + : set t_Sb=<Esc>[&v7S + :else + : set t_Co=8 + : set t_Sf=<Esc>[&v%dS + : set t_Sb=<Esc>[&v7S + :endif +< [<Esc> is a real escape, type CTRL-V <Esc>] + + *Eterm* *enlightened-terminal* +These settings have been reported to work for the Enlightened terminal +emulator, or Eterm. They might work for all xterm-like terminals that use the +bold attribute to get bright colors. Add an ":if" like above when needed. > + :set t_Co=16 + :set t_AF=^[[%?%p1%{8}%<%t3%p1%d%e%p1%{22}%+%d;1%;m + :set t_AB=^[[%?%p1%{8}%<%t4%p1%d%e%p1%{32}%+%d;1%;m +< + *TTpro-telnet* +These settings should work for TTpro telnet. Tera Term Pro is a freeware / +open-source program for MS-Windows. > + set t_Co=16 + set t_AB=^[[%?%p1%{8}%<%t%p1%{40}%+%e%p1%{32}%+5;%;%dm + set t_AF=^[[%?%p1%{8}%<%t%p1%{30}%+%e%p1%{22}%+1;%;%dm +Also make sure TTpro's Setup / Window / Full Color is enabled, and make sure +that Setup / Font / Enable Bold is NOT enabled. +(info provided by John Love-Jensen <eljay@Adobe.COM>) + + vim:tw=78:sw=4:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/tabpage.txt b/share/vim/vim73/doc/tabpage.txt new file mode 100644 index 0000000000..a30d3a1797 --- /dev/null +++ b/share/vim/vim73/doc/tabpage.txt @@ -0,0 +1,382 @@ +*tabpage.txt* For Vim version 7.3. Last change: 2010 Jul 31 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + +Editing with windows in multiple tab pages. *tab-page* *tabpage* + +The commands which have been added to use multiple tab pages are explained +here. Additionally, there are explanations for commands that work differently +when used in combination with more than one tab page. + +1. Introduction |tab-page-intro| +2. Commands |tab-page-commands| +3. Other items |tab-page-other| +4. Setting 'tabline' |setting-tabline| +5. Setting 'guitablabel' |setting-guitablabel| + +{Vi does not have any of these commands} +{not able to use multiple tab pages when the |+windows| feature was disabled +at compile time} + +============================================================================== +1. Introduction *tab-page-intro* + +A tab page holds one or more windows. You can easily switch between tab +pages, so that you have several collections of windows to work on different +things. + +Usually you will see a list of labels at the top of the Vim window, one for +each tab page. With the mouse you can click on the label to jump to that tab +page. There are other ways to move between tab pages, see below. + +Most commands work only in the current tab page. That includes the |CTRL-W| +commands, |:windo|, |:all| and |:ball| (when not using the |:tab| modifier). +The commands that are aware of other tab pages than the current one are +mentioned below. + +Tabs are also a nice way to edit a buffer temporarily without changing the +current window layout. Open a new tab page, do whatever you want to do and +close the tab page. + +============================================================================== +2. Commands *tab-page-commands* + +OPENING A NEW TAB PAGE: + +When starting Vim "vim -p filename ..." opens each file argument in a separate +tab page (up to 'tabpagemax'). See |-p| + +A double click with the mouse in the non-GUI tab pages line opens a new, empty +tab page. It is placed left of the position of the click. The first click +may select another tab page first, causing an extra screen update. + +This also works in a few GUI versions, esp. Win32 and Motif. But only when +clicking right of the labels. + +In the GUI tab pages line you can use the right mouse button to open menu. +|tabline-menu|. + +:[count]tabe[dit] *:tabe* *:tabedit* *:tabnew* +:[count]tabnew + Open a new tab page with an empty window, after the current + tab page. For [count] see |:tab| below. + +:[count]tabe[dit] [++opt] [+cmd] {file} +:[count]tabnew [++opt] [+cmd] {file} + Open a new tab page and edit {file}, like with |:edit|. + For [count] see |:tab| below. + +:[count]tabf[ind] [++opt] [+cmd] {file} *:tabf* *:tabfind* + Open a new tab page and edit {file} in 'path', like with + |:find|. For [count] see |:tab| below. + {not available when the |+file_in_path| feature was disabled + at compile time} + +:[count]tab {cmd} *:tab* + Execute {cmd} and when it opens a new window open a new tab + page instead. Doesn't work for |:diffsplit|, |:diffpatch|, + |:execute| and |:normal|. + When [count] is omitted the tab page appears after the current + one. + When [count] is specified the new tab page comes after tab + page [count]. Use ":0tab cmd" to get the new tab page as the + first one. + Examples: > + :tab split " opens current buffer in new tab page + :tab help gt " opens tab page with help for "gt" + +CTRL-W gf Open a new tab page and edit the file name under the cursor. + See |CTRL-W_gf|. + +CTRL-W gF Open a new tab page and edit the file name under the cursor + and jump to the line number following the file name. + See |CTRL-W_gF|. + +CLOSING A TAB PAGE: + +Closing the last window of a tab page closes the tab page too, unless there is +only one tab page. + +Using the mouse: If the tab page line is displayed you can click in the "X" at +the top right to close the current tab page. A custom |'tabline'| may show +something else. + + *:tabc* *:tabclose* +:tabc[lose][!] Close current tab page. + This command fails when: + - There is only one tab page on the screen. *E784* + - When 'hidden' is not set, [!] is not used, a buffer has + changes, and there is no other window on this buffer. + Changes to the buffer are not written and won't get lost, so + this is a "safe" command. + +:tabc[lose][!] {count} + Close tab page {count}. Fails in the same way as ':tabclose" + above. + + *:tabo* *:tabonly* +:tabo[nly][!] Close all other tab pages. + When the 'hidden' option is set, all buffers in closed windows + become hidden. + When 'hidden' is not set, and the 'autowrite' option is set, + modified buffers are written. Otherwise, windows that have + buffers that are modified are not removed, unless the [!] is + given, then they become hidden. But modified buffers are + never abandoned, so changes cannot get lost. + + +SWITCHING TO ANOTHER TAB PAGE: + +Using the mouse: If the tab page line is displayed you can click in a tab page +label to switch to that tab page. Click where there is no label to go to the +next tab page. |'tabline'| + +:tabn[ext] *:tabn* *:tabnext* *gt* +<C-PageDown> *CTRL-<PageDown>* *<C-PageDown>* +gt *i_CTRL-<PageDown>* *i_<C-PageDown>* + Go to the next tab page. Wraps around from the last to the + first one. + +:tabn[ext] {count} +{count}<C-PageDown> +{count}gt Go to tab page {count}. The first tab page has number one. + + +:tabp[revious] *:tabp* *:tabprevious* *gT* *:tabN* +:tabN[ext] *:tabNext* *CTRL-<PageUp>* +<C-PageUp> *<C-PageUp>* *i_CTRL-<PageUp>* *i_<C-PageUp>* +gT Go to the previous tab page. Wraps around from the first one + to the last one. + +:tabp[revious] {count} +:tabN[ext] {count} +{count}<C-PageUp> +{count}gT Go {count} tab pages back. Wraps around from the first one + to the last one. + +:tabr[ewind] *:tabfir* *:tabfirst* *:tabr* *:tabrewind* +:tabfir[st] Go to the first tab page. + + *:tabl* *:tablast* +:tabl[ast] Go to the last tab page. + + +Other commands: + *:tabs* +:tabs List the tab pages and the windows they contain. + Shows a ">" for the current window. + Shows a "+" for modified buffers. + + +REORDERING TAB PAGES: + +:tabm[ove] [N] *:tabm* *:tabmove* + Move the current tab page to after tab page N. Use zero to + make the current tab page the first one. Without N the tab + page is made the last one. + + +LOOPING OVER TAB PAGES: + + *:tabd* *:tabdo* +:tabd[o] {cmd} Execute {cmd} in each tab page. + It works like doing this: > + :tabfirst + :{cmd} + :tabnext + :{cmd} + etc. +< This only operates in the current window of each tab page. + When an error is detected on one tab page, further tab pages + will not be visited. + The last tab page (or where an error occurred) becomes the + current tab page. + {cmd} can contain '|' to concatenate several commands. + {cmd} must not open or close tab pages or reorder them. + {not in Vi} {not available when compiled without the + |+listcmds| feature} + Also see |:windo|, |:argdo| and |:bufdo|. + +============================================================================== +3. Other items *tab-page-other* + + *tabline-menu* +The GUI tab pages line has a popup menu. It is accessed with a right click. +The entries are: + Close Close the tab page under the mouse pointer. The + current one if there is no label under the mouse + pointer. + New Tab Open a tab page, editing an empty buffer. It appears + to the left of the mouse pointer. + Open Tab... Like "New Tab" and additionally use a file selector to + select a file to edit. + +Diff mode works per tab page. You can see the diffs between several files +within one tab page. Other tab pages can show differences between other +files. + +Variables local to a tab page start with "t:". |tabpage-variable| + +Currently there is only one option local to a tab page: 'cmdheight'. + +The TabLeave and TabEnter autocommand events can be used to do something when +switching from one tab page to another. The exact order depends on what you +are doing. When creating a new tab page this works as if you create a new +window on the same buffer and then edit another buffer. Thus ":tabnew" +triggers: + WinLeave leave current window + TabLeave leave current tab page + TabEnter enter new tab page + WinEnter enter window in new tab page + BufLeave leave current buffer + BufEnter enter new empty buffer + +When switching to another tab page the order is: + BufLeave + WinLeave + TabLeave + TabEnter + WinEnter + BufEnter + +============================================================================== +4. Setting 'tabline' *setting-tabline* + +The 'tabline' option specifies what the line with tab pages labels looks like. +It is only used when there is no GUI tab line. + +You can use the 'showtabline' option to specify when you want the line with +tab page labels to appear: never, when there is more than one tab page or +always. + +The highlighting of the tab pages line is set with the groups TabLine +TabLineSel and TabLineFill. |hl-TabLine| |hl-TabLineSel| |hl-TabLineFill| + +A "+" will be shown for a tab page that has a modified window. The number of +windows in a tabpage is also shown. Thus "3+" means three windows and one of +them has a modified buffer. + +The 'tabline' option allows you to define your preferred way to tab pages +labels. This isn't easy, thus an example will be given here. + +For basics see the 'statusline' option. The same items can be used in the +'tabline' option. Additionally, the |tabpagebuflist()|, |tabpagenr()| and +|tabpagewinnr()| functions are useful. + +Since the number of tab labels will vary, you need to use an expression for +the whole option. Something like: > + :set tabline=%!MyTabLine() + +Then define the MyTabLine() function to list all the tab pages labels. A +convenient method is to split it in two parts: First go over all the tab +pages and define labels for them. Then get the label for each tab page. > + + function MyTabLine() + let s = '' + for i in range(tabpagenr('$')) + " select the highlighting + if i + 1 == tabpagenr() + let s .= '%#TabLineSel#' + else + let s .= '%#TabLine#' + endif + + " set the tab page number (for mouse clicks) + let s .= '%' . (i + 1) . 'T' + + " the label is made by MyTabLabel() + let s .= ' %{MyTabLabel(' . (i + 1) . ')} ' + endfor + + " after the last tab fill with TabLineFill and reset tab page nr + let s .= '%#TabLineFill#%T' + + " right-align the label to close the current tab page + if tabpagenr('$') > 1 + let s .= '%=%#TabLine#%999Xclose' + endif + + return s + endfunction + +Now the MyTabLabel() function is called for each tab page to get its label. > + + function MyTabLabel(n) + let buflist = tabpagebuflist(a:n) + let winnr = tabpagewinnr(a:n) + return bufname(buflist[winnr - 1]) + endfunction + +This is just a simplistic example that results in a tab pages line that +resembles the default, but without adding a + for a modified buffer or +truncating the names. You will want to reduce the width of labels in a +clever way when there is not enough room. Check the 'columns' option for the +space available. + +============================================================================== +5. Setting 'guitablabel' *setting-guitablabel* + +When the GUI tab pages line is displayed, 'guitablabel' can be used to +specify the label to display for each tab page. Unlike 'tabline', which +specifies the whole tab pages line at once, 'guitablabel' is used for each +label separately. + +'guitabtooltip' is very similar and is used for the tooltip of the same label. +This only appears when the mouse pointer hovers over the label, thus it +usually is longer. Only supported on some systems though. + +See the 'statusline' option for the format of the value. + +The "%N" item can be used for the current tab page number. The |v:lnum| +variable is also set to this number when the option is evaluated. +The items that use a file name refer to the current window of the tab page. + +Note that syntax highlighting is not used for the option. The %T and %X +items are also ignored. + +A simple example that puts the tab page number and the buffer name in the +label: > + :set guitablabel=%N\ %f + +An example that resembles the default 'guitablabel': Show the number of +windows in the tab page and a '+' if there is a modified buffer: > + + function GuiTabLabel() + let label = '' + let bufnrlist = tabpagebuflist(v:lnum) + + " Add '+' if one of the buffers in the tab page is modified + for bufnr in bufnrlist + if getbufvar(bufnr, "&modified") + let label = '+' + break + endif + endfor + + " Append the number of windows in the tab page if more than one + let wincount = tabpagewinnr(v:lnum, '$') + if wincount > 1 + let label .= wincount + endif + if label != '' + let label .= ' ' + endif + + " Append the buffer name + return label . bufname(bufnrlist[tabpagewinnr(v:lnum) - 1]) + endfunction + + set guitablabel=%{GuiTabLabel()} + +Note that the function must be defined before setting the option, otherwise +you get an error message for the function not being known. + +If you want to fall back to the default label, return an empty string. + +If you want to show something specific for a tab page, you might want to use a +tab page local variable. |t:var| + + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/tags b/share/vim/vim73/doc/tags new file mode 100644 index 0000000000..3ebcf41fd2 --- /dev/null +++ b/share/vim/vim73/doc/tags @@ -0,0 +1,8529 @@ +! change.txt /*!* +!! change.txt /*!!* +# pattern.txt /*#* +$ motion.txt /*$* +$HOME options.txt /*$HOME* +$HOME-use version5.txt /*$HOME-use* +$MYGVIMRC gui.txt /*$MYGVIMRC* +$MYVIMRC starting.txt /*$MYVIMRC* +$VIM starting.txt /*$VIM* +$VIM-use version5.txt /*$VIM-use* +$VIMRUNTIME starting.txt /*$VIMRUNTIME* +% motion.txt /*%* +%:. cmdline.txt /*%:.* +%:8 cmdline.txt /*%:8* +%:e cmdline.txt /*%:e* +%:gs cmdline.txt /*%:gs* +%:h cmdline.txt /*%:h* +%:p cmdline.txt /*%:p* +%:r cmdline.txt /*%:r* +%:s cmdline.txt /*%:s* +%:t cmdline.txt /*%:t* +%:~ cmdline.txt /*%:~* +& change.txt /*&* +' motion.txt /*'* +'' motion.txt /*''* +'( motion.txt /*'(* +') motion.txt /*')* +'. motion.txt /*'.* +'0 motion.txt /*'0* +'< motion.txt /*'<* +'> motion.txt /*'>* +'A motion.txt /*'A* +'[ motion.txt /*'[* +'] motion.txt /*']* +'^ motion.txt /*'^* +'a motion.txt /*'a* +'acd' options.txt /*'acd'* +'ai' options.txt /*'ai'* +'akm' options.txt /*'akm'* +'al' options.txt /*'al'* +'aleph' options.txt /*'aleph'* +'allowrevins' options.txt /*'allowrevins'* +'altkeymap' options.txt /*'altkeymap'* +'ambiwidth' options.txt /*'ambiwidth'* +'ambw' options.txt /*'ambw'* +'anti' options.txt /*'anti'* +'antialias' options.txt /*'antialias'* +'ap' vi_diff.txt /*'ap'* +'ar' options.txt /*'ar'* +'arab' options.txt /*'arab'* +'arabic' options.txt /*'arabic'* +'arabicshape' options.txt /*'arabicshape'* +'ari' options.txt /*'ari'* +'arshape' options.txt /*'arshape'* +'as' todo.txt /*'as'* +'autochdir' options.txt /*'autochdir'* +'autoindent' options.txt /*'autoindent'* +'autoprint' vi_diff.txt /*'autoprint'* +'autoread' options.txt /*'autoread'* +'autosave' todo.txt /*'autosave'* +'autowrite' options.txt /*'autowrite'* +'autowriteall' options.txt /*'autowriteall'* +'aw' options.txt /*'aw'* +'awa' options.txt /*'awa'* +'background' options.txt /*'background'* +'backspace' options.txt /*'backspace'* +'backup' options.txt /*'backup'* +'backupcopy' options.txt /*'backupcopy'* +'backupdir' options.txt /*'backupdir'* +'backupext' options.txt /*'backupext'* +'backupskip' options.txt /*'backupskip'* +'balloondelay' options.txt /*'balloondelay'* +'ballooneval' options.txt /*'ballooneval'* +'balloonexpr' options.txt /*'balloonexpr'* +'bdir' options.txt /*'bdir'* +'bdlay' options.txt /*'bdlay'* +'beautify' vi_diff.txt /*'beautify'* +'beval' options.txt /*'beval'* +'bex' options.txt /*'bex'* +'bexpr' options.txt /*'bexpr'* +'bf' vi_diff.txt /*'bf'* +'bg' options.txt /*'bg'* +'bh' options.txt /*'bh'* +'bin' options.txt /*'bin'* +'binary' options.txt /*'binary'* +'biosk' options.txt /*'biosk'* +'bioskey' options.txt /*'bioskey'* +'bk' options.txt /*'bk'* +'bkc' options.txt /*'bkc'* +'bl' options.txt /*'bl'* +'bomb' options.txt /*'bomb'* +'breakat' options.txt /*'breakat'* +'brk' options.txt /*'brk'* +'browsedir' options.txt /*'browsedir'* +'bs' options.txt /*'bs'* +'bsdir' options.txt /*'bsdir'* +'bsk' options.txt /*'bsk'* +'bt' options.txt /*'bt'* +'bufhidden' options.txt /*'bufhidden'* +'buflisted' options.txt /*'buflisted'* +'buftype' options.txt /*'buftype'* +'casemap' options.txt /*'casemap'* +'cb' options.txt /*'cb'* +'cc' options.txt /*'cc'* +'ccv' options.txt /*'ccv'* +'cd' options.txt /*'cd'* +'cdpath' options.txt /*'cdpath'* +'cedit' options.txt /*'cedit'* +'cf' options.txt /*'cf'* +'cfu' options.txt /*'cfu'* +'ch' options.txt /*'ch'* +'character' intro.txt /*'character'* +'charconvert' options.txt /*'charconvert'* +'ci' options.txt /*'ci'* +'cin' options.txt /*'cin'* +'cindent' options.txt /*'cindent'* +'cink' options.txt /*'cink'* +'cinkeys' options.txt /*'cinkeys'* +'cino' options.txt /*'cino'* +'cinoptions' options.txt /*'cinoptions'* +'cinw' options.txt /*'cinw'* +'cinwords' options.txt /*'cinwords'* +'clipboard' options.txt /*'clipboard'* +'cm' options.txt /*'cm'* +'cmdheight' options.txt /*'cmdheight'* +'cmdwinheight' options.txt /*'cmdwinheight'* +'cmp' options.txt /*'cmp'* +'cms' options.txt /*'cms'* +'co' options.txt /*'co'* +'cocu' options.txt /*'cocu'* +'cole' options.txt /*'cole'* +'colorcolumn' options.txt /*'colorcolumn'* +'columns' options.txt /*'columns'* +'com' options.txt /*'com'* +'comments' options.txt /*'comments'* +'commentstring' options.txt /*'commentstring'* +'compatible' options.txt /*'compatible'* +'complete' options.txt /*'complete'* +'completefunc' options.txt /*'completefunc'* +'completeopt' options.txt /*'completeopt'* +'concealcursor' options.txt /*'concealcursor'* +'conceallevel' options.txt /*'conceallevel'* +'confirm' options.txt /*'confirm'* +'consk' options.txt /*'consk'* +'conskey' options.txt /*'conskey'* +'copyindent' options.txt /*'copyindent'* +'cot' options.txt /*'cot'* +'cp' options.txt /*'cp'* +'cpo' options.txt /*'cpo'* +'cpoptions' options.txt /*'cpoptions'* +'cpt' options.txt /*'cpt'* +'crb' options.txt /*'crb'* +'cryptmethod' options.txt /*'cryptmethod'* +'cscopepathcomp' options.txt /*'cscopepathcomp'* +'cscopeprg' options.txt /*'cscopeprg'* +'cscopequickfix' options.txt /*'cscopequickfix'* +'cscopetag' options.txt /*'cscopetag'* +'cscopetagorder' options.txt /*'cscopetagorder'* +'cscopeverbose' options.txt /*'cscopeverbose'* +'cspc' options.txt /*'cspc'* +'csprg' options.txt /*'csprg'* +'csqf' options.txt /*'csqf'* +'cst' options.txt /*'cst'* +'csto' options.txt /*'csto'* +'csverb' options.txt /*'csverb'* +'cuc' options.txt /*'cuc'* +'cul' options.txt /*'cul'* +'cursorbind' options.txt /*'cursorbind'* +'cursorcolumn' options.txt /*'cursorcolumn'* +'cursorline' options.txt /*'cursorline'* +'cwh' options.txt /*'cwh'* +'debug' options.txt /*'debug'* +'deco' options.txt /*'deco'* +'def' options.txt /*'def'* +'define' options.txt /*'define'* +'delcombine' options.txt /*'delcombine'* +'dex' options.txt /*'dex'* +'dg' options.txt /*'dg'* +'dict' options.txt /*'dict'* +'dictionary' options.txt /*'dictionary'* +'diff' options.txt /*'diff'* +'diffexpr' options.txt /*'diffexpr'* +'diffopt' options.txt /*'diffopt'* +'digraph' options.txt /*'digraph'* +'dip' options.txt /*'dip'* +'dir' options.txt /*'dir'* +'directory' options.txt /*'directory'* +'display' options.txt /*'display'* +'dy' options.txt /*'dy'* +'ea' options.txt /*'ea'* +'ead' options.txt /*'ead'* +'eadirection' options.txt /*'eadirection'* +'eb' options.txt /*'eb'* +'ed' options.txt /*'ed'* +'edcompatible' options.txt /*'edcompatible'* +'ef' options.txt /*'ef'* +'efm' options.txt /*'efm'* +'ei' options.txt /*'ei'* +'ek' options.txt /*'ek'* +'enc' options.txt /*'enc'* +'encoding' options.txt /*'encoding'* +'endofline' options.txt /*'endofline'* +'eol' options.txt /*'eol'* +'ep' options.txt /*'ep'* +'equalalways' options.txt /*'equalalways'* +'equalprg' options.txt /*'equalprg'* +'errorbells' options.txt /*'errorbells'* +'errorfile' options.txt /*'errorfile'* +'errorformat' options.txt /*'errorformat'* +'esckeys' options.txt /*'esckeys'* +'et' options.txt /*'et'* +'eventignore' options.txt /*'eventignore'* +'ex' options.txt /*'ex'* +'expandtab' options.txt /*'expandtab'* +'exrc' options.txt /*'exrc'* +'fcl' options.txt /*'fcl'* +'fcs' options.txt /*'fcs'* +'fdc' options.txt /*'fdc'* +'fde' options.txt /*'fde'* +'fdi' options.txt /*'fdi'* +'fdl' options.txt /*'fdl'* +'fdls' options.txt /*'fdls'* +'fdm' options.txt /*'fdm'* +'fdn' options.txt /*'fdn'* +'fdo' options.txt /*'fdo'* +'fdt' options.txt /*'fdt'* +'fe' options.txt /*'fe'* +'fen' options.txt /*'fen'* +'fenc' options.txt /*'fenc'* +'fencs' options.txt /*'fencs'* +'fex' options.txt /*'fex'* +'ff' options.txt /*'ff'* +'ffs' options.txt /*'ffs'* +'fileencoding' options.txt /*'fileencoding'* +'fileencodings' options.txt /*'fileencodings'* +'fileformat' options.txt /*'fileformat'* +'fileformats' options.txt /*'fileformats'* +'filetype' options.txt /*'filetype'* +'fillchars' options.txt /*'fillchars'* +'fk' options.txt /*'fk'* +'fkmap' options.txt /*'fkmap'* +'fl' vi_diff.txt /*'fl'* +'flash' vi_diff.txt /*'flash'* +'flp' options.txt /*'flp'* +'fml' options.txt /*'fml'* +'fmr' options.txt /*'fmr'* +'fo' options.txt /*'fo'* +'foldclose' options.txt /*'foldclose'* +'foldcolumn' options.txt /*'foldcolumn'* +'foldenable' options.txt /*'foldenable'* +'foldexpr' options.txt /*'foldexpr'* +'foldignore' options.txt /*'foldignore'* +'foldlevel' options.txt /*'foldlevel'* +'foldlevelstart' options.txt /*'foldlevelstart'* +'foldmarker' options.txt /*'foldmarker'* +'foldmethod' options.txt /*'foldmethod'* +'foldminlines' options.txt /*'foldminlines'* +'foldnestmax' options.txt /*'foldnestmax'* +'foldopen' options.txt /*'foldopen'* +'foldtext' options.txt /*'foldtext'* +'formatexpr' options.txt /*'formatexpr'* +'formatlistpat' options.txt /*'formatlistpat'* +'formatoptions' options.txt /*'formatoptions'* +'formatprg' options.txt /*'formatprg'* +'fp' options.txt /*'fp'* +'fs' options.txt /*'fs'* +'fsync' options.txt /*'fsync'* +'ft' options.txt /*'ft'* +'gcr' options.txt /*'gcr'* +'gd' options.txt /*'gd'* +'gdefault' options.txt /*'gdefault'* +'gfm' options.txt /*'gfm'* +'gfn' options.txt /*'gfn'* +'gfs' options.txt /*'gfs'* +'gfw' options.txt /*'gfw'* +'ghr' options.txt /*'ghr'* +'go' options.txt /*'go'* +'go-A' options.txt /*'go-A'* +'go-F' options.txt /*'go-F'* +'go-L' options.txt /*'go-L'* +'go-M' options.txt /*'go-M'* +'go-R' options.txt /*'go-R'* +'go-T' options.txt /*'go-T'* +'go-a' options.txt /*'go-a'* +'go-b' options.txt /*'go-b'* +'go-c' options.txt /*'go-c'* +'go-e' options.txt /*'go-e'* +'go-f' options.txt /*'go-f'* +'go-g' options.txt /*'go-g'* +'go-h' options.txt /*'go-h'* +'go-i' options.txt /*'go-i'* +'go-l' options.txt /*'go-l'* +'go-m' options.txt /*'go-m'* +'go-p' options.txt /*'go-p'* +'go-r' options.txt /*'go-r'* +'go-t' options.txt /*'go-t'* +'go-v' options.txt /*'go-v'* +'gp' options.txt /*'gp'* +'gr' vi_diff.txt /*'gr'* +'graphic' vi_diff.txt /*'graphic'* +'grepformat' options.txt /*'grepformat'* +'grepprg' options.txt /*'grepprg'* +'gtl' options.txt /*'gtl'* +'gtt' options.txt /*'gtt'* +'guicursor' options.txt /*'guicursor'* +'guifont' options.txt /*'guifont'* +'guifontset' options.txt /*'guifontset'* +'guifontwide' options.txt /*'guifontwide'* +'guiheadroom' options.txt /*'guiheadroom'* +'guioptions' options.txt /*'guioptions'* +'guipty' options.txt /*'guipty'* +'guitablabel' options.txt /*'guitablabel'* +'guitabtooltip' options.txt /*'guitabtooltip'* +'hardtabs' vi_diff.txt /*'hardtabs'* +'helpfile' options.txt /*'helpfile'* +'helpheight' options.txt /*'helpheight'* +'helplang' options.txt /*'helplang'* +'hf' options.txt /*'hf'* +'hh' options.txt /*'hh'* +'hi' options.txt /*'hi'* +'hid' options.txt /*'hid'* +'hidden' options.txt /*'hidden'* +'highlight' options.txt /*'highlight'* +'history' options.txt /*'history'* +'hk' options.txt /*'hk'* +'hkmap' options.txt /*'hkmap'* +'hkmapp' options.txt /*'hkmapp'* +'hkp' options.txt /*'hkp'* +'hl' options.txt /*'hl'* +'hlg' options.txt /*'hlg'* +'hls' options.txt /*'hls'* +'hlsearch' options.txt /*'hlsearch'* +'ht' vi_diff.txt /*'ht'* +'ic' options.txt /*'ic'* +'icon' options.txt /*'icon'* +'iconstring' options.txt /*'iconstring'* +'ignorecase' options.txt /*'ignorecase'* +'im' options.txt /*'im'* +'imactivatekey' options.txt /*'imactivatekey'* +'imak' options.txt /*'imak'* +'imc' options.txt /*'imc'* +'imcmdline' options.txt /*'imcmdline'* +'imd' options.txt /*'imd'* +'imdisable' options.txt /*'imdisable'* +'imi' options.txt /*'imi'* +'iminsert' options.txt /*'iminsert'* +'ims' options.txt /*'ims'* +'imsearch' options.txt /*'imsearch'* +'inc' options.txt /*'inc'* +'include' options.txt /*'include'* +'includeexpr' options.txt /*'includeexpr'* +'incsearch' options.txt /*'incsearch'* +'inde' options.txt /*'inde'* +'indentexpr' options.txt /*'indentexpr'* +'indentkeys' options.txt /*'indentkeys'* +'indk' options.txt /*'indk'* +'inex' options.txt /*'inex'* +'inf' options.txt /*'inf'* +'infercase' options.txt /*'infercase'* +'insertmode' options.txt /*'insertmode'* +'is' options.txt /*'is'* +'isf' options.txt /*'isf'* +'isfname' options.txt /*'isfname'* +'isi' options.txt /*'isi'* +'isident' options.txt /*'isident'* +'isk' options.txt /*'isk'* +'iskeyword' options.txt /*'iskeyword'* +'isp' options.txt /*'isp'* +'isprint' options.txt /*'isprint'* +'joinspaces' options.txt /*'joinspaces'* +'js' options.txt /*'js'* +'key' options.txt /*'key'* +'keymap' options.txt /*'keymap'* +'keymodel' options.txt /*'keymodel'* +'keywordprg' options.txt /*'keywordprg'* +'km' options.txt /*'km'* +'kmp' options.txt /*'kmp'* +'kp' options.txt /*'kp'* +'langmap' options.txt /*'langmap'* +'langmenu' options.txt /*'langmenu'* +'laststatus' options.txt /*'laststatus'* +'lazyredraw' options.txt /*'lazyredraw'* +'lbr' options.txt /*'lbr'* +'lcs' options.txt /*'lcs'* +'linebreak' options.txt /*'linebreak'* +'lines' options.txt /*'lines'* +'linespace' options.txt /*'linespace'* +'lisp' options.txt /*'lisp'* +'lispwords' options.txt /*'lispwords'* +'list' options.txt /*'list'* +'listchars' options.txt /*'listchars'* +'lm' options.txt /*'lm'* +'lmap' options.txt /*'lmap'* +'loadplugins' options.txt /*'loadplugins'* +'lpl' options.txt /*'lpl'* +'ls' options.txt /*'ls'* +'lsp' options.txt /*'lsp'* +'lw' options.txt /*'lw'* +'lz' options.txt /*'lz'* +'ma' options.txt /*'ma'* +'macatsui' options.txt /*'macatsui'* +'magic' options.txt /*'magic'* +'makeef' options.txt /*'makeef'* +'makeprg' options.txt /*'makeprg'* +'mat' options.txt /*'mat'* +'matchpairs' options.txt /*'matchpairs'* +'matchtime' options.txt /*'matchtime'* +'maxcombine' options.txt /*'maxcombine'* +'maxfuncdepth' options.txt /*'maxfuncdepth'* +'maxmapdepth' options.txt /*'maxmapdepth'* +'maxmem' options.txt /*'maxmem'* +'maxmempattern' options.txt /*'maxmempattern'* +'maxmemtot' options.txt /*'maxmemtot'* +'mco' options.txt /*'mco'* +'mef' options.txt /*'mef'* +'menuitems' options.txt /*'menuitems'* +'mesg' vi_diff.txt /*'mesg'* +'mfd' options.txt /*'mfd'* +'mh' options.txt /*'mh'* +'mis' options.txt /*'mis'* +'mkspellmem' options.txt /*'mkspellmem'* +'ml' options.txt /*'ml'* +'mls' options.txt /*'mls'* +'mm' options.txt /*'mm'* +'mmd' options.txt /*'mmd'* +'mmp' options.txt /*'mmp'* +'mmt' options.txt /*'mmt'* +'mod' options.txt /*'mod'* +'modeline' options.txt /*'modeline'* +'modelines' options.txt /*'modelines'* +'modifiable' options.txt /*'modifiable'* +'modified' options.txt /*'modified'* +'more' options.txt /*'more'* +'mouse' options.txt /*'mouse'* +'mousef' options.txt /*'mousef'* +'mousefocus' options.txt /*'mousefocus'* +'mousehide' options.txt /*'mousehide'* +'mousem' options.txt /*'mousem'* +'mousemodel' options.txt /*'mousemodel'* +'mouses' options.txt /*'mouses'* +'mouseshape' options.txt /*'mouseshape'* +'mouset' options.txt /*'mouset'* +'mousetime' options.txt /*'mousetime'* +'mp' options.txt /*'mp'* +'mps' options.txt /*'mps'* +'msm' options.txt /*'msm'* +'mzq' options.txt /*'mzq'* +'mzquantum' options.txt /*'mzquantum'* +'nf' options.txt /*'nf'* +'noacd' options.txt /*'noacd'* +'noai' options.txt /*'noai'* +'noakm' options.txt /*'noakm'* +'noallowrevins' options.txt /*'noallowrevins'* +'noaltkeymap' options.txt /*'noaltkeymap'* +'noanti' options.txt /*'noanti'* +'noantialias' options.txt /*'noantialias'* +'noar' options.txt /*'noar'* +'noarab' options.txt /*'noarab'* +'noarabic' options.txt /*'noarabic'* +'noarabicshape' options.txt /*'noarabicshape'* +'noari' options.txt /*'noari'* +'noarshape' options.txt /*'noarshape'* +'noas' todo.txt /*'noas'* +'noautochdir' options.txt /*'noautochdir'* +'noautoindent' options.txt /*'noautoindent'* +'noautoread' options.txt /*'noautoread'* +'noautosave' todo.txt /*'noautosave'* +'noautowrite' options.txt /*'noautowrite'* +'noautowriteall' options.txt /*'noautowriteall'* +'noaw' options.txt /*'noaw'* +'noawa' options.txt /*'noawa'* +'nobackup' options.txt /*'nobackup'* +'noballooneval' options.txt /*'noballooneval'* +'nobeval' options.txt /*'nobeval'* +'nobin' options.txt /*'nobin'* +'nobinary' options.txt /*'nobinary'* +'nobiosk' options.txt /*'nobiosk'* +'nobioskey' options.txt /*'nobioskey'* +'nobk' options.txt /*'nobk'* +'nobl' options.txt /*'nobl'* +'nobomb' options.txt /*'nobomb'* +'nobuflisted' options.txt /*'nobuflisted'* +'nocf' options.txt /*'nocf'* +'noci' options.txt /*'noci'* +'nocin' options.txt /*'nocin'* +'nocindent' options.txt /*'nocindent'* +'nocompatible' options.txt /*'nocompatible'* +'noconfirm' options.txt /*'noconfirm'* +'noconsk' options.txt /*'noconsk'* +'noconskey' options.txt /*'noconskey'* +'nocopyindent' options.txt /*'nocopyindent'* +'nocp' options.txt /*'nocp'* +'nocrb' options.txt /*'nocrb'* +'nocscopetag' options.txt /*'nocscopetag'* +'nocscopeverbose' options.txt /*'nocscopeverbose'* +'nocst' options.txt /*'nocst'* +'nocsverb' options.txt /*'nocsverb'* +'nocuc' options.txt /*'nocuc'* +'nocul' options.txt /*'nocul'* +'nocursorbind' options.txt /*'nocursorbind'* +'nocursorcolumn' options.txt /*'nocursorcolumn'* +'nocursorline' options.txt /*'nocursorline'* +'nodeco' options.txt /*'nodeco'* +'nodelcombine' options.txt /*'nodelcombine'* +'nodg' options.txt /*'nodg'* +'nodiff' options.txt /*'nodiff'* +'nodigraph' options.txt /*'nodigraph'* +'noea' options.txt /*'noea'* +'noeb' options.txt /*'noeb'* +'noed' options.txt /*'noed'* +'noedcompatible' options.txt /*'noedcompatible'* +'noek' options.txt /*'noek'* +'noendofline' options.txt /*'noendofline'* +'noeol' options.txt /*'noeol'* +'noequalalways' options.txt /*'noequalalways'* +'noerrorbells' options.txt /*'noerrorbells'* +'noesckeys' options.txt /*'noesckeys'* +'noet' options.txt /*'noet'* +'noex' options.txt /*'noex'* +'noexpandtab' options.txt /*'noexpandtab'* +'noexrc' options.txt /*'noexrc'* +'nofen' options.txt /*'nofen'* +'nofk' options.txt /*'nofk'* +'nofkmap' options.txt /*'nofkmap'* +'nofoldenable' options.txt /*'nofoldenable'* +'nogd' options.txt /*'nogd'* +'nogdefault' options.txt /*'nogdefault'* +'noguipty' options.txt /*'noguipty'* +'nohid' options.txt /*'nohid'* +'nohidden' options.txt /*'nohidden'* +'nohk' options.txt /*'nohk'* +'nohkmap' options.txt /*'nohkmap'* +'nohkmapp' options.txt /*'nohkmapp'* +'nohkp' options.txt /*'nohkp'* +'nohls' options.txt /*'nohls'* +'nohlsearch' options.txt /*'nohlsearch'* +'noic' options.txt /*'noic'* +'noicon' options.txt /*'noicon'* +'noignorecase' options.txt /*'noignorecase'* +'noim' options.txt /*'noim'* +'noimc' options.txt /*'noimc'* +'noimcmdline' options.txt /*'noimcmdline'* +'noimd' options.txt /*'noimd'* +'noimdisable' options.txt /*'noimdisable'* +'noincsearch' options.txt /*'noincsearch'* +'noinf' options.txt /*'noinf'* +'noinfercase' options.txt /*'noinfercase'* +'noinsertmode' options.txt /*'noinsertmode'* +'nois' options.txt /*'nois'* +'nojoinspaces' options.txt /*'nojoinspaces'* +'nojs' options.txt /*'nojs'* +'nolazyredraw' options.txt /*'nolazyredraw'* +'nolbr' options.txt /*'nolbr'* +'nolinebreak' options.txt /*'nolinebreak'* +'nolisp' options.txt /*'nolisp'* +'nolist' options.txt /*'nolist'* +'noloadplugins' options.txt /*'noloadplugins'* +'nolpl' options.txt /*'nolpl'* +'nolz' options.txt /*'nolz'* +'noma' options.txt /*'noma'* +'nomacatsui' options.txt /*'nomacatsui'* +'nomagic' options.txt /*'nomagic'* +'nomh' options.txt /*'nomh'* +'noml' options.txt /*'noml'* +'nomod' options.txt /*'nomod'* +'nomodeline' options.txt /*'nomodeline'* +'nomodifiable' options.txt /*'nomodifiable'* +'nomodified' options.txt /*'nomodified'* +'nomore' options.txt /*'nomore'* +'nomousef' options.txt /*'nomousef'* +'nomousefocus' options.txt /*'nomousefocus'* +'nomousehide' options.txt /*'nomousehide'* +'nonu' options.txt /*'nonu'* +'nonumber' options.txt /*'nonumber'* +'noodev' options.txt /*'noodev'* +'noopendevice' options.txt /*'noopendevice'* +'nopaste' options.txt /*'nopaste'* +'nopi' options.txt /*'nopi'* +'nopreserveindent' options.txt /*'nopreserveindent'* +'nopreviewwindow' options.txt /*'nopreviewwindow'* +'noprompt' options.txt /*'noprompt'* +'nopvw' options.txt /*'nopvw'* +'noreadonly' options.txt /*'noreadonly'* +'norelativenumber' options.txt /*'norelativenumber'* +'noremap' options.txt /*'noremap'* +'norestorescreen' options.txt /*'norestorescreen'* +'norevins' options.txt /*'norevins'* +'nori' options.txt /*'nori'* +'norightleft' options.txt /*'norightleft'* +'norl' options.txt /*'norl'* +'nornu' options.txt /*'nornu'* +'noro' options.txt /*'noro'* +'nors' options.txt /*'nors'* +'noru' options.txt /*'noru'* +'noruler' options.txt /*'noruler'* +'nosb' options.txt /*'nosb'* +'nosc' options.txt /*'nosc'* +'noscb' options.txt /*'noscb'* +'noscrollbind' options.txt /*'noscrollbind'* +'noscs' options.txt /*'noscs'* +'nosecure' options.txt /*'nosecure'* +'nosft' options.txt /*'nosft'* +'noshellslash' options.txt /*'noshellslash'* +'noshelltemp' options.txt /*'noshelltemp'* +'noshiftround' options.txt /*'noshiftround'* +'noshortname' options.txt /*'noshortname'* +'noshowcmd' options.txt /*'noshowcmd'* +'noshowfulltag' options.txt /*'noshowfulltag'* +'noshowmatch' options.txt /*'noshowmatch'* +'noshowmode' options.txt /*'noshowmode'* +'nosi' options.txt /*'nosi'* +'nosm' options.txt /*'nosm'* +'nosmartcase' options.txt /*'nosmartcase'* +'nosmartindent' options.txt /*'nosmartindent'* +'nosmarttab' options.txt /*'nosmarttab'* +'nosmd' options.txt /*'nosmd'* +'nosn' options.txt /*'nosn'* +'nosol' options.txt /*'nosol'* +'nospell' options.txt /*'nospell'* +'nosplitbelow' options.txt /*'nosplitbelow'* +'nosplitright' options.txt /*'nosplitright'* +'nospr' options.txt /*'nospr'* +'nosr' options.txt /*'nosr'* +'nossl' options.txt /*'nossl'* +'nosta' options.txt /*'nosta'* +'nostartofline' options.txt /*'nostartofline'* +'nostmp' options.txt /*'nostmp'* +'noswapfile' options.txt /*'noswapfile'* +'noswf' options.txt /*'noswf'* +'nota' options.txt /*'nota'* +'notagbsearch' options.txt /*'notagbsearch'* +'notagrelative' options.txt /*'notagrelative'* +'notagstack' options.txt /*'notagstack'* +'notbi' options.txt /*'notbi'* +'notbidi' options.txt /*'notbidi'* +'notbs' options.txt /*'notbs'* +'notermbidi' options.txt /*'notermbidi'* +'noterse' options.txt /*'noterse'* +'notextauto' options.txt /*'notextauto'* +'notextmode' options.txt /*'notextmode'* +'notf' options.txt /*'notf'* +'notgst' options.txt /*'notgst'* +'notildeop' options.txt /*'notildeop'* +'notimeout' options.txt /*'notimeout'* +'notitle' options.txt /*'notitle'* +'noto' options.txt /*'noto'* +'notop' options.txt /*'notop'* +'notr' options.txt /*'notr'* +'nottimeout' options.txt /*'nottimeout'* +'nottybuiltin' options.txt /*'nottybuiltin'* +'nottyfast' options.txt /*'nottyfast'* +'notx' options.txt /*'notx'* +'novb' options.txt /*'novb'* +'novice' vi_diff.txt /*'novice'* +'novisualbell' options.txt /*'novisualbell'* +'nowa' options.txt /*'nowa'* +'nowarn' options.txt /*'nowarn'* +'nowb' options.txt /*'nowb'* +'noweirdinvert' options.txt /*'noweirdinvert'* +'nowfh' options.txt /*'nowfh'* +'nowfw' options.txt /*'nowfw'* +'nowildmenu' options.txt /*'nowildmenu'* +'nowinfixheight' options.txt /*'nowinfixheight'* +'nowinfixwidth' options.txt /*'nowinfixwidth'* +'nowiv' options.txt /*'nowiv'* +'nowmnu' options.txt /*'nowmnu'* +'nowrap' options.txt /*'nowrap'* +'nowrapscan' options.txt /*'nowrapscan'* +'nowrite' options.txt /*'nowrite'* +'nowriteany' options.txt /*'nowriteany'* +'nowritebackup' options.txt /*'nowritebackup'* +'nows' options.txt /*'nows'* +'nrformats' options.txt /*'nrformats'* +'nu' options.txt /*'nu'* +'number' options.txt /*'number'* +'numberwidth' options.txt /*'numberwidth'* +'nuw' options.txt /*'nuw'* +'odev' options.txt /*'odev'* +'oft' options.txt /*'oft'* +'ofu' options.txt /*'ofu'* +'omnifunc' options.txt /*'omnifunc'* +'op' vi_diff.txt /*'op'* +'open' vi_diff.txt /*'open'* +'opendevice' options.txt /*'opendevice'* +'operatorfunc' options.txt /*'operatorfunc'* +'opfunc' options.txt /*'opfunc'* +'optimize' vi_diff.txt /*'optimize'* +'option' intro.txt /*'option'* +'osfiletype' options.txt /*'osfiletype'* +'pa' options.txt /*'pa'* +'para' options.txt /*'para'* +'paragraphs' options.txt /*'paragraphs'* +'paste' options.txt /*'paste'* +'pastetoggle' options.txt /*'pastetoggle'* +'patchexpr' options.txt /*'patchexpr'* +'patchmode' options.txt /*'patchmode'* +'path' options.txt /*'path'* +'pdev' options.txt /*'pdev'* +'penc' options.txt /*'penc'* +'pex' options.txt /*'pex'* +'pexpr' options.txt /*'pexpr'* +'pfn' options.txt /*'pfn'* +'ph' options.txt /*'ph'* +'pheader' options.txt /*'pheader'* +'pi' options.txt /*'pi'* +'pm' options.txt /*'pm'* +'pmbcs' options.txt /*'pmbcs'* +'pmbfn' options.txt /*'pmbfn'* +'popt' options.txt /*'popt'* +'preserveindent' options.txt /*'preserveindent'* +'previewheight' options.txt /*'previewheight'* +'previewwindow' options.txt /*'previewwindow'* +'printdevice' options.txt /*'printdevice'* +'printencoding' options.txt /*'printencoding'* +'printexpr' options.txt /*'printexpr'* +'printfont' options.txt /*'printfont'* +'printheader' options.txt /*'printheader'* +'printmbcharset' options.txt /*'printmbcharset'* +'printmbfont' options.txt /*'printmbfont'* +'printoptions' options.txt /*'printoptions'* +'prompt' options.txt /*'prompt'* +'pt' options.txt /*'pt'* +'pumheight' options.txt /*'pumheight'* +'pvh' options.txt /*'pvh'* +'pvw' options.txt /*'pvw'* +'qe' options.txt /*'qe'* +'quote motion.txt /*'quote* +'quoteescape' options.txt /*'quoteescape'* +'rdt' options.txt /*'rdt'* +'readonly' options.txt /*'readonly'* +'redraw' vi_diff.txt /*'redraw'* +'redrawtime' options.txt /*'redrawtime'* +'relativenumber' options.txt /*'relativenumber'* +'remap' options.txt /*'remap'* +'report' options.txt /*'report'* +'restorescreen' options.txt /*'restorescreen'* +'revins' options.txt /*'revins'* +'ri' options.txt /*'ri'* +'rightleft' options.txt /*'rightleft'* +'rightleftcmd' options.txt /*'rightleftcmd'* +'rl' options.txt /*'rl'* +'rlc' options.txt /*'rlc'* +'rnu' options.txt /*'rnu'* +'ro' options.txt /*'ro'* +'rs' options.txt /*'rs'* +'rtp' options.txt /*'rtp'* +'ru' options.txt /*'ru'* +'ruf' options.txt /*'ruf'* +'ruler' options.txt /*'ruler'* +'rulerformat' options.txt /*'rulerformat'* +'runtimepath' options.txt /*'runtimepath'* +'sb' options.txt /*'sb'* +'sbo' options.txt /*'sbo'* +'sbr' options.txt /*'sbr'* +'sc' options.txt /*'sc'* +'scb' options.txt /*'scb'* +'scr' options.txt /*'scr'* +'scroll' options.txt /*'scroll'* +'scrollbind' options.txt /*'scrollbind'* +'scrolljump' options.txt /*'scrolljump'* +'scrolloff' options.txt /*'scrolloff'* +'scrollopt' options.txt /*'scrollopt'* +'scs' options.txt /*'scs'* +'sect' options.txt /*'sect'* +'sections' options.txt /*'sections'* +'secure' options.txt /*'secure'* +'sel' options.txt /*'sel'* +'selection' options.txt /*'selection'* +'selectmode' options.txt /*'selectmode'* +'sessionoptions' options.txt /*'sessionoptions'* +'sft' options.txt /*'sft'* +'sh' options.txt /*'sh'* +'shcf' options.txt /*'shcf'* +'shell' options.txt /*'shell'* +'shellcmdflag' options.txt /*'shellcmdflag'* +'shellpipe' options.txt /*'shellpipe'* +'shellquote' options.txt /*'shellquote'* +'shellredir' options.txt /*'shellredir'* +'shellslash' options.txt /*'shellslash'* +'shelltemp' options.txt /*'shelltemp'* +'shelltype' options.txt /*'shelltype'* +'shellxquote' options.txt /*'shellxquote'* +'shiftround' options.txt /*'shiftround'* +'shiftwidth' options.txt /*'shiftwidth'* +'shm' options.txt /*'shm'* +'shortmess' options.txt /*'shortmess'* +'shortname' options.txt /*'shortname'* +'showbreak' options.txt /*'showbreak'* +'showcmd' options.txt /*'showcmd'* +'showfulltag' options.txt /*'showfulltag'* +'showmatch' options.txt /*'showmatch'* +'showmode' options.txt /*'showmode'* +'showtabline' options.txt /*'showtabline'* +'shq' options.txt /*'shq'* +'si' options.txt /*'si'* +'sidescroll' options.txt /*'sidescroll'* +'sidescrolloff' options.txt /*'sidescrolloff'* +'siso' options.txt /*'siso'* +'sj' options.txt /*'sj'* +'slm' options.txt /*'slm'* +'slow' vi_diff.txt /*'slow'* +'slowopen' vi_diff.txt /*'slowopen'* +'sm' options.txt /*'sm'* +'smartcase' options.txt /*'smartcase'* +'smartindent' options.txt /*'smartindent'* +'smarttab' options.txt /*'smarttab'* +'smc' options.txt /*'smc'* +'smd' options.txt /*'smd'* +'sn' options.txt /*'sn'* +'so' options.txt /*'so'* +'softtabstop' options.txt /*'softtabstop'* +'sol' options.txt /*'sol'* +'sourceany' vi_diff.txt /*'sourceany'* +'sp' options.txt /*'sp'* +'spc' options.txt /*'spc'* +'spell' options.txt /*'spell'* +'spellcapcheck' options.txt /*'spellcapcheck'* +'spellfile' options.txt /*'spellfile'* +'spelllang' options.txt /*'spelllang'* +'spellsuggest' options.txt /*'spellsuggest'* +'spf' options.txt /*'spf'* +'spl' options.txt /*'spl'* +'splitbelow' options.txt /*'splitbelow'* +'splitright' options.txt /*'splitright'* +'spr' options.txt /*'spr'* +'sps' options.txt /*'sps'* +'sr' options.txt /*'sr'* +'srr' options.txt /*'srr'* +'ss' options.txt /*'ss'* +'ssl' options.txt /*'ssl'* +'ssop' options.txt /*'ssop'* +'st' options.txt /*'st'* +'sta' options.txt /*'sta'* +'stal' options.txt /*'stal'* +'startofline' options.txt /*'startofline'* +'statusline' options.txt /*'statusline'* +'stl' options.txt /*'stl'* +'stmp' options.txt /*'stmp'* +'sts' options.txt /*'sts'* +'su' options.txt /*'su'* +'sua' options.txt /*'sua'* +'suffixes' options.txt /*'suffixes'* +'suffixesadd' options.txt /*'suffixesadd'* +'sw' options.txt /*'sw'* +'swapfile' options.txt /*'swapfile'* +'swapsync' options.txt /*'swapsync'* +'swb' options.txt /*'swb'* +'swf' options.txt /*'swf'* +'switchbuf' options.txt /*'switchbuf'* +'sws' options.txt /*'sws'* +'sxq' options.txt /*'sxq'* +'syn' options.txt /*'syn'* +'synmaxcol' options.txt /*'synmaxcol'* +'syntax' options.txt /*'syntax'* +'t_#2' term.txt /*'t_#2'* +'t_#4' term.txt /*'t_#4'* +'t_%1' term.txt /*'t_%1'* +'t_%i' term.txt /*'t_%i'* +'t_&8' term.txt /*'t_&8'* +'t_@7' term.txt /*'t_@7'* +'t_AB' term.txt /*'t_AB'* +'t_AF' term.txt /*'t_AF'* +'t_AL' term.txt /*'t_AL'* +'t_CS' term.txt /*'t_CS'* +'t_CV' term.txt /*'t_CV'* +'t_Ce' term.txt /*'t_Ce'* +'t_Co' term.txt /*'t_Co'* +'t_Cs' term.txt /*'t_Cs'* +'t_DL' term.txt /*'t_DL'* +'t_EI' term.txt /*'t_EI'* +'t_F1' term.txt /*'t_F1'* +'t_F2' term.txt /*'t_F2'* +'t_F3' term.txt /*'t_F3'* +'t_F4' term.txt /*'t_F4'* +'t_F5' term.txt /*'t_F5'* +'t_F6' term.txt /*'t_F6'* +'t_F7' term.txt /*'t_F7'* +'t_F8' term.txt /*'t_F8'* +'t_F9' term.txt /*'t_F9'* +'t_IE' term.txt /*'t_IE'* +'t_IS' term.txt /*'t_IS'* +'t_K1' term.txt /*'t_K1'* +'t_K3' term.txt /*'t_K3'* +'t_K4' term.txt /*'t_K4'* +'t_K5' term.txt /*'t_K5'* +'t_K6' term.txt /*'t_K6'* +'t_K7' term.txt /*'t_K7'* +'t_K8' term.txt /*'t_K8'* +'t_K9' term.txt /*'t_K9'* +'t_KA' term.txt /*'t_KA'* +'t_KB' term.txt /*'t_KB'* +'t_KC' term.txt /*'t_KC'* +'t_KD' term.txt /*'t_KD'* +'t_KE' term.txt /*'t_KE'* +'t_KF' term.txt /*'t_KF'* +'t_KG' term.txt /*'t_KG'* +'t_KH' term.txt /*'t_KH'* +'t_KI' term.txt /*'t_KI'* +'t_KJ' term.txt /*'t_KJ'* +'t_KK' term.txt /*'t_KK'* +'t_KL' term.txt /*'t_KL'* +'t_RI' term.txt /*'t_RI'* +'t_RV' term.txt /*'t_RV'* +'t_SI' term.txt /*'t_SI'* +'t_Sb' term.txt /*'t_Sb'* +'t_Sf' term.txt /*'t_Sf'* +'t_WP' term.txt /*'t_WP'* +'t_WS' term.txt /*'t_WS'* +'t_ZH' term.txt /*'t_ZH'* +'t_ZR' term.txt /*'t_ZR'* +'t_al' term.txt /*'t_al'* +'t_bc' term.txt /*'t_bc'* +'t_cd' term.txt /*'t_cd'* +'t_ce' term.txt /*'t_ce'* +'t_cl' term.txt /*'t_cl'* +'t_cm' term.txt /*'t_cm'* +'t_cs' term.txt /*'t_cs'* +'t_da' term.txt /*'t_da'* +'t_db' term.txt /*'t_db'* +'t_dl' term.txt /*'t_dl'* +'t_fs' term.txt /*'t_fs'* +'t_k1' term.txt /*'t_k1'* +'t_k2' term.txt /*'t_k2'* +'t_k3' term.txt /*'t_k3'* +'t_k4' term.txt /*'t_k4'* +'t_k5' term.txt /*'t_k5'* +'t_k6' term.txt /*'t_k6'* +'t_k7' term.txt /*'t_k7'* +'t_k8' term.txt /*'t_k8'* +'t_k9' term.txt /*'t_k9'* +'t_k;' term.txt /*'t_k;'* +'t_kB' term.txt /*'t_kB'* +'t_kD' term.txt /*'t_kD'* +'t_kI' term.txt /*'t_kI'* +'t_kN' term.txt /*'t_kN'* +'t_kP' term.txt /*'t_kP'* +'t_kb' term.txt /*'t_kb'* +'t_kd' term.txt /*'t_kd'* +'t_ke' term.txt /*'t_ke'* +'t_kh' term.txt /*'t_kh'* +'t_kl' term.txt /*'t_kl'* +'t_kr' term.txt /*'t_kr'* +'t_ks' term.txt /*'t_ks'* +'t_ku' term.txt /*'t_ku'* +'t_le' term.txt /*'t_le'* +'t_mb' term.txt /*'t_mb'* +'t_md' term.txt /*'t_md'* +'t_me' term.txt /*'t_me'* +'t_mr' term.txt /*'t_mr'* +'t_ms' term.txt /*'t_ms'* +'t_nd' term.txt /*'t_nd'* +'t_op' term.txt /*'t_op'* +'t_se' term.txt /*'t_se'* +'t_so' term.txt /*'t_so'* +'t_sr' term.txt /*'t_sr'* +'t_star7' term.txt /*'t_star7'* +'t_te' term.txt /*'t_te'* +'t_ti' term.txt /*'t_ti'* +'t_ts' term.txt /*'t_ts'* +'t_ue' term.txt /*'t_ue'* +'t_us' term.txt /*'t_us'* +'t_ut' term.txt /*'t_ut'* +'t_vb' term.txt /*'t_vb'* +'t_ve' term.txt /*'t_ve'* +'t_vi' term.txt /*'t_vi'* +'t_vs' term.txt /*'t_vs'* +'t_xs' term.txt /*'t_xs'* +'ta' options.txt /*'ta'* +'tabline' options.txt /*'tabline'* +'tabpagemax' options.txt /*'tabpagemax'* +'tabstop' options.txt /*'tabstop'* +'tag' options.txt /*'tag'* +'tagbsearch' options.txt /*'tagbsearch'* +'taglength' options.txt /*'taglength'* +'tagrelative' options.txt /*'tagrelative'* +'tags' options.txt /*'tags'* +'tagstack' options.txt /*'tagstack'* +'tal' options.txt /*'tal'* +'tb' options.txt /*'tb'* +'tbi' options.txt /*'tbi'* +'tbidi' options.txt /*'tbidi'* +'tbis' options.txt /*'tbis'* +'tbs' options.txt /*'tbs'* +'tenc' options.txt /*'tenc'* +'term' options.txt /*'term'* +'termbidi' options.txt /*'termbidi'* +'termencoding' options.txt /*'termencoding'* +'terse' options.txt /*'terse'* +'textauto' options.txt /*'textauto'* +'textmode' options.txt /*'textmode'* +'textwidth' options.txt /*'textwidth'* +'tf' options.txt /*'tf'* +'tgst' options.txt /*'tgst'* +'thesaurus' options.txt /*'thesaurus'* +'tildeop' options.txt /*'tildeop'* +'timeout' options.txt /*'timeout'* +'timeoutlen' options.txt /*'timeoutlen'* +'title' options.txt /*'title'* +'titlelen' options.txt /*'titlelen'* +'titleold' options.txt /*'titleold'* +'titlestring' options.txt /*'titlestring'* +'tl' options.txt /*'tl'* +'tm' options.txt /*'tm'* +'to' options.txt /*'to'* +'toolbar' options.txt /*'toolbar'* +'toolbariconsize' options.txt /*'toolbariconsize'* +'top' options.txt /*'top'* +'tpm' options.txt /*'tpm'* +'tr' options.txt /*'tr'* +'ts' options.txt /*'ts'* +'tsl' options.txt /*'tsl'* +'tsr' options.txt /*'tsr'* +'ttimeout' options.txt /*'ttimeout'* +'ttimeoutlen' options.txt /*'ttimeoutlen'* +'ttm' options.txt /*'ttm'* +'tty' options.txt /*'tty'* +'ttybuiltin' options.txt /*'ttybuiltin'* +'ttyfast' options.txt /*'ttyfast'* +'ttym' options.txt /*'ttym'* +'ttymouse' options.txt /*'ttymouse'* +'ttyscroll' options.txt /*'ttyscroll'* +'ttytype' options.txt /*'ttytype'* +'tw' options.txt /*'tw'* +'tx' options.txt /*'tx'* +'uc' options.txt /*'uc'* +'udf' options.txt /*'udf'* +'udir' options.txt /*'udir'* +'ul' options.txt /*'ul'* +'undodir' options.txt /*'undodir'* +'undofile' options.txt /*'undofile'* +'undolevels' options.txt /*'undolevels'* +'undoreload' options.txt /*'undoreload'* +'updatecount' options.txt /*'updatecount'* +'updatetime' options.txt /*'updatetime'* +'ur' options.txt /*'ur'* +'ut' options.txt /*'ut'* +'vb' options.txt /*'vb'* +'vbs' options.txt /*'vbs'* +'vdir' options.txt /*'vdir'* +'ve' options.txt /*'ve'* +'verbose' options.txt /*'verbose'* +'verbosefile' options.txt /*'verbosefile'* +'vfile' options.txt /*'vfile'* +'vi' options.txt /*'vi'* +'viewdir' options.txt /*'viewdir'* +'viewoptions' options.txt /*'viewoptions'* +'viminfo' options.txt /*'viminfo'* +'virtualedit' options.txt /*'virtualedit'* +'visualbell' options.txt /*'visualbell'* +'vop' options.txt /*'vop'* +'w1200' vi_diff.txt /*'w1200'* +'w300' vi_diff.txt /*'w300'* +'w9600' vi_diff.txt /*'w9600'* +'wa' options.txt /*'wa'* +'wak' options.txt /*'wak'* +'warn' options.txt /*'warn'* +'wb' options.txt /*'wb'* +'wc' options.txt /*'wc'* +'wcm' options.txt /*'wcm'* +'wd' options.txt /*'wd'* +'weirdinvert' options.txt /*'weirdinvert'* +'wfh' options.txt /*'wfh'* +'wfw' options.txt /*'wfw'* +'wh' options.txt /*'wh'* +'whichwrap' options.txt /*'whichwrap'* +'wi' options.txt /*'wi'* +'wig' options.txt /*'wig'* +'wildchar' options.txt /*'wildchar'* +'wildcharm' options.txt /*'wildcharm'* +'wildignore' options.txt /*'wildignore'* +'wildmenu' options.txt /*'wildmenu'* +'wildmode' options.txt /*'wildmode'* +'wildoptions' options.txt /*'wildoptions'* +'wim' options.txt /*'wim'* +'winaltkeys' options.txt /*'winaltkeys'* +'window' options.txt /*'window'* +'winfixheight' options.txt /*'winfixheight'* +'winfixwidth' options.txt /*'winfixwidth'* +'winheight' options.txt /*'winheight'* +'winminheight' options.txt /*'winminheight'* +'winminwidth' options.txt /*'winminwidth'* +'winwidth' options.txt /*'winwidth'* +'wiv' options.txt /*'wiv'* +'wiw' options.txt /*'wiw'* +'wm' options.txt /*'wm'* +'wmh' options.txt /*'wmh'* +'wmnu' options.txt /*'wmnu'* +'wmw' options.txt /*'wmw'* +'wop' options.txt /*'wop'* +'wrap' options.txt /*'wrap'* +'wrapmargin' options.txt /*'wrapmargin'* +'wrapscan' options.txt /*'wrapscan'* +'write' options.txt /*'write'* +'writeany' options.txt /*'writeany'* +'writebackup' options.txt /*'writebackup'* +'writedelay' options.txt /*'writedelay'* +'ws' options.txt /*'ws'* +'ww' options.txt /*'ww'* +'{ motion.txt /*'{* +'} motion.txt /*'}* +( motion.txt /*(* +) motion.txt /*)* ++ motion.txt /*+* +++bad editing.txt /*++bad* +++bin editing.txt /*++bin* +++builtin_terms various.txt /*++builtin_terms* +++edit editing.txt /*++edit* +++enc editing.txt /*++enc* +++ff editing.txt /*++ff* +++nobin editing.txt /*++nobin* +++opt editing.txt /*++opt* ++ARP various.txt /*+ARP* ++GUI_Athena various.txt /*+GUI_Athena* ++GUI_GTK various.txt /*+GUI_GTK* ++GUI_Motif various.txt /*+GUI_Motif* ++GUI_Photon various.txt /*+GUI_Photon* ++GUI_neXtaw various.txt /*+GUI_neXtaw* ++X11 various.txt /*+X11* ++arabic various.txt /*+arabic* ++autocmd various.txt /*+autocmd* ++balloon_eval various.txt /*+balloon_eval* ++browse various.txt /*+browse* ++builtin_terms various.txt /*+builtin_terms* ++byte_offset various.txt /*+byte_offset* ++cindent various.txt /*+cindent* ++clientserver various.txt /*+clientserver* ++clipboard various.txt /*+clipboard* ++cmd editing.txt /*+cmd* ++cmdline_compl various.txt /*+cmdline_compl* ++cmdline_hist various.txt /*+cmdline_hist* ++cmdline_info various.txt /*+cmdline_info* ++comments various.txt /*+comments* ++conceal various.txt /*+conceal* ++cryptv various.txt /*+cryptv* ++cscope various.txt /*+cscope* ++cursorbind various.txt /*+cursorbind* ++cursorshape various.txt /*+cursorshape* ++debug various.txt /*+debug* ++dialog_con various.txt /*+dialog_con* ++dialog_con_gui various.txt /*+dialog_con_gui* ++dialog_gui various.txt /*+dialog_gui* ++diff various.txt /*+diff* ++digraphs various.txt /*+digraphs* ++dnd various.txt /*+dnd* ++emacs_tags various.txt /*+emacs_tags* ++eval various.txt /*+eval* ++ex_extra various.txt /*+ex_extra* ++extra_search various.txt /*+extra_search* ++farsi various.txt /*+farsi* ++feature-list various.txt /*+feature-list* ++file_in_path various.txt /*+file_in_path* ++find_in_path various.txt /*+find_in_path* ++float various.txt /*+float* ++folding various.txt /*+folding* ++footer various.txt /*+footer* ++fork various.txt /*+fork* ++gettext various.txt /*+gettext* ++hangul_input various.txt /*+hangul_input* ++iconv various.txt /*+iconv* ++iconv/dyn various.txt /*+iconv\/dyn* ++insert_expand various.txt /*+insert_expand* ++jumplist various.txt /*+jumplist* ++keymap various.txt /*+keymap* ++langmap various.txt /*+langmap* ++libcall various.txt /*+libcall* ++linebreak various.txt /*+linebreak* ++lispindent various.txt /*+lispindent* ++listcmds various.txt /*+listcmds* ++localmap various.txt /*+localmap* ++lua various.txt /*+lua* ++lua/dyn various.txt /*+lua\/dyn* ++menu various.txt /*+menu* ++mksession various.txt /*+mksession* ++modify_fname various.txt /*+modify_fname* ++mouse various.txt /*+mouse* ++mouse_dec various.txt /*+mouse_dec* ++mouse_gpm various.txt /*+mouse_gpm* ++mouse_netterm various.txt /*+mouse_netterm* ++mouse_pterm various.txt /*+mouse_pterm* ++mouse_sysmouse various.txt /*+mouse_sysmouse* ++mouse_xterm various.txt /*+mouse_xterm* ++mouseshape various.txt /*+mouseshape* ++multi_byte various.txt /*+multi_byte* ++multi_byte_ime various.txt /*+multi_byte_ime* ++multi_lang various.txt /*+multi_lang* ++mzscheme various.txt /*+mzscheme* ++mzscheme/dyn various.txt /*+mzscheme\/dyn* ++netbeans_intg various.txt /*+netbeans_intg* ++ole various.txt /*+ole* ++osfiletype various.txt /*+osfiletype* ++path_extra various.txt /*+path_extra* ++perl various.txt /*+perl* ++perl/dyn various.txt /*+perl\/dyn* ++persistent_undo various.txt /*+persistent_undo* ++postscript various.txt /*+postscript* ++printer various.txt /*+printer* ++profile various.txt /*+profile* ++python various.txt /*+python* ++python/dyn various.txt /*+python\/dyn* ++python3 various.txt /*+python3* ++python3/dyn various.txt /*+python3\/dyn* ++quickfix various.txt /*+quickfix* ++reltime various.txt /*+reltime* ++rightleft various.txt /*+rightleft* ++ruby various.txt /*+ruby* ++ruby/dyn various.txt /*+ruby\/dyn* ++scrollbind various.txt /*+scrollbind* ++signs various.txt /*+signs* ++smartindent various.txt /*+smartindent* ++sniff various.txt /*+sniff* ++startuptime various.txt /*+startuptime* ++statusline various.txt /*+statusline* ++sun_workshop various.txt /*+sun_workshop* ++syntax various.txt /*+syntax* ++system() various.txt /*+system()* ++tag_any_white various.txt /*+tag_any_white* ++tag_binary various.txt /*+tag_binary* ++tag_old_static various.txt /*+tag_old_static* ++tcl various.txt /*+tcl* ++tcl/dyn various.txt /*+tcl\/dyn* ++terminfo various.txt /*+terminfo* ++termresponse various.txt /*+termresponse* ++textobjects various.txt /*+textobjects* ++tgetent various.txt /*+tgetent* ++title various.txt /*+title* ++toolbar various.txt /*+toolbar* ++user_commands various.txt /*+user_commands* ++vertsplit various.txt /*+vertsplit* ++viminfo various.txt /*+viminfo* ++virtualedit various.txt /*+virtualedit* ++visual various.txt /*+visual* ++visualextra various.txt /*+visualextra* ++vreplace various.txt /*+vreplace* ++wildignore various.txt /*+wildignore* ++wildmenu various.txt /*+wildmenu* ++windows various.txt /*+windows* ++writebackup various.txt /*+writebackup* ++xfontset various.txt /*+xfontset* ++xim various.txt /*+xim* ++xsmp various.txt /*+xsmp* ++xsmp_interact various.txt /*+xsmp_interact* ++xterm_clipboard various.txt /*+xterm_clipboard* ++xterm_save various.txt /*+xterm_save* +, motion.txt /*,* +- motion.txt /*-* +-+ starting.txt /*-+* +-+/ starting.txt /*-+\/* +-+c starting.txt /*-+c* +-+reverse gui_x11.txt /*-+reverse* +-+rv gui_x11.txt /*-+rv* +-- starting.txt /*--* +--- starting.txt /*---* +--cmd starting.txt /*--cmd* +--echo-wid starting.txt /*--echo-wid* +--help starting.txt /*--help* +--literal starting.txt /*--literal* +--nofork starting.txt /*--nofork* +--noplugin starting.txt /*--noplugin* +--remote remote.txt /*--remote* +--remote-expr remote.txt /*--remote-expr* +--remote-send remote.txt /*--remote-send* +--remote-silent remote.txt /*--remote-silent* +--remote-tab remote.txt /*--remote-tab* +--remote-tab-silent remote.txt /*--remote-tab-silent* +--remote-tab-wait remote.txt /*--remote-tab-wait* +--remote-tab-wait-silent remote.txt /*--remote-tab-wait-silent* +--remote-wait remote.txt /*--remote-wait* +--remote-wait-silent remote.txt /*--remote-wait-silent* +--role starting.txt /*--role* +--serverlist remote.txt /*--serverlist* +--servername remote.txt /*--servername* +--socketid starting.txt /*--socketid* +--startuptime starting.txt /*--startuptime* +--version starting.txt /*--version* +--windowid starting.txt /*--windowid* +-A starting.txt /*-A* +-C starting.txt /*-C* +-D starting.txt /*-D* +-E starting.txt /*-E* +-F starting.txt /*-F* +-H starting.txt /*-H* +-L starting.txt /*-L* +-M starting.txt /*-M* +-N starting.txt /*-N* +-O starting.txt /*-O* +-P starting.txt /*-P* +-R starting.txt /*-R* +-S starting.txt /*-S* +-T starting.txt /*-T* +-U starting.txt /*-U* +-V starting.txt /*-V* +-W starting.txt /*-W* +-X starting.txt /*-X* +-Z starting.txt /*-Z* +-b starting.txt /*-b* +-background gui_x11.txt /*-background* +-bg gui_x11.txt /*-bg* +-boldfont gui_x11.txt /*-boldfont* +-borderwidth gui_x11.txt /*-borderwidth* +-bw gui_x11.txt /*-bw* +-c starting.txt /*-c* +-d starting.txt /*-d* +-dev starting.txt /*-dev* +-display gui_x11.txt /*-display* +-e starting.txt /*-e* +-f starting.txt /*-f* +-fg gui_x11.txt /*-fg* +-file starting.txt /*-file* +-fn gui_x11.txt /*-fn* +-font gui_x11.txt /*-font* +-foreground gui_x11.txt /*-foreground* +-g starting.txt /*-g* +-geom gui_x11.txt /*-geom* +-geometry gui_x11.txt /*-geometry* +-geometry-example gui_x11.txt /*-geometry-example* +-gui gui_x11.txt /*-gui* +-h starting.txt /*-h* +-i starting.txt /*-i* +-iconic gui_x11.txt /*-iconic* +-italicfont gui_x11.txt /*-italicfont* +-l starting.txt /*-l* +-m starting.txt /*-m* +-menufont gui_x11.txt /*-menufont* +-menufontset gui_x11.txt /*-menufontset* +-menuheight gui_x11.txt /*-menuheight* +-mf gui_x11.txt /*-mf* +-mh gui_x11.txt /*-mh* +-n starting.txt /*-n* +-nb starting.txt /*-nb* +-o starting.txt /*-o* +-p starting.txt /*-p* +-q starting.txt /*-q* +-qf starting.txt /*-qf* +-r starting.txt /*-r* +-register if_ole.txt /*-register* +-reverse gui_x11.txt /*-reverse* +-rv gui_x11.txt /*-rv* +-s starting.txt /*-s* +-s-ex starting.txt /*-s-ex* +-scrollbarwidth gui_x11.txt /*-scrollbarwidth* +-silent if_ole.txt /*-silent* +-sw gui_x11.txt /*-sw* +-t starting.txt /*-t* +-tag starting.txt /*-tag* +-u starting.txt /*-u* +-ul gui_x11.txt /*-ul* +-unregister if_ole.txt /*-unregister* +-v starting.txt /*-v* +-vim starting.txt /*-vim* +-w starting.txt /*-w* +-w_nr starting.txt /*-w_nr* +-x starting.txt /*-x* +-xrm gui_x11.txt /*-xrm* +-y starting.txt /*-y* +. repeat.txt /*.* +... eval.txt /*...* +.Xdefaults gui_x11.txt /*.Xdefaults* +.aff spell.txt /*.aff* +.dic spell.txt /*.dic* +.exrc starting.txt /*.exrc* +.gvimrc gui.txt /*.gvimrc* +.vimrc starting.txt /*.vimrc* +/ pattern.txt /*\/* +/$ pattern.txt /*\/$* +/. pattern.txt /*\/.* +// version7.txt /*\/\/* +//; pattern.txt /*\/\/;* +/<CR> pattern.txt /*\/<CR>* +/[[. pattern.txt /*\/[[.* +/[[= pattern.txt /*\/[[=* +/[\n] pattern.txt /*\/[\\n]* +/[] pattern.txt /*\/[]* +/\ pattern.txt /*\/\\* +/\$ pattern.txt /*\/\\$* +/\%# pattern.txt /*\/\\%#* +/\%$ pattern.txt /*\/\\%$* +/\%'m pattern.txt /*\/\\%'m* +/\%( pattern.txt /*\/\\%(* +/\%(\) pattern.txt /*\/\\%(\\)* +/\%<'m pattern.txt /*\/\\%<'m* +/\%<c pattern.txt /*\/\\%<c* +/\%<l pattern.txt /*\/\\%<l* +/\%<v pattern.txt /*\/\\%<v* +/\%>'m pattern.txt /*\/\\%>'m* +/\%>c pattern.txt /*\/\\%>c* +/\%>l pattern.txt /*\/\\%>l* +/\%>v pattern.txt /*\/\\%>v* +/\%U pattern.txt /*\/\\%U* +/\%V pattern.txt /*\/\\%V* +/\%[] pattern.txt /*\/\\%[]* +/\%^ pattern.txt /*\/\\%^* +/\%c pattern.txt /*\/\\%c* +/\%d pattern.txt /*\/\\%d* +/\%l pattern.txt /*\/\\%l* +/\%o pattern.txt /*\/\\%o* +/\%u pattern.txt /*\/\\%u* +/\%v pattern.txt /*\/\\%v* +/\%x pattern.txt /*\/\\%x* +/\& pattern.txt /*\/\\&* +/\( pattern.txt /*\/\\(* +/\(\) pattern.txt /*\/\\(\\)* +/\) pattern.txt /*\/\\)* +/\+ pattern.txt /*\/\\+* +/\. pattern.txt /*\/\\.* +/\1 pattern.txt /*\/\\1* +/\2 pattern.txt /*\/\\2* +/\3 pattern.txt /*\/\\3* +/\9 pattern.txt /*\/\\9* +/\< pattern.txt /*\/\\<* +/\= pattern.txt /*\/\\=* +/\> pattern.txt /*\/\\>* +/\? pattern.txt /*\/\\?* +/\@! pattern.txt /*\/\\@!* +/\@<! pattern.txt /*\/\\@<!* +/\@<= pattern.txt /*\/\\@<=* +/\@= pattern.txt /*\/\\@=* +/\@> pattern.txt /*\/\\@>* +/\A pattern.txt /*\/\\A* +/\C pattern.txt /*\/\\C* +/\D pattern.txt /*\/\\D* +/\F pattern.txt /*\/\\F* +/\H pattern.txt /*\/\\H* +/\I pattern.txt /*\/\\I* +/\K pattern.txt /*\/\\K* +/\L pattern.txt /*\/\\L* +/\M pattern.txt /*\/\\M* +/\O pattern.txt /*\/\\O* +/\P pattern.txt /*\/\\P* +/\S pattern.txt /*\/\\S* +/\U pattern.txt /*\/\\U* +/\V pattern.txt /*\/\\V* +/\W pattern.txt /*\/\\W* +/\X pattern.txt /*\/\\X* +/\Z pattern.txt /*\/\\Z* +/\[] pattern.txt /*\/\\[]* +/\\ pattern.txt /*\/\\\\* +/\] pattern.txt /*\/\\]* +/\^ pattern.txt /*\/\\^* +/\_ pattern.txt /*\/\\_* +/\_$ pattern.txt /*\/\\_$* +/\_. pattern.txt /*\/\\_.* +/\_A pattern.txt /*\/\\_A* +/\_D pattern.txt /*\/\\_D* +/\_F pattern.txt /*\/\\_F* +/\_H pattern.txt /*\/\\_H* +/\_I pattern.txt /*\/\\_I* +/\_K pattern.txt /*\/\\_K* +/\_L pattern.txt /*\/\\_L* +/\_O pattern.txt /*\/\\_O* +/\_P pattern.txt /*\/\\_P* +/\_S pattern.txt /*\/\\_S* +/\_U pattern.txt /*\/\\_U* +/\_W pattern.txt /*\/\\_W* +/\_X pattern.txt /*\/\\_X* +/\_[] pattern.txt /*\/\\_[]* +/\_^ pattern.txt /*\/\\_^* +/\_a pattern.txt /*\/\\_a* +/\_d pattern.txt /*\/\\_d* +/\_f pattern.txt /*\/\\_f* +/\_h pattern.txt /*\/\\_h* +/\_i pattern.txt /*\/\\_i* +/\_k pattern.txt /*\/\\_k* +/\_l pattern.txt /*\/\\_l* +/\_o pattern.txt /*\/\\_o* +/\_p pattern.txt /*\/\\_p* +/\_s pattern.txt /*\/\\_s* +/\_u pattern.txt /*\/\\_u* +/\_w pattern.txt /*\/\\_w* +/\_x pattern.txt /*\/\\_x* +/\a pattern.txt /*\/\\a* +/\b pattern.txt /*\/\\b* +/\bar pattern.txt /*\/\\bar* +/\c pattern.txt /*\/\\c* +/\d pattern.txt /*\/\\d* +/\e pattern.txt /*\/\\e* +/\f pattern.txt /*\/\\f* +/\h pattern.txt /*\/\\h* +/\i pattern.txt /*\/\\i* +/\k pattern.txt /*\/\\k* +/\l pattern.txt /*\/\\l* +/\m pattern.txt /*\/\\m* +/\n pattern.txt /*\/\\n* +/\o pattern.txt /*\/\\o* +/\p pattern.txt /*\/\\p* +/\r pattern.txt /*\/\\r* +/\s pattern.txt /*\/\\s* +/\star pattern.txt /*\/\\star* +/\t pattern.txt /*\/\\t* +/\u pattern.txt /*\/\\u* +/\v pattern.txt /*\/\\v* +/\w pattern.txt /*\/\\w* +/\x pattern.txt /*\/\\x* +/\z( syntax.txt /*\/\\z(* +/\z(\) syntax.txt /*\/\\z(\\)* +/\z1 syntax.txt /*\/\\z1* +/\z2 syntax.txt /*\/\\z2* +/\z3 syntax.txt /*\/\\z3* +/\z4 syntax.txt /*\/\\z4* +/\z5 syntax.txt /*\/\\z5* +/\z6 syntax.txt /*\/\\z6* +/\z7 syntax.txt /*\/\\z7* +/\z8 syntax.txt /*\/\\z8* +/\z9 syntax.txt /*\/\\z9* +/\ze pattern.txt /*\/\\ze* +/\zs pattern.txt /*\/\\zs* +/\{ pattern.txt /*\/\\{* +/\{- pattern.txt /*\/\\{-* +/\~ pattern.txt /*\/\\~* +/^ pattern.txt /*\/^* +/atom pattern.txt /*\/atom* +/bar pattern.txt /*\/bar* +/branch pattern.txt /*\/branch* +/character-classes pattern.txt /*\/character-classes* +/collection pattern.txt /*\/collection* +/concat pattern.txt /*\/concat* +/dyn various.txt /*\/dyn* +/ignorecase pattern.txt /*\/ignorecase* +/magic pattern.txt /*\/magic* +/multi pattern.txt /*\/multi* +/ordinary-atom pattern.txt /*\/ordinary-atom* +/pattern pattern.txt /*\/pattern* +/piece pattern.txt /*\/piece* +/star pattern.txt /*\/star* +/zero-width pattern.txt /*\/zero-width* +/~ pattern.txt /*\/~* +0 motion.txt /*0* +01.1 usr_01.txt /*01.1* +01.2 usr_01.txt /*01.2* +01.3 usr_01.txt /*01.3* +01.4 usr_01.txt /*01.4* +02.1 usr_02.txt /*02.1* +02.2 usr_02.txt /*02.2* +02.3 usr_02.txt /*02.3* +02.4 usr_02.txt /*02.4* +02.5 usr_02.txt /*02.5* +02.6 usr_02.txt /*02.6* +02.7 usr_02.txt /*02.7* +02.8 usr_02.txt /*02.8* +03.1 usr_03.txt /*03.1* +03.10 usr_03.txt /*03.10* +03.2 usr_03.txt /*03.2* +03.3 usr_03.txt /*03.3* +03.4 usr_03.txt /*03.4* +03.5 usr_03.txt /*03.5* +03.6 usr_03.txt /*03.6* +03.7 usr_03.txt /*03.7* +03.8 usr_03.txt /*03.8* +03.9 usr_03.txt /*03.9* +04.1 usr_04.txt /*04.1* +04.10 usr_04.txt /*04.10* +04.2 usr_04.txt /*04.2* +04.3 usr_04.txt /*04.3* +04.4 usr_04.txt /*04.4* +04.5 usr_04.txt /*04.5* +04.6 usr_04.txt /*04.6* +04.7 usr_04.txt /*04.7* +04.8 usr_04.txt /*04.8* +04.9 usr_04.txt /*04.9* +05.1 usr_05.txt /*05.1* +05.2 usr_05.txt /*05.2* +05.3 usr_05.txt /*05.3* +05.4 usr_05.txt /*05.4* +05.5 usr_05.txt /*05.5* +05.6 usr_05.txt /*05.6* +05.7 usr_05.txt /*05.7* +06.1 usr_06.txt /*06.1* +06.2 usr_06.txt /*06.2* +06.3 usr_06.txt /*06.3* +06.4 usr_06.txt /*06.4* +06.5 usr_06.txt /*06.5* +06.6 usr_06.txt /*06.6* +07.1 usr_07.txt /*07.1* +07.2 usr_07.txt /*07.2* +07.3 usr_07.txt /*07.3* +07.4 usr_07.txt /*07.4* +07.5 usr_07.txt /*07.5* +07.6 usr_07.txt /*07.6* +07.7 usr_07.txt /*07.7* +08.1 usr_08.txt /*08.1* +08.2 usr_08.txt /*08.2* +08.3 usr_08.txt /*08.3* +08.4 usr_08.txt /*08.4* +08.5 usr_08.txt /*08.5* +08.6 usr_08.txt /*08.6* +08.7 usr_08.txt /*08.7* +08.8 usr_08.txt /*08.8* +08.9 usr_08.txt /*08.9* +09.1 usr_09.txt /*09.1* +09.2 usr_09.txt /*09.2* +09.3 usr_09.txt /*09.3* +09.4 usr_09.txt /*09.4* +10.1 usr_10.txt /*10.1* +10.2 usr_10.txt /*10.2* +10.3 usr_10.txt /*10.3* +10.4 usr_10.txt /*10.4* +10.5 usr_10.txt /*10.5* +10.6 usr_10.txt /*10.6* +10.7 usr_10.txt /*10.7* +10.8 usr_10.txt /*10.8* +10.9 usr_10.txt /*10.9* +11.1 usr_11.txt /*11.1* +11.2 usr_11.txt /*11.2* +11.3 usr_11.txt /*11.3* +11.4 usr_11.txt /*11.4* +12.1 usr_12.txt /*12.1* +12.2 usr_12.txt /*12.2* +12.3 usr_12.txt /*12.3* +12.4 usr_12.txt /*12.4* +12.5 usr_12.txt /*12.5* +12.6 usr_12.txt /*12.6* +12.7 usr_12.txt /*12.7* +12.8 usr_12.txt /*12.8* +1gD pattern.txt /*1gD* +1gd pattern.txt /*1gd* +20.1 usr_20.txt /*20.1* +20.2 usr_20.txt /*20.2* +20.3 usr_20.txt /*20.3* +20.4 usr_20.txt /*20.4* +20.5 usr_20.txt /*20.5* +21.1 usr_21.txt /*21.1* +21.2 usr_21.txt /*21.2* +21.3 usr_21.txt /*21.3* +21.4 usr_21.txt /*21.4* +21.5 usr_21.txt /*21.5* +21.6 usr_21.txt /*21.6* +22.1 usr_22.txt /*22.1* +22.2 usr_22.txt /*22.2* +22.3 usr_22.txt /*22.3* +22.4 usr_22.txt /*22.4* +23.1 usr_23.txt /*23.1* +23.2 usr_23.txt /*23.2* +23.3 usr_23.txt /*23.3* +23.4 usr_23.txt /*23.4* +23.5 usr_23.txt /*23.5* +24.1 usr_24.txt /*24.1* +24.10 usr_24.txt /*24.10* +24.2 usr_24.txt /*24.2* +24.3 usr_24.txt /*24.3* +24.4 usr_24.txt /*24.4* +24.5 usr_24.txt /*24.5* +24.6 usr_24.txt /*24.6* +24.7 usr_24.txt /*24.7* +24.8 usr_24.txt /*24.8* +24.9 usr_24.txt /*24.9* +25.1 usr_25.txt /*25.1* +25.2 usr_25.txt /*25.2* +25.3 usr_25.txt /*25.3* +25.4 usr_25.txt /*25.4* +25.5 usr_25.txt /*25.5* +26.1 usr_26.txt /*26.1* +26.2 usr_26.txt /*26.2* +26.3 usr_26.txt /*26.3* +26.4 usr_26.txt /*26.4* +27.1 usr_27.txt /*27.1* +27.2 usr_27.txt /*27.2* +27.3 usr_27.txt /*27.3* +27.4 usr_27.txt /*27.4* +27.5 usr_27.txt /*27.5* +27.6 usr_27.txt /*27.6* +27.7 usr_27.txt /*27.7* +27.8 usr_27.txt /*27.8* +27.9 usr_27.txt /*27.9* +28.1 usr_28.txt /*28.1* +28.10 usr_28.txt /*28.10* +28.2 usr_28.txt /*28.2* +28.3 usr_28.txt /*28.3* +28.4 usr_28.txt /*28.4* +28.5 usr_28.txt /*28.5* +28.6 usr_28.txt /*28.6* +28.7 usr_28.txt /*28.7* +28.8 usr_28.txt /*28.8* +28.9 usr_28.txt /*28.9* +29.1 usr_29.txt /*29.1* +29.2 usr_29.txt /*29.2* +29.3 usr_29.txt /*29.3* +29.4 usr_29.txt /*29.4* +29.5 usr_29.txt /*29.5* +2html.vim syntax.txt /*2html.vim* +30.1 usr_30.txt /*30.1* +30.2 usr_30.txt /*30.2* +30.3 usr_30.txt /*30.3* +30.4 usr_30.txt /*30.4* +30.5 usr_30.txt /*30.5* +30.6 usr_30.txt /*30.6* +31.1 usr_31.txt /*31.1* +31.2 usr_31.txt /*31.2* +31.3 usr_31.txt /*31.3* +31.4 usr_31.txt /*31.4* +31.5 usr_31.txt /*31.5* +32.1 usr_32.txt /*32.1* +32.2 usr_32.txt /*32.2* +32.3 usr_32.txt /*32.3* +32.4 usr_32.txt /*32.4* +40.1 usr_40.txt /*40.1* +40.2 usr_40.txt /*40.2* +40.3 usr_40.txt /*40.3* +41.1 usr_41.txt /*41.1* +41.10 usr_41.txt /*41.10* +41.11 usr_41.txt /*41.11* +41.12 usr_41.txt /*41.12* +41.13 usr_41.txt /*41.13* +41.14 usr_41.txt /*41.14* +41.15 usr_41.txt /*41.15* +41.16 usr_41.txt /*41.16* +41.2 usr_41.txt /*41.2* +41.3 usr_41.txt /*41.3* +41.4 usr_41.txt /*41.4* +41.5 usr_41.txt /*41.5* +41.6 usr_41.txt /*41.6* +41.7 usr_41.txt /*41.7* +41.8 usr_41.txt /*41.8* +41.9 usr_41.txt /*41.9* +42 usr_42.txt /*42* +42.1 usr_42.txt /*42.1* +42.2 usr_42.txt /*42.2* +42.3 usr_42.txt /*42.3* +42.4 usr_42.txt /*42.4* +43.1 usr_43.txt /*43.1* +43.2 usr_43.txt /*43.2* +44.1 usr_44.txt /*44.1* +44.10 usr_44.txt /*44.10* +44.11 usr_44.txt /*44.11* +44.12 usr_44.txt /*44.12* +44.2 usr_44.txt /*44.2* +44.3 usr_44.txt /*44.3* +44.4 usr_44.txt /*44.4* +44.5 usr_44.txt /*44.5* +44.6 usr_44.txt /*44.6* +44.7 usr_44.txt /*44.7* +44.8 usr_44.txt /*44.8* +44.9 usr_44.txt /*44.9* +45.1 usr_45.txt /*45.1* +45.2 usr_45.txt /*45.2* +45.3 usr_45.txt /*45.3* +45.4 usr_45.txt /*45.4* +45.5 usr_45.txt /*45.5* +8g8 various.txt /*8g8* +90.1 usr_90.txt /*90.1* +90.2 usr_90.txt /*90.2* +90.3 usr_90.txt /*90.3* +90.4 usr_90.txt /*90.4* +90.5 usr_90.txt /*90.5* +: cmdline.txt /*:* +:! various.txt /*:!* +:!! various.txt /*:!!* +:!cmd various.txt /*:!cmd* +:!start os_win32.txt /*:!start* +:# various.txt /*:#* +:#! various.txt /*:#!* +:$ cmdline.txt /*:$* +:% cmdline.txt /*:%* +:& change.txt /*:&* +:' cmdline.txt /*:'* +:, cmdline.txt /*:,* +:. cmdline.txt /*:.* +:/ cmdline.txt /*:\/* +:0file editing.txt /*:0file* +:2match pattern.txt /*:2match* +:3match pattern.txt /*:3match* +::. cmdline.txt /*::.* +::8 cmdline.txt /*::8* +::e cmdline.txt /*::e* +::gs cmdline.txt /*::gs* +::h cmdline.txt /*::h* +::p cmdline.txt /*::p* +::r cmdline.txt /*::r* +::s cmdline.txt /*::s* +::t cmdline.txt /*::t* +::~ cmdline.txt /*::~* +:; cmdline.txt /*:;* +:< change.txt /*:<* +:<abuf> cmdline.txt /*:<abuf>* +:<afile> cmdline.txt /*:<afile>* +:<amatch> cmdline.txt /*:<amatch>* +:<cWORD> cmdline.txt /*:<cWORD>* +:<cfile> cmdline.txt /*:<cfile>* +:<cword> cmdline.txt /*:<cword>* +:<sfile> cmdline.txt /*:<sfile>* +:= various.txt /*:=* +:> change.txt /*:>* +:? cmdline.txt /*:?* +:@ repeat.txt /*:@* +:@: repeat.txt /*:@:* +:@@ repeat.txt /*:@@* +:AdaLines ft_ada.txt /*:AdaLines* +:AdaRainbow ft_ada.txt /*:AdaRainbow* +:AdaSpaces ft_ada.txt /*:AdaSpaces* +:AdaTagDir ft_ada.txt /*:AdaTagDir* +:AdaTagFile ft_ada.txt /*:AdaTagFile* +:AdaTypes ft_ada.txt /*:AdaTypes* +:CompilerSet usr_41.txt /*:CompilerSet* +:DiffOrig diff.txt /*:DiffOrig* +:DoMatchParen pi_paren.txt /*:DoMatchParen* +:Explore pi_netrw.txt /*:Explore* +:GLVS pi_getscript.txt /*:GLVS* +:GetLatestVimScripts_dat pi_getscript.txt /*:GetLatestVimScripts_dat* +:GnatFind ft_ada.txt /*:GnatFind* +:GnatPretty ft_ada.txt /*:GnatPretty* +:GnatTags ft_ada.txt /*:GnatTags* +:Hexplore pi_netrw.txt /*:Hexplore* +:Man filetype.txt /*:Man* +:MkVimball pi_vimball.txt /*:MkVimball* +:N editing.txt /*:N* +:NetrwClean pi_netrw.txt /*:NetrwClean* +:Nexplore pi_netrw.txt /*:Nexplore* +:Next editing.txt /*:Next* +:NoMatchParen pi_paren.txt /*:NoMatchParen* +:Nr pi_netrw.txt /*:Nr* +:Nread pi_netrw.txt /*:Nread* +:Ns pi_netrw.txt /*:Ns* +:Nsource pi_netrw.txt /*:Nsource* +:Nw pi_netrw.txt /*:Nw* +:Nwrite pi_netrw.txt /*:Nwrite* +:P various.txt /*:P* +:Pexplore pi_netrw.txt /*:Pexplore* +:Print various.txt /*:Print* +:Rexplore pi_netrw.txt /*:Rexplore* +:RmVimball pi_vimball.txt /*:RmVimball* +:Sexplore pi_netrw.txt /*:Sexplore* +:TOhtml syntax.txt /*:TOhtml* +:Texplore pi_netrw.txt /*:Texplore* +:UseVimball pi_vimball.txt /*:UseVimball* +:Vexplore pi_netrw.txt /*:Vexplore* +:VimballList pi_vimball.txt /*:VimballList* +:Vimuntar pi_tar.txt /*:Vimuntar* +:X editing.txt /*:X* +:XMLent insert.txt /*:XMLent* +:XMLns insert.txt /*:XMLns* +:\bar cmdline.txt /*:\\bar* +:_! cmdline.txt /*:_!* +:_# cmdline.txt /*:_#* +:_## cmdline.txt /*:_##* +:_#0 cmdline.txt /*:_#0* +:_#< cmdline.txt /*:_#<* +:_#n cmdline.txt /*:_#n* +:_% cmdline.txt /*:_%* +:_%: cmdline.txt /*:_%:* +:_%< cmdline.txt /*:_%<* +:a insert.txt /*:a* +:ab map.txt /*:ab* +:abbreviate map.txt /*:abbreviate* +:abbreviate-<buffer> map.txt /*:abbreviate-<buffer>* +:abbreviate-local map.txt /*:abbreviate-local* +:abbreviate-verbose map.txt /*:abbreviate-verbose* +:abc map.txt /*:abc* +:abclear map.txt /*:abclear* +:abo windows.txt /*:abo* +:aboveleft windows.txt /*:aboveleft* +:al windows.txt /*:al* +:all windows.txt /*:all* +:am gui.txt /*:am* +:amenu gui.txt /*:amenu* +:an gui.txt /*:an* +:anoremenu gui.txt /*:anoremenu* +:append insert.txt /*:append* +:ar editing.txt /*:ar* +:arga editing.txt /*:arga* +:argadd editing.txt /*:argadd* +:argd editing.txt /*:argd* +:argdelete editing.txt /*:argdelete* +:argdo editing.txt /*:argdo* +:arge editing.txt /*:arge* +:argedit editing.txt /*:argedit* +:argglobal editing.txt /*:argglobal* +:arglocal editing.txt /*:arglocal* +:args editing.txt /*:args* +:args_f editing.txt /*:args_f* +:args_f! editing.txt /*:args_f!* +:argu editing.txt /*:argu* +:argument editing.txt /*:argument* +:as various.txt /*:as* +:ascii various.txt /*:ascii* +:au autocmd.txt /*:au* +:aug autocmd.txt /*:aug* +:augroup autocmd.txt /*:augroup* +:augroup-delete autocmd.txt /*:augroup-delete* +:aun gui.txt /*:aun* +:aunmenu gui.txt /*:aunmenu* +:autocmd autocmd.txt /*:autocmd* +:autocmd-verbose autocmd.txt /*:autocmd-verbose* +:b windows.txt /*:b* +:bN windows.txt /*:bN* +:bNext windows.txt /*:bNext* +:ba windows.txt /*:ba* +:bad windows.txt /*:bad* +:badd windows.txt /*:badd* +:ball windows.txt /*:ball* +:bar cmdline.txt /*:bar* +:bd windows.txt /*:bd* +:bdel windows.txt /*:bdel* +:bdelete windows.txt /*:bdelete* +:be gui.txt /*:be* +:behave gui.txt /*:behave* +:bel windows.txt /*:bel* +:belowright windows.txt /*:belowright* +:bf windows.txt /*:bf* +:bfirst windows.txt /*:bfirst* +:bl windows.txt /*:bl* +:blast windows.txt /*:blast* +:bm windows.txt /*:bm* +:bmodified windows.txt /*:bmodified* +:bn windows.txt /*:bn* +:bnext windows.txt /*:bnext* +:botright windows.txt /*:botright* +:bp windows.txt /*:bp* +:bprevious windows.txt /*:bprevious* +:br windows.txt /*:br* +:brea eval.txt /*:brea* +:break eval.txt /*:break* +:breaka repeat.txt /*:breaka* +:breakadd repeat.txt /*:breakadd* +:breakd repeat.txt /*:breakd* +:breakdel repeat.txt /*:breakdel* +:breakl repeat.txt /*:breakl* +:breaklist repeat.txt /*:breaklist* +:brewind windows.txt /*:brewind* +:bro editing.txt /*:bro* +:browse editing.txt /*:browse* +:browse-set options.txt /*:browse-set* +:bu windows.txt /*:bu* +:buf windows.txt /*:buf* +:bufdo windows.txt /*:bufdo* +:buffer windows.txt /*:buffer* +:buffer-! windows.txt /*:buffer-!* +:buffers windows.txt /*:buffers* +:bun windows.txt /*:bun* +:bunload windows.txt /*:bunload* +:bw windows.txt /*:bw* +:bwipe windows.txt /*:bwipe* +:bwipeout windows.txt /*:bwipeout* +:c change.txt /*:c* +:cN quickfix.txt /*:cN* +:cNext quickfix.txt /*:cNext* +:cNf quickfix.txt /*:cNf* +:cNfile quickfix.txt /*:cNfile* +:ca map.txt /*:ca* +:cabbrev map.txt /*:cabbrev* +:cabc map.txt /*:cabc* +:cabclear map.txt /*:cabclear* +:cad quickfix.txt /*:cad* +:caddb quickfix.txt /*:caddb* +:caddbuffer quickfix.txt /*:caddbuffer* +:caddexpr quickfix.txt /*:caddexpr* +:caddf quickfix.txt /*:caddf* +:caddfile quickfix.txt /*:caddfile* +:cal eval.txt /*:cal* +:call eval.txt /*:call* +:cat eval.txt /*:cat* +:catch eval.txt /*:catch* +:cb quickfix.txt /*:cb* +:cbuffer quickfix.txt /*:cbuffer* +:cc quickfix.txt /*:cc* +:ccl quickfix.txt /*:ccl* +:cclose quickfix.txt /*:cclose* +:cd editing.txt /*:cd* +:cd- editing.txt /*:cd-* +:ce change.txt /*:ce* +:center change.txt /*:center* +:cex quickfix.txt /*:cex* +:cexpr quickfix.txt /*:cexpr* +:cf quickfix.txt /*:cf* +:cfile quickfix.txt /*:cfile* +:cfir quickfix.txt /*:cfir* +:cfirst quickfix.txt /*:cfirst* +:cg quickfix.txt /*:cg* +:cgetb quickfix.txt /*:cgetb* +:cgetbuffer quickfix.txt /*:cgetbuffer* +:cgete quickfix.txt /*:cgete* +:cgetexpr quickfix.txt /*:cgetexpr* +:cgetfile quickfix.txt /*:cgetfile* +:ch change.txt /*:ch* +:change change.txt /*:change* +:changes motion.txt /*:changes* +:chd editing.txt /*:chd* +:chdir editing.txt /*:chdir* +:che tagsrch.txt /*:che* +:checkpath tagsrch.txt /*:checkpath* +:checkt editing.txt /*:checkt* +:checktime editing.txt /*:checktime* +:cl quickfix.txt /*:cl* +:cla quickfix.txt /*:cla* +:clast quickfix.txt /*:clast* +:clist quickfix.txt /*:clist* +:clo windows.txt /*:clo* +:close windows.txt /*:close* +:cm map.txt /*:cm* +:cmap map.txt /*:cmap* +:cmap_l map.txt /*:cmap_l* +:cmapc map.txt /*:cmapc* +:cmapclear map.txt /*:cmapclear* +:cme gui.txt /*:cme* +:cmenu gui.txt /*:cmenu* +:cn quickfix.txt /*:cn* +:cnew quickfix.txt /*:cnew* +:cnewer quickfix.txt /*:cnewer* +:cnext quickfix.txt /*:cnext* +:cnf quickfix.txt /*:cnf* +:cnfile quickfix.txt /*:cnfile* +:cno map.txt /*:cno* +:cnorea map.txt /*:cnorea* +:cnoreabbrev map.txt /*:cnoreabbrev* +:cnoremap map.txt /*:cnoremap* +:cnoreme gui.txt /*:cnoreme* +:cnoremenu gui.txt /*:cnoremenu* +:co change.txt /*:co* +:col quickfix.txt /*:col* +:colder quickfix.txt /*:colder* +:colo syntax.txt /*:colo* +:colorscheme syntax.txt /*:colorscheme* +:com map.txt /*:com* +:comc map.txt /*:comc* +:comclear map.txt /*:comclear* +:command map.txt /*:command* +:command-bang map.txt /*:command-bang* +:command-bar map.txt /*:command-bar* +:command-buffer map.txt /*:command-buffer* +:command-complete map.txt /*:command-complete* +:command-completion map.txt /*:command-completion* +:command-completion-custom map.txt /*:command-completion-custom* +:command-completion-customlist map.txt /*:command-completion-customlist* +:command-count map.txt /*:command-count* +:command-nargs map.txt /*:command-nargs* +:command-range map.txt /*:command-range* +:command-register map.txt /*:command-register* +:command-verbose map.txt /*:command-verbose* +:comment cmdline.txt /*:comment* +:comp quickfix.txt /*:comp* +:compiler quickfix.txt /*:compiler* +:con eval.txt /*:con* +:conf editing.txt /*:conf* +:confirm editing.txt /*:confirm* +:continue eval.txt /*:continue* +:cope quickfix.txt /*:cope* +:copen quickfix.txt /*:copen* +:copy change.txt /*:copy* +:cp quickfix.txt /*:cp* +:cpf quickfix.txt /*:cpf* +:cpfile quickfix.txt /*:cpfile* +:cprevious quickfix.txt /*:cprevious* +:cq quickfix.txt /*:cq* +:cquit quickfix.txt /*:cquit* +:cr quickfix.txt /*:cr* +:crewind quickfix.txt /*:crewind* +:cs if_cscop.txt /*:cs* +:cscope if_cscop.txt /*:cscope* +:cstag if_cscop.txt /*:cstag* +:cu map.txt /*:cu* +:cuna map.txt /*:cuna* +:cunabbrev map.txt /*:cunabbrev* +:cunmap map.txt /*:cunmap* +:cunme gui.txt /*:cunme* +:cunmenu gui.txt /*:cunmenu* +:cw quickfix.txt /*:cw* +:cwindow quickfix.txt /*:cwindow* +:d change.txt /*:d* +:de change.txt /*:de* +:debug repeat.txt /*:debug* +:debug-name repeat.txt /*:debug-name* +:debugg repeat.txt /*:debugg* +:debuggreedy repeat.txt /*:debuggreedy* +:del change.txt /*:del* +:delc map.txt /*:delc* +:delcommand map.txt /*:delcommand* +:delcr todo.txt /*:delcr* +:delete change.txt /*:delete* +:delf eval.txt /*:delf* +:delfunction eval.txt /*:delfunction* +:delm motion.txt /*:delm* +:delmarks motion.txt /*:delmarks* +:di change.txt /*:di* +:diffg diff.txt /*:diffg* +:diffget diff.txt /*:diffget* +:diffo diff.txt /*:diffo* +:diffoff diff.txt /*:diffoff* +:diffp diff.txt /*:diffp* +:diffpatch diff.txt /*:diffpatch* +:diffpu diff.txt /*:diffpu* +:diffput diff.txt /*:diffput* +:diffs diff.txt /*:diffs* +:diffsplit diff.txt /*:diffsplit* +:difft diff.txt /*:difft* +:diffthis diff.txt /*:diffthis* +:diffu diff.txt /*:diffu* +:diffupdate diff.txt /*:diffupdate* +:dig digraph.txt /*:dig* +:digraphs digraph.txt /*:digraphs* +:display change.txt /*:display* +:dj tagsrch.txt /*:dj* +:djump tagsrch.txt /*:djump* +:dli tagsrch.txt /*:dli* +:dlist tagsrch.txt /*:dlist* +:do autocmd.txt /*:do* +:doau autocmd.txt /*:doau* +:doautoa autocmd.txt /*:doautoa* +:doautoall autocmd.txt /*:doautoall* +:doautocmd autocmd.txt /*:doautocmd* +:dr windows.txt /*:dr* +:drop windows.txt /*:drop* +:ds tagsrch.txt /*:ds* +:dsearch tagsrch.txt /*:dsearch* +:dsp tagsrch.txt /*:dsp* +:dsplit tagsrch.txt /*:dsplit* +:e editing.txt /*:e* +:ea undo.txt /*:ea* +:earlier undo.txt /*:earlier* +:ec eval.txt /*:ec* +:echo eval.txt /*:echo* +:echo-redraw eval.txt /*:echo-redraw* +:echoe eval.txt /*:echoe* +:echoerr eval.txt /*:echoerr* +:echoh eval.txt /*:echoh* +:echohl eval.txt /*:echohl* +:echom eval.txt /*:echom* +:echomsg eval.txt /*:echomsg* +:echon eval.txt /*:echon* +:edit editing.txt /*:edit* +:edit! editing.txt /*:edit!* +:edit!_f editing.txt /*:edit!_f* +:edit_f editing.txt /*:edit_f* +:el eval.txt /*:el* +:else eval.txt /*:else* +:elsei eval.txt /*:elsei* +:elseif eval.txt /*:elseif* +:em gui.txt /*:em* +:emenu gui.txt /*:emenu* +:en eval.txt /*:en* +:endf eval.txt /*:endf* +:endfo eval.txt /*:endfo* +:endfor eval.txt /*:endfor* +:endfunction eval.txt /*:endfunction* +:endif eval.txt /*:endif* +:endt eval.txt /*:endt* +:endtry eval.txt /*:endtry* +:endw eval.txt /*:endw* +:endwhile eval.txt /*:endwhile* +:ene editing.txt /*:ene* +:ene! editing.txt /*:ene!* +:enew editing.txt /*:enew* +:enew! editing.txt /*:enew!* +:ex editing.txt /*:ex* +:exe eval.txt /*:exe* +:exe-comment eval.txt /*:exe-comment* +:execute eval.txt /*:execute* +:exi editing.txt /*:exi* +:exit editing.txt /*:exit* +:exu helphelp.txt /*:exu* +:exusage helphelp.txt /*:exusage* +:f editing.txt /*:f* +:fi editing.txt /*:fi* +:file editing.txt /*:file* +:file_f editing.txt /*:file_f* +:filename editing.txt /*:filename* +:files windows.txt /*:files* +:filet filetype.txt /*:filet* +:filetype filetype.txt /*:filetype* +:filetype-indent-off filetype.txt /*:filetype-indent-off* +:filetype-indent-on filetype.txt /*:filetype-indent-on* +:filetype-off filetype.txt /*:filetype-off* +:filetype-overview filetype.txt /*:filetype-overview* +:filetype-plugin-off filetype.txt /*:filetype-plugin-off* +:filetype-plugin-on filetype.txt /*:filetype-plugin-on* +:fin editing.txt /*:fin* +:fina eval.txt /*:fina* +:finally eval.txt /*:finally* +:find editing.txt /*:find* +:fini repeat.txt /*:fini* +:finish repeat.txt /*:finish* +:fir editing.txt /*:fir* +:first editing.txt /*:first* +:fix options.txt /*:fix* +:fixdel options.txt /*:fixdel* +:fo fold.txt /*:fo* +:fold fold.txt /*:fold* +:foldc fold.txt /*:foldc* +:foldclose fold.txt /*:foldclose* +:foldd fold.txt /*:foldd* +:folddoc fold.txt /*:folddoc* +:folddoclosed fold.txt /*:folddoclosed* +:folddoopen fold.txt /*:folddoopen* +:foldo fold.txt /*:foldo* +:foldopen fold.txt /*:foldopen* +:for eval.txt /*:for* +:fu eval.txt /*:fu* +:function eval.txt /*:function* +:function-verbose eval.txt /*:function-verbose* +:g repeat.txt /*:g* +:global repeat.txt /*:global* +:go motion.txt /*:go* +:goto motion.txt /*:goto* +:gr quickfix.txt /*:gr* +:grep quickfix.txt /*:grep* +:grepa quickfix.txt /*:grepa* +:grepadd quickfix.txt /*:grepadd* +:gu gui_x11.txt /*:gu* +:gui gui_x11.txt /*:gui* +:gv gui_x11.txt /*:gv* +:gvim gui_x11.txt /*:gvim* +:h helphelp.txt /*:h* +:ha print.txt /*:ha* +:hardcopy print.txt /*:hardcopy* +:help helphelp.txt /*:help* +:helpf helphelp.txt /*:helpf* +:helpfind helphelp.txt /*:helpfind* +:helpg helphelp.txt /*:helpg* +:helpgrep helphelp.txt /*:helpgrep* +:helpt helphelp.txt /*:helpt* +:helptags helphelp.txt /*:helptags* +:hi syntax.txt /*:hi* +:hi-default syntax.txt /*:hi-default* +:hi-link syntax.txt /*:hi-link* +:hi-normal syntax.txt /*:hi-normal* +:hi-normal-cterm syntax.txt /*:hi-normal-cterm* +:hide windows.txt /*:hide* +:highlight syntax.txt /*:highlight* +:highlight-default syntax.txt /*:highlight-default* +:highlight-link syntax.txt /*:highlight-link* +:highlight-normal syntax.txt /*:highlight-normal* +:highlight-verbose syntax.txt /*:highlight-verbose* +:his cmdline.txt /*:his* +:history cmdline.txt /*:history* +:history-indexing cmdline.txt /*:history-indexing* +:i insert.txt /*:i* +:ia map.txt /*:ia* +:iabbrev map.txt /*:iabbrev* +:iabc map.txt /*:iabc* +:iabclear map.txt /*:iabclear* +:if eval.txt /*:if* +:ij tagsrch.txt /*:ij* +:ijump tagsrch.txt /*:ijump* +:il tagsrch.txt /*:il* +:ilist tagsrch.txt /*:ilist* +:im map.txt /*:im* +:imap map.txt /*:imap* +:imap_l map.txt /*:imap_l* +:imapc map.txt /*:imapc* +:imapclear map.txt /*:imapclear* +:ime gui.txt /*:ime* +:imenu gui.txt /*:imenu* +:in insert.txt /*:in* +:index index.txt /*:index* +:ino map.txt /*:ino* +:inorea map.txt /*:inorea* +:inoreabbrev map.txt /*:inoreabbrev* +:inoremap map.txt /*:inoremap* +:inoreme gui.txt /*:inoreme* +:inoremenu gui.txt /*:inoremenu* +:insert insert.txt /*:insert* +:intro starting.txt /*:intro* +:is tagsrch.txt /*:is* +:isearch tagsrch.txt /*:isearch* +:isp tagsrch.txt /*:isp* +:isplit tagsrch.txt /*:isplit* +:iu map.txt /*:iu* +:iuna map.txt /*:iuna* +:iunabbrev map.txt /*:iunabbrev* +:iunmap map.txt /*:iunmap* +:iunme gui.txt /*:iunme* +:iunmenu gui.txt /*:iunmenu* +:j change.txt /*:j* +:join change.txt /*:join* +:ju motion.txt /*:ju* +:jumps motion.txt /*:jumps* +:k motion.txt /*:k* +:kee motion.txt /*:kee* +:keepa editing.txt /*:keepa* +:keepalt editing.txt /*:keepalt* +:keepj motion.txt /*:keepj* +:keepjumps motion.txt /*:keepjumps* +:keepmarks motion.txt /*:keepmarks* +:l various.txt /*:l* +:lN quickfix.txt /*:lN* +:lNext quickfix.txt /*:lNext* +:lNf quickfix.txt /*:lNf* +:lNfile quickfix.txt /*:lNfile* +:la editing.txt /*:la* +:lad quickfix.txt /*:lad* +:laddb quickfix.txt /*:laddb* +:laddbuffer quickfix.txt /*:laddbuffer* +:laddexpr quickfix.txt /*:laddexpr* +:laddf quickfix.txt /*:laddf* +:laddfile quickfix.txt /*:laddfile* +:lan mlang.txt /*:lan* +:lang mlang.txt /*:lang* +:language mlang.txt /*:language* +:last editing.txt /*:last* +:lat undo.txt /*:lat* +:later undo.txt /*:later* +:lb quickfix.txt /*:lb* +:lbuffer quickfix.txt /*:lbuffer* +:lc editing.txt /*:lc* +:lcd editing.txt /*:lcd* +:lch editing.txt /*:lch* +:lchdir editing.txt /*:lchdir* +:lcl quickfix.txt /*:lcl* +:lclose quickfix.txt /*:lclose* +:lcs if_cscop.txt /*:lcs* +:lcscope if_cscop.txt /*:lcscope* +:le change.txt /*:le* +:left change.txt /*:left* +:lefta windows.txt /*:lefta* +:leftabove windows.txt /*:leftabove* +:let eval.txt /*:let* +:let+= eval.txt /*:let+=* +:let-$ eval.txt /*:let-$* +:let-& eval.txt /*:let-&* +:let-= eval.txt /*:let-=* +:let-@ eval.txt /*:let-@* +:let-environment eval.txt /*:let-environment* +:let-option eval.txt /*:let-option* +:let-register eval.txt /*:let-register* +:let-unpack eval.txt /*:let-unpack* +:let.= eval.txt /*:let.=* +:lex quickfix.txt /*:lex* +:lexpr quickfix.txt /*:lexpr* +:lf quickfix.txt /*:lf* +:lfile quickfix.txt /*:lfile* +:lfir quickfix.txt /*:lfir* +:lfirst quickfix.txt /*:lfirst* +:lg quickfix.txt /*:lg* +:lgetb quickfix.txt /*:lgetb* +:lgetbuffer quickfix.txt /*:lgetbuffer* +:lgete quickfix.txt /*:lgete* +:lgetexpr quickfix.txt /*:lgetexpr* +:lgetfile quickfix.txt /*:lgetfile* +:lgr quickfix.txt /*:lgr* +:lgrep quickfix.txt /*:lgrep* +:lgrepa quickfix.txt /*:lgrepa* +:lgrepadd quickfix.txt /*:lgrepadd* +:lh helphelp.txt /*:lh* +:lhelpgrep helphelp.txt /*:lhelpgrep* +:list various.txt /*:list* +:ll quickfix.txt /*:ll* +:lla quickfix.txt /*:lla* +:llast quickfix.txt /*:llast* +:lli quickfix.txt /*:lli* +:llist quickfix.txt /*:llist* +:lm map.txt /*:lm* +:lmak quickfix.txt /*:lmak* +:lmake quickfix.txt /*:lmake* +:lmap map.txt /*:lmap* +:lmap_l map.txt /*:lmap_l* +:lmapc map.txt /*:lmapc* +:lmapclear map.txt /*:lmapclear* +:ln map.txt /*:ln* +:lne quickfix.txt /*:lne* +:lnew quickfix.txt /*:lnew* +:lnewer quickfix.txt /*:lnewer* +:lnext quickfix.txt /*:lnext* +:lnf quickfix.txt /*:lnf* +:lnfile quickfix.txt /*:lnfile* +:lnoremap map.txt /*:lnoremap* +:lo starting.txt /*:lo* +:loadk mbyte.txt /*:loadk* +:loadkeymap mbyte.txt /*:loadkeymap* +:loadview starting.txt /*:loadview* +:loc motion.txt /*:loc* +:lockmarks motion.txt /*:lockmarks* +:lockv eval.txt /*:lockv* +:lockvar eval.txt /*:lockvar* +:lol quickfix.txt /*:lol* +:lolder quickfix.txt /*:lolder* +:lop quickfix.txt /*:lop* +:lopen quickfix.txt /*:lopen* +:lp quickfix.txt /*:lp* +:lpf quickfix.txt /*:lpf* +:lpfile quickfix.txt /*:lpfile* +:lprevious quickfix.txt /*:lprevious* +:lr quickfix.txt /*:lr* +:lrewind quickfix.txt /*:lrewind* +:ls windows.txt /*:ls* +:lt tagsrch.txt /*:lt* +:ltag tagsrch.txt /*:ltag* +:lu map.txt /*:lu* +:lua if_lua.txt /*:lua* +:luado if_lua.txt /*:luado* +:luafile if_lua.txt /*:luafile* +:lunmap map.txt /*:lunmap* +:lv quickfix.txt /*:lv* +:lvimgrep quickfix.txt /*:lvimgrep* +:lvimgrepa quickfix.txt /*:lvimgrepa* +:lvimgrepadd quickfix.txt /*:lvimgrepadd* +:lw quickfix.txt /*:lw* +:lwindow quickfix.txt /*:lwindow* +:m change.txt /*:m* +:ma motion.txt /*:ma* +:mak quickfix.txt /*:mak* +:make quickfix.txt /*:make* +:make_makeprg quickfix.txt /*:make_makeprg* +:map map.txt /*:map* +:map! map.txt /*:map!* +:map-<buffer> map.txt /*:map-<buffer>* +:map-<expr> map.txt /*:map-<expr>* +:map-<script> map.txt /*:map-<script>* +:map-<silent> map.txt /*:map-<silent>* +:map-<special> map.txt /*:map-<special>* +:map-<unique> map.txt /*:map-<unique>* +:map-alt-keys map.txt /*:map-alt-keys* +:map-arguments map.txt /*:map-arguments* +:map-commands map.txt /*:map-commands* +:map-expression map.txt /*:map-expression* +:map-local map.txt /*:map-local* +:map-modes map.txt /*:map-modes* +:map-operator map.txt /*:map-operator* +:map-script map.txt /*:map-script* +:map-silent map.txt /*:map-silent* +:map-special map.txt /*:map-special* +:map-special-chars map.txt /*:map-special-chars* +:map-special-keys map.txt /*:map-special-keys* +:map-undo map.txt /*:map-undo* +:map-verbose map.txt /*:map-verbose* +:map_l map.txt /*:map_l* +:map_l! map.txt /*:map_l!* +:mapc map.txt /*:mapc* +:mapc! map.txt /*:mapc!* +:mapclear map.txt /*:mapclear* +:mapclear! map.txt /*:mapclear!* +:mark motion.txt /*:mark* +:marks motion.txt /*:marks* +:mat pattern.txt /*:mat* +:match pattern.txt /*:match* +:me gui.txt /*:me* +:menu gui.txt /*:menu* +:menu-<script> gui.txt /*:menu-<script>* +:menu-<silent> gui.txt /*:menu-<silent>* +:menu-<special> gui.txt /*:menu-<special>* +:menu-disable gui.txt /*:menu-disable* +:menu-enable gui.txt /*:menu-enable* +:menu-script gui.txt /*:menu-script* +:menu-silent gui.txt /*:menu-silent* +:menu-special gui.txt /*:menu-special* +:menut mlang.txt /*:menut* +:menutrans mlang.txt /*:menutrans* +:menutranslate mlang.txt /*:menutranslate* +:mes message.txt /*:mes* +:messages message.txt /*:messages* +:mk starting.txt /*:mk* +:mkexrc starting.txt /*:mkexrc* +:mks starting.txt /*:mks* +:mksession starting.txt /*:mksession* +:mksp spell.txt /*:mksp* +:mkspell spell.txt /*:mkspell* +:mkv starting.txt /*:mkv* +:mkvie starting.txt /*:mkvie* +:mkview starting.txt /*:mkview* +:mkvimrc starting.txt /*:mkvimrc* +:mo change.txt /*:mo* +:mod term.txt /*:mod* +:mode term.txt /*:mode* +:move change.txt /*:move* +:mz if_mzsch.txt /*:mz* +:mzf if_mzsch.txt /*:mzf* +:mzfile if_mzsch.txt /*:mzfile* +:mzscheme if_mzsch.txt /*:mzscheme* +:n editing.txt /*:n* +:nbclose netbeans.txt /*:nbclose* +:nbkey netbeans.txt /*:nbkey* +:nbstart netbeans.txt /*:nbstart* +:ne editing.txt /*:ne* +:new windows.txt /*:new* +:next editing.txt /*:next* +:next_f editing.txt /*:next_f* +:nm map.txt /*:nm* +:nmap map.txt /*:nmap* +:nmap_l map.txt /*:nmap_l* +:nmapc map.txt /*:nmapc* +:nmapclear map.txt /*:nmapclear* +:nme gui.txt /*:nme* +:nmenu gui.txt /*:nmenu* +:nn map.txt /*:nn* +:nnoremap map.txt /*:nnoremap* +:nnoreme gui.txt /*:nnoreme* +:nnoremenu gui.txt /*:nnoremenu* +:no map.txt /*:no* +:no! map.txt /*:no!* +:noa autocmd.txt /*:noa* +:noautocmd autocmd.txt /*:noautocmd* +:noh pattern.txt /*:noh* +:nohlsearch pattern.txt /*:nohlsearch* +:norea map.txt /*:norea* +:noreabbrev map.txt /*:noreabbrev* +:noremap map.txt /*:noremap* +:noremap! map.txt /*:noremap!* +:noreme gui.txt /*:noreme* +:noremenu gui.txt /*:noremenu* +:norm various.txt /*:norm* +:normal various.txt /*:normal* +:normal-range various.txt /*:normal-range* +:nu various.txt /*:nu* +:number various.txt /*:number* +:nun map.txt /*:nun* +:nunmap map.txt /*:nunmap* +:nunme gui.txt /*:nunme* +:nunmenu gui.txt /*:nunmenu* +:o vi_diff.txt /*:o* +:ol starting.txt /*:ol* +:oldfiles starting.txt /*:oldfiles* +:om map.txt /*:om* +:omap map.txt /*:omap* +:omap_l map.txt /*:omap_l* +:omapc map.txt /*:omapc* +:omapclear map.txt /*:omapclear* +:ome gui.txt /*:ome* +:omenu gui.txt /*:omenu* +:on windows.txt /*:on* +:only windows.txt /*:only* +:ono map.txt /*:ono* +:onoremap map.txt /*:onoremap* +:onoreme gui.txt /*:onoreme* +:onoremenu gui.txt /*:onoremenu* +:op vi_diff.txt /*:op* +:open vi_diff.txt /*:open* +:opt options.txt /*:opt* +:options options.txt /*:options* +:ou map.txt /*:ou* +:ounmap map.txt /*:ounmap* +:ounme gui.txt /*:ounme* +:ounmenu gui.txt /*:ounmenu* +:ownsyntax syntax.txt /*:ownsyntax* +:p various.txt /*:p* +:pc windows.txt /*:pc* +:pclose windows.txt /*:pclose* +:pe if_perl.txt /*:pe* +:ped windows.txt /*:ped* +:pedit windows.txt /*:pedit* +:perl if_perl.txt /*:perl* +:perld if_perl.txt /*:perld* +:perldo if_perl.txt /*:perldo* +:po tagsrch.txt /*:po* +:pop tagsrch.txt /*:pop* +:popu gui.txt /*:popu* +:popup gui.txt /*:popup* +:pp windows.txt /*:pp* +:ppop windows.txt /*:ppop* +:pr various.txt /*:pr* +:pre recover.txt /*:pre* +:preserve recover.txt /*:preserve* +:prev editing.txt /*:prev* +:previous editing.txt /*:previous* +:print various.txt /*:print* +:pro change.txt /*:pro* +:prof repeat.txt /*:prof* +:profd repeat.txt /*:profd* +:profdel repeat.txt /*:profdel* +:profile repeat.txt /*:profile* +:promptfind change.txt /*:promptfind* +:promptr change.txt /*:promptr* +:promptrepl change.txt /*:promptrepl* +:ps windows.txt /*:ps* +:psearch windows.txt /*:psearch* +:ptN tagsrch.txt /*:ptN* +:ptNext tagsrch.txt /*:ptNext* +:pta windows.txt /*:pta* +:ptag windows.txt /*:ptag* +:ptf tagsrch.txt /*:ptf* +:ptfirst tagsrch.txt /*:ptfirst* +:ptj tagsrch.txt /*:ptj* +:ptjump tagsrch.txt /*:ptjump* +:ptl tagsrch.txt /*:ptl* +:ptlast tagsrch.txt /*:ptlast* +:ptn tagsrch.txt /*:ptn* +:ptnext tagsrch.txt /*:ptnext* +:ptp tagsrch.txt /*:ptp* +:ptprevious tagsrch.txt /*:ptprevious* +:ptr tagsrch.txt /*:ptr* +:ptrewind tagsrch.txt /*:ptrewind* +:pts tagsrch.txt /*:pts* +:ptselect tagsrch.txt /*:ptselect* +:pu change.txt /*:pu* +:put change.txt /*:put* +:pw editing.txt /*:pw* +:pwd editing.txt /*:pwd* +:py if_pyth.txt /*:py* +:py3 if_pyth.txt /*:py3* +:py3file if_pyth.txt /*:py3file* +:pyf if_pyth.txt /*:pyf* +:pyfile if_pyth.txt /*:pyfile* +:python if_pyth.txt /*:python* +:python3 if_pyth.txt /*:python3* +:q editing.txt /*:q* +:qa editing.txt /*:qa* +:qall editing.txt /*:qall* +:quit editing.txt /*:quit* +:quita editing.txt /*:quita* +:quitall editing.txt /*:quitall* +:quote cmdline.txt /*:quote* +:r insert.txt /*:r* +:r! insert.txt /*:r!* +:range cmdline.txt /*:range* +:range! change.txt /*:range!* +:re insert.txt /*:re* +:read insert.txt /*:read* +:read! insert.txt /*:read!* +:rec recover.txt /*:rec* +:recover recover.txt /*:recover* +:recover-crypt recover.txt /*:recover-crypt* +:red undo.txt /*:red* +:redi various.txt /*:redi* +:redir various.txt /*:redir* +:redo undo.txt /*:redo* +:redr various.txt /*:redr* +:redraw various.txt /*:redraw* +:redraws various.txt /*:redraws* +:redrawstatus various.txt /*:redrawstatus* +:reg change.txt /*:reg* +:registers change.txt /*:registers* +:res windows.txt /*:res* +:resize windows.txt /*:resize* +:ret change.txt /*:ret* +:retab change.txt /*:retab* +:retu eval.txt /*:retu* +:return eval.txt /*:return* +:rew editing.txt /*:rew* +:rewind editing.txt /*:rewind* +:ri change.txt /*:ri* +:right change.txt /*:right* +:rightb windows.txt /*:rightb* +:rightbelow windows.txt /*:rightbelow* +:ru repeat.txt /*:ru* +:rub if_ruby.txt /*:rub* +:ruby if_ruby.txt /*:ruby* +:rubyd if_ruby.txt /*:rubyd* +:rubydo if_ruby.txt /*:rubydo* +:rubyf if_ruby.txt /*:rubyf* +:rubyfile if_ruby.txt /*:rubyfile* +:rundo undo.txt /*:rundo* +:runtime repeat.txt /*:runtime* +:rv starting.txt /*:rv* +:rviminfo starting.txt /*:rviminfo* +:s change.txt /*:s* +:s% change.txt /*:s%* +:sN windows.txt /*:sN* +:sNext windows.txt /*:sNext* +:s\= change.txt /*:s\\=* +:s_c change.txt /*:s_c* +:s_flags change.txt /*:s_flags* +:sa windows.txt /*:sa* +:sal windows.txt /*:sal* +:sall windows.txt /*:sall* +:san eval.txt /*:san* +:sandbox eval.txt /*:sandbox* +:sargument windows.txt /*:sargument* +:sav editing.txt /*:sav* +:saveas editing.txt /*:saveas* +:sb windows.txt /*:sb* +:sbN windows.txt /*:sbN* +:sbNext windows.txt /*:sbNext* +:sba windows.txt /*:sba* +:sball windows.txt /*:sball* +:sbf windows.txt /*:sbf* +:sbfirst windows.txt /*:sbfirst* +:sbl windows.txt /*:sbl* +:sblast windows.txt /*:sblast* +:sbm windows.txt /*:sbm* +:sbmodified windows.txt /*:sbmodified* +:sbn windows.txt /*:sbn* +:sbnext windows.txt /*:sbnext* +:sbp windows.txt /*:sbp* +:sbprevious windows.txt /*:sbprevious* +:sbr windows.txt /*:sbr* +:sbrewind windows.txt /*:sbrewind* +:sbuffer windows.txt /*:sbuffer* +:scrip repeat.txt /*:scrip* +:scripte repeat.txt /*:scripte* +:scriptencoding repeat.txt /*:scriptencoding* +:scriptnames repeat.txt /*:scriptnames* +:scs if_cscop.txt /*:scs* +:scscope if_cscop.txt /*:scscope* +:se options.txt /*:se* +:search-args tagsrch.txt /*:search-args* +:set options.txt /*:set* +:set+= options.txt /*:set+=* +:set-! options.txt /*:set-!* +:set-& options.txt /*:set-&* +:set-&vi options.txt /*:set-&vi* +:set-&vim options.txt /*:set-&vim* +:set-= options.txt /*:set-=* +:set-args options.txt /*:set-args* +:set-browse options.txt /*:set-browse* +:set-default options.txt /*:set-default* +:set-inv options.txt /*:set-inv* +:set-termcap options.txt /*:set-termcap* +:set-verbose options.txt /*:set-verbose* +:set^= options.txt /*:set^=* +:set_env options.txt /*:set_env* +:setf options.txt /*:setf* +:setfiletype options.txt /*:setfiletype* +:setg options.txt /*:setg* +:setglobal options.txt /*:setglobal* +:setl options.txt /*:setl* +:setlocal options.txt /*:setlocal* +:sf windows.txt /*:sf* +:sfind windows.txt /*:sfind* +:sfir windows.txt /*:sfir* +:sfirst windows.txt /*:sfirst* +:sh various.txt /*:sh* +:shell various.txt /*:shell* +:si gui_w32.txt /*:si* +:sig sign.txt /*:sig* +:sign sign.txt /*:sign* +:sign-define sign.txt /*:sign-define* +:sign-fname sign.txt /*:sign-fname* +:sign-jump sign.txt /*:sign-jump* +:sign-list sign.txt /*:sign-list* +:sign-place sign.txt /*:sign-place* +:sign-undefine sign.txt /*:sign-undefine* +:sign-unplace sign.txt /*:sign-unplace* +:sil various.txt /*:sil* +:silent various.txt /*:silent* +:simalt gui_w32.txt /*:simalt* +:sl various.txt /*:sl* +:sla windows.txt /*:sla* +:slast windows.txt /*:slast* +:sleep various.txt /*:sleep* +:sm change.txt /*:sm* +:smagic change.txt /*:smagic* +:smap map.txt /*:smap* +:smap_l map.txt /*:smap_l* +:smapc map.txt /*:smapc* +:smapclear map.txt /*:smapclear* +:sme gui.txt /*:sme* +:smenu gui.txt /*:smenu* +:sn windows.txt /*:sn* +:snext windows.txt /*:snext* +:sni if_sniff.txt /*:sni* +:sniff if_sniff.txt /*:sniff* +:sno change.txt /*:sno* +:snomagic change.txt /*:snomagic* +:snor map.txt /*:snor* +:snoremap map.txt /*:snoremap* +:snoreme gui.txt /*:snoreme* +:snoremenu gui.txt /*:snoremenu* +:so repeat.txt /*:so* +:sor change.txt /*:sor* +:sort change.txt /*:sort* +:source repeat.txt /*:source* +:source_crnl repeat.txt /*:source_crnl* +:sp windows.txt /*:sp* +:spe spell.txt /*:spe* +:spelld spell.txt /*:spelld* +:spelldump spell.txt /*:spelldump* +:spellgood spell.txt /*:spellgood* +:spelli spell.txt /*:spelli* +:spellinfo spell.txt /*:spellinfo* +:spellr spell.txt /*:spellr* +:spellrepall spell.txt /*:spellrepall* +:spellu spell.txt /*:spellu* +:spellundo spell.txt /*:spellundo* +:spellw spell.txt /*:spellw* +:spellwrong spell.txt /*:spellwrong* +:split windows.txt /*:split* +:split_f windows.txt /*:split_f* +:spr windows.txt /*:spr* +:sprevious windows.txt /*:sprevious* +:sre windows.txt /*:sre* +:srewind windows.txt /*:srewind* +:st starting.txt /*:st* +:sta windows.txt /*:sta* +:stag windows.txt /*:stag* +:star repeat.txt /*:star* +:start insert.txt /*:start* +:startgreplace insert.txt /*:startgreplace* +:startinsert insert.txt /*:startinsert* +:startreplace insert.txt /*:startreplace* +:stj tagsrch.txt /*:stj* +:stjump tagsrch.txt /*:stjump* +:stop starting.txt /*:stop* +:stopi insert.txt /*:stopi* +:stopinsert insert.txt /*:stopinsert* +:sts tagsrch.txt /*:sts* +:stselect tagsrch.txt /*:stselect* +:su change.txt /*:su* +:substitute change.txt /*:substitute* +:sun windows.txt /*:sun* +:sunhide windows.txt /*:sunhide* +:sunm map.txt /*:sunm* +:sunmap map.txt /*:sunmap* +:sunme gui.txt /*:sunme* +:sunmenu gui.txt /*:sunmenu* +:sus starting.txt /*:sus* +:suspend starting.txt /*:suspend* +:sv windows.txt /*:sv* +:sview windows.txt /*:sview* +:sw recover.txt /*:sw* +:swapname recover.txt /*:swapname* +:sy syntax.txt /*:sy* +:syn syntax.txt /*:syn* +:syn-arguments syntax.txt /*:syn-arguments* +:syn-case syntax.txt /*:syn-case* +:syn-cchar syntax.txt /*:syn-cchar* +:syn-clear syntax.txt /*:syn-clear* +:syn-cluster syntax.txt /*:syn-cluster* +:syn-conceal syntax.txt /*:syn-conceal* +:syn-conceal-implicit syntax.txt /*:syn-conceal-implicit* +:syn-concealends syntax.txt /*:syn-concealends* +:syn-contained syntax.txt /*:syn-contained* +:syn-containedin syntax.txt /*:syn-containedin* +:syn-contains syntax.txt /*:syn-contains* +:syn-context syntax.txt /*:syn-context* +:syn-default-override usr_06.txt /*:syn-default-override* +:syn-define syntax.txt /*:syn-define* +:syn-display syntax.txt /*:syn-display* +:syn-enable syntax.txt /*:syn-enable* +:syn-end syntax.txt /*:syn-end* +:syn-excludenl syntax.txt /*:syn-excludenl* +:syn-ext-match syntax.txt /*:syn-ext-match* +:syn-extend syntax.txt /*:syn-extend* +:syn-file-remarks syntax.txt /*:syn-file-remarks* +:syn-files syntax.txt /*:syn-files* +:syn-fold syntax.txt /*:syn-fold* +:syn-include syntax.txt /*:syn-include* +:syn-keepend syntax.txt /*:syn-keepend* +:syn-keyword syntax.txt /*:syn-keyword* +:syn-lc syntax.txt /*:syn-lc* +:syn-leading syntax.txt /*:syn-leading* +:syn-list syntax.txt /*:syn-list* +:syn-manual usr_06.txt /*:syn-manual* +:syn-match syntax.txt /*:syn-match* +:syn-matchgroup syntax.txt /*:syn-matchgroup* +:syn-multi-line syntax.txt /*:syn-multi-line* +:syn-nextgroup syntax.txt /*:syn-nextgroup* +:syn-off usr_06.txt /*:syn-off* +:syn-on syntax.txt /*:syn-on* +:syn-oneline syntax.txt /*:syn-oneline* +:syn-pattern syntax.txt /*:syn-pattern* +:syn-pattern-offset syntax.txt /*:syn-pattern-offset* +:syn-priority syntax.txt /*:syn-priority* +:syn-qstart syntax.txt /*:syn-qstart* +:syn-region syntax.txt /*:syn-region* +:syn-reset syntax.txt /*:syn-reset* +:syn-skip syntax.txt /*:syn-skip* +:syn-skipempty syntax.txt /*:syn-skipempty* +:syn-skipnl syntax.txt /*:syn-skipnl* +:syn-skipwhite syntax.txt /*:syn-skipwhite* +:syn-spell syntax.txt /*:syn-spell* +:syn-start syntax.txt /*:syn-start* +:syn-sync syntax.txt /*:syn-sync* +:syn-sync-ccomment syntax.txt /*:syn-sync-ccomment* +:syn-sync-first syntax.txt /*:syn-sync-first* +:syn-sync-fourth syntax.txt /*:syn-sync-fourth* +:syn-sync-linebreaks syntax.txt /*:syn-sync-linebreaks* +:syn-sync-maxlines syntax.txt /*:syn-sync-maxlines* +:syn-sync-minlines syntax.txt /*:syn-sync-minlines* +:syn-sync-second syntax.txt /*:syn-sync-second* +:syn-sync-third syntax.txt /*:syn-sync-third* +:syn-transparent syntax.txt /*:syn-transparent* +:sync scroll.txt /*:sync* +:syncbind scroll.txt /*:syncbind* +:syntax syntax.txt /*:syntax* +:syntax-enable syntax.txt /*:syntax-enable* +:syntax-on syntax.txt /*:syntax-on* +:syntax-reset syntax.txt /*:syntax-reset* +:t change.txt /*:t* +:tN tagsrch.txt /*:tN* +:tNext tagsrch.txt /*:tNext* +:ta tagsrch.txt /*:ta* +:tab tabpage.txt /*:tab* +:tabN tabpage.txt /*:tabN* +:tabNext tabpage.txt /*:tabNext* +:tabc tabpage.txt /*:tabc* +:tabclose tabpage.txt /*:tabclose* +:tabd tabpage.txt /*:tabd* +:tabdo tabpage.txt /*:tabdo* +:tabe tabpage.txt /*:tabe* +:tabedit tabpage.txt /*:tabedit* +:tabf tabpage.txt /*:tabf* +:tabfind tabpage.txt /*:tabfind* +:tabfir tabpage.txt /*:tabfir* +:tabfirst tabpage.txt /*:tabfirst* +:tabl tabpage.txt /*:tabl* +:tablast tabpage.txt /*:tablast* +:tabm tabpage.txt /*:tabm* +:tabmove tabpage.txt /*:tabmove* +:tabn tabpage.txt /*:tabn* +:tabnew tabpage.txt /*:tabnew* +:tabnext tabpage.txt /*:tabnext* +:tabo tabpage.txt /*:tabo* +:tabonly tabpage.txt /*:tabonly* +:tabp tabpage.txt /*:tabp* +:tabprevious tabpage.txt /*:tabprevious* +:tabr tabpage.txt /*:tabr* +:tabrewind tabpage.txt /*:tabrewind* +:tabs tabpage.txt /*:tabs* +:tag tagsrch.txt /*:tag* +:tags tagsrch.txt /*:tags* +:tc if_tcl.txt /*:tc* +:tcl if_tcl.txt /*:tcl* +:tcld if_tcl.txt /*:tcld* +:tcldo if_tcl.txt /*:tcldo* +:tclf if_tcl.txt /*:tclf* +:tclfile if_tcl.txt /*:tclfile* +:te gui_w32.txt /*:te* +:tearoff gui_w32.txt /*:tearoff* +:tf tagsrch.txt /*:tf* +:tfirst tagsrch.txt /*:tfirst* +:th eval.txt /*:th* +:throw eval.txt /*:throw* +:tj tagsrch.txt /*:tj* +:tjump tagsrch.txt /*:tjump* +:tl tagsrch.txt /*:tl* +:tlast tagsrch.txt /*:tlast* +:tm gui.txt /*:tm* +:tmenu gui.txt /*:tmenu* +:tn tagsrch.txt /*:tn* +:tnext tagsrch.txt /*:tnext* +:topleft windows.txt /*:topleft* +:tp tagsrch.txt /*:tp* +:tprevious tagsrch.txt /*:tprevious* +:tr tagsrch.txt /*:tr* +:trewind tagsrch.txt /*:trewind* +:try eval.txt /*:try* +:ts tagsrch.txt /*:ts* +:tselect tagsrch.txt /*:tselect* +:tu gui.txt /*:tu* +:tunmenu gui.txt /*:tunmenu* +:u undo.txt /*:u* +:un undo.txt /*:un* +:una map.txt /*:una* +:unabbreviate map.txt /*:unabbreviate* +:undo undo.txt /*:undo* +:undoj undo.txt /*:undoj* +:undojoin undo.txt /*:undojoin* +:undol undo.txt /*:undol* +:undolist undo.txt /*:undolist* +:unh windows.txt /*:unh* +:unhide windows.txt /*:unhide* +:unl eval.txt /*:unl* +:unlet eval.txt /*:unlet* +:unlo eval.txt /*:unlo* +:unlockvar eval.txt /*:unlockvar* +:unm map.txt /*:unm* +:unm! map.txt /*:unm!* +:unmap map.txt /*:unmap* +:unmap! map.txt /*:unmap!* +:unme gui.txt /*:unme* +:unmenu gui.txt /*:unmenu* +:unmenu-all gui.txt /*:unmenu-all* +:uns various.txt /*:uns* +:unsilent various.txt /*:unsilent* +:up editing.txt /*:up* +:update editing.txt /*:update* +:v repeat.txt /*:v* +:ve various.txt /*:ve* +:verb various.txt /*:verb* +:verbose various.txt /*:verbose* +:verbose-cmd various.txt /*:verbose-cmd* +:version various.txt /*:version* +:vert windows.txt /*:vert* +:vertical windows.txt /*:vertical* +:vertical-resize windows.txt /*:vertical-resize* +:vglobal repeat.txt /*:vglobal* +:vi editing.txt /*:vi* +:vie editing.txt /*:vie* +:view editing.txt /*:view* +:vim quickfix.txt /*:vim* +:vimgrep quickfix.txt /*:vimgrep* +:vimgrepa quickfix.txt /*:vimgrepa* +:vimgrepadd quickfix.txt /*:vimgrepadd* +:visual editing.txt /*:visual* +:visual_example visual.txt /*:visual_example* +:viu helphelp.txt /*:viu* +:viusage helphelp.txt /*:viusage* +:vm map.txt /*:vm* +:vmap map.txt /*:vmap* +:vmap_l map.txt /*:vmap_l* +:vmapc map.txt /*:vmapc* +:vmapclear map.txt /*:vmapclear* +:vme gui.txt /*:vme* +:vmenu gui.txt /*:vmenu* +:vn map.txt /*:vn* +:vne windows.txt /*:vne* +:vnew windows.txt /*:vnew* +:vnoremap map.txt /*:vnoremap* +:vnoreme gui.txt /*:vnoreme* +:vnoremenu gui.txt /*:vnoremenu* +:vs windows.txt /*:vs* +:vsplit windows.txt /*:vsplit* +:vu map.txt /*:vu* +:vunmap map.txt /*:vunmap* +:vunme gui.txt /*:vunme* +:vunmenu gui.txt /*:vunmenu* +:w editing.txt /*:w* +:w! editing.txt /*:w!* +:wN editing.txt /*:wN* +:wNext editing.txt /*:wNext* +:w_a editing.txt /*:w_a* +:w_c editing.txt /*:w_c* +:w_f editing.txt /*:w_f* +:wa editing.txt /*:wa* +:wall editing.txt /*:wall* +:wh eval.txt /*:wh* +:while eval.txt /*:while* +:win gui.txt /*:win* +:winc windows.txt /*:winc* +:wincmd windows.txt /*:wincmd* +:windo windows.txt /*:windo* +:winp gui.txt /*:winp* +:winpos gui.txt /*:winpos* +:winsize gui.txt /*:winsize* +:wn editing.txt /*:wn* +:wnext editing.txt /*:wnext* +:wp editing.txt /*:wp* +:wprevious editing.txt /*:wprevious* +:wq editing.txt /*:wq* +:wqa editing.txt /*:wqa* +:wqall editing.txt /*:wqall* +:write editing.txt /*:write* +:write_a editing.txt /*:write_a* +:write_c editing.txt /*:write_c* +:write_f editing.txt /*:write_f* +:ws workshop.txt /*:ws* +:wsverb workshop.txt /*:wsverb* +:wundo undo.txt /*:wundo* +:wv starting.txt /*:wv* +:wviminfo starting.txt /*:wviminfo* +:x editing.txt /*:x* +:xa editing.txt /*:xa* +:xall editing.txt /*:xall* +:xit editing.txt /*:xit* +:xm map.txt /*:xm* +:xmap map.txt /*:xmap* +:xmap_l map.txt /*:xmap_l* +:xmapc map.txt /*:xmapc* +:xmapclear map.txt /*:xmapclear* +:xme gui.txt /*:xme* +:xmenu gui.txt /*:xmenu* +:xn map.txt /*:xn* +:xnoremap map.txt /*:xnoremap* +:xnoreme gui.txt /*:xnoreme* +:xnoremenu gui.txt /*:xnoremenu* +:xu map.txt /*:xu* +:xunmap map.txt /*:xunmap* +:xunme gui.txt /*:xunme* +:xunmenu gui.txt /*:xunmenu* +:y change.txt /*:y* +:yank change.txt /*:yank* +:z various.txt /*:z* +:z# various.txt /*:z#* +:~ change.txt /*:~* +; motion.txt /*;* +< change.txt /*<* +<2-LeftMouse> term.txt /*<2-LeftMouse>* +<3-LeftMouse> term.txt /*<3-LeftMouse>* +<4-LeftMouse> term.txt /*<4-LeftMouse>* +<< change.txt /*<<* +<> intro.txt /*<>* +<A- intro.txt /*<A-* +<A-LeftMouse> term.txt /*<A-LeftMouse>* +<A-RightMouse> term.txt /*<A-RightMouse>* +<BS> motion.txt /*<BS>* +<Bar> intro.txt /*<Bar>* +<Bslash> intro.txt /*<Bslash>* +<C- intro.txt /*<C-* +<C-Del> os_dos.txt /*<C-Del>* +<C-End> motion.txt /*<C-End>* +<C-Home> motion.txt /*<C-Home>* +<C-Insert> os_dos.txt /*<C-Insert>* +<C-Left> motion.txt /*<C-Left>* +<C-LeftMouse> tagsrch.txt /*<C-LeftMouse>* +<C-PageDown> tabpage.txt /*<C-PageDown>* +<C-PageUp> tabpage.txt /*<C-PageUp>* +<C-Right> motion.txt /*<C-Right>* +<C-RightMouse> tagsrch.txt /*<C-RightMouse>* +<C-ScrollWheelDown> scroll.txt /*<C-ScrollWheelDown>* +<C-ScrollWheelLeft> scroll.txt /*<C-ScrollWheelLeft>* +<C-ScrollWheelRight> scroll.txt /*<C-ScrollWheelRight>* +<C-ScrollWheelUp> scroll.txt /*<C-ScrollWheelUp>* +<CR> motion.txt /*<CR>* +<CSI> intro.txt /*<CSI>* +<Char-> map.txt /*<Char->* +<Char> map.txt /*<Char>* +<D- intro.txt /*<D-* +<Del> change.txt /*<Del>* +<Down> motion.txt /*<Down>* +<Drop> change.txt /*<Drop>* +<EOL> intro.txt /*<EOL>* +<End> motion.txt /*<End>* +<Enter> intro.txt /*<Enter>* +<Esc> intro.txt /*<Esc>* +<F10> term.txt /*<F10>* +<F11> term.txt /*<F11>* +<F12> term.txt /*<F12>* +<F13> term.txt /*<F13>* +<F14> term.txt /*<F14>* +<F15> term.txt /*<F15>* +<F16> term.txt /*<F16>* +<F17> term.txt /*<F17>* +<F18> term.txt /*<F18>* +<F19> term.txt /*<F19>* +<F1> helphelp.txt /*<F1>* +<F2> term.txt /*<F2>* +<F3> term.txt /*<F3>* +<F4> term.txt /*<F4>* +<F5> term.txt /*<F5>* +<F6> term.txt /*<F6>* +<F7> term.txt /*<F7>* +<F8> term.txt /*<F8>* +<F9> term.txt /*<F9>* +<Help> helphelp.txt /*<Help>* +<Home> motion.txt /*<Home>* +<Insert> insert.txt /*<Insert>* +<Leader> map.txt /*<Leader>* +<Left> motion.txt /*<Left>* +<LeftDrag> term.txt /*<LeftDrag>* +<LeftMouse> visual.txt /*<LeftMouse>* +<LeftRelease> visual.txt /*<LeftRelease>* +<LocalLeader> map.txt /*<LocalLeader>* +<M- intro.txt /*<M-* +<MiddleDrag> term.txt /*<MiddleDrag>* +<MiddleMouse> change.txt /*<MiddleMouse>* +<MiddleRelease> term.txt /*<MiddleRelease>* +<Mouse> term.txt /*<Mouse>* +<MouseDown> scroll.txt /*<MouseDown>* +<MouseUp> scroll.txt /*<MouseUp>* +<NL> motion.txt /*<NL>* +<Nop> map.txt /*<Nop>* +<Nul> intro.txt /*<Nul>* +<PageDown> scroll.txt /*<PageDown>* +<PageUp> scroll.txt /*<PageUp>* +<Plug> map.txt /*<Plug>* +<Return> intro.txt /*<Return>* +<Right> motion.txt /*<Right>* +<RightDrag> term.txt /*<RightDrag>* +<RightMouse> visual.txt /*<RightMouse>* +<RightRelease> term.txt /*<RightRelease>* +<S- intro.txt /*<S-* +<S-Del> os_dos.txt /*<S-Del>* +<S-Down> scroll.txt /*<S-Down>* +<S-End> term.txt /*<S-End>* +<S-F10> term.txt /*<S-F10>* +<S-F11> term.txt /*<S-F11>* +<S-F12> term.txt /*<S-F12>* +<S-F1> intro.txt /*<S-F1>* +<S-F2> term.txt /*<S-F2>* +<S-F3> term.txt /*<S-F3>* +<S-F4> term.txt /*<S-F4>* +<S-F5> term.txt /*<S-F5>* +<S-F6> term.txt /*<S-F6>* +<S-F7> term.txt /*<S-F7>* +<S-F8> term.txt /*<S-F8>* +<S-F9> term.txt /*<S-F9>* +<S-Home> term.txt /*<S-Home>* +<S-Insert> os_dos.txt /*<S-Insert>* +<S-Left> motion.txt /*<S-Left>* +<S-LeftMouse> term.txt /*<S-LeftMouse>* +<S-Right> motion.txt /*<S-Right>* +<S-RightMouse> term.txt /*<S-RightMouse>* +<S-ScrollWheelDown> scroll.txt /*<S-ScrollWheelDown>* +<S-ScrollWheelLeft> scroll.txt /*<S-ScrollWheelLeft>* +<S-ScrollWheelRight> scroll.txt /*<S-ScrollWheelRight>* +<S-ScrollWheelUp> scroll.txt /*<S-ScrollWheelUp>* +<S-Tab> term.txt /*<S-Tab>* +<S-Up> scroll.txt /*<S-Up>* +<S-xF1> term.txt /*<S-xF1>* +<S-xF2> term.txt /*<S-xF2>* +<S-xF3> term.txt /*<S-xF3>* +<S-xF4> term.txt /*<S-xF4>* +<SID> map.txt /*<SID>* +<SNR> map.txt /*<SNR>* +<ScrollWheelDown> scroll.txt /*<ScrollWheelDown>* +<ScrollWheelLeft> scroll.txt /*<ScrollWheelLeft>* +<ScrollWheelRight> scroll.txt /*<ScrollWheelRight>* +<ScrollWheelUp> scroll.txt /*<ScrollWheelUp>* +<Space> motion.txt /*<Space>* +<Tab> motion.txt /*<Tab>* +<Undo> undo.txt /*<Undo>* +<Up> motion.txt /*<Up>* +<abuf> cmdline.txt /*<abuf>* +<afile> cmdline.txt /*<afile>* +<amatch> cmdline.txt /*<amatch>* +<args> map.txt /*<args>* +<bang> map.txt /*<bang>* +<buffer=N> autocmd.txt /*<buffer=N>* +<buffer=abuf> autocmd.txt /*<buffer=abuf>* +<cfile> cmdline.txt /*<cfile>* +<character> intro.txt /*<character>* +<count> map.txt /*<count>* +<f-args> map.txt /*<f-args>* +<k0> term.txt /*<k0>* +<k1> term.txt /*<k1>* +<k2> term.txt /*<k2>* +<k3> term.txt /*<k3>* +<k4> term.txt /*<k4>* +<k5> term.txt /*<k5>* +<k6> term.txt /*<k6>* +<k7> term.txt /*<k7>* +<k8> term.txt /*<k8>* +<k9> term.txt /*<k9>* +<kDivide> term.txt /*<kDivide>* +<kEnd> motion.txt /*<kEnd>* +<kEnter> term.txt /*<kEnter>* +<kHome> motion.txt /*<kHome>* +<kMinus> term.txt /*<kMinus>* +<kMultiply> term.txt /*<kMultiply>* +<kPageDown> scroll.txt /*<kPageDown>* +<kPageUp> scroll.txt /*<kPageUp>* +<kPlus> term.txt /*<kPlus>* +<kPoint> term.txt /*<kPoint>* +<line1> map.txt /*<line1>* +<line2> map.txt /*<line2>* +<lt> intro.txt /*<lt>* +<q-args> map.txt /*<q-args>* +<reg> map.txt /*<reg>* +<register> map.txt /*<register>* +<sfile> cmdline.txt /*<sfile>* +<xCSI> intro.txt /*<xCSI>* +<xDown> term.txt /*<xDown>* +<xEnd> term.txt /*<xEnd>* +<xEnd>-xterm term.txt /*<xEnd>-xterm* +<xF1> term.txt /*<xF1>* +<xF1>-xterm term.txt /*<xF1>-xterm* +<xF2> term.txt /*<xF2>* +<xF2>-xterm term.txt /*<xF2>-xterm* +<xF3> term.txt /*<xF3>* +<xF3>-xterm term.txt /*<xF3>-xterm* +<xF4> term.txt /*<xF4>* +<xF4>-xterm term.txt /*<xF4>-xterm* +<xHome> term.txt /*<xHome>* +<xHome>-xterm term.txt /*<xHome>-xterm* +<xLeft> term.txt /*<xLeft>* +<xRight> term.txt /*<xRight>* +<xUp> term.txt /*<xUp>* += change.txt /*=* +== change.txt /*==* +> change.txt /*>* +>> change.txt /*>>* +>cont repeat.txt /*>cont* +>finish repeat.txt /*>finish* +>interrupt repeat.txt /*>interrupt* +>next repeat.txt /*>next* +>quit repeat.txt /*>quit* +>step repeat.txt /*>step* +? pattern.txt /*?* +?<CR> pattern.txt /*?<CR>* +@ repeat.txt /*@* +@/ change.txt /*@\/* +@: repeat.txt /*@:* +@= change.txt /*@=* +@@ repeat.txt /*@@* +@r eval.txt /*@r* +A insert.txt /*A* +ACL editing.txt /*ACL* +ATTENTION usr_11.txt /*ATTENTION* +Abbreviations map.txt /*Abbreviations* +Aleph options.txt /*Aleph* +Amiga os_amiga.txt /*Amiga* +Arabic arabic.txt /*Arabic* +Atari os_mint.txt /*Atari* +Athena gui_x11.txt /*Athena* +B motion.txt /*B* +BeBox os_beos.txt /*BeBox* +BeOS os_beos.txt /*BeOS* +Bram intro.txt /*Bram* +BufAdd autocmd.txt /*BufAdd* +BufCreate autocmd.txt /*BufCreate* +BufDelete autocmd.txt /*BufDelete* +BufEnter autocmd.txt /*BufEnter* +BufFilePost autocmd.txt /*BufFilePost* +BufFilePre autocmd.txt /*BufFilePre* +BufHidden autocmd.txt /*BufHidden* +BufLeave autocmd.txt /*BufLeave* +BufNew autocmd.txt /*BufNew* +BufNewFile autocmd.txt /*BufNewFile* +BufRead autocmd.txt /*BufRead* +BufReadCmd autocmd.txt /*BufReadCmd* +BufReadPost autocmd.txt /*BufReadPost* +BufReadPre autocmd.txt /*BufReadPre* +BufUnload autocmd.txt /*BufUnload* +BufWinEnter autocmd.txt /*BufWinEnter* +BufWinLeave autocmd.txt /*BufWinLeave* +BufWipeout autocmd.txt /*BufWipeout* +BufWrite autocmd.txt /*BufWrite* +BufWriteCmd autocmd.txt /*BufWriteCmd* +BufWritePost autocmd.txt /*BufWritePost* +BufWritePre autocmd.txt /*BufWritePre* +C change.txt /*C* +C-editing tips.txt /*C-editing* +C-indenting indent.txt /*C-indenting* +COMSPEC starting.txt /*COMSPEC* +CR-used-for-NL pattern.txt /*CR-used-for-NL* +CTRL-6 editing.txt /*CTRL-6* +CTRL-<PageDown> tabpage.txt /*CTRL-<PageDown>* +CTRL-<PageUp> tabpage.txt /*CTRL-<PageUp>* +CTRL-A change.txt /*CTRL-A* +CTRL-B scroll.txt /*CTRL-B* +CTRL-C pattern.txt /*CTRL-C* +CTRL-D scroll.txt /*CTRL-D* +CTRL-E scroll.txt /*CTRL-E* +CTRL-F scroll.txt /*CTRL-F* +CTRL-G editing.txt /*CTRL-G* +CTRL-H motion.txt /*CTRL-H* +CTRL-I motion.txt /*CTRL-I* +CTRL-J motion.txt /*CTRL-J* +CTRL-L various.txt /*CTRL-L* +CTRL-M motion.txt /*CTRL-M* +CTRL-N motion.txt /*CTRL-N* +CTRL-O motion.txt /*CTRL-O* +CTRL-P motion.txt /*CTRL-P* +CTRL-Q gui_w32.txt /*CTRL-Q* +CTRL-R undo.txt /*CTRL-R* +CTRL-T tagsrch.txt /*CTRL-T* +CTRL-U scroll.txt /*CTRL-U* +CTRL-U-changed version6.txt /*CTRL-U-changed* +CTRL-V visual.txt /*CTRL-V* +CTRL-V-alternative gui_w32.txt /*CTRL-V-alternative* +CTRL-W index.txt /*CTRL-W* +CTRL-W_+ windows.txt /*CTRL-W_+* +CTRL-W_- windows.txt /*CTRL-W_-* +CTRL-W_< windows.txt /*CTRL-W_<* +CTRL-W_<BS> windows.txt /*CTRL-W_<BS>* +CTRL-W_<CR> quickfix.txt /*CTRL-W_<CR>* +CTRL-W_<Down> windows.txt /*CTRL-W_<Down>* +CTRL-W_<Enter> quickfix.txt /*CTRL-W_<Enter>* +CTRL-W_<Left> windows.txt /*CTRL-W_<Left>* +CTRL-W_<Right> windows.txt /*CTRL-W_<Right>* +CTRL-W_<Up> windows.txt /*CTRL-W_<Up>* +CTRL-W_= windows.txt /*CTRL-W_=* +CTRL-W_> windows.txt /*CTRL-W_>* +CTRL-W_CTRL-B windows.txt /*CTRL-W_CTRL-B* +CTRL-W_CTRL-C windows.txt /*CTRL-W_CTRL-C* +CTRL-W_CTRL-D tagsrch.txt /*CTRL-W_CTRL-D* +CTRL-W_CTRL-F windows.txt /*CTRL-W_CTRL-F* +CTRL-W_CTRL-H windows.txt /*CTRL-W_CTRL-H* +CTRL-W_CTRL-I tagsrch.txt /*CTRL-W_CTRL-I* +CTRL-W_CTRL-J windows.txt /*CTRL-W_CTRL-J* +CTRL-W_CTRL-K windows.txt /*CTRL-W_CTRL-K* +CTRL-W_CTRL-L windows.txt /*CTRL-W_CTRL-L* +CTRL-W_CTRL-N windows.txt /*CTRL-W_CTRL-N* +CTRL-W_CTRL-O windows.txt /*CTRL-W_CTRL-O* +CTRL-W_CTRL-P windows.txt /*CTRL-W_CTRL-P* +CTRL-W_CTRL-Q windows.txt /*CTRL-W_CTRL-Q* +CTRL-W_CTRL-R windows.txt /*CTRL-W_CTRL-R* +CTRL-W_CTRL-S windows.txt /*CTRL-W_CTRL-S* +CTRL-W_CTRL-T windows.txt /*CTRL-W_CTRL-T* +CTRL-W_CTRL-V windows.txt /*CTRL-W_CTRL-V* +CTRL-W_CTRL-W windows.txt /*CTRL-W_CTRL-W* +CTRL-W_CTRL-X windows.txt /*CTRL-W_CTRL-X* +CTRL-W_CTRL-Z windows.txt /*CTRL-W_CTRL-Z* +CTRL-W_CTRL-] windows.txt /*CTRL-W_CTRL-]* +CTRL-W_CTRL-^ windows.txt /*CTRL-W_CTRL-^* +CTRL-W_CTRL-_ windows.txt /*CTRL-W_CTRL-_* +CTRL-W_F windows.txt /*CTRL-W_F* +CTRL-W_H windows.txt /*CTRL-W_H* +CTRL-W_J windows.txt /*CTRL-W_J* +CTRL-W_K windows.txt /*CTRL-W_K* +CTRL-W_L windows.txt /*CTRL-W_L* +CTRL-W_P windows.txt /*CTRL-W_P* +CTRL-W_R windows.txt /*CTRL-W_R* +CTRL-W_S windows.txt /*CTRL-W_S* +CTRL-W_T windows.txt /*CTRL-W_T* +CTRL-W_W windows.txt /*CTRL-W_W* +CTRL-W_] windows.txt /*CTRL-W_]* +CTRL-W_^ windows.txt /*CTRL-W_^* +CTRL-W__ windows.txt /*CTRL-W__* +CTRL-W_b windows.txt /*CTRL-W_b* +CTRL-W_bar windows.txt /*CTRL-W_bar* +CTRL-W_c windows.txt /*CTRL-W_c* +CTRL-W_d tagsrch.txt /*CTRL-W_d* +CTRL-W_f windows.txt /*CTRL-W_f* +CTRL-W_gF windows.txt /*CTRL-W_gF* +CTRL-W_g] windows.txt /*CTRL-W_g]* +CTRL-W_g_CTRL-] windows.txt /*CTRL-W_g_CTRL-]* +CTRL-W_gf windows.txt /*CTRL-W_gf* +CTRL-W_g} windows.txt /*CTRL-W_g}* +CTRL-W_h windows.txt /*CTRL-W_h* +CTRL-W_i tagsrch.txt /*CTRL-W_i* +CTRL-W_j windows.txt /*CTRL-W_j* +CTRL-W_k windows.txt /*CTRL-W_k* +CTRL-W_l windows.txt /*CTRL-W_l* +CTRL-W_n windows.txt /*CTRL-W_n* +CTRL-W_o windows.txt /*CTRL-W_o* +CTRL-W_p windows.txt /*CTRL-W_p* +CTRL-W_q windows.txt /*CTRL-W_q* +CTRL-W_r windows.txt /*CTRL-W_r* +CTRL-W_s windows.txt /*CTRL-W_s* +CTRL-W_t windows.txt /*CTRL-W_t* +CTRL-W_v windows.txt /*CTRL-W_v* +CTRL-W_w windows.txt /*CTRL-W_w* +CTRL-W_x windows.txt /*CTRL-W_x* +CTRL-W_z windows.txt /*CTRL-W_z* +CTRL-W_} windows.txt /*CTRL-W_}* +CTRL-X change.txt /*CTRL-X* +CTRL-Y scroll.txt /*CTRL-Y* +CTRL-Z starting.txt /*CTRL-Z* +CTRL-\_CTRL-G intro.txt /*CTRL-\\_CTRL-G* +CTRL-\_CTRL-N intro.txt /*CTRL-\\_CTRL-N* +CTRL-] tagsrch.txt /*CTRL-]* +CTRL-^ editing.txt /*CTRL-^* +CTRL-{char} intro.txt /*CTRL-{char}* +Chinese mbyte.txt /*Chinese* +Cmd-event autocmd.txt /*Cmd-event* +Cmdline cmdline.txt /*Cmdline* +Cmdline-mode cmdline.txt /*Cmdline-mode* +CmdwinEnter autocmd.txt /*CmdwinEnter* +CmdwinLeave autocmd.txt /*CmdwinLeave* +ColorScheme autocmd.txt /*ColorScheme* +Command-line cmdline.txt /*Command-line* +Command-line-mode cmdline.txt /*Command-line-mode* +Contents quickref.txt /*Contents* +Cscope if_cscop.txt /*Cscope* +CursorHold autocmd.txt /*CursorHold* +CursorHold-example windows.txt /*CursorHold-example* +CursorHoldI autocmd.txt /*CursorHoldI* +CursorIM mbyte.txt /*CursorIM* +CursorMoved autocmd.txt /*CursorMoved* +CursorMovedI autocmd.txt /*CursorMovedI* +D change.txt /*D* +DOS os_dos.txt /*DOS* +DOS-format editing.txt /*DOS-format* +DOS-format-write editing.txt /*DOS-format-write* +DPMI os_msdos.txt /*DPMI* +Dictionaries eval.txt /*Dictionaries* +Dictionary eval.txt /*Dictionary* +Dictionary-function eval.txt /*Dictionary-function* +Digraphs digraph.txt /*Digraphs* +E motion.txt /*E* +E10 message.txt /*E10* +E100 diff.txt /*E100* +E101 diff.txt /*E101* +E102 diff.txt /*E102* +E103 diff.txt /*E103* +E104 digraph.txt /*E104* +E105 mbyte.txt /*E105* +E106 eval.txt /*E106* +E107 eval.txt /*E107* +E108 eval.txt /*E108* +E109 eval.txt /*E109* +E11 cmdline.txt /*E11* +E110 eval.txt /*E110* +E111 eval.txt /*E111* +E112 eval.txt /*E112* +E113 eval.txt /*E113* +E114 eval.txt /*E114* +E115 eval.txt /*E115* +E116 eval.txt /*E116* +E117 eval.txt /*E117* +E118 eval.txt /*E118* +E119 eval.txt /*E119* +E12 message.txt /*E12* +E120 eval.txt /*E120* +E121 eval.txt /*E121* +E122 eval.txt /*E122* +E123 eval.txt /*E123* +E124 eval.txt /*E124* +E125 eval.txt /*E125* +E126 eval.txt /*E126* +E127 eval.txt /*E127* +E128 eval.txt /*E128* +E129 eval.txt /*E129* +E13 message.txt /*E13* +E130 eval.txt /*E130* +E131 eval.txt /*E131* +E132 eval.txt /*E132* +E133 eval.txt /*E133* +E134 change.txt /*E134* +E135 autocmd.txt /*E135* +E136 starting.txt /*E136* +E137 starting.txt /*E137* +E138 starting.txt /*E138* +E139 message.txt /*E139* +E14 cmdline.txt /*E14* +E140 message.txt /*E140* +E141 message.txt /*E141* +E142 message.txt /*E142* +E143 autocmd.txt /*E143* +E144 various.txt /*E144* +E145 starting.txt /*E145* +E146 change.txt /*E146* +E147 repeat.txt /*E147* +E148 repeat.txt /*E148* +E149 helphelp.txt /*E149* +E15 eval.txt /*E15* +E150 helphelp.txt /*E150* +E151 helphelp.txt /*E151* +E152 helphelp.txt /*E152* +E153 helphelp.txt /*E153* +E154 helphelp.txt /*E154* +E155 sign.txt /*E155* +E156 sign.txt /*E156* +E157 sign.txt /*E157* +E158 sign.txt /*E158* +E159 sign.txt /*E159* +E16 cmdline.txt /*E16* +E160 sign.txt /*E160* +E161 repeat.txt /*E161* +E162 message.txt /*E162* +E163 editing.txt /*E163* +E164 editing.txt /*E164* +E165 editing.txt /*E165* +E166 message.txt /*E166* +E167 repeat.txt /*E167* +E168 repeat.txt /*E168* +E169 message.txt /*E169* +E17 message.txt /*E17* +E170 eval.txt /*E170* +E171 eval.txt /*E171* +E172 message.txt /*E172* +E173 message.txt /*E173* +E174 map.txt /*E174* +E175 map.txt /*E175* +E176 map.txt /*E176* +E177 map.txt /*E177* +E178 map.txt /*E178* +E179 map.txt /*E179* +E18 eval.txt /*E18* +E180 map.txt /*E180* +E181 map.txt /*E181* +E182 map.txt /*E182* +E183 map.txt /*E183* +E184 map.txt /*E184* +E185 syntax.txt /*E185* +E186 editing.txt /*E186* +E187 editing.txt /*E187* +E188 gui.txt /*E188* +E189 message.txt /*E189* +E19 message.txt /*E19* +E190 message.txt /*E190* +E191 motion.txt /*E191* +E192 message.txt /*E192* +E193 eval.txt /*E193* +E194 message.txt /*E194* +E195 starting.txt /*E195* +E196 various.txt /*E196* +E197 mlang.txt /*E197* +E198 options.txt /*E198* +E199 cmdline.txt /*E199* +E20 motion.txt /*E20* +E200 autocmd.txt /*E200* +E201 autocmd.txt /*E201* +E202 options.txt /*E202* +E203 autocmd.txt /*E203* +E204 autocmd.txt /*E204* +E205 if_pyth.txt /*E205* +E206 options.txt /*E206* +E207 editing.txt /*E207* +E208 message.txt /*E208* +E209 message.txt /*E209* +E21 options.txt /*E21* +E210 message.txt /*E210* +E211 message.txt /*E211* +E212 message.txt /*E212* +E213 options.txt /*E213* +E214 options.txt /*E214* +E215 autocmd.txt /*E215* +E216 autocmd.txt /*E216* +E217 autocmd.txt /*E217* +E218 autocmd.txt /*E218* +E219 message.txt /*E219* +E22 message.txt /*E22* +E220 message.txt /*E220* +E222 message.txt /*E222* +E223 options.txt /*E223* +E224 map.txt /*E224* +E225 map.txt /*E225* +E226 map.txt /*E226* +E227 map.txt /*E227* +E228 message.txt /*E228* +E229 gui.txt /*E229* +E23 message.txt /*E23* +E230 starting.txt /*E230* +E231 options.txt /*E231* +E232 message.txt /*E232* +E233 gui.txt /*E233* +E234 options.txt /*E234* +E235 options.txt /*E235* +E236 options.txt /*E236* +E237 print.txt /*E237* +E238 print.txt /*E238* +E239 sign.txt /*E239* +E24 message.txt /*E24* +E240 remote.txt /*E240* +E241 eval.txt /*E241* +E243 if_ole.txt /*E243* +E244 options.txt /*E244* +E245 options.txt /*E245* +E246 autocmd.txt /*E246* +E247 remote.txt /*E247* +E248 remote.txt /*E248* +E25 message.txt /*E25* +E250 options.txt /*E250* +E251 remote.txt /*E251* +E252 options.txt /*E252* +E253 mbyte.txt /*E253* +E254 message.txt /*E254* +E255 sign.txt /*E255* +E256 message.txt /*E256* +E257 if_cscop.txt /*E257* +E258 remote.txt /*E258* +E259 if_cscop.txt /*E259* +E26 rileft.txt /*E26* +E260 if_cscop.txt /*E260* +E261 if_cscop.txt /*E261* +E262 if_cscop.txt /*E262* +E263 if_pyth.txt /*E263* +E264 if_pyth.txt /*E264* +E265 if_ruby.txt /*E265* +E266 if_ruby.txt /*E266* +E267 if_ruby.txt /*E267* +E268 if_ruby.txt /*E268* +E269 if_ruby.txt /*E269* +E27 farsi.txt /*E27* +E270 if_ruby.txt /*E270* +E271 if_ruby.txt /*E271* +E272 if_ruby.txt /*E272* +E273 if_ruby.txt /*E273* +E274 if_sniff.txt /*E274* +E275 if_sniff.txt /*E275* +E276 if_sniff.txt /*E276* +E277 remote.txt /*E277* +E278 if_sniff.txt /*E278* +E279 if_sniff.txt /*E279* +E28 syntax.txt /*E28* +E280 if_tcl.txt /*E280* +E281 if_tcl.txt /*E281* +E282 starting.txt /*E282* +E283 motion.txt /*E283* +E284 mbyte.txt /*E284* +E285 mbyte.txt /*E285* +E286 mbyte.txt /*E286* +E287 mbyte.txt /*E287* +E288 mbyte.txt /*E288* +E289 mbyte.txt /*E289* +E29 change.txt /*E29* +E290 mbyte.txt /*E290* +E291 mbyte.txt /*E291* +E292 mbyte.txt /*E292* +E293 message.txt /*E293* +E294 message.txt /*E294* +E295 message.txt /*E295* +E296 message.txt /*E296* +E297 message.txt /*E297* +E298 message.txt /*E298* +E299 if_perl.txt /*E299* +E30 change.txt /*E30* +E300 message.txt /*E300* +E301 message.txt /*E301* +E302 message.txt /*E302* +E303 message.txt /*E303* +E304 message.txt /*E304* +E305 recover.txt /*E305* +E306 recover.txt /*E306* +E307 recover.txt /*E307* +E308 recover.txt /*E308* +E309 recover.txt /*E309* +E31 message.txt /*E31* +E310 recover.txt /*E310* +E311 recover.txt /*E311* +E312 recover.txt /*E312* +E313 recover.txt /*E313* +E314 recover.txt /*E314* +E315 message.txt /*E315* +E316 message.txt /*E316* +E317 message.txt /*E317* +E318 message.txt /*E318* +E319 message.txt /*E319* +E32 message.txt /*E32* +E320 message.txt /*E320* +E321 editing.txt /*E321* +E322 message.txt /*E322* +E323 message.txt /*E323* +E324 print.txt /*E324* +E325 usr_11.txt /*E325* +E326 recover.txt /*E326* +E327 gui.txt /*E327* +E328 gui.txt /*E328* +E329 gui.txt /*E329* +E33 message.txt /*E33* +E330 gui.txt /*E330* +E331 gui.txt /*E331* +E332 gui.txt /*E332* +E333 gui.txt /*E333* +E334 gui.txt /*E334* +E335 gui.txt /*E335* +E336 gui.txt /*E336* +E337 gui.txt /*E337* +E338 editing.txt /*E338* +E339 message.txt /*E339* +E34 various.txt /*E34* +E340 vi_diff.txt /*E340* +E341 message.txt /*E341* +E342 message.txt /*E342* +E343 options.txt /*E343* +E344 options.txt /*E344* +E345 options.txt /*E345* +E346 options.txt /*E346* +E347 options.txt /*E347* +E348 pattern.txt /*E348* +E349 pattern.txt /*E349* +E35 message.txt /*E35* +E350 fold.txt /*E350* +E351 fold.txt /*E351* +E352 fold.txt /*E352* +E353 change.txt /*E353* +E354 change.txt /*E354* +E355 options.txt /*E355* +E356 message.txt /*E356* +E357 options.txt /*E357* +E358 options.txt /*E358* +E359 term.txt /*E359* +E36 windows.txt /*E36* +E360 various.txt /*E360* +E362 term.txt /*E362* +E363 options.txt /*E363* +E364 eval.txt /*E364* +E365 print.txt /*E365* +E366 options.txt /*E366* +E367 autocmd.txt /*E367* +E368 eval.txt /*E368* +E369 pattern.txt /*E369* +E37 message.txt /*E37* +E370 various.txt /*E370* +E371 various.txt /*E371* +E372 quickfix.txt /*E372* +E373 quickfix.txt /*E373* +E374 quickfix.txt /*E374* +E375 quickfix.txt /*E375* +E376 quickfix.txt /*E376* +E377 quickfix.txt /*E377* +E378 quickfix.txt /*E378* +E379 quickfix.txt /*E379* +E38 message.txt /*E38* +E380 quickfix.txt /*E380* +E381 quickfix.txt /*E381* +E382 options.txt /*E382* +E383 pattern.txt /*E383* +E384 options.txt /*E384* +E385 options.txt /*E385* +E386 pattern.txt /*E386* +E387 tagsrch.txt /*E387* +E388 tagsrch.txt /*E388* +E389 tagsrch.txt /*E389* +E39 digraph.txt /*E39* +E390 syntax.txt /*E390* +E391 syntax.txt /*E391* +E392 syntax.txt /*E392* +E393 syntax.txt /*E393* +E394 syntax.txt /*E394* +E395 syntax.txt /*E395* +E397 syntax.txt /*E397* +E398 syntax.txt /*E398* +E399 syntax.txt /*E399* +E40 message.txt /*E40* +E400 syntax.txt /*E400* +E401 syntax.txt /*E401* +E402 syntax.txt /*E402* +E403 syntax.txt /*E403* +E404 syntax.txt /*E404* +E405 syntax.txt /*E405* +E406 syntax.txt /*E406* +E407 syntax.txt /*E407* +E408 syntax.txt /*E408* +E409 syntax.txt /*E409* +E41 message.txt /*E41* +E410 syntax.txt /*E410* +E411 syntax.txt /*E411* +E412 syntax.txt /*E412* +E413 syntax.txt /*E413* +E414 syntax.txt /*E414* +E415 syntax.txt /*E415* +E416 syntax.txt /*E416* +E417 syntax.txt /*E417* +E418 syntax.txt /*E418* +E419 syntax.txt /*E419* +E42 quickfix.txt /*E42* +E420 syntax.txt /*E420* +E421 syntax.txt /*E421* +E422 syntax.txt /*E422* +E423 syntax.txt /*E423* +E424 message.txt /*E424* +E425 tagsrch.txt /*E425* +E426 tagsrch.txt /*E426* +E427 tagsrch.txt /*E427* +E428 tagsrch.txt /*E428* +E429 tagsrch.txt /*E429* +E43 message.txt /*E43* +E430 tagsrch.txt /*E430* +E431 tagsrch.txt /*E431* +E432 message.txt /*E432* +E433 options.txt /*E433* +E434 tagsrch.txt /*E434* +E435 tagsrch.txt /*E435* +E436 term.txt /*E436* +E437 term.txt /*E437* +E438 message.txt /*E438* +E439 message.txt /*E439* +E44 message.txt /*E44* +E440 message.txt /*E440* +E441 windows.txt /*E441* +E442 windows.txt /*E442* +E443 windows.txt /*E443* +E444 windows.txt /*E444* +E445 windows.txt /*E445* +E446 editing.txt /*E446* +E447 editing.txt /*E447* +E448 various.txt /*E448* +E449 eval.txt /*E449* +E45 message.txt /*E45* +E450 os_msdos.txt /*E450* +E451 os_msdos.txt /*E451* +E452 os_msdos.txt /*E452* +E453 os_msdos.txt /*E453* +E454 os_msdos.txt /*E454* +E455 print.txt /*E455* +E456 print.txt /*E456* +E457 print.txt /*E457* +E458 message.txt /*E458* +E459 message.txt /*E459* +E46 message.txt /*E46* +E460 message.txt /*E460* +E461 eval.txt /*E461* +E462 editing.txt /*E462* +E463 netbeans.txt /*E463* +E464 message.txt /*E464* +E465 gui.txt /*E465* +E466 gui.txt /*E466* +E467 map.txt /*E467* +E468 map.txt /*E468* +E469 if_cscop.txt /*E469* +E47 message.txt /*E47* +E470 change.txt /*E470* +E471 message.txt /*E471* +E472 editing.txt /*E472* +E473 message.txt /*E473* +E474 message.txt /*E474* +E475 message.txt /*E475* +E476 pattern.txt /*E476* +E477 message.txt /*E477* +E478 message.txt /*E478* +E479 editing.txt /*E479* +E48 eval.txt /*E48* +E480 editing.txt /*E480* +E481 message.txt /*E481* +E482 message.txt /*E482* +E483 message.txt /*E483* +E484 message.txt /*E484* +E485 message.txt /*E485* +E486 pattern.txt /*E486* +E487 options.txt /*E487* +E488 message.txt /*E488* +E489 intro.txt /*E489* +E49 message.txt /*E49* +E490 fold.txt /*E490* +E492 message.txt /*E492* +E493 cmdline.txt /*E493* +E494 editing.txt /*E494* +E495 cmdline.txt /*E495* +E496 cmdline.txt /*E496* +E497 cmdline.txt /*E497* +E498 cmdline.txt /*E498* +E499 cmdline.txt /*E499* +E50 syntax.txt /*E50* +E500 cmdline.txt /*E500* +E501 intro.txt /*E501* +E502 editing.txt /*E502* +E503 editing.txt /*E503* +E504 editing.txt /*E504* +E505 editing.txt /*E505* +E506 editing.txt /*E506* +E507 editing.txt /*E507* +E508 editing.txt /*E508* +E509 editing.txt /*E509* +E51 pattern.txt /*E51* +E510 editing.txt /*E510* +E511 netbeans.txt /*E511* +E512 editing.txt /*E512* +E513 options.txt /*E513* +E514 editing.txt /*E514* +E515 windows.txt /*E515* +E516 windows.txt /*E516* +E517 windows.txt /*E517* +E518 options.txt /*E518* +E519 options.txt /*E519* +E52 syntax.txt /*E52* +E520 options.txt /*E520* +E521 options.txt /*E521* +E522 options.txt /*E522* +E523 options.txt /*E523* +E524 options.txt /*E524* +E525 options.txt /*E525* +E526 options.txt /*E526* +E527 options.txt /*E527* +E528 options.txt /*E528* +E529 options.txt /*E529* +E53 pattern.txt /*E53* +E530 options.txt /*E530* +E531 options.txt /*E531* +E532 netbeans.txt /*E532* +E533 options.txt /*E533* +E534 options.txt /*E534* +E535 options.txt /*E535* +E536 options.txt /*E536* +E537 options.txt /*E537* +E538 options.txt /*E538* +E539 options.txt /*E539* +E54 pattern.txt /*E54* +E540 options.txt /*E540* +E541 options.txt /*E541* +E542 options.txt /*E542* +E543 options.txt /*E543* +E544 options.txt /*E544* +E545 options.txt /*E545* +E546 options.txt /*E546* +E547 options.txt /*E547* +E548 options.txt /*E548* +E549 options.txt /*E549* +E55 pattern.txt /*E55* +E550 options.txt /*E550* +E551 options.txt /*E551* +E552 options.txt /*E552* +E553 quickfix.txt /*E553* +E554 pattern.txt /*E554* +E555 tagsrch.txt /*E555* +E556 tagsrch.txt /*E556* +E557 term.txt /*E557* +E558 term.txt /*E558* +E559 term.txt /*E559* +E56 pattern.txt /*E56* +E560 if_cscop.txt /*E560* +E561 if_cscop.txt /*E561* +E562 if_cscop.txt /*E562* +E563 if_cscop.txt /*E563* +E564 if_cscop.txt /*E564* +E565 if_cscop.txt /*E565* +E566 if_cscop.txt /*E566* +E567 if_cscop.txt /*E567* +E568 if_cscop.txt /*E568* +E569 if_cscop.txt /*E569* +E57 pattern.txt /*E57* +E570 message.txt /*E570* +E571 if_tcl.txt /*E571* +E572 if_tcl.txt /*E572* +E573 remote.txt /*E573* +E574 starting.txt /*E574* +E575 starting.txt /*E575* +E576 starting.txt /*E576* +E577 starting.txt /*E577* +E578 editing.txt /*E578* +E579 eval.txt /*E579* +E58 pattern.txt /*E58* +E580 eval.txt /*E580* +E581 eval.txt /*E581* +E582 eval.txt /*E582* +E583 eval.txt /*E583* +E584 eval.txt /*E584* +E585 eval.txt /*E585* +E586 eval.txt /*E586* +E587 eval.txt /*E587* +E588 eval.txt /*E588* +E589 options.txt /*E589* +E59 pattern.txt /*E59* +E590 options.txt /*E590* +E591 options.txt /*E591* +E592 options.txt /*E592* +E593 options.txt /*E593* +E594 options.txt /*E594* +E595 options.txt /*E595* +E596 options.txt /*E596* +E597 options.txt /*E597* +E598 options.txt /*E598* +E599 options.txt /*E599* +E60 pattern.txt /*E60* +E600 eval.txt /*E600* +E601 eval.txt /*E601* +E602 eval.txt /*E602* +E603 eval.txt /*E603* +E604 eval.txt /*E604* +E605 eval.txt /*E605* +E606 eval.txt /*E606* +E607 eval.txt /*E607* +E608 eval.txt /*E608* +E609 if_cscop.txt /*E609* +E61 pattern.txt /*E61* +E610 options.txt /*E610* +E611 options.txt /*E611* +E612 sign.txt /*E612* +E613 print.txt /*E613* +E614 editing.txt /*E614* +E615 editing.txt /*E615* +E616 editing.txt /*E616* +E617 options.txt /*E617* +E618 print.txt /*E618* +E619 print.txt /*E619* +E62 pattern.txt /*E62* +E620 print.txt /*E620* +E621 print.txt /*E621* +E622 if_cscop.txt /*E622* +E623 if_cscop.txt /*E623* +E624 print.txt /*E624* +E625 if_cscop.txt /*E625* +E626 if_cscop.txt /*E626* +E627 netbeans.txt /*E627* +E628 netbeans.txt /*E628* +E629 netbeans.txt /*E629* +E63 pattern.txt /*E63* +E630 netbeans.txt /*E630* +E631 netbeans.txt /*E631* +E632 netbeans.txt /*E632* +E633 netbeans.txt /*E633* +E634 netbeans.txt /*E634* +E635 netbeans.txt /*E635* +E636 netbeans.txt /*E636* +E637 netbeans.txt /*E637* +E638 netbeans.txt /*E638* +E639 netbeans.txt /*E639* +E64 pattern.txt /*E64* +E640 netbeans.txt /*E640* +E641 netbeans.txt /*E641* +E642 netbeans.txt /*E642* +E643 netbeans.txt /*E643* +E644 netbeans.txt /*E644* +E645 netbeans.txt /*E645* +E646 netbeans.txt /*E646* +E647 netbeans.txt /*E647* +E648 netbeans.txt /*E648* +E649 netbeans.txt /*E649* +E65 pattern.txt /*E65* +E650 netbeans.txt /*E650* +E651 netbeans.txt /*E651* +E652 netbeans.txt /*E652* +E653 netbeans.txt /*E653* +E654 netbeans.txt /*E654* +E655 eval.txt /*E655* +E656 netbeans.txt /*E656* +E657 netbeans.txt /*E657* +E658 netbeans.txt /*E658* +E659 if_pyth.txt /*E659* +E66 syntax.txt /*E66* +E660 netbeans.txt /*E660* +E661 helphelp.txt /*E661* +E662 motion.txt /*E662* +E663 motion.txt /*E663* +E664 motion.txt /*E664* +E665 gui_x11.txt /*E665* +E666 quickfix.txt /*E666* +E667 editing.txt /*E667* +E668 netbeans.txt /*E668* +E669 syntax.txt /*E669* +E67 syntax.txt /*E67* +E670 helphelp.txt /*E670* +E671 starting.txt /*E671* +E672 starting.txt /*E672* +E673 print.txt /*E673* +E674 print.txt /*E674* +E675 print.txt /*E675* +E676 options.txt /*E676* +E677 eval.txt /*E677* +E678 pattern.txt /*E678* +E679 syntax.txt /*E679* +E68 pattern.txt /*E68* +E680 autocmd.txt /*E680* +E681 quickfix.txt /*E681* +E682 quickfix.txt /*E682* +E683 quickfix.txt /*E683* +E684 eval.txt /*E684* +E685 message.txt /*E685* +E686 eval.txt /*E686* +E687 eval.txt /*E687* +E688 eval.txt /*E688* +E689 eval.txt /*E689* +E69 pattern.txt /*E69* +E690 eval.txt /*E690* +E691 eval.txt /*E691* +E692 eval.txt /*E692* +E693 eval.txt /*E693* +E694 eval.txt /*E694* +E695 eval.txt /*E695* +E696 eval.txt /*E696* +E697 eval.txt /*E697* +E698 eval.txt /*E698* +E699 eval.txt /*E699* +E70 pattern.txt /*E70* +E700 eval.txt /*E700* +E701 eval.txt /*E701* +E702 eval.txt /*E702* +E703 eval.txt /*E703* +E704 eval.txt /*E704* +E705 eval.txt /*E705* +E706 eval.txt /*E706* +E707 eval.txt /*E707* +E708 eval.txt /*E708* +E709 eval.txt /*E709* +E71 pattern.txt /*E71* +E710 eval.txt /*E710* +E711 eval.txt /*E711* +E712 eval.txt /*E712* +E713 eval.txt /*E713* +E714 eval.txt /*E714* +E715 eval.txt /*E715* +E716 eval.txt /*E716* +E717 eval.txt /*E717* +E718 eval.txt /*E718* +E719 eval.txt /*E719* +E72 message.txt /*E72* +E720 eval.txt /*E720* +E721 eval.txt /*E721* +E722 eval.txt /*E722* +E723 eval.txt /*E723* +E724 eval.txt /*E724* +E725 eval.txt /*E725* +E726 eval.txt /*E726* +E727 eval.txt /*E727* +E728 eval.txt /*E728* +E729 eval.txt /*E729* +E73 tagsrch.txt /*E73* +E730 eval.txt /*E730* +E731 eval.txt /*E731* +E732 eval.txt /*E732* +E733 eval.txt /*E733* +E734 eval.txt /*E734* +E735 eval.txt /*E735* +E736 eval.txt /*E736* +E737 eval.txt /*E737* +E738 eval.txt /*E738* +E739 eval.txt /*E739* +E74 message.txt /*E74* +E740 eval.txt /*E740* +E741 eval.txt /*E741* +E742 eval.txt /*E742* +E743 eval.txt /*E743* +E744 netbeans.txt /*E744* +E745 eval.txt /*E745* +E746 eval.txt /*E746* +E747 editing.txt /*E747* +E748 repeat.txt /*E748* +E749 various.txt /*E749* +E75 vi_diff.txt /*E75* +E750 repeat.txt /*E750* +E751 spell.txt /*E751* +E752 spell.txt /*E752* +E753 spell.txt /*E753* +E754 spell.txt /*E754* +E755 spell.txt /*E755* +E756 spell.txt /*E756* +E757 options.txt /*E757* +E758 spell.txt /*E758* +E759 spell.txt /*E759* +E76 pattern.txt /*E76* +E760 spell.txt /*E760* +E761 spell.txt /*E761* +E762 spell.txt /*E762* +E763 spell.txt /*E763* +E764 options.txt /*E764* +E765 options.txt /*E765* +E766 eval.txt /*E766* +E767 eval.txt /*E767* +E768 message.txt /*E768* +E769 pattern.txt /*E769* +E77 message.txt /*E77* +E770 spell.txt /*E770* +E771 spell.txt /*E771* +E772 spell.txt /*E772* +E773 recover.txt /*E773* +E774 map.txt /*E774* +E775 map.txt /*E775* +E776 quickfix.txt /*E776* +E777 quickfix.txt /*E777* +E778 spell.txt /*E778* +E779 spell.txt /*E779* +E78 motion.txt /*E78* +E780 spell.txt /*E780* +E781 spell.txt /*E781* +E782 spell.txt /*E782* +E783 spell.txt /*E783* +E784 tabpage.txt /*E784* +E785 eval.txt /*E785* +E786 eval.txt /*E786* +E787 diff.txt /*E787* +E788 autocmd.txt /*E788* +E789 syntax.txt /*E789* +E79 message.txt /*E79* +E790 undo.txt /*E790* +E791 mbyte.txt /*E791* +E792 gui.txt /*E792* +E793 diff.txt /*E793* +E794 eval.txt /*E794* +E795 eval.txt /*E795* +E796 editing.txt /*E796* +E797 spell.txt /*E797* +E798 eval.txt /*E798* +E799 eval.txt /*E799* +E80 message.txt /*E80* +E800 arabic.txt /*E800* +E801 eval.txt /*E801* +E802 eval.txt /*E802* +E803 eval.txt /*E803* +E804 eval.txt /*E804* +E805 eval.txt /*E805* +E806 eval.txt /*E806* +E807 eval.txt /*E807* +E808 eval.txt /*E808* +E809 cmdline.txt /*E809* +E81 map.txt /*E81* +E810 diff.txt /*E810* +E811 autocmd.txt /*E811* +E812 autocmd.txt /*E812* +E813 editing.txt /*E813* +E814 editing.txt /*E814* +E815 if_mzsch.txt /*E815* +E816 diff.txt /*E816* +E817 editing.txt /*E817* +E818 editing.txt /*E818* +E819 editing.txt /*E819* +E82 message.txt /*E82* +E820 editing.txt /*E820* +E821 options.txt /*E821* +E822 undo.txt /*E822* +E823 undo.txt /*E823* +E824 undo.txt /*E824* +E825 undo.txt /*E825* +E826 undo.txt /*E826* +E827 undo.txt /*E827* +E828 undo.txt /*E828* +E829 undo.txt /*E829* +E83 message.txt /*E83* +E830 undo.txt /*E830* +E831 editing.txt /*E831* +E832 undo.txt /*E832* +E833 editing.txt /*E833* +E834 options.txt /*E834* +E835 options.txt /*E835* +E836 if_pyth.txt /*E836* +E837 if_pyth.txt /*E837* +E84 windows.txt /*E84* +E85 options.txt /*E85* +E86 windows.txt /*E86* +E87 windows.txt /*E87* +E88 windows.txt /*E88* +E89 message.txt /*E89* +E90 message.txt /*E90* +E91 options.txt /*E91* +E92 message.txt /*E92* +E93 windows.txt /*E93* +E94 windows.txt /*E94* +E95 message.txt /*E95* +E96 diff.txt /*E96* +E97 diff.txt /*E97* +E98 diff.txt /*E98* +E99 diff.txt /*E99* +EX intro.txt /*EX* +EXINIT starting.txt /*EXINIT* +Elvis intro.txt /*Elvis* +EncodingChanged autocmd.txt /*EncodingChanged* +Eterm syntax.txt /*Eterm* +Ex intro.txt /*Ex* +Ex-mode intro.txt /*Ex-mode* +Exuberant_ctags tagsrch.txt /*Exuberant_ctags* +F motion.txt /*F* +FAQ intro.txt /*FAQ* +Farsi farsi.txt /*Farsi* +FileAppendCmd autocmd.txt /*FileAppendCmd* +FileAppendPost autocmd.txt /*FileAppendPost* +FileAppendPre autocmd.txt /*FileAppendPre* +FileChangedRO autocmd.txt /*FileChangedRO* +FileChangedShell autocmd.txt /*FileChangedShell* +FileChangedShellPost autocmd.txt /*FileChangedShellPost* +FileEncoding autocmd.txt /*FileEncoding* +FileReadCmd autocmd.txt /*FileReadCmd* +FileReadPost autocmd.txt /*FileReadPost* +FileReadPre autocmd.txt /*FileReadPre* +FileType autocmd.txt /*FileType* +FileWriteCmd autocmd.txt /*FileWriteCmd* +FileWritePost autocmd.txt /*FileWritePost* +FileWritePre autocmd.txt /*FileWritePre* +FilterReadPost autocmd.txt /*FilterReadPost* +FilterReadPre autocmd.txt /*FilterReadPre* +FilterWritePost autocmd.txt /*FilterWritePost* +FilterWritePre autocmd.txt /*FilterWritePre* +Float eval.txt /*Float* +FocusGained autocmd.txt /*FocusGained* +FocusLost autocmd.txt /*FocusLost* +Folding fold.txt /*Folding* +FuncUndefined autocmd.txt /*FuncUndefined* +Funcref eval.txt /*Funcref* +G motion.txt /*G* +GNOME gui_x11.txt /*GNOME* +GTK gui_x11.txt /*GTK* +GTK+ gui_x11.txt /*GTK+* +GUI gui.txt /*GUI* +GUI-X11 gui_x11.txt /*GUI-X11* +GUIEnter autocmd.txt /*GUIEnter* +GUIFailed autocmd.txt /*GUIFailed* +GetLatestVimScripts pi_getscript.txt /*GetLatestVimScripts* +GetLatestVimScripts-copyright pi_getscript.txt /*GetLatestVimScripts-copyright* +GetLatestVimScripts_dat pi_getscript.txt /*GetLatestVimScripts_dat* +Gnome gui_x11.txt /*Gnome* +H motion.txt /*H* +I insert.txt /*I* +ICCF uganda.txt /*ICCF* +IM-server mbyte.txt /*IM-server* +IME mbyte.txt /*IME* +Insert insert.txt /*Insert* +Insert-mode insert.txt /*Insert-mode* +InsertChange autocmd.txt /*InsertChange* +InsertEnter autocmd.txt /*InsertEnter* +InsertLeave autocmd.txt /*InsertLeave* +J change.txt /*J* +Japanese mbyte.txt /*Japanese* +K various.txt /*K* +KDE gui_x11.txt /*KDE* +KVim gui_x11.txt /*KVim* +Kibaale uganda.txt /*Kibaale* +Korean mbyte.txt /*Korean* +L motion.txt /*L* +Linux-backspace options.txt /*Linux-backspace* +List eval.txt /*List* +Lists eval.txt /*Lists* +Lua if_lua.txt /*Lua* +M motion.txt /*M* +MDI starting.txt /*MDI* +MS-DOS os_msdos.txt /*MS-DOS* +MS-Windows os_win32.txt /*MS-Windows* +MSDOS os_msdos.txt /*MSDOS* +MSVisualStudio if_ole.txt /*MSVisualStudio* +MVS os_390.txt /*MVS* +Mac os_mac.txt /*Mac* +Mac-format editing.txt /*Mac-format* +Mac-format-write editing.txt /*Mac-format-write* +Macintosh os_mac.txt /*Macintosh* +Mark motion.txt /*Mark* +MenuPopup autocmd.txt /*MenuPopup* +MiNT os_mint.txt /*MiNT* +Moolenaar intro.txt /*Moolenaar* +MorphOS os_amiga.txt /*MorphOS* +Motif gui_x11.txt /*Motif* +Myspell spell.txt /*Myspell* +MzScheme if_mzsch.txt /*MzScheme* +N pattern.txt /*N* +N% motion.txt /*N%* +N: cmdline.txt /*N:* +N<Del> various.txt /*N<Del>* +NL-used-for-Nul pattern.txt /*NL-used-for-Nul* +NetBSD-backspace options.txt /*NetBSD-backspace* +NetUserPass() pi_netrw.txt /*NetUserPass()* +Normal intro.txt /*Normal* +Normal-mode intro.txt /*Normal-mode* +Number eval.txt /*Number* +Nvi intro.txt /*Nvi* +O insert.txt /*O* +OS/2 os_os2.txt /*OS\/2* +OS2 os_os2.txt /*OS2* +OS390 os_390.txt /*OS390* +OS390-Motif os_390.txt /*OS390-Motif* +OS390-PuTTY os_390.txt /*OS390-PuTTY* +OS390-bugs os_390.txt /*OS390-bugs* +OS390-has-ebcdic os_390.txt /*OS390-has-ebcdic* +OS390-limitations os_390.txt /*OS390-limitations* +OS390-open-source os_390.txt /*OS390-open-source* +OffTheSpot mbyte.txt /*OffTheSpot* +OnTheSpot mbyte.txt /*OnTheSpot* +Operator-pending intro.txt /*Operator-pending* +Operator-pending-mode intro.txt /*Operator-pending-mode* +OverTheSpot mbyte.txt /*OverTheSpot* +P change.txt /*P* +PATHEXT eval.txt /*PATHEXT* +Pattern pattern.txt /*Pattern* +Perl if_perl.txt /*Perl* +Posix intro.txt /*Posix* +Python if_pyth.txt /*Python* +Q intro.txt /*Q* +Q-command-changed version5.txt /*Q-command-changed* +QNX os_qnx.txt /*QNX* +Q_ab quickref.txt /*Q_ab* +Q_ac quickref.txt /*Q_ac* +Q_ai quickref.txt /*Q_ai* +Q_bu quickref.txt /*Q_bu* +Q_ce quickref.txt /*Q_ce* +Q_ch quickref.txt /*Q_ch* +Q_cm quickref.txt /*Q_cm* +Q_co quickref.txt /*Q_co* +Q_ct help.txt /*Q_ct* +Q_de quickref.txt /*Q_de* +Q_di quickref.txt /*Q_di* +Q_ed quickref.txt /*Q_ed* +Q_et quickref.txt /*Q_et* +Q_ex quickref.txt /*Q_ex* +Q_fl quickref.txt /*Q_fl* +Q_fo quickref.txt /*Q_fo* +Q_gu quickref.txt /*Q_gu* +Q_in quickref.txt /*Q_in* +Q_km quickref.txt /*Q_km* +Q_lr quickref.txt /*Q_lr* +Q_ma quickref.txt /*Q_ma* +Q_op quickref.txt /*Q_op* +Q_pa quickref.txt /*Q_pa* +Q_qf quickref.txt /*Q_qf* +Q_ra quickref.txt /*Q_ra* +Q_re quickref.txt /*Q_re* +Q_sc quickref.txt /*Q_sc* +Q_si quickref.txt /*Q_si* +Q_ss quickref.txt /*Q_ss* +Q_st quickref.txt /*Q_st* +Q_sy quickref.txt /*Q_sy* +Q_ta quickref.txt /*Q_ta* +Q_tm quickref.txt /*Q_tm* +Q_to quickref.txt /*Q_to* +Q_ud quickref.txt /*Q_ud* +Q_ur quickref.txt /*Q_ur* +Q_vc quickref.txt /*Q_vc* +Q_vi quickref.txt /*Q_vi* +Q_vm quickref.txt /*Q_vm* +Q_wi quickref.txt /*Q_wi* +Q_wq quickref.txt /*Q_wq* +QuickFixCmdPost autocmd.txt /*QuickFixCmdPost* +QuickFixCmdPost-example quickfix.txt /*QuickFixCmdPost-example* +QuickFixCmdPre autocmd.txt /*QuickFixCmdPre* +Quickfix quickfix.txt /*Quickfix* +R change.txt /*R* +RISC-OS os_risc.txt /*RISC-OS* +RISCOS os_risc.txt /*RISCOS* +RemoteReply autocmd.txt /*RemoteReply* +Replace insert.txt /*Replace* +Replace-mode insert.txt /*Replace-mode* +Root mbyte.txt /*Root* +Ruby if_ruby.txt /*Ruby* +Russian russian.txt /*Russian* +S change.txt /*S* +SHELL starting.txt /*SHELL* +SQLGetType ft_sql.txt /*SQLGetType* +SQLSetType ft_sql.txt /*SQLSetType* +Select visual.txt /*Select* +Select-mode visual.txt /*Select-mode* +Select-mode-mapping visual.txt /*Select-mode-mapping* +Session starting.txt /*Session* +SessionLoad-variable starting.txt /*SessionLoad-variable* +SessionLoadPost autocmd.txt /*SessionLoadPost* +ShellCmdPost autocmd.txt /*ShellCmdPost* +ShellFilterPost autocmd.txt /*ShellFilterPost* +SourceCmd autocmd.txt /*SourceCmd* +SourcePre autocmd.txt /*SourcePre* +SpellFileMissing autocmd.txt /*SpellFileMissing* +StdinReadPost autocmd.txt /*StdinReadPost* +StdinReadPre autocmd.txt /*StdinReadPre* +SwapExists autocmd.txt /*SwapExists* +Syntax autocmd.txt /*Syntax* +T motion.txt /*T* +TCL if_tcl.txt /*TCL* +TERM starting.txt /*TERM* +TSQL ft_sql.txt /*TSQL* +TTpro-telnet syntax.txt /*TTpro-telnet* +Tab intro.txt /*Tab* +TabEnter autocmd.txt /*TabEnter* +TabLeave autocmd.txt /*TabLeave* +Tcl if_tcl.txt /*Tcl* +TermChanged autocmd.txt /*TermChanged* +TermResponse autocmd.txt /*TermResponse* +Transact-SQL ft_sql.txt /*Transact-SQL* +U undo.txt /*U* +UTF-8 mbyte.txt /*UTF-8* +UTF8-xterm mbyte.txt /*UTF8-xterm* +Uganda uganda.txt /*Uganda* +Unicode mbyte.txt /*Unicode* +Unix os_unix.txt /*Unix* +Unix-format editing.txt /*Unix-format* +Unix-format-write editing.txt /*Unix-format-write* +User autocmd.txt /*User* +UserGettingBored autocmd.txt /*UserGettingBored* +V visual.txt /*V* +VIMINIT starting.txt /*VIMINIT* +VMS os_vms.txt /*VMS* +Vi intro.txt /*Vi* +View starting.txt /*View* +VimEnter autocmd.txt /*VimEnter* +VimLeave autocmd.txt /*VimLeave* +VimLeavePre autocmd.txt /*VimLeavePre* +VimResized autocmd.txt /*VimResized* +Vimball-copyright pi_vimball.txt /*Vimball-copyright* +Virtual-Replace-mode insert.txt /*Virtual-Replace-mode* +VisVim if_ole.txt /*VisVim* +Visual visual.txt /*Visual* +Visual-mode visual.txt /*Visual-mode* +W motion.txt /*W* +W10 message.txt /*W10* +W11 message.txt /*W11* +W12 message.txt /*W12* +W13 message.txt /*W13* +W14 message.txt /*W14* +W15 repeat.txt /*W15* +W16 message.txt /*W16* +W17 arabic.txt /*W17* +W18 syntax.txt /*W18* +WORD motion.txt /*WORD* +WWW intro.txt /*WWW* +Win32 os_win32.txt /*Win32* +WinEnter autocmd.txt /*WinEnter* +WinLeave autocmd.txt /*WinLeave* +X change.txt /*X* +X11 options.txt /*X11* +X11-icon gui_x11.txt /*X11-icon* +X11_mouse_shapes gui_x11.txt /*X11_mouse_shapes* +X1Drag term.txt /*X1Drag* +X1Mouse term.txt /*X1Mouse* +X1Release term.txt /*X1Release* +X2Drag term.txt /*X2Drag* +X2Mouse term.txt /*X2Mouse* +X2Release term.txt /*X2Release* +XIM mbyte.txt /*XIM* +XLFD mbyte.txt /*XLFD* +Y change.txt /*Y* +Y2K intro.txt /*Y2K* +ZQ editing.txt /*ZQ* +ZZ editing.txt /*ZZ* +[ index.txt /*[* +[# motion.txt /*[#* +[' motion.txt /*['* +[( motion.txt /*[(* +[++opt] editing.txt /*[++opt]* +[+cmd] editing.txt /*[+cmd]* +[..] pattern.txt /*[..]* +[/ motion.txt /*[\/* +[:alnum:] pattern.txt /*[:alnum:]* +[:alpha:] pattern.txt /*[:alpha:]* +[:backspace:] pattern.txt /*[:backspace:]* +[:blank:] pattern.txt /*[:blank:]* +[:cntrl:] pattern.txt /*[:cntrl:]* +[:digit:] pattern.txt /*[:digit:]* +[:escape:] pattern.txt /*[:escape:]* +[:graph:] pattern.txt /*[:graph:]* +[:lower:] pattern.txt /*[:lower:]* +[:print:] pattern.txt /*[:print:]* +[:punct:] pattern.txt /*[:punct:]* +[:return:] pattern.txt /*[:return:]* +[:space:] pattern.txt /*[:space:]* +[:tab:] pattern.txt /*[:tab:]* +[:upper:] pattern.txt /*[:upper:]* +[:xdigit:] pattern.txt /*[:xdigit:]* +[<MiddleMouse> change.txt /*[<MiddleMouse>* +[==] pattern.txt /*[==]* +[D tagsrch.txt /*[D* +[I tagsrch.txt /*[I* +[M motion.txt /*[M* +[P change.txt /*[P* +[S spell.txt /*[S* +[[ motion.txt /*[[* +[] motion.txt /*[]* +[_CTRL-D tagsrch.txt /*[_CTRL-D* +[_CTRL-I tagsrch.txt /*[_CTRL-I* +[` motion.txt /*[`* +[c diff.txt /*[c* +[count] intro.txt /*[count]* +[d tagsrch.txt /*[d* +[f editing.txt /*[f* +[i tagsrch.txt /*[i* +[m motion.txt /*[m* +[p change.txt /*[p* +[pattern] pattern.txt /*[pattern]* +[quotex] intro.txt /*[quotex]* +[range] cmdline.txt /*[range]* +[s spell.txt /*[s* +[star motion.txt /*[star* +[z fold.txt /*[z* +[{ motion.txt /*[{* +\0 change.txt /*\\0* +] index.txt /*]* +]# motion.txt /*]#* +]' motion.txt /*]'* +]) motion.txt /*])* +]/ motion.txt /*]\/* +]<MiddleMouse> change.txt /*]<MiddleMouse>* +]D tagsrch.txt /*]D* +]I tagsrch.txt /*]I* +]M motion.txt /*]M* +]P change.txt /*]P* +]S spell.txt /*]S* +][ motion.txt /*][* +]] motion.txt /*]]* +]_CTRL-D tagsrch.txt /*]_CTRL-D* +]_CTRL-I tagsrch.txt /*]_CTRL-I* +]` motion.txt /*]`* +]c diff.txt /*]c* +]d tagsrch.txt /*]d* +]f editing.txt /*]f* +]i tagsrch.txt /*]i* +]m motion.txt /*]m* +]p change.txt /*]p* +]s spell.txt /*]s* +]star motion.txt /*]star* +]z fold.txt /*]z* +]} motion.txt /*]}* +^ motion.txt /*^* +_ motion.txt /*_* +_exrc starting.txt /*_exrc* +_gvimrc gui.txt /*_gvimrc* +_vimrc starting.txt /*_vimrc* +` motion.txt /*`* +`( motion.txt /*`(* +`) motion.txt /*`)* +`-expansion editing.txt /*`-expansion* +`. motion.txt /*`.* +`0 motion.txt /*`0* +`< motion.txt /*`<* +`= editing.txt /*`=* +`> motion.txt /*`>* +`A motion.txt /*`A* +`[ motion.txt /*`[* +`] motion.txt /*`]* +`^ motion.txt /*`^* +`` motion.txt /*``* +`a motion.txt /*`a* +`quote motion.txt /*`quote* +`{ motion.txt /*`{* +`} motion.txt /*`}* +a insert.txt /*a* +a' motion.txt /*a'* +a( motion.txt /*a(* +a) motion.txt /*a)* +a4 print.txt /*a4* +a:0 eval.txt /*a:0* +a:000 eval.txt /*a:000* +a:1 eval.txt /*a:1* +a:firstline eval.txt /*a:firstline* +a:lastline eval.txt /*a:lastline* +a:var eval.txt /*a:var* +a< motion.txt /*a<* +a> motion.txt /*a>* +aB motion.txt /*aB* +aW motion.txt /*aW* +a[ motion.txt /*a[* +a] motion.txt /*a]* +a` motion.txt /*a`* +ab motion.txt /*ab* +abandon editing.txt /*abandon* +abbreviations map.txt /*abbreviations* +abel.vim syntax.txt /*abel.vim* +abs() eval.txt /*abs()* +acos() eval.txt /*acos()* +active-buffer windows.txt /*active-buffer* +ada#Create_Tags() ft_ada.txt /*ada#Create_Tags()* +ada#Jump_Tag() ft_ada.txt /*ada#Jump_Tag()* +ada#Listtags() ft_ada.txt /*ada#Listtags()* +ada#Switch_Syntax_Option() ft_ada.txt /*ada#Switch_Syntax_Option()* +ada#Word() ft_ada.txt /*ada#Word()* +ada-compiler ft_ada.txt /*ada-compiler* +ada-ctags ft_ada.txt /*ada-ctags* +ada-extra-plugins ft_ada.txt /*ada-extra-plugins* +ada-reference ft_ada.txt /*ada-reference* +ada.vim ft_ada.txt /*ada.vim* +add() eval.txt /*add()* +add-filetype-plugin usr_05.txt /*add-filetype-plugin* +add-global-plugin usr_05.txt /*add-global-plugin* +add-local-help usr_05.txt /*add-local-help* +add-option-flags options.txt /*add-option-flags* +add-plugin usr_05.txt /*add-plugin* +added-5.1 version5.txt /*added-5.1* +added-5.2 version5.txt /*added-5.2* +added-5.3 version5.txt /*added-5.3* +added-5.4 version5.txt /*added-5.4* +added-5.5 version5.txt /*added-5.5* +added-5.6 version5.txt /*added-5.6* +added-5.7 version5.txt /*added-5.7* +added-5.8 version5.txt /*added-5.8* +added-6.1 version6.txt /*added-6.1* +added-6.2 version6.txt /*added-6.2* +added-6.3 version6.txt /*added-6.3* +added-6.4 version6.txt /*added-6.4* +added-7.1 version7.txt /*added-7.1* +added-7.2 version7.txt /*added-7.2* +added-7.3 version7.txt /*added-7.3* +added-BeOS version5.txt /*added-BeOS* +added-Mac version5.txt /*added-Mac* +added-VMS version5.txt /*added-VMS* +added-cmdline-args version5.txt /*added-cmdline-args* +added-options version5.txt /*added-options* +added-regexp version5.txt /*added-regexp* +added-various version5.txt /*added-various* +added-win32-GUI version5.txt /*added-win32-GUI* +aff-dic-format spell.txt /*aff-dic-format* +after-directory options.txt /*after-directory* +aleph options.txt /*aleph* +alt intro.txt /*alt* +alt-input debugger.txt /*alt-input* +alternate-file editing.txt /*alternate-file* +amiga-window starting.txt /*amiga-window* +anonymous-function eval.txt /*anonymous-function* +ant.vim syntax.txt /*ant.vim* +ap motion.txt /*ap* +apache.vim syntax.txt /*apache.vim* +append() eval.txt /*append()* +aquote motion.txt /*aquote* +arabic.txt arabic.txt /*arabic.txt* +arabicfonts arabic.txt /*arabicfonts* +arabickeymap arabic.txt /*arabickeymap* +arg-functions usr_41.txt /*arg-functions* +argc() eval.txt /*argc()* +argidx() eval.txt /*argidx()* +arglist editing.txt /*arglist* +arglist-position editing.txt /*arglist-position* +arglist-quit usr_07.txt /*arglist-quit* +argument-list editing.txt /*argument-list* +argv() eval.txt /*argv()* +as motion.txt /*as* +asin() eval.txt /*asin()* +asm.vim syntax.txt /*asm.vim* +asm68k syntax.txt /*asm68k* +asmh8300.vim syntax.txt /*asmh8300.vim* +at motion.txt /*at* +atan() eval.txt /*atan()* +atan2() eval.txt /*atan2()* +athena-intellimouse gui.txt /*athena-intellimouse* +attr-list syntax.txt /*attr-list* +author intro.txt /*author* +auto-format change.txt /*auto-format* +auto-setting options.txt /*auto-setting* +auto-shortname editing.txt /*auto-shortname* +autocmd-<> tips.txt /*autocmd-<>* +autocmd-buffer-local autocmd.txt /*autocmd-buffer-local* +autocmd-buflocal autocmd.txt /*autocmd-buflocal* +autocmd-changes autocmd.txt /*autocmd-changes* +autocmd-define autocmd.txt /*autocmd-define* +autocmd-disable autocmd.txt /*autocmd-disable* +autocmd-events autocmd.txt /*autocmd-events* +autocmd-events-abc autocmd.txt /*autocmd-events-abc* +autocmd-execute autocmd.txt /*autocmd-execute* +autocmd-groups autocmd.txt /*autocmd-groups* +autocmd-intro autocmd.txt /*autocmd-intro* +autocmd-list autocmd.txt /*autocmd-list* +autocmd-nested autocmd.txt /*autocmd-nested* +autocmd-osfiletypes filetype.txt /*autocmd-osfiletypes* +autocmd-patterns autocmd.txt /*autocmd-patterns* +autocmd-remove autocmd.txt /*autocmd-remove* +autocmd-searchpat autocmd.txt /*autocmd-searchpat* +autocmd-use autocmd.txt /*autocmd-use* +autocmd.txt autocmd.txt /*autocmd.txt* +autocmds-kept version5.txt /*autocmds-kept* +autocommand autocmd.txt /*autocommand* +autocommand-events autocmd.txt /*autocommand-events* +autocommand-pattern autocmd.txt /*autocommand-pattern* +autoload eval.txt /*autoload* +autoload-functions eval.txt /*autoload-functions* +avoid-hit-enter version5.txt /*avoid-hit-enter* +aw motion.txt /*aw* +a{ motion.txt /*a{* +a} motion.txt /*a}* +b motion.txt /*b* +b:changedtick-variable eval.txt /*b:changedtick-variable* +b:changelog_name filetype.txt /*b:changelog_name* +b:current_syntax-variable syntax.txt /*b:current_syntax-variable* +b:netrw_lastfile pi_netrw.txt /*b:netrw_lastfile* +b:var eval.txt /*b:var* +baan-folding syntax.txt /*baan-folding* +baan-syntax syntax.txt /*baan-syntax* +baan.vim syntax.txt /*baan.vim* +backslash intro.txt /*backslash* +backspace intro.txt /*backspace* +backspace-delete version4.txt /*backspace-delete* +backtick-expansion editing.txt /*backtick-expansion* +backup editing.txt /*backup* +backup-changed version4.txt /*backup-changed* +backup-extension version4.txt /*backup-extension* +backup-table editing.txt /*backup-table* +balloon-eval debugger.txt /*balloon-eval* +bar motion.txt /*bar* +bars help.txt /*bars* +base_font_name_list mbyte.txt /*base_font_name_list* +basic.vim syntax.txt /*basic.vim* +beep options.txt /*beep* +beos-colors os_beos.txt /*beos-colors* +beos-compiling os_beos.txt /*beos-compiling* +beos-dragndrop os_beos.txt /*beos-dragndrop* +beos-fonts os_beos.txt /*beos-fonts* +beos-general os_beos.txt /*beos-general* +beos-gui os_beos.txt /*beos-gui* +beos-launch os_beos.txt /*beos-launch* +beos-meta os_beos.txt /*beos-meta* +beos-mouse os_beos.txt /*beos-mouse* +beos-perl os_beos.txt /*beos-perl* +beos-timeout os_beos.txt /*beos-timeout* +beos-unicode os_beos.txt /*beos-unicode* +beos-utf8 os_beos.txt /*beos-utf8* +beos-vimdir os_beos.txt /*beos-vimdir* +beval_bufnr-variable eval.txt /*beval_bufnr-variable* +beval_col-variable eval.txt /*beval_col-variable* +beval_lnum-variable eval.txt /*beval_lnum-variable* +beval_text-variable eval.txt /*beval_text-variable* +beval_winnr-variable eval.txt /*beval_winnr-variable* +blockwise-examples visual.txt /*blockwise-examples* +blockwise-operators visual.txt /*blockwise-operators* +blockwise-register change.txt /*blockwise-register* +blockwise-visual visual.txt /*blockwise-visual* +blowfish options.txt /*blowfish* +bold syntax.txt /*bold* +bom-bytes mbyte.txt /*bom-bytes* +book intro.txt /*book* +bookmark usr_03.txt /*bookmark* +boolean options.txt /*boolean* +break-finally eval.txt /*break-finally* +browse() eval.txt /*browse()* +browsedir() eval.txt /*browsedir()* +browsefilter editing.txt /*browsefilter* +bufexists() eval.txt /*bufexists()* +buffer-functions usr_41.txt /*buffer-functions* +buffer-hidden windows.txt /*buffer-hidden* +buffer-list windows.txt /*buffer-list* +buffer-variable eval.txt /*buffer-variable* +buffer-write editing.txt /*buffer-write* +buffer_exists() eval.txt /*buffer_exists()* +buffer_name() eval.txt /*buffer_name()* +buffer_number() eval.txt /*buffer_number()* +buffers windows.txt /*buffers* +buffers-menu gui.txt /*buffers-menu* +buflisted() eval.txt /*buflisted()* +bufloaded() eval.txt /*bufloaded()* +bufname() eval.txt /*bufname()* +bufnr() eval.txt /*bufnr()* +bufwinnr() eval.txt /*bufwinnr()* +bug-fixes-5 version5.txt /*bug-fixes-5* +bug-fixes-6 version6.txt /*bug-fixes-6* +bug-fixes-7 version7.txt /*bug-fixes-7* +bug-reports intro.txt /*bug-reports* +bugreport.vim intro.txt /*bugreport.vim* +bugs intro.txt /*bugs* +builtin-terms term.txt /*builtin-terms* +builtin-tools gui.txt /*builtin-tools* +builtin_terms term.txt /*builtin_terms* +byte-count editing.txt /*byte-count* +byte2line() eval.txt /*byte2line()* +byteidx() eval.txt /*byteidx()* +bzip2 pi_gzip.txt /*bzip2* +c change.txt /*c* +c.vim syntax.txt /*c.vim* +cW change.txt /*cW* +c_# cmdline.txt /*c_#* +c_## cmdline.txt /*c_##* +c_#< cmdline.txt /*c_#<* +c_#n cmdline.txt /*c_#n* +c_% cmdline.txt /*c_%* +c_<BS> cmdline.txt /*c_<BS>* +c_<C-Left> cmdline.txt /*c_<C-Left>* +c_<C-R> cmdline.txt /*c_<C-R>* +c_<C-R>_<C-A> cmdline.txt /*c_<C-R>_<C-A>* +c_<C-R>_<C-F> cmdline.txt /*c_<C-R>_<C-F>* +c_<C-R>_<C-O> cmdline.txt /*c_<C-R>_<C-O>* +c_<C-R>_<C-P> cmdline.txt /*c_<C-R>_<C-P>* +c_<C-R>_<C-R> cmdline.txt /*c_<C-R>_<C-R>* +c_<C-R>_<C-W> cmdline.txt /*c_<C-R>_<C-W>* +c_<C-Right> cmdline.txt /*c_<C-Right>* +c_<CR> cmdline.txt /*c_<CR>* +c_<Del> cmdline.txt /*c_<Del>* +c_<Down> cmdline.txt /*c_<Down>* +c_<End> cmdline.txt /*c_<End>* +c_<Esc> cmdline.txt /*c_<Esc>* +c_<Home> cmdline.txt /*c_<Home>* +c_<Insert> cmdline.txt /*c_<Insert>* +c_<Left> cmdline.txt /*c_<Left>* +c_<LeftMouse> cmdline.txt /*c_<LeftMouse>* +c_<NL> cmdline.txt /*c_<NL>* +c_<PageDown> cmdline.txt /*c_<PageDown>* +c_<PageUp> cmdline.txt /*c_<PageUp>* +c_<Right> cmdline.txt /*c_<Right>* +c_<S-Down> cmdline.txt /*c_<S-Down>* +c_<S-Left> cmdline.txt /*c_<S-Left>* +c_<S-Right> cmdline.txt /*c_<S-Right>* +c_<S-Tab> cmdline.txt /*c_<S-Tab>* +c_<S-Up> cmdline.txt /*c_<S-Up>* +c_<Tab> cmdline.txt /*c_<Tab>* +c_<Up> cmdline.txt /*c_<Up>* +c_CTRL-A cmdline.txt /*c_CTRL-A* +c_CTRL-B cmdline.txt /*c_CTRL-B* +c_CTRL-C cmdline.txt /*c_CTRL-C* +c_CTRL-D cmdline.txt /*c_CTRL-D* +c_CTRL-E cmdline.txt /*c_CTRL-E* +c_CTRL-F cmdline.txt /*c_CTRL-F* +c_CTRL-H cmdline.txt /*c_CTRL-H* +c_CTRL-I cmdline.txt /*c_CTRL-I* +c_CTRL-J cmdline.txt /*c_CTRL-J* +c_CTRL-K cmdline.txt /*c_CTRL-K* +c_CTRL-L cmdline.txt /*c_CTRL-L* +c_CTRL-N cmdline.txt /*c_CTRL-N* +c_CTRL-P cmdline.txt /*c_CTRL-P* +c_CTRL-Q cmdline.txt /*c_CTRL-Q* +c_CTRL-R cmdline.txt /*c_CTRL-R* +c_CTRL-R_= cmdline.txt /*c_CTRL-R_=* +c_CTRL-R_CTRL-A cmdline.txt /*c_CTRL-R_CTRL-A* +c_CTRL-R_CTRL-F cmdline.txt /*c_CTRL-R_CTRL-F* +c_CTRL-R_CTRL-O cmdline.txt /*c_CTRL-R_CTRL-O* +c_CTRL-R_CTRL-P cmdline.txt /*c_CTRL-R_CTRL-P* +c_CTRL-R_CTRL-R cmdline.txt /*c_CTRL-R_CTRL-R* +c_CTRL-R_CTRL-W cmdline.txt /*c_CTRL-R_CTRL-W* +c_CTRL-U cmdline.txt /*c_CTRL-U* +c_CTRL-V cmdline.txt /*c_CTRL-V* +c_CTRL-W cmdline.txt /*c_CTRL-W* +c_CTRL-Y cmdline.txt /*c_CTRL-Y* +c_CTRL-\_CTRL-G intro.txt /*c_CTRL-\\_CTRL-G* +c_CTRL-\_CTRL-N intro.txt /*c_CTRL-\\_CTRL-N* +c_CTRL-\_e cmdline.txt /*c_CTRL-\\_e* +c_CTRL-] cmdline.txt /*c_CTRL-]* +c_CTRL-^ cmdline.txt /*c_CTRL-^* +c_CTRL-_ cmdline.txt /*c_CTRL-_* +c_digraph cmdline.txt /*c_digraph* +c_wildchar cmdline.txt /*c_wildchar* +call() eval.txt /*call()* +carriage-return intro.txt /*carriage-return* +case change.txt /*case* +catch-all eval.txt /*catch-all* +catch-errors eval.txt /*catch-errors* +catch-interrupt eval.txt /*catch-interrupt* +catch-order eval.txt /*catch-order* +catch-text eval.txt /*catch-text* +cc change.txt /*cc* +ceil() eval.txt /*ceil()* +ch.vim syntax.txt /*ch.vim* +change-list-jumps motion.txt /*change-list-jumps* +change-name tips.txt /*change-name* +change-tabs change.txt /*change-tabs* +change.txt change.txt /*change.txt* +changed-5.1 version5.txt /*changed-5.1* +changed-5.2 version5.txt /*changed-5.2* +changed-5.3 version5.txt /*changed-5.3* +changed-5.4 version5.txt /*changed-5.4* +changed-5.5 version5.txt /*changed-5.5* +changed-5.6 version5.txt /*changed-5.6* +changed-5.7 version5.txt /*changed-5.7* +changed-5.8 version5.txt /*changed-5.8* +changed-6.1 version6.txt /*changed-6.1* +changed-6.2 version6.txt /*changed-6.2* +changed-6.3 version6.txt /*changed-6.3* +changed-6.4 version6.txt /*changed-6.4* +changed-7.1 version7.txt /*changed-7.1* +changed-7.2 version7.txt /*changed-7.2* +changed-7.3 version7.txt /*changed-7.3* +changelist motion.txt /*changelist* +changelog.vim syntax.txt /*changelog.vim* +changenr() eval.txt /*changenr()* +changetick eval.txt /*changetick* +changing change.txt /*changing* +char-variable eval.txt /*char-variable* +char2nr() eval.txt /*char2nr()* +characterwise motion.txt /*characterwise* +characterwise-register change.txt /*characterwise-register* +characterwise-visual visual.txt /*characterwise-visual* +charconvert_from-variable eval.txt /*charconvert_from-variable* +charconvert_to-variable eval.txt /*charconvert_to-variable* +charity uganda.txt /*charity* +charset mbyte.txt /*charset* +charset-conversion mbyte.txt /*charset-conversion* +chill.vim syntax.txt /*chill.vim* +cindent() eval.txt /*cindent()* +cinkeys-format indent.txt /*cinkeys-format* +cinoptions-values indent.txt /*cinoptions-values* +clear-undo undo.txt /*clear-undo* +clearmatches() eval.txt /*clearmatches()* +client-server remote.txt /*client-server* +clientserver remote.txt /*clientserver* +clipboard gui.txt /*clipboard* +cmdarg-variable eval.txt /*cmdarg-variable* +cmdbang-variable eval.txt /*cmdbang-variable* +cmdline-arguments vi_diff.txt /*cmdline-arguments* +cmdline-changed version5.txt /*cmdline-changed* +cmdline-completion cmdline.txt /*cmdline-completion* +cmdline-editing cmdline.txt /*cmdline-editing* +cmdline-history cmdline.txt /*cmdline-history* +cmdline-lines cmdline.txt /*cmdline-lines* +cmdline-ranges cmdline.txt /*cmdline-ranges* +cmdline-special cmdline.txt /*cmdline-special* +cmdline-too-long cmdline.txt /*cmdline-too-long* +cmdline-window cmdline.txt /*cmdline-window* +cmdline.txt cmdline.txt /*cmdline.txt* +cmdwin cmdline.txt /*cmdwin* +cmdwin-char cmdline.txt /*cmdwin-char* +cobol.vim syntax.txt /*cobol.vim* +codeset mbyte.txt /*codeset* +coding-style develop.txt /*coding-style* +col() eval.txt /*col()* +coldfusion.vim syntax.txt /*coldfusion.vim* +collapse tips.txt /*collapse* +color-xterm syntax.txt /*color-xterm* +coloring syntax.txt /*coloring* +colortest.vim syntax.txt /*colortest.vim* +command-line-functions usr_41.txt /*command-line-functions* +command-line-window cmdline.txt /*command-line-window* +command-mode intro.txt /*command-mode* +compatible-default starting.txt /*compatible-default* +compile-changes-5 version5.txt /*compile-changes-5* +compile-changes-6 version6.txt /*compile-changes-6* +compile-changes-7 version7.txt /*compile-changes-7* +compiler-compaqada ft_ada.txt /*compiler-compaqada* +compiler-decada ft_ada.txt /*compiler-decada* +compiler-gcc quickfix.txt /*compiler-gcc* +compiler-gnat ft_ada.txt /*compiler-gnat* +compiler-hpada ft_ada.txt /*compiler-hpada* +compiler-manx quickfix.txt /*compiler-manx* +compiler-perl quickfix.txt /*compiler-perl* +compiler-pyunit quickfix.txt /*compiler-pyunit* +compiler-select quickfix.txt /*compiler-select* +compiler-tex quickfix.txt /*compiler-tex* +compiler-vaxada ft_ada.txt /*compiler-vaxada* +compl-current insert.txt /*compl-current* +compl-define insert.txt /*compl-define* +compl-dictionary insert.txt /*compl-dictionary* +compl-filename insert.txt /*compl-filename* +compl-function insert.txt /*compl-function* +compl-generic insert.txt /*compl-generic* +compl-keyword insert.txt /*compl-keyword* +compl-omni insert.txt /*compl-omni* +compl-omni-filetypes insert.txt /*compl-omni-filetypes* +compl-spelling insert.txt /*compl-spelling* +compl-tag insert.txt /*compl-tag* +compl-vim insert.txt /*compl-vim* +compl-whole-line insert.txt /*compl-whole-line* +complete() eval.txt /*complete()* +complete-functions insert.txt /*complete-functions* +complete-items insert.txt /*complete-items* +complete_CTRL-E insert.txt /*complete_CTRL-E* +complete_CTRL-Y insert.txt /*complete_CTRL-Y* +complete_add() eval.txt /*complete_add()* +complete_check() eval.txt /*complete_check()* +completion-functions usr_41.txt /*completion-functions* +complex-change change.txt /*complex-change* +complex-repeat repeat.txt /*complex-repeat* +compress pi_gzip.txt /*compress* +conceal syntax.txt /*conceal* +confirm() eval.txt /*confirm()* +connection-refused message.txt /*connection-refused* +console-menus gui.txt /*console-menus* +control intro.txt /*control* +conversion-server mbyte.txt /*conversion-server* +convert-to-HTML syntax.txt /*convert-to-HTML* +convert-to-XHTML syntax.txt /*convert-to-XHTML* +convert-to-XML syntax.txt /*convert-to-XML* +copy() eval.txt /*copy()* +copy-diffs diff.txt /*copy-diffs* +copy-move change.txt /*copy-move* +copying uganda.txt /*copying* +copyright uganda.txt /*copyright* +cos() eval.txt /*cos()* +cosh() eval.txt /*cosh()* +count intro.txt /*count* +count() eval.txt /*count()* +count-bytes tips.txt /*count-bytes* +count-items tips.txt /*count-items* +count-variable eval.txt /*count-variable* +count1-variable eval.txt /*count1-variable* +cp-default version5.txt /*cp-default* +cpo-! options.txt /*cpo-!* +cpo-# options.txt /*cpo-#* +cpo-$ options.txt /*cpo-$* +cpo-% options.txt /*cpo-%* +cpo-& options.txt /*cpo-&* +cpo-+ options.txt /*cpo-+* +cpo-- options.txt /*cpo--* +cpo-. options.txt /*cpo-.* +cpo-/ options.txt /*cpo-\/* +cpo-< options.txt /*cpo-<* +cpo-> options.txt /*cpo->* +cpo-A options.txt /*cpo-A* +cpo-B options.txt /*cpo-B* +cpo-C options.txt /*cpo-C* +cpo-D options.txt /*cpo-D* +cpo-E options.txt /*cpo-E* +cpo-F options.txt /*cpo-F* +cpo-H options.txt /*cpo-H* +cpo-I options.txt /*cpo-I* +cpo-J options.txt /*cpo-J* +cpo-K options.txt /*cpo-K* +cpo-L options.txt /*cpo-L* +cpo-M options.txt /*cpo-M* +cpo-O options.txt /*cpo-O* +cpo-P options.txt /*cpo-P* +cpo-R options.txt /*cpo-R* +cpo-S options.txt /*cpo-S* +cpo-W options.txt /*cpo-W* +cpo-X options.txt /*cpo-X* +cpo-Z options.txt /*cpo-Z* +cpo-\ options.txt /*cpo-\\* +cpo-a options.txt /*cpo-a* +cpo-b options.txt /*cpo-b* +cpo-bar options.txt /*cpo-bar* +cpo-c options.txt /*cpo-c* +cpo-d options.txt /*cpo-d* +cpo-e options.txt /*cpo-e* +cpo-f options.txt /*cpo-f* +cpo-g options.txt /*cpo-g* +cpo-i options.txt /*cpo-i* +cpo-j options.txt /*cpo-j* +cpo-k options.txt /*cpo-k* +cpo-l options.txt /*cpo-l* +cpo-m options.txt /*cpo-m* +cpo-n options.txt /*cpo-n* +cpo-o options.txt /*cpo-o* +cpo-p options.txt /*cpo-p* +cpo-q options.txt /*cpo-q* +cpo-r options.txt /*cpo-r* +cpo-s options.txt /*cpo-s* +cpo-star options.txt /*cpo-star* +cpo-t options.txt /*cpo-t* +cpo-u options.txt /*cpo-u* +cpo-v options.txt /*cpo-v* +cpo-w options.txt /*cpo-w* +cpo-x options.txt /*cpo-x* +cpo-y options.txt /*cpo-y* +cpo-{ options.txt /*cpo-{* +crash-recovery recover.txt /*crash-recovery* +creating-menus gui.txt /*creating-menus* +credits intro.txt /*credits* +crontab options.txt /*crontab* +cs-find if_cscop.txt /*cs-find* +cs7-problem term.txt /*cs7-problem* +cscope if_cscop.txt /*cscope* +cscope-commands if_cscop.txt /*cscope-commands* +cscope-find if_cscop.txt /*cscope-find* +cscope-howtouse if_cscop.txt /*cscope-howtouse* +cscope-info if_cscop.txt /*cscope-info* +cscope-intro if_cscop.txt /*cscope-intro* +cscope-limitations if_cscop.txt /*cscope-limitations* +cscope-options if_cscop.txt /*cscope-options* +cscope-suggestions if_cscop.txt /*cscope-suggestions* +cscope-win32 if_cscop.txt /*cscope-win32* +cscope_connection() eval.txt /*cscope_connection()* +cscopepathcomp if_cscop.txt /*cscopepathcomp* +cscopeprg if_cscop.txt /*cscopeprg* +cscopequickfix if_cscop.txt /*cscopequickfix* +cscopetag if_cscop.txt /*cscopetag* +cscopetagorder if_cscop.txt /*cscopetagorder* +cscopeverbose if_cscop.txt /*cscopeverbose* +csh.vim syntax.txt /*csh.vim* +cspc if_cscop.txt /*cspc* +csprg if_cscop.txt /*csprg* +csqf if_cscop.txt /*csqf* +cst if_cscop.txt /*cst* +csto if_cscop.txt /*csto* +csverb if_cscop.txt /*csverb* +ctags tagsrch.txt /*ctags* +ctags-gone version6.txt /*ctags-gone* +cterm-colors syntax.txt /*cterm-colors* +ctrl intro.txt /*ctrl* +ctype-variable eval.txt /*ctype-variable* +curly-braces-function-names eval.txt /*curly-braces-function-names* +curly-braces-names eval.txt /*curly-braces-names* +curpos-visual version6.txt /*curpos-visual* +current-directory editing.txt /*current-directory* +current-file editing.txt /*current-file* +current_compiler quickfix.txt /*current_compiler* +cursor() eval.txt /*cursor()* +cursor-blinking options.txt /*cursor-blinking* +cursor-down intro.txt /*cursor-down* +cursor-functions usr_41.txt /*cursor-functions* +cursor-left intro.txt /*cursor-left* +cursor-motions motion.txt /*cursor-motions* +cursor-position pattern.txt /*cursor-position* +cursor-right intro.txt /*cursor-right* +cursor-up intro.txt /*cursor-up* +cursor_down intro.txt /*cursor_down* +cursor_left intro.txt /*cursor_left* +cursor_right intro.txt /*cursor_right* +cursor_up intro.txt /*cursor_up* +cw change.txt /*cw* +cweb.vim syntax.txt /*cweb.vim* +cynlib.vim syntax.txt /*cynlib.vim* +d change.txt /*d* +daB motion.txt /*daB* +daW motion.txt /*daW* +dab motion.txt /*dab* +dap motion.txt /*dap* +das motion.txt /*das* +date-functions usr_41.txt /*date-functions* +dav pi_netrw.txt /*dav* +davs pi_netrw.txt /*davs* +daw motion.txt /*daw* +dd change.txt /*dd* +debug-gcc debug.txt /*debug-gcc* +debug-highlight debugger.txt /*debug-highlight* +debug-leaks debug.txt /*debug-leaks* +debug-minidump debug.txt /*debug-minidump* +debug-mode repeat.txt /*debug-mode* +debug-scripts repeat.txt /*debug-scripts* +debug-signs debugger.txt /*debug-signs* +debug-vim debug.txt /*debug-vim* +debug-vs2005 debug.txt /*debug-vs2005* +debug-win32 debug.txt /*debug-win32* +debug-windbg debug.txt /*debug-windbg* +debug.txt debug.txt /*debug.txt* +debugger-compilation debugger.txt /*debugger-compilation* +debugger-features debugger.txt /*debugger-features* +debugger-integration debugger.txt /*debugger-integration* +debugger-support debugger.txt /*debugger-support* +debugger.txt debugger.txt /*debugger.txt* +dec-mouse options.txt /*dec-mouse* +decada_members ft_ada.txt /*decada_members* +deepcopy() eval.txt /*deepcopy()* +definition-search tagsrch.txt /*definition-search* +definitions intro.txt /*definitions* +delete() eval.txt /*delete()* +delete-insert change.txt /*delete-insert* +delete-menus gui.txt /*delete-menus* +deleting change.txt /*deleting* +design-assumptions develop.txt /*design-assumptions* +design-compatible develop.txt /*design-compatible* +design-decisions develop.txt /*design-decisions* +design-documented develop.txt /*design-documented* +design-flexible develop.txt /*design-flexible* +design-goals develop.txt /*design-goals* +design-improved develop.txt /*design-improved* +design-maintain develop.txt /*design-maintain* +design-multi-platform develop.txt /*design-multi-platform* +design-not develop.txt /*design-not* +design-speed-size develop.txt /*design-speed-size* +desktop.vim syntax.txt /*desktop.vim* +develop-spell develop.txt /*develop-spell* +develop-spell-suggestions develop.txt /*develop-spell-suggestions* +develop.txt develop.txt /*develop.txt* +development develop.txt /*development* +dh change.txt /*dh* +diB motion.txt /*diB* +diW motion.txt /*diW* +dialog gui_w32.txt /*dialog* +dialogs-added version5.txt /*dialogs-added* +dib motion.txt /*dib* +dict-functions usr_41.txt /*dict-functions* +dict-identity eval.txt /*dict-identity* +dict-modification eval.txt /*dict-modification* +did_filetype() eval.txt /*did_filetype()* +diff diff.txt /*diff* +diff-diffexpr diff.txt /*diff-diffexpr* +diff-mode diff.txt /*diff-mode* +diff-options diff.txt /*diff-options* +diff-original-file diff.txt /*diff-original-file* +diff-patchexpr diff.txt /*diff-patchexpr* +diff.txt diff.txt /*diff.txt* +diff_filler() eval.txt /*diff_filler()* +diff_hlID() eval.txt /*diff_hlID()* +digraph digraph.txt /*digraph* +digraph-arg change.txt /*digraph-arg* +digraph-encoding digraph.txt /*digraph-encoding* +digraph-table digraph.txt /*digraph-table* +digraph.txt digraph.txt /*digraph.txt* +digraphs digraph.txt /*digraphs* +digraphs-changed version6.txt /*digraphs-changed* +digraphs-default digraph.txt /*digraphs-default* +digraphs-define digraph.txt /*digraphs-define* +digraphs-use digraph.txt /*digraphs-use* +dip motion.txt /*dip* +dircolors.vim syntax.txt /*dircolors.vim* +dis motion.txt /*dis* +disable-menus gui.txt /*disable-menus* +distribute-script usr_41.txt /*distribute-script* +distribution intro.txt /*distribution* +diw motion.txt /*diw* +dl change.txt /*dl* +do diff.txt /*do* +doc-file-list help.txt /*doc-file-list* +docbk.vim syntax.txt /*docbk.vim* +docbksgml.vim syntax.txt /*docbksgml.vim* +docbkxml.vim syntax.txt /*docbkxml.vim* +docbook syntax.txt /*docbook* +documentation-6 version6.txt /*documentation-6* +donate uganda.txt /*donate* +dos os_dos.txt /*dos* +dos-:cd os_dos.txt /*dos-:cd* +dos-CTRL-Break os_dos.txt /*dos-CTRL-Break* +dos-backslash os_dos.txt /*dos-backslash* +dos-colors os_dos.txt /*dos-colors* +dos-file-formats os_dos.txt /*dos-file-formats* +dos-locations os_dos.txt /*dos-locations* +dos-shell os_dos.txt /*dos-shell* +dos-standard-mappings os_dos.txt /*dos-standard-mappings* +dos-temp-files os_dos.txt /*dos-temp-files* +dos16 os_msdos.txt /*dos16* +dos32 os_msdos.txt /*dos32* +dosbatch.vim syntax.txt /*dosbatch.vim* +double-click term.txt /*double-click* +download intro.txt /*download* +doxygen-syntax syntax.txt /*doxygen-syntax* +doxygen.vim syntax.txt /*doxygen.vim* +dp diff.txt /*dp* +drag-n-drop gui.txt /*drag-n-drop* +drag-n-drop-win32 gui_w32.txt /*drag-n-drop-win32* +drag-status-line term.txt /*drag-status-line* +dtd.vim syntax.txt /*dtd.vim* +dtd2vim insert.txt /*dtd2vim* +dying-variable eval.txt /*dying-variable* +e motion.txt /*e* +easy starting.txt /*easy* +edit-a-file editing.txt /*edit-a-file* +edit-binary editing.txt /*edit-binary* +edit-dialogs editing.txt /*edit-dialogs* +edit-files editing.txt /*edit-files* +edit-intro editing.txt /*edit-intro* +edit-no-break usr_25.txt /*edit-no-break* +editing.txt editing.txt /*editing.txt* +efm-%> quickfix.txt /*efm-%>* +efm-entries quickfix.txt /*efm-entries* +efm-ignore quickfix.txt /*efm-ignore* +eiffel.vim syntax.txt /*eiffel.vim* +emacs-keys tips.txt /*emacs-keys* +emacs-tags tagsrch.txt /*emacs-tags* +emacs_tags tagsrch.txt /*emacs_tags* +empty() eval.txt /*empty()* +encoding-names mbyte.txt /*encoding-names* +encoding-table mbyte.txt /*encoding-table* +encoding-values mbyte.txt /*encoding-values* +encryption editing.txt /*encryption* +end intro.txt /*end* +end-of-file pattern.txt /*end-of-file* +enlightened-terminal syntax.txt /*enlightened-terminal* +erlang.vim syntax.txt /*erlang.vim* +errmsg-variable eval.txt /*errmsg-variable* +error-file-format quickfix.txt /*error-file-format* +error-messages message.txt /*error-messages* +errorformat quickfix.txt /*errorformat* +errorformat-Jikes quickfix.txt /*errorformat-Jikes* +errorformat-LaTeX quickfix.txt /*errorformat-LaTeX* +errorformat-Perl quickfix.txt /*errorformat-Perl* +errorformat-ant quickfix.txt /*errorformat-ant* +errorformat-changed version4.txt /*errorformat-changed* +errorformat-jade quickfix.txt /*errorformat-jade* +errorformat-javac quickfix.txt /*errorformat-javac* +errorformat-multi-line quickfix.txt /*errorformat-multi-line* +errorformat-separate-filename quickfix.txt /*errorformat-separate-filename* +errorformats quickfix.txt /*errorformats* +errors message.txt /*errors* +escape intro.txt /*escape* +escape() eval.txt /*escape()* +escape-bar version4.txt /*escape-bar* +eval eval.txt /*eval* +eval() eval.txt /*eval()* +eval-examples eval.txt /*eval-examples* +eval-sandbox eval.txt /*eval-sandbox* +eval.txt eval.txt /*eval.txt* +eventhandler() eval.txt /*eventhandler()* +eview starting.txt /*eview* +evim starting.txt /*evim* +evim-keys starting.txt /*evim-keys* +evim.vim starting.txt /*evim.vim* +ex starting.txt /*ex* +ex-cmd-index index.txt /*ex-cmd-index* +ex-edit-index index.txt /*ex-edit-index* +ex-flags cmdline.txt /*ex-flags* +ex: options.txt /*ex:* +except-autocmd eval.txt /*except-autocmd* +except-autocmd-Cmd eval.txt /*except-autocmd-Cmd* +except-autocmd-Post eval.txt /*except-autocmd-Post* +except-autocmd-Pre eval.txt /*except-autocmd-Pre* +except-autocmd-ill eval.txt /*except-autocmd-ill* +except-compat eval.txt /*except-compat* +except-examine eval.txt /*except-examine* +except-from-finally eval.txt /*except-from-finally* +except-hier-param eval.txt /*except-hier-param* +except-several-errors eval.txt /*except-several-errors* +except-single-line eval.txt /*except-single-line* +except-syntax-err eval.txt /*except-syntax-err* +except-syntax-error eval.txt /*except-syntax-error* +exception-handling eval.txt /*exception-handling* +exception-variable eval.txt /*exception-variable* +exclusive motion.txt /*exclusive* +exclusive-linewise motion.txt /*exclusive-linewise* +executable() eval.txt /*executable()* +execute-menus gui.txt /*execute-menus* +exim starting.txt /*exim* +exists() eval.txt /*exists()* +exp() eval.txt /*exp()* +expand() eval.txt /*expand()* +expand-env options.txt /*expand-env* +expand-environment-var options.txt /*expand-environment-var* +expr eval.txt /*expr* +expr-! eval.txt /*expr-!* +expr-!= eval.txt /*expr-!=* +expr-!=# eval.txt /*expr-!=#* +expr-!=? eval.txt /*expr-!=?* +expr-!~ eval.txt /*expr-!~* +expr-!~# eval.txt /*expr-!~#* +expr-!~? eval.txt /*expr-!~?* +expr-% eval.txt /*expr-%* +expr-&& eval.txt /*expr-&&* +expr-' eval.txt /*expr-'* +expr-+ eval.txt /*expr-+* +expr-- eval.txt /*expr--* +expr-. eval.txt /*expr-.* +expr-/ eval.txt /*expr-\/* +expr-< eval.txt /*expr-<* +expr-<# eval.txt /*expr-<#* +expr-<= eval.txt /*expr-<=* +expr-<=# eval.txt /*expr-<=#* +expr-<=? eval.txt /*expr-<=?* +expr-<? eval.txt /*expr-<?* +expr-== eval.txt /*expr-==* +expr-==# eval.txt /*expr-==#* +expr-==? eval.txt /*expr-==?* +expr-=~ eval.txt /*expr-=~* +expr-=~# eval.txt /*expr-=~#* +expr-=~? eval.txt /*expr-=~?* +expr-> eval.txt /*expr->* +expr-># eval.txt /*expr->#* +expr->= eval.txt /*expr->=* +expr->=# eval.txt /*expr->=#* +expr->=? eval.txt /*expr->=?* +expr->? eval.txt /*expr->?* +expr-[:] eval.txt /*expr-[:]* +expr-[] eval.txt /*expr-[]* +expr-barbar eval.txt /*expr-barbar* +expr-entry eval.txt /*expr-entry* +expr-env eval.txt /*expr-env* +expr-env-expand eval.txt /*expr-env-expand* +expr-function eval.txt /*expr-function* +expr-is eval.txt /*expr-is* +expr-nesting eval.txt /*expr-nesting* +expr-number eval.txt /*expr-number* +expr-option eval.txt /*expr-option* +expr-quote eval.txt /*expr-quote* +expr-register eval.txt /*expr-register* +expr-star eval.txt /*expr-star* +expr-string eval.txt /*expr-string* +expr-unary-+ eval.txt /*expr-unary-+* +expr-unary-- eval.txt /*expr-unary--* +expr-variable eval.txt /*expr-variable* +expr1 eval.txt /*expr1* +expr2 eval.txt /*expr2* +expr3 eval.txt /*expr3* +expr4 eval.txt /*expr4* +expr5 eval.txt /*expr5* +expr6 eval.txt /*expr6* +expr7 eval.txt /*expr7* +expr8 eval.txt /*expr8* +expr9 eval.txt /*expr9* +expression eval.txt /*expression* +expression-commands eval.txt /*expression-commands* +expression-syntax eval.txt /*expression-syntax* +exrc starting.txt /*exrc* +extend() eval.txt /*extend()* +extension-removal cmdline.txt /*extension-removal* +extensions-improvements todo.txt /*extensions-improvements* +f motion.txt /*f* +faq intro.txt /*faq* +farsi farsi.txt /*farsi* +farsi.txt farsi.txt /*farsi.txt* +fasm.vim syntax.txt /*fasm.vim* +fcs_choice-variable eval.txt /*fcs_choice-variable* +fcs_reason-variable eval.txt /*fcs_reason-variable* +feature-list eval.txt /*feature-list* +feedkeys() eval.txt /*feedkeys()* +fetch pi_netrw.txt /*fetch* +file-browser-5.2 version5.txt /*file-browser-5.2* +file-formats editing.txt /*file-formats* +file-functions usr_41.txt /*file-functions* +file-pattern autocmd.txt /*file-pattern* +file-read insert.txt /*file-read* +file-searching editing.txt /*file-searching* +file-type filetype.txt /*file-type* +file-types filetype.txt /*file-types* +file_readable() eval.txt /*file_readable()* +fileencoding-changed version6.txt /*fileencoding-changed* +filename-backslash cmdline.txt /*filename-backslash* +filename-modifiers cmdline.txt /*filename-modifiers* +filereadable() eval.txt /*filereadable()* +filetype filetype.txt /*filetype* +filetype-detect filetype.txt /*filetype-detect* +filetype-ignore filetype.txt /*filetype-ignore* +filetype-overrule filetype.txt /*filetype-overrule* +filetype-plugin usr_43.txt /*filetype-plugin* +filetype-plugins filetype.txt /*filetype-plugins* +filetype.txt filetype.txt /*filetype.txt* +filetypedetect-changed version6.txt /*filetypedetect-changed* +filetypes filetype.txt /*filetypes* +filewritable() eval.txt /*filewritable()* +filter change.txt /*filter* +filter() eval.txt /*filter()* +find-manpage usr_12.txt /*find-manpage* +find-replace usr_10.txt /*find-replace* +finddir() eval.txt /*finddir()* +findfile() eval.txt /*findfile()* +fixed-5.1 version5.txt /*fixed-5.1* +fixed-5.2 version5.txt /*fixed-5.2* +fixed-5.3 version5.txt /*fixed-5.3* +fixed-5.4 version5.txt /*fixed-5.4* +fixed-5.5 version5.txt /*fixed-5.5* +fixed-5.6 version5.txt /*fixed-5.6* +fixed-5.7 version5.txt /*fixed-5.7* +fixed-5.8 version5.txt /*fixed-5.8* +fixed-6.1 version6.txt /*fixed-6.1* +fixed-6.2 version6.txt /*fixed-6.2* +fixed-6.3 version6.txt /*fixed-6.3* +fixed-6.4 version6.txt /*fixed-6.4* +fixed-7.1 version7.txt /*fixed-7.1* +fixed-7.2 version7.txt /*fixed-7.2* +fixed-7.3 version7.txt /*fixed-7.3* +flexwiki.vim syntax.txt /*flexwiki.vim* +float-e eval.txt /*float-e* +float-functions usr_41.txt /*float-functions* +float-pi eval.txt /*float-pi* +float2nr() eval.txt /*float2nr()* +floating-point-format eval.txt /*floating-point-format* +floating-point-precision eval.txt /*floating-point-precision* +floor() eval.txt /*floor()* +fmod() eval.txt /*fmod()* +fname_diff-variable eval.txt /*fname_diff-variable* +fname_in-variable eval.txt /*fname_in-variable* +fname_new-variable eval.txt /*fname_new-variable* +fname_out-variable eval.txt /*fname_out-variable* +fnameescape() eval.txt /*fnameescape()* +fnamemodify() eval.txt /*fnamemodify()* +fo-table change.txt /*fo-table* +fold-behavior fold.txt /*fold-behavior* +fold-colors fold.txt /*fold-colors* +fold-commands fold.txt /*fold-commands* +fold-create-marker fold.txt /*fold-create-marker* +fold-delete-marker fold.txt /*fold-delete-marker* +fold-diff fold.txt /*fold-diff* +fold-expr fold.txt /*fold-expr* +fold-foldcolumn fold.txt /*fold-foldcolumn* +fold-foldlevel fold.txt /*fold-foldlevel* +fold-foldtext fold.txt /*fold-foldtext* +fold-indent fold.txt /*fold-indent* +fold-manual fold.txt /*fold-manual* +fold-marker fold.txt /*fold-marker* +fold-methods fold.txt /*fold-methods* +fold-options fold.txt /*fold-options* +fold-syntax fold.txt /*fold-syntax* +fold.txt fold.txt /*fold.txt* +foldclosed() eval.txt /*foldclosed()* +foldclosedend() eval.txt /*foldclosedend()* +folddashes-variable eval.txt /*folddashes-variable* +foldend-variable eval.txt /*foldend-variable* +folding fold.txt /*folding* +folding-functions usr_41.txt /*folding-functions* +foldlevel() eval.txt /*foldlevel()* +foldlevel-variable eval.txt /*foldlevel-variable* +folds fold.txt /*folds* +foldstart-variable eval.txt /*foldstart-variable* +foldtext() eval.txt /*foldtext()* +foldtextresult() eval.txt /*foldtextresult()* +font-sizes gui_x11.txt /*font-sizes* +fontset mbyte.txt /*fontset* +foreground() eval.txt /*foreground()* +fork os_unix.txt /*fork* +form.vim syntax.txt /*form.vim* +format-bullet-list tips.txt /*format-bullet-list* +format-comments change.txt /*format-comments* +formatting change.txt /*formatting* +formfeed intro.txt /*formfeed* +fortran.vim syntax.txt /*fortran.vim* +frombook usr_01.txt /*frombook* +ft-abel-syntax syntax.txt /*ft-abel-syntax* +ft-ada-commands ft_ada.txt /*ft-ada-commands* +ft-ada-constants ft_ada.txt /*ft-ada-constants* +ft-ada-functions ft_ada.txt /*ft-ada-functions* +ft-ada-indent ft_ada.txt /*ft-ada-indent* +ft-ada-omni ft_ada.txt /*ft-ada-omni* +ft-ada-options ft_ada.txt /*ft-ada-options* +ft-ada-plugin ft_ada.txt /*ft-ada-plugin* +ft-ada-syntax ft_ada.txt /*ft-ada-syntax* +ft-ada-variables ft_ada.txt /*ft-ada-variables* +ft-ant-syntax syntax.txt /*ft-ant-syntax* +ft-apache-syntax syntax.txt /*ft-apache-syntax* +ft-asm-syntax syntax.txt /*ft-asm-syntax* +ft-asm68k-syntax syntax.txt /*ft-asm68k-syntax* +ft-asmh8300-syntax syntax.txt /*ft-asmh8300-syntax* +ft-aspperl-syntax syntax.txt /*ft-aspperl-syntax* +ft-aspvbs-syntax syntax.txt /*ft-aspvbs-syntax* +ft-bash-syntax syntax.txt /*ft-bash-syntax* +ft-basic-syntax syntax.txt /*ft-basic-syntax* +ft-c-omni insert.txt /*ft-c-omni* +ft-c-syntax syntax.txt /*ft-c-syntax* +ft-ch-syntax syntax.txt /*ft-ch-syntax* +ft-changelog-plugin filetype.txt /*ft-changelog-plugin* +ft-changelog-syntax syntax.txt /*ft-changelog-syntax* +ft-chill-syntax syntax.txt /*ft-chill-syntax* +ft-cobol-syntax syntax.txt /*ft-cobol-syntax* +ft-coldfusion-syntax syntax.txt /*ft-coldfusion-syntax* +ft-csh-syntax syntax.txt /*ft-csh-syntax* +ft-css-omni insert.txt /*ft-css-omni* +ft-cweb-syntax syntax.txt /*ft-cweb-syntax* +ft-cynlib-syntax syntax.txt /*ft-cynlib-syntax* +ft-desktop-syntax syntax.txt /*ft-desktop-syntax* +ft-dircolors-syntax syntax.txt /*ft-dircolors-syntax* +ft-docbk-syntax syntax.txt /*ft-docbk-syntax* +ft-docbksgml-syntax syntax.txt /*ft-docbksgml-syntax* +ft-docbkxml-syntax syntax.txt /*ft-docbkxml-syntax* +ft-dosbatch-syntax syntax.txt /*ft-dosbatch-syntax* +ft-dtd-syntax syntax.txt /*ft-dtd-syntax* +ft-eiffel-syntax syntax.txt /*ft-eiffel-syntax* +ft-erlang-syntax syntax.txt /*ft-erlang-syntax* +ft-flexwiki-syntax syntax.txt /*ft-flexwiki-syntax* +ft-form-syntax syntax.txt /*ft-form-syntax* +ft-fortran-indent indent.txt /*ft-fortran-indent* +ft-fortran-plugin filetype.txt /*ft-fortran-plugin* +ft-fortran-syntax syntax.txt /*ft-fortran-syntax* +ft-fvwm-syntax syntax.txt /*ft-fvwm-syntax* +ft-gitcommit-plugin filetype.txt /*ft-gitcommit-plugin* +ft-groff-syntax syntax.txt /*ft-groff-syntax* +ft-gsp-syntax syntax.txt /*ft-gsp-syntax* +ft-haskell-syntax syntax.txt /*ft-haskell-syntax* +ft-html-omni insert.txt /*ft-html-omni* +ft-html-syntax syntax.txt /*ft-html-syntax* +ft-htmlos-syntax syntax.txt /*ft-htmlos-syntax* +ft-ia64-syntax syntax.txt /*ft-ia64-syntax* +ft-inform-syntax syntax.txt /*ft-inform-syntax* +ft-java-syntax syntax.txt /*ft-java-syntax* +ft-javascript-omni insert.txt /*ft-javascript-omni* +ft-ksh-syntax syntax.txt /*ft-ksh-syntax* +ft-lace-syntax syntax.txt /*ft-lace-syntax* +ft-lex-syntax syntax.txt /*ft-lex-syntax* +ft-lifelines-syntax syntax.txt /*ft-lifelines-syntax* +ft-lisp-syntax syntax.txt /*ft-lisp-syntax* +ft-lite-syntax syntax.txt /*ft-lite-syntax* +ft-lpc-syntax syntax.txt /*ft-lpc-syntax* +ft-lua-syntax syntax.txt /*ft-lua-syntax* +ft-mail-plugin filetype.txt /*ft-mail-plugin* +ft-mail.vim syntax.txt /*ft-mail.vim* +ft-make-syntax syntax.txt /*ft-make-syntax* +ft-man-plugin filetype.txt /*ft-man-plugin* +ft-maple-syntax syntax.txt /*ft-maple-syntax* +ft-masm-syntax syntax.txt /*ft-masm-syntax* +ft-mathematica-syntax syntax.txt /*ft-mathematica-syntax* +ft-mma-syntax syntax.txt /*ft-mma-syntax* +ft-moo-syntax syntax.txt /*ft-moo-syntax* +ft-msql-syntax syntax.txt /*ft-msql-syntax* +ft-nasm-syntax syntax.txt /*ft-nasm-syntax* +ft-ncf-syntax syntax.txt /*ft-ncf-syntax* +ft-nroff-syntax syntax.txt /*ft-nroff-syntax* +ft-ocaml-syntax syntax.txt /*ft-ocaml-syntax* +ft-papp-syntax syntax.txt /*ft-papp-syntax* +ft-pascal-syntax syntax.txt /*ft-pascal-syntax* +ft-pdf-plugin filetype.txt /*ft-pdf-plugin* +ft-perl-syntax syntax.txt /*ft-perl-syntax* +ft-php-indent indent.txt /*ft-php-indent* +ft-php-omni insert.txt /*ft-php-omni* +ft-php-syntax syntax.txt /*ft-php-syntax* +ft-php3-syntax syntax.txt /*ft-php3-syntax* +ft-phtml-syntax syntax.txt /*ft-phtml-syntax* +ft-plaintex-syntax syntax.txt /*ft-plaintex-syntax* +ft-postscr-syntax syntax.txt /*ft-postscr-syntax* +ft-ppwiz-syntax syntax.txt /*ft-ppwiz-syntax* +ft-printcap-syntax syntax.txt /*ft-printcap-syntax* +ft-progress-syntax syntax.txt /*ft-progress-syntax* +ft-ptcap-syntax syntax.txt /*ft-ptcap-syntax* +ft-python-indent indent.txt /*ft-python-indent* +ft-python-syntax syntax.txt /*ft-python-syntax* +ft-quake-syntax syntax.txt /*ft-quake-syntax* +ft-readline-syntax syntax.txt /*ft-readline-syntax* +ft-rexx-syntax syntax.txt /*ft-rexx-syntax* +ft-ruby-omni insert.txt /*ft-ruby-omni* +ft-ruby-syntax syntax.txt /*ft-ruby-syntax* +ft-scheme-syntax syntax.txt /*ft-scheme-syntax* +ft-sdl-syntax syntax.txt /*ft-sdl-syntax* +ft-sed-syntax syntax.txt /*ft-sed-syntax* +ft-sgml-syntax syntax.txt /*ft-sgml-syntax* +ft-sh-indent indent.txt /*ft-sh-indent* +ft-sh-syntax syntax.txt /*ft-sh-syntax* +ft-spec-plugin filetype.txt /*ft-spec-plugin* +ft-spup-syntax syntax.txt /*ft-spup-syntax* +ft-sql filetype.txt /*ft-sql* +ft-sql-omni insert.txt /*ft-sql-omni* +ft-sql-syntax syntax.txt /*ft-sql-syntax* +ft-sqlanywhere-syntax syntax.txt /*ft-sqlanywhere-syntax* +ft-sqlinformix-syntax syntax.txt /*ft-sqlinformix-syntax* +ft-syntax-omni insert.txt /*ft-syntax-omni* +ft-tcsh-syntax syntax.txt /*ft-tcsh-syntax* +ft-termcap-syntax syntax.txt /*ft-termcap-syntax* +ft-tex-plugin filetype.txt /*ft-tex-plugin* +ft-tex-syntax syntax.txt /*ft-tex-syntax* +ft-tf-syntax syntax.txt /*ft-tf-syntax* +ft-vb-syntax syntax.txt /*ft-vb-syntax* +ft-verilog-indent indent.txt /*ft-verilog-indent* +ft-vhdl-indent indent.txt /*ft-vhdl-indent* +ft-vim-indent indent.txt /*ft-vim-indent* +ft-vim-syntax syntax.txt /*ft-vim-syntax* +ft-xf86conf-syntax syntax.txt /*ft-xf86conf-syntax* +ft-xhtml-omni insert.txt /*ft-xhtml-omni* +ft-xml-omni insert.txt /*ft-xml-omni* +ft-xml-syntax syntax.txt /*ft-xml-syntax* +ft-xpm-syntax syntax.txt /*ft-xpm-syntax* +ft_ada.txt ft_ada.txt /*ft_ada.txt* +ft_sql.txt ft_sql.txt /*ft_sql.txt* +ftdetect filetype.txt /*ftdetect* +ftp pi_netrw.txt /*ftp* +ftplugin usr_41.txt /*ftplugin* +ftplugin-docs filetype.txt /*ftplugin-docs* +ftplugin-name usr_05.txt /*ftplugin-name* +ftplugin-overrule filetype.txt /*ftplugin-overrule* +ftplugin-special usr_41.txt /*ftplugin-special* +ftplugins usr_05.txt /*ftplugins* +function() eval.txt /*function()* +function-argument eval.txt /*function-argument* +function-key intro.txt /*function-key* +function-list usr_41.txt /*function-list* +function-range-example eval.txt /*function-range-example* +function-search-undo eval.txt /*function-search-undo* +function_key intro.txt /*function_key* +functions eval.txt /*functions* +fvwm.vim syntax.txt /*fvwm.vim* +fvwm2rc syntax.txt /*fvwm2rc* +fvwmrc syntax.txt /*fvwmrc* +g index.txt /*g* +g# pattern.txt /*g#* +g$ motion.txt /*g$* +g& change.txt /*g&* +g' motion.txt /*g'* +g'a motion.txt /*g'a* +g+ undo.txt /*g+* +g, motion.txt /*g,* +g- undo.txt /*g-* +g0 motion.txt /*g0* +g8 various.txt /*g8* +g:NetrwTopLvlMenu pi_netrw.txt /*g:NetrwTopLvlMenu* +g:Netrw_funcref pi_netrw.txt /*g:Netrw_funcref* +g:ada#Comment ft_ada.txt /*g:ada#Comment* +g:ada#Ctags_Kinds ft_ada.txt /*g:ada#Ctags_Kinds* +g:ada#DotWordRegex ft_ada.txt /*g:ada#DotWordRegex* +g:ada#Keywords ft_ada.txt /*g:ada#Keywords* +g:ada#WordRegex ft_ada.txt /*g:ada#WordRegex* +g:ada_abbrev ft_ada.txt /*g:ada_abbrev* +g:ada_all_tab_usage ft_ada.txt /*g:ada_all_tab_usage* +g:ada_begin_preproc ft_ada.txt /*g:ada_begin_preproc* +g:ada_default_compiler ft_ada.txt /*g:ada_default_compiler* +g:ada_extended_completion ft_ada.txt /*g:ada_extended_completion* +g:ada_extended_tagging ft_ada.txt /*g:ada_extended_tagging* +g:ada_folding ft_ada.txt /*g:ada_folding* +g:ada_gnat_extensions ft_ada.txt /*g:ada_gnat_extensions* +g:ada_line_errors ft_ada.txt /*g:ada_line_errors* +g:ada_no_tab_space_error ft_ada.txt /*g:ada_no_tab_space_error* +g:ada_no_trail_space_error ft_ada.txt /*g:ada_no_trail_space_error* +g:ada_omni_with_keywords ft_ada.txt /*g:ada_omni_with_keywords* +g:ada_rainbow_color ft_ada.txt /*g:ada_rainbow_color* +g:ada_space_errors ft_ada.txt /*g:ada_space_errors* +g:ada_standard_types ft_ada.txt /*g:ada_standard_types* +g:ada_with_gnat_project_files ft_ada.txt /*g:ada_with_gnat_project_files* +g:ada_withuse_ordinary ft_ada.txt /*g:ada_withuse_ordinary* +g:colors_name options.txt /*g:colors_name* +g:decada ft_ada.txt /*g:decada* +g:decada.Error_Format ft_ada.txt /*g:decada.Error_Format* +g:decada.Make() ft_ada.txt /*g:decada.Make()* +g:decada.Make_Command ft_ada.txt /*g:decada.Make_Command* +g:decada.Unit_Name() ft_ada.txt /*g:decada.Unit_Name()* +g:gnat ft_ada.txt /*g:gnat* +g:gnat.Error_Format ft_ada.txt /*g:gnat.Error_Format* +g:gnat.Find() ft_ada.txt /*g:gnat.Find()* +g:gnat.Find_Program ft_ada.txt /*g:gnat.Find_Program* +g:gnat.Make() ft_ada.txt /*g:gnat.Make()* +g:gnat.Make_Command ft_ada.txt /*g:gnat.Make_Command* +g:gnat.Pretty() ft_ada.txt /*g:gnat.Pretty()* +g:gnat.Pretty_Program ft_ada.txt /*g:gnat.Pretty_Program* +g:gnat.Project_File ft_ada.txt /*g:gnat.Project_File* +g:gnat.Set_Project_File() ft_ada.txt /*g:gnat.Set_Project_File()* +g:gnat.Tags() ft_ada.txt /*g:gnat.Tags()* +g:gnat.Tags_Command ft_ada.txt /*g:gnat.Tags_Command* +g:netrw_alto pi_netrw.txt /*g:netrw_alto* +g:netrw_altv pi_netrw.txt /*g:netrw_altv* +g:netrw_banner pi_netrw.txt /*g:netrw_banner* +g:netrw_browse_split pi_netrw.txt /*g:netrw_browse_split* +g:netrw_browsex_viewer pi_netrw.txt /*g:netrw_browsex_viewer* +g:netrw_bufsettings pi_netrw.txt /*g:netrw_bufsettings* +g:netrw_chgperm pi_netrw.txt /*g:netrw_chgperm* +g:netrw_chgwin pi_netrw.txt /*g:netrw_chgwin* +g:netrw_compress pi_netrw.txt /*g:netrw_compress* +g:netrw_ctags pi_netrw.txt /*g:netrw_ctags* +g:netrw_cursorline pi_netrw.txt /*g:netrw_cursorline* +g:netrw_cygwin pi_netrw.txt /*g:netrw_cygwin* +g:netrw_dav_cmd pi_netrw.txt /*g:netrw_dav_cmd* +g:netrw_decompress pi_netrw.txt /*g:netrw_decompress* +g:netrw_fastbrowse pi_netrw.txt /*g:netrw_fastbrowse* +g:netrw_fetch_cmd pi_netrw.txt /*g:netrw_fetch_cmd* +g:netrw_fname_escape pi_netrw.txt /*g:netrw_fname_escape* +g:netrw_ftp pi_netrw.txt /*g:netrw_ftp* +g:netrw_ftp_browse_reject pi_netrw.txt /*g:netrw_ftp_browse_reject* +g:netrw_ftp_cmd pi_netrw.txt /*g:netrw_ftp_cmd* +g:netrw_ftp_list_cmd pi_netrw.txt /*g:netrw_ftp_list_cmd* +g:netrw_ftp_sizelist_cmd pi_netrw.txt /*g:netrw_ftp_sizelist_cmd* +g:netrw_ftp_timelist_cmd pi_netrw.txt /*g:netrw_ftp_timelist_cmd* +g:netrw_ftpextracmd pi_netrw.txt /*g:netrw_ftpextracmd* +g:netrw_ftpmode pi_netrw.txt /*g:netrw_ftpmode* +g:netrw_glob_escape pi_netrw.txt /*g:netrw_glob_escape* +g:netrw_hide pi_netrw.txt /*g:netrw_hide* +g:netrw_home pi_netrw.txt /*g:netrw_home* +g:netrw_http_cmd pi_netrw.txt /*g:netrw_http_cmd* +g:netrw_http_xcmd pi_netrw.txt /*g:netrw_http_xcmd* +g:netrw_ignorenetrc pi_netrw.txt /*g:netrw_ignorenetrc* +g:netrw_keepdir pi_netrw.txt /*g:netrw_keepdir* +g:netrw_list_cmd pi_netrw.txt /*g:netrw_list_cmd* +g:netrw_list_hide pi_netrw.txt /*g:netrw_list_hide* +g:netrw_liststyle pi_netrw.txt /*g:netrw_liststyle* +g:netrw_local_mkdir pi_netrw.txt /*g:netrw_local_mkdir* +g:netrw_local_rmdir pi_netrw.txt /*g:netrw_local_rmdir* +g:netrw_localcopycmd pi_netrw.txt /*g:netrw_localcopycmd* +g:netrw_localmovecmd pi_netrw.txt /*g:netrw_localmovecmd* +g:netrw_maxfilenamelen pi_netrw.txt /*g:netrw_maxfilenamelen* +g:netrw_menu pi_netrw.txt /*g:netrw_menu* +g:netrw_mkdir_cmd pi_netrw.txt /*g:netrw_mkdir_cmd* +g:netrw_mousemaps pi_netrw.txt /*g:netrw_mousemaps* +g:netrw_nogx pi_netrw.txt /*g:netrw_nogx* +g:netrw_preview pi_netrw.txt /*g:netrw_preview* +g:netrw_rcp_cmd pi_netrw.txt /*g:netrw_rcp_cmd* +g:netrw_retmap pi_netrw.txt /*g:netrw_retmap* +g:netrw_rm_cmd pi_netrw.txt /*g:netrw_rm_cmd* +g:netrw_rmdir_cmd pi_netrw.txt /*g:netrw_rmdir_cmd* +g:netrw_rmf_cmd pi_netrw.txt /*g:netrw_rmf_cmd* +g:netrw_rsync_cmd pi_netrw.txt /*g:netrw_rsync_cmd* +g:netrw_scp_cmd pi_netrw.txt /*g:netrw_scp_cmd* +g:netrw_scpport pi_netrw.txt /*g:netrw_scpport* +g:netrw_sepchr pi_netrw.txt /*g:netrw_sepchr* +g:netrw_sftp_cmd pi_netrw.txt /*g:netrw_sftp_cmd* +g:netrw_silent pi_netrw.txt /*g:netrw_silent* +g:netrw_sort_by pi_netrw.txt /*g:netrw_sort_by* +g:netrw_sort_direction pi_netrw.txt /*g:netrw_sort_direction* +g:netrw_sort_options pi_netrw.txt /*g:netrw_sort_options* +g:netrw_sort_sequence pi_netrw.txt /*g:netrw_sort_sequence* +g:netrw_special_syntax pi_netrw.txt /*g:netrw_special_syntax* +g:netrw_ssh_browse_reject pi_netrw.txt /*g:netrw_ssh_browse_reject* +g:netrw_ssh_cmd pi_netrw.txt /*g:netrw_ssh_cmd* +g:netrw_sshport pi_netrw.txt /*g:netrw_sshport* +g:netrw_timefmt pi_netrw.txt /*g:netrw_timefmt* +g:netrw_tmpfile_escape pi_netrw.txt /*g:netrw_tmpfile_escape* +g:netrw_uid pi_netrw.txt /*g:netrw_uid* +g:netrw_use_errorwindow pi_netrw.txt /*g:netrw_use_errorwindow* +g:netrw_use_noswf pi_netrw.txt /*g:netrw_use_noswf* +g:netrw_use_nt_rcp pi_netrw.txt /*g:netrw_use_nt_rcp* +g:netrw_win95ftp pi_netrw.txt /*g:netrw_win95ftp* +g:netrw_winsize pi_netrw.txt /*g:netrw_winsize* +g:netrw_xstrlen pi_netrw.txt /*g:netrw_xstrlen* +g:syntax_on syntax.txt /*g:syntax_on* +g:tar_browseoptions pi_tar.txt /*g:tar_browseoptions* +g:tar_cmd pi_tar.txt /*g:tar_cmd* +g:tar_copycmd pi_tar.txt /*g:tar_copycmd* +g:tar_extractcmd pi_tar.txt /*g:tar_extractcmd* +g:tar_nomax pi_tar.txt /*g:tar_nomax* +g:tar_readoptions pi_tar.txt /*g:tar_readoptions* +g:tar_secure pi_tar.txt /*g:tar_secure* +g:tar_writeoptions pi_tar.txt /*g:tar_writeoptions* +g:tex_conceal syntax.txt /*g:tex_conceal* +g:var eval.txt /*g:var* +g:vimball_home pi_vimball.txt /*g:vimball_home* +g:vimball_mkdir pi_vimball.txt /*g:vimball_mkdir* +g:vimsyn_embed syntax.txt /*g:vimsyn_embed* +g:vimsyn_folding syntax.txt /*g:vimsyn_folding* +g:vimsyn_maxlines syntax.txt /*g:vimsyn_maxlines* +g:vimsyn_minlines syntax.txt /*g:vimsyn_minlines* +g:vimsyn_noerror syntax.txt /*g:vimsyn_noerror* +g:zip_nomax pi_zip.txt /*g:zip_nomax* +g:zip_shq pi_zip.txt /*g:zip_shq* +g:zip_unzipcmd pi_zip.txt /*g:zip_unzipcmd* +g:zip_zipcmd pi_zip.txt /*g:zip_zipcmd* +g; motion.txt /*g;* +g< message.txt /*g<* +g<Down> motion.txt /*g<Down>* +g<End> motion.txt /*g<End>* +g<Home> motion.txt /*g<Home>* +g<LeftMouse> tagsrch.txt /*g<LeftMouse>* +g<RightMouse> tagsrch.txt /*g<RightMouse>* +g<Up> motion.txt /*g<Up>* +g? change.txt /*g?* +g?? change.txt /*g??* +g?g? change.txt /*g?g?* +g@ map.txt /*g@* +gD pattern.txt /*gD* +gE motion.txt /*gE* +gF editing.txt /*gF* +gH visual.txt /*gH* +gI insert.txt /*gI* +gJ change.txt /*gJ* +gP change.txt /*gP* +gQ intro.txt /*gQ* +gR change.txt /*gR* +gT tabpage.txt /*gT* +gU change.txt /*gU* +gUU change.txt /*gUU* +gUgU change.txt /*gUgU* +gV visual.txt /*gV* +g] tagsrch.txt /*g]* +g^ motion.txt /*g^* +g_ motion.txt /*g_* +g_CTRL-A various.txt /*g_CTRL-A* +g_CTRL-G editing.txt /*g_CTRL-G* +g_CTRL-H visual.txt /*g_CTRL-H* +g_CTRL-] tagsrch.txt /*g_CTRL-]* +g` motion.txt /*g`* +g`a motion.txt /*g`a* +ga various.txt /*ga* +garbagecollect() eval.txt /*garbagecollect()* +gd pattern.txt /*gd* +ge motion.txt /*ge* +get() eval.txt /*get()* +get-ms-debuggers debug.txt /*get-ms-debuggers* +getbufline() eval.txt /*getbufline()* +getbufvar() eval.txt /*getbufvar()* +getchar() eval.txt /*getchar()* +getcharmod() eval.txt /*getcharmod()* +getcmdline() eval.txt /*getcmdline()* +getcmdpos() eval.txt /*getcmdpos()* +getcmdtype() eval.txt /*getcmdtype()* +getcwd() eval.txt /*getcwd()* +getfontname() eval.txt /*getfontname()* +getfperm() eval.txt /*getfperm()* +getfsize() eval.txt /*getfsize()* +getftime() eval.txt /*getftime()* +getftype() eval.txt /*getftype()* +getlatestvimscripts-install pi_getscript.txt /*getlatestvimscripts-install* +getline() eval.txt /*getline()* +getloclist() eval.txt /*getloclist()* +getmatches() eval.txt /*getmatches()* +getpid() eval.txt /*getpid()* +getpos() eval.txt /*getpos()* +getqflist() eval.txt /*getqflist()* +getreg() eval.txt /*getreg()* +getregtype() eval.txt /*getregtype()* +getscript pi_getscript.txt /*getscript* +getscript-autoinstall pi_getscript.txt /*getscript-autoinstall* +getscript-data pi_getscript.txt /*getscript-data* +getscript-history pi_getscript.txt /*getscript-history* +getscript-plugins pi_getscript.txt /*getscript-plugins* +getscript-start pi_getscript.txt /*getscript-start* +gettabvar() eval.txt /*gettabvar()* +gettabwinvar() eval.txt /*gettabwinvar()* +getwinposx() eval.txt /*getwinposx()* +getwinposy() eval.txt /*getwinposy()* +getwinvar() eval.txt /*getwinvar()* +gex starting.txt /*gex* +gf editing.txt /*gf* +gg motion.txt /*gg* +gh visual.txt /*gh* +gi insert.txt /*gi* +gj motion.txt /*gj* +gk motion.txt /*gk* +glob() eval.txt /*glob()* +global-ime mbyte.txt /*global-ime* +global-local options.txt /*global-local* +global-variable eval.txt /*global-variable* +global_markfilelist pi_netrw.txt /*global_markfilelist* +globpath() eval.txt /*globpath()* +glvs pi_getscript.txt /*glvs* +glvs-alg pi_getscript.txt /*glvs-alg* +glvs-algorithm pi_getscript.txt /*glvs-algorithm* +glvs-autoinstall pi_getscript.txt /*glvs-autoinstall* +glvs-contents pi_getscript.txt /*glvs-contents* +glvs-copyright pi_getscript.txt /*glvs-copyright* +glvs-data pi_getscript.txt /*glvs-data* +glvs-dist-install pi_getscript.txt /*glvs-dist-install* +glvs-hist pi_getscript.txt /*glvs-hist* +glvs-install pi_getscript.txt /*glvs-install* +glvs-options pi_getscript.txt /*glvs-options* +glvs-plugins pi_getscript.txt /*glvs-plugins* +glvs-usage pi_getscript.txt /*glvs-usage* +gm motion.txt /*gm* +gnat#Insert_Tags_Header() ft_ada.txt /*gnat#Insert_Tags_Header()* +gnat#New() ft_ada.txt /*gnat#New()* +gnat-xref ft_ada.txt /*gnat-xref* +gnat_members ft_ada.txt /*gnat_members* +gnome-session gui_x11.txt /*gnome-session* +go motion.txt /*go* +gp change.txt /*gp* +gpm-mouse term.txt /*gpm-mouse* +gq change.txt /*gq* +gqap change.txt /*gqap* +gqgq change.txt /*gqgq* +gqq change.txt /*gqq* +gr change.txt /*gr* +graphic-option-gone version4.txt /*graphic-option-gone* +greek options.txt /*greek* +grep quickfix.txt /*grep* +groff.vim syntax.txt /*groff.vim* +group-name syntax.txt /*group-name* +gs various.txt /*gs* +gsp.vim syntax.txt /*gsp.vim* +gstar pattern.txt /*gstar* +gt tabpage.txt /*gt* +gtk-tooltip-colors gui_x11.txt /*gtk-tooltip-colors* +gu change.txt /*gu* +gugu change.txt /*gugu* +gui gui.txt /*gui* +gui-clipboard gui_w32.txt /*gui-clipboard* +gui-colors syntax.txt /*gui-colors* +gui-extras gui.txt /*gui-extras* +gui-footer debugger.txt /*gui-footer* +gui-fork gui_x11.txt /*gui-fork* +gui-functions usr_41.txt /*gui-functions* +gui-gnome gui_x11.txt /*gui-gnome* +gui-gnome-session gui_x11.txt /*gui-gnome-session* +gui-gtk gui_x11.txt /*gui-gtk* +gui-gtk-socketid gui_x11.txt /*gui-gtk-socketid* +gui-horiz-scroll gui.txt /*gui-horiz-scroll* +gui-init gui.txt /*gui-init* +gui-kde gui_x11.txt /*gui-kde* +gui-mouse gui.txt /*gui-mouse* +gui-mouse-focus gui.txt /*gui-mouse-focus* +gui-mouse-mapping gui.txt /*gui-mouse-mapping* +gui-mouse-modeless gui.txt /*gui-mouse-modeless* +gui-mouse-move gui.txt /*gui-mouse-move* +gui-mouse-select gui.txt /*gui-mouse-select* +gui-mouse-status gui.txt /*gui-mouse-status* +gui-mouse-various gui.txt /*gui-mouse-various* +gui-pty gui_x11.txt /*gui-pty* +gui-pty-erase gui_x11.txt /*gui-pty-erase* +gui-resources gui_x11.txt /*gui-resources* +gui-scrollbars gui.txt /*gui-scrollbars* +gui-selections gui.txt /*gui-selections* +gui-shell gui.txt /*gui-shell* +gui-shell-win32 gui_w32.txt /*gui-shell-win32* +gui-start gui.txt /*gui-start* +gui-toolbar gui.txt /*gui-toolbar* +gui-vert-scroll gui.txt /*gui-vert-scroll* +gui-w16 gui_w16.txt /*gui-w16* +gui-w32 gui_w32.txt /*gui-w32* +gui-w32-cmdargs gui_w32.txt /*gui-w32-cmdargs* +gui-w32-dialogs gui_w32.txt /*gui-w32-dialogs* +gui-w32-printing gui_w32.txt /*gui-w32-printing* +gui-w32-start gui_w32.txt /*gui-w32-start* +gui-w32-various gui_w32.txt /*gui-w32-various* +gui-w32-windowid gui_w32.txt /*gui-w32-windowid* +gui-w32s gui_w32.txt /*gui-w32s* +gui-win32-maximized gui_w32.txt /*gui-win32-maximized* +gui-x11 gui_x11.txt /*gui-x11* +gui-x11-athena gui_x11.txt /*gui-x11-athena* +gui-x11-compiling gui_x11.txt /*gui-x11-compiling* +gui-x11-gtk gui_x11.txt /*gui-x11-gtk* +gui-x11-kde gui_x11.txt /*gui-x11-kde* +gui-x11-misc gui_x11.txt /*gui-x11-misc* +gui-x11-motif gui_x11.txt /*gui-x11-motif* +gui-x11-neXtaw gui_x11.txt /*gui-x11-neXtaw* +gui-x11-printing gui_x11.txt /*gui-x11-printing* +gui-x11-start gui_x11.txt /*gui-x11-start* +gui-x11-various gui_x11.txt /*gui-x11-various* +gui.txt gui.txt /*gui.txt* +gui_w16.txt gui_w16.txt /*gui_w16.txt* +gui_w32.txt gui_w32.txt /*gui_w32.txt* +gui_x11.txt gui_x11.txt /*gui_x11.txt* +guifontwide_gtk2 options.txt /*guifontwide_gtk2* +guioptions_a options.txt /*guioptions_a* +guu change.txt /*guu* +gv visual.txt /*gv* +gview starting.txt /*gview* +gvim starting.txt /*gvim* +gvimdiff diff.txt /*gvimdiff* +gvimrc gui.txt /*gvimrc* +gw change.txt /*gw* +gwgw change.txt /*gwgw* +gww change.txt /*gww* +gzip pi_gzip.txt /*gzip* +gzip-autocmd pi_gzip.txt /*gzip-autocmd* +gzip-example autocmd.txt /*gzip-example* +gzip-helpfile tips.txt /*gzip-helpfile* +g~ change.txt /*g~* +g~g~ change.txt /*g~g~* +g~~ change.txt /*g~~* +h motion.txt /*h* +hangul hangulin.txt /*hangul* +hangulin.txt hangulin.txt /*hangulin.txt* +has() eval.txt /*has()* +has-patch eval.txt /*has-patch* +has_key() eval.txt /*has_key()* +haskell.vim syntax.txt /*haskell.vim* +haslocaldir() eval.txt /*haslocaldir()* +hasmapto() eval.txt /*hasmapto()* +hebrew hebrew.txt /*hebrew* +hebrew.txt hebrew.txt /*hebrew.txt* +help helphelp.txt /*help* +help-context help.txt /*help-context* +help-summary usr_02.txt /*help-summary* +help-tags tags 1 +help-translated helphelp.txt /*help-translated* +help-writing helphelp.txt /*help-writing* +help-xterm-window helphelp.txt /*help-xterm-window* +help.txt help.txt /*help.txt* +helpfile_name.txt helphelp.txt /*helpfile_name.txt* +helphelp helphelp.txt /*helphelp* +helphelp.txt helphelp.txt /*helphelp.txt* +hex-editing tips.txt /*hex-editing* +hidden-buffer windows.txt /*hidden-buffer* +hidden-changed version5.txt /*hidden-changed* +hidden-menus gui.txt /*hidden-menus* +hidden-options options.txt /*hidden-options* +hidden-quit windows.txt /*hidden-quit* +highlight-args syntax.txt /*highlight-args* +highlight-changed version4.txt /*highlight-changed* +highlight-cterm syntax.txt /*highlight-cterm* +highlight-ctermbg syntax.txt /*highlight-ctermbg* +highlight-ctermfg syntax.txt /*highlight-ctermfg* +highlight-default syntax.txt /*highlight-default* +highlight-font syntax.txt /*highlight-font* +highlight-groups syntax.txt /*highlight-groups* +highlight-gui syntax.txt /*highlight-gui* +highlight-guibg syntax.txt /*highlight-guibg* +highlight-guifg syntax.txt /*highlight-guifg* +highlight-guisp syntax.txt /*highlight-guisp* +highlight-start syntax.txt /*highlight-start* +highlight-stop syntax.txt /*highlight-stop* +highlight-term syntax.txt /*highlight-term* +highlightID() eval.txt /*highlightID()* +highlight_exists() eval.txt /*highlight_exists()* +highlighting-functions usr_41.txt /*highlighting-functions* +hist-names eval.txt /*hist-names* +histadd() eval.txt /*histadd()* +histdel() eval.txt /*histdel()* +histget() eval.txt /*histget()* +histnr() eval.txt /*histnr()* +history cmdline.txt /*history* +history-functions usr_41.txt /*history-functions* +hit-enter message.txt /*hit-enter* +hit-enter-prompt message.txt /*hit-enter-prompt* +hit-return message.txt /*hit-return* +hitest.vim syntax.txt /*hitest.vim* +hjkl usr_02.txt /*hjkl* +hl-ColorColumn syntax.txt /*hl-ColorColumn* +hl-Conceal syntax.txt /*hl-Conceal* +hl-Cursor syntax.txt /*hl-Cursor* +hl-CursorColumn syntax.txt /*hl-CursorColumn* +hl-CursorIM syntax.txt /*hl-CursorIM* +hl-CursorLine syntax.txt /*hl-CursorLine* +hl-DiffAdd syntax.txt /*hl-DiffAdd* +hl-DiffChange syntax.txt /*hl-DiffChange* +hl-DiffDelete syntax.txt /*hl-DiffDelete* +hl-DiffText syntax.txt /*hl-DiffText* +hl-Directory syntax.txt /*hl-Directory* +hl-ErrorMsg syntax.txt /*hl-ErrorMsg* +hl-FoldColumn syntax.txt /*hl-FoldColumn* +hl-Folded syntax.txt /*hl-Folded* +hl-Ignore syntax.txt /*hl-Ignore* +hl-IncSearch syntax.txt /*hl-IncSearch* +hl-LineNr syntax.txt /*hl-LineNr* +hl-MatchParen syntax.txt /*hl-MatchParen* +hl-Menu syntax.txt /*hl-Menu* +hl-ModeMsg syntax.txt /*hl-ModeMsg* +hl-MoreMsg syntax.txt /*hl-MoreMsg* +hl-NonText syntax.txt /*hl-NonText* +hl-Normal syntax.txt /*hl-Normal* +hl-Pmenu syntax.txt /*hl-Pmenu* +hl-PmenuSbar syntax.txt /*hl-PmenuSbar* +hl-PmenuSel syntax.txt /*hl-PmenuSel* +hl-PmenuThumb syntax.txt /*hl-PmenuThumb* +hl-Question syntax.txt /*hl-Question* +hl-Scrollbar syntax.txt /*hl-Scrollbar* +hl-Search syntax.txt /*hl-Search* +hl-SignColumn syntax.txt /*hl-SignColumn* +hl-SpecialKey syntax.txt /*hl-SpecialKey* +hl-SpellBad syntax.txt /*hl-SpellBad* +hl-SpellCap syntax.txt /*hl-SpellCap* +hl-SpellLocal syntax.txt /*hl-SpellLocal* +hl-SpellRare syntax.txt /*hl-SpellRare* +hl-StatusLine syntax.txt /*hl-StatusLine* +hl-StatusLineNC syntax.txt /*hl-StatusLineNC* +hl-TabLine syntax.txt /*hl-TabLine* +hl-TabLineFill syntax.txt /*hl-TabLineFill* +hl-TabLineSel syntax.txt /*hl-TabLineSel* +hl-Title syntax.txt /*hl-Title* +hl-Tooltip syntax.txt /*hl-Tooltip* +hl-User1 syntax.txt /*hl-User1* +hl-User1..9 syntax.txt /*hl-User1..9* +hl-User9 syntax.txt /*hl-User9* +hl-VertSplit syntax.txt /*hl-VertSplit* +hl-Visual syntax.txt /*hl-Visual* +hl-VisualNOS syntax.txt /*hl-VisualNOS* +hl-WarningMsg syntax.txt /*hl-WarningMsg* +hl-WildMenu syntax.txt /*hl-WildMenu* +hlID() eval.txt /*hlID()* +hlexists() eval.txt /*hlexists()* +holy-grail index.txt /*holy-grail* +home intro.txt /*home* +home-replace editing.txt /*home-replace* +hostname() eval.txt /*hostname()* +how-do-i howto.txt /*how-do-i* +how-to howto.txt /*how-to* +howdoi howto.txt /*howdoi* +howto howto.txt /*howto* +howto.txt howto.txt /*howto.txt* +hpterm term.txt /*hpterm* +hpterm-color syntax.txt /*hpterm-color* +html-flavor insert.txt /*html-flavor* +html.vim syntax.txt /*html.vim* +htmlos.vim syntax.txt /*htmlos.vim* +http pi_netrw.txt /*http* +i insert.txt /*i* +i' motion.txt /*i'* +i( motion.txt /*i(* +i) motion.txt /*i)* +i< motion.txt /*i<* +i> motion.txt /*i>* +iB motion.txt /*iB* +iW motion.txt /*iW* +i[ motion.txt /*i[* +i] motion.txt /*i]* +i_0_CTRL-D insert.txt /*i_0_CTRL-D* +i_<BS> insert.txt /*i_<BS>* +i_<C-End> insert.txt /*i_<C-End>* +i_<C-Home> insert.txt /*i_<C-Home>* +i_<C-Left> insert.txt /*i_<C-Left>* +i_<C-PageDown> tabpage.txt /*i_<C-PageDown>* +i_<C-PageUp> tabpage.txt /*i_<C-PageUp>* +i_<C-Right> insert.txt /*i_<C-Right>* +i_<CR> insert.txt /*i_<CR>* +i_<Del> insert.txt /*i_<Del>* +i_<Down> insert.txt /*i_<Down>* +i_<End> insert.txt /*i_<End>* +i_<Esc> insert.txt /*i_<Esc>* +i_<F1> helphelp.txt /*i_<F1>* +i_<Help> helphelp.txt /*i_<Help>* +i_<Home> insert.txt /*i_<Home>* +i_<Insert> insert.txt /*i_<Insert>* +i_<Left> insert.txt /*i_<Left>* +i_<LeftMouse> insert.txt /*i_<LeftMouse>* +i_<NL> insert.txt /*i_<NL>* +i_<PageDown> insert.txt /*i_<PageDown>* +i_<PageUp> insert.txt /*i_<PageUp>* +i_<Right> insert.txt /*i_<Right>* +i_<S-Down> insert.txt /*i_<S-Down>* +i_<S-Left> insert.txt /*i_<S-Left>* +i_<S-Right> insert.txt /*i_<S-Right>* +i_<S-ScrollWheelDown> insert.txt /*i_<S-ScrollWheelDown>* +i_<S-ScrollWheelLeft> insert.txt /*i_<S-ScrollWheelLeft>* +i_<S-ScrollWheelRight> insert.txt /*i_<S-ScrollWheelRight>* +i_<S-ScrollWheelUp> insert.txt /*i_<S-ScrollWheelUp>* +i_<S-Up> insert.txt /*i_<S-Up>* +i_<ScrollWheelDown> insert.txt /*i_<ScrollWheelDown>* +i_<ScrollWheelLeft> insert.txt /*i_<ScrollWheelLeft>* +i_<ScrollWheelRight> insert.txt /*i_<ScrollWheelRight>* +i_<ScrollWheelUp> insert.txt /*i_<ScrollWheelUp>* +i_<Tab> insert.txt /*i_<Tab>* +i_<Up> insert.txt /*i_<Up>* +i_BS insert.txt /*i_BS* +i_CTRL-<PageDown> tabpage.txt /*i_CTRL-<PageDown>* +i_CTRL-<PageUp> tabpage.txt /*i_CTRL-<PageUp>* +i_CTRL-@ insert.txt /*i_CTRL-@* +i_CTRL-A insert.txt /*i_CTRL-A* +i_CTRL-B-gone version5.txt /*i_CTRL-B-gone* +i_CTRL-C insert.txt /*i_CTRL-C* +i_CTRL-D insert.txt /*i_CTRL-D* +i_CTRL-E insert.txt /*i_CTRL-E* +i_CTRL-F indent.txt /*i_CTRL-F* +i_CTRL-G_<Down> insert.txt /*i_CTRL-G_<Down>* +i_CTRL-G_<Up> insert.txt /*i_CTRL-G_<Up>* +i_CTRL-G_CTRL-J insert.txt /*i_CTRL-G_CTRL-J* +i_CTRL-G_CTRL-K insert.txt /*i_CTRL-G_CTRL-K* +i_CTRL-G_j insert.txt /*i_CTRL-G_j* +i_CTRL-G_k insert.txt /*i_CTRL-G_k* +i_CTRL-G_u insert.txt /*i_CTRL-G_u* +i_CTRL-H insert.txt /*i_CTRL-H* +i_CTRL-I insert.txt /*i_CTRL-I* +i_CTRL-J insert.txt /*i_CTRL-J* +i_CTRL-K insert.txt /*i_CTRL-K* +i_CTRL-L insert.txt /*i_CTRL-L* +i_CTRL-M insert.txt /*i_CTRL-M* +i_CTRL-N insert.txt /*i_CTRL-N* +i_CTRL-O insert.txt /*i_CTRL-O* +i_CTRL-P insert.txt /*i_CTRL-P* +i_CTRL-Q insert.txt /*i_CTRL-Q* +i_CTRL-R insert.txt /*i_CTRL-R* +i_CTRL-R_= insert.txt /*i_CTRL-R_=* +i_CTRL-R_CTRL-O insert.txt /*i_CTRL-R_CTRL-O* +i_CTRL-R_CTRL-P insert.txt /*i_CTRL-R_CTRL-P* +i_CTRL-R_CTRL-R insert.txt /*i_CTRL-R_CTRL-R* +i_CTRL-T insert.txt /*i_CTRL-T* +i_CTRL-U insert.txt /*i_CTRL-U* +i_CTRL-V insert.txt /*i_CTRL-V* +i_CTRL-V_digit insert.txt /*i_CTRL-V_digit* +i_CTRL-W insert.txt /*i_CTRL-W* +i_CTRL-X insert.txt /*i_CTRL-X* +i_CTRL-X_CTRL-D insert.txt /*i_CTRL-X_CTRL-D* +i_CTRL-X_CTRL-E insert.txt /*i_CTRL-X_CTRL-E* +i_CTRL-X_CTRL-F insert.txt /*i_CTRL-X_CTRL-F* +i_CTRL-X_CTRL-I insert.txt /*i_CTRL-X_CTRL-I* +i_CTRL-X_CTRL-K insert.txt /*i_CTRL-X_CTRL-K* +i_CTRL-X_CTRL-L insert.txt /*i_CTRL-X_CTRL-L* +i_CTRL-X_CTRL-N insert.txt /*i_CTRL-X_CTRL-N* +i_CTRL-X_CTRL-O insert.txt /*i_CTRL-X_CTRL-O* +i_CTRL-X_CTRL-P insert.txt /*i_CTRL-X_CTRL-P* +i_CTRL-X_CTRL-S insert.txt /*i_CTRL-X_CTRL-S* +i_CTRL-X_CTRL-T insert.txt /*i_CTRL-X_CTRL-T* +i_CTRL-X_CTRL-U insert.txt /*i_CTRL-X_CTRL-U* +i_CTRL-X_CTRL-V insert.txt /*i_CTRL-X_CTRL-V* +i_CTRL-X_CTRL-Y insert.txt /*i_CTRL-X_CTRL-Y* +i_CTRL-X_CTRL-] insert.txt /*i_CTRL-X_CTRL-]* +i_CTRL-X_index index.txt /*i_CTRL-X_index* +i_CTRL-X_s insert.txt /*i_CTRL-X_s* +i_CTRL-Y insert.txt /*i_CTRL-Y* +i_CTRL-Z options.txt /*i_CTRL-Z* +i_CTRL-[ insert.txt /*i_CTRL-[* +i_CTRL-\_CTRL-G intro.txt /*i_CTRL-\\_CTRL-G* +i_CTRL-\_CTRL-N intro.txt /*i_CTRL-\\_CTRL-N* +i_CTRL-\_CTRL-O insert.txt /*i_CTRL-\\_CTRL-O* +i_CTRL-] insert.txt /*i_CTRL-]* +i_CTRL-^ insert.txt /*i_CTRL-^* +i_CTRL-_ insert.txt /*i_CTRL-_* +i_DEL insert.txt /*i_DEL* +i_Tab insert.txt /*i_Tab* +i_^_CTRL-D insert.txt /*i_^_CTRL-D* +i_backspacing insert.txt /*i_backspacing* +i_digraph digraph.txt /*i_digraph* +i_esc intro.txt /*i_esc* +i` motion.txt /*i`* +ia64.vim syntax.txt /*ia64.vim* +ib motion.txt /*ib* +iccf uganda.txt /*iccf* +iccf-donations uganda.txt /*iccf-donations* +icon-changed version4.txt /*icon-changed* +iconise starting.txt /*iconise* +iconize starting.txt /*iconize* +iconv() eval.txt /*iconv()* +iconv-dynamic mbyte.txt /*iconv-dynamic* +ident-search tips.txt /*ident-search* +idl-syntax syntax.txt /*idl-syntax* +idl.vim syntax.txt /*idl.vim* +if_cscop.txt if_cscop.txt /*if_cscop.txt* +if_lua.txt if_lua.txt /*if_lua.txt* +if_mzsch.txt if_mzsch.txt /*if_mzsch.txt* +if_ole.txt if_ole.txt /*if_ole.txt* +if_perl.txt if_perl.txt /*if_perl.txt* +if_pyth.txt if_pyth.txt /*if_pyth.txt* +if_ruby.txt if_ruby.txt /*if_ruby.txt* +if_sniff.txt if_sniff.txt /*if_sniff.txt* +if_tcl.txt if_tcl.txt /*if_tcl.txt* +ignore-errors eval.txt /*ignore-errors* +improved-autocmds-5.4 version5.txt /*improved-autocmds-5.4* +improved-quickfix version5.txt /*improved-quickfix* +improved-sessions version5.txt /*improved-sessions* +improved-viminfo version5.txt /*improved-viminfo* +improvements-5 version5.txt /*improvements-5* +improvements-6 version6.txt /*improvements-6* +improvements-7 version7.txt /*improvements-7* +inactive-buffer windows.txt /*inactive-buffer* +include-search tagsrch.txt /*include-search* +inclusive motion.txt /*inclusive* +incomp-small-6 version6.txt /*incomp-small-6* +incompatible-5 version5.txt /*incompatible-5* +incompatible-6 version6.txt /*incompatible-6* +incompatible-7 version7.txt /*incompatible-7* +indent() eval.txt /*indent()* +indent-expression indent.txt /*indent-expression* +indent.txt indent.txt /*indent.txt* +indentkeys-format indent.txt /*indentkeys-format* +index index.txt /*index* +index() eval.txt /*index()* +index.txt index.txt /*index.txt* +info-message starting.txt /*info-message* +inform.vim syntax.txt /*inform.vim* +informix ft_sql.txt /*informix* +initialization starting.txt /*initialization* +input() eval.txt /*input()* +inputdialog() eval.txt /*inputdialog()* +inputlist() eval.txt /*inputlist()* +inputrestore() eval.txt /*inputrestore()* +inputsave() eval.txt /*inputsave()* +inputsecret() eval.txt /*inputsecret()* +ins-completion insert.txt /*ins-completion* +ins-completion-menu insert.txt /*ins-completion-menu* +ins-expandtab insert.txt /*ins-expandtab* +ins-reverse rileft.txt /*ins-reverse* +ins-smarttab insert.txt /*ins-smarttab* +ins-softtabstop insert.txt /*ins-softtabstop* +ins-special-keys insert.txt /*ins-special-keys* +ins-special-special insert.txt /*ins-special-special* +ins-textwidth insert.txt /*ins-textwidth* +insert insert.txt /*insert* +insert() eval.txt /*insert()* +insert-index index.txt /*insert-index* +insert.txt insert.txt /*insert.txt* +insert_expand insert.txt /*insert_expand* +inserting insert.txt /*inserting* +inserting-ex insert.txt /*inserting-ex* +inserting-file insert.txt /*inserting-file* +insertmode-variable eval.txt /*insertmode-variable* +install usr_90.txt /*install* +install-home usr_90.txt /*install-home* +install-registry gui_w32.txt /*install-registry* +intel-itanium syntax.txt /*intel-itanium* +intellimouse-wheel-problems gui_w32.txt /*intellimouse-wheel-problems* +interactive-functions usr_41.txt /*interactive-functions* +interfaces-5.2 version5.txt /*interfaces-5.2* +internal-variables eval.txt /*internal-variables* +internal-wordlist spell.txt /*internal-wordlist* +internet intro.txt /*internet* +intro intro.txt /*intro* +intro.txt intro.txt /*intro.txt* +inverse syntax.txt /*inverse* +ip motion.txt /*ip* +iquote motion.txt /*iquote* +is motion.txt /*is* +isdirectory() eval.txt /*isdirectory()* +islocked() eval.txt /*islocked()* +it motion.txt /*it* +italic syntax.txt /*italic* +items() eval.txt /*items()* +iw motion.txt /*iw* +i{ motion.txt /*i{* +i} motion.txt /*i}* +j motion.txt /*j* +java-cinoptions indent.txt /*java-cinoptions* +java-indenting indent.txt /*java-indenting* +java.vim syntax.txt /*java.vim* +javascript-cinoptions indent.txt /*javascript-cinoptions* +javascript-indenting indent.txt /*javascript-indenting* +join() eval.txt /*join()* +jsbterm-mouse options.txt /*jsbterm-mouse* +jtags tagsrch.txt /*jtags* +jump-motions motion.txt /*jump-motions* +jumplist motion.txt /*jumplist* +jumpto-diffs diff.txt /*jumpto-diffs* +k motion.txt /*k* +kcc uganda.txt /*kcc* +kde gui_x11.txt /*kde* +key-codes intro.txt /*key-codes* +key-codes-changed version4.txt /*key-codes-changed* +key-mapping map.txt /*key-mapping* +key-notation intro.txt /*key-notation* +key-variable eval.txt /*key-variable* +keycodes intro.txt /*keycodes* +keymap-accents mbyte.txt /*keymap-accents* +keymap-file-format mbyte.txt /*keymap-file-format* +keymap-hebrew mbyte.txt /*keymap-hebrew* +keypad-0 intro.txt /*keypad-0* +keypad-9 intro.txt /*keypad-9* +keypad-comma term.txt /*keypad-comma* +keypad-divide intro.txt /*keypad-divide* +keypad-end intro.txt /*keypad-end* +keypad-enter intro.txt /*keypad-enter* +keypad-home intro.txt /*keypad-home* +keypad-minus intro.txt /*keypad-minus* +keypad-multiply intro.txt /*keypad-multiply* +keypad-page-down intro.txt /*keypad-page-down* +keypad-page-up intro.txt /*keypad-page-up* +keypad-plus intro.txt /*keypad-plus* +keypad-point intro.txt /*keypad-point* +keys() eval.txt /*keys()* +known-bugs todo.txt /*known-bugs* +l motion.txt /*l* +l:var eval.txt /*l:var* +lCursor mbyte.txt /*lCursor* +lace.vim syntax.txt /*lace.vim* +lang-variable eval.txt /*lang-variable* +language-mapping map.txt /*language-mapping* +last-pattern pattern.txt /*last-pattern* +last-position-jump eval.txt /*last-position-jump* +last_buffer_nr() eval.txt /*last_buffer_nr()* +lc_time-variable eval.txt /*lc_time-variable* +left-right-motions motion.txt /*left-right-motions* +len() eval.txt /*len()* +less various.txt /*less* +letter print.txt /*letter* +lex.vim syntax.txt /*lex.vim* +lhaskell.vim syntax.txt /*lhaskell.vim* +libcall() eval.txt /*libcall()* +libcallnr() eval.txt /*libcallnr()* +license uganda.txt /*license* +lid quickfix.txt /*lid* +lifelines.vim syntax.txt /*lifelines.vim* +limits vi_diff.txt /*limits* +line() eval.txt /*line()* +line-continuation repeat.txt /*line-continuation* +line2byte() eval.txt /*line2byte()* +linefeed intro.txt /*linefeed* +linewise motion.txt /*linewise* +linewise-register change.txt /*linewise-register* +linewise-visual visual.txt /*linewise-visual* +lisp.vim syntax.txt /*lisp.vim* +lispindent() eval.txt /*lispindent()* +list-functions usr_41.txt /*list-functions* +list-identity eval.txt /*list-identity* +list-index eval.txt /*list-index* +list-modification eval.txt /*list-modification* +list-repeat windows.txt /*list-repeat* +lite.vim syntax.txt /*lite.vim* +literal-string eval.txt /*literal-string* +lnum-variable eval.txt /*lnum-variable* +load-plugins starting.txt /*load-plugins* +load-vim-script repeat.txt /*load-vim-script* +local-additions help.txt /*local-additions* +local-function eval.txt /*local-function* +local-options options.txt /*local-options* +local-variable eval.txt /*local-variable* +local-variables eval.txt /*local-variables* +local_markfilelist pi_netrw.txt /*local_markfilelist* +locale mbyte.txt /*locale* +locale-name mbyte.txt /*locale-name* +localtime() eval.txt /*localtime()* +location-list quickfix.txt /*location-list* +location-list-window quickfix.txt /*location-list-window* +log() eval.txt /*log()* +log10() eval.txt /*log10()* +long-lines version5.txt /*long-lines* +lowercase change.txt /*lowercase* +lpc.vim syntax.txt /*lpc.vim* +lua if_lua.txt /*lua* +lua-buffer if_lua.txt /*lua-buffer* +lua-commands if_lua.txt /*lua-commands* +lua-vim if_lua.txt /*lua-vim* +lua-window if_lua.txt /*lua-window* +lua.vim syntax.txt /*lua.vim* +m motion.txt /*m* +m' motion.txt /*m'* +m[ motion.txt /*m[* +m] motion.txt /*m]* +m` motion.txt /*m`* +mac os_mac.txt /*mac* +mac-bug os_mac.txt /*mac-bug* +mac-compile os_mac.txt /*mac-compile* +mac-faq os_mac.txt /*mac-faq* +mac-filename os_mac.txt /*mac-filename* +mac-lack os_mac.txt /*mac-lack* +mac-vimfile os_mac.txt /*mac-vimfile* +macintosh os_mac.txt /*macintosh* +macro map.txt /*macro* +mail-list intro.txt /*mail-list* +mail.vim syntax.txt /*mail.vim* +maillist intro.txt /*maillist* +maillist-archive intro.txt /*maillist-archive* +make.vim syntax.txt /*make.vim* +manual-copyright usr_01.txt /*manual-copyright* +map() eval.txt /*map()* +map-<SID> map.txt /*map-<SID>* +map-ambiguous map.txt /*map-ambiguous* +map-backtick tips.txt /*map-backtick* +map-comments map.txt /*map-comments* +map-examples map.txt /*map-examples* +map-keys-fails map.txt /*map-keys-fails* +map-listing map.txt /*map-listing* +map-modes map.txt /*map-modes* +map-multibyte map.txt /*map-multibyte* +map-overview map.txt /*map-overview* +map-self-destroy tips.txt /*map-self-destroy* +map-typing map.txt /*map-typing* +map-which-keys map.txt /*map-which-keys* +map.txt map.txt /*map.txt* +map_CTRL-C map.txt /*map_CTRL-C* +map_backslash map.txt /*map_backslash* +map_bar map.txt /*map_bar* +map_empty_rhs map.txt /*map_empty_rhs* +map_return map.txt /*map_return* +map_space_in_lhs map.txt /*map_space_in_lhs* +map_space_in_rhs map.txt /*map_space_in_rhs* +maparg() eval.txt /*maparg()* +mapcheck() eval.txt /*mapcheck()* +maple.vim syntax.txt /*maple.vim* +mapleader map.txt /*mapleader* +maplocalleader map.txt /*maplocalleader* +mapmode-c map.txt /*mapmode-c* +mapmode-i map.txt /*mapmode-i* +mapmode-ic map.txt /*mapmode-ic* +mapmode-l map.txt /*mapmode-l* +mapmode-n map.txt /*mapmode-n* +mapmode-nvo map.txt /*mapmode-nvo* +mapmode-o map.txt /*mapmode-o* +mapmode-s map.txt /*mapmode-s* +mapmode-v map.txt /*mapmode-v* +mapmode-x map.txt /*mapmode-x* +mapping map.txt /*mapping* +mark motion.txt /*mark* +mark-functions usr_41.txt /*mark-functions* +mark-motions motion.txt /*mark-motions* +markfilelist pi_netrw.txt /*markfilelist* +masm.vim syntax.txt /*masm.vim* +match() eval.txt /*match()* +match-highlight pattern.txt /*match-highlight* +match-parens tips.txt /*match-parens* +matchadd() eval.txt /*matchadd()* +matcharg() eval.txt /*matcharg()* +matchdelete() eval.txt /*matchdelete()* +matchend() eval.txt /*matchend()* +matchit-install usr_05.txt /*matchit-install* +matchlist() eval.txt /*matchlist()* +matchparen pi_paren.txt /*matchparen* +matchstr() eval.txt /*matchstr()* +max() eval.txt /*max()* +mbyte-IME mbyte.txt /*mbyte-IME* +mbyte-XIM mbyte.txt /*mbyte-XIM* +mbyte-combining mbyte.txt /*mbyte-combining* +mbyte-composing mbyte.txt /*mbyte-composing* +mbyte-conversion mbyte.txt /*mbyte-conversion* +mbyte-encoding mbyte.txt /*mbyte-encoding* +mbyte-first mbyte.txt /*mbyte-first* +mbyte-fonts-MSwin mbyte.txt /*mbyte-fonts-MSwin* +mbyte-fonts-X11 mbyte.txt /*mbyte-fonts-X11* +mbyte-keymap mbyte.txt /*mbyte-keymap* +mbyte-locale mbyte.txt /*mbyte-locale* +mbyte-options mbyte.txt /*mbyte-options* +mbyte-terminal mbyte.txt /*mbyte-terminal* +mbyte-utf8 mbyte.txt /*mbyte-utf8* +mbyte.txt mbyte.txt /*mbyte.txt* +menu-changes-5.4 version5.txt /*menu-changes-5.4* +menu-examples gui.txt /*menu-examples* +menu-priority gui.txt /*menu-priority* +menu-separator gui.txt /*menu-separator* +menu.vim gui.txt /*menu.vim* +menus gui.txt /*menus* +merge diff.txt /*merge* +message-history message.txt /*message-history* +message.txt message.txt /*message.txt* +messages message.txt /*messages* +meta intro.txt /*meta* +min() eval.txt /*min()* +minimal-features os_msdos.txt /*minimal-features* +missing-options vi_diff.txt /*missing-options* +mkdir() eval.txt /*mkdir()* +mlang.txt mlang.txt /*mlang.txt* +mma.vim syntax.txt /*mma.vim* +mode() eval.txt /*mode()* +mode-Ex intro.txt /*mode-Ex* +mode-cmdline cmdline.txt /*mode-cmdline* +mode-ins-repl insert.txt /*mode-ins-repl* +mode-replace insert.txt /*mode-replace* +mode-switching intro.txt /*mode-switching* +modeless-and-clipboard version6.txt /*modeless-and-clipboard* +modeless-selection gui.txt /*modeless-selection* +modeline options.txt /*modeline* +modeline-local options.txt /*modeline-local* +modeline-version options.txt /*modeline-version* +moo.vim syntax.txt /*moo.vim* +more-compatible version5.txt /*more-compatible* +more-prompt message.txt /*more-prompt* +more-variables eval.txt /*more-variables* +motion.txt motion.txt /*motion.txt* +mouse-mode-table term.txt /*mouse-mode-table* +mouse-overview term.txt /*mouse-overview* +mouse-swap-buttons term.txt /*mouse-swap-buttons* +mouse-using term.txt /*mouse-using* +mouse_col-variable eval.txt /*mouse_col-variable* +mouse_lnum-variable eval.txt /*mouse_lnum-variable* +mouse_win-variable eval.txt /*mouse_win-variable* +movement intro.txt /*movement* +ms-dos os_msdos.txt /*ms-dos* +msdos os_msdos.txt /*msdos* +msdos-arrows os_msdos.txt /*msdos-arrows* +msdos-clipboard-limits os_msdos.txt /*msdos-clipboard-limits* +msdos-compiling os_msdos.txt /*msdos-compiling* +msdos-copy-paste os_msdos.txt /*msdos-copy-paste* +msdos-fname-extensions os_msdos.txt /*msdos-fname-extensions* +msdos-limitations os_msdos.txt /*msdos-limitations* +msdos-linked-files os_msdos.txt /*msdos-linked-files* +msdos-longfname os_msdos.txt /*msdos-longfname* +msdos-mode gui_w32.txt /*msdos-mode* +msdos-problems os_msdos.txt /*msdos-problems* +msdos-termcap os_msdos.txt /*msdos-termcap* +msdos-versions os_msdos.txt /*msdos-versions* +msql.vim syntax.txt /*msql.vim* +mswin.vim gui_w32.txt /*mswin.vim* +multi-byte mbyte.txt /*multi-byte* +multi-lang mlang.txt /*multi-lang* +multi-repeat repeat.txt /*multi-repeat* +multibyte mbyte.txt /*multibyte* +multibyte-ime mbyte.txt /*multibyte-ime* +multibyte-input mbyte.txt /*multibyte-input* +multilang mlang.txt /*multilang* +multilang-menus mlang.txt /*multilang-menus* +multilang-messages mlang.txt /*multilang-messages* +multilang-scripts mlang.txt /*multilang-scripts* +myfiletypefile syntax.txt /*myfiletypefile* +myscriptsfile syntax.txt /*myscriptsfile* +mysql ft_sql.txt /*mysql* +mysyntaxfile syntax.txt /*mysyntaxfile* +mysyntaxfile-add syntax.txt /*mysyntaxfile-add* +mysyntaxfile-replace syntax.txt /*mysyntaxfile-replace* +mzeval() eval.txt /*mzeval()* +mzscheme if_mzsch.txt /*mzscheme* +mzscheme-buffer if_mzsch.txt /*mzscheme-buffer* +mzscheme-commands if_mzsch.txt /*mzscheme-commands* +mzscheme-dynamic if_mzsch.txt /*mzscheme-dynamic* +mzscheme-examples if_mzsch.txt /*mzscheme-examples* +mzscheme-mzeval if_mzsch.txt /*mzscheme-mzeval* +mzscheme-sandbox if_mzsch.txt /*mzscheme-sandbox* +mzscheme-threads if_mzsch.txt /*mzscheme-threads* +mzscheme-vim if_mzsch.txt /*mzscheme-vim* +mzscheme-vimext if_mzsch.txt /*mzscheme-vimext* +mzscheme-window if_mzsch.txt /*mzscheme-window* +n pattern.txt /*n* +nasm.vim syntax.txt /*nasm.vim* +navigation motion.txt /*navigation* +nb-commands netbeans.txt /*nb-commands* +nb-events netbeans.txt /*nb-events* +nb-functions netbeans.txt /*nb-functions* +nb-messages netbeans.txt /*nb-messages* +nb-protocol_errors netbeans.txt /*nb-protocol_errors* +nb-special netbeans.txt /*nb-special* +nb-terms netbeans.txt /*nb-terms* +ncf.vim syntax.txt /*ncf.vim* +netbeans netbeans.txt /*netbeans* +netbeans-commands netbeans.txt /*netbeans-commands* +netbeans-configure netbeans.txt /*netbeans-configure* +netbeans-debugging netbeans.txt /*netbeans-debugging* +netbeans-download netbeans.txt /*netbeans-download* +netbeans-integration netbeans.txt /*netbeans-integration* +netbeans-intro netbeans.txt /*netbeans-intro* +netbeans-keybindings netbeans.txt /*netbeans-keybindings* +netbeans-messages netbeans.txt /*netbeans-messages* +netbeans-parameters netbeans.txt /*netbeans-parameters* +netbeans-preparation netbeans.txt /*netbeans-preparation* +netbeans-problems netbeans.txt /*netbeans-problems* +netbeans-protocol netbeans.txt /*netbeans-protocol* +netbeans-run netbeans.txt /*netbeans-run* +netbeans-setup netbeans.txt /*netbeans-setup* +netbeans-support netbeans.txt /*netbeans-support* +netbeans.txt netbeans.txt /*netbeans.txt* +netreadfixup pi_netrw.txt /*netreadfixup* +netrw pi_netrw.txt /*netrw* +netrw-% pi_netrw.txt /*netrw-%* +netrw-- pi_netrw.txt /*netrw--* +netrw-C pi_netrw.txt /*netrw-C* +netrw-D pi_netrw.txt /*netrw-D* +netrw-O pi_netrw.txt /*netrw-O* +netrw-P pi_netrw.txt /*netrw-P* +netrw-R pi_netrw.txt /*netrw-R* +netrw-S pi_netrw.txt /*netrw-S* +netrw-T pi_netrw.txt /*netrw-T* +netrw-U pi_netrw.txt /*netrw-U* +netrw-a pi_netrw.txt /*netrw-a* +netrw-activate pi_netrw.txt /*netrw-activate* +netrw-bookmark pi_netrw.txt /*netrw-bookmark* +netrw-bookmarks pi_netrw.txt /*netrw-bookmarks* +netrw-browse pi_netrw.txt /*netrw-browse* +netrw-browse-cmds pi_netrw.txt /*netrw-browse-cmds* +netrw-browse-maps pi_netrw.txt /*netrw-browse-maps* +netrw-browser pi_netrw.txt /*netrw-browser* +netrw-browser-options pi_netrw.txt /*netrw-browser-options* +netrw-browser-var pi_netrw.txt /*netrw-browser-var* +netrw-browsing pi_netrw.txt /*netrw-browsing* +netrw-c pi_netrw.txt /*netrw-c* +netrw-cadaver pi_netrw.txt /*netrw-cadaver* +netrw-chgup pi_netrw.txt /*netrw-chgup* +netrw-clean pi_netrw.txt /*netrw-clean* +netrw-contents pi_netrw.txt /*netrw-contents* +netrw-copyright pi_netrw.txt /*netrw-copyright* +netrw-cr pi_netrw.txt /*netrw-cr* +netrw-credits pi_netrw.txt /*netrw-credits* +netrw-ctrl-h pi_netrw.txt /*netrw-ctrl-h* +netrw-ctrl-l pi_netrw.txt /*netrw-ctrl-l* +netrw-ctrl_l pi_netrw.txt /*netrw-ctrl_l* +netrw-curdir pi_netrw.txt /*netrw-curdir* +netrw-d pi_netrw.txt /*netrw-d* +netrw-debug pi_netrw.txt /*netrw-debug* +netrw-del pi_netrw.txt /*netrw-del* +netrw-delete pi_netrw.txt /*netrw-delete* +netrw-dir pi_netrw.txt /*netrw-dir* +netrw-dirlist pi_netrw.txt /*netrw-dirlist* +netrw-downdir pi_netrw.txt /*netrw-downdir* +netrw-edithide pi_netrw.txt /*netrw-edithide* +netrw-ex pi_netrw.txt /*netrw-ex* +netrw-explore pi_netrw.txt /*netrw-explore* +netrw-explore-cmds pi_netrw.txt /*netrw-explore-cmds* +netrw-externapp pi_netrw.txt /*netrw-externapp* +netrw-file pi_netrw.txt /*netrw-file* +netrw-filigree pi_netrw.txt /*netrw-filigree* +netrw-fixup pi_netrw.txt /*netrw-fixup* +netrw-ftp pi_netrw.txt /*netrw-ftp* +netrw-ftype pi_netrw.txt /*netrw-ftype* +netrw-gb pi_netrw.txt /*netrw-gb* +netrw-getftype pi_netrw.txt /*netrw-getftype* +netrw-gh pi_netrw.txt /*netrw-gh* +netrw-gp pi_netrw.txt /*netrw-gp* +netrw-gx pi_netrw.txt /*netrw-gx* +netrw-handler pi_netrw.txt /*netrw-handler* +netrw-help pi_netrw.txt /*netrw-help* +netrw-hexplore pi_netrw.txt /*netrw-hexplore* +netrw-hide pi_netrw.txt /*netrw-hide* +netrw-hiding pi_netrw.txt /*netrw-hiding* +netrw-history pi_netrw.txt /*netrw-history* +netrw-horiz pi_netrw.txt /*netrw-horiz* +netrw-i pi_netrw.txt /*netrw-i* +netrw-incompatible pi_netrw.txt /*netrw-incompatible* +netrw-intro-browse pi_netrw.txt /*netrw-intro-browse* +netrw-leftmouse pi_netrw.txt /*netrw-leftmouse* +netrw-list pi_netrw.txt /*netrw-list* +netrw-listbookmark pi_netrw.txt /*netrw-listbookmark* +netrw-listhack pi_netrw.txt /*netrw-listhack* +netrw-login pi_netrw.txt /*netrw-login* +netrw-mB pi_netrw.txt /*netrw-mB* +netrw-mT pi_netrw.txt /*netrw-mT* +netrw-mb pi_netrw.txt /*netrw-mb* +netrw-mc pi_netrw.txt /*netrw-mc* +netrw-md pi_netrw.txt /*netrw-md* +netrw-me pi_netrw.txt /*netrw-me* +netrw-mf pi_netrw.txt /*netrw-mf* +netrw-mg pi_netrw.txt /*netrw-mg* +netrw-mh pi_netrw.txt /*netrw-mh* +netrw-middlemouse pi_netrw.txt /*netrw-middlemouse* +netrw-ml_get pi_netrw.txt /*netrw-ml_get* +netrw-mm pi_netrw.txt /*netrw-mm* +netrw-mouse pi_netrw.txt /*netrw-mouse* +netrw-move pi_netrw.txt /*netrw-move* +netrw-mp pi_netrw.txt /*netrw-mp* +netrw-mr pi_netrw.txt /*netrw-mr* +netrw-ms pi_netrw.txt /*netrw-ms* +netrw-mt pi_netrw.txt /*netrw-mt* +netrw-mu pi_netrw.txt /*netrw-mu* +netrw-mx pi_netrw.txt /*netrw-mx* +netrw-mz pi_netrw.txt /*netrw-mz* +netrw-netrc pi_netrw.txt /*netrw-netrc* +netrw-nexplore pi_netrw.txt /*netrw-nexplore* +netrw-noload pi_netrw.txt /*netrw-noload* +netrw-nread pi_netrw.txt /*netrw-nread* +netrw-nwrite pi_netrw.txt /*netrw-nwrite* +netrw-o pi_netrw.txt /*netrw-o* +netrw-options pi_netrw.txt /*netrw-options* +netrw-p pi_netrw.txt /*netrw-p* +netrw-p1 pi_netrw.txt /*netrw-p1* +netrw-p10 pi_netrw.txt /*netrw-p10* +netrw-p11 pi_netrw.txt /*netrw-p11* +netrw-p12 pi_netrw.txt /*netrw-p12* +netrw-p13 pi_netrw.txt /*netrw-p13* +netrw-p2 pi_netrw.txt /*netrw-p2* +netrw-p3 pi_netrw.txt /*netrw-p3* +netrw-p4 pi_netrw.txt /*netrw-p4* +netrw-p5 pi_netrw.txt /*netrw-p5* +netrw-p6 pi_netrw.txt /*netrw-p6* +netrw-p7 pi_netrw.txt /*netrw-p7* +netrw-p8 pi_netrw.txt /*netrw-p8* +netrw-p9 pi_netrw.txt /*netrw-p9* +netrw-passwd pi_netrw.txt /*netrw-passwd* +netrw-password pi_netrw.txt /*netrw-password* +netrw-path pi_netrw.txt /*netrw-path* +netrw-pexplore pi_netrw.txt /*netrw-pexplore* +netrw-preview pi_netrw.txt /*netrw-preview* +netrw-problems pi_netrw.txt /*netrw-problems* +netrw-protocol pi_netrw.txt /*netrw-protocol* +netrw-prvwin pi_netrw.txt /*netrw-prvwin* +netrw-pscp pi_netrw.txt /*netrw-pscp* +netrw-psftp pi_netrw.txt /*netrw-psftp* +netrw-putty pi_netrw.txt /*netrw-putty* +netrw-qb pi_netrw.txt /*netrw-qb* +netrw-qf pi_netrw.txt /*netrw-qf* +netrw-quickcom pi_netrw.txt /*netrw-quickcom* +netrw-quickcoms pi_netrw.txt /*netrw-quickcoms* +netrw-quickhelp pi_netrw.txt /*netrw-quickhelp* +netrw-quickmap pi_netrw.txt /*netrw-quickmap* +netrw-quickmaps pi_netrw.txt /*netrw-quickmaps* +netrw-r pi_netrw.txt /*netrw-r* +netrw-read pi_netrw.txt /*netrw-read* +netrw-ref pi_netrw.txt /*netrw-ref* +netrw-rename pi_netrw.txt /*netrw-rename* +netrw-reverse pi_netrw.txt /*netrw-reverse* +netrw-rexplore pi_netrw.txt /*netrw-rexplore* +netrw-rightmouse pi_netrw.txt /*netrw-rightmouse* +netrw-s pi_netrw.txt /*netrw-s* +netrw-settings pi_netrw.txt /*netrw-settings* +netrw-sexplore pi_netrw.txt /*netrw-sexplore* +netrw-sort pi_netrw.txt /*netrw-sort* +netrw-sortsequence pi_netrw.txt /*netrw-sortsequence* +netrw-source pi_netrw.txt /*netrw-source* +netrw-ssh-hack pi_netrw.txt /*netrw-ssh-hack* +netrw-star pi_netrw.txt /*netrw-star* +netrw-starpat pi_netrw.txt /*netrw-starpat* +netrw-starstar pi_netrw.txt /*netrw-starstar* +netrw-starstarpat pi_netrw.txt /*netrw-starstarpat* +netrw-start pi_netrw.txt /*netrw-start* +netrw-t pi_netrw.txt /*netrw-t* +netrw-texplore pi_netrw.txt /*netrw-texplore* +netrw-todo pi_netrw.txt /*netrw-todo* +netrw-transparent pi_netrw.txt /*netrw-transparent* +netrw-u pi_netrw.txt /*netrw-u* +netrw-updir pi_netrw.txt /*netrw-updir* +netrw-urls pi_netrw.txt /*netrw-urls* +netrw-userpass pi_netrw.txt /*netrw-userpass* +netrw-v pi_netrw.txt /*netrw-v* +netrw-var pi_netrw.txt /*netrw-var* +netrw-variables pi_netrw.txt /*netrw-variables* +netrw-vexplore pi_netrw.txt /*netrw-vexplore* +netrw-write pi_netrw.txt /*netrw-write* +netrw-x pi_netrw.txt /*netrw-x* +netrw-xfer pi_netrw.txt /*netrw-xfer* +netrw.vim pi_netrw.txt /*netrw.vim* +netrw_filehandler pi_netrw.txt /*netrw_filehandler* +netterm-mouse options.txt /*netterm-mouse* +network pi_netrw.txt /*network* +new-5 version5.txt /*new-5* +new-6 version6.txt /*new-6* +new-7 version7.txt /*new-7* +new-GTK-GUI version5.txt /*new-GTK-GUI* +new-MzScheme version7.txt /*new-MzScheme* +new-Select-mode version5.txt /*new-Select-mode* +new-View version6.txt /*new-View* +new-argument-list version6.txt /*new-argument-list* +new-buftype version6.txt /*new-buftype* +new-cmdwin version6.txt /*new-cmdwin* +new-color-schemes version6.txt /*new-color-schemes* +new-commands version5.txt /*new-commands* +new-commands-5.4 version5.txt /*new-commands-5.4* +new-conceal version7.txt /*new-conceal* +new-debug-itf version6.txt /*new-debug-itf* +new-debug-mode version6.txt /*new-debug-mode* +new-debug-support version7.txt /*new-debug-support* +new-define-operator version7.txt /*new-define-operator* +new-diff-mode version6.txt /*new-diff-mode* +new-encryption version5.txt /*new-encryption* +new-evim version6.txt /*new-evim* +new-ex-commands-5.2 version5.txt /*new-ex-commands-5.2* +new-file-browser version6.txt /*new-file-browser* +new-file-writing version6.txt /*new-file-writing* +new-filetype filetype.txt /*new-filetype* +new-filetype-5.4 version5.txt /*new-filetype-5.4* +new-filetype-plugins version6.txt /*new-filetype-plugins* +new-filetype-scripts filetype.txt /*new-filetype-scripts* +new-folding version6.txt /*new-folding* +new-functions-5.2 version5.txt /*new-functions-5.2* +new-global-values version6.txt /*new-global-values* +new-highlighting version5.txt /*new-highlighting* +new-indent-flex version6.txt /*new-indent-flex* +new-items-6 version6.txt /*new-items-6* +new-items-7 version7.txt /*new-items-7* +new-line-continuation version5.txt /*new-line-continuation* +new-location-list version7.txt /*new-location-list* +new-lua version7.txt /*new-lua* +new-manpage-trans version7.txt /*new-manpage-trans* +new-map-expression version7.txt /*new-map-expression* +new-map-select version7.txt /*new-map-select* +new-more-encryption version7.txt /*new-more-encryption* +new-more-highlighting version7.txt /*new-more-highlighting* +new-more-unicode version7.txt /*new-more-unicode* +new-multi-byte version5.txt /*new-multi-byte* +new-multi-lang version6.txt /*new-multi-lang* +new-netrw-explore version7.txt /*new-netrw-explore* +new-network-files version6.txt /*new-network-files* +new-omni-completion version7.txt /*new-omni-completion* +new-onemore version7.txt /*new-onemore* +new-operator-mod version6.txt /*new-operator-mod* +new-options-5.2 version5.txt /*new-options-5.2* +new-options-5.4 version5.txt /*new-options-5.4* +new-perl-python version5.txt /*new-perl-python* +new-persistent-undo version7.txt /*new-persistent-undo* +new-plugins version6.txt /*new-plugins* +new-posix version7.txt /*new-posix* +new-print-multi-byte version7.txt /*new-print-multi-byte* +new-printing version6.txt /*new-printing* +new-python3 version7.txt /*new-python3* +new-runtime-dir version5.txt /*new-runtime-dir* +new-script version5.txt /*new-script* +new-script-5.4 version5.txt /*new-script-5.4* +new-scroll-back version7.txt /*new-scroll-back* +new-search-path version6.txt /*new-search-path* +new-searchpat version6.txt /*new-searchpat* +new-session-files version5.txt /*new-session-files* +new-spell version7.txt /*new-spell* +new-tab-pages version7.txt /*new-tab-pages* +new-undo-branches version7.txt /*new-undo-branches* +new-unlisted-buffers version6.txt /*new-unlisted-buffers* +new-user-defined version5.txt /*new-user-defined* +new-user-manual version6.txt /*new-user-manual* +new-utf-8 version6.txt /*new-utf-8* +new-vertsplit version6.txt /*new-vertsplit* +new-vim-script version7.txt /*new-vim-script* +new-vim-server version6.txt /*new-vim-server* +new-vimgrep version7.txt /*new-vimgrep* +new-virtedit version6.txt /*new-virtedit* +news intro.txt /*news* +nextnonblank() eval.txt /*nextnonblank()* +nice todo.txt /*nice* +no-eval-feature eval.txt /*no-eval-feature* +no_buffers_menu gui.txt /*no_buffers_menu* +non-greedy pattern.txt /*non-greedy* +non-zero-arg eval.txt /*non-zero-arg* +normal-index index.txt /*normal-index* +not-compatible usr_01.txt /*not-compatible* +not-edited editing.txt /*not-edited* +notation intro.txt /*notation* +notepad gui_w32.txt /*notepad* +nr2char() eval.txt /*nr2char()* +nroff.vim syntax.txt /*nroff.vim* +numbered-function eval.txt /*numbered-function* +o insert.txt /*o* +o_CTRL-V motion.txt /*o_CTRL-V* +o_V motion.txt /*o_V* +o_v motion.txt /*o_v* +object-motions motion.txt /*object-motions* +object-select motion.txt /*object-select* +objects index.txt /*objects* +obtaining-exted netbeans.txt /*obtaining-exted* +ocaml.vim syntax.txt /*ocaml.vim* +octal eval.txt /*octal* +octal-number options.txt /*octal-number* +oldfiles-variable eval.txt /*oldfiles-variable* +ole-activation if_ole.txt /*ole-activation* +ole-eval if_ole.txt /*ole-eval* +ole-gethwnd if_ole.txt /*ole-gethwnd* +ole-interface if_ole.txt /*ole-interface* +ole-methods if_ole.txt /*ole-methods* +ole-normal if_ole.txt /*ole-normal* +ole-registration if_ole.txt /*ole-registration* +ole-sendkeys if_ole.txt /*ole-sendkeys* +ole-setforeground if_ole.txt /*ole-setforeground* +omap-info map.txt /*omap-info* +omni-sql-completion ft_sql.txt /*omni-sql-completion* +online-help helphelp.txt /*online-help* +opening-window windows.txt /*opening-window* +operator motion.txt /*operator* +operator-variable eval.txt /*operator-variable* +option-backslash options.txt /*option-backslash* +option-list quickref.txt /*option-list* +option-summary options.txt /*option-summary* +options options.txt /*options* +options-changed version5.txt /*options-changed* +options.txt options.txt /*options.txt* +oracle ft_sql.txt /*oracle* +os2 os_os2.txt /*os2* +os2ansi os_os2.txt /*os2ansi* +os390 os_390.txt /*os390* +os_390.txt os_390.txt /*os_390.txt* +os_amiga.txt os_amiga.txt /*os_amiga.txt* +os_beos.txt os_beos.txt /*os_beos.txt* +os_dos.txt os_dos.txt /*os_dos.txt* +os_mac.txt os_mac.txt /*os_mac.txt* +os_mint.txt os_mint.txt /*os_mint.txt* +os_msdos.txt os_msdos.txt /*os_msdos.txt* +os_os2.txt os_os2.txt /*os_os2.txt* +os_qnx.txt os_qnx.txt /*os_qnx.txt* +os_risc.txt os_risc.txt /*os_risc.txt* +os_unix.txt os_unix.txt /*os_unix.txt* +os_vms.txt os_vms.txt /*os_vms.txt* +os_win32.txt os_win32.txt /*os_win32.txt* +other-features vi_diff.txt /*other-features* +p change.txt /*p* +page-down intro.txt /*page-down* +page-up intro.txt /*page-up* +page_down intro.txt /*page_down* +page_up intro.txt /*page_up* +pager message.txt /*pager* +papp.vim syntax.txt /*papp.vim* +paragraph motion.txt /*paragraph* +pascal.vim syntax.txt /*pascal.vim* +pathshorten() eval.txt /*pathshorten()* +pattern pattern.txt /*pattern* +pattern-atoms pattern.txt /*pattern-atoms* +pattern-multi-byte pattern.txt /*pattern-multi-byte* +pattern-multi-items pattern.txt /*pattern-multi-items* +pattern-overview pattern.txt /*pattern-overview* +pattern-searches pattern.txt /*pattern-searches* +pattern.txt pattern.txt /*pattern.txt* +patterns-composing pattern.txt /*patterns-composing* +pdev-option print.txt /*pdev-option* +penc-option print.txt /*penc-option* +perl if_perl.txt /*perl* +perl-Append if_perl.txt /*perl-Append* +perl-Buffer if_perl.txt /*perl-Buffer* +perl-Buffers if_perl.txt /*perl-Buffers* +perl-Count if_perl.txt /*perl-Count* +perl-Delete if_perl.txt /*perl-Delete* +perl-DoCommand if_perl.txt /*perl-DoCommand* +perl-Eval if_perl.txt /*perl-Eval* +perl-Get if_perl.txt /*perl-Get* +perl-GetCursor if_perl.txt /*perl-GetCursor* +perl-Msg if_perl.txt /*perl-Msg* +perl-Name if_perl.txt /*perl-Name* +perl-Number if_perl.txt /*perl-Number* +perl-Set if_perl.txt /*perl-Set* +perl-SetHeight if_perl.txt /*perl-SetHeight* +perl-SetOption if_perl.txt /*perl-SetOption* +perl-Windows if_perl.txt /*perl-Windows* +perl-compiling if_perl.txt /*perl-compiling* +perl-dynamic if_perl.txt /*perl-dynamic* +perl-editing if_perl.txt /*perl-editing* +perl-overview if_perl.txt /*perl-overview* +perl-patterns pattern.txt /*perl-patterns* +perl-using if_perl.txt /*perl-using* +perl.vim syntax.txt /*perl.vim* +persistent-undo undo.txt /*persistent-undo* +pexpr-option print.txt /*pexpr-option* +pfn-option print.txt /*pfn-option* +pheader-option print.txt /*pheader-option* +photon-fonts os_qnx.txt /*photon-fonts* +photon-gui os_qnx.txt /*photon-gui* +php-comment indent.txt /*php-comment* +php-indent indent.txt /*php-indent* +php-indenting indent.txt /*php-indenting* +php.vim syntax.txt /*php.vim* +php3.vim syntax.txt /*php3.vim* +phtml.vim syntax.txt /*phtml.vim* +pi_getscript.txt pi_getscript.txt /*pi_getscript.txt* +pi_gzip.txt pi_gzip.txt /*pi_gzip.txt* +pi_netrw.txt pi_netrw.txt /*pi_netrw.txt* +pi_paren.txt pi_paren.txt /*pi_paren.txt* +pi_spec.txt pi_spec.txt /*pi_spec.txt* +pi_tar.txt pi_tar.txt /*pi_tar.txt* +pi_vimball.txt pi_vimball.txt /*pi_vimball.txt* +pi_zip.txt pi_zip.txt /*pi_zip.txt* +pkzip options.txt /*pkzip* +plaintex.vim syntax.txt /*plaintex.vim* +plsql ft_sql.txt /*plsql* +plugin usr_05.txt /*plugin* +plugin-details filetype.txt /*plugin-details* +plugin-filetype usr_41.txt /*plugin-filetype* +plugin-special usr_41.txt /*plugin-special* +pmbcs-option print.txt /*pmbcs-option* +pmbfn-option print.txt /*pmbfn-option* +popt-option print.txt /*popt-option* +popup-menu gui.txt /*popup-menu* +popup-menu-added version5.txt /*popup-menu-added* +popupmenu-completion insert.txt /*popupmenu-completion* +popupmenu-keys insert.txt /*popupmenu-keys* +ports-5.2 version5.txt /*ports-5.2* +ports-6 version6.txt /*ports-6* +posix vi_diff.txt /*posix* +posix-compliance vi_diff.txt /*posix-compliance* +posix-screen-size vi_diff.txt /*posix-screen-size* +postgresql ft_sql.txt /*postgresql* +postscr.vim syntax.txt /*postscr.vim* +postscript-cjk-printing print.txt /*postscript-cjk-printing* +postscript-print-encoding print.txt /*postscript-print-encoding* +postscript-print-trouble print.txt /*postscript-print-trouble* +postscript-print-util print.txt /*postscript-print-util* +postscript-printing print.txt /*postscript-printing* +pow() eval.txt /*pow()* +ppwiz.vim syntax.txt /*ppwiz.vim* +press-enter message.txt /*press-enter* +press-return message.txt /*press-return* +prevcount-variable eval.txt /*prevcount-variable* +preview-window windows.txt /*preview-window* +prevnonblank() eval.txt /*prevnonblank()* +print-intro print.txt /*print-intro* +print-options print.txt /*print-options* +print.txt print.txt /*print.txt* +printf() eval.txt /*printf()* +printf-% eval.txt /*printf-%* +printf-E eval.txt /*printf-E* +printf-G eval.txt /*printf-G* +printf-X eval.txt /*printf-X* +printf-c eval.txt /*printf-c* +printf-d eval.txt /*printf-d* +printf-e eval.txt /*printf-e* +printf-f eval.txt /*printf-f* +printf-g eval.txt /*printf-g* +printf-o eval.txt /*printf-o* +printf-s eval.txt /*printf-s* +printf-x eval.txt /*printf-x* +printing print.txt /*printing* +printing-formfeed print.txt /*printing-formfeed* +profile repeat.txt /*profile* +profiling repeat.txt /*profiling* +profiling-variable eval.txt /*profiling-variable* +progname-variable eval.txt /*progname-variable* +progress.vim syntax.txt /*progress.vim* +pronounce intro.txt /*pronounce* +psql ft_sql.txt /*psql* +ptcap.vim syntax.txt /*ptcap.vim* +pterm-mouse options.txt /*pterm-mouse* +pumvisible() eval.txt /*pumvisible()* +put change.txt /*put* +put-Visual-mode change.txt /*put-Visual-mode* +python if_pyth.txt /*python* +python-buffer if_pyth.txt /*python-buffer* +python-buffers if_pyth.txt /*python-buffers* +python-command if_pyth.txt /*python-command* +python-commands if_pyth.txt /*python-commands* +python-current if_pyth.txt /*python-current* +python-dynamic if_pyth.txt /*python-dynamic* +python-error if_pyth.txt /*python-error* +python-eval if_pyth.txt /*python-eval* +python-examples if_pyth.txt /*python-examples* +python-input if_pyth.txt /*python-input* +python-output if_pyth.txt /*python-output* +python-range if_pyth.txt /*python-range* +python-vim if_pyth.txt /*python-vim* +python-window if_pyth.txt /*python-window* +python-windows if_pyth.txt /*python-windows* +python.vim syntax.txt /*python.vim* +python3 if_pyth.txt /*python3* +q repeat.txt /*q* +q/ cmdline.txt /*q\/* +q: cmdline.txt /*q:* +q? cmdline.txt /*q?* +qnx os_qnx.txt /*qnx* +qnx-compiling os_qnx.txt /*qnx-compiling* +qnx-general os_qnx.txt /*qnx-general* +qnx-terminal os_qnx.txt /*qnx-terminal* +quake.vim syntax.txt /*quake.vim* +quickfix quickfix.txt /*quickfix* +quickfix-6 version6.txt /*quickfix-6* +quickfix-directory-stack quickfix.txt /*quickfix-directory-stack* +quickfix-error-lists quickfix.txt /*quickfix-error-lists* +quickfix-functions usr_41.txt /*quickfix-functions* +quickfix-gcc quickfix.txt /*quickfix-gcc* +quickfix-manx quickfix.txt /*quickfix-manx* +quickfix-perl quickfix.txt /*quickfix-perl* +quickfix-valid quickfix.txt /*quickfix-valid* +quickfix-window quickfix.txt /*quickfix-window* +quickfix.txt quickfix.txt /*quickfix.txt* +quickref quickref.txt /*quickref* +quickref.txt quickref.txt /*quickref.txt* +quote change.txt /*quote* +quote# change.txt /*quote#* +quote% change.txt /*quote%* +quote+ gui_x11.txt /*quote+* +quote- change.txt /*quote-* +quote. change.txt /*quote.* +quote/ change.txt /*quote\/* +quote0 change.txt /*quote0* +quote1 change.txt /*quote1* +quote2 change.txt /*quote2* +quote3 change.txt /*quote3* +quote4 change.txt /*quote4* +quote9 change.txt /*quote9* +quote: change.txt /*quote:* +quote= change.txt /*quote=* +quote_ change.txt /*quote_* +quote_# change.txt /*quote_#* +quote_% change.txt /*quote_%* +quote_- change.txt /*quote_-* +quote_. change.txt /*quote_.* +quote_/ change.txt /*quote_\/* +quote_: change.txt /*quote_:* +quote_= change.txt /*quote_=* +quote_alpha change.txt /*quote_alpha* +quote_number change.txt /*quote_number* +quote_quote change.txt /*quote_quote* +quote_~ change.txt /*quote_~* +quotea change.txt /*quotea* +quotecommandquote intro.txt /*quotecommandquote* +quoteplus gui_x11.txt /*quoteplus* +quotequote change.txt /*quotequote* +quotes quotes.txt /*quotes* +quotes.txt quotes.txt /*quotes.txt* +quotestar gui.txt /*quotestar* +quote~ change.txt /*quote~* +r change.txt /*r* +range() eval.txt /*range()* +raw-terminal-mode term.txt /*raw-terminal-mode* +rcp pi_netrw.txt /*rcp* +read-messages insert.txt /*read-messages* +read-only-share editing.txt /*read-only-share* +read-stdin version5.txt /*read-stdin* +readfile() eval.txt /*readfile()* +readline.vim syntax.txt /*readline.vim* +recording repeat.txt /*recording* +recover.txt recover.txt /*recover.txt* +recovery recover.txt /*recovery* +recursive_mapping map.txt /*recursive_mapping* +redo undo.txt /*redo* +redo-register undo.txt /*redo-register* +ref intro.txt /*ref* +reference intro.txt /*reference* +reference_toc help.txt /*reference_toc* +regexp pattern.txt /*regexp* +regexp-changes-5.4 version5.txt /*regexp-changes-5.4* +register sponsor.txt /*register* +register-faq sponsor.txt /*register-faq* +register-variable eval.txt /*register-variable* +registers change.txt /*registers* +regular-expression pattern.txt /*regular-expression* +reltime() eval.txt /*reltime()* +reltimestr() eval.txt /*reltimestr()* +remote.txt remote.txt /*remote.txt* +remote_expr() eval.txt /*remote_expr()* +remote_foreground() eval.txt /*remote_foreground()* +remote_peek() eval.txt /*remote_peek()* +remote_read() eval.txt /*remote_read()* +remote_send() eval.txt /*remote_send()* +remove() eval.txt /*remove()* +remove-filetype filetype.txt /*remove-filetype* +remove-option-flags options.txt /*remove-option-flags* +rename() eval.txt /*rename()* +rename-files tips.txt /*rename-files* +repeat() eval.txt /*repeat()* +repeat.txt repeat.txt /*repeat.txt* +repeating repeat.txt /*repeating* +replacing change.txt /*replacing* +replacing-ex insert.txt /*replacing-ex* +reselect-Visual visual.txt /*reselect-Visual* +resolve() eval.txt /*resolve()* +restore-cursor usr_05.txt /*restore-cursor* +restore-position tips.txt /*restore-position* +restricted-mode starting.txt /*restricted-mode* +retab-example change.txt /*retab-example* +rethrow eval.txt /*rethrow* +reverse() eval.txt /*reverse()* +rexx.vim syntax.txt /*rexx.vim* +rgb.txt gui_w32.txt /*rgb.txt* +rgview starting.txt /*rgview* +rgvim starting.txt /*rgvim* +right-justify change.txt /*right-justify* +rileft rileft.txt /*rileft* +rileft.txt rileft.txt /*rileft.txt* +riscos os_risc.txt /*riscos* +riscos-commandline os_risc.txt /*riscos-commandline* +riscos-filetypes os_risc.txt /*riscos-filetypes* +riscos-gui os_risc.txt /*riscos-gui* +riscos-interrupt os_risc.txt /*riscos-interrupt* +riscos-locations os_risc.txt /*riscos-locations* +riscos-memory os_risc.txt /*riscos-memory* +riscos-munging os_risc.txt /*riscos-munging* +riscos-porting os_risc.txt /*riscos-porting* +riscos-remote os_risc.txt /*riscos-remote* +riscos-shell os_risc.txt /*riscos-shell* +riscos-temp-files os_risc.txt /*riscos-temp-files* +rot13 change.txt /*rot13* +round() eval.txt /*round()* +rsync pi_netrw.txt /*rsync* +ruby if_ruby.txt /*ruby* +ruby-buffer if_ruby.txt /*ruby-buffer* +ruby-command if_ruby.txt /*ruby-command* +ruby-commands if_ruby.txt /*ruby-commands* +ruby-dynamic if_ruby.txt /*ruby-dynamic* +ruby-evaluate if_ruby.txt /*ruby-evaluate* +ruby-globals if_ruby.txt /*ruby-globals* +ruby-message if_ruby.txt /*ruby-message* +ruby-set_option if_ruby.txt /*ruby-set_option* +ruby-vim if_ruby.txt /*ruby-vim* +ruby-window if_ruby.txt /*ruby-window* +ruby.vim syntax.txt /*ruby.vim* +russian russian.txt /*russian* +russian-intro russian.txt /*russian-intro* +russian-issues russian.txt /*russian-issues* +russian-keymap russian.txt /*russian-keymap* +russian-l18n russian.txt /*russian-l18n* +russian.txt russian.txt /*russian.txt* +rview starting.txt /*rview* +rvim starting.txt /*rvim* +rxvt syntax.txt /*rxvt* +s change.txt /*s* +s/\& change.txt /*s\/\\&* +s/\0 change.txt /*s\/\\0* +s/\1 change.txt /*s\/\\1* +s/\2 change.txt /*s\/\\2* +s/\3 change.txt /*s\/\\3* +s/\9 change.txt /*s\/\\9* +s/\<CR> change.txt /*s\/\\<CR>* +s/\E change.txt /*s\/\\E* +s/\L change.txt /*s\/\\L* +s/\U change.txt /*s\/\\U* +s/\\ change.txt /*s\/\\\\* +s/\b change.txt /*s\/\\b* +s/\e change.txt /*s\/\\e* +s/\l change.txt /*s\/\\l* +s/\n change.txt /*s\/\\n* +s/\r change.txt /*s\/\\r* +s/\t change.txt /*s\/\\t* +s/\u change.txt /*s\/\\u* +s/\~ change.txt /*s\/\\~* +s:netrw_passwd pi_netrw.txt /*s:netrw_passwd* +s:var eval.txt /*s:var* +s<CR> change.txt /*s<CR>* +sandbox eval.txt /*sandbox* +sandbox-option eval.txt /*sandbox-option* +save-file editing.txt /*save-file* +save-settings starting.txt /*save-settings* +scheme.vim syntax.txt /*scheme.vim* +scp pi_netrw.txt /*scp* +script usr_41.txt /*script* +script-here if_perl.txt /*script-here* +script-local map.txt /*script-local* +script-variable eval.txt /*script-variable* +scriptnames-dictionary eval.txt /*scriptnames-dictionary* +scriptout-changed version4.txt /*scriptout-changed* +scroll-binding scroll.txt /*scroll-binding* +scroll-cursor scroll.txt /*scroll-cursor* +scroll-down scroll.txt /*scroll-down* +scroll-horizontal scroll.txt /*scroll-horizontal* +scroll-insert tips.txt /*scroll-insert* +scroll-mouse-wheel scroll.txt /*scroll-mouse-wheel* +scroll-region term.txt /*scroll-region* +scroll-smooth tips.txt /*scroll-smooth* +scroll-up scroll.txt /*scroll-up* +scroll.txt scroll.txt /*scroll.txt* +scrollbind-quickadj scroll.txt /*scrollbind-quickadj* +scrollbind-relative scroll.txt /*scrollbind-relative* +scrolling scroll.txt /*scrolling* +scrollstart-variable eval.txt /*scrollstart-variable* +sdl.vim syntax.txt /*sdl.vim* +search() eval.txt /*search()* +search()-sub-match eval.txt /*search()-sub-match* +search-commands pattern.txt /*search-commands* +search-offset pattern.txt /*search-offset* +search-pattern pattern.txt /*search-pattern* +search-range pattern.txt /*search-range* +search-replace change.txt /*search-replace* +searchdecl() eval.txt /*searchdecl()* +searchforward-variable eval.txt /*searchforward-variable* +searchpair() eval.txt /*searchpair()* +searchpairpos() eval.txt /*searchpairpos()* +searchpos() eval.txt /*searchpos()* +section motion.txt /*section* +sed.vim syntax.txt /*sed.vim* +self eval.txt /*self* +send-money sponsor.txt /*send-money* +send-to-menu gui_w32.txt /*send-to-menu* +sendto gui_w32.txt /*sendto* +sentence motion.txt /*sentence* +server-functions usr_41.txt /*server-functions* +server2client() eval.txt /*server2client()* +serverlist() eval.txt /*serverlist()* +servername-variable eval.txt /*servername-variable* +session-file starting.txt /*session-file* +set-option options.txt /*set-option* +set-spc-auto spell.txt /*set-spc-auto* +setbufvar() eval.txt /*setbufvar()* +setcmdpos() eval.txt /*setcmdpos()* +setline() eval.txt /*setline()* +setloclist() eval.txt /*setloclist()* +setmatches() eval.txt /*setmatches()* +setpos() eval.txt /*setpos()* +setqflist() eval.txt /*setqflist()* +setreg() eval.txt /*setreg()* +settabvar() eval.txt /*settabvar()* +settabwinvar() eval.txt /*settabwinvar()* +setting-guifont gui.txt /*setting-guifont* +setting-guitablabel tabpage.txt /*setting-guitablabel* +setting-tabline tabpage.txt /*setting-tabline* +setuid change.txt /*setuid* +setwinvar() eval.txt /*setwinvar()* +sftp pi_netrw.txt /*sftp* +sgml.vim syntax.txt /*sgml.vim* +sh.vim syntax.txt /*sh.vim* +shell-window tips.txt /*shell-window* +shell_error-variable eval.txt /*shell_error-variable* +shellescape() eval.txt /*shellescape()* +shift intro.txt /*shift* +shift-left-right change.txt /*shift-left-right* +short-name-changed version4.txt /*short-name-changed* +showing-menus gui.txt /*showing-menus* +sign-commands sign.txt /*sign-commands* +sign-intro sign.txt /*sign-intro* +sign-support sign.txt /*sign-support* +sign.txt sign.txt /*sign.txt* +signs sign.txt /*signs* +simple-change change.txt /*simple-change* +simplify() eval.txt /*simplify()* +simulated-command vi_diff.txt /*simulated-command* +sin() eval.txt /*sin()* +single-repeat repeat.txt /*single-repeat* +sinh() eval.txt /*sinh()* +skeleton autocmd.txt /*skeleton* +slice eval.txt /*slice* +slow-fast-terminal term.txt /*slow-fast-terminal* +slow-start starting.txt /*slow-start* +slow-terminal term.txt /*slow-terminal* +sniff if_sniff.txt /*sniff* +sniff-commands if_sniff.txt /*sniff-commands* +sniff-compiling if_sniff.txt /*sniff-compiling* +sniff-intro if_sniff.txt /*sniff-intro* +socket-interface netbeans.txt /*socket-interface* +sort() eval.txt /*sort()* +sorting change.txt /*sorting* +soundfold() eval.txt /*soundfold()* +space intro.txt /*space* +spec-customizing pi_spec.txt /*spec-customizing* +spec-how-to-use-it pi_spec.txt /*spec-how-to-use-it* +spec-setting-a-map pi_spec.txt /*spec-setting-a-map* +spec_chglog_format pi_spec.txt /*spec_chglog_format* +spec_chglog_prepend pi_spec.txt /*spec_chglog_prepend* +spec_chglog_release_info pi_spec.txt /*spec_chglog_release_info* +special-buffers windows.txt /*special-buffers* +speed-up tips.txt /*speed-up* +spell spell.txt /*spell* +spell-ACCENT spell.txt /*spell-ACCENT* +spell-AUTHOR spell.txt /*spell-AUTHOR* +spell-BAD spell.txt /*spell-BAD* +spell-BREAK spell.txt /*spell-BREAK* +spell-CHECKCOMPOUNDCASE spell.txt /*spell-CHECKCOMPOUNDCASE* +spell-CHECKCOMPOUNDDUP spell.txt /*spell-CHECKCOMPOUNDDUP* +spell-CHECKCOMPOUNDPATTERN spell.txt /*spell-CHECKCOMPOUNDPATTERN* +spell-CHECKCOMPOUNDREP spell.txt /*spell-CHECKCOMPOUNDREP* +spell-CHECKCOMPOUNDTRIPLE spell.txt /*spell-CHECKCOMPOUNDTRIPLE* +spell-CIRCUMFIX spell.txt /*spell-CIRCUMFIX* +spell-COMMON spell.txt /*spell-COMMON* +spell-COMPLEXPREFIXES spell.txt /*spell-COMPLEXPREFIXES* +spell-COMPOUND spell.txt /*spell-COMPOUND* +spell-COMPOUNDBEGIN spell.txt /*spell-COMPOUNDBEGIN* +spell-COMPOUNDEND spell.txt /*spell-COMPOUNDEND* +spell-COMPOUNDFIRST spell.txt /*spell-COMPOUNDFIRST* +spell-COMPOUNDFLAG spell.txt /*spell-COMPOUNDFLAG* +spell-COMPOUNDFORBIDFLAG spell.txt /*spell-COMPOUNDFORBIDFLAG* +spell-COMPOUNDMIDDLE spell.txt /*spell-COMPOUNDMIDDLE* +spell-COMPOUNDMIN spell.txt /*spell-COMPOUNDMIN* +spell-COMPOUNDPERMITFLAG spell.txt /*spell-COMPOUNDPERMITFLAG* +spell-COMPOUNDROOT spell.txt /*spell-COMPOUNDROOT* +spell-COMPOUNDRULE spell.txt /*spell-COMPOUNDRULE* +spell-COMPOUNDRULES spell.txt /*spell-COMPOUNDRULES* +spell-COMPOUNDSYLLABLE spell.txt /*spell-COMPOUNDSYLLABLE* +spell-COMPOUNDSYLMAX spell.txt /*spell-COMPOUNDSYLMAX* +spell-COMPOUNDWORDMAX spell.txt /*spell-COMPOUNDWORDMAX* +spell-COPYRIGHT spell.txt /*spell-COPYRIGHT* +spell-EMAIL spell.txt /*spell-EMAIL* +spell-FLAG spell.txt /*spell-FLAG* +spell-FOL spell.txt /*spell-FOL* +spell-FORBIDDENWORD spell.txt /*spell-FORBIDDENWORD* +spell-HOME spell.txt /*spell-HOME* +spell-KEEPCASE spell.txt /*spell-KEEPCASE* +spell-KEY spell.txt /*spell-KEY* +spell-LANG spell.txt /*spell-LANG* +spell-LEMMA_PRESENT spell.txt /*spell-LEMMA_PRESENT* +spell-LOW spell.txt /*spell-LOW* +spell-MAP spell.txt /*spell-MAP* +spell-MAXNGRAMSUGS spell.txt /*spell-MAXNGRAMSUGS* +spell-NAME spell.txt /*spell-NAME* +spell-NEEDAFFIX spell.txt /*spell-NEEDAFFIX* +spell-NEEDCOMPOUND spell.txt /*spell-NEEDCOMPOUND* +spell-NOBREAK spell.txt /*spell-NOBREAK* +spell-NOSPLITSUGS spell.txt /*spell-NOSPLITSUGS* +spell-NOSUGFILE spell.txt /*spell-NOSUGFILE* +spell-NOSUGGEST spell.txt /*spell-NOSUGGEST* +spell-ONLYINCOMPOUND spell.txt /*spell-ONLYINCOMPOUND* +spell-PFX spell.txt /*spell-PFX* +spell-PFXPOSTPONE spell.txt /*spell-PFXPOSTPONE* +spell-PSEUDOROOT spell.txt /*spell-PSEUDOROOT* +spell-RARE spell.txt /*spell-RARE* +spell-REP spell.txt /*spell-REP* +spell-SAL spell.txt /*spell-SAL* +spell-SET spell.txt /*spell-SET* +spell-SFX spell.txt /*spell-SFX* +spell-SLASH spell.txt /*spell-SLASH* +spell-SOFOFROM spell.txt /*spell-SOFOFROM* +spell-SOFOTO spell.txt /*spell-SOFOTO* +spell-SUGSWITHDOTS spell.txt /*spell-SUGSWITHDOTS* +spell-SYLLABLE spell.txt /*spell-SYLLABLE* +spell-SYLLABLENUM spell.txt /*spell-SYLLABLENUM* +spell-SpellFileMissing spell.txt /*spell-SpellFileMissing* +spell-TRY spell.txt /*spell-TRY* +spell-UPP spell.txt /*spell-UPP* +spell-VERSION spell.txt /*spell-VERSION* +spell-WORDCHARS spell.txt /*spell-WORDCHARS* +spell-aff-format spell.txt /*spell-aff-format* +spell-affix-chars spell.txt /*spell-affix-chars* +spell-affix-comment spell.txt /*spell-affix-comment* +spell-affix-flags spell.txt /*spell-affix-flags* +spell-affix-mbyte spell.txt /*spell-affix-mbyte* +spell-affix-not-supported spell.txt /*spell-affix-not-supported* +spell-affix-vim spell.txt /*spell-affix-vim* +spell-compound spell.txt /*spell-compound* +spell-dic-format spell.txt /*spell-dic-format* +spell-double-scoring spell.txt /*spell-double-scoring* +spell-file-format spell.txt /*spell-file-format* +spell-functions usr_41.txt /*spell-functions* +spell-german spell.txt /*spell-german* +spell-load spell.txt /*spell-load* +spell-midword spell.txt /*spell-midword* +spell-mkspell spell.txt /*spell-mkspell* +spell-quickstart spell.txt /*spell-quickstart* +spell-remarks spell.txt /*spell-remarks* +spell-russian spell.txt /*spell-russian* +spell-sug-file spell.txt /*spell-sug-file* +spell-syntax spell.txt /*spell-syntax* +spell-wordlist-format spell.txt /*spell-wordlist-format* +spell-yiddish spell.txt /*spell-yiddish* +spell.txt spell.txt /*spell.txt* +spellbadword() eval.txt /*spellbadword()* +spellfile-cleanup spell.txt /*spellfile-cleanup* +spellfile.vim spell.txt /*spellfile.vim* +spellsuggest() eval.txt /*spellsuggest()* +split() eval.txt /*split()* +splitfind windows.txt /*splitfind* +splitview windows.txt /*splitview* +sponsor sponsor.txt /*sponsor* +sponsor-faq sponsor.txt /*sponsor-faq* +sponsor.txt sponsor.txt /*sponsor.txt* +spoon os_unix.txt /*spoon* +spup.vim syntax.txt /*spup.vim* +sql-adding-dialects ft_sql.txt /*sql-adding-dialects* +sql-completion ft_sql.txt /*sql-completion* +sql-completion-columns ft_sql.txt /*sql-completion-columns* +sql-completion-customization ft_sql.txt /*sql-completion-customization* +sql-completion-dynamic ft_sql.txt /*sql-completion-dynamic* +sql-completion-filetypes ft_sql.txt /*sql-completion-filetypes* +sql-completion-maps ft_sql.txt /*sql-completion-maps* +sql-completion-procedures ft_sql.txt /*sql-completion-procedures* +sql-completion-static ft_sql.txt /*sql-completion-static* +sql-completion-tables ft_sql.txt /*sql-completion-tables* +sql-completion-tutorial ft_sql.txt /*sql-completion-tutorial* +sql-completion-views ft_sql.txt /*sql-completion-views* +sql-dialects ft_sql.txt /*sql-dialects* +sql-macros ft_sql.txt /*sql-macros* +sql-matchit ft_sql.txt /*sql-matchit* +sql-navigation ft_sql.txt /*sql-navigation* +sql-object-motions ft_sql.txt /*sql-object-motions* +sql-predefined-objects ft_sql.txt /*sql-predefined-objects* +sql-type-default ft_sql.txt /*sql-type-default* +sql-types ft_sql.txt /*sql-types* +sql.vim syntax.txt /*sql.vim* +sqlanywhere ft_sql.txt /*sqlanywhere* +sqlanywhere.vim syntax.txt /*sqlanywhere.vim* +sqlgettype ft_sql.txt /*sqlgettype* +sqlinformix.vim syntax.txt /*sqlinformix.vim* +sqlj ft_sql.txt /*sqlj* +sqlserver ft_sql.txt /*sqlserver* +sqlsettype ft_sql.txt /*sqlsettype* +sqrt() eval.txt /*sqrt()* +sscanf eval.txt /*sscanf* +standard-plugin usr_05.txt /*standard-plugin* +standard-plugin-list help.txt /*standard-plugin-list* +standout syntax.txt /*standout* +star pattern.txt /*star* +starstar editing.txt /*starstar* +starstar-wildcard editing.txt /*starstar-wildcard* +start-of-file pattern.txt /*start-of-file* +starting starting.txt /*starting* +starting-amiga starting.txt /*starting-amiga* +starting.txt starting.txt /*starting.txt* +startup starting.txt /*startup* +startup-options starting.txt /*startup-options* +startup-terminal term.txt /*startup-terminal* +static-tag tagsrch.txt /*static-tag* +status-line windows.txt /*status-line* +statusmsg-variable eval.txt /*statusmsg-variable* +sticky-type-checking eval.txt /*sticky-type-checking* +str2float() eval.txt /*str2float()* +str2nr() eval.txt /*str2nr()* +strcasestr() eval.txt /*strcasestr()* +strchars() eval.txt /*strchars()* +strchr() eval.txt /*strchr()* +strcspn() eval.txt /*strcspn()* +strdisplaywidth() eval.txt /*strdisplaywidth()* +strftime() eval.txt /*strftime()* +stridx() eval.txt /*stridx()* +string() eval.txt /*string()* +string-functions usr_41.txt /*string-functions* +string-match eval.txt /*string-match* +strlen() eval.txt /*strlen()* +strpart() eval.txt /*strpart()* +strpbrk() eval.txt /*strpbrk()* +strrchr() eval.txt /*strrchr()* +strridx() eval.txt /*strridx()* +strspn() eval.txt /*strspn()* +strstr() eval.txt /*strstr()* +strtrans() eval.txt /*strtrans()* +strwidth() eval.txt /*strwidth()* +style-changes develop.txt /*style-changes* +style-examples develop.txt /*style-examples* +style-functions develop.txt /*style-functions* +style-names develop.txt /*style-names* +style-spaces develop.txt /*style-spaces* +style-various develop.txt /*style-various* +sub-menu-priority gui.txt /*sub-menu-priority* +sub-replace-\= change.txt /*sub-replace-\\=* +sub-replace-expression change.txt /*sub-replace-expression* +sub-replace-special change.txt /*sub-replace-special* +sublist eval.txt /*sublist* +submatch() eval.txt /*submatch()* +subscribe-maillist intro.txt /*subscribe-maillist* +substitute() eval.txt /*substitute()* +substitute-CR version6.txt /*substitute-CR* +suffixes cmdline.txt /*suffixes* +suspend starting.txt /*suspend* +swap-exists-choices usr_11.txt /*swap-exists-choices* +swap-file recover.txt /*swap-file* +swapchoice-variable eval.txt /*swapchoice-variable* +swapcommand-variable eval.txt /*swapcommand-variable* +swapfile-changed version4.txt /*swapfile-changed* +swapname-variable eval.txt /*swapname-variable* +sybase ft_sql.txt /*sybase* +syn-sync-grouphere syntax.txt /*syn-sync-grouphere* +syn-sync-groupthere syntax.txt /*syn-sync-groupthere* +syn-sync-linecont syntax.txt /*syn-sync-linecont* +synID() eval.txt /*synID()* +synIDattr() eval.txt /*synIDattr()* +synIDtrans() eval.txt /*synIDtrans()* +syncbind scroll.txt /*syncbind* +syncolor syntax.txt /*syncolor* +synconcealed() eval.txt /*synconcealed()* +synload-1 syntax.txt /*synload-1* +synload-2 syntax.txt /*synload-2* +synload-3 syntax.txt /*synload-3* +synload-4 syntax.txt /*synload-4* +synload-5 syntax.txt /*synload-5* +synload-6 syntax.txt /*synload-6* +synstack() eval.txt /*synstack()* +syntax syntax.txt /*syntax* +syntax-functions usr_41.txt /*syntax-functions* +syntax-highlighting syntax.txt /*syntax-highlighting* +syntax-loading syntax.txt /*syntax-loading* +syntax-printing usr_06.txt /*syntax-printing* +syntax.txt syntax.txt /*syntax.txt* +syntax_cmd syntax.txt /*syntax_cmd* +sys-file-list help.txt /*sys-file-list* +sysmouse term.txt /*sysmouse* +system() eval.txt /*system()* +system-functions usr_41.txt /*system-functions* +system-vimrc starting.txt /*system-vimrc* +s~ change.txt /*s~* +t motion.txt /*t* +t:var eval.txt /*t:var* +t_#2 term.txt /*t_#2* +t_#4 term.txt /*t_#4* +t_%1 term.txt /*t_%1* +t_%i term.txt /*t_%i* +t_&8 term.txt /*t_&8* +t_@7 term.txt /*t_@7* +t_AB term.txt /*t_AB* +t_AF term.txt /*t_AF* +t_AL term.txt /*t_AL* +t_CS term.txt /*t_CS* +t_CV term.txt /*t_CV* +t_Ce term.txt /*t_Ce* +t_Co term.txt /*t_Co* +t_Cs term.txt /*t_Cs* +t_DL term.txt /*t_DL* +t_EI term.txt /*t_EI* +t_F1 term.txt /*t_F1* +t_F2 term.txt /*t_F2* +t_F3 term.txt /*t_F3* +t_F4 term.txt /*t_F4* +t_F5 term.txt /*t_F5* +t_F6 term.txt /*t_F6* +t_F7 term.txt /*t_F7* +t_F8 term.txt /*t_F8* +t_F9 term.txt /*t_F9* +t_IE term.txt /*t_IE* +t_IS term.txt /*t_IS* +t_K1 term.txt /*t_K1* +t_K3 term.txt /*t_K3* +t_K4 term.txt /*t_K4* +t_K5 term.txt /*t_K5* +t_K6 term.txt /*t_K6* +t_K7 term.txt /*t_K7* +t_K8 term.txt /*t_K8* +t_K9 term.txt /*t_K9* +t_KA term.txt /*t_KA* +t_KB term.txt /*t_KB* +t_KC term.txt /*t_KC* +t_KD term.txt /*t_KD* +t_KE term.txt /*t_KE* +t_KF term.txt /*t_KF* +t_KG term.txt /*t_KG* +t_KH term.txt /*t_KH* +t_KI term.txt /*t_KI* +t_KJ term.txt /*t_KJ* +t_KK term.txt /*t_KK* +t_KL term.txt /*t_KL* +t_RI term.txt /*t_RI* +t_RV term.txt /*t_RV* +t_SI term.txt /*t_SI* +t_Sb term.txt /*t_Sb* +t_Sf term.txt /*t_Sf* +t_WP term.txt /*t_WP* +t_WS term.txt /*t_WS* +t_ZH term.txt /*t_ZH* +t_ZR term.txt /*t_ZR* +t_al term.txt /*t_al* +t_bc term.txt /*t_bc* +t_cd term.txt /*t_cd* +t_cdl version4.txt /*t_cdl* +t_ce term.txt /*t_ce* +t_ci version4.txt /*t_ci* +t_cil version4.txt /*t_cil* +t_cl term.txt /*t_cl* +t_cm term.txt /*t_cm* +t_cri version4.txt /*t_cri* +t_cs term.txt /*t_cs* +t_csc version4.txt /*t_csc* +t_cv version4.txt /*t_cv* +t_cvv version4.txt /*t_cvv* +t_da term.txt /*t_da* +t_db term.txt /*t_db* +t_dl term.txt /*t_dl* +t_ed version4.txt /*t_ed* +t_el version4.txt /*t_el* +t_f1 version4.txt /*t_f1* +t_f10 version4.txt /*t_f10* +t_f2 version4.txt /*t_f2* +t_f3 version4.txt /*t_f3* +t_f4 version4.txt /*t_f4* +t_f5 version4.txt /*t_f5* +t_f6 version4.txt /*t_f6* +t_f7 version4.txt /*t_f7* +t_f8 version4.txt /*t_f8* +t_f9 version4.txt /*t_f9* +t_fs term.txt /*t_fs* +t_help version4.txt /*t_help* +t_il version4.txt /*t_il* +t_k1 term.txt /*t_k1* +t_k2 term.txt /*t_k2* +t_k3 term.txt /*t_k3* +t_k4 term.txt /*t_k4* +t_k5 term.txt /*t_k5* +t_k6 term.txt /*t_k6* +t_k7 term.txt /*t_k7* +t_k8 term.txt /*t_k8* +t_k9 term.txt /*t_k9* +t_k; term.txt /*t_k;* +t_kB term.txt /*t_kB* +t_kD term.txt /*t_kD* +t_kI term.txt /*t_kI* +t_kN term.txt /*t_kN* +t_kP term.txt /*t_kP* +t_kb term.txt /*t_kb* +t_kd term.txt /*t_kd* +t_ke term.txt /*t_ke* +t_kh term.txt /*t_kh* +t_kl term.txt /*t_kl* +t_kr term.txt /*t_kr* +t_ks term.txt /*t_ks* +t_ku term.txt /*t_ku* +t_le term.txt /*t_le* +t_mb term.txt /*t_mb* +t_md term.txt /*t_md* +t_me term.txt /*t_me* +t_mr term.txt /*t_mr* +t_ms term.txt /*t_ms* +t_nd term.txt /*t_nd* +t_op term.txt /*t_op* +t_se term.txt /*t_se* +t_sf1 version4.txt /*t_sf1* +t_sf10 version4.txt /*t_sf10* +t_sf2 version4.txt /*t_sf2* +t_sf3 version4.txt /*t_sf3* +t_sf4 version4.txt /*t_sf4* +t_sf5 version4.txt /*t_sf5* +t_sf6 version4.txt /*t_sf6* +t_sf7 version4.txt /*t_sf7* +t_sf8 version4.txt /*t_sf8* +t_sf9 version4.txt /*t_sf9* +t_skd version4.txt /*t_skd* +t_skl version4.txt /*t_skl* +t_skr version4.txt /*t_skr* +t_sku version4.txt /*t_sku* +t_so term.txt /*t_so* +t_sr term.txt /*t_sr* +t_star7 term.txt /*t_star7* +t_tb version4.txt /*t_tb* +t_te term.txt /*t_te* +t_ti term.txt /*t_ti* +t_tp version4.txt /*t_tp* +t_ts term.txt /*t_ts* +t_ts_old version4.txt /*t_ts_old* +t_ue term.txt /*t_ue* +t_undo version4.txt /*t_undo* +t_us term.txt /*t_us* +t_ut term.txt /*t_ut* +t_vb term.txt /*t_vb* +t_ve term.txt /*t_ve* +t_vi term.txt /*t_vi* +t_vs term.txt /*t_vs* +t_xs term.txt /*t_xs* +tab intro.txt /*tab* +tab-page tabpage.txt /*tab-page* +tab-page-commands tabpage.txt /*tab-page-commands* +tab-page-intro tabpage.txt /*tab-page-intro* +tab-page-other tabpage.txt /*tab-page-other* +tabline-menu tabpage.txt /*tabline-menu* +tabpage tabpage.txt /*tabpage* +tabpage-variable eval.txt /*tabpage-variable* +tabpage.txt tabpage.txt /*tabpage.txt* +tabpagebuflist() eval.txt /*tabpagebuflist()* +tabpagenr() eval.txt /*tabpagenr()* +tabpagewinnr() eval.txt /*tabpagewinnr()* +tag tagsrch.txt /*tag* +tag-! tagsrch.txt /*tag-!* +tag-any-white tagsrch.txt /*tag-any-white* +tag-binary-search tagsrch.txt /*tag-binary-search* +tag-blocks motion.txt /*tag-blocks* +tag-commands tagsrch.txt /*tag-commands* +tag-details tagsrch.txt /*tag-details* +tag-highlight syntax.txt /*tag-highlight* +tag-matchlist tagsrch.txt /*tag-matchlist* +tag-old-static tagsrch.txt /*tag-old-static* +tag-overloaded version5.txt /*tag-overloaded* +tag-preview tagsrch.txt /*tag-preview* +tag-priority tagsrch.txt /*tag-priority* +tag-regexp tagsrch.txt /*tag-regexp* +tag-search tagsrch.txt /*tag-search* +tag-security tagsrch.txt /*tag-security* +tag-skip-file tagsrch.txt /*tag-skip-file* +tag-stack tagsrch.txt /*tag-stack* +tagfiles() eval.txt /*tagfiles()* +taglist() eval.txt /*taglist()* +tags tagsrch.txt /*tags* +tags-and-searches tagsrch.txt /*tags-and-searches* +tags-file-changed version5.txt /*tags-file-changed* +tags-file-format tagsrch.txt /*tags-file-format* +tags-option tagsrch.txt /*tags-option* +tagsrch.txt tagsrch.txt /*tagsrch.txt* +tagstack tagsrch.txt /*tagstack* +tan() eval.txt /*tan()* +tanh() eval.txt /*tanh()* +tar pi_tar.txt /*tar* +tar-contents pi_tar.txt /*tar-contents* +tar-copyright pi_tar.txt /*tar-copyright* +tar-history pi_tar.txt /*tar-history* +tar-manual pi_tar.txt /*tar-manual* +tar-options pi_tar.txt /*tar-options* +tar-usage pi_tar.txt /*tar-usage* +tcl if_tcl.txt /*tcl* +tcl-beep if_tcl.txt /*tcl-beep* +tcl-buffer if_tcl.txt /*tcl-buffer* +tcl-buffer-append if_tcl.txt /*tcl-buffer-append* +tcl-buffer-cmds if_tcl.txt /*tcl-buffer-cmds* +tcl-buffer-command if_tcl.txt /*tcl-buffer-command* +tcl-buffer-count if_tcl.txt /*tcl-buffer-count* +tcl-buffer-delcmd if_tcl.txt /*tcl-buffer-delcmd* +tcl-buffer-delete if_tcl.txt /*tcl-buffer-delete* +tcl-buffer-expr if_tcl.txt /*tcl-buffer-expr* +tcl-buffer-get if_tcl.txt /*tcl-buffer-get* +tcl-buffer-insert if_tcl.txt /*tcl-buffer-insert* +tcl-buffer-last if_tcl.txt /*tcl-buffer-last* +tcl-buffer-mark if_tcl.txt /*tcl-buffer-mark* +tcl-buffer-option if_tcl.txt /*tcl-buffer-option* +tcl-buffer-set if_tcl.txt /*tcl-buffer-set* +tcl-buffer-windows if_tcl.txt /*tcl-buffer-windows* +tcl-bugs if_tcl.txt /*tcl-bugs* +tcl-command if_tcl.txt /*tcl-command* +tcl-commands if_tcl.txt /*tcl-commands* +tcl-dynamic if_tcl.txt /*tcl-dynamic* +tcl-ex-commands if_tcl.txt /*tcl-ex-commands* +tcl-examples if_tcl.txt /*tcl-examples* +tcl-expr if_tcl.txt /*tcl-expr* +tcl-linenumbers if_tcl.txt /*tcl-linenumbers* +tcl-misc if_tcl.txt /*tcl-misc* +tcl-option if_tcl.txt /*tcl-option* +tcl-output if_tcl.txt /*tcl-output* +tcl-var-current if_tcl.txt /*tcl-var-current* +tcl-var-lbase if_tcl.txt /*tcl-var-lbase* +tcl-var-line if_tcl.txt /*tcl-var-line* +tcl-var-lnum if_tcl.txt /*tcl-var-lnum* +tcl-var-range if_tcl.txt /*tcl-var-range* +tcl-variables if_tcl.txt /*tcl-variables* +tcl-window if_tcl.txt /*tcl-window* +tcl-window-buffer if_tcl.txt /*tcl-window-buffer* +tcl-window-cmds if_tcl.txt /*tcl-window-cmds* +tcl-window-command if_tcl.txt /*tcl-window-command* +tcl-window-cursor if_tcl.txt /*tcl-window-cursor* +tcl-window-delcmd if_tcl.txt /*tcl-window-delcmd* +tcl-window-expr if_tcl.txt /*tcl-window-expr* +tcl-window-height if_tcl.txt /*tcl-window-height* +tcl-window-option if_tcl.txt /*tcl-window-option* +tcsh-style cmdline.txt /*tcsh-style* +tcsh.vim syntax.txt /*tcsh.vim* +tear-off-menus gui.txt /*tear-off-menus* +telnet-CTRL-] tagsrch.txt /*telnet-CTRL-]* +temp-file-name eval.txt /*temp-file-name* +tempfile change.txt /*tempfile* +template autocmd.txt /*template* +tempname() eval.txt /*tempname()* +term-dependent-settings term.txt /*term-dependent-settings* +term-list syntax.txt /*term-list* +term.txt term.txt /*term.txt* +termcap term.txt /*termcap* +termcap-changed version4.txt /*termcap-changed* +termcap-colors term.txt /*termcap-colors* +termcap-cursor-color term.txt /*termcap-cursor-color* +termcap-cursor-shape term.txt /*termcap-cursor-shape* +termcap-options term.txt /*termcap-options* +termcap-title term.txt /*termcap-title* +terminal-colors os_unix.txt /*terminal-colors* +terminal-info term.txt /*terminal-info* +terminal-options term.txt /*terminal-options* +terminfo term.txt /*terminfo* +termresponse-variable eval.txt /*termresponse-variable* +tex-cchar syntax.txt /*tex-cchar* +tex-cole syntax.txt /*tex-cole* +tex-conceal syntax.txt /*tex-conceal* +tex-error syntax.txt /*tex-error* +tex-folding syntax.txt /*tex-folding* +tex-math syntax.txt /*tex-math* +tex-morecommands syntax.txt /*tex-morecommands* +tex-nospell syntax.txt /*tex-nospell* +tex-package syntax.txt /*tex-package* +tex-runon syntax.txt /*tex-runon* +tex-slow syntax.txt /*tex-slow* +tex-style syntax.txt /*tex-style* +tex-verb syntax.txt /*tex-verb* +tex.vim syntax.txt /*tex.vim* +text-functions usr_41.txt /*text-functions* +text-objects motion.txt /*text-objects* +text-objects-changed version5.txt /*text-objects-changed* +textlock eval.txt /*textlock* +tf.vim syntax.txt /*tf.vim* +this_session-variable eval.txt /*this_session-variable* +throw-catch eval.txt /*throw-catch* +throw-expression eval.txt /*throw-expression* +throw-from-catch eval.txt /*throw-from-catch* +throw-variables eval.txt /*throw-variables* +throwpoint-variable eval.txt /*throwpoint-variable* +time-functions usr_41.txt /*time-functions* +timestamp editing.txt /*timestamp* +timestamps editing.txt /*timestamps* +tips tips.txt /*tips* +tips.txt tips.txt /*tips.txt* +todo todo.txt /*todo* +todo.txt todo.txt /*todo.txt* +toggle options.txt /*toggle* +toggle-revins version4.txt /*toggle-revins* +tolower() eval.txt /*tolower()* +toolbar-icon gui.txt /*toolbar-icon* +toupper() eval.txt /*toupper()* +tr() eval.txt /*tr()* +trojan-horse starting.txt /*trojan-horse* +trunc() eval.txt /*trunc()* +try-conditionals eval.txt /*try-conditionals* +try-echoerr eval.txt /*try-echoerr* +try-finally eval.txt /*try-finally* +try-nested eval.txt /*try-nested* +try-nesting eval.txt /*try-nesting* +tutor usr_01.txt /*tutor* +twice if_cscop.txt /*twice* +type() eval.txt /*type()* +type-mistakes tips.txt /*type-mistakes* +typecorr-settings usr_41.txt /*typecorr-settings* +typecorr.txt usr_41.txt /*typecorr.txt* +u undo.txt /*u* +uganda uganda.txt /*uganda* +uganda.txt uganda.txt /*uganda.txt* +undercurl syntax.txt /*undercurl* +underline syntax.txt /*underline* +undo undo.txt /*undo* +undo-blocks undo.txt /*undo-blocks* +undo-branches undo.txt /*undo-branches* +undo-commands undo.txt /*undo-commands* +undo-persistence undo.txt /*undo-persistence* +undo-redo undo.txt /*undo-redo* +undo-remarks undo.txt /*undo-remarks* +undo-tree undo.txt /*undo-tree* +undo-two-ways undo.txt /*undo-two-ways* +undo.txt undo.txt /*undo.txt* +undo_ftplugin usr_41.txt /*undo_ftplugin* +undofile() eval.txt /*undofile()* +undotree() eval.txt /*undotree()* +unicode mbyte.txt /*unicode* +unix os_unix.txt /*unix* +unlisted-buffer windows.txt /*unlisted-buffer* +up-down-motions motion.txt /*up-down-motions* +uppercase change.txt /*uppercase* +use-cpo-save usr_41.txt /*use-cpo-save* +use-visual-cmds version4.txt /*use-visual-cmds* +useful-mappings tips.txt /*useful-mappings* +usenet intro.txt /*usenet* +user-cmd-ambiguous map.txt /*user-cmd-ambiguous* +user-commands map.txt /*user-commands* +user-functions eval.txt /*user-functions* +user-manual usr_toc.txt /*user-manual* +using-<Plug> usr_41.txt /*using-<Plug>* +using-menus gui.txt /*using-menus* +using-scripts repeat.txt /*using-scripts* +using-xxd tips.txt /*using-xxd* +using_CTRL-V map.txt /*using_CTRL-V* +usr_01.txt usr_01.txt /*usr_01.txt* +usr_02.txt usr_02.txt /*usr_02.txt* +usr_03.txt usr_03.txt /*usr_03.txt* +usr_04.txt usr_04.txt /*usr_04.txt* +usr_05.txt usr_05.txt /*usr_05.txt* +usr_06.txt usr_06.txt /*usr_06.txt* +usr_07.txt usr_07.txt /*usr_07.txt* +usr_08.txt usr_08.txt /*usr_08.txt* +usr_09.txt usr_09.txt /*usr_09.txt* +usr_10.txt usr_10.txt /*usr_10.txt* +usr_11.txt usr_11.txt /*usr_11.txt* +usr_12.txt usr_12.txt /*usr_12.txt* +usr_20.txt usr_20.txt /*usr_20.txt* +usr_21.txt usr_21.txt /*usr_21.txt* +usr_22.txt usr_22.txt /*usr_22.txt* +usr_23.txt usr_23.txt /*usr_23.txt* +usr_24.txt usr_24.txt /*usr_24.txt* +usr_25.txt usr_25.txt /*usr_25.txt* +usr_26.txt usr_26.txt /*usr_26.txt* +usr_27.txt usr_27.txt /*usr_27.txt* +usr_28.txt usr_28.txt /*usr_28.txt* +usr_29.txt usr_29.txt /*usr_29.txt* +usr_30.txt usr_30.txt /*usr_30.txt* +usr_31.txt usr_31.txt /*usr_31.txt* +usr_32.txt usr_32.txt /*usr_32.txt* +usr_40.txt usr_40.txt /*usr_40.txt* +usr_41.txt usr_41.txt /*usr_41.txt* +usr_42.txt usr_42.txt /*usr_42.txt* +usr_43.txt usr_43.txt /*usr_43.txt* +usr_44.txt usr_44.txt /*usr_44.txt* +usr_45.txt usr_45.txt /*usr_45.txt* +usr_90.txt usr_90.txt /*usr_90.txt* +usr_toc.txt usr_toc.txt /*usr_toc.txt* +utf-8 mbyte.txt /*utf-8* +utf-8-char-arg mbyte.txt /*utf-8-char-arg* +utf-8-in-xwindows mbyte.txt /*utf-8-in-xwindows* +utf-8-typing mbyte.txt /*utf-8-typing* +utf8 mbyte.txt /*utf8* +v visual.txt /*v* +v:beval_bufnr eval.txt /*v:beval_bufnr* +v:beval_col eval.txt /*v:beval_col* +v:beval_lnum eval.txt /*v:beval_lnum* +v:beval_text eval.txt /*v:beval_text* +v:beval_winnr eval.txt /*v:beval_winnr* +v:char eval.txt /*v:char* +v:charconvert_from eval.txt /*v:charconvert_from* +v:charconvert_to eval.txt /*v:charconvert_to* +v:cmdarg eval.txt /*v:cmdarg* +v:cmdbang eval.txt /*v:cmdbang* +v:count eval.txt /*v:count* +v:count1 eval.txt /*v:count1* +v:ctype eval.txt /*v:ctype* +v:dying eval.txt /*v:dying* +v:errmsg eval.txt /*v:errmsg* +v:exception eval.txt /*v:exception* +v:fcs_choice eval.txt /*v:fcs_choice* +v:fcs_reason eval.txt /*v:fcs_reason* +v:fname_diff eval.txt /*v:fname_diff* +v:fname_in eval.txt /*v:fname_in* +v:fname_new eval.txt /*v:fname_new* +v:fname_out eval.txt /*v:fname_out* +v:folddashes eval.txt /*v:folddashes* +v:foldend eval.txt /*v:foldend* +v:foldlevel eval.txt /*v:foldlevel* +v:foldstart eval.txt /*v:foldstart* +v:insertmode eval.txt /*v:insertmode* +v:key eval.txt /*v:key* +v:lang eval.txt /*v:lang* +v:lc_time eval.txt /*v:lc_time* +v:lnum eval.txt /*v:lnum* +v:mouse_col eval.txt /*v:mouse_col* +v:mouse_lnum eval.txt /*v:mouse_lnum* +v:mouse_win eval.txt /*v:mouse_win* +v:oldfiles eval.txt /*v:oldfiles* +v:operator eval.txt /*v:operator* +v:prevcount eval.txt /*v:prevcount* +v:profiling eval.txt /*v:profiling* +v:progname eval.txt /*v:progname* +v:register eval.txt /*v:register* +v:scrollstart eval.txt /*v:scrollstart* +v:searchforward eval.txt /*v:searchforward* +v:servername eval.txt /*v:servername* +v:shell_error eval.txt /*v:shell_error* +v:statusmsg eval.txt /*v:statusmsg* +v:swapchoice eval.txt /*v:swapchoice* +v:swapcommand eval.txt /*v:swapcommand* +v:swapname eval.txt /*v:swapname* +v:termresponse eval.txt /*v:termresponse* +v:this_session eval.txt /*v:this_session* +v:throwpoint eval.txt /*v:throwpoint* +v:val eval.txt /*v:val* +v:var eval.txt /*v:var* +v:version eval.txt /*v:version* +v:warningmsg eval.txt /*v:warningmsg* +v_! change.txt /*v_!* +v_$ visual.txt /*v_$* +v_: cmdline.txt /*v_:* +v_< change.txt /*v_<* +v_<BS> change.txt /*v_<BS>* +v_<Del> change.txt /*v_<Del>* +v_<Esc> visual.txt /*v_<Esc>* +v_= change.txt /*v_=* +v_> change.txt /*v_>* +v_C change.txt /*v_C* +v_CTRL-C visual.txt /*v_CTRL-C* +v_CTRL-G visual.txt /*v_CTRL-G* +v_CTRL-H change.txt /*v_CTRL-H* +v_CTRL-O visual.txt /*v_CTRL-O* +v_CTRL-V visual.txt /*v_CTRL-V* +v_CTRL-Z starting.txt /*v_CTRL-Z* +v_CTRL-\_CTRL-G intro.txt /*v_CTRL-\\_CTRL-G* +v_CTRL-\_CTRL-N intro.txt /*v_CTRL-\\_CTRL-N* +v_CTRL-] tagsrch.txt /*v_CTRL-]* +v_D change.txt /*v_D* +v_J change.txt /*v_J* +v_K various.txt /*v_K* +v_O visual.txt /*v_O* +v_P change.txt /*v_P* +v_R change.txt /*v_R* +v_S change.txt /*v_S* +v_U change.txt /*v_U* +v_V visual.txt /*v_V* +v_X change.txt /*v_X* +v_Y change.txt /*v_Y* +v_a motion.txt /*v_a* +v_a' motion.txt /*v_a'* +v_a( motion.txt /*v_a(* +v_a) motion.txt /*v_a)* +v_a< motion.txt /*v_a<* +v_a> motion.txt /*v_a>* +v_aB motion.txt /*v_aB* +v_aW motion.txt /*v_aW* +v_a[ motion.txt /*v_a[* +v_a] motion.txt /*v_a]* +v_a` motion.txt /*v_a`* +v_ab motion.txt /*v_ab* +v_ap motion.txt /*v_ap* +v_aquote motion.txt /*v_aquote* +v_as motion.txt /*v_as* +v_at motion.txt /*v_at* +v_aw motion.txt /*v_aw* +v_a{ motion.txt /*v_a{* +v_a} motion.txt /*v_a}* +v_b_< visual.txt /*v_b_<* +v_b_<_example visual.txt /*v_b_<_example* +v_b_> visual.txt /*v_b_>* +v_b_>_example visual.txt /*v_b_>_example* +v_b_A visual.txt /*v_b_A* +v_b_A_example visual.txt /*v_b_A_example* +v_b_C visual.txt /*v_b_C* +v_b_D change.txt /*v_b_D* +v_b_I visual.txt /*v_b_I* +v_b_I_example visual.txt /*v_b_I_example* +v_b_c visual.txt /*v_b_c* +v_b_r visual.txt /*v_b_r* +v_b_r_example visual.txt /*v_b_r_example* +v_c change.txt /*v_c* +v_d change.txt /*v_d* +v_g? change.txt /*v_g?* +v_gF editing.txt /*v_gF* +v_gJ change.txt /*v_gJ* +v_gV visual.txt /*v_gV* +v_g] tagsrch.txt /*v_g]* +v_g_CTRL-G editing.txt /*v_g_CTRL-G* +v_g_CTRL-] tagsrch.txt /*v_g_CTRL-]* +v_gf editing.txt /*v_gf* +v_gq change.txt /*v_gq* +v_gv visual.txt /*v_gv* +v_gw change.txt /*v_gw* +v_i motion.txt /*v_i* +v_i' motion.txt /*v_i'* +v_i( motion.txt /*v_i(* +v_i) motion.txt /*v_i)* +v_i< motion.txt /*v_i<* +v_i> motion.txt /*v_i>* +v_iB motion.txt /*v_iB* +v_iW motion.txt /*v_iW* +v_i[ motion.txt /*v_i[* +v_i] motion.txt /*v_i]* +v_i` motion.txt /*v_i`* +v_ib motion.txt /*v_ib* +v_ip motion.txt /*v_ip* +v_iquote motion.txt /*v_iquote* +v_is motion.txt /*v_is* +v_it motion.txt /*v_it* +v_iw motion.txt /*v_iw* +v_i{ motion.txt /*v_i{* +v_i} motion.txt /*v_i}* +v_o visual.txt /*v_o* +v_p change.txt /*v_p* +v_r change.txt /*v_r* +v_s change.txt /*v_s* +v_u change.txt /*v_u* +v_v visual.txt /*v_v* +v_x change.txt /*v_x* +v_y change.txt /*v_y* +v_~ change.txt /*v_~* +val-variable eval.txt /*val-variable* +valgrind debug.txt /*valgrind* +values() eval.txt /*values()* +var-functions usr_41.txt /*var-functions* +variables eval.txt /*variables* +various various.txt /*various* +various-cmds various.txt /*various-cmds* +various-functions usr_41.txt /*various-functions* +various-motions motion.txt /*various-motions* +various.txt various.txt /*various.txt* +vb.vim syntax.txt /*vb.vim* +vba pi_vimball.txt /*vba* +verbose starting.txt /*verbose* +version-5.1 version5.txt /*version-5.1* +version-5.2 version5.txt /*version-5.2* +version-5.3 version5.txt /*version-5.3* +version-5.4 version5.txt /*version-5.4* +version-5.5 version5.txt /*version-5.5* +version-5.6 version5.txt /*version-5.6* +version-5.7 version5.txt /*version-5.7* +version-5.8 version5.txt /*version-5.8* +version-6.1 version6.txt /*version-6.1* +version-6.2 version6.txt /*version-6.2* +version-6.3 version6.txt /*version-6.3* +version-6.4 version6.txt /*version-6.4* +version-7.0 version7.txt /*version-7.0* +version-7.1 version7.txt /*version-7.1* +version-7.2 version7.txt /*version-7.2* +version-7.3 version7.txt /*version-7.3* +version-variable eval.txt /*version-variable* +version4.txt version4.txt /*version4.txt* +version5.txt version5.txt /*version5.txt* +version6.txt version6.txt /*version6.txt* +version7.0 version7.txt /*version7.0* +version7.1 version7.txt /*version7.1* +version7.2 version7.txt /*version7.2* +version7.3 version7.txt /*version7.3* +version7.txt version7.txt /*version7.txt* +vi intro.txt /*vi* +vi-differences vi_diff.txt /*vi-differences* +vi: options.txt /*vi:* +vi_diff.txt vi_diff.txt /*vi_diff.txt* +view starting.txt /*view* +view-diffs diff.txt /*view-diffs* +view-file starting.txt /*view-file* +views-sessions starting.txt /*views-sessions* +vim-additions vi_diff.txt /*vim-additions* +vim-announce intro.txt /*vim-announce* +vim-arguments starting.txt /*vim-arguments* +vim-default-editor gui_w32.txt /*vim-default-editor* +vim-dev intro.txt /*vim-dev* +vim-mac intro.txt /*vim-mac* +vim-modes intro.txt /*vim-modes* +vim-modes-intro intro.txt /*vim-modes-intro* +vim-multibyte intro.txt /*vim-multibyte* +vim-script-intro usr_41.txt /*vim-script-intro* +vim-variable eval.txt /*vim-variable* +vim.vim syntax.txt /*vim.vim* +vim7 version7.txt /*vim7* +vim: options.txt /*vim:* +vimball pi_vimball.txt /*vimball* +vimball-contents pi_vimball.txt /*vimball-contents* +vimball-extract pi_vimball.txt /*vimball-extract* +vimball-history pi_vimball.txt /*vimball-history* +vimball-intro pi_vimball.txt /*vimball-intro* +vimball-manual pi_vimball.txt /*vimball-manual* +vimball-windows pi_vimball.txt /*vimball-windows* +vimdev intro.txt /*vimdev* +vimdiff diff.txt /*vimdiff* +vimfiles options.txt /*vimfiles* +viminfo starting.txt /*viminfo* +viminfo-encoding starting.txt /*viminfo-encoding* +viminfo-errors starting.txt /*viminfo-errors* +viminfo-file starting.txt /*viminfo-file* +viminfo-file-marks starting.txt /*viminfo-file-marks* +viminfo-file-name starting.txt /*viminfo-file-name* +viminfo-read starting.txt /*viminfo-read* +viminfo-read-write starting.txt /*viminfo-read-write* +viminfo-write starting.txt /*viminfo-write* +vimrc starting.txt /*vimrc* +vimrc-filetype usr_05.txt /*vimrc-filetype* +vimrc-intro usr_05.txt /*vimrc-intro* +vimrc-option-example starting.txt /*vimrc-option-example* +vimrc_example.vim usr_05.txt /*vimrc_example.vim* +vimtutor usr_01.txt /*vimtutor* +virtcol() eval.txt /*virtcol()* +visual-block visual.txt /*visual-block* +visual-change visual.txt /*visual-change* +visual-examples visual.txt /*visual-examples* +visual-index index.txt /*visual-index* +visual-mode visual.txt /*visual-mode* +visual-operators visual.txt /*visual-operators* +visual-repeat visual.txt /*visual-repeat* +visual-search visual.txt /*visual-search* +visual-start visual.txt /*visual-start* +visual-use visual.txt /*visual-use* +visual.txt visual.txt /*visual.txt* +visualmode() eval.txt /*visualmode()* +vms os_vms.txt /*vms* +vms-authors os_vms.txt /*vms-authors* +vms-changes os_vms.txt /*vms-changes* +vms-compiling os_vms.txt /*vms-compiling* +vms-deploy os_vms.txt /*vms-deploy* +vms-download os_vms.txt /*vms-download* +vms-gui os_vms.txt /*vms-gui* +vms-notes os_vms.txt /*vms-notes* +vms-problems os_vms.txt /*vms-problems* +vms-started os_vms.txt /*vms-started* +vms-usage os_vms.txt /*vms-usage* +vote-for-features sponsor.txt /*vote-for-features* +votes-counted sponsor.txt /*votes-counted* +votes-for-changes todo.txt /*votes-for-changes* +vreplace-mode insert.txt /*vreplace-mode* +vt100-cursor-keys term.txt /*vt100-cursor-keys* +vt100-function-keys term.txt /*vt100-function-keys* +w motion.txt /*w* +w32-clientserver remote.txt /*w32-clientserver* +w:current_syntax syntax.txt /*w:current_syntax* +w:quickfix_title quickfix.txt /*w:quickfix_title* +w:var eval.txt /*w:var* +warningmsg-variable eval.txt /*warningmsg-variable* +white-space pattern.txt /*white-space* +whitespace pattern.txt /*whitespace* +wildcard editing.txt /*wildcard* +wildcards editing.txt /*wildcards* +win16-!start gui_w16.txt /*win16-!start* +win16-clipboard gui_w16.txt /*win16-clipboard* +win16-colors gui_w16.txt /*win16-colors* +win16-default-editor gui_w16.txt /*win16-default-editor* +win16-dialogs gui_w16.txt /*win16-dialogs* +win16-drag-n-drop gui_w16.txt /*win16-drag-n-drop* +win16-gui gui_w16.txt /*win16-gui* +win16-maximized gui_w16.txt /*win16-maximized* +win16-printing gui_w16.txt /*win16-printing* +win16-shell gui_w16.txt /*win16-shell* +win16-start gui_w16.txt /*win16-start* +win16-truetype gui_w16.txt /*win16-truetype* +win16-various gui_w16.txt /*win16-various* +win32 os_win32.txt /*win32* +win32-!start gui_w32.txt /*win32-!start* +win32-PATH os_win32.txt /*win32-PATH* +win32-colors gui_w32.txt /*win32-colors* +win32-compiling os_win32.txt /*win32-compiling* +win32-curdir os_win32.txt /*win32-curdir* +win32-faq os_win32.txt /*win32-faq* +win32-gettext mlang.txt /*win32-gettext* +win32-gui gui_w32.txt /*win32-gui* +win32-hidden-menus gui.txt /*win32-hidden-menus* +win32-mouse os_win32.txt /*win32-mouse* +win32-open-with-menu gui_w32.txt /*win32-open-with-menu* +win32-popup-menu gui_w32.txt /*win32-popup-menu* +win32-problems os_win32.txt /*win32-problems* +win32-restore os_win32.txt /*win32-restore* +win32-startup os_win32.txt /*win32-startup* +win32-term os_win32.txt /*win32-term* +win32-vimrun gui_w32.txt /*win32-vimrun* +win32-win3.1 os_win32.txt /*win32-win3.1* +win32s os_win32.txt /*win32s* +winbufnr() eval.txt /*winbufnr()* +wincol() eval.txt /*wincol()* +window windows.txt /*window* +window-contents intro.txt /*window-contents* +window-exit editing.txt /*window-exit* +window-functions usr_41.txt /*window-functions* +window-move-cursor windows.txt /*window-move-cursor* +window-moving windows.txt /*window-moving* +window-resize windows.txt /*window-resize* +window-size term.txt /*window-size* +window-size-functions usr_41.txt /*window-size-functions* +window-tag windows.txt /*window-tag* +window-variable eval.txt /*window-variable* +windows windows.txt /*windows* +windows-3.1 os_win32.txt /*windows-3.1* +windows-intro windows.txt /*windows-intro* +windows-starting windows.txt /*windows-starting* +windows.txt windows.txt /*windows.txt* +windows95 os_win32.txt /*windows95* +winheight() eval.txt /*winheight()* +winline() eval.txt /*winline()* +winnr() eval.txt /*winnr()* +winrestcmd() eval.txt /*winrestcmd()* +winrestview() eval.txt /*winrestview()* +winsaveview() eval.txt /*winsaveview()* +winwidth() eval.txt /*winwidth()* +word motion.txt /*word* +word-count editing.txt /*word-count* +word-motions motion.txt /*word-motions* +workbench starting.txt /*workbench* +workshop workshop.txt /*workshop* +workshop-commands workshop.txt /*workshop-commands* +workshop-compiling workshop.txt /*workshop-compiling* +workshop-configure workshop.txt /*workshop-configure* +workshop-intro workshop.txt /*workshop-intro* +workshop-support workshop.txt /*workshop-support* +workshop-xpm workshop.txt /*workshop-xpm* +workshop.txt workshop.txt /*workshop.txt* +wrap-off intro.txt /*wrap-off* +write-compiler-plugin usr_41.txt /*write-compiler-plugin* +write-device editing.txt /*write-device* +write-fail editing.txt /*write-fail* +write-filetype-plugin usr_41.txt /*write-filetype-plugin* +write-library-script usr_41.txt /*write-library-script* +write-local-help usr_41.txt /*write-local-help* +write-plugin usr_41.txt /*write-plugin* +write-plugin-quickload usr_41.txt /*write-plugin-quickload* +write-quit editing.txt /*write-quit* +write-readonly editing.txt /*write-readonly* +writefile() eval.txt /*writefile()* +writing editing.txt /*writing* +www intro.txt /*www* +x change.txt /*x* +x-input-method mbyte.txt /*x-input-method* +x-resources version5.txt /*x-resources* +x11-clientserver remote.txt /*x11-clientserver* +x11-cut-buffer gui_x11.txt /*x11-cut-buffer* +x11-selection gui_x11.txt /*x11-selection* +xf86conf.vim syntax.txt /*xf86conf.vim* +xfontset mbyte.txt /*xfontset* +xfree-xterm syntax.txt /*xfree-xterm* +xim mbyte.txt /*xim* +xim-input-style mbyte.txt /*xim-input-style* +xiterm syntax.txt /*xiterm* +xml-folding syntax.txt /*xml-folding* +xml-omni-datafile insert.txt /*xml-omni-datafile* +xml.vim syntax.txt /*xml.vim* +xpm.vim syntax.txt /*xpm.vim* +xterm-8-bit term.txt /*xterm-8-bit* +xterm-8bit term.txt /*xterm-8bit* +xterm-blink syntax.txt /*xterm-blink* +xterm-blinking-cursor syntax.txt /*xterm-blinking-cursor* +xterm-clipboard term.txt /*xterm-clipboard* +xterm-codes term.txt /*xterm-codes* +xterm-color syntax.txt /*xterm-color* +xterm-command-server term.txt /*xterm-command-server* +xterm-copy-paste term.txt /*xterm-copy-paste* +xterm-cursor-keys term.txt /*xterm-cursor-keys* +xterm-end-home-keys term.txt /*xterm-end-home-keys* +xterm-function-keys term.txt /*xterm-function-keys* +xterm-modifier-keys term.txt /*xterm-modifier-keys* +xterm-mouse options.txt /*xterm-mouse* +xterm-mouse-wheel scroll.txt /*xterm-mouse-wheel* +xterm-resize term.txt /*xterm-resize* +xterm-save-screen tips.txt /*xterm-save-screen* +xterm-screens tips.txt /*xterm-screens* +xterm-scroll-region term.txt /*xterm-scroll-region* +xterm-shifted-keys term.txt /*xterm-shifted-keys* +y change.txt /*y* +yank change.txt /*yank* +ye-option-gone version4.txt /*ye-option-gone* +year-2000 intro.txt /*year-2000* +your-runtime-dir usr_43.txt /*your-runtime-dir* +yy change.txt /*yy* +z index.txt /*z* +z+ scroll.txt /*z+* +z- scroll.txt /*z-* +z. scroll.txt /*z.* +z/OS os_390.txt /*z\/OS* +z<CR> scroll.txt /*z<CR>* +z<Left> scroll.txt /*z<Left>* +z<Right> scroll.txt /*z<Right>* +z= spell.txt /*z=* +zA fold.txt /*zA* +zC fold.txt /*zC* +zD fold.txt /*zD* +zE fold.txt /*zE* +zF fold.txt /*zF* +zG spell.txt /*zG* +zH scroll.txt /*zH* +zL scroll.txt /*zL* +zM fold.txt /*zM* +zN fold.txt /*zN* +zN<CR> scroll.txt /*zN<CR>* +zO fold.txt /*zO* +zOS os_390.txt /*zOS* +zOS-Bugs os_390.txt /*zOS-Bugs* +zOS-Motif os_390.txt /*zOS-Motif* +zOS-PuTTY os_390.txt /*zOS-PuTTY* +zOS-has-ebcdic os_390.txt /*zOS-has-ebcdic* +zOS-limitations os_390.txt /*zOS-limitations* +zOS-open-source os_390.txt /*zOS-open-source* +zR fold.txt /*zR* +zW spell.txt /*zW* +zX fold.txt /*zX* +z^ scroll.txt /*z^* +za fold.txt /*za* +zb scroll.txt /*zb* +zc fold.txt /*zc* +zd fold.txt /*zd* +ze scroll.txt /*ze* +zf fold.txt /*zf* +zg spell.txt /*zg* +zh scroll.txt /*zh* +zi fold.txt /*zi* +zip pi_zip.txt /*zip* +zip-contents pi_zip.txt /*zip-contents* +zip-copyright pi_zip.txt /*zip-copyright* +zip-extension pi_zip.txt /*zip-extension* +zip-history pi_zip.txt /*zip-history* +zip-manual pi_zip.txt /*zip-manual* +zip-usage pi_zip.txt /*zip-usage* +zj fold.txt /*zj* +zk fold.txt /*zk* +zl scroll.txt /*zl* +zm fold.txt /*zm* +zn fold.txt /*zn* +zo fold.txt /*zo* +zr fold.txt /*zr* +zs scroll.txt /*zs* +zt scroll.txt /*zt* +zuG spell.txt /*zuG* +zuW spell.txt /*zuW* +zug spell.txt /*zug* +zuw spell.txt /*zuw* +zv fold.txt /*zv* +zw spell.txt /*zw* +zx fold.txt /*zx* +zz scroll.txt /*zz* +{ motion.txt /*{* +{Visual} intro.txt /*{Visual}* +{address} cmdline.txt /*{address}* +{arglist} editing.txt /*{arglist}* +{char1-char2} intro.txt /*{char1-char2}* +{event} autocmd.txt /*{event}* +{file} editing.txt /*{file}* +{group-name} syntax.txt /*{group-name}* +{lhs} map.txt /*{lhs}* +{motion} intro.txt /*{motion}* +{move-around} visual.txt /*{move-around}* +{offset} pattern.txt /*{offset}* +{pat} autocmd.txt /*{pat}* +{rhs} map.txt /*{rhs}* +{subject} helphelp.txt /*{subject}* +{} intro.txt /*{}* +} motion.txt /*}* +~ change.txt /*~* diff --git a/share/vim/vim73/doc/tagsrch.txt b/share/vim/vim73/doc/tagsrch.txt new file mode 100644 index 0000000000..70c6c68a4f --- /dev/null +++ b/share/vim/vim73/doc/tagsrch.txt @@ -0,0 +1,837 @@ +*tagsrch.txt* For Vim version 7.3. Last change: 2009 Feb 18 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + +Tags and special searches *tags-and-searches* + +See section |29.1| of the user manual for an introduction. + +1. Jump to a tag |tag-commands| +2. Tag stack |tag-stack| +3. Tag match list |tag-matchlist| +4. Tags details |tag-details| +5. Tags file format |tags-file-format| +6. Include file searches |include-search| + +============================================================================== +1. Jump to a tag *tag-commands* + + *tag* *tags* +A tag is an identifier that appears in a "tags" file. It is a sort of label +that can be jumped to. For example: In C programs each function name can be +used as a tag. The "tags" file has to be generated by a program like ctags, +before the tag commands can be used. + +With the ":tag" command the cursor will be positioned on the tag. With the +CTRL-] command, the keyword on which the cursor is standing is used as the +tag. If the cursor is not on a keyword, the first keyword to the right of the +cursor is used. + +The ":tag" command works very well for C programs. If you see a call to a +function and wonder what that function does, position the cursor inside of the +function name and hit CTRL-]. This will bring you to the function definition. +An easy way back is with the CTRL-T command. Also read about the tag stack +below. + + *:ta* *:tag* *E426* *E429* +:[count]ta[g][!] {ident} + Jump to the definition of {ident}, using the + information in the tags file(s). Put {ident} in the + tag stack. See |tag-!| for [!]. + {ident} can be a regexp pattern, see |tag-regexp|. + When there are several matching tags for {ident}, jump + to the [count] one. When [count] is omitted the + first one is jumped to. See |tag-matchlist| for + jumping to other matching tags. + +g<LeftMouse> *g<LeftMouse>* +<C-LeftMouse> *<C-LeftMouse>* *CTRL-]* +CTRL-] Jump to the definition of the keyword under the + cursor. Same as ":tag {ident}", where {ident} is the + keyword under or after cursor. + When there are several matching tags for {ident}, jump + to the [count] one. When no [count] is given the + first one is jumped to. See |tag-matchlist| for + jumping to other matching tags. + {Vi: identifier after the cursor} + + *v_CTRL-]* +{Visual}CTRL-] Same as ":tag {ident}", where {ident} is the text that + is highlighted. {not in Vi} + + *telnet-CTRL-]* +CTRL-] is the default telnet escape key. When you type CTRL-] to jump to a +tag, you will get the telnet prompt instead. Most versions of telnet allow +changing or disabling the default escape key. See the telnet man page. You +can 'telnet -E {Hostname}' to disable the escape character, or 'telnet -e +{EscapeCharacter} {Hostname}' to specify another escape character. If +possible, try to use "ssh" instead of "telnet" to avoid this problem. + + *tag-priority* +When there are multiple matches for a tag, this priority is used: +1. "FSC" A full matching static tag for the current file. +2. "F C" A full matching global tag for the current file. +3. "F " A full matching global tag for another file. +4. "FS " A full matching static tag for another file. +5. " SC" An ignore-case matching static tag for the current file. +6. " C" An ignore-case matching global tag for the current file. +7. " " An ignore-case matching global tag for another file. +8. " S " An ignore-case matching static tag for another file. + +Note that when the current file changes, the priority list is mostly not +changed, to avoid confusion when using ":tnext". It is changed when using +":tag {ident}". + +The ignore-case matches are not found for a ":tag" command when the +'ignorecase' option is off. They are found when a pattern is used (starting +with a "/") and for ":tselect", also when 'ignorecase' is off. Note that +using ignore-case tag searching disables binary searching in the tags file, +which causes a slowdown. This can be avoided by fold-case sorting the tag +file. See the 'tagbsearch' option for an explanation. + +============================================================================== +2. Tag stack *tag-stack* *tagstack* *E425* + +On the tag stack is remembered which tags you jumped to, and from where. +Tags are only pushed onto the stack when the 'tagstack' option is set. + +g<RightMouse> *g<RightMouse>* +<C-RightMouse> *<C-RightMouse>* *CTRL-T* +CTRL-T Jump to [count] older entry in the tag stack + (default 1). {not in Vi} + + *:po* *:pop* *E555* *E556* +:[count]po[p][!] Jump to [count] older entry in tag stack (default 1). + See |tag-!| for [!]. {not in Vi} + +:[count]ta[g][!] Jump to [count] newer entry in tag stack (default 1). + See |tag-!| for [!]. {not in Vi} + + *:tags* +:tags Show the contents of the tag stack. The active + entry is marked with a '>'. {not in Vi} + +The output of ":tags" looks like this: + + # TO tag FROM line in file/line + 1 1 main 1 harddisk2:text/vim/test + > 2 2 FuncA 58 i = FuncA(10); + 3 1 FuncC 357 harddisk2:text/vim/src/amiga.c + +This list shows the tags that you jumped to and the cursor position before +that jump. The older tags are at the top, the newer at the bottom. + +The '>' points to the active entry. This is the tag that will be used by the +next ":tag" command. The CTRL-T and ":pop" command will use the position +above the active entry. + +Below the "TO" is the number of the current match in the match list. Note +that this doesn't change when using ":pop" or ":tag". + +The line number and file name are remembered to be able to get back to where +you were before the tag command. The line number will be correct, also when +deleting/inserting lines, unless this was done by another program (e.g. +another instance of Vim). + +For the current file, the "file/line" column shows the text at the position. +An indent is removed and a long line is truncated to fit in the window. + +You can jump to previously used tags with several commands. Some examples: + + ":pop" or CTRL-T to position before previous tag + {count}CTRL-T to position before {count} older tag + ":tag" to newer tag + ":0tag" to last used tag + +The most obvious way to use this is while browsing through the call graph of +a program. Consider the following call graph: + + main ---> FuncA ---> FuncC + ---> FuncB + +(Explanation: main calls FuncA and FuncB; FuncA calls FuncC). +You can get from main to FuncA by using CTRL-] on the call to FuncA. Then +you can CTRL-] to get to FuncC. If you now want to go back to main you can +use CTRL-T twice. Then you can CTRL-] to FuncB. + +If you issue a ":ta {ident}" or CTRL-] command, this tag is inserted at the +current position in the stack. If the stack was full (it can hold up to 20 +entries), the oldest entry is deleted and the older entries shift one +position up (their index number is decremented by one). If the last used +entry was not at the bottom, the entries below the last used one are +deleted. This means that an old branch in the call graph is lost. After the +commands explained above the tag stack will look like this: + + # TO tag FROM line in file + 1 main 1 harddisk2:text/vim/test + 2 FuncB 59 harddisk2:text/vim/src/main.c + + *E73* +When you try to use the tag stack while it doesn't contain anything you will +get an error message. + +============================================================================== +3. Tag match list *tag-matchlist* *E427* *E428* + +When there are several matching tags, these commands can be used to jump +between them. Note that these commands don't change the tag stack, they keep +the same entry. + + *:ts* *:tselect* +:ts[elect][!] [ident] List the tags that match [ident], using the + information in the tags file(s). + When [ident] is not given, the last tag name from the + tag stack is used. + With a '>' in the first column is indicated which is + the current position in the list (if there is one). + [ident] can be a regexp pattern, see |tag-regexp|. + See |tag-priority| for the priorities used in the + listing. {not in Vi} + Example output: + +> + nr pri kind tag file + 1 F f mch_delay os_amiga.c + mch_delay(msec, ignoreinput) + > 2 F f mch_delay os_msdos.c + mch_delay(msec, ignoreinput) + 3 F f mch_delay os_unix.c + mch_delay(msec, ignoreinput) + Enter nr of choice (<CR> to abort): +< + See |tag-priority| for the "pri" column. Note that + this depends on the current file, thus using + ":tselect xxx" can produce different results. + The "kind" column gives the kind of tag, if this was + included in the tags file. + The "info" column shows information that could be + found in the tags file. It depends on the program + that produced the tags file. + When the list is long, you may get the |more-prompt|. + If you already see the tag you want to use, you can + type 'q' and enter the number. + + *:sts* *:stselect* +:sts[elect][!] [ident] Does ":tselect[!] [ident]" and splits the window for + the selected tag. {not in Vi} + + *g]* +g] Like CTRL-], but use ":tselect" instead of ":tag". + {not in Vi} + + *v_g]* +{Visual}g] Same as "g]", but use the highlighted text as the + identifier. {not in Vi} + + *:tj* *:tjump* +:tj[ump][!] [ident] Like ":tselect", but jump to the tag directly when + there is only one match. {not in Vi} + + *:stj* *:stjump* +:stj[ump][!] [ident] Does ":tjump[!] [ident]" and splits the window for the + selected tag. {not in Vi} + + *g_CTRL-]* +g CTRL-] Like CTRL-], but use ":tjump" instead of ":tag". + {not in Vi} + + *v_g_CTRL-]* +{Visual}g CTRL-] Same as "g CTRL-]", but use the highlighted text as + the identifier. {not in Vi} + + *:tn* *:tnext* +:[count]tn[ext][!] Jump to [count] next matching tag (default 1). See + |tag-!| for [!]. {not in Vi} + + *:tp* *:tprevious* +:[count]tp[revious][!] Jump to [count] previous matching tag (default 1). + See |tag-!| for [!]. {not in Vi} + + *:tN* *:tNext* +:[count]tN[ext][!] Same as ":tprevious". {not in Vi} + + *:tr* *:trewind* +:[count]tr[ewind][!] Jump to first matching tag. If [count] is given, jump + to [count]th matching tag. See |tag-!| for [!]. {not + in Vi} + + *:tf* *:tfirst* +:[count]tf[irst][!] Same as ":trewind". {not in Vi} + + *:tl* *:tlast* +:tl[ast][!] Jump to last matching tag. See |tag-!| for [!]. {not + in Vi} + + *:lt* *:ltag* +:lt[ag][!] [ident] Jump to tag [ident] and add the matching tags to a new + location list for the current window. [ident] can be + a regexp pattern, see |tag-regexp|. When [ident] is + not given, the last tag name from the tag stack is + used. The search pattern to locate the tag line is + prefixed with "\V" to escape all the special + characters (very nomagic). The location list showing + the matching tags is independent of the tag stack. + See |tag-!| for [!]. + {not in Vi} + +When there is no other message, Vim shows which matching tag has been jumped +to, and the number of matching tags: > + tag 1 of 3 or more +The " or more" is used to indicate that Vim didn't try all the tags files yet. +When using ":tnext" a few times, or with ":tlast", more matches may be found. + +When you didn't see this message because of some other message, or you just +want to know where you are, this command will show it again (and jump to the +same tag as last time): > + :0tn +< + *tag-skip-file* +When a matching tag is found for which the file doesn't exist, this match is +skipped and the next matching tag is used. Vim reports this, to notify you of +missing files. When the end of the list of matches has been reached, an error +message is given. + + *tag-preview* +The tag match list can also be used in the preview window. The commands are +the same as above, with a "p" prepended. +{not available when compiled without the |+quickfix| feature} + + *:pts* *:ptselect* +:pts[elect][!] [ident] Does ":tselect[!] [ident]" and shows the new tag in a + "Preview" window. See |:ptag| for more info. + {not in Vi} + + *:ptj* *:ptjump* +:ptj[ump][!] [ident] Does ":tjump[!] [ident]" and shows the new tag in a + "Preview" window. See |:ptag| for more info. + {not in Vi} + + *:ptn* *:ptnext* +:[count]ptn[ext][!] ":tnext" in the preview window. See |:ptag|. + {not in Vi} + + *:ptp* *:ptprevious* +:[count]ptp[revious][!] ":tprevious" in the preview window. See |:ptag|. + {not in Vi} + + *:ptN* *:ptNext* +:[count]ptN[ext][!] Same as ":ptprevious". {not in Vi} + + *:ptr* *:ptrewind* +:[count]ptr[ewind][!] ":trewind" in the preview window. See |:ptag|. + {not in Vi} + + *:ptf* *:ptfirst* +:[count]ptf[irst][!] Same as ":ptrewind". {not in Vi} + + *:ptl* *:ptlast* +:ptl[ast][!] ":tlast" in the preview window. See |:ptag|. + {not in Vi} + +============================================================================== +4. Tags details *tag-details* + + *static-tag* +A static tag is a tag that is defined for a specific file. In a C program +this could be a static function. + +In Vi jumping to a tag sets the current search pattern. This means that +the "n" command after jumping to a tag does not search for the same pattern +that it did before jumping to the tag. Vim does not do this as we consider it +to be a bug. You can still find the tag search pattern in the search history. +If you really want the old Vi behavior, set the 't' flag in 'cpoptions'. + + *tag-binary-search* +Vim uses binary searching in the tags file to find the desired tag quickly +(when enabled at compile time |+tag_binary|). But this only works if the +tags file was sorted on ASCII byte value. Therefore, if no match was found, +another try is done with a linear search. If you only want the linear search, +reset the 'tagbsearch' option. Or better: Sort the tags file! + +Note that the binary searching is disabled when not looking for a tag with a +specific name. This happens when ignoring case and when a regular expression +is used that doesn't start with a fixed string. Tag searching can be a lot +slower then. The former can be avoided by case-fold sorting the tags file. +See 'tagbsearch' for details. + + *tag-regexp* +The ":tag" and "tselect" commands accept a regular expression argument. See +|pattern| for the special characters that can be used. +When the argument starts with '/', it is used as a pattern. If the argument +does not start with '/', it is taken literally, as a full tag name. +Examples: > + :tag main +< jumps to the tag "main" that has the highest priority. > + :tag /^get +< jumps to the tag that starts with "get" and has the highest priority. > + :tag /norm +< lists all the tags that contain "norm", including "id_norm". +When the argument both exists literally, and match when used as a regexp, a +literal match has a higher priority. For example, ":tag /open" matches "open" +before "open_file" and "file_open". +When using a pattern case is ignored. If you want to match case use "\C" in +the pattern. + + *tag-!* +If the tag is in the current file this will always work. Otherwise the +performed actions depend on whether the current file was changed, whether a ! +is added to the command and on the 'autowrite' option: + + tag in file autowrite ~ +current file changed ! option action ~ +----------------------------------------------------------------------------- + yes x x x goto tag + no no x x read other file, goto tag + no yes yes x abandon current file, read other file, goto + tag + no yes no on write current file, read other file, goto + tag + no yes no off fail +----------------------------------------------------------------------------- + +- If the tag is in the current file, the command will always work. +- If the tag is in another file and the current file was not changed, the + other file will be made the current file and read into the buffer. +- If the tag is in another file, the current file was changed and a ! is + added to the command, the changes to the current file are lost, the other + file will be made the current file and read into the buffer. +- If the tag is in another file, the current file was changed and the + 'autowrite' option is on, the current file will be written, the other + file will be made the current file and read into the buffer. +- If the tag is in another file, the current file was changed and the + 'autowrite' option is off, the command will fail. If you want to save + the changes, use the ":w" command and then use ":tag" without an argument. + This works because the tag is put on the stack anyway. If you want to lose + the changes you can use the ":tag!" command. + + *tag-security* +Note that Vim forbids some commands, for security reasons. This works like +using the 'secure' option for exrc/vimrc files in the current directory. See +|trojan-horse| and |sandbox|. +When the {tagaddress} changes a buffer, you will get a warning message: + "WARNING: tag command changed a buffer!!!" +In a future version changing the buffer will be impossible. All this for +security reasons: Somebody might hide a nasty command in the tags file, which +would otherwise go unnoticed. Example: > + :$d|/tag-function-name/ +{this security prevention is not present in Vi} + +In Vi the ":tag" command sets the last search pattern when the tag is searched +for. In Vim this is not done, the previous search pattern is still remembered, +unless the 't' flag is present in 'cpoptions'. The search pattern is always +put in the search history, so you can modify it if searching fails. + + *emacs-tags* *emacs_tags* *E430* +Emacs style tag files are only supported if Vim was compiled with the +|+emacs_tags| feature enabled. Sorry, there is no explanation about Emacs tag +files here, it is only supported for backwards compatibility :-). + +Lines in Emacs tags files can be very long. Vim only deals with lines of up +to about 510 bytes. To see whether lines are ignored set 'verbose' to 5 or +higher. + + *tags-option* +The 'tags' option is a list of file names. Each of these files is searched +for the tag. This can be used to use a different tags file than the default +file "tags". It can also be used to access a common tags file. + +The next file in the list is not used when: +- A matching static tag for the current buffer has been found. +- A matching global tag has been found. +This also depends on the 'ignorecase' option. If it is off, and the tags file +only has a match without matching case, the next tags file is searched for a +match with matching case. If no tag with matching case is found, the first +match without matching case is used. If 'ignorecase' is on, and a matching +global tag with or without matching case is found, this one is used, no +further tags files are searched. + +When a tag file name starts with "./", the '.' is replaced with the path of +the current file. This makes it possible to use a tags file in the directory +where the current file is (no matter what the current directory is). The idea +of using "./" is that you can define which tag file is searched first: In the +current directory ("tags,./tags") or in the directory of the current file +("./tags,tags"). + +For example: > + :set tags=./tags,tags,/home/user/commontags + +In this example the tag will first be searched for in the file "tags" in the +directory where the current file is. Next the "tags" file in the current +directory. If it is not found there, then the file "/home/user/commontags" +will be searched for the tag. + +This can be switched off by including the 'd' flag in 'cpoptions', to make +it Vi compatible. "./tags" will then be the tags file in the current +directory, instead of the tags file in the directory where the current file +is. + +Instead of the comma a space may be used. Then a backslash is required for +the space to be included in the string option: > + :set tags=tags\ /home/user/commontags + +To include a space in a file name use three backslashes. To include a comma +in a file name use two backslashes. For example, use: > + :set tags=tag\\\ file,/home/user/common\\,tags + +for the files "tag file" and "/home/user/common,tags". The 'tags' option will +have the value "tag\ file,/home/user/common\,tags". + +If the 'tagrelative' option is on (which is the default) and using a tag file +in another directory, file names in that tag file are relative to the +directory where the tag file is. + +============================================================================== +5. Tags file format *tags-file-format* *E431* + + *ctags* *jtags* +A tags file can be created with an external command, for example "ctags". It +will contain a tag for each function. Some versions of "ctags" will also make +a tag for each "#defined" macro, typedefs, enums, etc. + +Some programs that generate tags files: +ctags As found on most Unix systems. Only supports C. Only + does the basic work. + *Exuberant_ctags* +exuberant ctags This a very good one. It works for C, C++, Java, + Fortran, Eiffel and others. It can generate tags for + many items. See http://ctags.sourceforge.net. +etags Connected to Emacs. Supports many languages. +JTags For Java, in Java. It can be found at + http://www.fleiner.com/jtags/. +ptags.py For Python, in Python. Found in your Python source + directory at Tools/scripts/ptags.py. +ptags For Perl, in Perl. It can be found at + http://www.eleves.ens.fr:8080/home/nthiery/Tags/. +gnatxref For Ada. See http://www.gnuada.org/. gnatxref is + part of the gnat package. + + +The lines in the tags file must have one of these three formats: + +1. {tagname} {TAB} {tagfile} {TAB} {tagaddress} +2. {tagfile}:{tagname} {TAB} {tagfile} {TAB} {tagaddress} +3. {tagname} {TAB} {tagfile} {TAB} {tagaddress} {term} {field} .. + +The first is a normal tag, which is completely compatible with Vi. It is the +only format produced by traditional ctags implementations. This is often used +for functions that are global, also referenced in other files. + +The lines in the tags file can end in <LF> or <CR><LF>. On the Macintosh <CR> +also works. The <CR> and <NL> characters can never appear inside a line. + + *tag-old-static* +The second format is for a static tag only. It is obsolete now, replaced by +the third format. It is only supported by Elvis 1.x and Vim and a few +versions of ctags. A static tag is often used for functions that are local, +only referenced in the file {tagfile}. Note that for the static tag, the two +occurrences of {tagfile} must be exactly the same. Also see |tags-option| +below, for how static tags are used. + +The third format is new. It includes additional information in optional +fields at the end of each line. It is backwards compatible with Vi. It is +only supported by new versions of ctags (such as Exuberant ctags). + +{tagname} The identifier. Normally the name of a function, but it can + be any identifier. It cannot contain a <Tab>. +{TAB} One <Tab> character. Note: previous versions allowed any + white space here. This has been abandoned to allow spaces in + {tagfile}. It can be re-enabled by including the + |+tag_any_white| feature at compile time. *tag-any-white* +{tagfile} The file that contains the definition of {tagname}. It can + have an absolute or relative path. It may contain environment + variables and wildcards (although the use of wildcards is + doubtful). It cannot contain a <Tab>. +{tagaddress} The Ex command that positions the cursor on the tag. It can + be any Ex command, although restrictions apply (see + |tag-security|). Posix only allows line numbers and search + commands, which are mostly used. +{term} ;" The two characters semicolon and double quote. This is + interpreted by Vi as the start of a comment, which makes the + following be ignored. This is for backwards compatibility + with Vi, it ignores the following fields. +{field} .. A list of optional fields. Each field has the form: + + <Tab>{fieldname}:{value} + + The {fieldname} identifies the field, and can only contain + alphabetical characters [a-zA-Z]. + The {value} is any string, but cannot contain a <Tab>. + These characters are special: + "\t" stands for a <Tab> + "\r" stands for a <CR> + "\n" stands for a <NL> + "\\" stands for a single '\' character + + There is one field that doesn't have a ':'. This is the kind + of the tag. It is handled like it was preceded with "kind:". + See the documentation of ctags for the kinds it produces. + + The only other field currently recognized by Vim is "file:" + (with an empty value). It is used for a static tag. + +The first lines in the tags file can contain lines that start with + !_TAG_ +These are sorted to the first lines, only rare tags that start with "!" can +sort to before them. Vim recognizes two items. The first one is the line +that indicates if the file was sorted. When this line is found, Vim uses +binary searching for the tags file: + !_TAG_FILE_SORTED<Tab>1<Tab>{anything} ~ + +A tag file may be case-fold sorted to avoid a linear search when 'ignorecase' +is on. See 'tagbsearch' for details. The value '2' should be used then: + !_TAG_FILE_SORTED<Tab>2<Tab>{anything} ~ + +The other tag that Vim recognizes, but only when compiled with the +|+multi_byte| feature, is the encoding of the tags file: + !_TAG_FILE_ENCODING<Tab>utf-8<Tab>{anything} ~ +Here "utf-8" is the encoding used for the tags. Vim will then convert the tag +being searched for from 'encoding' to the encoding of the tags file. And when +listing tags the reverse happens. When the conversion fails the unconverted +tag is used. + + *tag-search* +The command can be any Ex command, but often it is a search command. +Examples: + tag1 file1 /^main(argc, argv)/ ~ + tag2 file2 108 ~ + +The command is always executed with 'magic' not set. The only special +characters in a search pattern are "^" (begin-of-line) and "$" (<EOL>). +See |pattern|. Note that you must put a backslash before each backslash in +the search text. This is for backwards compatibility with Vi. + + *E434* *E435* +If the command is a normal search command (it starts and ends with "/" or +"?"), some special handling is done: +- Searching starts on line 1 of the file. + The direction of the search is forward for "/", backward for "?". + Note that 'wrapscan' does not matter, the whole file is always searched. (Vi + does use 'wrapscan', which caused tags sometimes not be found.) {Vi starts + searching in line 2 of another file. It does not find a tag in line 1 of + another file when 'wrapscan' is not set} +- If the search fails, another try is done ignoring case. If that fails too, + a search is done for: + "^tagname[ \t]*(" + (the tag with '^' prepended and "[ \t]*(" appended). When using function + names, this will find the function name when it is in column 0. This will + help when the arguments to the function have changed since the tags file was + made. If this search also fails another search is done with: + "^[#a-zA-Z_].*\<tagname[ \t]*(" + This means: A line starting with '#' or an identifier and containing the tag + followed by white space and a '('. This will find macro names and function + names with a type prepended. {the extra searches are not in Vi} + +============================================================================== +6. Include file searches *include-search* *definition-search* + *E387* *E388* *E389* + +These commands look for a string in the current file and in all encountered +included files (recursively). This can be used to find the definition of a +variable, function or macro. If you only want to search in the current +buffer, use the commands listed at |pattern-searches|. + +These commands are not available when the |+find_in_path| feature was disabled +at compile time. + +When a line is encountered that includes another file, that file is searched +before continuing in the current buffer. Files included by included files are +also searched. When an include file could not be found it is silently +ignored. Use the |:checkpath| command to discover which files could not be +found, possibly your 'path' option is not set up correctly. Note: the +included file is searched, not a buffer that may be editing that file. Only +for the current file the lines in the buffer are used. + +The string can be any keyword or a defined macro. For the keyword any match +will be found. For defined macros only lines that match with the 'define' +option will be found. The default is "^#\s*define", which is for C programs. +For other languages you probably want to change this. See 'define' for an +example for C++. The string cannot contain an end-of-line, only matches +within a line are found. + +When a match is found for a defined macro, the displaying of lines continues +with the next line when a line ends in a backslash. + +The commands that start with "[" start searching from the start of the current +file. The commands that start with "]" start at the current cursor position. + +The 'include' option is used to define a line that includes another file. The +default is "\^#\s*include", which is for C programs. Note: Vim does not +recognize C syntax, if the 'include' option matches a line inside +"#ifdef/#endif" or inside a comment, it is searched anyway. The 'isfname' +option is used to recognize the file name that comes after the matched +pattern. + +The 'path' option is used to find the directory for the include files that +do not have an absolute path. + +The 'comments' option is used for the commands that display a single line or +jump to a line. It defines patterns that may start a comment. Those lines +are ignored for the search, unless [!] is used. One exception: When the line +matches the pattern "^# *define" it is not considered to be a comment. + +If you want to list matches, and then select one to jump to, you could use a +mapping to do that for you. Here is an example: > + + :map <F4> [I:let nr = input("Which one: ")<Bar>exe "normal " . nr ."[\t"<CR> +< + *[i* +[i Display the first line that contains the keyword + under the cursor. The search starts at the beginning + of the file. Lines that look like a comment are + ignored (see 'comments' option). If a count is given, + the count'th matching line is displayed, and comment + lines are not ignored. {not in Vi} + + *]i* +]i like "[i", but start at the current cursor position. + {not in Vi} + + *:is* *:isearch* +:[range]is[earch][!] [count] [/]pattern[/] + Like "[i" and "]i", but search in [range] lines + (default: whole file). + See |:search-args| for [/] and [!]. {not in Vi} + + *[I* +[I Display all lines that contain the keyword under the + cursor. Filenames and line numbers are displayed + for the found lines. The search starts at the + beginning of the file. {not in Vi} + + *]I* +]I like "[I", but start at the current cursor position. + {not in Vi} + + *:il* *:ilist* +:[range]il[ist][!] [/]pattern[/] + Like "[I" and "]I", but search in [range] lines + (default: whole file). + See |:search-args| for [/] and [!]. {not in Vi} + + *[_CTRL-I* +[ CTRL-I Jump to the first line that contains the keyword + under the cursor. The search starts at the beginning + of the file. Lines that look like a comment are + ignored (see 'comments' option). If a count is given, + the count'th matching line is jumped to, and comment + lines are not ignored. {not in Vi} + + *]_CTRL-I* +] CTRL-I like "[ CTRL-I", but start at the current cursor + position. {not in Vi} + + *:ij* *:ijump* +:[range]ij[ump][!] [count] [/]pattern[/] + Like "[ CTRL-I" and "] CTRL-I", but search in + [range] lines (default: whole file). + See |:search-args| for [/] and [!]. {not in Vi} + +CTRL-W CTRL-I *CTRL-W_CTRL-I* *CTRL-W_i* +CTRL-W i Open a new window, with the cursor on the first line + that contains the keyword under the cursor. The + search starts at the beginning of the file. Lines + that look like a comment line are ignored (see + 'comments' option). If a count is given, the count'th + matching line is jumped to, and comment lines are not + ignored. {not in Vi} + + *:isp* *:isplit* +:[range]isp[lit][!] [count] [/]pattern[/] + Like "CTRL-W i" and "CTRL-W i", but search in + [range] lines (default: whole file). + See |:search-args| for [/] and [!]. {not in Vi} + + *[d* +[d Display the first macro definition that contains the + macro under the cursor. The search starts from the + beginning of the file. If a count is given, the + count'th matching line is displayed. {not in Vi} + + *]d* +]d like "[d", but start at the current cursor position. + {not in Vi} + + *:ds* *:dsearch* +:[range]ds[earch][!] [count] [/]string[/] + Like "[d" and "]d", but search in [range] lines + (default: whole file). + See |:search-args| for [/] and [!]. {not in Vi} + + *[D* +[D Display all macro definitions that contain the macro + under the cursor. Filenames and line numbers are + displayed for the found lines. The search starts + from the beginning of the file. {not in Vi} + + *]D* +]D like "[D", but start at the current cursor position. + {not in Vi} + + *:dli* *:dlist* +:[range]dl[ist][!] [/]string[/] + Like "[D" and "]D", but search in [range] lines + (default: whole file). + See |:search-args| for [/] and [!]. {not in Vi} + Note that ":dl" works like ":delete" with the "l" + flag. + + *[_CTRL-D* +[ CTRL-D Jump to the first macro definition that contains the + keyword under the cursor. The search starts from + the beginning of the file. If a count is given, the + count'th matching line is jumped to. {not in Vi} + + *]_CTRL-D* +] CTRL-D like "[ CTRL-D", but start at the current cursor + position. {not in Vi} + + *:dj* *:djump* +:[range]dj[ump][!] [count] [/]string[/] + Like "[ CTRL-D" and "] CTRL-D", but search in + [range] lines (default: whole file). + See |:search-args| for [/] and [!]. {not in Vi} + +CTRL-W CTRL-D *CTRL-W_CTRL-D* *CTRL-W_d* +CTRL-W d Open a new window, with the cursor on the first + macro definition line that contains the keyword + under the cursor. The search starts from the + beginning of the file. If a count is given, the + count'th matching line is jumped to. {not in Vi} + + *:dsp* *:dsplit* +:[range]dsp[lit][!] [count] [/]string[/] + Like "CTRL-W d", but search in [range] lines + (default: whole file). + See |:search-args| for [/] and [!]. {not in Vi} + + *:che* *:checkpath* +:che[ckpath] List all the included files that could not be found. + {not in Vi} + +:che[ckpath]! List all the included files. {not in Vi} + + *:search-args* +Common arguments for the commands above: +[!] When included, find matches in lines that are recognized as comments. + When excluded, a match is ignored when the line is recognized as a + comment (according to 'comments'), or the match is in a C comment (after + "//" or inside /* */). Note that a match may be missed if a line is + recognized as a comment, but the comment ends halfway the line. + And if the line is a comment, but it is not recognized (according to + 'comments') a match may be found in it anyway. Example: > + /* comment + foobar */ +< A match for "foobar" is found, because this line is not recognized as a + comment (even though syntax highlighting does recognize it). + Note: Since a macro definition mostly doesn't look like a comment, the + [!] makes no difference for ":dlist", ":dsearch" and ":djump". +[/] A pattern can be surrounded by '/'. Without '/' only whole words are + matched, using the pattern "\<pattern\>". Only after the second '/' a + next command can be appended with '|'. Example: > + :isearch /string/ | echo "the last one" +< For a ":djump", ":dsplit", ":dlist" and ":dsearch" command the pattern + is used as a literal string, not as a search pattern. + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/term.txt b/share/vim/vim73/doc/term.txt new file mode 100644 index 0000000000..8dc9773950 --- /dev/null +++ b/share/vim/vim73/doc/term.txt @@ -0,0 +1,876 @@ +*term.txt* For Vim version 7.3. Last change: 2009 Nov 05 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + +Terminal information *terminal-info* + +Vim uses information about the terminal you are using to fill the screen and +recognize what keys you hit. If this information is not correct, the screen +may be messed up or keys may not be recognized. The actions which have to be +performed on the screen are accomplished by outputting a string of +characters. Special keys produce a string of characters. These strings are +stored in the terminal options, see |terminal-options|. + +NOTE: Most of this is not used when running the |GUI|. + +1. Startup |startup-terminal| +2. Terminal options |terminal-options| +3. Window size |window-size| +4. Slow and fast terminals |slow-fast-terminal| +5. Using the mouse |mouse-using| + +============================================================================== +1. Startup *startup-terminal* + +When Vim is started a default terminal type is assumed. For the Amiga this is +a standard CLI window, for MS-DOS the pc terminal, for Unix an ansi terminal. +A few other terminal types are always available, see below |builtin-terms|. + +You can give the terminal name with the '-T' Vim argument. If it is not given +Vim will try to get the name from the TERM environment variable. + + *termcap* *terminfo* *E557* *E558* *E559* +On Unix the terminfo database or termcap file is used. This is referred to as +"termcap" in all the documentation. At compile time, when running configure, +the choice whether to use terminfo or termcap is done automatically. When +running Vim the output of ":version" will show |+terminfo| if terminfo is +used. Also see |xterm-screens|. + +On non-Unix systems a termcap is only available if Vim was compiled with +TERMCAP defined. + + *builtin-terms* *builtin_terms* +Which builtin terminals are available depends on a few defines in feature.h, +which need to be set at compile time: + define output of ":version" terminals builtin ~ +NO_BUILTIN_TCAPS -builtin_terms none +SOME_BUILTIN_TCAPS +builtin_terms most common ones (default) +ALL_BUILTIN_TCAPS ++builtin_terms all available + +You can see a list of available builtin terminals with ":set term=xxx" (when +not running the GUI). Also see |+builtin_terms|. + +If the termcap code is included Vim will try to get the strings for the +terminal you are using from the termcap file and the builtin termcaps. Both +are always used, if an entry for the terminal you are using is present. Which +one is used first depends on the 'ttybuiltin' option: + +'ttybuiltin' on 1: builtin termcap 2: external termcap +'ttybuiltin' off 1: external termcap 2: builtin termcap + +If an option is missing in one of them, it will be obtained from the other +one. If an option is present in both, the one first encountered is used. + +Which external termcap file is used varies from system to system and may +depend on the environment variables "TERMCAP" and "TERMPATH". See "man +tgetent". + +Settings depending on terminal *term-dependent-settings* + +If you want to set options or mappings, depending on the terminal name, you +can do this best in your .vimrc. Example: > + + if &term == "xterm" + ... xterm maps and settings ... + elseif &term =~ "vt10." + ... vt100, vt102 maps and settings ... + endif +< + *raw-terminal-mode* +For normal editing the terminal will be put into "raw" mode. The strings +defined with 't_ti' and 't_ks' will be sent to the terminal. Normally this +puts the terminal in a state where the termcap codes are valid and activates +the cursor and function keys. When Vim exits the terminal will be put back +into the mode it was before Vim started. The strings defined with 't_te' and +'t_ke' will be sent to the terminal. On the Amiga, with commands that execute +an external command (e.g., "!!"), the terminal will be put into Normal mode +for a moment. This means that you can stop the output to the screen by +hitting a printing key. Output resumes when you hit <BS>. + + *cs7-problem* +Note: If the terminal settings are changed after running Vim, you might have +an illegal combination of settings. This has been reported on Solaris 2.5 +with "stty cs8 parenb", which is restored as "stty cs7 parenb". Use +"stty cs8 -parenb -istrip" instead, this is restored correctly. + +Some termcap entries are wrong in the sense that after sending 't_ks' the +cursor keys send codes different from the codes defined in the termcap. To +avoid this you can set 't_ks' (and 't_ke') to empty strings. This must be +done during initialization (see |initialization|), otherwise it's too late. + +Some termcap entries assume that the highest bit is always reset. For +example: The cursor-up entry for the Amiga could be ":ku=\E[A:". But the +Amiga really sends "\233A". This works fine if the highest bit is reset, +e.g., when using an Amiga over a serial line. If the cursor keys don't work, +try the entry ":ku=\233A:". + +Some termcap entries have the entry ":ku=\E[A:". But the Amiga really sends +"\233A". On output "\E[" and "\233" are often equivalent, on input they +aren't. You will have to change the termcap entry, or change the key code with +the :set command to fix this. + +Many cursor key codes start with an <Esc>. Vim must find out if this is a +single hit of the <Esc> key or the start of a cursor key sequence. It waits +for a next character to arrive. If it does not arrive within one second a +single <Esc> is assumed. On very slow systems this may fail, causing cursor +keys not to work sometimes. If you discover this problem reset the 'timeout' +option. Vim will wait for the next character to arrive after an <Esc>. If +you want to enter a single <Esc> you must type it twice. Resetting the +'esckeys' option avoids this problem in Insert mode, but you lose the +possibility to use cursor and function keys in Insert mode. + +On the Amiga the recognition of window resizing is activated only when the +terminal name is "amiga" or "builtin_amiga". + +Some terminals have confusing codes for the cursor keys. The televideo 925 is +such a terminal. It sends a CTRL-H for cursor-left. This would make it +impossible to distinguish a backspace and cursor-left. To avoid this problem +CTRL-H is never recognized as cursor-left. + + *vt100-cursor-keys* *xterm-cursor-keys* +Other terminals (e.g., vt100 and xterm) have cursor keys that send <Esc>OA, +<Esc>OB, etc. Unfortunately these are valid commands in insert mode: Stop +insert, Open a new line above the new one, start inserting 'A', 'B', etc. +Instead of performing these commands Vim will erroneously recognize this typed +key sequence as a cursor key movement. To avoid this and make Vim do what you +want in either case you could use these settings: > + :set notimeout " don't timeout on mappings + :set ttimeout " do timeout on terminal key codes + :set timeoutlen=100 " timeout after 100 msec +This requires the key-codes to be sent within 100 msec in order to recognize +them as a cursor key. When you type you normally are not that fast, so they +are recognized as individual typed commands, even though Vim receives the same +sequence of bytes. + + *vt100-function-keys* *xterm-function-keys* +An xterm can send function keys F1 to F4 in two modes: vt100 compatible or +not. Because Vim may not know what the xterm is sending, both types of keys +are recognized. The same happens for the <Home> and <End> keys. + normal vt100 ~ + <F1> t_k1 <Esc>[11~ <xF1> <Esc>OP *<xF1>-xterm* + <F2> t_k2 <Esc>[12~ <xF2> <Esc>OQ *<xF2>-xterm* + <F3> t_k3 <Esc>[13~ <xF3> <Esc>OR *<xF3>-xterm* + <F4> t_k4 <Esc>[14~ <xF4> <Esc>OS *<xF4>-xterm* + <Home> t_kh <Esc>[7~ <xHome> <Esc>OH *<xHome>-xterm* + <End> t_@7 <Esc>[4~ <xEnd> <Esc>OF *<xEnd>-xterm* + +When Vim starts, <xF1> is mapped to <F1>, <xF2> to <F2> etc. This means that +by default both codes do the same thing. If you make a mapping for <xF2>, +because your terminal does have two keys, the default mapping is overwritten, +thus you can use the <F2> and <xF2> keys for something different. + + *xterm-shifted-keys* +Newer versions of xterm support shifted function keys and special keys. Vim +recognizes most of them. Use ":set termcap" to check which are supported and +what the codes are. Mostly these are not in a termcap, they are only +supported by the builtin_xterm termcap. + + *xterm-modifier-keys* +Newer versions of xterm support Alt and Ctrl for most function keys. To avoid +having to add all combinations of Alt, Ctrl and Shift for every key a special +sequence is recognized at the end of a termcap entry: ";*X". The "X" can be +any character, often '~' is used. The ";*" stands for an optional modifier +argument. ";2" is Shift, ";3" is Alt, ";5" is Ctrl and ";9" is Meta (when +it's different from Alt). They can be combined. Examples: > + :set <F8>=^[[19;*~ + :set <Home>=^[[1;*H +Another speciality about these codes is that they are not overwritten by +another code. That is to avoid that the codes obtained from xterm directly +|t_RV| overwrite them. + *xterm-scroll-region* +The default termcap entry for xterm on Sun and other platforms does not +contain the entry for scroll regions. Add ":cs=\E[%i%d;%dr:" to the xterm +entry in /etc/termcap and everything should work. + + *xterm-end-home-keys* +On some systems (at least on FreeBSD with XFree86 3.1.2) the codes that the +<End> and <Home> keys send contain a <Nul> character. To make these keys send +the proper key code, add these lines to your ~/.Xdefaults file: + +*VT100.Translations: #override \n\ + <Key>Home: string("0x1b") string("[7~") \n\ + <Key>End: string("0x1b") string("[8~") + + *xterm-8bit* *xterm-8-bit* +Xterm can be run in a mode where it uses 8-bit escape sequences. The CSI code +is used instead of <Esc>[. The advantage is that an <Esc> can quickly be +recognized in Insert mode, because it can't be confused with the start of a +special key. +For the builtin termcap entries, Vim checks if the 'term' option contains +"8bit" anywhere. It then uses 8-bit characters for the termcap entries, the +mouse and a few other things. You would normally set $TERM in your shell to +"xterm-8bit" and Vim picks this up and adjusts to the 8-bit setting +automatically. +When Vim receives a response to the |t_RV| (request version) sequence and it +starts with CSI, it assumes that the terminal is in 8-bit mode and will +convert all key sequences to their 8-bit variants. + +============================================================================== +2. Terminal options *terminal-options* *termcap-options* *E436* + +The terminal options can be set just like normal options. But they are not +shown with the ":set all" command. Instead use ":set termcap". + +It is always possible to change individual strings by setting the +appropriate option. For example: > + :set t_ce=^V^[[K (CTRL-V, <Esc>, [, K) + +{Vi: no terminal options. You have to exit Vi, edit the termcap entry and +try again} + +The options are listed below. The associated termcap code is always equal to +the last two characters of the option name. Only one termcap code is +required: Cursor motion, 't_cm'. + +The options 't_da', 't_db', 't_ms', 't_xs' represent flags in the termcap. +When the termcap flag is present, the option will be set to "y". But any +non-empty string means that the flag is set. An empty string means that the +flag is not set. 't_CS' works like this too, but it isn't a termcap flag. + +OUTPUT CODES + option meaning ~ + + t_AB set background color (ANSI) *t_AB* *'t_AB'* + t_AF set foreground color (ANSI) *t_AF* *'t_AF'* + t_AL add number of blank lines *t_AL* *'t_AL'* + t_al add new blank line *t_al* *'t_al'* + t_bc backspace character *t_bc* *'t_bc'* + t_cd clear to end of screen *t_cd* *'t_cd'* + t_ce clear to end of line *t_ce* *'t_ce'* + t_cl clear screen *t_cl* *'t_cl'* + t_cm cursor motion (required!) *E437* *t_cm* *'t_cm'* + t_Co number of colors *t_Co* *'t_Co'* + t_CS if non-empty, cursor relative to scroll region *t_CS* *'t_CS'* + t_cs define scrolling region *t_cs* *'t_cs'* + t_CV define vertical scrolling region *t_CV* *'t_CV'* + t_da if non-empty, lines from above scroll down *t_da* *'t_da'* + t_db if non-empty, lines from below scroll up *t_db* *'t_db'* + t_DL delete number of lines *t_DL* *'t_DL'* + t_dl delete line *t_dl* *'t_dl'* + t_fs set window title end (from status line) *t_fs* *'t_fs'* + t_ke exit "keypad transmit" mode *t_ke* *'t_ke'* + t_ks start "keypad transmit" mode *t_ks* *'t_ks'* + t_le move cursor one char left *t_le* *'t_le'* + t_mb blinking mode *t_mb* *'t_mb'* + t_md bold mode *t_md* *'t_md'* + t_me Normal mode (undoes t_mr, t_mb, t_md and color) *t_me* *'t_me'* + t_mr reverse (invert) mode *t_mr* *'t_mr'* + *t_ms* *'t_ms'* + t_ms if non-empty, cursor can be moved in standout/inverse mode + t_nd non destructive space character *t_nd* *'t_nd'* + t_op reset to original color pair *t_op* *'t_op'* + t_RI cursor number of chars right *t_RI* *'t_RI'* + t_Sb set background color *t_Sb* *'t_Sb'* + t_Sf set foreground color *t_Sf* *'t_Sf'* + t_se standout end *t_se* *'t_se'* + t_so standout mode *t_so* *'t_so'* + t_sr scroll reverse (backward) *t_sr* *'t_sr'* + t_te out of "termcap" mode *t_te* *'t_te'* + t_ti put terminal in "termcap" mode *t_ti* *'t_ti'* + t_ts set window title start (to status line) *t_ts* *'t_ts'* + t_ue underline end *t_ue* *'t_ue'* + t_us underline mode *t_us* *'t_us'* + t_Ce undercurl end *t_Ce* *'t_Ce'* + t_Cs undercurl mode *t_Cs* *'t_Cs'* + t_ut clearing uses the current background color *t_ut* *'t_ut'* + t_vb visual bell *t_vb* *'t_vb'* + t_ve cursor visible *t_ve* *'t_ve'* + t_vi cursor invisible *t_vi* *'t_vi'* + t_vs cursor very visible *t_vs* *'t_vs'* + *t_xs* *'t_xs'* + t_xs if non-empty, standout not erased by overwriting (hpterm) + t_ZH italics mode *t_ZH* *'t_ZH'* + t_ZR italics end *t_ZR* *'t_ZR'* + +Added by Vim (there are no standard codes for these): + t_IS set icon text start *t_IS* *'t_IS'* + t_IE set icon text end *t_IE* *'t_IE'* + t_WP set window position (Y, X) in pixels *t_WP* *'t_WP'* + t_WS set window size (height, width) in characters *t_WS* *'t_WS'* + t_SI start insert mode (bar cursor shape) *t_SI* *'t_SI'* + t_EI end insert mode (block cursor shape) *t_EI* *'t_EI'* + |termcap-cursor-shape| + t_RV request terminal version string (for xterm) *t_RV* *'t_RV'* + |xterm-8bit| |v:termresponse| |'ttymouse'| |xterm-codes| + +KEY CODES +Note: Use the <> form if possible + + option name meaning ~ + + t_ku <Up> arrow up *t_ku* *'t_ku'* + t_kd <Down> arrow down *t_kd* *'t_kd'* + t_kr <Right> arrow right *t_kr* *'t_kr'* + t_kl <Left> arrow left *t_kl* *'t_kl'* + <xUp> alternate arrow up *<xUp>* + <xDown> alternate arrow down *<xDown>* + <xRight> alternate arrow right *<xRight>* + <xLeft> alternate arrow left *<xLeft>* + <S-Up> shift arrow up + <S-Down> shift arrow down + t_%i <S-Right> shift arrow right *t_%i* *'t_%i'* + t_#4 <S-Left> shift arrow left *t_#4* *'t_#4'* + t_k1 <F1> function key 1 *t_k1* *'t_k1'* + <xF1> alternate F1 *<xF1>* + t_k2 <F2> function key 2 *<F2>* *t_k2* *'t_k2'* + <xF2> alternate F2 *<xF2>* + t_k3 <F3> function key 3 *<F3>* *t_k3* *'t_k3'* + <xF3> alternate F3 *<xF3>* + t_k4 <F4> function key 4 *<F4>* *t_k4* *'t_k4'* + <xF4> alternate F4 *<xF4>* + t_k5 <F5> function key 5 *<F5>* *t_k5* *'t_k5'* + t_k6 <F6> function key 6 *<F6>* *t_k6* *'t_k6'* + t_k7 <F7> function key 7 *<F7>* *t_k7* *'t_k7'* + t_k8 <F8> function key 8 *<F8>* *t_k8* *'t_k8'* + t_k9 <F9> function key 9 *<F9>* *t_k9* *'t_k9'* + t_k; <F10> function key 10 *<F10>* *t_k;* *'t_k;'* + t_F1 <F11> function key 11 *<F11>* *t_F1* *'t_F1'* + t_F2 <F12> function key 12 *<F12>* *t_F2* *'t_F2'* + t_F3 <F13> function key 13 *<F13>* *t_F3* *'t_F3'* + t_F4 <F14> function key 14 *<F14>* *t_F4* *'t_F4'* + t_F5 <F15> function key 15 *<F15>* *t_F5* *'t_F5'* + t_F6 <F16> function key 16 *<F16>* *t_F6* *'t_F6'* + t_F7 <F17> function key 17 *<F17>* *t_F7* *'t_F7'* + t_F8 <F18> function key 18 *<F18>* *t_F8* *'t_F8'* + t_F9 <F19> function key 19 *<F19>* *t_F9* *'t_F9'* + <S-F1> shifted function key 1 + <S-xF1> alternate <S-F1> *<S-xF1>* + <S-F2> shifted function key 2 *<S-F2>* + <S-xF2> alternate <S-F2> *<S-xF2>* + <S-F3> shifted function key 3 *<S-F3>* + <S-xF3> alternate <S-F3> *<S-xF3>* + <S-F4> shifted function key 4 *<S-F4>* + <S-xF4> alternate <S-F4> *<S-xF4>* + <S-F5> shifted function key 5 *<S-F5>* + <S-F6> shifted function key 6 *<S-F6>* + <S-F7> shifted function key 7 *<S-F7>* + <S-F8> shifted function key 8 *<S-F8>* + <S-F9> shifted function key 9 *<S-F9>* + <S-F10> shifted function key 10 *<S-F10>* + <S-F11> shifted function key 11 *<S-F11>* + <S-F12> shifted function key 12 *<S-F12>* + t_%1 <Help> help key *t_%1* *'t_%1'* + t_&8 <Undo> undo key *t_&8* *'t_&8'* + t_kI <Insert> insert key *t_kI* *'t_kI'* + t_kD <Del> delete key *t_kD* *'t_kD'* + t_kb <BS> backspace key *t_kb* *'t_kb'* + t_kB <S-Tab> back-tab (shift-tab) *<S-Tab>* *t_kB* *'t_kB'* + t_kh <Home> home key *t_kh* *'t_kh'* + t_#2 <S-Home> shifted home key *<S-Home>* *t_#2* *'t_#2'* + <xHome> alternate home key *<xHome>* + t_@7 <End> end key *t_@7* *'t_@7'* + t_*7 <S-End> shifted end key *<S-End>* *t_star7* *'t_star7'* + <xEnd> alternate end key *<xEnd>* + t_kP <PageUp> page-up key *t_kP* *'t_kP'* + t_kN <PageDown> page-down key *t_kN* *'t_kN'* + t_K1 <kHome> keypad home key *t_K1* *'t_K1'* + t_K4 <kEnd> keypad end key *t_K4* *'t_K4'* + t_K3 <kPageUp> keypad page-up key *t_K3* *'t_K3'* + t_K5 <kPageDown> keypad page-down key *t_K5* *'t_K5'* + t_K6 <kPlus> keypad plus key *<kPlus>* *t_K6* *'t_K6'* + t_K7 <kMinus> keypad minus key *<kMinus>* *t_K7* *'t_K7'* + t_K8 <kDivide> keypad divide *<kDivide>* *t_K8* *'t_K8'* + t_K9 <kMultiply> keypad multiply *<kMultiply>* *t_K9* *'t_K9'* + t_KA <kEnter> keypad enter key *<kEnter>* *t_KA* *'t_KA'* + t_KB <kPoint> keypad decimal point *<kPoint>* *t_KB* *'t_KB'* + t_KC <k0> keypad 0 *<k0>* *t_KC* *'t_KC'* + t_KD <k1> keypad 1 *<k1>* *t_KD* *'t_KD'* + t_KE <k2> keypad 2 *<k2>* *t_KE* *'t_KE'* + t_KF <k3> keypad 3 *<k3>* *t_KF* *'t_KF'* + t_KG <k4> keypad 4 *<k4>* *t_KG* *'t_KG'* + t_KH <k5> keypad 5 *<k5>* *t_KH* *'t_KH'* + t_KI <k6> keypad 6 *<k6>* *t_KI* *'t_KI'* + t_KJ <k7> keypad 7 *<k7>* *t_KJ* *'t_KJ'* + t_KK <k8> keypad 8 *<k8>* *t_KK* *'t_KK'* + t_KL <k9> keypad 9 *<k9>* *t_KL* *'t_KL'* + <Mouse> leader of mouse code *<Mouse>* + +Note about t_so and t_mr: When the termcap entry "so" is not present the +entry for "mr" is used. And vice versa. The same is done for "se" and "me". +If your terminal supports both inversion and standout mode, you can see two +different modes. If your terminal supports only one of the modes, both will +look the same. + + *keypad-comma* +The keypad keys, when they are not mapped, behave like the equivalent normal +key. There is one exception: if you have a comma on the keypad instead of a +decimal point, Vim will use a dot anyway. Use these mappings to fix that: > + :noremap <kPoint> , + :noremap! <kPoint> , +< *xterm-codes* +There is a special trick to obtain the key codes which currently only works +for xterm. When |t_RV| is defined and a response is received which indicates +an xterm with patchlevel 141 or higher, Vim uses special escape sequences to +request the key codes directly from the xterm. The responses are used to +adjust the various t_ codes. This avoids the problem that the xterm can +produce different codes, depending on the mode it is in (8-bit, VT102, +VT220, etc.). The result is that codes like <xF1> are no longer needed. +Note: This is only done on startup. If the xterm options are changed after +Vim has started, the escape sequences may not be recognized any more. + + *xterm-resize* +Window resizing with xterm only works if the allowWindowOps resource is +enabled. On some systems and versions of xterm it's disabled by default +because someone thought it would be a security issue. It's not clear if this +is actually the case. + +To overrule the default, put this line in your ~/.Xdefaults or +~/.Xresources: +> + XTerm*allowWindowOps: true + +And run "xrdb -merge .Xresources" to make it effective. You can check the +value with the context menu (right mouse button while CTRL key is pressed), +there should be a tick at allow-window-ops. + + *termcap-colors* +Note about colors: The 't_Co' option tells Vim the number of colors available. +When it is non-zero, the 't_AB' and 't_AF' options are used to set the color. +If one of these is not available, 't_Sb' and 't_Sf' are used. 't_me' is used +to reset to the default colors. + + *termcap-cursor-shape* *termcap-cursor-color* +When Vim enters Insert mode the 't_SI' escape sequence is sent. When leaving +Insert mode 't_EI' is used. But only if both are defined. This can be used +to change the shape or color of the cursor in Insert mode. These are not +standard termcap/terminfo entries, you need to set them yourself. +Example for an xterm, this changes the color of the cursor: > + if &term =~ "xterm" + let &t_SI = "\<Esc>]12;purple\x7" + let &t_EI = "\<Esc>]12;blue\x7" + endif +NOTE: When Vim exits the shape for Normal mode will remain. The shape from +before Vim started will not be restored. +{not available when compiled without the |+cursorshape| feature} + + *termcap-title* +The 't_ts' and 't_fs' options are used to set the window title if the terminal +allows title setting via sending strings. They are sent before and after the +title string, respectively. Similar 't_IS' and 't_IE' are used to set the +icon text. These are Vim-internal extensions of the Unix termcap, so they +cannot be obtained from an external termcap. However, the builtin termcap +contains suitable entries for xterm and iris-ansi, so you don't need to set +them here. + *hpterm* +If inversion or other highlighting does not work correctly, try setting the +'t_xs' option to a non-empty string. This makes the 't_ce' code be used to +remove highlighting from a line. This is required for "hpterm". Setting the +'weirdinvert' option has the same effect as making 't_xs' non-empty, and vice +versa. + + *scroll-region* +Some termcaps do not include an entry for 'cs' (scroll region), although the +terminal does support it. For example: xterm on a Sun. You can use the +builtin_xterm or define t_cs yourself. For example: > + :set t_cs=^V^[[%i%d;%dr +Where ^V is CTRL-V and ^[ is <Esc>. + +The vertical scroll region t_CV is not a standard termcap code. Vim uses it +internally in the GUI. But it can also be defined for a terminal, if you can +find one that supports it. The two arguments are the left and right column of +the region which to restrict the scrolling to. Just like t_cs defines the top +and bottom lines. Defining t_CV will make scrolling in vertically split +windows a lot faster. Don't set t_CV when t_da or t_db is set (text isn't +cleared when scrolling). + +Unfortunately it is not possible to deduce from the termcap how cursor +positioning should be done when using a scrolling region: Relative to the +beginning of the screen or relative to the beginning of the scrolling region. +Most terminals use the first method. A known exception is the MS-DOS console +(pcterm). The 't_CS' option should be set to any string when cursor +positioning is relative to the start of the scrolling region. It should be +set to an empty string otherwise. It defaults to "yes" when 'term' is +"pcterm". + +Note for xterm users: The shifted cursor keys normally don't work. You can + make them work with the xmodmap command and some mappings in Vim. + + Give these commands in the xterm: + xmodmap -e "keysym Up = Up F13" + xmodmap -e "keysym Down = Down F16" + xmodmap -e "keysym Left = Left F18" + xmodmap -e "keysym Right = Right F19" + + And use these mappings in Vim: + :map <t_F3> <S-Up> + :map! <t_F3> <S-Up> + :map <t_F6> <S-Down> + :map! <t_F6> <S-Down> + :map <t_F8> <S-Left> + :map! <t_F8> <S-Left> + :map <t_F9> <S-Right> + :map! <t_F9> <S-Right> + +Instead of, say, <S-Up> you can use any other command that you want to use the +shift-cursor-up key for. (Note: To help people that have a Sun keyboard with +left side keys F14 is not used because it is confused with the undo key; F15 +is not used, because it does a window-to-front; F17 is not used, because it +closes the window. On other systems you can probably use them.) + +============================================================================== +3. Window size *window-size* + +[This is about the size of the whole window Vim is using, not a window that is +created with the ":split" command.] + +If you are running Vim on an Amiga and the terminal name is "amiga" or +"builtin_amiga", the amiga-specific window resizing will be enabled. On Unix +systems three methods are tried to get the window size: + +- an ioctl call (TIOCGSIZE or TIOCGWINSZ, depends on your system) +- the environment variables "LINES" and "COLUMNS" +- from the termcap entries "li" and "co" + +If everything fails a default size of 24 lines and 80 columns is assumed. If +a window-resize signal is received the size will be set again. If the window +size is wrong you can use the 'lines' and 'columns' options to set the +correct values. + +One command can be used to set the screen size: + + *:mod* *:mode* *E359* *E362* +:mod[e] [mode] + +Without argument this only detects the screen size and redraws the screen. +With MS-DOS it is possible to switch screen mode. [mode] can be one of these +values: + "bw40" 40 columns black&white + "c40" 40 columns color + "bw80" 80 columns black&white + "c80" 80 columns color (most people use this) + "mono" 80 columns monochrome + "c4350" 43 or 50 lines EGA/VGA mode + number mode number to use, depends on your video card + +============================================================================== +4. Slow and fast terminals *slow-fast-terminal* + *slow-terminal* + +If you have a fast terminal you may like to set the 'ruler' option. The +cursor position is shown in the status line. If you are using horizontal +scrolling ('wrap' option off) consider setting 'sidescroll' to a small +number. + +If you have a slow terminal you may want to reset the 'showcmd' option. +The command characters will not be shown in the status line. If the terminal +scrolls very slowly, set the 'scrolljump' to 5 or so. If the cursor is moved +off the screen (e.g., with "j") Vim will scroll 5 lines at a time. Another +possibility is to reduce the number of lines that Vim uses with the command +"z{height}<CR>". + +If the characters from the terminal are arriving with more than 1 second +between them you might want to set the 'timeout' and/or 'ttimeout' option. +See the "Options" chapter |options|. + +If your terminal does not support a scrolling region, but it does support +insert/delete line commands, scrolling with multiple windows may make the +lines jump up and down. If you don't want this set the 'ttyfast' option. +This will redraw the window instead of scroll it. + +If your terminal scrolls very slowly, but redrawing is not slow, set the +'ttyscroll' option to a small number, e.g., 3. This will make Vim redraw the +screen instead of scrolling, when there are more than 3 lines to be scrolled. + +If you are using a color terminal that is slow, use this command: > + hi NonText cterm=NONE ctermfg=NONE +This avoids that spaces are sent when they have different attributes. On most +terminals you can't see this anyway. + +If you are using Vim over a slow serial line, you might want to try running +Vim inside the "screen" program. Screen will optimize the terminal I/O quite +a bit. + +If you are testing termcap options, but you cannot see what is happening, +you might want to set the 'writedelay' option. When non-zero, one character +is sent to the terminal at a time (does not work for MS-DOS). This makes the +screen updating a lot slower, making it possible to see what is happening. + +============================================================================== +5. Using the mouse *mouse-using* + +This section is about using the mouse on a terminal or a terminal window. How +to use the mouse in a GUI window is explained in |gui-mouse|. For scrolling +with a mouse wheel see |scroll-mouse-wheel|. + +Don't forget to enable the mouse with this command: > + :set mouse=a +Otherwise Vim won't recognize the mouse in all modes (See 'mouse'). + +Currently the mouse is supported for Unix in an xterm window, in a *BSD +console with |sysmouse|, in a Linux console (with GPM |gpm-mouse|), for +MS-DOS and in a Windows console. +Mouse clicks can be used to position the cursor, select an area and paste. + +These characters in the 'mouse' option tell in which situations the mouse will +be used by Vim: + n Normal mode + v Visual mode + i Insert mode + c Command-line mode + h all previous modes when in a help file + a all previous modes + r for |hit-enter| prompt + +The default for 'mouse' is empty, the mouse is not used. Normally you would +do: > + :set mouse=a +to start using the mouse (this is equivalent to setting 'mouse' to "nvich"). +If you only want to use the mouse in a few modes or also want to use it for +the two questions you will have to concatenate the letters for those modes. +For example: > + :set mouse=nv +Will make the mouse work in Normal mode and Visual mode. > + :set mouse=h +Will make the mouse work in help files only (so you can use "g<LeftMouse>" to +jump to tags). + +Whether the selection that is started with the mouse is in Visual mode or +Select mode depends on whether "mouse" is included in the 'selectmode' +option. + +In an xterm, with the currently active mode included in the 'mouse' option, +normal mouse clicks are used by Vim, mouse clicks with the shift or ctrl key +pressed go to the xterm. With the currently active mode not included in +'mouse' all mouse clicks go to the xterm. + + *xterm-clipboard* +In the Athena and Motif GUI versions, when running in a terminal and there is +access to the X-server (DISPLAY is set), the copy and paste will behave like +in the GUI. If not, the middle mouse button will insert the unnamed register. +In that case, here is how you copy and paste a piece of text: + +Copy/paste with the mouse and Visual mode ('mouse' option must be set, see +above): +1. Press left mouse button on first letter of text, move mouse pointer to last + letter of the text and release the button. This will start Visual mode and + highlight the selected area. +2. Press "y" to yank the Visual text in the unnamed register. +3. Click the left mouse button at the insert position. +4. Click the middle mouse button. + +Shortcut: If the insert position is on the screen at the same time as the +Visual text, you can do 2, 3 and 4 all in one: Click the middle mouse button +at the insert position. + +Note: When the |-X| command line argument is used, Vim will not connect to the +X server and copy/paste to the X clipboard (selection) will not work. Use the +shift key with the mouse buttons to let the xterm do the selection. + + *xterm-command-server* +When the X-server clipboard is available, the command server described in +|x11-clientserver| can be enabled with the --servername command line argument. + + *xterm-copy-paste* +NOTE: In some (older) xterms, it's not possible to move the cursor past column +95. This is an xterm problem, not Vim's. Get a newer xterm |color-xterm|. + +Copy/paste in xterm with (current mode NOT included in 'mouse'): +1. Press left mouse button on first letter of text, move mouse pointer to last + letter of the text and release the button. +2. Use normal Vim commands to put the cursor at the insert position. +3. Press "a" to start Insert mode. +4. Click the middle mouse button. +5. Press ESC to end Insert mode. +(The same can be done with anything in 'mouse' if you keep the shift key +pressed while using the mouse.) + +Note: if you lose the 8th bit when pasting (special characters are translated +into other characters), you may have to do "stty cs8 -istrip -parenb" in your +shell before starting Vim. + +Thus in an xterm the shift and ctrl keys cannot be used with the mouse. Mouse +commands requiring the CTRL modifier can be simulated by typing the "g" key +before using the mouse: + "g<LeftMouse>" is "<C-LeftMouse> (jump to tag under mouse click) + "g<RightMouse>" is "<C-RightMouse> ("CTRL-T") + + *mouse-mode-table* *mouse-overview* +A short overview of what the mouse buttons do, when 'mousemodel' is "extend": + +Normal Mode: +event position selection change action ~ + cursor window ~ +<LeftMouse> yes end yes +<C-LeftMouse> yes end yes "CTRL-]" (2) +<S-LeftMouse> yes no change yes "*" (2) *<S-LeftMouse>* +<LeftDrag> yes start or extend (1) no *<LeftDrag>* +<LeftRelease> yes start or extend (1) no +<MiddleMouse> yes if not active no put +<MiddleMouse> yes if active no yank and put +<RightMouse> yes start or extend yes +<A-RightMouse> yes start or extend blockw. yes *<A-RightMouse>* +<S-RightMouse> yes no change yes "#" (2) *<S-RightMouse>* +<C-RightMouse> no no change no "CTRL-T" +<RightDrag> yes extend no *<RightDrag>* +<RightRelease> yes extend no *<RightRelease>* + +Insert or Replace Mode: +event position selection change action ~ + cursor window ~ +<LeftMouse> yes (cannot be active) yes +<C-LeftMouse> yes (cannot be active) yes "CTRL-O^]" (2) +<S-LeftMouse> yes (cannot be active) yes "CTRL-O*" (2) +<LeftDrag> yes start or extend (1) no like CTRL-O (1) +<LeftRelease> yes start or extend (1) no like CTRL-O (1) +<MiddleMouse> no (cannot be active) no put register +<RightMouse> yes start or extend yes like CTRL-O +<A-RightMouse> yes start or extend blockw. yes +<S-RightMouse> yes (cannot be active) yes "CTRL-O#" (2) +<C-RightMouse> no (cannot be active) no "CTRL-O CTRL-T" + +In a help window: +event position selection change action ~ + cursor window ~ +<2-LeftMouse> yes (cannot be active) no "^]" (jump to help tag) + +When 'mousemodel' is "popup", these are different: + +Normal Mode: +event position selection change action ~ + cursor window ~ +<S-LeftMouse> yes start or extend (1) no +<A-LeftMouse> yes start or extend blockw. no *<A-LeftMouse>* +<RightMouse> no popup menu no + +Insert or Replace Mode: +event position selection change action ~ + cursor window ~ +<S-LeftMouse> yes start or extend (1) no like CTRL-O (1) +<A-LeftMouse> yes start or extend blockw. no +<RightMouse> no popup menu no + +(1) only if mouse pointer moved since press +(2) only if click is in same buffer + +Clicking the left mouse button causes the cursor to be positioned. If the +click is in another window that window is made the active window. When +editing the command-line the cursor can only be positioned on the +command-line. When in Insert mode Vim remains in Insert mode. If 'scrolloff' +is set, and the cursor is positioned within 'scrolloff' lines from the window +border, the text is scrolled. + +A selection can be started by pressing the left mouse button on the first +character, moving the mouse to the last character, then releasing the mouse +button. You will not always see the selection until you release the button, +only in some versions (GUI, MS-DOS, WIN32) will the dragging be shown +immediately. Note that you can make the text scroll by moving the mouse at +least one character in the first/last line in the window when 'scrolloff' is +non-zero. + +In Normal, Visual and Select mode clicking the right mouse button causes the +Visual area to be extended. When 'mousemodel' is "popup", the left button has +to be used while keeping the shift key pressed. When clicking in a window +which is editing another buffer, the Visual or Select mode is stopped. + +In Normal, Visual and Select mode clicking the right mouse button with the alt +key pressed causes the Visual area to become blockwise. When 'mousemodel' is +"popup" the left button has to be used with the alt key. Note that this won't +work on systems where the window manager consumes the mouse events when the +alt key is pressed (it may move the window). + + *double-click* +Double, triple and quadruple clicks are supported when the GUI is active, +for MS-DOS and Win32, and for an xterm (if the gettimeofday() function is +available). For selecting text, extra clicks extend the selection: + click select ~ + double word or % match *<2-LeftMouse>* + triple line *<3-LeftMouse>* + quadruple rectangular block *<4-LeftMouse>* +Exception: In a Help window a double click jumps to help for the word that is +clicked on. +A double click on a word selects that word. 'iskeyword' is used to specify +which characters are included in a word. A double click on a character +that has a match selects until that match (like using "v%"). If the match is +an #if/#else/#endif block, the selection becomes linewise. +For MS-DOS and xterm the time for double clicking can be set with the +'mousetime' option. For the other systems this time is defined outside of +Vim. +An example, for using a double click to jump to the tag under the cursor: > + :map <2-LeftMouse> :exe "tag ". expand("<cword>")<CR> + +Dragging the mouse with a double click (button-down, button-up, button-down +and then drag) will result in whole words to be selected. This continues +until the button is released, at which point the selection is per character +again. + + *gpm-mouse* +The GPM mouse is only supported when the |+mouse_gpm| feature was enabled at +compile time. The GPM mouse driver (Linux console) does not support quadruple +clicks. + +In Insert mode, when a selection is started, Vim goes into Normal mode +temporarily. When Visual or Select mode ends, it returns to Insert mode. +This is like using CTRL-O in Insert mode. Select mode is used when the +'selectmode' option contains "mouse". + *sysmouse* +The sysmouse is only supported when the |+mouse_sysmouse| feature was enabled +at compile time. The sysmouse driver (*BSD console) does not support keyboard +modifiers. + + *drag-status-line* +When working with several windows, the size of the windows can be changed by +dragging the status line with the mouse. Point the mouse at a status line, +press the left button, move the mouse to the new position of the status line, +release the button. Just clicking the mouse in a status line makes that window +the current window, without moving the cursor. If by selecting a window it +will change position or size, the dragging of the status line will look +confusing, but it will work (just try it). + + *<MiddleRelease>* *<MiddleDrag>* +Mouse clicks can be mapped. The codes for mouse clicks are: + code mouse button normal action ~ + <LeftMouse> left pressed set cursor position + <LeftDrag> left moved while pressed extend selection + <LeftRelease> left released set selection end + <MiddleMouse> middle pressed paste text at cursor position + <MiddleDrag> middle moved while pressed - + <MiddleRelease> middle released - + <RightMouse> right pressed extend selection + <RightDrag> right moved while pressed extend selection + <RightRelease> right released set selection end + <X1Mouse> X1 button pressed - *X1Mouse* + <X1Drag> X1 moved while pressed - *X1Drag* + <X1Release> X1 button release - *X1Release* + <X2Mouse> X2 button pressed - *X2Mouse* + <X2Drag> X2 moved while pressed - *X2Drag* + <X2Release> X2 button release - *X2Release* + +The X1 and X2 buttons refer to the extra buttons found on some mice. The +'Microsoft Explorer' mouse has these buttons available to the right thumb. +Currently X1 and X2 only work on Win32 environments. + +Examples: > + :noremap <MiddleMouse> <LeftMouse><MiddleMouse> +Paste at the position of the middle mouse button click (otherwise the paste +would be done at the cursor position). > + + :noremap <LeftRelease> <LeftRelease>y +Immediately yank the selection, when using Visual mode. + +Note the use of ":noremap" instead of "map" to avoid a recursive mapping. +> + :map <X1Mouse> <C-O> + :map <X2Mouse> <C-I> +Map the X1 and X2 buttons to go forwards and backwards in the jump list, see +|CTRL-O| and |CTRL-I|. + + *mouse-swap-buttons* +To swap the meaning of the left and right mouse buttons: > + :noremap <LeftMouse> <RightMouse> + :noremap <LeftDrag> <RightDrag> + :noremap <LeftRelease> <RightRelease> + :noremap <RightMouse> <LeftMouse> + :noremap <RightDrag> <LeftDrag> + :noremap <RightRelease> <LeftRelease> + :noremap g<LeftMouse> <C-RightMouse> + :noremap g<RightMouse> <C-LeftMouse> + :noremap! <LeftMouse> <RightMouse> + :noremap! <LeftDrag> <RightDrag> + :noremap! <LeftRelease> <RightRelease> + :noremap! <RightMouse> <LeftMouse> + :noremap! <RightDrag> <LeftDrag> + :noremap! <RightRelease> <LeftRelease> +< + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/tips.txt b/share/vim/vim73/doc/tips.txt new file mode 100644 index 0000000000..a27463b94c --- /dev/null +++ b/share/vim/vim73/doc/tips.txt @@ -0,0 +1,534 @@ +*tips.txt* For Vim version 7.3. Last change: 2009 Nov 07 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + +Tips and ideas for using Vim *tips* + +These are just a few that we thought would be helpful for many users. +You can find many more tips on the wiki. The URL can be found on +http://www.vim.org + +Don't forget to browse the user manual, it also contains lots of useful tips +|usr_toc.txt|. + +Editing C programs |C-editing| +Finding where identifiers are used |ident-search| +Switching screens in an xterm |xterm-screens| +Scrolling in Insert mode |scroll-insert| +Smooth scrolling |scroll-smooth| +Correcting common typing mistakes |type-mistakes| +Counting words, lines, etc. |count-items| +Restoring the cursor position |restore-position| +Renaming files |rename-files| +Change a name in multiple files |change-name| +Speeding up external commands |speed-up| +Useful mappings |useful-mappings| +Compressing the help files |gzip-helpfile| +Executing shell commands in a window |shell-window| +Hex editing |hex-editing| +Using <> notation in autocommands |autocmd-<>| +Highlighting matching parens |match-parens| + +============================================================================== +Editing C programs *C-editing* + +There are quite a few features in Vim to help you edit C program files. Here +is an overview with tags to jump to: + +|usr_29.txt| Moving through programs chapter in the user manual. +|usr_30.txt| Editing programs chapter in the user manual. +|C-indenting| Automatically set the indent of a line while typing + text. +|=| Re-indent a few lines. +|format-comments| Format comments. + +|:checkpath| Show all recursively included files. +|[i| Search for identifier under cursor in current and + included files. +|[_CTRL-I| Jump to match for "[i" +|[I| List all lines in current and included files where + identifier under the cursor matches. +|[d| Search for define under cursor in current and included + files. + +|CTRL-]| Jump to tag under cursor (e.g., definition of a + function). +|CTRL-T| Jump back to before a CTRL-] command. +|:tselect| Select one tag out of a list of matching tags. + +|gd| Go to Declaration of local variable under cursor. +|gD| Go to Declaration of global variable under cursor. + +|gf| Go to file name under the cursor. + +|%| Go to matching (), {}, [], /* */, #if, #else, #endif. +|[/| Go to previous start of comment. +|]/| Go to next end of comment. +|[#| Go back to unclosed #if, #ifdef, or #else. +|]#| Go forward to unclosed #else or #endif. +|[(| Go back to unclosed '(' +|])| Go forward to unclosed ')' +|[{| Go back to unclosed '{' +|]}| Go forward to unclosed '}' + +|v_ab| Select "a block" from "[(" to "])", including braces +|v_ib| Select "inner block" from "[(" to "])" +|v_aB| Select "a block" from "[{" to "]}", including brackets +|v_iB| Select "inner block" from "[{" to "]}" + +============================================================================== +Finding where identifiers are used *ident-search* + +You probably already know that |tags| can be used to jump to the place where a +function or variable is defined. But sometimes you wish you could jump to all +the places where a function or variable is being used. This is possible in +two ways: +1. Using the |:grep| command. This should work on most Unix systems, + but can be slow (it reads all files) and only searches in one directory. +2. Using ID utils. This is fast and works in multiple directories. It uses a + database to store locations. You will need some additional programs for + this to work. And you need to keep the database up to date. + +Using the GNU id-tools: + +What you need: +- The GNU id-tools installed (mkid is needed to create ID and lid is needed to + use the macros). +- An identifier database file called "ID" in the current directory. You can + create it with the shell command "mkid file1 file2 ..". + +Put this in your .vimrc: > + map _u :call ID_search()<Bar>execute "/\\<" . g:word . "\\>"<CR> + map _n :n<Bar>execute "/\\<" . g:word . "\\>"<CR> + + function! ID_search() + let g:word = expand("<cword>") + let x = system("lid --key=none ". g:word) + let x = substitute(x, "\n", " ", "g") + execute "next " . x + endfun + +To use it, place the cursor on a word, type "_u" and vim will load the file +that contains the word. Search for the next occurrence of the word in the +same file with "n". Go to the next file with "_n". + +This has been tested with id-utils-3.2 (which is the name of the id-tools +archive file on your closest gnu-ftp-mirror). + +[the idea for this comes from Andreas Kutschera] + +============================================================================== +Switching screens in an xterm *xterm-screens* *xterm-save-screen* + +(From comp.editors, by Juergen Weigert, in reply to a question) + +:> Another question is that after exiting vim, the screen is left as it +:> was, i.e. the contents of the file I was viewing (editing) was left on +:> the screen. The output from my previous like "ls" were lost, +:> ie. no longer in the scrolling buffer. I know that there is a way to +:> restore the screen after exiting vim or other vi like editors, +:> I just don't know how. Helps are appreciated. Thanks. +: +:I imagine someone else can answer this. I assume though that vim and vi do +:the same thing as each other for a given xterm setup. + +They not necessarily do the same thing, as this may be a termcap vs. +terminfo problem. You should be aware that there are two databases for +describing attributes of a particular type of terminal: termcap and +terminfo. This can cause differences when the entries differ AND when of +the programs in question one uses terminfo and the other uses termcap +(also see |+terminfo|). + +In your particular problem, you are looking for the control sequences +^[[?47h and ^[[?47l. These switch between xterms alternate and main screen +buffer. As a quick workaround a command sequence like > + echo -n "^[[?47h"; vim ... ; echo -n "^[[?47l" +may do what you want. (My notation ^[ means the ESC character, further down +you'll see that the databases use \E instead). + +On startup, vim echoes the value of the termcap variable ti (terminfo: +smcup) to the terminal. When exiting, it echoes te (terminfo: rmcup). Thus +these two variables are the correct place where the above mentioned control +sequences should go. + +Compare your xterm termcap entry (found in /etc/termcap) with your xterm +terminfo entry (retrieved with "infocmp -C xterm"). Both should contain +entries similar to: > + :te=\E[2J\E[?47l\E8:ti=\E7\E[?47h: + +PS: If you find any difference, someone (your sysadmin?) should better check + the complete termcap and terminfo database for consistency. + +NOTE 1: If you recompile Vim with FEAT_XTERM_SAVE defined in feature.h, the +builtin xterm will include the mentioned "te" and "ti" entries. + +NOTE 2: If you want to disable the screen switching, and you don't want to +change your termcap, you can add these lines to your .vimrc: > + :set t_ti= t_te= + +============================================================================== +Scrolling in Insert mode *scroll-insert* + +If you are in insert mode and you want to see something that is just off the +screen, you can use CTRL-X CTRL-E and CTRL-X CTRL-Y to scroll the screen. + |i_CTRL-X_CTRL-E| + +To make this easier, you could use these mappings: > + :inoremap <C-E> <C-X><C-E> + :inoremap <C-Y> <C-X><C-Y> +(Type this literally, make sure the '<' flag is not in 'cpoptions'). +You then lose the ability to copy text from the line above/below the cursor +|i_CTRL-E|. + +Also consider setting 'scrolloff' to a larger value, so that you can always see +some context around the cursor. If 'scrolloff' is bigger than half the window +height, the cursor will always be in the middle and the text is scrolled when +the cursor is moved up/down. + +============================================================================== +Smooth scrolling *scroll-smooth* + +If you like the scrolling to go a bit smoother, you can use these mappings: > + :map <C-U> <C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y><C-Y> + :map <C-D> <C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E><C-E> + +(Type this literally, make sure the '<' flag is not in 'cpoptions'). + +============================================================================== +Correcting common typing mistakes *type-mistakes* + +When there are a few words that you keep on typing in the wrong way, make +abbreviations that correct them. For example: > + :ab teh the + :ab fro for + +============================================================================== +Counting words, lines, etc. *count-items* + +To count how often any pattern occurs in the current buffer use the substitute +command and add the 'n' flag to avoid the substitution. The reported number +of substitutions is the number of items. Examples: > + + :%s/./&/gn characters + :%s/\i\+/&/gn words + :%s/^//n lines + :%s/the/&/gn "the" anywhere + :%s/\<the\>/&/gn "the" as a word + +You might want to reset 'hlsearch' or do ":nohlsearch". +Add the 'e' flag if you don't want an error when there are no matches. + +An alternative is using |v_g_CTRL-G| in Visual mode. + +If you want to find matches in multiple files use |:vimgrep|. + + *count-bytes* +If you want to count bytes, you can use this: + + Visually select the characters (block is also possible) + Use "y" to yank the characters + Use the strlen() function: > + :echo strlen(@") +A line break is counted for one byte. + +============================================================================== +Restoring the cursor position *restore-position* + +Sometimes you want to write a mapping that makes a change somewhere in the +file and restores the cursor position, without scrolling the text. For +example, to change the date mark in a file: > + :map <F2> msHmtgg/Last [cC]hange:\s*/e+1<CR>"_D"=strftime("%Y %b %d")<CR>p'tzt`s + +Breaking up saving the position: + ms store cursor position in the 's' mark + H go to the first line in the window + mt store this position in the 't' mark + +Breaking up restoring the position: + 't go to the line previously at the top of the window + zt scroll to move this line to the top of the window + `s jump to the original position of the cursor + +For something more advanced see |winsaveview()| and |winrestview()|. + +============================================================================== +Renaming files *rename-files* + +Say I have a directory with the following files in them (directory picked at +random :-): + +buffer.c +charset.c +digraph.c +... + +and I want to rename *.c *.bla. I'd do it like this: > + + $ vim + :r !ls *.c + :%s/\(.*\).c/mv & \1.bla + :w !sh + :q! + +============================================================================== +Change a name in multiple files *change-name* + +Example for using a script file to change a name in several files: + + Create a file "subs.vim" containing substitute commands and a :update + command: > + :%s/Jones/Smith/g + :%s/Allen/Peter/g + :update +< + Execute Vim on all files you want to change, and source the script for + each argument: > + + vim *.let + argdo source subs.vim + +See |:argdo|. + +============================================================================== +Speeding up external commands *speed-up* + +In some situations, execution of an external command can be very slow. This +can also slow down wildcard expansion on Unix. Here are a few suggestions to +increase the speed. + +If your .cshrc (or other file, depending on the shell used) is very long, you +should separate it into a section for interactive use and a section for +non-interactive use (often called secondary shells). When you execute a +command from Vim like ":!ls", you do not need the interactive things (for +example, setting the prompt). Put the stuff that is not needed after these +lines: > + + if ($?prompt == 0) then + exit 0 + endif + +Another way is to include the "-f" flag in the 'shell' option, e.g.: > + + :set shell=csh\ -f + +(the backslash is needed to include the space in the option). +This will make csh completely skip the use of the .cshrc file. This may cause +some things to stop working though. + +============================================================================== +Useful mappings *useful-mappings* + +Here are a few mappings that some people like to use. + + *map-backtick* > + :map ' ` +Make the single quote work like a backtick. Puts the cursor on the column of +a mark, instead of going to the first non-blank character in the line. + + *emacs-keys* +For Emacs-style editing on the command-line: > + " start of line + :cnoremap <C-A> <Home> + " back one character + :cnoremap <C-B> <Left> + " delete character under cursor + :cnoremap <C-D> <Del> + " end of line + :cnoremap <C-E> <End> + " forward one character + :cnoremap <C-F> <Right> + " recall newer command-line + :cnoremap <C-N> <Down> + " recall previous (older) command-line + :cnoremap <C-P> <Up> + " back one word + :cnoremap <Esc><C-B> <S-Left> + " forward one word + :cnoremap <Esc><C-F> <S-Right> + +NOTE: This requires that the '<' flag is excluded from 'cpoptions'. |<>| + + *format-bullet-list* +This mapping will format any bullet list. It requires that there is an empty +line above and below each list entry. The expression commands are used to +be able to give comments to the parts of the mapping. > + + :let m = ":map _f :set ai<CR>" " need 'autoindent' set + :let m = m . "{O<Esc>" " add empty line above item + :let m = m . "}{)^W" " move to text after bullet + :let m = m . "i <CR> <Esc>" " add space for indent + :let m = m . "gq}" " format text after the bullet + :let m = m . "{dd" " remove the empty line + :let m = m . "5lDJ" " put text after bullet + :execute m |" define the mapping + +(<> notation |<>|. Note that this is all typed literally. ^W is "^" "W", not +CTRL-W. You can copy/paste this into Vim if '<' is not included in +'cpoptions'.) + +Note that the last comment starts with |", because the ":execute" command +doesn't accept a comment directly. + +You also need to set 'textwidth' to a non-zero value, e.g., > + :set tw=70 + +A mapping that does about the same, but takes the indent for the list from the +first line (Note: this mapping is a single long line with a lot of spaces): > + :map _f :set ai<CR>}{a <Esc>WWmmkD`mi<CR><Esc>kkddpJgq}'mJO<Esc>j +< + *collapse* +These two mappings reduce a sequence of empty (;b) or blank (;n) lines into a +single line > + :map ;b GoZ<Esc>:g/^$/.,/./-j<CR>Gdd + :map ;n GoZ<Esc>:g/^[ <Tab>]*$/.,/[^ <Tab>]/-j<CR>Gdd + +============================================================================== +Compressing the help files *gzip-helpfile* + +For those of you who are really short on disk space, you can compress the help +files and still be able to view them with Vim. This makes accessing the help +files a bit slower and requires the "gzip" program. + +(1) Compress all the help files: "gzip doc/*.txt". + +(2) Edit "doc/tags" and change the ".txt" to ".txt.gz": > + :%s=\(\t.*\.txt\)\t=\1.gz\t= + +(3) Add this line to your vimrc: > + set helpfile={dirname}/help.txt.gz + +Where {dirname} is the directory where the help files are. The |gzip| plugin +will take care of decompressing the files. +You must make sure that $VIMRUNTIME is set to where the other Vim files are, +when they are not in the same location as the compressed "doc" directory. See +|$VIMRUNTIME|. + +============================================================================== +Executing shell commands in a window *shell-window* + +There have been questions for the possibility to execute a shell in a window +inside Vim. The answer: you can't! Including this would add a lot of code to +Vim, which is a good reason not to do this. After all, Vim is an editor, it +is not supposed to do non-editing tasks. However, to get something like this, +you might try splitting your terminal screen or display window with the +"splitvt" program. You can probably find it on some ftp server. The person +that knows more about this is Sam Lantinga <slouken@cs.ucdavis.edu>. +An alternative is the "window" command, found on BSD Unix systems, which +supports multiple overlapped windows. Or the "screen" program, found at +www.uni-erlangen.de, which supports a stack of windows. + +============================================================================== +Hex editing *hex-editing* *using-xxd* + +See section |23.4| of the user manual. + +If one has a particular extension that one uses for binary files (such as exe, +bin, etc), you may find it helpful to automate the process with the following +bit of autocmds for your <.vimrc>. Change that "*.bin" to whatever +comma-separated list of extension(s) you find yourself wanting to edit: > + + " vim -b : edit binary using xxd-format! + augroup Binary + au! + au BufReadPre *.bin let &bin=1 + au BufReadPost *.bin if &bin | %!xxd + au BufReadPost *.bin set ft=xxd | endif + au BufWritePre *.bin if &bin | %!xxd -r + au BufWritePre *.bin endif + au BufWritePost *.bin if &bin | %!xxd + au BufWritePost *.bin set nomod | endif + augroup END + +============================================================================== +Using <> notation in autocommands *autocmd-<>* + +The <> notation is not recognized in the argument of an :autocmd. To avoid +having to use special characters, you could use a self-destroying mapping to +get the <> notation and then call the mapping from the autocmd. Example: + + *map-self-destroy* > + " This is for automatically adding the name of the file to the menu list. + " It uses a self-destroying mapping! + " 1. use a line in the buffer to convert the 'dots' in the file name to \. + " 2. store that in register '"' + " 3. add that name to the Buffers menu list + " WARNING: this does have some side effects, like overwriting the + " current register contents and removing any mapping for the "i" command. + " + autocmd BufNewFile,BufReadPre * nmap i :nunmap i<CR>O<C-R>%<Esc>:.g/\./s/\./\\./g<CR>0"9y$u:menu Buffers.<C-R>9 :buffer <C-R>%<C-V><CR><CR> + autocmd BufNewFile,BufReadPre * normal i + +Another method, perhaps better, is to use the ":execute" command. In the +string you can use the <> notation by preceding it with a backslash. Don't +forget to double the number of existing backslashes and put a backslash before +'"'. +> + autocmd BufNewFile,BufReadPre * exe "normal O\<C-R>%\<Esc>:.g/\\./s/\\./\\\\./g\<CR>0\"9y$u:menu Buffers.\<C-R>9 :buffer \<C-R>%\<C-V>\<CR>\<CR>" + +For a real buffer menu, user functions should be used (see |:function|), but +then the <> notation isn't used, which defeats using it as an example here. + +============================================================================== +Highlighting matching parens *match-parens* + +This example shows the use of a few advanced tricks: +- using the |CursorMoved| autocommand event +- using |searchpairpos()| to find a matching paren +- using |synID()| to detect whether the cursor is in a string or comment +- using |:match| to highlight something +- using a |pattern| to match a specific position in the file. + +This should be put in a Vim script file, since it uses script-local variables. +It skips matches in strings or comments, unless the cursor started in string +or comment. This requires syntax highlighting. + +A slightly more advanced version is used in the |matchparen| plugin. +> + let s:paren_hl_on = 0 + function s:Highlight_Matching_Paren() + if s:paren_hl_on + match none + let s:paren_hl_on = 0 + endif + + let c_lnum = line('.') + let c_col = col('.') + + let c = getline(c_lnum)[c_col - 1] + let plist = split(&matchpairs, ':\|,') + let i = index(plist, c) + if i < 0 + return + endif + if i % 2 == 0 + let s_flags = 'nW' + let c2 = plist[i + 1] + else + let s_flags = 'nbW' + let c2 = c + let c = plist[i - 1] + endif + if c == '[' + let c = '\[' + let c2 = '\]' + endif + let s_skip ='synIDattr(synID(line("."), col("."), 0), "name") ' . + \ '=~? "string\\|comment"' + execute 'if' s_skip '| let s_skip = 0 | endif' + + let [m_lnum, m_col] = searchpairpos(c, '', c2, s_flags, s_skip) + + if m_lnum > 0 && m_lnum >= line('w0') && m_lnum <= line('w$') + exe 'match Search /\(\%' . c_lnum . 'l\%' . c_col . + \ 'c\)\|\(\%' . m_lnum . 'l\%' . m_col . 'c\)/' + let s:paren_hl_on = 1 + endif + endfunction + + autocmd CursorMoved,CursorMovedI * call s:Highlight_Matching_Paren() + autocmd InsertEnter * match none +< + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/todo.txt b/share/vim/vim73/doc/todo.txt new file mode 100644 index 0000000000..b2ab959adf --- /dev/null +++ b/share/vim/vim73/doc/todo.txt @@ -0,0 +1,4748 @@ +*todo.txt* For Vim version 7.3. Last change: 2010 Aug 15 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + + TODO list for Vim *todo* + +This is a veeeery long list of known bugs, current work and desired +improvements. To make it a little bit accessible, the items are grouped by +subject. In the first column of the line a classification is used to be able +to look for "the next thing to do": + +Priority classification: +9 next point release +8 next release +7 as soon as possible +6 soon +5 should be included +4 nice to have +3 consider including +2 maybe not +1 probably not +- unclassified + + *votes-for-changes* +See |develop.txt| for development plans. You can vote for which items should +be worked on, but only if you sponsor Vim development. See |sponsor|. + + *known-bugs* +-------------------- Known bugs and current work ----------------------- + +":find e" completion, editing a file in the Vim source directory, 'path' set +to "./proto", does not shorten ./proto/eval.pro, probably because of +./proto/ex_eval.pro. + +Problem with \NL in Ex script. (Ray Frish, 2010 Aug 10) + +Bug: E685 error for func_unref(). (ZyX, 2010 Aug 5) + +CTRL-] on help tag |/[\n]| doesn't jump to the right place. (Tony Mechelynck, +2010 Aug 8) + +":command Print echo 'print'" works, but ":Print" doesn't. Builtin Print +should be overruled. (Aaron Thoma) + +GTK: drawing a double-width combining character over single-width characters +doesn't look right. (Dominique Pelle, 2010 Aug 8) + +Editing a file with a ^M with 'ff' set to "mac", opening a help file, then the +^M is displayed as ^J sometimes. Getting 'ff' value from wrong window/buffer? + +Problem producing tags file when hebrew.frx is present. It has a BOM. +Results in E670. (Tony Mechelynck, 2010 May 2) + +setpos() does not restore cursor position after :normal. (Tyru, 2010 Aug 11) + +Test 73 fails on MS-Windows when compiled with DJGPP and run twice. How to +delete the Xfind directory? Add an rmdir() function, just like we have +mkdir(). + +'cindent' not correct when 'list' is set. (Zdravi Korusef, 2010 Apr 15) + +":helpgrep" does not put the cursor in the correct column when preceded by +accented character. (Tony Mechelynck, 2010 Apr 15) + +Echo starts in the wrong column: + while 1 | let s = input('A') | echo 'R' | endw +(Boyko Bantchev, 2010 Aug 9) + +Patch: Let rare word highlighting overrule good word highlighting. +(Jakson A. Aquino, 2010 Jul 30) + +Patch to make more characters work in dialogs. (Yankwei Jia, 2010 Aug 4) + +":drop" does not respect 'autochdir'. (Peter Odding, 2010 Jul 24) + +Problem with cursor in the wrong column. (SungHyun Nam, 2010 Mar 11) +Additional info by Dominique Pelle. (also on 2010 Apr 10) + +Is ~/bin (literally) in $PATH supposed to work? (Paul, 2010 March 29) +Looks like only bash can do it. (Yakov Lerner) + +8 Add an event like CursorHold that is triggered repeatedly, not just once + after typing something. +Need for CursorHold that retriggers. Use a key that doesn't do anything, or a +function that resets did_cursorhold. + +Cscope "cs add" stopped working somewhat before 7.2.438. (Gary Johnson, 2010 +Jun 29) Caused by 7.2.433? + +I often see pasted text (from Firefox, to Vim in xterm) appear twice. +Also, Vim in xterm sometimes loses copy/paste ability (probably after running +an external command). + +Jumplist doesn't work properly in Insert mode? (Jean Johner, 2010 Mar 20) + +Problem with transparent cmdline. Also: Terminal title is wrong with +non-ASCII character. (Lily White, 2010 Mar 7) + +iconv() doesn't fail on an illegal character, as documented. (Yongwei Wu, 2009 +Nov 15, example Nov 26) Add argument to specify whether iconv() should fail +or replace with a character and continue? + +Add local time at start of --startuptime output. +Requires configure check for localtime(). +Use format year-month-day hr:min:sec. + +Shell not recognized properly if it ends in "csh -f". (James Vega, 2009 Nov 3) +Find tail? Might have a / in argument. Find space? Might have space in +path. + +":function f(x) keepjumps" creates a function where every command is executed +like it has ":keepjumps" before it. + +Coverity: ask someone to create new user: Dominique. +Check if there are new reported defects: http://scan.coverity.com/rung2.html + +When setting 'undofile' while the file is already loaded, but unchanged, try +to read the undo file. Requires computing a checksum of the text. (Andy +Wokula) + +Bug with 'incsearch' going to wrong line. (Wolfram Kresse, 2009 Aug 17) +Only with "vim -u NONE". + +Problem with editing file in binary mode. (Ingo Krabbe, 2009 Oct 8) + +Display error when 'tabline' that includes a file name with double-width +characters. (2010 Aug 14, bootleq) + +Problem with stop directory in findfile(). (Adam Simpkins, 2009 Aug 26) + +Undo problem: line not removed as expected when using setline() from Insert +mode. (Israel Chauca, 2010 May 13, more in second msg) +Break undo when CTRL-R = changes the text? Or save more lines? + +Change to C syntax folding to make it work much faster, but a bit less +reliable. (Lech Lorens, 2009 Nov 9) Enable with an option? +Most time is spent in in_id_list(). + +Slow combination of folding and PHP syntax highlighting. Script to reproduce +it. Caused by "syntax sync fromstart" in combination with patch 7.2.274. +(Christian Brabandt, 2010 May 27) + +When completion inserts the first match, it may trigger the line to be folded. +Disable updating folds while completion is active? (Peter Odding, 2010 Jun 9) + +In command line window ":close" doesn't work properly. (Tony Mechelynck, 2009 +Jun 1) + +When a:base in 'completefunc' starts with a number it's passed as a number, +not a string. (Sean Ma) Need to add flag to call_func_retlist() to force a +string value. + +There is no command line completion for ":lmap". + +Invalid read error in Farsi mode. (Dominique Pelle, 2009 Aug 2) + +For running gvim on an USB stick: avoid the OLE registration. Use a command +line argument -noregister. + +When a mapping exists both for insert mode and lang-insert mode, the last one +doesn't work. (Tyru, 2010 May 6) Or is this intended? + +Still a problem with ":make" in the wrong directory. Caused by ":bufdo". +(Ajit Thakkar, 2009 Jul 1) More information Jul 9, Jul 15. +Caused by "doautoall syntaxset BufEnter *" in syntax/nosyntax.vim ? +There also is a BufLeave/BufEnter aucmd to save/restore view. +Does the patch to save/restore globaldir work? + +":bufdo normal gg" while 'hidden' is set leaves buffers without syntax +highlighting. Don't disable Syntax autocommands then? Or add a flag/modifier +to avoid changing 'eventignore'? + +Patch for displaying 0x200c and 0x200d. (Ali Gholami Rudi, 2009 May 6) +Probably needs a bit of work. + +List of encoding aliases. (Takao Fujiware, 2009 Jul 18) +Are they all OK? Update Jul 22. + +Win32: Expanding 'path' runs into a maximum size limit. (bgold12, 2009 Nov 15) + +Putting a Visual block while 'visualedit' is "all" does not leave the cursor +on the first character. (John Beckett, 2010 Aug 7) + +Setting 'tags' to "tagsdir/*" does not find "tagsdir/tags". (Steven K. Wong, +2009 Jul 18) + +Patch to add farsi handling to arabic.c (Ali Gholami Rudi, 2009 May 2) +Added test, updates, June 23. + +Patch to add "focusonly" to 'scrollopt', so that scrollbind also applies in +window that doesn't have focus. (Jonathon Mah, 2009 Jan 12) +Needs more work. + +Problem with <script> mappings (Andy Wokula, 2009 Mar 8) + +When starting Vim with "gvim -f -u non_existent_file > foo.txt" there are a +few control characters in the output. (Dale Wiles, 2009 May 28) + +'cmdwinheight is only used in last window when 'winheight' is a large value. +(Tony Mechelynck, 2009 Apr 15) + +Status line containing winnr() isn't updated when splitting the window (Clark +J. Wang, 2009 Mar 31) + +When $VIMRUNTIME is set in .vimrc, need to reload lang files. Already done +for GTK, how about others? (Ron Aaron, 2010 Apr 10) + +Patch for GTK buttons X1Mouse and X2Mouse. (Christian J. Robinson, 2010 Aug 9) + +Motif: Build on Ubuntu can't enter any text in dialog text fields. + +When 'ft' changes redraw custom status line. + +":tab split fname" doesn't set the alternate file in the original window, +because win_valid() always returns FALSE. Below win_new_tabpage() in +ex_docmd.c. + +Space before comma in function definition not allowed: "function x(a , b)" +Give a more appropriate error message. Add a remark to the docs. + +string_convert() should be able to convert between utf-8 and utf-16le. Used +for GTK clipboard. Avoid requirement for iconv. + +Now that colnr_T is int instead of unsigned, more type casts can be removed. + +'delcombine' does not work for the command line. (Tony Mechelynck, 2009 Jul +20) + +Unwanted file name escaping: ":echo input('file:' , '', 'file')" +And use file name completion on a file with spaces. (Frederic Hardy, 2009 Mar +23) + +Don't load macmap.vim on startup, turn it into a plugin. (Ron Aaron, +2009 Apr 7) Reminder Apr 14. + +Add "no_hlsearch" to winsaveview(). + +Cursorline highlighting combines with Search ('hlsearch') but not with +SpellBad. (Jim Karsten, 2009 Mar 18) + +When 'foldmethod' is "indent", using >> on a line just above a fold makes the +cursor line folded. (Evan Laforge, 2009 Oct 17) + +When 'foldmethod' is "indent", adding an empty line below a fold and then +indented text, creates a new fold instead of joining it with the previous one. +(Evan Laforge, 2009 Oct 17) + +Bug: When reloading a buffer changed outside of Vim, BufRead autocommands +are applied to the wrong buffer/window. (Ben Fritz, 2009 Apr 2, May 11) +Ignore window options when not in the right window? +Perhaps we need to use a hidden window for applying autocommands to a buffer +that doesn't have a window. + +When using "ab foo bar" and mapping <Tab> to <Esc>, pressing <Tab> after foo +doesn't trigger the abbreviation like <Esc> would. (Ramana Kumar, 2009 Sep 6) + +getbufvar() to get a window-local option value for a buffer that's not +displayed in a window should return the value that's stored for that buffer. + +":he ctrl_u" can be auto-corrected to ":he ctrl-u". + +There should be a way after an abbreviation has expanded to go back to what +was typed. CTRL-G h ? Would also undo last word or line break inserted +perhaps. And undo CTRL-W. CTRL-G l would redo. + +Diff mode out of sync. (Gary Johnson, 2010 Aug 4) + +Win32: A --remote command that has a directory name starting with a ( doesn't +work, the backslash is removed, assuming that it escapes the (. (Valery +Kondakoff, 2009 May 13) + +Win32 GUI: Changing manifest helps for dpi changes (Joe Castro, 2009 Mar 27) + +Win32 GUI: last message from startup doesn't show up when there is an echoerr +command. (Cyril Slobin, 2009 Mar 13) + +Win32: use different args for SearchPath()? (Yasuhiro Matsumoto, 2009 Jan 30) + +Win32: completion of file name ":e c:\!test" results in ":e c:\\!test", which +does not work. (Nieko Maatjes, 2009 Jan 8, Ingo Karkat, 2009 Jan 22) + +opening/closing window causes other window with 'winfixheight' to change +height. Also happens when there is another window in the frame, if it's not +very high. (Yegappan Lakshmanan, 2010 Jul 22, Michael Peeters, 2010 Jul 22) + +Directory wrong in session file, caused by ":lcd" in BufEnter autocommand. +(Felix Kater, 2009 Mar 3) + +maparg() doesn't return the flags, such as <buffer>, <script>, <silent>. +These are needed to save and restore a mapping. +Also: the rhs string is not always correct. (Hari Krishna Dara, 2009 Sept 29) + +Using ~ works OK on 'a' with composing char, but not on 0x0418 with composing +char 0x0301. (Tony Mechelynck, 2009 Mar 4) + +Inconsistent: starting with $LANG set to es_ES.utf-8 gives Spanish +messages, even though locale is not supported. But ":lang messages +es_ES.utf-8" gives an error and doesn't switch messages. (Dominique Pelle, +2009 Jan 26) + +When $HOME contains special characters, sich as a comma, escape them when used +in an option. (Michael Hordijk, 2009 May 5) +Turn "esc" argument of expand_env_esc() into string of chars to be escaped. + +Can 'undolevels' be a buffer-local option? Helps for making big changes in +one file only, set 'ul' to -1 only for that buffer. + +Should make 'ignorecase' global-local, so that it makes sense setting it from +a modeline. + +Add cscope target to Makefile. (Tony Mechelynck, 2009 Jun 18, replies by +Sergey Khorev) + +Consider making YankRing or something else that keeps a list of yanked text +part of standard Vim. The "1 to "9 registers are not sufficient. + +netrw: dragging status line causes selection of entry. Should check row +number to be below last visible line. + +After doing "su" $HOME can be the old user's home, thus ~root/file is not +correct. Don't use it in the swap file. + +Completion for ":buf" doesn't work properly on Win32 when 'shellslash' is off. +(Henrik Ohman, 2009, Jan 29) + +Allow patches to add something to version.c, like with an official patch, so +that :version output shows which patches have been applied. + +Bug: in Ex mode (after "Q") backslash before line break, when yanked into a +register and executed, results in <Nul>: instead of line break. +(Konrad Schwarz, 2010 Apr 16) + +Have a look at patch for utf-8 line breaking. (Yongwei Wu, 2008 Mar 1, Mar 23) +Now at: http://vimgadgets.sourceforge.net/liblinebreak/ + +Greek sigma character should be lower cased depending on the context. Can we +make this work? (Dominique Pelle, 2009 Sep 24) + +When changing 'encoding' convert all the swap file names, so that we can +still delete them. Also convert all buffer file names? + +"gqip" in Insert mode has an off-by-one error, causing it to reflow text. +(Raul Coronado, 2009 Nov 2) + +Update src/testdir/main.aap. + +"vim -c 'sniff connect'" hangs Vim. (Dominique Pelle, 2008 Dec 7) + +Something wrong with session that has "cd" commands and "badd", in such a way +that Vim doesn't find the edited file in the buffer list, causing the +ATTENTION message? (Tony Mechelynck, 2008 Dec 1) +Also: swap files are in ~/tmp/ One has relative file name ".mozilla/...". + +Add v:motion_force. (Kana Natsuno, 2008 Dec 6) + +Runtime files for Clojure. (Toralf Wittner, 2008 Jun 25) + +MS-Windows: editing the first, empty buffer, 'ffs' set to "unix,dos", ":enew" +doesn't set 'ff' to "unix". (Ben Fritz, 2008 Dec 5) Reusing the old buffer +probably causes this. + +'scrollbind' is not respected when deleting lines or undo. (Milan Vancura, +2009 Jan 16) + +Document that default font in Athena can be set with resources: + XtDefaultFont: "9x15" + XtDefaultFontSet: "9x15" +(Richard Sherman, 2009 Apr 12) + +Having "Syntax" in 'eventignore' for :bufdo may cause problems, e.g. for +":bufdo e" when buffers are open in windows. ex_listdo(eap) could set the +option only for when jumping to another buffer, not when the command argument +is executed. + +Crash with dragn-n-drop of file combined with netrw (Marius Gedminas, 2008 Jun +11) I can't reproduce it. It's probably caused by a handle_drop() call +in combination with autocommands that invoke a ":redraw" command. +Another valgrind output Jun 30. + +":pedit %" with a BufReadPre autocommand causes the cursor to move to the +first line. (Ingo Karkat, 2008 Jul 1) Ian Kelling is working on this. + +Wildmenu not deleted: "gvim -u NONE", ":set nocp wildmenu cmdheight=3 +laststatus=2", CTRL-D CTRL-H CTRL-H CTRL-H. (A.Politz, 2008 April 1) +Works OK with Vim in an xterm. + +Cursor line moves in other window when using CTRL-W J that doesn't change +anything. (Dasn, 2009 Apr 7) + +On Unix "glob('does not exist~')" returns the string. Without the "~" it +doesn't. (John Little, 2008 Nov 9) +Shell expansion returns unexpanded string? +Don't use shell when "~" is not at the start? + +":unlet $VAR" doesn't work. + +When using ":e ++enc=foo file" and the file is already loaded with +'fileencoding' set to "bar", then do_ecmd() uses that buffer, even though the +fileencoding differs. Reload the buffer in this situation? Need to check for +the buffer to be unmodified. +Unfinished patch by Ian Kelling, 2008 Jul 11. Followup Jul 14, need to have +another look at it. + +Patch for c.vim and cpp.vim syntax files. (Chung-chieh Shan, 2008 Nov 26) + +c.vim: XXX in a comment is colored yellow, but not when it's after "#if 0". +(Ilya Dogolazky, 2009 Aug 7) + +Win32: ":dis +" shows nothing, but "+p does insert text. Problem with "* and +"+ being the same thing? + +You can type ":w ++bad=x fname", but the ++bad argument is ignored. Give an +error message? Or is this easy to implement? (Nathan Stratton Treadway, 2008 +Aug 20) This is in ucs2bytes(), search for 0xBF. Using the ++bad argument is +at the other match for 0xBF. + +Fix for matchparen HL doesn't work. beep. + +When adding "-complete=file" to a user command this also changes how the +argument is processed for <f-args>. (Ivan Tishchenko, 2008 Aug 19) + +Win32: associating a type with Vim doesn't take care of space after a +backslash? (Robert Vibrant, 2008 Jun 5) + +After using <Tab> for command line completion after ":ta blah" and getting E33 +(no tags file), further editing the command to e.g., ":echo 'blah'", the +command is not executed. Fix by Ian Kelling? + +":help s/~" jumps to *s/\~*, while ":help s/\~" doesn't find anything. (Tim +Chase) Fix by Ian Kelling, 2008 Jul 14. + +Use "\U12345678" for 32 bit Unicode characters? (Tony Mechelynck, 2009 +Apr 6) Or use "\u(123456)", similar to Perl. + +When mapping : to ; and ; to :, @; doesn't work like @: and @: doesn't work +either. Matt Wozniski: nv_at() calls do_execreg() which uses +put_in_typebuf(). Char mapped twice? + +8 Some file systems are case-sensitive, some are not. Turn + CASE_INSENSITIVE_FILENAME into an option, at least for completion. + +Despite adding save_subexpr() this still doesn't work properly: +Regexp: matchlist('12a4aaa', '^\(.\{-}\)\(\%5c\@<=a\+\)\(.\+\)\?') +Returns ['12a4', 'aaa', '4aaa'], should be ['12a4', 'aaa', ''] +Backreference not cleared when retrying after \@<= fails? +(Brett Stahlman, 2008 March 8) + +Problem with remote_send(). (Charles Campbell, 2008 Aug 12) + +ftplugin for help file should set 'isk' to help file value. + +Win32: remote editing fails when the current directory name contains "[". +(Ivan Tishchenko, Liu Yubao) Suggested patch by Chris Lubinski: Avoid +escaping characters where the backslash is not removed later. Asked Chris for +an alternate solution, also for src/ex_getln.c. +This also fails when the file or directory name contains "%". (Thoml, 2008 +July 7) + +The str2special() function doesn't handle multi-byte characters properly. +Patch from Vladimir Vichniakov, 2007 Apr 24. +Should clean up the whole function. Also allow modifiers like <S-Char-32>? +find_special_key() also has this problem. + +Problem with 'langmap' being used on the rhs of a mapping. (Nikolai Weibull, +2008 May 14) + +Problem with CTRL-F. (Charles Campbell, 2008 March 21) +Only happens with "gvim -geometry "160x26+4+27" -u NONE -U NONE prop.c". +'lines' is 54. (2008 March 27) + +Problem with pointer wrapping around in getvcol(). (Wolfgang Kroworsch, 2008 +Oct 19) Check for "col" being "MAXCOL" separately? + +Unexpectedly inserting a double quote. (Anton Woellert, 2008 Mar 23) +Works OK when 'cmdheight' is 2. + +Test54 should not use shell commands. Make it portable. + +The utf class table is missing some entries: + 0x2212, minus sign + 0x2217, star + 0x2500, bar + 0x26ab, circle + +Visual line mode doesn't highlight properly when 'showbreak' is used and the +line doesn't fit. (Dasn, 2008 May 1) + +GUI: In Normal mode can't yank the modeless selection. Make "gy" do this? +Works like CTRL-Y in Command line mode. + +Mac: Move Carbon todo items to os_mac.txt. Note that this version is frozen, +try the Cocoa version. + +Mac: After a ":vsplit" the left scrollbar doesn't appear until 'columns' is +changed or the window is resized. + +Mac: Patch for configure: remove arch from ruby link args. (Knezevic, 2008 +Mar 5) Alternative: Kazuki Sakamoto, Mar 7. + +Mac: trouble compiling with Motif, requires --disable-darwin. (Raf, 2008 Aug +1) Reply by Ben Schmidt. + +C't: On utf-8 system, editing file with umlaut through Gnome results in URL +with %nn%nn, which is taken as two characters instead of one. +Try to reproduce at work. + +Patch for default choice in file changed dialog. (Bjorn Winckler, 2008 Oct 19) +Is there a way to list all the files first? + +When 'smartcase' is set and using CTRL-L to add to the search pattern it may +result in no matches. Convert chars to lower case? (Erik Wognsen, 2009 Apr +16) + +Patch for redo register. (Ben Schmidt, 2007 Oct 19) +Await response to question to make the register writable. + +src/testdir/Make_dos.mak: not all tests are included, e.g., test49, without a +remark why. + +Problem with 'ts' set to 9 and 'showbreak' to ">>>". (Matthew Winn, 2007 Oct +1) + +In the swapfile dialog, add a H(elp) option that gives more info about what +each choice does. Similar to ":help swap-exists-choices" + +try/catch not working for argument of return. (Matt Wozniski, 2008 Sep 15) + +Recognize and ignore BOM in error file. (Aleksey Baibarin) + +":tab help" always opens a new tab, while ":help" re-uses an existing window. +Would be more consistent when an existing tab is re-used. (Tony Mechelynck) + +":tab drop filename" doesn't work nicely when "filename" is open in a window +in another tab. (Tony Mechelynck, 2009 Feb 13) + +Add ":nofold". Range will apply without expanding to closed fold. + +Including NFA regexp code: +Use "\%#= to set the engine: 0 = automatic, 1 = backtracking, 2 = new. +Useful in tests. +Performance tests: +- ~/vim/test/veryslow.js (file from Daniel Fetchinson) +- ~/vim/test/slowsearch +- ~/vim/test/rgb.vim +- ~/vim/text/FeiqCfg.xml (file from Netjune) +- search for a.*e*exn in the vim executable. Go to last line to use + 'hlsearch'. + +Using Aap to build Vim: add remarks about how to set personal preferences. +Example on http://www.calmar.ws/tmp/aap.html + +Syntax highlighting wrong for transparent region. (Doug Kearns, 2007 Feb 26) +Bug in using a transparent syntax region. (Hanlen in vim-dev maillist, 2007 +Jul 31) + +C syntax: {} inside () causes following {} to be highlighted as error. +(Michalis Giannakidis, 2006 Jun 1) + +Can't easily close the help window, like ":pc" closes the preview window and +":ccl" closes the quickfix window. Add ":hclose". (Chris Gaal) + +When 'diffopt' has "context:0" a single deleted line causes two folds to merge +and mess up syncing. (Austin Jennings, 2008 Jan 31) + +Gnome improvements: Edward Catmur, 2007 Jan 7 + Also use Save/Discard for other GUIs + +New PHP syntax file, use it? (Peter Hodge) + +'foldcolumn' in modeline applied to wrong window when using a session. (Teemu +Likonen, March 19) + +Test 54 uses shell commands, that doesn't work on non-Unix systems. Use some +other way to test buffer-local autocommands. + +The documentation mentions the priority for ":2match" and ":3match", but it +appears the last one wins. (John Beckett, 2008 Jul 22) Caused by adding +matchadd()? Suggested patch by John, 2008 Jul 24. + +When 'encoding' is utf-8 the command line is redrawn as a whole on every +character typed. (Tyler Spivey, 2008 Sep 3) Only redraw cmdline for +'arabicshape' when there is a character on the command line for which +(ARABIC_CHAR(u8c)) is TRUE. + +Cheng Fang made javacomplete. (2007 Aug 11) +Asked about latest version: 0.77.1 is on www.vim.org. + +More AmigaOS4 patches. (Peter Bengtsson, Nov 9) + +Insert mode completion: When editing the text and pressing CTRL-N again goes +back to originally completed text, edited text is gone. (Peng Yu, 2008 Jul 24) +Suggestion by Ben Schmidt, 2008 Aug 6. + +Problem with compound words? (Bert, 2008 May 6) +No warning for when flags are defined after they are used in an affix. + +Screen redrawing when continuously updating the buffer and resizing the +terminal. (Yakov Lerner, 2006 Sept 7) + +Add option settings to help ftplugin. (David Eggum, 2006 Dec 18) + +Autoconf problem: when checking for iconv library we may add -L/usr/local/lib, +but when compiling further tests -liconv is added without the -L argument, +that may fail (e.g., sizeof(int)). (Blaine, 2007 Aug 21) + +When opening quickfix window, disable spell checking? + +Problem with ".add" files when using two languages and restarting Vim. (Raul +Coronado, 2008 Oct 30) + +Popup menu redraw: Instead of first redrawing the text and then drawing the +popup menu over it, first draw the new popup menu, remember its position and +size and then redraw the text, skipping the characters under the popup menu. +This should avoid flicker. Other solution by A.Politz, 2007 Aug 22. + +When the popup menu is close to the edge of the window it is truncated. Patch +to anchor the popup menu in a different way. (James Vega, 2008 Jul 30) + +Windows 98: pasting from the clipboard with text from another application has +a trailing NUL. (Joachim Hofmann) Perhaps the length specified for CF_TEXT +isn't right? + +When a register contains illegal bytes, writing viminfo in utf-8 and reading +it back doesn't result in utf-8. (Devin Bayer) + +Command line completion: Scanning for tags doesn't check for typed key now and +then? Hangs for about 5 seconds. Appears to be caused by finding include +files with "foo/**" in 'path'. (Kalisiak, 2006 July 15) +Additional info: When using the |wildcards| ** globing, vim hangs +indefinitely on lots of directories. The |file-searching| globing, like in +":set path=/**" does not hang as often as with globing with |wildcards|, like +in ":1find /**/file". This is for a files that unix "find" can find very +quick. Merging the 2 kinds of globing might make this an easier fix. (Ian +Kelling, 2008 July 4) + +When the file name has parenthesis, e.g., "foo (bar).txt", ":!ls '%'" has the +parenthesis escaped but not the space. That's inconsistent. Either escape +neither or both. No escaping might be best, because it doesn't depend on +particularities of the shell. (Zvi Har'El, 2007 Nov 10) (Teemu Likonen, 2008 +Jun 3) +However, for backwards compatibility escaping might be necessary. Check if +the user put quotes around the expanded item? + +Error E324 can be given when a cron script has wiped out our temp directory. +Give a clear error message about this (and tell them not to wipe out /tmp). + +Color for cUserLabel should differ from case label, so that a mistake in a +switch list is noticed: + switch (i) + { + case 1: + foobar: + } + +Look at http://www.gtk-server.org/ . It has a Vim script implementation. + +Netbeans problem. Use "nc -l 127.0.0.1 55555" for the server, then run gvim +with "gvim -nb:localhost:55555:foo". From nc do: '1:editFile!0 "foo"'. Then +go to Insert mode and add a few lines. Then backspacing every other time +moves the cursor instead of deleting. (Chris Kaiser, 2007 Sep 25) + +Patch to use Modern UI 2.0 for the Nsis installer. (Guopeng Wen, 2010 Jul 30) + +Changes for Win32 makefile. (Mike Williams, 2007 Jan 22, Alexei Alexandrov, +2007 Feb 8) + +Patch for Win32 clipboard under Cygwin. (Frodak Baksik, Feb 15) + Sutcliffe says it works well. + Update 2007 May 22 for Vim 7.1 + Update 2008 Dec 2008 for Vim 7.2.xx (Sharonov) + +Win32: Can't complete shell command names. Why is setting xp_context in +set_one_cmd_context() inside #ifndef BACKSLASH_IN_FILENAME? + +Win32: Patch for convert_filterW(). (Taro Muraoka, 2007 Mar 2) + +Win32: Patch for cscope external command. (Mike Williams, 2007 Aug 7) + +Win32: XPM support only works with path without spaces. Patch by Mathias +Michaelis, 2006 Jun 9. Another patch for more path names, 2006 May 31. +New version: http://members.tcnet.ch/michaelis/vim/patches.zip (also for other +patches by Mathias, see mail Feb 22) + +Win32: compiling with normal features and OLE fails. Patch by Mathias +Michaelis, 2006 Jun 4. + +Win32: echo doesn't work for gvim.exe.mnf. Use inline file. Patch by Mathias +Michaelis. http://groups.yahoo.com/group/vimdev/message/43765 +Patch that includes this and does more by George Reilly, 2007 Feb 12 + +Win16: include patches to make Win16 version work. (Vince Negri, 2006 May 22) + +Win32: after "[I" showing matches, scroll wheel messes up screen. (Tsakiridis, +2007 Feb 18) +Patch by Alex Dobrynin, 2007 Jun 3. Also fixes other scroll wheel problems. + +Win32: using CTRL-S in Insert mode doesn't remove the "+" from the tab pages +label. (Tsakiridis, 2007 Feb 18) Patch from Ian Kelling, 2008 Aug 6. + +Win32: using "gvim --remote-tab-silent fname" sometimes gives an empty screen +with the more prompt. Caused by setting the guitablabel? (Thomas Michael +Engelke, 2007 Dec 20 - 2008 Jan 17) + +Win64: Seek error in swap file for a very big file (3 Gbyte). Check storing +pointer in long and seek offset in 64 bit var. + +Win32: patch for fullscreen mode. (Liushaolin, 2008 April 17) + +Win32: When 'shell' is cmd.exe this command fails: + echo system('"c:/path/echo.exe" "foo bar"') +Should we set the default for 'shellxquote' to a double quote, when 'shell' +contains "cmd" in the tail? (Benjamin Fritz, 2008 Oct 13) +Also set 'shellcmdflag' to include /s. + +Win32: When there is 4 Gbyte of memory mch_avail_mem() doesn't work properly. +Unfinished patch by Jelle Geerts, 2008 Aug 24. +Let mch_avail_mem() return Kbyte instead? + +Win32: With two monitors, gvim partly on both, and adding/removing a scrollbar +Vim resizes and moves to one of the monitors. (Chris Monkiewicz, 2008 Oct) + +Win32: When 'shell' is bash shellescape() doesn't always do the right thing. +Depends on 'shellslash', 'shellquote' and 'shellxquote', but shellescape() +only takes 'shellslash' into account. + +Pressing the 'pastetoggle' key doesn't update the statusline. (Jan Christoph +Ebersbach, 2008 Feb 1) + +Menu item that does "xxd -r" doesn't work when 'fileencoding' is utf-16. +Check for this and use iconv? (Edward L. Fox, 2007 Sep 12) +Does the conversion in the other direction work when 'filenecodings' is set +properly? + +Cursor displayed in the wrong position when using 'numberwidth'. (James Vega, +2007 Jun 21) + +When $VAR contains a backslash expand('$VAR') removes it. (Teemu Likonen, 2008 +Jun 18) + +If the variable "g:x#y#z" exists completion after ":echo g:x#" doesn't work. + +Feature request: Command to go to previous tab, like what CTRL-W p does for +windows. (Adam George) + +When using input() in a loop and then ":echo" the display column isn't right. +(Benjamin Fritz, 2008 Aug 28) Patch by Ben Schmidt, 2008 Sep 2. + +F1 - F4 in an xterm produce a different escape sequence when used with a +modifier key. Need to catch three different sequences. Use K_ZF1, like +K_ZHOME? (Dickey, 2007 Dec 2) + +UTF-8: mapping a multi-byte key where the second byte is 0x80 doesn't appear +to work. (Tony Mechelynck, 2007 March 2) + +In debug mode, using CTRL-R = to evaluate a function causes stepping through +the function. (Hari Krishna Dara, 2006 Jun 28) + +C++ indenting wrong with "=". (James Kanze, 2007 Jan 26) + +":lockvar" should use copyID to avoid endless loop. + +When using --remote-silent and the file name matches 'wildignore' get an E479 +error. without --remote-silent it works fine. (Ben Fritz, 2008 Jun 20) + +Gvim: dialog for closing Vim should check if Vim is busy writing a file. Then +use a different dialog: "busy saving, really quit? yes / no". + +Check other interfaces for changing curbuf in a wrong way. Patch like for +if_ruby.c. + +":helpgrep" should use the directory from 'helpfile'. + +Patch to dynamically load Python on Solaris. (Danek Duvall, 2009 Feb 16) +Needs more work. + +The need_fileinfo flag is messy. Instead make the message right away and put +it in keep_msg? + +Editing a file remotely that matches 'wildignore' results in a "no match" +error. Should only happen when there are wildcards, not when giving the file +name literally, and esp. if there is only one name. + +Test 61 fails sometimes. This is a timing problem: "sleep 2" sometimes takes +longer than 2 seconds. + +Using ":au CursorMoved * cmd" invokes mch_FullName(), which can be slow. +Can this be avoided? (Thomas Waba, 2008 Aug 24) +Also for ":w" without a file name. +The buffer has the full path in ffname, should pass this to the autocommand. + +"vim -C" often has 'nocompatible', because it's set in some startup script. +Set 'compatible' after startup is done? Patch by James Vega, 2008 Feb 7. + +VMS: while editing a file found in complex, Vim will save file into the first +directory of the path and not to the original location of the file. +(Zoltan Arpadffy) + +VMS: VFC files are in some cases truncated during reading (Zoltan Arpadffy) + +input() completion should not insert a backslash to escape a space in a file +name? + +getpos()/setpos() don't include curswant. getpos() could return a fifth +element. setpos() could accept an optional fifth element. + +Ruby completion is insecure. Can this be fixed? + +When 'backupskip' is set from $TEMP special characters need to be escaped. +(patch by Grembowietz, 2007 Feb 26, not quite right) +Another problem is that file_pat_to_reg_pat() doesn't recognize "\\", so "\\(" +will be seen as a path separator plus "\(". + +gvim d:\path\path\(FILE).xml should not remove the \ before the (. +This also fails with --remote. + +When doing ":quit" the Netbeans "killed" event isn't sent. (Xavier de Gaye, +2008 Nov 10) call netbeans_file_closed() at the end of buf_freeall(), or in +all places where buf_freeall() is called? + +":python os.chdir('/tmp')" makes short buffer names invalid. (Xavier de Gaye) +Check directory and call shorten_fnames()? + +aucmd_prepbuf() should also use a window in another tab page. + +When unloading a buffer in a BufHidden autocommand the hidden flag is reset? +(Bob Hiestand, 2008 Aug 26, Aug 27) + +Substituting an area with a line break with almost the same area does change +the Visual area. Can this be fixed? (James Vega, 2006 Sept 15) + +Windows installer could add a "open in new tab of existing Vim" menu entry. +Gvimext: patch to add "Edit with single Vim &tabbed" menu entry. +Just have two choices, always using one Vim and selecting between using an +argument list or opening each file in a separate tab. +(Erik Falor, 2008 May 21, 2008 Jun 26) + +GUI: When combining fg en bg make sure they are not equal. + +Spell checking: Add a way to specify punctuation characters. Add the +superscript numbers by default: 0x2070, 0xb9, 0xb2, 0xb3, 0x2074 - 0x2079. + +Spell checking in popup menu: If the only problem is the case of the first +character, don't offer "ignore" and "add to word list". + +Use different pt_br dictionary for spell checking. (Jackson A. Aquino, 2006 +Jun 5) + +Use different romanian dictionary for spell checking. (Andrei Popescu, Nov +2008) Use http://downloads.sourceforge.net/rospell/ro_RO.3.2.zip +Or the hunspell-ro.3.2.tar.gz file, it also has a iso-8859-2 list. + +In a C file with spell checking, in "% integer" "nteger" is seen as an error, +but "]s" doesn't find it. "nteger" by itself is found. (Ralf Wildenhues, 2008 +Jul 22) + +There should be something about spell checking in the user manual. + +Spell menu: When using the Popup menu to select a replacement word, +":spellrepeat" doesn't work. SpellReplace() uses setline(). Can it use "z=" +somehow? Or use a new function. + +Mac: Using gvim: netrw window disappears. (Nick Lo, 2006 Jun 21) + +Mac: OS/X 10.4 with Python 2.5 installed: configure finds an extra argument +that breaks the build. (Brian Victor, 2008 Sep 1) + +Add an option to specify the character to use when a double-width character is +moved to the next line. Default '>', set to a space to blank it out. Check +that char is single width when it's set (compare with 'listchars'). + +The generated vim.bat can avoid the loop for NT. (Carl Zmola, 2006 Sep 3) + +Session file creation: 'autochdir' causes trouble. Keep it off until after +loading all files. + +Win32: When 'autochdir' is on and 'encoding' is changed, files on the command +line are opened again, but from the wrong directory. Apply 'autochdir' only +after starting up? + +When showing a diff between a non-existent file and an existing one, with the +cursor in the empty buffer, the other buffer only shows the last line. Change +the "insert" into a change from one line to many? (Yakov Lerner, 2008 May 27) + +Add autocommand for when a tabpage is being closed. Also for when a tab page +has been created. + +Using ":make" blocks Vim. Allow running one make in the background (if the +shell supports it), catch errors in a file and update the error list on the +fly. A bit like "!make > file&" and repeating ":cf file". ":bgmake", +background make. ":bgcancel" interrupts it. +A.Politz may work on this. + +These two abbreviations don't give the same result: + let asdfasdf = "xyz\<Left>" + cabbr XXX <C-R>=asdfasdf<CR> + cabbr YYY xyz<Left> + +Michael Dietrich: maximized gvim sometimes displays output of external command +partly. (2006 Dec 7) + +In FileChangedShell command it's no longer allowed to switch to another +buffer. But the changed buffer may differ from the current buffer, how to +reload it then? + +New syntax files for fstab and resolv from Radu Dineiu, David Necas did +previous version. + +For Aap: include a config.arg.example file with hints how to use config.arg. + +Command line completion when 'cmdheight' is maximum and 'wildmenu' is set, +only one buffer line displayed, causes display errors. + +Completing with 'wildmenu' and using <Up> and <Down> to move through directory +tree stops unexpectedly when using ":cd " and entering a directory that +doesn't contain other directories. + +Linux distributions: +- Suggest compiling xterm with --enable-tcap-query, so that nr of colors is + known to Vim. 88 colors instead of 16 works better. See ":help + xfree-xterm". +- Suggest including bare "vi" and "vim" with X11, syntax, etc. + +Completion menu: For a wrapping line, completing a long file name, only the +start of the path is shown in the menu. Should move the menu to the right to +show more text of the completions. Shorten the items that don't fit in the +middle? + +When running inside screen it's possible to kill the X server and restart it +(using pty's the program can keep on running). Vim dies because it loses the +connection to the X server. Can Vim simply quit using the X server instead of +dying? Also relevant when running in a console. + +Accessing file#var in a function should not need the g: prepended. + +When exiting detects a modified buffer, instead of opening the buffer in the +current tab, use an existing tab, if possible. Like finding a window where +the buffer is displayed. (Antonios Tsakiridis) + +When ":cn" moves to an error in the same line the message isn't shortened. +Only skip shortening for ":cc"? + +Write "making vim work better" for the docs (mostly pointers): *nice* + - sourcing $VIMRUNTIME/vimrc_example.vim + - setting 'mouse' to "a" + - getting colors in xterm + - compiling Vim with X11, GUI, etc. + +Problem with ":call" and dictionary function. Hari Krishna Dara, Charles +Campbell 2006 Jul 06. + +Syntax HL error caused by "containedin". (Peter Hodge, 2006 Oct 6) + +A custom completion function in a ":command" cannot be a Funcref. (Andy +Wokula, 2007 Aug 25) + +Problem with using :redir in user command completion function? (Hari Krishna +Dara, 2006 June 21) + +Another resizing problem when setting 'columns' and 'lines' to a very large +number. (Tony Mechelynck, 2007 Feb 6) + +After starting Vim, using '0 to jump somewhere in a file, ":sp" doesn't center +the cursor line. It works OK after some other commands. + +Win32: Is it possible to have both postscript and Win32 printing? +Does multi-byte printing with ":hardcopy" work? Add remark in documentation +about this. + +Check: Running Vim in a console and still having connect to the X server for +copy/paste: is stopping the X server handled gracefully? Should catch the X +error and stop using the connection to the server. + +Problem with 'cdpath' on MS-Windows when a directory is equal to $HOME. (2006 +Jul 26, Gary Johnson) + +Using UTF-8 character with ":command" does not work properly. (Matt Wozniski, +2008 Sep 29) + +In the Netbeans interface add a "vimeval" function, so that the other side can +check the result of has("patch13"). + +Cursor line at bottom of window instead of halfway after saving view and +restoring. Only with 'nowrap'. (Robert Webb, 2008 Aug 25) + +Add command modifier that skips wildcard expansion, so that you don't need to +put backslashes before special chars, only for white space. + +Syntax HL: open two windows on the same C code, delete a ")" in one window, +resulting in highlighted "{" in that window, not in the other. + +In mswin.vim: Instead of mapping <C-V> for Insert mode in a complicated way, +can it be done like ":imap <C-V> <MiddleMouse>" without negative side effects? + +Win32: When the GUI tab pages line is displayed Vim jumps from the secondary +to the primary monitor. (Afton Lewis, 2007 Mar 9) Old resizing problem? + +GTK: when the Tab pages bar appears or disappears while the window is +maximized the window is no longer maximized. Patch that has some idea but +doesn't work from Geoffrey Antos, 2008 May 5. +Also: the window may no longer fit on the screen, thus the command line is not +visible. + +GTK: when setting 'columns' in a startup script and doing ":vertical diffsplit" +the window isn't redrawn properly, see two vertical bars. + +The magic clipboard format "VimClipboard2" appears in several places. Should +be only one. + +"vim -C" often has 'nocompatible', because it's set somewhere in a startup +script. Do "set compatible" after startup? + +It's difficult to debug numbered functions (function in a Dictionary). Print +the function name before resolving it to a number? + let d = {} + fun! d.foo() + echo "here" + endfun + call d.foo(9) + +Add a mark for the other end of the Visual area (VIsual pos). '< and '> are +only set after Visual moded is ended. +Also add a variable for the Visual mode. So that this mode and '< '> can be +used to set what "gv" selects. (Ben Schmidt) + +Win32: When running ":make" and 'encoding' differs from the system locale, the +output should be converted. Esp. when 'encoding' is "utf-8". (Yongwei Wu) +Should we use 'termencoding' for this? + +Win32, NTFS: When editing a specific infostream directly and 'backupcopy' is +"auto" should detect this situation and work like 'backupcopy' is "yes". File +name is something like "c:\path\foo.txt:bar", includes a colon. (Alex +Jakushev, 2008 Feb 1) + +Small problem displaying diff filler line when opening windows with a script. +(David Luyer, 2007 Mar 1 ~/Mail/oldmail/mool/in.15872 ) + +Is it allowed that 'backupext' is empty? Problems when backup is in same dir +as original file? If it's OK don't compare with 'patchmode'. (Thierry Closen) + +Patch for supporting count before CR in quickfix window. (AOYAMA Shotaro, 2007 +Jan 1) + +Patch for adding ":lscscope". (Navdeep Parhar, 2007 Apr 26; update 2008 Apr +23) + +":mkview" isn't called with the right buffer argument. Happens when using +tabs and the autocommand "autocmd BufWinLeave * mkview". (James Vega, 2007 +Jun 18) + +xterm should be able to pass focus changes to Vim, so that Vim can check for +buffers that changed. Perhaps in misc.c, function selectwindow(). +Xterm 224 supports it! + +When completing from another file that uses a different encoding completion +text has the wrong encoding. E.g., when 'encoding' is utf-8 and file is +latin1. Example from Gombault Damien, 2007 Mar 24. + +Is it possible to use "foo#var" instead of "g:foo#var" inside a function? + +Syntax HL: When using "nextgroup" and the group has an empty match, there is +no search at that position for another match. (Lukas Mai, 2008 April 11) + +In gvim the backspace key produces a backspace character, but on Linux the +VERASE key is Delete. Set VERASE to Backspace? (patch by Stephane Chazelas, +2007 Oct 16) + +When entering a C /* comment, after typing <Enter> for 70 times the indent +disappears. (Vincent Beffara, 2008 Jul 3) + +TermResponse autocommand isn't always triggered when using vimdiff. (Aron +Griffis, 2007 Sep 19) + +Create a gvimtutor.1 file and change Makefiles to install it. + +When 'encoding' is utf-8 typing text at the end of the line causes previously +typed characters to be redrawn. Caused by patch 7.1.329. (Tyler Spivey, 2008 +Sep 3, 11) + +When Vim in an xterm owns the selection and the user does ":shell" Vim doesn't +respond to selection requests. Invoking XtDisownSelection() before executing +the shell doesn't help. Would require forking and doing a message loop, like +what happens for the GUI. + +X11: Putting more than about 262040 characters of text on the clipboard and +pasting it in another Vim doesn't work. (Dominique Pelle, 2008 Aug 21-23) +clip_x11_request_selection_cb() is called with zero value and length. +Also: Get an error message from free() in the process that owns the selection. +Seems to happen when the selection is requested the second time, but before +clip_x11_convert_selection_cb() is invoked, thus in X library code. + +":vimgrep" does not recognize a recursive symlink. Is it possible to detect +this, at least for Unix (using device/inode)? + +When switching between windows the cursor is often put in the middle. +Remember the relative position and restore that, just like lnum and col are +restored. (Luc St-Louis) + +Patch to support horizontal scroll wheel in GTK. Untested. (Bjorn Winckler, +2010 Jun 30) + + +More patches: +- Another patch for Javascript indenting. (Hari Kumar, 2010 Jul 11) + Needs a few tests. +- Add 'cscopeignorecase' option. (Liang Wenzhi, 2006 Sept 3) +- Argument for feedkeys() to prepend to typeahead (Yakov Lerner, 2006 Oct + 21) +- Load intl.dll too, not only libintl.dll. (Mike Williams, 2006 May 9, docs + patch May 10) +- Extra argument to strtrans() to translate special keys to their name (Eric + Arnold, 2006 May 22) +- 'threglookexp' option: only match with first word in thesaurus file. + (Jakson A. Aquino, 2006 Jun 14) +- Mac: indicate whether a buffer was modified. (Nicolas Weber, 2006 Jun 30) +- Allow negative 'nrwidth' for left aligning. (Nathan Laredo, 2006 Aug 16) +- ml_append_string(): efficiently append to an existing line. (Brad + Beveridge, 2006 Aug 26) Use in some situations, e.g., when pasting a + character at a time? +- recognize hex numbers better. (Mark Manning, 2006 Sep 13) +- Add <AbbrExpand> key, to expand an abbreviation in a mapping. (Kana + Natsuno, 2008 Jul 17) +- Add 'wspara' option, also accept blank lines like empty lines for "{" and + "}". (Mark Lundquist, 2008 Jul 18) +- Patch to add CTRL-T to delete part of a path on cmdline. (Adek, 2008 Jul + 21) +- Instead of creating a copy of the tutor in all the shell scripts, do it in + vimtutor.vim. (Jan Minar, 2008 Jul 20) +- When fsync() fails there is no hint about what went wrong. Patch by Ben + Schmidt, 2008 Jul 22. +- testdir/Make_dos_sh.mak for running tests with MingW. (Bill Mccarthy, 2008 + Sep 13) +- Patch for adding "space" item in 'listchars'. (Jérémie Roquet, 2009 Oct 29, + Docs patch Oct 30) +- Replace ccomplete.vim by cppcomplete.vim from www.vim.org? script 1520 by + Vissale Neang. (Martin Stubenschrott) Asked Vissale to make the scripts + more friendly for the Vim distribution. + New version received 2008 Jan 6. + No maintenance in two years... +- Patch to access screen under Python. (Marko Mahni, 2010 Jul 18) +- Patch to open dropped files in new tabs. (Michael Trim, 2010 Aug 3) + +Awaiting updated patches: +9 Mac unicode patch (Da Woon Jung, Eckehard Berns): + 8 Add patch from Muraoka Taro (Mar 16) to support input method on Mac? + New patch 2004 Jun 16 + - selecting proportional font breaks display + - UTF-8 text causes display problems. Font replacement causes this. + - Command-key mappings do not work. (Alan Schmitt) + - With 'nopaste' pasting is wrong, with 'paste' Command-V doesn't work. + (Alan Schmitt) + - remove 'macatsui' option when this has been fixed. + - when 'macatsui' is off should we always convert to "macroman" and ignore + 'termencoding'? +9 HTML indenting can be slow. Caused by using searchpair(). Can search() + be used instead? A.Politz is looking into a solution. +8 Win32: Add minidump generation. (George Reilly, 2006 Apr 24) +8 Add ":n" to fnamemodify(): normalize path, remove "../" when possible. + Aric Blumer has a patch for this. He will update the patch for 6.3. +7 Completion of network shares, patch by Yasuhiro Matsumoto. + Update 2004 Sep 6. + How does this work? Missing comments. +- Patch for 'breakindent' option: repeat indent for wrapped line. (Vaclav + Smilauer, 2004 Sep 13, fix Oct 31, update 2007 May 30) + Version for latest MacVim: Tobia Conforto, 2009 Nov 23 +8 Add a few more command names to the menus. Patch from Jiri Brezina + (28 feb 2002). Will mess the translations... +7 ATTENTION dialog choices are more logical when "Delete it' appears + before "Quit". Patch by Robert Webb, 2004 May 3. +- Include flipcase patch: ~/vim/patches/wall.flipcase2 ? Make it work + for multi-byte characters. +- Win32: add options to print dialog. Patch from Vipin Aravind. +- Patch to add highlighting for whitespace. (Tom Schumm, 2003 Jul 5) + use the patch that keeps using HLF_8 if HLF_WS has not + been given values. + Add section in help files for these highlight groups? +8 "fg" and "bg" don't work in an xterm. Get default colors from xterm + with an ESC sequence. + xterm can send colors for many things. E.g. for the cursor: + <Esc>]12;?<Bel> + Can use this to get the background color and restore the colors on exit. +7 Add "DefaultFG" and "DefaultBG" for the colors of the menu. (Marcin + Dalecki has a patch for Motif and Carbon) +- Add possibility to highlight specific columns (for Fortran). Or put a + line in between columns (e.g., for 'textwidth'). + Patch to add 'hlcolumn' from Vit Stradal, 2004 May 20. +8 Add functions: + gettext() Translate a message. (Patch from Yasuhiro Matsumoto) + Update 2004 Sep 10 + Another patch from Edward L. Fox (2005 Nov 24) + Search in 'runtimepath'? + More docs needed about how to use this. + How to get the messages into the .po files? + strchars() Like strlen() and strwidth() but counting characters + instead of bytes. + confirm() add "flags" argument, with 'v' for vertical + layout and 'c' for console dialog. (Haegg) + Flemming Madsen has a patch for the 'c' flag + (2003 May 13) + raisewin() raise gvim window (see HierAssist patch for + Tcl implementation ~/vim/HierAssist/ ) + taglist() add argument to specify maximum number of matches. + useful for interactive things or completion. + col('^') column of first non-white character. + Can use "len(substitute(getline('.'), '\S.*', '', '')) + + 1", but that's ugly. +7 Add patch from Benoit Cerrina to integrate Vim and Perl functions + better. Now also works for Ruby (2001 Nov 10) +- Patch from Herculano de Lima Einloft Neto for better formatting of the + quickfix window (2004 dec 2) +7 When 'rightleft' is set, the search pattern should be displayed right + to left as well? See patch of Dec 26. (Nadim Shaikli) +8 Option to lock all used memory so that it doesn't get swapped to disk + (uncrypted). Patch by Jason Holt, 2003 May 23. Uses mlock. +7 Add ! register, for shell commands. (patch from Grenie) +8 In the gzip plugin, also recognize *.gz.orig, *.gz.bak, etc. Like it's + done for filetype detection. Patch from Walter Briscoe, 2003 Jul 1. +7 Add a "-@ filelist" argument: read file names from a file. (David + Kotchan has a patch for it) +8 Include a connection to an external program through a pipe? See + patches from Felbinger for a mathematica interface. + Or use emacs server kind of thing? +7 Add ":justify" command. Patch from Vit Stradal 2002 Nov 25. +- findmatch() should be adjusted for Lisp. See remark at + get_lisp_indent(). Esp. \( and \) should be skipped. (Dorai Sitaram, + incomplete patch Mar 18) +- For GUI Find/Replace dialog support using a regexp. Patch for Motif + and GTK by degreneir (nov 10 and nov 18). +- Patch for "paranoid mode" by Kevin Collins, March 7. Needs much more work. + + +Vi incompatibility: +- Try new POSIX tests, made after my comments. (Geoff Clare, 2005 April 7) + Version 1.5 is in ~/src/posix/1.5. (Lynne Canal) +8 With undo/redo only marks in the changed lines should be changed. Other + marks should be kept. Vi keeps each mark at the same text, even when it + is deleted or restored. (Webb) + Also: A mark is lost after: make change, undo, redo and undo. + Example: "{d''" then "u" then "d''": deletes an extra line, because the '' + position is one line down. (Veselinovic) +8 When stdin is not a tty, and Vim reads commands from it, an error should + make Vim exit. +7 Unix Vim (not gvim): Typing CTRL-C in Ex mode should finish the line + (currently you can continue typing, but it's truncated later anyway). + Requires a way to make CTRL-C interrupt select() when in cooked input. +8 When loading a file in the .exrc, Vi loads the argument anyway. Vim skips + loading the argument if there is a file already. When no file argument + given, Vi starts with an empty buffer, Vim keeps the loaded file. (Bearded) +6 In Insert mode, when using <BS> or <Del>, don't wipe out the text, but + only move back the cursor. Behaves like '$' in 'cpoptions'. Use a flag + in 'cpoptions' to switch this on/off. +8 When editing a file which is a symbolic link, and then opening another + symbolic link on the same file, Vim uses the name of the first one. + Adjust the file name in the buffer to the last one used? Use several file + names in one buffer??? + Also: When first editing file "test", which is symlink to "test2", and + then editing "test2", you end up editing buffer "test" again. It's not + logical that the name that was first used sticks with the buffer. +7 The ":undo" command works differently in Ex mode. Edit a file, make some + changes, "Q", "undo" and _all_ changes are undone, like the ":visual" + command was one command. + On the other hand, an ":undo" command in an Ex script only undoes the last + change (e.g., use two :append commands, then :undo). +7 The ":map" command output overwrites the command. Perhaps it should keep + the ":map" when it's used without arguments? +7 CTRL-L is not the end of a section? It is for Posix! Make it an option. +7 Implement 'prompt' option. Init to off when stdin is not a tty. +7 CTRL-T in Insert mode inserts 'shiftwidth' of spaces at the cursor. Add a + flag in 'cpoptions' for this. +7 Add a way to send an email for a crashed edit session. Create a file when + making changes (containing name of the swap file), delete it when writing + the file. Supply a program that can check for crashed sessions (either + all, for a system startup, or for one user, for in a .login file). +7 Vi doesn't do autoindenting when input is not from a tty (in Ex mode). +7 "z3<CR>" should still use the whole window, but only redisplay 3 lines. +7 ":tag xx" should move the cursor to the first non-blank. Or should it go + to the match with the tag? Option? +7 Implement 'autoprint'/'ap' option. +7 Add flag in 'cpoptions' that makes <BS> after a count work like <Del> + (Sayre). +7 Add flag in 'cpoptions' that makes operator (yank, filter) not move the + cursor, at least when cancelled. (default Vi compatible). +7 This Vi-trick doesn't work: "Q" to go to Ex mode, then "g/pattern/visual". + In Vi you can edit in visual mode, and when doing "Q" you jump to the next + match. Nvi can do it too. +7 Support '\' for line continuation in Ex mode for these commands: (Luebking) + g/./a\ g/pattern1/ s/pattern2/rep1\\ + line 1\ line 2\\ + line 2\ line 3\\ + . line4/ +6 ":e /tmp/$tty" doesn't work. ":e $uid" does. Is $tty not set because of + the way the shell is started? +6 Vi compatibility (optional): make "ia<CR><ESC>10." do the same strange + thing. (only repeat insert for the first line). + + +GTK+ GUI known bugs: +9 Crash with X command server over ssh. (Ciaran McCreesh, 2006 Feb 6) +8 GTK 2: Combining UTF-8 characters not displayed properly in menus (Mikolaj + Machowski) They are displayed as separate characters. Problem in + creating a label? +8 GTK 2: Combining UTF-8 characters are sometimes not drawn properly. + Depends on the font size, "monospace 13" has the problem. Vim seems to do + everything right, must be a GTK bug. Is there a way to work around it? +9 Can't paste a Visual selection from GTK-gvim to vim in xterm or Motif gvim + when it is longer than 4000 characters. Works OK from gvim to gvim and + vim to vim. Pasting through xterm (using the shift key) also works. + It starts working after GTK gvim loses the selection and gains it again. +- Gnome2: When moving the toolbar out of the dock, so that it becomes + floating, it can no longer be moved. Therefore making it float has been + blocked for now. + + +Win32 GUI known bugs: +- Win32: tearoff menu window should have a scrollbar when it's taller than + the screen. +8 non-ASCII font names don't work. Need to convert from 'encoding' and use + the wide functions. +8 On Windows 98 the unicows library is needed to support functions with UCS2 + file names. Can we load unicows.dll dynamically? +8 When the primary monitor is below or right of the secondary monitor and + Vim is on the secondary monitor it will often move to the primary monitor. + Window position coordinates can be negative. (James Harvey) +8 The -P argument doesn't work very well with many MDI applications. + The last argument of CreateWindowEx() should be used, see MSDN docs. + Tutorial: http://win32assembly.online.fr/tut32.html +8 In eval.c, io.h is included when MSWIN32 is defined. Shouldn't this be + WIN32? Or can including io.h be moved to vim.h? (Dan Sharp) +7 Windows XP: When using "ClearType" for text smoothing, a column of yellow + pixels remains when typing spaces in front of a "D" ('guifont' set to + "lucida_console:h8"). +6 Win32 GUI: With "-u NONE -U NONE" and doing "CTRL-W v" "CTRL-W o", the ":" + of ":only" is highlighted like the cursor. (Lipelis) +8 When 'encoding' is "utf-8", should use 'guifont' for both normal and wide + characters to make Asian languages work. Win32 fonts contain both + type of characters. +7 When font smoothing is enabled, redrawing can become very slow. The reason + appears to be drawing with a transparent background. Would it be possible + to use an opaque background in most places? +8 Use another default for 'termencoding': the active codepage. Means that + when 'encoding' is changed typing characters still works properly. + Alternative: use the Unicode functions to obtain typed characters. +8 Win32: Multi-byte characters are not displayed, even though the same font + in Notepad can display them. (Srinath Avadhanula) Try with the + UTF-8-demo.txt page with Andale Mono. +7 The cursor color indicating IME mode doesn't work properly. (Shizhu Pan, + 2004 May 9) +8 Win32: When clicking on the gvim title bar, which gives it focus, produces + a file-changed dialog, after clicking on a button in that dialog the gvim + window follows the mouse. The button-up event is lost. Only with + MS-Windows 98? + Try this: ":set sw ts", get enter-prompt, then change the file in a + console, go back to Vim and click "reload" in the dialog for the changed + file: Window moves with the cursor! + Put focus event in input buffer and let generic Vim code handle it? +8 Win32: When mouse is hidden and in the toolbar, moving it won't make it + appear. (Sami Salonen) +8 Win32 GUI: With maximized window, ":set go-=r" doesn't use the space that + comes available. (Poucet) It works OK on Win 98 but doesn't work on Win + NT 4.0. Leaves a grey area where the scrollbar was. ":set go+=r" also + doesn't work properly. +8 When Vim is minimized and when maximizing it a file-changed dialog pops + up, Vim isn't maximized. It should be done before the dialog, so that it + appears in the right position. (Webb) +9 When selecting at the more-prompt or hit-enter-prompt, the right mouse + button doesn't give popup menu. + At the hit-enter prompt CTRL-Y doesn't work to copy the modeless + selection. + On the command line, don't get a popup menu for the right mouse button. + Let the middle button paste selected text (not the clipboard but the + non-Visual selection)? Otherwise CTRL-Y has to be used to copy the text. +8 When 'grepprg' doesn't execute, the error only flashes by, the + user can hardly see what is wrong. (Moore) + Could use vimrun with an "-nowait" argument to only wait when an error + occurs, but "command.com" doesn't return an error code. +8 When the 'shell' cannot be executed, should give an appropriate error msg. + Esp. for a filter command, currently it only complains the file could not + be read. +7 Add an option to add one pixel column to the character width? Lucida + Console italic is wider than the normal font ("d" overlaps with next char). + Opposite of 'linespace': 'columnspace'. +7 At the hit-enter prompt scrolling now no longer works. Need to use the + keyboard to get around this. Pretend <CR> was hit when the user tries to + scroll? +7 Scrollbar width doesn't change when selecting other windows appearance. + Also background color of Toolbar and rectangle below vert. scrollbar. +7 "!start /min cmd" should run in a minimized window, instead of using + "/min" as the command name. (Rogall) +6 Drawing text transparently doesn't seem to work (when drawing part cursor). +8 CTRL key doesn't always work in combination with ALT key. It does work + for function keys, not for alphabetic characters. Perhaps this is because + CTRL-ALT is used by Windows as AltGr? +8 CTRL-- doesn't work for AZERTY, because it's CTRL-[ for QWERTY. How do we + know which keyboard is being used? +7 When scrolling, and a background color is dithered, the dither pattern + doesn't always join correctly between the scrolled area and the new drawn + area (Koloseike). +8 When gui_init_font() is called with "*", p_guifont is freed while it might + still be used somewhere. This is too tricky, do the font selection first, + then set the new font by name (requires putting all logfont parameters in + the font name). + + +Athena and Motif: +6 New Motif toolbar button from Marcin Dalecki: + - When the mouse pointer is over an Agide button the red becomes black. + Something with the way colors are specified in the .xpm file. + - The pixmap is two pixels smaller than it should be. The gap is filled + with grey instead of the current toolbar background color. +9 Can configure be changed to disable netbeans if the Xpm library is + required and it's missing? +8 When using the resource "Vim*borderwidth 2" the widgets are positioned + wrong. +9 XIM is disabled by default for SGI/IRIX. Fix XIM so that 'imdisable' can + be off by default. +9 XIM doesn't work properly for Athena/Motif. (Yasuhiro Matsumoto) For now, + keep XIM active at all times when the input method has the preediting + flag. +8 X11: A menu that contains an umlaut is truncated at that character. + Happens when the locale is "C", which uses ASCII instead of IS0-8859-1. + Is there a way to use latin1 by default? Gnome_init() seems to do this. +8 Perhaps use fontsets for everything? +6 When starting in English and switching the language to Japanese, setting + the locale with ":lang", 'guifontset' and "hi menu font=", deleting all + menus and setting them again, the menus don't use the new font. Most of + the tooltips work though... +7 Motif: when using a file selection dialog, the specified file name is not + always used (when specifying a filter or another directory). +8 When 'encoding' is different from the current locale (e.g., utf-8) the + menu strings don't work. Requires conversion from 'encoding' to the + current locale. Workaround: set 'langmenu'. + + +Athena GUI: +9 When dragging the scrollbar thumb very fast, focus is only obtained in + the scrollbar itself. And the thumb is no longer updated when moving + through files. +7 The file selector is not resizable. With a big font it is difficult to + read long file names. (Schroeder) +4 Re-write the widget attachments and code so that we will not have to go + through and calculate the absolute position of every widget every time the + window is refreshed/changes size. This will help the "flashing-widgets" + problem during a refresh. +5 When starting gvim with all the default colors and then typing + ":hi Menu guibg=cyan", the menus change color but the background of the + pullright pixmap doesn't change colors. + If you type ":hi Menu guibg=cyan font=anyfont", then the pixmap changes + colors as it should. + Allocating a new pixmap and setting the resource doesn't change the + pullright pixmap's colors. Why? Possible Athena bug? + + +Motif GUI: +- gui_mch_browsedir() is missing. +7 Use XmStringCreateLocalized() instead of XmStringCreateSimple()? + David Harrison says it's OK (it exists in Motif 1.2). +8 Lesstif: When deleting a menu that's torn off, the torn off menu becomes + very small instead of disappearing. When closing it, Vim crashes. + (Phillipps) + + +GUI: +9 On Solaris, creating the popup menu causes the right mouse button no + longer to work for extending the selection. (Halevy) +9 When running an external program, it can't always be killed with CTRL-C. + e.g., on Solaris 5.5, when using "K" (Keech). Other 'guipty' problems on + Solaris 2.6. (Marley) +9 On Solaris: Using a "-geometry" argument, bigger than the window where Vim + is started from, causes empty lines below the cmdline. (raf) +8 X11 GUI: When menu is disabled by excluding 'm' from 'guioptions', ALT key + should not be used to trigger a menu (like the Win32 version). +8 When setting 'langmenu', it should be effective immediately. Store both + the English and the translated text in the menu structure. Re-generate + the translation when 'langmenu' has changed. +8 Basic flaw in the GUI code: NextScreen is updated before calling + gui_write(), but the GUI code relies on NextScreen to represent the state + of where it is processing the output. + Need better separation of Vim core and GUI code. +8 When fontset support is enabled, setting 'guifont' to a single font + doesn't work. +8 Menu priority for sub-menus for: Amiga, BeOS. +8 When translating menus ignore the part after the Tab, the shortcut. So + that the same menu item with a different shortcut (e.g., for the Mac) are + still translated. +8 Add menu separators for Amiga, RISCOS. +8 Add way to specify the file filter for the browse dialog. At least for + browse(). +8 Add dialog for search/replace to other GUIs? Tk has something for this, + use that code? Or use console dialog. +8 When selecting a font with the font dialog and the font is invalid, the + error message disappears too quick. +7 More features in the find/replace dialog: + - regexp on/off + - search in selection/buffer/all buffers/directory + when all buffers/directory is used: + - filter for file name + when directory is used: + - subdirectory on/off + - top directory browser +8 gui_check_colors() is not called at the right moment. Do it much later, + to avoid problems. +8 gui_update_cursor() is called for a cursor shape change, even when there + are mappings to be processed. Only do something when going to wait for + input. Or maybe every 100 ms? +8 X11: When the window size is reduced to fit on screen, there are blank + lines below the text and bottom scrollbar. "gvim -geometry 80x78+0+0". + When the "+0+0" is omitted it works. +8 When starting an external command, and 'guipty' set, BS and DEL are mixed + up. Set erase character somehow? +8 A dead circumflex followed by a space should give the '^' character + (Rommel). Look how xterm does this. + Also: Bednar has some code for dead key handling. + Also: Nedit 5.0.2 with USE_XMIM does it right. (Gaya) +8 The compose key doesn't work properly (Cepas). Both for Win32 and X11. +7 The cursor in an inactive window should be hollow. Currently it's not + visible. +7 GUI on Solaris 2.5.1, using /usr/dt/..: When gvim starts, cursor is + hollow, after window lowered/raised it's OK. (Godfrey) +7 When starting GUI with ":gui", and window is made smaller because it + doesn't fit on the screen, there is an extra redraw. +8 When setting font with .Xdefaults, there is an extra empty line at the + bottom, which disappears when using ":set guifont=<Tab>". (Chadzelek) +8 When font shape changes, but not the size, doing ":set font=" does not + redraw the screen with the new font. Also for Win32. + When the size changes, on Solaris 2.5 there isn't a redraw for the + remaining part of the window (Phillipps). +- Flashes really badly in certain cases when running remotely from a Sun. +4 Re-write the code so that the highlighting isn't changed multiple times + when doing a ":hi clear". The color changes happen three or more times + currently. This is very obvious on a 66Mhz 486. + + +MSDOS/DJGPP: +9 Pressing CTRL-C often crashes the console Vim runs in. (Ken Liao) + When 'bioskey' isn't set it doesn't happen. Could be a problem with the + BIOS emulation of the console. Version 5.6 already had this problem. +8 DJGPP: "cd c:" can take us to a directory that no longer exists. + change_drive() doesn't check this. How to check for this error? +9 The 16 bit version runs out of memory very quickly. Should find unused + code and reduce static data. Resetting 'writebackup' helps to be able to + write a file. +9 Crash when running on Windows 98 in a console window and pressing CTRL-C. + Happens now and then. When debugging Vim in gdb this also happens. Since + the console crashes, might be a bug in the DOS console. Resetting + 'bioskey' avoids it, but then CTRL-C doesn't work. +9 DOS: Make CTRL-Fx and ALT-Fx work. + CTRL-F1 = CE-5E, CTRL-F2 = CE-5F, .., CTRL-F10 = CE-67 + ALT-F1 = CE-68, ALT-F2 = CE-69, .., ALT-F10 = CE-71 + Shifted cursor keys produce same codes as unshifted keys. Use bioskey(2) + to get modifier mask for <S-C-M-Fx>. + Use K_SPECIAL/KS_MODIFIER codes to insert modifier mask in input stream? + Make this work like in Win32 console. + Mapping things like <M-A> doesn't work, because it generates an extended + key code. Use a translation table? +9 Can't read an opened swap file when the "share" command has not been used. + At least ignore the swap files that Vim has opened itself. +8 Use DJGPP 2.03. +8 The Dos32 version (DJGPP) can't use long file names on Windows NT. + Check if new package can be used (v2misc/ntlfn08[bs].zip). +8 setlocale() is bogus. +8 Vim busy waits for new characters or mouse clicks. Should put in some + sort of sleep, to avoid eating 50% of the CPU time. Test on an unpatched + Windows 95 system! +8 DJGPP: when shell is bash, make fails. (Donahoe) +7 Hitting CTRL-P twice quickly (e.g., in keyword completion) on a 8088 + machine, starts printer echo! (John Mullin). +7 MSDOS 16 bit version can't work with COMSPEC that has an argument, e.g.: + COMSPEC=C:\WINDOWS\COMMAND.COM /E:4096 (Bradley) + Caused by BCC system() function (Borland "make" has the same problem). +8 Mouse: handle left&right button pressed as middle button pressed. Add + modifier keys shift, ctrl and alt. +7 When too many files are open (depends on FILES), strange things happen. + The Dos16 version runs out of memory, in the Dos32 version "!ls" causes a + crash. Another symptom: .swp files are not deleted, existing files are + "[New file]". +7 DJGPP version doesn't work with graphics display mode. Switch to a mode + that is supported? +8 DJGPP: ":mode" doesn't work for many modes. Disable them. +8 DJGPP: When starting in Ex mode, shouldn't clear the screen. (Walter + Briscoe) + + +MSDOS, OS/2 and Win32: +8 OS/2: Add backtick expansion. Undefine NO_EXPANDPATH and use + gen_expand_wildcards(). +8 OS/2: Add clipboard support? See example clipbrd.exe from Alexander + Wagner. +8 OS/2: Add Extended Attributes support and define HAVE_ACL. +8 OS/2: When editing a file name "foo.txt" that is actually called FOO.txt, + writing uses "foo.txt". Should obtain the real file name. +8 Should $USERPROFILE be preferred above $HOMEDRIVE/$HOMEPATH? No, but it's + a good fallback, thus use: + $HOME + $HOMEDRIVE$HOMEPATH + SHGetSpecialFolderPath(NULL, lpzsPath, CSIDL_APPDATA, FALSE); + $USERPROFILE + SHGetSpecialFolderPath(NULL, lpzsPath, CSIDL_COMMON_APPDATA, FALSE); + $ALLUSERSPROFILE + $SYSTEMDRIVE\ + C:\ +8 Win32 console: <M-Up> and <M-Down> don't work. (Geddes) We don't have + special keys for these. Should use modifier + key. +8 Win32 console: caps-lock makes non-alpha keys work like with shift. + Should work like in the GUI version. +8 Environment variables in DOS are not case sensitive. Make a define for + STRCMP_ENV(), and use it when comparing environment var names. +8 Setting 'shellslash' has no immediate effect. Change all file names when + it is set/reset? Or only use it when actually executing a shell command? +8 When editing a file on a Samba server, case might matter. ":e file" + followed by ":e FILE" will edit "file" again, even though "FILE" might be + another one. Set last used name in buflist_new()? Fix do_ecmd(), etc. +8 When a buffer is editing a file like "ftp://mach/file", which is not going + to be used like a normal file name, don't change the slashes to + backslashes. (Ronald Hoellwarth) + + +Windows 95: +8 Editing a file by its short file name and writing it, makes the long file + name disappear. Setting 'backupcopy' helps. + Use FindFirstFile()->cAlternateFileName in fname_case() (George Reilly). +8 Doing wildcard expansion, will match the short filename, but result in the + long filename (both DJGPP and Win32). + + +Win32 console: +9 When editing a file by its short file name, it should be expanded into its + long file name, to avoid problems like these: (Mccollister) + 1) Create a file called ".bashrc" using some other editor. + 2) Drag that file onto a shortcut or the actual executable. + 3) Note that the file name is something like BASHRC~1 + 4) Go to File->Save As menu item and type ".bashrc" as the file name. + 5) Press "Yes" to indicate that I want to overwrite the file. + 6) Note that the message "File exists (add ! to override)" is displayed + and the file is not saved. + Use FindFirstFile() to expand a file name and directory in the path to its + long name. +8 Also implement 'conskey' option for the Win32 console version? Look at + how Xvi does console I/O under Windows NT. +7 Re-install the use of $TERM and support the use of different terminals, + besides the console. +8 Use of <altgr> modifier doesn't work? 5.3 was OK. (Garcia-Suarez/Guckes) +9 Mapping <C-S-Tab> doesn't work correctly. How to see the difference with + <C-S-i>? +9 tmpnam() uses file in root of file system: "\asdf". That doesn't work on + a Netware network drive. Use same function as for Win32 GUI? +8 In os_win32.h, HAVE_STRICMP and HAVE_STRNICMP are defined only if __GNUC__ + is not defined. Shouldn't that be the other way around? +7 Use SetConsoleCP() and SetConsoleOutputCP() to implement 'termencoding'? + Avoids that input and output work differently. Need to be restored when + exiting. + + +Amiga: +8 In mch_inchar() should use convert_input_safe() to handle incomplete byte + sequences. +9 In mch_expandpath() a "*" is to be expanded, but "\*" isn't. Remove + backslashes in result. +8 Executing a shell, only one option for 'shell' is separated. Should do + all options, using white space separation. + + +Macintosh: +- GUI: gui_mch_browsedir() is missing. +7 Patch to add 'transparency' option. Disadvantage: it's slow. (Eckehard + Berns, 2004 May 9) http://ecki.to/vim/TransBack-2004-05-09.diff + Needs more work. Add when someone really wants it. +7 Loading the Perl library only works on OS/X 10.2 or 10.3, never on both. + Load the Perl library dynamically see Python sources file dynload_mac + (Jack) + dynamic linking: http://developer.apple.com/technotes/tn2002/tn2064.html +8 Inputting Unicode characters does not work in the terminal. They appear + to arrive as upper and lower bytes. (David Brown, 2004 April 17) +8 Typing Unicode characters doesn't work at all in the GUI. +8 inputdialog() doesn't resize when giving more text lines. (David Fishburn, + 2006 Sept 28) +9 Problems in Carbon version for OS X: (Benji Fisher) + - keyboard shortcuts in the menus get lost. +8 The Vim/About menu doesn't work. +8 ":gui" doesn't fork. Enabling the code in gui.c to fork causes a SEGV. +8 Define vim_mkdir() for Macintosh. +8 Define mch_writable() for Macintosh. +9 When DiskLock is running, using a swap file causes a crash. Appears to be + a problem with writing a file that starts with a dot. (Giacalone) +9 On G3 Mac, OS version 8, control strip causes characters messed up when + scrolling (CTRL-L cleans it up). (Benji Fisher) +9 On G3 Mac, OS version 8, variable-speed scrolling doesn't work, after two + seconds of scrolling the screen freezes. (Benji Fisher) +9 In mac_expandpath() check that handling of backslashes is done properly. +8 Standard Mac shortcuts are missing. (Amerige) +8 Handling of non-fixed width fonts is wrong. (Amerige) + + +"Small" problems: +- Can't disable terminal flow control, to enable the use of CTRL-S and + CTRL-Q. Add an option for it? +- When using e_secure in do_one_cmd() mention the command being executed, + otherwise it's not clear where it comes from. +- When the quickfix window is open and executing ":echo 'hello'" using the + Command-line window, the text is immediately removed by the redrawing. + (Michael Henry, 2008 Nov 1) + Generic solution: When redrawing while there is a message on the + cmdline, don't erase the display but draw over the existing text. + Other solution, redraw after closing the cmdline window, before executing + the command. +9 For Turkish vim_tolower() and vim_toupper() also need to use utf_ + functions for characters below 0x80. (Sertacyildiz) +9 When the last edited file is a help file, using '0 in a new Vim doesn't + edit the file as a help file. 'filetype' is OK, but 'iskeyword' isn't, + file isn't readonly, etc. +8 When an ":edit" is inside a try command and the ATTENTION prompt is used, + the :catch commands are always executed, also when the file is edited + normally. Should reset did_emsg and undo side effects. Also make sure + the ATTENTION message shows up. Servatius Brandt works on this. +8 ":g//" gives "Pattern not found error" with E486. Should not use the + error number, it's not a regular error message. +7 Vimtutor leaves escape sequence in terminal. This is the xterm response to + requesting the version number. (Yasuhiro Matsumoto) +8 When redirecting and using ":silent" the current column for displaying and + redirection can be different. Use a separate variable to hold the column + for redirection. +7 The messages for "vim --help" and "vim --version" don't use + 'termencoding'. +- Could the hit-enter prompt be avoided when a message only overlaps the + 'showcmd' area? Clear that area when the next cmd is typed. +8 When 'scrollbind' is set, a window won't scroll horizontally if the cursor + line is too short. Add a word in 'scrollopt' to allow moving the cursor + to longer line that is visible. A similar thing is done for the GUI when + using the horizontal scrollbar. +7 VisVim can only open one file. Hard to solve: each opened file is passed + with a separate invocation, would need to use timestamps to know the + invocations belong together. +8 When giving a ":bwipeout" command a file-changed dialog may popup for this + buffer, which is pointless. (Mike Williams) +8 On MS-Windows ":make" doesn't show output while it is working. Use the + tee.exe from http://unxutils.sourceforge.net/ ? About 16 Kbyte in the + UnxUtils.zip archive. + Alternate one: http://www.pramodx.20m.com/tee_for_win32.htm, but Walter + Briscoe says it's not as good. +8 "stl" and "stlnc" in 'fillchars' don't work for multi-byte characters. +8 When doing Insert mode completion a mapping cannot recursively call + edit(), because the completion information is global. Put everything in + an allocated structure? +6 Python: ":py raw_input('prompt')" doesn't work. (Manu Hack) +8 Command line completion: buffers "foo.txt" and "../b/foo.txt", completing + ":buf foo<Tab>" doesn't find the second one. (George V. Reilly) +7 Output for ":scriptnames" and ":breaklist" should shorten the file names: + use "~/" when possible. +7 mb_off2cells() doesn't work correctly on the tail byte of a double-byte + character. (Yasuhiro Matsumoto) It should return 1 when used on a tail + byte, like for utf-8. Store second byte of double-byte in ScreenLines2[] + (like for DBCS_JPNU) and put a zero in the second byte (like for UTF-8). +8 'backupdir' and 'directory' should use $TMPDIR, $TMP and/or $TEMP when + defined. +7 Inside a function with "perl <<EOF" a line with "$i++" is recognized as an + ":insert" command, causing the following "endfunction" not to be found. + Add skipping this perl construction inside function definitions. +7 When 'ttimeoutlen' is 10 and 'timeoutlen' is 1000, there is a keycode + "<Esc>a" and a mapping <Esc>x", when typing "<Esc>a" with half a second + delay should not be interpreted as a keycode. (Hans Ginzel) +7 ":botright 1 new" twice causes all window heights to be changed. Make the + bottom window only bigger as much as needed. +7 The Cygwin and MingW makefiles define "PC", but it's not used anywhere. + Remove? (Dan Sharp) +9 User commands use the context of the script they were defined in. This + causes a "s:var" argument to unexpectedly use a variable in the defining + script, not the calling script. Add an argument to ":command": + "-keepcontext". Do replace <SID>, so that a function in the defining + script can be called. +8 The Japanese message translations for MS-Windows are called ja.sjis.po, + but they use encoding cp932. Rename the file and check that it still + works. +8 A very long message in confirm() can't be quit. Make this possible with + CTRL-C. +7 clip_x11_own_selection() uses CurrentTime, that is not allowed. VNC X + server has a problem with this. (Mark Waggoner) Remembering the timestamp + of events isn't always possible. We don't get them in an xterm. GTK + doesn't obtain the selection again when the timestamp differs, thus it + won't work for GTK anyway. +8 When the clipboard isn't supported: ":yank*" gives a confusing error + message. Specifically mention that the register name is invalid. +8 "gf" always excludes trailing punctuation characters. file_name_in_line() + is currently fixed to use ".,:;!". Add an option to make this + configurable? +8 'hkmap' should probably be global-local. +9 When "$" is in 'cpoptions' and folding is active, a "C" command changes + the folds and resets w_lines_valid. The display updating doesn't work + then. (Pritesh Mistry) +8 Using ":s" in a function changes the previous replacement string. Save + "old_sub" in save_search_patterns()? +8 Should allow multi-byte characters for the delimiter: ":s+a+b+" where "+" + is a multi-byte character. +8 When appending to a file and 'patchmode' isn't empty, a backup file is + always written, even when the original file already exists. +7 When using "daw" on the last word in a file and this is a single letter, + nothing is deleted. Should delete the letter and preceding white space. +9 When getting focus while writing a large file, could warn for this file + being changed outside of Vim. Avoid checking this while the file is being + written. +7 The message in bt_dontwrite_msg() could be clearer. +8 The script ID that is stored with an option and displayed with ":verbose + set" isn't reset when the option is set internally. For example when + 'foldlevel' is set from 'foldlevelstart'. +8 Also store the line number with the script ID and use it for ":verbose", + so that "set nocompatible" is found when it changes other option values. + When an option is set indirectly mention the command? E.g. when + ":diffsplit" sets 'foldmethod'. +8 In the fileformat dialog, "Cancel" isn't translated. Add a global + variable for this. (Eduardo Fernandez) +9 When editing a file with 'readonly' set, there is no check for an existing + swap file. Then using ":write" (without making any changes) doesn't give + a warning either. Should check for an existing swap file without creating + one. Unfinished patch by Ian Kelling, 2008 July 14. +7 When 'showbreak' is set, the amount of space a Tab occupies changes. + Should work like 'showbreak' is inserted without changing the Tabs. +7 When 'mousefocus' is set and switching to another window with a typed + command, the mouse pointer may be moved to a part of the window that's + covered by another window and we lose focus. Only move in the y + direction, not horizontally? +8 ":hardcopy": + - Using the cterm_color[] table is wrong when t_colors is > 16. + - Need to handle unprintable characters. + - Win32: On a B&W printer syntax highlighting isn't visible. Perform + dithering to make grey text? + - Add a flag in 'printoptions' to add an empty page to make the total + number even. "addempty"? (Mike Williams) + - Respect 'linebreak'. Perhaps also 'showbreak'? + - Should interpret CTRL-L as a page break. + - Grey line numbers are not always readable. Add field in 'printoptions'. + Default to black when no syntax highlighting. + - Be able to print a window in diff mode. + - Be able to specify a colorscheme to use for printing. And a separate + one for B&W printing (if that can be detected). +8 In Visual block mode with 'lbr' set, a change command doesn't insert the + text in following lines where the linebreak changes. +9 dosinst.c: The DJGPP version can't uninstall the Uninstall registry key on + Windows NT. How to install a .inf file on Windows NT and how to detect + that Windows NT is being used? +8 When 'virtualedit' is "block,insert" and encoding is "utf-8", selecting a + block of one double-wide character, then "d" deletes only half of it. +8 When 'virtualedit' is set, should "I" in blockwise visual mode also insert + in lines that don't extend into the block? +8 With 'virtualedit' set, in Insert mode just after the end of line, CTRL-O + yh does not yank the last character of the line. (Pavel Papushev) + Doing "hl" first appears to make it work. +8 With 'virtualedit' set it's possible to move into the blank area from + 'linebreak'. +8 With 'virtualedit' set and 'selection' "exclusive", a Visual selection + that ends in or after a tab, "d" doesn't delete (part of) the tab. + (Helmut Stiegler) +9 When jumping to a tag, the search pattern is put in the history. When + 'magic' is on, the pattern may not work. Translate the pattern depending + on p_magic when putting it in the history? Alternative: Store value of + 'magic' in history. (Margo) +9 optwin.vim: Restoring a mapping for <Space> or <CR> is not correct for + ":noremap". Add "mapcmd({string}, {mode})? Use code from ":mkexrc". +9 incsearch is incorrect for "/that/<Return>/this/;//" (last search pattern + isn't updated). +9 term_console is used before it is set (msdos, Amiga). +9 Get out-of-memory for ":g/^/,$s//@/" on 1000 lines, this is not handled + correctly. Get many error messages while redrawing the screen, which + cause another redraw, etc. +8 [<C-I> doesn't work when '*' is in 'iskeyword'. find_pattern_in_path() + must escape special characters in the pattern. +8 Vim can overwrite a read-only file with ":w!". ":w" can't overwrite an + existing file, "w!" can, but perhaps not a read-only file? Then use + ":w!!" for that. + Or ask for permission to overwrite it (if file can be made writable) and + restore file to readonly afterwards. + Overwriting a file for which a swap file exists is similar issue. +7 When compiled with "xterm_clipboard", startup can be slower and might get + error message for invalid $DISPLAY. Try connecting to the X server in the + background (forked), so that Vim starts up quicker? Connect as soon as + the clipboard is to be used (Visual select mode starts, paste from + clipboard) +7 X11: Some people prefer to use CLIPBOARD instead of PRIMARY for the normal + selection. Add an "xclipboard" argument to the 'clipboard' option? (Mark + Waggoner) +8 For xterm need to open a connection to the X server to get the window + title, which can be slow. Can also get the title with "<Esc>[21t", no + need to use X11 calls. This returns "<Esc>]l{title}<Esc>\". +6 When the xterm reports the number of colors, a redraw occurs. This is + annoying on a slow connection. Wait for the xterm to report the number of + colors before drawing the screen. With a timeout. +8 When the builtin xterm termcap contains codes that are not wanted, need a + way to avoid using the builtin termcap. +8 Xterm sends ^[[H for <Home> and ^[[F for <End> in some mode. Also + recognize these keys? Mostly useful for xterm simulators, like gnometerm. + See http://dickey.his.com/xterm/xterm.faq.html#xterm_pc_style. +8 For xterm also recognize keypad up/down/left/right and insert. +8 '[ and '] should be set to start/end of line when using a linewise operator + (e.g., ":w"). +8 CTRL-A can't handle big "long" numbers, they become negative. Check for + "-" character, if not present, use unsigned long. +8 Make it possible to disable the special meaning of "#" in the first column + for ">>". +8 Add suspending with CTRL-Z at the "more" prompt, and when executing a long + script in do_cmdline(). +8 When using 'hidden', many swap files will be open. When Vim runs into the + maximum number of open files, error messages will appear. Detect that + this problem is present, and close any hidden files that don't have + changes. +8 With 'viminfo' set such that the ".viminfo" file is written on a FAT + filesystem, an illegal file name may be created: ".vim". +8 For each buffer that is opened, the viminfo file is opened and read to + check for file marks. This can be slow. +7 In xterm, recognize both vt100 and vt220 cursor keys. Change + add_termcode() to not remove an existing entry for a name, when it's + needed. + Need a generic solution to recognize different codes for the same key. +8 Core dump within signal function: gdb doesn't show stack backtrace! Option + to skip catch_signals()? +9 Repeating a "cw" with "." doesn't work if the text was pasted from the + clipboard. (Thomas Jones) It's because the menu/toolbar item exits Insert + mode and uses "gP". How to fix this without breaking inserting a block of + text? +8 In Replace mode pasting from the clipboard (using menu or toolbar) inserts + all the text. Add ":rmenu"? +8 Pasting with the mouse in Replace mode inserts the text, instead of + overwriting, when it is more than one line. Same for using <C-R>. +9 CTRL-E and CTRL-Y don't work in small window when 'so' is 4 and lines are + wrapping (Acevedo/in.226). E.g., when using CTRL-E, window height 7, + window might actually scroll down when last line of buffer is displayed. + --> Remember if the previous command was "cursor follows screen" or + "screen follow cursor" and use this in cursupdate(). +7 tilde_replace() can only handle "~/", should also do "~user/". + Get the list of home directories (from /etc/passwd? Use getpwent()) and + use some clever algorithm to match a path with that. Find common strings + in the list? +8 When dragging status line with mouse, sometimes a jump when first clicking + on the status line (caused by 'winheight'). Select window on button up, + instead of on button down. +8 Dragging the status line doesn't scroll but redraw. +9 Evaluating 'statusline' in build_stl_str_hl() does not properly check for + reaching the end of the available buffer. + Patch to dynamically allocate the buffer for % items. (Eric Arnold, 2006 + May 14) +8 When performing incremental search, should abort searching as soon as a + character is typed. +8 When the value of $MAKE contains a path, configure can't handle this. + It's an autoconf bug. Remove the path from $MAKE to work around it. +8 How to set VIMRC_FILE to \"something\" for configure? Why does this not + work: CFLAGS='-DVIMRC_FILE=\"/mydir/myfile\"' ./configure +8 The temporary file is sometimes not writable. Check for this, and use an + alternate name when it isn't. Or add the 'temptemplate' option: template + for the temp file name ":set temptemplate=/usr/tmp/?????.tmp". + Also: Win32 version uses Windows temp directory, which might not work for + cygwin bash. +7 Get error "*, \+ or \( operand could be empty" for pattern "\(.\)\1\{3}". + Remember flags for backreferences. +7 When switching to Daylight Saving Time, Vim complains that a file has been + changed since last read. Can we use a function that uses GMT? +7 When completing an environment variable after a '$', check for file names + that contain a '$' after all have been found. +8 When "cm" termcap entry is missing, starting gvim shouldn't complain about + it. (Lohner) Try out with "vt100" entry, cm replaced with cX. +7 When an include file starts with "../", the check for already visiting + this file doesn't work. Need to simplify the file name. +7 The names and comments for the arguments of do_browse() are confusing. + "dflt" isn't the default file name when "initdir" is not NULL and + "initdir" is the default path to be used. +7 When 'scrolloff' is exactly half the window height, "j" causes a scroll of + two lines at a time. "k" doesn't do this. (Cory T. Echols) +8 When write_viminfo() is used while there are many orphaned viminfo + tempfiles writing the viminfo file fails. Give a clear error message so + that the user knows he has to delete the files. +7 It's possible to redefine a script-local function with ":func + <SNR>123_Test()". (Krishna) Disallow this. + + +I can't reproduce these (if you can, let me know how!): +9 NT 4.0 on NTFS file system: Editing ".bashrc" (drag and drop), file + disappears. Editing ".xyz" is OK. Also, drag&drop only works for three + files. (McCollister) + + +Problems that will (probably) not be solved: +- GTK: when using the popup menu with spelling suggestions and releasing the + right mouse button before the menu appears selecting an item with the + right mouse button has no effect. GTK does not produce an event for this. +- GTK 2: Cannot use the file selector. When using it many things become + slow. This is caused by some code in GTK that writes + ~/.recently-used.xbel every time an event is handled. It assumes the main + loop is never quit, which is a wrong assumption. Also, it overwrites the + file with different file permissions, which is a privacy issue. This + needs to be fixed in GTK. A solution in Vim would be really complicated. + (2008 Jul 31) This appears to be fixed in Vim 7.3. +- xterm title: The following scenario may occur (esp. when running the Vim + test script): Vim 1 sets the title to "file1", then restores the title to + "xterm" with an ESC sequence when exiting. Vim 2 obtains the old title + with an X library call, this may result in "file1", because the window + manager hasn't processed the "xterm" title yet. Can apparently only be + worked around with a delay. +- In a terminal with 'mouse' set such that the mouse is active when entering + a command line, after executing a shell command that scrolls up the + display and then pressing ":": Selecting text with the mouse works like + the display wasn't scrolled. Vim doesn't know how much the external + command scrolled up the display. Use Shift to select text. +- X windows: When $DISPLAY points to a X server where there is no access + permission, trying to connect to the X server causes an error message. + XtOpenDisplay() prints this directly, there is no way to avoid it. +- X windows: Setting 'guifontset' to an illegal value sometimes crashes Vim. + This is caused by a fault in a X library function, can't be solved in Vim. +- Win32 tcl: has("tcl") hangs when the tcl84.dll is from cygwin. +- Motif: When adding a menu item "Find this &Symbol", the "s" in "this" will + be underlined, instead of in "Symbol". Motif doesn't let us specify which + character gets the highlighting. +- Moving the cursor removes color in color-xterm. This is a color-xterm + problem! color-xterm ver. 6.1 beta 3 and later work properly. +- In zsh, "gvim&" changes the terminal settings. This is a zsh problem. + (Jennings) +- Problem with HPterm under X: old contents of window is lost (Cosentino). +- Amiga: When using quickfix with the Manx compiler we only get the first 25 + errors. How do we get the rest? +- Amiga: The ":cq" command does not always abort the Manx compiler. Why? +- Linux: A file with protection r--rw-rw- is seen readonly for others. The + access() function in GNU libc is probably wrong. +- MSDOS: When using smartdrive with write-back buffering, writing to a + readonly floppy will cause problems. How to test for a writable floppy + first? +- MSDOS: Both 16 and 32 bit versions: File name expansion doesn't work for + names that start with a dot. These used to be illegal file names. +- When doing a CTRL-Z and typing a command for the shell, while Vim is busy + (e.g. writing a file), the command for the shell is sometimes eaten by Vim, + because the terminal mode is changed from RAW to CBREAK. +- An old version of GNU tgoto can't handle the terminfo code for "AF". The + "%p1" is interpreted as "%p" and "1", causing color not to be working. + Fix: Change the "%p1" in the "AF" and "AB" terminfo entries to "%p". + (Benzinger). +- When running an external command from the GUI, typeahead is going to that + program, not to Vim. It looks like the shell eats the characters, Vim + can't get back what the external command didn't use. +- Win32 GUI: Error code from external command not returned in shell_error. + It appears that cmd.exe and command.com don't return an error code. +- Win32 GUI: The Toolbar is a bit too high when the flat style is being + used. We don't have control over the height of the Toolbar. +- Win32: All files created on the day of switching from winter to summer + time cause "changed since editing started" messages. It goes away when + the file is written again the next day, or the timezone is adjusted. + DJGPP version is OK. (Zaimi) Looks like a problem with the Win32 library. + Rebooting doesn't help. Time stamps look OK in directory. (Penn) + Is this on FAT (stores wall clock time) or NTFS (stores UTS)? +- Win32, MS-Windows XP: $HOME uses the wrong drive when the user profiles + are not on the boot disk. This is caused by a wrong value of $HOMEDRIVE. + This is a bug in XP, see MSKB article 818134. +- SunOS 5.5.1 with Motif: The file open dialog does not have a horizontal + scroll bar for the "files" selection. This is a problem in the Motif + libraries, get a patch from Sun. +- Solaris 2.6 with GTK and Perl: gvim crashes when started. Problem with X + input method called from GDK code. Without Perl it doesn't crash. +- VMS: Vimdiff doesn't work with the VMS diff, because the output looks + different. This makes test 47 fail. Install a Unix-compatible diff. +- VMS v7.1 and older: Tests 21 and 32 fail. From VMS v7.1-2 and newer Vim + does not have this behavior. (Zoltan Arpadffy) +- Win32 GUI: mouse wheel always scrolls rightmost window. The events arrive + in Vim as if the rightmost scrollbar was used. +- GTK with Gnome: Produces an error message when starting up: + Gdk-WARNING **: locale not supported by C library + This is caused by the gnome library gnome_init() setting $LC_CTYPE to + "en_US". Not all systems support this locale name, thus causing the + error. Hopefully a newer version of GTK/Gnome fixes this problem. +- GTK 2: With this mapping the hit-enter prompt is _sometimes_ below the + screen, at other times there is a grey area below the command line: + :nmap <F11> :if &guioptions=~'m' \| set guioptions-=m \| else \| set guioptions+=m \| endif<cr> +- GTK: When pasting a selection from Vim to xclipboard gvim crashes with a + ABRT signal. Probably an error in the file gdkselection.c, the assert + always fails when XmbTextListToTextProperty() fails. (Tom Allard) +- GTK 2: gives an assertion error for every non-builtin icon in the toolbar. + This is a GTK 2.4.x bug, fixed in GTK 2.4.2. (Thomas de Grenier de Latour) +- When using an xterm that supports the termresponse feature, and the 't_Co' + termcap option was wrong when Vim started, it will be corrected when the + termresponse is received. Since the number of colors changes, the + highlighting needs to be initialized again. This may cause colors defined + in the vimrc file to be lost. +- On Windows NT 4.0 the number of files passed to Vim with drag&drop and + "Edit with Vim" is limited. The maximum command line length is 255 chars. + +--------------------- extensions and improvements ---------------------- + *extensions-improvements* + +Most interesting new features to be added when all bugs have been fixed: +- Using ":exe edit fname" has escaping problems. Use ":edit ++(fname)". + Thus use "++=" to give arguments as expressions, comma separated as if + calling a function. + With options: ":edit ++(['!', '++enc=abc'], ['+/pat'], fname)". + Alternative: Make a function for Ex commands: cmd_edit(). +- Add COLUMN NUMBERS to ":" commands ":line1,line2[col1,col2]cmd". Block + can be selected with CTRL-V. Allow '$' (end of line) for col2. +- Add DEBUGGER INTERFACE. Implementation for gdb by Xavier de Gaye. + Should work like an IDE. Try to keep it generic. Now found here: + http://clewn.sf.net. + And the idevim plugin/script. + To be able to start the debugger from inside Vim: For GUI run a program + with a netbeans connection; for console: start a program that splits the + terminal, runs the debugger in one window and reconnect Vim I/O to the + other window. + Wishes for NetBeans commands: + - make it possible to have 'defineAnnoType' also handle terminal colors. + - send 'balloonText' events for the cursor position (using CursorHold ?) + in terminal mode. +- ECLIPSE plugin. Problem is: the interface is very complicated. Need to + implement part in Java and then connect to Vim. Some hints from Alexandru + Roman, 2004 Dec 15. Should then also work with Oracle Jdeveloper, see JSR + 198 standard http://www.jcp.org/en/jsr/detail?id=198. + Eclim does it: http://eclim.sourceforge.net/ (Eric Van Dewoestine) + Plugin that uses a terminal emulator: http://vimplugin.sf.net + And another one: http://www.satokar.com/viplugin/index.php +- STICKY CURSOR: Add a way of scrolling that leaves the cursor where it is. + Especially when using the scrollbar. Typing a cursor-movement command + scrolls back to where the cursor is. +- Scroll commands by screen line. g CTRL-E and g CTRL-Y ? Requires the + first line to be able to start halfway. +- Running a shell command from the GUI still has limitations. Look into how + the terminal emulator of the Vim shell project can help: + http://vimshell.wana.at +8 Add a command to jump to a certain kind of tag. Allow the user to specify + values for the optional fields. E.g., ":tag size type=m". + Also allow specifying the file and command, so that the result of + taglist() can be used. +- X11: Make it possible to run Vim inside a window of another program. + This can be done with XReparentWindow(). But how exactly? + + +Documentation: +8 List of Vim runtime directories. dotvim.txt from Charles Campbell, 2007 + Feb 20. +8 The GUI help should explain the Find and Find/Replace dialogs. Add a link + to it from ":promptrepl" and ":promptfind". +8 List of options should mention whether environment variables are expanded + or not. +8 Extend usr_27.txt a bit. (Adam Seyfarth) +7 Add a section on debugging scripts in the user manual. +9 Make the Reference Manual more precise. For each command mention: + - change to cursor position and curswant + - if it can be undone (u/CTRL-R) and redone (.) + - how it works for folded lines + - how it works with multi-byte characters +9 In change.txt, remark about Javadoc isn't right. Right alignment would + work too. +8 Spread the windows commands over the other files. For example, ":stag" + should be with ":tag". Cross-link with tags to avoid too much double + text. +8 Add tags for all features, e.g. "gui_running". +7 MS-Windows: When a wrong command is typed with an ALT key, give a hint to + look at the help for 'winaltkeys'. +7 Add a help.vim plugin that maps <Tab> to jump to the next tag in || and + <C-Tab> (and <S-Tab>) to the previous tag. + Patch by Balazs Kezes, 2007 Dec 30. Remark from A. Politz. +- Check text editor compendium for vi and Vim remarks. + + +Help: +- First try using the ":help" argument literally, before using it as a + pattern. And then match it as part of a tag. +- When a help item has multiple matches make it possible to use ":tn" to go + to the other matches. +- Support a way to view (and edit) .info files. +- Default mapping for help files: <Tab> to position cursor on next |:tag|. +- Implement a "sticky" help window, some help text lines that are always + displayed in a window with fixed height. (Guckes) Use "~/.vimhelp" file, + user can edit it to insert his favorite commands, new account can contain a + default contents. +- Make 'winminheight' a local option, so that the user can set a minimal + height for the help window (and other windows). +- ":help :s^I" should expand to ":help :substitute". +- Make the help key (<F1>) context sensitive? +- Learn mode: show short help while typing commands. + + +User Friendlier: +8 Windows install with NSIS: make it possible to do a silent install, see + http://nsis.sourceforge.net/Docs/Chapter4.html#4.12 +8 Windows install with install.exe: Use .exe instead of .bat files for + links, so that command line arguments are passed on unmodified? (Walter + Briscoe) +8 Windows install: Be able to associate Vim with a selection of file types? +8 Windows uninstall: Have uninstal.c delete the vimfiles directories that + dosinst.c creates. List the contents of the directory (recursively) if + the user asks for it. Requires an implementation of "rm -rf". +8 Remember the name of the vimrc file that was used (~/.vimrc, $VIM/_vimrc, + $HOME/_vimrc, etc.) and add "edit vimrc" to the File menu. +- Add a way to save local settings and mappings into a new plugin file. + ":mkplugin <file>"? +8 Add ":plugininstall" command. Can be used to install a plugin file that + includes documentation. Let the user select a directory from + 'runtimepath'. + " Vim plugin + <main plugin code> + " >>> plugin help start <<< + <plugin docs> +- Add mappings local to a window: ":map <window> ..."? +9 Add buffer-local menu. Should offer a choice between removing the menu or + disabling it. Be careful that tear-offs don't disappear (keep one empty + item?). + Alternative: use BufEnter and BufLeave autocommands. +8 make a vimtutor script for Amiga and other systems. +7 Add the arguments for configure to the ":version" output? +7 When Vim detects a file is being edited elsewhere and it's a gvim session + of the same user it should offer a "Raise" button, so that the other gvim + window can be displayed. (Eduard) +8 Support saving and restoring session for X windows? It should work to do + ":mksession" and use "-S fname" for the restart command. The + gui_x11_wm_protocol_handler() already takes care of the rest. + global_event_filter() for GTK. + + +Tab pages: +9 GUI implementation for the tab pages line for other systems. +7 GUI: Control over the appearance of the text in the labels (bold, color, + font, etc.) +8 Make GUI menu in tab pages line configurable. Like the popup menu. +8 balloons for the tab page labels that are shortened to show the full path. +8 :tabmove +N move tab page N pages forward +8 :tabmove -N move tab page N pages backward +7 :tabdup duplicate the tab with all its windows. +7 Option to put tab line at the left or right? Need an option to specify + its width. It's like a separate window with ":tabs" output. +7 Add local variables for each tab page? +8 Add local options for each tab page? E.g., 'diffopt' could differ between + tab pages. +7 Add local highlighting for each tab page? +7 Add local directory for tab pages? How would this interfere with + window-local directories? + + +Spell checking: +- have some way not to give spelling errors for a range of characters. + E.g. for Chinese and other languages with specific characters for which we + don't have a spell file. Useful when there is also text in other + languages in the file. +- Support more regions? Caolan McNamara argues it's needed for es_XX. + https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=219777 +- Unicode defines another quote character: 0x2019. Use it as an equivalent + of a single quote, thus use it as a word character like a quote and match + with words, replacing the curly quote with a single quote. +- Could filter é things for HTML before doing spell checking. + Similarly for TeX. +- The Hungarian spell file uses four extra characters in the FOL/UPP/LOW + items than other spell files with the ISO-8859-2 encoding, that causes + problem when changing 'spelllang'. There is no obvious way to fix this. +- Considering Hunspell 1.1.4: + What does MAXNGRAMSUGS do? + Is COMPLEXPREFIXES necessary when we have flags for affixes? +- Support spelling words in CamelCase as if they were two separate words. + Requires some option to enable it. (Timothy Knox) +- There is no Finnish spell checking file. For openoffice Voikko is now + used, which is based on Malaga: http://home.arcor.de/bjoern-beutel/malaga/ + (Teemu Likonen) +8 ":mkspell" still takes much too long in Hungarian dictionary from + hunspell. Only solution appears to be to postpone secondary suffixes. +8 Handle postponed prefix with COMPOUNDPERMITFLAG or COMPOUNDFORBIDFLAG. + WFP_COMPPERMIT and WFP_COMPFORBID +8 implement use of <compoptions> in .spl file: + implement CHECKCOMPOUNDREP: when a compound word seems to be OK apply REP + items and check if the result is a valid word. + implement CHECKCOMPOUNDDUP + implement CHECKCOMPOUNDTRIPLE + Add CHECKCOMPOUNDCASE: when compounding make leading capital lower case. + How is it supposed to work? +- Add a command the repeats ]s and z=, showing the misspelled word in its + context. Thus to spell-check a whole file. +- suggestion for "KG" to "kg" when it's keepcase. +- For flags on affixes: Use a "AFFCOMPSET" flag; means the compound flags of + the word are not used. +- Support breakpoint character ? 0xb7 and ignore it? Makes it possible to + use same wordlist for hyphenation. +- Compound word is accepted if nr of words is <= COMPOUNDWORDMAX OR nr of + syllables <= COMPOUNDSYLMAX. Specify using AND in the affix file? +- NEEDCOMPOUND also used for affix? Or is this called ONLYINCOMPOUND now? + Or is ONLYINCOMPOUND only for inside a compound, not at start or end? +- Do we need a flag for the rule that when compounding is done the following + word doesn't have a capital after a word character, even for Onecap words? +- New hunspell home page: http://hunspell.sourceforge.net/ + - Version 1.1.0 is out now, look into that. + - Lots of code depends on LANG, that isn't right. Enable each mechanism + in the affix file separately. + - Example with compounding dash is bad, gets in the way of setting + COMPOUNDMIN and COMPOUNDWORDMAX to a reasonable value. + - PSEUDOROOT == NEEDAFFIX + - COMPOUNDROOT -> COMPOUNDED? For a word that already is a compound word + Or use COMPOUNDED2, COMPOUNDED3, etc. +- CIRCUMFIX: when a word uses a prefix marked with the CIRCUMFIX flag, then + the word must also have a suffix marked with the CIRCUMFIX flag. It's a + bit primitive, since only one flag is used, which doesn't allow matching + specific prefixes with suffixes. + Alternative: + PSFX {flag} {pchop} {padd} {pcond} {schop} {sadd}[/flags] {scond} + We might not need this at all, you can use the NEEDAFFIX flag and the + affix which is required. +- When a suffix has more than one syllable, it may count as a word for + COMPOUNDWORDMAX. +- Add flags to count extra syllables in a word. SYLLABLEADD1 SYLLABLEADD2, + etc.? Or make it possible to specify the syllable count of a word + directly, e.g., after another slash: /abc/3 +- MORPHO item in affix file: ignore TAB and morphological field after + word/flags and affix. +- Implement multiple flags for compound words and CMP item? + Await comments from other spell checking authors. +- Also see tklspell: http://tkltrans.sourceforge.net/ +8 Charles Campbell asks for method to add "contained" groups to existing + syntax items (to add @Spell). + Add ":syntax contains {pattern} add=@Spell" command? A bit like ":syn + cluster" but change the contains list directly for matching syntax items. +- References: MySpell library (in OpenOffice.org). + http://spellchecker.mozdev.org/source.html + http://whiteboard.openoffice.org/source/browse/whiteboard/lingucomponent/source/spellcheck/myspell/ + author: Kevin Hendricks <kevin.hendricks@sympatico.ca> +8 It is currently not possible to mark "can not" as rare, because "can" and + "not" are good words. Find a way to let "rare" overrule "good"? +8 Make "en-rare" spell file? Ask Charles Campbell. +8 The English dictionaries for different regions are not consistent in their + use of words with a dash. +7 Insert mode completion mechanism that uses the spell word lists. +8 Add hl groups to 'spelllang'? + :set spelllang=en_us,en-rare/SpellRare,en-math/SpellMath + More complicated: Regions with different languages? E.g., comments + in English, strings in German (po file). + + +Diff mode: +9 Instead invoking an external diff program, use builtin code. One can be + found here: http://www.ioplex.com/~miallen/libmba/dl/src/diff.c + It's quite big and badly documented though. +8 Use diff mode to show the changes made in a buffer (compared to the file). + Use an unnamed buffer, like doing: + new | set bt=nofile | r # | 0d_ | diffthis | wincmd p | diffthis + Also show difference with the file when editing started? Should show what + can be undone. (Tom Popovich) +7 Add cursor-binding: when moving the cursor in one diff'ed buffer, also + move it in other diff'ed buffers, so that CTRL-W commands go to the same + location. + + +Folding: + (commands still available: zI zJ zK zp zP zq zQ zV zy zY; + secondary: zB zS zT zZ, z=) +8 Vertical folds: looks like vertically split windows, but the cursor moves + through the vertical separator, separator moves when scrolling. +8 Add "z/" and "z?" for searching in not folded text only. +9 Add search pattern item to only match in closed or open fold and/or fold + with certain level. Allows doing ":g/pat/cmd" to work on closed folds. +7 Use "++--", "+++--" for different levels instead of "+---" "+----". +8 When a closed fold is displayed open because of 'foldminlines', the + behavior of commands is still like the fold is closed. How to make the + user aware of this? +8 Add an option 'foldskip' with values like 'foldopen' that specifies which + commands skip over a closed fold. +8 "H" and "L" count buffer lines instead of window lines. (Servatius Brandt) +8 Add a way to add fold-plugins. Johannes Zellner has one for VB. +7 When using manual folding, the undo command should also restore folds. +- Allow completely hiding a closed fold. E.g., by setting 'foldtext' to an + empty string. Require showing a character in 'foldcolumn' to avoid the + missing line goes unnoticed. + How to implement this? +- When pressing the down arrow of a scrollbar, a closed fold doesn't scroll + until after a long time. How to make scrolling with closed folds + smoother? +- When creating a session, also store folds for buffers in the buffer list, + using the wininfo in wi_folds. +- When currently editing the first file in the argument list the session + file can contain: + args version.c main.c + edit version.c + Can editing version.c twice be avoided? +- 'foldmethod' "textobject": fold on sections and paragraph text objects. +- "zuf": undo change in manual fold. "zUf" redo change in manual fold. How + to implement this? +- "zJ" command: add the line or fold below the fold in the fold under the + cursor. +- 'foldmethod' "syntax": "fold=3" argument: set fold level for a region or + match. +- Apply a new foldlevel to a range of lines. (Steve Litt) +8 Have some way to restrict commands to not folded text. Also commands like + searches. + + +Multi-byte characters: +- When editing a file with both utf-8 and latin1 text Vim always falls back + to latin1. Add a command to convert the latin1 characters to utf-8? + :unmix utf-8,latin1 filename + Would only work when 'encoding' is utf-8. +9 When the tail byte of a double-byte character is illegal (e.g., a CR), the + display is messed up (Yasuhiro Matsumoto). Should check for illegal + double-byte characters and display them differently (display each single + byte). +9 'fenc' in modeline problem: add option to reload the file when 'fenc' is + set to a different value in a modeline? Option can be default on. Could + it be done with an autocommand? +8 Add an item in 'fileencodings' to check the first lines of a file for + the encoding. See Python PEP: http://www.python.org/peps/pep-0263.html. + To avoid getting a wrong encoding only accept something Emacs-like: + "-*- coding: enc-na_me.foo -*-" and "-*- coding= enc-na_me.foo -*-" + Match with "-\*-\s*coding[:=]\s*\([::word::-_.]\+\)\s*-\*-" and use first + item. +8 Add an item in 'fileencodings' to check the first line of an XML file for + the encoding. <?xml version="1.0" encoding="UTF-8"?> Or "charset=UTF-8"? + For HTML look for "charset=utf-8". +8 The quickfix file is read without conversion, thus in 'encoding'. Add an + option to specify the encoding of the errorfile and convert it. Also for + ":grep" and ":helpgrep". + More generic solution: support a filter (e.g., by calling a function). +8 When a file was converted from 'fileencoding' to 'encoding', a tag search + should also do this on the search pattern. (Andrzej M. Ostruszka) +8 When filtering changes the encoding 'fileencoding' may not work. E.g., + when using xxd and 'fileencoding' is "utf-16". Add an option to set a + different fileencoding for filter output? +7 When converting a file fails, mention which byte could not be converted, + so that the user can fix the problem. +8 Add configure option to be able to disable using the iconv library. (Udo + Schweigert) +9 'aleph' should be set to 1488 for Unicode. (Zvi Har'El) +8 Should add test for using various commands with multi-byte characters. +8 'infercase' doesn't work with multi-byte characters. +8 toupper() function doesn't handle byte count changes. +7 Searching and composing characters: + When searching, should order of composing characters be ignored? + Add special item to match with a composing character, zero-width, so that + one can replace a base character and keep the composing characters. + Add a special item to match with a composing character, so that composing + characters can be manipulated. + Add a modifier to ignore composing characters, only compare base + characters. Useful for Hebrew (Ron Aaron) +8 Should implement 'delcombine' for command line editing. +8 Detect overlong UTF-8 sequences and handle them like illegal bytes. +8 ":s/x/\u\1/" doesn't work, making uppercase isn't done for multi-byte + characters. +8 UTF-8: "r" in Visual mode doesn't take composing characters. +8 UTF-8: When there is a precomposed character in the font, use it instead + of a character and a composing character. See xterm for an example. +7 When a character can't be displayed, display its digraph instead. + 'display' option to specify this. +7 Use ideas for nl_langinfo() from Markus Kuhn in enc_default(): + (www.cl.cam.ac.uk/~mgk25/ucs/langinfo.c) +- GTK and Win32: Allow selecting fonts for 'guifontset' with the + fontselector somehow. +- GTK and Win32: make it possible to set the font for the menu to make it + possible to have 'encoding' different from the current locale. +- dbcs_class() only works for Japanese and Korean. Implement this for + other encodings. The "euc-jp" and "euc-kr" choices might be wrong. +- Find some way to automatically select the right GUI font or fontset, + depending on the default value of 'encoding'. + Irrelevant in the GTK+ 2 GUI so long as UTF-8 is used. + For Windows, the charset_pairs[] table could be used. But how do we know + if a font exists? +- Do keyboard conversion from 'termencoding' to 'encoding' with + convert_input() for Mac GUI and RiscOS GUI. +- Add mnemonics from RFC1345 longer than two characters. + Support CTRL-K _{mnemonic}_ +7 In "-- INSERT (lang) --" show the name of the keymap used instead of + "lang". (Ilya Dogolazky) +- Make 'breakat' accept multi-byte characters. Problem: can't use a lookup + table anymore (breakat_flags[]). + Simplistic solution: when 'formatoptions' contains "m" also break a line + at a multi-byte character >= 0x100. +- Add the possibility to enter mappings which are used whenever normal text + could be entered. E.g., for "f" command. But not in Normal mode. Sort + of opposite of 'langmap'. Use ":tmap" command? +- When breaking a line, take properties of multi-byte characters into + account. The "linebreak" program from Bruno Haible can do it: + ftp://ftp.ilog.fr/pub/Users/haible/gnu/linebreak-0.1.tar.gz + But it's very complicated... + + +Printing: +7 Implement "undercurl" for printing. +- Add "page width" to wrap long lines. +- Win32: use a font dialog for setting 'printfont'. Can reuse the code for + the 'guifont' dialog, put the common code in a separate function. +- Add the file timestamp to the page header (with an option). (George + Reilly) +- Win32: when 'printfont' is empty use 'guifont'. +- Unix: Use some dialog box to do the obvious settings (paper size, printer + name, portrait/landscape, etc). +- PostScript: Only works for text that can be converted to an 8-bit + character set. How to support Unicode fully? +- Allow specifying the paper size, instead of using a standard size. Same + units as for the margins. +- Support right-to-left text? +8 Make the foreground color darkening function preserve the hue of the + color. + + +Syntax highlighting: +8 Make ":syn off" use 'runtimepath' instead of $VIMRUNTIME. (Gary Johnson) + Should do the same for ":syn on" and ":syn manual". +8 Support "containedin" argument for ":syn include", so that the defined + cluster can be added to existing syntax items. +8 C syntax: Don't highlight {} as errors inside () when used like this: + "({ something })", often used in GCC code. +7 Add a "startgroup" to a region. Used like "nextgroup" inside the region, + preferred item at the start of the region. (Charles Campbell) +8 When editing a new file without a name and giving it a name (by writing + it) and 'filetype' is not set, detect the filetype. Avoid doing it for + ":wq file". +7 For "nextgroup" we have skipwhite, skipnl and skipempty. It would be + really nice to be able to skip with a pattern. Or skip with a syntax + group. (Nikolai Weibull, 2007 Feb 27) +8 Make conversion to HTML faster (Write it in C or pre-compile the script). +9 There is still a redraw bug somewhere. Probably because a cached state is + used in a wrong way. I can't reproduce it... +7 Be able to change only the background highlighting. Useful for Diff* and + Search highlighting. +7 When 'number' is set highlight the number of the current line. + Must be enabled with an option, because it slows down display updating. +8 Allow the user to add items to the Syntax menu sorted, without having to + change this for each release. +8 Add a "matchcontains" for regions: items contained in the start or end + pattern, but not in the body. +8 Add a "keepend-contained" argument: Don't change the end of an item this + one is contained in. Like "keepend" but specified on the contained item, + instead of the containing item. +8 cpp.vim: In C++ it's allowed to use {} inside (). +8 Some syntax files set 'iskeyword'. When switching to another filetype + this isn't reset. Add a special keyword definition for the syntax rules? + When this is done, use vim.vim syntax highlighting for help file examples, + but without ":" in 'iskeyword' for syntax. +8 Add specific syntax item to match with parens/braces that don't have a + "%" match. :syntax nomatch cMatchError (,{,[,),},] [contained] +8 Highlight the text between two matching parens (e.g., with a grey + background) when on one of the parens or in between them. + Option for the matchparen plugin? +8 Add a command to jump to the next character highlighted with "Error". +8 When using a cterm, and no ctermfg or ctermbg are defined, use start/stop + sequences. Add remark in docs that :if 'term' == "term-name" should be + used. +8 Add @spell cluster to String and Comment groups for many languages. Will + allow spell checking. (Fleiner) +8 When listing syntax items, try to sort the keywords alphabetically. And + re-insert the [] if possible. +8 Make it possible to use color of text for Visual highlight group (like for + the Cursor). +8 It would be useful to make the highlight group name an expression. Then + when there is a match, the expression would be evaluated to find out what + highlight group to use. Could be used to check if the shell used in a + password file appears in /etc/shells. (Nikolai Weibull) + syn match =s:checkShell(v:match) contained 'pattern' +8 Make it possible to only highlight a sub-expression of a match. Like + using "\1" in a ":s" command. +8 Support for deleting syntax items: + :syn keyword cTodo remove this + :syn match cTodo remove "pattern" + :syn region cString remove start="this" end="that" +8 Add possibility to sync on something else, when the syncing in one way + doesn't find match. For HTML: When no {script} is found, try looking for + a '<'. (Fleiner) +7 Replace the synchronizing method with a state machine specification? + Should be able to start at any line in the file, search forwards or + backwards, and use the result of matching a pattern. +7 Use parsing like awk, so that e.g., a ( without a matching ) can be + detected. +8 Make it possible to use "inverted" highlighting, invert the original + character. For Visual mode. (xterm-selection already does this). +8 Highlight non-printable characters with "SpecialChar", linked to + "Special". Display them with the digraph characters, if possible. +8 Highlight the clipboard-selection with a highlight group. +8 Be able to reset highlighting to its original (default) values. +7 Be able to write current highlighting to a file as commands, similar to + ":mkvimrc". +8 Improve c.vim: + - Add check for unterminated strings, with a variable to switch it on: + "c_strict_ansi". + - Detect unbalanced "#endif". Requires looking back a long way... +8 Add an option to restrict the updating of syntax highlighting to the + current line while in Insert mode. +8 When guessing value of 'background', the syntax file has already been + loaded (from the .gvimrc). After changing 'background', load it again? +8 Add ":syn resync" command, to re-parse the whole file until the current + display position. +8 Should support "me" offset for a region start pattern. To be used to + allow searching for the end pattern inside the match of the end pattern. + Example: syn region pikeXX start="([^{]" end=")" should work on "()". +8 When using a regexp for "contains=", should delay matching with it until + redrawing happens. Set a flag when a group is added, check this flag when + highlighting starts. +8 Some terminals can display colors like the GUI. Add some setting to use + GUI colors for the terminal? With something to define the escape + sequence. +7 It's possible for an item to be transparent, so that the colors of an item + lower on the stack is used. Also do this with highlighting, so that the + user can set transparent highlighting? E.g. a number in a C comment would + get the color of a comment, a number in an assignment Normal. (Nikolai + Weibull) +7 Add "semitrans": Add highlighting. E.g., make the text bold, but keep the + colors. And add colors, so that Green+Red becomes Yellow. + E.g. for this html: + <B> bold text <I> italic+bold text </B> italic text </I> +7 Wild idea: Not only set highlighting, but also change what is displayed + (e.g., remove characters, so that "<B>bold</B>" can be shown as "bold"): + :syn region boldstuff start="<B>" display="" end="</B>" display="" +7 CTRL-] checks the highlight group for finding out what the tag is. +7 Add an explanation how a list of words can be used to highlight misspelled + words. +8 Add more command line completion for :syntax. +8 Add more command line completion for :highlight. +7 Should find a better way to parse the :syntax and :highlight commands. + Use tables or lists that can be shared by parsing for execution and + completion? +8 Add ColorSchemePost autocommand event, so that scripts can set up their + highlighting. (Salman Halim) +7 Add a few sets of colors (e.g. Borland Turbo C one). With a menu to + select one of the sets. +8 Add offsets to sub-matches: "\(a*\) *"he=e1-1 + 'e' is end of match 'e1' is end of sub-match 1, 's2' is start of submatch + 2, etc. +8 In Insert mode, when there are typeahead characters, postpone the + highlighting (for "." command). +8 Syncing on comments isn't 100% correct when / / lines mix with / * and * /. + For example: What about a line that starts with / / and contains * /? +8 Ignore / * and * / inside strings, when syncing. +7 Build a few more syntax files from the file "/usr/share/misc/vgrindefs": + ISP, LDL, Icon, ratfor. And check "nedit/source/highlight.c". +6 Add possibility to have background color continue until the right edge of + the window. Useful for comment blocks and function headings. (Rogall) +- Make it possible to add "contains" items for all items in a group. Useful + when extending an already existing syntax file. +- Add line-continuation pattern for non-syncing items too? +- Add possibility to highlight the whole line, including the right margin + (for comment blocks). +- Add 'hlmatch' option: List of flags: + 'c': highlight match for character under the cursor. + 'b': highlight the previous (, and its match. + 'a': highlight all text from the previous ( until its match. + Also for {}, <>, etc.? + 'e': highlight all braces without a match (slow?) + OR: add an argument "cursor" to the syntax command, which means that the + region/match/keyword is only highlighted when the cursor is on it. + (Campbell) + Or do it like Elvis: define text objects and how to highlight them around + the cursor. (Iain Truskett) +7 Make it possible to use all words in the tags files as Keyword. + Can also be done with a script (but it's slow). +7 Make it possible to call a ":" command when a match is found. Should + allow for adding keywords from the text (e.g. variables that are set). + And allows for sections with different highlighting. +7 Add highlight group for commandline: "Commandline". Make sure it + highlights the command line while typing a command, and any output from + messages. And external commands? +8 Make a version that works like less, but with highlighting: read stdin for + text, exit at end of file, don't allow editing, etc. moreim? lessim? +7 SpecialKey highlighting overrules syntax highlighting. Can't give an + unprintable char another color. Would be useful for ^M at end of line. + + +Built-in script language: +8 Make the filename and line number available to script functions, so that + they can give useful debugging info. The whole call stack would be ideal. +7 Execute a function with standard option values. No need to save and + restore option values. Especially useful for new options. Problem: how + to avoid a performance penalty (esp. for string options)? +8 Add referring to key options with "&t_xx". Both for "echo &t_xx" and + ":let &t_xx =". Useful for making portable mappings. +- Add ":let var ?= value", conditional assignment. Patch by Dave Eggum, + 2006 Dec 11. +- range for ":exec", pass it on to the executed command. (Webb) +8 ":{range}source": source the lines from the current file. + You can already yank lines and use :@" to execute them. + Most of do_source() would not be used, need a new function. + It's easy when not doing breakpoints or profiling. + Requires copying the lines into a list and then creating a function to + execute lines from the list. Similar to getnextac(). +7 ":include" command: just like ":source" but doesn't start a new scriptID? + Will be tricky for the list of script names. +8 Have a look at VSEL. Would it be useful to include? (Bigham) +8 Add ":fungroup" command, to group function definitions together. When + encountered, all functions in the group are removed. Suggest using an + obscure name to avoid name clashes. Require a ":fungroup END" in the same + sourced file? Assume the group ends at the end of the file. Handle + nested packages? + Alternative: Support packages. {package-name}:{function-name}(). + Packages are loaded automatically when first used, from + $VIMRUNTIME/packages (or use a search path). +7 Pre-parse or compile Vim scripts into a bytecode. + 1. Put the bytecode with the original script, with an ":if + has('bytecode')" around it, so that it's only used with a Vim that + supports it. Update the code with a command, can be used in an + autocommand. + 2. Use a ".vic" file (like Python use .pyc). Create it when writing a + .vim file. Problem: distribution. + 3. Use a cache directory for each user. How to recognize which cached + file belongs to a sourced script? +7 Add argument to winwidth() to subtract the space taken by 'foldcolumn', + signs and/or 'number'. +6 Add ++ and -- operators? They only work on variables (lvals), how to + implement this? +8 Add functions: + has(":command") Check if ":command" works. compare function + with "ex_ni". E.g. for ":simalt". + system() With a List argument. Bypasses the shell, use + exec() directly. (Bob Hiestand) + escape() Add argument to specify what to escape with. + modestack() Instead of just the current mode return the + stack of Insert / CTRL-O / :normal things. + realname() Get user name (first, last, full) + user_fullname() patch by Nikolai Weibull, Nov + 3 2002 + Only add this when also implemented for + non-Unix systems, otherwise a shell cmd could + be used. + get_user_name() gets login name. + menuprop({name}, {idx}, {what}) + Get menu property of menu {name} item {idx}. + menuprop("", 1, "name") returns "File". + menuprop("File", 1, "n") returns "nmenu + File.Open..." argument. + Patch by Ilya Sher, 2004 Apr 22 + Return a list of menus and/or a dictionary + with properties instead. + mapname({idx}, mode) return the name of the idx'th mapping. + Patch by Ilya Sher, 2004 Mar 4. + Return a list instead. + char2hex() convert char string to hex string. + attributes() return file protection flags "drwxrwxrwx" + filecopy(from, to) Copy a file + shorten(fname) shorten a file name, like home_replace() + perl(cmd) call Perl and return string + inputrl() like input() but right-to-left + typed() return the characters typed and consumed (to + find out what happened) + virtualmode() add argument to obtain whether "$" was used in + Visual block mode. + getacp() Win32: get codepage (Glenn Maynard) + deletebufline() delete line in any buffer + appendbufline() append line in any buffer + libcall() Allow more than one argument. + libcallext() Like libcall(), but using a callback function + to allow the library to execute a command or + evaluate an expression. +7 Make bufname("'0") return the buffer name from mark '0. How to get the + column and line number? col("'0") currently returns zero. +8 argc() returns 0 when using "vim -t tag". How to detect that no file was + specified in any way? To be able to jump to the last edited file. +8 Pass the command line arguments to Vim scripts in some way. As v:args + List? Or extra parameter to argv()? +8 Add command arguments with three dashes, passed on to Vim scripts. +7 Add optional arguments to user functions: + :func myFunc(arg1, arg2, arg3 = "blah", arg4 = 17) +6 User functions: Functions local to buffer "b:func()"? +8 For Strings add ":let var[{expr}] = {expr}". When past the end of "var" + just ignore. +8 The "= register should be writable, if followed by the name of a variable, + option or environment variable. +8 ":let &option" should list the value of the option. +8 ":let Func().foo = value" should work, also when "foo" doesn't exist. + Also: ":let Func()[foo] = value" should work. Same for a List. +7 Add synIDlist(), making the whole list of syntax items on the syntax stack + available as a List. +8 Add autocommand-event for when a variable is changed: + :au VarChanged {varname} {commands} +8 Add "has("gui_capable")", to check if the GUI can be started. +8 Add possibility to use variables like registers: characterwise (default), + linewise (when ending in '\n'), blockwise (when ending in '\001'). reg0, + rega, reg%, etc. Add functions linewise({expr}), blockwise({expr}) and + charwise({expr}). +7 Make it possible to do any command on a string variable (make a buffer + with one line, containing the string). Maybe add an (invisible) scratch + buffer for this? + result = scratch(string, command) + result = apply(string, command) + result = execute(string, command) + "command" would use <> notation. + Does scratch buffer have a number? Or re-use same number? +7 Add function to generate unique number (date in milliseconds). +7 Automatically load a function from a file when it is called. Need an + option for the search path. (Sekera) + + +Robustness: +6 Add file locking. Lock a file when starting to edit it with flock() or + fcntl(). This patch has advisory file locking while reading/writing + the file for Vim 5.4: ~/vim/patches/kahn_file_locking . + The patch is incomplete (needs support for more systems, autoconf). + Andy doesn't have time to work on it. + Disadvantage: Need to find ways to gracefully handle failure to obtain a + lock. When to release a lock: When buffer is unloaded? + + +Performance: +7 For string variables up to 3 bytes don't allocate memory, use v_list + itself as a character array. Use VAR_SSTRING (short string). +7 Add 'lazysize' option: Above this size Vim doesn't load everything before + starting to edit a file. Things like 'fileencodings' only work up to this + size, modelines only work at the top. Useful for large log files where + you only want to look at the first few pages. Use zero to disable it. +8 move_lines() copies every line into allocated memory, making reloading a + buffer a lot slower than re-editing the file. Can the memline be locked + so that we don't need to make a copy? Or avoid invoking ml_updatechunk(), + that is taking a lot of time. (Ralf Wildenhues, 2008 Jul 7) + With a patch, but does it work? +8 Instead of loading rgb.txt every time a color wasn't recognized load it + once and keep it in memory. Move the code to a common place to avoid + repeating it in various system files. +8 Turn b_syn_ic and b_syn_containedin into b_syn_flags. +9 Loading menu.vim still takes quite a bit of time. How to make it faster? +8 in_id_list() takes much time for syntax highlighting. Cache the result? +7 setpcmark() shifts the jumplist, this takes quite a bit of time when + jumping around. Instead use an index for the start? +8 When displaying a space with only foreground highlighting, it's the same + as a space without attributes. Avoid displaying spaces for the "~" lines + when starting up in a color terminal. +8 Avoid alloc() for scratch buffer use, esp. in syntax.c. It's very slow on + Win16. +8 Profiling shows that in_id_list() is used very often for C code. Can this + function be improved? +8 For an existing file, the page size of the swap file is always the + default, instead of using the block size of the device, because the swap + file is created only after setting the block size in mf_open(). How can + this be improved? +8 Set default for 'ttyscroll' to half a screen height? Should speed up + MS-DOS version. (Negri) +7 C syntax highlighting gets a lot slower after ":set foldmethod=syntax". + (Charles Campbell) Inserting a "{" is very slow. (dman) +7 HTML syntax highlighting is slow for long lines. Try displaying + http://www.theregister.co.uk/content/4/22908.html. (Andre Pang) +7 Check how performance of loading the wordlist can be improved (adding a + lot of abbreviations). +7 DOS console: Add t_DL support, to make scrolling faster. +7 Compile Ex commands to byte codes. Store byte codes in a vim script file + at the end, after "compiled:. Make it look like a single comment line + for old Vim versions. Insert first line "Vim script compiled <timestamp>. + Only used compiled code when timestamp matches the file stat. + Add command to compile a vim script and add it to the file in-place. + Split Ex command executing into a parsing and executing phase. + Use compiled code for functions, while loops, etc. +8 When editing a file with extremely long lines (e.g., an executable), the + "linerest" in readfile() is allocated twice to be able to copy what was + read so far. Use realloc() instead? Or split the line when allocating + memory fails and "linerest" is big (> 100000)? +8 When defining autocommands (e.g., from $VIMRUNTIME/filetype.vim), need to + compare each pattern with all existing patterns. Use a hash code to avoid + using strcmp() too often? +7 Include turbo_loader patches, speeding up reading a file? + Speed up reading a file by reading it into a fixed-size buffer, creating + the list of indexes in another buffer, and then copying the result into a + memfile block with two copies. Then read the next block into another + fixed-size buffer, create the second list of indexes and copy text from + the two blocks to the memfile block. +7 do_cmdline(): Avoid that the command line is copied to allocated memory + and freed again later all the time. For while loops, and for when called + with an argument that can be messed with. + Generic solution: Make a struct that contains a pointer and a flag that + indicates if the pointer should be freed when replaced. +7 Check that the file size is not more than "sizeof(long)". +- Further improve finding mappings in maphash[] in vgetorpeek() +8 Syntax highlighting is slow when deleting lines. Try in + $VIMRUNTIME/filetype.vim. +- "out of memory" after deleting (1,$d) and changing (:%s/^/> /) a lot of + lines (27000) a few times. Memory fragmentation? +- Have a look at how pdksh does memory allocation (alloc.c). (Dalecki) +- Do profiling on: + - :g/pat/normal cmd + - 1000ii<Esc> + - deleting 10Mbyte worth of lines (netscape binary) + - "[i" and "[d" (Yegappan Lakshmanan) + - ":g/^/m0" on a 450Kbyte file. And the "u". + - highlighting "~/vim/test/longline.tex", "~/vim/test/scwoop.tcl" and + "~/vim/test/lockup.pl". + - loading a syntax file to highlight all words not from a dictionary. + - editing a Vim script with syntax highlighting on (loading vim.vim). +7 Screen updating can be further improved by only redrawing lines that were + changed (and lines after them, when syntax highlighting was used, and it + changed). + - On each change, remember start and end of the change. + - When inserting/deleting lines, remember begin, end, and line count. +- Use macros/duarte/capicua for profiling. Nvi 1.71 is the fastest! +- When using a file with one long line (1Mbyte), then do "$hhhh", is still + very slow. Avoid calling getvcol() for each "h"? +- Executing a register, e.g. "10000@@" is slow, because ins_typebuf has to + move the previous commands forward each time. Pass count from + normal_cmd() down to do_execreg(). +- Repeating insert "1000i-<Esc>" displays --INSERT-- all the time, because of + the <Esc> at the end. Make this work faster (disable redrawing). +- Avoid calls to plines() for cursor line, use w_cline_height. +- After ":set nowrap" remove superfluous redraw with wrong hor. offset if + cursor is right of the screen. +8 Make CTRL-C on Unix generate a signal, avoid using select() to check for a + CTRL-C (it's slow). + + +Code size: +8 GUI: When NO_CONSOLE is defined, more code can be excluded. +- Put getline() and cookie in a struct, so only one argument has to be + passed to do_cmdline() and other functions. +8 Make a GUI-only version for Unix? +8 In buf_write _() isn't needed when setting errmsg, do it once when using + it. +7 When compiling with a GUI-only version, the code for cterm colors can be + left out. +8 When compiled with a GUI-only version, the termcap entries for terminals + can be removed. +8 Can the check for libelf in configure.in be removed? + + +Messages: +8 When using ":q" in a changed file, the error says to "add !". Add the + command so that beginners understand it: "use :q!". +8 For 'verbose' level 12 prints commands from source'ed files. How to skip + lines that aren't executed? Perhaps move the echoing to do_cmdline()? +8 Use 'report' for ":bdel"? (Krishna) To avoid these messages when using a + script. +- Delete message after new command has been entered and have waited for key. + Perhaps after ten seconds? +- Make message history available in "msg" variables: msg1, msg2, .. msg9. +8 When reading from stdin allow suppressing the "reading from stdin" + message. +9 Check handling of overwriting of messages and delays: + Very wrong: errors while redrawing cause endless loop. + When switching to another file and screen scrolls because of the long + message and return must be typed, don't scroll the screen back before + redrawing. +8 When address range is wrong you only get "Invalid range". Be a bit more + specific: Negative, beyond last line, reverse range? Include the text. +8 Make it possible to ignore errors for a moment ('errorignore'?). Another + option to switch off giving error messages ('errorquiet'?). Also an option + not to give any messages ('quiet')? Or ":quiet on", ":quiet off". + Careful: For a severe error (out of memory), and when the user starts + typing, error messages must be switched back on. + Also a flag to ignore error messages for shell commands (for mappings). +- Option to set time for emsg() sleep. Interrupt sleep when key is typed? + Sleep before second message? +8 In Ex silent mode or when reading commands from a file, what exactly is + not printed and what is? Check ":print", ":set all", ":args", ":vers", + etc. At least there should be no prompt. (Smulders) And don't clear the + screen when reading commands from stdin. (Kendall) + --> Make a difference between informative messages, prompts, etc. and + error messages, printing text, etc. +8 Window should be redrawn when resizing at the hit-enter prompt. + Also at the ":tselect" prompt. Find a generic solution for redrawing when + a prompt is present (with a callback function?). + + +Screen updating: +7 Add a string to the 'display' option to make CTRL-E and CTRL-Y scroll one + screen line, also if this means the first line doesn't start with the + first character (like what happens with a single line that doesn't fit). +- screen_line(): + - insert/delete character stuff. + - improve delete rest of line (spaces at end of line). +- When moving or resizing window, try to avoid a complete redraw (esp. when + dragging the status line with the mouse). +- When 'lazyredraw' set, don't echo :ex commands? Need a flag to redraw when + waiting for a character. +8 Add a ":refresh [winnr]" command, to force updating a window. Useful from + an event handler where ":normal" can't be used. Also useful when + 'lazyredraw' is set in a mapping. +7 Make 'list' and 'linebreak' work together. + + +Scrolling: +8 Add "zm" command: scroll horizontally to put the cursor in the middle. +6 Add option to set the overlap for CTRL-F and CTRL-B. (Garhi) +- extend 'scrollbind' option: 'scrollopt' words "search", "relative", etc.. + Also 'e'xecute some commands (search, vertical movements) in all bound + windows. +7 Add 'scrollbind' feature to make the offset of one window with the next + one equal to the window height. When editing one file in both windows it + looks like each window displays a page of the buffer. +- Allow scrolling by dragging with the mouse (grab a character and move it + up/down). Like the "hand" in Acrobat reader. Use Alt-LeftMouse for this? + (Goldfarb) +- Add command to execute some commands (search, vertical movements) in all + bound windows. +- Add 'search' option to 'scrollopt' to allow 'scrollbind' windows to + be bound by regexp searches +- Add "z>" and "z<": scroll sideways one screenful. (Campbell) +- Add option to set the number of lines when not to scroll, instead of the + fixed number used now (for terminals that scroll slow with a large number + of lines but not with a single line). + + +Autoconf: +8 Should use acconfig.h to define prototypes that are used by autoheader. +8 Some compilers don't give an error for "-OPT:Olimit" but a warning. (Webb) + Add a check for the warning, so that "Olimit" can be added automatically? +- Autoconf: Use @datadir@ for the system independent files. Make sure the + system dependent and system independent files are separated. (Leitner). +- Add autoconf check for waitpid()/wait4(). +- Remove fcntl() from autoconf, all systems have it? +- Set default for 'dictionary', add search for dictionary to autoconf. + + +Perl interface: +8 Rename typemap file to something else? +7 Make buffers accessed as Perl arrays. (Clark) +7 Make it possible to compile with non-ANSI C? +6 Tcl/Tk has the "load" command: load a shared library (.so or .dll). + + +Shared libraries: +6 Add support for loading shared libraries, and calling functions in it. + :libload internal-name libname + :libunload internal-name + :liblist + :libcall internal-name function(arg1, arg2, ...) + :libcall function(arg1, arg2, ...) + libcall() can have only one integer or String argument at the moment. +6 Have a look on how Perl handles loading dynamic libraries. + + +Tags: +9 With ":set tags=./tags,../tags" and a tag appears in both tags files it is + added twice. Requires figuring out the actual file name for each found + match. Remove tag_fname from the match and combine it with the fname in + the match (without expanding or other things that take time). When + 'tagrelative' is off tag_fname isn't needed at all. +8 For 'tags' wildcard in the file name is not supported, only in the path. + This is due to it using |file-searching|. Suboptimal solution would be to + make the filename or the whole option use |wildcards| globing, better + would be to merge the 2 kinds of globing. originally (Erik Falor, 2008 + April 18), updated (Ian Kelling, 2008 July 4) +8 Use a mechanism similar to omni completion to figure out the kind of tab + for CTRL-] and jump to the appropriate matching tag (if there are + several). + Alternative: be able to define a function that takes the tag name and uses + taglist() to find the right location. With indication of using CTRL-] so + that the context can be taken into account. (Robert Webb) +7 Can CTRL-] (jump to tag) include a following "." and "->" to restrict the + number of possible matches? Check tags file for an item that has members. + (Flemming Madsen) +8 Scope arguments for ":tag", e.g.: ":tag class:cPage open", like Elvis. +8 When output of ":tselect" is long, getting the more-prompt, should be able + to type the tag number directly. +7 Add the possibility to use the "-t {tag}" argument multiple times. Open a + window for each tag. +7 Make output of ":tselect" a bit nicer. Use highlighting? +7 Highlight the "tag 1 of >2" message. New highlight group, or same as "hit + bottom" search message. +7 When using ":tag" at the top of the tag stack, should add another entry, + so CTRL-T can bring you back to where you are now AND to where you were + before the previous ":tag" command. (Webb) +- When doing "[^I" or "[^D" add position to tag stack. +- Add command to put current position to tag stack: ":tpush". +- Add functions to save and restore the tag stack? Or a command to switch + to another tag stack? So that you can do something else and come back to + what you were working on. +7 When using CTRL-] on someClass::someMethod, separate class from method and + use ":ta class:someClass someMethod". + Include C++ tags changes (Bertin). Change "class::func" tag into "func" + with "class=class"? Docs in oldmail/bertin/in.xxx. +7 Add ":tagargs", to set values for fields: + :tagargs class:someclass file:version.c + :tagargs clear + These are then the default values (changes the order of priority in tag + matching). +7 Support for "gtags" and "global"? With ":rtag" command? + There is an example for how to do this in Nvi. + Or do it like Elvis: 'tagprg' and 'tagprgonce' options. (Yamaguchi) + The Elvis method is far more flexible, do it that way. +7 Support "col:99" extra field, to position the cursor in that column. With + a flag in 'cpoptions' to switch it off again. +7 Better support for jumping to where a function or variable is used. Use + the id-utils, with a connection to "gid" (Emacs can do it too). Add + ":idselect", which uses an "ID" database (made by "mkid") like "tselect". + + +Win32 GUI: +8 Make debug mode work while starting up (vim -D). Open console window for + the message and input? +7 The Python interface only works with one version of Python, selected at + compile time. Can this be made to work with version 2.1 and 2.2 + dynamically? +7 GvimExt: when there are several existing Vims, move the list to a submenu. + (Mike McCollister) +8 When using "Edit with Vim" for one file it changes directory, when several + files are selected and using "Edit with single Vim" the directory isn't + changed. At least change directory when the path is the same for all + files. Perhaps just use the path of the first file or use the longest + common part of the path. +8 Add font argument to set the lfCharSet. (Bobcik) +8 Somehow automatically detect the system language and set $LANG, so that + gettext and menus work. +8 Could keep console open to run multiple commands, to avoid the need to hit + return in every console. + Also: Look at how Emacs does run external commands: + http://www.cs.washington.edu/homes/voelker/ntemacs.html. +8 Need a separate PopUp menu for modeless selection. Need two new commands: + Copy selection to clipboard, Paste selection (as typed text). +8 Support copy/paste for other file formats. At least HTML, perhaps RTF. + Add "copy special" and "paste special" commands? +7 Use different default colors, to match the current Windows color scheme. + Sys_WindowText, Sys_Window, etc. (Lionel Schaffhauser) +7 Use <C-Tab> to cycle through open windows (e.g., the find dialog). +7 <Esc> should close a dialog. +7 Keep the console for external commands open. Don't wait for a key to be + hit. Re-open it when the user has closed it anyway. Or use a prepended + command: ":nowait {cmd}", or ":quiet", which executes {cmd} without any + prompts. +7 Should be able to set an option so that when you double click a file that + is associated with Vim, you can either get a new instance of Vim, or have + the file added into an already running Vim. +7 The "-P" argument only works for the current codepage. Use wide + functions to find the window title. + + +GUI: +8 Make inputdialog() work for Photon, Amiga, RiscOS. +- <C--> cannot be mapped. Should be possible to recognize this as a + normal "-" with the Ctrl modifier. +7 Implement ":popup" for other systems than Windows. +8 Implement ":tearoff" for other systems than Win32 GUI. +6 Implement ":untearoff": hide a torn-off menu. +8 When using the scrollbar to scroll, don't move the cursor position. When + moving the cursor: scroll to the cursor position. +9 Make <S-Insert> paste from the clipboard by default. (Kunze) +7 Menu local to a buffer, like mappings. Or local to a filetype? +8 In Buffers menu, add a choice whether selecting a buffer opens it in the + current window, splits the window or uses ":hide". +8 Dragging the mouse pointer outside of a Vim Window should make the text + scroll. Return a value from gui_send_mouse_event() to the machine + specific code to indicate the time in which the event should be repeated. +8 Make it possible to ignore a mouse click when it's used to give Vim (gvim) + window focus. Also when a mouse click is used to bring a window to front. +8 Make the split into system independent code and system specific code more + explicit. There are too many #ifdefs in gui.c. + If possible, separate the Vim code completely from the GUI code, to allow + running them in separate processes. +7 X11: Support cursorColor resource and "-cr" argument. +8 X11 (and others): CTRL-; is not different from ';'. Set the modifier mask + to include CTRL for keys where CTRL produces the same ASCII code. +7 Add some code to handle proportional fonts on more systems? Need to draw + each character separately (like xterm). Also for when a double-width font + is not exactly double-width. (Maeda) +8 Should take font from xterm where gvim was started (if no other default). +8 Selecting font names in X11 is difficult, make a script or something to + select one. +8 Visual highlighting should keep the same font (bold, italic, etc.). +8 Add flag to 'guioptions' to not put anything in the clipboard at all? +8 Should support a way to use keys that we don't recognize yet. Add a + command that adds entries to special_keys somehow. How do we make this + portable (X11, Win32, ..)? +7 Add a flag to 'guioptions' that tells not to remove inactive menu items. + For systems where greying-out or removing menu items is very slow. The + menu items would remain visibly normally, but not do anything. +7 Add ":minimize" and ":maximize", which iconize the window and back. + Useful when using gvim to run a script (e.g. 2html.vim). +7 X11: Is it possible to free allocated colors, so that other programs can + use them again? Otherwise, allow disabling allocating the default colors. + Or allocate an own colormap (check UAE). With an option to use it. For + the commandline, "-install" is mostly used for X11 programs. +7 Add command line argument for "gvim" not to start the GUI. Sort of the + inverse of "vim -g". (Vikas) +7 Should support multi-column menus. +- Should add option for where to put the "Help" menu: like Motif at the far + right, or with the other menus (but still at the right). +- Add menu item to "Keep Insert mode". +8 ":mkgvimrc" command, that includes menus. +6 Big change: Move GUI to separate program "vimgui", to make startup of vim a + lot faster, but still be able to do "vim -g" or ":gui". +7 More explicit mouse button binding instead of 'mousemodel'? +7 Add option to set the position of the window on the screen. 'windowpos', + which has a value of "123,456": <x>,<y>. + Or add a command, like ":winsize"? +7 Add toolbar for more GUIs. +8 Make it possible to use "amenu icon=BuiltIn##", so that the toolbar item + name can be chosen free. +7 Make it possible to put the toolbar on top, left, right and/or bottom of + the window? Allows for softkey-like use. +6 Separate the part of Vim that does the editing from the part that runs the + GUI. Communicate through a pseudo-tty. Vim starts up, creates a + pty that is connected to the terminal. When the GUI starts, the pty is + reconnected to the GUI process. When the GUI stops, it is connected to + the terminal again. Also use the pty for external processes, it looks + like a vt100 terminal to them. Vim uses extra commands to communicate GUI + things. +7 Motif: For a confirm() dialog <Enter> should be ignored when no default + button selected, <Esc> should close the dialog. +7 When using a pseudo-tty Vim should behave like some terminal (vt52 looks + simple enough). Terminal codes to/from shell should be translated. +- Would it be useful to be able to quit the GUI and go back to the terminal + where it was started from? +7 Support "-visual <type>" command line argument. + + +Autocommands: +- Put autocommand event names in a hashtable for faster lookup? +8 When the SwapExists event is triggered, provide information about the + swap file, e.g., whether the process is running, file was modified, etc. + Must be possible to check the situation that it's probably OK to delete + the swap file. (Marc Merlin) +8 When all the patterns for an event are "*" there is no need to expand + buffer names to a full path. This can be slow for NFS. +7 For autocommand events that trigger multiple times per buffer (e.g., + CursorHold), go through the list once and cache the result for a specific + buffer. Invalidate the cache when adding/deleting autocommands or + changing the buffer name. +8 Add ScriptReadCmd event: used to load remote Vim scripts, e.g. + "vim -u http://mach/path/vimrc". +7 Add TagJump event: do something after jumping to a tag. +8 Add "TagJumpFile" autocommand: When jumping to another file for a tag. + Can be used to open "main.c.gz" when "main.c" isn't found. +8 Use another option than 'updatetime' for the CursorHold event. The two + things are unrelated for the user (but the implementation is more + difficult). +7 Add autocommand event for when a buffer cannot be abandoned. So that the + user can define the action taking (autowrite, dialog, fail) based on the + kind of file. (Yakov Lerner) Or is BufLeave sufficient? +8 Autocommand for when modified files have been found, when getting input + focus again (e.g., FileChangedFocus). + Check when: getting focus, jumping to another buffer, ... +7 Autocommand for when an option is changed. Match buffer name or option + name? +8 Autocommands should not change registers. And marks? And the jumplist? + And anything else? Add a command to save and restore these things. +8 Add autocommands, user functions and user commands to ":mkvimrc". +6 Add KeymapChanged event, so that the effects of a different keymap can be + handled (e.g., other font) (Ron Aaron) +7 When trying to open a directory, trigger an OpenDirectory event. +7 Add file type in front of file pattern: <d> for directory, <l> for link, + <x> for executable, etc. <&xxx> for Risc OS. With commas to separate + alternatives. The autocommand is only executed when both the file type + AND the file pattern match. (Leonard) +5 Add option that specifies extensions which are to be discarded from the + file name. E.g. 'ausuffix', with ".gz,.orig". Such that file.c.gz will + trigger the "*.c" autocommands. (Belabas) +7 Add something to break the autocommands for the current event, and for + what follows. Useful for a "BufWritePre" that wants to avoid writing the + file. +8 When editing "tt.gz", which is in DOS format, 'fileformat' stays at + "unix", thus writing the file changes it. Somehow detect that the read + command used dos fileformat. Same for 'fileencoding'. +- Add events to autocommands: + Error - When an error happens + NormalEnter - Entering Normal mode + ReplaceEnter - Entering Replace mode + CmdEnter - Entering Cmdline mode (with type of cmdline to allow + different mapping) + VisualEnter - Entering Visual mode + *Leave - Leaving a mode (in pair with the above *Enter) + VimLeaveCheck - Before Vim decides to exit, so that it can be cancelled + when exiting isn't a good idea. + CursorHoldC - CursorHold while command-line editing + WinMoved - when windows have been moved around, e.g, ":wincmd J" + CmdUndefined - Like FuncUndefined but for user commands. + SearchPost - After doing a search command (e.g. to do "M") + PreDirChanged/PostDirChanged + - Before/after ":cd" has been used (for changing the + window title) + BufReadAction - replaces reading a file + BufWriteAction - replaces writing a file + ShutDown - when the system is about to shut down + InsertCharPre - user typed character Insert mode, before inserting the + char. Pattern is matched with text before the cursor. + Set v:char to the character, can be changed. + (not triggered when 'paste' is set). + InsertCharPost - user typed a character in Insert mode, after inserting + the char. + BufModified - When a buffer becomes modified, or unmodified (for + putting a [+] in the window title or checking out the + file from CVS). + BufFirstChange - When making a change, when 'modified' is set. Can be + used to do a :preserve for remote files. + BufChange - after a change was made. Set some variables to indicate + the position and number of inserted/deleted lines, so + that marks can be updated. HierAssist has patch to add + BufChangePre, BufChangePost and RevertBuf. (Shah) + ViewChanged - triggered when the text scrolls and when the window size + changes. + WinResized - After a window has been resized + WinClose - Just before closing a window +- Write the file now and then ('autosave'): + *'autosave'* *'as'* *'noautosave'* *'noas'* + 'autosave' 'as' number (default 0) + Automatically write the current buffer to file N seconds after the + last change has been made and when |'modified'| is still set. + Default: 0 = do not autosave the buffer. + Alternative: have 'autosave' use 'updatetime' and 'updatecount' but make + them save the file itself besides the swapfile. + + +Omni completion: +- Add a flag to 'complete' to be able to do omni completion with CTRL-N (and + mix it with other kinds of completion). +- Ideas from the Vim 7 BOF at SANE: + - For interpreted languages, use the interpreter to obtain information. + Should work for Java (Eclipse does this), Python, Tcl, etc. + Richard Emberson mentioned working on an interface to Java. + - Check Readline for its completion interface. +- Ideas from others: + http://www.wholetomato.com/ + http://www.vim.org/scripts/script.php?script_id=747 + http://sourceforge.net/projects/insenvim + or http://insenvim.sourceforge.net + Java, XML, HTML, C++, JSP, SQL, C# + MS-Windows only, lots of dependencies (e.g. Perl, Internet + explorer), uses .dll shared libraries. + For C++ uses $INCLUDE environment var. + Uses Perl for C++. + Uses ctags to find the info: + ctags -f $allTagsFile --fields=+aiKmnsSz --language-force=C++ --C++-kinds=+cefgmnpsut-dlux -u $files + www.vim.org script 1213 (Java Development Environment) (Fuchuan Wang) + IComplete: http://www.vim.org/scripts/script.php?script_id=1265 + and http://stud4.tuwien.ac.at/~e0125672/icomplete/ + http://cedet.sourceforge.net/intellisense.shtml (for Emacs) + Ivan Villanueva has something for Java. + Emacs: http://www.xref-tech.com/xrefactory/more_c_completion.html + Completion in .NET framework SharpDevelop: http://www.icsharpcode.net +- Pre-expand abbreviations, show which abbrevs would match? + + +Insert mode completion/expansion: +- GUI implementation of the popup menu. +7 When searching in other files the name flash by, too fast to read. Only + display a name every second or so, like with ":vimgrep". +7 When expanding file names with an environment variable, add the match with + the unexpanded var. So $HOME/tm expands to "/home/guy/tmp" and + "$HOME/tmp" +8 When there is no word before the cursor but something like "sys." complete + with "sys.". Works well for C and similar languages. +9 ^X^L completion doesn't repeat correctly. It uses the first match with + the last added line, instead of continuing where the last match ended. + (Webb) +8 Add option to set different behavior for Insert mode completion: + - ignore/match case + - different characters than 'iskeyword' +8 Add option 'isexpand', containing characters when doing expansion (so that + "." and "\" can be included, without changing 'iskeyword'). (Goldfarb) + Also: 'istagword': characters used for CTRL-]. + When 'isexpand' or 'istagword' are empty, use 'iskeyword'. + Alternative: Use a pattern so that start and end of a keyword can be + defined, only allow dash in the middle, etc. +8 Add a command to undo the completion, go back to the original text. +7 Completion of an abbreviation: Can leave letters out, like what Instant + text does: www.textware.com +8 Use the class information in the tags file to do context-sensitive + completion. After "foo." complete all member functions/variables of + "foo". Need to search backwards for the class definition of foo. + Should work for C++ and Java. + Even more context would be nice: "import java.^N" -> "io", "lang", etc. +7 When expanding $HOME/dir with ^X^F keep the $HOME (with an option?). +7 Add CTRL-X command in Insert mode like CTRL-X CTRL-N, that completes WORDS + instead of words. +8 Add CTRL-X CTRL-R: complete words from register contents. +8 Add completion of previously inserted texts (like what CTRL-A does). + Requires remembering a number of insertions. +8 Add 'f' flag to 'complete': Expand file names. + Also apply 'complete' to whole line completion. +- Add a flag to 'complete' to only scan local header files, not system + header files. (Andri Moell) +- Make it possible to search include files in several places. Use the + 'path' option? Can this be done with the dictionary completion (use + wildcards in the file name)? +- Make CTRL-X CTRL-K do a binary search in the dictionary (if it's sorted). +- Speed up CTRL-X CTRL-K dictionary searching (don't use a regexp?). +- Set a mark at the position where the match was found (file mark, could + be in another file). +- Add CTRL-A command in CTRL-X mode: show all matches. +- Make CTRL-X CTRL-L use the 'complete' option? +- Add command in CTRL-X mode to add following words to the completed string + (e.g. to complete "Pointer->element" with CTRL-X CTRL-P CTRL-W CTRL-W) +- CTRL-X CTRL-F: Use 'path' to find completions. +- CTRL-X CTRL-F: Option to use forward slashes on MS-Windows? +- CTRL-X CTRL-F: Don't replace "$VIM" with the actual value. (Kelly) +- Allow listing all matches in some way (and picking one from the list). + + +Command line editing: +7 Add commands (keys) to delete from the cursor to the end of the command + line. +8 Custom completion of user commands can't use the standard completion + functions. Add a hook to invoke a user function that returns the type of + completion to be done: "file", "tag", "custom", etc. +- Add flags to 'whichwrap' for command line editing (cursor right at end of + lines wraps to start of line). +- Make editing the command line work like Insert mode in a single-line view + on a buffer that contains the command line history. But this has many + disadvantages, only implement it when these can be solved. Elvis has run + into these, see remarks from Steve (~/Mail/oldmail/kirkendall/in.00012). + - Going back in history and editing a line there would change the history. + Would still need to keep a copy of the history elsewhere. Like the + cmdwin does now already. + - Use CTRL-O to execute one Normal mode command. How to switch to normal + mode for more commands? <Esc> should cancel the command line. CTRL-T? + - To allow "/" and "= need to recursively call getcmdline(), overwrite the + cmdline. But then we are editing a command-line again. How to avoid + that the user gets confused by the stack of command lines? + - Use edit() for normal cmdline editing? Would have to integrate + getcmdline() into edit(). Need to solve conflicts between Insert mode + and Command-line mode commands. Make it work like Korn shell and tcsh. + Problems: + - Insert: completion with 'wildchar' + - Insert: use cmdline abbreviations + - Insert: CTRL-D deletes indent instead of listing matches + - Normal: no CTRL-W commands + - Normal: no ":" commands? + - Normal: allow Visual mode only within one line. + - where to show insert/normal mode message? Change highlighting of + character in first column? + - Implementation ideas: + - Set "curwin" and "curbuf" to the command line window and buffer. + - curwin->w_topline is always equal to curwin->w_cursor.lnum. + - never set 'number', no folding, etc. No status line. + - sync undo after entering a command line? + - use NV_NOCL flag for commands that are not allowed in Command-line + Mode. + + +Command line completion: +8 Completing ":r ~br" should find matching user names. +8 Change expand_interactively into a flag that is passed as an argument. +8 With command line completion after '%' and '#', expand current/alternate + file name, so it can be edited. Also with modifiers, such as "%:h". +8 When completing command names, either sort them on the long name, or list + them with the optional part inside []. +8 Add an option to ignore case when doing interactive completion. So that + ":e file<Tab>" also lists "Filelist" (sorted after matching case matches). +7 Completion of ":map x ": fill in the current mapping, so that it can be + edited. (Sven Guckes) +- For 'wildmenu': Simplify "../bar" when possible. +- When using <Up> in wildmenu mode for a submenu, should go back to the + current menu, not the first one. E.g., ":emenu File.Save<Up>". +8 When using backtick expansion, the external command may write a greeting + message. Add an option or commands to remove lines that match a regexp? +7 When listing matches of files, display the common path separately from the + file names, if this makes the listing shorter. (Webb) +- Add command line completion for ":ilist" and friends, show matching + identifiers (Webb). +8 Add command line completion for "old value" of a command. ":args <key>" + would result in the current list of arguments, which you can then edit. +7 Add command line completion with CTRL-X, just like Insert mode completion. + Useful for ":s/word/xx/". +- Add command to go back to the text as it was before completion started. + Also to be used for <Up> in the command line. +- Add 'wildlongest' option: Key to use to find longest common match for + command line completion (default CTRL-L), like 'wildchar'. (Cregut) + Also: when there are several matches, show them line a CTRL-D. + + +Command line history: +9 Remember which command lines were actually typed and were not loaded from + viminfo. When writing viminfo append only these lines, so that lines from + other Vim's are not overwritten. +- Add "KeyWasTyped" flag: It's reset before each command and set when a + character from the keyboard is consumed. Value is used to decide to put a + command line in history or not. Put line in history if it didn't + completely resulted from one mapping. +- When using ":browse", also put the resulting edit command in the history, + so that it can be repeated. (Demirel) + + +Insert mode: +9 When 'autoindent' is set, hitting <CR> twice, while there is text after + the cursor, doesn't delete the autoindent in the resulting blank line. + (Rich Wales) This is Vi compatible, but it looks like a bug. +8 When using CTRL-O in Insert mode, then executing an insert command + "a" or "i", should we return to Insert mode after <Esc>? (Eggink) + Perhaps it can be allowed a single time, to be able to do + "<C-O>10axyz<Esc>". Nesting this further is confusing. + ":map <F2> 5aabc<Esc>" works only once from Insert mode. +8 When using CTRL-G CTRL-O do like CTRL-\ CTRL-O, but when returning with + the cursor in the same position and the text didn't change continue the + same change, so that "." repeats the whole insert. +7 Use CTRL-G <count> to repeat what follows. Useful for inserting a + character multiple times or repeating CTRL-Y. +- Make 'revins' work in Replace mode. +7 Use 'matchpairs' for 'showmatch': When inserting a character check if it + appears in the rhs of 'matchpairs'. +- In Insert mode (and command line editing?): Allow undo of the last typed + character. This is useful for CTRL-U, CTRL-W, delete and backspace, and + also for characters that wrap to the next line. + Also: be able to undo CTRL-R (insert register). + Possibly use 'backspace'="whole" for a mode where at least a <CR> that + inserts autoindent is undone by a single <BS>. +- Use CTRL-G in Insert mode for an extra range of commands, like "g" in + Normal mode. +- Make 'paste' work without resetting other options, but override their + value. Avoids problems when changing files and modelines or autocommands + are used. +- When typing CTRL-V and a digit higher than 2, only expect two digits. +- Insert binary numbers with CTRL-V b. +- Make it possible to undo <BS>, <C-W> and <C-U>. Bash uses CTRL-Y. + + +'cindent', 'smartindent': +9 ") :" confuses continuation line: (Colin Bennett, 2007 Dec 14) + cout << "a" + << ") :" + << "y"; +9 "} else" causes following lines to be indented too much. (Rouben + Rostamian, 2008 Aug 30) +8 Lisp indenting: "\\" confuses the indenter. (Dorai Sitaram, 2006 May 17) +8 Why are continuation lines outside of a {} block not indented? E.g.: + long_type foo = + value; +8 Java: Inside an anonymous class, after an "else" or "try" the indent is + too small. (Vincent Bergbauer) + Problem of using {} inside (), 'cindent' doesn't work then. +8 In C++ it's possible to have {} inside (): (Kirshna) + func( + new String[] { + "asdf", + "asdf" + } + ); +8 In C++ a function isn't recognized inside a namespace: + (Chow Loong Jin) + namespace { + int + func(int arg) { + } + } +6 Add 'cino' flag for this function argument layout: (Spencer Collyer) + func( arg1 + , arg2 + , arg3 + ); +7 Add separate "(0" option into inside/outside a function (Zellner): + func( + int x) // indent like "(4" + { + if (a + && b) // indent like "(0" +9 Using "{" in a comment: (Helmut Stiegler) + if (a) + { + if (b) + { + // { + } + } <-- this is indented incorrect + Problem is that find_start_brace() checks for the matching brace to be in + a comment, but not braces in between. Requires adding a comment check to + findmatchlimit(). +- Make smartindenting configurable. Add 'sioptions', e.g. '#' setting the + indent to 0 should be switched on/off. +7 Support ANSI style function header, with each argument on its own line. +- "[p" and "]p" should use 'cindent' code if it's on (only for the first + line). +- Add option to 'cindent' to set indent for comments outside of {}? +- Make a command to line up a comment after a code line with a previous + comment after a code line. Can 'cindent' do this automatically? +7 Add 'j' flag to 'formatoptions': Remove comment leader when joining lines. +- When 'cindent'ing a '}', showmatch is done before fixing the indent. It + looks better when the indent is fixed before the showmatch. (Webb) +- Add option to make indenting work in comments too (for commented-out + code), unless the line starts with "*". +- Don't use 'cindent' when doing formatting with "gq"? +- When formatting a comment after some text, insert the '*' for the new line + (indent is correct if 'cindent' is set, but '*' doesn't get inserted). +8 When 'comments' has both "s1:/*,mb:*,ex:*/" and "s1:(*,mb:*,ex:*)", the + 'x' flag always uses the first match. Need to continue looking for more + matches of "*" and remember all characters that could end the comment. +- For smartindent: When typing 'else' line it up with matching 'if'. +- 'smartindent': allow patterns in 'cinwords', for e.g. TeX files, where + lines start with "\item". +- Support this style of comments (with an option): (Brown) + /* here is a comment that + is just autoindented, and + nothing else */ +- Add words to 'cinwords' to reduce the indent, e.g., "end" or "fi". +7 Use Tabs for the indent of starting lines, pad with spaces for + continuation lines. Allows changing 'tabstop' without messing up the + indents. + 'keeptabs': when set don't change the tabs and spaces used for indent, + when the indent remains the same or increases. + + +Java: +8 Can have {} constructs inside parens. Include changes from Steve + Odendahl? +8 Recognize "import java.util.Vector" and use $CLASSPATH to find files for + "[i" commands and friends. +- For files found with 'include': handle "*" in included name, for Java. + (Jason) +- How to make a "package java.util" cause all classes in the package to be + searched? Also for "import java.util.*". (Mark Brophy) + + +'comments': +8 When formatting C comments that are after code, the "*" isn't repeated + like it's done when there is no code. And there is no automatic wrapping. + Recognize comments that come after code. Should insert the comment leader + when it's "#" or "//". + Other way around: when a C command starts with "* 4" the "*" is repeated + while it should not. Use syntax HL comment recognition? +7 When using "comments=fg:--", Vim inserts three spaces for a new line. + When hitting a TAB, these spaces could be removed. +7 The 'n'esting flag doesn't do the indenting of the last (rightmost) item. +6 Make strings in 'comments' option a RE, to be able to match more + complicated things. (Phillipps) Use a special flag to indicate that a + regexp is used. +8 Make the 'comments' option with "/* * */" lines only repeat the "*" line + when there is a "/*" before it? Or include this in 'cindent'? + + +Virtual edit: +8 Make the horizontal scrollbar work to move the text further left. +7 Allow specifying it separately for Tabs and beyond end-of-line? + + +Text objects: +8 Add text object for fold, so that it can be yanked when it's open. +8 Add test script for text object commands "aw", "iW", etc. +8 Add text object for part of a CamelHumpedWord and under_scored_word. + (Scott Graham) "ac" and "au"? +8 Add a text object for any kind of quoting, also with multi-byte + characters. Option to specify what quotes are recognized (default: all) + use "aq" and "iq". Use 'quotepairs' to define pairs of quotes, like + 'matchpairs'? +8 Add text object for any kind of parens, also multi-byte ones. +7 Add text object for current search pattern: "a/" and "i/". Makes it + possible to turn text highlighted for 'hlsearch' into a Visual area. +8 Add a way to make an ":omap" for a user-defined text object. Requires + changing the starting position in oap->start. +8 Add "gp" and "gP" commands: insert text and make sure there is a single + space before it, unless at the start of the line, and after it, unless at + the end of the line or before a ".". +7 Add objects with backwards extension? Use "I" and "A". Thus "2dAs" + deletes the current and previous sentence. (Jens Paulus) +7 Add "g{" and "g}" to move to the first/last character of a paragraph + (instead of the line just before/after a paragraph as with "{" and "}"). +6 Ignore comment leaders for objects. Make "das" work in reply-email. +5 Make it possible to use syntax group matches as a text object. For + example, define a "ccItem" group, then do "da<ccItem>" to delete one. + Or, maybe just define "dai", delete-an-item, to delete the syntax item the + cursor is on. + + +Select mode: +8 In blockwise mode, typed characters are inserted in front of the block, + backspace deletes a column before the block. (Steve Hall) +7 Alt-leftmouse starts block mode selection in MS Word. + See http://www.vim.org/tips/tip.php?tip_id=743 +7 Add Cmdline-select mode. Like Select mode, but used on the command line. + - Change gui_send_mouse_event() to pass on mouse events when 'mouse' + contains 'C' or 'A'. + - Catch mouse events in ex_getln.c. Also shift-cursor, etc., like in + normal_cmd(). + - remember start and end of selection in cmdline_info. + - Typing text replaces the selection. + + +Visual mode: +- When dragging the Visual selection with the mouse and 'scrolloff' is zero, + behave like 'scrolloff' is one, so that the text scrolls when the pointer + is in the top line. +- Displaying size of Visual area: use 24-33 column display. + When selecting multiple lines, up to about a screenful, also count the + characters. +8 When using "I" or "A" in Visual block mode, short lines do not get the new + text. Make it possible to add the text to short lines too, with padding + where needed. +7 With a Visual block selected, "2x" deletes a block of double the width, + "3y" yanks a block of triple width, etc. +7 When selecting linewise, using "itext" should insert "text" at the start + of each selected line. +8 What is "R" supposed to do in Visual mode? +8 Make Visual mode local to the buffer. Allow changing to another buffer. + When starting a new Visual selection, remove the Visual selection in any + other buffer. (Ron Aaron) +8 Support dragging the Visual area to drop it somewhere else. (Ron Aaron, + Ben Godfrey) +7 Support dragging the Visual area to drop it in another program, and + receive dropped text from another program. (Ben Godfrey) +7 With blockwise Visual mode and "c", "C", "I", "A", etc., allow the use of + a <CR>. The entered lines are repeated over the Visual area. +7 CTRL-V :s should substitute only in the block, not to whole lines. (David + Young is working on this) +7 Filtering a block should only apply to the block, not to the whole lines. + When the number of lines is increased, add lines. When decreased, pad with + spaces or delete? Use ":`<,`>" on the command line. +8 After filtering the Visual area, make "gv" select the filtered text? + Currently "gv" only selects a single line, not useful. +7 Don't move the cursor when scrolling? Needed when the selection should + stay the same. Scroll to the cursor at any movement command. With an + option! +7 In Visual block mode, need to be able to define a corner on a position + that doesn't have text? Also: when using the mouse, be able to select + part of a TAB. Even more: Add a mode where the cursor can be on a screen + position where there is no text. When typing, add spaces to fill the gap. + Other solution: Always use curswant, so that you can move the cursor to + the right column, and then use up/down movements to select the line, + without changing the column. +6 ":left" and ":right" should work in Visual block mode. +7 CTRL-I and CTRL-O should work in Visual mode, but only jump to marks in the + current buffer. +7 CTRL-A and CTRL-X should increase/decrease all numbers in the Visual area. +6 In non-Block mode, "I" should insert the same text in front of each line, + before the first non-blank, "gI" in column 1. +6 In non-Block mode, "A" should append the same text after each line. +6 When in blockwise visual selection (CTRL-V), allow cursor to be placed + right of the line. Could also allow cursor to be placed anywhere on a TAB + or other special character. +6 Add commands to move selected text, without deselecting. + + +More advanced repeating commands: +- Add "." command for visual mode: redo last visual command (e.g. ":fmt"). +7 Repeating "d:{cmd}" with "." doesn't work. (Benji Fisher) Somehow remember + the command line so that it can be repeated? +- Add "gn": repeat last movement command. Including count. +- Add "." command after operator: repeat last command of same operator. E.g. + "c." will repeat last change, also when "x" used since then (Webb). + "y." will repeat last yank. + "c2." will repeat the last but one change? + Also: keep history of Normal mode commands, add command to list the history + and/or pick an older command. +- History stack for . command? Use "g." command. + + +Mappings and Abbreviations: +8 When "0" is mapped (it is a movement command) this mapping should not be + used after typing another number, e.g. "20l". (Charles Campbell) + Is this possible without disabling the mapping of the following command? +8 Should mapping <C-A> and <C-S-A> both work? +7 ":abbr b byte", append "b " to an existing word still expands to "byte". + This is Vi compatible, but can we avoid it anyway? +8 To make a mapping work with a prepended "x to select a register, store the + last _typed_ register name and access it with "&. +8 Add ":amap", like ":amenu". +7 Add a mapping that works always, for remapping the keyboard. +8 Add ":cab!", abbreviations that only apply to Command-line mode and not to + entering search strings. +8 Add a flag to ":abbrev" to eat the character that triggers the + abbreviation. Thus "abb ab xxx" and typing "ab<Space>" inserts "xxx" and + not the <Space>. +8 Allow mapping of CTRL-@ (anywhere in the LHS). +8 Give a warning when using CTRL-C in the lhs of a mapping. It will never + (?) work. +8 Add a way to save a current mapping and restore it later. Use a function + that returns the mapping command to restore it: mapcmd()? mapcheck() is + not fool proof. How to handle ambiguous mappings? +7 Add <0x8f> (hex), <033> (octal) and <123> (decimal) to <> notation? +7 Allow mapping "Q" and "Q}" at the same time. Need to put a flag with "Q", + that it needs an extra character before it can match. See Vile 'maplonger' + option. +7 When someone tries to unmap with a trailing space, and it fails, try + unmapping without the trailing space. Helps for ":unmap xx | unmap yy". +7 Make it possible to map 'wildchar', but only when it's a special character + (like CTRL-E). Currently it's only recognized when typed. Useful for + mapping a key to do something and then completion. +6 Context-sensitive abbreviations: Specify syntax group(s) in which the + abbreviations are to be used. +- Add mappings that take arguments. Could work like the ":s" command. For + example, for a mouse escape sequence: + :mapexp <Esc>{\([0-9]*\),\([0-9]*\); H\1j\2l +- Add optional <Number> argument for mappings: + :map <Number>q ^W^W<Number>G + :map <Number>q<Number>t ^W^W<Number1-1>G<Number2>l + :map q<Char> :s/<Char>/\u\0/g + Or implicit: + :map q <Register>d<Number>$ +- Make it possible to include a <Nul> in the lhs and rhs of a mapping. +- Add command to repeat a whole mapping ("." only repeats the last change in + a mapping). Also: Repeat a whole insert command, including any mappings + that it included. Sort-of automatic recording? +- Add an option to ":map" that makes it display the special keys in + <> notation (e.g. <CR> instead of ^M). Or just always do this? +- Include an option (or flag to 'cpoptions') that makes errors in mappings + not flush the rest of the mapping (like nvi does). +- Use context sensitiveness of completion to switch abbreviations and + mappings off for :unab and :unmap. +6 When using mappings in Insert mode, insert characters for incomplete + mappings first, then remove them again when a mapping matches. Avoids + that characters that are the start of some mapping are not shown until you + hit another character. +- Add mappings for replace mode: ":rmap". How do we then enter mappings for + non-replace Insert mode? +- Add separate mappings for Visual-character/block/line mode? +- Add 'mapstop' command, to stop recursive mappings. +- List mappings that have a raw escape sequence both with the name of the key + for that escape sequence (if there is one) and the sequence itself. +- List mappings: Once with special keys listed as <>, once with meta chars as + <M-a>, once with the byte values (octal?). Sort of "spell mapping" command? +- When entering mappings: Add the possibility to enter meta keys like they + are displayed, within <>: <M-a>, <~@> or <|a>. +- Allow multiple arguments to :unmap. +- Command to show keys that are not used and available for mapping + ":freekeys". +- Allow any character except white space in abbreviations lhs (Riehm). + + +Incsearch: +- Add a limit to the number of lines that are searched for 'incsearch'? +- When no match is found and the user types more, the screen is redrawn + anyway. Could skip that. Esp. if the line wraps and the text is scrolled + up every time. +- Temporarily open folds to show where the search ends up. Restore the + folds when going to another line. +- When incsearch used and hitting return, no need to search again in many + cases, saves a lot of time in big files. (Slootman wants to work on this?) + When not using special characters, can continue search from the last match + (or not at all, when there was no match). See oldmail/webb/in.872. +- With incsearch, use CTRL-N/CTRL-P to go to next/previous match, some other + key to copy matched word to search pattern (Alexander Schmid). + + +Searching: +8 Add "g/" and "gb" to search for a pattern in the Visually selected text? + "g?" is already used for rot13. + The vis.vim script has a ":S" command that does something like this. + Can use "g/" in Normal mode, uses the '< to '> area. + Use "&/" for searching the text in the Visual area? +9 Add "v" offset: "/pat/v": search for pattern and start Visual mode on the + matching text. +8 Add a mechanism for recursiveness: "\@(([^()]*\@g[^()]*)\)". \@g stands + for "go recursive here" and \@( \) marks the recursive part. + Perl does it this way: + $paren = qr/ \(( [^()] | (??{ $paren }) )* \) /x; + Here $paren is evaluated when it's encountered. This is like a regexp + inside a regexp. In the above terms it would be: + \@((\([^()]\|\@g\)*)\) +8 Show the progress every second. Could use the code that checks for CTRL-C + to find out how much time has passed. Or use SIGALRM. Where to show the + number? +8 When using an expression for ":s", set the match position in a v: + variable. So that you can do ":%s/^/\=v:lnum/" to put a line number + before each line. +7 Support for approximate-regexps to find similar words (agrep + http://www.tgries.de/agrep/ tre: http://laurikari.net/tre/index.html). +8 Add an item for a big character range, so that one can search for a + chinese character: \z[234-1234] or \z[XX-YY] or \z[0x23-0x234]. +7 Add an item stack to allow matching (). One side is "push X on + the stack if previous atom matched". Other side is "match with top of + stack, pop it when it matches". Use "\@pX" and "\@m"? + Example: \((\@p).\{-}\@m\)* +7 Add an option to accept a match at the cursor position. Also for + search(). (Brett) +7 Add a flag to "/pat/" to discard an error. Useful to continue a mapping + when a search fails. Could be "/pat/E" (e is already used for end offset). +7 Add pattern item to use properties of Unicode characters. In Perl it's + "\p{L}" for a letter. See Regular Expression Pocket Reference. +8 Would it be possible to allow ":23,45/pat/flags" to search for "pat" in + lines 23 to 45? Or does this conflict with Ex range syntax? +8 Allow identical pairs in 'matchpairs'. Restrict the search to the current + line. +7 Allow longer pairs in 'matchpairs'. Use ~/vim/macros/matchit.vim as an + example. +8 Make it possible to define the character that "%" checks for in + #if/#endif. For nmake it's !if/!endif. +- For "%" command: set hierarchy for which things include other things that + should be ignored (like "*/" or "#endif" inside /* */). + Also: use "%" to jump from start to end of syntax region and back. + Alternative: use matchit.vim +8 "/:/e+1" gets stuck on a match at the end of the line. Do we care? +8 A pattern like "\([^a]\+\)\+" takes an awful long time. Recognize that + the recursive "\+" is meaningless and optimize for it. + This one is also very slow on "/* some comment */": "^\/\*\(.*[^/]\)*$". +7 Recognize "[a-z]", "[0-9]", etc. and replace them with the faster "\l" and + "\d". +7 Add a way to specify characters in <C-M> or <Key> form. Could be + \%<C-M>. +8 Add an argument after ":s/pat/str/" for a range of matches. For example, + ":s/pat/str/#3-4" to replace only the third and fourth "pat" in a line. +8 When 'iskeyword' is changed the matches from 'hlsearch' may change. (Benji + Fisher) redraw if some options are set while 'hlsearch' is set? +8 Add an option not to use 'hlsearch' highlighting for ":s" and ":g" + commands. (Kahn) It would work like ":noh" is used after that command. + Also: An extra flag to do this once, and a flag to keep the existing + search pattern. +- Make 'hlsearch' a local/global option, so that it can be disabled in some + of the windows. +- Add \%h{group-name}; to search for a specific highlight group. + Add \%s{syntax-group}; to search for a specific syntax group. +- Support Perl regexp. Use PCRE (Perl Compatible RE) package. (Shade) + Or translate the pattern to a Vim one. + Don't switch on with an option for typed commands/mappings/functions, it's + too confusing. Use "\@@" in the pattern, to avoid incompatibilities. +8 Add a way to access the last substitute text, what is used for ":s//~/". + Can't use the ~ register, it's already used for drag & drop. +- Remember flags for backreferenced items, so that "*" can be used after it. + Check with "\(\S\)\1\{3}". (Hemmerling) +8 Flags that apply to the whole pattern. + This works for all places where a regexp is used. + Add "\q" to not store this pattern as the last search pattern? +- Add flags to search command (also for ":s"?): + i ignore case + I use case + p use Perl regexp syntax (or POSIX?) + v use Vi regexp syntax + f forget pattern, don't keep it for "n" command + F remember pattern, keep it for "n" command + Perl uses these too: + e evaluate the right side as an expression (Perl only) + m multiple line expression (we don't need it) + o compile only once (Perl only) + s single line expression (we don't need it) + x extended regexp (we don't need it) + When used after ":g" command, backslash needed to avoid confusion with the + following command. + Add 'searchflags' for default flags (replaces 'gdefault'). +- Add command to display the last used substitute pattern and last used + pattern. (Margo) Maybe make it accessible through a register (like "/ + for search string)? +7 Use T-search algorithm, to speed up searching for strings without special + characters. See C't article, August 1997. +- Add 'fuzzycase' option, so that case doesn't matter, and '-' and '_' are + equivalent (for Unix filenames). +- Add 'v' flag to search command: enter Visual mode, with the matching text + as Visual area. (variation on idea from Bertin) +- Searching: "/this//that/" should find "that" after "this". +- Add global search commands: Instead of wrapping at the end of the buffer, + they continue in another buffer. Use flag after search pattern: + a for the next file in the argument list + f for file in the buffer list + w for file edited in a window. + e.g. "/pat/f". Then "n" and "N" work through files too. "f" flag also for + ":s/pat/foo/f"??? Then when 'autowrite' and 'hidden' are both not set, ask + before saving files: "Save modified buffer "/path/file"? (Yes/Hide/No + Save-all/hide-All/Quit) ". +- ":s/pat/foo/3": find 3rd match of "pat", like sed. (Thomas Koehler) +7 When searching with 'n' give message when getting back where the search + first started. Remember start of search in '/ mark. +7 Add option that scrolls screen to put cursor in middle of screen after + search always/when off-screen/never. And after a ":tag" command. Maybe + specify how many lines below the screen causes a redraw with the cursor in + the middle (default would be half a screen, zero means always). +6 Support multiple search buffers, so macros can be made without side + effects. +7 From xvim: Allow a newline in search patterns (also for :s, can delete + newline). Add BOW, EOW, NEWL, NLORANY, NLBUTANY, magic 'n' and 'r', etc. + [not in xvim:] Add option to switch on matches crossing ONE line boundary. +7 Add ":iselect", a combination of ":ilist" and ":tselect". (Aaron) (Zellner) + Also ":dselect". + + +Undo: +9 After undo/redo, in the message show whether the buffer is modified or + not. +8 Use timestamps for undo, so that a version a certain time ago can be found + and info before some time/date can be flushed. 'undopersist' gives maximum + time to keep undo: "3h", "1d", "2w", "1y", etc. +8 Search for pattern in undo tree, showing when it happened and the text + state, so that you can jump to it. +8 Undo tree: visually show the tree somehow (Damian Conway) + Show only the leaves, indicating how many changed from the branch and the + timestamp? + Put branch with most recent change on the left, older changes get more + indent? +8 See ":e" as a change operation, find the changes and add them to the + undo info. Also be able to undo the "Reload file" choice for when a file + was changed outside of Vim. + Would require doing a diff between the buffer text and the file and + storing the differences. + Alternative: before reloading a buffer, store it somewhere. Keep a list + of about 10 last reloaded buffers. +- Make it possible to undo all the commands from a mapping, including a + trailing unfinished command, e.g. for ":map K iX^[r". +- When accidentally hitting "R" instead of Ctrl-R, further Ctrl-R is not + possible, even when typing <Esc> immediately. (Grahn) Also for "i", "a", + etc. Postpone saving for undo until something is really inserted? +8 When Inserting a lot of text, it can only be undone as a whole. Make undo + sync points at every line or word. Could recognize the start of a new + word (white space and then non-white space) and backspacing. + Can already use CTRL-G u, but that requires remapping a lot of things. +8 Make undo more memory-efficient: Compare text before and after change, + only remember the lines that really changed. +7 Add undo for a range of lines. Can change these back to a previous + version without changing the rest of the file. Stop doing this when a + change includes only some of these lines and changes the line count. Need + to store these undo actions as a separate change that can be undone. +- For u_save() include the column number. This can be used to set '[ and ']. + And in the future the undo can be made more efficient (Webb). +- In out-of-memory situations: Free allocated space in undo, and reduce the + number of undo levels (with confirmation). +- Instead of [+], give the number of changes since the last write: [+123]. + When undoing to before the last write, change this to a negative number: + [-99]. +- With undo with simple line delete/insert: optimize screen updating. +- When executing macro's: Save each line for undo only once. +- When doing a global substitute, causing almost all lines to be changed, + undo info becomes very big. Put undo info in swap file?? + + +Buffer list: +7 Command to execute a command in another buffer: ":inbuf {bufname} {cmd}". + Also for other windows: ":inwin {winnr} {cmd}". How to make sure that + this works properly for all commands, and still be able to return to the + current buffer/window? E.g.: ":inbuf xxx only". +8 Add File.{recent_files} menu entries: Recently edited files. + Ron Aaron has a plugin for this: mru.vim. +8 Unix: Check all uses of fnamecmp() and fnamencmp() if they should check + inode too. +7 Add another number for a buffer, which is visible for the user. When + creating a new buffer, use the lowest number not in use (or the highest + number in use plus one?). +7 Offer some buffer selection from the command line? Like using ":ls" and + asking for a buffer number. (Zachmann) +- When starting to edit a file that is already in the buffer list, use the + file name argument for the new short file name. (Webb) +- Add an option to make ":bnext" and ":bprev" wrap around the end of the + buffer list. Also for ":next" and ":prev"? +7 Add argument to ":ls" which is a pattern for buffers to list. + E.g. ":ls *.c". (Thompson) +7 Add expansion of buffer names, so that "*.c" is expanded to all buffer + names. Needed for ":bdel *.c", ":bunload *.c", etc. +8 Support for <afile> where a buffer name is expected. +8 Some commands don't use line numbers, but buffer numbers. '$' + should then mean the number of the last buffer. E.g.: "4,$bdel". +7 Add an option to mostly use slashes in file names. Separately for + internal use and for when executing an external program? + + +Swap (.swp) files: +8 If writing to the swap file fails, should try to open one in another + directory from 'dir'. Useful in case the file system is full and when + there are short file name problems. +8 Also use the code to try using a short file name for the backup and swap + file for the Win32 and Dos 32 bit versions. +8 When a file is edited by root, add $LOGNAME to know who did su. +8 When the edited file is a symlink, try to put the swap file in the same + dir as the actual file. Adjust FullName(). Avoids editing the same file + twice (e.g. when using quickfix). Also try to make the name of the backup + file the same as the actual file? + Use the code for resolve()? +7 When using 64 bit inode numbers, also store the top 32 bits. Add another + field for this, using part of bo_fname[], to keep it compatible. +7 When editing a file on removable media, should put swap file somewhere + else. Use something like 'r' flag in 'viminfo'. 'diravoid'? + Also: Be able to specify minimum disk space, skip directory when not + enough room. +7 Add a configure check for which directory should be used: /tmp, /var/tmp + or /var/preserve. +- Add an option to create a swap file only when making the first change to + the buffer. (Liang) Or only when the buffer is not read-only. +- Add option to set "umask" for backup files and swap files (Antwerpen). + 'backupumask' and 'swapumask'? Or 'umaskback' and 'umaskswap'? +- When editing a readonly file, don't use a swap file but read parts from the + original file. Also do this when the file is huge (>'maxmem'). We do + need to load the file once to count the number of lines? Perhaps keep a + cached list of which line is where. + + +Viminfo: +7 Can probably remove the code that checks for a writable viminfo file, + because we now do the chown() for root, and others can't overwrite someone + else's viminfo file. +8 When there is no .viminfo file and someone does "su", runs Vim, a + root-owned .viminfo file is created. Is there a good way to avoid this? + Perhaps check the owner of the directory. Only when root? +8 Add argument to keep the list of buffers when Vim is started with a file + name. (Schild) +8 Keep the last used directory of the file browser (File/Open menu). +8 Remember the last used register for "@@". +8 Remember the redo buffer, so that "." works after restarting. +8 Remember a list of last accessed files. To be used in the + "File.Open Recent" menu. Default is to remember 10 files or so. + Also remember which files have been read and written. How to display + this? +7 Also store the ". register (last inserted text). +7 Make it possible to store buffer names in viminfo file relative to some + directory, to make them portable over a network. (Aaron) +6 Store a snapshot of the currently opened windows. So that when quitting + Vim, and then starting again (without a file name argument), you see the + same files in the windows. Use ":mksession" code? +- Make marks present in .viminfo usable as file marks: Display a list of + "last visited files" and select one to jump to. + + +Modelines: +8 Before trying to execute a modeline, check that it looks like one (valid + option names). If it's very wrong, silently ignore it. + Ignore a line that starts with "Subject: ". +- Add an option to whitelist options that are allowed in a modeline. This + would allow careful users to use modelines, e.g., only allowing + 'shiftwidth'. +- Add an option to let modelines only set local options, not global ones + such as 'encoding'. +- When an option value is coming from a modeline, do not carry it over to + another edited file? Would need to remember the value from before the + modeline setting. +- Allow setting a variable from a modeline? Only allow using fixed strings, + no function calls, to avoid a security problem. +- Allow ":doauto BufRead x.cpp" in modelines, to execute autocommands for + .cpp files. +- Support the "abbreviate" command in modelines (Kearns). Careful for + characters after <Esc>, that is a security leak. +- Add option setting to ask user if he wants to have the modelines executed + or not. Same for .exrc in local dir. + + +Sessions: +8 DOS/Windows: ":mksession" generates a "cd" command where "aa\#bb" means + directory "#bb" in "aa", but it's used as "aa#bb". (Ronald Hoellwarth) +7 When there is a "help.txt" window in a session file, restoring that + session will not get the "LOCAL ADDITIONS" back. +8 With ":mksession" always store the 'sessionoptions' option, even when + "options" isn't in it. (St-Amant) +8 When using ":mksession", also store a command to reset all options to + their default value, before setting the options that are not at their + default value. +7 With ":mksession" also store the tag stack and jump history. (Michal + Malecki) +7 Persistent variables: "p:var"; stored in viminfo file and sessions files. + + +Options: +7 ":with option=value | command": temporarily set an option value and + restore it after the command has executed. +7 Setting an option always sets "w_set_curswant", while this is only + required for a few options. Only do it for those options to avoid the + side effect. +8 Make "old" number options that really give a number of effects into string + options that are a comma separated list. The old number values should + also be supported. +8 Add commands to save and restore an option, which also preserves the flag + that marks if the option was set. Useful to keep the effect of setting + 'compatible' after ":syntax on" has been used. +7 There is 'titleold', why is there no 'iconold'? (Chazelas) +7 Make 'scrolloff' a global-local option, so that it can be different in the + quickfix window, for example. (Gary Holloway) + + +External commands: +8 When filtering text, redirect stderr so that it can't mess up the screen + and Vim doesn't need to redraw it. Also for ":r !cmd". +4 Set separate shell for ":sh", piping "range!filter", reading text "r !ls" + and writing text "w !wc". (Deutsche) Allow arguments for fast start (e.g. + -f). +4 Allow direct execution, without using a shell. +4 Run an external command in the background. But how about I/O in the GUI? + Careful: don't turn Vim into a shell! +4 Add feature to disable using a shell or external commands. + + +Multiple Windows: +7 "vim -oO file ..." use both horizontal and vertical splits. +8 Add CTRL-W T: go to the top window in the column of the current window. + And CTRL-W B: go to bottom window. +7 Use CTRL-W <Tab>, like alt-tab, to switch between buffers. Repeat <Tab> + to select another buffer (only loaded ones?), <BS> to go back, <Enter> to + select buffer, <Esc> to go back to original buffer. +7 Make it possible to edit a new buffer in the preview window. A script can + then fill it with something. ":popen"? +7 Add a 'tool' window: behaves like a preview window but there can be + several. Don't count it in only_one_window(). (Alexei Alexandrov) +6 Add an option to resize the shell when splitting and/or closing a window. + ":vsp" would make the shell wider by as many columns as needed for the new + window. Specify a maximum size (or use the screen size). ":close" would + shrink the shell by as many columns as come available. (Demirel) +7 When starting Vim several times, instantiate a Vim server, that allows + communication between the different Vims. Feels like one Vim running with + multiple top-level windows. Esp. useful when Vim is started from an IDE + too. Requires some form of inter process communication. +- Support a connection to an external viewer. Could call the viewer + automatically after some seconds of non-activity, or with a command. + Allow some way of reporting scrolling and cursor positioning in the viewer + to Vim, so that the link between the viewed and edited text can be made. + + +Marks: +8 Add ten marks for last changed files: ':0, ':1, etc. One mark per file. +8 When cursor is first moved because of scrolling, set a mark at this + position. (Rimon Barr) Use '-. +8 Add a command to jump to a mark and make the motion inclusive. g'm and g`m? +8 The '" mark is set to the first line, even when doing ":next" a few times. + Only set the '" mark when the cursor was really moved in a file. +8 Make `` and '', which would position the new cursor position in the middle + of the window, restore the old topline (or relative position) from when + the mark was set. +7 Make a list of file marks in a separate window. For listing all buffers, + matching tags, errors, etc. Normal commands to move around. Add commands + to jump to the mark (in current window or new window). Start it with + ":browse marks"? +6 Add a menu that lists the Marks like ":marks". (Amerige) +7 For ":jumps", ":tags" and ":marks", for not loaded buffers, remember the + text at the mark. Highlight the column with the mark. +7 Highlight each mark in some way (With "Mark" highlight group). + Or display marks in a separate column, like 'number' does. +7 Use d"m to delete rectangular area from cursor to mark m (like Vile's \m + command). +7 Try to keep marks in the same position when: + - replacing with a line break, like in ":s/pat/^M/", move marks after the + line break column to the next line. (Acevedo) + - inserting/deleting characters in a line. +5 Include marks for start/end of the current word and section. Useful in + mappings. +6 Add "unnamed mark" feature: Like marks for the ":g" command, but place and + unplace them with commands before doing something with the lines. + Highlight the marked lines somehow. + + +Digraphs: +7 Make "ga" show the digraph for a character, if it exists. + Also the keymap? +- Make it possible to enter "r<C-E>" and "r<C-Y>" (get character from line + below/above). +- Use digraph table to tell Vim about the collating sequence of special + characters? +8 Add command to remove one or more (all) digraphs. (Brown) +7 Support different sets of digraphs (depending on the character set?). At + least Latin1/Unicode, Latin-2, MS-DOS (esp. for Win32). + + +Writing files: +- In vim_rename(), should lock "from" file when deleting "to" file for + systems other than Amiga. Avoids problems with unexpected longname to + shortname conversion. +8 write mch_isdevice() for Amiga, Mac, VMS, etc. +8 When appending to a file, Vim should also make a backup and a 'patchmode' + file. +8 'backupskip' doesn't write a backup file at all, a bit dangerous for some + applications. Add 'backupelsewhere' to write a backup file in another + directory? Or add a flag to 'backupdir'? +7 The 'directory' option supports changing path separators to "%" to make + file names unique, also support this for 'backupdir'. (Mikolaj Machowski) +6 Add an option to write a new, numbered, backup file each time. Like + 'patchmode', e.g., 'backupmode'. +6 Make it possible to write 'patchmode' files to a different directory. + E.g., ":set patchmode=~/backups/*.orig". (Thomas) +6 Add an option to prepend something to the backup file name. E.g., "#". + Or maybe allow a function to modify the backup file name? +8 Only make a backup when overwriting a file for the first time. Avoids + losing the original when writing twice. (Slootman) +7 On non-Unix machines, also overwrite the original file in some situations + (file system full, it's a link on an NFS partition). +7 When editing a file, check that it has been change outside of Vim more + often, not only when writing over it. E.g., at the time the swap file is + flushed. Or every ten seconds or so (use the time of day, check it before + waiting for a character to be typed). +8 When a file was changed since editing started, show this in the status + line of the window, like "[time]". + Make it easier to reload all outdated files that don't have changes. + Automatic and/or with a command. + + +Substitute: +8 Substitute with hex/unicode number "\%xff" and "\%uabcd". Just like + "\%uabcd" in search pattern. +8 Make it easier to replace in all files in the argument list. E.g.: + ":argsub/oldword/newword/". Works like ":argdo %s/oldword/newword/g|w". +- :s///p prints the line after a substitution. +- With :s///c replace \&, ~, etc. when showing the replacement pattern. +8 With :s///c allow scrolling horizontally when 'nowrap' is effective. + Also allow a count before the scrolling keys. +- Add number option to ":s//2": replace second occurrence of string? Or: + :s///N substitutes N times. +- Add answers to ":substitute" with 'c' flag, used in a ":global", e.g.: + ":g/pat1/s/pat2/pat3/cg": 'A' do all remaining replacements, 'Q' don't do + any replacements, 'u' undo last substitution. +7 Substitute in a block of text. Use {line}.{column} notation in an Ex + range, e.g.: ":1.3,$.5s" means to substitute from line 1 column 3 to the + last line column 5. +5 Add commands to bookmark lines, display bookmarks, remove bookmarks, + operate on lines with bookmarks, etc. Like ":global" but with the + possibility to keep the bookmarks and use them with several commands. + (Stanislav Sitar) + + +Mouse support: +8 Add 'o' flag to 'mouse'? +7 Be able to set a 'mouseshape' for the popup menu. +8 Add 'mouse' flag, which sets a behavior like Visual mode, but automatic + yanking at the button-up event. Or like Select mode, but typing gets you + out of Select mode, instead of replacing the text. (Bhaskar) +- Implement mouse support for the Amiga console. +- Using right mouse button to extend a blockwise selection should attach to + the nearest corner of the rectangle (four possible corners). +- Precede mouse click by a number to simulate double clicks?!? +- When mouse click after 'r' command, get character that was pointed to. + + +Argument list: +6 Add command to put all filenames from the tag files in the argument list. + When given an argument, only use the files where that argument matches + (like `grep -l ident`) and jump to the first match. +6 Add command to form an args list from all the buffers? + + +Registers: +8 Don't display empty registers with ":display". (Etienne) +8 Make the # register writable, so that it can be restored after jumping + around in windows. +8 Add put command that overwrites existing text. Should also work for + blocks. Useful to move text around in a table. Works like using "R ^R r" + for every line. +6 When yanking into the unnamed registers several times, somehow make the + previous contents also available (like it's done for deleting). What + register names to use? g"1, g"2, etc.? +- When appending to a register, also report the total resulting number of + lines. Or just say "99 more lines yanked", add the "more". +- When inserting a register in Insert mode with CTRL-R, don't insert comment + leader when line wraps? +- The ":@r" commands should take a range and execute the register for each + line in the range. +- Add "P" command to insert contents of unnamed register, move selected text + to position of previous deleted (to swap foo and bar in " + foo") +8 Should be able to yank and delete into the "/ register. + How to take care of the flags (offset, magic)? + + +Debug mode: +7 Add something to enable debugging when a remote message is received. +8 Add breakpoints for setting an option +8 Add breakpoints for assigning to a variable. +7 Add a watchpoint in the debug mode: An expression that breaks execution + when evaluating to non-zero. Add the "watchadd expr" command, stop when + the value of the expression changes. ":watchdel" deletes an item, + ":watchlist" lists the items. (Charles Campbell) +7 Store the history from debug mode in viminfo. +7 Make the debug mode history available with histget() et al. + + +Various improvements: +8 ":sign unplace * file={filename}" should work. Also: ":sign unplace * + buffer={bufnr}". So one can remove all signs for one file/buffer. +7 Add plugins for formatting? Should be able to make a choice depending on + the language of a file (English/Korean/Japanese/etc.). + Setting the 'langformat' option to "chinese" would load the + "format/chinese.vim" plugin. + The plugin would set 'formatexpr' and define the function being called. + Edward L. Fox explains how it should be done for most Asian languages. + (2005 Nov 24) + Alternative: patch for utf-8 line breaking. (Yongwei Wu, 2008 Feb 23) +7 [t to move to previous xml/html tag (like "vatov"), ]t to move to next + ("vatv"). +7 [< to move to previous xml/html tag, e.g., previous <li>. ]< to move to + next <li>, ]< to next </li>, [< to previous </li>. +8 Add ":rename" command: rename the file of the current buffer and rename + the buffer. Buffer may be modified. +7 Instead of filtering errors with a shell script it should be possible to + do this with Vim script. A function that filters the raw text that comes + from the 'makeprg'? +- Add %b to 'errorformat': buffer number. (Yegappan Lakshmanan / Suresh + Govindachar) +7 Add a command that goes back to the position from before jumping to the + first quickfix location. ":cbefore"? +7 Allow a window not to have a statusline. Makes it possible to use a + window as a buffer-tab selection. +8 Allow non-active windows to have a different statusline. (Yakov Lerner) +6 Python interface: add vim.message() function. (Michal Vitecek, 2002 Nov 5) +7 Support using ":vert" with User commands. Add expandable items <vert>. + Do the same for ":browse" and ":confirm"? + For ":silent" and ":debug" apply to the whole user command. + More general: need a way to access command modifiers in a user command. + Assign them to a v: variable? +7 Add an invisible buffer which can be edited. For use in scripts that want + to manipulate text without changing the window layout. +8 Add a command to revert to the saved version of file; undo or redo until + all changes are gone. +6 "vim -q -" should read the list of errors from stdin. (Gautam Mudunuri) +8 Add "--remote-fail": When contacting the server fails, exit Vim. + Add "--remote-self": When contacting the server fails, do it in this Vim. + Overrules the default of "--remote-send" to fail and "--remote" to do it + in this Vim. +8 When Vim was started without a server, make it possible to start one, as + if the "--servername" argument was given. ":startserver <name>"? +8 No address range can be used before the command modifiers. This makes + them difficult to use in a menu for Visual mode. Accept the range and + have it apply to the following command. +8 Add the possibility to set 'fileformats' to force a format and strip other + CR characters. For example, for "dos" files remove CR characters at the + end of the line, so that a file with mixed line endings is cleaned up. + To just not display the CR characters: Add a flag to 'display'? +7 Some compilers give error messages in which the file name does not have a + path. Be able to specify that 'path' is used for these files. +7 Xterm sends <Esc>O3F for <M-End>. Similarly for other <M-Home>, <M-Left>, + etc. Combinations of Alt, Ctrl and Shift are also possible. Recognize + these to avoid inserting the raw byte sequence, handle like the key + without modifier (unless mapped). +6 Add "gG": like what "gj" is to "j": go to the N'th window line. +8 Add command like ":normal" that accepts <Key> notation like ":map". +9 Support ACLs on more systems. +7 Add ModeMsgVisual, ModeMsgInsert, etc. so that each mode message can be + highlighted differently. +7 Add a message area for the user. Set some option to reserve space (above + the command line?). Use an ":echouser" command to display the message + (truncated to fit in the space). +7 Add %s to 'keywordprg': replace with word under the cursor. (Zellner) +8 Support printing on Unix. Can use "lpansi.c" as an example. (Bookout) +8 Add put command that replaces the text under it. Esp. for blockwise + Visual mode. +7 Enhance termresponse stuff: Add t_CV(?): pattern of term response, use + regexp: "\e\[[>?][0-9;]*c", but only check just after sending t_RV. +7 Add "g|" command: move to N'th column from the left margin (after wrapping + and applying 'leftcol'). Works as "|" like what "g0" is to "0". +7 Support setting 'equalprg' to a user function name. +7 Highlight the characters after the end-of-line differently. +7 When 'whichwrap' contains "l", "$dl" should join lines? +8 Add an argument to configure to use $CFLAGS and not modify it? (Mooney) +8 Enabling features is a mix of configure arguments and defines in + feature.h. How to make this consistent? Feature.h is required for + non-unix systems. Perhaps let configure define CONF_XXX, and use #ifdef + CONF_XXX in feature.h? Then what should min-features and max-features do? +8 Add "g^E" and "g^Y", to scroll a screen-full line up and down. +6 Add ":timer" command, to set a command to be executed at a certain + interval, or once after some time has elapsed. (Aaron) + Perhaps an autocommand event like CursorHold is better? +8 Add ":confirm" handling in open_exfile(), for when file already exists. +8 When quitting with changed files, make the dialog list the changed file + and allow "write all", "discard all", "write some". The last one would + then ask "write" or "discard" for each changed file. Patch in HierAssist + does something like this. (Shah) +7 Use growarray for replace stack. +7 Have a look at viH (Hellenic or Greek version of Vim). But a solution + outside of Vim might be satisfactory (Haritsis). +3 Make "2d%" work like "d%d%" instead of "d2%"? +7 "g CTRL-O" jumps back to last used buffer. Skip CTRL-O jumps in the same + buffer. Make jumplist remember the last ten accessed buffers? +- Add code to disable the CAPS key when going from Insert to Normal mode. +- Set date/protection/etc. of the patchfile the same as the original file. +- Use growarray for termcodes[] in term.c +- Add <window-99>, like <cword> but use filename of 99'th window. +7 Add a way to change an operator to always work characterwise-inclusive + (like "v" makes the operator characterwise-exclusive). "x" could be used. +- Make a set of operations on list of names: expand wildcards, replace home + dir, append a string, delete a string, etc. +- Remove mktemp() and use tmpname() only? Ctags does this. +- When replacing environment variables, and there is one that is not set, + turn it into an empty string? Only when expanding options? (Hiebert) +- Option to set command to be executed instead of producing a beep (e.g. to + call "play newbeep.au"). +- Add option to show the current function name in the status line. More or + less what you find with "[[k", like how 'cindent' recognizes a function. + (Bhatt). +- "[r" and "]r": like "p" and "P", but replace instead of insert (esp. for + blockwise registers). +- Add 'timecheck' option, on by default. Makes it possible to switch off the + timestamp warning and question. (Dodt). +- Add an option to set the time after which Vim should check the timestamps + of the files. Only check when an event occurs (e.g., character typed, + mouse moved). Useful for non-GUI versions where keyboard focus isn't + noticeable. +- Make 'smartcase' work even though 'ic' isn't set (Webb). +7 When formatting text, allow to break the line at a number of characters. + Use an option for this: 'breakchars'? Useful for formatting Fortran code. +- Add flag to 'formatoptions' to be able to format book-style paragraphs + (first line of paragraph has larger indent, no empty lines between + paragraphs). Complements the '2' flag. Use '>' flag when larger indent + starts a new paragraph, use '<' flag when smaller indent starts a new + paragraph. Both start a new paragraph on any indent change. +8 The 'a' flag in 'formatoptions' is too dangerous. In some way only do + auto-formatting in specific regions, e.g. defined by syntax highlighting. +8 Allow using a trailing space to signal a paragraph that continues on the + next line (MIME text/plain; format=flowed, RFC 2646). Can be used for + continuous formatting. Could use 'autoformat' option, which specifies a + regexp which triggers auto-formatting (for one line). + ":set autoformat=\\s$". +- Be able to redefine where a sentence stops. Use a regexp pattern? +- Support multi-byte characters for sentences. Example from Ben Peterson. +7 Add command "g)" to go to the end of a sentence, "g(" to go back to the + end of a sentence. (Servatius Brandt) +- Be able to redefine where a paragraph starts. For "[[" where the '{' is + not in column 1. +6 Add ":cdprev": go back to the previous directory. Need to remember a + stack of previous directories. We also need ":cdnext". +7 Should ":cd" for MS-DOS go to $HOME, when it's defined? +- Make "gq<CR>" work on the last line in the file. Maybe for every operator? +- Add more redirecting of Ex commands: + :redir #> bufname + :redir #>> bufname (append) +- Give error message when starting :redir: twice or using END when no + redirection was active. +- Setting of options, specifically for a buffer or window, with + ":set window.option" or ":set buffer.option=val". Or use ":buffer.set". + Also: "buffer.map <F1> quit". +6 Would it be possible to change the color of the cursor in the Win32 + console? (Klaus Hast) +- Add :delcr command: + *:delcr* + :[range]delcr[!] Check [range] lines (default: whole buffer) for lines + ending in <CR>. If all lines end in <CR>, or [!] is + used, remove the <CR> at the end of lines in [range]. + A CTRL-Z at the end of the file is removed. If + [range] is omitted, or it is the whole file, and all + lines end in <CR> 'textmode' is set. {not in Vi} +- Should integrate addstar() and file_pat_to_reg_pat(). +- When working over a serial line with 7 bit characters, remove meta + characters from 'isprint'. +- Use fchdir() in init_homedir(), like in FullName(). +- In win_update(), when the GUI is active, always use the scrolling area. + Avoid that the last status line is deleted and needs to be redrawn. +- That "cTx" fails when the cursor is just after 'x' is Vi compatible, but + may not be what you expect. Add a flag in 'cpoptions' for this? More + general: Add an option to allow "c" to work with a null motion. +- Give better error messages by using errno (strerror()). +- Give "Usage:" error message when command used with wrong arguments (like + Nvi). +- Make 'restorescreen' option also work for xterm (and others), replaces the + SAVE_XTERM_SCREEN define. +7 Support for ":winpos" In xterm: report the current window position. +- Give warning message when using ":set t_xx=asdf" for a termcap code that + Vim doesn't know about. Add flag in 'shortmess'? +6 Add ":che <file>", list all the include paths which lead to this file. +- For a commandline that has several commands (:s, :d, etc.) summarize the + changes all together instead of for each command (e.g. for the rot13 + macro). +- Add command like "[I" that also shows the tree of included files. +- ":set sm^L" results in ":set s", because short names of options are also + expanded. Is there a better way to do this? +- Add ":@!" command, to ":@" like what ":source!" is to ":source". +8 Add ":@:!": repeat last command with forceit set. +- Should be possible to write to a device, e.g. ":w! /dev/null". +- Add 't_normal': Used whenever t_me, t_se, t_ue or t_Zr is empty. +- ":cab map test ^V| je", ":cunab map" doesn't work. This is vi compatible! +- CTRL-W CTRL-E and CTRL-W CTRL-Y should move the current window up or down + if it is not the first or last window. +- Include-file-search commands should look in the loaded buffer of a file (if + there is one) instead of the file itself. +7 Change 'nrformats' to include the leader for each format. Example: + nrformats=hex:$,binary:b,octal:0 + Add setting of 'nrformats' to syntax files. +- 'path' can become very long, don't use NameBuff for expansion. +- When unhiding a hidden buffer, put the same line at top of the window as + the one before hiding it. Or: keep the same relative cursor position (so + many percent down the windows). +- Make it possible for the 'showbreak' to be displayed at the end of the + line. Use a comma to separate the part at the end and the start of the + line? Highlight the linebreak characters, add flag in 'highlight'. +- Some string options should be expanded if they have wildcards, e.g. + 'dictionary' when it is "*.h". +- Use a specific type for number and boolean options, making it possible to + change it for specific machines (e.g. when a long is 64 bit). +- Add option for <Insert> in replace mode going to normal mode. (Nugent) +- Add a next/previous possibility to "[^I" and friends. +- Add possibility to change the HOME directory. Use the directory from the + passwd file? (Antwerpen) +8 Add commands to push and pop all or individual options. ":setpush tw", + ":setpop tw", ":setpush all". Maybe pushing/popping all options is + sufficient. ":setflush" resets the option stack? + How to handle an aborted mapping? Remember position in tag stack when + mapping starts, restore it when an error aborts the mapping? +- Change ":fixdel" into option 'fixdel', t_del will be adjusted each time + t_bs is set? (Webb) +- "gc": goto character, move absolute character positions forward, also + counting newlines. "gC" goes backwards (Weigert). +- When doing CTRL-^, redraw buffer with the same topline. (Demirel) Store + cursor row and window height to redraw cursor at same percentage of window + (Webb). +- Besides remembering the last used line number of a file, also remember the + column. Use it with CTRL-^ et. al. +- Check for non-digits when setting a number option (careful when entering + hex codes like 0xff). +- Add option to make "." redo the "@r" command, instead of the last command + executed by it. Also to make "." redo the whole mapping. Basically: redo + the last TYPED command. +- Support URL links for ^X^F in Insert mode, like for "gf". +- Support %name% expansion for "gf" on Windows. +- Make "gf" work on "file://c:/path/name". "file:/c:/" and "file:///c:/" + should also work? +- Add 'urlpath', used like 'path' for when "gf" used on an URL? +8 When using "gf" on an absolute file name, while editing a remote file + (starts with scp:// or http://) should prepend the method and machine + name. +- When finding an URL or file name, and it doesn't exist, try removing a + trailing '.'. +- Add ":path" command modifier. Should work for every command that takes a + file name argument, to search for the file name in 'path'. Use + find_file_in_path(). +- Highlight control characters on the screen: Shows the difference between + CTRL-X and "^" followed by "X" (Colon). +- Integrate parsing of cmdline command and parsing for expansion. +- Create a program that can translate a .swp file from any machine into a + form usable by Vim on the current machine. +- Add ":noro" command: Reset 'ro' flag for all buffers, except ones that have + a readonly file. ":noro!" will reset all 'ro' flags. +- Add a variant of CTRL-V that stops interpretation of more than one + character. For entering mappings on the command line where a key contains + several special characters, e.g. a trailing newline. +- Add regex for 'paragraphs' and 'sections': 'parare' and 'sectre'. Combine + the two into a regex for searching. (Ned Konz) +- Make '2' option in 'formatoptions' also work inside comments. +- Add 's' flag to 'formatoptions': Do not break when inside a string. (Dodt) +- When window size changed (with the mouse) and made too small, set it back + to the minimal size. +- Add "]>" and "[<", shift comment at end of line (command; /* comment */). +- Should not call cursorcmd() for each vgetc() in getcmdline(). +- ":split file1 file2" adds two more windows (Webb). +- Don't give message "Incomplete last line" when editing binary file. +- Add ":a", ":i" for preloading of named buffers. +- Allow autowrite when doing ":e file" (with an option 'eaw'). +- Allow a "+command" argument before each file name in the Vim command line: + "vim +123 file1 +234 file2 +345 file3". ??? +- When entering text, keep other windows on same buffer updated (when a line + entered)? +- Check out how screen does output optimizing. Apparently this is possible + as an output filter. +- In dosub() regexec is called twice for the same line. Try to avoid this. +- Window updating from memline.c: insert/delete/replace line. +- Optimize ml_append() for speed, esp. for reading a file. +- V..c should keep indent when 'ai' is set, just like [count]cc. +- Updatescript() can be done faster with a string instead of a char. +- Screen updating is inefficient with CTRL-F and CTRL-B when there are long + lines. +- Uppercase characters in Ex commands can be made lowercase? +8 Add option to show characters in text not as "|A" but as decimal ("^129"), + hex ("\x81") or octal ("\201") or meta (M-x). Nvi has the 'octal' option + to switch from hex to octal. Vile can show unprintable characters in hex + or in octal. +7 Tighter integration with xxd to edit binary files. Make it more + easy/obvious to use. Command line argument? +- How does vi detect whether a filter has messed up the screen? Check source. + After ":w !command" a wait_return? +- Improve screen updating code for doput() (use s_ins()). +- With 'p' command on last line: scroll screen up (also for terminals without + insert line command). +- Use insert/delete char when terminal supports it. +- Optimize screen redraw for slow terminals. +- Optimize "dw" for long row of spaces (say, 30000). +- Add "-d null" for editing from a script file without displaying. +- In Insert mode: Remember the characters that were removed with backspace + and re-insert them one at a time with <key1>, all together with <key2>. +- Amiga: Add possibility to set a keymap. The code in amiga.c does not work + yet. +- Implement 'redraw' option. +- Add special code to 'sections' option to define something else but '{' or + '}' as the start of a section (e.g. one shiftwidth to the right). +7 Allow using Vim in a pipe: "ls | vim -u xxx.vim - | yyy". Only needs + implementing ":w" to stdout in the buffer that was read from stdin. + Perhaps writing to stdout will work, since stderr is used for the terminal + I/O. +8 Allow opening an unnamed buffer with ":e !cmd" and ":sp !cmd". Vile can + do it. +- Add commands like ]] and [[ that do not include the line jumped to. +- When :unab without matching "from" part and several matching "to" parts, + delete the entry that was used last, instead of the first in the list. +- Add text justification option. +- Set boolean options on/off with ":set paste=off", ":set paste=on". +- After "inv"ing an option show the value: ":set invpaste" gives "paste is + off". +- Check handling of CTRL-V and '\' for ":" commands that do not have TRLBAR. +- When a file cannot be opened but does exist, give error message. +- Amiga: When 'r' protection bit is not set, file can still be opened but + gives read errors. Check protection before opening. +- When writing check for file exists but no permission, "Permission denied". +- If file does not exist, check if directory exists. +- MSDOS: although t_cv and t_ci are not set, do invert char under cursor. +- Settings edit mode: make file with ":set opt=xx", edit it, parse it as ex + commands. +- ":set -w all": list one option per line. +- Amiga: test for 'w' flag when reading a file. +- :table command (Webb) +- Add new operator: clear, make area white (replace with spaces): "g ". +- Add command to ":read" a file at a certain column (blockwise read?). +- Add sort of replace mode where case is taken from the old text (Goldfarb). +- Allow multiple arguments for ":read", read all the files. +- Support for tabs in specific columns: ":set tabcol=8,20,34,56" (Demirel). +- Add 'searchdir' option: Directories to search for file name being edited + (Demirel). +- Modifier for the put command: Change to linewise, charwise, blockwise, etc. +- Add commands for saving and restoring options ":set save" "set restore", + for use in macro's and the like. +- Keep output from listings in a window, so you can have a look at it while + working in another window. Put cmdline in a separate window? +- Add possibility to put output of Ex commands in a buffer or file, e.g. for + ":set all". ":r :set all"? +- 'edit' option: When off changing the buffer is not possible (Really + read-only mode). +- When the 'equalalways' option is set, creating a new window should not + result in windows to become bigger. Deleting a window should not result in + a window to become smaller (Webb). +- When resizing the whole Vim window, the windows inside should be resized + proportionally (Webb). +- Include options directly in option table, no indirect pointers. Use + mkopttab to make option table? +- When doing ":w dir", where "dir" is a directory name, write the current + file into that directory, with the current file name (without the path)? +- Support for 'dictionary's that are sorted, makes access a lot faster + (Haritsis). +- Add "^Vrx" on the command line, replace with contents of register x. Used + instead of CTRL-R to make repeating possible. (Marinichev) +- Add "^Vb" on the command line, replace with word before or under the + cursor? +- Option to make a .swp file only when a change is made (Templeton). +- Support mapping for replace mode and "r" command (Vi doesn't do this)? +5 Add 'ignorefilecase' option: Ignore case when expanding file names. + ":e ma<Tab>" would also find "Makefile" on Unix. +8 Sorting of filenames for completion is wrong on systems that ignore + case of filenames. Add 'ignorefncase' option. When set, case in + filenames is ignored for sorting them. Patch by Mike Williams: + ~/vim/patches/ignorefncase. Also change what matches? Or use another + option name. +8 Should be able to compile Vim in another directory, with $(srcdir) set to + where the sources are. Add $(srcdir) in the Makefile in a lot of places. + (Netherton) +6 Make it configurable when "J" inserts a space or not. Should not add a + space after "(", for example. +5 When inserting spaces after the end-of-line for 'virtualedit', use tabs + when the user wants this (e.g., add a "tab" field to 'virtualedit'). + (Servatius Brandt) + + +From Elvis: +- Use "instman.sh" to install manpages? +- Add ":alias" command. +- Search patterns: + \@ match word under cursor. + but do: + \@w match the word under the cursor? + \@W match the WORD under the cursor? +8 ":window" command: + :win + next window (up) + :win ++ idem, wrapping + :win - previous window (down) + :win -- idem, wrapping + :win nr to window number "nr" + :win name to window editing buffer "name" +7 ":cc" compiles a single file (default: current one). 'ccprg' option is + program to use with ":cc". Use ":compile" instead of ":cc"? + + +From xvi: +- CTRL-_ : swap 8th bit of character. +- Add egrep-like regex type, like xvi (Ned Konz) or Perl (Emmanuel Mogenet) + + +From vile: +- When horizontal scrolling, use '>' for lines continuing right of a window. +- Support putting .swp files in /tmp: Command in rc.local to move .swp files + from /tmp to some directory before deleting files. + + +Far future and "big" extensions: +- Instead of using a Makefile and autoconf, use a simple shell script to + find the C compiler and do everything with C code. Translate something + like an Aap recipe and configure.in to C. Avoids depending on Python, + thus will work everywhere. With batch file to find the C compiler it + would also work on MS-Windows. +- Make it easy to setup Vim for groups of users: novice vi users, novice + Vim users, C programmers, xterm users, GUI users,... +- Change layout of blocks in swap file: Text at the start, with '\n' in + between lines (just load the file without changes, except for Mac). + Indexes for lines are from the end of the block backwards. It's the + current layout mirrored. +- Make it possible to edit a register, in a window, like a buffer. +- Add stuff to syntax highlighting to change the text (upper-case keywords, + set indent, define other highlighting, etc.). +- Mode to keep C-code formatted all the time (sort of on-line indent). +- Several top-level windows in one Vim session. Be able to use a different + font in each top-level window. +- Allow editing above start and below end of buffer (flag in 'virtualedit'). +- Smart cut/paste: recognize words and adjust spaces before/after them. +- Add open mode, use it when terminal has no cursor positioning. +- Special "drawing mode": a line is drawn where the cursor is moved to. + Backspace deletes along the line (from jvim). +- Implement ":Bset", set option in all buffers. Also ":Wset", set in all + windows, ":Aset, set in all arguments and ":Tset", set in all files + mentioned in the tags file. + Add buffer/arg range, like in ":2,5B%s/..." (do we really need this???) + Add search string: "B/*.c/%s/.."? Or ":F/*.c/%s/.."? +- Support for underlining (underscore-BS-char), bold (char-BS-char) and other + standout modes switched on/off with , 'overstrike' option (Reiter). +- Add vertical mode (Paul Jury, Demirel): "5vdw" deletes a word in five + lines, "3vitextESC" will insert "text" in three lines, etc.. +4 Recognize l, #, p as 'flags' to EX commands: + :g/RE/#l shall print lines with line numbers and in list format. + :g/RE/dp shall print lines that are deleted. + POSIX: Commands where flags shall apply to all lines written: list, + number, open, print, substitute, visual, &, z. For other commands, flags + shall apply to the current line after the command completes. Examples: + :7,10j #l Join the lines 7-10 and print the result in list +- Allow two or more users to edit the same file at the same time. Changes + are reflected in each Vim immediately. Could work with local files but + also over the internet. See http://www.codingmonkeys.de/subethaedit/. + +When using "do" or ":diffget" in a buffer with changes in every line an extra +empty line would appear. + +vim:tw=78:sw=4:sts=4:ts=8:ft=help:norl: +vim: set fo+=n : diff --git a/share/vim/vim73/doc/uganda.txt b/share/vim/vim73/doc/uganda.txt new file mode 100644 index 0000000000..3f23f1dc12 --- /dev/null +++ b/share/vim/vim73/doc/uganda.txt @@ -0,0 +1,288 @@ +*uganda.txt* For Vim version 7.3. Last change: 2010 Aug 07 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + + *uganda* *Uganda* *copying* *copyright* *license* +SUMMARY + *iccf* *ICCF* +Vim is Charityware. You can use and copy it as much as you like, but you are +encouraged to make a donation for needy children in Uganda. Please see |kcc| +below or visit the ICCF web site, available at these URLs: + + http://iccf-holland.org/ + http://www.vim.org/iccf/ + http://www.iccf.nl/ + +You can also sponsor the development of Vim. Vim sponsors can vote for +features. See |sponsor|. The money goes to Uganda anyway. + +The Open Publication License applies to the Vim documentation, see +|manual-copyright|. + +=== begin of license === + +VIM LICENSE + +I) There are no restrictions on distributing unmodified copies of Vim except + that they must include this license text. You can also distribute + unmodified parts of Vim, likewise unrestricted except that they must + include this license text. You are also allowed to include executables + that you made from the unmodified Vim sources, plus your own usage + examples and Vim scripts. + +II) It is allowed to distribute a modified (or extended) version of Vim, + including executables and/or source code, when the following four + conditions are met: + 1) This license text must be included unmodified. + 2) The modified Vim must be distributed in one of the following five ways: + a) If you make changes to Vim yourself, you must clearly describe in + the distribution how to contact you. When the maintainer asks you + (in any way) for a copy of the modified Vim you distributed, you + must make your changes, including source code, available to the + maintainer without fee. The maintainer reserves the right to + include your changes in the official version of Vim. What the + maintainer will do with your changes and under what license they + will be distributed is negotiable. If there has been no negotiation + then this license, or a later version, also applies to your changes. + The current maintainer is Bram Moolenaar <Bram@vim.org>. If this + changes it will be announced in appropriate places (most likely + vim.sf.net, www.vim.org and/or comp.editors). When it is completely + impossible to contact the maintainer, the obligation to send him + your changes ceases. Once the maintainer has confirmed that he has + received your changes they will not have to be sent again. + b) If you have received a modified Vim that was distributed as + mentioned under a) you are allowed to further distribute it + unmodified, as mentioned at I). If you make additional changes the + text under a) applies to those changes. + c) Provide all the changes, including source code, with every copy of + the modified Vim you distribute. This may be done in the form of a + context diff. You can choose what license to use for new code you + add. The changes and their license must not restrict others from + making their own changes to the official version of Vim. + d) When you have a modified Vim which includes changes as mentioned + under c), you can distribute it without the source code for the + changes if the following three conditions are met: + - The license that applies to the changes permits you to distribute + the changes to the Vim maintainer without fee or restriction, and + permits the Vim maintainer to include the changes in the official + version of Vim without fee or restriction. + - You keep the changes for at least three years after last + distributing the corresponding modified Vim. When the maintainer + or someone who you distributed the modified Vim to asks you (in + any way) for the changes within this period, you must make them + available to him. + - You clearly describe in the distribution how to contact you. This + contact information must remain valid for at least three years + after last distributing the corresponding modified Vim, or as long + as possible. + e) When the GNU General Public License (GPL) applies to the changes, + you can distribute the modified Vim under the GNU GPL version 2 or + any later version. + 3) A message must be added, at least in the output of the ":version" + command and in the intro screen, such that the user of the modified Vim + is able to see that it was modified. When distributing as mentioned + under 2)e) adding the message is only required for as far as this does + not conflict with the license used for the changes. + 4) The contact information as required under 2)a) and 2)d) must not be + removed or changed, except that the person himself can make + corrections. + +III) If you distribute a modified version of Vim, you are encouraged to use + the Vim license for your changes and make them available to the + maintainer, including the source code. The preferred way to do this is + by e-mail or by uploading the files to a server and e-mailing the URL. + If the number of changes is small (e.g., a modified Makefile) e-mailing a + context diff will do. The e-mail address to be used is + <maintainer@vim.org> + +IV) It is not allowed to remove this license from the distribution of the Vim + sources, parts of it or from a modified version. You may use this + license for previous Vim releases instead of the license that they came + with, at your option. + +=== end of license === + +Note: + +- If you are happy with Vim, please express that by reading the rest of this + file and consider helping needy children in Uganda. + +- If you want to support further Vim development consider becoming a + |sponsor|. The money goes to Uganda anyway. + +- According to Richard Stallman the Vim license is GNU GPL compatible. + A few minor changes have been made since he checked it, but that should not + make a difference. + +- If you link Vim with a library that goes under the GNU GPL, this limits + further distribution to the GNU GPL. Also when you didn't actually change + anything in Vim. + +- Once a change is included that goes under the GNU GPL, this forces all + further changes to also be made under the GNU GPL or a compatible license. + +- If you distribute a modified version of Vim, you can include your name and + contact information with the "--with-modified-by" configure argument or the + MODIFIED_BY define. + +============================================================================== +Kibaale Children's Centre *kcc* *Kibaale* *charity* + +Kibaale Children's Centre (KCC) is located in Kibaale, a small town in the +south of Uganda, near Tanzania, in East Africa. The area is known as Rakai +District. The population is mostly farmers. Although people are poor, there +is enough food. But this district is suffering from AIDS more than any other +part of the world. Some say that it started there. Estimations are that 10 +to 30% of the Ugandans are infected with HIV. Because parents die, there are +many orphans. In this district about 60,000 children have lost one or both +parents, out of a population of 350,000. And this is still continuing. + +The children need a lot of help. The KCC is working hard to provide the needy +with food, medical care and education. Food and medical care to keep them +healthy now, and education so that they can take care of themselves in the +future. KCC works on a Christian base, but help is given to children of any +religion. + +The key to solving the problems in this area is education. This has been +neglected in the past years with president Idi Amin and the following civil +wars. Now that the government is stable again, the children and parents have +to learn how to take care of themselves and how to avoid infections. There is +also help for people who are ill and hungry, but the primary goal is to +prevent people from getting ill and to teach them how to grow healthy food. + +Most of the orphans are living in an extended family. An uncle or older +sister is taking care of them. Because these families are big and the income +(if any) is low, a child is lucky if it gets healthy food. Clothes, medical +care and schooling is beyond its reach. To help these needy children, a +sponsorship program was put into place. A child can be financially adopted. +For a few dollars a month KCC sees to it that the child gets indispensable +items, is healthy, goes to school and KCC takes care of anything else that +needs to be done for the child and the family that supports it. + +Besides helping the child directly, the environment where the child grows up +needs to be improved. KCC helps schools to improve their teaching methods. +There is a demonstration school at the centre and teacher trainings are given. +Health workers are being trained, hygiene education is carried out and +households are stimulated to build a proper latrine. I helped setting up a +production site for cement slabs. These are used to build a good latrine. +They are sold below cost price. + +There is a small clinic at the project, which provides children and their +family with medical help. When needed, transport to a hospital is offered. +Immunization programs are carried out and help is provided when an epidemic is +breaking out (measles and cholera have been a problem). + *donate* +Summer 1994 to summer 1995 I spent a whole year at the centre, working as a +volunteer. I have helped to expand the centre and worked in the area of water +and sanitation. I learned that the help that the KCC provides really helps. +When I came back to Holland, I wanted to continue supporting KCC. To do this +I'm raising funds and organizing the sponsorship program. Please consider one +of these possibilities: + +1. Sponsor a child in primary school: 17 euro a month (or more). +2. Sponsor a child in secondary school: 25 euro a month (or more). +3. Sponsor the clinic: Any amount a month or quarter +4. A one-time donation + +Compared with other organizations that do child sponsorship the amounts are +very low. This is because the money goes directly to the centre. Less than +5% is used for administration. This is possible because this is a small +organization that works with volunteers. If you would like to sponsor a +child, you should have the intention to do this for at least one year. + +How do you know that the money will be spent right? First of all you have my +personal guarantee as the author of Vim. I trust the people that are working +at the centre, I know them personally. Further more, the centre has been +co-sponsored and inspected by World Vision, Save the Children Fund and is now +under the supervision of Pacific Academy Outreach Society. The centre is +visited about once a year to check the progress (at our own cost). I have +visited the centre myself many times, starting in 1993. The visit reports are +on the ICCF web site. + +If you have any further questions, send me e-mail: <Bram@vim.org>. + +The address of the centre is: + Kibaale Children's Centre + p.o. box 1658 + Masaka, Uganda, East Africa + +Sending money: *iccf-donations* + +Check the ICCF web site for the latest information! See |iccf| for the URL. + + +USA: The methods mentioned below can be used. + Sending a check to the Nehemiah Group Outreach Society (NGOS) + is no longer possible, unfortunately. We are looking for + another way to get you an IRS tax receipt. + For sponsoring a child contact KCF in Canada (see below). US + checks can be sent to them to lower banking costs. + +Canada: Contact Kibaale Children's Fund (KCF) in Surrey, Canada. They + take care of the Canadian sponsors for the children in + Kibaale. KCF forwards 100% of the money to the project in + Uganda. You can send them a one time donation directly. + Please send me a note so that I know what has been donated + because of Vim. Ask KCF for information about sponsorship. + Kibaale Children's Fund c/o Pacific Academy + 10238-168 Street + Surrey, B.C. V4N 1Z4 + Canada + Phone: 604-581-5353 + If you make a donation to Kibaale Children's Fund (KCF) you + will receive a tax receipt which can be submitted with your + tax return. + +Holland: Transfer to the account of "Stichting ICCF Holland" in Lisse. + This will allow for tax deduction if you live in Holland. + Postbank, nr. 4548774 + +Germany: It is possible to make donations that allow for a tax return. + Check the ICCF web site for the latest information: + http://iccf-holland.org/germany.html + +World: Use a postal money order. That should be possible from any + country, mostly from the post office. Use this name (which is + in my passport): "Abraham Moolenaar". Use Euro for the + currency if possible. + +Europe: Use a bank transfer if possible. Your bank should have a form + that you can use for this. See "Others" below for the swift + code and IBAN number. + Any other method should work. Ask for information about + sponsorship. + +Credit Card: You can use PayPal to send money with a Credit card. This is + the most widely used Internet based payment system. It's + really simple to use. Use this link to find more info: + https://www.paypal.com/en_US/mrb/pal=XAC62PML3GF8Q + The e-mail address for sending the money to is: + Bram@iccf-holland.org + For amounts above 400 Euro ($500) sending a check is + preferred. + +Others: Transfer to one of these accounts if possible: + Postbank, account 4548774 + Swift code: INGB NL 2A + IBAN: NL47 PSTB 0004 5487 74 + under the name "stichting ICCF Holland", Lisse + If that doesn't work: + Rabobank Lisse, account 3765.05.117 + Swift code: RABO NL 2U + under the name "Bram Moolenaar", Lisse + Otherwise, send a check in euro or US dollars to the address + below. Minimal amount: $70 (my bank does not accept smaller + amounts for foreign check, sorry) + +Address to send checks to: + stichting ICCF Holland + Bram Moolenaar + Finsterruetihof 1 + 8134 Adliswil + Switzerland + +This address is expected to be valid for a long time. + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/undo.txt b/share/vim/vim73/doc/undo.txt new file mode 100644 index 0000000000..3c47db7f36 --- /dev/null +++ b/share/vim/vim73/doc/undo.txt @@ -0,0 +1,386 @@ +*undo.txt* For Vim version 7.3. Last change: 2010 Jul 20 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + +Undo and redo *undo-redo* + +The basics are explained in section |02.5| of the user manual. + +1. Undo and redo commands |undo-commands| +2. Two ways of undo |undo-two-ways| +3. Undo blocks |undo-blocks| +4. Undo branches |undo-branches| +5. Undo persistence |undo-persistence| +6. Remarks about undo |undo-remarks| + +============================================================================== +1. Undo and redo commands *undo-commands* + +<Undo> or *undo* *<Undo>* *u* +u Undo [count] changes. {Vi: only one level} + + *:u* *:un* *:undo* +:u[ndo] Undo one change. {Vi: only one level} + *E830* +:u[ndo] {N} Jump to after change number {N}. See |undo-branches| + for the meaning of {N}. {not in Vi} + + *CTRL-R* +CTRL-R Redo [count] changes which were undone. {Vi: redraw + screen} + + *:red* *:redo* *redo* +:red[o] Redo one change which was undone. {Vi: no redo} + + *U* +U Undo all latest changes on one line. {Vi: while not + moved off of it} + +The last changes are remembered. You can use the undo and redo commands above +to revert the text to how it was before each change. You can also apply the +changes again, getting back the text before the undo. + +The "U" command is treated by undo/redo just like any other command. Thus a +"u" command undoes a "U" command and a 'CTRL-R' command redoes it again. When +mixing "U", "u" and 'CTRL-R' you will notice that the "U" command will +restore the situation of a line to before the previous "U" command. This may +be confusing. Try it out to get used to it. +The "U" command will always mark the buffer as changed. When "U" changes the +buffer back to how it was without changes, it is still considered changed. +Use "u" to undo changes until the buffer becomes unchanged. + +============================================================================== +2. Two ways of undo *undo-two-ways* + +How undo and redo commands work depends on the 'u' flag in 'cpoptions'. +There is the Vim way ('u' excluded) and the vi-compatible way ('u' included). +In the Vim way, "uu" undoes two changes. In the Vi-compatible way, "uu" does +nothing (undoes an undo). + +'u' excluded, the Vim way: +You can go back in time with the undo command. You can then go forward again +with the redo command. If you make a new change after the undo command, +the redo will not be possible anymore. + +'u' included, the Vi-compatible way: +The undo command undoes the previous change, and also the previous undo command. +The redo command repeats the previous undo command. It does NOT repeat a +change command, use "." for that. + +Examples Vim way Vi-compatible way ~ +"uu" two times undo no-op +"u CTRL-R" no-op two times undo + +Rationale: Nvi uses the "." command instead of CTRL-R. Unfortunately, this + is not Vi compatible. For example "dwdwu." in Vi deletes two + words, in Nvi it does nothing. + +============================================================================== +3. Undo blocks *undo-blocks* + +One undo command normally undoes a typed command, no matter how many changes +that command makes. This sequence of undo-able changes forms an undo block. +Thus if the typed key(s) call a function, all the commands in the function are +undone together. + +If you want to write a function or script that doesn't create a new undoable +change but joins in with the previous change use this command: + + *:undoj* *:undojoin* *E790* +:undoj[oin] Join further changes with the previous undo block. + Warning: Use with care, it may prevent the user from + properly undoing changes. Don't use this after undo + or redo. + {not in Vi} + +This is most useful when you need to prompt the user halfway a change. For +example in a function that calls |getchar()|. Do make sure that there was a +related change before this that you must join with. + +This doesn't work by itself, because the next key press will start a new +change again. But you can do something like this: > + + :undojoin | delete + +After this an "u" command will undo the delete command and the previous +change. + +To do the opposite, break a change into two undo blocks, in Insert mode use +CTRL-G u. This is useful if you want an insert command to be undoable in +parts. E.g., for each sentence. |i_CTRL-G_u| +Setting the value of 'undolevels' also breaks undo. Even when the new value +is equal to the old value. + +============================================================================== +4. Undo branches *undo-branches* *undo-tree* + +Above we only discussed one line of undo/redo. But it is also possible to +branch off. This happens when you undo a few changes and then make a new +change. The undone changes become a branch. You can go to that branch with +the following commands. + +This is explained in the user manual: |usr_32.txt|. + + *:undol* *:undolist* +:undol[ist] List the leafs in the tree of changes. Example: + number changes time ~ + 4 10 10:34:11 + 18 4 11:01:46 + + The "number" column is the change number. This number + continuously increases and can be used to identify a + specific undo-able change, see |:undo|. + The "changes" column is the number of changes to this + leaf from the root of the tree. + The "time" column is the time this change was made. + For more details use the |undotree()| function. + + *g-* +g- Go to older text state. With a count repeat that many + times. {not in Vi} + *:ea* *:earlier* +:earlier {count} Go to older text state {count} times. +:earlier {N}s Go to older text state about {N} seconds before. +:earlier {N}m Go to older text state about {N} minutes before. +:earlier {N}h Go to older text state about {N} hours before. +:earlier {N}d Go to older text state about {N} days before. + +:earlier {N}f Go to older text state {N} file writes before. + When changes were made since the laste write + ":earlier 1f" will revert the text to the state when + it was written. Otherwise it will go to the write + before that. + When at the state of the first file write, or when + the file was not written, ":earlier 1f" will go to + before the first change. + + *g+* +g+ Go to newer text state. With a count repeat that many + times. {not in Vi} + *:lat* *:later* +:later {count} Go to newer text state {count} times. +:later {N}s Go to newer text state about {N} seconds later. +:later {N}m Go to newer text state about {N} minutes later. +:later {N}h Go to newer text state about {N} hours later. +:later {N}d Go to newer text state about {N} days later. + +:later {N}f Go to newer text state {N} file writes later. + When at the state of the last file write, ":later 1f" + will go to the newest text state. + + +Note that text states will become unreachable when undo information is cleared +for 'undolevels'. + +Don't be surprised when moving through time shows multiple changes to take +place at a time. This happens when moving through the undo tree and then +making a new change. + +EXAMPLE + +Start with this text: + one two three ~ + +Delete the first word by pressing "x" three times: + ne two three ~ + e two three ~ + two three ~ + +Now undo that by pressing "u" three times: + e two three ~ + ne two three ~ + one two three ~ + +Delete the second word by pressing "x" three times: + one wo three ~ + one o three ~ + one three ~ + +Now undo that by using "g-" three times: + one o three ~ + one wo three ~ + two three ~ + +You are now back in the first undo branch, after deleting "one". Repeating +"g-" will now bring you back to the original text: + e two three ~ + ne two three ~ + one two three ~ + +Jump to the last change with ":later 1h": + one three ~ + +And back to the start again with ":earlier 1h": + one two three ~ + + +Note that using "u" and CTRL-R will not get you to all possible text states +while repeating "g-" and "g+" does. + +============================================================================== +5. Undo persistence *undo-persistence* *persistent-undo* + +When unloading a buffer Vim normally destroys the tree of undos created for +that buffer. By setting the 'undofile' option, Vim will automatically save +your undo history when you write a file and restore undo history when you edit +the file again. + +The 'undofile' option is checked after writing a file, before the BufWritePost +autocommands. If you want to control what files to write undo information +for, you can use a BufWritePre autocommand: > + au BufWritePre /tmp/* setlocal noundofile + +Vim saves undo trees in a separate undo file, one for each edited file, using +a simple scheme that maps filesystem paths directly to undo files. Vim will +detect if an undo file is no longer synchronized with the file it was written +for (with a hash of the file contents) and ignore it when the file was changed +after the undo file was written, to prevent corruption. + +Undo files are normally saved in the same directory as the file. This can be +changed with the 'undodir' option. + +When the file is encrypted, the text in the undo file is also crypted. The +same key and method is used. |encryption| + +You can also save and restore undo histories by using ":wundo" and ":rundo" +respectively: + *:wundo* *:rundo* +:wundo[!] {file} + Write undo history to {file}. + When {file} exists and it does not look like an undo file + (the magic number at the start of the file is wrong), then + this fails, unless the ! was added. + If it exists and does look like an undo file it is + overwritten. + {not in Vi} + +:rundo {file} Read undo history from {file}. + {not in Vi} + +You can use these in autocommands to explicitly specify the name of the +history file. E.g.: > + + au BufReadPost * call ReadUndo() + au BufWritePost * call WriteUndo() + func ReadUndo() + if filereadable(expand('%:h'). '/UNDO/' . expand('%:t')) + rundo %:h/UNDO/%:t + endif + endfunc + func WriteUndo() + let dirname = expand('%:h') . '/UNDO' + if !isdirectory(dirname) + call mkdir(dirname) + endif + wundo %:h/UNDO/%:t + endfunc + +You should keep 'undofile' off, otherwise you end up with two undo files for +every write. + +You can use the |undofile()| function to find out the file name that Vim would +use. + +Note that while reading/writing files and 'undofile' is set most errors will +be silent, unless 'verbose' is set. With :wundo and :rundo you will get more +error messages, e.g., when the file cannot be read or written. + +NOTE: undo files are never deleted by Vim. You need to delete them yourself. + +Reading an existing undo file may fail for several reasons: +*E822* It cannot be opened, because the file permissions don't allow it. +*E823* The magic number at the start of the file doesn't match. This usually + means it is not an undo file. +*E824* The version number of the undo file indicates that it's written by a + newer version of Vim. You need that newer version to open it. Don't + write the buffer if you want to keep the undo info in the file. +"File contents changed, cannot use undo info" + The file text differs from when the undo file was written. This means + the undo file cannot be used, it would corrupt the text. This also + happens when 'encoding' differs from when the undo file was written. +*E825* The undo file does not contain valid contents and cannot be used. +*E826* The undo file is encrypted but decryption failed. +*E827* The undo file is encrypted but this version of Vim does not support + encryption. Open the file with another Vim. +*E832* The undo file is encrypted but 'key' is not set, the text file is not + encrypted. This would happen if the text file was written by Vim + encrypted at first, and later overwritten by not encrypted text. + You probably want to delete this undo file. +"Not reading undo file, owner differs" + The undo file is owned by someone else than the owner of the text + file. For safety the undo file is not used. + +Writing an undo file may fail for these reasons: +*E828* The file to be written cannot be created. Perhaps you do not have + write permissions in the directory. +"Cannot write undo file in any directory in 'undodir'" + None of the directories in 'undodir' can be used. +"Will not overwrite with undo file, cannot read" + A file exists with the name of the undo file to be written, but it + cannot be read. You may want to delete this file or rename it. +"Will not overwrite, this is not an undo file" + A file exists with the name of the undo file to be written, but it + does not start with the right magic number. You may want to delete + this file or rename it. +"Skipping undo file write, noting to undo" + There is no undo information not be written, nothing has been changed + or 'undolevels' is negative. +*E829* An error occurred while writing the undo file. You may want to try + again. + +============================================================================== +6. Remarks about undo *undo-remarks* + +The number of changes that are remembered is set with the 'undolevels' option. +If it is zero, the Vi-compatible way is always used. If it is negative no +undo is possible. Use this if you are running out of memory. + + *clear-undo* +When you set 'undolevels' to -1 the undo information is not immediately +cleared, this happens at the next change. To force clearing the undo +information you can use these commands: > + :let old_undolevels = &undolevels + :set undolevels=-1 + :exe "normal a \<BS>\<Esc>" + :let &undolevels = old_undolevels + :unlet old_undolevels + +Marks for the buffer ('a to 'z) are also saved and restored, together with the +text. {Vi does this a little bit different} + +When all changes have been undone, the buffer is not considered to be changed. +It is then possible to exit Vim with ":q" instead of ":q!" {not in Vi}. Note +that this is relative to the last write of the file. Typing "u" after ":w" +actually changes the buffer, compared to what was written, so the buffer is +considered changed then. + +When manual |folding| is being used, the folds are not saved and restored. +Only changes completely within a fold will keep the fold as it was, because +the first and last line of the fold don't change. + +The numbered registers can also be used for undoing deletes. Each time you +delete text, it is put into register "1. The contents of register "1 are +shifted to "2, etc. The contents of register "9 are lost. You can now get +back the most recent deleted text with the put command: '"1P'. (also, if the +deleted text was the result of the last delete or copy operation, 'P' or 'p' +also works as this puts the contents of the unnamed register). You can get +back the text of three deletes ago with '"3P'. + + *redo-register* +If you want to get back more than one part of deleted text, you can use a +special feature of the repeat command ".". It will increase the number of the +register used. So if you first do ""1P", the following "." will result in a +'"2P'. Repeating this will result in all numbered registers being inserted. + +Example: If you deleted text with 'dd....' it can be restored with + '"1P....'. + +If you don't know in which register the deleted text is, you can use the +:display command. An alternative is to try the first register with '"1P', and +if it is not what you want do 'u.'. This will remove the contents of the +first put, and repeat the put command for the second register. Repeat the +'u.' until you got what you want. + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_01.txt b/share/vim/vim73/doc/usr_01.txt new file mode 100644 index 0000000000..da9772339b --- /dev/null +++ b/share/vim/vim73/doc/usr_01.txt @@ -0,0 +1,185 @@ +*usr_01.txt* For Vim version 7.3. Last change: 2008 May 07 + + VIM USER MANUAL - by Bram Moolenaar + + About the manuals + + +This chapter introduces the manuals available with Vim. Read this to know the +conditions under which the commands are explained. + +|01.1| Two manuals +|01.2| Vim installed +|01.3| Using the Vim tutor +|01.4| Copyright + + Next chapter: |usr_02.txt| The first steps in Vim +Table of contents: |usr_toc.txt| + +============================================================================== +*01.1* Two manuals + +The Vim documentation consists of two parts: + +1. The User manual + Task oriented explanations, from simple to complex. Reads from start to + end like a book. + +2. The Reference manual + Precise description of how everything in Vim works. + +The notation used in these manuals is explained here: |notation| + + +JUMPING AROUND + +The text contains hyperlinks between the two parts, allowing you to quickly +jump between the description of an editing task and a precise explanation of +the commands and options used for it. Use these two commands: + + Press CTRL-] to jump to a subject under the cursor. + Press CTRL-O to jump back (repeat to go further back). + +Many links are in vertical bars, like this: |bars|. An option name, like +'number', a command in double quotes like ":write" and any other word can also +be used as a link. Try it out: Move the cursor to CTRL-] and press CTRL-] +on it. + +Other subjects can be found with the ":help" command, see |help.txt|. + +============================================================================== +*01.2* Vim installed + +Most of the manuals assume that Vim has been properly installed. If you +didn't do that yet, or if Vim doesn't run properly (e.g., files can't be found +or in the GUI the menus do not show up) first read the chapter on +installation: |usr_90.txt|. + *not-compatible* +The manuals often assume you are using Vim with Vi-compatibility switched +off. For most commands this doesn't matter, but sometimes it is important, +e.g., for multi-level undo. An easy way to make sure you are using a nice +setup is to copy the example vimrc file. By doing this inside Vim you don't +have to check out where it is located. How to do this depends on the system +you are using: + +Unix: > + :!cp -i $VIMRUNTIME/vimrc_example.vim ~/.vimrc +MS-DOS, MS-Windows, OS/2: > + :!copy $VIMRUNTIME/vimrc_example.vim $VIM/_vimrc +Amiga: > + :!copy $VIMRUNTIME/vimrc_example.vim $VIM/.vimrc + +If the file already exists you probably want to keep it. + +If you start Vim now, the 'compatible' option should be off. You can check it +with this command: > + + :set compatible? + +If it responds with "nocompatible" you are doing well. If the response is +"compatible" you are in trouble. You will have to find out why the option is +still set. Perhaps the file you wrote above is not found. Use this command +to find out: > + + :scriptnames + +If your file is not in the list, check its location and name. If it is in the +list, there must be some other place where the 'compatible' option is switched +back on. + +For more info see |vimrc| and |compatible-default|. + + Note: + This manual is about using Vim in the normal way. There is an + alternative called "evim" (easy Vim). This is still Vim, but used in + a way that resembles a click-and-type editor like Notepad. It always + stays in Insert mode, thus it feels very different. It is not + explained in the user manual, since it should be mostly self + explanatory. See |evim-keys| for details. + +============================================================================== +*01.3* Using the Vim tutor *tutor* *vimtutor* + +Instead of reading the text (boring!) you can use the vimtutor to learn your +first Vim commands. This is a 30 minute tutorial that teaches the most basic +Vim functionality hands-on. + +On Unix, if Vim has been properly installed, you can start it from the shell: +> + vimtutor + +On MS-Windows you can find it in the Program/Vim menu. Or execute +vimtutor.bat in the $VIMRUNTIME directory. + +This will make a copy of the tutor file, so that you can edit it without +the risk of damaging the original. + There are a few translated versions of the tutor. To find out if yours is +available, use the two-letter language code. For French: > + + vimtutor fr + +On Unix, if you prefer using the GUI version of Vim, use "gvimtutor" or +"vimtutor -g" instead of "vimtutor". + +For OpenVMS, if Vim has been properly installed, you can start vimtutor from a +VMS prompt with: > + + @VIM:vimtutor + +Optionally add the two-letter language code as above. + + +On other systems, you have to do a little work: + +1. Copy the tutor file. You can do this with Vim (it knows where to find it): +> + vim -u NONE -c 'e $VIMRUNTIME/tutor/tutor' -c 'w! TUTORCOPY' -c 'q' +< + This will write the file "TUTORCOPY" in the current directory. To use a +translated version of the tutor, append the two-letter language code to the +filename. For French: +> + vim -u NONE -c 'e $VIMRUNTIME/tutor/tutor.fr' -c 'w! TUTORCOPY' -c 'q' +< +2. Edit the copied file with Vim: +> + vim -u NONE -c "set nocp" TUTORCOPY +< + The extra arguments make sure Vim is started in a good mood. + +3. Delete the copied file when you are finished with it: +> + del TUTORCOPY +< +============================================================================== +*01.4* Copyright *manual-copyright* + +The Vim user manual and reference manual are Copyright (c) 1988-2003 by Bram +Moolenaar. This material may be distributed only subject to the terms and +conditions set forth in the Open Publication License, v1.0 or later. The +latest version is presently available at: + http://www.opencontent.org/openpub/ + +People who contribute to the manuals must agree with the above copyright +notice. + *frombook* +Parts of the user manual come from the book "Vi IMproved - Vim" by Steve +Oualline (published by New Riders Publishing, ISBN: 0735710015). The Open +Publication License applies to this book. Only selected parts are included +and these have been modified (e.g., by removing the pictures, updating the +text for Vim 6.0 and later, fixing mistakes). The omission of the |frombook| +tag does not mean that the text does not come from the book. + +Many thanks to Steve Oualline and New Riders for creating this book and +publishing it under the OPL! It has been a great help while writing the user +manual. Not only by providing literal text, but also by setting the tone and +style. + +If you make money through selling the manuals, you are strongly encouraged to +donate part of the profit to help AIDS victims in Uganda. See |iccf|. + +============================================================================== + +Next chapter: |usr_02.txt| The first steps in Vim + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_02.txt b/share/vim/vim73/doc/usr_02.txt new file mode 100644 index 0000000000..6b9f9ae6d6 --- /dev/null +++ b/share/vim/vim73/doc/usr_02.txt @@ -0,0 +1,564 @@ +*usr_02.txt* For Vim version 7.3. Last change: 2010 Jul 20 + + VIM USER MANUAL - by Bram Moolenaar + + The first steps in Vim + + +This chapter provides just enough information to edit a file with Vim. Not +well or fast, but you can edit. Take some time to practice with these +commands, they form the base for what follows. + +|02.1| Running Vim for the First Time +|02.2| Inserting text +|02.3| Moving around +|02.4| Deleting characters +|02.5| Undo and Redo +|02.6| Other editing commands +|02.7| Getting out +|02.8| Finding help + + Next chapter: |usr_03.txt| Moving around + Previous chapter: |usr_01.txt| About the manuals +Table of contents: |usr_toc.txt| + +============================================================================== +*02.1* Running Vim for the First Time + +To start Vim, enter this command: > + + gvim file.txt + +In UNIX you can type this at any command prompt. If you are running Microsoft +Windows, open an MS-DOS prompt window and enter the command. + In either case, Vim starts editing a file called file.txt. Because this +is a new file, you get a blank window. This is what your screen will look +like: + + +---------------------------------------+ + |# | + |~ | + |~ | + |~ | + |~ | + |"file.txt" [New file] | + +---------------------------------------+ + ('#" is the cursor position.) + +The tilde (~) lines indicate lines not in the file. In other words, when Vim +runs out of file to display, it displays tilde lines. At the bottom of the +screen, a message line indicates the file is named file.txt and shows that you +are creating a new file. The message information is temporary and other +information overwrites it. + + +THE VIM COMMAND + +The gvim command causes the editor to create a new window for editing. If you +use this command: > + + vim file.txt + +the editing occurs inside your command window. In other words, if you are +running inside an xterm, the editor uses your xterm window. If you are using +an MS-DOS command prompt window under Microsoft Windows, the editing occurs +inside this window. The text in the window will look the same for both +versions, but with gvim you have extra features, like a menu bar. More about +that later. + +============================================================================== +*02.2* Inserting text + +The Vim editor is a modal editor. That means that the editor behaves +differently, depending on which mode you are in. The two basic modes are +called Normal mode and Insert mode. In Normal mode the characters you type +are commands. In Insert mode the characters are inserted as text. + Since you have just started Vim it will be in Normal mode. To start Insert +mode you type the "i" command (i for Insert). Then you can enter +the text. It will be inserted into the file. Do not worry if you make +mistakes; you can correct them later. To enter the following programmer's +limerick, this is what you type: > + + iA very intelligent turtle + Found programming UNIX a hurdle + +After typing "turtle" you press the <Enter> key to start a new line. Finally +you press the <Esc> key to stop Insert mode and go back to Normal mode. You +now have two lines of text in your Vim window: + + +---------------------------------------+ + |A very intelligent turtle | + |Found programming UNIX a hurdle | + |~ | + |~ | + | | + +---------------------------------------+ + + +WHAT IS THE MODE? + +To be able to see what mode you are in, type this command: > + + :set showmode + +You will notice that when typing the colon Vim moves the cursor to the last +line of the window. That's where you type colon commands (commands that start +with a colon). Finish this command by pressing the <Enter> key (all commands +that start with a colon are finished this way). + Now, if you type the "i" command Vim will display --INSERT-- at the bottom +of the window. This indicates you are in Insert mode. + + +---------------------------------------+ + |A very intelligent turtle | + |Found programming UNIX a hurdle | + |~ | + |~ | + |-- INSERT -- | + +---------------------------------------+ + +If you press <Esc> to go back to Normal mode the last line will be made blank. + + +GETTING OUT OF TROUBLE + +One of the problems for Vim novices is mode confusion, which is caused by +forgetting which mode you are in or by accidentally typing a command that +switches modes. To get back to Normal mode, no matter what mode you are in, +press the <Esc> key. Sometimes you have to press it twice. If Vim beeps back +at you, you already are in Normal mode. + +============================================================================== +*02.3* Moving around + +After you return to Normal mode, you can move around by using these keys: + + h left *hjkl* + j down + k up + l right + +At first, it may appear that these commands were chosen at random. After all, +who ever heard of using l for right? But actually, there is a very good +reason for these choices: Moving the cursor is the most common thing you do in +an editor, and these keys are on the home row of your right hand. In other +words, these commands are placed where you can type them the fastest +(especially when you type with ten fingers). + + Note: + You can also move the cursor by using the arrow keys. If you do, + however, you greatly slow down your editing because to press the arrow + keys, you must move your hand from the text keys to the arrow keys. + Considering that you might be doing it hundreds of times an hour, this + can take a significant amount of time. + Also, there are keyboards which do not have arrow keys, or which + locate them in unusual places; therefore, knowing the use of the hjkl + keys helps in those situations. + +One way to remember these commands is that h is on the left, l is on the +right and j points down. In a picture: > + + k + h l + j + +The best way to learn these commands is by using them. Use the "i" command to +insert some more lines of text. Then use the hjkl keys to move around and +insert a word somewhere. Don't forget to press <Esc> to go back to Normal +mode. The |vimtutor| is also a nice way to learn by doing. + +For Japanese users, Hiroshi Iwatani suggested using this: + + Komsomolsk + ^ + | + Huan Ho <--- ---> Los Angeles + (Yellow river) | + v + Java (the island, not the programming language) + +============================================================================== +*02.4* Deleting characters + +To delete a character, move the cursor over it and type "x". (This is a +throwback to the old days of the typewriter, when you deleted things by typing +xxxx over them.) Move the cursor to the beginning of the first line, for +example, and type xxxxxxx (seven x's) to delete "A very ". The result should +look like this: + + +---------------------------------------+ + |intelligent turtle | + |Found programming UNIX a hurdle | + |~ | + |~ | + | | + +---------------------------------------+ + +Now you can insert new text, for example by typing: > + + iA young <Esc> + +This begins an insert (the i), inserts the words "A young", and then exits +insert mode (the final <Esc>). The result: + + +---------------------------------------+ + |A young intelligent turtle | + |Found programming UNIX a hurdle | + |~ | + |~ | + | | + +---------------------------------------+ + + +DELETING A LINE + +To delete a whole line use the "dd" command. The following line will +then move up to fill the gap: + + +---------------------------------------+ + |Found programming UNIX a hurdle | + |~ | + |~ | + |~ | + | | + +---------------------------------------+ + + +DELETING A LINE BREAK + +In Vim you can join two lines together, which means that the line break +between them is deleted. The "J" command does this. + Take these two lines: + + A young intelligent ~ + turtle ~ + +Move the cursor to the first line and press "J": + + A young intelligent turtle ~ + +============================================================================== +*02.5* Undo and Redo + +Suppose you delete too much. Well, you can type it in again, but an easier +way exists. The "u" command undoes the last edit. Take a look at this in +action: After using "dd" to delete the first line, "u" brings it back. + Another one: Move the cursor to the A in the first line: + + A young intelligent turtle ~ + +Now type xxxxxxx to delete "A young". The result is as follows: + + intelligent turtle ~ + +Type "u" to undo the last delete. That delete removed the g, so the undo +restores the character. + + g intelligent turtle ~ + +The next u command restores the next-to-last character deleted: + + ng intelligent turtle ~ + +The next u command gives you the u, and so on: + + ung intelligent turtle ~ + oung intelligent turtle ~ + young intelligent turtle ~ + young intelligent turtle ~ + A young intelligent turtle ~ + + Note: + If you type "u" twice, and the result is that you get the same text + back, you have Vim configured to work Vi compatible. Look here to fix + this: |not-compatible|. + This text assumes you work "The Vim Way". You might prefer to use + the good old Vi way, but you will have to watch out for small + differences in the text then. + + +REDO + +If you undo too many times, you can press CTRL-R (redo) to reverse the +preceding command. In other words, it undoes the undo. To see this in +action, press CTRL-R twice. The character A and the space after it disappear: + + young intelligent turtle ~ + +There's a special version of the undo command, the "U" (undo line) command. +The undo line command undoes all the changes made on the last line that was +edited. Typing this command twice cancels the preceding "U". + + A very intelligent turtle ~ + xxxx Delete very + + A intelligent turtle ~ + xxxxxx Delete turtle + + A intelligent ~ + Restore line with "U" + A very intelligent turtle ~ + Undo "U" with "u" + A intelligent ~ + +The "U" command is a change by itself, which the "u" command undoes and CTRL-R +redoes. This might be a bit confusing. Don't worry, with "u" and CTRL-R you +can go to any of the situations you had. More about that in section |32.2|. + +============================================================================== +*02.6* Other editing commands + +Vim has a large number of commands to change the text. See |Q_in| and below. +Here are a few often used ones. + + +APPENDING + +The "i" command inserts a character before the character under the cursor. +That works fine; but what happens if you want to add stuff to the end of the +line? For that you need to insert text after the cursor. This is done with +the "a" (append) command. + For example, to change the line + + and that's not saying much for the turtle. ~ +to + and that's not saying much for the turtle!!! ~ + +move the cursor over to the dot at the end of the line. Then type "x" to +delete the period. The cursor is now positioned at the end of the line on the +e in turtle. Now type > + + a!!!<Esc> + +to append three exclamation points after the e in turtle: + + and that's not saying much for the turtle!!! ~ + + +OPENING UP A NEW LINE + +The "o" command creates a new, empty line below the cursor and puts Vim in +Insert mode. Then you can type the text for the new line. + Suppose the cursor is somewhere in the first of these two lines: + + A very intelligent turtle ~ + Found programming UNIX a hurdle ~ + +If you now use the "o" command and type new text: > + + oThat liked using Vim<Esc> + +The result is: + + A very intelligent turtle ~ + That liked using Vim ~ + Found programming UNIX a hurdle ~ + +The "O" command (uppercase) opens a line above the cursor. + + +USING A COUNT + +Suppose you want to move up nine lines. You can type "kkkkkkkkk" or you can +enter the command "9k". In fact, you can precede many commands with a number. +Earlier in this chapter, for instance, you added three exclamation points to +the end of a line by typing "a!!!<Esc>". Another way to do this is to use the +command "3a!<Esc>". The count of 3 tells the command that follows to triple +its effect. Similarly, to delete three characters, use the command "3x". The +count always comes before the command it applies to. + +============================================================================== +*02.7* Getting out + +To exit, use the "ZZ" command. This command writes the file and exits. + + Note: + Unlike many other editors, Vim does not automatically make a backup + file. If you type "ZZ", your changes are committed and there's no + turning back. You can configure the Vim editor to produce backup + files, see |07.4|. + + +DISCARDING CHANGES + +Sometimes you will make a sequence of changes and suddenly realize you were +better off before you started. Not to worry; Vim has a +quit-and-throw-things-away command. It is: > + + :q! + +Don't forget to press <Enter> to finish the command. + +For those of you interested in the details, the three parts of this command +are the colon (:), which enters Command-line mode; the q command, which tells +the editor to quit; and the override command modifier (!). + The override command modifier is needed because Vim is reluctant to throw +away changes. If you were to just type ":q", Vim would display an error +message and refuse to exit: + + E37: No write since last change (use ! to override) ~ + +By specifying the override, you are in effect telling Vim, "I know that what +I'm doing looks stupid, but I'm a big boy and really want to do this." + +If you want to continue editing with Vim: The ":e!" command reloads the +original version of the file. + +============================================================================== +*02.8* Finding help + +Everything you always wanted to know can be found in the Vim help files. +Don't be afraid to ask! + To get generic help use this command: > + + :help + +You could also use the first function key <F1>. If your keyboard has a <Help> +key it might work as well. + If you don't supply a subject, ":help" displays the general help window. +The creators of Vim did something very clever (or very lazy) with the help +system: They made the help window a normal editing window. You can use all +the normal Vim commands to move through the help information. Therefore h, j, +k, and l move left, down, up and right. + To get out of the help window, use the same command you use to get out of +the editor: "ZZ". This will only close the help window, not exit Vim. + +As you read the help text, you will notice some text enclosed in vertical bars +(for example, |help|). This indicates a hyperlink. If you position the +cursor anywhere between the bars and press CTRL-] (jump to tag), the help +system takes you to the indicated subject. (For reasons not discussed here, +the Vim terminology for a hyperlink is tag. So CTRL-] jumps to the location +of the tag given by the word under the cursor.) + After a few jumps, you might want to go back. CTRL-T (pop tag) takes you +back to the preceding position. CTRL-O (jump to older position) also works +nicely here. + At the top of the help screen, there is the notation *help.txt*. This name +between "*" characters is used by the help system to define a tag (hyperlink +destination). + See |29.1| for details about using tags. + +To get help on a given subject, use the following command: > + + :help {subject} + +To get help on the "x" command, for example, enter the following: > + + :help x + +To find out how to delete text, use this command: > + + :help deleting + +To get a complete index of all Vim commands, use the following command: > + + :help index + +When you need to get help for a control character command (for example, +CTRL-A), you need to spell it with the prefix "CTRL-". > + + :help CTRL-A + +The Vim editor has many different modes. By default, the help system displays +the normal-mode commands. For example, the following command displays help +for the normal-mode CTRL-H command: > + + :help CTRL-H + +To identify other modes, use a mode prefix. If you want the help for the +insert-mode version of a command, use "i_". For CTRL-H this gives you the +following command: > + + :help i_CTRL-H + +When you start the Vim editor, you can use several command-line arguments. +These all begin with a dash (-). To find what the -t argument does, for +example, use the command: > + + :help -t + +The Vim editor has a number of options that enable you to configure and +customize the editor. If you want help for an option, you need to enclose it +in single quotation marks. To find out what the 'number' option does, for +example, use the following command: > + + :help 'number' + +The table with all mode prefixes can be found here: |help-context|. + +Special keys are enclosed in angle brackets. To find help on the up-arrow key +in Insert mode, for instance, use this command: > + + :help i_<Up> + +If you see an error message that you don't understand, for example: + + E37: No write since last change (use ! to override) ~ + +You can use the error ID at the start to find help about it: > + + :help E37 + + +Summary: *help-summary* > + :help +< Gives you very general help. Scroll down to see a list of all + helpfiles, including those added locally (i.e. not distributed + with Vim). > + :help user-toc.txt +< Table of contents of the User Manual. > + :help :subject +< Ex-command "subject", for instance the following: > + :help :help +< Help on getting help. > + :help abc +< normal-mode command "abc". > + :help CTRL-B +< Control key <C-B> in Normal mode. > + :help i_abc + :help i_CTRL-B +< The same in Insert mode. > + :help v_abc + :help v_CTRL-B +< The same in Visual mode. > + :help c_abc + :help c_CTRL-B +< The same in Command-line mode. > + :help 'subject' +< Option 'subject'. > + :help subject() +< Function "subject". > + :help -subject +< Command-line option "-subject". > + :help +subject +< Compile-time feature "+subject". > + :help EventName +< Autocommand event "EventName". > + :help digraphs.txt +< The top of the helpfile "digraph.txt". + Similarly for any other helpfile. > + :help pattern<Tab> +< Find a help tag starting with "pattern". Repeat <Tab> for + others. > + :help pattern<Ctrl-D> +< See all possible help tag matches "pattern" at once. > + :helpgrep pattern +< Search the whole text of all help files for pattern "pattern". + Jumps to the first match. Jump to other matches with: > + :cn +< next match > + :cprev + :cN +< previous match > + :cfirst + :clast +< first or last match > + :copen + :cclose +< open/close the quickfix window; press <Enter> to jump + to the item under the cursor + + +============================================================================== + +Next chapter: |usr_03.txt| Moving around + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_03.txt b/share/vim/vim73/doc/usr_03.txt new file mode 100644 index 0000000000..0f73c5512e --- /dev/null +++ b/share/vim/vim73/doc/usr_03.txt @@ -0,0 +1,654 @@ +*usr_03.txt* For Vim version 7.3. Last change: 2006 Jun 21 + + VIM USER MANUAL - by Bram Moolenaar + + Moving around + + +Before you can insert or delete text the cursor has to be moved to the right +place. Vim has a large number of commands to position the cursor. This +chapter shows you how to use the most important ones. You can find a list of +these commands below |Q_lr|. + +|03.1| Word movement +|03.2| Moving to the start or end of a line +|03.3| Moving to a character +|03.4| Matching a parenthesis +|03.5| Moving to a specific line +|03.6| Telling where you are +|03.7| Scrolling around +|03.8| Simple searches +|03.9| Simple search patterns +|03.10| Using marks + + Next chapter: |usr_04.txt| Making small changes + Previous chapter: |usr_02.txt| The first steps in Vim +Table of contents: |usr_toc.txt| + +============================================================================== +*03.1* Word movement + +To move the cursor forward one word, use the "w" command. Like most Vim +commands, you can use a numeric prefix to move past multiple words. For +example, "3w" moves three words. This figure shows how it works: + + This is a line with example text ~ + --->-->->-----------------> + w w w 3w + +Notice that "w" moves to the start of the next word if it already is at the +start of a word. + The "b" command moves backward to the start of the previous word: + + This is a line with example text ~ + <----<--<-<---------<--- + b b b 2b b + +There is also the "e" command that moves to the next end of a word and "ge", +which moves to the previous end of a word: + + This is a line with example text ~ + <- <--- -----> ----> + ge ge e e + +If you are at the last word of a line, the "w" command will take you to the +first word in the next line. Thus you can use this to move through a +paragraph, much faster than using "l". "b" does the same in the other +direction. + +A word ends at a non-word character, such as a ".", "-" or ")". To change +what Vim considers to be a word, see the 'iskeyword' option. + It is also possible to move by white-space separated WORDs. This is not a +word in the normal sense, that's why the uppercase is used. The commands for +moving by WORDs are also uppercase, as this figure shows: + + ge b w e + <- <- ---> ---> + This is-a line, with special/separated/words (and some more). ~ + <----- <----- --------------------> -----> + gE B W E + +With this mix of lowercase and uppercase commands, you can quickly move +forward and backward through a paragraph. + +============================================================================== +*03.2* Moving to the start or end of a line + +The "$" command moves the cursor to the end of a line. If your keyboard has +an <End> key it will do the same thing. + +The "^" command moves to the first non-blank character of the line. The "0" +command (zero) moves to the very first character of the line. The <Home> key +does the same thing. In a picture: + + ^ + <------------ + .....This is a line with example text ~ + <----------------- ---------------> + 0 $ + +(the "....." indicates blanks here) + + The "$" command takes a count, like most movement commands. But moving to +the end of the line several times doesn't make sense. Therefore it causes the +editor to move to the end of another line. For example, "1$" moves you to +the end of the first line (the one you're on), "2$" to the end of the next +line, and so on. + The "0" command doesn't take a count argument, because the "0" would be +part of the count. Unexpectedly, using a count with "^" doesn't have any +effect. + +============================================================================== +*03.3* Moving to a character + +One of the most useful movement commands is the single-character search +command. The command "fx" searches forward in the line for the single +character x. Hint: "f" stands for "Find". + For example, you are at the beginning of the following line. Suppose you +want to go to the h of human. Just execute the command "fh" and the cursor +will be positioned over the h: + + To err is human. To really foul up you need a computer. ~ + ---------->---------------> + fh fy + +This also shows that the command "fy" moves to the end of the word really. + You can specify a count; therefore, you can go to the "l" of "foul" with +"3fl": + + To err is human. To really foul up you need a computer. ~ + ---------------------> + 3fl + +The "F" command searches to the left: + + To err is human. To really foul up you need a computer. ~ + <--------------------- + Fh + +The "tx" command works like the "fx" command, except it stops one character +before the searched character. Hint: "t" stands for "To". The backward +version of this command is "Tx". + + To err is human. To really foul up you need a computer. ~ + <------------ -------------> + Th tn + +These four commands can be repeated with ";". "," repeats in the other +direction. The cursor is never moved to another line. Not even when the +sentence continues. + +Sometimes you will start a search, only to realize that you have typed the +wrong command. You type "f" to search backward, for example, only to realize +that you really meant "F". To abort a search, press <Esc>. So "f<Esc>" is an +aborted forward search and doesn't do anything. Note: <Esc> cancels most +operations, not just searches. + +============================================================================== +*03.4* Matching a parenthesis + +When writing a program you often end up with nested () constructs. Then the +"%" command is very handy: It moves to the matching paren. If the cursor is +on a "(" it will move to the matching ")". If it's on a ")" it will move to +the matching "(". + + % + <-----> + if (a == (b * c) / d) ~ + <----------------> + % + +This also works for [] and {} pairs. (This can be defined with the +'matchpairs' option.) + +When the cursor is not on a useful character, "%" will search forward to find +one. Thus if the cursor is at the start of the line of the previous example, +"%" will search forward and find the first "(". Then it moves to its match: + + if (a == (b * c) / d) ~ + ---+----------------> + % + +============================================================================== +*03.5* Moving to a specific line + +If you are a C or C++ programmer, you are familiar with error messages such as +the following: + + prog.c:33: j undeclared (first use in this function) ~ + +This tells you that you might want to fix something on line 33. So how do you +find line 33? One way is to do "9999k" to go to the top of the file and "32j" +to go down thirty two lines. It is not a good way, but it works. A much +better way of doing things is to use the "G" command. With a count, this +command positions you at the given line number. For example, "33G" puts you +on line 33. (For a better way of going through a compiler's error list, see +|usr_30.txt|, for information on the :make command.) + With no argument, "G" positions you at the end of the file. A quick way to +go to the start of a file use "gg". "1G" will do the same, but is a tiny bit +more typing. + + | first line of a file ^ + | text text text text | + | text text text text | gg + 7G | text text text text | + | text text text text + | text text text text + V text text text text | + text text text text | G + text text text text | + last line of a file V + +Another way to move to a line is using the "%" command with a count. For +example "50%" moves you to halfway the file. "90%" goes to near the end. + +The previous assumes that you want to move to a line in the file, no matter if +it's currently visible or not. What if you want to move to one of the lines +you can see? This figure shows the three commands you can use: + + +---------------------------+ + H --> | text sample text | + | sample text | + | text sample text | + | sample text | + M --> | text sample text | + | sample text | + | text sample text | + | sample text | + L --> | text sample text | + +---------------------------+ + +Hints: "H" stands for Home, "M" for Middle and "L" for Last. + +============================================================================== +*03.6* Telling where you are + +To see where you are in a file, there are three ways: + +1. Use the CTRL-G command. You get a message like this (assuming the 'ruler' + option is off): + + "usr_03.txt" line 233 of 650 --35%-- col 45-52 ~ + + This shows the name of the file you are editing, the line number where the + cursor is, the total number of lines, the percentage of the way through + the file and the column of the cursor. + Sometimes you will see a split column number. For example, "col 2-9". + This indicates that the cursor is positioned on the second character, but + because character one is a tab, occupying eight spaces worth of columns, + the screen column is 9. + +2. Set the 'number' option. This will display a line number in front of + every line: > + + :set number +< + To switch this off again: > + + :set nonumber +< + Since 'number' is a boolean option, prepending "no" to its name has the + effect of switching it off. A boolean option has only these two values, + it is either on or off. + Vim has many options. Besides the boolean ones there are options with + a numerical value and string options. You will see examples of this where + they are used. + +3. Set the 'ruler' option. This will display the cursor position in the + lower right corner of the Vim window: > + + :set ruler + +Using the 'ruler' option has the advantage that it doesn't take much room, +thus there is more space for your text. + +============================================================================== +*03.7* Scrolling around + +The CTRL-U command scrolls down half a screen of text. Think of looking +through a viewing window at the text and moving this window up by half the +height of the window. Thus the window moves up over the text, which is +backward in the file. Don't worry if you have a little trouble remembering +which end is up. Most users have the same problem. + The CTRL-D command moves the viewing window down half a screen in the file, +thus scrolls the text up half a screen. + + +----------------+ + | some text | + | some text | + | some text | + +---------------+ | some text | + | some text | CTRL-U --> | | + | | | 123456 | + | 123456 | +----------------+ + | 7890 | + | | +----------------+ + | example | CTRL-D --> | 7890 | + +---------------+ | | + | example | + | example | + | example | + | example | + +----------------+ + +To scroll one line at a time use CTRL-E (scroll up) and CTRL-Y (scroll down). +Think of CTRL-E to give you one line Extra. (If you use MS-Windows compatible +key mappings CTRL-Y will redo a change instead of scroll.) + +To scroll forward by a whole screen (except for two lines) use CTRL-F. The +other way is backward, CTRL-B is the command to use. Fortunately CTRL-F is +Forward and CTRL-B is Backward, that's easy to remember. + +A common issue is that after moving down many lines with "j" your cursor is at +the bottom of the screen. You would like to see the context of the line with +the cursor. That's done with the "zz" command. + + +------------------+ +------------------+ + | some text | | some text | + | some text | | some text | + | some text | | some text | + | some text | zz --> | line with cursor | + | some text | | some text | + | some text | | some text | + | line with cursor | | some text | + +------------------+ +------------------+ + +The "zt" command puts the cursor line at the top, "zb" at the bottom. There +are a few more scrolling commands, see |Q_sc|. To always keep a few lines of +context around the cursor, use the 'scrolloff' option. + +============================================================================== +*03.8* Simple searches + +To search for a string, use the "/string" command. To find the word include, +for example, use the command: > + + /include + +You will notice that when you type the "/" the cursor jumps to the last line +of the Vim window, like with colon commands. That is where you type the word. +You can press the backspace key (backarrow or <BS>) to make corrections. Use +the <Left> and <Right> cursor keys when necessary. + Pressing <Enter> executes the command. + + Note: + The characters .*[]^%/\?~$ have special meanings. If you want to use + them in a search you must put a \ in front of them. See below. + +To find the next occurrence of the same string use the "n" command. Use this +to find the first #include after the cursor: > + + /#include + +And then type "n" several times. You will move to each #include in the text. +You can also use a count if you know which match you want. Thus "3n" finds +the third match. Using a count with "/" doesn't work. + +The "?" command works like "/" but searches backwards: > + + ?word + +The "N" command repeats the last search the opposite direction. Thus using +"N" after a "/" command search backwards, using "N" after "?" searches +forward. + + +IGNORING CASE + +Normally you have to type exactly what you want to find. If you don't care +about upper or lowercase in a word, set the 'ignorecase' option: > + + :set ignorecase + +If you now search for "word", it will also match "Word" and "WORD". To match +case again: > + + :set noignorecase + + +HISTORY + +Suppose you do three searches: > + + /one + /two + /three + +Now let's start searching by typing a simple "/" without pressing <Enter>. If +you press <Up> (the cursor key), Vim puts "/three" on the command line. +Pressing <Enter> at this point searches for three. If you do not press +<Enter>, but press <Up> instead, Vim changes the prompt to "/two". Another +press of <Up> moves you to "/one". + You can also use the <Down> cursor key to move through the history of +search commands in the other direction. + +If you know what a previously used pattern starts with, and you want to use it +again, type that character before pressing <Up>. With the previous example, +you can type "/o<Up>" and Vim will put "/one" on the command line. + +The commands starting with ":" also have a history. That allows you to recall +a previous command and execute it again. These two histories are separate. + + +SEARCHING FOR A WORD IN THE TEXT + +Suppose you see the word "TheLongFunctionName" in the text and you want to +find the next occurrence of it. You could type "/TheLongFunctionName", but +that's a lot of typing. And when you make a mistake Vim won't find it. + There is an easier way: Position the cursor on the word and use the "*" +command. Vim will grab the word under the cursor and use it as the search +string. + The "#" command does the same in the other direction. You can prepend a +count: "3*" searches for the third occurrence of the word under the cursor. + + +SEARCHING FOR WHOLE WORDS + +If you type "/the" it will also match "there". To only find words that end +in "the" use: > + + /the\> + +The "\>" item is a special marker that only matches at the end of a word. +Similarly "\<" only matches at the begin of a word. Thus to search for the +word "the" only: > + + /\<the\> + +This does not match "there" or "soothe". Notice that the "*" and "#" commands +use these start-of-word and end-of-word markers to only find whole words (you +can use "g*" and "g#" to match partial words). + + +HIGHLIGHTING MATCHES + +While editing a program you see a variable called "nr". You want to check +where it's used. You could move the cursor to "nr" and use the "*" command +and press "n" to go along all the matches. + There is another way. Type this command: > + + :set hlsearch + +If you now search for "nr", Vim will highlight all matches. That is a very +good way to see where the variable is used, without the need to type commands. + To switch this off: > + + :set nohlsearch + +Then you need to switch it on again if you want to use it for the next search +command. If you only want to remove the highlighting, use this command: > + + :nohlsearch + +This doesn't reset the option. Instead, it disables the highlighting. As +soon as you execute a search command, the highlighting will be used again. +Also for the "n" and "N" commands. + + +TUNING SEARCHES + +There are a few options that change how searching works. These are the +essential ones: +> + :set incsearch + +This makes Vim display the match for the string while you are still typing it. +Use this to check if the right match will be found. Then press <Enter> to +really jump to that location. Or type more to change the search string. +> + :set nowrapscan + +This stops the search at the end of the file. Or, when you are searching +backwards, at the start of the file. The 'wrapscan' option is on by default, +thus searching wraps around the end of the file. + + +INTERMEZZO + +If you like one of the options mentioned before, and set it each time you use +Vim, you can put the command in your Vim startup file. + Edit the file, as mentioned at |not-compatible|. Or use this command to +find out where it is: > + + :scriptnames + +Edit the file, for example with: > + + :edit ~/.vimrc + +Then add a line with the command to set the option, just like you typed it in +Vim. Example: > + + Go:set hlsearch<Esc> + +"G" moves to the end of the file. "o" starts a new line, where you type the +":set" command. You end insert mode with <Esc>. Then write the file: > + + ZZ + +If you now start Vim again, the 'hlsearch' option will already be set. + +============================================================================== +*03.9* Simple search patterns + +The Vim editor uses regular expressions to specify what to search for. +Regular expressions are an extremely powerful and compact way to specify a +search pattern. Unfortunately, this power comes at a price, because regular +expressions are a bit tricky to specify. + In this section we mention only a few essential ones. More about search +patterns and commands in chapter 27 |usr_27.txt|. You can find the full +explanation here: |pattern|. + + +BEGINNING AND END OF A LINE + +The ^ character matches the beginning of a line. On an English-US keyboard +you find it above the 6. The pattern "include" matches the word include +anywhere on the line. But the pattern "^include" matches the word include +only if it is at the beginning of a line. + The $ character matches the end of a line. Therefore, "was$" matches the +word was only if it is at the end of a line. + +Let's mark the places where "the" matches in this example line with "x"s: + + the solder holding one of the chips melted and the ~ + xxx xxx xxx + +Using "/the$" we find this match: + + the solder holding one of the chips melted and the ~ + xxx + +And with "/^the" we find this one: + the solder holding one of the chips melted and the ~ + xxx + +You can try searching with "/^the$", it will only match a single line +consisting of "the". White space does matter here, thus if a line contains a +space after the word, like "the ", the pattern will not match. + + +MATCHING ANY SINGLE CHARACTER + +The . (dot) character matches any existing character. For example, the +pattern "c.m" matches a string whose first character is a c, whose second +character is anything, and whose the third character is m. Example: + + We use a computer that became the cummin winter. ~ + xxx xxx xxx + + +MATCHING SPECIAL CHARACTERS + +If you really want to match a dot, you must avoid its special meaning by +putting a backslash before it. + If you search for "ter.", you will find these matches: + + We use a computer that became the cummin winter. ~ + xxxx xxxx + +Searching for "ter\." only finds the second match. + +============================================================================== +*03.10* Using marks + +When you make a jump to a position with the "G" command, Vim remembers the +position from before this jump. This position is called a mark. To go back +where you came from, use this command: > + + `` + +This ` is a backtick or open single-quote character. + If you use the same command a second time you will jump back again. That's +because the ` command is a jump itself, and the position from before this jump +is remembered. + +Generally, every time you do a command that can move the cursor further than +within the same line, this is called a jump. This includes the search +commands "/" and "n" (it doesn't matter how far away the match is). But not +the character searches with "fx" and "tx" or the word movements "w" and "e". + Also, "j" and "k" are not considered to be a jump. Even when you use a +count to make them move the cursor quite a long way away. + +The `` command jumps back and forth, between two points. The CTRL-O command +jumps to older positions (Hint: O for older). CTRL-I then jumps back to newer +positions (Hint: I is just next to O on the keyboard). Consider this sequence +of commands: > + + 33G + /^The + CTRL-O + +You first jump to line 33, then search for a line that starts with "The". +Then with CTRL-O you jump back to line 33. Another CTRL-O takes you back to +where you started. If you now use CTRL-I you jump to line 33 again. And +to the match for "The" with another CTRL-I. + + + | example text ^ | + 33G | example text | CTRL-O | CTRL-I + | example text | | + V line 33 text ^ V + | example text | | + /^The | example text | CTRL-O | CTRL-I + V There you are | V + example text + + Note: + CTRL-I is the same as <Tab>. + +The ":jumps" command gives a list of positions you jumped to. The entry which +you used last is marked with a ">". + + +NAMED MARKS *bookmark* + +Vim enables you to place your own marks in the text. The command "ma" marks +the place under the cursor as mark a. You can place 26 marks (a through z) in +your text. You can't see them, it's just a position that Vim remembers. + To go to a mark, use the command `{mark}, where {mark} is the mark letter. +Thus to move to the a mark: +> + `a + +The command 'mark (single quotation mark, or apostrophe) moves you to the +beginning of the line containing the mark. This differs from the `mark +command, which moves you to marked column. + +The marks can be very useful when working on two related parts in a file. +Suppose you have some text near the start of the file you need to look at, +while working on some text near the end of the file. + Move to the text at the start and place the s (start) mark there: > + + ms + +Then move to the text you want to work on and put the e (end) mark there: > + + me + +Now you can move around, and when you want to look at the start of the file, +you use this to jump there: > + + 's + +Then you can use '' to jump back to where you were, or 'e to jump to the text +you were working on at the end. + There is nothing special about using s for start and e for end, they are +just easy to remember. + +You can use this command to get a list of marks: > + + :marks + +You will notice a few special marks. These include: + + ' The cursor position before doing a jump + " The cursor position when last editing the file + [ Start of the last change + ] End of the last change + +============================================================================== + +Next chapter: |usr_04.txt| Making small changes + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_04.txt b/share/vim/vim73/doc/usr_04.txt new file mode 100644 index 0000000000..5a3f97b496 --- /dev/null +++ b/share/vim/vim73/doc/usr_04.txt @@ -0,0 +1,514 @@ +*usr_04.txt* For Vim version 7.3. Last change: 2008 Sep 06 + + VIM USER MANUAL - by Bram Moolenaar + + Making small changes + + +This chapter shows you several ways of making corrections and moving text +around. It teaches you the three basic ways to change text: operator-motion, +Visual mode and text objects. + +|04.1| Operators and motions +|04.2| Changing text +|04.3| Repeating a change +|04.4| Visual mode +|04.5| Moving text +|04.6| Copying text +|04.7| Using the clipboard +|04.8| Text objects +|04.9| Replace mode +|04.10| Conclusion + + Next chapter: |usr_05.txt| Set your settings + Previous chapter: |usr_03.txt| Moving around +Table of contents: |usr_toc.txt| + +============================================================================== +*04.1* Operators and motions + +In chapter 2 you learned the "x" command to delete a single character. And +using a count: "4x" deletes four characters. + The "dw" command deletes a word. You may recognize the "w" command as the +move word command. In fact, the "d" command may be followed by any motion +command, and it deletes from the current location to the place where the +cursor winds up. + The "4w" command, for example, moves the cursor over four words. The d4w +command deletes four words. + + To err is human. To really foul up you need a computer. ~ + ------------------> + d4w + + To err is human. you need a computer. ~ + +Vim only deletes up to the position where the motion takes the cursor. That's +because Vim knows that you probably don't want to delete the first character +of a word. If you use the "e" command to move to the end of a word, Vim +guesses that you do want to include that last character: + + To err is human. you need a computer. ~ + --------> + d2e + + To err is human. a computer. ~ + +Whether the character under the cursor is included depends on the command you +used to move to that character. The reference manual calls this "exclusive" +when the character isn't included and "inclusive" when it is. + +The "$" command moves to the end of a line. The "d$" command deletes from the +cursor to the end of the line. This is an inclusive motion, thus the last +character of the line is included in the delete operation: + + To err is human. a computer. ~ + ------------> + d$ + + To err is human ~ + +There is a pattern here: operator-motion. You first type an operator command. +For example, "d" is the delete operator. Then you type a motion command like +"4l" or "w". This way you can operate on any text you can move over. + +============================================================================== +*04.2* Changing text + +Another operator is "c", change. It acts just like the "d" operator, except +it leaves you in Insert mode. For example, "cw" changes a word. Or more +specifically, it deletes a word and then puts you in Insert mode. + + To err is human ~ + -------> + c2wbe<Esc> + + To be human ~ + +This "c2wbe<Esc>" contains these bits: + + c the change operator + 2w move two words (they are deleted and Insert mode started) + be insert this text + <Esc> back to Normal mode + +If you have paid attention, you will have noticed something strange: The space +before "human" isn't deleted. There is a saying that for every problem there +is an answer that is simple, clear, and wrong. That is the case with the +example used here for the "cw" command. The c operator works just like the +d operator, with one exception: "cw". It actually works like "ce", change to +end of word. Thus the space after the word isn't included. This is an +exception that dates back to the old Vi. Since many people are used to it +now, the inconsistency has remained in Vim. + + +MORE CHANGES + +Like "dd" deletes a whole line, "cc" changes a whole line. It keeps the +existing indent (leading white space) though. + +Just like "d$" deletes until the end of the line, "c$" changes until the end +of the line. It's like doing "d$" to delete the text and then "a" to start +Insert mode and append new text. + + +SHORTCUTS + +Some operator-motion commands are used so often that they have been given a +single letter command: + + x stands for dl (delete character under the cursor) + X stands for dh (delete character left of the cursor) + D stands for d$ (delete to end of the line) + C stands for c$ (change to end of the line) + s stands for cl (change one character) + S stands for cc (change a whole line) + + +WHERE TO PUT THE COUNT + +The commands "3dw" and "d3w" delete three words. If you want to get really +picky about things, the first command, "3dw", deletes one word three times; +the command "d3w" deletes three words once. This is a difference without a +distinction. You can actually put in two counts, however. For example, +"3d2w" deletes two words, repeated three times, for a total of six words. + + +REPLACING WITH ONE CHARACTER + +The "r" command is not an operator. It waits for you to type a character, and +will replace the character under the cursor with it. You could do the same +with "cl" or with the "s" command, but with "r" you don't have to press <Esc> + + there is somerhing grong here ~ + rT rt rw + + There is something wrong here ~ + +Using a count with "r" causes that many characters to be replaced with the +same character. Example: + + There is something wrong here ~ + 5rx + + There is something xxxxx here ~ + +To replace a character with a line break use "r<Enter>". This deletes one +character and inserts a line break. Using a count here only applies to the +number of characters deleted: "4r<Enter>" replaces four characters with one +line break. + +============================================================================== +*04.3* Repeating a change + +The "." command is one of the most simple yet powerful commands in Vim. It +repeats the last change. For instance, suppose you are editing an HTML file +and want to delete all the <B> tags. You position the cursor on the first < +and delete the <B> with the command "df>". You then go to the < of the next +</B> and kill it using the "." command. The "." command executes the last +change command (in this case, "df>"). To delete another tag, position the +cursor on the < and use the "." command. + + To <B>generate</B> a table of <B>contents ~ + f< find first < ---> + df> delete to > --> + f< find next < ---------> + . repeat df> ---> + f< find next < -------------> + . repeat df> --> + +The "." command works for all changes you make, except for the "u" (undo), +CTRL-R (redo) and commands that start with a colon (:). + +Another example: You want to change the word "four" to "five". It appears +several times in your text. You can do this quickly with this sequence of +commands: + + /four<Enter> find the first string "four" + cwfive<Esc> change the word to "five" + n find the next "four" + . repeat the change to "five' + n find the next "four" + . repeat the change + etc. + +============================================================================== +*04.4* Visual mode + +To delete simple items the operator-motion changes work quite well. But often +it's not so easy to decide which command will move over the text you want to +change. Then you can use Visual mode. + +You start Visual mode by pressing "v". You move the cursor over the text you +want to work on. While you do this, the text is highlighted. Finally type +the operator command. + For example, to delete from halfway one word to halfway another word: + + This is an examination sample of visual mode ~ + ----------> + velllld + + This is an example of visual mode ~ + +When doing this you don't really have to count how many times you have to +press "l" to end up in the right position. You can immediately see what text +will be deleted when you press "d". + +If at any time you decide you don't want to do anything with the highlighted +text, just press <Esc> and Visual mode will stop without doing anything. + + +SELECTING LINES + +If you want to work on whole lines, use "V" to start Visual mode. You will +see right away that the whole line is highlighted, without moving around. +When you move left or right nothing changes. When you move up or down the +selection is extended whole lines at a time. + For example, select three lines with "Vjj": + + +------------------------+ + | text more text | + >> | more text more text | | + selected lines >> | text text text | | Vjj + >> | text more | V + | more text more | + +------------------------+ + + +SELECTING BLOCKS + +If you want to work on a rectangular block of characters, use CTRL-V to start +Visual mode. This is very useful when working on tables. + + name Q1 Q2 Q3 + pierre 123 455 234 + john 0 90 39 + steve 392 63 334 + +To delete the middle "Q2" column, move the cursor to the "Q" of "Q2". Press +CTRL-V to start blockwise Visual mode. Now move the cursor three lines down +with "3j" and to the next word with "w". You can see the first character of +the last column is included. To exclude it, use "h". Now press "d" and the +middle column is gone. + + +GOING TO THE OTHER SIDE + +If you have selected some text in Visual mode, and discover that you need to +change the other end of the selection, use the "o" command (Hint: o for other +end). The cursor will go to the other end, and you can move the cursor to +change where the selection starts. Pressing "o" again brings you back to the +other end. + +When using blockwise selection, you have four corners. "o" only takes you to +one of the other corners, diagonally. Use "O" to move to the other corner in +the same line. + +Note that "o" and "O" in Visual mode work very differently from Normal mode, +where they open a new line below or above the cursor. + +============================================================================== +*04.5* Moving text + +When you delete something with the "d", "x", or another command, the text is +saved. You can paste it back by using the p command. (The Vim name for +this is put). + Take a look at how this works. First you will delete an entire line, by +putting the cursor on the line you want to delete and typing "dd". Now you +move the cursor to where you want to put the line and use the "p" (put) +command. The line is inserted on the line below the cursor. + + a line a line a line + line 2 dd line 3 p line 3 + line 3 line 2 + +Because you deleted an entire line, the "p" command placed the text line below +the cursor. If you delete part of a line (a word, for instance), the "p" +command puts it just after the cursor. + + Some more boring try text to out commands. ~ + ----> + dw + + Some more boring text to out commands. ~ + -------> + welp + + Some more boring text to try out commands. ~ + + +MORE ON PUTTING + +The "P" command puts text like "p", but before the cursor. When you deleted a +whole line with "dd", "P" will put it back above the cursor. When you deleted +a word with "dw", "P" will put it back just before the cursor. + +You can repeat putting as many times as you like. The same text will be used. + +You can use a count with "p" and "P". The text will be repeated as many times +as specified with the count. Thus "dd" and then "3p" puts three copies of the +same deleted line. + + +SWAPPING TWO CHARACTERS + +Frequently when you are typing, your fingers get ahead of your brain (or the +other way around?). The result is a typo such as "teh" for "the". Vim +makes it easy to correct such problems. Just put the cursor on the e of "teh" +and execute the command "xp". This works as follows: "x" deletes the +character e and places it in a register. "p" puts the text after the cursor, +which is after the h. + + teh th the ~ + x p + +============================================================================== +*04.6* Copying text + +To copy text from one place to another, you could delete it, use "u" to undo +the deletion and then "p" to put it somewhere else. There is an easier way: +yanking. The "y" operator copies text into a register. Then a "p" command +can be used to put it. + Yanking is just a Vim name for copying. The "c" letter was already used +for the change operator, and "y" was still available. Calling this +operator "yank" made it easier to remember to use the "y" key. + +Since "y" is an operator, you use "yw" to yank a word. A count is possible as +usual. To yank two words use "y2w". Example: + + let sqr = LongVariable * ~ + --------------> + y2w + + let sqr = LongVariable * ~ + p + + let sqr = LongVariable * LongVariable ~ + +Notice that "yw" includes the white space after a word. If you don't want +this, use "ye". + +The "yy" command yanks a whole line, just like "dd" deletes a whole line. +Unexpectedly, while "D" deletes from the cursor to the end of the line, "Y" +works like "yy", it yanks the whole line. Watch out for this inconsistency! +Use "y$" to yank to the end of the line. + + a text line yy a text line a text line + line 2 line 2 p line 2 + last line last line a text line + last line + +============================================================================== +*04.7* Using the clipboard + +If you are using the GUI version of Vim (gvim), you can find the "Copy" item +in the "Edit" menu. First select some text with Visual mode, then use the +Edit/Copy menu. The selected text is now copied to the clipboard. You can +paste the text in other programs. In Vim itself too. + +If you have copied text to the clipboard in another application, you can paste +it in Vim with the Edit/Paste menu. This works in Normal mode and Insert +mode. In Visual mode the selected text is replaced with the pasted text. + +The "Cut" menu item deletes the text before it's put on the clipboard. The +"Copy", "Cut" and "Paste" items are also available in the popup menu (only +when there is a popup menu, of course). If your Vim has a toolbar, you can +also find these items there. + +If you are not using the GUI, or if you don't like using a menu, you have to +use another way. You use the normal "y" (yank) and "p" (put) commands, but +prepend "* (double-quote star) before it. To copy a line to the clipboard: > + + "*yy + +To put text from the clipboard back into the text: > + + "*p + +This only works on versions of Vim that include clipboard support. More about +the clipboard in section |09.3| and here: |clipboard|. + +============================================================================== +*04.8* Text objects + +If the cursor is in the middle of a word and you want to delete that word, you +need to move back to its start before you can do "dw". There is a simpler way +to do this: "daw". + + this is some example text. ~ + daw + + this is some text. ~ + +The "d" of "daw" is the delete operator. "aw" is a text object. Hint: "aw" +stands for "A Word". Thus "daw" is "Delete A Word". To be precise, the white +space after the word is also deleted (the white space before the word at the +end of the line). + +Using text objects is the third way to make changes in Vim. We already had +operator-motion and Visual mode. Now we add operator-text object. + It is very similar to operator-motion, but instead of operating on the text +between the cursor position before and after a movement command, the text +object is used as a whole. It doesn't matter where in the object the cursor +was. + +To change a whole sentence use "cis". Take this text: + + Hello there. This ~ + is an example. Just ~ + some text. ~ + +Move to the start of the second line, on "is an". Now use "cis": + + Hello there. Just ~ + some text. ~ + +The cursor is in between the blanks in the first line. Now you type the new +sentence "Another line.": + + Hello there. Another line. Just ~ + some text. ~ + +"cis" consists of the "c" (change) operator and the "is" text object. This +stands for "Inner Sentence". There is also the "as" (a sentence) object. The +difference is that "as" includes the white space after the sentence and "is" +doesn't. If you would delete a sentence, you want to delete the white space +at the same time, thus use "das". If you want to type new text the white +space can remain, thus you use "cis". + +You can also use text objects in Visual mode. It will include the text object +in the Visual selection. Visual mode continues, thus you can do this several +times. For example, start Visual mode with "v" and select a sentence with +"as". Now you can repeat "as" to include more sentences. Finally you use an +operator to do something with the selected sentences. + +You can find a long list of text objects here: |text-objects|. + +============================================================================== +*04.9* Replace mode + +The "R" command causes Vim to enter replace mode. In this mode, each +character you type replaces the one under the cursor. This continues until +you type <Esc>. + In this example you start Replace mode on the first "t" of "text": + + This is text. ~ + Rinteresting.<Esc> + + This is interesting. ~ + +You may have noticed that this command replaced 5 characters in the line with +twelve others. The "R" command automatically extends the line if it runs out +of characters to replace. It will not continue on the next line. + +You can switch between Insert mode and Replace mode with the <Insert> key. + +When you use <BS> (backspace) to make correction, you will notice that the +old text is put back. Thus it works like an undo command for the last typed +character. + +============================================================================== +*04.10* Conclusion + +The operators, movement commands and text objects give you the possibility to +make lots of combinations. Now that you know how it works, you can use N +operators with M movement commands to make N * M commands! + +You can find a list of operators here: |operator| + +For example, there are many other ways to delete pieces of text. Here are a +few often used ones: + +x delete character under the cursor (short for "dl") +X delete character before the cursor (short for "dh") +D delete from cursor to end of line (short for "d$") +dw delete from cursor to next start of word +db delete from cursor to previous start of word +diw delete word under the cursor (excluding white space) +daw delete word under the cursor (including white space) +dG delete until the end of the file +dgg delete until the start of the file + +If you use "c" instead of "d" they become change commands. And with "y" you +yank the text. And so forth. + + +There are a few often used commands to make changes that didn't fit somewhere +else: + + ~ change case of the character under the cursor, and move the + cursor to the next character. This is not an operator (unless + 'tildeop' is set), thus you can't use it with a motion + command. It does work in Visual mode and changes case for + all the selected text then. + + I Start Insert mode after moving the cursor to the first + non-blank in the line. + + A Start Insert mode after moving the cursor to the end of the + line. + +============================================================================== + +Next chapter: |usr_05.txt| Set your settings + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_05.txt b/share/vim/vim73/doc/usr_05.txt new file mode 100644 index 0000000000..b0f27d1fce --- /dev/null +++ b/share/vim/vim73/doc/usr_05.txt @@ -0,0 +1,625 @@ +*usr_05.txt* For Vim version 7.3. Last change: 2009 Jun 04 + + VIM USER MANUAL - by Bram Moolenaar + + Set your settings + + +Vim can be tuned to work like you want it to. This chapter shows you how to +make Vim start with options set to different values. Add plugins to extend +Vim's capabilities. Or define your own macros. + +|05.1| The vimrc file +|05.2| The example vimrc file explained +|05.3| Simple mappings +|05.4| Adding a plugin +|05.5| Adding a help file +|05.6| The option window +|05.7| Often used options + + Next chapter: |usr_06.txt| Using syntax highlighting + Previous chapter: |usr_04.txt| Making small changes +Table of contents: |usr_toc.txt| + +============================================================================== +*05.1* The vimrc file *vimrc-intro* + +You probably got tired of typing commands that you use very often. To start +Vim with all your favorite option settings and mappings, you write them in +what is called the vimrc file. Vim executes the commands in this file when it +starts up. + +If you already have a vimrc file (e.g., when your sysadmin has one setup for +you), you can edit it this way: > + + :edit $MYVIMRC + +If you don't have a vimrc file yet, see |vimrc| to find out where you can +create a vimrc file. Also, the ":version" command mentions the name of the +"user vimrc file" Vim looks for. + +For Unix and Macintosh this file is always used and is recommended: + + ~/.vimrc ~ + +For MS-DOS and MS-Windows you can use one of these: + + $HOME/_vimrc ~ + $VIM/_vimrc ~ + +The vimrc file can contain all the commands that you type after a colon. The +most simple ones are for setting options. For example, if you want Vim to +always start with the 'incsearch' option on, add this line you your vimrc +file: > + + set incsearch + +For this new line to take effect you need to exit Vim and start it again. +Later you will learn how to do this without exiting Vim. + +This chapter only explains the most basic items. For more information on how +to write a Vim script file: |usr_41.txt|. + +============================================================================== +*05.2* The example vimrc file explained *vimrc_example.vim* + +In the first chapter was explained how the example vimrc (included in the +Vim distribution) file can be used to make Vim startup in not-compatible mode +(see |not-compatible|). The file can be found here: + + $VIMRUNTIME/vimrc_example.vim ~ + +In this section we will explain the various commands used in this file. This +will give you hints about how to set up your own preferences. Not everything +will be explained though. Use the ":help" command to find out more. + +> + set nocompatible + +As mentioned in the first chapter, these manuals explain Vim working in an +improved way, thus not completely Vi compatible. Setting the 'compatible' +option off, thus 'nocompatible' takes care of this. + +> + set backspace=indent,eol,start + +This specifies where in Insert mode the <BS> is allowed to delete the +character in front of the cursor. The three items, separated by commas, tell +Vim to delete the white space at the start of the line, a line break and the +character before where Insert mode started. +> + + set autoindent + +This makes Vim use the indent of the previous line for a newly created line. +Thus there is the same amount of white space before the new line. For example +when pressing <Enter> in Insert mode, and when using the "o" command to open a +new line. +> + + if has("vms") + set nobackup + else + set backup + endif + +This tells Vim to keep a backup copy of a file when overwriting it. But not +on the VMS system, since it keeps old versions of files already. The backup +file will have the same name as the original file with "~" added. See |07.4| +> + + set history=50 + +Keep 50 commands and 50 search patterns in the history. Use another number if +you want to remember fewer or more lines. +> + + set ruler + +Always display the current cursor position in the lower right corner of the +Vim window. + +> + set showcmd + +Display an incomplete command in the lower right corner of the Vim window, +left of the ruler. For example, when you type "2f", Vim is waiting for you to +type the character to find and "2f" is displayed. When you press "w" next, +the "2fw" command is executed and the displayed "2f" is removed. + + +-------------------------------------------------+ + |text in the Vim window | + |~ | + |~ | + |-- VISUAL -- 2f 43,8 17% | + +-------------------------------------------------+ + ^^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^ + 'showmode' 'showcmd' 'ruler' + +> + set incsearch + +Display the match for a search pattern when halfway typing it. + +> + map Q gq + +This defines a key mapping. More about that in the next section. This +defines the "Q" command to do formatting with the "gq" operator. This is how +it worked before Vim 5.0. Otherwise the "Q" command starts Ex mode, but you +will not need it. + +> + vnoremap _g y:exe "grep /" . escape(@", '\\/') . "/ *.c *.h"<CR> + +This mapping yanks the visually selected text and searches for it in C files. +This is a complicated mapping. You can see that mappings can be used to do +quite complicated things. Still, it is just a sequence of commands that are +executed like you typed them. + +> + if &t_Co > 2 || has("gui_running") + syntax on + set hlsearch + endif + +This switches on syntax highlighting, but only if colors are available. And +the 'hlsearch' option tells Vim to highlight matches with the last used search +pattern. The "if" command is very useful to set options only when some +condition is met. More about that in |usr_41.txt|. + + *vimrc-filetype* > + filetype plugin indent on + +This switches on three very clever mechanisms: +1. Filetype detection. + Whenever you start editing a file, Vim will try to figure out what kind of + file this is. When you edit "main.c", Vim will see the ".c" extension and + recognize this as a "c" filetype. When you edit a file that starts with + "#!/bin/sh", Vim will recognize it as a "sh" filetype. + The filetype detection is used for syntax highlighting and the other two + items below. + See |filetypes|. + +2. Using filetype plugin files + Many different filetypes are edited with different options. For example, + when you edit a "c" file, it's very useful to set the 'cindent' option to + automatically indent the lines. These commonly useful option settings are + included with Vim in filetype plugins. You can also add your own, see + |write-filetype-plugin|. + +3. Using indent files + When editing programs, the indent of a line can often be computed + automatically. Vim comes with these indent rules for a number of + filetypes. See |:filetype-indent-on| and 'indentexpr'. + +> + autocmd FileType text setlocal textwidth=78 + +This makes Vim break text to avoid lines getting longer than 78 characters. +But only for files that have been detected to be plain text. There are +actually two parts here. "autocmd FileType text" is an autocommand. This +defines that when the file type is set to "text" the following command is +automatically executed. "setlocal textwidth=78" sets the 'textwidth' option +to 78, but only locally in one file. + + *restore-cursor* > + autocmd BufReadPost * + \ if line("'\"") > 1 && line("'\"") <= line("$") | + \ exe "normal! g`\"" | + \ endif + +Another autocommand. This time it is used after reading any file. The +complicated stuff after it checks if the '" mark is defined, and jumps to it +if so. The backslash at the start of a line is used to continue the command +from the previous line. That avoids a line getting very long. +See |line-continuation|. This only works in a Vim script file, not when +typing commands at the command-line. + +============================================================================== +*05.3* Simple mappings + +A mapping enables you to bind a set of Vim commands to a single key. Suppose, +for example, that you need to surround certain words with curly braces. In +other words, you need to change a word such as "amount" into "{amount}". With +the :map command, you can tell Vim that the F5 key does this job. The command +is as follows: > + + :map <F5> i{<Esc>ea}<Esc> +< + Note: + When entering this command, you must enter <F5> by typing four + characters. Similarly, <Esc> is not entered by pressing the <Esc> + key, but by typing five characters. Watch out for this difference + when reading the manual! + +Let's break this down: + <F5> The F5 function key. This is the trigger key that causes the + command to be executed as the key is pressed. + + i{<Esc> Insert the { character. The <Esc> key ends Insert mode. + + e Move to the end of the word. + + a}<Esc> Append the } to the word. + +After you execute the ":map" command, all you have to do to put {} around a +word is to put the cursor on the first character and press F5. + +In this example, the trigger is a single key; it can be any string. But when +you use an existing Vim command, that command will no longer be available. +You better avoid that. + One key that can be used with mappings is the backslash. Since you +probably want to define more than one mapping, add another character. You +could map "\p" to add parentheses around a word, and "\c" to add curly braces, +for example: > + + :map \p i(<Esc>ea)<Esc> + :map \c i{<Esc>ea}<Esc> + +You need to type the \ and the p quickly after another, so that Vim knows they +belong together. + +The ":map" command (with no arguments) lists your current mappings. At +least the ones for Normal mode. More about mappings in section |40.1|. + +============================================================================== +*05.4* Adding a plugin *add-plugin* *plugin* + +Vim's functionality can be extended by adding plugins. A plugin is nothing +more than a Vim script file that is loaded automatically when Vim starts. You +can add a plugin very easily by dropping it in your plugin directory. +{not available when Vim was compiled without the |+eval| feature} + +There are two types of plugins: + + global plugin: Used for all kinds of files + filetype plugin: Only used for a specific type of file + +The global plugins will be discussed first, then the filetype ones +|add-filetype-plugin|. + + +GLOBAL PLUGINS *standard-plugin* + +When you start Vim, it will automatically load a number of global plugins. +You don't have to do anything for this. They add functionality that most +people will want to use, but which was implemented as a Vim script instead of +being compiled into Vim. You can find them listed in the help index +|standard-plugin-list|. Also see |load-plugins|. + + *add-global-plugin* +You can add a global plugin to add functionality that will always be present +when you use Vim. There are only two steps for adding a global plugin: +1. Get a copy of the plugin. +2. Drop it in the right directory. + + +GETTING A GLOBAL PLUGIN + +Where can you find plugins? +- Some come with Vim. You can find them in the directory $VIMRUNTIME/macros + and its sub-directories. +- Download from the net. There is a large collection on http://www.vim.org. +- They are sometimes posted in a Vim |maillist|. +- You could write one yourself, see |write-plugin|. + +Some plugins come as a vimball archive, see |vimball|. +Some plugins can be updated automatically, see |getscript|. + + +USING A GLOBAL PLUGIN + +First read the text in the plugin itself to check for any special conditions. +Then copy the file to your plugin directory: + + system plugin directory ~ + Unix ~/.vim/plugin/ + PC and OS/2 $HOME/vimfiles/plugin or $VIM/vimfiles/plugin + Amiga s:vimfiles/plugin + Macintosh $VIM:vimfiles:plugin + Mac OS X ~/.vim/plugin/ + RISC-OS Choices:vimfiles.plugin + +Example for Unix (assuming you didn't have a plugin directory yet): > + + mkdir ~/.vim + mkdir ~/.vim/plugin + cp /usr/local/share/vim/vim60/macros/justify.vim ~/.vim/plugin + +That's all! Now you can use the commands defined in this plugin to justify +text. + +Instead of putting plugins directly into the plugin/ directory, you may +better organize them by putting them into subdirectories under plugin/. +As an example, consider using "~/.vim/plugin/perl/*.vim" for all your Perl +plugins. + + +FILETYPE PLUGINS *add-filetype-plugin* *ftplugins* + +The Vim distribution comes with a set of plugins for different filetypes that +you can start using with this command: > + + :filetype plugin on + +That's all! See |vimrc-filetype|. + +If you are missing a plugin for a filetype you are using, or you found a +better one, you can add it. There are two steps for adding a filetype plugin: +1. Get a copy of the plugin. +2. Drop it in the right directory. + + +GETTING A FILETYPE PLUGIN + +You can find them in the same places as the global plugins. Watch out if the +type of file is mentioned, then you know if the plugin is a global or a +filetype one. The scripts in $VIMRUNTIME/macros are global ones, the filetype +plugins are in $VIMRUNTIME/ftplugin. + + +USING A FILETYPE PLUGIN *ftplugin-name* + +You can add a filetype plugin by dropping it in the right directory. The +name of this directory is in the same directory mentioned above for global +plugins, but the last part is "ftplugin". Suppose you have found a plugin for +the "stuff" filetype, and you are on Unix. Then you can move this file to the +ftplugin directory: > + + mv thefile ~/.vim/ftplugin/stuff.vim + +If that file already exists you already have a plugin for "stuff". You might +want to check if the existing plugin doesn't conflict with the one you are +adding. If it's OK, you can give the new one another name: > + + mv thefile ~/.vim/ftplugin/stuff_too.vim + +The underscore is used to separate the name of the filetype from the rest, +which can be anything. If you use "otherstuff.vim" it wouldn't work, it would +be loaded for the "otherstuff" filetype. + +On MS-DOS you cannot use long filenames. You would run into trouble if you +add a second plugin and the filetype has more than six characters. You can +use an extra directory to get around this: > + + mkdir $VIM/vimfiles/ftplugin/fortran + copy thefile $VIM/vimfiles/ftplugin/fortran/too.vim + +The generic names for the filetype plugins are: > + + ftplugin/<filetype>.vim + ftplugin/<filetype>_<name>.vim + ftplugin/<filetype>/<name>.vim + +Here "<name>" can be any name that you prefer. +Examples for the "stuff" filetype on Unix: > + + ~/.vim/ftplugin/stuff.vim + ~/.vim/ftplugin/stuff_def.vim + ~/.vim/ftplugin/stuff/header.vim + +The <filetype> part is the name of the filetype the plugin is to be used for. +Only files of this filetype will use the settings from the plugin. The <name> +part of the plugin file doesn't matter, you can use it to have several plugins +for the same filetype. Note that it must end in ".vim". + + +Further reading: +|filetype-plugins| Documentation for the filetype plugins and information + about how to avoid that mappings cause problems. +|load-plugins| When the global plugins are loaded during startup. +|ftplugin-overrule| Overruling the settings from a global plugin. +|write-plugin| How to write a plugin script. +|plugin-details| For more information about using plugins or when your + plugin doesn't work. +|new-filetype| How to detect a new file type. + +============================================================================== +*05.5* Adding a help file *add-local-help* *matchit-install* + +If you are lucky, the plugin you installed also comes with a help file. We +will explain how to install the help file, so that you can easily find help +for your new plugin. + Let us use the "matchit.vim" plugin as an example (it is included with +Vim). This plugin makes the "%" command jump to matching HTML tags, +if/else/endif in Vim scripts, etc. Very useful, although it's not backwards +compatible (that's why it is not enabled by default). + This plugin comes with documentation: "matchit.txt". Let's first copy the +plugin to the right directory. This time we will do it from inside Vim, so +that we can use $VIMRUNTIME. (You may skip some of the "mkdir" commands if +you already have the directory.) > + + :!mkdir ~/.vim + :!mkdir ~/.vim/plugin + :!cp $VIMRUNTIME/macros/matchit.vim ~/.vim/plugin + +The "cp" command is for Unix, on MS-DOS you can use "copy". + +Now create a "doc" directory in one of the directories in 'runtimepath'. > + + :!mkdir ~/.vim/doc + +Copy the help file to the "doc" directory. > + + :!cp $VIMRUNTIME/macros/matchit.txt ~/.vim/doc + +Now comes the trick, which allows you to jump to the subjects in the new help +file: Generate the local tags file with the |:helptags| command. > + + :helptags ~/.vim/doc + +Now you can use the > + + :help g% + +command to find help for "g%" in the help file you just added. You can see an +entry for the local help file when you do: > + + :help local-additions + +The title lines from the local help files are automagically added to this +section. There you can see which local help files have been added and jump to +them through the tag. + +For writing a local help file, see |write-local-help|. + +============================================================================== +*05.6* The option window + +If you are looking for an option that does what you want, you can search in +the help files here: |options|. Another way is by using this command: > + + :options + +This opens a new window, with a list of options with a one-line explanation. +The options are grouped by subject. Move the cursor to a subject and press +<Enter> to jump there. Press <Enter> again to jump back. Or use CTRL-O. + +You can change the value of an option. For example, move to the "displaying +text" subject. Then move the cursor down to this line: + + set wrap nowrap ~ + +When you hit <Enter>, the line will change to: + + set nowrap wrap ~ + +The option has now been switched off. + +Just above this line is a short description of the 'wrap' option. Move the +cursor one line up to place it in this line. Now hit <Enter> and you jump to +the full help on the 'wrap' option. + +For options that take a number or string argument you can edit the value. +Then press <Enter> to apply the new value. For example, move the cursor a few +lines up to this line: + + set so=0 ~ + +Position the cursor on the zero with "$". Change it into a five with "r5". +Then press <Enter> to apply the new value. When you now move the cursor +around you will notice that the text starts scrolling before you reach the +border. This is what the 'scrolloff' option does, it specifies an offset +from the window border where scrolling starts. + +============================================================================== +*05.7* Often used options + +There are an awful lot of options. Most of them you will hardly ever use. +Some of the more useful ones will be mentioned here. Don't forget you can +find more help on these options with the ":help" command, with single quotes +before and after the option name. For example: > + + :help 'wrap' + +In case you have messed up an option value, you can set it back to the +default by putting an ampersand (&) after the option name. Example: > + + :set iskeyword& + + +NOT WRAPPING LINES + +Vim normally wraps long lines, so that you can see all of the text. Sometimes +it's better to let the text continue right of the window. Then you need to +scroll the text left-right to see all of a long line. Switch wrapping off +with this command: > + + :set nowrap + +Vim will automatically scroll the text when you move to text that is not +displayed. To see a context of ten characters, do this: > + + :set sidescroll=10 + +This doesn't change the text in the file, only the way it is displayed. + + +WRAPPING MOVEMENT COMMANDS + +Most commands for moving around will stop moving at the start and end of a +line. You can change that with the 'whichwrap' option. This sets it to the +default value: > + + :set whichwrap=b,s + +This allows the <BS> key, when used in the first position of a line, to move +the cursor to the end of the previous line. And the <Space> key moves from +the end of a line to the start of the next one. + +To allow the cursor keys <Left> and <Right> to also wrap, use this command: > + + :set whichwrap=b,s,<,> + +This is still only for Normal mode. To let <Left> and <Right> do this in +Insert mode as well: > + + :set whichwrap=b,s,<,>,[,] + +There are a few other flags that can be added, see 'whichwrap'. + + +VIEWING TABS + +When there are tabs in a file, you cannot see where they are. To make them +visible: > + + :set list + +Now every tab is displayed as ^I. And a $ is displayed at the end of each +line, so that you can spot trailing spaces that would otherwise go unnoticed. + A disadvantage is that this looks ugly when there are many Tabs in a file. +If you have a color terminal, or are using the GUI, Vim can show the spaces +and tabs as highlighted characters. Use the 'listchars' option: > + + :set listchars=tab:>-,trail:- + +Now every tab will be displayed as ">---" (with more or less "-") and trailing +white space as "-". Looks a lot better, doesn't it? + + +KEYWORDS + +The 'iskeyword' option specifies which characters can appear in a word: > + + :set iskeyword +< iskeyword=@,48-57,_,192-255 ~ + +The "@" stands for all alphabetic letters. "48-57" stands for ASCII +characters 48 to 57, which are the numbers 0 to 9. "192-255" are the +printable latin characters. + Sometimes you will want to include a dash in keywords, so that commands +like "w" consider "upper-case" to be one word. You can do it like this: > + + :set iskeyword+=- + :set iskeyword +< iskeyword=@,48-57,_,192-255,- ~ + +If you look at the new value, you will see that Vim has added a comma for you. + To remove a character use "-=". For example, to remove the underscore: > + + :set iskeyword-=_ + :set iskeyword +< iskeyword=@,48-57,192-255,- ~ + +This time a comma is automatically deleted. + + +ROOM FOR MESSAGES + +When Vim starts there is one line at the bottom that is used for messages. +When a message is long, it is either truncated, thus you can only see part of +it, or the text scrolls and you have to press <Enter> to continue. + You can set the 'cmdheight' option to the number of lines used for +messages. Example: > + + :set cmdheight=3 + +This does mean there is less room to edit text, thus it's a compromise. + +============================================================================== + +Next chapter: |usr_06.txt| Using syntax highlighting + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_06.txt b/share/vim/vim73/doc/usr_06.txt new file mode 100644 index 0000000000..208cc3ef9c --- /dev/null +++ b/share/vim/vim73/doc/usr_06.txt @@ -0,0 +1,280 @@ +*usr_06.txt* For Vim version 7.3. Last change: 2009 Oct 28 + + VIM USER MANUAL - by Bram Moolenaar + + Using syntax highlighting + + +Black and white text is boring. With colors your file comes to life. This +not only looks nice, it also speeds up your work. Change the colors used for +the different sorts of text. Print your text, with the colors you see on the +screen. + +|06.1| Switching it on +|06.2| No or wrong colors? +|06.3| Different colors +|06.4| With colors or without colors +|06.5| Printing with colors +|06.6| Further reading + + Next chapter: |usr_07.txt| Editing more than one file + Previous chapter: |usr_05.txt| Set your settings +Table of contents: |usr_toc.txt| + +============================================================================== +*06.1* Switching it on + +It all starts with one simple command: > + + :syntax enable + +That should work in most situations to get color in your files. Vim will +automagically detect the type of file and load the right syntax highlighting. +Suddenly comments are blue, keywords brown and strings red. This makes it +easy to overview the file. After a while you will find that black&white text +slows you down! + +If you always want to use syntax highlighting, put the ":syntax enable" +command in your |vimrc| file. + +If you want syntax highlighting only when the terminal supports colors, you +can put this in your |vimrc| file: > + + if &t_Co > 1 + syntax enable + endif + +If you want syntax highlighting only in the GUI version, put the ":syntax +enable" command in your |gvimrc| file. + +============================================================================== +*06.2* No or wrong colors? + +There can be a number of reasons why you don't see colors: + +- Your terminal does not support colors. + Vim will use bold, italic and underlined text, but this doesn't look + very nice. You probably will want to try to get a terminal with + colors. For Unix, I recommend the xterm from the XFree86 project: + |xfree-xterm|. + +- Your terminal does support colors, but Vim doesn't know this. + Make sure your $TERM setting is correct. For example, when using an + xterm that supports colors: > + + setenv TERM xterm-color +< + or (depending on your shell): > + + TERM=xterm-color; export TERM + +< The terminal name must match the terminal you are using. If it + still doesn't work, have a look at |xterm-color|, which shows a few + ways to make Vim display colors (not only for an xterm). + +- The file type is not recognized. + Vim doesn't know all file types, and sometimes it's near to impossible + to tell what language a file uses. Try this command: > + + :set filetype +< + If the result is "filetype=" then the problem is indeed that Vim + doesn't know what type of file this is. You can set the type + manually: > + + :set filetype=fortran + +< To see which types are available, look in the directory + $VIMRUNTIME/syntax. For the GUI you can use the Syntax menu. + Setting the filetype can also be done with a |modeline|, so that the + file will be highlighted each time you edit it. For example, this + line can be used in a Makefile (put it near the start or end of the + file): > + + # vim: syntax=make + +< You might know how to detect the file type yourself. Often the file + name extension (after the dot) can be used. + See |new-filetype| for how to tell Vim to detect that file type. + +- There is no highlighting for your file type. + You could try using a similar file type by manually setting it as + mentioned above. If that isn't good enough, you can write your own + syntax file, see |mysyntaxfile|. + + +Or the colors could be wrong: + +- The colored text is very hard to read. + Vim guesses the background color that you are using. If it is black + (or another dark color) it will use light colors for text. If it is + white (or another light color) it will use dark colors for text. If + Vim guessed wrong the text will be hard to read. To solve this, set + the 'background' option. For a dark background: > + + :set background=dark + +< And for a light background: > + + :set background=light + +< Make sure you put this _before_ the ":syntax enable" command, + otherwise the colors will already have been set. You could do + ":syntax reset" after setting 'background' to make Vim set the default + colors again. + +- The colors are wrong when scrolling bottom to top. + Vim doesn't read the whole file to parse the text. It starts parsing + wherever you are viewing the file. That saves a lot of time, but + sometimes the colors are wrong. A simple fix is hitting CTRL-L. Or + scroll back a bit and then forward again. + For a real fix, see |:syn-sync|. Some syntax files have a way to make + it look further back, see the help for the specific syntax file. For + example, |tex.vim| for the TeX syntax. + +============================================================================== +*06.3* Different colors *:syn-default-override* + +If you don't like the default colors, you can select another color scheme. In +the GUI use the Edit/Color Scheme menu. You can also type the command: > + + :colorscheme evening + +"evening" is the name of the color scheme. There are several others you might +want to try out. Look in the directory $VIMRUNTIME/colors. + +When you found the color scheme that you like, add the ":colorscheme" command +to your |vimrc| file. + +You could also write your own color scheme. This is how you do it: + +1. Select a color scheme that comes close. Copy this file to your own Vim + directory. For Unix, this should work: > + + !mkdir ~/.vim/colors + !cp $VIMRUNTIME/colors/morning.vim ~/.vim/colors/mine.vim +< + This is done from Vim, because it knows the value of $VIMRUNTIME. + +2. Edit the color scheme file. These entries are useful: + + term attributes in a B&W terminal + cterm attributes in a color terminal + ctermfg foreground color in a color terminal + ctermbg background color in a color terminal + gui attributes in the GUI + guifg foreground color in the GUI + guibg background color in the GUI + + For example, to make comments green: > + + :highlight Comment ctermfg=green guifg=green +< + Attributes you can use for "cterm" and "gui" are "bold" and "underline". + If you want both, use "bold,underline". For details see the |:highlight| + command. + +3. Tell Vim to always use your color scheme. Put this line in your |vimrc|: > + + colorscheme mine + +If you want to see what the most often used color combinations look like, use +this command: > + + :runtime syntax/colortest.vim + +You will see text in various color combinations. You can check which ones are +readable and look nice. + +============================================================================== +*06.4* With colors or without colors + +Displaying text in color takes a lot of effort. If you find the displaying +too slow, you might want to disable syntax highlighting for a moment: > + + :syntax clear + +When editing another file (or the same one) the colors will come back. + + *:syn-off* +If you want to stop highlighting completely use: > + + :syntax off + +This will completely disable syntax highlighting and remove it immediately for +all buffers. + + *:syn-manual* +If you want syntax highlighting only for specific files, use this: > + + :syntax manual + +This will enable the syntax highlighting, but not switch it on automatically +when starting to edit a buffer. To switch highlighting on for the current +buffer, set the 'syntax' option: > + + :set syntax=ON +< +============================================================================== +*06.5* Printing with colors *syntax-printing* + +In the MS-Windows version you can print the current file with this command: > + + :hardcopy + +You will get the usual printer dialog, where you can select the printer and a +few settings. If you have a color printer, the paper output should look the +same as what you see inside Vim. But when you use a dark background the +colors will be adjusted to look good on white paper. + +There are several options that change the way Vim prints: + 'printdevice' + 'printheader' + 'printfont' + 'printoptions' + +To print only a range of lines, use Visual mode to select the lines and then +type the command: > + + v100j:hardcopy + +"v" starts Visual mode. "100j" moves a hundred lines down, they will be +highlighted. Then ":hardcopy" will print those lines. You can use other +commands to move in Visual mode, of course. + +This also works on Unix, if you have a PostScript printer. Otherwise, you +will have to do a bit more work. You need to convert the text to HTML first, +and then print it from a web browser. + +Convert the current file to HTML with this command: > + + :TOhtml + +In case that doesn't work: > + + :source $VIMRUNTIME/syntax/2html.vim + +You will see it crunching away, this can take quite a while for a large file. +Some time later another window shows the HTML code. Now write this somewhere +(doesn't matter where, you throw it away later): +> + :write main.c.html + +Open this file in your favorite browser and print it from there. If all goes +well, the output should look exactly as it does in Vim. See |2html.vim| for +details. Don't forget to delete the HTML file when you are done with it. + +Instead of printing, you could also put the HTML file on a web server, and let +others look at the colored text. + +============================================================================== +*06.6* Further reading + +|usr_44.txt| Your own syntax highlighted. +|syntax| All the details. + +============================================================================== + +Next chapter: |usr_07.txt| Editing more than one file + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_07.txt b/share/vim/vim73/doc/usr_07.txt new file mode 100644 index 0000000000..4722ddbf07 --- /dev/null +++ b/share/vim/vim73/doc/usr_07.txt @@ -0,0 +1,479 @@ +*usr_07.txt* For Vim version 7.3. Last change: 2006 Apr 24 + + VIM USER MANUAL - by Bram Moolenaar + + Editing more than one file + + +No matter how many files you have, you can edit them without leaving Vim. +Define a list of files to work on and jump from one to the other. Copy text +from one file and put it in another one. + +|07.1| Edit another file +|07.2| A list of files +|07.3| Jumping from file to file +|07.4| Backup files +|07.5| Copy text between files +|07.6| Viewing a file +|07.7| Changing the file name + + Next chapter: |usr_08.txt| Splitting windows + Previous chapter: |usr_06.txt| Using syntax highlighting +Table of contents: |usr_toc.txt| + +============================================================================== +*07.1* Edit another file + +So far you had to start Vim for every file you wanted to edit. There is a +simpler way. To start editing another file, use this command: > + + :edit foo.txt + +You can use any file name instead of "foo.txt". Vim will close the current +file and open the new one. If the current file has unsaved changes, however, +Vim displays an error message and does not open the new file: + + E37: No write since last change (use ! to override) ~ + + Note: + Vim puts an error ID at the start of each error message. If you do + not understand the message or what caused it, look in the help system + for this ID. In this case: > + + :help E37 + +At this point, you have a number of alternatives. You can write the file +using this command: > + + :write + +Or you can force Vim to discard your changes and edit the new file, using the +force (!) character: > + + :edit! foo.txt + +If you want to edit another file, but not write the changes in the current +file yet, you can make it hidden: > + + :hide edit foo.txt + +The text with changes is still there, but you can't see it. This is further +explained in section |22.4|: The buffer list. + +============================================================================== +*07.2* A list of files + +You can start Vim to edit a sequence of files. For example: > + + vim one.c two.c three.c + +This command starts Vim and tells it that you will be editing three files. +Vim displays just the first file. After you have done your thing in this +file, to edit the next file you use this command: > + + :next + +If you have unsaved changes in the current file, you will get an error +message and the ":next" will not work. This is the same problem as with +":edit" mentioned in the previous section. To abandon the changes: > + + :next! + +But mostly you want to save the changes and move on to the next file. There +is a special command for this: > + + :wnext + +This does the same as using two separate commands: > + + :write + :next + + +WHERE AM I? + +To see which file in the argument list you are editing, look in the window +title. It should show something like "(2 of 3)". This means you are editing +the second file out of three files. + If you want to see the list of files, use this command: > + + :args + +This is short for "arguments". The output might look like this: + + one.c [two.c] three.c ~ + +These are the files you started Vim with. The one you are currently editing, +"two.c", is in square brackets. + + +MOVING TO OTHER ARGUMENTS + +To go back one file: > + + :previous + +This is just like the ":next" command, except that it moves in the other +direction. Again, there is a shortcut command for when you want to write the +file first: > + + :wprevious + +To move to the very last file in the list: > + + :last + +And to move back to the first one again: > + + :first + +There is no ":wlast" or ":wfirst" command though! + +You can use a count for ":next" and ":previous". To skip two files forward: > + + :2next + + +AUTOMATIC WRITING + +When moving around the files and making changes, you have to remember to use +":write". Otherwise you will get an error message. If you are sure you +always want to write modified files, you can tell Vim to automatically write +them: > + + :set autowrite + +When you are editing a file which you may not want to write, switch it off +again: > + + :set noautowrite + + +EDITING ANOTHER LIST OF FILES + +You can redefine the list of files without the need to exit Vim and start it +again. Use this command to edit three other files: > + + :args five.c six.c seven.h + +Or use a wildcard, like it's used in the shell: > + + :args *.txt + +Vim will take you to the first file in the list. Again, if the current file +has changes, you can either write the file first, or use ":args!" (with ! +added) to abandon the changes. + + +DID YOU EDIT THE LAST FILE? + *arglist-quit* +When you use a list of files, Vim assumes you want to edit them all. To +protect you from exiting too early, you will get this error when you didn't +edit the last file in the list yet: + + E173: 46 more files to edit ~ + +If you really want to exit, just do it again. Then it will work (but not when +you did other commands in between). + +============================================================================== +*07.3* Jumping from file to file + +To quickly jump between two files, press CTRL-^ (on English-US keyboards the ^ +is above the 6 key). Example: > + + :args one.c two.c three.c + +You are now in one.c. > + + :next + +Now you are in two.c. Now use CTRL-^ to go back to one.c. Another CTRL-^ and +you are back in two.c. Another CTRL-^ and you are in one.c again. If you now +do: > + + :next + +You are in three.c. Notice that the CTRL-^ command does not change the idea +of where you are in the list of files. Only commands like ":next" and +":previous" do that. + +The file you were previously editing is called the "alternate" file. When you +just started Vim CTRL-^ will not work, since there isn't a previous file. + + +PREDEFINED MARKS + +After jumping to another file, you can use two predefined marks which are very +useful: > + + `" + +This takes you to the position where the cursor was when you left the file. +Another mark that is remembered is the position where you made the last +change: > + + `. + +Suppose you are editing the file "one.txt". Somewhere halfway the file you +use "x" to delete a character. Then you go to the last line with "G" and +write the file with ":w". You edit several other files, and then use ":edit +one.txt" to come back to "one.txt". If you now use `" Vim jumps to the last +line of the file. Using `. takes you to the position where you deleted the +character. Even when you move around in the file `" and `. will take you to +the remembered position. At least until you make another change or leave the +file. + + +FILE MARKS + +In chapter 4 was explained how you can place a mark in a file with "mx" and +jump to that position with "`x". That works within one file. If you edit +another file and place marks there, these are specific for that file. Thus +each file has its own set of marks, they are local to the file. + So far we were using marks with a lowercase letter. There are also marks +with an uppercase letter. These are global, they can be used from any file. +For example suppose that we are editing the file "foo.txt". Go to halfway the +file ("50%") and place the F mark there (F for foo): > + + 50%mF + +Now edit the file "bar.txt" and place the B mark (B for bar) at its last line: +> + GmB + +Now you can use the "'F" command to jump back to halfway foo.txt. Or edit yet +another file, type "'B" and you are at the end of bar.txt again. + +The file marks are remembered until they are placed somewhere else. Thus you +can place the mark, do hours of editing and still be able to jump back to that +mark. + It's often useful to think of a simple connection between the mark letter +and where it is placed. For example, use the H mark in a header file, M in +a Makefile and C in a C code file. + +To see where a specific mark is, give an argument to the ":marks" command: > + + :marks M + +You can also give several arguments: > + + :marks MCP + +Don't forget that you can use CTRL-O and CTRL-I to jump to older and newer +positions without placing marks there. + +============================================================================== +*07.4* Backup files + +Usually Vim does not produce a backup file. If you want to have one, all you +need to do is execute the following command: > + + :set backup + +The name of the backup file is the original file with a ~ added to the end. +If your file is named data.txt, for example, the backup file name is +data.txt~. + If you do not like the fact that the backup files end with ~, you can +change the extension: > + + :set backupext=.bak + +This will use data.txt.bak instead of data.txt~. + Another option that matters here is 'backupdir'. It specifies where the +backup file is written. The default, to write the backup in the same +directory as the original file, will mostly be the right thing. + + Note: + When the 'backup' option isn't set but the 'writebackup' is, Vim will + still create a backup file. However, it is deleted as soon as writing + the file was completed successfully. This functions as a safety + against losing your original file when writing fails in some way (disk + full is the most common cause; being hit by lightning might be + another, although less common). + + +KEEPING THE ORIGINAL FILE + +If you are editing source files, you might want to keep the file before you +make any changes. But the backup file will be overwritten each time you write +the file. Thus it only contains the previous version, not the first one. + To make Vim keep the original file, set the 'patchmode' option. This +specifies the extension used for the first backup of a changed file. Usually +you would do this: > + + :set patchmode=.orig + +When you now edit the file data.txt for the first time, make changes and write +the file, Vim will keep a copy of the unchanged file under the name +"data.txt.orig". + If you make further changes to the file, Vim will notice that +"data.txt.orig" already exists and leave it alone. Further backup files will +then be called "data.txt~" (or whatever you specified with 'backupext'). + If you leave 'patchmode' empty (that is the default), the original file +will not be kept. + +============================================================================== +*07.5* Copy text between files + +This explains how to copy text from one file to another. Let's start with a +simple example. Edit the file that contains the text you want to copy. Move +the cursor to the start of the text and press "v". This starts Visual mode. +Now move the cursor to the end of the text and press "y". This yanks (copies) +the selected text. + To copy the above paragraph, you would do: > + + :edit thisfile + /This + vjjjj$y + +Now edit the file you want to put the text in. Move the cursor to the +character where you want the text to appear after. Use "p" to put the text +there. > + :edit otherfile + /There + p + +Of course you can use many other commands to yank the text. For example, to +select whole lines start Visual mode with "V". Or use CTRL-V to select a +rectangular block. Or use "Y" to yank a single line, "yaw" to yank-a-word, +etc. + The "p" command puts the text after the cursor. Use "P" to put the text +before the cursor. Notice that Vim remembers if you yanked a whole line or a +block, and puts it back that way. + + +USING REGISTERS + +When you want to copy several pieces of text from one file to another, having +to switch between the files and writing the target file takes a lot of time. +To avoid this, copy each piece of text to its own register. + A register is a place where Vim stores text. Here we will use the +registers named a to z (later you will find out there are others). Let's copy +a sentence to the f register (f for First): > + + "fyas + +The "yas" command yanks a sentence like before. It's the "f that tells Vim +the text should be place in the f register. This must come just before the +yank command. + Now yank three whole lines to the l register (l for line): > + + "l3Y + +The count could be before the "l just as well. To yank a block of text to the +b (for block) register: > + + CTRL-Vjjww"by + +Notice that the register specification "b is just before the "y" command. +This is required. If you would have put it before the "w" command, it would +not have worked. + Now you have three pieces of text in the f, l and b registers. Edit +another file, move around and place the text where you want it: > + + "fp + +Again, the register specification "f comes before the "p" command. + You can put the registers in any order. And the text stays in the register +until you yank something else into it. Thus you can put it as many times as +you like. + +When you delete text, you can also specify a register. Use this to move +several pieces of text around. For example, to delete-a-word and write it in +the w register: > + + "wdaw + +Again, the register specification comes before the delete command "d". + + +APPENDING TO A FILE + +When collecting lines of text into one file, you can use this command: > + + :write >> logfile + +This will write the text of the current file to the end of "logfile". Thus it +is appended. This avoids that you have to copy the lines, edit the log file +and put them there. Thus you save two steps. But you can only append to the +end of a file. + To append only a few lines, select them in Visual mode before typing +":write". In chapter 10 you will learn other ways to select a range of lines. + +============================================================================== +*07.6* Viewing a file + +Sometimes you only want to see what a file contains, without the intention to +ever write it back. There is the risk that you type ":w" without thinking and +overwrite the original file anyway. To avoid this, edit the file read-only. + To start Vim in readonly mode, use this command: > + + vim -R file + +On Unix this command should do the same thing: > + + view file + +You are now editing "file" in read-only mode. When you try using ":w" you +will get an error message and the file won't be written. + When you try to make a change to the file Vim will give you a warning: + + W10: Warning: Changing a readonly file ~ + +The change will be done though. This allows for formatting the file, for +example, to be able to read it easily. + If you make changes to a file and forgot that it was read-only, you can +still write it. Add the ! to the write command to force writing. + +If you really want to forbid making changes in a file, do this: > + + vim -M file + +Now every attempt to change the text will fail. The help files are like this, +for example. If you try to make a change you get this error message: + + E21: Cannot make changes, 'modifiable' is off ~ + +You could use the -M argument to setup Vim to work in a viewer mode. This is +only voluntary though, since these commands will remove the protection: > + + :set modifiable + :set write + +============================================================================== +*07.7* Changing the file name + +A clever way to start editing a new file is by using an existing file that +contains most of what you need. For example, you start writing a new program +to move a file. You know that you already have a program that copies a file, +thus you start with: > + + :edit copy.c + +You can delete the stuff you don't need. Now you need to save the file under +a new name. The ":saveas" command can be used for this: > + + :saveas move.c + +Vim will write the file under the given name, and edit that file. Thus the +next time you do ":write", it will write "move.c". "copy.c" remains +unmodified. + When you want to change the name of the file you are editing, but don't +want to write the file, you can use this command: > + + :file move.c + +Vim will mark the file as "not edited". This means that Vim knows this is not +the file you started editing. When you try to write the file, you might get +this message: + + E13: File exists (use ! to override) ~ + +This protects you from accidentally overwriting another file. + +============================================================================== + +Next chapter: |usr_08.txt| Splitting windows + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_08.txt b/share/vim/vim73/doc/usr_08.txt new file mode 100644 index 0000000000..9a9280203b --- /dev/null +++ b/share/vim/vim73/doc/usr_08.txt @@ -0,0 +1,601 @@ +*usr_08.txt* For Vim version 7.3. Last change: 2006 Jul 18 + + VIM USER MANUAL - by Bram Moolenaar + + Splitting windows + + +Display two different files above each other. Or view two locations in the +file at the same time. See the difference between two files by putting them +side by side. All this is possible with split windows. + +|08.1| Split a window +|08.2| Split a window on another file +|08.3| Window size +|08.4| Vertical splits +|08.5| Moving windows +|08.6| Commands for all windows +|08.7| Viewing differences with vimdiff +|08.8| Various +|08.9| Tab pages + + Next chapter: |usr_09.txt| Using the GUI + Previous chapter: |usr_07.txt| Editing more than one file +Table of contents: |usr_toc.txt| + +============================================================================== +*08.1* Split a window + +The easiest way to open a new window is to use the following command: > + + :split + +This command splits the screen into two windows and leaves the cursor in the +top one: + + +----------------------------------+ + |/* file one.c */ | + |~ | + |~ | + |one.c=============================| + |/* file one.c */ | + |~ | + |one.c=============================| + | | + +----------------------------------+ + +What you see here is two windows on the same file. The line with "====" is +that status line. It displays information about the window above it. (In +practice the status line will be in reverse video.) + The two windows allow you to view two parts of the same file. For example, +you could make the top window show the variable declarations of a program, and +the bottom one the code that uses these variables. + +The CTRL-W w command can be used to jump between the windows. If you are in +the top window, CTRL-W w jumps to the window below it. If you are in the +bottom window it will jump to the first window. (CTRL-W CTRL-W does the same +thing, in case you let go of the CTRL key a bit later.) + + +CLOSE THE WINDOW + +To close a window, use the command: > + + :close + +Actually, any command that quits editing a file works, like ":quit" and "ZZ". +But ":close" prevents you from accidentally exiting Vim when you close the +last window. + + +CLOSING ALL OTHER WINDOWS + +If you have opened a whole bunch of windows, but now want to concentrate on +one of them, this command will be useful: > + + :only + +This closes all windows, except for the current one. If any of the other +windows has changes, you will get an error message and that window won't be +closed. + +============================================================================== +*08.2* Split a window on another file + +The following command opens a second window and starts editing the given file: +> + :split two.c + +If you were editing one.c, then the result looks like this: + + +----------------------------------+ + |/* file two.c */ | + |~ | + |~ | + |two.c=============================| + |/* file one.c */ | + |~ | + |one.c=============================| + | | + +----------------------------------+ + +To open a window on a new, empty file, use this: > + + :new + +You can repeat the ":split" and ":new" commands to create as many windows as +you like. + +============================================================================== +*08.3* Window size + +The ":split" command can take a number argument. If specified, this will be +the height of the new window. For example, the following opens a new window +three lines high and starts editing the file alpha.c: > + + :3split alpha.c + +For existing windows you can change the size in several ways. When you have a +working mouse, it is easy: Move the mouse pointer to the status line that +separates two windows, and drag it up or down. + +To increase the size of a window: > + + CTRL-W + + +To decrease it: > + + CTRL-W - + +Both of these commands take a count and increase or decrease the window size +by that many lines. Thus "4 CTRL-W +" make the window four lines higher. + +To set the window height to a specified number of lines: > + + {height}CTRL-W _ + +That's: a number {height}, CTRL-W and then an underscore (the - key with Shift +on English-US keyboards). + To make a window as high as it can be, use the CTRL-W _ command without a +count. + + +USING THE MOUSE + +In Vim you can do many things very quickly from the keyboard. Unfortunately, +the window resizing commands require quite a bit of typing. In this case, +using the mouse is faster. Position the mouse pointer on a status line. Now +press the left mouse button and drag. The status line will move, thus making +the window on one side higher and the other smaller. + + +OPTIONS + +The 'winheight' option can be set to a minimal desired height of a window and +'winminheight' to a hard minimum height. + Likewise, there is 'winwidth' for the minimal desired width and +'winminwidth' for the hard minimum width. + The 'equalalways' option, when set, makes Vim equalize the windows sizes +when a window is closed or opened. + +============================================================================== +*08.4* Vertical splits + +The ":split" command creates the new window above the current one. To make +the window appear at the left side, use: > + + :vsplit + +or: > + :vsplit two.c + +The result looks something like this: + + +--------------------------------------+ + |/* file two.c */ |/* file one.c */ | + |~ |~ | + |~ |~ | + |~ |~ | + |two.c===============one.c=============| + | | + +--------------------------------------+ + +Actually, the | lines in the middle will be in reverse video. This is called +the vertical separator. It separates the two windows left and right of it. + +There is also the ":vnew" command, to open a vertically split window on a new, +empty file. Another way to do this: > + + :vertical new + +The ":vertical" command can be inserted before another command that splits a +window. This will cause that command to split the window vertically instead +of horizontally. (If the command doesn't split a window, it works +unmodified.) + + +MOVING BETWEEN WINDOWS + +Since you can split windows horizontally and vertically as much as you like, +you can create almost any layout of windows. Then you can use these commands +to move between them: + + CTRL-W h move to the window on the left + CTRL-W j move to the window below + CTRL-W k move to the window above + CTRL-W l move to the window on the right + + CTRL-W t move to the TOP window + CTRL-W b move to the BOTTOM window + +You will notice the same letters as used for moving the cursor. And the +cursor keys can also be used, if you like. + More commands to move to other windows: |Q_wi|. + +============================================================================== +*08.5* Moving windows + +You have split a few windows, but now they are in the wrong place. Then you +need a command to move the window somewhere else. For example, you have three +windows like this: + + +----------------------------------+ + |/* file two.c */ | + |~ | + |~ | + |two.c=============================| + |/* file three.c */ | + |~ | + |~ | + |three.c===========================| + |/* file one.c */ | + |~ | + |one.c=============================| + | | + +----------------------------------+ + +Clearly the last one should be at the top. Go to that window (using CTRL-W w) +and the type this command: > + + CTRL-W K + +This uses the uppercase letter K. What happens is that the window is moved to +the very top. You will notice that K is again used for moving upwards. + When you have vertical splits, CTRL-W K will move the current window to the +top and make it occupy the full width of the Vim window. If this is your +layout: + + +-------------------------------------------+ + |/* two.c */ |/* three.c */ |/* one.c */ | + |~ |~ |~ | + |~ |~ |~ | + |~ |~ |~ | + |~ |~ |~ | + |~ |~ |~ | + |two.c=========three.c=========one.c========| + | | + +-------------------------------------------+ + +Then using CTRL-W K in the middle window (three.c) will result in: + + +-------------------------------------------+ + |/* three.c */ | + |~ | + |~ | + |three.c====================================| + |/* two.c */ |/* one.c */ | + |~ |~ | + |two.c==================one.c===============| + | | + +-------------------------------------------+ + +The other three similar commands (you can probably guess these now): + + CTRL-W H move window to the far left + CTRL-W J move window to the bottom + CTRL-W L move window to the far right + +============================================================================== +*08.6* Commands for all windows + +When you have several windows open and you want to quit Vim, you can close +each window separately. A quicker way is using this command: > + + :qall + +This stands for "quit all". If any of the windows contain changes, Vim will +not exit. The cursor will automatically be positioned in a window with +changes. You can then either use ":write" to save the changes, or ":quit!" to +throw them away. + +If you know there are windows with changes, and you want to save all these +changes, use this command: > + + :wall + +This stands for "write all". But actually, it only writes files with +changes. Vim knows it doesn't make sense to write files that were not +changed. + And then there is the combination of ":qall" and ":wall": the "write and +quit all" command: > + + :wqall + +This writes all modified files and quits Vim. + Finally, there is a command that quits Vim and throws away all changes: > + + :qall! + +Be careful, there is no way to undo this command! + + +OPENING A WINDOW FOR ALL ARGUMENTS + +To make Vim open a window for each file, start it with the "-o" argument: > + + vim -o one.txt two.txt three.txt + +This results in: + + +-------------------------------+ + |file one.txt | + |~ | + |one.txt========================| + |file two.txt | + |~ | + |two.txt========================| + |file three.txt | + |~ | + |three.txt======================| + | | + +-------------------------------+ + +The "-O" argument is used to get vertically split windows. + When Vim is already running, the ":all" command opens a window for each +file in the argument list. ":vertical all" does it with vertical splits. + +============================================================================== +*08.7* Viewing differences with vimdiff + +There is a special way to start Vim, which shows the differences between two +files. Let's take a file "main.c" and insert a few characters in one line. +Write this file with the 'backup' option set, so that the backup file +"main.c~" will contain the previous version of the file. + Type this command in a shell (not in Vim): > + + vimdiff main.c~ main.c + +Vim will start, with two windows side by side. You will only see the line +in which you added characters, and a few lines above and below it. + + VV VV + +-----------------------------------------+ + |+ +--123 lines: /* a|+ +--123 lines: /* a| <- fold + | text | text | + | text | text | + | text | text | + | text | changed text | <- changed line + | text | text | + | text | ------------------| <- deleted line + | text | text | + | text | text | + | text | text | + |+ +--432 lines: text|+ +--432 lines: text| <- fold + | ~ | ~ | + | ~ | ~ | + |main.c~==============main.c==============| + | | + +-----------------------------------------+ + +(This picture doesn't show the highlighting, use the vimdiff command for a +better look.) + +The lines that were not modified have been collapsed into one line. This is +called a closed fold. They are indicated in the picture with "<- fold". Thus +the single fold line at the top stands for 123 text lines. These lines are +equal in both files. + The line marked with "<- changed line" is highlighted, and the inserted +text is displayed with another color. This clearly shows what the difference +is between the two files. + The line that was deleted is displayed with "---" in the main.c window. +See the "<- deleted line" marker in the picture. These characters are not +really there. They just fill up main.c, so that it displays the same number +of lines as the other window. + + +THE FOLD COLUMN + +Each window has a column on the left with a slightly different background. In +the picture above these are indicated with "VV". You notice there is a plus +character there, in front of each closed fold. Move the mouse pointer to that +plus and click the left button. The fold will open, and you can see the text +that it contains. + The fold column contains a minus sign for an open fold. If you click on +this -, the fold will close. + Obviously, this only works when you have a working mouse. You can also use +"zo" to open a fold and "zc" to close it. + + +DIFFING IN VIM + +Another way to start in diff mode can be done from inside Vim. Edit the +"main.c" file, then make a split and show the differences: > + + :edit main.c + :vertical diffsplit main.c~ + +The ":vertical" command is used to make the window split vertically. If you +omit this, you will get a horizontal split. + +If you have a patch or diff file, you can use the third way to start diff +mode. First edit the file to which the patch applies. Then tell Vim the name +of the patch file: > + + :edit main.c + :vertical diffpatch main.c.diff + +WARNING: The patch file must contain only one patch, for the file you are +editing. Otherwise you will get a lot of error messages, and some files might +be patched unexpectedly. + The patching will only be done to the copy of the file in Vim. The file on +your harddisk will remain unmodified (until you decide to write the file). + + +SCROLL BINDING + +When the files have more changes, you can scroll in the usual way. Vim will +try to keep both the windows start at the same position, so you can easily see +the differences side by side. + When you don't want this for a moment, use this command: > + + :set noscrollbind + + +JUMPING TO CHANGES + +When you have disabled folding in some way, it may be difficult to find the +changes. Use this command to jump forward to the next change: > + + ]c + +To go the other way use: > + + [c + +Prepended a count to jump further away. + + +REMOVING CHANGES + +You can move text from one window to the other. This either removes +differences or adds new ones. Vim doesn't keep the highlighting updated in +all situations. To update it use this command: > + + :diffupdate + +To remove a difference, you can move the text in a highlighted block from one +window to another. Take the "main.c" and "main.c~" example above. Move the +cursor to the left window, on the line that was deleted in the other window. +Now type this command: > + + dp + +The change will be removed by putting the text of the current window in the +other window. "dp" stands for "diff put". + You can also do it the other way around. Move the cursor to the right +window, to the line where "changed" was inserted. Now type this command: > + + do + +The change will now be removed by getting the text from the other window. +Since there are no changes left now, Vim puts all text in a closed fold. +"do" stands for "diff obtain". "dg" would have been better, but that already +has a different meaning ("dgg" deletes from the cursor until the first line). + +For details about diff mode, see |vimdiff|. + +============================================================================== +*08.8* Various + +The 'laststatus' option can be used to specify when the last window has a +statusline: + + 0 never + 1 only when there are split windows (the default) + 2 always + +Many commands that edit another file have a variant that splits the window. +For Command-line commands this is done by prepending an "s". For example: +":tag" jumps to a tag, ":stag" splits the window and jumps to a +tag. + For Normal mode commands a CTRL-W is prepended. CTRL-^ jumps to the +alternate file, CTRL-W CTRL-^ splits the window and edits the alternate file. + +The 'splitbelow' option can be set to make a new window appear below the +current window. The 'splitright' option can be set to make a vertically split +window appear right of the current window. + +When splitting a window you can prepend a modifier command to tell where the +window is to appear: + + :leftabove {cmd} left or above the current window + :aboveleft {cmd} idem + :rightbelow {cmd} right or below the current window + :belowright {cmd} idem + :topleft {cmd} at the top or left of the Vim window + :botright {cmd} at the bottom or right of the Vim window + + +============================================================================== +*08.9* Tab pages + +You will have noticed that windows never overlap. That means you quickly run +out of screen space. The solution for this is called Tab pages. + +Assume you are editing "thisfile". To create a new tab page use this command: > + + :tabedit thatfile + +This will edit the file "thatfile" in a window that occupies the whole Vim +window. And you will notice a bar at the top with the two file names: + + +----------------------------------+ + | thisfile | /thatfile/ __________X| (thatfile is bold) + |/* thatfile */ | + |that | + |that | + |~ | + |~ | + |~ | + | | + +----------------------------------+ + +You now have two tab pages. The first one has a window for "thisfile" and the +second one a window for "thatfile". It's like two pages that are on top of +eachother, with a tab sticking out of each page showing the file name. + +Now use the mouse to click on "thisfile" in the top line. The result is + + +----------------------------------+ + | /thisfile/ | thatfile __________X| (thisfile is bold) + |/* thisfile */ | + |this | + |this | + |~ | + |~ | + |~ | + | | + +----------------------------------+ + +Thus you can switch between tab pages by clicking on the label in the top +line. If you don't have a mouse or don't want to use it, you can use the "gt" +command. Mnemonic: Goto Tab. + +Now let's create another tab page with the command: > + + :tab split + +This makes a new tab page with one window that is editing the same buffer as +the window we were in: + + +-------------------------------------+ + | thisfile | /thisfile/ | thatfile __X| (thisfile is bold) + |/* thisfile */ | + |this | + |this | + |~ | + |~ | + |~ | + | | + +-------------------------------------+ + +You can put ":tab" before any Ex command that opens a window. The window will +be opened in a new tab page. Another example: > + + :tab help gt + +Will show the help text for "gt" in a new tab page. + +A few more things you can do with tab pages: + +- click with the mouse in the space after the last label + The next tab page will be selected, like with "gt". + +- click with the mouse on the "X" in the top right corner + The current tab page will be closed. Unless there are unsaved + changes in the current tab page. + +- double click with the mouse in the top line + A new tab page will be created. + +- the "tabonly" command + Closes all tab pages except the current one. Unless there are unsaved + changes in other tab pages. + +For more information about tab pages see |tab-page|. + +============================================================================== + +Next chapter: |usr_09.txt| Using the GUI + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_09.txt b/share/vim/vim73/doc/usr_09.txt new file mode 100644 index 0000000000..fbc38656d8 --- /dev/null +++ b/share/vim/vim73/doc/usr_09.txt @@ -0,0 +1,289 @@ +*usr_09.txt* For Vim version 7.3. Last change: 2006 Apr 24 + + VIM USER MANUAL - by Bram Moolenaar + + Using the GUI + + +Vim works in an ordinary terminal. GVim can do the same things and a few +more. The GUI offers menus, a toolbar, scrollbars and other items. This +chapter is about these extra things that the GUI offers. + +|09.1| Parts of the GUI +|09.2| Using the mouse +|09.3| The clipboard +|09.4| Select mode + + Next chapter: |usr_10.txt| Making big changes + Previous chapter: |usr_08.txt| Splitting windows +Table of contents: |usr_toc.txt| + +============================================================================== +*09.1* Parts of the GUI + +You might have an icon on your desktop that starts gVim. Otherwise, one of +these commands should do it: > + + gvim file.txt + vim -g file.txt + +If this doesn't work you don't have a version of Vim with GUI support. You +will have to install one first. + Vim will open a window and display "file.txt" in it. What the window looks +like depends on the version of Vim. It should resemble the following picture +(for as far as this can be shown in ASCII!). + + +----------------------------------------------------+ + | file.txt + (~/dir) - VIM X | <- window title + +----------------------------------------------------+ + | File Edit Tools Syntax Buffers Window Help | <- menubar + +----------------------------------------------------+ + | aaa bbb ccc ddd eee fff ggg hhh iii jjj | <- toolbar + | aaa bbb ccc ddd eee fff ggg hhh iii jjj | + +----------------------------------------------------+ + | file text | ^ | + | ~ | # | + | ~ | # | <- scrollbar + | ~ | # | + | ~ | # | + | ~ | # | + | | V | + +----------------------------------------------------+ + +The largest space is occupied by the file text. This shows the file in the +same way as in a terminal. With some different colors and another font +perhaps. + + +THE WINDOW TITLE + +At the very top is the window title. This is drawn by your window system. +Vim will set the title to show the name of the current file. First comes the +name of the file. Then some special characters and the directory of the file +in parens. These special character can be present: + + - The file cannot be modified (e.g., a help file) + + The file contains changes + = The file is read-only + =+ The file is read-only, contains changes anyway + +If nothing is shown you have an ordinary, unchanged file. + + +THE MENUBAR + +You know how menus work, right? Vim has the usual items, plus a few more. +Browse them to get an idea of what you can use them for. A relevant submenu +is Edit/Global Settings. You will find these entries: + + Toggle Toolbar make the toolbar appear/disappear + Toggle Bottom Scrollbar make a scrollbar appear/disappear at the bottom + Toggle Left Scrollbar make a scrollbar appear/disappear at the left + Toggle Right Scrollbar make a scrollbar appear/disappear at the right + +On most systems you can tear-off the menus. Select the top item of the menu, +the one that looks like a dashed line. You will get a separate window with +the items of the menu. It will hang around until you close the window. + + +THE TOOLBAR + +This contains icons for the most often used actions. Hopefully the icons are +self-explanatory. There are tooltips to get an extra hint (move the mouse +pointer to the icon without clicking and don't move it for a second). + +The "Edit/Global Settings/Toggle Toolbar" menu item can be used to make the +toolbar disappear. If you never want a toolbar, use this command in your +vimrc file: > + + :set guioptions-=T + +This removes the 'T' flag from the 'guioptions' option. Other parts of the +GUI can also be enabled or disabled with this option. See the help for it. + + +THE SCROLLBARS + +By default there is one scrollbar on the right. It does the obvious thing. +When you split the window, each window will get its own scrollbar. + You can make a horizontal scrollbar appear with the menu item +Edit/Global Settings/Toggle Bottom Scrollbar. This is useful in diff mode, or +when the 'wrap' option has been reset (more about that later). + +When there are vertically split windows, only the windows on the right side +will have a scrollbar. However, when you move the cursor to a window on the +left, it will be this one the that scrollbar controls. This takes a bit of +time to get used to. + When you work with vertically split windows, consider adding a scrollbar on +the left. This can be done with a menu item, or with the 'guioptions' option: +> + :set guioptions+=l + +This adds the 'l' flag to 'guioptions'. + +============================================================================== +*09.2* Using the mouse + +Standards are wonderful. In Microsoft Windows, you can use the mouse to +select text in a standard manner. The X Window system also has a standard +system for using the mouse. Unfortunately, these two standards are not the +same. + Fortunately, you can customize Vim. You can make the behavior of the mouse +work like an X Window system mouse or a Microsoft Windows mouse. The following +command makes the mouse behave like an X Window mouse: > + + :behave xterm + +The following command makes the mouse work like a Microsoft Windows mouse: > + + :behave mswin + +The default behavior of the mouse on UNIX systems is xterm. The default +behavior on a Microsoft Windows system is selected during the installation +process. For details about what the two behaviors are, see |:behave|. Here +follows a summary. + + +XTERM MOUSE BEHAVIOR + +Left mouse click position the cursor +Left mouse drag select text in Visual mode +Middle mouse click paste text from the clipboard +Right mouse click extend the selected text until the mouse + pointer + + +MSWIN MOUSE BEHAVIOR + +Left mouse click position the cursor +Left mouse drag select text in Select mode (see |09.4|) +Left mouse click, with Shift extend the selected text until the mouse + pointer +Middle mouse click paste text from the clipboard +Right mouse click display a pop-up menu + + +The mouse can be further tuned. Check out these options if you want to change +the way how the mouse works: + + 'mouse' in which mode the mouse is used by Vim + 'mousemodel' what effect a mouse click has + 'mousetime' time between clicks for a double-click + 'mousehide' hide the mouse while typing + 'selectmode' whether the mouse starts Visual or Select mode + +============================================================================== +*09.3* The clipboard + +In section |04.7| the basic use of the clipboard was explained. There is one +essential thing to explain about X-windows: There are actually two places to +exchange text between programs. MS-Windows doesn't have this. + +In X-Windows there is the "current selection". This is the text that is +currently highlighted. In Vim this is the Visual area (this assumes you are +using the default option settings). You can paste this selection in another +application without any further action. + For example, in this text select a few words with the mouse. Vim will +switch to Visual mode and highlight the text. Now start another gVim, without +a file name argument, so that it displays an empty window. Click the middle +mouse button. The selected text will be inserted. + +The "current selection" will only remain valid until some other text is +selected. After doing the paste in the other gVim, now select some characters +in that window. You will notice that the words that were previously selected +in the other gVim window are displayed differently. This means that it no +longer is the current selection. + +You don't need to select text with the mouse, using the keyboard commands for +Visual mode works just as well. + + +THE REAL CLIPBOARD + +Now for the other place with which text can be exchanged. We call this the +"real clipboard", to avoid confusion. Often both the "current selection" and +the "real clipboard" are called clipboard, you'll have to get used to that. + To put text on the real clipboard, select a few different words in one of +the gVims you have running. Then use the Edit/Copy menu entry. Now the text +has been copied to the real clipboard. You can't see this, unless you have +some application that shows the clipboard contents (e.g., KDE's klipper). + Now select the other gVim, position the cursor somewhere and use the +Edit/Paste menu. You will see the text from the real clipboard is inserted. + + +USING BOTH + +This use of both the "current selection" and the "real clipboard" might sound +a bit confusing. But it is very useful. Let's show this with an example. +Use one gVim with a text file and perform these actions: + +- Select two words in Visual mode. +- Use the Edit/Copy menu to get these words onto the clipboard. +- Select one other word in Visual mode. +- Use the Edit/Paste menu item. What will happen is that the single selected + word is replaced with the two words from the clipboard. +- Move the mouse pointer somewhere else and click the middle button. You + will see that the word you just overwrote with the clipboard is inserted + here. + +If you use the "current selection" and the "real clipboard" with care, you can +do a lot of useful editing with them. + + +USING THE KEYBOARD + +If you don't like using the mouse, you can access the current selection and +the real clipboard with two registers. The "* register is for the current +selection. + To make text become the current selection, use Visual mode. For example, +to select a whole line just press "V". + To insert the current selection before the cursor: > + + "*P + +Notice the uppercase "P". The lowercase "p" puts the text after the cursor. + +The "+ register is used for the real clipboard. For example, to copy the text +from the cursor position until the end of the line to the clipboard: > + + "+y$ + +Remember, "y" is yank, which is Vim's copy command. + To insert the contents of the real clipboard before the cursor: > + + "+P + +It's the same as for the current selection, but uses the plus (+) register +instead of the star (*) register. + +============================================================================== +*09.4* Select mode + +And now something that is used more often on MS-Windows than on X-Windows. +But both can do it. You already know about Visual mode. Select mode is like +Visual mode, because it is also used to select text. But there is an obvious +difference: When typing text, the selected text is deleted and the typed text +replaces it. + +To start working with Select mode, you must first enable it (for MS-Windows +it is probably already enabled, but you can do this anyway): > + + :set selectmode+=mouse + +Now use the mouse to select some text. It is highlighted like in Visual mode. +Now press a letter. The selected text is deleted, and the single letter +replaces it. You are in Insert mode now, thus you can continue typing. + +Since typing normal text causes the selected text to be deleted, you can not +use the normal movement commands "hjkl", "w", etc. Instead, use the shifted +function keys. <S-Left> (shifted cursor left key) moves the cursor left. The +selected text is changed like in Visual mode. The other shifted cursor keys +do what you expect. <S-End> and <S-Home> also work. + +You can tune the way Select mode works with the 'selectmode' option. + +============================================================================== + +Next chapter: |usr_10.txt| Making big changes + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_10.txt b/share/vim/vim73/doc/usr_10.txt new file mode 100644 index 0000000000..9bf6a2212f --- /dev/null +++ b/share/vim/vim73/doc/usr_10.txt @@ -0,0 +1,824 @@ +*usr_10.txt* For Vim version 7.3. Last change: 2006 Nov 05 + + VIM USER MANUAL - by Bram Moolenaar + + Making big changes + + +In chapter 4 several ways to make small changes were explained. This chapter +goes into making changes that are repeated or can affect a large amount of +text. The Visual mode allows doing various things with blocks of text. Use +an external program to do really complicated things. + +|10.1| Record and playback commands +|10.2| Substitution +|10.3| Command ranges +|10.4| The global command +|10.5| Visual block mode +|10.6| Reading and writing part of a file +|10.7| Formatting text +|10.8| Changing case +|10.9| Using an external program + + Next chapter: |usr_11.txt| Recovering from a crash + Previous chapter: |usr_09.txt| Using the GUI +Table of contents: |usr_toc.txt| + +============================================================================== +*10.1* Record and playback commands + +The "." command repeats the preceding change. But what if you want to do +something more complex than a single change? That's where command recording +comes in. There are three steps: + +1. The "q{register}" command starts recording keystrokes into the register + named {register}. The register name must be between a and z. +2. Type your commands. +3. To finish recording, press q (without any extra character). + +You can now execute the macro by typing the command "@{register}". + +Take a look at how to use these commands in practice. You have a list of +filenames that look like this: + + stdio.h ~ + fcntl.h ~ + unistd.h ~ + stdlib.h ~ + +And what you want is the following: + + #include "stdio.h" ~ + #include "fcntl.h" ~ + #include "unistd.h" ~ + #include "stdlib.h" ~ + +You start by moving to the first character of the first line. Next you +execute the following commands: + + qa Start recording a macro in register a. + ^ Move to the beginning of the line. + i#include "<Esc> Insert the string #include " at the beginning + of the line. + $ Move to the end of the line. + a"<Esc> Append the character double quotation mark (") + to the end of the line. + j Go to the next line. + q Stop recording the macro. + +Now that you have done the work once, you can repeat the change by typing the +command "@a" three times. + The "@a" command can be preceded by a count, which will cause the macro to +be executed that number of times. In this case you would type: > + + 3@a + + +MOVE AND EXECUTE + +You might have the lines you want to change in various places. Just move the +cursor to each location and use the "@a" command. If you have done that once, +you can do it again with "@@". That's a bit easier to type. If you now +execute register b with "@b", the next "@@" will use register b. + If you compare the playback method with using ".", there are several +differences. First of all, "." can only repeat one change. As seen in the +example above, "@a" can do several changes, and move around as well. +Secondly, "." can only remember the last change. Executing a register allows +you to make any changes and then still use "@a" to replay the recorded +commands. Finally, you can use 26 different registers. Thus you can remember +26 different command sequences to execute. + + +USING REGISTERS + +The registers used for recording are the same ones you used for yank and +delete commands. This allows you to mix recording with other commands to +manipulate the registers. + Suppose you have recorded a few commands in register n. When you execute +this with "@n" you notice you did something wrong. You could try recording +again, but perhaps you will make another mistake. Instead, use this trick: + + G Go to the end of the file. + o<Esc> Create an empty line. + "np Put the text from the n register. You now see + the commands you typed as text in the file. + {edits} Change the commands that were wrong. This is + just like editing text. + 0 Go to the start of the line. + "ny$ Yank the corrected commands into the n + register. + dd Delete the scratch line. + +Now you can execute the corrected commands with "@n". (If your recorded +commands include line breaks, adjust the last two items in the example to +include all the lines.) + + +APPENDING TO A REGISTER + +So far we have used a lowercase letter for the register name. To append to a +register, use an uppercase letter. + Suppose you have recorded a command to change a word to register c. It +works properly, but you would like to add a search for the next word to +change. This can be done with: > + + qC/word<Enter>q + +You start with "qC", which records to the c register and appends. Thus +writing to an uppercase register name means to append to the register with +the same letter, but lowercase. + +This works both with recording and with yank and delete commands. For +example, you want to collect a sequence of lines into the a register. Yank +the first line with: > + + "aY + +Now move to the second line, and type: > + + "AY + +Repeat this command for all lines. The a register now contains all those +lines, in the order you yanked them. + +============================================================================== +*10.2* Substitution *find-replace* + +The ":substitute" command enables you to perform string replacements on a +whole range of lines. The general form of this command is as follows: > + + :[range]substitute/from/to/[flags] + +This command changes the "from" string to the "to" string in the lines +specified with [range]. For example, you can change "Professor" to "Teacher" +in all lines with the following command: > + + :%substitute/Professor/Teacher/ +< + Note: + The ":substitute" command is almost never spelled out completely. + Most of the time, people use the abbreviated version ":s". From here + on the abbreviation will be used. + +The "%" before the command specifies the command works on all lines. Without +a range, ":s" only works on the current line. More about ranges in the next +section |10.3|. + +By default, the ":substitute" command changes only the first occurrence on +each line. For example, the preceding command changes the line: + + Professor Smith criticized Professor Johnson today. ~ + +to: + + Teacher Smith criticized Professor Johnson today. ~ + +To change every occurrence on the line, you need to add the g (global) flag. +The command: > + + :%s/Professor/Teacher/g + +results in (starting with the original line): + + Teacher Smith criticized Teacher Johnson today. ~ + +Other flags include p (print), which causes the ":substitute" command to print +out the last line it changes. The c (confirm) flag tells ":substitute" to ask +you for confirmation before it performs each substitution. Enter the +following: > + + :%s/Professor/Teacher/c + +Vim finds the first occurrence of "Professor" and displays the text it is +about to change. You get the following prompt: > + + replace with Teacher (y/n/a/q/l/^E/^Y)? + +At this point, you must enter one of the following answers: + + y Yes; make this change. + n No; skip this match. + a All; make this change and all remaining ones without + further confirmation. + q Quit; don't make any more changes. + l Last; make this change and then quit. + CTRL-E Scroll the text one line up. + CTRL-Y Scroll the text one line down. + + +The "from" part of the substitute command is actually a pattern. The same +kind as used for the search command. For example, this command only +substitutes "the" when it appears at the start of a line: > + + :s/^the/these/ + +If you are substituting with a "from" or "to" part that includes a slash, you +need to put a backslash before it. A simpler way is to use another character +instead of the slash. A plus, for example: > + + :s+one/two+one or two+ + +============================================================================== +*10.3* Command ranges + +The ":substitute" command, and many other : commands, can be applied to a +selection of lines. This is called a range. + The simple form of a range is {number},{number}. For example: > + + :1,5s/this/that/g + +Executes the substitute command on the lines 1 to 5. Line 5 is included. +The range is always placed before the command. + +A single number can be used to address one specific line: > + + :54s/President/Fool/ + +Some commands work on the whole file when you do not specify a range. To make +them work on the current line the "." address is used. The ":write" command +works like that. Without a range, it writes the whole file. To make it write +only the current line into a file: > + + :.write otherfile + +The first line always has number one. How about the last line? The "$" +character is used for this. For example, to substitute in the lines from the +cursor to the end: > + + :.,$s/yes/no/ + +The "%" range that we used before, is actually a short way to say "1,$", from +the first to the last line. + + +USING A PATTERN IN A RANGE + +Suppose you are editing a chapter in a book, and want to replace all +occurrences of "grey" with "gray". But only in this chapter, not in the next +one. You know that only chapter boundaries have the word "Chapter" in the +first column. This command will work then: > + + :?^Chapter?,/^Chapter/s=grey=gray=g + +You can see a search pattern is used twice. The first "?^Chapter?" finds the +line above the current position that matches this pattern. Thus the ?pattern? +range is used to search backwards. Similarly, "/^Chapter/" is used to search +forward for the start of the next chapter. + To avoid confusion with the slashes, the "=" character was used in the +substitute command here. A slash or another character would have worked as +well. + + +ADD AND SUBTRACT + +There is a slight error in the above command: If the title of the next chapter +had included "grey" it would be replaced as well. Maybe that's what you +wanted, but what if you didn't? Then you can specify an offset. + To search for a pattern and then use the line above it: > + + /Chapter/-1 + +You can use any number instead of the 1. To address the second line below the +match: > + + /Chapter/+2 + +The offsets can also be used with the other items in a range. Look at this +one: > + + :.+3,$-5 + +This specifies the range that starts three lines below the cursor and ends +five lines before the last line in the file. + + +USING MARKS + +Instead of figuring out the line numbers of certain positions, remembering them +and typing them in a range, you can use marks. + Place the marks as mentioned in chapter 3. For example, use "mt" to mark +the top of an area and "mb" to mark the bottom. Then you can use this range +to specify the lines between the marks (including the lines with the marks): > + + :'t,'b + + +VISUAL MODE AND RANGES + +You can select text with Visual mode. If you then press ":" to start a colon +command, you will see this: > + + :'<,'> + +Now you can type the command and it will be applied to the range of lines that +was visually selected. + + Note: + When using Visual mode to select part of a line, or using CTRL-V to + select a block of text, the colon commands will still apply to whole + lines. This might change in a future version of Vim. + +The '< and '> are actually marks, placed at the start and end of the Visual +selection. The marks remain at their position until another Visual selection +is made. Thus you can use the "'<" command to jump to position where the +Visual area started. And you can mix the marks with other items: > + + :'>,$ + +This addresses the lines from the end of the Visual area to the end of the +file. + + +A NUMBER OF LINES + +When you know how many lines you want to change, you can type the number and +then ":". For example, when you type "5:", you will get: > + + :.,.+4 + +Now you can type the command you want to use. It will use the range "." +(current line) until ".+4" (four lines down). Thus it spans five lines. + +============================================================================== +*10.4* The global command + +The ":global" command is one of the more powerful features of Vim. It allows +you to find a match for a pattern and execute a command there. The general +form is: > + + :[range]global/{pattern}/{command} + +This is similar to the ":substitute" command. But, instead of replacing the +matched text with other text, the command {command} is executed. + + Note: + The command executed for ":global" must be one that starts with a + colon. Normal mode commands can not be used directly. The |:normal| + command can do this for you. + +Suppose you want to change "foobar" to "barfoo", but only in C++ style +comments. These comments start with "//". Use this command: > + + :g+//+s/foobar/barfoo/g + +This starts with ":g". That is short for ":global", just like ":s" is short +for ":substitute". Then the pattern, enclosed in plus characters. Since the +pattern we are looking for contains a slash, this uses the plus character to +separate the pattern. Next comes the substitute command that changes "foobar" +into "barfoo". + The default range for the global command is the whole file. Thus no range +was specified in this example. This is different from ":substitute", which +works on one line without a range. + The command isn't perfect, since it also matches lines where "//" appears +halfway a line, and the substitution will also take place before the "//". + +Just like with ":substitute", any pattern can be used. When you learn more +complicated patterns later, you can use them here. + +============================================================================== +*10.5* Visual block mode + +With CTRL-V you can start selection of a rectangular area of text. There are +a few commands that do something special with the text block. + +There is something special about using the "$" command in Visual block mode. +When the last motion command used was "$", all lines in the Visual selection +will extend until the end of the line, also when the line with the cursor is +shorter. This remains effective until you use a motion command that moves the +cursor horizontally. Thus using "j" keeps it, "h" stops it. + + +INSERTING TEXT + +The command "I{string}<Esc>" inserts the text {string} in each line, just +left of the visual block. You start by pressing CTRL-V to enter visual block +mode. Now you move the cursor to define your block. Next you type I to enter +Insert mode, followed by the text to insert. As you type, the text appears on +the first line only. + After you press <Esc> to end the insert, the text will magically be +inserted in the rest of the lines contained in the visual selection. Example: + + include one ~ + include two ~ + include three ~ + include four ~ + +Move the cursor to the "o" of "one" and press CTRL-V. Move it down with "3j" +to "four". You now have a block selection that spans four lines. Now type: > + + Imain.<Esc> + +The result: + + include main.one ~ + include main.two ~ + include main.three ~ + include main.four ~ + +If the block spans short lines that do not extend into the block, the text is +not inserted in that line. For example, make a Visual block selection that +includes the word "long" in the first and last line of this text, and thus has +no text selected in the second line: + + This is a long line ~ + short ~ + Any other long line ~ + + ^^^^ selected block + +Now use the command "Ivery <Esc>". The result is: + + This is a very long line ~ + short ~ + Any other very long line ~ + +In the short line no text was inserted. + +If the string you insert contains a newline, the "I" acts just like a Normal +insert command and affects only the first line of the block. + +The "A" command works the same way, except that it appends after the right +side of the block. And it does insert text in a short line. Thus you can +make a choice whether you do or don't want to append text to a short line. + There is one special case for "A": Select a Visual block and then use "$" +to make the block extend to the end of each line. Using "A" now will append +the text to the end of each line. + Using the same example from above, and then typing "$A XXX<Esc>, you get +this result: + + This is a long line XXX ~ + short XXX ~ + Any other long line XXX ~ + +This really requires using the "$" command. Vim remembers that it was used. +Making the same selection by moving the cursor to the end of the longest line +with other movement commands will not have the same result. + + +CHANGING TEXT + +The Visual block "c" command deletes the block and then throws you into Insert +mode to enable you to type in a string. The string will be inserted in each +line in the block. + Starting with the same selection of the "long" words as above, then typing +"c_LONG_<Esc>", you get this: + + This is a _LONG_ line ~ + short ~ + Any other _LONG_ line ~ + +Just like with "I" the short line is not changed. Also, you can't enter a +newline in the new text. + +The "C" command deletes text from the left edge of the block to the end of +line. It then puts you in Insert mode so that you can type in a string, +which is added to the end of each line. + Starting with the same text again, and typing "Cnew text<Esc>" you get: + + This is a new text ~ + short ~ + Any other new text ~ + +Notice that, even though only the "long" word was selected, the text after it +is deleted as well. Thus only the location of the left edge of the visual +block really matters. + Again, short lines that do not reach into the block are excluded. + +Other commands that change the characters in the block: + + ~ swap case (a -> A and A -> a) + U make uppercase (a -> A and A -> A) + u make lowercase (a -> a and A -> a) + + +FILLING WITH A CHARACTER + +To fill the whole block with one character, use the "r" command. Again, +starting with the same example text from above, and then typing "rx": + + This is a xxxx line ~ + short ~ + Any other xxxx line ~ + + + Note: + If you want to include characters beyond the end of the line in the + block, check out the 'virtualedit' feature in chapter 25. + + +SHIFTING + +The command ">" shifts the selected text to the right one shift amount, +inserting whitespace. The starting point for this shift is the left edge of +the visual block. + With the same example again, ">" gives this result: + + This is a long line ~ + short ~ + Any other long line ~ + +The shift amount is specified with the 'shiftwidth' option. To change it to +use 4 spaces: > + + :set shiftwidth=4 + +The "<" command removes one shift amount of whitespace at the left +edge of the block. This command is limited by the amount of text that is +there; so if there is less than a shift amount of whitespace available, it +removes what it can. + + +JOINING LINES + +The "J" command joins all selected lines together into one line. Thus it +removes the line breaks. Actually, the line break, leading white space and +trailing white space is replaced by one space. Two spaces are used after a +line ending (that can be changed with the 'joinspaces' option). + Let's use the example that we got so familiar with now. The result of +using the "J" command: + + This is a long line short Any other long line ~ + +The "J" command doesn't require a blockwise selection. It works with "v" and +"V" selection in exactly the same way. + +If you don't want the white space to be changed, use the "gJ" command. + +============================================================================== +*10.6* Reading and writing part of a file + +When you are writing an e-mail message, you may want to include another file. +This can be done with the ":read {filename}" command. The text of the file is +put below the cursor line. + Starting with this text: + + Hi John, ~ + Here is the diff that fixes the bug: ~ + Bye, Pierre. ~ + +Move the cursor to the second line and type: > + + :read patch + +The file named "patch" will be inserted, with this result: + + Hi John, ~ + Here is the diff that fixes the bug: ~ + 2c2 ~ + < for (i = 0; i <= length; ++i) ~ + --- ~ + > for (i = 0; i < length; ++i) ~ + Bye, Pierre. ~ + +The ":read" command accepts a range. The file will be put below the last line +number of this range. Thus ":$r patch" appends the file "patch" at the end of +the file. + What if you want to read the file above the first line? This can be done +with the line number zero. This line doesn't really exist, you will get an +error message when using it with most commands. But this command is allowed: +> + :0read patch + +The file "patch" will be put above the first line of the file. + + +WRITING A RANGE OF LINES + +To write a range of lines to a file, the ":write" command can be used. +Without a range it writes the whole file. With a range only the specified +lines are written: > + + :.,$write tempo + +This writes the lines from the cursor until the end of the file into the file +"tempo". If this file already exists you will get an error message. Vim +protects you from accidentally overwriting an existing file. If you know what +you are doing and want to overwrite the file, append !: > + + :.,$write! tempo + +CAREFUL: The ! must follow the ":write" command immediately, without white +space. Otherwise it becomes a filter command, which is explained later in +this chapter. + + +APPENDING TO A FILE + +In the first section of this chapter was explained how to collect a number of +lines into a register. The same can be done to collect lines in a file. +Write the first line with this command: > + + :.write collection + +Now move the cursor to the second line you want to collect, and type this: > + + :.write >>collection + +The ">>" tells Vim the "collection" file is not to be written as a new file, +but the line must be appended at the end. You can repeat this as many times +as you like. + +============================================================================== +*10.7* Formatting text + +When you are typing plain text, it's nice if the length of each line is +automatically trimmed to fit in the window. To make this happen while +inserting text, set the 'textwidth' option: > + + :set textwidth=72 + +You might remember that in the example vimrc file this command was used for +every text file. Thus if you are using that vimrc file, you were already +using it. To check the current value of 'textwidth': > + + :set textwidth + +Now lines will be broken to take only up to 72 characters. But when you +insert text halfway a line, or when you delete a few words, the lines will get +too long or too short. Vim doesn't automatically reformat the text. + To tell Vim to format the current paragraph: > + + gqap + +This starts with the "gq" command, which is an operator. Following is "ap", +the text object that stands for "a paragraph". A paragraph is separated from +the next paragraph by an empty line. + + Note: + A blank line, which contains white space, does NOT separate + paragraphs. This is hard to notice! + +Instead of "ap" you could use any motion or text object. If your paragraphs +are properly separated, you can use this command to format the whole file: > + + gggqG + +"gg" takes you to the first line, "gq" is the format operator and "G" the +motion that jumps to the last line. + +In case your paragraphs aren't clearly defined, you can format just the lines +you manually select. Move the cursor to the first line you want to format. +Start with the command "gqj". This formats the current line and the one below +it. If the first line was short, words from the next line will be appended. +If it was too long, words will be moved to the next line. The cursor moves to +the second line. Now you can use "." to repeat the command. Keep doing this +until you are at the end of the text you want to format. + +============================================================================== +*10.8* Changing case + +You have text with section headers in lowercase. You want to make the word +"section" all uppercase. Do this with the "gU" operator. Start with the +cursor in the first column: > + + gUw +< section header ----> SECTION header + +The "gu" operator does exactly the opposite: > + + guw +< SECTION header ----> section header + +You can also use "g~" to swap case. All these are operators, thus they work +with any motion command, with text objects and in Visual mode. + To make an operator work on lines you double it. The delete operator is +"d", thus to delete a line you use "dd". Similarly, "gugu" makes a whole line +lowercase. This can be shortened to "guu". "gUgU" is shortened to "gUU" and +"g~g~" to "g~~". Example: > + + g~~ +< Some GIRLS have Fun ----> sOME girls HAVE fUN ~ + +============================================================================== +*10.9* Using an external program + +Vim has a very powerful set of commands, it can do anything. But there may +still be something that an external command can do better or faster. + The command "!{motion}{program}" takes a block of text and filters it +through an external program. In other words, it runs the system command +represented by {program}, giving it the block of text represented by {motion} +as input. The output of this command then replaces the selected block. + Because this summarizes badly if you are unfamiliar with UNIX filters, take +a look at an example. The sort command sorts a file. If you execute the +following command, the unsorted file input.txt will be sorted and written to +output.txt. (This works on both UNIX and Microsoft Windows.) > + + sort <input.txt >output.txt + +Now do the same thing in Vim. You want to sort lines 1 through 5 of a file. +You start by putting the cursor on line 1. Next you execute the following +command: > + + !5G + +The "!" tells Vim that you are performing a filter operation. The Vim editor +expects a motion command to follow, indicating which part of the file to +filter. The "5G" command tells Vim to go to line 5, so it now knows that it +is to filter lines 1 (the current line) through 5. + In anticipation of the filtering, the cursor drops to the bottom of the +screen and a ! prompt displays. You can now type in the name of the filter +program, in this case "sort". Therefore, your full command is as follows: > + + !5Gsort<Enter> + +The result is that the sort program is run on the first 5 lines. The output +of the program replaces these lines. + + line 55 line 11 + line 33 line 22 + line 11 --> line 33 + line 22 line 44 + line 44 line 55 + last line last line + +The "!!" command filters the current line through a filter. In Unix the "date" +command prints the current time and date. "!!date<Enter>" replaces the current +line with the output of "date". This is useful to add a timestamp to a file. + + +WHEN IT DOESN'T WORK + +Starting a shell, sending it text and capturing the output requires that Vim +knows how the shell works exactly. When you have problems with filtering, +check the values of these options: + + 'shell' specifies the program that Vim uses to execute + external programs. + 'shellcmdflag' argument to pass a command to the shell + 'shellquote' quote to be used around the command + 'shellxquote' quote to be used around the command and redirection + 'shelltype' kind of shell (only for the Amiga) + 'shellslash' use forward slashes in the command (only for + MS-Windows and alikes) + 'shellredir' string used to write the command output into a file + +On Unix this is hardly ever a problem, because there are two kinds of shells: +"sh" like and "csh" like. Vim checks the 'shell' option and sets related +options automatically, depending on whether it sees "csh" somewhere in +'shell'. + On MS-Windows, however, there are many different shells and you might have +to tune the options to make filtering work. Check the help for the options +for more information. + + +READING COMMAND OUTPUT + +To read the contents of the current directory into the file, use this: + +on Unix: > + :read !ls +on MS-Windows: > + :read !dir + +The output of the "ls" or "dir" command is captured and inserted in the text, +below the cursor. This is similar to reading a file, except that the "!" is +used to tell Vim that a command follows. + The command may have arguments. And a range can be used to tell where Vim +should put the lines: > + + :0read !date -u + +This inserts the current time and date in UTC format at the top of the file. +(Well, if you have a date command that accepts the "-u" argument.) Note the +difference with using "!!date": that replaced a line, while ":read !date" will +insert a line. + + +WRITING TEXT TO A COMMAND + +The Unix command "wc" counts words. To count the words in the current file: > + + :write !wc + +This is the same write command as before, but instead of a file name the "!" +character is used and the name of an external command. The written text will +be passed to the specified command as its standard input. The output could +look like this: + + 4 47 249 ~ + +The "wc" command isn't verbose. This means you have 4 lines, 47 words and 249 +characters. + +Watch out for this mistake: > + + :write! wc + +This will write the file "wc" in the current directory, with force. White +space is important here! + + +REDRAWING THE SCREEN + +If the external command produced an error message, the display may have been +messed up. Vim is very efficient and only redraws those parts of the screen +that it knows need redrawing. But it can't know about what another program +has written. To tell Vim to redraw the screen: > + + CTRL-L + +============================================================================== + +Next chapter: |usr_11.txt| Recovering from a crash + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_11.txt b/share/vim/vim73/doc/usr_11.txt new file mode 100644 index 0000000000..fed950c349 --- /dev/null +++ b/share/vim/vim73/doc/usr_11.txt @@ -0,0 +1,307 @@ +*usr_11.txt* For Vim version 7.3. Last change: 2010 Jul 20 + + VIM USER MANUAL - by Bram Moolenaar + + Recovering from a crash + + +Did your computer crash? And you just spent hours editing? Don't panic! Vim +stores enough information to be able to restore most of your work. This +chapter shows you how to get your work back and explains how the swap file is +used. + +|11.1| Basic recovery +|11.2| Where is the swap file? +|11.3| Crashed or not? +|11.4| Further reading + + Next chapter: |usr_12.txt| Clever tricks + Previous chapter: |usr_10.txt| Making big changes +Table of contents: |usr_toc.txt| + +============================================================================== +*11.1* Basic recovery + +In most cases recovering a file is quite simple, assuming you know which file +you were editing (and the harddisk is still working). Start Vim on the file, +with the "-r" argument added: > + + vim -r help.txt + +Vim will read the swap file (used to store text you were editing) and may read +bits and pieces of the original file. If Vim recovered your changes you will +see these messages (with different file names, of course): + + Using swap file ".help.txt.swp" ~ + Original file "~/vim/runtime/doc/help.txt" ~ + Recovery completed. You should check if everything is OK. ~ + (You might want to write out this file under another name ~ + and run diff with the original file to check for changes) ~ + You may want to delete the .swp file now. ~ + +To be on the safe side, write this file under another name: > + + :write help.txt.recovered + +Compare the file with the original file to check if you ended up with what you +expected. Vimdiff is very useful for this |08.7|. For example: > + + :write help.txt.recovered + :edit # + :diffsp help.txt + +Watch out for the original file to contain a more recent version (you saved +the file just before the computer crashed). And check that no lines are +missing (something went wrong that Vim could not recover). + If Vim produces warning messages when recovering, read them carefully. +This is rare though. + +If the recovery resulted in text that is exactly the same as the file +contents, you will get this message: + + Using swap file ".help.txt.swp" ~ + Original file "~/vim/runtime/doc/help.txt" ~ + Recovery completed. Buffer contents equals file contents. ~ + You may want to delete the .swp file now. ~ + +This usually happens if you already recovered your changes, or you wrote the +file after making changes. It is safe to delete the swap file now. + +It is normal that the last few changes can not be recovered. Vim flushes the +changes to disk when you don't type for about four seconds, or after typing +about two hundred characters. This is set with the 'updatetime' and +'updatecount' options. Thus when Vim didn't get a chance to save itself when +the system went down, the changes after the last flush will be lost. + +If you were editing without a file name, give an empty string as argument: > + + vim -r "" + +You must be in the right directory, otherwise Vim can't find the swap file. + +============================================================================== +*11.2* Where is the swap file? + +Vim can store the swap file in several places. Normally it is in the same +directory as the original file. To find it, change to the directory of the +file, and use: > + + vim -r + +Vim will list the swap files that it can find. It will also look in other +directories where the swap file for files in the current directory may be +located. It will not find swap files in any other directories though, it +doesn't search the directory tree. + The output could look like this: + + Swap files found: ~ + In current directory: ~ + 1. .main.c.swp ~ + owned by: mool dated: Tue May 29 21:00:25 2001 ~ + file name: ~mool/vim/vim6/src/main.c ~ + modified: YES ~ + user name: mool host name: masaka.moolenaar.net ~ + process ID: 12525 ~ + In directory ~/tmp: ~ + -- none -- ~ + In directory /var/tmp: ~ + -- none -- ~ + In directory /tmp: ~ + -- none -- ~ + +If there are several swap files that look like they may be the one you want to +use, a list is given of these swap files and you are requested to enter the +number of the one you want to use. Carefully look at the dates to decide +which one you want to use. + In case you don't know which one to use, just try them one by one and check +the resulting files if they are what you expected. + + +USING A SPECIFIC SWAP FILE + +If you know which swap file needs to be used, you can recover by giving the +swap file name. Vim will then finds out the name of the original file from +the swap file. + +Example: > + vim -r .help.txt.swo + +This is also handy when the swap file is in another directory than expected. +Vim recognizes files with the pattern *.s[uvw][a-z] as swap files. + +If this still does not work, see what file names Vim reports and rename the +files accordingly. Check the 'directory' option to see where Vim may have +put the swap file. + + Note: + Vim tries to find the swap file by searching the directories in the + 'dir' option, looking for files that match "filename.sw?". If + wildcard expansion doesn't work (e.g., when the 'shell' option is + invalid), Vim does a desperate try to find the file "filename.swp". + If that fails too, you will have to give the name of the swapfile + itself to be able to recover the file. + +============================================================================== +*11.3* Crashed or not? *ATTENTION* *E325* + +Vim tries to protect you from doing stupid things. Suppose you innocently +start editing a file, expecting the contents of the file to show up. Instead, +Vim produces a very long message: + + E325: ATTENTION ~ + Found a swap file by the name ".main.c.swp" ~ + owned by: mool dated: Tue May 29 21:09:28 2001 ~ + file name: ~mool/vim/vim6/src/main.c ~ + modified: no ~ + user name: mool host name: masaka.moolenaar.net ~ + process ID: 12559 (still running) ~ + While opening file "main.c" ~ + dated: Tue May 29 19:46:12 2001 ~ + ~ + (1) Another program may be editing the same file. ~ + If this is the case, be careful not to end up with two ~ + different instances of the same file when making changes. ~ + Quit, or continue with caution. ~ + ~ + (2) An edit session for this file crashed. ~ + If this is the case, use ":recover" or "vim -r main.c" ~ + to recover the changes (see ":help recovery"). ~ + If you did this already, delete the swap file ".main.c.swp" ~ + to avoid this message. ~ + +You get this message, because, when starting to edit a file, Vim checks if a +swap file already exists for that file. If there is one, there must be +something wrong. It may be one of these two situations. + +1. Another edit session is active on this file. Look in the message for the + line with "process ID". It might look like this: + + process ID: 12559 (still running) ~ + + The text "(still running)" indicates that the process editing this file + runs on the same computer. When working on a non-Unix system you will not + get this extra hint. When editing a file over a network, you may not see + the hint, because the process might be running on another computer. In + those two cases you must find out what the situation is yourself. + If there is another Vim editing the same file, continuing to edit will + result in two versions of the same file. The one that is written last will + overwrite the other one, resulting in loss of changes. You better quit + this Vim. + +2. The swap file might be the result from a previous crash of Vim or the + computer. Check the dates mentioned in the message. If the date of the + swap file is newer than the file you were editing, and this line appears: + + modified: YES ~ + + Then you very likely have a crashed edit session that is worth recovering. + If the date of the file is newer than the date of the swap file, then + either it was changed after the crash (perhaps you recovered it earlier, + but didn't delete the swap file?), or else the file was saved before the + crash but after the last write of the swap file (then you're lucky: you + don't even need that old swap file). Vim will warn you for this with this + extra line: + + NEWER than swap file! ~ + + +UNREADABLE SWAP FILE + +Sometimes the line + + [cannot be read] ~ + +will appear under the name of the swap file. This can be good or bad, +depending on circumstances. + +It is good if a previous editing session crashed without having made any +changes to the file. Then a directory listing of the swap file will show +that it has zero bytes. You may delete it and proceed. + +It is slightly bad if you don't have read permission for the swap file. You +may want to view the file read-only, or quit. On multi-user systems, if you +yourself did the last changes under a different login name, a logout +followed by a login under that other name might cure the "read error". Or +else you might want to find out who last edited (or is editing) the file and +have a talk with them. + +It is very bad if it means there is a physical read error on the disk +containing the swap file. Fortunately, this almost never happens. +You may want to view the file read-only at first (if you can), to see the +extent of the changes that were "forgotten". If you are the one in charge of +that file, be prepared to redo your last changes. + + +WHAT TO DO? *swap-exists-choices* + +If dialogs are supported you will be asked to select one of five choices: + + Swap file ".main.c.swp" already exists! ~ + [O]pen Read-Only, (E)dit anyway, (R)ecover, (Q)uit, (A)bort, (D)elete it: ~ + +O Open the file readonly. Use this when you just want to view the file and + don't need to recover it. You might want to use this when you know someone + else is editing the file, but you just want to look in it and not make + changes. + +E Edit the file anyway. Use this with caution! If the file is being edited + in another Vim, you might end up with two versions of the file. Vim will + try to warn you when this happens, but better be safe then sorry. + +R Recover the file from the swap file. Use this if you know that the swap + file contains changes that you want to recover. + +Q Quit. This avoids starting to edit the file. Use this if there is another + Vim editing the same file. + When you just started Vim, this will exit Vim. When starting Vim with + files in several windows, Vim quits only if there is a swap file for the + first one. When using an edit command, the file will not be loaded and you + are taken back to the previously edited file. + +A Abort. Like Quit, but also abort further commands. This is useful when + loading a script that edits several files, such as a session with multiple + windows. + +D Delete the swap file. Use this when you are sure you no longer need it. + For example, when it doesn't contain changes, or when the file itself is + newer than the swap file. + On Unix this choice is only offered when the process that created the + swap file does not appear to be running. + +If you do not get the dialog (you are running a version of Vim that does not +support it), you will have to do it manually. To recover the file, use this +command: > + + :recover + + +Vim cannot always detect that a swap file already exists for a file. This is +the case when the other edit session puts the swap files in another directory +or when the path name for the file is different when editing it on different +machines. Therefore, don't rely on Vim always warning you. + +If you really don't want to see this message, you can add the 'A' flag to the +'shortmess' option. But it's very unusual that you need this. + +For remarks about encryption and the swap file, see |:recover-crypt|. + +============================================================================== +*11.4* Further reading + +|swap-file| An explanation about where the swap file will be created and + what its name is. +|:preserve| Manually flushing the swap file to disk. +|:swapname| See the name of the swap file for the current file. +'updatecount' Number of key strokes after which the swap file is flushed to + disk. +'updatetime' Timeout after which the swap file is flushed to disk. +'swapsync' Whether the disk is synced when the swap file is flushed. +'directory' List of directory names where to store the swap file. +'maxmem' Limit for memory usage before writing text to the swap file. +'maxmemtot' Same, but for all files in total. + +============================================================================== + +Next chapter: |usr_12.txt| Clever tricks + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_12.txt b/share/vim/vim73/doc/usr_12.txt new file mode 100644 index 0000000000..5dda76aa3b --- /dev/null +++ b/share/vim/vim73/doc/usr_12.txt @@ -0,0 +1,358 @@ +*usr_12.txt* For Vim version 7.3. Last change: 2007 May 11 + + VIM USER MANUAL - by Bram Moolenaar + + Clever tricks + + +By combining several commands you can make Vim do nearly everything. In this +chapter a number of useful combinations will be presented. This uses the +commands introduced in the previous chapters and a few more. + +|12.1| Replace a word +|12.2| Change "Last, First" to "First Last" +|12.3| Sort a list +|12.4| Reverse line order +|12.5| Count words +|12.6| Find a man page +|12.7| Trim blanks +|12.8| Find where a word is used + + Next chapter: |usr_20.txt| Typing command-line commands quickly + Previous chapter: |usr_11.txt| Recovering from a crash +Table of contents: |usr_toc.txt| + +============================================================================== +*12.1* Replace a word + +The substitute command can be used to replace all occurrences of a word with +another word: > + + :%s/four/4/g + +The "%" range means to replace in all lines. The "g" flag at the end causes +all words in a line to be replaced. + This will not do the right thing if your file also contains "thirtyfour". +It would be replaced with "thirty4". To avoid this, use the "\<" item to +match the start of a word: > + + :%s/\<four/4/g + +Obviously, this still goes wrong on "fourteen". Use "\>" to match the end of +a word: > + + :%s/\<four\>/4/g + +If you are programming, you might want to replace "four" in comments, but not +in the code. Since this is difficult to specify, add the "c" flag to have the +substitute command prompt you for each replacement: > + + + :%s/\<four\>/4/gc + + +REPLACING IN SEVERAL FILES + +Suppose you want to replace a word in more than one file. You could edit each +file and type the command manually. It's a lot faster to use record and +playback. + Let's assume you have a directory with C++ files, all ending in ".cpp". +There is a function called "GetResp" that you want to rename to "GetAnswer". + + vim *.cpp Start Vim, defining the argument list to + contain all the C++ files. You are now in the + first file. + qq Start recording into the q register + :%s/\<GetResp\>/GetAnswer/g + Do the replacements in the first file. + :wnext Write this file and move to the next one. + q Stop recording. + @q Execute the q register. This will replay the + substitution and ":wnext". You can verify + that this doesn't produce an error message. + 999@q Execute the q register on the remaining files. + +At the last file you will get an error message, because ":wnext" cannot move +to the next file. This stops the execution, and everything is done. + + Note: + When playing back a recorded sequence, an error stops the execution. + Therefore, make sure you don't get an error message when recording. + +There is one catch: If one of the .cpp files does not contain the word +"GetResp", you will get an error and replacing will stop. To avoid this, add +the "e" flag to the substitute command: > + + :%s/\<GetResp\>/GetAnswer/ge + +The "e" flag tells ":substitute" that not finding a match is not an error. + +============================================================================== +*12.2* Change "Last, First" to "First Last" + +You have a list of names in this form: + + Doe, John ~ + Smith, Peter ~ + +You want to change that to: + + John Doe ~ + Peter Smith ~ + +This can be done with just one command: > + + :%s/\([^,]*\), \(.*\)/\2 \1/ + +Let's break this down in parts. Obviously it starts with a substitute +command. The "%" is the line range, which stands for the whole file. Thus +the substitution is done in every line in the file. + The arguments for the substitute command are "/from/to/". The slashes +separate the "from" pattern and the "to" string. This is what the "from" +pattern contains: + \([^,]*\), \(.*\) ~ + + The first part between \( \) matches "Last" \( \) + match anything but a comma [^,] + any number of times * + matches ", " literally , + The second part between \( \) matches "First" \( \) + any character . + any number of times * + +In the "to" part we have "\2" and "\1". These are called backreferences. +They refer to the text matched by the "\( \)" parts in the pattern. "\2" +refers to the text matched by the second "\( \)", which is the "First" name. +"\1" refers to the first "\( \)", which is the "Last" name. + You can use up to nine backreferences in the "to" part of a substitute +command. "\0" stands for the whole matched pattern. There are a few more +special items in a substitute command, see |sub-replace-special|. + +============================================================================== +*12.3* Sort a list + +In a Makefile you often have a list of files. For example: + + OBJS = \ ~ + version.o \ ~ + pch.o \ ~ + getopt.o \ ~ + util.o \ ~ + getopt1.o \ ~ + inp.o \ ~ + patch.o \ ~ + backup.o ~ + +To sort this list, filter the text through the external sort command: > + + /^OBJS + j + :.,/^$/-1!sort + +This goes to the first line, where "OBJS" is the first thing in the line. +Then it goes one line down and filters the lines until the next empty line. +You could also select the lines in Visual mode and then use "!sort". That's +easier to type, but more work when there are many lines. + The result is this: + + OBJS = \ ~ + backup.o ~ + getopt.o \ ~ + getopt1.o \ ~ + inp.o \ ~ + patch.o \ ~ + pch.o \ ~ + util.o \ ~ + version.o \ ~ + + +Notice that a backslash at the end of each line is used to indicate the line +continues. After sorting, this is wrong! The "backup.o" line that was at +the end didn't have a backslash. Now that it sorts to another place, it +must have a backslash. + The simplest solution is to add the backslash with "A \<Esc>". You can +keep the backslash in the last line, if you make sure an empty line comes +after it. That way you don't have this problem again. + +============================================================================== +*12.4* Reverse line order + +The |:global| command can be combined with the |:move| command to move all the +lines before the first line, resulting in a reversed file. The command is: > + + :global/^/m 0 + +Abbreviated: > + + :g/^/m 0 + +The "^" regular expression matches the beginning of the line (even if the line +is blank). The |:move| command moves the matching line to after the mythical +zeroth line, so the current matching line becomes the first line of the file. +As the |:global| command is not confused by the changing line numbering, +|:global| proceeds to match all remaining lines of the file and puts each as +the first. + +This also works on a range of lines. First move to above the first line and +mark it with "mt". Then move the cursor to the last line in the range and +type: > + + :'t+1,.g/^/m 't + +============================================================================== +*12.5* Count words + +Sometimes you have to write a text with a maximum number of words. Vim can +count the words for you. + When the whole file is what you want to count the words in, use this +command: > + + g CTRL-G + +Do not type a space after the g, this is just used here to make the command +easy to read. + The output looks like this: + + Col 1 of 0; Line 141 of 157; Word 748 of 774; Byte 4489 of 4976 ~ + +You can see on which word you are (748), and the total number of words in the +file (774). + +When the text is only part of a file, you could move to the start of the text, +type "g CTRL-G", move to the end of the text, type "g CTRL-G" again, and then +use your brain to compute the difference in the word position. That's a good +exercise, but there is an easier way. With Visual mode, select the text you +want to count words in. Then type g CTRL-G. The result: + + Selected 5 of 293 Lines; 70 of 1884 Words; 359 of 10928 Bytes ~ + +For other ways to count words, lines and other items, see |count-items|. + +============================================================================== +*12.6* Find a man page *find-manpage* + +While editing a shell script or C program, you are using a command or function +that you want to find the man page for (this is on Unix). Let's first use a +simple way: Move the cursor to the word you want to find help on and press > + + K + +Vim will run the external "man" program on the word. If the man page is +found, it is displayed. This uses the normal pager to scroll through the text +(mostly the "more" program). When you get to the end pressing <Enter> will +get you back into Vim. + +A disadvantage is that you can't see the man page and the text you are working +on at the same time. There is a trick to make the man page appear in a Vim +window. First, load the man filetype plugin: > + + :runtime! ftplugin/man.vim + +Put this command in your vimrc file if you intend to do this often. Now you +can use the ":Man" command to open a window on a man page: > + + :Man csh + +You can scroll around and the text is highlighted. This allows you to find +the help you were looking for. Use CTRL-W w to jump to the window with the +text you were working on. + To find a man page in a specific section, put the section number first. +For example, to look in section 3 for "echo": > + + :Man 3 echo + +To jump to another man page, which is in the text with the typical form +"word(1)", press CTRL-] on it. Further ":Man" commands will use the same +window. + +To display a man page for the word under the cursor, use this: > + + \K + +(If you redefined the <Leader>, use it instead of the backslash). +For example, you want to know the return value of "strstr()" while editing +this line: + + if ( strstr (input, "aap") == ) ~ + +Move the cursor to somewhere on "strstr" and type "\K". A window will open +to display the man page for strstr(). + +============================================================================== +*12.7* Trim blanks + +Some people find spaces and tabs at the end of a line useless, wasteful, and +ugly. To remove whitespace at the end of every line, execute the following +command: > + + :%s/\s\+$// + +The line range "%" is used, thus this works on the whole file. The pattern +that the ":substitute" command matches with is "\s\+$". This finds white +space characters (\s), 1 or more of them (\+), before the end-of-line ($). +Later will be explained how you write patterns like this |usr_27.txt|. + The "to" part of the substitute command is empty: "//". Thus it replaces +with nothing, effectively deleting the matched white space. + +Another wasteful use of spaces is placing them before a tab. Often these can +be deleted without changing the amount of white space. But not always! +Therefore, you can best do this manually. Use this search command: > + + / + +You cannot see it, but there is a space before a tab in this command. Thus +it's "/<Space><Tab>". Now use "x" to delete the space and check that the +amount of white space doesn't change. You might have to insert a tab if it +does change. Type "n" to find the next match. Repeat this until no more +matches can be found. + +============================================================================== +*12.8* Find where a word is used + +If you are a UNIX user, you can use a combination of Vim and the grep command +to edit all the files that contain a given word. This is extremely useful if +you are working on a program and want to view or edit all the files that +contain a specific variable. + For example, suppose you want to edit all the C program files that contain +the word "frame_counter". To do this you use the command: > + + vim `grep -l frame_counter *.c` + +Let's look at this command in detail. The grep command searches through a set +of files for a given word. Because the -l argument is specified, the command +will only list the files containing the word and not print the matching lines. +The word it is searching for is "frame_counter". Actually, this can be any +regular expression. (Note: What grep uses for regular expressions is not +exactly the same as what Vim uses.) + The entire command is enclosed in backticks (`). This tells the UNIX shell +to run this command and pretend that the results were typed on the command +line. So what happens is that the grep command is run and produces a list of +files, these files are put on the Vim command line. This results in Vim +editing the file list that is the output of grep. You can then use commands +like ":next" and ":first" to browse through the files. + + +FINDING EACH LINE + +The above command only finds the files in which the word is found. You still +have to find the word within the files. + Vim has a built-in command that you can use to search a set of files for a +given string. If you want to find all occurrences of "error_string" in all C +program files, for example, enter the following command: > + + :grep error_string *.c + +This causes Vim to search for the string "error_string" in all the specified +files (*.c). The editor will now open the first file where a match is found +and position the cursor on the first matching line. To go to the next +matching line (no matter in what file it is), use the ":cnext" command. To go +to the previous match, use the ":cprev" command. Use ":clist" to see all the +matches and where they are. + The ":grep" command uses the external commands grep (on Unix) or findstr +(on Windows). You can change this by setting the option 'grepprg'. + +============================================================================== + +Next chapter: |usr_20.txt| Typing command-line commands quickly + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_20.txt b/share/vim/vim73/doc/usr_20.txt new file mode 100644 index 0000000000..2b5393a95e --- /dev/null +++ b/share/vim/vim73/doc/usr_20.txt @@ -0,0 +1,384 @@ +*usr_20.txt* For Vim version 7.3. Last change: 2006 Apr 24 + + VIM USER MANUAL - by Bram Moolenaar + + Typing command-line commands quickly + + +Vim has a few generic features that makes it easier to enter commands. Colon +commands can be abbreviated, edited and repeated. Completion is available for +nearly everything. + +|20.1| Command line editing +|20.2| Command line abbreviations +|20.3| Command line completion +|20.4| Command line history +|20.5| Command line window + + Next chapter: |usr_21.txt| Go away and come back + Previous chapter: |usr_12.txt| Clever tricks +Table of contents: |usr_toc.txt| + +============================================================================== +*20.1* Command line editing + +When you use a colon (:) command or search for a string with / or ?, Vim puts +the cursor on the bottom of the screen. There you type the command or search +pattern. This is called the Command line. Also when it's used for entering a +search command. + +The most obvious way to edit the command you type is by pressing the <BS> key. +This erases the character before the cursor. To erase another character, +typed earlier, first move the cursor with the cursor keys. + For example, you have typed this: > + + :s/col/pig/ + +Before you hit <Enter>, you notice that "col" should be "cow". To correct +this, you type <Left> five times. The cursor is now just after "col". Type +<BS> and "w" to correct: > + + :s/cow/pig/ + +Now you can press <Enter> directly. You don't have to move the cursor to the +end of the line before executing the command. + +The most often used keys to move around in the command line: + + <Left> one character left + <Right> one character right + <S-Left> or <C-Left> one word left + <S-Right> or <C-Right> one word right + CTRL-B or <Home> to begin of command line + CTRL-E or <End> to end of command line + + Note: + <S-Left> (cursor left key with Shift key pressed) and <C-Left> (cursor + left key with Control pressed) will not work on all keyboards. Same + for the other Shift and Control combinations. + +You can also use the mouse to move the cursor. + + +DELETING + +As mentioned, <BS> deletes the character before the cursor. To delete a whole +word use CTRL-W. + + /the fine pig ~ + + CTRL-W + + /the fine ~ + +CTRL-U removes all text, thus allows you to start all over again. + + +OVERSTRIKE + +The <Insert> key toggles between inserting characters and replacing the +existing ones. Start with this text: + + /the fine pig ~ + +Move the cursor to the start of "fine" with <S-Left> twice (or <Left> eight +times, if <S-Left> doesn't work). Now press <Insert> to switch to overstrike +and type "great": + + /the greatpig ~ + +Oops, we lost the space. Now, don't use <BS>, because it would delete the +"t" (this is different from Replace mode). Instead, press <Insert> to switch +from overstrike to inserting, and type the space: + + /the great pig ~ + + +CANCELLING + +You thought of executing a : or / command, but changed your mind. To get rid +of what you already typed, without executing it, press CTRL-C or <Esc>. + + Note: + <Esc> is the universal "get out" key. Unfortunately, in the good old + Vi pressing <Esc> in a command line executed the command! Since that + might be considered to be a bug, Vim uses <Esc> to cancel the command. + But with the 'cpoptions' option it can be made Vi compatible. And + when using a mapping (which might be written for Vi) <Esc> also works + Vi compatible. Therefore, using CTRL-C is a method that always works. + +If you are at the start of the command line, pressing <BS> will cancel the +command. It's like deleting the ":" or "/" that the line starts with. + +============================================================================== +*20.2* Command line abbreviations + +Some of the ":" commands are really long. We already mentioned that +":substitute" can be abbreviated to ":s". This is a generic mechanism, all +":" commands can be abbreviated. + +How short can a command get? There are 26 letters, and many more commands. +For example, ":set" also starts with ":s", but ":s" doesn't start a ":set" +command. Instead ":set" can be abbreviated to ":se". + When the shorter form of a command could be used for two commands, it +stands for only one of them. There is no logic behind which one, you have to +learn them. In the help files the shortest form that works is mentioned. For +example: > + + :s[ubstitute] + +This means that the shortest form of ":substitute" is ":s". The following +characters are optional. Thus ":su" and ":sub" also work. + +In the user manual we will either use the full name of command, or a short +version that is still readable. For example, ":function" can be abbreviated +to ":fu". But since most people don't understand what that stands for, we +will use ":fun". (Vim doesn't have a ":funny" command, otherwise ":fun" would +be confusing too.) + +It is recommended that in Vim scripts you write the full command name. That +makes it easier to read back when you make later changes. Except for some +often used commands like ":w" (":write") and ":r" (":read"). + A particularly confusing one is ":end", which could stand for ":endif", +":endwhile" or ":endfunction". Therefore, always use the full name. + + +SHORT OPTION NAMES + +In the user manual the long version of the option names is used. Many options +also have a short name. Unlike ":" commands, there is only one short name +that works. For example, the short name of 'autoindent' is 'ai'. Thus these +two commands do the same thing: > + + :set autoindent + :set ai + +You can find the full list of long and short names here: |option-list|. + +============================================================================== +*20.3* Command line completion + +This is one of those Vim features that, by itself, is a reason to switch from +Vi to Vim. Once you have used this, you can't do without. + +Suppose you have a directory that contains these files: + + info.txt + intro.txt + bodyofthepaper.txt + +To edit the last one, you use the command: > + + :edit bodyofthepaper.txt + +It's easy to type this wrong. A much quicker way is: > + + :edit b<Tab> + +Which will result in the same command. What happened? The <Tab> key does +completion of the word before the cursor. In this case "b". Vim looks in the +directory and finds only one file that starts with a "b". That must be the +one you are looking for, thus Vim completes the file name for you. + +Now type: > + + :edit i<Tab> + +Vim will beep, and give you: > + + :edit info.txt + +The beep means that Vim has found more than one match. It then uses the first +match it found (alphabetically). If you press <Tab> again, you get: > + + :edit intro.txt + +Thus, if the first <Tab> doesn't give you the file you were looking for, press +it again. If there are more matches, you will see them all, one at a time. + If you press <Tab> on the last matching entry, you will go back to what you +first typed: > + + :edit i + +Then it starts all over again. Thus Vim cycles through the list of matches. +Use CTRL-P to go through the list in the other direction: + + <------------------- <Tab> -------------------------+ + | + <Tab> --> <Tab> --> + :edit i :edit info.txt :edit intro.txt + <-- CTRL-P <-- CTRL-P + | + +---------------------- CTRL-P ------------------------> + + +CONTEXT + +When you type ":set i" instead of ":edit i" and press <Tab> you get: > + + :set icon + +Hey, why didn't you get ":set info.txt"? That's because Vim has context +sensitive completion. The kind of words Vim will look for depends on the +command before it. Vim knows that you cannot use a file name just after a +":set" command, but you can use an option name. + Again, if you repeat typing the <Tab>, Vim will cycle through all matches. +There are quite a few, it's better to type more characters first: > + + :set isk<Tab> + +Gives: > + + :set iskeyword + +Now type "=" and press <Tab>: > + + :set iskeyword=@,48-57,_,192-255 + +What happens here is that Vim inserts the old value of the option. Now you +can edit it. + What is completed with <Tab> is what Vim expects in that place. Just try +it out to see how it works. In some situations you will not get what you +want. That's either because Vim doesn't know what you want, or because +completion was not implemented for that situation. In that case you will get +a <Tab> inserted (displayed as ^I). + + +LIST MATCHES + +When there are many matches, you would like to see an overview. Do this by +pressing CTRL-D. For example, pressing CTRL-D after: > + + :set is + +results in: > + + :set is + incsearch isfname isident iskeyword isprint + :set is + +Vim lists the matches and then comes back with the text you typed. You can +now check the list for the item you wanted. If it isn't there, you can use +<BS> to correct the word. If there are many matches, type a few more +characters before pressing <Tab> to complete the rest. + If you have watched carefully, you will have noticed that "incsearch" +doesn't start with "is". In this case "is" stands for the short name of +"incsearch". (Many options have a short and a long name.) Vim is clever +enough to know that you might have wanted to expand the short name of the +option into the long name. + + +THERE IS MORE + +The CTRL-L command completes the word to the longest unambiguous string. If +you type ":edit i" and there are files "info.txt" and "info_backup.txt" you +will get ":edit info". + +The 'wildmode' option can be used to change the way completion works. +The 'wildmenu' option can be used to get a menu-like list of matches. +Use the 'suffixes' option to specify files that are less important and appear +at the end of the list of files. +The 'wildignore' option specifies files that are not listed at all. + +More about all of this here: |cmdline-completion| + +============================================================================== +*20.4* Command line history + +In chapter 3 we briefly mentioned the history. The basics are that you can +use the <Up> key to recall an older command line. <Down> then takes you back +to newer commands. + +There are actually four histories. The ones we will mention here are for ":" +commands and for "/" and "?" search commands. The "/" and "?" commands share +the same history, because they are both search commands. The two other +histories are for expressions and input lines for the input() function. +|cmdline-history| + +Suppose you have done a ":set" command, typed ten more colon commands and then +want to repeat that ":set" command again. You could press ":" and then ten +times <Up>. There is a quicker way: > + + :se<Up> + +Vim will now go back to the previous command that started with "se". You have +a good chance that this is the ":set" command you were looking for. At least +you should not have to press <Up> very often (unless ":set" commands is all +you have done). + +The <Up> key will use the text typed so far and compare it with the lines in +the history. Only matching lines will be used. + If you do not find the line you were looking for, use <Down> to go back to +what you typed and correct that. Or use CTRL-U to start all over again. + +To see all the lines in the history: > + + :history + +That's the history of ":" commands. The search history is displayed with this +command: > + + :history / + +CTRL-P will work like <Up>, except that it doesn't matter what you already +typed. Similarly for CTRL-N and <Down>. CTRL-P stands for previous, CTRL-N +for next. + +============================================================================== +*20.5* Command line window + +Typing the text in the command line works different from typing text in Insert +mode. It doesn't allow many commands to change the text. For most commands +that's OK, but sometimes you have to type a complicated command. That's where +the command line window is useful. + +Open the command line window with this command: > + + q: + +Vim now opens a (small) window at the bottom. It contains the command line +history, and an empty line at the end: + + +-------------------------------------+ + |other window | + |~ | + |file.txt=============================| + |:e c | + |:e config.h.in | + |:set path=.,/usr/include,, | + |:set iskeyword=@,48-57,_,192-255 | + |:set is | + |:q | + |: | + |command-line=========================| + | | + +-------------------------------------+ + +You are now in Normal mode. You can use the "hjkl" keys to move around. For +example, move up with "5k" to the ":e config.h.in" line. Type "$h" to go to +the "i" of "in" and type "cwout". Now you have changed the line to: + + :e config.h.out ~ + +Now press <Enter> and this command will be executed. The command line window +will close. + The <Enter> command will execute the line under the cursor. It doesn't +matter whether Vim is in Insert mode or in Normal mode. + Changes in the command line window are lost. They do not result in the +history to be changed. Except that the command you execute will be added to +the end of the history, like with all executed commands. + +The command line window is very useful when you want to have overview of the +history, lookup a similar command, change it a bit and execute it. A search +command can be used to find something. + In the previous example the "?config" search command could have been used +to find the previous command that contains "config". It's a bit strange, +because you are using a command line to search in the command line window. +While typing that search command you can't open another command line window, +there can be only one. + +============================================================================== + +Next chapter: |usr_21.txt| Go away and come back + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_21.txt b/share/vim/vim73/doc/usr_21.txt new file mode 100644 index 0000000000..a49c98c2b2 --- /dev/null +++ b/share/vim/vim73/doc/usr_21.txt @@ -0,0 +1,499 @@ +*usr_21.txt* For Vim version 7.3. Last change: 2008 Nov 09 + + VIM USER MANUAL - by Bram Moolenaar + + Go away and come back + + +This chapter goes into mixing the use of other programs with Vim. Either by +executing program from inside Vim or by leaving Vim and coming back later. +Furthermore, this is about the ways to remember the state of Vim and restore +it later. + +|21.1| Suspend and resume +|21.2| Executing shell commands +|21.3| Remembering information; viminfo +|21.4| Sessions +|21.5| Views +|21.6| Modelines + + Next chapter: |usr_22.txt| Finding the file to edit + Previous chapter: |usr_20.txt| Typing command-line commands quickly +Table of contents: |usr_toc.txt| + +============================================================================== +*21.1* Suspend and resume + +Like most Unix programs Vim can be suspended by pressing CTRL-Z. This stops +Vim and takes you back to the shell it was started in. You can then do any +other commands until you are bored with them. Then bring back Vim with the +"fg" command. > + + CTRL-Z + {any sequence of shell commands} + fg + +You are right back where you left Vim, nothing has changed. + In case pressing CTRL-Z doesn't work, you can also use ":suspend". +Don't forget to bring Vim back to the foreground, you would lose any changes +that you made! + +Only Unix has support for this. On other systems Vim will start a shell for +you. This also has the functionality of being able to execute shell commands. +But it's a new shell, not the one that you started Vim from. + When you are running the GUI you can't go back to the shell where Vim was +started. CTRL-Z will minimize the Vim window instead. + +============================================================================== +*21.2* Executing shell commands + +To execute a single shell command from Vim use ":!{command}". For example, to +see a directory listing: > + + :!ls + :!dir + +The first one is for Unix, the second one for MS-Windows. + Vim will execute the program. When it ends you will get a prompt to hit +<Enter>. This allows you to have a look at the output from the command before +returning to the text you were editing. + The "!" is also used in other places where a program is run. Let's take +a look at an overview: + + :!{program} execute {program} + :r !{program} execute {program} and read its output + :w !{program} execute {program} and send text to its input + :[range]!{program} filter text through {program} + +Notice that the presence of a range before "!{program}" makes a big +difference. Without it executes the program normally, with the range a number +of text lines is filtered through the program. + +Executing a whole row of programs this way is possible. But a shell is much +better at it. You can start a new shell this way: > + + :shell + +This is similar to using CTRL-Z to suspend Vim. The difference is that a new +shell is started. + +When using the GUI the shell will be using the Vim window for its input and +output. Since Vim is not a terminal emulator, this will not work perfectly. +If you have trouble, try toggling the 'guipty' option. If this still doesn't +work well enough, start a new terminal to run the shell in. For example with: +> + :!xterm& + +============================================================================== +*21.3* Remembering information; viminfo + +After editing for a while you will have text in registers, marks in various +files, a command line history filled with carefully crafted commands. When +you exit Vim all of this is lost. But you can get it back! + +The viminfo file is designed to store status information: + + Command-line and Search pattern history + Text in registers + Marks for various files + The buffer list + Global variables + +Each time you exit Vim it will store this information in a file, the viminfo +file. When Vim starts again, the viminfo file is read and the information +restored. + +The 'viminfo' option is set by default to restore a limited number of items. +You might want to set it to remember more information. This is done through +the following command: > + + :set viminfo=string + +The string specifies what to save. The syntax of this string is an option +character followed by an argument. The option/argument pairs are separated by +commas. + Take a look at how you can build up your own viminfo string. First, the ' +option is used to specify how many files for which you save marks (a-z). Pick +a nice even number for this option (1000, for instance). Your command now +looks like this: > + + :set viminfo='1000 + +The f option controls whether global marks (A-Z and 0-9) are stored. If this +option is 0, none are stored. If it is 1 or you do not specify an f option, +the marks are stored. You want this feature, so now you have this: > + + :set viminfo='1000,f1 + +The < option controls how many lines are saved for each of the registers. By +default, all the lines are saved. If 0, nothing is saved. To avoid adding +thousands of lines to your viminfo file (which might never get used and makes +starting Vim slower) you use a maximum of 500 lines: > + + :set viminfo='1000,f1,<500 +< +Other options you might want to use: + : number of lines to save from the command line history + @ number of lines to save from the input line history + / number of lines to save from the search history + r removable media, for which no marks will be stored (can be + used several times) + ! global variables that start with an uppercase letter and + don't contain lowercase letters + h disable 'hlsearch' highlighting when starting + % the buffer list (only restored when starting Vim without file + arguments) + c convert the text using 'encoding' + n name used for the viminfo file (must be the last option) + +See the 'viminfo' option and |viminfo-file| for more information. + +When you run Vim multiple times, the last one exiting will store its +information. This may cause information that previously exiting Vims stored +to be lost. Each item can be remembered only once. + + +GETTING BACK TO WHERE YOU STOPPED VIM + +You are halfway editing a file and it's time to leave for holidays. You exit +Vim and go enjoy yourselves, forgetting all about your work. After a couple +of weeks you start Vim, and type: +> + '0 + +And you are right back where you left Vim. So you can get on with your work. + Vim creates a mark each time you exit Vim. The last one is '0. The +position that '0 pointed to is made '1. And '1 is made to '2, and so forth. +Mark '9 is lost. + The |:marks| command is useful to find out where '0 to '9 will take you. + + +GETTING BACK TO SOME FILE + +If you want to go back to a file that you edited recently, but not when +exiting Vim, there is a slightly more complicated way. You can see a list of +files by typing the command: > + + :oldfiles +< 1: ~/.viminfo ~ + 2: ~/text/resume.txt ~ + 3: /tmp/draft ~ + +Now you would like to edit the second file, which is in the list preceded by +"2:". You type: > + + :e #<2 + +Instead of ":e" you can use any command that has a file name argument, the +"#<2" item works in the same place as "%" (current file name) and "#" +(alternate file name). So you can also split the window to edit the third +file: > + + :split #<3 + +That #<123 thing is a bit complicated when you just want to edit a file. +Fortunately there is a simpler way: > + + :browse oldfiles +< 1: ~/.viminfo ~ + 2: ~/text/resume.txt ~ + 3: /tmp/draft ~ + -- More -- + +You get the same list of files as with |:oldfiles|. If you want to edit +"resume.txt" first press "q" to stop the listing. You will get a prompt: + + Type number and <Enter> (empty cancels): ~ + +Type "2" and press <Enter> to edit the second file. + +More info at |:oldfiles|, |v:oldfiles| and |c_#<|. + + +MOVE INFO FROM ONE VIM TO ANOTHER + +You can use the ":wviminfo" and ":rviminfo" commands to save and restore the +information while still running Vim. This is useful for exchanging register +contents between two instances of Vim, for example. In the first Vim do: > + + :wviminfo! ~/tmp/viminfo + +And in the second Vim do: > + + :rviminfo! ~/tmp/viminfo + +Obviously, the "w" stands for "write" and the "r" for "read". + The ! character is used by ":wviminfo" to forcefully overwrite an existing +file. When it is omitted, and the file exists, the information is merged into +the file. + The ! character used for ":rviminfo" means that all the information is +used, this may overwrite existing information. Without the ! only information +that wasn't set is used. + These commands can also be used to store info and use it again later. You +could make a directory full of viminfo files, each containing info for a +different purpose. + +============================================================================== +*21.4* Sessions + +Suppose you are editing along, and it is the end of the day. You want to quit +work and pick up where you left off the next day. You can do this by saving +your editing session and restoring it the next day. + A Vim session contains all the information about what you are editing. +This includes things such as the file list, window layout, global variables, +options and other information. (Exactly what is remembered is controlled by +the 'sessionoptions' option, described below.) + The following command creates a session file: > + + :mksession vimbook.vim + +Later if you want to restore this session, you can use this command: > + + :source vimbook.vim + +If you want to start Vim and restore a specific session, you can use the +following command: > + + vim -S vimbook.vim + +This tells Vim to read a specific file on startup. The 'S' stands for +session (actually, you can source any Vim script with -S, thus it might as +well stand for "source"). + +The windows that were open are restored, with the same position and size as +before. Mappings and option values are like before. + What exactly is restored depends on the 'sessionoptions' option. The +default value is "blank,buffers,curdir,folds,help,options,winsize". + + blank keep empty windows + buffers all buffers, not only the ones in a window + curdir the current directory + folds folds, also manually created ones + help the help window + options all options and mappings + winsize window sizes + +Change this to your liking. To also restore the size of the Vim window, for +example, use: > + + :set sessionoptions+=resize + + +SESSION HERE, SESSION THERE + +The obvious way to use sessions is when working on different projects. +Suppose you store you session files in the directory "~/.vim". You are +currently working on the "secret" project and have to switch to the "boring" +project: > + + :wall + :mksession! ~/.vim/secret.vim + :source ~/.vim/boring.vim + +This first uses ":wall" to write all modified files. Then the current session +is saved, using ":mksession!". This overwrites the previous session. The +next time you load the secret session you can continue where you were at this +point. And finally you load the new "boring" session. + +If you open help windows, split and close various window, and generally mess +up the window layout, you can go back to the last saved session: > + + :source ~/.vim/boring.vim + +Thus you have complete control over whether you want to continue next time +where you are now, by saving the current setup in a session, or keep the +session file as a starting point. + Another way of using sessions is to create a window layout that you like to +use, and save this in a session. Then you can go back to this layout whenever +you want. + For example, this is a nice layout to use: + + +----------------------------------------+ + | VIM - main help file | + | | + |Move around: Use the cursor keys, or "h| + |help.txt================================| + |explorer | | + |dir |~ | + |dir |~ | + |file |~ | + |file |~ | + |file |~ | + |file |~ | + |~/=========|[No File]===================| + | | + +----------------------------------------+ + +This has a help window at the top, so that you can read this text. The narrow +vertical window on the left contains a file explorer. This is a Vim plugin +that lists the contents of a directory. You can select files to edit there. +More about this in the next chapter. + Create this from a just started Vim with: > + + :help + CTRL-W w + :vertical split ~/ + +You can resize the windows a bit to your liking. Then save the session with: +> + :mksession ~/.vim/mine.vim + +Now you can start Vim with this layout: > + + vim -S ~/.vim/mine.vim + +Hint: To open a file you see listed in the explorer window in the empty +window, move the cursor to the filename and press "O". Double clicking with +the mouse will also do this. + + +UNIX AND MS-WINDOWS + +Some people have to do work on MS-Windows systems one day and on Unix another +day. If you are one of them, consider adding "slash" and "unix" to +'sessionoptions'. The session files will then be written in a format that can +be used on both systems. This is the command to put in your vimrc file: > + + :set sessionoptions+=unix,slash + +Vim will use the Unix format then, because the MS-Windows Vim can read and +write Unix files, but Unix Vim can't read MS-Windows format session files. +Similarly, MS-Windows Vim understands file names with / to separate names, but +Unix Vim doesn't understand \. + + +SESSIONS AND VIMINFO + +Sessions store many things, but not the position of marks, contents of +registers and the command line history. You need to use the viminfo feature +for these things. + In most situations you will want to use sessions separately from viminfo. +This can be used to switch to another session, but keep the command line +history. And yank text into registers in one session, and paste it back in +another session. + You might prefer to keep the info with the session. You will have to do +this yourself then. Example: > + + :mksession! ~/.vim/secret.vim + :wviminfo! ~/.vim/secret.viminfo + +And to restore this again: > + + :source ~/.vim/secret.vim + :rviminfo! ~/.vim/secret.viminfo + +============================================================================== +*21.5* Views + +A session stores the looks of the whole of Vim. When you want to store the +properties for one window only, use a view. + The use of a view is for when you want to edit a file in a specific way. +For example, you have line numbers enabled with the 'number' option and +defined a few folds. Just like with sessions, you can remember this view on +the file and restore it later. Actually, when you store a session, it stores +the view of each window. + There are two basic ways to use views. The first is to let Vim pick a name +for the view file. You can restore the view when you later edit the same +file. To store the view for the current window: > + + :mkview + +Vim will decide where to store the view. When you later edit the same file +you get the view back with this command: > + + :loadview + +That's easy, isn't it? + Now you want to view the file without the 'number' option on, or with all +folds open, you can set the options to make the window look that way. Then +store this view with: > + + :mkview 1 + +Obviously, you can get this back with: > + + :loadview 1 + +Now you can switch between the two views on the file by using ":loadview" with +and without the "1" argument. + You can store up to ten views for the same file this way, one unnumbered +and nine numbered 1 to 9. + + +A VIEW WITH A NAME + +The second basic way to use views is by storing the view in a file with a name +you chose. This view can be loaded while editing another file. Vim will then +switch to editing the file specified in the view. Thus you can use this to +quickly switch to editing another file, with all its options set as you saved +them. + For example, to save the view of the current file: > + + :mkview ~/.vim/main.vim + +You can restore it with: > + + :source ~/.vim/main.vim + +============================================================================== +*21.6* Modelines + +When editing a specific file, you might set options specifically for that +file. Typing these commands each time is boring. Using a session or view for +editing a file doesn't work when sharing the file between several people. + The solution for this situation is adding a modeline to the file. This is +a line of text that tells Vim the values of options, to be used in this file +only. + A typical example is a C program where you make indents by a multiple of 4 +spaces. This requires setting the 'shiftwidth' option to 4. This modeline +will do that: + + /* vim:set shiftwidth=4: */ ~ + +Put this line as one of the first or last five lines in the file. When +editing the file, you will notice that 'shiftwidth' will have been set to +four. When editing another file, it's set back to the default value of eight. + For some files the modeline fits well in the header, thus it can be put at +the top of the file. For text files and other files where the modeline gets +in the way of the normal contents, put it at the end of the file. + +The 'modelines' option specifies how many lines at the start and end of the +file are inspected for containing a modeline. To inspect ten lines: > + + :set modelines=10 + +The 'modeline' option can be used to switch this off. Do this when you are +working as root on Unix or Administrator on MS-Windows, or when you don't +trust the files you are editing: > + + :set nomodeline + +Use this format for the modeline: + + any-text vim:set {option}={value} ... : any-text ~ + +The "any-text" indicates that you can put any text before and after the part +that Vim will use. This allows making it look like a comment, like what was +done above with /* and */. + The " vim:" part is what makes Vim recognize this line. There must be +white space before "vim", or "vim" must be at the start of the line. Thus +using something like "gvim:" will not work. + The part between the colons is a ":set" command. It works the same way as +typing the ":set" command, except that you need to insert a backslash before a +colon (otherwise it would be seen as the end of the modeline). + +Another example: + + // vim:set textwidth=72 dir=c\:\tmp: use c:\tmp here ~ + +There is an extra backslash before the first colon, so that it's included in +the ":set" command. The text after the second colon is ignored, thus a remark +can be placed there. + +For more details see |modeline|. + +============================================================================== + +Next chapter: |usr_22.txt| Finding the file to edit + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_22.txt b/share/vim/vim73/doc/usr_22.txt new file mode 100644 index 0000000000..8ca034e898 --- /dev/null +++ b/share/vim/vim73/doc/usr_22.txt @@ -0,0 +1,400 @@ +*usr_22.txt* For Vim version 7.3. Last change: 2010 Feb 21 + + VIM USER MANUAL - by Bram Moolenaar + + Finding the file to edit + + +Files can be found everywhere. So how do you find them? Vim offers various +ways to browse the directory tree. There are commands to jump to a file that +is mentioned in another. And Vim remembers which files have been edited +before. + +|22.1| The file browser +|22.2| The current directory +|22.3| Finding a file +|22.4| The buffer list + + Next chapter: |usr_23.txt| Editing other files + Previous chapter: |usr_21.txt| Go away and come back +Table of contents: |usr_toc.txt| + +============================================================================== +*22.1* The file browser + +Vim has a plugin that makes it possible to edit a directory. Try this: > + + :edit . + +Through the magic of autocommands and Vim scripts, the window will be filled +with the contents of the directory. It looks like this: + +" ============================================================================ ~ +" Netrw Directory Listing (netrw v109) ~ +" Sorted by name ~ +" Sort sequence: [\/]$,\.h$,\.c$,\.cpp$,*,\.info$,\.swp$,\.o$\.obj$,\.bak$ ~ +" Quick Help: <F1>:help -:go up dir D:delete R:rename s:sort-by x:exec ~ +" ============================================================================ ~ +../ ~ +./ ~ +check/ ~ +Makefile ~ +autocmd.txt ~ +change.txt ~ +eval.txt~ ~ +filetype.txt~ ~ +help.txt.info ~ + +You can see these items: + +1. The name of the browsing tool and its version number +2. The name of the browsing directory +3. The method of sorting (may be by name, time, or size) +4. How names are to be sorted (directories first, then *.h files, + *.c files, etc) +5. How to get help (use the <F1> key), and an abbreviated listing + of available commands +6. A listing of files, including "../", which allows one to list + the parent directory. + +If you have syntax highlighting enabled, the different parts are highlighted +so as to make it easier to spot them. + +You can use Normal mode Vim commands to move around in the text. For example, +move the cursor atop a file and press <Enter>; you will then be editing that +file. To go back to the browser use ":edit ." again, or use ":Explore". +CTRL-O also works. + +Try using <Enter> while the cursor is atop a directory name. The result is +that the file browser moves into that directory and displays the items found +there. Pressing <Enter> on the first directory "../" moves you one level +higher. Pressing "-" does the same thing, without the need to move to the +"../" item first. + +You can press <F1> to get help on the things you can do in the netrw file +browser. This is what you get: > + + 9. Directory Browsing netrw-browse netrw-dir netrw-list netrw-help + + MAPS netrw-maps + <F1>.............Help.......................................|netrw-help| + <cr>.............Browsing...................................|netrw-cr| + <del>............Deleting Files or Directories..............|netrw-delete| + -................Going Up...................................|netrw--| + a................Hiding Files or Directories................|netrw-a| + mb...............Bookmarking a Directory....................|netrw-mb| + gb...............Changing to a Bookmarked Directory.........|netrw-gb| + c................Make Browsing Directory The Current Dir....|netrw-c| + d................Make A New Directory.......................|netrw-d| + D................Deleting Files or Directories..............|netrw-D| + <c-h>............Edit File/Directory Hiding List............|netrw-ctrl-h| + i................Change Listing Style.......................|netrw-i| + <c-l>............Refreshing the Listing.....................|netrw-ctrl-l| + o................Browsing with a Horizontal Split...........|netrw-o| + p................Use Preview Window.........................|netrw-p| + P................Edit in Previous Window....................|netrw-p| + q................Listing Bookmarks and History..............|netrw-q| + r................Reversing Sorting Order....................|netrw-r| +< (etc) + +The <F1> key thus brings you to a netrw directory browsing contents help page. +It's a regular help page; use the usual |CTRL-]| to jump to tagged help items +and |CTRL-O| to jump back. + +To select files for display and editing: (with the cursor is atop a filename) + + <enter> Open the file in the current window. |netrw-cr| + o Horizontally split window and display file |netrw-o| + v Vertically split window and display file |netrw-v| + p Use the |preview-window| |netrw-p| + P Edit in the previous window |netrw-P| + t Open file in a new tab |netrw-t| + +The following normal-mode commands may be used to control the browser display: + + i Controls listing style (thin, long, wide, and tree). + The long listing includes size and date information. + s Repeatedly pressing s will change the way the files + are sorted; one may sort on name, modification time, + or size. + r Reverse the sorting order. + +As a sampling of extra normal-mode commands: + + c Change Vim's notion of the current directory to be + the same as the browser directory. (see + |g:netrw_keepdir| to control this, too) + R Rename the file or directory under the cursor; a + prompt will be issued for the new name. + D Delete the file or directory under the cursor; a + confirmation request will be issued. + mb gb Make bookmark/goto bookmark + + +One may also use command mode; again, just a sampling: + + :Explore [directory] Browse specified/current directory + :NetrwSettings A comprehensive list of your current netrw + settings with help linkage. + +The netrw browser is not limited to just your local machine; one may use +urls such as: (that trailing / is important) + + :Explore ftp://somehost/path/to/dir/ + :e scp://somehost/path/to/dir/ + +See |netrw-browse| for more. + +============================================================================== +*22.2* The current directory + +Just like the shell, Vim has the concept of a current directory. Suppose you +are in your home directory and want to edit several files in a directory +"VeryLongFileName". You could do: > + + :edit VeryLongFileName/file1.txt + :edit VeryLongFileName/file2.txt + :edit VeryLongFileName/file3.txt + +To avoid much of the typing, do this: > + + :cd VeryLongFileName + :edit file1.txt + :edit file2.txt + :edit file3.txt + +The ":cd" command changes the current directory. You can see what the current +directory is with the ":pwd" command: > + + :pwd + /home/Bram/VeryLongFileName + +Vim remembers the last directory that you used. Use "cd -" to go back to it. +Example: > + + :pwd + /home/Bram/VeryLongFileName + :cd /etc + :pwd + /etc + :cd - + :pwd + /home/Bram/VeryLongFileName + :cd - + :pwd + /etc + + +WINDOW LOCAL DIRECTORY + +When you split a window, both windows use the same current directory. When +you want to edit a number of files somewhere else in the new window, you can +make it use a different directory, without changing the current directory in +the other window. This is called a local directory. > + + :pwd + /home/Bram/VeryLongFileName + :split + :lcd /etc + :pwd + /etc + CTRL-W w + :pwd + /home/Bram/VeryLongFileName + +So long as no ":lcd" command has been used, all windows share the same current +directory. Doing a ":cd" command in one window will also change the current +directory of the other window. + For a window where ":lcd" has been used a different current directory is +remembered. Using ":cd" or ":lcd" in other windows will not change it. + When using a ":cd" command in a window that uses a different current +directory, it will go back to using the shared directory. + +============================================================================== +*22.3* Finding a file + +You are editing a C program that contains this line: + + #include "inits.h" ~ + +You want to see what is in that "inits.h" file. Move the cursor on the name +of the file and type: > + + gf + +Vim will find the file and edit it. + What if the file is not in the current directory? Vim will use the 'path' +option to find the file. This option is a list of directory names where to +look for your file. + Suppose you have your include files located in "c:/prog/include". This +command will add it to the 'path' option: > + + :set path+=c:/prog/include + +This directory is an absolute path. No matter where you are, it will be the +same place. What if you have located files in a subdirectory, below where the +file is? Then you can specify a relative path name. This starts with a dot: +> + :set path+=./proto + +This tells Vim to look in the directory "proto", below the directory where the +file in which you use "gf" is. Thus using "gf" on "inits.h" will make Vim +look for "proto/inits.h", starting in the directory of the file. + Without the "./", thus "proto", Vim would look in the "proto" directory +below the current directory. And the current directory might not be where the +file that you are editing is located. + +The 'path' option allows specifying the directories where to search for files +in many more ways. See the help on the 'path' option. + The 'isfname' option is used to decide which characters are included in the +file name, and which ones are not (e.g., the " character in the example +above). + +When you know the file name, but it's not to be found in the file, you can +type it: > + + :find inits.h + +Vim will then use the 'path' option to try and locate the file. This is the +same as the ":edit" command, except for the use of 'path'. + +To open the found file in a new window use CTRL-W f instead of "gf", or use +":sfind" instead of ":find". + + +A nice way to directly start Vim to edit a file somewhere in the 'path': > + + vim "+find stdio.h" + +This finds the file "stdio.h" in your value of 'path'. The quotes are +necessary to have one argument |-+c|. + +============================================================================== +*22.4* The buffer list + +The Vim editor uses the term buffer to describe a file being edited. +Actually, a buffer is a copy of the file that you edit. When you finish +changing the buffer, you write the contents of the buffer to the file. +Buffers not only contain file contents, but also all the marks, settings, and +other stuff that goes with it. + + +HIDDEN BUFFERS + +Suppose you are editing the file one.txt and need to edit the file two.txt. +You could simply use ":edit two.txt", but since you made changes to one.txt +that won't work. You also don't want to write one.txt yet. Vim has a +solution for you: > + + :hide edit two.txt + +The buffer "one.txt" disappears from the screen, but Vim still knows that you +are editing this buffer, so it keeps the modified text. This is called a +hidden buffer: The buffer contains text, but you can't see it. + The argument of ":hide" is another command. ":hide" makes that command +behave as if the 'hidden' option was set. You could also set this option +yourself. The effect is that when any buffer is abandoned, it becomes hidden. + Be careful! When you have hidden buffers with changes, don't exit Vim +without making sure you have saved all the buffers. + + +INACTIVE BUFFERS + + When a buffer has been used once, Vim remembers some information about it. +When it is not displayed in a window and it is not hidden, it is still in the +buffer list. This is called an inactive buffer. Overview: + + Active Appears in a window, text loaded. + Hidden Not in a window, text loaded. + Inactive Not in a window, no text loaded. + +The inactive buffers are remembered, because Vim keeps information about them, +like marks. And remembering the file name is useful too, so that you can see +which files you have edited. And edit them again. + + +LISTING BUFFERS + +View the buffer list with this command: > + + :buffers + +A command which does the same, is not so obvious to list buffers, but is much +shorter to type: > + + :ls + +The output could look like this: + + 1 #h "help.txt" line 62 ~ + 2 %a+ "usr_21.txt" line 1 ~ + 3 "usr_toc.txt" line 1 ~ + +The first column contains the buffer number. You can use this to edit the +buffer without having to type the name, see below. + After the buffer number come the flags. Then the name of the file +and the line number where the cursor was the last time. + The flags that can appear are these (from left to right): + + u Buffer is unlisted |unlisted-buffer|. + % Current buffer. + # Alternate buffer. + a Buffer is loaded and displayed. + h Buffer is loaded but hidden. + = Buffer is read-only. + - Buffer is not modifiable, the 'modifiable' option is off. + + Buffer has been modified. + + +EDITING A BUFFER + +You can edit a buffer by its number. That avoids having to type the file +name: > + + :buffer 2 + +But the only way to know the number is by looking in the buffer list. You can +use the name, or part of it, instead: > + + :buffer help + +Vim will find the best match for the name you type. If there is only one +buffer that matches the name, it will be used. In this case "help.txt". + To open a buffer in a new window: > + + :sbuffer 3 + +This works with a name as well. + + +USING THE BUFFER LIST + +You can move around in the buffer list with these commands: + + :bnext go to next buffer + :bprevious go to previous buffer + :bfirst go to the first buffer + :blast go to the last buffer + +To remove a buffer from the list, use this command: > + + :bdelete 3 + +Again, this also works with a name. + If you delete a buffer that was active (visible in a window), that window +will be closed. If you delete the current buffer, the current window will be +closed. If it was the last window, Vim will find another buffer to edit. You +can't be editing nothing! + + Note: + Even after removing the buffer with ":bdelete" Vim still remembers it. + It's actually made "unlisted", it no longer appears in the list from + ":buffers". The ":buffers!" command will list unlisted buffers (yes, + Vim can do the impossible). To really make Vim forget about a buffer, + use ":bwipe". Also see the 'buflisted' option. + +============================================================================== + +Next chapter: |usr_23.txt| Editing other files + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_23.txt b/share/vim/vim73/doc/usr_23.txt new file mode 100644 index 0000000000..50e7f8f6c7 --- /dev/null +++ b/share/vim/vim73/doc/usr_23.txt @@ -0,0 +1,343 @@ +*usr_23.txt* For Vim version 7.3. Last change: 2006 Apr 24 + + VIM USER MANUAL - by Bram Moolenaar + + Editing other files + + +This chapter is about editing files that are not ordinary files. With Vim you +can edit files that are compressed or encrypted. Some files need to be +accessed over the internet. With some restrictions, binary files can be +edited as well. + +|23.1| DOS, Mac and Unix files +|23.2| Files on the internet +|23.3| Encryption +|23.4| Binary files +|23.5| Compressed files + + Next chapter: |usr_24.txt| Inserting quickly + Previous chapter: |usr_22.txt| Finding the file to edit +Table of contents: |usr_toc.txt| + +============================================================================== +*23.1* DOS, Mac and Unix files + +Back in the early days, the old Teletype machines used two characters to +start a new line. One to move the carriage back to the first position +(carriage return, <CR>), another to move the paper up (line feed, <LF>). + When computers came out, storage was expensive. Some people decided that +they did not need two characters for end-of-line. The UNIX people decided +they could use <Line Feed> only for end-of-line. The Apple people +standardized on <CR>. The MS-DOS (and Microsoft Windows) folks decided to +keep the old <CR><LF>. + This means that if you try to move a file from one system to another, you +have line-break problems. The Vim editor automatically recognizes the +different file formats and handles things properly behind your back. + The option 'fileformats' contains the various formats that will be tried +when a new file is edited. The following command, for example, tells Vim to +try UNIX format first and MS-DOS format second: > + + :set fileformats=unix,dos + +You will notice the format in the message you get when editing a file. You +don't see anything if you edit a native file format. Thus editing a Unix file +on Unix won't result in a remark. But when you edit a dos file, Vim will +notify you of this: + + "/tmp/test" [dos] 3L, 71C ~ + +For a Mac file you would see "[mac]". + The detected file format is stored in the 'fileformat' option. To see +which format you have, execute the following command: > + + :set fileformat? + +The three names that Vim uses are: + + unix <LF> + dos <CR><LF> + mac <CR> + + +USING THE MAC FORMAT + +On Unix, <LF> is used to break a line. It's not unusual to have a <CR> +character halfway a line. Incidentally, this happens quite often in Vi (and +Vim) scripts. + On the Macintosh, where <CR> is the line break character, it's possible to +have a <LF> character halfway a line. + The result is that it's not possible to be 100% sure whether a file +containing both <CR> and <LF> characters is a Mac or a Unix file. Therefore, +Vim assumes that on Unix you probably won't edit a Mac file, and doesn't check +for this type of file. To check for this format anyway, add "mac" to +'fileformats': > + + :set fileformats+=mac + +Then Vim will take a guess at the file format. Watch out for situations where +Vim guesses wrong. + + +OVERRULING THE FORMAT + +If you use the good old Vi and try to edit an MS-DOS format file, you will +find that each line ends with a ^M character. (^M is <CR>). The automatic +detection avoids this. Suppose you do want to edit the file that way? Then +you need to overrule the format: > + + :edit ++ff=unix file.txt + +The "++" string is an item that tells Vim that an option name follows, which +overrules the default for this single command. "++ff" is used for +'fileformat'. You could also use "++ff=mac" or "++ff=dos". + This doesn't work for any option, only "++ff" and "++enc" are currently +implemented. The full names "++fileformat" and "++encoding" also work. + + +CONVERSION + +You can use the 'fileformat' option to convert from one file format to +another. Suppose, for example, that you have an MS-DOS file named README.TXT +that you want to convert to UNIX format. Start by editing the MS-DOS format +file: > + vim README.TXT + +Vim will recognize this as a dos format file. Now change the file format to +UNIX: > + + :set fileformat=unix + :write + +The file is written in Unix format. + +============================================================================== +*23.2* Files on the internet + +Someone sends you an e-mail message, which refers to a file by its URL. For +example: + + You can find the information here: ~ + ftp://ftp.vim.org/pub/vim/README ~ + +You could start a program to download the file, save it on your local disk and +then start Vim to edit it. + There is a much simpler way. Move the cursor to any character of the URL. +Then use this command: > + + gf + +With a bit of luck, Vim will figure out which program to use for downloading +the file, download it and edit the copy. To open the file in a new window use +CTRL-W f. + If something goes wrong you will get an error message. It's possible that +the URL is wrong, you don't have permission to read it, the network connection +is down, etc. Unfortunately, it's hard to tell the cause of the error. You +might want to try the manual way of downloading the file. + +Accessing files over the internet works with the netrw plugin. Currently URLs +with these formats are recognized: + + ftp:// uses ftp + rcp:// uses rcp + scp:// uses scp + http:// uses wget (reading only) + +Vim doesn't do the communication itself, it relies on the mentioned programs +to be available on your computer. On most Unix systems "ftp" and "rcp" will +be present. "scp" and "wget" might need to be installed. + +Vim detects these URLs for each command that starts editing a new file, also +with ":edit" and ":split", for example. Write commands also work, except for +http://. + +For more information, also about passwords, see |netrw|. + +============================================================================== +*23.3* Encryption + +Some information you prefer to keep to yourself. For example, when writing +a test on a computer that students also use. You don't want clever students +to figure out a way to read the questions before the exam starts. Vim can +encrypt the file for you, which gives you some protection. + To start editing a new file with encryption, use the "-x" argument to start +Vim. Example: > + + vim -x exam.txt + +Vim prompts you for a key used for encrypting and decrypting the file: + + Enter encryption key: ~ + +Carefully type the secret key now. You cannot see the characters you type, +they will be replaced by stars. To avoid the situation that a typing mistake +will cause trouble, Vim asks you to enter the key again: + + Enter same key again: ~ + +You can now edit this file normally and put in all your secrets. When you +finish editing the file and tell Vim to exit, the file is encrypted and +written. + When you edit the file with Vim, it will ask you to enter the same key +again. You don't need to use the "-x" argument. You can also use the normal +":edit" command. Vim adds a magic string to the file by which it recognizes +that the file was encrypted. + If you try to view this file using another program, all you get is garbage. +Also, if you edit the file with Vim and enter the wrong key, you get garbage. +Vim does not have a mechanism to check if the key is the right one (this makes +it much harder to break the key). + + +SWITCHING ENCRYPTION ON AND OFF + +To disable the encryption of a file, set the 'key' option to an empty string: +> + :set key= + +The next time you write the file this will be done without encryption. + Setting the 'key' option to enable encryption is not a good idea, because +the password appears in the clear. Anyone shoulder-surfing can read your +password. + To avoid this problem, the ":X" command was created. It asks you for an +encryption key, just like the "-x" argument did: > + + :X + Enter encryption key: ****** + Enter same key again: ****** + + +LIMITS ON ENCRYPTION + +The encryption algorithm used by Vim is weak. It is good enough to keep out +the casual prowler, but not good enough to keep out a cryptology expert with +lots of time on his hands. Also you should be aware that the swap file is not +encrypted; so while you are editing, people with superuser privileges can read +the unencrypted text from this file. + One way to avoid letting people read your swap file is to avoid using one. +If the -n argument is supplied on the command line, no swap file is used +(instead, Vim puts everything in memory). For example, to edit the encrypted +file "file.txt" without a swap file use the following command: > + + vim -x -n file.txt + +When already editing a file, the swapfile can be disabled with: > + + :setlocal noswapfile + +Since there is no swapfile, recovery will be impossible. Save the file a bit +more often to avoid the risk of losing your changes. + +While the file is in memory, it is in plain text. Anyone with privilege can +look in the editor's memory and discover the contents of the file. + If you use a viminfo file, be aware that the contents of text registers are +written out in the clear as well. + If you really want to secure the contents of a file, edit it only on a +portable computer not connected to a network, use good encryption tools, and +keep the computer locked up in a big safe when not in use. + +============================================================================== +*23.4* Binary files + +You can edit binary files with Vim. Vim wasn't really made for this, thus +there are a few restrictions. But you can read a file, change a character and +write it back, with the result that only that one character was changed and +the file is identical otherwise. + To make sure that Vim does not use its clever tricks in the wrong way, add +the "-b" argument when starting Vim: > + + vim -b datafile + +This sets the 'binary' option. The effect of this is that unexpected side +effects are turned off. For example, 'textwidth' is set to zero, to avoid +automatic formatting of lines. And files are always read in Unix file format. + +Binary mode can be used to change a message in a program. Be careful not to +insert or delete any characters, it would stop the program from working. Use +"R" to enter replace mode. + +Many characters in the file will be unprintable. To see them in Hex format: > + + :set display=uhex + +Otherwise, the "ga" command can be used to see the value of the character +under the cursor. The output, when the cursor is on an <Esc>, looks like +this: + + <^[> 27, Hex 1b, Octal 033 ~ + +There might not be many line breaks in the file. To get some overview switch +the 'wrap' option off: > + + :set nowrap + + +BYTE POSITION + +To see on which byte you are in the file use this command: > + + g CTRL-G + +The output is verbose: + + Col 9-16 of 9-16; Line 277 of 330; Word 1806 of 2058; Byte 10580 of 12206 ~ + +The last two numbers are the byte position in the file and the total number of +bytes. This takes into account how 'fileformat' changes the number of bytes +that a line break uses. + To move to a specific byte in the file, use the "go" command. For +example, to move to byte 2345: > + + 2345go + + +USING XXD + +A real binary editor shows the text in two ways: as it is and in hex format. +You can do this in Vim by first converting the file with the "xxd" program. +This comes with Vim. + First edit the file in binary mode: > + + vim -b datafile + +Now convert the file to a hex dump with xxd: > + + :%!xxd + +The text will look like this: + + 0000000: 1f8b 0808 39d7 173b 0203 7474 002b 4e49 ....9..;..tt.+NI ~ + 0000010: 4b2c 8660 eb9c ecac c462 eb94 345e 2e30 K,.`.....b..4^.0 ~ + 0000020: 373b 2731 0b22 0ca6 c1a2 d669 1035 39d9 7;'1.".....i.59. ~ + +You can now view and edit the text as you like. Vim treats the information as +ordinary text. Changing the hex does not cause the printable character to be +changed, or the other way around. + Finally convert it back with: +> + :%!xxd -r + +Only changes in the hex part are used. Changes in the printable text part on +the right are ignored. + +See the manual page of xxd for more information. + +============================================================================== +*23.5* Compressed files + +This is easy: You can edit a compressed file just like any other file. The +"gzip" plugin takes care of decompressing the file when you edit it. And +compressing it again when you write it. + These compression methods are currently supported: + + .Z compress + .gz gzip + .bz2 bzip2 + +Vim uses the mentioned programs to do the actual compression and +decompression. You might need to install the programs first. + +============================================================================== + +Next chapter: |usr_24.txt| Inserting quickly + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_24.txt b/share/vim/vim73/doc/usr_24.txt new file mode 100644 index 0000000000..e33e0c7357 --- /dev/null +++ b/share/vim/vim73/doc/usr_24.txt @@ -0,0 +1,606 @@ +*usr_24.txt* For Vim version 7.3. Last change: 2006 Jul 23 + + VIM USER MANUAL - by Bram Moolenaar + + Inserting quickly + + +When entering text, Vim offers various ways to reduce the number of keystrokes +and avoid typing mistakes. Use Insert mode completion to repeat previously +typed words. Abbreviate long words to short ones. Type characters that +aren't on your keyboard. + +|24.1| Making corrections +|24.2| Showing matches +|24.3| Completion +|24.4| Repeating an insert +|24.5| Copying from another line +|24.6| Inserting a register +|24.7| Abbreviations +|24.8| Entering special characters +|24.9| Digraphs +|24.10| Normal mode commands + + Next chapter: |usr_25.txt| Editing formatted text + Previous chapter: |usr_23.txt| Editing other files +Table of contents: |usr_toc.txt| + +============================================================================== +*24.1* Making corrections + +The <BS> key was already mentioned. It deletes the character just before the +cursor. The <Del> key does the same for the character under (after) the +cursor. + When you typed a whole word wrong, use CTRL-W: + + The horse had fallen to the sky ~ + CTRL-W + The horse had fallen to the ~ + +If you really messed up a line and want to start over, use CTRL-U to delete +it. This keeps the text after the cursor and the indent. Only the text from +the first non-blank to the cursor is deleted. With the cursor on the "f" of +"fallen" in the next line pressing CTRL-U does this: + + The horse had fallen to the ~ + CTRL-U + fallen to the ~ + +When you spot a mistake a few words back, you need to move the cursor there to +correct it. For example, you typed this: + + The horse had follen to the ground ~ + +You need to change "follen" to "fallen". With the cursor at the end, you +would type this to correct it: > + + <Esc>4blraA + +< get out of Insert mode <Esc> + four words back 4b + move on top of the "o" l + replace with "a" ra + restart Insert mode A + +Another way to do this: > + + <C-Left><C-Left><C-Left><C-Left><Right><Del>a<End> + +< four words back <C-Left><C-Left><C-Left><C-Left> + move on top of the "o" <Right> + delete the "o" <Del> + insert an "a" a + go to end of the line <End> + +This uses special keys to move around, while remaining in Insert mode. This +resembles what you would do in a modeless editor. It's easier to remember, +but takes more time (you have to move your hand from the letters to the cursor +keys, and the <End> key is hard to press without looking at the keyboard). + These special keys are most useful when writing a mapping that doesn't +leave Insert mode. The extra typing doesn't matter then. + An overview of the keys you can use in Insert mode: + + <C-Home> to start of the file + <PageUp> a whole screenful up + <Home> to start of line + <S-Left> one word left + <C-Left> one word left + <S-Right> one word right + <C-Right> one word right + <End> to end of the line + <PageDown> a whole screenful down + <C-End> to end of the file + +There are a few more, see |ins-special-special|. + +============================================================================== +*24.2* Showing matches + +When you type a ) it would be nice to see with which ( it matches. To make +Vim do that use this command: > + + :set showmatch + +When you now type a text like "(example)", as soon as you type the ) Vim will +briefly move the cursor to the matching (, keep it there for half a second, +and move back to where you were typing. + In case there is no matching (, Vim will beep. Then you know that you +might have forgotten the ( somewhere, or typed a ) too many. + The match will also be shown for [] and {} pairs. You don't have to wait +with typing the next character, as soon as Vim sees it the cursor will move +back and inserting continues as before. + You can change the time Vim waits with the 'matchtime' option. For +example, to make Vim wait one and a half second: > + + :set matchtime=15 + +The time is specified in tenths of a second. + +============================================================================== +*24.3* Completion + +Vim can automatically complete words on insertion. You type the first part of +a word, press CTRL-P, and Vim guesses the rest. + Suppose, for example, that you are creating a C program and want to type in +the following: + + total = ch_array[0] + ch_array[1] + ch_array[2]; ~ + +You start by entering the following: + + total = ch_array[0] + ch_ ~ + +At this point, you tell Vim to complete the word using the command CTRL-P. +Vim searches for a word that starts with what's in front of the cursor. In +this case, it is "ch_", which matches with the word ch_array. So typing +CTRL-P gives you the following: + + total = ch_array[0] + ch_array ~ + +After a little more typing, you get this (ending in a space): + + total = ch_array[0] + ch_array[1] + ~ + +If you now type CTRL-P Vim will search again for a word that completes the +word before the cursor. Since there is nothing in front of the cursor, it +finds the first word backwards, which is "ch_array". Typing CTRL-P again +gives you the next word that matches, in this case "total". A third CTRL-P +searches further back. If there is nothing else, it causes the editor to run +out of words, so it returns to the original text, which is nothing. A fourth +CTRL-P causes the editor to start over again with "ch_array". + +To search forward, use CTRL-N. Since the search wraps around the end of the +file, CTRL-N and CTRL-P will find the same matches, but in a different +sequence. Hint: CTRL-N is Next-match and CTRL-P is Previous-match. + +The Vim editor goes through a lot of effort to find words to complete. By +default, it searches the following places: + + 1. Current file + 2. Files in other windows + 3. Other loaded files (hidden buffers) + 4. Files which are not loaded (inactive buffers) + 5. Tag files + 6. All files #included by the current file + + +OPTIONS + +You can customize the search order with the 'complete' option. + +The 'ignorecase' option is used. When it is set, case differences are ignored +when searching for matches. + +A special option for completion is 'infercase'. This is useful to find +matches while ignoring case ('ignorecase' must be set) but still using the +case of the word typed so far. Thus if you type "For" and Vim finds a match +"fortunately", it will result in "Fortunately". + + +COMPLETING SPECIFIC ITEMS + +If you know what you are looking for, you can use these commands to complete +with a certain type of item: + + CTRL-X CTRL-F file names + CTRL-X CTRL-L whole lines + CTRL-X CTRL-D macro definitions (also in included files) + CTRL-X CTRL-I current and included files + CTRL-X CTRL-K words from a dictionary + CTRL-X CTRL-T words from a thesaurus + CTRL-X CTRL-] tags + CTRL-X CTRL-V Vim command line + +After each of them CTRL-N can be used to find the next match, CTRL-P to find +the previous match. + More information for each of these commands here: |ins-completion|. + + +COMPLETING FILE NAMES + +Let's take CTRL-X CTRL-F as an example. This will find file names. It scans +the current directory for files and displays each one that matches the word in +front of the cursor. + Suppose, for example, that you have the following files in the current +directory: + + main.c sub_count.c sub_done.c sub_exit.c + +Now enter Insert mode and start typing: + + The exit code is in the file sub ~ + +At this point, you enter the command CTRL-X CTRL-F. Vim now completes the +current word "sub" by looking at the files in the current directory. The +first match is sub_count.c. This is not the one you want, so you match the +next file by typing CTRL-N. This match is sub_done.c. Typing CTRL-N again +takes you to sub_exit.c. The results: + + The exit code is in the file sub_exit.c ~ + +If the file name starts with / (Unix) or C:\ (MS-Windows) you can find all +files in the file system. For example, type "/u" and CTRL-X CTRL-F. This +will match "/usr" (this is on Unix): + + the file is found in /usr/ ~ + +If you now press CTRL-N you go back to "/u". Instead, to accept the "/usr/" +and go one directory level deeper, use CTRL-X CTRL-F again: + + the file is found in /usr/X11R6/ ~ + +The results depend on what is found in your file system, of course. The +matches are sorted alphabetically. + + +COMPLETING IN SOURCE CODE + +Source code files are well structured. That makes it possible to do +completion in an intelligent way. In Vim this is called Omni completion. In +some other editors it's called intellisense, but that is a trademark. + +The key to Omni completion is CTRL-X CTRL-O. Obviously the O stands for Omni +here, so that you can remember it easier. Let's use an example for editing C +source: + + { ~ + struct foo *p; ~ + p-> ~ + +The cursor is after "p->". Now type CTRL-X CTRL-O. Vim will offer you a list +of alternatives, which are the items that "struct foo" contains. That is +quite different from using CTRL-P, which would complete any word, while only +members of "struct foo" are valid here. + +For Omni completion to work you may need to do some setup. At least make sure +filetype plugins are enabled. Your vimrc file should contain a line like +this: > + filetype plugin on +Or: > + filetype plugin indent on + +For C code you need to create a tags file and set the 'tags' option. That is +explained |ft-c-omni|. For other filetypes you may need to do something +similar, look below |compl-omni-filetypes|. It only works for specific +filetypes. Check the value of the 'omnifunc' option to find out if it would +work. + +============================================================================== +*24.4* Repeating an insert + +If you press CTRL-A, the editor inserts the text you typed the last time you +were in Insert mode. + Assume, for example, that you have a file that begins with the following: + + "file.h" ~ + /* Main program begins */ ~ + +You edit this file by inserting "#include " at the beginning of the first +line: + + #include "file.h" ~ + /* Main program begins */ ~ + +You go down to the beginning of the next line using the commands "j^". You +now start to insert a new "#include" line. So you type: > + + i CTRL-A + +The result is as follows: + + #include "file.h" ~ + #include /* Main program begins */ ~ + +The "#include " was inserted because CTRL-A inserts the text of the previous +insert. Now you type "main.h"<Enter> to finish the line: + + + #include "file.h" ~ + #include "main.h" ~ + /* Main program begins */ ~ + +The CTRL-@ command does a CTRL-A and then exits Insert mode. That's a quick +way of doing exactly the same insertion again. + +============================================================================== +*24.5* Copying from another line + +The CTRL-Y command inserts the character above the cursor. This is useful +when you are duplicating a previous line. For example, you have this line of +C code: + + b_array[i]->s_next = a_array[i]->s_next; ~ + +Now you need to type the same line, but with "s_prev" instead of "s_next". +Start the new line, and press CTRL-Y 14 times, until you are at the "n" of +"next": + + b_array[i]->s_next = a_array[i]->s_next; ~ + b_array[i]->s_ ~ + +Now you type "prev": + + b_array[i]->s_next = a_array[i]->s_next; ~ + b_array[i]->s_prev ~ + +Continue pressing CTRL-Y until the following "next": + + b_array[i]->s_next = a_array[i]->s_next; ~ + b_array[i]->s_prev = a_array[i]->s_ ~ + +Now type "prev;" to finish it off. + +The CTRL-E command acts like CTRL-Y except it inserts the character below the +cursor. + +============================================================================== +*24.6* Inserting a register + +The command CTRL-R {register} inserts the contents of the register. This is +useful to avoid having to type a long word. For example, you need to type +this: + + r = VeryLongFunction(a) + VeryLongFunction(b) + VeryLongFunction(c) ~ + +The function name is defined in a different file. Edit that file and move the +cursor on top of the function name there, and yank it into register v: > + + "vyiw + +"v is the register specification, "yiw" is yank-inner-word. Now edit the file +where the new line is to be inserted, and type the first letters: + + r = ~ + +Now use CTRL-R v to insert the function name: + + r = VeryLongFunction ~ + +You continue to type the characters in between the function name, and use +CTRL-R v two times more. + You could have done the same with completion. Using a register is useful +when there are many words that start with the same characters. + +If the register contains characters such as <BS> or other special characters, +they are interpreted as if they had been typed from the keyboard. If you do +not want this to happen (you really want the <BS> to be inserted in the text), +use the command CTRL-R CTRL-R {register}. + +============================================================================== +*24.7* Abbreviations + +An abbreviation is a short word that takes the place of a long one. For +example, "ad" stands for "advertisement". Vim enables you to type an +abbreviation and then will automatically expand it for you. + To tell Vim to expand "ad" into "advertisement" every time you insert it, +use the following command: > + + :iabbrev ad advertisement + +Now, when you type "ad", the whole word "advertisement" will be inserted into +the text. This is triggered by typing a character that can't be part of a +word, for example a space: + + What Is Entered What You See + I saw the a I saw the a ~ + I saw the ad I saw the ad ~ + I saw the ad<Space> I saw the advertisement<Space> ~ + +The expansion doesn't happen when typing just "ad". That allows you to type a +word like "add", which will not get expanded. Only whole words are checked +for abbreviations. + + +ABBREVIATING SEVERAL WORDS + +It is possible to define an abbreviation that results in multiple words. For +example, to define "JB" as "Jack Benny", use the following command: > + + :iabbrev JB Jack Benny + +As a programmer, I use two rather unusual abbreviations: > + + :iabbrev #b /**************************************** + :iabbrev #e <Space>****************************************/ + +These are used for creating boxed comments. The comment starts with #b, which +draws the top line. I then type the comment text and use #e to draw the +bottom line. + Notice that the #e abbreviation begins with a space. In other words, the +first two characters are space-star. Usually Vim ignores spaces between the +abbreviation and the expansion. To avoid that problem, I spell space as seven +characters: <, S, p, a, c, e, >. + + Note: + ":iabbrev" is a long word to type. ":iab" works just as well. + That's abbreviating the abbreviate command! + + +FIXING TYPING MISTAKES + +It's very common to make the same typing mistake every time. For example, +typing "teh" instead of "the". You can fix this with an abbreviation: > + + :abbreviate teh the + +You can add a whole list of these. Add one each time you discover a common +mistake. + + +LISTING ABBREVIATIONS + +The ":abbreviate" command lists the abbreviations: + + :abbreviate + i #e ****************************************/ + i #b /**************************************** + i JB Jack Benny + i ad advertisement + ! teh the + +The "i" in the first column indicates Insert mode. These abbreviations are +only active in Insert mode. Other possible characters are: + + c Command-line mode :cabbrev + ! both Insert and Command-line mode :abbreviate + +Since abbreviations are not often useful in Command-line mode, you will mostly +use the ":iabbrev" command. That avoids, for example, that "ad" gets expanded +when typing a command like: > + + :edit ad + + +DELETING ABBREVIATIONS + +To get rid of an abbreviation, use the ":unabbreviate" command. Suppose you +have the following abbreviation: > + + :abbreviate @f fresh + +You can remove it with this command: > + + :unabbreviate @f + +While you type this, you will notice that @f is expanded to "fresh". Don't +worry about this, Vim understands it anyway (except when you have an +abbreviation for "fresh", but that's very unlikely). + To remove all the abbreviations: > + + :abclear + +":unabbreviate" and ":abclear" also come in the variants for Insert mode +(":iunabbreviate and ":iabclear") and Command-line mode (":cunabbreviate" and +":cabclear"). + + +REMAPPING ABBREVIATIONS + +There is one thing to watch out for when defining an abbreviation: The +resulting string should not be mapped. For example: > + + :abbreviate @a adder + :imap dd disk-door + +When you now type @a, you will get "adisk-doorer". That's not what you want. +To avoid this, use the ":noreabbrev" command. It does the same as +":abbreviate", but avoids that the resulting string is used for mappings: > + + :noreabbrev @a adder + +Fortunately, it's unlikely that the result of an abbreviation is mapped. + +============================================================================== +*24.8* Entering special characters + +The CTRL-V command is used to insert the next character literally. In other +words, any special meaning the character has, it will be ignored. For +example: > + + CTRL-V <Esc> + +Inserts an escape character. Thus you don't leave Insert mode. (Don't type +the space after CTRL-V, it's only to make this easier to read). + + Note: + On MS-Windows CTRL-V is used to paste text. Use CTRL-Q instead of + CTRL-V. On Unix, on the other hand, CTRL-Q does not work on some + terminals, because it has a special meaning. + +You can also use the command CTRL-V {digits} to insert a character with the +decimal number {digits}. For example, the character number 127 is the <Del> +character (but not necessarily the <Del> key!). To insert <Del> type: > + + CTRL-V 127 + +You can enter characters up to 255 this way. When you type fewer than two +digits, a non-digit will terminate the command. To avoid the need of typing a +non-digit, prepend one or two zeros to make three digits. + All the next commands insert a <Tab> and then a dot: + + CTRL-V 9. + CTRL-V 09. + CTRL-V 009. + +To enter a character in hexadecimal, use an "x" after the CTRL-V: > + + CTRL-V x7f + +This also goes up to character 255 (CTRL-V xff). You can use "o" to type a +character as an octal number and two more methods allow you to type up to +a 16 bit and a 32 bit number (e.g., for a Unicode character): > + + CTRL-V o123 + CTRL-V u1234 + CTRL-V U12345678 + +============================================================================== +*24.9* Digraphs + +Some characters are not on the keyboard. For example, the copyright character +(©). To type these characters in Vim, you use digraphs, where two characters +represent one. To enter a ©, for example, you press three keys: > + + CTRL-K Co + +To find out what digraphs are available, use the following command: > + + :digraphs + +Vim will display the digraph table. Here are three lines of it: + + AC ~_ 159 NS | 160 !I ¡ 161 Ct ¢ 162 Pd £ 163 Cu ¤ 164 Ye ¥ 165 ~ + BB ¦ 166 SE § 167 ': ¨ 168 Co © 169 -a ª 170 << « 171 NO ¬ 172 ~ + -- ­ 173 Rg ® 174 'm ¯ 175 DG ° 176 +- ± 177 2S ² 178 3S ³ 179 ~ + +This shows, for example, that the digraph you get by typing CTRL-K Pd is the +character (£). This is character number 163 (decimal). + Pd is short for Pound. Most digraphs are selected to give you a hint about +the character they will produce. If you look through the list you will +understand the logic. + You can exchange the first and second character, if there is no digraph for +that combination. Thus CTRL-K dP also works. Since there is no digraph for +"dP" Vim will also search for a "Pd" digraph. + + Note: + The digraphs depend on the character set that Vim assumes you are + using. On MS-DOS they are different from MS-Windows. Always use + ":digraphs" to find out which digraphs are currently available. + +You can define your own digraphs. Example: > + + :digraph a" ä + +This defines that CTRL-K a" inserts an ä character. You can also specify the +character with a decimal number. This defines the same digraph: > + + :digraph a" 228 + +More information about digraphs here: |digraphs| + Another way to insert special characters is with a keymap. More about that +here: |45.5| + +============================================================================== +*24.10* Normal mode commands + +Insert mode offers a limited number of commands. In Normal mode you have many +more. When you want to use one, you usually leave Insert mode with <Esc>, +execute the Normal mode command, and re-enter Insert mode with "i" or "a". + There is a quicker way. With CTRL-O {command} you can execute any Normal +mode command from Insert mode. For example, to delete from the cursor to the +end of the line: > + + CTRL-O D + +You can execute only one Normal mode command this way. But you can specify a +register or a count. A more complicated example: > + + CTRL-O "g3dw + +This deletes up to the third word into register g. + +============================================================================== + +Next chapter: |usr_25.txt| Editing formatted text + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_25.txt b/share/vim/vim73/doc/usr_25.txt new file mode 100644 index 0000000000..3cc46e250a --- /dev/null +++ b/share/vim/vim73/doc/usr_25.txt @@ -0,0 +1,578 @@ +*usr_25.txt* For Vim version 7.3. Last change: 2007 May 11 + + VIM USER MANUAL - by Bram Moolenaar + + Editing formatted text + + +Text hardly ever comes in one sentence per line. This chapter is about +breaking sentences to make them fit on a page and other formatting. +Vim also has useful features for editing single-line paragraphs and tables. + +|25.1| Breaking lines +|25.2| Aligning text +|25.3| Indents and tabs +|25.4| Dealing with long lines +|25.5| Editing tables + + Next chapter: |usr_26.txt| Repeating + Previous chapter: |usr_24.txt| Inserting quickly +Table of contents: |usr_toc.txt| + +============================================================================== +*25.1* Breaking lines + +Vim has a number of functions that make dealing with text easier. By default, +the editor does not perform automatic line breaks. In other words, you have +to press <Enter> yourself. This is useful when you are writing programs where +you want to decide where the line ends. It is not so good when you are +creating documentation and want the text to be at most 70 character wide. + If you set the 'textwidth' option, Vim automatically inserts line breaks. +Suppose, for example, that you want a very narrow column of only 30 +characters. You need to execute the following command: > + + :set textwidth=30 + +Now you start typing (ruler added): + + 1 2 3 + 12345678901234567890123456789012345 + I taught programming for a whi ~ + +If you type "l" next, this makes the line longer than the 30-character limit. +When Vim sees this, it inserts a line break and you get the following: + + 1 2 3 + 12345678901234567890123456789012345 + I taught programming for a ~ + whil ~ + +Continuing on, you can type in the rest of the paragraph: + + 1 2 3 + 12345678901234567890123456789012345 + I taught programming for a ~ + while. One time, I was stopped ~ + by the Fort Worth police, ~ + because my homework was too ~ + hard. True story. ~ + +You do not have to type newlines; Vim puts them in automatically. + + Note: + The 'wrap' option makes Vim display lines with a line break, but this + doesn't insert a line break in the file. + + +REFORMATTING + +The Vim editor is not a word processor. In a word processor, if you delete +something at the beginning of the paragraph, the line breaks are reworked. In +Vim they are not; so if you delete the word "programming" from the first line, +all you get is a short line: + + 1 2 3 + 12345678901234567890123456789012345 + I taught for a ~ + while. One time, I was stopped ~ + by the Fort Worth police, ~ + because my homework was too ~ + hard. True story. ~ + +This does not look good. To get the paragraph into shape you use the "gq" +operator. + Let's first use this with a Visual selection. Starting from the first +line, type: > + + v4jgq + +"v" to start Visual mode, "4j' to move to the end of the paragraph and then +the "gq" operator. The result is: + + 1 2 3 + 12345678901234567890123456789012345 + I taught for a while. One ~ + time, I was stopped by the ~ + Fort Worth police, because my ~ + homework was too hard. True ~ + story. ~ + +Note: there is a way to do automatic formatting for specific types of text +layouts, see |auto-format|. + +Since "gq" is an operator, you can use one of the three ways to select the +text it works on: With Visual mode, with a movement and with a text object. + The example above could also be done with "gq4j". That's less typing, but +you have to know the line count. A more useful motion command is "}". This +moves to the end of a paragraph. Thus "gq}" formats from the cursor to the +end of the current paragraph. + A very useful text object to use with "gq" is the paragraph. Try this: > + + gqap + +"ap" stands for "a-paragraph". This formats the text of one paragraph +(separated by empty lines). Also the part before the cursor. + If you have your paragraphs separated by empty lines, you can format the +whole file by typing this: > + + gggqG + +"gg" to move to the first line, "gqG" to format until the last line. + Warning: If your paragraphs are not properly separated, they will be joined +together. A common mistake is to have a line with a space or tab. That's a +blank line, but not an empty line. + +Vim is able to format more than just plain text. See |fo-table| for how to +change this. See the 'joinspaces' option to change the number of spaces used +after a full stop. + It is possible to use an external program for formatting. This is useful +if your text can't be properly formatted with Vim's builtin command. See the +'formatprg' option. + +============================================================================== +*25.2* Aligning text + +To center a range of lines, use the following command: > + + :{range}center [width] + +{range} is the usual command-line range. [width] is an optional line width to +use for centering. If [width] is not specified, it defaults to the value of +'textwidth'. (If 'textwidth' is 0, the default is 80.) + For example: > + + :1,5center 40 + +results in the following: + + I taught for a while. One ~ + time, I was stopped by the ~ + Fort Worth police, because my ~ + homework was too hard. True ~ + story. ~ + + +RIGHT ALIGNMENT + +Similarly, the ":right" command right-justifies the text: > + + :1,5right 37 + +gives this result: + + I taught for a while. One ~ + time, I was stopped by the ~ + Fort Worth police, because my ~ + homework was too hard. True ~ + story. ~ + +LEFT ALIGNMENT + +Finally there is this command: > + + :{range}left [margin] + +Unlike ":center" and ":right", however, the argument to ":left" is not the +length of the line. Instead it is the left margin. If it is omitted, the +text will be put against the left side of the screen (using a zero margin +would do the same). If it is 5, the text will be indented 5 spaces. For +example, use these commands: > + + :1left 5 + :2,5left + +This results in the following: + + I taught for a while. One ~ + time, I was stopped by the ~ + Fort Worth police, because my ~ + homework was too hard. True ~ + story. ~ + + +JUSTIFYING TEXT + +Vim has no built-in way of justifying text. However, there is a neat macro +package that does the job. To use this package, execute the following +command: > + + :runtime macros/justify.vim + +This Vim script file defines a new visual command "_j". To justify a block of +text, highlight the text in Visual mode and then execute "_j". + Look in the file for more explanations. To go there, do "gf" on this name: +$VIMRUNTIME/macros/justify.vim. + +An alternative is to filter the text through an external program. Example: > + + :%!fmt + +============================================================================== +*25.3* Indents and tabs + +Indents can be used to make text stand out from the rest. The example texts +in this manual, for example, are indented by eight spaces or a tab. You would +normally enter this by typing a tab at the start of each line. Take this +text: + the first line ~ + the second line ~ + +This is entered by typing a tab, some text, <Enter>, tab and more text. + The 'autoindent' option inserts indents automatically: > + + :set autoindent + +When a new line is started it gets the same indent as the previous line. In +the above example, the tab after the <Enter> is not needed anymore. + + +INCREASING INDENT + +To increase the amount of indent in a line, use the ">" operator. Often this +is used as ">>", which adds indent to the current line. + The amount of indent added is specified with the 'shiftwidth' option. The +default value is 8. To make ">>" insert four spaces worth of indent, for +example, type this: > + + :set shiftwidth=4 + +When used on the second line of the example text, this is what you get: + + the first line ~ + the second line ~ + +"4>>" will increase the indent of four lines. + + +TABSTOP + +If you want to make indents a multiple of 4, you set 'shiftwidth' to 4. But +when pressing a <Tab> you still get 8 spaces worth of indent. To change this, +set the 'softtabstop' option: > + + :set softtabstop=4 + +This will make the <Tab> key insert 4 spaces worth of indent. If there are +already four spaces, a <Tab> character is used (saving seven characters in the +file). (If you always want spaces and no tab characters, set the 'expandtab' +option.) + + Note: + You could set the 'tabstop' option to 4. However, if you edit the + file another time, with 'tabstop' set to the default value of 8, it + will look wrong. In other programs and when printing the indent will + also be wrong. Therefore it is recommended to keep 'tabstop' at eight + all the time. That's the standard value everywhere. + + +CHANGING TABS + +You edit a file which was written with a tabstop of 3. In Vim it looks ugly, +because it uses the normal tabstop value of 8. You can fix this by setting +'tabstop' to 3. But you have to do this every time you edit this file. + Vim can change the use of tabstops in your file. First, set 'tabstop' to +make the indents look good, then use the ":retab" command: > + + :set tabstop=3 + :retab 8 + +The ":retab" command will change 'tabstop' to 8, while changing the text such +that it looks the same. It changes spans of white space into tabs and spaces +for this. You can now write the file. Next time you edit it the indents will +be right without setting an option. + Warning: When using ":retab" on a program, it may change white space inside +a string constant. Therefore it's a good habit to use "\t" instead of a +real tab. + +============================================================================== +*25.4* Dealing with long lines + +Sometimes you will be editing a file that is wider than the number of columns +in the window. When that occurs, Vim wraps the lines so that everything fits +on the screen. + If you switch the 'wrap' option off, each line in the file shows up as one +line on the screen. Then the ends of the long lines disappear off the screen +to the right. + When you move the cursor to a character that can't be seen, Vim will scroll +the text to show it. This is like moving a viewport over the text in the +horizontal direction. + By default, Vim does not display a horizontal scrollbar in the GUI. If you +want to enable one, use the following command: > + + :set guioptions+=b + +One horizontal scrollbar will appear at the bottom of the Vim window. + +If you don't have a scrollbar or don't want to use it, use these commands to +scroll the text. The cursor will stay in the same place, but it's moved back +into the visible text if necessary. + + zh scroll right + 4zh scroll four characters right + zH scroll half a window width right + ze scroll right to put the cursor at the end + zl scroll left + 4zl scroll four characters left + zL scroll half a window width left + zs scroll left to put the cursor at the start + +Let's attempt to show this with one line of text. The cursor is on the "w" of +"which". The "current window" above the line indicates the text that is +currently visible. The "window"s below the text indicate the text that is +visible after the command left of it. + + |<-- current window -->| + some long text, part of which is visible in the window ~ + ze |<-- window -->| + zH |<-- window -->| + 4zh |<-- window -->| + zh |<-- window -->| + zl |<-- window -->| + 4zl |<-- window -->| + zL |<-- window -->| + zs |<-- window -->| + + +MOVING WITH WRAP OFF + +When 'wrap' is off and the text has scrolled horizontally, you can use the +following commands to move the cursor to a character you can see. Thus text +left and right of the window is ignored. These never cause the text to +scroll: + + g0 to first visible character in this line + g^ to first non-blank visible character in this line + gm to middle of this line + g$ to last visible character in this line + + |<-- window -->| + some long text, part of which is visible ~ + g0 g^ gm g$ + + +BREAKING AT WORDS *edit-no-break* + +When preparing text for use by another program, you might have to make +paragraphs without a line break. A disadvantage of using 'nowrap' is that you +can't see the whole sentence you are working on. When 'wrap' is on, words are +broken halfway, which makes them hard to read. + A good solution for editing this kind of paragraph is setting the +'linebreak' option. Vim then breaks lines at an appropriate place when +displaying the line. The text in the file remains unchanged. + Without 'linebreak' text might look like this: + + +---------------------------------+ + |letter generation program for a b| + |ank. They wanted to send out a s| + |pecial, personalized letter to th| + |eir richest 1000 customers. Unfo| + |rtunately for the programmer, he | + +---------------------------------+ +After: > + + :set linebreak + +it looks like this: + + +---------------------------------+ + |letter generation program for a | + |bank. They wanted to send out a | + |special, personalized letter to | + |their richest 1000 customers. | + |Unfortunately for the programmer,| + +---------------------------------+ + +Related options: +'breakat' specifies the characters where a break can be inserted. +'showbreak' specifies a string to show at the start of broken line. +Set 'textwidth' to zero to avoid a paragraph to be split. + + +MOVING BY VISIBLE LINES + +The "j" and "k" commands move to the next and previous lines. When used on +a long line, this means moving a lot of screen lines at once. + To move only one screen line, use the "gj" and "gk" commands. When a line +doesn't wrap they do the same as "j" and "k". When the line does wrap, they +move to a character displayed one line below or above. + You might like to use these mappings, which bind these movement commands to +the cursor keys: > + + :map <Up> gk + :map <Down> gj + + +TURNING A PARAGRAPH INTO ONE LINE + +If you want to import text into a program like MS-Word, each paragraph should +be a single line. If your paragraphs are currently separated with empty +lines, this is how you turn each paragraph into a single line: > + + :g/./,/^$/join + +That looks complicated. Let's break it up in pieces: + + :g/./ A ":global" command that finds all lines that contain + at least one character. + ,/^$/ A range, starting from the current line (the non-empty + line) until an empty line. + join The ":join" command joins the range of lines together + into one line. + +Starting with this text, containing eight lines broken at column 30: + + +----------------------------------+ + |A letter generation program | + |for a bank. They wanted to | + |send out a special, | + |personalized letter. | + | | + |To their richest 1000 | + |customers. Unfortunately for | + |the programmer, | + +----------------------------------+ + +You end up with two lines: + + +----------------------------------+ + |A letter generation program for a | + |bank. They wanted to send out a s| + |pecial, personalized letter. | + |To their richest 1000 customers. | + |Unfortunately for the programmer, | + +----------------------------------+ + +Note that this doesn't work when the separating line is blank but not empty; +when it contains spaces and/or tabs. This command does work with blank lines: +> + :g/\S/,/^\s*$/join + +This still requires a blank or empty line at the end of the file for the last +paragraph to be joined. + +============================================================================== +*25.5* Editing tables + +Suppose you are editing a table with four columns: + + nice table test 1 test 2 test 3 ~ + input A 0.534 ~ + input B 0.913 ~ + +You need to enter numbers in the third column. You could move to the second +line, use "A", enter a lot of spaces and type the text. + For this kind of editing there is a special option: > + + set virtualedit=all + +Now you can move the cursor to positions where there isn't any text. This is +called "virtual space". Editing a table is a lot easier this way. + Move the cursor by searching for the header of the last column: > + + /test 3 + +Now press "j" and you are right where you can enter the value for "input A". +Typing "0.693" results in: + + nice table test 1 test 2 test 3 ~ + input A 0.534 0.693 ~ + input B 0.913 ~ + +Vim has automatically filled the gap in front of the new text for you. Now, +to enter the next field in this column use "Bj". "B" moves back to the start +of a white space separated word. Then "j" moves to the place where the next +field can be entered. + + Note: + You can move the cursor anywhere in the display, also beyond the end + of a line. But Vim will not insert spaces there, until you insert a + character in that position. + + +COPYING A COLUMN + +You want to add a column, which should be a copy of the third column and +placed before the "test 1" column. Do this in seven steps: +1. Move the cursor to the left upper corner of this column, e.g., with + "/test 3". +2. Press CTRL-V to start blockwise Visual mode. +3. Move the cursor down two lines with "2j". You are now in "virtual space": + the "input B" line of the "test 3" column. +4. Move the cursor right, to include the whole column in the selection, plus + the space that you want between the columns. "9l" should do it. +5. Yank the selected rectangle with "y". +6. Move the cursor to "test 1", where the new column must be placed. +7. Press "P". + +The result should be: + + nice table test 3 test 1 test 2 test 3 ~ + input A 0.693 0.534 0.693 ~ + input B 0.913 ~ + +Notice that the whole "test 1" column was shifted right, also the line where +the "test 3" column didn't have text. + +Go back to non-virtual cursor movements with: > + + :set virtualedit= + + +VIRTUAL REPLACE MODE + +The disadvantage of using 'virtualedit' is that it "feels" different. You +can't recognize tabs or spaces beyond the end of line when moving the cursor +around. Another method can be used: Virtual Replace mode. + Suppose you have a line in a table that contains both tabs and other +characters. Use "rx" on the first tab: + + inp 0.693 0.534 0.693 ~ + + | + rx | + V + + inpx0.693 0.534 0.693 ~ + +The layout is messed up. To avoid that, use the "gr" command: + + inp 0.693 0.534 0.693 ~ + + | + grx | + V + + inpx 0.693 0.534 0.693 ~ + +What happens is that the "gr" command makes sure the new character takes the +right amount of screen space. Extra spaces or tabs are inserted to fill the +gap. Thus what actually happens is that a tab is replaced by "x" and then +blanks added to make the text after it keep its place. In this case a +tab is inserted. + When you need to replace more than one character, you use the "R" command +to go to Replace mode (see |04.9|). This messes up the layout and replaces +the wrong characters: + + inp 0 0.534 0.693 ~ + + | + R0.786 | + V + + inp 0.78634 0.693 ~ + +The "gR" command uses Virtual Replace mode. This preserves the layout: + + inp 0 0.534 0.693 ~ + + | + gR0.786 | + V + + inp 0.786 0.534 0.693 ~ + +============================================================================== + +Next chapter: |usr_26.txt| Repeating + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_26.txt b/share/vim/vim73/doc/usr_26.txt new file mode 100644 index 0000000000..e32802c84b --- /dev/null +++ b/share/vim/vim73/doc/usr_26.txt @@ -0,0 +1,221 @@ +*usr_26.txt* For Vim version 7.3. Last change: 2006 Apr 24 + + VIM USER MANUAL - by Bram Moolenaar + + Repeating + + +An editing task is hardly ever unstructured. A change often needs to be made +several times. In this chapter a number of useful ways to repeat a change +will be explained. + +|26.1| Repeating with Visual mode +|26.2| Add and subtract +|26.3| Making a change in many files +|26.4| Using Vim from a shell script + + Next chapter: |usr_27.txt| Search commands and patterns + Previous chapter: |usr_25.txt| Editing formatted text +Table of contents: |usr_toc.txt| + +============================================================================== +*26.1* Repeating with Visual mode + +Visual mode is very handy for making a change in any sequence of lines. You +can see the highlighted text, thus you can check if the correct lines are +changed. But making the selection takes some typing. The "gv" command +selects the same area again. This allows you to do another operation on the +same text. + Suppose you have some lines where you want to change "2001" to "2002" and +"2000" to "2001": + + The financial results for 2001 are better ~ + than for 2000. The income increased by 50%, ~ + even though 2001 had more rain than 2000. ~ + 2000 2001 ~ + income 45,403 66,234 ~ + +First change "2001" to "2002". Select the lines in Visual mode, and use: > + + :s/2001/2002/g + +Now use "gv" to reselect the same text. It doesn't matter where the cursor +is. Then use ":s/2000/2001/g" to make the second change. + Obviously, you can repeat these changes several times. + +============================================================================== +*26.2* Add and subtract + +When repeating the change of one number into another, you often have a fixed +offset. In the example above, one was added to each year. Instead of typing +a substitute command for each year that appears, the CTRL-A command can be +used. + Using the same text as above, search for a year: > + + /19[0-9][0-9]\|20[0-9][0-9] + +Now press CTRL-A. The year will be increased by one: + + The financial results for 2002 are better ~ + than for 2000. The income increased by 50%, ~ + even though 2001 had more rain than 2000. ~ + 2000 2001 ~ + income 45,403 66,234 ~ + +Use "n" to find the next year, and press "." to repeat the CTRL-A ("." is a +bit quicker to type). Repeat "n" and "." for all years that appear. + Hint: set the 'hlsearch' option to see the matches you are going to change, +then you can look ahead and do it faster. + +Adding more than one can be done by prepending the number to CTRL-A. Suppose +you have this list: + + 1. item four ~ + 2. item five ~ + 3. item six ~ + +Move the cursor to "1." and type: > + + 3 CTRL-A + +The "1." will change to "4.". Again, you can use "." to repeat this on the +other numbers. + +Another example: + + 006 foo bar ~ + 007 foo bar ~ + +Using CTRL-A on these numbers results in: + + 007 foo bar ~ + 010 foo bar ~ + +7 plus one is 10? What happened here is that Vim recognized "007" as an octal +number, because there is a leading zero. This notation is often used in C +programs. If you do not want a number with leading zeros to be handled as +octal, use this: > + + :set nrformats-=octal + +The CTRL-X command does subtraction in a similar way. + +============================================================================== +*26.3* Making a change in many files + +Suppose you have a variable called "x_cnt" and you want to change it to +"x_counter". This variable is used in several of your C files. You need to +change it in all files. This is how you do it. + Put all the relevant files in the argument list: > + + :args *.c +< +This finds all C files and edits the first one. Now you can perform a +substitution command on all these files: > + + :argdo %s/\<x_cnt\>/x_counter/ge | update + +The ":argdo" command takes an argument that is another command. That command +will be executed on all files in the argument list. + The "%s" substitute command that follows works on all lines. It finds the +word "x_cnt" with "\<x_cnt\>". The "\<" and "\>" are used to match the whole +word only, and not "px_cnt" or "x_cnt2". + The flags for the substitute command include "g" to replace all occurrences +of "x_cnt" in the same line. The "e" flag is used to avoid an error message +when "x_cnt" does not appear in the file. Otherwise ":argdo" would abort on +the first file where "x_cnt" was not found. + The "|" separates two commands. The following "update" command writes the +file only if it was changed. If no "x_cnt" was changed to "x_counter" nothing +happens. + +There is also the ":windo" command, which executes its argument in all +windows. And ":bufdo" executes its argument on all buffers. Be careful with +this, because you might have more files in the buffer list than you think. +Check this with the ":buffers" command (or ":ls"). + +============================================================================== +*26.4* Using Vim from a shell script + +Suppose you have a lot of files in which you need to change the string +"-person-" to "Jones" and then print it. How do you do that? One way is to +do a lot of typing. The other is to write a shell script to do the work. + The Vim editor does a superb job as a screen-oriented editor when using +Normal mode commands. For batch processing, however, Normal mode commands do +not result in clear, commented command files; so here you will use Ex mode +instead. This mode gives you a nice command-line interface that makes it easy +to put into a batch file. ("Ex command" is just another name for a +command-line (:) command.) + The Ex mode commands you need are as follows: > + + %s/-person-/Jones/g + write tempfile + quit + +You put these commands in the file "change.vim". Now to run the editor in +batch mode, use this shell script: > + + for file in *.txt; do + vim -e -s $file < change.vim + lpr -r tempfile + done + +The for-done loop is a shell construct to repeat the two lines in between, +while the $file variable is set to a different file name each time. + The second line runs the Vim editor in Ex mode (-e argument) on the file +$file and reads commands from the file "change.vim". The -s argument tells +Vim to operate in silent mode. In other words, do not keep outputting the +:prompt, or any other prompt for that matter. + The "lpr -r tempfile" command prints the resulting "tempfile" and deletes +it (that's what the -r argument does). + + +READING FROM STDIN + +Vim can read text on standard input. Since the normal way is to read commands +there, you must tell Vim to read text instead. This is done by passing the +"-" argument in place of a file. Example: > + + ls | vim - + +This allows you to edit the output of the "ls" command, without first saving +the text in a file. + If you use the standard input to read text from, you can use the "-S" +argument to read a script: > + + producer | vim -S change.vim - + + +NORMAL MODE SCRIPTS + +If you really want to use Normal mode commands in a script, you can use it +like this: > + + vim -s script file.txt ... +< + Note: + "-s" has a different meaning when it is used without "-e". Here it + means to source the "script" as Normal mode commands. When used with + "-e" it means to be silent, and doesn't use the next argument as a + file name. + +The commands in "script" are executed like you typed them. Don't forget that +a line break is interpreted as pressing <Enter>. In Normal mode that moves +the cursor to the next line. + To create the script you can edit the script file and type the commands. +You need to imagine what the result would be, which can be a bit difficult. +Another way is to record the commands while you perform them manually. This +is how you do that: > + + vim -w script file.txt ... + +All typed keys will be written to "script". If you make a small mistake you +can just continue and remember to edit the script later. + The "-w" argument appends to an existing script. That is good when you +want to record the script bit by bit. If you want to start from scratch and +start all over, use the "-W" argument. It overwrites any existing file. + +============================================================================== + +Next chapter: |usr_27.txt| Search commands and patterns + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_27.txt b/share/vim/vim73/doc/usr_27.txt new file mode 100644 index 0000000000..107411ea1c --- /dev/null +++ b/share/vim/vim73/doc/usr_27.txt @@ -0,0 +1,563 @@ +*usr_27.txt* For Vim version 7.3. Last change: 2010 Mar 28 + + VIM USER MANUAL - by Bram Moolenaar + + Search commands and patterns + + +In chapter 3 a few simple search patterns were mentioned |03.9|. Vim can do +much more complex searches. This chapter explains the most often used ones. +A detailed specification can be found here: |pattern| + +|27.1| Ignoring case +|27.2| Wrapping around the file end +|27.3| Offsets +|27.4| Matching multiple times +|27.5| Alternatives +|27.6| Character ranges +|27.7| Character classes +|27.8| Matching a line break +|27.9| Examples + + Next chapter: |usr_28.txt| Folding + Previous chapter: |usr_26.txt| Repeating +Table of contents: |usr_toc.txt| + +============================================================================== +*27.1* Ignoring case + +By default, Vim's searches are case sensitive. Therefore, "include", +"INCLUDE", and "Include" are three different words and a search will match +only one of them. + Now switch on the 'ignorecase' option: > + + :set ignorecase + +Search for "include" again, and now it will match "Include", "INCLUDE" and +"InClUDe". (Set the 'hlsearch' option to quickly see where a pattern +matches.) + You can switch this off again with: > + + :set noignorecase + +But let's keep it set, and search for "INCLUDE". It will match exactly the +same text as "include" did. Now set the 'smartcase' option: > + + :set ignorecase smartcase + +If you have a pattern with at least one uppercase character, the search +becomes case sensitive. The idea is that you didn't have to type that +uppercase character, so you must have done it because you wanted case to +match. That's smart! + With these two options set you find the following matches: + + pattern matches ~ + word word, Word, WORD, WoRd, etc. + Word Word + WORD WORD + WoRd WoRd + + +CASE IN ONE PATTERN + +If you want to ignore case for one specific pattern, you can do this by +prepending the "\c" string. Using "\C" will make the pattern to match case. +This overrules the 'ignorecase' and 'smartcase' options, when "\c" or "\C" is +used their value doesn't matter. + + pattern matches ~ + \Cword word + \CWord Word + \cword word, Word, WORD, WoRd, etc. + \cWord word, Word, WORD, WoRd, etc. + +A big advantage of using "\c" and "\C" is that it sticks with the pattern. +Thus if you repeat a pattern from the search history, the same will happen, no +matter if 'ignorecase' or 'smartcase' was changed. + + Note: + The use of "\" items in search patterns depends on the 'magic' option. + In this chapter we will assume 'magic' is on, because that is the + standard and recommended setting. If you would change 'magic', many + search patterns would suddenly become invalid. + + Note: + If your search takes much longer than you expected, you can interrupt + it with CTRL-C on Unix and CTRL-Break on MS-DOS and MS-Windows. + +============================================================================== +*27.2* Wrapping around the file end + +By default, a forward search starts searching for the given string at the +current cursor location. It then proceeds to the end of the file. If it has +not found the string by that time, it starts from the beginning and searches +from the start of the file to the cursor location. + Keep in mind that when repeating the "n" command to search for the next +match, you eventually get back to the first match. If you don't notice this +you keep searching forever! To give you a hint, Vim displays this message: + + search hit BOTTOM, continuing at TOP ~ + +If you use the "?" command, to search in the other direction, you get this +message: + + search hit TOP, continuing at BOTTOM ~ + +Still, you don't know when you are back at the first match. One way to see +this is by switching on the 'ruler' option: > + + :set ruler + +Vim will display the cursor position in the lower righthand corner of the +window (in the status line if there is one). It looks like this: + + 101,29 84% ~ + +The first number is the line number of the cursor. Remember the line number +where you started, so that you can check if you passed this position again. + + +NOT WRAPPING + +To turn off search wrapping, use the following command: > + + :set nowrapscan + +Now when the search hits the end of the file, an error message displays: + + E385: search hit BOTTOM without match for: forever ~ + +Thus you can find all matches by going to the start of the file with "gg" and +keep searching until you see this message. + If you search in the other direction, using "?", you get: + + E384: search hit TOP without match for: forever ~ + +============================================================================== +*27.3* Offsets + +By default, the search command leaves the cursor positioned on the beginning +of the pattern. You can tell Vim to leave it some other place by specifying +an offset. For the forward search command "/", the offset is specified by +appending a slash (/) and the offset: > + + /default/2 + +This command searches for the pattern "default" and then moves to the +beginning of the second line past the pattern. Using this command on the +paragraph above, Vim finds the word "default" in the first line. Then the +cursor is moved two lines down and lands on "an offset". + +If the offset is a simple number, the cursor will be placed at the beginning +of the line that many lines from the match. The offset number can be positive +or negative. If it is positive, the cursor moves down that many lines; if +negative, it moves up. + + +CHARACTER OFFSETS + +The "e" offset indicates an offset from the end of the match. It moves the +cursor onto the last character of the match. The command: > + + /const/e + +puts the cursor on the "t" of "const". + From that position, adding a number moves forward that many characters. +This command moves to the character just after the match: > + + /const/e+1 + +A positive number moves the cursor to the right, a negative number moves it to +the left. For example: > + + /const/e-1 + +moves the cursor to the "s" of "const". + +If the offset begins with "b", the cursor moves to the beginning of the +pattern. That's not very useful, since leaving out the "b" does the same +thing. It does get useful when a number is added or subtracted. The cursor +then goes forward or backward that many characters. For example: > + + /const/b+2 + +Moves the cursor to the beginning of the match and then two characters to the +right. Thus it lands on the "n". + + +REPEATING + +To repeat searching for the previously used search pattern, but with a +different offset, leave out the pattern: > + + /that + //e + +Is equal to: > + + /that/e + +To repeat with the same offset: > + + / + +"n" does the same thing. To repeat while removing a previously used offset: > + + // + + +SEARCHING BACKWARDS + +The "?" command uses offsets in the same way, but you must use "?" to separate +the offset from the pattern, instead of "/": > + + ?const?e-2 + +The "b" and "e" keep their meaning, they don't change direction with the use +of "?". + + +START POSITION + +When starting a search, it normally starts at the cursor position. When you +specify a line offset, this can cause trouble. For example: > + + /const/-2 + +This finds the next word "const" and then moves two lines up. If you +use "n" to search again, Vim could start at the current position and find the same +"const" match. Then using the offset again, you would be back where you started. +You would be stuck! + It could be worse: Suppose there is another match with "const" in the next +line. Then repeating the forward search would find this match and move two +lines up. Thus you would actually move the cursor back! + +When you specify a character offset, Vim will compensate for this. Thus the +search starts a few characters forward or backward, so that the same match +isn't found again. + +============================================================================== +*27.4* Matching multiple times + +The "*" item specifies that the item before it can match any number of times. +Thus: > + + /a* + +matches "a", "aa", "aaa", etc. But also "" (the empty string), because zero +times is included. + The "*" only applies to the item directly before it. Thus "ab*" matches +"a", "ab", "abb", "abbb", etc. To match a whole string multiple times, it +must be grouped into one item. This is done by putting "\(" before it and +"\)" after it. Thus this command: > + + /\(ab\)* + +Matches: "ab", "abab", "ababab", etc. And also "". + +To avoid matching the empty string, use "\+". This makes the previous item +match one or more times. > + + /ab\+ + +Matches "ab", "abb", "abbb", etc. It does not match "a" when no "b" follows. + +To match an optional item, use "\=". Example: > + + /folders\= + +Matches "folder" and "folders". + + +SPECIFIC COUNTS + +To match a specific number of items use the form "\{n,m}". "n" and "m" are +numbers. The item before it will be matched "n" to "m" times |inclusive|. +Example: > + + /ab\{3,5} + +matches "abbb", "abbbb" and "abbbbb". + When "n" is omitted, it defaults to zero. When "m" is omitted it defaults +to infinity. When ",m" is omitted, it matches exactly "n" times. +Examples: + + pattern match count ~ + \{,4} 0, 1, 2, 3 or 4 + \{3,} 3, 4, 5, etc. + \{0,1} 0 or 1, same as \= + \{0,} 0 or more, same as * + \{1,} 1 or more, same as \+ + \{3} 3 + + +MATCHING AS LITTLE AS POSSIBLE + +The items so far match as many characters as they can find. To match as few +as possible, use "\{-n,m}". It works the same as "\{n,m}", except that the +minimal amount possible is used. + For example, use: > + + /ab\{-1,3} + +Will match "ab" in "abbb". Actually, it will never match more than one b, +because there is no reason to match more. It requires something else to force +it to match more than the lower limit. + The same rules apply to removing "n" and "m". It's even possible to remove +both of the numbers, resulting in "\{-}". This matches the item before it +zero or more times, as few as possible. The item by itself always matches +zero times. It is useful when combined with something else. Example: > + + /a.\{-}b + +This matches "axb" in "axbxb". If this pattern would be used: > + + /a.*b + +It would try to match as many characters as possible with ".*", thus it +matches "axbxb" as a whole. + +============================================================================== +*27.5* Alternatives + +The "or" operator in a pattern is "\|". Example: > + + /foo\|bar + +This matches "foo" or "bar". More alternatives can be concatenated: > + + /one\|two\|three + +Matches "one", "two" and "three". + To match multiple times, the whole thing must be placed in "\(" and "\)": > + + /\(foo\|bar\)\+ + +This matches "foo", "foobar", "foofoo", "barfoobar", etc. + Another example: > + + /end\(if\|while\|for\) + +This matches "endif", "endwhile" and "endfor". + +A related item is "\&". This requires that both alternatives match in the +same place. The resulting match uses the last alternative. Example: > + + /forever\&... + +This matches "for" in "forever". It will not match "fortuin", for example. + +============================================================================== +*27.6* Character ranges + +To match "a", "b" or "c" you could use "/a\|b\|c". When you want to match all +letters from "a" to "z" this gets very long. There is a shorter method: > + + /[a-z] + +The [] construct matches a single character. Inside you specify which +characters to match. You can include a list of characters, like this: > + + /[0123456789abcdef] + +This will match any of the characters included. For consecutive characters +you can specify the range. "0-3" stands for "0123". "w-z" stands for "wxyz". +Thus the same command as above can be shortened to: > + + /[0-9a-f] + +To match the "-" character itself make it the first or last one in the range. +These special characters are accepted to make it easier to use them inside a +[] range (they can actually be used anywhere in the search pattern): + + \e <Esc> + \t <Tab> + \r <CR> + \b <BS> + +There are a few more special cases for [] ranges, see |/[]| for the whole +story. + + +COMPLEMENTED RANGE + +To avoid matching a specific character, use "^" at the start of the range. +The [] item then matches everything but the characters included. Example: > + + /"[^"]*" +< + " a double quote + [^"] any character that is not a double quote + * as many as possible + " a double quote again + +This matches "foo" and "3!x", including the double quotes. + + +PREDEFINED RANGES + +A number of ranges are used very often. Vim provides a shortcut for these. +For example: > + + /\a + +Finds alphabetic characters. This is equal to using "/[a-zA-Z]". Here are a +few more of these: + + item matches equivalent ~ + \d digit [0-9] + \D non-digit [^0-9] + \x hex digit [0-9a-fA-F] + \X non-hex digit [^0-9a-fA-F] + \s white space [ ] (<Tab> and <Space>) + \S non-white characters [^ ] (not <Tab> and <Space>) + \l lowercase alpha [a-z] + \L non-lowercase alpha [^a-z] + \u uppercase alpha [A-Z] + \U non-uppercase alpha [^A-Z] + + Note: + Using these predefined ranges works a lot faster than the character + range it stands for. + These items can not be used inside []. Thus "[\d\l]" does NOT work to + match a digit or lowercase alpha. Use "\(\d\|\l\)" instead. + +See |/\s| for the whole list of these ranges. + +============================================================================== +*27.7* Character classes + +The character range matches a fixed set of characters. A character class is +similar, but with an essential difference: The set of characters can be +redefined without changing the search pattern. + For example, search for this pattern: > + + /\f\+ + +The "\f" items stands for file name characters. Thus this matches a sequence +of characters that can be a file name. + Which characters can be part of a file name depends on the system you are +using. On MS-Windows, the backslash is included, on Unix it is not. This is +specified with the 'isfname' option. The default value for Unix is: > + + :set isfname + isfname=@,48-57,/,.,-,_,+,,,#,$,%,~,= + +For other systems the default value is different. Thus you can make a search +pattern with "\f" to match a file name, and it will automatically adjust to +the system you are using it on. + + Note: + Actually, Unix allows using just about any character in a file name, + including white space. Including these characters in 'isfname' would + be theoretically correct. But it would make it impossible to find the + end of a file name in text. Thus the default value of 'isfname' is a + compromise. + +The character classes are: + + item matches option ~ + \i identifier characters 'isident' + \I like \i, excluding digits + \k keyword characters 'iskeyword' + \K like \k, excluding digits + \p printable characters 'isprint' + \P like \p, excluding digits + \f file name characters 'isfname' + \F like \f, excluding digits + +============================================================================== +*27.8* Matching a line break + +Vim can find a pattern that includes a line break. You need to specify where +the line break happens, because all items mentioned so far don't match a line +break. + To check for a line break in a specific place, use the "\n" item: > + + /the\nword + +This will match at a line that ends in "the" and the next line starts with +"word". To match "the word" as well, you need to match a space or a line +break. The item to use for it is "\_s": > + + /the\_sword + +To allow any amount of white space: > + + /the\_s\+word + +This also matches when "the " is at the end of a line and " word" at the +start of the next one. + +"\s" matches white space, "\_s" matches white space or a line break. +Similarly, "\a" matches an alphabetic character, and "\_a" matches an +alphabetic character or a line break. The other character classes and ranges +can be modified in the same way by inserting a "_". + +Many other items can be made to match a line break by prepending "\_". For +example: "\_." matches any character or a line break. + + Note: + "\_.*" matches everything until the end of the file. Be careful with + this, it can make a search command very slow. + +Another example is "\_[]", a character range that includes a line break: > + + /"\_[^"]*" + +This finds a text in double quotes that may be split up in several lines. + +============================================================================== +*27.9* Examples + +Here are a few search patterns you might find useful. This shows how the +items mentioned above can be combined. + + +FINDING A CALIFORNIA LICENSE PLATE + +A sample license plate number is "1MGU103". It has one digit, three uppercase +letters and three digits. Directly putting this into a search pattern: > + + /\d\u\u\u\d\d\d + +Another way is to specify that there are three digits and letters with a +count: > + + /\d\u\{3}\d\{3} + +Using [] ranges instead: > + + /[0-9][A-Z]\{3}[0-9]\{3} + +Which one of these you should use? Whichever one you can remember. The +simple way you can remember is much faster than the fancy way that you can't. +If you can remember them all, then avoid the last one, because it's both more +typing and slower to execute. + + +FINDING AN IDENTIFIER + +In C programs (and many other computer languages) an identifier starts with a +letter and further consists of letters and digits. Underscores can be used +too. This can be found with: > + + /\<\h\w*\> + +"\<" and "\>" are used to find only whole words. "\h" stands for "[A-Za-z_]" +and "\w" for "[0-9A-Za-z_]". + + Note: + "\<" and "\>" depend on the 'iskeyword' option. If it includes "-", + for example, then "ident-" is not matched. In this situation use: > + + /\w\@<!\h\w*\w\@! +< + This checks if "\w" does not match before or after the identifier. + See |/\@<!| and |/\@!|. + +============================================================================== + +Next chapter: |usr_28.txt| Folding + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_28.txt b/share/vim/vim73/doc/usr_28.txt new file mode 100644 index 0000000000..8a02838d59 --- /dev/null +++ b/share/vim/vim73/doc/usr_28.txt @@ -0,0 +1,426 @@ +*usr_28.txt* For Vim version 7.3. Last change: 2008 Jun 14 + + VIM USER MANUAL - by Bram Moolenaar + + Folding + + +Structured text can be separated in sections. And sections in sub-sections. +Folding allows you to display a section as one line, providing an overview. +This chapter explains the different ways this can be done. + +|28.1| What is folding? +|28.2| Manual folding +|28.3| Working with folds +|28.4| Saving and restoring folds +|28.5| Folding by indent +|28.6| Folding with markers +|28.7| Folding by syntax +|28.8| Folding by expression +|28.9| Folding unchanged lines +|28.10| Which fold method to use? + + Next chapter: |usr_29.txt| Moving through programs + Previous chapter: |usr_27.txt| Search commands and patterns +Table of contents: |usr_toc.txt| + +============================================================================== +*28.1* What is folding? + +Folding is used to show a range of lines in the buffer as a single line on the +screen. Like a piece of paper which is folded to make it shorter: + + +------------------------+ + | line 1 | + | line 2 | + | line 3 | + |_______________________ | + \ \ + \________________________\ + / folded lines / + /________________________/ + | line 12 | + | line 13 | + | line 14 | + +------------------------+ + +The text is still in the buffer, unchanged. Only the way lines are displayed +is affected by folding. + +The advantage of folding is that you can get a better overview of the +structure of text, by folding lines of a section and replacing it with a line +that indicates that there is a section. + +============================================================================== +*28.2* Manual folding + +Try it out: Position the cursor in a paragraph and type: > + + zfap + +You will see that the paragraph is replaced by a highlighted line. You have +created a fold. |zf| is an operator and |ap| a text object selection. You +can use the |zf| operator with any movement command to create a fold for the +text that it moved over. |zf| also works in Visual mode. + +To view the text again, open the fold by typing: > + + zo + +And you can close the fold again with: > + + zc + +All the folding commands start with "z". With some fantasy, this looks like a +folded piece of paper, seen from the side. The letter after the "z" has a +mnemonic meaning to make it easier to remember the commands: + + zf F-old creation + zo O-pen a fold + zc C-lose a fold + +Folds can be nested: A region of text that contains folds can be folded +again. For example, you can fold each paragraph in this section, and then +fold all the sections in this chapter. Try it out. You will notice that +opening the fold for the whole chapter will restore the nested folds as they +were, some may be open and some may be closed. + +Suppose you have created several folds, and now want to view all the text. +You could go to each fold and type "zo". To do this faster, use this command: > + + zr + +This will R-educe the folding. The opposite is: > + + zm + +This folds M-ore. You can repeat "zr" and "zm" to open and close nested folds +of several levels. + +If you have nested several levels deep, you can open all of them with: > + + zR + +This R-educes folds until there are none left. And you can close all folds +with: > + + zM + +This folds M-ore and M-ore. + +You can quickly disable the folding with the |zn| command. Then |zN| brings +back the folding as it was. |zi| toggles between the two. This is a useful +way of working: +- create folds to get overview on your file +- move around to where you want to do your work +- do |zi| to look at the text and edit it +- do |zi| again to go back to moving around + +More about manual folding in the reference manual: |fold-manual| + +============================================================================== +*28.3* Working with folds + +When some folds are closed, movement commands like "j" and "k" move over a +fold like it was a single, empty line. This allows you to quickly move around +over folded text. + +You can yank, delete and put folds as if it was a single line. This is very +useful if you want to reorder functions in a program. First make sure that +each fold contains a whole function (or a bit less) by selecting the right +'foldmethod'. Then delete the function with "dd", move the cursor and put it +with "p". If some lines of the function are above or below the fold, you can +use Visual selection: +- put the cursor on the first line to be moved +- hit "V" to start Visual mode +- put the cursor on the last line to be moved +- hit "d" to delete the selected lines. +- move the cursor to the new position and "p"ut the lines there. + +It is sometimes difficult to see or remember where a fold is located, thus +where a |zo| command would actually work. To see the defined folds: > + + :set foldcolumn=4 + +This will show a small column on the left of the window to indicate folds. +A "+" is shown for a closed fold. A "-" is shown at the start of each open +fold and "|" at following lines of the fold. + +You can use the mouse to open a fold by clicking on the "+" in the foldcolumn. +Clicking on the "-" or a "|" below it will close an open fold. + +To open all folds at the cursor line use |zO|. +To close all folds at the cursor line use |zC|. +To delete a fold at the cursor line use |zd|. +To delete all folds at the cursor line use |zD|. + +When in Insert mode, the fold at the cursor line is never closed. That allows +you to see what you type! + +Folds are opened automatically when jumping around or moving the cursor left +or right. For example, the "0" command opens the fold under the cursor +(if 'foldopen' contains "hor", which is the default). The 'foldopen' option +can be changed to open folds for specific commands. If you want the line +under the cursor always to be open, do this: > + + :set foldopen=all + +Warning: You won't be able to move onto a closed fold then. You might want to +use this only temporarily and then set it back to the default: > + + :set foldopen& + +You can make folds close automatically when you move out of it: > + + :set foldclose=all + +This will re-apply 'foldlevel' to all folds that don't contain the cursor. +You have to try it out if you like how this feels. Use |zm| to fold more and +|zr| to fold less (reduce folds). + +The folding is local to the window. This allows you to open two windows on +the same buffer, one with folds and one without folds. Or one with all folds +closed and one with all folds open. + +============================================================================== +*28.4* Saving and restoring folds + +When you abandon a file (starting to edit another one), the state of the folds +is lost. If you come back to the same file later, all manually opened and +closed folds are back to their default. When folds have been created +manually, all folds are gone! To save the folds use the |:mkview| command: > + + :mkview + +This will store the settings and other things that influence the view on the +file. You can change what is stored with the 'viewoptions' option. +When you come back to the same file later, you can load the view again: > + + :loadview + +You can store up to ten views on one file. For example, to save the current +setup as the third view and load the second view: > + + :mkview 3 + :loadview 2 + +Note that when you insert or delete lines the views might become invalid. +Also check out the 'viewdir' option, which specifies where the views are +stored. You might want to delete old views now and then. + +============================================================================== +*28.5* Folding by indent + +Defining folds with |zf| is a lot of work. If your text is structured by +giving lower level items a larger indent, you can use the indent folding +method. This will create folds for every sequence of lines with the same +indent. Lines with a larger indent will become nested folds. This works well +with many programming languages. + +Try this by setting the 'foldmethod' option: > + + :set foldmethod=indent + +Then you can use the |zm| and |zr| commands to fold more and reduce folding. +It's easy to see on this example text: + +This line is not indented + This line is indented once + This line is indented twice + This line is indented twice + This line is indented once +This line is not indented + This line is indented once + This line is indented once + +Note that the relation between the amount of indent and the fold depth depends +on the 'shiftwidth' option. Each 'shiftwidth' worth of indent adds one to the +depth of the fold. This is called a fold level. + +When you use the |zr| and |zm| commands you actually increase or decrease the +'foldlevel' option. You could also set it directly: > + + :set foldlevel=3 + +This means that all folds with three times a 'shiftwidth' indent or more will +be closed. The lower the foldlevel, the more folds will be closed. When +'foldlevel' is zero, all folds are closed. |zM| does set 'foldlevel' to zero. +The opposite command |zR| sets 'foldlevel' to the deepest fold level that is +present in the file. + +Thus there are two ways to open and close the folds: +(A) By setting the fold level. + This gives a very quick way of "zooming out" to view the structure of the + text, move the cursor, and "zoom in" on the text again. + +(B) By using |zo| and |zc| commands to open or close specific folds. + This allows opening only those folds that you want to be open, while other + folds remain closed. + +This can be combined: You can first close most folds by using |zm| a few times +and then open a specific fold with |zo|. Or open all folds with |zR| and +then close specific folds with |zc|. + +But you cannot manually define folds when 'foldmethod' is "indent", as that +would conflict with the relation between the indent and the fold level. + +More about folding by indent in the reference manual: |fold-indent| + +============================================================================== +*28.6* Folding with markers + +Markers in the text are used to specify the start and end of a fold region. +This gives precise control over which lines are included in a fold. The +disadvantage is that the text needs to be modified. + +Try it: > + + :set foldmethod=marker + +Example text, as it could appear in a C program: + + /* foobar () {{{ */ + int foobar() + { + /* return a value {{{ */ + return 42; + /* }}} */ + } + /* }}} */ + +Notice that the folded line will display the text before the marker. This is +very useful to tell what the fold contains. + +It's quite annoying when the markers don't pair up correctly after moving some +lines around. This can be avoided by using numbered markers. Example: + + /* global variables {{{1 */ + int varA, varB; + + /* functions {{{1 */ + /* funcA() {{{2 */ + void funcA() {} + + /* funcB() {{{2 */ + void funcB() {} + /* }}}1 */ + +At every numbered marker a fold at the specified level begins. This will make +any fold at a higher level stop here. You can just use numbered start markers +to define all folds. Only when you want to explicitly stop a fold before +another starts you need to add an end marker. + +More about folding with markers in the reference manual: |fold-marker| + +============================================================================== +*28.7* Folding by syntax + +For each language Vim uses a different syntax file. This defines the colors +for various items in the file. If you are reading this in Vim, in a terminal +that supports colors, the colors you see are made with the "help" syntax file. + In the syntax files it is possible to add syntax items that have the "fold" +argument. These define a fold region. This requires writing a syntax file +and adding these items in it. That's not so easy to do. But once it's done, +all folding happens automatically. + Here we'll assume you are using an existing syntax file. Then there is +nothing more to explain. You can open and close folds as explained above. +The folds will be created and deleted automatically when you edit the file. + +More about folding by syntax in the reference manual: |fold-syntax| + +============================================================================== +*28.8* Folding by expression + +This is similar to folding by indent, but instead of using the indent of a +line a user function is called to compute the fold level of a line. You can +use this for text where something in the text indicates which lines belong +together. An example is an e-mail message where the quoted text is indicated +by a ">" before the line. To fold these quotes use this: > + + :set foldmethod=expr + :set foldexpr=strlen(substitute(substitute(getline(v:lnum),'\\s','',\"g\"),'[^>].*','','')) + +You can try it out on this text: + +> quoted text he wrote +> quoted text he wrote +> > double quoted text I wrote +> > double quoted text I wrote + +Explanation for the 'foldexpr' used in the example (inside out): + getline(v:lnum) gets the current line + substitute(...,'\\s','','g') removes all white space from the line + substitute(...,'[^>].*','','') removes everything after leading '>'s + strlen(...) counts the length of the string, which + is the number of '>'s found + +Note that a backslash must be inserted before every space, double quote and +backslash for the ":set" command. If this confuses you, do > + + :set foldexpr + +to check the actual resulting value. To correct a complicated expression, use +the command-line completion: > + + :set foldexpr=<Tab> + +Where <Tab> is a real Tab. Vim will fill in the previous value, which you can +then edit. + +When the expression gets more complicated you should put it in a function and +set 'foldexpr' to call that function. + +More about folding by expression in the reference manual: |fold-expr| + +============================================================================== +*28.9* Folding unchanged lines + +This is useful when you set the 'diff' option in the same window. The +|vimdiff| command does this for you. Example: > + + :setlocal diff foldmethod=diff scrollbind nowrap foldlevel=1 + +Do this in every window that shows a different version of the same file. You +will clearly see the differences between the files, while the text that didn't +change is folded. + +For more details see |fold-diff|. + +============================================================================== +*28.10* Which fold method to use? + +All these possibilities make you wonder which method you should choose. +Unfortunately, there is no golden rule. Here are some hints. + +If there is a syntax file with folding for the language you are editing, that +is probably the best choice. If there isn't one, you might try to write it. +This requires a good knowledge of search patterns. It's not easy, but when +it's working you will not have to define folds manually. + +Typing commands to manually fold regions can be used for unstructured text. +Then use the |:mkview| command to save and restore your folds. + +The marker method requires you to change the file. If you are sharing the +files with other people or you have to meet company standards, you might not +be allowed to add them. + The main advantage of markers is that you can put them exactly where you +want them. That avoids that a few lines are missed when you cut and paste +folds. And you can add a comment about what is contained in the fold. + +Folding by indent is something that works in many files, but not always very +well. Use it when you can't use one of the other methods. However, it is +very useful for outlining. Then you specifically use one 'shiftwidth' for +each nesting level. + +Folding with expressions can make folds in almost any structured text. It is +quite simple to specify, especially if the start and end of a fold can easily +be recognized. + If you use the "expr" method to define folds, but they are not exactly how +you want them, you could switch to the "manual" method. This will not remove +the defined folds. Then you can delete or add folds manually. + +============================================================================== + +Next chapter: |usr_29.txt| Moving through programs + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_29.txt b/share/vim/vim73/doc/usr_29.txt new file mode 100644 index 0000000000..fb7d688a53 --- /dev/null +++ b/share/vim/vim73/doc/usr_29.txt @@ -0,0 +1,613 @@ +*usr_29.txt* For Vim version 7.3. Last change: 2008 Jun 28 + + VIM USER MANUAL - by Bram Moolenaar + + Moving through programs + + +The creator of Vim is a computer programmer. It's no surprise that Vim +contains many features to aid in writing programs. Jump around to find where +identifiers are defined and used. Preview declarations in a separate window. +There is more in the next chapter. + +|29.1| Using tags +|29.2| The preview window +|29.3| Moving through a program +|29.4| Finding global identifiers +|29.5| Finding local identifiers + + Next chapter: |usr_30.txt| Editing programs + Previous chapter: |usr_28.txt| Folding +Table of contents: |usr_toc.txt| + +============================================================================== +*29.1* Using tags + +What is a tag? It is a location where an identifier is defined. An example +is a function definition in a C or C++ program. A list of tags is kept in a +tags file. This can be used by Vim to directly jump from any place to the +tag, the place where an identifier is defined. + To generate the tags file for all C files in the current directory, use the +following command: > + + ctags *.c + +"ctags" is a separate program. Most Unix systems already have it installed. +If you do not have it yet, you can find Exuberant ctags here: + + http://ctags.sf.net ~ + +Now when you are in Vim and you want to go to a function definition, you can +jump to it by using the following command: > + + :tag startlist + +This command will find the function "startlist" even if it is in another file. + The CTRL-] command jumps to the tag of the word that is under the cursor. +This makes it easy to explore a tangle of C code. Suppose, for example, that +you are in the function "write_block". You can see that it calls +"write_line". But what does "write_line" do? By placing the cursor on the +call to "write_line" and pressing CTRL-], you jump to the definition of this +function. + The "write_line" function calls "write_char". You need to figure out what +it does. So you position the cursor over the call to "write_char" and press +CTRL-]. Now you are at the definition of "write_char". + + +-------------------------------------+ + |void write_block(char **s; int cnt) | + |{ | + | int i; | + | for (i = 0; i < cnt; ++i) | + | write_line(s[i]); | + |} | | + +-----------|-------------------------+ + | + CTRL-] | + | +----------------------------+ + +--> |void write_line(char *s) | + |{ | + | while (*s != 0) | + | write_char(*s++); | + |} | | + +--------|-------------------+ + | + CTRL-] | + | +------------------------------------+ + +--> |void write_char(char c) | + |{ | + | putchar((int)(unsigned char)c); | + |} | + +------------------------------------+ + +The ":tags" command shows the list of tags that you traversed through: + + :tags + # TO tag FROM line in file/text ~ + 1 1 write_line 8 write_block.c ~ + 2 1 write_char 7 write_line.c ~ + > ~ +> +Now to go back. The CTRL-T command goes to the preceding tag. In the example +above you get back to the "write_line" function, in the call to "write_char". + This command takes a count argument that indicates how many tags to jump +back. You have gone forward, and now back. Let's go forward again. The +following command goes to the tag on top of the list: > + + :tag + +You can prefix it with a count and jump forward that many tags. For example: +":3tag". CTRL-T also can be preceded with a count. + These commands thus allow you to go down a call tree with CTRL-] and back +up again with CTRL-T. Use ":tags" to find out where you are. + + +SPLIT WINDOWS + +The ":tag" command replaces the file in the current window with the one +containing the new function. But suppose you want to see not only the old +function but also the new one? You can split the window using the ":split" +command followed by the ":tag" command. Vim has a shorthand command that does +both: > + :stag tagname + +To split the current window and jump to the tag under the cursor use this +command: > + + CTRL-W ] + +If a count is specified, the new window will be that many lines high. + + +MORE TAGS FILES + +When you have files in many directories, you can create a tags file in each of +them. Vim will then only be able to jump to tags within that directory. + To find more tags files, set the 'tags' option to include all the relevant +tags files. Example: > + + :set tags=./tags,./../tags,./*/tags + +This finds a tags file in the same directory as the current file, one +directory level higher and in all subdirectories. + This is quite a number of tags files, but it may still not be enough. For +example, when editing a file in "~/proj/src", you will not find the tags file +"~/proj/sub/tags". For this situation Vim offers to search a whole directory +tree for tags files. Example: > + + :set tags=~/proj/**/tags + + +ONE TAGS FILE + +When Vim has to search many places for tags files, you can hear the disk +rattling. It may get a bit slow. In that case it's better to spend this +time while generating one big tags file. You might do this overnight. + This requires the Exuberant ctags program, mentioned above. It offers an +argument to search a whole directory tree: > + + cd ~/proj + ctags -R . + +The nice thing about this is that Exuberant ctags recognizes various file +types. Thus this doesn't work just for C and C++ programs, also for Eiffel +and even Vim scripts. See the ctags documentation to tune this. + Now you only need to tell Vim where your big tags file is: > + + :set tags=~/proj/tags + + +MULTIPLE MATCHES + +When a function is defined multiple times (or a method in several classes), +the ":tag" command will jump to the first one. If there is a match in the +current file, that one is used first. + You can now jump to other matches for the same tag with: > + + :tnext + +Repeat this to find further matches. If there are many, you can select which +one to jump to: > + + :tselect tagname + +Vim will present you with a list of choices: + + # pri kind tag file ~ + 1 F f mch_init os_amiga.c ~ + mch_init() ~ + 2 F f mch_init os_mac.c ~ + mch_init() ~ + 3 F f mch_init os_msdos.c ~ + mch_init(void) ~ + 4 F f mch_init os_riscos.c ~ + mch_init() ~ + Enter nr of choice (<CR> to abort): ~ + +You can now enter the number (in the first column) of the match that you would +like to jump to. The information in the other columns give you a good idea of +where the match is defined. + +To move between the matching tags, these commands can be used: + + :tfirst go to first match + :[count]tprevious go to [count] previous match + :[count]tnext go to [count] next match + :tlast go to last match + +If [count] is omitted then one is used. + + +GUESSING TAG NAMES + +Command line completion is a good way to avoid typing a long tag name. Just +type the first bit and press <Tab>: > + + :tag write_<Tab> + +You will get the first match. If it's not the one you want, press <Tab> until +you find the right one. + Sometimes you only know part of the name of a function. Or you have many +tags that start with the same string, but end differently. Then you can tell +Vim to use a pattern to find the tag. + Suppose you want to jump to a tag that contains "block". First type +this: > + + :tag /block + +Now use command line completion: press <Tab>. Vim will find all tags that +contain "block" and use the first match. + The "/" before a tag name tells Vim that what follows is not a literal tag +name, but a pattern. You can use all the items for search patterns here. For +example, suppose you want to select a tag that starts with "write_": > + + :tselect /^write_ + +The "^" specifies that the tag starts with "write_". Otherwise it would also +be found halfway a tag name. Similarly "$" at the end makes sure the pattern +matches until the end of a tag. + + +A TAGS BROWSER + +Since CTRL-] takes you to the definition of the identifier under the cursor, +you can use a list of identifier names as a table of contents. Here is an +example. + First create a list of identifiers (this requires Exuberant ctags): > + + ctags --c-types=f -f functions *.c + +Now start Vim without a file, and edit this file in Vim, in a vertically split +window: > + + vim + :vsplit functions + +The window contains a list of all the functions. There is some more stuff, +but you can ignore that. Do ":setlocal ts=99" to clean it up a bit. + In this window, define a mapping: > + + :nnoremap <buffer> <CR> 0ye<C-W>w:tag <C-R>"<CR> + +Move the cursor to the line that contains the function you want to go to. +Now press <Enter>. Vim will go to the other window and jump to the selected +function. + + +RELATED ITEMS + +You can set 'ignorecase' to make case in tag names be ignored. + +The 'tagbsearch' option tells if the tags file is sorted or not. The default +is to assume a sorted tags file, which makes a tags search a lot faster, but +doesn't work if the tags file isn't sorted. + +The 'taglength' option can be used to tell Vim the number of significant +characters in a tag. + +When you use the SNiFF+ program, you can use the Vim interface to it |sniff|. +SNiFF+ is a commercial program. + +Cscope is a free program. It does not only find places where an identifier is +declared, but also where it is used. See |cscope|. + +============================================================================== +*29.2* The preview window + +When you edit code that contains a function call, you need to use the correct +arguments. To know what values to pass you can look at how the function is +defined. The tags mechanism works very well for this. Preferably the +definition is displayed in another window. For this the preview window can be +used. + To open a preview window to display the function "write_char": > + + :ptag write_char + +Vim will open a window, and jumps to the tag "write_char". Then it takes you +back to the original position. Thus you can continue typing without the need +to use a CTRL-W command. + If the name of a function appears in the text, you can get its definition +in the preview window with: > + + CTRL-W } + +There is a script that automatically displays the text where the word under +the cursor was defined. See |CursorHold-example|. + +To close the preview window use this command: > + + :pclose + +To edit a specific file in the preview window, use ":pedit". This can be +useful to edit a header file, for example: > + + :pedit defs.h + +Finally, ":psearch" can be used to find a word in the current file and any +included files and display the match in the preview window. This is +especially useful when using library functions, for which you do not have a +tags file. Example: > + + :psearch popen + +This will show the "stdio.h" file in the preview window, with the function +prototype for popen(): + + FILE *popen __P((const char *, const char *)); ~ + +You can specify the height of the preview window, when it is opened, with the +'previewheight' option. + +============================================================================== +*29.3* Moving through a program + +Since a program is structured, Vim can recognize items in it. Specific +commands can be used to move around. + C programs often contain constructs like this: + + #ifdef USE_POPEN ~ + fd = popen("ls", "r") ~ + #else ~ + fd = fopen("tmp", "w") ~ + #endif ~ + +But then much longer, and possibly nested. Position the cursor on the +"#ifdef" and press %. Vim will jump to the "#else". Pressing % again takes +you to the "#endif". Another % takes you to the "#ifdef" again. + When the construct is nested, Vim will find the matching items. This is a +good way to check if you didn't forget an "#endif". + When you are somewhere inside a "#if" - "#endif", you can jump to the start +of it with: > + + [# + +If you are not after a "#if" or "#ifdef" Vim will beep. To jump forward to +the next "#else" or "#endif" use: > + + ]# + +These two commands skip any "#if" - "#endif" blocks that they encounter. +Example: + + #if defined(HAS_INC_H) ~ + a = a + inc(); ~ + # ifdef USE_THEME ~ + a += 3; ~ + # endif ~ + set_width(a); ~ + +With the cursor in the last line, "[#" moves to the first line. The "#ifdef" +- "#endif" block in the middle is skipped. + + +MOVING IN CODE BLOCKS + +In C code blocks are enclosed in {}. These can get pretty long. To move to +the start of the outer block use the "[[" command. Use "][" to find the end. +This assumes that the "{" and "}" are in the first column. + The "[{" command moves to the start of the current block. It skips over +pairs of {} at the same level. "]}" jumps to the end. + An overview: + + function(int a) + +-> { + | if (a) + | +-> { + [[ | | for (;;) --+ + | | +-> { | + | [{ | | foo(32); | --+ + | | [{ | if (bar(a)) --+ | ]} | + +-- | +-- break; | ]} | | + | } <-+ | | ][ + +-- foobar(a) | | + } <-+ | + } <-+ + +When writing C++ or Java, the outer {} block is for the class. The next level +of {} is for a method. When somewhere inside a class use "[m" to find the +previous start of a method. "]m" finds the next start of a method. + +Additionally, "[]" moves backward to the end of a function and "]]" moves +forward to the start of the next function. The end of a function is defined +by a "}" in the first column. + + int func1(void) + { + return 1; + +----------> } + | + [] | int func2(void) + | +-> { + | [[ | if (flag) + start +-- +-- return flag; + | ][ | return 2; + | +-> } + ]] | + | int func3(void) + +----------> { + return 3; + } + +Don't forget you can also use "%" to move between matching (), {} and []. +That also works when they are many lines apart. + + +MOVING IN BRACES + +The "[(" and "])" commands work similar to "[{" and "]}", except that they +work on () pairs instead of {} pairs. +> + [( +< <-------------------------------- + <------- + if (a == b && (c == d || (e > f)) && x > y) ~ + --------------> + --------------------------------> > + ]) + +MOVING IN COMMENTS + +To move back to the start of a comment use "[/". Move forward to the end of a +comment with "]/". This only works for /* - */ comments. + + +-> +-> /* + | [/ | * A comment about --+ + [/ | +-- * wonderful life. | ]/ + | */ <-+ + | + +-- foo = bar * 3; --+ + | ]/ + /* a short comment */ <-+ + +============================================================================== +*29.4* Finding global identifiers + +You are editing a C program and wonder if a variable is declared as "int" or +"unsigned". A quick way to find this is with the "[I" command. + Suppose the cursor is on the word "column". Type: > + + [I + +Vim will list the matching lines it can find. Not only in the current file, +but also in all included files (and files included in them, etc.). The result +looks like this: + + structs.h ~ + 1: 29 unsigned column; /* column number */ ~ + +The advantage over using tags or the preview window is that included files are +searched. In most cases this results in the right declaration to be found. +Also when the tags file is out of date. Also when you don't have tags for the +included files. + However, a few things must be right for "[I" to do its work. First of all, +the 'include' option must specify how a file is included. The default value +works for C and C++. For other languages you will have to change it. + + +LOCATING INCLUDED FILES + + Vim will find included files in the places specified with the 'path' +option. If a directory is missing, some include files will not be found. You +can discover this with this command: > + + :checkpath + +It will list the include files that could not be found. Also files included +by the files that could be found. An example of the output: + + --- Included files not found in path --- ~ + <io.h> ~ + vim.h --> ~ + <functions.h> ~ + <clib/exec_protos.h> ~ + +The "io.h" file is included by the current file and can't be found. "vim.h" +can be found, thus ":checkpath" goes into this file and checks what it +includes. The "functions.h" and "clib/exec_protos.h" files, included by +"vim.h" are not found. + + Note: + Vim is not a compiler. It does not recognize "#ifdef" statements. + This means every "#include" statement is used, also when it comes + after "#if NEVER". + +To fix the files that could not be found, add a directory to the 'path' +option. A good place to find out about this is the Makefile. Look out for +lines that contain "-I" items, like "-I/usr/local/X11". To add this directory +use: > + + :set path+=/usr/local/X11 + +When there are many subdirectories, you can use the "*" wildcard. Example: > + + :set path+=/usr/*/include + +This would find files in "/usr/local/include" as well as "/usr/X11/include". + +When working on a project with a whole nested tree of included files, the "**" +items is useful. This will search down in all subdirectories. Example: > + + :set path+=/projects/invent/**/include + +This will find files in the directories: + + /projects/invent/include ~ + /projects/invent/main/include ~ + /projects/invent/main/os/include ~ + etc. + +There are even more possibilities. Check out the 'path' option for info. + If you want to see which included files are actually found, use this +command: > + + :checkpath! + +You will get a (very long) list of included files, the files they include, and +so on. To shorten the list a bit, Vim shows "(Already listed)" for files that +were found before and doesn't list the included files in there again. + + +JUMPING TO A MATCH + +"[I" produces a list with only one line of text. When you want to have a +closer look at the first item, you can jump to that line with the command: > + + [<Tab> + +You can also use "[ CTRL-I", since CTRL-I is the same as pressing <Tab>. + +The list that "[I" produces has a number at the start of each line. When you +want to jump to another item than the first one, type the number first: > + + 3[<Tab> + +Will jump to the third item in the list. Remember that you can use CTRL-O to +jump back to where you started from. + + +RELATED COMMANDS + + [i only lists the first match + ]I only lists items below the cursor + ]i only lists the first item below the cursor + + +FINDING DEFINED IDENTIFIERS + +The "[I" command finds any identifier. To find only macros, defined with +"#define" use: > + + [D + +Again, this searches in included files. The 'define' option specifies what a +line looks like that defines the items for "[D". You could change it to make +it work with other languages than C or C++. + The commands related to "[D" are: + + [d only lists the first match + ]D only lists items below the cursor + ]d only lists the first item below the cursor + +============================================================================== +*29.5* Finding local identifiers + +The "[I" command searches included files. To search in the current file only, +and jump to the first place where the word under the cursor is used: > + + gD + +Hint: Goto Definition. This command is very useful to find a variable or +function that was declared locally ("static", in C terms). Example (cursor on +"counter"): + + +-> static int counter = 0; + | + | int get_counter(void) + gD | { + | ++counter; + +-- return counter; + } + +To restrict the search even further, and look only in the current function, +use this command: > + + gd + +This will go back to the start of the current function and find the first +occurrence of the word under the cursor. Actually, it searches backwards to +an empty line above a "{" in the first column. From there it searches forward +for the identifier. Example (cursor on "idx"): + + int find_entry(char *name) + { + +-> int idx; + | + gd | for (idx = 0; idx < table_len; ++idx) + | if (strcmp(table[idx].name, name) == 0) + +-- return idx; + } + +============================================================================== + +Next chapter: |usr_30.txt| Editing programs + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_30.txt b/share/vim/vim73/doc/usr_30.txt new file mode 100644 index 0000000000..09f90f82f1 --- /dev/null +++ b/share/vim/vim73/doc/usr_30.txt @@ -0,0 +1,643 @@ +*usr_30.txt* For Vim version 7.3. Last change: 2007 Nov 10 + + VIM USER MANUAL - by Bram Moolenaar + + Editing programs + + +Vim has various commands that aid in writing computer programs. Compile a +program and directly jump to reported errors. Automatically set the indent +for many languages and format comments. + +|30.1| Compiling +|30.2| Indenting C files +|30.3| Automatic indenting +|30.4| Other indenting +|30.5| Tabs and spaces +|30.6| Formatting comments + + Next chapter: |usr_31.txt| Exploiting the GUI + Previous chapter: |usr_29.txt| Moving through programs +Table of contents: |usr_toc.txt| + +============================================================================== +*30.1* Compiling + +Vim has a set of so called "quickfix" commands. They enable you to compile a +program from within Vim and then go through the errors generated and fix them +(hopefully). You can then recompile and fix any new errors that are found +until finally your program compiles without any error. + +The following command runs the program "make" (supplying it with any argument +you give) and captures the results: > + + :make {arguments} + +If errors were generated, they are captured and the editor positions you where +the first error occurred. + Take a look at an example ":make" session. (Typical :make sessions generate +far more errors and fewer stupid ones.) After typing ":make" the screen looks +like this: + + :!make | &tee /tmp/vim215953.err ~ + gcc -g -Wall -o prog main.c sub.c ~ + main.c: In function 'main': ~ + main.c:6: too many arguments to function 'do_sub' ~ + main.c: At top level: ~ + main.c:10: parse error before '}' ~ + make: *** [prog] Error 1 ~ + + 2 returned ~ + "main.c" 11L, 111C ~ + (3 of 6): too many arguments to function 'do_sub' ~ + Press ENTER or type command to continue ~ + +From this you can see that you have errors in the file "main.c". When you +press <Enter>, Vim displays the file "main.c", with the cursor positioned on +line 6, the first line with an error. You did not need to specify the file or +the line number, Vim knew where to go by looking in the error messages. + + +---------------------------------------------------+ + |int main() | + |{ | + | int i=3; | + cursor -> | do_sub("foo"); | + | ++i; | + | return (0); | + |} | + |} | + | ~ | + |(3 of 12): too many arguments to function 'do_sub' | + +---------------------------------------------------+ + +The following command goes to where the next error occurs: > + + :cnext + +Vim jumps to line 10, the last line in the file, where there is an extra '}'. + When there is not enough room, Vim will shorten the error message. To see +the whole message use: > + + :cc + +You can get an overview of all the error messages with the ":clist" command. +The output looks like this: > + + :clist +< 3 main.c: 6:too many arguments to function 'do_sub' ~ + 5 main.c: 10:parse error before '}' ~ + +Only the lines where Vim recognized a file name and line number are listed +here. It assumes those are the interesting lines and the rest is just boring +messages. However, sometimes unrecognized lines do contain something you want +to see. Output from the linker, for example, about an undefined function. +To see all the messages add a "!" to the command: > + + :clist! +< 1 gcc -g -Wall -o prog main.c sub.c ~ + 2 main.c: In function 'main': ~ + 3 main.c:6: too many arguments to function 'do_sub' ~ + 4 main.c: At top level: ~ + 5 main.c:10: parse error before '}' ~ + 6 make: *** [prog] Error 1 ~ + +Vim will highlight the current error. To go back to the previous error, use: +> + :cprevious + +Other commands to move around in the error list: + + :cfirst to first error + :clast to last error + :cc 3 to error nr 3 + + +USING ANOTHER COMPILER + +The name of the program to run when the ":make" command is executed is defined +by the 'makeprg' option. Usually this is set to "make", but Visual C++ users +should set this to "nmake" by executing the following command: > + + :set makeprg=nmake + +You can also include arguments in this option. Special characters need to +be escaped with a backslash. Example: > + + :set makeprg=nmake\ -f\ project.mak + +You can include special Vim keywords in the command specification. The % +character expands to the name of the current file. So if you execute the +command: > + :set makeprg=make\ % + +When you are editing main.c, then ":make" executes the following command: > + + make main.c + +This is not too useful, so you will refine the command a little and use the :r +(root) modifier: > + + :set makeprg=make\ %:r.o + +Now the command executed is as follows: > + + make main.o + +More about these modifiers here: |filename-modifiers|. + + +OLD ERROR LISTS + +Suppose you ":make" a program. There is a warning message in one file and an +error message in another. You fix the error and use ":make" again to check if +it was really fixed. Now you want to look at the warning message. It doesn't +show up in the last error list, since the file with the warning wasn't +compiled again. You can go back to the previous error list with: > + + :colder + +Then use ":clist" and ":cc {nr}" to jump to the place with the warning. + To go forward to the next error list: > + + :cnewer + +Vim remembers ten error lists. + + +SWITCHING COMPILERS + +You have to tell Vim what format the error messages are that your compiler +produces. This is done with the 'errorformat' option. The syntax of this +option is quite complicated and it can be made to fit almost any compiler. +You can find the explanation here: |errorformat|. + +You might be using various different compilers. Setting the 'makeprg' option, +and especially the 'errorformat' each time is not easy. Vim offers a simple +method for this. For example, to switch to using the Microsoft Visual C++ +compiler: > + + :compiler msvc + +This will find the Vim script for the "msvc" compiler and set the appropriate +options. + You can write your own compiler files. See |write-compiler-plugin|. + + +OUTPUT REDIRECTION + +The ":make" command redirects the output of the executed program to an error +file. How this works depends on various things, such as the 'shell'. If your +":make" command doesn't capture the output, check the 'makeef' and +'shellpipe' options. The 'shellquote' and 'shellxquote' options might also +matter. + +In case you can't get ":make" to redirect the file for you, an alternative is +to compile the program in another window and redirect the output into a file. +Then have Vim read this file with: > + + :cfile {filename} + +Jumping to errors will work like with the ":make" command. + +============================================================================== +*30.2* Indenting C style text + +A program is much easier to understand when the lines have been properly +indented. Vim offers various ways to make this less work. For C or C style +programs like Java or C++, set the 'cindent' option. Vim knows a lot about C +programs and will try very hard to automatically set the indent for you. Set +the 'shiftwidth' option to the amount of spaces you want for a deeper level. +Four spaces will work fine. One ":set" command will do it: > + + :set cindent shiftwidth=4 + +With this option enabled, when you type something such as "if (x)", the next +line will automatically be indented an additional level. + + if (flag) + Automatic indent ---> do_the_work(); + Automatic unindent <-- if (other_flag) { + Automatic indent ---> do_file(); + keep indent do_some_more(); + Automatic unindent <-- } + +When you type something in curly braces ({}), the text will be indented at the +start and unindented at the end. The unindenting will happen after typing the +'}', since Vim can't guess what you are going to type. + +One side effect of automatic indentation is that it helps you catch errors in +your code early. When you type a } to finish a function, only to find that +the automatic indentation gives it more indent than what you expected, there +is probably a } missing. Use the "%" command to find out which { matches the +} you typed. + A missing ) and ; also cause extra indent. Thus if you get more white +space than you would expect, check the preceding lines. + +When you have code that is badly formatted, or you inserted and deleted lines, +you need to re-indent the lines. The "=" operator does this. The simplest +form is: > + + == + +This indents the current line. Like with all operators, there are three ways +to use it. In Visual mode "=" indents the selected lines. A useful text +object is "a{". This selects the current {} block. Thus, to re-indent the +code block the cursor is in: > + + =a{ + +I you have really badly indented code, you can re-indent the whole file with: +> + gg=G + +However, don't do this in files that have been carefully indented manually. +The automatic indenting does a good job, but in some situations you might want +to overrule it. + + +SETTING INDENT STYLE + +Different people have different styles of indentation. By default Vim does a +pretty good job of indenting in a way that 90% of programmers do. There are +different styles, however; so if you want to, you can customize the +indentation style with the 'cinoptions' option. + By default 'cinoptions' is empty and Vim uses the default style. You can +add various items where you want something different. For example, to make +curly braces be placed like this: + + if (flag) ~ + { ~ + i = 8; ~ + j = 0; ~ + } ~ + +Use this command: > + + :set cinoptions+={2 + +There are many of these items. See |cinoptions-values|. + +============================================================================== +*30.3* Automatic indenting + +You don't want to switch on the 'cindent' option manually every time you edit +a C file. This is how you make it work automatically: > + + :filetype indent on + +Actually, this does a lot more than switching on 'cindent' for C files. First +of all, it enables detecting the type of a file. That's the same as what is +used for syntax highlighting. + When the filetype is known, Vim will search for an indent file for this +type of file. The Vim distribution includes a number of these for various +programming languages. This indent file will then prepare for automatic +indenting specifically for this file. + +If you don't like the automatic indenting, you can switch it off again: > + + :filetype indent off + +If you don't like the indenting for one specific type of file, this is how you +avoid it. Create a file with just this one line: > + + :let b:did_indent = 1 + +Now you need to write this in a file with a specific name: + + {directory}/indent/{filetype}.vim + +The {filetype} is the name of the file type, such as "cpp" or "java". You can +see the exact name that Vim detected with this command: > + + :set filetype + +In this file the output is: + + filetype=help ~ + +Thus you would use "help" for {filetype}. + For the {directory} part you need to use your runtime directory. Look at +the output of this command: > + + set runtimepath + +Now use the first item, the name before the first comma. Thus if the output +looks like this: + + runtimepath=~/.vim,/usr/local/share/vim/vim60/runtime,~/.vim/after ~ + +You use "~/.vim" for {directory}. Then the resulting file name is: + + ~/.vim/indent/help.vim ~ + +Instead of switching the indenting off, you could write your own indent file. +How to do that is explained here: |indent-expression|. + +============================================================================== +*30.4* Other indenting + +The most simple form of automatic indenting is with the 'autoindent' option. +It uses the indent from the previous line. A bit smarter is the 'smartindent' +option. This is useful for languages where no indent file is available. +'smartindent' is not as smart as 'cindent', but smarter than 'autoindent'. + With 'smartindent' set, an extra level of indentation is added for each { +and removed for each }. An extra level of indentation will also be added for +any of the words in the 'cinwords' option. Lines that begin with # are +treated specially: all indentation is removed. This is done so that +preprocessor directives will all start in column 1. The indentation is +restored for the next line. + + +CORRECTING INDENTS + +When you are using 'autoindent' or 'smartindent' to get the indent of the +previous line, there will be many times when you need to add or remove one +'shiftwidth' worth of indent. A quick way to do this is using the CTRL-D and +CTRL-T commands in Insert mode. + For example, you are typing a shell script that is supposed to look like +this: + + if test -n a; then ~ + echo a ~ + echo "-------" ~ + fi ~ + +Start off by setting these options: > + + :set autoindent shiftwidth=3 + +You start by typing the first line, <Enter> and the start of the second line: + + if test -n a; then ~ + echo ~ + +Now you see that you need an extra indent. Type CTRL-T. The result: + + if test -n a; then ~ + echo ~ + +The CTRL-T command, in Insert mode, adds one 'shiftwidth' to the indent, no +matter where in the line you are. + You continue typing the second line, <Enter> and the third line. This time +the indent is OK. Then <Enter> and the last line. Now you have this: + + if test -n a; then ~ + echo a ~ + echo "-------" ~ + fi ~ + +To remove the superfluous indent in the last line press CTRL-D. This deletes +one 'shiftwidth' worth of indent, no matter where you are in the line. + When you are in Normal mode, you can use the ">>" and "<<" commands to +shift lines. ">" and "<" are operators, thus you have the usual three ways to +specify the lines you want to indent. A useful combination is: > + + >i{ + +This adds one indent to the current block of lines, inside {}. The { and } +lines themselves are left unmodified. ">a{" includes them. In this example +the cursor is on "printf": + + original text after ">i{" after ">a{" + + if (flag) if (flag) if (flag) ~ + { { { ~ + printf("yes"); printf("yes"); printf("yes"); ~ + flag = 0; flag = 0; flag = 0; ~ + } } } ~ + +============================================================================== +*30.5* Tabs and spaces + +'tabstop' is set to eight by default. Although you can change it, you quickly +run into trouble later. Other programs won't know what tabstop value you +used. They probably use the default value of eight, and your text suddenly +looks very different. Also, most printers use a fixed tabstop value of eight. +Thus it's best to keep 'tabstop' alone. (If you edit a file which was written +with a different tabstop setting, see |25.3| for how to fix that.) + For indenting lines in a program, using a multiple of eight spaces makes +you quickly run into the right border of the window. Using a single space +doesn't provide enough visual difference. Many people prefer to use four +spaces, a good compromise. + Since a <Tab> is eight spaces and you want to use an indent of four spaces, +you can't use a <Tab> character to make your indent. There are two ways to +handle this: + +1. Use a mix of <Tab> and space characters. Since a <Tab> takes the place of + eight spaces, you have fewer characters in your file. Inserting a <Tab> + is quicker than eight spaces. Backspacing works faster as well. + +2. Use spaces only. This avoids the trouble with programs that use a + different tabstop value. + +Fortunately, Vim supports both methods quite well. + + +SPACES AND TABS + +If you are using a combination of tabs and spaces, you just edit normally. +The Vim defaults do a fine job of handling things. + You can make life a little easier by setting the 'softtabstop' option. +This option tells Vim to make the <Tab> key look and feel as if tabs were set +at the value of 'softtabstop', but actually use a combination of tabs and +spaces. + After you execute the following command, every time you press the <Tab> key +the cursor moves to the next 4-column boundary: > + + :set softtabstop=4 + +When you start in the first column and press <Tab>, you get 4 spaces inserted +in your text. The second time, Vim takes out the 4 spaces and puts in a <Tab> +(thus taking you to column 8). Thus Vim uses as many <Tab>s as possible, and +then fills up with spaces. + When backspacing it works the other way around. A <BS> will always delete +the amount specified with 'softtabstop'. Then <Tab>s are used as many as +possible and spaces to fill the gap. + The following shows what happens pressing <Tab> a few times, and then using +<BS>. A "." stands for a space and "------->" for a <Tab>. + + type result ~ + <Tab> .... + <Tab><Tab> -------> + <Tab><Tab><Tab> ------->.... + <Tab><Tab><Tab><BS> -------> + <Tab><Tab><Tab><BS><BS> .... + +An alternative is to use the 'smarttab' option. When it's set, Vim uses +'shiftwidth' for a <Tab> typed in the indent of a line, and a real <Tab> when +typed after the first non-blank character. However, <BS> doesn't work like +with 'softtabstop'. + + +JUST SPACES + +If you want absolutely no tabs in your file, you can set the 'expandtab' +option: > + + :set expandtab + +When this option is set, the <Tab> key inserts a series of spaces. Thus you +get the same amount of white space as if a <Tab> character was inserted, but +there isn't a real <Tab> character in your file. + The backspace key will delete each space by itself. Thus after typing one +<Tab> you have to press the <BS> key up to eight times to undo it. If you are +in the indent, pressing CTRL-D will be a lot quicker. + + +CHANGING TABS IN SPACES (AND BACK) + +Setting 'expandtab' does not affect any existing tabs. In other words, any +tabs in the document remain tabs. If you want to convert tabs to spaces, use +the ":retab" command. Use these commands: > + + :set expandtab + :%retab + +Now Vim will have changed all indents to use spaces instead of tabs. However, +all tabs that come after a non-blank character are kept. If you want these to +be converted as well, add a !: > + + :%retab! + +This is a little bit dangerous, because it can also change tabs inside a +string. To check if these exist, you could use this: > + + /"[^"\t]*\t[^"]*" + +It's recommended not to use hard tabs inside a string. Replace them with +"\t" to avoid trouble. + +The other way around works just as well: > + + :set noexpandtab + :%retab! + +============================================================================== +*30.6* Formatting comments + +One of the great things about Vim is that it understands comments. You can +ask Vim to format a comment and it will do the right thing. + Suppose, for example, that you have the following comment: + + /* ~ + * This is a test ~ + * of the text formatting. ~ + */ ~ + +You then ask Vim to format it by positioning the cursor at the start of the +comment and type: > + + gq]/ + +"gq" is the operator to format text. "]/" is the motion that takes you to the +end of a comment. The result is: + + /* ~ + * This is a test of the text formatting. ~ + */ ~ + +Notice that Vim properly handled the beginning of each line. + An alternative is to select the text that is to be formatted in Visual mode +and type "gq". + +To add a new line to the comment, position the cursor on the middle line and +press "o". The result looks like this: + + /* ~ + * This is a test of the text formatting. ~ + * ~ + */ ~ + +Vim has automatically inserted a star and a space for you. Now you can type +the comment text. When it gets longer than 'textwidth', Vim will break the +line. Again, the star is inserted automatically: + + /* ~ + * This is a test of the text formatting. ~ + * Typing a lot of text here will make Vim ~ + * break ~ + */ ~ + +For this to work some flags must be present in 'formatoptions': + + r insert the star when typing <Enter> in Insert mode + o insert the star when using "o" or "O" in Normal mode + c break comment text according to 'textwidth' + +See |fo-table| for more flags. + + +DEFINING A COMMENT + +The 'comments' option defines what a comment looks like. Vim distinguishes +between a single-line comment and a comment that has a different start, end +and middle part. + Many single-line comments start with a specific character. In C++ // is +used, in Makefiles #, in Vim scripts ". For example, to make Vim understand +C++ comments: > + + :set comments=:// + +The colon separates the flags of an item from the text by which the comment is +recognized. The general form of an item in 'comments' is: + + {flags}:{text} + +The {flags} part can be empty, as in this case. + Several of these items can be concatenated, separated by commas. This +allows recognizing different types of comments at the same time. For example, +let's edit an e-mail message. When replying, the text that others wrote is +preceded with ">" and "!" characters. This command would work: > + + :set comments=n:>,n:! + +There are two items, one for comments starting with ">" and one for comments +that start with "!". Both use the flag "n". This means that these comments +nest. Thus a line starting with ">" may have another comment after the ">". +This allows formatting a message like this: + + > ! Did you see that site? ~ + > ! It looks really great. ~ + > I don't like it. The ~ + > colors are terrible. ~ + What is the URL of that ~ + site? ~ + +Try setting 'textwidth' to a different value, e.g., 80, and format the text by +Visually selecting it and typing "gq". The result is: + + > ! Did you see that site? It looks really great. ~ + > I don't like it. The colors are terrible. ~ + What is the URL of that site? ~ + +You will notice that Vim did not move text from one type of comment to +another. The "I" in the second line would have fit at the end of the first +line, but since that line starts with "> !" and the second line with ">", Vim +knows that this is a different kind of comment. + + +A THREE PART COMMENT + +A C comment starts with "/*", has "*" in the middle and "*/" at the end. The +entry in 'comments' for this looks like this: > + + :set comments=s1:/*,mb:*,ex:*/ + +The start is defined with "s1:/*". The "s" indicates the start of a +three-piece comment. The colon separates the flags from the text by which the +comment is recognized: "/*". There is one flag: "1". This tells Vim that the +middle part has an offset of one space. + The middle part "mb:*" starts with "m", which indicates it is a middle +part. The "b" flag means that a blank must follow the text. Otherwise Vim +would consider text like "*pointer" also to be the middle of a comment. + The end part "ex:*/" has the "e" for identification. The "x" flag has a +special meaning. It means that after Vim automatically inserted a star, +typing / will remove the extra space. + +For more details see |format-comments|. + +============================================================================== + +Next chapter: |usr_31.txt| Exploiting the GUI + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_31.txt b/share/vim/vim73/doc/usr_31.txt new file mode 100644 index 0000000000..adbd56a2e4 --- /dev/null +++ b/share/vim/vim73/doc/usr_31.txt @@ -0,0 +1,272 @@ +*usr_31.txt* For Vim version 7.3. Last change: 2007 May 08 + + VIM USER MANUAL - by Bram Moolenaar + + Exploiting the GUI + + +Vim works well in a terminal, but the GUI has a few extra items. A file +browser can be used for commands that use a file. A dialog to make a choice +between alternatives. Use keyboard shortcuts to access menu items quickly. + +|31.1| The file browser +|31.2| Confirmation +|31.3| Menu shortcuts +|31.4| Vim window position and size +|31.5| Various + + Next chapter: |usr_32.txt| The undo tree + Previous chapter: |usr_30.txt| Editing programs +Table of contents: |usr_toc.txt| + +============================================================================== +*31.1* The file browser + +When using the File/Open... menu you get a file browser. This makes it easier +to find the file you want to edit. But what if you want to split a window to +edit another file? There is no menu entry for this. You could first use +Window/Split and then File/Open..., but that's more work. + Since you are typing most commands in Vim, opening the file browser with a +typed command is possible as well. To make the split command use the file +browser, prepend "browse": > + + :browse split + +Select a file and then the ":split" command will be executed with it. If you +cancel the file dialog nothing happens, the window isn't split. + You can also specify a file name argument. This is used to tell the file +browser where to start. Example: > + + :browse split /etc + +The file browser will pop up, starting in the directory "/etc". + +The ":browse" command can be prepended to just about any command that opens a +file. + If no directory is specified, Vim will decide where to start the file +browser. By default it uses the same directory as the last time. Thus when +you used ":browse split" and selected a file in "/usr/local/share", the next +time you use a ":browse" it will start in "/usr/local/share" again. + This can be changed with the 'browsedir' option. It can have one of three +values: + + last Use the last directory browsed (default) + buffer Use the same directory as the current buffer + current use the current directory + +For example, when you are in the directory "/usr", editing the file +"/usr/local/share/readme", then the command: > + + :set browsedir=buffer + :browse edit + +Will start the browser in "/usr/local/share". Alternatively: > + + :set browsedir=current + :browse edit + +Will start the browser in "/usr". + + Note: + To avoid using the mouse, most file browsers offer using key presses + to navigate. Since this is different for every system, it is not + explained here. Vim uses a standard browser when possible, your + system documentation should contain an explanation on the keyboard + shortcuts somewhere. + +When you are not using the GUI version, you could use the file explorer window +to select files like in a file browser. However, this doesn't work for the +":browse" command. See |netrw-browse|. + +============================================================================== +*31.2* Confirmation + +Vim protects you from accidentally overwriting a file and other ways to lose +changes. If you do something that might be a bad thing to do, Vim produces an +error message and suggests appending ! if you really want to do it. + To avoid retyping the command with the !, you can make Vim give you a +dialog. You can then press "OK" or "Cancel" to tell Vim what you want. + For example, you are editing a file and made changes to it. You start +editing another file with: > + + :confirm edit foo.txt + +Vim will pop up a dialog that looks something like this: + + +-----------------------------------+ + | | + | ? Save changes to "bar.txt"? | + | | + | YES NO CANCEL | + +-----------------------------------+ + +Now make your choice. If you do want to save the changes, select "YES". If +you want to lose the changes for ever: "NO". If you forgot what you were +doing and want to check what really changed use "CANCEL". You will be back in +the same file, with the changes still there. + +Just like ":browse", the ":confirm" command can be prepended to most commands +that edit another file. They can also be combined: > + + :confirm browse edit + +This will produce a dialog when the current buffer was changed. Then it will +pop up a file browser to select the file to edit. + + Note: + In the dialog you can use the keyboard to select the choice. + Typically the <Tab> key and the cursor keys change the choice. + Pressing <Enter> selects the choice. This depends on the system + though. + +When you are not using the GUI, the ":confirm" command works as well. Instead +of popping up a dialog, Vim will print the message at the bottom of the Vim +window and ask you to press a key to make a choice. > + + :confirm edit main.c +< Save changes to "Untitled"? ~ + [Y]es, (N)o, (C)ancel: ~ + +You can now press the single key for the choice. You don't have to press +<Enter>, unlike other typing on the command line. + +============================================================================== +*31.3* Menu shortcuts + +The keyboard is used for all Vim commands. The menus provide a simple way to +select commands, without knowing what they are called. But you have to move +your hand from the keyboard and grab the mouse. + Menus can often be selected with keys as well. This depends on your +system, but most often it works this way. Use the <Alt> key in combination +with the underlined letter of a menu. For example, <A-w> (<Alt> and w) pops +up the Window menu. + In the Window menu, the "split" item has the p underlined. To select it, +let go of the <Alt> key and press p. + +After the first selection of a menu with the <Alt> key, you can use the cursor +keys to move through the menus. <Right> selects a submenu and <left> closes +it. <Esc> also closes a menu. <Enter> selects a menu item. + +There is a conflict between using the <Alt> key to select menu items, and +using <Alt> key combinations for mappings. The 'winaltkeys' option tells Vim +what it should do with the <Alt> key. + The default value "menu" is the smart choice: If the key combination is a +menu shortcut it can't be mapped. All other keys are available for mapping. + The value "no" doesn't use any <Alt> keys for the menus. Thus you must use +the mouse for the menus, and all <Alt> keys can be mapped. + The value "yes" means that Vim will use any <Alt> keys for the menus. Some +<Alt> key combinations may also do other things than selecting a menu. + +============================================================================== +*31.4* Vim window position and size + +To see the current Vim window position on the screen use: > + + :winpos + +This will only work in the GUI. The output may look like this: + + Window position: X 272, Y 103 ~ + +The position is given in screen pixels. Now you can use the numbers to move +Vim somewhere else. For example, to move it to the left a hundred pixels: > + + :winpos 172 103 +< + Note: + There may be a small offset between the reported position and where + the window moves. This is because of the border around the window. + This is added by the window manager. + +You can use this command in your startup script to position the window at a +specific position. + +The size of the Vim window is computed in characters. Thus this depends on +the size of the font being used. You can see the current size with this +command: > + + :set lines columns + +To change the size set the 'lines' and/or 'columns' options to a new value: > + + :set lines=50 + :set columns=80 + +Obtaining the size works in a terminal just like in the GUI. Setting the size +is not possible in most terminals. + +You can start the X-Windows version of gvim with an argument to specify the +size and position of the window: > + + gvim -geometry {width}x{height}+{x_offset}+{y_offset} + +{width} and {height} are in characters, {x_offset} and {y_offset} are in +pixels. Example: > + + gvim -geometry 80x25+100+300 + +============================================================================== +*31.5* Various + +You can use gvim to edit an e-mail message. In your e-mail program you must +select gvim to be the editor for messages. When you try that, you will +see that it doesn't work: The mail program thinks that editing is finished, +while gvim is still running! + What happens is that gvim disconnects from the shell it was started in. +That is fine when you start gvim in a terminal, so that you can do other work +in that terminal. But when you really want to wait for gvim to finish, you +must prevent it from disconnecting. The "-f" argument does this: > + + gvim -f file.txt + +The "-f" stands for foreground. Now Vim will block the shell it was started +in until you finish editing and exit. + + +DELAYED START OF THE GUI + +On Unix it's possible to first start Vim in a terminal. That's useful if you +do various tasks in the same shell. If you are editing a file and decide you +want to use the GUI after all, you can start it with: > + + :gui + +Vim will open the GUI window and no longer use the terminal. You can continue +using the terminal for something else. The "-f" argument is used here to run +the GUI in the foreground. You can also use ":gui -f". + + +THE GVIM STARTUP FILE + +When gvim starts, it reads the gvimrc file. That's similar to the vimrc file +used when starting Vim. The gvimrc file can be used for settings and commands +that are only to be used when the GUI is going to be started. For example, +you can set the 'lines' option to set a different window size: > + + :set lines=55 + +You don't want to do this in a terminal, since its size is fixed (except for +an xterm that supports resizing). + The gvimrc file is searched for in the same locations as the vimrc file. +Normally its name is "~/.gvimrc" for Unix and "$VIM/_gvimrc" for MS-Windows. +The $MYGVIMRC environment variable is set to it, thus you can use this command +to edit the file, if you have one: > + + :edit $MYGVIMRC +< + If for some reason you don't want to use the normal gvimrc file, you can +specify another one with the "-U" argument: > + + gvim -U thisrc ... + +That allows starting gvim for different kinds of editing. You could set +another font size, for example. + To completely skip reading a gvimrc file: > + + gvim -U NONE ... + +============================================================================== + +Next chapter: |usr_32.txt| The undo tree + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_32.txt b/share/vim/vim73/doc/usr_32.txt new file mode 100644 index 0000000000..7999efee53 --- /dev/null +++ b/share/vim/vim73/doc/usr_32.txt @@ -0,0 +1,180 @@ +*usr_32.txt* For Vim version 7.3. Last change: 2010 Jul 20 + + VIM USER MANUAL - by Bram Moolenaar + + The undo tree + + +Vim provides multi-level undo. If you undo a few changes and then make a new +change you create a branch in the undo tree. This text is about moving +through the branches. + +|32.1| Undo up to a file write +|32.2| Numbering changes +|32.3| Jumping around the tree +|32.4| Time travelling + + Next chapter: |usr_40.txt| Make new commands + Previous chapter: |usr_31.txt| Exploiting the GUI +Table of contents: |usr_toc.txt| + +============================================================================== +*32.1* Undo up to a file write + +Sometimes you make several changes, and then discover you want to go back to +when you have last written the file. You can do that with this command: > + + :earlier 1f + +The "f" stands for "file" here. + +You can repeat this command to go further back in the past. Or use a count +different from 1 to go back faster. + +If you go back too far, go forward again with: > + + :later 1f + +Note that these commands really work in time sequence. This matters if you +made changes after undoing some changes. It's explained in the next section. + +Also note that we are talking about text writes here. For writing the undo +information in a file see |undo-persistence|. + +============================================================================== +*32.2* Numbering changes + +In section |02.5| we only discussed one line of undo/redo. But it is also +possible to branch off. This happens when you undo a few changes and then +make a new change. The new changes become a branch in the undo tree. + +Let's start with the text "one". The first change to make is to append +" too". And then move to the first 'o' and change it into 'w'. We then have +two changes, numbered 1 and 2, and three states of the text: + + one ~ + | + change 1 + | + one too ~ + | + change 2 + | + one two ~ + +If we now undo one change, back to "one too", and change "one" to "me" we +create a branch in the undo tree: + + one ~ + | + change 1 + | + one too ~ + / \ + change 2 change 3 + | | + one two me too ~ + +You can now use the |u| command to undo. If you do this twice you get to +"one". Use |CTRL-R| to redo, and you will go to "one too". One more |CTRL-R| +takes you to "me too". Thus undo and redo go up and down in the tree, using +the branch that was last used. + +What matters here is the order in which the changes are made. Undo and redo +are not considered changes in this context. After each change you have a new +state of the text. + +Note that only the changes are numbered, the text shown in the tree above has +no identifier. They are mostly referred to by the number of the change above +it. But sometimes by the number of one of the changes below it, especially +when moving up in the tree, so that you know which change was just undone. + +============================================================================== +*32.3* Jumping around the tree + +So how do you get to "one two" now? You can use this command: > + + :undo 2 + +The text is now "one two", you are below change 2. You can use the |:undo| +command to jump to below any change in the tree. + +Now make another change: change "one" to "not": + + one ~ + | + change 1 + | + one too ~ + / \ + change 2 change 3 + | | + one two me too ~ + | + change 4 + | + not two ~ + +Now you change your mind and want to go back to "me too". Use the |g-| +command. This moves back in time. Thus it doesn't walk the tree upwards or +downwards, but goes to the change made before. + +You can repeat |g-| and you will see the text change: + me too ~ + one two ~ + one too ~ + one ~ + +Use |g+| to move forward in time: + one ~ + one too ~ + one two ~ + me too ~ + not two ~ + +Using |:undo| is useful if you know what change you want to jump to. |g-| and +|g+| are useful if you don't know exactly what the change number is. + +You can type a count before |g-| and |g+| to repeat them. + +============================================================================== +*32.4* Time travelling + +When you have been working on text for a while the tree grows to become big. +Then you may want to go to the text of some minutes ago. + +To see what branches there are in the undo tree use this command: > + + :undolist +< number changes time ~ + 3 2 16 seconds ago + 4 3 5 seconds ago + +Here you can see the number of the leaves in each branch and when the change +was made. Assuming we are below change 4, at "not two", you can go back ten +seconds with this command: > + + :earlier 10s + +Depending on how much time you took for the changes you end up at a certain +position in the tree. The |:earlier| command argument can be "m" for minutes, +"h" for hours and "d" for days. To go all the way back use a big number: > + + :earlier 100d + +To travel forward in time again use the |:later| command: > + + :later 1m + +The arguments are "s", "m" and "h", just like with |:earlier|. + +If you want even more details, or want to manipulate the information, you can +use the |undotree()| function. To see what it returns: > + + :echo undotree() + +============================================================================== + +Next chapter: |usr_40.txt| Make new commands + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_40.txt b/share/vim/vim73/doc/usr_40.txt new file mode 100644 index 0000000000..c7a5e47731 --- /dev/null +++ b/share/vim/vim73/doc/usr_40.txt @@ -0,0 +1,657 @@ +*usr_40.txt* For Vim version 7.3. Last change: 2006 Jun 21 + + VIM USER MANUAL - by Bram Moolenaar + + Make new commands + + +Vim is an extensible editor. You can take a sequence of commands you use +often and turn it into a new command. Or redefine an existing command. +Autocommands make it possible to execute commands automatically. + +|40.1| Key mapping +|40.2| Defining command-line commands +|40.3| Autocommands + + Next chapter: |usr_41.txt| Write a Vim script + Previous chapter: |usr_32.txt| The undo tree +Table of contents: |usr_toc.txt| + +============================================================================== +*40.1* Key mapping + +A simple mapping was explained in section |05.3|. The principle is that one +sequence of key strokes is translated into another sequence of key strokes. +This is a simple, yet powerful mechanism. + The simplest form is that one key is mapped to a sequence of keys. Since +the function keys, except <F1>, have no predefined meaning in Vim, these are +good choices to map. Example: > + + :map <F2> GoDate: <Esc>:read !date<CR>kJ + +This shows how three modes are used. After going to the last line with "G", +the "o" command opens a new line and starts Insert mode. The text "Date: " is +inserted and <Esc> takes you out of insert mode. + Notice the use of special keys inside <>. This is called angle bracket +notation. You type these as separate characters, not by pressing the key +itself. This makes the mappings better readable and you can copy and paste +the text without problems. + The ":" character takes Vim to the command line. The ":read !date" command +reads the output from the "date" command and appends it below the current +line. The <CR> is required to execute the ":read" command. + At this point of execution the text looks like this: + + Date: ~ + Fri Jun 15 12:54:34 CEST 2001 ~ + +Now "kJ" moves the cursor up and joins the lines together. + To decide which key or keys you use for mapping, see |map-which-keys|. + + +MAPPING AND MODES + +The ":map" command defines remapping for keys in Normal mode. You can also +define mappings for other modes. For example, ":imap" applies to Insert mode. +You can use it to insert a date below the cursor: > + + :imap <F2> <CR>Date: <Esc>:read !date<CR>kJ + +It looks a lot like the mapping for <F2> in Normal mode, only the start is +different. The <F2> mapping for Normal mode is still there. Thus you can map +the same key differently for each mode. + Notice that, although this mapping starts in Insert mode, it ends in Normal +mode. If you want it to continue in Insert mode, append an "a" to the +mapping. + +Here is an overview of map commands and in which mode they work: + + :map Normal, Visual and Operator-pending + :vmap Visual + :nmap Normal + :omap Operator-pending + :map! Insert and Command-line + :imap Insert + :cmap Command-line + +Operator-pending mode is when you typed an operator character, such as "d" or +"y", and you are expected to type the motion command or a text object. Thus +when you type "dw", the "w" is entered in operator-pending mode. + +Suppose that you want to define <F7> so that the command d<F7> deletes a C +program block (text enclosed in curly braces, {}). Similarly y<F7> would yank +the program block into the unnamed register. Therefore, what you need to do +is to define <F7> to select the current program block. You can do this with +the following command: > + + :omap <F7> a{ + +This causes <F7> to perform a select block "a{" in operator-pending mode, just +like you typed it. This mapping is useful if typing a { on your keyboard is a +bit difficult. + + +LISTING MAPPINGS + +To see the currently defined mappings, use ":map" without arguments. Or one +of the variants that include the mode in which they work. The output could +look like this: + + _g :call MyGrep(1)<CR> ~ + v <F2> :s/^/> /<CR>:noh<CR>`` ~ + n <F2> :.,$s/^/> /<CR>:noh<CR>`` ~ + <xHome> <Home> + <xEnd> <End> + + +The first column of the list shows in which mode the mapping is effective. +This is "n" for Normal mode, "i" for Insert mode, etc. A blank is used for a +mapping defined with ":map", thus effective in both Normal and Visual mode. + One useful purpose of listing the mapping is to check if special keys in <> +form have been recognized (this only works when color is supported). For +example, when <Esc> is displayed in color, it stands for the escape character. +When it has the same color as the other text, it is five characters. + + +REMAPPING + +The result of a mapping is inspected for other mappings in it. For example, +the mappings for <F2> above could be shortened to: > + + :map <F2> G<F3> + :imap <F2> <Esc><F3> + :map <F3> oDate: <Esc>:read !date<CR>kJ + +For Normal mode <F2> is mapped to go to the last line, and then behave like +<F3> was pressed. In Insert mode <F2> stops Insert mode with <Esc> and then +also uses <F3>. Then <F3> is mapped to do the actual work. + +Suppose you hardly ever use Ex mode, and want to use the "Q" command to format +text (this was so in old versions of Vim). This mapping will do it: > + + :map Q gq + +But, in rare cases you need to use Ex mode anyway. Let's map "gQ" to Q, so +that you can still go to Ex mode: > + + :map gQ Q + +What happens now is that when you type "gQ" it is mapped to "Q". So far so +good. But then "Q" is mapped to "gq", thus typing "gQ" results in "gq", and +you don't get to Ex mode at all. + To avoid keys to be mapped again, use the ":noremap" command: > + + :noremap gQ Q + +Now Vim knows that the "Q" is not to be inspected for mappings that apply to +it. There is a similar command for every mode: + + :noremap Normal, Visual and Operator-pending + :vnoremap Visual + :nnoremap Normal + :onoremap Operator-pending + :noremap! Insert and Command-line + :inoremap Insert + :cnoremap Command-line + + +RECURSIVE MAPPING + +When a mapping triggers itself, it will run forever. This can be used to +repeat an action an unlimited number of times. + For example, you have a list of files that contain a version number in the +first line. You edit these files with "vim *.txt". You are now editing the +first file. Define this mapping: > + + :map ,, :s/5.1/5.2/<CR>:wnext<CR>,, + +Now you type ",,". This triggers the mapping. It replaces "5.1" with "5.2" +in the first line. Then it does a ":wnext" to write the file and edit the +next one. The mapping ends in ",,". This triggers the same mapping again, +thus doing the substitution, etc. + This continues until there is an error. In this case it could be a file +where the substitute command doesn't find a match for "5.1". You can then +make a change to insert "5.1" and continue by typing ",," again. Or the +":wnext" fails, because you are in the last file in the list. + When a mapping runs into an error halfway, the rest of the mapping is +discarded. CTRL-C interrupts the mapping (CTRL-Break on MS-Windows). + + +DELETE A MAPPING + +To remove a mapping use the ":unmap" command. Again, the mode the unmapping +applies to depends on the command used: + + :unmap Normal, Visual and Operator-pending + :vunmap Visual + :nunmap Normal + :ounmap Operator-pending + :unmap! Insert and Command-line + :iunmap Insert + :cunmap Command-line + +There is a trick to define a mapping that works in Normal and Operator-pending +mode, but not in Visual mode. First define it for all three modes, then +delete it for Visual mode: > + + :map <C-A> /---><CR> + :vunmap <C-A> + +Notice that the five characters "<C-A>" stand for the single key CTRL-A. + +To remove all mappings use the |:mapclear| command. You can guess the +variations for different modes by now. Be careful with this command, it can't +be undone. + + +SPECIAL CHARACTERS + +The ":map" command can be followed by another command. A | character +separates the two commands. This also means that a | character can't be used +inside a map command. To include one, use <Bar> (five characters). Example: +> + :map <F8> :write <Bar> !checkin %<CR> + +The same problem applies to the ":unmap" command, with the addition that you +have to watch out for trailing white space. These two commands are different: +> + :unmap a | unmap b + :unmap a| unmap b + +The first command tries to unmap "a ", with a trailing space. + +When using a space inside a mapping, use <Space> (seven characters): > + + :map <Space> W + +This makes the spacebar move a blank-separated word forward. + +It is not possible to put a comment directly after a mapping, because the " +character is considered to be part of the mapping. You can use |", this +starts a new, empty command with a comment. Example: > + + :map <Space> W| " Use spacebar to move forward a word + + +MAPPINGS AND ABBREVIATIONS + +Abbreviations are a lot like Insert mode mappings. The arguments are handled +in the same way. The main difference is the way they are triggered. An +abbreviation is triggered by typing a non-word character after the word. A +mapping is triggered when typing the last character. + Another difference is that the characters you type for an abbreviation are +inserted in the text while you type them. When the abbreviation is triggered +these characters are deleted and replaced by what the abbreviation produces. +When typing the characters for a mapping, nothing is inserted until you type +the last character that triggers it. If the 'showcmd' option is set, the +typed characters are displayed in the last line of the Vim window. + An exception is when a mapping is ambiguous. Suppose you have done two +mappings: > + + :imap aa foo + :imap aaa bar + +Now, when you type "aa", Vim doesn't know if it should apply the first or the +second mapping. It waits for another character to be typed. If it is an "a", +the second mapping is applied and results in "bar". If it is a space, for +example, the first mapping is applied, resulting in "foo", and then the space +is inserted. + + +ADDITIONALLY... + +The <script> keyword can be used to make a mapping local to a script. See +|:map-<script>|. + +The <buffer> keyword can be used to make a mapping local to a specific buffer. +See |:map-<buffer>| + +The <unique> keyword can be used to make defining a new mapping fail when it +already exists. Otherwise a new mapping simply overwrites the old one. See +|:map-<unique>|. + +To make a key do nothing, map it to <Nop> (five characters). This will make +the <F7> key do nothing at all: > + + :map <F7> <Nop>| map! <F7> <Nop> + +There must be no space after <Nop>. + +============================================================================== +*40.2* Defining command-line commands + +The Vim editor enables you to define your own commands. You execute these +commands just like any other Command-line mode command. + To define a command, use the ":command" command, as follows: > + + :command DeleteFirst 1delete + +Now when you execute the command ":DeleteFirst" Vim executes ":1delete", which +deletes the first line. + + Note: + User-defined commands must start with a capital letter. You cannot + use ":X", ":Next" and ":Print". The underscore cannot be used! You + can use digits, but this is discouraged. + +To list the user-defined commands, execute the following command: > + + :command + +Just like with the builtin commands, the user defined commands can be +abbreviated. You need to type just enough to distinguish the command from +another. Command line completion can be used to get the full name. + + +NUMBER OF ARGUMENTS + +User-defined commands can take a series of arguments. The number of arguments +must be specified by the -nargs option. For instance, the example +:DeleteFirst command takes no arguments, so you could have defined it as +follows: > + + :command -nargs=0 DeleteFirst 1delete + +However, because zero arguments is the default, you do not need to add +"-nargs=0". The other values of -nargs are as follows: + + -nargs=0 No arguments + -nargs=1 One argument + -nargs=* Any number of arguments + -nargs=? Zero or one argument + -nargs=+ One or more arguments + + +USING THE ARGUMENTS + +Inside the command definition, the arguments are represented by the +<args> keyword. For example: > + + :command -nargs=+ Say :echo "<args>" + +Now when you type > + + :Say Hello World + +Vim echoes "Hello World". However, if you add a double quote, it won't work. +For example: > + + :Say he said "hello" + +To get special characters turned into a string, properly escaped to use as an +expression, use "<q-args>": > + + :command -nargs=+ Say :echo <q-args> + +Now the above ":Say" command will result in this to be executed: > + + :echo "he said \"hello\"" + +The <f-args> keyword contains the same information as the <args> keyword, +except in a format suitable for use as function call arguments. For example: +> + :command -nargs=* DoIt :call AFunction(<f-args>) + :DoIt a b c + +Executes the following command: > + + :call AFunction("a", "b", "c") + + +LINE RANGE + +Some commands take a range as their argument. To tell Vim that you are +defining such a command, you need to specify a -range option. The values for +this option are as follows: + + -range Range is allowed; default is the current line. + -range=% Range is allowed; default is the whole file. + -range={count} Range is allowed; the last number in it is used as a + single number whose default is {count}. + +When a range is specified, the keywords <line1> and <line2> get the values of +the first and last line in the range. For example, the following command +defines the SaveIt command, which writes out the specified range to the file +"save_file": > + + :command -range=% SaveIt :<line1>,<line2>write! save_file + + +OTHER OPTIONS + +Some of the other options and keywords are as follows: + + -count={number} The command can take a count whose default is + {number}. The resulting count can be used + through the <count> keyword. + -bang You can use a !. If present, using <bang> will + result in a !. + -register You can specify a register. (The default is + the unnamed register.) + The register specification is available as + <reg> (a.k.a. <register>). + -complete={type} Type of command-line completion used. See + |:command-completion| for the list of possible + values. + -bar The command can be followed by | and another + command, or " and a comment. + -buffer The command is only available for the current + buffer. + +Finally, you have the <lt> keyword. It stands for the character <. Use this +to escape the special meaning of the <> items mentioned. + + +REDEFINING AND DELETING + +To redefine the same command use the ! argument: > + + :command -nargs=+ Say :echo "<args>" + :command! -nargs=+ Say :echo <q-args> + +To delete a user command use ":delcommand". It takes a single argument, which +is the name of the command. Example: > + + :delcommand SaveIt + +To delete all the user commands: > + + :comclear + +Careful, this can't be undone! + +More details about all this in the reference manual: |user-commands|. + +============================================================================== +*40.3* Autocommands + +An autocommand is a command that is executed automatically in response to some +event, such as a file being read or written or a buffer change. Through the +use of autocommands you can train Vim to edit compressed files, for example. +That is used in the |gzip| plugin. + Autocommands are very powerful. Use them with care and they will help you +avoid typing many commands. Use them carelessly and they will cause a lot of +trouble. + +Suppose you want to replace a datestamp on the end of a file every time it is +written. First you define a function: > + + :function DateInsert() + : $delete + : read !date + :endfunction + +You want this function to be called each time, just before a file is written. +This will make that happen: > + + :autocmd FileWritePre * call DateInsert() + +"FileWritePre" is the event for which this autocommand is triggered: Just +before (pre) writing a file. The "*" is a pattern to match with the file +name. In this case it matches all files. + With this command enabled, when you do a ":write", Vim checks for any +matching FileWritePre autocommands and executes them, and then it +performs the ":write". + The general form of the :autocmd command is as follows: > + + :autocmd [group] {events} {file_pattern} [nested] {command} + +The [group] name is optional. It is used in managing and calling the commands +(more on this later). The {events} parameter is a list of events (comma +separated) that trigger the command. + {file_pattern} is a filename, usually with wildcards. For example, using +"*.txt" makes the autocommand be used for all files whose name end in ".txt". +The optional [nested] flag allows for nesting of autocommands (see below), and +finally, {command} is the command to be executed. + + +EVENTS + +One of the most useful events is BufReadPost. It is triggered after a new +file is being edited. It is commonly used to set option values. For example, +you know that "*.gsm" files are GNU assembly language. To get the syntax file +right, define this autocommand: > + + :autocmd BufReadPost *.gsm set filetype=asm + +If Vim is able to detect the type of file, it will set the 'filetype' option +for you. This triggers the Filetype event. Use this to do something when a +certain type of file is edited. For example, to load a list of abbreviations +for text files: > + + :autocmd Filetype text source ~/.vim/abbrevs.vim + +When starting to edit a new file, you could make Vim insert a skeleton: > + + :autocmd BufNewFile *.[ch] 0read ~/skeletons/skel.c + +See |autocmd-events| for a complete list of events. + + +PATTERNS + +The {file_pattern} argument can actually be a comma-separated list of file +patterns. For example: "*.c,*.h" matches files ending in ".c" and ".h". + The usual file wildcards can be used. Here is a summary of the most often +used ones: + + * Match any character any number of times + ? Match any character once + [abc] Match the character a, b or c + . Matches a dot + a{b,c} Matches "ab" and "ac" + +When the pattern includes a slash (/) Vim will compare directory names. +Without the slash only the last part of a file name is used. For example, +"*.txt" matches "/home/biep/readme.txt". The pattern "/home/biep/*" would +also match it. But "home/foo/*.txt" wouldn't. + When including a slash, Vim matches the pattern against both the full path +of the file ("/home/biep/readme.txt") and the relative path (e.g., +"biep/readme.txt"). + + Note: + When working on a system that uses a backslash as file separator, such + as MS-Windows, you still use forward slashes in autocommands. This + makes it easier to write the pattern, since a backslash has a special + meaning. It also makes the autocommands portable. + + +DELETING + +To delete an autocommand, use the same command as what it was defined with, +but leave out the {command} at the end and use a !. Example: > + + :autocmd! FileWritePre * + +This will delete all autocommands for the "FileWritePre" event that use the +"*" pattern. + + +LISTING + +To list all the currently defined autocommands, use this: > + + :autocmd + +The list can be very long, especially when filetype detection is used. To +list only part of the commands, specify the group, event and/or pattern. For +example, to list all BufNewFile autocommands: > + + :autocmd BufNewFile + +To list all autocommands for the pattern "*.c": > + + :autocmd * *.c + +Using "*" for the event will list all the events. To list all autocommands +for the cprograms group: > + + :autocmd cprograms + + +GROUPS + +The {group} item, used when defining an autocommand, groups related autocommands +together. This can be used to delete all the autocommands in a certain group, +for example. + When defining several autocommands for a certain group, use the ":augroup" +command. For example, let's define autocommands for C programs: > + + :augroup cprograms + : autocmd BufReadPost *.c,*.h :set sw=4 sts=4 + : autocmd BufReadPost *.cpp :set sw=3 sts=3 + :augroup END + +This will do the same as: > + + :autocmd cprograms BufReadPost *.c,*.h :set sw=4 sts=4 + :autocmd cprograms BufReadPost *.cpp :set sw=3 sts=3 + +To delete all autocommands in the "cprograms" group: > + + :autocmd! cprograms + + +NESTING + +Generally, commands executed as the result of an autocommand event will not +trigger any new events. If you read a file in response to a FileChangedShell +event, it will not trigger the autocommands that would set the syntax, for +example. To make the events triggered, add the "nested" argument: > + + :autocmd FileChangedShell * nested edit + + +EXECUTING AUTOCOMMANDS + +It is possible to trigger an autocommand by pretending an event has occurred. +This is useful to have one autocommand trigger another one. Example: > + + :autocmd BufReadPost *.new execute "doautocmd BufReadPost " . expand("<afile>:r") + +This defines an autocommand that is triggered when a new file has been edited. +The file name must end in ".new". The ":execute" command uses expression +evaluation to form a new command and execute it. When editing the file +"tryout.c.new" the executed command will be: > + + :doautocmd BufReadPost tryout.c + +The expand() function takes the "<afile>" argument, which stands for the file +name the autocommand was executed for, and takes the root of the file name +with ":r". + +":doautocmd" executes on the current buffer. The ":doautoall" command works +like "doautocmd" except it executes on all the buffers. + + +USING NORMAL MODE COMMANDS + +The commands executed by an autocommand are Command-line commands. If you +want to use a Normal mode command, the ":normal" command can be used. +Example: > + + :autocmd BufReadPost *.log normal G + +This will make the cursor jump to the last line of *.log files when you start +to edit it. + Using the ":normal" command is a bit tricky. First of all, make sure its +argument is a complete command, including all the arguments. When you use "i" +to go to Insert mode, there must also be a <Esc> to leave Insert mode again. +If you use a "/" to start a search pattern, there must be a <CR> to execute +it. + The ":normal" command uses all the text after it as commands. Thus there +can be no | and another command following. To work around this, put the +":normal" command inside an ":execute" command. This also makes it possible +to pass unprintable characters in a convenient way. Example: > + + :autocmd BufReadPost *.chg execute "normal ONew entry:\<Esc>" | + \ 1read !date + +This also shows the use of a backslash to break a long command into more +lines. This can be used in Vim scripts (not at the command line). + +When you want the autocommand do something complicated, which involves jumping +around in the file and then returning to the original position, you may want +to restore the view on the file. See |restore-position| for an example. + + +IGNORING EVENTS + +At times, you will not want to trigger an autocommand. The 'eventignore' +option contains a list of events that will be totally ignored. For example, +the following causes events for entering and leaving a window to be ignored: > + + :set eventignore=WinEnter,WinLeave + +To ignore all events, use the following command: > + + :set eventignore=all + +To set it back to the normal behavior, make 'eventignore' empty: > + + :set eventignore= + +============================================================================== + +Next chapter: |usr_41.txt| Write a Vim script + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_41.txt b/share/vim/vim73/doc/usr_41.txt new file mode 100644 index 0000000000..6ac0dc18ee --- /dev/null +++ b/share/vim/vim73/doc/usr_41.txt @@ -0,0 +1,2429 @@ +*usr_41.txt* For Vim version 7.3. Last change: 2010 Jul 20 + + VIM USER MANUAL - by Bram Moolenaar + + Write a Vim script + + +The Vim script language is used for the startup vimrc file, syntax files, and +many other things. This chapter explains the items that can be used in a Vim +script. There are a lot of them, thus this is a long chapter. + +|41.1| Introduction +|41.2| Variables +|41.3| Expressions +|41.4| Conditionals +|41.5| Executing an expression +|41.6| Using functions +|41.7| Defining a function +|41.8| Lists and Dictionaries +|41.9| Exceptions +|41.10| Various remarks +|41.11| Writing a plugin +|41.12| Writing a filetype plugin +|41.13| Writing a compiler plugin +|41.14| Writing a plugin that loads quickly +|41.15| Writing library scripts +|41.16| Distributing Vim scripts + + Next chapter: |usr_42.txt| Add new menus + Previous chapter: |usr_40.txt| Make new commands +Table of contents: |usr_toc.txt| + +============================================================================== +*41.1* Introduction *vim-script-intro* *script* + +Your first experience with Vim scripts is the vimrc file. Vim reads it when +it starts up and executes the commands. You can set options to values you +prefer. And you can use any colon command in it (commands that start with a +":"; these are sometimes referred to as Ex commands or command-line commands). + Syntax files are also Vim scripts. As are files that set options for a +specific file type. A complicated macro can be defined by a separate Vim +script file. You can think of other uses yourself. + +Let's start with a simple example: > + + :let i = 1 + :while i < 5 + : echo "count is" i + : let i += 1 + :endwhile +< + Note: + The ":" characters are not really needed here. You only need to use + them when you type a command. In a Vim script file they can be left + out. We will use them here anyway to make clear these are colon + commands and make them stand out from Normal mode commands. + Note: + You can try out the examples by yanking the lines from the text here + and executing them with :@" + +The output of the example code is: + + count is 1 ~ + count is 2 ~ + count is 3 ~ + count is 4 ~ + +In the first line the ":let" command assigns a value to a variable. The +generic form is: > + + :let {variable} = {expression} + +In this case the variable name is "i" and the expression is a simple value, +the number one. + The ":while" command starts a loop. The generic form is: > + + :while {condition} + : {statements} + :endwhile + +The statements until the matching ":endwhile" are executed for as long as the +condition is true. The condition used here is the expression "i < 5". This +is true when the variable i is smaller than five. + Note: + If you happen to write a while loop that keeps on running, you can + interrupt it by pressing CTRL-C (CTRL-Break on MS-Windows). + +The ":echo" command prints its arguments. In this case the string "count is" +and the value of the variable i. Since i is one, this will print: + + count is 1 ~ + +Then there is the ":let i += 1" command. This does the same thing as +":let i = i + 1". This adds one to the variable i and assigns the new value +to the same variable. + +The example was given to explain the commands, but would you really want to +make such a loop it can be written much more compact: > + + :for i in range(1, 4) + : echo "count is" i + :endfor + +We won't explain how |:for| and |range()| work until later. Follow the links +if you are impatient. + + +THREE KINDS OF NUMBERS + +Numbers can be decimal, hexadecimal or octal. A hexadecimal number starts +with "0x" or "0X". For example "0x1f" is decimal 31. An octal number starts +with a zero. "017" is decimal 15. Careful: don't put a zero before a decimal +number, it will be interpreted as an octal number! + The ":echo" command always prints decimal numbers. Example: > + + :echo 0x7f 036 +< 127 30 ~ + +A number is made negative with a minus sign. This also works for hexadecimal +and octal numbers. A minus sign is also used for subtraction. Compare this +with the previous example: > + + :echo 0x7f -036 +< 97 ~ + +White space in an expression is ignored. However, it's recommended to use it +for separating items, to make the expression easier to read. For example, to +avoid the confusion with a negative number above, put a space between the +minus sign and the following number: > + + :echo 0x7f - 036 + +============================================================================== +*41.2* Variables + +A variable name consists of ASCII letters, digits and the underscore. It +cannot start with a digit. Valid variable names are: + + counter + _aap3 + very_long_variable_name_with_underscores + FuncLength + LENGTH + +Invalid names are "foo+bar" and "6var". + These variables are global. To see a list of currently defined variables +use this command: > + + :let + +You can use global variables everywhere. This also means that when the +variable "count" is used in one script file, it might also be used in another +file. This leads to confusion at least, and real problems at worst. To avoid +this, you can use a variable local to a script file by prepending "s:". For +example, one script contains this code: > + + :let s:count = 1 + :while s:count < 5 + : source other.vim + : let s:count += 1 + :endwhile + +Since "s:count" is local to this script, you can be sure that sourcing the +"other.vim" script will not change this variable. If "other.vim" also uses an +"s:count" variable, it will be a different copy, local to that script. More +about script-local variables here: |script-variable|. + +There are more kinds of variables, see |internal-variables|. The most often +used ones are: + + b:name variable local to a buffer + w:name variable local to a window + g:name global variable (also in a function) + v:name variable predefined by Vim + + +DELETING VARIABLES + +Variables take up memory and show up in the output of the ":let" command. To +delete a variable use the ":unlet" command. Example: > + + :unlet s:count + +This deletes the script-local variable "s:count" to free up the memory it +uses. If you are not sure if the variable exists, and don't want an error +message when it doesn't, append !: > + + :unlet! s:count + +When a script finishes, the local variables used there will not be +automatically freed. The next time the script executes, it can still use the +old value. Example: > + + :if !exists("s:call_count") + : let s:call_count = 0 + :endif + :let s:call_count = s:call_count + 1 + :echo "called" s:call_count "times" + +The "exists()" function checks if a variable has already been defined. Its +argument is the name of the variable you want to check. Not the variable +itself! If you would do this: > + + :if !exists(s:call_count) + +Then the value of s:call_count will be used as the name of the variable that +exists() checks. That's not what you want. + The exclamation mark ! negates a value. When the value was true, it +becomes false. When it was false, it becomes true. You can read it as "not". +Thus "if !exists()" can be read as "if not exists()". + What Vim calls true is anything that is not zero. Zero is false. + Note: + Vim automatically converts a string to a number when it is looking for + a number. When using a string that doesn't start with a digit the + resulting number is zero. Thus look out for this: > + :if "true" +< The "true" will be interpreted as a zero, thus as false! + + +STRING VARIABLES AND CONSTANTS + +So far only numbers were used for the variable value. Strings can be used as +well. Numbers and strings are the basic types of variables that Vim supports. +The type is dynamic, it is set each time when assigning a value to the +variable with ":let". More about types in |41.8|. + To assign a string value to a variable, you need to use a string constant. +There are two types of these. First the string in double quotes: > + + :let name = "peter" + :echo name +< peter ~ + +If you want to include a double quote inside the string, put a backslash in +front of it: > + + :let name = "\"peter\"" + :echo name +< "peter" ~ + +To avoid the need for a backslash, you can use a string in single quotes: > + + :let name = '"peter"' + :echo name +< "peter" ~ + +Inside a single-quote string all the characters are as they are. Only the +single quote itself is special: you need to use two to get one. A backslash +is taken literally, thus you can't use it to change the meaning of the +character after it. + In double-quote strings it is possible to use special characters. Here are +a few useful ones: + + \t <Tab> + \n <NL>, line break + \r <CR>, <Enter> + \e <Esc> + \b <BS>, backspace + \" " + \\ \, backslash + \<Esc> <Esc> + \<C-W> CTRL-W + +The last two are just examples. The "\<name>" form can be used to include +the special key "name". + See |expr-quote| for the full list of special items in a string. + +============================================================================== +*41.3* Expressions + +Vim has a rich, yet simple way to handle expressions. You can read the +definition here: |expression-syntax|. Here we will show the most common +items. + The numbers, strings and variables mentioned above are expressions by +themselves. Thus everywhere an expression is expected, you can use a number, +string or variable. Other basic items in an expression are: + + $NAME environment variable + &name option + @r register + +Examples: > + + :echo "The value of 'tabstop' is" &ts + :echo "Your home directory is" $HOME + :if @a > 5 + +The &name form can be used to save an option value, set it to a new value, +do something and restore the old value. Example: > + + :let save_ic = &ic + :set noic + :/The Start/,$delete + :let &ic = save_ic + +This makes sure the "The Start" pattern is used with the 'ignorecase' option +off. Still, it keeps the value that the user had set. (Another way to do +this would be to add "\C" to the pattern, see |/\C|.) + + +MATHEMATICS + +It becomes more interesting if we combine these basic items. Let's start with +mathematics on numbers: + + a + b add + a - b subtract + a * b multiply + a / b divide + a % b modulo + +The usual precedence is used. Example: > + + :echo 10 + 5 * 2 +< 20 ~ + +Grouping is done with braces. No surprises here. Example: > + + :echo (10 + 5) * 2 +< 30 ~ + +Strings can be concatenated with ".". Example: > + + :echo "foo" . "bar" +< foobar ~ + +When the ":echo" command gets multiple arguments, it separates them with a +space. In the example the argument is a single expression, thus no space is +inserted. + +Borrowed from the C language is the conditional expression: + + a ? b : c + +If "a" evaluates to true "b" is used, otherwise "c" is used. Example: > + + :let i = 4 + :echo i > 5 ? "i is big" : "i is small" +< i is small ~ + +The three parts of the constructs are always evaluated first, thus you could +see it work as: + + (a) ? (b) : (c) + +============================================================================== +*41.4* Conditionals + +The ":if" commands executes the following statements, until the matching +":endif", only when a condition is met. The generic form is: + + :if {condition} + {statements} + :endif + +Only when the expression {condition} evaluates to true (non-zero) will the +{statements} be executed. These must still be valid commands. If they +contain garbage, Vim won't be able to find the ":endif". + You can also use ":else". The generic form for this is: + + :if {condition} + {statements} + :else + {statements} + :endif + +The second {statements} is only executed if the first one isn't. + Finally, there is ":elseif": + + :if {condition} + {statements} + :elseif {condition} + {statements} + :endif + +This works just like using ":else" and then "if", but without the need for an +extra ":endif". + A useful example for your vimrc file is checking the 'term' option and +doing something depending upon its value: > + + :if &term == "xterm" + : " Do stuff for xterm + :elseif &term == "vt100" + : " Do stuff for a vt100 terminal + :else + : " Do something for other terminals + :endif + + +LOGIC OPERATIONS + +We already used some of them in the examples. These are the most often used +ones: + + a == b equal to + a != b not equal to + a > b greater than + a >= b greater than or equal to + a < b less than + a <= b less than or equal to + +The result is one if the condition is met and zero otherwise. An example: > + + :if v:version >= 700 + : echo "congratulations" + :else + : echo "you are using an old version, upgrade!" + :endif + +Here "v:version" is a variable defined by Vim, which has the value of the Vim +version. 600 is for version 6.0. Version 6.1 has the value 601. This is +very useful to write a script that works with multiple versions of Vim. +|v:version| + +The logic operators work both for numbers and strings. When comparing two +strings, the mathematical difference is used. This compares byte values, +which may not be right for some languages. + When comparing a string with a number, the string is first converted to a +number. This is a bit tricky, because when a string doesn't look like a +number, the number zero is used. Example: > + + :if 0 == "one" + : echo "yes" + :endif + +This will echo "yes", because "one" doesn't look like a number, thus it is +converted to the number zero. + +For strings there are two more items: + + a =~ b matches with + a !~ b does not match with + +The left item "a" is used as a string. The right item "b" is used as a +pattern, like what's used for searching. Example: > + + :if str =~ " " + : echo "str contains a space" + :endif + :if str !~ '\.$' + : echo "str does not end in a full stop" + :endif + +Notice the use of a single-quote string for the pattern. This is useful, +because backslashes would need to be doubled in a double-quote string and +patterns tend to contain many backslashes. + +The 'ignorecase' option is used when comparing strings. When you don't want +that, append "#" to match case and "?" to ignore case. Thus "==?" compares +two strings to be equal while ignoring case. And "!~#" checks if a pattern +doesn't match, also checking the case of letters. For the full table see +|expr-==|. + + +MORE LOOPING + +The ":while" command was already mentioned. Two more statements can be used +in between the ":while" and the ":endwhile": + + :continue Jump back to the start of the while loop; the + loop continues. + :break Jump forward to the ":endwhile"; the loop is + discontinued. + +Example: > + + :while counter < 40 + : call do_something() + : if skip_flag + : continue + : endif + : if finished_flag + : break + : endif + : sleep 50m + :endwhile + +The ":sleep" command makes Vim take a nap. The "50m" specifies fifty +milliseconds. Another example is ":sleep 4", which sleeps for four seconds. + +Even more looping can be done with the ":for" command, see below in |41.8|. + +============================================================================== +*41.5* Executing an expression + +So far the commands in the script were executed by Vim directly. The +":execute" command allows executing the result of an expression. This is a +very powerful way to build commands and execute them. + An example is to jump to a tag, which is contained in a variable: > + + :execute "tag " . tag_name + +The "." is used to concatenate the string "tag " with the value of variable +"tag_name". Suppose "tag_name" has the value "get_cmd", then the command that +will be executed is: > + + :tag get_cmd + +The ":execute" command can only execute colon commands. The ":normal" command +executes Normal mode commands. However, its argument is not an expression but +the literal command characters. Example: > + + :normal gg=G + +This jumps to the first line and formats all lines with the "=" operator. + To make ":normal" work with an expression, combine ":execute" with it. +Example: > + + :execute "normal " . normal_commands + +The variable "normal_commands" must contain the Normal mode commands. + Make sure that the argument for ":normal" is a complete command. Otherwise +Vim will run into the end of the argument and abort the command. For example, +if you start Insert mode, you must leave Insert mode as well. This works: > + + :execute "normal Inew text \<Esc>" + +This inserts "new text " in the current line. Notice the use of the special +key "\<Esc>". This avoids having to enter a real <Esc> character in your +script. + +If you don't want to execute a string but evaluate it to get its expression +value, you can use the eval() function: > + + :let optname = "path" + :let optval = eval('&' . optname) + +A "&" character is prepended to "path", thus the argument to eval() is +"&path". The result will then be the value of the 'path' option. + The same thing can be done with: > + :exe 'let optval = &' . optname + +============================================================================== +*41.6* Using functions + +Vim defines many functions and provides a large amount of functionality that +way. A few examples will be given in this section. You can find the whole +list here: |functions|. + +A function is called with the ":call" command. The parameters are passed in +between braces, separated by commas. Example: > + + :call search("Date: ", "W") + +This calls the search() function, with arguments "Date: " and "W". The +search() function uses its first argument as a search pattern and the second +one as flags. The "W" flag means the search doesn't wrap around the end of +the file. + +A function can be called in an expression. Example: > + + :let line = getline(".") + :let repl = substitute(line, '\a', "*", "g") + :call setline(".", repl) + +The getline() function obtains a line from the current buffer. Its argument +is a specification of the line number. In this case "." is used, which means +the line where the cursor is. + The substitute() function does something similar to the ":substitute" +command. The first argument is the string on which to perform the +substitution. The second argument is the pattern, the third the replacement +string. Finally, the last arguments are the flags. + The setline() function sets the line, specified by the first argument, to a +new string, the second argument. In this example the line under the cursor is +replaced with the result of the substitute(). Thus the effect of the three +statements is equal to: > + + :substitute/\a/*/g + +Using the functions becomes more interesting when you do more work before and +after the substitute() call. + + +FUNCTIONS *function-list* + +There are many functions. We will mention them here, grouped by what they are +used for. You can find an alphabetical list here: |functions|. Use CTRL-] on +the function name to jump to detailed help on it. + +String manipulation: *string-functions* + nr2char() get a character by its ASCII value + char2nr() get ASCII value of a character + str2nr() convert a string to a Number + str2float() convert a string to a Float + printf() format a string according to % items + escape() escape characters in a string with a '\' + shellescape() escape a string for use with a shell command + fnameescape() escape a file name for use with a Vim command + tr() translate characters from one set to another + strtrans() translate a string to make it printable + tolower() turn a string to lowercase + toupper() turn a string to uppercase + match() position where a pattern matches in a string + matchend() position where a pattern match ends in a string + matchstr() match of a pattern in a string + matchlist() like matchstr() and also return submatches + stridx() first index of a short string in a long string + strridx() last index of a short string in a long string + strlen() length of a string + substitute() substitute a pattern match with a string + submatch() get a specific match in a ":substitute" + strpart() get part of a string + expand() expand special keywords + iconv() convert text from one encoding to another + byteidx() byte index of a character in a string + repeat() repeat a string multiple times + eval() evaluate a string expression + +List manipulation: *list-functions* + get() get an item without error for wrong index + len() number of items in a List + empty() check if List is empty + insert() insert an item somewhere in a List + add() append an item to a List + extend() append a List to a List + remove() remove one or more items from a List + copy() make a shallow copy of a List + deepcopy() make a full copy of a List + filter() remove selected items from a List + map() change each List item + sort() sort a List + reverse() reverse the order of a List + split() split a String into a List + join() join List items into a String + range() return a List with a sequence of numbers + string() String representation of a List + call() call a function with List as arguments + index() index of a value in a List + max() maximum value in a List + min() minimum value in a List + count() count number of times a value appears in a List + repeat() repeat a List multiple times + +Dictionary manipulation: *dict-functions* + get() get an entry without an error for a wrong key + len() number of entries in a Dictionary + has_key() check whether a key appears in a Dictionary + empty() check if Dictionary is empty + remove() remove an entry from a Dictionary + extend() add entries from one Dictionary to another + filter() remove selected entries from a Dictionary + map() change each Dictionary entry + keys() get List of Dictionary keys + values() get List of Dictionary values + items() get List of Dictionary key-value pairs + copy() make a shallow copy of a Dictionary + deepcopy() make a full copy of a Dictionary + string() String representation of a Dictionary + max() maximum value in a Dictionary + min() minimum value in a Dictionary + count() count number of times a value appears + +Floating point computation: *float-functions* + float2nr() convert Float to Number + abs() absolute value (also works for Number) + round() round off + ceil() round up + floor() round down + trunc() remove value after decimal point + log10() logarithm to base 10 + pow() value of x to the exponent y + sqrt() square root + sin() sine + cos() cosine + atan() arc tangent + +Variables: *var-functions* + type() type of a variable + islocked() check if a variable is locked + function() get a Funcref for a function name + getbufvar() get a variable value from a specific buffer + setbufvar() set a variable in a specific buffer + getwinvar() get a variable from specific window + gettabvar() get a variable from specific tab page + gettabwinvar() get a variable from specific window & tab page + setwinvar() set a variable in a specific window + settabvar() set a variable in a specific tab page + settabwinvar() set a variable in a specific window & tab page + garbagecollect() possibly free memory + +Cursor and mark position: *cursor-functions* *mark-functions* + col() column number of the cursor or a mark + virtcol() screen column of the cursor or a mark + line() line number of the cursor or mark + wincol() window column number of the cursor + winline() window line number of the cursor + cursor() position the cursor at a line/column + getpos() get position of cursor, mark, etc. + setpos() set position of cursor, mark, etc. + byte2line() get line number at a specific byte count + line2byte() byte count at a specific line + diff_filler() get the number of filler lines above a line + +Working with text in the current buffer: *text-functions* + getline() get a line or list of lines from the buffer + setline() replace a line in the buffer + append() append line or list of lines in the buffer + indent() indent of a specific line + cindent() indent according to C indenting + lispindent() indent according to Lisp indenting + nextnonblank() find next non-blank line + prevnonblank() find previous non-blank line + search() find a match for a pattern + searchpos() find a match for a pattern + searchpair() find the other end of a start/skip/end + searchpairpos() find the other end of a start/skip/end + searchdecl() search for the declaration of a name + + *system-functions* *file-functions* +System functions and manipulation of files: + glob() expand wildcards + globpath() expand wildcards in a number of directories + findfile() find a file in a list of directories + finddir() find a directory in a list of directories + resolve() find out where a shortcut points to + fnamemodify() modify a file name + pathshorten() shorten directory names in a path + simplify() simplify a path without changing its meaning + executable() check if an executable program exists + filereadable() check if a file can be read + filewritable() check if a file can be written to + getfperm() get the permissions of a file + getftype() get the kind of a file + isdirectory() check if a directory exists + getfsize() get the size of a file + getcwd() get the current working directory + haslocaldir() check if current window used |:lcd| + tempname() get the name of a temporary file + mkdir() create a new directory + delete() delete a file + rename() rename a file + system() get the result of a shell command + hostname() name of the system + readfile() read a file into a List of lines + writefile() write a List of lines into a file + +Date and Time: *date-functions* *time-functions* + getftime() get last modification time of a file + localtime() get current time in seconds + strftime() convert time to a string + reltime() get the current or elapsed time accurately + reltimestr() convert reltime() result to a string + + *buffer-functions* *window-functions* *arg-functions* +Buffers, windows and the argument list: + argc() number of entries in the argument list + argidx() current position in the argument list + argv() get one entry from the argument list + bufexists() check if a buffer exists + buflisted() check if a buffer exists and is listed + bufloaded() check if a buffer exists and is loaded + bufname() get the name of a specific buffer + bufnr() get the buffer number of a specific buffer + tabpagebuflist() return List of buffers in a tab page + tabpagenr() get the number of a tab page + tabpagewinnr() like winnr() for a specified tab page + winnr() get the window number for the current window + bufwinnr() get the window number of a specific buffer + winbufnr() get the buffer number of a specific window + getbufline() get a list of lines from the specified buffer + +Command line: *command-line-functions* + getcmdline() get the current command line + getcmdpos() get position of the cursor in the command line + setcmdpos() set position of the cursor in the command line + getcmdtype() return the current command-line type + +Quickfix and location lists: *quickfix-functions* + getqflist() list of quickfix errors + setqflist() modify a quickfix list + getloclist() list of location list items + setloclist() modify a location list + +Insert mode completion: *completion-functions* + complete() set found matches + complete_add() add to found matches + complete_check() check if completion should be aborted + pumvisible() check if the popup menu is displayed + +Folding: *folding-functions* + foldclosed() check for a closed fold at a specific line + foldclosedend() like foldclosed() but return the last line + foldlevel() check for the fold level at a specific line + foldtext() generate the line displayed for a closed fold + foldtextresult() get the text displayed for a closed fold + +Syntax and highlighting: *syntax-functions* *highlighting-functions* + clearmatches() clear all matches defined by |matchadd()| and + the |:match| commands + getmatches() get all matches defined by |matchadd()| and + the |:match| commands + hlexists() check if a highlight group exists + hlID() get ID of a highlight group + synID() get syntax ID at a specific position + synIDattr() get a specific attribute of a syntax ID + synIDtrans() get translated syntax ID + diff_hlID() get highlight ID for diff mode at a position + matchadd() define a pattern to highlight (a "match") + matcharg() get info about |:match| arguments + matchdelete() delete a match defined by |matchadd()| or a + |:match| command + setmatches() restore a list of matches saved by + |getmatches()| + +Spelling: *spell-functions* + spellbadword() locate badly spelled word at or after cursor + spellsuggest() return suggested spelling corrections + soundfold() return the sound-a-like equivalent of a word + +History: *history-functions* + histadd() add an item to a history + histdel() delete an item from a history + histget() get an item from a history + histnr() get highest index of a history list + +Interactive: *interactive-functions* + browse() put up a file requester + browsedir() put up a directory requester + confirm() let the user make a choice + getchar() get a character from the user + getcharmod() get modifiers for the last typed character + feedkeys() put characters in the typeahead queue + input() get a line from the user + inputlist() let the user pick an entry from a list + inputsecret() get a line from the user without showing it + inputdialog() get a line from the user in a dialog + inputsave() save and clear typeahead + inputrestore() restore typeahead + +GUI: *gui-functions* + getfontname() get name of current font being used + getwinposx() X position of the GUI Vim window + getwinposy() Y position of the GUI Vim window + +Vim server: *server-functions* + serverlist() return the list of server names + remote_send() send command characters to a Vim server + remote_expr() evaluate an expression in a Vim server + server2client() send a reply to a client of a Vim server + remote_peek() check if there is a reply from a Vim server + remote_read() read a reply from a Vim server + foreground() move the Vim window to the foreground + remote_foreground() move the Vim server window to the foreground + +Window size and position: *window-size-functions* + winheight() get height of a specific window + winwidth() get width of a specific window + winrestcmd() return command to restore window sizes + winsaveview() get view of current window + winrestview() restore saved view of current window + +Various: *various-functions* + mode() get current editing mode + visualmode() last visual mode used + hasmapto() check if a mapping exists + mapcheck() check if a matching mapping exists + maparg() get rhs of a mapping + exists() check if a variable, function, etc. exists + has() check if a feature is supported in Vim + changenr() return number of most recent change + cscope_connection() check if a cscope connection exists + did_filetype() check if a FileType autocommand was used + eventhandler() check if invoked by an event handler + getpid() get process ID of Vim + + libcall() call a function in an external library + libcallnr() idem, returning a number + + getreg() get contents of a register + getregtype() get type of a register + setreg() set contents and type of a register + + taglist() get list of matching tags + tagfiles() get a list of tags files + + mzeval() evaluate |MzScheme| expression + +============================================================================== +*41.7* Defining a function + +Vim enables you to define your own functions. The basic function declaration +begins as follows: > + + :function {name}({var1}, {var2}, ...) + : {body} + :endfunction +< + Note: + Function names must begin with a capital letter. + +Let's define a short function to return the smaller of two numbers. It starts +with this line: > + + :function Min(num1, num2) + +This tells Vim that the function is named "Min" and it takes two arguments: +"num1" and "num2". + The first thing you need to do is to check to see which number is smaller: + > + : if a:num1 < a:num2 + +The special prefix "a:" tells Vim that the variable is a function argument. +Let's assign the variable "smaller" the value of the smallest number: > + + : if a:num1 < a:num2 + : let smaller = a:num1 + : else + : let smaller = a:num2 + : endif + +The variable "smaller" is a local variable. Variables used inside a function +are local unless prefixed by something like "g:", "a:", or "s:". + + Note: + To access a global variable from inside a function you must prepend + "g:" to it. Thus "g:today" inside a function is used for the global + variable "today", and "today" is another variable, local to the + function. + +You now use the ":return" statement to return the smallest number to the user. +Finally, you end the function: > + + : return smaller + :endfunction + +The complete function definition is as follows: > + + :function Min(num1, num2) + : if a:num1 < a:num2 + : let smaller = a:num1 + : else + : let smaller = a:num2 + : endif + : return smaller + :endfunction + +For people who like short functions, this does the same thing: > + + :function Min(num1, num2) + : if a:num1 < a:num2 + : return a:num1 + : endif + : return a:num2 + :endfunction + +A user defined function is called in exactly the same way as a built-in +function. Only the name is different. The Min function can be used like +this: > + + :echo Min(5, 8) + +Only now will the function be executed and the lines be interpreted by Vim. +If there are mistakes, like using an undefined variable or function, you will +now get an error message. When defining the function these errors are not +detected. + +When a function reaches ":endfunction" or ":return" is used without an +argument, the function returns zero. + +To redefine a function that already exists, use the ! for the ":function" +command: > + + :function! Min(num1, num2, num3) + + +USING A RANGE + +The ":call" command can be given a line range. This can have one of two +meanings. When a function has been defined with the "range" keyword, it will +take care of the line range itself. + The function will be passed the variables "a:firstline" and "a:lastline". +These will have the line numbers from the range the function was called with. +Example: > + + :function Count_words() range + : let lnum = a:firstline + : let n = 0 + : while lnum <= a:lastline + : let n = n + len(split(getline(lnum))) + : let lnum = lnum + 1 + : endwhile + : echo "found " . n . " words" + :endfunction + +You can call this function with: > + + :10,30call Count_words() + +It will be executed once and echo the number of words. + The other way to use a line range is by defining a function without the +"range" keyword. The function will be called once for every line in the +range, with the cursor in that line. Example: > + + :function Number() + : echo "line " . line(".") . " contains: " . getline(".") + :endfunction + +If you call this function with: > + + :10,15call Number() + +The function will be called six times. + + +VARIABLE NUMBER OF ARGUMENTS + +Vim enables you to define functions that have a variable number of arguments. +The following command, for instance, defines a function that must have 1 +argument (start) and can have up to 20 additional arguments: > + + :function Show(start, ...) + +The variable "a:1" contains the first optional argument, "a:2" the second, and +so on. The variable "a:0" contains the number of extra arguments. + For example: > + + :function Show(start, ...) + : echohl Title + : echo "Show is " . a:start + : echohl None + : let index = 1 + : while index <= a:0 + : echo " Arg " . index . " is " . a:{index} + : let index = index + 1 + : endwhile + : echo "" + :endfunction + +This uses the ":echohl" command to specify the highlighting used for the +following ":echo" command. ":echohl None" stops it again. The ":echon" +command works like ":echo", but doesn't output a line break. + +You can also use the a:000 variable, it is a List of all the "..." arguments. +See |a:000|. + + +LISTING FUNCTIONS + +The ":function" command lists the names and arguments of all user-defined +functions: > + + :function +< function Show(start, ...) ~ + function GetVimIndent() ~ + function SetSyn(name) ~ + +To see what a function does, use its name as an argument for ":function": > + + :function SetSyn +< 1 if &syntax == '' ~ + 2 let &syntax = a:name ~ + 3 endif ~ + endfunction ~ + + +DEBUGGING + +The line number is useful for when you get an error message or when debugging. +See |debug-scripts| about debugging mode. + You can also set the 'verbose' option to 12 or higher to see all function +calls. Set it to 15 or higher to see every executed line. + + +DELETING A FUNCTION + +To delete the Show() function: > + + :delfunction Show + +You get an error when the function doesn't exist. + + +FUNCTION REFERENCES + +Sometimes it can be useful to have a variable point to one function or +another. You can do it with the function() function. It turns the name of a +function into a reference: > + + :let result = 0 " or 1 + :function! Right() + : return 'Right!' + :endfunc + :function! Wrong() + : return 'Wrong!' + :endfunc + : + :if result == 1 + : let Afunc = function('Right') + :else + : let Afunc = function('Wrong') + :endif + :echo call(Afunc, []) +< Wrong! ~ + +Note that the name of a variable that holds a function reference must start +with a capital. Otherwise it could be confused with the name of a builtin +function. + The way to invoke a function that a variable refers to is with the call() +function. Its first argument is the function reference, the second argument +is a List with arguments. + +Function references are most useful in combination with a Dictionary, as is +explained in the next section. + +============================================================================== +*41.8* Lists and Dictionaries + +So far we have used the basic types String and Number. Vim also supports two +composite types: List and Dictionary. + +A List is an ordered sequence of things. The things can be any kind of value, +thus you can make a List of numbers, a List of Lists and even a List of mixed +items. To create a List with three strings: > + + :let alist = ['aap', 'mies', 'noot'] + +The List items are enclosed in square brackets and separated by commas. To +create an empty List: > + + :let alist = [] + +You can add items to a List with the add() function: > + + :let alist = [] + :call add(alist, 'foo') + :call add(alist, 'bar') + :echo alist +< ['foo', 'bar'] ~ + +List concatenation is done with +: > + + :echo alist + ['foo', 'bar'] +< ['foo', 'bar', 'foo', 'bar'] ~ + +Or, if you want to extend a List directly: > + + :let alist = ['one'] + :call extend(alist, ['two', 'three']) + :echo alist +< ['one', 'two', 'three'] ~ + +Notice that using add() will have a different effect: > + + :let alist = ['one'] + :call add(alist, ['two', 'three']) + :echo alist +< ['one', ['two', 'three']] ~ + +The second argument of add() is added as a single item. + + +FOR LOOP + +One of the nice things you can do with a List is iterate over it: > + + :let alist = ['one', 'two', 'three'] + :for n in alist + : echo n + :endfor +< one ~ + two ~ + three ~ + +This will loop over each element in List "alist", assigning the value to +variable "n". The generic form of a for loop is: > + + :for {varname} in {listexpression} + : {commands} + :endfor + +To loop a certain number of times you need a List of a specific length. The +range() function creates one for you: > + + :for a in range(3) + : echo a + :endfor +< 0 ~ + 1 ~ + 2 ~ + +Notice that the first item of the List that range() produces is zero, thus the +last item is one less than the length of the list. + You can also specify the maximum value, the stride and even go backwards: > + + :for a in range(8, 4, -2) + : echo a + :endfor +< 8 ~ + 6 ~ + 4 ~ + +A more useful example, looping over lines in the buffer: > + + :for line in getline(1, 20) + : if line =~ "Date: " + : echo matchstr(line, 'Date: \zs.*') + : endif + :endfor + +This looks into lines 1 to 20 (inclusive) and echoes any date found in there. + + +DICTIONARIES + +A Dictionary stores key-value pairs. You can quickly lookup a value if you +know the key. A Dictionary is created with curly braces: > + + :let uk2nl = {'one': 'een', 'two': 'twee', 'three': 'drie'} + +Now you can lookup words by putting the key in square brackets: > + + :echo uk2nl['two'] +< twee ~ + +The generic form for defining a Dictionary is: > + + {<key> : <value>, ...} + +An empty Dictionary is one without any keys: > + + {} + +The possibilities with Dictionaries are numerous. There are various functions +for them as well. For example, you can obtain a list of the keys and loop +over them: > + + :for key in keys(uk2nl) + : echo key + :endfor +< three ~ + one ~ + two ~ + +You will notice the keys are not ordered. You can sort the list to get a +specific order: > + + :for key in sort(keys(uk2nl)) + : echo key + :endfor +< one ~ + three ~ + two ~ + +But you can never get back the order in which items are defined. For that you +need to use a List, it stores items in an ordered sequence. + + +DICTIONARY FUNCTIONS + +The items in a Dictionary can normally be obtained with an index in square +brackets: > + + :echo uk2nl['one'] +< een ~ + +A method that does the same, but without so many punctuation characters: > + + :echo uk2nl.one +< een ~ + +This only works for a key that is made of ASCII letters, digits and the +underscore. You can also assign a new value this way: > + + :let uk2nl.four = 'vier' + :echo uk2nl +< {'three': 'drie', 'four': 'vier', 'one': 'een', 'two': 'twee'} ~ + +And now for something special: you can directly define a function and store a +reference to it in the dictionary: > + + :function uk2nl.translate(line) dict + : return join(map(split(a:line), 'get(self, v:val, "???")')) + :endfunction + +Let's first try it out: > + + :echo uk2nl.translate('three two five one') +< drie twee ??? een ~ + +The first special thing you notice is the "dict" at the end of the ":function" +line. This marks the function as being used from a Dictionary. The "self" +local variable will then refer to that Dictionary. + Now let's break up the complicated return command: > + + split(a:line) + +The split() function takes a string, chops it into white separated words +and returns a list with these words. Thus in the example it returns: > + + :echo split('three two five one') +< ['three', 'two', 'five', 'one'] ~ + +This list is the first argument to the map() function. This will go through +the list, evaluating its second argument with "v:val" set to the value of each +item. This is a shortcut to using a for loop. This command: > + + :let alist = map(split(a:line), 'get(self, v:val, "???")') + +Is equivalent to: > + + :let alist = split(a:line) + :for idx in range(len(alist)) + : let alist[idx] = get(self, alist[idx], "???") + :endfor + +The get() function checks if a key is present in a Dictionary. If it is, then +the value is retrieved. If it isn't, then the default value is returned, in +the example it's '???'. This is a convenient way to handle situations where a +key may not be present and you don't want an error message. + +The join() function does the opposite of split(): it joins together a list of +words, putting a space in between. + This combination of split(), map() and join() is a nice way to filter a line +of words in a very compact way. + + +OBJECT ORIENTED PROGRAMMING + +Now that you can put both values and functions in a Dictionary, you can +actually use a Dictionary like an object. + Above we used a Dictionary for translating Dutch to English. We might want +to do the same for other languages. Let's first make an object (aka +Dictionary) that has the translate function, but no words to translate: > + + :let transdict = {} + :function transdict.translate(line) dict + : return join(map(split(a:line), 'get(self.words, v:val, "???")')) + :endfunction + +It's slightly different from the function above, using 'self.words' to lookup +word translations. But we don't have a self.words. Thus you could call this +an abstract class. + +Now we can instantiate a Dutch translation object: > + + :let uk2nl = copy(transdict) + :let uk2nl.words = {'one': 'een', 'two': 'twee', 'three': 'drie'} + :echo uk2nl.translate('three one') +< drie een ~ + +And a German translator: > + + :let uk2de = copy(transdict) + :let uk2de.words = {'one': 'ein', 'two': 'zwei', 'three': 'drei'} + :echo uk2de.translate('three one') +< drei ein ~ + +You see that the copy() function is used to make a copy of the "transdict" +Dictionary and then the copy is changed to add the words. The original +remains the same, of course. + +Now you can go one step further, and use your preferred translator: > + + :if $LANG =~ "de" + : let trans = uk2de + :else + : let trans = uk2nl + :endif + :echo trans.translate('one two three') +< een twee drie ~ + +Here "trans" refers to one of the two objects (Dictionaries). No copy is +made. More about List and Dictionary identity can be found at |list-identity| +and |dict-identity|. + +Now you might use a language that isn't supported. You can overrule the +translate() function to do nothing: > + + :let uk2uk = copy(transdict) + :function! uk2uk.translate(line) + : return a:line + :endfunction + :echo uk2uk.translate('three one wladiwostok') +< three one wladiwostok ~ + +Notice that a ! was used to overwrite the existing function reference. Now +use "uk2uk" when no recognized language is found: > + + :if $LANG =~ "de" + : let trans = uk2de + :elseif $LANG =~ "nl" + : let trans = uk2nl + :else + : let trans = uk2uk + :endif + :echo trans.translate('one two three') +< one two three ~ + +For further reading see |Lists| and |Dictionaries|. + +============================================================================== +*41.9* Exceptions + +Let's start with an example: > + + :try + : read ~/templates/pascal.tmpl + :catch /E484:/ + : echo "Sorry, the Pascal template file cannot be found." + :endtry + +The ":read" command will fail if the file does not exist. Instead of +generating an error message, this code catches the error and gives the user a +nice message instead. + +For the commands in between ":try" and ":endtry" errors are turned into +exceptions. An exception is a string. In the case of an error the string +contains the error message. And every error message has a number. In this +case, the error we catch contains "E484:". This number is guaranteed to stay +the same (the text may change, e.g., it may be translated). + +When the ":read" command causes another error, the pattern "E484:" will not +match in it. Thus this exception will not be caught and result in the usual +error message. + +You might be tempted to do this: > + + :try + : read ~/templates/pascal.tmpl + :catch + : echo "Sorry, the Pascal template file cannot be found." + :endtry + +This means all errors are caught. But then you will not see errors that are +useful, such as "E21: Cannot make changes, 'modifiable' is off". + +Another useful mechanism is the ":finally" command: > + + :let tmp = tempname() + :try + : exe ".,$write " . tmp + : exe "!filter " . tmp + : .,$delete + : exe "$read " . tmp + :finally + : call delete(tmp) + :endtry + +This filters the lines from the cursor until the end of the file through the +"filter" command, which takes a file name argument. No matter if the +filtering works, something goes wrong in between ":try" and ":finally" or the +user cancels the filtering by pressing CTRL-C, the "call delete(tmp)" is +always executed. This makes sure you don't leave the temporary file behind. + +More information about exception handling can be found in the reference +manual: |exception-handling|. + +============================================================================== +*41.10* Various remarks + +Here is a summary of items that apply to Vim scripts. They are also mentioned +elsewhere, but form a nice checklist. + +The end-of-line character depends on the system. For Unix a single <NL> +character is used. For MS-DOS, Windows, OS/2 and the like, <CR><LF> is used. +This is important when using mappings that end in a <CR>. See |:source_crnl|. + + +WHITE SPACE + +Blank lines are allowed and ignored. + +Leading whitespace characters (blanks and TABs) are always ignored. The +whitespaces between parameters (e.g. between the 'set' and the 'cpoptions' in +the example below) are reduced to one blank character and plays the role of a +separator, the whitespaces after the last (visible) character may or may not +be ignored depending on the situation, see below. + +For a ":set" command involving the "=" (equal) sign, such as in: > + + :set cpoptions =aABceFst + +the whitespace immediately before the "=" sign is ignored. But there can be +no whitespace after the "=" sign! + +To include a whitespace character in the value of an option, it must be +escaped by a "\" (backslash) as in the following example: > + + :set tags=my\ nice\ file + +The same example written as > + + :set tags=my nice file + +will issue an error, because it is interpreted as: > + + :set tags=my + :set nice + :set file + + +COMMENTS + +The character " (the double quote mark) starts a comment. Everything after +and including this character until the end-of-line is considered a comment and +is ignored, except for commands that don't consider comments, as shown in +examples below. A comment can start on any character position on the line. + +There is a little "catch" with comments for some commands. Examples: > + + :abbrev dev development " shorthand + :map <F3> o#include " insert include + :execute cmd " do it + :!ls *.c " list C files + +The abbreviation 'dev' will be expanded to 'development " shorthand'. The +mapping of <F3> will actually be the whole line after the 'o# ....' including +the '" insert include'. The "execute" command will give an error. The "!" +command will send everything after it to the shell, causing an error for an +unmatched '"' character. + There can be no comment after ":map", ":abbreviate", ":execute" and "!" +commands (there are a few more commands with this restriction). For the +":map", ":abbreviate" and ":execute" commands there is a trick: > + + :abbrev dev development|" shorthand + :map <F3> o#include|" insert include + :execute cmd |" do it + +With the '|' character the command is separated from the next one. And that +next command is only a comment. For the last command you need to do two +things: |:execute| and use '|': > + :exe '!ls *.c' |" list C files + +Notice that there is no white space before the '|' in the abbreviation and +mapping. For these commands, any character until the end-of-line or '|' is +included. As a consequence of this behavior, you don't always see that +trailing whitespace is included: > + + :map <F4> o#include + +To spot these problems, you can set the 'list' option when editing vimrc +files. + +For Unix there is one special way to comment a line, that allows making a Vim +script executable: > + #!/usr/bin/env vim -S + echo "this is a Vim script" + quit + +The "#" command by itself lists a line with the line number. Adding an +exclamation mark changes it into doing nothing, so that you can add the shell +command to execute the rest of the file. |:#!| |-S| + + +PITFALLS + +Even bigger problem arises in the following example: > + + :map ,ab o#include + :unmap ,ab + +Here the unmap command will not work, because it tries to unmap ",ab ". This +does not exist as a mapped sequence. An error will be issued, which is very +hard to identify, because the ending whitespace character in ":unmap ,ab " is +not visible. + +And this is the same as what happens when one uses a comment after an 'unmap' +command: > + + :unmap ,ab " comment + +Here the comment part will be ignored. However, Vim will try to unmap +',ab ', which does not exist. Rewrite it as: > + + :unmap ,ab| " comment + + +RESTORING THE VIEW + +Sometimes you want to make a change and go back to where cursor was. +Restoring the relative position would also be nice, so that the same line +appears at the top of the window. + This example yanks the current line, puts it above the first line in the +file and then restores the view: > + + map ,p ma"aYHmbgg"aP`bzt`a + +What this does: > + ma"aYHmbgg"aP`bzt`a +< ma set mark a at cursor position + "aY yank current line into register a + Hmb go to top line in window and set mark b there + gg go to first line in file + "aP put the yanked line above it + `b go back to top line in display + zt position the text in the window as before + `a go back to saved cursor position + + +PACKAGING + +To avoid your function names to interfere with functions that you get from +others, use this scheme: +- Prepend a unique string before each function name. I often use an + abbreviation. For example, "OW_" is used for the option window functions. +- Put the definition of your functions together in a file. Set a global + variable to indicate that the functions have been loaded. When sourcing the + file again, first unload the functions. +Example: > + + " This is the XXX package + + if exists("XXX_loaded") + delfun XXX_one + delfun XXX_two + endif + + function XXX_one(a) + ... body of function ... + endfun + + function XXX_two(b) + ... body of function ... + endfun + + let XXX_loaded = 1 + +============================================================================== +*41.11* Writing a plugin *write-plugin* + +You can write a Vim script in such a way that many people can use it. This is +called a plugin. Vim users can drop your script in their plugin directory and +use its features right away |add-plugin|. + +There are actually two types of plugins: + + global plugins: For all types of files. +filetype plugins: Only for files of a specific type. + +In this section the first type is explained. Most items are also relevant for +writing filetype plugins. The specifics for filetype plugins are in the next +section |write-filetype-plugin|. + + +NAME + +First of all you must choose a name for your plugin. The features provided +by the plugin should be clear from its name. And it should be unlikely that +someone else writes a plugin with the same name but which does something +different. And please limit the name to 8 characters, to avoid problems on +old Windows systems. + +A script that corrects typing mistakes could be called "typecorr.vim". We +will use it here as an example. + +For the plugin to work for everybody, it should follow a few guidelines. This +will be explained step-by-step. The complete example plugin is at the end. + + +BODY + +Let's start with the body of the plugin, the lines that do the actual work: > + + 14 iabbrev teh the + 15 iabbrev otehr other + 16 iabbrev wnat want + 17 iabbrev synchronisation + 18 \ synchronization + 19 let s:count = 4 + +The actual list should be much longer, of course. + +The line numbers have only been added to explain a few things, don't put them +in your plugin file! + + +HEADER + +You will probably add new corrections to the plugin and soon have several +versions laying around. And when distributing this file, people will want to +know who wrote this wonderful plugin and where they can send remarks. +Therefore, put a header at the top of your plugin: > + + 1 " Vim global plugin for correcting typing mistakes + 2 " Last Change: 2000 Oct 15 + 3 " Maintainer: Bram Moolenaar <Bram@vim.org> + +About copyright and licensing: Since plugins are very useful and it's hardly +worth restricting their distribution, please consider making your plugin +either public domain or use the Vim |license|. A short note about this near +the top of the plugin should be sufficient. Example: > + + 4 " License: This file is placed in the public domain. + + +LINE CONTINUATION, AVOIDING SIDE EFFECTS *use-cpo-save* + +In line 18 above, the line-continuation mechanism is used |line-continuation|. +Users with 'compatible' set will run into trouble here, they will get an error +message. We can't just reset 'compatible', because that has a lot of side +effects. To avoid this, we will set the 'cpoptions' option to its Vim default +value and restore it later. That will allow the use of line-continuation and +make the script work for most people. It is done like this: > + + 11 let s:save_cpo = &cpo + 12 set cpo&vim + .. + 42 let &cpo = s:save_cpo + +We first store the old value of 'cpoptions' in the s:save_cpo variable. At +the end of the plugin this value is restored. + +Notice that a script-local variable is used |s:var|. A global variable could +already be in use for something else. Always use script-local variables for +things that are only used in the script. + + +NOT LOADING + +It's possible that a user doesn't always want to load this plugin. Or the +system administrator has dropped it in the system-wide plugin directory, but a +user has his own plugin he wants to use. Then the user must have a chance to +disable loading this specific plugin. This will make it possible: > + + 6 if exists("g:loaded_typecorr") + 7 finish + 8 endif + 9 let g:loaded_typecorr = 1 + +This also avoids that when the script is loaded twice it would cause error +messages for redefining functions and cause trouble for autocommands that are +added twice. + +The name is recommended to start with "loaded_" and then the file name of the +plugin, literally. The "g:" is prepended just to avoid mistakes when using +the variable in a function (without "g:" it would be a variable local to the +function). + +Using "finish" stops Vim from reading the rest of the file, it's much quicker +than using if-endif around the whole file. + + +MAPPING + +Now let's make the plugin more interesting: We will add a mapping that adds a +correction for the word under the cursor. We could just pick a key sequence +for this mapping, but the user might already use it for something else. To +allow the user to define which keys a mapping in a plugin uses, the <Leader> +item can be used: > + + 22 map <unique> <Leader>a <Plug>TypecorrAdd + +The "<Plug>TypecorrAdd" thing will do the work, more about that further on. + +The user can set the "mapleader" variable to the key sequence that he wants +this mapping to start with. Thus if the user has done: > + + let mapleader = "_" + +the mapping will define "_a". If the user didn't do this, the default value +will be used, which is a backslash. Then a map for "\a" will be defined. + +Note that <unique> is used, this will cause an error message if the mapping +already happened to exist. |:map-<unique>| + +But what if the user wants to define his own key sequence? We can allow that +with this mechanism: > + + 21 if !hasmapto('<Plug>TypecorrAdd') + 22 map <unique> <Leader>a <Plug>TypecorrAdd + 23 endif + +This checks if a mapping to "<Plug>TypecorrAdd" already exists, and only +defines the mapping from "<Leader>a" if it doesn't. The user then has a +chance of putting this in his vimrc file: > + + map ,c <Plug>TypecorrAdd + +Then the mapped key sequence will be ",c" instead of "_a" or "\a". + + +PIECES + +If a script gets longer, you often want to break up the work in pieces. You +can use functions or mappings for this. But you don't want these functions +and mappings to interfere with the ones from other scripts. For example, you +could define a function Add(), but another script could try to define the same +function. To avoid this, we define the function local to the script by +prepending it with "s:". + +We will define a function that adds a new typing correction: > + + 30 function s:Add(from, correct) + 31 let to = input("type the correction for " . a:from . ": ") + 32 exe ":iabbrev " . a:from . " " . to + .. + 36 endfunction + +Now we can call the function s:Add() from within this script. If another +script also defines s:Add(), it will be local to that script and can only +be called from the script it was defined in. There can also be a global Add() +function (without the "s:"), which is again another function. + +<SID> can be used with mappings. It generates a script ID, which identifies +the current script. In our typing correction plugin we use it like this: > + + 24 noremap <unique> <script> <Plug>TypecorrAdd <SID>Add + .. + 28 noremap <SID>Add :call <SID>Add(expand("<cword>"), 1)<CR> + +Thus when a user types "\a", this sequence is invoked: > + + \a -> <Plug>TypecorrAdd -> <SID>Add -> :call <SID>Add() + +If another script would also map <SID>Add, it would get another script ID and +thus define another mapping. + +Note that instead of s:Add() we use <SID>Add() here. That is because the +mapping is typed by the user, thus outside of the script. The <SID> is +translated to the script ID, so that Vim knows in which script to look for +the Add() function. + +This is a bit complicated, but it's required for the plugin to work together +with other plugins. The basic rule is that you use <SID>Add() in mappings and +s:Add() in other places (the script itself, autocommands, user commands). + +We can also add a menu entry to do the same as the mapping: > + + 26 noremenu <script> Plugin.Add\ Correction <SID>Add + +The "Plugin" menu is recommended for adding menu items for plugins. In this +case only one item is used. When adding more items, creating a submenu is +recommended. For example, "Plugin.CVS" could be used for a plugin that offers +CVS operations "Plugin.CVS.checkin", "Plugin.CVS.checkout", etc. + +Note that in line 28 ":noremap" is used to avoid that any other mappings cause +trouble. Someone may have remapped ":call", for example. In line 24 we also +use ":noremap", but we do want "<SID>Add" to be remapped. This is why +"<script>" is used here. This only allows mappings which are local to the +script. |:map-<script>| The same is done in line 26 for ":noremenu". +|:menu-<script>| + + +<SID> AND <Plug> *using-<Plug>* + +Both <SID> and <Plug> are used to avoid that mappings of typed keys interfere +with mappings that are only to be used from other mappings. Note the +difference between using <SID> and <Plug>: + +<Plug> is visible outside of the script. It is used for mappings which the + user might want to map a key sequence to. <Plug> is a special code + that a typed key will never produce. + To make it very unlikely that other plugins use the same sequence of + characters, use this structure: <Plug> scriptname mapname + In our example the scriptname is "Typecorr" and the mapname is "Add". + This results in "<Plug>TypecorrAdd". Only the first character of + scriptname and mapname is uppercase, so that we can see where mapname + starts. + +<SID> is the script ID, a unique identifier for a script. + Internally Vim translates <SID> to "<SNR>123_", where "123" can be any + number. Thus a function "<SID>Add()" will have a name "<SNR>11_Add()" + in one script, and "<SNR>22_Add()" in another. You can see this if + you use the ":function" command to get a list of functions. The + translation of <SID> in mappings is exactly the same, that's how you + can call a script-local function from a mapping. + + +USER COMMAND + +Now let's add a user command to add a correction: > + + 38 if !exists(":Correct") + 39 command -nargs=1 Correct :call s:Add(<q-args>, 0) + 40 endif + +The user command is defined only if no command with the same name already +exists. Otherwise we would get an error here. Overriding the existing user +command with ":command!" is not a good idea, this would probably make the user +wonder why the command he defined himself doesn't work. |:command| + + +SCRIPT VARIABLES + +When a variable starts with "s:" it is a script variable. It can only be used +inside a script. Outside the script it's not visible. This avoids trouble +with using the same variable name in different scripts. The variables will be +kept as long as Vim is running. And the same variables are used when sourcing +the same script again. |s:var| + +The fun is that these variables can also be used in functions, autocommands +and user commands that are defined in the script. In our example we can add +a few lines to count the number of corrections: > + + 19 let s:count = 4 + .. + 30 function s:Add(from, correct) + .. + 34 let s:count = s:count + 1 + 35 echo s:count . " corrections now" + 36 endfunction + +First s:count is initialized to 4 in the script itself. When later the +s:Add() function is called, it increments s:count. It doesn't matter from +where the function was called, since it has been defined in the script, it +will use the local variables from this script. + + +THE RESULT + +Here is the resulting complete example: > + + 1 " Vim global plugin for correcting typing mistakes + 2 " Last Change: 2000 Oct 15 + 3 " Maintainer: Bram Moolenaar <Bram@vim.org> + 4 " License: This file is placed in the public domain. + 5 + 6 if exists("g:loaded_typecorr") + 7 finish + 8 endif + 9 let g:loaded_typecorr = 1 + 10 + 11 let s:save_cpo = &cpo + 12 set cpo&vim + 13 + 14 iabbrev teh the + 15 iabbrev otehr other + 16 iabbrev wnat want + 17 iabbrev synchronisation + 18 \ synchronization + 19 let s:count = 4 + 20 + 21 if !hasmapto('<Plug>TypecorrAdd') + 22 map <unique> <Leader>a <Plug>TypecorrAdd + 23 endif + 24 noremap <unique> <script> <Plug>TypecorrAdd <SID>Add + 25 + 26 noremenu <script> Plugin.Add\ Correction <SID>Add + 27 + 28 noremap <SID>Add :call <SID>Add(expand("<cword>"), 1)<CR> + 29 + 30 function s:Add(from, correct) + 31 let to = input("type the correction for " . a:from . ": ") + 32 exe ":iabbrev " . a:from . " " . to + 33 if a:correct | exe "normal viws\<C-R>\" \b\e" | endif + 34 let s:count = s:count + 1 + 35 echo s:count . " corrections now" + 36 endfunction + 37 + 38 if !exists(":Correct") + 39 command -nargs=1 Correct :call s:Add(<q-args>, 0) + 40 endif + 41 + 42 let &cpo = s:save_cpo + +Line 33 wasn't explained yet. It applies the new correction to the word under +the cursor. The |:normal| command is used to use the new abbreviation. Note +that mappings and abbreviations are expanded here, even though the function +was called from a mapping defined with ":noremap". + +Using "unix" for the 'fileformat' option is recommended. The Vim scripts will +then work everywhere. Scripts with 'fileformat' set to "dos" do not work on +Unix. Also see |:source_crnl|. To be sure it is set right, do this before +writing the file: > + + :set fileformat=unix + + +DOCUMENTATION *write-local-help* + +It's a good idea to also write some documentation for your plugin. Especially +when its behavior can be changed by the user. See |add-local-help| for how +they are installed. + +Here is a simple example for a plugin help file, called "typecorr.txt": > + + 1 *typecorr.txt* Plugin for correcting typing mistakes + 2 + 3 If you make typing mistakes, this plugin will have them corrected + 4 automatically. + 5 + 6 There are currently only a few corrections. Add your own if you like. + 7 + 8 Mappings: + 9 <Leader>a or <Plug>TypecorrAdd + 10 Add a correction for the word under the cursor. + 11 + 12 Commands: + 13 :Correct {word} + 14 Add a correction for {word}. + 15 + 16 *typecorr-settings* + 17 This plugin doesn't have any settings. + +The first line is actually the only one for which the format matters. It will +be extracted from the help file to be put in the "LOCAL ADDITIONS:" section of +help.txt |local-additions|. The first "*" must be in the first column of the +first line. After adding your help file do ":help" and check that the entries +line up nicely. + +You can add more tags inside ** in your help file. But be careful not to use +existing help tags. You would probably use the name of your plugin in most of +them, like "typecorr-settings" in the example. + +Using references to other parts of the help in || is recommended. This makes +it easy for the user to find associated help. + + +FILETYPE DETECTION *plugin-filetype* + +If your filetype is not already detected by Vim, you should create a filetype +detection snippet in a separate file. It is usually in the form of an +autocommand that sets the filetype when the file name matches a pattern. +Example: > + + au BufNewFile,BufRead *.foo set filetype=foofoo + +Write this single-line file as "ftdetect/foofoo.vim" in the first directory +that appears in 'runtimepath'. For Unix that would be +"~/.vim/ftdetect/foofoo.vim". The convention is to use the name of the +filetype for the script name. + +You can make more complicated checks if you like, for example to inspect the +contents of the file to recognize the language. Also see |new-filetype|. + + +SUMMARY *plugin-special* + +Summary of special things to use in a plugin: + +s:name Variables local to the script. + +<SID> Script-ID, used for mappings and functions local to + the script. + +hasmapto() Function to test if the user already defined a mapping + for functionality the script offers. + +<Leader> Value of "mapleader", which the user defines as the + keys that plugin mappings start with. + +:map <unique> Give a warning if a mapping already exists. + +:noremap <script> Use only mappings local to the script, not global + mappings. + +exists(":Cmd") Check if a user command already exists. + +============================================================================== +*41.12* Writing a filetype plugin *write-filetype-plugin* *ftplugin* + +A filetype plugin is like a global plugin, except that it sets options and +defines mappings for the current buffer only. See |add-filetype-plugin| for +how this type of plugin is used. + +First read the section on global plugins above |41.11|. All that is said there +also applies to filetype plugins. There are a few extras, which are explained +here. The essential thing is that a filetype plugin should only have an +effect on the current buffer. + + +DISABLING + +If you are writing a filetype plugin to be used by many people, they need a +chance to disable loading it. Put this at the top of the plugin: > + + " Only do this when not done yet for this buffer + if exists("b:did_ftplugin") + finish + endif + let b:did_ftplugin = 1 + +This also needs to be used to avoid that the same plugin is executed twice for +the same buffer (happens when using an ":edit" command without arguments). + +Now users can disable loading the default plugin completely by making a +filetype plugin with only this line: > + + let b:did_ftplugin = 1 + +This does require that the filetype plugin directory comes before $VIMRUNTIME +in 'runtimepath'! + +If you do want to use the default plugin, but overrule one of the settings, +you can write the different setting in a script: > + + setlocal textwidth=70 + +Now write this in the "after" directory, so that it gets sourced after the +distributed "vim.vim" ftplugin |after-directory|. For Unix this would be +"~/.vim/after/ftplugin/vim.vim". Note that the default plugin will have set +"b:did_ftplugin", but it is ignored here. + + +OPTIONS + +To make sure the filetype plugin only affects the current buffer use the > + + :setlocal + +command to set options. And only set options which are local to a buffer (see +the help for the option to check that). When using |:setlocal| for global +options or options local to a window, the value will change for many buffers, +and that is not what a filetype plugin should do. + +When an option has a value that is a list of flags or items, consider using +"+=" and "-=" to keep the existing value. Be aware that the user may have +changed an option value already. First resetting to the default value and +then changing it often a good idea. Example: > + + :setlocal formatoptions& formatoptions+=ro + + +MAPPINGS + +To make sure mappings will only work in the current buffer use the > + + :map <buffer> + +command. This needs to be combined with the two-step mapping explained above. +An example of how to define functionality in a filetype plugin: > + + if !hasmapto('<Plug>JavaImport') + map <buffer> <unique> <LocalLeader>i <Plug>JavaImport + endif + noremap <buffer> <unique> <Plug>JavaImport oimport ""<Left><Esc> + +|hasmapto()| is used to check if the user has already defined a map to +<Plug>JavaImport. If not, then the filetype plugin defines the default +mapping. This starts with |<LocalLeader>|, which allows the user to select +the key(s) he wants filetype plugin mappings to start with. The default is a +backslash. +"<unique>" is used to give an error message if the mapping already exists or +overlaps with an existing mapping. +|:noremap| is used to avoid that any other mappings that the user has defined +interferes. You might want to use ":noremap <script>" to allow remapping +mappings defined in this script that start with <SID>. + +The user must have a chance to disable the mappings in a filetype plugin, +without disabling everything. Here is an example of how this is done for a +plugin for the mail filetype: > + + " Add mappings, unless the user didn't want this. + if !exists("no_plugin_maps") && !exists("no_mail_maps") + " Quote text by inserting "> " + if !hasmapto('<Plug>MailQuote') + vmap <buffer> <LocalLeader>q <Plug>MailQuote + nmap <buffer> <LocalLeader>q <Plug>MailQuote + endif + vnoremap <buffer> <Plug>MailQuote :s/^/> /<CR> + nnoremap <buffer> <Plug>MailQuote :.,$s/^/> /<CR> + endif + +Two global variables are used: +no_plugin_maps disables mappings for all filetype plugins +no_mail_maps disables mappings for a specific filetype + + +USER COMMANDS + +To add a user command for a specific file type, so that it can only be used in +one buffer, use the "-buffer" argument to |:command|. Example: > + + :command -buffer Make make %:r.s + + +VARIABLES + +A filetype plugin will be sourced for each buffer of the type it's for. Local +script variables |s:var| will be shared between all invocations. Use local +buffer variables |b:var| if you want a variable specifically for one buffer. + + +FUNCTIONS + +When defining a function, this only needs to be done once. But the filetype +plugin will be sourced every time a file with this filetype will be opened. +This construct makes sure the function is only defined once: > + + :if !exists("*s:Func") + : function s:Func(arg) + : ... + : endfunction + :endif +< + +UNDO *undo_ftplugin* + +When the user does ":setfiletype xyz" the effect of the previous filetype +should be undone. Set the b:undo_ftplugin variable to the commands that will +undo the settings in your filetype plugin. Example: > + + let b:undo_ftplugin = "setlocal fo< com< tw< commentstring<" + \ . "| unlet b:match_ignorecase b:match_words b:match_skip" + +Using ":setlocal" with "<" after the option name resets the option to its +global value. That is mostly the best way to reset the option value. + +This does require removing the "C" flag from 'cpoptions' to allow line +continuation, as mentioned above |use-cpo-save|. + + +FILE NAME + +The filetype must be included in the file name |ftplugin-name|. Use one of +these three forms: + + .../ftplugin/stuff.vim + .../ftplugin/stuff_foo.vim + .../ftplugin/stuff/bar.vim + +"stuff" is the filetype, "foo" and "bar" are arbitrary names. + + +SUMMARY *ftplugin-special* + +Summary of special things to use in a filetype plugin: + +<LocalLeader> Value of "maplocalleader", which the user defines as + the keys that filetype plugin mappings start with. + +:map <buffer> Define a mapping local to the buffer. + +:noremap <script> Only remap mappings defined in this script that start + with <SID>. + +:setlocal Set an option for the current buffer only. + +:command -buffer Define a user command local to the buffer. + +exists("*s:Func") Check if a function was already defined. + +Also see |plugin-special|, the special things used for all plugins. + +============================================================================== +*41.13* Writing a compiler plugin *write-compiler-plugin* + +A compiler plugin sets options for use with a specific compiler. The user can +load it with the |:compiler| command. The main use is to set the +'errorformat' and 'makeprg' options. + +Easiest is to have a look at examples. This command will edit all the default +compiler plugins: > + + :next $VIMRUNTIME/compiler/*.vim + +Use |:next| to go to the next plugin file. + +There are two special items about these files. First is a mechanism to allow +a user to overrule or add to the default file. The default files start with: > + + :if exists("current_compiler") + : finish + :endif + :let current_compiler = "mine" + +When you write a compiler file and put it in your personal runtime directory +(e.g., ~/.vim/compiler for Unix), you set the "current_compiler" variable to +make the default file skip the settings. + *:CompilerSet* +The second mechanism is to use ":set" for ":compiler!" and ":setlocal" for +":compiler". Vim defines the ":CompilerSet" user command for this. However, +older Vim versions don't, thus your plugin should define it then. This is an +example: > + + if exists(":CompilerSet") != 2 + command -nargs=* CompilerSet setlocal <args> + endif + CompilerSet errorformat& " use the default 'errorformat' + CompilerSet makeprg=nmake + +When you write a compiler plugin for the Vim distribution or for a system-wide +runtime directory, use the mechanism mentioned above. When +"current_compiler" was already set by a user plugin nothing will be done. + +When you write a compiler plugin to overrule settings from a default plugin, +don't check "current_compiler". This plugin is supposed to be loaded +last, thus it should be in a directory at the end of 'runtimepath'. For Unix +that could be ~/.vim/after/compiler. + +============================================================================== +*41.14* Writing a plugin that loads quickly *write-plugin-quickload* + +A plugin may grow and become quite long. The startup delay may become +noticeable, while you hardly ever use the plugin. Then it's time for a +quickload plugin. + +The basic idea is that the plugin is loaded twice. The first time user +commands and mappings are defined that offer the functionality. The second +time the functions that implement the functionality are defined. + +It may sound surprising that quickload means loading a script twice. What we +mean is that it loads quickly the first time, postponing the bulk of the +script to the second time, which only happens when you actually use it. When +you always use the functionality it actually gets slower! + +Note that since Vim 7 there is an alternative: use the |autoload| +functionality |41.15|. + +The following example shows how it's done: > + + " Vim global plugin for demonstrating quick loading + " Last Change: 2005 Feb 25 + " Maintainer: Bram Moolenaar <Bram@vim.org> + " License: This file is placed in the public domain. + + if !exists("s:did_load") + command -nargs=* BNRead call BufNetRead(<f-args>) + map <F19> :call BufNetWrite('something')<CR> + + let s:did_load = 1 + exe 'au FuncUndefined BufNet* source ' . expand('<sfile>') + finish + endif + + function BufNetRead(...) + echo 'BufNetRead(' . string(a:000) . ')' + " read functionality here + endfunction + + function BufNetWrite(...) + echo 'BufNetWrite(' . string(a:000) . ')' + " write functionality here + endfunction + +When the script is first loaded "s:did_load" is not set. The commands between +the "if" and "endif" will be executed. This ends in a |:finish| command, thus +the rest of the script is not executed. + +The second time the script is loaded "s:did_load" exists and the commands +after the "endif" are executed. This defines the (possible long) +BufNetRead() and BufNetWrite() functions. + +If you drop this script in your plugin directory Vim will execute it on +startup. This is the sequence of events that happens: + +1. The "BNRead" command is defined and the <F19> key is mapped when the script + is sourced at startup. A |FuncUndefined| autocommand is defined. The + ":finish" command causes the script to terminate early. + +2. The user types the BNRead command or presses the <F19> key. The + BufNetRead() or BufNetWrite() function will be called. + +3. Vim can't find the function and triggers the |FuncUndefined| autocommand + event. Since the pattern "BufNet*" matches the invoked function, the + command "source fname" will be executed. "fname" will be equal to the name + of the script, no matter where it is located, because it comes from + expanding "<sfile>" (see |expand()|). + +4. The script is sourced again, the "s:did_load" variable exists and the + functions are defined. + +Notice that the functions that are loaded afterwards match the pattern in the +|FuncUndefined| autocommand. You must make sure that no other plugin defines +functions that match this pattern. + +============================================================================== +*41.15* Writing library scripts *write-library-script* + +Some functionality will be required in several places. When this becomes more +than a few lines you will want to put it in one script and use it from many +scripts. We will call that one script a library script. + +Manually loading a library script is possible, so long as you avoid loading it +when it's already done. You can do this with the |exists()| function. +Example: > + + if !exists('*MyLibFunction') + runtime library/mylibscript.vim + endif + call MyLibFunction(arg) + +Here you need to know that MyLibFunction() is defined in a script +"library/mylibscript.vim" in one of the directories in 'runtimepath'. + +To make this a bit simpler Vim offers the autoload mechanism. Then the +example looks like this: > + + call mylib#myfunction(arg) + +That's a lot simpler, isn't it? Vim will recognize the function name and when +it's not defined search for the script "autoload/mylib.vim" in 'runtimepath'. +That script must define the "mylib#myfunction()" function. + +You can put many other functions in the mylib.vim script, you are free to +organize your functions in library scripts. But you must use function names +where the part before the '#' matches the script name. Otherwise Vim would +not know what script to load. + +If you get really enthusiastic and write lots of library scripts, you may +want to use subdirectories. Example: > + + call netlib#ftp#read('somefile') + +For Unix the library script used for this could be: + + ~/.vim/autoload/netlib/ftp.vim + +Where the function is defined like this: > + + function netlib#ftp#read(fname) + " Read the file fname through ftp + endfunction + +Notice that the name the function is defined with is exactly the same as the +name used for calling the function. And the part before the last '#' +exactly matches the subdirectory and script name. + +You can use the same mechanism for variables: > + + let weekdays = dutch#weekdays + +This will load the script "autoload/dutch.vim", which should contain something +like: > + + let dutch#weekdays = ['zondag', 'maandag', 'dinsdag', 'woensdag', + \ 'donderdag', 'vrijdag', 'zaterdag'] + +Further reading: |autoload|. + +============================================================================== +*41.16* Distributing Vim scripts *distribute-script* + +Vim users will look for scripts on the Vim website: http://www.vim.org. +If you made something that is useful for others, share it! + +Vim scripts can be used on any system. There might not be a tar or gzip +command. If you want to pack files together and/or compress them the "zip" +utility is recommended. + +For utmost portability use Vim itself to pack scripts together. This can be +done with the Vimball utility. See |vimball|. + +It's good if you add a line to allow automatic updating. See |glvs-plugins|. + +============================================================================== + +Next chapter: |usr_42.txt| Add new menus + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_42.txt b/share/vim/vim73/doc/usr_42.txt new file mode 100644 index 0000000000..82007a0338 --- /dev/null +++ b/share/vim/vim73/doc/usr_42.txt @@ -0,0 +1,365 @@ +*usr_42.txt* For Vim version 7.3. Last change: 2008 May 05 + + VIM USER MANUAL - by Bram Moolenaar + + Add new menus + + +By now you know that Vim is very flexible. This includes the menus used in +the GUI. You can define your own menu entries to make certain commands easily +accessible. This is for mouse-happy users only. + +|42.1| Introduction +|42.2| Menu commands +|42.3| Various +|42.4| Toolbar and popup menus + + Next chapter: |usr_43.txt| Using filetypes + Previous chapter: |usr_41.txt| Write a Vim script +Table of contents: |usr_toc.txt| + +============================================================================== +*42.1* Introduction + +The menus that Vim uses are defined in the file "$VIMRUNTIME/menu.vim". If +you want to write your own menus, you might first want to look through that +file. + To define a menu item, use the ":menu" command. The basic form of this +command is as follows: > + + :menu {menu-item} {keys} + +The {menu-item} describes where on the menu to put the item. A typical +{menu-item} is "File.Save", which represents the item "Save" under the +"File" menu. A dot is used to separate the names. Example: > + + :menu File.Save :update<CR> + +The ":update" command writes the file when it was modified. + You can add another level: "Edit.Settings.Shiftwidth" defines a submenu +"Settings" under the "Edit" menu, with an item "Shiftwidth". You could use +even deeper levels. Don't use this too much, you need to move the mouse quite +a bit to use such an item. + The ":menu" command is very similar to the ":map" command: the left side +specifies how the item is triggered and the right hand side defines the +characters that are executed. {keys} are characters, they are used just like +you would have typed them. Thus in Insert mode, when {keys} is plain text, +that text is inserted. + + +ACCELERATORS + +The ampersand character (&) is used to indicate an accelerator. For instance, +you can use Alt-F to select "File" and S to select "Save". (The 'winaltkeys' +option may disable this though!). Therefore, the {menu-item} looks like +"&File.&Save". The accelerator characters will be underlined in the menu. + You must take care that each key is used only once in each menu. Otherwise +you will not know which of the two will actually be used. Vim doesn't warn +you for this. + + +PRIORITIES + +The actual definition of the File.Save menu item is as follows: > + + :menu 10.340 &File.&Save<Tab>:w :confirm w<CR> + +The number 10.340 is called the priority number. It is used by the editor to +decide where it places the menu item. The first number (10) indicates the +position on the menu bar. Lower numbered menus are positioned to the left, +higher numbers to the right. + These are the priorities used for the standard menus: + + 10 20 40 50 60 70 9999 + + +------------------------------------------------------------+ + | File Edit Tools Syntax Buffers Window Help | + +------------------------------------------------------------+ + +Notice that the Help menu is given a very high number, to make it appear on +the far right. + The second number (340) determines the location of the item within the +pull-down menu. Lower numbers go on top, higher number on the bottom. These +are the priorities in the File menu: + + +-----------------+ + 10.310 |Open... | + 10.320 |Split-Open... | + 10.325 |New | + 10.330 |Close | + 10.335 |---------------- | + 10.340 |Save | + 10.350 |Save As... | + 10.400 |---------------- | + 10.410 |Split Diff with | + 10.420 |Split Patched By | + 10.500 |---------------- | + 10.510 |Print | + 10.600 |---------------- | + 10.610 |Save-Exit | + 10.620 |Exit | + +-----------------+ + +Notice that there is room in between the numbers. This is where you can +insert your own items, if you really want to (it's often better to leave the +standard menus alone and add a new menu for your own items). + When you create a submenu, you can add another ".number" to the priority. +Thus each name in {menu-item} has its priority number. + + +SPECIAL CHARACTERS + +The {menu-item} in this example is "&File.&Save<Tab>:w". This brings up an +important point: {menu-item} must be one word. If you want to put a dot, +space or tabs in the name, you either use the <> notation (<Space> and <Tab>, +for instance) or use the backslash (\) escape. > + + :menu 10.305 &File.&Do\ It\.\.\. :exit<CR> + +In this example, the name of the menu item "Do It..." contains a space and the +command is ":exit<CR>". + +The <Tab> character in a menu name is used to separate the part that defines +the menu name from the part that gives a hint to the user. The part after the +<Tab> is displayed right aligned in the menu. In the File.Save menu the name +used is "&File.&Save<Tab>:w". Thus the menu name is "File.Save" and the hint +is ":w". + + +SEPARATORS + +The separator lines, used to group related menu items together, can be defined +by using a name that starts and ends in a '-'. For example "-sep-". When +using several separators the names must be different. Otherwise the names +don't matter. + The command from a separator will never be executed, but you have to define +one anyway. A single colon will do. Example: > + + :amenu 20.510 Edit.-sep3- : + +============================================================================== +*42.2* Menu commands + +You can define menu items that exist for only certain modes. This works just +like the variations on the ":map" command: + + :menu Normal, Visual and Operator-pending mode + :nmenu Normal mode + :vmenu Visual mode + :omenu Operator-pending mode + :menu! Insert and Command-line mode + :imenu Insert mode + :cmenu Command-line mode + :amenu All modes + +To avoid that the commands of a menu item are being mapped, use the command +":noremenu", ":nnoremenu", ":anoremenu", etc. + + +USING :AMENU + +The ":amenu" command is a bit different. It assumes that the {keys} you +give are to be executed in Normal mode. When Vim is in Visual or Insert mode +when the menu is used, Vim first has to go back to Normal mode. ":amenu" +inserts a CTRL-C or CTRL-O for you. For example, if you use this command: +> + :amenu 90.100 Mine.Find\ Word * + +Then the resulting menu commands will be: + + Normal mode: * + Visual mode: CTRL-C * + Operator-pending mode: CTRL-C * + Insert mode: CTRL-O * + Command-line mode: CTRL-C * + +When in Command-line mode the CTRL-C will abandon the command typed so far. +In Visual and Operator-pending mode CTRL-C will stop the mode. The CTRL-O in +Insert mode will execute the command and then return to Insert mode. + CTRL-O only works for one command. If you need to use two or more +commands, put them in a function and call that function. Example: > + + :amenu Mine.Next\ File :call <SID>NextFile()<CR> + :function <SID>NextFile() + : next + : 1/^Code + :endfunction + +This menu entry goes to the next file in the argument list with ":next". Then +it searches for the line that starts with "Code". + The <SID> before the function name is the script ID. This makes the +function local to the current Vim script file. This avoids problems when a +function with the same name is defined in another script file. See |<SID>|. + + +SILENT MENUS + +The menu executes the {keys} as if you typed them. For a ":" command this +means you will see the command being echoed on the command line. If it's a +long command, the hit-Enter prompt will appear. That can be very annoying! + To avoid this, make the menu silent. This is done with the <silent> +argument. For example, take the call to NextFile() in the previous example. +When you use this menu, you will see this on the command line: + + :call <SNR>34_NextFile() ~ + +To avoid this text on the command line, insert "<silent>" as the first +argument: > + + :amenu <silent> Mine.Next\ File :call <SID>NextFile()<CR> + +Don't use "<silent>" too often. It is not needed for short commands. If you +make a menu for someone else, being able the see the executed command will +give him a hint about what he could have typed, instead of using the mouse. + + +LISTING MENUS + +When a menu command is used without a {keys} part, it lists the already +defined menus. You can specify a {menu-item}, or part of it, to list specific +menus. Example: > + + :amenu + +This lists all menus. That's a long list! Better specify the name of a menu +to get a shorter list: > + + :amenu Edit + +This lists only the "Edit" menu items for all modes. To list only one +specific menu item for Insert mode: > + + :imenu Edit.Undo + +Take care that you type exactly the right name. Case matters here. But the +'&' for accelerators can be omitted. The <Tab> and what comes after it can be +left out as well. + + +DELETING MENUS + +To delete a menu, the same command is used as for listing, but with "menu" +changed to "unmenu". Thus ":menu" becomes, ":unmenu", ":nmenu" becomes +":nunmenu", etc. To delete the "Tools.Make" item for Insert mode: > + + :iunmenu Tools.Make + +You can delete a whole menu, with all its items, by using the menu name. +Example: > + + :aunmenu Syntax + +This deletes the Syntax menu and all the items in it. + +============================================================================== +*42.3* Various + +You can change the appearance of the menus with flags in 'guioptions'. In the +default value they are all included, except "M". You can remove a flag with a +command like: > + + :set guioptions-=m +< + m When removed the menubar is not displayed. + + M When added the default menus are not loaded. + + g When removed the inactive menu items are not made grey + but are completely removed. (Does not work on all + systems.) + + t When removed the tearoff feature is not enabled. + +The dotted line at the top of a menu is not a separator line. When you select +this item, the menu is "teared-off": It is displayed in a separate window. +This is called a tearoff menu. This is useful when you use the same menu +often. + +For translating menu items, see |:menutrans|. + +Since the mouse has to be used to select a menu item, it is a good idea to use +the ":browse" command for selecting a file. And ":confirm" to get a dialog +instead of an error message, e.g., when the current buffer contains changes. +These two can be combined: > + + :amenu File.Open :browse confirm edit<CR> + +The ":browse" makes a file browser appear to select the file to edit. The +":confirm" will pop up a dialog when the current buffer has changes. You can +then select to save the changes, throw them away or cancel the command. + For more complicated items, the confirm() and inputdialog() functions can +be used. The default menus contain a few examples. + +============================================================================== +*42.4* Toolbar and popup menus + +There are two special menus: ToolBar and PopUp. Items that start with these +names do not appear in the normal menu bar. + + +TOOLBAR + +The toolbar appears only when the "T" flag is included in the 'guioptions' +option. + The toolbar uses icons rather than text to represent the command. For +example, the {menu-item} named "ToolBar.New" causes the "New" icon to appear +on the toolbar. + The Vim editor has 28 built-in icons. You can find a table here: +|builtin-tools|. Most of them are used in the default toolbar. You can +redefine what these items do (after the default menus are setup). + You can add another bitmap for a toolbar item. Or define a new toolbar +item with a bitmap. For example, define a new toolbar item with: > + + :tmenu ToolBar.Compile Compile the current file + :amenu ToolBar.Compile :!cc % -o %:r<CR> + +Now you need to create the icon. For MS-Windows it must be in bitmap format, +with the name "Compile.bmp". For Unix XPM format is used, the file name is +"Compile.xpm". The size must be 18 by 18 pixels. On MS-Windows other sizes +can be used as well, but it will look ugly. + Put the bitmap in the directory "bitmaps" in one of the directories from +'runtimepath'. E.g., for Unix "~/.vim/bitmaps/Compile.xpm". + +You can define tooltips for the items in the toolbar. A tooltip is a short +text that explains what a toolbar item will do. For example "Open file". It +appears when the mouse pointer is on the item, without moving for a moment. +This is very useful if the meaning of the picture isn't that obvious. +Example: > + + :tmenu ToolBar.Make Run make in the current directory +< + Note: + Pay attention to the case used. "Toolbar" and "toolbar" are different + from "ToolBar"! + +To remove a tooltip, use the |:tunmenu| command. + +The 'toolbar' option can be used to display text instead of a bitmap, or both +text and a bitmap. Most people use just the bitmap, since the text takes +quite a bit of space. + + +POPUP MENU + +The popup menu pops up where the mouse pointer is. On MS-Windows you activate +it by clicking the right mouse button. Then you can select an item with the +left mouse button. On Unix the popup menu is used by pressing and holding the +right mouse button. + The popup menu only appears when the 'mousemodel' has been set to "popup" +or "popup_setpos". The difference between the two is that "popup_setpos" +moves the cursor to the mouse pointer position. When clicking inside a +selection, the selection will be used unmodified. When there is a selection +but you click outside of it, the selection is removed. + There is a separate popup menu for each mode. Thus there are never grey +items like in the normal menus. + +What is the meaning of life, the universe and everything? *42* +Douglas Adams, the only person who knew what this question really was about is +now dead, unfortunately. So now you might wonder what the meaning of death +is... + +============================================================================== + +Next chapter: |usr_43.txt| Using filetypes + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_43.txt b/share/vim/vim73/doc/usr_43.txt new file mode 100644 index 0000000000..2d9fbf71aa --- /dev/null +++ b/share/vim/vim73/doc/usr_43.txt @@ -0,0 +1,173 @@ +*usr_43.txt* For Vim version 7.3. Last change: 2008 Dec 28 + + VIM USER MANUAL - by Bram Moolenaar + + Using filetypes + + +When you are editing a file of a certain type, for example a C program or a +shell script, you often use the same option settings and mappings. You +quickly get tired of manually setting these each time. This chapter explains +how to do it automatically. + +|43.1| Plugins for a filetype +|43.2| Adding a filetype + + Next chapter: |usr_44.txt| Your own syntax highlighted + Previous chapter: |usr_42.txt| Add new menus +Table of contents: |usr_toc.txt| + +============================================================================== +*43.1* Plugins for a filetype *filetype-plugin* + +How to start using filetype plugins has already been discussed here: +|add-filetype-plugin|. But you probably are not satisfied with the default +settings, because they have been kept minimal. Suppose that for C files you +want to set the 'softtabstop' option to 4 and define a mapping to insert a +three-line comment. You do this with only two steps: + + *your-runtime-dir* +1. Create your own runtime directory. On Unix this usually is "~/.vim". In + this directory create the "ftplugin" directory: > + + mkdir ~/.vim + mkdir ~/.vim/ftplugin +< + When you are not on Unix, check the value of the 'runtimepath' option to + see where Vim will look for the "ftplugin" directory: > + + set runtimepath + +< You would normally use the first directory name (before the first comma). + You might want to prepend a directory name to the 'runtimepath' option in + your |vimrc| file if you don't like the default value. + +2. Create the file "~/.vim/ftplugin/c.vim", with the contents: > + + setlocal softtabstop=4 + noremap <buffer> <LocalLeader>c o/**************<CR><CR>/<Esc> + +Try editing a C file. You should notice that the 'softtabstop' option is set +to 4. But when you edit another file it's reset to the default zero. That is +because the ":setlocal" command was used. This sets the 'softtabstop' option +only locally to the buffer. As soon as you edit another buffer, it will be +set to the value set for that buffer. For a new buffer it will get the +default value or the value from the last ":set" command. + +Likewise, the mapping for "\c" will disappear when editing another buffer. +The ":map <buffer>" command creates a mapping that is local to the current +buffer. This works with any mapping command: ":map!", ":vmap", etc. The +|<LocalLeader>| in the mapping is replaced with the value of the +"maplocalleader" variable. + +You can find examples for filetype plugins in this directory: > + + $VIMRUNTIME/ftplugin/ + +More details about writing a filetype plugin can be found here: +|write-plugin|. + +============================================================================== +*43.2* Adding a filetype + +If you are using a type of file that is not recognized by Vim, this is how to +get it recognized. You need a runtime directory of your own. See +|your-runtime-dir| above. + +Create a file "filetype.vim" which contains an autocommand for your filetype. +(Autocommands were explained in section |40.3|.) Example: > + + augroup filetypedetect + au BufNewFile,BufRead *.xyz setf xyz + augroup END + +This will recognize all files that end in ".xyz" as the "xyz" filetype. The +":augroup" commands put this autocommand in the "filetypedetect" group. This +allows removing all autocommands for filetype detection when doing ":filetype +off". The "setf" command will set the 'filetype' option to its argument, +unless it was set already. This will make sure that 'filetype' isn't set +twice. + +You can use many different patterns to match the name of your file. Directory +names can also be included. See |autocmd-patterns|. For example, the files +under "/usr/share/scripts/" are all "ruby" files, but don't have the expected +file name extension. Adding this to the example above: > + + augroup filetypedetect + au BufNewFile,BufRead *.xyz setf xyz + au BufNewFile,BufRead /usr/share/scripts/* setf ruby + augroup END + +However, if you now edit a file /usr/share/scripts/README.txt, this is not a +ruby file. The danger of a pattern ending in "*" is that it quickly matches +too many files. To avoid trouble with this, put the filetype.vim file in +another directory, one that is at the end of 'runtimepath'. For Unix for +example, you could use "~/.vim/after/filetype.vim". + You now put the detection of text files in ~/.vim/filetype.vim: > + + augroup filetypedetect + au BufNewFile,BufRead *.txt setf text + augroup END + +That file is found in 'runtimepath' first. Then use this in +~/.vim/after/filetype.vim, which is found last: > + + augroup filetypedetect + au BufNewFile,BufRead /usr/share/scripts/* setf ruby + augroup END + +What will happen now is that Vim searches for "filetype.vim" files in each +directory in 'runtimepath'. First ~/.vim/filetype.vim is found. The +autocommand to catch *.txt files is defined there. Then Vim finds the +filetype.vim file in $VIMRUNTIME, which is halfway 'runtimepath'. Finally +~/.vim/after/filetype.vim is found and the autocommand for detecting ruby +files in /usr/share/scripts is added. + When you now edit /usr/share/scripts/README.txt, the autocommands are +checked in the order in which they were defined. The *.txt pattern matches, +thus "setf text" is executed to set the filetype to "text". The pattern for +ruby matches too, and the "setf ruby" is executed. But since 'filetype' was +already set to "text", nothing happens here. + When you edit the file /usr/share/scripts/foobar the same autocommands are +checked. Only the one for ruby matches and "setf ruby" sets 'filetype' to +ruby. + + +RECOGNIZING BY CONTENTS + +If your file cannot be recognized by its file name, you might be able to +recognize it by its contents. For example, many script files start with a +line like: + + #!/bin/xyz ~ + +To recognize this script create a file "scripts.vim" in your runtime directory +(same place where filetype.vim goes). It might look like this: > + + if did_filetype() + finish + endif + if getline(1) =~ '^#!.*[/\\]xyz\>' + setf xyz + endif + +The first check with did_filetype() is to avoid that you will check the +contents of files for which the filetype was already detected by the file +name. That avoids wasting time on checking the file when the "setf" command +won't do anything. + The scripts.vim file is sourced by an autocommand in the default +filetype.vim file. Therefore, the order of checks is: + + 1. filetype.vim files before $VIMRUNTIME in 'runtimepath' + 2. first part of $VIMRUNTIME/filetype.vim + 3. all scripts.vim files in 'runtimepath' + 4. remainder of $VIMRUNTIME/filetype.vim + 5. filetype.vim files after $VIMRUNTIME in 'runtimepath' + +If this is not sufficient for you, add an autocommand that matches all files +and sources a script or executes a function to check the contents of the file. + +============================================================================== + +Next chapter: |usr_44.txt| Your own syntax highlighted + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_44.txt b/share/vim/vim73/doc/usr_44.txt new file mode 100644 index 0000000000..266708f699 --- /dev/null +++ b/share/vim/vim73/doc/usr_44.txt @@ -0,0 +1,719 @@ +*usr_44.txt* For Vim version 7.3. Last change: 2008 Dec 28 + + VIM USER MANUAL - by Bram Moolenaar + + Your own syntax highlighted + + +Vim comes with highlighting for a couple of hundred different file types. If +the file you are editing isn't included, read this chapter to find out how to +get this type of file highlighted. Also see |:syn-define| in the reference +manual. + +|44.1| Basic syntax commands +|44.2| Keywords +|44.3| Matches +|44.4| Regions +|44.5| Nested items +|44.6| Following groups +|44.7| Other arguments +|44.8| Clusters +|44.9| Including another syntax file +|44.10| Synchronizing +|44.11| Installing a syntax file +|44.12| Portable syntax file layout + + Next chapter: |usr_45.txt| Select your language + Previous chapter: |usr_43.txt| Using filetypes +Table of contents: |usr_toc.txt| + +============================================================================== +*44.1* Basic syntax commands + +Using an existing syntax file to start with will save you a lot of time. Try +finding a syntax file in $VIMRUNTIME/syntax for a language that is similar. +These files will also show you the normal layout of a syntax file. To +understand it, you need to read the following. + +Let's start with the basic arguments. Before we start defining any new +syntax, we need to clear out any old definitions: > + + :syntax clear + +This isn't required in the final syntax file, but very useful when +experimenting. + +There are more simplifications in this chapter. If you are writing a syntax +file to be used by others, read all the way through the end to find out the +details. + + +LISTING DEFINED ITEMS + +To check which syntax items are currently defined, use this command: > + + :syntax + +You can use this to check which items have actually been defined. Quite +useful when you are experimenting with a new syntax file. It also shows the +colors used for each item, which helps to find out what is what. + To list the items in a specific syntax group use: > + + :syntax list {group-name} + +This also can be used to list clusters (explained in |44.8|). Just include +the @ in the name. + + +MATCHING CASE + +Some languages are not case sensitive, such as Pascal. Others, such as C, are +case sensitive. You need to tell which type you have with the following +commands: > + :syntax case match + :syntax case ignore + +The "match" argument means that Vim will match the case of syntax elements. +Therefore, "int" differs from "Int" and "INT". If the "ignore" argument is +used, the following are equivalent: "Procedure", "PROCEDURE" and "procedure". + The ":syntax case" commands can appear anywhere in a syntax file and affect +the syntax definitions that follow. In most cases, you have only one ":syntax +case" command in your syntax file; if you work with an unusual language that +contains both case-sensitive and non-case-sensitive elements, however, you can +scatter the ":syntax case" command throughout the file. + +============================================================================== +*44.2* Keywords + +The most basic syntax elements are keywords. To define a keyword, use the +following form: > + + :syntax keyword {group} {keyword} ... + +The {group} is the name of a syntax group. With the ":highlight" command you +can assign colors to a {group}. The {keyword} argument is an actual keyword. +Here are a few examples: > + + :syntax keyword xType int long char + :syntax keyword xStatement if then else endif + +This example uses the group names "xType" and "xStatement". By convention, +each group name is prefixed by the filetype for the language being defined. +This example defines syntax for the x language (eXample language without an +interesting name). In a syntax file for "csh" scripts the name "cshType" +would be used. Thus the prefix is equal to the value of 'filetype'. + These commands cause the words "int", "long" and "char" to be highlighted +one way and the words "if", "then", "else" and "endif" to be highlighted +another way. Now you need to connect the x group names to standard Vim +names. You do this with the following commands: > + + :highlight link xType Type + :highlight link xStatement Statement + +This tells Vim to highlight "xType" like "Type" and "xStatement" like +"Statement". See |group-name| for the standard names. + + +UNUSUAL KEYWORDS + +The characters used in a keyword must be in the 'iskeyword' option. If you +use another character, the word will never match. Vim doesn't give a warning +message for this. + The x language uses the '-' character in keywords. This is how it's done: +> + :setlocal iskeyword+=- + :syntax keyword xStatement when-not + +The ":setlocal" command is used to change 'iskeyword' only for the current +buffer. Still it does change the behavior of commands like "w" and "*". If +that is not wanted, don't define a keyword but use a match (explained in the +next section). + +The x language allows for abbreviations. For example, "next" can be +abbreviated to "n", "ne" or "nex". You can define them by using this command: +> + :syntax keyword xStatement n[ext] + +This doesn't match "nextone", keywords always match whole words only. + +============================================================================== +*44.3* Matches + +Consider defining something a bit more complex. You want to match ordinary +identifiers. To do this, you define a match syntax item. This one matches +any word consisting of only lowercase letters: > + + :syntax match xIdentifier /\<\l\+\>/ +< + Note: + Keywords overrule any other syntax item. Thus the keywords "if", + "then", etc., will be keywords, as defined with the ":syntax keyword" + commands above, even though they also match the pattern for + xIdentifier. + +The part at the end is a pattern, like it's used for searching. The // is +used to surround the pattern (like how it's done in a ":substitute" command). +You can use any other character, like a plus or a quote. + +Now define a match for a comment. In the x language it is anything from # to +the end of a line: > + + :syntax match xComment /#.*/ + +Since you can use any search pattern, you can highlight very complex things +with a match item. See |pattern| for help on search patterns. + +============================================================================== +*44.4* Regions + +In the example x language, strings are enclosed in double quotation marks ("). +To highlight strings you define a region. You need a region start (double +quote) and a region end (double quote). The definition is as follows: > + + :syntax region xString start=/"/ end=/"/ + +The "start" and "end" directives define the patterns used to find the start +and end of the region. But what about strings that look like this? + + "A string with a double quote (\") in it" ~ + +This creates a problem: The double quotation marks in the middle of the string +will end the region. You need to tell Vim to skip over any escaped double +quotes in the string. Do this with the skip keyword: > + + :syntax region xString start=/"/ skip=/\\"/ end=/"/ + +The double backslash matches a single backslash, since the backslash is a +special character in search patterns. + +When to use a region instead of a match? The main difference is that a match +item is a single pattern, which must match as a whole. A region starts as +soon as the "start" pattern matches. Whether the "end" pattern is found or +not doesn't matter. Thus when the item depends on the "end" pattern to match, +you cannot use a region. Otherwise, regions are often simpler to define. And +it is easier to use nested items, as is explained in the next section. + +============================================================================== +*44.5* Nested items + +Take a look at this comment: + + %Get input TODO: Skip white space ~ + +You want to highlight TODO in big yellow letters, even though it is in a +comment that is highlighted blue. To let Vim know about this, you define the +following syntax groups: > + + :syntax keyword xTodo TODO contained + :syntax match xComment /%.*/ contains=xTodo + +In the first line, the "contained" argument tells Vim that this keyword can +exist only inside another syntax item. The next line has "contains=xTodo". +This indicates that the xTodo syntax element is inside it. The result is that +the comment line as a whole is matched with "xComment" and made blue. The +word TODO inside it is matched by xTodo and highlighted yellow (highlighting +for xTodo was setup for this). + + +RECURSIVE NESTING + +The x language defines code blocks in curly braces. And a code block may +contain other code blocks. This can be defined this way: > + + :syntax region xBlock start=/{/ end=/}/ contains=xBlock + +Suppose you have this text: + + while i < b { ~ + if a { ~ + b = c; ~ + } ~ + } ~ + +First a xBlock starts at the { in the first line. In the second line another +{ is found. Since we are inside a xBlock item, and it contains itself, a +nested xBlock item will start here. Thus the "b = c" line is inside the +second level xBlock region. Then a } is found in the next line, which matches +with the end pattern of the region. This ends the nested xBlock. Because the +} is included in the nested region, it is hidden from the first xBlock region. +Then at the last } the first xBlock region ends. + + +KEEPING THE END + +Consider the following two syntax items: > + + :syntax region xComment start=/%/ end=/$/ contained + :syntax region xPreProc start=/#/ end=/$/ contains=xComment + +You define a comment as anything from % to the end of the line. A +preprocessor directive is anything from # to the end of the line. Because you +can have a comment on a preprocessor line, the preprocessor definition +includes a "contains=xComment" argument. Now look what happens with this +text: + + #define X = Y % Comment text ~ + int foo = 1; ~ + +What you see is that the second line is also highlighted as xPreProc. The +preprocessor directive should end at the end of the line. That is why +you have used "end=/$/". So what is going wrong? + The problem is the contained comment. The comment starts with % and ends +at the end of the line. After the comment ends, the preprocessor syntax +continues. This is after the end of the line has been seen, so the next +line is included as well. + To avoid this problem and to avoid a contained syntax item eating a needed +end of line, use the "keepend" argument. This takes care of +the double end-of-line matching: > + + :syntax region xComment start=/%/ end=/$/ contained + :syntax region xPreProc start=/#/ end=/$/ contains=xComment keepend + + +CONTAINING MANY ITEMS + +You can use the contains argument to specify that everything can be contained. +For example: > + + :syntax region xList start=/\[/ end=/\]/ contains=ALL + +All syntax items will be contained in this one. It also contains itself, but +not at the same position (that would cause an endless loop). + You can specify that some groups are not contained. Thus contain all +groups but the ones that are listed: +> + :syntax region xList start=/\[/ end=/\]/ contains=ALLBUT,xString + +With the "TOP" item you can include all items that don't have a "contained" +argument. "CONTAINED" is used to only include items with a "contained" +argument. See |:syn-contains| for the details. + +============================================================================== +*44.6* Following groups + +The x language has statements in this form: + + if (condition) then ~ + +You want to highlight the three items differently. But "(condition)" and +"then" might also appear in other places, where they get different +highlighting. This is how you can do this: > + + :syntax match xIf /if/ nextgroup=xIfCondition skipwhite + :syntax match xIfCondition /([^)]*)/ contained nextgroup=xThen skipwhite + :syntax match xThen /then/ contained + +The "nextgroup" argument specifies which item can come next. This is not +required. If none of the items that are specified are found, nothing happens. +For example, in this text: + + if not (condition) then ~ + +The "if" is matched by xIf. "not" doesn't match the specified nextgroup +xIfCondition, thus only the "if" is highlighted. + +The "skipwhite" argument tells Vim that white space (spaces and tabs) may +appear in between the items. Similar arguments are "skipnl", which allows a +line break in between the items, and "skipempty", which allows empty lines. +Notice that "skipnl" doesn't skip an empty line, something must match after +the line break. + +============================================================================== +*44.7* Other arguments + +MATCHGROUP + +When you define a region, the entire region is highlighted according to the +group name specified. To highlight the text enclosed in parentheses () with +the group xInside, for example, use the following command: > + + :syntax region xInside start=/(/ end=/)/ + +Suppose, that you want to highlight the parentheses differently. You can do +this with a lot of convoluted region statements, or you can use the +"matchgroup" argument. This tells Vim to highlight the start and end of a +region with a different highlight group (in this case, the xParen group): > + + :syntax region xInside matchgroup=xParen start=/(/ end=/)/ + +The "matchgroup" argument applies to the start or end match that comes after +it. In the previous example both start and end are highlighted with xParen. +To highlight the end with xParenEnd: > + + :syntax region xInside matchgroup=xParen start=/(/ + \ matchgroup=xParenEnd end=/)/ + +A side effect of using "matchgroup" is that contained items will not match in +the start or end of the region. The example for "transparent" uses this. + + +TRANSPARENT + +In a C language file you would like to highlight the () text after a "while" +differently from the () text after a "for". In both of these there can be +nested () items, which should be highlighted in the same way. You must make +sure the () highlighting stops at the matching ). This is one way to do this: +> + :syntax region cWhile matchgroup=cWhile start=/while\s*(/ end=/)/ + \ contains=cCondNest + :syntax region cFor matchgroup=cFor start=/for\s*(/ end=/)/ + \ contains=cCondNest + :syntax region cCondNest start=/(/ end=/)/ contained transparent + +Now you can give cWhile and cFor different highlighting. The cCondNest item +can appear in either of them, but take over the highlighting of the item it is +contained in. The "transparent" argument causes this. + Notice that the "matchgroup" argument has the same group as the item +itself. Why define it then? Well, the side effect of using a matchgroup is +that contained items are not found in the match with the start item then. +This avoids that the cCondNest group matches the ( just after the "while" or +"for". If this would happen, it would span the whole text until the matching +) and the region would continue after it. Now cCondNest only matches after +the match with the start pattern, thus after the first (. + + +OFFSETS + +Suppose you want to define a region for the text between ( and ) after an +"if". But you don't want to include the "if" or the ( and ). You can do this +by specifying offsets for the patterns. Example: > + + :syntax region xCond start=/if\s*(/ms=e+1 end=/)/me=s-1 + +The offset for the start pattern is "ms=e+1". "ms" stands for Match Start. +This defines an offset for the start of the match. Normally the match starts +where the pattern matches. "e+1" means that the match now starts at the end +of the pattern match, and then one character further. + The offset for the end pattern is "me=s-1". "me" stands for Match End. +"s-1" means the start of the pattern match and then one character back. The +result is that in this text: + + if (foo == bar) ~ + +Only the text "foo == bar" will be highlighted as xCond. + +More about offsets here: |:syn-pattern-offset|. + + +ONELINE + +The "oneline" argument indicates that the region does not cross a line +boundary. For example: > + + :syntax region xIfThen start=/if/ end=/then/ oneline + +This defines a region that starts at "if" and ends at "then". But if there is +no "then" after the "if", the region doesn't match. + + Note: + When using "oneline" the region doesn't start if the end pattern + doesn't match in the same line. Without "oneline" Vim does _not_ + check if there is a match for the end pattern. The region starts even + when the end pattern doesn't match in the rest of the file. + + +CONTINUATION LINES AND AVOIDING THEM + +Things now become a little more complex. Let's define a preprocessor line. +This starts with a # in the first column and continues until the end of the +line. A line that ends with \ makes the next line a continuation line. The +way you handle this is to allow the syntax item to contain a continuation +pattern: > + + :syntax region xPreProc start=/^#/ end=/$/ contains=xLineContinue + :syntax match xLineContinue "\\$" contained + +In this case, although xPreProc normally matches a single line, the group +contained in it (namely xLineContinue) lets it go on for more than one line. +For example, it would match both of these lines: + + #define SPAM spam spam spam \ ~ + bacon and spam ~ + +In this case, this is what you want. If it is not what you want, you can call +for the region to be on a single line by adding "excludenl" to the contained +pattern. For example, you want to highlight "end" in xPreProc, but only at +the end of the line. To avoid making the xPreProc continue on the next line, +like xLineContinue does, use "excludenl" like this: > + + :syntax region xPreProc start=/^#/ end=/$/ + \ contains=xLineContinue,xPreProcEnd + :syntax match xPreProcEnd excludenl /end$/ contained + :syntax match xLineContinue "\\$" contained + +"excludenl" must be placed before the pattern. Since "xLineContinue" doesn't +have "excludenl", a match with it will extend xPreProc to the next line as +before. + +============================================================================== +*44.8* Clusters + +One of the things you will notice as you start to write a syntax file is that +you wind up generating a lot of syntax groups. Vim enables you to define a +collection of syntax groups called a cluster. + Suppose you have a language that contains for loops, if statements, while +loops, and functions. Each of them contains the same syntax elements: numbers +and identifiers. You define them like this: > + + :syntax match xFor /^for.*/ contains=xNumber,xIdent + :syntax match xIf /^if.*/ contains=xNumber,xIdent + :syntax match xWhile /^while.*/ contains=xNumber,xIdent + +You have to repeat the same "contains=" every time. If you want to add +another contained item, you have to add it three times. Syntax clusters +simplify these definitions by enabling you to have one cluster stand for +several syntax groups. + To define a cluster for the two items that the three groups contain, use +the following command: > + + :syntax cluster xState contains=xNumber,xIdent + +Clusters are used inside other syntax items just like any syntax group. +Their names start with @. Thus, you can define the three groups like this: > + + :syntax match xFor /^for.*/ contains=@xState + :syntax match xIf /^if.*/ contains=@xState + :syntax match xWhile /^while.*/ contains=@xState + +You can add new group names to this cluster with the "add" argument: > + + :syntax cluster xState add=xString + +You can remove syntax groups from this list as well: > + + :syntax cluster xState remove=xNumber + +============================================================================== +*44.9* Including another syntax file + +The C++ language syntax is a superset of the C language. Because you do not +want to write two syntax files, you can have the C++ syntax file read in the +one for C by using the following command: > + + :runtime! syntax/c.vim + +The ":runtime!" command searches 'runtimepath' for all "syntax/c.vim" files. +This makes the C parts of the C++ syntax be defined like for C files. If you +have replaced the c.vim syntax file, or added items with an extra file, these +will be loaded as well. + After loading the C syntax items the specific C++ items can be defined. +For example, add keywords that are not used in C: > + + :syntax keyword cppStatement new delete this friend using + +This works just like in any other syntax file. + +Now consider the Perl language. A Perl script consists of two distinct parts: +a documentation section in POD format, and a program written in Perl itself. +The POD section starts with "=head" and ends with "=cut". + You want to define the POD syntax in one file, and use it from the Perl +syntax file. The ":syntax include" command reads in a syntax file and stores +the elements it defined in a syntax cluster. For Perl, the statements are as +follows: > + + :syntax include @Pod <sfile>:p:h/pod.vim + :syntax region perlPOD start=/^=head/ end=/^=cut/ contains=@Pod + +When "=head" is found in a Perl file, the perlPOD region starts. In this +region the @Pod cluster is contained. All the items defined as top-level +items in the pod.vim syntax files will match here. When "=cut" is found, the +region ends and we go back to the items defined in the Perl file. + The ":syntax include" command is clever enough to ignore a ":syntax clear" +command in the included file. And an argument such as "contains=ALL" will +only contain items defined in the included file, not in the file that includes +it. + The "<sfile>:p:h/" part uses the name of the current file (<sfile>), +expands it to a full path (:p) and then takes the head (:h). This results in +the directory name of the file. This causes the pod.vim file in the same +directory to be included. + +============================================================================== +*44.10* Synchronizing + +Compilers have it easy. They start at the beginning of a file and parse it +straight through. Vim does not have it so easy. It must start in the middle, +where the editing is being done. So how does it tell where it is? + The secret is the ":syntax sync" command. This tells Vim how to figure out +where it is. For example, the following command tells Vim to scan backward +for the beginning or end of a C-style comment and begin syntax coloring from +there: > + + :syntax sync ccomment + +You can tune this processing with some arguments. The "minlines" argument +tells Vim the minimum number of lines to look backward, and "maxlines" tells +the editor the maximum number of lines to scan. + For example, the following command tells Vim to look at least 10 lines +before the top of the screen: > + + :syntax sync ccomment minlines=10 maxlines=500 + +If it cannot figure out where it is in that space, it starts looking farther +and farther back until it figures out what to do. But it looks no farther +back than 500 lines. (A large "maxlines" slows down processing. A small one +might cause synchronization to fail.) + To make synchronizing go a bit faster, tell Vim which syntax items can be +skipped. Every match and region that only needs to be used when actually +displaying text can be given the "display" argument. + By default, the comment to be found will be colored as part of the Comment +syntax group. If you want to color things another way, you can specify a +different syntax group: > + + :syntax sync ccomment xAltComment + +If your programming language does not have C-style comments in it, you can try +another method of synchronization. The simplest way is to tell Vim to space +back a number of lines and try to figure out things from there. The following +command tells Vim to go back 150 lines and start parsing from there: > + + :syntax sync minlines=150 + +A large "minlines" value can make Vim slower, especially when scrolling +backwards in the file. + Finally, you can specify a syntax group to look for by using this command: +> + :syntax sync match {sync-group-name} + \ grouphere {group-name} {pattern} + +This tells Vim that when it sees {pattern} the syntax group named {group-name} +begins just after the pattern given. The {sync-group-name} is used to give a +name to this synchronization specification. For example, the sh scripting +language begins an if statement with "if" and ends it with "fi": + + if [ --f file.txt ] ; then ~ + echo "File exists" ~ + fi ~ + +To define a "grouphere" directive for this syntax, you use the following +command: > + + :syntax sync match shIfSync grouphere shIf "\<if\>" + +The "groupthere" argument tells Vim that the pattern ends a group. For +example, the end of the if/fi group is as follows: > + + :syntax sync match shIfSync groupthere NONE "\<fi\>" + +In this example, the NONE tells Vim that you are not in any special syntax +region. In particular, you are not inside an if block. + +You also can define matches and regions that are with no "grouphere" or +"groupthere" arguments. These groups are for syntax groups skipped during +synchronization. For example, the following skips over anything inside {}, +even if it would normally match another synchronization method: > + + :syntax sync match xSpecial /{.*}/ + +More about synchronizing in the reference manual: |:syn-sync|. + +============================================================================== +*44.11* Installing a syntax file + +When your new syntax file is ready to be used, drop it in a "syntax" directory +in 'runtimepath'. For Unix that would be "~/.vim/syntax". + The name of the syntax file must be equal to the file type, with ".vim" +added. Thus for the x language, the full path of the file would be: + + ~/.vim/syntax/x.vim ~ + +You must also make the file type be recognized. See |43.2|. + +If your file works well, you might want to make it available to other Vim +users. First read the next section to make sure your file works well for +others. Then e-mail it to the Vim maintainer: <maintainer@vim.org>. Also +explain how the filetype can be detected. With a bit of luck your file will +be included in the next Vim version! + + +ADDING TO AN EXISTING SYNTAX FILE + +We were assuming you were adding a completely new syntax file. When an existing +syntax file works, but is missing some items, you can add items in a separate +file. That avoids changing the distributed syntax file, which will be lost +when installing a new version of Vim. + Write syntax commands in your file, possibly using group names from the +existing syntax. For example, to add new variable types to the C syntax file: +> + :syntax keyword cType off_t uint + +Write the file with the same name as the original syntax file. In this case +"c.vim". Place it in a directory near the end of 'runtimepath'. This makes +it loaded after the original syntax file. For Unix this would be: + + ~/.vim/after/syntax/c.vim ~ + +============================================================================== +*44.12* Portable syntax file layout + +Wouldn't it be nice if all Vim users exchange syntax files? To make this +possible, the syntax file must follow a few guidelines. + +Start with a header that explains what the syntax file is for, who maintains +it and when it was last updated. Don't include too much information about +changes history, not many people will read it. Example: > + + " Vim syntax file + " Language: C + " Maintainer: Bram Moolenaar <Bram@vim.org> + " Last Change: 2001 Jun 18 + " Remark: Included by the C++ syntax. + +Use the same layout as the other syntax files. Using an existing syntax file +as an example will save you a lot of time. + +Choose a good, descriptive name for your syntax file. Use lowercase letters +and digits. Don't make it too long, it is used in many places: The name of +the syntax file "name.vim", 'filetype', b:current_syntax and the start of each +syntax group (nameType, nameStatement, nameString, etc). + +Start with a check for "b:current_syntax". If it is defined, some other +syntax file, earlier in 'runtimepath' was already loaded: > + + if exists("b:current_syntax") + finish + endif + +To be compatible with Vim 5.8 use: > + + if version < 600 + syntax clear + elseif exists("b:current_syntax") + finish + endif + +Set "b:current_syntax" to the name of the syntax at the end. Don't forget +that included files do this too, you might have to reset "b:current_syntax" if +you include two files. + +If you want your syntax file to work with Vim 5.x, add a check for v:version. +See yacc.vim for an example. + +Do not include anything that is a user preference. Don't set 'tabstop', +'expandtab', etc. These belong in a filetype plugin. + +Do not include mappings or abbreviations. Only include setting 'iskeyword' if +it is really necessary for recognizing keywords. + +To allow users select their own preferred colors, make a different group name +for every kind of highlighted item. Then link each of them to one of the +standard highlight groups. That will make it work with every color scheme. +If you select specific colors it will look bad with some color schemes. And +don't forget that some people use a different background color, or have only +eight colors available. + +For the linking use "hi def link", so that the user can select different +highlighting before your syntax file is loaded. Example: > + + hi def link nameString String + hi def link nameNumber Number + hi def link nameCommand Statement + ... etc ... + +Add the "display" argument to items that are not used when syncing, to speed +up scrolling backwards and CTRL-L. + +============================================================================== + +Next chapter: |usr_45.txt| Select your language + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_45.txt b/share/vim/vim73/doc/usr_45.txt new file mode 100644 index 0000000000..1026ee6fe0 --- /dev/null +++ b/share/vim/vim73/doc/usr_45.txt @@ -0,0 +1,419 @@ +*usr_45.txt* For Vim version 7.3. Last change: 2008 Nov 15 + + VIM USER MANUAL - by Bram Moolenaar + + Select your language + + +The messages in Vim can be given in several languages. This chapter explains +how to change which one is used. Also, the different ways to work with files +in various languages is explained. + +|45.1| Language for Messages +|45.2| Language for Menus +|45.3| Using another encoding +|45.4| Editing files with a different encoding +|45.5| Entering language text + + Next chapter: |usr_90.txt| Installing Vim + Previous chapter: |usr_44.txt| Your own syntax highlighted +Table of contents: |usr_toc.txt| + +============================================================================== +*45.1* Language for Messages + +When you start Vim, it checks the environment to find out what language you +are using. Mostly this should work fine, and you get the messages in your +language (if they are available). To see what the current language is, use +this command: > + + :language + +If it replies with "C", this means the default is being used, which is +English. + + Note: + Using different languages only works when Vim was compiled to handle + it. To find out if it works, use the ":version" command and check the + output for "+gettext" and "+multi_lang". If they are there, you are + OK. If you see "-gettext" or "-multi_lang" you will have to find + another Vim. + +What if you would like your messages in a different language? There are +several ways. Which one you should use depends on the capabilities of your +system. + The first way is to set the environment to the desired language before +starting Vim. Example for Unix: > + + env LANG=de_DE.ISO_8859-1 vim + +This only works if the language is available on your system. The advantage is +that all the GUI messages and things in libraries will use the right language +as well. A disadvantage is that you must do this before starting Vim. If you +want to change language while Vim is running, you can use the second method: > + + :language fr_FR.ISO_8859-1 + +This way you can try out several names for your language. You will get an +error message when it's not supported on your system. You don't get an error +when translated messages are not available. Vim will silently fall back to +using English. + To find out which languages are supported on your system, find the +directory where they are listed. On my system it is "/usr/share/locale". On +some systems it's in "/usr/lib/locale". The manual page for "setlocale" +should give you a hint where it is found on your system. + Be careful to type the name exactly as it should be. Upper and lowercase +matter, and the '-' and '_' characters are easily confused. + +You can also set the language separately for messages, edited text and the +time format. See |:language|. + + +DO-IT-YOURSELF MESSAGE TRANSLATION + +If translated messages are not available for your language, you could write +them yourself. To do this, get the source code for Vim and the GNU gettext +package. After unpacking the sources, instructions can be found in the +directory src/po/README.txt. + It's not too difficult to do the translation. You don't need to be a +programmer. You must know both English and the language you are translating +to, of course. + When you are satisfied with the translation, consider making it available +to others. Upload it at vim-online (http://vim.sf.net) or e-mail it to +the Vim maintainer <maintainer@vim.org>. Or both. + +============================================================================== +*45.2* Language for Menus + +The default menus are in English. To be able to use your local language, they +must be translated. Normally this is automatically done for you if the +environment is set for your language, just like with messages. You don't need +to do anything extra for this. But it only works if translations for the +language are available. + Suppose you are in Germany, with the language set to German, but prefer to +use "File" instead of "Datei". You can switch back to using the English menus +this way: > + + :set langmenu=none + +It is also possible to specify a language: > + + :set langmenu=nl_NL.ISO_8859-1 + +Like above, differences between "-" and "_" matter. However, upper/lowercase +differences are ignored here. + The 'langmenu' option must be set before the menus are loaded. Once the +menus have been defined changing 'langmenu' has no direct effect. Therefore, +put the command to set 'langmenu' in your vimrc file. + If you really want to switch menu language while running Vim, you can do it +this way: > + + :source $VIMRUNTIME/delmenu.vim + :set langmenu=de_DE.ISO_8859-1 + :source $VIMRUNTIME/menu.vim + +There is one drawback: All menus that you defined yourself will be gone. You +will need to redefine them as well. + + +DO-IT-YOURSELF MENU TRANSLATION + +To see which menu translations are available, look in this directory: + + $VIMRUNTIME/lang ~ + +The files are called menu_{language}.vim. If you don't see the language you +want to use, you can do your own translations. The simplest way to do this is +by copying one of the existing language files, and change it. + First find out the name of your language with the ":language" command. Use +this name, but with all letters made lowercase. Then copy the file to your +own runtime directory, as found early in 'runtimepath'. For example, for Unix +you would do: > + + :!cp $VIMRUNTIME/lang/menu_ko_kr.euckr.vim ~/.vim/lang/menu_nl_be.iso_8859-1.vim + +You will find hints for the translation in "$VIMRUNTIME/lang/README.txt". + +============================================================================== +*45.3* Using another encoding + +Vim guesses that the files you are going to edit are encoded for your +language. For many European languages this is "latin1". Then each byte is +one character. That means there are 256 different characters possible. For +Asian languages this is not sufficient. These mostly use a double-byte +encoding, providing for over ten thousand possible characters. This still +isn't enough when a text is to contain several different languages. This is +where Unicode comes in. It was designed to include all characters used in +commonly used languages. This is the "Super encoding that replaces all +others". But it isn't used that much yet. + Fortunately, Vim supports these three kinds of encodings. And, with some +restrictions, you can use them even when your environment uses another +language than the text. + Nevertheless, when you only edit files that are in the encoding of your +language, the default should work fine and you don't need to do anything. The +following is only relevant when you want to edit different languages. + + Note: + Using different encodings only works when Vim was compiled to handle + it. To find out if it works, use the ":version" command and check the + output for "+multi_byte". If it's there, you are OK. If you see + "-multi_byte" you will have to find another Vim. + + +USING UNICODE IN THE GUI + +The nice thing about Unicode is that other encodings can be converted to it +and back without losing information. When you make Vim use Unicode +internally, you will be able to edit files in any encoding. + Unfortunately, the number of systems supporting Unicode is still limited. +Thus it's unlikely that your language uses it. You need to tell Vim you want +to use Unicode, and how to handle interfacing with the rest of the system. + Let's start with the GUI version of Vim, which is able to display Unicode +characters. This should work: > + + :set encoding=utf-8 + :set guifont=-misc-fixed-medium-r-normal--18-120-100-100-c-90-iso10646-1 + +The 'encoding' option tells Vim the encoding of the characters that you use. +This applies to the text in buffers (files you are editing), registers, Vim +script files, etc. You can regard 'encoding' as the setting for the internals +of Vim. + This example assumes you have this font on your system. The name in the +example is for the X Window System. This font is in a package that is used to +enhance xterm with Unicode support. If you don't have this font, you might +find it here: + + http://www.cl.cam.ac.uk/~mgk25/download/ucs-fonts.tar.gz ~ + +For MS-Windows, some fonts have a limited number of Unicode characters. Try +using the "Courier New" font. You can use the Edit/Select Font... menu to +select and try out the fonts available. Only fixed-width fonts can be used +though. Example: > + + :set guifont=courier_new:h12 + +If it doesn't work well, try getting a fontpack. If Microsoft didn't move it, +you can find it here: + + http://www.microsoft.com/typography/fonts/default.aspx ~ + +Now you have told Vim to use Unicode internally and display text with a +Unicode font. Typed characters still arrive in the encoding of your original +language. This requires converting them to Unicode. Tell Vim the language +from which to convert with the 'termencoding' option. You can do it like +this: > + + :let &termencoding = &encoding + :set encoding=utf-8 + +This assigns the old value of 'encoding' to 'termencoding' before setting +'encoding' to utf-8. You will have to try out if this really works for your +setup. It should work especially well when using an input method for an Asian +language, and you want to edit Unicode text. + + +USING UNICODE IN A UNICODE TERMINAL + +There are terminals that support Unicode directly. The standard xterm that +comes with XFree86 is one of them. Let's use that as an example. + First of all, the xterm must have been compiled with Unicode support. See +|UTF8-xterm| how to check that and how to compile it when needed. + Start the xterm with the "-u8" argument. You might also need so specify a +font. Example: > + + xterm -u8 -fn -misc-fixed-medium-r-normal--18-120-100-100-c-90-iso10646-1 + +Now you can run Vim inside this terminal. Set 'encoding' to "utf-8" as +before. That's all. + + +USING UNICODE IN AN ORDINARY TERMINAL + +Suppose you want to work with Unicode files, but don't have a terminal with +Unicode support. You can do this with Vim, although characters that are not +supported by the terminal will not be displayed. The layout of the text +will be preserved. > + + :let &termencoding = &encoding + :set encoding=utf-8 + +This is the same as what was used for the GUI. But it works differently: Vim +will convert the displayed text before sending it to the terminal. That +avoids that the display is messed up with strange characters. + For this to work the conversion between 'termencoding' and 'encoding' must +be possible. Vim will convert from latin1 to Unicode, thus that always works. +For other conversions the |+iconv| feature is required. + Try editing a file with Unicode characters in it. You will notice that Vim +will put a question mark (or underscore or some other character) in places +where a character should be that the terminal can't display. Move the cursor +to a question mark and use this command: > + + ga + +Vim will display a line with the code of the character. This gives you a hint +about what character it is. You can look it up in a Unicode table. You could +actually view a file that way, if you have lots of time at hand. + + Note: + Since 'encoding' is used for all text inside Vim, changing it makes + all non-ASCII text invalid. You will notice this when using registers + and the 'viminfo' file (e.g., a remembered search pattern). It's + recommended to set 'encoding' in your vimrc file, and leave it alone. + +============================================================================== +*45.4* Editing files with a different encoding + +Suppose you have setup Vim to use Unicode, and you want to edit a file that is +in 16-bit Unicode. Sounds simple, right? Well, Vim actually uses utf-8 +encoding internally, thus the 16-bit encoding must be converted, since there +is a difference between the character set (Unicode) and the encoding (utf-8 or +16-bit). + Vim will try to detect what kind of file you are editing. It uses the +encoding names in the 'fileencodings' option. When using Unicode, the default +value is: "ucs-bom,utf-8,latin1". This means that Vim checks the file to see +if it's one of these encodings: + + ucs-bom File must start with a Byte Order Mark (BOM). This + allows detection of 16-bit, 32-bit and utf-8 Unicode + encodings. + utf-8 utf-8 Unicode. This is rejected when a sequence of + bytes is illegal in utf-8. + latin1 The good old 8-bit encoding. Always works. + +When you start editing that 16-bit Unicode file, and it has a BOM, Vim will +detect this and convert the file to utf-8 when reading it. The 'fileencoding' +option (without s at the end) is set to the detected value. In this case it +is "utf-16le". That means it's Unicode, 16-bit and little-endian. This +file format is common on MS-Windows (e.g., for registry files). + When writing the file, Vim will compare 'fileencoding' with 'encoding'. If +they are different, the text will be converted. + An empty value for 'fileencoding' means that no conversion is to be done. +Thus the text is assumed to be encoded with 'encoding'. + +If the default 'fileencodings' value is not good for you, set it to the +encodings you want Vim to try. Only when a value is found to be invalid will +the next one be used. Putting "latin1" first doesn't work, because it is +never illegal. An example, to fall back to Japanese when the file doesn't +have a BOM and isn't utf-8: > + + :set fileencodings=ucs-bom,utf-8,sjis + +See |encoding-values| for suggested values. Other values may work as well. +This depends on the conversion available. + + +FORCING AN ENCODING + +If the automatic detection doesn't work you must tell Vim what encoding the +file is. Example: > + + :edit ++enc=koi8-r russian.txt + +The "++enc" part specifies the name of the encoding to be used for this file +only. Vim will convert the file from the specified encoding, Russian in this +example, to 'encoding'. 'fileencoding' will also be set to the specified +encoding, so that the reverse conversion can be done when writing the file. + The same argument can be used when writing the file. This way you can +actually use Vim to convert a file. Example: > + + :write ++enc=utf-8 russian.txt +< + Note: + Conversion may result in lost characters. Conversion from an encoding + to Unicode and back is mostly free of this problem, unless there are + illegal characters. Conversion from Unicode to other encodings often + loses information when there was more than one language in the file. + +============================================================================== +*45.5* Entering language text + +Computer keyboards don't have much more than a hundred keys. Some languages +have thousands of characters, Unicode has ten thousands. So how do you type +these characters? + First of all, when you don't use too many of the special characters, you +can use digraphs. This was already explained in |24.9|. + When you use a language that uses many more characters than keys on your +keyboard, you will want to use an Input Method (IM). This requires learning +the translation from typed keys to resulting character. When you need an IM +you probably already have one on your system. It should work with Vim like +with other programs. For details see |mbyte-XIM| for the X Window system and +|mbyte-IME| for MS-Windows. + + +KEYMAPS + +For some languages the character set is different from latin, but uses a +similar number of characters. It's possible to map keys to characters. Vim +uses keymaps for this. + Suppose you want to type Hebrew. You can load the keymap like this: > + + :set keymap=hebrew + +Vim will try to find a keymap file for you. This depends on the value of +'encoding'. If no matching file was found, you will get an error message. + +Now you can type Hebrew in Insert mode. In Normal mode, and when typing a ":" +command, Vim automatically switches to English. You can use this command to +switch between Hebrew and English: > + + CTRL-^ + +This only works in Insert mode and Command-line mode. In Normal mode it does +something completely different (jumps to alternate file). + The usage of the keymap is indicated in the mode message, if you have the +'showmode' option set. In the GUI Vim will indicate the usage of keymaps with +a different cursor color. + You can also change the usage of the keymap with the 'iminsert' and +'imsearch' options. + +To see the list of mappings, use this command: > + + :lmap + +To find out which keymap files are available, in the GUI you can use the +Edit/Keymap menu. Otherwise you can use this command: > + + :echo globpath(&rtp, "keymap/*.vim") + + +DO-IT-YOURSELF KEYMAPS + +You can create your own keymap file. It's not very difficult. Start with +a keymap file that is similar to the language you want to use. Copy it to the +"keymap" directory in your runtime directory. For example, for Unix, you +would use the directory "~/.vim/keymap". + The name of the keymap file must look like this: + + keymap/{name}.vim ~ +or + keymap/{name}_{encoding}.vim ~ + +{name} is the name of the keymap. Chose a name that is obvious, but different +from existing keymaps (unless you want to replace an existing keymap file). +{name} cannot contain an underscore. Optionally, add the encoding used after +an underscore. Examples: + + keymap/hebrew.vim ~ + keymap/hebrew_utf-8.vim ~ + +The contents of the file should be self-explanatory. Look at a few of the +keymaps that are distributed with Vim. For the details, see |mbyte-keymap|. + + +LAST RESORT + +If all other methods fail, you can enter any character with CTRL-V: + + encoding type range ~ + 8-bit CTRL-V 123 decimal 0-255 + 8-bit CTRL-V x a1 hexadecimal 00-ff + 16-bit CTRL-V u 013b hexadecimal 0000-ffff + 31-bit CTRL-V U 001303a4 hexadecimal 00000000-7fffffff + +Don't type the spaces. See |i_CTRL-V_digit| for the details. + +============================================================================== + +Next chapter: |usr_90.txt| Installing Vim + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_90.txt b/share/vim/vim73/doc/usr_90.txt new file mode 100644 index 0000000000..3b1358daaf --- /dev/null +++ b/share/vim/vim73/doc/usr_90.txt @@ -0,0 +1,498 @@ +*usr_90.txt* For Vim version 7.3. Last change: 2008 Sep 10 + + VIM USER MANUAL - by Bram Moolenaar + + Installing Vim + + *install* +Before you can use Vim you have to install it. Depending on your system it's +simple or easy. This chapter gives a few hints and also explains how +upgrading to a new version is done. + +|90.1| Unix +|90.2| MS-Windows +|90.3| Upgrading +|90.4| Common installation issues +|90.5| Uninstalling Vim + + Previous chapter: |usr_45.txt| Select your language +Table of contents: |usr_toc.txt| + +============================================================================== +*90.1* Unix + +First you have to decide if you are going to install Vim system-wide or for a +single user. The installation is almost the same, but the directory where Vim +is installed in differs. + For a system-wide installation the base directory "/usr/local" is often +used. But this may be different for your system. Try finding out where other +packages are installed. + When installing for a single user, you can use your home directory as the +base. The files will be placed in subdirectories like "bin" and "shared/vim". + + +FROM A PACKAGE + +You can get precompiled binaries for many different UNIX systems. There is a +long list with links on this page: + + http://www.vim.org/binaries.html ~ + +Volunteers maintain the binaries, so they are often out of date. It is a +good idea to compile your own UNIX version from the source. Also, creating +the editor from the source allows you to control which features are compiled. +This does require a compiler though. + +If you have a Linux distribution, the "vi" program is probably a minimal +version of Vim. It doesn't do syntax highlighting, for example. Try finding +another Vim package in your distribution, or search on the web site. + + +FROM SOURCES + +To compile and install Vim, you will need the following: + + - A C compiler (GCC preferred) + - The GZIP program (you can get it from www.gnu.org) + - The Vim source and runtime archives + +To get the Vim archives, look in this file for a mirror near you, this should +provide the fastest download: + + ftp://ftp.vim.org/pub/vim/MIRRORS ~ + +Or use the home site ftp.vim.org, if you think it's fast enough. Go to the +"unix" directory and you'll find a list of files there. The version number is +embedded in the file name. You will want to get the most recent version. + You can get the files for Unix in two ways: One big archive that contains +everything, or four smaller ones that each fit on a floppy disk. For version +6.1 the single big one is called: + + vim-6.1.tar.bz2 ~ + +You need the bzip2 program to uncompress it. If you don't have it, get the +four smaller files, which can be uncompressed with gzip. For Vim 6.1 they are +called: + + vim-6.1-src1.tar.gz ~ + vim-6.1-src2.tar.gz ~ + vim-6.1-rt1.tar.gz ~ + vim-6.1-rt2.tar.gz ~ + + +COMPILING + +First create a top directory to work in, for example: > + + mkdir ~/vim + cd ~/vim + +Then unpack the archives there. If you have the one big archive, you unpack +it like this: > + + bzip2 -d -c path/vim-6.1.tar.bz2 | tar xf - + +Change "path" to where you have downloaded the file. > + + gzip -d -c path/vim-6.1-src1.tar.gz | tar xf - + gzip -d -c path/vim-6.1-src2.tar.gz | tar xf - + gzip -d -c path/vim-6.1-rt1.tar.gz | tar xf - + gzip -d -c path/vim-6.1-rt2.tar.gz | tar xf - + +If you are satisfied with getting the default features, and your environment +is setup properly, you should be able to compile Vim with just this: > + + cd vim61/src + make + +The make program will run configure and compile everything. Further on we +will explain how to compile with different features. + If there are errors while compiling, carefully look at the error messages. +There should be a hint about what went wrong. Hopefully you will be able to +correct it. You might have to disable some features to make Vim compile. +Look in the Makefile for specific hints for your system. + + +TESTING + +Now you can check if compiling worked OK: > + + make test + +This will run a sequence of test scripts to verify that Vim works as expected. +Vim will be started many times and all kinds of text and messages flash by. +If it is alright you will finally see: + + test results: ~ + ALL DONE ~ + +If you get "TEST FAILURE" some test failed. If there are one or two messages +about failed tests, Vim might still work, but not perfectly. If you see a lot +of error messages or Vim doesn't finish until the end, there must be something +wrong. Either try to find out yourself, or find someone who can solve it. +You could look in the |maillist-archive| for a solution. If everything else +fails, you could ask in the vim |maillist| if someone can help you. + + +INSTALLING + *install-home* +If you want to install in your home directory, edit the Makefile and search +for a line: + + #prefix = $(HOME) ~ + +Remove the # at the start of the line. + When installing for the whole system, Vim has most likely already selected +a good installation directory for you. You can also specify one, see below. +You need to become root for the following. + +To install Vim do: > + + make install + +That should move all the relevant files to the right place. Now you can try +running vim to verify that it works. Use two simple tests to check if Vim can +find its runtime files: > + + :help + :syntax enable + +If this doesn't work, use this command to check where Vim is looking for the +runtime files: > + + :echo $VIMRUNTIME + +You can also start Vim with the "-V" argument to see what happens during +startup: > + + vim -V + +Don't forget that the user manual assumes you Vim in a certain way. After +installing Vim, follow the instructions at |not-compatible| to make Vim work +as assumed in this manual. + + +SELECTING FEATURES + +Vim has many ways to select features. One of the simple ways is to edit the +Makefile. There are many directions and examples. Often you can enable or +disable a feature by uncommenting a line. + An alternative is to run "configure" separately. This allows you to +specify configuration options manually. The disadvantage is that you have to +figure out what exactly to type. + Some of the most interesting configure arguments follow. These can also be +enabled from the Makefile. + + --prefix={directory} Top directory where to install Vim. + + --with-features=tiny Compile with many features disabled. + --with-features=small Compile with some features disabled. + --with-features=big Compile with more features enabled. + --with-features=huge Compile with most features enabled. + See |+feature-list| for which feature + is enabled in which case. + + --enable-perlinterp Enable the Perl interface. There are + similar arguments for ruby, python and + tcl. + + --disable-gui Do not compile the GUI interface. + --without-x Do not compile X-windows features. + When both of these are used, Vim will + not connect to the X server, which + makes startup faster. + +To see the whole list use: > + + ./configure --help + +You can find a bit of explanation for each feature, and links for more +information here: |feature-list|. + For the adventurous, edit the file "feature.h". You can also change the +source code yourself! + +============================================================================== +*90.2* MS-Windows + +There are two ways to install the Vim program for Microsoft Windows. You can +uncompress several archives, or use a self-installing big archive. Most users +with fairly recent computers will prefer the second method. For the first +one, you will need: + + - An archive with binaries for Vim. + - The Vim runtime archive. + - A program to unpack the zip files. + +To get the Vim archives, look in this file for a mirror near you, this should +provide the fastest download: + + ftp://ftp.vim.org/pub/vim/MIRRORS ~ + +Or use the home site ftp.vim.org, if you think it's fast enough. Go to the +"pc" directory and you'll find a list of files there. The version number is +embedded in the file name. You will want to get the most recent version. +We will use "61" here, which is version 6.1. + + gvim61.exe The self-installing archive. + +This is all you need for the second method. Just launch the executable, and +follow the prompts. + +For the first method you must chose one of the binary archives. These are +available: + + gvim61.zip The normal MS-Windows GUI version. + gvim61ole.zip The MS-Windows GUI version with OLE support. + Uses more memory, supports interfacing with + other OLE applications. + vim61w32.zip 32 bit MS-Windows console version. For use in + a Win NT/2000/XP console. Does not work well + on Win 95/98. + vim61d32.zip 32 bit MS-DOS version. For use in the + Win 95/98 console window. + vim61d16.zip 16 bit MS-DOS version. Only for old systems. + Does not support long filenames. + +You only need one of them. Although you could install both a GUI and a +console version. You always need to get the archive with runtime files. + + vim61rt.zip The runtime files. + +Use your un-zip program to unpack the files. For example, using the "unzip" +program: > + + cd c:\ + unzip path\gvim61.zip + unzip path\vim61rt.zip + +This will unpack the files in the directory "c:\vim\vim61". If you already +have a "vim" directory somewhere, you will want to move to the directory just +above it. + Now change to the "vim\vim61" directory and run the install program: > + + install + +Carefully look through the messages and select the options you want to use. +If you finally select "do it" the install program will carry out the actions +you selected. + The install program doesn't move the runtime files. They remain where you +unpacked them. + +In case you are not satisfied with the features included in the supplied +binaries, you could try compiling Vim yourself. Get the source archive from +the same location as where the binaries are. You need a compiler for which a +makefile exists. Microsoft Visual C works, but is expensive. The Free +Borland command-line compiler 5.5 can be used, as well as the free MingW and +Cygwin compilers. Check the file src/INSTALLpc.txt for hints. + +============================================================================== +*90.3* Upgrading + +If you are running one version of Vim and want to install another, here is +what to do. + + +UNIX + +When you type "make install" the runtime files will be copied to a directory +which is specific for this version. Thus they will not overwrite a previous +version. This makes it possible to use two or more versions next to +each other. + The executable "vim" will overwrite an older version. If you don't care +about keeping the old version, running "make install" will work fine. You can +delete the old runtime files manually. Just delete the directory with the +version number in it and all files below it. Example: > + + rm -rf /usr/local/share/vim/vim58 + +There are normally no changed files below this directory. If you did change +the "filetype.vim" file, for example, you better merge the changes into the +new version before deleting it. + +If you are careful and want to try out the new version for a while before +switching to it, install the new version under another name. You need to +specify a configure argument. For example: > + + ./configure --with-vim-name=vim6 + +Before running "make install", you could use "make -n install" to check that +no valuable existing files are overwritten. + When you finally decide to switch to the new version, all you need to do is +to rename the binary to "vim". For example: > + + mv /usr/local/bin/vim6 /usr/local/bin/vim + + +MS-WINDOWS + +Upgrading is mostly equal to installing a new version. Just unpack the files +in the same place as the previous version. A new directory will be created, +e.g., "vim61", for the files of the new version. Your runtime files, vimrc +file, viminfo, etc. will be left alone. + If you want to run the new version next to the old one, you will have to do +some handwork. Don't run the install program, it will overwrite a few files +of the old version. Execute the new binaries by specifying the full path. +The program should be able to automatically find the runtime files for the +right version. However, this won't work if you set the $VIMRUNTIME variable +somewhere. + If you are satisfied with the upgrade, you can delete the files of the +previous version. See |90.5|. + +============================================================================== +*90.4* Common installation issues + +This section describes some of the common problems that occur when installing +Vim and suggests some solutions. It also contains answers to many +installation questions. + + +Q: I Do Not Have Root Privileges. How Do I Install Vim? (Unix) + +Use the following configuration command to install Vim in a directory called +$HOME/vim: > + + ./configure --prefix=$HOME + +This gives you a personal copy of Vim. You need to put $HOME/bin in your +path to execute the editor. Also see |install-home|. + + +Q: The Colors Are Not Right on My Screen. (Unix) + +Check your terminal settings by using the following command in a shell: > + + echo $TERM + +If the terminal type listed is not correct, fix it. For more hints, see +|06.2|. Another solution is to always use the GUI version of Vim, called +gvim. This avoids the need for a correct terminal setup. + + +Q: My Backspace And Delete Keys Don't Work Right + +The definition of what key sends what code is very unclear for backspace <BS> +and Delete <Del> keys. First of all, check your $TERM setting. If there is +nothing wrong with it, try this: > + + :set t_kb=^V<BS> + :set t_kD=^V<Del> + +In the first line you need to press CTRL-V and then hit the backspace key. +In the second line you need to press CTRL-V and then hit the Delete key. +You can put these lines in your vimrc file, see |05.1|. A disadvantage is +that it won't work when you use another terminal some day. Look here for +alternate solutions: |:fixdel|. + + +Q: I Am Using RedHat Linux. Can I Use the Vim That Comes with the System? + +By default RedHat installs a minimal version of Vim. Check your RPM packages +for something named "Vim-enhanced-version.rpm" and install that. + + +Q: How Do I Turn Syntax Coloring On? How do I make plugins work? + +Use the example vimrc script. You can find an explanation on how to use it +here: |not-compatible|. + +See chapter 6 for information about syntax highlighting: |usr_06.txt|. + + +Q: What Is a Good vimrc File to Use? + +See the www.vim.org Web site for several good examples. + + +Q: Where Do I Find a Good Vim Plugin? + +See the Vim-online site: http://vim.sf.net. Many users have uploaded useful +Vim scripts and plugins there. + + +Q: Where Do I Find More Tips? + +See the Vim-online site: http://vim.sf.net. There is an archive with hints +from Vim users. You might also want to search in the |maillist-archive|. + +============================================================================== +*90.5* Uninstalling Vim + +In the unlikely event you want to uninstall Vim completely, this is how you do +it. + + +UNIX + +When you installed Vim as a package, check your package manager to find out +how to remove the package again. + If you installed Vim from sources you can use this command: > + + make uninstall + +However, if you have deleted the original files or you used an archive that +someone supplied, you can't do this. Do delete the files manually, here is an +example for when "/usr/local" was used as the root: > + + rm -rf /usr/local/share/vim/vim61 + rm /usr/local/bin/eview + rm /usr/local/bin/evim + rm /usr/local/bin/ex + rm /usr/local/bin/gview + rm /usr/local/bin/gvim + rm /usr/local/bin/gvim + rm /usr/local/bin/gvimdiff + rm /usr/local/bin/rgview + rm /usr/local/bin/rgvim + rm /usr/local/bin/rview + rm /usr/local/bin/rvim + rm /usr/local/bin/rvim + rm /usr/local/bin/view + rm /usr/local/bin/vim + rm /usr/local/bin/vimdiff + rm /usr/local/bin/vimtutor + rm /usr/local/bin/xxd + rm /usr/local/man/man1/eview.1 + rm /usr/local/man/man1/evim.1 + rm /usr/local/man/man1/ex.1 + rm /usr/local/man/man1/gview.1 + rm /usr/local/man/man1/gvim.1 + rm /usr/local/man/man1/gvimdiff.1 + rm /usr/local/man/man1/rgview.1 + rm /usr/local/man/man1/rgvim.1 + rm /usr/local/man/man1/rview.1 + rm /usr/local/man/man1/rvim.1 + rm /usr/local/man/man1/view.1 + rm /usr/local/man/man1/vim.1 + rm /usr/local/man/man1/vimdiff.1 + rm /usr/local/man/man1/vimtutor.1 + rm /usr/local/man/man1/xxd.1 + + +MS-WINDOWS + +If you installed Vim with the self-installing archive you can run +the "uninstall-gui" program located in the same directory as the other Vim +programs, e.g. "c:\vim\vim61". You can also launch it from the Start menu if +installed the Vim entries there. This will remove most of the files, menu +entries and desktop shortcuts. Some files may remain however, as they need a +Windows restart before being deleted. + You will be given the option to remove the whole "vim" directory. It +probably contains your vimrc file and other runtime files that you created, so +be careful. + +Else, if you installed Vim with the zip archives, the preferred way is to use +the "uninstal" program (note the missing l at the end). You can find it in +the same directory as the "install" program, e.g., "c:\vim\vim61". This +should also work from the usual "install/remove software" page. + However, this only removes the registry entries for Vim. You have to +delete the files yourself. Simply select the directory "vim\vim61" and delete +it recursively. There should be no files there that you changed, but you +might want to check that first. + The "vim" directory probably contains your vimrc file and other runtime +files that you created. You might want to keep that. + +============================================================================== + +Table of contents: |usr_toc.txt| + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/usr_toc.txt b/share/vim/vim73/doc/usr_toc.txt new file mode 100644 index 0000000000..5d360d511e --- /dev/null +++ b/share/vim/vim73/doc/usr_toc.txt @@ -0,0 +1,354 @@ +*usr_toc.txt* For Vim version 7.3. Last change: 2010 Jul 20 + + VIM USER MANUAL - by Bram Moolenaar + + Table Of Contents *user-manual* + +============================================================================== +Overview ~ + +Getting Started +|usr_01.txt| About the manuals +|usr_02.txt| The first steps in Vim +|usr_03.txt| Moving around +|usr_04.txt| Making small changes +|usr_05.txt| Set your settings +|usr_06.txt| Using syntax highlighting +|usr_07.txt| Editing more than one file +|usr_08.txt| Splitting windows +|usr_09.txt| Using the GUI +|usr_10.txt| Making big changes +|usr_11.txt| Recovering from a crash +|usr_12.txt| Clever tricks + +Editing Effectively +|usr_20.txt| Typing command-line commands quickly +|usr_21.txt| Go away and come back +|usr_22.txt| Finding the file to edit +|usr_23.txt| Editing other files +|usr_24.txt| Inserting quickly +|usr_25.txt| Editing formatted text +|usr_26.txt| Repeating +|usr_27.txt| Search commands and patterns +|usr_28.txt| Folding +|usr_29.txt| Moving through programs +|usr_30.txt| Editing programs +|usr_31.txt| Exploiting the GUI +|usr_32.txt| The undo tree + +Tuning Vim +|usr_40.txt| Make new commands +|usr_41.txt| Write a Vim script +|usr_42.txt| Add new menus +|usr_43.txt| Using filetypes +|usr_44.txt| Your own syntax highlighted +|usr_45.txt| Select your language + +Making Vim Run +|usr_90.txt| Installing Vim + + +Reference manual +|reference_toc| More detailed information for all commands + +The user manual is available as a single, ready to print HTML and PDF file +here: + http://vimdoc.sf.net + +============================================================================== +Getting Started ~ + +Read this from start to end to learn the essential commands. + +|usr_01.txt| About the manuals + |01.1| Two manuals + |01.2| Vim installed + |01.3| Using the Vim tutor + |01.4| Copyright + +|usr_02.txt| The first steps in Vim + |02.1| Running Vim for the First Time + |02.2| Inserting text + |02.3| Moving around + |02.4| Deleting characters + |02.5| Undo and Redo + |02.6| Other editing commands + |02.7| Getting out + |02.8| Finding help + +|usr_03.txt| Moving around + |03.1| Word movement + |03.2| Moving to the start or end of a line + |03.3| Moving to a character + |03.4| Matching a paren + |03.5| Moving to a specific line + |03.6| Telling where you are + |03.7| Scrolling around + |03.8| Simple searches + |03.9| Simple search patterns + |03.10| Using marks + +|usr_04.txt| Making small changes + |04.1| Operators and motions + |04.2| Changing text + |04.3| Repeating a change + |04.4| Visual mode + |04.5| Moving text + |04.6| Copying text + |04.7| Using the clipboard + |04.8| Text objects + |04.9| Replace mode + |04.10| Conclusion + +|usr_05.txt| Set your settings + |05.1| The vimrc file + |05.2| The example vimrc file explained + |05.3| Simple mappings + |05.4| Adding a plugin + |05.5| Adding a help file + |05.6| The option window + |05.7| Often used options + +|usr_06.txt| Using syntax highlighting + |06.1| Switching it on + |06.2| No or wrong colors? + |06.3| Different colors + |06.4| With colors or without colors + |06.5| Printing with colors + |06.6| Further reading + +|usr_07.txt| Editing more than one file + |07.1| Edit another file + |07.2| A list of files + |07.3| Jumping from file to file + |07.4| Backup files + |07.5| Copy text between files + |07.6| Viewing a file + |07.7| Changing the file name + +|usr_08.txt| Splitting windows + |08.1| Split a window + |08.2| Split a window on another file + |08.3| Window size + |08.4| Vertical splits + |08.5| Moving windows + |08.6| Commands for all windows + |08.7| Viewing differences with vimdiff + |08.8| Various + +|usr_09.txt| Using the GUI + |09.1| Parts of the GUI + |09.2| Using the mouse + |09.3| The clipboard + |09.4| Select mode + +|usr_10.txt| Making big changes + |10.1| Record and playback commands + |10.2| Substitution + |10.3| Command ranges + |10.4| The global command + |10.5| Visual block mode + |10.6| Reading and writing part of a file + |10.7| Formatting text + |10.8| Changing case + |10.9| Using an external program + +|usr_11.txt| Recovering from a crash + |11.1| Basic recovery + |11.2| Where is the swap file? + |11.3| Crashed or not? + |11.4| Further reading + +|usr_12.txt| Clever tricks + |12.1| Replace a word + |12.2| Change "Last, First" to "First Last" + |12.3| Sort a list + |12.4| Reverse line order + |12.5| Count words + |12.6| Find a man page + |12.7| Trim blanks + |12.8| Find where a word is used + +============================================================================== +Editing Effectively ~ + +Subjects that can be read independently. + +|usr_20.txt| Typing command-line commands quickly + |20.1| Command line editing + |20.2| Command line abbreviations + |20.3| Command line completion + |20.4| Command line history + |20.5| Command line window + +|usr_21.txt| Go away and come back + |21.1| Suspend and resume + |21.2| Executing shell commands + |21.3| Remembering information; viminfo + |21.4| Sessions + |21.5| Views + |21.6| Modelines + +|usr_22.txt| Finding the file to edit + |22.1| The file explorer + |22.2| The current directory + |22.3| Finding a file + |22.4| The buffer list + +|usr_23.txt| Editing other files + |23.1| DOS, Mac and Unix files + |23.2| Files on the internet + |23.3| Encryption + |23.4| Binary files + |23.5| Compressed files + +|usr_24.txt| Inserting quickly + |24.1| Making corrections + |24.2| Showing matches + |24.3| Completion + |24.4| Repeating an insert + |24.5| Copying from another line + |24.6| Inserting a register + |24.7| Abbreviations + |24.8| Entering special characters + |24.9| Digraphs + |24.10| Normal mode commands + +|usr_25.txt| Editing formatted text + |25.1| Breaking lines + |25.2| Aligning text + |25.3| Indents and tabs + |25.4| Dealing with long lines + |25.5| Editing tables + +|usr_26.txt| Repeating + |26.1| Repeating with Visual mode + |26.2| Add and subtract + |26.3| Making a change in many files + |26.4| Using Vim from a shell script + +|usr_27.txt| Search commands and patterns + |27.1| Ignoring case + |27.2| Wrapping around the file end + |27.3| Offsets + |27.4| Matching multiple times + |27.5| Alternatives + |27.6| Character ranges + |27.7| Character classes + |27.8| Matching a line break + |27.9| Examples + +|usr_28.txt| Folding + |28.1| What is folding? + |28.2| Manual folding + |28.3| Working with folds + |28.4| Saving and restoring folds + |28.5| Folding by indent + |28.6| Folding with markers + |28.7| Folding by syntax + |28.8| Folding by expression + |28.9| Folding unchanged lines + |28.10| Which fold method to use? + +|usr_29.txt| Moving through programs + |29.1| Using tags + |29.2| The preview window + |29.3| Moving through a program + |29.4| Finding global identifiers + |29.5| Finding local identifiers + +|usr_30.txt| Editing programs + |30.1| Compiling + |30.2| Indenting C files + |30.3| Automatic indenting + |30.4| Other indenting + |30.5| Tabs and spaces + |30.6| Formatting comments + +|usr_31.txt| Exploiting the GUI + |31.1| The file browser + |31.2| Confirmation + |31.3| Menu shortcuts + |31.4| Vim window position and size + |31.5| Various + +|usr_32.txt| The undo tree + |32.1| Undo up to a file write + |32.2| Numbering changes + |32.3| Jumping around the tree + |32.4| Time travelling + +============================================================================== +Tuning Vim ~ + +Make Vim work as you like it. + +|usr_40.txt| Make new commands + |40.1| Key mapping + |40.2| Defining command-line commands + |40.3| Autocommands + +|usr_41.txt| Write a Vim script + |41.1| Introduction + |41.2| Variables + |41.3| Expressions + |41.4| Conditionals + |41.5| Executing an expression + |41.6| Using functions + |41.7| Defining a function + |41.8| Lists and Dictionaries + |41.9| Exceptions + |41.10| Various remarks + |41.11| Writing a plugin + |41.12| Writing a filetype plugin + |41.13| Writing a compiler plugin + |41.14| Writing a plugin that loads quickly + |41.15| Writing library scripts + |41.16| Distributing Vim scripts + +|usr_42.txt| Add new menus + |42.1| Introduction + |42.2| Menu commands + |42.3| Various + |42.4| Toolbar and popup menus + +|usr_43.txt| Using filetypes + |43.1| Plugins for a filetype + |43.2| Adding a filetype + +|usr_44.txt| Your own syntax highlighted + |44.1| Basic syntax commands + |44.2| Keywords + |44.3| Matches + |44.4| Regions + |44.5| Nested items + |44.6| Following groups + |44.7| Other arguments + |44.8| Clusters + |44.9| Including another syntax file + |44.10| Synchronizing + |44.11| Installing a syntax file + |44.12| Portable syntax file layout + +|usr_45.txt| Select your language + |45.1| Language for Messages + |45.2| Language for Menus + |45.3| Using another encoding + |45.4| Editing files with a different encoding + |45.5| Entering language text + +============================================================================== +Making Vim Run ~ + +Before you can use Vim. + +|usr_90.txt| Installing Vim + |90.1| Unix + |90.2| MS-Windows + |90.3| Upgrading + |90.4| Common installation issues + |90.5| Uninstalling Vim + +============================================================================== + +Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/various.txt b/share/vim/vim73/doc/various.txt new file mode 100644 index 0000000000..d3b15526ab --- /dev/null +++ b/share/vim/vim73/doc/various.txt @@ -0,0 +1,629 @@ +*various.txt* For Vim version 7.3. Last change: 2010 Aug 10 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + +Various commands *various* + +1. Various commands |various-cmds| +2. Using Vim like less or more |less| + +============================================================================== +1. Various commands *various-cmds* + + *CTRL-L* +CTRL-L Clear and redraw the screen. The redraw may happen + later, after processing typeahead. + + *:redr* *:redraw* +:redr[aw][!] Redraw the screen right now. When ! is included it is + cleared first. + Useful to update the screen halfway executing a script + or function. Also when halfway a mapping and + 'lazyredraw' is set. + + *:redraws* *:redrawstatus* +:redraws[tatus][!] Redraw the status line of the current window. When ! + is included all status lines are redrawn. + Useful to update the status line(s) when 'statusline' + includes an item that doesn't cause automatic + updating. + + *N<Del>* +<Del> When entering a number: Remove the last digit. + Note: if you like to use <BS> for this, add this + mapping to your .vimrc: > + :map CTRL-V <BS> CTRL-V <Del> +< See |:fixdel| if your <Del> key does not do what you + want. + +:as[cii] or *ga* *:as* *:ascii* +ga Print the ascii value of the character under the + cursor in decimal, hexadecimal and octal. For + example, when the cursor is on a 'R': + <R> 82, Hex 52, Octal 122 ~ + When the character is a non-standard ASCII character, + but printable according to the 'isprint' option, the + non-printable version is also given. When the + character is larger than 127, the <M-x> form is also + printed. For example: + <~A> <M-^A> 129, Hex 81, Octal 201 ~ + <p> <|~> <M-~> 254, Hex fe, Octal 376 ~ + (where <p> is a special character) + The <Nul> character in a file is stored internally as + <NL>, but it will be shown as: + <^@> 0, Hex 00, Octal 000 ~ + If the character has composing characters these are + also shown. The value of 'maxcombine' doesn't matter. + Mnemonic: Get Ascii value. {not in Vi} + + *g8* +g8 Print the hex values of the bytes used in the + character under the cursor, assuming it is in |UTF-8| + encoding. This also shows composing characters. The + value of 'maxcombine' doesn't matter. + Example of a character with two composing characters: + e0 b8 81 + e0 b8 b9 + e0 b9 89 ~ + {not in Vi} {only when compiled with the |+multi_byte| + feature} + + *8g8* +8g8 Find an illegal UTF-8 byte sequence at or after the + cursor. This works in two situations: + 1. when 'encoding' is any 8-bit encoding + 2. when 'encoding' is "utf-8" and 'fileencoding' is + any 8-bit encoding + Thus it can be used when editing a file that was + supposed to be UTF-8 but was read as if it is an 8-bit + encoding because it contains illegal bytes. + Does not wrap around the end of the file. + Note that when the cursor is on an illegal byte or the + cursor is halfway a multi-byte character the command + won't move the cursor. + {not in Vi} {only when compiled with the |+multi_byte| + feature} + + *:p* *:pr* *:print* *E749* +:[range]p[rint] [flags] + Print [range] lines (default current line). + Note: If you are looking for a way to print your text + on paper see |:hardcopy|. In the GUI you can use the + File.Print menu entry. + See |ex-flags| for [flags]. + +:[range]p[rint] {count} [flags] + Print {count} lines, starting with [range] (default + current line |cmdline-ranges|). + See |ex-flags| for [flags]. + + *:P* *:Print* +:[range]P[rint] [count] [flags] + Just as ":print". Was apparently added to Vi for + people that keep the shift key pressed too long... + See |ex-flags| for [flags]. + + *:l* *:list* +:[range]l[ist] [count] [flags] + Same as :print, but display unprintable characters + with '^' and put $ after the line. This can be + changed with the 'listchars' option. + See |ex-flags| for [flags]. + + *:nu* *:number* +:[range]nu[mber] [count] [flags] + Same as :print, but precede each line with its line + number. (See also 'highlight' and 'numberwidth' + option). + See |ex-flags| for [flags]. + + *:#* +:[range]# [count] [flags] + synonym for :number. + + *:#!* +:#!{anything} Ignored, so that you can start a Vim script with: > + #!vim -S + echo "this is a Vim script" + quit +< + *:z* *E144* +:{range}z[+-^.=]{count} Display several lines of text surrounding the line + specified with {range}, or around the current line + if there is no {range}. If there is a {count}, that's + how many lines you'll see; if there is only one window + then the 'window' option is used, otherwise the + current window size is used. + + :z can be used either alone or followed by any of + several punctuation marks. These have the following + effect: + + mark first line last line new location ~ + ---- ---------- --------- ------------ + + current line 1 scr forward 1 scr forward + - 1 scr back current line current line + ^ 2 scr back 1 scr back 1 scr back + . 1/2 scr back 1/2 scr fwd 1/2 scr fwd + = 1/2 scr back 1/2 scr fwd current line + + Specifying no mark at all is the same as "+". + If the mark is "=", a line of dashes is printed + around the current line. + +:{range}z#[+-^.=]{count} *:z#* + Like ":z", but number the lines. + {not in all versions of Vi, not with these arguments} + + *:=* +:= [flags] Print the last line number. + See |ex-flags| for [flags]. + +:{range}= [flags] Prints the last line number in {range}. For example, + this prints the current line number: > + :.= +< See |ex-flags| for [flags]. + +:norm[al][!] {commands} *:norm* *:normal* + Execute Normal mode commands {commands}. This makes + it possible to execute Normal mode commands typed on + the command-line. {commands} is executed like it is + typed. For undo all commands are undone together. + Execution stops when an error is encountered. + If the [!] is given, mappings will not be used. + {commands} should be a complete command. If + {commands} does not finish a command, the last one + will be aborted as if <Esc> or <C-C> was typed. + The display isn't updated while ":normal" is busy. + This implies that an insert command must be completed + (to start Insert mode, see |:startinsert|). A ":" + command must be completed as well. And you can't use + "Q" or "gQ" to start Ex mode. + {commands} cannot start with a space. Put a count of + 1 (one) before it, "1 " is one space. + The 'insertmode' option is ignored for {commands}. + This command cannot be followed by another command, + since any '|' is considered part of the command. + This command can be used recursively, but the depth is + limited by 'maxmapdepth'. + When this command is called from a non-remappable + mapping |:noremap|, the argument can be mapped anyway. + An alternative is to use |:execute|, which uses an + expression as argument. This allows the use of + printable characters to represent special characters. + Example: > + :exe "normal \<c-w>\<c-w>" +< {not in Vi, of course} + {not available when the |+ex_extra| feature was + disabled at compile time} + +:{range}norm[al][!] {commands} *:normal-range* + Execute Normal mode commands {commands} for each line + in the {range}. Before executing the {commands}, the + cursor is positioned in the first column of the range, + for each line. Otherwise it's the same as the + ":normal" command without a range. + {not in Vi} + {not available when |+ex_extra| feature was disabled + at compile time} + + *:sh* *:shell* *E371* +:sh[ell] This command starts a shell. When the shell exits + (after the "exit" command) you return to Vim. The + name for the shell command comes from 'shell' option. + *E360* + Note: This doesn't work when Vim on the Amiga was + started in QuickFix mode from a compiler, because the + compiler will have set stdin to a non-interactive + mode. + + *:!cmd* *:!* *E34* +:!{cmd} Execute {cmd} with the shell. See also the 'shell' + and 'shelltype' option. + Any '!' in {cmd} is replaced with the previous + external command (see also 'cpoptions'). But not when + there is a backslash before the '!', then that + backslash is removed. Example: ":!ls" followed by + ":!echo ! \! \\!" executes "echo ls ! \!". + After the command has been executed, the timestamp of + the current file is checked |timestamp|. + A '|' in {cmd} is passed to the shell, you cannot use + it to append a Vim command. See |:bar|. + A newline character ends {cmd}, what follows is + interpreted as a following ":" command. However, if + there is a backslash before the newline it is removed + and {cmd} continues. It doesn't matter how many + backslashes are before the newline, only one is + removed. + On Unix the command normally runs in a non-interactive + shell. If you want an interactive shell to be used + (to use aliases) set 'shellcmdflag' to "-ic". + For Win32 also see |:!start|. + Vim redraws the screen after the command is finished, + because it may have printed any text. This requires a + hit-enter prompt, so that you can read any messages. + To avoid this use: > + :silent !{cmd} +< The screen is not redrawn then, thus you have to use + CTRL-L or ":redraw!" if the command did display + something. + Also see |shell-window|. + + *:!!* +:!! Repeat last ":!{cmd}". + + *:ve* *:version* +:ve[rsion] Print the version number of the editor. If the + compiler used understands "__DATE__" the compilation + date is mentioned. Otherwise a fixed release-date is + shown. + The following lines contain information about which + features were enabled when Vim was compiled. When + there is a preceding '+', the feature is included, + when there is a '-' it is excluded. To change this, + you have to edit feature.h and recompile Vim. + To check for this in an expression, see |has()|. + Here is an overview of the features. + The first column shows the smallest version in which + they are included: + T tiny + S small + N normal + B big + H huge + m manually enabled or depends on other features + (none) system dependent + Thus if a feature is marked with "N", it is included + in the normal, big and huge versions of Vim. + + *+feature-list* + *+ARP* Amiga only: ARP support included +B *+arabic* |Arabic| language support +N *+autocmd* |:autocmd|, automatic commands +m *+balloon_eval* |balloon-eval| support. Included when compiling with + supported GUI (Motif, GTK, GUI) and either + Netbeans/Sun Workshop integration or |+eval| feature. +N *+browse* |:browse| command +N *+builtin_terms* some terminals builtin |builtin-terms| +B *++builtin_terms* maximal terminals builtin |builtin-terms| +N *+byte_offset* support for 'o' flag in 'statusline' option, "go" + and ":goto" commands. +N *+cindent* |'cindent'|, C indenting +N *+clientserver* Unix and Win32: Remote invocation |clientserver| + *+clipboard* |clipboard| support +N *+cmdline_compl* command line completion |cmdline-completion| +N *+cmdline_hist* command line history |cmdline-history| +N *+cmdline_info* |'showcmd'| and |'ruler'| +N *+comments* |'comments'| support +B *+conceal* "conceal" support, see |conceal| |:syn-conceal| etc. +N *+cryptv* encryption support |encryption| +B *+cscope* |cscope| support +m *+cursorbind* |'cursorbind'| support +m *+cursorshape* |termcap-cursor-shape| support +m *+debug* Compiled for debugging. +N *+dialog_gui* Support for |:confirm| with GUI dialog. +N *+dialog_con* Support for |:confirm| with console dialog. +N *+dialog_con_gui* Support for |:confirm| with GUI and console dialog. +N *+diff* |vimdiff| and 'diff' +N *+digraphs* |digraphs| *E196* + *+dnd* Support for DnD into the "~ register |quote_~|. +B *+emacs_tags* |emacs-tags| files +N *+eval* expression evaluation |eval.txt| +N *+ex_extra* Vim's extra Ex commands: |:center|, |:left|, + |:normal|, |:retab| and |:right| +N *+extra_search* |'hlsearch'| and |'incsearch'| options. +B *+farsi* |farsi| language +N *+file_in_path* |gf|, |CTRL-W_f| and |<cfile>| +N *+find_in_path* include file searches: |[I|, |:isearch|, + |CTRL-W_CTRL-I|, |:checkpath|, etc. +N *+folding* |folding| + *+footer* |gui-footer| + *+fork* Unix only: |fork| shell commands + *+float* Floating point support +N *+gettext* message translations |multi-lang| + *+GUI_Athena* Unix only: Athena |GUI| + *+GUI_neXtaw* Unix only: neXtaw |GUI| + *+GUI_GTK* Unix only: GTK+ |GUI| + *+GUI_Motif* Unix only: Motif |GUI| + *+GUI_Photon* QNX only: Photon |GUI| +m *+hangul_input* Hangul input support |hangul| + *+iconv* Compiled with the |iconv()| function + *+iconv/dyn* Likewise |iconv-dynamic| |/dyn| +N *+insert_expand* |insert_expand| Insert mode completion +N *+jumplist* |jumplist| +B *+keymap* |'keymap'| +B *+langmap* |'langmap'| +N *+libcall* |libcall()| +N *+linebreak* |'linebreak'|, |'breakat'| and |'showbreak'| +N *+lispindent* |'lisp'| +N *+listcmds* Vim commands for the list of buffers |buffer-hidden| + and argument list |:argdelete| +N *+localmap* Support for mappings local to a buffer |:map-local| +m *+lua* |Lua| interface +m *+lua/dyn* |Lua| interface |/dyn| +N *+menu* |:menu| +N *+mksession* |:mksession| +N *+modify_fname* |filename-modifiers| +N *+mouse* Mouse handling |mouse-using| +N *+mouseshape* |'mouseshape'| +B *+mouse_dec* Unix only: Dec terminal mouse handling |dec-mouse| +N *+mouse_gpm* Unix only: Linux console mouse handling |gpm-mouse| +B *+mouse_netterm* Unix only: netterm mouse handling |netterm-mouse| +N *+mouse_pterm* QNX only: pterm mouse handling |qnx-terminal| +N *+mouse_sysmouse* Unix only: *BSD console mouse handling |sysmouse| +N *+mouse_xterm* Unix only: xterm mouse handling |xterm-mouse| +B *+multi_byte* 16 and 32 bit characters |multibyte| + *+multi_byte_ime* Win32 input method for multibyte chars |multibyte-ime| +N *+multi_lang* non-English language support |multi-lang| +m *+mzscheme* Mzscheme interface |mzscheme| +m *+mzscheme/dyn* Mzscheme interface |mzscheme-dynamic| |/dyn| +m *+netbeans_intg* |netbeans| +m *+ole* Win32 GUI only: |ole-interface| + *+osfiletype* Support for the 'osfiletype' option and filetype + checking in automatic commands. |autocmd-osfiletypes| +N *+path_extra* Up/downwards search in 'path' and 'tags' +m *+perl* Perl interface |perl| +m *+perl/dyn* Perl interface |perl-dynamic| |/dyn| +N *+persistent_undo* Persistent undo |undo-persistence| + *+postscript* |:hardcopy| writes a PostScript file +N *+printer* |:hardcopy| command +H *+profile* |:profile| command +m *+python* Python 2 interface |python| +m *+python/dyn* Python 2 interface |python-dynamic| |/dyn| +m *+python3* Python 3 interface |python| +m *+python3/dyn* Python 3 interface |python-dynamic| |/dyn| +N *+quickfix* |:make| and |quickfix| commands +N *+reltime* |reltime()| function, 'hlsearch'/'incsearch' timeout, + 'redrawtime' option +B *+rightleft* Right to left typing |'rightleft'| +m *+ruby* Ruby interface |ruby| +m *+ruby/dyn* Ruby interface |ruby-dynamic| |/dyn| +N *+scrollbind* |'scrollbind'| +B *+signs* |:sign| +N *+smartindent* |'smartindent'| +m *+sniff* SniFF interface |sniff| +N *+startuptime* |--startuptime| argument +N *+statusline* Options 'statusline', 'rulerformat' and special + formats of 'titlestring' and 'iconstring' +m *+sun_workshop* |workshop| +N *+syntax* Syntax highlighting |syntax| + *+system()* Unix only: opposite of |+fork| +N *+tag_binary* binary searching in tags file |tag-binary-search| +N *+tag_old_static* old method for static tags |tag-old-static| +m *+tag_any_white* any white space allowed in tags file |tag-any-white| +m *+tcl* Tcl interface |tcl| +m *+tcl/dyn* Tcl interface |tcl-dynamic| |/dyn| + *+terminfo* uses |terminfo| instead of termcap +N *+termresponse* support for |t_RV| and |v:termresponse| +N *+textobjects* |text-objects| selection + *+tgetent* non-Unix only: able to use external termcap +N *+title* Setting the window 'title' and 'icon' +N *+toolbar* |gui-toolbar| +N *+user_commands* User-defined commands. |user-commands| +N *+viminfo* |'viminfo'| +N *+vertsplit* Vertically split windows |:vsplit| +N *+virtualedit* |'virtualedit'| +S *+visual* Visual mode |Visual-mode| +N *+visualextra* extra Visual mode commands |blockwise-operators| +N *+vreplace* |gR| and |gr| +N *+wildignore* |'wildignore'| +N *+wildmenu* |'wildmenu'| +S *+windows* more than one window +m *+writebackup* |'writebackup'| is default on +m *+xim* X input method |xim| + *+xfontset* X fontset support |xfontset| + *+xsmp* XSMP (X session management) support + *+xsmp_interact* interactive XSMP (X session management) support +N *+xterm_clipboard* Unix only: xterm clipboard handling +m *+xterm_save* save and restore xterm screen |xterm-screens| +N *+X11* Unix only: can restore window title |X11| + + */dyn* *E370* *E448* + To some of the features "/dyn" is added when the + feature is only available when the related library can + be dynamically loaded. + +:ve[rsion] {nr} Is now ignored. This was previously used to check the + version number of a .vimrc file. It was removed, + because you can now use the ":if" command for + version-dependent behavior. {not in Vi} + + *:redi* *:redir* +:redi[r][!] > {file} Redirect messages to file {file}. The messages which + are the output of commands are written to that file, + until redirection ends. The messages are also still + shown on the screen. When [!] is included, an + existing file is overwritten. When [!] is omitted, + and {file} exists, this command fails. + Only one ":redir" can be active at a time. Calls to + ":redir" will close any active redirection before + starting redirection to the new target. + To stop the messages and commands from being echoed to + the screen, put the commands in a function and call it + with ":silent call Function()". + An alternative is to use the 'verbosefile' option, + this can be used in combination with ":redir". + {not in Vi} + +:redi[r] >> {file} Redirect messages to file {file}. Append if {file} + already exists. {not in Vi} + +:redi[r] @{a-zA-Z} +:redi[r] @{a-zA-Z}> Redirect messages to register {a-z}. Append to the + contents of the register if its name is given + uppercase {A-Z}. The ">" after the register name is + optional. {not in Vi} +:redi[r] @{a-z}>> Append messages to register {a-z}. {not in Vi} + +:redi[r] @*> +:redi[r] @+> Redirect messages to the selection or clipboard. For + backward compatibility, the ">" after the register + name can be omitted. See |quotestar| and |quoteplus|. + {not in Vi} +:redi[r] @*>> +:redi[r] @+>> Append messages to the selection or clipboard. + {not in Vi} + +:redi[r] @"> Redirect messages to the unnamed register. For + backward compatibility, the ">" after the register + name can be omitted. {not in Vi} +:redi[r] @">> Append messages to the unnamed register. {not in Vi} + +:redi[r] => {var} Redirect messages to a variable. If the variable + doesn't exist, then it is created. If the variable + exists, then it is initialized to an empty string. + The variable will remain empty until redirection ends. + Only string variables can be used. After the + redirection starts, if the variable is removed or + locked or the variable type is changed, then further + command output messages will cause errors. {not in Vi} + +:redi[r] =>> {var} Append messages to an existing variable. Only string + variables can be used. {not in Vi} + +:redi[r] END End redirecting messages. {not in Vi} + + *:sil* *:silent* +:sil[ent][!] {command} Execute {command} silently. Normal messages will not + be given or added to the message history. + When [!] is added, error messages will also be + skipped, and commands and mappings will not be aborted + when an error is detected. |v:errmsg| is still set. + When [!] is not used, an error message will cause + further messages to be displayed normally. + Redirection, started with |:redir|, will continue as + usual, although there might be small differences. + This will allow redirecting the output of a command + without seeing it on the screen. Example: > + :redir >/tmp/foobar + :silent g/Aap/p + :redir END +< To execute a Normal mode command silently, use the + |:normal| command. For example, to search for a + string without messages: > + :silent exe "normal /path\<CR>" +< ":silent!" is useful to execute a command that may + fail, but the failure is to be ignored. Example: > + :let v:errmsg = "" + :silent! /^begin + :if v:errmsg != "" + : ... pattern was not found +< ":silent" will also avoid the hit-enter prompt. When + using this for an external command, this may cause the + screen to be messed up. Use |CTRL-L| to clean it up + then. + ":silent menu ..." defines a menu that will not echo a + Command-line command. The command will still produce + messages though. Use ":silent" in the command itself + to avoid that: ":silent menu .... :silent command". + + *:uns* *:unsilent* +:uns[ilent] {command} Execute {command} not silently. Only makes a + difference when |:silent| was used to get to this + command. + Use this for giving a message even when |:silent| was + used. In this example |:silent| is used to avoid the + message about reading the file and |:unsilent| to be + able to list the first line of each file. > + :silent argdo unsilent echo expand('%') . ": " . getline(1) +< + + *:verb* *:verbose* +:[count]verb[ose] {command} + Execute {command} with 'verbose' set to [count]. If + [count] is omitted one is used. ":0verbose" can be + used to set 'verbose' to zero. + The additional use of ":silent" makes messages + generated but not displayed. + The combination of ":silent" and ":verbose" can be + used to generate messages and check them with + |v:statusmsg| and friends. For example: > + :let v:statusmsg = "" + :silent verbose runtime foobar.vim + :if v:statusmsg != "" + : " foobar.vim could not be found + :endif +< When concatenating another command, the ":verbose" + only applies to the first one: > + :4verbose set verbose | set verbose +< verbose=4 ~ + verbose=0 ~ + For logging verbose messages in a file use the + 'verbosefile' option. + + *:verbose-cmd* +When 'verbose' is non-zero, listing the value of a Vim option or a key map or +an abbreviation or a user-defined function or a command or a highlight group +or an autocommand will also display where it was last defined. If it was +defined manually then there will be no "Last set" message. When it was +defined while executing a function, user command or autocommand, the script in +which it was defined is reported. +{not available when compiled without the |+eval| feature} + + *K* +K Run a program to lookup the keyword under the + cursor. The name of the program is given with the + 'keywordprg' (kp) option (default is "man"). The + keyword is formed of letters, numbers and the + characters in 'iskeyword'. The keyword under or + right of the cursor is used. The same can be done + with the command > + :!{program} {keyword} +< There is an example of a program to use in the tools + directory of Vim. It is called 'ref' and does a + simple spelling check. + Special cases: + - If 'keywordprg' is empty, the ":help" command is + used. It's a good idea to include more characters + in 'iskeyword' then, to be able to find more help. + - When 'keywordprg' is equal to "man", a count before + "K" is inserted after the "man" command and before + the keyword. For example, using "2K" while the + cursor is on "mkdir", results in: > + !man 2 mkdir +< - When 'keywordprg' is equal to "man -s", a count + before "K" is inserted after the "-s". If there is + no count, the "-s" is removed. + {not in Vi} + + *v_K* +{Visual}K Like "K", but use the visually highlighted text for + the keyword. Only works when the highlighted text is + not more than one line. {not in Vi} + +[N]gs *gs* *:sl* *:sleep* +:[N]sl[eep] [N] [m] Do nothing for [N] seconds. When [m] is included, + sleep for [N] milliseconds. The count for "gs" always + uses seconds. The default is one second. > + :sleep "sleep for one second + :5sleep "sleep for five seconds + :sleep 100m "sleep for a hundred milliseconds + 10gs "sleep for ten seconds +< Can be interrupted with CTRL-C (CTRL-Break on MS-DOS). + "gs" stands for "goto sleep". + While sleeping the cursor is positioned in the text, + if at a visible position. {not in Vi} + + *g_CTRL-A* +g CTRL-A Only when Vim was compiled with MEM_PROFILING defined + (which is very rare): print memory usage statistics. + Only useful for debugging Vim. + +============================================================================== +3. Using Vim like less or more *less* + +If you use the less or more program to view a file, you don't get syntax +highlighting. Thus you would like to use Vim instead. You can do this by +using the shell script "$VIMRUNTIME/macros/less.sh". + +This shell script uses the Vim script "$VIMRUNTIME/macros/less.vim". It sets +up mappings to simulate the commands that less supports. Otherwise, you can +still use the Vim commands. + +This isn't perfect. For example, when viewing a short file Vim will still use +the whole screen. But it works good enough for most uses, and you get syntax +highlighting. + +The "h" key will give you a short overview of the available commands. + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/version4.txt b/share/vim/vim73/doc/version4.txt new file mode 100644 index 0000000000..c652398ca1 --- /dev/null +++ b/share/vim/vim73/doc/version4.txt @@ -0,0 +1,355 @@ +*version4.txt* For Vim version 7.3. Last change: 2006 Apr 24 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + +This document lists the incompatible differences between Vim 3.0 and Vim 4.0. +Although 4.0 is mentioned here, this is also for version 4.1, 4.2, etc.. + +This file is important for everybody upgrading from Vim 3.0. Read it +carefully to avoid unexpected problems. + +'backup' option default changed |backup-changed| +Extension for backup file changed |backup-extension| +Structure of swap file changed |swapfile-changed| +"-w scriptout" argument changed |scriptout-changed| +Backspace and Delete keys |backspace-delete| +Escape for | changed |escape-bar| +Key codes changed |key-codes-changed| +Terminal options changed |termcap-changed| +'errorformat' option changed |errorformat-changed| +'graphic' option gone |graphic-option-gone| +'yankendofline' option gone |ye-option-gone| +'icon' and 'title' default value changed |icon-changed| +'highlight' option changed |highlight-changed| +'tildeop' and 'weirdinvert' short names changed |short-name-changed| +Use of "v", "V" and "CTRL-V" in Visual mode |use-visual-cmds| +CTRL-B in Insert mode removed |toggle-revins| + + +'backup' option default changed *backup-changed* +------------------------------- + +The default value for 'backup' used to be on. This resulted in a backup file +being made when the original file was overwritten. + +Now the default for 'backup' is off. As soon as the writing of the file has +successfully finished, the backup file is deleted. If you want to keep the +backup file, set 'backup' on in your vimrc. The reason for this change is +that many people complained that leaving a backup file behind is not +Vi-compatible. |'backup'| + + +Extension for backup file changed *backup-extension* +--------------------------------- + +The extension for the backup file used to be ".bak". Since other programs +also use this extension and some users make copies with this extension, it was +changed to the less obvious "~". Another advantage is that this takes less +space, which is useful when working on a system with short file names. For +example, on MS-DOS the backup files for "longfile.c" and "longfile.h" would +both become "longfile.bak"; now they will be "longfile.c~" and "longfile.h~". + +If you prefer to use ".bak", you can set the 'backupext' option: > + :set bex=.bak + + +Structure of swap file changed *swapfile-changed* +------------------------------ + +The contents of the swap file were extended with several parameters. Vim +stores the user name and other information about the edited file to make +recovery more easy and to be able to know where the swap file comes from. The +first part of the swap file can now be understood on a machine with a +different byte order or sizeof(int). When you try to recover a file on such a +machine, you will get an error message that this is not possible. + +Because of this change, swap files cannot be exchanged between 3.0 and 4.0. +If you have a swap file from a crashed session with 3.0, use Vim 3.0 to +recover the file---don't use 4.0. |swap-file| + + +"-w scriptout" argument changed *scriptout-changed* +------------------------------- + +"vim -w scriptout" used to append to the scriptout file. Since this was +illogical, it now creates a new file. An existing file is not overwritten +(to avoid destroying an existing file for those who rely on the appending). +[This was removed again later] |-w| + + +Backspace and Delete keys *backspace-delete* +------------------------- + +In 3.0 both the delete key and the backspace key worked as a backspace in +insert mode; they deleted the character to the left of the cursor. In 4.0 the +delete key has a new function: it deletes the character under the cursor, just +like it does on the command-line. If the cursor is after the end of the line +and 'bs' is set, two lines are joined. |<Del>| |i_<Del>| + +In 3.0 the backspace key was always defined as CTRL-H and delete as CTRL-?. +In 4.0 the code for the backspace and delete key is obtained from termcap or +termlib, and adjusted for the "stty erase" value on Unix. This helps people +who define the erase character according to the keyboard they are working on. + |<BS>| |i_<BS>| + +If you prefer backspace and delete in Insert mode to have the old behavior, +put this line in your vimrc: + + inoremap ^? ^H + +And you may also want to add these, to fix the values for <BS> and <Del>: + + set t_kb=^H + set t_kD=^? + +(Enter ^H with CTRL-V CTRL-H and ^? with CTRL-V CTRL-? or <Del>.) + +If the value for t_kb is correct, but the t_kD value is not, use the ":fixdel" +command. It will set t_kD according to the value of t_kb. This is useful if +you are using several different terminals. |:fixdel| + +When ^H is not recognized as <BS> or <Del>, it is used like a backspace. + + +Escape for | changed *escape-bar* +-------------------- + +When the 'b' flag is present in 'cpoptions', the backslash cannot be used to +escape '|' in mapping and abbreviate commands, only CTRL-V can. This is +Vi-compatible. If you work in Vi-compatible mode and had used "\|" to include +a bar in a mapping, this needs to be replaced by "^V|". See |:bar|. + + +Key codes changed *key-codes-changed* +----------------- + +The internal representation of key codes has changed dramatically. In 3.0 a +one-byte code was used to represent a key. This caused problems with +different characters sets that also used these codes. In 4.0 a three-byte +code is used that cannot be confused with a character. |key-notation| + +If you have used the single-byte key codes in your vimrc for mappings, you +will have to replace them with the 4.0 codes. Instead of using the three-byte +code directly, you should use the symbolic representation for this in <>. See +the table below. The table also lists the old name, as it was used in the 3.0 +documentation. + +The key names in <> can be used in mappings directly. This makes it possible +to copy/paste examples or type them literally. The <> notation has been +introduced for this |<>|. The 'B' and '<' flags must not be present in +'cpoptions' to enable this to work |'cpoptions'|. + +old name new name old code old MS-DOS code ~ + hex dec hex dec ~ +<ESC> <Esc> +<TAB> <Tab> +<LF> <NL> <NewLine> <LineFeed> +<SPACE> <Space> +<NUL> <Nul> +<BELL> <Bell> +<BS> <BS> <BackSpace> +<INSERT> <Insert> +<DEL> <Del> <Delete> +<HOME> <Home> +<END> <End> +<PAGE_UP> <PageUp> +<PAGE_DOWN> <PageDown> + +<C_UP> <Up> 0x80 128 0xb0 176 +<C_DOWN> <Down> 0x81 129 0xb1 177 +<C_LEFT> <Left> 0x82 130 0xb2 178 +<C_RIGHT> <Right> 0x83 131 0xb3 179 +<SC_UP> <S-Up> 0x84 132 0xb4 180 +<SC_DOWN> <S-Down> 0x85 133 0xb5 181 +<SC_LEFT> <S-Left> 0x86 134 0xb6 182 +<SC_RIGHT> <S-Right> 0x87 135 0xb7 183 + +<F1> <F1> 0x88 136 0xb8 184 +<F2> <F2> 0x89 137 0xb9 185 +<F3> <F3> 0x8a 138 0xba 186 +<F4> <F4> 0x8b 139 0xbb 187 +<F5> <F5> 0x8c 140 0xbc 188 +<F6> <F6> 0x8d 141 0xbd 189 +<F7> <F7> 0x8e 142 0xbe 190 +<F8> <F8> 0x8f 143 0xbf 191 +<F9> <F9> 0x90 144 0xc0 192 +<F10> <F10> 0x91 145 0xc1 193 + +<SF1> <S-F1> 0x92 146 0xc2 194 +<SF2> <S-F2> 0x93 147 0xc3 195 +<SF3> <S-F3> 0x94 148 0xc4 196 +<SF4> <S-F4> 0x95 149 0xc5 197 +<SF5> <S-F5> 0x96 150 0xc6 198 +<SF6> <S-F6> 0x97 151 0xc7 199 +<SF7> <S-F7> 0x98 152 0xc8 200 +<SF8> <S-F8> 0x99 153 0xc9 201 +<SF9> <S-F9> 0x9a 154 0xca 202 +<SF10> <S-F10> 0x9b 155 0xcb 203 + +<HELP> <Help> 0x9c 156 0xcc 204 +<UNDO> <Undo> 0x9d 157 0xcd 205 + + (not used) 0x9e 158 0xce 206 + (not used) 0x9f 159 0xcf 207 + + +Terminal options changed *termcap-changed* +------------------------ + +The names of the terminal options have been changed to match the termcap names +of these options. All terminal options now have the name t_xx, where xx is +the termcap name. Normally these options are not used, unless you have a +termcap entry that is wrong or incomplete, or you have set the highlight +options to a different value. |terminal-options| + +Note that for some keys there is no termcap name. Use the <> type of name +instead, which is a good idea anyway. + +Note that "t_ti" has become "t_mr" (invert/reverse output) and "t_ts" has +become "t_ti" (init terminal mode). Be careful when you use "t_ti"! + +old name new name meaning ~ +t_cdl t_DL delete number of lines *t_cdl* +t_ci t_vi cursor invisible *t_ci* +t_cil t_AL insert number of lines *t_cil* +t_cm t_cm move cursor +t_cri t_RI cursor number of chars right *t_cri* +t_cv t_ve cursor visible *t_cv* +t_cvv t_vs cursor very visible *t_cvv* +t_dl t_dl delete line +t_cs t_cs scroll region +t_ed t_cl clear display *t_ed* +t_el t_ce clear line *t_el* +t_il t_al insert line *t_il* + t_da display may be retained above the screen + t_db display may be retained below the screen +t_ke t_ke put terminal out of keypad transmit mode +t_ks t_ks put terminal in keypad transmit mode +t_ms t_ms save to move cursor in highlight mode +t_se t_se normal mode (undo t_so) +t_so t_so shift out (standout) mode +t_ti t_mr reverse highlight +t_tb t_md bold mode *t_tb* +t_tp t_me highlight end *t_tp* +t_sr t_sr scroll reverse +t_te t_te out of termcap mode +t_ts t_ti into termcap mode *t_ts_old* +t_vb t_vb visual bell +t_csc t_CS cursor is relative to scroll region *t_csc* + +t_ku t_ku <Up> arrow up +t_kd t_kd <Down> arrow down +t_kr t_kr <Right> arrow right +t_kl t_kl <Left> arrow left +t_sku <S-Up> shifted arrow up *t_sku* +t_skd <S-Down> shifted arrow down *t_skd* +t_skr t_%i <S-Right> shifted arrow right *t_skr* +t_skl t_#4 <S-Left> shifted arrow left *t_skl* +t_f1 t_k1 <F1> function key 1 *t_f1* +t_f2 t_k2 <F2> function key 2 *t_f2* +t_f3 t_k3 <F3> function key 3 *t_f3* +t_f4 t_k4 <F4> function key 4 *t_f4* +t_f5 t_k5 <F5> function key 5 *t_f5* +t_f6 t_k6 <F6> function key 6 *t_f6* +t_f7 t_k7 <F7> function key 7 *t_f7* +t_f8 t_k8 <F8> function key 8 *t_f8* +t_f9 t_k9 <F9> function key 9 *t_f9* +t_f10 t_k; <F10> function key 10 *t_f10* +t_sf1 <S-F1> shifted function key 1 *t_sf1* +t_sf2 <S-F2> shifted function key 2 *t_sf2* +t_sf3 <S-F3> shifted function key 3 *t_sf3* +t_sf4 <S-F4> shifted function key 4 *t_sf4* +t_sf5 <S-F5> shifted function key 5 *t_sf5* +t_sf6 <S-F6> shifted function key 6 *t_sf6* +t_sf7 <S-F7> shifted function key 7 *t_sf7* +t_sf8 <S-F8> shifted function key 8 *t_sf8* +t_sf9 <S-F9> shifted function key 9 *t_sf9* +t_sf10 <S-F10> shifted function key 10 *t_sf10* +t_help t_%1 <Help> help key *t_help* +t_undo t_&8 <Undo> undo key *t_undo* + + +'errorformat' option changed *errorformat-changed* +---------------------------- + +'errorformat' can now contain several formats, separated by commas. The first +format that matches is used. The default values have been adjusted to catch +the most common formats. |errorformat| + +If you have a format that contains a comma, it needs to be preceded with a +backslash. Type two backslashes, because the ":set" command will eat one. + + +'graphic' option gone *graphic-option-gone* +--------------------- + +The 'graphic' option was used to make the characters between <~> and 0xa0 +display directly on the screen. Now the 'isprint' option takes care of this +with many more possibilities. The default setting is the same; you only need +to look into this if you previously set the 'graphic' option in your vimrc. + |'isprint'| + + +'yankendofline' option gone *ye-option-gone* +--------------------------- + +The 'yankendofline' option has been removed. Instead you can just use + :map Y y$ + + +'icon' and 'title' default value changed *icon-changed* +---------------------------------------- + +The 'title' option is now only set by default if the original title can be +restored. Avoids "Thanks for flying Vim" titles. If you want them anyway, +put ":set title" in your vimrc. |'title'| + +The default for 'icon' now depends on the possibility of restoring the +original value, just like 'title'. If you don't like your icon titles to be +changed, add this line to your vimrc: |'icon'| + :set noicon + + +'highlight' option changed *highlight-changed* +-------------------------- + +The 'i' flag now means italic highlighting, instead of invert. The 'r' flag +is used for reverse highlighting, which is what 'i' used to be. Normally you +won't see the difference, because italic mode is not supported on most +terminals and reverse mode is used as a fallback. |'highlight'| + +When an occasion is not present in 'highlight', use the mode from the default +value for 'highlight', instead of reverse mode. + + +'tildeop' and 'weirdinvert' short names changed *short-name-changed* +----------------------------------------------- + +Renamed 'to' (abbreviation for 'tildeop') to 'top'. |'tildeop'| +Renamed 'wi' (abbreviation for 'weirdinvert') to 'wiv'. |'weirdinvert'| + +This was done because Vi uses 'wi' as the short name for 'window' and 'to' as +the short name for 'timeout'. This means that if you try setting these +options, you won't get an error message, but the effect will be different. + + +Use of "v", "V" and "CTRL-V" in Visual mode *use-visual-cmds* +------------------------------------------- + +In Visual mode, "v", "V", and "CTRL-V" used to end Visual mode. Now this +happens only if the Visual mode was in the corresponding type. Otherwise the +type of Visual mode is changed. Now only ESC can be used in all circumstances +to end Visual mode without doing anything. |v_V| + + +CTRL-B in Insert mode removed *toggle-revins* +----------------------------- + +CTRL-B in Insert mode used to toggle the 'revins' option. If you don't know +this and accidentally hit CTRL-B, it is very difficult to find out how to undo +it. Since hardly anybody uses this feature, it is disabled by default. If +you want to use it, define RIGHTLEFT in feature.h before compiling. |'revins'| + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/version5.txt b/share/vim/vim73/doc/version5.txt new file mode 100644 index 0000000000..868d129049 --- /dev/null +++ b/share/vim/vim73/doc/version5.txt @@ -0,0 +1,7813 @@ +*version5.txt* For Vim version 7.3. Last change: 2008 Dec 17 + + + VIM REFERENCE MANUAL by Bram Moolenaar + +Welcome to Vim Version 5.0! + +This document lists the differences between Vim 4.x and Vim 5.0. +Although 5.0 is mentioned here, this is also for version 5.1, 5.2, etc.. +See |vi_diff.txt| for an overview of differences between Vi and Vim 5.0. +See |version4.txt| for differences between Vim 3.0 and Vim 4.0. + +INCOMPATIBLE: |incompatible-5| + +Default value for 'compatible' changed |cp-default| +Text formatting command "Q" changed |Q-command-changed| +Command-line arguments changed |cmdline-changed| +Autocommands are kept |autocmds-kept| +Use of 'hidden' changed |hidden-changed| +Text object commands changed |text-objects-changed| +X-Windows Resources removed |x-resources| +Use of $VIM |$VIM-use| +Use of $HOME for MS-DOS and Win32 |$HOME-use| +Tags file format changed |tags-file-changed| +Options changed |options-changed| +CTRL-B in Insert mode gone |i_CTRL-B-gone| + +NEW FEATURES: |new-5| + +Syntax highlighting |new-highlighting| +Built-in script language |new-script| +Perl and Python support |new-perl-python| +Win32 GUI version |added-win32-GUI| +VMS version |added-VMS| +BeOS version |added-BeOS| +Macintosh GUI version |added-Mac| +More Vi compatible |more-compatible| +Read input from stdin |read-stdin| +Regular expression patterns |added-regexp| +Overloaded tags |tag-overloaded| +New commands |new-commands| +New options |added-options| +New command-line arguments |added-cmdline-args| +Various additions |added-various| + +IMPROVEMENTS |improvements-5| + +COMPILE TIME CHANGES |compile-changes-5| + +BUG FIXES |bug-fixes-5| + +VERSION 5.1 |version-5.1| +Changed |changed-5.1| +Added |added-5.1| +Fixed |fixed-5.1| + +VERSION 5.2 |version-5.2| +Long lines editable |long-lines| +File browser added |file-browser-5.2| +Dialogs added |dialogs-added| +Popup menu added |popup-menu-added| +Select mode added |new-Select-mode| +Session files added |new-session-files| +User defined functions and commands |new-user-defined| +New interfaces |interfaces-5.2| +New ports |ports-5.2| +Multi-byte support |new-multi-byte| +New functions |new-functions-5.2| +New options |new-options-5.2| +New Ex commands |new-ex-commands-5.2| +Changed |changed-5.2| +Added |added-5.2| +Fixed |fixed-5.2| + +VERSION 5.3 |version-5.3| +Changed |changed-5.3| +Added |added-5.3| +Fixed |fixed-5.3| + +VERSION 5.4 |version-5.4| +Runtime directory introduced |new-runtime-dir| +Filetype introduced |new-filetype-5.4| +Vim script line continuation |new-line-continuation| +Improved session files |improved-sessions| +Autocommands improved |improved-autocmds-5.4| +Encryption |new-encryption| +GTK GUI port |new-GTK-GUI| +Menu changes |menu-changes-5.4| +Viminfo improved |improved-viminfo| +Various new commands |new-commands-5.4| +Various new options |new-options-5.4| +Vim scripts |new-script-5.4| +Avoid hit-enter prompt |avoid-hit-enter| +Improved quickfix |improved-quickfix| +Regular expressions |regexp-changes-5.4| +Changed |changed-5.4| +Added |added-5.4| +Fixed |fixed-5.4| + +VERSION 5.5 |version-5.5| +Changed |changed-5.5| +Added |added-5.5| +Fixed |fixed-5.5| + +VERSION 5.6 |version-5.6| +Changed |changed-5.6| +Added |added-5.6| +Fixed |fixed-5.6| + +VERSION 5.7 |version-5.7| +Changed |changed-5.7| +Added |added-5.7| +Fixed |fixed-5.7| + +VERSION 5.8 |version-5.8| +Changed |changed-5.8| +Added |added-5.8| +Fixed |fixed-5.8| + +============================================================================== + INCOMPATIBLE *incompatible-5* + +Default value for 'compatible' changed *cp-default* +-------------------------------------- + +Vim version 5.0 tries to be more Vi compatible. This helps people who use Vim +as a drop-in replacement for Vi, but causes some things to be incompatible +with version 4.x. + +In version 4.x the default value for the 'compatible' option was off. Now the +default is on. The first thing you will notice is that the "u" command undoes +itself. Other side effects will be that mappings may work differently or not +work at all. + +Since a lot of people switching from Vim 4.x to 5.0 will find this annoying, +the 'compatible' option is switched off if Vim finds a vimrc file. This is a +bit of magic to make sure that 90% of the Vim users will not be bitten by +this change. + +What does this mean? +- If you prefer to run in 'compatible' mode and don't have a vimrc file, you + don't have to do anything. +- If you prefer to run in 'nocompatible' mode and do have a vimrc file, you + don't have to do anything. +- If you prefer to run in 'compatible' mode and do have a vimrc file, you + should put this line first in your vimrc file: > + :set compatible +- If you prefer to run in 'nocompatible' mode and don't have a vimrc file, + you can do one of the following: + - Create an empty vimrc file (e.g.: "~/.vimrc" for Unix). + - Put this command in your .exrc file or $EXINIT: > + :set nocompatible +< - Start Vim with the "-N" argument. + +If you are new to Vi and Vim, using 'nocompatible' is strongly recommended, +because Vi has a lot of unexpected side effects, which are avoided by this +setting. See 'compatible'. + +If you like some things from 'compatible' and some not, you can tune the +compatibility with 'cpoptions'. + +When you invoke Vim as "ex" or "gex", Vim always starts in compatible mode. + + +Text formatting command "Q" changed *Q-command-changed* +----------------------------------- + +The "Q" command formerly formatted lines to the width the 'textwidth' option +specifies. The command for this is now "gq" (see |gq| for more info). The +reason for this change is that "Q" is the standard Vi command to enter "Ex" +mode, and Vim now does in fact have an "Ex" mode (see |Q| for more info). + +If you still want to use "Q" for formatting, use this mapping: > + :noremap Q gq +And if you also want to use the functionality of "Q": > + :noremap gQ Q + + +Command-line arguments changed *cmdline-changed* +------------------------------ + +Command-line file-arguments and option-arguments can now be mixed. You can +give options after the file names. Example: > + vim main.c -g + +This is not possible when editing a file that starts with a '-'. Use the "--" +argument then |---|: > + vim -g -- -main.c + +"-v" now means to start Ex in Vi mode, use "-R" for read-only mode. +old: "vim -v file" |-v| +new: "vim -R file" |-R| + +"-e" now means to start Vi in Ex mode, use "-q" for quickfix. +old: "vim -e errorfile" |-e| +new: "vim -q errorfile" |-q| + +"-s" in Ex mode now means to run in silent (batch) mode. |-s-ex| + +"-x" reserved for crypt, use "-f" to avoid starting a new CLI (Amiga). +old: "vim -x file" |-x| +new: "vim -f file" |-f| + +Vim allows up to ten "+cmd" and "-c cmd" arguments. Previously Vim executed +only the last one. + +"-n" now overrides any setting for 'updatecount' in a vimrc file, but not in +a gvimrc file. + + +Autocommands are kept *autocmds-kept* +--------------------- + +Before version 5.0, autocommands with the same event, file name pattern, and +command could appear only once. This was fine for simple autocommands (like +setting option values), but for more complicated autocommands, where the same +command might appear twice, this restriction caused problems. Therefore +Vim stores all autocommands and keeps them in the order that they are defined. + +The most obvious side effect of this change is that when you source a vimrc +file twice, the autocommands in it will be defined twice. To avoid this, do +one of these: + +- Remove any autocommands that might potentially defined twice before + defining them. Example: > + :au! * *.ext + :au BufEnter *.ext ... + +- Put the autocommands inside an ":if" command. Example: > + if !exists("did_ext_autocmds") + let did_ext_autocmds = 1 + autocmd BufEnter *.ext ... + endif + +- Put your autocommands in a different autocommand group so you can remove + them before defining them |:augroup|: > + augroup uncompress + au! + au BufReadPost *.gz ... + augroup END + + +Use of 'hidden' changed *hidden-changed* +----------------------- + +In version 4.x, only some commands used the 'hidden' option. Now all commands +uses it whenever a buffer disappears from a window. + +Previously you could do ":buf xxx" in a changed buffer and that buffer would +then become hidden. Now you must set the 'hidden' option for this to work. + +The new behavior is simpler: whether Vim hides buffers no longer depends on +the specific command that you use. +- with 'hidden' not set, you never get hidden buffers. Exceptions are the + ":hide" and ":close!" commands and, in rare cases, where you would otherwise + lose changes to the buffer. +- With 'hidden' set, you almost never unload a buffer. Exceptions are the + ":bunload" or ":bdel" commands. + +":buffer" now supports a "!": abandon changes in current buffer. So do +":bnext", ":brewind", etc. + + +Text object commands changed *text-objects-changed* +---------------------------- + +Text object commands have new names. This allows more text objects and makes +characters available for other Visual mode commands. Since no more single +characters were available, text objects names now require two characters. +The first one is always 'i' or 'a'. + OLD NEW ~ + a aw a word |v_aw| + A aW a WORD |v_aW| + s as a sentence |v_as| + p ap a paragraph |v_ap| + S ab a () block |v_ab| + P aB a {} block |v_aB| + +There is another set of text objects that starts with "i", for "inner". These +select the same objects, but exclude white space. + + +X-Windows Resources removed *x-resources* +-------------------------- + +Vim no longer supports the following X resources: +- boldColor +- italicColor +- underlineColor +- cursorColor + +Vim now uses highlight groups to set colors. This avoids the confusion of +using a bold Font, which would imply a certain color. See |:highlight| and +|gui-resources|. + + +Use of $VIM *$VIM-use* +----------- + +Vim now uses the VIM environment variable to find all Vim system files. This +includes the global vimrc, gvimrc, and menu.vim files and all on-line help +and syntax files. See |$VIM|. Starting with version 5.4, |$VIMRUNTIME| can +also be used. +For Unix, Vim sets a default value for $VIM when doing "make install". +When $VIM is not set, its default value is the directory from 'helpfile', +excluding "/doc/help.txt". + + +Use of $HOME for MS-DOS and Win32 *$HOME-use* +--------------------------------- + +The MS-DOS and Win32 versions of Vim now first check $HOME when searching for +a vimrc or exrc file and for reading/storing the viminfo file. Previously Vim +used $VIM for these systems, but this causes trouble on a system with several +users. Now Vim uses $VIM only when $HOME is not set or the file is not found +in $HOME. See |_vimrc|. + + +Tags file format changed *tags-file-changed* +------------------------ + +Only tabs are allowed to separate fields in a tags file. This allows for +spaces in a file name and is still Vi compatible. In previous versions of +Vim, any white space was allowed to separate the fields. If you have a file +which doesn't use a single tab between fields, edit the tags file and execute +this command: > + :%s/\(\S*\)\s\+\(\S*\)\s\+\(.*\)/\1\t\2\t\3/ + + +Options changed *options-changed* +--------------- + +The default value of 'errorfile' has changed from "errors.vim" to "errors.err". +The reason is that only Vim scripts should have the ".vim" extensions. + +The ":make" command no longer uses the 'errorfile' option. This prevents the +output of the ":make" command from overwriting a manually saved error file. +":make" uses the 'makeef' option instead. This also allows for generating a +unique name, to prevent concurrently running ":make" commands from overwriting +each other's files. + +With 'insertmode' set, a few more things change: +- <Esc> in Normal mode goes to Insert mode. +- <Esc> in Insert mode doesn't leave Insert mode. +- When doing ":set im", go to Insert mode immediately. + +Vim considers a buffer to be changed when the 'fileformat' (formerly the +'textmode' option) is different from the buffer's initial format. + + +CTRL-B in Insert mode gone *i_CTRL-B-gone* +-------------------------- + +When Vim was compiled with the |+rightleft| feature, you could use CTRL-B to +toggle the 'revins' option. Unfortunately, some people hit the 'B' key +accidentally when trying to type CTRL-V or CTRL-N and then didn't know how to +undo this. Since toggling the 'revins' option can easily be done with the +mapping below, this use of the CTRL-B key is disabled. You can still use the +CTRL-_ key for this |i_CTRL-_|. > + :imap <C-B> <C-O>:set revins!<CR> + +============================================================================== + NEW FEATURES *new-5* + +Syntax highlighting *new-highlighting* +------------------- + +Vim now has a very flexible way to highlighting just about any type of file. +See |syntax|. Summary: > + :syntax on + +Colors and attributes can be set for the syntax highlighting, and also for +other highlighted items with the ':' flag in the 'highlight' option. All +highlighted items are assigned a highlight group which specifies their +highlighting. See |:highlight|. The default colors have been improved. + +You can use the "Normal" group to set the default fore/background colors for a +color terminal. For the GUI, you can use this group to specify the font, too. + +The "2html.vim" script can be used to convert any file that has syntax +highlighting to HTML. The colors will be exactly the same as how you see them +in Vim. With a HTML viewer you can also print the file with colors. + + +Built-in script language *new-script* +------------------------ + +A few extra commands and an expression evaluator enable you to write simple +but powerful scripts. Commands include ":if" and ":while". Expressions can +manipulate numbers and strings. You can use the '=' register to insert +directly the result of an expression. See |expression|. + + +Perl and Python support *new-perl-python* +----------------------- + +Vim can call Perl commands with ":perldo", ":perl", etc. See |perl|. +Patches made by Sven Verdoolaege and Matt Gerassimoff. + +Vim can call Python commands with ":python" and ":pyfile". See |python|. + +Both of these are only available when enabled at compile time. + + +Win32 GUI version *added-win32-GUI* +----------------- + +The GUI has been ported to MS Windows 95 and NT. All the features of the X11 +GUI are available to Windows users now. |gui-w32| +This also fixes problems with running the Win32 console version under Windows +95, where console support has always been bad. +There is also a version that supports OLE automation interface. |if_ole.txt| +Vim can be integrated with Microsoft Developer Studio using the VisVim DLL. +It is possible to produce a DLL version of gvim with Borland C++ (Aaron). + + +VMS version *added-VMS* +----------- + +Vim can now also be used on VMS systems. Port done by Henk Elbers. +This has not been tested much, but it should work. +Sorry, no documentation! + + +BeOS version *added-BeOS* +------------ + +Vim can be used on BeOS systems (including the BeBox). (Olaf Seibert) +See |os_beos.txt|. + + +Macintosh GUI version *added-Mac* +--------------------- + +Vim can now be used on the Macintosh. (Dany St-Amant) +It has not been tested much yet, be careful! +See |os_mac.txt|. + + +More Vi compatible *more-compatible* +------------------ + +There is now a real Ex mode. Started with the "Q" command, or by calling the +executable "ex" or "gex". |Ex-mode| + +Always allow multi-level undo, also in Vi compatible mode. When the 'u' flag +in 'cpoptions' is included, CTRL-R is used for repeating the undo or redo +(like "." in Nvi). + + +Read input from stdin *read-stdin* +--------------------- + +When using the "-" command-line argument, Vim reads its text input from stdin. +This can be used for putting Vim at the end of a pipe: > + grep "^a.*" *.c | vim - +See |--|. + + +Regular expression patterns *added-regexp* +--------------------------- + +Added specifying a range for the number of matches of an atom: "\{a,b}". |/\{| +Added the "shortest match" regexp "\{-}" (Webb). +Added "\s", matches a white character. Can replace "[ \t]". |/\s| +Added "\S", matches a non-white character. Can replace "[^ \t]". |/\S| + + +Overloaded tags *tag-overloaded* +--------------- + +When using a language like C++, there can be several tags for the same +tagname. Commands have been added to be able to jump to any of these +overloaded tags: +|:tselect| List matching tags, and jump to one of them. +|:stselect| Idem, and split window. +|g_CTRL-]| Do ":tselect" with the word under the cursor. + + After ":ta {tagname}" with multiple matches: +|:tnext| Go to next matching tag. +|:tprevious| Go to previous matching tag. +|:trewind| Go to first matching tag. +|:tlast| Go to last matching tag. + +The ":tag" command now also accepts wildcards. When doing command-line +completion on tags, case-insensitive matching is also available (at the end). + + +New commands *new-commands* +------------ + +|:amenu| Define menus for all modes, inserting a CTRL-O for Insert + mode, ESC for Visual and CTRL-C for Cmdline mode. "amenu" is + used for the default menus and the Syntax menu. + +|:augroup| Set group to be used for following autocommands. Allows the + grouping of autocommands to enable deletion of a specific + group. + +|:crewind| Go to first error. +|:clast| Go to last error. + +|:doautoall| Execute autocommands for all loaded buffers. + +|:echo| Echo its argument, which is an expression. Can be used to + display messages which include variables. + +|:execute| Execute its argument, which is an expression. Can be used to + built up an Ex command with anything. + +|:hide| Works like ":close". + +|:if| Conditional execution, for built-in script language. + +|:intro| Show introductory message. This is always executed when Vim + is started without file arguments. + +|:let| Assign a value to an internal variable. + +|:omap| Map only in operator-pending mode. Makes it possible to map + text-object commands. + +|:redir| Redirect output of messages to a file. + +|:update| Write when buffer has changed. + +|:while| While-loop for built-in script language. + +Visual mode: +|v_O| "O" in Visual block mode, moves the cursor to the other corner + horizontally. +|v_D| "D" in Visual block mode deletes till end of line. + +Insert mode: +|i_CTRL-]| Triggers abbreviation, without inserting any character. + + +New options *added-options* +----------- + +'background' Used for selecting highlight color defaults. Also used in + "syntax.vim" for selecting the syntax colors. Often set + automatically, depending on the terminal used. + +'complete' Specifies how Insert mode completion works. + +'eventignore' Makes it possible to ignore autocommands temporarily. + +'fileformat' Current file format. Replaces 'textmode'. +'fileformats' Possible file formats. Replaces 'textauto'. + New is that this also supports Macintosh format: A single <CR> + separates lines. + The default for 'fileformats' for MS-DOS, Win32 and OS/2 is + "dos,unix", also when 'compatible' set. Unix type files + didn't work anyway when 'fileformats' was empty. + +'guicursor' Set the cursor shape and blinking in various modes. + Default is to adjust the cursor for Insert and Replace mode, + and when an operator is pending. Blinking is default on. + +'fkmap' Farsi key mapping. + +'hlsearch' Highlight all matches with the last used search pattern. + +'hkmapp' Phonetic Hebrew mapping. (Ilya Dogolazky) + +'iconstring' Define the name of the icon, when not empty. (Version 5.2: the + string is used literally, a newline can be used to make two + lines.) + +'lazyredraw' Don't redraw the screen while executing macros, registers or + other not typed commands. + +'makeef' Errorfile to be used for ":make". "##" is replaced with a + unique number. Avoids that two Vim sessions overwrite each + others errorfile. The Unix default is "/tmp/vim##.err"; for + Amiga "t:vim##.Err, for others "vim##.err". + +'matchtime' 1/10s of a second to show a matching paren, when 'showmatch' + is set. Like Nvi. + +'mousehide' Hide mouse pointer in GUI when typing text. + +'nrformats' Defines what bases Vim will consider for numbers when using + the CTRL-A and CTRL-X commands. Default: "hex,octal". + +'shellxquote' Add extra quotes around the whole shell command, including + redirection. + +'softtabstop' Make typing behave like tabstop is set at this value, without + changing the value of 'tabstop'. Makes it more easy to keep + 'ts' at 8, while still getting four spaces for a <Tab>. + +'titlestring' String for the window title, when not empty. (Version 5.2: + this string is used literally, a newline can be used to make + two lines.) + +'verbose' Level of verbosity. Makes it possible to show which .vimrc, + .exrc, .viminfo files etc. are used for initializing. Also + to show autocommands that are being executed. Can also be set + by using the "-V" command-line argument. + + +New command-line arguments *added-cmdline-args* +-------------------------- + +|-U| Set the gvimrc file to be used. Like "-u" for the vimrc. + +|-V| Set the 'verbose' option. E.g. "vim -V10". + +|-N| Start in non-compatible mode. + +|-C| Start in compatible mode. + +|-Z| Start in restricted mode, disallow shell commands. Can also + be done by calling the executable "rvim". + +|-h| Show usage information and exit. + + +Various additions *added-various* +----------------- + +Added support for SNiFF+ connection (submitted by Toni Leherbauer). Vim can +be used as an editor for SNiFF. No documentation available... + +For producing a bug report, the bugreport.vim script has been included. +Can be used with ":so $VIMRUNTIME/bugreport.vim", which creates the file +"bugreport.txt" in the current directory. |bugs| + +Added range to ":normal" command. Now you can repeat the same command for +each line in the range. |:normal-range| + +Included support for the Farsi language (Shiran). Only when enabled at +compile time. See |farsi|. + +============================================================================== + IMPROVEMENTS *improvements-5* + +Performance: +- When 'showcmd' was set, mappings would execute much more slowly because the + output would be flushed very often. Helps a lot when executing the "life" + macros with 'showcmd' set. +- Included patches for binary searching in tags file (David O'Neill). + Can be disabled by resetting the 'tagbsearch' option. +- Don't update the ruler when repeating insert (slowed it down a lot). +- For Unix, file name expansion is now done internally instead of starting a + shell for it. +- Expand environment variables with expand_env(), instead of calling the + shell. Makes ":so $VIMRUNTIME/syntax/syntax.vim" a LOT faster. +- Reduced output for cursor positioning: Use CR-LF for moving to first few + columns in next few lines; Don't output CR twice when using termios. +- Optimized cursor positioning. Use CR, BS and NL when it's shorter than + absolute cursor positioning. +- Disable redrawing while repeating insert "1000ii<Esc>". +- Made "d$" or "D" for long lines a lot faster (delete all characters at once, + instead of one by one). +- Access option table by first letter, instead of searching from start. +- Made setting special highlighting attributes a lot faster by using + highlight_attr[], instead of searching in the 'highlight' string. +- Don't show the mode when redrawing is disabled. +- When setting an option, only redraw the screen when required. +- Improved performance of Ex commands by using a lookup table for the first + character. + +Options: +'cinoptions' Added 'g' flag, for C++ scope declarations. +'cpoptions' Added 'E' flag: Disallow yanking, deleting, etc. empty text + area. Default is to allow empty yanks. When 'E' is included, + "y$" in an empty line now is handled as an error (Vi + compatible). + Added 'j' flag: Only add two spaces for a join after a '.', + not after a '?' or '!'. + Added 'A' flag: don't give ATTENTION message. + Added 'L' flag: When not included, and 'list' is set, + 'textwidth' formatting works like 'list' is not set. + Added 'W' flag: Let ":w!" behave like Vi: don't overwrite + readonly files, or a file owned by someone else. +'highlight' Added '@' flag, for '@' characters after the last line on the + screen, and '$' at the end of the line when 'list' is set. + Added 'i' flag: Set highlighting for 'incsearch'. Default + uses "IncSearch" highlight group, which is linked to "Visual". + Disallow 'h' flag in 'highlight' (wasn't used anymore since + 3.0). +'guifont' Win32 GUI only: When set to "*" brings up a font requester. +'guipty' Default on, because so many people need it. +'path' Can contain wildcards, and "**" for searching a whole tree. +'shortmess' Added 'I' flag to avoid the intro message. +'viminfo' Added '%' flag: Store buffer list in viminfo file. + +- Increased defaults for 'maxmem' and 'maxmemtot' for Unix and Win32. Most + machines have much more RAM now that prices have dropped. +- Implemented ":set all&", set all options to their default value. |:set| + +Swap file: +- Don't create a swap file for a readonly file. Then create one on the first + change. Also create a swapfile when the amount of memory used is getting + too high. |swap-file| +- Make swap file "hidden", if possible. On Unix this is done by prepending a + dot to the swap file name. When long file names are used, the DJGPP and + Win32 versions also prepend a dot, in case a file on a mounted Unix file + system is edited. |:swapname| On MSDOS the hidden file attribute is NOT + set, because this causes problems with share.exe. +- 'updatecount' always defaults to non-zero, also for Vi compatible mode. + This means there is a swap file, which can be used for recovery. + +Tags: +- Included ctags 2.0 (Darren Hiebert). The syntax for static tags changed + from + {tag}:{fname} {fname} {command} + to + {tag} {fname} {command};" file: + Which is both faster to parse, shorter and Vi compatible. The old format is + also still accepted, unless disabled in src/feature.h (see OLD_STATIC_TAGS). + |tags-file-format| +- Completion of tags now also includes static tags for other files, at the + end. +- Included "shtags" from Stephen Riehm. +- When finding a matching tag, but the file doesn't exist, continue searching + for another match. Helps when using the same tags file (with links) for + different versions of source code. +- Give a tag with a global match in the current file a higher priority than a + global match in another file. + +Included xxd version V1.8 (Juergen Weigert). + +Autocommands: +- VimLeave autocommands are executed after writing the viminfo file, instead + of before. |VimLeave| +- Allow changing autocommands while executing them. This allows for + self-modifying autocommands. (idea from Goldberg) +- When using autocommands with two or more patterns, could not split + ":if/:endif" over two lines. Now all matching autocommands are executed in + one do_cmdline(). +- Autocommands no longer change the command repeated with ".". +- Search patterns are restored after executing autocommands. This avoids + that the 'hlsearch' highlighting is messed up by autocommands. +- When trying to execute an autocommand, also try matching the pattern with + the short file name. Helps when short file name is different from full + file name (expanded symbolic links). |autocmd-patterns| +- Made the output of ":autocmd" shorter and look better. +- Expand <sfile> in an ":autocmd" when it is defined. |<sfile>| +- Added "nested" flag to ":autocmd", allows nesting. |autocmd-nested| +- Added [group] argument to ":autocmd". Overrides the currently set group. + |autocmd-groups| +- new events: + |BufUnload| before a buffer is unloaded + |BufDelete| before a buffer is deleted from the buffer list + |FileChangedShell| when a file's modification time has changed after + executing a shell command + |User| user-defined autocommand +- When 'modified' was set by a BufRead* autocommand, it was reset again + afterwards. Now the ":set modified" is remembered. + +GUI: +- Improved GUI scrollbar handling when redrawing is slower than the scrollbar + events are generated. +- "vim -u NONE" now also stops loading the .gvimrc and other GUI inits. |-u| + Use "-U" to use another gvimrc file. |-U| +- Handle CTRL-C for external command, also for systems where "setsid()" is + supported. +- When starting the GUI, restrict the window size to the screen size. +- The default menus are read from $VIMRUNTIME/menu.vim. This allows for a + customized default menu. |menu.vim| +- Improved the default menus. Added File/Print, a Window menu, Syntax menu, + etc. +- Added priority to the ":menu" command. Now each menu can be put in a place + where you want it, independent of the order in which the menus are defined. + |menu-priority| + +Give a warning in the intro screen when running the Win32 console version on +Windows 95 because there are problems using this version under Windows 95. +|win32-problems| + +Added 'e' flag for ":substitute" command: Don't complain when not finding a +match (Campbell). |:s| + +When using search commands in a mapping, only the last one is kept in the +history. Avoids that the history is trashed by long mappings. + +Ignore characters after "ex", "view" and "gvim" when checking startup mode. +Allows the use of "gvim5" et. al. |gvim| "gview" starts the GUI in readonly +mode. |gview| + +When resizing windows, the cursor is kept in the same relative position, if +possible. (Webb) + +":all" and ":ball" no longer close and then open a window for the same buffer. +Avoids losing options, jumplist, and other info. + +"-f" command-line argument is now ignored if Vim was compiled without GUI. +|-f| + +In Visual block mode, the right mouse button picks up the nearest corner. + +Changed default mappings for DOS et al. Removed the DOS-specific mappings, +only use the Windows ones. Added Shift-Insert, Ctrl-Insert, Ctrl-Del and +Shift-Del. + +Changed the numbers in the output of ":jumps", so you can see where {count} +CTRL-O takes you. |:jumps| + +Using "~" for $HOME now works for all systems. |$HOME| + +Unix: Besides using CTRL-C, also use the INTR character from the tty settings. +Somebody has INTR set to DEL. + +Allow a <LF> in a ":help" command argument to end the help command, so another +command can follow. + +Doing "%" on a line that starts with " #if" didn't jump to matching "#else". +Don't recognize "#if", "#else" etc. for '%' when 'cpo' contains the '%' flag. +|%| + +Insert mode expansion with "CTRL-N", "CTRL-P" and "CTRL-X" improved +|ins-completion|: +- 'complete' option added. +- When 'nowrapscan' is set, and no match found, report the searched direction + in the error message. +- Repeating CTRL-X commands adds following words/lines after the match. +- When adding-expansions, accept single character matches. +- Made repeated CTRL-X CTRL-N not break undo, and "." repeats the whole + insertion. Also fixes not being able to backspace over a word that has been + inserted with CTRL-N. + +When copying characters in Insert mode from previous/next line, with CTRL-E or +CTRL-Y, 'textwidth' is no longer used. |i_CTRL-E| + +Commands that move in the arglist, like ":n" and ":rew", keep the old cursor +position of the file (this is mostly Vi compatible). + +Vim now remembers the '< and '> marks for each buffer. This fixes a problem +that a line-delete in one buffer invalidated the '< and '> marks in another +buffer. |'<| + +For MSDOS, Unix and OS/2: When $VIM not set, use the path from the executable. +When using the executable path for $VIM, remove "src/" when present. Should +make Vim find the docs and syntax files when it is run directly after +compiling. |$VIM| + +When quitting Visual mode with <Esc>, the cursor is put at start of the Visual +area (like after executing an operator). + +Win32 and Unix version: Removed 1100 character limit on external commands. + +Added possibility to include a space in a ":edit +command" argument, by +putting a backslash before it. |+cmd| + +After recovery, BufReadPost autocommands are applied. |:recover| + +Added color support for "os2ansi", OS/2 console. (Slootman) |os2ansi| + +Allow "%:p:h" when % is empty. |:_%| + +Included "<sfile>": file name from the ":source" command. |<sfile>| + +Added "<Bslash>" special character. Helps for avoiding multiple backslashes +in mappings and menus. + +In a help window, a double-click jumps to the tag under the cursor (like +CTRL-]). + +<C-Left> and <C-Right> now work like <S-Left> and <S-Right>, move a word +forward/backward (Windows compatible). |<C-Left>| + +Removed the requirement for a ":version" command in a .vimrc file. It wasn't +used for anything. You can use ":if" to handle differences between versions. +|:version| + +For MS-DOS, Win32 and OS/2: When comparing file names for autocommands, don't +make a difference between '/' and '\' for path separator. + +New termcap options: +"mb": blink. Can only be used by assigning it to one of the other highlight + options. |t_mb| +"bc": backspace character. |t_bc| +"nd": Used for moving the cursor right in the GUI, to avoid removing one line + of pixels from the last bold character. |t_nd| +"xs": highlighting not erased by overwriting, for hpterm. Combined with + 'weirdinvert'. Visual mode works on hpterm now. |t_xs| + +Unix: Set time of patch and backup file same as original file. (Hiebert). + +Amiga: In QuickFix mode no longer opens another window. Shell commands can be +used now. + +Added decmouse patches from David Binette. Can now use Dec and Netterm mouse. +But only when enabled at compile time. + +Added '#' register: Alternate file name |quote#|. Display '#' register with +":dis" command. |:display| + +Removed ':' from 'isfname' default for Unix. Check for "://" in a file name +anyway. Also check for ":\\", for MS-DOS. + +Added count to "K"eyword command, when 'keywordprg' is "man", is inserted in +the man command. "2K" results in "!man 2 <cword>". |K| + +When using "gf" on a relative path name, remove "../" from the file name, like +it's done for file names in the tags file. |gf| + +When finishing recording, don't make the recorded register the default put +register. + +When using "!!", don't put ":5,5!" on the command-line, but ":.!". And some +other enhancements to replace the line number with "." or "$" when possible. + +MSDOS et al.: Renamed $VIM/viminfo to $VIM/_viminfo. It's more consistent: +.vimrc/_vimrc and .viminfo/_viminfo + +For systems where case doesn't matter in file names (MSDOS, Amiga), ignore +case while sorting file names. For buffer names too. + +When reading from stdin doesn't work, read from stderr (helps for "foo | xargs +vim"). + +32 bit MS-DOS version: Replaced csdpmi3 by csdpmi4. + +Changed <C-Left> and <C-Right> to skip a WORD instead of a word. + +Warning for changed modified time when overwriting a file now also works on +other systems than Unix. + +Unix: Changed the defaults for configure to be the same as the defaults for +Makefile: include GUI, Perl, and Python. + +Some versions of Motif require "-lXpm". Added check for this in configure. + +Don't add "-L/usr/lib" to the link line, causes problems on a few systems. + +============================================================================== + COMPILE TIME CHANGES *compile-changes-5* + +When compiling, allow a choice for minimal, normal or maximal features in an +easy way, by changing a single line in src/feature.h. +The DOS16 version has been compiled with minimal features to avoid running +out of memory too quickly. |dos16| +The Win32, DJGPP, and OS/2 versions use maximal features, because they have +enough memory. +The Amiga version is available with normal and maximal features. + +Added "make test" to Unix version Makefile. Allows for a quick check if most +"normal" commands work properly. Also tests a few specific commands. + +Added setlocale() with codepage support for DJGPP version. + +autoconf: +- Added autoconf check for -lXdmcp. +- Included check for -lXmu, no longer needed to edit the Makefile for this. +- Switched to autoconf 2.12. +- Added configure check for <poll.h>. Seems to be needed when including + Perl on Linux? +- termlib is now checked before termcap. +- Added configure check for strncasecmp(), stricmp() and strnicmp(). Added + vim_stricmp() for when there's no library function for stricmp(). +- Use "datadir" in configure, instead of our own check for HELPDIR. + +Removed "make proto" from Makefile.manx. Could not make it work without a lot +of #ifdefs. + +Removed "proto/" from paths in proto.h. Needed for the Mac port. + +Drastically changed Makefile.mint. Now it includes the Unix Makefile. + +Added support for Dos16 in Makefile.b32 (renamed Makefile.b32 to Makefile.bor) + +All source files are now edited with a tabstop of 8 instead of 4, which is +better when debugging and using other tools. 'softtabstop' is set to 4, to +make editing easier. + +Unix: Added "link.sh" script, which removes a few unnecessary libraries from +the link command. + +Don't use HPUX digraphs by default, but only when HPUX_DIGRAPHS is defined. +|digraphs-default| + +============================================================================== + BUG FIXES *bug-fixes-5* + +Note: Some of these fixes may only apply to test versions which were + created after version 4.6, but before 5.0. + + +When doing ":bdel", try going to the next loaded buffer. Don't rewind to the +start of the buffer list. + +mch_isdir() for Unix returned TRUE for "" on some systems. + +Win32: 'shell' set to "mksnt/sh.exe" breaks ":!" commands. Don't use +backslashes in the temp file names. + +On linux, with a FAT file system, could get spurious "file xxx changed since +editing started" messages, because the time is rounded off to two seconds +unexpectedly. + +Crash in GUI, when selecting a word (double click) and then extend until an +empty line. + +For systems where isdigit() can't handle characters > 255, get_number() caused +a crash when moving the mouse during the prompt for recovery. + +In Insert mode, "CTRL-O P" left the cursor on the last inserted character. +Now the cursor is left after the last putted character. + +When quickfix found an error type other than 'e' or 'w', it was never printed. + +A setting for 'errorfile' in a .vimrc overruled the "-q errorfile" argument. + +Some systems create a file when generating a temp file name. Filtering would +then create a backup file for this, which was never deleted. Now no backup +file is made when filtering. + +simplify_filename() could remove a ".." after a link, resulting in the wrong +file name. Made simplify_filename also work for MSDOS. Don't use it for +Amiga, since it doesn't have "../". + +otherfile() was unreliable when using links. Could think that reading/writing +was for a different file, when it was the same. + +Pasting with mouse in Replace mode didn't replace anything. + +Window height computed wrong when resizing a window with an autocommand (could +cause a crash). + +":s!foo!bar!" wasn't possible (Vi compatible). + +do_bang() freed memory twice when called recursively, because of autocommands +(test11). Thanks to Electric Fence! + +"v$d" on an empty line didn't remove the "-- VISUAL --" mode message from the +command-line, and inverted the cursor. + +":mkexrc" didn't check for failure to open the file, causing a crash. +(Felderhoff). + +Win32 mch_write() wrote past fixed buffer, causing terminal keys no longer to +be recognized. Both console and GUI version. + +Athena GUI: Crash when removing a menu item. Now Vim doesn't crash, but the +reversing of the menu item is still wrong. + +Always reset 'list' option for the help window. + +When 'scrolloff' is non-zero, a 'showmatch' could cause the shown match to be +in the wrong line and the window to be scrolled (Acevedo). + +After ":set all&", 'lines' and 'ttytype' were still non-default, because the +defaults never got set. Now the defaults for 'lines' and 'columns' are set +after detecting the window size. 'term' and 'ttytype' defaults are set when +detecting the terminal type. + +For (most) non-Unix systems, don't add file names with illegal characters when +expanding. Fixes "cannot open swapfile" error when doing ":e *.burp", when +there is no match. + +In X11 GUI, drawing part of the cursor obscured the text. Now the text is +drawn over the cursor, like when it fills the block. (Seibert) + +when started with "-c cmd -q errfile", the cursor would be left in line 1. +Now a ":cc" is done after executing "cmd". + +":ilist" never ignored case, even when 'ignorecase' set. + +"vim -r file" for a readonly file, then making a change, got ATTENTION message +in insert mode, display mixed up until <Esc> typed. Also don't give ATTENTION +message after recovering a file. + +The abbreviation ":ab #i #include" could not be removed. + +CTRL-L completion (longest common match) on command-line didn't work properly +for case-insensitive systems (MS-DOS, Windows, etc.). (suggested by Richard +Kilgore). + +For terminals that can hide the cursor ("vi" termcap entry), resizing the +window caused the cursor to disappear. + +Using an invalid mark in an Ex address didn't abort the command. + +When 'smarttab' set, would use 'shiftround' when inserting a TAB after a +space. Now it always rounds to a tabstop. + +Set '[ and '] marks for ":copy", ":move", ":append", ":insert", ":substitute" +and ":change". (Acevedo). + +"d$" in an empty line still caused an error, even when 'E' is not in +'cpoptions'. + +Help files were stored in the viminfo buffer list without a path. + +GUI: Displaying cursor was not synchronized with other displaying. Caused +several display errors. For example, when the last two lines in the file +start with spaces, "dd" on the last line copied text to the (then) last line. + +Win32: Needed to type CTRL-SHIFT-- to get CTRL-_. + +GUI: Moving the cursor forwards over bold text would remove one column of bold +pixels. + +X11 GUI: When a bold character in the last column was scrolled up or down, one +column of pixels would not be copied. + +Using <BS> to move the cursor left can sometimes erase a character. Now use +"le" termcap entry for this. + +Keyword completion with regexp didn't work. e.g., for "b.*crat". + +Fixed: With CTRL-O that jumps to another file, cursor could end up just after +the line. + +Amiga: '$' was missing from character recognized as wildcards, causing $VIM +sometimes not to be expanded. + +":change" didn't adjust marks for deleted lines. + +":help [range]" didn't work. Also for [pattern], [count] and [quotex]. + +For 'cindent'ing, typing "class::method" doesn't align like a label when the +second ':' is typed. +When inserting a CR with 'cindent' set (and a bunch of other conditions) the +cursor went to a wrong location. +'cindent' was wrong for a line that ends in '}'. +'cindent' was wrong after "else {". + +While editing the cmdline in the GUI, could not use the mouse to select text +from the command-line itself. + +When deleting lines, marks in tag stack were only adjusted for the current +window, not for other windows on the same buffer. + +Tag guessing could find a function "some_func" instead of the "func" we were +looking for. + +Tags file name relative to the current file didn't work. + +":g/pat2/s//pat2/g", causing the number of subs to be reported, used to cause +a scroll up. Now you no longer have to hit <CR>. + +X11 GUI: Selecting text could cause a crash. + +32 bit DOS version: CTRL-C in external command killed Vim. When SHELL is set +to "sh.exe", external commands didn't work. Removed using of command.com, no +longer need to set 'shellquote'. + +Fixed crash when using ":g/pat/i". + +Fixed (potential) crash for X11 GUI, when using an X selection. Was giving a +pointer on the stack to a callback function, now it's static. + +Using "#" and "*" with an operator didn't work. E.g. "c#". + +Command-line expansion didn't work properly after ":*". (Acevedo) + +Setting 'weirdinvert' caused highlighting to be wrong in the GUI. + +":e +4 #" didn't work, because the "4" was in unallocated memory (could cause +a crash). + +Cursor position was wrong for ":e #", after ":e #" failed, because of changes +to the buffer. + +When doing ":buf N", going to a buffer that was edited with ":view", the +readonly flag was reset. Now make a difference between ":e file" and ":buf +file": Only set/reset 'ro' for the first one. + +Avoid |hit-enter| prompt when not able to write viminfo on exit. + +When giving error messages in the terminal where the GUI was started, GUI +escape codes would be written to the terminal. In an xterm this could be seen +as a '$' after the message. + +Mouse would not work directly after ":gui", because full_screen isn't set, +which causes starttermcap() not to do its work. + +'incsearch' did not scroll the window in the same way as the actual search. +When 'nowrap' set, incsearch didn't show a match when it was off the side of +the screen. Now it also shows the whole match, instead of just the cursor +position (if possible). + +":unmap", ":unab" and ":unmenu" did not accept a double quote, it was seen as +the start of a comment. Now it's Vi compatible. + +Using <Up><Left><Left><Up> in the command-line, when there is no previous +cmdline in the history, inserted a NUL on the command-line. + +"i<Esc>" when on a <Tab> in column 0 left the cursor in the wrong place. + +GUI Motif: When adding a lot of menu items, the menu bar goes into two rows. +Deleting menu items, reducing the number of rows, now also works. + +With ":g/pat/s//foo/c", a match in the first line was scrolled off of the +screen, so you could not see it. +When using ":s//c", with 'nowrap' set, a match could be off the side of the +screen, so you could not see it. + +When 'helpfile' was set to a fixed, non-absolute path in feature.h, Vim would +crash. mch_Fullname can now handle file names in read-only memory. (Lottem) + +When using CTRL-A or CTRL-@ in Insert mode, there could be strange effects +when using CTRL-D next. Also, when repeating inserted text that included "0 +CTRL-D" or "^ CTRL-D" this didn't work. (Acevedo) +Using CTRL-D after using CTRL-E or CTRL-Y in Insert mode that inserted a '0' +or '^', removed the '0' or '^' and more indent. + +The command "2".p" caused the last inserted text to be executed as commands. +(Acevedo) + +Repeating the insert of "CTRL-V 048" resulted in "^@" to be inserted. + +Repeating Insert completion could fail if there are special characters in the +text. (Acevedo) + +":normal /string<CR>" caused the window to scroll. Now all ":normal" commands +are executed without scrolling messages. + +Redo of CTRL-E or CTRL-Y in Insert mode interpreted special characters as +commands. + +Line wrapping for 'tw' was done one character off for insert expansion +inserts. + +buffer_exists() function didn't work properly for buffer names with a symbolic +link in them (e.g. when using buffer_exists(#)). + +Removed the "MOTIF_COMMENT" construction from Makefile. It now works with +FreeBSD make, and probably with NeXT make too. + +Matching the 'define' and 'include' arguments now honor the settings for +'ignorecase'. (Acevedo) + +When one file shown in two windows, Visual selection mixed up cursor position +in current window and other window. + +When doing ":e file" from a help file, the 'isk' option wasn't reset properly, +because of a modeline in the help file. + +When doing ":e!", a cursor in another window on the same buffer could become +invalid, leading to "ml_get: invalid lnum" errors. + +Matching buffer name for when expanded name has a different path from not +expanded name (Brugnara). + +Normal mappings didn't work after an operator. For example, with ":map Q gq", +"QQ" didn't work. + +When ":make" resulted in zero errors, a "No Errors" error message was given +(which breaks mappings). + +When ":sourcing" a file, line length was limited to 1024 characters. CTRL-V +before <EOL> was not handled Vi compatible. (Acevedo) + +Unexpected exit for X11 GUI, caused by SAVE_YOURSELF event. (Heimann) + +CTRL-X CTRL-I only found one match per line. (Acevedo) +When using an illegal CTRL-X key in Insert mode, the CTRL-X mode message +was stuck. + +Finally managed to ignore the "Quit" menu entry of the Window manager! Now +Vim only exists when there are no changed buffers. + +Trying to start the GUI when $DISPLAY is not set resulted in a crash. +When $DISPLAY is not set and gvim starts vim, title was restored to "Thanks +for flying Vim". +When $DISPLAY not set, starting "gvim" (dropping back to vim) and then +selecting text with the mouse caused a crash. + +"J", with 'joinspaces' set, on a line ending in ". ", caused one space too +many to be added. (Acevedo) + +In insert mode, a CTRL-R {regname} which didn't insert anything left the '"' +on the screen. + +":z10" didn't work. (Clapp) + +"Help "*" didn't work. + +Renamed a lot of functions, to avoid clashes with POSIX name space. + +When adding characters to a line, making it wrap, the following lines were +sometimes not shifted down (e.g. after a tag jump). + +CTRL-E, with 'so' set and cursor on last line, now does not move cursor as +long as the last line is on the screen. + +When there are two windows, doing "^W+^W-" in the bottom window could cause +the status line to be doubled (not redrawn correctly). + +This command would hang: ":n `cat`". Now connect stdin of the external +command to /dev/null, when expanding. + +Fixed lalloc(0,) error for ":echo %:e:r". (Acevedo) + +The "+command" argument to ":split" didn't work when there was no file name. + +When selecting text in the GUI, which is the output of a command-line command +or an external command, the inversion would sometimes remain. + +GUI: "-mh 70" argument was broken. Now, when menuheight is specified, it is +not changed anymore. + +GUI: When using the scrollbar or mouse while executing an external command, +this caused garbage characters. + +Showmatch sometimes jumped to the wrong position. Was caused by a call to +findmatch() when redrawing the display (when syntax highlighting is on). + +Search pattern "\(a *\)\{3} did not work correctly, also matched "a a". +Problem with brace_count not being decremented. + +Wildcard expansion added too many non-matching file names. + +When 'iskeyword' contains characters like '~', "*" and "#" didn't work +properly. (Acevedo) + +On Linux, on a FAT file system, modification time can change by one second. +Avoid a "file has changed" warning for a one second difference. + +When using the page-switching in an xterm, Vim would position the cursor on +the last line of the window on exit. Also removed the cursor positioning for +":!" commands. + +":g/pat/p" command (partly) overwrote the command. Now the output is on a +separate line. + +With 'ic' and 'scs' set, a search for "Keyword", ignore-case matches were +highlighted too. + +"^" on a line with only white space, put cursor beyond the end of the line. + +When deleting characters before where insertion started ('bs' == 2), could not +use abbreviations. + +CTRL-E at end of file puts cursor below the file, in Visual mode, when 'so' is +non-zero. CTRL-E didn't work when 'so' is big and the line below the window +wraps. CTRL-E, when 'so' is non-zero, at end of the file, caused jumping +up-down. + +":retab" didn't work well when 'list' is set. + +Amiga: When inserting characters at the last line on the screen, causing it +to wrap, messed up the display. It appears that a '\n' on the last line +doesn't always cause a scroll up. + +In Insert mode "0<C-D><C-D>" deleted an extra character, because Vim thought +that the "0" was still there. (Acevedo) + +"z{count}l" ignored the count. Also for "zh" et. al. (Acevedo) + +"S" when 'autoindent' is off didn't delete leading white space. + +"/<Tab>" landed on the wrong character when 'incsearch' is set. + +Asking a yes/no question could cause a |hit-enter| prompt. + +When the file consists of one long line (>4100 characters), making changes +caused various errors and a crash. + +DJGPP version could not save long lines (>64000) for undo. + +"yw" on the last char in the file didn't work. Also fixed "6x" at the end of +the line. "6X" at the start of a line fails, but does not break a mapping. In +general, a movement for an operator doesn't beep or flush a mapping, but when +there is nothing to operate on it beeps (this is Vi compatible). + +"m'" and "m`" now set the '' mark at the cursor position. + +Unix: Resetting of signals for external program didn't work, because SIG_DFL +and NULL are the same! For "!!yes|dd count=1|, the yes command kept on +running. + +Partly fixed: Unix GUI: Typeahead while executing an external command was lost. +Now it's not lost while the command is producing output. + +Typing <S-Tab> in Insert mode, when it isn't mapped, inserted "<S-Tab>". Now +it works like a normal <Tab>, just like <C-Tab> and <M-Tab>. + +Redrawing ruler didn't check for old value correctly (caused UMR warnings in +Purify). + +Negative array index in finish_viminfo_history(). + +":g/^/d|mo $" deleted all the lines. The ":move" command now removes the +:global mark from the moved lines. + +Using "vG" while the last line in the window is a "@" line, didn't update +correctly. Just the "v" showed "~" lines. + +"daw" on the last char of the file, when it's a space, moved the cursor beyond +the end of the line. + +When 'hlsearch' was set or reset, only the current buffer was redrawn, while +this affects all windows. + +CTRL-^, positioning the cursor somewhere from 1/2 to 1 1/2 screen down the +file, put the cursor at the bottom of the window, instead of halfway. + +When scrolling up for ":append" command, not all windows were updated +correctly. + +When 'hlsearch' is set, and an auto-indent is highlighted, pressing <Esc> +didn't remove the highlighting, although the indent was deleted. + +When 'ru' set and 'nosc', using "$j" showed a wrong ruler. + +Under Xfree 3.2, Shift-Tab didn't work (wrong keysym is used). + +Mapping <S-Tab> didn't work. Changed the key translations to use the shortest +key code possible. This makes the termcode translations and mappings more +consistent. Now all modifiers work in all combinations, not only with <Tab>, +but also with <Space>, <CR>, etc. + +For Unix, restore three more signals. And Vim catches SIGINT now, so CTRL-C +in Ex mode doesn't make Vim exit. + +""a5Y" yanked 25 lines instead of 5. + +"vrxxx<Esc>" in an empty line could not be undone. + +A CTRL-C that breaks ":make" caused the errorfile not to be read (annoying +when you want to handle what ":make" produced so far). + +":0;/pat" didn't find "pat" in line 1. + +Search for "/test/s+1" at first char of file gave bottom-top message, or +didn't work at all with 'nowrapscan'. + +Bug in viminfo history. Could cause a crash on exit. + +":print" didn't put cursor on first non-blank in line. + +":0r !cat </dev/null" left cursor in line zero, with very strange effects. + +With 'showcmd' set and 'timeoutlen' set to a few seconds, trick to position +the cursor leftwards didn't work. + +AIX stty settings were restored to cs5 instead of cs8 (Winn). + +File name completion didn't work for "zsh" versions that put spaces between +file names, instead of NULs. + +Changed "XawChain*" to "XtChain*", should work for more systems. + +Included quite a few fixes for rightleft mode (Lottem). + +Didn't ask to |hit-enter| when GUI is started and error messages are printed. + +When trying to edit a file in a non-existent directory, ended up with editing +"No file". + +"gqap" to format a paragraph did too much redrawing. + +When 'hlsearch' set, only the current window was updated for a new search +pattern. + +Sometimes error messages on startup didn't cause a |hit-enter| prompt, +because of autocommands containing an empty line. + +Was possible to select part of the window in the border, below the command +line. + +'< and '> marks were not at the correct position after linewise Visual +selection. + +When translating a help argument to "CTRL-x", prepend or append a '_', when +applicable. + +Blockwise visual mode wasn't correct when moving vertically over a special +character (displayed as two screen characters). + +Renamed "struct option" to "struct vimoption" to avoid name clash with GNU +getopt(). + +":abclear" didn't work (but ":iabclear" and ":cabclear" did work). + +When 'nowrap' used, screen wasn't always updated correctly. + +"vim -c split file" displayed extra lines. + +After starting the GUI, searched the termcap for a "gui" term. + +When 'hls' used, search for "^$" caused a hang. +When 'hls' was set, an error in the last regexp caused trouble. + +Unix: Only output an extra <EOL> on exit when outputted something in the +alternate screen, or when there is a message that needs to be cleared. + +"/a\{" did strange things, depending on previous search. + +"c}" only redrew one line (with -u NONE). + +For mappings, CTRL-META-A was shown as <M-^A> instead of <MC-A>, while :map +only accepts <MC-A>. Now <M-C-A> is shown. + +Unix: When using full path name in a tags file, which contains a link, and +'hidden' set and jumping to a tag in the current file, would get bogus +ATTENTION message. Solved by always expanding file names, even when starting +with '/'. + +'hlsearch' highlighting of special characters (e.g., a TAB) didn't highlight +the whole thing. + +"r<CR>" didn't work correctly on the last char of a line. + +Sometimes a window resize or other signal caused an endless loop, involving +set_winsize(). + +"vim -r" didn't work, it would just hang (using tgetent() while 'term' is +empty). + +"gk" while 'nowrap' set moved two lines up. + +When windows are split, a message that causes a scroll-up messed up one of the +windows, which required a CTRL-L to be typed. + +Possible endless loop when using shell command in the GUI. + +Menus defined in the .vimrc were removed when GUI started. + +Crash when pasting with the mouse in insert mode. + +Crash with ":unmenu *" in .gvimrc for Athena. + +"5>>" shifted 5 lines 5 times, instead of 1 time. + +CTRL-C when getting a prompt in ":global" didn't interrupt. + +When 'so' is non-zero, and moving the scrollbar completely to the bottom, +there was a lot of flashing. + +GUI: Scrollbar ident must be long for DEC Alpha. + +Some functions called vim_regcomp() without setting reg_magic, which could +lead to unpredictable magicness. + +Crash when clicking around the status line, could get a selection with a +backwards range. + +When deleting more than one line characterwise, the last character wasn't +deleted. + +GUI: Status line could be overwritten when moving the scrollbar quickly (or +when 'wd' is non-zero). + +An ESC at the end of a ":normal" command caused a wait for a terminal code to +finish. Now, a terminal code is not recognized when its start comes from a +mapping or ":normal" command. + +Included patches from Robert Webb for GUI. Layout of the windows is now done +inside Vim, instead of letting the layout manager do this. Makes Vim work +with Lesstif! + +UMR warning in set_expand_context(). + +Memory leak: b_winlnum list was never freed. + +Removed TIOCLSET/TIOCLGET code from os_unix.c. Was changing some of the +terminal settings, and looked like it wasn't doing anything good. (suggested +by Juergen Weigert). + +Ruler overwrote "is a directory" message. When starting up, and 'cmdheight' +set to > 1, first message could still be in the last line. + +Removed prototype for putenv() from proto.h, it's already in osdef2.h.in. + +In replace mode, when moving the cursor and then backspacing, wrong characters +were inserted. + +Win32 GUI was checking for a CTRL-C too often, making it slow. + +Removed mappings for MS-DOS that were already covered by commands. + +When visually selecting all lines in a file, cursor at last line, then "J". +Gave ml_get errors. Was a problem with scrolling down during redrawing. + +When doing a linewise operator, and then an operator with a mouse click, it +was also linewise, instead of characterwise. + +When 'list' is set, the column of the ruler was wrong. + +Spurious error message for "/\(b\+\)*". + +When visually selected many lines, message from ":w file" disappeared when +redrawing the screen. + +":set <M-b>=^[b", then insert "^[b", waited for another character. And then +inserted "<M-b>" instead of the real <M-b> character. Was trying to insert +K_SPECIAL x NUL. + +CTRL-W ] didn't use count to set window height. + +GUI: "-font" command-line argument didn't override 'guifont' setting from +.gvimrc. (Acevedo) + +GUI: clipboard wasn't used for "*y". And some more Win32/X11 differences +fixed for the clipboard (Webb). + +Jumping from one help file to another help file, with 'compatible' set, +removed the 'help' flag from the buffer. + +File-writable bit could be reset when using ":w!" for a readonly file. + +There was a wait for CTRL-O n in Insert mode, because the search pattern was +shown. +Reduced wait, to allow reading a message, from 10 to 3 seconds. It seemed +nothing was happening. + +":recover" found same swap file twice. + +GUI: "*yy only worked the second time (when pasting to an xterm)." + +DJGPP version (dos32): The system flags were cleared. + +Dos32 version: Underscores were sometimes replaced with y-umlaut (Levin). + +Version 4.1 of ncurses can't handle tputs("", ..). Avoid calling tputs() with +an empty string. + +<S-Tab> in the command-line worked like CTRL-P when no completion started yet. +Now it does completion, last match first. + +Unix: Could get annoying "can't write viminfo" message after doing "su". Now +the viminfo file is overwritten, and the user set back to the original one. + +":set term=builtin_gui" started the GUI in a wrong way. Now it's not +allowed anymore. But "vim -T gui" does start the GUI correctly now. + +GUI: Triple click after a line only put last char in selection, when it is a +single character word. + +When the window is bigger than the screen, the scrolling up of messages was +wrong (e.g. ":vers", ":hi"). Also when the bottom part of the window was +obscured by another window. + +When using a wrong option only an error message is printed, to avoid that the +usage information makes it scroll off the screen. + +When exiting because of not being able to read from stdin, didn't preserve the +swap files properly. + +Visual selecting all chars in more than one line, then hit "x" didn't leave an +empty line. For one line it did leave an empty line. + +Message for which autocommand is executing messed up file write message (for +FileWritePost event). + +"vim -h" included "-U" even when GUI is not available, and "-l" when lisp is +not available. + +Crash for ":he <C-A>" (command-line longer than screen). + +":s/this/that/gc", type "y" two times, then undo, did reset the modified +option, even though the file is still modified. + +Empty lines in a tags file caused a ":tag" to be aborted. + +When hitting 'q' at the more prompt for ":menu", still scrolled a few lines. + +In an xterm that uses the bold trick a single row of characters could remain +after an erased bold character. Now erase one extra char after the bold char, +like for the GUI. + +":pop!" didn't work. + +When the reading a buffer was interrupted, ":w" should not be able to +overwrite the file, ":w!" is required. + +":cf%" caused a crash. + +":gui longfilename", when forking is enabled, could leave part of the +longfilename at the shell prompt. + +============================================================================== +VERSION 5.1 *version-5.1* + +Improvements made between version 5.0 and 5.1. + +This was mostly a bug-fix release, not many new features. + + +Changed *changed-5.1* +------- + +The expand() function now separates file names with <NL> instead of a space. +This avoids problems for file names with embedded spaces. To get the old +result, use substitute(expand(foo), "\n", " ", "g"). + +For Insert-expanding dictionaries allow a backslash to be used for +wildchars. Allows expanding "ze\kra", when 'isk' includes a backslash. + +New icon for the Win32 GUI. + +":tag", ":tselect" etc. only use the argument as a regexp when it starts +with '/'. Avoids that ":tag xx~" gives an error message: "No previous sub. +regexp". Also, when the :tag argument contained wildcard characters, it was +not Vi compatible. +When using '/', the argument is taken literally too, with a higher priority, +so it's found before wildcard matches. +Only when the '/' is used are matches with different case found, even though +'ignorecase' isn't set. +Changed "g^]" to only do ":tselect" when there is more than on matching tag. + +Changed some of the default colors, because they were not very readable on a +dark background. + +A character offset to a search pattern can move the cursor to the next or +previous line. Also fixes that "/pattern/e+2" got stuck on "pattern" at the +end of a line. + +Double-clicks in the status line do no longer start Visual mode. Dragging a +status line no longer stops Visual mode. + +Perl interface: Buffers() and Windows() now use more logical arguments, like +they are used in the rest of Vim (Moore). + +Init '" mark to the first character of the first line. Makes it possible to +use '" in an autocommand without getting an error message. + + +Added *added-5.1* +----- + +"shell_error" internal variable: result of last shell command. + +":echohl" command: Set highlighting for ":echo". + +'S' flag in 'highlight' and StatusLineNC highlight group: highlighting for +status line of not-current window. Default is to use bold for current +window. + +Added buffer_name() and buffer_number() functions (Aaron). +Added flags argument "g" to substitute() function (Aaron). +Added winheight() function. + +Win32: When an external command starts with "start ", no console is opened +for it (Aaron). + +Win32 console: Use termcap codes for bold/reverse based on the current +console attributes. + +Configure check for "strip". (Napier) + +CTRL-R CTRL-R x in Insert mode: Insert the contents of a register literally, +instead of as typed. + +Made a few "No match" error messages more informative by adding the pattern +that didn't match. + +"make install" now also copies the macro files. + +tools/tcltags, a shell script to generate a tags file from a TCL file. + +"--with-tlib" setting for configure. Easy way to use termlib: "./configure +--with-tlib=termlib". + +'u' flag in 'cino' for setting the indent for contained () parts. + +When Win32 OLE version can't load the registered type library, ask the user +if he wants to register Vim now. (Erhardt) +Win32 with OLE: When registered automatically, exit Vim. +Included VisVim 1.1b, with a few enhancements and the new icon (Heiko +Erhardt). + +Added patch from Vince Negri for Win32s support. Needs to be compiled with +VC 4.1! + +Perl interface: Added $curbuf. Rationalized Buffers() and Windows(). +(Moore) Added "group" argument to Msg(). + +Included Perl files in DOS source archive. Changed Makefile.bor and +Makefile.w32 to support building a Win32 version with Perl included. + +Included new Makefile.w32 from Ken Scott. Now it's able to make all Win32 +versions, including OLE, Perl and Python. + +Added CTRL-W g ] and CTRL-W g ^]: split window and do g] or g^]. + +Added "g]" to always do ":tselect" for the ident under the cursor. +Added ":tjump" and ":stjump" commands. +Improved listing of ":tselect" when tag names are a bit long. + +Included patches for the Macintosh version. Also for Python interface. +(St-Amant) + +":buf foo" now also restores cursor column, when the buffer was used before. + +Adjusted the Makefile for different final destinations for the syntax files +and scripts (for Debian Linux). + +Amiga: $VIM can be used everywhere. When $VIM is not defined, "VIM:" is +used. This fixes that "VIM:" had to be assigned for the help files, and +$VIM set for the syntax files. Now either of these work. + +Some xterms send vt100 compatible function keys F1-F4. Since it's not +possible to detect this, recognize both type of keys and translate them to +<F1> - <F4>. + +Added "VimEnter" autocommand. Executed after loading all the startup stuff. + +BeOS version now also runs on Intel CPUs (Seibert). + + +Fixed *fixed-5.1* +----- + +":ts" changed position in the tag stack when cancelled with <CR>. +":ts" changed the cursor position for CTRL-T when cancelled with <CR>. +":tn" would always jump to the second match. Was using the wrong entry in +the tag stack. +Doing "tag foo", then ":tselect", overwrote the original cursor position in +the tag stack. + +"make install" changed the vim.1 manpage in a wrong way, causing "doc/doc" +to appear for the documentation files. + +When compiled with MAX_FEAT, xterm mouse handling failed. Was caused by DEC +mouse handling interfering. + +Was leaking memory when using selection in X11. + +CTRL-D halfway a command-line left some characters behind the first line(s) +of the listing. + +When expanding directories for ":set path=", put two extra backslashes +before a space in a directory name. + +When 'lisp' set, first line of a function would be indented. Now its indent +is set to zero. And use the indent of the first previous line that is at +the same () level. Added test33. + +"so<Esc>u" in an empty file didn't work. + +DOS: "seek error in swap file write" errors, when using DOS 6.2 share.exe, +because the swap file was made hidden. It's no longer hidden. + +":global" command would sometimes not execute on a matching line. Happened +when a data block is full in ml_replace(). + +For AIX use a tgetent buffer of 2048 bytes, instead of 1024. + +Win32 gvim now only sets the console size for external commands to 25x80 +on Windows 95, not on NT. + +Win32 console: Dead key could cause a crash, because of a missing "WINAPI" +(Deshpande). + +The right mouse button started Visual mode, even when 'mouse' is empty, and +in the command-line, a left click moved the cursor when 'mouse' is empty. +In Visual mode, 'n' in 'mouse' would be used instead of 'v'. + +A blinking cursor or focus change cleared a non-Visual selection. + +CTRL-Home and CTRL-End didn't work for MS-DOS versions. + +Could include NUL in 'iskeyword', causing a crash when doing insert mode +completion. + +Use _dos_commit() to flush the swap file to disk for MSDOS 16 bit version. + +In mappings, CTRL-H was replaced by the backspace key code. This caused +problems when it was used as text, e.g. ":map _U :%s/.^H//g<CR>". + +":set t_Co=0" was not handled like a normal term. Now it's translated into +":set t_Co=", which works. + +For ":syntax keyword" the "transparent" option did work, although not +mentioned in the help. But synID() returned wrong name. + +"gqG" in a file with one-word-per-line (e.g. a dictionary) was very slow and +not interruptible. + +"gq" operator inserted screen lines in the wrong situation. Now screen +lines are inserted or deleted when this speeds up displaying. + +cindent was wrong when an "if" contained "((". + +'r' flag in 'viminfo' was not used for '%'. Could get files in the buffer +list from removable media. + +Win32 GUI with OLE: if_ole_vc.mak could not be converted into a project. +Hand-edited to fix this... + +With 'nosol' set, doing "$kdw" below an empty line positioned the cursor at +the end of the line. + +Dos32 version changed "\dir\file" into "/dir/file", to work around a DJGPP +bug. That bug appears to have been fixed, therefore this translation has +been removed. + +"/^*" didn't work (find '*' in first column). + +"<afile>" was not always set for autocommands. E.g., for ":au BufEnter * +let &tags = expand("<afile>:p:h") . "/tags". + +In an xterm, the window may be a child of the outer xterm window. Use the +parent window when getting the title and icon names. (Smith) + +When starting with "gvim -bg black -fg white", the value of 'background' is +only set after reading the .gvimrc file. This causes a ":syntax on" to use +the wrong colors. Now allow using ":gui" to open the GUI window and set the +colors. Previously ":gui" in a gvimrc crashed Vim. + +tempname() returned the same name all the time, unless the file was actually +created. Now there are at least 26 different names. + +File name used for <afile> was sometimes full path, sometimes file name +relative to current directory. + +When 'background' was set after the GUI window was opened, it could change +colors that were set by the user in the .gvimrc file. Now it only changes +colors that have not been set by the user. + +Ignore special characters after a CSI in the GUI version. These could be +interpreted as special characters in a wrong way. (St-Amant) + +Memory leak in farsi code, when using search or ":s" command. +Farsi string reversing for a mapping was only done for new mappings. Now it +also works for replacing a mapping. + +Crash in Win32 when using a file name longer than _MAX_PATH. (Aaron) + +When BufDelete autocommands were executed, some things for the buffer were +already deleted (esp. Perl stuff). + +Perl interface: Buffer specific items were deleted too soon; fixes "screen +no longer exists" messages. (Moore) + +The Perl functions didn't set the 'modified' flag. + +link.sh did not return an error on exit, which may cause Vim to start +installing, even though there is no executable to install. (Riehm) + +Vi incompatibility: In Vi "." redoes the "y" command. Added the 'y' flag to +'cpoptions'. Only for 'compatible' mode. + +":echohl" defined a new group, when the argument was not an existing group. + +"syn on" and ":syn off" could move the cursor, if there is a hidden buffer +that is shorter that the current cursor position. + +The " mark was not set when doing ":b file". + +When a "nextgroup" is used with "skipwhite" in syntax highlighting, space at +the end of the line made the nextgroup also be found in the next line. + +":he g<CTRL-D>", then ":" and backspace to the start didn't redraw. + +X11 GUI: "gvim -rv" reversed the colors twice on Sun. Now Vim checks if the +result is really reverse video (background darker than foreground). + +"cat link.sh | vim -" didn't set syntax highlighting. + +Win32: Expanding "file.sw?" matched ".file.swp". This is an error of +FindnextFile() that we need to work around. (Kilgore) + +"gqgq" gave an "Invalid lnum" error on the last line. +Formatting with "gq" didn't format the first line after a change of comment +leader. + +There was no check for out-of-memory in win_alloc(). + +"vim -h" didn't mention "-register" and "-unregister" for the OLE version. + +Could not increase 'cmdheight' when the last window is only one line. Now +other windows are also made smaller, when necessary. + +Added a few {} to avoid "suggest braces around" warnings from gcc 2.8.x. +Changed return type of main() from void to int. (Nam) + +Using '~' twice in a substitute pattern caused a crash. + +"syn on" and ":syn off" could scroll the window, if there is a hidden buffer +that is shorter that the current cursor position. + +":if 0 | if 1 | endif | endif" didn't work. Same for ":while" and "elseif". + +With two windows on modified files, with 'autowrite' set, cursor in second +window, ":qa" gave a warning for the file in the first window, but then +auto-wrote the file in the second window. (Webb) + +Win32 GUI scrollbar could only handle 32767 lines. Also makes the +intellimouse wheel use the configurable number of scrolls. (Robinson) + +When using 'patchmode', and the backup file is on another partition, the file +copying messed up the write-file message. + +GUI X11: Alt-Backspace and Alt-Delete didn't work. + +"`0" could put the cursor after the last character in the line, causing +trouble for other commands, like "i". + +When completing tags in insert mode with ^X^], some matches were skipped, +because the compare with other tags was wrong. E.g., when "mnuFileSave" was +already there, "mnuFile" would be skipped. (Negri) + +When scrolling up/down, a syntax item with "keepend" didn't work properly. +Now the flags are also stored for the syntax state at the start of each line. + +When 'ic' was changed while 'hlsearch' is on, there was no redraw to show the +effect. + +Win32 GUI: Don't display "No write since last chance" in a message box, but in +the Vim window. + +============================================================================== +VERSION 5.2 *version-5.2* + +Improvements made between version 5.1 and 5.2. + + +Long lines editable *long-lines* +------------------- + +A single long line that doesn't fit in the window doesn't show a line of @@@ +anymore. Redrawing starts at a character further on in the line, such that +the text around the cursor can be seen. This makes it possible to edit these +long lines when wrapping is on. + + +File browser added *file-browser-5.2* +------------------ + +The Win32, Athena and Motif GUI bring up a file requester if the user asks to +":browse" for the ":e", ":w", ":r", ":so", ":redirect" and +":mkexrc/vimrc/vsess" commands. ::browse e /foo/bar" opens the requester in +the /foo/bar directory, so you can have nice mapping rhs's like ":browse so +$vim/macros". If no initial dir specified for ":browse e", can be compiled to +either begin in the current directory, or that of the current buffer. (Negri +and Kahn) +Added the 'browsedir' option, with value "current", "last" or "buffer". Tells +whether a browse dialog starts in last used dir, dir of current buffer, or +current dir. ":browse w" is unaffected. +The default menus have been changed to use the ":browse" command. + + +Dialogs added *dialogs-added* +------------- + +Added the ":confirm" command. Works on ":e", ":q", ":w", ":cl". Win32, +Athena and Motif GUI uses a window-dialog. All other platforms can use +prompt in command-line. ":confirm qa" offers a choice to save all modified +files. + +confirm() function: allows user access to the confirm engine. + +Added 'v' flag to 'guioptions'. When included, a vertical button layout is +always used for the Win32 GUI dialog. Otherwise, a horizontal layout is +preferred. + +Win32 GUI: ":promptfind" and ":promptrepl" pop up a dialog to find/replace. +To be used from a menu entry. (Negri) + + +Popup menu added *popup-menu-added* +---------------- + +When the 'mousemodel' option is set to "popup", the right mouse button +displays the top level menu headed with "PopUp" as pop-up context menu. The +"PopUp" menu is not displayed in the normal menu bar. This currently only +works for Win32 and Athena GUI. + + +Select mode added *new-Select-mode* +----------------- + +A new mode has been added: "Select mode". It is like Visual mode, but typing +a printable character replaces the selection. +- CTRL-G can be used to toggle between Visual mode and Select mode. +- CTRL-O can be used to switch from Select mode to Visual mode for one command. +- Added 'selectmode' option: tells when to start Select mode instead of Visual + mode. +- Added 'mousemodel' option: Change use of mouse buttons. +- Added 'keymodel' option: tells to use shifted special keys to start a + Visual or Select mode selection. +- Added ":behave". Can be used to quickly set 'selectmode', 'mousemodel' + and 'keymodel' for MS-Windows and xterm behavior. +- The xterm-like selection is now called modeless selection. +- Visual mode mappings and menus are used in Select mode. They automatically + switch to Visual mode first. Afterwards, reselect the area, unless it was + deleted. The "gV" command can be used in a mapping to skip the reselection. +- Added the "gh", "gH" and "g^H" commands: start Select (highlight) mode. +- Backspace in Select mode deletes the selected area. + +"mswin.vim" script. Sets behavior mostly like MS-Windows. + + +Session files added *new-session-files* +------------------- + +":mks[ession]" acts like "mkvimrc", but also writes the full filenames of the +currently loaded buffers and current directory, so that :so'ing the file +re-loads those files and cd's to that directory. Also stores and restores +windows. File names are made relative to session file. +The 'sessionoptions' option sets behavior of ":mksession". (Negri) + + +User defined functions and commands *new-user-defined* +----------------------------------- + +Added user defined functions. Defined with ":function" until ":endfunction". +Called with "Func()". Allows the use of a variable number of arguments. +Included support for local variables "l:name". Return a value with ":return". +See |:function|. +Call a function with ":call". When using a range, the function is called for +each line in the range. |:call| +"macros/justify.vim" is an example of using user defined functions. +User functions do not change the last used search pattern or the command to be +redone with ".". +'maxfuncdepth' option. Restricts the depth of function calls. Avoids trouble +(crash because of out-of-memory) when a function uses endless recursion. + +User definable Ex commands: ":command", ":delcommand" and ":comclear". +(Moore) See |user-commands|. + + +New interfaces *interfaces-5.2* +-------------- + +Tcl interface. (Wilken) See |tcl|. +Uses the ":tcl", ":tcldo" and "tclfile" commands. + +Cscope support. (Kahn) (Sekera) See |cscope|. +Uses the ":cscope" and ":cstag" commands. Uses the options 'cscopeprg', +'cscopetag', 'cscopetagorder' and 'cscopeverbose'. + + +New ports *ports-5.2* +--------- + +Amiga GUI port. (Nielsen) Not tested much yet! + +RISC OS version. (Thomas Leonard) See |riscos|. +This version can run either with a GUI or in text mode, depending upon where +it is invoked. +Deleted the "os_archie" files, they were not working anyway. + + +Multi-byte support *new-multi-byte* +------------------ + +MultiByte support for Win32 GUI. (Baek) +The 'fileencoding' option decides how the text in the file is encoded. +":ascii" works for multi-byte characters. Multi-byte characters work on +Windows 95, even when using the US version. (Aaron) +Needs to be enabled in feature.h. +This has not been tested much yet! + + +New functions *new-functions-5.2* +------------- + +|browse()| puts up a file requester when available. (Negri) +|escape()| escapes characters in a string with a backslash. +|fnamemodify()| modifies a file name. +|input()| asks the user to enter a line. (Aaron) There is a separate + history for lines typed for the input() function. +|argc()| +|argv()| can be used to access the argument list. +|winbufnr()| buffer number of a window. (Aaron) +|winnr()| window number. (Aaron) +|matchstr()| Return matched string. +|setline()| Set a line to a string value. + + +New options *new-options-5.2* +----------- + +'allowrevins' Enable the CTRL-_ command in Insert and Command-line mode. +'browsedir' Tells in which directory a browse dialog starts. +'confirm' when set, :q :w and :e commands always act as if ":confirm" + is used. (Negri) +'cscopeprg' +'cscopetag' +'cscopetagorder' +'cscopeverbose' Set the |cscope| behavior. +'filetype' RISC-OS specific type of file. +'grepformat' +'grepprg' For the |:grep| command. +'keymodel' Tells to use shifted special keys to start a Visual or Select + mode selection. +'listchars' Set character to show in 'list' mode for end-of-line, tabs and + trailing spaces. (partly by Smith) Also sets character to + display if a line doesn't fit when 'nowrap' is set. +'matchpairs' Allows matching '<' with '>', and other single character + pairs. +'mousefocus' Window focus follows mouse (partly by Terhaar). Changing the + focus with a keyboard command moves the pointer to that + window. Also move the pointer when changing the window layout + (split window, change window height, etc.). +'mousemodel' Change use of mouse buttons. +'selection' When set to "inclusive" or "exclusive", the cursor can go one + character past the end of the line in Visual or Select mode. + When set to "old" the old behavior is used. When + "inclusive", the character under the cursor is included in the + operation. When using "exclusive", the new "ve" entry of + 'guicursor' is used. The default is a vertical bar. +'selectmode' Tells when to start Select mode instead of Visual mode. +'sessionoptions' Sets behavior of ":mksession". (Negri) +'showfulltag' When completing a tag in Insert mode, show the tag search + pattern (tidied up) as a choice as well (if there is one). +'swapfile' Whether to use a swap file for a buffer. +'syntax' When it is set, the syntax by that name is loaded. Allows for + setting a specific syntax from a modeline. +'ttymouse' Allows using xterm mouse codes for terminals which name + doesn't start with "xterm". +'wildignore' List of patterns for files that should not be completed at + all. +'wildmode' Can be used to set the type of expansion for 'wildchar'. + Replaces the CTRL-T command for command line completion. + Don't beep when listing all matches. +'winaltkeys' Win32 and Motif GUI. When "yes", ALT keys are handled + entirely by the window system. When "no", ALT keys are never + used by the window system. When "menu" it depends on whether + a key is a menu shortcut. +'winminheight' Minimal height for each window. Default is 1. Set to 0 if + you want zero-line windows. Scrollbar is removed for + zero-height windows. (Negri) + + + +New Ex commands *new-ex-commands-5.2* +--------------- + +|:badd| Add file name to buffer list without side effects. (Negri) +|:behave| Quickly set MS-Windows or xterm behavior. +|:browse| Use file selection dialog. +|:call| Call a function, optionally with a range. +|:cnewer| +|:colder| To access a stack of quickfix error lists. +|:comclear| Clear all user-defined commands. +|:command| Define a user command. +|:continue| Go back to ":while". +|:confirm| Ask confirmation if something unexpected happens. +|:cscope| Execute cscope command. +|:cstag| Use cscope to jump to a tag. +|:delcommand| Delete a user-defined command. +|:delfunction| Delete a user-defined function. +|:endfunction| End of user-defined function. +|:function| Define a user function. +|:grep| Works similar to ":make". (Negri) +|:mksession| Create a session file. +|:nohlsearch| Stop 'hlsearch' highlighting for a moment. +|:Print| This is Vi compatible. Does the same as ":print". +|:promptfind| Search dialog (Win32 GUI). +|:promptrepl| Search/replace dialog (Win32 GUI). +|:return| Return from a user-defined function. +|:simalt| Win32 GUI: Simulate alt-key pressed. (Negri) +|:smagic| Like ":substitute", but always use 'magic'. +|:snomagic| Like ":substitute", but always use 'nomagic'. +|:tcl| Execute TCL command. +|:tcldo| Execute TCL command for a range of lines. +|:tclfile| Execute a TCL script file. +|:tearoff| Tear-off a menu (Win32 GUI). +|:tmenu| +|:tunmenu| Win32 GUI: menu tooltips. (Negri) +|:star| :* Execute a register. + + +Changed *changed-5.2* +------- + +Renamed functions: + buffer_exists() -> bufexists() + buffer_name() -> bufname() + buffer_number() -> bufnr() + file_readable() -> filereadable() + highlight_exists() -> hlexists() + highlightID() -> hlID() + last_buffer_nr() -> bufnr("$") +The old ones are still there, for backwards compatibility. + +The CTRL-_ command in Insert and Command-line mode is only available when the +new 'allowrevins' option is set. Avoids that people who want to type SHIFT-_ +accidentally enter reverse Insert mode, and don't know how to get out. + +When a file name path in ":tselect" listing is too long, remove a part in the +middle and put "..." there. + +Win32 GUI: Made font selector appear inside Vim window, not just any odd +place. (Negri) + +":bn" skips help buffers, unless currently in a help buffer. (Negri) + +When there is a status line and only one window, don't show '^' in the status +line of the current window. + +":*" used to be used for "'<,'>", the Visual area. But in Vi it's used as an +alternative for ":@". When 'cpoptions' includes '*' this is Vi compatible. + +When 'insertmode' is set, using CTRL-O to execute a mapping will work like +'insertmode' was not set. This allows "normal" mappings to be used even when +'insertmode' is set. + +When 'mouse' was set already (e.g., in the .vimrc file), don't automatically +set 'mouse' when the GUI starts. + +Removed the 'N', 'I' and 'A' flags from the 'mouse' option. + +Renamed "toggle option" to "boolean option". Some people thought that ":set +xyz" would toggle 'xyz' on/off each time. + +The internal variable "shell_error" contains the error code from the shell, +instead of just 0 or 1. + +When inserting or replacing, typing CTRL-V CTRL-<CR> used to insert "<C-CR>". +That is not very useful. Now the CTRL key is ignored and a <CR> is inserted. +Same for all other "normal" keys with modifiers. Mapping these modified key +combinations is still possible. +In Insert mode, <C-CR> and <S-Space> can be inserted by using CTRL-K and then +the special character. + +Moved "quotes" file to doc/quotes.txt, and "todo" file to doc/todo.txt. They +are now installed like other documentation files. + +winheight() function returns -1 for a non-existing window. It used to be +zero, but that is a valid height now. + +The default for 'selection' is "inclusive", which makes a difference when +using "$" or the mouse to move the cursor in Visual mode. + +":q!" does not exit when there are changed buffers which are hidden. Use +":qa!" to exit anyway. + +Disabled the Perl/Python/Tcl interfaces by default. Not many people use them +and they make the executable a lot bigger. The internal scripting language is +now powerful enough for most tasks. + +The strings from the 'titlestring' and 'iconstring' options are used +untranslated for the Window title and icon. This allows for including a <CR>. +Previously a <CR> would be shown as "^M" (two characters). + +When a mapping is started in Visual or Select mode which was started from +Insert mode (the mode shows "(insert) Visual"), don't return to Insert mode +until the mapping has ended. Makes it possible to use a mapping in Visual +mode that also works when the Visual mode was started from Select mode. + +Menus in $VIMRUNTIME/menu.vim no longer overrule existing menus. This helps +when defining menus in the .vimrc file, or when sourcing mswin.vim. + +Unix: Use /var/tmp for .swp files, if it exists. Files there survive a +reboot (at least on Linux). + + +Added *added-5.2* +----- + +--with-motif-lib configure argument. Allows for using a static Motif library. + +Support for mapping numeric keypad +,-,*,/ keys. (Negri) +When not mapped, they produce the normal character. + +Win32 GUI: When directory dropped on Gvim, cd there and edit new buffer. +(Negri) + +Win32 GUI: Made CTRL-Break work as interrupt, so that CTRL-C can be +used for mappings. + +In the output of ":map", highlight the "*" to make clear it's not part of the +rhs. (Roemer) + +When showing the Visual area, the cursor is not switched off, so that it can +be located. The Visual area is now highlighted with a grey background in the +GUI. This makes the cursor visible when it's also reversed. + +Win32: When started with single full pathname (e.g. via double-clicked file), +cd to that file's directory. (Negri) + +Win32 GUI: Tear-off menus, with ":tearoff <menu-name>" command. (Negri) +'t' option to 'guioptions': Add tearoff menu items for Win32 GUI and Motif. +It's included by default. +Win32 GUI: tearoff menu with submenus is indicated with a ">>". (Negri) + +Added ^Kaa and ^KAA digraphs. +Added "euro" symbol to digraph.c. (Corry) + +Support for Motif menu shortcut keys, using '&' like MS-Windows (Ollis). +Other GUIs ignore '&' in a menu name. + +DJGPP: Faster screen updating (John Lange). + +Clustering of syntax groups ":syntax cluster" (Bigham). +Including syntax files: ":syntax include" (Bigham). + +Keep column when switching buffers, when 'nosol' is set (Radics). + +Number function for Perl interface. + +Support for Intellimouse in Athena GUI. (Jensen) + +":sleep" also accepts an argument in milliseconds, when "m" is used. + +Added 'p' flag in 'guioptions': Install callbacks for enter/leave window +events. Makes cursor blinking work for Terhaar, breaks it for me. + +"--help" and "--version" command-line arguments. + +Non-text in ":list" output is highlighted with NonText. + +Added text objects: "i(" and "i)" as synonym for "ib". "i{" and "i}" as +synonym for "iB". New: "i<" and "i>", to select <thing>. All this also for +"a" objects. + +'O' flag in 'shortmess': message for reading a file overwrites any previous +message. (Negri) + +Win32 GUI: 'T' flag in 'guioptions': switch toolbar on/off. +Included a list with self-made toolbar bitmaps. (Negri) + +Added menu priority for sub-menus. Implemented for Win32 and Motif GUI. +Display menu priority with ":menu" command. +Default and Syntax menus now include priority for items. Allows inserting +menu items in between the default ones. + +When the 'number' option is on, highlight line numbers with the LineNr group. + +"Ignore" highlight group: Text highlighted with this is made blank. It is +used to hide special characters in the help text. + +Included Exuberant Ctags version 2.3, with C++ support, Java support and +recurse into directories. (Hiebert) + +When a tags file is not sorted, and this is detected (in a simplistic way), an +error message is given. + +":unlet" accepts a "!", to ignore non-existing variables, and accepts more +than one argument. (Roemer) +Completion of variable names for ":unlet". (Roemer) + +When there is an error in a function which is called by another function, show +the call stack in the error message. + +New file name modifiers: +":.": reduce file name to be relative to current dir. +":~": reduce file name to be relative to home dir. +":s?pat?sub?": substitute "pat" with "sub" once. +":gs?pat?sub?": substitute "pat" with "sub" globally. + +New configure arguments: --enable-min-features and --enable-max-features. +Easy way to switch to minimum or maximum features. + +New compile-time feature: modify_fname. For file name modifiers, e.g, +"%:p:h". Can be disabled to save some code (16 bit DOS). + +When using whole-line completion in Insert mode, and 'cindent' is set, indent +the line properly. + +MSDOS and Win32 console: 'guicursor' sets cursor thickness. (Negri) + +Included new set of Farsi fonts. (Shiran) + +Accelerator text now also works in Motif. All menus can be defined with & for +mnemonic and TAB for accelerator text. They are ignored on systems that don't +support them. +When removing or replacing a menu, compare the menu name only up to the <Tab> +before the mnemonic. + +'i' and 'I' flags after ":substitute": ignore case or not. + +"make install" complains if the runtime files are missing. + +Unix: When finding an existing swap file that can't be opened, mention the +owner of the file in the ATTENTION message. + +The 'i', 't' and 'k' options in 'complete' now also print the place where they +are looking for matches. (Acevedo) + +"gJ" command: Join lines without inserting a space. + +Setting 'keywordprg' to "man -s" is handled specifically. The "-s" is removed +when no count given, the count is added otherwise. Configure checks if "man +-s 2 read" works, and sets the default for 'keywordprg' accordingly. + +If you do a ":bd" and there is only one window open, Vim tries to move to a +buffer of the same type (i.e. non-help to non-help, help to help), for +consistent behavior to :bnext/:bprev. (Negri) + +Allow "<Nop>" to be used as the rhs of a mapping. ":map xx <Nop>", maps "xx" +to nothing at all. + +In a ":menu" command, "<Tab>" can be used instead of a real tab, in the menu +path. This makes it more easy to type, no backslash needed. + +POSIX compatible character classes for regexp patterns: [:alnum:], [:alpha:], +[:blank:], [:cntrl:], [:digit:], [:graph:], [:lower:], [:print:], [:punct:], +[:space:], [:upper:] and [:xdigit:]. (Briscoe) + +regexp character classes (for fast syntax highlight matching): + digits: \d [0-9] \D not digit (Roemer) + hex: \x [0-9a-fA-F] \X not hex + octal: \o [0-7] \O not octal + word: \w [a-zA-Z0-9_] \W not word + head: \h [a-zA-Z_] \H not head + alphabetic: \a [a-zA-Z] \A not alphabetic + lowercase: \l [a-z] \L not lowercase + uppercase: \u [A-Z] \U not uppercase + +":set" now accepts "+=", |^=" and "-=": add or remove parts of a string +option, add or subtract a number from a number option. A comma is +automagically inserted or deleted for options that are a comma separated list. + +Filetype feature, for autocommands. Uses a file type instead of a pattern to +match a file. Currently only used for RISC OS. (Leonard) + +In a pattern for an autocommand, environment variables can be used. They are +expanded when the autocommand is defined. + +"BufFilePre" and "BufFilePost" autocommand evens: Before and after applying +the ":file" command to change the name of a buffer. +"VimLeavePre" autocommand event: before writing the .viminfo file. + +For autocommands argument: <abuf> is buffer number, like <afile>. + +Made syntax highlighting a bit faster when scrolling backwards, by keeping +more syncing context. + +Win32 GUI: Made scrolling faster by avoiding a redraw when deleting or +inserting screen lines. + +GUI: Made scrolling faster by not redrawing the scrollbar when the thumb moved +less than a pixel. + +Included ":highlight" in bugreport.vim. + +Created install.exe program, for simplistic installation on DOS and +MS-Windows. + +New register: '_', the black hole. When writing to it, nothing happens. When +reading from it, it's always empty. Can be used to avoid a delete or change +command to modify the registers, or reduce memory use for big changes. + +CTRL-V xff enters character by hex number. CTRL-V o123 enters character by +octal number. (Aaron) + +Improved performance of syntax highlighting by skipping check for "keepend" +when there isn't any. + +Moved the mode message ("-- INSERT --") to the last line of the screen. When +'cmdheight' is more than one, messages will remain readable. + +When listing matching files, they are also sorted on 'suffixes', such that +they are listed in the same order as CTRL-N retrieves them. + +synIDattr() takes a third argument (optionally), which tells for which +terminal type to get the attributes for. This makes it possible to run +2html.vim outside of gvim (using color names instead of #RRGGBB). + +Memory profiling, only for debugging. Prints at exit, and with "g^A" command. +(Kahn) + +DOS: When using a file in the current drive, remove the drive name: +"A:\dir\file" -> "\dir\file". This helps when moving a session file on a +floppy from "A:\dir" to "B:\dir". + +Increased number of remembered jumps from 30 to 50 per window. + +Command to temporarily disable 'hls' highlighting until the next search: +":nohlsearch". + +"gp" and "gP" commands: like "p" and "P", but leave the cursor just after the +inserted text. Used for the CTRL-V command in MS-Windows mode. + + +Fixed *fixed-5.2* +----- + +Win32 GUI: Could draw text twice in one place, for fake-bold text. Removed +this, Windows will handle the bold text anyway. (Negri) + +patch 5.1.1: Win32s GUI: pasting caused a crash (Negri) + +patch 5.1.2: When entering another window, where characters before the cursor +have been deleted, could have a cursor beyond the end of the line. + +patch 5.1.3: Win32s GUI: Didn't wait for external command to finish. (Negri) + +patch 5.1.4: Makefile.w32 can now also be used to generate the OLE version +(Scott). + +patch 5.1.5: Crashed when using syntax highlighting: cursor on a line that +doesn't fit in the window, and splitting that line in two. + +patch 5.1.6: Visual highlighting bug: After ":set nowrap", go to end of line +(so that the window scrolls horizontally), ":set wrap". Following Visual +selection was wrong. + +patch 5.1.7: When 'tagbsearch' off, and 'ignorecase' off, still could do +binary searching. + +patch 5.1.8: Win32 GUI: dragging the scrollbar didn't update the ruler. + +patch 5.1.9: Using ":gui" in .vimrc, caused xterm cursor to disappear. + +patch 5.1.10: A CTRL-N in Insert mode could cause a crash, when a buffer +without a name exists. + +patch 5.1.11: "make test" didn't work in the shadow directory. Also adjusted +"make shadow" for the links in the ctags directory. + +patch 5.1.12: "buf 123foo" used "123" as a count, instead as the start of a +buffer name. + +patch 5.1.13: When completing file names on the command-line, reallocating the +command-line may go wrong. + +patch 5.1.14: ":[nvci]unmenu" removed menu for all modes, when full menu patch +specified. + +Graceful handling of NULLs in drag-dropped file list. Handle passing NULL to +Fullname_save(). (Negri) + +Win32: ":!start" to invoke a program without opening a console, swapping +screens, or waiting for completion in either console or gui version, e.g. you +can type ":!start winfile". ALSO fixes "can't delete swapfile after spawning +a shell" bug. (enhancement of Aaron patch) (Negri) + +Win32 GUI: Fix CTRL-X default keymapping to be more Windows-like. (Negri) + +Shorten filenames on startup. If in /foo/bar, entering "vim ../bar/bang.c" +displays "bang.c" in status bar, not "/foo/bar/bang.c" (Negri) + +Win32 GUI: No copy to Windows clipboard when it's not desired. + +Win32s: Fix pasting from clipboard - made an assumption not valid under +Win32s. (Negri) + +Win32 GUI: Speed up calls to gui_mch_draw_string() and cursor drawing +functions. (Negri) + +Win32 GUI: Middle mouse button emulation now works in GUI! (Negri) + +Could skip messages when combining commands in one line, e.g.: +":echo "hello" | write". + +Perl interpreter was disabled before executing VimLeave autocommands. Could +not use ":perl" in them. (Aaron) + +Included patch for the Intellimouse (Aaron/Robinson). + +Could not set 'ls' to one, when last window has only one line. (Mitterand) + +Fixed a memory leak when removing menus. + +After ":only" the ruler could overwrite a message. + +Dos32: removed changing of __system_flags. It appears to work better when +it's left at the default value. + +p_aleph was an int instead of along, caused trouble on systems where +sizeof(int) != sizeof(long). (Schmidt) + +Fixed enum problems for Ultrix. (Seibert) + +Small redraw problem: "dd" on last line in file cleared wrong line. + +Didn't interpret "cmd | endif" when "cmd" starts with a range. E.g. "if 0 | +.d | endif". + +Command "+|" on the last line of the file caused ml_get errors. + +Memory underrun in eval_vars(). (Aaron) + +Don't rename files in a difficult way, except on Windows 95 (was also done on +Windows NT). + +Win32 GUI: An external command that produces an error code put the error +message in a dialog box. had to close the window and close the dialog. Now +the error code is displayed in the console. (Negri) + +"comctl32.lib" was missing from the GUI libraries in Makefile.w32. (Battle) + +In Insert mode, when entering a window in Insert mode, allow the cursor to be +one char beyond the text. + +Renamed machine dependent rename() to mch_rename(). Define mch_rename() to +rename() when it works properly. + +Rename vim_chdir() to mch_chdir(), because it's machine dependent. + +When using an arglist, and editing file 5 of 4, ":q" could cause "-1 more +files to edit" error. + +In if_python.c, VimCommand() caused an assertion when a do_cmdline() failed. +Moved the Python_Release_Vim() to before the VimErrorCheck(). (Harkins) + +Give an error message for an unknown argument after "--". E.g. for "vim +--xyz". + +The FileChangedShell autocommand didn't set <afile> to the name of the changed +file. + +When doing ":e file", causing the attention message, there sometimes was no +hit-enter prompt. Caused by empty line or "endif" at end of sourced file. + +A large number of patches for the VMS version. (Hunsaker) + +When CTRL-L completion (find longest match) results in a shorter string, no +completion is done (happens with ":help"). + +Crash in Win32 GUI version, when using an Ex "@" command, because +LinePointers[] was used while not initialized. + +Win32 GUI: allow mapping of Alt-Space. + +Output from "vim -h" was sent to stderr. Sending it to stdout is better, so +one can use "vim -h | more". + +In command-line mode, ":vi[!]" should reload the file, just like ":e[!]". +In Ex mode, ":vi" stops Ex mode, but doesn't reload the file. This is Vi +compatible. + +When using a ":set ls=1" in the .gvimrc file, would get a status line for a +single window. (Robinson) + +Didn't give an error message for ":set ai,xx". (Roemer) +Didn't give an error message for ":set ai?xx", ":set ai&xx", ":set ai!xx". + +Non-Unix systems: That a file exists but is unreadable is recognized as "new +file". Now check for existence when file can't be opened (like Unix). + +Unix: osdef.sh didn't handle declarations where the function name is at the +first column of the line. + +DJGPP: Shortening of file names didn't work properly, because get_cwd() +returned a path with backslashes. (Negri) + +When using a 'comments' part where a space is required after the middle part, +always insert a space when starting a new line. Helps for C comments, below a +line with "/****". + +Replacing path of home directory with "~/" could be wrong for file names +with embedded spaces or commas. + +A few fixes for the Sniff interface. (Leherbauer) + +When asking to hit 'y' or 'n' (e.g. for ":3,1d"), using the mouse caused +trouble. Same for ":s/x/y/c" prompt. + +With 'nowrap' and 'list', a Tab halfway on the screen was displayed as blanks, +instead of the characters specified with 'listchars'. Also for other +characters that take more than one screen character. + +When setting 'guifont' to an unknown font name, the previous font was lost and +a default font would be used. (Steed) + +DOS: Filenames in the root directory didn't get shortened properly. (Negri) + +DJGPP: making a full path name out of a file name didn't work properly when +there is no _fullpath() function. (Negri) + +Win32 console: ":sh" caused a crash. (Negri) + +Win32 console: Setting 'lines' and/or 'columns' in the _vimrc failed miserably +(could hang Windows 95). (Negri) + +Win32: The change-drive function was not correct, went to the wrong drive. +(Tsindlekht) + +GUI: When editing a command line in Ex mode, Tabs were sometimes not +backspaced properly, and unprintable characters were displayed directly. +non-GUI can still be wrong, because a system function is called for this. + +":set" didn't stop after an error. For example ":set no ai" gave an error for +"no", but still set "ai". Now ":set" stops after the first error. + +When running configure for ctags, $LDFLAGS wasn't passed to it, causing +trouble for IRIX. + +"@%" and "@#" when file name not set gave an error message. Now they just +return an empty string. (Steed) + +CTRL-X and CTRL-A didn't work correctly with negative hex and octal numbers. +(Steed) + +":echo" always started with a blank. + +Updating GUI cursor shape didn't always work (e.g., when blinking is off). + +In silent Ex mode ("ex -s" or "ex <file") ":s///p" didn't print a line. Also +a few other commands that explicitly print a text line didn't work. Made this +Vi compatible. + +Win32 version of _chdrive() didn't return correct value. (Tsindlekht) + +When using 't' in 'complete' option, no longer give an error message for a +missing tags file. + +Unix: tgoto() can return NULL, which was not handled correctly in configure. + +When doing ":help" from a buffer where 'binary' is set, also edited the help +file in binary mode. Caused extra ^Ms for DOS systems. + +Cursor position in a file was reset to 1 when closing a window. + +":!ls" in Ex mode switched off echo. + +When doing a double click in window A, while currently in window B, first +click would reset double click time, had to click three times to select a +word. + +When using <F11> in mappings, ":mkexrc" produced an exrc file that can't be +used in Vi compatible mode. Added setting of 'cpo' to avoid this. Also, add +a CTRL-V in front of a '<', to avoid a normal string to be interpreted as a +special key name. + +Gave confusing error message for ":set guifont=-*-lucida-*": first "font is +not fixed width", then "Unknown font". + +Some options were still completely left out, instead of included as hidden +options. + +While running the X11 GUI, ignore SIGHUP signals. Avoids a crash after +executing an external command (in rare cases). + +In os_unixx.h, signal() was defined to sigset(), while it already was. + +Memory leak when executing autocommands (was reported as a memory leak in +syntax highlighting). + +Didn't print source of error sometimes, because pointers were the same, +although names were different. + +Avoid a number of UMR errors from Purify (third argument to open()). + +A swap file could still be created just after setting 'updatecount' to zero, +when there is an empty buffer and doing ":e file". (Kutschera) + +Test 35 failed on 64 bit machines. (Schild) + +With "p" and "P" commands, redrawing was slow. + +Awk script for html documentation didn't work correctly with AIX awk. +Replaced "[ ,.);\] ]" with "[] ,.); ]". (Briscoe) +The makehtml.awk script had a small problem, causing extra lines to be +inserted. (Briscoe) + +"gqgq" could not be repeated. Repeating for "gugu" and "gUgU" worked in a +wrong way. Also made "gqq" work to be consistent with "guu". + +C indent was wrong after "case ':':". + +":au BufReadPre *.c put": Line from put text was deleted, because the buffer +was still assumed to be empty. + +Text pasted with the Edit/Paste menu was subject to 'textwidth' and +'autoindent'. That was inconsistent with using the mouse to paste. Now "*p +is used. + +When using CTRL-W CTRL-] on a word that's not a tag, and then CTRL-] on a tag, +window was split. + +":ts" got stuck on a tags line that has two extra fields. + +In Insert mode, with 'showmode' on, <C-O><C-G> message was directly +overwritten by mode message, if preceded with search command warning message. + +When putting the result of an expression with "=<expr>p, newlines were +inserted like ^@ (NUL in the file). Now the string is split up in lines at +the newline. + +putenv() was declared with "const char *" in pty.c, but with "char *" in +osdef2.h.in. Made the last one also "const char *". + +":help {word}", where +{word} is a feature, jumped to the feature list instead +of where the command was explained. E.g., ":help browse", ":help autocmd". + +Using the "\<xx>" form in an expression only got one byte, even when using a +special character that uses several bytes (e.g., "\<F9>"). +Changed "\<BS>" to produce CTRL-H instead of the special key code for the +backspace key. "\<Del>" produces 0x7f. + +":mkvimrc" didn't write a command to set 'compatible' or 'nocompatible'. + +The shell syntax didn't contain a "syn sync maxlines" setting. In a long file +without recognizable items, syncing took so long it looked like Vim hangs. +Added a maxlines setting, and made syncing interruptible. + +The "gs" command didn't flush output before waiting. + +Memory leaks for: + ":if 0 | let a = b . c | endif" + "let a = b[c]" + ":so {file}" where {file} contains a ":while" + +GUI: allocated fonts were never released. (Leonard) + +Makefile.bor: +- Changed $(DEFINES) into a list of "-D" options, so that it can also be used + for the resource compiler. (not tested!) +- "bcc.cfg" was used for all configurations. When building for another + configuration, the settings for the previous one would be used. Moved + "bcc.cfg" to the object directory. (Geddes) +- Included targets for vimrun, install, ctags and xxd. Changed the default to + use the Borland DLL Runtime Library, makes Vim.exe a log smaller. (Aaron) + +"2*" search for the word under the cursor with "2" prepended. (Leonard) + +When deleting into a specific register, would still overwrite the non-Win32 +GUI selection. Now ""x"*P works. + +When deleting into the "" register, would write to the last used register. +Now ""x always writes to the unnamed register. + +GUI Athena: A submenu with a '.' in it didn't work. E.g., +":amenu Syntax.XY\.Z.foo lll". + +When first doing ":tag foo" and then ":tnext" and/or ":tselect" the order of +matching tags could change, because the current file is different. Now the +existing matches are kept in the same order, newly found matches are added +after them, not matter what the current file is. + +":ta" didn't find the second entry in a tags file, if the second entry was +longer than the first one. + +When using ":set si tw=7" inserting "foo {^P}" made the "}" inserted at the +wrong position. can_si was still TRUE when the cursor is not in the indent of +the line. + +Running an external command in Win32 version had the problem that Vim exits +when the X on the console is hit (and confirmed). Now use the "vimrun" +command to start the external command indirectly. (Negri) + +Win32 GUI: When running an external filter, do it in a minimized DOS box. +(Negri) + +":let" listed variables without translation into printable characters. + +Win32 console: When resizing the window, switching back to the old size +(when exiting or executing an external command) sometimes failed. (Negri) +This appears to also fix a "non fixable" problem: +Win32 console in NT 4.0: When running Vim in a cmd window with a scrollbar, +the scrollbar disappeared and was not restored when Vim exits. This does work +under NT 3.51, it appears not to be a Vim problem. + +When executing BufDelete and BufUnload autocommands for a buffer without a +name, the name of the current buffer was used for <afile>. + +When jumping to a tag it reported "tag 1 of >2", while in fact there could be +only two matches. Changed to "tag 1 of 2 or more". + +":tjump tag" did a linear search in the tags file, which can be slow. + +Configure didn't find "LibXm.so.2.0", a Xm library with a version number. + +Win32 GUI: When using a shifted key with ALT, the shift modifier would remain +set, even when it was already used by changing the used key. E.g., "<M-S-9>" +resulted in "<M-S-(>", but it should be "<M-(>". (Negri) + +A call to ga_init() was often followed by setting growsize and itemsize. +Created ga_init2() for this, which looks better. (Aaron) + +Function filereadable() could call fopen() with an empty string, which might +be illegal. + +X Windows GUI: When executing an external command that outputs text, could +write one character beyond the end of a buffer, which caused a crash. (Kohan) + +When using "*" or "#" on a string that includes '/' or '?' (when these are +included in 'isk'), they were not escaped. (Parmelan) + +When adding a ToolBar menu in the Motif GUI, the submenu_id field was not +cleared, causing random problems. + +When adding a menu, the check if this menu (or submenu) name already exists +didn't compare with the simplified version (no mnemonic or accelerator) of the +new menu. Could get two menus with the same name, e.g., "File" and "&File". + +Breaking a line because of 'textwidth' at the last line in the window caused a +redraw of the whole window instead of a scroll. Speeds up normal typing with +'textwidth' a lot for slow terminals. + +An invalid line number produced an "invalid range" error, even when it wasn't +to be executed (inside "if 0"). + +When the unnamed, first buffer is re-used, the "BufDelete" autocommand was +not called. It would stick in a buffer list menu. + +When doing "%" on the NUL after the line, a "{" or "}" in the last character +of the line was not found. + +The Insert mode menu was not used for the "s" command, the Operator-pending +menu was used instead. + +With 'compatible' set, some syntax highlighting was not correct, because of +using "[\t]" for a search pattern. Now use the regexps for syntax +highlighting like the 'cpoptions' option is empty (as was documented already). + +When using "map <M-Space> ms" or "map <Space> sss" the output of ":map" didn't +show any lhs for the mapping (if 'isprint' includes 160). Now always use +<Space> and <M-Space>, even when they are printable. + +Adjusted the Syntax menu, so that the lowest entry fits on a small screen (for +Athena, where menus don't wrap). + +When using CTRL-E or CTRL-Y in Insert mode for characters like 'o', 'x' and +digits, repeating the insert didn't work. + +The file "tools/ccfilter.README.txt" could not be unpacked when using short +file names, because of the two dots. Renamed it to +"tools/ccfilter_README.txt". + +For a dark 'background', using Blue for Directory and SpecialKey highlight +groups is not very readable. Use Cyan instead. + +In the function uc_scan_attr() in ex_docmd.c there was a goto that jumped into +a block with a local variable. That's illegal for some compilers. + +Win32 GUI: There was a row of pixels at the bottom of the window which was not +drawn. (Aaron) + +Under DOS, editing "filename/" created a swap file of "filename/.swp". Should +be "filename/_swp". + +Win32 GUI: pointer was hidden when executing an external command. + +When 'so' is 999, "J" near the end of the file didn't redisplay correctly. + +":0a" inserted after the first line, instead of before the first line. + +Unix: Wildcard expansion didn't handle single quotes and {} patterns. Now +":file 'window.c'" removes the quotes and ":e 'main*.c'" works (literal '*'). +":file {o}{n}{e}" now results in file name "one". + +Memory leak when setting a string option back to its default value. + +============================================================================== +VERSION 5.3 *version-5.3* + +Version 5.3 was a bug-fix version of 5.2. There are not many changes. +Improvements made between version 5.2 and 5.3: + +Changed *changed-5.3* +------- + +Renamed "IDE" menu to "Tools" menu. + + +Added *added-5.3* +----- + +Win32 GUI: Give a warning when Vim is activated, and one of the files changed +since editing started. (Negri) + + +Fixed *fixed-5.3* +----- + +5.2.1: Win32 GUI: space for external command was not properly allocated, could +cause a crash. (Aaron) This was the reason to bring out 5.3 quickly after +5.2. + +5.2.2: Some commands didn't complain when used without an argument, although +they need one: ":badd", ":browse", ":call", ":confirm", ":behave", +":delfunction", ":delcommand" and ":tearoff". +":endfunction" outside of a function gave wrong error message: "Command not +implemented". Should be ":endfunction not inside a function". + +5.2.3: Win32 GUI: When gvim was installed in "Program files", or another path +with a space in it, executing external commands with vimrun didn't work. + +5.2.4: Pasting with the mouse in Insert mode left the cursor on the last +pasted character, instead of behind it. + +5.2.5: In Insert mode, cursor after the end of the line, a shift-cursor-left +didn't include the last character in the selection. + +5.2.6: When deleting text from Insert mode (with "<C-O>D" or the mouse), which +includes the last character in the line, the cursor could be left on the last +character in the line, instead of just after it. + +5.2.7: Win32 GUI: scrollbar was one pixel too big. + +5.2.8: Completion of "PopUp" menu showed the derivatives "PopUpc", "PopUPi", +etc. ":menu" also showed these. + +5.2.9: When using two input() functions on a row, the prompt would not be +drawn in column 0. + +5.2.10: A loop with input() could not be broken with CTRL-C. + +5.2.11: ":call asdf" and ":call asdf(" didn't give an error message. + +5.2.12: Recursively using ":normal" crashes Vim after a while. E.g.: +":map gq :normal gq<CR>" + +5.2.13: Syntax highlighting used 'iskeyword' from wrong buffer. When using +":help", then "/\k*" in another window with 'hlsearch' set. + +5.2.14: When using ":source" from a function, global variables would not be +available unless "g:" was used. + +5.2.15: XPM files can have the extension ".pm", which is the same as for Perl +modules. Added "syntax/pmfile.vim" to handle this. + +5.2.16: On Win32 and Amiga, "echo expand("%:p:h")" removed one dirname in an +empty buffer. mch_Fullname() didn't append a slash at the end of a directory +name. + +Should include the character under the cursor in the Visual area when using +'selection' "exclusive". This wasn't done for "%", "e", "E", "t" and "f". + +""p would always put register 0, instead of the unnamed (last used) register. +Reverse the change that ""x doesn't write in the unnamed (last used) register. +It would always write in register 0, which isn't very useful. Use "-x for the +paste mappings in Visual mode. + +When there is one long line on the screen, and 'showcmd' is off, "0$" didn't +redraw the screen. + +Win32 GUI: When using 'mousehide', the pointer would flicker when the cursor +shape is changed. (Negri) + +When cancelling Visual mode, and the cursor moves to the start, the wanted +column wasn't set, "k" or "j" moved to the wrong column. + +When using ":browse" or ":confirm", was checking for a comment and separating +bar, which can break some commands. + +Included fixes for Macintosh. (Kielhorn) + +============================================================================== +VERSION 5.4 *version-5.4* + +Version 5.4 adds new features, useful changes and a lot of bug fixes. + + +Runtime directory introduced *new-runtime-dir* +---------------------------- + +The distributed runtime files are now in $VIMRUNTIME, the user files in $VIM. +You normally don't set $VIMRUNTIME but let Vim find it, by using +$VIM/vim{version}, or use $VIM when that doesn't exist. This allows for +separating the user files from the distributed files and makes it more easy to +upgrade to another version. It also makes it possible to keep two versions of +Vim around, each with their own runtime files. + +In the Unix distribution the runtime files have been moved to the "runtime" +directory. This makes it possible to copy all the runtime files at once, +without the need to know what needs to be copied. + +The archives for DOS, Windows, Amiga and OS/2 now have an extra top-level +"vim" directory. This is to make clear that user-modified files should be put +here. The directory that contains the executables doesn't have '-' or '.' +characters. This avoids strange extensions. + +The $VIM and $VIMRUNTIME variables are set when they are first used. This +allows them to be used by Perl, for example. + +The runtime files are also found in a directory called "$VIM/runtime". This +helps when running Vim after just unpacking the runtime archive. When using +an executable in the "src" directory, Vim checks if "vim54" or "runtime" can +be added after removing it. This make the runtime files be found just after +compiling. + +A default for $VIMRUNTIME can be given in the Unix Makefile. This is useful +if $VIM doesn't point to above the runtime directory but to e.g., "/etc/". + + +Filetype introduced *new-filetype-5.4* +------------------- + +Syntax files are now loaded with the new FileType autocommand. Old +"mysyntaxfile" files will no longer work. |filetypes| + +The scripts for loading syntax highlighting have been changed to use the +new Syntax autocommand event. + +This combination of Filetype and Syntax events allows tuning the syntax +highlighting a bit more, also when selected from the Syntax menu. The +FileType autocommand can also be used to set options and mappings specifically +for that type of file. + +The "$VIMRUNTIME/filetype.vim" file is not loaded automatically. The +":filetype on" command has been added for this. ":syntax on" also loads it. + +The 'filetype' option has been added. It is used to trigger the FileType +autocommand event, like the 'syntax' option does for the Syntax event. + +":set syntax=OFF" and ":set syntax=ON" can be used (in a modeline) to switch +syntax highlighting on/off for the current file. + +The Syntax menu commands have been moved to $VIMRUNTIME/menu.vim. The Syntax +menu is included both when ":filetype on" and when ":syntax manual" is used. + +Renamed the old 'filetype' option to 'osfiletype'. It was only used for +RISCOS. 'filetype' is now used for the common file type. + +Added the ":syntax manual" command. Allows manual selection of the syntax to +be used, e.g., from a modeline. + + +Vim script line continuation *new-line-continuation* +---------------------------- + +When an Ex line starts with a backslash, it is concatenated to the previous +line. This avoids the need for long lines. |line-continuation| (Roemer) +Example: > + if has("dialog_con") || + \ has("dialog_gui") + :let result = confirm("Enter your choice", + \ "&Yes\n&No\n&Maybe", + \ 2) + endif + + +Improved session files *improved-sessions* +---------------------- + +New words for 'sessionoptions': +- "help" Restore the help window. +- "blank" Restore empty windows. +- "winpos" Restore the Vim window position. Uses the new ":winpos" + command +- "buffers" Restore hidden and unloaded buffers. Without it only the + buffers in windows are restored. +- "slash" Replace backward by forward slashes in file names. +- "globals" Store global variables. +- "unix" Use unix file format (<NL> instead of <CR><NL>) + +The ":mksession" and 'sessionoptions' are now in the +mksession feature. + +The top line of the window is also restored when using a session file. + +":mksession" and ":mkvimrc" don't store 'fileformat', it should be detected +when loading a file. + +(Most of this was done by Vince Negri and Robert Webb) + + +Autocommands improved *improved-autocmds-5.4* +--------------------- + +New events: +|FileType| When the file type has been detected. +|FocusGained| When Vim got input focus. (Negri) +|FocusLost| When Vim lost input focus. (Negri) +|BufCreate| Called just after a new buffer has been created or has been + renamed. (Madsen) +|CursorHold| Triggered when no key has been typed for 'updatetime'. Can be + used to do something with the word under the cursor. (Negri) + Implemented CursorHold autocommand event for Unix. (Zellner) + Also for Amiga and MS-DOS. +|GUIEnter| Can be used to do something with the GUI window after it has + been created (e.g., a ":winpos 100 50"). +|BufHidden| When a buffer becomes hidden. Used to delete the + option-window when it becomes hidden. + +Also trigger |BufDelete| just before a buffer is going to be renamed. (Madsen) + +The "<amatch>" pattern can be used like "<afile>" for autocommands, except +that it is the matching value for the FileType and Syntax events. + +When ":let @/ = <string>" is used in an autocommand, this last search pattern +will be used after the autocommand finishes. + +Made loading autocommands a bit faster. Avoid doing strlen() on each exiting +pattern for each new pattern by remembering the length. + + +Encryption *new-encryption* +---------- + +Files can be encrypted when writing and decrypted when reading. Added the +'key' option, "-x" command line argument and ":X" command. |encryption| (based +on patch from Mohsin Ahmed) + +When reading a file, there is an automatic detection whether it has been +crypted. Vim will then prompt for the key. + +Note that the encryption method is not compatible with Vi. The encryption is +not unbreakable. This allows it to be exported from the US. + + +GTK GUI port *new-GTK-GUI* +------------ + +New GUI port for GTK+. Includes a toolbar, menu tearoffs, etc. |gui-gtk| +Added the |:helpfind| command. (Kahn and Dalecki) + + +Menu changes *menu-changes-5.4* +------------ + +Menus can now also be used in the console. It is enabled by the new +'wildmenu' option. This shows matches for command-line completion like a +menu. This works as a minimal file browser. + +The new |:emenu| command can be used to execute a menu item. + +Uses the last status line to list items, or inserts a line just above the +command line. (Negri) + +The 'wildcharx' option can be used to trigger 'wildmenu' completion from a +mapping. + +When compiled without menus, this can be detected with has("menu"). Also show +this in the ":version" output. Allow compiling GUI versions without menu +support. Only include toolbar support when there is menu support. + +Moved the "Window" menu all the way to the right (priority 70). Looks more +familiar for people working with MS-Windows, shouldn't matter for others. + +Included "Buffers" menu. Works with existing autocommands and functions. It +can be disabled by setting the "no_buffers_menu" variable. (Aaron and Madsen) + +Win32 supports separators in a menu: "-.*-". (Geddes) +Menu separators for Motif now work too. + +Made Popup menu for Motif GUI work. (Madsen) + +'M' flag in 'guioptions': Don't source the system menu. + +All the menu code has been moved from gui.c to menu.c. + + +Viminfo improved *improved-viminfo* +---------------- + +New flags for 'viminfo': +'!' Store global variables in the viminfo file if they are in uppercase + letters. (Negri) +'h' Do ":nohlsearch" when loading a viminfo file. + +Store search patterns in the viminfo file with their offset, magic, etc. Also +store the flag whether 'hlsearch' highlighting is on or off (which is not used +if the 'h' flag is in 'viminfo'). + +Give an error message when setting 'viminfo' without commas. + + +Various new commands *new-commands-5.4* +-------------------- + +Operator |g?|: rot13 encoding. (Negri) + +|zH| and |zL| commands: Horizontal scrolling by half a page. +|gm| move cursor to middle of screen line. (Ideas by Campbell) + +Operations on Visual blocks: |v_b_I|, |v_b_A|, |v_b_c|, |v_b_C|, |v_b_r|, +|v_b_<| and |v_b_>|. (Kelly) + +New command: CTRL-\ CTRL-N, which does nothing in Normal mode, and goes to +Normal mode when in Insert or Command-line mode. Can be used by VisVim or +other OLE programs to make sure Vim is in Normal mode, without causing a beep. +|CTRL-\_CTRL-N| + +":cscope kill" command to use the connection filename. |:cscope| (Kahn) + +|:startinsert| command: Start Insert mode next. + +|:history| command, to show all four types of histories. (Roemer) + +|[m|, |[M|, |]m| and |]M| commands, for jumping backward/forward to start/end +of method in a (Java) class. + +":@*" executes the * register. |:@| (Acevedo) + +|go| and |:goto| commands: Jump to byte offset in the file. + +|gR| and |gr| command: Virtual Replace mode. Replace characters without +changing the layout. (Webb) + +":cd -" changes to the directory from before the previous ":cd" command. +|:cd-| (Webb) + +Tag preview commands |:ptag|. Shows the result of a ":tag" in a dedicated +window. Can be used to see the context of the tag (e.g., function arguments). +(Negri) +|:pclose| command, and CTRL-W CTRL-Z: Close preview window. (Moore) +'previewheight' option, height for the preview window. +Also |:ppop|, |:ptnext|, |:ptprevious|, |:ptNext|, |:ptrewind|, |:ptlast|. + +|:find| and |:sfind| commands: Find a file in 'path', (split window) and edit +it. + +The |:options| command opens an option window that shows the current option +values. Or use ":browse set" to open it. Options are grouped by function. +Offers short help on each option. Hit <CR> to jump to more help. Edit the +option value and hit <CR> on a "set" line to set a new value. + + +Various new options *new-options-5.4* +------------------- + +Scroll-binding: 'scrollbind' and 'scrollopt' options. Added |:syncbind| +command. Makes windows scroll the same amount (horizontally and/or +vertically). (Ralston) + +'conskey' option for MS-DOS. Use direct console I/O. This should work with +telnet (untested!). + +'statusline' option: Configurable contents of the status line. Also allows +showing the byte offset in the file. Highlighting with %1* to %9*, using the +new highlight groups User1 to User9. (Madsen) + +'rulerformat' option: Configurable contents of the ruler, like 'statusline'. +(Madsen) + +'write' option: When off, writing files is not allowed. Avoids overwriting a +file even with ":w!". The |-m| command line option resets 'write'. + +'clipboard' option: How the clipboard is used. Value "unnamed": Use unnamed +register like "*. (Cortopassi) Value "autoselect": Like what 'a' in +'guioptions' does but works in the terminal. + +'guifontset' option: Specify fonts for the +fontset feature, for the X11 GUI +versions. Allows using normal fonts when vim is compiled with this feature. +(Nam) + +'guiheadroom' option: How much room to allow above/below the GUI window. +Used for Motif, Athena and GTK. + +Implemented 'tagstack' option: When off, pushing tags onto the stack is +disabled (Vi compatible). Useful for mappings. + +'shellslash' option. Only for systems that use a backslash as a file +separator. This option will use a forward slash in file names when expanding +it. Useful when 'shell' is sh or csh. + +'pastetoggle' option: Key sequence that toggles 'paste'. Works around the +problem that mappings don't work in Insert mode when 'paste' is set. + +'display' option: When set to "lastline", the last line fills the window, +instead of being replaced with "@" lines. Only the last three characters are +replaced with "@@@", to indicate that the line has not finished yet. + +'switchbuf' option: Allows re-using existing windows on a buffer that is being +jumped to, or split the window to open a new buffer. (Roemer) + +'titleold' option. Replaces the fixed string "Thanks for flying Vim", which +is used to set the title when exiting. (Schild) + + +Vim scripts *new-script-5.4* +----------- + +The |exists()| function can also check for existence of a function. (Roemer) +An internal function is now found with a binary search, should be a bit +faster. (Roemer) + +New functions: +- |getwinposx()| and |getwinposy()|: get Vim window position. (Webb) +- |histnr()|, |histadd()|, |histget()| and |histdel()|: Make history + available. (Roemer) +- |maparg()|: Returns rhs of a mapping. Based on a patch from Vikas. +- |mapcheck()|: Check if a map name matches with an existing one. +- |visualmode()|: Return type of last Visual mode. (Webb) +- |libcall()|: Call a function in a library. Currently only for Win32. (Negri) +- |bufwinnr()|: find window that contains the specified buffer. (Roemer) +- |bufloaded()|: Whether a buffer exists and is loaded. +- |localtime()| and |getftime()|: wall clock time and last modification time + of a file (Webb) +- |glob()|: expand file name wildcards only. +- |system()|: get the raw output of an external command. (based on a patch + from Aaron). +- |strtrans()|: Translate String into printable characters. Used for + 2html.vim script. +- |append()|: easy way to append a line of text in a buffer. + +Changed functions: +- Optional argument to |strftime()| to give the time in seconds. (Webb) +- |expand()| now also returns names for files that don't exist. + +Allow numbers in the name of a user command. (Webb) + +Use "v:" for internal Vim variables: "v:errmsg", "v:shell_error", etc. The +ones from version 5.3 can be used without "v:" too, for backwards +compatibility. + +New variables: +"v:warningmsg" and "v:statusmsg" internal variables. Contain the last given +warning and status message. |v:warningmsg| |v:statusmsg| (Madsen) +"v:count1" variable: like "v:count", but defaults to one when no count is +used. |v:count1| + +When compiling without expression evaluation, "if 1" can be used around the +not supported commands to avoid it being executed. Works like in Vim 4.x. +Some of the runtime scripts gave errors when used with a Vim that was compiled +with minimal features. Now "if 1" is used around code that is not always +supported. + +When evaluating an expression with && and ||, skip the parts that will not +influence the outcome. This makes it faster and avoids error messages. (Webb) +Also optimized the skipping of expressions inside an "if 0". + + +Avoid hit-enter prompt *avoid-hit-enter* +----------------------- + +Added 'T' flag to 'shortmess': Truncate all messages that would cause the +hit-enter prompt (unless that would happen anyway). +The 'O' flag in 'shortmess' now also applies to quickfix messages, e.g., from +the ":cn" command. + +The default for 'shortmess' is now "filnxtToO", to make most messages fit on +the command line, and not cause the hit-enter prompt. + +Previous messages can be viewed with the new |:messages| command. + +Some messages are shown fully, even when 'shortmess' tells to shorten +messages, because the user is expected to want to see them in full: CTRL-G and +some quickfix commands. + + +Improved quickfix *improved-quickfix* +----------------- + +Parse change-directory lines for gmake: "make[1]: Entering directory 'name'". +Uses "%D" and "%X" in 'errorformat'. +Also parse "Making {target} in {dir}" messages from make. Helps when not +using GNU make. (Schandl) + +Use 'isfname' for "%f" in 'errorformat'. + +Parsing of multi-line messages. |errorformat-multi-line| + +Allow a range for the |:clist| command. (Roemer) + +Support for "global" file names, for error formats that output the file name +once for several errors. (Roemer) + +|:cnfile| jumps to first error in next file. + +"$*" in 'makeprg' is replaced by arguments to ":make". (Roemer) + + +Regular expressions *regexp-changes-5.4* +------------------- + +In a regexp, a '$' before "\)" is also considered to be an end-of-line. |/$| +In patterns "^" after "\|" or "\(" is a start-of-line. |/^| (Robinson) + +In a regexp, in front of "\)" and "\|" both "$" and "\$" were considered +end-of-line. Now use "$" as end-of-line and "\$" for a literal dollar. Same +for '^' after "\(" and "\|". |/\$| |/\^| + +Some search patterns can be extremely slow, even though they are not really +illegal. For example: "\([^a-z]\+\)\+Q". Allow interrupting any regexp +search with CTRL-C. + +Register "/: last search string (read-only). (Kohan) Changed to use last used +search pattern (like what 'hlsearch' uses). Can set the search pattern with +":let @/ = {expr}". + +Added character classes to search patterns, to avoid the need for removing the +'l' flag from 'cpoptions': |[:tab:]|, |[:return:]|, |[:backspace:]| and +|[:escape:]|. + +By adding a '?' after a comparative operator in an expression, the comparison +is done by ignoring case. |expr-==?| + + +Other improvements made between version 5.3 and 5.4 +--------------------------------------------------- + +Changed *changed-5.4* +------- + +Unix: Use $TMPDIR for temporary files, if it is set and exists. + +Removed "Empty buffer" message. It isn't useful and can cause a hit-enter +prompt. (Negri) + +"ex -" now reads commands from stdin and works in silent mode. This is to be +compatible with the original "ex" command that is used for scripts. + +Default range for ":tcldo" is the whole file. + +Cancelling Visual mode with ESC moved the cursor. There appears to be no +reason for this. Now leave the cursor where it is. + +The ":grep" and ":make" commands see " as part of the arguments, instead of +the start of a comment. + +In expressions the "=~" and "!~" operators no longer are affected by +'ignorecase'. + +Renamed vimrc_example to vimrc_example.vim and gvimrc_example to +gvimrc_example.vim. Makes them being recognized as vim scripts. + +"gd" no longer starts searching at the end of the previous function, but at +the first blank line above the start of the current function. Avoids that +using "gd" in the first function finds global a variable. + +Default for 'complete' changed from ".,b" to ".,w,b,u,t,i". Many more matches +will be found, at the cost of time (the search can be interrupted). + +It is no longer possible to set 'shell*' options from a modeline. Previously +only a warning message was given. This reduces security risks. + +The ordering of the index of documentation files was changed to make it more +easy to find a subject. + +On MS-DOS and win32, when $VIM was not set, $HOME was used. This caused +trouble if $HOME was set to e.g., "C:\" for some other tool, the runtime files +would not be found. Now use $HOME only for _vimrc, _gvimrc, etc., not to find +the runtime file. + +When 'tags' is "./{fname}" and there is no file name for the current buffer, +just use it. Previously it was skipped, causing "vim -t {tag}" not to find +many tags. + +When trying to select text in the 'scrolloff' area by mouse dragging, the +resulting scrolling made this difficult. Now 'scrolloff' is temporarily set +to 0 or 1 to avoid this. But still allow scrolling in the top line to extend +to above the displayed text. + +Default for 'comments' now includes "sl:/*,mb: *,ex:*/", to make javadoc +comments work. Also helps for C comments that start with "/*******". + +CTRL-X CTRL-] Insert mode tag expansion tried to expand to all tags when used +after a non-ID character, which can take a very long time. Now limit this to +200 matches. Also used for command-line tag completion. + +The OS/2 distribution has been split in two files. It was too big to fit on a +floppy. The same runtime archive as for the PC is now used. + +In the documentation, items like <a-z> have been replaced with {a-z} for +non-optional arguments. This avoids confusion with key names: <C-Z> is a +CTRL-Z, not a character between C and Z, that is {C-Z}. + + +Added *added-5.4* +----- + +Color support for the iris-ansi builtin termcap entry. (Tubman) + +Included VisVim version 1.3a. (Erhardt) + +Win32 port for SNiFF+ interface. (Leherbauer) +Documentation file for sniff interface: if_sniff.txt. (Leherbauer) + +Included the "SendToVim" and "OpenWithVim" programs in the OleVim directory. +To be used with the OLE version of gvim under MS-Windows. (Schaller) + +Included Exuberant Ctags version 3.2.4 with Eiffel support. (Hiebert) + +When a file that is being edited is deleted, give a warning (like when the +time stamp changed). + +Included newer versions of the HTML-generating Awk and Perl scripts. (Colombo) + +Linux console mouse support through "gpm". (Tsindlekht) + +Security fix: Disallow changing 'secure' and 'exrc' from a modeline. When +'secure' is set, give a warning for changing options that contain a program +name. + +Made the Perl interface work with Perl 5.005 and threads. (Verdoolaege) + +When giving an error message for an ambiguous mapping, include the offending +mapping. (Roemer) + +Command line editing: +- Command line completion of mappings. (Roemer) +- Command line completion for ":function", ":delfunction", ":let", ":call", + ":if", etc. (Roemer) +- When using CTRL-D completion for user commands that have + "-complete=tag_listfiles" also list the file names. (Madsen) +- Complete the arguments of the ":command" command. (Webb) +- CTRL-R . in command line inserts last inserted text. CTRL-F, CTRL-P, CTRL-W + and CTRL-A after CTRL-R are used to insert an object from under the cursor. + (Madsen) + +Made the text in uganda.txt about copying Vim a bit more clear. + +Updated the Vim tutor. Added the "vimtutor" command, which copies the tutor +and starts Vim on it. "make install" now also copies the tutor. + +In the output of ":clist" the current entry is highlighted, with the 'i' +highlighting (same as used for 'incsearch'). + +For the ":clist" command, you can scroll backwards with "b" (one screenful), +"u" (half a screenful) and "k" (one line). + +Multi-byte support: +- X-input method for multi-byte characters. And various fixes for multi-byte + support. (Nam) +- Hangul input method feature: |hangul|. (Nam) +- Cleaned up configuration of multi-byte support, XIM, fontset and Hangul + input. Each is now configurable separately. +- Changed check for GTK_KEYBOARD to HANGUL_KEYBOARD_TYPE. (Nam) +- Added doc/hangulin.txt: Documentation for the Hangul input code. (Nam) +- XIM support for GTK+. (Nam) +- First attempt to include support for SJIS encoding. (Nagano) +- When a double-byte character doesn't fit at the end of the line, put a "~" + there and print it on the next line. +- Optimize output of multi-byte text. (Park) +- Win32 IME: preedit style is like over-the-spot. (Nagano) +- Win32 IME: IME mode change now done with ImmSetOpenStatus. (Nagano) +- GUI Athena: file selection dialog can display multi-byte characters. + (Nagano) +- Selection reply for XA_TEXT as XA_STRING. (Nagano) + +"runtime/macros/diffwin.vim". Mappings to make a diff window. (Campbell) + +Added ".obj" to the 'suffixes' option. + +Reduced size of syntax/synload.vim by using the ":SynAu" user command. +Automated numbering of Syntax menu entries in menu.vim. +In the Syntax menu, insert separators between syntax names that start with +a different letter. (Geddes) + +Xterm: +- Clipboard support when using the mouse in an xterm. (Madsen) +- When using the xterm mouse, track dragging of the mouse. Use xterm escape + sequences when possible. It is more precise than other methods, but + requires a fairly recent xterm version. It is enabled with "xterm2" in + 'ttymouse'. (Madsen) +- Check xterm patch level, to set the value of 'ttymouse'. Has only been + added to xterm recently (patch level > 95). Uses the new 't_RV' termcap + option. Set 'ttymouse' to "xterm2" when a correct response is recognized. + Will make xterm mouse dragging work better. +- Support for shifted function keys on xterm. Changed codes for shifted + cursor keys to what the xterm actually produces. Added codes for shifted + <End> and <Home>. +- Added 't_WP' to set the window position in pixels and 't_WS' to set the + window size in characters. Xterm can now move (used for ":winpos") and + resize (use for ":set lines=" and ":set columns="). + +X11: +- When in Visual mode but not owning the selection, display the Visual area + with the VisualNOS group to show this. (Madsen) +- Support for requesting the type of clipboard support. Used for AIX and + dtterm. (Wittig) +- Support compound_text selection (even when compiled without multi-byte). + +Swap file: +- New variation for naming swap files: Replace path separators into %, place + all swap files in one directory. Used when a name in 'dir' ends in two path + separators. (Madsen) +- When a swap file is found, show whether it contains modifications or not in + the informative message. (Madsen) +- When dialogs are supported, use a dialog to ask the user what to do when a + swapfile already exists. + +"popup_setpos" in 'mousemodel' option. Allows for moving the cursor when +using the right mouse button. + +When a buffer is deleted, the selection for which buffer to display instead +now uses the most recent entry from the jump list. (Madsen) + +When using CTRL-O/CTRL-I, skip deleted buffers. + +A percentage is shown in the ruler, when there is room. + +Used autoconf 1.13 to generate configure. + +Included get_lisp_indent() from Dirk van Deun. Does better Lisp indenting +when 'p' flag in 'cpoptions' is not included. + +Made the 2html.vim script quite a bit faster. (based on ideas from Geddes) + +Unix: +- Included the name of the user that compiled Vim and the system name it was + compiled on in the version message. +- "make install" now also installs the "tools" directory. Makes them + available for everybody. +- "make check" now does the same as "make test". "make test" checks for + Visual block mode shift, insert, replace and change. +- Speed up comparing a file name with existing buffers by storing the + device/inode number with the buffer. +- Added configure arguments "--disable-gtk", "--disable-motif" and + "--disable-athena", to be able to disable a specific GUI (when it doesn't + work). +- Renamed the configure arguments for disabling the check for specific GUIs. + Should be clearer now. (Kahn) +- On a Digital Unix system ("OSF1") check for the curses library before + termlib and termcap. (Schild) +- "make uninstall_runtime" will only delete the version-specific files. Can + be used to delete the runtime files of a previous version. + +Macintosh: (St-Amant) +- Dragging the scrollbar, like it's done for the Win32 GUI. Moved common code + from gui_w32.c to gui.c +- Added dialogs and file browsing. +- Resource fork preserved, warning when it will be lost. +- Copy original file attributes to newly written file. +- Set title/notitle bug solved. +- Filename completion improved. +- Grow box limit resize to a char by char size. +- Use of rgb.txt for more colors (but give back bad color). +- Apple menu works (beside the about...). +- Internal border now vim compliant. +- Removing a menu doesn't crash anymore. +- Weak-linking of Python 1.5.1 (only on PPC). Python is supported when the + library is available. +- If an error is encountered when sourcing the users .vimrc, the alert box now + shows right away with the OK button defaulted. There's no more "Delete"-key + sign at the start of each line +- Better management of environment variables. Now $VIM is calculated only + once, not regenerated every time it is used. +- No more CPU hog when in background. +- In a sourced Vim script the Mac file format can be recognized, just like DOS + file format is. + +When both "unix" and "mac" are present in 'fileformats', prefer "mac" format +when there are more CR than NL characters. +When using "mac" fileformat, use CR instead of a NL, because NL is used for +NUL. Will preserve all characters in a file. (Madsen) + +The DOS install.exe now contains checks for an existing installation. It +avoids setting $VIM and $PATH again. +The install program for Dos/Windows can now install Vim in the popup menu, by +adding two registry keys. + +Port to EGCS/mingw32. New Makefile.ming. (Aaron) + +DOS 16 bit: Don't include cursor shape stuff. Save some bytes. + +TCL support to Makefile.w32. (Duperval) + +OS/2: Use argv[0] to find runtime files. + +When using "gf" to go to a buffer that has already been used, jump to the +line where the cursor last was. + +Colored the output of ":tselect" a bit more. Different highlighting between +tag name and file name. Highlight field name ("struct:") separately from +argument. + +Backtick expansion for non-Unix systems. Based on a patch from Aaron. +Allows the use of things like ":n `grep -l test *.c`" and +"echo expand('`ls m*`')". + +Check for the 'complete' option when it is set. (Acevedo) +'d' flag in 'complete' searches for defined names or macros. +While searching for Insert mode completions in include files and tags files, +check for typeahead, so that you can use matches early. (Webb) +The '.' flag in 'complete' now scans the current buffer completely, ignoring +'nowrapscan'. (Webb) + +Added '~' flag to 'whichwrap'. (Acevedo) + +When ending the Visual mode (e.g., with ESC) don't grab ownership of the +selection. + +In a color terminal, "fg" and "bg" can be used as color names. They stand for +the "Normal" colors. + +A few cscope cleanups. (Kahn) + +Included changed vimspell.sh from Schemenauer. + +Concatenation of strings in an expression with "." is a bit faster. (Roemer) + +The ":redir" command can now redirect to a register: ":redir @r". (Roemer) + +Made the output of ":marks" and ":jumps" look similar. When the mark is in +the current file, show the text at the mark. Also for ":tags". + +When configure finds ftello() and fseeko(), they are used in tag.c (for when +you have extremely big tags files). + +Configure check for "-FOlimit,2000" argument for the compiler. (Borsenkow) + +GUI: +- When using ":gui" in a non-GUI Vim, give a clear error message. +- "gvim -v" doesn't start the GUI (if console support is present). +- When in Ex mode, use non-Visual selection for the whole screen. +- When starting with "gvim -f" and using ":gui" in the .gvimrc file, Vim + forked anyway. Now the "-f" flag is remembered for ":gui". Added "gui -b" + to run gvim in the background anyway. + +Motif GUI: +- Check for "-lXp" library in configure (but it doesn't work yet...). +- Let configure check for Lesstif in "/usr/local/Lesstif/Motif*". Changed the + order to let a local Motif version override a system standard version. + +Win32 GUI: +- When using "-register" or "-unregister" in the non-OLE version, give an + error message. +- Use GTK toolbar icons. Make window border look better. Use sizing handles + on the lower left&right corners of the window. (Negri) +- When starting an external command with ":!start" and the command can not be + executed, give an error message. (Webb) +- Use sizing handles for the grey rectangles below the scrollbars. Can draw + toolbar in flat mode now, looks better. (Negri) +- Preparations for MS-Windows 3.1 addition. Mostly changing WIN32 to MSWIN + and USE_GUI_WIN32 to USE_GUI_MSWIN. (Negri) + +Avoid allocating the same string four times in buflist_findpat(). (Williams) + +Set title and icon text with termcap options 't_ts', 't_fs', 't_IS' and +'t_IE'. Allows doing this on any terminal that supports setting the title +and/or icon text. (Schild) + +New 'x' flag in 'comments': Automatically insert the end part when its last +character is typed. Helps to close a /* */ comment in C. (Webb) + +When expand() has a second argument which is non-zero, don't use 'suffixes' +and 'wildignore', return all matches. + +'O' flag in 'cpoptions: When not included, Vim will not overwrite a file, if +it didn't exist when editing started but it does exist when the buffer is +written to the file. The file must have been created outside of Vim, possibly +without the user knowing it. When this is detected after a shell command, +give a warning message. + +When editing a new file, CTRL-G will show [New file]. When there were errors +while reading the file, CTRL-G will show [Read errors]. + +":wall" can now use a dialog and file-browsing when needed. + +Grouped functionality into new features, mainly to reduce the size of the +minimal version: ++linebreak: 'showbreak', 'breakat' and 'linebreak' ++visualextra: "I"nsert and "A"ppend in Visual block mode, "c"hange all lines + in a block, ">" and "<": Shifting a block, "r": Replacing a + Visual area with one character. ++comments: 'comments' ++cmdline_info: 'ruler' and 'showcmd'. Replaces +showcmd. +"+title" Don't add code to set title or icon for MSDOS, this was not + possible anyway. ++cmdline_compl Disable commandline completion at compile time, except for + files, directories and help items. + +Moved features from a list of function calls into an array. Should save a bit +of space. + +While entering the body of a function, adjust indent according to "if" and +"while" commands. + +VMS: Adjusted os_vms.mms a bit according to suggestions from Arpadffy. + +The flags in the 'comments' option can now include an offset. This makes it +possible to align "/*****", "/* xxx" and "/*" comments with the same +'comments' setting. The default value for 'comments' uses this. +Added 'O' flag: Don't use this part for the "O" command. Useful for "set +com=sO:*\ -,mO:*\ \ ,exO:*/" + +FileType autocommands recognize ".bak", ".orig" and "~" extensions and remove +them to find the relevant extension. + +The tutorial for writing a Vim script file has been extended. + +Some more highlighting in help files, for items that are not typed literally. + +Can use "CTRL-W CTRL-G" like "CTRL-W g". + +"make test" for OS/2. + +Adjusted configure to automatically use the GUI for BeOS. + + +Fixed *fixed-5.4* +----- + +5.3.1: When using an autocommand for BufWritePre that changes the name of the +buffer, freed memory would be used. (Geddes) + +Mac: Compiler didn't understand start of skip_class_name(). + +Win32 GUI: +- When cancelling the font requester, don't give an error message. +- When a tearoff-menu is open and its menu is deleted, Vim could crash. + (Negri) +- There was a problem on Windows 95 with (un)maximizing the window. + (Williams) +- when 'mousehide' is set, the mouse would stay hidden when a menu is dropped + with the keyboard. (Ralston) +- The tempname() function already created the file. Caused problems when + using ":w". Now the file is deleted. +- Cursor disappeared when ending up in the top-left character on the screen + after scrolling. (Webb) +- When adding a submenu for a torn-off menu, it was not updated. +- Menu tooltip was using the toolbar tooltip. (Negri) +- Setting 'notitle' didn't remove the title. (Steed) +- Using ":!start cmd" scrolled the screen one line up, and didn't wait for + return when the command wasn't found. + +Cscope interface: Sorting of matches was wrong. Starting the interface could +fail. (Kahn) + +Motif GUI: Could not compile with Motif 1.1, because some tear-off +functionality was not in #ifdefs. + +Configure could sometimes not compile or link the test program for sizeof(int) +properly. This caused alignment problems for the undo structure allocations. +Added a safety check that SIZEOF_INT is not zero. + +Added configure check to test if strings.h can be included after string.h. +Some systems can't handle it. +Some systems need both string.h and strings.h included. Adjusted vim.h for +that. Removed including string.h from os_unixx.h, since it's already in +vim.h. (Savage) +AIX: defining _NO_PROTO in os_unix.h causes a conflict between string.h and +strings.h, but after the configure check said it was OK. Also define +_NO_PROTO for AIX in the configure check. (Winn) + +When closing a window with CTRL-W c, the value of 'hidden' was not taken into +account, the buffer was always unloaded. (Negri) + +Unix Makefile: "make install" always tried to rename an older executable and +remove it. This caused an error message when it didn't exit. Added a check +for the existence of an old executable. +The command line for "make install" could get too long, because of the many +syntax files. Now first do a "cd" to reduce the length. + +On RISCOS and MSDOS, reading a file could fail, because the short filename was +used, which can be wrong after a ":!cd". + +In the DOS versions, the wrong install.exe was included (required Windows). +Now the install.exe version is included that is the same as the Vim version. +This also supports long file names where possible. + +When recording, and stopping while in Insert mode with CTRL-O q, the CTRL-O +would also be recorded. + +32bit DOS version: "vim \file", while in a subdirectory, resulted in "new +file" for "file" in the local directory, while "\file" did exist. When +"file" in the current directory existed, this didn't happen. + +MSDOS: Mouse could not go beyond 80 columns in 132 columns mode. (Young) + +"make test" failed in the RedHat RPM, because compatible is off by default. + +In Insert mode <C-O><C-W><C-W> changes to other window, but the status bars +were not updated until another character was typed. + +MSDOS: environment options in lowercase didn't work, although they did in the +Win32 versions. (Negri) + +After ":nohlsearch", a tag command switched highlighting back on. + +When using "append" command as the last line in an autocommand, Vim would +crash. + +RISCOS: The scroll bumpers (?) were not working properly. (Leonard) + +"zl" and "zh" could move the cursor, but this didn't set the column in which +e.g., "k" would move the cursor. + +When doing ":set all&" the value of 'scroll' was not set correctly. This +caused an error message when later setting any other number option. + +When 'hlsearch' highlighting has been disabled with ":nohlsearch", +incremental searching would switch it back on too early. + +When listing tags for ":tselect", and using a non-search command, and the last +character was equal to the first (e.g., "99"), the last char would not be +shown. + +When searching for tags with ":tag" Vim would assume that all matches had been +found when there were still more (e.g. from another tags file). + +Win32: Didn't recognize "c:\" (e.g., in tags file) as absolute path when +upper/lowercase was different. + +Some xterms (Debian) send <Esc>OH for HOME and <Esc>OF for END. Added these +to the builtin-xterm. + +In ex mode, any CR was seen as the end of the line. Only a NL should be +handled that way. broke ":s/foo/some^Mtext/". + +In menu.vim, a vmenu was used to override an amenu. That didn't work, because +the system menu file doesn't overwrite existing menus. Added explicit vunmenu +to solve this. + +Configure check for terminal library could find a library that doesn't work at +runtime (Solaris: shared library not found). Added a check that a program +with tgoto() can run correctly. + +Unix: "echo -n" in the Makefile doesn't work on all systems, causing errors +compiling pathdef.c. Replaced it with "tr". + +Perl: DO_JOIN was redefined by Perl. Undefined it in the perl files. + +Various XIM and multi-byte fixes: +- Fix user cannot see his language while he is typing his language with + off-the-spot method. (Nagano) +- Fix preedit position using text/edit area (using gui.wid). (Nagano) +- remove 'fix dead key' codes. It was needed since XNFocusWindow was + "x11_window", XNFocusWindow is now gui.wid. (Nagano) +- Remove some compile warnings and fix typos. (Namsh) +- For status area, check the gtk+ version while Vim runs. I believe it is + better than compile time check. (Namsh) +- Remove one FIXME for gtk+-xim. (Namsh) +- XIM: Dead keys didn't work for Czech. (Vyskovsky) +- Multibyte: If user input only 3byte such as mb1_mb2_eng or eng_mb1_mb2 VIM + could convert it to special character. (Nam) +- Athena/Motif with XIM: fix preedit area. (Nam) +- XIM: Composed strings were sometimes ignored. Vim crashed when compose + string was longer than 256 bytes. IM's geometry control is fixed. (Nam, + Nagano) +- Win32 multi-byte: hollowed cursor width on a double byte char was wrong. + (Nagano) +- When there is no GUI, selecting XIM caused compilation problems. + Automatically disable XIM when there is no GUI in configure. +- Motif and Athena: When compiled with XIM, but the input method was not + enabled, there would still be a status line. Now the status line is gone if + the input method doesn't work. (Nam) + +Win32: tooltip was not removed when selecting a parent menu (it was when +selecting a menu entry). (Negri) + +Unix with X: Some systems crash on exit, because of the XtCloseDisplay() call. +Removed it, it should not be necessary when exiting. + +Win32: Crash on keypress when compiled with Borland C++. (Aaron) + +When checking for Motif library files, prefer the same location as the include +files (with "include" replaced with "lib") above another entry. + +Athena GUI: Changed "XtOffset()" in gui_at_fs.c to "XtOffsetOf()", like it's +used in gui_x11.c. + +Win32: When testing for a timestamp of a file on floppy, would get a dialog +box when the floppy has been removed. Now return with an error. (Negri) + +Win32 OLE: When forced to come to the foreground, a minimized window was still +minimized, now it's restored. (Zivkov) + +There was no check for a positive 'shiftwidth'. A negative value could cause +a hangup, a zero value a crash. + +Athena GUI: horizontal scrollbar wasn't updated correctly when clicking right +or left of the thumb. + +When making a Visual-block selection in one window, and trying to scroll +another, could cause errors for accessing non-existent line numbers. + +When 'matchpairs' contains "`:'", jumping from the ` to the ' didn't work +properly. + +Changed '\"' to '"' to make it compatible with old C compilers. + +The command line expansion for mappings caused a script with a TAB between lhs +and rhs of a map command to fail. Assume the TAB is to separate lhs and rhs +when there are no mappings to expand. + +When editing a file with very long lines with 'scrolloff' set, "j" would +sometimes end up in a line which wasn't displayed. + +When editing a read-only file, it was completely read into memory, even when +it would not fit. Now create a swap file for a read-only file when running +out of memory while reading the file. + +When using ":set cino={s,e-s", a line after "} else {" was not indented +properly. Also added a check for this in test3.in. + +The Hebrew mapping for the command line was remembered for the next command +line. That isn't very useful, a command is not Hebrew. (Kol) + +When completing file names with embedded spaces, like "Program\ files", this +didn't work. Also for user commands. Moved backslash_halve() down to +mch_expandpath(). + +When using "set mouse=a" in Ex mode, mouse events were handled like typed +text. Then typing "quit" screwed up the mouse behavior of the xterm. + +When repeating an insert with "." that contains a CTRL-Y, a number 5 was +inserted as "053". + +Yanking a Visual area, with the cursor past the line, didn't move the cursor +back onto the line. Same for "~", "u", "U" and "g?" + +Win32: Default for 'grepprg' could be "findstr /n" even though there is no +findstr.exe (Windows 95). Check if it exists, and fall back to "grep -n" if +it doesn't. + +Because gui_mouse_moved() inserted a leftmouse click in the input buffer, +remapping a leftmouse click caused strange effects. Now Insert another code +in the input buffer. Also insert a leftmouse release, to avoid the problem +with ":map <LeftMouse> l" that the next release is seen as the release for the +focus click. + +With 'wrap' on, when using a line that doesn't fit on the screen, if the start +of the Visual area is before the start of the screen, there was no +highlighting. Also, 'showbreak' doesn't work properly. + +DOS, Win32: A pattern "[0-9]\+" didn't work in autocommands. + +When creating a swap file for a buffer which isn't the current buffer, could +get a mixup of short file name, resulting in a long file name when a short +file name was required. makeswapname() was calling modname() instead of +buf_modname(). + +When a function caused an error, and the error message was very long because +of recursiveness, this would cause a crash. + +'suffixes' were always compared with matching case. For MS-DOS, Win32 and +OS/2 case is now ignored. + +The use of CHARBITS in regexp.c didn't work on some Linux. Don't use it. + +When generating a script file, 'cpo' was made empty. This caused backslashes +to disappear from mappings. Set it to "B" to avoid that. + +Lots of typos in the documentation. (Campbell) + +When editing an existing (hidden) buffer, jump to the last used cursor +position. (Madsen) + +On a Sun the xterm screen was not restored properly when suspending. (Madsen) + +When $VIMINIT is processed, 'nocompatible' was only set after processing it. + +Unix: Polling for a character wasn't done for GPM, Sniff and Xterm clipboard +all together. Cleaned up the code for using select() too. + +When executing external commands from the GUI, some typeahead was lost. Added +some code to regain as much typeahead as possible. + +When the window height is 5 lines or fewer, <PageDown> didn't use a one-line +overlap, while <PageUp> does. Made sure that <PageUp> uses the same overlap +as <PageDown>, so that using them both always displays the same lines. + +Removed a few unused functions and variables (found with lint). + +Dictionary completion didn't use 'infercase'. (Raul) + +Configure tests failed when the Perl library was not in LD_LIBRARY_PATH. +Don't use the Perl library for configure tests, add it to the linker line only +when linking Vim. + +When using ncurses/terminfo, could get a 't_Sf' and 't_Sb' termcap entry that +has "%d" instead of "%p1%d". The light background colors didn't work then. + +GTK GUI with ncurses: Crashed when starting up in tputs(). Don't use tputs() +when the GUI is active. + +Could use the ":let" command to set the "count", "shell_error" and "version" +variables, but that didn't work. Give an error message when trying to set +them. + +On FreeBSD 3.0, tclsh is called tclsh8.0. Adjusted configure.in to find it. + +When Vim is linked with -lncurses, but python uses -ltermcap, this causes +trouble: "OOPS". Configure now removes the -ltermcap. + +:@" and :*" didn't work properly, because the " was recognized as the start of +a comment. + +Win32s GUI: Minimizing the console where a filter command runs in caused +trouble for detecting that the filter command has finished. (Negri) + +After executing a filter command from an xterm, the mouse would be disabled. +It would work again after changing the mode. + +Mac GUI: Crashed in newenv(). (St-Amant) + +The menus and mappings in mswin.vim didn't handle text ending in a NL +correctly. (Acevedo) + +The ":k" command didn't check if it had a valid argument or extra characters. +Now give a meaningful error message. (Webb) + +On SGI, the signal function doesn't always have three arguments. Check for +struct sigcontext to find out. Might still be wrong... + +Could crash when using 'hlsearch' and search pattern is "^". + +When search patterns were saved and restored, status of no_hlsearch was not +also saved and restored (from ":nohlsearch" command). + +When using setline() to make a line shorter, the cursor position was not +adjusted. + +MS-DOS and Win95: When trying to edit a file and accidentally adding a slash +or backslash at the end, the file was deleted. Probably when trying to create +the swap file. Explicitly check for a trailing slash or backslash before +trying to read a file. + +X11 GUI: When starting the GUI failed and received a deadly signal while +setting the title, would lock up when trying to exit, because the title is +reset again. Avoid using mch_settitle() recursively. + +X11 GUI: When starting the GUI fails, and then trying it again, would crash, +because argv[] has been freed and x11_display was reset to NULL. + +Win32: When $HOME was set, would put "~user" in the swap file, which would +never compare with a file name, and never cause the attention message. Put +the full path in the swap file instead. + +Win32 console: There were funny characters at the end of the "vim -r" swap +files message (direct output of CR CR LF). + +DOS 32 bit: "vim -r" put the text at the top of the window. + +GUI: With 'mousefocus' set, got mouse codes as text with "!sleep 100" or "Q". + +Motif and Win32 GUI: When changing 'guifont' to a font of the same size the +screen wasn't redrawn. + +Unix: When using ":make", jumping to a file b.c, which is already open as a +symbolic link a.c, opened a new buffer instead of using the existing one. + +Inserting text in the current buffer while sourcing the .vimrc file would +cause a crash or hang. The memfile for the current buffer was never +allocated. Now it's allocated as soon as something is written in the buffer. + +DOS 32 bit: "lightblue" background worked for text, but not drawn parts were +black. + +DOS: Colors of console were not restored upon exiting. + +When recording, with 'cmdheight' set to 2 and typing Esc> in Insert mode +caused the "recording" message to be doubled. + +Spurious "file changed" messages could happen on Windows. Now tolerate a one +second difference, like for Linux. + +GUI: When returning from Ex mode, scrollbars were not updated. + +Win32: Copying text to the clipboard containing a <CR>, pasting it would +replace it with a <NL> and drop the next character. + +Entering a double byte character didn't work if the second byte is in [xXoO]. +(Eric Lee) + +vim_realloc was both defined and had a prototype in proto/misc2.pro. Caused +conflicts on Solaris. + +A pattern in an autocommand was treated differently on DOS et al. than on +Unix. Now it's the same, also when using backslashes. + +When using <Tab> twice for command line completion, without a match, the <Tab> +would be inserted. (Negri) + +Bug in MS-Visual C++ 6.0 when compiling ex_docmd.c with optimization. (Negri) + +Testing the result of mktemp() for failure was wrong. Could cause a crash. +(Peters) + +GUI: When checking for a ".gvimrc" file in the current directory, didn't check +for a "_gvimrc" file too. + +Motif GUI: When using the popup menu and then adding an item to the menu bar, +the menu bar would get very high. + +Mouse clicks and special keys (e.g. cursor keys) quit the more prompt and +dialogs. Now they are ignored. + +When at the more-prompt, xterm selection didn't work. Now use the 'r' flag in +'mouse' also for the more-prompt. + +When selecting a Visual area of more than 1023 lines, with 'guioptions' set to +"a", could mess up the display because of a message in free_yank(). Removed +that message, except for the Amiga. + +Moved auto-selection from ui_write() to the screen update functions. Avoids +unexpected behavior from a low-level function. Also makes the different +feedback of owning the selection possible. + +Vi incompatibility: Using "i<CR>" in an indent, with 'ai' set, used the +original indent instead of truncating it at the cursor. (Webb) + +":echo x" didn't stop at "q" for the more prompt. + +Various fixes for Macintosh. (St-Amant) + +When using 'selectmode' set to "exclusive", selecting a word and then using +CTRL-] included the character under the cursor. + +Using ":let a:name" in a function caused a crash. (Webb) + +When using ":append", an empty line didn't scroll up. + +DOS etc.: A file name starting with '!' didn't work. Added '!' to default for +'isfname'. + +BeOS: Compilation problem with prototype of skip_class_name(). (Price) + +When deleting more than one line, e.g., with "de", could still use "U" +command, which didn't work properly then. + +Amiga: Could not compile ex_docmd.c, it was getting too big. Moved some +functions to ex_cmds.c. + +The expand() function would add a trailing slash for directories. + +Didn't give an error message when trying to assign a value to an argument of a +function. (Webb) + +Moved including sys/ptem.h to after termios.h. Needed for Sinix. + +OLE interface: Don't delete the object in CVimCF::Release() when the reference +count becomes zero. (Cordell) +VisVim could still crash on exit. (Erhardt) + +"case a: case b:" (two case statements in one line) aligned with the second +case. Now it uses one 'sw' for indent. (Webb) + +Font initialisation wasn't right for Athena/Motif GUI. Moved the call to +highlight_gui_started() gui_mch_init() to gui_mch_open(). (Nam) + +In Replace mode, backspacing over a TAB before where the replace mode started +while 'sts' is different from 'ts', would delete the TAB. + +Win32 console: When executing external commands and switching between the two +console screens, Vim would copy the text between the buffers. That caused the +screen to be messed up for backtick expansion. + +":winpos -1" then ":winpos" gave wrong error message. + +Windows commander creates files called c:\tmp\$wc\abc.txt. Don't remove the +backslash before the $. Environment variables were not expanded anyway, +because of the backslash before the dollar. + +Using "-=" with ":set" could remove half a part when it contains a "\,". +E.g., ":set path+=a\\,b" and then "set path-=b" removed ",b". + +When Visually selecting lines, with 'selection' set to "inclusive", including +the last char of the line, "<<" moved an extra line. Also for other operators +that always work on lines. + +link.sh changed "-lnsl_s" to "_s" when looking for "nsl" to be removed. +Now it only remove whole words. + +When jumped to a mark or using "fz", and there is an error, the current column +was lost. E.g. when using "$fzj". + +The "g CTRL-G" command could not be interrupted, even though it can take a +long time. + +Some terminals do have <F4> and <xF4>. <xF4> was always interpreted as <F4>. +Now map <xF4> to <F4>, so that the user can override this. + +When compiling os_win32.c with MIN_FEAT the apply_autocmds() should not be +used. (Aaron) + +This autocommand looped forever: ":au FileChangedShell * nested e <afile>" +Now FileChangeShell never nests. (Roemer) + +When evaluating an ":elseif" that was not going to matter anyway, ignore +errors. (Roemer) + +GUI Lesstif: Tearoff bar was the last item, instead of the first. + +GUI Motif: Colors of tear-off widgets was wrong when 't' flag added to +'guioptions' afterwards. When 't' flag in 'guioptions' is excluded, would +still get a tearoff item in a new menu. + +An inode number can be "long long". Use ino_t instead of long. Added +configure check for ino_t. + +Binary search for tags was using a file offset "long" instead of "off_t". + +Insert mode completion of tags was not using 'ignorecase' properly. + +In Insert mode, the <xFn> keys were not properly mapped to <Fn> for the +default mappings. Also caused errors for ":mkvimrc" and ":mksession". + +When jumping to another window while in Insert mode, would get the "warning: +changing readonly file" even when not making a change. + +A '(' or '{' inside a trailing "//" comment would disturb C-indenting. +When using two labels below each other, the second one was not indented +properly. Comments could mess up C-indenting in many places. (Roemer) + +Could delete or redefine a function while it was being used. Could cause a +crash. +In a function it's logical to prepend "g:" to a system variable, but this +didn't work. (Roemer) + +Hangul input: Buffer would overflow when user inputs invalid key sequence. +(Nam) + +When BufLoad or BufEnter autocommands change the topline of the buffer in the +window, it was overruled and the cursor put halfway the window. Now only put +the cursor halfway if the autocommands didn't change the topline. + +Calling exists("&option") always returned 1. (Roemer) + +Win32: Didn't take actually available memory into account. (Williams) + +White space after an automatically inserted comment leader was not removed +when 'ai' is not set and <CR> hit just after inserting it. (Webb) + +A few menus had duplicated accelerators. (Roemer) + +Spelling errors in documentation, quite a few "the the". (Roemer) + +Missing prototypes for Macintosh. (Kielhorn) + +Win32: When using 'shellquote' or 'shellxquote', the "!start cmd" wasn't +executed in a disconnected process. + +When resizing the window, causing a line before the cursor to wrap or unwrap, +the cursor was displayed in the wrong position. + +There was quite a bit of dead code when compiling with minimal features. + +When doing a ":%s///" command that makes lines shorter, such that lines above +the final cursor position no longer wrap, the cursor position was not updated. + +get_id_list() could allocate an array one too small, when a "contains=" item +has a wildcard that matches a group name that is added just after it. E.g.: +"contains=a.*b,axb". Give an error message for it. + +When yanking a Visual area and using the middle mouse button -> crash. When +clipboard doesn't work, now make "* always use "". + +Win32: Using ":buf a\ b\file" didn't work, it was interpreted as "ab\file". + +Using ":ts ident", then hit <CR>, with 'cmdheight' set to 2: command line was +not cleared, the tselect prompt was on the last but one line. + +mksession didn't restore the cursor column properly when it was after a tab. +Could not get all windows back when using a smaller terminal screen. Didn't +restore all windows when "winsize" was not in 'sessionoptions'. (Webb) + +Command line completion for ":buffer" depended on 'ignorecase' for Unix, but +not for DOS et al.. Now don't use 'ignorecase', but let it depend on whether +file names are case sensitive or not (like when expanding file names). + +Win32 GUI: (Negri) +- Redrawing the background caused flicker when resizing the window. Removed + _OnEraseBG(). Removed CS_HREDRAW and CS_VREDRAW flags from the + sndclass.style. +- Some parts of the window were drawn in grey, instead of using the color from + the user color scheme. +- Dropping a file on gvim didn't activate the window. +- When there is no menu ('guioptions' excludes 'm'), never use the ALT key for + it. + +GUI: When resizing the window, would make the window height a bit smaller. +Now round off to the nearest char cell size. (Negri) + +In Vi the ")" and "(" commands don't stop at a single space after a dot. +Added 'J' flag in 'cpoptions' to make this behave Vi compatible. (Roemer) + +When saving a session without any buffers loaded, there would be a ":normal" +command without arguments in it. (Webb) + +Memory leaks fixed: (Madsen) +- eval.c: forgot to release func structure when func deleted +- ex_docmd.c: forgot to release string after "<sfile>" +- misc1.c: leak when completion pattern had no matches. +- os_unix.c: forgot to release regexp after file completions + +Could crash when using a buffer without a name. (Madsen) +Could crash when doing file name completion, because of backslash_halve(). +(Madsen) + +":@a" would do mappings on register a, which is not Vi compatible. (Roemer) + +":g/foo.*()/s/foobar/_&/gc" worked fine, but then "n" searched for "foobar" +and displayed "/foo.*()". (Roemer) + +OS/2: get_cmd_output() was not included. Didn't check for $VIM/.vimrc file. + +Command line completion of options didn't work after "+=" and "-=". + +Unix configure: Test for memmove()/bcopy()/memcpy() tried redefining these +functions, which could fail if they are defined already. Use mch_memmove() to +redefine. + +Unix: ":let a = expand("`xterm`&")" started an xterm asynchronously, but +":let a = expand("`xterm&`")" generated an error message, because the +redirection was put after the '&'. + +Win32 GUI: Dialog buttons could not be selected properly with cursor keys, +when the default is not the first button. (Webb) + +The "File has changed since editing started" (when regaining focus) could not +always be seen. (Webb) + +When starting with "ex filename", the file message was overwritten with +the "entering Ex mode" message. + +Output of ":tselect" listed name of file directly from the tags file. Now it +is corrected for the position of the tags file. + +When 'backspace' is 0, could backspace over autoindent. Now it is no longer +allowed (Vi compatible). + +In Replace mode, when 'noexpandtab' and 'smarttab' were set, and inserting +Tabs, backspacing didn't work correctly for Tabs inserted at the start of the +line (unless 'sts' was set too). Also, when replacing the first non-blank +after which is a space, rounding the indent was done on the first non-blank +instead of on the character under the cursor. + +When 'sw' at 4, 'ts' at 8 and 'smarttab' set: When a tab was appended after +four spaces (they are replaced with a tab) couldn't backspace over the tab. + +In Insert mode, with 'bs' set to 0, couldn't backspace to before autoindent, +even when it was removed with CTRL-D. + +When repeating an insert command where a <BS>, <Left> or other key causes an +error, would flush buffers and remain in Insert mode. No longer flush +buffers, only beep and continue with the insert command. + +Dos and Win32 console: Setting t_me didn't work to get another color. Made +this works backwards compatible. + +For Turkish (LANG = "tr") uppercase 'i' is not an 'I'. Use ASCII uppercase +translation in vim_strup() to avoid language problems. (Komur) + +Unix: Use usleep() or nanosleep() for mch_delay() when available. Hopefully +this avoids a hangup in select(0, ..) for Solaris 2.6. + +Vim would crash when using a script file with 'let &sp = "| tee"', starting +vim with "vim -u test", then doing ":set sp=". The P_WAS_SET flag wasn't set +for a string option, could cause problems with any string option. + +When using "cmd | vim -", stdin is not a terminal. This gave problems with +GPM (Linux console mouse) and when executing external commands. Now close +stdin and re-open it as a copy of stderr. + +Syntax highlighting: A "nextgroup" item was not properly stored in the state +list. This caused missing of next groups when not redrawing from start to +end, but starting halfway. + +Didn't check for valid values of 'ttymouse'. + +When executing an external command from the GUI, waiting for the child to +terminate might not work, causing a hang. (Parmelan) + +"make uninstall" didn't delete the vimrc_example.vim and gvimrc_example.vim +files and the vimtutor. + +Win32: "expand("%:p:h")" with no buffer name removed the directory name. +"fnamemodify("", ":p")" did not add a trailing slash, fname_case() removed it. + +Fixed: When 'hlsearch' was set and the 'c' flag was not in 'cpoptions': +highlighting was not correct. Now overlapping matches are handled correctly. + +Athena, Motif and GTK GUI: When started without focus, cursor was shown as if +with focus. + +Don't include 'shellpipe' when compiled without quickfix, it's not used. +Don't include 'dictionary' option when compiled without the +insert_expand +feature. +Only include the 'shelltype' option for the Amiga. + +When making a change to a line, with 'hlsearch' on, causing it to wrap, while +executing a register, the screen would not be updated correctly. This was a +generic problem in update_screenline() being called while must_redraw is +VALID. + +Using ":bdelete" in a BufUnload autocommand could cause a crash. The window +height was added to another window twice in close_window(). + +Win32 GUI: When removing a menu item, the tearoff wasn't updated. (Negri) + +Some performance bottlenecks removed. Allocating memory was not efficient. +For Win32 checking for available memory was slow, don't check it every time +now. On NT obtaining the user name takes a long time, cache the result (for +all systems). + +fnamemodify() with an argument ":~:." or ":.:~" didn't work properly. + +When editing a new file and exiting, the marks for the buffer were not saved +in the viminfo file. + +":confirm only" didn't put up a dialog. + +These text objects didn't work when 'selection' was "exclusive": va( vi( va{ +vi{ va< vi< vi[ va[. + +The dialog for writing a readonly file didn't have a valid default. (Negri) + +The line number used for error messages when sourcing a file was reset when +modelines were inspected. It was wrong when executing a function. + +The file name and line number for an error message wasn't displayed when it +was the same as for the last error, even when this was long ago. Now reset +the name/lnum after a hit-enter prompt. + +In a session file, a "%" in a file name caused trouble, because fprintf() was +used to write it to the file. + +When skipping statements, a mark in an address wasn't skipped correctly: +"ka|if 0|'ad|else|echo|endif". (Roemer) + +":wall" could overwrite a not-edited file without asking. + +GUI: When $DISPLAY was not set or starting the GUI failed in another way, the +console mode then started with wrong colors and skipped initializations. Now +do an early check if the GUI can be started. Don't source the menu.vim or +gvimrc when it will not. Also do normal terminal initializations if the GUI +might not start. + +When using a BufEnter autocommand to position the cursor and scroll the +window, the cursor was always put at the last used line and halfway the window +anyhow. + +When 'wildmode' was set to "longest,list:full", ":e *.c<Tab><Tab>" didn't list +the matches. Also avoid that listing after a "longest" lists the wrong +matches when the first expansion changed the string in front of the cursor. + +When using ":insert", ":append" or ":change" inside a while loop, was not able +to break out of it with a CTRL-C. + +Win32: ":e ." took an awful long time before an error message when used in +"C:\". Was caused by adding another backslash and then trying to get the full +name for "C:\\". + +":winpos -10 100" was working like ":winpos -10 -10", because a pointer was +not advanced past the '-' sign. + +When obtaining the value of a hidden option, would give an error message. Now +just use a zero value. + +OS/2: Was using argv[0], even though it was not a useful name. It could be +just "vim", found in the search path. + +Xterm: ":set columns=78" didn't redraw properly (when lines wrap/unwrap) until +after a delay of 'updatetime'. Didn't check for the size-changed signal. + +'scrollbind' didn't work in Insert mode. +Horizontal scrollbinding didn't always work for "0" and "$" commands (e.g., +when 'showcmd' was off). + +When compiled with minimal features but with GUI, switching on the mouse in an +xterm caused garbage, because the mouse codes were not recognized. Don't +enable the mouse when it can't be recognized. In the GUI it also didn't work, +the arguments to the mouse code were not interpreted. + +When 'showbreak' used, in Insert mode, when the cursor is just after the last +character in the line, which is also the in the rightmost column, the cursor +position would be like the 'showbreak' string is shown, but it wasn't. + +Autocommands could move the cursor in a new file, so that CTRL-W i didn't show +the right line. Same for when using a filemark to jump to another file. + +When redefining the argument list, the title used for other windows could be +showing the wrong info about the position in the argument list. Also update +this for a ":split" command without arguments. + +When editing file 97 of 13, ":Next" didn't work. Now it goes to the last +file in the argument list. + +Insert mode completion (for dictionaries or included files) could not be +interrupted by typing an <Esc>. Could get hit-enter prompt after line +completion, or whenever the informative message would get too long. + +When using the ":edit" command to re-edit the same file, an autocommand to +jump to the last cursor position caused the cursor to move. Now set the last +used cursor position to avoid this. + +When 'comments' has a part that starts with white space, formatting the +comment didn't work. + +At the ":tselect" prompt Normal mode mappings were used. That has been +disabled. + +When 'selection' is not "old", some commands still didn't allow the cursor +past the end-of-line in Visual mode. + +Athena: When a menu was deleted, it would appear again (but not functional) +when adding another menu. Now they don't reappear anymore (although they are +not really deleted either). + +Borland C++ 4.x had an optimizer problem in fill_breakat_flags(). (Negri) + +"ze" didn't work when 'number' was on. (Davis) + +Win32 GUI: Intellimouse code didn't work properly on Windows 98. (Robinson) + +A few files were including proto.h a second time, after vim.h had already done +that, which could cause problems with the vim_realloc() macro. + +Win32 console: <M-x> or ALT-x was not recognized. Also keypad '+', '-' and +'*'. (Negri) +MS-DOS: <M-x> didn't work, produced a two-byte code. Now the alphabetic and +number keys work. (Negri) + +When finding a lot of matches for a tag completion, the check for avoiding +double matches could take a lot of time. Add a line_breakcheck() to be able +to interrupt this. (Deshpande) + +When the command line was getting longer than the screen, the more-prompt +would be given regularly, and the cursor position would be wrong. Now only +show the part of the command line that fits on the screen and force the cursor +to be positioned on the visible part. There can be text after the cursor +which isn't editable. + +At the more prompt and with the console dialog, a cursor key was interpreted +as <Esc> and OA. Now recognize special keys in get_keystroke(). Ignore mouse +and scrollbar events. + +When typing a BS after inserting a middle comment leader, typing the last char +of the end comment leader still changed it into the end comment leader. (Webb) + +When a file system is full, writing to a swap file failed. Now first try to +write one block to the file. Try next entry in 'dir' if it fails. + +When "~" is in 'whichwrap', doing "~" on last char of a line didn't update the +display. + +Unix: Expanding wildcards for ":file {\\}" didn't work, because "\}" was +translated to "}" before the shell got it. Now don't remove backslashes when +wildcards are going to be expanded. + +Unix: ":e /tmp/$uid" didn't work. When expanding environment variables in a +file name doesn't work, use the shell to expand the file name. ":e /tmp/$tty" +still doesn't work though. + +"make test" didn't always work on DOS/Windows for test30, because it depended +on the external "echo" command. + +The link.sh script used "make" instead of $MAKE from the Makefile. Caused +problems for generating pathdef.c when "make" doesn't work properly. + +On versions that can do console and GUI: In the console a typed CSI code could +cause trouble. + +The patterns in expression evaluation didn't ignore the 'l' flag in +'cpoptions'. This broke the working of <CR> in the options window. + +When 'hls' off and 'ai' on, "O<Esc>" did remove the indent, but it was still +highlighted red for trailing space. + +Win32 GUI: Dropping an encrypted file on a running gvim didn't work right. Vim +would loop while outputting "*" characters. vgetc() was called recursively, +thus it returns NUL. Added safe_vgetc(), which reads input directly from the +user in this situation. + +While reading text from stdin, only an empty screen was shown. Now show that +Vim is reading from stdin. + +The cursor shape wasn't set properly when returning to Insert mode, after +using a CTRL-O /asdf command which fails. It would be OK after a few seconds. +Now it's OK right away. + +The 'isfname' default for DOS/Windows didn't include the '@' character. File +names that contained "dir\@file" could not be edited. + +Win32 console: <C-S-Left> could cause a crash when compiled with Borland or +egcs. (Aaron) + +Unix and VMS: "#if HAVE_DIRENT_H" caused problems for some compilers. Use +"#ifdef HAVE_DIRENT_H" instead. (Jones) + +When a matching tag is in the current file but has a search pattern that +doesn't match, the cursor would jump to the first line. + +Unix: Dependencies for pty.c were not included in Makefile. Dependency of +ctags/config.h was not included (only matters for parallel make). + +Removed a few Uninitialized Memory Reads (potential crashes). In do_call() +calling clear_var() when not evaluating. In win32_expandpath() and +dos_expandpath() calling backslash_halve() past the end of a file name. + +Removed memory leaks: Set_vim_var_string() never freed the value. The +next_list for a syntax keyword was never freed. + +On non-Unix systems, using a file name with wildcards without a match would +silently fail. E.g., ":e *.sh". Now give a "No match" error message. + +The life/life.mac, urm/urm.mac and hanoi/hanoi.mac files were not recognized +as Vim scripts. Renamed them to *.vim. + +[Note: some numbered patches are not relevant when upgrading from version 5.3, +they have been removed] + +Patch 5.4m.1 +Problem: When editing a file with a long name, would get the hit-enter + prompt, even though all settings are such that the name should be + truncated to avoid that. filemess() was printing the file name + without truncating it. +Solution: Truncate the message in filemess(). Use the same code as for + msg_trunc_attr(), which is moved to the new function + msg_may_trunc(). +Files: src/message.c, src/proto/message.pro, src/fileio.c + +Patch 5.4m.3 +Problem: The Motif libraries were not found by configure for Digital Unix. +Solution: Add "/usr/shlib" to the search path. (Andy Kahn) +Files: src/configure.in, src/configure + +Patch 5.4m.5 +Problem: Win32 GUI: When using the Save-As menu entry and selecting an + existing file in the file browser, would get a dialog to confirm + overwriting twice. (Ed Krall) +Solution: Removed the dialog from the file browser. It would be nicer to + set the "forceit" flag and skip Vim's ":confirm" dialog, but it + requires quite a few changes to do that. +Files: src/gui_w32.c + +Patch 5.4m.6 +Problem: Win32 GUI: When reading text from stdin, e.g., "cat foo | gvim -", + a message box would pop up with "-stdin-" (when exiting). (Michael + Schaap) +Solution: Don't switch off termcap mode for versions that are GUI-only. + They use another terminal to read from stdin. +Files: src/main.c, src/fileio.c + +Patch 5.4m.7 +Problem: Unix: running configure with --enable-gtk-check, + --enable-motif-check, --enable-athena-check or --enable-gtktest + had the reverse effect. (Thomas Koehler) +Solution: Use $enable_gtk_check variable correctly in AC_ARG_ENABLE(). +Files: src/configure.in, src/configure + +Patch 5.4m.9 +Problem: Multi-byte: With wrapping lines, the cursor was sometimes 2 + characters to the left. Syntax highlighting was wrong when a + double-byte character was split for a wrapping line. When + 'showbreak' was on the splitting also didn't work. +Solution: Adjust getvcol() and win_line(). (Chong-Dae Park) +Files: src/charset.c, src/screen.c + +Patch 5.4m.11 +Problem: The ":call" command didn't check for illegal trailing characters. + (Stefan Roemer) +Solution: Add the check in do_call(). +Files: src/eval.c + +Patch 5.4m.13 +Problem: With the ":s" command: + 1. When performing a substitute command, the mouse would be + disabled and enabled for every substitution. + 2. The cursor position could be beyond the end of the line. + Calling line_breakcheck() could try to position the cursor, + which causes a crash in the Win32 GUI. + 3. When using ":s" in a ":g" command, the cursor was not put on + the first non-white in the line. + 4. There was a hit-enter prompt when confirming the substitution + and the replacement was a bit longer. +Solution: 1. Only disable/enable the mouse when asking for confirmation. + 2. Always put the cursor on the first character, it is going to be + moved to the first non-blank anyway. + Don't use the cursor position in gui_mch_draw_hollow_cursor(), + get the character from the screen buffer. + 3. Added global_need_beginline flag to call beginline() after ":g" + has finished all substitutions. + 4. Clear the need_wait_return flag after prompting the user. +Files: src/ex_cmds.c, src/gui_w32.c + +Patch 5.4m.14 +Problem: When doing "vim xxx", ":opt", ":only" and then ":e xxx" we end + up with two swapfiles for "xxx". That is caused by the ":bdel" + command which is executed when unloading the option-window. + Also, there was no check if closing a buffer made the new one + invalid, this could cause a crash. +Solution: When closing a buffer causes the current buffer to be deleted, + use the new buffer to replace it. Also detect that the new buffer + has become invalid as a side effect of closing the current one. + Make autocommand that calls ":bdel" in optwin.vim nested, so that + the buffer loading it triggers also executes autocommands. + Also added a test for this in test13. +Files: runtime/optwin.vim, src/buffer.c, src/ex_cmds.c, src/globals.h + src/testdir/test13.in, src/testdir/test13.ok + +Patch 5.4m.15 +Problem: When using a BufEnter autocommand to reload the syntax file, + conversion to HTML caused a crash. (Sung-Hyun Nam) +Solution: When using ":syntax clear" the current stack of syntax items was + not cleared. This will cause memory to be used that has already + been freed. Added call to invalidate_current_state() in + syntax_clear(). +Files: src/syntax.c + +Patch 5.4m.17 +Problem: When omitting a ')' in an expression it would not be seen as a + failure. + When detecting an error inside (), there would be an error message + for a missing ')' too. + When using ":echo 1+|echo 2" there was no error message. (Roemer) + When using ":exe 1+" there was no error message. + When using ":return 1+" there was no error message. +Solution: Fix do_echo(), do_execute() and do_return() to give an error + message when eval1() returns FAIL. + Fix eval6() to handle trailing ')' correctly and return FAIL when + it's missing. +Files: src/eval.c + +Patch 5.4m.18 +Problem: When using input() from inside an expression entered with + "CTRL-R =" on the command line, there could be a crash. And the + resulting command line was wrong. +Solution: Added getcmdline_prompt(), which handles recursive use of + getcmdline() correctly. It also sets the command line prompt. + Removed cmdline_prompt(). Also use getcmdline_prompt() for + getting the crypt key in get_crypt_key(). +Files: src/proto/ex_getln.pro, src/ex_getln.c, src/eval.c, src/misc2.c + +Patch 5.4m.21 +Problem: When starting up, the screen structures were first allocated at + the minimal size, then initializations were done with Rows + possibly different from screen_Rows. Caused a crash in rare + situations (GTK with XIM and fontset). +Solution: Call screenalloc() in main() only after calling ui_get_winsize(). + Also avoids a potential delay because of calling screenclear() + while "starting" is non-zero. +Files: src/main.c + +Patch 5.4m.22 +Problem: In the GUI it was possible that the screen was resized and the + screen structures re-allocated while redrawing the screen. This + could cause a crash (hard to reproduce). The call sequence goes + through update_screen() .. syntax_start() .. ui_breakcheck() .. + gui_resize_window() .. screenalloc(). +Solution: Set updating_screen while redrawing. If the window is resized + remember the new size and handle it only after redrawing is + finished. + This also fixes that resizing the screen while still redrawing + (slow syntax highlighting) would not work properly. + Also disable display_hint, it was never used. +Files: src/globals.h, src/gui.c, src/screen.c, src/proto/gui.pro + +Patch 5.4m.23 +Problem: When using expand("<cword>") when there was no word under the + cursor, would get an error message. Same for <cWORD> and <cfile>. +Solution: Don't give an error message, return an empty string. +Files: src/eval.c + +Patch 5.4m.24 +Problem: ":help \|" didn't find anything. It was translated to "/\\|". +Solution: Translate "\|" into "\\bar". First check the table for specific + translations before checking for "\x". +Files: src/ex_cmds.c + +Patch 5.4m.25 +Problem: Unix: When using command line completion on files that contain + ''', '"' or '|' the file name could not be used. + Adding this file name to the Buffers menu caused an error message. +Solution: Insert a backslash before these three characters. + Adjust Mungename() function to insert a backslash before '|'. +Files: src/ex_getln.c, runtime/menu.vim + +Patch 5.4m.26 +Problem: When using a mapping of two function keys, e.g., <F1><F1>, and + only the first char of the second key has been read, the mapping + would not be recognized. Noticed on some Unix systems with xterm. +Solution: Add 'K' flag to 'cpoptions' to wait for the whole key code, even + when halfway a mapping. +Files: src/option.h, src/term.c + +Patch 5.4m.27 +Problem: When making test33 without the lisp feature it hangs. Interrupting + the execution of the script then might cause a crash. +Solution: In inchar(), after closing a script, don't use buf[] anymore. + closescript() has freed typebuf[] and buf[] might be pointing + inside typebuf[]. + Avoid that test33 hangs when the lisp feature is missing. +Files: src/getchar.c src/testdir/test33.in + +"os2" was missing from the feature list. Useful for has("os2"). + +BeOS: +- Included patches from Richard Offer for BeOS R4.5. +- menu code didn't work right. Crashed in the Buffers menu. The window title + wasn't set. (Offer) + +Patch 5.4n.3 +Problem: C-indenting was wrong after " } else". The white space was not + skipped. Visible when 'cino' has "+10". +Solution: Skip white space before calling cin_iselse(). (Norbert Zeh) +Files: src/misc1.c + +Patch 5.4n.4 +Problem: When the 't' flag in 'cpoptions' is included, after a + ":nohlsearch" the search highlighting would not be enabled again + after a tag search. (Norbert Zeh) +Solution: When setting the new search pattern in jumpto_tag(), don't restore + no_hlsearch. +Files: src/tag.c + +Patch 5.4n.5 +Problem: When using ":normal" from a CursorHold autocommand Vim hangs. The + autocommand is executed down from vgetc(). Calling vgetc() + recursively to execute the command doesn't work then. +Solution: Forbid the use of ":normal" when vgetc_busy is set. Give an error + message when this happens. +Files: src/ex_docmd.c, runtime/doc/autocmd.txt + +Patch 5.4n.6 +Problem: "gv" could reselect a Visual that starts and/or ends past the end + of a line. (Robert Webb) +Solution: Check that the start and end of the Visual area are on a valid + character by calling adjust_cursor(). +Files: src/normal.c + +Patch 5.4n.8 +Problem: When a mark was on a non existing line (e.g., when the .viminfo + was edited), jumping to it caused ml_get errors. (Alexey + Marinichev). +Solution: Added check_cursor_lnum() in nv_gomark(). +Files: src/normal.c + +Patch 5.4n.9 +Problem: ":-2" moved the cursor to a negative line number. (Ralf Schandl) +Solution: Give an error message for a negative line number. +Files: src/ex_docmd.c + +Patch 5.4n.10 +Problem: Win32 GUI: At the hit-enter prompt, it was possible to scroll the + text. This erased the prompt and made Vim look like it is in + Normal mode, while it is actually still waiting for a <CR>. +Solution: Disallow scrolling at the hit-enter prompt for systems that use + on the fly scrolling. +Files: src/message.c + +Patch 5.4n.14 +Problem: Win32 GUI: When using ":winsize 80 46" and the height is more than + what fits on the screen, the window size was made smaller than + asked for (that's OK) and Vim crashed (that's not OK)> +Solution: Call check_winsize() from gui_set_winsize() to resize the windows. +Files: src/gui.c + +Patch 5.4n.16 +Problem: Win32 GUI: The <F10> key both selected the menu and was handled as + a key hit. +Solution: Apply 'winaltkeys' to <F10>, like it is used for Alt keys. +Files: src/gui_w32.c + +Patch 5.4n.17 +Problem: Local buffer variables were freed when the buffer is unloaded. + That's not logical, since options are not freed. (Ron Aaron) +Solution: Free local buffer variables only when deleting the buffer. +Files: src/buffer.c + +Patch 5.4n.19 +Problem: Doing ":e" (without argument) in an option-window causes trouble. + The mappings for <CR> and <Space> are not removed. When there is + another buffer loaded, the swap file for it gets mixed up. + (Steve Mueller) +Solution: Also remove the mappings at the BufUnload event, if they are still + present. + When re-editing the same file causes the current buffer to be + deleted, don't try editing it. + Also added a test for this situation. +Files: runtime/optwin.vim, src/ex_cmds.c, src/testdir/test13.in, + src/testdir/test13.ok + +Patch 5.4n.24 +Problem: BeOS: configure never enabled the GUI, because $with_x was "no". + Unix prototypes caused problems, because Display and Widget are + undefined. + Freeing fonts on exit caused a crash. +Solution: Only disable the GUI when $with_x is "no" and $BEOS is not "yes". + Add dummy defines for Display and Widget in proto.h. + Don't free the fonts in gui_exit() for BeOS. +Files: src/configure.in, src/configure, src/proto.h, src/gui.c. + + +The runtime/vim48x48.xpm icon didn't have a transparent background. (Schild) + +Some versions of the mingw32/egcs compiler didn't have WINBASEAPI defined. +(Aaron) + +VMS: +- mch_setenv() had two arguments instead of three. +- The system vimrc and gvimrc files were called ".vimrc" and ".gvimrc". + Removed the dot. +- call to RealWaitForChar() had one argument too many. (Campbell) +- WaitForChar() is static, removed the prototype from proto/os_vms.pro. +- Many file accesses failed, because Unix style file names were used. + Translate file names to VMS style by using vim_fopen(). +- Filtering didn't work, because the temporary file name was generated wrong. +- There was an extra newline every 9192 characters when writing a file. Work + around it by writing line by line. (Campbell) +- os_vms.c contained "# typedef int DESC". Should be "typedef int DESC;". + Only mattered for generating prototypes. +- Added file name translation to many places. Made easy by defining macros + mch_access(), mch_fopen(), mch_fstat(), mch_lstat() and mch_stat(). +- Set default for 'tagbsearch' to off, because binary tag searching apparently + doesn't work for VMS. +- make mch_get_host_name() work with /dec and /standard=vaxc. (Campbell) + + +Patch 5.4o.2 +Problem: Crash when using "gf" on "file.c://comment here". (Scott Graham) +Solution: Fix wrong use of pointers in get_file_name_in_path(). +Files: src/window.c + +Patch 5.4o.3 +Problem: The horizontal scrollbar was not sized correctly when 'number' is + set and 'wrap' not set. + Athena: Horizontal scrollbar wasn't updated when the cursor was + positioned with a mouse click just after dragging. +Solution: Subtract 8 from the size when 'number' set and 'wrap' not set. + Reset gui.dragged_sb when a mouse click is received. +Files: src/gui.c + +Patch 5.4o.4 +Problem: When running in an xterm and $WINDOWID is set to an illegal value, + Vim would exit with "Vim: Got X error". +Solution: When using the display which was opened for the xterm clipboard, + check if x11_window is valid by trying to obtain the window title. + Also add a check in setup_xterm_clip(), for when using X calls to + get the pointer position in an xterm. +Files: src/os_unix.c + +Patch 5.4o.5 +Problem: Motif version with Lesstif: When removing the menubar and then + using a menu shortcut key, Vim would crash. (raf) +Solution: Disable the menu mnemonics when the menu bar is removed. +Files: src/gui_motif.c + +Patch 5.4o.9 +Problem: The DOS install.exe program used the "move" program. That doesn't + work on Windows NT, where "move" is internal to cmd.exe. +Solution: Don't use an external program for moving the executables. Use C + functions to copy the file and delete the original. +Files: src/dosinst.c + +Motif and Athena obtained the status area height differently from GTK. Moved +status_area_enabled from global.h to gui_x11.c and call +xim_get_status_area_height() to get the status area height. + +Patch 5.4p.1 +Problem: When using auto-select, and the "gv" command is used, would not + always obtain ownership of the selection. Caused by the Visual + area still being the same, but ownership taken away by another + program. +Solution: Reset the clipboard Visual mode to force updating the selection. +Files: src/normal.c + +Patch 5.4p.2 +Problem: Motif and Athena with XIM: Typing 3-byte + <multibyte><multibyte><space> doesn't work correctly with Ami XIM. +Solution: Avoid using key_sym XK_VoidSymbol. (Nam) +Files: src/multbyte.c, src/gui_x11.c + +Patch 5.4p.4 +Problem: Win32 GUI: The scrollbar values were reduced for a file with more + than 32767 lines. But this info was kept global for all + scrollbars, causing a mixup between the windows. + Using the down arrow of a scrollbar in a large file didn't work. + Because of round-off errors there is no scroll at all. +Solution: Give each scrollbar its own scroll_shift field. When the down + arrow is used, scroll several lines. +Files: src/gui.h, src/gui_w32.c + +Patch 5.4p.5 +Problem: When changing buffers in a BufDelete autocommand, there could be + ml_line errors and/or a crash. (Schandl) Was caused by deleting + the current buffer. +Solution: When the buffer to be deleted unexpectedly becomes the current + buffer, don't delete it. + Also added a check for this in test13. +Files: src/buffer.c, src/testdir/test13.in, src/testdir/test13.ok + +Patch 5.4p.7 +Problem: Win32 GUI: When using 'mousemodel' set to "popup_setpos" and + clicking the right mouse button outside of the selected area, the + selected area wasn't removed until the popup menu has gone. + (Aaron) +Solution: Set the cursor and update the display before showing the popup + menu. +Files: src/normal.c + +Patch 5.4p.8 +Problem: The generated bugreport didn't contain information about + $VIMRUNTIME and whether runtime files actually exist. +Solution: Added a few checks to the bugreport script. +Files: runtime/bugreport.vim + +Patch 5.4p.9 +Problem: The windows install.exe created a wrong entry in the popup menu. + The "%1" was "". The full directory was included, even when the + executable had been moved elsewhere. (Ott) +Solution: Double the '%' to get one from printf. Only include the path to + gvim.exe when it wasn't moved and it's not in $PATH. +Files: src/dosinst.c + +Patch 5.4p.10 +Problem: Win32: On top of 5.4p.9: The "Edit with Vim" entry sometimes used + a short file name for a directory. +Solution: Change the "%1" to "%L" in the registry entry. +Files: src/dosinst.c + +Patch 5.4p.11 +Problem: Motif, Athena and GTK: When closing the GUI window when there is a + changed buffer, there was only an error message and Vim would not + exit. +Solution: Put up a dialog, like for ":confirm qa". Uses the code that was + already used for MS-Windows. +Files: src/gui.c, src/gui_w32.c + +Patch 5.4p.12 +Problem: Win32: Trying to expand a string that is longer than 256 + characters could cause a crash. (Steed) +Solution: For the buffer in win32_expandpath() don't use a fixed size array, + allocate it. +Files: src/os_win32.c + +MSDOS: Added "-Wall" to Makefile.djg compile flags. Function prototypes for +fname_case() and mch_update_cursor() were missing. "fd" was unused in +mf_sync(). "puiLocation" was unused in myputch(). "newcmd" unused in +mch_call_shell() for DJGPP version. + +============================================================================== +VERSION 5.5 *version-5.5* + +Version 5.5 is a bug-fix version of 5.4. + + +Changed *changed-5.5* +------- + +The DJGPP version is now compiled with "-O2" instead of "-O4" to reduce the +size of the executables. + +Moved the src/STYLE file to runtime/doc/develop.txt. Added the design goals +to it. + +'backspace' is now a string option. See patch 5.4.15. + + +Added *added-5.5* +----- + +Included Exuberant Ctags version 3.3. (Darren Hiebert) + +In runtime/mswin.vim, map CTRL-Q to CTRL-V, so that CTRL-Q can be used +everywhere to do what CTRL-V used to do. + +Support for decompression of bzip2 files in vimrc_example.vim. + +When a patch is included, the patch number is entered in a table in version.c. +This allows skipping a patch without breaking a next one. + +Support for mouse scroll wheel in X11. See patch 5.5a.14. + +line2byte() can be used to get the size of the buffer. See patch 5.4.35. + +The CTRL-R CTRL-O r and CTRL-R CTRL-P r commands in Insert mode are used to +insert a register literally. See patch 5.4.48. + +Uninstall program for MS-Windows. To be able to remove the registry entries +for "Edit with Vim". It is registered to be run from the "Add/Remove +programs" application. See patch 5.4.x7. + + +Fixed *fixed-5.5* +----- + +When using vimrc_example.vim: An error message when the cursor is on a line +higher than the number of lines in the compressed file. Move the autocommand +for jumping to the last known cursor position to after the decompressing +autocommands. + +":mkexrc" and ":mksession" wrote the current value of 'textmode'. That may +mark a file as modified, which causes problems. This is a buffer-specific +setting, it should not affect all files. + +"vim --version" wrote two empty lines. + +Unix: The alarm signal could kill Vim. It is generated by the Perl alarm() +function. Ignore SIGALRM. + +Win32 GUI: Toolbar still had the yellow bitmap for running a Vim script. + +BeOS: "tmo" must be bigtime_t, instead of double. (Seibert) + +Patch 5.4.1 +Problem: Test11 fails when $GZIP is set to "-v". (Matthew Jackson) +Solution: Set $GZIP to an empty string. +Files: src/testdir/test11.in + +Patch 5.4.2 +Problem: Typing <Esc> at the crypt key prompt caused a crash. (Kallingal) +Solution: Check for a NULL pointer returned from get_crypt_key(). +Files: src/fileio.c + +Patch 5.4.3 +Problem: Python: Trying to use the name of an unnamed buffer caused a + crash. (Daniel Burrows) +Solution: Check for b_fname being a NULL pointer. +Files: src/if_python.c + +Patch 5.4.4 +Problem: Win32: When compiled without toolbar, but the 'T' flag is in + 'guioptions', there would be an empty space for the toolbar. +Solution: Add two #ifdefs where checking for the 'T' flag. (Vince Negri) +Files: src/gui.c + +Patch 5.4.5 +Problem: Athena GUI: Using the Buffers.Refresh menu entry caused a crash. + Looks like any ":unmenu" command may cause trouble. +Solution: Disallow ":unmenu" in the Athena version. Disable the Buffers + menu, because the Refresh item would not work. +Files: src/menu.c, runtime/menu.vim + +Patch 5.4.6 +Problem: GTK GUI: Using ":gui" in the .gvimrc file caused an error. Only + happens when the GUI forks. +Solution: Don't fork in a recursive call of gui_start(). +Files: src/gui.c + +Patch 5.4.7 +Problem: Typing 'q' at the more prompt for the ATTENTION message causes the + file loading to be interrupted. (Will Day) +Solution: Reset got_int after showing the ATTENTION message. +Files: src/memline.c + +Patch 5.4.8 +Problem: Edit some file, ":he", ":opt": options from help window are shown, + but pressing space updates from the other window. (Phillipps) + Also: When there are changes in the option-window, ":q!" gives an + error message. +Solution: Before creating the option-window, go to a non-help window. + Use ":bdel!" to delete the buffer. +Files: runtime/optwin.vim + +Patch 5.4.9 + Just updates version.h. The real patch has been moved to 5.4.x1. + This patch is just to keep the version number correct. + +Patch 5.4.10 +Problem: GTK GUI: When $DISPLAY is invalid, "gvim -f" just exits. It + should run in the terminal. +Solution: Use gtk_init_check() instead of gtk_init(). +Files: src/gui_gtk_x11.c + +Patch 5.4.11 +Problem: When using the 'S' flag in 'cpoptions', 'tabstop' is not copied to + the next buffer for some commands, e.g., ":buffer". +Solution: When the BCO_NOHELP flag is given to buf_copy_options(), still + copy the options used by do_help() when neither the "from" or "to" + buffer is a help buffer. +Files: src/option.c + +Patch 5.4.12 +Problem: When using 'smartindent', there would be no extra indent if the + current line did not have any indent already. (Hanus Adler) +Solution: There was a wrongly placed "else", that previously matched with + the "if" that set trunc_line. Removed the "else" and added a + check for trunc_line to be false. +Files: src/misc1.c + +Patch 5.4.13 +Problem: New SGI C compilers need another option for optimisation. +Solution: Add a check in configure for "-OPT:Olimit". (Chin A Young) +Files: src/configure.in, src/configure + +Patch 5.4.14 +Problem: Motif GUI: When the popup menu is present, a tiny window appears + on the desktop for some users. +Solution: Set the menu widget ID for a popup menu to 0. (Thomas Koehler) +Files: src/gui_motif.c + +Patch 5.4.15 +Problem: Since 'backspace' set to 0 has been made Vi compatible, it is no + longer possible to only allow deleting autoindent. +Solution: Make 'backspace' a list of parts, to allow each kind of + backspacing separately. +Files: src/edit.c, src/option.c, src/option.h, src/proto/option.pro, + runtime/doc/option.txt, runtime/doc/insert.txt + +Patch 5.4.16 +Problem: Multibyte: Locale zh_TW.Big5 was not checked for in configure. +Solution: Add zh_TW.Big5 to configure check. (Chih-Tsun Huang) +Files: src/configure.in, src/configure + +Patch 5.4.17 +Problem: GUI: When started from inside gvim with ":!gvim", Vim would not + start. ":!gvim -f" works fine. +Solution: After forking, wait a moment in the parent process, to give the + child a chance to set its process group. +Files: src/gui.c + +Patch 5.4.18 +Problem: Python: The clear_history() function also exists in a library. +Solution: Rename clear_history() to clear_hist(). +Files: src/ex_getln.c, src/eval.c, src/proto/ex_getln.pro + +Patch 5.4.19 +Problem: In a terminal with 25 lines, there is a more prompt after the + ATTENTION message. When hitting 'q' here the dialog prompt + doesn't appear and file loading is interrupted. (Will Day) +Solution: Don't allow quitting the printing of a message for the dialog + prompt. Added the msg_noquit_more flag for this. +Files: src/message.c + +Patch 5.4.20 +Problem: GTK: When starting gvim, would send escape sequences to the + terminal to switch the cursor off and on. +Solution: Don't call msg_start() if the GUI is expected to start. +Files: src/main.c + +Patch 5.4.21 +Problem: Motif: Toplevel menu ordering was wrong when using tear-off items. +Solution: Don't add one to the index for a toplevel menu. +Files: src/gui_motif.c + +Patch 5.4.22 +Problem: In Insert mode, <C-Left>, <S-Left>, <C-Right> and <S-Right> didn't + update the column used for vertical movement. +Solution: Set curwin->w_set_curswant for those commands. +Files: src/edit.c + +Patch 5.4.23 +Problem: When a Visual selection is lost to another program, and then the + same text is Visually selected again, the clipboard ownership + wasn't regained. +Solution: Set clipboard.vmode to NUL to force regaining the clipboard. +Files: src/normal.c + +Patch 5.4.24 +Problem: Encryption: When using ":r file" while 'key' has already entered, + the 'key' option would be messed up. When writing the file it + would be encrypted with an unknown key and lost! (Brad Despres) +Solution: Don't free cryptkey when it is equal to the 'key' option. +Files: src/fileio.c + +Patch 5.4.25 +Problem: When 'cindent' is set, but 'autoindent' isn't, comments are not + properly indented when starting a new line. (Mitterand) +Solution: When there is a comment leader for the new line, but 'autoindent' + isn't set, do C-indenting. +Files: src/misc1.c + +Patch 5.4.26 +Problem: Multi-byte: a multi-byte character is never recognized in a file + name, causing a backslash before it to be removed on Windows. +Solution: Assume that a leading-byte character is a file name character in + vim_isfilec(). +Files: src/charset.c + +Patch 5.4.27 +Problem: Entries in the PopUp[nvic] menus were added for several modes, but + only deleted for the mode they were used for. This resulted in + the entry remaining in the PopUp menu. + When removing a PopUp[nvic] menu, the name had been truncated, + could result in greying-out the whole PopUp menu. +Solution: Remove entries for all modes from the PopUp[nvic] menus. Remove + the PopUp[nvic] menu entries first, before the name is changed. +Files: src/menu.c + +Patch 5.4.28 +Problem: When using a BufWritePre autocommand to change 'fileformat', the + new value would not be used for writing the file. +Solution: Check 'fileformat' after executing the autocommands instead of + before. +Files: src/fileio.c + +Patch 5.4.29 +Problem: Athena GUI: When removing the 'g' flag from 'guioptions', using a + menu can result in a crash. +Solution: Always grey-out menus for Athena, don't hide them. +Files: src/menu.c + +Patch 5.4.30 +Problem: BeOS: Suspending Vim with CTRL-Z didn't work (killed Vim). The + first character typed after ":sh" goes to Vim, instead of the + started shell. +Solution: Don't suspend Vim, start a new shell. Kill the async read thread + when starting a new shell. It will be restarted later. (Will Day) +Files: src/os_unix.c, src/ui.c + +Patch 5.4.31 +Problem: GUI: When 'mousefocus' is set, moving the mouse over where a + window boundary was, causes a hit-enter prompt to be finished. + (Jeff Walker) +Solution: Don't use 'mousefocus' at the hit-enter prompt. Also ignore it + for the more prompt and a few other situations. When an operator + is pending, abort it first. +Files: src/gui.c + +Patch 5.4.32 +Problem: Unix: $LDFLAGS was not passed to configure. +Solution: Pass $LDFLAGS to configure just like $CFLAGS. (Jon Miner) +Files: src/Makefile + +Patch 5.4.33 +Problem: Unix: After expanding an environment variable with the shell, the + next expansion would also use the shell, even though it is not + needed. +Solution: Reset "recursive" before returning from gen_expand_wildcards(). +Files: src/misc1.c + +Patch 5.4.34 (also see 5.4.x5) +Problem: When editing a file, and the file name is relative to a directory + above the current directory, the file name was made absolute. + (Gregory Margo) +Solution: Add an argument to shorten_fnames() which indicates if all file + names should be shortened, or only absolute names. In main() only + use shorten_fnames() to shorten absolute names. +Files: src/ex_docmd.c, src/fileio.c, src/main.c, src/proto/fileio.pro + +Patch 5.4.35 +Problem: There is no function to get the current file size. +Solution: Allow using line2byte() with the number of lines in the file plus + one. This returns the offset of the line past the end of the + file, which is the file size plus one. +Files: src/eval.c, runtime/doc/eval.txt + +Patch 5.4.36 +Problem: Comparing strings while ignoring case didn't work correctly for + some machines. (Mide Steed) +Solution: vim_stricmp() and vim_strnicmp() only returned 0 or 1. Changed + them to return -1 when the first argument is smaller. +Files: src/misc2.c + +Patch 5.4.37 (also see 5.4.40 and 5.4.43) +Problem: Long strings from the viminfo file are truncated. +Solution: When writing a long string to the viminfo file, first write a line + with the length, then the string itself in a second line. +Files: src/eval.c, src/ex_cmds.c, src/ex_getln.c, src/mark.c, src/ops.c, + src/search.c, src/proto/ex_cmds.pro, runtime/syntax/viminfo.vim + +Patch 5.4.38 +Problem: In the option-window, ":set go&" resulted in 'go' being handled + like a boolean option. + Mappings for <Space> and <CR> were overruled by the option-window. +Solution: When the value of an option isn't 0 or 1, don't handle it like a + boolean option. + Save and restore mappings for <Space> and <CR> when entering and + leaving the option-window. +Files: runtime/optwin.vim + +Patch 5.4.39 +Problem: When setting a hidden option, spaces before the equal sign were + not skipped and cause an error message. E.g., ":set csprg =cmd". +Solution: When skipping over a hidden option, check for a following "=val" + and skip it too. +Files: src/option.c + +Patch 5.4.40 (depends on 5.4.37) +Problem: Compiler error for "atol(p + 1)". (Axel Kielhorn) +Solution: Add a typecast: "atol((char *)p + 1)". +Files: src/ex_cmds.c + +Patch 5.4.41 +Problem: Some commands that were not included would give an error message, + even when after "if 0". +Solution: Don't give an error message for an unsupported command when not + executing the command. +Files: src/ex_docmd.c + +Patch 5.4.42 +Problem: ":w" would also cause a truncated message to appear in the message + history. +Solution: Don't put a kept message in the message history when it starts + with "<". +Files: src/message.c + +Patch 5.4.43 (depends on 5.4.37) +Problem: Mixing long lines with multiple lines in a register causes errors + when writing the viminfo file. (Robinson) +Solution: When reading the viminfo file to skip register contents, skip + lines that start with "<". +Files: src/ops.c + +Patch 5.4.44 +Problem: When 'whichwrap' includes '~', a "~" command that goes on to the + next line cannot be properly undone. (Zellner) +Solution: Save each line for undo in n_swapchar(). +Files: src/normal.c + +Patch 5.4.45 (also see 5.4.x8) +Problem: When expand("$ASDF") fails, there is an error message. +Solution: Remove the global expand_interactively. Pass a flag down to skip + the error message. + Also: expand("$ASDF") returns an empty string if $ASDF isn't set. + Previously it returned "$ASDF" when 'shell' is "sh". + Also: system() doesn't print an error when the command returns an + error code. +Files: many + +Patch 5.4.46 +Problem: Backspacing did not always use 'softtabstop' after hitting <CR>, + inserting a register, moving the cursor, etc. +Solution: Reset inserted_space much more often in edit(). +Files: src/edit.c + +Patch 5.4.47 +Problem: When executing BufWritePre or BufWritePost autocommands for a + hidden buffer, the cursor could be moved to a non-existing + position. (Vince Negri) +Solution: Save and restore the cursor and topline for the current window + when it is going to be used to execute autocommands for a hidden + buffer. Use an existing window for the buffer when it's not + hidden. +Files: src/fileio.c + +Patch 5.4.48 +Problem: A paste with the mouse in Insert mode was not repeated exactly the + same with ".". For example, when 'autoindent' is set and pasting + text with leading indent. (Perry) +Solution: Add the CTRL-R CTRL-O r and CTRL-R CTRL-P r commands in Insert + mode, which insert the contents of a register literally. +Files: src/edit.c, src/normal.c, runtime/doc/insert.txt + +Patch 5.4.49 +Problem: When pasting text with [ <MiddleMouse>, the cursor could end up + after the last character of the line. +Solution: Correct the cursor position for the change in indent. +Files: src/ops.c + +Patch 5.4.x1 (note: Replaces patch 5.4.9) +Problem: Win32 GUI: menu hints were never used, because WANT_MENU is not + defined until vim.h is included. +Solution: Move the #ifdef WANT_MENU from where MENUHINTS is defined to where + it is used. +Files: src/gui_w32.c + +Patch 5.4.x2 +Problem: BeOS: When pasting text, one character was moved to the end. +Solution: Re-enable the BeOS code in fill_input_buf(), and fix timing out + with acquire_sem_etc(). (Will Day) +Files: src/os_beos.c, src/ui.c + +Patch 5.4.x3 +Problem: Win32 GUI: When dropping a directory on a running gvim it crashes. +Solution: Avoid using a NULL file name. Also display a message to indicate + that the current directory was changed. +Files: src/gui_w32.c + +Patch 5.4.x4 +Problem: Win32 GUI: Removing an item from the popup menu doesn't work. +Solution: Don't remove the item from the menubar, but from the parent popup + menu. +Files: src/gui_w32.c + +Patch 5.4.x5 (addition to 5.4.34) +Files: src/gui_w32.c + +Patch 5.4.x6 +Problem: Win32: Expanding (dir)name starting with a dot doesn't work. + (McCormack) Only when there is a path before it. +Solution: Fix the check, done before expansion, if the file name pattern + starts with a dot. +Files: src/os_win32.c + +Patch 5.4.x7 +Problem: Win32 GUI: Removing "Edit with Vim" from registry is difficult. +Solution: Add uninstall program to remove the registry keys. It is installed + in the "Add/Remove programs" list for ease of use. + Also: don't set $VIM when the executable is with the runtime files. + Also: Add a text file with a step-by-step description of how to + uninstall Vim for DOS and Windows. +Files: src/uninstal.c, src/dosinst.c, src/Makefile.w32, uninstal.txt + +Patch 5.4.x8 (addition to 5.4.45) +Files: many + +Patch 5.4.x9 +Problem: Win32 GUI: After executing an external command, focus is not + always regained (when using focus-follows-mouse). +Solution: Add SetFocus() in mch_system(). (Mike Steed) +Files: src/os_win32.c + + +Patch 5.5a.1 +Problem: ":let @* = @:" did not work. The text was not put on the + I clipboard. (Fisher) +Solution: Own the clipboard and put the text on it. +Files: src/ops.c + +Patch 5.5a.2 +Problem: append() did not mark the buffer modified. Marks below the + new line were not adjusted. +Solution: Fix the f_append() function. +Files: src/eval.c + +Patch 5.5a.3 +Problem: Editing compressed ".gz" files doesn't work on non-Unix systems, + because there is no "mv" command. +Solution: Add the rename() function and use it instead of ":!mv". + Also: Disable the automatic jump to the last position, because it + changes the jumplist. +Files: src/eval.c, runtime/doc/eval.txt, runtime/vimrc_example.vim + +Patch 5.5a.4 +Problem: When using whole-line completion in insert mode while the cursor + is in the indent, get "out of memory" error. (Stekrt) +Solution: Don't allocate a negative amount of memory in ins_complete(). +Files: src/edit.c + +Patch 5.5a.5 +Problem: Win32: The 'path' option can hold only up to 256 characters, + because _MAX_PATH is 256. (Robert Webb) +Solution: Use a fixed path length of 1024. +Files: src/os_win32.h + +Patch 5.5a.6 +Problem: Compiling with gcc on Win32, using the Unix Makefile, didn't work. +Solution: Add $(SUFFIX) to all places where an executable is used. Also + pass it to ctags. (Reynolds) +Files: src/Makefile + +Patch 5.5a.7 +Problem: When using "cat | vim -" in an xterm, the xterm version reply + would end up in the file. +Solution: Read the file from stdin before switching the terminal to RAW + mode. Should also avoid problems with programs that use a + specific terminal setting. + Also: when using the GUI, print "Reading from stdin..." in the GUI + window, to give a hint why it doesn't do anything. +Files: src/main.c, src/fileio.c + +Patch 5.5a.8 +Problem: On multi-threaded Solaris, suspending doesn't work. +Solution: Call pause() when the SIGCONT signal was not received after + sending the SIGTSTP signal. (Nagano) +Files: src/os_unix.c + +Patch 5.5a.9 +Problem: 'winaltkeys' could be set to an empty argument, which is illegal. +Solution: Give an error message when doing ":set winaltkeys=". +Files: src/option.c + +Patch 5.5a.10 +Problem: Win32 console: Using ALTGR on a German keyboard to produce "}" + doesn't work, because the 8th bit is set when ALT is pressed. +Solution: Don't set the 8th bit when ALT and CTRL are used. (Leipert) +Files: src/os_win32.c + +Patch 5.5a.11 +Problem: Tcl: Configure always uses tclsh8.0. + Also: Loading a library doesn't work. +Solution: Add "--with-tclsh" configure argument to allow specifying another + name for the tcl shell. + Call Tcl_Init() in tclinit() to make loading libraries work. + (Johannes Zellner) +Files: src/configure.in, src/configure, src/if_tcl.c + +Patch 5.5a.12 +Problem: The "user_commands" feature is called "user-commands". +Solution: Replace "user-commands" with "user_commands". (Kim Sung-bom) + Keep "user-commands" for the has() function, to remain backwards + compatible with 5.4. +Files: src/eval.c, src/version.c + +Patch 5.5a.13 +Problem: OS/2: When $HOME is not defined, "C:/" is used for the viminfo + file. That is very wrong when OS/2 is on another partition. +Solution: Use $VIM for the viminfo file when it is defined, like for MSDOS. + Also: Makefile.os2 didn't depend on os_unix.h. +Files: src/os_unix.h, src/Makefile.os2 + +Patch 5.5a.14 +Problem: Athena, Motif and GTK: The Mouse scroll wheel doesn't work. +Solution: Interpret a click of the wheel as a key press of the <MouseDown> + or <MouseUp> keys. Default behavior is to scroll three lines, or + a full page when Shift is used. +Files: src/edit.c, src/ex_getln.c, src/gui.c, src/gui_gtk_x11.c, + src/gui_x11.c, src/keymap.h, src/message.c, src/misc1.c, + src/misc2.c, src/normal.c, src/proto/normal.pro, src/vim.h, + runtime/doc/scroll.txt + +Patch 5.5a.15 +Problem: Using CTRL-A in Insert mode doesn't work correctly when the insert + started with the <Insert> key. (Andreas Rohrschneider) +Solution: Replace <Insert> with "i" before setting up the redo buffer. +Files: src/normal.c + +Patch 5.5a.16 +Problem: VMS: GUI does not compile and run. +Solution: Various fixes. (Zoltan Arpadffy) + Moved functions from os_unix.c to ui.c, so that VMS can use them + too: open_app_context(), x11_setup_atoms() and clip_x11* functions. + Made xterm_dpy global, it's now used by ui.c and os_unix.c. + Use gethostname() always, sys_hostname doesn't exist. +Files: src/globals.h, src/gui_x11.c, src/os_vms.mms, src/os_unix.c, + src/os_vms.c, src/ui.c, src/proto/os_unix.pro, src/proto/ui.pro + +Renamed AdjustCursorForMultiByteCharacter() to AdjustCursorForMultiByteChar() +to avoid symbol length limit of 31 characters. (Steve P. Wall) + +Patch 5.5b.1 +Problem: SASC complains about dead assignments and implicit type casts. +Solution: Removed the dead assignments. Added explicit type casts. +Files: src/buffer.c, src/edit.c, src/eval.c, src/ex_cmds.c, + src/ex_getln.c, src/fileio.c, src/getchar.c, src/memline.c, + src/menu.c, src/misc1.c, src/normal.c, src/ops.c, src/quickfix.c, + src/screen.c + +Patch 5.5b.2 +Problem: When using "CTRL-O O" in Insert mode, hit <Esc> and then "o" in + another line truncates that line. (Devin Weaver) +Solution: When using a command that starts Insert mode from CTRL-O, reset + "restart_edit" first. This avoids that edit() is called with a + mix of starting a new edit command and restarting a previous one. +Files: src/normal.c + +============================================================================== +VERSION 5.6 *version-5.6* + +Version 5.6 is a bug-fix version of 5.5. + + +Changed *changed-5.6* +------- + +Small changes to OleVim files. (Christian Schaller) + +Inserted "/**/" between patch numbers in src/version.c. This allows for one +line of context, which some versions of patch need. + +Reordered the Syntax menu to avoid long submenus. Removed keyboard shortcuts +for alphabetical items to avoid a clash with fixed items. + + +Added *added-5.6* +----- + +Included Exuberant Ctags version 3.4. (Darren Hiebert) + +OpenWithVim in Python. (Christian Schaller) + +Win32 GUI: gvimext.dll, for the context menu "Edit with Vim" entry. Avoids +the reported problems with the MS Office taskbar. Now it's a Shell Extension. +(Tianmiao Hu) + +New syntax files: +abel Abel (John Cook) +aml Arc Macro Language (Nikki Knuit) +apachestyle Apache-style config file (Christian Hammers) +cf Cold Fusion (Jeff Lanzarotta) +ctrlh files with CTRL-H sequences (Bram Moolenaar) +cupl CUPL (John Cook) +cuplsim CUPL simulation (John Cook) +erlang Erlang (Kresimir Marzic) +gedcom Gedcom (Paul Johnson) +icon Icon (Wendell Turner) +ist MakeIndex style (Peter Meszaros) +jsp Java Server Pages (Rafael Garcia-Suarez) +rcslog Rcslog (Joe Karthauser) +remind Remind (Davide Alberani) +sqr Structured Query Report Writer (Paul Moore) +tads TADS (Amir Karger) +texinfo Texinfo (Sandor Kopanyi) +xpm2 X Pixmap v2 (Steve Wall) + +The 'C' flag in 'cpoptions' can be used to switch off concatenation for +sourced lines. See patch 5.5.013 below. |line-continuation| + +"excludenl" argument for the ":syntax" command. See patch 5.5.032 below. +|:syn-excludenl| + +Implemented |z+| and |z^| commands. See patch 5.5.050 below. + +Vim logo in Corel Draw format. Can be scaled to any resolution. + + +Fixed *fixed-5.6* +----- + +Using this mapping in Select mode, terminated completion: +":vnoremap <C-N> <Esc>a<C-N>" (Benji Fisher) +Ignore K_SELECT in ins_compl_prep(). + +VMS (Zoltan Arpadffy, David Elins): +- ioctl() in pty.c caused trouble, #ifndef VMS added. +- Cut & paste mismatch corrected. +- Popup menu line crash corrected. (Patch 5.5.047) +- Motif directories during open and save as corrected. +- Handle full file names with version numbers. (Patch 5.5.046) +- Directory handling (CD command etc.) +- Corrected file name conversion VMS to Unix and v.v. +- Recovery was not working. +- Terminal and signal handling was outdated compared to os_unix.c. +- Improved os_vms.txt. + +Configure used fprintf() instead of printf() to check for __DATE__ and +__TIME__. (John Card II) + +BeOS: Adjust computing the char_height and char_ascent. Round them up +separately, avoids redrawing artifacts. (Mike Steed) + +Fix a few multi-byte problems in menu_name_skip(), set_reg_ic(), searchc() and +findmatchlimit(). (Taro Muraoka) + +GTK GUI: +- With GTK 1.2.5 and later the scrollbars were not redrawn correctly. +- Adjusted the gtk_form_draw() function. +- SNiFF connection didn't work. +- 'mousefocus' was not working. (Dalecki) +- Some keys were not working with modifiers: Shift-Tab, Ctrl-Space and CTRL-@. + + +Patch 5.5.001 +Problem: Configure in the top directory did not pass on an argument with a + space correctly. For example "./configure --previs="/My home". + (Stephane Chazelas) +Solution: Use '"$@"' instead of '$*' to pass on the arguments. +Files: configure + +Patch 5.5.002 +Problem: Compilation error for using "fds[] & POLLIN". (Jeff Walker) +Solution: Use "fds[].revents & POLLIN". +Files: src/os_unix.c + +Patch 5.5.003 +Problem: The autoconf check for sizeof(int) is wrong on machines where + sizeof(size_t) != sizeof(int). +Solution: Use our own configure check. Also fixes the warning for + cross-compiling. +Files: src/configure.in, src/configure + +Patch 5.5.004 +Problem: On Unix it's not possible to interrupt ":sleep 100". +Solution: Switch terminal to cooked mode while asleep, to allow a SIGINT to + wake us up. But switch off echo, added TMODE_SLEEP. +Files: src/term.h, src/os_unix.c + +Patch 5.5.005 +Problem: When using <f-args> with a user command, an empty argument to the + command resulted in one empty string, while no string was + expected. +Solution: Catch an empty argument and pass no argument to the function. + (Paul Moore) +Files: src/ex_docmd.c + +Patch 5.5.006 +Problem: Python: When platform-dependent files are in another directory + than the platform-independent files it doesn't work. +Solution: Also check the executable directory, and add it to CFLAGS. (Tessa + Lau) +Files: src/configure.in, src/configure + +Patch 5.5.007 (extra) +Problem: Win32 OLE: Occasional crash when exiting while still being used + via OLE. +Solution: Move OleUninitialize() to before deleting the application object. + (Vince Negri) +Files: src/if_ole.cpp + +Patch 5.5.008 +Problem: 10000@@ takes a long time and cannot be interrupted. +Solution: Check for CTRL-C typed while in the loop to push the register. +Files: src/normal.c + +Patch 5.5.009 +Problem: Recent Sequent machines don't link with "-linet". (Kurtis Rader) +Solution: Remove configure check for Sequent. +Files: src/configure.in, src/configure + +Patch 5.5.010 +Problem: Ctags freed a memory block twice when exiting. When out of + memory, a misleading error message was given. +Solution: Update to ctags 3.3.2. Also fixes a few other problems. (Darren + Hiebert) +Files: src/ctags/* + +Patch 5.5.011 +Problem: After "CTRL-V s", the cursor jumps back to the start, while all + other operators leave the cursor on the last changed character. + (Xiangjiang Ma) +Solution: Position cursor on last changed character, if possible. +Files: src/ops.c + +Patch 5.5.012 +Problem: Using CTRL-] in Visual mode doesn't work when the text includes a + space (just where it's useful). (Stefan Bittner) +Solution: Don't escape special characters in a tag name with a backslash. +Files: src/normal.c + +Patch 5.5.013 +Problem: The ":append" and ":insert" commands allow using a leading + backslash in a line. The ":source" command concatenates those + lines. (Heinlein) +Solution: Add the 'C' flag in 'cpoptions' to switch off concatenation. +Files: src/ex_docmd.c, src/option.h, runtime/doc/options.txt, + runtime/filetype.vim, runtime/scripts.vim + +Patch 5.5.014 +Problem: When executing a register with ":@", the ":append" command would + get text lines with a ':' prepended. (Heinlein) +Solution: Remove the ':' characters. +Files: src/ex_docmd.c, src/ex_getln.c, src/globals.h + +Patch 5.5.015 +Problem: When using ":g/pat/p", it's hard to see where the output starts, + the ":g" command is overwritten. Vi keeps the ":g" command. +Solution: Keep the ":g" command, but allow overwriting it with the report + for the number of changes. +Files: src/ex_cmds.c + +Patch 5.5.016 (extra) +Problem: Win32: Using regedit to install Vim in the popup menu requires the + user to confirm this in a dialog. +Solution: Use "regedit /s" to avoid the dialog +Files: src/dosinst.c + +Patch 5.5.017 +Problem: If an error occurs when closing the current window, Vim could get + stuck in the error handling. +Solution: Don't set curwin to NULL when closing the current window. +Files: src/window.c + +Patch 5.5.018 +Problem: Absolute paths in shell scripts do not always work. +Solution: Use /usr/bin/env to find out the path. +Files: runtime/doc/vim2html.pl, runtime/tools/efm_filter.pl, + runtime/tools/shtags.pl + +Patch 5.5.019 +Problem: A function call in 'statusline' stops using ":q" twice from + exiting, when the last argument hasn't been edited. +Solution: Don't decrement quitmore when executing a function. (Madsen) +Files: src/ex_docmd.c + +Patch 5.5.020 +Problem: When the output of CTRL-D completion in the commandline goes all + the way to the last column, there is an empty line. +Solution: Don't add a newline when the cursor wrapped already. (Madsen) +Files: src/ex_getln.c + +Patch 5.5.021 +Problem: When checking if a file name in the tags file is relative, + environment variables were not expanded. +Solution: Expand the file name before checking if it is relative. (Madsen) +Files: src/tag.c + +Patch 5.5.022 +Problem: When setting or resetting 'paste' the ruler wasn't updated. +Solution: Update the status lines when 'ruler' changes because of 'paste'. +Files: src/option.c + +Patch 5.5.023 +Problem: When editing a new file and autocommands change the cursor + position, the cursor was moved back to the first non-white, unless + 'startofline' was reset. +Solution: Keep the new column, just like the line number. +Files: src/ex_cmds.c + +Patch 5.5.024 (extra) +Problem: Win32 GUI: When using confirm() to put up a dialog without a + default button, the dialog would not have keyboard focus. + (Krishna) +Solution: Always set focus to the dialog window. Only set focus to a button + when a default one is specified. +Files: src/gui_w32.c + +Patch 5.5.025 +Problem: When using "keepend" in a syntax region, a contained match that + includes the end-of-line could still force that region to + continue, if there is another contained match in between. +Solution: Check the keepend_level in check_state_ends(). +Files: src/syntax.c + +Patch 5.5.026 +Problem: When starting Vim in a white-on-black xterm, with 'bg' set to + "dark", and then starting the GUI with ":gui", setting 'bg' to + "light" in the gvimrc, the highlighting isn't set. (Tsjokwing) +Solution: Set the highlighting when 'bg' is changed in the gvimrc, even + though full_screen isn't set. +Files: src/option.c + +Patch 5.5.027 +Problem: Unix: os_unix.c doesn't compile when XTERM_CLIP is used but + WANT_TITLE isn't. (Barnum) +Solution: Move a few functions that are used by the X11 title and clipboard + and put another "#if" around it. +Files: src/os_unix.c + +Patch 5.5.028 (extra) +Problem: Win32 GUI: When a file is dropped on Win32 gvim while at the ":" + prompt, the file is edited but the command line is actually still + there, the cursor goes back to command line on the next command. + (Krishna) +Solution: When dropping a file or directory on gvim while at the ":" prompt, + insert the name of the file/directory. Allows using the + file/directory name for any Ex command. +Files: src/gui_w32.c + +Patch 5.5.029 +Problem: "das" at the end of the file didn't delete the last character of + the sentence. +Solution: When there is no character after the sentence, make the operation + inclusive in current_sent(). +Files: src/search.c + +Patch 5.5.030 +Problem: Unix: in os_unix.c, "term_str" is used, which is also defined in + vim.h as a macro. (wuxin) +Solution: Renamed "term_str" to "buf" in do_xterm_trace(). +Files: src/os_unix.c + +Patch 5.5.031 (extra) +Problem: Win32 GUI: When exiting Windows, gvim will leave swap files behind + and will be killed ungracefully. (Krishna) +Solution: Catch the WM_QUERYENDSESSION and WM_ENDSESSION messages and try to + exit gracefully. Allow the user to cancel the shutdown if there + is a changed buffer. +Files: src/gui_w32.c + +Patch 5.5.032 +Problem: Patch 5.5.025 wasn't right. And C highlighting was still not + working correctly for a #define. +Solution: Added "excludenl" argument to ":syntax", to be able not to extend + a containing item when there is a match with the end-of-line. +Files: src/syntax.c, runtime/doc/syntax.txt, runtime/syntax/c.vim + +Patch 5.5.033 +Problem: When reading from stdin, a long line in viminfo would mess up the + file message. readfile() uses IObuff for keep_msg, which could be + overwritten by anyone. +Solution: Copy the message from IObuff to msg_buf and set keep_msg to that. + Also change vim_fgets() to not use IObuff any longer. +Files: src/fileio.c + +Patch 5.5.034 +Problem: "gvim -rv" caused a crash. Using 't_Co' before it's set. +Solution: Don't try to initialize the highlighting before it has been + initialized from main(). +Files: src/syntax.c + +Patch 5.5.035 +Problem: GTK with XIM: Resizing with status area was messy, and + ":set guioptions+=b" didn't work. +Solution: Make status area a separate widget, but not a separate window. + (Chi-Deok Hwang) +Files: src/gui_gtk_f.c, src/gui_gtk_x11.c, src/multbyte.c + +Patch 5.5.036 +Problem: The GZIP_read() function in $VIMRUNTIME/vimrc_example.vim to + uncompress a file did not do detection for 'fileformat'. This is + because the filtering is done with 'binary' set. +Solution: Split the filtering into separate write, filter and read commands. +Files: runtime/vimrc_example.vim + +Patch 5.5.037 +Problem: The "U" command didn't mark the buffer as changed. (McCormack) +Solution: Set the 'modified' flag when using "U". +Files: src/undo.c + +Patch 5.5.038 +Problem: When typing a long ":" command, so that the screen scrolls up, + causes the hit-enter prompt, even though the user just typed + return to execute the command. +Solution: Reset need_wait_return if (part of) the command was typed in + getcmdline(). +Files: src/ex_getln.c + +Patch 5.5.039 +Problem: When using a custom status line, "%a" (file # of #) reports the + index of the current window for all windows. +Solution: Pass a window pointer to append_arg_number(), and pass the window + being updated from build_stl_str_hl(). (Stephen P. Wall) +Files: src/buffer.c, src/screen.c, src/proto/buffer.pro + +Patch 5.5.040 +Problem: Multi-byte: When there is some error in xim_real_init(), it can + close XIM and return. After this there can be a segv. +Solution: Test "xic" for being non-NULL, don't set "xim" to NULL. Also try + to find more matches for supported styles. (Sung-Hyun Nam) +Files: src/multbyte.c + +Patch 5.5.041 +Problem: X11 GUI: CTRL-_ requires the SHIFT key only on some machines. +Solution: Translate CTRL-- to CTRL-_. (Robert Webb) +Files: src/gui_x11.c + +Patch 5.5.042 +Problem: X11 GUI: keys with ALT were assumed to be used for the menu, even + when the menu has been disabled by removing 'm' from 'guioptions'. +Solution: Ignore keys with ALT only when gui.menu_is_active is set. (Raf) +Files: src/gui_x11.c + +Patch 5.5.043 +Problem: GTK: Handling of fontset fonts was not right when 'guifontset' + contains exactly 14 times '-'. +Solution: Avoid setting fonts when working with a fontset. (Sung-Hyun Nam) +Files: src/gui_gtk_x11.c + +Patch 5.5.044 +Problem: pltags.pl contains an absolute path "/usr/local/bin/perl". That + might not work everywhere. +Solution: Use "/usr/bin/env perl" instead. +Files: runtime/tools/pltags.pl + +Patch 5.5.045 +Problem: Using "this_session" variable does not work, requires preceding it + with "v:". Default filename for ":mksession" isn't mentioned + in the docs. (Fisher) +Solution: Support using "this_session" to be backwards compatible. +Files: src/eval.c, runtime/doc/options.txt + +Patch 5.5.046 (extra) +Problem: VMS: problems with path and filename. +Solution: Truncate file name at last ';', etc. (Zoltan Arpadffy) +Files: src/buffer.c, src/fileio.c, src/gui_motif.c, src/os_vms.c, + src/proto/os_vms.pro + +Patch 5.5.047 +Problem: VMS: Crash when using the popup menu +Solution: Turn the #define MENU_MODE_CHARS into an array. (Arpadffy) +Files: src/structs.h, src/menu.c + +Patch 5.5.048 +Problem: HP-UX 11: Compiling doesn't work, because both string.h and + strings.h are included. (Squassabia) +Solution: The configure test for including both string.h and strings.h + must include <Xm/Xm.h> first, because it causes problems. +Files: src/configure.in, src/configure, src/config.h.in + +Patch 5.5.049 +Problem: Unix: When installing Vim, the protection bits of files might be + influenced by the umask. +Solution: Add $(FILEMOD) to Makefile. (Shetye) +Files: src/Makefile + +Patch 5.5.050 +Problem: "z+" and "z^" commands are missing. +Solution: Implemented "z+" and "z^". +Files: src/normal.c, runtime/doc/scroll.txt, runtime/doc/index.txt + +Patch 5.5.051 +Problem: Several Unix systems have a problem with the optimization limits + check in configure. +Solution: Removed the configure check, let the user add it manually in + Makefile or the environment. +Files: src/configure.in, src/configure, src/Makefile + +Patch 5.5.052 +Problem: Crash when using a cursor key at the ATTENTION prompt. (Alberani) +Solution: Ignore special keys at the console dialog. Also ignore characters + > 255 for other uses of tolower() and toupper(). +Files: src/menu.c, src/message.c, src/misc2.c + +Patch 5.5.053 +Problem: Indenting is wrong after a function when 'cino' has "fs". Another + problem when 'cino' has "{s". +Solution: Put line after closing "}" of a function at the left margin. + Apply ind_open_extra in the right way after a '{'. +Files: src/misc1.c, src/testdir/test3.in, src/testdir/test3.ok + +Patch 5.5.054 +Problem: Unix: ":e #" doesn't work if the alternate file name contains a + space or backslash. (Hudacek) +Solution: When replacing "#", "%" or other items that stand for a file name, + prepend a backslash before special characters. +Files: src/ex_docmd.c + +Patch 5.5.055 +Problem: Using "<C-V>$r-" in blockwise Visual mode replaces one character + beyond the end of the line. (Zivkov) +Solution: Only replace existing characters. +Files: src/ops.c + +Patch 5.5.056 +Problem: After "z20<CR>" messages were printed at the old command line + position once. (Veselinovic) +Solution: Set msg_row and msg_col when changing cmdline_row in + win_setheight(). +Files: src/window.c + +Patch 5.5.057 +Problem: After "S<Esc>" it should be possible to restore the line with "U". + (Veselinovic) +Solution: Don't call u_clearline() in op_delete() when changing only one + line. +Files: src/ops.c + +Patch 5.5.058 +Problem: Using a long search pattern and then "n" causes the hit-enter + prompt. (Krishna) +Solution: Truncate the echoed pattern, like other messages. Moved code for + truncating from msg_attr() to msg_strtrunc(). +Files: src/message.c, src/proto/message.pro, src/search.c + +Patch 5.5.059 +Problem: GTK GUI: When $term is invalid, using "gvim" gives an error + message, even though $term isn't really used. (Robbins) +Solution: When the GUI is about to start, skip the error messages for a + wrong $term. +Files: src/term.c + +Patch 5.5.060 (extra) +Problem: Dos 32 bit: When a directory in 'backupdir' doesn't exist, ":w" + causes the file to be renamed to "axlqwqhy.ba~". (Matzdorf) +Solution: The code to work around a LFN bug in Windows 95 doesn't handle a + non-existing target name correctly. When renaming fails, make + sure the file has its original name. Also do this for the Win32 + version, although it's unlikely that it runs into this problem. +Files: src/os_msdos.c, src/os_win32.c + +Patch 5.5.061 +Problem: When using "\:" in a modeline, the backslash is included in the + option value. (Mohsin) +Solution: Remove one backslash before the ':' in a modeline. +Files: src/buffer.c, runtime/doc/options.txt + +Patch 5.5.062 (extra) +Problem: Win32 console: Temp files are created in the root of the current + drive, which may be read-only. (Peterson) +Solution: Use the same mechanism of the GUI version: Use $TMP, $TEMP or the + current directory. Cleaned up vim_tempname() a bit. +Files: src/fileio.c, src/os_win32.h, runtime/doc/os_dos.txt + +Patch 5.5.063 +Problem: When using whole-line completion in Insert mode, 'cindent' is + applied, even after changing the indent of the line. +Solution: Don't reindent the completed line after inserting/removing indent. + (Robert Webb) +Files: src/edit.c + +Patch 5.5.064 +Problem: has("sniff") doesn't work correctly. +Solution: Return 1 when Vim was compiled with the +sniff feature. (Pruemmer) +Files: src/eval.c + +Patch 5.5.065 +Problem: When dropping a file on Vim, the 'shellslash' option is not + effective. (Krishna) +Solution: Fix the slashes in the dropped file names according to + 'shellslash'. +Files: src/ex_docmd.c, runtime/doc/options.txt + +Patch 5.5.066 +Problem: For systems with backslash in file name: Setting a file name + option to a value starting with "\\machine" removed a backslash. +Solution: Keep the double backslash for "\\machine", but do change + "\\\\machine" to "\\machine" for backwards compatibility. +Files: src/option.c, runtime/doc/options.txt + +Patch 5.5.067 +Problem: With 'hlsearch' set, the pattern "\>" doesn't highlight the first + match in a line. (Benji Fisher) +Solution: Fix highlighting an empty match. Also highlight the first + character in an empty line for "$". +Files: src/screen.c + +Patch 5.5.068 +Problem: Crash when a ":while" is used with an argument that has an error. + (Sylvain Viart) +Solution: Was using an uninitialized index in the cs_line[] array. The + crash only happened when the index was far off. Made sure the + uninitialized index isn't used. +Files: src/ex_docmd.c + +Patch 5.5.069 +Problem: Shifting lines in blockwise Visual mode didn't set the 'modified' + flag. +Solution: Do set the 'modified' flag. +Files: src/ops.c + +Patch 5.5.070 +Problem: When editing a new file, creating that file outside of Vim, then + editing it again, ":w" still warns for overwriting an existing + file. (Nam) +Solution: The BF_NEW flag in the "b_flags" field wasn't cleared properly. +Files: src/buffer.c, src/fileio.c + +Patch 5.5.071 +Problem: Using a matchgroup in a ":syn region", which is the same syntax + group as the region, didn't stop a contained item from matching in + the start pattern. +Solution: Also push an item on the stack when the syntax ID of the + matchgroup is the same as the syntax ID of the region. +Files: src/syntax.c + +Patch 5.5.072 (extra) +Problem: Dos 32 bit: When setting 'columns' to a too large value, Vim may + crash, and the DOS console too. +Solution: Check that the value of 'columns' isn't larger than the number of + columns that the BIOS reports. +Files: src/os_msdos.c, src/proto/os_msdos.pro, src/option.c + +Patch 5.5.073 (extra) +Problem: Win 32 GUI: The Find and Find/Replace dialogs didn't show the + "match case" checkbox. The Find/Replace dialog didn't handle the + "match whole word" checkbox. +Solution: Support the "match case" and "match whole word" checkboxes. +Files: src/gui_w32.c + +Patch 5.6a.001 +Problem: Using <C-End> with a count doesn't work like it does with "G". + (Benji Fisher) +Solution: Accept a count for <C-End> and <C-Home>. +Files: src/normal.c + +Patch 5.6a.002 +Problem: The script for conversion to HTML was an older version. +Solution: Add support for running 2html.vim on a color terminal. +Files: runtime/syntax/2html.vim + +Patch 5.6a.003 +Problem: Defining a function inside a function didn't give an error + message. A missing ":endfunction" doesn't give an error message. +Solution: Allow defining a function inside a function. +Files: src/eval.c, runtime/doc/eval.txt + +Patch 5.6a.004 +Problem: A missing ":endwhile" or ":endif" doesn't give an error message. + (Johannes Zellner) +Solution: Check for missing ":endwhile" and ":endif" in sourced files. + Add missing ":endif" in file selection macros. +Files: src/ex_docmd.c, runtime/macros/file_select.vim + +Patch 5.6a.005 +Problem: 'hlsearch' was not listed alphabetically. The value of 'toolbar' + was changed when 'compatible' is set. +Solution: Moved entry of 'hlsearch' in options[] table down. + Don't reset 'toolbar' option to the default value when + 'compatible' is set. +Files: src/option.c + +Patch 5.6a.006 +Problem: Using a backwards range inside ":if 0" gave an error message. +Solution: Don't complain about a range when it is not going to be used. + (Stefan Roemer) +Files: src/ex_docmd.c + +Patch 5.6a.007 +Problem: ":let" didn't show internal Vim variables. (Ron Aaron) +Solution: Do show ":v" variables for ":let" and ":let v:name". +Files: src/eval.c + +Patch 5.6a.008 +Problem: Selecting a syntax from the Syntax menu gives an error message. +Solution: Replace "else if" in SetSyn() with "elseif". (Ronald Schild) +Files: runtime/menu.vim + +Patch 5.6a.009 +Problem: When compiling with +extra_search but without +syntax, there is a + compilation error in screen.c. (Axel Kielhorn) +Solution: Adjust the #ifdef for declaring and initializing "line" in + win_line(). Also solve compilation problem when +statusline is + used without +eval. Another one when +cmdline_compl is used + without +eval. +Files: src/screen.c, src/misc2.c + +Patch 5.6a.010 +Problem: In a function, ":startinsert!" does not append to the end of the + line if a ":normal" command was used to move the cursor. (Fisher) +Solution: Reset "w_set_curswant" to avoid that w_curswant is changed again. +Files: src/ex_docmd.c + +Patch 5.6a.011 (depends on 5.6a.004) +Problem: A missing ":endif" or ":endwhile" in a function doesn't give an + error message. +Solution: Give that error message. +Files: src/ex_docmd.c + +Patch 5.6a.012 (depends on 5.6a.008) +Problem: Some Syntax menu entries caused a hit-enter prompt. +Solution: Call a function to make the command shorter. Also rename a few + functions to avoid name clashes. +Files: runtime/menu.vim + +Patch 5.6a.013 +Problem: Command line completion works different when another completion + was done earlier. (Johannes Zellner) +Solution: Reset wim_index when starting a new completion. +Files: src/ex_getln.c + +Patch 5.6a.014 +Problem: Various warning messages when compiling and running lint with + different combinations of features. +Solution: Fix the warning messages. +Files: src/eval.c, src/ex_cmds.c, src/ex_docmd.c, src/gui_gtk_x11.c, + src/option.c, src/screen.c, src/search.c, src/syntax.c, + src/feature.h, src/globals.h + +Patch 5.6a.015 +Problem: The vimtutor command doesn't always know the value of $VIMRUNTIME. +Solution: Let Vim expand $VIMRUNTIME, instead of the shell. +Files: src/vimtutor + +Patch 5.6a.016 (extra) +Problem: Mac: Window size is restricted when starting. Cannot drag the + window all over the desktop. +Solution: Get real screen size instead of assuming 640x400. Do not use a + fixed number for the drag limits. (Axel Kielhorn) +Files: src/gui_mac.c + +Patch 5.6a.017 +Problem: The "Paste" entry in popup menu for Visual, Insert and Cmdline + mode is in the wrong position. (Stol) +Solution: Add priority numbers for all Paste menu entries. +Files: runtime/menu.vim + +Patch 5.6a.018 +Problem: GTK GUI: submenu priority doesn't work. + Help dialog could be destroyed too soon. + When closing a dialog window (e.g. the "ATTENTION" one), Vim would + just hang. + When GTK theme is changed, Vim doesn't adjust to the new colors. + Argument for ":promptfind" isn't used. +Solution: Fixed the mentioned problems. + Made the dialogs look&feel nicer. + Moved functions to avoid the need for a forward declaration. + Fixed reentrancy of the file browser dialog. + Added drag&drop support for GNOME. + Init the text for the Find/replace dialog from the last used + search string. Set "match whole word" toggle button correctly. + Made repeat rate for drag outside of window depend on the + distance from the window. (Marcin Dalecki) + Made the drag in Visual mode actually work. + Removed recursiveness protection from gui_mch_get_rgb(), it might + cause more trouble than it solves. +Files: src/ex_docmd.c, src/gui_gtk.c, src/gui_gtk_x11.c, src/ui.c, + src/proto/ui.pro, src/misc2.c + +Patch 5.6a.019 +Problem: When trying to recover through NFS, which uses a large block size, + Vim might think the swap file is empty, because mf_blocknr_max is + zero. (Scott McDermott) +Solution: When computing the number of blocks of the file in mf_open(), + round up instead of down. +Files: src/memfile.c + +Patch 5.6a.020 +Problem: GUI GTK: Could not set display for gvim. +Solution: Add "-display" and "--display" arguments. (Marcin Dalecki) +Files: src/gui_gtk_x11.c + +Patch 5.6a.021 +Problem: Recovering still may not work when the block size of the device + where the swap file is located is larger than 4096. +Solution: Read block 0 with the minimal block size. +Files: src/memline.c, src/memfile.c, src/vim.h + +Patch 5.6a.022 (extra) +Problem: Win32 GUI: When an error in the vimrc causes a dialog to pop up + (e.g., for an existing swap file), Vim crashes. (David Elins) +Solution: Before showing a dialog, open the main window. +Files: src/gui_w32.c + +Patch 5.6a.023 +Problem: Using expand("%:gs??/?") causes a crash. (Ron Aaron) +Solution: Check for running into the end of the string in do_string_sub(). +Files: src/eval.c + +Patch 5.6a.024 +Problem: Using an autocommand to delete a buffer when leaving it can cause + a crash when jumping to a tag. (Franz Gorkotte) +Solution: In do_tag(), store tagstacklen before jumping to another buffer. + Check tagstackidx after jumping to another buffer. + Add extra check in win_split() if tagname isn't NULL. +Files: src/tag.c, src/window.c + +Patch 5.6a.025 (extra) +Problem: Win32 GUI: The tables for toupper() and tolower() are initialized + too late. (Mike Steed) +Solution: Move the initialization to win32_init() and call it from main(). +Files: src/main.c, src/os_w32.c, src/proto/os_w32.pro + +Patch 5.6a.026 +Problem: When the SNiFF connection is open, shell commands hang. (Pruemmer) +Solution: Skip a second wait() call if waitpid() already detected that the + child has exited. +Files: src/os_unix.c + +Patch 5.6a.027 (extra) +Problem: Win32 GUI: The "Edit with Vim" popup menu entry causes problems + for the Office toolbar. +Solution: Use a shell extension dll. (Tianmiao Hu) + Added it to the install and uninstal programs, replaces the old + "Edit with Vim" menu registry entries. +Files: src/dosinst.c, src/uninstal.c, gvimext/*, runtime/doc/gui_w32.txt + +Patch 5.6a.028 (extra) +Problem: Win32 GUI: Dialogs and tear-off menus can't handle multi-byte + characters. +Solution: Adjust nCopyAnsiToWideChar() to handle multi-byte characters + correctly. +Files: src/gui_w32.c + +============================================================================== +VERSION 5.7 *version-5.7* + +Version 5.7 is a bug-fix version of 5.6. + +Changed *changed-5.7* +------- + +Renamed src/INSTALL.mac to INSTALL_mac.txt to avoid it being recognized with a +wrong file type. Also renamed src/INSTALL.amiga to INSTALL_ami.txt. + + +Added *added-5.7* +----- + +New syntax files: +stp Stored Procedures (Jeff Lanzarotta) +snnsnet, snnspat, snnsres SNNS (Davide Alberani) +mel MEL (Robert Minsk) +ruby Ruby (Mirko Nasato) +tli TealInfo (Kurt W. Andrews) +ora Oracle config file (Sandor Kopanyi) +abaqus Abaqus (Carl Osterwisch) +jproperties Java Properties (Simon Baldwin) +apache Apache config (Allan Kelly) +csp CSP (Jan Bredereke) +samba Samba config (Rafael Garcia-Suarez) +kscript KDE script (Thomas Capricelli) +hb Hyper Builder (Alejandro Forero Cuervo) +fortran Fortran (rewritten) (Ajit J. Thakkar) +sml SML (Fabrizio Zeno Cornelli) +cvs CVS commit (Matt Dunford) +aspperl ASP Perl (Aaron Hope) +bc BC calculator (Vladimir Scholtz) +latte Latte (Nick Moffitt) +wml WML (Gerfried Fuchs) + +Included Exuberant ctags 3.5.1. (Darren Hiebert) + +"display" and "fold" arguments for syntax items. For future extension, they +are ignored now. + +strftime() function for the Macintosh. + +macros/explorer.vim: A file browser script (M A Aziz Ahmed) + + +Fixed *fixed-5.7* +----- + +The 16 bit MS-DOS version is now compiled with Bcc 3.1 instead of 4.0. The +executable is smaller. + +When a "make test" failed, the output file was lost. Rename it to +test99.failed to be able to see what went wrong. + +After sourcing bugreport.vim, it's not clear that bugreport.txt has been +written in the current directory. Edit bugreport.txt to avoid that. + +Adding IME support when using Makefile.w32 didn't work. (Taro Muraoka) + +Win32 console: Mouse drags were passed on even when the mouse didn't move. + +Perl interface: In Buffers(), type of argument to SvPV() was int, should be +STRLEN. (Tony Leneis) + +Problem with prototype for index() on AIX 4.3.0. Added check for _AIX43 in +os_unix.h. (Jake Hamby) + +Mappings in mswin.vim could break when some commands are mapped. Add "nore" +to most mappings to avoid re-mapping. + +modify_fname() made a copy of a file name for ":p" when it already was a full +path name, which is a bit slow. + +Win32 with Borland C++ 5.5: Pass the path to the compiler on to xxd and ctags, +to avoid depending on $PATH. Fixed "make clean". + +Many fixes to Macintosh specific parts: (mostly by Dany StAmant) +- Only one Help menu. +- No more crash when removing a menu item. +- Support as External Editor for Codewarrior (still some little glitches). +- Popup menu support. +- Fixed crash when pasting after application switch. +- Color from rgb.txt properly displayed. +- 'isprint' default includes all chars above '~'. (Axel Kielhorn) +- mac_expandpath() was leaking memory. +- Add digraphs table. (Axel Kielhorn) +- Multi-byte support: (Kenichi Asai) + Switch keyscript when going in/out of Insert mode. + Draw multi-byte character correctly. + Don't use mblen() but highest bit of char to detect multi-byte char. + Display value of multi-byte in statusline (also for other systems). +- mouse button was not initialized properly to MOUSE_LEFT when + USE_CTRLCLICKMENU not defined. +- With Japanese SJIS characters: Make "w", "b", and "e" work + properly. (Kenichi Asai) +- Replaced old CodeWarrior file os_mac.CW9.hqx with os_mac.cw5.sit.hqx. + +Fixes for VMS: (Zoltan Arpadffy) (also see patch 5.6.045 below) +- Added Makefile_vms.mms and vimrc.vms to src/testdir to be able to run the + tests. +- Various fixes. +- Set 'undolevels' to 1000 by default. +- Made mch_settitle() equivalent to the one in os_unix.c. + +RiscOS: A few prototypes for os_riscos.c were outdated. Generate prototypes +automatically. + + +Previously released patches: + +Patch 5.6.001 +Problem: When using "set bs=0 si cin", Inserting "#<BS>" or "}<BS>" which + reduces the indent doesn't delete the "#" or "}". (Lorton) +Solution: Adjust ai_col in ins_try_si(). +Files: src/edit.c + +Patch 5.6.002 +Problem: When using the vim.vim syntax file, a comment with all uppercase + characters causes a hang. +Solution: Adjust pattern for vimCommentTitle (Charles Campbell) +Files: runtime/syntax/vim.vim + +Patch 5.6.003 +Problem: GTK GUI: Loading a user defined toolbar bitmap gives a warning + about the colormap. Probably because the window has not been + opened yet. +Solution: Use gdk_pixmap_colormap_create_from_xpm() to convert the xpm file. + (Keith Radebaugh) +Files: src/gui_gtk.c + +Patch 5.6.004 (extra) +Problem: Win32 GUI with IME: When setting 'guifont' to "*", the font + requester appears twice. +Solution: In gui_mch_init_font() don't call get_logfont() but copy + norm_logfont from fh. (Yasuhiro Matsumoto) +Files: src/gui_w32.c + +Patch 5.6.005 +Problem: When 'winminheight' is zero, CTRL-W - with a big number causes a + crash. (David Kotchan) +Solution: Check for negative window height in win_setheight(). +Files: src/window.c + +Patch 5.6.006 +Problem: GTK GUI: Bold font cannot always be used. Memory is freed too + early in gui_mch_init_font(). +Solution: Move call to g_free() to after where sdup is used. (Artem Hodyush) +Files: src/gui_gtk_x11.c + +Patch 5.6.007 (extra) +Problem: Win32 IME: Font is not changed when screen font is changed. And + IME composition window does not trace the cursor. +Solution: Initialize IME font. When cursor is moved, set IME composition + window with ImeSetCompositionWindow(). Add call to + ImmReleaseContext() in several places. (Taro Muraoka) +Files: src/gui.c, src/gui_w32.c, src/proto/gui_w32.pro + +Patch 5.6.008 (extra) +Problem: Win32: When two files exist with the same name but different case + (through NFS or Samba), fixing the file name case could cause the + wrong one to be edited. +Solution: Prefer a perfect match above a match while ignoring case in + fname_case(). (Flemming Madsen) +Files: src/os_win32.c + +Patch 5.6.009 (extra) +Problem: Win32 GUI: Garbage in Windows Explorer help line when selecting + "Edit with Vim" popup menu entry. +Solution: Only return the help line when called with the GCS_HELPTEXT flag. + (Tianmiao Hu) +Files: GvimExt/gvimext.cpp + +Patch 5.6.010 +Problem: A file name which contains a TAB was not read correctly from the + viminfo file and the ":ls" listing was not aligned properly. +Solution: Parse the buffer list lines in the viminfo file from the end + backwards. Count a Tab for two characters to align the ":ls" list. +Files: src/buffer.c + +Patch 5.6.011 +Problem: When 'columns' is huge (using a tiny font) and 'statusline' is + used, Vim can crash. +Solution: Limit maxlen to MAXPATHL in win_redr_custom(). (John Mullin) +Files: src/screen.c + +Patch 5.6.012 +Problem: When using "zsh" for /bin/sh, toolcheck may hang until "exit" is + typed. (Kuratczyk) +Solution: Add "-c exit" when checking for the shell version. +Files: src/toolcheck + +Patch 5.6.013 +Problem: Multibyte char in tooltip is broken. +Solution: Consider multibyte char in replace_termcodes(). (Taro Muraoka) +Files: src/term.c + +Patch 5.6.014 +Problem: When cursor is at the end of line and the character under cursor + is a multibyte character, "yl" doesn't yank 1 multibyte-char. + (Takuhiro Nishioka) +Solution: Recognize a multibyte-char at end-of-line correctly in oneright(). + (Taro Muraoka) + Also: make "+quickfix" in ":version" output appear alphabetically. +Files: src/edit.c + +Patch 5.6.015 +Problem: New xterm delete key sends <Esc>[3~ by default. +Solution: Added <kDel> and <kIns> to make the set of keypad keys complete. +Files: src/edit.c, src/ex_getln.c, src/keymap.h, src/misc1.c, + src/misc2.c, src/normal.c, src/os_unix.c, src/term.c + +Patch 5.6.016 +Problem: When deleting a search string from history from inside a mapping, + another entry is deleted too. (Benji Fisher) +Solution: Reset last_maptick when deleting the last entry of the search + history. Also: Increment maptick when starting a mapping from + typed characters to avoid a just added search string being + overwritten or removed from history. +Files: src/ex_getln.c, src/getchar.c + +Patch 5.6.017 +Problem: ":s/e/\^M/" should replace an "e" with a CTRL-M, not split the + line. (Calder) +Solution: Replace the backslash with a CTRL-V internally. (Stephen P. Wall) +Files: src/ex_cmds.c + +Patch 5.6.018 +Problem: ":help [:digit:]" takes a long time to jump to the wrong place. +Solution: Insert a backslash to avoid the special meaning of '[]'. +Files: src/ex_cmds.c + +Patch 5.6.019 +Problem: "snd.c", "snd.java", etc. were recognized as "mail" filetype. +Solution: Make pattern for mail filetype more strict. +Files: runtime/filetype.vim + +Patch 5.6.020 (extra) +Problem: The DJGPP version eats processor time (Walter Briscoe). +Solution: Call __dpmi_yield() in the busy-wait loop. +Files: src/os_msdos.c + +Patch 5.6.021 +Problem: When 'selection' is "exclusive", a double mouse click in Insert + mode doesn't select last char in line. (Lutz) +Solution: Allow leaving the cursor on the NUL past the line in this case. +Files: src/edit.c + +Patch 5.6.022 +Problem: ":e \~<Tab>" expands to ":e ~\$ceelen", which doesn't work. +Solution: Re-insert the backslash before the '~'. +Files: src/ex_getln.c + +Patch 5.6.023 (extra) +Problem: Various warnings for the Ming compiler. +Solution: Changes to avoid the warnings. (Bill McCarthy) +Files: src/ex_cmds.c, src/gui_w32.c, src/os_w32exe.c, src/os_win32.c, + src/syntax.c, src/vim.rc + +Patch 5.6.024 (extra) +Problem: Win32 console: Entering CTRL-_ requires the shift key. (Kotchan) +Solution: Specifically catch keycode 0xBD, like the GUI. +Files: src/os_win32.c + +Patch 5.6.025 +Problem: GTK GUI: Starting the GUI could be interrupted by a SIGWINCH. + (Nils Lohner) +Solution: Repeat the read() call to get the gui_in_use value when + interrupted by a signal. +Files: src/gui.c + +Patch 5.6.026 (extra) +Problem: Win32 GUI: Toolbar bitmaps are searched for in + $VIMRUNTIME/bitmaps, while GTK looks in $VIM/bitmaps. (Keith + Radebaugh) +Solution: Use $VIM/bitmaps for both, because these are not part of the + distribution but defined by the user. +Files: src/gui_w32.c, runtime/doc/gui.txt + +Patch 5.6.027 +Problem: TCL: Crash when using a Tcl script (reported for Win32). +Solution: Call Tcl_FindExecutable() in main(). (Brent Fulgham) +Files: src/main.c + +Patch 5.6.028 +Problem: Xterm patch level 126 sends codes for mouse scroll wheel. + Fully works with xterm patch level 131. +Solution: Recognize the codes for button 4 (0x60) and button 5 (0x61). +Files: src/term.c + +Patch 5.6.029 +Problem: GTK GUI: Shortcut keys cannot be used for a dialog. (Johannes + Zellner) +Solution: Add support for shortcut keys. (Marcin Dalecki) +Files: src/gui_gtk.c + +Patch 5.6.030 +Problem: When closing a window and 'ea' is set, Vim can crash. (Yasuhiro + Matsumoto) +Solution: Set "curbuf" to a valid value in win_close(). +Files: src/window.c + +Patch 5.6.031 +Problem: Multi-byte: When a double-byte character ends in CSI, Vim waits + for another character to be typed. +Solution: Recognize the CSI as the second byte of a character and don't wait + for another one. (Yasuhiro Matsumoto) +Files: src/getchar.c + +Patch 5.6.032 +Problem: Functions with an argument that is a line number don't all accept + ".", "$", etc. (Ralf Arens) +Solution: Add get_art_lnum() and use it for setline(), line2byte() and + synID(). +Files: src/eval.c + +Patch 5.6.033 +Problem: Multi-byte: "f " sometimes skips to the second space. (Sung-Hyun + Nam) +Solution: Change logic in searchc() to skip trailing byte of a double-byte + character. + Also: Ask for second byte when searching for double-byte + character. (Park Chong-Dae) +Files: src/search.c + +Patch 5.6.034 (extra) +Problem: Compiling with Borland C++ 5.5 fails on tolower() and toupper(). +Solution: Use TO_LOWER() and TO_UPPER() instead. Also adjust the Makefile + to make using bcc 5.5 easier. +Files: src/edit.c, src/ex_docmd.c, src/misc1.c, src/Makefile.bor + +Patch 5.6.035 +Problem: Listing the"+comments" feature in the ":version" output depended + on the wrong ID. (Stephen P. Wall) +Solution: Change "CRYPTV" to "COMMENTS". +Files: src/version.c + +Patch 5.6.036 +Problem: GTK GUI: Copy/paste text doesn't work between gvim and Eterm. +Solution: Support TEXT and COMPOUND_TEXT selection targets. (ChiDeok Hwang) +Files: src/gui_gtk_x11.c + +Patch 5.6.037 +Problem: Multi-byte: Can't use "f" command with multi-byte character in GUI. +Solution: Enable XIM in Normal mode for the GUI. (Sung-Hyun Nam) +Files: src/gui_gtk_x11.c, src/multbyte.c + +Patch 5.6.038 +Problem: Multi-clicks in GUI are interpreted as a mouse wheel click. When + 'ttymouse' is "xterm" a mouse click is interpreted as a mouse + wheel click. +Solution: Don't recognize the mouse wheel in check_termcode() in the GUI. + Use 0x43 for a mouse drag in do_xterm_trace(), not 0x63. +Files: src/term.c, src/os_unix.c + +Patch 5.6.039 +Problem: Motif GUI under KDE: When trying to logout, Vim hangs up the + system. (Hermann Rochholz) +Solution: When handling the WM_SAVE_YOURSELF event, set the WM_COMMAND + property of the window to let the session manager know we finished + saving ourselves. +Files: src/gui_x11.c + +Patch 5.6.040 +Problem: When using ":s" command, matching the regexp is done twice. +Solution: After copying the matched line, adjust the pointers instead of + finding the match again. (Loic Grenie) Added vim_regnewptr(). +Files: src/ex_cmds.c, src/regexp.c, src/proto/regexp.pro + +Patch 5.6.041 +Problem: GUI: Athena, Motif and GTK don't give more than 10 dialog buttons. +Solution: Remove the limit on the number of buttons. + Also support the 'v' flag in 'guioptions'. + For GTK: Center the buttons. +Files: src/gui_athena.c, src/gui_gtk.c, src/gui_motif.c + +Patch 5.6.042 +Problem: When doing "vim -u vimrc" and vimrc contains ":q", the cursor in + the terminal can remain off. +Solution: Call cursor_on() in mch_windexit(). +Files: src/os_unix.c + +Patch 5.6.043 (extra) +Problem: Win32 GUI: When selecting guifont with the dialog, 'guifont' + doesn't include the bold or italic attributes. +Solution: Append ":i" and/or ":b" to 'guifont' in gui_mch_init_font(). +Files: src/gui_w32.c + +Patch 5.6.044 (extra) +Problem: MS-DOS and Windows: The line that dosinst.exe appends to + autoexec.bat to set PATH is wrong when Vim is in a directory with + an embedded space. +Solution: Use double quotes for the value when there is an embedded space. +Files: src/dosinst.c + +Patch 5.6.045 (extra) (fixed version) +Problem: VMS: Various small problems. +Solution: Many small changes. (Zoltan Arpadffy) + File name modifier ":h" keeps the path separator. + File name modifier ":e" also removes version. + Compile with MAX_FEAT by default. + When checking for autocommands ignore version in file name. + Be aware of file names being case insensitive. + Added vt320 builtin termcap. + Be prepared for an empty default_vim_dir. +Files: runtime/gvimrc_example.vim, runtime/vimrc_example.vim, + runtime/doc/os_vms.txt, src/eval.c, src/feature.h, src/fileio.c, + src/gui_motif.c, src/gui_vms_conf.h, src/main.c, src/memline.c, + src/misc1.c, src/option.c, src/os_vms_conf.h, src/os_vms.c, + src/os_vms.h, src/os_vms.mms, src/tag.c, src/term.c, src/version.c + +Patch 5.6.046 +Problem: Systems with backslash in file name: With 'shellslash' set, "vim + */*.c" only uses a slash for the first file name. (Har'El) +Solution: Fix slashes in file name arguments after reading the vimrc file. +Files: src/option.c + +Patch 5.6.047 +Problem: $CPPFLAGS is not passed on to ctags configure. +Solution: Add it. (Walter Briscoe) +Files: src/config.mk.in, src/Makefile + +Patch 5.6.048 +Problem: CTRL-R in Command-line mode is documented to insert text as typed, + but inserts text literally. +Solution: Make CTRL-R insert text as typed, use CTRL-R CTRL-R to insert + literally. This is consistent with Insert mode. But characters + that end Command-line mode are inserted literally. +Files: runtime/doc/index.txt, runtime/doc/cmdline.txt, src/ex_getln.c, + src/ops.c, src/proto/ops.pro + +Patch 5.6.049 +Problem: Documentation for [!] after ":ijump" is wrong way around. (Benji + Fisher) +Solution: Fix the documentation. Also improve the code to check for a match + after a /* */ comment. +Files: runtime/doc/tagsearch.txt, src/search.c + +Patch 5.6.050 +Problem: Replacing is wrong when replacing a single-byte char with + double-byte char or the other way around. +Solution: Shift the text after the character when it is replaced. + (Yasuhiro Matsumoto) +Files: src/normal.c, src/misc1.c + +Patch 5.6.051 +Problem: ":tprev" and ":tnext" don't give an error message when trying to + go before the first or beyond the last tag. (Robert Webb) +Solution: Added error messages. Also: Delay a second when a file-read + message is going to overwrite an error message, otherwise it won't + be seen. +Files: src/fileio.c, src/tag.c + +Patch 5.6.052 +Problem: Multi-byte: When an Ex command has a '|' or '"' as a second byte, + it terminates the command. +Solution: Skip second byte of multi-byte char when checking for '|' and '"'. + (Asai Kenichi) +Files: src/ex_docmd.c + +Patch 5.6.053 +Problem: CTRL-] doesn't work on a tag that contains a '|'. (Cesar Crusius) +Solution: Escape '|', '"' and '\' in tag names when using CTRL-] and also + for command-line completion. +Files: src/ex_getln.c, src/normal.c + +Patch 5.6.054 +Problem: When using ":e" and ":e #" the cursor is put in the first column + when 'startofline' is set. (Cordell) +Solution: Use the last known column when 'startofline' is set. + Also, use ECMD_LAST more often to simplify the code. +Files: src/buffer.c, src/ex_cmds.c, src/ex_docmd.c, src/proto/buffer.pro + +Patch 5.6.055 +Problem: When 'statusline' only contains a text without "%" and doesn't fit + in the window, Vim crashes. (Ron Aaron) +Solution: Don't use the pointer for the first item if there is no item. +Files: src/screen.c + +Patch 5.6.056 (extra) +Problem: MS-DOS: F11 and F12 don't work when 'bioskey' is set. +Solution: Use enhanced keyboard functions. (Vince Negri) + Detect presence of enhanced keyboard and set bioskey_read and + bioskey_ready. +Files: src/os_msdos.c + +Patch 5.6.057 (extra) +Problem: Win32 GUI: Multi-byte characters are wrong in dialogs and tear-off + menus. +Solution: Use system font instead of a fixed font. (Matsumoto, Muraoka) +Files: src/gui_w32.c + +Patch 5.6.058 +Problem: When the 'a' flag is not in 'guioptions', non-Windows systems + copy Visually selected text to the clipboard/selection on a yank + or delete command anyway. On Windows it isn't done even when the + 'a' flag is included. +Solution: Respect the 'a' flag in 'guioptions' on all systems. +Files: src/normal.c + +Patch 5.6.059 (extra) +Problem: When moving the cursor over italic text and the characters spill + over to the cell on the right, that spill-over is deleted. + Noticed in the Win32 GUI, can happen on other systems too. +Solution: Redraw italic text starting from a blank, like this is already + done for bold text. (Vince Negri) +Files: src/gui.c, src/gui.h, src/gui_w32.c + +Patch 5.6.060 +Problem: Some bold characters spill over to the cell on the left, that + spill-over can remain sometimes. +Solution: Redraw a character when the next character was bold and needs + redrawing. (Robert Webb) +Files: src/screen.c + +Patch 5.6.061 +Problem: When xterm sends 8-bit controls, recognizing the version response + doesn't work. + When using CSI instead of <Esc>[ for the termcap color codes, + using 16 colors doesn't work. (Neil Bird) +Solution: Also accept CSI in place of <Esc>[ for the version string. + Also check for CSI when handling colors 8-15 in term_color(). + Use CSI for builtin xterm termcap entries when 'term' contains + "8bit". +Files: runtime/doc/term.txt, src/ex_cmds.c, src/option.c, src/term.c, + src/os_unix.c, src/proto/option.pro, src/proto/term.pro + +Patch 5.6.062 +Problem: The documentation says that setting 'smartindent' doesn't have an + effect when 'cindent' is set, but it does make a difference for + lines starting with "#". (Neil Bird) +Solution: Really ignore 'smartindent' when 'cindent' is set. +Files: src/misc1.c, src/ops.c + +Patch 5.6.063 +Problem: Using "I" in Visual-block mode doesn't accept a count. (Johannes + Zellner) +Solution: Pass the count on to do_insert() and edit(). (Allan Kelly) +Files: src/normal.c, src/ops.c, src/proto/ops.pro + +Patch 5.6.064 +Problem: MS-DOS and Win32 console: Mouse doesn't work correctly after + including patch 5.6.28. (Vince Negri) +Solution: Don't check for mouse scroll wheel when the mouse code contains + the number of clicks. +Files: src/term.c + +Patch 5.6.065 +Problem: After moving the cursor around in Insert mode, typing a space can + still trigger an abbreviation. (Benji Fisher) +Solution: Don't check for an abbreviation after moving around in Insert mode. +Files: src/edit.c + +Patch 5.6.066 +Problem: Still a few bold character spill-over remains after patch 60. +Solution: Clear character just in front of blanking out rest of the line. + (Robert Webb) +Files: src/screen.c + +Patch 5.6.067 +Problem: When a file name contains a NL, the viminfo file is corrupted. +Solution: Use viminfo_writestring() to convert the NL to CTRL-V n. + Also fix the Buffers menu and listing a menu name with a newline. +Files: runtime/menu.vim, src/buffer.c, src/mark.c, src/menu.c + +Patch 5.6.068 +Problem: Compiling the Perl interface doesn't work with Perl 5.6.0. + (Bernhard Rosenkraenzer) +Solution: Also check xs_apiversion for the version number when prepending + defines for PL_*. +Files: src/Makefile + +Patch 5.6.069 +Problem: "go" doesn't always end up at the right character when + 'fileformat' is "dos". (Bruce DeVisser) +Solution: Correct computations in ml_find_line_or_offset(). +Files: src/memline. + +Patch 5.6.070 (depends on 5.6.068) +Problem: Compiling the Perl interface doesn't work with Perl 5.6.0. + (Bernhard Rosenkraenzer) +Solution: Simpler check instead of the one from patch 68. +Files: src/Makefile + +Patch 5.6.071 +Problem: "A" in Visual block mode on a Tab positions the cursor one char to + the right. (Michael Haumann) +Solution: Correct the column computation in op_insert(). +Files: src/ops.c + +Patch 5.6.072 +Problem: When starting Vim with "vim +startinsert", it enters Insert mode + only after typing the first command. (Andrew Pimlott) +Solution: Insert a dummy command in the stuff buffer. +Files: src/main.c + +Patch 5.6.073 (extra) (depends on 5.6.034) +Problem: Win32 GUI: When compiled with Bcc 5.5 menus don't work. + In dosinst.c toupper() and tolower() give an "internal compiler + error" for Bcc 5.5. +Solution: Define WINVER to 4 to avoid compiling for Windows 2000. (Dan + Sharp) Also cleaned up compilation arguments. + Use our own implementation of toupper() in dosinst.c. Use + mytoupper() instead of tolower(). +Files: src/Makefile.bor, src/dosinst.c + +Patch 5.6.074 (extra) +Problem: Entering CSI directly doesn't always work, because it's recognized + as the start of a special key. Mostly a problem with multi-byte + in the GUI. +Solution: Use K_CSI for a typed CSI character. Use <CSI> for a normal CSI, + <xCSI> for a CSI typed in the GUI. +Files: runtime/doc/intro.txt, src/getchar.c, src/gui_amiga.c, + src/gui_gtk_x11.c, src/gui_mac.c, src/gui_riscos.c, src/gui_w32.c, + src/keymap.h, src/misc2.c + +Patch 5.6.075 +Problem: When using "I" or "A" in Visual block mode while 'sts' is set may + change spaces to a Tab the inserted text is not correct. (Mike + Steed) And some other problems when using "A" to append after the + end of the line. +Solution: Check for change in spaces/tabs after inserting the text. Append + spaces to fill the gap between the end-of-line and the right edge + of the block. +Files: src/ops.c + +Patch 5.6.076 +Problem: GTK GUI: Mapping <M-Space> doesn't work. +Solution: Don't use the "Alt" modifier twice in key_press_event(). +Files: src/gui_gtk_x11.c + +Patch 5.6.077 +Problem: GUI: When interrupting an external program with CTRL-C, gvim might + crash. (Benjamin Korvemaker) +Solution: Avoid using a NULL pointer in ui_inchar_undo(). +Files: src/ui.c + +Patch 5.6.078 +Problem: Locale doesn't always work on FreeBSD. (David O'Brien) +Solution: Link with the "xpg4" library when available. +Files: src/configure.in, src/configure + +Patch 5.6.079 +Problem: Vim could crash when several Tcl interpreters are created and + destroyed. +Solution: handle the "exit" command and nested ":tcl" commands better. (Ingo + Wilken) +Files: runtime/doc/if_tcl.txt, src/if_tcl.c + +Patch 5.6.080 +Problem: When jumping to a tag, generating the tags file and jumping to the + same tag again uses the old search pattern. (Sung-Hyun Nam) +Solution: Flush cached tag matches when executing an external command. +Files: src/misc2.c, src/proto/tag.pro, src/tag.c + +Patch 5.6.081 +Problem: ":syn include" uses a level for the included file, this confuses + contained items included at the same level. +Solution: Use a unique tag for each included file. Changed sp_syn_inc_lvl + to sp_syn_inc_tag. (Scott Bigham) +Files: src/syntax.c, src/structs.h + +Patch 5.6.082 +Problem: When using cscope, Vim can crash. +Solution: Initialize tag_fname in find_tags(). (Anton Blanchard) +Files: src/tag.c + +Patch 5.6.083 (extra) +Problem: Win32: The visual beep can't be seen. (Eric Roesinger) +Solution: Flush the output before waiting with GdiFlush(). (Maurice S. Barnum) + Also: Allow specifying the delay in t_vb for the GUI. +Files: src/gui.c, src/gui_amiga.c, src/gui_gtk_x11.c, src/gui_mac.c, + src/gui_riscos.c, src/gui_w32.c, src/gui_x11.c, src/gui_beos.cc, + src/proto/gui_amiga.pro, src/proto/gui_gtk_x11.pro, + src/proto/gui_mac.pro, src/proto/gui_riscos.pro, + src/proto/gui_w32.pro, src/proto/gui_x11.pro, + src/proto/gui_beos.pro + +Patch 5.6.084 (depends on 5.6.074) +Problem: GUI: Entering CSI doesn't always work for Athena and Motif. +Solution: Handle typed CSI as <xCSI> (forgot this bit in 5.6.074). +Files: src/gui_x11.c + +Patch 5.6.085 +Problem: Multi-byte: Using "r" to replace a double-byte char with a + single-byte char moved the cursor one character. (Matsumoto) + Also, using a count when replacing a single-byte char with a + double-byte char didn't work. +Solution: Don't use del_char() to delete the second byte. + Get "ptr" again after calling ins_char(). +Files: src/normal.c + +Patch 5.6.086 (extra) +Problem: Win32: When using libcall() and the returned value is not a valid + pointer, Vim crashes. +Solution: Use IsBadStringPtr() to check if the pointer is valid. +Files: src/os_win32.c + +Patch 5.6.087 +Problem: Multi-byte: Commands and messages with multi-byte characters are + displayed wrong. +Solution: Detect double-byte characters. (Yasuhiro Matsumoto) +Files: src/ex_getln.c, src/message.c, src/misc2.c, src/screen.c + +Patch 5.6.088 +Problem: Multi-byte with Motif or Athena: The message "XIM requires + fontset" is annoying when Vim was compiled with XIM support but it + is not being used. +Solution: Remove that message. +Files: src/multbyte.c + +Patch 5.6.089 +Problem: On non-Unix systems it's possible to overwrite a read-only file + without using "!". +Solution: Check if the file permissions allow overwriting before moving the + file to become the backup file. +Files: src/fileio.c + +Patch 5.6.090 +Problem: When editing a file in "/home/dir/home/dir" this was replaced with + "~~". (Andreas Jellinghaus) +Solution: Replace the home directory only once in home_replace(). +Files: src/misc1.c + +Patch 5.6.091 +Problem: When editing many "no file" files, can't create swap file, because + .sw[a-p] have all been used. (Neil Bird) +Solution: Also use ".sv[a-z]", ".su[a-z]", etc. +Files: src/memline.c + +Patch 5.6.092 +Problem: FreeBSD: When setting $TERM to a non-valid terminal name, Vim + hangs in tputs(). +Solution: After tgetent() returns an error code, call it again with the + terminal name "dumb". This apparently creates an environment in + which tputs() doesn't fail. +Files: src/term.c + +Patch 5.6.093 (extra) +Problem: Win32 GUI: "ls | gvim -" will show a message box about reading + stdin when Vim exits. (Donohue) +Solution: Don't write a message about the file read from stdin until the GUI + has started. +Files: src/fileio.c + +Patch 5.6.094 +Problem: Problem with multi-byte string for ":echo var". +Solution: Check for length in msg_outtrans_len_attr(). (Sung-Hyun Nam) + Also make do_echo() aware of multi-byte characters. +Files: src/eval.c, src/message.c + +Patch 5.6.095 +Problem: With an Emacs TAGS file that include another a relative path + doesn't always work. +Solution: Use expand_tag_fname() on the name of the included file. + (Utz-Uwe Haus) +Files: src/tag.c + +Patch 5.6.096 +Problem: Unix: When editing many files, startup can be slow. (Paul + Ackersviller) +Solution: Halve the number of stat() calls used to add a file to the buffer + list. +Files: src/buffer.c + +Patch 5.7a.001 +Problem: GTK doesn't respond on drag&drop from ROX-Filer. +Solution: Add "text/uri-list" target. (Thomas Leonard) + Also: fix problem with checking for trash arguments. +Files: src/gui_gtk_x11.c + +Patch 5.7a.002 +Problem: Multi-byte: 'showmatch' is performed when second byte of an + inserted double-byte char is a paren or brace. +Solution: Check IsTrailByte() before calling showmatch(). (Taro Muraoka) +Files: src/misc1.c + +Patch 5.7a.003 +Problem: Multi-byte: After using CTRL-O in Insert mode with the cursor at + the end of the line on a multi-byte character the cursor moves to + the left. +Solution: Check for multi-byte character at end-of-line. (Taro Muraoka) + Also: fix cls() to detect a double-byte character. (Chong-Dae Park) +Files: src/edit.c, src/search.c + +Patch 5.7a.004 +Problem: When reporting the search pattern offset, the string could be + unterminated, which may cause a crash. +Solution: Terminate the string for the search offset. (Stephen P. Wall) +Files: src/search.c + +Patch 5.7a.005 +Problem: When ":s//~/" doesn't find a match it reports "[NULL]" for the + pattern. +Solution: Use get_search_pat() to obtain the actually used pattern. +Files: src/ex_cmds.c, src/proto/search.pro, src/search.c + +Patch 5.7a.006 (extra) +Problem: VMS: Various problems, also with the VAXC compiler. +Solution: In many places use the Unix code for VMS too. + Added time, date and compiler version to version message. + (Zoltan Arpadffy) +Files: src/ex_cmds.c, src/ex_docmd.c, src/globals.h, src/gui_vms_conf.h, + src/main.c, src/message.c, src/misc1.c, src/os_vms.c, + src/os_vms.h, src/os_vms.mms, src/os_vms_conf.h, + src/proto/os_vms.pro, src/proto/version.pro, src/term.c, + src/version.c, src/xxd/os_vms.mms, src/xxd/xxd.c + +Patch 5.7a.007 +Problem: Motif and Athena GUI: CTRL-@ is interpreted as CTRL-C. +Solution: Only use "intr_char" when it has been set. +Files: src/gui_x11.c + +Patch 5.7a.008 +Problem: GTK GUI: When using CTRL-L the screen is redrawn twice, causing + trouble for bold characters. Also happens when moving with the + scrollbar. Best seen when 'writedelay' is non-zero. + When starting the GUI with ":gui" the screen is redrawn once with + the wrong colors. +Solution: Only set the geometry hints when the window size really changed. + This avoids setting it each time the scrollbar is forcefully + redrawn. + Don't redraw in expose_event() when gui.starting is still set. +Files: src/gui_gtk_x11.c + + +============================================================================== +VERSION 5.8 *version-5.8* + +Version 5.8 is a bug-fix version of 5.7. + + +Changed *changed-5.8* +------- + +Ctags is no longer included with Vim. It has grown into a project of its own. +You can find it here: http://ctags.sf.net. It is highly recommended as a Vim +companion when you are writing programs. + + +Added *added-5.8* +----- + +New syntax files: +acedb AceDB (Stewart Morris) +aflex Aflex (Mathieu Clabaut) +antlr Antlr (Mathieu Clabaut) +asm68k 68000 Assembly (Steve Wall) +automake Automake (John Williams) +ayacc Ayacc (Mathieu Clabaut) +b B (Mathieu Clabaut) +bindzone BIND zone (glory hump) +blank Blank (Rafal Sulejman) +cfg Configure files (Igor Prischepoff) +changelog ChangeLog (Gediminas Paulauskas) +cl Clever (Phil Uren) +crontab Crontab (John Hoelzel) +csc Essbase script (Raul Segura Acevedo) +cynlib Cynlib(C++) (Phil Derrick) +cynpp Cyn++ (Phil Derrick) +debchangelog Debian Changelog (Wichert Akkerman) +debcontrol Debian Control (Wichert Akkerman) +dns DNS zone file (Jehsom) +dtml Zope's DTML (Jean Jordaan) +dylan Dylan, Dylan-intr and Dylan-lid (Brent Fulgham) +ecd Embedix Component Description (John Beppu) +fgl Informix 4GL (Rafal Sulejman) +foxpro FoxPro (Powing Tse) +gsp GNU Server Pages (Nathaniel Harward) +gtkrc GTK rc (David Necas) +hercules Hercules (Avant! Corporation) (Dana Edwards) +htmlos HTML/OS by Aestiva (Jason Rust) +inittab SysV process control (David Necas) +iss Inno Setup (Dominique Stephan) +jam Jam (Ralf Lemke) +jess Jess (Paul Baleme) +lprolog LambdaProlog (Markus Mottl) +ia64 Intel Itanium (parth malwankar) +kix Kixtart (Nigel Gibbs) +mgp MaGic Point (Gerfried Fuchs) +mason Mason (HTML with Perl) (Andrew Smith) +mma Mathematica (Wolfgang Waltenberger) +nqc Not Quite C (Stefan Scherer) +omnimark Omnimark (Paul Terray) +openroad OpenROAD (Luis Moreno Serrano) +named BIND configuration (glory hump) +papp PApp (Marc Lehmann) +pfmain Postfix main config (Peter Kelemen) +pic PIC assembly (Aleksandar Veselinovic) +ppwiz PPWizard (Stefan Schwarzer) +progress Progress (Phil Uren) +psf Product Specification File (Rex Barzee) +r R (Tom Payne) +registry MS-Windows registry (Dominique Stephan) +robots Robots.txt (Dominique Stephan) +rtf Rich Text Format (Dominique Stephan) +setl SETL (Alex Poylisher) +sgmldecl SGML Declarations (Daniel A. Molina W.) +sinda Sinda input (Adrian Nagle) +sindacmp Sinda compare (Adrian Nagle) +sindaout Sinda output (Adrian Nagle) +smith SMITH (Rafal Sulejman) +snobol4 Snobol 4 (Rafal Sulejman) +strace Strace (David Necas) +tak TAK input (Adrian Nagle) +takcmp TAK compare (Adrian Nagle) +takout TAK output (Adrian Nagle) +tasm Turbo assembly (FooLman) +texmf TeX configuration (David Necas) +trasys Trasys input (Adrian Nagle) +tssgm TSS Geometry (Adrian Nagle) +tssop TSS Optics (Adrian Nagle) +tsscl TSS Command line (Adrian Nagle) +virata Virata Configuration Script (Manuel M.H. Stol) +vsejcl VSE JCL (David Ondrejko) +wdiff Wordwise diff (Gerfried Fuchs) +wsh Windows Scripting Host (Paul Moore) +xkb X Keyboard Extension (David Necas) + +Renamed php3 to php, it now also supports php4 (Lutz Eymers) + +Patch 5.7.015 +Problem: Syntax files for Vim 6.0 can't be used with 5.x. +Solution: Add the "default" argument to the ":highlight" command: Ignore the + command if highlighting was already specified. +Files: src/syntax.c + +Generate the Syntax menu with makemenu.vim, so that it doesn't have to be done +when Vim is starting up. Reduces the startup time of the GUI. + + +Fixed *fixed-5.8* +----- + +Conversion of docs to HTML didn't convert "|tag|s" to a hyperlink. + +Fixed compiling under NeXT. (Jeroen C.M. Goudswaard) + +optwin.vim gave an error when used in Vi compatible mode ('cpo' contains 'C'). + +Tcl interpreter: "buffer" command didn't check for presence of an argument. +(Dave Bodenstab) + +dosinst.c: Added checks for too long file name. + +Amiga: a file name starting with a colon was considered absolute but it isn't. +Amiga: ":pwd" added a slash when in the root of a drive. + +Macintosh: Warnings for unused variables. (Bernhard Pruemmer) + +Unix: When catching a deadly signal, handle it in such a way that it's +unlikely that Vim will hang. Call _exit() instead of exit() in case of a +severe problem. + +Setting the window title from nothing to something didn't work after patch 29. + +Check for ownership of .exrc and .vimrc was done with stat(). Use lstat() as +well for extra security. + +Win32 GUI: Printing a file with 'fileformat' "unix" didn't work. Set +'fileformat' to "dos" before writing the temp file. + +Unix: Could start waiting for a character when checking for a CTRL-C typed +when an X event is received. + +Could not use Perl and Python at the same time on FreeBSD, because Perl used +"-lc" and Python used the threaded C library. + +Win32: The Mingw compiler gave a few warning messages. + +When using "ZZ" and an autocommand for writing uses an abbreviation it didn't +work. Don't stuff the ":x" command but execute it directly. (Mikael Berthe) + +VMS doesn't always have lstat(), added an #ifdef around it. + +Added a few corrections for the Macintosh. (Axel Kielhorn) + +Win32: Gvimext could not edit more than a few files at once, the length of the +argument was fixed. + + +Previously released patches for Vim 5.7: + +Patch 5.7.001 +Problem: When the current buffer is crypted, and another modified buffer + isn't, ":wall" will encrypt the other buffer. +Solution: In buf_write() use "buf" instead of "curbuf" to check for the + crypt key. +Files: src/fileio.c + +Patch 5.7.002 +Problem: When 'showmode' is set, using "CTRL-O :r file" waits three seconds + before displaying the read text. (Wichert Akkerman) +Solution: Set "keep_msg" to the file message so that the screen is redrawn + before the three seconds wait for displaying the mode message. +Files: src/fileio.c + +Patch 5.7.003 +Problem: Searching for "[[:cntrl:]]" doesn't work. +Solution: Exclude NUL from the matching characters, it terminates the list. +Files: src/regexp.c + +Patch 5.7.004 +Problem: GTK: When selecting a new font, Vim can crash. +Solution: In gui_mch_init_font() unreference the old font, not the new one. +Files: src/gui_gtk_x11.c + +Patch 5.7.005 +Problem: Multibyte: Inserting a wrapped line corrupts kterm screen. + Pasting TEXT/COMPOUND_TEXT into Vim does not work. + On Motif no XIM status line is displayed even though it is + available. +Solution: Don't use xterm trick for wrapping lines for multibyte mode. + Correct a missing "break", added TEXT/COMPOUND_TEXT selection + request. + Add XIMStatusArea fallback code. + (Katsuhito Nagano) +Files: src/gui_gtk_x11.c, src/multbyte.c, src/screen.c, src/ui.c + +Patch 5.7.006 +Problem: GUI: redrawing the non-Visual selection is wrong when the window + is unobscured. (Jean-Pierre Etienne) +Solution: Redraw the selection properly and don't clear it. Added "len" + argument to clip_may_redraw_selection(). +Files: src/gui.c, src/ui.c, src/proto/ui.pro + +Patch 5.7.007 +Problem: Python: Crash when using the current buffer twice. +Solution: Increase the reference count for buffer and window objects. + (Johannes Zellner) +Files: src/if_python.c + +Patch 5.7.008 +Problem: In Ex mode, backspacing over the first TAB doesn't work properly. + (Wichert Akkerman) +Solution: Switch the cursor on before printing the newline. +Files: src/ex_getln.c + +Patch 5.7.009 (extra) +Problem: Mac: Crash when using a long file. +Solution: Don't redefine malloc() and free(), because it will break using + realloc(). +Files: src/os_mac.h + +Patch 5.7.010 +Problem: When using CTRL-A on a very long number Vim can crash. (Michael + Naumann) +Solution: Truncate the length of the new number to avoid a buffer overflow. +Files: src/ops.c + +Patch 5.7.011 (extra) +Problem: Win32 GUI on NT 5 and Win98: Displaying Hebrew is reversed. +Solution: Output each character separately, to avoid that Windows reverses + the text for some fonts. (Ron Aaron) +Files: src/gui_w32.c + +Patch 5.7.012 +Problem: When using "-complete=buffer" for ":command" the user command + fails. +Solution: In a user command don't replace the buffer name with a count for + the buffer number. +Files: src/ex_docmd.c + +Patch 5.7.013 +Problem: "gD" didn't always find a match in the first line, depending on + the column the search started at. +Solution: Reset the column to zero before starting to search. +Files: src/normal.c + +Patch 5.7.014 +Problem: Rot13 encoding was done on characters with accents, which is + wrong. (Sven Gottwald) +Solution: Only do rot13 encoding on ASCII characters. +Files: src/ops.c + +Patch 5.7.016 +Problem: When hitting 'n' for a ":s///c" command, the ignore-case flag was + not restored, some matches were skipped. (Daniel Blaustein) +Solution: Restore the reg_ic variable when 'n' was hit. +Files: src/ex_cmds.c + +Patch 5.7.017 +Problem: When using a Vim script for Vim 6.0 with <SID> before a function + name, it produces an error message even when inside an "if version + >= 600". (Charles Campbell) +Solution: Ignore errors in the function name when the function is not going + to be defined. +Files: src/eval.c + +Patch 5.7.018 +Problem: When running "rvim" or "vim -Z" it was still possible to execute a + shell command with system() and backtick-expansion. (Antonios A. + Kavarnos) +Solution: Disallow executing a shell command in get_cmd_output() and + mch_expand_wildcards(). +Files: src/misc1.c, src/os_unix.c + +Patch 5.7.019 +Problem: Multibyte: In a substitute string, a multi-byte character isn't + skipped properly, can be a problem when the second byte is a + backslash. +Solution: Skip an extra byte for a double-byte character. (Muraoka Taro) +Files: src/ex_cmds.c + +Patch 5.7.020 +Problem: Compilation doesn't work on MacOS-X. +Solution: Add a couple of #ifdefs. (Jamie Curmi) +Files: src/regexp.c, src/ctags/general.h + +Patch 5.7.021 +Problem: Vim sometimes produces a beep when started in an xterm. Only + happens when compiled without mouse support. +Solution: Requesting the xterm version results in a K_IGNORE. This wasn't + handled when mouse support is disabled. Accept K_IGNORE always. +Files: src/normal.c + +Patch 5.7.022 +Problem: %v in 'statusline' is not displayed when it's equal to %c. +Solution: Check if %V or %v is used and handle them differently. +Files: src/screen.c + +Patch 5.7.023 +Problem: Crash when a WinLeave autocommand deletes the buffer in the other + window. +Solution: Check that after executing the WinLeave autocommands there still + is a window to be closed. Also update the test that was supposed + to check for this problem. +Files: src/window.c, testdir/test13.in, testdir/test13.ok + +Patch 5.7.024 +Problem: Evaluating an expression for 'statusline' can have side effects. +Solution: Evaluate the expression in a sandbox. +Files: src/edit.c, src/eval.c, src/proto/eval.pro, src/ex_cmds.c, + src/ex_cmds.h, src/ex_docmd.c, src/globals.h, src/option.c, + src/screen.c, src/undo.c + +Patch 5.7.025 (fixed) +Problem: Creating a temp file has a race condition. +Solution: Create a private directory to write the temp files in. +Files: src/fileio.c, src/misc1.c, src/proto/misc1.pro, + src/proto/fileio.pro, src/memline.c, src/os_unix.h + +Patch 5.7.026 (extra) +Problem: Creating a temp file has a race condition. +Solution: Create a private directory to write the temp files in. + This is the extra part of patch 5.7.025. +Files: src/os_msdos.h + +Patch 5.7.027 +Problem: Starting to edit a file can cause a crash. For example when in + Insert mode, using CTRL-O :help abbr<Tab> to scroll the screen and + then <CR>, which edits a help file. (Robert Bogomip) +Solution: Check if keep_msg is NULL before copying it. +Files: src/fileio.c + +Patch 5.7.028 +Problem: Creating a backup or swap file could fail in rare situations. +Solution: Use O_EXCL for open(). +Files: src/fileio.c, src/memfile.c + +Patch 5.7.029 +Problem: Editing a file with an extremely long name crashed Vim. +Solution: Check for length of the name when setting the window title. +Files: src/buffer.c + +Patch 5.7.030 +Problem: A ":make" or ":grep" command with a very long argument could cause + a crash. +Solution: Allocate the buffer for the shell command. +Files: src/ex_docmd.c + + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/version6.txt b/share/vim/vim73/doc/version6.txt new file mode 100644 index 0000000000..17a29e4bdb --- /dev/null +++ b/share/vim/vim73/doc/version6.txt @@ -0,0 +1,14530 @@ +*version6.txt* For Vim version 7.3. Last change: 2008 Aug 06 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + +Welcome to Vim Version 6.0! A large number of features has been added. This +file mentions all the new items that have been added, changes to existing +features and bug fixes compared to Vim 5.x. + +See |vi_diff.txt| for an overview of differences between Vi and Vim 6.0. +See |version4.txt| for differences between Vim 3.0 and Vim 4.0. +See |version5.txt| for differences between Vim 4.0 and Vim 5.0. + +INCOMPATIBLE CHANGES |incompatible-6| + +Cursor position in Visual mode |curpos-visual| +substitute command Vi compatible |substitute-CR| +global option values introduced |new-global-values| +'fileencoding' changed |fileencoding-changed| +Digraphs changed |digraphs-changed| +Filetype detection changed |filetypedetect-changed| +Unlisted buffers introduced |new-unlisted-buffers| +CTRL-U in Command-line mode changed |CTRL-U-changed| +Ctags gone |ctags-gone| +Documentation reorganized |documentation-6| +Modeless selection and clipboard |modeless-and-clipboard| +Small incompatibilities |incomp-small-6| + +NEW FEATURES |new-6| + +Folding |new-folding| +Vertically split windows |new-vertsplit| +Diff mode |new-diff-mode| +Easy Vim: click-and-type |new-evim| +User manual |new-user-manual| +Flexible indenting |new-indent-flex| +Extended search patterns |new-searchpat| +UTF-8 support |new-utf-8| +Multi-language support |new-multi-lang| +Plugin support |new-plugins| +Filetype plugins |new-filetype-plugins| +File browser |new-file-browser| +Editing files over a network |new-network-files| +Window for command-line editing |new-cmdwin| +Debugging mode |new-debug-mode| +Cursor in virtual position |new-virtedit| +Debugger interface |new-debug-itf| +Communication between Vims |new-vim-server| +Buffer type options |new-buftype| +Printing |new-printing| +Ports |ports-6| +Quickfix extended |quickfix-6| +Operator modifiers |new-operator-mod| +Search Path |new-search-path| +Writing files improved |new-file-writing| +Argument list |new-argument-list| +Restore a View |new-View| +Color schemes |new-color-schemes| +Various new items |new-items-6| + +IMPROVEMENTS |improvements-6| + +COMPILE TIME CHANGES |compile-changes-6| + +BUG FIXES |bug-fixes-6| + +VERSION 6.1 |version-6.1| +Changed |changed-6.1| +Added |added-6.1| +Fixed |fixed-6.1| + +VERSION 6.2 |version-6.2| +Changed |changed-6.2| +Added |added-6.2| +Fixed |fixed-6.2| + +VERSION 6.3 |version-6.3| +Changed |changed-6.3| +Added |added-6.3| +Fixed |fixed-6.3| + +VERSION 6.4 |version-6.4| +Changed |changed-6.4| +Added |added-6.4| +Fixed |fixed-6.4| + +============================================================================== +INCOMPATIBLE CHANGES *incompatible-6* + +These changes are incompatible with previous releases. Check this list if you +run into a problem when upgrading from Vim 5.x to 6.0 + + +Cursor position in Visual mode *curpos-visual* +------------------------------ + +When going from one window to another window on the same buffer while in +Visual mode, the cursor position of the other window is adjusted to keep the +same Visual area. This can be used to set the start of the Visual area in one +window and the end in another. In vim 5.x the cursor position of the other +window would be used, which could be anywhere and was not very useful. + + +Substitute command Vi compatible *substitute-CR* +-------------------------------- + +The substitute string (the "to" part of the substitute command) has been made +Vi compatible. Previously a CTRL-V had a special meaning and could be used to +prevent a <CR> to insert a line break. This made it impossible to insert a +CTRL-V before a line break. Now a backslash is used to prevent a <CR> to +cause a line break. Since the number of backslashes is halved, it is still +possible to insert a line break at the end of the line. This now works just +like Vi, but it's not compatible with Vim versions before 6.0. + +When a ":s" command doesn't make any substitutions, it no longer sets the '[ +and '] marks. This is not related to Vi, since it doesn't have these marks. + + +Global option values introduced *new-global-values* +------------------------------- + +There are now global values for options which are local to a buffer or window. +Previously the local options were copied from one buffer to another. When +editing another file this could cause option values from a modeline to be used +for the wrong file. Now the global values are used when entering a buffer +that has not been used before. Also, when editing another buffer in a window, +the local window options are reset to their global values. The ":set" command +sets both the local and global values, this is still compatible. But a +modeline only sets the local value, this is not backwards compatible. + +":let &opt = val" now sets the local and global values, like ":set". New +commands have been added to set the global or local value: + :let &opt = val like ":set" + :let &g:opt = val like ":setglobal" + :let &l:opt = val like ":setlocal" + + +'fileencoding' changed *fileencoding-changed* +---------------------- + +'fileencoding' was used in Vim 5.x to set the encoding used inside all of Vim. +This was a bit strange, because it was local to a buffer and worked for all +buffers. It could never be different between buffers, because it changed the +way text in all buffers was interpreted. +It is now used for the encoding of the file related to the buffer. If you +still set 'fileencoding' it is likely to be overwritten by the detected +encoding from 'fileencodings', thus it is "mostly harmless". +The old FileEncoding autocommand now does the same as the new EncodingChanged +event. + + +Digraphs changed *digraphs-changed* +---------------- + +The default digraphs now correspond to RFC1345. This is very different from +what was used in Vim 5.x. |digraphs| + + +Filetype detection changed *filetypedetect-changed* +-------------------------- + +The filetype detection previously was using the "filetype" autocommand group. +This caused confusion with the FileType event name (case is ignored). The +group is now called "filetypedetect". It still works, but if the "filetype" +group is used the autocommands will not be removed by ":filetype off". + The support for 'runtimepath' has made the "myfiletypefile" and +"mysyntaxfile" mechanism obsolete. They are still used for backwards +compatibility. + +The connection between the FileType event and setting the 'syntax' option was +previously in the "syntax" autocommand group. That caused confusion with the +Syntax event name. The group is now called "syntaxset". + +The distributed syntax files no longer contain "syntax clear". That makes it +possible to include one in the other without tricks. The syntax is now +cleared when the 'syntax' option is set (by an autocommand added from +synload.vim). This makes the syntax cleared when the value of 'syntax' does +not correspond to a syntax file. Previously the existing highlighting was +kept. + + +Unlisted buffers introduced *new-unlisted-buffers* +--------------------------- + +There is now a difference between buffers which don't appear in the buffer +list and buffers which are really not in the buffer list. Commands like +":ls", ":bnext", ":blast" and the Buffers menu will skip buffers not in the +buffer list. |unlisted-buffer| +The 'buflisted' option can be used to make a buffer appear in the buffer list +or not. + +Several commands that previously added a buffer to the buffer list now create +an unlisted buffer. This means that a ":bnext" and ":ball" will not find these +files until they have actually been edited. For example, buffers used for the +alternative file by ":write file" and ":read file". + Other commands previously completely deleted a buffer and now only remove +the buffer from the buffer list. Commands relying on a buffer not to be +present might fail. For example, a ":bdelete" command in an autocommand that +relied on something following to fail (was used in the automatic tests). +|:bwipeout| can be used for the old meaning of ":bdelete". + +The BufDelete autocommand event is now triggered when a buffer is removed from +the buffer list. The BufCreate event is only triggered when a buffer is +created that is added to the buffer list, or when an existing buffer is added +to the buffer list. BufAdd is a new name for BufCreate. +The new BufNew event is for creating any buffer and BufWipeout for really +deleting a buffer. + +When doing Insert mode completion, only buffers in the buffer list are +scanned. Added the 'U' flag to 'complete' to do completion from unlisted +buffers. + +Unlisted buffers are not stored in a viminfo file. + + +CTRL-U in Command-line mode changed *CTRL-U-changed* +----------------------------------- + +Using CTRL-U when editing the command line cleared the whole line. Most +shells only delete the characters before the cursor. Made it work like that. +(Steve Wall) + +You can get the old behavior with CTRL-E CTRL-U: > + :cnoremap <C-U> <C-E><C-U> + + +Ctags gone *ctags-gone* +---------- + +Ctags is no longer part of the Vim distribution. It's now a grown-up program +by itself, it deserves to be distributed separately. +Ctags can be found here: http://ctags.sf.net/. + + +Documentation reorganized *documentation-6* +------------------------- + +The documentation has been reorganized, an item may not be where you found it +in Vim 5.x. +- The user manual was added, some items have been moved to it from the + reference manual. +- The quick reference is now in a separate file (so that it can be printed). + +The examples in the documentation were previously marked with a ">" in the +first column. This made it difficult to copy/paste them. There is now a +single ">" before the example and it ends at a "<" or a non-blank in the first +column. This also looks better without highlighting. + +'helpfile' is no longer used to find the help tags file. This allows a user +to add its own help files (e.g., for plugins). + + +Modeless selection and clipboard *modeless-and-clipboard* +-------------------------------- + +The modeless selection is used to select text when Visual mode can't be used, +for example when editing the command line or at the more prompt. +In Vim 5.x the modeless selection was always used. On MS-Windows this caused +the clipboard to be overwritten, with no way to avoid that. The modeless +selection now obeys the 'a' and 'A' flags in 'guioptions' and "autoselect" and +"autoselectml" in 'clipboard'. By default there is no automatic copy on +MS-Windows. Use the |c_CTRL-Y| command to manually copy the selection. + +To get the old behavior back, do this: > + + :set clipboard^=autoselectml guioptions+=A + + +Small incompatibilities *incomp-small-6* +----------------------- + +'backupdir', 'cdpath', 'directory', 'equalprg', 'errorfile', 'formatprg', +'grepprg', 'helpfile', 'makeef', 'makeprg', 'keywordprg', 'cscopeprg', +'viminfo' and 'runtimepath' can no longer be set from a modeline, for better +security. + +Removed '_' from the 'breakat' default: It's commonly used in keywords. + +The default for 'mousehide' is on, because this works well for most people. + +The Amiga binary is now always compiled with "big" features. The "big" binary +archive no longer exists. + +The items "[RO]", "[+]", "[help]", "[Preview]" and "[filetype]" in +'statusline' no longer have a leading space. + +Non-Unix systems: When expanding wildcards for the Vim arguments, don't use +'suffixes'. It now works as if the shell had expanded the arguments. + +The 'lisp', 'smartindent' and 'cindent' options are not switched off when +'paste' is set. The auto-indenting is disabled when 'paste' is set, but +manual indenting with "=" still works. + +When formatting with "=" uses 'cindent' or 'indentexpr' indenting, and there +is no change in indent, this is not counted as a change ('modified' isn't set +and there is nothing to undo). + +Report 'modified' as changed when 'fileencoding' or 'fileformat' was set. +Thus it reflects the possibility to abandon the buffer without losing changes. + +The "Save As" menu entry now edits the saved file. Most people expect it to +work like this. + +A buffer for a directory is no longer added to the Buffers menu. + +Renamed <Return> to <Enter>, since that's what it's called on most keyboards. +Thus it's now the hit-enter prompt instead of the hit-return prompt. +Can map <Enter> just like <CR> or <Return>. + +The default for the 'viminfo' option is now '20,"50,h when 'compatible' isn't +set. Most people will want to use it, including beginners, but it required +setting the option, which isn't that easy. + +After using ":colder" the newer error lists are overwritten. This makes it +possible to use ":grep" to browse in a tree-like way. Must use ":cnewer 99" +to get the old behavior. + +The patterns in 'errorformat' would sometimes ignore case (MS-Windows) and +sometimes not (Unix). Now case is always ignored. Add "\C" to the pattern to +match case. + +The 16 bit MS-DOS version is now compiled without the +listcmds feature +(buffer list manipulation commands). They are not often needed and this +executable needs to be smaller. + +'sessionoptions' now includes "curdir" by default. This means that restoring +a session will result in the current directory being restored, instead of +going to the directory where the session file is located. + +A session deleted all buffers, deleting all marks. Now keep the buffer list, +it shouldn't hurt for some existing buffers to remain present. +When the argument list is empty ":argdel *" caused an error message. + +No longer put the search pattern from a tag jump in the history. + +Use "SpecialKey" highlighting for unprintable characters instead of "NonText". +The idea is that unprintable text or any text that's displayed differently +from the characters in the file is using "SpecialKey", and "NonText" is used +for text that doesn't really exist in the file. + +Motif now uses the system default colors for the menu and scrollbar. Used to +be grey. It's still possible to set the colors with ":highlight" commands and +resources. + +Formatting text with "gq" breaks a paragraph at a non-empty blank line. +Previously the line would be removed, which wasn't very useful. + +":normal" does no longer hang when the argument ends in half a command. +Previously Vim would wait for more characters to be typed, without updating +the screen. Now it pretends an <Esc> was typed. + +Bitmaps for the toolbar are no longer searched for in "$VIM/bitmaps" but in +the "bitmaps" directories in 'runtimepath'. + +Now use the Cmdline-mode menus for the hit-enter prompt instead of the Normal +mode menus. This generally works better and allows using the "Copy" menu to +produce CTRL-Y to copy the modeless selection. + +Moved the font selection from the Window to the Edit menu, together with the +other settings. + +The default values for 'isfname' include more characters to make "gf" work +better. + +Changed the license for the documentation to the Open Publication License. +This seemed fair, considering the inclusion of parts of the Vim book, which is +also published under the OPL. The downside is that we can't force someone who +would sell copies of the manual to contribute to Uganda. + +After "ayy don't let ""yy or :let @" = val overwrite the "a register. +Use the unnamed register instead. + +MSDOS: A pattern "*.*" previously also matched a file name without a dot. +This was inconsistent with other versions. + +In Insert mode, CTRL-O CTRL-\ CTRL-N {cmd} remains in Normal mode. Previously +it would go back to Insert mode, thus confusing the meaning of CTRL-\ CTRL-N, +which is supposed to take us to Normal mode (especially in ":amenu"). + +Allow using ":" commands after an operator. Could be used to implement a new +movement command. Thus it no longer aborts a pending operator. + +For the Amiga the "-d {device}" argument was possible. When compiled with the +diff feature, this no longer works. Use "-dev {device}" instead. |-dev| + +Made the default mappings for <S-Insert> in Insert mode insert the text +literally, avoids that special characters like BS cause side effects. + +Using ":confirm" applied to the rest of the line. Now it applies only to the +command right after it. Thus ":confirm if x | edit | endif" no longer works, +use ":if x | confirm edit | endif". This was the original intention, that it +worked differently was a bug. + +============================================================================== +NEW FEATURES *new-6* + +Folding *new-folding* +------- + +Vim can now display a buffer with text folded. This allows overviewing the +structure of a file quickly. It is also possible to yank, delete and put +folded text, for example to move a function to another position. + +There is a whole bunch of new commands and options related to folding. +See |folding|. + + +Vertically split windows *new-vertsplit* +------------------------ + +Windows can also be split vertically. This makes it possible to have windows +side by side. One nice use for this is to compare two similar files (see +|new-diff-mode|). The 'scrollbind' option can be used to synchronize +scrolling. + +A vertical split can be created with the commands: + :vsplit or CTRL-W v or CTRL-W CTRL-V |:vsplit| + :vnew |:vnew| + :vertical {cmd} |:vertical| +The last one is a modifier, which has a meaning for any command that splits a +window. For example: > + :vertical stag main +Will vertically split the window and jump to the tag "main" in the new window. + +Moving from window to window horizontally can be done with the |CTRL-W_h| and +|CTRL-W_l| commands. The |CTRL-W_k| and |CTRL-W_j| commands have been changed +to jump to the window above or below the cursor position. + +The vertical and horizontal splits can be mixed as you like. Resizing windows +is easy when using the mouse, just position the pointer on a status line or +vertical separator and drag it. In the GUI a special mouse pointer shape +indicates where you can drag a status or separator line. + +To resize vertically split windows use the |CTRL-W_<| and |CTRL-W_>| commands. +To make a window the maximum width use the CTRL-W | command |CTRL-W_bar|. + +To force a new window to use the full width or height of the Vim window, +these two modifiers are available: + :topleft {cmd} New window appears at the top with full + width or at the left with full height. + :botright {cmd} New window appears at the bottom with full + width or at the right with full height. +This can be combined with ":vertical" to force a vertical split: > + :vert bot dsplit DEBUG +This will open a window at the far right, occupying the full height of the Vim +window, with the cursor on the first definition of "DEBUG". +The help window is opened at the top, like ":topleft" was used, if the current +window is fewer than 80 characters wide. + +A few options can be used to set the preferences for vertically split windows. +They work similar to their existing horizontal equivalents: + horizontal vertical ~ + 'splitbelow' 'splitright' + 'winheight' 'winwidth' + 'winminheight' 'winminwidth' +It's possible to set 'winminwidth' to zero, so that temporarily unused windows +hardly take up space without closing them. + +The new 'eadirection' option tells where 'equalalways' applies: + :set eadirection=both both directions + :set eadirection=ver equalize window heights + :set eadirection=hor equalize windows widths +This can be used to avoid changing window sizes when you want to keep them. + +Since windows can become quite narrow with vertical splits, text lines will +often not fit. The 'sidescrolloff' has been added to keep some context left +and right of the cursor. The 'listchars' option has been extended with the +"precedes" item, to show a "<" for example, when there is text left off the +screen. (Utz-Uwe Haus) + +"-O" command line argument: Like "-o" but split windows vertically. (Scott +Urban) + +Added commands to move the current window to the very top (CTRL-W K), bottom +(CTRL-W J), left (CTRL-W H) and right (CTRL-W L). In the new position the +window uses the full width/height of the screen. + +When there is not enough room in the status line for both the file name and +the ruler, use up to half the width for the ruler. Useful for narrow windows. + + +Diff mode *new-diff-mode* +--------- + +In diff mode Vim shows the differences between two, three or four files. +Folding is used to hide the parts of the file that are equal. +Highlighting is used to show deleted and changed lines. +See |diff-mode|. + +An easy way to start in diff mode is to start Vim as "vimdiff file1 file2". +Added the vimdiff manpage. + +In a running Vim the |:diffsplit| command starts diff mode for the current +file and another file. The |:diffpatch| command starts diff mode using the +current file and a patch file. The |:diffthis| command starts diff mode for +the current window. + +Differences can be removed with the |:diffget| and |:diffput| commands. + +- The 'diff' option switches diff mode on in a window. +- The |:diffupdate| command refreshes the diffs. +- The 'diffopt' option changes how diffs are displayed. +- The 'diffexpr' option can be set how a diff is to be created. +- The 'patchexpr' option can be set how patch is applied to a file. +- Added the "diff" folding method. When opening a window for diff-mode, set + 'foldlevel' to zero and 'foldenable' on, to close the folds. +- Added the DiffAdd, DiffChange, DiffDelete and DiffText highlight groups to + specify the highlighting for differences. The defaults are ugly... +- Unix: make a vimdiff symbolic link for "make install". +- Removed the now obsolete "vimdiff.vim" script from the distribution. +- Added the "[c" and "]c" commands to move to the next/previous change in diff + mode. + + +Easy Vim: click-and-type *new-evim* +------------------------ + +eVim stands for "Easy Vim". This is a separate program, but can also be +started as "vim -y". + +This starts Vim with 'insertmode' set to allow click-and-type editing. The +$VIMRUNTIME/evim.vim script is used to add mappings and set options to be able +to do most things like Notepad. This is only for people who can't stand two +modes. + +eView does the same but in readonly mode. + +In the GUI a CTRL-C now only interrupts when busy with something, not when +waiting for a character. Allows using CTRL-C to copy text to the clipboard. + + +User manual *new-user-manual* +----------- + +The user manual has been added. It is organised around editing tasks. It +reads like a book, from start to end. It should allow beginners to start +learning Vim. It helps everybody to learn using the most useful Vim features. +It is much easier to read than the reference manual, but omits details. See +|user-manual|. + +The user manual includes parts of the Vim book by Steve Oualline |frombook|. +It is published under the OPL |manual-copyright|. + +When syntax highlighting is not enabled, the characters in the help file which +mark examples ('>' and '<') and header lines ('~') are replaced with a space. + +When closing the help window, the window layout is restored from before +opening it, if the window layout didn't change since then. +When opening the help window, put it at the top of the Vim window if the +current window is fewer than 80 characters and not full width. + + +Flexible indenting *new-indent-flex* +------------------ + +Automatic indenting is now possible for any language. It works with a Vim +script, which makes it very flexible to compute the indent. + +The ":filetype indent on" command enables using the provided indent scripts. +This is explained in the user manual: |30.3|. + +The 'indentexpr' option is evaluated to get the indent for a line. The +'indentkeys' option tells when to trigger re-indenting. Normally these +options are set from an indent script. Like Syntax files, indent scripts will +be created and maintained by many people. + + +Extended search patterns *new-searchpat* +------------------------ + +Added the possibility to match more than one line with a pattern. (partly by +Loic Grenie) +New items in a search pattern for multi-line matches: +\n match end-of-line, also in [] +\_[] match characters in range and end-of-line +\_x match character class and end-of-line +\_. match any character or end-of-line +\_^ match start-of-line, can be used anywhere in the regexp +\_$ match end-of-line, can be used anywhere in the regexp + +Various other new items in search patterns: +\c ignore case for the whole pattern +\C match case for the whole pattern +\m magic on for the following +\M magic off for the following +\v make following characters "very magic" +\V make following characters "very nomagic" + +\@! don't match atom before this. + Example: "foo\(bar\)\@!" matches "foo " but not "foobar". +\@= match atom, resulting in zero-width match + Example: "foo\(bar\)\@=" matches "foo" in "foobar". +\@<! don't match preceding atom before the current position +\@<= match preceding atom before the current position +\@> match preceding atom as a subexpression + +\& match only when branch before and after it match + +\%[] optionally match a list of atoms; "end\%[if]" matches "end", + "endi" and "endif" +\%(\) like \(\), but without creating a back-reference; there can be + any number of these, overcomes the limit of nine \( \) pairs +\%^ match start-of-file (Chase Tingley) +\%$ match end-of-file (Chase Tingley) +\%# Match with the cursor position. (Chase Tingley) +\? Just like "\=" but can't be used in a "?" command. + +\%23l match in line 23 +\%<23l match before line 23 +\%>23l match after line 23 +\%23c, \%<23c, \%>23c match in/before/after column 23 +\%23v, \%<23v, \%>23v match in/before/after virtual column 23 + + +For syntax items: +\z(...\) external reference match set (in region start pattern) +\z1 - \z9 external reference match use (in region skip or end pattern) + (Scott Bigham) + +\zs use position as start of match +\ze use position as end of match + +Removed limit of matching only up to 32767 times with *, \+, etc. + +Added support to match multi-byte characters. (partly by Muraoka Taro) +Made "\<" and "\>" work for UTF-8. (Muraoka Taro) + + +UTF-8 support *new-utf-8* +------------- + +Vim can now edit files in UTF-8 encoding. Up to 31 bit characters can be +used, but only 16 bit characters are displayed. Up to two combining +characters are supported, they overprint the preceding character. +Double-wide characters are also supported. See |UTF-8|. + +UCS-2, UCS-4 and UTF-16 encodings are supported too, they are converted to +UTF-8 internally. There is also support for editing Unicode files in a Latin1 +environment. Other encodings are converted with iconv() or an external +converter specified with 'charconvert'. + +Many new items for Multi-byte support: +- Added 'encoding' option: specifies character encoding used inside Vim. It + can be any 8-bit encoding, some double-byte encodings or Unicode. + It is initialized from the environment when a supported value is found. +- Added 'fileencoding' and 'fileencodings': specify character coding in a + file, similar to 'fileformat' and 'fileformats'. + When 'encoding' is "utf-8" and 'fileencodings' is "utf-8,latin1" this will + automatically switch to latin1 if a file does not contain valid UTF-8. +- Added 'bomb' option and detection of a BOM at the start of a file. Can be + used with "ucs-bom" in 'fileencodings' to automatically detect a Unicode + file if it starts with a BOM. Especially useful on MS-Windows (NT and + 2000), which uses ucs-2le files with a BOM (e.g., when exporting the + registry). +- Added the 'termencoding' option: Specifies the encoding used for the + terminal. Useful to put Vim in utf-8 mode while in a non-Unicode locale: > + :let &termencoding = &encoding + :set encoding=utf-8 +- When 'viminfo' contains the 'c' flag, the viminfo file is converted from the + 'encoding' it was written with to the current 'encoding'. +- Added ":scriptencoding" command: convert lines in a sourced script to + 'encoding'. Useful for menu files. +- Added 'guifontwide' to specify a font for double-wide characters. +- Added Korean support for character class detection. Also fix cls() in + search.c. (Chong-Dae Park) +- Win32: Typing multi-byte characters without IME. (Alexander Smishlajev) +- Win32 with Mingw: compile with iconv library. (Ron Aaron) +- Win32 with MSVC: dynamically load iconv.dll library. (Muraoka Taro) +- Make it possible to build a version with multi-byte and iconv support with + Borland 5.5. (Yasuhiro Matsumoto) +- Added 'delcombine' option: Delete combining character separately. (Ron + Aaron) +- The "xfontset" feature isn't required for "xim". These are now two + independent features. +- XIM: enable XIM when typing a language character (Insert mode, Search + pattern, "f" or "r" command). Disable XIM when typing a Normal mode + command. +- When the XIM is active, show "XIM" in the 'showmode' message. (Nam SungHyun) +- Support "CursorIM" for XIM. (Nam SungHyun) +- Added 'm' flag to 'formatoptions': When wrapping words, allow splitting at + each multibyte character, not only at a space. +- Made ":syntax keyword" work with multi-byte characters. +- Added support for Unicode upper/lowercase flipping and comparing. (based on + patch by Raphael Finkel) + Let "~" on multi-byte characters that have a third case ("title case") + switch between the three cases. (Raphael Finkel) + +Allow defining digraphs for multi-byte characters. +Added RFC1345 digraphs for Unicode. +Most Normal mode commands that accept a character argument, like "r", "t" and +"f" now accept a digraph. The 'D' flag in 'cpoptions' disables this to remain +Vi compatible. + +Added Language mapping and 'keymap' to be able to type multi-byte characters: +- Added the ":lmap" command and friends: Define mappings that are used when + typing characters in the language of the text. Also for "r", "t", etc. In + Insert and Command-line mode CTRL-^ switches the use of the mappings on/off. + CTRL-^ also toggles the use of an input method when no language mappings are + present. Allows switching the IM back on halfway typing. +- "<char-123>" argument to ":map", allows to specify the decimal, octal or + hexadecimal value of a character. +- Implemented the 'keymap' option: Load a keymap file. Uses ":lnoremap" to + define mappings for the keymap. The new ":loadkeymap" command is used in + the keymap file. +- Added 'k' flag in 'statusline': Value of "b:keymap_name" or 'keymap' when + it's being used. Uses "<lang>" when no keymap is loaded and ":lmap"s are + active. Show this text in the default statusline too. +- Added the 'iminsert' and 'imsearch' options: Specify use of langmap mappings + and Input Method with an option. (Muraoka Taro) + Added 'imcmdline' option: When set the input method is always enabled when + starting to edit a command line. Useful for a XIM that uses dead keys to + type accented characters. + Added 'imactivatekey' option to better control XIM. (Muraoka Taro) +- When typing a mapping that's not finished yet, display the last character + under the cursor in Insert mode and Command-line mode. Looks good for dead + characters. +- Made the 'langmap' option recognize multi-byte characters. But mapping only + works for 8-bit characters. Helps when using UTF-8. +- Use a different cursor for when ":lmap" mappings are active. Can specify + two highlight groups for an item in 'guicursor'. By default "lCursor" and + "Cursor" are equal, the user must set a color he likes. + Use the cursor color for hangul input as well. (Sung-Hyun Nam) +- Show "(lang)" for 'showmode' when language mapping is enabled. +- UTF-8: Made "r" work with a ":lmap" that includes a composing character. + Also works for "f", which now works to find a character that includes a + composing character. + +Other multi-byte character additions: +- Support double-byte single-width characters for euc-jp: Characters starting + with 0x8E. Added ScreenLines2[] to store the second byte. + + +Multi-language support *new-multi-lang* +---------------------- + +The messages used in Vim can be translated. Several translations are +available. This uses the gettext mechanism. It allows adding a translation +without recompiling Vim. |multi-lang| (partly by Marcin Dalecki) + +The translation files are in the src/po directory. The src/po/README.txt file +explains a few things about doing a translation. + +Menu translations are available as well. This uses the new |:menutranslate| +command. The translations are found in the runtime directory "lang". This +allows a user to add a translation. + +Added |:language| command to set the language (locale) for messages, time and +character type. This allows switching languages in Vim without changing the +locale outside of Vim. + +Made it possible to have vimtutor use different languages. (Eduardo Fernandez) +Spanish (Eduardo Fernandez), Italian (Antonio Colombo), Japanese (Yasuhiro +Matsumoto) and French (Adrien Beau) translations are included. +Added "vimtutor.bat": script to start Vim on a copy of the tutor file for +MS-Windows. (Dan Sharp) + +- Added v:lang variable to be able to get current language setting. + (Marcin Dalecki) Also v:lc_time and v:ctype. +- Make it possible to translate the dialogs used by the menus. Uses global + "menutrans_" variables. ":menutrans clear" deletes them. +- removed "broken locale" (Marcin Dalecki). +- Don't use color names in icons, use RGB values. The names could be + translated. +- Win32: Added global IME support (Muraoka) +- Win32: Added dynamic loading of IME support. +- ":messages" prints a message about who maintains the messages or the + translations. Useful to find out where to make a remark about a wrong + translation. +- --disable-nls argument for configure: Disable use of gettext(). (Sung-Hyun + Nam) +- Added NLS support for Win32 with the MingW compiler. (Eduardo Fernandez) +- When available, call bind_textdomain_codeset() to have gettext() translate + messages to 'encoding'. This requires GNU gettext 0.10.36 or later. +- Added gettext support for Win32. This means messages will be translated + when the locale is set and libintl.dll can be found. (Muraoka Taro) + Also made it work with MingW compiler. (Eduardo Fernandez) + Detect the language and set $LANG to get the appropriate translated messages + (if supported). Also use $LANG to select a language, v:lang is a very + different kind of name. +- Made gvimext.dll use translated messages, if possible. (Yasuhiro Matsumoto) + + +Plugin support *new-plugins* +-------------- + +To make it really easy to load a Vim script when starting Vim, the "plugin" +runtime directory can be used. All "*.vim" files in it will be automatically +loaded. For Unix, the directory "~/.vim/plugin" is used by default. The +'runtimepath' option can be set to look in other directories for plugins. +|load-plugins| |add-plugin| + +The |:runtime| command has been added to load one or more files in +'runtimepath'. + +Standard plugins: +netrw.vim - Edit files over a network |new-network-files| +gzip.vim - Edit compressed files +explorer.vim - Browse directories |new-file-browser| + +Added support for local help files. |add-local-help|. +When searching for help tags, all "doc/tags" files in 'runtimepath' are used. +Added the ":helptags" command: Generate a tags file for a help directory. +The first line of each help file is automagically added to the "LOCAL +ADDITIONS" section in doc/help.txt. + +Added the <unique> argument to ":map": only add a mapping when it wasn't +defined before. + +When displaying an option value with 'verbose' set will give a message about +where the option was last set. Very useful to find out which script did set +the value. + +The new |:scriptnames| command displays a list of all scripts that have been +sourced. + +GUI: For Athena, Motif and GTK look for a toolbar bitmap in the "bitmaps" +directories in 'runtimepath'. Allows adding your own bitmaps. + + +Filetype plugins *new-filetype-plugins* +----------------- + +A new group of files has been added to do settings for specific file types. +These can be options and mappings which are specifically used for one value of +'filetype'. + +The files are located in "$VIMRUNTIME/ftplugin". The 'runtimepath' option +makes it possible to use several sets of plugins: Your own, system-wide, +included in the Vim distribution, etc. + +To be able to make this work, several features were added: +- Added the "s:" variables, local to a script. Avoids name conflicts with + global variables. They can be used in the script and in functions, + autocommands and user commands defined in the script. They are kept between + invocations of the same script. |s:var| +- Added the global value for local options. This value is used when opening + a new buffer or editing another file. The option value specified in a + modeline or filetype setting is not carried over to another buffer. + ":set" sets both the local and the global value. + ":setlocal" sets the local option value only. + ":setglobal" sets or displays the global value for a local option. + ":setlocal name<" sets a local option to its global value. +- Added the buffer-local value for some global options: 'equalprg', 'makeprg', + 'errorformat', 'grepprg', 'path', 'dictionary', 'thesaurus', 'tags', + 'include' and 'define'. This allows setting a local value for these global + options, without making it incompatible. +- Added mappings and abbreviations local to a buffer: ":map <buffer>". +- In a mapping "<Leader>" can be used to get the value of the "mapleader" + variable. This simplifies mappings that use "mapleader". "<Leader>" + defaults to "\". "<LocalLeader>" does the same with "maplocalleader". This + is to be used for mappings local to a buffer. +- Added <SID> Script ID to define functions and mappings local to a script. +- Added <script> argument to ":noremap" and ":noremenu": Only remap + script-local mappings. Avoids that mappings from other scripts get in the + way, but does allow using mappings defined in the script. +- User commands can be local to a buffer: ":command -buffer". + +The new ":setfiletype" command is used in the filetype detection autocommands, +to avoid that 'filetype' is set twice. + + +File browser *new-file-browser* +------------ + +When editing a directory, the explorer plugin will list the files in the +directory. Pressing <Enter> on a file name edits that file. Pressing <Enter> +on a directory moves the browser to that directory. + +There are several other possibilities, such as opening a file in the preview +window, renaming files and deleting files. + + +Editing files over a network *new-network-files* +---------------------------- + +Files starting with scp://, rcp://, ftp:// and http:// are recognized as +remote files. An attempt is made to access these files with the indicated +method. For http:// only reading is possible, for the others writing is also +supported. Uses the netrw.vim script as a standard "plugin". |netrw| + +Made "gf" work on a URL. It no longer assumes the file is local on the +computer (mostly didn't work anyway, because the full path was required). +Adjusted test2 for this. + +Allow using a URL in 'path'. Makes ":find index.html" work. + +GTK: Allow dropping a http:// and ftp:// URL on Vim. The netrw plugin takes +care of downloading the file. (MiKael Berthe) + + +Window for command-line editing *new-cmdwin* +------------------------------- + +The Command-line window can be used to edit a command-line with Normal and +Insert mode commands. When it is opened it contains the history. This allows +copying parts of previous command lines. |cmdwin| + +The command-line window can be opened from the command-line with the key +specified by the 'cedit' option (like Nvi). It can also be opened directly +from Normal mode with "q:", "q/" and "q?". + +The 'cmdwinheight' is used to specify the initial height of the window. + +In Insert mode CTRL-X CTRL-V can be used to complete an Ex command line, like +it's done on the command-line. This is also useful for writing Vim scripts! + +Additionally, there is "improved Ex mode". Entered when Vim is started as +"exim" or "vim -E", and with the "gQ" command. Works like repeated use of +":", with full command-line editing and completion. (Ulf Carlsson) + + +Debugging mode *new-debug-mode* +-------------- + +In debugging mode sourced scripts and user functions can be executed line by +line. There are commands to step over a command or step into it. |debug-mode| + +Breakpoints can be set to run until a certain line in a script or user +function is executed. |:breakadd| + +Debugging can be started with ":debug {cmd}" to debug what happens when a +command executes. The |-D| argument can be used to debug while starting up. + + +Cursor in virtual position *new-virtedit* +-------------------------- + +Added the 'virtualedit' option: Allow positioning the cursor where there is no +actual character in Insert mode, Visual mode or always. (Matthias Kramm) +This is especially useful in Visual-block mode. It allows positioning a +corner of the area where there is no text character. (Many improvements by +Chase Tingley) + + +Debugger interface *new-debug-itf* +------------------ + +This was originally made to work with Sun Visual Workshop. (Gordon Prieur) +See |debugger.txt|, |sign.txt| and |workshop.txt|. + +Added the ":sign" command to define and place signs. They can be displayed +with two ASCII characters or an icon. The line after it can be highlighted. +Useful to display breakpoints and the current PC position. + +Added the |:wsverb| command to execute debugger commands. + +Added balloon stuff: 'balloondelay' and 'ballooneval' options. + +Added "icon=" argument for ":menu". Allows defining a specific icon for a +ToolBar item. + + +Communication between Vims *new-vim-server* +-------------------------- + +Added communication between two Vims. Makes it possible to send commands from +one Vim to another. Works for X-Windows and MS-Windows |clientserver|. + +Use "--remote" to have files be edited in an already running Vim. +Use "--remote-wait" to do the same and wait for the editing to finish. +Use "--remote-send" to send commands from one Vim to another. +Use "--remote-expr" to have an expression evaluated in another Vim. +Use "--serverlist" to list the currently available Vim servers. (X only) +There are also functions to communicate between the server and the client. +|remote_send()| |remote_expr()| + +(X-windows version implemented by Flemming Madsen, MS-Windows version by Paul +Moore) + +Added the command server name to the window title, so you can see which server +name belongs to which Vim. + +Removed the OleVim directory and SendToVim.exe and EditWithVim.exe from the +distribution. Can now use "gvim --remote" and "gvim --remote-send", which is +portable. + +GTK+: Support running Vim inside another window. Uses the --socketid argument +(Neil Bird) + + +Buffer type options *new-buftype* +------------------- + +The 'buftype' and 'bufhidden' options have been added. They can be set to +have different kinds of buffers. For example: +- 'buftype' = "quickfix": buffer with error list +- 'buftype' = "nofile" and 'bufhidden' = "delete": scratch buffer that will be + deleted as soon as there is no window displaying it. + +'bufhidden' can be used to overrule the 'hidden' option for one buffer. + +In combination with 'buflisted' and 'swapfile' this offers the possibility to +use various kinds of special buffers. See |special-buffers|. + + +Printing *new-printing* +-------- + +Included first implementation of the ":hardcopy" command for printing +to paper. For MS-Windows any installed printer can be used. For other +systems a PostScript file is generated, which can be printed with the +'printexpr' option. +(MS-Windows part by Vince Negri, Vipin Aravind, PostScript by Vince Negri and +Mike Williams) + +Made ":hardcopy" work with multi-byte characters. (Muraoka Taro, Yasuhiro +Matsumoto) + +Added options to tune the way printing works: (Vince Negri) +- 'printoptions' defines various things. +- 'printheader' specifies the header format. Added "N" field to 'statusline' + for the page number. +- 'printfont' specifies the font name and attributes. +- 'printdevice' defines the default printer for ":hardcopy!". + + +Ports *ports-6* +----- + +Port to OS/390 Unix (Ralf Schandl) +- A lot of changes to handle EBCDIC encoding. +- Changed Ctrl('x') to Ctrl_x define. + +Included jsbmouse support. (Darren Garth) +Support for dec mouse in Unix. (Steve Wall) + +Port to 16-bit MS Windows (Windows 3.1x) (Vince Negri) + +Port to QNX. Supports the Photon GUI, mouse, etc. (Julian Kinraid) + +Allow cross-compiling the Win32 version with Make_ming.mak. (Ron Aaron) +Added Python support for compiling with Mingw. (Ron Aaron) + +Dos 32 bit: Added support the Windows clipboard. (David Kotchan) + +Win32: Dynamically load Perl and Python. Allows compiling Vim with these +interfaces and will try to find the DLLs at runtime. (Muraoka Taro) + +Compiling the Win32 GUI with Cygwin. Also compile vimrun, dosinst and +uninstall. (Gerfried) + +Mac: Make Vim compile with the free MPW compiler supplied by Apple. And +updates for CodeWarrior. (Axel Kielhorn) + +Added typecasts and ifdefs as a start to make Vim work on Win64 (George +Reilly) + + +Quickfix extended *quickfix-6* +----------------- + +Added the "error window". It contains all the errors of the current error +list. Pressing <Enter> in a line makes Vim jump to that line (in another +window). This makes it easy to navigate through the error list. +|quickfix-window|. + +- |:copen| opens the quickfix window. +- |:cclose| closes the quickfix window. +- |:cwindow| takes care that there is a quickfix window only when there are + recognized errors. (Dan Sharp) + +- Quickfix also knows "info", next to "warning" and "error" types. "%I" can be + used for the start of a multi-line informational message. (Tony Leneis) +- The "%p" argument can be used in 'errorformat' to get the column number from + a line where "^" points to the column. (Stefan Roemer) +- When using "%f" in 'errorformat' on a DOS/Windows system, also include "c:" + in the filename, even when using "%f:". + + +Operator modifiers *new-operator-mod* +------------------ + +Insert "v", "V" or CTRL-V between an operator and a motion command to force +the operator to work characterwise, linewise or blockwise. |o_v| + + +Search Path *new-search-path* +----------- + +Vim can search in a directory tree not only in downwards but also upwards. +Works for the 'path', 'cdpath' and 'tags' options. (Ralf Schandl) + +Also use "**" for 'tags' option. (Ralf Schandl) + +Added 'includeexpr', can be used to modify file name found by 'include' +option. +Also use 'includeexpr' for "gf" and "<cfile>" when the file can't be found +without modification. Useful for doing "gf" on the name after an include or +import statement. + +Added the 'cdpath' option: Locations to find a ":cd" argument. (Raf) + +Added the 'suffixesadd' option: Suffixes to be added to a file name when +searching for a file for the "gf", "[I", etc. commands. + + +Writing files improved *new-file-writing* +---------------------- + +Added the 'backupcopy' option: Select whether a file is to be copied or +renamed to make a backup file. Useful on Unix to speed up writing an ordinary +file. Useful on other systems to preserve file attributes and when editing a +file on a Unix filesystem. + +Added the 'autowriteall' option. Works like 'autowrite' but for more +commands. + +Added the 'backupskip' option: A list of file patterns to skip making a backup +file when it matches. The default for Unix includes "/tmp/*", this makes +"crontab -e" work. + +Added support for Access Control Lists (ACL) for FreeBSD and Win32. The ACL +is copied from the original file to the new file (or the backup if it's +copied). +ACL is also supported for AIX, Solaris and generic POSIX. (Tomas Ogren) +And on SGI. + + +Argument list *new-argument-list* +------------- + +The support for the argument list has been extended. It can now be +manipulated to contain the files you want it to contain. + +The argument list can now be local to a window. It is created with the +|:arglocal| command. The |:argglobal| command can be used to go back to the +global argument list. + +The |:argdo| command executes a command on all files in the argument list. + +File names can be added to the argument list with |:argadd|. File names can +be removed with |:argdelete|. + +"##" can be used like "#", it is replaced by all the names in the argument +list concatenated. Useful for ":grep foo ##". + +The |:argedit| adds a file to the argument list and edits it. Like ":argadd" +and then ":edit". + + +Restore a View *new-View* +-------------- + +The ":mkview" command writes a Vim script with the settings and mappings for +one window. When the created file is sourced, the view of the window is +restored. It's like ":mksession" for one window. +The View also contains the local argument list and manually created, opened +and closed folds. + +Added the ":loadview" command and the 'viewdir' option: Allows for saving and +restoring views of a file with simple commands. ":mkview 1" saves view 1 for +the current file, ":loadview 1" loads it again. Also allows quickly switching +between two views on one file. And saving and restoring manual folds and the +folding state. + +Added 'viewoptions' to specify how ":mkview" works. + +":mksession" now also works fine with vertical splits. It has been further +improved and restores the view of each window. It also works properly with +preview and quickfix windows. + +'sessionoptions' is used for ":mkview" as well. +Added "curdir" and "sesdir" to 'sessionoptions'. Allows selection of what +the current directory will be restored to. + +The session file now also contains the argument list(s). + + +Color schemes *new-color-schemes* +------------- + +Support for loading a color scheme. Added the ":colorscheme" command. +Automatically add menu entries for available schemes. +Should now properly reset the colors when 'background' or 't_Co' is changed. +":highlight clear" sets the default colors again. +":syntax reset" sets the syntax highlight colors back to the defaults. +For ":set bg&" guess the value. This allows a color scheme to switch back to +the default colors. +When syntax highlighting is switched on and a color scheme was defined, reload +the color scheme to define the colors. + + +Various new items *new-items-6* +----------------- + +Normal mode commands: ~ + +"gi" Jump to the ^ mark and start Insert mode. Also works when the + mark is just after the line. |gi| + +"g'm" and "g`m" + Jump to a mark without changing the jumplist. Now you can use + g`" to jump to the last known position in a file without side + effects. Also useful in mappings. + +[', [`, ]' and ]` + move the cursor to the next/previous lowercase mark. + +g_ Go to last non-blank in line. (Steve Wall) + + +Options: ~ + +'autoread' When detected that a file changed outside of Vim, + automatically read a buffer again when it's not changed. + It has a global and a local value. Use ":setlocal autoread<" + to go back to using the global value for 'autoread'. + +'debug' When set to "msg" it will print error messages that would + otherwise be omitted. Useful for debugging 'indentexpr' and + 'foldexpr'. + +'lispwords' List of words used for lisp indenting. It was previously hard + coded. Added a number of Lisp names to the default. + +'fold...' Many new options for folding. + +'modifiable' When off, it is impossible to make changes to a buffer. + The %m and %M items in 'statusline' show a '-'. + +'previewwindow' Set in the preview window. Used in a session file to mark a + window as the preview window. + +'printfont' +'printexpr' +'printheader' +'printdevice' +'printoptions' for ":hardcopy". + +'buflisted' Makes a buffer appear in the buffer list or not. + +Use "vim{version}:" for modelines, only to be executed when the version is +>= {version}. Also "vim>{version}", "vim<{version}" and "vim={version}". + + +Ex commands: ~ + +:sav[eas][!] {file} + Works like ":w file" and ":e #", but without loading the file + again and avoiding other side effects. |:saveas| + +:silent[!] {cmd} + Execute a command silently. Also don't use a delay that would + come after the message. And don't do 'showmatch'. + RISCOS: Removed that "!~cmd" didn't output anything, and + didn't wait for <Enter> afterwards. Can use ":silent !cmd" + now. +:menu <silent> Add a menu that won't echo Ex commands. +:map <silent> Add a mapping that won't echo Ex commands. + +:checktime Check for changed buffers. + +:verbose {cmd} Set 'verbose' for one command. + +:echomsg {expr} +:echoerr {expr} Like ":echo" but store the message in the history. (Mark + Waggoner) + +:grepadd Works just like ":grep" but adds to the current error list + instead of defining a new list. |:grepadd| + +:finish Finish sourcing a file. Can be used to skip the rest of a Vim + script. |:finish| + +:leftabove +:aboveleft Split left/above current window. + +:rightbelow +:belowright Split right/below current window. + +:first, :bfirst, :ptfirst, etc. + Alias for ":rewind". It's more logical compared to ":last". + +:enew Edit a new, unnamed buffer. This is needed, because ":edit" + re-edits the same file. (Wall) + +:quitall Same as ":qall". + +:match Define match highlighting local to a window. Allows + highlighting an item in the current window without interfering + with syntax highlighting. + +:menu enable +:menu disable Commands to enable/disable menu entries without removing them. + (Monish Shah) + +:windo Execute a command in all windows. +:bufdo Execute a command in all buffers. + +:wincmd Window (CTRL-W) command. Useful when a Normal mode command + can't be used (e.g., for a CursorHold autocommand). See + |CursorHold-example| for a nice application with it. + +:lcd and :lchdir + Set local directory for a window. (Benjie Chen) + +:hide {command} + Execute {command} with 'hidden' set. + +:emenu in Visual mode to execute a ":vmenu" entry. + +:popup Pop up a popup menu. + +:redraw Redraw the screen even when busy with a script or function. + +:hardcopy Print to paper. + +:compiler Load a Vim script to do settings for a specific compiler. + +:z# List numbered lines. (Bohdan Vlasyuk) + + +New marks: ~ + +'( and ') Begin or end of current sentence. Useful in Ex commands. +'{ and '} Begin or end of current paragraph. Useful in Ex commands. +'. Position of the last change in the current buffer. +'^ Position where Insert mode was stopped. + +Store the ^ and . marks in the viminfo file. Makes it possible to jump to the +last insert position or changed text. + + +New functions: ~ +argidx() Current index in argument list. +buflisted() Checks if the buffer exists and has 'buflisted' set. +cindent() Get indent according to 'cindent'. +eventhandler() Returns 1 when inside an event handler and interactive + commands can't be used. +executable() Checks if a program or batch script can be executed. +filewritable() Checks if a file can be written. (Ron Aaron) +foldclosed() Find out if there is a closed fold. (Johannes Zellner). +foldcloseend() Find the end of a closed fold. +foldlevel() Find out the foldlevel. (Johannes Zellner) +foreground() Move the GUI window to the foreground. +getchar() Get one character from the user. Can be used to define a + mapping that takes an argument. +getcharmod() Get last used key modifier. +getbufvar() gets the value of an option or local variable in a buffer (Ron + Aaron) +getfsize() Return the size of a file. +getwinvar() gets the value of an option or local variable in a window (Ron + Aaron) +globpath() Find matching files in a list of directories. +hasmapto() Detect if a mapping to a string is already present. +iconv() Convert a string from one encoding to another. +indent() gets the indent of a line (Ron Aaron) +inputdialog() Like input() but use a GUI dialog when possible. Currently + only works for Win32, Motif, Athena and GTK. + Use inputdialog() for the Edit/Settings/Text Width menu. Also + for the Help/Find.. and Toolbar FindHelp items. + (Win32 support by Thore B. Karlsen) + (Win16 support by Vince Negri) +inputsecret() Ask the user to type a string without showing the typed keys. + (Charles Campbell) +libcall() for Unix (Neil Bird, Johannes Zellner, Stephen Wall) +libcallnr() for Win32 and Unix +lispindent() Get indent according to 'lisp'. +mode() Return a string that indicates the current mode. +nextnonblank() Skip blank lines forwards. +prevnonblank() Skip blank lines backwards. Useful to for indent scripts. +resolve() MS-Windows: resolve a shortcut to the file it points to. + Unix: resolve a symbolic link. +search() Search for a pattern. +searchpair() Search for matching pair. Can be used in indent files to find + the "if" matching an endif. +setbufvar() sets an option or variable local to a buffer (Ron Aaron) +setwinvar() sets an option or variable local to a window (Ron Aaron) +stridx() Search for first occurrence of one string in another. +strridx() Search for last occurrence of one string in another. +tolower() Convert string to all-lowercase. +toupper() Convert string to all-uppercase. +type() Check the type of an expression. +wincol() window column of the cursor +winwidth() Width of a window. (Johannes Zellner) +winline() window line of the cursor + + +Added expansion of curly braces in variable and function names. This can be +used for variable names that include the value of an option. Or a primitive +form of arrays. (Vince Negri) + + +New autocommand events: ~ +BufWinEnter Triggered when a buffer is displayed in a window, after using + the modelines. Can be used to load a view. +BufWinLeave Triggered when a buffer is no longer in a window. Also + triggered when exiting Vim. Can be used to save views. +FileChangedRO Triggered before making the first change to a read-only file. + Can be used to check-out the file. (Scott Graham) +TermResponse Triggered when the terminal replies to the version-request. + The v:termresponse internal variable holds the result. Can be + used to react to the version of the terminal. (Ronald Schild) +FileReadCmd Triggered before reading a file. +BufReadCmd Triggered before reading a file into a buffer. +FileWriteCmd Triggered before writing a file. +BufWriteCmd Triggered before writing a buffer into a file. +FileAppendCmd Triggered before appending to a file. +FuncUndefined Triggered when a user function is not defined. (Ron Aaron) + +The autocommands for the *Cmd events read or write the file instead of normal +file read/write. Use this in netrw.vim to be able to edit files on a remote +system. (Charles Campbell) + + +New Syntax files: ~ + +bdf BDF font definition (Nikolai Weibull) +catalog SGML catalog (Johannes Zellner) +debchangelog Debian Changelog (Wichert Akkerman) +debcontrol Debian Control (Wichert Akkerman) +dot dot (Markus Mottl) +dsl DSSSL syntax (Johannes Zellner) +eterm Eterm configuration (Nikolai Weibull) +indent Indent profile (Nikolai Weibull) +lftp LFTP (Nikolai Weibull) +lynx Lynx config (Doug Kearns) +mush mush sourcecode (Bek Oberin) +natural Natural (Marko Leipert) +pilrc Pal resource compiler (Brian Schau) +plm PL/M (Philippe Coulonges) +povini Povray configuration (David Necas) +ratpoison Ratpoison config/command (Doug Kearns) +readline readline config (Nikolai Weibull) +screen Screen RC (Nikolai Weibull) +specman Specman (Or Freund) +sqlforms SQL*Forms (Austin Ziegler) +terminfo terminfo (Nikolai Weibull) +tidy Tidy configuration (Doug Kearns) +wget Wget configuration (Doug Kearns) + + +Updated many syntax files to work both with Vim 5.7 and 6.0. + +Interface to Ruby. (Shugo Maeda) +Support dynamic loading of the Ruby interface on MS-Windows. (Muraoka Taro) +Support this for Mingw too. (Benoit Cerrina) + +Win32: Added possibility to load TCL dynamically. (Muraoka Taro) +Also for Borland 5.5. (Dan Sharp) + +Win32: When editing a file that is a shortcut (*.lnk file), edit the file it +links to. Unless 'binary' is set, then edit the shortcut file itself. +(Yasuhiro Matsumoto) + +The ":command" command now accepts a "-bar" argument. This allows the user +command to be followed by "| command". + +The preview window is now also used by these commands: +- |:pedit| edits the specified file in the preview window +- |:psearch| searches for a word in included files, like |:ijump|, and + displays the found text in the preview window. +Added the CTRL-W P command: go to preview window. + +MS-DOS and MS-Windows also read the system-wide vimrc file $VIM/vimrc. Mostly +for NT systems with multiple users. + +A double-click of the mouse on a character that has a "%" match selects from +that character to the match. Similar to "v%". + +"-S session.vim" argument: Source a script file when starting up. Convenient +way to start Vim with a session file. + +Added "--cmd {command}" Vim argument to execute a command before a vimrc file +is loaded. (Vince Negri) + +Added the "-M" Vim argument: reset 'modifiable' and 'write', thus disallow +making changes and writing files. + +Added runtime/delmenu.vim. Source this to remove all menus and prepare for +loading new menus. Useful when changing 'langmenu'. + +Perl script to filter Perl error messages to quickfix usable format. (Joerg +Ziefle) + +Added runtime/macros/less.vim: Vim script to simulate less, but with syntax +highlighting. + +MS-Windows install program: (Jon Merz) +- The Win32 program can now create shortcuts on the desktop and install Vim in + the Start menu. +- Possibly remove old "Edit with Vim" entries. +- The Vim executable is never moved or $PATH changed. A small batch file is + created in a directory in $PATH. Fewer choices to be made. +- Detect already installed Vim versions and offer to uninstall them first. + +Improved the MS-Windows uninstal program. It now also deletes the entries in +the Start menu, icons from the desktop and the created batch files. (Jon Merz) +Also made it possible to delete only some of these. Also unregister gvim for +OLE. + +Generate a self-installing Vim package for MS-Windows. This uses NSIS. (Jon +Merz et al.) + +Added ":filetype detect". Try detecting the filetype again. Helps when +writing a new shell script, after adding "#!/bin/csh". + +Added ":augroup! name" to delete an autocommand group. Needed for the +client-server "--remote-wait". + +Add the Vim version number to the viminfo file, useful for debugging. + +============================================================================== +IMPROVEMENTS *improvements-6* + +Added the 'n' flag in 'cpoptions': When omitted text of wrapped lines is not +put between line numbers from 'number' option. Makes it a lot easier to read +wrapped lines. + +When there is a format error in a tags file, the byte position is reported so +that the error can be located. + +"gf" works in Visual mode: Use the selected text as the file name. (Chase +Tingley) + +Allow ambiguous mappings. Thus "aa" and "aaa" can both be mapped, the longest +matching one is used. Especially useful for ":lmap" and 'keymap'. + +Encryption: Ask the key to be typed twice when crypting the first time. +Otherwise a typo might cause the text to be lost forever. (Chase Tingley) + +The window title now has "VIM" on the end. The file name comes first, useful +in the taskbar. A "+" is added when the file is modified. "=" is added for +a read-only file. "-" is added for a file with 'modifiable' off. + +In Visual mode, mention the size of the selected area in the 'showcmd' +position. + +Added the "b:changedtick" variable. Incremented at each change, also for +undo. Can be used to take action only if the buffer has been changed. + +In the replacement string of a ":s" command "\=" can be used to replace with +the result of an expression. From this expression the submatch() function can +be used to access submatches. + +When doing ":qall" and there is a change in a buffer that is being edited in +another window, jump to that window, instead of editing that buffer in the +current window. + +Added the "++enc=" and "++ff=" arguments to file read/write commands to force +using the given 'encoding' or 'fileformat'. And added the "v:cmdarg" +variable, to be used for FileReadCmd autocommands that read/write the file +themselves. + +When reading stdin, first read the text in binary mode and then re-read it +with automatic selection of 'fileformat' and 'fileencoding'. This avoids +problems with not being able to rewind the file (e.g., when a line near the +end of the file ends in LF instead of CR-LF). +When reading text from stdin and the buffer is empty, don't mark it changed. +Allows exiting without trouble. + +Added an ID to many error messages. This will make it easier to find help for +a message. + +Insert mode: +- "CTRL-G j" and "CTRL-G k" can be used to insert in another line in the same + column. Useful for editing a table. +- Added Thesaurus completion with CTRL-X CTRL-T. (Vince Negri) +- Added the 'thesaurus' option, to use instead of 'dictionary' for thesaurus + completion. Added the 's' flag in 'complete'. +- Made CTRL-X CTRL-L in Insert mode use the 'complete' option. It now also + scans other loaded buffers for matching lines. +- CTRL-R now also works in Insert mode while doing completion with CTRL-X or + CTRL-N. (Neil Bird) +- When doing Insert mode completion, when completion is finished check for a + match with words from 'cinkeys' or 'indentkeys'. + +Performance: +- Made display updating more efficient. Insert/delete lines may be used for + all changes, also for undo/redo. +- The display is not redrawn when there is typeahead in Insert mode. Speeds + up CTRL-R a lot. +- Improved speed of screen output for 32 bit DOS version. (Vince Negri) +- When dragging with the mouse, there is a lookahead to skip mouse codes when + there is another one next. Makes dragging with the mouse a lot faster. +- Also a memory usage improvement: When calling u_save with a single line, + don't save it if the line was recently saved for the same undo already. +- When using a script that appends one character at a time, the amount of + allocated memory was growing steadily. Also when 'undolevels' is -1. + Caused by the line saved for "U" never to be freed. Now free an undo block + when it becomes empty. +- GUI and Dos32: Use a vertical scroll region, to make scrolling in a + vertically split window faster. No need to redraw the whole window. +- When scrolling isn't possible with terminal codes (e.g., for a vertically + split window) redraw from ScreenLines[]. That should be faster than going + through the lines with win_line(), especially when using syntax + highlighting. +- The Syntax menu is now pre-generated by a separate script. Makes loading + the menu 70% faster. This can halve the startup time of gvim. +- When doing ":help tag", don't open help.txt first, jump directly to the help + tag. It's faster and avoids an extra message. +- Win32: When a file name doesn't end in ".lnk" don't try resolving a + shortcut, it takes quite a bit of time. +- Don't update the mouse pointer shape while there are typeahead characters. +- Change META[] from a string into an array, avoids using strchr() on it. +- Don't clear the command line when adding characters, avoids that screen_fill + is called but doesn't do anything. + +Robustness: +- Unix: Check for running out of stack space when executing a regexp. Avoids + a nasty crash. Only works when the system supports running the signal + function on another stack. +- Disallow ":source <dirname>". On unix it's possible to read a directory, + does not make sense to use it as Vim commands. + +Security: +- When reading from or writing to a temporary file, check that it isn't a + symbolic link. Gives some protection against symlink attacks. +- When creating a backup file copy or a swap file, check for it already + existing to avoid a symlink attack. (Colin Phipps) +- Evaluating options which are an expression is done in a |sandbox|. If the + option was set by a modeline, it cannot cause damage. +- Use a secure way to generate temp file names: Create a private directory for + temp files. Used for Unix, MS-DOS and OS/2. +- 'makeef' can be empty, which means that an internally generated file name is + used. The old default was "/tmp/file", which is a security risk. + Writing 'makeef' in the current directory fails in a read-only directory and + causes trouble when using ":grep" on all files. Made the default empty for + all systems, so that a temp file is used. +- The command from a tags file is executed in the sandbox for better security. +- The Ruby, Tcl and Python interfaces cannot be used from the sandbox. They + might do dangerous things. Perl is still possible, but limited to the Safe + environment. (Donnie Smith) + +Syntax highlighting: +- Optimized the speed by caching the state stack all over the file, not just + the part being displayed. Required for folding. +- Added ":syntax sync fromstart": Always parse from the start of the file. +- Added the "display" argument for syntax items: use the item only when + displaying the result. Can make parsing faster for text that isn't going to + be displayed. +- When using CTRL-L, the cached states are deleted, to force parsing the text + again. +- Use elfhash algorithm for table of keywords. This should give a better + distribution and speedup keyword lookup. (Campbell) +- Also allow the "lc" leading context for skip and end patterns. (Scott + Bigham) +- Syntax items can have the "extend" argument to undo the effect of a + "keepend" argument of an item it is contained in. Makes it possible to have + some contained items extend a region while others don't. +- ":syntax clear" now deletes the b:current_syntax variable. That's logical, + since no syntax is defined after this command. +- Added ":syntax enable": switch on syntax highlighting without changing the + colors. This allows specifying the colors in the .vimrc file without the + need for a mysyntaxfile. +- Added ":syntax reset": reset the colors to their defaults. +- Added the "contains=TOP" and "contains=CONTAINED" arguments. Makes it + possible to define a transparent item that doesn't contain itself. +- Added a "containedin" argument to syntax items. Allows adding a contained + item to an existing item (e.g., to highlight a name in a comment). + +Modeless selection: +- When in the command-line window, use modeless selection in the other + windows. Makes it possible to copy visible text to the command-line window. +- Support modeless selection on the cmdline in a terminal. Previously it was + only possible for the GUI. +- Make double-right-click in modeless selection select a whole word. Single + right click doesn't use the word selection started by a double-left-click. + Makes it work like in Visual mode. +- The modeless selection no longer has an implied automatic copy to the + clipboard. It now obeys the 'a' and 'A' flags in 'guioptions' or + "autoselect" and "autoselectml" in 'clipboard'. +- Added the CTRL-Y command in Cmdline-mode to copy the modeless selection to + the clipboard. Also works at the hit-enter prompt and the more prompt. + Removed the mappings in runtime/mswin.vim for CTRL-Y and CTRL-Z in + cmdline-mode to be able to use CTRL-Y in the new way. + +Reduced the amount of stack space used by regmatch() to allow it to handle +complicated patterns on a longer text. + +'isfname' now includes '%' and '#'. Makes "vim dir\#file" work for MS-DOS. + +Added keypad special keys <kEnter>, <k0> - <k9>. When not mapped they behave +like the ASCII equivalent. (Ivan Wellesz and Vince Negri) +Recognize a few more xterm keys: <C-Right>, <C-Left>, <C-End>, <C-Home> + +Also trigger the BufUnload event when Vim is going to exit. Perhaps a script +needs to do some cleaning up. + +Expand expression in backticks: `={expr}`. Can be used where backtick +expansion is done. (Vince Negri) + +GUI: +- Added 'L' and 'R' flags in 'guioptions': Add a left or right scrollbar only + when there is a vertically split window. +- X11: When a color can't be allocated, use the nearest match from the + colormap. This avoids that black is used for many things. (Monish Shah) + Also do this for the menu and scrollbar, to avoid that they become black. +- Win32 and X11: Added 'mouseshape' option: Adjust the mouse pointer shape to + the current mode. (Vince Negri) +- Added the 'linespace' option: Insert a pixel line between lines. (Nam) +- Allow modeless selection (without moving the cursor) by keeping CTRL and + SHIFT pressed. (Ivan Wellesz) +- Motif: added toolbar. (Gordon Prieur) Also added tooltips. +- Athena: added toolbar and tooltips. (David Harrison -- based on Gordon + Prieur's work) +- Made the 'toolbar' option work for Athena and Motif. Can now switch between + text and icons on the fly. (David Harrison) +- Support menu separator lines for Athena. (David Harrison) +- Athena: Adjust the arrow pixmap used in a pullright menu to the size of the + font. (David Harrison) +- Win32: Added "c" flag to 'guifont' to be able to specify the charset. (Artem + Khodush) +- When no --enable-xim argument is given, automatically enable it when a X GUI + is used. Required for dead key support (and multi-byte input). +- After a file selection dialog, check that the edited files were not changed + or deleted. The Win32 dialog allows deleting and renaming files. +- Motif and Athena: Added support for "editres". (Marcin Dalecki) +- Motif and Athena: Added "menuFont" to be able to specify a font or fontset + for the menus. Can also be set with the "Menu" highlight group. Useful + when the locale is different from 'encoding'. (David Harrison) + When FONTSET_ALWAYS is defined, always use a fontset for the menus. Should + avoid trouble with changing from a font to a fontset. (David Harrison) +- Highlighting and font for the tooltips can be specified with the "Tooltip" + highlight group. (David Harrison) +- The Cmdline-mode menus can be used at the more-prompt. This mostly works + fine, because they start with a CTRL-C. The "Copy" menu works to copy the + modeless selection. Allows copying the output of ":set all" or ":intro" + without auto-selection. +- When starting the GUI when there is no terminal connected to stdout and + stderr, display error messages in a dialog. Previously they wouldn't be + displayed at all. +- Allow setting 'browsedir' to the name of a directory, to be used for the + file dialog. (Dan Sharp) +- b:browsefilter and g:browsefilter can be set to the filters used for the + file dialog. Supported for Win32 and Motif GUI. (Dan Sharp) + +X11: +- Support for the clipboard selection as register "+. When exiting or + suspending copy the selection to cut buffer 0. Should allow copy/paste with + more applications in a X11-standard way. (Neil Bird) +- Use the X clipboard in any terminal, not just in an xterm. + Added "exclude:" in 'clipboard': Specify a pattern to match against terminal + names for which no connection should be made to the X server. The default + currently work for FreeBSD and Linux consoles. +- Added a few messages for when 'verbose' is non-zero to show what happens + when trying to connect to the X server. Should help when trying to find out + why startup is slow. + +GTK GUI: (partly by Marcin Dalecki) +- With some fonts the characters can be taller than ascent + descent. E.g., + "-misc-fixed-*-*-*-*-18-*-*-*-*-*-iso10646-1". Add one to the character + cell height. +- Implement "no" value for 'winaltkeys': don't use Alt-Key as a menu shortcut, + when 'wak' changed after creating the menus. +- Setting 'wak' after the GUI started works. +- recycle text GC's to reduce communication. +- Adjust icon size to window manager. +- Cleanup in font handling. +- Replace XQueryColor with GDK calls. +- Gnome support. Detects Gnome in configure and uses different widgets. + Otherwise it's much like GTK. (Andy Kahn) + It is disabled by default, because it causes a few problems. +- Removed the special code to fork first and then start the GUI. Now use + _exit() instead of exit(), this works fine without special tricks. +- Dialogs sometimes appeared a bit far away. Position the dialogs inside + the gvim window. (Brent Verner) +- When dropping a file on Vim, remove extra slashes from the start of the + path. Also shorten the file name if possible. + +Motif: (Marcin Dalecki) +- Made the dialog layout better. +- Added find and find/replace dialogs. +- For the menus, change "iso-8859" to "iso_8859", Linux appears to need this. +- Added icon to dialogs, like for GTK. +- Use XPM bitmaps for the icon when possible. Use the Solaris XpmP.h include + file when it's available. +- Change the shadow of the toolbar items to get a visual feedback of it being + pressed on non-LessTif. +- Use gadgets instead of windows for some items for speed. + +Command line completion: +- Complete environment variable names. (Mike Steed) +- For ":command", added a few completion methods: "mapping", "function", + "expression" and "environment". +- When a function doesn't take arguments, let completion add () instead of (. + +For MS-DOS, MS-Windows and OS/2: Expand %VAR% environment variables like $VAR. +(Walter Briscoe) + +Redirect messages to the clipboard ":redir @*" and to the unnamed register +":redir @"". (Wall) + +":let @/ = ''" clears the search pattern, instead of setting it to an empty +string. + +Expression evaluation: +- "? :" can be used like in C. +- col("$") returns the length of the cursor line plus one. (Stephen P. Wall) +- Optional extra argument for match(), matchend() and matchstr(): Offset to + start looking for a match. +- Made third argument to strpart() optional. (Paul Moore, Zdenek Sekera) +- exists() can also be used to check for Ex commands and defined autocommands. +- Added extra argument to input(): Default text. +- Also set "v:errmsg" when using ":silent! cmd". +- Added the v:prevcount variable: v:count for the previous command. +- Added "v:progname", name with which Vim was started. (Vince Negri) +- In the verbose message about returning from a function, also show the return + value. + +Cscope: +- Added the cscope_connection() function. (Andy Kahn) +- ":cscope kill -1" kills all cscope connections. (Andy Kahn) +- Added the 'cscopepathcomp' option. (Scott Hauck) +- Added ":scscope" command, split window and execute Cscope command. (Jason + Duell) + +VMS: +- Command line arguments are always uppercase. Interpret a "-X" argument as + "-x" and "-/X" as "-X". +- Set 'makeprg' and 'grepprg' to meaningful defaults. (Zoltan Arpadffy) +- Use the X-clipboard feature and the X command server. (Zoltan Arpadffy) + +Macintosh: (Dany St-Amant) +- Allow a tags file to have CR, CR-LF or LF line separator. (Axel Kielhorn) +- Carbonized (while keeping non Carbon code) + (Some work "stolen" from Ammon Skidmore) +- Improved the menu item index handling (should be faster) +- Runtime commands now handle / in file name (MacOS 9 version) +- Added ":winpos" support. +- Support using "~" in file names for home directory. + +Options: +- When using set += or ^= , check for items used twice. Duplicates are + removed. (Vince Negri) +- When setting an option that is a list of flags, remove duplicate flags. +- If possible, use getrlimit() to set 'maxmemtot' and 'maxmem'. (Pina) +- Added "alpha" to 'nrformats': increment or decrement an alphabetic character + with CTRL-A and CTRL-X. +- ":set opt&vi" sets an option to its Vi default, ":set opt&vim" to its Vim + default. Useful to set 'cpo' to its Vim default without knowing what flags + that includes. +- 'scrolloff' now also applies to a long, wrapped line that doesn't fit in the + window. +- Added more option settings to the default menus. +- Updated the option window with new options. Made it a bit easier to read. + +Internal changes: +- Split line pointers in text part and attributes part. Allows for future + change to make attribute more than one byte. +- Provide a qsort() function for systems that don't have it. +- Changed the big switch for Normal mode commands into a table. This cleans + up the code considerably and avoids trouble for some optimizing compilers. +- Assigned a negative value to special keys, to avoid them being mixed up with + Unicode characters. +- Global variables expand_context and expand_pattern were not supposed to be + global. Pass them to ExpandOne() and all functions called by it. +- No longer use the global reg_ic flag. It caused trouble and in a few places + it was not set. +- Removed the use of the stuff buffer for "*", "K", CTRL-], etc. Avoids + problem with autocommands. +- Moved some code from ex_docmd.c to ex_cmds2.c. The file was getting too + big. Also moved some code from screen.c to move.c. +- Don't include the CRC table for encryption, generate it. Saves quite a bit + of space in the source code. (Matthias Kramm) +- Renamed multibyte.c to mbyte.c to avoid a problem with 8.3 filesystems. +- Removed the GTK implementation of ":findhelp", it now uses the + ToolBar.FindHelp menu entry. +- Renamed mch_windexit() to mch_exit(), mch_init() to mch_early_init() and + mch_shellinit() to mch_init(). + +Highlighting: +- In a ":highlight" listing, show "xxx" with the highlight color. +- Added support for xterm with 88 or 256 colors. The right color numbers will + be used for the name used in a ":highlight" command. (Steve Wall) +- Added "default" argument for ":highlight". When included, the command is + ignored if highlighting for the group was already defined. + All syntax files now use ":hi default ..." to allow the user to specify + colors in his vimrc file. Also, the "if did_xxx_syntax_inits" is not needed + anymore. This greatly simplifies using non-default colors for a specific + language. +- Adjusted colortest.vim: Included colors on normal background and reduced the + size by using a while loop. (Rafael Garcia-Suarez) +- Added the "DarkYellow" color name. Just to make the list of standard colors + consistent, it's not really a nice color to use. + +When an xterm is in 8-bit mode this is detected by the code returned for +|t_RV|. All key codes are automatically converted to their 8-bit versions. + +The OPT_TCAP_QUERY in xterm patch level 141 and later is used to obtain the +actual key codes used and the number of colors for t_Co. Only when |t_RV| is +also used. + +":browse set" now also works in the console mode. ":browse edit" will give an +error message. + +":bdelete" and ":bunload" only report the number of deleted/unloaded buffers +when more than 'report'. The message was annoying when deleting a buffer in a +script. + +Jump list: +- The number of marks kept in the jumplist has been increased from 50 to 100. +- The jumplist is now stored in the viminfo file. CTRL-O can be used to jump + to positions from a previous edit session. +- When doing ":split" copy the jumplist to the new window. + +Also set the '[ and '] marks for the "~" and "r" commands. These marks are +now always set when making a change with a Normal mode command. + +Python interface: Allow setting the width of a vertically split window. (John +Cook) + +Added "=word" and "=~word" to 'cinkeys' (also used in 'indentkeys'). + +Added "j1" argument in 'cinoptions': indent {} inside () for Java. (Johannes +Zellner) +Added the "l" flag in 'cinoptions'. (Anduin Withers) +Added 'C', 'U', 'w' and 'm' flags to 'cinoptions'. (Servatius Brandt) + +When doing ":wall" or ":wqall" and a modified buffer doesn't have a name, +mention its buffer number in the error message. + +":function Name" lists the function with line numbers. Makes it easier to +find out where an error happened. + +In non-blockwise Visual mode, "r" replaces all selected characters with the +typed one, like in blockwise Visual mode. + +When editing the last file in the argument list in any way, allow exiting. +Previously this was only possible when getting to that file with ":next" or +":last". + +Added the '1' flag to 'formatoptions'. (Vit Stradal) +Added 'n' flag in 'formatoptions': format a numbered list. + +Swap file: +- When a swap file already exists, and the user selects "Delete" at the + ATTENTION prompt, use the same ".swp" swapfile, to avoid creating a ".swo" + file which won't always be found. +- When giving the ATTENTION message and the date of the file is newer than the + date of swap file, give a warning about this. +- Made the info for an existing swap file a bit shorter, so that it still fits + on a 24 line screen. +- It was possible to make a symlink with the name of a swap file, linking to a + file that doesn't exist. Vim would then silently use another file (if open + with O_EXCL refuses a symlink). Now check for a symlink to exist. Also do + another check for an existing swap file just before creating it to catch a + symlink attack. + +The g CTRL-G command also works in Visual mode and counts the number of words. +(Chase Tingley) + +Give an error message when using 'shell' and it's empty. + +Added the possibility to include "%s" in 'shellpipe'. + +Added "uhex" value for 'display': show non-printable characters as <xx>. +Show unprintable characters with NonText highlighting, also in the command +line. + +When asked to display the value of a hidden option, tell it's not supported. + +Win32: +- When dropping a shortcut on gvim (.lnk file) edit the target, not the + shortcut itself. (Yasuhiro Matsumoto) +- Added C versions of the OpenWithVim and SendToVim programs. (Walter Briscoe) +- When 'shell' is "cmd" or "cmd.exe", set 'shellredir' to redirect stderr too. + Also check for the Unix shell names. +- When $HOMEDRIVE and $HOMEPATH are defined, use them to define $HOME. (Craig + Barkhouse) + +Win32 console version: +- Includes the user and system name in the ":version" message, when available. + It generates a pathdef.c file for this. (Jon Miner) +- Set the window icon to Vim's icon (only for Windows 2000). While executing + a shell command, modify the window title to show this. When exiting, + restore the cursor position too. (Craig Barkhouse) +- The Win32 console version can be compiled with OLE support. It can only + function as a client, not as an OLE server. + +Errorformat: +- Let "%p" in 'errorformat' (column of error indicated by a row of characters) + also accept a line of dots. +- Added "%v" item in 'errorformat': Virtual column number. (Dan Sharp) +- Added a default 'errorformat' value for VMS. (Jim Bush) + +The "p" command can now be used in Visual mode. It overwrites the selected +text with the contents of a register. + +Highlight the <> items in the intro message to make clear they are special. + +When using the "c" flag for ":substitute", allow typing "l" for replacing this +item and then stop: "last". + +When printing a verbose message about sourcing another file, print the line +number. + +When resizing the Vim window, don't use 'equalalways'. Avoids that making the +Vim window smaller makes split windows bigger. And it's what the docs say. + +When typing CTRL-D in Insert mode, just after an autoindent, then hitting CR +kept the remaining white space. Now made it work like BS: delete the +autoindent to avoid a blank non-empty line results. + +Added a GetHwnd() call to the OLE interface. (Vince Negri) + +Made ":normal" work in an event handler. Useful when dropping a file on Vim +and for CursorHold autocommands. + +For the MS-Windows version, don't change to the directory of the file when a +slash is used instead of a backslash. Explorer should always use a backslash, +the user can use a slash when typing the command. + +Timestamps: +- When a buffer was changed outside of Vim and regaining focus, give a dialog + to allow the user to reload the file. Now also for other GUIs than + MS-Windows. And also used in the console, when compiled with dialog + support. +- Inspect the file contents to find out if it really changed, ignore + situations where only the time stamp changed (e.g., checking the file out + from CVS). +- When checking the timestamp, first check if the file size changed, to avoid + a file compare then. Makes it quicker for large (log) files that are + appended to. +- Don't give a warning for a changed or deleted file when 'buftype' is set. +- No longer warn for a changed directory. This avoids that the file explorer + produces warnings. +- Checking timestamps is only done for buffers that are not hidden. These + will be checked when they become unhidden. +- When checking for a file being changed outside of Vim, also check if the + file permissions changed. When the file contents didn't change but the + permissions did, give a warning. +- Avoid checking too often, otherwise the dialog keeps popping up for a log + file that steadily grows. + +Mapping <M-A> when 'encoding' is "latin1" and then setting 'encoding' to +"utf-8" causes the first byte of a multi-byte to be mapped. Can cause very +hard to find problems. Disallow mapping part of a multi-byte character. + +For ":python" and ":tcl" accept an in-line script. (Johannes Zellner) +Also for ":ruby" and ":perl". (Benoit Cerrina) + +Made ":syn include" use 'runtimepath' when the file name is not a full path. + +When 'switchbuf' contains "split" and the current window is empty, don't split +the window. + +Unix: Catch SIGPWR to preserve files when the power is about to go down. + +Sniff interface: (Anton Leherbauer) +- fixed windows code, esp. the event handling stuff +- adaptations for sniff 4.x ($SNIFF_DIR4) +- support for adding sniff requests at runtime + +Support the notation <A-x> as an alias for <M-x>. This logical, since the Alt +key is used. + +":find" accepts a count, which means that the count'th match in 'path' is +used. + +":ls" and ":buffers" output shows modified/readonly/modifiable flag. When a +buffer is active show "a" instead of nothing. When a buffer isn't loaded +show nothing instead of "-". + +Unix install: +- When installing the tools, set absolute paths in tools scripts efm_perl.pl + and mve.awk. Avoids that the user has to edit these files. +- Install Icons for KDE when the directories exist and the icons do not exist + yet. + +Added has("win95"), to be able to distinguish between MS-Windows 95/98/ME and +NT/2000/XP in a Vim script. + +When a ":cd" command was typed, echo the new current directory. (Dan Sharp) + +When using ":winpos" before the GUI window has been opened, remember the +values until it is opened. + +In the ":version" output, add "/dyn" for features that are dynamically loaded. +This indicates the feature may not always work. + +On Windows NT it is possible that a directory is read-only, but a file can be +deleted. When making a backup by renaming the file and 'backupdir' doesn't +use the current directory, this causes the original file to be deleted, +without the possibility to create a new file. Give an extra error message +then to warn to user about this. + +Made CTRL-R CTRL-O at the command line work like CTRL-R CTRL-R, so that it's +consistent with Insert mode. + +============================================================================== +COMPILE TIME CHANGES *compile-changes-6* + +All generated files have been moved out of the "src" directory. This makes it +easy to see which files are not edited by hand. The files generated by +configure are now in the "src/auto" directory. For Unix, compiled object +files go in the objects directory. + +The source archive was over the 1.4M floppy limit. The archives are now split +up into two runtime and two source archives. Also provide a bzip2 compressed +archive that contains all the sources and runtime files. + +Added "reconfig" as a target for make. Useful when changing some of the +arguments that require flushing the cache, such as switching from GTK to +Motif. Adjusted the meaning of GUI_INC_LOC and GUI_LIB_LOC to be consistent +over different GUIs. + +Added src/README.txt to give an overview of the main parts of the source code. + +The Unix Makefile now fully supports using $(DESTDIR) to install to a specific +location. Replaces the manual setting of *ENDLOC variables. + +Added the possibility for a maintainer of a binary version to include his +e-mail address with the --with-compiledby configure argument. + +Included features are now grouped in "tiny", "small", "normal", "big" and +"huge". This replaces "min-features" and "max-features". Using "tiny" +disables multiple windows for a really small Vim. + +For the tiny version or when FEAT_WINDOWS is not defined: Firstwin and lastwin +are equal to curwin and don't use w_next and w_prev. + +Added the +listcmds feature. Can be used to compile without the Vim commands +that manipulate the buffer list and argument list (the buffer list itself is +still there, can't do without it). + +Added the +vreplace feature. It is disabled in the "small" version to avoid +that the 16 bit DOS version runs out of memory. + +Removed GTK+ support for versions older than 1.1.16. + +The configure checks for using PTYs have been improved. Code taken from a +recent version of screen. + +Added configure options to install Vim, Ex and View under another name (e.g., +vim6, ex6 and view6). + +Added "--with-global-runtime" configure argument. Allows specifying the +global directory used in the 'runtimepath' default. + +Made enabling the SNiFF+ interface possible with a configure argument. + +Configure now always checks /usr/local/lib for libraries and +/usr/local/include for include files. Helps finding the stuff for iconv() and +gettext(). + +Moved the command line history stuff into the +cmdline_hist feature, to +exclude the command line history from the tiny version. + +MS-Windows: Moved common functions from Win16 and Win32 to os_mswin.c. Avoids +having to change two files for one problem. (Vince Negri) + +Moved common code from gui_w16.c and gui_w32.c to gui_w48.c (Vince Negri) + +The jumplist is now a separate feature. It is disabled for the "small" +version (16 bit MS-DOS). + +Renamed all types ending in _t to end in _T. Avoids potential problems with +system types. + +Added a configure check for X11 header files that implicitly define the return +type to int. (Steve Wall) + +"make doslang" in the top directory makes an archive with the menu and .mo +files for Windows. This uses the files generated on Unix, these should work +on MS-Windows as well. + +Merged a large part of os_vms.c with os_unix.c. The code was duplicated in +the past which made maintenance more work. (Zoltan Arpadffy) + +Updated the Borland C version 5 Makefile: (Dan Sharp) +- Fixed the Perl build +- Added python and tcl builds +- Added dynamic perl and dynamic python builds +- Added uninstal.exe build +- Use "yes" and "no" for the options, like in Make_mvc.mak. + +Win32: Merged Make_gvc.mak and Make_ovc.mak into one file: Make_ivc.mak. It's +much smaller, many unnecessary text has been removed. (Walter Briscoe) +Added Make_dvc.mak to be able to debug exe generated with Make_mvc.mak in +MS-Devstudio. (Walter Briscoe) + +MS-Windows: The big gvim.exe, which includes OLE, now also includes +dynamically loaded Tcl, Perl and Python. This uses ActivePerl 5.6.1, +ActivePython 2.1.1 and ActiveTCL 8.3.3 + +Added AC_EXEEXT to configure.in, to check if the executable needs ".exe" for +Cygwin or MingW. Renamed SUFFIX to EXEEXT in Makefile. + +Win32: Load comdlg32.dll delayed for faster startup. Only when using VC 6. +(Vipin Aravind) + +Win32: When compiling with Borland, allow using IME. (Yasuhiro Matsumoto) + +Win32: Added Makefile for Borland 5 to compile gvimext.dll. (Yasuhiro +Matsumoto) + +============================================================================== +BUG FIXES *bug-fixes-6* + +When checking the command name for "gvim", "ex", etc. ignore case. Required +for systems where case is ignored in command names. + +Search pattern "[a-c-e]" also matched a 'd' and didn't match a '-'. + +When double-clicking in another window, wasn't recognized as double click, +because topline is different. Added set_mouse_topline(). + +The BROKEN_LOCALE check was broken. (Marcin Dalecki) + +When "t_Co" is set, the default colors remain the same, thus wrong. Reset the +colors after changing "t_Co". (Steve Wall) + +When exiting with ":wqall" the messages about writing files could overwrite +each other and be lost forever. + +When starting Vim with an extremely long file name (around 1024 characters) it +would crash. Added a few checks to avoid buffer overflows. + +CTRL-E could get stuck in a file with very long lines. + +":au syntax<Tab>" expanded event names while it should expand groups starting +with "syntax". + +When expanding a file name caused an error (e.g., for <amatch>) it was +produced even when inside an "if 0". + +'cindent' formatted C comments differently from what the 'comments' option +specified. (Steve Wall) + +Default for 'grepprg' didn't include the file name when only grepping in one +file. Now /dev/null has been added for Unix. + +Opening the option window twice caused trouble. Now the cursor goes to the +existing option window. + +":sview" and ":view" didn't set 'readonly' for an existing buffer. Now do set +'readonly', unless the buffer is also edited in another window. + +GTK GUI: When 'guioptions' excluded 'g', the more prompt caused the toolbar +and menubar to disappear and resize the window (which clears the text). +Now always grey-out the toplevel menus to avoid that the menubar changes size +or disappears. + +When re-using the current buffer for a new buffer, buffer-local variables were +not deleted. + +GUI: when 'scrolloff' is 0 dragging the mouse above the window didn't cause a +down scroll. Now pass on a mouse event with mouse_row set to -1. + +Win32: Console version didn't work on telnet, because of switching between two +console screens. Now use one console screen and save/restore the contents +when needed. (Craig Barkhouse) + +When reading a file the magic number for encryption was included in the file +length. (Antonio Colombo) + +The quickfix window contained leading whitespace and NULs for multi-line +messages. (David Harrison) + +When using cscope, redundant tags were removed. This caused a numbering +problem, because they were all listed. Don't remove redundant cscope tags. +(David Bustos). + +Cscope: Test for which matches are in the current buffer sometimes failed, +causing a jump to another match than selected. (David Bustos) + +Win32: Buffer overflow when adding a charset name in a font. + +'titlestring' and 'iconstring' were evaluating an expression in the current +context, which could be a user function, which is a problem for local +variables vs global variables. + +Win32 GUI: Mapping <M-F> didn't work. Now handle SHIFT and CTRL in +_OnSysChar(). + +Win32 GUI: (on no file), :vs<CR>:q<CR> left a trail of pixels down the middle. +Could also happen for the ruler. screen_puts() didn't clear the right char in +ScreenLines[] for the bold trick. + +Win32: ":%!sort|uniq" didn't work, because the input file name touches the +"|". Insert a space before the "|". + +OS/2: Expanding wildcards included non-existing files. Caused ":runtime" to +fail, which caused syntax highlighting to fail. + +Pasting a register containing CTRL-R on the command line could cause an +endless loop that can't be interrupted. Now it can be stopped with CTRL-C. + +When 'verbose' is set, a message for file read/write could overwrite the +previous message. +When 'verbose' is set, the header from ":select" was put after the last +message. Now start a new line. + +The hit-enter prompt reacted to the response of the t_RV string, causing +messages at startup to disappear. + +When t_Co was set to 1, colors were still used. Now only use color when t_Co +> 1. + +Listing functions with ":function" didn't quit when 'q' or ':' was typed at +the more prompt. + +Use mkstemp() instead of mktemp() when it's available, avoids a warning for +linking on FreeBSD. + +When doing Insert mode completion it's possible that b_sfname is NULL. Don't +give it to printf() for the "Scanning" message. + +":set runtimepath-=$VIMRUNTIME" didn't work, because expansion of wildcards +was done after trying to remove the string. Now for ":set opt+=val" and ":set +opt-=val" the expansion of wildcards is done before adding or removing "val". + +Using CTRL-V with the "r" command with a blockwise Visual selection inserted a +CTRL-V instead of getting a special character. + +Unix: Changed the order of libraries: Put -lXdmcp after -lX11 and -lSM -lICE +after -lXdmcp. Should fix link problem on HP-UX 10.20. + +Don't remove the last "-lm" from the link line. Vim may link but fail later +when the GUI starts. + +When the shell returns with an error when trying to expand wildcards, do +include the pattern when the "EW_NOTFOUND" flag was set. +When expanding wildcards with the shell fails, give a clear error message +instead of just "1 returned". + +Selecting a Visual block, with the start partly on a Tab, deleting it leaves +the cursor too far to the left. Causes "s" to work in the wrong position. + +Pound sign in normal.c caused trouble on some compilers. Use 0xA3 instead. + +Warning for changing a read-only file wasn't given when 'insertmode' was set. + +Win32: When 'shellxquote' is set to a double quote (e.g., using csh), ":!start +notepad file" doesn't work. Remove the double quotes added by 'shellxquote' +when using ":!start". (Pavol Juhas) + +The "<f-args>" argument of ":command" didn't accept Tabs for white space. +Also, don't add an empty argument when there are trailing blanks. + +":e test\\je" edited "test\je", but ":next test\\je" edited "testje". +Backslashes were removed one time too many for ":next". + +VMS: "gf" didn't work properly. Use vms_fixfilename() to translate the file +name. (Zoltan Arpadffy) + +After ":hi Normal ctermbg=black ctermfg=white" and suspending Vim not all +characters are redrawn with the right background. + +When doing "make test" without +eval or +windows feature, many tests failed. +Now have test1 generate a script to copy the correct output, so that a test +that doesn't work is skipped. + +On FreeBSD the Perl interface added "-lc" to the link command and Python added +"-pthread". These two don't work together, because the libc_r library should +be used. Removed "-lc" from Perl, it should not be needed. +Also: Add "-pthread" to $LIBS, so that the checks for functions is done with +libc_r. Sigaltstack() appears to be missing from libc_r. + +The Syntax sub-menus were getting too long, reorganized them and added another +level for some languages. + +Visual block "r"eplace didn't work well when a Tab is partly included. +(Matthias Kramm) + +When yanking a Visual block, where some lines end halfway the block, putting +the text somewhere else doesn't insert a block. Padd with spaces for missing +characters. Added "y_width" to struct yankreg. (Matthias Kramm) + +If a substitute string has a multibyte character after a backslash only the +first byte of it was skipped. (Muraoka Taro) + +Win32: Numeric keypad keys were missing from the builtin termcap entry. + +When a file was read-only ":wa!" didn't force it to be written. (Vince Negri) + +Amiga: A file name starting with a colon was considered absolute but it isn't. +Amiga: ":pwd" added a slash when in the root of a drive. + +Don't let 'ttymouse' default to "dec" when compiled with dec mouse support. +It breaks the gpm mouse (Linux console). + +The prototypes for the Perl interface didn't work for threaded Perl. Added a +sed command to remove the prototypes from proto/if_perl.pro and added them +manually to if_perl.xs. + +When ":w!" resets the 'readonly' option the title and status lines were not +updated. + +":args" showed the current file when the argument list was empty. Made this +work like Vi: display nothing. + +"99:<C-U>echo v:count" echoed "99" in Normal mode, but 0 in Visual mode. +Don't set v:count when executing a stuffed command. + +Amiga: Got a requester for "home:" because it's in the default runtime path. +Don't bring up a requester when searching for a file in 'path', sourcing the +.vimrc file or using ":runtime". + +Win16 and Win32: Considered a file "\path\file" absolute. Can cause the same +file to appear as two different buffers. + +Win32: Renaming a file to an empty string crashed Vim. Happened when using +explorer.vim and hitting ESC at the rename prompt. + +Win32: strftime() crashed when called with a "-1" value for the time. + +Win32 with Borland compiler: mch_FullName() didn't work, caused tag file not +to be found. + +Cscope sometimes jumped to the wrong tag. (David Bustos) + +OS/2: Could not find the tags file. mch_expand_wildcards() added another +slash to a directory name. + +When using ">>" the `] mark was not in the last column. + +When Vim was compiled without menu support, filetype.vim was still trying to +source the menu.vim script. (Rafael Garcia-Suarez) + +":ptag" added an item to the tag stack. + +Win32 IME: "gr" didn't use IME mode. + +In the "vim --help" message the term "options" was used for arguments. That's +confusing, call them "arguments". + +When there are two windows, and a BufUnload autocommand for closing window #1 +closed window #2, Vim would crash. + +When there is a preview window and only one other window, ":q" wouldn't exit. + +In Insert mode, when cancelling a digraph with ESC, the '?' wasn't removed. + +On Unix glob(".*") returned "." and "..", on Windows it didn't. On Windows +glob("*") also returned files starting with a dot. Made this work like Unix +on all systems. + +Win32: Removed old code to open a console. Vimrun is now used and works fine. + +Compute the room needed by the intro message accurately, so that it also fits +on a 25 line console. (Craig Barkhouse) + +":ptnext" was broken. Now remember the last tag used in the preview window +separately from the tagstack. + +Didn't check for "-display" being the last argument. (Wichert Akkerman) + +GTK GUI: When starting "gvim" under some conditions there would be an X error. +Don't replace the error handler when creating the xterm clipboard. (Wichert +Akkerman) + +Adding a space after a help tag caused the tag not to be found. E.g., ":he +autoindent ". + +Was trying to expand a URL into a full path name. On Windows this resulted in +the current directory to be prepended to the URL. Added vim_isAbsName() and +vim_FullName() to avoid that various machine specific functions do it +differently. + +":n *.c" ":cd .." ":n" didn't use the original directory of the file. Vi only +does it for the current file (looks like a bug). Now remember the buffer used +for the entry in the argument list and use it's name (adjusted when doing +":cd"), unless it's deleted. + +When inserting a special key as its name ("<F8>" as four characters) after +moving around in Insert mode, undo didn't work properly. + +Motif GUI: When using the right mouse button, for some people gvim froze for +a couple of seconds (Motif 1.2?). This doesn't happen when there is no Popup +menu. Solved by only creating a popup menu when 'mousemodel' is "popup" or +"popup_setpos". (David Harrison) + +Motif: When adding many menu items, the "Help" menu disappeared but the +menubar didn't wrap. Now manually set the menubar height. + +When using <BS> in Insert mode to remove a line break, or using "J" to join +lines, the cursor could end up halfway a multi-byte character. (Muraoka Taro) + +Removed defining SVR4 in configure. It causes problems for some X header +files and doesn't appear to be used anywhere. + +When 'wildignore' is used, 'ignorecase' for a tag match was not working. + +When 'wildignore' contains "*~" it was impossible to edit a file ending in a +"~". Now don't recognize a file ending in "~" as containing wildcards. + +Disabled the mouse code for OS/2. It was not really used. + +":mksession" always used the full path name for a buffer, also when the short +name could be used. +":mkvimrc" and ":mksession" didn't save 'wildchar' and 'pastetoggle' in such a +way that they would be restored. Now use the key name if possible, this is +portable. + +After recovering a file and abandoning it, an ":edit" command didn't give the +ATTENTION prompt again. Would be useful to be able to delete the file in an +easy way. Reset the BF_RECOVERED flag when unloading the buffer. + +histdel() could match or ignore case, depending on what happened before it. +Now always match case. + +When a window size was specified when splitting a window, it would still get +the size from 'winheight' or 'winwidth' if it's larger. + +When using "append" or "insert" inside a function definition, a line starting +with "function" or "endfunction" caused confusion. Now recognize the commands +and skip lines until a ".". + +At the end of any function or sourced file need_wait_return could be reset, +causing messages to disappear when redrawing. + +When in a while loop the line number for error messages stayed fixed. Now the +line number is remembered in the while loop. + +"cd c:/" didn't work on MS-DOS. mch_isdir() removed a trailing slash. + +MS-Windows: getftime() didn't work when a directory had a trailing slash or +backslash. Didn't show the time in the explorer because of this. + +When doing wildcard completion, a directory "a/" sorted after "a-b". Now +recognize path separators when sorting files. + +Non-Unix systems: When editing "c:/dir/../file" and "c:/file" they were +created as different buffers, although it's the same file. Expand to a full +file name also when an absolute name contains "..". + +"g&" didn't repeat the last substitute properly. + +When 'clipboard' was set to "unnamed", a "Y" command would not write to "0. +Now make a copy of register 0 to the clipboard register. + +When the search pattern matches in many ways, it could not always be +interrupted with a CTRL-C. And CTRL-C would have to be hit once for every +line when 'hlsearch' is on. +When 'incsearch' is on and interrupting the search for a match, don't abandon +the command line. + +When turning a directory name into a full path, e.g., with fnamemodify(), +sometimes a slash was added. Make this consistent: Don't add a slash. + +When a file name contains a "!", using it in a shell command will cause +trouble: ":!cat %". Escape the "!" to avoid that. Escape it another time +when 'shell' contains "sh". + +Completing a file name that has a tail that starts with a "~" didn't work: +":e view/~<Tab>". + +Using a ":command" argument that contains < and > but not for a special +argument was not skipped properly. + +The DOS install program: On Win2000 the check for a vim.exe or gvim.exe in +$PATH didn't work, it always found it in the current directory. +Rename the vim.exe in the current dir to avoid this. (Walter Briscoe) + +In the MS-DOS/Windows install program, use %VIM% instead of an absolute path, +so that moving Vim requires only one change in the batch file. + +Mac: mch_FullName() changed the "fname" argument and didn't always initialize +the buffer. + +MS-DOS: mch_FullName() didn't fix forward/backward slashes in an absolute file +name. + +"echo expand("%:p:h")" with an empty file name removed one directory name on +MS-DOS. For Unix, when the file name is a directory, the directory name was +removed. Now make it consistent: "%:p" adds a path separator for all systems, +but no path separator is added in other situations. + +Unix: When checking for a CTRL-C (could happen any time) and there is an X +event (e.g., clipboard updated) and there is typeahead, Vim would hang until a +character was typed. + +MS-DOS, MS-Windows and Amiga: expanding "$ENV/foo" when $ENV ends in a colon, +had the slash removed. + +":he \^=" gave an error for using \_. ":he ^=" didn't find tag :set^=. Even +"he :set^=" didn't find it. + +A tags file name "D:/tags" was used as file "tags" in "D:". That doesn't work +when the current path for D: isn't the root of the drive. + +Removed calls to XtInitializeWidgetClass(), they shouldn't be necessary. + +When using a dtterm or various other color terminals, and the Normal group has +been set to use a different background color, the background wouldn't always +be displayed with that color. Added check for "ut" termcap entry: If it's +missing, clearing the screen won't give us the current background color. Need +to draw each character instead. Vim now also works when the "cl" (clear +screen) termcap entry is missing. + +When repeating a "/" search command with a line offset, the "n" did use the +offset but didn't make the motion linewise. Made "d/pat/+2" and "dn" do the +same. + +Win32: Trying to use ":tearoff" for a menu that doesn't exist caused a crash. + +OpenPTY() didn't work on Sequent. Add a configure check for getpseudotty(). + +C-indenting: Indented a line starting with ")" with the matching "(", but not +a line starting with "x)" looks strange. Also compute the indent for aligning +with items inside the () and use the lowest indent. + +MS-DOS and Windows: ":n *.vim" also matched files ending in "~". +Moved mch_expandpath() from os_win16.c and os_msdos.c to misc1.c, they are +equal. + +Macintosh: (Dany St-Amant) +- In Vi-compatible mode didn't read files with CR line separators. +- Fixed a bug in the handling of Activate/Deactivate Event +- Fixed a bug in gui_mch_dialog (using wrong pointer) + +Multibyte GDK XIM: While composing a multibyte-word, if user presses a +mouse button, then the word is removed. It should remain and composing end. +(Sung-Hyun Nam) + +MS-DOS, MS-Windows and OS/2: When reading from stdin, automatic CR-LF +conversion by the C library got in the way of detecting a "dos" 'fileformat'. + +When 'smartcase' is set, patterns with "\S" would also make 'ignorecase' +reset. + +When clicking the mouse in a column larger than 222, it moved to the first +column. Can't encode a larger number in a character. Now limit the number to +222, don't jump back to the first column. + +GUI: In some versions CSI would cause trouble, either when typed directly or +when part of a multi-byte sequence. + +When using multibyte characters in a ":normal" command, a trailing byte that +is CSI or K_SPECIAL caused problems. + +Wildmenu didn't handle multi-byte characters. + +":sleep 10" could not be interrupted on Windows, while "gs" could. Made them +both work the same. + +Unix: When waiting for a character is interrupted by an X-windows event (e.g., +to obtain the contents of the selection), the wait time would not be honored. +A message could be overwritten quickly. Now compute the remaining waiting +time. + +Windows: Completing "\\share\c$\S" inserted a backslash before the $ and then +the name is invalid. Don't insert the backslash. + +When doing an auto-write before ":make", IObuff was overwritten and the wrong +text displayed later. + +On the Mac the directories "c:/tmp" and "c:/temp" were used in the defaults +for 'backupdir' and 'directory', they don't exist. + +The check for a new file not to be on an MS-DOS filesystem created the file +temporarily, which can be slow. Don't do this if there is another check for +the swap file being on an MS-DOS filesystem. + +Don't give the "Changing a readonly file" warning when reading from stdin. + +When using the "Save As" menu entry and not entering a file name, would get an +error message for the trailing ":edit #". Now only do that when the +alternate file name was changed. + +When Vim owns the X11 selection and is being suspended, an application that +tries to use the selection hangs. When Vim continues it could no longer +obtain the selection. Now give up the selection when suspending. + +option.h and globals.h were included in some files, while they were already +included in vim.h. Moved the definition of EXTERN to vim.h to avoid doing it +twice. + +When repeating an operator that used a search pattern and the search pattern +contained characters that have a special meaning on the cmdline (e.g., CTRL-U) +it didn't work. + +Fixed various problems with using K_SPECIAL (0x80) and CSI (0x9b) as a byte in +a (multibyte) character. For example, the "r" command could not be repeated. + +The DOS/Windows install program didn't always work from a directory with a +long filename, because $VIM and the executable name would not have the same +path. + +Multi-byte: +- Using an any-but character range [^x] in a regexp didn't work for UTF-8. + (Muraoka Taro) +- When backspacing over inserted characters in Replace mode multi-byte + characters were not handled correctly. (Muraoka Taro) +- Search commands "#" and "*" didn't work with multibyte characters. (Muraoka + Taro) +- Word completion in Insert mode didn't work with multibyte characters. + (Muraoka Taro) +- Athena/Motif GUI: when 'linespace' is non-zero the cursor would be drawn too + wide (number of bytes instead of cell width). +- When changing 'encoding' to "euc-jp" and inserting a character Vim would + crash. +- For euc-jp characters positioning the cursor would sometimes be wrong. + Also, with two characters with 0x8e leading byte only the first one would be + displayed. +- When using DYNAMIC_ICONV on Win32 conversion might fail because of using the + wrong error number. (Muraoka Taro) +- Using Alt-x in the GUI while 'encoding' was set to "utf-8" didn't produce + the right character. +- When using Visual block selection and only the left halve of a double-wide + character is selected, the highlighting continued to the end of the line. +- Visual-block delete didn't work properly when deleting the right halve of a + double-wide character. +- Overstrike mode for the cmdline replaced only the first byte of a multibyte + character. +- The cursor in Replace mode (also in the cmdline) was to small on a + double-wide character. +- When a multibyte character contained a 0x80 byte, it didn't work (was using + a CSI byte instead). (Muraoka Taro) +- Wordwise selection with the mouse didn't work. +- Yanking a modeless selection of multi-byte characters didn't work. +- When 'selection' is "exclusive", selecting a word that ends in a multi-byte + character used wrong highlighting for the following character. + +Win32 with Make_mvc.mak: Didn't compile for debugging. (Craig Barkhouse) + +Win32 GUI: When "vimrun.exe" is used to execute an external command, don't +give a message box with the return value, it was already printed by vimrun. +Also avoid printing the return value of the shell when ":silent!" is used. + +Win32: selecting a lot of text and using the "find/replace" dialog caused a +crash. + +X11 GUI: When typing a character with the 8th bit set and the Meta/Alt +modifier, the modifier was removed without changing the character. + +Truncating a message to make it fit on the command line, using "..." for the +middle, didn't always compute the space correctly. + +Could not imap <C-@>. Now it works like <Nul>. + +VMS: +- Fixed a few things for VAXC. os_vms_fix.com had some strange CTRL-M + characters. (Zoltan Arpadffy and John W. Hamill) +- Added VMS-specific defaults for the 'isfname' and 'isprint' options. + (Zoltan Arpadffy) +- Removed os_vms_osdef.h, it's no longer used. + +The gzip plugin used a ":normal" command, this doesn't work when dropping a +compressed file on Vim. + +In very rare situations a binary search for a tag would fail, because an +uninitialized value happens to be half the size of the tag file. (Narendran) + +When using BufEnter and BufLeave autocommands to enable/disable a menu, it +wasn't updated right away. + +When doing a replace with the "c"onfirm flag, the cursor was positioned after +the ruler, instead of after the question. With a long replacement string the +screen could scroll up and cause a "more" prompt. Now the message is +truncated to make it fit. + +Motif: The autoconf check for the Xp library didn't work. + +When 'verbose' is set to list lines of a sourced file, defining a function +would reset the counter used for the "more" prompt. + +In the Win32 find/replace dialog, a '/' character caused problems. Escape it +with a backslash. + +Starting a shell with ":sh" was different from starting a shell for CTRL-Z +when suspending doesn't work. They now work the same way. + +Jumping to a file mark while in a changed buffer gave a "mark not set" error. + +":execute histget("cmd")" causes an endless loop and crashed Vim. Now catch +all commands that cause too much recursiveness. + +Removed "Failed to open input method" error message, too many people got this +when they didn't want to use a XIM. + +GUI: When compiled without the +windows feature, the scrollbar would start +below line one. + +Removed the trick with redefining character class functions from regexp.c. + +Win32 GUI: Find dialog gives focus back to main window, when typing a +character mouse pointer is blanked, it didn't reappear when moving it in the +dialog window. (Vince Negri) + +When recording and typing a CTRL-C, no character was recorded. When in Insert +mode or cancelling half a command, playing back the recorded sequence wouldn't +work. Now record the CTRL-C. + +When the GUI was started, mouse codes for DEC and netterm were still checked +for. + +GUI: When scrolling and 'writedelay' is non-zero, the character under the +cursor was displayed in the wrong position (one line above/below with +CTRL-E/CTRL-Y). + +A ":normal" command would reset the 'scrollbind' info. Causes problems when +using a ":normal" command in an autocommand for opening a file. + +Windows GUI: a point size with a dot, like "7.5", wasn't recognized. (Muraoka +Taro) + +When 'scrollbind' wasn't set would still remember the current position, +wasting time. + +GTK: Crash when 'shell' doesn't exist and doing":!ls". Use _exit() instead of +exit() when the child couldn't execute the shell. + +Multi-byte: +- GUI with double-byte encoding: a mouse click in left halve of double-wide + character put the cursor in previous char. +- Using double-byte encoding and 'selection' is "exclusive": "vey" and "^Vey" + included the character after the word. +- When using a double-byte encoding and there is a lead byte at the end of the + line, the preceding line would be displayed. "ga" also showed wrong info. +- "gf" didn't include multi-byte characters before the cursor properly. + (Muraoka Taro) + +GUI: The cursor was sometimes not removed when scrolling. Changed the policy +from redrawing the cursor after each call to gui_write() to only update it at +the end of update_screen() or when setting the cursor position. Also only +update the scrollbars at the end of update_screen(), that's the only place +where the window text may have been scrolled. + +Formatting "/*<Tab>long text", produced "* <Tab>" in the next line. Now +remove the space before the Tab. +Formatting "/*<Tab> long text", produced "* <Tab> long text" in the next +line. Now keep the space after the Tab. + +In some places non-ASCII alphabetical characters were accepted, which could +cause problems. For example, ":X" (X being such a character). + +When a pattern matches the end of the line, the last character in the line was +highlighted for 'hlsearch'. That looks wrong for "/\%3c". Now highlight the +character just after the line. + +Motif: If a dialog was closed by clicking on the "X" of the window frame Vim +would no longer respond. + +When using CTRL-X or CTRL-A on a number with many leading zeros, Vim would +crash. (Matsumoto) + +When 'insertmode' is set, the mapping in mswin.vim for CTRL-V didn't work in +Select mode. Insert mode wasn't restarted after overwriting the text. +Now allow nesting Insert mode with insert and change commands. CTRL-O +cwfoo<Esc> now also works. + +Clicking with the right mouse button in another window started Visual mode, +but used the start position of the current window. Caused ml_get errors when +the line number was invalid. Now stay in the same window. + +When 'selection' is "exclusive", "gv" sometimes selected one character fewer. + +When 'comments' contains more than one start/middle/end triplet, the optional +flags could be mixed up. Also didn't align the end with the middle part. + +Double-right-click in Visual mode didn't update the shown mode. + +When the Normal group has a font name, it was never used when starting up. +Now use it when 'guifont' and 'guifontset' are empty. +Setting a font name to a highlight group before the GUI was started didn't +work. + +"make test" didn't use the name of the generated Vim executable. + +'cindent' problems: +- Aligned with an "else" inside a do-while loop for a line below that loop. + (Meikel Brandmeyer) +- A line before a function would be indented even when terminated with a + semicolon. (Meikel Brandmeyer) +- 'cindent' gave too much indent to a line after a "};" that ends an array + init. +- Support declaration lines ending in "," and "\". (Meikel Brandmeyer) +- A case statement inside a do-while loop was used for indenting a line after + the do-while loop. (Meikel Brandmeyer) +- When skipping a string in a line with one double quote it could continue in + the previous line. (Meikel Brandmeyer) + +When 'list' is set, 'hlsearch' didn't highlight a match at the end of the +line. Now highlight the '$'. + +The Paste menu item in the menu bar, the popup menu and the toolbar were all +different. Now made them all equal to how it was done in mswin.vim. + +st_dev can be smaller than "unsigned". The compiler may give an overflow +warning. Added a configure check for dev_t. + +Athena: closing a confirm() dialog killed Vim. + +Various typos in the documentation. (Matt Dunford) + +Python interface: The definition of _DEBUG could cause trouble, undefine it. +The error message for not being able to load the shared library wasn't +translated. (Muraoka Taro) + +Mac: (Dany St-Amant and Axel Kielhorn) +- Several fixes. +- Vim was eating 80% of the CPU time. +- The project os_mac.pbxproj didn't work, Moved it to a subdirectory. +- Made the menu priority work for the menubar. +- Fixed a problem with dragging the scrollbar. +- Cleaned up the various #ifdefs. + +Unix: When catching a deadly signal and we keep getting one use _exit() to +exit in a quick and dirty way. + +Athena menu ordering didn't work correctly. (David Harrison) + +A ":make" or ":grep" command with a long argument could cause a crash. + +Doing ":new file" and using "Quit" for the ATTENTION dialog still opened a new +window. + +GTK: When starting the GUI and there is an error in the .vimrc file, don't +present the wait-return prompt, since the message was given in the terminal. + +When there was an error in a .vimrc file the terminal where gvim was started +could be cleared. Set msg_row in main.c before writing any messages. + +GTK and X11 GUI: When trying to read characters from the user (e.g. with +input()) before the Vim window was opened caused Vim to hang when it was +started from the desktop. + +OS/390 uses 31 bit pointers. That broke some computations with MAX_COL. +Reduce MAX_COL by one bit for OS/390. (Ralf Schandl) + +When defining a function and it already exists, Vim didn't say it existed +until after typing it. Now do this right away when typing it. + +The message remembered for displaying later (keep_msg) was sometimes pointing +into a generic buffer, which might be changed by the time the message is +displayed. Now make a copy of the message. + +When using multi-byte characters in a menu and a trailing byte is a backslash, +the menu would not be created correctly. (Muraoka Taro) +Using a multibyte character in the substitute string where a trail byte is a +backslash didn't work. (Muraoka Taro) + +When setting "t_Co" in a vimrc file, then setting it automatically from an +xterm termresponse and then setting it again manually caused a crash. + +When getting the value of a string option that is not supported, the number +zero was returned. This breaks a check like "&enc == "asdf". Now an empty +string is returned for string options. + +Crashed when starting the GTK GUI while using 'notitle' in the vimrc, setting +'title' in the gvimrc and starting the GUI with ":gui". Closed the connection +to the X server accidentally. + +Had to hit return after selecting an entry for ":ts". + +The message from ":cn" message was sometimes cleared. Now display it after +redrawing if it doesn't cause a scroll (truncated when necessary). + +hangulin.c didn't compile when the GUI was disabled. Disable it when it won't +work. + +When setting a termcap option like "t_CO", the value could be displayed as +being for a normal key with a modifier, like "<M-=>". + +When expanding the argument list, entries which are a directory name did not +get included. This stopped "vim c:/" from opening the file explorer. + +":syn match sd "^" nextgroup=asdf" skipped the first column and matched the +nextgroup in the second column. + +GUI: When 'lazyredraw' is set, 'showmatch' didn't work. Required flushing +the output. + +Don't define the <NetMouse> termcode in an xterm, reduces the problem when +someone types <Esc> } in Insert mode. + +Made slash_adjust() work correctly for multi-byte characters. (Yasuhiro +Matsumoto) +Using a filename in Big5 encoding for autocommands didn't work (backslash in +trailbyte). (Yasuhiro Matsumoto) + +DOS and Windows: Expanding *.vim also matched file.vimfoo. Expand path like +Unix to avoid problems with Windows dir functions. Merged the DOS and Win32 +functions. + +Win32: Gvimext could not edit more than a few files at once, the length of the +argument was fixed. + +"ls -1 * | xargs vim" worked, but the input was in cooked mode. Now switch to +raw mode when needed. Use dup() to copy the stderr file descriptor to stdin +to make shell commands work. No longer requires an external program to do +this. + +When using ":filetype off", ftplugin and indent usage would be switched off at +the same time. Don't do this, setting 'filetype' manually can still use them. + +GUI: When writing a double-byte character, it could be split up in two calls +to gui_write(), which doesn't work. Now flush before the output buffer +becomes full. + +When 'laststatus' is set and 'cmdheight' is two or bigger, the intro message +would be written over the status line. +The ":intro" command didn't work when there wasn't enough room. + +Configuring for Ruby failed with a recent version of Ruby. (Akinori Musha) + +Athena: When deleting the directory in which Vim was started, using the file +browser made Vim exit. Removed the use of XtAppError(). + +When using autoconf 2.50, UNIX was not defined. Moved the comment for "#undef +UNIX" to a separate line. + +Win32: Disabled _OnWindowPosChanging() to make maximize work better. + +Win32: Compiling with VC 4.0 didn't work. (Walter Briscoe) + +Athena: +- Finally fixed the problems with deleting a menu. (David Harrison) +- Athena: When closing the confirm() dialog, worked like OK was pressed, + instead of Cancel. + +The file explorer didn't work in compatible mode, because of line +continuation. + +Didn't give an error message for ":digraph a". + +When using Ex mode in the GUI and typing a special key, <BS> didn't delete it +correctly. Now display '?' for a special key. + +When an operator is pending, clicking in another window made it apply to that +window, even though the line numbers could be beyond the end of the buffer. + +When a function call doesn't have a terminating ")" Vim could crash. + +Perl interface: could crash on exit with perl 5.6.1. (Anduin Withers) + +Using %P in 'errorformat' wasn't handled correctly. (Tomas Zellerin) + +Using a syntax cluster that includes itself made Vim crash. + +GUI: With 'ls' set to 2, dragging the status line all the way up, then making +the Vim window smaller: Could not the drag status line anymore. + +"vim -c startinsert! file" placed cursor on last char of a line, instead of +after it. A ":set" command in the buffer menu set w_set_curswant. Now don't +do this when w_curswant is MAXCOL. + +Win32: When the gvim window was maximized and selecting another font, the +window would no longer fill the screen. + +The line with 'pastetoggle' in ":options" didn't show the right value when it +is a special key. Hitting <CR> didn't work either. + +Formatting text, resulting in a % landing in the first line, repeated the % in +the following lines, like it's the start of a comment. + +GTK: When adding a toolbar item while gvim is already running, it wasn't +possible to use the tooltip. Now it works by adding the tooltip first. + +The output of "g CTRL-G" mentioned "Char" but it's actually bytes. + +Searching for the end of a oneline region didn't work correctly when there is +an offset for the highlighting. + +Syntax highlighting: When synchronizing on C-comments, //*/ was seen as the +start of a comment. + +Win32: Without scrollbars present, the MS mouse scroll wheel didn't work. +Also handle the scrollbars when they are not visible. + +Motif: When there is no right scrollbar, the bottom scrollbar would still +leave room for it. (Marcin Dalecki) + +When changing 'guicursor' and the value is invalid, some of the effects would +still take place. Now first check for errors and only make the new value +effective when it's OK. + +Using "A" In Visual block mode, appending to lines that don't extend into the +block, padding was wrong. + +When pasting a block of text, a character that occupies more than one screen +column could be deleted and spaces inserted instead. Now only do that with a +tab. + +Fixed conversion of documentation to HTML using Perl. (Dan Sharp) + +Give an error message when a menu name starts with a dot. + +Avoid a hang when executing a shell from the GUI on HP-UX by pushing "ptem" +even when sys/ptem.h isn't present. + +When creating the temp directory, make sure umask is 077, otherwise the +directory is not accessible when it was set to 0177. + +Unix: When resizing the window and a redraw is a bit slow, could get a window +resize event while redrawing, resulting in a messed up window. Any input +(e.g., a mouse click) would redraw. + +The "%B" item in the status line became zero in Insert mode (that's normal) +for another than the current window. + +The menu entries to convert to xxd and back didn't work in Insert mode. + +When ":vglobal" didn't find a line where the pattern doesn't match, the error +message would be the wrong way around. + +When ignoring a multi-line error message with "%-A", the continuation lines +would be used anyway. (Servatius Brandt) + +"grx" on a double-wide character inserted "x", instead of replacing the +character with "x ". "gR" on <xx> ('display' set the "uhex") didn't replace +at all. When doing "gRxx" on a control character the first "x" would be +inserted, breaking the alignment. + +Added "0)" to 'cinkeys', so that when typing a ) it is put in the same place +as where "==" would put it. + +Win32: When maximized, adding/removing toolbar didn't resize the text area. + +When using <C-RightMouse> a count was discarded. + +When typing CTRL-V and <RightMouse> in the command line, would insert +<LeftMouse>. + +Using "vis" or "vas" when 'selection' is exclusive didn't include the last +character. + +When adding to an option like 'grepprg', leading space would be lost. Don't +expand environment variables when there is no comma separating the items. + +GUI: When using a bold-italic font, would still use the bold trick and +underlining. + +Motif: The default button didn't work in dialogs, the first one was always +used. Had to give input focus to the default button. + +When using CTRL-T to jump within the same file, the '' mark wasn't set. + +Undo wasn't Vi compatible when using the 'c' flag for ":s". Now it undoes the +whole ":s" command instead of each confirmed replacement. + +The Buffers menu, when torn-off, disappeared when being refreshed. Add a +dummy item to avoid this. + +Removed calling msg_start() in main(), it should not be needed. + +vim_strpbrk() did not support multibyte characters. (Muraoka Taro) + +The Amiga version didn't compile, the code was too big for relative jumps. +Moved a few files from ex_docmd.c to ex_cmds2.c + +When evaluating the "= register resulted in the "= register being changed, Vim +would crash. + +When doing ":view file" and it fails, the current buffer was made read-only. + +Motif: For some people the separators in the toolbar disappeared when resizing +the Vim window. (Marcin Dalecki) + +Win32 GUI: when setting 'lines' to a huge number, would not compute the +available space correctly. Was counting the menu height twice. + +Conversion of the docs to HTML didn't handle the line with the +quickfix tag +correctly. (Antonio Colombo) + +Win32: fname_case() didn't handle multi-byte characters correctly. (Yasuhiro +Matsumoto) + +The Cygwin version had trouble with fchdir(). Don't use that function for +Cygwin. + +The generic check in scripts.vim for "conf" syntax was done before some checks +in filetype.vim, resulting in "conf" syntax too often. + +Dos32: Typing lagged behind. Would wait for one biostick when checking if a +character is available. + +GTK: When setting 'columns' while starting up "gvim", would set the width of +the terminal it was started in. + +When using ESC in Insert mode, an autoindent that wraps to the next line +caused the cursor to move to the end of the line temporarily. When the +character before the cursor was a double-wide multi-byte character the cursor +would be on the right halve, which causes problems with some terminals. + +Didn't handle multi-byte characters correctly when expanding a file name. +(Yasuhiro Matsumoto) + +Win32 GUI: Errors generated before the GUI is decided to start were not +reported. + +globpath() didn't reserve enough room for concatenated results. (Anduin +Withers) + +When expanding an option that is very long already, don't do the expansion, it +would be truncated to MAXPATHL. (Anduin Withers) + +When 'selection' is "exclusive", using "Fx" in Visual mode only moved until +just after the character. + +When using IME on the console to enter a file name, the screen may scroll up. +Redraw the screen then. (Yasuhiro Matsumoto) + +Motif: In the find/replace dialog the "Replace" button didn't work first time, +second time it replaced all matches. Removed the use of ":s///c". +GTK: Similar problems with the find/replace dialog, moved the code to a common +function. + +X11: Use shared GC's for text. (Marcin Dalecki) + +"]i" found the match under the cursor, instead of the first one below it. +Same for "]I", "] CTRL-I", "]d", "]D" and "] CTRL-D". + +Win16: When maximized and the font is changed, don't change the window size. +(Vince Negri) + +When 'lbr' is set, deleting a block of text could leave the cursor in the +wrong position. + +Win32: When opening a file with the "Edit with Vim" popup menu entry, +wildcards would cause trouble. Added the "--literal" argument to avoid +expanding file names. + +When using "gv", it didn't restore that "$" was used in Visual block mode. + +Win32 GUI: While waiting for a shell command to finish, the window wasn't +redrawn at all. (Yasuhiro Matsumoto) + +Syntax highlighting: A match that continues on a next line because of a +contained region didn't end when that region ended. + +The ":s" command didn't allow flags like 'e' and 'i' right after it. + +When using ":s" to split a line, marks were moved to the next line. Vi keeps +them in the first line. + +When using ":n" ":rew", the previous context mark was at the top of the file, +while Vi puts it in the same place as the cursor. Made it Vi compatible. + +Fixed Vi incompatibility: Text was not put in register 1 when using "c" and +"d" with a motion character, when deleting within one line with one of the +commands: % ( ) `<character> / ? N n { } + +Win32 GUI: The tooltip for tear-off items remained when the tear-off item was +no longer selected. + +GUI: When typing ":" at the more prompt, would return to Normal mode and not +redraw the screen. + +When starting Vim with an argument "-c g/at/p" the printed lines would +overwrite each other. + +BeOS: Didn't compile. Configure didn't add the os_beos files, the QNX check +removed them. Various changes to os_beos.cc. (Joshua Haberman) +Removed the check for the hardware platform, the BeBox has not been produced +for a long time now. + +Win32 GUI: don't use a message box when the shell returns an error code, +display the message in the Vim window. + +Make_mvc.mak always included "/debug" for linking. "GUI=no" argument didn't +work. Use "DEBUG=yes" instead of "DEBUG=1" to make it consistent. (Dan Sharp) + +When a line in the tags file ended in ;" (no TAB following) the command would +not be recognized as a search command. + +X11: The inputMethod resource never worked. Don't use the "none" input method +for SGI, it apparently makes the first character in Input method dropped. + +Fixed incorrect tests in os_mac.h. (Axel Kielhorn) + +Win32 console: When the console where Vim runs in is closed, Vim could hang in +trying to restore the window icon. (Yasuhiro Matsumoto) + +When using ":3call func()" or ":3,3call func() the line number was ignored. + +When 'showbreak' and 'linebreak' were both set, Visual highlighting sometimes +continued until the end of the line. + +GTK GUI: Tearoff items were added even when 'guioptions' didn't contain 't' +when starting up. + +MS-Windows: When the current directory includes a "~", searching files with +"gf" or ":find" didn't work. A "$" in the directory had the same problem. +Added mch_has_exp_wildcard() functions. + +When reducing the Vim window height while starting up, would get an +out-of-memory error message. + +When editing a very long search pattern, 'incsearch' caused the redraw of the +command line to fail. + +Motif GUI: On some systems the "Help" menu would not be on the far right, as +it should be. On some other systems (esp. IRIX) the command line would not +completely show. Solution is to only resize the menubar for Lesstif. + +Using "%" in a line that contains "\\" twice didn't take care of the quotes +properly. Now make a difference between \" and \\". + +For non-Unix systems a dummy file is created when finding a swap name to +detect a 8.3 filesystem. When there is an existing swap file, would get a +warning for the file being created outside of Vim. Also, when closing the Vim +window the file would remain. + +Motif: The menu height was always computed, using a "-menuheight" argument +was setting the room for the command line. Now make clear the argument is not +supported. + +For some (EBCDIC) systems, POUND was equal to '#'. Added an #if for that to +avoid a duplicate case in a switch. + +The GUI may have problems when forking. Always call _exit() instead of exit() +in the parent, the child will call exit(). + +Win32 GUI: Accented characters were often wrong in dialogs and tearoff menus. +Now use CP_ACP instead of CP_OEMCP. (Vince Negri) + +When displaying text with syntax highlighting causes an error (e.g., running +out of stack) the syntax highlighting is disabled to avoid further messages. + +When a command in a .vimrc or .gvimrc causes an ATTENTION prompt, and Vim was +started from the desktop (no place to display messages) it would hang. Now +open the GUI window early to be able to display the messages and pop up the +dialog. + +"r<CR>" on a multi-byte character deleted only the first byte of the +character. "3r<CR>" deleted three bytes instead of three characters. + +When interrupting reading a file, Vi considers the buffer modified. Added the +'i' flag in 'cpoptions' flag for this (we don't want it modified to be able to +do ":q"). + +When using an item in 'guicursor' that starts with a colon, Vim would get +stuck or crash. + +When putting a file mark in a help file and later jumping back to it, the +options would not be set. Extended the modeline in all help files to make +this work better. + +When a modeline contained "::" the local option values would be printed. Now +ignore it. + +Some help files did not use a 8.3 names, which causes problems when using +MS-DOS unzip. Renamed "multibyte.txt" to "mbyte.txt", "rightleft.txt" to +"rileft.txt", "tagsearch.txt" to "tagsrch.txt", "os_riscos.txt" to +"os_risc.txt". + +When Visual mode is blockwise, using "iw" or "aw" made it characterwise. That +doesn't seem right, only do this when in linewise mode. But then do it +always, not only when start and end of Visual mode are equal. + +When using "viw" on a single-letter word and 'selection' is exclusive, would +not include the word. + +When formatting text from Insert mode, using CTRL-O, could mess up undo +information. + +While writing a file (also for the backup file) there was no check for an +interrupt (hitting CTRL-C). Vim could hang when writing a large file over a +slow network, and moving the mouse didn't make it appear (when 'mousehide' is +set) and the screen wasn't updated in the GUI. Also allow interrupting when +syncing the swap file, it can take a long time. + +When using ":mksession" while there is help window, it would later be restored +to the right file but not marked as a help buffer. ":help" would then open +another window. Now use the value "help" for 'buftype' to mark a help buffer. + +The session file contained absolute path names in option values, that doesn't +work when the home directory depends on the situation. Replace the home +directory with ~/ when possible. + +When using 'showbreak' a TAB just after the shown break would not be counted +correctly, the cursor would be positioned wrong. + +With 'showbreak' set to "--->" or "------->" and 'sts' set to 4, inserting +tabs did not work right. Could cause a crash. Backspacing was also wrong, +could get stuck at a line break. + +Win32: crashed when tearing off a menu with over 300 items. + +GUI: A menu or toolbar item would appear when only a tooltip was defined for +it. + +When 'scrolloff' is non-zero and "$" is in 'cpoptions', using "s" while the +last line of the file is the first line on screen, the text wasn't displayed. + +When running "autoconf", delete the configure cache to force starting cleanly +when configure is run again. + +When changing the Normal colors for cterm, the value of 'background' was +changed even when the GUI was used. + +The warning for a missing vimrun.exe was always given on startup, but some +people just editing a file don't need to be bothered by it. Only show it when +vimrun would be used. + +When using "%" in a multibyte text it could get confused by trailbytes that +match. (Muraoka Taro) + +Termcap entry for RiscOS was wrong, using 7 and 8 in octal codes. + +Athena: The title of a dialog window and the file selector window were not +set. (David Harrison) + +The "htmlLink" highlight group specified colors, which gives problems when +using a color scheme. Added the "Underlined" highlight group for this. + +After using ":insert" or ":change" the '[ mark would be one line too low. + +When looking for the file name after a match with 'include' one character was +skipped. Same for 'define'. + +Win32 and DJGPP: When editing a file with a short name in a directory, and +editing the same file but using the long name, would end up with two buffers +on the same file. + +"gf" on a filename that starts with "../" only worked when the file being +edited is in the current directory. An include file search didn't work +properly for files starting with "../" or ".". Now search both relative to +the file and to the current directory. + +When 'printheader', 'titlestring', 'iconstring', 'rulerformat' or 'statusline' +contained "%{" but no following "}" memory was corrupted and a crash could +happen. + +":0append" and then inserting two lines did not redraw the blank lines that +were scrolled back down. + +When using insert mode completion in a narrow window, the message caused a +scroll up. Now shorten the message if it doesn't fit and avoid writing the +ruler over the message. + +XIM still didn't work correctly on some systems, especially SGI/IRIX. Added +the 'imdisable' option, which is set by default for that system. + +Patch 6.0aw.008 +Problem: When the first character of a file name is over 127, the Buffers + menu entry would get a negative priority and cause problems. +Solution: Reduce the multiplier for the first character when computing + the hash value for a Buffers menu entry. +Files: runtime/menu.vim + +Patch 6.0aw.010 +Problem: Win32: ":browse edit dir/dir" didn't work. (Vikas) +Solution: Change slashes to backslashes in the directory passed to the file + browser. +Files: src/gui_w48.c + +Athena file browser: On some systems wcstombs() can't be used to get the +length of a multi-byte string. Use the maximum length then. (Yasuhiro +Matsumoto) + +Patch 6.0ax.001 +Problem: When 'patchmode' is set, appending to a file gives an empty + original file. (Ed Ralston) +Solution: Also make a backup copy when appending and 'patchmode' is set. +Files: src/fileio.c + +Patch 6.0ax.002 +Problem: When 'patchmode' is set, appending to a compressed file gives an + uncompressed original file. (Ed Ralston) +Solution: Create the original file before decompressing. +Files: runtime/plugin/gzip.vim + +Patch 6.0ax.005 +Problem: Athena file selector keeps the title of the first invocation. +Solution: Set the title each time the file selector is opened. (David + Harrison) +Files: src/gui_at_fs.c + +Patch 6.0ax.007 +Problem: When using GPM (mouse driver in a Linux console) a double click is + interpreted as a scroll wheel click. +Solution: Check if GPM is being used when deciding if a mouse event is for + the scroll wheel. +Files: src/term.c + +Patch 6.0ax.010 +Problem: The Edit.Save menu and the Save toolbar button didn't work when + the buffer has no file name. +Solution: Use a file browser to ask for a file name. Also fix the toolbar + Find item in Visual mode. +Files: runtime/menu.vim + +Patch 6.0ax.012 +Problem: When 'cpoptions' contains "$", breaking a line for 'textwidth' + doesn't redraw properly. (Stefan Schulze) +Solution: Remove the dollar before breaking the line. +Files: src/edit.c + +Patch 6.0ax.014 +Problem: Win32: On Windows 98 ":make -f file" doesn't work when 'shell' is + "command.com" and 'makeprg' is "nmake". The environment isn't + passed on to "nmake". +Solution: Also use vimrun.exe when redirecting the output of a command. +Files: src/os_win32.c + +Patch 6.0ax.016 +Problem: The version number was reported wrong in the intro screen. +Solution: Check for a version number with two additional letters. +Files: src/version.c + +Patch 6.0ax.019 +Problem: When scrolling a window with folds upwards, switching to another + vertically split window and back may not update the scrollbar. +Solution: Limit w_botline to the number of lines in the buffer plus one. +Files: src/move.c + + +============================================================================== +VERSION 6.1 *version-6.1* + +This section is about improvements made between version 6.0 and 6.1. + +This is a bug-fix release, there are not really any new features. + + +Changed *changed-6.1* +------- + +'iminsert' and 'imsearch' are no longer set as a side effect of defining a +language-mapping using ":lmap". + + +Added *added-6.1* +----- + +Syntax files: +ampl AMPL (David Krief) +ant Ant (Johannes Zellner) +baan Baan (Her van de Vliert) +cs C# (Johannes Zellner) +lifelines Lifelines (Patrick Texier) +lscript LotusScript (Taryn East) +moo MOO (Timo Frenay) +nsis NSIS (Alex Jakushev) +ppd Postscript Printer Description (Bjoern Jacke) +rpl RPL/2 (Joel Bertrand) +scilab Scilab (Benoit Hamelin) +splint Splint (Ralf Wildenhues) +sqlj SQLJ (Andreas Fischbach) +wvdial WvDial (Prahlad Vaidyanathan) +xf86conf XFree86 config (Nikolai Weibull) +xmodmap Xmodmap (Nikolai Weibull) +xslt Xslt (Johannes Zellner) +monk Monk (Mike Litherland) +xsd Xsd (Johannes Zellner) +cdl CDL (Raul Segura Acevedo) +sendpr Send-pr (Hendrik Scholz) + +Added indent file for Scheme. (Dorai Sitaram) +Added indent file for Prolog. (Kontra Gergely) +Added indent file for Povray (David Necas) +Added indent file for IDL (Aleksandar Jelenak) +Added C# indent and ftplugin scripts. + +Added Ukrainian menu translations. (Bohdan Vlasyuk) +Added ASCII version of the Czech menus. (Jiri Brezina) + +Added Simplified Chinese translation of the tutor. (Mendel L Chan) + +Added Russian keymap for yawerty keyboard. + +Added an explanation of using the vimrc file in the tutor. +Changed tutor.vim to get the right encoding for the Taiwainese tutor. + +Added Russian tutor. (Andrey Kiselev) +Added Polish tutor. (Mikolaj Machowski) + +Added darkblue color scheme. (Bohdan Vlasyuk) + +When packing the dos language archive automatically generate the .mo files +that are required. + +Improved NSIS script to support NSIS 180. Added icons for the +enabled/disabled status. (Mirek Pruchnik) + +cp1250 version of the Slovak message translations. + +Compiler plugins for IRIX compilers. (David Harrison) + + +Fixed *fixed-6.1* +----- + +The license text was updated to make the meaning clearer and make it +compatible with the GNU GPL. Otherwise distributors have a problem when +linking Vim with a GPL'ed library. + +When installing the "less.sh" script it was not made executable. (Chuck Berg) + +Win32: The "9" key on the numpad wasn't working. (Julian Kinraid) + +The NSIS install script didn't work with NSIS 1.80 or later. Also add +Vim-specific icons. (Pruchnik) + +The script for conversion to HTML contained an "if" in the wrong place. +(Michael Geddes) + +Allow using ":ascii" in the sandbox, it's harmless. + +Removed creat() from osdef2.h.in, it wasn't used and may cause a problem when +it's redefined to creat64(). + +The text files in the VisVim directory were in "dos" format. This caused +problems when applying a patch. Now keep them in "unix" format and convert +them to "dos" format only for the PC archives. + +Add ruby files to the dos source archive, they can be used by Make_mvc.mak. +(Mirek Pruchnik) + +"cp -f" doesn't work on all systems. Change "cp -f" in the Makefile to "rm +-f" and "cp". + +Didn't compile on a Compaq Tandem Himalaya OSS. (Michael A. Benzinger) + +The GTK file selection dialog didn't include the "Create Dir", "Delete File" +and "Rename File" buttons. + +When doing ":browse source" the dialog has the title "Run Macro". Better +would be "Source Vim script". (Yegappan Lakshmanan) + +Win32: Don't use the printer font as default for the font dialog. + +"make doslang" didn't work when configure didn't run (yet). Set $MAKEMO to +"yes". (Mirek Pruchnik) + +The ToolBar TagJump item used "g]", which prompts for a selection even when +there is only one matching tag. Use "g<C-]>" instead. + +The ming makefile for message translations didn't have the right list of +files. + +The MS-Windows 3.1 version complains about LIBINTL.DLL not found. Compile +this version without message translations. + +The Borland 5 makefile contained a check for Ruby which is no longer needed. +The URLs for the TCL library was outdated. (Dan Sharp) + +The eviso.ps file was missing from the DOS runtime archive, it's needed for +printing PostScript in the 32bit DOS version. + +In menu files ":scriptencoding" was used in a wrong way after patch 6.1a.032 +Now use ":scriptencoding" in the file where the translations are given. Do +the same for all menus in latin1 encoding. + +Included a lot of fixes for the Macintosh, mostly to make it work with Carbon. +(Dany StAmant, Axel Kielhorn, Benji Fisher) + +Improved the vimtutor shell script to use $TMPDIR when it exists, and delete +the copied file when exiting in an abnormal way. (Max Ischenko) + +When "iconv.dll" can't be found, try using "libiconv.dll". + +When encryption is used, filtering with a shell command wasn't possible. + +DJGPP: ":cd c:" always failed, can't get permissions for "c:". +Win32: ":cd c:/" failed if the previous current directory on c: had become +invalid. + +DJGPP: Shift-Del and Del both produce \316\123. Default mapping for Del is +wrong. Disabled it. + +Dependencies on header files in MingW makefile was wrong. + +Win32: Don't use ACL stuff for MSVC 4.2, it's not supported. (Walter Briscoe) + +Win32 with Borland: bcc.cfg was caching the value for $(BOR), but providing a +different argument to make didn't regenerate it. + +Win32 with MSVC: Make_ivc.mak generates a new if_ole.h in a different +directory, the if_ole.h in the src directory may be used instead. Delete the +distributed file. + +When a window is vertically split and then ":ball" is used, the window layout +is messed up, can cause a crash. (Muraoka Taro) + +When 'insertmode' is set, using File/New menu and then double clicking, "i" is +soon inserted. (Merlin Hansen) + +When Select mode is active and using the Buffers menu to switch to another +buffer, an old selection comes back. Reset VIsual_reselect for a ":buffer" +command. + +When Select mode is active and 'insertmode' is set, using the Buffers menu to +switch to another buffer, did not return to Insert mode. Make sure +"restart_edit" is set. + +When double clicking on the first character of a word while 'selection' is +"exclusive" didn't select that word. + + +Patch 6.0.001 +Problem: Loading the sh.vim syntax file causes error messages . (Corinna + Vinschen) +Solution: Add an "if". (Charles Campbell) +Files: runtime/syntax/sh.vim + +Patch 6.0.002 +Problem: Using a '@' item in 'viminfo' doesn't work. (Marko Leipert) +Solution: Add '@' to the list of accepted items. +Files: src/option.c + +Patch 6.0.003 +Problem: The configure check for ACLs on AIX doesn't work. +Solution: Fix the test program so that it compiles. (Tomas Ogren) +Files: src/configure.in, src/auto/configure + +Patch 6.0.004 +Problem: The find/replace dialog doesn't reuse a previous argument + properly. +Solution: After removing a "\V" terminate the string. (Zwane Mwaikambo) +Files: src/gui.c + +Patch 6.0.005 +Problem: In Insert mode, "CTRL-O :ls" has a delay before redrawing. +Solution: Don't delay just after wait_return() was called. Added the + did_wait_return flag. +Files: src/globals.h, src/message.c, src/normal.c, src/screen.c + +Patch 6.0.006 +Problem: With a vertical split, 'number' set and 'scrolloff' non-zero, + making the window width very small causes a crash. (Niklas + Lindstrom) +Solution: Check for a zero width. +Files: src/move.c + +Patch 6.0.007 +Problem: When setting 'filetype' while there is no FileType autocommand, a + following ":setfiletype" would set 'filetype' again. (Kobus + Retief) +Solution: Set did_filetype always when 'filetype' has been set. +Files: src/option.c + +Patch 6.0.008 +Problem: 'imdisable' is missing from the options window. (Michael Naumann) +Solution: Add an entry for it. +Files: runtime/optwin.vim + +Patch 6.0.009 +Problem: Nextstep doesn't have S_ISBLK. (John Beppu) +Solution: Define S_ISBLK using S_IFBLK. +Files: src/os_unix.h + +Patch 6.0.010 +Problem: Using "gf" on a file name starting with "./" or "../" in a buffer + without a name causes a crash. (Roy Lewis) +Solution: Check for a NULL file name. +Files: src/misc2.c + +Patch 6.0.011 +Problem: Python: After replacing or deleting lines get an ml_get error. + (Leo Lipelis) +Solution: Adjust the cursor position for deleted or added lines. +Files: src/if_python.c + +Patch 6.0.012 +Problem: Polish translations contain printf format errors, this can result + in a crash when using one of them. +Solution: Fix for translated messages. (Michal Politowski) +Files: src/po/pl.po + +Patch 6.0.013 +Problem: Using ":silent! cmd" still gives some error messages, like for an + invalid range. (Salman Halim) +Solution: Reset emsg_silent after calling emsg() in do_one_cmd(). +Files: src/ex_docmd.c + +Patch 6.0.014 +Problem: When 'modifiable' is off and 'virtualedit' is "all", "rx" on a TAB + still changes the buffer. (Muraoka Taro) +Solution: Check if saving the line for undo fails. +Files: src/normal.c + +Patch 6.0.015 +Problem: When 'cpoptions' includes "S" and "filetype plugin on" has been + used, can get an error for deleting the b:did_ftplugin variable. + (Ralph Henderson) +Solution: Only delete the variable when it exists. +Files: runtime/ftplugin.vim + +Patch 6.0.016 +Problem: bufnr(), bufname() and bufwinnr() don't find unlisted buffers when + the argument is a string. (Hari Krishna Dara) + Also for setbufvar() and getbufvar(). +Solution: Also find unlisted buffers. +Files: src/eval.c + +Patch 6.0.017 +Problem: When 'ttybuiltin' is set and a builtin termcap entry defines t_Co + and the external one doesn't, it gets reset to empty. (David + Harrison) +Solution: Only set t_Co when it wasn't set yet. +Files: src/term.c + +Patch 6.0.018 +Problem: Initializing 'encoding' may cause a crash when setlocale() is not + used. (Dany St-Amant) +Solution: Check for a NULL pointer. +Files: src/mbyte.c + +Patch 6.0.019 +Problem: Converting a string with multi-byte characters to a printable + string, e.g., with strtrans(), may cause a crash. (Tomas Zellerin) +Solution: Correctly compute the length of the result in transstr(). +Files: src/charset.c + +Patch 6.0.020 +Problem: When obtaining the value of a global variable internally, could + get the function-local value instead. Applies to using <Leader> + and <LocalLeader> and resetting highlighting in a function. +Solution: Prepend "g:" to the variable name. (Aric Blumer) +Files: src/syntax.c, src/term.c + +Patch 6.0.021 +Problem: The 'cscopepathcomp' option didn't work. +Solution: Change USE_CSCOPE to FEAT_CSCOPE. (Mark Feng) +Files: src/option.c + +Patch 6.0.022 +Problem: When using the 'langmap' option, the second character of a command + starting with "g" isn't adjusted. +Solution: Apply 'langmap' to the second character. (Alex Kapranoff) +Files: src/normal.c + +Patch 6.0.023 +Problem: Loading the lhaskell syntax doesn't work. (Thore B. Karlsen) +Solution: Use ":runtime" instead of "source" to load haskell.vim. +Files: runtime/syntax/lhaskell.vim + +Patch 6.0.024 +Problem: Using "CTRL-V u 9900" in Insert mode may cause a crash. (Noah + Levitt) +Solution: Don't insert a NUL byte in the text, use a newline. +Files: src/misc1.c + +Patch 6.0.025 +Problem: The pattern "\vx(.|$)" doesn't match "x" at the end of a line. + (Preben Peppe Guldberg) +Solution: Always see a "$" as end-of-line after "\v". Do the same for "^". +Files: src/regexp.c + +Patch 6.0.026 +Problem: GTK: When using arrow keys to navigate through the menus, the + separators are selected. +Solution: Set the separators "insensitive". (Pavel Kankovsky) +Files: src/gui_gtk.c, src/gui_gtk_x11.c + +Patch 6.0.027 +Problem: VMS: Printing doesn't work, the file is deleted too quickly. + No longer need the VMS specific printing menu. + gethostname() is not available with VAXC. + The makefile was lacking selection of the tiny-huge feature set. +Solution: Adjust the 'printexpr' option default. Fix the other problems and + update the documentation. (Zoltan Arpadffy) +Files: runtime/doc/os_vms.txt, runtime/menu.vim, src/INSTALLvms.txt, + src/Make_vms.mms, src/option.c, src/os_unix.c, src/os_vms_conf.h + +Patch 6.0.028 +Problem: Can't compile without +virtualedit and with +visualextra. (Geza + Lakner) +Solution: Add an #ifdef for +virtualedit. +Files: src/ops.c + +Patch 6.0.029 +Problem: When making a change in line 1, then in line 2 and then deleting + line 1, undo info could be wrong. Only when the changes are undone + at once. (Gerhard Hochholzer) +Solution: When not saving a line for undo because it was already done + before, remember for which entry the last line must be computed. + Added ue_getbot_entry pointer for this. When the number of lines + changes, adjust the position of newer undo entries. +Files: src/structs.h, src/undo.c + +Patch 6.0.030 +Problem: Using ":source! file" doesn't work inside a loop or after + ":argdo". (Pavol Juhas) +Solution: Execute the commands in the file right away, do not let the main + loop do it. +Files: src/ex_cmds2.c, src/ex_docmd.c, src/getchar.c, src/globals.h, + src/proto/ex_docmd.pro, src/proto/getchar.pro + +Patch 6.0.031 +Problem: Nextstep doesn't have setenv() or putenv(). (John Beppu) +Solution: Move putenv() from pty.c to misc2.c +Files: src/misc2.c, src/pty.c + +Patch 6.0.032 +Problem: When changing a setting that affects all folds, they are not + displayed immediately. +Solution: Set the redraw flag in foldUpdateAll(). +Files: src/fold.c + +Patch 6.0.033 +Problem: Using 'wildmenu' on MS-Windows, file names that include a space + are only displayed starting with that space. (Xie Yuheng) +Solution: Don't recognize a backslash before a space as a path separator. +Files: src/screen.c + +Patch 6.0.034 +Problem: Calling searchpair() with three arguments could result in a crash + or strange error message. (Kalle Bjorklid) +Solution: Don't use the fifth argument when there is no fourth argument. +Files: src/eval.c + +Patch 6.0.035 +Problem: The menu item Edit/Global_Settings/Toggle_Toolbar doesn't work + when 'ignorecase' is set. (Allen Castaban) +Solution: Always match case when checking if a flag is already present in + 'guioptions'. +Files: runtime/menu.vim + +Patch 6.0.036 +Problem: OS/2, MS-DOS and MS-Windows: Using a path that starts with a + slash in 'tags' doesn't work as expected. (Mathias Koehrer) +Solution: Only use the drive, not the whole path to the current directory. + Also make it work for "c:dir/file". +Files: src/misc2.c + +Patch 6.0.037 +Problem: When the user has set "did_install_syntax_menu" to avoid the + default Syntax menu it still appears. (Virgilio) +Solution: Don't add the three default items when "did_install_syntax_menu" + is set. +Files: runtime/menu.vim + +Patch 6.0.038 +Problem: When 'selection' is "exclusive", deleting a block of text at the + end of a line can leave the cursor beyond the end of the line. +Solution: Correct the cursor position. +Files: src/ops.c + +Patch 6.0.039 +Problem: "gP" leaves the cursor in the wrong position when 'virtualedit' is + used. Using "c" in blockwise Visual mode leaves the cursor in a + strange position. +Solution: For "gP" reset the "coladd" field for the '] mark. For "c" leave + the cursor on the last inserted character. +Files: src/ops.c + +Patch 6.0.040 +Problem: When 'fileencoding' is invalid and writing fails because of + this, the original file is gone. (Eric Carlier) +Solution: Restore the original file from the backup. +Files: src/fileio.c + +Patch 6.0.041 +Problem: Using ":language messages en" when LC_MESSAGES is undefined + results in setting LC_CTYPE. (Eric Carlier) +Solution: Set $LC_MESSAGES instead. +Files: src/ex_cmds2.c + +Patch 6.0.042 +Problem: ":mksession" can't handle file names with a space. +Solution: Escape special characters in file names with a backslash. +Files: src/ex_docmd.c + +Patch 6.0.043 +Problem: Patch 6.0.041 was wrong. +Solution: Use mch_getenv() instead of vim_getenv(). +Files: src/ex_cmds2.c + +Patch 6.0.044 +Problem: Using a "containedin" list for a syntax item doesn't work for an + item that doesn't have a "contains" argument. Also, "containedin" + doesn't ignore a transparent item. (Timo Frenay) +Solution: When there is a "containedin" argument somewhere, always check for + contained items. Don't check for the transparent item but the + item it's contained in. +Files: src/structs.h, src/syntax.c + +Patch 6.0.045 +Problem: After creating a fold with a Visual selection, another window + with the same buffer still has inverted text. (Sami Salonen) +Solution: Redraw the inverted text. +Files: src/normal.c + +Patch 6.0.046 +Problem: When getrlimit() returns an 8 byte number the check for running + out of stack may fail. (Anthony Meijer) +Solution: Skip the stack check if the limit doesn't fit in a long. +Files: src/auto/configure, src/config.h.in, src/configure.in, + src/os_unix.c + +Patch 6.0.047 +Problem: Using a regexp with "\(\)" inside a "\%[]" item causes a crash. + (Samuel Lacas) +Solution: Don't allow nested atoms inside "\%[]". +Files: src/regexp.c + +Patch 6.0.048 +Problem: Win32: In the console the mouse doesn't always work correctly. + Sometimes after getting focus a mouse movement is interpreted like + a button click. +Solution: Use a different function to obtain the number of mouse buttons. + Avoid recognizing a button press from undefined bits. (Vince Negri) +Files: src/os_win32.c + +Patch 6.0.049 +Problem: When using evim the intro screen is misleading. (Adrian Nagle) +Solution: Mention whether 'insertmode' is set and the menus to be used. +Files: runtime/menu.vim, src/version.c + +Patch 6.0.050 +Problem: UTF-8: "viw" doesn't include non-ASCII characters before the + cursor. (Bertilo Wennergren) +Solution: Use dec_cursor() instead of decrementing the column number. +Files: src/search.c + +Patch 6.0.051 +Problem: UTF-8: Using CTRL-R on the command line doesn't insert composing + characters. (Ron Aaron) +Solution: Also include the composing characters and fix redrawing them. +Files: src/ex_getln.c, src/ops.c + +Patch 6.0.052 +Problem: The check for rlim_t in patch 6.0.046 does not work on some + systems. (Zdenek Sekera) +Solution: Also look in sys/resource.h for rlim_t. +Files: src/auto/configure, src/configure.in + +Patch 6.0.053 (extra) +Problem: Various problems with QNX. +Solution: Minor fix for configure. Switch on terminal clipboard support in + main.c. Fix "pterm" mouse support. os_qnx.c didn't build without + photon. (Julian Kinraid) +Files: src/auto/configure, src/configure.in, src/gui_photon.c, + src/main.c, src/misc2.c, src/option.h, src/os_qnx.c, src/os_qnx.h, + src/syntax.c + +Patch 6.0.054 +Problem: When using mswin.vim, CTRL-V pastes a block of text like it is + normal text. Using CTRL-V in blockwise Visual mode leaves "x" + characters behind. +Solution: Make CTRL-V work as it should. Do the same for the Paste menu + entries. +Files: runtime/menu.vim, runtime/mswin.vim + +Patch 6.0.055 +Problem: GTK: The selection isn't copied the first time. +Solution: Own the selection at the right moment. +Files: src/gui_gtk_x11.c + +Patch 6.0.056 +Problem: Using "CTRL-O cw" in Insert mode results in a nested Insert mode. + <Esc> doesn't leave Insert mode then. +Solution: Only use nested Insert mode when 'insertmode' is set or when a + mapping is used. +Files: src/normal.c + +Patch 6.0.057 +Problem: Using ":wincmd g}" in a function doesn't work. (Gary Holloway) +Solution: Execute the command directly, instead of putting it in the + typeahead buffer. +Files: src/normal.c, src/proto/normal.pro, src/window.c + +Patch 6.0.058 +Problem: When a Cursorhold autocommand moved the cursor, the ruler wasn't + updated. (Bohdan Vlasyuk) +Solution: Update the ruler after executing the autocommands. +Files: src/gui.c + +Patch 6.0.059 +Problem: Highlighting for 'hlsearch' isn't visible in lines that are + highlighted for diff highlighting. (Gary Holloway) +Solution: Let 'hlsearch' highlighting overrule diff highlighting. +Files: src/screen.c + +Patch 6.0.060 +Problem: Motif: When the tooltip is to be popped up, Vim crashes. + (Gary Holloway) +Solution: Check for a NULL return value from gui_motif_fontset2fontlist(). +Files: src/gui_beval.c + +Patch 6.0.061 +Problem: The toolbar buttons to load and save a session do not correctly + use v:this_session. +Solution: Check for v:this_session to be empty instead of existing. +Files: runtime/menu.vim + +Patch 6.0.062 +Problem: Crash when 'verbose' is > 3 and using ":shell". (Yegappan + Lakshmanan) +Solution: Avoid giving a NULL pointer to printf(). Also output a newline + and switch the cursor on. +Files: src/misc2.c + +Patch 6.0.063 +Problem: When 'cpoptions' includes "$", using "cw" to type a ')' on top of + the "$" doesn't update syntax highlighting after it. +Solution: Stop displaying the "$" when typing a ')' in its position. +Files: src/search.c + +Patch 6.0.064 (extra) +Problem: The NSIS install script doesn't work with newer versions of NSIS. + The diff feature doesn't work when there isn't a good diff.exe on + the system. +Solution: Replace the GetParentDir instruction by a user function. + Fix a few cosmetic problems. Use defined constants for the + version number, so that it's defined in one place only. + Only accept the install directory when it ends in "vim". + (Eduardo Fernandez) + Add a diff.exe and use it from the default _vimrc. +Files: nsis/gvim.nsi, nsis/README.txt, src/dosinst.c + +Patch 6.0.065 +Problem: When using ":normal" in 'indentexpr' it may use redo characters + before its argument. (Neil Bird) +Solution: Save and restore the stuff buffer in ex_normal(). +Files: src/ex_docmd.c, src/getchar.c, src/globals.h, src/structs.h + +Patch 6.0.066 +Problem: Sometimes undo for one command is split into two undo actions. + (Halim Salman) +Solution: Don't set the undo-synced flag when reusing a line that was + already saved for undo. +Files: src/undo.c + +Patch 6.0.067 +Problem: if_xcmdsrv.c doesn't compile on systems where fd_set isn't defined + in the usual header file (e.g., AIX). (Mark Waggoner) +Solution: Include sys/select.h in if_xcmdsrv.c for systems that have it. +Files: src/if_xcmdsrv.c + +Patch 6.0.068 +Problem: When formatting a Visually selected area with "gq" and the number + of lines increases the last line may not be redrawn correctly. + (Yegappan Lakshmanan) +Solution: Correct the area to be redrawn for inserted/deleted lines. +Files: src/ops.c + +Patch 6.0.069 +Problem: Using "K" on a word that includes a "!" causes a "No previous + command" error, because the "!" is expanded. (Craig Jeffries) +Solution: Put a backslash before the "!". +Files: src/normal.c + +Patch 6.0.070 +Problem: Win32: The error message for a failed dynamic linking of a Perl, + Ruby, Tcl and Python library is unclear about what went wrong. +Solution: Give the name of the library or function that could not be loaded. + Also for the iconv and gettext libraries when 'verbose' is set. +Files: src/eval.c, src/if_perl.xs, src/if_python.c, src/if_ruby.c, + src/if_tcl.c, src/mbyte.c, src/os_win32.c, src/proto/if_perl.pro, + src/proto/if_python.pro, src/proto/if_ruby.pro, + src/proto/if_tcl.pro, src/proto/mbyte.pro + +Patch 6.0.071 +Problem: The "iris-ansi" builtin termcap isn't very good. +Solution: Fix the wrong entries. (David Harrison) +Files: src/term.c + +Patch 6.0.072 +Problem: When 'lazyredraw' is set, a mapping that stops Visual mode, moves + the cursor and starts Visual mode again causes a redraw problem. + (Brian Silverman) +Solution: Redraw both the old and the new Visual area when necessary. +Files: src/normal.c, src/screen.c + +Patch 6.0.073 (extra) +Problem: DJGPP: When using CTRL-Z to start a shell, the prompt is halfway + the text. (Volker Kiefel) +Solution: Position the system cursor before starting the shell. +Files: src/os_msdos.c + +Patch 6.0.074 +Problem: When using "&" in a substitute string a multi-byte character with + a trailbyte 0x5c is not handled correctly. +Solution: Recognize multi-byte characters inside the "&" part. (Muraoka Taro) +Files: src/regexp.c + +Patch 6.0.075 +Problem: When closing a horizontally split window while 'eadirection' is + "hor" another horizontally split window is still resized. (Aron + Griffis) +Solution: Only resize windows in the same top frame as the window that is + split or closed. +Files: src/main.c, src/proto/window.pro, src/window.c + +Patch 6.0.076 +Problem: Warning for wrong pointer type when compiling. +Solution: Use char instead of char_u pointer. +Files: src/version.c + +Patch 6.0.077 +Problem: Patch 6.0.075 was incomplete. +Solution: Fix another call to win_equal(). +Files: src/option.c + +Patch 6.0.078 +Problem: Using "daw" at the end of a line on a single-character word didn't + include the white space before it. At the end of the file it + didn't work at all. (Gavin Sinclair) +Solution: Include the white space before the word. +Files: src/search.c + +Patch 6.0.079 +Problem: When "W" is in 'cpoptions' and 'backupcopy' is "no" or "auto", can + still overwrite a read-only file, because it's renamed. (Gary + Holloway) +Solution: Add a check for a read-only file before renaming the file to + become the backup. +Files: src/fileio.c + +Patch 6.0.080 +Problem: When using a session file that has the same file in two windows, + the fileinfo() call in do_ecmd() causes a scroll and a hit-enter + prompt. (Robert Webb) +Solution: Don't scroll this message when 'shortmess' contains 'O'. +Files: src/ex_cmds.c + +Patch 6.0.081 +Problem: After using ":saveas" the new buffer name is added to the Buffers + menu with a wrong number. (Chauk-Mean Proum) +Solution: Trigger BufFilePre and BufFilePost events for the renamed buffer + and BufAdd for the old name (which is with a new buffer). +Files: src/ex_cmds.c + +Patch 6.0.082 +Problem: When swapping screens in an xterm and there is an (error) message + from the vimrc script, the shell prompt is after the message. +Solution: Output a newline when there was output on the alternate screen. + Also when starting the GUI. +Files: src/main.c + +Patch 6.0.083 +Problem: GTK: When compiled without menu support the buttons in a dialog + don't have any text. (Erik Edelmann) +Solution: Add the text also when GTK_USE_ACCEL isn't defined. And define + GTK_USE_ACCEL also when not using menus. +Files: src/gui_gtk.c + +Patch 6.0.084 +Problem: UTF-8: a "r" command with an argument that is a keymap for a + character with a composing character can't be repeated with ".". + (Raphael Finkel) +Solution: Add the composing characters to the redo buffer. +Files: src/normal.c + +Patch 6.0.085 +Problem: When 'mousefocus' is set, using "s" to go to Insert mode and then + moving the mouse pointer to another window stops Insert mode, + while this doesn't happen with "a" or "i". (Robert Webb) +Solution: Reset finish_op before calling edit(). +Files: src/normal.c + +Patch 6.0.086 +Problem: When using "gu" the message says "~ed". +Solution: Make the message say "changed". +Files: src/ops.c + +Patch 6.0.087 (lang) +Problem: Message translations are incorrect, which may cause a crash. + (Peter Figura) + The Turkish translations needed more work and the maintainer + didn't have time. +Solution: Fix order of printf arguments. Remove %2$d constructs. + Add "-v" to msgfmt to get a warning for wrong translations. + Don't install the Turkish translations for now. + Update a few more translations. +Files: src/po/Makefile, src/po/af.po, src/po/cs.po, src/po/cs.cp1250.po, + src/po/de.po, src/po/es.po, src/po/fr.po, src/po/it.po, + src/po/ja.po, src/po/ja.sjis.po, src/po/ko.po, src/po/pl.po, + src/po/sk.po, src/po/uk.po, src/po/zh_CN.UTF-8.po, + src/po/zh_CN.cp936.po, src/po/zh_CN.po, src/po/zh_TW.po + +Patch 6.0.088 +Problem: "." doesn't work after using "rx" in Visual mode. (Charles + Campbell) +Solution: Also store the replacement character in the redo buffer. +Files: src/normal.c + +Patch 6.0.089 +Problem: In a C file, using "==" to align a line starting with "* " after + a line with "* -" indents one space too few. (Piet Delport) +Solution: Align with the previous line if the comment-start-string matches + there. +Files: src/misc1.c + +Patch 6.0.090 +Problem: When a wrapping line does not fit in a window and 'scrolloff' is + bigger than half the window height, moving the cursor left or + right causes the screen to flash badly. (Lubomir Host) +Solution: When there is not enough room to show 'scrolloff' screen lines and + near the end of the line, show the end of the line. +Files: src/move.c + +Patch 6.0.091 +Problem: Using CTRL-O in Insert mode, while 'virtualedit' is "all" and the + cursor is after the end-of-line, moves the cursor left. (Yegappan + Lakshmanan) +Solution: Keep the cursor in the same position. +Files: src/edit.c + +Patch 6.0.092 +Problem: The explorer plugin doesn't ignore case of 'suffixes' on + MS-Windows. (Mike Williams) +Solution: Match or ignore case as appropriate for the OS. +Files: runtime/plugin/explorer.vim + +Patch 6.0.093 +Problem: When the Tcl library couldn't be loaded dynamically, get an error + message when closing a buffer or window. (Muraoka Taro) +Solution: Only free structures if already using the Tcl interpreter. +Files: src/if_tcl.c + +Patch 6.0.094 +Problem: Athena: When clicking in the horizontal scrollbar Vim crashes. + (Paul Ackersviller) +Solution: Use the thumb size instead of the window pointer of the scrollbar + (which is NULL). (David Harrison) + Also avoid that scrolling goes the wrong way in a narrow window. +Files: src/gui_athena.c + +Patch 6.0.095 +Problem: Perl: Deleting lines may leave the cursor beyond the end of the + file. +Solution: Check the cursor position after deleting a line. (Serguei) +Files: src/if_perl.xs + +Patch 6.0.096 +Problem: When ":saveas fname" fails because the file already exists, the + file name is changed anyway and a following ":w" will overwrite + the file. (Eric Carlier) +Solution: Don't change the file name if the file already exists. +Files: src/ex_cmds.c + +Patch 6.0.097 +Problem: Re-indenting in Insert mode with CTRL-F may cause a crash with a + multi-byte encoding. +Solution: Avoid using a character before the start of a line. (Sergey + Vlasov) +Files: src/edit.c + +Patch 6.0.098 +Problem: GTK: When using Gnome the "Search" and "Search and Replace" dialog + boxes are not translated. +Solution: Define ENABLE_NLS before including gnome.h. (Eduardo Fernandez) +Files: src/gui_gtk.c, src/gui_gtk_x11.c + +Patch 6.0.099 +Problem: Cygwin: When running Vi compatible MS-DOS line endings cause + trouble. +Solution: Make the default for 'fileformats' "unix,dos" in Vi compatible + mode. (Michael Schaap) +Files: src/option.h + +Patch 6.0.100 +Problem: ":badd +0 test%file" causes a crash. +Solution: Take into account that the "+0" is NUL terminated when allocating + room for replacing the "%". +Files: src/ex_docmd.c + +Patch 6.0.101 +Problem: ":mksession" doesn't restore editing a file that has a '#' or '%' + in its name. (Wolfgang Blankenburg) +Solution: Put a backslash before the '#' and '%'. +Files: src/ex_docmd.c + +Patch 6.0.102 +Problem: When changing folds the cursor may appear halfway a closed fold. + (Nam SungHyun) +Solution: Set w_cline_folded correctly. (Yasuhiro Matsumoto) +Files: src/move.c + +Patch 6.0.103 +Problem: When using 'scrollbind' a large value of 'scrolloff' will make the + scroll binding stop near the end of the file. (Coen Engelbarts) +Solution: Don't use 'scrolloff' when limiting the topline for scroll + binding. (Dany StAmant) +Files: src/normal.c + +Patch 6.0.104 +Problem: Multi-byte: When '$' is in 'cpoptions', typing a double-wide + character that overwrites the left halve of an old double-wide + character causes a redraw problem and the cursor stops blinking. +Solution: Clear the right half of the old character. (Yasuhiro Matsumoto) +Files: src/edit.c, src/screen.c + +Patch 6.0.105 +Problem: Multi-byte: In a window of one column wide, with syntax + highlighting enabled a crash might happen. +Solution: Skip getting the syntax attribute when the character doesn't fit + anyway. (Yasuhiro Matsumoto) +Files: src/screen.c + +Patch 6.0.106 (extra) +Problem: Win32: When the printer font is wrong, there is no error message. +Solution: Give an appropriate error message. (Yasuhiro Matsumoto) +Files: src/os_mswin.c + +Patch 6.0.107 (extra) +Problem: VisVim: When editing another file, a modified file may be written + unexpectedly and without warning. +Solution: Split the window if a file was modified. +Files: VisVim/Commands.cpp + +Patch 6.0.108 +Problem: When using folding could try displaying line zero, resulting in an + error for a NULL pointer. +Solution: Stop decrementing w_topline when the first line of a window is in + a closed fold. +Files: src/window.c + +Patch 6.0.109 +Problem: XIM: When the input method is enabled, repeating an insertion with + "." disables it. (Marcel Svitalsky) +Solution: Don't store the input method status when a command comes from the + stuff buffer. +Files: src/ui.c + +Patch 6.0.110 +Problem: Using undo after executing "OxjAxkdd" from a register in + an empty buffer gives an error message. (Gerhard Hochholzer) +Solution: Don't adjust the bottom line number of an undo block when it's + zero. Add a test for this problem. +Files: src/undo.c, src/testdir/test20.in, src/testdir/test20.ok + +Patch 6.0.111 +Problem: The virtcol() function doesn't take care of 'virtualedit'. +Solution: Add the column offset when needed. (Yegappan Lakshmanan) +Files: src/eval.c + +Patch 6.0.112 +Problem: The explorer plugin doesn't sort directories with a space or + special character after a directory with a shorter name. +Solution: Ignore the trailing slash when comparing directory names. (Mike + Williams) +Files: runtime/plugin/explorer.vim + +Patch 6.0.113 +Problem: ":edit ~/fname" doesn't work if $HOME includes a space. Also, + expanding wildcards with the shell may fail. (John Daniel) +Solution: Escape spaces with a backslash when needed. +Files: src/ex_docmd.c, src/misc1.c, src/proto/misc1.pro, src/os_unix.c + +Patch 6.0.114 +Problem: Using ":p" with fnamemodify() didn't expand "~/" or "~user/" to a + full path. For Win32 the current directory was prepended. + (Michael Geddes) +Solution: Expand the home directory. +Files: src/eval.c + +Patch 6.0.115 (extra) +Problem: Win32: When using a dialog with a textfield it cannot scroll the + text. +Solution: Add ES_AUTOHSCROLL to the textfield style. (Pedro Gomes) +Files: src/gui_w32.c + +Patch 6.0.116 (extra) +Problem: MS-Windows NT/2000/XP: filewritable() doesn't work correctly for + filesystems that use ACLs. +Solution: Use ACL functions to check if a file is writable. (Mike Williams) +Files: src/eval.c, src/macros.h, src/os_win32.c, src/proto/os_win32.pro + +Patch 6.0.117 (extra) +Problem: Win32: when disabling the menu, "set lines=999" doesn't use all + the available screen space. +Solution: Don't subtract the fixed caption height but the real menu height + from the available screen space. Also: Avoid recursion in + gui_mswin_get_menu_height(). +Files: src/gui_w32.c, src/gui_w48.c + +Patch 6.0.118 +Problem: When $TMPDIR is a relative path, the temp directory is missing a + trailing slash and isn't deleted when Vim exits. (Peter Holm) +Solution: Add the slash after expanding the directory to an absolute path. +Files: src/fileio.c + +Patch 6.0.119 (depends on patch 6.0.116) +Problem: VMS: filewritable() doesn't work properly. +Solution: Use the same method as for Unix. (Zoltan Arpadffy) +Files: src/eval.c + +Patch 6.0.120 +Problem: The conversion to html isn't compatible with XHTML. +Solution: Quote the values. (Jess Thrysoee) +Files: runtime/syntax/2html.vim + +Patch 6.0.121 (extra) (depends on patch 6.0.116) +Problem: Win32: After patch 6.0.116 Vim doesn't compile with mingw32. +Solution: Add an #ifdef HAVE_ACL. +Files: src/os_win32.c + +Patch 6.0.122 (extra) +Problem: Win16: Same resize problems as patch 6.0.117 fixed for Win32. And + dialog textfield problem from patch 6.0.115. +Solution: Set old_menu_height only when used. Add ES_AUTOHSCROLL flag. + (Vince Negri) +Files: src/gui_w16.c + +Patch 6.0.123 (depends on patch 6.0.119) +Problem: Win16: Compilation problems. +Solution: Move "&&" to other lines. (Vince Negri) +Files: src/eval.c + +Patch 6.0.124 +Problem: When using a ":substitute" command that starts with "\=" + (evaluated as an expression), "~" was still replaced with the + previous substitute string. +Solution: Skip the replacement when the substitute string starts with "\=". + Also adjust the documentation about doubling backslashes. +Files: src/ex_cmds.c, runtime/doc/change.txt + +Patch 6.0.125 (extra) +Problem: Win32: When using the multi_byte_ime feature pressing the shift + key would be handled as if a character was entered, thus mappings + with a shifted key didn't work. (Charles Campbell) +Solution: Ignore pressing the shift, control and alt keys. +Files: src/os_win32.c + +Patch 6.0.126 +Problem: The python library was always statically linked. +Solution: Link the python library dynamically. (Matthias Klose) +Files: src/auto/configure, src/configure.in + +Patch 6.0.127 +Problem: When using a terminal that swaps screens and the Normal background + color has a different background, using an external command may + cause the color of the wrong screen to be changed. (Mark Waggoner) +Solution: Don't call screen_stop_highlight() in stoptermcap(). +Files: src/term.c + +Patch 6.0.128 +Problem: When moving a vertically split window to the far left or right, + the scrollbars are not adjusted. (Scott E Lee) When 'mousefocus' + is set the mouse pointer wasn't adjusted. +Solution: Adjust the scrollbars and the mouse pointer. +Files: src/window.c + +Patch 6.0.129 +Problem: When using a very long file name, ":ls" (repeated a few times) + causes a crash. Test with "vim `perl -e 'print "A"x1000'`". + (Tejeda) +Solution: Terminate a string before getting its length in buflist_list(). +Files: src/buffer.c + +Patch 6.0.130 +Problem: When using ":cprev" while the error window is open, and the new + line at the top wraps, the window isn't correctly drawn. + (Yegappan Lakshmanan) +Solution: When redrawing the topline don't scroll twice. +Files: src/screen.c + +Patch 6.0.131 +Problem: When using bufname() and there are two matches for listed buffers + and one match for an unlisted buffer, the unlisted buffer is used. + (Aric Blumer) +Solution: When there is a match with a listed buffer, don't check for + unlisted buffers. +Files: src/buffer.c + +Patch 6.0.132 +Problem: When setting 'iminsert' in the vimrc and using an xterm with two + screens the ruler is drawn in the wrong screen. (Igor Goldenberg) +Solution: Only draw the ruler when using the right screen. +Files: src/option.c + +Patch 6.0.133 +Problem: When opening another buffer while 'keymap' is set and 'iminsert' + is zero, 'iminsert' is set to one unexpectedly. (Igor Goldenberg) +Solution: Don't set 'iminsert' as a side effect of defining a ":lmap" + mapping. Only do that when 'keymap' is set. +Files: src/getchar.c, src/option.c + +Patch 6.0.134 +Problem: When completing ":set tags=" a path with an embedded space causes + the completion to stop. (Sektor van Skijlen) +Solution: Escape spaces with backslashes, like for ":set path=". Also take + backslashes into account when searching for the start of the path + to complete (e.g., for 'backupdir' and 'cscopeprg'). +Files: src/ex_docmd.c, src/ex_getln.c, src/option.c, src/structs.h + +Patch 6.0.135 +Problem: Menus that are not supposed to do anything used "<Nul>", which + still produced an error beep. + When CTRL-O is mapped for Insert mode, ":amenu" commands didn't + work in Insert mode. + Menu language falls back to English when $LANG ends in "@euro". +Solution: Use "<Nop>" for a menu item that doesn't do anything, just like + mappings. + Use ":anoremenu" instead of ":amenu". + Ignore "@euro" in the locale name. +Files: runtime/makemenu.vim, runtime/menu.vim, src/menu.c + +Patch 6.0.136 +Problem: When completing in Insert mode, a mapping could be unexpectedly + applied. +Solution: Don't use mappings when checking for a typed character. +Files: src/edit.c + +Patch 6.0.137 +Problem: GUI: When using the find or find/replace dialog from Insert mode, + the input mode is stopped. +Solution: Don't use the input method status when the main window doesn't + have focus. +Files: src/ui.c + +Patch 6.0.138 +Problem: GUI: When using the find or find/replace dialog from Insert mode, + the text is inserted when CTRL-O is mapped. (Andre Pang) + When opening the dialog again, a whole word search isn't + recognized. + When doing "replace all" a whole word search was never done. +Solution: Don't put a search or replace command in the input buffer, + execute it directly. + Recognize "\<" and "\>" after removing "\V". + Add "\<" and "\>" also for "replace all". +Files: src/gui.c + +Patch 6.0.139 +Problem: When stopping 'wildmenu' completion, the statusline of the + bottom-left vertically split window isn't redrawn. (Yegappan + Lakshmanan) +Solution: Redraw all the bottom statuslines. +Files: src/ex_getln.c, src/proto/screen.pro, src/screen.c + +Patch 6.0.140 +Problem: Memory allocated for local mappings and abbreviations is leaked + when the buffer is wiped out. +Solution: Clear the local mappings when deleting a buffer. +Files: src/buffer.c, src/getchar.c, src/proto/getchar.pro, src/vim.h + +Patch 6.0.141 +Problem: When using ":enew" in an empty buffer, some buffer-local things + are not cleared. b:keymap_name is not set. +Solution: Clear user commands and mappings local to the buffer when re-using + the current buffer. Reload the keymap. +Files: src/buffer.c + +Patch 6.0.142 +Problem: When Python is linked statically, loading dynamic extensions might + fail. +Solution: Add an extra linking flag when needed. (Andrew Rodionoff) +Files: src/configure.in, src/auto/configure + +Patch 6.0.143 +Problem: When a syntax item includes a line break in a pattern, the syntax + may not be updated properly when making a change. +Solution: Add the "linebreaks" argument to ":syn sync". +Files: runtime/doc/syntax.txt, src/screen.c, src/structs.h, src/syntax.c + +Patch 6.0.144 +Problem: After patch 6.0.088 redoing "veU" doesn't work. +Solution: Don't add the "U" to the redo buffer, it will be used as an undo + command. +Files: src/normal.c + +Patch 6.0.145 +Problem: When Vim can't read any input it might get stuck. When + redirecting stdin and stderr Vim would not read commands from a + file. (Servatius Brandt) +Solution: When repeatedly trying to read a character when it's not possible, + exit Vim. When stdin and stderr are not a tty, still try reading + from them, but don't do a blocking wait. +Files: src/ui.c + +Patch 6.0.146 +Problem: When 'statusline' contains "%{'-'}" this results in a zero. + (Milan Vancura) +Solution: Don't handle numbers with a minus as a number, they were not + displayed anyway. +Files: src/buffer.c + +Patch 6.0.147 +Problem: It's not easy to mark a Vim version as being modified. The new + license requires this. +Solution: Add the --modified-by argument to configure and the MODIFIED_BY + define. It's used in the intro screen and the ":version" output. +Files: src/auto/configure, src/configure.in, src/config.h.in, + src/feature.h, src/version.c + +Patch 6.0.148 +Problem: After "p" in an empty line, `[ goes to the second character. + (Kontra Gergely) +Solution: Don't increment the column number in an empty line. +Files: src/ops.c + +Patch 6.0.149 +Problem: The pattern "\(.\{-}\)*" causes a hang. When using a search + pattern that causes a stack overflow to be detected Vim could + still hang. +Solution: Correctly report "operand could be empty" when using "\{-}". + Check for "out_of_stack" inside loops to avoid a hang. +Files: src/regexp.c + +Patch 6.0.150 +Problem: When using a multi-byte encoding, patch 6.0.148 causes "p" to work + like "P". (Sung-Hyun Nam) +Solution: Compute the byte length of a multi-byte character. +Files: src/ops.c + +Patch 6.0.151 +Problem: Redrawing the status line and ruler can be wrong when it contains + multi-byte characters. +Solution: Use character width and byte length correctly. (Yasuhiro Matsumoto) +Files: src/screen.c + +Patch 6.0.152 +Problem: strtrans() could hang on an illegal UTF-8 byte sequence. +Solution: Skip over illegal bytes. (Yasuhiro Matsumoto) +Files: src/charset.c + +Patch 6.0.153 +Problem: When using (illegal) double-byte characters and Vim syntax + highlighting Vim can crash. (Yasuhiro Matsumoto) +Solution: Increase a pointer over a character instead of a byte. +Files: src/regexp.c + +Patch 6.0.154 +Problem: MS-DOS and MS-Windows: The menu entries for xxd don't work when + there is no xxd in the path. + When converting back from Hex the filetype may remain "xxd" if it + is not detected. +Solution: When xxd is not in the path use the one in the runtime directory, + where the install program has put it. + Clear the 'filetype' option before detecting the new value. +Files: runtime/menu.vim + +Patch 6.0.155 +Problem: Mac: compilation problems in ui.c after patch 6.0.145. (Axel + Kielhorn) +Solution: Don't call mch_inchar() when NO_CONSOLE is defined. +Files: src/ui.c + +Patch 6.0.156 +Problem: Starting Vim with the -b argument and two files, ":next" doesn't + set 'binary' in the second file, like Vim 5.7. (Norman Diamond) +Solution: Set the global value for 'binary'. +Files: src/option.c + +Patch 6.0.157 +Problem: When defining a user command with "-complete=dir" files will also + be expanded. Also, "-complete=mapping" doesn't appear to work. + (Michael Naumann) +Solution: Use the expansion flags defined with the user command. + Handle expanding mappings specifically. +Files: src/ex_docmd.c + +Patch 6.0.158 +Problem: When getting the warning for a file being changed outside of Vim + and reloading the file, the 'readonly' option is reset, even when + the permissions didn't change. (Marcel Svitalsky) +Solution: Keep 'readonly' set when reloading a file and the permissions + didn't change. +Files: src/fileio.c + +Patch 6.0.159 +Problem: Wildcard expansion for ":emenu" also shows separators. +Solution: Skip menu separators for ":emenu", ":popup" and ":tearoff". + Also, don't handle ":tmenu" as if it was ":tearoff". And leave + out the alternatives with "&" included. +Files: src/menu.c + +Patch 6.0.160 +Problem: When compiling with GCC 3.0.2 and using the "-O2" argument, the + optimizer causes a problem that makes Vim crash. +Solution: Add a configure check to avoid "-O2" for this version of gcc. +Files: src/configure.in, src/auto/configure + +Patch 6.0.161 (extra) +Problem: Win32: Bitmaps don't work with signs. +Solution: Make it possible to use bitmaps with signs. (Muraoka Taro) +Files: src/ex_cmds.c, src/feature.h, src/gui_w32.c, src/gui_x11.c, + src/proto/gui_w32.pro, src/proto/gui_x11.pro + +Patch 6.0.162 +Problem: Client-server: An error message for a wrong expression appears in + the server instead of the client. +Solution: Pass the error message from the server to the client. Also + adjust the example code. (Flemming Madsen) +Files: src/globals.h, src/if_xcmdsrv.c, src/main.c, src/os_mswin.c, + src/proto/if_xcmdsrv.pro, src/proto/os_mswin.pro, + runtime/doc/eval.txt, runtime/tools/xcmdsrv_client.c + +Patch 6.0.163 +Problem: When using a GUI dialog, a file name is sometimes used like it was + a directory. +Solution: Separate path and file name properly. + For GTK, Motif and Athena concatenate directory and file name for + the default selection. +Files: src/diff.c, src/ex_cmds.c, src/ex_cmds2.c, src/ex_docmd.c, + src/gui_athena.c, src/gui_gtk.c, src/gui_motif.c, src/message.c + +Patch 6.0.164 +Problem: After patch 6.0.135 the menu entries for pasting don't work in + Insert and Visual mode. (Muraoka Taro) +Solution: Add <script> to allow script-local mappings. +Files: runtime/menu.vim + +Patch 6.0.165 +Problem: Using --remote and executing locally gives unavoidable error + messages. +Solution: Add --remote-silent and --remote-wait-silent to silently execute + locally. + For Win32 there was no error message when a server didn't exist. +Files: src/eval.c, src/if_xcmdsrv.c, src/main.c, src/os_mswin.c, + src/proto/if_xcmdsrv.pro, src/proto/os_mswin.pro + +Patch 6.0.166 +Problem: GUI: There is no way to avoid dialogs to pop up. +Solution: Add the 'c' flag to 'guioptions': Use console dialogs. (Yegappan + Lakshmanan) +Files: runtime/doc/options.txt, src/option.h, src/message.c + +Patch 6.0.167 +Problem: When 'fileencodings' is "latin2" some characters in the help files + are displayed wrong. +Solution: Force the 'fileencoding' for the help files to be "latin1". +Files: src/fileio.c + +Patch 6.0.168 +Problem: ":%s/\n/#/" doesn't replace at an empty line. (Bruce DeVisser) +Solution: Don't skip matches after joining two lines. +Files: src/ex_cmds.c + +Patch 6.0.169 +Problem: When run as evim and the GUI can't be started we get stuck in a + terminal without menus in Insert mode. +Solution: Exit when using "evim" and "gvim -y" when the GUI can't be + started. +Files: src/main.c + +Patch 6.0.170 +Problem: When printing double-width characters the size of tabs after them + is wrong. (Muraoka Taro) +Solution: Correctly compute the column after a double-width character. +Files: src/ex_cmds2.c + +Patch 6.0.171 +Problem: With 'keymodel' including "startsel", in Insert mode after the end + of a line, shift-Left does not move the cursor. (Steve Hall) +Solution: CTRL-O doesn't move the cursor left, need to do that explicitly. +Files: src/edit.c + +Patch 6.0.172 +Problem: CTRL-Q doesn't replace CTRL-V after CTRL-X in Insert mode while it + does in most other situations. +Solution: Make CTRL-X CTRL-Q work like CTRL-X CTRL-V in Insert mode. +Files: src/edit.c + +Patch 6.0.173 +Problem: When using "P" to insert a line break the cursor remains past the + end of the line. +Solution: Check for the cursor being beyond the end of the line. +Files: src/ops.c + +Patch 6.0.174 +Problem: After using "gd" or "gD" the search direction for "n" may still be + backwards. (Servatius Brandt) +Solution: Reset the search direction to forward. +Files: src/normal.c, src/search.c, src/proto/search.pro + +Patch 6.0.175 +Problem: ":help /\z(\)" doesn't work. (Thomas Koehler) +Solution: Double the backslashes. +Files: src/ex_cmds.c + +Patch 6.0.176 +Problem: When killed by a signal autocommands are still triggered as if + nothing happened. +Solution: Add the v:dying variable to allow autocommands to work differently + when a deadly signal has been trapped. +Files: src/eval.c, src/os_unix.c, src/vim.h + +Patch 6.0.177 +Problem: When 'commentstring' is empty and 'foldmethod' is "marker", "zf" + doesn't work. (Thomas S. Urban) +Solution: Add the marker even when 'commentstring' is empty. +Files: src/fold.c, src/normal.c + +Patch 6.0.178 +Problem: Uninitialized memory read from xp_backslash field. +Solution: Initialize xp_backslash field properly. +Files: src/eval.c, src/ex_docmd.c, src/ex_getln.c, src/misc1.c, src/tag.c + +Patch 6.0.179 +Problem: Win32: When displaying UTF-8 characters may read uninitialized + memory. +Solution: Add utfc_ptr2len_check_len() to avoid reading past the end of a + string. +Files: src/mbyte.c, src/proto/mbyte.pro, src/gui_w32.c + +Patch 6.0.180 +Problem: Expanding environment variables in a string that ends in a + backslash could go past the end of the string. +Solution: Detect the trailing backslash. +Files: src/misc1.c + +Patch 6.0.181 +Problem: When using ":cd dir" memory was leaked. +Solution: Free the allocated memory. Also avoid an uninitialized memory + read. +Files: src/misc2.c + +Patch 6.0.182 +Problem: When using a regexp on multi-byte characters, could try to read a + character before the start of the line. +Solution: Don't decrement a pointer to before the start of the line. +Files: src/regexp.c + +Patch 6.0.183 +Problem: Leaking memory when ":func!" redefines a function. +Solution: Free the function name when it's not used. +Files: src/eval.c + +Patch 6.0.184 +Problem: Leaking memory when expanding option values. +Solution: Don't always copy the expanded option into allocated memory. +Files: src/option.c + +Patch 6.0.185 +Problem: Crash in Vim when pasting a selection in another application, on a + 64 bit machine. +Solution: Fix the format for an Atom to 32 bits. (Peter Derr) +Files: src/ui.c + +Patch 6.0.186 +Problem: X11: Three warnings when compiling the client-server code. +Solution: Add a typecast to unsigned char. +Files: src/if_xcmdsrv.c + +Patch 6.0.187 +Problem: "I" in Visual mode and then "u" reports too many changes. (Andrew + Stryker) + "I" in Visual linewise mode adjusts the indent for no apparent + reason. +Solution: Only save those lines for undo that are changed. + Don't change the indent after inserting in Visual linewise mode. +Files: src/ops.c + +Patch 6.0.188 +Problem: Win32: After patch 6.0.161 signs defined in the vimrc file don't + work. +Solution: Initialize the sign icons after initializing the GUI. (Vince + Negri) +Files: src/gui.c, src/gui_x11.c + +Patch 6.0.189 +Problem: The size of the Visual area isn't always displayed when scrolling + ('ruler' off, 'showcmd' on). Also not when using a search + command. (Sylvain Hitier) +Solution: Redisplay the size of the selection after showing the mode. +Files: src/screen.c + +Patch 6.0.190 +Problem: GUI: when 'mouse' is empty a click with the middle button still + moves the cursor. +Solution: Paste at the cursor position instead of the mouse position. +Files: src/normal.c + +Patch 6.0.191 +Problem: When no servers are available serverlist() gives an error instead + of returning an empty string. (Hari Krishna) +Solution: Don't give an error message. +Files: src/eval.c + +Patch 6.0.192 +Problem: When 'virtualedit' is set, "ylj" goes to the wrong column. (Andrew + Nikitin) +Solution: Reset the flag that w_virtcol is valid when moving the cursor back + to the start of the operated area. +Files: src/normal.c + +Patch 6.0.193 +Problem: When 'virtualedit' is set, col(".") after the end of the line + should return one extra. +Solution: Add one to the column. +Files: src/eval.c + +Patch 6.0.194 +Problem: "--remote-silent" tries to send a reply to the client, like it was + "--remote-wait". +Solution: Properly check for the argument. +Files: src/main.c + +Patch 6.0.195 +Problem: When 'virtualedit' is set and a search starts in virtual space + ":call search('x')" goes to the wrong position. (Eric Long) +Solution: Reset coladd when finding a match. +Files: src/search.c + +Patch 6.0.196 +Problem: When 'virtualedit' is set, 'selection' is "exclusive" and visually + selecting part of a tab at the start of a line, "x" joins it with + the previous line. Also, when the selection spans more than one + line the whole tab is deleted. +Solution: Take coladd into account when adjusting for 'selection' being + "exclusive". Also expand a tab into spaces when deleting more + than one line. +Files: src/normal.c, src/ops.c + +Patch 6.0.197 +Problem: When 'virtualedit' is set and 'selection' is "exclusive", "v$x" + doesn't delete the last character in the line. (Eric Long) +Solution: Don't reset the inclusive flag. (Helmut Stiegler) +Files: src/normal.c + +Patch 6.0.198 +Problem: When 'virtualedit' is set and 'showbreak' is not empty, moving the + cursor over the line break doesn't work properly. (Eric Long) +Solution: Make getviscol() and getviscol2() use getvvcol() to obtain the + virtual cursor position. Adjust coladvance() and oneleft() to + skip over the 'showbreak' characters. +Files: src/edit.c, src/misc2.c + +Patch 6.0.199 +Problem: Multi-byte: could use iconv() after calling iconv_end(). + (Yasuhiro Matsumoto) +Solution: Stop converting input and output stream after calling iconv_end(). +Files: src/mbyte.c + +Patch 6.0.200 +Problem: A script that starts with "#!perl" isn't recognized as a Perl + filetype. +Solution: Ignore a missing path in a script header. Also, speed up + recognizing scripts by simplifying the patterns used. +Files: runtime/scripts.vim + +Patch 6.0.201 +Problem: When scrollbinding and doing a long jump, switching windows jumps + to another position in the file. Scrolling a few lines at a time + is OK. (Johannes Zellner) +Solution: When setting w_topline reset the flag that indicates w_botline is + valid. +Files: src/diff.c + +Patch 6.0.202 +Problem: The "icon=" argument for the menu command to define a toolbar icon + with a file didn't work for GTK. (Christian J. Robinson) + For Motif and Athena a full path was required. +Solution: Search the icon file using the specified path. Expand environment + variables in the file name. +Files: src/gui_gtk.c, src/gui_x11.c + +Patch 6.0.203 +Problem: Can change 'fileformat' even though 'modifiable' is off. + (Servatius Brandt) +Solution: Correct check for kind of set command. +Files: src/option.c + +Patch 6.0.204 +Problem: ":unlet" doesn't work for variables with curly braces. (Thomas + Scott Urban) +Solution: Handle variable names with curly braces properly. (Vince Negri) +Files: src/eval.c + +Patch 6.0.205 (extra) +Problem: "gvim -f" still forks when using the batch script to start Vim. +Solution: Add an argument to "start" to use a foreground session (Michael + Geddes) +Files: src/dosinst.c + +Patch 6.0.206 +Problem: Unix: if expanding a wildcard in a file name results in a + wildcard character and there are more parts in the path with a + wildcard, it is expanded again. + Windows: ":edit \[abc]" could never edit the file "[abc]". +Solution: Don't expand wildcards in already expanded parts. + Don't remove backslashes used to escape the special meaning of a + wildcard; can edit "[abc]" if '[' is removed from 'isfname'. +Files: src/misc1.c, src/os_unix.c + +Patch 6.0.207 (extra) +Problem: Win32: The shortcuts and start menu entries let Vim startup in the + desktop directory, which is not very useful. +Solution: Let shortcuts start Vim in $HOME or $HOMEDIR$HOMEPATH. +Files: src/dosinst.c + +Patch 6.0.208 +Problem: GUI: When using a keymap and the cursor is not blinking, CTRL-^ in + Insert mode doesn't directly change the cursor color. (Alex + Solow) +Solution: Force a redraw of the cursor after CTRL-^. +Files: src/edit.c + +Patch 6.0.209 +Problem: GUI GTK: After selecting a 'guifont' with the font dialog there + are redraw problems for multi-byte characters. +Solution: Separate the font dialog from setting the new font name to avoid + that "*" is used to find wide and bold fonts. + When redrawing extra characters for the bold trick, take care of + UTF-8 characters. +Files: src/gui.c, src/gui_gtk_x11.c, src/option.c, src/proto/gui.pro, + src/proto/gui_gtk_x11.pro + +Patch 6.0.210 +Problem: After patch 6.0.167 it's no longer possible to edit a help file in + another encoding than latin1. +Solution: Let the "++enc=" argument overrule the encoding. +Files: src/fileio.c + +Patch 6.0.211 +Problem: When reading a file fails, the buffer is empty, but it might still + be possible to write it with ":w" later. The original file is + lost then. (Steve Amerige) +Solution: Set the 'readonly' option for the buffer. +Files: src/fileio.c + +Patch 6.0.212 +Problem: GUI GTK: confirm("foo", "") causes a crash. +Solution: Don't make a non-existing button the default. Add a default "OK" + button if none is specified. +Files: src/eval.c, src/gui_gtk.c + +Patch 6.0.213 +Problem: When a file name contains unprintable characters, CTRL-G and other + commands don't work well. +Solution: Turn unprintable into printable characters. (Yasuhiro Matsumoto) +Files: src/buffer.c, src/charset.c + +Patch 6.0.214 +Problem: When there is a buffer without a name, empty entries appear in the + jumplist saved in the viminfo file. +Solution: Don't write jumplist entries without a file name. +Files: src/mark.c + +Patch 6.0.215 +Problem: After using "/" from Visual mode the Paste menu and Toolbar + entries don't work. Pasting with the middle mouse doesn't work + and modeless selection doesn't work. +Solution: Use the command line mode menus and use the mouse like in the + command line. +Files: src/gui.c, src/menu.c, src/ui.c + +Patch 6.0.216 +Problem: After reloading a file, displayed in another window than the + current one, which was changed outside of Vim the part of the file + around the cursor set by autocommands may be displayed, but + jumping back to the original cursor position when entering the + window again. +Solution: Restore the topline of the window. +Files: src/fileio.c + +Patch 6.0.217 +Problem: When getting help from a help file that was used before, an empty + unlisted buffer remains in the buffer list. (Eric Long) +Solution: Wipe out the buffer used to do the tag jump from. +Files: src/buffer.c, src/ex_cmds.c, src/proto/buffer.pro + +Patch 6.0.218 +Problem: With explorer plugin: "vim -o filename dirname" doesn't load the + explorer window until entering the window. +Solution: Call s:EditDir() for each window after starting up. +Files: runtime/plugin/explorer.vim + +Patch 6.0.219 +Problem: ":setlocal" and ":setglobal", without arguments, display terminal + options. (Zdenek Sekera) +Solution: Skip terminal options for these two commands. +Files: src/option.c + +Patch 6.0.220 +Problem: After patch 6.0.218 get a beep on startup. (Muraoka Taro) +Solution: Don't try going to another window when there isn't one. +Files: runtime/plugin/explorer.vim + +Patch 6.0.221 +Problem: When using ":bdel" and all other buffers are unloaded the lowest + numbered buffer is jumped to instead of the most recent one. (Dave + Cecil) +Solution: Prefer an unloaded buffer from the jumplist. +Files: src/buffer.c + +Patch 6.0.222 +Problem: When 'virtualedit' is set and using autoindent, pressing Esc after + starting a new line leaves behind part of the autoindent. (Helmut + Stiegler) +Solution: After deleting the last char in the line adjust the cursor + position in del_bytes(). +Files: src/misc1.c, src/ops.c + +Patch 6.0.223 +Problem: When splitting a window that contains the explorer, hitting CR on + a file name gives error messages. +Solution: Set the window variables after splitting the window. +Files: runtime/plugin/explorer.vim + +Patch 6.0.224 +Problem: When 'sidescroll' and 'sidescrolloff' are set in a narrow window + the text may jump left-right and the cursor is displayed in the + wrong position. (Aric Blumer) +Solution: When there is not enough room, compute the left column for the + window to put the cursor in the middle. +Files: src/move.c + +Patch 6.0.225 +Problem: In Visual mode "gk" gets stuck in a closed fold. (Srinath + Avadhanula) +Solution: Behave differently in a closed fold. +Files: src/normal.c + +Patch 6.0.226 +Problem: When doing ":recover file" get the ATTENTION prompt. + After recovering the same file five times get a read error or a + crash. (Alex Davis) +Solution: Set the recoverymode flag before setting the file name. + Correct the amount of used memory for the size of block zero. +Files: src/ex_docmd.c + +Patch 6.0.227 (extra) +Problem: The RISC OS port has several problems. +Solution: Update the makefile and fix some of the problems. (Andy Wingate) +Files: src/Make_ro.mak, src/os_riscos.c, src/os_riscos.h, + src/proto/os_riscos.pro, src/search.c + +Patch 6.0.228 +Problem: After putting text in Visual mode the '] mark is not at the end of + the put text. + Undo doesn't work properly when putting a word into a Visual + selection that spans more than one line. +Solution: Correct the '] mark for the deleting the Visually selected text. + #ifdef code that depends on FEAT_VISUAL properly. + Also fix that "d" crossing line boundary puts '[ just before + deleted text. + Fix undo by saving all deleted lines at once. +Files: src/ex_docmd.c, src/globals.h, src/normal.c, src/ops.c, + src/structs.h, src/vim.h + +Patch 6.0.229 +Problem: Multi-byte: With 'm' in 'formatoptions', formatting doesn't break + at a multi-byte char followed by an ASCII char, and the other way + around. (Muraoka Taro) + When joining lines a space is inserted between multi-byte + characters, which is not always wanted. +Solution: Check for multi-byte character before and after the breakpoint. + Don't insert a space before or after a multi-byte character when + joining lines and the 'M' flag is in 'formatoptions'. Don't + insert a space between multi-byte characters when the 'B' flag is + in 'formatoptions'. +Files: src/edit.c, src/ops.c, src/option.h + +Patch 6.0.230 +Problem: The ":" used as a motion after an operator is exclusive, but + sometimes it should be inclusive. +Solution: Make the "v" in between an operator and motion toggle + inclusive/exclusive. (Servatius Brandt) +Files: runtime/doc/motion.txt, src/normal.c + +Patch 6.0.231 +Problem: "gd" and "gD" don't work when the variable matches in a comment + just above the match to be found. (Servatius Brandt) +Solution: Continue searching in the first column below the comment. +Files: src/normal.c + +Patch 6.0.232 +Problem: "vim --version" prints on stderr while "vim --help" prints on + stdout. +Solution: Make "vim --version" use stdout. +Files: runtime/doc/starting.txt, src/globals.h, src/main.c, src/message.c + +Patch 6.0.233 +Problem: "\1\{,8}" in a regexp is not allowed, but it should work, because + there is an upper limit. (Jim Battle) +Solution: Allow using "\{min,max}" after an atom that can be empty if there + is an upper limit. +Files: src/regexp.c + +Patch 6.0.234 +Problem: It's not easy to set the cursor position without modifying marks. +Solution: Add the cursor() function. (Yegappan Lakshmanan) +Files: runtime/doc/eval.txt, src/eval.c + +Patch 6.0.235 +Problem: When writing a file and renaming the original file to make the + backup, permissions could change when setting the owner. +Solution: Only set the owner when it's needed and set the permissions again + afterwards. + When 'backupcopy' is "auto" check that the owner and permissions + of a newly created file can be set properly. +Files: src/fileio.c + +Patch 6.0.236 +Problem: ":edit" without argument should move cursor to line 1 in Vi + compatible mode. +Solution: Add 'g' flag to 'cpoptions'. +Files: runtime/doc/options.txt, src/ex_docmd.c, src/option.h + +Patch 6.0.237 +Problem: In a C file, using the filetype plugin, re-indenting a comment + with two spaces after the middle "*" doesn't align properly. +Solution: Don't use a middle entry from a start/middle/end to line up with + the start of the comment when the start part doesn't match with + the actual comment start. +Files: src/misc1.c + +Patch 6.0.238 +Problem: Using a ":substitute" command with a substitute() call in the + substitution expression causes errors. (Srinath Avadhanula) +Solution: Save and restore pointers when doing substitution recursively. +Files: src/regexp.c + +Patch 6.0.239 +Problem: Using "A" to append after a Visually selected block which is after + the end of the line, spaces are inserted in the wrong line and + other unexpected effects. (Michael Naumann) +Solution: Don't advance the cursor to the next line. +Files: src/ops.c + +Patch 6.0.240 +Problem: Win32: building with Python 2.2 doesn't work. +Solution: Add support for Python 2.2 with dynamic linking. (Paul Moore) +Files: src/if_python.c + +Patch 6.0.241 +Problem: Win32: Expanding the old value of an option that is a path that + starts with a backslash, an extra backslash is inserted. +Solution: Only insert backslashes where needed. + Also handle multi-byte characters properly when removing + backslashes. +Files: src/option.c + +Patch 6.0.242 +Problem: GUI: On a system with an Exceed X server sometimes get a "Bad + Window" error. (Tommi Maekitalo) +Solution: When forking, use a pipe to wait in the parent for the child to + have done the setsid() call. +Files: src/gui.c + +Patch 6.0.243 +Problem: Unix: "vim --version" outputs a NL before the last line instead of + after it. (Charles Campbell) +Solution: Send the NL to the same output stream as the text. +Files: src/message.c, src/os_unix.c, src/proto/message.pro + +Patch 6.0.244 +Problem: Multi-byte: Problems with (illegal) UTF-8 characters in menu and + file name (e.g., icon text, status line). +Solution: Correctly handle unprintable characters. Catch illegal UTF-8 + characters and replace them with <xx>. Truncating the status line + wasn't done correctly at a multi-byte character. (Yasuhiro + Matsumoto) + Added correct_cmdspos() and transchar_byte(). +Files: src/buffer.c, src/charset.c, src/ex_getln.c, src/gui.c, + src/message.c, src/screen.c, src/vim.h + +Patch 6.0.245 +Problem: After using a color scheme, setting the 'background' option might + not work. (Peter Horst) +Solution: Disable the color scheme if it switches 'background' back to the + wrong value. +Files: src/option.c + +Patch 6.0.246 +Problem: ":echomsg" didn't use the highlighting set by ":echohl". (Gary + Holloway) +Solution: Use the specified attributes for the message. (Yegappan + Lakshmanan) +Files: src/eval.c + +Patch 6.0.247 +Problem: GTK GUI: Can't use gvim in a kpart widget. +Solution: Add the "--echo-wid" argument to let Vim echo the window ID on + stdout. (Philippe Fremy) +Files: runtime/doc/starting.txt, src/globals.h, src/gui_gtk_x11.c, + src/main.c + +Patch 6.0.248 +Problem: When using compressed help files and 'encoding' isn't "latin1", + Vim converts the help file before decompressing. (David Reviejo) +Solution: Don't convert a help file when 'binary' is set. +Files: src/fileio.c + +Patch 6.0.249 +Problem: "vim -t edit -c 'sta ex_help'" doesn't move cursor to edit(). +Solution: Don't set the cursor on the first line for "-c" arguments when + there also is a "-t" argument. +Files: src/main.c + +Patch 6.0.250 (extra) +Problem: Macintosh: Various problems when compiling. +Solution: Various fixes, mostly #ifdefs. (Dany St. Amant) +Files: src/gui_mac.c, src/main.c, src/misc2.c, src/os_mac.h, + src/os_mac.pbproj/project.pbxproj, src/os_unix.c + +Patch 6.0.251 (extra) +Problem: Macintosh: menu shortcuts are not very clear. +Solution: Show the shortcut with the Mac clover symbol. (raindog) +Files: src/gui_mac.c + +Patch 6.0.252 +Problem: When a user function was defined with "abort", an error that is + not inside if/endif or while/endwhile doesn't abort the function. + (Servatius Brandt) +Solution: Don't reset did_emsg when the function is to be aborted. +Files: src/ex_docmd.c + +Patch 6.0.253 +Problem: When 'insertmode' is set, after "<C-O>:edit file" the next <C-O> + doesn't work. (Benji Fisher) <C-L> has the same problem. +Solution: Reset need_start_insertmode once in edit(). +Files: src/edit.c + +Patch 6.0.254 (extra) +Problem: Borland C++ 5.5: Checking for stack overflow doesn't work + correctly. Matters when using a complicated regexp. +Solution: Remove -N- from Make_bc5.mak. (Yasuhiro Matsumoto) +Files: src/Make_bc5.mak + +Patch 6.0.255 (extra) (depends on patch 6.0.116 and 6.0.121) +Problem: Win32: ACL support doesn't work well on Samba drives. +Solution: Add a check for working ACL support. (Mike Williams) +Files: src/os_win32.c + +Patch 6.0.256 (extra) +Problem: Win32: ":highlight Comment guifg=asdf" does not give an error + message. (Randall W. Morris) Also for other systems. +Solution: Add gui_get_color() to give one error message for all systems. +Files: src/gui.c, src/gui_amiga.c, src/gui_athena.c, src/gui_motif.c, + src/gui_riscos.c, src/gui_x11.c, src/gui_gtk_x11.c, + src/proto/gui.pro, src/syntax.c + +Patch 6.0.257 +Problem: Win32: When 'mousefocus' is set and there is a BufRead + autocommand, after the dialog for permissions changed outside of + Vim: 'mousefocus' stops working. (Robert Webb) +Solution: Reset need_mouse_correct after checking timestamps. +Files: src/fileio.c + +Patch 6.0.258 +Problem: When 'scrolloff' is 999 and there are folds, the text can jump up + and down when moving the cursor down near the end of the file. + (Lubomir Host) +Solution: When putting the cursor halfway the window start counting lines at + the end of a fold. +Files: src/move.c + +Patch 6.0.259 +Problem: MS-DOS: after editing the command line the cursor shape may remain + like in Insert mode. (Volker Kiefel) +Solution: Reset the cursor shape after editing the command line. +Files: src/ex_getln.c + +Patch 6.0.260 +Problem: GUI: May crash while starting up when giving an error message for + missing color. (Servatius Brandt) +Solution: Don't call gui_write() when still starting up. Don't give error + message for empty color name. Don't use 't_vb' while the GUI is + still starting up. +Files: src/fileio.c, src/gui.c, src/misc1.c, src/ui.c + +Patch 6.0.261 +Problem: nr2char() and char2nr() don't work with multi-byte characters. +Solution: Use 'encoding' for these functions. (Yasuhiro Matsumoto) +Files: runtime/doc/eval.txt, src/eval.c + +Patch 6.0.262 (extra) +Problem: Win32: IME doesn't work properly. OnImeComposition() isn't used + at all. +Solution: Adjust various things for IME. +Files: src/globals.h, src/gui_w32.c, src/mbyte.c, src/proto/ui.pro, + src/structs.h, src/ui.c + +Patch 6.0.263 +Problem: GTK: When a dialog is closed by the window manager, Vim hangs. + (Christian J. Robinson) +Solution: Use GTK_WIDGET_DRAWABLE() instead of GTK_WIDGET_VISIBLE(). +Files: src/gui_gtk.c, src/gui_gtk_x11.c + +Patch 6.0.264 +Problem: The amount of virtual memory is used to initialize 'maxmemtot', + which may be much more than the amount of physical memory, + resulting in a lot of swapping. +Solution: Get the amount of physical memory with sysctl(), sysconf() or + sysinfo() when possible. +Files: src/auto/configure, src/configure.in, src/config.h.in, + src/os_unix.c, src/os_unix.h + +Patch 6.0.265 +Problem: Win32: Using backspace while 'fkmap' is set causes a crash. + (Jamshid Oasjmoha) +Solution: Don't try mapping special keys. +Files: src/farsi.c + +Patch 6.0.266 +Problem: The rename() function deletes the file if the old and the new name + are the same. (Volker Kiefel) +Solution: Don't do anything if the names are equal. +Files: src/fileio.c + +Patch 6.0.267 +Problem: UTF-8: Although 'isprint' says a character is printable, + utf_char2cells() still considers it unprintable. +Solution: Use vim_isprintc() for characters upto 0x100. (Yasuhiro Matsumoto) +Files: src/mbyte.c + +Patch 6.0.268 (extra) (depends on patch 6.0.255) +Problem: Win32: ACL check crashes when using forward slash in file name. +Solution: Improve the check for the path in the file name. +Files: src/os_win32.c + +Patch 6.0.269 +Problem: Unprintable characters in a file name may cause problems when + using the 'statusline' option or when 'buftype' is "nofile". +Solution: call trans_characters() for the resulting statusline. (Yasuhiro + Matsumoto) +Files: src/buffer.c, src/screen.c, src/charset.c + +Patch 6.0.270 (depends on patch 6.0.267) +Problem: A tab causes UTF-8 text to be displayed in the wrong position. + (Ron Aaron) +Solution: Correct utf_char2cells() again. +Files: src/mbyte.c + +Patch 6.1a.001 (extra) +Problem: 32bit DOS: copying text to the clipboard may cause a crash. + (Jonathan D Johnston) +Solution: Don't copy one byte too much in SetClipboardData(). +Files: src/os_msdos.c + +Patch 6.1a.002 +Problem: GTK: On some configurations, when closing a dialog from the window + manager, Vim hangs. +Solution: Catch the "destroy" signal. (Aric Blumer) +Files: src/gui_gtk.c + +Patch 6.1a.003 +Problem: Multi-byte: With UTF-8 double-wide char and 'virtualedit' set: + yanking in Visual mode doesn't include the last byte. (Eric Long) +Solution: Don't add a space for a double-wide character. +Files: src/ops.c + +Patch 6.1a.004 (extra) +Problem: MINGW: undefined type. (Ron Aaron) +Solution: Make GetCompositionString_inUCS2() static. +Files: src/gui_w32.c, src/gui_w48.c, src/proto/gui_w32.pro + +Patch 6.1a.005 (extra) +Problem: Win32: ":hardcopy" doesn't work after ":hardcopy!". (Jonathan + Johnston) +Solution: Don't keep the driver context when using ":hardcopy!". (Vince + Negri) +Files: src/os_mswin.c + +Patch 6.1a.006 +Problem: multi-byte: after setting 'encoding' the window title might be + wrong. +Solution: Force resetting the title. (Yasuhiro Matsumoto) +Files: src/option.c + +Patch 6.1a.007 +Problem: Filetype detection for "*.inc" doesn't work. +Solution: Use a ":let" command. (David Schweikert) +Files: runtime/filetype.vim + +Patch 6.1a.008 (extra) +Problem: Win32: ACL detection for network shares doesn't work. +Solution: Include the trailing (back)slash in the root path. (Mike Williams) +Files: src/os_win32.c + +Patch 6.1a.009 +Problem: When using "\@<=" or "\@<!" in a pattern, a "\1" may refer to a () + part that follows, but it generates an error message. +Solution: Allow a forward reference when there is a following "\@<=" or + "\@<!". +Files: runtime/doc/pattern.txt, src/regexp.c + +Patch 6.1a.010 +Problem: When using ":help" and opening a new window, the alternate file + isn't set. +Solution: Set the alternate file to the previously edited file. +Files: src/ex_cmds.c + +Patch 6.1a.011 +Problem: GTK: ":set co=77", change width with the mouse, ":set co=77" + doesn't resize the window. (Darren Hiebert) +Solution: Set the form size after handling a resize event. +Files: src/gui_gtk_x11.c + +Patch 6.1a.012 +Problem: GTK: The file browser always returns a full path. (Lohner) +Solution: Shorten the file name if possible. +Files: src/gui_gtk.c + +Patch 6.1a.013 +Problem: When using "=~word" in 'cinkeys' or 'indentkeys', the case of the + last character of the word isn't ignored. (Raul Segura Acevedo) +Solution: Ignore case when checking the last typed character. +Files: src/edit.c + +Patch 6.1a.014 +Problem: After patch 6.1a.006 can't compile without the title feature. +Solution: Add an #ifdef. +Files: src/option.c + +Patch 6.1a.015 +Problem: MS-Windows: When expanding a file name that contains a '[' or '{' + an extra backslash is inserted. (Raul Segura Acevedo) +Solution: Avoid adding the backslash. +Files: src/ex_getln.c + +Patch 6.1a.016 +Problem: Completion after ":language" doesn't include "time". (Raul Segura + Acevedo) +Solution: Add the alternative to the completions. +Files: src/ex_cmds2.c + +Patch 6.1a.017 +Problem: Clicking the mouse in the top row of a window where the first line + doesn't fit moves the cursor to the wrong column. +Solution: Add the skipcol also for the top row of a window. +Files: src/ui.c + +Patch 6.1a.018 +Problem: When 'scrolloff' is one and the window height is one, "gj" can put + the cursor above the window. (Raul Segura Acevedo) +Solution: Don't let skipcol become bigger than the cursor column. +Files: src/move.c + +Patch 6.1a.019 +Problem: When using a composing character on top of an ASCII character, the + "l" command clears the composing character. Only when 'ruler' and + 'showcmd' are off. (Raphael Finkel) +Solution: Don't move the cursor by displaying characters when there are + composing characters. +Files: src/screen.c + +Patch 6.1a.020 +Problem: GTK: after patch 6.1a.011 resizing with the mouse doesn't always + work well for small sizes. (Adrien Beau) +Solution: Use another way to avoid the problem with ":set co=77". +Files: src/gui_gtk_x11.c + +Patch 6.1a.021 +Problem: Several Syntax menu entries are wrong or confusing. +Solution: Rephrase and correct the menu entries. (Adrien Beau) +Files: runtime/makemenu.vim, runtime/menu.vim + +Patch 6.1a.022 +Problem: A tags file might be used twice on case insensitive systems. + (Rick Swanton) +Solution: Don't use the same file name twice in the default for the 'tags' + option. Ignore case when comparing names of already visited + files. +Files: src/misc2.c, src/option.c + +Patch 6.1a.023 +Problem: When starting the GUI get "C" characters echoed in the terminal. +Solution: Don't try sending a clear-screen command while the GUI is starting + up. +Files: src/screen.c + +Patch 6.1a.024 +Problem: In other editors CTRL-F is often used for a find dialog. +Solution: In evim use CTRL-F for the find dialog. +Files: runtime/evim.vim + +Patch 6.1a.025 +Problem: The choices for the fileformat dialog can't be translated. +Solution: Add g:menutrans_fileformat_choices. (Adrien Beau) +Files: runtime/menu.vim + +Patch 6.1a.026 +Problem: Indenting Java files is wrong with "throws", "extends" and + "implements" clauses. +Solution: Update the Java indent script. +Files: runtime/indent/java.vim + +Patch 6.1a.027 +Problem: A few Syntax menu entries missing or incorrect. +Solution: Add and correct the menu entries. (Adrien Beau) + Shorten a few menus to avoid they become too long. +Files: runtime/makemenu.vim, runtime/menu.vim + +Patch 6.1a.028 +Problem: XIM: problems with feedback and some input methods. +Solution: Use iconv for calculating the cells. Remove the queue for + key_press_event only when text was changed. (Yasuhiro Matsumoto) +Files: src/globals.h, src/mbyte.c, src/screen.c + +Patch 6.1a.029 +Problem: After patch 6.1a.028 can't compile GTK version with XIM but + without multi-byte chars. +Solution: Add an #ifdef. (Aschwin Marsman) +Files: src/mbyte.c + +Patch 6.1a.030 +Problem: With double-byte encodings toupper() and tolower() may have wrong + results. +Solution: Skip double-byte characters. (Eric Long) +Files: src/eval.c + +Patch 6.1a.031 +Problem: Accessing the 'balloondelay' variable may cause a crash. +Solution: Make the variable for 'balloondelay' a long. (Olaf Seibert) +Files: src/option.h + +Patch 6.1a.032 (extra) +Problem: Some menu files used a wrong encoding name for "scriptencoding". +Solution: Move the translations to a separate file, which is sourced after + setting "scriptencoding". + Also add Czech menu translations in ASCII and update the other + encodings. +Files: runtime/lang/menu_cs_cz.iso_8859-1.vim, + runtime/lang/menu_cs_cz.iso_8859-2.vim, + runtime/lang/menu_czech_czech_republic.1250.vim, + runtime/lang/menu_czech_czech_republic.1252.vim, + runtime/lang/menu_czech_czech_republic.ascii.vim, + runtime/lang/menu_de_de.iso_8859-1.vim, + runtime/lang/menu_de_de.latin1.vim, + runtime/lang/menu_fr_fr.iso_8859-1.vim, + runtime/lang/menu_fr_fr.latin1.vim, + runtime/lang/menu_french_france.1252.vim, + runtime/lang/menu_german_germany.1252.vim, + runtime/lang/menu_ja_jp.euc-jp.vim, + runtime/lang/menu_ja_jp.utf-8.vim, + runtime/lang/menu_japanese_japan.932.vim + +Patch 6.1a.033 +Problem: XIM: doesn't reset input context. +Solution: call xim_reset() with im_set_active(FALSE). (Takuhiro Nishioka) +Files: src/mbyte.c + +Patch 6.1a.034 (extra) +Problem: Win32: The ACL checks for a readonly file still don't work well. +Solution: Remove the ACL checks, go back to how it worked in Vim 6.0. +Files: src/os_win32.c + +Patch 6.1a.035 +Problem: multi-byte: When using ":sh" in the GUI, typed and displayed + multi-byte characters are not handled correctly. +Solution: Deal with multi-byte characters to and from the shell. (Yasuhiro + Matsumoto) Also handle UTF-8 composing characters. +Files: src/os_unix.c + +Patch 6.1a.036 +Problem: GTK: the save-yourself event was not handled. +Solution: Catch the save-yourself event and preserve swap files. (Neil Bird) +Files: src/gui_gtk_x11.c + +Patch 6.1a.037 +Problem: The MS-Windows key mapping doesn't include CTRL-S for saving. + (Vlad Sandrini) +Solution: Map CTRL-S to ":update". +Files: runtime/mswin.vim + +Patch 6.1a.038 +Problem: Solaris: Including both sys/sysctl.h and sys/sysinfo.h doesn't + work. (Antonio Colombo) +Solution: Don't include sys/sysinfo.h when not calling sysinfo(). +Files: src/os_unix.c + +Patch 6.1a.039 +Problem: Not all visual basic files are recognized. +Solution: Add checks to catch *.ctl files. (Raul Segura Acevedo) +Files: runtime/filetype.vim + +Patch 6.1a.040 +Problem: A *.pl file is recognized as Perl, but it could be a prolog file. +Solution: Check the first non-empty line. (Kontra Gergely) +Files: runtime/filetype.vim + +Patch 6.1a.041 +Problem: When pressing the left mouse button in the command line and them + moving the mouse upwards, nearly all the text is selected. +Solution: Don't try extending a modeless selection when there isn't one. +Files: src/ui.c + +Patch 6.1a.042 +Problem: When merging files, ":diffput" and ":diffget" are used a lot, but + they require a lot of typing. +Solution: Add "dp" for ":diffput" and "do" for ":diffget". +Files: runtime/doc/diff.txt, src/diff.c, src/normal.c, src/proto/diff.pro + + +Patch 6.1b.001 (extra) +Problem: Checking for wildcards in a path does not handle multi-byte + characters with a trail byte which is a wildcard. +Solution: Handle multi-byte characters correctly. (Muraoka Taro) +Files: src/os_amiga.c, src/os_mac.c, src/os_msdos.c, src/os_mswin.c, + src/os_unix.c + +Patch 6.1b.002 +Problem: A regexp that ends in "\{" is not flagged as an error. May cause + a stack overflow when 'incsearch' is set. (Gerhard Hochholzer) +Solution: Handle a missing "}" as an error. +Files: src/regexp.c + +Patch 6.1b.003 (extra) +Problem: The RISC OS GUI doesn't compile. +Solution: Include changes since Vim 5.7. (Andy Wingate) +Files: src/Make_ro.mak, src/gui_riscos.c, src/os_riscos.c, + src/os_riscos.h, src/proto/gui_riscos.pro + +Patch 6.1b.004 +Problem: col("'>") returns a negative number for linewise selection. (Neil + Bird) +Solution: Don't add one to MAXCOL. +Files: src/eval.c + +Patch 6.1b.005 +Problem: Using a search pattern that causes an out-of-stack error while + 'hlsearch' is set keeps giving the hit-Enter prompt. + A search pattern that takes a long time delays typing when + 'incsearch' is set. +Solution: Stop 'hlsearch' highlighting when the regexp causes an error. + Stop searching for 'incsearch' when a character is typed. +Files: src/globals.h, src/message.c, src/screen.c, src/search.c, + src/vim.h + +Patch 6.1b.006 +Problem: When entering a composing character on the command line with + CTRL-V, the text isn't redrawn correctly. +Solution: Redraw the text under and after the cursor. +Files: src/ex_getln.c + +Patch 6.1b.007 +Problem: When the cursor is in the white space between two sentences, "dis" + deletes the first character of the following sentence, "das" + deletes a space after the sentence. +Solution: Backup the cursor one character in these situations. +Files: src/search.c + +Patch 6.1b.008 +Problem: *.xsl files are not recognized as xslt but xml. + Monk files are not recognized. +Solution: Delete the duplicate line for *.xsl. (Johannes Zellner) + Recognize monk files. +Files: runtime/filetype.vim + +Patch 6.1b.009 +Problem: Can't always compile small features and then adding eval feature, + "sandbox" is undefined. (Axel Kielhorn) +Solution: Always define "sandbox" when the eval feature is used. +Files: src/globals.h + +Patch 6.1b.010 (extra) +Problem: When compiling gvimext.cpp with MSVC 4.2 get a number of warnings. +Solution: Change "true" to "TRUE". (Walter Briscoe) +Files: GvimExt/gvimext.cpp + +Patch 6.1b.011 +Problem: When using a very long string for confirm(), can't quit the + displaying at the more prompt. (Hari Krishna Dara) +Solution: Jump to the end of the message to show the choices. +Files: src/message.c + +Patch 6.1b.012 +Problem: Multi-byte: When 'showbreak' is set and a double-wide character + doesn't fit at the right window edge the cursor gets stuck there. + Using cursor-left gets stuck when 'virtualedit' is set. (Eric + Long) +Solution: Fix the way the extra ">" character is counted when 'showbreak' is + set. Don't correct cursor for virtual editing on a double-wide + character. +Files: src/charset.c, src/edit.c + +Patch 6.1b.013 +Problem: A user command that partly matches with a buffer-local user + command and matches full with a global user command unnecessarily + gives an 'ambiguous command' error. +Solution: Find the full global match even after a partly local match. +Files: src/ex_docmd.c + +Patch 6.1b.014 +Problem: EBCDIC: switching mouse events off causes garbage on screen. + Positioning the cursor in the GUI causes garbage. +Solution: Insert an ESC in the terminal code. (Ralf Schandl) + Use "\b" instead of "\010" for KS_LE. +Files: src/os_unix.c, src/term.c + +Patch 6.1b.015 +Problem: Vimtutor has a typo. Get a warning for "tempfile" if it + doesn't exist. +Solution: Move a quote to the end of a line. (Max Ischenko) + Use "mktemp" first, more systems have it. +Files: src/vimtutor + +Patch 6.1b.016 +Problem: GTK: loading a fontset that works partly, Vim might hang or crash. +Solution: Avoid that char_width becomes zero. (Yasuhiro Matsumoto) +Files: src/gui_gtk_x11.c + +Patch 6.1b.017 +Problem: GUI: When using ":shell" and there is a beep, nothing happens. +Solution: Call vim_beep() to produce the beep from the shell. (Yasuhiro + Matsumoto) +Files: src/message.c + +Patch 6.1b.018 (depends on 6.1b.006) +Problem: When entering the encryption key, special keys may still reveal + the typed characters. +Solution: Make sure stars are used or nothing is shown in all cases. +Files: src/digraph.c, src/getchar.c, src/ex_getln.c + +Patch 6.1b.019 (depends on 6.1b.005) +Problem: A search pattern that takes a long time slows down typing when + 'incsearch' is set. +Solution: Pass SEARCH_PEEK to dosearch(). +Files: src/ex_getln.c + +Patch 6.1b.020 +Problem: When using the matchit plugin, "%" finds a match on the "end" of a + ":syntax region" command in Vim scripts. +Solution: Skip over ":syntax region" commands by setting b:match_skip. +Files: runtime/ftplugin/vim.vim + +Patch 6.1b.021 +Problem: when 'mousefocus' is set, CTRL-W CTRL-] sometimes doesn't warp the + pointer to the new window. (Robert Webb) +Solution: Don't reset need_mouse_correct when checking the timestamp of a + file. +Files: src/fileio.c + +Patch 6.1b.022 +Problem: With lots of folds "j" does not obey 'scrolloff' properly. + (Srinath Avadhanula) +Solution: Go to end of the fold before counting context lines. +Files: src/move.c + +Patch 6.1b.023 +Problem: On MS-Windows system() may cause checking timestamps, because Vim + loses and gains input focus, while this doesn't happen on Unix. +Solution: Don't check timestamps while system() is busy. +Files: src/ex_cmds2.c, src/fileio.c, src/globals.h, src/misc1.c + +Patch 6.1b.024 (extra) +Problem: Gettext 0.11 complains that "sjis" is not a standard name. +Solution: Use "cp932" instead. +Files: src/po/sjiscorr.c + +Patch 6.1b.025 (extra) +Problem: Win32: When closing gvim while it is minimized and has a changed + file, the file-changed dialog pops up in a corner of the screen. +Solution: Put the dialog in the middle of the screen. +Files: src/gui_w48.c + +Patch 6.1b.026 +Problem: When 'diffopt' contains 'iwhite' but not 'icase': differences in + case are not highlighted properly. (Gerhard Hochholzer) +Solution: Don't ignore case when ignoring white space differences. +Files: src/diff.c + +Patch 6.1b.027 +Problem: "vim --remote +" may cause a crash. +Solution: Check for missing file name argument. (Martin Kahlert) +Files: src/main.c + +Patch 6.1b.028 (extra) +Problem: Win16: Can't compile after patch 6.1b.025. +Solution: Add code specifically for Win16. (Vince Negri) +Files: src/gui_w48.c + +Patch 6.1b.029 +Problem: Win32: When a directory on an NTFS partition is read/execute (no + delete,modify,write) and the file has modify rights, trying to + write the file deletes it. Making the file read/write/execute + (not delete) solves it. (Mark Canup) +Solution: Use the Unix code to check for a writable directory. If not, then + make a backup copy and overwrite the file. +Files: src/fileio.c + +Patch 6.1b.030 (extra) +Problem: Mac: small mistake in the build script and prototypes. +Solution: Fix the build script and add the prototypes. (Axel Kielhorn) +Files: src/os_mac.build, src/gui_mac.c + +Patch 6.1b.031 (extra) +Problem: Win32 GUI: ":set guifont=*" doesn't set 'guifont' to the resulting + font name. (Vlad Sandrini) +Solution: Put the code back in gui_mch_init_font() to form the font name out + of the logfont. +Files: src/gui_w48.c + +Patch 6.1b.032 +Problem: Athena: Setting a color scheme before the GUI has started causes a + crash. (Todd Blumer) +Solution: Don't try using color names that haven't been set yet. +Files: src/gui_athena.c + +Patch 6.1b.033 +Problem: When using a count after a ":s" command may get ml_get errors. + (Dietmar Lang) +Solution: Check that the resulting range does not go past the end of the + buffer. +Files: src/ex_cmds.c + +Patch 6.1b.034 +Problem: After sourcing mswin.vim, when using <C-S-Right> after + auto-indenting and then <Del>, get warning for allocating + ridiculous amount of memory. (Dave Delgreco) +Solution: Adjust the start of the Visual area when deleting the auto-indent. +Files: src/edit.c + +Patch 6.1b.035 +Problem: When using evim, dropping a file on Vim and then double clicking + on a word, it is changed to "i". (Merlin Hansen) +Solution: Reset need_start_insertmode after editing the file. +Files: src/ex_docmd.c + + +============================================================================== +VERSION 6.2 *version-6.2* + +This section is about improvements made between version 6.1 and 6.2. + +This is mainly a bug-fix release. There are also a few new features. + +Main new features: +- Support for GTK 2. (Daniel Elstner) +- Support for editing Arabic text. (Nadim Shaikli & Isam Bayazidi) +- ":try" command and exception handling. (Servatius Brandt) +- Support for the neXtaw GUI toolkit (mostly like Athena). (Alexey Froloff) +- Cscope support for Win32. (Khorev Sergey) +- Support for PostScript printing in various 8-bit encodings. (Mike Williams) + + +Changed *changed-6.2* +------- + +Removed the scheme indent file, the internal Lisp indenting works well now. + +Moved the GvimEXt, OleVim and VisVim directories into the "src" directory. +This is more consistent with how xxd is handled. + +The VisVim.dll file is installed in the top directory, next to gvimext.dll, +instead of in a subdirectory "VisVim". Fixes that NSIS was uninstalling it +from the wrong directory. + +Removed the art indent file, it didn't do anything. + +submatch() returned line breaks with CR instead of LF. + +Changed the Win32 Makefiles to become more uniform and compile gvimext.dll. +(Dan Sharp) + +'cindent': Align a "//" comment with a "//" comment in a previous line. +(Helmut Stiegler) + +Previously only for xterm-like terminals parent widgets were followed to find +the title and icon label. Now do this for all terminal emulators. + +Made it possible to recognize backslashes for "%" matching. The 'M' flag in +'cpoptions' disables it. (Haakon Riiser) + +Removed the Make_tcc.mak makefile for Turbo C. It didn't work and we probably +can't make it work (the compiler runs out of memory). + +Even though the documentation refers to keywords, "[ CTRL-D" was using +'isident' to find matches. Changed it to use 'iskeyword'. Also applies to +other commands that search for defined words in included files such as +":dsearch", "[D" and "[d". + +Made 'keywordprg' global-local. (Christian Robinson) + +Enabled the Netbeans interface by default. Reversed the configure argument +from "--enable-netbeans" to "--disable-netbeans". + + +Added *added-6.2* +----- + +New options: + 'arabic' + 'arabicshape' + 'ambiwidth' + 'autochdir' + 'casemap' + 'copyindent' + 'cscopequickfix' + 'preserveindent' + 'printencoding' + 'rightleftcmd' + 'termbidi' + 'toolbariconsize' + 'winfixheight' + +New keymaps: + Serbian (Aleksandar Veselinovic) + Chinese Pinyin (Fredrik Roubert) + Esperanto (Antoine J. Mechelynck) + +New syntax files: + Valgrind (Roger Luethi) + Smarty template (Manfred Stienstra) + MySQL (Kenneth Pronovici) + RockLinux package description (Piotr Esden-Tempski) + MMIX (Dirk Huesken) + gkrellmrc (David Necas) + Tilde (Tobias Rundtrom) + Logtalk (Paulo Moura) + PLP (Juerd Waalboer) + fvwm2m4 (David Necas) + IPfilter (Hendrik Scholz) + fstab (Radu Dineiu) + Quake (Nikolai Weibull) + Occam (Mario Schweigler) + lpc (Shizhu Pan) + Exim conf (David Necas) + EDIF (Artem Zankovich) + .cvsrc (Nikolai Weibull) + .fetchmailrc (Nikolai Weibull) + GNU gpg (Nikolai Weibull) + Grub (Nikolai Weibull) + Modconf (Nikolai Weibull) + RCS (Dmitry Vasiliev) + Art (Dorai Sitaram) + Renderman Interface Bytestream (Andrew J Bromage) + Mailcap (Doug Kearns) + Subversion commit file (Dmitry Vasiliev) + Microsoft IDL (Vadim Zeitlin) + WildPackets EtherPeek Decoder (Christopher Shinn) + Spyce (Rimon Barr) + Resolv.conf (Radu Dineiu) + A65 (Clemens Kirchgatterer) + sshconfig and sshdconfig (David Necas) + Cheetah and HTMLCheetah (Max Ischenko) + Packet filter (Camiel Dobbelaar) + +New indent files: + Eiffel (David Clarke) + Tilde (Tobias Rundtrom) + Occam (Mario Schweigler) + Art (Dorai Sitaram) + PHP (Miles Lott) + Dylan (Brent Fulgham) + +New tutor translations: + Slovak (Lubos Celko) + Greek (Christos Kontas) + German (Joachim Hofmann) + Norwegian (Øyvind Holm) + +New filetype plugins: + Occam (Mario Schweigler) + Art (Dorai Sitaram) + ant.vim, aspvbs.vim, config.vim, csc.vim, csh.vim, dtd.vim, html.vim, + jsp.vim, pascal.vim, php.vim, sgml.vim, sh.vim, svg.vim, tcsh.vim, + xhtml.vim, xml.vim, xsd.vim. (Dan Sharp) + +New compiler plugins: + Checkstyle (Doug Kearns) + g77 (Ralf Wildenhues) + fortran (Johann-Guenter Simon) + Xmllint (Doug Kearns) + Ruby (Tim Hammerquist) + Modelsim vcom (Paul Baleme) + +New menu translations: + Brazilian (José de Paula) + British (Mike Williams) + Korean in UTF-8. (Nam SungHyun) + Norwegian (Øyvind Holm) + Serbian (Aleksandar Jelenak) + +New message translation for Norwegian. (Øyvind Holm) + +New color scheme: + desert (Hans Fugal) + +Arabic specific features. 'arabicshape', 'termbidi', 'arabic' and +'rightleftcmd' options. (Nadim Shaikli & Isam Bayazidi) + +Support for neXtaw GUI toolkit, mostly like Athena. (Alexey Froloff) + +Win32: cscope support. (Khorev Sergey) + +VMS: various improvements to documentation and makefiles. (Zoltan Arpadffy) + +Added "x" key to the explorer plugin: execute the default action. (Yasuhiro +Matsumoto) + +Compile gvimext.dll with MingW. (Rene de Zwart) + +Add the "tohtml.vim" plugin. It defines the ":TOhtml" user command, an easy +way to convert text to HTML. + +Added ":try" / ":catch" / ":finally" / ":endtry" commands. Add E999 numbers +to all error messages, so that they can be caught by the number. +(Servatius Brandt) +Moved part of ex_docmd.c to the new ex_eval.c source file. + +Include support for GTK+ 2.2.x (Daniel Elstner) +Adds the "~" register: drag & drop text. +Adds the 'toolbariconsize' option. +Add -Dalloca when running lint to work around a problem with alloca() +prototype. + +When selecting an item in the error window to jump to, take some effort to +find an ordinary window to show the file in (not a preview window). + +Support for PostScript printing of various 8-bit encodings. (Mike Williams) + +inputdialog() accepts a third argument that is used when the dialog is +cancelled. Makes it possible to see a difference between cancelling and +entering nothing. + +Included Aap recipes. Can be used to update Vim to the latest version, +building and installing. + +"/" option in 'cinoptions': extra indent for comment lines. (Helmut Stiegler) + +Vim variable "v:register" and functions setreg(), getreg() and getregtype(). +(Michael Geddes) + +"v" flag in 'cpoptions': Leave text on screen with backspace in Insert mode. +(Phillip Vandry) + +Dosinst.exe also finds gvimext.dll in the "GvimExt" directory. Useful when +running install in the "src" directory for testing. + +Support tag files that were sorted with case ignored. (Flemming Madsen) + +When completing a wildcard in a leading path element, as in "../*/Makefile", +only the last part ("Makefile") was listed. Support custom defined +command line completion. (Flemming Madsen) + +Also recognize "rxvt" as an xterm-like terminal. (Tomas Styblo) + +Proper X11 session management. Fixes that the WM_SAVE_YOURSELF event was not +used by popular desktops. (Neil Bird) +Not used for Gnome 2, it has its own handling. + +Support BOR, DEBUG and SPAWNO arguments for the Borland 3 Makefile. (Walter +Briscoe) + +Support page breaks for printing. Adds the "formfeed" field in +'printoptions'. (Mike Williams) + +Mac OSX: multi-language support: iconv and gettext. (Muraoka Taro, Axel +Kielhorn) + +"\Z" flag in patterns: ignore differences in combining characters. (Ron Aaron) + +Added 'preserveindent' and 'copyindent' options. They use existing white +space characters instead of using Tabs as much as possible. (Chris Leishman) + +Updated Unicode tables to Unicode 4.0. (Raphael Finkel) + +Support for the mouse wheel in rxvt. (AIDA Shinra) + +Win32: Added ":8" file modifier to get short filename. Test50 tests the ":8" +expansion on Win32 systems. (Michael Geddes) + +'cscopequickfix' option: Open quickfix window for Cscope commands. Also +cleanup the code for giving messages. (Khorev Sergey) + +GUI: Support more than 222 columns for mouse positions. + +":stopinsert" command: Don't return to Insert mode. + +"interrupt" command for debug mode. Useful for simulating CTRL-C. (Servatius +Brandt) + + +Fixed *fixed-6.2* +----- + +Removed a few unused #defines from config.h.in, os_os2_cfg.h and os_vms_conf.h. + +The Vim icons in PNG format didn't have a transparent background. (Greg +Roelofs) + +Fixed a large number of spelling mistakes in the docs. (Adri Verhoef) + +The #defines for prototype generation were causing trouble. Changed them to +typedefs. + +A new version of libintl.h uses __asm__, which confuses cproto. Define a +dummy __asm__ macro. + +When 'virtualedit' is set can't move to halfway an unprintable character. +Cripples CTRL-V selection. (Taro Muraoka) +Allow moving to halfway an unprintable character. Don't let getvvcol() change +the pos->coladd argument. + +When a tab wraps to the next line, 'listchars' is set and 'foldcolumn' is +non-zero, only one character of the foldcolumn is highlighted. (Muraoka Taro) + +When using ":catch" without an argument Vim crashes. (Yasuhiro Matsumoto) +When no argument given use the ".*" pattern. + +Win32: When gvim.exe is started from a shortcut with the window style property +set to maximize Vim doesn't start with a maximized window. (Yasuhiro +Matsumoto) Open the window with the default size and don't call ShowWindow() +again when it's already visible. (Helmut Stiegler) + +gui_gtk.c used MAX, but it's undefined to avoid a conflict with system header +files. + +Win32: When closing a window from a mapping some pixels remain on the +statusline. (Yasuhiro Matsumoto) + +A column number in an errorformat that goes beyond the end of the line may +cause a crash. + +":throw 'test'" crashes Vim. (Yasuhiro Matsumoto) + +The file selector's scrollbar colors are not set after doing a ":hi Scrollbar +guifg=color". And the file selector's colors are not changed by the +colorscheme command. (David Harrison) + +Motif: When compiling with FEAT_FOOTER defined, the text area gets a few +pixels extra space on the right. Remove the special case in +gui_get_base_width(). (David Harrison) + +Using CTRL-R CTRL-P in Insert mode puts the '] mark in the wrong position. +(Helmut Stiegler) + +When 'formatoptions' includes "awct" a non-comment wasn't auto-formatted. + +Using a "--cmd" argument more than 10 times caused a crash. + +DEC style mouse support didn't work if the page field is not empty. +(Uribarri) + +"vim -l one two" did only set 'lisp' in the first file. Vi does it for every +file. + +":set tw<" didn't work. Was checking for '^' instead of '<'. + +In ":hardcopy > %.ps" the "%" was not expanded to the current filename. + +Made ":redraw" also update the Visual area. + +When a not implemented command, such as ":perl", has wrong arguments the less +important error was reported, giving the user the idea the command could work. + +On non-Unix systems autocommands for writing did not attempt a match with the +short file name, causing a pattern like "a/b" to fail. + +VMS: e_screenmode was not defined and a few other fixes for VMS. (Zoltan +Arpadffy) + +redraw_msg() depended on FEAT_ARABIC instead of FEAT_RIGHTLEFT. (Walter +Briscoe) + +Various changes for the PC Makefiles. (Walter Briscoe) + +Use _truename() instead of our own code to expand a file name into a full +path. (Walter Briscoe) + +Error in filetype check for /etc/modutils. (Lubomir Host) + +Cscope interface: allocated a buffer too small. + +Win16: remove a trailing backslash from a path when obtaining the permission +flags. (Vince Negri) + +When searching for tags with case ignored Vim could hang. + +When searching directories with a stopdir could get a crash. Did not +re-allocate enough memory. (Vince Negri) + +A user command may cause a crash. Don't use the command index when it's +negative. (Vince Negri) + +putenv() didn't work for MingW and Cygwin. (Dan Sharp) + +Many functions were common between os_msdos.c and os_win16.c. Use os_msdos.c +for compiling the Win16 version and remove the functions from os_win16.c. +(Vince Negri) + +For terminals that behave like an xterm but didn't have a name that is +recognized, the window title would not always be set. + +When syntax highlighting is off ":hardcopy" could still attempt printing +colors. + +Crash when using ":catch" without an argument. (Servatius Brandt) + +Win32: ":n #" doubled the backslashes. + +Fixed Arabic shaping for the command line. (Nadim Shaikli) + +Avoid splitting up a string displayed on the command line into individual +characters, it breaks Arabic shaping. + +Updated Cygwin and MingW makefiles to use more dependencies. (Dan Sharp) + +2html.vim didn't work with 'nomagic' set. + +When a local argument list is used and doing ":only" Vim could crash later. +(Muraoka Taro) + +When using "%P" in 'statusline' and the fillchar is "-", a percentage of 3% +could result in "-3%". Also avoid changing a space inside a filename to the +fill character. + +MSwin: Handling of backslashes and double quotes for command line arguments +was not like what other applications do. (Walter Briscoe) + +Test32 sometimes didn't work, because test11.out was written as TEST11.OUT. + +Avoid pointer conversions warnings for Borland C 5.5 in dosinst.c and +uninstal.c. + +More improvements for Make_bc3.mak file. (Walter Briscoe) + +When ":syn sync linebreaks=1" is used, editing the first line caused a redraw +of the whole screen. + +Making translated messages didn't work, if_perl.xs wasn't found. (Vlad +Sandrini) + +Motif and Athena: moving Vim to the foreground didn't uniconify it. Use +XMapRaised() instead of XRaiseWindow(). (Srikanth Sankaran) + +When using ":ptag" in a window where 'scrollbind' is set the preview window +would also have 'scrollbind' set. Also reset 'foldcolumn' and 'diff'. + +Various commands that split a window took over 'scrollbind', which is hardly +ever desired. Esp. for "q:" and ":copen". Mostly reset 'scrollbind' when +splitting a window. + +When 'shellslash' is set in the vimrc file the first entry of ":scriptnames" +would still have backslashes. Entries in the quickfix list could also have +wrong (back)slashes. + +Win32: printer dialog texts were not translated. (Yasuhiro Matsumoto) + +When using a multi-byte character with a K_SPECIAL byte or a special key code +with "--remote-send" the received byte sequence was mangled. Put it in the +typeahead buffer instead of the input buffer. + +Win32: The cursor position was incorrect after changing cursor shape. +(Yasuhiro Matsumoto). + +Win32: When 'encoding' is not the current codepage the title could not be set +to non-ascii characters. + +"vim -d scp://machine/file1 scp://machine/file2" did not work, there was only +one window. Fixed the netrw plugin not to wipe out the buffer if it is +displayed in other windows. + +"/$" caused "e" in last column of screen to disappear, a highlighted blank was +displayed instead. + +":s/ *\ze\n//e" removed the line break and introduced arbitrary text. Was +using the line count including what matched after the "\ze". + +Using the "c" flag with ":s" changed the behavior when a line break is +replaced and "\@<=" is used. Without "c" a following match was not found. + +":%s/\vA@<=\nB@=//gce" got stuck on "A\nB" when entering "n". + +VMS: add HAVE_STRFTIME in the config file. (Zoltan Arpadffy) + +When a delete prompts if a delete should continue when yanking is not +possible, restore msg_silent afterwards. + +":sign" did not complain about a missing argument. + +When adding or deleting a sign 'hlsearch' highlighting could disappear. +Use the generic functions for updating signs. + +On MS-Windows NT, 2K and XP don't use command.com but cmd.exe for testing. +Makes the tests work on more systems. + +In the DOS tests don't create "/tmp" to avoid an error. + +Mac classic: Problems with reading files with CR vs CR/LF. Rely on the +library version of fgets() to work correctly for Metrowerks 2.2. (Axel +Kielhorn) + +When typing a password a "*" was shown for each byte instead of for each +character. Added multi-byte handling to displaying the stars. (Yasuhiro +Matsumoto) + +When using Perl 5.6 accessing $curbuf doesn't work. Add an #ifdef to use +different code for 5.6 and 5.8. (Dan Sharp) + +MingW and Cygwin: Don't strip the debug executable. (Dan Sharp) + +An assignment to a variable with curlies that includes "==" doesn't work. +Skip over the curlies before searching for an "=". (Vince Negri) + +When cancelling the selection of alternate matching tags the tag stack index +could be advanced too far, resulting in an error message when using CTRL-T. + + +Patch 6.1.001 +Problem: When formatting UTF-8 text it might be wrapped at a space that is + followed by a composing character. (Raphael Finkel) + Also correct a display error for removing a composing char on top + of a space. +Solution: Check for a composing character on a space. +Files: src/edit.c, src/misc1.c, src/screen.c + +Patch 6.1.002 (extra) +Problem: Win32: after a ":popup" command the mouse pointer stays hidden. +Solution: Unhide the mouse pointer before showing the menu. +Files: src/gui_w48.c + +Patch 6.1.003 +Problem: When 'laststatus' is zero and there is a vertical split, the + vertical separator is drawn in the command line. (Srikant + Sankaran) +Solution: Don't draw the vertical separator where there is no statusline. +Files: src/screen.c + +Patch 6.1.004 +Problem: Unicode 3.2 changes width and composing of a few characters. + (Markus Kuhn) +Solution: Adjust the Unicode functions for the character width and composing + characters. +Files: src/mbyte.c + +Patch 6.1.005 +Problem: When using more than 50 items in 'statusline' Vim might crash. + (Steve Hall) +Solution: Increment itemcnt in check_stl_option(). (Flemming Madsen) +Files: src/option.c + +Patch 6.1.006 +Problem: When using "P" in Visual mode to put linewise selected text, the + wrong text is deleted. (Jakub Turski) +Solution: Put the text before the Visual area and correct the text to be + deleted for the inserted lines. + Also fix that "p" of linewise text in Visual block mode doesn't + work correctly. +Files: src/normal.c, src/ops.c + +Patch 6.1.007 +Problem: Using ":filetype plugin off" when filetype plugins were never + enabled causes an error message. (Yiu Wing) +Solution: Use ":silent!" to avoid the error message. +Files: runtime/ftplugof.vim + +Patch 6.1.008 +Problem: The "%" command doesn't ignore \" inside a string, it's seen as + the end of the string. (Ken Clark) +Solution: Skip a double quote preceded by an odd number of backslashes. +Files: src/search.c + +Patch 6.1.009 +Problem: Vim crashes when using a huge number for the maxwid value in a + statusline. (Robert M. Nowotniak) +Solution: Check for an overflow that makes maxwid negative. +Files: src/buffer.c + +Patch 6.1.010 +Problem: Searching backwards for a question mark with "?\?" doesn't work. + (Alan Isaac) Same problem in ":s?\??" and ":g?\??". +Solution: Change the "\?" in a pattern to "?" when using "?" as delimiter. +Files: src/ex_cmds.c, src/ex_docmd.c, src/proto/regexp.pro, src/regexp.c, + src/search.c, src/syntax.c, src/tag.c + +Patch 6.1.011 +Problem: XIM: doesn't work correctly when 'number' is set. Also, a focus + problem when selecting candidates. +Solution: Fix the XIM problems. (Yasuhiro Matsumoto) +Files: src/mbyte.c, src/screen.c + +Patch 6.1.012 +Problem: A system() call might fail if fread() does CR-LF to LF + translation. +Solution: Open the output file in binary mode. (Pavol Huhas) +Files: src/misc1.c + +Patch 6.1.013 +Problem: Win32: The default for 'printexpr' doesn't work when there are + special characters in 'printdevice'. +Solution: Add double quotes around the device name. (Mike Williams) +Files: runtime/doc/option.txt, src/option.c + +Patch 6.1.014 +Problem: An operator like "r" used in Visual block mode doesn't use + 'virtualedit' when it's set to "block". +Solution: Check for 'virtualedit' being active in Visual block mode when the + operator was started. +Files: src/ex_docmd.c, src/globals.h, src/misc2.c, src/normal.c, + src/ops.c, src/undo.c + +Patch 6.1.015 +Problem: After patch 6.1.014 can't compile with tiny features. (Christian + J. Robinson) +Solution: Add the missing define of virtual_op. +Files: src/vim.h + +Patch 6.1.016 (extra) +Problem: Win32: Outputting Hebrew or Arabic text might have a problem with + reversing. +Solution: Replace the RevOut() function with ETO_IGNORELANGUAGE. (Ron Aaron) +Files: src/gui_w32.c + +Patch 6.1.017 +Problem: Cygwin: After patch 6.1.012 Still doesn't do binary file I/O. + (Pavol Juhas) +Solution: Define BINARY_FILE_IO for Cygwin. +Files: src/os_unix.h + +Patch 6.1.018 +Problem: Error message when using cterm highlighting. (Leonardo Di Lella) +Solution: Remove a backslash before a question mark. +Files: runtime/syntax/cterm.vim + +Patch 6.1.019 (extra) +Problem: Win32: File name is messed up when editing just a drive name. + (Walter Briscoe) +Solution: Append a NUL after the drive name. (Vince Negri) +Files: src/os_win32.c + +Patch 6.1.020 +Problem: col("'>") returns a huge number after using Visual line mode. +Solution: Return the length of the line instead. +Files: src/eval.c + +Patch 6.1.021 (depends on patch 6.1.009) +Problem: Vim crashes when using a huge number for the minwid value in a + statusline. (Robert M. Nowotniak) +Solution: Check for an overflow that makes minwid negative. +Files: src/buffer.c + +Patch 6.1.022 +Problem: Grabbing the status line above the command-line window works like + the bottom status line was grabbed. (Jim Battle) +Solution: Make it possible to grab the status line above the command-line + window, so that it can be resized. +Files: src/ui.c + +Patch 6.1.023 (extra) +Problem: VMS: running tests doesn't work properly. +Solution: Adjust the makefile. (Zoltan Arpadffy) +Files: src/testdir/Make_vms.mms + +Patch 6.1.024 +Problem: When header files use a new syntax for declaring functions, Vim + can't figure out missing prototypes properly. +Solution: Accept braces around a function name. (M. Warner Losh) +Files: src/osdef.sh + +Patch 6.1.025 +Problem: Five messages for "vim --help" don't start with a capital. (Vlad + Sandrini) +Solution: Make the messages consistent. +Files: src/main.c + +Patch 6.1.026 +Problem: *.patch files are not recognized as diff files. In a script a + "VAR=val" argument after "env" isn't ignored. PHP scripts are not + recognized. +Solution: Add *.patch for diff filetypes. Ignore "VAR=val". Recognize PHP + scripts. (Roman Neuhauser) +Files: runtime/filetype.vim, runtime/scripts.vim + +Patch 6.1.027 +Problem: When 'foldcolumn' is non-zero, a special character that wraps to + the next line disturbs the foldcolumn highlighting. (Yasuhiro + Matsumoto) +Solution: Only use the special highlighting when drawing text characters. +Files: src/screen.c + +Patch 6.1.028 +Problem: Client-server: When a --remote-expr fails, Vim still exits with + status zero. +Solution: Exit Vim with a non-zero status to indicate the --remote-expr + failed. (Thomas Scott Urban) +Files: src/main.c + +Patch 6.1.029 +Problem: When 'encoding' is an 8-bit encoding other than "latin1", editing + a utf-8 or other Unicode file uses the wrong conversion. (Jan + Fedak) +Solution: Don't use Unicode to latin1 conversion for 8-bit encodings other + than "latin1". +Files: src/fileio.c + +Patch 6.1.030 +Problem: When CTRL-N is mapped in Insert mode, it is also mapped after + CTRL-X CTRL-N, while it is not mapped after CTRL-X CTRL-F. + (Kontra Gergely) +Solution: Don't map CTRL-N after CTRL-X CTRL-N. Same for CTRL-P. +Files: src/getchar.c + +Patch 6.1.031 +Problem: Cygwin: Xxd could read a file in text mode instead of binary mode. +Solution: Use "rb" or "rt" when needed. (Pavol Juhas) +Files: src/xxd/xxd.c + +Patch 6.1.032 +Problem: Can't specify a quickfix file without jumping to the first error. +Solution: Add the ":cgetfile" command. (Yegappan Lakshmanan) +Files: runtime/doc/index.txt, runtime/doc/quickfix.txt, src/ex_cmds.h, + src/quickfix.c + +Patch 6.1.033 +Problem: GUI: When the selection is lost and the Visual highlighting is + changed to underlining, the cursor is left in a different + position. (Christian Michon) +Solution: Update the cursor position after redrawing the selection. +Files: src/ui.c + +Patch 6.1.034 +Problem: A CVS diff file isn't recognized as diff filetype. +Solution: Skip lines starting with "? " before checking for an "Index:" line. +Files: runtime/scripts.vim + +Patch 6.1.035 (extra, depends on 6.1.016) +Problem: Win32: Outputting Hebrew or Arabic text might have a problem with + reversing on MS-Windows 95/98/ME. +Solution: Restore the RevOut() function and use it in specific situations + only. (Ron Aaron) +Files: src/gui_w32.c + +Patch 6.1.036 +Problem: This command may cause a crash: ":v/./,//-j". (Ralf Arens) +Solution: Compute the right length of the regexp when it's empty. +Files: src/search.c + +Patch 6.1.037 +Problem: When 'lazyredraw' is set, pressing "q" at the hit-enter prompt + causes an incomplete redraw and the cursor isn't positioned. + (Lubomir Host) +Solution: Overrule 'lazyredraw' when do_redraw is set. +Files: src/main.c, src/screen.c + +Patch 6.1.038 +Problem: Multi-byte: When a ":s" command contains a multi-byte character + where the trail byte is '~' the text is messed up. +Solution: Properly skip multi-byte characters in regtilde() (Muraoka Taro) +Files: src/regexp.c + +Patch 6.1.039 +Problem: When folds are defined and the file is changed outside of Vim, + reloading the file doesn't update the folds. (Anders + Schack-Nielsen) +Solution: Recompute the folds after reloading the file. +Files: src/fileio.c + +Patch 6.1.040 +Problem: When changing directory for expanding a file name fails there is + no error message. +Solution: Give an error message for this situation. Don't change directory + if we can't return to the original directory. +Files: src/diff.c, src/ex_docmd.c, src/globals.h, src/misc1.c, + src/os_unix.c + +Patch 6.1.041 +Problem: ":mkvimrc" doesn't handle a mapping that has a leading space in + the rhs. (Davyd Ondrejko) +Solution: Insert a CTRL-V before the leading space. Also display leading + and trailing white space in <> form. +Files: src/getchar.c, src/message.c + +Patch 6.1.042 +Problem: "vim -r" doesn't show all matches when 'wildignore' removes swap + files. (Steve Talley) +Solution: Keep all matching swap file names. +Files: src/memline.c + +Patch 6.1.043 +Problem: After patch 6.1.040 a few warnings are produced. +Solution: Add a type cast to "char *" for mch_chdir(). (Axel Kielhorn) +Files: src/diff.c, src/ex_docmd.c.c, src/misc1.c, src/os_unix.c + +Patch 6.1.044 (extra) +Problem: GUI: When using the find/replace dialog with text that contains a + slash, an invalid substitute command is generated. + On Win32 a find doesn't work when 'insertmode' is set. +Solution: Escape slashes with a backslash. + Make the Win32, Motif and GTK gui use common code for the + find/replace dialog. + Add the "match case" option for Motif and GTK. +Files: src/feature.h, src/proto/gui.pro, src/gui.c, src/gui.h, + src/gui_motif.c, src/gui_gtk.c, src/gui_w48.c + +Patch 6.1.045 +Problem: In Visual mode, with lots of folds and 'scrolloff' set to 999, + moving the cursor down near the end of the file causes the text to + jump up and down. (Lubomir Host) +Solution: Take into account that the cursor may be on the last line of a + closed fold. +Files: src/move.c + +Patch 6.1.046 +Problem: X11 GUI: ":set lsp=2 gcr=n-v-i:hor1-blinkon0" draws a black + rectangle. ":set lsp=2 gcr=n-v-i:hor10-blinkon0" makes the cursor + disappear. (Nam SungHyun) +Solution: Correctly compute the height of the horizontal cursor. +Files: src/gui_gtk_x11.c, src/gui_x11.c + +Patch 6.1.047 +Problem: When skipping commands after an error was encountered, expressions + for ":if", ";elseif" and ":while" are still evaluated. +Solution: Skip the expression after an error. (Servatius Brandt) +Files: src/ex_docmd.c + +Patch 6.1.048 +Problem: Unicode 3.2 changes were missing a few Hangul Jamo characters. +Solution: Recognize more characters as composing characters. (Jungshik Shin) +Files: src/mbyte.c + +Patch 6.1.049 (extra) +Problem: On a 32 bit display a valid color may cause an error message, + because its pixel value is negative. (Chris Paulson-Ellis) +Solution: Check for -11111 instead of the color being negative. + Don't add one to the pixel value, -1 may be used for white. +Files: src/globals.h, src/gui.c, src/gui.h, src/gui_amiga.c, + src/gui_athena.c, src/gui_beos.cc, src/gui_gtk_x11.c, + src/gui_mac.c, src/gui_motif.c, src/gui_photon.c, + src/gui_riscos.c, src/gui_w16.c, src/gui_w32.c, src/gui_w48.c, + src/gui_x11.c, src/mbyte.c, src/syntax.c + +Patch 6.1.050 (depends on 6.1.049) +Problem: After patch 6.1.049 the non-GUI version doesn't compile. +Solution: Add an #ifdef FEAT_GUI. (Robert Stanton) +Files: src/syntax.c + +Patch 6.1.051 (depends on 6.1.044) +Problem: Doesn't compile with GUI and small features. +Solution: Adjust the #if for ga_append(). +Files: src/misc2.c + +Patch 6.1.052 +Problem: Unix: The executable() function doesn't work when the "which" + command isn't available. +Solution: Go through $PATH manually. Also makes it work for VMS. +Files: src/os_unix.c + +Patch 6.1.053 +Problem: When 'sessionoptions' contains "globals", or "localoptions" and an + option value contains a line break, the resulting script is wrong. +Solution: Use "\n" and "\r" for a line break. (Srinath Avadhanula) +Files: src/eval.c + +Patch 6.1.054 +Problem: GUI: A mouse click is not recognized at the more prompt, even when + 'mouse' includes 'r'. +Solution: Recognize a mouse click at the more prompt. + Also accept a mouse click in the last line in the GUI. + Add "ml" entry in 'mouseshape'. +Files: src/gui.c, src/message.c, src/misc1.c, src/misc2.c, src/option.c, + src/structs.h + +Patch 6.1.055 +Problem: When editing a compressed file, Vim will inspect the contents to + guess the filetype. +Solution: Don't source scripts.vim for .Z, .gz, .bz2, .zip and .tgz files. +Files: runtime/filetype.vim, runtime/plugin/gzip.vim + +Patch 6.1.056 +Problem: Loading the Syntax menu can take quite a bit of time. +Solution: Add the "skip_syntax_sel_menu" variable. When it's defined the + available syntax files are not in the Syntax menu. +Files: runtime/doc/gui.txt, runtime/menu.vim + +Patch 6.1.057 +Problem: An ESC inside a mapping doesn't work as documented when + 'insertmode' is set, it does go from Visual or Normal mode to + Insert mode. (Benji Fisher) +Solution: Make it work as documented. +Files: src/normal.c + +Patch 6.1.058 +Problem: When there is a closed fold just above the first line in the + window, using CTRL-X CTRL-Y in Insert mode will show only one line + of the fold. (Alexey Marinichev) +Solution: Correct the topline by putting it at the start of the fold. +Files: src/move.c + +Patch 6.1.059 +Problem: ":redir > ~/file" doesn't work. (Stephen Rasku) +Solution: Expand environment variables in the ":redir >" argument. +Files: src/ex_docmd.c + +Patch 6.1.060 +Problem: When 'virtualedit' is set and 'selection' is "exclusive", deleting + a character just before a tab changes the tab into spaces. Undo + doesn't restore the tab. (Helmut Stiegler) +Solution: Don't replace the tab by spaces when it's not needed. Correctly + save the line before it's changed. +Files: src/ops.c + +Patch 6.1.061 +Problem: When 'virtualedit' is set and 'selection' is "exclusive", a Visual + selection that ends just after a tab doesn't include that tab in + the highlighting. (Helmut Stiegler) +Solution: Use a different way to exclude the character under the cursor. +Files: src/screen.c + +Patch 6.1.062 +Problem: The "man" filetype plugin doesn't work properly on Solaris 5. +Solution: Use a different way to detect that "man -s" should be used. (Hugh + Sasse) +Files: runtime/ftplugin/man.vim + +Patch 6.1.063 +Problem: Java indenting doesn't work properly. +Solution: Ignore comments when checking if the indent doesn't increase after + a "}". +Files: runtime/indent/java.vim + +Patch 6.1.064 +Problem: The URLs that the netrw plugin recognized for ftp and rcp did not + conform to the standard method://[user@]host[:port]/path. +Solution: Use ftp://[user@]host[[:#]port]/path, which supports both the new + and the previous style. Also added a bit of dav/cadaver support. + (Charles Campbell) +Files: runtime/plugin/netrw.vim + +Patch 6.1.065 +Problem: VMS: The colorscheme, keymap and compiler menus are not filled in. +Solution: Ignore case when looking for ".vim" files. (Coen Engelbarts) +Files: runtime/menu.vim + +Patch 6.1.066 (extra) +Problem: When calling system() in a plugin reading stdin hangs. +Solution: Don't set the terminal to RAW mode when it wasn't in RAW mode + before the system() call. +Files: src/os_amiga.c, src/os_msdos.c, src/os_riscos.c, src/os_unix.c, + src/os_win16.c, src/os_win32.c + +Patch 6.1.067 +Problem: ":set viminfo+=f0" is not working. (Benji Fisher) +Solution: Check the "f" flag instead of "'" in 'viminfo'. +Files: src/mark.c + +Patch 6.1.068 +Problem: When a file is reloaded after it was changed outside of Vim, diff + mode isn't updated. (Michael Naumann) +Solution: Invalidate the diff info so that it's updated when needed. +Files: src/fileio.c + +Patch 6.1.069 +Problem: When 'showmatch' is set and "$" is in 'cpoptions', using + "C}<Esc>" may forget to remove the "$". (Preben Guldberg) +Solution: Restore dollar_vcol after displaying the matching cursor position. +Files: src/search.c + +Patch 6.1.070 (depends on 6.1.060) +Problem: Compiler warning for signed/unsigned mismatch. (Mike Williams) +Solution: Add a typecast to int. +Files: src/ops.c + +Patch 6.1.071 +Problem: When 'selection' is exclusive, g CTRL-G in Visual mode counts one + character too much. (David Necas) +Solution: Subtract one from the end position. +Files: src/ops.c + +Patch 6.1.072 +Problem: When a file name in a tags file starts with http:// or something + else for which there is a BufReadCmd autocommand, the file isn't + opened anyway. +Solution: Check if there is a matching BufReadCmd autocommand and try to + open the file. +Files: src/fileio.c, src/proto/fileio.pro, src/tag.c + +Patch 6.1.073 (extra) +Problem: BC5: Can't easily specify a tiny, small, normal, big or huge + version. +Solution: Allow selecting the version with the FEATURES variable. (Ajit + Thakkar) +Files: src/Make_bc5.mak + +Patch 6.1.074 +Problem: When 'cdpath' includes "../..", changing to a directory in which + we currently already are doesn't work. ff_check_visited() adds + the directory both when using it as the root for searching and for + the actual matches. (Stephen Rasku) +Solution: Use a separate list for the already searched directories. +Files: src/misc2.c + +Patch 6.1.075 (depends on 6.1.072) +Problem: Can't compile fileio.c on MS-Windows. +Solution: Add a declaration for the "p" pointer. (Madoka Machitani) +Files: src/fileio.c + +Patch 6.1.076 (extra) +Problem: Macintosh: explorer plugin doesn't work on Mac Classic. + IME doesn't work. Dialog boxes don't work on Mac OS X +Solution: Fix explorer plugin and key modifiers. (Axel Kielhorn) + Fix IME support. (Muraoka Taro) + Disable dialog boxes. (Benji Fisher) +Files: src/edit.c, src/feature.h, src/gui_mac.c, src/os_mac.c + +Patch 6.1.077 +Problem: On a Debian system with ACL linking fails. (Lubomir Host) +Solution: When the "acl" library is used, check if the "attr" library is + present and use it. +Files: src/auto/configure, src/configure.in, src/link.sh + +Patch 6.1.078 +Problem: When using 'foldmethod' "marker" and the end marker appears before + the start marker in the file, no fold is found. (Nazri Ramliy) +Solution: Don't let the fold depth go negative. +Files: src/fold.c + +Patch 6.1.079 +Problem: When using "s" in Visual block mode with 'virtualedit' set, when + the selected block is after the end of some lines the wrong text + is inserted and some lines are skipped. (Servatius Brandt) +Solution: Insert the right text and extend short lines. +Files: src/ops.c + +Patch 6.1.080 +Problem: When using gcc with /usr/local already in the search path, adding + it again causes problems. +Solution: Adjust configure.in to avoid adding /usr/local/include and + /usr/local/lib when using GCC and they are already used. (Johannes + Zellner) +Files: src/auto/configure, src/configure.in + +Patch 6.1.081 +Problem: ":help CTRL-\_CTRL-N" doesn't work. (Christian J. Robinson) +Solution: Double the backslash to avoid the special meaning of "\_". +Files: src/ex_cmds.c + +Patch 6.1.082 +Problem: On MS-Windows the vimrc_example.vim script is sourced and then + mswin.vim. This enables using select mode, but since "p" is + mapped it doesn't replace the selection. +Solution: Remove the mapping of "p" from vimrc_example.vim, it's obsolete. + (Vlad Sandrini) +Files: runtime/vimrc_example.vim + +Patch 6.1.083 +Problem: When $LANG is "sk" or "sk_sk", the Slovak menu file isn't found. + (Martin Lacko) +Solution: Guess the right menu file based on the system. +Files: runtime/lang/menu_sk_sk.vim + +Patch 6.1.084 (depends on 6.1.080) +Problem: "include" and "lib" are mixed up when checking the directories gcc + already searches. +Solution: Swap the variable names. (SunHo Kim) +Files: src/auto/configure, src/configure.in + +Patch 6.1.085 +Problem: When using CTRL-O CTRL-\ CTRL-N from Insert mode, the displayed + mode "(insert)" isn't removed. (Benji Fisher) +Solution: Clear the command line. +Files: src/normal.c + +Patch 6.1.086 (depends on 6.1.049) +Problem: The guifg color for CursorIM doesn't take effect. +Solution: Use the foreground color when it's defined. (Muraoka Taro) +Files: src/gui.c + +Patch 6.1.087 +Problem: A thesaurus with Japanese characters has problems with characters + in different word classes. +Solution: Only separate words with single-byte non-word characters. + (Muraoka Taro) +Files: src/edit.c + +Patch 6.1.088 (extra) +Problem: Win32: no debugging info is generated. Tags file excludes .cpp + files. +Solution: Add "/map" to compiler flags. Add "*.cpp" to ctags command. + (Muraoka Taro) +Files: src/Make_mvc.mak + +Patch 6.1.089 +Problem: On BSDI systems there is no ss_sp field in stack_t. (Robert Jan) +Solution: Use ss_base instead. +Files: src/auto/configure, src/configure.in, src/config.h.in, + src/os_unix.c + +Patch 6.1.090 +Problem: CTRL-F gets stuck when 'scrolloff' is non-zero and there is a mix + of long wrapping lines and a non-wrapping line. +Solution: Check that CTRL-F scrolls at least one line. +Files: src/move.c + +Patch 6.1.091 +Problem: GTK: Can't change preeditstate without setting 'imactivatekey'. +Solution: Add some code to change preeditstate for OnTheSpot. (Yasuhiro + Matsumoto) +Files: src/mbyte.c + +Patch 6.1.092 +Problem: ":mapclear <buffer>" doesn't work. (Srikanth Adayapalam) +Solution: Allow an argument for ":mapclear". +Files: src/ex_cmds.h + +Patch 6.1.093 (extra) +Problem: Mac and MS-Windows GUI: when scrolling while ":s" is working the + results can be messed up, because the cursor is moved. +Solution: Disallow direct scrolling when not waiting for a character. +Files: src/gui_mac.c, src/gui_w16.c, src/gui_w32.c, src/gui_w48.c + +Patch 6.1.094 +Problem: Cygwin: Passing a file name that has backslashes isn't handled + very well. +Solution: Convert file name arguments to Posix. (Chris Metcalf) +Files: src/main.c + +Patch 6.1.095 +Problem: When using signs can free an item on the stack. + Overruling sign colors doesn't work. (Srikanth Sankaran) +Solution: Don't free the item on the stack. Use NULL instead of "none" for + the value of the color. +Files: src/gui_x11.c + +Patch 6.1.096 +Problem: When erasing the right halve of a double-byte character, it may + cause further characters to be erased. (Yasuhiro Matsumoto) +Solution: Make sure only one character is erased. +Files: src/screen.c + +Patch 6.1.097 (depends on 6.1.090) +Problem: When 'scrolloff' is set to a huge value, CTRL-F at the end of the + file scrolls one line. (Lubomir Host) +Solution: Don't scroll when CTRL-F detects the end-of-file. +Files: src/move.c + +Patch 6.1.098 +Problem: MS-Windows: When the xxd program is under "c:\program files" the + "Convert to Hex" menu doesn't work. (Brian Mathis) +Solution: Put the path to xxd in double quotes. +Files: runtime/menu.vim + +Patch 6.1.099 +Problem: Memory corrupted when closing a fold with more than 99999 lines. +Solution: Allocate more space for the fold text. (Walter Briscoe) +Files: src/eval.c + +Patch 6.1.100 (extra, depends on 6.1.088) +Problem: Win32: VC5 and earlier don't support the /mapinfo option. +Solution: Add "/mapinfo" only when "MAP=lines" is specified. (Muraoka Taro) +Files: src/Make_mvc.mak + +Patch 6.1.101 +Problem: After using ":options" the tabstop of a new window is 15. Entry + in ":options" window for 'autowriteall' is wrong. (Antoine J + Mechelynck) Can't insert a space in an option value. +Solution: Use ":setlocal" instead of ":set". Change "aw" to "awa". + Don't map space in Insert mode. +Files: runtime/optwin.vim + +Patch 6.1.102 +Problem: Unprintable and multi-byte characters in a statusline item are not + truncated correctly. (Yasuhiro Matsumoto) +Solution: Count the width of characters instead of the number of bytes. +Files: src/buffer.c + +Patch 6.1.103 +Problem: A function returning from a while loop, with 'verbose' set to 12 + or higher, doesn't mention the return value. A function with the + 'abort' attribute may return -1 while the verbose message says + something else. +Solution: Move the verbose message about returning from a function to + call_func(). (Servatius Brandt) +Files: src/eval.c + +Patch 6.1.104 +Problem: GCC 3.1 appears to have an optimizer problem that makes test 3 + crash. +Solution: For GCC 3.1 add -fno-strength-reduce to avoid the optimizer bug. + Filter out extra info from "gcc --version". +Files: src/auto/configure, src/configure.in + +Patch 6.1.105 +Problem: Win32: The default for 'shellpipe' doesn't redirect stderr. (Dion + Nicolaas) +Solution: Redirect stderr, depending on the shell (like for 'shellredir'). +Files: src/option.c + +Patch 6.1.106 +Problem: The maze program crashes. +Solution: Change "11" to "27" and it works. (Greg Roelofs) +Files: runtime/macros/maze/mazeansi.c + +Patch 6.1.107 +Problem: When 'list' is set the current line in the error window may be + displayed wrong. (Muraoka Taro) +Solution: Don't continue the line after the $ has been displayed and the + rightmost column is reached. +Files: src/screen.c + +Patch 6.1.108 +Problem: When interrupting a filter command such as "!!sleep 20" the file + becomes read-only. (Mark Brader) +Solution: Only set the read-only flag when opening a buffer is interrupted. + When the shell command was interrupted, read the output that was + produced so far. +Files: src/ex_cmds.c, src/fileio.c + +Patch 6.1.109 +Problem: When 'eadirection' is "hor", using CTRL-W = doesn't equalize the + window heights. (Roman Neuhauser) +Solution: Ignore 'eadirection' for CTRL-W = +Files: src/window.c + +Patch 6.1.110 +Problem: When using ":badd file" when "file" is already present but not + listed, it stays unlisted. (David Frey) +Solution: Set 'buflisted'. +Files: src/buffer.c + +Patch 6.1.111 +Problem: It's not possible to detect using the Unix sources on Win32 or Mac. +Solution: Add has("macunix") and has("win32unix"). +Files: runtime/doc/eval.txt, src/eval.c + +Patch 6.1.112 +Problem: When using ":argdo", ":bufdo" or ":windo", CTRL-O doesn't go to + the cursor position from before this command but every position + where the argument was executed. +Solution: Only remember the cursor position from before the ":argdo", + ":bufdo" and ":windo". +Files: src/ex_cmds2.c, src/mark.c + +Patch 6.1.113 +Problem: ":bufdo bwipe" only wipes out half the buffers. (Roman Neuhauser) +Solution: Decide what buffer to go to next before executing the command. +Files: src/ex_cmds2.c + +Patch 6.1.114 +Problem: ":python import vim", ":python vim.current.buffer[0:0] = []" gives + a lalloc(0) error. (Chris Southern) +Solution: Don't allocate an array when it's size is zero. +Files: src/if_python.c + +Patch 6.1.115 +Problem: "das" on the white space at the end of a paragraph does not delete + the "." the sentence ends with. +Solution: Don't exclude the last character when it is not white space. +Files: src/search.c + +Patch 6.1.116 +Problem: When 'endofline' is changed while 'binary' is set a file should be + considered modified. (Olaf Buddenhagen) +Solution: Remember the 'eol' value when editing started and consider the + file changed when the current value is different and 'binary' is + set. Also fix that the window title isn't updated when 'ff' or + 'bin' changes. +Files: src/option.c, src/structs.h + +Patch 6.1.117 +Problem: Small problem with editing a file over ftp: and with Cygwin. +Solution: Remove a dot from a ":normal" command. Use "cygdrive" where + appropriate. (Charles Campbell) +Files: runtime/plugin/netrw.vim + +Patch 6.1.118 +Problem: When a file in diff mode is reloaded because it changed outside + of Vim, other windows in diff mode are not always updated. + (Michael Naumann) +Solution: After reloading a file in diff mode mark all windows in diff mode + for redraw. +Files: src/diff.c + +Patch 6.1.119 (extra) +Problem: With the Sniff interface, using Sniff 4.0.X on HP-UX, there may be + a crash when connecting to Sniff. +Solution: Initialize sniff_rq_sep such that its value can be changed. + (Martin Egloff) +Files: src/if_sniff.c + +Patch 6.1.120 (depends on 6.1.097) +Problem: When 'scrolloff' is non-zero and there are folds, CTRL-F at the + end of the file scrolls part of a closed fold. (Lubomir Host) +Solution: Adjust the first line to the start of a fold. +Files: src/move.c + +Patch 6.1.121 (depends on 6.1.098) +Problem: When starting Select mode from Insert mode, then using the Paste + menu entry, the cursor is left before the last pasted character. + (Mario Schweigler) +Solution: Set the cursor for Insert mode one character to the right. +Files: runtime/menu.vim + +Patch 6.1.122 +Problem: ":file name" creates a new buffer to hold the old buffer name, + which becomes the alternate file. This buffer is unexpectedly + listed. +Solution: Create the buffer for the alternate name unlisted. +Files: src/ex_cmds.c + +Patch 6.1.123 +Problem: A ":match" command with more than one argument doesn't report an + error. +Solution: Check for extra characters. (Servatius Brandt) +Files: src/ex_docmd.c + +Patch 6.1.124 +Problem: When trying to exit and there is a hidden buffer that had 'eol' + off and 'bin' set exiting isn't possible. (John McGowan) +Solution: Set b_start_eol when clearing the buffer. +Files: src/buffer.c + +Patch 6.1.125 +Problem: Explorer plugin asks for saving a modified buffer even when it's + open in another window as well. +Solution: Count the number of windows using the buffer. +Files: runtime/plugin/explorer.vim + +Patch 6.1.126 +Problem: Adding the choices in the syntax menu is consuming much of the + startup time of the GUI while it's not often used. +Solution: Only add the choices when the user wants to use them. +Files: Makefile, runtime/makemenu.vim, runtime/menu.vim, + runtime/synmenu.vim, src/Makefile + +Patch 6.1.127 +Problem: When using "--remote file" and the server has 'insertmode' set, + commands are inserted instead of being executed. (Niklas Volbers) +Solution: Go to Normal mode again after the ":drop" command. +Files: src/main.c + +Patch 6.1.128 +Problem: The expression "input('very long prompt')" puts the cursor in the + wrong line (column is OK). +Solution: Add the wrapped lines to the indent. (Yasuhiro Matsumoto) +Files: src/ex_getln.c + +Patch 6.1.129 +Problem: On Solaris editing "file/" and then "file" results in using the + same buffer. (Jim Battle) +Solution: Before using stat(), check that there is no illegal trailing + slash. +Files: src/auto/configure, src/config.h.in, src/configure.in, + src/macros.h src/misc2.c, src/proto/misc2.pro + +Patch 6.1.130 +Problem: The documentation for some of the 'errorformat' items is unclear. +Solution: Add more examples and explain hard to understand items. (Stefan + Roemer) +Files: runtime/doc/quickfix.txt + +Patch 6.1.131 +Problem: X11 GUI: when expanding a CSI byte in the input stream to K_CSI, + the CSI byte itself isn't copied. +Solution: Copy the CSI byte. +Files: src/gui_x11.c + +Patch 6.1.132 +Problem: Executing a register in Ex mode may cause commands to be skipped. + (John McGowan) +Solution: In Ex mode use an extra check if the register contents was + consumed, to avoid input goes into the typeahead buffer. +Files: src/ex_docmd.c + +Patch 6.1.133 +Problem: When drawing double-wide characters in the statusline, may clear + half of a character. (Yasuhiro Matsumoto) +Solution: Force redraw of the next character by setting the attributes + instead of putting a NUL in ScreenLines[]. Do put a NUL in + ScreenLines[] when overwriting half of a double-wide character. +Files: src/screen.c + +Patch 6.1.134 +Problem: An error for a trailing argument of ":match" should not be given + after ":if 0". (Servatius Brandt) +Solution: Only do the check when executing commands. +Files: src/ex_docmd.c + +Patch 6.1.135 +Problem: Passing a command to the shell that includes a newline always has + a backslash before the newline. +Solution: Remove one backslash before the newline. (Servatius Brandt) +Files: src/ex_docmd.c + +Patch 6.1.136 +Problem: When $TERM is "linux" the default for 'background' is "dark", even + though the GUI uses a light background. (Hugh Allen) +Solution: Don't mark the option as set when defaulting to "dark" for the + linux console. Also reset 'background' to "light" when the GUI + has a light background. +Files: src/option.c + +Patch 6.1.137 +Problem: Converting to HTML has a clumsy way of dealing with tabs which may + change the highlighting. +Solution: Replace tabs with spaces after converting a line to HTML. (Preben + Guldberg) +Files: runtime/syntax/2html.vim + +Patch 6.1.138 (depends on 6.1.126) +Problem: Adding extra items to the Syntax menu can't be done when the "Show + individual choices" menu is used. +Solution: Use ":runtime!" instead of ":source", so that all synmenu.vim + files in the runtime path are loaded. (Servatius Brandt) + Also fix that a translated menu can't be removed. +Files: runtime/menu.vim + +Patch 6.1.139 +Problem: Cygwin: PATH_MAX is not defined. +Solution: Include limits.h. (Dan Sharp) +Files: src/main.c + +Patch 6.1.140 +Problem: Cygwin: ":args `ls *.c`" does not work if the shell command + produces CR NL line separators. +Solution: Remove the CR characters ourselves. (Pavol Juhas) +Files: src/os_unix.c + +Patch 6.1.141 +Problem: ":wincmd gx" may cause problems when mixed with other commands. + ":wincmd c" doesn't close the window immediately. (Benji Fisher) +Solution: Pass the extra command character directly instead of using the + stuff buffer and call ex_close() directly. +Files: src/ex_docmd.c, src/normal.c, src/proto/normal.pro, + src/proto/window.pro, src/window.c + +Patch 6.1.142 +Problem: Defining paragraphs without a separating blank line isn't + possible. Paragraphs can't be formatted automatically. +Solution: Allow defining paragraphs with lines that end in white space. + Added the 'w' and 'a' flags in 'formatoptions'. +Files: runtime/doc/change.txt, src/edit.c, src/misc1.c, src/normal.c, + src/option.h, src/ops.c, src/proto/edit.pro, src/proto/ops.pro, + src/vim.h + +Patch 6.1.143 (depends on 6.1.142) +Problem: Auto formatting near the end of the file moves the cursor to a + wrong position. In Insert mode some lines are made one char too + narrow. When deleting a line undo might not always work properly. +Solution: Don't always move to the end of the line in the last line. Don't + position the cursor past the end of the line in Insert mode. + After deleting a line save the cursor line for undo. +Files: src/edit.c, src/ops.c, src/normal.c + +Patch 6.1.144 +Problem: Obtaining the size of a line in screen characters can be wrong. + A pointer may wrap around zero. +Solution: In win_linetabsize() check for a MAXCOL length argument. (Jim + Dunleavy) +Files: src/charset.c + +Patch 6.1.145 +Problem: GTK: Drag&drop with more than 3 files may cause a crash. (Mickael + Marchand) +Solution: Rewrite the code that parses the received list of files to be more + robust. +Files: src/charset.c, src/gui_gtk_x11.c + +Patch 6.1.146 +Problem: MS-Windows: When $HOME is constructed from $HOMEDRIVE and + $HOMEPATH, it is not used for storing the _viminfo file. (Normal + Diamond) +Solution: Set $HOME with the value obtained from $HOMEDRIVE and $HOMEPATH. +Files: src/misc1.c + +Patch 6.1.147 (extra) +Problem: MS-Windows: When a dialog has no default button, pressing Enter + ends it anyway and all buttons are selected. +Solution: Don't end a dialog when there is no default button. Don't select + all button when there is no default. (Vince Negri) +Files: src/gui_w32.c + +Patch 6.1.148 (extra) +Problem: MS-Windows: ACL is not properly supported. +Solution: Add an access() replacement that also works for ACL. (Mike + Williams) +Files: runtime/doc/editing.txt, src/os_win32.c + +Patch 6.1.149 (extra) +Problem: MS-Windows: Can't use diff mode from the file explorer. +Solution: Add a "diff with Vim" context menu entry. (Dan Sharp) +Files: GvimExt/gvimext.cpp, GvimExt/gvimext.h + +Patch 6.1.150 +Problem: OS/2, MS-Windows and MS-DOS: When 'shellslash' is set getcwd() + still uses backslash. (Yegappan Lakshmanan) +Solution: Adjust slashes in getcwd(). +Files: src/eval.c + +Patch 6.1.151 (extra) +Problem: Win32: The NTFS substream isn't copied. +Solution: Copy the substream when making a backup copy. (Muraoka Taro) +Files: src/fileio.c, src/os_win32.c, src/proto/os_win32.pro + +Patch 6.1.152 +Problem: When $LANG is iso8859-1 translated menus are not used. +Solution: Change iso8859 to iso_8859. +Files: runtime/menu.vim + +Patch 6.1.153 +Problem: Searching in included files may search recursively when the path + starts with "../". (Sven Berkvens-Matthijsse) +Solution: Compare full file names, use inode/device when possible. +Files: src/search.c + +Patch 6.1.154 (extra) +Problem: DJGPP: "vim -h" leaves the cursor in a wrong position. +Solution: Don't position the cursor using uninitialized variables. (Jim + Dunleavy) +Files: src/os_msdos.c + +Patch 6.1.155 +Problem: Win32: Cursor may sometimes disappear in Insert mode. +Solution: Change "hor10" in 'guicursor' to "hor15". (Walter Briscoe) +Files: src/option.c + +Patch 6.1.156 +Problem: Conversion between DBCS and UCS-2 isn't implemented cleanly. +Solution: Clean up a few things. +Files: src/mbyte.c, src/structs.h + +Patch 6.1.157 +Problem: 'hlsearch' highlights only the second comma in ",,,,," with + "/,\@<=[^,]*". (Preben Guldberg) +Solution: Also check for an empty match to start just after a previous + match. +Files: src/screen.c + +Patch 6.1.158 +Problem: "zs" and "ze" don't work correctly with ":set nowrap siso=1". + (Preben Guldberg) +Solution: Take 'siso' into account when computing the horizontal scroll + position for "zs" and "ze". +Files: src/normal.c + +Patch 6.1.159 +Problem: When expanding an abbreviation that includes a multi-byte + character too many characters are deleted. (Andrey Urazov) +Solution: Delete the abbreviation counting characters instead of bytes. +Files: src/getchar.c + +Patch 6.1.160 +Problem: ":$read file.gz" doesn't work. (Preben Guldberg) +Solution: Don't use the '[ mark after it has become invalid. +Files: runtime/plugin/gzip.vim + +Patch 6.1.161 (depends on 6.1.158) +Problem: Warning for signed/unsigned compare. Can set 'siso' to a negative + value. (Mike Williams) +Solution: Add a typecast. Add a check for 'siso' being negative. +Files: src/normal.c, src/option.c + +Patch 6.1.162 +Problem: Python interface: Didn't initialize threads properly. +Solution: Call PyEval_InitThreads() when starting up. +Files: src/if_python.c + +Patch 6.1.163 +Problem: Win32: Can't compile with Python after 6.1.162. +Solution: Dynamically load PyEval_InitThreads(). (Dan Sharp) +Files: src/if_python.c + +Patch 6.1.164 +Problem: If 'modifiable' is off, converting to xxd fails and 'filetype' is + changed to "xxd" anyway. +Solution: Don't change 'filetype' when conversion failed. +Files: runtime/menu.vim + +Patch 6.1.165 +Problem: Making changes in several lines and then a change in one of these + lines that splits it in two or more lines, undo information was + corrupted. May cause a crash. (Dave Fishburn) +Solution: When skipping to save a line for undo because it was already + saved, move it to become the last saved line, so that when the + command changes the line count other saved lines are not involved. +Files: src/undo.c + +Patch 6.1.166 +Problem: When 'autoindent' is set and mswin.vim has been sourced, pasting + with CTRL-V just after auto-indenting removes the indent. (Shlomi + Fish) +Solution: First insert an "x" and delete it again, so that the auto-indent + remains. +Files: runtime/mswin.vim + +Patch 6.1.167 +Problem: When giving a negative argument to ":retab" strange things start + happening. (Hans Ginzel) +Solution: Check for a negative value. +Files: src/ex_cmds.c + +Patch 6.1.168 +Problem: Pressing CTRL-C at the hit-enter prompt doesn't end the prompt. +Solution: Make CTRL-C stop the hit-enter prompt. +Files: src/message.c + +Patch 6.1.169 +Problem: bufexists() finds a buffer by using the name of a symbolic link to + it, but bufnr() doesn't. (Yegappan Lakshmanan) +Solution: When bufnr() can't find a buffer, try using the same method as + bufexists(). +Files: src/eval.c + +Patch 6.1.170 +Problem: Using ":mksession" uses the default session file name, but "vim + -S" doesn't. (Hans Ginzel) +Solution: Use the default session file name if "-S" is the last command + line argument or another option follows. +Files: runtime/doc/starting.txt, src/main.c + +Patch 6.1.171 +Problem: When opening a line just above a closed fold with "O" and the + comment leader is automatically inserted, the cursor is displayed + in the first column. (Sung-Hyun Nam) +Solution: Update the flag that indicates the cursor is in a closed fold. +Files: src/misc1.c + +Patch 6.1.172 +Problem: Command line completion of ":tag /pat" does not show the same + results as the tags the command actually finds. (Gilles Roy) +Solution: Don't modify the pattern to make it a regexp. +Files: src/ex_getln.c, src/tag.c + +Patch 6.1.173 +Problem: When using remote control to edit a position in a file and this + file is the current buffer and it's modified, the window is split + and the ":drop" command fails. +Solution: Don't split the window, keep editing the same buffer. + Use the ":drop" command in VisVim to avoid the problem there. +Files: src/ex_cmds.c, src/ex_cmds2.c, src/proto/ex_cmds2.pro, + VisVim/Commands.cpp + +Patch 6.1.174 +Problem: It is difficult to know in a script whether an option not only + exists but really works. +Solution: Add "exists('+option')". +Files: runtime/doc/eval.txt, src/eval.c + +Patch 6.1.175 +Problem: When reading commands from a pipe and a CTRL-C is pressed, Vim + will hang. (Piet Delport) +Solution: Don't keep reading characters to clear typeahead when an interrupt + was detected, stop when a single CTRL-C is read. +Files: src/getchar.c, src/ui.c + +Patch 6.1.176 +Problem: When the stack limit is very big a false out-of-stack error may + be detected. +Solution: Add a check for overflow of the stack limit computation. (Jim + Dunleavy) +Files: src/os_unix.c + +Patch 6.1.177 (depends on 6.1.141) +Problem: ":wincmd" does not allow a following command. (Gary Johnson) +Solution: Check for a following " | cmd". Also give an error for trailing + characters. +Files: src/ex_docmd.c + +Patch 6.1.178 +Problem: When 'expandtab' is set "r<C-V><Tab>" still expands the Tab. + (Bruce deVisser) +Solution: Replace with a literal Tab. +Files: src/normal.c + +Patch 6.1.179 (depends on 6.1.091) +Problem: When using X11R5 XIMPreserveState is undefined. (Albert Chin) +Solution: Include the missing definitions. +Files: src/mbyte.c + +Patch 6.1.180 +Problem: Use of the GUI code for forking is inconsistent. +Solution: Define MAY_FORK and use it for later #ifdefs. (Ben Fowlwer) +Files: src/gui.c + +Patch 6.1.181 +Problem: If the terminal doesn't wrap from the last char in a line to the + next line, the last column is blanked out. (Peter Karp) +Solution: Don't output a space to mark the wrap, but the same character + again. +Files: src/screen.c + +Patch 6.1.182 (depends on 6.1.142) +Problem: It is not possible to auto-format comments only. (Moshe Kaminsky) +Solution: When the 'a' and 'c' flags are in 'formatoptions' only auto-format + comments. +Files: runtime/doc/change.txt, src/edit.c + +Patch 6.1.183 +Problem: When 'fencs' is empty and 'enc' is utf-8, reading a file with + illegal bytes gives "CONVERSION ERROR" even though no conversion + is done. 'readonly' is set, even though writing the file results + in an unmodified file. +Solution: For this specific error use "ILLEGAL BYTE" and don't set + 'readonly'. +Files: src/fileio.c + +Patch 6.1.184 (extra) +Problem: The extra mouse buttons found on some mice don't work. +Solution: Support two extra buttons for MS-Windows. (Michael Geddes) +Files: runtime/doc/term.txt, src/edit.c, src/ex_getln.c, src/gui.c, + src/gui_w32.c, src/gui_w48.c, src/keymap.h, src/message.c, + src/misc1.c, src/misc2.c, src/normal.c, src/vim.h + +Patch 6.1.185 (depends on 6.1.182) +Problem: Can't compile without +comments feature. +Solution: Add #ifdef FEAT_COMMENTS. (Christian J. Robinson) +Files: src/edit.c + +Patch 6.1.186 (depends on 6.1.177) +Problem: ":wincmd" does not allow a following comment. (Aric Blumer) +Solution: Check for a following double quote. +Files: src/ex_docmd.c + +Patch 6.1.187 +Problem: Using ":doarg" with 'hidden' set and the current file is the only + argument and was modified gives an error message. (Preben + Guldberg) +Solution: Don't try re-editing the same file. +Files: src/ex_cmds2.c + +Patch 6.1.188 (depends on 6.1.173) +Problem: Unused variable in the small version. +Solution: Move the declaration for "p" inside #ifdef FEAT_LISTCMDS. +Files: src/ex_cmds2.c + +Patch 6.1.189 +Problem: inputdialog() doesn't work when 'c' is in 'guioptions'. (Aric + Blumer) +Solution: Fall back to the input() function in this situation. +Files: src/eval.c + +Patch 6.1.190 (extra) +Problem: VMS: doesn't build with GTK GUI. Various other problems. +Solution: Fix building for GTK. Improved Perl, Python and TCL support. + Improved VMS documentation. (Zoltan Arpadffy) + Added Vimtutor for VMS (T. R. Wyant) +Files: runtime/doc/os_vms.txt, src/INSTALLvms.txt, src/gui_gtk_f.h, + src/if_tcl.c, src/main.c, src/gui_gtk_vms.h, src/Make_vms.mms, + src/os_vms.opt, src/proto/if_tcl.pro, vimtutor.com, + src/testdir/Make_vms.mms + +Patch 6.1.191 +Problem: When using "vim -s script" and redirecting the output, the delay + for the "Output is not to a terminal" warning slows Vim down too + much. +Solution: Don't delay when reading commands from a script. +Files: src/main.c + +Patch 6.1.192 +Problem: ":diffsplit" doesn't add "hor" to 'scrollopt'. (Gary Johnson) +Solution: Add "hor" to 'scrollopt' each time ":diffsplit" is used. +Files: src/diff.c, src/main.c + +Patch 6.1.193 +Problem: Crash in in_id_list() for an item with a "containedin" list. (Dave + Fishburn) +Solution: Check for a negative syntax id, used for keywords. +Files: src/syntax.c + +Patch 6.1.194 +Problem: When "t_ti" is set but it doesn't cause swapping terminal pages, + "ZZ" may cause the shell prompt to appear on top of the file-write + message. +Solution: Scroll the text up in the Vim page before swapping to the terminal + page. (Michael Schroeder) +Files: src/os_unix.c + +Patch 6.1.195 +Problem: The quickfix and preview windows always keep their height, while + other windows can't fix their height. +Solution: Add the 'winfixheight' option, so that a fixed height can be + specified for any window. Also fix that the wildmenu may resize a + one-line window to a two-line window if 'ls' is zero. +Files: runtime/doc/options.txt, runtime/optwin.vim, src/ex_cmds.c, + src/ex_getln.c, src/globals.h, src/option.c, src/quickfix.c, + src/screen.c, src/structs.h, src/window.c + +Patch 6.1.196 (depends on 6.1.084) +Problem: On Mac OS X 10.2 generating osdef.h fails. +Solution: Add -no-cpp-precomp to avoid using precompiled header files, which + disables printing the search path. (Ben Fowler) +Files: src/auto/configure, src/configure.in + +Patch 6.1.197 +Problem: ":help <C-V><C-\><C-V><C-N>" (resulting in <1c><0e>) gives an + error message. (Servatius Brandt) +Solution: Double the backslash in "CTRL-\". +Files: src/ex_cmds.c + +Patch 6.1.198 (extra) (depends on 6.1.076) +Problem: Mac OS X: Dialogues don't work. +Solution: Fix a crashing problem for some GUI dialogues. Fix a problem when + saving to a new file from the GUI. (Peter Cucka) +Files: src/feature.h, src/gui_mac.c + +Patch 6.1.199 +Problem: 'guifontwide' doesn't work on Win32. +Solution: Output each wide character separately. (Michael Geddes) +Files: src/gui.c + +Patch 6.1.200 +Problem: ":syn sync fromstart" is not skipped after ":if 0". This can make + syntax highlighting very slow. +Solution: Check "eap->skip" appropriately. (Rob West) +Files: src/syntax.c + +Patch 6.1.201 (depends on 6.1.192) +Problem: Warning for illegal pointer combination. (Zoltan Arpadffy) +Solution: Add a typecast. +Files: src/diff.c + +Patch 6.1.202 (extra)(depends on 6.1.148) +Problem: Win32: filewritable() doesn't work properly on directories. +Solution: fix filewritable(). (Mike Williams) +Files: src/os_win32.c + +Patch 6.1.203 +Problem: ":%s/~//" causes a crash after ":%s/x//". (Gary Holloway) +Solution: Avoid reading past the end of a line when "~" is empty. +Files: src/regexp.c + +Patch 6.1.204 (depends on 6.1.129) +Problem: Warning for an illegal pointer on Solaris. +Solution: Add a typecast. (Derek Wyatt) +Files: src/misc2.c + +Patch 6.1.205 +Problem: The gzip plugin changes the alternate file when editing a + compressed file. (Oliver Fuchs) +Solution: Temporarily remove the 'a' and 'A' flags from 'cpo'. +Files: runtime/plugin/gzip.vim + +Patch 6.1.206 +Problem: The script generated with ":mksession" doesn't work properly when + some commands are mapped. +Solution: Use ":normal!" instead of ":normal". And use ":wincmd" where + possible. (Muraoka Taro) +Files: src/ex_docmd.c, src/fold.c + +Patch 6.1.207 +Problem: Indenting a Java file hangs below a line with a comment after a + command. +Solution: Break out of a loop. (Andre Pang) + Also line up } with matching {. +Files: runtime/indent/java.vim + +Patch 6.1.208 +Problem: Can't use the buffer number from the Python interface. +Solution: Add buffer.number. (Michal Vitecek) +Files: src/if_python.c + +Patch 6.1.209 +Problem: Printing doesn't work on Mac OS classic. +Solution: Use a ":" for path separator when opening the resource file. (Axel + Kielhorn) +Files: src/ex_cmds2.c + +Patch 6.1.210 +Problem: When there is an iconv() conversion error when reading a file + there can be an error the next time iconv() is used. +Solution: Reset the state of the iconv() descriptor. (Yasuhiro Matsumoto) +Files: src/fileio.c + +Patch 6.1.211 +Problem: The message "use ! to override" is confusing. +Solution: Make it "add ! to override". +Files: src/buffer.c, src/eval.c, src/ex_docmd.c, src/fileio.c, + src/globals.h + +Patch 6.1.212 +Problem: When Vim was started with "-R" ":new" creates a buffer + 'noreadonly' while ":enew" has 'readonly' set. (Preben Guldberg) +Solution: Don't set 'readonly in a new empty buffer for ":enew". +Files: src/ex_docmd.c + +Patch 6.1.213 +Problem: Using CTRL-W H may cause a big gap to appear below the last + window. (Aric Blumer) +Solution: Don't set the window height when there is a vertical split. + (Yasuhiro Matsumoto) +Files: src/window.c + +Patch 6.1.214 +Problem: When installing Vim and the runtime files were checked out from + CVS the CVS directories will also be installed. +Solution: Avoid installing the CVS dirs and their contents. +Files: src/Makefile + +Patch 6.1.215 +Problem: Win32: ":pwd" uses backslashes even when 'shellslash' is set. + (Xiangjiang Ma) +Solution: Adjust backslashes before printing the message. +Files: src/ex_docmd.c + +Patch 6.1.216 +Problem: When dynamically loading the iconv library, the error codes may be + confused. +Solution: Use specific error codes for iconv and redefine them for dynamic + loading. (Yasuhiro Matsumoto) +Files: src/fileio.c, src/mbyte.c, src/vim.h + +Patch 6.1.217 +Problem: When sourcing the same Vim script using a different name (symbolic + link or MS-Windows 8.3 name) it is listed twice with + ":scriptnames". (Tony Mechelynck) +Solution: Turn the script name into a full path before using it. On Unix + compare inode/device numbers. +Files: src/ex_cmds2.c + +Patch 6.1.218 +Problem: No error message for using the function argument "5+". (Servatius + Brandt) +Solution: Give an error message if a function or variable is expected but is + not found. +Files: src/eval.c + +Patch 6.1.219 +Problem: When using ":amenu :b 1<CR>" with a Visual selection and + 'insertmode' is set, Vim does not return to Insert mode. (Mickael + Marchand) +Solution: Add the command CTRL-\ CTRL-G that goes to Insert mode if + 'insertmode' is set and to Normal mode otherwise. Append this to + menus defined with ":amenu". +Files: src/edit.c, src/ex_getln.c, src/normal.c + +Patch 6.1.220 +Problem: When using a BufReadPost autocommand that changes the line count, + e.g., "$-1join", reloading a file that was changed outside Vim + does not work properly. (Alan G Isaac) +Solution: Make the buffer empty before reading the new version of the file. + Save the lines in a dummy buffer, so that they can be put back + when reading the file fails. +Files: src/buffer.c, src/ex_cmds.c, src/fileio.c, src/globals.h, + src/proto/buffer.pro + +Patch 6.1.221 +Problem: Changing case may not work properly, depending on the current + locale. +Solution: Add the 'casemap' option to let the user chose how changing case + is to be done. + Also fix lowering case when an UTF-8 character doesn't keep the + same byte length. +Files: runtime/doc/options.txt, src/ascii.h, src/auto/configure, + src/buffer.c, src/charset.c, src/config.h.in, src/configure.in, + src/diff.c, src/edit.c, src/eval.c, src/ex_cmds2.c, + src/ex_docmd.c, src/ex_getln.c, src/fileio.c, src/gui_amiga.c + src/gui_mac.c, src/gui_photon.c, src/gui_w48.c, src/gui_beos.cc, + src/macros.h, src/main.c, src/mbyte.c, src/menu.c, src/message.c, + src/misc1.c, src/misc2.c, src/option.c, src/os_msdos.c, + src/os_mswin.c, src/proto/charset.pro, src/regexp.c, src/option.h, + src/syntax.c + +Patch 6.1.222 (depends on 6.1.219) +Problem: Patch 6.1.219 was incomplete. +Solution: Add the changes for ":amenu". +Files: src/menu.c + +Patch 6.1.223 (extra) +Problem: Win32: When IME is activated 'iminsert' is set, but it might never + be reset when IME is disabled. (Muraoka Taro) + All systems: 'iminsert' is set to 2 when leaving Insert mode, even + when langmap is being used. (Peter Valach) +Solution: Don't set "b_p_iminsert" in _OnImeNotify(). (Muraoka Taro) + Don't store the status of the input method in 'iminsert' when + 'iminsert' is one. Also for editing the command line and for + arguments to Normal mode commands. +Files: src/edit.c, src/ex_getln.c, src/gui_w32.c, src/normal.c + +Patch 6.1.224 +Problem: "expand('$VAR')" returns an empty string when the expanded $VAR + is not an existing file. (Aric Blumer) +Solution: Included non-existing files, as documented. +Files: src/eval.c + +Patch 6.1.225 +Problem: Using <C-O><C-^> in Insert mode has a delay when starting "vim -u + NONE" and ":set nocp hidden". (Emmanuel) do_ecmd() uses + fileinfo(), the redraw is done after a delay to give the user time + to read the message. +Solution: Put the message from fileio() in "keep_msg", so that the redraw is + done before the delay (still needed to avoid the mode message + overwrites the fileinfo() message). +Files: src/buffer.c + +Patch 6.1.226 +Problem: Using ":debug" with a ":normal" command may cause a hang. (Colin + Keith) +Solution: Save the typeahead buffer when obtaining a debug command. +Files: src/ex_cmds2.c, src/getchar.c, src/proto/getchar.pro + +Patch 6.1.227 +Problem: It is possible to use a variable name "asdf:asdf" and ":let j:asdf + = 5" does not give an error message. (Mikolaj Machowski) +Solution: Check for a ":" inside the variable name. +Files: src/eval.c + +Patch 6.1.228 (extra) +Problem: Win32: The special output function for Hangul is used too often, + causing special handling for other situations to be skipped. + bInComposition is always FALSE, causing ImeGetTempComposition() + always to return NULL. +Solution: Remove HanExtTextOut(). Delete the dead code around + bInComposition and ImeGetTempComposition(). +Files: src/gui_w16.c, src/gui_w32.c, src/gui_w48.c + +Patch 6.1.229 +Problem: Win32: Conversion to/from often used codepages requires the iconv + library, which is not always available. +Solution: Use standard MS-Windows functions for the conversion when + possible. (mostly by Glenn Maynard) + Also fixes missing declaration for patch 6.1.220. +Files: src/fileio.c + +Patch 6.1.230 (extra) +Problem: Win16: building doesn't work. +Solution: Exclude the XBUTTON handling. (Vince Negri) +Files: src/gui_w48.c + +Patch 6.1.231 +Problem: Double clicking with the mouse to select a word does not work for + multi-byte characters. +Solution: Use vim_iswordc() instead of vim_isIDc(). This means 'iskeyword' + is used instead of 'isident'. Also fix that mixing ASCII with + multi-byte word characters doesn't work, the mouse class for + punctuation and word characters was mixed up. +Files: src/normal.c + +Patch 6.1.232 (depends on 6.1.226) +Problem: Using ex_normal_busy while it might not be available. (Axel + Kielhorn) +Solution: Only use ex_normal_busy when FEAT_EX_EXTRA is defined. +Files: src/ex_cmds2.c + +Patch 6.1.233 +Problem: ":help expr-||" does not work. +Solution: Don't use the '|' as a command separator +Files: src/ex_cmds.c + +Patch 6.1.234 (depends on 6.1.217) +Problem: Get a warning for using a negative value for st_dev. +Solution: Don't assign a negative value to st_dev. +Files: src/ex_cmds2.c + +Patch 6.1.235 (depends on 6.1.223) +Problem: 'iminsert' is changed from 1 to 2 when leaving Insert mode. (Peter + Valach) +Solution: Check "State" before resetting it to NORMAL. +Files: src/edit.c + +Patch 6.1.236 +Problem: Memory leaks when appending lines for ":diffget" or ":diffput" and + when reloading a changed buffer. +Solution: Free a line after calling ml_append(). +Files: src/diff.c, src/fileio.c + +Patch 6.1.237 +Problem: Putting in Visual block mode does not work correctly when "$" was + used or when the first line is short. (Christian Michon) +Solution: First delete the selected text and then put the new text. Save + and restore registers as necessary. +Files: src/globals.h, src/normal.c, src/ops.c, src/proto/ops.pro, + src/vim.h + +Patch 6.1.238 (extra) +Problem: Win32: The "icon=" argument for the ":menu" command does not + search for the bitmap file. +Solution: Expand environment variables and search for the bitmap file. + (Vince Negri) + Make it consistent, use the same mechanism for X11 and GTK. +Files: src/gui.c src/gui_gtk.c, src/gui_w32.c, src/gui_x11.c, + src/proto/gui.pro + +Patch 6.1.239 +Problem: Giving an error for missing :endif or :endwhile when being + interrupted. +Solution: Don't give these messages when interrupted. +Files: src/ex_docmd.c, src/os_unix.c + +Patch 6.1.240 (extra) +Problem: Win32 with BCC 5: CPU may be defined in the environment, which + causes a wrong argument for the compiler. (Walter Briscoe) +Solution: Use CPUNR instead of CPU. +Files: src/Make_bc5.mak + +Patch 6.1.241 +Problem: Something goes wrong when drawing or undrawing the cursor. +Solution: Remember when the cursor invalid in a better way. +Files: src/gui.c + +Patch 6.1.242 +Problem: When pasting a large number of lines on the command line it is not + possible to interrupt. (Jean Jordaan) +Solution: Check for an interrupt after each pasted line. +Files: src/ops.c + +Patch 6.1.243 (extra) +Problem: Win32: When the OLE version is started and wasn't registered, a + message pops up to suggest registering, even when this isn't + possible (when the registry is not writable). +Solution: Check if registering is possible before asking whether it should + be done. (Walter Briscoe) + Also avoid restarting Vim after registering. +Files: src/if_ole.cpp + +Patch 6.1.244 +Problem: Patch 6.1.237 was missing the diff for vim.h. (Igor Goldenberg) +Solution: Include it here. +Files: src/vim.h + +Patch 6.1.245 +Problem: Comparing with ignored case does not work properly for Unicode + with a locale where case folding an ASCII character results in a + multi-byte character. (Glenn Maynard) +Solution: Handle ignore-case compare for Unicode differently. +Files: src/mbyte.c + +Patch 6.1.246 +Problem: ":blast" goes to the first buffer if the last one is unlisted. + (Andrew Stryker) +Solution: From the last buffer search backwards for the first listed buffer + instead of forwards. +Files: src/ex_docmd.c + +Patch 6.1.247 +Problem: ACL support doesn't always work properly. +Solution: Add a configure argument to disable ACL "--disable-acl". (Thierry + Vignaud) +Files: src/auto/configure, src/configure.in + +Patch 6.1.248 +Problem: Typing 'q' at the more-prompt for ":let" does not quit the + listing. (Hari Krishna Dara) +Solution: Quit the listing when got_int is set. +Files: src/eval.c + +Patch 6.1.249 +Problem: Can't expand a path on the command line if it includes a "|" as a + trail byte of a multi-byte character. +Solution: Check for multi-byte characters. (Yasuhiro Matsumoto) +Files: src/ex_docmd.c + +Patch 6.1.250 +Problem: When changing the value of 'lines' inside the expression set with + 'diffexpr' Vim might crash. (Dave Fishburn) +Solution: Don't allow changing the screen size while updating the screen. +Files: src/globals.h, src/option.c, src/screen.c + +Patch 6.1.251 +Problem: Can't use completion for ":lcd" and ":lchdir" like ":cd". +Solution: Expand directory names for these commands. (Servatius Brandt) +Files: src/ex_docmd.c + +Patch 6.1.252 +Problem: "vi}" does not include a line break when the "}" is at the start + of a following line. (Kamil Burzynski) +Solution: Include the line break. +Files: src/search.c + +Patch 6.1.253 (extra) +Problem: Win32 with Cygwin: Changes the path of arguments in a wrong way. + (Xiangjiang Ma) +Solution: Don't use cygwin_conv_to_posix_path() for the Win32 version. + Update the Cygwin makefile to support more features. (Dan Sharp) +Files: src/Make_cyg.mak, src/if_ole.cpp, src/main.c + +Patch 6.1.254 +Problem: exists("foo{bar}") does not work. ':unlet v{"a"}r' does not work. + ":let v{a}r1 v{a}r2" does not work. ":func F{(1)}" does not work. + ":delfunc F{" does not give an error message. ':delfunc F{"F"}' + does not work. +Solution: Support magic braces for the exists() argument. (Vince Negri) + Check for trailing comments explicitly for ":unlet". Add support + for magic braces in further arguments of ":let". Look for a + parenthesis only after the function name. (Servatius Brandt) + Also expand magic braces for "exists('*expr')". Give an error + message for an invalid ":delfunc" argument. Allow quotes in the + ":delfunc" argument. +Files: src/eval.c, src/ex_cmds.h, src/ex_docmd.c + +Patch 6.1.255 (depends on 6.1.254) +Problem: Crash when loading menu.vim a second time. (Christian Robinson) + ":unlet garbage foo" tries unletting "foo" after an error message. + (Servatius Brandt) + Very long function arguments cause very long messages when + 'verbose' is 14 or higher. +Solution: Avoid reading from uninitialized memory. + Break out of a loop after an invalid argument for ":unlet". + Truncate long function arguments to 80 characters. +Files: src/eval.c + +Patch 6.1.256 (depends on 6.1.255) +Problem: Defining a function after ":if 0" could still cause an error + message for an existing function. + Leaking memory when there are trailing characters for ":delfunc". +Solution: Check the "skip" flag. Free the memory. (Servatius Brandt) +Files: src/eval.c + +Patch 6.1.257 +Problem: ":cwindow" always sets the previous window to the last but one + window. (Benji Fisher) +Solution: Set the previous window properly. +Files: src/globals.c, src/quickfix.c, src/window.c + +Patch 6.1.258 +Problem: Buffers menu doesn't work properly for multibyte buffer names. +Solution: Use a pattern to get the left and right part of the name. + (Yasuhiro Matsumoto) +Files: runtime/menu.vim + +Patch 6.1.259 (extra) +Problem: Mac: with 'patchmode' is used filenames are truncated. +Solution: Increase the BASENAMELEN for Mac OS X. (Ed Ralston) +Files: src/os_mac.h + +Patch 6.1.260 (depends on 6.1.104) +Problem: GCC 3.2 still seems to have an optimizer problem. (Zvi Har'El) +Solution: Use the same configure check as used for GCC 3.1. +Files: src/auto/configure, src/configure.in + +Patch 6.1.261 +Problem: When deleting a line in a buffer which is not the current buffer, + using the Perl interface Delete(), the cursor in the current + window may move. (Chris Houser) +Solution: Don't adjust the cursor position when changing another buffer. +Files: src/if_perl.xs + +Patch 6.1.262 +Problem: When jumping over folds with "z[", "zj" and "zk" the previous + position is not remembered. (Hari Krishna Dara) +Solution: Set the previous context mark before jumping. +Files: src/fold.c + +Patch 6.1.263 +Problem: When typing a multi-byte character that triggers an abbreviation + it is not inserted properly. +Solution: Handle adding the typed multi-byte character. (Yasuhiro Matsumoto) +Files: src/getchar.c + +Patch 6.1.264 (depends on patch 6.1.254) +Problem: exists() does not work for built-in functions. (Steve Wall) +Solution: Don't check for the function name to start with a capital. +Files: src/eval.c + +Patch 6.1.265 +Problem: libcall() can be used in 'foldexpr' to call any system function. + rename(), delete() and remote_send() can also be used in + 'foldexpr'. These are security problems. (Georgi Guninski) +Solution: Don't allow using libcall(), rename(), delete(), remote_send() and + similar functions in the sandbox. +Files: src/eval.c + +Patch 6.1.266 (depends on 6.1.265) +Problem: Win32: compile error in eval.c. (Bill McCarthy) +Solution: Move a variable declaration. +Files: src/eval.c + +Patch 6.1.267 +Problem: Using "p" to paste into a Visual selected area may cause a crash. +Solution: Allocate enough memory for saving the register contents. (Muraoka + Taro) +Files: src/ops.c + +Patch 6.1.268 +Problem: When triggering an abbreviation with a multi-byte character, this + character is not correctly inserted after expanding the + abbreviation. (Taro Muraoka) +Solution: Add ABBR_OFF to all characters above 0xff. +Files: src/edit.c, src/ex_getln.c, src/getchar.c + +Patch 6.1.269 +Problem: After using input() text written with ":redir" gets extra indent. + (David Fishburn) +Solution: Restore msg_col after using input(). +Files: src/ex_getln.c + +Patch 6.1.270 (depends on 6.1.260) +Problem: GCC 3.2.1 still seems to have an optimizer problem. +Solution: Use the same configure check as used for GCC 3.1. +Files: src/auto/configure, src/configure.in + +Patch 6.1.271 +Problem: When compiling without the +syntax feature there are errors. +Solution: Don't use some code for syntax highlighting. (Roger Cornelius) + Make test 45 work without syntax highlighting. + Also fix an error in a pattern matching: "\%(" was not supported. +Files: src/ex_cmds2.c, src/regexp.c, src/testdir/test45.in + +Patch 6.1.272 +Problem: After using ":set define<" a crash may happen. (Christian Robinson) +Solution: Make a copy of the option value in allocated memory. +Files: src/option.c + +Patch 6.1.273 +Problem: When the cursor doesn't blink, redrawing an exposed area may hide + the cursor. +Solution: Always draw the cursor, also when it didn't move. (Muraoka Taro) +Files: src/gui.c + +Patch 6.1.274 (depends on 6.1.210) +Problem: Resetting the iconv() state after each error is wrong for an + incomplete sequence. +Solution: Don't reset the iconv() state. +Files: src/fileio.c + +Patch 6.1.275 +Problem: When using "v" in a startup script, get warning message that + terminal cannot highlight. (Charles Campbell) +Solution: Only give the message after the terminal has been initialized. +Files: src/normal.c + +Patch 6.1.276 +Problem: "gvim --remote file" doesn't prompt for an encryption key. +Solution: The further characters the client sends to the server are used. + Added inputsave() and inputrestore() to allow prompting the + user directly and not using typeahead. + Also fix possible memory leak for ":normal". +Files: src/eval.c, src/ex_cmds2.c, src/ex_docmd.c, src/getchar.c, + src/main.c, src/proto/getchar.pro, src/proto/ui.pro, + src/runtime/doc/eval.txt, src/structs.h, src/ui.c, src/vim.h + +Patch 6.1.277 (depends on 6.1.276) +Problem: Compilation error when building with small features. +Solution: Define trash_input_buf() when needed. (Kelvin Lee) +Files: src/ui.c + +Patch 6.1.278 +Problem: When using signs the line number of a closed fold doesn't line up + with the other line numbers. (Kamil Burzynski) +Solution: Insert two spaces for the sign column. +Files: src/screen.c + +Patch 6.1.279 +Problem: The prototype for smsg() and smsg_attr() do not match the function + definition. This may cause trouble for some compilers. (Nix) +Solution: Use va_list for systems that have stdarg.h. Use "int" instead of + "void" for the return type. +Files: src/auto/configure, src/config.h.in, src/configure.in, + src/proto.h, src/message.c + +Patch 6.1.280 +Problem: It's possible to use an argument "firstline" or "lastline" for a + function but using "a:firstline" or "a:lastline" in the function + won't work. (Benji Fisher) +Solution: Give an error message for these arguments. + Also avoid that the following function body causes a whole row of + errors, skip over it after an error in the first line. +Files: src/eval.c + +Patch 6.1.281 +Problem: In Insert mode CTRL-X CTRL-G leaves the cursor after the ruler. +Solution: Set the cursor position before waiting for the argument of CTRL-G. + (Yasuhiro Matsumoto) +Files: src/edit.c + +Patch 6.1.282 +Problem: Elvis uses "se" in a modeline, Vim doesn't recognize this. +Solution: Also accept "se " where "set " is accepted in a modeline. + (Yasuhiro Matsumoto) +Files: src/buffer.c + +Patch 6.1.283 +Problem: For ":sign" the icon file name cannot contain a space. +Solution: Handle backslashes in the file name. (Yasuhiro Matsumoto) +Files: src/ex_cmds.c + +Patch 6.1.284 +Problem: On Solaris there is a warning for "struct utimbuf". +Solution: Move including "utime.h" to outside the function. (Derek Wyatt) +Files: src/fileio.c + +Patch 6.1.285 +Problem: Can't wipe out a buffer with 'bufhide' option. +Solution: Add "wipe" value to 'bufhide'. (Yegappan Lakshmanan) +Files: runtime/doc/options.txt, src/buffer.c, src/option.c, + src/quickfix.c + +Patch 6.1.286 +Problem: 'showbreak' cannot contain multi-byte characters. +Solution: Allow using all printable characters for 'showbreak'. +Files: src/charset.c, src/move.c, src/option.c + +Patch 6.1.287 (depends on 6.1.285) +Problem: Effect of "delete" and "wipe" in 'bufhide' were mixed up. +Solution: Wipe out when wiping out is asked for. +Files: src/buffer.c + +Patch 6.1.288 +Problem: ":silent function F" hangs. (Hari Krishna Dara) +Solution: Don't use msg_col, it is not incremented when using ":silent". + Also made the function output look a bit better. Don't translate + "function". +Files: src/eval.c + +Patch 6.1.289 (depends on 6.1.278) +Problem: Compiler warning for pointer. (Axel Kielhorn) +Solution: Add a typecast for " ". +Files: src/screen.c + +Patch 6.1.290 (extra) +Problem: Truncating long text for message box may break multi-byte + character. +Solution: Adjust to start of multi-byte character. (Yasuhiro Matsumoto) +Files: src/os_mswin.c + +Patch 6.1.291 (extra) +Problem: Win32: CTRL-@ doesn't work. Don't even get a message for it. +Solution: Recognize the keycode for CTRL-@. (Yasuhiro Matsumoto) +Files: src/gui_w48.c + +Patch 6.1.292 (extra, depends on 6.1.253) +Problem: Win32: Can't compile with new MingW compiler. + Borland 5 makefile doesn't generate pathdef.c. +Solution: Remove -wwide-multiply argument. (Rene de Zwart) + Various fixes for other problems in Win32 makefiles. (Dan Sharp) +Files: src/Make_bc5.mak, src/Make_cyg.mak, src/Make_ming.mak, + src/Make_mvc.mak + +Patch 6.1.293 +Problem: byte2line() returns a wrong result for some values. +Solution: Change ">=" to ">" in ml_find_line_or_offset(). (Bradford C Smith) + Add one to the line number when at the end of a block. +Files: src/memline.c + +Patch 6.1.294 +Problem: Can't include a multi-byte character in a string by its hex value. + (Benji Fisher) +Solution: Add "\u....": a character specified with up to four hex numbers + and stored according to the value of 'encoding'. +Files: src/eval.c + +Patch 6.1.295 (extra) +Problem: Processing the cs.po file generates an error. (Rahul Agrawal) +Solution: Fix the printf format characters in the translation. +Files: src/po/cs.po + +Patch 6.1.296 +Problem: Win32: When cancelling the font dialog 'guifont' remains set to + "*". +Solution: Restore the old value of 'guifont' (Yasuhiro Matsumoto) +Files: src/option.c + +Patch 6.1.297 +Problem: "make test" fails in test6 in an UTF-8 environment. (Benji Fisher) +Solution: Before executing the BufReadPost autocommands save the current + fileencoding, so that the file isn't marked changed. +Files: src/fileio.c + +Patch 6.1.298 +Problem: When using signs and the first line of a closed fold has a sign + it can be redrawn as if the fold was open. (Kamil Burzynski) +Solution: Don't redraw a sign inside a closed fold. +Files: src/screen.c + +Patch 6.1.299 +Problem: ":edit +set\ ro file" doesn't work. +Solution: Halve the number of backslashes in the "+cmd" argument. +Files: src/ex_docmd.c + +Patch 6.1.300 (extra) +Problem: Handling of ETO_IGNORELANGUAGE is confusing. +Solution: Clean up the handling of ETO_IGNORELANGUAGE. (Glenn Maynard) +Files: src/gui_w32.c + +Patch 6.1.301 (extra) +Problem: French translation of file-save dialog doesn't show file name. +Solution: Insert a star in the printf string. (Francois Terrot) +Files: src/po/fr.po + +Patch 6.1.302 +Problem: Counting lines of the Visual area is incorrect for closed folds. + (Mikolaj Machowski) +Solution: Correct the start and end for the closed fold. +Files: src/normal.c + +Patch 6.1.303 (extra) +Problem: The Top/Bottom/All text does not always fit in the ruler when + translated to Japanese. Problem with a character being wider when + in a bold font. +Solution: Use ETO_PDY to specify the width of each character. (Yasuhiro + Matsumoto) +Files: src/gui_w32.c + +Patch 6.1.304 (extra, depends on 6.1.292) +Problem: Win32: Postscript is always enabled in the MingW Makefile. + Pathdef.c isn't generated properly with Make_bc5.mak. (Yasuhiro + Matsumoto) +Solution: Change an ifdef to an ifeq. (Madoka Machitani) + Use the Borland make redirection to generate pathdef.c. (Maurice + Barnum) +Files: src/Make_bc5.mak, src/Make_ming.mak + +Patch 6.1.305 +Problem: When 'verbose' is 14 or higher, a function call may cause reading + uninitialized data. (Walter Briscoe) +Solution: Check for end-of-string in trunc_string(). +Files: src/message.c + +Patch 6.1.306 +Problem: The AIX VisualAge cc compiler doesn't define __STDC__. +Solution: Use __EXTENDED__ like __STDC__. (Jess Thrysoee) +Files: src/os_unix.h + +Patch 6.1.307 +Problem: When a double-byte character has an illegal tail byte the display + is messed up. (Yasuhiro Matsumoto) +Solution: Draw "XX" instead of the wrong character. +Files: src/screen.c + +Patch 6.1.308 +Problem: Can't reset the Visual mode returned by visualmode(). +Solution: Use an optional argument to visualmode(). (Charles Campbell) +Files: runtime/doc/eval.txt, src/eval.c, src/normal.c, + src/structs.h + +Patch 6.1.309 +Problem: The tutor doesn't select German if the locale name is + "German_Germany.1252". (Joachim Hofmann) +Solution: Check for "German" in the locale name. Also check for + ".ge". And include the German and Greek tutors. +Files: runtime/tutor/tutor.de, runtime/tutor/tutor.vim, + runtime/tutor/tutor.gr, runtime/tutor/tutor.gr.cp737 + +Patch 6.1.310 (depends on 6.1.307) +Problem: All double-byte characters are displayed as "XX". +Solution: Use ">= 32" instead of "< 32". (Yasuhiro Matsumoto) +Files: src/screen.c + +Patch 6.1.311 (extra) +Problem: VMS: path in window title doesn't include necessary separator. + file version doesn't always work properly with Unix. + Crashes because of memory overwrite in GUI. + Didn't always handle files with lowercase and correct path. +Solution: Fix the problems. Remove unnecessary file name translations. + (Zoltan Arpadffy) +Files: src/buffer.c, src/ex_cmds2.c, src/fileio.c, src/memline.c, + src/misc1.c, src/misc2.c, src/os_unix.c, src/os_vms.c, src/tag.c + +Patch 6.1.312 +Problem: When using ":silent" debugging is also done silently. +Solution: Disable silence while at the debug prompt. +Files: src/ex_cmds2.c + +Patch 6.1.313 +Problem: When a ":drop fname" command is used and "fname" is open in + another window, it is also opened in the current window. +Solution: Change to the window with "fname" instead. + Don't redefine the argument list when dropping only one file. +Files: runtime/doc/windows.txt, src/ex_cmds2.c, src/ex_cmds.c, + src/ex_docmd.c, src/proto/ex_cmds2.pro, src/proto/ex_docmd.pro + +Patch 6.1.314 (depends on 6.1.126) +Problem: Missing backslash in "Generic Config file" syntax menu. +Solution: Insert the backslash. (Zak Beck) +Files: runtime/makemenu.vim, runtime/synmenu.vim + +Patch 6.1.315 (extra) +Problem: A very long hostname may lead to an unterminated string. Failing + to obtain a hostname may result in garbage. (Walter Briscoe) +Solution: Add a NUL at the end of the hostname buffer. +Files: src/os_mac.c, src/os_msdos.c, src/os_unix.c, src/os_win16.c, + src/os_win32.c + +Patch 6.1.316 +Problem: When exiting with "wq" and there is a hidden buffer, after the + "file changed" dialog there is a warning for a changed buffer. + (Ajit Thakkar) +Solution: Do update the buffer timestamps when exiting. +Files: src/fileio.c + +Patch 6.1.317 +Problem: Closing a window may cause some of the remaining windows to be + positioned wrong if there is a mix of horizontal and vertical + splits. (Stefan Ingi Valdimarsson) +Solution: Update the frame sizes before updating the window positions. +Files: src/window.c + +Patch 6.1.318 +Problem: auto/pathdef.c can include wrong quotes when a compiler flag + includes quotes. +Solution: Put a backslash before the quotes in compiler flags. (Shinra Aida) +Files: src/Makefile + +Patch 6.1.319 (depends on 6.1.276) +Problem: Using "--remote +cmd file" does not execute "cmd". +Solution: Call inputrestore() in the same command line as inputsave(), + otherwise it will never get executed. +Files: src/main.c + +Patch 6.1.320 (depends on 6.1.313) +Problem: When a ":drop one\ file" command is used the file "one\ file" is + opened, the backslash is not removed. (Taro Muraoka) +Solution: Handle backslashes correctly. Always set the argument list to + keep it simple. +Files: runtime/doc/windows.txt, src/ex_cmds.c + +Patch 6.1.321 +Problem: When 'mouse' includes 'n' but not 'v', don't allow starting Visual + mode with the mouse. +Solution: Don't use MOUSE_MAY_VIS when there is no 'v' in 'mouse'. (Flemming + Madsen) +Files: src/normal.c + +Patch 6.1.322 (extra, depends on 6.1.315) +Problem: Win32: The host name is always "PC " plus the real host name. +Solution: Don't insert "PC " before the host name. +Files: src/os_win32.c + +Patch 6.1.323 +Problem: ":registers" doesn't stop listing for a "q" at the more prompt. + (Hari Krishna Dara) +Solution: Check for interrupt and got_int. +Files: src/ops.c, src/proto/ops.pro + +Patch 6.1.324 +Problem: Crash when dragging a vertical separator when <LeftMouse> is + remapped to jump to another window. +Solution: Pass the window pointer to the function doing the dragging instead + of always using the current window. (Daniel Elstner) + Also fix that starting a drag changes window focus. +Files: src/normal.c, src/proto/window.pro, src/ui.c, src/vim.h, + src/window.c + +Patch 6.1.325 +Problem: Shift-Tab is not automatically recognized in an xterm. +Solution: Add <Esc>[Z as the termcap code. (Andrew Pimlott) +Files: src/term.c + +Patch 6.1.326 +Problem: Using a search pattern may read from uninitialized data (Yasuhiro + Matsumoto) +Solution: Initialize pointers to NULL. +Files: src/regexp.c + +Patch 6.1.327 +Problem: When opening the "mbyte.txt" help file the utf-8 characters are + unreadable, because the fileencoding is forced to be latin1. +Solution: Check for utf-8 encoding first in help files. (Daniel Elstner) +Files: runtime/doc/mbyte.txt, src/fileio.c + +Patch 6.1.328 +Problem: Prototype for enc_canon_search() is missing. +Solution: Add the prototype. (Walter Briscoe) +Files: src/mbyte.c + +Patch 6.1.329 +Problem: When editing a file "a b c" replacing "%" in ":Cmd %" or ":next %" + does not work properly. (Hari Krishna Dara) +Solution: Always escape spaces when expanding "%". Don't split argument for + <f-args> in a user command when only one argument is used. +Files: src/ex_docmd.c + +Patch 6.1.330 +Problem: GTK, Motif and Athena: Keypad keys produce the same code as + non-keypad keys, making it impossible to map them separately. +Solution: Use different termcap codes for the keypad keys. (Neil Bird) +Files: src/gui_gtk_x11.c, src/gui_x11.c + +Patch 6.1.331 +Problem: When translating the help files, "LOCAL ADDITIONS" no longer marks + the spot where help files from plugins are to be listed. +Solution: Add a "local-additions" tag and use that to find the right spot. +Files: runtime/doc/help.txt, src/ex_cmds.c + +Patch 6.1.332 (extra) +Problem: Win32: Loading Perl dynamically doesn't work with Perl 5.8. + Perl 5.8 also does not work with Cygwin and Ming. +Solution: Adjust the function calls. (Taro Muraoka) + Adjust the cyg and ming makefiles. (Dan Sharp) +Files: src/Make_cyg.mak, src/Make_ming.mak, src/Make_mvc.mak, + src/if_perl.xs + +Patch 6.1.333 (extra) +Problem: Win32: Can't handle Unicode text on the clipboard. + Can't pass NUL byte, it becomes a line break. (Bruce DeVisser) +Solution: Support Unicode for the clipboard (Ron Aaron and Glenn Maynard) + Also support copy/paste of NUL bytes. +Files: src/os_mswin.c, src/os_win16.c src/os_win32.c + +Patch 6.1.334 (extra, depends on 6.1.303) +Problem: Problem with drawing Hebrew characters. +Solution: Only use ETO_PDY for Windows NT and the like. (Yasuhiro Matsumoto) +Files: src/gui_w32.c + +Patch 6.1.335 (extra) +Problem: Failure of obtaining the cursor position and window size is + ignored. +Solution: Remove a semicolon after an "if". (Walter Briscoe) +Files: src/gui_w32.c + +Patch 6.1.336 (extra) +Problem: Warning for use of function prototypes of smsg(). +Solution: Define HAVE_STDARG_H. (Walter Briscoe) +Files: src/os_win32.h + +Patch 6.1.337 +Problem: When using "finish" in debug mode in function B() for ":call + A(B())" does not stop after B() is finished. +Solution: Increase debug_level while evaluating a function. +Files: src/ex_docmd.c + +Patch 6.1.338 +Problem: When using a menu that checks out the current file from Insert + mode, there is no warning for the changed file until exiting + Insert mode. (Srikanth Sankaran) +Solution: Add a check for need_check_timestamps in the Insert mode loop. +Files: src/edit.c + +Patch 6.1.339 +Problem: Completion doesn't allow "g:" in ":let g:did_<Tab>". (Benji + Fisher) +Solution: Return "g:var" for global variables when that is what is being + expanded. (Flemming Madsen) +Files: src/eval.c + +Patch 6.1.340 (extra, depends on 6.1.332) +Problem: Win32: Can't compile the Perl interface with nmake. +Solution: Don't compare the version number as a string but as a number. + (Juergen Kraemer) +Files: src/Make_mvc.mak + +Patch 6.1.341 +Problem: In Insert mode with 'rightleft' set the cursor is drawn halfway a + double-wide character. For CTRL-R and CTRL-K in Insert mode the " + or ? is not displayed. +Solution: Draw the cursor in the next character cell. Display the " or ? + over the right half of the double-wide character. (Yasuhiro + Matsumoto) Also fix that cancelling a digraph doesn't redraw + a double-byte character correctly. +Files: src/edit.c, src/gui.c, src/mbyte.c + +Patch 6.1.342 (depends on 6.1.341) +Problem: With 'rightleft' set typing "c" on a double-wide character causes + the cursor to be displayed one cell to the left. +Solution: Draw the cursor in the next character cell. (Yasuhiro Matsumoto) +Files: src/gui.c + +Patch 6.1.343 (depends on 6.1.342) +Problem: Cannot compile with the +multi_byte feature but without +rightleft. + Cannot compile without the GUI. +Solution: Fix the #ifdefs. (partly by Nam SungHyun) +Files: src/gui.c, src/mbyte.c, src/ui.c + +Patch 6.1.344 +Problem: When using ":silent filetype" the output is still put in the + message history. (Hari Krishna Dara) +Solution: Don't add messages in the history when ":silent" is used. +Files: src/message.c + +Patch 6.1.345 (extra) +Problem: Win32: 'imdisable' doesn't work. +Solution: Make 'imdisable' work. (Yasuhiro Matsumoto) +Files: src/gui_w32.c + +Patch 6.1.346 +Problem: The scroll wheel can only scroll the current window. +Solution: Make the scroll wheel scroll the window that the mouse points to. + (Daniel Elstner) +Files: src/edit.c, src/gui.c, src/normal.c, src/term.c + +Patch 6.1.347 +Problem: When using cscope to list matching tags, the listed number is + sometimes not equal to what cscope uses. (Vihren Milev) +Solution: For cscope tags use only one table, don't give tags in the current + file a higher priority. +Files: src/tag.c + +Patch 6.1.348 +Problem: Wildmode with wildmenu: ":set wildmode=list,full", ":colorscheme + <tab>" results in "zellner" instead of the first entry. (Anand + Hariharan) +Solution: Don't call ExpandOne() from globpath(). (Flemming Madsen) +Files: src/ex_getln.c + +Patch 6.1.349 +Problem: "vim --serverlist" when no server was ever started gives an error + message without "\n". + "vim --serverlist" doesn't exit when the X server can't be + contacted, it starts Vim unexpectedly. (Ricardo Signes) +Solution: Don't give an error when no Vim server was ever started. + Treat failing of opening the display equal to errors inside the + remote*() functions. (Flemming Madsen) +Files: src/if_xcmdsrv.c, src/main.c + +Patch 6.1.350 +Problem: When entering a buffer with ":bnext" for the first time, using an + autocommand to restore the last used cursor position doesn't work. + (Paolo Giarusso) +Solution: Don't use the last known cursor position of the current Vim + invocation if an autocommand changed the position. +Files: src/buffer.c + +Patch 6.1.351 (depends on 6.1.349) +Problem: Crash when starting Vim the first time in an X server. (John + McGowan) +Solution: Don't call xFree() with a fixed string. +Files: src/if_xcmdsrv.c + +Patch 6.1.352 (extra, depends on 6.1.345) +Problem: Win32: Crash when setting "imdisable" in _vimrc. +Solution: Don't call IME functions when imm32.dll was not loaded (yet). + Also add typecasts to avoid Compiler warnings for + ImmAssociateContext() argument. +Files: src/gui_w32.c + +Patch 6.1.353 (extra, depends on 6.1.334) +Problem: Problem with drawing Arabic characters. +Solution: Don't use ETO_PDY, do use padding. +Files: src/gui_w32.c + +Patch 6.1.354 (extra, depends on 6.1.333) +Problem: MS-Windows 98: Notepad can't paste text copied from Vim when + 'encoding' is "utf-8". +Solution: Also make CF_TEXT available on the clipboard. (Ron Aaron) +Files: src/os_mswin.c + +Patch 6.1.355 +Problem: In a regexp '\n' will never match anything in a string. +Solution: Make '\n' match a newline character. +Files: src/buffer.c, src/edit.c, src/eval.c, src/ex_cmds2.c, + src/ex_docmd.c, src/ex_getln.c, src/fileio.c, src/misc1.c, + src/option.c, src/os_mac.c, src/os_unix.c, src/quickfix.c, + src/regexp.c, src/search.c, src/syntax.c, src/tag.c, src/vim.h + +Patch 6.1.356 (extra, depends on, well, eh, several others) +Problem: Compiler warnings for using convert_setup() and a few other + things. +Solution: Add typecasts. +Files: src/mbyte.c, src/os_mswin.c, src/proto/os_win32.pro, src/os_win32.c + +Patch 6.1.357 +Problem: CR in the quickfix window jumps to the error under the cursor, but + this doesn't work in Insert mode. (Srikanth Sankaran) +Solution: Handle CR in Insert mode in the quickfix window. +Files: src/edit.c + +Patch 6.1.358 +Problem: The tutor doesn't select another locale version properly. +Solution: Insert the "let" command. (Yasuhiro Matsumoto) +Files: runtime/tutor/tutor.vim + +Patch 6.1.359 (extra) +Problem: Mac Carbon: Vim doesn't get focus when started from the command + line. Crash when using horizontal scroll bar. +Solution: Set Vim as the frontprocess. Fix scrolling. (Peter Cucka) +Files: src/gui_mac.c + +Patch 6.1.360 (depends on 6.1.341) +Problem: In Insert mode CTRL-K ESC messes up a multi-byte character. + (Anders Helmersson) +Solution: Save all bytes of a character when displaying a character + temporarily. +Files: src/edit.c, src/proto/screen.pro, src/screen.c + +Patch 6.1.361 +Problem: Cannot jump to a file mark with ":'M". +Solution: Allow jumping to another file for a mark in an Ex address when it + is the only thing in the command line. +Files: src/ex_docmd.c + +Patch 6.1.362 +Problem: tgetent() may return zero for success. tgetflag() may return -1 + for an error. +Solution: Check tgetflag() for returning a positive value. Add an autoconf + check for the value that tgetent() returns. +Files: src/auto/configure, src/config.h.in, src/configure.in, src/term.c + +Patch 6.1.363 +Problem: byte2line() can return one more than the number of lines. +Solution: Return -1 if the offset is one byte past the end. +Files: src/memline.c + +Patch 6.1.364 +Problem: That the FileChangedShell autocommand event never nests makes it + difficult to reload a file in a normal way. +Solution: Allow nesting for the FileChangedShell event but do not allow + triggering itself again. + Also avoid autocommands for the cmdline window in rare cases. +Files: src/ex_getln.c, src/fileio.c, src/window.c + +Patch 6.1.365 (depends on 6.1.217) +Problem: Setting a breakpoint in a sourced file with a relative path name + doesn't work. (Servatius Brandt) +Solution: Expand the file name to a full path. +Files: src/ex_cmds2.c + +Patch 6.1.366 +Problem: Can't use Vim with Netbeans. +Solution: Add the Netbeans interface. Includes support for sign icons and + "-fg" and "-bg" arguments for GTK. Add the 'autochdir' + option. (Gordon Prieur, George Hernandez, Dave Weatherford) + Make it possible to display both a sign with a text and one with + line highlighting in the same line. + Add support for Agide, interface version 2.1. + Also fix that when 'iskeyword' includes '?' the "*" command + doesn't work properly on a word that includes "?" (Bill McCarthy): + Don't escape "?" to "\?" when searching forward. +Files: runtime/doc/Makefile, runtime/doc/netbeans.txt, + runtime/doc/options.txt, runtime/doc/various.txt, + src/Makefile, src/auto/configure, src/buffer.c, src/config.h.in, + src/config.mk.in, src/configure.in, src/edit.c, src/ex_cmds.c, + src/ex_docmd.c, src/feature.h, src/fileio.c, src/globals.h, + src/gui.c, src/gui_beval.c, src/gui_gtk_x11.c, src/gui_x11.c, + src/main.c, src/memline.c, src/misc1.c, src/misc2.c, src/move.c, + src/nbdebug.c, src/nbdebug.h, src/netbeans.c, src/normal.c, + src/ops.c, src/option.c, src/option.h, src/proto/buffer.pro, + src/proto/gui_beval.pro, src/proto/gui_gtk_x11.pro, + src/proto/gui_x11.pro, src/proto/misc2.pro, + src/proto/netbeans.pro, src/proto/normal.pro, src/proto/ui.pro, + src/proto.h, src/screen.c, src/structs.h, src/ui.c, src/undo.c, + src/vim.h, src/window.c, src/workshop.c + +Patch 6.1.367 (depends on 6.1.365) +Problem: Setting a breakpoint in a function doesn't work. For a sourced + file it doesn't work when symbolic links are involved. (Servatius + Brandt) +Solution: Expand the file name in the same way as do_source() does. Don't + prepend the path to a function name. +Files: src/ex_cmds2.c + +Patch 6.1.368 +Problem: Completion for ":map" does not include <silent> and <script>. + ":mkexrc" do not save the <silent> attribute of mappings. +Solution: Add "<silent>" to the generated map commands when appropriate. + (David Elstner) + Add <silent> and <script> to command line completion. +Files: src/getchar.c + +Patch 6.1.369 (extra) +Problem: VMS: Vim hangs when attempting to edit a read-only file in the + terminal. Problem with VMS filenames for quickfix. +Solution: Rewrite low level input. Remove version number from file name in + a couple more places. Fix crash after patch 6.1.362. Correct + return code for system(). (Zoltan Arpadffy, Tomas Stehlik) +Files: src/misc1.c, src/os_unix.c, src/os_vms.c, src/proto/os_vms.pro, + src/os_vms_conf.h, src/quickfix.c, src/ui.c + +Patch 6.1.370 +Problem: #ifdef nesting is unclear. +Solution: Insert spaces to indicate the nesting. +Files: src/os_unix.c + +Patch 6.1.371 +Problem: "%V" in 'statusline' doesn't show "0-1" in an empty line. +Solution: Add one to the column when comparing with virtual column (Andrew + Pimlott) +Files: src/buffer.c + +Patch 6.1.372 +Problem: With 16 bit ints there are compiler warnings. (Walter Briscoe) +Solution: Change int into long. +Files: src/structs.h, src/syntax.c + +Patch 6.1.373 +Problem: The default page header for printing is not translated. +Solution: Add _() around the two places where "Page" is used. (Mike + Williams) Translate the default value of the 'titleold' and + 'printheader' options. +Files: src/ex_cmds2.c, src/option.c + +Patch 6.1.374 (extra) +Problem: MS-Windows: Cannot build GvimExt with MingW or Cygwin. +Solution: Add makefile and modified resource files. (Rene de Zwart) + Also support Cygwin. (Alejandro Lopez_Valencia) +Files: GvimExt/Make_cyg.mak, GvimExt/Make_ming.mak, GvimExt/Makefile, + GvimExt/gvimext_ming.def, GvimExt/gvimext_ming.rc + +Patch 6.1.375 +Problem: MS-Windows: ':!dir "%"' does not work for a file name with spaces. + (Xiangjiang Ma) +Solution: Don't insert backslashes for spaces in a shell command. +Files: src/ex_docmd.c + +Patch 6.1.376 +Problem: "vim --version" and "vim --help" have a non-zero exit code. + That is unusual. (Petesea) +Solution: Use a zero exit code. +Files: src/main.c + +Patch 6.1.377 +Problem: Can't add words to 'lispwords' option. +Solution: Add P_COMMA and P_NODUP flags. (Haakon Riiser) +Files: src/option.c + +Patch 6.1.378 +Problem: When two buffer-local user commands are ambiguous, a full match + with a global user command isn't found. (Hari Krishna Dara) +Solution: Detect this situation and accept the global command. +Files: src/ex_docmd.c + +Patch 6.1.379 +Problem: Linux with kernel 2.2 can't use the alternate stack in combination + with threading, causes an infinite loop. +Solution: Don't use the alternate stack in this situation. +Files: src/os_unix.c + +Patch 6.1.380 +Problem: When 'winminheight' is zero and the quickfix window is zero lines, + entering the window doesn't make it higher. (Christian J. + Robinson) +Solution: Make sure the current window is at least one line high. +Files: src/window.c + +Patch 6.1.381 +Problem: When a BufWriteCmd is used and it leaves the buffer modified, the + window may still be closed. (Hari Krishna Dara) +Solution: Return FAIL from buf_write() when the buffer is still modified + after a BufWriteCmd autocommand was used. +Files: src/fileio.c + +Patch 6.1.382 (extra) +Problem: Win32 GUI: When using two monitors, the code that checks/fixes the + window size and position (e.g. when a font changes) doesn't work + properly. (George Reilly) +Solution: Handle a double monitor situation. (Helmut Stiegler) +Files: src/gui_w32.c + +Patch 6.1.383 +Problem: The filling of the status line doesn't work properly for + multi-byte characters. (Nam SungHyun) + There is no check for going past the end of the buffer. +Solution: Properly distinguish characters and bytes. Properly check for + running out of buffer space. +Files: src/buffer.c, src/ex_cmds2.c, src/proto/buffer.pro, src/screen.c + +Patch 6.1.384 +Problem: It is not possible to find if a certain patch has been included. + (Lubomir Host) +Solution: Support using has() to check if a patch was included. +Files: runtime/doc/eval.txt, src/eval.c, src/proto/version.pro, + src/version.c + +Patch 6.1.385 (depends on 6.1.383) +Problem: Can't compile without the multi-byte feature. +Solution: Move an #ifdef. (Christian J. Robinson) +Files: src/buffer.c + +Patch 6.1.386 +Problem: Get duplicate tags when running ":helptags". +Solution: Do the other halve of moving a section to another help file. +Files: runtime/tagsrch.txt + +Patch 6.1.387 (depends on 6.1.373) +Problem: Compiler warning for pointer cast. +Solution: Add (char_u *). +Files: src/option.c + +Patch 6.1.388 (depends on 6.1.384) +Problem: Compiler warning for pointer cast. +Solution: Add (char *). Only include has_patch() when used. +Files: src/eval.c, src/version.c + +Patch 6.1.389 (depends on 6.1.366) +Problem: Balloon evaluation doesn't work for GTK. + has("balloon_eval") doesn't work. +Solution: Add balloon evaluation for GTK. Also improve displaying of signs. + (Daniel Elstner) + Also make ":gui" start the netbeans connection and avoid using + netbeans functions when the connection is not open. +Files: src/Makefile, src/feature.h, src/gui.c, src/gui.h, + src/gui_beval.c, src/gui_beval.h, src/gui_gtk.c, + src/gui_gtk_x11.c, src/eval.c, src/memline.c, src/menu.c, + src/netbeans.c, src/proto/gui_beval.pro, src/proto/gui_gtk.pro, + src/structs.h, src/syntax.c, src/ui.c, src/workshop.c + +Patch 6.1.390 (depends on 6.1.389) +Problem: It's not possible to tell Vim to save and exit through the + Netbeans interface. Would still try to send balloon eval text + after the connection is closed. + Can't use Unicode characters for sign text. +Solution: Add functions "saveAndExit" and "getModified". Check for a + working connection before sending a balloonText event. + various other cleanups. + Support any character for sign text. (Daniel Elstner) +Files: runtime/doc/netbeans.txt, runtime/doc/sign.txt, src/ex_cmds.c, + src/netbeans.c, src/screen.c + +Patch 6.1.391 +Problem: ml_get() error when using virtualedit. (Charles Campbell) +Solution: Get a line from a specific window, not the current one. +Files: src/charset.c + +Patch 6.1.392 (depends on 6.1.383) +Problem: Highlighting in the 'statusline' is in the wrong position when an + item is truncated. (Zak Beck) +Solution: Correct the start of 'statusline' items properly for a truncated + item. +Files: src/buffer.c + +Patch 6.1.393 +Problem: When compiled with Python and threads, detaching the terminal may + cause Vim to loop forever. +Solution: Add -pthread to $CFLAGS when using Python and gcc. (Daniel + Elstner) +Files: src/auto/configure,, src/configure.in + +Patch 6.1.394 (depends on 6.1.390) +Problem: The netbeans interface doesn't recognize multibyte glyph names. +Solution: Check the number of cells rather than bytes to decide + whether a glyph name is not a filename. (Daniel Elstner) +Files: src/netbeans.c + +Patch 6.1.395 (extra, depends on 6.1.369) +Problem: VMS: OLD_VMS is never defined. Missing function prototype. +Solution: Define OLD_VMS in Make_vms.mms. Add vms_sys_status() to + os_vms.pro. (Zoltan Arpadffy) +Files: src/Make_vms.mms, src/proto/os_vms.pro + +Patch 6.1.396 (depends on 6.1.330) +Problem: Compiler warnings for using enum. +Solution: Add typecast to char_u. +Files: src/gui_gtk_x11.c, src/gui_x11.c + +Patch 6.1.397 (extra) +Problem: The install program may use a wrong path for the diff command if + there is a space in the install directory path. +Solution: Use double quotes around the path if necessary. (Alejandro + Lopez-Valencia) Also use double quotes around the file name + arguments. +Files: src/dosinst.c + +Patch 6.1.398 +Problem: Saving the typeahead for debug mode causes trouble for a test + script. (Servatius Brandt) +Solution: Add the ":debuggreedy" command to avoid saving the typeahead. +Files: runtime/doc/repeat.txt, src/ex_cmds.h, src/ex_cmds2.c, + src/ex_docmd.c, src/proto/ex_cmds2.pro + +Patch 6.1.399 +Problem: Warning for unused variable. +Solution: Remove the variable two_or_more. +Files: src/ex_cmds.c + +Patch 6.1.400 (depends on 6.1.381) +Problem: When a BufWriteCmd wipes out the buffer it may still be accessed. +Solution: Don't try accessing a buffer that has been wiped out. +Files: src/fileio.c + +Patch 6.1.401 (extra) +Problem: Building the Win16 version with Borland 5.01 doesn't work. + "make test" doesn't work with Make_dos.mak. (Walter Briscoe) +Solution: Various fixes to the w16 makefile. (Walter Briscoe) + Don't use deltree. Use "mkdir \tmp" instead of "mkdir /tmp". +Files: src/Make_w16.mak, src/testdir/Make_dos.mak + +Patch 6.1.402 +Problem: When evaluating a function name with curly braces, an error + is not handled consistently. +Solution: Accept the result of an curly braces expression when an + error was encountered. Skip evaluating an expression in curly + braces when skipping. (Servatius Brandt) +Files: src/eval.c + +Patch 6.1.403 (extra) +Problem: MS-Windows 16 bit: compiler warnings. +Solution: Add typecasts. (Walter Briscoe) +Files: src/ex_cmds2.c, src/gui_w48.c, src/os_mswin.c, src/os_win16.c, + src/syntax.c + +Patch 6.1.404 (extra) +Problem: Various small problems. +Solution: Fix comments. Various small additions, changes in indent, removal + of unused items and fixes. +Files: Makefile, README.txt, runtime/menu.vim, runtime/vimrc_example.vim, + src/INSTALL, src/INSTALLole.txt, src/Make_bc5.mak, + src/Make_cyg.mak, src/Make_ming.mak, src/Makefile, + src/config.h.in, src/edit.c, src/eval.c, src/ex_cmds2.c, + src/ex_docmd.c, src/ex_getln.c, src/fileio.c, src/getchar.c, + src/gui.c, src/gui_gtk.c, src/gui_photon.c, src/if_cscope.c, + src/if_python.c, src/keymap.h, src/mark.c, src/mbyte.c, + src/message.c, src/misc1.c, src/misc2.c, src/normal.c, + src/option.c, src/os_os2_cfg.h, src/os_win32.c, + src/proto/getchar.pro, src/proto/message.pro, + src/proto/regexp.pro, src/screen.c, src/structs.h, src/syntax.c, + src/term.c, src/testdir/test15.in, src/testdir/test15.ok, + src/vim.rc, src/xxd/Make_cyg.mak, src/xxd/Makefile + +Patch 6.1.405 +Problem: A few files are missing from the toplevel Makefile. +Solution: Add the missing files. +Files: Makefile + +Patch 6.1.406 (depends on 6.1.392) +Problem: When a statusline item doesn't fit arbitrary text appears. + (Christian J. Robinson) +Solution: When there is just enough room but not for the "<" truncate the + statusline item like there is no room. +Files: src/buffer.c + +Patch 6.1.407 +Problem: ":set scrollbind | help" scrollbinds the help window. (Andrew + Pimlott) +Solution: Reset 'scrollbind' when opening a help window. +Files: src/ex_cmds.c + +Patch 6.1.408 +Problem: When 'rightleft' is set unprintable character 0x0c is displayed as + ">c0<". +Solution: Reverse the text of the hex character. +Files: src/screen.c + +Patch 6.1.409 +Problem: Generating tags for the help doesn't work for some locales. +Solution: Set LANG=C LC_ALL=C in the environment for "sort". (Daniel + Elstner) +Files: runtime/doc/Makefile + +Patch 6.1.410 (depends on 6.1.390) +Problem: Linking error when compiling with Netbeans but without sign icons. + (Malte Neumann) +Solution: Don't define buf_signcount() when sign icons are unavailable. +Files: src/buffer.c + +Patch 6.1.411 +Problem: When 'virtualedit' is set, highlighting a Visual block beyond the + end of a line may be wrong. +Solution: Correct the virtual column when the end of the line is before the + displayed part of the line. (Muraoka Taro) +Files: src/screen.c + +Patch 6.1.412 +Problem: When swapping terminal screens and using ":gui" to start the GUI, + the shell prompt may be after a hit-enter prompt. +Solution: Output a newline in the terminal when starting the GUI and there + was a hit-enter prompt.. +Files: src/gui.c + +Patch 6.1.413 +Problem: When 'clipboard' contains "unnamed", "p" in Visual mode doesn't + work correctly. +Solution: Save the register before overwriting it and put the resulting text + on the clipboard afterwards. (Muraoka Taro) +Files: src/normal.c, src/ops.c + +Patch 6.1.414 (extra, depends on 6.1.369) +Problem: VMS: Vim busy waits when waiting for input. +Solution: Delay for a short while before getting another character. (Zoltan + Arpadffy) +Files: src/os_vms.c + +Patch 6.1.415 +Problem: When there is a vertical split and a quickfix window, reducing the + size of the Vim window may result in a wrong window layout and a + crash. +Solution: When reducing the window size and there is not enough space for + 'winfixheight' set the frame height to the larger height, so that + there is a retry while ignoring 'winfixheight'. (Yasuhiro + Matsumoto) +Files: src/window.c + +Patch 6.1.416 (depends on 6.1.366) +Problem: When using the Netbeans interface, a line with a sign cannot be + changed. +Solution: Respect the GUARDEDOFFSET for sign IDs when checking for a guarded + area. +Files: src/netbeans.c + +Patch 6.1.417 +Problem: Unprintable multi-byte characters are not handled correctly. + Multi-byte characters above 0xffff are displayed as another + character. +Solution: Handle unprintable multi-byte characters. Display multi-byte + characters above 0xffff with a marker. Recognize UTF-16 words and + BOM words as unprintable. (Daniel Elstner) +Files: src/charset.c, src/mbyte.c, src/screen.c + +Patch 6.1.418 +Problem: The result of strftime() is in the current locals. Need to + convert it to 'encoding'. +Solution: Obtain the current locale and convert the argument for strftime() + to it and the result back to 'encoding'. (Daniel Elstner) +Files: src/eval.c, src/ex_cmds.c, src/ex_cmds2.c, src/mbyte.c, + src/proto/mbyte.pro, src/option.c, src/os_mswin.c + +Patch 6.1.419 +Problem: Vim doesn't compile on AIX 5.1. +Solution: Don't define _NO_PROTO on this system. (Uribarri) +Files: src/auto/configure, src/configure.in + +Patch 6.1.420 (extra) +Problem: convert_input() has an unnecessary STRLEN(). + Conversion from UCS-2 to a codepage uses word count instead of + byte count. +Solution: Remove the STRLEN() call. (Daniel Elstner) + Always use byte count for string_convert(). +Files: src/gui_w32.c, src/mbyte.c + +Patch 6.1.421 (extra, depends on 6.1.354) +Problem: MS-Windows 9x: When putting text on the clipboard it can be in + the wrong encoding. +Solution: Convert text to the active codepage for CF_TEXT. (Glenn Maynard) +Files: src/os_mswin.c + +Patch 6.1.422 +Problem: Error in .vimrc doesn't cause hit-enter prompt when swapping + screens. (Neil Bird) +Solution: Set msg_didany also when sending a message to the terminal + directly. +Files: src/message.c + +Patch 6.1.423 +Problem: Can't find arbitrary text in help files. +Solution: Added the ":helpgrep" command. +Files: runtime/doc/various.txt, src/ex_cmds.h, src/ex_docmd.c, + src/proto/quickfix.pro, src/quickfix.c + +Patch 6.1.424 (extra) +Problem: Win32: Gvim compiled with VC++ 7.0 run on Windows 95 does not show + menu items. +Solution: Define $WINVER to avoid an extra item is added to MENUITEMINFO. + (Muraoka Taro) +Files: src/Make_mvc.mak + +Patch 6.1.425 +Problem: ":helptags $VIMRUNTIME/doc" does not add the "help-tags" tag. +Solution: Do add the "help-tags" tag for that specific directory. +Files: src/ex_cmds.c + +Patch 6.1.426 +Problem: "--remote-wait +cmd file" waits forever. (Valery Kondakoff) +Solution: Don't wait for the "+cmd" argument to have been edited. +Files: src/main.c + +Patch 6.1.427 +Problem: Several error messages for regexp patterns are not translated. +Solution: Use _() properly. (Muraoka Taro) +Files: src/regexp.c + +Patch 6.1.428 +Problem: FreeBSD: wait() may hang when compiled with Python support and + doing a system() call in a startup script. +Solution: Use waitpid() instead of wait() and poll every 10 msec, just like + what is done in the GUI. +Files: src/os_unix.c + +Patch 6.1.429 (depends on 6.1.390) +Problem: Crash when using showmarks.vim plugin. (Charles Campbell) +Solution: Check for sign_get_text() returning a NULL pointer. +Files: src/screen.c + +Patch 6.1.430 +Problem: In Lisp code backslashed parens should be ignored for "%". (Dorai) +Solution: Skip over backslashed parens. +Files: src/search.c + +Patch 6.1.431 +Problem: Debug commands end up in redirected text. +Solution: Disable redirection while handling debug commands. +Files: src/ex_cmds2.c + +Patch 6.1.432 (depends on 6.1.375) +Problem: MS-Windows: ":make %:p" inserts extra backslashes. (David Rennalls) +Solution: Don't add backslashes, handle it like ":!cmd". +Files: src/ex_docmd.c + +Patch 6.1.433 +Problem: ":popup" only works for Win32. +Solution: Add ":popup" support for GTK. (Daniel Elstner) +Files: runtime/doc/gui.txt, src/ex_docmd.c, src/gui_gtk.c, src/menu.c, + src/proto/gui_gtk.pro + +Patch 6.1.434 (extra) +Problem: Win32: When there are more than 32767 lines, the scrollbar has a + roundoff error. +Solution: Make a click on an arrow move one line. Also move the code to + gui_w48.c, there is hardly any difference between the 16 bit and + 32 bit versions. (Walter Briscoe) +Files: src/gui_w16.c, src/gui_w32.c, src/gui_w48.c + +Patch 6.1.435 +Problem: ":winsize x" resizes the Vim window to the minimal size. (Andrew + Pimlott) +Solution: Give an error message for wrong arguments of ":winsize" and + ":winpos". +Files: src/ex_docmd.c + +Patch 6.1.436 +Problem: When a long UTF-8 file contains an illegal byte it's hard to find + out where it is. (Ron Aaron) +Solution: Add the line number to the error message. +Files: src/fileio.c + +Patch 6.1.437 (extra, depends on 6.1.421) +Problem: Using multi-byte functions when they are not available. +Solution: Put the clipboard conversion inside an #ifdef. (Vince Negri) + Also fix a pointer type mistake. (Walter Briscoe) +Files: src/os_mswin.c + +Patch 6.1.438 +Problem: When Perl has thread support Vim cannot use the Perl interface. +Solution: Add a configure check and disable Perl when it will not work. + (Aron Griffis) +Files: src/auto/configure, src/configure.in + +Patch 6.1.439 +Problem: Netbeans: A "create" function doesn't actually create a buffer, + following functions may fail. +Solution: Create a Vim buffer without a name when "create" is called. + (Gordon Prieur) +Files: runtime/doc/netbeans.txt, src/netbeans.c + +Patch 6.1.440 +Problem: The "@*" command doesn't obtain the actual contents of the + clipboard. (Hari Krishna Dara) +Solution: Obtain the clipboard text before executing the command. +Files: src/ops.c + +Patch 6.1.441 +Problem: "zj" and "zk" cannot be used as a motion command after an + operator. (Ralf Hetzel) +Solution: Accept these commands as motion commands. +Files: src/normal.c + +Patch 6.1.442 +Problem: Unicode 3.2 defines more space and punctuation characters. +Solution: Add the new characters to the Unicode tables. (Raphael Finkel) +Files: src/mbyte.c + +Patch 6.1.443 (extra) +Problem: Win32: The gvimext.dll build with Borland 5.5 requires another + DLL. +Solution: Build a statically linked version by default. (Dan Sharp) +Files: GvimExt/Make_bc5.mak + +Patch 6.1.444 (extra) +Problem: Win32: Enabling a build with gettext support is not consistent. +Solution: Use "GETTEXT" for Borland and msvc makefiles. (Dan Sharp) +Files: src/Make_bc5.mak, src/Make_mvc.mak + +Patch 6.1.445 (extra) +Problem: DJGPP: get warning for argument of putenv() +Solution: Define HAVE_PUTENV to use DJGPP's putenv(). (Walter Briscoe) +Files: src/os_msdos.h + +Patch 6.1.446 (extra) +Problem: Win32: The MingW makefile uses a different style of arguments than + other makefiles. + Dynamic IME is not supported for Cygwin. +Solution: Use "no" and "yes" style arguments. Remove the use of the + dyn-ming.h include file. (Dan Sharp) + Do not include the ime.h file and adjust the makefile. (Alejandro + Lopez-Valencia) +Files: src/Make_cyg.mak, src/Make_ming.mak, src/gui_w32.c, + src/if_perl.xs, src/if_python.c, src/if_ruby.c, src/os_win32.c + +Patch 6.1.447 +Problem: "make install" uses "make" directly for generating help tags. +Solution: Use $(MAKE) instead of "make". (Tim Mooney) +Files: src/Makefile + +Patch 6.1.448 +Problem: 'titlestring' has a default maximum width of 50 chars per item. +Solution: Remove the default maximum (also for 'statusline'). +Files: src/buffer.c + +Patch 6.1.449 +Problem: When "1" and "a" are in 'formatoptions', auto-formatting always + moves a newly added character to the next line. (Servatius Brandt) +Solution: Don't move a single character to the next line when it was just + typed. +Files: src/edit.c + +Patch 6.1.450 +Problem: Termcap entry "kB" for back-tab is not recognized. +Solution: Use back-tab as the shift-tab code. +Files: src/keymap.h, src/misc2.c, src/term.c + +Patch 6.1.451 +Problem: GUI: When text in the find dialog contains a slash, a backslash is + inserted the next time it is opened. (Mezz) +Solution: Remove escaped backslashes and question marks. (Daniel Elstner) +Files: src/gui.c + +Patch 6.1.452 (extra, after 6.1.446) +Problem: Win32: IME support doesn't work for MSVC. +Solution: Use _MSC_VER instead of __MSVC. (Alejandro Lopez-Valencia) +Files: src/gui_w32.c + +Patch 6.1.453 (after 6.1.429) +Problem: When compiled without sign icons but with sign support, adding a + sign may cause a crash. +Solution: Check for the text sign to exist before using it. (Kamil + Burzynski) +Files: src/screen.c + +Patch 6.1.454 (extra) +Problem: Win32: pasting Russian text in Vim with 'enc' set to cp1251 + results in utf-8 bytes. (Perelyubskiy) + Conversion from DBCS to UCS2 does not work when 'encoding' is not + the active codepage. +Solution: Introduce enc_codepage and use it for conversion to 'encoding' + (Glenn Maynard) + Use MultiByteToWideChar() and WideCharToMultiByte() instead of + iconv(). Should do most needed conversions without iconv.dll. +Files: src/globals.h, src/gui_w32.c, src/mbyte.c, src/os_mswin.c, + src/proto/mbyte.pro, src/proto/os_mswin.pro, src/structs.h + +Patch 6.1.455 +Problem: Some Unicode characters can be one or two character cells wide. +Solution: Add the 'ambiwidth' option to tell Vim how to display these + characters. (Jungshik Shin) + Also reset the script ID when setting an option to its default + value, so that ":verbose set" won't give wrong info. +Files: runtime/doc/options.txt, src/mbyte.c, src/option.c, src/option.h + +Patch 6.1.456 (extra, after 6.1.454) +Problem: Win32: IME doesn't work. +Solution: ImmGetCompositionStringW() returns the size in bytes, not words. + (Yasuhiro Matsumoto) Also fix typecast problem. +Files: src/gui_w32.c, src/os_mswin.c + +Patch 6.1.457 +Problem: An empty register in viminfo causes conversion to fail. +Solution: Don't convert an empty string. (Yasuhiro Matsumoto) +Files: src/ex_cmds.c, src/mbyte.c + +Patch 6.1.458 +Problem: Compiler warning for pointer. +Solution: Add a typecast. +Files: src/ex_cmds.c + +Patch 6.1.459 (extra) +Problem: Win32: libcall() may return an invalid pointer and cause Vim to + crash. +Solution: Add a strict check for the returned pointer. (Bruce Mellows) +Files: src/os_mswin.c + +Patch 6.1.460 +Problem: GTK: after scrolling the text one line with a key, clicking the + arrow of the scrollbar does not always work. (Nam SungHyun) +Solution: Always update the scrollbar thumb when the value changed, even + when it would not move, like for RISCOS. (Daniel Elstner) +Files: src/gui.c, src/gui.h + +Patch 6.1.461 +Problem: When a keymap is active, typing a character in Select mode does + not use it. (Benji Fisher) +Solution: Apply Insert mode mapping to the character typed in Select mode. +Files: src/normal.c + +Patch 6.1.462 +Problem: When autocommands wipe out a buffer, a crash may happen. (Hari + Krishna Dara) +Solution: Don't decrement the window count of a buffer before calling the + autocommands for it. When re-using the current buffer, watch out + for autocommands changing the current buffer. +Files: src/buffer.c, src/ex_cmds.c, src/proto/buffer.pro + +Patch 6.1.463 +Problem: When writing a compressed file, the file name that gzip stores in + the file is the weird temporary file name. (David Rennalls) +Solution: Use the real file name when possible. +Files: runtime/plugin/gzip.vim + +Patch 6.1.464 +Problem: Crash when using C++ syntax highlighting. (Gerhard Hochholzer) +Solution: Check for a negative index. +Files: src/syntax.c + +Patch 6.1.465 (after 6.1.454) +Problem: Compile error when using cygwin. +Solution: Change #ifdef WIN32 to #ifdef WIN3264. (Alejandro Lopez-Valencia) + Undefine WIN32 after including windows.h +Files: src/mbyte.c + +Patch 6.1.466 +Problem: The "-f" argument is a bit obscure. +Solution: Add the "--nofork" argument. Improve the help text a bit. +Files: runtime/doc/starting.txt, src/main.c + +Patch 6.1.467 +Problem: Setting the window title doesn't work for Chinese. +Solution: Use an X11 function to convert text to a text property. (Kentaro + Nakazawa) +Files: src/os_unix.c + +Patch 6.1.468 +Problem: ":mksession" also stores folds for buffers which will not be + restored. +Solution: Only store folds for a buffer with 'buftype' empty and help files. +Files: src/ex_docmd.c + +Patch 6.1.469 +Problem: 'listchars' cannot contain multi-byte characters. +Solution: Handle multi-byte UTF-8 list characters. (Matthew Samsonoff) +Files: src/message.c, src/option.c, src/screen.c + +Patch 6.1.470 (lang) +Problem: Polish messages don't show up correctly on MS-Windows. +Solution: Convert messages to cp1250. (Mikolaj Machowski) + Also add English message translations, because it got in the way + of the patch. +Files: Makefile, src/po/Makefile, src/po/en_gb.po, src/po/pl.po + +Patch 6.1.471 +Problem: ":jumps" output continues after pressing "q" at the more-prompt. + (Hari Krishna Dara) +Solution: Check for "got_int" being set. +Files: src/mark.c + +Patch 6.1.472 +Problem: When there is an authentication error when connecting to the X + server Vim exits. +Solution: Use XSetIOErrorHandler() to catch the error and longjmp() to avoid + the exit. Also do this in the main loop, so that when the X + server exits a Vim running in a console isn't killed. +Files: src/globals.h, src/main.c, src/os_unix.c + +Patch 6.1.473 +Problem: Referring to $curwin or $curbuf in Perl 5.6 causes a crash. +Solution: Add "pTHX_" to cur_val(). (Yasuhiro Matsumoto) +Files: src/if_perl.xs + +Patch 6.1.474 +Problem: When opening the command-line window in Ex mode it's impossible to + go back. (Pavol Juhas) +Solution: Reset "exmode_active" and restore it when the command-line window + is closed. +Files: src/ex_getln.c + + +Patch 6.2f.001 +Problem: The configure check for Ruby didn't work properly for Ruby 1.8.0. +Solution: Change the way the Ruby check is done. (Aron Griffis) +Files: src/auto/configure, src/configure.in + +Patch 6.2f.002 +Problem: The output of ":ls" doesn't show whether a buffer had read errors. +Solution: Add the "x" flag in the ":ls" output. +Files: runtime/doc/windows.txt, src/buffer.c + +Patch 6.2f.003 +Problem: Test49 doesn't properly test the behavior of ":catch" without an + argument. +Solution: Update test49. (Servatius Brandt) +Files: src/testdir/test49.ok, src/testdir/test49.vim + +Patch 6.2f.004 +Problem: "vim --version" always uses CR/LF in the output. +Solution: Omit the CR. +Files: src/message.c, src/os_unix.c + +Patch 6.2f.005 +Problem: Two error messages without a colon after the number. +Solution: Add the colon. (Taro Muraoka) +Files: src/if_cscope.c + +Patch 6.2f.006 +Problem: When saving a file takes a while and Vim regains focus this can + result in a "file changed outside of Vim" warning and ml_get() + errors. (Mike Williams) +Solution: Add the "b_saving" flag to avoid checking the timestamp while the + buffer is being saved. (Michael Schaap) +Files: src/fileio.c, src/structs.h + +Patch 6.2f.007 +Problem: Irix compiler complains about multiple defined symbols. + vsnprintf() is not available. (Charles Campbell) +Solution: Insert EXTERN for variables in globals.h. Change the configure + check for vsnprintf() from compiling to linking. +Files: src/auto/configure, src/configure.in, src/globals.h + +Patch 6.2f.008 +Problem: The Aap recipe doesn't work with Aap 0.149. +Solution: Change targetarg to TARGETARG. Update the mysign file. +Files: src/main.aap, src/mysign + +Patch 6.2f.009 (extra) +Problem: Small problem when building with Borland 5.01. +Solution: Use mkdir() instead of _mkdir(). (Walter Briscoe) +Files: src/dosinst.h + +Patch 6.2f.010 +Problem: Warning for missing prototypes. +Solution: Add missing prototypes. (Walter Briscoe) +Files: src/if_cscope.c + +Patch 6.2f.011 +Problem: The configure script doesn't work with autoconf 2.5x. +Solution: Add square brackets around a header check. (Aron Griffis) + Note: touch src/auto/configure after applying this patch. +Files: src/configure.in + +Patch 6.2f.012 +Problem: ":echoerr" doesn't work correctly inside try/endtry. +Solution: Don't reset did_emsg inside a try/endtry. (Servatius Brandt) +Files: src/eval.c + +Patch 6.2f.013 (extra) +Problem: Macintosh: Compiler warning for a trigraph. +Solution: Insert a backslash before each question mark. (Peter Cucka) +Files: src/os_mac.h + +Patch 6.2f.014 (extra) +Problem: Macintosh: ex_eval is not included in the project file. +Solution: Add ex_eval. (Dany St-Amant) +Files: src/os_mac.pbproj/project.pbxproj + +Patch 6.2f.015 (extra) +Problem: Win32: When changing header files not all source files involved + are recompiled. +Solution: Improve the dependency rules. (Dan Sharp) +Files: src/Make_cyg.mak, src/Make_ming.mak + +Patch 6.2f.016 +Problem: "vim --version > ff" on non-Unix systems results in a file with a + missing line break at the end. (Bill McCArthy) +Solution: Add a line break. +Files: src/main.c + +Patch 6.2f.017 +Problem: Unix: starting Vim in the background and then bringing it to the + foreground may cause the terminal settings to be wrong. +Solution: Check for tcsetattr() to return an error, retry when it does. + (Paul Tapper) +Files: src/os_unix.c + +Patch 6.2f.018 +Problem: Mac OS X 10.2: OK is defined to zero in cursus.h while Vim uses + one. Redefining it causes a warning message. +Solution: Undefine OK before defining it to one. (Taro Muraoka) +Files: src/vim.h + +Patch 6.2f.019 +Problem: Mac OS X 10.2: COLOR_BLACK and COLOR_WHITE are defined in + curses.h. +Solution: Rename them to PRCOLOR_BLACK and PRCOLOR_WHITE. +Files: src/ex_cmds2.c + +Patch 6.2f.020 +Problem: Win32: test50 produces beeps and fails with some versions of diff. +Solution: Remove empty lines and convert the output to dos fileformat. +Files: src/testdir/test50.in + +Patch 6.2f.021 +Problem: Running configure with "--enable-netbeans" disables Netbeans. + (Gordon Prieur) +Solution: Fix the tests in configure.in where the default is to enable a + feature. Fix that "--enable-acl" reported "yes" confusingly. +Files: src/auto/configure, src/configure.in, src/mysign + +Patch 6.2f.022 +Problem: A bogus value for 'foldmarker' is not rejected, possibly causing a + hang. (Derek Wyatt) +Solution: Check for a non-empty string before and after the comma. +Files: src/option.c + +Patch 6.2f.023 +Problem: When the help files are not in $VIMRUNTIME but 'helpfile' is + correct Vim still can't find the help files. +Solution: Also look for a tags file in the directory of 'helpfile'. +Files: src/tag.c + +Patch 6.2f.024 +Problem: When 'delcombine' is set and a character has more than two + composing characters "x" deletes them all. +Solution: Always delete only the last composing character. +Files: src/misc1.c + +Patch 6.2f.025 +Problem: When reading a file from stdin that has DOS line endings but a + missing end-of-line for the last line 'fileformat' becomes "unix". + (Bill McCarthy) +Solution: Don't add the missing line break when re-reading the text from the + buffer. +Files: src/fileio.c + +Patch 6.2f.026 +Problem: When typing new text at the command line, old composing characters + may be displayed. +Solution: Don't read composing characters from after the end of the + text to be displayed. +Files: src/ex_getln.c, src/mbyte.c, src/message.c, src/proto/mbyte.pro, + src/screen.c + +Patch 6.2f.027 +Problem: Compiler warnings for unsigned char pointers. (Tony Leneis) +Solution: Add typecasts to char pointer. +Files: src/quickfix.c + +Patch 6.2f.028 +Problem: GTK: When 'imactivatekey' is empty and XIM is inactive it can't be + made active again. Cursor isn't updated immediately when changing + XIM activation. Japanese XIM may hang when using 'imactivatekey'. + Can't activate XIM after typing fFtT command or ":sh". +Solution: Properly set the flag that indicates the IM is active. Update the + cursor right away. Do not send a key-release event. Handle + Normal mode and running an external command differently. + (Yasuhiro Matsumoto) +Files: src/mbyte.c + +Patch 6.2f.029 +Problem: Mixing use of int and enum. +Solution: Adjust argument type of cs_usage_msg(). Fix wrong typedef. +Files: src/if_cscope.c, src/if_cscope.h + +Patch 6.2f.030 (after 6.2f.028) +Problem: Cursor moves up when using XIM. +Solution: Reset im_preedit_cursor. (Yasuhiro Matsumoto) +Files: src/mbyte.c + +Patch 6.2f.031 +Problem: Crash when listing a function argument in the debugger. (Ron Aaron) +Solution: Init the name field of an argument to NULL. +Files: src/eval.c + +Patch 6.2f.032 +Problem: When a write fails for a ":silent!" while inside try/endtry the + BufWritePost autocommands are not triggered. +Solution: Check the emsg_silent flag in should_abort(). (Servatius Brandt) +Files: src/ex_eval.c, src/testdir/test49.ok, src/testdir/test49.vim + +Patch 6.2f.033 +Problem: Cscope: re-entrance problem for ":cscope" command. Checking for + duplicate database didn't work well for Win95. Didn't check for + duplicate databases after an empty entry. +Solution: Don't set postponed_split too early. Remember first empty + database entry. (Sergey Khorev) +Files: src/if_cscope.c + +Patch 6.2f.034 +Problem: The netbeans interface cannot be used on systems without + vsnprintf(). (Tony Leneis) +Solution: Use EMSG(), EMSGN() and EMSG2() instead. +Files: src/auto/configure, src/configure.in, src/netbeans.c + +Patch 6.2f.035 +Problem: The configure check for the netbeans interface doesn't work if the + socket and nsl libraries are required. +Solution: Check for the socket and nsl libraries before the netbeans check. +Files: src/auto/configure, src/configure.in + +Patch 6.2f.036 +Problem: Moving leftwards over text with an illegal UTF-8 byte moves one + byte instead of one character. +Solution: Ignore an illegal byte after the cursor position. +Files: src/mbyte.c + +Patch 6.2f.037 +Problem: When receiving a Netbeans command at the hit-enter or more prompt + the screen is redrawn but Vim is still waiting at the prompt. +Solution: Quit the prompt like a CTRL-C was typed. +Files: src/netbeans.c + +Patch 6.2f.038 +Problem: The dependency to run autoconf causes a patch for configure.in + to run autoconf, even though the configure script was updated as + well. +Solution: Only run autoconf with "make autoconf". +Files: src/Makefile + +Patch 6.2f.039 +Problem: CTRL-W K makes the new top window very high. +Solution: When 'equalalways' is set equalize the window heights. +Files: src/window.c + + +============================================================================== +VERSION 6.3 *version-6.3* + +This section is about improvements made between version 6.2 and 6.3. + +This is mainly a bug-fix release. There are also a few new features. +The major number of new items is in the runtime files and translations. + + +Changed *changed-6.3* +------- + +The intro message also displays a note about sponsoring Vim, mixed randomly +with the message about helping children in Uganda. + +Included the translated menus, keymaps and tutors with the normal runtime +files. The separate "lang" archive now only contains translated messages. + +Made the translated menu file names a bit more consistent. Use "latin1" for +"iso_8859-1" and "iso_8859-15". + +Removed the "file_select.vim" script from the distribution. It's not more +useful than other scripts that can be downloaded from www.vim.org. + +The "runtime/doc/tags" file is now always in unix fileformat. On MS-Windows +it used to be dos fileformat, but ":helptags" generates a unix format file. + + +Added *added-6.3* +----- + +New commands: + :cNfile go to last error in previous file + :cpfile idem + :changes print the change list + :keepmarks following command keeps marks where they are + :keepjumps following command keeps jumplist and marks + :lockmarks following command keeps marks where they are + :redrawstatus force a redraw of the status line(s) + +New options: + 'antialias' Mac OS X: use smooth, antialiased fonts + 'helplang' preferred help languages + +Syntax files: + Arch inventory (Nikolai Weibull) + Calendar (Nikolai Weibull) + Ch (Wayne Cheng) + Controllable Regex Mutilator (Nikolai Weibull) + D (Jason Mills) + Desktop (Mikolaj Machowski) + Dircolors (Nikolai Weibull) + Elinks configuration (Nikolai Weibull) + FASM (Ron Aaron) + GrADS scripts (Stefan Fronzek) + Icewm menu (James Mahler) + LDIF (Zak Johnson) + Locale input, fdcc. (Dwayne Bailey) + Pinfo config (Nikolai Weibull) + Pyrex (Marco Barisione) + Relax NG Compact (Nikolai Weibull) + Slice (Morel Bodin) + VAX Macro Assembly (Tom Uijldert) + grads (Stefan Fronzek) + libao (Nikolai Weibull) + mplayer (Nikolai Weibull) + rst (Nikolai Weibull) + tcsh (Gautam Iyer) + yaml (Nikolai Weibull) + +Compiler plugins: + ATT dot (Marcos Macedo) + Apple Project Builder (Alexander von Below) + Intel (David Harrison) + bdf (Nikolai Weibull) + icc (Peter Puck) + javac (Doug Kearns) + neato (Marcos Macedo) + onsgmls (Robert B. Rowsome) + perl (Christian J. Robinson) + rst (Nikolai Weibull) + se (SmartEiffel) (Doug Kearns) + tcl (Doug Kearns) + xmlwf (Robert B. Rowsome) + +Filetype plugins: + Aap (Bram Moolenaar) + Ch (Wayne Cheng) + Css (Nikolai Weibull) + Pyrex (Marco Barisione) + Rst (Nikolai Weibull) + +Indent scripts: + Aap (Bram Moolenaar) + Ch (Wayne Cheng) + DocBook (Nikolai Weibull) + MetaPost (Eugene Minkovskii) + Objective-C (Kazunobu Kuriyama) + Pyrex (Marco Barisione) + Rst (Nikolai Weibull) + Tcsh (Gautam Iyer) + XFree86 configuration file (Nikolai Weibull) + Zsh (Nikolai Weibull) + +Keymaps: + Greek for cp1253 (Panagiotis Louridas) + Hungarian (Magyar) (Laszlo Zavaleta) + Persian-Iranian (Behnam Esfahbod) + +Message translations: + Catalan (Ernest Adrogue) + Russian (Vassily Ragosin) + Swedish (Johan Svedberg) + +Menu translations: + Catalan (Ernest Adrogue) + Russian (Tim Alexeevsky) + Swedish (Johan Svedberg) + +Tutor translations: + Catalan (Ernest Adrogue) + Russian in cp1251 (Alexey Froloff) + Slovak in cp1250 and iso8859-2 (Lubos Celko) + Swedish (Johan Svedberg) + Korean (Kee-Won Seo) + UTF-8 version of the Japanese tutor (Yasuhiro Matsumoto) Use this as + the original, create the other Japanese tutor by conversion. + +Included "russian.txt" help file. (Vassily Ragosin) + +Include Encapsulated PostScript and PDF versions of the Vim logo in the extra +archive. + +The help highlighting finds the highlight groups and shows them in the color +that is actually being used. (idea from Yakov Lerner) + +The big Win32 version is now compiled with Ruby interface, version 1.8. For +Python version 2.3 is used. For Perl version 5.8 is used. + +The "ftdetect" directory is mentioned in the documentation. The DOS install +program creates it. + + +Fixed *fixed-6.3* +----- + +Test 42 failed on MS-Windows. Set and reset 'fileformat' and 'binary' options +here and there. (Walter Briscoe) + +The explorer plugin didn't work for double-byte 'encoding's. + +Use "copy /y" in Make_bc5.mak to avoid a prompt for overwriting. + +Patch 6.2.001 +Problem: The ":stopinsert" command doesn't have a help tag. +Solution: Add the tag. (Antoine J. Mechelynck) +Files: runtime/doc/insert.txt, runtime/doc/tags + +Patch 6.2.002 +Problem: When compiled with the +multi_byte feature but without +eval, + displaying UTF-8 characters may cause a crash. (Karsten Hopp) +Solution: Also set the default for 'ambiwidth' when compiled without the + +eval feature. +Files: src/option.c + +Patch 6.2.003 +Problem: GTK 2: double-wide characters below 256 are not displayed + correctly. +Solution: Check the cell width for characters above 127. (Yasuhiro + Matsumoto) +Files: src/gui_gtk_x11.c + +Patch 6.2.004 +Problem: With a line-Visual selection at the end of the file a "p" command + puts the text one line upwards. +Solution: Detect that the last line was deleted and put forward. (Taro + Muraoka) +Files: src/normal.c + +Patch 6.2.005 +Problem: GTK: the "Find" and "Find and Replace" tools don't work. (Aschwin + Marsman) +Solution: Show the dialog after creating it. (David Necas) +Files: src/gui_gtk.c + +Patch 6.2.006 +Problem: The Netbeans code contains an obsolete function that uses "vim61" + and sets the fall-back value for $VIMRUNTIME. +Solution: Delete the obsolete function. +Files: src/main.c, src/netbeans.c, src/proto/netbeans.pro + +Patch 6.2.007 +Problem: Listing tags for Cscope doesn't always work. +Solution: Avoid using smgs_attr(). (Sergey Khorev) +Files: src/if_cscope.c + +Patch 6.2.008 +Problem: XIM with GTK 2: After backspacing preedit characters are wrong. +Solution: Reset the cursor position. (Yasuhiro Matsumoto) +Files: src/mbyte.c + +Patch 6.2.009 +Problem: Win32: The self-installing executable "Full" selection only + selects some of the items to install. (Salman Mohsin) +Solution: Change commas to spaces in between section numbers. +Files: nsis/gvim.nsi + +Patch 6.2.010 +Problem: When 'virtualedit' is effective and a line starts with a + multi-byte character, moving the cursor right doesn't work. +Solution: Obtain the right character to compute the column offset. (Taro + Muraoka) +Files: src/charset.c + +Patch 6.2.011 +Problem: Alpha OSF1: stat() is a macro and doesn't allow an #ifdef halfway. + (Moshe Kaminsky) +Solution: Move the #ifdef outside of stat(). +Files: src/os_unix.c + +Patch 6.2.012 +Problem: May hang when polling for a character. +Solution: Break the wait loop when not waiting for a character. +Files: src/os_unix.c + +Patch 6.2.013 (extra) +Problem: Win32: The registry key for uninstalling GvimExt still uses "6.1". +Solution: Change the version number to "6.2". (Ajit Thakkar) +Files: src/GvimExt/GvimExt.reg + +Patch 6.2.014 (after 6.2.012) +Problem: XSMP doesn't work when using poll(). +Solution: Use xsmp_idx instead of gpm_idx. (Neil Bird) +Files: src/os_unix.c + +Patch 6.2.015 +Problem: The +xsmp feature is never enabled. +Solution: Move the #define for USE_XSMP to below where WANT_X11 is defined. + (Alexey Froloff) +Files: src/feature.h + +Patch 6.2.016 +Problem: Using ":scscope find" with 'cscopequickfix' does not always split + the window. (Gary Johnson) + Win32: ":cscope add" could make the script that contains it + read-only until the corresponding ":cscope kill". + Errors during ":cscope add" may not be handled properly. +Solution: When using the quickfix window may need to split the window. + Avoid file handle inheritance for the script. + Check for a failed connection and/or process. (Sergey Khorev) +Files: src/ex_cmds2.c, src/if_cscope.c + +Patch 6.2.017 +Problem: Test11 sometimes prompts the user, because a file would have been + changed outside of Vim. (Antonio Colombo) +Solution: Add a FileChangedShell autocommand to avoid the prompt. +Files: src/testdir/test11.in + +Patch 6.2.018 +Problem: When using the XSMP protocol and reading from stdin Vim may wait + for a key to be pressed. +Solution: Avoid that RealWaitForChar() is used recursively. +Files: src/os_unix.c + +Patch 6.2.019 (lang) +Problem: Loading the Portuguese menu causes an error message. +Solution: Join two lines. (Jose Pedro Oliveira, José de Paula) +Files: runtime/lang/menu_pt_br.vim + +Patch 6.2.020 +Problem: The "Syntax/Set syntax only" menu item causes an error message. + (Oyvind Holm) +Solution: Set the script-local variable in a function. (Benji Fisher) +Files: runtime/synmenu.vim + +Patch 6.2.021 +Problem: The user manual section on exceptions contains small mistakes. +Solution: Give a good example of an error that could be missed and other + improvements. (Servatius Brandt) +Files: runtime/doc/usr_41.txt + +Patch 6.2.022 (extra) +Problem: Win32: After deleting a menu item it still appears in a tear-off + window. +Solution: Set the mode to zero for the deleted item. (Yasuhiro Matsumoto) +Files: src/gui_w32.c + +Patch 6.2.023 (extra) +Problem: Win32: Make_ivc.mak does not clean everything. +Solution: Delete more files in the clean rule. (Walter Briscoe) +Files: src/Make_ivc.mak + +Patch 6.2.024 (extra) +Problem: Win32: Compiler warnings for typecasts. +Solution: Use DWORD instead of WORD. (Walter Briscoe) +Files: src/gui_w32.c + +Patch 6.2.025 +Problem: Missing prototype for sigaltstack(). +Solution: Add the prototype when it is not found in a header file. +Files: src/os_unix.c + +Patch 6.2.026 +Problem: Warning for utimes() argument. +Solution: Add a typecast. +Files: src/fileio.c + +Patch 6.2.027 +Problem: Warning for uninitialized variable. +Solution: Set mb_l to one when not using multi-byte characters. +Files: src/message.c + +Patch 6.2.028 +Problem: Cscope connection may kill Vim process and others. +Solution: Check for pid being larger than one. (Khorev Sergey) +Files: src/if_cscope.c + +Patch 6.2.029 +Problem: When using the remote server functionality Vim may leak memory. + (Srikanth Sankaran) +Solution: Free the result of XListProperties(). +Files: src/if_xcmdsrv.c + +Patch 6.2.030 +Problem: Mac: Warning for not being able to use precompiled header files. +Solution: Don't redefine select. Use -no-cpp-precomp for compiling, so that + function prototypes are still found. +Files: src/os_unix.c, src/osdef.sh + +Patch 6.2.031 +Problem: The langmenu entry in the options window doesn't work. (Rodolfo + Lima) + With GTK 1 the ":options" command causes an error message. + (Michael Naumann) +Solution: Change "lmenu" to "langmenu". Only display the 'tbis' option for + GTK 2. +Files: runtime/optwin.vim + +Patch 6.2.032 +Problem: The lpc filetype is never recognized. (Shizhu Pan) +Solution: Check for g:lpc_syntax_for_c instead of the local variable + lpc_syntax_for_c. (Benji Fisher) +Files: runtime/filetype.vim + +Patch 6.2.033 (extra) +Problem: Mac: Various compiler warnings. +Solution: Don't include Classic-only headers in Unix version. + Remove references to several unused variables. (Ben Fowler) + Fix double definition of DEFAULT_TERM. + Use int instead of unsigned short for pixel values, so that the + negative error values are recognized. +Files: src/gui_mac.c, src/term.c + +Patch 6.2.034 +Problem: Mac: Compiler warning for redefining DEFAULT_TERM. +Solution: Fix double definition of DEFAULT_TERM. +Files: src/term.c + +Patch 6.2.035 +Problem: Mac: Compiler warnings in Python interface. +Solution: Make a difference between pure Mac and Unix-Mac. (Peter Cucka) +Files: src/if_python.c + +Patch 6.2.036 (extra) +Problem: Mac Unix version: If foo is a directory, then ":e f<Tab>" should + expand to ":e foo/" instead of ":e foo" . (Vadim Zeitlin) +Solution: Define DONT_ADD_PATHSEP_TO_DIR only for pure Mac. (Benji Fisher) +Files: src/os_mac.h + +Patch 6.2.037 +Problem: Win32: converting an encoding name to a codepage could result in + an arbitrary number. +Solution: make encname2codepage() return zero if the encoding name doesn't + contain a codepage number. +Files: src/mbyte.c + +Patch 6.2.038 (extra) +Problem: Warning messages when using the MingW compiler. (Bill McCarthy) + Can't compile console version without +mouse feature. +Solution: Initialize variables, add parenthesis. + Add an #ifdef around g_nMouseClick. (Ajit Thakkar) +Files: src/eval.c, src/os_win32.c, src/gui_w32.c, src/dosinst.c + +Patch 6.2.039 (extra) +Problem: More warning messages when using the MingW compiler. +Solution: Initialize variables. (Bill McCarthy) +Files: src/os_mswin.c + +Patch 6.2.040 +Problem: FreeBSD: Crash while starting up when compiled with +xsmp feature. +Solution: Pass a non-NULL argument to IceAddConnectionWatch(). +Files: src/os_unix.c + +Patch 6.2.041 (extra, after 6.2.033) +Problem: Mac: Compiler warnings for conversion types, missing prototype, + missing return type. +Solution: Change sscanf "%hd" to "%d", the argument is an int now. Add + gui_mch_init_check() prototype. Add "int" to termlib functions. +Files: src/gui_mac.c, src/proto/gui_mac.pro, src/termlib.c. + +Patch 6.2.042 (extra) +Problem: Cygwin: gcc 3.2 has an optimizer problem, sometimes causing a + crash. +Solution: Add -fno-strength-reduce to the compiler arguments. (Dan Sharp) +Files: src/Make_cyg.mak + +Patch 6.2.043 +Problem: Compiling with both netbeans and workshop doesn't work. +Solution: Move the shellRectangle() function to gui_x11.c. (Gordon Prieur) +Files: src/gui_x11.c, src/integration.c, src/netbeans.c, + src/proto/netbeans.pro + +Patch 6.2.044 +Problem: ":au filetypedetect" gives an error for a non-existing event name, + but it's actually a non-existing group name. (Antoine Mechelynck) +Solution: Make the error message clearer. +Files: src/fileio.c + +Patch 6.2.045 +Problem: Obtaining the '( mark changes the '' mark. (Gary Holloway) +Solution: Don't set the '' mark when searching for the start/end of the + current sentence/paragraph. +Files: src/mark.c + +Patch 6.2.046 +Problem: When evaluating an argument of a function throws an exception the + function is still called. (Hari Krishna Dara) +Solution: Don't call the function when an exception was thrown. +Files: src/eval.c + +Patch 6.2.047 (extra) +Problem: Compiler warnings when using MingW. (Bill McCarthy) +Solution: Give the s_dwLastClickTime variable a type. Initialize dwEndTime. +Files: src/os_win32.c + +Patch 6.2.048 +Problem: The Python interface doesn't compile with Python 2.3 when + dynamically loaded. +Solution: Use dll_PyObject_Malloc and dll_PyObject_Free. (Paul Moore) +Files: src/if_python.c + +Patch 6.2.049 +Problem: Using a "-range=" argument with ":command" doesn't work and + doesn't generate an error message. +Solution: Generate an error message. +Files: src/ex_docmd.c + +Patch 6.2.050 +Problem: Test 32 didn't work on MS-Windows. +Solution: Write the temp file in Unix fileformat. (Walter Briscoe) +Files: src/testdir/test32.in + +Patch 6.2.051 +Problem: When using "\=submatch(0)" in a ":s" command, line breaks become + NUL characters. +Solution: Change NL to CR characters, so that they become line breaks. +Files: src/regexp.c + +Patch 6.2.052 +Problem: A few messages are not translated. +Solution: Add _() to the messages. (Muraoka Taro) +Files: src/ex_cmds.c + +Patch 6.2.053 +Problem: Prototype for bzero() doesn't match most systems. +Solution: Use "void *" instead of "char *" and "size_t" instead of "int". +Files: src/osdef1.h.in + +Patch 6.2.054 +Problem: A double-byte character with a second byte that is a backslash + causes problems inside a string. +Solution: Skip over multi-byte characters in a string properly. (Yasuhiro + Matsumoto) +Files: src/eval.c + +Patch 6.2.055 +Problem: Using col('.') from CTRL-O in Insert mode does not return the + correct value for multi-byte characters. +Solution: Correct the cursor position when it is necessary, move to the + first byte of a multi-byte character. (Yasuhiro Matsumoto) +Files: src/edit.c + +Patch 6.2.056 (extra) +Problem: Building with Sniff++ doesn't work. +Solution: Use the multi-threaded libc when needed. (Holger Ditting) +Files: src/Make_mvc.mak + +Patch 6.2.057 (extra) +Problem: Mac: With -DMACOS_X putenv() is defined twice, it is in a system + library. Get a warning for redefining OK. Unused variables in + os_mac.c +Solution: Define HAVE_PUTENV. Undefine OK after including curses.h. + Remove declarations for unused variables. +Files: src/os_mac.c, src/os_mac.h, src/vim.h + +Patch 6.2.058 +Problem: When 'autochdir' is set ":bnext" to a buffer without a name causes + a crash. +Solution: Don't call vim_chdirfile() when the file name is NULL. (Taro + Muraoka) +Files: src/buffer.c + +Patch 6.2.059 +Problem: When 'scrolloff' is a large number and listing completion results + on the command line, then executing a command that jumps close to + where the cursor was before, part of the screen is not updated. + (Yakov Lerner) +Solution: Don't skip redrawing part of the window when it was scrolled. +Files: src/screen.c + +Patch 6.2.060 (extra) +Problem: Win32: When 'encoding' is set to "iso-8859-7" copy/paste to/from + the clipboard gives a lalloc(0) error. (Kriton Kyrimis) +Solution: When the string length is zero allocate one byte. Also fix that + when the length of the Unicode text is zero (conversion from + 'encoding' to UCS-2 was not possible) the normal text is used. +Files: src/os_mswin.c + +Patch 6.2.061 +Problem: GUI: Using the left mouse button with the shift key should work + like "*" but it scrolls instead. (Martin Beller) +Solution: Don't recognize an rxvt scroll wheel event when using the GUI. +Files: src/term.c + +Patch 6.2.062 +Problem: When one buffer uses a syntax with "containedin" and another + buffer does not, redrawing depends on what the current buffer is. + (Brett Pershing Stahlman) +Solution: Use "syn_buf" instead of "curbuf" to get the b_syn_containedin + flag. +Files: src/syntax.c + +Patch 6.2.063 +Problem: When using custom completion end up with no matches. +Solution: Make cmd_numfiles and cmd_files local to completion to avoid that + they are overwritten when ExpandOne() is called recursively by + f_glob(). +Files: src/eval.c, src/ex_docmd.c, src/ex_getln.c, src/proto/ex_getln.pro, + src/misc1.c, src/structs.h, src/tag.c + +Patch 6.2.064 +Problem: resolve() only handles one symbolic link, need to repeat it to + resolve all of them. Then need to simplify the file name. +Solution: Make resolve() resolve all symbolic links and simplify the result. + Add simplify() to just simplify a file name. Fix that test49 + doesn't work if /tmp is a symbolic link. (Servatius Brandt) +Files: runtime/doc/eval.txt, src/eval.c, src/tag.c, + src/testdir/test49.vim + +Patch 6.2.065 +Problem: ":windo 123" only updates other windows when entering them. + (Walter Briscoe) +Solution: Update the topline before going to the next window. +Files: src/ex_cmds2.c + +Patch 6.2.066 (extra) +Problem: Ruby interface doesn't work with Ruby 1.8.0. +Solution: Change "defout" to "stdout". (Aron Griffis) + Change dynamic loading. (Taro Muraoka) +Files: src/if_ruby.c, src/Make_mvc.mak + +Patch 6.2.067 +Problem: When searching for a string that starts with a composing character + the command line isn't drawn properly. +Solution: Don't count the space to draw the composing character on and + adjust the cursor column after drawing the string. +Files: src/message.c + +Patch 6.2.068 +Problem: Events for the netbeans interface that include a file name with + special characters don't work properly. +Solution: Use nb_quote() on the file name. (Sergey Khorev) +Files: src/netbeans.c + +Patch 6.2.069 (after 6.2.064) +Problem: Unused variables "limit" and "new_st" and unused label "fail" in + some situation. (Bill McCarthy) +Solution: Put the declarations inside an #ifdef. (Servatius Brandt) +Files: src/eval.c, src/tag.c + +Patch 6.2.070 (after 6.2.069) +Problem: Still unused variable "new_st". (Bill McCarthy) +Solution: Move the declaration to the right block this time. +Files: src/tag.c + +Patch 6.2.071 +Problem: 'statusline' can only contain 50 % items. (Antony Scriven) +Solution: Allow 80 items and mention it in the docs. +Files: runtime/doc/option.txt, src/vim.h + +Patch 6.2.072 +Problem: When using expression folding, foldexpr() mostly returns -1 for + the previous line, which makes it difficult to write a fold + expression. +Solution: Make the level of the previous line available while still looking + for the end of a fold. +Files: src/fold.c + +Patch 6.2.073 +Problem: When adding detection of a specific filetype for a plugin you need + to edit "filetype.vim". +Solution: Source files from the "ftdetect" directory, so that a filetype + detection plugin only needs to be dropped in a directory. +Files: runtime/doc/filetype.txt, runtime/doc/usr_05.txt, + runtime/doc/usr_41.txt, runtime/filetype.vim + +Patch 6.2.074 +Problem: Warnings when compiling the Python interface. (Ajit Thakkar) +Solution: Use ANSI function declarations. +Files: src/if_python.c + +Patch 6.2.075 +Problem: When the temp file for writing viminfo can't be used "NULL" + appears in the error message. (Ben Lavender) +Solution: Print the original file name when there is no temp file name. +Files: src/ex_cmds.c + +Patch 6.2.076 +Problem: The tags listed for cscope are in the wrong order. (Johannes + Stezenbach) +Solution: Remove the reordering of tags for the current file. (Sergey + Khorev) +Files: src/if_cscope.c + +Patch 6.2.077 +Problem: When a user function specifies custom completion, the function + gets a zero argument instead of an empty string when there is no + word before the cursor. (Preben Guldberg) +Solution: Don't convert an empty string to a zero. +Files: src/eval.c + +Patch 6.2.078 +Problem: "make test" doesn't work if Vim wasn't compiled yet. (Ed Avis) +Solution: Build Vim before running the tests. +Files: src/Makefile + +Patch 6.2.079 +Problem: ":w ++enc=utf-8 !cmd" doesn't work. +Solution: Check for the "++" argument before the "!". +Files: src/ex_docmd.c + +Patch 6.2.080 +Problem: When 't_ti' is not empty but doesn't swap screens, using "ZZ" in + an unmodified file doesn't clear the last line. +Solution: Call msg_clr_eos() when needed. (Michael Schroeder) +Files: src/os_unix.c + +Patch 6.2.081 +Problem: Problem when using a long multibyte string for the statusline. +Solution: Use the right pointer to get the cell size. (Taro Muraoka) +Files: src/buffer.c + +Patch 6.2.082 +Problem: Can't compile with Perl 5.8.1. +Solution: Rename "e_number" to "e_number_exp". (Sascha Blank) +Files: src/digraph.c, src/globals.h + +Patch 6.2.083 +Problem: When a compiler uses ^^^^ to mark a word the information is not + visible in the quickfix window. (Srikanth Sankaran) +Solution: Don't remove the indent for a line that is not recognized as an + error message. +Files: src/quickfix.c + +Patch 6.2.084 +Problem: "g_" in Visual mode always goes to the character after the line. + (Jean-Rene David) +Solution: Ignore the NUL at the end of the line. +Files: src/normal.c + +Patch 6.2.085 +Problem: ":verbose set ts" doesn't say an option was set with a "-c" or + "--cmd" argument. +Solution: Remember the option was set from a Vim argument. +Files: src/main.c, src/ex_cmds2.c, src/vim.h + +Patch 6.2.086 +Problem: "{" and "}" stop inside a closed fold. +Solution: Only stop once inside a closed fold. (Stephen Riehm) +Files: src/search.c + +Patch 6.2.087 +Problem: CTRL-^ doesn't use the 'confirm' option. Same problem with + ":bnext". (Yakov Lerner) +Solution: Put up a dialog for a changed file when 'confirm' is set in more + situations. +Files: src/buffer.c, src/ex_cmds.c + +Patch 6.2.088 +Problem: When 'sidescrolloff' is set 'showmatch' doesn't work correctly if + the match is less than 'sidescrolloff' off from the side of the + window. (Roland Stahn) +Solution: Set 'sidescrolloff' to zero while displaying the match. +Files: src/search.c + +Patch 6.2.089 +Problem: ":set isk+=" adds a comma. (Mark Waggoner) +Solution: Don't add a comma when the added value is empty. +Files: src/option.c + +Patch 6.2.090 (extra) +Problem: Win32: MingW compiler complains about #pragmas. (Bill McCarthy) +Solution: Put an #ifdef around the #pragmas. +Files: src/os_win32.c + +Patch 6.2.091 +Problem: When an autocommand is triggered when a file is dropped on Vim and + it produces output, messages from a following command may be + scrolled unexpectedly. (David Rennalls) +Solution: Save and restore msg_scroll in handle_drop(). +Files: src/ex_docmd.c + +Patch 6.2.092 +Problem: Invalid items appear in the help file tags. (Antonio Colombo) +Solution: Only accept tags with white space before the first "*". +Files: runtime/doc/doctags.c, src/ex_cmds.c + +Patch 6.2.093 +Problem: ":nnoremenu" also defines menu for Visual mode. (Klaus Bosau) +Solution: Check the second command character for an "o", not the third. +Files: src/menu.c + +Patch 6.2.094 +Problem: Can't compile with GTK and tiny features. +Solution: Include handle_drop() and vim_chdirfile() when FEAT_DND is defined. + Do not try to split the window. +Files: src/ex_docmd.c, src/misc2.c + +Patch 6.2.095 +Problem: The message "Cannot go to buffer x" is confusing for ":buf 6". + (Frans Englich) +Solution: Make it "Buffer x does not exist". +Files: src/buffer.c + +Patch 6.2.096 +Problem: Win32: ":let @* = ''" put a newline on the clipboard. (Klaus + Bosau) +Solution: Put zero bytes on the clipboard for an empty string. +Files: src/ops.c + +Patch 6.2.097 +Problem: Setting or resetting 'insertmode' in a BufEnter autocommand + doesn't always have immediate effect. (Nagger) +Solution: When 'insertmode' is set, set need_start_insertmode, when it's + reset set stop_insert_mode. +Files: src/option.c + +Patch 6.2.098 (after 6.2.097) +Problem: Can't build Vim with tiny features. (Christian J. Robinson) +Solution: Declare stop_insert_mode always. +Files: src/edit.c, src/globals.h + +Patch 6.2.099 (extra) +Problem: Test 49 fails. (Mikolaj Machowski) +Solution: The Polish translation must not change "E116" to "R116". +Files: src/po/pl.po + +Patch 6.2.100 +Problem: "make proto" fails when compiled with the Perl interface. +Solution: Remove "-fno.*" from PERL_CFLAGS, cproto sees it as its option. +Files: src/auto/configure, src/configure.in + +Patch 6.2.101 +Problem: When using syntax folding, opening a file slows down a lot when + it's size increases by only 20%. (Gary Johnson) +Solution: The array with cached syntax states is leaking entries. After + cleaning up the list obtain the current entry again. +Files: src/syntax.c + +Patch 6.2.102 +Problem: The macros equal() and CR conflict with a Carbon header file. +Solution: Rename equal() to equalpos(). Rename CR to CAR. + Do this in the non-extra files only. +Files: src/ascii.h, src/buffer.c, src/charset.c, src/edit.c, src/eval.c, + src/ex_cmds.c, src/ex_cmds2.c, src/ex_getln.c, src/fileio.c, + src/getchar.c, src/gui.c, src/gui_athena.c, src/gui_gtk_x11.c, + src/gui_motif.c, src/macros.h, src/mark.c, src/message.c, + src/misc1.c, src/misc2.c, src/normal.c, src/ops.c, src/os_unix.c, + src/regexp.c, src/search.c, src/ui.c, src/workshop.c + +Patch 6.2.103 (extra) +Problem: The macros equal() and CR conflict with a Carbon header file. +Solution: Rename equal() to equalpos(). Rename CR to CAR. + Do this in the extra files only. +Files: src/gui_photon.c, src/gui_w48.c + +Patch 6.2.104 +Problem: Unmatched braces in the table with options. +Solution: Move the "}," outside of the #ifdef. (Yakov Lerner) +Files: src/option.c + +Patch 6.2.105 +Problem: When the cursor is past the end of the line when calling + get_c_indent() a crash might occur. +Solution: Don't look past the end of the line. (NJ Verenini) +Files: src/misc1.c + +Patch 6.2.106 +Problem: Tag searching gets stuck on a very long line in the tags file. +Solution: When skipping back to search the first matching tag remember the + offset where searching started looking for a line break. +Files: src/tag.c + +Patch 6.2.107 (extra) +Problem: The NetBeans interface cannot be used on Win32. +Solution: Add support for the NetBeans for Win32. Add support for reading + XPM files on Win32. Also fixes that a sign icon with a space in + the file name did not work through the NetBeans interface. + (Sergey Khorev) + Also: avoid repeating error messages when the connection is lost. +Files: Makefile, runtime/doc/netbeans.txt, src/Make_bc5.mak, + src/Make_cyg.mak, src/Make_ming.mak, src/Make_mvc.mak, + src/bigvim.bat, src/feature.h, src/gui_beval.c, src/gui_beval.h, + src/gui_w32.c, src/gui_w48.c, src/menu.c, src/nbdebug.c, + src/nbdebug.h, src/netbeans.c, src/os_mswin.c, src/os_win32.h, + src/proto/gui_beval.pro, src/proto/gui_w32.pro, + src/proto/netbeans.pro, src/proto.h, src/version.c, src/vim.h, + src/xpm_w32.c, src/xpm_w32.h + +Patch 6.2.108 +Problem: Crash when giving a message about ignoring case in a tag. (Manfred + Kuehn) +Solution: Use a longer buffer for the message. +Files: src/tag.c + +Patch 6.2.109 +Problem: Compiler warnings with various Amiga compilers. +Solution: Add typecast, prototypes, et al. that are also useful for other + systems. (Flavio Stanchina) +Files: src/eval.c, src/ops.c + +Patch 6.2.110 +Problem: When $LANG includes the encoding, a menu without an encoding name + is not found. +Solution: Also look for a menu file without any encoding. +Files: runtime/menu.vim + +Patch 6.2.111 +Problem: Encoding "cp1251" is not recognized. +Solution: Add "cp1251" to the table of encodings. (Alexey Froloff) +Files: src/mbyte.c + +Patch 6.2.112 +Problem: After applying patches test32 fails. (Antonio Colombo) +Solution: Have "make clean" in the testdir delete *.rej and *.orig files. + Use this when doing "make clean" in the src directory. +Files: src/Makefile, src/testdir/Makefile + +Patch 6.2.113 +Problem: Using ":startinsert" after "$" works like "a" instead of "i". + (Ajit Thakkar) +Solution: Reset "w_curswant" for ":startinsert" and reset o_eol in edit(). +Files: src/edit.c, src/ex_docmd.c + +Patch 6.2.114 +Problem: When stdout is piped through "tee", the size of the screen may not + be correct. +Solution: Use stdin instead of stdout for ioctl() when stdin is a tty and + stdout isn't. +Files: src/os_unix.c + +Patch 6.2.115 (extra) +Problem: Compiler warnings with various Amiga compilers. +Solution: Add typecast, prototypes, et al. Those changes that are + Amiga-specific. (Flavio Stanchina) +Files: src/fileio.c, src/memfile.c, src/os_amiga.c, src/os_amiga.h, + src/vim.h + +Patch 6.2.116 (extra) +Problem: German keyboard with Numlock set different from system startup + causes problems. +Solution: Ignore keys with code 0xff. (Helmut Stiegler) +Files: src/gui_w48.c + +Patch 6.2.117 +Problem: Breakpoints in loops of sourced files and functions are not + detected. (Hari Krishna Dara) +Solution: Check for breakpoints when using lines that were previously read. + (Servatius Brandt) +Files: src/eval.c, src/ex_cmds2.c, src/ex_docmd.c, src/proto/eval.pro, + src/proto/ex_cmds2.pro + +Patch 6.2.118 (extra) +Problem: Mac: Compiling is done in a non-standard way. +Solution: Use the Unix method for Mac OS X, with autoconf. Add "CARBONGUI" + to Makefile and configure. (Eric Kow) + Move a few prototypes from os_mac.pro to gui_mac.pro. +Files: src/Makefile, src/auto/configure, src/configure.in, + src/config.mk.in, src/gui_mac.c, src/os_mac.h, src/os_macosx.c, + src/proto/gui_mac.pro, src/proto/os_mac.pro, + src/infplist.xml, src/vim.h + +Patch 6.2.119 (after 6.2.107) +Problem: When packing the MS-Windows archives a few files are missing. + (Guopeng Wen) +Solution: Add gui_beval.* to the list of generic source files. +Files: Makefile + +Patch 6.2.120 +Problem: Win32 GUI: The console dialogs are not supported on MS-Windows, + disabling the 'c' flag of 'guioptions'. (Servatius Brandt) +Solution: Define FEAT_CON_DIALOG also for GUI-only builds. +Files: src/feature.h + +Patch 6.2.121 (after 6.2.118) +Problem: Not all make programs support "+=". (Charles Campbell) +Solution: Use a normal assignment. +Files: src/Makefile + +Patch 6.2.122 (after 6.2.119) +Problem: Not all shells can expand [^~]. File missing. (Guopeng Wen) +Solution: Use a simpler pattern. Add the Aap recipe for the maze program + and a clean version of the source code. +Files: Makefile, runtime/macros/maze/Makefile, + runtime/macros/maze/README.txt, runtime/macros/maze/main.aap, + runtime/macros/maze/mazeclean.c + +Patch 6.2.123 (after 6.2.118) +Problem: Running configure fails. (Tony Leneis) +Solution: Change "==" to "=" for a test. +Files: src/auto/configure, src/configure.in + +Patch 6.2.124 (after 6.2.121)(extra) +Problem: Mac: Recursive use of M4FLAGS causes problems. When running Vim + directly it can't find the runtime files. (Emily Jackson) + Using GNU constructs causes warnings with other make programs. + (Ronald Schild) +Solution: Use another name for the M4FLAGS variable. + Don't remove "Vim.app" from the path. + Update the explanation for compiling on the Mac. (Eric Kow) + Don't use $(shell ) and $(addprefix ). +Files: src/INSTALLmac.txt, src/Makefile, src/misc1.c + +Patch 6.2.125 (after 6.2.107) +Problem: The "winsock2.h" file isn't always available. +Solution: Don't include this header file. +Files: src/netbeans.c + +Patch 6.2.126 +Problem: Typing CTRL-C at a confirm() prompt doesn't throw an exception. +Solution: Reset "mapped_ctrl_c" in get_keystroke(), so that "got_int" is set + in _OnChar(). +Files: src/misc1.c + +Patch 6.2.127 (extra) +Problem: Win32 console: Typing CTRL-C doesn't throw an exception. +Solution: Set got_int immediately when CTRL-C is typed, don't wait for + mch_breakcheck() being called. +Files: src/os_win32.c + +Patch 6.2.128 (after 6.2.118) +Problem: src/auto/configure is not consistent with src/configure.in. +Solution: Use the newly generated configure script. +Files: src/auto/configure + +Patch 6.2.129 +Problem: When 'number' is set 'wrapmargin' does not work Vi-compatible. + (Yasuhiro Matsumoto) +Solution: Reduce the textwidth when 'number' is set. Also for 'foldcolumn' + and similar things. +Files: src/edit.c + +Patch 6.2.130 (extra) +Problem: Win32 console: When 'restorescreen' is not set exiting Vim causes + the screen to be cleared. (Michael A. Mangino) +Solution: Don't clear the screen when exiting and 'restorescreen' isn't set. +Files: src/os_win32.c + +Patch 6.2.131 (extra) +Problem: Win32: Font handles are leaked. +Solution: Free italic, bold and bold-italic handles before overwriting them. + (Michael Wookey) +Files: src/gui_w48.c + +Patch 6.2.132 (extra) +Problem: Win32: console version doesn't work on latest Windows Server 2003. +Solution: Copy 12000 instead of 15000 cells at a time to avoid running out + of memory. +Files: src/os_win32.c + +Patch 6.2.133 +Problem: When starting the GUI a bogus error message about 'imactivatekey' + may be given. +Solution: Only check the value of 'imactivatekey' when the GUI is running. +Files: src/gui.c, src/option.c + +Patch 6.2.134 (extra) +Problem: Win32: When scrolling parts of the window are redrawn when this + isn't necessary. +Solution: Only invalidate parts of the window when they are obscured by + other windows. (Michael Wookey) +Files: src/gui_w48.c + +Patch 6.2.135 +Problem: An item <> in the ":command" argument is interpreted as <args>. +Solution: Avoid that <> is recognized as <args>. +Files: src/ex_docmd.c + +Patch 6.2.136 +Problem: ":e ++enc=latin1 newfile" doesn't set 'fenc' when the file doesn't + exist. (Miroslaw Dobrzanski-Neumann) +Solution: Set 'fileencoding' to the specified encoding when editing a file + that does not exist. +Files: src/fileio.c + +Patch 6.2.137 +Problem: "d:cmd<CR>" cannot be repeated with ".". Breaks repeating "d%" + when using the matchit plugin. +Solution: Store the command to be repeated. This is restricted to + single-line commands. +Files: src/ex_docmd.c, src/globals.h, src/normal.c, src/vim.h + +Patch 6.2.138 (extra) +Problem: Compilation problem on VMS with dynamic buffer on the stack. +Solution: Read one byte less than the size of the buffer, so that we can + check for the string length without an extra buffer. +Files: src/os_vms.c + +Patch 6.2.139 +Problem: Code is repeated in the two Perl files. +Solution: Move common code from if_perl.xs and if_perlsfio.c to vim.h. + Also fix a problem with generating prototypes. +Files: src/if_perl.xs, src/if_perlsfio.c, src/vim.h + +Patch 6.2.140 (after 6.2.121) +Problem: Mac: Compiling with Python and Perl doesn't work. +Solution: Adjust the configure check for Python to use "-framework Python" + for Python 2.3 on Mac OS/X. + Move "-ldl" after "DynaLoader.a" in the link command. + Change "perllibs" to "PERL_LIBS". +Files: src/auto/configure, src/configure.in, src/config.mk.in + +Patch 6.2.141 (extra) +Problem: Mac: The b_FSSpec field is sometimes unused. +Solution: Change the #ifdef to FEAT_CW_EDITOR and defined it in feature.h +Files: src/fileio.c, src/gui_mac.c, src/structs.h, src/feature.h + +Patch 6.2.142 (after 6.2.124) +Problem: Mac: building without GUI through configure doesn't work. + When the system is slow, unpacking the resource file takes too + long. +Solution: Don't always define FEAT_GUI_MAC when MACOS is defined, define it + in the Makefile. + Add a configure option to skip Darwin detection. + Use a Python script to unpack the resources to avoid a race + condition. (Taro Muraoka) +Files: Makefile, src/Makefile, src/auto/configure, src/configure.in, + src/dehqx.py, src/vim.h + +Patch 6.2.143 +Problem: Using "K" on Visually selected text doesn't work if it ends in + a multi-byte character. +Solution: Include all the bytes of the last character. (Taro Muraoka) +Files: src/normal.c + +Patch 6.2.144 +Problem: When "g:html_use_css" is set the HTML header generated by the + 2html script is wrong. +Solution: Add the header after adding HREF for links. + Also use ":normal!" instead of ":normal" to avoid mappings + getting in the way. +Files: runtime/syntax/2html.vim + +Patch 6.2.145 (after 6.2.139) +Problem: Undefining "bool" doesn't work for older systems. (Wojtek Pilorz) +Solution: Only undefine "bool" on Mac OS. +Files: src/vim.h + +Patch 6.2.146 +Problem: On some systems the prototype for iconv() is wrong, causing a + warning message. +Solution: Use a cast (void *) to avoid the warning. (Charles Campbell) +Files: src/fileio.c, src/mbyte.c + +Patch 6.2.147 +Problem: ":s/pat/\=col('.')" always replaces with "1". +Solution: Set the cursor to the start of the match before substituting. + (Helmut Stiegler) +Files: src/ex_cmds.c + +Patch 6.2.148 +Problem: Can't break an Insert into several undoable parts. +Solution: Add the CTRL-G u command. +Files: runtime/doc/insert.txt, src/edit.c + +Patch 6.2.149 +Problem: When the cursor is on a line past 21,474,748 the indicated + percentage of the position is invalid. With that many lines + "100%" causes a negative cursor line number, resulting in a crash. + (Daniel Goujot) +Solution: Divide by 100 instead of multiplying. Avoid overflow when + computing the line number for "100%". +Files: src/buffer.c, src/ex_cmds2.c, src/normal.c + +Patch 6.2.150 +Problem: When doing "vim - < file" lines are broken at NUL chars. + (Daniel Goujot) +Solution: Change NL characters back to NUL when reading from the temp + buffer. +Files: src/fileio.c + +Patch 6.2.151 +Problem: When doing "vim --remote +startinsert file" some commands are + inserted as text. (Klaus Bosau) +Solution: Put all the init commands in one Ex line, not using a <CR>, so + that Insert mode isn't started too early. +Files: src/main.c + +Patch 6.2.152 +Problem: The cursor() function doesn't reset the column offset for + 'virtualedit'. +Solution: Reset the offset to zero. (Helmut Stiegler) +Files: src/eval.c + +Patch 6.2.153 +Problem: Win32: ":lang german" doesn't use German messages. +Solution: Add a table to translate the Win32 language names to two-letter + language codes. +Files: src/ex_cmds2.c + +Patch 6.2.154 +Problem: Python bails out when giving a warning message. (Eugene + Minkovskii) +Solution: Set sys.argv[] to an empty string. +Files: src/if_python.c + +Patch 6.2.155 +Problem: Win32: Using ":tjump www" in a help file gives two results. + (Dave Roberts) +Solution: Ignore differences between slashes and backslashes when checking + for identical tag matches. +Files: src/tag.c + +Patch 6.2.156 (after 6.2.125) +Problem: Win32: Netbeans fails to build, EINTR is not defined. +Solution: Redefine EINTR to WSAEINTR. (Mike Williams) +Files: src/netbeans.c + +Patch 6.2.157 +Problem: Using "%p" in 'errorformat' gives a column number that is too + high. +Solution: Set the flag to use the number as a virtual column. (Lefteris + Koutsoloukas) +Files: src/quickfix.c + +Patch 6.2.158 +Problem: The sed command on Solaris and HPUX doesn't work for a line that + doesn't end in a newline. +Solution: Add a newline when feeding text to sed. (Mark Waggoner) +Files: src/configure.in, src/auto/configure + +Patch 6.2.159 +Problem: When using expression folding and 'foldopen' is "undo" an undo + command doesn't always open the fold. +Solution: Save and restore the KeyTyped variable when evaluating 'foldexpr'. + (Taro Muraoka) +Files: src/fold.c + +Patch 6.2.160 +Problem: When 'virtualedit' is "all" and 'selection is "exclusive", + selecting a double-width character below a single-width character + may cause a crash. +Solution: Avoid overflow on unsigned integer decrement. (Taro Muraoka) +Files: src/normal.c + +Patch 6.2.161 (extra) +Problem: VMS: Missing header file. Reading input busy loops. +Solution: Include termdef.h. Avoid the use of a wait function in + vms_read(). (Frank Ries) +Files: src/os_unix.h, src/os_vms.c + +Patch 6.2.162 +Problem: ":redraw" doesn't always display the text that includes the cursor + position, e.g. after ":call cursor(1, 0)". (Eugene Minkovskii) +Solution: Call update_topline() before redrawing. +Files: src/ex_docmd.c + +Patch 6.2.163 +Problem: "make install" may also copy AAPDIR directories. +Solution: Delete AAPDIR directories, just like CVS directories. +Files: src/Makefile + +Patch 6.2.164 (after 6.2.144) +Problem: When "g:html_use_css" is set the HTML header generated by the + 2html script is still wrong. +Solution: Search for a string instead of jumping to a fixed line number. + Go to the start of the line before inserting the header. + (Jess Thrysoee) +Files: runtime/syntax/2html.vim + +Patch 6.2.165 +Problem: The configure checks hang when using autoconf 2.57. +Solution: Invoke AC_PROGRAM_EGREP to set $EGREP. (Aron Griffis) +Files: src/auto/configure, src/configure.in + +Patch 6.2.166 +Problem: When $GZIP contains "-N" editing compressed files doesn't work + properly. +Solution: Add "-n" to "gzip -d" to avoid restoring the file name. (Oyvind + Holm) +Files: runtime/plugin/gzip.vim + +Patch 6.2.167 +Problem: The Python interface leaks memory when assigning lines to a + buffer. (Sergey Khorev) +Solution: Do not copy the line when calling ml_replace(). +Files: src/if_python.c + +Patch 6.2.168 +Problem: Python interface: There is no way to get the indices from a range + object. +Solution: Add the "start" and "end" attributes. (Maurice S. Barnum) +Files: src/if_python.c, runtime/doc/if_pyth.txt + +Patch 6.2.169 +Problem: The prototype for _Xmblen() appears in a recent XFree86 header + file, causing a warning for our prototype. (Hisashi T Fujinaka) +Solution: Move the prototype to an osdef file, so that it's filtered out. +Files: src/mbyte.c, src/osdef2.h.in + +Patch 6.2.170 +Problem: When using Sun WorkShop the current directory isn't changed to + where the file is. +Solution: Set the 'autochdir' option when using WorkShop. And avoid using + the basename when 'autochdir' is not set. +Files: src/gui_x11.c, src/ex_cmds.c + +Patch 6.2.171 (after 6.2.163) +Problem: The "-or" argument of "find" doesn't work for SysV systems. +Solution: Use "-o" instead. (Gordon Prieur) +Files: src/Makefile + +Patch 6.2.172 (after 6.2.169) +Problem: The prototype for _Xmblen() still causes trouble. +Solution: Include the X11 header file that defines the prototype. +Files: src/osdef2.h.in, src/osdef.sh + +Patch 6.2.173 (extra) +Problem: Win32: Ruby interface doesn't work with Ruby 1.8.0 for other + compilers than MSVC. +Solution: Fix the BC5, Cygwin and Mingw makefiles. (Dan Sharp) +Files: src/Make_bc5.mak, src/Make_cyg.mak, src/Make_ming.mak + +Patch 6.2.174 +Problem: After the ":intro" message only a mouse click in the last line + gets past the hit-return prompt. +Solution: Accept a click at or below the hit-return prompt. +Files: src/gui.c, src/message.c + +Patch 6.2.175 +Problem: Changing 'backupext' in a *WritePre autocommand doesn't work. + (William Natter) +Solution: Move the use of p_bex to after executing the *WritePre + autocommands. Also avoids reading allocated memory after freeing. +Files: src/fileio.c + +Patch 6.2.176 +Problem: Accented characters in translated help files are not handled + correctly. (Fabien Vayssiere) +Solution: Include "192-255" in 'iskeyword' for the help window. +Files: src/ex_cmds.c + +Patch 6.2.177 (extra) +Problem: VisVim: Opening a file with a space in the name doesn't work. (Rob + Retter) Arbitrary commands are being executed. (Neil Bird) +Solution: Put a backslash in front of every space in the file name. + (Gerard Blais) Terminate the CTRL-\ CTRL-N command with a NUL. +Files: src/VisVim/Commands.cpp, src/VisVim/VisVim.rc + +Patch 6.2.178 +Problem: People who don't know how to exit Vim try pressing CTRL-C. +Solution: Give a message how to exit Vim when CTRL-C is pressed and it + doesn't cancel anything. +Files: src/normal.c + +Patch 6.2.179 (extra) +Problem: The en_gb messages file isn't found on case sensitive systems. +Solution: Rename en_gb to en_GB. (Mike Williams) +Files: src/po/en_gb.po, src/po/en_GB.po, src/po/Make_ming.mak, + src/po/Make_mvc.mak, src/po/Makefile, src/po/README_mvc.txt + +Patch 6.2.180 +Problem: Compiling with GTK2 on Win32 doesn't work. +Solution: Include gdkwin32.h instead of gdkx.h. (Srinath Avadhanula) +Files: src/gui_gtk.c, src/gui_gtk_f.c, src/gui_gtk_x11.c, src/mbyte.c + +Patch 6.2.181 (after 6.2.171) +Problem: The "-o" argument of "find" has lower priority than the implied + "and" with "-print". +Solution: Add parenthesis around the "-o" expression. (Gordon Prieur) +Files: src/Makefile + +Patch 6.2.182 (after 6.2.094) +Problem: Compilation with tiny features fails because of missing + get_past_head() function. +Solution: Adjust the #ifdef for get_past_head(). +Files: src/misc1.c + +Patch 6.2.183 (after 6.2.178) +Problem: Warning for char/unsigned char mixup. +Solution: Use MSG() instead of msg(). (Tony Leneis) +Files: src/normal.c + +Patch 6.2.184 +Problem: With 'formatoptions' set to "1aw" inserting text may cause the + paragraph to be ended. (Alan Schmitt) +Solution: Temporarily add an extra space to make the paragraph continue + after moving the word after the cursor to the next line. + Also format when pressing Esc. +Files: src/edit.c, src/normal.c, src/proto/edit.pro + +Patch 6.2.185 +Problem: Restoring a session with zero-height windows does not work + properly. (Charles Campbell) +Solution: Accept a zero argument to ":resize" as intended. Add a window + number argument to ":resize" to be able to set the size of other + windows, because the current window cannot be zero-height. + Fix the explorer plugin to avoid changing the window sizes. Add + the winrestcmd() function for this. +Files: runtime/doc/eval.txt, runtime/plugin/explorer.vim, src/eval.c, + src/ex_cmds.h, src/ex_docmd.c, src/proto/window.pro, src/window.c + +Patch 6.2.186 (after 6.2.185) +Problem: Documentation file eval.txt contains examples without indent. +Solution: Insert the indent. Also fix other mistakes. +Files: runtime/doc/eval.txt + +Patch 6.2.187 +Problem: Using Insure++ reveals a number of bugs. (Dominique Pelle) +Solution: Initialize variables where needed. Free allocated memory to avoid + leaks. Fix comparing tags to avoid reading past allocated memory. +Files: src/buffer.c, src/diff.c, src/fileio.c, src/mark.c, src/misc1.c, + src/misc2.c, src/ops.c, src/option.c, src/tag.c, src/ui.c + +Patch 6.2.188 (extra) +Problem: MS-Windows: Multi-byte characters in a filename cause trouble for + the window title. +Solution: Return when the wide function for setting the title did its work. +Files: src/gui_w48.c + +Patch 6.2.189 +Problem: When setting 'viminfo' after editing a new buffer its marks are + not stored. (Keith Roberts) +Solution: Set the "b_marks_read" flag when skipping to read marks from the + viminfo file. +Files: src/fileio.c + +Patch 6.2.190 +Problem: When editing a compressed files, marks are lost. +Solution: Add the ":lockmarks" modifier and use it in the gzip plugin. + Make exists() also check for command modifiers, so that the + existence of ":lockmarks" can be checked for. + Also add ":keepmarks" to avoid that marks are deleted when + filtering text. + When deleting lines put marks 'A - 'Z and '0 - '9 at the first + deleted line instead of clearing the mark. They were kept in the + viminfo file anyway. + Avoid that the gzip plugin puts deleted text in registers. +Files: runtime/doc/motion.txt, runtime/plugin/gzip.vim, src/ex_cmds.c, + src/ex_docmd.c, src/mark.c, src/structs.h + +Patch 6.2.191 +Problem: The intro message is outdated. Information about sponsoring and + registering is missing. +Solution: Show info about sponsoring and registering Vim in the intro + message now and then. Add help file about sponsoring. +Files: runtime/doc/help.txt, runtime/doc/sponsor.txt, runtime/doc/tags, + runtime/menu.vim, src/version.c + +Patch 6.2.192 +Problem: Using CTRL-T and CTRL-D with "gR" messes up the text. (Jonathan + Hankins) +Solution: Avoid calling change_indent() recursively. +Files: src/edit.c + +Patch 6.2.193 +Problem: When recalling a search pattern from the history from a ":s,a/c," + command the '/' ends the search string. (JC van Winkel) +Solution: Store the separator character with the history entries. Escape + characters when needed, replace the old separator with the new one. + Also fixes that recalling a "/" search for a "?" command messes up + trailing flags. +Files: src/eval.c, src/ex_getln.c, src/normal.c, src/proto/ex_getln.pro, + src/search.c, src/tag.c + +Patch 6.2.194 (after 6.2.068) +Problem: For NetBeans, instead of writing the file and sending an event + about it, tell NetBeans to write the file. +Solution: Add the "save" command, "netbeansBuffer" command and + "buttonRelease" event to the netbeans protocol. Updated the + interface to version 2.2. (Gordon Prieur) + Also: open a fold when the cursor has been positioned. + Also: fix memory leak, free result of nb_quote(). +Files: runtime/doc/netbeans.txt, src/fileio.c, src/netbeans.c, + src/normal.c, src/proto/netbeans.pro, src/structs.h + +Patch 6.2.195 (after 6.2.190) +Problem: Compiling fails for missing CPO_REMMARK symbol. +Solution: Add the patch I forgot to include... +Files: src/option.h + +Patch 6.2.196 (after 6.2.191) +Problem: Rebuilding the documentation doesn't use the sponsor.txt file. +Solution: Add sponsor.txt to the Makefile. (Christian J. Robinson) +Files: runtime/doc/Makefile + +Patch 6.2.197 +Problem: It is not possible to force a redraw of status lines. (Gary + Johnson) +Solution: Add the ":redrawstatus" command. +Files: runtime/doc/various.txt, src/ex_cmds.h, src/ex_docmd.c, + src/screen.c + +Patch 6.2.198 +Problem: A few messages are not translated. (Ernest Adrogue) +Solution: Mark the messages to be translated. +Files: src/ex_cmds.c + +Patch 6.2.199 (after 6.2.194) +Problem: Vim doesn't work perfectly well with NetBeans. +Solution: When NetBeans saves the file, reset the timestamp to avoid "file + changed" warnings. Close a buffer in a proper way. Don't try + giving a debug message with an invalid pointer. Send a + newDotAndMark message when needed. Report a change by the "r" + command to NetBeans. (Gordon Prieur) +Files: src/netbeans.c, src/normal.c + +Patch 6.2.200 +Problem: When recovering a file, 'fileformat' is always the default, thus + writing the file may result in differences. (Penelope Fudd) +Solution: Before recovering the file try reading the original file to obtain + the values of 'fileformat', 'fileencoding', etc. +Files: src/memline.c + +Patch 6.2.201 +Problem: When 'autowriteall' is set ":qall" still refuses to exit if there + is a modified buffer. (Antoine Mechelynck) +Solution: Attempt writing modified buffers as intended. +Files: src/ex_cmds2.c + +Patch 6.2.202 +Problem: Filetype names of CHILL and ch script are confusing. +Solution: Rename "ch" to "chill" and "chscript" to "ch". +Files: runtime/filetype.vim, runtime/makemenu.vim, runtime/synmenu.vim + runtime/syntax/ch.vim, runtime/syntax/chill.vim + +Patch 6.2.203 +Problem: With characterwise text that has more than one line, "3P" works + wrong. "3p" has the same problem. There also is a display + problem. (Daniel Goujot) +Solution: Perform characterwise puts with a count in the right position. +Files: src/ops.c + +Patch 6.2.204 (after 6.2.086) +Problem: "]]" in a file with closed folds moves to the end of the file. + (Nam SungHyun) +Solution: Find one position in each closed fold, then move to after the fold. +Files: src/search.c + +Patch 6.2.205 (extra) +Problem: MS-Windows: When the taskbar is at the left or top of the screen, + the Vim window placement is wrong. +Solution: Compute the size and position of the window correctly. (Taro + Muraoka) +Files: src/gui_w32.c, src/gui_w48.c + +Patch 6.2.206 +Problem: Multi-byte characters cannot be used as hotkeys in a console + dialog. (Mattias Erkisson) +Solution: Handle multi-byte characters properly. Also put () or [] around + default hotkeys. +Files: src/message.c, src/macros.h + +Patch 6.2.207 +Problem: When 'encoding' is a multi-byte encoding, expanding an + abbreviation that starts where insertion started results in + characters before the insertion to be deleted. (Xiangjiang Ma) +Solution: Stop searching leftwards for the start of the word at the position + where insertion started. +Files: src/getchar.c + +Patch 6.2.208 +Problem: When using fold markers, three lines in a row have the start + marker and deleting the first one with "dd", a nested fold is not + deleted. (Kamil Burzynski) + Using marker folding, a level 1 fold doesn't stop when it is + followed by "{{{2", starting a level 2 fold. +Solution: Don't stop updating folds at the end of a change when the nesting + level of folds is larger than the fold level. + Correctly compute the number of folds that start at "{{{2". + Also avoid a crash for a NULL pointer. +Files: src/fold.c + +Patch 6.2.209 +Problem: A bogus fold is created when using "P" while the cursor is in the + middle of a closed fold. (Kamil Burzynski) +Solution: Correct the line number where marks are modified for closed folds. +Files: src/ops.c + +Patch 6.2.210 (extra) +Problem: Mac OSX: antialiased fonts are not supported. +Solution: Add the 'antialias' option to switch on antialiasing on Mac OSX + 10.2 and later. (Peter Cucka) +Files: runtime/doc/options.txt, src/gui_mac.c, src/option.h, src/option.c + +Patch 6.2.211 (extra) +Problem: Code for handling file dropped on Vim is duplicated. +Solution: Move the common code to gui_handle_drop(). + Add code to drop the files in the window under the cursor. + Support drag&drop on the Macintosh. (Taro Muraoka) + When dropping a directory name edit that directory (using the + explorer plugin) + Fix that changing directory with Shift pressed didn't work for + relative path names. +Files: src/fileio.c, src/gui.c, src/gui_gtk_x11.c, src/gui_mac.c, + src/gui_w48.c, src/proto/fileio.pro, src/proto/gui.pro + +Patch 6.2.212 (after 6.2.199) +Problem: NetBeans: Replacing with a count is not handled correctly. +Solution: Move reporting the change outside of the loop for the count. + (Gordon Prieur) +Files: src/normal.c + +Patch 6.2.213 (after 6.2.208) +Problem: Using marker folding, "{{{1" doesn't start a new fold when already + at fold level 1. (Servatius Brandt) +Solution: Correctly compute the number of folds that start at "{{{1". +Files: src/fold.c + +Patch 6.2.214 (after 6.2.211) (extra) +Problem: Warning for an unused variable. +Solution: Delete the declaration. (Bill McCarthy) +Files: src/gui_w48.c + +Patch 6.2.215 +Problem: NetBeans: problems saving an unmodified file. +Solution: Add isNetbeansModified() function. Disable netbeans_unmodified(). + (Gordon Prieur) +Files: src/fileio.c, src/netbeans.c, src/proto/netbeans.pro, + runtime/doc/netbeans.txt, runtime/doc/tags + +Patch 6.2.216 (after 6.2.206) +Problem: Multi-byte characters still cannot be used as hotkeys in a console + dialog. (Mattias Erkisson) +Solution: Make get_keystroke() handle multi-byte characters. +Files: src/misc1.c + +Patch 6.2.217 +Problem: GTK: setting the title doesn't always work correctly. +Solution: Invoke gui_mch_settitle(). (Tomas Stehlik) +Files: src/os_unix.c + +Patch 6.2.218 +Problem: Warning for function without prototype. +Solution: Add argument types to the msgCB field of the BalloonEval struct. +Files: src/gui_beval.h + +Patch 6.2.219 +Problem: Syntax highlighting hangs on an empty match of an item with a + nextgroup. (Charles Campbell) +Solution: Remember that the item has already matched and don't match it + again at the same position. +Files: src/syntax.c + +Patch 6.2.220 +Problem: When a Vim server runs in a console a remote command isn't handled + before a key is typed. (Joshua Neuheisel) +Solution: Don't try reading more input when a client-server command has been + received. +Files: src/os_unix.c + +Patch 6.2.221 +Problem: No file name completion for ":cscope add". +Solution: Add the XFILE flag to ":cscope". (Gary Johnson) +Files: src/ex_cmds.h + +Patch 6.2.222 +Problem: Using "--remote" several times on a row only opens some of the + files. (Dany St-Amant) +Solution: Don't delete all typeahead when the server receives a command from + a client, only delete typed characters. +Files: src/main.c + +Patch 6.2.223 +Problem: Cscope: Avoid a hang when cscope waits for a response while Vim + waits for a prompt. + Error messages from Cscope mess up the display. +Solution: Detect the hit-enter message and respond by sending a return + character to cscope. (Gary Johnson) + Use EMSG() and strerror() when possible. Replace perror() with + PERROR() everywhere, add emsg3(). +Files: src/diff.c, src/if_cscope.c, src/integration.c, src/message.c, + src/proto/message.pro, src/misc2.c, src/netbeans.c, src/vim.h + +Patch 6.2.224 +Problem: Mac: Can't compile with small features. (Axel Kielhorn) +Solution: Also include vim_chdirfile() when compiling for the Mac. +Files: src/misc2.c + +Patch 6.2.225 +Problem: NetBeans: Reported modified state isn't exactly right. +Solution: Report a file being modified in the NetBeans way. +Files: src/netbeans.c + +Patch 6.2.226 (after 6.2.107) (extra) +Problem: The "ws2-32.lib" file isn't always available. +Solution: Use "WSock32.lib" instead. (Taro Muraoka, Dan Sharp) +Files: src/Make_cyg.mak, src/Make_ming.mak, src/Make_mvc.mak + +Patch 6.2.227 (extra) +Problem: The "PC" symbol is defined but not used anywhere. +Solution: Remove "-DPC" from the makefiles. +Files: src/Make_bc3.mak, src/Make_bc5.mak, src/Make_cyg.mak, + src/Make_ming.mak + +Patch 6.2.228 +Problem: Receiving CTRL-\ CTRL-N after typing "f" or "m" doesn't switch Vim + back to Normal mode. Same for CTRL-\ CTRL-G. +Solution: Check if the character typed after a command is CTRL-\ and obtain + another character to check for CTRL-N or CTRL-G, waiting up to + 'ttimeoutlen' msec. +Files: src/normal.c + +Patch 6.2.229 +Problem: ":function" with a name that uses magic curlies does not work + inside a function. (Servatius Brandt) +Solution: Skip over the function name properly. +Files: src/eval.c + +Patch 6.2.230 (extra) +Problem: Win32: a complex pattern may cause a crash. +Solution: Use __try and __except to catch the exception and handle it + gracefully, when possible. Add myresetstkoflw() to reset the + stack overflow. (Benjamin Peterson) +Files: src/Make_bc5.mak, src/os_mswin.c src/os_win32.c, src/os_win32.h, + src/proto/os_win32.pro, src/regexp.c + +Patch 6.2.231 (after 6.2.046) +Problem: Various problems when an error exception is raised from within a + builtin function. When it is invoked while evaluating arguments + to a function following arguments are still evaluated. When + invoked with a line range it will be called for remaining lines. +Solution: Update "force_abort" also after calling a builtin function, so + that aborting() always returns the correct value. (Servatius + Brandt) +Files: src/eval.c, src/ex_eval.c, src/proto/ex_eval.pro, + src/testdir/test49.ok, src/testdir/test49.vim + +Patch 6.2.232 +Problem: ":python vim.command('python print 2*2')" crashes Vim. (Eugene + Minkovskii) +Solution: Disallow executing a Python command recursively and give an error + message. +Files: src/if_python.c + +Patch 6.2.233 +Problem: On Mac OSX adding -pthread for Python only generates a warning. + The test for Perl threads rejects Perl while it's OK. + Tcl doesn't work at all. + The test for Ruby fails if ruby exists but there are no header + files. The Ruby library isn't detected properly +Solution: Avoid adding -pthread on Mac OSX. Accept Perl threads when it's + not the 5.5 threads. + Use the Tcl framework for header files. For Ruby rename cWindow + to cVimWindow to avoid a name clash. (Ken Scott) + Only enable Ruby when the header files can be found. Use "-lruby" + instead of "libruby.a" when it can't be found. +Files: src/auto/configure, src/configure.in, src/if_ruby.c + +Patch 6.2.234 +Problem: GTK 2 GUI: ":sp" and the ":q" leaves the cursor on the command + line. +Solution: Flush output before removing scrollbars. Also do this in other + places where gui_mch_*() functions are invoked. +Files: src/ex_cmds.c, src/option.c, src/window.c + +Patch 6.2.235 (extra) +Problem: Win32: Cursor isn't removed with a 25x80 window and doing: + "1830ia<Esc>400a-<Esc>0w0". (Yasuhiro Matsumoto) +Solution: Remove the call to gui_undraw_cursor() from gui_mch_insert_lines(). +Files: src/gui_w48.c + +Patch 6.2.236 +Problem: Using gvim with Agide gives "connection lost" error messages. +Solution: Only give the "connection lost" message when the buffer was once + owned by NetBeans. +Files: src/netbeans.c, src/structs.h + +Patch 6.2.237 +Problem: GTK 2: Thai text is drawn wrong. It changes when moving the + cursor over it. +Solution: Disable the shaping engine, it moves combining characters to a + wrong position and combines characters, while drawing the cursor + doesn't combine characters. +Files: src/gui_gtk_x11.c + +Patch 6.2.238 (after 6.2.231) +Problem: ":function" does not work inside a while loop. (Servatius Brandt) +Solution: Add get_while_line() and pass it to do_one_cmd() when in a while + loop, so that all lines are stored and can be used again when + repeating the loop. + Adjust test 49 so that it checks for the fixed problems. + (Servatius Brandt) +Files: src/digraph.c, src/ex_cmds2.c, src/ex_docmd.c, src/ex_eval.c, + src/proto/ex_cmds2.pro, src/proto/ex_docmd.pro, + src/testdir/test49.in, src/testdir/test49.ok, + src/testdir/test49.vim + +Patch 6.2.239 +Problem: GTK 2: With closed folds the arrow buttons of a vertical scrollbar + often doesn't scroll. (Moshe Kaminsky) +Solution: Hackish solution: Detect that the button was pressed from the + mouse pointer position. +Files: src/gui_gtk.c, src/gui.c + +Patch 6.2.240 +Problem: GTK 2: Searching for bitmaps for the toolbar doesn't work as with + other systems. Need to explicitly use "icon=name". (Ned Konz, + Christian J. Robinson) +Solution: Search for icons like done for Motif. +Files: src/gui_gtk.c + +Patch 6.2.241 +Problem: GTK 2: Search and Search/Replace dialogs are synced, that makes no + sense. Buttons are sometimes greyed-out. (Jeremy Messenger) +Solution: Remove the code to sync the two dialogs. Adjust the code to react + to an empty search string to also work for GTK2. (David Necas) +Files: src/gui_gtk.c + +Patch 6.2.242 +Problem: Gnome: "vim --help" only shows the Gnome arguments, not the Vim + arguments. +Solution: Don't let the Gnome code remove the "--help" argument and don't + exit at the end of usage(). +Files: src/gui_gtk_x11.c, src/main.c + +Patch 6.2.243 (extra) +Problem: Mac: Dropping a file on a Vim icon causes a hit-enter prompt. +Solution: Move the dropped files to the global argument list, instead of the + usual drop handling. (Eckehard Berns) +Files: src/main.c, src/gui_mac.c + +Patch 6.2.244 +Problem: ':echo "\xf7"' displays the illegal byte as if it was a character + and leaves "cho" after it. +Solution: When checking the length of a UTF-8 byte sequence and it's shorter + than the number of bytes available, assume it's an illegal byte. +Files: src/mbyte.c + +Patch 6.2.245 +Problem: Completion doesn't work for ":keepmarks" and ":lockmarks". +Solution: Add the command modifiers to the table of commands. (Madoka + Machitani) +Files: src/ex_cmds.h, src/ex_docmd.c + +Patch 6.2.246 +Problem: Mac: Starting Vim from Finder doesn't show error messages. +Solution: Recognize that output is being displayed by stderr being + "/dev/console". (Eckehard Berns) +Files: src/main.c, src/message.c + +Patch 6.2.247 (after 6.2.193) +Problem: When using a search pattern from the viminfo file the last + character is replaced with a '/'. +Solution: Store the separator character in the right place. (Kelvin Lee) +Files: src/ex_getln.c + +Patch 6.2.248 +Problem: GTK: When XIM is enabled normal "2" and keypad "2" cannot be + distinguished. +Solution: Detect that XIM changes the keypad key to the expected ASCII + character and fall back to the non-XIM code. (Neil Bird) +Files: src/gui_gtk_x11.c, src/mbyte.c, src/proto/mbyte.pro + +Patch 6.2.249 +Problem: ":cnext" moves to the error in the next file, but there is no + method to go back. +Solution: Add ":cpfile" and ":cNfile". +Files: src/ex_cmds.h, src/quickfix.c, src/vim.h, runtime/doc/quickfix.txt + +Patch 6.2.250 +Problem: Memory leaks when using signs. (Xavier de Gaye) +Solution: Delete the list of signs when unloading a buffer. +Files: src/buffer.c + +Patch 6.2.251 +Problem: GTK: The 'v' flag in 'guioptions' doesn't work. (Steve Hall) + Order of buttons is reversed for GTK 2.2.4. Don't always get + focus back after handling a dialog. +Solution: Make buttons appear vertically when desired. Reverse the order in + which buttons are added to a dialog. Move mouse pointer around + when the dialog is done and we don't have focus. +Files: src/gui_gtk.c + +Patch 6.2.252 (extra, after 6.2.243) +Problem: Mac: Dropping a file on a Vim icon causes a hit-enter prompt for + Mac OS classic. +Solution: Remove the #ifdef from the code that fixes it for Mac OSX. +Files: src/gui_mac.c + +Patch 6.2.253 +Problem: When 'tagstack' is not set a ":tag id" command does not work after + a ":tjump" command. +Solution: Set "new_tag" when 'tagstack' isn't set. (G. Narendran) +Files: src/tag.c + +Patch 6.2.254 +Problem: May run out of space for error messages. +Solution: Keep room for two more bytes. +Files: src/quickfix.c + +Patch 6.2.255 +Problem: GTK: A new item in the popup menu is put just after instead of + just before the right item. (Gabriel Zachmann) +Solution: Don't increment the menu item index. +Files: src/gui_gtk.c + +Patch 6.2.256 +Problem: Mac: "macroman" encoding isn't recognized, need to use + "8bit-macroman. +Solution: Recognize "macroman" with an alias "mac". (Eckehard Berns) +Files: src/mbyte.c + +Patch 6.2.257 (after 6.2.250) +Problem: Signs are deleted for ":bdel", but they could still be useful. +Solution: Delete signs only for ":bwipe". +Files: src/buffer.c + +Patch 6.2.258 +Problem: GUI: can't disable (grey-out) a popup menu item. (Ajit Thakkar) +Solution: Loop over the popup menus for all modes. +Files: src/menu.c + +Patch 6.2.259 +Problem: If there are messages when exiting, on the console there is a + hit-enter prompt while the message can be read; in the GUI the + message may not be visible. +Solution: Use the hit-enter prompt when there is an error message from + writing the viminfo file or autocommands, or when there is any + output in the GUI and 'verbose' is set. Don't use a hit-enter + prompt for the non-GUI version unless there is an error message. +Files: src/main.c + +Patch 6.2.260 +Problem: GTK 2: Can't quit a dialog with <Esc>. + GTK 1 and 2: <Enter> always gives a result, even when the default + button has been disabled. +Solution: Handle these keys explicitly. When no default button is specified + use the first one (works mostly like it was before). +Files: src/gui_gtk.c + +Patch 6.2.261 +Problem: When 'autoindent' and 'cindent' are set and a line is recognized + as a comment, starting a new line won't do 'cindent' formatting. +Solution: Also use 'cindent' formatting for lines that are used as a + comment. (Servatius Brandt) +Files: src/misc1.c + +Patch 6.2.262 +Problem: 1 CTRL-W w beeps, even though going to the first window is + possible. (Charles Campbell) +Solution: Don't beep. +Files: src/window.c + +Patch 6.2.263 +Problem: Lint warnings: Duplicate function prototypes, duplicate macros, + use of a zero character instead of a zero pointer, unused + variable. Clearing allocated memory in a complicated way. +Solution: Remove the function prototypes from farsi.h. Remove the + duplicated lines in keymap.h. Change getvcol() argument from NUL + to NULL. Remove the "col" variable in regmatch(). Use + lalloc_clear() instead of lalloc(). (Walter Briscoe) +Files: src/farsi.h, src/keymap.h, src/ops.c, src/regexp.c, src/search.c + +Patch 6.2.264 (after 6.2.247) +Problem: Writing past allocated memory when using a command line from the + viminfo file. +Solution: Store the NUL in the right place. +Files: src/ex_getln.c + +Patch 6.2.265 +Problem: Although ":set" is not allowed in the sandbox, ":let &opt = val" + works. +Solution: Do allow changing options in the sandbox, but not the ones that + can't be changed from a modeline. +Files: src/ex_cmds.h, src/options.c + +Patch 6.2.266 +Problem: When redirecting output and using ":silent", line breaks are + missing from output of ":map" and ":tselect". Alignment of + columns is wrong. +Solution: Insert a line break where "msg_didout" was tested. Update msg_col + when redirecting and using ":silent". +Files: src/getchar.c, src/message.c + +Patch 6.2.267 (extra) +Problem: Win32: "&&" in a tearoff menu is not shown. (Luc Hermitte) +Solution: Use the "name" item from the menu instead of the "dname" item. +Files: src/gui_w32.c, src/menu.c + +Patch 6.2.268 +Problem: GUI: When changing 'guioptions' part of the window may be off + screen. (Randall Morris) +Solution: Adjust the size of the window when changing 'guioptions', but only + when adding something. +Files: src/gui.c + +Patch 6.2.269 +Problem: Diff mode does not highlight a change in a combining character. + (Raphael Finkel) +Solution: Make diff_find_change() multi-byte aware: find the start byte of + a character that contains a change. +Files: src/diff.c + +Patch 6.2.270 +Problem: Completion in Insert mode, then repeating with ".", doesn't handle + composing characters in the completed text. (Raphael Finkel) +Solution: Don't skip over composing chars when adding completed text to the + redo buffer. +Files: src/getchar.c + +Patch 6.2.271 +Problem: NetBeans: Can't do "tail -f" on the log. Passing socket info with + an argument or environment variable is not secure. +Solution: Wait after initializing the log. Allow passing the socket info + through a file. (Gordon Prieur) +Files: runtime/doc/netbeans.txt, src/main.c, src/netbeans.c + +Patch 6.2.272 +Problem: When the "po" directory exists, but "po/Makefile" doesn't, + building fails. Make loops when the "po" directory has been + deleted after running configure. +Solution: Check for the "po/Makefile" instead of just the "po" directory. + Check this again before trying to run make with that Makefile. +Files: src/auto/configure, src/configure.in, src/Makefile + +Patch 6.2.273 +Problem: Changing the sort order in an explorer window for an empty + directory produces error messages. (Doug Kearns) +Solution: When an invalid range is used for a function that is not going to + be executed, skip over the arguments anyway. +Files: src/eval.c + +Patch 6.2.274 +Problem: ":print" skips empty lines when 'list' is set and there is no + "eol" in 'listchars'. (Yakov Lerner) +Solution: Skip outputting a space for an empty line only when 'list' is set + and the end-of-line character is not empty. +Files: src/message.c + +Patch 6.2.275 (extra, after 6.2.267) +Problem: Warning for uninitialized variable when using gcc. +Solution: Initialize "acLen" to zero. (Bill McCarthy) +Files: src/gui_w32.c + +Patch 6.2.276 +Problem: ":echo X()" does not put a line break between the message that X() + displays and the text that X() returns. (Yakov Lerner) +Solution: Invoke msg_start() after evaluating the argument. +Files: src/eval.c + +Patch 6.2.277 +Problem: Vim crashes when a ":runtime ftplugin/ada.vim" causes a recursive + loop. (Robert Nowotniak) +Solution: Restore "msg_list" before returning from do_cmdline(). +Files: src/ex_docmd.c + +Patch 6.2.278 +Problem: Using "much" instead of "many". +Solution: Correct the error message. +Files: src/eval.c + +Patch 6.2.279 +Problem: There is no default choice for a confirm() dialog, now that it is + possible not to have a default choice. +Solution: Make the first choice the default choice. +Files: runtime/doc/eval.txt, src/eval.c + +Patch 6.2.280 +Problem: "do" and ":diffget" don't work in the first line and the last line + of a buffer. (Aron Griffis) +Solution: Find a difference above the first line and below the last line. + Also fix a few display updating bugs. +Files: src/diff.c, src/fold.c, src/move.c + +Patch 6.2.281 +Problem: PostScript printing doesn't work on Mac OS X 10.3.2. +Solution: Adjust the header file. (Mike Williams) +Files: runtime/print/prolog.ps + +Patch 6.2.282 +Problem: When using CTRL-O to go back to a help file, it becomes listed. + (Andrew Nesbit) + Using ":tag" or ":tjump" in a help file doesn't keep the help file + settings (e.g. for 'iskeyword'). +Solution: Don't mark a buffer as listed when its help flag is set. Put all + the option settings for a help buffer together in do_ecmd(). +Files: src/ex_cmds.c + +Patch 6.2.283 +Problem: The "local additions" in help.txt are used without conversion, + causing latin1 characters showing up wrong when 'enc' is utf-8. + (Antoine J. Mechelynck) +Solution: Convert the text to 'encoding'. +Files: src/ex_cmds.c + +Patch 6.2.284 +Problem: Listing a function puts "endfunction" in the message history. + Typing "q" at the more prompt isn't handled correctly when listing + variables and functions. (Hara Krishna Dara) +Solution: Don't use msg() for "endfunction". Check "got_int" regularly. +Files: src/eval.c + +Patch 6.2.285 +Problem: GUI: In a single wrapped line that fills the window, "gj" in the + last screen line leaves the cursor behind. (Ivan Tarasov) +Solution: Undraw the cursor before scrolling the text up. +Files: src/gui.c + +Patch 6.2.286 +Problem: When trying to rename a file and it doesn't exist, the destination + file is deleted anyway. (Luc Deux) +Solution: Don't delete the destination when the source doesn't exist. (Taro + Muraoka) +Files: src/fileio.c + +Patch 6.2.287 (after 6.2.264) +Problem: Duplicate lines are added to the viminfo file. +Solution: Compare with existing entries without an offset. Also fixes + reading very long history lines from viminfo. +Files: src/ex_getln.c + +Patch 6.2.288 (extra) +Problem: Mac: An external program can't be interrupted. +Solution: Don't use the 'c' key for backspace. (Eckehard Berns) +Files: src/gui_mac.c + +Patch 6.2.289 +Problem: Compiling the Tcl interface with thread support causes ":make" to + fail. (Juergen Salk) +Solution: Use $TCL_DEFS from the Tcl config script to obtain the required + compile flags for using the thread library. +Files: src/auto/configure, src/configure.in + +Patch 6.2.290 (extra) +Problem: Mac: The mousewheel doesn't work. +Solution: Add mousewheel support. Also fix updating the thumb after a drag + and then using another way to scroll. (Eckehard Berns) +Files: src/gui_mac.c + +Patch 6.2.291 (extra) +Problem: Mac: the plus button and close button don't do anything. +Solution: Make the plus button maximize the window and the close button + close Vim. (Eckehard Berns) +Files: src/gui.c, src/gui_mac.c + +Patch 6.2.292 +Problem: Motif: When removing GUI arguments from argv[] a "ps -ef" shows + the last argument repeated. +Solution: Set argv[argc] to NULL. (Michael Jarvis) +Files: src/gui_x11.c + +Patch 6.2.293 (after 6.2.255) +Problem: GTK: A new item in a menu is put before the tearoff item. +Solution: Do increment the menu item index for non-popup menu items. +Files: src/gui_gtk.c + +Patch 6.2.294 (extra) +Problem: Mac: Cannot use modifiers with Space, Tab, Enter and Escape. +Solution: Handle all modifiers for these keys. (Eckehard Berns) +Files: src/gui_mac.c + +Patch 6.2.295 +Problem: When in debug mode, receiving a message from a remote client + causes a crash. Evaluating an expression causes Vim to wait for + "cont" to be typed, without a prompt. (Hari Krishna Dara) +Solution: Disable debugging when evaluating an expression for a client. + (Michael Geddes) Don't try reading into the typeahead buffer when + it may have been filled in another way. +Files: src/ex_getln.c, src/getchar.c, src/if_xcmdsrv.c, src/main.c, + src/misc1.c, src/proto/getchar.pro, src/proto/main.pro, + src/proto/os_unix.pro, src/proto/ui.pro, src/structs.h, + src/os_unix.c, src/ui.c + +Patch 6.2.296 (extra) +Problem: Same as 6.2.295. +Solution: Extra files for patch 6.2.295. +Files: src/os_amiga.c, src/os_msdos.c, src/os_riscos.c, src/os_win32.c, + src/proto/os_amiga.pro, src/proto/os_msdos.pro, + src/proto/os_riscos.pro, src/proto/os_win32.pro + +Patch 6.2.297 (after 6.2.232) +Problem: Cannot invoke Python commands recursively. +Solution: With Python 2.3 and later use the available mechanisms to invoke + Python recursively. (Matthew Mueller) +Files: src/if_python.c + +Patch 6.2.298 +Problem: A change always sets the '. mark and an insert always sets the '^ + mark, even when this is not wanted. + Cannot go back to the position of older changes without undoing + those changes. +Solution: Add the ":keepjumps" command modifier. + Add the "g," and "g;" commands. +Files: runtime/doc/motion.txt, src/ex_cmds.h, src/ex_docmd.c, src/edit.c, + src/mark.c, src/misc1.c, src/normal.c, src/proto/mark.pro, + src/structs.h, src/undo.c + +Patch 6.2.299 +Problem: Can only use one language for help files. +Solution: Add the 'helplang' option to select the preferred language(s). + Make ":helptags" generate tags files for all languages. +Files: runtime/doc/options.txt, runtime/doc/various.txt, src/Makefile, + src/ex_cmds.c, src/ex_cmds2.c, src/ex_cmds.h, src/ex_getln.c, + src/normal.c, src/option.c, src/option.h, src/proto/ex_cmds.pro, + src/proto/ex_cmds2.pro, src/proto/option.pro, src/structs.h, + src/tag.c, src/vim.h + +Patch 6.2.300 (after 6.2.297) +Problem: Cannot build Python interface with Python 2.2 or earlier. +Solution: Add a semicolon. +Files: src/if_python.c + +Patch 6.2.301 +Problem: The "select all" item from the popup menu doesn't work for Select + mode. +Solution: Use the same commands as for the "Edit.select all" menu. + (Benji Fisher) +Files: runtime/menu.vim + +Patch 6.2.302 +Problem: Using "CTRL-O ." in Insert mode doesn't work properly. (Benji + Fisher) +Solution: Restore "restart_edit" after an insert command that was not typed. + Avoid waiting with displaying the mode when there is no text to be + overwritten. + Fix that "CTRL-O ." sometimes doesn't put the cursor back after + the end-of-line. Only reset the flag that CTRL-O was used past + the end of the line when restarting editing. Update "o_lnum" + number when inserting text and "o_eol" is set. +Files: src/edit.c, src/normal.c + +Patch 6.2.303 +Problem: Cannot use Unicode digraphs while 'encoding' is not Unicode. +Solution: Convert the character from Unicode to 'encoding' when needed. + Use the Unicode digraphs for the Macintosh. (Eckehard Berns) +Files: src/digraph.c + +Patch 6.2.304 (extra, after 6.2.256) +Problem: Mac: No proper support for 'encoding'. Conversion without iconv() + is not possible. +Solution: Convert input from 'termencoding' to 'encoding'. Add + mac_string_convert(). Convert text for the clipboard when needed. + (Eckehard Berns) +Files: src/gui_mac.c, src/mbyte.c, src/structs.h, src/vim.h + +Patch 6.2.305 (after 6.2.300) +Problem: Win32: Cannot build Python interface with Python 2.3. (Ajit + Thakkar) +Solution: Add two functions to the dynamic loading feature. +Files: src/if_python.c + +Patch 6.2.306 (extra) +Problem: Win32: Building console version with BCC 5.5 gives a warning for + get_cmd_args() prototype missing. (Ajit Thakkar) +Solution: Don't build os_w32exe.c for the console version. +Files: src/Make_bc5.mak + +Patch 6.2.307 (after 6.2.299) +Problem: Installing help files fails. +Solution: Expand wildcards for translated help files separately. +Files: src/Makefile + +Patch 6.2.308 +Problem: Not all systems have "whoami", resulting in an empty user name. +Solution: Use "logname" when possible, "whoami" otherwise. (David Boyce) +Files: src/Makefile + +Patch 6.2.309 +Problem: "3grx" waits for two ESC to be typed. (Jens Paulus) +Solution: Append the ESC to the stuff buffer when redoing the "gr" insert. +Files: src/edit.c + +Patch 6.2.310 +Problem: When setting 'undolevels' to -1, making a change and setting + 'undolevels' to a positive value an "undo list corrupt" error + occurs. (Madoka Machitani) +Solution: Sync undo before changing 'undolevels'. +Files: src/option.c + +Patch 6.2.311 (after 6.2.298) +Problem: When making several changes in one line the changelist grows + quickly. There is no error message for reaching the end of the + changelist. Reading changelist marks from viminfo doesn't work + properly. +Solution: Only make a new entry in the changelist when making a change in + another line or 'textwidth' columns away. Add E662, E663 and E664 + error messages. Put a changelist mark from viminfo one position + before the end. +Files: runtime/doc/motion.txt, src/mark.c, src/misc1.c, src/normal.c + +Patch 6.2.312 (after 6.2.299) +Problem: "make install" clears the screen when installing the docs. +Solution: Execute ":helptags" in silent mode. +Files: runtime/doc/Makefile + +Patch 6.2.313 +Problem: When opening folds in a diff window, other diff windows no longer + show the same text. +Solution: Sync the folds in diff windows. +Files: src/diff.c, src/fold.c, src/move.c, src/proto/diff.pro, + src/proto/move.pro + +Patch 6.2.314 +Problem: When 'virtualedit' is set "rx" may cause a crash with a blockwise + selection and using "$". (Moritz Orbach) +Solution: Don't try replacing chars in a line that has no characters in the + block. +Files: src/ops.c + +Patch 6.2.315 +Problem: Using CTRL-C in a Visual mode mapping while 'insertmode' is set + stops Vim from returning to Insert mode. +Solution: Don't reset "restart_edit" when a CTRL-C is found and 'insertmode' + is set. +Files: src/normal.c + +Patch 6.2.316 (after 6.2.312) +Problem: "make install" tries connecting to the X server when installing + the docs. (Stephen Thomas) +Solution: Add the "-X" argument. +Files: runtime/doc/Makefile + +Patch 6.2.317 (after 6.2.313) +Problem: When using "zi" in a diff window, other diff windows are not + adjusted. (Richard Curnow) +Solution: Distribute a change in 'foldenable' to other diff windows. +Files: src/normal.c + +Patch 6.2.318 +Problem: When compiling with _THREAD_SAFE external commands don't echo + typed characters. +Solution: Don't set the terminal mode to TMODE_SLEEP when it's already at + TMODE_COOK. +Files: src/os_unix.c + +Patch 6.2.319 (extra) +Problem: Building gvimext.dll with Mingw doesn't work properly. +Solution: Use gcc instead of dllwrap. Use long option names. (Alejandro + Lopez-Valencia) +Files: src/GvimExt/Make_ming.mak + +Patch 6.2.320 +Problem: Win32: Adding and removing the menubar resizes the Vim window. + (Jonathon Merz) +Solution: Don't let a resize event change 'lines' unexpectedly. +Files: src/gui.c + +Patch 6.2.321 +Problem: When using modeless selection, wrapping lines are not recognized, + a line break is always inserted. +Solution: Add LineWraps[] to remember whether a line wrapped or not. +Files: src/globals.h, src/screen.c, src/ui.c + +Patch 6.2.322 +Problem: With 'showcmd' set, after typing "dd" the next "d" may not be + displayed. (Jens Paulus) +Solution: Redraw the command line after updating the screen, scrolling may + have set "clear_cmdline". +Files: src/screen.c + +Patch 6.2.323 +Problem: Win32: expanding "~/file" in an autocommand pattern results in + backslashes, while this pattern should only have forward slashes. +Solution: Make expanding environment variables respect 'shellslash' and set + p_ssl when expanding the autocommand pattern. +Files: src/fileio.c, src/misc1.c, src/proto/fileio.pro + +Patch 6.2.324 (extra) +Problem: Win32: when "vimrun.exe" has a path with white space, such as + "Program Files", executing external commands may fail. +Solution: Put double quotes around the path to "vimrun". +Files: src/os_win32.c + +Patch 6.2.325 +Problem: When $HOME includes a space, doing ":set tags=~/tags" doesn't + work, the space is used to separate file names. (Brett Stahlman) +Solution: Escape the space with a backslash. +Files: src/option.c + +Patch 6.2.326 +Problem: ":windo set syntax=foo" doesn't work. (Tim Chase) +Solution: Don't change 'eventignore' for ":windo". +Files: src/ex_cmds2.c + +Patch 6.2.327 +Problem: When formatting text all marks in the formatted lines are lost. + A word is not joined to a previous line when this would be + possible. (Mikolaj Machowski) +Solution: Try to keep marks in the same position as much as possible. + Also keep mark positions when joining lines. + Start auto-formatting in the previous line when appropriate. + Add the "gw" operator: Like "gq" but keep the cursor where it is. +Files: runtime/doc/change.txt, src/edit.c, src/globals.h, src/mark.c, + src/misc1.c, src/normal.c, src/ops.c, src/proto/edit.pro, + src/proto/mark.pro, src/proto/ops.pro, src/structs.h, src/vim.h + +Patch 6.2.328 +Problem: XIM with GTK: It is hard to understand what XIM is doing. +Solution: Add xim_log() to log XIM events and help with debugging. +Files: src/mbyte.c + +Patch 6.2.329 +Problem: ":=" does not work Vi compatible. (Antony Scriven) +Solution: Print the last line number instead of the current line. Don't + print "line". +Files: src/ex_cmds.h, src/ex_docmd.c + +Patch 6.2.330 (extra, after 6.2.267) +Problem: Win32: Crash when tearing off a menu. +Solution: Terminate a string with a NUL. (Yasuhiro Matsumoto) +Files: src/gui_w32.c + +Patch 6.2.331 (after 6.2.327) +Problem: "gwap" leaves cursor in the wrong line. +Solution: Remember the cursor position before finding the ends of the + paragraph. +Files: src/normal.c, src/ops.c, src/structs.h + +Patch 6.2.332 (extra) +Problem: Amiga: Compile error for string array. Compiling the Amiga GUI + doesn't work. +Solution: Use a char pointer instead. Move including "gui_amiga.h" to after + including "vim.h". Add a semicolon. (Ali Akcaagac) +Files: src/gui_amiga.c, src/os_amiga.c + +Patch 6.2.333 (extra) +Problem: Win32: printing doesn't work with specified font charset. +Solution: Use the specified font charset. (Mike Williams) +Files: src/os_mswin.c + +Patch 6.2.334 (extra, after 6.2.296) +Problem: Win32: evaluating client expression in debug mode requires typing + "cont". +Solution: Use eval_client_expr_to_string(). +Files: src/os_mswin.c + +Patch 6.2.335 +Problem: The ":sign" command cannot be followed by another command. +Solution: Add TRLBAR to the command flags. +Files: src/ex_cmds.h + +Patch 6.2.336 (after 6.2.327) +Problem: Mixup of items in an expression. +Solution: Move "== NUL" to the right spot. +Files: src/edit.c + +Patch 6.2.337 (extra, after 6.2.319) +Problem: Building gvimext.dll with Mingw doesn't work properly. +Solution: Fix white space and other details. (Alejandro Lopez-Valencia) +Files: src/GvimExt/Make_ming.mak + +Patch 6.2.338 (after 6.2.331) +Problem: When undoing "gwap" the cursor is always put at the start of the + paragraph. When undoing auto-formatting the cursor may be above + the change. +Solution: Try to move the cursor back to where it was or to the first line + that actually changed. +Files: src/normal.c, src/ops.c, src/undo.c + +Patch 6.2.339 +Problem: Crash when using many different highlight groups and a User + highlight group. (Juergen Kraemer) +Solution: Do not use the sg_name_u pointer when it is NULL. Also simplify + use of the highlight group table. +Files: src/syntax.c + +Patch 6.2.340 +Problem: ":reg" doesn't show the actual contents of the clipboard if it was + filled outside of Vim. (Stuart MacDonald) +Solution: Obtain the clipboard contents before displaying it. +Files: src/ops.c + +Patch 6.2.341 (extra) +Problem: Win32: When the path to diff.exe contains a space and using the + vimrc generated by the install program, diff mode does not work. +Solution: Put the first double quote just before the space instead of before + the path. +Files: src/dosinst.c + +Patch 6.2.342 (extra) +Problem: Win32: macros are not always used as expected. +Solution: Define WINVER to 0x0400 instead of 0x400. (Alejandro + Lopez-Valencia) +Files: src/Make_bc5.mak, src/Make_cyg.mak, src/Make_mvc.mak + +Patch 6.2.343 +Problem: Title doesn't work with some window managers. X11: Setting the + text property for the window title is hard coded. +Solution: Use STRING format when possible. Use the UTF-8 function when + it's available and 'encoding' is utf-8. Use + XStringListToTextProperty(). Do the same for the icon name. + (David Harrison) +Files: src/os_unix.c + +Patch 6.2.344 (extra, after 6.2.337) +Problem: Cannot build gvimext.dll with MingW on Linux. +Solution: Add support for cross compiling. (Ronald Hoellwarth) +Files: src/GvimExt/Make_ming.mak + +Patch 6.2.345 (extra) +Problem: Win32: Copy/paste between two Vims fails if 'encoding' is not set + properly or there are illegal bytes. +Solution: Use a raw byte format. Always set it when copying. When pasting + use the raw format if 'encoding' is the same. +Files: src/os_mswin.c, src/os_win16.c, src/os_win32.c, src/vim.h + +Patch 6.2.346 +Problem: Win32 console: After using "chcp" Vim does not detect the + different codepage. +Solution: Use GetConsoleCP() and when it is different from GetACP() set + 'termencoding'. +Files: src/option.c + +Patch 6.2.347 (extra) +Problem: Win32: XP theme support is missing. +Solution: Add a manifest and refer to it from the resource file. (Michael + Wookey) +Files: Makefile, src/gvim.exe.mnf, src/vim.rc + +Patch 6.2.348 +Problem: Win32: "vim c:\dir\(test)" doesn't work, because the 'isfname' + default value doesn't contain parenthesis. +Solution: Temporarily add '(' and ')' to 'isfname' when expanding file name + arguments. +Files: src/main.c + +Patch 6.2.349 +Problem: Finding a match using 'matchpairs' may cause a crash. + 'matchpairs' is not used for 'showmatch'. +Solution: Don't look past the NUL in 'matchpairs'. Use 'matchpairs' for + 'showmatch'. (Dave Olszewkski) +Files: src/misc1.c, src/normal.c, src/proto/search.pro, src/search.c + +Patch 6.2.350 +Problem: Not enough info about startup timing. +Solution: Add a few more TIME_MSG() calls. +Files: src/main.c + +Patch 6.2.351 +Problem: Win32: $HOME may be set to %USERPROFILE%. +Solution: Expand %VAR% at the start of $HOME. +Files: src/misc1.c + +Patch 6.2.352 (after 6.2.335) +Problem: ":sign texthl=||" does not work. +Solution: Remove the check for a following command. Give an error for extra + arguments after "buff=1". +Files: src/ex_cmds.c, src/ex_cmds.h + +Patch 6.2.353 (extra) +Problem: Win32: Supported server name length is limited. (Paul Bossi) +Solution: Use MAX_PATH instead of 25. +Files: src/os_mswin.c + +Patch 6.2.354 (extra) +Problem: Win32: When the mouse pointer is on a tear-off menu it is hidden + when typing but is not redisplayed when moved. (Markx Hackmann) +Solution: Handle the pointer move event for the tear-off menu window. +Files: src/gui_w32.c + +Patch 6.2.355 (after 6.2.303) +Problem: When 'encoding' is a double-byte encoding different from the + current locale, the width of characters is not correct. + Possible failure and memory leak when using iconv, Unicode + digraphs and 'encoding' is not "utf-8". +Solution: Use iconv() to discover the actual width of characters. + Add the "vc_fail" field to vimconv_T. + When converting a digraph, init the conversion type to NONE and + cleanup afterwards. +Files: src/digraph.c, src/mbyte.c, src/structs.h + +Patch 6.2.356 +Problem: When using a double-byte 'encoding' and 'selection' is + "exclusive", "vy" only yanks the first byte of a double-byte + character. (Xiangjiang Ma) +Solution: Correct the column in unadjust_for_sel() to position on the first + byte, always include the trailing byte of the selected text. +Files: src/normal.c + +Patch 6.2.357 (after 6.2.321) +Problem: Memory leak when resizing the Vim window. +Solution: Free the LineWraps array. +Files: src/screen.c + +Patch 6.2.358 (after 6.2.299) +Problem: Memory leak when using ":help" and the language doesn't match. +Solution: Free the array with matching tags. +Files: src/ex_cmds.c + +Patch 6.2.359 (after 6.2.352) +Problem: Compiler warning for long to int type cast. +Solution: Add explicit type cast. +Files: src/ex_cmds.c + +Patch 6.2.360 +Problem: "100|" in an empty line results in a ruler "1,0-100". (Pavol + Juhas) +Solution: Recompute w_virtcol if the target column was not reached. +Files: src/misc2.c + +Patch 6.2.361 (extra) +Problem: Win32: Run gvim, ":set go-=m", use Alt-Tab, keep Alt pressed while + pressing Esc, then release Alt: Cursor disappears and typing a key + causes a beep. (Hari Krishna Dara) +Solution: Don't ignore the WM_SYSKEYUP event when the menu is disabled. +Files: src/gui_w32.c + +Patch 6.2.362 (extra, after 6.2.347) +Problem: Win32: The manifest causes Gvim not to work. (Dave Roberts) +Solution: Change "x86" to "X86". (Serge Pirotte) +Files: src/gvim.exe.mnf + +Patch 6.2.363 +Problem: In an empty file with 'showmode' off, "i" doesn't change the ruler + from "0-1" to "1". Typing "x<BS>" does show "1", but then <Esc> + doesn't make it "0-1" again. Same problem for ruler in + statusline. (Andrew Pimlott) +Solution: Remember the "empty line" flag with Insert mode and'ed to it. +Files: src/screen.c + +Patch 6.2.364 +Problem: HTML version of the documentation doesn't mention the encoding, + which is a problem for mbyte.txt. +Solution: Adjust the awk script. (Ilya Sher) +Files: runtime/doc/makehtml.awk + +Patch 6.2.365 +Problem: The configure checks for Perl and Python may add compile and link + arguments that break building Vim. +Solution: Do a sanity check: try building with the arguments. +Files: src/auto/configure, src/configure.in + +Patch 6.2.366 +Problem: When the GUI can't start because no valid font is found, there is + no error message. (Ugen) +Solution: Add an error message. +Files: src/gui.c + +Patch 6.2.367 +Problem: Building the help tags file while installing may fail if there is + another Vim in $PATH. +Solution: Specify the just installed Vim executable. (Gordon Prieur) +Files: src/Makefile + +Patch 6.2.368 +Problem: When 'autochdir' is set, closing a window doesn't change to the + directory of the new current window. (Salman Halim) +Solution: Handle 'autochdir' always when a window becomes the current one. +Files: src/window.c + +Patch 6.2.369 +Problem: Various memory leaks: when using globpath(), when searching for + help tags files, when defining a function inside a function, when + giving an error message through an exception, for the final "." + line in ":append", in expression "cond ? a : b" that fails and for + missing ")" in an expression. Using NULL pointer when adding + first user command and for pointer computations with regexp. + (tests by Dominique Pelle) +Solution: Fix the leaks by freeing the allocated memory. Don't use the + array of user commands when there are no entries. Use a macro + instead of a function call for saving and restoring regexp states. +Files: src/eval.c, src/ex_cmds.c, src/ex_docmd.c, src/ex_getln.c, + src/misc2.c, src/regexp.c, src/screen.c, src/tag.c + +Patch 6.2.370 (extra, after6.2.341) +Problem: Win32: When the path to diff.exe contains a space and using the + vimrc generated by the install program, diff mode may not work. + (Alejandro Lopez-Valencia) +Solution: Do not use double quotes for arguments that do not have a space. +Files: src/dosinst.c + +Patch 6.2.371 +Problem: When 'virtualedit' is set and there is a Tab before the next "x", + "dtx" does not delete the whole Tab. (Ken Hashishi) +Solution: Move the cursor to the last position of the Tab. Also for + "df<Tab>". +Files: src/normal.c + +Patch 6.2.372 +Problem: When using balloon evaluation, no value is displayed for members + of structures and items of an array. +Solution: Include "->", "." and "[*]" in the expression. +Files: src/gui_beval.c, src/normal.c, src/vim.h + +Patch 6.2.373 +Problem: When 'winminheight' is zero and a window is reduced to zero + height, the ruler always says "Top" instead of the cursor + position. (Antoine J. Mechelynck) +Solution: Don't recompute w_topline for a zero-height window. +Files: src/window.c + +Patch 6.2.374 +Problem: ":echo "hello" | silent normal n" removes the "hello" message. + (Servatius Brandt) +Solution: Don't echo the search string when ":silent" was used. Also don't + show the mode. In general: don't clear to the end of the screen. +Files: src/gui.c, src/message.c, src/os_unix.c, src/proto/message.pro, + src/screen.c, src/search.c, src/window.c + +Patch 6.2.375 +Problem: When changing 'guioptions' the hit-enter prompt may be below the + end of the Vim window. +Solution: Call screen_alloc() before showing the prompt. +Files: src/message.c + +Patch 6.2.376 +Problem: Win32: Ruby interface cannot be dynamically linked with Ruby 1.6. +Solution: Add #ifdefs around use of rb_w32_snprintf(). (Benoît Cerrina) +Files: src/if_ruby.c + +Patch 6.2.377 (after 6.2.372) +Problem: Compiler warnings for signed/unsigned compare. (Michael Wookey) +Solution: Add type cast. +Files: src/normal.c + +Patch 6.2.378 (extra, after 6.2.118) +Problem: Mac: cannot build with Project Builder. +Solution: Add remove_tail_with_ext() to locate and remove the "build" + directory from the runtime path. Include os_unix.c when needed. + (Dany St Amant) +Files: src/misc1.c, src/os_macosx.c, src/vim.h + +Patch 6.2.379 +Problem: Using ":mkvimrc" in the ":options" window sets 'bufhidden' to + "delete". (Michael Naumann) +Solution: Do not add buffer-specific option values to a global vimrc file. +Files: src/option.c + +Patch 6.2.380 (extra) +Problem: DOS: "make test" fails when running it again. Can't "make test" + with Borland C. +Solution: Make sure ".out" files are deleted when they get in the way. Add + a "test" target to the Borland C Makefile. +Files: src/Make_bc5.mak, src/testdir/Make_dos.mak + +Patch 6.2.381 +Problem: Setting 'fileencoding' to a comma separated list (confusing it + with 'fileencodings') does not result in an error message. + Setting 'fileencoding' in an empty file marks it as modified. + There is no "+" in the title after setting 'fileencoding'. +Solution: Check for a comma in 'fileencoding'. Only consider a non-empty + file modified by changing 'fileencoding'. Update the title after + changing 'fileencoding'. +Files: src/option.c + +Patch 6.2.382 +Problem: Running "make test" puts marks from test files in viminfo. +Solution: Specify a different viminfo file to use. +Files: src/testdir/test15.in, src/testdir/test49.in + +Patch 6.2.383 +Problem: ":hi foo term='bla" crashes Vim. (Antony Scriven) +Solution: Check that the closing ' is there. +Files: src/syntax.c + +Patch 6.2.384 +Problem: ":menu a.&b" ":unmenu a.b" only works if "&b" isn't translated. +Solution: Also compare the names without '&' characters. +Files: src/menu.c + +Patch 6.2.385 (extra) +Problem: Win32: forward_slash() and trash_input_buf() are undefined when + compiling with small features. (Ajit Thakkar) +Solution: Change the #ifdefs for forward_slash(). Don't call + trash_input_buf() if the input buffer isn't used. +Files: src/fileio.c, src/os_win32.c + +Patch 6.2.386 +Problem: Wasting time trying to read marks from the viminfo file for a + buffer without a name. +Solution: Skip reading marks when the buffer has no name. +Files: src/fileio.c + +Patch 6.2.387 +Problem: There is no highlighting of translated items in help files. +Solution: Search for a "help_ab.vim" syntax file when the help file is + called "*.abx". Also improve the help highlighting a bit. +Files: runtime/syntax/help.vim + +Patch 6.2.388 +Problem: GTK: When displaying some double-width characters they are drawn + as single-width, because of conversion to UTF-8. +Solution: Check the width that GTK uses and add a space if it's one instead + of two. +Files: src/gui_gtk_x11.c + +Patch 6.2.389 +Problem: When working over a slow connection, it's very annoying that the + last line is partly drawn and then cleared for every change. +Solution: Don't redraw the bottom line if no rows were inserted or deleted. + Don't draw the line if we know "@" lines will be used. +Files: src/screen.c + +Patch 6.2.390 +Problem: Using "r*" in Visual mode on multi-byte characters only replaces + every other character. (Tyson Roberts) +Solution: Correct the cursor position after replacing each character. +Files: src/ops.c + +Patch 6.2.391 (extra) +Problem: The ":highlight" command is not tested. +Solution: Add a test script for ":highlight". +Files: src/testdir/Makefile, src/testdir/Make_amiga.mak, + src/testdir/Make_dos.mak, src/testdir/Make_os2.mak, + src/testdir/Make_vms.mms, src/testdir/test51.in, + src/testdir/test51.ok + +Patch 6.2.392 (after 6.2.384) +Problem: Unused variable. +Solution: Remove "dlen". +Files: src/menu.c + +Patch 6.2.393 +Problem: When using very long lines the viminfo file can become very big. +Solution: Add the "s" flag to 'viminfo': skip registers with more than the + specified Kbyte of text. +Files: runtime/doc/options.txt, src/ops.c, src/option.c + +Patch 6.2.394 (after 6.2.391) +Problem: Test 51 fails on a terminal with 8 colors. (Tony Leneis) +Solution: Use "DarkBlue" instead of "Blue" to avoid the "bold" attribute. +Files: src/testdir/test51.in + +Patch 6.2.395 +Problem: When using ":tag" or ":pop" the previous matching tag is used. + But since the current file is different, the ordering of the tags + may change. +Solution: Remember what the current buffer was for when re-using cur_match. +Files: src/edit.c, src/ex_cmds.c, src/proto/tag.pro, src/structs.h, + src/tag.c + +Patch 6.2.396 +Problem: When CTRL-T jumps to another file and an autocommand moves the + cursor to the '" mark, don't end up on the right line. (Michal + Malecki) +Solution: Set the line number after loading the file. +Files: src/tag.c + +Patch 6.2.397 +Problem: When using a double-byte 'encoding' mapping <M-x> doesn't work. + (Yasuhiro Matsumoto) +Solution: Do not set the 8th bit of the character but use a modifier. +Files: src/gui_gtk_x11.c, src/gui_x11.c, src/misc2.c + +Patch 6.2.398 (extra) +Problem: Win32 console: no extra key modifiers are supported. +Solution: Encode the modifiers into the input stream. Also fix that special + keys are converted and stop working when 'tenc' is set. Also fix + that when 'tenc' is initialized the input and output conversion is + not setup properly until 'enc' or 'tenc' is set. +Files: src/getchar.c, src/option.c, src/os_win32.c + +Patch 6.2.399 +Problem: A ":set" command that fails still writes a message when it is + inside a try/catch block. +Solution: Include all the text of the message in the error message. +Files: src/charset.c, src/option.c + +Patch 6.2.400 +Problem: Can't compile if_xcmdsrv.c on HP-UX 11.0. +Solution: Include header file poll.h. (Malte Neumann) +Files: src/if_xcmdsrv.c + +Patch 6.2.401 +Problem: When opening a buffer that was previously opened, Vim does not + restore the cursor position if the first line starts with white + space. (Gregory Margo) +Solution: Don't skip restoring the cursor position if it is past the blanks + in the first line. +Files: src/buffer.c + +Patch 6.2.402 +Problem: Mac: "make install" doesn't generate help tags. (Benji Fisher) +Solution: Generate help tags before copying the runtime files. +Files: src/Makefile + +Patch 6.2.403 +Problem: ":@y" checks stdin if there are more commands to execute. This + fails if stdin is not connected, e.g., when starting the GUI from + KDE. (Ned Konz) +Solution: Only check for a next command if there still is typeahead. +Files: src/ex_docmd.c + +Patch 6.2.404 +Problem: Our own function to determine width of Unicode characters may get + outdated. (Markus Kuhn) +Solution: Use wcwidth() when it is available. Also use iswprint(). +Files: src/auto/configure, src/configure.in, src/config.h.in, src/mbyte.c + +Patch 6.2.405 +Problem: Cannot map zero without breaking the count before a command. + (Benji Fisher) +Solution: Disable mapping zero when entering a count. +Files: src/getchar.c, src/globals.h, src/normal.c + +Patch 6.2.406 +Problem: ":help \zs", ":help \@=" and similar don't find useful help. +Solution: Prepend "/\" to the arguments to find the desired help tag. +Files: src/ex_cmds.c + +Patch 6.2.407 (after 6.2.299) +Problem: ":help \@<=" doesn't find help. +Solution: Avoid that ":help \@<=" searches for the "<=" language. +Files: src/tag.c + +Patch 6.2.408 +Problem: ":compiler" is not consistent: Sets local options and a global + variable. (Douglas Potts) There is no error message when a + compiler is not supported. +Solution: Use ":compiler!" to set a compiler globally, otherwise it's local + to the buffer and "b:current_compiler" is used. Give an error + when no compiler script could be found. + Note: updated compiler plugins can be found at + ftp://ftp.vim.org/pub/vim/runtime/compiler/ +Files: runtime/compiler/msvc.vim, runtime/doc/quickfix.txt, src/eval.c, + src/ex_cmds2.c + +Patch 6.2.409 +Problem: The cursor ends up in the last column instead of after the line + when doing "i//<Esc>o" with 'indentexpr' set to "cindent(v:lnum)". + (Toby Allsopp) +Solution: Adjust the cursor as if in Insert mode. +Files: src/misc1.c + +Patch 6.2.410 (after 6.2.389) +Problem: In diff mode, when there are more filler lines than fit in the + window, they are not drawn. +Solution: Check for filler lines when skipping to draw a line that doesn't + fit. +Files: src/screen.c + +Patch 6.2.411 +Problem: A "\n" inside a string is not seen as a line break by the regular + expression matching. (Hari Krishna Dara) +Solution: Add the vim_regexec_nl() function for strings where "\n" is to be + matched with a line break. +Files: src/eval.c, src/ex_eval.c, src/proto/regexp.c, src/regexp.c + +Patch 6.2.412 +Problem: Ruby: "ruby << EOF" inside a function doesn't always work. Also + for ":python", ":tcl" and ":perl". +Solution: Check for "<< marker" and skip until "marker" before checking for + "endfunction". +Files: src/eval.c + +Patch 6.2.413 (after 6.2.411) +Problem: Missing prototype for vim_regexec_nl(). (Marcel Svitalsky) +Solution: Now really include the prototype. +Files: src/proto/regexp.pro + +Patch 6.2.414 +Problem: The function used for custom completion of user commands cannot + have <SID> to make it local. (Hari Krishna Dara) +Solution: Pass the SID of the script where the user command was defined on + to the completion. Also clean up #ifdefs. +Files: src/ex_docmd.c, src/eval.c, src/ex_getln.c, src/structs.h + +Patch 6.2.415 +Problem: Vim may crash after a sequence of events that change the window + size. The window layout assumes a larger window than is actually + available. (Servatius Brandt) +Solution: Invoke win_new_shellsize() from screenalloc() instead of from + set_shellsize(). +Files: src/screen.c, src/term.c + +Patch 6.2.416 +Problem: Compiler warning for incompatible pointer. +Solution: Remove the "&" in the call to poll(). (Xavier de Gaye) +Files: src/os_unix.c + +Patch 6.2.417 (after 6.2.393) +Problem: Many people forget that the '"' item in 'viminfo' needs to be + preceded with a backslash, +Solution: Add '<' as an alias for the '"' item. +Files: runtime/doc/options.txt, src/ops.c, src/option.c + +Patch 6.2.418 +Problem: Using ":nnoremap <F12> :echo "cheese" and ":cabbr cheese xxx": + when pressing <F12> still uses the abbreviation. (Hari Krishna) +Solution: Also apply "noremap" to abbreviations. +Files: src/getchar.c + +Patch 6.2.419 (extra) +Problem: Win32: Cannot open the Vim window inside another application. +Solution: Add the "-P" argument to specify the window title of the + application to run inside. (Zibo Zhao) +Files: runtime/doc/starting.txt, src/main.c, src/gui_w32.c, + src/gui_w48.c, src/if_ole.cpp, src/os_mswin.c, + src/proto/gui_w32.pro + +Patch 6.2.420 +Problem: Cannot specify a file to be edited in binary mode without setting + the global value of the 'binary' option. +Solution: Support ":edit ++bin file". +Files: runtime/doc/editing.txt, src/buffer.c, src/eval.c, src/ex_cmds.h, + src/ex_docmd.c, src/fileio.c, src/misc2.c + +Patch 6.2.421 +Problem: Cannot set the '[ and '] mark, which may be necessary when an + autocommand simulates reading a file. +Solution: Allow using "m[" and "m]". +Files: runtime/doc/motion.txt, src/mark.c + +Patch 6.2.422 +Problem: In CTRL-X completion messages the "/" makes them less readable. +Solution: Remove the slashes. (Antony Scriven) +Files: src/edit.c + +Patch 6.2.423 +Problem: ":vertical wincmd ]" does not split vertically. +Solution: Add "postponed_split_flags". +Files: src/ex_docmd.c, src/globals.h, src/if_cscope.c, src/tag.c + +Patch 6.2.424 +Problem: A BufEnter autocommand that sets an option stops 'mousefocus' from + working in Insert mode (Normal mode is OK). (Gregory Seidman) +Solution: In the Insert mode loop invoke gui_mouse_correct() when needed. +Files: src/edit.c + +Patch 6.2.425 +Problem: Vertical split and command line window: can only drag status line + above the cmdline window on the righthand side, not lefthand side. +Solution: Check the status line row instead of the window pointer. +Files: src/ui.c + +Patch 6.2.426 +Problem: A syntax region end match with a matchgroup that includes a line + break only highlights the last line with matchgroup. (Gary + Holloway) +Solution: Also use the line number of the position where the region + highlighting ends. +Files: src/syntax.c + +Patch 6.2.427 (extra) +Problem: When pasting a lot of text in a multi-byte encoding, conversion + from 'termencoding' to 'encoding' may fail for some characters. + (Kuang-che Wu) +Solution: When there is an incomplete byte sequence at the end of the read + text keep it for the next time. +Files: src/mbyte.c, src/os_amiga.c, src/os_mswin.c, src/proto/mbyte.pro, + src/proto/os_mswin.pro, src/ui.c + +Patch 6.2.428 +Problem: The X11 clipboard supports the Vim selection for char/line/block + mode, but since the encoding is not included can't copy/paste + between two Vims with a different 'encoding'. +Solution: Add a new selection format that includes the 'encoding'. Perform + conversion when necessary. +Files: src/gui_gtk_x11.c, src/ui.c, src/vim.h + +Patch 6.2.429 +Problem: Unix: glob() doesn't work for a directory with a single quote in + the name. (Nazri Ramliy) +Solution: When using the shell to expand, only put double quotes around + spaces and single quotes, not the whole thing. +Files: src/os_unix.c + +Patch 6.2.430 +Problem: BOM at start of a vim script file is not recognized and causes an + error message. +Solution: Detect the BOM and skip over it. Also fix that after using + ":scriptencoding" the iconv() file descriptor was not closed + (memory leak). +Files: src/ex_cmds2.c + +Patch 6.2.431 +Problem: When using the horizontal scrollbar, the scrolling is limited to + the length of the cursor line. +Solution: Make the scroll limit depend on the longest visible line. The + cursor is moved when necessary. Including the 'h' flag in + 'guioptions' disables this. +Files: runtime/doc/gui.txt, runtime/doc/options.txt, src/gui.c, + src/misc2.c, src/option.h + +Patch 6.2.432 (after 6.2.430 and 6.2.431) +Problem: Lint warnings. +Solution: Add type casts. +Files: src/ex_cmds2.c, src/gui.c + +Patch 6.2.433 +Problem: Translating "VISUAL" and "BLOCK" separately doesn't give a good + result. (Alejandro Lopez Valencia) +Solution: Use a string for each combination. +Files: src/screen.c + +Patch 6.2.434 (after 6.2.431) +Problem: Compiler warning. (Salman Halim) +Solution: Add type casts. +Files: src/gui.c + +Patch 6.2.435 +Problem: When there are vertically split windows the minimal Vim window + height is computed wrong. +Solution: Use frame_minheight() to correctly compute the minimal height. +Files: src/window.c + +Patch 6.2.436 +Problem: Running the tests changes the user's viminfo file. +Solution: In test 49 tell the extra Vim to use the test viminfo file. +Files: src/testdir/test49.vim + +Patch 6.2.437 +Problem: ":mksession" always puts "set nocompatible" in the session file. + This changes option settings. (Ron Aaron) +Solution: Add an "if" to only change 'compatible' when needed. +Files: src/ex_docmd.c + +Patch 6.2.438 +Problem: When the 'v' flag is present in 'cpoptions', backspacing and then + typing text again: one character too much is overtyped before + inserting is done again. +Solution: Set "dollar_vcol" to the right column. +Files: src/edit.c + +Patch 6.2.439 +Problem: GTK 2: Changing 'lines' may cause a mismatch between the window + layout and the size of the window. +Solution: Disable the hack with force_shell_resize_idle(). +Files: src/gui_gtk_x11.c + +Patch 6.2.440 +Problem: When 'lazyredraw' is set the window title is still updated. + The size of the Visual area and the ruler are displayed too often. +Solution: Postpone redrawing the window title. Only show the Visual area + size when waiting for a character. Don't draw the ruler + unnecessary. +Files: src/buffer.c, src/normal.c, src/screen.c + +Patch 6.2.441 +Problem: ":unabbreviate foo " doesn't work, because of the trailing space, + while an abbreviation with a trailing space is not possible. (Paul + Jolly) +Solution: Accept a match with the lhs of an abbreviation without the + trailing space. +Files: src/getchar.c + +Patch 6.2.442 +Problem: Cannot manipulate the command line from a function. +Solution: Add getcmdline(), getcmdpos() and setcmdpos() functions and the + CTRL-\ e command. +Files: runtime/doc/cmdline.txt, runtime/doc/eval.txt, src/eval.c + src/ex_getln.c, src/ops.c, src/proto/ex_getln.pro, + src/proto/ops.pro + +Patch 6.2.443 +Problem: With ":silent! echoerr something" you don't get the position of + the error. emsg() only writes the message itself and returns. +Solution: Also redirect the position of the error. +Files: src/message.c + +Patch 6.2.444 +Problem: When adding the 'c' flag to a ":substitute" command it may replace + more times than without the 'c' flag. Happens for a match that + starts with "\ze" (Marcel Svitalsk) and when using "\@<=" (Klaus + Bosau). +Solution: Correct "prev_matchcol" when replacing the line. Don't replace + the line when the pattern uses look-behind matching. +Files: src/ex_cmds.c, src/proto/regexp.pro, src/regexp.c + +Patch 6.2.445 +Problem: Copying vimtutor to /tmp/something is not secure, a symlink may + cause trouble. +Solution: Create a directory and create the file in it. Use "umask" to + create the directory with mode 700. (Stefan Nordhausen) +Files: src/vimtutor + +Patch 6.2.446 (after 6.2.404) +Problem: Using library functions wcwidth() and iswprint() results in + display problems for Hebrew characters. (Ron Aaron) +Solution: Disable the code to use the library functions, use our own. +Files: src/mbyte.c + +Patch 6.2.447 (after 6.2.440) +Problem: Now that the title is only updated when redrawing, it is no longer + possible to show it while executing a function. (Madoka Machitani) +Solution: Make ":redraw" also update the title. +Files: src/ex_docmd.c + +Patch 6.2.448 (after 6.2.427) +Problem: Mac: conversion done when 'termencoding' differs from 'encoding' + fails when pasting a longer text. +Solution: Check for an incomplete sequence at the end of the chunk to be + converted. (Eckehard Berns) +Files: src/mbyte.c + +Patch 6.2.449 (after 6.2.431) +Problem: Get error messages when switching files. +Solution: Check for a valid line number when calculating the width of the + horizontal scrollbar. (Helmut Stiegler) +Files: src/gui.c + +Patch 6.2.450 +Problem: " #include" and " #define" are not recognized with the default + option values for 'include' and 'defined'. (RG Kiran) +Solution: Adjust the default values to allow white space before the #. +Files: runtime/doc/options.txt, src/option.c + +Patch 6.2.451 +Problem: GTK: when using XIM there are various problems, including setting + 'modified' and breaking undo at the wrong moment. +Solution: Add "xim_changed_while_preediting", "preedit_end_col" and + im_is_preediting(). (Yasuhiro Matsumoto) +Files: src/ex_getln.c, src/globals.h, src/gui_gtk.c, src/gui_gtk_x11.c, + src/mbyte.c, src/misc1.c, src/proto/mbyte.pro, src/screen.c, + src/undo.c + +Patch 6.2.452 +Problem: In diff mode, when DiffAdd and DiffText highlight settings are + equal, an added line is highlighted with DiffChange. (Tom Schumm) +Solution: Remember the diff highlight type instead of the attributes. +Files: src/screen.c + +Patch 6.2.453 +Problem: ":s/foo\|\nbar/x/g" does not replace two times in "foo\nbar". + (Pavel Papushev) +Solution: When the pattern can match a line break also try matching at the + NUL at the end of a line. +Files: src/ex_cmds.c, src/regexp.c + +Patch 6.2.454 +Problem: ":let b:changedtick" doesn't work. (Alan Schmitt) ":let + b:changedtick = 99" does not give an error message. +Solution: Add code to recognize ":let b:changedtick". +Files: src/eval.c + +Patch 6.2.455 (after 6.2.297) +Problem: In Python commands the current locale changes how certain Python + functions work. (Eugene M. Minkovskii) +Solution: Set the LC_NUMERIC locale to "C" while executing a Python command. +Files: src/if_python.c + +Patch 6.2.456 (extra) +Problem: Win32: Editing a file by its Unicode name (dropping it on Vim or + using the file selection dialog) doesn't work. (Yakov Lerner, Alex + Jakushev) +Solution: Use wide character functions when file names are involved and + convert from/to 'encoding' where needed. +Files: src/gui_w48.c, src/macros.h, src/memfile.c, src/memline.c, + src/os_mswin.c, src/os_win32.c + +Patch 6.2.457 (after 6.2.244) +Problem: When 'encoding' is "utf-8" and writing text with chars above 0x80 + in latin1, conversion is wrong every 8200 bytes. (Oyvind Holm) +Solution: Correct the utf_ptr2len_check_len() function and fix the problem + of displaying 0xf7 in utfc_ptr2len_check_len(). +Files: src/mbyte.c + +Patch 6.2.458 +Problem: When 'virtualedit' is set "$" doesn't move to the end of an + unprintable character, causing "y$" not to include that character. + (Fred Ma) +Solution: Set "coladd" to move the cursor to the end of the character. +Files: src/misc2.c + +Patch 6.2.459 (after 6.2.454) +Problem: Variable "b" cannot be written. (Salman Halim) +Solution: Compare strings properly. +Files: src/eval.c + +Patch 6.2.460 (extra, after 6.2.456) +Problem: Compiler warnings for missing prototypes. +Solution: Include the missing prototypes. +Files: src/proto/os_win32.pro + +Patch 6.2.461 +Problem: After using a search command "x" starts putting single characters + in the numbered registers. +Solution: Reset "use_reg_one" at the right moment. +Files: src/normal.c + +Patch 6.2.462 +Problem: Finding a matching parenthesis does not correctly handle a + backslash in a trailing byte. +Solution: Handle multi-byte characters correctly. (Taro Muraoka) +Files: src/search.c + +Patch 6.2.463 (extra) +Problem: Win32: An NTFS file system may contain files with extra info + streams. The current method to copy them creates one and then + deletes it again. (Peter Toennies) Also, only three streams with + hard coded names are copied. +Solution: Use BackupRead() to check which info streams the original file + contains and only copy these streams. +Files: src/os_win32.c + +Patch 6.2.464 (extra, after 6.2.427) +Problem: Amiga: Compilation error with gcc. (Ali Akcaagac) +Solution: Move the #ifdef outside of Read(). +Files: src/os_amiga.c + +Patch 6.2.465 +Problem: When resizing the GUI window the window manager sometimes moves it + left of or above the screen. (Michael McCarty) +Solution: Check the window position after resizing it and move it onto the + screen when it isn't. +Files: src/gui.c + +Patch 6.2.466 (extra, after 6.2.456) +Problem: Win32: Compiling with Borland C fails, and an un/signed warning. +Solution: Redefine wcsicmp() to wcscmpi() and add type casts. (Yasuhiro + Matsumoto) +Files: src/os_win32.c + +Patch 6.2.467 (extra, after 6.2.463) +Problem: Win32: can't compile without multi-byte feature. (Ajit Thakkar) +Solution: Add #ifdefs around the info stream code. +Files: src/os_win32.c + +Patch 6.2.468 +Problem: Compiler warnings for shadowed variables. (Matthias Mohr) +Solution: Delete superfluous variables and rename others. +Files: src/eval.c, src/ex_docmd.c, src/ex_eval.c, src/if_cscope.c, + src/fold.c, src/option.c, src/os_unix.c, src/quickfix.c, + src/regexp.c + +Patch 6.2.469 (extra, after 6.2.456) +Problem: Win32: Can't create swap file when 'encoding' differs from the + active code page. (Kriton Kyrimis) +Solution: In enc_to_ucs2() terminate the converted string with a NUL +Files: src/os_mswin.c + +Patch 6.2.470 +Problem: The name returned by tempname() may be equal to the file used for + shell output when ignoring case. +Solution: Skip 'O' and 'I' in tempname(). +Files: src/eval.c + +Patch 6.2.471 +Problem: "-L/usr/lib" is used in the link command, even though it's + supposed to be filtered out. "-lw" and "-ldl" are not + automatically added when needed for "-lXmu". (Antonio Colombo) +Solution: Check for a space after the argument instead of before. Also + remove "-R/usr/lib" if it's there. Check for "-lw" and "-ldl" + before trying "-lXmu". +Files: src/auto/configure, src/configure.in, src/link.sh + +Patch 6.2.472 +Problem: When using a FileChangedShell autocommand that changes the current + buffer, a buffer exists that can't be wiped out. + Also, Vim sometimes crashes when executing an external command + that changes the buffer and a FileChangedShell autocommand is + used. (Hari Krishna Dara) + Users are confused by the warning for a file being changed outside + of Vim. +Solution: Avoid that the window counter for a buffer is incremented twice. + Avoid that buf_check_timestamp() is used recursively. + Add a hint to look in the help for more info. +Files: src/ex_cmds.c, src/fileio.c + +Patch 6.2.473 +Problem: Using CTRL-] in a help buffer without a name causes a crash. +Solution: Check for name to be present before using it. (Taro Muraoka) +Files: src/tag.c + +Patch 6.2.474 (extra, after 6.2.456) +Problem: When Vim is starting up conversion is done unnecessarily. Failure + to find the runtime files on Windows 98. (Randall W. Morris) +Solution: Init enc_codepage negative, only use it when not negative. + Don't use GetFileAttributesW() on Windows 98 or earlier. +Files: src/globals.h, src/gui_w32.c, src/gui_w48.c, src/os_mswin.c, + src/os_win32.c + +Patch 6.2.475 +Problem: Commands after "perl <<EOF" are parsed as Vim commands when they + are not executed. +Solution: Properly skip over the perl commands. +Files: src/ex_docmd.c, src/ex_getln.c, src/if_perl.xs, src/if_python.c, + src/if_ruby.c, src/if_tcl.c, src/misc2.c + +Patch 6.2.476 +Problem: When reloading a hidden buffer changed outside of Vim and the + current buffer is read-only, the reloaded buffer becomes + read-only. (Hari Krishna Dara) +Solution: Save the 'readonly' flag of the reloaded buffer instead of the + current buffer. +Files: src/fileio.c + +Patch 6.2.477 +Problem: Using remote_send(v:servername, "\<C-V>") causes Vim to hang. + (Yakov Lerner) +Solution: When the resulting string is empty don't set received_from_client. +Files: src/main.c + +Patch 6.2.478 +Problem: Win32: "--remote file" fails changing directory if the current + directory name starts with a single quote. (Iestyn Walters) +Solution: Add a backslash where it will be removed later. +Files: src/main.c, src/misc2.c, src/proto/misc2.pro + +Patch 6.2.479 +Problem: The error message for errors during recovery goes unnoticed. +Solution: Avoid that the hit-enter prompt overwrites the message. Add a few + lines to make the error stand out. +Files: src/main.c, src/message.c, src/memline.c + +Patch 6.2.480 +Problem: NetBeans: Using negative index in array. backslash at end of + message may cause Vim to crash. (Xavier de Gaye) +Solution: Initialize buf_list_used to zero. Check for trailing backslash. +Files: src/netbeans.c + +Patch 6.2.481 +Problem: When writing a file it is not possible to specify that hard and/or + symlinks are to be broken instead of preserved. +Solution: Add the "breaksymlink" and "breakhardlink" values to 'backupcopy'. + (Simon Ekstrand) +Files: runtime/doc/options.txt, src/fileio.c, src/option.c, src/option.h + +Patch 6.2.482 +Problem: Repeating insert of CTRL-K 1 S doesn't work. The superscript 1 is + considered to be a digit. (Juergen Kraemer) +Solution: In vim_isdigit() only accept '0' to '9'. Use VIM_ISDIGIT() for + speed where possible. Also add vim_isxdigit(). +Files: src/buffer.c, src/charset.c, src/diff.c, src/digraph.c, + src/edit.c, src/eval.c,, src/ex_cmds.c, src/ex_cmds2.c, + src/ex_docmd.c, src/ex_eval.c, src/ex_getln.c, + src/if_xcmdsrv.c, src/farsi.c, src/fileio.c, src/fold.c, + src/getchar.c, src/gui.c, src/if_cscope.c, src/macros.h, + src/main.c, src/mark.c, src/mbyte.c, src/menu.c, src/misc1.c, + src/misc2.c, src/normal.c, src/ops.c, src/option.c, + src/proto/charset.pro, src/regexp.c, src/screen.c, src/search.c, + src/syntax.c, src/tag.c, src/term.c, src/termlib.c + +Patch 6.2.483 (extra, after 6.2.482) +Problem: See 6.2.482. +Solution: Extra part of patch 6.2.482. +Files: src/gui_photon.c, src/gui_w48.c, src/os_msdos.c, src/os_mswin.c + +Patch 6.2.484 +Problem: MS-Windows: With the included diff.exe, differences after a CTRL-Z + are not recognized. (Peter Keresztes) +Solution: Write the files with unix fileformat and invoke diff with --binary + if possible. +Files: src/diff.c + +Patch 6.2.485 +Problem: A BufWriteCmd autocommand cannot know if "!" was used or not. + (Hari Krishna Dara) +Solution: Add the v:cmdbang variable. +Files: runtime/doc/eval.txt, src/eval.c, src/proto/eval.pro, + src/fileio.c, src/vim.h + +Patch 6.2.486 (6.2.482) +Problem: Diff for eval.c is missing. +Solution: Addition to patch 6.2.482. +Files: src/eval.c + +Patch 6.2.487 (extra, after 6.2.456) +Problem: Compiler warnings for wrong prototype. (Alejandro Lopez Valencia) +Solution: Delete the prototype for Handle_WM_Notify(). +Files: src/proto/gui_w32.pro + +Patch 6.2.488 +Problem: Missing ")" in *.ch filetype detection. +Solution: Add the ")". (Ciaran McCreesh) +Files: runtime/filetype.vim + +Patch 6.2.489 +Problem: When accidentally opening a session in Vim which has already been + opened in another Vim there is a long row of ATTENTION prompts. + Need to quit each of them to get out. (Robert Webb) +Solution: Add the "Abort" alternative to the dialog. +Files: src/memline.c + +Patch 6.2.490 +Problem: With 'paragraph' it is not possible to use a single dot as a + paragraph boundary. (Dorai Sitaram) +Solution: Allow using " " (two spaces) in 'paragraph' to match ".$" or + ". $" +Files: src/search.c + +Patch 6.2.491 +Problem: Decrementing a position doesn't take care of multi-byte chars. +Solution: Adjust the column for multi-byte characters. Remove mb_dec(). + (Yasuhiro Matsumoto) +Files: src/mbyte.c, src/misc2.c, src/proto/mbyte.pro + +Patch 6.2.492 +Problem: When using ":redraw" while there is a message, the next ":echo" + still causes text to scroll. (Yasuhiro Matsumoto) +Solution: Reset msg_didout and msg_col, so that after ":redraw" the next + message overwrites an existing one. +Files: src/ex_docmd.c + +Patch 6.2.493 +Problem: "@x" doesn't work when 'insertmode' is set. (Benji Fisher) +Solution: Put "restart_edit" in the typeahead buffer, so that it's used + after executing the register contents. +Files: src/ops.c + +Patch 6.2.494 +Problem: Using diff mode with two windows, when moving horizontally in + inserted lines, a fold in the other window may open. +Solution: Compute the line number in the other window correctly. +Files: src/diff.c + +Patch 6.2.495 (extra, after 6.2.456) +Problem: Win32: The file dialog doesn't work on Windows 95. +Solution: Put the wide code of gui_mch_browse() in gui_mch_browseW() and use + it only on Windows NT/2000/XP. +Files: src/gui_w32.c, src/gui_w48.c + +Patch 6.2.496 +Problem: FreeBSD 4.x: When compiled with the pthread library (Python) a + complicated pattern may cause Vim to crash. Catching the signal + doesn't work. +Solution: When compiled with threads, instead of using the normal stacksize + limit, use the size of the initial stack. +Files: src/auto/configure, src/config.h.in, src/configure.in, + src/os_unix.c + +Patch 6.2.497 (extra) +Problem: Russian messages are only available in one encoding. +Solution: Convert the messages to MS-Windows codepages. (Vassily Ragosin) +Files: src/po/Makefile + +Patch 6.2.498 +Problem: Non-latin1 help files are not properly supported. +Solution: Support utf-8 help files and convert them to 'encoding' when + needed. +Files: src/fileio.c + +Patch 6.2.499 +Problem: When writing a file and halting the system, the file might be lost + when using a journaling file system. +Solution: Use fsync() to flush the file data to disk after writing a file. + (Radim Kolar) +Files: src/fileio.c + +Patch 6.2.500 (extra) +Problem: The DOS/MS-Windows the installer doesn't use the --binary flag for + diff. +Solution: Add --binary to the diff argument in MyDiff(). (Alejandro Lopez- + Valencia) +Files: src/dosinst.c + +Patch 6.2.501 +Problem: Vim does not compile with MorphOS. +Solution: Add a Makefile and a few changes to make Vim work with MorphOS. + (Ali Akcaagac) +Files: runtime/doc/os_amiga.txt, src/INSTALLami.txt, + src/Make_morphos.mak, src/memfile.c, src/term.c + +Patch 6.2.502 +Problem: Building fails for generating message files. +Solution: Add dummy message files. +Files: src/po/ca.po, src/po/ru.po, src/po/sv.po + +Patch 6.2.503 +Problem: Mac: Can't compile MacRoman conversions without the GUI. +Solution: Also link with the Carbon framework for the terminal version, for + the MacRoman conversion functions. (Eckehard Berns) + Remove -ltermcap from the GUI link command, it is not needed. +Files: src/auto/configure, src/Makefile, src/configure.in + +Patch 6.2.504 +Problem: Various problems with 'cindent', among which that a + list of variable declarations is not indented properly. +Solution: Fix the wrong indenting. Improve indenting of C++ methods. + Add the 'i', 'b' and 'W' options to 'cinoptions'. (mostly by + Helmut Stiegler) + Improve indenting of preprocessor-continuation lines. +Files: runtime/doc/indent.txt, src/misc1.c, src/testdir/test3.in, + src/testdir/test3.ok + +Patch 6.2.505 +Problem: Help for -P argument is missing. (Ronald Hoellwarth) +Solution: Add the patch that was missing in 6.2.419. +Files: runtime/doc/starting.txt + +Patch 6.2.506 (extra) +Problem: Win32: When 'encoding' is a codepage then reading a utf-8 file + only works when iconv is available. Writing a file in another + codepage uses the wrong kind of conversion. +Solution: Use internal conversion functions. Enable reading and writing + files with 'fileencoding' different from 'encoding' for all valid + codepages and utf-8 without the need for iconv. +Files: src/fileio.c, src/testdir/Make_dos.mak, src/testdir/test52.in, + src/testdir/test52.ok + +Patch 6.2.507 +Problem: The ownership of the file with the password for the NetBeans + connection is not checked. "-nb={file}" doesn't work for GTK. +Solution: Only accept the file when owned by the user and not accessible by + others. Detect "-nb=" for GTK. +Files: src/netbeans.c, src/gui_gtk_x11.c + +Patch 6.2.508 +Problem: Win32: "v:lang" does not show the current language for messages if + it differs from the other locale settings. +Solution: Use the value of the $LC_MESSAGES environment variable. +Files: src/ex_cmds2.c + +Patch 6.2.509 (after 6.2.508) +Problem: Crash when $LANG is not set. +Solution: Add check for NULL pointer. (Ron Aaron) +Files: src/ex_cmds2.c + +Patch 6.2.510 (after 6.2.507) +Problem: Warning for pointer conversion. +Solution: Add a type cast. +Files: src/gui_gtk_x11.c + +Patch 6.2.511 +Problem: Tags in Russian help files are in utf-8 encoding, which may be + different from 'encoding'. +Solution: Use the "TAG_FILE_ENCODING" field in the tags file to specify the + encoding of the tags. Convert help tags from 'encoding' to the + tag file encoding when searching for matches, do the reverse when + listing help tags. +Files: runtime/doc/tagsrch.txt, src/ex_cmds.c, src/tag.c + +Patch 6.2.512 +Problem: Translating "\"\n" is useless. (Gerfried Fuchs) +Solution: Remove the _() around it. +Files: src/main.c, src/memline.c + +Patch 6.2.513 (after 6.2.507) +Problem: NetBeans: the check for owning the connection info file can be + simplified. (Nikolay Molchanov) +Solution: Only check if the access mode is right. +Files: src/netbeans.c + +Patch 6.2.514 +Problem: When a highlight/syntax group name contains invalid characters + there is no warning. +Solution: Add an error for unprintable characters and a warning for other + invalid characters. +Files: src/syntax.c + +Patch 6.2.515 +Problem: When using the options window 'swapfile' is reset. +Solution: Use ":setlocal" instead of ":set". +Files: runtime/optwin.vim + +Patch 6.2.516 +Problem: The sign column cannot be seen, looks like there are two spaces + before the text. (Rob Retter) +Solution: Add the SignColumn highlight group. +Files: runtime/doc/options.txt, runtime/doc/sign.txt, src/option.c, + src/screen.c, src/syntax.c, src/vim.h + +Patch 6.2.517 +Problem: Using "r*" in Visual mode on multi-byte characters replaces + too many characters. In Visual Block mode replacing with a + multi-byte character doesn't work. +Solution: Adjust the operator end for the difference in byte length of the + original and the replaced character. Insert all bytes of a + multi-byte character, take care of double-wide characters. +Files: src/ops.c + +Patch 6.2.518 +Problem: Last line of a window is not updated after using "J" and then "D". + (Adri Verhoef) +Solution: When no line is found below a change that doesn't need updating, + update all lines below the change. +Files: src/screen.c + +Patch 6.2.519 +Problem: Mac: cannot read/write files in MacRoman format. +Solution: Do internal conversion from/to MacRoman to/from utf-8 and latin1. + (Eckehard Berns) +Files: src/fileio.c + +Patch 6.2.520 (extra) +Problem: The NSIS installer is outdated. +Solution: Make it work with NSIS 2.0. Also include console executables for + Win 95/98/ME and Win NT/2000/XP. Use LZWA compression. Use + "/oname" to avoid having to rename files before running NSIS. +Files: Makefile, nsis/gvim.nsi + +Patch 6.2.521 +Problem: When using silent Ex mode the "changing a readonly file" warning + is omitted but the one second wait isn't. (Yakov Lerner) +Solution: Skip the delay when "silent_mode" is set. +Files: src/misc1.c + +Patch 6.2.522 +Problem: GUI: when changing 'cmdheight' in the gvimrc file the window + layout is messed up. (Keith Dart) +Solution: Skip updating the window layout when changing 'cmdheight' while + still starting up. +Files: src/option.c + +Patch 6.2.523 +Problem: When loading a session and aborting when a swap file already + exists, the user is left with useless windows. (Robert Webb) +Solution: Load one file before creating the windows. +Files: src/ex_docmd.c + +Patch 6.2.524 (extra, after 6.2.520) +Problem: Win32: (un)installing gvimext.dll may fail if it was used. + The desktop and start menu links are created for the current user + instead of all users. + Using the home directory as working directory for the links is a + bad idea for multi-user systems. + Cannot use Vim from the "Open With..." menu. +Solution: Force a reboot if necessary. (Alejandro Lopez-Valencia) Also use + macros for the directory of the source and runtime files. Use + "CSIDL_COMMON_*" instead of "CSIDL_*" when possible. + Do not specify a working directory in the links. + Add Vim to the "Open With..." menu. (Giuseppe Bilotta) +Files: nsis/gvim.nsi, src/dosinst.c, src/dosinst.h, src/uninstal.c + +Patch 6.2.525 +Problem: When the history contains a very long line ":history" causes a + crash. (Volker Kiefel) +Solution: Shorten the history entry to fit it in one line. +Files: src/ex_getln.c + +Patch 6.2.526 +Problem: When s:lang is "ja" the Japanese menus are not used. +Solution: Add 'encoding' to the language when there is no charset. +Files: runtime/menu.vim + +Patch 6.2.527 +Problem: The 2html script uses ":wincmd p", which breaks when using some + autocommands. +Solution: Remember the window numbers and jump to them with ":wincmd w". + Also add XHTML support. (Panagiotis Issaris) +Files: runtime/syntax/2html.vim + +Patch 6.2.528 +Problem: NetBeans: Changes of the "~" command are not reported. +Solution: Call netbeans_inserted() after performing "~". (Gordon Prieur) + Also change NetBeans debugging to append to the log file. + Also fix that "~" in Visual block mode changes too much if there + are multi-byte characters. +Files: src/nbdebug.c, src/normal.c, src/ops.c + +Patch 6.2.529 (extra) +Problem: VisVim only works for Admin. Doing it for one user doesn't work. + (Alexandre Gouraud) +Solution: When registering the module fails, simply continue. +Files: src/VisVim/VisVim.cpp + +Patch 6.2.530 +Problem: Warning for missing prototype on the Amiga. +Solution: Include time.h +Files: src/version.c + +Patch 6.2.531 +Problem: In silent ex mode no messages are given, which makes debugging + very difficult. +Solution: Do output messages when 'verbose' is set. +Files: src/message.c, src/ui.c + +Patch 6.2.532 (extra) +Problem: Compiling for Win32s with VC 4.1 doesn't work. +Solution: Don't use CP_UTF8 if it's not defined. Don't use CSIDL_COMMON* + when not defined. +Files: src/dosinst.h, src/fileio.c + +Win32 console: After patch 6.2.398 Ex mode did not work. (Yasuhiro Matsumoto) + +Patch 6.3a.001 +Problem: Win32: if testing for the "--binary" option fails, diff isn't used + at all. +Solution: Handle the "ok" flag properly. (Yasuhiro Matsumoto) +Files: src/diff.c + +Patch 6.3a.002 +Problem: NetBeans: An insert command from NetBeans beyond the end of a + buffer crashes Vim. (Xavier de Gaye) +Solution: Use a local pos_T structure for the position. +Files: src/netbeans.c + +Patch 6.3a.003 +Problem: E315 error with auto-formatting comments. (Henry Van Roessel) +Solution: Pass the line number to same_leader(). +Files: src/ops.c + +Patch 6.3a.004 +Problem: Test32 fails on Windows XP for the DJGPP version. Renaming + test11.out fails. +Solution: Don't try renaming, create new files to use for the test. +Files: src/testdir/test32.in, src/testdir/test32.ok + +Patch 6.3a.005 +Problem: ":checkpath!" does not use 'includeexpr'. +Solution: Use a file name that was found directly. When a file was not + found and the located name is empty, use the rest of the line. +Files: src/search.c + +Patch 6.3a.006 +Problem: "yip" moves the cursor to the first yanked line, but not to the + first column. Looks like not all text was yanked. (Jens Paulus) +Solution: Move the cursor to the first column. +Files: src/search.c + +Patch 6.3a.007 +Problem: 'cindent' recognizes "enum" but not "typedef enum". +Solution: Skip over "typedef" before checking for "enum". (Helmut Stiegler) + Also avoid that searching for this item goes too far back. +Files: src/misc1.c, src/testdir/test3.in, src/testdir/test3.ok + +Patch 6.3a.008 (extra) +Problem: Windows 98: Some of the wide functions are not implemented, + resulting in file I/O to fail. This depends on what Unicode + support is installed. +Solution: Handle the failure and fall back to non-wide functions. +Files: src/os_win32.c + +Patch 6.3a.009 +Problem: Win32: Completion of filenames does not work properly when + 'encoding' differs from the active code page. +Solution: Use wide functions for expanding wildcards when appropriate. +Files: src/misc1.c + +Patch 6.3a.010 (extra) +Problem: Win32: Characters in the window title that do not appear in the + active codepage are replaced by a question mark. +Solution: Use DefWindowProcW() instead of DefWindowProc() when possible. +Files: src/glbl_ime.cpp, src/globals.h, src/proto/gui_w16.pro, + src/proto/gui_w32.pro, src/gui_w16.c, src/gui_w32.c, src/gui_w48.c + +Patch 6.3a.011 +Problem: Using the explorer plugin changes a local directory to the global + directory. +Solution: Don't use ":chdir" to restore the current directory. Make + "expand('%:p')" remove "/../" and "/./" items from the path. +Files: runtime/plugin/explorer.vim, src/eval.c, src/os_unix.c + +Patch 6.3a.012 (extra) +Problem: On Windows 98 the installer doesn't work, don't even get the "I + agree" button. The check for the path ending in "vim" makes the + browse dialog hard to use. The default path when no previous Vim + is installed is "c:\vim" instead of "c:\Program Files\Vim". +Solution: Remove the background gradient command. Change the + .onVerifyInstDir function to a leave function for the directory + page. Don't let the install program default to c:\vim when no + path could be found. +Files: nsis/gvim.nsi, src/dosinst.c + +Patch 6.3a.013 (extra) +Problem: Win32: Characters in the menu that are not in the active codepage + are garbled. +Solution: Convert menu strings from 'encoding' to the active codepage. +Files: src/gui_w32.c, src/gui_w48.c + +Patch 6.3a.014 +Problem: Using multi-byte text and highlighting in a statusline causes gaps + to appear. (Helmut Stiegler) +Solution: Advance the column by text width instead of number of bytes. Add + the vim_strnsize() function. +Files: src/charset.c, src/proto/charset.pro, src/screen.c + +Patch 6.3a.015 +Problem: Using the "select all" menu item when 'insertmode' is set and + clicking the mouse button doesn't return to Insert mode. The + Buffers/Delete menu doesn't offer a choice to abandon a changed + buffer. (Jens Paulus) +Solution: Don't use CTRL-\ CTRL-N. Add ":confirm" for the Buffers menu + items. +Files: runtime/menu.vim + +Patch 6.3a.016 +Problem: After cancelling the ":confirm" dialog the error message and + hit-enter prompt may not be displayed properly. +Solution: Flush output after showing the dialog. +Files: src/message.c + +Patch 6.3a.017 +Problem: servername() doesn't work when Vim was started with the "-X" + argument or when the "exclude" in 'clipboard' matches the terminal + name. (Robert Nowotniak) +Solution: Force connecting to the X server when using client-server + commands. +Files: src/eval.c, src/globals.h, src/os_unix.c + +Patch 6.3a.018 (after 6.3a.017) +Problem: Compiler warning for return value of make_connection(). +Solution: Use void return type. +Files: src/eval.c + +Patch 6.3a.019 (extra) +Problem: Win32: typing non-latin1 characters doesn't work. +Solution: Invoke _OnChar() directly to avoid that the argument is truncated + to a byte. Convert the UTF-16 character to bytes according to + 'encoding' and ignore 'termencoding'. Same for _OnSysChar(). +Files: src/gui_w32.c, src/gui_w48.c + +Patch 6.3a.020 (extra) +Problem: Missing support for AROS (AmigaOS reimplementation). Amiga GUI + doesn't work. +Solution: Add AROS support. (Adam Chodorowski) + Fix Amiga GUI problems. (Georg Steger, Ali Akcaagac) +Files: Makefile, src/Make_aros.mak, src/gui_amiga.c, src/gui_amiga.h, + src/memfile.c, src/os_amiga.c, src/term.c + +Patch 6.3a.021 (after 6.3a.017) +Problem: Can't compile with X11 but without GUI. +Solution: Put use of "gui.in_use" inside an #ifdef. +Files: src/eval.c + +Patch 6.3a.022 +Problem: When typing Tabs when 'softtabstop' is used and 'list' is set a + tab is counted for two spaces. +Solution: Use the "L" flag in 'cpoptions' to tell whether a tab is counted + as two spaces or as 'tabstop'. (Antony Scriven) +Files: runtime/doc/options.txt, src/edit.c + +Patch 6.3a.023 +Problem: Completion on the command line doesn't handle backslashes + properly. Only the tail of matches is shown, even when not + completing filenames. +Solution: When turning the string into a pattern double backslashes. Don't + omit the path when not expanding files or directories. +Files: src/ex_getln.c + +Patch 6.3a.024 +Problem: The "save all" toolbar item fails for buffers that don't have a + name. When using ":wa" or closing the Vim window and there are + nameless buffers, browsing for a name may cause the name being + given to the wrong buffer or not stored properly. ":browse" only + worked for one file. +Solution: Use ":confirm browse" for "save all". + Pass buffer argument to setfname(). Restore "browse" flag and + "forceit" after doing the work for one file. +Files: runtime/menu.vim, src/buffer.c, src/ex_cmds.c, src/ex_cmds2.c, + src/ex_docmd.c, src/ex_getln.c, src/fileio.c, src/memline.c, + src/message.c, src/window.c, src/proto/buffer.pro, + src/proto/ex_cmds2.pro, src/proto/memline.pro + +Patch 6.3a.025 +Problem: Setting 'virtualedit' moves the cursor. (Benji Fisher) +Solution: Update the virtual column before using it. +Files: src/option.c + +Patch 6.3a.026 (extra, after 6.3a.008) +Problem: Editing files on Windows 98 doesn't work when 'encoding' is + "utf-8" (Antoine Mechelynck) + Warning for missing function prototype. +Solution: For all wide functions check if it failed because it is not + implemented. Use ANSI function declaration for char_to_string(). +Files: src/gui_w48.c, src/os_mswin.c, src/os_win32.c + +Patch 6.3a.027 (extra, after 6.3a.026) +Problem: Compiler warning for function argument. +Solution: Declare both char and WCHAR arrays. +Files: src/gui_w48.c + +Patch 6.3a.028 +Problem: ":normal ." doesn't work inside a function, because redo is saved + and restored. (Benji Fisher) +Solution: Make a copy of the redo buffer when executing a function. +Files: src/getchar.c + +Patch 6.3b.001 (extra) +Problem: Bcc 5: The generated auto/pathdef can't be compiled. +Solution: Fix the way quotes and backslashes are escaped. +Files: src/Make_bc5.mak + +Patch 6.3b.002 +Problem: Win32: conversion during file write fails when a double-byte + character is split over two writes. +Solution: Fix the conversion retry without a trailing byte. (Taro Muraoka) +Files: src/fileio.c + +Patch 6.3b.003 (extra) +Problem: Win32: When compiling with Borland C 5.5 and 'encoding' is "utf-8" + then Vim can't open files under MS-Windows 98. (Antoine J. + Mechelynck) +Solution: Don't use _wstat(), _wopen() and _wfopen() in this situation. +Files: src/os_mswin.c, src/os_win32.c + +Patch 6.3b.004 +Problem: ":helpgrep" includes a trailing CR in the text line. +Solution: Remove the CR. +Files: src/quickfix.c + +Patch 6.3b.005 +Problem: ":echo &g:ai" results in the local option value. (Salman Halim) +Solution: Pass the flags from find_option_end() to get_option_value(). +Files: src/eval.c + +Patch 6.3b.006 +Problem: When using "mswin.vim", CTRL-V in Insert mode leaves cursor before + last pasted character. (Mathew Davis) +Solution: Use the same Paste() function as in menu.vim. +Files: runtime/mswin.vim + +Patch 6.3b.007 +Problem: Session file doesn't restore view on windows properly. (Robert + Webb) +Solution: Restore window sizes both before and after restoring the view, so + that the view, cursor position and size are restored properly. +Files: src/ex_docmd.c + +Patch 6.3b.008 +Problem: Using ":finally" in a user command doesn't always work. (Hari + Krishna Dara) +Solution: Don't assume that using getexline() means the command was typed. +Files: src/ex_docmd.c + +Patch 6.3b.009 (extra) +Problem: Win32: When the -P argument is not found in a window title, there + is no error message. +Solution: When the window can't be found give an error message and exit. + Also use try/except to catch failing to open the MDI window. + (Michael Wookey) +Files: src/gui_w32.c + +Patch 6.3b.010 +Problem: Win32: Using the "-D" argument and expanding arguments may cause a + hang, because the terminal isn't initialized yet. (Vince Negri) +Solution: Don't go into debug mode before the terminal is initialized. +Files: src/main.c + +Patch 6.3b.011 +Problem: Using CTRL-\ e while obtaining an expression aborts the command + line. (Hari Krishna Dara) +Solution: Insert the CTRL-\ e as typed. +Files: src/ex_getln.c + +Patch 6.3b.012 (after 6.3b.010) +Problem: Can't compile with tiny features. (Norbert Tretkowski) +Solution: Add #ifdefs. +Files: src/main.c + +Patch 6.3b.013 +Problem: Loading a session file results in editing the wrong file in the + first window when this is not the file at the current position in + the argument list. (Robert Webb) +Solution: Check w_arg_idx_invalid to decide whether to edit a file. +Files: src/ex_docmd.c + +Patch 6.3b.014 +Problem: ":runtime! foo*.vim" may using freed memory when a sourced script + changes the value of 'runtimepath'. +Solution: Make a copy of 'runtimepath' when looping over the matches. +Files: src/ex_cmds2.c + +Patch 6.3b.015 +Problem: Get lalloc(0) error when using "p" in Visual mode while + 'clipboard' contains "autoselect,unnamed". (Mark Wagonner) +Solution: Avoid allocating zero bytes. Obtain the clipboard when necessary. +Files: src/ops.c + +Patch 6.3b.016 +Problem: When 'virtualedit' is used "x" doesn't delete the last character + of a line that has as many characters as 'columns'. (Yakov Lerner) +Solution: When the cursor isn't moved let oneright() return FAIL. +Files: src/edit.c + +Patch 6.3b.017 +Problem: Win32: "vim --remote-wait" doesn't exit when the server finished + editing the file. (David Fishburn) +Solution: In the rrhelper plugin change backslashes to forward slashes and + escape special characters. +Files: runtime/plugin/rrhelper.vim + +Patch 6.3b.018 +Problem: The list of help files in the "local additions" table doesn't + recognize utf-8 encoding. (Yasuhiro Matsumoto) +Solution: Recognize utf-8 characters. +Files: src/ex_cmds.c + +Patch 6.3b.019 +Problem: When $VIMRUNTIME is not a full path name the "local additions" + table lists all the help files. +Solution: Use fullpathcmp() instead of fnamecmp() to compare the directory + names. +Files: src/ex_cmds.c + +Patch 6.3b.020 +Problem: When using CTRL-^ when entering a search string, the item in the + statusline that indicates the keymap is not updated. (Ilya + Dogolazky) +Solution: Mark the statuslines for updating. +Files: src/ex_getln.c + +Patch 6.3b.021 +Problem: The swapfile is not readable for others, the ATTENTION prompt does + not show all info when someone else is editing the same file. + (Marcel Svitalsky) +Solution: Use the protection of original file for the swapfile and set it + after creating the swapfile. +Files: src/fileio.c + +Patch 6.3b.022 +Problem: Using "4v" to select four times the old Visual area may put the + cursor beyond the end of the line. (Jens Paulus) +Solution: Correct the cursor column. +Files: src/normal.c + +Patch 6.3b.023 +Problem: When "3dip" starts in an empty line, white lines after the + non-white lines are not deleted. (Jens Paulus) +Solution: Include the white lines. +Files: src/search.c + +Patch 6.3b.024 +Problem: "2daw" does not delete leading white space like "daw" does. (Jens + Paulus) +Solution: Include the white space when a count is used. +Files: src/search.c + +Patch 6.3b.025 +Problem: Percentage in ruler isn't updated when a line is deleted. (Jens + Paulus) +Solution: Check for a change in line count when deciding to update the ruler. +Files: src/screen.c, src/structs.h + +Patch 6.3b.026 +Problem: When selecting "abort" at the ATTENTION prompt for a file that is + already being edited Vim crashes. +Solution: Don't abort creating a new buffer when we really need it. +Files: src/buffer.c, src/vim.h + +Patch 6.3b.027 +Problem: Win32: When enabling the menu in a maximized window, Vim uses more + lines than what is room for. (Shizhu Pan) +Solution: When deciding to call shell_resized(), also compare the text area + size with Rows and Columns, not just with screen_Rows and + screen_Columns. +Files: src/gui.c + +Patch 6.3b.028 +Problem: When in diff mode, setting 'rightleft' causes a crash. (Eddine) +Solution: Check for last column differently when 'rightleft' is set. +Files: src/screen.c + +Patch 6.3b.029 +Problem: Win32: warning for uninitialized variable. +Solution: Initialize to zero. +Files: src/misc1.c + +Patch 6.3b.030 +Problem: After Visually selecting four characters, changing it to other + text, Visually selecting and yanking two characters: "." changes + four characters, another "." changes two characters. (Robert Webb) +Solution: Don't store the size of the Visual area when redo is active. +Files: src/normal.c + +============================================================================== +VERSION 6.4 *version-6.4* + +This section is about improvements made between version 6.3 and 6.4. + +This is a bug-fix release. There are also a few new features. The major +number of new items is in the runtime files and translations. + +The big MS-Windows version now uses: + Ruby version 1.8.3 + Perl version 5.8.7 + Python version 2.4.2 + + +Changed *changed-6.4* +------- + +Removed runtime/tools/tcltags, Exuberant ctags does it better. + + +Added *added-6.4* +----- + +Alsaconf syntax file (Nikolai Weibull) +Eruby syntax, indent, compiler and ftplugin file (Doug Kearns) +Esterel syntax file (Maurizio Tranchero) +Mathematica indent file (Steve Layland) +Netrc syntax file (Nikolai Weibull) +PHP compiler file (Doug Kearns) +Pascal indent file (Neil Carter) +Prescribe syntax file (Klaus Muth) +Rubyunit compiler file (Doug Kearns) +SMTPrc syntax file (Kornel Kielczewski) +Sudoers syntax file (Nikolai Weibull) +TPP syntax file (Gerfried Fuchs) +VHDL ftplugin file (R. Shankar) +Verilog-AMS syntax file (S. Myles Prather) + +Bulgarian keymap (Alberto Mardegan) +Canadian keymap (Eric Joanis) + +Hungarian menu translations in UTF-8 (Kantra Gergely) +Ukrainian menu translations (Bohdan Vlasyuk) + +Irish message translations (Kevin Patrick Scannell) + +Configure also checks for tclsh8.4. + + +Fixed *fixed-6.4* +----- + +"dFxd;" deleted the character under the cursor, "d;" didn't remember the +exclusiveness of the motion. + +When using "set laststatus=2 cmdheight=2" in the .gvimrc you may only get one +line for the cmdline. (Christian Robinson) Invoke command_height() after the +GUI has started up. + +Gcc would warn "dereferencing type-punned pointer will break strict -aliasing +rules". Avoid using typecasts for variable pointers. + +Gcc 3.x interprets the -MM argument differently. Change "-I /path" to +"-isystem /path" for "make depend". + + +Patch 6.3.001 +Problem: ":browse split" gives the file selection dialog twice. (Gordon + Bazeley) Same problem for ":browse diffpatch". +Solution: Reset cmdmod.browse before calling do_ecmd(). +Files: src/diff.c, src/ex_docmd.c + +Patch 6.3.002 +Problem: When using translated help files with non-ASCII latin1 characters + in the first line the utf-8 detection is wrong. +Solution: Properly detect utf-8 characters. When a mix of encodings is + detected continue with the next language and avoid a "no matches" + error because of "got_int" being set. Add the directory name to + the error message for a duplicate tag. +Files: src/ex_cmds.c + +Patch 6.3.003 +Problem: Crash when using a console dialog and the first choice does not + have a default button. (Darin Ohashi) +Solution: Allocate two more characters for the [] around the character for + the default choice. +Files: src/message.c + +Patch 6.3.004 +Problem: When searching for a long string (140 chars in a 80 column + terminal) get three hit-enter prompts. (Robert Webb) +Solution: Avoid the hit-enter prompt when giving the message for wrapping + around the end of the buffer. Don't give that message again when + the string was not found. +Files: src/message.c, src/search.c + +Patch 6.3.005 +Problem: Crash when searching for a pattern with a character offset and + starting in a closed fold. (Frank Butler) +Solution: Check for the column to be past the end of the line. Also fix + that a pattern with a character offset relative to the end isn't + read back from the viminfo properly. +Files: src/search.c + +Patch 6.3.006 +Problem: ":breakadd file *foo" prepends the current directory to the file + pattern. (Hari Krishna Dara) +Solution: Keep the pattern as-is. +Files: src/ex_cmds2.c + +Patch 6.3.007 +Problem: When there is a buffer with 'buftype' set to "nofile" and using a + ":cd" command, the swap file is not deleted when exiting. +Solution: Use the full path of the swap file also for "nofile" buffers. +Files: src/fileio.c + +Patch 6.3.008 +Problem: Compiling fails under OS/2. +Solution: Include "e_screenmode" also for OS/2. (David Sanders) +Files: src/globals.h + +Patch 6.3.009 (after 6.3.006) +Problem: ":breakadd file /path/foo.vim" does not match when a symbolic link + is involved. (Servatius Brandt) +Solution: Do expand the pattern when it does not start with "*". +Files: runtime/doc/repeat.txt, src/ex_cmds2.c + +Patch 6.3.010 +Problem: When writing to a named pipe there is an error for fsync() + failing. +Solution: Ignore the fsync() error for devices. +Files: src/fileio.c + +Patch 6.3.011 +Problem: Crash when the completion function of a user-command uses a + "normal :cmd" command. (Hari Krishna Dara) +Solution: Save the command line when invoking the completion function. +Files: src/ex_getln.c + +Patch 6.3.012 +Problem: Internal lalloc(0) error when using a complicated multi-line + pattern in a substitute command. (Luc Hermitte) +Solution: Avoid going past the end of a line. +Files: src/ex_cmds.c + +Patch 6.3.013 +Problem: Crash when editing a command line and typing CTRL-R = to evaluate + a function that uses "normal :cmd". (Hari Krishna Dara) +Solution: Save and restore the command line when evaluating an expression + for CTRL-R =. +Files: src/ex_getln.c, src/ops.c, src/proto/ex_getln.pro, + src/proto/ops.pro + +Patch 6.3.014 +Problem: When using Chinese or Taiwanese the default for 'helplang' is + wrong. (Simon Liang) +Solution: Use the part of the locale name after "zh_". +Files: src/option.c + +Patch 6.3.015 +Problem: The string that winrestcmd() returns may end in garbage. +Solution: NUL-terminate the string. (Walter Briscoe) +Files: src/eval.c + +Patch 6.3.016 +Problem: The default value for 'define' has "\s" before '#'. +Solution: Add a star after "\s". (Herculano de Lima Einloft Neto) +Files: src/option.c + +Patch 6.3.017 +Problem: "8zz" may leave the cursor beyond the end of the line. (Niko + Maatjes) +Solution: Correct the cursor column after moving to another line. +Files: src/normal.c + +Patch 6.3.018 +Problem: ":0argadd zero" added the argument after the first one, instead of + before it. (Adri Verhoef) +Solution: Accept a zero range for ":argadd". +Files: src/ex_cmds.h + +Patch 6.3.019 +Problem: Crash in startup for debug version. (David Rennals) +Solution: Move the call to nbdebug_wait() to after allocating NameBuff. +Files: src/main.c + +Patch 6.3.020 +Problem: When 'encoding' is "utf-8" and 'delcombine' is set, "dw" does not + delete a word but only a combining character of the first + character, if there is one. (Raphael Finkel) +Solution: Correctly check that one character is being deleted. +Files: src/misc1.c + +Patch 6.3.021 +Problem: When the last character of a file name is a multi-byte character + and the last byte is a path separator, the file cannot be edited. +Solution: Check for the last byte to be part of a multi-byte character. + (Taro Muraoka) +Files: src/fileio.c + +Patch 6.3.022 (extra) +Problem: Win32: When the last character of a file name is a multi-byte + character and the last byte is a path separator, the file cannot + be written. A trail byte that is a space makes that a file cannot + be opened from the command line. +Solution: Recognize double-byte characters when parsing the command line. + In mch_stat() check for the last byte to be part of a multi-byte + character. (Taro Muraoka) +Files: src/gui_w48.c, src/os_mswin.c + +Patch 6.3.023 +Problem: When the "to" part of a mapping starts with its "from" part, + abbreviations for the same characters is not possible. For + example, when <Space> is mapped to something that starts with a + space, typing <Space> does not expand abbreviations. +Solution: Only disable expanding abbreviations when a mapping is not + remapped, don't disable it when the RHS of a mapping starts with + the LHS. +Files: src/getchar.c, src/vim.h + +Patch 6.3.024 +Problem: In a few places a string in allocated memory is not terminated + with a NUL. +Solution: Add ga_append(NUL) in script_get(), gui_do_findrepl() and + serverGetVimNames(). +Files: src/ex_getln.c, src/gui.c, src/if_xcmdsrv.c, src/os_mswin.c + +Patch 6.3.025 (extra) +Problem: Missing NUL for list of server names. +Solution: Add ga_append(NUL) in serverGetVimNames(). +Files: src/os_mswin.c + +Patch 6.3.026 +Problem: When ~/.vim/after/syntax/syncolor.vim contains a command that + reloads the colors an endless loop and/or a crash may occur. +Solution: Only free the old value of an option when it was originally + allocated. Limit recursiveness of init_highlight() to 5 levels. +Files: src/option.c, src/syntax.c + +Patch 6.3.027 +Problem: VMS: Writing a file may insert extra CR characters. Not all + terminals are recognized correctly. Vt320 doesn't support colors. + Environment variables are not expanded correctly. +Solution: Use another method to write files. Add vt320 termcap codes for + colors. (Zoltan Arpadffy) +Files: src/fileio.c, src/misc1.c, src/os_unix.c, src/structs.h, + src/term.c + +Patch 6.3.028 +Problem: When appending to a file the BOM marker may be written. (Alex + Jakushev) +Solution: Do not write the BOM marker when appending. +Files: src/fileio.c + +Patch 6.3.029 +Problem: Crash when inserting a line break. (Walter Briscoe) +Solution: In the syntax highlighting code, don't use an old state after a + change was made, current_col may be past the end of the line. +Files: src/syntax.c + +Patch 6.3.030 +Problem: GTK 2: Crash when sourcing a script that deletes the menus, sets + 'encoding' to "utf-8" and loads the menus again. GTK error + message when tooltip text is in a wrong encoding. +Solution: Don't copy characters from the old screen to the new screen when + switching 'encoding' to utf-8, they may be invalid. Only set the + tooltip when it is valid utf-8. +Files: src/gui_gtk.c, src/mbyte.c, src/proto/mbyte.pro, src/screen.c + +Patch 6.3.031 +Problem: When entering a mapping and pressing Tab halfway the command line + isn't redrawn properly. (Adri Verhoef) +Solution: Reposition the cursor after drawing over the "..." of the + completion attempt. +Files: src/ex_getln.c + +Patch 6.3.032 +Problem: Using Python 2.3 with threads doesn't work properly. +Solution: Release the lock after initialization. +Files: src/if_python.c + +Patch 6.3.033 +Problem: When a mapping ends in a Normal mode command of more than one + character Vim doesn't return to Insert mode. +Solution: Check that the mapping has ended after obtaining all characters of + the Normal mode command. +Files: src/normal.c + +Patch 6.3.034 +Problem: VMS: crash when using ":help". +Solution: Avoid using "tags-??", some Open VMS systems can't handle the "?" + wildcard. (Zoltan Arpadffy) +Files: src/tag.c + +Patch 6.3.035 (extra) +Problem: RISC OS: Compile errors. +Solution: Change e_screnmode to e_screenmode. Change the way + __riscosify_control is set. Improve the makefile. (Andy Wingate) +Files: src/os_riscos.c, src/search.c, src/Make_ro.mak + +Patch 6.3.036 +Problem: ml_get errors when the whole file is a fold, switching + 'foldmethod' and doing "zj". (Christian J. Robinson) Was not + deleting the fold but creating a fold with zero lines. +Solution: Delete the fold properly. +Files: src/fold.c + +Patch 6.3.037 (after 6.3.032) +Problem: Warning for unused variable. +Solution: Change the #ifdefs for the saved thread stuff. +Files: src/if_python.c + +Patch 6.3.038 (extra) +Problem: Win32: When the "file changed" dialog pops up after a click that + gives gvim focus and not moving the mouse after that, the effect + of the click may occur when moving the mouse later. (Ken Clark) + Happened because the release event was missed. +Solution: Clear the s_button_pending variable when any input is received. +Files: src/gui_w48.c + +Patch 6.3.039 +Problem: When 'number' is set and inserting lines just above the first + displayed line (in another window on the same buffer), the line + numbers are not updated. (Hitier Sylvain) +Solution: When 'number' is set and lines are inserted/deleted redraw all + lines below the change. +Files: src/screen.c + +Patch 6.3.040 +Problem: Error handling does not always work properly and may cause a + buffer to be marked as if it's viewed in a window while it isn't. + Also when selecting "Abort" at the attention prompt. +Solution: Add enter_cleanup() and leave_cleanup() functions to move + saving/restoring things for error handling to one place. + Clear a buffer read error when it's unloaded. +Files: src/buffer.c, src/ex_docmd.c, src/ex_eval.c, + src/proto/ex_eval.pro, src/structs.h, src/vim.h + +Patch 6.3.041 (extra) +Problem: Win32: When the path to a file has Russian characters, ":cd %:p:h" + doesn't work. (Valery Kondakoff) +Solution: Use a wide function to change directory. +Files: src/os_mswin.c + +Patch 6.3.042 +Problem: When there is a closed fold at the top of the window, CTRL-X + CTRL-E in Insert mode reduces the size of the fold instead of + scrolling the text up. (Gautam) +Solution: Scroll over the closed fold. +Files: src/move.c + +Patch 6.3.043 +Problem: 'hlsearch' highlighting sometimes disappears when inserting text + in PHP code with syntax highlighting. (Marcel Svitalsky) +Solution: Don't use pointers to remember where a match was found, use an + index. The pointers may become invalid when searching in other + lines. +Files: src/screen.c + +Patch 6.3.044 (extra) +Problem: Mac: When 'linespace' is non-zero the Insert mode cursor leaves + pixels behind. (Richard Sandilands) +Solution: Erase the character cell before drawing the text when needed. +Files: src/gui_mac.c + + +Patch 6.3.045 +Problem: Unusual characters in an option value may cause unexpected + behavior, especially for a modeline. (Ciaran McCreesh) +Solution: Don't allow setting termcap options or 'printdevice' in a + modeline. Don't list options for "termcap" and "all" in a + modeline. Don't allow unusual characters in 'filetype', 'syntax', + 'backupext', 'keymap', 'patchmode' and 'langmenu'. +Files: src/option.c, runtime/doc/options.txt + +Patch 6.3.046 +Problem: ":registers" doesn't show multi-byte characters properly. + (Valery Kondakoff) +Solution: Get the length of each character before displaying it. +Files: src/ops.c + +Patch 6.3.047 (extra) +Problem: Win32 with Borland C 5.5 on Windows XP: A new file is created with + read-only attributes. (Tony Mechelynck) +Solution: Don't use the _wopen() function for Borland. +Files: src/os_win32.c + +Patch 6.3.048 (extra) +Problem: Build problems with VMS on IA64. +Solution: Add dependencies to the build file. (Zoltan Arpadffy) +Files: src/Make_vms.mms + +Patch 6.3.049 (after 6.3.045) +Problem: Compiler warning for "char" vs "char_u" mixup. (Zoltan Arpadffy) +Solution: Add a typecast. +Files: src/option.c + +Patch 6.3.050 +Problem: When SIGHUP is received while busy exiting, non-reentrant + functions such as free() may cause a crash. +Solution: Ignore SIGHUP when exiting because of an error. (Scott Anderson) +Files: src/misc1.c, src/main.c + +Patch 6.3.051 +Problem: When 'wildmenu' is set and completed file names contain multi-byte + characters Vim may crash. +Solution: Reserve room for multi-byte characters. (Yasuhiro Matsumoto) +Files: src/screen.c + +Patch 6.3.052 (extra) +Problem: Windows 98: typed keys that are not ASCII may not work properly. + For example with a Russian input method. (Jiri Jezdinsky) +Solution: Assume that the characters arrive in the current codepage instead + of UCS-2. Perform conversion based on that. +Files: src/gui_w48.c + +Patch 6.3.053 +Problem: Win32: ":loadview" cannot find a file with non-ASCII characters. + (Valerie Kondakoff) +Solution: Use mch_open() instead of open() to open the file. +Files: src/ex_cmds2.c + +Patch 6.3.054 +Problem: When 'insertmode' is set <C-L>4ixxx<C-L> hangs Vim. (Jens Paulus) + Vim is actually still working but redraw is disabled. +Solution: When stopping Insert mode with CTRL-L don't put an Esc in the redo + buffer but a CTRL-L. +Files: src/edit.c + +Patch 6.3.055 (after 6.3.013) +Problem: Can't use getcmdline(), getcmdpos() or setcmdpos() with <C-R>= + when editing a command line. Using <C-\>e may crash Vim. (Peter + Winters) +Solution: When moving ccline out of the way for recursive use, make it + available to the functions that need it. Also save and restore + ccline when calling get_expr_line(). Make ccline.cmdbuf NULL at + the end of getcmdline(). +Files: src/ex_getln.c + +Patch 6.3.056 +Problem: The last characters of a multi-byte file name may not be displayed + in the window title. +Solution: Avoid to remove a multi-byte character where the last byte looks + like a path separator character. (Yasuhiro Matsumoto) +Files: src/buffer.c, src/ex_getln.c + +Patch 6.3.057 +Problem: When filtering lines folds are not updated. (Carl Osterwisch) +Solution: Update folds for filtered lines. +Files: src/ex_cmds.c + +Patch 6.3.058 +Problem: When 'foldcolumn' is equal to the window width and 'wrap' is on + Vim may crash. Disabling the vertical split feature breaks + compiling. (Peter Winters) +Solution: Check for zero room for wrapped text. Make compiling without + vertical splits possible. +Files: src/move.c, src/quickfix.c, src/screen.c, src/netbeans.c + +Patch 6.3.059 +Problem: Crash when expanding an ":edit" command containing several spaces + with the shell. (Brian Hirt) +Solution: Allocate enough space for the quotes. +Files: src/os_unix.c + +Patch 6.3.060 +Problem: Using CTRL-R CTRL-O in Insert mode with an invalid register name + still causes something to be inserted. +Solution: Check the register name for being valid. +Files: src/edit.c + +Patch 6.3.061 +Problem: When editing a utf-8 file in an utf-8 xterm and there is a + multi-byte character in the last column, displaying is messed up. + (Joël Rio) +Solution: Check for a multi-byte character, not a multi-column character. +Files: src/screen.c + +Patch 6.3.062 +Problem: ":normal! gQ" hangs. +Solution: Quit getcmdline() and do_exmode() when out of typeahead. +Files: src/ex_getln.c, src/ex_docmd.c + +Patch 6.3.063 +Problem: When a CursorHold autocommand changes to another window + (temporarily) 'mousefocus' stops working. +Solution: Call gui_mouse_correct() after triggering CursorHold. +Files: src/gui.c + +Patch 6.3.064 +Problem: line2byte(line("$") + 1) sometimes returns the wrong number. + (Charles Campbell) +Solution: Flush the cached line before counting the bytes. +Files: src/memline.c + +Patch 6.3.065 +Problem: The euro digraph doesn't always work. +Solution: Add an "e=" digraph for Unicode euro character and adjust the + help files. +Files: src/digraph.c, runtime/doc/digraph.txt + +Patch 6.3.066 +Problem: Backup file may get wrong permissions. +Solution: Use permissions of original file for backup file in more places. +Files: src/fileio.c + +Patch 6.3.067 (after 6.3.066) +Problem: Newly created file gets execute permission. +Solution: Check for "perm" to be negative before using it. +Files: src/fileio.c + +Patch 6.3.068 +Problem: When editing a compressed file xxx.gz which is a symbolic link to + the actual file a ":write" renames the link. +Solution: Resolve the link, so that the actual file is renamed and + compressed. +Files: runtime/plugin/gzip.vim + +Patch 6.3.069 +Problem: When converting text with illegal characters Vim may crash. +Solution: Avoid that too much is subtracted from the length. (Da Woon Jung) +Files: src/mbyte.c + +Patch 6.3.070 +Problem: After ":set number linebreak wrap" and a vertical split, moving + the vertical separator far left will crash Vim. (Georg Dahn) +Solution: Avoid dividing by zero. +Files: src/charset.c + +Patch 6.3.071 +Problem: The message for CTRL-X mode is still displayed after an error for + 'thesaurus' or 'dictionary' being empty. +Solution: Clear "edit_submode". +Files: src/edit.c + +Patch 6.3.072 +Problem: Crash in giving substitute message when language is Chinese and + encoding is utf-8. (Yongwei) +Solution: Make the msg_buf size larger when using multi-byte. +Files: src/vim.h + +Patch 6.3.073 +Problem: Win32 GUI: When the Vim window is partly above or below the + screen, scrolling causes display errors when the taskbar is not on + that side. +Solution: Use the SW_INVALIDATE flag when the Vim window is partly below or + above the screen. +Files: src/gui_w48.c + +Patch 6.3.074 +Problem: When mswin.vim is used and 'insertmode' is set, typing text in + Select mode and then using CTRL-V results in <SNR>99_Pastegi. + (Georg Dahn) +Solution: When restart_edit is set use "d" instead of "c" to remove the + selected text to avoid calling edit() twice. +Files: src/normal.c + +Patch 6.3.075 +Problem: After unloading another buffer, syntax highlighting in the current + buffer may be wrong when it uses "containedin". (Eric Arnold) +Solution: Use "buf" instead of "curbuf" in syntax_clear(). +Files: src/syntax.c + +Patch 6.3.076 +Problem: Crash when using cscope and there is a parse error (e.g., line too + long). (Alexey I. Froloff) +Solution: Pass the actual number of matches to cs_manage_matches() and + correctly handle the error situation. +Files: src/if_cscope.c + +Patch 6.3.077 (extra) +Problem: VMS: First character input after ESC was not recognized. +Solution: Added TRM$M_TM_TIMED in vms_read(). (Zoltan Arpadffy) +Files: src/os_vms.c + +Patch 6.3.078 (extra, after 6.3.077) +Problem: VMS: Performance issue after patch 6.3.077 +Solution: Add a timeout in the itemlist. (Zoltan Arpadffy) +Files: src/os_vms.c + +Patch 6.3.079 +Problem: Crash when executing a command in the command line window while + syntax highlighting is enabled. (Pero Brbora) +Solution: Don't use a pointer to a buffer that has been deleted. +Files: src/syntax.c + +Patch 6.3.080 (extra) +Problem: Win32: With 'encoding' set to utf-8 while the current codepage is + Chinese editing a file with some specific characters in the name + fails. +Solution: Use _wfullpath() instead of _fullpath() when necessary. +Files: src/os_mswin.c + +Patch 6.3.081 +Problem: Unix: glob() may execute a shell command when it's not wanted. + (Georgi Guninski) +Solution: Verify the sandbox flag is not set. +Files: src/os_unix.c + +Patch 6.3.082 (after 6.3.081) +Problem: Unix: expand() may execute a shell command when it's not wanted. + (Georgi Guninski) +Solution: A more generic solution than 6.3.081. +Files: src/os_unix.c + +Patch 6.3.083 +Problem: VMS: The vt320 termcap entry is incomplete. +Solution: Add missing function keys. (Zoltan Arpadffy) +Files: src/term.c + +Patch 6.3.084 (extra) +Problem: Cygwin: compiling with DEBUG doesn't work. Perl path was ignored. + Failure when $(OUTDIR) already exists. "po" makefile is missing. +Solution: Use changes tested in Vim 7. (Tony Mechelynck) +Files: src/Make_cyg.mak, src/po/Make_cyg.mak + +Patch 6.3.085 +Problem: Crash in syntax highlighting code. (Marc Espie) +Solution: Prevent current_col going past the end of the line. +Files: src/syntax.c + +Patch 6.3.086 (extra) +Problem: Can't produce message translation file with msgfmt that checks + printf strings. +Solution: Fix the Russian translation. +Files: src/po/ru.po, src/po/ru.cp1251.po + +Patch 6.3.087 +Problem: MS-DOS: Crash. (Jason Hood) +Solution: Don't call fname_case() with a NULL pointer. +Files: src/ex_cmds.c + +Patch 6.3.088 +Problem: Editing ".in" causes error E218. (Stefan Karlsson) +Solution: Require some characters before ".in". Same for ".orig" and others. +Files: runtime/filetype.vim + +Patch 6.3.089 +Problem: A session file doesn't work when created while the current + directory contains a space or the directory of the session files + contains a space. (Paolo Giarrusso) +Solution: Escape spaces with a backslash. +Files: src/ex_docmd.c + +Patch 6.3.090 +Problem: A very big value for 'columns' or 'lines' may cause a crash. +Solution: Limit the values to 10000 and 1000. +Files: src/option.c + +Patch 6.4a.001 +Problem: The Unix Makefile contained too many dependencies and a few + uncommented lines. +Solution: Run "make depend" with manual changes to avoid a gcc + incompatibility. Comment a few lines. +Files: src/Makefile + +Patch 6.4b.001 +Problem: Vim reports "Vim 6.4a" in the ":version" output. +Solution: Change "a" to "b". (Tony Mechelynck) +Files: src/version.h + +Patch 6.4b.002 +Problem: In Insert mode, pasting a multi-byte character after the end of + the line leaves the cursor just before that character. +Solution: Make sure "gP" leaves the cursor in the right place when + 'virtualedit' is set. +Files: src/ops.c + +Patch 6.4b.003 (after 6.4b.002) +Problem: The problem still exists when 'encoding' is set to "cp936". +Solution: Fix the problem in getvvcol(), compute the coladd field correctly. +Files: src/charset.c, src/ops.c + +Patch 6.4b.004 +Problem: Selecting a {} block with "viB" includes the '}' when there is an + empty line before it. +Solution: Don't advance the cursor to include a line break when it's already + at the line break. +Files: src/search.c + + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/version7.txt b/share/vim/vim73/doc/version7.txt new file mode 100644 index 0000000000..1d559f7cdd --- /dev/null +++ b/share/vim/vim73/doc/version7.txt @@ -0,0 +1,10154 @@ +*version7.txt* For Vim version 7.3. Last change: 2010 Aug 15 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + *vim7* *version-7.0* *version7.0* +Welcome to Vim 7! A large number of features has been added. This file +mentions all the new items, changes to existing features and bug fixes +since Vim 6.x. Use this command to see the version you are using: > + :version + +See |vi_diff.txt| for an overview of differences between Vi and Vim 7.0. +See |version4.txt| for differences between Vim 3.x and Vim 4.x. +See |version5.txt| for differences between Vim 4.x and Vim 5.x. +See |version6.txt| for differences between Vim 5.x and Vim 6.x. + +INCOMPATIBLE CHANGES |incompatible-7| + +NEW FEATURES |new-7| + +Vim script enhancements |new-vim-script| +Spell checking |new-spell| +Omni completion |new-omni-completion| +MzScheme interface |new-MzScheme| +Printing multi-byte text |new-print-multi-byte| +Tab pages |new-tab-pages| +Undo branches |new-undo-branches| +Extended Unicode support |new-more-unicode| +More highlighting |new-more-highlighting| +Translated manual pages |new-manpage-trans| +Internal grep |new-vimgrep| +Scroll back in messages |new-scroll-back| +Cursor past end of the line |new-onemore| +POSIX compatibility |new-posix| +Debugger support |new-debug-support| +Remote file explorer |new-netrw-explore| +Define an operator |new-define-operator| +Mapping to an expression |new-map-expression| +Visual and Select mode mappings |new-map-select| +Location list |new-location-list| +Various new items |new-items-7| + +IMPROVEMENTS |improvements-7| + +COMPILE TIME CHANGES |compile-changes-7| + +BUG FIXES |bug-fixes-7| + +VERSION 7.1 |version-7.1| +Changed |changed-7.1| +Added |added-7.1| +Fixed |fixed-7.1| + +VERSION 7.2 |version-7.2| +Changed |changed-7.2| +Added |added-7.2| +Fixed |fixed-7.2| + +VERSION 7.3 |version-7.3| + +Persistent undo |new-persistent-undo| +More encryption |new-more-encryption| +Conceal text |new-conceal| +Lua interface |new-lua| +Python3 interface |new-python3| + +Changed |changed-7.3| +Added |added-7.3| +Fixed |fixed-7.3| + +============================================================================== +INCOMPATIBLE CHANGES *incompatible-7* + +These changes are incompatible with previous releases. Check this list if you +run into a problem when upgrading from Vim 6.x to 7.0. + +A ":write file" command no longer resets the 'modified' flag of the buffer, +unless the '+' flag is in 'cpoptions' |cpo-+|. This was illogical, since the +buffer is still modified compared to the original file. And when undoing +all changes the file would actually be marked modified. It does mean that +":quit" fails now. + +":helpgrep" now uses a help window to display a match. + +In an argument list double quotes could be used to include spaces in a file +name. This caused a difference between ":edit" and ":next" for escaping +double quotes and it is incompatible with some versions of Vi. + Command Vim 6.x file name Vim 7.x file name ~ + :edit foo\"888 foo"888 foo"888 + :next foo\"888 foo888 foo"888 + :next a\"b c\"d ab cd a"b and c"d + +In a |literal-string| a single quote can be doubled to get one. +":echo 'a''b'" would result in "a b", but now that two quotes stand for one it +results in "a'b". + +When overwriting a file with ":w! fname" there was no warning for when "fname" +was being edited by another Vim. Vim now gives an error message |E768|. + +The support for Mac OS 9 has been removed. + +Files ending in .tex now have 'filetype' set to "context", "plaintex", or +"tex". |ft-tex-plugin| + + +Minor incompatibilities: + +For filetype detection: For many types, use */.dir/filename instead of +~/.dir/filename, so that it also works for other user's files. + +For quite a few filetypes the indent settings have been moved from the +filetype plugin to the indent plugin. If you used: > + :filetype plugin on +Then some indent settings may be missing. You need to use: > + :filetype plugin indent on + +":0verbose" now sets 'verbose' to zero instead of one. + +Removed the old and incomplete "VimBuddy" code. + +Buffers without a name report "No Name" instead of "No File". It was +confusing for buffers with a name and 'buftype' set to "nofile". + +When ":file xxx" is used in a buffer without a name, the alternate file name +isn't set. This avoids creating buffers without a name, they are not useful. + +The "2html.vim" script now converts closed folds to HTML. This means the HTML +looks like it's displayed, with the same folds open and closed. Use "zR", or +"let html_ignore_folding=1", if no folds should appear in the HTML. (partly by +Carl Osterwisch) +Diff mode is now also converted to HTML as it is displayed. + +Win32: The effect of the <F10> key depended on 'winaltkeys'. Now it depends +on whether <F10> has been mapped or not. This allows mapping <F10> without +changing 'winaltkeys'. + +When 'octal' is in 'nrformats' and using CTRL-A on "08" it became "018", which +is illogical. Now it becomes "9". The leading zero(s) is(are) removed to +avoid the number becoming octal after incrementing "009" to "010". + +When 'encoding' is set to a Unicode encoding, the value for 'fileencodings' +now includes "default" before "latin1". This means that for files with 8-bit +encodings the default is to use the encoding specified by the environment, if +possible. Previously latin1 would always be used, which is wrong in a +non-latin1 environment, such as Russian. + +Previously Vim would exit when there are two windows, both of them displaying +a help file, and using ":quit". Now only the window is closed. + +"-w {scriptout}" only works when {scriptout} doesn't start with a digit. +Otherwise it's used to set the 'window' option. + +Previously <Home> and <xHome> could be mapped separately. This had the +disadvantage that all mappings (with modifiers) had to be duplicated, since +you can't be sure what the keyboard generates. Now all <xHome> are internally +translated to <Home>, both for the keys and for mappings. Also for <xEnd>, +<xF1>, etc. + +":put" now leaves the cursor on the last inserted line. + +When a .gvimrc file exists then 'compatible' is off, just like when a ".vimrc" +file exists. + +When making a string upper-case with "vlllU" or similar then the German sharp +s is replaced with "SS". This does not happen with "~" to avoid backwards +compatibility problems and because "SS" can't be changed back to a sharp s. + +"gd" previously found the very first occurrence of a variable in a function, +that could be the function argument without type. Now it finds the position +where the type is given. + +The line continuation in functions was not taken into account, line numbers in +errors were logical lines, not lines in the sourced file. That made it +difficult to locate errors. Now the line number in the sourced file is +reported, relative to the function start. This also means that line numbers +for ":breakadd func" are different. + +When defining a user command with |:command| the special items could be +abbreviated. This caused unexpected behavior, such as <li> being recognized +as <line1>. The items can no longer be abbreviated. + +When executing a FileChangedRO autocommand it is no longer allowed to switch +to another buffer or edit another file. This is to prevent crashes (the event +is triggered deep down in the code where changing buffers is not anticipated). +It is still possible to reload the buffer. + +At the |more-prompt| and the |hit-enter-prompt|, when the 'more' option is +set, the 'k', 'u', 'g' and 'b' keys are now used to scroll back to previous +messages. Thus they are no longer used as typeahead. + +============================================================================== +NEW FEATURES *new-7* + +Vim script enhancements *new-vim-script* +----------------------- + +In Vim scripts the following types have been added: + + |List| ordered list of items + |Dictionary| associative array of items + |Funcref| reference to a function + +Many functions and commands have been added to support the new types. + +The |string()| function can be used to get a string representation of a +variable. Works for Numbers, Strings and composites of them. Then |eval()| +can be used to turn the string back into the variable value. + +The |:let| command can now use "+=", "-=" and ".=": > + :let var += expr " works like :let var = var + expr + :let var -= expr " works like :let var = var - expr + :let var .= string " works like :let var = var . string + +With the |:profile| command you can find out where your function or script +is wasting time. + +In the Python interface vim.eval() also handles Dictionaries and Lists. +|python-eval| (G. Sumner Hayes) + +The |getscript| plugin was added as a convenient way to update scripts from +www.vim.org automatically. (Charles Campbell) + +The |vimball| plugin was added as a convenient way to distribute a set of +files for a plugin (plugin file, autoload script, documentation). (Charles +Campbell) + + +Spell checking *new-spell* +-------------- + +Spell checking has been integrated in Vim. There were a few implementations +with scripts, but they were slow and/or required an external program. + +The 'spell' option is used to switch spell checking on or off +The 'spelllang' option is used to specify the accepted language(s) +The 'spellfile' option specifies where new words are added +The 'spellsuggest' option specifies the methods used for making suggestions + +The |]s| and |[s| commands can be used to move to the next or previous error +The |zg| and |zw| commands can be used to add good and wrong words +The |z=| command can be used to list suggestions and correct the word +The |:mkspell| command is used to generate a Vim spell file from word lists + +The "undercurl" highlighting attribute was added to nicely point out spelling +mistakes in the GUI (based on patch from Marcin Dalecki). +The "guisp" color can be used to give it a color different from foreground and +background. +The number of possible different highlight attributes was raised from about +220 to over 30000. This allows for the attributes of spelling to be combined +with syntax highlighting attributes. This is also used for syntax +highlighting and marking the Visual area. + +Much more info here: |spell|. + + +Omni completion *new-omni-completion* +--------------- + +This could also be called "intellisense", but that is a trademark. It is a +smart kind of completion. The text in front of the cursor is inspected to +figure out what could be following. This may suggest struct and class +members, system functions, etc. + +Use CTRL-X CTRL-O in Insert mode to start the completion. |i_CTRL-X_CTRL-O| + +The 'omnifunc' option is set by filetype plugins to define the function that +figures out the completion. + +Currently supported languages: + C |ft-c-omni| + (X)HTML with CSS |ft-html-omni| + JavaScript |ft-javascript-omni| + PHP |ft-php-omni| + Python + Ruby |ft-ruby-omni| + SQL |ft-sql-omni| + XML |ft-xml-omni| + any language with syntax highlighting |ft-syntax-omni| + +You can add your own omni completion scripts. + +When the 'completeopt' option contains "menu" then matches for Insert mode +completion are displayed in a (rather primitive) popup menu. + + +MzScheme interface *new-MzScheme* +------------------ + +The MzScheme interpreter is supported. |MzScheme| + +The |:mzscheme| command can be used to execute MzScheme commands +The |:mzfile| command can be used to execute an MzScheme script file + +This depends on Vim being compiled with the |+mzscheme| feature. + + +Printing multi-byte text *new-print-multi-byte* +------------------------ + +The |:hardcopy| command now supports printing multi-byte characters when using +PostScript. + +The 'printmbcharset' and 'printmbfont' options are used for this. +Also see |postscript-cjk-printing|. (Mike Williams) + + +Tab pages *new-tab-pages* +--------- + +A tab page is a page with one or more windows with a label (aka tab) at the top. +By clicking on the label you can quickly switch between the tab pages. And +with the keyboard, using the |gt| (Goto Tab) command. This is a convenient +way to work with many windows. + +To start Vim with each file argument in a separate tab page use the |-p| +argument. The maximum number of pages can be set with 'tabpagemax'. + +The line with tab labels is either made with plain text and highlighting or +with a GUI mechanism. The GUI labels look better but are only available on a +few systems. The line can be customized with 'tabline', 'guitablabel' and +'guitabtooltip'. Whether it is displayed is set with 'showtabline'. Whether +to use the GUI labels is set with the "e" flag in 'guioptions'. + +The |:tab| command modifier can be used to have most commands that open a new +window open a new tab page instead. + +The |--remote-tab| argument can be used to edit a file in a new tab page in an +already running Vim server. + +Variables starting with "t:" are local to a tab page. + +More info here: |tabpage| +Most of the GUI stuff was implemented by Yegappan Lakshmanan. + + +Undo branches *new-undo-branches* +------------- + +Previously there was only one line of undo-redo. If, after undoing a number +of changes, a new change was made all the undone changes were lost. This +could lead to accidentally losing work. + +Vim now makes an undo branch in this situation. Thus you can go back to the +text after any change, even if they were undone. So long as you do not run +into 'undolevels', when undo information is freed up to limit the memory used. + +To be able to navigate the undo branches each change is numbered sequentially. +The commands |g-| and |:earlier| go back in time, to older changes. The +commands |g+| and |:later| go forward in time, to newer changes. + +The changes are also timestamped. Use ":earlier 10m" to go to the text as it +was about ten minutes earlier. + +The |:undolist| command can be used to get an idea of which undo branches +exist. The |:undo| command now takes an argument to directly jump to a +specific position in this list. The |changenr()| function can be used to +obtain the change number. + +There is no graphical display of the tree with changes, navigation can be +quite confusing. + + +Extended Unicode support *new-more-unicode* +------------------------ + +Previously only two combining characters were displayed. The limit is now +raised to 6. This can be set with the 'maxcombine' option. The default is +still 2. + +|ga| now shows all combining characters, not just the first two. + +Previously only 16 bit Unicode characters were supported for displaying. Now +the full 32 bit character set can be used. Unless manually disabled at +compile time to save a bit of memory. + +For pattern matching it is now possible to search for individual composing +characters. |patterns-composing| + +The |8g8| command searches for an illegal UTF-8 byte sequence. + + +More highlighting *new-more-highlighting* +----------------- + +Highlighting matching parens: + +When moving the cursor through the text and it is on a paren, then the +matching paren can be highlighted. This uses the new |CursorMoved| +autocommand event. + +This means some commands are executed every time you move the cursor. If this +slows you down too much switch it off with: > + :NoMatchParen + +See |matchparen| for more information. + +The plugin uses the |:match| command. It now supports three match patterns. +The plugin uses the third one. The first one is for the user and the second +one can be used by another plugin. + +Highlighting the cursor line and column: + +The 'cursorline' and 'cursorcolumn' options have been added. These highlight +the screen line and screen column of the cursor. This makes the cursor +position easier to spot. 'cursorcolumn' is also useful to align text. This +may make screen updating quite slow. The CursorColumn and CursorLine +highlight groups allow changing the colors used. |hl-CursorColumn| +|hl-CursorLine| + +The number of possible different highlight attributes was raised from about +220 to over 30000. This allows for the attributes of spelling to be combined +with syntax highlighting attributes. This is also used for syntax +highlighting, marking the Visual area, CursorColumn, etc. + + +Translated manual pages *new-manpage-trans* +----------------------- + +The manual page of Vim and associated programs is now also available in +several other languages. + +French - translated by David Blanchet +Italian - translated by Antonio Colombo +Russian - translated by Vassily Ragosin +Polish - translated by Mikolaj Machowski + +The Unix Makefile installs the Italian manual pages in .../man/it/man1/, +.../man/it.ISO8859-1/man1/ and .../man/it.UTF-8/man1/. There appears to be no +standard for what encoding goes in the "it" directory, the 8-bit encoded file +is used there as a best guess. +Other languages are installed in similar places. +The translated pages are not automatically installed when Vim was configured +with "--disable-nls", but "make install-languages install-tool-languages" will +do it anyway. + + +Internal grep *new-vimgrep* +------------- + +The ":vimgrep" command can be used to search for a pattern in a list of files. +This is like the ":grep" command, but no external program is used. Besides +better portability, handling of different file encodings and using multi-line +patterns, this also allows grepping in compressed and remote files. +|:vimgrep|. + +If you want to use the search results in a script you can use the +|getqflist()| function. + +To grep files in various directories the "**" pattern can be used. It expands +into an arbitrary depth of directories. "**" can be used in all places where +file names are expanded, thus also with |:next| and |:args|. + + +Scroll back in messages *new-scroll-back* +----------------------- + +When displaying messages, at the |more-prompt| and the |hit-enter-prompt|, The +'k', 'u', 'g' and 'b' keys can be used to scroll back to previous messages. +This is especially useful for commands such as ":syntax", ":autocommand" and +":highlight". This is implemented in a generic way thus it works for all +commands and highlighting is kept. Only works when the 'more' option is set. +Previously it only partly worked for ":clist". + +The |g<| command can be used to see the last page of messages after you have +hit <Enter> at the |hit-enter-prompt|. Then you can scroll further back. + + +Cursor past end of the line *new-onemore* +--------------------------- + +When the 'virtualedit' option contains "onemore" the cursor can move just past +the end of the line. As if it's on top of the line break. + +This makes some commands more consistent. Previously the cursor was always +past the end of the line if the line was empty. But it is far from Vi +compatible. It may also break some plugins or Vim scripts. Use with care! + +The patch was provided by Mattias Flodin. + + +POSIX compatibility *new-posix* +------------------- + +The POSIX test suite was used to verify POSIX compatibility. A number of +problems have been fixed to make Vim more POSIX compatible. Some of them +conflict with traditional Vi or expected behavior. The $VIM_POSIX environment +variable can be set to get POSIX compatibility. See |posix|. + +Items that were fixed for both Vi and POSIX compatibility: +- repeating "R" with a count only overwrites text once; added the 'X' flag to + 'cpoptions' |cpo-X| +- a vertical movement command that moves to a non-existing line fails; added + the '-' flag to 'cpoptions' |cpo--| +- when preserving a file and doing ":q!" the file can be recovered; added the + '&' flag to 'cpoptions' |cpo-&| +- The 'window' option is partly implemented. It specifies how much CTRL-F and + CTRL-B scroll when there is one window. The "-w {number}" argument is now + accepted. "-w {scriptout}" only works when {scriptout} doesn't start with a + digit. +- Allow "-c{command}" argument, no space between "-c" and {command}. +- When writing a file with ":w!" don't reset 'readonly' when 'Z' is present in + 'cpoptions'. +- Allow 'l' and '#' flags for ":list", ":print" and ":number". +- Added the '.' flag to 'cpoptions': ":cd" fails when the buffer is modified. +- In Ex mode with an empty buffer ":read file" doesn't keep an empty line + above or below the new lines. +- Remove a backslash before a NL for the ":global" command. +- When ":append", ":insert" or ":change" is used with ":global", get the + inserted lines from the command. Can use backslash-NL to separate lines. +- Can use ":global /pat/ visual" to execute Normal mode commands at each + matched line. Use "Q" to continue and go to the next line. +- The |:open| command has been partially implemented. It stops Ex mode, but + redraws the whole screen, not just one line as open mode is supposed to do. +- Support using a pipe to read the output from and write input to an external + command. Added the 'shelltemp' option and has("filterpipe"). +- In ex silent mode the ":set" command output is displayed. +- The ":@@" and ":**" give an error message when no register was used before. +- The search pattern "[]-`]" matches ']', '^', '_' and '`'. +- Autoindent for ":insert" is using the line below the insert. +- Autoindent for ":change" is using the first changed line. +- Editing Ex command lines is not done in cooked mode, because CTRL-D and + CTRL-T cannot be handled then. +- In Ex mode, "1,3" prints three lines. "%" prints all lines. +- In Ex mode "undo" would undo all changes since Ex mode was started. +- Implemented the 'prompt' option. + + +Debugger support *new-debug-support* +---------------- + +The 'balloonexpr' option has been added. This is a generic way to implement +balloon functionality. You can use it to show info for the word under the +mouse pointer. + + +Remote file explorer *new-netrw-explore* +-------------------- + +The netrw plugin now also supports viewing a directory, when "scp://" is used. +Deleting and renaming files is possible. + +To avoid duplicating a lot of code, the previous file explorer plugin has been +integrated in the netrw plugin. This means browsing local and remote files +works the same way. + +":browse edit" and ":browse split" use the netrw plugin when it's available +and a GUI dialog is not possible. + +The netrw plugin is maintained by Charles Campbell. + + +Define an operator *new-define-operator* +------------------ + +Previously it was not possible to define your own operator; a command that is +followed by a {motion}. Vim 7 introduces the 'operatorfunc' option and the +|g@| operator. This makes it possible to define a mapping that works like an +operator. The actual work is then done by a function, which is invoked +through the |g@| operator. + +See |:map-operator| for the explanation and an example. + + +Mapping to an expression *new-map-expression* +------------------------ + +The {rhs} argument of a mapping can be an expression. That means the +resulting characters can depend on the context. Example: > + :inoremap <expr> . InsertDot() +Here the dot will be mapped to whatever InsertDot() returns. + +This also works for abbreviations. See |:map-<expr>| for the details. + + +Visual and Select mode mappings *new-map-select* +------------------------------- + +Previously Visual mode mappings applied both to Visual and Select mode. With +a trick to have the mappings work in Select mode like they would in Visual +mode. + +Commands have been added to define mappings for Visual and Select mode +separately: |:xmap| and |:smap|. With the associated "noremap" and "unmap" +commands. + +The same is done for menus: |:xmenu|, |:smenu|, etc. + + +Location list *new-location-list* +------------- + +The support for a per-window quickfix list (location list) is added. The +location list can be displayed in a location window (similar to the quickfix +window). You can open more than one location list window. A set of commands +similar to the quickfix commands are added to browse the location list. +(Yegappan Lakshmanan) + + +Various new items *new-items-7* +----------------- + +Normal mode commands: ~ + +a", a' and a` New text objects to select quoted strings. |a'| +i", i' and i` (Taro Muraoka) + +CTRL-W <Enter> In the quickfix window: opens a new window to show the + location of the error under the cursor. + +|at| and |it| text objects select a block of text between HTML or XML tags. + +<A-LeftMouse> ('mousemodel' "popup" or "popup-setpos") +<A-RightMouse> ('mousemodel' "extend") + Make a blockwise selection. |<A-LeftMouse>| + +gF Start editing the filename under the cursor and jump + to the line number following the file name. + (Yegappan Lakshmanan) + +CTRL-W F Start editing the filename under the cursor in a new + window and jump to the line number following the file + name. (Yegappan Lakshmanan) + +Insert mode commands: ~ + +CTRL-\ CTRL-O Execute a Normal mode command. Like CTRL-O but + without moving the cursor. |i_CTRL-\_CTRL-O| + +Options: ~ + +'balloonexpr' expression for text to show in evaluation balloon +'completefunc' The name of the function used for user-specified + Insert mode completion. CTRL-X CTRL-U can be used in + Insert mode to do any kind of completion. (Taro + Muraoka) +'completeopt' Enable popup menu and other settings for Insert mode + completion. +'cursorcolumn' highlight column of the cursor +'cursorline' highlight line of the cursor +'formatexpr' expression for formatting text with |gq| and when text + goes over 'textwidth' in Insert mode. +'formatlistpat' pattern to recognize a numbered list for formatting. + (idea by Hugo Haas) +'fsync' Whether fsync() is called after writing a file. + (Ciaran McCreesh) +'guitablabel' expression for text to display in GUI tab page label +'guitabtooltip' expression for text to display in GUI tab page tooltip +'macatsui' Mac: use ATSUI text display functions +'maxcombine' maximum number of combining characters displayed +'maxmempattern' maximum amount of memory to use for pattern matching +'mkspellmem' parameters for |:mkspell| memory use +'mzquantum' Time in msec to schedule MzScheme threads. +'numberwidth' Minimal width of the space used for the 'number' and + 'relativenumber' option. (Emmanuel Renieris) +'omnifunc' The name of the function used for omni completion. +'operatorfunc' function to be called for |g@| operator +'printmbcharset' CJK character set to be used for :hardcopy +'printmbfont' font names to be used for CJK output of :hardcopy +'pumheight' maximum number of items to show in the popup menu +'quoteescape' Characters used to escape quotes inside a string. + Used for the a", a' and a` text objects. |a'| +'shelltemp' whether to use a temp file or pipes for shell commands +'showtabline' whether to show the tab pages line +'spell' switch spell checking on/off +'spellcapcheck' pattern to locate the end of a sentence +'spellfile' file where good and wrong words are added +'spelllang' languages to check spelling for +'spellsuggest' methods for spell suggestions +'synmaxcol' maximum column to look for syntax items; avoids very + slow redrawing when there are very long lines +'tabline' expression for text to display in the tab pages line +'tabpagemax' maximum number of tab pages to open for |-p| +'verbosefile' Log messages in a file. +'wildoptions' "tagfile" value enables listing the file name of + matching tags for CTRL-D command line completion. + (based on an idea from Yegappan Lakshmanan) +'winfixwidth' window with fixed width, similar to 'winfixheight' + + +Ex commands: ~ + +Win32: The ":winpos" command now also works in the console. (Vipin Aravind) + +|:startreplace| Start Replace mode. (Charles Campbell) +|:startgreplace| Start Virtual Replace mode. + +|:0file| Removes the name of the buffer. (Charles Campbell) + +|:diffoff| Switch off diff mode in the current window or in all + windows. + +|:delmarks| Delete marks. + +|:exusage| Help for Ex commands (Nvi command). +|:viusage| Help for Vi commands (Nvi command). + +|:sort| Sort lines in the buffer without depending on an + external command. (partly by Bryce Wagner) + +|:vimgrep| Internal grep command, search for a pattern in files. +|:vimgrepadd| Like |:vimgrep| but don't make a new list. + +|:caddfile| Add error messages to an existing quickfix list + (Yegappan Lakshmanan). +|:cbuffer| Read error lines from a buffer. (partly by Yegappan + Lakshmanan) +|:cgetbuffer| Create a quickfix list from a buffer but don't jump to + the first error. +|:caddbuffer| Add errors from the current buffer to the quickfix + list. +|:cexpr| Read error messages from a Vim expression (Yegappan + Lakshmanan). +|:caddexpr| Add error messages from a Vim expression to an + existing quickfix list. (Yegappan Lakshmanan). +|:cgetexpr| Create a quickfix list from a Vim expression, but + don't jump to the first error. (Yegappan Lakshmanan). + +|:lfile| Like |:cfile| but use the location list. +|:lgetfile| Like |:cgetfile| but use the location list. +|:laddfile| Like |:caddfile| but use the location list. +|:lbuffer| Like |:cbuffer| but use the location list. +|:lgetbuffer| Like |:cgetbuffer| but use the location list. +|:laddbuffer| Like |:caddbuffer| but use the location list. +|:lexpr| Like |:cexpr| but use the location list. +|:lgetexpr| Like |:cgetexpr| but use the location list. +|:laddexpr| Like |:caddexpr| but use the location list. +|:ll| Like |:cc| but use the location list. +|:llist| Like |:clist| but use the location list. +|:lnext| Like |:cnext| but use the location list. +|:lprevious| Like |:cprevious| but use the location list. +|:lNext| Like |:cNext| but use the location list. +|:lfirst| Like |:cfirst| but use the location list. +|:lrewind| Like |:crewind| but use the location list. +|:llast| Like |:clast| but use the location list. +|:lnfile| Like |:cnfile| but use the location list. +|:lpfile| Like |:cpfile| but use the location list. +|:lNfile| Like |:cNfile| but use the location list. +|:lolder| Like |:colder| but use the location list. +|:lnewer| Like |:cnewer| but use the location list. +|:lwindow| Like |:cwindow| but use the location list. +|:lopen| Like |:copen| but use the location list. +|:lclose| Like |:cclose| but use the location list. +|:lmake| Like |:make| but use the location list. +|:lgrep| Like |:grep| but use the location list. +|:lgrepadd| Like |:grepadd| but use the location list. +|:lvimgrep| Like |:vimgrep| but use the location list. +|:lvimgrepadd| Like |:vimgrepadd| but use the location list. +|:lhelpgrep| Like |:helpgrep| but use the location list. +|:lcscope| Like |:cscope| but use the location list. +|:ltag| Jump to a tag and add matching tags to a location list. + +|:undojoin| Join a change with the previous undo block. +|:undolist| List the leafs of the undo tree. + +|:earlier| Go back in time for changes in the text. +|:later| Go forward in time for changes in the text. + +|:for| Loop over a |List|. +|:endfor| + +|:lockvar| Lock a variable, prevents it from being changed. +|:unlockvar| Unlock a locked variable. + +|:mkspell| Create a Vim spell file. +|:spellgood| Add a word to the list of good words. +|:spellwrong| Add a word to the list of bad words +|:spelldump| Dump list of good words. +|:spellinfo| Show information about the spell files used. +|:spellrepall| Repeat a spelling correction for the whole buffer. +|:spellundo| Remove a word from list of good and bad words. + +|:mzscheme| Execute MzScheme commands. +|:mzfile| Execute an MzScheme script file. + +|:nbkey| Pass a key to NetBeans for processing. + +|:profile| Commands for Vim script profiling. +|:profdel| Stop profiling for specified items. + +|:smap| Select mode mapping. +|:smapclear| +|:snoremap| +|:sunmap| + +|:xmap| Visual mode mapping, not used for Select mode. +|:xmapclear| +|:xnoremap| +|:xunmap| + +|:smenu| Select mode menu. +|:snoremenu| +|:sunmenu| + +|:xmenu| Visual mode menu, not used for Select mode. +|:xnoremenu| +|:xunmenu| + +|:tabclose| Close the current tab page. +|:tabdo| Perform a command in every tab page. +|:tabedit| Edit a file in a new tab page. +|:tabnew| Open a new tab page. +|:tabfind| Search for a file and open it in a new tab page. +|:tabnext| Go to the next tab page. +|:tabprevious| Go to the previous tab page. +|:tabNext| Go to the previous tab page. +|:tabfirst| Go to the first tab page. +|:tabrewind| Go to the first tab page. +|:tablast| Go to the last tab page. +|:tabmove| Move the current tab page elsewhere. +|:tabonly| Close all other tab pages. +|:tabs| List the tab pages and the windows they contain. + +Ex command modifiers: ~ + +|:keepalt| Do not change the alternate file. + +|:noautocmd| Do not trigger autocommand events. + +|:sandbox| Execute a command in the sandbox. + +|:tab| When opening a new window create a new tab page. + + +Ex command arguments: ~ + +|++bad| Specify what happens with characters that can't be + converted and illegal bytes. (code example by Yasuhiro + Matsumoto) + Also, when a conversion error occurs or illegal bytes + are found include the line number in the error + message. + + +New and extended functions: ~ + +|add()| append an item to a List +|append()| append List of lines to the buffer +|argv()| without an argument return the whole argument list +|browsedir()| dialog to select a directory +|bufnr()| takes an extra argument: create buffer +|byteidx()| index of a character (Ilya Sher) +|call()| call a function with List as arguments +|changenr()| number of current change +|complete()| set matches for Insert mode completion +|complete_add()| add match for 'completefunc' +|complete_check()| check for key pressed, for 'completefunc' +|copy()| make a shallow copy of a List or Dictionary +|count()| count nr of times a value is in a List or Dictionary +|cursor()| also accepts an offset for 'virtualedit', and + the first argument can be a list: [lnum, col, off] +|deepcopy()| make a full copy of a List or Dictionary +|diff_filler()| returns number of filler lines above line {lnum}. +|diff_hlID()| returns the highlight ID for diff mode +|empty()| check if List or Dictionary is empty +|eval()| evaluate {string} and return the result +|extend()| append one List to another or add items from one + Dictionary to another +|feedkeys()| put characters in the typeahead buffer +|filter()| remove selected items from a List or Dictionary +|finddir()| find a directory in 'path' +|findfile()| find a file in 'path' (Johannes Zellner) +|foldtextresult()| the text displayed for a closed fold at line "lnum" +|function()| make a Funcref out of a function name +|garbagecollect()| cleanup unused |Lists| and |Dictionaries| with circular + references +|get()| get an item from a List or Dictionary +|getbufline()| get a list of lines from a specified buffer + (Yegappan Lakshmanan) +|getcmdtype()| return the current command-line type + (Yegappan Lakshmanan) +|getfontname()| get actual font name being used +|getfperm()| get file permission string (Nikolai Weibull) +|getftype()| get type of file (Nikolai Weibull) +|getline()| with second argument: get List with buffer lines +|getloclist()| list of location list items (Yegappan Lakshmanan) +|getpos()| return a list with the position of cursor, mark, etc. +|getqflist()| list of quickfix errors (Yegappan Lakshmanan) +|getreg()| get contents of a register +|gettabwinvar()| get variable from window in specified tab page. +|has_key()| check whether a key appears in a Dictionary +|haslocaldir()| check if current window used |:lcd| +|hasmapto()| check for a mapping to a string +|index()| index of item in List +|inputlist()| prompt the user to make a selection from a list +|insert()| insert an item somewhere in a List +|islocked()| check if a variable is locked +|items()| get List of Dictionary key-value pairs +|join()| join List items into a String +|keys()| get List of Dictionary keys +|len()| number of items in a List or Dictionary +|map()| change each List or Dictionary item +|maparg()| extra argument: use abbreviation +|mapcheck()| extra argument: use abbreviation +|match()| extra argument: count +|matcharg()| return arguments of |:match| command +|matchend()| extra argument: count +|matchlist()| list with match and submatches of a pattern in a string +|matchstr()| extra argument: count +|max()| maximum value in a List or Dictionary +|min()| minimum value in a List or Dictionary +|mkdir()| create a directory +|pathshorten()| reduce directory names to a single character +|printf()| format text +|pumvisible()| check whether the popup menu is displayed +|range()| generate a List with numbers +|readfile()| read a file into a list of lines +|reltime()| get time value, possibly relative +|reltimestr()| turn a time value into a string +|remove()| remove one or more items from a List or Dictionary +|repeat()| repeat "expr" "count" times (Christophe Poucet) +|reverse()| reverse the order of a List +|search()| extra argument: +|searchdecl()| search for declaration of variable +|searchpair()| extra argument: line to stop searching +|searchpairpos()| return a List with the position of the match +|searchpos()| return a List with the position of the match +|setloclist()| modify a location list (Yegappan Lakshmanan) +|setpos()| set cursor or mark to a position +|setqflist()| modify a quickfix list (Yegappan Lakshmanan) +|settabwinvar()| set variable in window of specified tab page +|sort()| sort a List +|soundfold()| get the sound-a-like equivalent of a word +|spellbadword()| get a badly spelled word +|spellsuggest()| get suggestions for correct spelling +|split()| split a String into a List +|str2nr()| convert a string to a number, base 8, 10 or 16 +|stridx()| extra argument: start position +|strridx()| extra argument: start position +|string()| string representation of a List or Dictionary +|system()| extra argument: filters {input} through a shell command +|tabpagebuflist()| List of buffers in a tab page +|tabpagenr()| number of current or last tab page +|tabpagewinnr()| window number in a tab page +|tagfiles()| List with tags file names +|taglist()| get list of matching tags (Yegappan Lakshmanan) +|tr()| translate characters (Ron Aaron) +|values()| get List of Dictionary values +|winnr()| takes an argument: what window to use +|winrestview()| restore the view of the current window +|winsaveview()| save the view of the current window +|writefile()| write a list of lines into a file + +User defined functions can now be loaded automatically from the "autoload" +directory in 'runtimepath'. See |autoload-functions|. + + +New Vim variables: ~ + +|v:insertmode| used for |InsertEnter| and |InsertChange| autocommands +|v:val| item value in a |map()| or |filter()| function +|v:key| item key in a |map()| or |filter()| function +|v:profiling| non-zero after a ":profile start" command +|v:fcs_reason| the reason why |FileChangedShell| was triggered +|v:fcs_choice| what should happen after |FileChangedShell| +|v:beval_bufnr| buffer number for 'balloonexpr' +|v:beval_winnr| window number for 'balloonexpr' +|v:beval_lnum| line number for 'balloonexpr' +|v:beval_col| column number for 'balloonexpr' +|v:beval_text| text under the mouse pointer for 'balloonexpr' +|v:scrollstart| what caused the screen to be scrolled up +|v:swapname| name of the swap file for the |SwapExists| event +|v:swapchoice| what to do for an existing swap file +|v:swapcommand| command to be executed after handling |SwapExists| +|v:char| argument for evaluating 'formatexpr' + + +New autocommand events: ~ + +|ColorScheme| after loading a color scheme + +|CursorHoldI| the user doesn't press a key for a while in Insert mode +|CursorMoved| the cursor was moved in Normal mode +|CursorMovedI| the cursor was moved in Insert mode + +|FileChangedShellPost| after handling a file changed outside of Vim + +|InsertEnter| starting Insert or Replace mode +|InsertChange| going from Insert to Replace mode or back +|InsertLeave| leaving Insert or Replace mode + +|MenuPopup| just before showing popup menu + +|QuickFixCmdPre| before :make, :grep et al. (Ciaran McCreesh) +|QuickFixCmdPost| after :make, :grep et al. (Ciaran McCreesh) + +|SessionLoadPost| after loading a session file. (Yegappan Lakshmanan) + +|ShellCmdPost| after executing a shell command +|ShellFilterPost| after filtering with a shell command + +|SourcePre| before sourcing a Vim script + +|SpellFileMissing| when a spell file can't be found + +|SwapExists| found existing swap file when editing a file + +|TabEnter| just after entering a tab page +|TabLeave| just before leaving a tab page + +|VimResized| after the Vim window size changed (Yakov Lerner) + + +New highlight groups: ~ + +Pmenu Popup menu: normal item |hl-Pmenu| +PmenuSel Popup menu: selected item |hl-PmenuSel| +PmenuThumb Popup menu: scrollbar |hl-PmenuThumb| +PmenuSbar Popup menu: Thumb of the scrollbar |hl-PmenuSbar| + +TabLine tab pages line, inactive label |hl-TabLine| +TabLineSel tab pages line, selected label |hl-TabLineSel| +TabLineFill tab pages line, filler |hl-TabLineFill| + +SpellBad badly spelled word |hl-SpellBad| +SpellCap word with wrong caps |hl-SpellCap| +SpellRare rare word |hl-SpellRare| +SpellLocal word only exists in other region |hl-SpellLocal| + +CursorColumn 'cursorcolumn' |hl-CursorColumn| +CursorLine 'cursorline' |hl-CursorLine| + +MatchParen matching parens |pi_paren.txt| |hl-MatchParen| + + +New items in search patterns: ~ +|/\%d| \%d123 search for character with decimal number +|/\]| [\d123] idem, in a collection +|/\%o| \%o103 search for character with octal number +|/\]| [\o1o3] idem, in a collection +|/\%x| \%x1a search for character with 2 pos. hex number +|/\]| [\x1a] idem, in a collection +|/\%u| \%u12ab search for character with 4 pos. hex number +|/\]| [\u12ab] idem, in a collection +|/\%U| \%U1234abcd search for character with 8 pos. hex number +|/\]| [\U1234abcd] idem, in a collection + (The above partly by Ciaran McCreesh) + +|/[[=| [[=a=]] an equivalence class (only for latin1 characters) +|/[[.| [[.a.]] a collation element (only works with single char) + +|/\%'m| \%'m match at mark m +|/\%<'m| \%<'m match before mark m +|/\%>'m| \%>'m match after mark m +|/\%V| \%V match in Visual area + +Nesting |/multi| items no longer is an error when an empty match is possible. + +It is now possible to use \{0}, it matches the preceding atom zero times. Not +useful, just for compatibility. + + +New Syntax/Indent/FTplugin files: ~ + +Moved all the indent settings from the filetype plugin to the indent file. +Implemented b:undo_indent to undo indent settings when setting 'filetype' to a +different value. + +a2ps syntax and ftplugin file. (Nikolai Weibull) +ABAB/4 syntax file. (Marius van Wyk) +alsaconf ftplugin file. (Nikolai Weibull) +AppendMatchGroup ftplugin file. (Dave Silvia) +arch ftplugin file. (Nikolai Weibull) +asterisk and asteriskvm syntax file. (Tilghman Lesher) +BDF ftplugin file. (Nikolai Weibull) +BibTeX indent file. (Dorai Sitaram) +BibTeX Bibliography Style syntax file. (Tim Pope) +BTM ftplugin file. (Bram Moolenaar) +calendar ftplugin file. (Nikolai Weibull) +Changelog indent file. (Nikolai Weibull) +ChordPro syntax file. (Niels Bo Andersen) +Cmake indent and syntax file. (Andy Cedilnik) +conf ftplugin file. (Nikolai Weibull) +context syntax and ftplugin file. (Nikolai Weibull) +CRM114 ftplugin file. (Nikolai Weibull) +cvs RC ftplugin file. (Nikolai Weibull) +D indent file. (Jason Mills) +Debian Sources.list syntax file. (Matthijs Mohlmann) +dictconf and dictdconf syntax, indent and ftplugin files. (Nikolai Weibull) +diff ftplugin file. (Bram Moolenaar) +dircolors ftplugin file. (Nikolai Weibull) +django and htmldjango syntax file. (Dave Hodder) +doxygen syntax file. (Michael Geddes) +elinks ftplugin file. (Nikolai Weibull) +eterm ftplugin file. (Nikolai Weibull) +eviews syntax file. (Vaidotas Zemlys) +fetchmail RC ftplugin file. (Nikolai Weibull) +FlexWiki syntax and ftplugin file. (George Reilly) +Generic indent file. (Dave Silvia) +gpg ftplugin file. (Nikolai Weibull) +gretl syntax file. (Vaidotas Zemlys) +groovy syntax file. (Alessio Pace) +group syntax and ftplugin file. (Nikolai Weibull) +grub ftplugin file. (Nikolai Weibull) +Haskell ftplugin file. (Nikolai Weibull) +help ftplugin file. (Nikolai Weibull) +indent ftplugin file. (Nikolai Weibull) +Javascript ftplugin file. (Bram Moolenaar) +Kconfig ftplugin and syntax file. (Nikolai Weibull) +ld syntax, indent and ftplugin file. (Nikolai Weibull) +lftp ftplugin file. (Nikolai Weibull) +libao config ftplugin file. (Nikolai Weibull) +limits syntax and ftplugin file. (Nikolai Weibull) +Lisp indent file. (Sergey Khorev) +loginaccess and logindefs syntax and ftplugin file. (Nikolai Weibull) +m4 ftplugin file. (Nikolai Weibull) +mailaliases syntax file. (Nikolai Weibull) +mailcap ftplugin file. (Nikolai Weibull) +manconf syntax and ftplugin file. (Nikolai Weibull) +matlab ftplugin file. (Jake Wasserman) +Maxima syntax file. (Robert Dodier) +MGL syntax file. (Gero Kuhlmann) +modconf ftplugin file. (Nikolai Weibull) +mplayer config ftplugin file. (Nikolai Weibull) +Mrxvtrc syntax and ftplugin file. (Gautam Iyer) +MuPAD source syntax, indent and ftplugin. (Dave Silvia) +mutt RC ftplugin file. (Nikolai Weibull) +nanorc syntax and ftplugin file. (Nikolai Weibull) +netrc ftplugin file. (Nikolai Weibull) +pamconf syntax and ftplugin file. (Nikolai Weibull) +Pascal indent file. (Neil Carter) +passwd syntax and ftplugin file. (Nikolai Weibull) +PHP compiler plugin. (Doug Kearns) +pinfo ftplugin file. (Nikolai Weibull) +plaintex syntax and ftplugin files. (Nikolai Weibull, Benji Fisher) +procmail ftplugin file. (Nikolai Weibull) +prolog ftplugin file. (Nikolai Weibull) +protocols syntax and ftplugin file. (Nikolai Weibull) +quake ftplugin file. (Nikolai Weibull) +racc syntax and ftplugin file. (Nikolai Weibull) +readline ftplugin file. (Nikolai Weibull) +rhelp syntax file. (Johannes Ranke) +rnoweb syntax file. (Johannes Ranke) +Relax NG compact ftplugin file. (Nikolai Weibull) +Scheme indent file. (Sergey Khorev) +screen ftplugin file. (Nikolai Weibull) +sensors syntax and ftplugin file. (Nikolai Weibull) +services syntax and ftplugin file. (Nikolai Weibull) +setserial syntax and ftplugin file. (Nikolai Weibull) +sieve syntax and ftplugin file. (Nikolai Weibull) +SiSU syntax file (Ralph Amissah) +Sive syntax file. (Nikolai Weibull) +slp config, reg and spi syntax and ftplugin files. (Nikolai Weibull) +SML indent file. (Saikat Guha) +SQL anywhere syntax and indent file. (David Fishburn) +SQL indent file. +SQL-Informix syntax file. (Dean L Hill) +SQL: Handling of various variants. (David Fishburn) +sshconfig ftplugin file. (Nikolai Weibull) +Stata and SMCL syntax files. (Jeff Pitblado) +sudoers ftplugin file. (Nikolai Weibull) +sysctl syntax and ftplugin file. (Nikolai Weibull) +terminfo ftplugin file. (Nikolai Weibull) +trustees syntax file. (Nima Talebi) +Vera syntax file. (David Eggum) +udev config, permissions and rules syntax and ftplugin files. (Nikolai Weibull) +updatedb syntax and ftplugin file. (Nikolai Weibull) +VHDL indent file (Gerald Lai) +WSML syntax file. (Thomas Haselwanter) +Xdefaults ftplugin file. (Nikolai Weibull) +XFree86 config ftplugin file. (Nikolai Weibull) +xinetd syntax, indent and ftplugin file. (Nikolai Weibull) +xmodmap ftplugin file. (Nikolai Weibull) +Xquery syntax file. (Jean-Marc Vanel) +xsd (XML schema) indent file. +YAML ftplugin file. (Nikolai Weibull) +Zsh ftplugin file. (Nikolai Weibull) + + +New Keymaps: ~ + +Sinhala (Sri Lanka) (Harshula Jayasuriya) +Tamil in TSCII encoding (Yegappan Lakshmanan) +Greek in cp737 (Panagiotis Louridas) +Polish-slash (HS6_06) +Ukrainian-jcuken (Anatoli Sakhnik) +Kana (Edward L. Fox) + + +New message translations: ~ + +The Ukrainian messages are now also available in cp1251. +Vietnamese message translations and menu. (Phan Vinh Thinh) + + +Others: ~ + +The |:read| command has the |++edit| argument. This means it will use the +detected 'fileformat', 'fileencoding' and other options for the buffer. This +also fixes the problem that editing a compressed file didn't set these +options. + +The Netbeans interface was updated for Sun Studio 10. The protocol number +goes from 2.2 to 2.3. (Gordon Prieur) + +Mac: When starting up Vim will load the $VIMRUNTIME/macmap.vim script to +define default command-key mappings. (mostly by Benji Fisher) + +Mac: Add the selection type to the clipboard, so that Block, line and +character selections can be used between two Vims. (Eckehard Berns) +Also fixes the problem that setting 'clipboard' to "unnamed" breaks using +"yyp". + +Mac: GUI font selector. (Peter Cucka) + +Mac: support for multi-byte characters. (Da Woon Jung) +This doesn't always work properly. If you see text drawing problems try +switching the 'macatsui' option off. + +Mac: Support the xterm mouse in the non-GUI version. + +Mac: better integration with Xcode. Post a fake mouse-up event after the odoc +event and the drag receive handler to work around a stall after Vim loads a +file. Fixed an off-by-one line number error. (Da Woon Jung) + +Mac: When started from Finder change directory to the file being edited or the +user home directory. + +Added the t_SI and t_EI escape sequences for starting and ending Insert mode. +To be used to set the cursor shape to a bar or a block. No default values, +they are not supported by termcap/terminfo. + +GUI font selector for Motif. (Marcin Dalecki) + +Nicer toolbar buttons for Motif. (Marcin Dalecki) + +Mnemonics for the Motif find/replace dialog. (Marcin Dalecki) + +Included a few improvements for Motif from Marcin Dalecki. Draw label +contents ourselves to make them handle fonts in a way configurable by Vim and +a bit less dependent on the X11 font management. + +Autocommands can be defined local to a buffer. This means they will also work +when the buffer does not have a name or no specific name. See +|autocmd-buflocal|. (Yakov Lerner) + +For xterm most combinations of modifiers with function keys are recognized. +|xterm-modifier-keys| + +When 'verbose' is set the output of ":highlight" will show where a highlight +item was last set. +When 'verbose' is set the output of the ":map", ":abbreviate", ":command", +":function" and ":autocmd" commands will show where it was last defined. +(Yegappan Lakshmanan) + +":function /pattern" lists functions matching the pattern. + +"1gd" can be used like "gd" but ignores matches in a {} block that ends before +the cursor position. Likewise for "1gD" and "gD". + +'scrolljump' can be set to a negative number to scroll a percentage of the +window height. + +The |v:scrollstart| variable has been added to help find the location in +your script that causes the hit-enter prompt. + +To make it possible to handle the situation that a file is being edited that +is already being edited by another Vim instance, the |SwapExists| event has +been added. The |v:swapname|, |v:swapchoice| and |v:swapcommand| variables +can be used, for example to use the |client-server| functionality to bring the +other Vim to the foreground. +When starting Vim with a "-t tag" argument, there is an existing swapfile and +the user selects "quit" or "abort" then exit Vim. + +Undo now also restores the '< and '> marks. "gv" selects the same area as +before the change and undo. + +When editing a search pattern for a "/" or "?" command and 'incsearch' is set +CTRL-L can be used to add a character from the current match. CTRL-R CTRL-W +will add a word, but exclude the part of the word that was already typed. + +Ruby interface: add line number methods. (Ryan Paul) + +The $MYVIMRC environment variable is set to the first found vimrc file. +The $MYGVIMRC environment variable is set to the first found gvimrc file. + +============================================================================== +IMPROVEMENTS *improvements-7* + +":helpgrep" accepts a language specifier after the pattern: "pat@it". + +Moved the help for printing to a separate help file. It's quite a lot now. + +When doing completion for ":!cmd", ":r !cmd" or ":w !cmd" executable files are +found in $PATH instead of looking for ordinary files in the current directory. + +When ":silent" is used and a backwards range is given for an Ex command the +range is swapped automatically instead of asking if that is OK. + +The pattern matching code was changed from a recursive function to an +iterative mechanism. This avoids out-of-stack errors. State is stored in +allocated memory, running out of memory can always be detected. Allows +matching more complex things, but Vim may seem to hang while doing that. + +Previously some options were always evaluated in the |sandbox|. Now that only +happens when the option was set from a modeline or in secure mode. Applies to +'balloonexpr', 'foldexpr', 'foldtext' and 'includeexpr'. (Sumner Hayes) + +Some commands and expressions could have nasty side effects, such as using +CTRL-R = while editing a search pattern and the expression invokes a function +that jumps to another window. The |textlock| has been added to prevent this +from happening. + +":breakadd here" and ":breakdel here" can be used to set or delete a +breakpoint at the cursor. + +It is now possible to define a function with: > + :exe "func Test()\n ...\n endfunc" + +The tutor was updated to make it simpler to use and text was added to explain +a few more important commands. Used ideas from Gabriel Zachmann. + +Unix: When libcall() fails obtain an error message with dlerror() and display +it. (Johannes Zellner) + +Mac and Cygwin: When editing an existing file make the file name the same case +of the edited file. Thus when typing ":e os_UNIX.c" the file name becomes +"os_unix.c". + +Added "nbsp" in 'listchars'. (David Blanchet) + +Added the "acwrite" value for the 'buftype' option. This is for a buffer that +does not have a name that refers to a file and is written with BufWriteCmd +autocommands. + +For lisp indenting and matching parenthesis: (Sergey Khorev) +- square brackets are recognized properly +- #\(, #\), #\[ and #\] are recognized as character literals +- Lisp line comments (delimited by semicolon) are recognized + +Added the "count" argument to match(), matchend() and matchstr(). (Ilya Sher) + +winnr() takes an optional "$" or "#" argument. (Nikolai Weibull, Yegappan +Lakshmanan) + +Added 's' flag to search(): set ' mark if cursor moved. (Yegappan Lakshmanan) +Added 'n' flag to search(): don't move the cursor. (Nikolai Weibull) +Added 'c' flag to search(): accept match at the cursor. +Added 'e' flag to search(): move to end of the match. (Benji Fisher) +Added 'p' flag to search(): return number of sub-pattern. (Benji Fisher) +These also apply to searchpos(), searchpair() and searchpairpos(). + +The search() and searchpair() functions have an extra argument to specify +where to stop searching. Speeds up searches that should not continue too far. + +When uncompressing fails in the gzip plugin, give an error message but don't +delete the raw text. Helps if the file has a .gz extension but is not +actually compressed. (Andrew Pimlott) + +When C, C++ or IDL syntax is used, may additionally load doxygen syntax. +(Michael Geddes) + +Support setting 'filetype' and 'syntax' to "aaa.bbb" for "aaa" plus "bbb" +filetype or syntax. + +The ":registers" command now displays multi-byte characters properly. + +VMS: In the usage message mention that a slash can be used to make a flag +upper case. Add color support to the builtin vt320 terminal codes. +(Zoltan Arpadffy) + +For the '%' item in 'viminfo', allow a number to set a maximum for the number +of buffers. + +For recognizing the file type: When a file looks like a shell script, check +for an "exec" command that starts the tcl interpreter. (suggested by Alexios +Zavras) + +Support conversion between utf-8 and latin9 (iso-8859-15) internally, so that +digraphs still work when iconv is not available. + +When a session file is loaded while editing an unnamed, empty buffer that +buffer is wiped out. Avoids that there is an unused buffer in the buffer +list. + +Win32: When libintl.dll supports bind_textdomain_codeset(), use it. +(NAKADAIRA Yukihiro) + +Win32: Vim was not aware of hard links on NTFS file systems. These are +detected now for when 'backupcopy' is "auto". Also fixed a bogus "file has +been changed since reading it" error for links. + +When foldtext() finds no text after removing the comment leader, use the +second line of the fold. Helps for C-style /* */ comments where the first +line is just "/*". + +When editing the same file from two systems (e.g., Unix and MS-Windows) there +mostly was no warning for an existing swap file, because the name of the +edited file differs (e.g., y:\dir\file vs /home/me/dir/file). Added a flag to +the swap file to indicate it is in the same directory as the edited file. The +used path then doesn't matter and the check for editing the same file is much +more reliable. + +Unix: When editing a file through a symlink the swap file would use the name +of the symlink. Now use the name of the actual file, so that editing the same +file twice is detected. (suggestions by Stefano Zacchiroli and James Vega) + +Client-server communication now supports 'encoding'. When setting 'encoding' +in a Vim server to "utf-8", and using "vim --remote fname" in a console, +"fname" is converted from the console encoding to utf-8. Also allows Vims +with different 'encoding' settings to exchange messages. + +Internal: Changed ga_room into ga_maxlen, so that it doesn't need to be +incremented/decremented each time. + +When a register is empty it is not stored in the viminfo file. + +Removed the tcltags script, it's obsolete. + +":redir @*>>" and ":redir @+>>" append to the clipboard. Better check for +invalid characters after the register name. |:redir| + +":redir => variable" and ":redir =>> variable" write or append to a variable. +(Yegappan Lakshmanan) |:redir| + +":redir @{a-z}>>" appends to register a to z. (Yegappan Lakshmanan) + +The 'verbosefile' option can be used to log messages in a file. Verbose +messages are not displayed then. The "-V{filename}" argument can be used to +log startup messages. + +":let g:" lists global variables. +":let b:" lists buffer-local variables. +":let w:" lists window-local variables. +":let v:" lists Vim variables. + +The stridx() and strridx() functions take a third argument, where to start +searching. (Yegappan Lakshmanan) + +The getreg() function takes an extra argument to be able to get the expression +for the '=' register instead of the result of evaluating it. + +The setline() function can take a List argument to set multiple lines. When +the line number is just below the last line the line is appended. + +g CTRL-G also shows the number of characters if it differs from the number of +bytes. + +Completion for ":debug" and entering an expression for the '=' register. Skip +":" between range and command name. (Peter winters) + +CTRL-Q in Insert mode now works like CTRL-V by default. Previously it was +ignored. + +When "beep" is included in 'debug' a function or script that causes a beep +will result in a message with the source of the error. + +When completing buffer names, match with "\(^\|[\/]\)" instead of "^", so that +":buf stor<Tab>" finds both "include/storage.h" and "storage/main.c". + +To count items (pattern matches) without changing the buffer the 'n' flag has +been added to |:substitute|. See |count-items|. + +In a |:substitute| command the \u, \U, \l and \L items now also work for +multi-byte characters. + +The "screen.linux" $TERM name is recognized to set the default for +'background' to "dark". (Ciaran McCreesh) Also for "cygwin" and "putty". + +The |FileChangedShell| autocommand event can now use the |v:fcs_reason| +variable that specifies what triggered the event. |v:fcs_choice| can be used +to reload the buffer or ask the user what to do. + +Not all modifiers were recognized for xterm function keys. Added the +possibility in term codes to end in ";*X" or "O*X", where X is any character +and the * stands for the modifier code. +Added the <xUp>, <xDown>, <xLeft> and <xRight> keys, to be able to recognize +the two forms that xterm can send their codes in and still handle all possible +modifiers. + +getwinvar() now also works to obtain a buffer-local option from the specified +window. + +Added the "%s" item to 'errorformat'. (Yegappan Lakshmanan) +Added the "%>" item to 'errorformat'. + +For 'errorformat' it was not possible to have a file name that contains the +character that follows after "%f". For example, in "%f:%l:%m" the file name +could not contain ":". Now include the first ":" where the rest of the +pattern matches. In the example a ":" not followed by a line number is +included in the file name. (suggested by Emanuele Giaquinta) + +GTK GUI: use the GTK file dialog when it's available. Mix from patches by +Grahame Bowland and Evan Webb. + +Added ":scriptnames" to bugreport.vim, so that we can see what plugins were +used. + +Win32: If the user changes the setting for the number of lines a scroll wheel +click scrolls it is now used immediately. Previously Vim would need to be +restarted. + +When using @= in an expression the value is expression @= contains. ":let @= += value" can be used to set the register contents. + +A ! can be added to ":popup" to have the popup menu appear at the mouse +pointer position instead of the text cursor. + +The table with encodings has been expanded with many MS-Windows codepages, +such as cp1250 and cp737, so that these can also be used on Unix without +prepending "8bit-". +When an encoding name starts with "microsoft-cp" ignore the "microsoft-" part. + +Added the "customlist" completion argument to a user-defined command. The +user-defined completion function should return the completion candidates as a +Vim List and the returned results are not filtered by Vim. (Yegappan +Lakshmanan) + +Win32: Balloons can have multiple lines if common controls supports it. +(Sergey Khorev) + +For command-line completion the matches for various types of arguments are now +sorted: user commands, variables, syntax names, etc. + +When no locale is set, thus using the "C" locale, Vim will work with latin1 +characters, using its own isupper()/toupper()/etc. functions. + +When using an rxvt terminal emulator guess the value of 'background' using the +COLORFGBG environment variable. (Ciaran McCreesh) + +Also support t_SI and t_EI on Unix with normal features. (Ciaran McCreesh) + +When 'foldcolumn' is one then put as much info in it as possible. This allows +closing a fold with the mouse by clicking on the '-'. + +input() takes an optional completion argument to specify the type of +completion supported for the input. (Yegappan Lakshmanan) + +"dp" works with more than two buffers in diff mode if there is only one where +'modifiable' is set. + +The 'diffopt' option has three new values: "horizontal", "vertical" and +"foldcolumn". + +When the 'include' option contains \zs the file name found is what is being +matched from \zs to the end or \ze. Useful to pass more to 'includeexpr'. + +Loading plugins on startup now supports subdirectories in the plugin +directory. |load-plugins| + +In the foldcolumn always show the '+' for a closed fold, so that it can be +opened easily. It may overwrite another character, esp. if 'foldcolumn' is 1. + +It is now possible to get the W10 message again by setting 'readonly'. Useful +in the FileChangedRO autocommand when checking out the file fails. + +Unix: When open() returns EFBIG give an appropriate message. + +":mksession" sets the SessionLoad variable to notify plugins. A modeline is +added to the session file to set 'filetype' to "vim". + +In the ATTENTION prompt put the "Delete it" choice before "Quit" to make it +more logical. (Robert Webb) + +When appending to a file while the buffer has no name the name of the appended +file would be used for the current buffer. But the buffer contents is +actually different from the file content. Don't set the file name, unless the +'P' flag is present in 'cpoptions'. + +When starting to edit a new file and the directory for the file doesn't exist +then Vim will report "[New DIRECTORY]" instead of "[New File] to give the user +a hint that something might be wrong. + +Win32: Preserve the hidden attribute of the viminfo file. + +In Insert mode CTRL-A didn't keep the last inserted text when using CTRL-O and +then a cursor key. Now keep the previously inserted text if nothing is +inserted after the CTRL-O. Allows using CTRL-O commands to move the cursor +without losing the last inserted text. + +The exists() function now supports checking for autocmd group definition +and for supported autocommand events. (Yegappan Lakshmanan) + +Allow using ":global" in the sandbox, it doesn't do anything harmful by +itself. + +":saveas asdf.c" will set 'filetype' to c when it's empty. Also for ":w +asdf.c" when it sets the filename for the buffer. + +Insert mode completion for whole lines now also searches unloaded buffers. + +The colortest.vim script can now be invoked directly with ":source" or +":runtime syntax/colortest.vim". + +The 'statusline' option can be local to the window, so that each window can +have a different value. (partly by Yegappan Lakshmanan) + +The 'statusline' option and other options that support the same format can now +use these new features: +- When it starts with "%!" the value is first evaluated as an expression + before parsing the value. +- "%#HLname#" can be used to start highlighting with HLname. + +When 'statusline' is set to something that causes an error message then it is +made empty to avoid an endless redraw loop. Also for other options, such at +'tabline' and 'titlestring'. ":verbose set statusline" will mention that it +was set in an error handler. + +When there are several matching tags, the ":tag <name>" and CTRL-] commands +jump to the [count] matching tag. (Yegappan Lakshmanan) + +Win32: In the batch files generated by the install program, use $VIMRUNTIME or +$VIM if it's set. Example provided by Mathias Michaelis. +Also create a vimtutor.bat batch file. + +The 'balloonexpr' option is now |global-local|. + +The system() function now runs in cooked mode, thus can be interrupted by +CTRL-C. + +============================================================================== +COMPILE TIME CHANGES *compile-changes-7* + +Dropped the support for the BeOS and Amiga GUI. They were not maintained and +probably didn't work. If you want to work on this: get the Vim 6.x version +and merge it back in. + +When running the tests and one of them fails to produce "test.out" the +following tests are still executed. This helps when running out of memory. + +When compiling with EXITFREE defined and the ccmalloc library it is possible +to detect memory leaks. Some memory will always reported as leaked, such as +allocated by X11 library functions and the memory allocated in alloc_cmdbuff() +to store the ":quit" command. + +Moved the code for printing to src/hardcopy.c. + +Moved some code from main() to separate functions to make it easier to see +what is being done. Using a structure to avoid a lot of arguments to the +functions. + +Moved unix_expandpath() to misc1.c, so that it can also be used by os_mac.c +without copying the code. + +--- Mac --- + +"make" now creates the Vim.app directory and "make install" copies it to its +final destination. (Raf) + +Put the runtime directory not directly in Vim.app but in +Vim.app/Contents/Resources/vim, so that it's according to Mac specs. + +Made it possible to compile with Motif, Athena or GTK without tricks and still +being able to use the MacRoman conversion. Added the os_mac_conv.c file. + +When running "make install" the runtime files are installed as for Unix. +Avoids that too many files are copied. When running "make" a link to the +runtime files is created to avoid a recursive copy that takes much time. + +Configure will attempt to build Vim for both Intel and PowerPC. The +--with-mac-arch configure argument can change it. + +--- Win32 --- + +The Make_mvc.mak file was adjusted to work with the latest MS compilers, +including the free version of Visual Studio 2005. (George Reilly) + +INSTALLpc.txt was updated for the recent changes. (George Reilly) + +The distributed executable is now produced with the free Visual C++ Toolkit +2003 and other free SDK chunks. msvcsetup.bat was added to support this. + +Also generate the .pdb file that can be used to generate a useful crash report +on MS-Windows. (George Reilly) + +============================================================================== +BUG FIXES *bug-fixes-7* + +When using PostScript printing on MS-DOS the default 'printexpr' used "lpr" +instead of "copy". When 'printdevice' was empty the copy command did not +work. Use "LPT1" then. + +The GTK font dialog uses a font size zero when the font name doesn't include a +size. Use a default size of 10. + +This example in the documentation didn't work: + :e `=foo . ".c" ` +Skip over the expression in `=expr` when looking for comments, |, % and #. + +When ":helpgrep" doesn't find anything there is no error message. + +"L" and "H" did not take closed folds into account. + +Win32: The "-P title" argument stopped at the first title that matched, even +when it doesn't support MDI. + +Mac GUI: CTRL-^ and CTRL-@ did not work. + +"2daw" on "word." at the end of a line didn't include the preceding white +space. + +Win32: Using FindExecutable() doesn't work to find a program. Use +SearchPath() instead. For executable() use $PATHEXT when the program searched +for doesn't have an extension. + +When 'virtualedit' is set, moving the cursor up after appending a character +may move it to a different column. Was caused by auto-formatting moving the +cursor and not putting it back where it was. + +When indent was added automatically and then moving the cursor, the indent was +not deleted (like when pressing ESC). The "I" flag in 'cpoptions' can be used +to make it work the old way. + +When opening a command-line window, 'textwidth' gets set to 78 by the Vim +filetype plugin. Reset 'textwidth' to 0 to avoid lines are broken. + +After using cursor(line, col) moving up/down doesn't keep the same column. + +Win32: Borland C before 5.5 requires using ".u." for LowPart and HighPart +fields. (Walter Briscoe) + +On Sinix SYS_NMLN isn't always defined. Define it ourselves. (Cristiano De +Michele) + +Printing with PostScript may keep the printer waiting for more. Append a +CTRL-D to the printer output. (Mike Williams) + +When converting a string with a hex or octal number the leading '-' was +ignored. ":echo '-05' + 0" resulted in 5 instead of -5. + +Using "@:" to repeat a command line didn't work when it contains control +characters. Also remove "'<,'>" when in Visual mode to avoid that it appears +twice. + +When using file completion for a user command, it would not expand environment +variables like for a regular command with a file argument. + +'cindent': When the argument of a #define looks like a C++ class the next line +is indented too much. + +When 'comments' includes multi-byte characters inserting the middle part and +alignment may go wrong. 'cindent' also suffers from this for right-aligned +items. + +Win32: when 'encoding' is set to "utf-8" getenv() still returns strings in the +active codepage. Convert to utf-8. Also for $HOME. + +The default for 'helplang' was "zh" for both "zh_cn" and "zh_tw". Now use +"cn" or "tw" as intended. + +When 'bin' is set and 'eol' is not set then line2byte() added the line break +after the last line while it's not there. + +Using foldlevel() in a WinEnter autocommand may not work. Noticed when +resizing the GUI shell upon startup. + +Python: Using buffer.append(f.readlines()) didn't work. Allow appending a +string with a trailing newline. The newline is ignored. + +When using the ":saveas f2" command for buffer "f1", the Buffers menu would +contain "f2" twice, one of them leading to "f1". Also trigger the BufFilePre +and BufFilePost events for the alternate buffer that gets the old name. + +strridx() did not work well when the needle is empty. (Ciaran McCreesh) + +GTK: Avoid a potential hang in gui_mch_wait_for_chars() when input arrives +just before it is invoked + +VMS: Occasionally CR characters were inserted in the file. Expansion of +environment variables was not correct. (Zoltan Arpadffy) + +UTF-8: When 'delcombine' is set "dw" only deleted the last combining character +from the first character of the word. + +When using ":sball" in an autocommand only the filetype in one buffer was +detected. Reset did_filetype in enter_buffer(). + +When using ":argdo" and the window already was at the first argument index, +but not actually editing it, the current buffer would be used instead. + +When ":next dir/*" includes many matches, adding the names to the argument +list may take an awful lot of time and can't be interrupted. Allow +interrupting this. + +When editing a file that was already loaded in a buffer, modelines were not +used. Now window-local options in the modeline are set. Buffer-local options +and global options remain unmodified. + +Win32: When 'encoding' is set to "utf-8" in the vimrc file, files from the +command line with non-ASCII characters are not used correctly. Recode the +file names when 'encoding' is set, using the Unicode command line. + +Win32 console: When the default for 'encoding' ends up to be "latin1", the +default value of 'isprint' was wrong. + +When an error message is given while waiting for a character (e.g., when an +xterm reports the number of colors), the hit-enter prompt overwrote the last +line. Don't reset msg_didout in normal_cmd() for K_IGNORE. + +Mac GUI: Shift-Tab didn't work. + +When defining tooltip text, don't translate terminal codes, since it's not +going to be used like a command. + +GTK 2: Check the tooltip text for valid utf-8 characters to avoid getting a +GTK error. Invalid characters may appear when 'encoding' is changed. + +GTK 2: Add a safety check for invalid utf-8 sequences, they can crash pango. + +Win32: When 'encoding' is changed while starting up, use the Unicode command +line to convert the file arguments to 'encoding'. Both for the GUI and the +console version. + +Win32 GUI: latin9 text (iso-8859-15) was not displayed correctly, because +there is no codepage for latin9. Do our own conversion from latin9 to UCS2. + +When two versions of GTK+ 2 are installed it was possible to use the header +files from one and the library from the other. Use GTK_LIBDIR to put the +directory for the library early in the link flags. + +With the GUI find/replace dialog a replace only worked if the pattern was +literal text. Now it works for any pattern. + +When 'equalalways' is set and 'eadirection' is "hor", ":quit" would still +cause equalizing window heights in the vertical direction. + +When ":emenu" is used in a startup script the command was put in the typeahead +buffer, causing a prompt for the crypt key to be messed up. + +Mac OS/X: The default for 'isprint' included characters 128-160, causes +problems for Terminal.app. + +When a syntax item with "containedin" is used, it may match in the start or +end of a region with a matchgroup, while this doesn't happen for a "contains" +argument. + +When a transparent syntax items matches in another item where the highlighting +has already stopped (because of a he= argument), the highlighting would come +back. + +When cscope is used to set the quickfix error list, it didn't get set if there +was only one match. (Sergey Khorev) + +When 'confirm' is set and using ":bdel" in a modified buffer, then selecting +"cancel", would still give an error message. + +The PopUp menu items that started Visual mode didn't work when not in Normal +mode. Switching between selecting a word and a line was not possible. + +Win32: The keypad decimal point always resulted in a '.', while on some +keyboards it's a ','. Use MapVirtualKey(VK_DECIMAL, 2). + +Removed unused function DisplayCompStringOpaque() from gui_w32.c + +In Visual mode there is not always an indication whether the line break is +selected or not. Highlight the character after the line when the line break +is included, e.g., after "v$o". + +GTK: The <F10> key can't be mapped, it selects the menu. Disable that with a +GTK setting and do select the menu when <F10> isn't mapped. (David Necas) + +After "Y" '[ and '] were not at start/end of the yanked text. + +When a telnet connection is dropped Vim preserves files and exits. While +doing that a SIGHUP may arrive and disturb us, thus ignore it. (Scott +Anderson) Also postpone SIGHUP, SIGQUIT and SIGTERM until it's safe to +handle. Added handle_signal(). + +When completing a file name on the command line backslashes are required for +white space. Was only done for a space, not for a Tab. + +When configure could not find a terminal library, compiling continued for a +long time before reporting the problem. Added a configure check for tgetent() +being found in a library. + +When the cursor is on the first char of the last line a ":g/pat/s///" command +may cause the cursor to be displayed below the text. + +Win32: Editing a file with non-ASCII characters doesn't work when 'encoding' +is "utf-8". use _wfullpath() instead of _fullpath(). (Yu-sung Moon) + +When recovering the 'fileformat' and 'fileencoding' were taken from the +original file instead of from the swapfile. When the file didn't exist, was +empty or the option was changed (e.g., with ":e ++fenc=cp123 file") it could +be wrong. Now store 'fileformat' and 'fileencoding' in the swapfile and use +the values when recovering. + +":bufdo g/something/p" overwrites each last printed text line with the file +message for the next buffer. Temporarily clear 'shortmess' to avoid that. + +Win32: Cannot edit a file starting with # with --remote. Do escape % and # +when building the ":drop" command. + +A comment or | just after an expression-backtick argument was not recognized. +E.g. in :e `="foo"`"comment. + +"(" does not stop at an empty sentence (single dot and white space) while ")" +does. Also breaks "das" on that dot. + +When doing "yy" with the cursor on a TAB the ruler could be wrong and "k" +moved the cursor to another column. + +When 'commentstring' is '"%s' and there is a double quote in the line a double +quote before the fold marker isn't removed in the text displayed for a closed +fold. + +In Visual mode, when 'bin' and 'eol' set, g CTRL-G counted the last line +break, resulting in "selected 202 of 201 bytes". + +Motif: fonts were not used for dialog components. (Marcin Dalecki) + +Motif: After using a toolbar button the keyboard focus would be on the toolbar +(Lesstif problem). (Marcin Dalecki) + +When using "y<C-V>`x" where mark x is in the first column, the last line was +not included. + +Not all test scripts work properly on MS-Windows when checked out from CVS. +Use a Vim command to fix all fileformats to dos before executing the tests. + +When using ":new" and the file fits in the window, lines could still be above +the window. Now remove empty lines instead of keeping the relative position. + +Cmdline completion didn't work after ":let var1 var<Tab>". + +When using ":startinsert" or ":startreplace" when already in Insert mode +(possible when using CTRL-R =), pressing Esc would directly restart Insert +mode. (Peter Winters) + +"2daw" didn't work at end of file if the last word is a single character. + +Completion for ":next a'<Tab>" put a backslash before single quote, but it was +not removed when editing a file. Now halve backslashes in save_patterns(). +Also fix expanding a file name with the shell that contains "\'". + +When doing "1,6d|put" only "fewer lines" was reported. Now a following "more +lines" overwrites the message. + +Configure could not handle "-Dfoo=long\ long" in the TCL config output. + +When searching backwards, using a pattern that matches a newline and uses \zs +after that, didn't find a match. Could also get a hang or end up in the right +column in the wrong line. + +When $LANG is "sl" for slovenian, the slovak menu was used, since "slovak" +starts with "sl". + +When 'paste' is set in the GUI the Paste toolbar button doesn't work. Clear +'paste' when starting the GUI. + +A message about a wrong viminfo line included the trailing NL. + +When 'paste' is set in the GUI the toolbar button doesn't work in Insert mode. +Use ":exe" in menu.vim to avoid duplicating the commands, instead of using a +mapping. + +Treat "mlterm" as an xterm-like terminal. (Seiichi Sato) + +":z.4" and ":z=4" didn't work Vi compatible. + +When sourcing a file, editing it and sourcing it again, it could appear twice +in ":scriptnames" and get a new <SID>, because the inode has changed. + +When $SHELL is set but empty the 'shell' option would be empty. Don't use an +empty $SHELL value. + +A command "w! file" in .vimrc or $EXINIT didn't work. Now it writes an empty +file. + +When a CTRL-F command at the end of the file failed, the cursor was still +moved to the start of the line. Now it remains where it is. + +When using ":s" or "&" to repeat the last substitute and "$" was used to put +the cursor in the last column, put the cursor in the last column again. This +is Vi compatible. + +Vim is not fully POSIX compliant but sticks with traditional Vi behavior. +Added a few flags in 'cpoptions' to behave the POSIX way when wanted. The +$VIM_POSIX environment variable is checked to set the default. + +Appending to a register didn't insert a line break like Vi. Added the '>' +flag to 'cpoptions' for this. + +Using "I" in a line with only blanks appended to the line. This is not Vi +compatible. Added the 'H' flag in 'coptions' for this. + +When joining multiple lines the cursor would be at the last joint, but Vi +leaves it at the position where "J" would put it. Added the 'q' flag in +'cpoptions' for this. + +Autoindent didn't work for ":insert" and ":append". + +Using ":append" in an empty buffer kept the dummy line. Now it's deleted to +be Vi compatible. + +When reading commands from a file and stdout goes to a terminal, would still +request the xterm version. Vim can't read it, thus the output went to the +shell and caused trouble there. + +When redirecting to a register with an invalid name the redirection would +still be done (after an error message). Now reset "redir_reg". (Yegappan +Lakshmanan) + +It was not possible to use a NL after a backslash in Ex mode. This is +sometimes used to feed multiple lines to a shell command. + +When 'cmdheight' is set to 2 in .vimrc and the GUI uses the number of lines +from the terminal we actually get 3 lines for the cmdline in gvim. + +When setting $HOME allocated memory would leak. + +Win32: bold characters may sometimes write in another character cell. Use +unicodepdy[] as for UTF-8. (Taro Muraoka) + +":w fname" didn't work for files with 'buftype' set to "nofile". + +The method used to locate user commands for completion differed from when they +are executed. Ambiguous command names were not completed properly. + +Incremental search may cause a crash when there is a custom statusline that +indirectly invokes ":normal". + +Diff mode failed when $DIFF_OPTIONS was set in the environment. Unset it +before invoking "diff". + +Completion didn't work after ":argdo", ":windo" and ":bufdo". Also for ":set +&l:opt" and ":set &g:opt". (Peter Winters) + +When setting 'ttymouse' to "dec" in an xterm that supports the DEC mouse +locator it doesn't work. Now switch off the mouse before selecting another +mouse model. + +When the CursorHold event is triggered and the commands peek for typed +characters the typeahead buffer may be messed up, e.g., when a mouse-up event +is received. Avoid invoking the autocommands from the function waiting for a +character, let it put K_CURSORHOLD in the input buffer. + +Removed the "COUNT" flag from ":argadd", to avoid ":argadd 1*" to be used like +":1argadd *". Same for ":argdelete" and ":argedit". + +Avoid that $LANG is used for the menus when LC_MESSAGES is "en_US". + +Added backslashes before dashes in the vim.1 manual page to make the appear as +real dashes. (Pierr Habouzit) + +Where "gq" left the cursor depended on the value of 'formatprg'. Now "gq" +always leaves the cursor at the last line of the formatted text. + +When editing a compressed file, such as "changelog.Debian.gz" file, filetype +detection may try to check the contents of the file while it's still +compressed. Skip setting 'filetype' for compressed files until they have been +decompressed. Required for patterns that end in a "*". + +Starting with an argument "+cmd" or "-S script" causes the cursor the be moved +to the first line. That breaks a BufReadPost autocommand that uses g`". +Don't move the cursor if it's somewhere past the first line. + +"gg=G" while 'modifiable' is off was uninterruptible. + +When 'encoding' is "sjis" inserting CTRL-V u d800 a few times causes a crash. +Don't insert a DBCS character with a NUL second byte. + +In Insert mode CTRL-O <Home> didn't move the cursor. Made "ins_at_eol" global +and reset it in nv_home(). + +Wildcard expansion failed: ":w /tmp/$$.`echo test`". Don't put quotes around +spaces inside backticks. + +After this sequence of commands: Y V p gv: the wrong line is selected. Now +let "gv" select the text that was put, since the original text is deleted. +This should be the most useful thing to do. + +":sleep 100u" sleeps for 100 seconds, not 100 usec as one might expect. Give +an error message when the argument isn't recognized. + +In gui_mch_draw_string() in gui_w32.c "unibuflen" wasn't static, resulting in +reallocating the buffer every time. (Alexei Alexandrov) + +When using a Python "atexit" function it was not invoked when Vim exits. Now +call Py_Finalize() for that. (Ugo Di Girolamo) +This breaks the thread stuff though, fixed by Ugo. + +GTK GUI: using a .vimrc with "set cmdheight=2 lines=43" and ":split" right +after startup, the window layout is messed up. (Michael Schaap) Added +win_new_shellsize() call in gui_init() to fix the topframe size. + +Trick to get ...MOUSE_NM not used when there are vertical splits. Now pass +column -1 for the left most window and add MOUSE_COLOFF for others. Limits +mouse column to 10000. + +searchpair() may hang when the end pattern has "\zs" at the end. Check that +we find the same position again and advance one character. + +When in diff mode and making a change that causes the "changed" highlighting +to disappear or reappear, it was still highlighted in another window. + +When a ":next" command fails because the user selects "Abort" at the ATTENTION +prompt the argument index was advanced anyway. + +When "~" is in 'iskeyword' the "gd" doesn't work, it's used for the previous +substitute pattern. Put "\V" in the pattern to avoid that. + +Use of sprintf() sometimes didn't check properly for buffer overflow. Also +when using smsg(). Included code for snprintf() to avoid having to do size +checks where invoking them + +":help \=<Tab>" didn't find "sub-replace-\=". Wild menu for help tags didn't +show backslashes. ":he :s\=" didn't work. + +When reading an errorfile "~/" in a file name was not expanded. + +GTK GUI: When adding a scrollbar (e.g. when using ":vsplit") in a script or +removing it the window size may change. GTK sends us resize events when we +change the window size ourselves, but they may come at an unexpected moment. +Peek for a character to get any window resize events and fix 'columns' and +'lines' to undo this. + +When using the GTK plug mechanism, resizing and focus was not working +properly. (Neil Bird) + +After deleting files from the argument list a session file generated with +":mksession" may contain invalid ":next" commands. + +When 'shortmess' is empty and 'keymap' set to accents, in Insert mode CTRL-N +may cause the hit-enter prompt. Typing 'a then didn't result in the accented +character. Put the character typed at the prompt back in the typeahead buffer +so that mapping is done in the right mode. + +setbufvar() and setwinvar() did not give error messages. + +It was possible to set a variable with an illegal name, e.g. with setbufvar(). +It was possible to define a function with illegal name, e.t. ":func F{-1}()" + +CTRL-W F and "gf" didn't use the same method to get the file name. + +When reporting a conversion error the line number of the last error could be +given. Now report the first encountered error. + +When using ":e ++enc=name file" and iconv() was used for conversion an error +caused a fall-back to no conversion. Now replace a character with '?' and +continue. + +When opening a new buffer the local value of 'bomb' was not initialized from +the global value. + +Win32: When using the "Edit with Vim" entry the file name was limited to about +200 characters. + +When using command line completion for ":e *foo" and the file "+foo" exists +the resulting command ":e +foo" doesn't work. Now insert a backslash: ":e +\+foo". + +When the translation of "-- More --" was not 10 characters long the following +message would be in the wrong position. + +At the more-prompt the last character in the last line wasn't drawn. + +When deleting non-existing text while 'virtualedit' is set the '[ and '] marks +were not set. + +Win32: Could not use "**/" in 'path', it had to be "**\". + +The search pattern "\n" did not match at the end of the last line. + +Searching for a pattern backwards, starting on the NUL at the end of the line +and 'encoding' is "utf-8" would match the pattern just before it incorrectly. +Affected searchpair('/\*', '', '\*/'). + +For the Find/Replace dialog it was possible that not finding the text resulted +in an error message while redrawing, which cleared the syntax highlighting +while it was being used, resulting in a crash. Now don't clear syntax +highlighting, disable it with b_syn_error. + +Win32: Combining UTF-8 characters were drawn on the previous character. +Could be noticed with a Thai font. + +Output of ":function" could leave some of the typed text behind. (Yegappan +Lakshmanan) + +When the command line history has only a few lines the command line window +would be opened with these lines above the first window line. + +When using a command line window for search strings ":qa" would result in +searching for "qa" instead of quitting all windows. + +GUI: When scrolling with the scrollbar and there is a line that doesn't fit +redrawing may fail. Make sure w_skipcol is valid before redrawing. + +Limit the values of 'columns' and 'lines' to avoid an overflow in Rows * +Columns. Fixed bad effects when running out of memory (command line would be +reversed, ":qa!" resulted in ":!aq"). + +Motif: "gvim -iconic" opened the window anyway. (David Harrison) + +There is a tiny chance that a symlink gets created between checking for an +existing file and creating a file. Use the O_NOFOLLOW for open() if it's +available. + +In an empty line "ix<CTRL-O>0" moved the cursor to after the line instead of +sticking to the first column. + +When using ":wq" and a BufWriteCmd autocmd uses inputsecret() the text was +echoed anyway. Set terminal to raw mode in getcmdline(). + +Unix: ":w a;b~c" caused an error in expanding wildcards. + +When appending to a file with ":w >>fname" in a buffer without a name, causing +the buffer to use "fname", the modified flag was reset. + +When appending to the current file the "not edited" flag would be reset. +":w" would overwrite the file accidentally. + +Unix: When filtering text with an external command Vim would still read input, +causing text typed for the command (e.g., a password) to be eaten and echoed. +Don't read input when the terminal is in cooked mode. + +The Cygwin version of xxd used CR/LF line separators. (Corinna Vinschen) + +Unix: When filtering text through a shell command some resulting text may be +dropped. Now after detecting that the child has exited try reading some more +of its output. + +When inside input(), using "CTRL-R =" and the expression throws an exception +the command line was not abandoned but it wasn't used either. Now abandon +typing the command line. + +'delcombine' was also used in Visual and Select mode and for commands like +"cl". That was illogical and has been disabled. + +When recording while a CursorHold autocommand was defined special keys would +appear in the register. Now the CursorHold event is not triggered while +recording. + +Unix: the src/configure script used ${srcdir-.}, not all shells understand +that. Use ${srcdir:-.} instead. + +When editing file "a" which is a symlink to file "b" that doesn't exist, +writing file "a" to create "b" and then ":split b" resulted in two buffers on +the same file with two different swapfile names. Now set the inode in the +buffer when creating a new file. + +When 'esckeys' is not set don't send the xterm code to request the version +string, because it may cause trouble in Insert mode. + +When evaluating an expression for CTRL-R = on the command line it was possible +to call a function that opens a new window, resulting in errors for +incremental search, and many other nasty things were possible. Now use the +|textlock| to disallow changing the buffer or jumping to another window +to protect from unexpected behavior. Same for CTRL-\ e. + +"d(" deleted the character under the cursor, while the documentation specified +an exclusive motion. Vi also doesn't delete the character under the cursor. + +Shift-Insert in Insert mode could put the cursor before the last character +when it just fits in the window. In coladvance() don't stop at the window +edge when filling with spaces and when in Insert mode. In mswin.vim avoid +getting a beep from the "l" command. + +Win32 GUI: When Alt-F4 is used to close the window and Cancel is selected in +the dialog then Vim would insert <M-F4> in the text. Now it's ignored. + +When ":silent! {cmd}" caused the swap file dialog, which isn't displayed, +there would still be a hit-enter prompt. + +Requesting the termresponse (|t_RV|) early may cause problems with "-c" +arguments that invoke an external command or even "-c quit". Postpone it +until after executing "-c" arguments. + +When typing in Insert mode so that a new line is started, using CTRL-G u to +break undo and start a new change, then joining the lines with <BS> caused +undo info to be missing. Now reset the insertion start point. + +Syntax HL: When a region start match has a matchgroup and an offset that +happens to be after the end of the line then it continued in the next line and +stopped at the region end match, making the region continue after that. +Now check for the column being past the end of the line in syn_add_end_off(). + +When changing a file, setting 'swapfile' off and then on again, making another +change and killing Vim, then some blocks may be missing from the swapfile. +When 'swapfile' is switched back on mark all blocks in the swapfile as dirty. +Added mf_set_dirty(). + +Expanding wildcards in a command like ":e aap;<>!" didn't work. Put +backslashes before characters that are special to the shell. (Adri Verhoef) + +A CursorHold autocommand would cause a message to be cleared. Don't show the +special key for the event for 'showcmd'. + +When expanding a file name for a shell command, as in "!cmd foo<Tab>" or ":r +!cmd foo<Tab>" also escape characters that are special for the shell: +"!;&()<>". + +When the name of the buffer was set by a ":r fname" command |cpo-f| no +autocommands were triggered to notify about the change in the buffer list. + +In the quickfix buffer 'bufhidden' was set to "delete", which caused closing +the quickfix window to leave an unlisted "No Name" buffer behind every time. + +Win32: when using two screens of different size, setting 'lines' to a large +value didn't fill the whole screen. (SungHyun Nam) + +Win32 installer: The generated _vimrc contained an absolute path to diff.exe. +After upgrading it becomes invalid. Now use $VIMRUNTIME instead. + +The command line was cleared to often when 'showmode' was set and ":silent +normal vy" was used. Don't clear the command line unless the mode was +actually displayed. Added the "mode_displayed" variable. + +The "load session" toolbar item could not handle a space or other special +characters in v:this_session. + +":set sta ts=8 sw=4 sts=2" deleted 4 spaces halfway a line instead of 2. + +In a multi-byte file the foldmarker could be recognized in the trail byte. +(Taro Muraoka) + +Pasting with CTRL-V and menu didn't work properly when some commands are +mapped. Use ":normal!" instead of ":normal". (Tony Apuzzo) + +Crashed when expanding a file name argument in backticks. + +In some situations the menu and scrollbar didn't work, when the value contains +a CSI byte. (Yukihiro Nakadaira) + +GTK GUI: When drawing the balloon focus changes and we might get a key release +event that removed the balloon again. Ignore the key release event. + +'titleold' was included in ":mkexrc" and ":mksession" files. + +":set background&" didn't use the same logic as was used when starting up. + +When "umask" is set such that nothing is writable then the viminfo file would +be written without write permission. (Julian Bridle) + +Motif: In diff mode dragging one scrollbar didn't update the scrollbar of the +other diff'ed window. + +When editing in an xterm with a different number of colors than expected the +screen would be cleared and redrawn, causing the message about the edited file +to be cleared. Now set "keep_msg" to redraw the last message. + +For a color terminal: When the Normal HL uses bold, possibly to make the color +lighter, and another HL group specifies a color it might become light as well. +Now reset bold if a HL group doesn't specify bold itself. + +When using 256 color xterm the color 255 would show up as color 0. Use a +short instead of a char to store the color number. + +ml_get errors when searching for "\n\zs" in an empty file. + +When selecting a block and using "$" to select until the end of every line and +not highlighting the character under the cursor the first character of the +block could be unhighlighted. + +When counting words for the Visual block area and using "$" to select until +the end of every line only up to the length of the last line was counted. + +"dip" in trailing empty lines left one empty line behind. + +The script ID was only remembered globally for each option. When a buffer- or +window-local option was set the same "last set" location was changed for all +buffers and windows. Now remember the script ID for each local option +separately. + +GUI: The "Replace All" button didn't handle backslashes in the replacement in +the same way as "Replace". Escape backslashes so that they are taken +literally. + +When using Select mode from Insert mode and typing a key, causing lines to be +deleted and a message displayed, delayed the effect of inserting the key. +Now overwrite the message without delay. + +When 'whichwrap' includes "l" then "dl" and "yl" on a single letter line +worked differently. Now recognize all operators when using "l" at the end of +a line. + +GTK GUI: when the font selector returned a font name with a comma in it then +it would be handled like two font names. Now put a backslash before the +comma. + +MS-DOS, Win32: When 'encoding' defaults to "latin1" then the value for +'iskeyword' was still for CPxxx. And when 'nocompatible' was set 'isprint' +would also be the wrong value. + +When a command was defined not to take arguments and no '|' no warning message +would be given for using a '|'. Also with ":loadkeymap". + +Motif: When using a fontset and 'encoding' is "utf-8" and sizeof(wchar_t) != +sizeof(XChar2b) then display was wrong. (Yukihiro Nakadaira) + +":all" always set the current window to the first window, even when it +contains a buffer that is not in the argument list (can't be closed because it +is modified). Now go to the window that has the first item of the argument +list. + +GUI: To avoid left-over pixels from bold text all characters after a character +with special attributes were redrawn. Now only do this for characters that +actually are bold. Speeds up displaying considerably. + +When only highlighting changes and the text is scrolled at the same time +everything is redraw instead of using a scroll and updating the changed text. +E.g., when using ":match" to highlight a paren that the cursor landed on. +Added SOME_VALID: Redraw the whole window but also try to scroll to minimize +redrawing. + +Win32: When using Korean IME making it active didn't work properly. (Moon, +Yu-sung, 2005 March 21) + +Ruby interface: when inserting/deleting lines display wasn't updated. (Ryan +Paul) + +--- fixes since Vim 7.0b --- + +Getting the GCC version in configure didn't work with Solaris sed. First +strip any "darwin." and then get the version number. + +The "autoload" directory was missing from the self-installing executable for +MS-Windows. + +The MS-Windows install program would find "vimtutor.bat" in the install +directory. After changing to "c:" also change to "\" to avoid looking in the +install directory. + +To make the 16 bit DOS version compile exclude not used highlight +initializations and build a tiny instead of small version. + +finddir() and findfile() accept a negative count and return a List then. + +The Python indent file contained a few debugging statements, removed. + +Expanding {} for a function name, resulting in a name starting with "s:" was +not handled correctly. + +Spelling: renamed COMPOUNDMAX to COMPOUNDWORDMAX. Added several items to be +able to handle the new Hungarian dictionary. + +Mac: Default to building for the current platform only, that is much faster +than building a universal binary. Also, using Perl/Python/etc. only works for +the current platform. + +The time on undo messages disappeared for someone. Using %T for strftime() +apparently doesn't work everywhere. Use %H:%M:%S instead. + +Typing BS at the "z=" prompt removed the prompt. + +--- fixes and changes since Vim 7.0c --- + +When jumping to another tab page the Vim window size was always set, even when +nothing in the layout changed. + +Win32 GUI tab pages line wasn't always enabled. Do a proper check for the +compiler version. + +Win32: When switching between tab pages the Vim window was moved when part of +it was outside of the screen. Now only do that in the direction of a size +change. + +Win32: added menu to GUI tab pages line. (Yegappan Lakshmanan) + +Mac: Added document icons. (Benji Fisher) + +Insert mode completion: Using Enter to accept the current match causes +confusion. Use CTRL-Y instead. Also, use CTRL-E to go back to the typed +text. + +GUI: When there are left and right scrollbars, ":tabedit" kept them instead of +using the one that isn't needed. + +Using "gP" to replace al the text could leave the cursor below the last line, +causing ml_get errors. + +When 'cursorline' is set don't use the highlighting when Visual mode is +active, otherwise it's difficult to see the selected area. + +The matchparen plugin restricts the search to 100 lines, to avoid a long delay +when there are closed folds. + +Sometimes using CTRL-X s to list spelling suggestions used text from another +line. + +Win32: Set the default for 'isprint' back to the wrong default "@,~-255", +because many people use Windows-1252 while 'encoding' is "latin1". + +GTK: Added a workaround for gvim crashing when used over an untrusted ssh +link, caused by GTK doing something nasty. (Ed Catmur) + +Win32: The font used for the tab page labels is too big. Use the system menu +font. (George Reilly) + +Win32: Adjusting the window position and size to keep it on the screen didn't +work properly when the taskbar is on the left or top of the screen. + +The installman.sh and installml.sh scripts use ${10}, that didn't work with +old shells. And use "test -f" instead of "test -e". + +Win32: When 'encoding' was set in the vimrc then a directory argument for diff +mode didn't work. + +GUI: at the inputlist() prompt the cursorshape was adjusted as if the windows +were still at their old position. + +The parenmatch plugin didn't remember the highlighting per window. + +Using ":bd" for a buffer that's the current window in another tab page caused +a crash. + +For a new tab page the 'scroll' option wasn't set to a good default. + +Using an end offset for a search "/pat/e" didn't work properly for multi-byte +text. (Yukihiro Nakadaira) + +":s/\n/,/" doubled the text when used on the last line. + +When "search" is in 'foldopen' "[s" and "]s" now open folds. + +When using a numbered function "dict" can be omitted, but "self" didn't work +then. Always add FC_DICT to the function flags when it's part of a +dictionary. + +When "--remote-tab" executes locally it left an empty tab page. + +"gvim -u NONE", ":set cursorcolumn", "C" in the second line didn't update +text. Do update further lines even though the "$" is displayed. + +VMS: Support GTK better, also enable +clientserver. (Zoltan Arpadffy) + +When highlighting of statusline or tabline is changed there was no redraw to +show the effect. + +Mac: Added "CFBundleIdentifier" to infplist.xml. + +Added tabpage-local variables t:var. + +Win32: Added double-click in tab pages line creates new tab. (Yegappan +Lakshmanan) + +Motif: Added GUI tab pages line. (Yegappan Lakshmanan) + +Fixed crash when 'lines' was set to 1000 in a modeline. + +When init_spellfile() finds a writable directory in 'runtimepath' but it +doesn't contain a "spell" directory, create one. + +Win32: executable() also finds "xxd" in the directory where Vim was started, +but "!xxd" doesn't work. Append the Vim starting directory to $PATH. + +The tab page labels are shortened, directory names are reduced to a single +letter by default. Added the pathshorten() function to allow a user to do the +same. + +":saveas" now resets 'readonly' if the file was successfully written. + +Set $MYVIMRC file to the first found .vimrc file. +Set $MYGVIMRC file to the first found .gvimrc file. +Added menu item "Startup Settings" that edits the $MYVIMRC file + +Added matcharg(). + +Error message E745 appeared twice. Renamed one to E786. + +Fixed crash when using "au BufRead * Sexplore" and doing ":help". Was wiping +out a buffer that's still in a window. + +":hardcopy" resulted in an error message when 'encoding' is "utf-8" and +'printencoding' is empty. Now it assumes latin1. (Mike Williams) + +The check for the toolbar feature for Motif, depending on certain included +files, wasn't detailed enough, causing building to fail in gui_xmebw.c. + +Using CTRL-E in Insert mode completion after CTRL-P inserted the first match +instead of the original text. + +When displaying a UTF-8 character with a zero lower byte Vim might think the +previous character is double-wide. + +The "nbsp" item of 'listchars' didn't work when 'encoding' was utf-8. + +Motif: when Xm/xpm.h is missing gui_xmebw.c would not compile. +HAVE_XM_UNHIGHLIGHTT_H was missing a T. + +Mac: Moved the .icns files into src/os_mac_rsrc, so that they can all be +copied at once. Adjusted the Info.plist file for three icons. + +When Visual mode is active while switching to another tabpage could get ml_get +errors. + +When 'list' is set, 'nowrap' the $ in the first column caused 'cursorcolumn' +to move to the right. + +When a line wraps, 'cursorcolumn' was never displayed past the end of the +line. + +'autochdir' was only available when compiled with NetBeans and GUI. Now it's +a separate feature, also available in the "big" version. + +Added CTRL-W gf: open file under cursor in new tab page. + +When using the menu in the tab pages line, "New Tab" opens the new tab before +where the click was. Beyond the labels the new tab appears at the end instead +of after the current tab page. + +Inside a mapping with an expression getchar() could not be used. + +When vgetc is used recursively vgetc_busy protects it from being used +recursively. But after a ":normal" command the protection was reset. + +":s/a/b/n" didn't work when 'modifiable' was off. + +When $VIMRUNTIME includes a multi-byte character then rgb.txt could not be +found. (Yukihiro Nakadaira) + +":mkspell" didn't work correctly for non-ASCII affix flags when conversion is +needed on the spell file. + +glob('/dir/\$ABC/*') didn't work. + +When using several tab pages and changing 'cmdheight' the display could become +messed up. Now store the value of 'cmdheight' separately for each tab page. + +The user of the Enter key while the popup menu is visible was still confusing. +Now use Enter to select the match after using a cursor key. + +Added "usetab" to 'switchbuf'. + + +--- fixes and changes since Vim 7.0d --- + +Added CTRL-W T: move a window to a new tab page. + +Using CTRL-X s in Insert mode to complete spelling suggestions and using BS +deleted characters before the bad word. + +A few small fixes for the VMS makefile. (Zoltan Arpadffy) + +With a window of 91 lines 45 cols, ":vsp" scrolled the window. Copy w_wrow +when splitting a window and skip setting the height when it's already at the +right value. + +Using <silent> in a mapping with a shell command and the GUI caused redraw +to use wrong attributes. + +Win32: Using MSVC 4.1 for install.exe resulted in the start menu items to be +created in the administrator directory instead of "All Users". Define the +CSIDL_ items if they are missing. + +Motif: The GUI tabline did not use the space above the right scrollbar. Work +around a bug in the Motif library. (Yegappan Lakshmanan) + +The extra files for XML Omni completion are now also installed. +|xml-omni-datafile| + +GTK GUI: when 'm' is missing from 'guioptions' during startup and pressing +<F10> GTK produced error messages. Now do create the menu but disable it just +after the first gui_mch_update(). + +":mkspell" doesn't work well with the Hungarian dictionary from the Hunspell +project. Back to the Myspell dictionary. + +In help files hide the | used around tags. + +Renamed pycomplete to pythoncomplete. + +Added "tabpages" to 'sessionoptions'. + +When 'guitablabel' is set the effect wasn't visible right away. + +Fixed a few 'cindent' errors. + +When completing menu names, e.g., after ":emenu", don't sort the entries but +keep them in the original order. + +Fixed a crash when editing a directory in diff mode. Don't trigger +autocommands when executing the diff command. + +Getting a keystroke could get stuck if 'encoding' is a multi-byte encoding and +typing a special key. + +When 'foldignore' is set the folds were not updated right away. + +When a list is indexed with [a : b] and b was greater than the length an error +message was given. Now silently truncate the result. + +When using BS during Insert mode completion go back to the original text, so +that CTRL-N selects the first matching entry. + +Added the 'M' flag to 'cinoptions'. + +Win32: Make the "gvim --help" window appear in the middle of the screen +instead of at an arbitrary position. (Randall W. Morris) + +Added gettabwinvar() and settabwinvar(). + +Command line completion: pressing <Tab> after ":e /usr/*" expands the whole +tree, because it becomes ":e /usr/**". Don't add a star if there already is +one. + +Added grey10 to grey90 to all GUIs, so that they can all be used for +initializing highlighting. Use grey40 for CursorColumn and CursorLine when +'background' is "dark". + +When reading a file and using iconv for conversion, an incomplete byte +sequence at the end caused problems. (Yukihiro Nakadaira) + + +--- fixes and changes since Vim 7.0e --- + +Default color for MatchParen when 'background' is "dark" is now DarkCyan. + +":syn off" had to be used twice in a file that sets 'syntax' in a modeline. +(Michael Geddes) + +When using ":vsp" or ":sp" the available space wasn't used equally between +windows. (Servatius Brandt) + +Expanding <cWORD> on a trailing blank resulted in the first word in the line +if 'encoding' is a multi-byte encoding. + +Spell checking: spellbadword() didn't see a missing capital in the first word +of a line. Popup menu now only suggest the capitalized word when appropriate. + +When using whole line completion CTRL-L moves through the matches but it +didn't work when at the original text. + +When completion finds the longest match, don't go to the first match but stick +at the original text, so that CTRL-N selects the first one. + +Recognize "zsh-beta" like "zsh" for setting the 'shellpipe' default. (James +Vega) + +When using ":map <expr>" and the expression results in something with a +special byte (NUL or CSI) then it didn't work properly. Now escape special +bytes. + +The default Visual highlighting for a color xterm with 8 colors was a magenta +background, which made magenta text disappear. Now use reverse in this +specific situation. + +After completing the longest match "." didn't insert the same text. Repeating +also didn't work correctly for multi-byte text. + +When using Insert mode completion and BS the whole word that was completed +would result in all possible matches. Now stop completion. Also fixes that +for spell completion the previous word was deleted. + +GTK: When 'encoding' is "latin1" and using non-ASCII characters in a file name +the tab page label was wrong and an error message would be given. + +The taglist() function could hang on a tags line with a non-ASCII character. + +Win32: When 'encoding' differs from the system encoding tab page labels with +non-ASCII characters looked wrong. (Yegappan Lakshmanan) + +Motif: building failed when Xm/Notebook.h doesn't exist. Added a configure +check, disable GUI tabline when it's missing. + +Mac: When compiled without multi-byte feature the clipboard didn't work. + +It was possible to switch to another tab page when the cmdline window is open. + +Completion could hang when 'lines' is 6 and a preview window was opened. + +Added CTRL-W gF: open file under cursor in new tab page and jump to the line +number following the file name. +Added 'guitabtooltip'. Implemented for Win32 (Yegappan Lakshmanan). + +Added "throw" to 'debug' option: throw an exception for error messages even +whey they would otherwise be ignored. + +When 'keymap' is set and a line contains an invalid entry could get a "No +mapping found" warning instead of a proper error message. + +Motif: default to using XpmAttributes instead of XpmAttributes_21. + +A few more changes for 64 bit MS-Windows. (George Reilly) + +Got ml_get errors when doing "o" and selecting in other window where there are +less lines shorter than the cursor position in the other window. ins_mouse() +was using position in wrong window. + +Win32 GUI: Crash when giving a lot of messages during startup. Allocate twice +as much memory for the dialog template. + +Fixed a few leaks and wrong pointer use reported by coverity. + +When showing menus the mode character was sometimes wrong. + +Added feedkeys(). (Yakov Lerner) + +Made matchlist() always return all submatches. + +Moved triggering QuickFixCmdPost to before jumping to the first location. + +Mac: Added the 'macatsui' option as a temporary work around for text drawing +problems. + +Line completion on "/**" gave error messages when scanning an unloaded buffer. + +--- fixes and changes since Vim 7.0f --- + +Win32: The height of the tab page labels is now adjusted to the font height. +(Yegappan Lakshmanan) + +Win32: selecting the tab label was off by one. (Yegappan Lakshmanan) + +Added tooltips for Motif and GTK tab page labels. (Yegappan Lakshmanan) + +When 'encoding' is "utf-8" then ":help spell" would report an illegal byte and +the file was not converted from latin1 to utf-8. Now retry with latin1 if +reading the file as utf-8 results in illegal bytes. + +Escape the argument of feedkeys() before putting it in the typeahead buffer. +(Yukihiro Nakadaira) + +Added the v:char variable for evaluating 'formatexpr'. (Yukihiro Nakadaira) + +With 8 colors Search highlighting combined with Statement highlighted text +made the text disappear. + +VMS: avoid warnings for redefining MAX and MIN. (Zoltan Arpadffy) + +When 'virtualedit' includes "onemore", stopping Visual selection would still +move the cursor left. + +Prevent that using CTRL-R = in Insert mode can start Visual mode. + +Fixed a crash that occurred when in Insert mode with completion active and a +mapping caused edit() to be called recursively. + +When using CTRL-O in Insert mode just after the last character while +'virtualedit' is "all", then typing CR moved the last character to the next +line. Call coladvance() before starting the new line. + +When using |:shell| ignore clicks on the tab page labels. Also when using the +command line window. + +When 'eventignore' is "all" then adding more to ignoring some events, e.g., +for ":vimgrep", would actually trigger more events. + +Win32: When a running Vim uses server name GVIM1 then "gvim --remote fname" +didn't find it. When looking for a server name that doesn't end in a digit +and it is not found then use another server with that name and a number (just +like on Unix). + +When using "double" in 'spellsuggest' when the language doesn't support sound +folding resulted in too many suggestions. + +Win32: Dropping a shortcut on the Vim icon didn't edit the referred file like +editing it in another way would. Use fname_expand() in buf_set_name() instead +of simply make the file name a full path. + +Using feedkeys() could cause Vim to hang. + +When closing another tab page from the tabline menu in Insert mode the tabline +was not updated right away. + +The syntax menu didn't work in compatible mode. + +After using ":tag id" twice with the same "id", ":ts" and then ":pop" a ":ts" +reported no matching tag. Clear the cached tag name. + +In Insert mode the matchparen plugin highlighted the wrong paren when there is +a string just next to a paren. + +GTK: After opening a new tab page the text was sometimes not drawn correctly. +Flush output and catch up with events when updating the tab page labels. + +In the GUI, using CTRL-W q to close the last window of a tab page could cause +a crash. + +GTK: The tab pages line menu was not converted from 'encoding' to utf-8. + +Typing a multi-byte character or a special key at the hit-enter prompt did not +work. + +When 'virtualedit' contains "onemore" CTRL-O in Insert mode still moved the +cursor left when it was after the end of the line, even though it's allowed to +be there. + +Added test for using tab pages. + +towupper() and towlower() were not used, because of checking for +__STDC__ISO_10646__ instead of __STDC_ISO_10646__. (sertacyildiz) + +For ":map <expr>" forbid changing the text, jumping to another buffer and +using ":normal" to avoid nasty side effects. + +--- fixes and changes since Vim 7.0g --- + +Compilation error on HP-UX, use of "dlerr" must be inside a #ifdef. +(Gary Johnson) + +Report +reltime feature in ":version" output. + +The tar and zip plugins detect failure to get the contents of the archive and +edit the file as-is. + +When the result of 'guitablabel' is empty fall back to the default label. + +Fixed crash when using ":insert" in a while loop and missing "endwhile". + +"gt" and other commands could move to another window when |textlock| active +and when the command line window was open. + +Spell checking a file with syntax highlighting and a bad word at the end of +the line is ignored could make "]s" hang. + +Mac: inputdialog() didn't work when compiled with big features. + +Interrupting ":vimgrep" while it is busy loading a file left a modified and +hidden buffer behind. Use enter_cleanup() and leave_cleanup() around +wipe_buffer(). + +When making 'keymap' empty the b:keymap_name variable wasn't deleted. + +Using CTRL-N that searches a long time, pressing space to interrupt the +searching and accept the first match, the popup menu was still displayed +briefly. + +When setting the Vim window height with -geometry the 'window' option could be +at a value that makes CTRL-F behave differently. + +When opening a quickfix window in two tabs they used different buffers, +causing redrawing problems later. Now use the same buffer for all quickfix +windows. (Yegappan Lakshmanan) + +When 'mousefocus' is set moving the mouse to the text tab pages line would +move focus to the first window. Also, the mouse pointer would jump to the +active window. + +In a session file, when an empty buffer is wiped out, do this silently. + +When one window has the cursor on the last line and another window is resized +to make that window smaller, the cursor line could go below the displayed +lines. In win_new_height() subtract one from the available space. +Also avoid that using "~" lines makes the window scroll down. + +Mac: When sourcing the "macmap.vim" script and then finding a .vimrc file the +'cpo' option isn't set properly, because it was already set and restored. +Added the <special> argument to ":map", so that 'cpo' doesn't need to be +changed to be able to use <> notation. Also do this for ":menu" for +consistency. + +When using "/encoding=abc" in a spell word list, only "bc" was used. + +When 'encoding' and 'printencoding' were both "utf-8" then ":hardcopy" didn't +work. (Mike Williams) + +Mac: When building with "--disable-gui" the install directory would still be +"/Applications" and Vim.app would be installed. Now install in /usr/local as +usual for a console application. + +GUI: when doing completion and there is one match and still searching for +another, the cursor was displayed at the end of the line instead of after the +match. Now show the cursor after the match while still searching for matches. + +GUI: The mouse shape changed on the statusline even when 'mouse' was empty and +they can't be dragged. + +GTK2: Selecting a button in the confirm() dialog with Tab or cursor keys and +hitting Enter didn't select that button. Removed GTK 1 specific code. (Neil +Bird) + +When evaluating 'balloonexpr' takes a long time it could be called +recursively, which could cause a crash. + +exists() could not be used to detect whether ":2match" is supported. Added a +check for it specifically. + +GTK1: Tab page labels didn't work. (Yegappan Lakshmanan) + +Insert mode completion: When finding matches use 'ignorecase', but when adding +matches to the list don't use it, so that all words with different case are +added, "word", "Word" and "WORD". + +When 'cursorline' and 'hlsearch' are set and the search pattern is "x\n" +the rest of the line was highlighted as a match. + +Cursor moved while evaluating 'balloonexpr' that invokes ":isearch" and +redirects the output. Don't move the cursor to the command line if msg_silent +is set. + +exists() ignored text after a function name and option name, which could +result in false positives. + +exists() ignored characters after the recognized word, which can be wrong when +using a name with non-keyword characters. Specifically, these calls no longer +allow characters after the name: exists('*funcname') exists('*funcname(...') +exists('&option') exists(':cmd') exists('g:name') exists('g:name[n]') +exists('g:name.n') + +Trigger the TabEnter autocommand only after entering the current window of the +tab page, otherwise the commands are executed with an invalid current window. + +Win32: When using two monitors and Vim is on the second monitor, changing the +width of the Vim window could make it jump to the first monitor. + +When scrolling back at the more prompt and the quitting a line of text would +be left behind when 'cmdheight' is 2 or more. + +Fixed a few things for Insert mode completion, especially when typing BS, +CTRL-N or a printable character while still searching for matches. + + +============================================================================== +VERSION 7.1 *version-7.1* *version7.1* + +This section is about improvements made between version 7.0 and 7.1. + +This is a bug-fix release, there are no fancy new features. + + +Changed *changed-7.1* +------- + +Added setting 'mouse' in vimrc_example.vim. + +When building with MZscheme also look for include files in the "plt" +subdirectory. That's where they are for FreeBSD. + +The Ruby interface module is now called "Vim" instead of "VIM". But "VIM" is +an alias, so it's backwards compatible. (Tim Pope) + + +Added *added-7.1* +----- + +New syntax files: + /var/log/messages (Yakov Lerner) + Autohotkey (Nikolai Weibull) + AutoIt v3 (Jared Breland) + Bazaar commit file "bzr". (Dmitry Vasiliev) + Cdrdao TOC (Nikolai Weibull) + Cmusrc (Nikolai Weibull) + Conary recipe (rPath Inc) + Framescript (Nikolai Weibull) + FreeBasic (Mark Manning) + Hamster (David Fishburn) + IBasic (Mark Manning) + Initng (Elan Ruusamae) + Ldapconf (Nikolai Weibull) + Litestep (Nikolai Weibull) + Privoxy actions file (Doug Kearns) + Streaming Descriptors "sd" (Puria Nafisi Azizi) + +New tutor files: + Czech (Lubos Turek) + Hungarian (Arpad Horvath) + Turkish (Serkan kkk) + utf-8 version of Greek tutor. + utf-8 version of Russian tutor. + utf-8 version of Slowak tutor. + +New filetype plugins: + Bst (Tim Pope) + Cobol (Tim Pope) + Fvwm (Gautam Iyer) + Hamster (David Fishburn) + Django HTML template (Dave Hodder) + +New indent files: + Bst (Tim Pope) + Cobol (Tim Pope) + Hamster (David Fishburn) + Django HTML template (Dave Hodder) + Javascript + JSP (David Fishburn) + +New keymap files: + Bulgarian (Boyko Bantchev) + Mongolian (Natsagdorj Shagdar) + Thaana (Ibrahim Fayaz) + Vietnamese (Samuel Thibault) + +Other new runtime files: + Ada support files. (Neil Bird, Martin Krischik) + Slovenian menu translations (Mojca Miklavec) + Mono C# compiler plugin (Jarek Sobiecki) + + +Fixed *fixed-7.1* +----- + +Could not build the Win32s version. Added a few structure definitions in +src/gui_w32.c + + +Patch 7.0.001 +Problem: ":set spellsuggest+=10" does not work. (Suresh Govindachar) +Solution: Add P_COMMA to the 'spellsuggest' flags. +Files: src/option.c + +Patch 7.0.002 +Problem: C omni completion has a problem with tags files with a path + containing "#" or "%". +Solution: Escape these characters. (Sebastian Baberowski) +Files: runtime/autoload/ccomplete.vim + +Patch 7.0.003 +Problem: GUI: clicking in the lower part of a label in the tab pages line + while 'mousefocus' is set may warp the mouse pointer. (Robert + Webb) +Solution: Check for a negative mouse position. +Files: src/gui.c + +Patch 7.0.004 +Problem: Compiler warning for debug_saved used before set. (Todd Blumer) +Solution: Remove the "else" for calling save_dbg_stuff(). +Files: src/ex_docmd.c + +Patch 7.0.005 (extra) +Problem: Win32: The installer doesn't remove the "autoload" and "spell" + directories. (David Fishburn) +Solution: Add the directories to the list to be removed. +Files: nsis/gvim.nsi + +Patch 7.0.006 +Problem: Mac: "make shadow" doesn't make a link for infplist.xml. (Axel + Kielhorn) +Solution: Make the link. +Files: src/Makefile + +Patch 7.0.007 +Problem: AIX: compiling fails for message.c. (Ruediger Hornig) +Solution: Move the #if outside of memchr(). +Files: src/message.c + +Patch 7.0.008 +Problem: Can't call a function that uses both <SID> and {expr}. (Thomas) +Solution: Check both the expanded and unexpanded name for <SID>. +Files: src/eval.c + +Patch 7.0.009 +Problem: ml_get errors with both 'sidescroll' and 'spell' set. +Solution: Use ml_get_buf() instead of ml_get(), get the line from the right + buffer, not the current one. +Files: src/spell.c + +Patch 7.0.010 +Problem: The spellfile plugin required typing login name and password. +Solution: Use "anonymous" and "vim7user" by default. No need to setup a + .netrc file. +Files: runtime/autoload/spellfile.vim + +Patch 7.0.011 +Problem: Can't compile without the folding and with the eval feature. +Solution: Add an #ifdef. (Vallimar) +Files: src/option.c + +Patch 7.0.012 +Problem: Using the matchparen plugin, moving the cursor in Insert mode to a + shorter line that ends in a brace, changes the preferred column +Solution: Use winsaveview()/winrestview() instead of getpos()/setpos(). +Files: runtime/plugin/matchparen.vim + +Patch 7.0.013 +Problem: Insert mode completion: using CTRL-L to add an extra character + also deselects the current match, making it impossible to use + CTRL-L a second time. +Solution: Keep the current match. Also make CTRL-L work at the original + text, using the first displayed match. +Files: src/edit.c + +Patch 7.0.014 +Problem: Compiling gui_xmebw.c fails on Dec Alpha Tru64. (Rolfe) +Solution: Disable some code for Motif 1.2 and older. +Files: src/gui_xmebw.c + +Patch 7.0.015 +Problem: Athena: compilation problems with modern compiler. +Solution: Avoid type casts for lvalue. (Alexey Froloff) +Files: src/gui_at_fs.c + +Patch 7.0.016 +Problem: Printing doesn't work for "dec-mcs" encoding. +Solution: Add "dec-mcs", "mac-roman" and "hp-roman8" to the list of + recognized 8-bit encodings. (Mike Williams) +Files: src/mbyte.c + +Patch 7.0.017 (after 7.0.014) +Problem: Linking gui_xmebw.c fails on Dec Alpha Tru64. (Rolfe) +Solution: Adjust defines for Motif 1.2 and older. +Files: src/gui_xmebw.c + +Patch 7.0.018 +Problem: VMS: plugins are not loaded on startup. +Solution: Remove "**" from the path. (Zoltan Arpadffy) +Files: src/main.c + +Patch 7.0.019 +Problem: Repeating "VjA789" may cause a crash. (James Vega) +Solution: Check the cursor column after moving it to another line. +Files: src/ops.c + +Patch 7.0.020 +Problem: Crash when using 'mousefocus'. (William Fulton) +Solution: Make buffer for mouse coordinates 2 bytes longer. (Juergen Weigert) +Files: src/gui.c + +Patch 7.0.021 +Problem: Crash when using "\\[" and "\\]" in 'errorformat'. (Marc Weber) +Solution: Check for valid submatches after matching the pattern. +Files: src/quickfix.c + +Patch 7.0.022 +Problem: Using buffer.append() in Ruby may append the line to the wrong + buffer. (Alex Norman) +Solution: Properly switch to the buffer to do the appending. Also for + buffer.delete() and setting a buffer line. +Files: src/if_ruby.c + +Patch 7.0.023 +Problem: Crash when doing spell completion in an empty line and pressing + CTRL-E. +Solution: Check for a zero pointer. (James Vega) + Also handle a situation without a matching pattern better, report + "No matches" instead of remaining in undefined CTRL-X mode. And + get out of CTRL-X mode when typing a letter. +Files: src/edit.c + +Patch 7.0.024 +Problem: It is possible to set arbitrary "v:" variables. +Solution: Disallow setting "v:" variables that are not predefined. +Files: src/eval.c + +Patch 7.0.025 +Problem: Crash when removing an element of a:000. (Nikolai Weibull) +Solution: Mark the a:000 list with VAR_FIXED. +Files: src/eval.c + +Patch 7.0.026 +Problem: Using libcall() may show an old error. +Solution: Invoke dlerror() to clear a previous error. (Yukihiro Nakadaira) +Files: src/os_unix.c + +Patch 7.0.027 (extra) +Problem: Win32: When compiled with SNIFF gvim may hang on exit. +Solution: Translate and dispatch the WM_USER message. (Mathias Michaelis) +Files: src/gui_w48.c + +Patch 7.0.028 (extra) +Problem: OS/2: Vim doesn't compile with gcc 3.2.1. +Solution: Add argument to after_pathsep(), don't define vim_handle_signal(), + define HAVE_STDARG_H. (David Sanders) +Files: src/os_unix.c, src/vim.h, src/os_os2_cfg.h + +Patch 7.0.029 +Problem: getchar() may not position the cursor after a space. +Solution: Position the cursor explicitly. +Files: src/eval.c + +Patch 7.0.030 +Problem: The ":compiler" command can't be used in a FileChangedRO event. + (Hari Krishna Dara) +Solution: Add the CMDWIN flag to the ":compiler" command. +Files: src/ex_cmds.h + +Patch 7.0.031 +Problem: When deleting a buffer the buffer-local mappings for Select mode + remain. +Solution: Add the Select mode bit to MAP_ALL_MODES. (Edwin Steiner) +Files: src/vim.h + +Patch 7.0.032 (extra, after 7.0.027) +Problem: Missing semicolon. +Solution: Add the semicolon. +Files: src/gui_w48.c + +Patch 7.0.033 +Problem: When pasting text, with the menu or CTRL-V, autoindent is removed. +Solution: Use "x<BS>" to avoid indent to be removed. (Benji Fisher) +Files: runtime/autoload/paste.vim + +Patch 7.0.034 +Problem: After doing completion and typing more characters or using BS + repeating with "." didn't work properly. (Martin Stubenschrott) +Solution: Don't put BS and other characters in the redo buffer right away, + do this when finishing completion. +Files: src/edit.c + +Patch 7.0.035 +Problem: Insert mode completion works when typed but not when replayed from + a register. (Hari Krishna Dara) + Also: Mappings for Insert mode completion don't always work. +Solution: When finding a non-completion key in the input don't interrupt + completion when it wasn't typed. + Do use mappings when checking for typeahead while still finding + completions. Avoids that completion is interrupted too soon. + Use "compl_pending" in a different way. +Files: src/edit.c + +Patch 7.0.036 +Problem: Can't compile with small features and syntax highlighting or the + diff feature. +Solution: Define LINE_ATTR whenever syntax highlighting or the diff feature + is enabled. +Files: src/screen.c + +Patch 7.0.037 +Problem: Crash when resizing the GUI window vertically when there is a line + that doesn't fit. +Solution: Don't redraw while the screen data is invalid. +Files: src/screen.c + +Patch 7.0.038 +Problem: When calling complete() from an Insert mode expression mapping + text could be inserted in an improper way. +Solution: Make undo_allowed() global and use it in complete(). +Files: src/undo.c, src/proto/undo.pro, src/eval.c + +Patch 7.0.039 +Problem: Calling inputdialog() with a third argument in the console doesn't + work. +Solution: Make a separate function for input() and inputdialog(). (Yegappan + Lakshmanan) +Files: src/eval.c + +Patch 7.0.040 +Problem: When 'cmdheight' is larger than 1 using inputlist() or selecting + a spell suggestion with the mouse gets the wrong entry. +Solution: Start listing the first alternative on the last line of the screen. +Files: src/eval.c, src/spell.c + +Patch 7.0.041 +Problem: cursor([1, 1]) doesn't work. (Peter Hodge) +Solution: Allow leaving out the third item of the list and use zero for the + virtual column offset. +Files: src/eval.c + +Patch 7.0.042 +Problem: When pasting a block of text in Insert mode Vim hangs or crashes. + (Noam Halevy) +Solution: Avoid that the cursor is positioned past the NUL of a line. +Files: src/ops.c + +Patch 7.0.043 +Problem: Using "%!" at the start of 'statusline' doesn't work. +Solution: Recognize the special item when the option is being set. +Files: src/option.c + +Patch 7.0.044 +Problem: Perl: setting a buffer line in another buffer may result in + changing the current buffer. +Solution: Properly change to the buffer to be changed. +Files: src/if_perl.xs + +Patch 7.0.045 (extra) +Problem: Win32: Warnings when compiling OLE version with MSVC 2005. +Solution: Move including vim.h to before windows.h. (Ilya Bobir) +Files: src/if_ole.cpp + +Patch 7.0.046 +Problem: The matchparen plugin ignores parens in strings, but not in single + quotes, often marked with "character". +Solution: Also ignore parens in syntax items matching "character". +Files: runtime/plugin/matchparen.vim + +Patch 7.0.047 +Problem: When running configure the exit status is wrong. +Solution: Handle the exit status properly. (Matthew Woehlke) +Files: configure, src/configure + +Patch 7.0.048 +Problem: Writing a compressed file fails when there are parens in the name. + (Wang Jian) +Solution: Put quotes around the temp file name. +Files: runtime/autoload/gzip.vim + +Patch 7.0.049 +Problem: Some TCL scripts are not recognized. (Steven Atkinson) +Solution: Check for "exec wish" in the file. +Files: runtime/scripts.vim + +Patch 7.0.050 +Problem: After using the netbeans interface close command a stale pointer + may be used. +Solution: Clear the pointer to the closed buffer. (Xaview de Gaye) +Files: src/netbeans.c + +Patch 7.0.051 (after 7.0.44) +Problem: The Perl interface doesn't compile or doesn't work properly. +Solution: Remove the spaces before #ifdef and avoid an empty line above it. +Files: src/if_perl.xs + +Patch 7.0.052 +Problem: The user may not be aware that the Vim server allows others more + functionality than desired. +Solution: When running Vim as root don't become a Vim server without an + explicit --servername argument. +Files: src/main.c + +Patch 7.0.053 +Problem: Shortening a directory name may fail when there are multi-byte + characters. +Solution: Copy the correct bytes. (Titov Anatoly) +Files: src/misc1.c + +Patch 7.0.054 +Problem: Mac: Using a menu name that only has a mnemonic or accelerator + causes a crash. (Elliot Shank) +Solution: Check for an empty menu name. Also delete empty submenus that + were created before detecting the error. +Files: src/menu.c + +Patch 7.0.055 +Problem: ":startinsert" in a CmdwinEnter autocommand doesn't take immediate + effect. (Bradley White) +Solution: Put a NOP key in the typeahead buffer. Also avoid that using + CTRL-C to go back to the command line moves the cursor left. +Files: src/edit.c, src/ex_getln.c + +Patch 7.0.056 +Problem: "#!something" gives an error message. +Solution: Ignore this line, so that it can be used in an executable Vim + script. +Files: src/ex_docmd.c + +Patch 7.0.057 (extra, after 7.0.45) +Problem: Win32: Compilation problem with Borland C 5.5. +Solution: Include vim.h as before. (Mark S. Williams) +Files: src/if_ole.cpp + +Patch 7.0.058 +Problem: The gbk and gb18030 encodings are not recognized. +Solution: Add aliases to cp936. (Edward L. Fox) +Files: src/mbyte.c + +Patch 7.0.059 +Problem: The Perl interface doesn't compile with ActiveState Perl 5.8.8. +Solution: Remove the __attribute__() items. (Liu Yubao) +Files: src/if_perl.xs + +Patch 7.0.060 (after 7.0.51) +Problem: Code for temporarily switching to another buffer is duplicated in + quite a few places. +Solution: Use aucmd_prepbuf() and aucmd_restbuf() also when FEAT_AUTOCMD is + not defined. +Files: src/buffer.c, src/eval.c, src/fileio.c, src/if_ruby.c, + src/if_perl.xs, src/quickfix.c, src/structs.h + +Patch 7.0.061 +Problem: Insert mode completion for Vim commands may crash if there is + nothing to complete. +Solution: Instead of freeing the pattern make it empty, so that a "not + found" error is given. (Yukihiro Nakadaira) +Files: src/edit.c + +Patch 7.0.062 +Problem: Mac: Crash when using the popup menu for spell correction. The + popup menu appears twice when letting go of the right mouse button + early. +Solution: Don't show the popup menu on the release of the right mouse + button. Also check that a menu pointer is actually valid. +Files: src/proto/menu.pro, src/menu.c, src/normal.c, src/term.c + +Patch 7.0.063 +Problem: Tiny chance for a memory leak. (coverity) +Solution: Free pointer when next memory allocation fails. +Files: src/eval.c + +Patch 7.0.064 +Problem: Using uninitialized variable. (Tony Mechelynck) +Solution: When not used set "temp" to zero. Also avoid a warning for + "files" in ins_compl_dictionaries(). +Files: src/edit.c + +Patch 7.0.065 (extra) +Problem: Mac: left-right movement of the scrollwheel causes up-down + scrolling. +Solution: Ignore mouse wheel events that are not up-down. (Nicolas Weber) +Files: src/gui_mac.c + +Patch 7.0.066 +Problem: After the popup menu for Insert mode completion overlaps the tab + pages line it is not completely removed. +Solution: Redraw the tab pages line after removing the popup menu. (Ori + Avtalion) +Files: src/popupmnu.c + +Patch 7.0.067 +Problem: Undo doesn't always work properly when using "scim" input method. + Undo is split up when using preediting. +Solution: Reset xim_has_preediting also when preedit_start_col is not + MAXCOL. Don't split undo when <Left> is used while preediting. + (Yukihiro Nakadaira) +Files: src/edit.c, src/mbyte.c + +Patch 7.0.068 +Problem: When 'ignorecase' is set and using Insert mode completion, + typing characters to change the list of matches, case is not + ignored. (Hugo Ahlenius) +Solution: Store the 'ignorecase' flag with the matches where needed. +Files: src/edit.c, src/search.c, src/spell.c + +Patch 7.0.069 +Problem: Setting 'guitablabel' to %!expand(\%) causes Vim to free an + invalid pointer. (Kim Schulz) +Solution: Don't try freeing a constant string pointer. +Files: src/buffer.c + +Patch 7.0.070 +Problem: Compiler warnings for shadowed variables and uninitialized + variables. +Solution: Rename variables such as "index", "msg" and "dup". Initialize + variables. +Files: src/edit.c, src/eval.c, src/ex_cmds.c, src/ex_cmds2.c, + src/ex_docmd.c, src/gui_beval.c, src/gui_gtk.c, src/gui_gtk_x11.c, + src/hardcopy.c, src/if_cscope.c, src/main.c, src/mbyte.c, + src/memline.c, src/netbeans.c, src/normal.c, src/option.c, + src/os_unix.c, src/quickfix.c, src/regexp.c, src/screen.c, + src/search.c, src/spell.c, src/ui.c, src/undo.c, src/window.c, + src/version.c + +Patch 7.0.071 +Problem: Using an empty search pattern may cause a crash. +Solution: Avoid using a NULL pointer. +Files: src/search.c + +Patch 7.0.072 +Problem: When starting the GUI fails there is no way to adjust settings or + do something else. +Solution: Add the GUIFailed autocommand event. +Files: src/fileio.c, src/gui.c, src/vim.h + +Patch 7.0.073 +Problem: Insert mode completion: Typing <CR> sometimes selects the original + text instead of keeping what was typed. (Justin Constantino) +Solution: Don't let <CR> select the original text if there is no popup menu. +Files: src/edit.c + +Patch 7.0.074 (extra) +Problem: Win32: tooltips were not converted from 'encoding' to Unicode. +Solution: Set the tooltip to use Unicode and do the conversion. Also + cleanup the code for the tab pages tooltips. (Yukihiro Nakadaira) +Files: src/gui_w32.c, src/gui_w48.c + +Patch 7.0.075 +Problem: winsaveview() did not store the actual value of the desired cursor + column. This could move the cursor in the matchparen plugin. +Solution: Call update_curswant() before using the value w_curswant. +Files: src/eval.c + +Patch 7.0.076 (after 7.0.010) +Problem: Automatic downloading of spell files only works for ftp. +Solution: Don't add login and password for non-ftp URLs. (Alexander Patrakov) +Files: runtime/autoload/spellfile.vim + +Patch 7.0.077 +Problem: ":unlet v:this_session" causes a crash. (Marius Roets) +Solution: When trying to unlet a fixed variable give an error message. +Files: src/eval.c + +Patch 7.0.078 +Problem: There are two error messages E46. +Solution: Change the number for the sandbox message to E794. +Files: src/globals.h + +Patch 7.0.079 +Problem: Russian tutor doesn't work when 'encoding' is "utf-8". +Solution: Use tutor.ru.utf-8 as the master, and generate the other encodings + from it. Select the right tutor depending on 'encoding'. (Alexey + Froloff) +Files: runtime/tutor/Makefile, runtime/tutor/tutor.vim, + runtime/tutor/tutor.ru.utf-8 + +Patch 7.0.080 +Problem: Generating auto/pathdef.c fails for CFLAGS with a backslash. +Solution: Double backslashes in the string. (Alexey Froloff) +Files: src/Makefile + +Patch 7.0.081 +Problem: Command line completion doesn't work for a shell command with an + absolute path. +Solution: Don't use $PATH when there is an absolute path. +Files: src/ex_getln.c + +Patch 7.0.082 +Problem: Calling a function that waits for input may cause List and + Dictionary arguments to be freed by the garbage collector. +Solution: Keep a list of all arguments to internal functions. +Files: src/eval.c + +Patch 7.0.083 +Problem: Clicking with the mouse on an item for inputlist() doesn't work + when 'compatible' is set and/or when 'cmdheight' is more than one. + (Christian J. Robinson) +Solution: Also decrement "lines_left" when 'more' isn't set. Set + "cmdline_row" to zero to get all mouse events. +Files: src/message.c, src/misc1.c + +Patch 7.0.084 +Problem: The garbage collector may do its work while some Lists or + Dictionaries are used internally, e.g., by ":echo" that runs into + the more-prompt or ":echo [garbagecollect()]". +Solution: Only do garbage collection when waiting for a character at the + toplevel. Let garbagecollect() set a flag that is handled at the + toplevel before waiting for a character. +Files: src/eval.c, src/getchar.c, src/globals.h, src/main.c + +Patch 7.0.085 +Problem: When doing "make test" the viminfo file is modified. +Solution: Use another viminfo file after setting 'compatible. +Files: src/testdir/test56.in + +Patch 7.0.086 +Problem: getqflist() returns entries for pattern and text with the number + zero. Passing these to setqflist() results in the string "0". +Solution: Use an empty string instead of the number zero. +Files: src/quickfix.c + +Patch 7.0.087 +Problem: After ":file fname" and ":saveas fname" the 'autochdir' option + does not take effect. (Yakov Lerner) + Commands for handling 'autochdir' are repeated many times. +Solution: Add the DO_AUTOCHDIR macro and do_autochdir(). Use it for + ":file fname" and ":saveas fname". +Files: src/proto/buffer.pro, src/buffer.c, src/ex_cmds.c, src/macros.h, + src/netbeans.c, src/option.c, src/window.c + +Patch 7.0.088 +Problem: When compiled with Perl the generated prototypes have "extern" + unnecessarily added. +Solution: Remove the "-pipe" argument from PERL_CFLAGS. +Files: src/auto/configure, src/configure.in + +Patch 7.0.089 +Problem: "ga" does not work properly for a non-Unicode multi-byte encoding. +Solution: Only check for composing chars for utf-8. (Taro Muraoka) +Files: src/ex_cmds.c + +Patch 7.0.090 +Problem: Cancelling the conform() dialog on the console with Esc requires + typing it twice. (Benji Fisher) +Solution: When the start of an escape sequence is found use 'timeoutlen' or + 'ttimeoutlen'. +Files: src/misc1.c + +Patch 7.0.091 +Problem: Using winrestview() while 'showcmd' is set causes the cursor to be + displayed in the wrong position. (Yakov Lerner) +Solution: Set the window topline properly. +Files: src/eval.c + +Patch 7.0.092 (after 7.0.082 and 7.0.084) +Problem: The list of internal function arguments is obsolete now that + garbage collection is only done at the toplevel. +Solution: Remove the list of all arguments to internal functions. +Files: src/eval.c + +Patch 7.0.093 +Problem: The matchparen plugin can't handle a 'matchpairs' value where a + colon is matched. +Solution: Change the split() that is used to change 'matchpairs' into a + List. +Files: runtime/plugin/matchparen.vim + +Patch 7.0.094 +Problem: When a hidden buffer is made the current buffer and another file + edited later, the file message will still be given. Using + ":silent" also doesn't prevent the file message. (Marvin Renich) +Solution: Reset the need_fileinfo flag when reading a file. Don't set + need_fileinfo when msg_silent is set. +Files: src/buffer.c, src/fileio.c + +Patch 7.0.095 +Problem: The Greek tutor is not available in utf-8. "el" is used for the + language, only "gr" for the country is recognized. +Solution: Add the utf-8 Greek tutor. Use it for conversion to iso-8859-7 + and cp737. (Lefteris Dimitroulakis) +Files: runtime/tutor/Makefile, runtime/tutor/tutor.gr.utf-8, + runtime/tutor/tutor.vim + +Patch 7.0.096 +Problem: taglist() returns the filename relative to the tags file, while + the directory of the tags file is unknown. (Hari Krishna Dara) +Solution: Expand the file name. (Yegappan Lakshmanan) +Files: src/tag.c + +Patch 7.0.097 +Problem: ":tabclose N" that closes another tab page does not remove the tab + pages line. Same problem when using the mouse. +Solution: Adjust the tab pages line when needed in tabpage_close_other(). +Files: src/ex_docmd.c + +Patch 7.0.098 +Problem: Redirecting command output in a cmdline completion function + doesn't work. (Hari Krishna Dara) +Solution: Enable redirection when redirection is started. +Files: src/ex_docmd.c, src/ex_getln.c + +Patch 7.0.099 +Problem: GUI: When the popup menu is visible using the scrollbar messes up + the display. +Solution: Disallow scrolling the current window. Redraw the popup menu + after scrolling another window. +Files: src/gui.c + +Patch 7.0.100 +Problem: "zug" may report the wrong filename. (Lawrence Kesteloot) +Solution: Call home_replace() to fill NameBuff[]. +Files: src/spell.c + +Patch 7.0.101 +Problem: When the "~/.vim/spell" directory does not exist "zg" may create + a wrong directory. "zw" doesn't work. +Solution: Use the directory of the file name instead of NameBuff. For "zw" + not only remove a good word but also add the word with "!". +Files: src/spell.c + +Patch 7.0.102 +Problem: Redrawing cmdline is not correct when using SCIM. +Solution: Don't call im_get_status(). (Yukihiro Nakadaira) +Files: src/ex_getln.c + +Patch 7.0.103 (after 7.0.101) +Problem: Compiler warning for uninitialized variable. (Tony Mechelynck) +Solution: Init variable. +Files: src/spell.c + +Patch 7.0.104 +Problem: The CursorHoldI event only triggers once in Insert mode. It also + triggers after CTRL-V and other two-key commands. +Solution: Set "did_cursorhold" before getting a second key. Reset + "did_cursorhold" after handling a command. +Files: src/edit.c, src/fileio.c + +Patch 7.0.105 +Problem: When using incremental search the statusline ruler isn't updated. + (Christoph Koegl) +Solution: Update the statusline when it contains the ruler. +Files: src/ex_getln.c + +Patch 7.0.106 +Problem: The spell popup menu uses ":amenu", triggering mappings. Other + PopupMenu autocommands are removed. (John Little) +Solution: Use ":anoremenu" and use an autocmd group. +Files: runtime/menu.vim + +Patch 7.0.107 +Problem: Incremental search doesn't redraw the text tabline. (Ilya Bobir) + Also happens in other situations with one window in a tab page. +Solution: Redraw the tabline after clearing the screen. +Files: src/screen.c + +Patch 7.0.108 (extra) +Problem: Amiga: Compilation problem. +Solution: Have mch_mkdir() return a failure flag. (Willy Catteau) +Files: src/os_amiga.c, src/proto/os_amiga.pro + +Patch 7.0.109 +Problem: Lisp indenting is confused by escaped quotes in strings. (Dorai + Sitaram) +Solution: Check for backslash inside strings. (Sergey Khorev) +Files: src/misc1.c + +Patch 7.0.110 +Problem: Amiga: Compilation problems when not using libnix. +Solution: Change a few #ifdefs. (Willy Catteau) +Files: src/memfile.c + +Patch 7.0.111 +Problem: The gzip plugin can't handle filenames with single quotes. +Solution: Add and use the shellescape() function. (partly by Alexey Froloff) +Files: runtime/autoload/gzip.vim, runtime/doc/eval.txt, src/eval.c, + src/mbyte.c, src/misc2.c, src/proto/misc2.pro + +Patch 7.0.112 +Problem: Python interface does not work with Python 2.5. +Solution: Change PyMem_DEL() to Py_DECREF(). (Sumner Hayes) +Files: src/if_python.c + +Patch 7.0.113 +Problem: Using CTRL-L in Insert completion when there is no current match + may cause a crash. (Yukihiro Nakadaira) +Solution: Check for compl_leader to be NULL +Files: src/edit.c + +Patch 7.0.114 +Problem: When aborting an insert with CTRL-C an extra undo point is + created in the GUI. (Yukihiro Nakadaira) +Solution: Call gotchars() only when advancing. +Files: src/getchar.c + +Patch 7.0.115 +Problem: When 'ignorecase' is set, Insert mode completion only adds "foo" + and not "Foo" when both are found. + A found match isn't displayed right away when 'completeopt' does + not have "menu" or "menuone". +Solution: Do not ignore case when checking if a completion match already + exists. call ins_compl_check_keys() also when not using a popup + menu. (Yukihiro Nakadaira) +Files: src/edit.c + +Patch 7.0.116 +Problem: 64 bit Windows version reports "32 bit" in the ":version" output. + (M. Veerman) +Solution: Change the text for Win64. +Files: src/version.c + +Patch 7.0.117 +Problem: Using "extend" on a syntax item inside a region with "keepend", an + intermediate item may be truncated. + When applying the "keepend" and there is an offset to the end + pattern the highlighting of a contained item isn't adjusted. +Solution: Use the seen_keepend flag to remember when to apply the "keepend" + flag. Adjust the keepend highlighting properly. (Ilya Bobir) +Files: src/syntax.c + +Patch 7.0.118 +Problem: printf() does not do zero padding for strings. +Solution: Do allow zero padding for strings. +Files: src/message.c + +Patch 7.0.119 +Problem: When going back from Insert to Normal mode the CursorHold event + doesn't trigger. (Yakov Lerner) +Solution: Reset "did_cursorhold" when leaving Insert mode. +Files: src/edit.c + +Patch 7.0.120 +Problem: Crash when using CTRL-R = at the command line and entering + "getreg('=')". (James Vega) +Solution: Avoid recursiveness of evaluating the = register. +Files: src/ops.c + +Patch 7.0.121 +Problem: GUI: Dragging the last status line doesn't work when there is a + text tabline. (Markus Wolf) +Solution: Take the text tabline into account when deciding to start modeless + selection. +Files: src/gui.c + +Patch 7.0.122 +Problem: GUI: When clearing after a bold, double-wide character half a + character may be drawn. +Solution: Check for double-wide character and redraw it. (Yukihiro Nakadaira) +Files: src/screen.c + +Patch 7.0.123 +Problem: On SCO Openserver configure selects the wrong terminal library. +Solution: Put terminfo before the other libraries. (Roger Cornelius) + Also fix a small problem compiling on Mac without Darwin. +Files: src/configure.in, src/auto/configure + +Patch 7.0.124 +Problem: getwinvar() obtains a dictionary with window-local variables, but + it's always for the current window. +Solution: Get the variables of the specified window. (Geoff Reedy) +Files: src/eval.c + +Patch 7.0.125 +Problem: When "autoselect" is in the 'clipboard' option then the '< and '> + marks are set while Visual mode is still active. +Solution: Don't set the '< and '> marks when yanking the selected area for + the clipboard. +Files: src/normal.c + +Patch 7.0.126 +Problem: When 'formatexpr' uses setline() and later internal formatting is + used undo information is not correct. (Jiri Cerny, Benji Fisher) +Solution: Set ins_need_undo after using 'formatexpr'. +Files: src/edit.c + +Patch 7.0.127 +Problem: Crash when swap files has invalid timestamp. +Solution: Check return value of ctime() for being NULL. +Files: src/memline.c + +Patch 7.0.128 +Problem: GUI: when closing gvim is cancelled because there is a changed + buffer the screen isn't updated to show the changed buffer in the + current window. (Krzysztof Kacprzak) +Solution: Redraw when closing gvim is cancelled. +Files: src/gui.c + +Patch 7.0.129 +Problem: GTK GUI: the GTK file dialog can't handle a relative path. +Solution: Make the initial directory a full path before passing it to GTK. + (James Vega) Also postpone adding the default file name until + after setting the directory. +Files: src/gui_gtk.c + +Patch 7.0.130 (extra) +Problem: Win32: Trying to edit or write devices may cause Vim to get stuck. +Solution: Add the 'opendevice' option, default off. Disallow + reading/writing from/to devices when it's off. + Also detect more devices by the full name starting with "\\.\". +Files: runtime/doc/options.txt, src/fileio.c, src/option.c, src/option.h, + src/os_win32.c + +Patch 7.0.131 +Problem: Win32: "vim -r" does not list all the swap files. +Solution: Also check for swap files starting with a dot. +Files: src/memline.c + +Patch 7.0.132 (after 7.0.130) +Problem: Win32: Crash when Vim reads from stdin. +Solution: Only use mch_nodetype() when there is a file name. +Files: src/fileio.c + +Patch 7.0.133 +Problem: When searching included files messages are added to the history. +Solution: Set msg_hist_off for messages about scanning included files. + Set msg_silent to avoid message about wrapping around. +Files: src/edit.c, src/globals.h, src/message.c, src/search.c + +Patch 7.0.134 +Problem: Crash when comparing a recursively looped List or Dictionary. +Solution: Limit recursiveness for comparing to 1000. +Files: src/eval.c + +Patch 7.0.135 +Problem: Crash when garbage collecting list or dict with loop. +Solution: Don't use DEL_REFCOUNT but don't recurse into Lists and + Dictionaries when freeing them in the garbage collector. + Also add allocated Dictionaries to the list of Dictionaries to + avoid leaking memory. +Files: src/eval.c, src/proto/eval.pro, src/tag.c + +Patch 7.0.136 +Problem: Using "O" while matching parens are highlighted may not remove the + highlighting. (Ilya Bobir) +Solution: Also trigger CursorMoved when a line is inserted under the cursor. +Files: src/misc1.c + +Patch 7.0.137 +Problem: Configure check for big features is wrong. +Solution: Change "==" to "=". (Martti Kuparinen) +Files: src/auto/configure, src/configure.in + +Patch 7.0.138 (extra) +Problem: Mac: modifiers don't work with function keys. +Solution: Use GetEventParameter() to obtain modifiers. (Nicolas Weber) +Files: src/gui_mac.c + +Patch 7.0.139 +Problem: Using CTRL-PageUp or CTRL-PageDown in Insert mode to go to another + tab page does not prepare for undo properly. (Stefano Zacchiroli) +Solution: Call start_arrow() before switching tab page. +Files: src/edit.c + +Patch 7.0.140 (after 7.0.134) +Problem: Comparing recursively looped List or Dictionary doesn't work well. +Solution: Detect comparing a List or Dictionary with itself. +Files: src/eval.c + +Patch 7.0.141 +Problem: When pasting a while line on the command line an extra CR is added + literally. +Solution: Don't add the trailing CR when pasting with the mouse. +Files: src/ex_getln.c, src/proto/ops.pro, src/ops.c + +Patch 7.0.142 +Problem: Using the middle mouse button in Select mode to paste text results + in an extra "y". (Kriton Kyrimis) +Solution: Let the middle mouse button replace the selected text with the + contents of the clipboard. +Files: src/normal.c + +Patch 7.0.143 +Problem: Setting 'scroll' to its default value was not handled correctly. +Solution: Compare the right field to PV_SCROLL. +Files: src/option.c + +Patch 7.0.144 +Problem: May compare two unrelated pointers when matching a pattern against + a string. (Dominique Pelle) +Solution: Avoid calling reg_getline() when REG_MULTI is false. +Files: src/regexp.c + +Patch 7.0.145 (after 7.0.142) +Problem: Compiler warning. +Solution: Add type cast. +Files: src/normal.c + +Patch 7.0.146 +Problem: When 'switchbuf' is set to "usetab" and the current tab has only a + quickfix window, jumping to an error always opens a new window. + Also, when the buffer is open in another tab page it's not found. +Solution: Check for the "split" value of 'switchbuf' properly. Search in + other tab pages for the desired buffer. (Yegappan Lakshmanan) +Files: src/buffer.c, src/quickfix.c + +Patch 7.0.147 +Problem: When creating a session file and there are several tab pages and + some windows have a local directory a short file name may be used + when it's not valid. (Marius Roets) + A session with multiple tab pages may result in "No Name" buffers. + (Bill McCarthy) +Solution: Don't enter tab pages when going through the list, only use a + pointer to the first window in each tab page. + Use "tabedit" instead of "tabnew | edit" when possible. +Files: src/ex_docmd.c + +Patch 7.0.148 +Problem: When doing "call a.xyz()" and "xyz" does not exist in dictionary + "a" there is no error message. (Yegappan Lakshmanan) +Solution: Add the error message. +Files: src/eval.c + +Patch 7.0.149 +Problem: When resizing a window that shows "~" lines the text sometimes + jumps down. +Solution: Remove code that uses "~" lines in some situations. Fix the + computation of the screen line of the cursor. Also set w_skipcol + to handle very long lines. +Files: src/misc1.c, src/window.c + +Patch 7.0.150 +Problem: When resizing the Vim window scrollbinding doesn't work. (Yakov + Lerner) +Solution: Do scrollbinding in set_shellsize(). +Files: src/term.c + +Patch 7.0.151 +Problem: Buttons in file dialog are not according to Gnome guidelines. +Solution: Swap Cancel and Open buttons. (Stefano Zacchiroli) +Files: src/gui_gtk.c + +Patch 7.0.152 +Problem: Crash when using lesstif 2. +Solution: Fill in the extension field. (Ben Hutchings) +Files: src/gui_xmebw.c + +Patch 7.0.153 +Problem: When using cscope and opening the temp file fails Vim crashes. + (Kaya Bekiroglu) +Solution: Check for NULL pointer returned from mch_open(). +Files: src/if_cscope.c + +Patch 7.0.154 +Problem: When 'foldnextmax' is negative Vim can hang. (James Vega) +Solution: Avoid the fold level becoming negative. +Files: src/fold.c, src/syntax.c + +Patch 7.0.155 +Problem: When getchar() returns a mouse button click there is no way to get + the mouse coordinates. +Solution: Add v:mouse_win, v:mouse_lnum and v:mouse_col. +Files: runtime/doc/eval.txt, src/eval.c, src/vim.h + +Patch 7.0.156 (extra) +Problem: Vim doesn't compile for Amiga OS 4. +Solution: Various changes for Amiga OS4. (Peter Bengtsson) +Files: src/feature.h, src/mbyte.c, src/memfile.c, src/memline.c, + src/os_amiga.c, src/os_amiga.h, src/pty.c + +Patch 7.0.157 +Problem: When a function is used recursively the profiling information is + invalid. (Mikolaj Machowski) +Solution: Put the start time on the stack instead of in the function. +Files: src/eval.c + +Patch 7.0.158 +Problem: In a C file with ":set foldmethod=syntax", typing {<CR> on the + last line results in the cursor being in a closed fold. (Gautam + Iyer) +Solution: Open fold after inserting a new line. +Files: src/edit.c + +Patch 7.0.159 +Problem: When there is an I/O error in the swap file the cause of the error + cannot be seen. +Solution: Use PERROR() instead of EMSG() where possible. +Files: src/memfile.c + +Patch 7.0.160 +Problem: ":@a" echoes the command, Vi doesn't do that. +Solution: Set the silent flag in the typeahead buffer to avoid echoing the + command. +Files: src/ex_docmd.c, src/normal.c, src/ops.c, src/proto/ops.pro + +Patch 7.0.161 +Problem: Win32: Tab pages line popup menu isn't using the right encoding. + (Yongwei Wu) +Solution: Convert the text when necessary. Also fixes the Find/Replace + dialog title. (Yegappan Lakshmanan) +Files: src/gui_w48.c + +Patch 7.0.162 +Problem: "vim -o a b" when file "a" triggers the ATTENTION dialog, + selecting "Quit" exits Vim instead of editing "b" only. + When file "b" triggers the ATTENTION dialog selecting "Quit" or + "Abort" results in editing file "a" in that window. +Solution: When selecting "Abort" exit Vim. When selecting "Quit" close the + window. Also avoid hit-enter prompt when selecting Abort. +Files: src/buffer.c, src/main.c + +Patch 7.0.163 +Problem: Can't retrieve the position of a sign after it was set. +Solution: Add the netbeans interface getAnno command. (Xavier de Gaye) +Files: runtime/doc/netbeans.txt, src/netbeans.c + +Patch 7.0.164 +Problem: ":redir @+" doesn't work. +Solution: Accept "@+" just like "@*". (Yegappan Lakshmanan) +Files: src/ex_docmd.c + +Patch 7.0.165 +Problem: Using CTRL-L at the search prompt adds a "/" and other characters + without escaping, causing the pattern not to match. +Solution: Escape special characters with a backslash. +Files: src/ex_getln.c + +Patch 7.0.166 +Problem: Crash in cscope code when connection could not be opened. + (Kaya Bekiroglu) +Solution: Check for the file descriptor to be NULL. +Files: src/if_cscope.c + +Patch 7.0.167 +Problem: ":function" redefining a dict function doesn't work properly. + (Richard Emberson) +Solution: Allow a function name to be a number when it's a function + reference. +Files: src/eval.c + +Patch 7.0.168 +Problem: Using uninitialized memory and memory leak. (Dominique Pelle) +Solution: Use alloc_clear() instead of alloc() for w_lines. Free + b_ml.ml_stack after recovery. +Files: src/memline.c, src/window.c + +Patch 7.0.169 +Problem: With a Visual block selection, with the cursor in the left upper + corner, pressing "I" doesn't remove the highlighting. (Guopeng + Wen) +Solution: When checking if redrawing is needed also check if Visual + selection is still active. +Files: src/screen.c + +Patch 7.0.170 (extra) +Problem: Win32: Using "gvim --remote-tab foo" when gvim is minimized while + it previously was maximized, un-maximizing doesn't work properly. + And the labels are not displayed properly when 'encoding' is + utf-8. +Solution: When minimized check for SW_SHOWMINIMIZED. When updating the tab + pages line use TCM_SETITEMW instead of TCM_INSERTITEMW. (Liu + Yubao) +Files: src/gui_w48.c + +Patch 7.0.171 (extra) +Problem: VMS: A file name with multiple paths is written in the wrong file. +Solution: Get the actually used file name. (Zoltan Arpadffy) + Also add info to the :version command about compilation. +Files: src/Make_vms.mms, src/buffer.c, src/os_unix.c, src/version.c + +Patch 7.0.172 +Problem: Crash when recovering and quitting at the "press-enter" prompt. +Solution: Check for "msg_list" to be NULL. (Liu Yubao) +Files: src/ex_eval.c + +Patch 7.0.173 +Problem: ":call f().TT()" doesn't work. (Richard Emberson) +Solution: When a function returns a Dictionary or another composite continue + evaluating what follows. +Files: src/eval.c + +Patch 7.0.174 +Problem: ":mksession" doesn't restore window layout correctly in tab pages + other than the current one. (Zhibin He) +Solution: Use the correct topframe for producing the window layout commands. +Files: src/ex_docmd.c + +Patch 7.0.175 +Problem: The result of tr() is missing the terminating NUL. (Ingo Karkat) +Solution: Add the NUL. +Files: src/eval.c + +Patch 7.0.176 +Problem: ":emenu" isn't executed directly, causing the encryption key + prompt to fail. (Life Jazzer) +Solution: Fix wrong #ifdef. +Files: src/menu.c + +Patch 7.0.177 +Problem: When the press-enter prompt gets a character from a non-remappable + mapping, it's put back in the typeahead buffer as remappable, + which may cause an endless loop. +Solution: Restore the non-remappable flag and the silent flag when putting a + char back in the typeahead buffer. +Files: src/getchar.c, src/message.c, src/normal.c + +Patch 7.0.178 +Problem: When 'enc' is "utf-8" and 'ignorecase' is set the result of ":echo + ("\xe4" == "\xe4")" varies. +Solution: In mb_strnicmp() avoid looking past NUL bytes. +Files: src/mbyte.c + +Patch 7.0.179 +Problem: Using ":recover" or "vim -r" without a swapfile crashes Vim. +Solution: Check for "buf" to be unequal NULL. (Yukihiro Nakadaira) +Files: src/memline.c + +Patch 7.0.180 (extra, after 7.0.171) +Problem: VMS: build failed. Problem with swapfiles. +Solution: Add "compiled_arch". Always expand path and pass it to + buf_modname(). (Zoltan Arpadffy) +Files: src/globals.h, src/memline.c, src/os_unix.c, runtime/menu.vim + +Patch 7.0.181 +Problem: When reloading a file that starts with an empty line, the reloaded + buffer has an extra empty line at the end. (Motty Lentzitzky) +Solution: Delete all lines, don't use bufempty(). +Files: src/fileio.c + +Patch 7.0.182 +Problem: When using a mix of undo and "g-" it may no longer be possible to + go to every point in the undo tree. (Andy Wokula) +Solution: Correctly update pointers in the undo tree. +Files: src/undo.c + +Patch 7.0.183 +Problem: Crash in ":let" when redirecting to a variable that's being + displayed. (Thomas Link) +Solution: When redirecting to a variable only do the assignment when + stopping redirection to avoid that setting the variable causes a + freed string to be accessed. +Files: src/eval.c + +Patch 7.0.184 +Problem: When the cscope program is called "mlcscope" the Cscope interface + doesn't work. +Solution: Accept "\S*cscope:" instead of "cscope:". (Frodak D. Baksik) +Files: src/if_cscope.c + +Patch 7.0.185 +Problem: Multi-byte characters in a message are displayed with attributes + from what comes before it. +Solution: Don't use the attributes for a multi-byte character. Do use + attributes for special characters. (Yukihiro Nakadaira) +Files: src/message.c + +Patch 7.0.186 +Problem: Get an ml_get error when 'encoding' is "utf-8" and searching for + "/\_s*/e" in an empty buffer. (Andrew Maykov) +Solution: Don't try getting the line just below the last line. +Files: src/search.c + +Patch 7.0.187 +Problem: Can't source a remote script properly. +Solution: Add the SourceCmd event. (Charles Campbell) +Files: runtime/doc/autocmd.txt, src/ex_cmds2.c, src/fileio.c, src/vim.h + +Patch 7.0.188 (after 7.0.186) +Problem: Warning for wrong pointer type. +Solution: Add a type cast. +Files: src/search.c + +Patch 7.0.189 +Problem: Translated message about finding matches is truncated. (Yukihiro + Nakadaira) +Solution: Enlarge the buffer. Also use vim_snprintf(). +Files: src/edit.c + +Patch 7.0.190 +Problem: "syntax spell default" results in an error message. +Solution: Change 4 to 7 for STRNICMP(). (Raul Nunez de Arenas Coronado) +Files: src/syntax.c + +Patch 7.0.191 +Problem: The items used by getqflist() and setqflist() don't match. +Solution: Support the "bufnum" item for setqflist(). (Yegappan Lakshmanan) +Files: runtime/doc/eval.txt, src/quickfix.c + +Patch 7.0.192 +Problem: When 'swapfile' is switched off in an empty file it is possible + that not all blocks are loaded into memory, causing ml_get errors + later. +Solution: Rename "dont_release" to "mf_dont_release" and also use it to + avoid using the cached line and locked block. +Files: src/globals.h, src/memfile.c, src/memline.c + +Patch 7.0.193 +Problem: Using --remote or --remote-tab with an argument that matches + 'wildignore' causes a crash. +Solution: Check the argument count before using ARGLIST[0]. +Files: src/ex_cmds.c + +Patch 7.0.194 +Problem: Once an ml_get error is given redrawing part of the screen may + cause it again, resulting in an endless loop. +Solution: Don't give the error message for a recursive call. +Files: src/memline.c + +Patch 7.0.195 +Problem: When a buffer is modified and 'autowriteall' is set, ":quit" + results in an endless loop when there is a conversion error while + writing. (Nikolai Weibull) +Solution: Make autowrite() return FAIL if the buffer is still changed after + writing it. + /* put the cursor on the last char, for 'tw' formatting */ +Files: src/ex_cmds2.c + +Patch 7.0.196 +Problem: When using ":vert ball" the computation of the mouse pointer + position may be off by one column. (Stefan Karlsson) +Solution: Recompute the frame width when moving the vertical separator from + one window to another. +Files: src/window.c + +Patch 7.0.197 (extra) +Problem: Win32: Compiling with EXITFREE doesn't work. +Solution: Adjust a few #ifdefs. (Alexei Alexandrof) +Files: src/misc2.c, src/os_mswin.c + +Patch 7.0.198 (extra) +Problem: Win32: Compiler warnings. No need to generate gvim.exe.mnf. +Solution: Add type casts. Use "*" for processorArchitecture. (George Reilly) +Files: src/Make_mvc.mak, src/eval.c, src/gvim.exe.mnf, src/misc2.c + +Patch 7.0.199 +Problem: When using multi-byte characters the combination of completion and + formatting may result in a wrong cursor position. +Solution: Don't decrement the cursor column, use dec_cursor(). (Yukihiro + Nakadaira) Also check for the column to be zero. +Files: src/edit.c + +Patch 7.0.200 +Problem: Memory leaks when out of memory. +Solution: Free the memory. +Files: src/edit.c, src/diff.c + +Patch 7.0.201 +Problem: Message for ":diffput" about buffer not being in diff mode may be + wrong. +Solution: Check for buffer in diff mode but not modifiable. +Files: src/diff.c + +Patch 7.0.202 +Problem: Problems on Tandem systems while compiling and at runtime. +Solution: Recognize root uid is 65535. Check select() return value for it + not being supported. Avoid wrong function prototypes. Mention + use of -lfloss. (Matthew Woehlke) +Files: src/Makefile, src/ex_cmds.c, src/fileio.c, src/main.c, + src/osdef1.h.in, src/osdef2.h.in, src/os_unix.c, src/pty.c, + src/vim.h + +Patch 7.0.203 +Problem: 0x80 characters in a register are not handled correctly for the + "@" command. +Solution: Escape CSI and 0x80 characters. (Yukihiro Nakadaira) +Files: src/ops.c + +Patch 7.0.204 +Problem: Cscope: Parsing matches for listing isn't done properly. +Solution: Check for line number being found. (Yu Zhao) +Files: src/if_cscope.c + +Patch 7.0.205 (after 7.0.203) +Problem: Can't compile. +Solution: Always include the vim_strsave_escape_csi function. +Files: src/getchar.c + +Patch 7.0.206 (after 7.0.058) +Problem: Some characters of the "gb18030" encoding are not handled + properly. +Solution: Do not use "cp936" as an alias for "gb18030" encoding. Instead + initialize 'encoding' to "cp936". +Files: src/mbyte.c, src/option.c + +Patch 7.0.207 +Problem: After patch 2.0.203 CSI and K_SPECIAL characters are escaped when + recorded and then again when the register is executed. +Solution: Remove escaping before putting the recorded characters in a + register. (Yukihiro Nakadaira) +Files: src/getchar.c, src/ops.c, src/proto/getchar.pro + +Patch 7.0.208 (after 7.0.171 and 7.0.180) +Problem: VMS: changes to path handling cause more trouble than they solve. +Solution: Revert changes. +Files: src/buffer.c, src/memline.c, src/os_unix.c + +Patch 7.0.209 +Problem: When replacing a line through Python the cursor may end up beyond + the end of the line. +Solution: Check the cursor column after replacing the line. +Files: src/if_python.c + +Patch 7.0.210 +Problem: ":cbuffer" and ":lbuffer" always fail when the buffer is modified. + (Gary Johnson) +Solution: Support adding a !. (Yegappan Lakshmanan) +Files: runtime/doc/quickfix.txt, src/ex_cmds.h + +Patch 7.0.211 +Problem: With ":set cindent noai bs=0" using CTRL-U in Insert mode will + delete auto-indent. After ":set ai" it doesn't. +Solution: Also check 'cindent' being set. (Ryan Lortie) +Files: src/edit.c + +Patch 7.0.212 +Problem: The GUI can't be terminated with SIGTERM. (Mark Logan) +Solution: Use the signal protection in the GUI as in the console, allow + signals when waiting for 100 msec or longer. +Files: src/ui.c + +Patch 7.0.213 +Problem: When 'spellfile' has two regions that use the same sound folding + using "z=" will cause memory to be freed twice. (Mark Woodward) +Solution: Clear the hashtable properly so that the items are only freed once. +Files: src/spell.c + +Patch 7.0.214 +Problem: When using <f-args> in a user command it's not possible to have an + argument end in '\ '. +Solution: Change the handling of backslashes. (Yakov Lerner) +Files: runtime/doc/map.txt, src/ex_docmd.c + +Patch 7.0.215 (extra) +Problem: Mac: Scrollbar size isn't set. Context menu has disabled useless + Help entry. Call to MoreMasterPointers() is ignored. +Solution: Call SetControlViewSize() in gui_mch_set_scrollbar_thumb(). Use + kCMHelpItemRemoveHelp for ContextualMenuSelect(). Remove call to + MoreMasterPointers(). (Nicolas Weber) +Files: src/gui_mac.c + +Patch 7.0.216 +Problem: ":tab wincmd ]" does not open a tab page. (Tony Mechelynck) +Solution: Copy the cmdmod.tab value to postponed_split_tab and use it. +Files: src/globals.h, src/ex_docmd.c, src/if_cscope.c, src/window.c + +Patch 7.0.217 +Problem: This hangs when pressing "n": ":%s/\n/,\r/gc". (Ori Avtalion) +Solution: Set "skip_match" to advance to the next line. +Files: src/ex_cmds.c + +Patch 7.0.218 +Problem: "%B" in 'statusline' always shows zero in Insert mode. (DervishD) +Solution: Remove the exception for Insert mode, check the column for being + valid instead. +Files: src/buffer.c + +Patch 7.0.219 +Problem: When using the 'editexisting.vim' script and a file is being + edited in another tab page the window is split. The "+123" + argument is not used. +Solution: Make the tab page with the file the current tab page. Set + v:swapcommand when starting up to the first "+123" or "-c" command + line argument. +Files: runtime/macros/editexisting.vim, src/main.c + +Patch 7.0.220 +Problem: Crash when using winnr('#') in a new tab page. (Andy Wokula) +Solution: Check for not finding the window. +Files: src/eval.c + +Patch 7.0.221 +Problem: finddir() uses 'path' by default, where "." means relative to the + current file. But it works relative to the current directory. + (Tye Zdrojewski) +Solution: Add the current buffer name to find_file_in_path_option() for the + relative file name. +Files: runtime/doc/eval.txt, src/eval.c + +Patch 7.0.222 +Problem: Perl indenting using 'cindent' works almost right. +Solution: Recognize '#' to start a comment. (Alex Manoussakis) Added '#' + flag in 'cinoptions'. +Files: runtime/doc/indent.txt, src/misc1.c + +Patch 7.0.223 +Problem: Unprintable characters in completion text mess up the popup menu. + (Gombault Damien) +Solution: Use strtrans() to make the text printable. +Files: src/charset.c, src/popupmnu.c + +Patch 7.0.224 +Problem: When expanding "##" spaces are escaped twice. (Pavol Juhas) +Solution: Don't escape the spaces that separate arguments. +Files: src/eval.c, src/ex_docmd.c, src/proto/ex_docmd.pro + +Patch 7.0.225 +Problem: When using setline() in an InsertEnter autocommand and doing "A" + the cursor ends up on the last byte in the line. (Yukihiro + Nakadaira) +Solution: Only adjust the column when using setline() for the cursor line. + Move it back to the head byte if necessary. +Files: src/eval.c, src/misc2.c + +Patch 7.0.226 +Problem: Display flickering when updating signs through the netbeans + interface. (Xavier de Gaye) +Solution: Remove the redraw_later(CLEAR) call. +Files: src/netbeans.c + +Patch 7.0.227 +Problem: Crash when closing a window in the GUI. (Charles Campbell) +Solution: Don't call out_flush() from win_free(). +Files: src/window.c + +Patch 7.0.228 +Problem: Cygwin: problem with symlink to DOS style path. +Solution: Invoke cygwin_conv_to_posix_path(). (Luca Masini) +Files: src/os_unix.c + +Patch 7.0.229 +Problem: When 'pastetoggle' starts with Esc then pressing Esc in Insert + mode will not time out. (Jeffery Small) +Solution: Use KL_PART_KEY instead of KL_PART_MAP, so that 'ttimeout' applies + to the 'pastetoggle' key. +Files: src/getchar.c + +Patch 7.0.230 +Problem: After using ":lcd" a script doesn't know how to restore the + current directory. +Solution: Add the haslocaldir() function. (Bob Hiestand) +Files: runtime/doc/usr_41.txt, runtime/doc/eval.txt, src/eval.c + +Patch 7.0.231 +Problem: When recovering from a swap file the page size is likely to be + different from the minimum. The block used for the first page + then has a buffer of the wrong size, causing a crash when it's + reused later. (Zephaniah Hull) +Solution: Reallocate the buffer when the page size changes. Also check that + the page size is at least the minimum value. +Files: src/memline.c + +Patch 7.0.232 (extra) +Problem: Mac: doesn't support GUI tab page labels. +Solution: Add GUI tab page labels. (Nicolas Weber) +Files: src/feature.h, src/gui.c, src/gui.h, src/gui_mac.c, + src/proto/gui_mac.pro + +Patch 7.0.233 (extra) +Problem: Mac: code formatted badly. +Solution: Fix code formatting +Files: src/gui_mac.c + +Patch 7.0.234 +Problem: It's possible to use feedkeys() from a modeline. That is a + security issue, can be used for a trojan horse. +Solution: Disallow using feedkeys() in the sandbox. +Files: src/eval.c + +Patch 7.0.235 +Problem: It is possible to use writefile() in the sandbox. +Solution: Add a few more checks for the sandbox. +Files: src/eval.c + +Patch 7.0.236 +Problem: Linux 2.4 uses sysinfo() with a mem_unit field, which is not + backwards compatible. +Solution: Add an autoconf check for sysinfo.mem_unit. Let mch_total_mem() + return Kbyte to avoid overflow. +Files: src/auto/configure, src/configure.in, src/config.h.in, + src/option.c, src/os_unix.c + +Patch 7.0.237 +Problem: For root it is recommended to not use 'modeline', but in + not-compatible mode the default is on. +Solution: Let 'modeline' default to off for root. +Files: runtime/doc/options.txt, src/option.c + +Patch 7.0.238 +Problem: Crash when ":match" pattern runs into 'maxmempattern'. (Yakov + Lerner) +Solution: Don't free the regexp program of match_hl. +Files: src/screen.c + +Patch 7.0.239 +Problem: When using local directories and tab pages ":mksession" uses a + short file name when it shouldn't. Window-local options from a + modeline may be applied to the wrong window. (Teemu Likonen) +Solution: Add the did_lcd flag, use the full path when it's set. Don't use + window-local options from the modeline when using the current + window for another buffer in ":doautoall". +Files: src/fileio.c, src/ex_docmd.c + +Patch 7.0.240 +Problem: Crash when splitting a window in the GUI. (opposite of 7.0.227) +Solution: Don't call out_flush() from win_alloc(). Also avoid this for + win_delete(). Also block autocommands while the window structure + is invalid. +Files: src/window.c + +Patch 7.0.241 +Problem: ":windo throw 'foo'" loops forever. (Andy Wokula) +Solution: Detect that win_goto() doesn't work. +Files: src/ex_cmds2.c + +Patch 7.0.242 (extra) +Problem: Win32: Using "-register" in a Vim that does not support OLE causes + a crash. +Solution: Don't use EMSG() but mch_errmsg(). Check p_go for being NULL. + (partly by Michael Wookey) +Files: src/gui_w32.c + +Patch 7.0.243 (extra) +Problem: Win32: When GvimExt is built with MSVC 2005 or later, the "Edit + with vim" context menu doesn't appear in the Windows Explorer. +Solution: Embed the linker manifest file into the resources of GvimExt.dll. + (Mathias Michaelis) +Files: src/GvimExt/Makefile + + +Fixes after Vim 7.1a BETA: + +The extra archive had CVS directories included below "farsi" and +"runtime/icons". CVS was missing the farsi icon files. + +Fix compiling with Gnome 2.18, undefine bind_textdomain_codeset. (Daniel +Drake) + +Mac: "make install" didn't copy rgb.txt. + +When editing a compressed file while there are folds caused "ml_get" errors +and some lines could be missing. When decompressing failed option values were +not restored. + + +Patch 7.1a.001 +Problem: Crash when downloading a spell file. (Szabolcs Horvat) +Solution: Avoid that did_set_spelllang() is used recursively when a new + window is opened for the download. + Also avoid wiping out the wrong buffer. +Files: runtime/autoload/spellfile.vim, src/buffer.c, src/ex_cmds.c, + src/spell.c + +Patch 7.1a.002 (extra) +Problem: Compilation error with MingW. +Solution: Check for LPTOOLTIPTEXT to be defined. +Files: src/gui_w32.c + + +Fixes after Vim 7.1b BETA: + +Made the Mzscheme interface build both with old and new versions of Mzscheme, +using an #ifdef. (Sergey Khorev) +Mzscheme interface didn't link, missing function. Changed order of libraries +in the configure script. + +Ruby interface didn't compile on Mac. Changed #ifdef. (Kevin Ballard) + +Patch 7.1b.001 (extra) +Problem: Random text in a source file. No idea how it got there. +Solution: Delete the text. +Files: src/gui_w32.c + +Patch 7.1b.002 +Problem: When 'maxmem' is large there can be an overflow in computations. + (Thomas Wiegner) +Solution: Use the same mechanism as in mch_total_mem(): first reduce the + multiplier as much as possible. +Files: src/memfile.c + +============================================================================== +VERSION 7.2 *version-7.2* *version7.2* + +This section is about improvements made between version 7.1 and 7.2. + +This is mostly a bug-fix release. The main new feature is floating point +support. |Float| + + +Changed *changed-7.2* +------- + +Changed the command line buffer name from "command-line" to "[Command Line]". + +Removed optional ! for ":caddexpr", ":cgetexpr", ":cgetfile", ":laddexpr", +":lgetexpr" and ":lgetfile". They are not needed. (Yegappan Lakshmanan) + +An offset for syntax matches worked on bytes instead of characters. That is +inconsistent and can easily be done wrong. Use character offsets now. +(Yukihiro Nakadaira) + +The FileChangedShellPost event was also given when a file didn't change. +(John Little) + +When the current line is long (doesn't fit) the popup menu can't be seen. +Display it below the screen line instead of below the text line. +(Francois Ingelrest) + +Switched to autoconf version 2.62. + +Moved including fcntl.h to vim.h and removed it from all .c files. + +Introduce macro STRMOVE(d, s), like STRCPY() for overlapping strings. +Use it instead of mch_memmove(p, p + x, STRLEN(p + x) + 1). + +Removed the bulgarian.vim keymap file, two more standard ones replace it. +(Boyko Bantchev) + +Increased the maximum number of tag matches for command line completion from +200 to 300. + +Renamed help file sql.txt to ft_sql.txt and ada.txt to ft_ada.txt. + + +Added *added-7.2* +----- + +New syntax files: + CUDA (Timothy B. Terriberry) + Cdrdao config (Nikolai Weibull) + Coco/R (Ashish Shukla) + Denyhosts config (Nikolai Weibull) + Dtrace script (Nicolas Weber) + Git output, commit, config, rebase, send-email (Tim Pope) + HASTE and HastePreProc (M. Tranchero) + Haml (Tim Pope) + Host conf (Nikolai Weibull) + Linden script (Timo Frenay) + MS messages (Kevin Locke) + PDF (Tim Pope) + ProMeLa (Maurizio Tranchero) + Reva Foth (Ron Aaron) + Sass (Tim Pope) + Symbian meta-makefile, MMP (Ron Aaron) + VOS CM macro (Andrew McGill) + XBL (Doug Kearns) + +New tutor files: + Made UTF-8 versions of all the tutor files. + Greek renamed from ".gr" to ".el" (Greek vs Greece). + Esperanto (Dominique Pelle) + Croatian (Paul B. Mahol) + +New filetype plugins: + Cdrdao config (Nikolai Weibull) + Debian control files (Debian Vim maintainers) + Denyhosts (Nikolai Weibull) + Dos .ini file (Nikolai Weibull) + Dtrace script (Nicolas Weber) + FnameScript (Nikolai Weibull) + Git, Git config, Git commit, Git rebase, Git send-email (Tim Pope) + Haml (Tim Pope) + Host conf (Nikolai Weibull) + Host access (Nikolai Weibull) + Logtalk (Paulo Moura) + MS messages (Kevin Locke) + NSIS script (Nikolai Weibull) + PDF (Tim Pope) + Reva Forth (Ron Aaron) + Sass (Tim Pope) + +New indent files: + DTD (Nikolai Weibull) + Dtrace script (Nicolas Weber) + Erlang (Csaba Hoch) + FrameScript (Nikolai Weibull) + Git config (Tim Pope) + Haml (Tim Pope) + Logtalk (Paulo Moura) + Sass (Tim Pope) + Tiny Fugue (Christian J. Robinson) + +New compiler plugins: + RSpec (Tim Pope) + +New keymap files: + Croatian (Paul B. Mahol) + Russian Dvorak (Serhiy Boiko) + Ukrainian Dvorak (Serhiy Boiko) + Removed plain Bulgarian, "bds" and phonetic are sufficient. + +Other new runtime files: + Esperanto menu and message translations. (Dominique Pelle) + Finnish menu and message translations. (Flammie Pirinen) + Brazilian Portuguese message translations. (Eduardo Dobay) + +Added floating point support. |Float| + +Added argument to mode() to return a bit more detail about the current mode. +(Ben Schmidt) + +Added support for BSD console mouse: |sysmouse|. (Paul B. Mahol) + +Added the "newtab" value for the 'switchbuf' option. (partly by Yegappan +Lakshmanan) + +Improved error messages for the netbeans interface. (Philippe Fremy) + +Added support for using xterm mouse codes for screen. (Micah Cowan) + +Added support for cross compiling: +Adjusted configure.in and added INSTALLcross.txt. (Marc Haisenko) Fixed +mistakes in configure.in after that. +Don't use /usr/local/include and /usr/local/lib in configure. (Philip +Prindeville) +For cross compiling the Cygwin version on Unix, change VIM.TLB to vim.tlb in +src/vim.rc. (Tsuneo Nakagawa) + +Added v:searchforward variable: What direction we're searching in. (Yakov +Lerner) + + +Fixed *fixed-7.2* +----- + +Patch 7.1.001 +Problem: Still can't build with Gnome libraries. +Solution: Fix typo in bind_textdomain_codeset. (Mike Kelly) +Files: src/gui_gtk.c, src/gui_gtk_x11.c + +Patch 7.1.002 +Problem: Oracle Pro*C/C++ files are not detected. +Solution: Add the missing star. (Micah J. Cowan) +Files: runtime/filetype.vim + +Patch 7.1.003 (extra) +Problem: The "Tear off this menu" message appears in the message history + when using a menu. (Yongwei Wu) +Solution: Disable message history when displaying the menu tip. +Files: src/gui_w32.c + +Patch 7.1.004 +Problem: Crash when doing ":next directory". (Raphael Finkel) +Solution: Do not use "buf", it may be invalid after autocommands. +Files: src/ex_cmds.c + +Patch 7.1.005 +Problem: "cit" used on <foo></foo> deletes <foo>. Should not delete + anything and start insertion, like "ci'" does on "". (Michal + Bozon) +Solution: Handle an empty object specifically. Made it work consistent for + various text objects. +Files: src/search.c + +Patch 7.1.006 +Problem: Resetting 'modified' in a StdinReadPost autocommand doesn't work. +Solution: Set 'modified' before the autocommands instead of after it. +Files: src/buffer.c + +Patch 7.1.007 (extra) +Problem: Mac: Context menu doesn't work on Intel Macs. + Scrollbars are not dimmed when Vim is not the active application. +Solution: Remove the test whether context menus are supported. They are + always there in OS/X. Handle the dimming. (Nicolas Weber) +Files: src/gui_mac.c, src/gui.h + +Patch 7.1.008 +Problem: getfsize() returns a negative number for very big files. +Solution: Check for overflow and return -2. +Files: runtime/doc/eval.txt, src/eval.c + +Patch 7.1.009 +Problem: In diff mode, displaying the difference between a tab and spaces + is not highlighted correctly. +Solution: Only change highlighting at the end of displaying a tab. +Files: src/screen.c + +Patch 7.1.010 +Problem: The Gnome session file doesn't restore tab pages. +Solution: Add SSOP_TABPAGES to the session flags. (Matias D'Ambrosio) +Files: src/gui_gtk_x11.c + +Patch 7.1.011 +Problem: Possible buffer overflow when $VIMRUNTIME is very long. (Victor + Stinner) +Solution: Use vim_snprintf(). +Files: src/main.c + +Patch 7.1.012 +Problem: ":let &shiftwidth = 'asdf'" doesn't produce an error message. +Solution: Check for a string argument. (Chris Lubinski) +Files: src/option.c + +Patch 7.1.013 +Problem: ":syn include" only loads the first file, while it is documented + as doing the equivalent of ":runtime!". +Solution: Change the argument to source_runtime(). (James Vega) +Files: src/syntax.c + +Patch 7.1.014 +Problem: Crash when doing C indenting. (Chris Monson) +Solution: Obtain the current line again after invoking cin_islabel(). +Files: src/edit.c + +Patch 7.1.015 +Problem: MzScheme interface: current-library-collection-paths produces no + list. Interface doesn't build on a Mac. +Solution: Use a list instead of a pair. (Bernhard Fisseni) Use "-framework" + argument for MZSCHEME_LIBS in configure. +Files: src/configure.in, src/if_mzsch.c, src/auto/configure + +Patch 7.1.016 (after patch 7.1.012) +Problem: Error message about setting 'diff' to a string. +Solution: Don't pass an empty string to set_option_value() when setting + 'diff'. +Files: src/quickfix.c, src/popupmnu.c + +Patch 7.1.017 +Problem: ":confirm w" does give a prompt when 'readonly' is set, but not + when the file permissions are read-only. (Michael Schaap) +Solution: Provide a dialog in both situations. (Chris Lubinski) +Files: src/ex_cmds.c, src/fileio.c, src/proto/fileio.pro + +Patch 7.1.018 +Problem: When 'virtualedit' is set a "p" of a block just past the end of + the line inserts before the cursor. (Engelke) +Solution: Check for the cursor being just after the line (Chris Lubinski) +Files: src/ops.c + +Patch 7.1.019 +Problem: ":py" asks for an argument, ":py asd" then gives the error that + ":py" isn't implemented. Should already happen for ":py". +Solution: Compare with ex_script_ni. (Chris Lubinski) +Files: src/ex_docmd.c + +Patch 7.1.020 +Problem: Reading from uninitialized memory when using a dialog. (Dominique + Pelle) +Solution: In msg_show_console_dialog() append a NUL after every appended + character. +Files: src/message.c + +Patch 7.1.021 (after 7.1.015) +Problem: Mzscheme interface doesn't compile on Win32. +Solution: Fix the problem that 7.1.015 fixed in a better way. (Sergey Khorev) +Files: src/if_mzsch.c + +Patch 7.1.022 +Problem: When setting 'keymap' twice the b:keymap_name variable isn't set. + (Milan Berta) +Solution: Don't unlet b:keymap_name for ":loadkeymap". (Martin Toft) +Files: src/digraph.c + +Patch 7.1.023 +Problem: "dw" in a line with one character deletes the line. Vi and nvi + don't do this. (Kjell Arne Rekaa) +Solution: Check for one-character words especially. +Files: src/search.c + +Patch 7.1.024 +Problem: Using a pointer that has become invalid. (Chris Monson) +Solution: Obtain the line pointer again after we looked at another line. +Files: src/search.c + +Patch 7.1.025 +Problem: search() and searchpos() don't use match under cursor at start of + line when using 'bc' flags. (Viktor Kojouharov) +Solution: Don't go to the previous line when the 'c' flag is present. + Also fix that "j" doesn't move the cursor to the right column. +Files: src/eval.c, src/search.c + +Patch 7.1.026 +Problem: "[p" doesn't work in Visual mode. (David Brown) +Solution: Use checkclearop() instead of checkclearopq(). +Files: src/normal.c + +Patch 7.1.027 +Problem: On Sun systems opening /dev/fd/N doesn't work, and they are used + by process substitutions. +Solution: Allow opening specific character special files for Sun systems. + (Gary Johnson) +Files: src/fileio.c, src/os_unix.h + +Patch 7.1.028 +Problem: Can't use last search pattern for ":sort". (Brian McKee) +Solution: When the pattern is empty use the last search pattern. (Martin + Toft) +Files: runtime/doc/change.txt, src/ex_cmds.c + +Patch 7.1.029 (after 7.1.019) +Problem: Can't compile when all interfaces are used. (Taylor Venable) +Solution: Only check for ex_script_ni when it's defined. +Files: src/ex_docmd.c + +Patch 7.1.030 +Problem: The "vimtutor" shell script checks for "vim6" but not for "vim7". + (Christian Robinson) +Solution: Check for more versions, but prefer using "vim". +Files: src/vimtutor + +Patch 7.1.031 +Problem: virtcol([123, '$']) doesn't work. (Michael Schaap) +Solution: When '$' is used for the column number get the last column. +Files: runtime/doc/eval.txt, src/eval.c + +Patch 7.1.032 +Problem: Potential crash when editing a command line. (Chris Monson) +Solution: Check the position to avoid access before the start of an array. +Files: src/ex_getln.c + +Patch 7.1.033 +Problem: A buffer is marked modified when it was first deleted and then + added again using a ":next" command. (John Mullin) +Solution: When checking if a buffer is modified use the BF_NEVERLOADED flag. +Files: src/option.c + +Patch 7.1.034 +Problem: Win64: A few compiler warnings. Problems with optimizer. +Solution: Use int instead of size_t. Disable the optimizer in one function. + (George V. Reilly) +Files: src/eval.c, src/spell.c + +Patch 7.1.035 +Problem: After ":s/./&/#" all listed lines have a line number. (Yakov + Lerner) +Solution: Reset the line number flag when not using the "&" flag. +Files: src/ex_cmds.c + +Patch 7.1.036 +Problem: Completing ":echohl" argument should include "None". (Ori + Avtalion) ":match" should have "none" too. +Solution: Add flags to use expand_highlight(). Also fix that when disabling + FEAT_CMDL_COMPL compilation fails. (Chris Lubinski) +Files: src/eval.c, src/ex_docmd.c, src/ex_getln.c, src/proto/syntax.pro + src/syntax.c + +Patch 7.1.037 +Problem: strcpy() used for overlapping strings. (Chris Monson) +Solution: Use mch_memmove() instead. +Files: src/option.c + +Patch 7.1.038 +Problem: When 'expandtab' is set then a Tab copied for 'copyindent' is + expanded to spaces, even when 'preserveindent' is set. (Alexei + Alexandrov) +Solution: Remove the check for 'expandtab'. Also fix that ">>" doesn't obey + 'preserveindent'. (Chris Lubinski) +Files: src/misc1.c + +Patch 7.1.039 +Problem: A tag in a help file that starts with "help-tags" and contains a + percent sign may make Vim crash. (Ulf Harnhammar) +Solution: Use puts() instead of fprintf(). +Files: src/ex_cmds.c + +Patch 7.1.040 +Problem: ":match" only supports three matches. +Solution: Add functions clearmatches(), getmatches(), matchadd(), + matchdelete() and setmatches(). Changed the data structures for + this. A small bug in syntax.c is fixed, so newly created + highlight groups can have their name resolved correctly from their + ID. (Martin Toft) +Files: runtime/doc/eval.txt, runtime/doc/pattern.txt, + runtime/doc/usr_41.txt, src/eval.c, src/ex_docmd.c, + src/proto/window.pro, src/screen.c, src/structs.h, src/syntax.c, + src/testdir/Makefile, src/testdir/test63.in, + src/testdir/test63.ok, src/window.c + +Patch 7.1.041 (extra, after 7.1.040) +Problem: Some changes for patch 7.1.040 are in extra files. +Solution: Update the extra files. +Files: src/testdir/Make_amiga.mak, src/testdir/Make_dos.mak, + src/testdir/Make_os2.mak, src/testdir/Make_vms.mms + +Patch 7.1.042 (after 7.1.040) +Problem: Internal error when using matchadd(). (David Larson) +Solution: Check the third argument to be present before using the fourth + argument. (Martin Toft) +Files: src/eval.c + +Patch 7.1.043 +Problem: In Ex mode using CTRL-D twice may cause a crash. Cursor isn't + positioned properly after CTRL-D. +Solution: Set prev_char properly. Position the cursor correctly. (Antony + Scriven) +Files: src/ex_getln.c + +Patch 7.1.044 +Problem: In Insert mode 0 CTRL-T deletes all indent, it should add indent. + (Gautam Iyer) +Solution: Check for CTRL-D typed. +Files: src/edit.c + +Patch 7.1.045 +Problem: Unnecessary screen redrawing. (Jjgod Jiang) +Solution: Reset "must_redraw" after clearing the screen. +Files: src/screen.c + +Patch 7.1.046 +Problem: ":s" command removes combining characters. (Ron Aaron) +Solution: Copy composing characters individually. (Chris Lubinski) +Files: src/regexp.c + +Patch 7.1.047 +Problem: vim_regcomp() called with invalid argument. (Xiaozhou Liu) +Solution: Change TRUE to RE_MAGIC + RE_STRING. +Files: src/ex_eval.c + +Patch 7.1.048 +Problem: The matchparen plugin doesn't update the match when scrolling with + the mouse wheel. (Ilya Bobir) +Solution: Set the match highlighting for text that can be scrolled into the + viewable area without moving the cursor. (Chris Lubinski) +Files: runtime/plugin/matchparen.vim + +Patch 7.1.049 +Problem: Cannot compile GTK2 version with Hangul input feature. +Solution: Don't define FEAT_XFONTSET when using GTK2. +Files: src/feature.h + +Patch 7.1.050 +Problem: Possible crash when using C++ indenting. (Chris Monson) +Solution: Keep the line pointer to the line to compare with. Avoid going + past the end of line. +Files: src/misc1.c + +Patch 7.1.051 +Problem: Accessing uninitialized memory when finding spell suggestions. +Solution: Don't try swapping characters at the end of a word. +Files: src/spell.c + +Patch 7.1.052 +Problem: When creating a new match not all fields are initialized, which + may lead to unpredictable results. +Solution: Initialise rmm_ic and rmm_maxcol. +Files: src/window.c + +Patch 7.1.053 +Problem: Accessing uninitialized memory when giving a message. +Solution: Check going the length before checking for a NUL byte. +Files: src/message.c + +Patch 7.1.054 +Problem: Accessing uninitialized memory when displaying the fold column. +Solution: Add a NUL to the extra array. (Dominique Pelle). Also do this in + a couple of other situations. +Files: src/screen.c + +Patch 7.1.055 +Problem: Using strcpy() with arguments that overlap. +Solution: Use mch_memmove() instead. +Files: src/buffer.c, src/charset.c, src/eval.c, src/ex_getln.c, + src/misc1.c, src/regexp.c, src/termlib.c + +Patch 7.1.056 +Problem: More prompt does not behave correctly after scrolling back. + (Randall W. Morris) +Solution: Avoid lines_left becomes negative. (Chris Lubinski) Don't check + mp_last when deciding to show the more prompt. (Martin Toft) +Files: src/message.c + +Patch 7.1.057 +Problem: Problem with CursorHoldI when using "r" in Visual mode (Max + Dyckhoff) +Solution: Ignore CursorHold(I) when getting a second character for a Normal + mode command. Also abort the "r" command in Visual when a special + key is typed. +Files: src/normal.c + +Patch 7.1.058 +Problem: When 'rightleft' is set the completion menu is positioned wrong. + (Baha-Eddine MOKADEM) +Solution: Fix the completion menu. (Martin Toft) +Files: src/popupmnu.c, src/proto/search.pro, src/search.c + +Patch 7.1.059 +Problem: When in Ex mode and doing "g/^/vi" and then pressing CTRL-C Vim + hangs and beeps. (Antony Scriven) +Solution: Clear "got_int" in the main loop to avoid the hang. When typing + CTRL-C twice in a row abort the ":g" command. This is Vi + compatible. +Files: src/main.c + +Patch 7.1.060 +Problem: Splitting quickfix window messes up window layout. (Marius + Gedminas) +Solution: Compute the window size in a smarter way. (Martin Toft) +Files: src/window.c + +Patch 7.1.061 +Problem: Win32: When 'encoding' is "latin1" 'ignorecase' doesn't work for + characters with umlaut. (Joachim Hofmann) +Solution: Do not use islower()/isupper()/tolower()/toupper() but our own + functions. (Chris Lubinski) +Files: src/mbyte.c, src/regexp.c, src/vim.h + +Patch 7.1.062 (after 7.1.038) +Problem: Indents of C comments can be wrong. (John Mullin) +Solution: Adjust ind_len. (Chris Lubinski) +Files: src/misc1.c + +Patch 7.1.063 (after 7.1.040) +Problem: Warning for uninitialized variable. +Solution: Initialise it to NULL. +Files: src/ex_docmd.c + +Patch 7.1.064 +Problem: On Interix some files appear not to exist. +Solution: Remove the top bit from st_mode. (Ligesh) +Files: src/os_unix.c + +Patch 7.1.065 (extra) +Problem: Win32: Compilation problem for newer version of w32api. +Solution: Only define __IID_DEFINED__ when needed. (Chris Sutcliffe) +Files: src/Make_ming.mak, src/iid_ole.c + +Patch 7.1.066 +Problem: When 'bomb' is set or reset the file should be considered + modified. (Tony Mechelynck) +Solution: Handle like 'endofline'. (Martin Toft) +Files: src/buffer.c, src/fileio.c, src/option.c, src/structs.h + +Patch 7.1.067 +Problem: 'thesaurus' doesn't work when 'infercase' is set. (Mohsin) +Solution: Don't copy the characters being completed but check the case and + apply it to the suggested word. Also fix that the first word in + the thesaurus line is not used. (Martin Toft) +Files: src/edit.c + +Patch 7.1.068 +Problem: When 'equalalways' is set and splitting a window, it's possible + that another small window gets bigger. +Solution: Only equalize window sizes when after a split the windows are + smaller than another window. (Martin Toft) +Files: runtime/doc/options.txt, runtime/doc/windows.txt, src/window.c + +Patch 7.1.069 +Problem: GTK GUI: When using confirm() without a default button there still + is a default choice. +Solution: Ignore Enter and Space when there is no default button. (Chris + Lubinski) +Files: src/gui_gtk.c + +Patch 7.1.070 (extra) +Problem: Win32 GUI: When using confirm() without a default button there + still is a default choice. +Solution: Set focus on something else than a button. (Chris Lubinski) +Files: src/gui_w32.c + +Patch 7.1.071 (after 7.1.040) +Problem: Regexp patterns are not tested. +Solution: Add a basic test, to be expanded later. + Also add (commented-out) support for valgrind. +Files: src/testdir/Makefile, src/testdir/test64.in, src/testdir/test64.ok + +Patch 7.1.072 (extra, after 7.1.041 and 7.1.071) +Problem: Some changes for patch 7.1.071 are in extra files. +Solution: Update the extra files. Also fix a few warnings from the DOS test + makefile. +Files: src/testdir/Make_amiga.mak, src/testdir/Make_dos.mak, + src/testdir/Make_os2.mak, src/testdir/Make_vms.mms + +Patch 7.1.073 (after 7.1.062) +Problem: Wrong cursor position and crash when 'preserveindent' is set. + (Charles Campbell) +Solution: Handle the situation that we start without indent. (Chris + Lubinski) +Files: src/misc1.c + +Patch 7.1.074 +Problem: Crash when calling string() on a recursively nested List. +Solution: Check result value for being NULL. (Yukihiro Nakadaira) +Files: src/eval.c + +Patch 7.1.075 +Problem: ":let v:statusmsg" reads memory already freed. +Solution: Don't set v:statusmsg when listing it. +Files: src/eval.c + +Patch 7.1.076 +Problem: Another strcpy() with overlapping arguments. +Solution: Use mch_memmove(). (Dominique Pelle) And another one. +Files: src/ex_docmd.c, src/normal.c + +Patch 7.1.077 +Problem: Using "can_spell" without initializing it. (Dominique Pelle) +Solution: Set a default for get_syntax_attr(). +Files: src/syntax.c + +Patch 7.1.078 +Problem: Dropping a file name on gvim that contains a CSI byte doesn't work + when editing the command line. +Solution: Escape the CSI byte when inserting in the input buffer. (Yukihiro + Nakadaira) +Files: src/gui.c, src/ui.c + +Patch 7.1.079 +Problem: When the locale is "C" and 'encoding' is "latin1" then the "@" + character in 'isfname', 'isprint', etc. doesn't pick up accented + characters. +Solution: Instead of isalpha() use MB_ISLOWER() and MB_ISUPPER(). +Files: src/charset.c, src/macros.h + +Patch 7.1.080 (extra) +Problem: Compiler warnings for using "const char *" for "char *". +Solution: Add type casts. (Chris Sutcliffe) +Files: src/GvimExt/gvimext.cpp + +Patch 7.1.081 +Problem: Command line completion for a shell command: "cat </tmp/file<Tab>" + doesn't work. +Solution: Start the file name at any character that can't be in a file name. + (Martin Toft) +Files: src/ex_docmd.c + +Patch 7.1.082 +Problem: After a ":split" the matchparen highlighting isn't there. +Solution: Install a WinEnter autocommand. Also fixes that after + ":NoMatchParen" only the current window is updated. (Martin Toft) +Files: runtime/doc/pi_paren.txt, runtime/plugin/matchparen.vim + +Patch 7.1.083 (after 7.1.081) +Problem: Command line completion doesn't work with wildcards. +Solution: Add vim_isfilec_or_wc() and use it. (Martin Toft) +Files: src/charset.c, src/proto/charset.pro, src/ex_docmd.c + +Patch 7.1.084 +Problem: Using the "-nb" argument twice causes netbeans not to get + fileOpened events. +Solution: Change "&" to "&&". (Xavier de Gaye) +Files: src/ex_cmds.c + +Patch 7.1.085 +Problem: ":e fold.c" then ":sp fold.c" results in folds of original window + to disappear. (Akita Noek) +Solution: Invoke foldUpdateAll() for all windows of the changed buffer. + (Martin Toft) +Files: src/ex_cmds.c + +Patch 7.1.086 +Problem: Crash when using specific Python syntax highlighting. (Quirk) +Solution: Check for a negative index, coming from a keyword match at the + start of a line from a saved state. +Files: src/syntax.c + +Patch 7.1.087 +Problem: Reading past ":cscope find" command. Writing past end of a buffer. +Solution: Check length of the argument before using the pattern. Use + vim_strncpy(). (Dominique Pelle) +Files: if_cscope.c + +Patch 7.1.088 (extra) +Problem: The coordinates used by ":winpos" differ from what getwinposx() + and getwinposy() return. +Solution: Use MoveWindowStructure() instead of MoveWindow(). (Michael Henry) +Files: src/gui_mac.c + +Patch 7.1.089 +Problem: ":let loaded_getscriptPlugin" doesn't clear to eol, result is + "#1in". +Solution: Clear to the end of the screen after displaying the first variable + value. +Files: src/eval.c + +Patch 7.1.090 +Problem: Compiler warning on Mac OS X 10.5. +Solution: Don't redeclare sigaltstack(). (Hisashi T Fujinaka) +Files: src/os_unix.c + +Patch 7.1.091 (extra) +Problem: Win32: Can't embed Vim inside another application. +Solution: Add the --windowid argument. (Nageshwar) +Files: runtime/doc/gui_w32.txt, runtime/doc/starting.txt, + runtime/doc/vi_diff.txt, src/globals.h, src/gui_w32.c, src/main.c + +Patch 7.1.092 (extra, after 7.1.088) +Problem: Wrong arguments for MoveWindowStructure(). +Solution: Remove "TRUE". (Michael Henry) +Files: src/gui_mac.c + +Patch 7.1.093 +Problem: Reading past end of a screen line when determining cell width. + (Dominique Pelle) +Solution: Add an argument to mb_off2cells() for the maximum offset. +Files: src/globals.h, src/gui.c, src/mbyte.c, src/proto/mbyte.pro, + src/screen.c + +Patch 7.1.094 +Problem: When checking if syntax highlighting is present, looking in the + current buffer instead of the specified one. +Solution: Use "buf" instead of "curbuf". +Files: src/syntax.c + +Patch 7.1.095 +Problem: The FocusLost and FocusGained autocommands are triggered + asynchronously in the GUI. This may cause arbitrary problems. +Solution: Put the focus event in the input buffer and handle it when ready + for it. +Files: src/eval.c, src/getchar.c, src/gui.c, src/gui_gtk_x11.c, + src/keymap.h + +Patch 7.1.096 +Problem: Reading past end of a string when resizing Vim. (Dominique Pelle) +Solution: Check the string pointer before getting the char it points to. +Files: src/message.c + +Patch 7.1.097 +Problem: ":setlocal stl=%!1+1" does not work. +Solution: Adjust check for pointer. (Politz) +Files: src/option.c + +Patch 7.1.098 +Problem: ":call s:var()" doesn't work if "s:var" is a Funcref. (Andy Wokula) +Solution: Before converting "s:" into a script ID, check if it is a Funcref. +Files: src/eval.c + +Patch 7.1.099 +Problem: When the 'keymap' and 'paste' options have a non-default value, + ":mkexrc" and ":mksession" do not correctly set the options. +Solution: Set the options with side effects before other options. +Files: src/option.c + +Patch 7.1.100 +Problem: Win32: Executing cscope doesn't always work properly. +Solution: Use another way to invoke cscope. (Mike Williams) +Files: src/if_cscope.c, src/if_cscope.h, src/main.c, + src/proto/if_cscope.pro + +Patch 7.1.101 +Problem: Ruby: The Buffer.line= method does not work. +Solution: Add the "self" argument to set_current_line(). (Jonathan Hankins) +Files: src/if_ruby.c + +Patch 7.1.102 +Problem: Perl interface doesn't compile with new version of Perl. +Solution: Add two variables to the dynamic library loading. (Suresh + Govindachar) +Files: src/if_perl.xs + +Patch 7.1.103 +Problem: Using "dw" with the cursor past the end of the last line (using + CTRL-\ CTRL-O from Insert mode) deletes a character. (Tim Chase) +Solution: Don't move the cursor back when the movement failed. +Files: src/normal.c + +Patch 7.1.104 (after 7.1.095) +Problem: When 'lazyredraw' is set a focus event causes redraw to be + postponed until a key is pressed. +Solution: Instead of not returning from vgetc() when a focus event is + encountered return K_IGNORE. Add plain_vgetc() for when the + caller doesn't want to get K_IGNORE. +Files: src/digraph.c, src/edit.c, src/ex_cmds.c, src/ex_getln.c, + src/getchar.c, src/normal.c, src/proto/getchar.pro, src/window.c + +Patch 7.1.105 +Problem: Internal error when using "0 ? {'a': 1} : {}". (A.Politz) +Solution: When parsing a dictionary value without using the value, don't try + obtaining the key name. +Files: src/eval.c + +Patch 7.1.106 +Problem: ":messages" doesn't quit listing on ":". +Solution: Break the loop when "got_int" is set. +Files: src/message.c + +Patch 7.1.107 +Problem: When doing a block selection and using "s" to change the text, + while triggering auto-indenting, causes the wrong text to be + repeated in other lines. (Adri Verhoef) +Solution: Compute the change of indent and compensate for that. +Files: src/ops.c + +Patch 7.1.108 (after 7.1.100) +Problem: Win32: Compilation problems in Cscope code. (Jeff Lanzarotta) +Solution: Use (long) instead of (intptr_t) when it's not defined. +Files: src/if_cscope.c + +Patch 7.1.109 +Problem: GTK: when there are many tab pages, clicking on the arrow left of + the labels moves to the next tab page on the right. (Simeon Bird) +Solution: Check the X coordinate of the click and pass -1 as value for the + left arrow. +Files: src/gui_gtk_x11.c, src/term.c + +Patch 7.1.110 (after 7.1.102) +Problem: Win32: Still compilation problems with Perl. +Solution: Change the #ifdefs. (Suresh Govindachar) +Files: src/if_perl.xs + +Patch 7.1.111 +Problem: When using ":vimgrep" with the "j" flag folds from another buffer + may be displayed. (A.Politz) +Solution: When not jumping to another buffer update the folds. +Files: src/quickfix.c + +Patch 7.1.112 +Problem: Using input() with a wrong argument may crash Vim. (A.Politz) +Solution: Init the input() return value to NULL. +Files: src/eval.c + +Patch 7.1.113 +Problem: Using map() to go over an empty list causes memory to be freed + twice. (A.Politz) +Solution: Don't clear the typeval in restore_vimvar(). +Files: src/eval.c + +Patch 7.1.114 +Problem: Memory leak in getmatches(). +Solution: Don't increment the refcount twice. +Files: src/eval.c + +Patch 7.1.115 (after 7.1.105) +Problem: Compiler warning for uninitialized variable. (Tony Mechelynck) +Solution: Init variable to NULL. +Files: src/eval.c + +Patch 7.1.116 +Problem: Cannot display Unicode characters above 0x10000. +Solution: Remove the replacement with a question mark when UNICODE16 is not + defined. (partly by Nicolas Weber) +Files: src/screen.c + +Patch 7.1.117 +Problem: Can't check whether Vim was compiled with Gnome. (Tony Mechelynck) +Solution: Add gui_gnome to the has() list. +Files: src/eval.c + +Patch 7.1.118 (after 7.1.107) +Problem: Compiler warning for Visual C compiler. +Solution: Add typecast. (Mike Williams) +Files: src/ops.c + +Patch 7.1.119 +Problem: Crash when 'cmdheight' set to very large value. (A.Politz) +Solution: Limit 'cmdheight' to 'lines' minus one. Store right value of + 'cmdheight' when running out of room. +Files: src/option.c, src/window.c + +Patch 7.1.120 +Problem: Can't properly check memory leaks while running tests. +Solution: Add an argument to garbagecollect(). Delete functions and + variables in the test scripts. +Files: runtime/doc/eval.txt src/eval.c, src/globals.h, src/main.c, + src/testdir/Makefile, src/testdir/test14.in, + src/testdir/test26.in, src/testdir/test34.in, + src/testdir/test45.in, src/testdir/test47.in, + src/testdir/test49.in, src/testdir/test55.in, + src/testdir/test56.in, src/testdir/test58.in, + src/testdir/test59.in, src/testdir/test60.in, + src/testdir/test60.vim, src/testdir/test62.in, + src/testdir/test63.in, src/testdir/test64.in, + +Patch 7.1.121 +Problem: Using ":cd %:h" when editing a file in the current directory + results in an error message for using an empty string. +Solution: When "%:h" results in an empty string use ".". +Files: src/eval.c + +Patch 7.1.122 +Problem: Mac: building Vim.app fails. Using wrong architecture. +Solution: Use line continuation for the gui_bundle dependency. Detect the + system architecture with "uname -a". +Files: src/main.aap + +Patch 7.1.123 +Problem: Win32: ":edit foo ~ foo" expands "~". +Solution: Change the call to expand_env(). +Files: src/ex_docmd.c, src/misc1.c, src/proto/misc1.pro, src/option.c + +Patch 7.1.124 (extra) +Problem: Mac: When dropping a file on Vim.app that is already in the buffer + list (from .viminfo) results in editing an empty, unnamed buffer. + (Axel Kielhorn) Also: warning for unused variable. +Solution: Move to the buffer of the first argument. Delete unused variable. +Files: src/gui_mac.c + +Patch 7.1.125 +Problem: The TermResponse autocommand event is not always triggered. (Aron + Griffis) +Solution: When unblocking autocommands check if v:termresponse changed and + trigger the event then. +Files: src/buffer.c, src/diff.c, src/ex_getln.c, src/fileio.c, + src/globals.h, src/misc2.c, src/proto/fileio.pro, src/window.c + +Patch 7.1.126 (extra) +Problem: ":vimgrep */*" fails when a BufRead autocommand changes directory. + (Bernhard Kuhn) +Solution: Change back to the original directory after loading a file. + Also: use shorten_fname1() to avoid duplicating code. +Files: src/buffer.c, src/ex_docmd.c, src/fileio.c, src/gui_gtk.c, + src/gui_w48.c, src/proto/ex_docmd.pro, src/proto/fileio.pro, + src/quickfix.c + +Patch 7.1.127 +Problem: Memory leak when doing cmdline completion. (Dominique Pelle) +Solution: Free "orig" argument of ExpandOne() when it's not used. +Files: src/ex_getln.c + +Patch 7.1.128 (extra) +Problem: Build problems with new version of Cygwin. +Solution: Remove -D__IID_DEFINED__, like with MingW. (Guopeng Wen) +Files: src/Make_cyg.mak + +Patch 7.1.129 (extra) +Problem: Win32: Can't get the user name when it is longer than 15 + characters. +Solution: Use UNLEN instead of MAX_COMPUTERNAME_LENGTH. (Alexei Alexandrov) +Files: src/os_win32.c + +Patch 7.1.130 +Problem: Crash with specific order of undo and redo. (A.Politz) +Solution: Clear and adjust pointers properly. Add u_check() for debugging. +Files: src/undo.c, src/structs.h + +Patch 7.1.131 +Problem: ":mksession" always adds ":setlocal autoread". (Christian J. + Robinson) +Solution: Skip boolean global/local option using global value. +Files: src/option.c + +Patch 7.1.132 +Problem: getpos("'>") may return a negative column number for a Linewise + selection. (A.Politz) +Solution: Don't add one to MAXCOL. +Files: src/eval.c + +Patch 7.1.133 (after 7.1.126) +Problem: shorten_fname1() linked when it's not needed. +Solution: Add #ifdef. +Files: src/fileio.c + +Patch 7.1.134 (extra) +Problem: Win32: Can't build with VC8 +Solution: Detect the MSVC version instead of using NMAKE_VER. + (Mike Williams) +Files: src/Make_mvc.mak + +Patch 7.1.135 +Problem: Win32: When editing a file c:\tmp\foo and c:\tmp\\foo we have two + buffers for the same file. (Suresh Govindachar) +Solution: Invoke FullName_save() when a path contains "//" or "\\". +Files: src/buffer.c + +Patch 7.1.136 +Problem: Memory leak when using Ruby syntax highlighting. (Dominique Pelle) +Solution: Free the contained-in list. +Files: src/syntax.c + +Patch 7.1.137 +Problem: Build failure when using EXITFREE. (Dominique Pelle) +Solution: Add an #ifdef around using clip_exclude_prog. +Files: src/misc2.c + +Patch 7.1.138 +Problem: The Perl Msg() function doesn't stop when "q" is typed at the more + prompt. (Hari Krishna Dara) +Solution: Check got_int. +Files: src/if_perl.xs + +Patch 7.1.139 +Problem: When using marker folding and ending Insert mode with CTRL-C the + current fold is truncated. (Fred Kater) +Solution: Ignore got_int while updating folds. +Files: src/fold.c + +Patch 7.1.140 +Problem: v:count is set only after typing a non-digit, that makes it + difficult to make a nice mapping. +Solution: Set v:count while still typing the count. +Files: src/normal.c + +Patch 7.1.141 +Problem: GTK: -geom argument doesn't support a negative offset. +Solution: Compute position from the right/lower corner. +Files: src/gui_gtk_x11.c + +Patch 7.1.142 +Problem: ":redir @A>" doesn't work. +Solution: Ignore the extra ">" also when appending. (James Vega) +Files: src/ex_docmd.c + +Patch 7.1.143 +Problem: Uninitialized memory read when diffing three files. (Dominique + Pelle) +Solution: Remove "+ !notset" so that we don't use fields that were not + computed. +Files: src/diff.c + +Patch 7.1.144 +Problem: After ":diffup" cursor can be in the wrong position. +Solution: Force recomputing the cursor position. +Files: src/diff.c + +Patch 7.1.145 +Problem: Insert mode completion: When using the popup menu, after + completing a word and typing a non-word character Vim is still + completing the same word, following CTRL-N doesn't work. + Insert mode Completion: When using CTRL-X O and there is only + "struct." before the cursor, typing one char to reduce the + matches, then BS completion stops. +Solution: When typing a character that is not part of the item being + completed, stop complete mode. For whole line completion also + accept a space. For file name completion stop at a path + separator. + For omni completion stay in completion mode even if completing + with empty string. +Files: src/edit.c + +Patch 7.1.146 (extra) +Problem: VMS: Files with a very rare record organization (VFC) cannot be + properly written by Vim. + On older VAX systems mms runs into a syntax error. +Solution: Check for this special situation. Do not wrap a comment, make it + one long line. (Zoltan Arpadffy) +Files: src/fileio.c, src/Make_vms.mms + +Patch 7.1.147 (after 7.1.127) +Problem: Freeing memory already freed when completing user name. (Meino + Cramer) +Solution: Use a flag to remember if "orig" needs to be freed. +Files: src/ex_getln.c + +Patch 7.1.148 +Problem: Some types are not found by configure. +Solution: Test for the sys/types.h header file. (Sean Boudreau) +Files: src/configure.in, src/auto/configure + +Patch 7.1.149 +Problem: GTK GUI: When the completion popup menu is used scrolling another + window by the scrollbar is OK, but using the scroll wheel it + behaves line <Enter>. +Solution: Ignore K_MOUSEDOWN and K_MOUSEUP. Fix redrawing the popup menu. +Files: src/edit.c, src/gui.c + +Patch 7.1.150 +Problem: When 'clipboard' has "unnamed" using "p" in Visual mode doesn't + work correctly. (Jianrong Yu) +Solution: When 'clipboard' has "unnamed" also obtain the selection when + getting the default register. +Files: src/ops.c + +Patch 7.1.151 +Problem: Using whole line completion with 'ignorecase' and 'infercase' set + and the line is empty get an lalloc(0) error. +Solution: Don't try changing case for an empty match. (Matthew Wozniski) +Files: src/edit.c + +Patch 7.1.152 +Problem: Display problem when 'hls' and 'cursorcolumn' are set and + searching for "$". (John Mullin) Also when scrolling + horizontally when 'wrap' is off. +Solution: Keep track of the column where highlighting was set. Check the + column offset when skipping characters. +Files: src/screen.c + +Patch 7.1.153 +Problem: Compiler warnings on SGI. Undefined XpmAllocColor (Charles + Campbell) +Solution: Add type casts. Init st_dev and st_ino separately. Don't use + type casts for vim_snprintf() when HAVE_STDARG_H is defined. + Define XpmAllocColor when needed. +Files: src/eval.c, src/ex_cmds.c, src/fileio.c, src/misc2.c, + src/gui_xmebw.c + +Patch 7.1.154 +Problem: Compiler warning for signed/unsigned compare. +Solution: Add type cast. +Files: src/screen.c + +Patch 7.1.155 +Problem: Crash when 'undolevels' is 0 and repeating "udd". (James Vega) +Solution: When there is only one branch use u_freeheader() to delete it. +Files: src/undo.c + +Patch 7.1.156 +Problem: Overlapping arguments for strcpy() when expanding command line + variables. +Solution: Use mch_memmove() instead of STRCPY(). Also fix a few typos. + (Dominique Pelle) +Files: src/ex_docmd.c + +Patch 7.1.157 +Problem: In Ex mode, :" gives an error at end-of-file. (Michael Hordijk) +Solution: Only give an error for an empty line, not for a comment. +Files: src/ex_docmd.c + +Patch 7.1.158 (extra) +Problem: Win32 console: When 'encoding' is "utf-8" and typing Alt-y the + result is wrong. Win32 GUI: Alt-y results in "u" when 'encoding' + is "cp1250" (Lukas Cerman) +Solution: For utf-8 don't set the 7th bit in a byte, convert to the correct + byte sequence. For cp1250, when conversion to 'encoding' results + in the 7th bit not set, set the 7th bit after conversion. +Files: src/os_win32.c, src/gui_w48.c + +Patch 7.1.159 +Problem: strcpy() has overlapping arguments. +Solution: Use mch_memmove() instead. (Dominique Pelle) +Files: src/ex_cmds.c + +Patch 7.1.160 +Problem: When a focus autocommand is defined, getting or losing focus + causes the hit-enter prompt to be redrawn. (Bjorn Winckler) +Solution: Overwrite the last line. +Files: src/message.c + +Patch 7.1.161 +Problem: Compilation errors with tiny features and EXITFREE. +Solution: Add #ifdefs. (Dominique Pelle) +Files: src/edit.c, src/misc2.c + +Patch 7.1.162 +Problem: Crash when using a modifier before "while" or "for". (A.Politz) +Solution: Skip modifiers when checking for a loop command. +Files: src/proto/ex_docmd.pro, src/ex_docmd.c, src/ex_eval.c + +Patch 7.1.163 +Problem: Warning for the unknown option 'bufsecret'. +Solution: Remove the lines .vim that use this option. (Andy Wokula) +Files: runtime/menu.vim + +Patch 7.1.164 +Problem: Reading past end of regexp pattern. (Dominique Pelle) +Solution: Use utf_ptr2len(). +Files: src/regexp.c + +Patch 7.1.165 +Problem: Crash related to getting X window ID. (Dominique Pelle) +Solution: Don't trust the window ID that we got in the past, check it every + time. +Files: src/os_unix.c + +Patch 7.1.166 +Problem: Memory leak for using "gp" in Visual mode. +Solution: Free memory in put_register(). (Dominique Pelle) +Files: src/ops.c + +Patch 7.1.167 +Problem: Xxd crashes when using "xxd -b -c 110". (Debian bug 452789) +Solution: Allocate more memory. Fix check for maximum number of columns. +Files: src/xxd/xxd.c + +Patch 7.1.168 (extra) +Problem: Win32 GUI: Since patch 7.1.095, when the Vim window does not have + focus, clicking in it doesn't position the cursor. (Juergen + Kraemer) +Solution: Don't reset s_button_pending just after receiving focus. +Files: src/gui_w48.c + +Patch 7.1.169 +Problem: Using uninitialized variable when system() fails. (Dominique + Pelle) +Solution: Let system() return an empty string when it fails. +Files: src/eval.c + +Patch 7.1.170 +Problem: Valgrind warning for overlapping arguments for strcpy(). +Solution: Use mch_memmove() instead. (Dominique Pelle) +Files: src/getchar.c + +Patch 7.1.171 +Problem: Reading one byte before allocated memory. +Solution: Check index not to become negative. (Dominique Pelle) +Files: src/ex_getln.c + +Patch 7.1.172 +Problem: When 'buftype' is "acwrite" Vim still checks if the file or + directory exists before overwriting. +Solution: Don't check for overwriting when the buffer name is not a file + name. +Files: src/ex_cmds.c + +Patch 7.1.173 +Problem: Accessing freed memory. (Dominique Pelle) +Solution: Don't call reg_getline() to check if a line is the first in the + file. +Files: src/regexp.c + +Patch 7.1.174 +Problem: Writing NUL past end of a buffer. +Solution: Copy one byte less when using strncat(). (Dominique Pelle) +Files: src/ex_cmds.c, src/ex_docmd.c, + +Patch 7.1.175 +Problem: <BS> doesn't work with some combination of 'sts', 'linebreak' and + 'backspace'. (Francois Ingelrest) +Solution: When adding white space results in not moving back delete one + character. +Files: src/edit.c + +Patch 7.1.176 +Problem: Building with Aap fails when the "compiledby" argument contains + '<' or '>' characters. (Alex Yeh) +Solution: Change how quoting is done in the Aap recipe. +Files: src/main.aap + +Patch 7.1.177 +Problem: Freeing memory twice when in debug mode while reading a script. +Solution: Ignore script input while in debug mode. +Files: src/ex_cmds2.c, src/getchar.c, src/globals.h + +Patch 7.1.178 +Problem: "%" doesn't work on "/* comment *//* comment */". +Solution: Don't handle the "//" in "*//*" as a C++ comment. (Markus + Heidelberg) +Files: src/search.c + +Patch 7.1.179 +Problem: Need to check for TCL 8.5. +Solution: Adjust configure script. (Alexey Froloff) +Files: src/configure.in, src/auto/configure + +Patch 7.1.180 +Problem: Regexp patterns not tested sufficiently. +Solution: Add more checks to the regexp test. +Files: src/testdir/test64.in, src/testdir/test64.ok + +Patch 7.1.181 +Problem: Accessing uninitialized memory in Farsi mode. (Dominique Pelle) +Solution: Only invoke lrF_sub() when there is something to do. +Files: src/ex_cmds.c + +Patch 7.1.182 +Problem: When using tab pages and an argument list the session file may + contain wrong "next" commands. (Alexander Bluem) +Solution: Use "argu" commands and only when needed. +Files: src/ex_docmd.c + +Patch 7.1.183 +Problem: "Internal error" for ":echo matchstr('a', 'a\%[\&]')" (Mitanu + Paul) +Solution: Inside "\%[]" detect \&, \| and \) as an error. +Files: src/regexp.c + +Patch 7.1.184 +Problem: Crash when deleting backwards over a line break in Insert mode. +Solution: Don't advance the cursor when it's already on the NUL after a + line. (Matthew Wozniski) +Files: src/normal.c + +Patch 7.1.185 +Problem: Using "gR" with a multi-byte encoding and typing a CR pushes + characters onto the replace stack incorrectly, resulting in BS + putting back the wrong characters. (Paul B. Mahol) +Solution: Push multi-byte characters onto the replace stack in reverse byte + order. Add replace_push_mb(). +Files: src/edit.c, src/misc1.c, src/proto/edit.pro + +Patch 7.1.186 +Problem: "expand('<afile>')" returns a bogus value after changing + directory. (Dave Fishburn) +Solution: Copy "autocmd_fname" to allocated memory and expand to full + filename. Shorten the path when expanding <afile>. +Files: src/ex_docmd.c, src/fileio.c + +Patch 7.1.187 +Problem: Win32 GUI: Custom completion using system() no longer works + after patch 7.1.104. (Erik Falor) +Solution: Loop when safe_vgetc() returns K_IGNORE. +Files: src/ex_getln.c + +Patch 7.1.188 +Problem: When 'showmode' is off the message for changing a readonly file is + given in the second column instead of the first. (Payl B. Mahol) +Solution: Put the W10 message in the first column. +Files: src/edit.c + +Patch 7.1.189 (after 7.1.104) +Problem: Patch 7.1.104 was incomplete. +Solution: Also call plain_vgetc() in ask_yesno(). +Files: src/misc1.c + +Patch 7.1.190 +Problem: Cursor after end-of-line: "iA sentence.<Esc>)" +Solution: Move cursor back and make motion inclusive. +Files: src/normal.c + +Patch 7.1.191 +Problem: Win32 GUI: after patch 7.1.168 there is still a problem when + clicking in a scrollbar. (Juergen Jottkaerr) +Solution: Don't check the input buffer when dragging the scrollbar. +Files: src/gui.c + +Patch 7.1.192 +Problem: With Visual block selection, "s" and typing something, CTRL-C + doesn't stop Vim from repeating the replacement in other lines, + like happens for "I". +Solution: Check for "got_int" to be set. +Files: src/ops.c + +Patch 7.1.193 +Problem: Some Vim 5.x digraphs are missing in Vim 7, even though the + character pairs are not used. (Philippe de Muyter) +Solution: Add those Vim 5.x digraphs that don't conflict with others. +Files: src/digraph.c + +Patch 7.1.194 +Problem: ":echo glob('~/{}')" results in /home/user//. +Solution: Don't add a slash if there already is one. +Files: src/os_unix.c + +Patch 7.1.195 +Problem: '0 mark doesn't work for "~/foo ~ foo". +Solution: Don't expand the whole file name, only "~/". +Files: src/mark.c + +Patch 7.1.196 (extra) +Problem: Win32 GUI: "\n" in a tooltip doesn't cause a line break. (Erik + Falor) +Solution: Use the TTM_SETMAXTIPWIDTH message. +Files: src/gui_w32.c + +Patch 7.1.197 +Problem: Mac: "make install" doesn't work when prefix defined. +Solution: Pass different arguments to "make installruntime". (Jjgod Jiang) +Files: src/Makefile + +Patch 7.1.198 +Problem: Hang when using ":s/\n//gn". (Burak Gorkemli) +Solution: Set "skip_match". +Files: src/ex_cmds.c + +Patch 7.1.199 +Problem: Can't do command line completion for a specific file name + extension. +Solution: When the pattern ends in "$" don't add a star for completion and + remove the "$" before matching with file names. +Files: runtime/doc/cmdline.txt, src/ex_getln.c + +Patch 7.1.200 (after 7.1.177 and 7.1.182) +Problem: Compiler warnings for uninitialized variables. +Solution: Init variables. +Files: src/ex_cmds2.c, src/ex_docmd.c + +Patch 7.1.201 +Problem: When reading stdin 'fenc' and 'ff are not set. +Solution: Set the options after reading stdin. (Ben Schmidt) +Files: src/fileio.c + +Patch 7.1.202 +Problem: Incomplete utf-8 byte sequence is not checked for validity. +Solution: Check the bytes that are present for being valid. (Ben Schmidt) +Files: src/mbyte.c + +Patch 7.1.203 +Problem: When 'virtualedit' is "onemore" then "99|" works but ":normal 99|" + doesn't. (Andy Wokula) +Solution: Check for "onemore" flag in check_cursor_col(). +Files: src/misc2.c + +Patch 7.1.204 (extra) +Problem: Win32: Using the example at 'balloonexpr' the balloon disappears + after four seconds and then comes back again. Also moves the + mouse pointer a little bit. (Yongwei Wu) +Solution: Set the autopop time to 30 seconds (the max value). (Sergey + Khorev) Move the mouse two pixels forward and one back to end up + in the same position (really!). +Files: src/gui_w32.c + +Patch 7.1.205 +Problem: Can't get the operator in an ":omap". +Solution: Add the "v:operator" variable. (Ben Schmidt) +Files: runtime/doc/eval.txt, src/eval.c, src/normal.c, src/vim.h + +Patch 7.1.206 +Problem: Compiler warnings when using MODIFIED_BY. +Solution: Add type casts. (Ben Schmidt) +Files: src/version.c + +Patch 7.1.207 +Problem: Netbeans: "remove" cannot delete one line. +Solution: Remove partial lines and whole lines properly. Avoid a memory + leak. (Xavier de Gaye) +Files: src/netbeans.c + +Patch 7.1.208 +Problem: On Alpha get an unaligned access error. +Solution: Store the dictitem pointer before using it. (Matthew Luckie) +Files: src/eval.c + +Patch 7.1.209 +Problem: GTK: When using the netrw plugin and doing ":gui" Vim hangs. +Solution: Stop getting a selection after three seconds. This is a hack. +Files: src/gui_gtk_x11.c + +Patch 7.1.210 +Problem: Listing mapping for 0xdb fails when 'encoding' is utf-8. (Tony + Mechelynck) +Solution: Recognize K_SPECIAL KS_EXTRA KE_CSI as a CSI byte. +Files: src/mbyte.c + +Patch 7.1.211 +Problem: The matchparen plugin may take an unexpected amount of time, so + that it looks like Vim hangs. +Solution: Add a timeout to searchpair(), searchpairpos(), search() and + searchpos(). Use half a second timeout in the plugin. +Files: runtime/doc/eval.txt, runtime/plugin/matchparen.vim, src/edit.c, + src/eval.c, src/ex_cmds2.c, src/ex_docmd.c, src/normal.c, + src/proto/eval.pro, src/proto/ex_cmds2.pro, src/proto/search.pro, + src/search.c + +Patch 7.1.212 +Problem: Accessing a byte before a line. +Solution: Check that the column is 1 or more. (Dominique Pelle) +Files: src/edit.c + +Patch 7.1.213 +Problem: A ":tabedit" command that results in the "swap file exists" dialog + and selecting "abort" doesn't close the new tab. (Al Budden) +Solution: Pass "old_curwin" to do_exedit(). +Files: src/ex_docmd.c + +Patch 7.1.214 +Problem: ":1s/g\n\zs1//" deletes characters from the first line. (A Politz) +Solution: Start replacing in the line where the match starts. +Files: src/ex_cmds.c + +Patch 7.1.215 +Problem: It is difficult to figure out what syntax items are nested at a + certain position. +Solution: Add the synstack() function. +Files: runtime/doc/eval.txt, src/eval.c, src/proto/syntax.pro, + src/syntax.c + +Patch 7.1.216 +Problem: Variants of --remote-tab are not mentioned for "vim --help". +Solution: Display optional -wait and -silent. +Files: src/main.c + +Patch 7.1.217 +Problem: The "help-tags" tag may be missing from runtime/doc/tags when it + was generated during "make install". +Solution: Add the "++t" argument to ":helptags" to force adding the tag. +Files: runtime/doc/Makefile, runtime/doc/various.txt, src/ex_cmds.c, + src/ex_cmds.h + +Patch 7.1.218 +Problem: A syntax region without a "keepend", containing a region with + "extend" could be truncated at the end of the containing region. +Solution: Do not call syn_update_ends() when there are no keepend items. +Files: src/syntax.c + +Patch 7.1.219 (after 7.1.215) +Problem: synstack() returns situation after the current character, can't + see the state for a one-character region. +Solution: Don't update ending states in the requested column. +Files: runtime/doc/eval.txt, src/eval.c, src/hardcopy.c, + src/proto/syntax.pro, src/screen.c, src/spell.c, src/syntax.c + +Patch 7.1.220 +Problem: When a ")" or word movement command moves the cursor back from the + end of the line it may end up on the trail byte of a multi-byte + character. It's also moved back when it isn't needed. +Solution: Add the adjust_cursor() function. +Files: src/normal.c + +Patch 7.1.221 +Problem: When inserting a "(", triggering the matchparen plugin, the + following highlighting may be messed up. +Solution: Before triggering the CursorMovedI autocommands update the display + to update the stored syntax stacks for the change. +Files: src/edit.c + +Patch 7.1.222 (after 7.1.217) +Problem: Wildcards in argument of ":helptags" are not expanded. (Marcel + Svitalsky) +Solution: Expand wildcards in the directory name. +Files: src/ex_cmds.c + +Patch 7.1.223 +Problem: glob() doesn't work properly when 'shell' is "sh" or "bash" and + the expanded name contains spaces, '~', single quotes and other + special characters. (Adri Verhoef, Charles Campbell) +Solution: For Posix shells define a vimglob() function to list the matches + instead of using "echo" directly. +Files: src/os_unix.c + +Patch 7.1.224 +Problem: When using "vim -F -o file1 file2" only one window is + right-to-left. Same for "-H". (Ben Schmidt) +Solution: use set_option_value() to set 'rightleft'. +Files: src/main.c + +Patch 7.1.225 +Problem: Using uninitialized value when XGetWMNormalHints() fails. +Solution: Check the return value. (Dominique Pelle) +Files: src/os_unix.c + +Patch 7.1.226 +Problem: Command line completion doesn't work when a file name contains a + '&' character. +Solution: Accept all characters in a file name, except ones that end a + command or white space. +Files: src/ex_docmd.c + +Patch 7.1.227 +Problem: Hang in syntax HL when moving over a ")". (Dominique Pelle) +Solution: Avoid storing a syntax state in the wrong position in the list of + remembered states. +Files: src/syntax.c + +Patch 7.1.228 +Problem: When 'foldmethod' is "indent" and a fold is created with ">>" it + can't be closed with "zc". (Daniel Shahaf) +Solution: Reset the "small" flag of a fold when adding a line to it. +Files: src/fold.c + +Patch 7.1.229 +Problem: A fold is closed when it shouldn't when 'foldmethod' is "indent" + and backspacing a non-white character so that the indent increases. +Solution: Keep the fold open after backspacing a character. +Files: src/edit.c + +Patch 7.1.230 +Problem: Memory leak when executing SourceCmd autocommands. +Solution: Free the memory. (Dominique Pelle) +Files: src/ex_cmds2.c + +Patch 7.1.231 +Problem: When shifting lines the change is acted upon multiple times. +Solution: Don't have shift_line() call changed_bytes. +Files: src/edit.c, src/ops.c, src/proto/edit.pro, src/proto/ops.pro + +Patch 7.1.232 (after 7.1.207 and 7.1.211) +Problem: Compiler warnings with MSVC. +Solution: Add type casts. (Mike Williams) +Files: src/ex_cmds2.c, src/netbeans.c + +Patch 7.1.233 +Problem: Crash when doing Insert mode completion for a user defined + command. (Yegappan Lakshmanan) +Solution: Don't use the non-existing command line. +Files: src/ex_getln.c + +Patch 7.1.234 +Problem: When diff'ing three files the third one isn't displayed correctly. + (Gary Johnson) +Solution: Compute the size of diff blocks correctly when merging blocks. + Compute filler lines correctly when scrolling. +Files: src/diff.c + +Patch 7.1.235 +Problem: Pattern matching is slow when using a lot of simple patterns. +Solution: Avoid allocating memory by not freeing it when it's not so much. + (Alexei Alexandrov) +Files: src/regexp.c + +Patch 7.1.236 +Problem: When using 'incsearch' and 'hlsearch' a complicated pattern may + make Vim hang until CTRL-C is pressed. +Solution: Add the 'redrawtime' option. +Files: runtime/doc/options.txt, src/ex_cmds.c, src/ex_docmd.c, + src/ex_getln.c, src/gui.c, src/misc1.c, src/normal.c, + src/option.c, src/quickfix.c, src/regexp.c, src/proto/regexp.pro, + src/proto/search.pro, src/search.c, src/screen.c, + src/option.h, src/spell.c, src/structs.h, src/syntax.c, src/tag.c, + src/vim.h + +Patch 7.1.237 +Problem: Compiler warning on an Alpha processor in Motif code. +Solution: Change a typecast. (Adri Verhoef) +Files: src/gui_motif.c + +Patch 7.1.238 +Problem: Using the 'c' flag with searchpair() may cause it to fail. Using + the 'r' flag doesn't work when 'wrapscan' is set. (A.Politz) +Solution: Only use the 'c' flag for the first search, not for repeating. + When using 'r' imply 'W'. (Antony Scriven) +Files: src/eval.c + +Patch 7.1.239 (after 7.1.233) +Problem: Compiler warning for sprintf() argument. +Solution: Add a typecast. (Nico Weber) +Files: src/ex_getln.c + +Patch 7.1.240 +Problem: When "gUe" turns a German sharp s into SS the operation stops + before the end of the word. Latin2 has the same sharp s but it's + not changed to SS there. +Solution: Make sure all the characters are operated upon. Detect the sharp + s in latin2. Also fixes that changing case of a multi-byte + character that changes the byte count doesn't always work. +Files: src/ops.c + +Patch 7.1.241 +Problem: Focus change events not always ignored. (Erik Falor) +Solution: Ignore K_IGNORE in Insert mode in a few more places. +Files: src/edit.c + +Patch 7.1.242 (after 7.1.005) +Problem: "cib" doesn't work properly on "(x)". (Tim Pope) +Solution: Use ltoreq() instead of lt(). Also fix "ciT" on "<a>x</a>". +Files: src/search.c + +Patch 7.1.243 (after 7.1.240) +Problem: "U" doesn't work on all text in Visual mode. (Adri Verhoef) +Solution: Loop over all the lines to be changed. Add tests for this. +Files: src/ops.c, src/testdir/test39.in, src/testdir/test39.ok + +Patch 7.1.244 +Problem: GUI may have part of the command line cut off. +Solution: Don't round the number of lines up, always round down. + (Tony Houghton, Scott Dillard) +Files: src/gui.c + +Patch 7.1.245 +Problem: Pressing CTRL-\ three times causes Vim to quit. (Ranganath Rao). + Also for f CTRL-\ CTRL-\. +Solution: When going to cooked mode in mch_delay() set a flag to ignore + SIGQUIT. +Files: src/os_unix.c + +Patch 7.1.246 +Problem: Configure hangs when the man pager is something strange. (lorien) +Solution: Set MANPAGER and PAGER to "cat". (Micah Cowan) +Files: src/auto/configure, src/configure.in + +Patch 7.1.247 +Problem: When using Netbeans backspacing in Insert mode skips a character + now and then. (Ankit Jain) +Solution: Avoid calling netbeans_removed(), it frees the line pointer. + (partly by Dominique Pelle). +Files: src/misc1.c + +Patch 7.1.248 +Problem: Can't set the '" mark. Can't know if setpos() was successful. +Solution: Allow setting the '" mark with setpos(). Have setpos() return a + value indicating success/failure. +Files: runtime/doc/eval.txt, src/eval.c, src/mark.c + +Patch 7.1.249 +Problem: After "U" the cursor can be past end of line. (Adri Verhoef) +Solution: Adjust the cursor position in u_undoline(). +Files: src/undo.c + +Patch 7.1.250 +Problem: ":setglobal fenc=anything" gives an error message in a buffer + where 'modifiable' is off. (Ben Schmidt) +Solution: Don't give an error if 'modifiable' doesn't matter. +Files: src/option.c + +Patch 7.1.251 +Problem: Using freed memory when spell checking enabled. +Solution: Obtain the current line again after calling spell_move_to(). + (Dominique Pelle) +Files: src/screen.c + +Patch 7.1.252 (after 7.1.243) +Problem: Test 39 fails when the environment has a utf-8 locale. (Dominique + Pelle) +Solution: Force 'encoding' to be latin1. +Files: src/testdir/test39.in + +Patch 7.1.253 +Problem: ":sort" doesn't work in a one line file. (Patrick Texier) +Solution: Don't sort if there is only one line. (Dominique Pelle) +Files: src/ex_cmds.c + +Patch 7.1.254 +Problem: Tests 49 and 55 fail when the locale is French. +Solution: Using C messages for test 49. Filter the error message in test 55 + such that it works when the number is halfway the message. +Files: src/testdir/test49.in, src/testdir/test55.in + +Patch 7.1.255 +Problem: Vim doesn't support utf-32. (Yongwei Wu) +Solution: Add aliases for utf-32, it's the same as ucs-4. +Files: src/mbyte.c + +Patch 7.1.256 +Problem: findfile() also returns directories. +Solution: Cleanup the code for finding files and directories in a list of + directories. Remove the ugly global ff_search_ctx. +Files: src/eval.c, src/misc2.c, src/vim.h, src/tag.c + +Patch 7.1.257 +Problem: Configure can't always find the Tcl header files. +Solution: Also look in /usr/local/include/tcl$tclver and + /usr/include/tcl$tclver (James Vega) +Files: src/auto/configure, src/configure.in + +Patch 7.1.258 +Problem: Crash when doing "d/\n/e" and 'virtualedit' is "all". (Andy Wokula) +Solution: Avoid that the column becomes negative. Also fixes other problems + with the end of a pattern match is in column zero. (A.Politz) +Files: src/search.c + +Patch 7.1.259 +Problem: Cursor is in the wrong position when 'rightleft' is set, + 'encoding' is "utf-8" and on an illegal byte. (Dominique Pelle) +Solution: Only put the cursor in the first column when actually on a + double-wide character. (Yukihiro Nakadaira) +Files: src/screen.c + +Patch 7.1.260 +Problem: Cursor positioning problem after ^@ wrapping halfway when + 'encoding' is utf-8. +Solution: Only count a position for printable characters. (partly by + Yukihiro Nakadaira) +Files: src/charset.c + +Patch 7.1.261 +Problem: When a 2 byte BOM is detected Vim uses UCS-2, which doesn't work + for UTF-16 text. (Tony Mechelynck) +Solution: Default to UTF-16. +Files: src/fileio.c, src/testdir/test42.ok + +Patch 7.1.262 +Problem: Can't get the process ID of Vim. +Solution: Implement getpid(). +Files: src/eval.c, runtime/doc/eval.txt + +Patch 7.1.263 +Problem: The filetype can consist of two dot separated names. This works + for syntax and ftplugin, but not for indent. (Brett Stahlman) +Solution: Use split() and loop over each dot separated name. +Files: runtime/indent.vim + +Patch 7.1.264 +Problem: Crash when indenting lines. (Dominique Pelle) +Solution: Set the cursor column when changing the cursor line. +Files: src/ops.c, src/misc1.c + +Patch 7.1.265 +Problem: When 'isfname' contains a space, cmdline completion can hang. + (James Vega) +Solution: Reset the "len" variable. +Files: src/ex_docmd.c + +Patch 7.1.266 +Problem: When the version string returned by the terminal contains + unexpected characters, it is used as typed input. (James Vega) +Solution: Assume the escape sequence ends in a letter. +Files: src/term.c + +Patch 7.1.267 +Problem: When changing folds cursor may be positioned in the wrong place. +Solution: Call changed_window_setting_win() instead of + changed_window_setting(). +Files: src/fold.c + +Patch 7.1.268 +Problem: Always shows "+" at end of screen line with: ":set + listchars=eol:$,extends:+ nowrap list cursorline" (Gary Johnson) +Solution: Check for lcs_eol_one instead of lcs_eol. +Files: src/screen.c + +Patch 7.1.269 +Problem: The matchparen plugin has an arbitrary limit for the number of + lines to look for a match. +Solution: Rely on the searchpair() timeout. +Files: runtime/plugin/matchparen.vim + +Patch 7.1.270 +Problem: ":?foo?" matches in current line since patch 7.1.025. (A.Politz) +Solution: Remove the SEARCH_START flag. +Files: src/ex_docmd.c, src/search.c + +Patch 7.1.271 +Problem: In a Vim build without autocommands, checking a file that was + changed externally causes the current buffer to be changed + unexpectedly. (Karsten Hopp) +Solution: Store "curbuf" instead of "buf". +Files: src/fileio.c + +Patch 7.1.272 +Problem: The special buffer name [Location List] is not used for a buffer + displayed in another tab page. +Solution: Use FOR_ALL_TAB_WINDOWS instead of FOR_ALL_WINDOWS. (Hiroaki + Nishihara) +Files: src/buffer.c + +Patch 7.1.273 +Problem: When profiling on Linux Vim exits early. (Liu Yubao) +Solution: When profiling don't exit on SIGPROF. +Files: src/Makefile, src/os_unix.c + +Patch 7.1.274 (after 7.1.272) +Problem: Compiler warning for optimized build. +Solution: Init win to NULL. +Files: src/buffer.c + +Patch 7.1.275 (extra) +Problem: Mac: ATSUI and 'antialias' don't work properly together. +Solution: Fix this and the input method. (Jjgod Jiang) +Files: src/vim.h, src/gui_mac.c + +Patch 7.1.276 +Problem: "gw" uses 'formatexpr', even though the docs say it doesn't. +Solution: Don't use 'formatexpr' for "gw". +Files: src/vim.h, src/edit.c, src/ops.c, src/proto/ops.pro + +Patch 7.1.277 +Problem: Default for 'paragraphs' misses some items (Colin Watson) +Solution: Add TP, HP, Pp, Lp and It to 'paragraphs'. (James Vega) +Files: runtime/doc/options.txt, src/option.c + +Patch 7.1.278 (extra, after 7.1.275) +Problem: Build failure when USE_CARBONKEYHANDLER is not defined. +Solution: Remove #ifdef. +Files: src/gui_mac.c + +Patch 7.1.279 +Problem: When using cscope temporary files are left behind. +Solution: Send the quit command to cscope and give it two seconds to exit + nicely before killing it. (partly by Dominique Pelle) +Files: src/if_cscope.c + +Patch 7.1.280 (after 7.1.275) +Problem: Mac: build problems when not using multibyte feature. (Nicholas + Stallard) +Solution: Don't define USE_IM_CONTROL when not using multibyte. +Files: src/vim.h + +Patch 7.1.281 (after 7.1.279) +Problem: sa.sa_mask is not initialized. Cscope may not exit. +Solution: Use sigemptyset(). Use SIGKILL instead of SIGTERM. (Dominique + Pelle) +Files: src/if_cscope.c + +Patch 7.1.282 (extra) +Problem: Win64: Edit with Vim context menu isn't installed correctly. + Compiler warnings and a few other things. +Solution: Add [ and ] to entry of class name. Use UINT_PTR instead of UINT. + And a fixes for the other things. (George V. Reilly) +Files: src/GvimExt/Makefile, src/dosinst.c, src/if_ole.cpp, src/if_ole.h, + src/if_ole.idl, src/INSTALLpc.txt, src/Make_mvc.mak, + src/os_win32.c, + +Patch 7.1.283 +Problem: Non-extra part for 7.1.282. +Solution: Various changes. +Files: src/ex_docmd.c, src/globals.h, src/if_cscope.c, src/main.c, + src/mark.c, src/netbeans.c, src/popupmnu.c, src/vim.h, + src/window.c + +Patch 7.1.284 +Problem: Compiler warnings for functions without prototype. +Solution: Add the function prototypes. (Patrick Texier) +Files: src/eval.c, src/quickfix.c + +Patch 7.1.285 (extra) +Problem: Mac: dialog hotkeys don't work. +Solution: Add hotkey support. (Dan Sandler) +Files: src/gui_mac.c + +Patch 7.1.286 (after 7.1.103) +Problem: "w" at the end of the buffer moves the cursor past the end of the + line. (Markus Heidelberg) +Solution: Move the cursor back from the NUL when it was moved forward. +Files: src/normal.c + +Patch 7.1.287 +Problem: Crash when reversing a list after using it. (Andy Wokula) +Solution: Update the pointer to the last used element. (Dominique Pelle) +Files: src/eval.c + +Patch 7.1.288 (after 7.1.281) +Problem: Cscope still leaves behind temp files when using gvim. +Solution: When getting the ECHILD error loop for a while until cscope exits. + (Dominique Pelle) +Files: if_cscope.c + +Patch 7.1.289 +Problem: When EXITFREE is defined and 'acd' is set freed memory is used. + (Dominique Pelle) +Solution: Reset p_acd before freeing all buffers. +Files: src/misc2.c + +Patch 7.1.290 +Problem: Reading bytes that were not written when spell checking and a line + has a very large indent. +Solution: Don't copy the start of the next line when it only contains + spaces. (Dominique Pelle) +Files: src/spell.c + +Patch 7.1.291 (after 7.1.288) +Problem: Compiler warning. +Solution: Change 50 to 50L. +Files: src/if_cscope.c + +Patch 7.1.292 +Problem: When using a pattern with "\@<=" the submatches can be wrong. + (Brett Stahlman) +Solution: Save the submatches when attempting a look-behind match. +Files: src/regexp.c + +Patch 7.1.293 +Problem: Spell checking considers super- and subscript characters as word + characters. +Solution: Recognize the Unicode super and subscript characters. +Files: src/spell.c + +Patch 7.1.294 +Problem: Leaking memory when executing a shell command. +Solution: Free memory when not able to save for undo. (Dominique Pelle) +Files: src/ex_cmds.c + +Patch 7.1.295 +Problem: Vimtutor only works with vim, not gvim. +Solution: Add the -g flag to vimtutor. (Dominique Pelle) Add gvimtutor. +Files: src/Makefile, src/gvimtutor, src/vimtutor, runtime/doc/vimtutor.1 + +Patch 7.1.296 +Problem: SELinux is not supported. +Solution: Detect the selinux library and use mch_copy_sec(). (James Vega) +Files: src/auto/configure, src/config.h.in, src/configure.in, + src/fileio.c, src/memfile.c, src/os_unix.c, src/proto/os_unix.pro + +Patch 7.1.297 +Problem: When using the search/replace dialog the parenmatch highlighting + can be wrong. (Tim Duncan) +Solution: In the GUI redraw function invoke the CursorMoved autocmd. +Files: src/gui.c + +Patch 7.1.298 (after 7.1.295) +Problem: src/gvimtutor is not distributed. +Solution: Add it to the list of distributed files. +Files: Filelist + +Patch 7.1.299 +Problem: Filetype detection doesn't work properly for file names ending in + a part that is ignored and contain a space or other special + characters. +Solution: Escape the special characters using the new fnameescape function. +Files: runtime/doc/eval.txt, runtime/filetype.vim, src/eval.c, + src/ex_getln.c, src/proto/ex_getln.pro, src/vim.h + +Patch 7.1.300 +Problem: Value of asmsyntax argument isn't checked for valid characters. +Solution: Only accepts letters and digits. +Files: runtime/filetype.vim + +Patch 7.1.301 +Problem: When the "File/Save" menu is used in Insert mode, a tab page label + is not updated to remove the "+". +Solution: Call draw_tabline() from showruler(). (Bjorn Winckler) +Files: src/screen.c + +Patch 7.1.302 (after 7.1.299) +Problem: Compilation error on MS-Windows. +Solution: Don't use xp_shell when it's not defined. +Files: src/ex_getln.c + +Patch 7.1.303 (after 7.1.302) +Problem: Compilation error on MS-Windows, again. +Solution: Declare p. +Files: src/ex_getln.c + +Patch 7.1.304 +Problem: Shortpath_for_invalid_fname() does not work correctly and is + unnecessary complex. +Solution: Clean up shortpath_for_invalid_fname(). (mostly by Yegappan + Lakshmanan) +Files: src/eval.c + +Patch 7.1.305 +Problem: Editing a compressed file with special characters in the name + doesn't work properly. +Solution: Escape special characters. +Files: runtime/autoload/gzip.vim + +Patch 7.1.306 +Problem: Some Unicode characters are handled like word characters while + they are symbols. +Solution: Adjust the table for Unicode classification. +Files: src/mbyte.c + +Patch 7.1.307 +Problem: Many warnings when compiling with Python 2.5. +Solution: Use ssize_t instead of int for some types. (James Vega) +Files: src/if_python.c + +Patch 7.1.308 +Problem: When in readonly mode ":options" produces an error. +Solution: Reset 'readonly'. (Gary Johnson) +Files: runtime/optwin.vim + +Patch 7.1.309 +Problem: Installing and testing with a shadow directory doesn't work. + (James Vega) +Solution: Add "po" to the list of directories to link. Also link the Vim + scripts in testdir. And a few more small fixes. +Files: src/Makefile + +Patch 7.1.310 +Problem: Incomplete utf-8 byte sequence at end of the file is not detected. + Accessing memory that wasn't written. +Solution: Check the last bytes in the buffer for being a valid utf-8 + character. (mostly by Ben Schmidt) + Also fix that the reported line number of the error was wrong. +Files: src/fileio.c + +Patch 7.1.311 +Problem: Compiler warning for missing sentinel in X code. +Solution: Change 0 to NULL. (Markus Heidelberg) +Files: src/mbyte.c + +Patch 7.1.312 +Problem: The .po files have mistakes in error numbers. +Solution: Search for these mistakes in the check script. (Dominique Pelle) +Files: src/po/check.vim + +Patch 7.1.313 +Problem: When the netbeans interface setModified call is used the status + lines and window title are not updated. +Solution: Redraw the status lines and title. (Philippe Fremy) +Files: src/netbeans.c + +Patch 7.1.314 +Problem: The value of 'pastetoggle' is written to the session file without + any escaping. (Randall Hansen) +Solution: Use put_escstr(). (Ben Schmidt) +Files: src/option.c + +Patch 7.1.315 +Problem: Crash with specific search pattern using look-behind match. + (Andreas Politz) +Solution: Also save the value of "need_clear_subexpr". +Files: src/regexp.c + +Patch 7.1.316 +Problem: When 'cscopetag' is set ":tag" gives an error message instead of + going to the next tag in the tag stack. +Solution: Don't call do_cstag() when there is no argument. (Mark Goldman) +Files: src/ex_docmd.c + +Patch 7.1.317 +Problem: Compiler warnings in Motif calls. +Solution: Change zero to NULL. (Dominique Pelle) +Files: src/gui_motif.c + +Patch 7.1.318 +Problem: Memory leak when closing xsmp connection. Crash on exit when + using Lesstif. +Solution: Don't close the X display to work around a Lesstif bug. Free + clientid. Also fix a leak for Motif and Athena. (Dominique Pelle) +Files: src/gui_x11.c, src/os_unix.c + +Patch 7.1.319 +Problem: When a register has an illegal utf-8 sequence, pasting it on the + command line causes an illegal memory access. +Solution: Use mb_cptr2char_adv(). (Dominique Pelle) +Files: src/ex_getln.c + +Patch 7.1.320 (extra) +Problem: Win64: Warnings while compiling Python interface. +Solution: Use PyInt in more places. Also update version message for the + console. (George Reilly) +Files: src/if_python.c, src/version.c + +Patch 7.1.321 (extra) +Problem: Win32 / Win64: Install file is outdated. +Solution: Update the text for recent compiler. (George Reilly) +Files: src/INSTALLpc.txt + +Patch 7.1.322 +Problem: Can't get start of Visual area in an <expr> mapping. +Solution: Add the 'v' argument to getpos(). +Files: runtime/doc/eval.txt, src/eval.c + +Patch 7.1.323 +Problem: Test 19 fails with some termcaps. (Dominique Pelle) +Solution: Set the t_kb and t_kD termcap values. +Files: src/testdir/test19.in, src/testdir/test38.in + +Patch 7.1.324 +Problem: File name path length on Unix is limited to 1024. +Solution: Use PATH_MAX when it's more than 1000. +Files: src/os_unix.h + +Patch 7.1.325 +Problem: When editing a command line that's longer than available space in + the window, the characters at the end are in reverse order. +Solution: Increment the insert position even when the command line doesn't + fit. (Ingo Karkat) +Files: src/ex_getln.c + +Patch 7.1.326 +Problem: ":s!from!to!" works, but ":smagic!from!to!" doesn't. It sees the + "!" as a flag to the command. Same for ":snomagic". (Johan Spetz) +Solution: When checking for a forced command also ignore ":smagic" and + ":snomagic". (Ian Kelling) +Files: src/ex_docmd.c + +Patch 7.1.327 +Problem: The GUI tutor is installed when there is no GUI version. +Solution: Only install gvimtutor when building a GUI version. +Files: src/Makefile + +Patch 7.1.328 +Problem: Crash when using Cygwin and non-posix path name in tags file. +Solution: Use separate buffer for posix path. (Ben Schmidt) +Files: src/os_unix.c + +Patch 7.1.329 +Problem: When the popup menu is removed a column of cells, the right halve + of double-wide characters, may not be redrawn. +Solution: Check if the right halve of a character needs to be redrawn. + (Yukihiro Nakadaira) +Files: src/screen.c + +Patch 7.1.330 +Problem: Reading uninitialized memory when using Del in replace mode. +Solution: Use utfc_ptr2len_len() instead of mb_ptr2len(). (Dominique Pelle) +Files: src/misc1.c + + +Warning for missing sentinel in gui_xmldlg.c. (Dominique Pelle) + +A search offset from the end of a match didn't work properly for multi-byte +characters. (Yukihiro Nakadaira) + +When displaying the value of 'key' don't show "*****" when the value is empty. +(Ben Schmidt) + +Internal error when compiled with EXITFREE and using the nerd_tree plugin. +Set last_msg_hist to NULL when history becomes empty. Call +free_all_functions() after garbage collection. (Dominique Pelle) + +GTK with XIM: <S-Space> does not work. (Yukihiro Nakadaira) + +Some shells do not support "echo -n", which breaks glob(). Use "echo" instead +of "echo -n $1; echo". (Gary Johnson) + +"echo 22,44" printed "22" on top of the command, the error messages caused +the rest not to be cleared. Added the need_clr_eos flag. + +Netbeans events are handled while updating the screen, causing a crash. +Change the moment when events are handled. Rename nb_parse_messages() to +netbeans_parse_messages(). (Xavier de Gaye) + +Test 11 was broken after patch 7.1.186 on Win32 console. (Daniel Shahaf) +Use shellescape() on the file name. + +IM was turned off in im_preedit_end_cb() for no good reason. (Takuhiro +Nishioka) + +A corrupted spell file could cause Vim to use lots of memory. Better +detection for running into the end of the file. (idea from James Vega) + +Mac: Included a patch to make it build with GTK. Moved language init to +mac_lang_init() function. (Ben Schmidt) + +Problem with 'wildmenu' after ":lcd", up/down arrows don't work. (Erik Falor) + +Fix configure.in to avoid "implicitly declared" warnings when running +configure. + +Fixed a memory leak when redefining a keymap. (Dominique Pelle) + +Setting 'pastetoggle' to "jj" didn't work. + +'ic' and 'smartcase' don't work properly when using \%V in a search pattern. +(Kana Natsuno) + +Patch 7.2a.001 +Problem: On some systems X11/Xlib.h exists (from X11-dev package) but + X11/Intrinsic.h does not (in Xt-dev package). This breaks the + build. Also, on Solaris 9 sys/ptem.h isn't found. +Solution: Have configure only accept X11 when X11/Intrinsic.h exists. + Check for sys/ptem.h while including sys/stream.h. (Vladimir + Marek) +Files: src/auto/configure, src/configure.in + +Patch 7.2a.002 +Problem: getbufvar(N, "") gets the dictionary of the current buffer instead + of buffer N. +Solution: Set curbuf before calling find_var_in_ht(). (Kana Natsuno) +Files: src/eval.c + +Patch 7.2a.003 +Problem: Leaking memory when using ":file name" and using access control + lists. +Solution: Invoke mch_free_acl() in vim_rename(). (Dominique Pelle) +Files: src/fileio.c + +Patch 7.2a.004 +Problem: Some systems can't get spell files by ftp. +Solution: Use http when it looks like it's possible. (James Vega) +Files: runtime/autoload/spellfile.vim + +Patch 7.2a.005 +Problem: A few error messages use confusing names. Misspelling. +Solution: Change "dissallows" to "disallows". (Dominique Pelle) Change + "number" to "Number". +Files: src/eval.c, src/fileio.c + +Patch 7.2a.006 +Problem: Reading past NUL in a string. +Solution: Check for invalid utf-8 byte sequence. (Dominique Pelle) +Files: src/charset.c + +Patch 7.2a.007 +Problem: ":let v = 1.2.3" was OK in Vim 7.1, now it gives an error. +Solution: Don't look for a floating point number after the "." operator. +Files: src/eval.c + +Patch 7.2a.008 +Problem: printf("%g", 1) doesn't work. +Solution: Convert Number to Float when needed. +Files: src/message.c + +Patch 7.2a.009 +Problem: cygwin_conv_to_posix_path() does not specify buffer size. +Solution: Use new Cygwin function: cygwin_conv_path(). (Corinna Vinschen) +Files: src/main.c, src/os_unix.c + +Patch 7.2a.010 +Problem: When a file name has an illegal byte sequence Vim may read + uninitialised memory. +Solution: Don't use UTF_COMPOSINGLIKE() on an illegal byte. In + msg_outtrans_len_attr() use char2cells() instead of ptr2cells(). + In utf_ptr2char() don't check second byte when first byte is + illegal. (Dominique Pelle) +Files: src/mbyte.c, src/message.c + +Patch 7.2a.011 +Problem: The Edit/Startup Settings menu doesn't work. +Solution: Expand environment variables. (Ben Schmidt) +Files: runtime/menu.vim + +Patch 7.2a.012 +Problem: Compiler warnings for casting int to pointer. +Solution: Add cast to long in between. (Martin Toft) +Files: src/gui_gtk_x11.c + +Patch 7.2a.013 +Problem: shellescape() does not escape "%" and "#" characters. +Solution: Add find_cmdline_var() and use it when the second argument to + shellescape() is non-zero. +Files: runtime/doc/eval.txt, src/eval.c, src/ex_docmd.c, + src/proto/ex_docmd.pro, src/proto/misc2.pro, src/misc2.c + +Patch 7.2a.014 +Problem: Problem with % in message. +Solution: Put % in single quotes. +Files: src/eval.c + +Patch 7.2a.015 (after 7.2a.010) +Problem: Misaligned messages. +Solution: Compute length of unprintable chars correctly. +Files: src/message.c + +Patch 7.2a.016 +Problem: Using CTRL-W v in the quickfix window results in two quickfix + windows, which is not allowed. ":tab split" should be allowed to + open a new quickfix window in another tab. +Solution: For CTRL-W v instead of splitting the window open a new one. + When using ":tab" do allow splitting the quickfix window (was + already included in patch 7.2a.013). +Files: src/window.c + +Patch 7.2a.017 +Problem: ":doautoall" executes autocommands for all buffers instead of just + for loaded buffers. +Solution: Change "curbuf" to "buf". +Files: src/fileio.c + +Patch 7.2a.018 +Problem: Compiler warnings when compiling with Gnome. (Tony Mechelynck) +Solution: Add type casts. +Files: src/gui_gtk_x11.c + +Patch 7.2a.019 +Problem: ":let &g:tw = 44" sets the local option value. (Cyril Slobin) +Solution: Use get_varp_scope() instead of get_varp(). (Ian Kelling) +Files: src/option.c + +There is no way to avoid adding /usr/local/{include|lib} to the build +commands. Add the --with-local-dir argument to configure. (Michael +Haubenwallner) + +When using CTRL-D after ":help", the number of matches could be thousands. +Restrict to TAG_MANY to avoid this taking too long. (Ian Kelling) + +The popup menu could be placed at a weird location. Caused by w_wcol computed +by curs_columns(). (Dominique Pelle) + +Overlapping STRCPY() arguments when using %r item in 'errorformat'. Use +STRMOVE() instead. (Ralf Wildenhues) + +Mac: On Leopard gvim, when using the mouse wheel nothing would happen until +another event occurs, such as moving the mouse. Then the recorded scrolling +would take place all at once. (Eckehard Berns) + +Solution for cursor color not reflecting IM status for GTK 2. Add +preedit_is_active flag. (SungHyun Nam) + +filereadable() can hang on a FIFO on Linux. Use open() instead of fopen(), +with O_NONBLOCK. (suggested by Lars Kotthoff) + +Included patch to support Perl 5.10. (Yasuhiro Matsumoto) + +When files are dropped on gvim while the screen is being updated, ignore the +drop command to avoid freeing memory that is being used. + +In a terminal, when drawing the popup menu over double-wide characters, half +characters may not be cleared properly. (Yukihiro Nakadaira) + +The #ifdef for including "vimio.h" was inconsistent. In a few files it +depended on MSWIN, which isn't defined until later. + +Patch 7.2b.001 +Problem: Compilation problem: mb_fix_col() missing with multi-byte feature + but without GUI or clipboard. +Solution: Remove #ifdef. +Files: src/mbyte.c + +Patch 7.2b.002 +Problem: Compiler warnings for signed/unsigned mismatch. +Solution: Add type casts. +Files: src/screen.c + +Patch 7.2b.003 +Problem: Still a compilation problem, check_col() and check_row() missing. +Solution: Add FEAT_MBYTE to the #if. +Files: src/ui.c + +Patch 7.2b.004 +Problem: Trying to free memory for a static string when using ":helpgrep". + (George Reilly) +Solution: Set 'cpo' to empty_option instead of an empty string. Also for + searchpair() and substitute(). +Files: src/quickfix.c, src/eval.c + +Patch 7.2b.005 +Problem: The special character "!" isn't handled properly in shellescape(). + (Jan Minar) +Solution: Escape "!" when using a "csh" like shell and with + shellescape(s, 1). Twice for both. Also escape <NL>. +Files: src/misc2.c + +Patch 7.2b.006 +Problem: Reading past end of string when reading info from tags line. +Solution: Break the loop when encountering a NUL. (Dominique Pelle) +Files: src/tag.c + +Patch 7.2b.007 +Problem: Part of a message cannot be translated. +Solution: Put _() around the message. +Files: src/search.c + +Patch 7.2b.008 +Problem: A few filetypes are not detected or not detected properly. +Solution: Add filetype detection patterns. (Nikolai Weibull) +Files: runtime/filetype.vim + +Patch 7.2b.009 +Problem: Reading past end of screen line. (Epicurus) +Solution: Avoid going past the value of Columns. +Files: src/screen.c + +Patch 7.2b.010 +Problem: ":mksession" doesn't work for ":map , foo", ":sunmap ,". (Ethan + Mallove) +Solution: Check for "nxo", "nso" and other strange mapping combinations. +Files: src/getchar.c + +Patch 7.2b.011 +Problem: Configure for TCL ends up with include file in compiler command. + (Richard Hogg) +Solution: Delete items from $TCL_DEFS that do not start with a dash. +Files: src/auto/configure, src/configure.in + +Patch 7.2b.012 +Problem: Build failure with +multi_byte but without +diff. +Solution: Add #ifdef. (Patrick Texier) +Files: src/main.c + +Patch 7.2b.013 +Problem: Build fails with tiny features and Perl. (Dominique Pelle) +Solution: Define missing functions. Also when compiling Python. +Files: src/if_perl.xs, src/if_python.c + +Patch 7.2b.014 +Problem: Configure uses an unsafe temp file to store commands. +Solution: Create the temp file in local directory. +Files: src/auto/configure, src/configure.in + +Patch 7.2b.015 +Problem: Build fails on Mac when using Aap. +Solution: Fix typo in configure script. +Files: src/auto/configure, src/configure.in + +Patch 7.2b.016 +Problem: Build fails with normal features but without +autocmd. +Solution: Fix #ifdefs. (Ian Kelling) +Files: src/eval.c, src/ex_cmds.c, src/quickfix.c, src/option.c, + src/ex_docmd.c + +Patch 7.2b.017 +Problem: "vim -O foo foo" results in only one window. (Zdenek Sekera) +Solution: Handle result of ATTENTION prompt properly. (Ian Kelling) +Files: src/main.c + +Patch 7.2b.018 +Problem: When doing command line completion on a file name for a csh-like + shell argument a '!' character isn't escaped properly. +Solution: Add another backslash. +Files: src/ex_getln.c, src/misc2.c, src/proto/misc2.pro, src/screen.c + +Patch 7.2b.019 (extra) +Problem: Win32: Various compiler warnings. +Solution: Use __w64 attribute. Comment-out unused parameters. Adjust a few + #ifdefs. (George Reilly) +Files: src/gui_w48.c, src/GvimExt/gvimext.cpp, src/Make_mvc.mak, + src/os_mswin.c, src/os_win32.c, src/vim.h + +Patch 7.2b.020 +Problem: ":sort n" doesn't handle negative numbers. (James Vega) +Solution: Include '-' in the number. +Files: src/charset.c, src/ex_cmds.c + +Patch 7.2b.021 +Problem: Reloading doesn't read the BOM correctly. (Steve Gardner) +Solution: Accept utf-8 BOM when specified file encoding is utf-8. +Files: src/fileio.c + +Patch 7.2b.022 +Problem: When using ":normal" while updating the status line the count of + an operator is lost. (Dominique Pelle) +Solution: Save and restore "opcount". +Files: src/ex_docmd.c, src/globals.h, src/normal.c + +Patch 7.2b.023 +Problem: Crash when using the result of synstack(0,0). (Matt Wozniski) +Solution: Check for v_list to be NULL in a few more places. +Files: src/eval.c + +Patch 7.2b.024 +Problem: Using ":gui" while the netrw plugin is active causes a delay in + updating the display. +Solution: Don't check for terminal codes when starting the GUI. +Files: src/term.c + +Patch 7.2b.025 +Problem: When the CursorHold event triggers a pending count is lost. + (Juergen Kraemer) +Solution: Save the counts and restore them. +Files: src/normal.c, src/structs.h + +Patch 7.2b.026 +Problem: The GTK 2 file chooser causes the ~/.recently-used.xbel file to be + written over and over again. This may cause a significant + slowdown. (Guido Berhoerster) +Solution: Don't use the GTK 2 file chooser. +Files: src/gui_gtk.c + +Patch 7.2b.027 +Problem: Memory leak for Python, Perl, etc. script command with end marker. +Solution: Free the memory of the end marker. (Andy Kittner) +Files: src/ex_getln.c + +Patch 7.2b.028 +Problem: Reading uninitialized memory when doing ":gui -f". (Dominique + Pelle) +Solution: Don't position the cursor when the screen size is invalid. +Files: src/gui.c + +Patch 7.2b.029 +Problem: ":help a" doesn't jump to "a" tag in docs. (Tony Mechelynck) +Solution: Get all tags and throw away more than TAG_MANY after sorting. + When there is no argument find matches for "help" to avoid a long + delay. +Files: src/ex_cmds.c, src/ex_getln.c + +Patch 7.2b.030 +Problem: When changing the value of t_Co from 8 to 16 the Visual + highlighting keeps both reverse and a background color. +Solution: Remove the attribute when setting the default highlight color. + (Markus Heidelberg) +Files: src/syntax.c + +Error when cancelling completion menu and auto-formatting. (fixed by Ian +Kelling) + +Patch 7.2c.001 +Problem: ":let x=[''] | let x += x" causes hang. (Matt Wozniski) +Solution: Only insert elements up to the original length of the List. +Files: runtime/doc/eval.txt, src/eval.c + +Patch 7.2c.002 +Problem: fnameescape() doesn't handle a leading '+' or '>'. (Jan Minar) +Solution: Escape a leading '+' and '>'. And a single '-'. +Files: runtime/doc/eval.txt, src/ex_getln.c + +Patch 7.2c.003 +Problem: Searching for "foo\%[bar]\+" gives a "Corrupted regexp program" + error. (Joachim Hofmann) +Solution: Mark the \%[] item as not being simple. +Files: src/regexp.c + +On Vista access to system directories is virtualized. (Michael Mutschler) +Adjusted the manifest file to avoid this. (George Reilly) + +Memory leak when using CTRL-C to cancel listing the jump list. (Dominique +Pelle) + +Mac: Could not build with Perl interface. + +============================================================================== +VERSION 7.3 *version-7.3* *version7.3* + +This section is about improvements made between version 7.2 and 7.3. + +This release has hundreds of bug fixes and there are a few new features. The +most notable new features are: + + +Persistent undo *new-persistent-undo* +--------------- + +Store undo information in a file. Can undo to before when the file was read, +also for unloaded buffers. See |undo-persistence| (partly by Jordan Lewis) + +Added the ":earlier 1f" and ":later 1f" commands. +Added file save counter to undo information. +Added the |undotree()| and |undofile()| functions. + +Also added the 'undoreload' option. This makes it possible to save the +current text when reloading the buffer, so that the reload can be undone. + + +More encryption *new-more-encryption* +--------------- + +Support for Blowfish encryption. Added the 'cryptmethod' option. +Mostly by Moshin Ahmed. + +Also encrypt the text in the swap file and the undo file. + + +Conceal text *new-conceal* +------------ + +Added the |+conceal| feature. (Vince Negri) +This allows hiding stretches of text, based on syntax highlighting. +It also allows replacing a stretch of text by a character |:syn-cchar|. +The 'conceallevel' option specifies what happens with text matching a syntax +item that has the conceal attribute. +The 'concealcursor' option specifies what happens in the cursor line. + +The help files conceal characters used to mark tags and examples. + +Added the |synconcealed()| function and use it for :TOhtml. (Benjamin Fritz) + +Added the 'cursorbind' option, keeps the cursor in two windows with the same +text in sync. + + +Lua interface *new-lua* +------------- + +Added the |Lua| interface. (Luis Carvalho) + + +Python3 interface *new-python3* +----------------- + +Added the Python3 interface. It exists next to Python 2.x, both can be used +at the same time. See |python3| (Roland Puntaier) + + +Changed *changed-7.3* +------- + +The MS-Windows installer no longer requires the user to type anything in the +console windows. The installer now also works on 64 bit systems, including +the "Edit with Vim" context menu. +The gvim executable is 32 bits, the installed gvimext.dll is either a 32 or 64 +bit version. (mostly by George Reilly) +Made the DOS installer work with more compilers. +The MS-Windows big gvim is now built with Python 2.7 and 3.1.2, Perl 5.12 and +Ruby 1.9.1. You need the matching .dll files to use them. + +The extra and language files are no longer distributed separately. +The source files for all systems are included in one distribution. + +After using ":recover" or recovering a file in another way, ":x" and "ZZ" +didn't save what you see. This could result in work being lost. Now the text +after recovery is compared to the original file contents. When they differ +the buffer is marked as modified. + +When Vim is exiting because of a deadly signal, when v:dying is 2 or more, +VimLeavePre, VimLeave, BufWinLeave and BufUnload autocommands are not +executed. + +Removed support for GTK 1. It was no longer maintained and required a lot of +#ifdefs in the source code. GTK 2 should be available for every system. +(James Vega) + +It is no longer allowed to set the 'encoding' option from a modeline. It +would corrupt the text. (Patrick Texier) + +Renamed runtime/spell/fixdup to runtime/spell/fixdup.vim. + +Removed obsolete Mac code. + +Updated spell files for Ubuntu locale names. + +Switched from autoconf 2.63 to 2.65. + +Removed Mupad indent and ftplugin files, they are not useful. + +The maximum number of messages remembered in the history is now 200 (was 100). + + +Added *added-7.3* +----- + +Added the 'relativenumber' option. (Markus Heidelberg) + +Added the 'colorcolumn' option: highlight one or more columns in a window. +E.g. to highlight the column after 'textwidth'. (partly by Gregor Uhlenheuer) + +Added support for NetBeans in a terminal. Added |:nbstart| and |:nbclose|. +(Xavier de Gaye) + +More floating point functions: |acos()|, |asin()|, |atan2()|, |cosh()|, +|exp()|, |fmod()|, |log()|, |sinh()|, |tan()|, |tanh()|. (Bill McCarthy) + +Added the |gettabvar()| and |settabvar()| functions. (Yegappan Lakshmanan) + +Added the |strchars()|, |strwidth()| and |strdisplaywidth()| functions. + +Support GDK_SUPER_MASK for GTK on Mac. (Stephan Schulz) + +Made CTRL and ALT modifier work for mouse wheel. (Benjamin Haskell) + +Added support for horizontal scroll wheel. (Bjorn Winckler) + +When the buffer is in diff mode, have :TOhtml create HTML to show the diff +side-by-side. (Christian Brabandt) + +Various improvements to ":TOhtml" and the 2html.vim script. (Benjamin Fritz) + +Add the 'L' item to 'cinoptions'. (Manuel Konig) + +Improve Javascript indenting. Add "J" flag to 'cinoptions'. (Hari Kumar G) + +Mac: Support disabling antialias. (LC Mi) + +Mac: Add clipboard support in the Mac console. (Bjorn Winckler) + +Make it possible to drag a tab page label to another position. (Paul B. Mahol) + +Better implementation of creating the Color Scheme menu. (Juergen Kraemer) + +In Visual mode with 'showcmd' display the number of bytes and characters. + +Allow synIDattr() getting GUI attributes when built without GUI. (Matt +Wozniski) + +Support completion for ":find". Added test 73. (Nazri Ramliy) + +Command line completion for :ownsyntax and :setfiletype. (Dominique Pelle) + +Command line completion for :lmap and :lunmap. + +Support syntax and filetype completion for user commands. (Christian Brabandt) + +Add completion for ":ownsyntax" and improve completion for ":filetype". + +Avoid use of the GTK main_loop() so that the GtkFileChooser can be used. +(James Vega) + +When 'formatexpr' evaluates to non-zero fall back to internal formatting, also +for "gq". (James Vega) + +Support :browse for commands that use an error file argument. (Lech Lorens) + +Support wide file names in gvimext. (Szabolcs Horvat) + +Improve test for joining lines. (Milan Vancura) +Make joining a range of lines much faster. (Milan Vancura) + +Add patch to improve support of z/OS (OS/390). (Ralf Schandl) + +Added the helphelp.txt file. Moved text from various.txt to it. + +Added "q" item for 'statusline'. Added |w:quickfix_title|. (Lech Lorens) + +Various improvements for VMS. (Zoltan Arpadffy) + + +New syntax files: ~ +Haskell Cabal build file (Vincent Berthoux) +ChaiScript (Jason Turner) +Cucumber (Tim Pope) +Datascript (Dominique Pelle) +Fantom (Kamil Toman) +Liquid (Tim Pope) +Markdown (Tim Pope) +wavefront's obj file (Vincent Berthoux) +Perl 6 (Andy Lester) +SDC - Synopsys Design Constraints (Maurizio Tranchero) +SVG - Scalable Vector Graphics (Vincent Berthoux) +task data (John Florian) +task 42 edit (John Florian) + +New filetype plugins: ~ +Cucumber (Tim Pope) +Liquid (Tim Pope) +Logcheck (Debian) +Markdown (Tim Pope) +Perl 6 (Andy Lester) +Quickfix window (Lech Lorens) +Tcl (Robert L Hicks) + +New indent plugins: ~ +CUDA (Bram Moolenaar) +ChaiScript (Jason Turner) +Cucumber (Tim Pope) +LifeLines (Patrick Texier) +Liquid (Tim Pope) +Mail (Bram Moolenaar) +Perl 6 (Andy Lester) + +Other new runtime files: ~ +Breton spell file (Dominique Pelle) +Dvorak keymap (Ashish Shukla) +Korean translations. (SungHyun Nam) +Python 3 completion (Aaron Griffin) +Serbian menu translations (Aleksandar Jelenak) +Tetum spell files +Tutor Bairish (Sepp Hell) +Tutor in Esperanto. (Dominique Pellé) +Tutor in Portuguese. +Norwegian Tutor now also available as tutor.nb + +Removed the Mupad runtime files, they were not maintained. + + +Fixed *fixed-7.3* +----- + +Patch 7.2.001 +Problem: Mac: pseudo-ttys don't work properly on Leopard, resulting in the + shell not to have a prompt, CTRL-C not working, etc. +Solution: Don't use SVR4 compatible ptys, even though they are detected. + (Ben Schmidt) +Files: src/pty.c + +Patch 7.2.002 +Problem: Leaking memory when displaying menus. +Solution: Free allocated memory. (Dominique Pelle) +Files: src/menu.c + +Patch 7.2.003 +Problem: Typo in translated message. Message not translated. +Solution: Correct spelling. Add _(). (Dominique Pelle) +Files: src/spell.c, src/version.c + +Patch 7.2.004 +Problem: Cscope help message is not translated. +Solution: Put it in _(). (Dominique Pelle) +Files: src/if_cscope.c, src/if_cscope.h + +Patch 7.2.005 +Problem: A few problems when profiling. Using flag pointer instead of flag + value. Allocating zero bytes. Not freeing used memory. +Solution: Remove wrong '&' characters. Skip dumping when there is nothing + to dump. Free used memory. (Dominique Pelle) +Files: src/eval.c + +Patch 7.2.006 +Problem: HTML files are not recognized by contents. +Solution: Add a rule to the scripts file. (Nico Weber) +Files: runtime/scripts.vim + +Patch 7.2.007 (extra) +Problem: Minor issues for VMS. +Solution: Minor fixes for VMS. Add float support. (Zoltan Arpadffy) +Files: runtime/doc/os_vms.txt, src/os_vms_conf.h, src/Make_vms.mms, + src/testdir/Make_vms.mms, src/testdir/test30.in, + src/testdir/test54.in + +Patch 7.2.008 +Problem: With a BufHidden autocommand that invokes ":bunload" the window + count for a buffer can be wrong. (Bob Hiestand) +Solution: Don't call enter_buffer() when already in that buffer. +Files: src/buffer.c + +Patch 7.2.009 +Problem: Can't compile with Perl 5.10 on MS-Windows. (Cesar Romani) +Solution: Add the Perl_sv_free2 function for dynamic loading. (Dan Sharp) +Files: src/if_perl.xs + +Patch 7.2.010 +Problem: When using "K" in Visual mode not all characters are properly + escaped. (Ben Schmidt) +Solution: Use a function with the functionality of shellescape(). (Jan + Minar) +Files: src/mbyte.c, src/misc2.c, src/normal.c + +Patch 7.2.011 +Problem: Get an error when inserting a float value from the expression + register. +Solution: Convert the Float to a String automatically in the same place + where a List would be converted to a String. +Files: src/eval.c + +Patch 7.2.012 +Problem: Compiler warnings when building with startup timing. +Solution: Add type casts. +Files: src/ex_cmds2.c + +Patch 7.2.013 +Problem: While waiting for the X selection Vim consumes a lot of CPU time + and hangs until a response is received. +Solution: Sleep a bit when the selection event hasn't been received yet. + Time out after a couple of seconds to avoid a hang when the + selection owner isn't responding. +Files: src/ui.c + +Patch 7.2.014 +Problem: synstack() doesn't work in an empty line. +Solution: Accept column zero as a valid position. +Files: src/eval.c + +Patch 7.2.015 +Problem: "make all test install" doesn't stop when the test fails. (Daniel + Shahaf) +Solution: When test.log contains failures exit with non-zero status. +Files: src/testdir/Makefile + +Patch 7.2.016 +Problem: The pattern being completed may be in freed memory when the + command line is being reallocated. (Dominique Pelle) +Solution: Keep a pointer to the expand_T in the command line structure. + Don't use <S-Tab> as CTRL-P when there are no results. Clear the + completion when using a command line from the history. +Files: src/ex_getln.c + +Patch 7.2.017 +Problem: strlen() used on text that may not end in a NUL. (Dominique Pelle) + Pasting a very big selection doesn't work. +Solution: Use the length passed to the XtSelectionCallbackProc() function. + After getting the SelectionNotify event continue dispatching + events until the callback is actually called. Also dispatch the + PropertyNotify event. +Files: src/ui.c + +Patch 7.2.018 +Problem: Memory leak when substitute is aborted. +Solution: Free the buffer allocated for the new text. (Dominique Pelle) +Files: src/ex_cmds.c + +Patch 7.2.019 +Problem: Completion of ":noautocmd" doesn't work and exists(":noautocmd") + returns zero. (Ben Fritz) +Solution: Add "noautocmd" to the list of modifiers and commands. +Files: src/ex_cmds.h, src/ex_docmd.c + +Patch 7.2.020 +Problem: Starting the GUI when the executable starts with 'k', but the KDE + version no longer exists. +Solution: Don't have "kvim" start the GUI. +Files: src/main.c + +Patch 7.2.021 +Problem: When executing autocommands getting the full file name may be + slow. (David Kotchan) +Solution: Postpone calling FullName_save() until autocmd_fname is used. +Files: src/ex_docmd.c, src/fileio.c, src/globals.h + +Patch 7.2.022 (extra) +Problem: Testing is not possible when compiling with MingW. +Solution: Add a MingW specific test Makefile. (Bill McCarthy) +Files: Filelist, src/testdir/Make_ming.mak + +Patch 7.2.023 +Problem: 'cursorcolumn' is in the wrong place in a closed fold when the + display is shifted left. (Gary Johnson) +Solution: Subtract w_skipcol or w_leftcol when needed. +Files: src/screen.c + +Patch 7.2.024 +Problem: It's possible to set 'history' to a negative value and that causes + an out-of-memory error. +Solution: Check that 'history' has a positive value. (Doug Kearns) +Files: src/option.c + +Patch 7.2.025 +Problem: When a CursorHold event invokes system() it is retriggered over + and over again. +Solution: Don't reset did_cursorhold when getting K_IGNORE. +Files: src/normal.c + +Patch 7.2.026 (after 7.2.010) +Problem: "K" doesn't use the length of the identifier but uses the rest of + the line. +Solution: Copy the desired number of characters first. +Files: src/normal.c + +Patch 7.2.027 +Problem: Can use cscope commands in the sandbox. +Solution: Disallow them, they might not be safe. +Files: src/ex_cmds.h + +Patch 7.2.028 +Problem: Confusing error message for missing (). +Solution: Change "braces" to "parentheses". (Gary Johnson) +Files: src/eval.c + +Patch 7.2.029 +Problem: No completion for ":doautoall". +Solution: Complete ":doautoall" like ":doautocmd". (Doug Kearns) +Files: src/ex_docmd.c + +Patch 7.2.030 (after 7.2.027) +Problem: Can't compile. +Solution: Remove prematurely added ex_oldfiles. +Files: src/ex_cmds.h + +Patch 7.2.031 +Problem: Information in the viminfo file about previously edited files is + not available to the user. There is no way to get a complete list + of files edited in previous Vim sessions. +Solution: Add v:oldfiles and fill it with the list of old file names when + first reading the viminfo file. Add the ":oldfiles" command, + ":browse oldfiles" and the "#<123" special file name. Increase + the default value for 'viminfo' from '20 to '100. +Files: runtime/doc/cmdline.txt, runtime/doc/eval.txt, + runtime/doc/starting.txt, runtime/doc/usr_21.txt, src/eval.c, + src/ex_cmds.c, src/ex_cmds.h, src/ex_docmd.c, src/feature.h, + src/fileio.c, src/main.c, src/mark.c, src/misc1.c, + src/proto/eval.pro, src/proto/ex_cmds.pro, src/proto/mark.pro, + src/option.c, src/structs.h, src/vim.h + +Patch 7.2.032 (after 7.2.031) +Problem: Can't build with EXITFREE defined. (Dominique Pelle) +Solution: Change vv_string to vv_str. +Files: src/eval.c + +Patch 7.2.033 +Problem: When detecting a little endian BOM "ucs-2le" is used, but the text + might be "utf-16le". +Solution: Default to "utf-16le", it also works for "ucs-2le". (Jia Yanwei) +Files: src/fileio.c, src/testdir/test42.ok + +Patch 7.2.034 +Problem: Memory leak in spell info when deleting buffer. +Solution: Free the memory. (Dominique Pelle) +Files: src/buffer.c + +Patch 7.2.035 +Problem: Mismatches between alloc/malloc, free/vim_free, + realloc/vim_realloc. +Solution: Use the right function. (Dominique Pelle) +Files: src/gui_x11.c, src/mbyte.c, src/misc2.c, src/os_unix.c + +Patch 7.2.036 (extra) +Problem: Mismatches between alloc/malloc, free/vim_free, + realloc/vim_realloc. +Solution: Use the right function. (Dominique Pelle) +Files: src/gui_riscos.c, src/gui_w48.c, src/mbyte.c, src/os_vms.c, + src/os_w32exe.c, src/os_win16.c + +Patch 7.2.037 +Problem: Double free with GTK 1 and compiled with EXITFREE. +Solution: Don't close display. (Dominique Pelle) +Files: src/os_unix.c + +Patch 7.2.038 +Problem: Overlapping arguments to memcpy(). +Solution: Use mch_memmove(). (Dominique Pelle) +Files: src/if_xcmdsrv.c + +Patch 7.2.039 +Problem: Accessing freed memory on exit when EXITFREE is defined. +Solution: Call hash_init() on the v: hash table. +Files: src/eval.c + +Patch 7.2.040 +Problem: When using ":e ++ff=dos fname" and the file contains a NL without + a CR before it and 'ffs' contains "unix" then the fileformat + becomes unix. +Solution: Ignore 'ffs' when using the ++ff argument. (Ben Schmidt) + Also remove unreachable code. +Files: src/fileio.c + +Patch 7.2.041 +Problem: In diff mode, when using two tabs, each with two diffed buffers, + editing a buffer of the other tab messes up the diff. (Matt + Mzyzik) +Solution: Only copy options from a window where the buffer was edited that + doesn't have 'diff' set or is for the current tab page. + Also fix that window options for a buffer are stored with the + wrong window. +Files: src/buffer.c, src/ex_cmds.c, src/ex_cmds2.c, src/ex_docmd.c, + src/ex_getln.c, src/if_sniff.c, src/main.c, src/netbeans.c, + src/normal.c, src/popupmnu.c, src/proto/buffer.pro, + src/proto/ex_cmds.pro src/quickfix.c, src/window.c + +Patch 7.2.042 +Problem: When using winrestview() in a BufWinEnter autocommand the window + is scrolled anyway. (Matt Zyzik) +Solution: Don't recompute topline when above 'scrolloff' from the bottom. + Don't always put the cursor halfway when entering a buffer. Add + "w_topline_was_set". +Files: src/buffer.c, src/move.c, src/structs.h + +Patch 7.2.043 +Problem: VMS: Too many characters are escaped in filename and shell + commands. +Solution: Escape fewer characters. (Zoltan Arpadffy) +Files: src/vim.h + +Patch 7.2.044 +Problem: Crash because of STRCPY() being over protective of the destination + size. (Dominique Pelle) +Solution: Add -D_FORTIFY_SOURCE=1 to CFLAGS. Use an intermediate variable + for the pointer to avoid a warning. +Files: src/auto/configure, src/configure.in, src/eval.c + +Patch 7.2.045 +Problem: The Python interface has an empty entry in sys.path. +Solution: Filter out the empty entry. (idea from James Vega) +Files: src/if_python.c + +Patch 7.2.046 +Problem: Wrong check for filling buffer with encoding. (Danek Duvall) +Solution: Remove pointers. (Dominique Pelle) +Files: src/mbyte.c + +Patch 7.2.047 +Problem: Starting Vim with the -nb argument while it's not supported causes + the other side to hang. +Solution: When -nb is used while it's not supported exit Vim. (Xavier de + Gaye) +Files: src/main.c, src/vim.h + +Patch 7.2.048 +Problem: v:prevcount is changed too often. Counts are not multiplied when + setting v:count. +Solution: Set v:prevcount properly. Multiply counts. (idea by Ben Schmidt) +Files: src/eval.c, src/normal.c, src/proto/eval.pro + +Patch 7.2.049 (extra) +Problem: Win32: the clipboard doesn't support UTF-16. +Solution: Change UCS-2 support to UTF-16 support. (Jia Yanwei) +Files: src/gui_w32.c, src/gui_w48.c, src/mbyte.c, src/misc1.c, + src/os_mswin.c, src/os_win32.c, src/proto/os_mswin.pro + +Patch 7.2.050 +Problem: Warnings for not checking return value of fwrite(). (Chip Campbell) +Solution: Use the return value. +Files: src/spell.c + +Patch 7.2.051 +Problem: Can't avoid 'wildignore' and 'suffixes' for glob() and globpath(). +Solution: Add an extra argument to these functions. (Ingo Karkat) +Files: src/eval.c, src/ex_getln.c, src/proto/ex_getln.pro, + runtime/doc/eval.txt, runtime/doc/options.txt + +Patch 7.2.052 +Problem: synIDattr() doesn't support "sp" for special color. +Solution: Recognize "sp" and "sp#". (Matt Wozniski) +Files: runtime/doc/eval.txt, src/eval.c + +Patch 7.2.053 +Problem: Crash when using WorkShop command ":ws foo". (Dominique Pelle) +Solution: Avoid using a NULL pointer. +Files: src/workshop.c + +Patch 7.2.054 +Problem: Compilation warnings for format in getchar.c. +Solution: Use fputs() instead of fprintf(). (Dominique Pelle) +Files: src/getchar.c + +Patch 7.2.055 +Problem: Various compiler warnings with strict checking. +Solution: Avoid the warnings by using return values and renaming. +Files: src/diff.c, src/eval.c, src/ex_cmds.c, src/ex_docmd.c, + src/fileio.c, src/fold.c, src/globals.h, src/gui.c, + src/gui_at_sb.c, src/gui_gtk_x11.c, src/gui_xmdlg.c, + src/gui_xmebw.c, src/main.c, src/mbyte.c, src/message.c, + src/netbeans.c, src/option.c, src/os_unix.c, src/spell.c, + src/ui.c, src/window.c + +Patch 7.2.056 (after 7.2.050) +Problem: Tests 58 and 59 fail. +Solution: Don't invoke fwrite() with a zero length. (Dominique Pelle) +Files: src/spell.c + +Patch 7.2.057 (after 7.2.056) +Problem: Combination of int and size_t may not work. +Solution: Use size_t for variable. +Files: src/spell.c + +Patch 7.2.058 +Problem: Can't add a patch name to the ":version" output. +Solution: Add the extra_patches array. +Files: src/version.c + +Patch 7.2.059 +Problem: Diff display is not always updated. +Solution: Update the display more often. +Files: src/diff.c + +Patch 7.2.060 +Problem: When a spell files has many compound rules it may take a very long + time making the list of suggestions. Displaying also can be slow + when there are misspelled words. + Can't parse some Hunspell .aff files. +Solution: Check if a compounding can possibly work before trying a + combination, if the compound rules don't contain wildcards. + Implement using CHECKCOMPOUNDPATTERN. + Ignore COMPOUNDRULES. Ignore a comment after most items. + Accept ONLYINCOMPOUND as an alias for NEEDCOMPOUND. + Accept FORBIDDENWORD as an alias for BAD. +Files: runtime/doc/spell.txt, src/spell.c + +Patch 7.2.061 +Problem: Can't create a funcref for an autoload function without loading + the script first. (Marc Weber) +Solution: Accept autoload functions that don't exist yet in function(). +Files: src/eval.c + +Patch 7.2.062 +Problem: "[Scratch]" is not translated. +Solution: Mark the string for translation. (Dominique Pelle) +Files: src/buffer.c + +Patch 7.2.063 +Problem: Warning for NULL argument of Perl_sys_init3(). +Solution: Use Perl_sys_init() instead. (partly by Dominique Pelle) +Files: src/if_perl.xs + +Patch 7.2.064 +Problem: Screen update bug when repeating "~" on a Visual block and the + last line doesn't change. +Solution: Keep track of changes for all lines. (Moritz Orbach) +Files: src/ops.c + +Patch 7.2.065 +Problem: GTK GUI: the cursor disappears when doing ":vsp" and the Vim + window is maximized. (Dominique Pelle, Denis Smolyar) +Solution: Don't change "Columns" back to an old value at a wrong moment. + Do change "Rows" when it should not be a problem. +Files: src/gui.c + +Patch 7.2.066 +Problem: It's not easy to see whether 'encoding' is a multi-byte encoding. +Solution: Add has('multi_byte_encoding'). +Files: runtime/doc/eval.txt, src/eval.c + +Patch 7.2.067 +Problem: Session file can't load extra file when the path contains special + characters. +Solution: Escape the file name. (Lech Lorens) +Files: src/ex_docmd.c + +Patch 7.2.068 +Problem: Emacs tags file lines can be too long, resulting in an error + message. (James Vega) +Solution: Ignore lines with errors if they are too long. +Files: src/tag.c + +Patch 7.2.069 (after 7.2.060) +Problem: Compiler warning for storing size_t in int. +Solution: Add type cast. +Files: src/spell.c + +Patch 7.2.070 +Problem: Crash when a function returns a:000. (Matt Wozniski) +Solution: Don't put the function struct on the stack, allocate it. Free it + only when nothing in it is used. +Files: src/eval.c + +Patch 7.2.071 (extra) +Problem: Win32: Handling netbeans events while Vim is busy updating the + screen may cause a crash. +Solution: Like with GTK, only handle netbeans messages in the main loop. + (Xavier de Gaye) +Files: src/gui_w48.c, src/netbeans.c + +Patch 7.2.072 (extra) +Problem: Compiler warning in Sniff code. +Solution: Use return value of pipe(). (Dominique Pelle) +Files: src/if_sniff.c + +Patch 7.2.073 +Problem: ":set <xHome>" has the same output as ":set <Home>". (Matt + Wozniski) +Solution: Don't translate "x" keys to its alternative for ":set". +Files: src/gui_mac.c, src/misc2.c, src/option.c, src/proto/misc2.pro + +Patch 7.2.074 (extra, after 7.2.073) +Problem: ":set <xHome>" has the same output as ":set <Home>". (Matt + Wozniski) +Solution: Don't translate "x" keys to its alternative for ":set". +Files: src/gui_mac.c + +Patch 7.2.075 (after 7.2.058) +Problem: Explanation about making a diff for extra_patches is unclear. +Solution: Adjust comment. +Files: src/version.c + +Patch 7.2.076 +Problem: rename(from, to) deletes the file if "from" and "to" are not equal + but still refer to the same file. E.g., on a FAT32 filesystem + under Unix. +Solution: Go through another file name. +Files: src/fileio.c + +Patch 7.2.077 (after 7.2.076) +Problem: rename(from, to) doesn't work if "from" and "to" differ only in + case on a system that ignores case in file names. +Solution: Go through another file name. +Files: src/fileio.c + +Patch 7.2.078 +Problem: When deleting a fold that is specified with markers the cursor + position may be wrong. Folds may not be displayed properly after + a delete. Wrong fold may be deleted. +Solution: Fix the problems. (mostly by Lech Lorens) +Files: src/fold.c + +Patch 7.2.079 +Problem: "killed" netbeans events are not handled correctly. +Solution: A "killed" netbeans event is sent when the buffer is deleted or + wiped out (in this case, the netbeans annotations in this buffer + have been removed). A user can still remove a sign with the + command ":sign unplace" and this does not trigger a "killed" + event. (Xavier de Gaye) +Files: runtime/doc/netbeans.txt, src/buffer.c, src/globals.h, + src/netbeans.c, src/proto/netbeans.pro + +Patch 7.2.080 +Problem: When typing a composing character just after starting completion + may access memory before its allocation point. (Dominique Pelle) +Solution: Don't delete before the completion start column. Add extra checks + for the offset not being negative. +Files: src/edit.c + +Patch 7.2.081 +Problem: Compiler warning for floating point overflow on VAX. +Solution: For VAX use a smaller number. (Zoltan Arpadffy) +Files: src/message.c + +Patch 7.2.082 +Problem: When 'ff' is "mac" then "ga" on a ^J shows 0x0d instead of 0x0a. + (Andy Wokula) +Solution: Use NL for this situation. (Lech Lorens) +Files: src/ex_cmds.c + +Patch 7.2.083 +Problem: ":tag" does not return to the right tag entry from the tag stack. +Solution: Don't change the current match when there is no argument. + (Erik Falor) +Files: src/tag.c + +Patch 7.2.084 +Problem: Recursive structures are not handled properly in Python + vim.eval(). +Solution: Keep track of references in a better way. (Yukihiro Nakadaira) +Files: src/if_python.c + +Patch 7.2.085 +Problem: ":set <M-b>=<Esc>b" does not work when 'encoding' is utf-8. +Solution: Put the <M-b> character in the input buffer as valid utf-8. + (partly by Matt Wozniski) +Files: src/term.c + +Patch 7.2.086 +Problem: Using ":diffget 1" in buffer 1 corrupts the text. +Solution: Don't do anything when source and destination of ":diffget" or + ":diffput" is the same buffer. (Dominique Pelle) +Files: src/diff.c + +Patch 7.2.087 +Problem: Adding URL to 'path' doesn't work to edit a file. +Solution: Skip simplify_filename() for URLs. (Matt Wozniski) +Files: src/misc2.c + +Patch 7.2.088 (extra) +Problem: OpenClipboard() may fail when another application is using the + clipboard. +Solution: Retry OpenClipboard() a few times. (Jianrong Yu) +Files: src/os_mswin.c + +Patch 7.2.089 (extra) +Problem: Win32: crash when using Ultramon buttons. +Solution: Don't use a WM_OLE message of zero size. (Ray Megal) +Files: src/if_ole.cpp, src/gui_w48.c + +Patch 7.2.090 +Problem: User command containing 0x80 in multi-byte character does not work + properly. (Yasuhiro Matsumoto) +Solution: Undo replacement of K_SPECIAL and CSI characters when executing + the command. +Files: src/ex_docmd.c + +Patch 7.2.091 +Problem: ":cs help" output is not aligned for some languages. +Solution: Compute character size instead of byte size. (Dominique Pelle) +Files: src/if_cscope.c + +Patch 7.2.092 +Problem: Some error messages are not translated. +Solution: Add _() around the messages. (Dominique Pelle) +Files: src/eval.c + +Patch 7.2.093 (extra) +Problem: Win32: inputdialog() and find/replace dialogs can't handle + multi-byte text. +Solution: Use the wide version of dialog functions when available. (Yanwei + Jia) +Files: src/gui_w32.c, src/gui_w48.c + +Patch 7.2.094 +Problem: Compiler warning for signed/unsigned compare. +Solution: Add type cast. Also fix a few typos. +Files: src/edit.c + +Patch 7.2.095 +Problem: With Visual selection, "r" and then CTRL-C Visual mode is stopped + but the highlighting is not removed. +Solution: Call reset_VIsual(). +Files: src/normal.c + +Patch 7.2.096 +Problem: After ":number" the "Press Enter" message may be on the wrong + screen, if switching screens for shell commands. +Solution: Reset info_message. (James Vega) +Files: src/ex_cmds.c + +Patch 7.2.097 +Problem: "!xterm&" doesn't work when 'shell' is "bash". +Solution: Ignore SIGHUP after calling setsid(). (Simon Schubert) +Files: src/os_unix.c + +Patch 7.2.098 +Problem: Warning for signed/unsigned pointer. +Solution: Add type cast. +Files: src/eval.c + +Patch 7.2.099 +Problem: Changing GUI options causes an unnecessary redraw when the GUI + isn't active. +Solution: Avoid the redraw. (Lech Lorens) +Files: src/option.c + +Patch 7.2.100 +Problem: When using ":source" on a FIFO or something else that can't rewind + the first three bytes are skipped. +Solution: Instead of rewinding read the first line and detect a BOM in that. + (mostly by James Vega) +Files: src/ex_cmds2.c + +Patch 7.2.101 (extra) +Problem: MSVC version not recognized. +Solution: Add the version number to the list. (Zhong Zhang) +Files: src/Make_mvc.mak + +Patch 7.2.102 (after 7.2.100) +Problem: When 'encoding' is "utf-8" a BOM at the start of a Vim script is + not removed. (Tony Mechelynck) +Solution: When no conversion is taking place make a copy of the line without + the BOM. +Files: src/ex_cmds2.c + +Patch 7.2.103 +Problem: When 'bomb' is changed the window title is updated to show/hide a + "+", but the tab page label isn't. (Patrick Texier) +Solution: Set "redraw_tabline" in most places where "need_maketitle" is set. + (partly by Lech Lorens) +Files: src/option.c + +Patch 7.2.104 +Problem: When using ":saveas bar.c" the tab label isn't updated right away. +Solution: Set redraw_tabline. (Francois Ingelrest) +Files: src/ex_cmds.c + +Patch 7.2.105 +Problem: Modeline setting for 'foldmethod' overrules diff options. (Ingo + Karkat) +Solution: Don't set 'foldmethod' and 'wrap' from a modeline when 'diff' is + on. +Files: src/option.c + +Patch 7.2.106 +Problem: Endless loop when using "]s" in HTML when there are no + misspellings. (Ingo Karkat) +Solution: Break the search loop. Also fix pointer alignment for systems + with pointers larger than int. +Files: src/spell.c + +Patch 7.2.107 +Problem: When using a GUI dialog and ":echo" commands the messages are + deleted after the dialog. (Vincent Birebent) +Solution: Don't call msg_end_prompt() since there was no prompt. +Files: src/message.c + +Patch 7.2.108 (after 7.2.105) +Problem: Can't build without the diff feature. +Solution: Add #ifdef. +Files: src/option.c + +Patch 7.2.109 +Problem: 'langmap' does not work for multi-byte characters. +Solution: Add a list of mapped multi-byte characters. (based on work by + Konstantin Korikov, Agathoklis Hatzimanikas) +Files: runtime/doc/options.txt, src/edit.c, src/getchar.c, src/macros.h, + src/normal.c, src/option.c, src/proto/option.pro, src/window.c + +Patch 7.2.110 +Problem: Compiler warning for unused variable. +Solution: Init the variable. +Files: src/ex_docmd.c + +Patch 7.2.111 +Problem: When using Visual block mode with 'cursorcolumn' it's unclear what + is selected. +Solution: Don't use 'cursorcolumn' highlighting inside the Visual selection. + (idea by Dominique Pelle) +Files: src/screen.c + +Patch 7.2.112 +Problem: Cursor invisible in Visual mode when 'number' is set and cursor in + first column. (Matti Niemenmaa, Renato Alves) +Solution: Check that vcol_prev is smaller than vcol. +Files: src/screen.c + +Patch 7.2.113 +Problem: Crash for substitute() call using submatch(1) while there is no + such submatch. (Yukihiro Nakadaira) +Solution: Also check the start of the submatch is set, it can be NULL when + an attempted match didn't work out. +Files: src/regexp.c + +Patch 7.2.114 +Problem: Using wrong printf format. +Solution: Use "%ld" instead of "%d". (Dominique Pelle) +Files: src/netbeans.c + +Patch 7.2.115 +Problem: Some debugging code is never used. +Solution: Remove nbtrace() and nbprt(). (Dominique Pelle) +Files: src/nbdebug.c, src/nbdebug.h + +Patch 7.2.116 +Problem: Not all memory is freed when EXITFREE is defined. +Solution: Free allocated memory on exit. (Dominique Pelle) +Files: src/ex_docmd.c, src/gui_gtk_x11.c, src/misc2.c, src/search.c, + src/tag.c + +Patch 7.2.117 +Problem: Location list incorrectly labelled "Quickfix List". +Solution: Break out of both loops for finding window for location list + buffer. (Lech Lorens) +Files: src/buffer.c, src/quickfix.c, src/screen.c + +Patch 7.2.118 +Problem: <PageUp> at the more prompt only does half a page. +Solution: Make <PageUp> go up a whole page. Also make 'f' go a page + forward, but not quit the more prompt. (Markus Heidelberg) +Files: src/message.c + +Patch 7.2.119 +Problem: Status line is redrawn too often. +Solution: Check ScreeenLinesUC[] properly. (Yukihiro Nakadaira) +Files: src/screen.c + +Patch 7.2.120 +Problem: When opening the quickfix window or splitting the window and + setting the location list, the location list is copied and then + deleted, which is inefficient. +Solution: Don't copy the location list when not needed. (Lech Lorens) +Files: src/quickfix.c, src/vim.h, src/window.c + +Patch 7.2.121 +Problem: In gvim "!grep a *.c" spews out a lot of text that can't be + stopped with CTRL-C. +Solution: When looping to read and show text, do check for typed characters + every two seconds. +Files: src/os_unix.c + +Patch 7.2.122 +Problem: Invalid memory access when the VimResized autocommand changes + 'columns' and/or 'lines'. +Solution: After VimResized check for changed values. (Dominique Pelle) +Files: src/screen.c + +Patch 7.2.123 +Problem: Typing 'q' at more prompt for ":map" output still displays another + line, causing another more prompt. (Markus Heidelberg) +Solution: Quit listing maps when 'q' typed. +Files: src/getchar.c + +Patch 7.2.124 +Problem: Typing 'q' at more prompt for ":tselect" output still displays + more lines, causing another more prompt. (Markus Heidelberg) +Solution: Quit listing tags when 'q' typed. +Files: src/tag.c + +Patch 7.2.125 +Problem: Leaking memory when reading XPM bitmap for a sign. +Solution: Don't allocate the memory twice. (Dominique Pelle) +Files: src/gui_x11.c + +Patch 7.2.126 +Problem: When EXITFREE is defined signs are not freed. +Solution: Free all signs on exit. Also free keymaps. (Dominique Pelle) +Files: src/misc2.c, src/ex_cmds.c, src/proto/ex_cmds.pro + +Patch 7.2.127 +Problem: When listing mappings and a wrapping line causes the more prompt, + after typing 'q' there can be another more prompt. (Markus + Heidelberg) +Solution: Set "lines_left" to allow more lines to be displayed. +Files: src/message.c + +Patch 7.2.128 (after 7.2.055) +Problem: Using ":lcd" makes session files not work. +Solution: Compare return value of mch_chdir() properly. (Andreas Bernauer) +Files: src/ex_docmd.c + +Patch 7.2.129 +Problem: When opening a command window from input() it uses the search + history. +Solution: Use get_cmdline_type(). (James Vega) +Files: src/ex_getln.c + +Patch 7.2.130 +Problem: Vim may haing until CTRL-C is typed when using CTRL-Z. +Solution: Avoid using pause(). Also use "volatile" for variables used in + signal functions. (Dominique Pelle) +Files: src/auto/configure, src/configure.in, src/config.h.in, + src/globals.h, src/os_unix.c + +Patch 7.2.131 +Problem: When 'keymap' is cleared may still use the cursor highlighting for + when it's enabled. +Solution: Reset 'iminsert' and 'imsearch'. (partly by Dominique Pelle) + Also avoid ":setlocal" for these options have a global effect. +Files: src/option.c + +Patch 7.2.132 +Problem: When changing directory during a SwapExists autocmd freed memory + may be accessed. (Dominique Pelle) +Solution: Add the allbuf_lock flag. +Files: src/ex_getln.c, src/globals.h, src/fileio.c, + src/proto/ex_getln.pro + +Patch 7.2.133 +Problem: ":diffoff!" changes settings in windows not in diff mode. +Solution: Only change settings in other windows when 'diff' is set, always + do it for the current window. (Lech Lorens) +Files: src/diff.c + +Patch 7.2.134 +Problem: Warning for discarding "const" from pointer. +Solution: Don't pass const pointer to mch_memmove(). +Files: src/fileio.c + +Patch 7.2.135 +Problem: Memory leak when redefining user command with complete argument. +Solution: Free the old complete argument. (Dominique Pelle) +Files: src/ex_docmd.c + +Patch 7.2.136 (after 7.2.132) +Problem: ":cd" is still possible in a SwapExists autocmd. +Solution: Check the allbuf_lock flag in ex_cd(). +Files: src/ex_docmd.c + +Patch 7.2.137 +Problem: When 'virtualedit' is set, a left shift of a blockwise selection + that starts and ends inside a tab shifts too much. (Helmut + Stiegler) +Solution: Redo the block left shift code. (Lech Lorens) +Files: src/ops.c, src/testdir/Makefile, src/testdir/test66.in, + src/testdir/test66.ok + +Patch 7.2.138 (extra part of 7.2.137) +Problem: See 7.2.137. +Solution: See 7.2.137. +Files: src/testdir/Make_amiga.mak, src/testdir/Make_dos.mak, + src/testdir/Make_ming.mak, src/testdir/Make_os2.mak, + src/testdir/Make_vms.mms + +Patch 7.2.139 +Problem: Crash when 'virtualedit' is "all". (James Vega) +Solution: Avoid overflow when column is MAXCOL. (Dominique Pelle) +Files: src/misc2.c + +Patch 7.2.140 +Problem: Diff highlighting isn't displayed before the Visual area if it + starts at the cursor position. (Markus Heidelberg) +Solution: Also check fromcol_prev. +Files: src/screen.c + +Patch 7.2.141 +Problem: When redrawing a character for bold spill this causes the next + character to be redrawn as well. +Solution: Only redraw one extra character. (Yukihiro Nakadaira) +Files: src/screen.c + +Patch 7.2.142 +Problem: Motif and Athena balloons don't use tooltip colors. +Solution: Set the colors. (Matt Wozniski) +Files: src/gui_beval.c + +Patch 7.2.143 +Problem: No command line completion for ":cscope" command. +Solution: Add the completion for ":cscope". (Dominique Pelle) +Files: src/ex_docmd.c, src/ex_getln.c, src/if_cscope.c, + src/proto/if_cscope.pro, src/vim.h + +Patch 7.2.144 +Problem: When 't_Co' is set to the value it already had the color scheme is + reloaded anyway. +Solution: Only load the colorscheme when the t_Co value changes. (Dominique + Pelle) +Files: src/option.c + +Patch 7.2.145 +Problem: White space in ":cscope find" is not ignored. +Solution: Ignore the white space, but not when the leading white space is + useful for the argument. +Files: runtime/doc/if_scop.txt, src/if_cscope.c + +Patch 7.2.146 +Problem: v:warningmsg isn't used for all warnings. +Solution: Set v:warningmsg for relevant warnings. (Ingo Karkat) +Files: src/fileio.c, src/misc1.c, src/option.c + +Patch 7.2.147 +Problem: When compiled as small version and 'number' is on the cursor is + displayed in the wrong position after a tab. (James Vega) +Solution: Don't increment vcol when still displaying the line number. +Files: src/screen.c + +Patch 7.2.148 +Problem: When searching for "$" while 'hlsearch' is set, highlighting the + character after the line does not work in the cursor column. + Also highlighting for Visual mode after the line end when this + isn't needed. (Markus Heidelberg) +Solution: Only compare the cursor column in the cursor line. Only highlight + for Visual selection after the last character when it's needed to + see where the Visual selection ends. +Files: src/screen.c + +Patch 7.2.149 +Problem: Using return value of function that doesn't return a value results + in reading uninitialized memory. +Solution: Set the default to return zero. Make cursor() return -1 on + failure. Let complete() return an empty string in case of an + error. (partly by Dominique Pelle) +Files: runtime/doc/eval.txt, src/eval.c + +Patch 7.2.150 (extra) +Problem: Can't use tab pages from VisVim. +Solution: Add tab page support to VisVim. (Adam Slater) +Files: src/VisVim/Commands.cpp, src/VisVim/Resource.h, + src/VisVim/VisVim.rc + +Patch 7.2.151 +Problem: ":hist a" doesn't work like ":hist all" as the docs suggest. +Solution: Make ":hist a" and ":hist al" work. (Dominique Pelle) +Files: src/ex_getln.c + +Patch 7.2.152 +Problem: When using "silent echo x" inside ":redir" a next echo may start + halfway the line. (Tony Mechelynck, Dennis Benzinger) +Solution: Reset msg_col after redirecting silently. +Files: src/ex_docmd.c, src/message.c, src/proto/message.pro + +Patch 7.2.153 +Problem: Memory leak for ":recover empty_dir/". +Solution: Free files[] when it becomes empty. (Dominique Pelle) +Files: src/memline.c + +Patch 7.2.154 (after 7.2.132) +Problem: ":cd" is still possible in a SwapExists autocmd. +Solution: Set allbuf_lock in do_swapexists(). +Files: src/memline.c + +Patch 7.2.155 +Problem: Memory leak in ":function /pat". +Solution: Free the memory. (Dominique Pelle) +Files: src/eval.c + +Patch 7.2.156 (after 7.2.143) +Problem: No completion for :scscope and :lcscope commands. +Solution: Implement the completion. (Dominique Pelle) +Files: src/if_cscope.c, src/ex_docmd.c, src/proto/if_cscope.pro + +Patch 7.2.157 +Problem: Illegal memory access when searching in path. +Solution: Avoid looking at a byte after end of a string. (Dominique Pelle) +Files: src/search.c + +Patch 7.2.158 +Problem: Warnings from VisualC compiler. +Solution: Add type casts. (George Reilly) +Files: src/ops.c + +Patch 7.2.159 +Problem: When $x_includes ends up being "NONE" configure fails. +Solution: Check for $x_includes not to be "NONE" (Rainer) +Files: src/auto/configure, src/configure.in + +Patch 7.2.160 +Problem: Search pattern not freed on exit when 'rightleft' set. +Solution: Free mr_pattern_alloced. +Files: src/search.c + +Patch 7.2.161 +Problem: Folds messed up in other tab page. (Vlad Irnov) +Solution: Instead of going over all windows in current tab page go over all + windows in all tab pages. Also free memory for location lists in + other tab pages when exiting. (Lech Lorens) +Files: src/fileio.c, src/mark.c, src/misc1.c, src/misc2.c + +Patch 7.2.162 +Problem: The quickfix window may get wrong filetype. +Solution: Do not detect the filetype for the quickfix window. (Lech Lorens) +Files: src/quickfix.c + +Patch 7.2.163 +Problem: The command line window may get folding. +Solution: Default to no/manual folding. (Lech Lorens) +Files: src/ex_getln.c + +Patch 7.2.164 +Problem: When 'showbreak' is set the size of the Visual block may be + reported wrong. (Eduardo Daudt Flach) +Solution: Temporarily make 'sbr' empty. +Files: src/normal.c, src/ops.c + +Patch 7.2.165 +Problem: The argument for the FuncUndefined autocmd event is expanded like + a file name. +Solution: Don't try expanding it. (Wang Xu) +Files: src/fileio.c + +Patch 7.2.166 +Problem: No completion for ":sign" command. +Solution: Add ":sign" completion. (Dominique Pelle) +Files: src/ex_cmds.c, src/ex_docmd.c, src/ex_getln.c, src/vim.h, + src/proto/ex_cmds.pro + +Patch 7.2.167 +Problem: Splint doesn't work well for checking the code. +Solution: Add splint arguments in the Makefile. Exclude some code from + splint that it can't handle. Tune splint arguments to give + reasonable errors. Add a filter for removing false warnings from + splint output. Many small changes to avoid warnings. More to + follow... +Files: Filelist, src/Makefile, src/buffer.c, src/charset.c, + src/cleanlint.vim, src/digraph.c, src/edit.c, src/ex_cmds.c, + src/globals.h, src/ops.c, src/os_unix.c, src/os_unix.h, + src/proto/buffer.pro, src/proto/edit.pro, src/screen.c, + src/structs.h + +Patch 7.2.168 +Problem: When no ctags program can be found, "make tags" attempts to + execute the first C file. +Solution: Default to "ctags" when no ctags program can be found. +Files: src/configure.in, src/auto/configure + +Patch 7.2.169 +Problem: Splint complains about a lot of things. +Solution: Add type casts, #ifdefs and other changes to avoid warnings. + Change colnr_T from unsigned to int. Avoids mistakes with + subtracting columns. +Files: src/cleanlint.vim, src/diff.c, src/edit.c, src/ex_cmds.c, + src/ex_cmds2.c, src/ex_docmd.c, src/proto/ex_cmds.pro, + src/proto/spell.pro, src/quickfix.c, src/spell.c, src/structs.h, + src/term.h, src/vim.h + +Patch 7.2.170 +Problem: Using b_dev while it was not set. (Dominique Pelle) +Solution: Add the b_dev_valid flag. +Files: src/buffer.c, src/fileio.c, src/structs.h + +Patch 7.2.171 (after 7.2.169) +Problem: Compiler warnings. (Tony Mechelynck) +Solution: Add function prototype. (Patrick Texier) Init variable. +Files: src/ex_cmds.c + +Patch 7.2.172 (extra) +Problem: Compiler warning. +Solution: Adjust function prototype. (Patrick Texier) +Files: src/os_mswin.c + +Patch 7.2.173 +Problem: Without lint there is no check for unused function arguments. +Solution: Use gcc -Wunused-parameter instead of lint. For a few files add + attributes to arguments that are known not to be used. +Files: src/auto/configure, src/buffer.c, src/charset.c, src/diff.c, + src/configure.in, src/config.h.in, src/edit.c, src/ex_cmds.c, + src/ex_cmds2.c, src/version.c, src/vim.h + +Patch 7.2.174 +Problem: Too many warnings from gcc -Wextra. +Solution: Change initializer. Add UNUSED. Add type casts. +Files: src/edit.c, src/eval.c, src/ex_cmds.c, src/ex_docmd.c, + src/ex_getln.c, src/fileio.c, getchar.c, globals.h, main.c, + memline.c, message.c, src/misc1.c, src/move.c, src/normal.c, + src/option.c, src/os_unix.c, src/os_unix.h, src/regexp.c, + src/search.c, src/tag.c + +Patch 7.2.175 +Problem: Compiler warning in OpenBSD. +Solution: Add type cast for NULL. (Dasn) +Files: src/if_cscope.c + +Patch 7.2.176 +Problem: Exceptions for splint are not useful. +Solution: Remove the S_SPLINT_S ifdefs. +Files: src/edit.c, src/ex_cmds.c, src/ex_docmd.c, src/os_unix.c, + src/os_unix.h, src/os_unixx.h, src/structs.h, src/term.h + +Patch 7.2.177 +Problem: Compiler warnings when using -Wextra +Solution: Add UNUSED and type casts. +Files: src/eval.c, src/ex_docmd.c, src/ex_eval.c, src/ex_getln.c, + src/fileio.c, src/hardcopy.c, src/if_cscope.c, src/if_xcmdsrv.c, + src/farsi.c, src/mark.c, src/menu.c + +Patch 7.2.178 +Problem: Using negative value for device number might not work. +Solution: Use a separate flag for whether ffv_dev was set. +Files: src/misc2.c + +Patch 7.2.179 +Problem: Using negative value for device number might not work. +Solution: Use a separate flag for whether sn_dev was set. +Files: src/ex_cmds2.c + +Patch 7.2.180 +Problem: Some more compiler warnings when using gcc -Wextra. +Solution: Add UNUSED and type casts. +Files: src/buffer.c, src/ex_cmds.c, src/macros.h, src/main.c, + src/menu.c, src/message.c, src/misc1.c, src/mbyte.c, + src/normal.c, src/option.c, src/os_unix.c, src/quickfix.c, + src/screen.c, src/search.c, src/spell.c, src/syntax.c, src/tag.c, + src/term.c, src/ui.c + +Patch 7.2.181 +Problem: Some more compiler warnings when using gcc -Wextra. +Solution: Add UNUSED and type casts. +Files: src/if_mzsch.c, src/gui.c, src/gui_gtk.c, src/gui_gtk_x11.c, + src/gui_gtk_f.c, src/gui_beval.c, src/netbeans.c + +Patch 7.2.182 (after 7.2.181) +Problem: Compilation problems after previous patch for Motif. Gvim with + GTK crashes on startup. +Solution: Add comma. Init form structure to zeroes. +Files: src/netbeans.c, src/gui_gtk_f.c + +Patch 7.2.183 +Problem: Configure problem for sys/sysctl.h on OpenBSD. (Dasn) +Solution: Add separate check for this header file. Also switch to newer + version of autoconf. +Files: src/auto/configure, src/configure.in + +Patch 7.2.184 +Problem: Some more compiler warnings when using gcc -Wextra. +Solution: Add UNUSED and type casts. Autoconf check for wchar_t. +Files: src/auto/configure, src/config.h.in, src/configure.in, + src/gui_athena.c, src/gui_x11.c, src/gui.c, src/gui_beval.c, + src/gui_at_sb.c, src/gui_at_fs.c, src/gui_motif.c, + src/gui_xmdlg.c, src/gui_xmebw.c, src/if_python.c, src/window.c, + src/workshop.c + +Patch 7.2.185 +Problem: Some more compiler warnings when using gcc -Wextra. +Solution: Add UNUSED and type casts. +Files: src/Makefile, src/if_tlc.c, src/if_ruby.c + +Patch 7.2.186 +Problem: Some more compiler warnings when using gcc -Wextra. +Solution: Now with the intended if_tcl.c changes. +Files: src/if_tcl.c + +Patch 7.2.187 (after 7.2.186) +Problem: Doesn't build with older versions of TCL. (Yongwei Wu) +Solution: Add #ifdefs. (Dominique Pelle) +Files: src/if_tcl.c + +Patch 7.2.188 +Problem: Crash with specific use of function calls. (Meikel Brandmeyer) +Solution: Make sure the items referenced by a function call are not freed + twice. (based on patch from Nico Weber) +Files: src/eval.c + +Patch 7.2.189 +Problem: Possible hang for deleting auto-indent. (Dominique Pelle) +Solution: Make sure the position is not beyond the end of the line. +Files: src/edit.c + +Patch 7.2.190 +Problem: The register executed by @@ isn't restored. +Solution: Mark the executable register in the viminfo file. +Files: src/ops.c + +Patch 7.2.191 +Problem: Mzscheme interface doesn't work on Ubuntu. +Solution: Change autoconf rules. Define missing macro. Some changes to + avoid gcc warnings. Remove per-buffer namespace. (Sergey Khorev) +Files: runtime/doc/if_mzsch.txt, src/Makefile, src/Make_ming.mak, + src/Make_mvc.mak, src/auto/configure, src/configure.in, + src/config.mk.in, src/eval.c, src/if_mzsch.c, src/if_mzsch.h, + src/main.c, src/proto/if_mzsch.pro + +Patch 7.2.192 (after 7.2.188) +Problem: Still a crash in the garbage collector for a very rare situation. +Solution: Make sure current_copyID is always incremented correctly. (Kent + Sibilev) +Files: src/eval.c + +Patch 7.2.193 +Problem: Warning for uninitialized values. +Solution: Initialize all the struct items. +Files: src/eval.c + +Patch 7.2.194 (extra) +Problem: MSVC: rem commands are echoed. +Solution: Add commands to switch off echo. (Wang Xu) +Files: src/msvc2008.bat + +Patch 7.2.195 +Problem: Leaking memory for the command Vim was started with. +Solution: Remember the pointer and free it. +Files: src/gui_gtk_x11.c + +Patch 7.2.196 (after 7.2.167) +Problem: Turns out splint doesn't work well enough to be usable. +Solution: Remove splint support. +Files: Filelist, src/cleanlint.vim + +Patch 7.2.197 +Problem: Warning for uninitialized values. +Solution: Initialize all the struct items of typebuf. +Files: src/globals.h + +Patch 7.2.198 +Problem: Size of buffer used for tgetent() may be too small. +Solution: Use the largest known size everywhere. +Files: src/vim.h + +Patch 7.2.199 +Problem: Strange character in comment. +Solution: Change to "message". (Yongwei Wu) +Files: src/term.c + +Patch 7.2.200 +Problem: Reading past end of string when navigating the menu bar or + resizing the window. +Solution: Add and use mb_ptr2len_len(). (partly by Dominique Pelle) + Also add mb_ptr2cells_len() to prevent more trouble. +Files: src/gui_gtk_x11.c, src/os_unix.c, src/globals.h, src/mbyte.c, + src/proto/mbyte.pro + +Patch 7.2.201 +Problem: Cannot copy/paste HTML to/from Firefox via the clipboard. +Solution: Implement this for GTK. Add the "html" value to 'clipboard'. +Files: runtime/doc/options.txt, src/globals.h, src/gui_gtk_x11.c, + src/mbyte.c, src/proto/mbyte.pro, src/option.c + +Patch 7.2.202 +Problem: BufWipeout autocommand that edits another buffer causes problems. +Solution: Check for the situation, give an error and quit the operation. +Files: src/fileio.c + +Patch 7.2.203 +Problem: When reloading a buffer or doing anything else with a buffer that + is not displayed in a visible window, autocommands may be applied + to the current window, folds messed up, etc. +Solution: Instead of using the current window for the hidden buffer use a + special window, splitting the current one temporarily. +Files: src/fileio.c, src/globals.h, src/gui.c, src/if_perl.xs, + src/progo/gui.pro, src/proto/window.pro, src/screen.c, + src/structs.h, src/window.c + +Patch 7.2.204 (extra) +Problem: Win32: Can't build with Visual Studio 2010 beta 1. +Solution: Fix the makefile. (George Reilly) +Files: src/Make_mvc.mak + +Patch 7.2.205 (extra) +Problem: Win32: No support for High DPI awareness. +Solution: Fix the manifest file. (George Reilly) +Files: src/Make_mvc.mak, src/gvim.exe.mnf + +Patch 7.2.206 +Problem: Win32: Can't build netbeans interface with Visual Studio 2010. +Solution: Undefine ECONNREFUSED. (George Reilly) +Files: src/netbeans.c + +Patch 7.2.207 +Problem: Using freed memory with ":redrawstatus" when it works recursively. +Solution: Prevent recursively updating the status line. (partly by Dominique + Pelle) +Files: src/screen.c + +Patch 7.2.208 +Problem: "set novice" gives an error message, it should be ignored. +Solution: Don't see "no" in "novice" as unsetting an option. (Patrick + Texier) +Files: src/option.c + +Patch 7.2.209 +Problem: For xxd setmode() is undefined on Cygwin. +Solution: Include io.h. (Dominique Pelle) +Files: src/xxd/xxd.c + +Patch 7.2.210 +Problem: When a file that is being edited has its timestamp updated outside + of Vim and ":checktime" is used still get a warning when writing + the file. (Matt Mueller) +Solution: Store the timestamp in b_mtime_read when the timestamp is the only + thing that changed. +Files: src/fileio.c + +Patch 7.2.211 +Problem: Memory leak when expanding a series of file names. +Solution: Use ga_clear_strings() instead of ga_clear(). +Files: src/misc1.c + +Patch 7.2.212 (extra) +Problem: Warnings for redefining SIG macros. +Solution: Don't define them if already defined. (Bjorn Winckler) +Files: src/os_mac.h + +Patch 7.2.213 +Problem: Warning for using vsprintf(). +Solution: Use vim_vsnprintf(). +Files: src/netbeans.c + +Patch 7.2.214 +Problem: Crash with complete function for user command. (Andy Wokula) +Solution: Avoid using a NULL pointer (Dominique Pelle) +Files: src/ex_getln.c + +Patch 7.2.215 +Problem: ml_get error when using ":vimgrep". +Solution: Load the memfile for the hidden buffer before putting it in a + window. Correct the order of splitting the window and filling + the window and buffer with data. +Files: src/fileio.c, src/proto/window.pro, src/quickfix.c, src/window.c + +Patch 7.2.216 +Problem: Two error messages have the same number E812. +Solution: Give one message a different number. +Files: runtime/doc/autocmd.txt, runtime/doc/if_mzsch.txt, src/if_mzsch.c + +Patch 7.2.217 +Problem: Running tests with valgrind doesn't work as advertised. +Solution: Fix the line in the Makefile. +Files: src/testdir/Makefile + +Patch 7.2.218 +Problem: Cannot build GTK with hangul_input feature. (Dominique Pelle) +Solution: Adjust #ifdef. (SungHyun Nam) +Files: src/gui.c + +Patch 7.2.219 (extra) +Problem: Photon GUI is outdated. +Solution: Updates for QNX 6.4.0. (Sean Boudreau) +Files: src/gui_photon.c + +Patch 7.2.220 (after 7.2.215) +Problem: a BufEnter autocommand that changes directory causes problems. + (Ajit Thakkar) +Solution: Disable autocommands when opening a hidden buffer in a window. +Files: src/fileio.c + +Patch 7.2.221 +Problem: X cut_buffer0 text is used as-is, it may be in the wrong encoding. +Solution: Convert between 'enc' and latin1. (James Vega) +Files: src/gui_gtk_x11.c, src/message.c, src/ops.c, src/proto/ui.pro, + src/ui.c + +Patch 7.2.222 +Problem: ":mksession" doesn't work properly with 'acd' set. +Solution: Make it work. (Yakov Lerner) +Files: src/ex_docmd.c + +Patch 7.2.223 +Problem: When a script is run with ":silent" it is not able to give warning + messages. +Solution: Add the ":unsilent" command. +Files: runtime/doc/various.txt, src/ex_cmds.h, src/ex_docmd.c + +Patch 7.2.224 +Problem: Crash when using 'completefunc'. (Ingo Karkat) +Solution: Disallow entering edit() recursively when doing completion. +Files: src/edit.c + +Patch 7.2.225 +Problem: When using ":normal" a saved character may be executed. +Solution: Also store old_char when saving typeahead. +Files: src/getchar.c, src/structs.h + +Patch 7.2.226 +Problem: ml_get error after deleting the last line. (Xavier de Gaye) +Solution: When adjusting marks a callback may be invoked. Adjust the cursor + position before invoking deleted_lines_mark(). +Files: src/ex_cmds.c, src/ex_docmd.c, src/if_mzsch.c, src/if_python.c, + src/if_perl.xs, src/misc1.c + +Patch 7.2.227 +Problem: When using ":cd" in a script there is no way to track this. +Solution: Display the directory when 'verbose' is 5 or higher. +Files: src/ex_docmd.c + +Patch 7.2.228 +Problem: Cscope is limited to 8 connections. +Solution: Allocated the connection array to handle any number of + connections. (Dominique Pelle) +Files: runtime/doc/if_cscop.txt, src/if_cscope.h, src/if_cscope.c + +Patch 7.2.229 +Problem: Warning for shadowed variable. +Solution: Rename "wait" to "wait_time". +Files: src/os_unix.c + +Patch 7.2.230 +Problem: A few old lint-style ARGUSED comments. +Solution: Change to the new UNUSED style. +Files: src/getchar.c + +Patch 7.2.231 +Problem: Warning for unreacheable code. +Solution: Add #ifdef. +Files: src/if_perl.xs + +Patch 7.2.232 +Problem: Cannot debug problems with being in a wrong directory. +Solution: When 'verbose' is 5 or higher report directory changes. +Files: src/os_unix.c, src/os_unix.h, src/proto/os_unix.pro + +Patch 7.2.233 (extra part of 7.2.232) +Problem: Cannot debug problems with being in a wrong directory. +Solution: When 'verbose' is 5 or higher report directory changes. +Files: src/os_msdos.c, src/os_mswin.c, src/os_riscos.c, src/os_mac.h + +Patch 7.2.234 +Problem: It is not possible to ignore file names without a suffix. +Solution: Use an empty entry in 'suffixes' for file names without a dot. +Files: runtime/doc/cmdline.txt, src/misc1.c + +Patch 7.2.235 +Problem: Using CTRL-O z= in Insert mode has a delay before redrawing. +Solution: Reset msg_didout and msg_scroll. +Files: src/misc1.c, src/spell.c + +Patch 7.2.236 +Problem: Mac: Compiling with Ruby doesn't always work. +Solution: In configure filter out the --arch argument (Bjorn Winckler) +Files: src/configure.in, src/auto/configure + +Patch 7.2.237 +Problem: Crash on exit when window icon not set. +Solution: Copy terminal name when using it for the icon name. +Files: src/os_unix.c + +Patch 7.2.238 +Problem: Leaking memory when setting term to "builtin_dumb". +Solution: Free memory when resetting term option t_Co. +Files: src/option.c, src/proto/option.pro, src/term.c + +Patch 7.2.239 +Problem: Using :diffpatch twice or when patching fails causes memory + corruption and/or a crash. (Bryan Venteicher) +Solution: Detect missing output file. Avoid using non-existing buffer. +Files: src/diff.c + +Patch 7.2.240 +Problem: Crash when using find/replace dialog repeatedly. (Michiel + Hartsuiker) +Solution: Avoid doing the operation while busy or recursively. Also refuse + replace when text is locked. +Files: src/gui.c + +Patch 7.2.241 +Problem: When using a combination of ":bufdo" and "doautoall" we may end up + in the wrong directory. (Ajit Thakkar) + Crash when triggering an autocommand in ":vimgrep". (Yukihiro + Nakadaira) +Solution: Clear w_localdir and globaldir when using the aucmd_win. + Use a separate flag to decide aucmd_win needs to be restored. +Files: src/fileio.c, src/globals.h, src/structs.h + +Patch 7.2.242 +Problem: Setting 'lazyredraw' causes the cursor column to be recomputed. + (Tom Link) +Solution: Only recompute the cursor column for a boolean option if changes + the cursor position. +Files: src/option.c + +Patch 7.2.243 +Problem: Memory leak when using :vimgrep and resizing. (Dominique Pelle) +Solution: Free memory for aucmd_win when resizing and don't allocate it + twice. +Files: src/screen.c + +Patch 7.2.244 +Problem: When 'enc' is utf-8 and 'fenc' is latin1, writing a non-latin1 + character gives a conversion error without any hint what is wrong. +Solution: When known add the line number to the error message. +Files: src/fileio.c + +Patch 7.2.245 +Problem: When 'enc' is "utf-16" and 'fenc' is "utf-8" writing a file does + conversion while none should be done. (Yukihiro Nakadaira) When + 'fenc' is empty the file is written as utf-8 instead of utf-16. +Solution: Do proper comparison of encodings, taking into account that all + Unicode values for 'enc' use utf-8 internally. +Files: src/fileio.c + +Patch 7.2.246 +Problem: Cscope home page link is wrong. +Solution: Update the URL. (Sergey Khorev) +Files: runtime/doc/if_cscop.txt + +Patch 7.2.247 +Problem: Mzscheme interface minor problem. +Solution: Better error message when build fails. (Sergey Khorev) +Files: src/if_mzsch.c + +Patch 7.2.248 (extra) +Problem: Mzscheme interface building minor problems. +Solution: Update Win32 makefiles. (Sergey Khorev) +Files: src/Make_cyg.mak, src/Make_ming.mak, src/Make_mvc.mak + +Patch 7.2.249 +Problem: The script to check .po files can't handle '%' in plural forms. +Solution: Remove "Plural-Forms:" from the checked string. +Files: src/po/check.vim + +Patch 7.2.250 (extra) +Problem: Possible buffer overflow. +Solution: Compute the remaining space. (Dominique Pelle) +Files: src/GvimExt/gvimext.cpp + +Patch 7.2.251 (after 7.2.044) +Problem: Compiler adds invalid memory bounds check. +Solution: Remove _FORTIFY_SOURCE=2 from CFLAGS. (Dominique Pelle) +Files: src/auto/configure, src/configure.in + +Patch 7.2.252 +Problem: When using a multi-byte 'enc' the 'iskeyword' option cannot + contain characters above 128. +Solution: Use mb_ptr2char_adv(). +Files: src/charset.c + +Patch 7.2.253 +Problem: Netbeans interface: getLength always uses current buffer. +Solution: Use ml_get_buf() instead of ml_get(). (Xavier de Gaye) +Files: src/netbeans.c + +Patch 7.2.254 +Problem: Compiler warning for assigning size_t to int. +Solution: Use size_t for the variable. (George Reilly) +Files: src/fileio.c + +Patch 7.2.255 (after 7.2.242) +Problem: Setting 'rightleft', 'linebreak' and 'wrap' may cause cursor to be + in wrong place. +Solution: Recompute the cursor column for these options. +Files: src/option.c + +Patch 7.2.256 +Problem: When 'guifont' was not set GTK font dialog doesn't have a default. + (Andreas Metzler) +Solution: Set default to DEFAULT_FONT. (James Vega) +Files: src/gui_gtk_x11.c + +Patch 7.2.257 +Problem: With GTK 2.17 lots of assertion error messages. +Solution: Remove check for static gravity. (Sebastian Droege) +Files: src/gui_gtk_f.c + +Patch 7.2.258 +Problem: v:beval_col and b:beval_text are wrong in UTF-8 text. (Tony + Mechelynck) +Solution: Use byte number instead of character number for the column. +Files: src/ui.c + +Patch 7.2.259 +Problem: exists() doesn't work properly for an empty aucmd group. +Solution: Change how au_exists() handles a missing pattern. Also add a + test for this. (Bob Hiestand) +Files: src/fileio.c, src/testdir/Makefile, src/testdir/test67.in, + src/testdir/test67.ok + +Patch 7.2.260 (extra part of 7.2.259) +Problem: exists() doesn't work properly for empty aucmd group. +Solution: Change how au_exists() handles a missing pattern. Also add a + test for this. (Bob Hiestand) +Files: src/testdir/Make_amiga.mak, src/testdir/Make_dos.mak, + src/testdir/Make_ming.mak, src/testdir/Make_os2.mak, + src/testdir/Make_vms.mms + +Patch 7.2.261 +Problem: When deleting lines with a specific folding configuration E38 may + appear. (Shahaf) +Solution: When adjusting nested folds for deleted lines take into account + that they don't start at the top of the enclosing fold. +Files: src/fold.c + +Patch 7.2.262 +Problem: When using custom completion for a user command the pattern string + goes beyond the cursor position. (Hari Krishna Dara) +Solution: Truncate the string at the cursor position. +Files: src/ex_getln.c, src/structs.h + +Patch 7.2.263 +Problem: GTK2: when using the -geom argument with an offset from the right + edge and the size is smaller than the default, the Vim window is + not positioned properly. +Solution: Use another function to set the size. (Vitaly Minko) +Files: src/gui_gtk_x11.c + +Patch 7.2.264 +Problem: GTK2: When the Vim window is maximized setting 'columns' or + 'lines' doesn't work. +Solution: Unmaximize the window before setting the size. (Vitaly Minko) +Files: src/gui.c, src/gui_gtk_x11.c, src/proto/gui_gtk_x11.pro + +Patch 7.2.265 +Problem: When using ":silent broken" inside try/catch silency may persist. + (dr-dr xp) +Solution: Set msg_silent when there is an error and it's bigger than the + saved value. +Files: src/ex_docmd.c + +Patch 7.2.266 +Problem: When an expression abbreviation is triggered, the typed character + is unknown. +Solution: Make the typed character available in v:char. +Files: runtime/doc/map.txt, src/eval.c, src/getchar.c, src/ops.c, + src/proto/eval.pro + +Patch 7.2.267 +Problem: Crash for narrow window and double-width character. +Solution: Check for zero width. (Taro Muraoka) +Files: src/charset.c + +Patch 7.2.268 +Problem: Crash when using Python to set cursor beyond end of line. + (winterTTr) +Solution: Check the column to be valid. +Files: src/if_python.c + +Patch 7.2.269 +Problem: Many people struggle to find out why Vim startup is slow. +Solution: Add the --startuptime command line flag. +Files: runtime/doc/starting.txt, src/globals.h, src/feature.h, + src/main.c, src/macros.h + +Patch 7.2.270 +Problem: Using ":@c" when the c register contains a CR causes the rest to + be executed later. (Dexter Douglas) +Solution: Don't check for typeahead to start with ':', keep executing + commands until all added typeahead has been used. +Files: src/ex_docmd.c + +Patch 7.2.271 +Problem: Using freed memory in Motif GUI version when making a choice. +Solution: Free memory only after using it. (Dominique Pelle) +Files: src/gui_xmdlg.c + +Patch 7.2.272 +Problem: "_.svz" is not recognized as a swap file. (David M. Besonen) +Solution: Accept .s[uvw][a-z] as a swap file name extension. +Files: src/memline.c + +Patch 7.2.273 +Problem: Crash with redir to unknown array. (Christian Brabandt) +Solution: Don't assign the redir result when there was an error. +Files: src/eval.c + +Patch 7.2.274 +Problem: Syntax folding doesn't work properly when adding a comment. +Solution: Fix it and add a test. (Lech Lorens) +Files: src/fold.c, src/testdir/test45.in, src/testdir/test45.ok + +Patch 7.2.275 +Problem: Warning for unused argument and comparing signed and unsigned. +Solution: Add type cast. +Files: src/memline.c + +Patch 7.2.276 +Problem: Crash when setting 'isprint' to a small bullet. (Raul Coronado) +Solution: Check for the character to be < 256. Also make it possible to + specify a range of multi-byte characters. (Lech Lorens) +Files: src/charset.c + +Patch 7.2.277 +Problem: CTRL-Y in a diff'ed window may move the cursor outside of the + window. (Lech Lorens) +Solution: Limit the number of filler lines to the height of the window. + Don't reset filler lines to zero for an empty buffer. +Files: src/move.c + +Patch 7.2.278 +Problem: Using magic number in the folding code. +Solution: Use the defined MAX_LEVEL. +Files: src/fold.c + +Patch 7.2.279 +Problem: Invalid memory read with visual mode "r". (Dominique Pelle) +Solution: Make sure the cursor position is valid. Don't check the cursor + position but the position being used. And make sure we get the + right line. +Files: src/misc2.c, src/ops.c + +Patch 7.2.280 +Problem: A redraw in a custom statusline with %! may cause a crash. + (Yukihiro Nakadaira) +Solution: Make a copy of 'statusline'. Also fix typo in function name + redraw_custum_statusline. (partly by Dominique Pelle) +Files: src/screen.c + +Patch 7.2.281 +Problem: 'cursorcolumn' highlighting is wrong in diff mode. +Solution: Adjust the column computation. (Lech Lorens) +Files: src/screen.c + +Patch 7.2.282 +Problem: A fold can't be closed. +Solution: Initialize fd_small to MAYBE. (Lech Lorens) +Files: src/fold.c + +Patch 7.2.283 +Problem: Changing font while the window is maximized doesn't keep the + window maximized. +Solution: Recompute number of lines and columns after changing font. (James + Vega) +Files: src/gui_gtk_x11.c + +Patch 7.2.284 +Problem: When editing the same buffer in two windows, one with folding, + display may be wrong after changes. +Solution: Call set_topline() to take care of side effects. (Lech Lorens) +Files: src/misc1.c + +Patch 7.2.285 (after 7.2.169) +Problem: CTRL-U in Insert mode also deletes indent. (Andrey Voropaev) +Solution: Fix mistake made in patch 7.2.169. +Files: src/edit.c + +Patch 7.2.286 (after 7.2.269) +Problem: The "--startuptime=<file>" argument is not consistent with other + arguments. +Solution: Use "--startuptime <file>". Added the +startuptime feature. +Files: runtime/doc/eval.txt, runtime/doc/starting.txt, + runtime/doc/various.txt, src/eval.c, src/main.c, src/version.c + +Patch 7.2.287 +Problem: Warning from gcc 3.4 about uninitialized variable. +Solution: Move assignment outside of #ifdef. +Files: src/if_perl.xs + +Patch 7.2.288 +Problem: Python 2.6 pyconfig.h redefines macros. +Solution: Undefine the macros before including pyconfig.h. +Files: src/if_python.c + +Patch 7.2.289 +Problem: Checking wrong struct member. +Solution: Change tb_buf to tb_noremap. (Dominique Pelle) +Files: src/getchar.c + +Patch 7.2.290 +Problem: Not freeing memory from ":lmap", ":xmap" and ":menutranslate". +Solution: Free the memory when exiting. (Dominique Pelle) +Files: src/misc2.c + +Patch 7.2.291 +Problem: Reading uninitialised memory in arabic mode. +Solution: Use utfc_ptr2char_len() rather than utfc_ptr2char(). (Dominique + Pelle) +Files: src/screen.c + +Patch 7.2.292 +Problem: Block right-shift doesn't work properly with multi-byte encoding + and 'list' set. +Solution: Add the missing "else". (Lech Lorens) +Files: src/ops.c + +Patch 7.2.293 +Problem: When setting 'comments' option it may be used in a wrong way. +Solution: Don't increment after skipping over digets. (Yukihiro Nakadaira) +Files: src/misc1.c + +Patch 7.2.294 +Problem: When using TEMPDIRS dir name could get too long. +Solution: Overwrite tail instead of appending each time. Use mkdtemp() when + available. (James Vega) +Files: src/auto/configure, src/config.h.in, src/configure.in, src/fileio.c + +Patch 7.2.295 +Problem: When using map() on a List the index is not known. +Solution: Set v:key to the index. (Hari Krishna Dara) +Files: runtime/doc/eval.txt, src/eval.c + +Patch 7.2.296 +Problem: Help message about startuptime is wrong. (Dominique Pelle) +Solution: Remove the equal sign. +Files: src/main.c + +Patch 7.2.297 +Problem: Reading freed memory when writing ":reg" output to a register. + (Dominique Pelle) +Solution: Skip the register being written to. +Files: src/ops.c + +Patch 7.2.298 +Problem: ":vimgrep" crashes when there is an autocommand that sets a + window-local variable. +Solution: Initialize the w: hashtab for re-use. (Yukihiro Nakadaira) +Files: src/fileio.c + +Patch 7.2.299 +Problem: Crash when comment middle is longer than start. +Solution: Fix size computation. (Lech Lorens) +Files: src/misc1.c + +Patch 7.2.300 +Problem: Vim doesn't close file descriptors when forking and executing + another command, e.g., ":shell". +Solution: Use FD_CLOEXEC when available. (James Vega) +Files: auto/configure, src/config.h.in, src/configure.in, + src/ex_cmdds2.c, src/fileio.c, src/memfile.c, src/memline.c + +Patch 7.2.301 +Problem: Formatting is wrong when 'tw' is set to a small value. +Solution: Fix it and add tests. Also fix behavior of "1" in 'fo'. (Yukihiro + Nakadaira) +Files: src/edit.c, src/testdir/Makefile, src/testdir/test68.in, + src/testdir/test68.ok, src/testdir/test69.in, + src/testdir/test69,ok + +Patch 7.2.302 (extra part of 7.2.301) +Problem: Formatting wrong with small 'tw' value. +Solution: Add build rules for tests. +Files: src/testdir/Make_amiga.mak, src/testdir/Make_dos.mak, + src/testdir/Make_ming.mak, src/testdir/Make_os2.mak, + src/testdir/Make_vms.mms + +Patch 7.2.303 (after 7.2.294) +Problem: Can't build on MS-Windows. +Solution: Add #ifdef around vim_settempdir(). (James Vega) +Files: src/fileio.c + +Patch 7.2.304 +Problem: Compiler warning for bad pointer cast. +Solution: Use another variable for int pointer. +Files: src/ops.c + +Patch 7.2.305 +Problem: Recursively redrawing causes a memory leak. (Dominique Pelle) +Solution: Disallow recursive screen updating. +Files: src/screen.c + +Patch 7.2.306 +Problem: shellescape("10%%", 1) only escapes first %. (Christian Brabandt) +Solution: Don't copy the character after the escaped one. +Files: src/misc2.c + +Patch 7.2.307 +Problem: Crash with a very long syntax match statement. (Guy Gur Ari) +Solution: When the offset does not fit in the two bytes available give an + error instead of continuing with invalid pointers. +Files: src/regexp.c + +Patch 7.2.308 +Problem: When using a regexp in the "\=" expression of a substitute + command, submatch() returns empty strings for further lines. + (Clockwork Jam) +Solution: Save and restore the line number and line count when calling + reg_getline(). +Files: src/regexp.c + +Patch 7.2.309 (after 7.2.308) +Problem: Warning for missing function prototype. (Patrick Texier) +Solution: Add the prototype. +Files: src/regexp.c + +Patch 7.2.310 +Problem: When a filetype plugin in ~/.vim/ftdetect uses ":setfiletype" and + the file starts with a "# comment" it gets "conf" filetype. +Solution: Check for "conf" filetype after using ftdetect plugins. +Files: runtime/filetype.vim + +Patch 7.2.311 +Problem: Can't compile with FreeMiNT. +Solution: Change #ifdef for limits.h. (Alan Hourihane) +Files: src/fileio.c + +Patch 7.2.312 +Problem: iconv() returns an invalid character sequence when conversion + fails. It should return an empty string. (Yongwei Wu) +Solution: Be more strict about invalid characters in the input. +Files: src/mbyte.c + +Patch 7.2.313 +Problem: Command line completion doesn't work after "%:h" and similar. +Solution: Expand these items before doing the completion. +Files: src/ex_getln.c, src/misc1.c, src/proto/misc1.pro + +Patch 7.2.314 +Problem: Missing function in small build. +Solution: Always include concat_str. +Files: src/misc1.c + +Patch 7.2.315 +Problem: Python libs can't be found on 64 bit system. +Solution: Add lib64 to the list of directories. (Michael Henry) +Files: src/auto/configure, src/configure.in + +Patch 7.2.316 +Problem: May get multiple _FORTIFY_SOURCE arguments. (Tony Mechelynck) +Solution: First remove all these arguments and then add the one we want. + (Dominique Pelle) +Files: src/auto/configure, src/configure.in + +Patch 7.2.317 +Problem: Memory leak when adding a highlight group with unprintable + characters, resulting in E669. +Solution: Free the memory. And fix a few typos. (Dominique Pelle) +Files: src/syntax.c + +Patch 7.2.318 +Problem: Wrong locale value breaks floating point numbers for gvim. +Solution: Set the locale again after doing GUI inits. (Dominique Pelle) +Files: src/main.c + +Patch 7.2.319 +Problem: Motif: accessing freed memory when cancelling font dialog. +Solution: Destroy the widget only after accessing it. (Dominique Pelle) +Files: src/gui_xmdlg.c + +Patch 7.2.320 +Problem: Unused function in Mzscheme interface. +Solution: Remove the function and what depends on it. (Dominique Pelle) +Files: src/if_mzsch.c, src/proto/if_mzsch.pro + +Patch 7.2.321 +Problem: histadd() and searching with "*" fails to add entry to history + when it is empty. +Solution: Initialize the history. (Lech Lorens) +Files: src/eval.c, src/normal.c + +Patch 7.2.322 +Problem: Wrong indenting in virtual replace mode with CTRL-Y below a short + line. +Solution: Check for character to be NUL. (suggested by Lech Lorens) +Files: src/edit.c + +Patch 7.2.323 (extra) +Problem: Balloon evaluation crashes on Win64. +Solution: Change pointer types. (Sergey Khorev) +Files: src/gui_w32.c + +Patch 7.2.324 +Problem: A negative column argument in setpos() may cause a crash. +Solution: Check for invalid column number. (James Vega) +Files: src/eval.c, src/misc2.c + +Patch 7.2.325 +Problem: A stray "w" in the startup vimrc file causes the edited file to be + replaced with an empty file. (Stone Kang). +Solution: Do not write a buffer when it has never been loaded. +Files: src/fileio.c + +Patch 7.2.326 +Problem: Win32: $HOME doesn't work when %HOMEPATH% is not defined. +Solution: Use "\" for %HOMEPATH% when it is not defined. +Files: src/misc1.c + +Patch 7.2.327 +Problem: Unused functions in Workshop. +Solution: Add "#if 0" and minor cleanup. (Dominique Pelle) +Files: src/workshop.c, src/integration.c, src/integration.h + +Patch 7.2.328 +Problem: has("win64") does not return 1 on 64 bit MS-Windows version. +Solution: Also check for _WIN64 besides WIN64. +Files: src/eval.c + +Patch 7.2.329 +Problem: "g_" doesn't position cursor correctly when in Visual mode and + 'selection' is "exclusive". (Ben Fritz) +Solution: Call adjust_for_sel(). +Files: src/normal.c + +Patch 7.2.330 +Problem: Tables for Unicode case operators are outdated. +Solution: Add a Vim script for generating the tables. Include tables for + Unicode 5.2. +Files: runtime/tools/README.txt, runtime/tools/unicode.vim, src/mbyte.c + +Patch 7.2.331 +Problem: Can't interrupt "echo list" for a very long list. +Solution: Call line_breakcheck() in list_join(). +Files: src/eval.c + +Patch 7.2.332 +Problem: Crash when spell correcting triggers an autocommand that reloads + the buffer. +Solution: Make a copy of the line to be modified. (Dominique Pelle) +Files: src/spell.c + +Patch 7.2.333 +Problem: Warnings from static code analysis. +Solution: Small changes to various lines. (Dominique Pelle) +Files: src/buffer.c, src/edit.c, src/ex_getln.c, src/fileio.c, + src/if_cscope.c, src/netbeans.c, src/ops.c, src/quickfix.c, + src/syntax.c, src/ui.c + +Patch 7.2.334 +Problem: Postponing keys in Netbeans interface does not work properly. +Solution: Store the key string instead of the number. Avoid an infinite + loop. (Mostly by Xavier de Gaye) +Files: src/netbeans.c, src/proto/netbeans.pro + +Patch 7.2.335 +Problem: The CTRL-] command escapes too many characters. +Solution: Use a different list of characters to be escaped. (Sergey Khorev) +Files: src/normal.c + +Patch 7.2.336 +Problem: MzScheme interface can't evaluate an expression. +Solution: Add mzeval(). (Sergey Khorev) +Files: runtime/doc/eval.txt, runtime/doc/if_mzsch.txt, + runtime/doc/usr_41.txt, src/eval.c, src/if_mzsch.c, + src/proto/eval.pro, src/proto/if_mzsch.pro, + src/testdir/Make_dos.mak, src/testdir/Make_ming.mak, + src/testdir/Makefile, src/testdir/main.aap, src/testdir/test1.in, + src/testdir/test70.in, src/testdir/test70.ok + +Patch 7.2.337 +Problem: The :compiler command doesn't function properly when invoked in a + function. +Solution: Add "g:" before "current_compiler". (Yukihiro Nakadaira) +Files: src/ex_cmds2.c + +Patch 7.2.338 (after 7.2.300) +Problem: Part of FD_CLOEXEC change is missing. +Solution: Include source file skipped because of typo. +Files: src/ex_cmds2.c + +Patch 7.2.339 (after 7.2.269) +Problem: Part of --startuptime patch is missing. +Solution: Add check for time_fd. +Files: src/ex_cmds2.c + +Patch 7.2.340 +Problem: Gcc warning for condition that can never be true. (James Vega) +Solution: Use start_lvl instead flp->lvl. +Files: src/fold.c + +Patch 7.2.341 +Problem: Popup menu wraps to next line when double-wide character doesn't + fit. (Jiang Ma) +Solution: Display a ">" instead. (Dominique Pelle) +Files: src/screen.c + +Patch 7.2.342 +Problem: Popup menu displayed wrong in 'rightleft' mode when there are + multi-byte characters. +Solution: Adjust the column computations. (Dominique Pelle) +Files: src/popupmnu.c + +Patch 7.2.343 (after 7.2.338) +Problem: Can't compile on Win32. +Solution: Insert the missing '|'. +Files: src/ex_cmds2.c + +Patch 7.2.344 (after 7.2.343) +Problem: Can't compile on some systems +Solution: Move the #ifdef outside of the mch_open macro. (Patrick Texier) +Files: src/ex_cmds2.c + +Patch 7.2.345 +Problem: Tab line is not updated when the value of 'bt' is changed. +Solution: Call redraw_titles(). (Lech Lorens) +Files: src/option.c + +Patch 7.2.346 +Problem: Repeating a command with @: causes a mapping to be applied twice. +Solution: Do not remap characters inserted in the typeahead buffer. (Kana + Natsuno) +Files: src/ops.c + +Patch 7.2.347 +Problem: Crash when executing <expr> mapping redefines that same mapping. +Solution: Save the values used before evaluating the expression. +Files: src/getchar.c + +Patch 7.2.348 (after 7.2.330) +Problem: Unicode double-width characters are not up-to date. +Solution: Produce the double-width table like the others. +Files: runtime/tools/unicode.vim, src/mbyte.c + +Patch 7.2.349 +Problem: CTRL-W gf doesn't put the new tab in the same place as "tab split" + and "gf". (Tony Mechelynck) +Solution: Store the tab number in cmdmod.tab. +Files: src/window.c + +Patch 7.2.350 +Problem: Win32: When changing font the window may jump from the secondary + to the primary screen. (Michael Wookey) +Solution: When the screen position was negative don't correct it to zero. +Files: src/gui.c + +Patch 7.2.351 (after 7.2.347) +Problem: Can't build with some compilers. +Solution: Move the #ifdef outside of a macro. Cleanup the code. +Files: src/getchar.c + +Patch 7.2.352 (extra) +Problem: Win64: Vim doesn't work when cross-compiled with MingW libraries. +Solution: Always return TRUE for the WM_NCCREATE message. (Andy Kittner) +Files: src/gui_w48.c + +Patch 7.2.353 +Problem: No command line completion for ":profile". +Solution: Complete the subcommand and file name. +Files: src/ex_docmd.c, src/ex_cmds2.c, src/ex_getln.c, + src/proto/ex_cmds2.pro, src/vim.h + +Patch 7.2.354 +Problem: Japanese single-width double-byte characters not handled correctly. +Solution: Put 0x8e in ScreenLines[] and the second byte in ScreenLines2[]. + (partly by Kikuchan) +Files: src/screen.c + +Patch 7.2.355 +Problem: Computing the cursor column in validate_cursor_col() is wrong when + line numbers are used and 'n' is not in 'cpoptions', causing the + popup menu to be positioned wrong. +Solution: Correctly use the offset. (partly by Dominique Pelle) +Files: src/move.c + +Patch 7.2.356 +Problem: When 'foldmethod' is changed not all folds are closed as expected. +Solution: In foldUpdate() correct the start position and reset fd_flags when + w_foldinvalid is set. (Lech Lorens) +Files: src/fold.c + +Patch 7.2.357 +Problem: When changing 'fileformat' from/to "mac" and there is a CR in the + text the display is wrong. +Solution: Redraw the text when 'fileformat' is changed. (Ben Schmidt) +Files: src/option.c + +Patch 7.2.358 +Problem: Compiler warnings on VMS. (Zoltan Arpadffy) +Solution: Pass array itself instead its address. Return a value. +Files: src/gui_gtk_x11.c, src/os_unix.c + +Patch 7.2.359 +Problem: Crash when using the Netbeans join command. +Solution: Make sure the ml_flush_line() function is not used recursively. + (Xavier de Gaye) +Files: src/memline.c + +Patch 7.2.360 +Problem: Ruby on MS-Windows: can't use sockets. +Solution: Call NtInitialize() during initialization. (Ariya Mizutani) +Files: src/if_ruby.c + +Patch 7.2.361 +Problem: Ruby 1.9 is not supported. +Solution: Add Ruby 1.9 support. (Masaki Suketa) +Files: src/Makefile, src/auto/configure, src/configure.in, src/if_ruby.c + +Patch 7.2.362 (extra, after 7.2.352) +Problem: Win64: Vim doesn't work when cross-compiled with MingW libraries. +Solution: Instead of handling WM_NCCREATE, create wide text area window + class if the parent window iw side. (Sergey Khorev) +Files: src/gui_w32.c, src/gui_w48.c + +Patch 7.2.363 +Problem: Can't dynamically load Perl 5.10. +Solution: Add the function Perl_croak_xs_usage. (Sergey Khorev) +Files: src/if_perl.xs + +Patch 7.2.364 (extra) +Problem: Can't build gvimext.dll on Win 7 x64 using MinGW (John Marriott) +Solution: Check if _MSC_VER is defined. (Andy Kittner) +Files: src/GvimExt/gvimext.h + +Patch 7.2.365 (extra) +Problem: MS-Windows with MingW: "File->Save As" does not work. (John + Marriott) +Solution: Correctly fill in structure size. (Andy Kittner) +Files: src/gui_w48.c + +Patch 7.2.366 +Problem: CTRL-B doesn't go back to the first line of the buffer. +Solution: Avoid an overflow when adding MAXCOL. +Files: src/move.c + +Patch 7.2.367 +Problem: "xxd -r -p" doesn't work as documented. +Solution: Skip white space. (James Vega) +Files: src/xxd/xxd.c + +Patch 7.2.368 (after 7.2.361) +Problem: Ruby interface: Appending line doesn't work. (Michael Henry) +Solution: Reverse check for NULL line. (James Vega) +Files: src/if_ruby.c + +Patch 7.2.369 +Problem: Error message is not easy to understand. +Solution: Add quotes. (SungHyun Nam) +Files: src/ex_cmds2.c + +Patch 7.2.370 (after 7.2.356) +Problem: A redraw may cause folds to be closed. +Solution: Revert part of the previous patch. Add a test. (Lech Lorens) +Files: src/diff.c, src/fold.c, src/option.c, src/testdir/test45.in, + src/testdir/test45.ok + +Patch 7.2.371 +Problem: Build problems on Tandem NonStop. +Solution: A few changes to #ifdefs (Joachim Schmitz) +Files: src/auto/configure, src/configure.in, src/config.h.in, src/vim.h, + src/if_cscope.c, src/osdef1.h.in, src/tag.c + +Patch 7.2.372 (extra) +Problem: Cross-compiling GvimExt and xxd doesn't work. +Solution: Change the build files. (Markus Heidelberg) +Files: src/INSTALLpc.txt, src/GvimExt/Make_ming.mak, src/Make_cyg.mak, + src/Make_ming.mak, src/xxd/Make_cyg.mak + +Patch 7.2.373 +Problem: Gcc 4.5 adds more error messages. (Chris Indy) +Solution: Update default 'errorformat'. +Files: src/option.h + +Patch 7.2.374 +Problem: Ruby eval() doesn't understand Vim types. +Solution: Add the vim_to_ruby() function. (George Gensure) +Files: src/eval.c, src/if_ruby.c + +Patch 7.2.375 +Problem: ml_get errors when using ":bprevious" in a BufEnter autocmd. + (Dominique Pelle) +Solution: Clear w_valid when entering another buffer. +Files: src/buffer.c + +Patch 7.2.376 +Problem: ml_get error when using SiSU syntax. (Nathan Thomas) +Solution: If the match ends below the last line move it to the end of the + last line. +Files: src/syntax.c + +Patch 7.2.377 (extra, after 7.2.372) +Problem: Misplaced assignment. Duplicate build line for gvimext.dll. +Solution: Move setting CROSS_COMPILE to before ifneq. Remove the wrong + build line. (Markus Heidelberg) +Files: src/Make_ming.mak + +Patch 7.2.378 +Problem: C function declaration indented too much. (Rui) +Solution: Don't see a line containing { or } as a type. (Matt Wozniski) +Files: src/misc1.c + +Patch 7.2.379 +Problem: 'eventignore' is set to an invalid value inside ":doau". (Antony + Scriven) +Solution: Don't include the leading comma when the option was empty. +Files: src/fileio.c + +Patch 7.2.380 (after 7.2.363) +Problem: Perl interface builds with 5.10.1 but not with 5.10.0. +Solution: Change the #ifdefs. (Sergey Khorev) +Files: src/if_perl.xs + +Patch 7.2.381 +Problem: No completion for :behave. +Solution: Add :behave completion. Minor related fixes. (Dominique Pelle) +Files: src/ex_docmd.c, src/ex_getln.c, src/proto/ex_docmd.pro, src/vim.h + +Patch 7.2.382 +Problem: Accessing freed memory when closing the cmdline window when + 'bufhide' is set to "wipe". +Solution: Check if the buffer still exists before invoking close_buffer() + (Dominique Pelle) +Files: src/ex_getln.c + +Patch 7.2.383 +Problem: Vim doesn't build cleanly with MSVC 2010. +Solution: Change a few types. (George Reilly) +Files: src/ex_cmds2.c, src/if_python.c, src/syntax.c + +Patch 7.2.384 (extra) +Problem: Vim doesn't build properly with MSVC 2010. +Solution: Add the nmake version to the build file. (George Reilly) +Files: src/Make_mvc.mak, src/testdir/Make_dos.mak + +Patch 7.2.385 +Problem: When in the command line window dragging status line only works + for last-but-one window. (Jean Johner) +Solution: Remove the code that disallows this. +Files: src/ui.c + +Patch 7.2.386 +Problem: Focus hack for KDE 3.1 causes problems for other window managers. +Solution: Remove the hack. (forwarded by Joel Bradshaw) +Files: src/gui_gtk.c + +Patch 7.2.387 +Problem: Ruby with MingW still doesn't build all versions. +Solution: More #ifdefs for the Ruby code. (Sergey Khorev) +Files: src/if_ruby.c + +Patch 7.2.388 (extra part of 7.2.387) +Problem: Ruby with MingW still doesn't build all versions. +Solution: Different approach to build file. (Sergey Khorev) +Files: src/Make_ming.mak + +Patch 7.2.389 +Problem: synIDattr() cannot return the font. +Solution: Support the "font" argument. (Christian Brabandt) +Files: runtime/doc/eval.txt, src/eval.c, src/syntax.c + +Patch 7.2.390 +Problem: In some situations the popup menu can be displayed wrong. +Solution: Remove the popup menu if the cursor moved. (Lech Lorens) +Files: src/edit.c + +Patch 7.2.391 +Problem: Internal alloc(0) error when doing "CTRL-V $ c". (Martti Kuparinen) +Solution: Fix computations in getvcol(). (partly by Lech Lorens) +Files: src/charset.c, src/memline.c + +Patch 7.2.392 +Problem: Netbeans hangs reading from a socket at the maximum block size. +Solution: Use select() or poll(). (Xavier de Gaye) +Files: src/vim.h, src/os_unixx.h, src/if_xcmdsrv.c, src/netbeans.c + +Patch 7.2.393 +Problem: Mac: Can't build with different Xcode developer tools directory. +Solution: make "Developer" directory name configurable. (Rainer Muller) +Files: src/configure.in, src/auto/configure + +Patch 7.2.394 +Problem: .lzma and .xz files are not supported. +Solution: Recognize .lzma and .xz files so that they can be edited. +Files: runtime/plugin/gzip.vim + +Patch 7.2.395 +Problem: In help CTRL=] on g?g? escapes the ?, causing it to fail. (Tony + Mechelynck) +Solution: Don't escape ? for a help command. (Sergey Khorev) +Files: src/normal.c + +Patch 7.2.396 +Problem: Get E38 errors. (Dasn) +Solution: Set cursor to line 1 instead of 0. (Dominique Pelle) +Files: src/popupmnu.c + +Patch 7.2.397 +Problem: Redundant check for w_lines_valid. +Solution: Remove the if. (Lech Lorens) +Files: src/fold.c + +Patch 7.2.398 +Problem: When moving windows the cursor ends up in the wrong line. +Solution: Set the window width and height properly. (Lech Lorens) +Files: src/window.c + +Patch 7.2.399 (extra, after 7.2.388) +Problem: Cannot compile on MingW. +Solution: Move ifneq to separate line. (Vlad Sandrini, Dominique Pelle) +Files: src/Make_ming.mak + +Patch 7.2.400 (after 7.2.387) +Problem: Dynamic Ruby is not initialised properly for version 1.9.1. + Ruby cannot create strings from NULL. +Solution: Cleanup #ifdefs. Handle NULL like an empty string. Add + ruby_init_stack. (Sergey Khorev) +Files: src/if_ruby.c + +Patch 7.2.401 +Problem: ":e dir<Tab>" with 'wildmode' set to "list" doesn't highlight + directory names with a space. (Alexandre Provencio) +Solution: Remove the backslash before checking if the name is a directory. + (Dominique Pelle) +Files: src/ex_getln.c + +Patch 7.2.402 +Problem: This gives a #705 error: let X = function('haslocaldir') + let X = function('getcwd') +Solution: Don't give E705 when the name is found in the hashtab. (Sergey + Khorev) +Files: src/eval.c + +Patch 7.2.403 (after 7.2.400) +Problem: Compiler warning for pointer type. (Tony Mechelynck) +Solution: Move type cast to the right place. +Files: src/if_ruby.c + +Patch 7.2.404 +Problem: Pointers for composing characters are not properly initialized. +Solution: Compute the size of the pointer, not what it points to. (Yukihiro + Nakadaira) +Files: src/screen.c + +Patch 7.2.405 +Problem: When built with small features the matching text is not + highlighted for ":s/pat/repl/c". +Solution: Remove the #ifdef for IncSearch. (James Vega) +Files: src/syntax.c + +Patch 7.2.406 +Problem: Patch 7.2.119 introduces uninit mem read. (Dominique Pelle) +Solution: Only used ScreeenLinesC when ScreeenLinesUC is not zero. (Yukihiro + Nakadaira) Also clear ScreeenLinesC when allocating. +Files: src/screen.c + +Patch 7.2.407 +Problem: When using an expression in ":s" backslashes in the result are + dropped. (Sergey Goldgaber, Christian Brabandt) +Solution: Double backslashes. +Files: src/regexp.c + +Patch 7.2.408 +Problem: With ":g/the/s/foo/bar/" the '[ and '] marks can be set to a line + that was not changed. +Solution: Only set '[ and '] marks when a substitution was done. +Files: src/ex_cmds.c + +Patch 7.2.409 +Problem: Summary of number of substitutes is incorrect for ":folddo". (Jean + Johner) +Solution: Reset sub_nsubs and sub_nlines in global_exe(). +Files: src/ex_cmds.c + +Patch 7.2.410 +Problem: Highlighting directories for completion doesn't work properly. +Solution: Don't halve backslashes when not needed, expanded "~/". + (Dominique Pelle) +Files: src/ex_getln.c + +Patch 7.2.411 +Problem: When parsing 'cino' a comma isn't skipped properly. +Solution: Skip the comma. (Lech Lorens) +Files: src/misc1.c + +Patch 7.2.412 +Problem: [ or ] followed by mouse click doesn't work. +Solution: Reverse check for key being a mouse event. (Dominique Pelle) +Files: src/normal.c + +Patch 7.2.413 +Problem: Large file support is incorrect. +Solution: Add AC_SYS_LARGEFILE to configure. (James Vega) +Files: src/configure.in, src/config.h.in, src/auto/configure + +Patch 7.2.414 +Problem: CTRK-K <space> <space> does not produce 0xa0 as expected. (Tony + Mechelynck) +Solution: Remove the Unicode range 0xe000 - 0xefff from digraphs, these are + not valid characters. +Files: src/digraph.c + +Patch 7.2.415 +Problem: Win32: Can't open a remote file when starting Vim. +Solution: Don't invoke cygwin_conv_path() for URLs. (Tomoya Adachi) +Files: src/main.c + +Patch 7.2.416 +Problem: Logtalk.dict is not installed. +Solution: Add it to the install target. (Markus Heidelberg) +Files: src/Makefile + +Patch 7.2.417 +Problem: When 'shell' has an argument with a slash then 'shellpipe' is not + set properly. (Britton Kerin) +Solution: Assume there are no spaces in the path, arguments follow. +Files: src/option.c + +Patch 7.2.418 +Problem: Vim tries to set the background or foreground color in a terminal + to -1. (Graywh) Happens with ":hi Normal ctermbg=NONE". +Solution: When resetting the foreground or background color don't set the + color, let the clear screen code do that. +Files: src/syntax.c + +Patch 7.2.419 +Problem: Memory leak in Motif when clicking on "Search Vim Help". +Solution: Free string returned by XmTextGetString(). (Dominique Pelle) +Files: src/gui_motif.c + +Patch 7.2.420 +Problem: ":argedit" does not accept "++enc=utf8" as documented. (Dominique + Pelle) +Solution: Add the ARGOPT flag to ":argedit". +Files: src/ex_cmds.h + +Patch 7.2.421 +Problem: Folds are sometimes not updated properly and there is no way to + force an update. +Solution: Make "zx" and "zX" recompute folds (suggested by Christian + Brabandt) +Files: src/normal.c + +Patch 7.2.422 +Problem: May get E763 when using spell dictionaries. +Solution: Avoid utf-8 case folded character to be truncated to 8 bits and + differ from latin1. (Dominique Pelle) +Files: src/spell.c + +Patch 7.2.423 +Problem: Crash when assigning s: to variable. (Yukihiro Nakadaira) +Solution: Make ga_scripts contain pointer to scriptvar_T instead of + scriptvar_T itself. (Dominique Pelle) +Files: src/eval.c + +Patch 7.2.424 +Problem: ":colorscheme" without an argument doesn't do anything. +Solution: Make it echo the current color scheme name. (partly by Christian + Brabandt) +Files: runtime/doc/syntax.txt, src/ex_cmds.h, src/ex_docmd.c + +Patch 7.2.425 +Problem: Some compilers complain about fourth EX() argument. +Solution: Add cast to long_u. +Files: src/ex_cmds.h + +Patch 7.2.426 +Problem: Commas in 'langmap' are not always handled correctly. +Solution: Require commas to be backslash escaped. (James Vega) +Files: src/option.c + +Patch 7.2.427 +Problem: The swapfile is created using the destination of a symlink, but + recovery doesn't follow symlinks. +Solution: When recovering, resolve symlinks. (James Vega) +Files: src/memline.c + +Patch 7.2.428 +Problem: Using setqflist([]) to clear the error list doesn't work properly. +Solution: Set qf_nonevalid to TRUE when appropriate. (Christian Brabandt) +Files: src/quickfix.c + +Patch 7.2.429 +Problem: A file that exists but access is denied may result in a "new file" + message. E.g. when its directory is unreadable. +Solution: Specifically check for ENOENT to decide a file doesn't exist. + (partly by James Vega) +Files: src/fileio.c + +Patch 7.2.430 +Problem: The ++bad argument is handled wrong, resulting in an invalid + memory access. +Solution: Use the bad_char field only for the replacement character, add + bad_char_idx to store the position. (Dominique Pelle) +Files: src/eval.c, src/ex_cmds.h, src/ex_docmd.c + +Patch 7.2.431 +Problem: ":amenu" moves the cursor when in Insert mode. +Solution: Use CTRL-\ CTRL-O instead of CTRL-O. (Christian Brabandt) +Files: src/menu.c + +Patch 7.2.432 +Problem: When menus are translated they can only be found by the translated + name. That makes ":emenu" difficult to use. +Solution: Store the untranslated name and use it for completion and :emenu. + (Liang Peng (Bezetek James), Edward L. Fox) +Files: src/menu.c, src/structs.h + +Patch 7.2.433 +Problem: Can't use cscope with QuickFixCmdPre and QuickFixCmdPost. +Solution: Add cscope support for these autocmd events. (Bryan Venteicher) +Files: runtime/doc/autocmd.txt, src/if_cscope.c + +Patch 7.2.434 (after 7.2.432) +Problem: Compilation fails without the multi-lang feature. +Solution: Add #ifdefs. (John Marriott) +Files: src/menu.c + +Patch 7.2.435 (after 7.2.430) +Problem: Crash when using bad_char_idx uninitialized. (Patrick Texier) +Solution: Don't use bad_char_idx, reproduce the ++bad argument from bad_char. +Files: src/eval.c, src/ex_cmds.h, src/ex_docmd.c + +Patch 7.2.436 +Problem: Reproducible crash in syntax HL. (George Reilly, Dominique Pelle) +Solution: Make sst_stacksize an int instead of short. (Dominique Pelle) +Files: src/structs.h + +Patch 7.2.437 (after 7.2.407) +Problem: When "\\\n" appears in the expression result the \n doesn't result + in a line break. (Andy Wokula) +Solution: Also replace a \n after a backslash into \r. +Files: src/regexp.c + +Patch 7.2.438 (after 7.2.427) +Problem: "vim -r" crashes. +Solution: Don't use NULL pointer argument. +Files: src/memline.c + +Patch 7.2.439 +Problem: Invalid memory access when doing thesaurus completion and + 'infercase' is set. +Solution: Use the minimal length of completed word and replacement. + (Dominique Pelle) +Files: src/edit.c + +Patch 7.2.440 +Problem: Calling a function through a funcref, where the function deletes + the funcref, leads to an invalid memory access. +Solution: Make a copy of the function name. (Lech Lorens) +Files: src/eval.c, src/testdir/test34.in, src/testdir/test34.ok + +Patch 7.2.441 +Problem: When using ":earlier" undo information may be wrong. +Solution: When changing alternate branches also adjust b_u_oldhead. +Files: src/undo.c + +Patch 7.2.442 (after 7.2.201) +Problem: Copy/paste with OpenOffice doesn't work. +Solution: Do not offer the HTML target when it is not supported. (James + Vega) +Files: src/gui_gtk_x11.c, src/option.c, src/proto/gui_gtk_x11.pro + +Patch 7.2.443 +Problem: Using taglist() on a tag file with duplicate fields generates an + internal error. (Peter Odding) +Solution: Check for duplicate field names. +Files: src/eval.c, src/proto/eval.pro, src/tag.c + +Patch 7.2.444 (after 7.2.442) +Problem: Can't build with GTK 1, gtk_selection_clear_targets() is not + available. (Patrick Texier) +Solution: Don't change the targets for GTK 1, set them once. +Files: src/gui_gtk_x11.c, src/option.c + +Patch 7.2.445 +Problem: Crash when using undo/redo and a FileChangedRO autocmd event that + reloads the buffer. (Dominique Pelle) +Solution: Do not allow autocommands while performing and undo or redo. +Files: src/misc1.c, src/undo.c + +Patch 7.2.446 +Problem: Crash in GUI when closing the last window in a tabpage. (ryo7000) +Solution: Remove the tabpage from the list before freeing the window. +Files: src/window.c + +When writing a file, switching tab pages and selecting a word the file write +message would be displayed again. This happened in Insert mode and with +'cmdheight' set to 2. + +When using ":lang" to set a locale that uses a comma for decimal separator and +using GTK floating point numbers stop working. Use gtk_disable_setlocale(). +(James Vega) + +"g8" didn't produce the right value on a NUL. (Dominique Pelle) + +Use BASEMODLIBS instead of MODLIBS for Python configuration to pick up the +right compiler flags. (Michael Bienia) + +Window title was not updated after dropping a file on Vim. (Hari G) + +synstack() did not return anything when just past the end of the line. Useful +when using the cursor position in Insert mode. + +When entering a digraph or special character after a line that fits the window +the '?' or '^' on the next line is not redrawn. (Ian Kelling) + +Composing characters in |:s| substitute text were dropped. + +|exists()| was causing an autoload script to be loaded. + +Filter out -pthread for cproto. + +Make CTRL-L in command line mode respect 'ignorecase' and 'smartcase'. (Martin +Toft) + +Spell menu moved the cursor, causing Copy not to work. Spell replacement +didn't work in 'compatible' mode. + +Various small fixes from Dominique Pelle. + +Fix that :mksession may generate "2argu" even though there is no such +argument. (Peter Odding) + +Fixes for time in clipboard request. Also fix ownership. (David Fries) + +Fixed completion of file names with '%' and '*'. + +Fixed MSVC makefile use of /Wp64 flag. + +Correct use of long instead of off_t for file size. (James Vega) + +Add a few #ifdefs to exclude functions that are not used. (Dominique Pelle) + +Remove old and unused method to allocate memory for undo. + +Fix definition of UINT_PTR for 64 bit systems. + +Some versions of Ruby redefine rb_str_new2 to rb_str_new_cstr. + +Window title not updated after file dropped. + +Fixed crash for ":find" completion, might also happen in other path expansion +usage. + +When 'searchhl' causes a hang make CTRL-C disable 'searchhl'. + +When resetting both 'title' and 'icon' the title would be set after a shell +command. + +Reset 'title' and 'icon' in test47 to avoid the xterm title getting messed up. + +Fix for compiler warning about function prototype in pty.c. + +Added 'window' to the options window. + +Fixed: errors for allocating zero bytes when profiling an empty function. + +Remove -arch flag from build flags for Perl. (Bjorn Wickler) + +Fix 'autochdir' not showing up in :options window. (Dominique Pelle) + +Fix: test 69 didn't work on MS-Windows. Test 72 beeped too often. + +Avoid illegal memory access in spell suggestion. (Dominique Pelle) +Fix: crash in spell checking with a 0x300 character. + +Avoid that running tests changes viminfo. + +Fix: changing case of a character removed combining characters. +Fixed: CTRL-R in Insert mode doesn't insert composing characters. + +Added the WOW64 flag to OLE registration, for 64 bit Windows systems. + +Various fixes for coverity warnings. + +Fix compile warnings, esp. for 64-bit systems. (Mike Williams) + +Fix: :redir to a dictionary that is changed before ":redir END" causes a +memory access error. + +Fix: terminal title not properly restored when there are multi-byte +characters. (partly by James Vega) + +Set 'wrapscan' when checking the .po files. (Mike Williams) + +Win32: Put quotes around the gvim.exe path for the "Open with" menu entry. + +On MS-Windows sometimes files with number 4913 or higher are left behind. + +'suffixesadd' was used for finding tags file. + +Removed unused code. + +Improved positioning of combining characters in GTK. + +Made test 11 pass when there is no gzip program. (John Beckett) + +Changed readfile() to ignore byte order marks, unless in binary mode. + +On MS-Windows completion of shell commands didn't work. + +An unprintable multi-byte character at the start of the screen line caused the +following text to be drawn at the wrong position. + +Got ml_get errors when using undo with 'virtualedit'. + +Call gui_mch_update() before triggering GuiEnter autocmd. (Ron Aaron) + +Unix "make install" installed a few Amiga .info files. + +Disallow setting 'ambiwidth' to "double" when 'listchars' or 'fillchars' +contains a character that would become double width. + +Set 'wrapscan' when checking the .po files. (Mike Williams) + +Fixed: using expression in command line may cause a crash. + +Avoid warnings from the clang compiler. (Dominique Pelle) + +Fix: Include wchar.h in charset.c for towupper(). + +Fixed: Using ":read file" in an empty buffer when 'compatible' is set caused +an error. Was caused by patch 7.2.132. + +Make the references to features in the help more consistent. (Sylvain Hitier) + + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/vi_diff.txt b/share/vim/vim73/doc/vi_diff.txt new file mode 100644 index 0000000000..5d6706b5d7 --- /dev/null +++ b/share/vim/vim73/doc/vi_diff.txt @@ -0,0 +1,1009 @@ +*vi_diff.txt* For Vim version 7.3. Last change: 2010 Jul 20 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + +Differences between Vim and Vi *vi-differences* + +Throughout the help files differences between Vim and Vi/Ex are given in +curly braces, like "{not in Vi}". This file only lists what has not been +mentioned in other files and gives an overview. + +Vim is mostly POSIX 1003.2-1 compliant. The only command known to be missing +is ":open". There are probably a lot of small differences (either because Vim +is missing something or because Posix is beside the mark). + +1. Simulated command |simulated-command| +2. Missing options |missing-options| +3. Limits |limits| +4. The most interesting additions |vim-additions| +5. Other vim features |other-features| +6. Command-line arguments |cmdline-arguments| +7. POSIX compliance |posix-compliance| + +============================================================================== +1. Simulated command *simulated-command* + +This command is in Vi, but Vim only simulates it: + + *:o* *:op* *:open* +:[range]o[pen] Works like |:visual|: end Ex mode. + {Vi: start editing in open mode} + +:[range]o[pen] /pattern/ As above, additionally move the cursor to the + column where "pattern" matches in the cursor + line. + +Vim does not support open mode, since it's not really useful. For those +situations where ":open" would start open mode Vim will leave Ex mode, which +allows executing the same commands, but updates the whole screen instead of +only one line. + +============================================================================== +2. Missing options *missing-options* + +These options are in the Unix Vi, but not in Vim. If you try to set one of +them you won't get an error message, but the value is not used and cannot be +printed. + +autoprint (ap) boolean (default on) *'autoprint'* *'ap'* +beautify (bf) boolean (default off) *'beautify'* *'bf'* +flash (fl) boolean (default ??) *'flash'* *'fl'* +graphic (gr) boolean (default off) *'graphic'* *'gr'* +hardtabs (ht) number (default 8) *'hardtabs'* *'ht'* + number of spaces that a <Tab> moves on the display +mesg boolean (default on) *'mesg'* +novice boolean (default off) *'novice'* +open boolean (default on) *'open'* +optimize (op) boolean (default off) *'optimize'* *'op'* +redraw boolean (default off) *'redraw'* +slowopen (slow) boolean (default off) *'slowopen'* *'slow'* +sourceany boolean (default off) *'sourceany'* +w300 number (default 23) *'w300'* +w1200 number (default 23) *'w1200'* +w9600 number (default 23) *'w9600'* + +============================================================================== +3. Limits *limits* + +Vim has only a few limits for the files that can be edited {Vi: can not handle +<Nul> characters and characters above 128, has limited line length, many other +limits}. + *E340* +Maximum line length On machines with 16-bit ints (Amiga and MS-DOS real + mode): 32767, otherwise 2147483647 characters. + Longer lines are split. +Maximum number of lines 2147483647 lines. +Maximum file size 2147483647 bytes (2 Gbyte) when a long integer is + 32 bits. Much more for 64 bit longs. Also limited + by available disk space for the |swap-file|. + *E75* +Length of a file path Unix and Win32: 1024 characters, otherwise 256 + characters (or as much as the system supports). +Length of an expanded string option + Unix and Win32: 1024 characters, otherwise 256 + characters +Maximum display width Unix and Win32: 1024 characters, otherwise 255 + characters +Maximum lhs of a mapping 50 characters. +Number of different highlighting types: over 30000 +Range of a Number variable: -2147483648 to 2147483647 (more on 64 bit + systems) + +Information for undo and text in registers is kept in memory, thus when making +(big) changes the amount of (virtual) memory available limits the number of +undo levels and the text that can be kept in registers. Other things are also +kept in memory: Command-line history, error messages for Quickfix mode, etc. + +Memory usage limits +------------------- + +The option 'maxmem' ('mm') is used to set the maximum memory used for one +buffer (in kilobytes). 'maxmemtot' is used to set the maximum memory used for +all buffers (in kilobytes). The defaults depend on the system used. For the +Amiga and MS-DOS, 'maxmemtot' is set depending on the amount of memory +available. +These are not hard limits, but tell Vim when to move text into a swap file. +If you don't like Vim to swap to a file, set 'maxmem' and 'maxmemtot' to a +very large value. The swap file will then only be used for recovery. If you +don't want a swap file at all, set 'updatecount' to 0, or use the "-n" +argument when starting Vim. + +============================================================================== +4. The most interesting additions *vim-additions* + +Vi compatibility. |'compatible'| + Although Vim is 99% Vi compatible, some things in Vi can be + considered to be a bug, or at least need improvement. But still, Vim + starts in a mode which behaves like the "real" Vi as much as possible. + To make Vim behave a little bit better, try resetting the 'compatible' + option: + :set nocompatible + Or start Vim with the "-N" argument: + vim -N + Vim starts with 'nocompatible' automatically if you have a .vimrc + file. See |startup|. + The 'cpoptions' option can be used to set Vi compatibility on/off for + a number of specific items. + +Support for different systems. + Vim can be used on: + - All Unix systems (it works on all systems it was tested on, although + the GUI and Perl interface may not work everywhere). + - Amiga (500, 1000, 1200, 2000, 3000, 4000, ...). + - MS-DOS in real-mode (no additional drivers required). + - In protected mode on Windows 3.1 and MS-DOS (DPMI driver required). + - Windows 95 and Windows NT, with support for long file names. + - OS/2 (needs emx.dll) + - Atari MiNT + - VMS + - BeOS + - Macintosh + - Risc OS + - IBM OS/390 + Note that on some systems features need to be disabled to reduce + resource usage, esp. on MS-DOS. For some outdated systems you need to + use an older Vim version. + +Multi level undo. |undo| + 'u' goes backward in time, 'CTRL-R' goes forward again. Set option + 'undolevels' to the number of changes to be remembered (default 1000). + Set 'undolevels' to 0 for a vi-compatible one level undo. Set it to + -1 for no undo at all. + When all changes in a buffer have been undone, the buffer is not + considered changed anymore. You can exit it with :q, without <!>. + When undoing a few changes and then making a new change Vim will + create a branch in the undo tree. This means you can go back to any + state of the text, there is no risk of a change causing text to be + lost forever. |undo-tree| + +Graphical User Interface (GUI). |gui| + Included support for GUI: menu's, mouse, scrollbars, etc. You can + define your own menus. Better support for CTRL/SHIFT/ALT keys in + combination with special keys and mouse. Supported for various + platforms, such as X11 (with Motif and Athena interfaces), GTK, Win32 + (Windows 95 and later), BeOS, Amiga and Macintosh. + +Multiple windows and buffers. |windows.txt| + Vim can split the screen into several windows, each editing a + different buffer or the same buffer at a different location. Buffers + can still be loaded (and changed) but not displayed in a window. This + is called a hidden buffer. Many commands and options have been added + for this facility. + Vim can also use multiple tab pages, each with one or more windows. A + line with tab labels can be used to quickly switch between these pages. + |tab-page| + +Syntax highlighting. |:syntax| + Vim can highlight keywords, patterns and other things. This is + defined by a number of |:syntax| commands, and can be made to + highlight most languages and file types. A number of files are + included for highlighting the most common languages, like C, C++, + Java, Pascal, Makefiles, shell scripts, etc. The colors used for + highlighting can be defined for ordinary terminals, color terminals + and the GUI with the |:highlight| command. A convenient way to do + this is using a |:colorscheme| command. + The highlighted text can be exported as HTML. |convert-to-HTML| + Other items that can be highlighted are matches with the search string + |'hlsearch'|, matching parens |matchparen| and the cursor line and + column |'cursorline'| |'cursorcolumn'|. + +Spell checking. |spell| + When the 'spell' option is set Vim will highlight spelling mistakes. + About 40 languages are currently supported, selected with the + 'spelllang' option. In source code only comments and strings are + checked for spelling. + +Folding. |folding| + A range of lines can be shown as one "folded" line. This allows + overviewing a file and moving blocks of text around quickly. + Folds can be created manually, from the syntax of the file, by indent, + etc. + +Diff mode. |diff| + Vim can show two versions of a file with the differences highlighted. + Parts of the text that are equal are folded away. Commands can be + used to move text from one version to the other. + +Plugins. |add-plugin| + The functionality can be extended by dropping a plugin file in the + right directory. That's an easy way to start using Vim scripts + written by others. Plugins can be for all kind of files, or + specifically for a filetype. + +Repeat a series of commands. |q| + "q{c}" starts recording typed characters into named register {c}. + A subsequent "q" stops recording. The register can then be executed + with the "@{c}" command. This is very useful to repeat a complex + action. + +Flexible insert mode. |ins-special-special| + The arrow keys can be used in insert mode to move around in the file. + This breaks the insert in two parts as far as undo and redo is + concerned. + + CTRL-O can be used to execute a single Normal mode command. This is + almost the same as hitting <Esc>, typing the command and doing |a|. + +Visual mode. |Visual-mode| + Visual mode can be used to first highlight a piece of text and then + give a command to do something with it. This is an (easy to use) + alternative to first giving the operator and then moving to the end of + the text to be operated upon. + |v| and |V| are used to start Visual mode. |v| works on characters + and |V| on lines. Move the cursor to extend the Visual area. It is + shown highlighted on the screen. By typing "o" the other end of the + Visual area can be moved. The Visual area can be affected by an + operator: + d delete + c change + y yank + > or < insert or delete indent + ! filter through external program + = filter through indent + : start |:| command for the Visual lines. + gq format text to 'textwidth' columns + J join lines + ~ swap case + u make lowercase + U make uppercase + +Block operators. |visual-block| + With Visual mode a rectangular block of text can be selected. Start + Visual mode with CTRL-V. The block can be deleted ("d"), yanked ("y") + or its case can be changed ("~", "u" and "U"). A deleted or yanked + block can be put into the text with the "p" and "P" commands. + +Help system. |:help| + Help is displayed in a window. The usual commands can be used to + move around, search for a string, etc. Tags can be used to jump + around in the help files, just like hypertext links. The |:help| + command takes an argument to quickly jump to the info on a subject. + <F1> is the quick access to the help system. The name of the help + index file can be set with the 'helpfile' option. + +Command-line editing and history. |cmdline-editing| + You can insert or delete at any place in the command-line using the + cursor keys. The right/left cursor keys can be used to move + forward/backward one character. The shifted right/left cursor keys + can be used to move forward/backward one word. CTRL-B/CTRL-E can be + used to go to the begin/end of the command-line. + |cmdline-history| + The command-lines are remembered. The up/down cursor keys can be used + to recall previous command-lines. The 'history' option can be set to + the number of lines that will be remembered. There is a separate + history for commands and for search patterns. + +Command-line completion. |cmdline-completion| + While entering a command-line (on the bottom line of the screen) + <Tab> can be typed to complete + what example ~ + - command :e<Tab> + - tag :ta scr<Tab> + - option :set sc<Tab> + - option value :set hf=<Tab> + - file name :e ve<Tab> + - etc. + + If there are multiple matches, CTRL-N (next) and CTRL-P (previous) + will walk through the matches. <Tab> works like CTRL-N, but wraps + around to the first match. + + The 'wildchar' option can be set to the character for command-line + completion, <Tab> is the default. CTRL-D can be typed after an + (incomplete) wildcard; all matches will be listed. CTRL-A will insert + all matches. CTRL-L will insert the longest common part of the + matches. + +Insert-mode completion. |ins-completion| + In Insert mode the CTRL-N and CTRL-P keys can be used to complete a + word that appears elsewhere. |i_CTRL-N| + With CTRL-X another mode is entered, through which completion can be + done for: + |i_CTRL-X_CTRL-F| file names + |i_CTRL-X_CTRL-K| words from 'dictionary' files + |i_CTRL-X_CTRL-T| words from 'thesaurus' files + |i_CTRL-X_CTRL-I| words from included files + |i_CTRL-X_CTRL-L| whole lines + |i_CTRL-X_CTRL-]| words from the tags file + |i_CTRL-X_CTRL-D| definitions or macros + |i_CTRL-X_CTRL-O| Omni completion: clever completion + specifically for a file type + etc. + +Long line support. |'wrap'| |'linebreak'| + If the 'wrap' option is off, long lines will not wrap and only part + of them will be shown. When the cursor is moved to a part that is not + shown, the screen will scroll horizontally. The minimum number of + columns to scroll can be set with the 'sidescroll' option. The |zh| + and |zl| commands can be used to scroll sideways. + Alternatively, long lines are broken in between words when the + 'linebreak' option is set. This allows editing a single-line + paragraph conveniently (e.g. when the text is later read into a DTP + program). Move the cursor up/down with the |gk| and |gj| commands. + +Text formatting. |formatting| + The 'textwidth' option can be used to automatically limit the line + length. This supplements the 'wrapmargin' option of Vi, which was not + very useful. The |gq| operator can be used to format a piece of text + (for example, |gqap| formats the current paragraph). Commands for + text alignment: |:center|, |:left| and |:right|. + +Extended search patterns. |pattern| + There are many extra items to match various text items. Examples: + A "\n" can be used in a search pattern to match a line break. + "x\{2,4}" matches "x" 2 to 4 times. + "\s" matches a white space character. + +Directory, remote and archive browsing. |netrw| + Vim can browse the file system. Simply edit a directory. Move around + in the list with the usual commands and press <Enter> to go to the + directory or file under the cursor. + This also works for remote files over ftp, http, ssh, etc. + Zip and tar archives can also be browsed. |tar| |zip| + +Edit-compile-edit speedup. |quickfix| + The |:make| command can be used to run the compilation and jump to the + first error. A file with compiler error messages is interpreted. Vim + jumps to the first error. + + Each line in the error file is scanned for the name of a file, line + number and error message. The 'errorformat' option can be set to a + list of scanf-like strings to handle output from many compilers. + + The |:cn| command can be used to jump to the next error. + |:cl| lists all the error messages. Other commands are available. + The 'makeef' option has the name of the file with error messages. + The 'makeprg' option contains the name of the program to be executed + with the |:make| command. + The 'shellpipe' option contains the string to be used to put the + output of the compiler into the errorfile. + +Finding matches in files. |:vimgrep| + Vim can search for a pattern in multiple files. This uses the + advanced Vim regexp pattern, works on all systems and also works to + search in compressed files. + +Improved indenting for programs. |'cindent'| + When the 'cindent' option is on the indent of each line is + automatically adjusted. C syntax is mostly recognized. The indent + for various styles can be set with 'cinoptions'. The keys to trigger + indenting can be set with 'cinkeys'. + + Comments can be automatically formatted. The 'comments' option can be + set to the characters that start and end a comment. This works best + for C code, but also works for e-mail (">" at start of the line) and + other types of text. The |=| operator can be used to re-indent + lines. + + For many other languages an indent plugin is present to support + automatic indenting. |30.3| + +Searching for words in included files. |include-search| + The |[i| command can be used to search for a match of the word under + the cursor in the current and included files. The 'include' option + can be set to a pattern that describes a command to include a file + (the default is for C programs). + The |[I| command lists all matches, the |[_CTRL-I| command jumps to + a match. + The |[d|, |[D| and |[_CTRL-D| commands do the same, but only for + lines where the pattern given with the 'define' option matches. + +Automatic commands. |autocommand| + Commands can be automatically executed when reading a file, writing a + file, jumping to another buffer, etc., depending on the file name. + This is useful to set options and mappings for C programs, + documentation, plain text, e-mail, etc. This also makes it possible + to edit compressed files. + +Scripts and Expressions. |expression| + Commands have been added to form up a powerful script language. + |:if| Conditional execution, which can be used for example + to set options depending on the value of $TERM. + |:while| Repeat a number of commands. + |:for| Loop over a list. + |:echo| Print the result of an expression. + |:let| Assign a value to an internal variable, option, etc. + Variable types are Number, String, List and Dictionary. + |:execute| Execute a command formed by an expression. + |:try| Catch exceptions. + etc., etc. See |eval|. + Debugging and profiling are supported. |debug-scripts| |profile| + If this is not enough, an interface is provided to |Python|, |Ruby|, + |Tcl|, |Lua|, |Perl| and |MzScheme|. + +Viminfo. |viminfo-file| + The command-line history, marks and registers can be stored in a file + that is read on startup. This can be used to repeat a search command + or command-line command after exiting and restarting Vim. It is also + possible to jump right back to where the last edit stopped with |'0|. + The 'viminfo' option can be set to select which items to store in the + .viminfo file. This is off by default. + +Printing. |printing| + The |:hardcopy| command sends text to the printer. This can include + syntax highlighting. + +Mouse support. |mouse-using| + The mouse is supported in the GUI version, in an xterm for Unix, for + BSDs with sysmouse, for Linux with gpm, for MS-DOS, and Win32. It + can be used to position the cursor, select the visual area, paste a + register, etc. + +Usage of key names. |<>| |key-notation| + Special keys now all have a name like <Up>, <End>, etc. + This name can be used in mappings, to make it easy to edit them. + +Editing binary files. |edit-binary| + Vim can edit binary files. You can change a few characters in an + executable file, without corrupting it. Vim doesn't remove NUL + characters (they are represented as <NL> internally). + |-b| command-line argument to start editing a binary file + |'binary'| Option set by |-b|. Prevents adding an <EOL> for the + last line in the file. + +Multi-language support. |multi-lang| + Files in double-byte or multi-byte encodings can be edited. There is + UTF-8 support to be able to edit various languages at the same time, + without switching fonts. |UTF-8| + Messages and menus are available in different languages. + +Move cursor beyond lines. + When the 'virtualedit' option is set the cursor can move all over the + screen, also where there is no text. This is useful to edit tables + and figures easily. + +============================================================================== +5. Other vim features *other-features* + +A random collection of nice extra features. + + +When Vim is started with "-s scriptfile", the characters read from +"scriptfile" are treated as if you typed them. If end of file is reached +before the editor exits, further characters are read from the console. + +The "-w" option can be used to record all typed characters in a script file. +This file can then be used to redo the editing, possibly on another file or +after changing some commands in the script file. + +The "-o" option opens a window for each argument. "-o4" opens four windows. + +Vi requires several termcap entries to be able to work full-screen. Vim only +requires the "cm" entry (cursor motion). + + +In command mode: + +When the 'showcmd' option is set, the command characters are shown in the last +line of the screen. They are removed when the command is finished. + +If the 'ruler' option is set, the current cursor position is shown in the +last line of the screen. + +"U" still works after having moved off the last changed line and after "u". + +Characters with the 8th bit set are displayed. The characters between '~' and +0xa0 are displayed as "~?", "~@", "~A", etc., unless they are included in the +'isprint' option. + +"][" goes to the next ending of a C function ('}' in column 1). +"[]" goes to the previous ending of a C function ('}' in column 1). + +"]f", "[f" and "gf" start editing the file whose name is under the cursor. +CTRL-W f splits the window and starts editing the file whose name is under +the cursor. + +"*" searches forward for the identifier under the cursor, "#" backward. +"K" runs the program defined by the 'keywordprg' option, with the identifier +under the cursor as argument. + +"%" can be preceded with a count. The cursor jumps to the line that +percentage down in the file. The normal "%" function to jump to the matching +brace skips braces inside quotes. + +With the CTRL-] command, the cursor may be in the middle of the identifier. + +The used tags are remembered. Commands that can be used with the tag stack +are CTRL-T, ":pop" and ":tag". ":tags" lists the tag stack. + +The 'tags' option can be set to a list of tag file names. Thus multiple +tag files can be used. For file names that start with "./", the "./" is +replaced with the path of the current file. This makes it possible to use a +tags file in the same directory as the file being edited. + +Previously used file names are remembered in the alternate file name list. +CTRL-^ accepts a count, which is an index in this list. +":files" command shows the list of alternate file names. +"#<N>" is replaced with the <N>th alternate file name in the list. +"#<" is replaced with the current file name without extension. + +Search patterns have more features. The <NL> character is seen as part of the +search pattern and the substitute string of ":s". Vi sees it as the end of +the command. + +Searches can put the cursor on the end of a match and may include a character +offset. + +Count added to "~", ":next", ":Next", "n" and "N". + +The command ":next!" with 'autowrite' set does not write the file. In vi the +file was written, but this is considered to be a bug, because one does not +expect it and the file is not written with ":rewind!". + +In Vi when entering a <CR> in replace mode deletes a character only when 'ai' +is set (but does not show it until you hit <Esc>). Vim always deletes a +character (and shows it immediately). + +Added :wnext command. Same as ":write" followed by ":next". + +The ":w!" command always writes, also when the file is write protected. In Vi +you would have to do ":!chmod +w %" and ":set noro". + +When 'tildeop' has been set, "~" is an operator (must be followed by a +movement command). + +With the "J" (join) command you can reset the 'joinspaces' option to have only +one space after a period (Vi inserts two spaces). + +"cw" can be used to change white space formed by several characters (Vi is +confusing: "cw" only changes one space, while "dw" deletes all white space). + +"o" and "O" accept a count for repeating the insert (Vi clears a part of +display). + +Flags after Ex commands not supported (no plans to include it). + +On non-UNIX systems ":cd" command shows current directory instead of going to +the home directory (there isn't one). ":pwd" prints the current directory on +all systems. + +After a ":cd" command the file names (in the argument list, opened files) +still point to the same files. In Vi ":cd" is not allowed in a changed file; +otherwise the meaning of file names change. + +":source!" command reads Vi commands from a file. + +":mkexrc" command writes current modified options and mappings to a ".exrc" +file. ":mkvimrc" writes to a ".vimrc" file. + +No check for "tail recursion" with mappings. This allows things like +":map! foo ^]foo". + +When a mapping starts with number, vi loses the count typed before it (e.g. +when using the mapping ":map g 4G" the command "7g" goes to line 4). This is +considered a vi bug. Vim concatenates the counts (in the example it becomes +"74G"), as most people would expect. + +The :put! command inserts the contents of a register above the current line. + +The "p" and "P" commands of vi cannot be repeated with "." when the putted +text is less than a line. In Vim they can always be repeated. + +":noremap" command can be used to enter a mapping that will not be remapped. +This is useful to exchange the meaning of two keys. ":cmap", ":cunmap" and +":cnoremap" can be used for mapping in command-line editing only. ":imap", +":iunmap" and ":inoremap" can be used for mapping in insert mode only. +Similar commands exist for abbreviations: ":noreabbrev", ":iabbrev" +":cabbrev", ":iunabbrev", ":cunabbrev", ":inoreabbrev", ":cnoreabbrev". + +In Vi the command ":map foo bar" would remove a previous mapping +":map bug foo". This is considered a bug, so it is not included in Vim. +":unmap! foo" does remove ":map! bug foo", because unmapping would be very +difficult otherwise (this is vi compatible). + +The ':' register contains the last command-line. +The '%' register contains the current file name. +The '.' register contains the last inserted text. + +":dis" command shows the contents of the yank registers. + +CTRL-O/CTRL-I can be used to jump to older/newer positions. These are the +same positions as used with the '' command, but may be in another file. The +":jumps" command lists the older positions. + +If the 'shiftround' option is set, an indent is rounded to a multiple of +'shiftwidth' with ">" and "<" commands. + +The 'scrolljump' option can be set to the minimum number of lines to scroll +when the cursor gets off the screen. Use this when scrolling is slow. + +The 'scrolloff' option can be set to the minimum number of lines to keep +above and below the cursor. This gives some context to where you are +editing. When set to a large number the cursor line is always in the middle +of the window. + +Uppercase marks can be used to jump between files. The ":marks" command lists +all currently set marks. The commands "']" and "`]" jump to the end of the +previous operator or end of the text inserted with the put command. "'[" and +"`[" do jump to the start. + +The 'shelltype' option can be set to reflect the type of shell used on the +Amiga. + +The 'highlight' option can be set for the highlight mode to be used for +several commands. + +The CTRL-A (add) and CTRL-X (subtract) commands are new. The count to the +command (default 1) is added to/subtracted from the number at or after the +cursor. That number may be decimal, octal (starts with a '0') or hexadecimal +(starts with '0x'). Very useful in macros. + +With the :set command the prefix "inv" can be used to invert boolean options. + +In both Vi and Vim you can create a line break with the ":substitute" command +by using a CTRL-M. For Vi this means you cannot insert a real CTRL-M in the +text. With Vim you can put a real CTRL-M in the text by preceding it with a +CTRL-V. + + +In Insert mode: + +If the 'revins' option is set, insert happens backwards. This is for typing +Hebrew. When inserting normal characters the cursor will not be shifted and +the text moves rightwards. Backspace, CTRL-W and CTRL-U will also work in +the opposite direction. CTRL-B toggles the 'revins' option. In replace mode +'revins' has no effect. Only when enabled at compile time. + +The backspace key can be used just like CTRL-D to remove auto-indents. + +You can backspace, CTRL-U and CTRL-W over line breaks if the 'backspace' (bs) +option includes "eol". You can backspace over the start of insert if the +'backspace' option includes "start". + +When the 'paste' option is set, a few option are reset and mapping in insert +mode and abbreviation are disabled. This allows for pasting text in windowing +systems without unexpected results. When the 'paste' option is reset, the old +option values are restored. + +CTRL-T/CTRL-D always insert/delete an indent in the current line, no matter +what column the cursor is in. + +CTRL-@ (insert previously inserted text) works always (Vi: only when typed as +first character). + +CTRL-A works like CTRL-@ but does not leave insert mode. + +CTRL-R {0-9a-z..} can be used to insert the contents of a register. + +When the 'smartindent' option is set, C programs will be better auto-indented. +With 'cindent' even more. + +CTRL-Y and CTRL-E can be used to copy a character from above/below the +current cursor position. + +After CTRL-V you can enter a three digit decimal number. This byte value is +inserted in the text as a single character. Useful for international +characters that are not on your keyboard. + +When the 'expandtab' (et) option is set, a <Tab> is expanded to the +appropriate number of spaces. + +The window always reflects the contents of the buffer (Vi does not do this +when changing text and in some other cases). + +If Vim is compiled with DIGRAPHS defined, digraphs are supported. A set of +normal digraphs is included. They are shown with the ":digraph" command. +More can be added with ":digraph {char1}{char2} {number}". A digraph is +entered with "CTRL-K {char1} {char2}" or "{char1} BS {char2}" (only when +'digraph' option is set). + +When repeating an insert, e.g. "10atest <Esc>" vi would only handle wrapmargin +for the first insert. Vim does it for all. + +A count to the "i" or "a" command is used for all the text. Vi uses the count +only for one line. "3iabc<NL>def<Esc>" would insert "abcabcabc<NL>def" in Vi +but "abc<NL>defabc<NL>defabc<NL>def" in Vim. + + +In Command-line mode: + +<Esc> terminates the command-line without executing it. In vi the command +line would be executed, which is not what most people expect (hitting <Esc> +should always get you back to command mode). To avoid problems with some +obscure macros, an <Esc> in a macro will execute the command. If you want a +typed <Esc> to execute the command like vi does you can fix this with + ":cmap ^V<Esc> ^V<CR>" + +General: + +The 'ttimeout' option is like 'timeout', but only works for cursor and +function keys, not for ordinary mapped characters. The 'timeoutlen' option +gives the number of milliseconds that is waited for. If the 'esckeys' option +is not set, cursor and function keys that start with <Esc> are not recognized +in insert mode. + +There is an option for each terminal string. Can be used when termcap is not +supported or to change individual strings. + +The 'fileformat' option can be set to select the <EOL>: "dos" <CR><NL>, "unix" +<NL> or "mac" <CR>. +When the 'fileformats' option is not empty, Vim tries to detect the type of +<EOL> automatically. The 'fileformat' option is set accordingly. + +On systems that have no job control (older Unix systems and non-Unix systems) +the CTRL-Z, ":stop" or ":suspend" command starts a new shell. + +If Vim is started on the Amiga without an interactive window for output, a +window is opened (and :sh still works). You can give a device to use for +editing with the |-d| argument, e.g. "-d con:20/20/600/150". + +The 'columns' and 'lines' options are used to set or get the width and height +of the display. + +Option settings are read from the first and last few lines of the file. +Option 'modelines' determines how many lines are tried (default is 5). Note +that this is different from the Vi versions that can execute any Ex command +in a modeline (a major security problem). |trojan-horse| + +If the 'insertmode' option is set (e.g. in .exrc), Vim starts in insert mode. +And it comes back there, when pressing <Esc>. + +Undo information is kept in memory. Available memory limits the number and +size of change that can be undone. This may be a problem with MS-DOS, is +hardly a problem on the Amiga and almost never with Unix and Win32. + +If the 'backup' or 'writebackup' option is set: Before a file is overwritten, +a backup file (.bak) is made. If the "backup" option is set it is left +behind. + +Vim creates a file ending in ".swp" to store parts of the file that have been +changed or that do not fit in memory. This file can be used to recover from +an aborted editing session with "vim -r file". Using the swap file can be +switched off by setting the 'updatecount' option to 0 or starting Vim with +the "-n" option. Use the 'directory' option for placing the .swp file +somewhere else. + +Vim is able to work correctly on filesystems with 8.3 file names, also when +using messydos or crossdos filesystems on the Amiga, or any 8.3 mounted +filesystem under Unix. See |'shortname'|. + +Error messages are shown at least one second (Vi overwrites error messages). + +If Vim gives the |hit-enter| prompt, you can hit any key. Characters other +than <CR>, <NL> and <Space> are interpreted as the (start of) a command. (Vi +only accepts a command starting with ':'). + +The contents of the numbered and unnamed registers is remembered when +changing files. + +The "No lines in buffer" message is a normal message instead of an error +message, since that may cause a mapping to be aborted. + +The AUX: device of the Amiga is supported. + +============================================================================== +6. Command-line arguments *cmdline-arguments* + +Different versions of Vi have different command-line arguments. This can be +confusing. To help you, this section gives an overview of the differences. + +Five variants of Vi will be considered here: + Elvis Elvis version 2.1b + Nvi Nvi version 1.79 + Posix Posix 1003.2 + Vi Vi version 3.7 (for Sun 4.1.x) + Vile Vile version 7.4 (incomplete) + Vim Vim version 5.2 + +Only Vim is able to accept options in between and after the file names. + ++{command} Elvis, Nvi, Posix, Vi, Vim: Same as "-c {command}". + +- Nvi, Posix, Vi: Run Ex in batch mode. + Vim: Read file from stdin (use -s for batch mode). + +-- Vim: End of options, only file names are following. + +--cmd {command} Vim: execute {command} before sourcing vimrc files. + +--echo-wid Vim: GTK+ echoes the Window ID on stdout + +--help Vim: show help message and exit. + +--literal Vim: take file names literally, don't expand wildcards. + +--nofork Vim: same as |-f| + +--noplugin[s] Vim: Skip loading plugins. + +--remote Vim: edit the files in another Vim server + +--remote-expr {expr} Vim: evaluate {expr} in another Vim server + +--remote-send {keys} Vim: send {keys} to a Vim server and exit + +--remote-silent {file} Vim: edit the files in another Vim server if possible + +--remote-wait Vim: edit the files in another Vim server and wait for it + +--remote-wait-silent Vim: like --remote-wait, no complaints if not possible + +--role {role} Vim: GTK+ 2: set role of main window + +--serverlist Vim: Output a list of Vim servers and exit + +--servername {name} Vim: Specify Vim server name + +--socketid {id} Vim: GTK window socket to run Vim in + +--windowid {id} Vim: Win32 window ID to run Vim in + +--version Vim: show version message and exit. + +-? Vile: print usage summary and exit. + +-a Elvis: Load all specified file names into a window (use -o for + Vim). + +-A Vim: Start in Arabic mode (when compiled with Arabic). + +-b {blksize} Elvis: Use {blksize} blocksize for the session file. +-b Vim: set 'binary' mode. + +-C Vim: Compatible mode. + +-c {command} Elvis, Nvi, Posix, Vim: run {command} as an Ex command after + loading the edit buffer. + Vim: allow up to 10 "-c" arguments + +-d {device} Vim: Use {device} for I/O (Amiga only). {only when compiled + without the |+diff| feature} +-d Vim: start with 'diff' set. |vimdiff| + +-dev {device} Vim: Use {device} for I/O (Amiga only). + +-D Vim: debug mode. + +-e Elvis, Nvi, Vim: Start in Ex mode, as if the executable is + called "ex". + +-E Vim: Start in improved Ex mode |gQ|, like "exim". + +-f Vim: Run GUI in foreground (Amiga: don't open new window). +-f {session} Elvis: Use {session} as the session file. + +-F Vim: Start in Farsi mode (when compiled with Farsi). + Nvi: Fast start, don't read the entire file when editing + starts. + +-G {gui} Elvis: Use the {gui} as user interface. + +-g Vim: Start GUI. +-g N Vile: start editing at line N + +-h Vim: Give help message. + Vile: edit the help file + +-H Vim: start Hebrew mode (when compiled with it). + +-i Elvis: Start each window in Insert mode. +-i {viminfo} Vim: Use {viminfo} for viminfo file. + +-L Vim: Same as "-r" (also in some versions of Vi). + +-l Nvi, Vi, Vim: Set 'lisp' and 'showmatch' options. + +-m Vim: Modifications not allowed to be written, resets 'write' + option. + +-M Vim: Modifications not allowed, resets 'modifiable' and the + 'write' option. + +-N Vim: No-compatible mode. + +-n Vim: No swap file used. + +-nb[args] Vim: open a NetBeans interface connection + +-O[N] Vim: Like -o, but use vertically split windows. + +-o[N] Vim: Open [N] windows, or one for each file. + +-p[N] Vim: Open [N] tab pages, or one for each file. + +-P {parent-title} Win32 Vim: open Vim inside a parent application window + +-q {name} Vim: Use {name} for quickfix error file. +-q{name} Vim: Idem. + +-R Elvis, Nvi, Posix, Vile, Vim: Set the 'readonly' option. + +-r Elvis, Nvi, Posix, Vi, Vim: Recovery mode. + +-S Nvi: Set 'secure' option. +-S {script} Vim: source script after starting up. + +-s Nvi, Posix, Vim: Same as "-" (silent mode), when in Ex mode. + Elvis: Sets the 'safer' option. +-s {scriptin} Vim: Read from script file {scriptin}; only when not in Ex + mode. +-s {pattern} Vile: search for {pattern} + +-t {tag} Elvis, Nvi, Posix, Vi, Vim: Edit the file containing {tag}. +-t{tag} Vim: Idem. + +-T {term} Vim: Set terminal name to {term}. + +-u {vimrc} Vim: Read initializations from {vimrc} file. + +-U {gvimrc} Vim: Read GUI initializations from {gvimrc} file. + +-v Nvi, Posix, Vi, Vim: Begin in Normal mode (visual mode, in Vi + terms). + Vile: View mode, no changes possible. + +-V Elvis, Vim: Verbose mode. +-V{nr} Vim: Verbose mode with specified level. + +-w {size} Elvis, Posix, Nvi, Vi, Vim: Set value of 'window' to {size}. +-w{size} Nvi, Vi: Same as "-w {size}". +-w {name} Vim: Write to script file {name} (must start with non-digit). + +-W {name} Vim: Append to script file {name}. + +-x Vi, Vim: Ask for encryption key. See |encryption|. + +-X Vim: Don't connect to the X server. + +-y Vim: Start in easy mode, like |evim|. + +-Z Vim: restricted mode + +@{cmdfile} Vile: use {cmdfile} as startup file. + +============================================================================== +7. POSIX compliance *posix* *posix-compliance* + +In 2005 the POSIX test suite was run to check the compatibility of Vim. Most +of the test was executed properly. There are the few things where Vim +is not POSIX compliant, even when run in Vi compatibility mode. + +Set the $VIM_POSIX environment variable to have 'cpoptions' include the POSIX +flags when Vim starts up. This makes Vim run as POSIX as it can. That's +a bit different from being Vi compatible. + +This is where Vim does not behave as POSIX specifies and why: + + *posix-screen-size* + The $COLUMNS and $LINES environment variables are ignored by Vim if + the size can be obtained from the terminal in a more reliable way. + Add the '|' flag to 'cpoptions' to have $COLUMNS and $LINES overrule + sizes obtained in another way. + + The "{" and "}" commands don't stop at a "{" in the original Vi, but + POSIX specifies it does. Add the '{' flag to 'cpoptions' if you want + it the POSIX way. + + The "D", "o" and "O" commands accept a count. Also when repeated. + Add the '#' flag to 'cpoptions' if you want to ignore the count. + + The ":cd" command fails if the current buffer is modified when the '.' + flag is present in 'cpoptions'. + + There is no ATTENTION message, the "A" flag is added to 'shortmess'. + +These are remarks about running the POSIX test suite: +- vi test 33 sometimes fails for unknown reasons +- vi test 250 fails; behavior will be changed in a new revision + http://www.opengroup.org/austin/mailarchives/ag-review/msg01710.html +- vi test 310 fails; exit code non-zero when any error occurred? +- ex test 24 fails because test is wrong. Changed between SUSv2 and SUSv3. +- ex tests 47, 48, 49, 72, 73 fail because .exrc file isn't read in silent + mode and $EXINIT isn't used. +- ex tests 76, 78 fail because echo is used instead of printf. (fixed) + Also: problem with \s not changed to space. +- ex test 355 fails because 'window' isn't used for "30z". +- ex test 368 fails because shell command isn't echoed in silent mode. +- ex test 394 fails because "=" command output isn't visible in silent mode. +- ex test 411 fails because test file is wrong, contains stray ':'. +- ex test 475 and 476 fail because reprint output isn't visible in silent mode. +- ex test 480 and 481 fail because the tags file has spaces instead of a tab. +- ex test 502 fails because .exrc isn't read in silent mode. +- ex test 509 fails because .exrc isn't read in silent mode. and exit code is + 1 instead of 2. +- ex test 534 fails because .exrc isn't read in silent mode. + + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/vim-fr.1 b/share/vim/vim73/doc/vim-fr.1 new file mode 100644 index 0000000000..5a5a871b3c --- /dev/null +++ b/share/vim/vim73/doc/vim-fr.1 @@ -0,0 +1,588 @@ +.\" Traduction Lundi 7 août 2000 par Richard Hitier +.\" (richard.hitier@dial.oleane.com) +.\" Mise à jour de la traduction par David Blanchet +.\" (david.blanchet@free.fr) 2006-06-10 +.\" Mise à jour de la traduction par Dominique Pellé +.\" (dominique.pelle@gmail.com) 2008-11-29 +.\" +.TH VIM 1 "22 Février 2002" +.SH NOM +vim \- Vi IMproved, éditeur de texte pour programmeurs +.SH SYNOPSIS +.br +.B vim +[options] [fichier ...] +.br +.B vim +[options] \- +.br +.B vim +[options] \-t marqueur +.br +.B vim +[options] \-q [fichiererreurs] +.PP +.br +.B ex +.br +.B view +.br +.B gvim +.B gview +.B evim +.B eview +.br +.B rvim +.B rview +.B rgvim +.B rgview +.SH DESCRIPTION +.B Vim +est un éditeur de texte proposant une compatibilité ascendante +avec Vi. Il permet d'éditer n'importe quel type de texte brut. +Il est particulièrement adapté pour l'édition des programmes. +.PP +Il comporte de nombreuses améliorations par rapport à Vi : annulation sur +plusieurs niveaux, fenêtres et tampons multiples, coloration syntaxique, +édition en ligne de commande, complètement des noms de fichiers, aide en +ligne, sélection visuelle, etc. +Voir ":help vi_diff.txt" pour un résumé des différences entre +.B Vim +et Vi. +.PP +Pendant l'exécution de +.B Vim +\, une aide abondante est accessible au travers du système d'aide +en ligne, grâce à la commande ":help". +Voir la section AIDE EN LIGNE plus bas. +.PP +Le plus souvent +.B Vim +est démarré pour éditer un unique fichier avec la commande +.PP + vim fichier +.PP +Plus généralement, +.B Vim +est lancé avec : +.PP + vim [options] [listefichiers] +.PP +Si la listefichiers est omise, l'éditeur démarre avec un tampon vide. +Autrement, l'une des quatre méthodes suivantes vous permettra de choisir +un ou plusieurs fichiers à éditer. +.TP 12 +fichier ... +Une liste de noms de fichiers. +Le premier sera le fichier courant et sera lu dans le tampon. +Le curseur sera placé sur la première ligne du tampon. +Vous pouvez passer aux autres fichiers avec la commande ":next". +Pour éditer un fichier débutant par un tiret, faites précéder la +liste de fichiers par "\-\-". +.TP +\- +Le fichier à éditer est lu sur l'entrée standard (stdin). Les commandes sont +lues depuis stderr, qui devrait être un terminal. +.TP +\-t {marqueur} +Le fichier à éditer et la position initiale du curseur dépendent +d'un "marqueur", qui est une sorte d'étiquette. +{marqueur} est recherché dans le fichier des marqueurs, le fichier correspondant +devient le fichier courant et la commande associée est exécutée. +Principalement utile pour les programmes en C ; dans ce cas, {marqueur} +peut être le nom d'une fonction. +Au final, le fichier contenant cette fonction devient le fichier +courant et le curseur est placé au début de la fonction. +Voir ":help tag\-commands". +.TP +\-q [fichiererreurs] +Démarre en mode Mise-au-point (QuickFix). +Le fichier [fichiererreurs] est lu et la première erreur est affichée. +Si [fichiererreurs] est omis, le nom du fichier est lu dans +l'option 'errorfile' ("AztecC.Err" par défaut sur Amiga, "errors.err" sur les +autres systèmes). +La commande ":cn" permet de sauter aux erreurs suivantes. +Voir ":help quickfix". +.PP +.B Vim +se comporte différemment selon le nom de la commande (l'exécutable peut +cependant être le même fichier). +.TP 10 +vim +La façon "normale", le comportement par défaut. +.TP +ex +Démarre en mode Ex. +La commande ":vi" permet de passer en mode Normal. +Ce mode est également accessible avec l'argument "\-e". +.TP +view +Démarre en mode Lecture-Seule. Vous êtes protégé de l'écriture accidentelle +des fichiers. Ce mode est également accessible avec l'argument "\-R". +.TP +gvim gview +La version graphique. +Ouvre une nouvelle fenêtre. +Également accessible avec l'argument "\-g". +.TP +evim eview +La version graphique en mode Débutant (easy). +Ouvre une nouvelle fenêtre. +Également accessible avec l'argument "\-y". +.TP +rvim rview rgvim rgview +Comme ci-dessus, mais avec des restrictions. Il vous sera impossible de +lancer des commandes du shell, ou de suspendre +.B Vim. +Également accessible avec l'argument "\-Z". +.SH OPTIONS +Les options peuvent être spécifiées dans n'importe quel ordre, +avant ou après les noms de fichiers. Les options sans arguments +peuvent être combinées après un unique tiret. +.TP 12 ++[num] +Place le curseur sur la ligne "num" dans le premier fichier. +Si "num" est omis, le curseur sera placé sur la dernière ligne. +.TP ++/{motif} +Place le curseur sur la première occurrence de {motif} dans le premier fichier. +Voir ":help search\-pattern" pour connaître les motifs de recherches +disponibles. +.TP ++{commande} +.TP +\-c {commande} +Exécute {commande} après la lecture du premier fichier. +{commande} est interprétée comme une commande Ex. +Si la {commande} contient des espaces, elle doit être entourée +de doubles-apostrophes (cela dépend du shell utilisé). +Exemple: Vim "+set si" main.c +.br +Note : vous pouvez utiliser jusqu'à 10 commandes "+" ou "\-c". +.TP +\-S {fichier} +Source {fichier} après la lecture du premier fichier. +C'est équivalent à \-c "source {fichier}". +{fichier} ne peut pas débuter par un '\-'. +Si {fichier} est omis, "Session.vim" est utilisé (cela ne fonctionne que si +\-S est le dernier argument). +.TP +\-\-cmd {commande} +Comme "\-c", mais la commande est exécutée juste avant de traiter les fichiers +vimrc. +Vous pouvez utiliser jusqu'à 10 de ces commandes, indépendamment des +commandes "\-c". +.TP +\-A +Si +.B Vim +a été compilé avec le support de la fonctionnalité ARABIC pour l'édition de +fichiers de droite à gauche et les claviers arabes, cette option lance +.B Vim +en mode Arabe, c.-à-d. que l'option 'arabic' est activée. +Sinon, un message d'erreur est émis et +.B Vim +quitte. +.TP +\-b +Mode Binaire. +Active plusieurs options pour permettre l'édition +d'un fichier binaire ou exécutable. +.TP +\-C +Compatible. Active l'option 'compatible'. +.B Vim +se comportera alors quasiment comme Vi, même s'il existe un fichier .vimrc. +.TP +\-d +Démarre en mode Diff. +Deux, trois ou quatre noms de fichiers doivent être spécifiés. +.B Vim +ouvrira alors tous les fichiers et affichera leurs différences. +Fonctionne comme vimdiff(1). +.TP +\-d {périph} +Ouvre {périph} pour l'utiliser comme terminal. +Uniquement sur Amiga. +Exemple: +"\-d con:20/30/600/150". +.TP +\-D +Debogage. Passe en mode Débogage lors de l'exécution de la première commande +d'un script. +.TP +\-e +Démarre +.B Vim +en mode Ex, comme si l'exécutable s'appelait "ex". +.TP +\-E +Démarre +.B Vim +en mode Ex amélioré, comme si l'exécutable "exim" avait été invoqué. +.TP +\-f +Premier-plan (Foreground). Pour la version graphique, +.B Vim +ne forke pas et ne se détache pas du shell dans lequel il a été invoqué. +Sur Amiga, +.B Vim +n'est pas relancé pour ouvrir une nouvelle fenêtre. +Cette option est utile quand +.B Vim +est exécuté par un programme qui attend la fin de la session d'édition +(par exemple mail). +Sur Amiga, les commandes ":sh" et ":!" ne fonctionneront pas. +.TP +\-\-nofork +Premier-plan (Foreground). Pour la version graphique, +.B Vim +ne forkera pas et ne se détachera pas du shell dans lequel il a été lancé. +.TP +\-F +Si +.B Vim +a été compilé avec le support de la fonctionnalité FKMAP pour l'édition de +fichiers de droite à gauche et les claviers farsi, cette option lance +.B Vim +en mode Farsi, c.-à-d. avec les options 'fkmap' et 'rightleft' activées. +Sinon, un message d'erreur est émis et +.B Vim +quitte. +.TP +\-g +Si +.B Vim +a été compilé avec le support de l'IHM graphique, cette option active +l'IHM graphique. Si le support n'a pas été compilé, un message d'erreur +est émis et +.B Vim +quitte. +.TP +\-h +Donne une aide succincte sur les arguments et les options de la ligne de +commande. Après cela, +.B Vim +quitte. +.TP +\-H +Si +.B Vim +a été compilé avec le support de la fonctionnalité RIGHTLEFT pour l'édition de +fichiers de droite à gauche et les claviers hébreu, cette option lance +.B Vim +en mode Hébreu, c.-à-d. avec les options 'hkmap' et 'rightleft' activées. +Sinon, un message d'erreur est émis et +.B Vim +quitte. +.TP +\-i {viminfo} +Lorsque l'utilisation d'un fichier viminfo est activée, cette option indique +le nom de fichier à utiliser à la place de "~/.viminfo" par défaut. +Il est possible d'empêcher l'utilisation d'un fichier ".viminfo", en +spécifiant le nom de fichier "NONE". +.TP +\-L +Comme \-r. +.TP +\-l +Mode Lisp. +Active les options 'lisp' et 'showmatch'. +.TP +\-m +Empêche la modification des fichiers. +Désactive l'option 'write'. +Vous pouvez toujours modifier le tampon, mais il vous sera impossible +d'écrire le fichier. +.TP +\-M +N'autorise aucune modification. les options 'modifiable' et 'write' sont +désactivées, de sorte que les changements ne sont pas autorisés et que les +fichiers ne peuvent pas être écrits. Note : ces options peuvent être activées +pour autoriser les modifications. +.TP +\-N +Mode Non-compatible. Désactive l'option 'compatible'. +Cela améliorera le comportement de +.B Vim +\, mais il sera moins conforme à celui de Vi, même s'il n'existe aucun +fichier ".vimrc". +.TP +\-n +N'utilise pas de fichier d'échange (swapfile). +Le recouvrement après un plantage sera impossible. +Utile pour éditer un fichier sur un support très lent (disquette par ex.). +Également activable avec ":set uc=0". +Il est possible de l'annuler avec ":set uc=200". +.TP +\-nb +Devient un serveur d'édition pour NetBeans. Consulter la documentation à ce +sujet pour davantage de détails. +.TP +\-o[N] +Ouvre N fenêtres les unes au-dessus des autres. +Quand N est omis, ouvre une fenêtre pour chaque fichier. +.TP +\-O[N] +Ouvre N fenêtres côte à côte. +Quand N est omis, ouvre une fenêtre pour chaque fichier fichier. +.TP +\-p[N] +Ouvre N onglets. +Quand N est omis, ouvre un onglet pour chaque fichier fichier. +.TP +\-R +Mode Lecture-Seule. +Active l'option 'readonly'. +Vous pouvez toujours éditer le tampon, mais il vous sera impossible de +d'écraser accidentellement un fichier. +Si vous voulez écraser un fichier, ajoutez un point d'exclamation à la commande +Ex, comme dans ":w!". +L'option \-R impose l'option \-n (voir ci-dessus). +L'option 'readonly' peut être désactivée avec ":set noro". +Voir ":help 'readonly'". +.TP +\-r +Donne la liste des fichiers d'échange, avec des informations pour les utiliser +à des fins de recouvrement. +.TP +\-r {file} +Mode Recouvrement. +Utilise le fichier d'échange pour récouvrer d'une session d'édition plantée. +Le fichier d'échange est un fichier avec le même nom que le fichier texte, +suivi du suffixe ".swp". +Voir ":help recovery". +.TP +\-s +Mode Silencieux. Disponible uniquement quand +.B Vim +est lancé en tant que "ex" ou quand l'option "\-e" a été spécifiée avant +l'option "\-s". +.TP +\-s {scriptEntrée} +Lit le fichier de script {scriptEntrée}. +Les caractères du fichier sont interprétés comme si vous les tapiez. +La commande ":source! {scriptEntrée}" donne le même résultat. +Si la fin du fichier est atteinte avant que l'éditeur quitte, les caractères +suivants sont lus depuis le clavier. +.TP +\-T {terminal} +Indique à +.B Vim +le nom du terminal utilisé. +Cela n'est requis que lorsque la détection automatique échoue. +Le {terminal} devrait être connu de +.B Vim +(intégré) ou défini dans le fichier termcap ou terminfo. +.TP +\-u {vimrc} +Utilise les commandes du fichier {vimrc} pour les initialisations. +Toutes les autres initialisations sont omises. +À utiliser pour éditer un type de fichiers particulier. +Cela permet aussi d'omettre toute initialisation en spécifiant le nom de +fichier "NONE". +Voir ":help initialization" dans Vim pour davantage de détails. +.TP +\-U {gvimrc} +Utilise les commandes du fichier {gvimrc} pour l'initialisation de l'IHM +graphique. +Toutes les autres initialisations graphiques sont omises. +Cela permet aussi d'omettre toute initialisation graphique en spécifiant le nom +de fichier "NONE". +Voir ":help gui\-init" dans Vim pour davantage de détails. +.TP +\-V[N] +Mode Verbeux. +Donne des messages à propos des fichiers sourcés, ainsi que sur la lecture +et les écritures dans le fichier viminfo. le nombre optionnel N précise la +valeur de l'option 'verbose' (10 par défaut). +.TP +\-v +Démarre +.B Vim +en mode Vi, comme si l'exécutable s'appelait "vi". Cela n'a d'effet que si +l'exécutable invoqué est "ex". +.TP +\-w {scriptSortie} +Tous les caractères que vous tapez sont enregistrés dans le fichier +{scriptSortie}, jusqu'à ce que vous quittiez +.B Vim. +C'est utile quand vous voulez créer un fichier de script à utiliser avec +"vim \-s" ou ":source!". +Si le fichier {scriptSortie} existe, les caractères sont ajoutés à la fin. +.TP +\-W {scriptSortie} +Comme \-w, mais un fichier existant sera écrasé. +.TP +\-x +Chiffre les fichiers lors de l'écriture. Une clé de chiffrement sera demandée. +.TP +\-X +Ne se connecte pas au serveur X. Accélère le temps de démarrage dans un +terminal, mais le titre de la fenêtre et le presse-papier seront inaccessibles. +.TP +\-y +Démarre +.B Vim +en mode Débutant (easy), comme si l'exécutable s'appelait "evim" ou "eview". +Donne à +.B Vim +un comportement plus proche des éditeurs « cliquez-tapez ». +.TP +\-Z +Mode restreint. Fonctionne comme si l'exécutable commençait par la lettre 'r'. +.TP +\-\- +Délimite la fin des options. +Les arguments qui suivent seront considérés comme des noms de fichiers. +Cela permet d'éditer des fichier débutant par un '\-'. +.TP +\-\-echo\-wid +IHM graphique GTK uniquement : retourne la Window ID sur stdout. +.TP +\-\-help +Donne un message d'aide et quitte, comme "\-h". +.TP +\-\-literal +Prend les arguments de noms de fichiers littéralement, sans étendre les +jokers. N'a aucun effet sur Unix, où le shell étend les jokers. +.TP +\-\-noplugin +Ne charge pas les greffons. Implicite avec \-u NONE. +.TP +\-\-remote +Se connecte à un serveur Vim et lui fait éditer les fichiers spécifiés dans +le reste des arguments. Si aucun serveur n'est trouvé, un avertissement est +émis et les fichiers sont édités dans le Vim courant. +.TP +\-\-remote\-expr {expr} +Se connecte à un serveur Vim, y évalue {expr} et affiche le résultat sur la +sortie standard (stdout). +.TP +\-\-remote\-send {touches} +Se connecte à un serveur Vim et y envoie {touches}. +.TP +\-\-remote\-silent +Comme \-\-remote, mais sans émettre d'avertissement si aucun serveur n'est +trouvé. +.TP +\-\-remote\-wait +Comme \-\-remote, mais Vim ne quitte pas tant que le fichier est en cours +d'édition. +.TP +\-\-remote\-wait\-silent +Comme \-\-remote\-wait, mais sans émettre d'avertissement si aucun serveur n'est +trouvé. +.TP +\-\-serverlist +Donne la liste des noms de tous les serveurs Vim disponibles. +.TP +\-\-servername {nom} +Utilise {nom} pour le nom de serveur. Ce nom est donné au Vim courant, à moins +qu'il ne soit utilisé avec un argument \-\-remote. Dans ce cas, il s'agit du nom +du serveur auquel se connecter. +.TP +\-\-socketid {id} +IHM graphique GTK+ uniquement : utilise le mécanisme GtkPlug pour faire +fonctionner gvim dans une autre fenêtre. +.TP +\-\-version +Affiche les informations sur la version puis quitte. +.SH AIDE EN LIGNE +Taper ":help" dans +.B Vim +pour commencer. +Taper ":help sujet" pour obtenir de l'aide sur un sujet précis. +Par exemple : ":help ZZ" pour consulter l'aide sur la commande "ZZ". +Utiliser <Tab> et CTRL\-D pour compléter les sujets (":help +cmdline\-completion"). +Des marqueurs sont inclus dans l'aide et vous permettent de sauter d'un endroit +à un autre (comme des liens hypertextes, voir ":help"). +L'ensemble des fichiers de la documentation peut être consulté de cette +façon, par exemple ":help syntax.txt". +.SH FICHIERS +.TP 15 +/usr/local/lib/vim/doc/*.txt +Les fichiers de la documentation de +.B Vim. +Utiliser ":help doc\-file\-list" pour obtenir la liste complète. +.TP +/usr/local/lib/vim/doc/tags +Le fichier des marqueurs utilisé pour trouver les informations dans les +fichiers de la documentation. +.TP +/usr/local/lib/vim/syntax/syntax.vim +Initialisation de la syntaxe pour l'ensemble du système. +.TP +/usr/local/lib/vim/syntax/*.vim +Fichiers de syntaxe pour différents langages. +.TP +/usr/local/lib/vim/vimrc +Initialisation de +.B Vim +pour l'ensemble du système. +.TP +~/.vimrc +Initialisation de +.B Vim +de votre compte utilisateur. +.TP +/usr/local/lib/vim/gvimrc +Initialisation de gvim pour l'ensemble du système. +.TP +~/.gvimrc +Initialisation de gvim pour votre compte utilisateur. +.TP +/usr/local/lib/vim/optwin.vim +Script utilisé pour la commande ":options", une manière pratique de consulter +et de modifier les options. +.TP +/usr/local/lib/vim/menu.vim +Initialisation des menus de gvim pour l'ensemble du système. +.TP +/usr/local/lib/vim/bugreport.vim +Script pour générer un rapport de bogue. Voir ":help bugs". +.TP +/usr/local/lib/vim/filetype.vim +Script pour détecter le type d'un fichier d'après son nom. +Voir ":help 'filetype'". +.TP +/usr/local/lib/vim/scripts.vim +Script pour détecter le type d'un fichier d'après son contenu. +Voir ":help 'filetype'". +.TP +/usr/local/lib/vim/print/*.ps +Fichiers utilisés pour l'impression PostScript. +.PP +Pour disposer d'informations récentes, consulter le site Internet de VIM : +.br +<URL:http://www.vim.org/> +.SH VOIR AUSSI +vimtutor(1) +.SH AUTEUR +La majeure partie de +.B Vim +a été écrite par Bram Moolenaar, avec l'aide de nombreux autres contributeurs. +Voir ":help credits" dans +.B Vim. +.br +.B Vim +est basé sur Stevie, réalisé par Tim Thompson, +Tony Andrews et G.R. (Fred) Walter. +Toutefois, pratiquement rien du code original ne subsiste. +.SH BOGUES +Probablement. +Voir ":help todo" pour consulter la liste des problèmes connus. +.PP +NOTE : Remarquez que bon nombre de points, qui pourraient être considérés comme +des bugs par certains, sont en fait dus à une reproduction trop fidèle +du comportement de Vi. Et si vous pensez que d'autres points sont des +bugs "parce que Vi le fait différemment", vous devriez jeter un oeil +attentif au fichier vi_diff.txt (ou taper ":help vi_diff.txt" dans Vim). +Regardez aussi les options 'compatible' et 'coptions'. +.SH TRADUCTION +Cette page de manuel a été traduite par Richard Hitier. +<richard.hitier@dial.oleane.com> 2000-08-07. +.br +Cette page de manuel a été mise à jour par David Blanchet. +<david.blanchet@free.fr> 2006-04-10. diff --git a/share/vim/vim73/doc/vim-fr.UTF-8.1 b/share/vim/vim73/doc/vim-fr.UTF-8.1 new file mode 100644 index 0000000000..9a8bea66c2 --- /dev/null +++ b/share/vim/vim73/doc/vim-fr.UTF-8.1 @@ -0,0 +1,588 @@ +.\" Traduction Lundi 7 août 2000 par Richard Hitier +.\" (richard.hitier@dial.oleane.com) +.\" Mise à jour de la traduction par David Blanchet +.\" (david.blanchet@free.fr) 2006-06-10 +.\" Mise à jour de la traduction par Dominique Pellé +.\" (dominique.pelle@gmail.com) 2008-11-29 +.\" +.TH VIM 1 "22 Février 2002" +.SH NOM +vim \- Vi IMproved, éditeur de texte pour programmeurs +.SH SYNOPSIS +.br +.B vim +[options] [fichier ...] +.br +.B vim +[options] \- +.br +.B vim +[options] \-t marqueur +.br +.B vim +[options] \-q [fichiererreurs] +.PP +.br +.B ex +.br +.B view +.br +.B gvim +.B gview +.B evim +.B eview +.br +.B rvim +.B rview +.B rgvim +.B rgview +.SH DESCRIPTION +.B Vim +est un éditeur de texte proposant une compatibilité ascendante +avec Vi. Il permet d'éditer n'importe quel type de texte brut. +Il est particulièrement adapté pour l'édition des programmes. +.PP +Il comporte de nombreuses améliorations par rapport à Vi : annulation sur +plusieurs niveaux, fenêtres et tampons multiples, coloration syntaxique, +édition en ligne de commande, complètement des noms de fichiers, aide en +ligne, sélection visuelle, etc. +Voir ":help vi_diff.txt" pour un résumé des différences entre +.B Vim +et Vi. +.PP +Pendant l'exécution de +.B Vim +\, une aide abondante est accessible au travers du système d'aide +en ligne, grâce à la commande ":help". +Voir la section AIDE EN LIGNE plus bas. +.PP +Le plus souvent +.B Vim +est démarré pour éditer un unique fichier avec la commande +.PP + vim fichier +.PP +Plus généralement, +.B Vim +est lancé avec : +.PP + vim [options] [listefichiers] +.PP +Si la listefichiers est omise, l'éditeur démarre avec un tampon vide. +Autrement, l'une des quatre méthodes suivantes vous permettra de choisir +un ou plusieurs fichiers à éditer. +.TP 12 +fichier ... +Une liste de noms de fichiers. +Le premier sera le fichier courant et sera lu dans le tampon. +Le curseur sera placé sur la première ligne du tampon. +Vous pouvez passer aux autres fichiers avec la commande ":next". +Pour éditer un fichier débutant par un tiret, faites précéder la +liste de fichiers par "\-\-". +.TP +\- +Le fichier à éditer est lu sur l'entrée standard (stdin). Les commandes sont +lues depuis stderr, qui devrait être un terminal. +.TP +\-t {marqueur} +Le fichier à éditer et la position initiale du curseur dépendent +d'un "marqueur", qui est une sorte d'étiquette. +{marqueur} est recherché dans le fichier des marqueurs, le fichier correspondant +devient le fichier courant et la commande associée est exécutée. +Principalement utile pour les programmes en C ; dans ce cas, {marqueur} +peut être le nom d'une fonction. +Au final, le fichier contenant cette fonction devient le fichier +courant et le curseur est placé au début de la fonction. +Voir ":help tag\-commands". +.TP +\-q [fichiererreurs] +Démarre en mode Mise-au-point (QuickFix). +Le fichier [fichiererreurs] est lu et la première erreur est affichée. +Si [fichiererreurs] est omis, le nom du fichier est lu dans +l'option 'errorfile' ("AztecC.Err" par défaut sur Amiga, "errors.err" sur les +autres systèmes). +La commande ":cn" permet de sauter aux erreurs suivantes. +Voir ":help quickfix". +.PP +.B Vim +se comporte différemment selon le nom de la commande (l'exécutable peut +cependant être le même fichier). +.TP 10 +vim +La façon "normale", le comportement par défaut. +.TP +ex +Démarre en mode Ex. +La commande ":vi" permet de passer en mode Normal. +Ce mode est également accessible avec l'argument "\-e". +.TP +view +Démarre en mode Lecture-Seule. Vous êtes protégé de l'écriture accidentelle +des fichiers. Ce mode est également accessible avec l'argument "\-R". +.TP +gvim gview +La version graphique. +Ouvre une nouvelle fenêtre. +Également accessible avec l'argument "\-g". +.TP +evim eview +La version graphique en mode Débutant (easy). +Ouvre une nouvelle fenêtre. +Également accessible avec l'argument "\-y". +.TP +rvim rview rgvim rgview +Comme ci-dessus, mais avec des restrictions. Il vous sera impossible de +lancer des commandes du shell, ou de suspendre +.B Vim. +Également accessible avec l'argument "\-Z". +.SH OPTIONS +Les options peuvent être spécifiées dans n'importe quel ordre, +avant ou après les noms de fichiers. Les options sans arguments +peuvent être combinées après un unique tiret. +.TP 12 ++[num] +Place le curseur sur la ligne "num" dans le premier fichier. +Si "num" est omis, le curseur sera placé sur la dernière ligne. +.TP ++/{motif} +Place le curseur sur la première occurrence de {motif} dans le premier fichier. +Voir ":help search\-pattern" pour connaître les motifs de recherches +disponibles. +.TP ++{commande} +.TP +\-c {commande} +Exécute {commande} après la lecture du premier fichier. +{commande} est interprétée comme une commande Ex. +Si la {commande} contient des espaces, elle doit être entourée +de doubles-apostrophes (cela dépend du shell utilisé). +Exemple: Vim "+set si" main.c +.br +Note : vous pouvez utiliser jusqu'à 10 commandes "+" ou "\-c". +.TP +\-S {fichier} +Source {fichier} après la lecture du premier fichier. +C'est équivalent à \-c "source {fichier}". +{fichier} ne peut pas débuter par un '\-'. +Si {fichier} est omis, "Session.vim" est utilisé (cela ne fonctionne que si +\-S est le dernier argument). +.TP +\-\-cmd {commande} +Comme "\-c", mais la commande est exécutée juste avant de traiter les fichiers +vimrc. +Vous pouvez utiliser jusqu'à 10 de ces commandes, indépendamment des +commandes "\-c". +.TP +\-A +Si +.B Vim +a été compilé avec le support de la fonctionnalité ARABIC pour l'édition de +fichiers de droite à gauche et les claviers arabes, cette option lance +.B Vim +en mode Arabe, c.-à-d. que l'option 'arabic' est activée. +Sinon, un message d'erreur est émis et +.B Vim +quitte. +.TP +\-b +Mode Binaire. +Active plusieurs options pour permettre l'édition +d'un fichier binaire ou exécutable. +.TP +\-C +Compatible. Active l'option 'compatible'. +.B Vim +se comportera alors quasiment comme Vi, même s'il existe un fichier .vimrc. +.TP +\-d +Démarre en mode Diff. +Deux, trois ou quatre noms de fichiers doivent être spécifiés. +.B Vim +ouvrira alors tous les fichiers et affichera leurs différences. +Fonctionne comme vimdiff(1). +.TP +\-d {périph} +Ouvre {périph} pour l'utiliser comme terminal. +Uniquement sur Amiga. +Exemple: +"\-d con:20/30/600/150". +.TP +\-D +Debogage. Passe en mode Débogage lors de l'exécution de la première commande +d'un script. +.TP +\-e +Démarre +.B Vim +en mode Ex, comme si l'exécutable s'appelait "ex". +.TP +\-E +Démarre +.B Vim +en mode Ex amélioré, comme si l'exécutable "exim" avait été invoqué. +.TP +\-f +Premier-plan (Foreground). Pour la version graphique, +.B Vim +ne forke pas et ne se détache pas du shell dans lequel il a été invoqué. +Sur Amiga, +.B Vim +n'est pas relancé pour ouvrir une nouvelle fenêtre. +Cette option est utile quand +.B Vim +est exécuté par un programme qui attend la fin de la session d'édition +(par exemple mail). +Sur Amiga, les commandes ":sh" et ":!" ne fonctionneront pas. +.TP +\-\-nofork +Premier-plan (Foreground). Pour la version graphique, +.B Vim +ne forkera pas et ne se détachera pas du shell dans lequel il a été lancé. +.TP +\-F +Si +.B Vim +a été compilé avec le support de la fonctionnalité FKMAP pour l'édition de +fichiers de droite à gauche et les claviers farsi, cette option lance +.B Vim +en mode Farsi, c.-à-d. avec les options 'fkmap' et 'rightleft' activées. +Sinon, un message d'erreur est émis et +.B Vim +quitte. +.TP +\-g +Si +.B Vim +a été compilé avec le support de l'IHM graphique, cette option active +l'IHM graphique. Si le support n'a pas été compilé, un message d'erreur +est émis et +.B Vim +quitte. +.TP +\-h +Donne une aide succincte sur les arguments et les options de la ligne de +commande. Après cela, +.B Vim +quitte. +.TP +\-H +Si +.B Vim +a été compilé avec le support de la fonctionnalité RIGHTLEFT pour l'édition de +fichiers de droite à gauche et les claviers hébreu, cette option lance +.B Vim +en mode Hébreu, c.-à-d. avec les options 'hkmap' et 'rightleft' activées. +Sinon, un message d'erreur est émis et +.B Vim +quitte. +.TP +\-i {viminfo} +Lorsque l'utilisation d'un fichier viminfo est activée, cette option indique +le nom de fichier à utiliser à la place de "~/.viminfo" par défaut. +Il est possible d'empêcher l'utilisation d'un fichier ".viminfo", en +spécifiant le nom de fichier "NONE". +.TP +\-L +Comme \-r. +.TP +\-l +Mode Lisp. +Active les options 'lisp' et 'showmatch'. +.TP +\-m +Empêche la modification des fichiers. +Désactive l'option 'write'. +Vous pouvez toujours modifier le tampon, mais il vous sera impossible +d'écrire le fichier. +.TP +\-M +N'autorise aucune modification. les options 'modifiable' et 'write' sont +désactivées, de sorte que les changements ne sont pas autorisés et que les +fichiers ne peuvent pas être écrits. Note : ces options peuvent être activées +pour autoriser les modifications. +.TP +\-N +Mode Non-compatible. Désactive l'option 'compatible'. +Cela améliorera le comportement de +.B Vim +\, mais il sera moins conforme à celui de Vi, même s'il n'existe aucun +fichier ".vimrc". +.TP +\-n +N'utilise pas de fichier d'échange (swapfile). +Le recouvrement après un plantage sera impossible. +Utile pour éditer un fichier sur un support très lent (disquette par ex.). +Également activable avec ":set uc=0". +Il est possible de l'annuler avec ":set uc=200". +.TP +\-nb +Devient un serveur d'édition pour NetBeans. Consulter la documentation à ce +sujet pour davantage de détails. +.TP +\-o[N] +Ouvre N fenêtres les unes au-dessus des autres. +Quand N est omis, ouvre une fenêtre pour chaque fichier. +.TP +\-O[N] +Ouvre N fenêtres côte à côte. +Quand N est omis, ouvre une fenêtre pour chaque fichier fichier. +.TP +\-p[N] +Ouvre N onglets. +Quand N est omis, ouvre un onglet pour chaque fichier fichier. +.TP +\-R +Mode Lecture-Seule. +Active l'option 'readonly'. +Vous pouvez toujours éditer le tampon, mais il vous sera impossible de +d'écraser accidentellement un fichier. +Si vous voulez écraser un fichier, ajoutez un point d'exclamation à la commande +Ex, comme dans ":w!". +L'option \-R impose l'option \-n (voir ci-dessus). +L'option 'readonly' peut être désactivée avec ":set noro". +Voir ":help 'readonly'". +.TP +\-r +Donne la liste des fichiers d'échange, avec des informations pour les utiliser +à des fins de recouvrement. +.TP +\-r {file} +Mode Recouvrement. +Utilise le fichier d'échange pour récouvrer d'une session d'édition plantée. +Le fichier d'échange est un fichier avec le même nom que le fichier texte, +suivi du suffixe ".swp". +Voir ":help recovery". +.TP +\-s +Mode Silencieux. Disponible uniquement quand +.B Vim +est lancé en tant que "ex" ou quand l'option "\-e" a été spécifiée avant +l'option "\-s". +.TP +\-s {scriptEntrée} +Lit le fichier de script {scriptEntrée}. +Les caractères du fichier sont interprétés comme si vous les tapiez. +La commande ":source! {scriptEntrée}" donne le même résultat. +Si la fin du fichier est atteinte avant que l'éditeur quitte, les caractères +suivants sont lus depuis le clavier. +.TP +\-T {terminal} +Indique à +.B Vim +le nom du terminal utilisé. +Cela n'est requis que lorsque la détection automatique échoue. +Le {terminal} devrait être connu de +.B Vim +(intégré) ou défini dans le fichier termcap ou terminfo. +.TP +\-u {vimrc} +Utilise les commandes du fichier {vimrc} pour les initialisations. +Toutes les autres initialisations sont omises. +À utiliser pour éditer un type de fichiers particulier. +Cela permet aussi d'omettre toute initialisation en spécifiant le nom de +fichier "NONE". +Voir ":help initialization" dans Vim pour davantage de détails. +.TP +\-U {gvimrc} +Utilise les commandes du fichier {gvimrc} pour l'initialisation de l'IHM +graphique. +Toutes les autres initialisations graphiques sont omises. +Cela permet aussi d'omettre toute initialisation graphique en spécifiant le nom +de fichier "NONE". +Voir ":help gui\-init" dans Vim pour davantage de détails. +.TP +\-V[N] +Mode Verbeux. +Donne des messages à propos des fichiers sourcés, ainsi que sur la lecture +et les écritures dans le fichier viminfo. le nombre optionnel N précise la +valeur de l'option 'verbose' (10 par défaut). +.TP +\-v +Démarre +.B Vim +en mode Vi, comme si l'exécutable s'appelait "vi". Cela n'a d'effet que si +l'exécutable invoqué est "ex". +.TP +\-w {scriptSortie} +Tous les caractères que vous tapez sont enregistrés dans le fichier +{scriptSortie}, jusqu'à ce que vous quittiez +.B Vim. +C'est utile quand vous voulez créer un fichier de script à utiliser avec +"vim \-s" ou ":source!". +Si le fichier {scriptSortie} existe, les caractères sont ajoutés à la fin. +.TP +\-W {scriptSortie} +Comme \-w, mais un fichier existant sera écrasé. +.TP +\-x +Chiffre les fichiers lors de l'écriture. Une clé de chiffrement sera demandée. +.TP +\-X +Ne se connecte pas au serveur X. Accélère le temps de démarrage dans un +terminal, mais le titre de la fenêtre et le presse-papier seront inaccessibles. +.TP +\-y +Démarre +.B Vim +en mode Débutant (easy), comme si l'exécutable s'appelait "evim" ou "eview". +Donne à +.B Vim +un comportement plus proche des éditeurs « cliquez-tapez ». +.TP +\-Z +Mode restreint. Fonctionne comme si l'exécutable commençait par la lettre 'r'. +.TP +\-\- +Délimite la fin des options. +Les arguments qui suivent seront considérés comme des noms de fichiers. +Cela permet d'éditer des fichier débutant par un '\-'. +.TP +\-\-echo\-wid +IHM graphique GTK uniquement : retourne la Window ID sur stdout. +.TP +\-\-help +Donne un message d'aide et quitte, comme "\-h". +.TP +\-\-literal +Prend les arguments de noms de fichiers littéralement, sans étendre les +jokers. N'a aucun effet sur Unix, où le shell étend les jokers. +.TP +\-\-noplugin +Ne charge pas les greffons. Implicite avec \-u NONE. +.TP +\-\-remote +Se connecte à un serveur Vim et lui fait éditer les fichiers spécifiés dans +le reste des arguments. Si aucun serveur n'est trouvé, un avertissement est +émis et les fichiers sont édités dans le Vim courant. +.TP +\-\-remote\-expr {expr} +Se connecte à un serveur Vim, y évalue {expr} et affiche le résultat sur la +sortie standard (stdout). +.TP +\-\-remote\-send {touches} +Se connecte à un serveur Vim et y envoie {touches}. +.TP +\-\-remote\-silent +Comme \-\-remote, mais sans émettre d'avertissement si aucun serveur n'est +trouvé. +.TP +\-\-remote\-wait +Comme \-\-remote, mais Vim ne quitte pas tant que le fichier est en cours +d'édition. +.TP +\-\-remote\-wait\-silent +Comme \-\-remote\-wait, mais sans émettre d'avertissement si aucun serveur n'est +trouvé. +.TP +\-\-serverlist +Donne la liste des noms de tous les serveurs Vim disponibles. +.TP +\-\-servername {nom} +Utilise {nom} pour le nom de serveur. Ce nom est donné au Vim courant, à moins +qu'il ne soit utilisé avec un argument \-\-remote. Dans ce cas, il s'agit du nom +du serveur auquel se connecter. +.TP +\-\-socketid {id} +IHM graphique GTK+ uniquement : utilise le mécanisme GtkPlug pour faire +fonctionner gvim dans une autre fenêtre. +.TP +\-\-version +Affiche les informations sur la version puis quitte. +.SH AIDE EN LIGNE +Taper ":help" dans +.B Vim +pour commencer. +Taper ":help sujet" pour obtenir de l'aide sur un sujet précis. +Par exemple : ":help ZZ" pour consulter l'aide sur la commande "ZZ". +Utiliser <Tab> et CTRL\-D pour compléter les sujets (":help +cmdline\-completion"). +Des marqueurs sont inclus dans l'aide et vous permettent de sauter d'un endroit +à un autre (comme des liens hypertextes, voir ":help"). +L'ensemble des fichiers de la documentation peut être consulté de cette +façon, par exemple ":help syntax.txt". +.SH FICHIERS +.TP 15 +/usr/local/lib/vim/doc/*.txt +Les fichiers de la documentation de +.B Vim. +Utiliser ":help doc\-file\-list" pour obtenir la liste complète. +.TP +/usr/local/lib/vim/doc/tags +Le fichier des marqueurs utilisé pour trouver les informations dans les +fichiers de la documentation. +.TP +/usr/local/lib/vim/syntax/syntax.vim +Initialisation de la syntaxe pour l'ensemble du système. +.TP +/usr/local/lib/vim/syntax/*.vim +Fichiers de syntaxe pour différents langages. +.TP +/usr/local/lib/vim/vimrc +Initialisation de +.B Vim +pour l'ensemble du système. +.TP +~/.vimrc +Initialisation de +.B Vim +de votre compte utilisateur. +.TP +/usr/local/lib/vim/gvimrc +Initialisation de gvim pour l'ensemble du système. +.TP +~/.gvimrc +Initialisation de gvim pour votre compte utilisateur. +.TP +/usr/local/lib/vim/optwin.vim +Script utilisé pour la commande ":options", une manière pratique de consulter +et de modifier les options. +.TP +/usr/local/lib/vim/menu.vim +Initialisation des menus de gvim pour l'ensemble du système. +.TP +/usr/local/lib/vim/bugreport.vim +Script pour générer un rapport de bogue. Voir ":help bugs". +.TP +/usr/local/lib/vim/filetype.vim +Script pour détecter le type d'un fichier d'après son nom. +Voir ":help 'filetype'". +.TP +/usr/local/lib/vim/scripts.vim +Script pour détecter le type d'un fichier d'après son contenu. +Voir ":help 'filetype'". +.TP +/usr/local/lib/vim/print/*.ps +Fichiers utilisés pour l'impression PostScript. +.PP +Pour disposer d'informations récentes, consulter le site Internet de VIM : +.br +<URL:http://www.vim.org/> +.SH VOIR AUSSI +vimtutor(1) +.SH AUTEUR +La majeure partie de +.B Vim +a été écrite par Bram Moolenaar, avec l'aide de nombreux autres contributeurs. +Voir ":help credits" dans +.B Vim. +.br +.B Vim +est basé sur Stevie, réalisé par Tim Thompson, +Tony Andrews et G.R. (Fred) Walter. +Toutefois, pratiquement rien du code original ne subsiste. +.SH BOGUES +Probablement. +Voir ":help todo" pour consulter la liste des problèmes connus. +.PP +NOTE : Remarquez que bon nombre de points, qui pourraient être considérés comme +des bugs par certains, sont en fait dus à une reproduction trop fidèle +du comportement de Vi. Et si vous pensez que d'autres points sont des +bugs "parce que Vi le fait différemment", vous devriez jeter un oeil +attentif au fichier vi_diff.txt (ou taper ":help vi_diff.txt" dans Vim). +Regardez aussi les options 'compatible' et 'coptions'. +.SH TRADUCTION +Cette page de manuel a été traduite par Richard Hitier. +<richard.hitier@dial.oleane.com> 2000-08-07. +.br +Cette page de manuel a été mise à jour par David Blanchet. +<david.blanchet@free.fr> 2006-04-10. diff --git a/share/vim/vim73/doc/vim-it.1 b/share/vim/vim73/doc/vim-it.1 new file mode 100644 index 0000000000..0ab3eff0d2 --- /dev/null +++ b/share/vim/vim73/doc/vim-it.1 @@ -0,0 +1,566 @@ +.TH VIM 1 "22 febbraio 2002" +.SH NOME +vim \- VI Migliorato, un editor di testi per programmatori +.SH SINTASSI +.br +.B vim +[opzioni] [file ..] +.br +.B vim +[opzioni] \- +.br +.B vim +[opzioni] \-t tag +.br +.B vim +[opzioni] \-q [file_errori] +.PP +.br +.B ex +.br +.B view +.br +.B gvim +.B gview +.B evim +.B eview +.br +.B rvim +.B rview +.B rgvim +.B rgview +.SH DESCRIZIONE +.B Vim +Un editore di testi, compatibile con, e migliore di, Vi. +Può essere usato per editare qualsiasi file di testo. +Particolarmente utile per editare programmi. +.PP +Ci sono parecchi miglioramenti rispetto a Vi: undo multipli, +finestre e buffer multipli, evidenziazione sintattica, possibilità +di modificare la linea di comando, completamento nomi file, help +in linea, selezione testi in Modo Visual, etc.. +Vedere ":help vi_diff.txt" per un sommario delle differenze fra +.B Vim +e Vi. +.PP +Mentre usate +.B Vim +potete ricevere molto aiuto dal sistema di help online, col comando ":help". +Vedere qui sotto la sezione AIUTO ONLINE. +.PP +Quasi sempre +.B Vim +viene invocato, per modificare un file, col comando +.PP + vim nome_file +.PP +Più in generale +.B Vim +viene invocato con: +.PP + vim [opzioni] [lista_file] +.PP +Se lista_file non è presente, l'editor inizia aprendo un buffer vuoto. +Altrimenti, una e una sola delle quattro maniere indicate qui sotto può +essere usata per scegliere uno o più file da modificare. +.TP 12 +nome_file .. +Una lista di nomi di file. +Il primo di questi sarà il file corrente, e verrà letto nel buffer. +Il cursore sarà posizionato sulla prima linea del buffer. +Potete arrivare agli altri file col comando ":next". +Per editare un file il cui nome inizia per "\-" premettete "\-\-" alla +lista_file. +.TP +\- +Il file da editare è letto dallo "stdin" [di solito, ma non +necessariamente, il terminale \- NdT]. I comandi sono letti da "stderr", +che dovrebbe essere un terminale [tty]. +.TP +\-t {tag} +Il file da editare e la posizione iniziale del cursore dipendono da "tag", +una specie di "etichetta" a cui saltare. +{tag} viene cercata nel file "tags", ed il file ad essa associato diventa +quello corrente, ed il comando ad essa associato viene eseguito. +Di solito si usa per programmi C, nel qual caso {tag} potrebbe essere un +nome di funzione. +L'effetto è che il file contenente quella funzione diventa il file corrente +e il cursore è posizionato all'inizio della funzione. +Vedere ":help tag\-commands". +.TP +\-q [file_errori] +Inizia in Modo QuickFix [correzione veloce]. +Il file [file_errori] è letto e il primo errore è visualizzato. +Se [file_errori] non è indicato, il suo nome è ottenuto dal valore +dell'opzione 'errorfile' (che, se non specificata, vale "AztecC.Err" +per l'Amiga, "errors.err" su altri sistemi). +Si può saltare all'errore successivo col comando ":cn". +Vedere ":help quickfix". +.PP +.B Vim +si comporta in modo diverso se invocato con nomi differenti (il programma +eseguibile "sottostante" può essere sempre lo stesso). +.TP 10 +vim +Modo Normal, comportamento normale. +.TP +ex +Inizia in Modo "Ex". +Si può passare in Modo Normal col comando ":vi". +Si può invocare il Modo "Ex" anche con l'argomento "\-e". +.TP +view +Inizia in Modo Read-only (Sola Lettura). Non potete modificare i file. +Si può invocare il Modo Read-only anche con l'argomento "\-R". +.TP +gvim gview +La versione GUI [Graphical User Interface]. +Apre una nuova finestra. +Si può invocare il Modo GUI anche con l'argomento "\-g". +.TP +evim eview +La versione GUI in Modo Easy (semplificata). +Apre una nuova finestra. +Si può invocare il Modo Easy anche con l'argomento "\-y". +.TP +rvim rview rgvim rgview +Come sopra, ma con restrizioni ai comandi. Non si potranno eseguire comandi +della shell o sospendere +.B Vim. +Si può chiedere la stessa cosa anche con l'argomento "\-Z". +.SH OPZIONI +Le opzioni possono essere in un ordine qualsiasi, prima o dopo i nomi di +file. Opzioni che non necessitano un argomento possono essere specificate +dietro a un solo "\-". +.TP 12 ++[numero] +Per il primo file il cursore sarà posizionato sulla linea "numero". +Se "numero" manca, il cursore sarà posizionato sull'ultima linea del file. +.TP ++/{espressione} +Per il primo file il cursore sarà posizionato alla +prima occorrenza di {espressione}. +Vedere ":help search\-pattern" per come specificare l'espressione. +.TP ++{comando} +.TP +\-c {comando} +{comando} sarà eseguito dopo che il +primo file è stato letto. +{comando} è interpretato come un comando Ex. +Se il {comando} contiene spazi deve essere incluso fra doppi apici +(o altro delimitatore, a seconda della shell che si sta usando). +Esempio: Vim "+set si" main.c +.br +Note: Si possono avere fino a 10 comandi "+" o "\-c". +.TP +\-S {file} +I comandi contenuti in {file} sono eseguiti dopo la lettura del primo file. +Equivalente a \-c "source {file}". +{file} non può avere un nome che inizia per '\-'. +Se {file} è omesso si usa "Session.vim" (funziona solo se \-S è l'ultimo +argomento specificato). +.TP +\-\-cmd {comando} +Come "\-c", ma il comando è eseguito PRIMA +di eseguire qualsiasi file vimrc. +Si possono usare fino a 10 di questi comandi, indipendentemente dai comandi +"\-c". +.TP +\-A +Se +.B Vim +è stato compilato con supporto Arabic per editare file con orientamento +destra-sinistra e tastiera con mappatura Araba, questa opzione inizia +.B Vim +in Modo Arabic, cioè impostando 'arabic'. +Altrimenti viene dato un messaggio di errore e +.B Vim +termina in modo anormale. +.TP +\-b +Modo Binary (binario). +Vengono impostate alcune opzioni che permettono di modificare un file +binario o un programma eseguibile. +.TP +\-C +Compatibile. Imposta l'opzione 'compatible'. +In questo modo +.B Vim +ha quasi lo stesso comportamento di Vi, anche in presenza di un file +di configurazione .vimrc [proprio di Vim, vi usa .exrc \- Ndt]. +.TP +\-d +Inizia in Modo Diff [differenze]. +Dovrebbero esserci come argomenti due o tre o quattro nomi di file. +.B Vim +aprirà tutti i file evidenziando le differenze fra gli stessi. +Funziona come vimdiff(1). +.TP +\-d {dispositivo} +Apre {dispositivo} per usarlo come terminale. +Solo per l'Amiga. +Esempio: +"\-d con:20/30/600/150". +.TP +\-D +Debugging. Vim si mette in Modo "debugging" a partire +dall'esecuzione del primo comando da uno script. +.TP +\-e +Eseguire +.B Vim +in Modo Ex, come se il programma eseguito sia "ex". +.TP +\-E +Eseguire +.B Vim +in Modo Ex migliorato, come se il programma eseguito sia "exim". +.TP +\-f +Direttamente [Foreground]. Per la versione GUI, +.B Vim +non crea [fork] una nuova finestra, indipendente dalla shell di invocazione. +Per l'Amiga, +.B Vim +non è fatto ripartire per aprire una nuova finestra. +Opzione da usare quando +.B Vim +è eseguito da un programma che attende la fine della +sessione di edit (ad es. mail). +Sull'Amiga i comandi ":sh" e ":!" non sono disponibili. +.TP +\-\-nofork +Direttamente [Foreground]. Per la versione GUI, +.B Vim +non crea [fork] una nuova finestra, indipendente dalla shell di invocazione. +.TP +\-F +Se +.B Vim +è stato compilato con supporto FKMAP per editare file con orientamento +destra-sinistra e tastiera con mappatura Farsi, questa opzione inizia +.B Vim +in Modo Farsi, cioè impostando 'fkmap' e 'rightleft'. +Altrimenti viene dato un messaggio di errore e +.B Vim +termina in modo anormale. +.TP +\-g +Se +.B Vim +è stato compilato con supporto GUI, questa opzione chiede di usarla. +Se Vim è stato compilato senza supporto GUI viene dato un messaggio di errore e +.B Vim +termina in modo anormale. +.TP +\-h +Un po' di aiuto su opzioni e argomenti che si possono dare invocando Vim. +Subito dopo +.B Vim +esce. +.TP +\-H +Se +.B Vim +è stato compilato col supporto RIGHTLEFT per editare file con orientamento +destra-sinistra e tastiera con mappatura Ebraica, questa opzione inizia +.B Vim +in Modo Ebraico, cioè impostando 'hkmap' e 'rightleft'. +Altrimenti viene dato un messaggio di errore e +.B Vim +termina in modo anormale. +.TP +\-i {viminfo} +Se è abilitato l'uso di un file viminfo, questa opzione indica il nome +del file da usare invece di quello predefinito "~/.viminfo". +Si può anche evitare l'uso di un file .viminfo, dando come nome "NONE". +.TP +\-L +Equivalente a \-r. +.TP +\-l +Modo Lisp. +Imposta le opzioni 'lisp' e 'showmatch'. +.TP +\-m +Inibisce modifica file. +Annulla l'opzione 'write'. +È ancora possibile modificare un buffer [in memoria \- Ndt], ma non scriverlo. +.TP +\-M +Modifiche non permesse. Le opzioni 'modifiable' e 'write' sono annullate, +in modo da impedire sia modifiche che riscritture. Da notare che queste +opzioni possono essere abilitate in seguito, permettendo così modifiche. +.TP +\-N +Modo "Non-compatibile". Annulla l'opzione 'compatible'. +Così +.B Vim +va un po' meglio, ma è meno compatibile con Vi, anche in assenza di un +file .vimrc. +.TP +\-n +Inibisce l'uso di un file di swap. +Il recupero dopo una caduta di macchina diventa impossibile. +Utile per editare un file su un supporto molto lento (ad es. floppy). +Il comando ":set uc=0" ha lo stesso effetto. +Per abilitare il recupero usare ":set uc=200". +.TP +\-nb +Diviene un Editor server per NetBeans. Vedere la documentazione per dettagli. +.TP +\-o[N] +Apri N finestre in orizzontale. +Se N manca, apri una finestra per ciascun file. +.TP +\-O[N] +Apri N finestre, in verticale. +Se N manca, apri una finestra per ciascun file. +.TP +\-R +Modo Read-only (Sola Lettura). +Imposta l'opzione 'readonly'. +Si può ancora modificare il buffer, ma siete protetti da una riscrittura +involontaria. +Se volete davvero riscrivere il file, aggiungete un punto esclamativo +al comando Ex, come in ":w!". +L'opzione \-R implica anche l'opzione \-n (vedere sotto). +L'opzione 'readonly' può essere annullata con ":set noro". +Vedere ":help 'readonly'". +.TP +\-r +Lista file di swap, assieme a dati utili per un recupero. +.TP +\-r {file} +Modo Recovery (ripristino). +Il file di swap è usato per recuperare una sessione di edit finita male. +Il file di swap è un file con lo stesso nome file del file di testo +editato, col suffisso ".swp". +Vedere ":help recovery". +.TP +\-s +Modo silenzioso. Solo quando invocato come "Ex" o quando l'opzione +"\-e" è stata data prima dell'opzione "\-s". +.TP +\-s {scriptin} +Lo script file {scriptin} è letto. +I caratteri nel file sono interpretati come se immessi da voi. +Lo stesso si può ottenere col comando ":source! {scriptin}". +Se la fine del file di input viene raggiunta prima che Vim termini, +l'ulteriore input viene preso dalla tastiera. +.TP +\-T {terminale} +Dice a +.B Vim +quale tipo di terminale state usando. +Utile solo se il terminale non viene riconosciuto correttamente da Vim. +Dovrebbe essere un terminale noto a +.B Vim +(internamente) o definito nel file termcap o terminfo. +.TP +\-u {vimrc} +Usa i comandi nel file {vimrc} per inizializzazioni. +Tutte le altre inizializzazioni non sono eseguite. +Usate questa opzione per editare qualche file di tipo speciale. +Può anche essere usato per non fare alcuna inizializzazione dando +come nome "NONE". +Vedere ":help initialization" da vim per ulteriori dettagli. +.TP +\-U {gvimrc} +Usa i comandi nel file {gvimrc} per inizializzazioni GUI. +Tutte le altre inizializzazioni GUI non sono eseguite. +Può anche essere usata per non fare alcuna inizializzazione GUI dando +come nome "NONE". +Vedere ":help gui-init" da vim per ulteriori dettagli. +.TP +\-V[N] +Verboso. Vim manda messaggi relativi agli script file che esegue +e quando legge o scrive un file viminfo. Il numero opzionale N è il valore +dell'opzione 'verbose'. +Il valore predefinito è 10. +.TP +\-v +Inizia +.B Vim +in Modo Vi, come se il programma eseguibile fosse "vi". Questo ha +effetto solo quando Vim viene invocato con il nome "ex". +.TP +\-w {scriptout} +Ogni carattere immesso viene registrato nel file {scriptout}, +finché non uscite da +.B Vim. +Utile se si vuole creare uno script file da usare con "vim \-s" o +":source!". +Se il file {scriptout} esiste, quel che immettete viene aggiunto in fondo. +.TP +\-W {scriptout} +Come \-w, ma uno script file esistente viene sovrascritto. +.TP +\-x +Uso di cifratura nella scrittura dei file. E' necessario immettere +una chiave di cifratura. +.TP +\-X +Non connetterti al server X. Vim parte più rapidamente, +ma il titolo della finestra e la clipboard non sono disponibili. +.TP +\-y +Eseguire +.B Vim +in Modo Easy (semplificata), come se l'eseguibile invocato +sia "evim" o "eview". +Fa sì che +.B Vim +si comporti come un editor che usa solo il mouse e i caratteri. +.TP +\-Z +Modo ristretto. Vim si comporta come se invocato con un nome +che inizia per "r". +.TP +\-\- +Specifica la fine delle opzioni. +Argomenti specificati dopo questo sono considerati nomi file. +Si può usare per editare un file il cui nome inizi per '-'. +.TP +\-\-echo\-wid +Solo con GUI GTK: Visualizza Window ID su "stdout". +.TP +\-\-help +Vim dà un messaggio ed esce, come con l'argomento "\-h". +.TP +\-\-literal +Considera i nomi passati come argomenti letterali, senza espandere +metacaratteri. Non necessario in Unix, la shell espande i metacaratteri. +.TP +\-\-noplugin +Non caricare plugin. Implicito se si specifica \-u NONE. +.TP +\-\-remote +Connettersi a un server Vim e chiedere di editare i file elencati come altri +argomenti. Se non si trova un server viene dato un messaggio e i file sono +editati nel Vim corrente. +.TP +\-\-remote\-expr {expr} +Connettersi a un server Vim, valutare ivi {expr} e stampare il risultato +su "stdout". +.TP +\-\-remote\-send {chiavi} +Connettersi a un server Vim e spedirgli {chiavi}. +.TP +\-\-remote\-silent +Come \-\-remote, ma senza avvisare se non si trova un server. +.TP +\-\-remote-wait +Come \-\-remote, ma Vim non termina finché i file non sono stati editati. +.TP +\-\-remote\-wait\-silent +Come \-\-remote\-wait, ma senza avvisare se non si trova un server. +.TP +\-\-serverlist +Lista i nomi di tutti i server Vim disponibili. +.TP +\-\-servername {nome} +Usa {nome} come nome server. Usato per il Vim corrente, a meno che sia +usato con l'argomento \-\-remote, nel qual caso indica il server a cui +connettersi. +.TP +\-\-socketid {id} +Solo con GUI GTK: Usa il meccanismo GtkPlug per eseguire gvim in un'altra +finestra. +.TP +\-\-version +Stampa la versione di Vim ed esci. +.SH AIUTO ONLINE +Battere ":help" in +.B Vim +per iniziare. +Battere ":help argomento" per ricevere aiuto su uno specifico argomento. +Per esempio: ":help ZZ" per ricevere aiuto sul comando "ZZ". +Usare <Tab> e CTRL\-D per completare gli argomenti +(":help cmdline\-completion"). +Ci sono "tag" nei file di help per saltare da un argomento a un altro +(simili a legami ipertestuali, vedere ":help"). +Tutti i file di documentazione possono essere navigati così. Ad es.: +":help syntax.txt". +.SH FILE +.TP 15 +/usr/local/lib/vim/doc/*.txt +I file di documentazione di +.B Vim +. +Usate ":help doc\-file\-list" per avere la lista completa. +.TP +/usr/local/lib/vim/doc/tags +Il file di tags usato per trovare informazioni nei file di documentazione. +.TP +/usr/local/lib/vim/syntax/syntax.vim +Inizializzazioni sintattiche a livello di sistema. +.TP +/usr/local/lib/vim/syntax/*.vim +File di colorazione sintattica per vari linguaggi. +.TP +/usr/local/lib/vim/vimrc +Inizializzazioni +.B Vim +a livello di sistema. +.TP +~/.vimrc +Le vostre personali inizializzazioni di +.B Vim +. +.TP +/usr/local/lib/vim/gvimrc +Inizializzazioni gvim a livello di sistema. +.TP +~/.gvimrc +Le vostre personali inizializzazioni di gvim. +.TP +/usr/local/lib/vim/optwin.vim +Script Vim usato dal comando ":options", un modo semplice +per visualizzare e impostare opzioni. +.TP +/usr/local/lib/vim/menu.vim +Inizializzazioni del menù gvim a livello di sistema. +.TP +/usr/local/lib/vim/bugreport.vim +Script Vim per generare una segnalazione di errore. Vedere ":help bugs". +.TP +/usr/local/lib/vim/filetype.vim +Script Vim per determinare il tipo di un file a partire dal suo nome. +Vedere ":help 'filetype'". +.TP +/usr/local/lib/vim/scripts.vim +Script Vim per determinare il tipo di un file a partire dal suo contenuto. +Vedere ":help 'filetype'". +.TP +/usr/local/lib/vim/print/*.ps +File usati per stampa PostScript. +.PP +Per informazioni aggiornate [in inglese \- NdT] vedere la home page di Vim: +.br +<URL:http://www.vim.org/> +.SH VEDERE ANCHE +vimtutor(1) +.SH AUTORE +Buona parte di +.B Vim +è stato scritto da Bram Moolenaar, con molto aiuto da altri. +Vedere ":help credits" in +.B Vim. +.br +.B Vim +è basato su Stevie, scritto da: Tim Thompson, +Tony Andrews e G.R. (Fred) Walter. +In verità, poco o nulla è rimasto del loro codice originale. +.SH BACHI +Probabili. +Vedere ":help todo" per una lista di problemi noti. +.PP +Si noti che un certo numero di comportamenti che possono essere considerati +errori da qualcuno, sono in effetti causati da una riproduzione fin troppo +fedele del comportamento di Vi. +Se ritenete che altre cose siano errori "perché Vi si comporta diversamente", +date prima un'occhiata al file vi_diff.txt +(o battere :help vi_diff.txt da Vim). +Date anche un'occhiata alle opzioni 'compatible' e 'cpoptions. diff --git a/share/vim/vim73/doc/vim-it.UTF-8.1 b/share/vim/vim73/doc/vim-it.UTF-8.1 new file mode 100644 index 0000000000..51e7e043da --- /dev/null +++ b/share/vim/vim73/doc/vim-it.UTF-8.1 @@ -0,0 +1,566 @@ +.TH VIM 1 "22 febbraio 2002" +.SH NOME +vim \- VI Migliorato, un editor di testi per programmatori +.SH SINTASSI +.br +.B vim +[opzioni] [file ..] +.br +.B vim +[opzioni] \- +.br +.B vim +[opzioni] \-t tag +.br +.B vim +[opzioni] \-q [file_errori] +.PP +.br +.B ex +.br +.B view +.br +.B gvim +.B gview +.B evim +.B eview +.br +.B rvim +.B rview +.B rgvim +.B rgview +.SH DESCRIZIONE +.B Vim +Un editore di testi, compatibile con, e migliore di, Vi. +Può essere usato per editare qualsiasi file di testo. +Particolarmente utile per editare programmi. +.PP +Ci sono parecchi miglioramenti rispetto a Vi: undo multipli, +finestre e buffer multipli, evidenziazione sintattica, possibilità +di modificare la linea di comando, completamento nomi file, help +in linea, selezione testi in Modo Visual, etc.. +Vedere ":help vi_diff.txt" per un sommario delle differenze fra +.B Vim +e Vi. +.PP +Mentre usate +.B Vim +potete ricevere molto aiuto dal sistema di help online, col comando ":help". +Vedere qui sotto la sezione AIUTO ONLINE. +.PP +Quasi sempre +.B Vim +viene invocato, per modificare un file, col comando +.PP + vim nome_file +.PP +Più in generale +.B Vim +viene invocato con: +.PP + vim [opzioni] [lista_file] +.PP +Se lista_file non è presente, l'editor inizia aprendo un buffer vuoto. +Altrimenti, una e una sola delle quattro maniere indicate qui sotto può +essere usata per scegliere uno o più file da modificare. +.TP 12 +nome_file .. +Una lista di nomi di file. +Il primo di questi sarà il file corrente, e verrà letto nel buffer. +Il cursore sarà posizionato sulla prima linea del buffer. +Potete arrivare agli altri file col comando ":next". +Per editare un file il cui nome inizia per "\-" premettete "\-\-" alla +lista_file. +.TP +\- +Il file da editare è letto dallo "stdin" [di solito, ma non +necessariamente, il terminale \- NdT]. I comandi sono letti da "stderr", +che dovrebbe essere un terminale [tty]. +.TP +\-t {tag} +Il file da editare e la posizione iniziale del cursore dipendono da "tag", +una specie di "etichetta" a cui saltare. +{tag} viene cercata nel file "tags", ed il file ad essa associato diventa +quello corrente, ed il comando ad essa associato viene eseguito. +Di solito si usa per programmi C, nel qual caso {tag} potrebbe essere un +nome di funzione. +L'effetto è che il file contenente quella funzione diventa il file corrente +e il cursore è posizionato all'inizio della funzione. +Vedere ":help tag\-commands". +.TP +\-q [file_errori] +Inizia in Modo QuickFix [correzione veloce]. +Il file [file_errori] è letto e il primo errore è visualizzato. +Se [file_errori] non è indicato, il suo nome è ottenuto dal valore +dell'opzione 'errorfile' (che, se non specificata, vale "AztecC.Err" +per l'Amiga, "errors.err" su altri sistemi). +Si può saltare all'errore successivo col comando ":cn". +Vedere ":help quickfix". +.PP +.B Vim +si comporta in modo diverso se invocato con nomi differenti (il programma +eseguibile "sottostante" può essere sempre lo stesso). +.TP 10 +vim +Modo Normal, comportamento normale. +.TP +ex +Inizia in Modo "Ex". +Si può passare in Modo Normal col comando ":vi". +Si può invocare il Modo "Ex" anche con l'argomento "\-e". +.TP +view +Inizia in Modo Read-only (Sola Lettura). Non potete modificare i file. +Si può invocare il Modo Read-only anche con l'argomento "\-R". +.TP +gvim gview +La versione GUI [Graphical User Interface]. +Apre una nuova finestra. +Si può invocare il Modo GUI anche con l'argomento "\-g". +.TP +evim eview +La versione GUI in Modo Easy (semplificata). +Apre una nuova finestra. +Si può invocare il Modo Easy anche con l'argomento "\-y". +.TP +rvim rview rgvim rgview +Come sopra, ma con restrizioni ai comandi. Non si potranno eseguire comandi +della shell o sospendere +.B Vim. +Si può chiedere la stessa cosa anche con l'argomento "\-Z". +.SH OPZIONI +Le opzioni possono essere in un ordine qualsiasi, prima o dopo i nomi di +file. Opzioni che non necessitano un argomento possono essere specificate +dietro a un solo "\-". +.TP 12 ++[numero] +Per il primo file il cursore sarà posizionato sulla linea "numero". +Se "numero" manca, il cursore sarà posizionato sull'ultima linea del file. +.TP ++/{espressione} +Per il primo file il cursore sarà posizionato alla +prima occorrenza di {espressione}. +Vedere ":help search\-pattern" per come specificare l'espressione. +.TP ++{comando} +.TP +\-c {comando} +{comando} sarà eseguito dopo che il +primo file è stato letto. +{comando} è interpretato come un comando Ex. +Se il {comando} contiene spazi deve essere incluso fra doppi apici +(o altro delimitatore, a seconda della shell che si sta usando). +Esempio: Vim "+set si" main.c +.br +Note: Si possono avere fino a 10 comandi "+" o "\-c". +.TP +\-S {file} +I comandi contenuti in {file} sono eseguiti dopo la lettura del primo file. +Equivalente a \-c "source {file}". +{file} non può avere un nome che inizia per '\-'. +Se {file} è omesso si usa "Session.vim" (funziona solo se \-S è l'ultimo +argomento specificato). +.TP +\-\-cmd {comando} +Come "\-c", ma il comando è eseguito PRIMA +di eseguire qualsiasi file vimrc. +Si possono usare fino a 10 di questi comandi, indipendentemente dai comandi +"\-c". +.TP +\-A +Se +.B Vim +è stato compilato con supporto Arabic per editare file con orientamento +destra-sinistra e tastiera con mappatura Araba, questa opzione inizia +.B Vim +in Modo Arabic, cioè impostando 'arabic'. +Altrimenti viene dato un messaggio di errore e +.B Vim +termina in modo anormale. +.TP +\-b +Modo Binary (binario). +Vengono impostate alcune opzioni che permettono di modificare un file +binario o un programma eseguibile. +.TP +\-C +Compatibile. Imposta l'opzione 'compatible'. +In questo modo +.B Vim +ha quasi lo stesso comportamento di Vi, anche in presenza di un file +di configurazione .vimrc [proprio di Vim, vi usa .exrc \- Ndt]. +.TP +\-d +Inizia in Modo Diff [differenze]. +Dovrebbero esserci come argomenti due o tre o quattro nomi di file. +.B Vim +aprirà tutti i file evidenziando le differenze fra gli stessi. +Funziona come vimdiff(1). +.TP +\-d {dispositivo} +Apre {dispositivo} per usarlo come terminale. +Solo per l'Amiga. +Esempio: +"\-d con:20/30/600/150". +.TP +\-D +Debugging. Vim si mette in Modo "debugging" a partire +dall'esecuzione del primo comando da uno script. +.TP +\-e +Eseguire +.B Vim +in Modo Ex, come se il programma eseguito sia "ex". +.TP +\-E +Eseguire +.B Vim +in Modo Ex migliorato, come se il programma eseguito sia "exim". +.TP +\-f +Direttamente [Foreground]. Per la versione GUI, +.B Vim +non crea [fork] una nuova finestra, indipendente dalla shell di invocazione. +Per l'Amiga, +.B Vim +non è fatto ripartire per aprire una nuova finestra. +Opzione da usare quando +.B Vim +è eseguito da un programma che attende la fine della +sessione di edit (ad es. mail). +Sull'Amiga i comandi ":sh" e ":!" non sono disponibili. +.TP +\-\-nofork +Direttamente [Foreground]. Per la versione GUI, +.B Vim +non crea [fork] una nuova finestra, indipendente dalla shell di invocazione. +.TP +\-F +Se +.B Vim +è stato compilato con supporto FKMAP per editare file con orientamento +destra-sinistra e tastiera con mappatura Farsi, questa opzione inizia +.B Vim +in Modo Farsi, cioè impostando 'fkmap' e 'rightleft'. +Altrimenti viene dato un messaggio di errore e +.B Vim +termina in modo anormale. +.TP +\-g +Se +.B Vim +è stato compilato con supporto GUI, questa opzione chiede di usarla. +Se Vim è stato compilato senza supporto GUI viene dato un messaggio di errore e +.B Vim +termina in modo anormale. +.TP +\-h +Un po' di aiuto su opzioni e argomenti che si possono dare invocando Vim. +Subito dopo +.B Vim +esce. +.TP +\-H +Se +.B Vim +è stato compilato col supporto RIGHTLEFT per editare file con orientamento +destra-sinistra e tastiera con mappatura Ebraica, questa opzione inizia +.B Vim +in Modo Ebraico, cioè impostando 'hkmap' e 'rightleft'. +Altrimenti viene dato un messaggio di errore e +.B Vim +termina in modo anormale. +.TP +\-i {viminfo} +Se è abilitato l'uso di un file viminfo, questa opzione indica il nome +del file da usare invece di quello predefinito "~/.viminfo". +Si può anche evitare l'uso di un file .viminfo, dando come nome "NONE". +.TP +\-L +Equivalente a \-r. +.TP +\-l +Modo Lisp. +Imposta le opzioni 'lisp' e 'showmatch'. +.TP +\-m +Inibisce modifica file. +Annulla l'opzione 'write'. +È ancora possibile modificare un buffer [in memoria \- Ndt], ma non scriverlo. +.TP +\-M +Modifiche non permesse. Le opzioni 'modifiable' e 'write' sono annullate, +in modo da impedire sia modifiche che riscritture. Da notare che queste +opzioni possono essere abilitate in seguito, permettendo così modifiche. +.TP +\-N +Modo "Non-compatibile". Annulla l'opzione 'compatible'. +Così +.B Vim +va un po' meglio, ma è meno compatibile con Vi, anche in assenza di un +file .vimrc. +.TP +\-n +Inibisce l'uso di un file di swap. +Il recupero dopo una caduta di macchina diventa impossibile. +Utile per editare un file su un supporto molto lento (ad es. floppy). +Il comando ":set uc=0" ha lo stesso effetto. +Per abilitare il recupero usare ":set uc=200". +.TP +\-nb +Diviene un Editor server per NetBeans. Vedere la documentazione per dettagli. +.TP +\-o[N] +Apri N finestre in orizzontale. +Se N manca, apri una finestra per ciascun file. +.TP +\-O[N] +Apri N finestre, in verticale. +Se N manca, apri una finestra per ciascun file. +.TP +\-R +Modo Read-only (Sola Lettura). +Imposta l'opzione 'readonly'. +Si può ancora modificare il buffer, ma siete protetti da una riscrittura +involontaria. +Se volete davvero riscrivere il file, aggiungete un punto esclamativo +al comando Ex, come in ":w!". +L'opzione \-R implica anche l'opzione \-n (vedere sotto). +L'opzione 'readonly' può essere annullata con ":set noro". +Vedere ":help 'readonly'". +.TP +\-r +Lista file di swap, assieme a dati utili per un recupero. +.TP +\-r {file} +Modo Recovery (ripristino). +Il file di swap è usato per recuperare una sessione di edit finita male. +Il file di swap è un file con lo stesso nome file del file di testo +editato, col suffisso ".swp". +Vedere ":help recovery". +.TP +\-s +Modo silenzioso. Solo quando invocato come "Ex" o quando l'opzione +"\-e" è stata data prima dell'opzione "\-s". +.TP +\-s {scriptin} +Lo script file {scriptin} è letto. +I caratteri nel file sono interpretati come se immessi da voi. +Lo stesso si può ottenere col comando ":source! {scriptin}". +Se la fine del file di input viene raggiunta prima che Vim termini, +l'ulteriore input viene preso dalla tastiera. +.TP +\-T {terminale} +Dice a +.B Vim +quale tipo di terminale state usando. +Utile solo se il terminale non viene riconosciuto correttamente da Vim. +Dovrebbe essere un terminale noto a +.B Vim +(internamente) o definito nel file termcap o terminfo. +.TP +\-u {vimrc} +Usa i comandi nel file {vimrc} per inizializzazioni. +Tutte le altre inizializzazioni non sono eseguite. +Usate questa opzione per editare qualche file di tipo speciale. +Può anche essere usato per non fare alcuna inizializzazione dando +come nome "NONE". +Vedere ":help initialization" da vim per ulteriori dettagli. +.TP +\-U {gvimrc} +Usa i comandi nel file {gvimrc} per inizializzazioni GUI. +Tutte le altre inizializzazioni GUI non sono eseguite. +Può anche essere usata per non fare alcuna inizializzazione GUI dando +come nome "NONE". +Vedere ":help gui-init" da vim per ulteriori dettagli. +.TP +\-V[N] +Verboso. Vim manda messaggi relativi agli script file che esegue +e quando legge o scrive un file viminfo. Il numero opzionale N è il valore +dell'opzione 'verbose'. +Il valore predefinito è 10. +.TP +\-v +Inizia +.B Vim +in Modo Vi, come se il programma eseguibile fosse "vi". Questo ha +effetto solo quando Vim viene invocato con il nome "ex". +.TP +\-w {scriptout} +Ogni carattere immesso viene registrato nel file {scriptout}, +finché non uscite da +.B Vim. +Utile se si vuole creare uno script file da usare con "vim \-s" o +":source!". +Se il file {scriptout} esiste, quel che immettete viene aggiunto in fondo. +.TP +\-W {scriptout} +Come \-w, ma uno script file esistente viene sovrascritto. +.TP +\-x +Uso di cifratura nella scrittura dei file. E' necessario immettere +una chiave di cifratura. +.TP +\-X +Non connetterti al server X. Vim parte più rapidamente, +ma il titolo della finestra e la clipboard non sono disponibili. +.TP +\-y +Eseguire +.B Vim +in Modo Easy (semplificata), come se l'eseguibile invocato +sia "evim" o "eview". +Fa sì che +.B Vim +si comporti come un editor che usa solo il mouse e i caratteri. +.TP +\-Z +Modo ristretto. Vim si comporta come se invocato con un nome +che inizia per "r". +.TP +\-\- +Specifica la fine delle opzioni. +Argomenti specificati dopo questo sono considerati nomi file. +Si può usare per editare un file il cui nome inizi per '-'. +.TP +\-\-echo\-wid +Solo con GUI GTK: Visualizza Window ID su "stdout". +.TP +\-\-help +Vim dà un messaggio ed esce, come con l'argomento "\-h". +.TP +\-\-literal +Considera i nomi passati come argomenti letterali, senza espandere +metacaratteri. Non necessario in Unix, la shell espande i metacaratteri. +.TP +\-\-noplugin +Non caricare plugin. Implicito se si specifica \-u NONE. +.TP +\-\-remote +Connettersi a un server Vim e chiedere di editare i file elencati come altri +argomenti. Se non si trova un server viene dato un messaggio e i file sono +editati nel Vim corrente. +.TP +\-\-remote\-expr {expr} +Connettersi a un server Vim, valutare ivi {expr} e stampare il risultato +su "stdout". +.TP +\-\-remote\-send {chiavi} +Connettersi a un server Vim e spedirgli {chiavi}. +.TP +\-\-remote\-silent +Come \-\-remote, ma senza avvisare se non si trova un server. +.TP +\-\-remote-wait +Come \-\-remote, ma Vim non termina finché i file non sono stati editati. +.TP +\-\-remote\-wait\-silent +Come \-\-remote\-wait, ma senza avvisare se non si trova un server. +.TP +\-\-serverlist +Lista i nomi di tutti i server Vim disponibili. +.TP +\-\-servername {nome} +Usa {nome} come nome server. Usato per il Vim corrente, a meno che sia +usato con l'argomento \-\-remote, nel qual caso indica il server a cui +connettersi. +.TP +\-\-socketid {id} +Solo con GUI GTK: Usa il meccanismo GtkPlug per eseguire gvim in un'altra +finestra. +.TP +\-\-version +Stampa la versione di Vim ed esci. +.SH AIUTO ONLINE +Battere ":help" in +.B Vim +per iniziare. +Battere ":help argomento" per ricevere aiuto su uno specifico argomento. +Per esempio: ":help ZZ" per ricevere aiuto sul comando "ZZ". +Usare <Tab> e CTRL\-D per completare gli argomenti +(":help cmdline\-completion"). +Ci sono "tag" nei file di help per saltare da un argomento a un altro +(simili a legami ipertestuali, vedere ":help"). +Tutti i file di documentazione possono essere navigati così. Ad es.: +":help syntax.txt". +.SH FILE +.TP 15 +/usr/local/lib/vim/doc/*.txt +I file di documentazione di +.B Vim +. +Usate ":help doc\-file\-list" per avere la lista completa. +.TP +/usr/local/lib/vim/doc/tags +Il file di tags usato per trovare informazioni nei file di documentazione. +.TP +/usr/local/lib/vim/syntax/syntax.vim +Inizializzazioni sintattiche a livello di sistema. +.TP +/usr/local/lib/vim/syntax/*.vim +File di colorazione sintattica per vari linguaggi. +.TP +/usr/local/lib/vim/vimrc +Inizializzazioni +.B Vim +a livello di sistema. +.TP +~/.vimrc +Le vostre personali inizializzazioni di +.B Vim +. +.TP +/usr/local/lib/vim/gvimrc +Inizializzazioni gvim a livello di sistema. +.TP +~/.gvimrc +Le vostre personali inizializzazioni di gvim. +.TP +/usr/local/lib/vim/optwin.vim +Script Vim usato dal comando ":options", un modo semplice +per visualizzare e impostare opzioni. +.TP +/usr/local/lib/vim/menu.vim +Inizializzazioni del menù gvim a livello di sistema. +.TP +/usr/local/lib/vim/bugreport.vim +Script Vim per generare una segnalazione di errore. Vedere ":help bugs". +.TP +/usr/local/lib/vim/filetype.vim +Script Vim per determinare il tipo di un file a partire dal suo nome. +Vedere ":help 'filetype'". +.TP +/usr/local/lib/vim/scripts.vim +Script Vim per determinare il tipo di un file a partire dal suo contenuto. +Vedere ":help 'filetype'". +.TP +/usr/local/lib/vim/print/*.ps +File usati per stampa PostScript. +.PP +Per informazioni aggiornate [in inglese \- NdT] vedere la home page di Vim: +.br +<URL:http://www.vim.org/> +.SH VEDERE ANCHE +vimtutor(1) +.SH AUTORE +Buona parte di +.B Vim +è stato scritto da Bram Moolenaar, con molto aiuto da altri. +Vedere ":help credits" in +.B Vim. +.br +.B Vim +è basato su Stevie, scritto da: Tim Thompson, +Tony Andrews e G.R. (Fred) Walter. +In verità, poco o nulla è rimasto del loro codice originale. +.SH BACHI +Probabili. +Vedere ":help todo" per una lista di problemi noti. +.PP +Si noti che un certo numero di comportamenti che possono essere considerati +errori da qualcuno, sono in effetti causati da una riproduzione fin troppo +fedele del comportamento di Vi. +Se ritenete che altre cose siano errori "perché Vi si comporta diversamente", +date prima un'occhiata al file vi_diff.txt +(o battere :help vi_diff.txt da Vim). +Date anche un'occhiata alle opzioni 'compatible' e 'cpoptions. diff --git a/share/vim/vim73/doc/vim-pl.1 b/share/vim/vim73/doc/vim-pl.1 new file mode 100644 index 0000000000..d506b33c98 --- /dev/null +++ b/share/vim/vim73/doc/vim-pl.1 @@ -0,0 +1,558 @@ +.TH VIM 1 "2006 kwi 11" +.SH NAME +vim \- Vi rozbudowany, edytor tekstu dla programisty +.SH SYNOPSIS +.br +.B vim +[opcje] [plik ..] +.br +.B vim +[opcje] \- +.br +.B vim +[opcje] \-t znacznik +.br +.B vim +[opcje] \-q [plik_b³êdu] +.PP +.br +.B ex +.br +.B view +.br +.B gvim +.B gview +.B evim +.B eview +.br +.B rvim +.B rview +.B rgvim +.B rgview +.SH OPIS +.B Vim +jest edytorem tekstu kompatybilnym z Vi. Mo¿e byæ +u¿ywany do edycji wszelkiego rodzaju plików tekstowych. +U¿yteczny zw³aszcza przy edycji programów. +.PP +Posiada wiele usprawnieñ w porównaniu z Vi: wielopoziomowe cofanie zmian, +wiele okien i buforów, pod¶wietlanie sk³adni, edycja linii poleceñ, +uzupe³nianie nazw plików, pomoc on-line, wizualna selekcja, itd. +Zobacz ":help vi_diff.txt" dla podsumowania ró¿nic pomiêdzy +.B Vimem +i Vi. +.PP +W czasie korzystania z +.B Vima +mo¿na uzyskaæ obszern± pomoc z systemu pomocy on-line dziêki poleceniu ":help". +Zobacz rozdzia³ POMOC ON-LINE poni¿ej. +.PP +Najczê¶ciej +.B Vim +jest uruchamiany do edycji pojedynczego pliku poleceniem +.PP + vim plik +.PP +Bardziej ogólnie +.B Vim +jest uruchamiany poprzez: +.PP + vim [opcje] [lista plików] +.PP +Je¶li brak listy plików edytor rozpocznie z pustym buforem. W innym +wypadku istnieje dok³adnie jedna z czterech mo¿liwo¶ci by wybraæ jeden +lub wiêcej plików do edycji. +.TP 12 +plik .. +Lista nazw plików. +Pierwsza nazwa bêdzie nazw± bie¿±cego pliku, który zostanie wczytany +do bufora. Kursor zostanie umieszczony w pierwszym wierszu. Do +kolejnych plików mo¿na przej¶æ dziêki poleceniu ":next". By otworzyæ +plik, którego nazwa zaczyna siê od my¶lnika nale¿y listê plików +poprzedziæ "\-\-". +.TP +\- +Plik do edycji jest wczytany ze standardowego wej¶cia. Polecenia s± +odczytywane ze standardowego wyj¶cia b³êdów, którym powinien byæ +terminal (tty). +.TP +\-t {znacznik} +Plik do edycji i pocz±tkowa pozycja kursora zale¿y od "znacznika", +rodzaju etykiety goto. +{znacznika} szuka siê w pliku tags, zwi±zany z nim plik staje siê +plikiem bie¿±cym i wykonuje siê powi±zane polecenie. +Zazwyczaj u¿ywa siê tego sposobu dla programów w C, w których wypadku +{znacznik} mo¿e byæ nazw± funkcji. +W efekcie plik zawieraj±cy okre¶lon± funkcjê staje siê plikiem +bie¿±cym a kursor jest umieszczony na pocz±tku funkcji. +Zobacz ":help tag-commands". +.TP +\-q [plik_b³êdów] +Zacznij w trybie quickFix. +Plik [plik_b³êdów] zostaje zinterpretowany i poka¿e siê pierwszy b³±d. +Je¶li brak opcji [plik_b³êdów] nazwa pliku zostanie pobrana z opcji +\&'errorfile' (domy¶lnie "AztecC.Err" dla Amigi, "errros.err" dla innych +systemów. +Do kolejnych b³êdów mo¿na przeskoczyæ dziêki poleceniu ":cn". +Zobacz ":help quickfix". +.PP +W zale¿no¶ci od wywo³ania +.B Vim +zachowuje siê inaczej (program mo¿e byæ ca³y czas tym samym +plikiem). +.TP 10 +vim +"Normalny" sposób, wszystko jest domy¶lne. +.TP +ex +Zacznij w trybie Ex. +Przejd¼ do trybu Normalnego poleceniem ":vi". +Mo¿na tak¿e uruchomiæ poprzez argument "\-e". +.TP +view +Zacznij w trybie tylko do odczytu. W ten sposób bêdziesz chroniony +przed zapisywaniem pliku. Mo¿na tak¿e uruchomiæ poprzez argument +"\-R". +.TP +gvim gview +Wersja GUI. +Uruchamia nowe okno. +Mo¿na tak¿e uruchomiæ poprzez argument "\-g". +.TP +evim eview +Wersja GUI w ³atwym trybie. +Uruchamia nowe okno. +Mo¿na tak¿e uruchomiæ poprzez argument "\-y". +.TP +rvim rview rgvim rgview +Podobnie jak powy¿ej, ale z ograniczeniami. Nie bêdzie mo¿na uruchomiæ +poleceñ pow³oki lub zawiesiæ +.B Vima. +Mo¿na tak¿e uruchomiæ poprzez argument "\-Z". +.SH OPCJE +Opcje mo¿na podaæ w dowolnej kolejno¶ci, przed lub po nazwach plików. +Opcje bez argumentów mo¿na ³±czyæ po pojedynczym my¶lniku. +.TP 12 ++[num] +W pierwszym pliku kursor zostanie umieszczony w wierszu "num". +Je¶li brak "num" kursor zostanie umieszczony w ostatnim wierszu. +.TP ++/{wzór} +W pierwszym pliku kursor zostanie umieszczony na pierwszym wyst±pieniu +{wzór}. +Zobacz ":help search-pattern" by dowiedzieæ siê jakie s± mo¿liwe +wzorce wyszukiwania. +.TP ++{polecenie} +.TP +\-c {polecenie} +{polecenie} zostanie wykonane po tym jak wczyta siê pierwszy plik. +{polecenie} jest interpretowane jako polecenie Ex. +Je¶li {poleceni} zawiera bia³e znaki musi byæ umieszczone w podwójnych +cudzys³owach (zale¿y to od u¿ywanej pow³oki). +Przyk³ad: Vim "+set si" main.c +.br +Uwaga: Mo¿na u¿yæ do 10 poleceñ "+" lub "\-c". +.TP +\-S {plik} +{plik} zostanie zinterpretowany po wczytaniu pierwszego pliku. +Jest równowa¿ne \-c "source {plik}". +{plik} nie mo¿e zaczynaæ siê '\-'. +Je¶li nie podano {plik} zostanie u¿yty "Session.vim" (dzia³a tylko +wtedy je¶li \-S jest ostatnim argumentem). +.TP +\-\-cmd {polecenie} +Podobne do "\-c", ale polecenie jest wykonywane tu¿ przed +interpretacj± jakiegokolwiek pliku vimrc. +Mo¿na u¿yæ do 10 takich poleceñ, niezale¿nie od poleceñ od "\-c" +.TP +\-A +Je¶li +.B Vim +zosta³ skompilowany ze wsparciem dla jêzyków arabskich (edycja od +prawej do lewej i arabska mapa klawiatury) ta opcja uruchamia +.B Vima +w trybie arabskim, np. ustawia siê opcja 'arabic'. W innym wypadku +pojawi siê komunikat b³êdu i +.B Vim +zakoñczy dzia³anie. +.TP +\-b +Tryb binarny. +Ustawi siê kilka opcji, które umo¿liwi± edycjê plików binarnych lub +wykonywalnych. +.TP +\-C +Kompatybilny. Ustawia opcjê 'compatible'. +W ten sposób +.B Vim +bêdzie zachowywa³ siê jak Vi, nawet je¶li istnieje plik .vimrc. +.TP +\-d +Uruchom w trybie diff. +Powinno siê u¿yæ dwóch, trzech lub czterech nazwy plików jako argumentów. +.B Vim +otworzy wszystkie te pliki i poka¿e ró¿nice miêdzy nimi. +Dzia³a jak vimdiff(1). +.TP +\-d {urz±dzenie} +Otwórz {urz±dzenie} by u¿ywaæ jako terminal. +Tylko na Amidze. +Przyk³ad: +"\-d con:20/30/600/150". +.TP +\-D +Debugowanie. Przejd¼ do trybu debugowanie wykonuj±c pierwsze polecenie +ze skryptu. +.TP +\-e +Uruchom +.B Vima +w trybie Ex, dzia³a tak samo jakby wywo³ano program jako "ex". +.TP +\-E +Uruchom +.B Vima +w ulepszonym trybie Ex, dzia³a tak samo jakby wywo³ano program jako +"exim". +.TP +\-f +Pierszy plan. Dla wersji GUI. +.B Vim +nie nie oddzieli siê od pow³oki w jakiej zosta³ uruchomiony. Na Amidze +.B Vim +nie jest uruchomiony ponownie by otworzyæ nowe okno. +Opcja powinna byæ u¿yta kiedy +.B Vim +jest wywo³ywany przez program, który ma zaczekaæ na koniec sesji (np. +mail). +Na Amidze polecenia ":sh" i ":!" nie bêd± dzia³aæ. +.TP +\-\-nofork +Pierwszy plan. Dla wersji GUI. +.B Vim +nie oddzieli siê od pow³oki w jakiej zosta³ uruchomiony. +.TP +\-F +Je¶li Vim zosta³ skompilowany ze wsparciem FKMAP dla edycji tekstów od +prawej do lewej i mapowania klawiatury Farsi, ta opcja uruchomi +.B Vima +w trybie Farsi, np. zostawi± ustawione opcje 'fkmap' i 'rightleft'. +W innym wypadku pojawi siê komunikat b³êdu i +.B Vim +zakoñczy dzia³anie. +.TP +\-g +Je¶li +.B Vim +zosta³ skompilowany ze wsparciem dla GUI ta opcja uruchomi GUI. +W innym wypadku pojawi siê komunikat b³êdu i +.B Vim +zakoñczy dzia³anie. +.TP +\-h +Wy¶wietli krótk± pomoc o argumentach linii poleceñ i opcjach. Potem +.B Vim +zakoñczy dzia³anie. +.TP +\-H +Je¶li +.B Vim +zosta³ skompilowany ze wsparciem RIGHTLEFT dla edycji od prawej do +lewej oraz ma mapowanie klawiatury dla hebrajskiego, ta opcja uruchomi +.B Vima +w trybie hebrajskim, np. ustawi opcje 'hkmap' i 'rightleft'. +W innym wypadku pojawi siê komunikat b³êdu i +.B Vim +zakoñczy dzia³anie. +.TP +\-i {viminfo} +Kiedy +.B Vim +u¿ywa pliku viminfo ta opcja wska¿e jakiego pliku u¿yæ zamiast +domy¶lnego "~/.viminfo". +Mo¿na te¿ omin±æ u¿ycie pliku .viminfo przez podanie nazwy "NONE". +.TP +\-L +To samo co \-r. +.TP +\-l +Tryb Lisp. +Ustawia opcje 'lisp' i 'showmatch'. +.TP +\-m +Zmiana pliku jest niemo¿liwa. +Przestawia opcjê 'write'. +Mo¿na zmieniaæ zawarto¶æ bufora, ale zapisanie pliku nie jest +mo¿liwe. +.TP +\-M +Opcje 'modifiable' i 'write' zostan± wy³±czone, tak wiêc zmiany +w pliku oraz ich zapisanie nie s± mo¿liwe. Warto¶æ tych opcji mo¿na +zmieniæ. +.TP +\-N +Tryb niekompatybilny. Przestawia opcjê 'compatible'. Dziêki temu +.B Vim +bêdzie zachowywa³ siê odrobinê lepiej, ale mniej zgodnie z Vi nawet +je¶li nie istnieje plik .vimrc. +.TP +\-n +Nie powstanie plik wymiany. Odzyskanie pliku po wypadku nie bêdzie +mo¿liwe. +Wygodne je¶li instnieje potrzeba edycji na bardzo wolnym medium (np. +dyskietce). Ten cel mo¿na osi±gn±æ tak¿e przez ":set uc=0". Mo¿na +odwróciæ przez ":set uc=200". +.TP +\-nb +Uruchom jako serwer edytora dla NetBeans. Zobacz dokumentacjê by +dowiedzieæ siê wiêcej. +.TP +\-o[N] +Otwórz N okien w stosie. +Kiedy brak N, otwórz jedno okno dla ka¿dego pliku. +.TP +\-O[N] +Otwórz N okien obok siebie. +Kiedy brak N, otwórz jedno okno dla ka¿dego pliku. +.TP +\-p[N] +Otwórz N kart. +Kiedy brak N, otwórz jedn± kartê dla ka¿dego pliku. +.TP +\-R +Tryb tylko do odczytu. +Zostanie ustawiona opcja 'readonly'. +Ca³y czas mo¿na zmieniaæ bufor, ale bêdzie istnia³a blokada by chroniæ +przed przypadkowym zapisaniem pliku. +Je¶li chcesz zapisaæ plik dodaj wykrzyknik do polecenia Ex, np. ":w!". +Opcja \-R implikuje opcjê \-n (zobacz poni¿ej). +Opcja 'readonly' mo¿e zostaæ przestawiona poprzez ":set noro". +Zobacz ":help 'readonly'". +.TP +\-r +Wypisz listê plików wymiany razem z informacjami o nich. +.TP +\-r {plik} +Tryb odzyskiwania danych. +Plik wymiany zostanie wykorzystany do odzyskania gwa³townie przerwanej sesji. +Plik wymiany to plik z tak± sam± nazw± co plik oryginalny z dodanym ".swp". +Zobacz ":help recovery". +.TP +\-s +Tryb cichy. Rozpoczêty tylko kiedy uruchomiony jako "Ex" lub opcja +"\-e" zosta³a podana przed opcj± "\-s". +.TP +\-s {skrypt} +Zostanie wczytany plik {skrypt}. +Znaki w pliku zostan± zinterpretowane jakby by³y wpisywane. +To samo mo¿na osi±gn±æ poprzez polecenie ":source! {skrypt}". +Je¶li osi±gniêto koniec pliku zanim edytor zakoñczy³ dzia³anie, dalsze +znaki odczytywane s± z klawiatury. +.TP +\-T {terminal} +Przekazuje +.B Vimowi +nazwê terminalu jakiego u¿ywasz. +Wymagane tylko wtedy je¶li nie dzia³a automatycznie. +Powinien byæ to terminal znany +.B Vimowi +(builtin) lub zdefiniowany w plikach termcap lub terminfo. +.TP +\-u {vimrc} +U¿yj poleceñ z pliku {vimrc} w czasie uruchamiania. +Wszystkie inne mo¿liwe pliki uruchamiania zostan± pominiête. +U¿ywaj do edytowania plików specjalnych. +Mo¿na pomin±æ tak¿e wszystkie mo¿liwe pliki uruchamiania poprzez +podanie nazwy "NONE". +Zobacz ":help initialization" by poznaæ wiêcej szczegó³ów. +.TP +\-U {gvimrc} +U¿yj poleceñ z pliku {gvimrc} w czasie uruchamiania GUI. +Wszystkie inne mo¿liwe pliki uruchamiania GUI zostan± pominiête. +Mo¿na pomin±æ tak¿e wszystkie mo¿liwe pliki uruchamiania GUI poprzez +podanie nazwy "NONE". +Zobacz ":help gui-init" by poznaæ wiêcej szczegó³ów. +.TP +\-V[N] +Tryb gadatliwy. Wypisz wiadomo¶ci o tym jaki pliki s± wczytywane +i o informacjach pobieranych i dodawanych do pliku viminfo. Opcjonalny +argument N jest warto¶ci± 'verbose'. Domy¶lnie 10. +.TP +\-v +Uruchom +.B Vima +w trybie Vi, tak jakby program by³ nazwany "vi". Ma znaczenie +tylko wtedy je¶li program nazwany jest "ex". +.TP +\-w {plik} +Wszystkie wci¶niêcia klawiszy, a¿ do zakoñczenia dzia³ania programu, +s± zapisywane w {plik} . +U¿yteczne je¶li chce siê stworzyæ skrypt do u¿ycia z "vim \-s" lub +":source!". +Je¶li {plik} istnieje, znaki s± dopisywane. +.TP +\-W {plik} +Podobnie do \-w, ale istniej±cy plik jest nadpisywany. +.TP +\-x +U¿yj szyfrowania podczas zapisywania plików. Zostaniesz poproszony +o podanie klucza. +.TP +\-X +Nie ³±cz z serwerem X. Skraca czas uruchamiania w terminalu, ale tytu³ +okna i schowek nie bêd± wykorzystywane. +.TP +\-y +Uruchom +.B Vima +w ³atwym trybie, tak jakby program zosta³ wywo³any "evim" lub "eview". +.B Vim +bêdzie zachowywa³ siê bardziej jak edytor kliknij-i-wpisz. +.TP +\-Z +Tryb ograniczony. Zachowuje siê jakby nazwa programu zaczyna³a siê od +"r". +.TP +\-\- +Oznacza koniec opcji. +Argumenty po tej opcji bêd± traktowane jak nazwy plików. U¿ywa siê do +otwierania plików, których nazwy zaczynaj± siê od '\-'. +.TP +\-\-echo\-wid +Wy³±cznie GTK GUI: wypisz ID okna na standardowe wyj¶cie. +.TP +\-\-help +Wy¶wietl informacjê o pomocy i zakoñczy, to samo co"\-h". +.TP +\-\-literal +Potraktuj nazwy plików dos³ownie i nie rozwi±zuj kwantyfikatorów. Nie +ma znaczenia na Uniksach gdzie pow³oka rozwi±zuje kwantyfikatory. +.TP +\-\-noplugin +Pomiñ ³adowanie wtyczek. Implikowane przy \-u NONE. +.TP +\-\-remote +Po³±cz siê z serwerem Vima i edytuj w nim resztê plików podanych jako +argumenty. Je¶li nie znaleziono serwera zostanie zg³oszony b³±d a pliki zostan± +otwarte w bie¿±cym Vimie. +.TP +\-\-remote\-expr {wyra¿enie} +Po³±cz z serwerem Vima, rozwi±¿ w nim {wyra¿enie} i wypisz rozwi±zanie +na standardowe wyj¶cie. +.TP +\-\-remote\-send {klawisze} +Po³±cz z serwerem Vima i wy¶lij do niego {klawisze}. +.TP +\-\-remote\-silent +Tak samo jak \-remote, ale bez ostrze¿enia kiedy nie znaleziono +serwera. +.TP +\-\-remote\-wait +Tak samo jak \-remote, ale Vim nie zakoñczy dopóki pliki pozostan± +otwarte. +.TP +\-\-remote\-wait\-silent +Tak samo jak \-\-remote\-wait, ale bez ostrze¿enie kiedy nie +znaleziono serwera. +.TP +\-\-serverlist +Wypisz nazwy wszystkich serwerów Vima jakie mo¿na znale¼æ. +.TP +\-\-servername {nazwa} +U¿yj {nazwa} jako nazwy serwera. Wykorzystane dla bie¿±cego Vima o ile +nie po³±czone z argumentem \-\-remote, wtedy jest to nazwa serwera do +po³±czenia. +.TP +\-\-socketid {id} +Wy³±cznie GTK GUI: U¿yj mechanizmu GtkPlug by uruchomiæ gvima w innym +oknie. +.TP +\-\-version +Wypisz informacjê o wersji i zakoñcz. +.SH POMOC ON-LINE +By rozpocz±æ wpisz ":help" w +.B Vimie +Wpisz ":help temat" by uzyskaæ pomoc na okre¶lony temat. +Przyk³ad: ":help ZZ" by uzyskaæ pomoc na temat polecenia "ZZ". +U¿yj <Tab> i CTRL\-D aby uzupe³niæ tematy (":help +cmdline\-completion"). W plikach pomocy istniej± znaczniki by u³atwiæ +skakanie z jednego miejsca do innego (rodzaj linków hipertekstowych, +zobacz ":help"). +Mo¿na w ten sposób zobaczyæ ca³± dokumentacjê, np. ":help syntax.txt". +.SH PLIKI +.TP 15 +/usr/local/lib/vim/doc/*.txt +Dokumentacja +.B Vima +U¿yj ":help doc\-file\-list" aby uzyskaæ pe³n± listê. +.TP +/usr/local/lib/vim/doc/tags +Plik znaczników s³u¿y do znajdowania informacji w plikach dokumentacji. +.TP +/usr/local/lib/vim/syntax/syntax.vim +Globalne uruchamianie pod¶wietlania sk³adni. +.TP +/usr/local/lib/vim/syntax/*.vim +Pliki sk³adni dla ró¿nych jêzyków. +.TP +/usr/local/lib/vim/vimrc +Globalny plik uruchamiania +.B Vima +.TP +~/.vimrc +Osobiste parametry uruchamiania +.B Vima +.TP +/usr/local/lib/vim/gvimrc +Globalne uruchamianie gvima. +.TP +~/.gvimrc +Osobiste parametry uruchamiania gvima. +.TP +/usr/local/lib/vim/optwin.vim +Skrypt u¿ywany w poleceniu ":options", dobry sposób do przegl±dania +i ustawiania opcji. +.TP +/usr/local/lib/vim/menu.vim +Globalne uruchamianie menu gvima. +.TP +/usr/local/lib/vim/bugreport.vim +Skrypt s³u¿±cy do tworzenia raportów o b³êdach. Zobacz ":help bugs". +.TP +/usr/local/lib/vim/filetype.vim +Skrypt do wykrywania typu pliku wed³ug jego nazwy. Zobacz ":help 'filetype'". +.TP +/usr/local/lib/vim/scripts.vim +Skrypt do wykrywania typu pliku wed³ug jego zawarto¶ci. Zobacz ":help 'filetype'". +.TP +/usr/local/lib/vim/print/*.ps +Pliku u¿ywane do drukowania PostScriptu. +.PP +Naj¶wie¿sze wiadomo¶ci na stronie +.B Vima: +.br +<URL:http://www.vim.org/> +.SH ZOBACZ TAK¯E +vimtutor(1) +.SH AUTOR +.B Vim +zosta³ napisany przez Brama Moolenaara z du¿± pomoc± innych osób. +Zobacz ":help credits" w +.B Vimie. +.br +.B Vim +bazuje na Steviem, nad którym pracowali: Tim Thompson, Tony Andrews +i G.R. (Fred) Walter. +Ma³o ju¿ zosta³o z oryginalnego kodu. +.SH B£ÊDY +Prawdopodobne. +Zobacz ":help todo" by poznaæ listê znanych problemów. +.PP +Pamiêtaj ¿e pewna ilo¶æ problemów, które mog± byæ uznawane przez +niektórych ludzi za b³êdy s± w rzeczywisto¶ci spowodowane wierno¶ci± +w odtwarzaniu zachowania Vi. +Je¶li s±dzisz, ¿e inne rzeczy s± b³êdami "poniewa¿ Vi robi to +inaczej", powiniene¶ przyjrzeæ siê bli¿ej plikowi vi_diff.txt (lub +wpisaæ ":help vi_diff.txt" w Vimie). +Sprawd¼ tak¿e opis opcji 'compatible' i 'cpoptions'. diff --git a/share/vim/vim73/doc/vim-pl.UTF-8.1 b/share/vim/vim73/doc/vim-pl.UTF-8.1 new file mode 100644 index 0000000000..f3551d2f63 --- /dev/null +++ b/share/vim/vim73/doc/vim-pl.UTF-8.1 @@ -0,0 +1,558 @@ +.TH VIM 1 "2006 kwi 11" +.SH NAME +vim \- Vi rozbudowany, edytor tekstu dla programisty +.SH SYNOPSIS +.br +.B vim +[opcje] [plik ..] +.br +.B vim +[opcje] \- +.br +.B vim +[opcje] \-t znacznik +.br +.B vim +[opcje] \-q [plik_błędu] +.PP +.br +.B ex +.br +.B view +.br +.B gvim +.B gview +.B evim +.B eview +.br +.B rvim +.B rview +.B rgvim +.B rgview +.SH OPIS +.B Vim +jest edytorem tekstu kompatybilnym z Vi. Może być +używany do edycji wszelkiego rodzaju plików tekstowych. +Użyteczny zwłaszcza przy edycji programów. +.PP +Posiada wiele usprawnień w porównaniu z Vi: wielopoziomowe cofanie zmian, +wiele okien i buforów, podświetlanie składni, edycja linii poleceń, +uzupełnianie nazw plików, pomoc on-line, wizualna selekcja, itd. +Zobacz ":help vi_diff.txt" dla podsumowania różnic pomiędzy +.B Vimem +i Vi. +.PP +W czasie korzystania z +.B Vima +można uzyskać obszerną pomoc z systemu pomocy on-line dzięki poleceniu ":help". +Zobacz rozdział POMOC ON-LINE poniżej. +.PP +Najczęściej +.B Vim +jest uruchamiany do edycji pojedynczego pliku poleceniem +.PP + vim plik +.PP +Bardziej ogólnie +.B Vim +jest uruchamiany poprzez: +.PP + vim [opcje] [lista plików] +.PP +Jeśli brak listy plików edytor rozpocznie z pustym buforem. W innym +wypadku istnieje dokładnie jedna z czterech możliwości by wybrać jeden +lub więcej plików do edycji. +.TP 12 +plik .. +Lista nazw plików. +Pierwsza nazwa będzie nazwą bieżącego pliku, który zostanie wczytany +do bufora. Kursor zostanie umieszczony w pierwszym wierszu. Do +kolejnych plików można przejść dzięki poleceniu ":next". By otworzyć +plik, którego nazwa zaczyna się od myślnika należy listę plików +poprzedzić "\-\-". +.TP +\- +Plik do edycji jest wczytany ze standardowego wejścia. Polecenia są +odczytywane ze standardowego wyjścia błędów, którym powinien być +terminal (tty). +.TP +\-t {znacznik} +Plik do edycji i początkowa pozycja kursora zależy od "znacznika", +rodzaju etykiety goto. +{znacznika} szuka się w pliku tags, związany z nim plik staje się +plikiem bieżącym i wykonuje się powiązane polecenie. +Zazwyczaj używa się tego sposobu dla programów w C, w których wypadku +{znacznik} może być nazwą funkcji. +W efekcie plik zawierający określoną funkcję staje się plikiem +bieżącym a kursor jest umieszczony na początku funkcji. +Zobacz ":help tag-commands". +.TP +\-q [plik_błędów] +Zacznij w trybie quickFix. +Plik [plik_błędów] zostaje zinterpretowany i pokaże się pierwszy błąd. +Jeśli brak opcji [plik_błędów] nazwa pliku zostanie pobrana z opcji +\&'errorfile' (domyślnie "AztecC.Err" dla Amigi, "errros.err" dla innych +systemów. +Do kolejnych błędów można przeskoczyć dzięki poleceniu ":cn". +Zobacz ":help quickfix". +.PP +W zależności od wywołania +.B Vim +zachowuje się inaczej (program może być cały czas tym samym +plikiem). +.TP 10 +vim +"Normalny" sposób, wszystko jest domyślne. +.TP +ex +Zacznij w trybie Ex. +Przejdź do trybu Normalnego poleceniem ":vi". +Można także uruchomić poprzez argument "\-e". +.TP +view +Zacznij w trybie tylko do odczytu. W ten sposób będziesz chroniony +przed zapisywaniem pliku. Można także uruchomić poprzez argument +"\-R". +.TP +gvim gview +Wersja GUI. +Uruchamia nowe okno. +Można także uruchomić poprzez argument "\-g". +.TP +evim eview +Wersja GUI w łatwym trybie. +Uruchamia nowe okno. +Można także uruchomić poprzez argument "\-y". +.TP +rvim rview rgvim rgview +Podobnie jak powyżej, ale z ograniczeniami. Nie będzie można uruchomić +poleceń powłoki lub zawiesić +.B Vima. +Można także uruchomić poprzez argument "\-Z". +.SH OPCJE +Opcje można podać w dowolnej kolejności, przed lub po nazwach plików. +Opcje bez argumentów można łączyć po pojedynczym myślniku. +.TP 12 ++[num] +W pierwszym pliku kursor zostanie umieszczony w wierszu "num". +Jeśli brak "num" kursor zostanie umieszczony w ostatnim wierszu. +.TP ++/{wzór} +W pierwszym pliku kursor zostanie umieszczony na pierwszym wystąpieniu +{wzór}. +Zobacz ":help search-pattern" by dowiedzieć się jakie są możliwe +wzorce wyszukiwania. +.TP ++{polecenie} +.TP +\-c {polecenie} +{polecenie} zostanie wykonane po tym jak wczyta się pierwszy plik. +{polecenie} jest interpretowane jako polecenie Ex. +Jeśli {poleceni} zawiera białe znaki musi być umieszczone w podwójnych +cudzysłowach (zależy to od używanej powłoki). +Przykład: Vim "+set si" main.c +.br +Uwaga: Można użyć do 10 poleceń "+" lub "\-c". +.TP +\-S {plik} +{plik} zostanie zinterpretowany po wczytaniu pierwszego pliku. +Jest równoważne \-c "source {plik}". +{plik} nie może zaczynać się '\-'. +Jeśli nie podano {plik} zostanie użyty "Session.vim" (działa tylko +wtedy jeśli \-S jest ostatnim argumentem). +.TP +\-\-cmd {polecenie} +Podobne do "\-c", ale polecenie jest wykonywane tuż przed +interpretacją jakiegokolwiek pliku vimrc. +Można użyć do 10 takich poleceń, niezależnie od poleceń od "\-c" +.TP +\-A +Jeśli +.B Vim +został skompilowany ze wsparciem dla języków arabskich (edycja od +prawej do lewej i arabska mapa klawiatury) ta opcja uruchamia +.B Vima +w trybie arabskim, np. ustawia się opcja 'arabic'. W innym wypadku +pojawi się komunikat błędu i +.B Vim +zakończy działanie. +.TP +\-b +Tryb binarny. +Ustawi się kilka opcji, które umożliwią edycję plików binarnych lub +wykonywalnych. +.TP +\-C +Kompatybilny. Ustawia opcję 'compatible'. +W ten sposób +.B Vim +będzie zachowywał się jak Vi, nawet jeśli istnieje plik .vimrc. +.TP +\-d +Uruchom w trybie diff. +Powinno się użyć dwóch, trzech lub czterech nazwy plików jako argumentów. +.B Vim +otworzy wszystkie te pliki i pokaże różnice między nimi. +Działa jak vimdiff(1). +.TP +\-d {urządzenie} +Otwórz {urządzenie} by używać jako terminal. +Tylko na Amidze. +Przykład: +"\-d con:20/30/600/150". +.TP +\-D +Debugowanie. Przejdź do trybu debugowanie wykonując pierwsze polecenie +ze skryptu. +.TP +\-e +Uruchom +.B Vima +w trybie Ex, działa tak samo jakby wywołano program jako "ex". +.TP +\-E +Uruchom +.B Vima +w ulepszonym trybie Ex, działa tak samo jakby wywołano program jako +"exim". +.TP +\-f +Pierszy plan. Dla wersji GUI. +.B Vim +nie nie oddzieli się od powłoki w jakiej został uruchomiony. Na Amidze +.B Vim +nie jest uruchomiony ponownie by otworzyć nowe okno. +Opcja powinna być użyta kiedy +.B Vim +jest wywoływany przez program, który ma zaczekać na koniec sesji (np. +mail). +Na Amidze polecenia ":sh" i ":!" nie będą działać. +.TP +\-\-nofork +Pierwszy plan. Dla wersji GUI. +.B Vim +nie oddzieli się od powłoki w jakiej został uruchomiony. +.TP +\-F +Jeśli Vim został skompilowany ze wsparciem FKMAP dla edycji tekstów od +prawej do lewej i mapowania klawiatury Farsi, ta opcja uruchomi +.B Vima +w trybie Farsi, np. zostawią ustawione opcje 'fkmap' i 'rightleft'. +W innym wypadku pojawi się komunikat błędu i +.B Vim +zakończy działanie. +.TP +\-g +Jeśli +.B Vim +został skompilowany ze wsparciem dla GUI ta opcja uruchomi GUI. +W innym wypadku pojawi się komunikat błędu i +.B Vim +zakończy działanie. +.TP +\-h +Wyświetli krótką pomoc o argumentach linii poleceń i opcjach. Potem +.B Vim +zakończy działanie. +.TP +\-H +Jeśli +.B Vim +został skompilowany ze wsparciem RIGHTLEFT dla edycji od prawej do +lewej oraz ma mapowanie klawiatury dla hebrajskiego, ta opcja uruchomi +.B Vima +w trybie hebrajskim, np. ustawi opcje 'hkmap' i 'rightleft'. +W innym wypadku pojawi się komunikat błędu i +.B Vim +zakończy działanie. +.TP +\-i {viminfo} +Kiedy +.B Vim +używa pliku viminfo ta opcja wskaże jakiego pliku użyć zamiast +domyślnego "~/.viminfo". +Można też ominąć użycie pliku .viminfo przez podanie nazwy "NONE". +.TP +\-L +To samo co \-r. +.TP +\-l +Tryb Lisp. +Ustawia opcje 'lisp' i 'showmatch'. +.TP +\-m +Zmiana pliku jest niemożliwa. +Przestawia opcję 'write'. +Można zmieniać zawartość bufora, ale zapisanie pliku nie jest +możliwe. +.TP +\-M +Opcje 'modifiable' i 'write' zostaną wyłączone, tak więc zmiany +w pliku oraz ich zapisanie nie są możliwe. Wartość tych opcji można +zmienić. +.TP +\-N +Tryb niekompatybilny. Przestawia opcję 'compatible'. Dzięki temu +.B Vim +będzie zachowywał się odrobinę lepiej, ale mniej zgodnie z Vi nawet +jeśli nie istnieje plik .vimrc. +.TP +\-n +Nie powstanie plik wymiany. Odzyskanie pliku po wypadku nie będzie +możliwe. +Wygodne jeśli instnieje potrzeba edycji na bardzo wolnym medium (np. +dyskietce). Ten cel można osiągnąć także przez ":set uc=0". Można +odwrócić przez ":set uc=200". +.TP +\-nb +Uruchom jako serwer edytora dla NetBeans. Zobacz dokumentację by +dowiedzieć się więcej. +.TP +\-o[N] +Otwórz N okien w stosie. +Kiedy brak N, otwórz jedno okno dla każdego pliku. +.TP +\-O[N] +Otwórz N okien obok siebie. +Kiedy brak N, otwórz jedno okno dla każdego pliku. +.TP +\-p[N] +Otwórz N kart. +Kiedy brak N, otwórz jedną kartę dla każdego pliku. +.TP +\-R +Tryb tylko do odczytu. +Zostanie ustawiona opcja 'readonly'. +Cały czas można zmieniać bufor, ale będzie istniała blokada by chronić +przed przypadkowym zapisaniem pliku. +Jeśli chcesz zapisać plik dodaj wykrzyknik do polecenia Ex, np. ":w!". +Opcja \-R implikuje opcję \-n (zobacz poniżej). +Opcja 'readonly' może zostać przestawiona poprzez ":set noro". +Zobacz ":help 'readonly'". +.TP +\-r +Wypisz listę plików wymiany razem z informacjami o nich. +.TP +\-r {plik} +Tryb odzyskiwania danych. +Plik wymiany zostanie wykorzystany do odzyskania gwałtownie przerwanej sesji. +Plik wymiany to plik z taką samą nazwą co plik oryginalny z dodanym ".swp". +Zobacz ":help recovery". +.TP +\-s +Tryb cichy. Rozpoczęty tylko kiedy uruchomiony jako "Ex" lub opcja +"\-e" została podana przed opcją "\-s". +.TP +\-s {skrypt} +Zostanie wczytany plik {skrypt}. +Znaki w pliku zostaną zinterpretowane jakby były wpisywane. +To samo można osiągnąć poprzez polecenie ":source! {skrypt}". +Jeśli osiągnięto koniec pliku zanim edytor zakończył działanie, dalsze +znaki odczytywane są z klawiatury. +.TP +\-T {terminal} +Przekazuje +.B Vimowi +nazwę terminalu jakiego używasz. +Wymagane tylko wtedy jeśli nie działa automatycznie. +Powinien być to terminal znany +.B Vimowi +(builtin) lub zdefiniowany w plikach termcap lub terminfo. +.TP +\-u {vimrc} +Użyj poleceń z pliku {vimrc} w czasie uruchamiania. +Wszystkie inne możliwe pliki uruchamiania zostaną pominięte. +Używaj do edytowania plików specjalnych. +Można pominąć także wszystkie możliwe pliki uruchamiania poprzez +podanie nazwy "NONE". +Zobacz ":help initialization" by poznać więcej szczegółów. +.TP +\-U {gvimrc} +Użyj poleceń z pliku {gvimrc} w czasie uruchamiania GUI. +Wszystkie inne możliwe pliki uruchamiania GUI zostaną pominięte. +Można pominąć także wszystkie możliwe pliki uruchamiania GUI poprzez +podanie nazwy "NONE". +Zobacz ":help gui-init" by poznać więcej szczegółów. +.TP +\-V[N] +Tryb gadatliwy. Wypisz wiadomości o tym jaki pliki są wczytywane +i o informacjach pobieranych i dodawanych do pliku viminfo. Opcjonalny +argument N jest wartością 'verbose'. Domyślnie 10. +.TP +\-v +Uruchom +.B Vima +w trybie Vi, tak jakby program był nazwany "vi". Ma znaczenie +tylko wtedy jeśli program nazwany jest "ex". +.TP +\-w {plik} +Wszystkie wciśnięcia klawiszy, aż do zakończenia działania programu, +są zapisywane w {plik} . +Użyteczne jeśli chce się stworzyć skrypt do użycia z "vim \-s" lub +":source!". +Jeśli {plik} istnieje, znaki są dopisywane. +.TP +\-W {plik} +Podobnie do \-w, ale istniejący plik jest nadpisywany. +.TP +\-x +Użyj szyfrowania podczas zapisywania plików. Zostaniesz poproszony +o podanie klucza. +.TP +\-X +Nie łącz z serwerem X. Skraca czas uruchamiania w terminalu, ale tytuł +okna i schowek nie będą wykorzystywane. +.TP +\-y +Uruchom +.B Vima +w łatwym trybie, tak jakby program został wywołany "evim" lub "eview". +.B Vim +będzie zachowywał się bardziej jak edytor kliknij-i-wpisz. +.TP +\-Z +Tryb ograniczony. Zachowuje się jakby nazwa programu zaczynała się od +"r". +.TP +\-\- +Oznacza koniec opcji. +Argumenty po tej opcji będą traktowane jak nazwy plików. Używa się do +otwierania plików, których nazwy zaczynają się od '\-'. +.TP +\-\-echo\-wid +Wyłącznie GTK GUI: wypisz ID okna na standardowe wyjście. +.TP +\-\-help +Wyświetl informację o pomocy i zakończy, to samo co"\-h". +.TP +\-\-literal +Potraktuj nazwy plików dosłownie i nie rozwiązuj kwantyfikatorów. Nie +ma znaczenia na Uniksach gdzie powłoka rozwiązuje kwantyfikatory. +.TP +\-\-noplugin +Pomiń ładowanie wtyczek. Implikowane przy \-u NONE. +.TP +\-\-remote +Połącz się z serwerem Vima i edytuj w nim resztę plików podanych jako +argumenty. Jeśli nie znaleziono serwera zostanie zgłoszony błąd a pliki zostaną +otwarte w bieżącym Vimie. +.TP +\-\-remote\-expr {wyrażenie} +Połącz z serwerem Vima, rozwiąż w nim {wyrażenie} i wypisz rozwiązanie +na standardowe wyjście. +.TP +\-\-remote\-send {klawisze} +Połącz z serwerem Vima i wyślij do niego {klawisze}. +.TP +\-\-remote\-silent +Tak samo jak \-remote, ale bez ostrzeżenia kiedy nie znaleziono +serwera. +.TP +\-\-remote\-wait +Tak samo jak \-remote, ale Vim nie zakończy dopóki pliki pozostaną +otwarte. +.TP +\-\-remote\-wait\-silent +Tak samo jak \-\-remote\-wait, ale bez ostrzeżenie kiedy nie +znaleziono serwera. +.TP +\-\-serverlist +Wypisz nazwy wszystkich serwerów Vima jakie można znaleźć. +.TP +\-\-servername {nazwa} +Użyj {nazwa} jako nazwy serwera. Wykorzystane dla bieżącego Vima o ile +nie połączone z argumentem \-\-remote, wtedy jest to nazwa serwera do +połączenia. +.TP +\-\-socketid {id} +Wyłącznie GTK GUI: Użyj mechanizmu GtkPlug by uruchomić gvima w innym +oknie. +.TP +\-\-version +Wypisz informację o wersji i zakończ. +.SH POMOC ON-LINE +By rozpocząć wpisz ":help" w +.B Vimie +Wpisz ":help temat" by uzyskać pomoc na określony temat. +Przykład: ":help ZZ" by uzyskać pomoc na temat polecenia "ZZ". +Użyj <Tab> i CTRL\-D aby uzupełnić tematy (":help +cmdline\-completion"). W plikach pomocy istnieją znaczniki by ułatwić +skakanie z jednego miejsca do innego (rodzaj linków hipertekstowych, +zobacz ":help"). +Można w ten sposób zobaczyć całą dokumentację, np. ":help syntax.txt". +.SH PLIKI +.TP 15 +/usr/local/lib/vim/doc/*.txt +Dokumentacja +.B Vima +Użyj ":help doc\-file\-list" aby uzyskać pełną listę. +.TP +/usr/local/lib/vim/doc/tags +Plik znaczników służy do znajdowania informacji w plikach dokumentacji. +.TP +/usr/local/lib/vim/syntax/syntax.vim +Globalne uruchamianie podświetlania składni. +.TP +/usr/local/lib/vim/syntax/*.vim +Pliki składni dla różnych języków. +.TP +/usr/local/lib/vim/vimrc +Globalny plik uruchamiania +.B Vima +.TP +~/.vimrc +Osobiste parametry uruchamiania +.B Vima +.TP +/usr/local/lib/vim/gvimrc +Globalne uruchamianie gvima. +.TP +~/.gvimrc +Osobiste parametry uruchamiania gvima. +.TP +/usr/local/lib/vim/optwin.vim +Skrypt używany w poleceniu ":options", dobry sposób do przeglądania +i ustawiania opcji. +.TP +/usr/local/lib/vim/menu.vim +Globalne uruchamianie menu gvima. +.TP +/usr/local/lib/vim/bugreport.vim +Skrypt służący do tworzenia raportów o błędach. Zobacz ":help bugs". +.TP +/usr/local/lib/vim/filetype.vim +Skrypt do wykrywania typu pliku według jego nazwy. Zobacz ":help 'filetype'". +.TP +/usr/local/lib/vim/scripts.vim +Skrypt do wykrywania typu pliku według jego zawartości. Zobacz ":help 'filetype'". +.TP +/usr/local/lib/vim/print/*.ps +Pliku używane do drukowania PostScriptu. +.PP +Najświeższe wiadomości na stronie +.B Vima: +.br +<URL:http://www.vim.org/> +.SH ZOBACZ TAKŻE +vimtutor(1) +.SH AUTOR +.B Vim +został napisany przez Brama Moolenaara z dużą pomocą innych osób. +Zobacz ":help credits" w +.B Vimie. +.br +.B Vim +bazuje na Steviem, nad którym pracowali: Tim Thompson, Tony Andrews +i G.R. (Fred) Walter. +Mało już zostało z oryginalnego kodu. +.SH BŁĘDY +Prawdopodobne. +Zobacz ":help todo" by poznać listę znanych problemów. +.PP +Pamiętaj że pewna ilość problemów, które mogą być uznawane przez +niektórych ludzi za błędy są w rzeczywistości spowodowane wiernością +w odtwarzaniu zachowania Vi. +Jeśli sądzisz, że inne rzeczy są błędami "ponieważ Vi robi to +inaczej", powinieneś przyjrzeć się bliżej plikowi vi_diff.txt (lub +wpisać ":help vi_diff.txt" w Vimie). +Sprawdź także opis opcji 'compatible' i 'cpoptions'. diff --git a/share/vim/vim73/doc/vim-ru.1 b/share/vim/vim73/doc/vim-ru.1 new file mode 100644 index 0000000000..dfcb3ece98 --- /dev/null +++ b/share/vim/vim73/doc/vim-ru.1 @@ -0,0 +1,489 @@ +.TH VIM 1 "2002 Feb 22" +.SH éíñ +vim \- Vi IMproved (õÌÕÞÛÅÎÎÙÊ Vi), ÔÅËÓÔÏ×ÙÊ ÒÅÄÁËÔÏÒ ÄÌÑ ÐÒÏÇÒÁÍÍÉÓÔÏ× +.SH ëïíáîäîáñ óôòïëá +.br +.B vim +[ËÌÀÞÉ] [ÆÁÊÌ ..] +.br +.B vim +[ËÌÀÞÉ] \- +.br +.B vim +[ËÌÀÞÉ] \-t ÍÅÔËÁ +.br +.B vim +[ËÌÀÞÉ] \-q [ÆÁÊÌ ÏÛÉÂÏË] +.PP +.br +.B ex +.br +.B view +.br +.B gvim +.B gview +.br +.B rvim +.B rview +.B rgvim +.B rgview +.SH ïðéóáîéå +.B Vim +-- ÔÅËÓÔÏ×ÙÊ ÒÅÄÁËÔÏÒ, ÏÂÒÁÔÎÏ-ÓÏ×ÍÅÓÔÉÍÙÊ Ó Vi. +ïÎ ÍÏÖÅÔ ÂÙÔØ ÉÓÐÏÌØÚÏ×ÁÎ ÄÌÑ ÐÒÁ×ËÉ ×ÓÅÈ ×ÉÄÏ× ÐÒÏÓÔÏÇÏ ÔÅËÓÔÁ. +ïÓÏÂÅÎÎÏ ÏÎ ÈÏÒÏÛ ÄÌÑ ÐÒÁ×ËÉ ÉÓÈÏÄÎÙÈ ÔÅËÓÔÏ× ÐÒÏÇÒÁÍÍ. +.PP +ðÏ ÓÒÁ×ÎÅÎÉÀ Ó Vi, +.B Vim +ÉÍÅÅÔ ÍÎÏÇÏ ÕÓÏ×ÅÒÛÅÎÓÔ×Ï×ÁÎÉÊ: ÍÎÏÇÏËÒÁÔÎÁÑ ÏÔÍÅÎÁ ÏÐÅÒÁÃÉÊ, +ÍÎÏÖÅÓÔ×ÅÎÎÏÓÔØ ÏËÏÎ É ÂÕÆÅÒÏ×, ÐÏÄÓ×ÅÔËÁ ÓÉÎÔÁËÓÉÓÁ, ÐÒÁ×ËÁ ËÏÍÁÎÄÎÏÊ ÓÔÒÏËÉ, +Á×ÔÏÄÏÐÏÌÎÅÎÉÅ ÉͣΠÆÁÊÌÏ×, ×ÓÔÒÏÅÎÎÁÑ ÓÐÒÁ×ËÁ, ×ÉÚÕÁÌØÎÏÅ ×ÙÄÅÌÅÎÉÅ É Ô.Ð. +óÍ. ":help vi_diff.txt" ÄÌÑ ÐÏÌÕÞÅÎÉÑ ÐÏÌÎÏÇÏ ÓÐÉÓËÁ ÒÁÚÌÉÞÉÊ ÍÅÖÄÕ +.B Vim +É Vi. +.PP +÷Ï ×ÒÅÍÑ ÒÁÂÏÔÙ × +.B Vim +ÍÏÖÎÏ ÐÏÌÕÞÉÔØ ÓÐÒÁ×ËÕ Ó ÐÏÍÏÝØÀ ÓÉÓÔÅÍÙ ×ÓÔÒÏÅÎÎÏÊ ÓÐÒÁ×ËÉ (ËÏÍÁÎÄÁ ":help"). +óÍ. ÒÁÚÄÅÌ "÷óôòïåîîáñ óðòá÷ëá" ÎÉÖÅ ÐÏ ÔÅËÓÔÕ. +.PP +þÁÝÅ ×ÓÅÇÏ +.B Vim +ÚÁÐÕÓËÁÀÔ ÄÌÑ ÐÒÁ×ËÉ ÏÄÎÏÇÏ ÆÁÊÌÁ ÐÒÉ ÐÏÍÏÝÉ ËÏÍÁÎÄÙ +.PP + vim ÆÁÊÌ +.PP +÷ ÏÂÝÅÍ ×ÉÄÅ ËÏÍÁÎÄÁ ÚÁÐÕÓËÁ +.B Vim +×ÙÇÌÑÄÉÔ ÔÁË: +.PP + vim [ËÌÀÞÉ] [ÓÐÉÓÏË ÆÁÊÌÏ×] +.PP +åÓÌÉ ÓÐÉÓÏË ÆÁÊÌÏ× ÏÔÓÕÔÓÔ×ÕÅÔ, ÒÅÄÁËÔÏÒ ÎÁÞÎ£Ô ÒÁÂÏÔÕ Ó ÐÕÓÔÙÍ ÂÕÆÅÒÏÍ. +÷ ÐÒÏÔÉ×ÎÏÍ ÓÌÕÞÁÅ ÉÍÑ ÆÁÊÌÁ ÄÏÌÖÎÏ ÂÙÔØ ÕËÁÚÁÎÏ ÏÄÎÉÍ ÉÚ ÓÌÅÄÕÀÝÉÈ ÞÅÔÙÒ£È ÓÐÏÓÏÂÏ×: +.TP 12 +ÆÁÊÌ .. +óÐÉÓÏË ÉͣΠÆÁÊÌÏ×. +ðÅÒ×ÙÊ ÆÁÊÌ ÂÕÄÅÔ ÏÂßÑ×ÌÅÎ ÁËÔÉ×ÎÙÍ É ÚÁÇÒÕÖÅÎ × ÂÕÆÅÒ. ëÕÒÓÏÒ ÂÕÄÅÔ ÐÏÍÅݣΠ+× ÐÅÒ×ÏÊ ÓÔÒÏËÅ ÂÕÆÅÒÁ. äÏÓÔÕÐ Ë ÄÒÕÇÉÍ ÆÁÊÌÁÍ ÍÏÖÅÔ ÂÙÔØ ÏÓÕÝÅÓÔ×̣ΠÐÒÉ +ÐÏÍÏÝÉ ËÏÍÁÎÄÙ ":next". þÔÏÂÙ ÐÒÁ×ÉÔØ ÆÁÊÌ, ÉÍÑ ËÏÔÏÒÏÇÏ ÎÁÞÉÎÁÅÔÓÑ Ó ÓÉÍ×ÏÌÁ +"ÄÅÆÉÓ" (-), ÐÅÒÅÄ ÓÐÉÓËÏÍ ÆÁÊÌÏ× ÎÅÏÂÈÏÄÉÍÏ ÐÏÓÔÁ×ÉÔØ "--". +.TP +\- +æÁÊÌ ÂÕÄÅÔ ÐÒÏÞÉÔÁÎ ÉÚ ÐÏÔÏËÁ ÓÔÁÎÄÁÒÔÎÏÇÏ ××ÏÄÁ. ëÏÍÁÎÄÙ ÂÕÄÕÔ ÓÞÉÔÙ×ÁÔØÓÑ +ÉÚ ÓÔÁÎÄÁÒÔÎÏÇÏ ÐÏÔÏËÁ ÄÉÁÇÎÏÓÔÉËÉ (stderr), ËÏÔÏÒÙÊ ÄÏÌÖÅÎ ÂÙÔØ +ÔÅÒÍÉÎÁÌÏÍ. +.TP +\-t {ÍÅÔËÁ} +éÍÑ ÆÁÊÌÁ É ÎÁÞÁÌØÎÁÑ ÐÏÚÉÃÉÑ ËÕÒÓÏÒÁ ÚÁ×ÉÓÑÔ ÏÔ "ÍÅÔËÉ", ÐÏÈÏÖÅÊ ÎÁ ÍÅÔËÕ goto. +{ÍÅÔËÁ} ÉÝÅÔÓÑ × ÆÁÊÌÅ ÍÅÔÏË, ÓÏÏÔ×ÅÔÓÔ×ÕÀÝÉÊ ÆÁÊÌ ÓÔÁÎÏ×ÉÔÓÑ ÁËÔÉ×ÎÙÍ, Á +ÓÏÏÔ×ÅÔÓÔ×ÕÀÝÁÑ ËÏÍÁÎÄÁ ÉÓÐÏÌÎÑÅÔÓÑ. +þÁÝÅ ×ÓÅÇÏ ÉÓÐÏÌØÚÕÅÔÓÑ × ÐÒÏÇÒÁÍÍÁÈ ÎÁ ÑÚÙËÅ óÉ, ÇÄÅ {ÍÅÔËÁ} ÍÏÖÅÔ ÂÙÔØ ÉÍÅÎÅÍ +ÆÕÎËÃÉÉ. +æÁÊÌ, ÓÏÄÅÒÖÁÝÉÊ ÆÕÎËÃÉÀ, ÓÔÁÎÏ×ÉÔÓÑ ÁËÔÉ×ÎÙÍ, Á ËÕÒÓÏÒ ÐÏÍÅÝÁÅÔÓÑ × ÎÁÞÁÌÏ ÆÕÎËÃÉÉ. +óÍ. ":help tag-commands". +.TP +\-q [ÆÁÊÌ ÏÛÉÂÏË] +îÁÞÁÔØ ÒÁÂÏÔÕ × ÒÅÖÉÍÅ ÂÙÓÔÒÏÇÏ ÉÓÐÒÁ×ÌÅÎÉÑ. +ðÒÉ ÜÔÏÍ ÓÞÉÔÙ×ÁÅÔÓÑ [ÆÁÊÌ ÏÛÉÂÏË] É ÐÅÒ×ÁÑ ÏÛÉÂËÁ ×Ù×ÏÄÉÔÓÑ ÎÁ ÜËÒÁÎ. +åÓÌÉ [ÆÁÊÌ ÏÛÉÂÏË] ÎÅ ÕËÁÚÁÎ, ÉÍÑ ÆÁÊÌÁ ÂÅÒ£ÔÓÑ ÉÚ ÚÎÁÞÅÎÉÑ ÏÐÃÉÉ 'errorfile' +(ÐÏ ÕÍÏÌÞÁÎÉÀ: "AztecC.Err" ÄÌÑ Amiga, "errors.err" ÄÌÑ ÄÒÕÇÉÈ ÓÉÓÔÅÍ). +ë ÓÌÅÄÕÀÝÉÍ ÏÛÉÂËÁÍ ÍÏÖÎÏ ÐÅÒÅÊÔÉ ÐÏ ËÏÍÁÎÄÅ ":cn". +óÍ. ":help quickfix". +.PP +.B Vim +×ÅÄ£Ô ÓÅÂÑ ÐÏ-ÒÁÚÎÏÍÕ × ÚÁ×ÉÓÉÍÏÓÔÉ ÏÔ ÉÍÅÎÉ ËÏÍÁÎÄÙ (ÉÓÐÏÌÎÑÅÍÙÊ ÆÁÊÌ ÍÏÖÅÔ +ÂÙÔØ ÏÄÎÉÍ É ÔÅÍ ÖÅ). +.TP 10 +vim +"îÏÒÍÁÌØÎÙÊ" ÚÁÐÕÓË, ×Ó£ ÐÏ ÕÍÏÌÞÁÎÉÀ. +.TP +ex +úÁÐÕÓË × ÒÅÖÉÍÅ Ex. äÌÑ ÐÅÒÅÈÏÄÁ × ÎÏÒÍÁÌØÎÙÊ ÒÅÖÉÍ +ÎÅÏÂÈÏÄÉÍÏ ×ÙÐÏÌÎÉÔØ ËÏÍÁÎÄÕ ":vi". òÅÖÉÍ Ex ×ËÌÀÞÁÅÔ +ÔÁËÖÅ ËÌÀÞ "\-e". +.TP +view +úÁÐÕÓË × ÒÅÖÉÍÅ "ÔÏÌØËÏ ÄÌÑ ÞÔÅÎÉÑ". ÷Ù ÂÕÄÅÔÅ ÚÁÝÉÝÅÎÙ ÏÔ ÓÌÕÞÁÊÎÏÊ ÚÁÐÉÓÉ +ÆÁÊÌÁ. ôÏ ÖÅ ÓÁÍÏÅ ÍÏÖÎÏ ÓÄÅÌÁÔØ ËÌÀÞÏÍ "\-R". +.TP +gvim gview +÷ÅÒÓÉÑ Ó ÇÒÁÆÉÞÅÓËÉÍ ÉÎÔÅÒÆÅÊÓÏÍ. úÁÐÕÓËÁÅÔÓÑ × ÎÏ×ÏÍ ÏËÎÅ. +ôÏ ÖÅ ÓÁÍÏÅ ÍÏÖÎÏ ÓÄÅÌÁÔØ ÐÒÉ ÚÁÐÕÓËÅ Ó ËÌÀÞÏÍ "\-g". +.TP +rvim rview rgvim rgview +ëÁË É ÐÒÅÄÙÄÕÝÉÅ ËÏÍÁÎÄÙ, ÎÏ Ó ÏÇÒÁÎÉÞÅÎÉÑÍÉ. îÅÌØÚÑ ÚÁÐÕÓËÁÔØ ËÏÍÁÎÄÙ ÏÂÏÌÏÞËÉ +ÉÌÉ ÐÒÉÏÓÔÁÎÁ×ÌÉ×ÁÔØ ÒÁÂÏÔÕ +.B Vim. +÷ÍÅÓÔÏ ÐÒÉÓÔÁ×ËÉ "r" ÍÏÖÎÏ ÉÓÐÏÌØÚÏ×ÁÔØ ËÌÀÞ "\-Z". +.SH ëìàþé +ëÌÀÞÉ ÍÏÇÕÔ ÂÙÔØ ÕËÁÚÁÎÙ × ÌÀÂÏÍ ÐÏÒÑÄËÅ, ÄÏ ÉÌÉ ÐÏÓÌÅ ÉͣΠ+ÆÁÊÌÏ×. ëÌÀÞÉ ÂÅÚ ÁÒÇÕÍÅÎÔÏ× ÍÏÇÕÔ ÂÙÔØ ÏÂßÅÄÉÎÅÎÙ ÐÏÄ ÏÄÎÉÍ +ÄÅÆÉÓÏÍ. +.TP 12 ++[ÎÏÍÅÒ] +÷ ÐÅÒ×ÏÍ ÆÁÊÌÅ ËÕÒÓÏÒ ÂÕÄÅÔ ÐÏÍÅݣΠÎÁ ÓÔÒÏËÕ Ó ÕËÁÚÁÎÎÙÍ ÎÏÍÅÒÏÍ. +åÓÌÉ "ÎÏÍÅÒ" ÎÅ ÕËÁÚÁÎ, ËÕÒÓÏÒ ÂÕÄÅÔ ÐÏÍÅݣΠÎÁ ÐÏÓÌÅÄÎÀÀ ÓÔÒÏËÕ. +.TP ++/{ÛÁÂÌÏÎ} +÷ ÐÅÒ×ÏÍ ÆÁÊÌÅ ËÕÒÓÏÒ ÂÕÄÅÔ ÐÏÍÅݣΠÎÁ ÍÅÓÔÏ ÐÅÒ×ÏÇÏ ÓÏ×ÐÁÄÅÎÉÑ +Ó ÕËÁÚÁÎÎÙÍ ÛÁÂÌÏÎÏÍ. óÍ. ":help search-pattern" ÄÌÑ ÐÏÌÕÞÅÎÉÑ +ÓÐÉÓËÁ ÄÏÐÕÓÔÉÍÙÈ ÛÁÂÌÏÎÏ×. +.TP ++{ËÏÍÁÎÄÁ} +.TP +\-c {ËÏÍÁÎÄÁ} +{ËÏÍÁÎÄÁ} ÉÓÐÏÌÎÑÅÔÓÑ ÐÏÓÌÅ ÚÁÇÒÕÚËÉ ÐÅÒ×ÏÇÏ ÆÁÊÌÁ ËÁË ËÏÍÁÎÄÁ Ex. +åÓÌÉ {ËÏÍÁÎÄÁ} ÓÏÄÅÒÖÉÔ ÐÒÏÂÅÌÙ, ÔÏ ÏÎÁ ÄÏÌÖÎÁ ÂÙÔØ ÚÁËÌÀÞÅÎÁ × +Ä×ÏÊÎÙÅ ËÁ×ÙÞËÉ (× ÚÁ×ÉÓÉÍÏÓÔÉ ÏÔ ÉÓÐÏÌØÚÕÅÍÏÊ ÏÂÏÌÏÞËÉ). +ðÒÉÍÅÒ: vim "+set si" main.c +.br +ðÒÉÍÅÞÁÎÉÅ: íÏÖÎÏ ÕËÁÚÙ×ÁÔØ ÄÏ ÄÅÓÑÔÉ ËÏÍÁÎÄ "+" ÉÌÉ "\-c". +.TP +\-\-cmd {ËÏÍÁÎÄÁ} +ëÁË "\-c", ÎÏ ËÏÍÁÎÄÁ ÉÓÐÏÌÎÑÅÔÓÑ ÐÅÒÅÄ ÏÂÒÁÂÏÔËÏÊ ÌÀÂÏÇÏ ÆÁÊÌÁ +ÎÁÓÔÒÏÅË (vimrc). +íÏÖÎÏ ÕËÁÚÙ×ÁÔØ ÄÏ ÄÅÓÑÔÉ ÔÁËÉÈ ËÏÍÁÎÄ, ÎÅÚÁ×ÉÓÉÍÏ ÏÔ ËÏÌÉÞÅÓÔ×Á +ËÏÍÁÎÄ "\-c". +.TP +\-A +åÓÌÉ +.B Vim +ÂÙÌ ÓÏÂÒÁÎ Ó ÐÏÄÄÅÒÖËÏÊ ÁÒÁÂÓËÏÇÏ ÑÚÙËÁ ÄÌÑ ÐÒÁ×ËÉ ÆÁÊÌÏ×, +ÎÁÂÒÁÎÎÙÈ ÓÐÒÁ×Á ÎÁÌÅ×Ï, É Ó ÐÏÄÄÅÒÖËÏÊ ÁÒÁÂÓËÏÊ ËÌÁ×ÉÁÔÕÒÙ, +ÜÔÏÔ ËÌÀÞ ÚÁÐÕÓËÁÅÔ +.B Vim +× ÁÒÁÂÓËÏÍ ÒÅÖÉÍÅ, Ó ×ËÌÀÞÅÎÎÏÊ ÏÐÃÉÅÊ 'arabic'. ÷ ÐÒÏÔÉ×ÎÏÍ +ÓÌÕÞÁÅ +.B Vim +ÚÁ×ÅÒÛÁÅÔ ÒÁÂÏÔÕ Ó ÏÛÉÂËÏÊ. +.TP +\-b +ä×ÏÉÞÎÙÊ ÒÅÖÉÍ. +ðÒÏÉÚ×ÏÄÉÔÓÑ ÎÁÓÔÒÏÊËÁ ÎÅËÏÔÏÒÙÈ ÏÐÃÉÊ, ÄÅÌÁÀÝÉÈ ×ÏÚÍÏÖÎÏÊ ÐÒÁ×ËÕ +Ä×ÏÉÞÎÏÇÏ ÉÌÉ ÉÓÐÏÌÎÑÅÍÏÇÏ ÆÁÊÌÁ. +.TP +\-C +òÅÖÉÍ ÓÏ×ÍÅÓÔÉÍÏÓÔÉ. ÷ËÌÀÞÁÅÔ ÏÐÃÉÀ 'compatible'. +.B Vim +ÂÕÄÅÔ ÒÁÂÏÔÁÔØ ÐÏÞÔÉ ËÁË Vi, ÄÁÖÅ ÅÓÌÉ ÓÕÝÅÓÔ×ÕÅÔ ÆÁÊÌ .vimrc. +.TP +\-d +òÅÖÉÍ ÐÏÉÓËÁ ÒÁÚÌÉÞÉÊ. +äÏÌÖÎÏ ÂÙÔØ ÕËÁÚÁÎÏ Ä×Á ÉÌÉ ÔÒÉ ÉÍÅÎÉ ÆÁÊÌÁ. +.B Vim +ÏÔËÒÏÅÔ ×ÓÅ ÆÁÊÌÙ É ÐÏËÁÖÅÔ ÒÁÚÌÉÞÉÑ ÍÅÖÄÕ ÎÉÍÉ +(ËÁË vimdiff(1)). +.TP +\-d {ÕÓÔÒÏÊÓÔ×Ï} +ïÔËÒÙÔØ {ÕÓÔÒÏÊÓÔ×Ï} ÄÌÑ ÉÓÐÏÌØÚÏ×ÁÎÉÑ × ËÁÞÅÓÔ×Å ÔÅÒÍÉÎÁÌÁ (ÔÏÌØËÏ ÎÁ Amiga). +ðÒÉÍÅÒ: +"\-d con:20/30/600/150". +.TP +\-e +úÁÐÕÓÔÉÔØ +.B Vim +× ÒÅÖÉÍÅ Ex, ËÁË ÂÕÄÔÏ ÉÓÐÏÌÎÑÅÍÙÊ ÆÁÊÌ ÉÍÅÅÔ ÉÍÑ "ex". +.TP +\-f +òÅÖÉÍ ÁËÔÉ×ÎÏÇÏ ÐÒÉÌÏÖÅÎÉÑ. ÷ÅÒÓÉÑ +.B Vim +Ó ÇÒÁÆÉÞÅÓËÉÍ ÉÎÔÅÒÆÅÊÓÏÍ ÎÅ ÂÕÄÅÔ ×ÅÔ×ÉÔØÓÑ É ÏÔËÌÀÞÁÔØÓÑ +ÏÔ ÚÁÐÕÓÔÉ×ÛÅÊ Å£ ÏÂÏÌÏÞËÉ. îÁ ÐÌÁÔÆÏÒÍÅ Amiga +.B Vim +ÎÅ ÂÕÄÅÔ ÓÏÚÄÁ×ÁÔØ ÎÏ×ÏÅ ÏËÎÏ. üÔÏÔ ËÌÀÞ ÎÕÖÎÏ ÉÓÐÏÌØÚÏ×ÁÔØ, +ËÏÇÄÁ +.B Vim +ÚÁÐÕÓËÁÅÔÓÑ ÐÒÏÇÒÁÍÍÏÊ, ËÏÔÏÒÁÑ ÄÏÌÖÎÁ ÖÄÁÔØ ÚÁ×ÅÒÛÅÎÉÑ +ÓÅÁÎÓÁ ÐÒÁ×ËÉ (ÎÁÐÒÉÍÅÒ, ÐÒÏÇÒÁÍÍÁ ÄÌÑ ÒÁÂÏÔÙ Ó ÜÌÅËÔÒÏÎÎÏÊ ÐÏÞÔÏÊ). +îÁ ÐÌÁÔÆÏÒÍÅ Amiga ËÏÍÁÎÄÙ ":sh" É ":!" ÎÅ ÂÕÄÕÔ ÒÁÂÏÔÁÔØ. +.TP +\-\-nofork +òÅÖÉÍ ÁËÔÉ×ÎÏÇÏ ÐÒÉÌÏÖÅÎÉÑ. ÷ÅÒÓÉÑ +.B Vim +Ó ÇÒÁÆÉÞÅÓËÉÍ ÉÎÔÅÒÆÅÊÓÏÍ ÎÅ ÂÕÄÅÔ ×ÅÔ×ÉÔØÓÑ É ÏÔËÌÀÞÁÔØÓÑ +ÏÔ ÚÁÐÕÓÔÉ×ÛÅÊ Å£ ÏÂÏÌÏÞËÉ. +.TP +\-F +åÓÌÉ +.B Vim +ÂÙÌ ÓÏÂÒÁÎ Ó ÐÏÄÄÅÒÖËÏÊ FKMAP ÄÌÑ ÐÒÁ×ËÉ ÔÅËÓÔÁ ÓÐÒÁ×Á ÎÁÌÅ×Ï +É ÎÁÓÔÒÏÅË ËÌÁ×ÉÁÔÕÒÙ ÄÌÑ ÑÚÙËÁ ÆÁÒÓÉ, ÜÔÏÔ ËÌÀÞ ÚÁÐÕÓËÁÅÔ +.B Vim +× ÒÅÖÉÍÅ ÆÁÒÓÉ, ÉÎÁÞÅ ÇÏ×ÏÒÑ, Ó ×ËÌÀÞ£ÎÎÙÍÉ ÏÐÃÉÑÍÉ +\&'fkmap' É 'rightleft'. +÷ ÐÒÏÔÉ×ÎÏÍ ÓÌÕÞÁÅ +.B Vim +ÚÁ×ÅÒÛÁÅÔ ÒÁÂÏÔÕ Ó ÓÏÏÂÝÅÎÉÅÍ Ï ÏÛÉÂËÅ. +.TP +\-g +åÓÌÉ +.B Vim +ÂÙÌ ÓÏÂÒÁÎ Ó ÐÏÄÄÅÒÖËÏÊ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ, ÜÔÏÔ ËÌÀÞ +×ËÌÀÞÁÅÔ ÇÒÁÆÉÞÅÓËÉÊ ÉÎÔÅÒÆÅÊÓ. ÷ ÐÒÏÔÉ×ÎÏÍ ÓÌÕÞÁÅ +.B Vim +ÚÁ×ÅÒÛÁÅÔ ÒÁÂÏÔÕ Ó ÓÏÏÂÝÅÎÉÅÍ Ï ÏÛÉÂËÅ. +.TP +\-h +÷Ù×ÏÄÉÔ ËÒÁÔËÕÀ ÉÎÆÏÒÍÁÃÉÀ Ï ÁÒÇÕÍÅÎÔÁÈ É ËÌÀÞÁÈ ËÏÍÁÎÄÎÏÊ ÓÔÒÏËÉ. +ðÏÓÌÅ ÜÔÏÇÏ +.B Vim +ÚÁ×ÅÒÛÁÅÔ ÒÁÂÏÔÕ. +.TP +\-H +åÓÌÉ +.B Vim +ÂÙÌ ÓÏÂÒÁÎ Ó ÐÏÄÄÅÒÖËÏÊ ÐÒÁ×ËÉ ÔÅËÓÔÁ ÓÐÒÁ×Á ÎÁÌÅ×Ï +É ÎÁÓÔÒÏÅË ËÌÁ×ÉÁÔÕÒÙ ÄÌÑ É×ÒÉÔÁ, ÜÔÏÔ ËÌÀÞ ÚÁÐÕÓËÁÅÔ +.B Vim +× ÒÅÖÉÍÅ É×ÒÉÔÁ, ÉÎÁÞÅ ÇÏ×ÏÒÑ, Ó ×ËÌÀÞ£ÎÎÙÍÉ ÏÐÃÉÑÍÉ 'hkmap' É 'rightleft'. +÷ ÐÒÏÔÉ×ÎÏÍ ÓÌÕÞÁÅ +.B Vim +ÚÁ×ÅÒÛÁÅÔ ÒÁÂÏÔÕ Ó ÓÏÏÂÝÅÎÉÅÍ Ï ÏÛÉÂËÅ. +.TP +\-i {viminfo} +åÓÌÉ ÉÓÐÏÌØÚÕÅÔÓÑ ÆÁÊÌ viminfo, ÔÏ ÜÔÏÔ ËÌÀÞ ÚÁÄÁ£Ô ÉÍÑ ÔÁËÏÇÏ ÆÁÊÌÁ (×ÍÅÓÔÏ +"~/.viminfo" ÐÏ ÕÍÏÌÞÁÎÉÀ). íÏÖÎÏ ÔÁËÖÅ ÉÚÂÅÖÁÔØ ÉÓÐÏÌØÚÏ×ÁÎÉÑ ÆÁÊÌÁ viminfo +ÐÕÔ£Í ÕËÁÚÁÎÉÑ ÉÍÅÎÉ "NONE". +.TP +\-L +ôÏ ÖÅ, ÞÔÏ É \-r. +.TP +\-l +òÅÖÉÍ Lisp. ÷ËÌÀÞÁÀÔÓÑ ÏÐÃÉÉ 'lisp' É 'showmatch'. +.TP +\-m +éÚÍÅÎÅÎÉÅ ÆÁÊÌÏ× ÚÁÐÒÅÝÅÎÏ. ðÒÉ ÜÔÏÍ ÏÔËÌÀÞÁÅÔÓÑ ÏÐÃÉÑ 'write', ÐÏÜÔÏÍÕ +ÚÁÐÉÓØ ÆÁÊÌÏ× ÓÔÁÎÏ×ÉÔÓÑ ÎÅ×ÏÚÍÏÖÎÏÊ. +.TP +\-N +òÅÖÉÍ ÎÅÐÏÌÎÏÊ ÓÏ×ÍÅÓÔÉÍÏÓÔÉ. ïÔËÌÀÞÁÅÔÓÑ 'compatible'. +.B Vim +ÂÕÄÅÔ ÒÁÂÏÔÁÔØ ÌÕÞÛÅ, ÎÏ ÎÅ ÂÕÄÅÔ ÐÏÌÎÏÓÔØÀ ÓÏ×ÍÅÓÔÉÍ Ó Vi, ÄÁÖÅ ÅÓÌÉ +ÏÔÓÕÔÓÔ×ÕÅÔ ÆÁÊÌ ÓÃÅÎÁÒÉÑ ÎÁÓÔÒÏÅË (.vimrc). +.TP +\-n +îÅ ÉÓÐÏÌØÚÏ×ÁÔØ Ó×ÏÐ-ÆÁÊÌ. ÷ÏÓÓÔÁÎÏ×ÌÅÎÉÅ ÐÒÉ ÓÂÏÅ × ÒÁÂÏÔÅ ÂÕÄÅÔ ÎÅ×ÏÚÍÏÖÎÏ. +õÄÏÂÎÏ ÄÌÑ ÐÒÁ×ËÉ ÆÁÊÌÁ ÎÁ ÏÞÅÎØ ÍÅÄÌÅÎÎÏÍ ÎÏÓÉÔÅÌÅ (ÎÁÐÒÉÍÅÒ, ÇÉÂËÏÍ ÄÉÓËÅ). +ôÏ ÖÅ ÓÁÍÏÅ ÍÏÖÎÏ ÓÄÅÌÁÔØ ËÏÍÁÎÄÏÊ ":set uc=0". ïÔÍÅÎÁ -- ":set uc=200". +.TP +\-o[N] +ïÔËÒÙÔØ N ÏËÏÎ, ÒÁÚÄÅÌ£ÎÎÙÈ ÐÏ ÇÏÒÉÚÏÎÔÁÌÉ. åÓÌÉ N ÎÅ ÕËÁÚÁÎÏ, ÔÏ ÏÔËÒÙ×ÁÅÔÓÑ +ÐÏ ÏÄÎÏÍÕ ÏËÎÕ ÎÁ ËÁÖÄÙÊ ÆÁÊÌ. +.TP +\-O[N] +ïÔËÒÙÔØ N ÏËÏÎ, ÒÁÚÄÅÌ£ÎÎÙÈ ÐÏ ×ÅÒÔÉËÁÌÉ. åÓÌÉ N ÎÅ ÕËÁÚÁÎÏ, ÔÏ ÏÔËÒÙ×ÁÅÔÓÑ +ÐÏ ÏÄÎÏÍÕ ÏËÎÕ ÎÁ ËÁÖÄÙÊ ÆÁÊÌ. +.TP +\-R +òÅÖÉÍ "ÔÏÌØËÏ ÄÌÑ ÞÔÅÎÉÑ". ÷ËÌÀÞÁÅÔÓÑ ÏÐÃÉÑ 'readonly'. +æÁÊÌ × ÂÕÆÅÒÅ ÄÏÓÔÕÐÅÎ ÄÌÑ ÒÅÄÁËÔÉÒÏ×ÁÎÉÑ, ÎÏ ÅÇÏ ËÏÐÉÀ ÎÁ ÄÉÓËÅ ÎÅÌØÚÑ +ÓÌÕÞÁÊÎÏ ÐÅÒÅÚÁÐÉÓÁÔØ. äÌÑ ÓÏÈÒÁÎÅÎÉÑ ÆÁÊÌÁ ÎÅÏÂÈÏÄÉÍÏ ÄÏÂÁ×ÉÔØ ×ÏÓËÌÉÃÁÔÅÌØÎÙÊ +ÚÎÁË Ë ÓÏÏÔ×ÅÔÓÔ×ÕÀÝÅÊ ËÏÍÁÎÄÅ Ex (ÎÁÐÒÉÍÅÒ, ":w!"). +ëÌÀÞ "\-R" ÐÏÄÒÁÚÕÍÅ×ÁÅÔ ÔÁËÖÅ, ÞÔÏ ÉÓÐÏÌØÚÕÅÔÓÑ É ËÌÀÞ "\-n" (ÓÍ. ×ÙÛÅ). +ïÐÃÉÑ 'readonly' ÍÏÖÅÔ ÂÙÔØ ×ÙËÌÀÞÅÎÁ ÐÏ ËÏÍÁÎÄÅ ":set noro". +óÍ. ":help 'readonly'". +.TP +\-r +÷Ù×ÅÓÔÉ ÓÐÉÓÏË Ó×ÏÐ-ÆÁÊÌÏ× É ÉÎÆÏÒÍÁÃÉÀ Ï ÉÈ ÉÓÐÏÌØÚÏ×ÁÎÉÉ ÄÌÑ ×ÏÓÓÔÁÎÏ×ÌÅÎÉÑ ÐÏÓÌÅ ÓÂÏÑ. +.TP +\-r {ÆÁÊÌ} +òÅÖÉÍ ×ÏÓÓÔÁÎÏ×ÌÅÎÉÑ. +äÌÑ ×ÏÓÓÔÁÎÏ×ÌÅÎÉÑ ÐÏÓÌÅ ÓÂÏÑ ÂÕÄÅÔ ÉÓÐÏÌØÚÏ×ÁÎ Ó×ÏÐ-ÆÁÊÌ. +ó×ÏÐ-ÆÁÊÌ ÉÍÅÅÔ ÔÏ ÖÅ ÉÍÑ, ÞÔÏ É ÔÅËÓÔÏ×ÙÊ ÆÁÊÌ, ÎÏ Ó ÄÏÂÁ×ÌÅÎÉÅÍ ÒÁÓÛÉÒÅÎÉÑ ".swp". +óÍ. ":help recovery". +.TP +\-s +ôÉÈÉÊ ÒÅÖÉÍ. ôÏÌØËÏ ÐÒÉ ÚÁÐÕÓËÅ ËÁË "Ex" ÉÌÉ ÅÓÌÉ ÐÅÒÅÄ "\-s" ÕËÁÚÁÎ ËÌÀÞ "\-e". +.TP +\-s {scriptin} +óÞÉÔÙ×ÁÅÔÓÑ ÆÁÊÌ ÓÃÅÎÁÒÉÑ {scriptin}. ðÒÉ ÜÔÏÍ, ÓÏÄÅÒÖÉÍÏÅ ÆÁÊÌÁ ×ÏÓÐÒÉÎÉÍÁÅÔÓÑ +× ×ÉÄÅ ËÏÍÁÎÄ, ËÁË ÅÓÌÉ ÂÙ ÏÎÉ ÂÙÌÉ ÎÁÂÒÁÎÙ ÎÁ ËÏÎÓÏÌÉ. +ôÏ ÖÅ ÓÁÍÏÅ ÄÏÓÔÉÇÁÅÔÓÑ ËÏÍÁÎÄÏÊ ":source! {scriptin}". +åÓÌÉ ËÏÎÅà ÆÁÊÌÁ ÓÞÉÔÙ×ÁÅÔÓÑ ÄÏ ÚÁ×ÅÒÛÅÎÉÑ ÒÁÂÏÔÙ ÒÅÄÁËÔÏÒÁ, ÔÏ × ÄÁÌØÎÅÊÛÅÍ +××ÏÄ ÏÓÕÝÅÓÔ×ÌÑÅÔÓÑ Ó ËÌÁ×ÉÁÔÕÒÙ. +.TP +\-T {terminal} +óÏÏÂÝÁÅÔ +.B Vim +ÔÉÐ ÉÓÐÏÌØÚÕÅÍÏÇÏ ÔÅÒÍÉÎÁÌÁ. îÅÏÂÈÏÄÉÍÏ ÔÏÌØËÏ × ÔÅÈ ÓÉÔÕÁÃÉÑÈ, ËÏÇÄÁ +Á×ÔÏÍÁÔÉÞÅÓËÏÅ ÏÐÒÅÄÅÌÅÎÉÅ ÔÅÒÍÉÎÁÌÁ ÎÅ ÒÁÂÏÔÁÅÔ. éÍÑ ÔÅÒÍÉÎÁÌÁ ÄÏÌÖÎÏ ÂÙÔØ +ÉÚ×ÅÓÔÎÏ +.B Vim +(×ÓÔÒÏÅÎÏ × ÎÅÇÏ) ÉÌÉ ÏÐÒÅÄÅÌÅÎÏ × ÆÁÊÌÁÈ termcap ÉÌÉ terminfo. +.TP +\-u {vimrc} +éÓÐÏÌØÚÏ×ÁÔØ ËÏÍÁÎÄÙ ÉÚ ÆÁÊÌÁ ÓÃÅÎÁÒÉÑ {vimrc} ÄÌÑ ÎÁÓÔÒÏÊËÉ. +÷ÓÅ ÏÓÔÁÌØÎÙÅ ÆÁÊÌÙ ÎÁÓÔÒÏÅË ÐÒÏÐÕÓËÁÀÔÓÑ. +õÄÏÂÎÏ ÄÌÑ ÒÅÄÁËÔÉÒÏ×ÁÎÉÑ ÓÐÅÃÉÁÌØÎÙÈ ÔÉÐÏ× ÆÁÊÌÏ×. +þÔÏÂÙ ÉÚÂÅÖÁÔØ ÉÓÐÏÌØÚÏ×ÁÎÉÑ ÓÃÅÎÁÒÉÅ× ÎÁÓÔÒÏÅË ×ÏÏÂÝÅ, ÍÏÖÎÏ ÉÓÐÏÌØÚÏ×ÁÔØ +ÉÍÑ "NONE". óÍ. ":help initialization". +.TP +\-U {gvimrc} +éÓÐÏÌØÚÏ×ÁÔØ ËÏÍÁÎÄÙ ÉÚ ÆÁÊÌÁ ÓÃÅÎÁÒÉÑ {gvimrc} ÄÌÑ ÎÁÓÔÒÏÊËÉ ÇÒÁÆÉÞÅÓËÏÇÏ +ÉÎÔÅÒÆÅÊÓÁ. +÷ÓÅ ÏÓÔÁÌØÎÙÅ ÆÁÊÌÙ ÎÁÓÔÒÏÅË ÄÌÑ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ ÐÒÏÐÕÓËÁÀÔÓÑ. +þÔÏÂÙ ÉÚÂÅÖÁÔØ ÉÓÐÏÌØÚÏ×ÁÎÉÑ ÓÃÅÎÁÒÉÅ× ÎÁÓÔÒÏÅË ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ ×ÏÏÂÝÅ, +ÍÏÖÎÏ ÉÓÐÏÌØÚÏ×ÁÔØ ÉÍÑ "NONE". óÍ. ":help gui-init". +.TP +\-V +"âÏÌÔÌÉ×ÙÊ" ÒÅÖÉÍ. ÷Ù×ÏÄÉÔØ ÓÏÏÂÝÅÎÉÑ Ï ÔÏÍ, ËÁËÉÅ ÆÁÊÌÙ ÞÉÔÁÀÔÓÑ, É Ï +ÞÔÅÎÉÉ-ÚÁÐÉÓÉ ÆÁÊÌÁ viminfo. +.TP +\-v +úÁÐÕÓÔÉÔØ +.B Vim +× ÒÅÖÉÍÅ Vi, ËÁË ÂÕÄÔÏ ÉÓÐÏÌÎÑÅÍÙÊ ÆÁÊÌ ÉÍÅÅÔ ÉÍÑ "vi". éÍÅÅÔ ÓÍÙÓÌ ÔÏÌØËÏ ÅÓÌÉ +ÉÓÐÏÌÎÑÅÍÙÊ ÆÁÊÌ ÉÍÅÅÔ ÉÍÑ "ex". +.TP +\-w {scriptout} +÷ÓÅ ÓÉÍ×ÏÌÙ, ××ÅÄ£ÎÎÙÅ Ó ËÌÁ×ÉÁÔÕÒÙ ×ÐÌÏÔØ ÄÏ ÍÏÍÅÎÔÁ ÚÁ×ÅÒÛÅÎÉÑ ÒÁÂÏÔÙ, +ÚÁÐÉÓÙ×ÁÀÔÓÑ × ÆÁÊÌ {scriptout}. +õÄÏÂÎÏ × ÔÏÍ ÓÌÕÞÁÅ, ËÏÇÄÁ ×Ù ÈÏÔÉÔÅ ÓÏÚÄÁÔØ ÆÁÊÌ ÓÃÅÎÁÒÉÑ ÄÌÑ ÐÏÓÌÅÄÕÀÝÅÇÏ +ÉÓÐÏÌØÚÏ×ÁÎÉÑ Ó "vim \-s" ÉÌÉ ":source!". åÓÌÉ ÆÁÊÌ {scriptout} ÕÖÅ ÓÕÝÅÓÔ×ÕÅÔ, +ÔÏ ÎÏ×ÙÅ ÓÉÍ×ÏÌÙ ÂÕÄÕÔ ÄÏÂÁ×ÌÑÀÔÓÑ × ËÏÎÅà ÆÁÊÌÁ. +.TP +\-W {scriptout} +ëÁË "\-w", ÎÏ ÕÖÅ ÓÕÝÅÓÔ×ÕÀÝÉÊ ÆÁÊÌ ÂÕÄÅÔ ÐÅÒÅÚÁÐÉÓÁÎ. +.TP +\-x +ûÉÆÒÏ×ÁÔØ ÚÁÐÉÓÙ×ÁÅÍÙÅ ÆÁÊÌÙ. âÕÄÅÔ ×ÙÄÁÎÏ ÐÒÉÇÌÁÛÅÎÉÅ ××ÅÓÔÉ ÐÁÒÏÌØ. +.TP +\-X +îÅ ÐÏÄËÌÀÞÁÔØÓÑ Ë X-ÓÅÒ×ÅÒÕ. õÓËÏÒÑÅÔ ÚÁÇÒÕÚËÕ ÎÁ ËÏÎÓÏÌÉ, ÎÏ ÄÅÌÁÅÔ ÎÅ×ÏÚÍÏÖÎÙÍ +ÉÓÐÏÌØÚÏ×ÁÎÉÅ ÚÁÇÏÌÏ×ËÁ ÏËÎÁ É ÂÕÆÅÒÁ ÏÂÍÅÎÁ. +.TP +\-Z +ïÇÒÁÎÉÞÅÎÎÙÊ ÒÅÖÉÍ. òÁÂÏÔÁÅÔ ÔÁË ÖÅ, ËÁË É ÐÒÏÇÒÁÍÍÙ, ÎÁÞÉÎÁÀÝÉÅÓÑ Ó "r". +.TP +\-\- +ëÏÎÅà ËÌÀÞÅÊ. ÷ÓÅ ÏÓÔÁÌØÎÙÅ ÁÒÇÕÍÅÎÔÙ ÒÁÓÓÍÁÔÒÉ×ÁÀÔÓÑ ËÁË ÉÍÅÎÁ ÆÁÊÌÏ×. +íÏÖÅÔ ÂÙÔØ ÉÓÐÏÌØÚÏ×ÁÎÏ ÄÌÑ ÐÒÁ×ËÉ ÆÁÊÌÏ×, ÉÍÅÎÁ ËÏÔÏÒÙÈ ÎÁÞÉÎÁÀÔÓÑ Ó ÄÅÆÉÓÁ. +.TP +\-\-help +÷Ù×ÅÓÔÉ ËÒÁÔËÕÀ ÓÐÒÁ×ËÕ É ÚÁ×ÅÒÛÉÔØ ÒÁÂÏÔÕ. ôÏ ÖÅ, ÞÔÏ É "\-h". +.TP +\-\-version +÷Ù×ÅÓÔÉ ÉÎÆÏÒÍÁÃÉÀ Ï ×ÅÒÓÉÉ ÐÒÏÇÒÁÍÍÙ É ÚÁ×ÅÒÛÉÔØ ÒÁÂÏÔÕ. +.TP +\-\-remote +ðÏÄËÌÀÞÉÔØÓÑ Ë ÓÅÒ×ÅÒÕ Vim É ÚÁÓÔÁ×ÉÔØ ÅÇÏ ÐÒÁ×ÉÔØ ÆÁÊÌÙ, ÕËÁÚÁÎÎÙÅ × +ÐÏÓÌÅÄÕÀÝÉÈ ÁÒÇÕÍÅÎÔÁÈ. åÓÌÉ ÓÅÒ×ÅÒ ÎÅ ÎÁÊÄÅÎ, ×Ù×ÏÄÉÔÓÑ ÐÒÅÄÕÐÒÅÖÄÅÎÉÅ, +Á ÆÁÊÌÙ ÐÒÁ×ÑÔÓÑ × ÍÅÓÔÎÏÊ ËÏÐÉÉ Vim. +.TP +\-\-remote\-expr {×ÙÒÁÖÅÎÉÅ} +ðÏÄËÌÀÞÉÔØÓÑ Ë ÓÅÒ×ÅÒÕ Vim É ×ÙÞÉÓÌÉÔØ ÎÁ Î£Í ÕËÁÚÁÎÎÏÅ {×ÙÒÁÖÅÎÉÅ}. +òÅÚÕÌØÔÁÔ ×ÙÞÉÓÌÅÎÉÑ ÂÕÄÅÔ ×Ù×ÅÄÅÎ × ÐÏÔÏË ÓÔÁÎÄÁÒÔÎÏÇÏ ×Ù×ÏÄÁ (stdout). +.TP +\-\-remote\-send {ËÌÀÞÉ} +ðÏÄËÌÀÞÉÔØÓÑ Ë ÓÅÒ×ÅÒÕ Vim É ÐÅÒÅÄÁÔØ ÅÍÕ ÕËÁÚÁÎÎÙÅ {ËÌÀÞÉ}. +.TP +\-\-remote\-silent +ëÁË "\-\-remote", ÎÏ ÂÅÚ ×Ù×ÏÄÁ ÐÒÅÄÕÐÒÅÖÄÅÎÉÑ, ÅÓÌÉ ÓÅÒ×ÅÒ ÎÅ ÎÁÊÄÅÎ. +.TP +\-\-remote\-wait +ëÁË "\-\-remote", ÎÏ Vim ÎÅ ÂÕÄÅÔ ÚÁ×ÅÒÛÁÔØ ÒÁÂÏÔÕ ÄÏ ÔÅÈ ÐÏÒ, ÐÏËÁ ÎÅ ÂÕÄÅÔ +×ÙÐÏÌÎÅÎÁ ÐÒÁ×ËÁ ×ÓÅÈ ÆÁÊÌÏ×. +.TP +\-\-remote\-wait\-silent +ëÁË "\-\-remote\-wait", ÎÏ ÂÅÚ ×Ù×ÏÄÁ ÐÒÅÄÕÐÒÅÖÄÅÎÉÑ, ÅÓÌÉ ÓÅÒ×ÅÒ ÎÅ ÎÁÊÄÅÎ. +.TP +\-\-serverlist +÷Ù×ÅÓÔÉ ÓÐÉÓÏË ×ÓÅÈ ÄÏÓÔÕÐÎÙÈ ÓÅÒ×ÅÒÏ× Vim. +.TP +\-\-servername {ÉÍÑ} +éÓÐÏÌØÚÏ×ÁÔØ ÕËÁÚÁÎÎÏÅ {ÉÍÑ} × ËÁÞÅÓÔ×Å ÉÍÅÎÉ ÓÅÒ×ÅÒÁ. åÓÌÉ ËÌÀÞ +"\-\-remote" ÎÅ ÕËÁÚÁÎ, ÔÏ {ÉÍÑ} ÐÒÉÓ×ÁÉ×ÁÅÔÓÑ ÄÁÎÎÏÊ ËÏÐÉÉ Vim, +× ÐÒÏÔÉ×ÎÏÍ ÓÌÕÞÁÅ ÕËÁÚÙ×ÁÅÔ ÎÁ ÉÍÑ ÓÅÒ×ÅÒÁ, Ë ËÏÔÏÒÏÍÕ ÓÌÅÄÕÅÔ +ÐÏÄËÌÀÞÉÔØÓÑ. +.TP +\-\-socketid {id} +ôÏÌØËÏ ÄÌÑ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ GTK: ÉÓÐÏÌØÚÏ×ÁÔØ ÍÅÈÁÎÉÚÍ GtkPlug ÄÌÑ +ÚÁÐÕÓËÁ gvim × ÏÔÄÅÌØÎÏÍ ÏËÎÅ. +.TP +\-\-echo\-wid +ôÏÌØËÏ ÄÌÑ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ GTK: ×Ù×ÅÓÔÉ ÉÄÅÎÔÉÆÉËÁÔÏÒ ÏËÎÁ (Window ID) +× ÐÏÔÏË ÓÔÁÎÄÁÒÔÎÏÇÏ ×Ù×ÏÄÁ (stdout). +.SH ÷óôòïåîîáñ óðòá÷ëá +äÌÑ ÎÁÞÁÌÁ, ÎÁÂÅÒÉÔÅ ËÏÍÁÎÄÕ ":help". +÷×ÅÄÉÔÅ ":help ÔÅÍÁ", ÞÔÏÂÙ ÐÏÌÕÞÉÔØ ÓÐÒÁ×ËÕ ÐÏ ËÏÎËÒÅÔÎÏÊ ÔÅÍÅ. +îÁÐÒÉÍÅÒ, ËÏÍÁÎÄÁ ":help ZZ" ×Ù×ÅÄÅÔ ÉÎÆÏÒÍÁÃÉÀ Ï ËÏÍÁÎÄÅ "ZZ". +éÓÐÏÌØÚÕÊÔÅ <Tab> É CTRL-D ÄÌÑ Á×ÔÏÍÁÔÉÞÅÓËÏÇÏ ÄÏÐÏÌÎÅÎÉÑ +ÎÁÚ×ÁÎÉÊ ÔÅÍ (":help cmdline-completion"). +äÌÑ ÂÙÓÔÒÏÇÏ ÐÅÒÅÍÅÝÅÎÉÑ ÐÏ ÓÐÒÁ×ÏÞÎÉËÕ ÉÓÐÏÌØÚÕÀÔÓÑ ÍÅÔËÉ (ÞÔÏ-ÔÏ +×ÒÏÄÅ ÇÉÐÅÒÔÅËÓÔÏ×ÙÈ ÓÓÙÌÏË, ÓÍ. ":help"). ôÁËÉÍ ÏÂÒÁÚÏÍ ÍÏÖÎÏ +ÐÒÏÓÍÁÔÒÉ×ÁÔØ ×ÓÅ ÆÁÊÌÙ ÓÐÒÁ×ËÉ, ÎÁÐÒÉÍÅÒ ":help syntax.txt". +.SH æáêìù +.TP 15 +/usr/local/lib/vim/doc/*.txt +æÁÊÌÙ ÓÐÒÁ×ÏÞÎÉËÁ +.B Vim. +óÍ. ":help doc-file-list" ÄÌÑ ÐÏÌÕÞÅÎÉÑ ÐÏÌÎÏÇÏ ÓÐÉÓËÁ. +.TP +/usr/local/lib/vim/doc/tags +æÁÊÌ ÍÅÔÏË, ÉÓÐÏÌØÚÕÅÍÙÊ ÄÌÑ ÐÏÉÓËÁ ÉÎÆÏÒÍÁÃÉÉ × ÆÁÊÌÁÈ ÓÐÒÁ×ËÉ. +.TP +/usr/local/lib/vim/syntax/syntax.vim +óÉÓÔÅÍÎÙÅ ÎÁÓÔÒÏÊËÉ ÓÉÎÔÁËÓÉÓÁ. +.TP +/usr/local/lib/vim/syntax/*.vim +æÁÊÌÙ ÓÉÎÔÁËÓÉÓÁ ÄÌÑ ÒÁÚÎÙÈ ÑÚÙËÏ×. +.TP +/usr/local/lib/vim/vimrc +óÉÓÔÅÍÎÙÅ ÎÁÓÔÒÏÊËÉ +.B Vim. +.TP +/usr/local/lib/vim/gvimrc +óÉÓÔÅÍÎÙÊ ÎÁÓÔÒÏÊËÉ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ. +.TP +/usr/local/lib/vim/optwin.vim +óÃÅÎÁÒÉÊ, ÉÓÐÏÌØÚÕÅÍÙÊ ÐÒÉ ×ÙÐÏÌÎÅÎÉÉ ËÏÍÁÎÄÙ ":options". +èÏÒÏÛÉÊ ÓÐÏÓÏ ÐÒÏÓÍÁÔÒÉ×ÁÔØ É ÉÚÍÅÎÑÔØ ÎÁÓÔÒÏÊËÉ. +.TP +/usr/local/lib/vim/menu.vim +óÉÓÔÅÍÎÙÅ ÎÁÓÔÒÏÊËÉ ÍÅÎÀ ÄÌÑ gvim. +.TP +/usr/local/lib/vim/bugreport.vim +óÃÅÎÁÒÉÊ ÄÌÑ ÓÏÚÄÁÎÉÑ ÏÔÞ£ÔÁ Ï ÏÂÎÁÒÕÖÅÎÎÙÈ ÇÌÀËÁÈ. óÍ. ":help bugs". +.TP +/usr/local/lib/vim/filetype.vim +óÃÅÎÁÒÉÊ ÄÌÑ ÏÐÒÅÄÅÌÅÎÉÑ ÔÉÐÁ ÆÁÊÌÁ ÐÏ ÉÍÅÎÉ. óÍ. ":help 'filetype'". +.TP +/usr/local/lib/vim/scripts.vim +óÃÅÎÁÒÉÊ ÄÌÑ ÏÐÒÅÄÅÌÅÎÉÑ ÔÉÐÁ ÆÁÊÌÁ ÐÏ ÓÏÄÅÒÖÉÍÏÍÕ. óÍ. ":help 'filetype'". +.TP +/usr/local/lib/vim/print/*.ps +æÁÊÌÙ ÄÌÑ ÐÅÞÁÔÉ PostScript. +.PP +âÏÌÅÅ Ó×ÅÖÁÑ ÉÎÆÏÒÍÁÃÉÑ -- ÎÁ ÓÁÊÔÅ VIM: +.br +<URL:http://www.vim.org/> +.SH óíïôòé ôáëöå +vimtutor(1) +.SH á÷ôïòù +âÏÌØÛÁÑ ÞÁÓÔØ +.B Vim +ÓÏÚÄÁÎÁ âÒÁÍÏÍ íÏÏÌÅÎÁÁÒÏÍ (Bram Moolenaar), ËÏÔÏÒÏÍÕ ÐÏÍÏÇÁÅÔ ÏÇÒÏÍÎÏÅ +ËÏÌÉÞÅÓÔ×Ï ÌÀÄÅÊ. óÍ. ":help credits" × +.B Vim. +.br +.B Vim +ÂÁÚÉÒÕÅÔÓÑ ÎÁ ËÏÄÅ ÒÅÄÁËÔÏÒÁ Stevie, ÎÁÐÉÓÁÎÎÏÇÏ ôÉÍÏÍ ôÏÍÐÓÏÎÏÍ (Tim Thompson), +ôÏÎÉ üÎÄÒÀÓÏÍ (Tony Andrews) É ç. ò. (æÒÅÄÏÍ) õÏÌÔÅÒÏÍ (G.R. (Fred) Walter). +ïÄÎÁËÏ, × ÎÁÓÔÏÑÝÅÅ ×ÒÅÍÑ × Vim ÐÏÞÔÉ ÎÅ ÏÓÔÁÌÏÓØ ÎÉÞÅÇÏ ÏÔ ÉÓÔÏÒÉÞÅÓËÏÇÏ ËÏÄÁ +ÅÇÏ ÐÒÅÄÛÅÓÔ×ÅÎÎÉËÁ. +.br +òÕÓÓËÁÑ ÌÏËÁÌÉÚÁÃÉÑ +.B Vim +×ÙÐÏÌÎÑÅÔÓÑ × ÒÁÍËÁÈ ÐÒÏÅËÔÁ "òÕ÷ÉÍ", +ÓÍ. <URL:http://sourceforge.net/projects/ruvim/>. +.SH çìàëé +óËÏÒÅÅ ×ÓÅÇÏ ÅÓÔØ. +óÍ. ":help todo" -- ÓÐÉÓÏË ÉÚ×ÅÓÔÎÙÈ ÐÒÏÂÌÅÍ. +.PP +úÁÍÅÔÉÍ, ÞÔÏ ÍÎÏÇÉÅ ×ÅÝÉ, ËÏÔÏÒÙÅ ÓÞÉÔÁÀÔÓÑ ÇÌÀËÁÍÉ, ÎÁ ÓÁÍÏÍ ÄÅÌÅ +Ñ×ÌÑÀÔÓÑ ÒÅÚÕÌØÔÁÔÏÍ ÓÌÉÛËÏÍ ÐÏÌÎÏÇÏ ×ÏÓÐÒÏÉÚ×ÅÄÅÎÉÑ ÐÏ×ÅÄÅÎÉÑ Vi. +åÓÌÉ ×Ù ÄÕÍÁÅÔÅ, ÞÔÏ ÞÔÏ-ÔÏ Ñ×ÌÑÅÔÓÑ ÏÛÉÂËÏÊ ÔÏÌØËÏ ÐÏÔÏÍÕ, ÞÔÏ +"Vi ÄÅÌÁÅÔ ÜÔÏ ÐÏ-ÄÒÕÇÏÍÕ", ×ÎÉÍÁÔÅÌØÎÏ ÐÒÏÞÉÔÁÊÔÅ ÆÁÊÌ vi_diff.txt +(ÉÌÉ ÎÁÂÅÒÉÔÅ ":help vi_diff.txt" × Vim) É ÉÓÐÏÌØÚÕÊÔÅ ÏÐÃÉÉ 'compatible' +É 'cpoptions'. diff --git a/share/vim/vim73/doc/vim-ru.UTF-8.1 b/share/vim/vim73/doc/vim-ru.UTF-8.1 new file mode 100644 index 0000000000..ef527213e3 --- /dev/null +++ b/share/vim/vim73/doc/vim-ru.UTF-8.1 @@ -0,0 +1,489 @@ +.TH VIM 1 "2002 Feb 22" +.SH ИМЯ +vim \- Vi IMproved (Улучшенный Vi), текстовый редактор для программистов +.SH КОМАНДНАЯ СТРОКА +.br +.B vim +[ключи] [файл ..] +.br +.B vim +[ключи] \- +.br +.B vim +[ключи] \-t метка +.br +.B vim +[ключи] \-q [файл ошибок] +.PP +.br +.B ex +.br +.B view +.br +.B gvim +.B gview +.br +.B rvim +.B rview +.B rgvim +.B rgview +.SH ОПИСАНИЕ +.B Vim +-- текстовый редактор, обратно-совместимый с Vi. +Он может быть использован для правки всех видов простого текста. +Особенно он хорош для правки исходных текстов программ. +.PP +По сравнению с Vi, +.B Vim +имеет много усовершенствований: многократная отмена операций, +множественность окон и буферов, подсветка синтаксиса, правка командной строки, +автодополнение имён файлов, встроенная справка, визуальное выделение и т.п. +См. ":help vi_diff.txt" для получения полного списка различий между +.B Vim +и Vi. +.PP +Во время работы в +.B Vim +можно получить справку с помощью системы встроенной справки (команда ":help"). +См. раздел "ВСТРОЕННАЯ СПРАВКА" ниже по тексту. +.PP +Чаще всего +.B Vim +запускают для правки одного файла при помощи команды +.PP + vim файл +.PP +В общем виде команда запуска +.B Vim +выглядит так: +.PP + vim [ключи] [список файлов] +.PP +Если список файлов отсутствует, редактор начнёт работу с пустым буфером. +В противном случае имя файла должно быть указано одним из следующих четырёх способов: +.TP 12 +файл .. +Список имён файлов. +Первый файл будет объявлен активным и загружен в буфер. Курсор будет помещён +в первой строке буфера. Доступ к другим файлам может быть осуществлён при +помощи команды ":next". Чтобы править файл, имя которого начинается с символа +"дефис" (-), перед списком файлов необходимо поставить "--". +.TP +\- +Файл будет прочитан из потока стандартного ввода. Команды будут считываться +из стандартного потока диагностики (stderr), который должен быть +терминалом. +.TP +\-t {метка} +Имя файла и начальная позиция курсора зависят от "метки", похожей на метку goto. +{метка} ищется в файле меток, соответствующий файл становится активным, а +соответствующая команда исполняется. +Чаще всего используется в программах на языке Си, где {метка} может быть именем +функции. +Файл, содержащий функцию, становится активным, а курсор помещается в начало функции. +См. ":help tag-commands". +.TP +\-q [файл ошибок] +Начать работу в режиме быстрого исправления. +При этом считывается [файл ошибок] и первая ошибка выводится на экран. +Если [файл ошибок] не указан, имя файла берётся из значения опции 'errorfile' +(по умолчанию: "AztecC.Err" для Amiga, "errors.err" для других систем). +К следующим ошибкам можно перейти по команде ":cn". +См. ":help quickfix". +.PP +.B Vim +ведёт себя по-разному в зависимости от имени команды (исполняемый файл может +быть одним и тем же). +.TP 10 +vim +"Нормальный" запуск, всё по умолчанию. +.TP +ex +Запуск в режиме Ex. Для перехода в нормальный режим +необходимо выполнить команду ":vi". Режим Ex включает +также ключ "\-e". +.TP +view +Запуск в режиме "только для чтения". Вы будете защищены от случайной записи +файла. То же самое можно сделать ключом "\-R". +.TP +gvim gview +Версия с графическим интерфейсом. Запускается в новом окне. +То же самое можно сделать при запуске с ключом "\-g". +.TP +rvim rview rgvim rgview +Как и предыдущие команды, но с ограничениями. Нельзя запускать команды оболочки +или приостанавливать работу +.B Vim. +Вместо приставки "r" можно использовать ключ "\-Z". +.SH КЛЮЧИ +Ключи могут быть указаны в любом порядке, до или после имён +файлов. Ключи без аргументов могут быть объединены под одним +дефисом. +.TP 12 ++[номер] +В первом файле курсор будет помещён на строку с указанным номером. +Если "номер" не указан, курсор будет помещён на последнюю строку. +.TP ++/{шаблон} +В первом файле курсор будет помещён на место первого совпадения +с указанным шаблоном. См. ":help search-pattern" для получения +списка допустимых шаблонов. +.TP ++{команда} +.TP +\-c {команда} +{команда} исполняется после загрузки первого файла как команда Ex. +Если {команда} содержит пробелы, то она должна быть заключена в +двойные кавычки (в зависимости от используемой оболочки). +Пример: vim "+set si" main.c +.br +Примечание: Можно указывать до десяти команд "+" или "\-c". +.TP +\-\-cmd {команда} +Как "\-c", но команда исполняется перед обработкой любого файла +настроек (vimrc). +Можно указывать до десяти таких команд, независимо от количества +команд "\-c". +.TP +\-A +Если +.B Vim +был собран с поддержкой арабского языка для правки файлов, +набранных справа налево, и с поддержкой арабской клавиатуры, +этот ключ запускает +.B Vim +в арабском режиме, с включенной опцией 'arabic'. В противном +случае +.B Vim +завершает работу с ошибкой. +.TP +\-b +Двоичный режим. +Производится настройка некоторых опций, делающих возможной правку +двоичного или исполняемого файла. +.TP +\-C +Режим совместимости. Включает опцию 'compatible'. +.B Vim +будет работать почти как Vi, даже если существует файл .vimrc. +.TP +\-d +Режим поиска различий. +Должно быть указано два или три имени файла. +.B Vim +откроет все файлы и покажет различия между ними +(как vimdiff(1)). +.TP +\-d {устройство} +Открыть {устройство} для использования в качестве терминала (только на Amiga). +Пример: +"\-d con:20/30/600/150". +.TP +\-e +Запустить +.B Vim +в режиме Ex, как будто исполняемый файл имеет имя "ex". +.TP +\-f +Режим активного приложения. Версия +.B Vim +с графическим интерфейсом не будет ветвиться и отключаться +от запустившей её оболочки. На платформе Amiga +.B Vim +не будет создавать новое окно. Этот ключ нужно использовать, +когда +.B Vim +запускается программой, которая должна ждать завершения +сеанса правки (например, программа для работы с электронной почтой). +На платформе Amiga команды ":sh" и ":!" не будут работать. +.TP +\-\-nofork +Режим активного приложения. Версия +.B Vim +с графическим интерфейсом не будет ветвиться и отключаться +от запустившей её оболочки. +.TP +\-F +Если +.B Vim +был собран с поддержкой FKMAP для правки текста справа налево +и настроек клавиатуры для языка фарси, этот ключ запускает +.B Vim +в режиме фарси, иначе говоря, с включёнными опциями +\&'fkmap' и 'rightleft'. +В противном случае +.B Vim +завершает работу с сообщением об ошибке. +.TP +\-g +Если +.B Vim +был собран с поддержкой графического интерфейса, этот ключ +включает графический интерфейс. В противном случае +.B Vim +завершает работу с сообщением об ошибке. +.TP +\-h +Выводит краткую информацию об аргументах и ключах командной строки. +После этого +.B Vim +завершает работу. +.TP +\-H +Если +.B Vim +был собран с поддержкой правки текста справа налево +и настроек клавиатуры для иврита, этот ключ запускает +.B Vim +в режиме иврита, иначе говоря, с включёнными опциями 'hkmap' и 'rightleft'. +В противном случае +.B Vim +завершает работу с сообщением об ошибке. +.TP +\-i {viminfo} +Если используется файл viminfo, то этот ключ задаёт имя такого файла (вместо +"~/.viminfo" по умолчанию). Можно также избежать использования файла viminfo +путём указания имени "NONE". +.TP +\-L +То же, что и \-r. +.TP +\-l +Режим Lisp. Включаются опции 'lisp' и 'showmatch'. +.TP +\-m +Изменение файлов запрещено. При этом отключается опция 'write', поэтому +запись файлов становится невозможной. +.TP +\-N +Режим неполной совместимости. Отключается 'compatible'. +.B Vim +будет работать лучше, но не будет полностью совместим с Vi, даже если +отсутствует файл сценария настроек (.vimrc). +.TP +\-n +Не использовать своп-файл. Восстановление при сбое в работе будет невозможно. +Удобно для правки файла на очень медленном носителе (например, гибком диске). +То же самое можно сделать командой ":set uc=0". Отмена -- ":set uc=200". +.TP +\-o[N] +Открыть N окон, разделённых по горизонтали. Если N не указано, то открывается +по одному окну на каждый файл. +.TP +\-O[N] +Открыть N окон, разделённых по вертикали. Если N не указано, то открывается +по одному окну на каждый файл. +.TP +\-R +Режим "только для чтения". Включается опция 'readonly'. +Файл в буфере доступен для редактирования, но его копию на диске нельзя +случайно перезаписать. Для сохранения файла необходимо добавить восклицательный +знак к соответствующей команде Ex (например, ":w!"). +Ключ "\-R" подразумевает также, что используется и ключ "\-n" (см. выше). +Опция 'readonly' может быть выключена по команде ":set noro". +См. ":help 'readonly'". +.TP +\-r +Вывести список своп-файлов и информацию об их использовании для восстановления после сбоя. +.TP +\-r {файл} +Режим восстановления. +Для восстановления после сбоя будет использован своп-файл. +Своп-файл имеет то же имя, что и текстовый файл, но с добавлением расширения ".swp". +См. ":help recovery". +.TP +\-s +Тихий режим. Только при запуске как "Ex" или если перед "\-s" указан ключ "\-e". +.TP +\-s {scriptin} +Считывается файл сценария {scriptin}. При этом, содержимое файла воспринимается +в виде команд, как если бы они были набраны на консоли. +То же самое достигается командой ":source! {scriptin}". +Если конец файла считывается до завершения работы редактора, то в дальнейшем +ввод осуществляется с клавиатуры. +.TP +\-T {terminal} +Сообщает +.B Vim +тип используемого терминала. Необходимо только в тех ситуациях, когда +автоматическое определение терминала не работает. Имя терминала должно быть +известно +.B Vim +(встроено в него) или определено в файлах termcap или terminfo. +.TP +\-u {vimrc} +Использовать команды из файла сценария {vimrc} для настройки. +Все остальные файлы настроек пропускаются. +Удобно для редактирования специальных типов файлов. +Чтобы избежать использования сценариев настроек вообще, можно использовать +имя "NONE". См. ":help initialization". +.TP +\-U {gvimrc} +Использовать команды из файла сценария {gvimrc} для настройки графического +интерфейса. +Все остальные файлы настроек для графического интерфейса пропускаются. +Чтобы избежать использования сценариев настроек графического интерфейса вообще, +можно использовать имя "NONE". См. ":help gui-init". +.TP +\-V +"Болтливый" режим. Выводить сообщения о том, какие файлы читаются, и о +чтении-записи файла viminfo. +.TP +\-v +Запустить +.B Vim +в режиме Vi, как будто исполняемый файл имеет имя "vi". Имеет смысл только если +исполняемый файл имеет имя "ex". +.TP +\-w {scriptout} +Все символы, введённые с клавиатуры вплоть до момента завершения работы, +записываются в файл {scriptout}. +Удобно в том случае, когда вы хотите создать файл сценария для последующего +использования с "vim \-s" или ":source!". Если файл {scriptout} уже существует, +то новые символы будут добавляются в конец файла. +.TP +\-W {scriptout} +Как "\-w", но уже существующий файл будет перезаписан. +.TP +\-x +Шифровать записываемые файлы. Будет выдано приглашение ввести пароль. +.TP +\-X +Не подключаться к X-серверу. Ускоряет загрузку на консоли, но делает невозможным +использование заголовка окна и буфера обмена. +.TP +\-Z +Ограниченный режим. Работает так же, как и программы, начинающиеся с "r". +.TP +\-\- +Конец ключей. Все остальные аргументы рассматриваются как имена файлов. +Может быть использовано для правки файлов, имена которых начинаются с дефиса. +.TP +\-\-help +Вывести краткую справку и завершить работу. То же, что и "\-h". +.TP +\-\-version +Вывести информацию о версии программы и завершить работу. +.TP +\-\-remote +Подключиться к серверу Vim и заставить его править файлы, указанные в +последующих аргументах. Если сервер не найден, выводится предупреждение, +а файлы правятся в местной копии Vim. +.TP +\-\-remote\-expr {выражение} +Подключиться к серверу Vim и вычислить на нём указанное {выражение}. +Результат вычисления будет выведен в поток стандартного вывода (stdout). +.TP +\-\-remote\-send {ключи} +Подключиться к серверу Vim и передать ему указанные {ключи}. +.TP +\-\-remote\-silent +Как "\-\-remote", но без вывода предупреждения, если сервер не найден. +.TP +\-\-remote\-wait +Как "\-\-remote", но Vim не будет завершать работу до тех пор, пока не будет +выполнена правка всех файлов. +.TP +\-\-remote\-wait\-silent +Как "\-\-remote\-wait", но без вывода предупреждения, если сервер не найден. +.TP +\-\-serverlist +Вывести список всех доступных серверов Vim. +.TP +\-\-servername {имя} +Использовать указанное {имя} в качестве имени сервера. Если ключ +"\-\-remote" не указан, то {имя} присваивается данной копии Vim, +в противном случае указывает на имя сервера, к которому следует +подключиться. +.TP +\-\-socketid {id} +Только для графического интерфейса GTK: использовать механизм GtkPlug для +запуска gvim в отдельном окне. +.TP +\-\-echo\-wid +Только для графического интерфейса GTK: вывести идентификатор окна (Window ID) +в поток стандартного вывода (stdout). +.SH ВСТРОЕННАЯ СПРАВКА +Для начала, наберите команду ":help". +Введите ":help тема", чтобы получить справку по конкретной теме. +Например, команда ":help ZZ" выведет информацию о команде "ZZ". +Используйте <Tab> и CTRL-D для автоматического дополнения +названий тем (":help cmdline-completion"). +Для быстрого перемещения по справочнику используются метки (что-то +вроде гипертекстовых ссылок, см. ":help"). Таким образом можно +просматривать все файлы справки, например ":help syntax.txt". +.SH ФАЙЛЫ +.TP 15 +/usr/local/lib/vim/doc/*.txt +Файлы справочника +.B Vim. +См. ":help doc-file-list" для получения полного списка. +.TP +/usr/local/lib/vim/doc/tags +Файл меток, используемый для поиска информации в файлах справки. +.TP +/usr/local/lib/vim/syntax/syntax.vim +Системные настройки синтаксиса. +.TP +/usr/local/lib/vim/syntax/*.vim +Файлы синтаксиса для разных языков. +.TP +/usr/local/lib/vim/vimrc +Системные настройки +.B Vim. +.TP +/usr/local/lib/vim/gvimrc +Системный настройки графического интерфейса. +.TP +/usr/local/lib/vim/optwin.vim +Сценарий, используемый при выполнении команды ":options". +Хороший способ просматривать и изменять настройки. +.TP +/usr/local/lib/vim/menu.vim +Системные настройки меню для gvim. +.TP +/usr/local/lib/vim/bugreport.vim +Сценарий для создания отчёта об обнаруженных глюках. См. ":help bugs". +.TP +/usr/local/lib/vim/filetype.vim +Сценарий для определения типа файла по имени. См. ":help 'filetype'". +.TP +/usr/local/lib/vim/scripts.vim +Сценарий для определения типа файла по содержимому. См. ":help 'filetype'". +.TP +/usr/local/lib/vim/print/*.ps +Файлы для печати PostScript. +.PP +Более свежая информация -- на сайте VIM: +.br +<URL:http://www.vim.org/> +.SH СМОТРИ ТАКЖЕ +vimtutor(1) +.SH АВТОРЫ +Большая часть +.B Vim +создана Брамом Мооленааром (Bram Moolenaar), которому помогает огромное +количество людей. См. ":help credits" в +.B Vim. +.br +.B Vim +базируется на коде редактора Stevie, написанного Тимом Томпсоном (Tim Thompson), +Тони Эндрюсом (Tony Andrews) и Г. Р. (Фредом) Уолтером (G.R. (Fred) Walter). +Однако, в настоящее время в Vim почти не осталось ничего от исторического кода +его предшественника. +.br +Русская локализация +.B Vim +выполняется в рамках проекта "РуВим", +см. <URL:http://sourceforge.net/projects/ruvim/>. +.SH ГЛЮКИ +Скорее всего есть. +См. ":help todo" -- список известных проблем. +.PP +Заметим, что многие вещи, которые считаются глюками, на самом деле +являются результатом слишком полного воспроизведения поведения Vi. +Если вы думаете, что что-то является ошибкой только потому, что +"Vi делает это по-другому", внимательно прочитайте файл vi_diff.txt +(или наберите ":help vi_diff.txt" в Vim) и используйте опции 'compatible' +и 'cpoptions'. diff --git a/share/vim/vim72/doc/vim.1 b/share/vim/vim73/doc/vim.1 similarity index 100% rename from share/vim/vim72/doc/vim.1 rename to share/vim/vim73/doc/vim.1 diff --git a/share/vim/vim72/doc/vim.man b/share/vim/vim73/doc/vim.man similarity index 100% rename from share/vim/vim72/doc/vim.man rename to share/vim/vim73/doc/vim.man diff --git a/share/vim/vim72/doc/vim.man.info b/share/vim/vim73/doc/vim.man.info similarity index 100% rename from share/vim/vim72/doc/vim.man.info rename to share/vim/vim73/doc/vim.man.info diff --git a/share/vim/vim72/doc/vim2html.pl b/share/vim/vim73/doc/vim2html.pl similarity index 100% rename from share/vim/vim72/doc/vim2html.pl rename to share/vim/vim73/doc/vim2html.pl diff --git a/share/vim/vim73/doc/vimdiff-fr.1 b/share/vim/vim73/doc/vimdiff-fr.1 new file mode 100644 index 0000000000..4948126752 --- /dev/null +++ b/share/vim/vim73/doc/vimdiff-fr.1 @@ -0,0 +1,53 @@ +.TH VIMDIFF 1 "30 mars 2001" +.SH NOM +vimdiff \- ouvre deux, trois ou quatre versions d'un fichier dans Vim et +affiche leurs différences +.SH SYNOPSIS +.br +.B vimdiff +[options] fichier1 fichier2 [fichier3 [fichier4]] +.PP +.B gvimdiff +.SH DESCRIPTION +.B Vimdiff +démarre +.B Vim +avec deux (ou trois ou quatre) fichiers. +Chaque fichier est ouvert dans sa propre fenêtre. +Les différences entres ces fichiers sont mises en surbrillance. +C'est un outil très pratique pour visualiser et reporter les +changements entre deux versions d'un même fichier. +.PP +Consulter vim(1) pour des informations sur l'éditeur Vim lui-même. +.PP +Si +.B gvimdiff +est invoqué, l'IHM graphique est démarrée quand elle est disponible. +.PP +L'option 'diff' est activée dans chacune des fenêtres, ce qui provoque la mise +en surbrillance des différences. +.br +Les options 'wrap' et 'scrollbind' sont activées pour donner un aspect +agréable au texte. +.br +L'option 'foldmethod' est fixée à "diff", ce qui replie les lignes consécutives +identiques. 'foldcolumn' est fixé à 2 pour trouver les replis rapidement et +les ouvrir ou les fermer facilement. +.SH ARGUMENTS +La fenêtre de Vim est partagée verticalement afin d'afficher les lignes +correspondantes les unes en face des autres, comme si l'argument "\-O" était +spécifié. Utilisez l'argument "\-o" pour obtenir un partage horizontal à la +place. +.PP +Pour connaître les autres arguments disponibles, consultez vim(1). +.SH VOIR AUSSI +vim(1) +.SH AUTEUR +La majeure partie de +.B Vim +a été écrite par Bram Moolenaar, avec l'aide de nombreux autres contributeurs. +Voir ":help credits" dans +.B Vim. +.SH TRADUCTION +Cette page de manuel a été traduite par David Blanchet +<david.blanchet@free.fr> 2005-03-12. diff --git a/share/vim/vim73/doc/vimdiff-fr.UTF-8.1 b/share/vim/vim73/doc/vimdiff-fr.UTF-8.1 new file mode 100644 index 0000000000..d143588cdd --- /dev/null +++ b/share/vim/vim73/doc/vimdiff-fr.UTF-8.1 @@ -0,0 +1,53 @@ +.TH VIMDIFF 1 "30 mars 2001" +.SH NOM +vimdiff \- ouvre deux, trois ou quatre versions d'un fichier dans Vim et +affiche leurs différences +.SH SYNOPSIS +.br +.B vimdiff +[options] fichier1 fichier2 [fichier3 [fichier4]] +.PP +.B gvimdiff +.SH DESCRIPTION +.B Vimdiff +démarre +.B Vim +avec deux (ou trois ou quatre) fichiers. +Chaque fichier est ouvert dans sa propre fenêtre. +Les différences entres ces fichiers sont mises en surbrillance. +C'est un outil très pratique pour visualiser et reporter les +changements entre deux versions d'un même fichier. +.PP +Consulter vim(1) pour des informations sur l'éditeur Vim lui-même. +.PP +Si +.B gvimdiff +est invoqué, l'IHM graphique est démarrée quand elle est disponible. +.PP +L'option 'diff' est activée dans chacune des fenêtres, ce qui provoque la mise +en surbrillance des différences. +.br +Les options 'wrap' et 'scrollbind' sont activées pour donner un aspect +agréable au texte. +.br +L'option 'foldmethod' est fixée à "diff", ce qui replie les lignes consécutives +identiques. 'foldcolumn' est fixé à 2 pour trouver les replis rapidement et +les ouvrir ou les fermer facilement. +.SH ARGUMENTS +La fenêtre de Vim est partagée verticalement afin d'afficher les lignes +correspondantes les unes en face des autres, comme si l'argument "\-O" était +spécifié. Utilisez l'argument "\-o" pour obtenir un partage horizontal à la +place. +.PP +Pour connaître les autres arguments disponibles, consultez vim(1). +.SH VOIR AUSSI +vim(1) +.SH AUTEUR +La majeure partie de +.B Vim +a été écrite par Bram Moolenaar, avec l'aide de nombreux autres contributeurs. +Voir ":help credits" dans +.B Vim. +.SH TRADUCTION +Cette page de manuel a été traduite par David Blanchet +<david.blanchet@free.fr> 2005-03-12. diff --git a/share/vim/vim73/doc/vimdiff-it.1 b/share/vim/vim73/doc/vimdiff-it.1 new file mode 100644 index 0000000000..2203877acf --- /dev/null +++ b/share/vim/vim73/doc/vimdiff-it.1 @@ -0,0 +1,48 @@ +.TH VIMDIFF 1 "30 marzo 2001" +.SH NOME +vimdiff \- modifica due, tre o quattro versioni di un file con Vim, +visualizzando le differenze +.SH SINTASSI +.br +.B vimdiff +[opzioni] file1 file2 [file3 [file4]] +.PP +.B gvimdiff +.SH DESCRIZIONE +.B Vimdiff +inizia +.B Vim +per due (o tre o quattro) file. +Ogni file ha una sua finestra. +Le differenze fra file sono evidenziate. +È una maniera elegante per controllare modifiche e portare modifiche +verso un'altra versione dello stesso file. +.PP +Vedere vim(1) per dettagli su Vim in generale. +.PP +Se iniziato con +.B gvimdiff +la GUI sarà utilizzata, se disponibile. +.PP +In ogni finestra l'opzione 'diff' è impostata, evidenziando così le +differenze. +.br +Le opzioni 'wrap' e 'scrollbind' sono impostate per migliorare la +visibilità del testo. +.br +L'opzione 'foldmethod' è impostata al valore "diff", che mette gruppi di +linee uguali fra i diversi file in una piegatura. 'foldcolumn' è impostato +a due per poter facilmente visualizzare le piegature, aprirle e chiuderle. +.SH OPZIONI +Lo schermo è diviso verticalmente, come se aveste usato l'opzione "\-O". +Per dividerlo orizzontalmente, usare l'opzione "\-o". +.PP +Per tutte le altre opzioni, vedere vim(1). +.SH VEDERE ANCHE +vim(1) +.SH AUTORE +Buona parte di +.B Vim +è stato scritto da Bram Moolenaar, con molto aiuto da altri. +Vedere ":help credits" in +.B Vim. diff --git a/share/vim/vim73/doc/vimdiff-it.UTF-8.1 b/share/vim/vim73/doc/vimdiff-it.UTF-8.1 new file mode 100644 index 0000000000..090892fa93 --- /dev/null +++ b/share/vim/vim73/doc/vimdiff-it.UTF-8.1 @@ -0,0 +1,48 @@ +.TH VIMDIFF 1 "30 marzo 2001" +.SH NOME +vimdiff \- modifica due, tre o quattro versioni di un file con Vim, +visualizzando le differenze +.SH SINTASSI +.br +.B vimdiff +[opzioni] file1 file2 [file3 [file4]] +.PP +.B gvimdiff +.SH DESCRIZIONE +.B Vimdiff +inizia +.B Vim +per due (o tre o quattro) file. +Ogni file ha una sua finestra. +Le differenze fra file sono evidenziate. +È una maniera elegante per controllare modifiche e portare modifiche +verso un'altra versione dello stesso file. +.PP +Vedere vim(1) per dettagli su Vim in generale. +.PP +Se iniziato con +.B gvimdiff +la GUI sarà utilizzata, se disponibile. +.PP +In ogni finestra l'opzione 'diff' è impostata, evidenziando così le +differenze. +.br +Le opzioni 'wrap' e 'scrollbind' sono impostate per migliorare la +visibilità del testo. +.br +L'opzione 'foldmethod' è impostata al valore "diff", che mette gruppi di +linee uguali fra i diversi file in una piegatura. 'foldcolumn' è impostato +a due per poter facilmente visualizzare le piegature, aprirle e chiuderle. +.SH OPZIONI +Lo schermo è diviso verticalmente, come se aveste usato l'opzione "\-O". +Per dividerlo orizzontalmente, usare l'opzione "\-o". +.PP +Per tutte le altre opzioni, vedere vim(1). +.SH VEDERE ANCHE +vim(1) +.SH AUTORE +Buona parte di +.B Vim +è stato scritto da Bram Moolenaar, con molto aiuto da altri. +Vedere ":help credits" in +.B Vim. diff --git a/share/vim/vim73/doc/vimdiff-pl.1 b/share/vim/vim73/doc/vimdiff-pl.1 new file mode 100644 index 0000000000..5332f78328 --- /dev/null +++ b/share/vim/vim73/doc/vimdiff-pl.1 @@ -0,0 +1,46 @@ +.TH VIMDIFF 1 "2001 Mar 30" +.SH NAZWA +vimdiff \- edytuj dwie, trzy lub cztery wersje pliku w Vimie i zobacz ró¿nice +.SH SYNOPSIS +.br +.B vimdiff +[opcje] plik1 plik2 [plik3 [plik4]] +.PP +.B gvimdiff +.SH OPIS +.B Vimdiff +uruchomi +.B Vima +z dwoma (trzema lub czterema plikami), ka¿dy z nich we w³asnym oknie. +Ró¿nice miêdzy plikami zostan± pod¶wietlone. +Jest to dobry sposób by przeanalizowaæ ró¿nice i przenie¶æ zmiany z jednej +wersji pliku do innej. +.PP +Zobacz vim(1) by poznaæ wiêcej szczegó³ów o samym Vimie. +.PP +Kiedy uruchomiony jako +.B gvimdiff +zostanie uruchomione GUI (je¶li dostêpne). +.PP +W ka¿dym oknie zostanie ustawiona opcja 'diff', która spowoduje +pod¶wietlenie ró¿nic. +.br +Opcje 'wrap' i 'scrollbind' zostan± ustawione by tekst siê +wygodnie przegl±da³o. +.br +Opcja 'foldmethod' zostanie ustawiona na "diff", dziêki czemu +niezmienione linie zostan± zwiniête. 'foldcolumn' bêdzie równe 2 aby +³atwo wyszukiwaæ, otwieraæ i zamykaæ zwiniêcia. +.SH OPCJE +Pionowy podzia³ zostanie u¿yty do wyrównania linii, tak jakby u¿yto +opcji "\-O". Aby uzyskaæ poziomy podzia³ u¿yj opcji "\-o". +.PP +Aby poznaæ inne opcje zobacz vim(1). +.SH ZOBACZ TAK¯E +vim(1) +.SH AUTOR +Wiêkszo¶æ +.B Vima +zosta³a napisana przez Brama Moolenaara przy pomocy wielu innych osób. +Zobacz ":help credits w +.B Vimie. diff --git a/share/vim/vim73/doc/vimdiff-pl.UTF-8.1 b/share/vim/vim73/doc/vimdiff-pl.UTF-8.1 new file mode 100644 index 0000000000..d66fdc9c03 --- /dev/null +++ b/share/vim/vim73/doc/vimdiff-pl.UTF-8.1 @@ -0,0 +1,46 @@ +.TH VIMDIFF 1 "2001 Mar 30" +.SH NAZWA +vimdiff \- edytuj dwie, trzy lub cztery wersje pliku w Vimie i zobacz różnice +.SH SYNOPSIS +.br +.B vimdiff +[opcje] plik1 plik2 [plik3 [plik4]] +.PP +.B gvimdiff +.SH OPIS +.B Vimdiff +uruchomi +.B Vima +z dwoma (trzema lub czterema plikami), każdy z nich we własnym oknie. +Różnice między plikami zostaną podświetlone. +Jest to dobry sposób by przeanalizować różnice i przenieść zmiany z jednej +wersji pliku do innej. +.PP +Zobacz vim(1) by poznać więcej szczegółów o samym Vimie. +.PP +Kiedy uruchomiony jako +.B gvimdiff +zostanie uruchomione GUI (jeśli dostępne). +.PP +W każdym oknie zostanie ustawiona opcja 'diff', która spowoduje +podświetlenie różnic. +.br +Opcje 'wrap' i 'scrollbind' zostaną ustawione by tekst się +wygodnie przeglądało. +.br +Opcja 'foldmethod' zostanie ustawiona na "diff", dzięki czemu +niezmienione linie zostaną zwinięte. 'foldcolumn' będzie równe 2 aby +łatwo wyszukiwać, otwierać i zamykać zwinięcia. +.SH OPCJE +Pionowy podział zostanie użyty do wyrównania linii, tak jakby użyto +opcji "\-O". Aby uzyskać poziomy podział użyj opcji "\-o". +.PP +Aby poznać inne opcje zobacz vim(1). +.SH ZOBACZ TAKŻE +vim(1) +.SH AUTOR +Większość +.B Vima +została napisana przez Brama Moolenaara przy pomocy wielu innych osób. +Zobacz ":help credits w +.B Vimie. diff --git a/share/vim/vim73/doc/vimdiff-ru.1 b/share/vim/vim73/doc/vimdiff-ru.1 new file mode 100644 index 0000000000..385536790e --- /dev/null +++ b/share/vim/vim73/doc/vimdiff-ru.1 @@ -0,0 +1,50 @@ +.TH VIMDIFF 1 "2001 March 30" +.SH éíñ +vimdiff \- ÐÏÚ×ÏÌÑÅÔ ÒÅÄÁËÔÉÒÏ×ÁÔØ Ä×Å ÉÌÉ ÔÒÉ ×ÅÒÓÉÉ ÆÁÊÌÁ Ó ÐÏÍÏÝØÀ Vim +Ó ÏÔÏÂÒÁÖÅÎÉÅÍ ÒÁÚÌÉÞÉÊ. +.SH ëïíáîäîáñ óôòïëá +.br +.B vimdiff +[ËÌÀÞÉ] ÆÁÊÌ1 ÆÁÊÌ2 [ÆÁÊÌ3] +.PP +.B gvimdiff +.SH ïðéóáîéå +ëÏÍÁÎÄÁ +.B vimdiff +ÚÁÇÒÕÖÁÅÔ × +.B Vim +Ä×Á (ÉÌÉ ÔÒÉ) ÆÁÊÌÁ. ëÁÖÄÙÊ ÆÁÊÌ ÏÔËÒÙ×ÁÅÔÓÑ × ÓÏÂÓÔ×ÅÎÎÏÍ ÏËÎÅ. +òÁÚÌÉÞÉÑ ÍÅÖÄÕ ÆÁÊÌÁÍÉ ÏÔÏÂÒÁÖÁÀÔÓÑ Ó ÐÏÍÏÝØÀ ÐÏÄÓ×ÅÔËÉ ÓÉÎÔÁËÓÉÓÁ. +üÔÁ ËÏÍÁÎÄÁ ÐÏÚ×ÏÌÑÅÔ ÎÁÇÌÑÄÎÏ ÏÔÏÂÒÁÖÁÔØ ×ÎÅÓ£ÎÎÙÅ ÉÚÍÅÎÅÎÉÑ É ÐÅÒÅÎÏÓÉÔØ +ÒÁÚÌÉÞÁÀÝÉÅÓÑ ÆÒÁÇÍÅÎÔÙ ÉÚ ÏÄÎÏÊ ×ÅÒÓÉÉ ÆÁÊÌÁ × ÄÒÕÇÕÀ. +.PP +ðÏÄÒÏÂÎÅÅ Ï Vim ÓÍ. ÎÁ ÓÔÒÁÎÉÃÅ ÓÐÒÁ×ÏÞÎÉËÁ vim(1). +.PP +ðÒÉ ÚÁÐÕÓËÅ Ó ÐÏÍÏÝØÀ ËÏÍÁÎÄÙ +.B gvimdiff +ÒÅÄÁËÔÏÒ ÚÁÐÕÓËÁÅÔÓÑ × ÒÅÖÉÍÅ ÇÒÁÆÉÞÅÓËÏÇÏ ÉÎÔÅÒÆÅÊÓÁ, ÅÓÌÉ ÜÔÏ ×ÏÚÍÏÖÎÏ. +.PP +÷ ËÁÖÄÏÍ ÏËÎÅ ×ËÌÀÞÁÅÔÓÑ ÏÐÃÉÑ 'diff', ÞÔÏ ÐÏÚ×ÏÌÑÅÔ ÉÓÐÏÌØÚÏ×ÁÔØ ÐÏÄÓ×ÅÔËÕ +ÓÉÎÔÁËÓÉÓÁ ÄÌÑ ÏÔÏÂÒÁÖÅÎÉÑ ÒÁÚÌÉÞÉÊ ÍÅÖÄÕ ÆÁÊÌÁÍÉ. +.br +äÌÑ ÕÌÕÞÛÅÎÉÑ ÒÁÂÏÔÙ Ó ÆÁÊÌÁÍÉ × ÒÅÖÉÍÅ ÏÔÏÂÒÁÖÅÎÉÑ ÏÔÌÉÞÉÊ ÔÁËÖÅ ×ËÌÀÞÁÀÔÓÑ +ÏÐÃÉÉ 'wrap' É 'scrollbind'. +.br +úÎÁÞÅÎÉÅ ÏÐÃÉÉ 'foldmethod' ÕÓÔÁÎÁ×ÌÉ×ÁÅÔÓÑ ÒÁ×ÎÙÍ "diff", ÞÔÏ ÐÏÚ×ÏÌÑÅÔ +ÐÒÑÔÁÔØ × ÓËÌÁÄËÕ ÏÂÌÁÓÔÉ ÔÅËÓÔÁ, ËÏÔÏÒÙÅ ÎÅ ÏÔÌÉÞÁÀÔÓÑ × ÒÁÚÌÉÞÎÙÈ ×ÅÒÓÉÑÈ ÆÁÊÌÁ. +úÎÁÞÅÎÉÅ ÏÐÃÉÉ 'foldcolumn' ÕÓÔÁÎÁ×ÌÉ×ÁÅÔÓÑ ÒÁ×ÎÙÍ 2, ÞÔÏÂÙ ÂÙÌÏ ÐÒÏÝÅ +ÎÁÈÏÄÉÔØ, ÏÔËÒÙ×ÁÔØ É ÚÁËÒÙ×ÁÔØ ÔÁËÉÅ ÓËÌÁÄËÉ. +.SH ëìàþé úáðõóëá +äÌÑ ×ÙÒÁ×ÎÉ×ÁÎÉÑ ÓÔÒÏË ÍÅÖÄÕ ÏËÎÁÍÉ ÉÓÐÏÌØÚÕÅÔÓÑ ×ÅÒÔÉËÁÌØÎÏÅ ÒÁÚÄÅÌÅÎÉÅ ÏËÏÎ, +ËÁË ÅÓÌÉ ÂÙ ÉÓÐÏÌØÚÏ×ÁÌÓÑ ËÌÀÞ "\-O". äÌÑ ÔÏÇÏ, ÞÔÏÂÙ ÉÓÐÏÌØÚÏ×ÁÔØ ÒÁÚÄÅÌÅÎÉÅ +ÏËÏÎ ÐÏ ÇÏÒÉÚÏÎÔÁÌÉ, ÓÌÅÄÕÅÔ ÕËÁÚÁÔØ × ËÏÍÁÎÄÎÏÊ ÓÔÒÏËÅ ËÌÀÞ "\-o". +.PP +ïÓÔÁÌØÎÙÅ ËÌÀÞÉ ËÏÍÁÎÄÎÏÊ ÓÔÒÏËÉ ÒÁÓÓÍÁÔÒÉ×ÁÀÔÓÑ ÎÁ ÓÔÒÁÎÉÃÅ ÓÐÒÁ×ÏÞÎÉËÁ vim(1). +.SH óíïôòé ôáëöå +vim(1) +.SH á÷ôïòù +âÏÌØÛÁÑ ÞÁÓÔØ +.B Vim +ÓÏÚÄÁÎÁ âÒÁÍÏÍ íÏÏÌÅÎÁÁÒÏÍ (Bram Moolenaar), ËÏÔÏÒÏÍÕ ÐÏÍÏÇÁÅÔ ÏÇÒÏÍÎÏÅ +ËÏÌÉÞÅÓÔ×Ï ÌÀÄÅÊ. óÍ. ":help credits" × +.B Vim. diff --git a/share/vim/vim73/doc/vimdiff-ru.UTF-8.1 b/share/vim/vim73/doc/vimdiff-ru.UTF-8.1 new file mode 100644 index 0000000000..2f17e9c2e5 --- /dev/null +++ b/share/vim/vim73/doc/vimdiff-ru.UTF-8.1 @@ -0,0 +1,50 @@ +.TH VIMDIFF 1 "2001 March 30" +.SH ИМЯ +vimdiff \- позволяет редактировать две или три версии файла с помощью Vim +с отображением различий. +.SH КОМАНДНАЯ СТРОКА +.br +.B vimdiff +[ключи] файл1 файл2 [файл3] +.PP +.B gvimdiff +.SH ОПИСАНИЕ +Команда +.B vimdiff +загружает в +.B Vim +два (или три) файла. Каждый файл открывается в собственном окне. +Различия между файлами отображаются с помощью подсветки синтаксиса. +Эта команда позволяет наглядно отображать внесённые изменения и переносить +различающиеся фрагменты из одной версии файла в другую. +.PP +Подробнее о Vim см. на странице справочника vim(1). +.PP +При запуске с помощью команды +.B gvimdiff +редактор запускается в режиме графического интерфейса, если это возможно. +.PP +В каждом окне включается опция 'diff', что позволяет использовать подсветку +синтаксиса для отображения различий между файлами. +.br +Для улучшения работы с файлами в режиме отображения отличий также включаются +опции 'wrap' и 'scrollbind'. +.br +Значение опции 'foldmethod' устанавливается равным "diff", что позволяет +прятать в складку области текста, которые не отличаются в различных версиях файла. +Значение опции 'foldcolumn' устанавливается равным 2, чтобы было проще +находить, открывать и закрывать такие складки. +.SH КЛЮЧИ ЗАПУСКА +Для выравнивания строк между окнами используется вертикальное разделение окон, +как если бы использовался ключ "\-O". Для того, чтобы использовать разделение +окон по горизонтали, следует указать в командной строке ключ "\-o". +.PP +Остальные ключи командной строки рассматриваются на странице справочника vim(1). +.SH СМОТРИ ТАКЖЕ +vim(1) +.SH АВТОРЫ +Большая часть +.B Vim +создана Брамом Мооленааром (Bram Moolenaar), которому помогает огромное +количество людей. См. ":help credits" в +.B Vim. diff --git a/share/vim/vim72/doc/vimdiff.1 b/share/vim/vim73/doc/vimdiff.1 similarity index 100% rename from share/vim/vim72/doc/vimdiff.1 rename to share/vim/vim73/doc/vimdiff.1 diff --git a/share/vim/vim72/doc/vimdiff.man b/share/vim/vim73/doc/vimdiff.man similarity index 100% rename from share/vim/vim72/doc/vimdiff.man rename to share/vim/vim73/doc/vimdiff.man diff --git a/share/vim/vim73/doc/vimtutor-fr.1 b/share/vim/vim73/doc/vimtutor-fr.1 new file mode 100644 index 0000000000..8367190112 --- /dev/null +++ b/share/vim/vim73/doc/vimtutor-fr.1 @@ -0,0 +1,59 @@ +.TH VIMTUTOR 1 "2 avril 2001" +.SH NAME +vimtutor \- tutoriel Vim +.SH SYNOPSIS +.br +.B vimtutor [-g] [langue] +.SH DESCRIPTION +.B Vimtutor +lance le tutoriel +.B Vim +\. +Il copie d'abord le fichier du tutoriel, afin que vous puissiez le modifier +sans altérer le fichier original. +.PP +.B Vimtutor +est utile pour les personnes souhaitant apprendre leurs premières commandes +.B Vim +\. +.PP +L'argument optionnel -g lance vimtutor avec gvim plutôt qu'avec vim, si l'IHM +graphique de vim est disponible, ou le lance avec vim si gvim n'est pas +disponible. +.PP +L'argument optionnel [langue] est le nom d'une langue, spécifiée par son +symbole à deux lettres, tels que "it" ou "es". Si l'argument [langue] est omis, +la langue de la région linguistique actuelle sera retenue. Si le tutoriel est +disponible dans cette langue, il est proposé. Sinon, c'est la version anglaise +qui est proposée. +.PP +.B Vim +est toujours lancé en mode Compatible Vi. +.SH FICHIERS +.TP 15 +/usr/local/lib/vim/tutor/tutor[.langue] +Les fichiers textes de +.B Vimtutor +\. +.TP 15 +/usr/local/lib/vim/tutor/tutor.vim +Le script Vim utilisé pour copier les fichiers texte de +.B Vimtutor +\. +.SH AUTEUR +.B Vimtutor +a été écrit à l'origine pour Vi par Michael C. Pierce et Robert K. Ware, de la +Colorado School of Mines, en reprenant des idées émises par Charles Smith, de +la Colorado State University. +E-mail : bware@mines.colorado.edu. +.br +Il a été modifié pour +.B Vim +par Bram Moolenaar. +Pour connaître le nom des traducteurs, consultez les fichiers textes du +tutoriel. +.SH VOIR AUSSI +vim(1) +.SH TRADUCTION +Cette page de manuel a été traduite par David Blanchet +<david.blanchet@free.fr> 2004-12-27. diff --git a/share/vim/vim73/doc/vimtutor-fr.UTF-8.1 b/share/vim/vim73/doc/vimtutor-fr.UTF-8.1 new file mode 100644 index 0000000000..9bf474d8f7 --- /dev/null +++ b/share/vim/vim73/doc/vimtutor-fr.UTF-8.1 @@ -0,0 +1,59 @@ +.TH VIMTUTOR 1 "2 avril 2001" +.SH NAME +vimtutor \- tutoriel Vim +.SH SYNOPSIS +.br +.B vimtutor [-g] [langue] +.SH DESCRIPTION +.B Vimtutor +lance le tutoriel +.B Vim +\. +Il copie d'abord le fichier du tutoriel, afin que vous puissiez le modifier +sans altérer le fichier original. +.PP +.B Vimtutor +est utile pour les personnes souhaitant apprendre leurs premières commandes +.B Vim +\. +.PP +L'argument optionnel -g lance vimtutor avec gvim plutôt qu'avec vim, si l'IHM +graphique de vim est disponible, ou le lance avec vim si gvim n'est pas +disponible. +.PP +L'argument optionnel [langue] est le nom d'une langue, spécifiée par son +symbole à deux lettres, tels que "it" ou "es". Si l'argument [langue] est omis, +la langue de la région linguistique actuelle sera retenue. Si le tutoriel est +disponible dans cette langue, il est proposé. Sinon, c'est la version anglaise +qui est proposée. +.PP +.B Vim +est toujours lancé en mode Compatible Vi. +.SH FICHIERS +.TP 15 +/usr/local/lib/vim/tutor/tutor[.langue] +Les fichiers textes de +.B Vimtutor +\. +.TP 15 +/usr/local/lib/vim/tutor/tutor.vim +Le script Vim utilisé pour copier les fichiers texte de +.B Vimtutor +\. +.SH AUTEUR +.B Vimtutor +a été écrit à l'origine pour Vi par Michael C. Pierce et Robert K. Ware, de la +Colorado School of Mines, en reprenant des idées émises par Charles Smith, de +la Colorado State University. +E-mail : bware@mines.colorado.edu. +.br +Il a été modifié pour +.B Vim +par Bram Moolenaar. +Pour connaître le nom des traducteurs, consultez les fichiers textes du +tutoriel. +.SH VOIR AUSSI +vim(1) +.SH TRADUCTION +Cette page de manuel a été traduite par David Blanchet +<david.blanchet@free.fr> 2004-12-27. diff --git a/share/vim/vim73/doc/vimtutor-it.1 b/share/vim/vim73/doc/vimtutor-it.1 new file mode 100644 index 0000000000..b5c1e61e01 --- /dev/null +++ b/share/vim/vim73/doc/vimtutor-it.1 @@ -0,0 +1,58 @@ +.TH VIMTUTOR 1 "2 aprile 2001" +.SH NOME +vimtutor \- Un breve corso per imparare Vim +.SH SINTASSI +.br +.B vimtutor [\-g] [lingua] +.SH DESCRIZIONE +.B Vimtutor +inizia il +.B Vim +tutor (una breve corso per imparare Vim). +Per prima cosa viene creata una copia del file di lavoro, che può così essere +modificato senza alterare il file usato come modello. +.PP +Il comando +.B Vimtutor +è utile a chi voglia imparare i primi comandi +.B Vim +. +.PP +L'argomento opzionale \-g inizia vimtutor usando gvim invece che vim, se la +versione GUI di vim è disponibile. oppure utilizza vim, se gvim non è +disponibile. +.PP +L'arogmento opzionale [lingua] è l'abbreviazione di due lettere del nome +di una lingua, per esempio "it" oppure "es". +se L'argomento [lingua] non viene specificato, si utilizza la lingua "locale" +del computer. +Se la versione in quella lingua del "tutor" è disponibile, sarà usata. +Altrimenti sarà usata la versione inglese. +.PP +.B Vim +è sempre iniziato in Modo compatibile con vi. +.SH FILE +.TP 15 +/usr/local/lib/vim/tutor/tutor[.language] +Il/I file di testo per +.B Vimtutor + +.TP 15 +/usr/local/lib/vim/tutor/tutor.vim +Lo script di Vim usato per copiare il file di testo +.B Vimtutor +. +.SH AUTORE +The +.B Vimtutor +è stato scritto in origine per Vi da Michael C. Pierce e Robert K. Ware, +Colorado School of Mines, usando idee fornite da Charles Smith, +Colorado State University. +E\-mail: bware@mines.colorado.edu. +.br +È stato modificato per +.B Vim +da Bram Moolenaar. +Per i nomi dei traduttori, vedere i file usati nelle rispettive lingue. +.SH VEDERE ANCHE +vim(1) diff --git a/share/vim/vim73/doc/vimtutor-it.UTF-8.1 b/share/vim/vim73/doc/vimtutor-it.UTF-8.1 new file mode 100644 index 0000000000..a33dcb00b0 --- /dev/null +++ b/share/vim/vim73/doc/vimtutor-it.UTF-8.1 @@ -0,0 +1,58 @@ +.TH VIMTUTOR 1 "2 aprile 2001" +.SH NOME +vimtutor \- Un breve corso per imparare Vim +.SH SINTASSI +.br +.B vimtutor [\-g] [lingua] +.SH DESCRIZIONE +.B Vimtutor +inizia il +.B Vim +tutor (una breve corso per imparare Vim). +Per prima cosa viene creata una copia del file di lavoro, che può così essere +modificato senza alterare il file usato come modello. +.PP +Il comando +.B Vimtutor +è utile a chi voglia imparare i primi comandi +.B Vim +. +.PP +L'argomento opzionale \-g inizia vimtutor usando gvim invece che vim, se la +versione GUI di vim è disponibile. oppure utilizza vim, se gvim non è +disponibile. +.PP +L'arogmento opzionale [lingua] è l'abbreviazione di due lettere del nome +di una lingua, per esempio "it" oppure "es". +se L'argomento [lingua] non viene specificato, si utilizza la lingua "locale" +del computer. +Se la versione in quella lingua del "tutor" è disponibile, sarà usata. +Altrimenti sarà usata la versione inglese. +.PP +.B Vim +è sempre iniziato in Modo compatibile con vi. +.SH FILE +.TP 15 +/usr/local/lib/vim/tutor/tutor[.language] +Il/I file di testo per +.B Vimtutor + +.TP 15 +/usr/local/lib/vim/tutor/tutor.vim +Lo script di Vim usato per copiare il file di testo +.B Vimtutor +. +.SH AUTORE +The +.B Vimtutor +è stato scritto in origine per Vi da Michael C. Pierce e Robert K. Ware, +Colorado School of Mines, usando idee fornite da Charles Smith, +Colorado State University. +E\-mail: bware@mines.colorado.edu. +.br +È stato modificato per +.B Vim +da Bram Moolenaar. +Per i nomi dei traduttori, vedere i file usati nelle rispettive lingue. +.SH VEDERE ANCHE +vim(1) diff --git a/share/vim/vim73/doc/vimtutor-pl.1 b/share/vim/vim73/doc/vimtutor-pl.1 new file mode 100644 index 0000000000..e603ca5b8f --- /dev/null +++ b/share/vim/vim73/doc/vimtutor-pl.1 @@ -0,0 +1,51 @@ +.TH VIMTUTOR 1 "2001 Kwi 2" +.SH NAZWA +vimtutor \- nauczyciel Vima +.SH SYNOPSIS +.br +.B vimtutor -g [jêzyk] +.SH OPIS +.B Vimtutor +uruchamia nauczyciela +.B Vima. +Najpierw kopiuje w³a¶ciwy plik, dziêki temu mo¿na go zmieniaæ bez obaw +utraty tre¶ci. +.PP +.B Vimtutor +przyda siê ludziom, którzy chc± siê nauczyæ pierwszych poleceñ +.B Vima +.PP +Opcjonalny argument \-g uruchamia vimtutor w gvimie a nie w Vimie je¶li +graficzna wersja Vima jest dostêpna, je¶li nie zostanie uruchomiony Vim. +.PP +Opcjonalny argument [jêzyk] jest dwu literowym kodem jêzyka, tak jak +"it" lub "es". +Je¶li brak argumentu [jêzyk] zostanie u¿yty jêzyk bie¿±cej +lokalizacji. +Je¶li nauczyciel w tym jêzyku jest dostêpny, zostanie u¿yty \- w innym +wypadku zostanie wykorzystana wersja angielska. +.PP +.B Vim +jest uruchamiany zawsze w trybie kompatybilno¶ci z Vi +.SH PLIKI +.TP 15 +/usr/local/lib/vim/tutor/tutor[.jêzyk] +Tekstowe pliki +.B Vimtutora. +.TP 15 +/usr/local/lib/vim/tutor/tutor.vim +Skrypt Vima u¿ywany do kopiowania pliku +.B Vimtutora. +.SH AUTOR +.B Vimtutor +zosta³ pocz±tkowo napisany dla Vi przez Michaela C. Pierce'a +i Roberta K. Ware'a z Colorado School of Mines zainspirowani przez +Charlesa Smitha z Colorado State University. +E-mail: bware@mines.colorado.edu +.br +Zmodyfikowany na potrzeby +.B Vima +przez Brama Moolenaara. +Nazwiska t³umaczy w plikach. +.SH ZOBACZ TAK¯E +vim(1) diff --git a/share/vim/vim73/doc/vimtutor-pl.UTF-8.1 b/share/vim/vim73/doc/vimtutor-pl.UTF-8.1 new file mode 100644 index 0000000000..199fcd0e8f --- /dev/null +++ b/share/vim/vim73/doc/vimtutor-pl.UTF-8.1 @@ -0,0 +1,51 @@ +.TH VIMTUTOR 1 "2001 Kwi 2" +.SH NAZWA +vimtutor \- nauczyciel Vima +.SH SYNOPSIS +.br +.B vimtutor -g [język] +.SH OPIS +.B Vimtutor +uruchamia nauczyciela +.B Vima. +Najpierw kopiuje właściwy plik, dzięki temu można go zmieniać bez obaw +utraty treści. +.PP +.B Vimtutor +przyda się ludziom, którzy chcą się nauczyć pierwszych poleceń +.B Vima +.PP +Opcjonalny argument \-g uruchamia vimtutor w gvimie a nie w Vimie jeśli +graficzna wersja Vima jest dostępna, jeśli nie zostanie uruchomiony Vim. +.PP +Opcjonalny argument [język] jest dwu literowym kodem języka, tak jak +"it" lub "es". +Jeśli brak argumentu [język] zostanie użyty język bieżącej +lokalizacji. +Jeśli nauczyciel w tym języku jest dostępny, zostanie użyty \- w innym +wypadku zostanie wykorzystana wersja angielska. +.PP +.B Vim +jest uruchamiany zawsze w trybie kompatybilności z Vi +.SH PLIKI +.TP 15 +/usr/local/lib/vim/tutor/tutor[.język] +Tekstowe pliki +.B Vimtutora. +.TP 15 +/usr/local/lib/vim/tutor/tutor.vim +Skrypt Vima używany do kopiowania pliku +.B Vimtutora. +.SH AUTOR +.B Vimtutor +został początkowo napisany dla Vi przez Michaela C. Pierce'a +i Roberta K. Ware'a z Colorado School of Mines zainspirowani przez +Charlesa Smitha z Colorado State University. +E-mail: bware@mines.colorado.edu +.br +Zmodyfikowany na potrzeby +.B Vima +przez Brama Moolenaara. +Nazwiska tłumaczy w plikach. +.SH ZOBACZ TAKŻE +vim(1) diff --git a/share/vim/vim72/doc/vimtutor-ru.1 b/share/vim/vim73/doc/vimtutor-ru.1 similarity index 100% rename from share/vim/vim72/doc/vimtutor-ru.1 rename to share/vim/vim73/doc/vimtutor-ru.1 diff --git a/share/vim/vim72/doc/vimtutor-ru.UTF-8.1 b/share/vim/vim73/doc/vimtutor-ru.UTF-8.1 similarity index 100% rename from share/vim/vim72/doc/vimtutor-ru.UTF-8.1 rename to share/vim/vim73/doc/vimtutor-ru.UTF-8.1 diff --git a/share/vim/vim73/doc/vimtutor.1 b/share/vim/vim73/doc/vimtutor.1 new file mode 100644 index 0000000000..0aa7e8d8d9 --- /dev/null +++ b/share/vim/vim73/doc/vimtutor.1 @@ -0,0 +1,57 @@ +.TH VIMTUTOR 1 "2001 April 2" +.SH NAME +vimtutor \- the Vim tutor +.SH SYNOPSIS +.br +.B vimtutor [\-g] [language] +.SH DESCRIPTION +.B Vimtutor +starts the +.B Vim +tutor. +It copies the tutor file first, so that it can be modified without changing +the original file. +.PP +The +.B Vimtutor +is useful for people that want to learn their first +.B Vim +commands. +.PP +The optional argument \-g starts vimtutor with gvim rather than vim, if the +GUI version of vim is available, or falls back to Vim if gvim is not found. +.PP +The optional [language] argument is the two-letter name of a language, like +"it" or "es". +If the [language] argument is missing, the language of the current locale will +be used. +If a tutor in this language is available, it will be used. +Otherwise the English version will be used. +.PP +.B Vim +is always started in Vi compatible mode. +.SH FILES +.TP 15 +/usr/local/lib/vim/tutor/tutor[.language] +The +.B Vimtutor +text file(s). +.TP 15 +/usr/local/lib/vim/tutor/tutor.vim +The Vim script used to copy the +.B Vimtutor +text file. +.SH AUTHOR +The +.B Vimtutor +was originally written for Vi by Michael C. Pierce and Robert K. Ware, +Colorado School of Mines using ideas supplied by Charles Smith, +Colorado State University. +E-mail: bware@mines.colorado.edu. +.br +It was modified for +.B Vim +by Bram Moolenaar. +For the names of the translators see the tutor files. +.SH SEE ALSO +vim(1) diff --git a/share/vim/vim73/doc/vimtutor.man b/share/vim/vim73/doc/vimtutor.man new file mode 100644 index 0000000000..9f2350a0ae --- /dev/null +++ b/share/vim/vim73/doc/vimtutor.man @@ -0,0 +1,50 @@ +VIMTUTOR(1) VIMTUTOR(1) + + + +NAME + vimtutor - the Vim tutor + +SYNOPSIS + vimtutor [-g] [language] + +DESCRIPTION + Vimtutor starts the Vim tutor. It copies the tutor file first, so that + it can be modified without changing the original file. + + The Vimtutor is useful for people that want to learn their first Vim + commands. + + The optional argument -g starts vimtutor with gvim rather than vim, if + the GUI version of vim is available, or falls back to Vim if gvim is + not found. + + The optional [language] argument is the two-letter name of a language, + like "it" or "es". If the [language] argument is missing, the language + of the current locale will be used. If a tutor in this language is + available, it will be used. Otherwise the English version will be + used. + + Vim is always started in Vi compatible mode. + +FILES + /usr/local/lib/vim/tutor/tutor[.language] + The Vimtutor text file(s). + + /usr/local/lib/vim/tutor/tutor.vim + The Vim script used to copy the Vimtutor text file. + +AUTHOR + The Vimtutor was originally written for Vi by Michael C. Pierce and + Robert K. Ware, Colorado School of Mines using ideas supplied by + Charles Smith, Colorado State University. E-mail: bware@mines.col‐ + orado.edu. + It was modified for Vim by Bram Moolenaar. For the names of the trans‐ + lators see the tutor files. + +SEE ALSO + vim(1) + + + + 2001 April 2 VIMTUTOR(1) diff --git a/share/vim/vim73/doc/visual.txt b/share/vim/vim73/doc/visual.txt new file mode 100644 index 0000000000..8c50a2900e --- /dev/null +++ b/share/vim/vim73/doc/visual.txt @@ -0,0 +1,509 @@ +*visual.txt* For Vim version 7.3. Last change: 2010 Feb 17 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + +Visual mode *Visual* *Visual-mode* *visual-mode* + +Visual mode is a flexible and easy way to select a piece of text for an +operator. It is the only way to select a block of text. + +This is introduced in section |04.4| of the user manual. + +1. Using Visual mode |visual-use| +2. Starting and stopping Visual mode |visual-start| +3. Changing the Visual area |visual-change| +4. Operating on the Visual area |visual-operators| +5. Blockwise operators |blockwise-operators| +6. Repeating |visual-repeat| +7. Examples |visual-examples| +8. Select mode |Select-mode| + +{Vi has no Visual mode, the name "visual" is used for Normal mode, to +distinguish it from Ex mode} +{not available when the |+visual| feature was disabled when compiling} + +============================================================================== +1. Using Visual mode *visual-use* + +Using Visual mode consists of three parts: +1. Mark the start of the text with "v", "V" or CTRL-V. + The character under the cursor will be used as the start. +2. Move to the end of the text. + The text from the start of the Visual mode up to and including the + character under the cursor is highlighted. +3. Type an operator command. + The highlighted characters will be operated upon. + +The 'highlight' option can be used to set the display mode to use for +highlighting in Visual mode. +The 'virtualedit' option can be used to allow positioning the cursor to +positions where there is no actual character. + +The highlighted text normally includes the character under the cursor. +However, when the 'selection' option is set to "exclusive" and the cursor is +after the Visual area, the character under the cursor is not included. + +With "v" the text before the start position and after the end position will +not be highlighted. However, all uppercase and non-alpha operators, except +"~" and "U", will work on whole lines anyway. See the list of operators +below. + + *visual-block* +With CTRL-V (blockwise Visual mode) the highlighted text will be a rectangle +between start position and the cursor. However, some operators work on whole +lines anyway (see the list below). The change and substitute operators will +delete the highlighted text and then start insertion at the top left +position. + +============================================================================== +2. Starting and stopping Visual mode *visual-start* + + *v* *characterwise-visual* +v start Visual mode per character. + + *V* *linewise-visual* +V start Visual mode linewise. + + *CTRL-V* *blockwise-visual* +CTRL-V start Visual mode blockwise. Note: Under Windows + CTRL-V could be mapped to paste text, it doesn't work + to start Visual mode then, see |CTRL-V-alternative|. + +If you use <Esc>, click the left mouse button or use any command that +does a jump to another buffer while in Visual mode, the highlighting stops +and no text is affected. Also when you hit "v" in characterwise Visual mode, +"CTRL-V" in blockwise Visual mode or "V" in linewise Visual mode. If you hit +CTRL-Z the highlighting stops and the editor is suspended or a new shell is +started |CTRL-Z|. + + new mode after typing: *v_v* *v_CTRL-V* *v_V* +old mode "v" "CTRL-V" "V" ~ + +Normal Visual blockwise Visual linewise Visual +Visual Normal blockwise Visual linewise Visual +blockwise Visual Visual Normal linewise Visual +linewise Visual Visual blockwise Visual Normal + + *gv* *v_gv* *reselect-Visual* +gv Start Visual mode with the same area as the previous + area and the same mode. + In Visual mode the current and the previous Visual + area are exchanged. + After using "p" or "P" in Visual mode the text that + was put will be selected. + + *<LeftMouse>* +<LeftMouse> Set the current cursor position. If Visual mode is + active it is stopped. Only when 'mouse' option is + contains 'n' or 'a'. If the position is within 'so' + lines from the last line on the screen the text is + scrolled up. If the position is within 'so' lines from + the first line on the screen the text is scrolled + down. + + *<RightMouse>* +<RightMouse> Start Visual mode if it is not active. The text from + the cursor position to the position of the click is + highlighted. If Visual mode was already active move + the start or end of the highlighted text, which ever + is closest, to the position of the click. Only when + 'mouse' option contains 'n' or 'a'. + + Note: when 'mousemodel' is set to "popup", + <S-LeftMouse> has to be used instead of <RightMouse>. + + *<LeftRelease>* +<LeftRelease> This works like a <LeftMouse>, if it is not at + the same position as <LeftMouse>. In an older version + of xterm you won't see the selected area until the + button is released, unless there is access to the + display where the xterm is running (via the DISPLAY + environment variable or the -display argument). Only + when 'mouse' option contains 'n' or 'a'. + +If Visual mode is not active and the "v", "V" or CTRL-V is preceded with a +count, the size of the previously highlighted area is used for a start. You +can then move the end of the highlighted area and give an operator. The type +of the old area is used (character, line or blockwise). +- Linewise Visual mode: The number of lines is multiplied with the count. +- Blockwise Visual mode: The number of lines and columns is multiplied with + the count. +- Normal Visual mode within one line: The number of characters is multiplied + with the count. +- Normal Visual mode with several lines: The number of lines is multiplied + with the count, in the last line the same number of characters is used as + in the last line in the previously highlighted area. +The start of the text is the Cursor position. If the "$" command was used as +one of the last commands to extend the highlighted text, the area will be +extended to the rightmost column of the longest line. + +If you want to highlight exactly the same area as the last time, you can use +"gv" |gv| |v_gv|. + + *v_<Esc>* +<Esc> In Visual mode: Stop Visual mode. + + *v_CTRL-C* +CTRL-C In Visual mode: Stop Visual mode. When insert mode is + pending (the mode message shows + "-- (insert) VISUAL --"), it is also stopped. + +============================================================================== +3. Changing the Visual area *visual-change* + + *v_o* +o Go to Other end of highlighted text: The current + cursor position becomes the start of the highlighted + text and the cursor is moved to the other end of the + highlighted text. The highlighted area remains the + same. + + *v_O* +O Go to Other end of highlighted text. This is like + "o", but in Visual block mode the cursor moves to the + other corner in the same line. When the corner is at + a character that occupies more than one position on + the screen (e.g., a <Tab>), the highlighted text may + change. + + *v_$* +When the "$" command is used with blockwise Visual mode, the right end of the +highlighted text will be determined by the longest highlighted line. This +stops when a motion command is used that does not move straight up or down. + +For moving the end of the block many commands can be used, but you cannot +use Ex commands, commands that make changes or abandon the file. Commands +(starting with) ".", "&", CTRL-^, "Z", CTRL-], CTRL-T, CTRL-R, CTRL-I +and CTRL-O cause a beep and Visual mode continues. + +When switching to another window on the same buffer, the cursor position in +that window is adjusted, so that the same Visual area is still selected. This +is especially useful to view the start of the Visual area in one window, and +the end in another. You can then use <RightMouse> (or <S-LeftMouse> when +'mousemodel' is "popup") to drag either end of the Visual area. + +============================================================================== +4. Operating on the Visual area *visual-operators* + +The operators that can be used are: + ~ switch case |v_~| + d delete |v_d| + c change (4) |v_c| + y yank |v_y| + > shift right (4) |v_>| + < shift left (4) |v_<| + ! filter through external command (1) |v_!| + = filter through 'equalprg' option command (1) |v_=| + gq format lines to 'textwidth' length (1) |v_gq| + +The objects that can be used are: + aw a word (with white space) |v_aw| + iw inner word |v_iw| + aW a WORD (with white space) |v_aW| + iW inner WORD |v_iW| + as a sentence (with white space) |v_as| + is inner sentence |v_is| + ap a paragraph (with white space) |v_ap| + ip inner paragraph |v_ip| + ab a () block (with parenthesis) |v_ab| + ib inner () block |v_ib| + aB a {} block (with braces) |v_aB| + iB inner {} block |v_iB| + at a <tag> </tag> block (with tags) |v_at| + it inner <tag> </tag> block |v_it| + a< a <> block (with <>) |v_a<| + i< inner <> block |v_i<| + a[ a [] block (with []) |v_a[| + i[ inner [] block |v_i[| + a" a double quoted string (with quotes) |v_aquote| + i" inner double quoted string |v_iquote| + a' a single quoted string (with quotes) |v_a'| + i' inner simple quoted string |v_i'| + a` a string in backticks (with backticks) |v_a`| + i` inner string in backticks |v_i`| + +Additionally the following commands can be used: + : start Ex command for highlighted lines (1) |v_:| + r change (4) |v_r| + s change |v_s| + C change (2)(4) |v_C| + S change (2) |v_S| + R change (2) |v_R| + x delete |v_x| + D delete (3) |v_D| + X delete (2) |v_X| + Y yank (2) |v_Y| + p put |v_p| + J join (1) |v_J| + U make uppercase |v_U| + u make lowercase |v_u| + ^] find tag |v_CTRL-]| + I block insert |v_b_I| + A block append |v_b_A| + +(1): Always whole lines, see |:visual_example|. +(2): Whole lines when not using CTRL-V. +(3): Whole lines when not using CTRL-V, delete until the end of the line when + using CTRL-V. +(4): When using CTRL-V operates on the block only. + +Note that the ":vmap" command can be used to specifically map keys in Visual +mode. For example, if you would like the "/" command not to extend the Visual +area, but instead take the highlighted text and search for that: > + :vmap / y/<C-R>"<CR> +(In the <> notation |<>|, when typing it you should type it literally; you +need to remove the 'B' and '<' flags from 'cpoptions'.) + +If you want to give a register name using the """ command, do this just before +typing the operator character: "v{move-around}"xd". + +If you want to give a count to the command, do this just before typing the +operator character: "v{move-around}3>" (move lines 3 indents to the right). + + *{move-around}* +The {move-around} is any sequence of movement commands. Note the difference +with {motion}, which is only ONE movement command. + +Another way to operate on the Visual area is using the |/\%V| item in a +pattern. For example, to replace all '(' in the Visual area with '#': > + + :%s/\%V(/X/g + +============================================================================== +5. Blockwise operators *blockwise-operators* + +{not available when compiled without the |+visualextra| feature} + +Reminder: Use 'virtualedit' to be able to select blocks that start or end +after the end of a line or halfway a tab. + +Visual-block Insert *v_b_I* +With a blockwise selection, I{string}<ESC> will insert {string} at the start +of block on every line of the block, provided that the line extends into the +block. Thus lines that are short will remain unmodified. TABs are split to +retain visual columns. +See |v_b_I_example|. + +Visual-block Append *v_b_A* +With a blockwise selection, A{string}<ESC> will append {string} to the end of +block on every line of the block. There is some differing behavior where the +block RHS is not straight, due to different line lengths: + +1. Block was created with <C-v>$ + In this case the string is appended to the end of each line. +2. Block was created with <C-v>{move-around} + In this case the string is appended to the end of the block on each line, + and whitespace is inserted to pad to the end-of-block column. +See |v_b_A_example|. +Note: "I" and "A" behave differently for lines that don't extend into the +selected block. This was done intentionally, so that you can do it the way +you want. + +Visual-block change *v_b_c* +All selected text in the block will be replaced by the same text string. When +using "c" the selected text is deleted and Insert mode started. You can then +enter text (without a line break). When you hit <Esc>, the same string is +inserted in all previously selected lines. + +Visual-block Change *v_b_C* +Like using "c", but the selection is extended until the end of the line for +all lines. + + *v_b_<* +Visual-block Shift *v_b_>* +The block is shifted by 'shiftwidth'. The RHS of the block is irrelevant. The +LHS of the block determines the point from which to apply a right shift, and +padding includes TABs optimally according to 'ts' and 'et'. The LHS of the +block determines the point upto which to shift left. +See |v_b_>_example|. +See |v_b_<_example|. + +Visual-block Replace *v_b_r* +Every screen char in the highlighted region is replaced with the same char, ie +TABs are split and the virtual whitespace is replaced, maintaining screen +layout. +See |v_b_r_example|. + + +============================================================================== +6. Repeating *visual-repeat* + +When repeating a Visual mode operator, the operator will be applied to the +same amount of text as the last time: +- Linewise Visual mode: The same number of lines. +- Blockwise Visual mode: The same number of lines and columns. +- Normal Visual mode within one line: The same number of characters. +- Normal Visual mode with several lines: The same number of lines, in the + last line the same number of characters as in the last line the last time. +The start of the text is the Cursor position. If the "$" command was used as +one of the last commands to extend the highlighted text, the repeating will +be applied up to the rightmost column of the longest line. + + +============================================================================== +7. Examples *visual-examples* + + *:visual_example* +Currently the ":" command works on whole lines only. When you select part of +a line, doing something like ":!date" will replace the whole line. If you +want only part of the line to be replaced you will have to make a mapping for +it. In a future release ":" may work on partial lines. + +Here is an example, to replace the selected text with the output of "date": > + :vmap _a <Esc>`>a<CR><Esc>`<i<CR><Esc>!!date<CR>kJJ + +(In the <> notation |<>|, when typing it you should type it literally; you +need to remove the 'B' and '<' flags from 'cpoptions') + +What this does is: +<Esc> stop Visual mode +`> go to the end of the Visual area +a<CR><Esc> break the line after the Visual area +`< jump to the start of the Visual area +i<CR><Esc> break the line before the Visual area +!!date<CR> filter the Visual text through date +kJJ Join the lines back together + + *visual-search* +Here is an idea for a mapping that makes it possible to do a search for the +selected text: > + :vmap X y/<C-R>"<CR> + +(In the <> notation |<>|, when typing it you should type it literally; you +need to remove the 'B' and '<' flags from 'cpoptions') + +Note that special characters (like '.' and '*') will cause problems. + +Visual-block Examples *blockwise-examples* +With the following text, I will indicate the commands to produce the block and +the results below. In all cases, the cursor begins on the 'a' in the first +line of the test text. +The following modeline settings are assumed ":ts=8:sw=4:". + +It will be helpful to +:set hls +/<TAB> +where <TAB> is a real TAB. This helps visualise the operations. + +The test text is: + +abcdefghijklmnopqrstuvwxyz +abc defghijklmnopqrstuvwxyz +abcdef ghi jklmnopqrstuvwxyz +abcdefghijklmnopqrstuvwxyz + +1. fo<C-v>3jISTRING<ESC> *v_b_I_example* + +abcdefghijklmnSTRINGopqrstuvwxyz +abc STRING defghijklmnopqrstuvwxyz +abcdef ghi STRING jklmnopqrstuvwxyz +abcdefghijklmnSTRINGopqrstuvwxyz + +2. fo<C-v>3j$ASTRING<ESC> *v_b_A_example* + +abcdefghijklmnopqrstuvwxyzSTRING +abc defghijklmnopqrstuvwxyzSTRING +abcdef ghi jklmnopqrstuvwxyzSTRING +abcdefghijklmnopqrstuvwxyzSTRING + +3. fo<C-v>3j3l<.. *v_b_<_example* + +abcdefghijklmnopqrstuvwxyz +abc defghijklmnopqrstuvwxyz +abcdef ghi jklmnopqrstuvwxyz +abcdefghijklmnopqrstuvwxyz + +4. fo<C-v>3j>.. *v_b_>_example* + +abcdefghijklmn opqrstuvwxyz +abc defghijklmnopqrstuvwxyz +abcdef ghi jklmnopqrstuvwxyz +abcdefghijklmn opqrstuvwxyz + +5. fo<C-v>5l3jrX *v_b_r_example* + +abcdefghijklmnXXXXXXuvwxyz +abc XXXXXXhijklmnopqrstuvwxyz +abcdef ghi XXXXXX jklmnopqrstuvwxyz +abcdefghijklmnXXXXXXuvwxyz + +============================================================================== +8. Select mode *Select* *Select-mode* + +Select mode looks like Visual mode, but the commands accepted are quite +different. This resembles the selection mode in Microsoft Windows. +When the 'showmode' option is set, "-- SELECT --" is shown in the last line. + +Entering Select mode: +- Using the mouse to select an area, and 'selectmode' contains "mouse". + 'mouse' must also contain a flag for the current mode. +- Using a non-printable movement command, with the Shift key pressed, and + 'selectmode' contains "key". For example: <S-Left> and <S-End>. 'keymodel' + must also contain "startsel". +- Using "v", "V" or CTRL-V command, and 'selectmode' contains "cmd". +- Using "gh", "gH" or "g_CTRL-H" command in Normal mode. +- From Visual mode, press CTRL-G. *v_CTRL-G* + +Commands in Select mode: +- Printable characters, <NL> and <CR> cause the selection to be deleted, and + Vim enters Insert mode. The typed character is inserted. +- Non-printable movement commands, with the Shift key pressed, extend the + selection. 'keymodel' must include "startsel". +- Non-printable movement commands, with the Shift key NOT pressed, stop Select + mode. 'keymodel' must include "stopsel". +- ESC stops Select mode. +- CTRL-O switches to Visual mode for the duration of one command. *v_CTRL-O* +- CTRL-G switches to Visual mode. + +Otherwise, typed characters are handled as in Visual mode. + +When using an operator in Select mode, and the selection is linewise, the +selected lines are operated upon, but like in characterwise selection. For +example, when a whole line is deleted, it can later be pasted halfway a line. + + +Mappings and menus in Select mode. *Select-mode-mapping* + +When mappings and menus are defined with the |:vmap| or |:vmenu| command they +work both in Visual mode and in Select mode. When these are used in Select +mode Vim automatically switches to Visual mode, so that the same behavior as +in Visual mode is effective. If you don't want this use |:xmap| or |:smap|. + +Users will expect printable characters to replace the selected area. +Therefore avoid mapping printable characters in Select mode. Or use +|:sunmap| after |:map| and |:vmap| to remove it for Select mode. + +After the mapping or menu finishes, the selection is enabled again and Select +mode entered, unless the selected area was deleted, another buffer became +the current one or the window layout was changed. + +When a character was typed that causes the selection to be deleted and Insert +mode started, Insert mode mappings are applied to this character. This may +cause some confusion, because it means Insert mode mappings apply to a +character typed in Select mode. Language mappings apply as well. + + *gV* *v_gV* +gV Avoid the automatic reselection of the Visual area + after a Select mode mapping or menu has finished. + Put this just before the end of the mapping or menu. + At least it should be after any operations on the + selection. + + *gh* +gh Start Select mode, characterwise. This is like "v", + but starts Select mode instead of Visual mode. + Mnemonic: "get highlighted". + + *gH* +gH Start Select mode, linewise. This is like "V", + but starts Select mode instead of Visual mode. + Mnemonic: "get Highlighted". + + *g_CTRL-H* +g CTRL-H Start Select mode, blockwise. This is like CTRL-V, + but starts Select mode instead of Visual mode. + Mnemonic: "get Highlighted". + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/windows.txt b/share/vim/vim73/doc/windows.txt new file mode 100644 index 0000000000..ccb980114e --- /dev/null +++ b/share/vim/vim73/doc/windows.txt @@ -0,0 +1,1194 @@ +*windows.txt* For Vim version 7.3. Last change: 2010 Aug 15 + + + VIM REFERENCE MANUAL by Bram Moolenaar + + +Editing with multiple windows and buffers. *windows* *buffers* + +The commands which have been added to use multiple windows and buffers are +explained here. Additionally, there are explanations for commands that work +differently when used in combination with more than one window. + +The basics are explained in chapter 7 and 8 of the user manual |usr_07.txt| +|usr_08.txt|. + +1. Introduction |windows-intro| +2. Starting Vim |windows-starting| +3. Opening and closing a window |opening-window| +4. Moving cursor to other windows |window-move-cursor| +5. Moving windows around |window-moving| +6. Window resizing |window-resize| +7. Argument and buffer list commands |buffer-list| +8. Do a command in all buffers or windows |list-repeat| +9. Tag or file name under the cursor |window-tag| +10. The preview window |preview-window| +11. Using hidden buffers |buffer-hidden| +12. Special kinds of buffers |special-buffers| + +{Vi does not have any of these commands} +{not able to use multiple windows when the |+windows| feature was disabled at +compile time} +{not able to use vertically split windows when the |+vertsplit| feature was +disabled at compile time} + +============================================================================== +1. Introduction *windows-intro* *window* + +Summary: + A buffer is the in-memory text of a file. + A window is a viewport on a buffer. + A tab page is a collection of windows. + +A window is a viewport onto a buffer. You can use multiple windows on one +buffer, or several windows on different buffers. + +A buffer is a file loaded into memory for editing. The original file remains +unchanged until you write the buffer to the file. + +A buffer can be in one of three states: + + *active-buffer* +active: The buffer is displayed in a window. If there is a file for this + buffer, it has been read into the buffer. The buffer may have been + modified since then and thus be different from the file. + *hidden-buffer* +hidden: The buffer is not displayed. If there is a file for this buffer, it + has been read into the buffer. Otherwise it's the same as an active + buffer, you just can't see it. + *inactive-buffer* +inactive: The buffer is not displayed and does not contain anything. Options + for the buffer are remembered if the file was once loaded. It can + contain marks from the |viminfo| file. But the buffer doesn't + contain text. + +In a table: + +state displayed loaded ":buffers" ~ + in window shows ~ +active yes yes 'a' +hidden no yes 'h' +inactive no no ' ' + +Note: All CTRL-W commands can also be executed with |:wincmd|, for those +places where a Normal mode command can't be used or is inconvenient. + +The main Vim window can hold several split windows. There are also tab pages +|tab-page|, each of which can hold multiple windows. + +============================================================================== +2. Starting Vim *windows-starting* + +By default, Vim starts with one window, just like Vi. + +The "-o" and "-O" arguments to Vim can be used to open a window for each file +in the argument list. The "-o" argument will split the windows horizontally; +the "-O" argument will split the windows vertically. If both "-o" and "-O" +are given, the last one encountered will be used to determine the split +orientation. For example, this will open three windows, split horizontally: > + vim -o file1 file2 file3 + +"-oN", where N is a decimal number, opens N windows split horizontally. If +there are more file names than windows, only N windows are opened and some +files do not get a window. If there are more windows than file names, the +last few windows will be editing empty buffers. Similarly, "-ON" opens N +windows split vertically, with the same restrictions. + +If there are many file names, the windows will become very small. You might +want to set the 'winheight' and/or 'winwidth' options to create a workable +situation. + +Buf/Win Enter/Leave |autocommand|s are not executed when opening the new +windows and reading the files, that's only done when they are really entered. + + *status-line* +A status line will be used to separate windows. The 'laststatus' option tells +when the last window also has a status line: + 'laststatus' = 0 never a status line + 'laststatus' = 1 status line if there is more than one window + 'laststatus' = 2 always a status line + +You can change the contents of the status line with the 'statusline' option. +This option can be local to the window, so that you can have a different +status line in each window. + +Normally, inversion is used to display the status line. This can be changed +with the 's' character in the 'highlight' option. For example, "sb" sets it to +bold characters. If no highlighting is used for the status line ("sn"), the +'^' character is used for the current window, and '=' for other windows. If +the mouse is supported and enabled with the 'mouse' option, a status line can +be dragged to resize windows. + +Note: If you expect your status line to be in reverse video and it isn't, +check if the 'highlight' option contains "si". In version 3.0, this meant to +invert the status line. Now it should be "sr", reverse the status line, as +"si" now stands for italic! If italic is not available on your terminal, the +status line is inverted anyway; you will only see this problem on terminals +that have termcap codes for italics. + +============================================================================== +3. Opening and closing a window *opening-window* *E36* + +CTRL-W s *CTRL-W_s* +CTRL-W S *CTRL-W_S* +CTRL-W CTRL-S *CTRL-W_CTRL-S* +:[N]sp[lit] [++opt] [+cmd] *:sp* *:split* + Split current window in two. The result is two viewports on + the same file. Make new window N high (default is to use half + the height of the current window). Reduces the current window + height to create room (and others, if the 'equalalways' option + is set, 'eadirection' isn't "hor", and one of them is higher + than the current or the new window). + Note: CTRL-S does not work on all terminals and might block + further input, use CTRL-Q to get going again. + Also see |++opt| and |+cmd|. + +CTRL-W CTRL-V *CTRL-W_CTRL-V* +CTRL-W v *CTRL-W_v* +:[N]vs[plit] [++opt] [+cmd] [file] *:vs* *:vsplit* + Like |:split|, but split vertically. The windows will be + spread out horizontally if + 1. a width was not specified, + 2. 'equalalways' is set, + 3. 'eadirection' isn't "ver", and + 4. one of the other windows is wider than the current or new + window. + Note: In other places CTRL-Q does the same as CTRL-V, but here + it doesn't! + +CTRL-W n *CTRL-W_n* +CTRL-W CTRL_N *CTRL-W_CTRL-N* +:[N]new [++opt] [+cmd] *:new* + Create a new window and start editing an empty file in it. + Make new window N high (default is to use half the existing + height). Reduces the current window height to create room (and + others, if the 'equalalways' option is set and 'eadirection' + isn't "hor"). + Also see |++opt| and |+cmd|. + If 'fileformats' is not empty, the first format given will be + used for the new buffer. If 'fileformats' is empty, the + 'fileformat' of the current buffer is used. This can be + overridden with the |++opt| argument. + Autocommands are executed in this order: + 1. WinLeave for the current window + 2. WinEnter for the new window + 3. BufLeave for the current buffer + 4. BufEnter for the new buffer + This behaves like a ":split" first, and then a ":e" command. + +:[N]vne[w] [++opt] [+cmd] [file] *:vne* *:vnew* + Like |:new|, but split vertically. If 'equalalways' is set + and 'eadirection' isn't "ver" the windows will be spread out + horizontally, unless a width was specified. + +:[N]new [++opt] [+cmd] {file} +:[N]sp[lit] [++opt] [+cmd] {file} *:split_f* + Create a new window and start editing file {file} in it. + If [+cmd] is given, execute the command when the file has been + loaded |+cmd|. + Also see |++opt|. + Make new window N high (default is to use half the existing + height). Reduces the current window height to create room + (and others, if the 'equalalways' option is set). + +:[N]sv[iew] [++opt] [+cmd] {file} *:sv* *:sview* *splitview* + Same as ":split", but set 'readonly' option for this buffer. + +:[N]sf[ind] [++opt] [+cmd] {file} *:sf* *:sfind* *splitfind* + Same as ":split", but search for {file} in 'path' like in + |:find|. Doesn't split if {file} is not found. + +CTRL-W CTRL-^ *CTRL-W_CTRL-^* *CTRL-W_^* +CTRL-W ^ Does ":split #", split window in two and edit alternate file. + When a count is given, it becomes ":split #N", split window + and edit buffer N. + +Note that the 'splitbelow' and 'splitright' options influence where a new +window will appear. + + *:vert* *:vertical* +:vert[ical] {cmd} + Execute {cmd}. If it contains a command that splits a window, + it will be split vertically. + Doesn't work for |:execute| and |:normal|. + +:lefta[bove] {cmd} *:lefta* *:leftabove* +:abo[veleft] {cmd} *:abo* *:aboveleft* + Execute {cmd}. If it contains a command that splits a window, + it will be opened left (vertical split) or above (horizontal + split) the current window. Overrules 'splitbelow' and + 'splitright'. + Doesn't work for |:execute| and |:normal|. + +:rightb[elow] {cmd} *:rightb* *:rightbelow* +:bel[owright] {cmd} *:bel* *:belowright* + Execute {cmd}. If it contains a command that splits a window, + it will be opened right (vertical split) or below (horizontal + split) the current window. Overrules 'splitbelow' and + 'splitright'. + Doesn't work for |:execute| and |:normal|. + + *:topleft* *E442* +:to[pleft] {cmd} + Execute {cmd}. If it contains a command that splits a window, + it will appear at the top and occupy the full width of the Vim + window. When the split is vertical the window appears at the + far left and occupies the full height of the Vim window. + Doesn't work for |:execute| and |:normal|. + + *:botright* +:bo[tright] {cmd} + Execute {cmd}. If it contains a command that splits a window, + it will appear at the bottom and occupy the full width of the + Vim window. When the split is vertical the window appears at + the far right and occupies the full height of the Vim window. + Doesn't work for |:execute| and |:normal|. + +These command modifiers can be combined to make a vertically split window +occupy the full height. Example: > + :vertical topleft edit tags +Opens a vertically split, full-height window on the "tags" file at the far +left of the Vim window. + + +Closing a window +---------------- + +CTRL-W q *CTRL-W_q* +CTRL-W CTRL-Q *CTRL-W_CTRL-Q* +:q[uit] Quit current window. When quitting the last window (not + counting a help window), exit Vim. + When 'hidden' is set, and there is only one window for the + current buffer, it becomes hidden. + When 'hidden' is not set, and there is only one window for the + current buffer, and the buffer was changed, the command fails. + (Note: CTRL-Q does not work on all terminals) + +:q[uit]! Quit current window. If this was the last window for a buffer, + any changes to that buffer are lost. When quitting the last + window (not counting help windows), exit Vim. The contents of + the buffer are lost, even when 'hidden' is set. + +CTRL-W c *CTRL-W_c* *:clo* *:close* +:clo[se][!] Close current window. When the 'hidden' option is set, or + when the buffer was changed and the [!] is used, the buffer + becomes hidden (unless there is another window editing it). + When there is only one window in the current tab page and + there is another tab page, this closes the current tab page. + |tab-page|. + This command fails when: *E444* + - There is only one window on the screen. + - When 'hidden' is not set, [!] is not used, the buffer has + changes, and there is no other window on this buffer. + Changes to the buffer are not written and won't get lost, so + this is a "safe" command. + +CTRL-W CTRL-C *CTRL-W_CTRL-C* + You might have expected that CTRL-W CTRL-C closes the current + window, but that does not work, because the CTRL-C cancels the + command. + + *:hide* +:hid[e] Quit current window, unless it is the last window on the + screen. The buffer becomes hidden (unless there is another + window editing it or 'bufhidden' is "unload" or "delete"). + If the window is the last one in the current tab page the tab + page is closed. |tab-page| + The value of 'hidden' is irrelevant for this command. + Changes to the buffer are not written and won't get lost, so + this is a "safe" command. + +:hid[e] {cmd} Execute {cmd} with 'hidden' is set. The previous value of + 'hidden' is restored after {cmd} has been executed. + Example: > + :hide edit Makefile +< This will edit "Makefile", and hide the current buffer if it + has any changes. + +CTRL-W o *CTRL-W_o* *E445* +CTRL-W CTRL-O *CTRL-W_CTRL-O* *:on* *:only* +:on[ly][!] Make the current window the only one on the screen. All other + windows are closed. + When the 'hidden' option is set, all buffers in closed windows + become hidden. + When 'hidden' is not set, and the 'autowrite' option is set, + modified buffers are written. Otherwise, windows that have + buffers that are modified are not removed, unless the [!] is + given, then they become hidden. But modified buffers are + never abandoned, so changes cannot get lost. + +============================================================================== +4. Moving cursor to other windows *window-move-cursor* + +CTRL-W <Down> *CTRL-W_<Down>* +CTRL-W CTRL-J *CTRL-W_CTRL-J* *CTRL-W_j* +CTRL-W j Move cursor to Nth window below current one. Uses the cursor + position to select between alternatives. + +CTRL-W <Up> *CTRL-W_<Up>* +CTRL-W CTRL-K *CTRL-W_CTRL-K* *CTRL-W_k* +CTRL-W k Move cursor to Nth window above current one. Uses the cursor + position to select between alternatives. + +CTRL-W <Left> *CTRL-W_<Left>* +CTRL-W CTRL-H *CTRL-W_CTRL-H* +CTRL-W <BS> *CTRL-W_<BS>* *CTRL-W_h* +CTRL-W h Move cursor to Nth window left of current one. Uses the + cursor position to select between alternatives. + +CTRL-W <Right> *CTRL-W_<Right>* +CTRL-W CTRL-L *CTRL-W_CTRL-L* *CTRL-W_l* +CTRL-W l Move cursor to Nth window right of current one. Uses the + cursor position to select between alternatives. + +CTRL-W w *CTRL-W_w* *CTRL-W_CTRL-W* +CTRL-W CTRL-W Without count: move cursor to window below/right of the + current one. If there is no window below or right, go to + top-left window. + With count: go to Nth window (windows are numbered from + top-left to bottom-right). To obtain the window number see + |bufwinnr()| and |winnr()|. When N is larger than the number + of windows go to the last window. + + *CTRL-W_W* +CTRL-W W Without count: move cursor to window above/left of current + one. If there is no window above or left, go to bottom-right + window. With count: go to Nth window, like with CTRL-W w. + +CTRL-W t *CTRL-W_t* *CTRL-W_CTRL-T* +CTRL-W CTRL-T Move cursor to top-left window. + +CTRL-W b *CTRL-W_b* *CTRL-W_CTRL-B* +CTRL-W CTRL-B Move cursor to bottom-right window. + +CTRL-W p *CTRL-W_p* *CTRL-W_CTRL-P* +CTRL-W CTRL-P Go to previous (last accessed) window. + + *CTRL-W_P* *E441* +CTRL-W P Go to preview window. When there is no preview window this is + an error. + {not available when compiled without the |+quickfix| feature} + +If Visual mode is active and the new window is not for the same buffer, the +Visual mode is ended. If the window is on the same buffer, the cursor +position is set to keep the same Visual area selected. + + *:winc* *:wincmd* +These commands can also be executed with ":wincmd": + +:[count]winc[md] {arg} + Like executing CTRL-W [count] {arg}. Example: > + :wincmd j +< Moves to the window below the current one. + This command is useful when a Normal mode cannot be used (for + the |CursorHold| autocommand event). Or when a Normal mode + command is inconvenient. + The count can also be a window number. Example: > + :exe nr . "wincmd w" +< This goes to window "nr". + +============================================================================== +5. Moving windows around *window-moving* + +CTRL-W r *CTRL-W_r* *CTRL-W_CTRL-R* *E443* +CTRL-W CTRL-R Rotate windows downwards/rightwards. The first window becomes + the second one, the second one becomes the third one, etc. + The last window becomes the first window. The cursor remains + in the same window. + This only works within the row or column of windows that the + current window is in. + + *CTRL-W_R* +CTRL-W R Rotate windows upwards/leftwards. The second window becomes + the first one, the third one becomes the second one, etc. The + first window becomes the last window. The cursor remains in + the same window. + This only works within the row or column of windows that the + current window is in. + +CTRL-W x *CTRL-W_x* *CTRL-W_CTRL-X* +CTRL-W CTRL-X Without count: Exchange current window with next one. If there + is no next window, exchange with previous window. + With count: Exchange current window with Nth window (first + window is 1). The cursor is put in the other window. + When vertical and horizontal window splits are mixed, the + exchange is only done in the row or column of windows that the + current window is in. + +The following commands can be used to change the window layout. For example, +when there are two vertically split windows, CTRL-W K will change that in +horizontally split windows. CTRL-W H does it the other way around. + + *CTRL-W_K* +CTRL-W K Move the current window to be at the very top, using the full + width of the screen. This works like closing the current + window and then creating another one with ":topleft split", + except that the current window contents is used for the new + window. + + *CTRL-W_J* +CTRL-W J Move the current window to be at the very bottom, using the + full width of the screen. This works like closing the current + window and then creating another one with ":botright split", + except that the current window contents is used for the new + window. + + *CTRL-W_H* +CTRL-W H Move the current window to be at the far left, using the + full height of the screen. This works like closing the + current window and then creating another one with + ":vert topleft split", except that the current window contents + is used for the new window. + {not available when compiled without the |+vertsplit| feature} + + *CTRL-W_L* +CTRL-W L Move the current window to be at the far right, using the full + height of the screen. This works like closing the + current window and then creating another one with + ":vert botright split", except that the current window + contents is used for the new window. + {not available when compiled without the |+vertsplit| feature} + + *CTRL-W_T* +CTRL-W T Move the current window to a new tab page. This fails if + there is only one window in the current tab page. + When a count is specified the new tab page will be opened + before the tab page with this index. Otherwise it comes after + the current tab page. + +============================================================================== +6. Window resizing *window-resize* + + *CTRL-W_=* +CTRL-W = Make all windows (almost) equally high and wide, but use + 'winheight' and 'winwidth' for the current window. + Windows with 'winfixheight' set keep their height and windows + with 'winfixwidth' set keep their width. + +:res[ize] -N *:res* *:resize* *CTRL-W_-* +CTRL-W - Decrease current window height by N (default 1). + If used after |:vertical|: decrease width by N. + +:res[ize] +N *CTRL-W_+* +CTRL-W + Increase current window height by N (default 1). + If used after |:vertical|: increase width by N. + +:res[ize] [N] +CTRL-W CTRL-_ *CTRL-W_CTRL-_* *CTRL-W__* +CTRL-W _ Set current window height to N (default: highest possible). + +z{nr}<CR> Set current window height to {nr}. + + *CTRL-W_<* +CTRL-W < Decrease current window width by N (default 1). + + *CTRL-W_>* +CTRL-W > Increase current window width by N (default 1). + +:vertical res[ize] [N] *:vertical-resize* *CTRL-W_bar* +CTRL-W | Set current window width to N (default: widest possible). + +You can also resize a window by dragging a status line up or down with the +mouse. Or by dragging a vertical separator line left or right. This only +works if the version of Vim that is being used supports the mouse and the +'mouse' option has been set to enable it. + +The option 'winheight' ('wh') is used to set the minimal window height of the +current window. This option is used each time another window becomes the +current window. If the option is '0', it is disabled. Set 'winheight' to a +very large value, e.g., '9999', to make the current window always fill all +available space. Set it to a reasonable value, e.g., '10', to make editing in +the current window comfortable. + +The equivalent 'winwidth' ('wiw') option is used to set the minimal width of +the current window. + +When the option 'equalalways' ('ea') is set, all the windows are automatically +made the same size after splitting or closing a window. If you don't set this +option, splitting a window will reduce the size of the current window and +leave the other windows the same. When closing a window, the extra lines are +given to the window above it. + +The 'eadirection' option limits the direction in which the 'equalalways' +option is applied. The default "both" resizes in both directions. When the +value is "ver" only the heights of windows are equalized. Use this when you +have manually resized a vertically split window and want to keep this width. +Likewise, "hor" causes only the widths of windows to be equalized. + +The option 'cmdheight' ('ch') is used to set the height of the command-line. +If you are annoyed by the |hit-enter| prompt for long messages, set this +option to 2 or 3. + +If there is only one window, resizing that window will also change the command +line height. If there are several windows, resizing the current window will +also change the height of the window below it (and sometimes the window above +it). + +The minimal height and width of a window is set with 'winminheight' and +'winminwidth'. These are hard values, a window will never become smaller. + +============================================================================== +7. Argument and buffer list commands *buffer-list* + + args list buffer list meaning ~ +1. :[N]argument [N] 11. :[N]buffer [N] to arg/buf N +2. :[N]next [file ..] 12. :[N]bnext [N] to Nth next arg/buf +3. :[N]Next [N] 13. :[N]bNext [N] to Nth previous arg/buf +4. :[N]previous [N] 14. :[N]bprevious [N] to Nth previous arg/buf +5. :rewind / :first 15. :brewind / :bfirst to first arg/buf +6. :last 16. :blast to last arg/buf +7. :all 17. :ball edit all args/buffers + 18. :unhide edit all loaded buffers + 19. :[N]bmod [N] to Nth modified buf + + split & args list split & buffer list meaning ~ +21. :[N]sargument [N] 31. :[N]sbuffer [N] split + to arg/buf N +22. :[N]snext [file ..] 32. :[N]sbnext [N] split + to Nth next arg/buf +23. :[N]sNext [N] 33. :[N]sbNext [N] split + to Nth previous arg/buf +24. :[N]sprevious [N] 34. :[N]sbprevious [N] split + to Nth previous arg/buf +25. :srewind / :sfirst 35. :sbrewind / :sbfirst split + to first arg/buf +26. :slast 36. :sblast split + to last arg/buf +27. :sall 37. :sball edit all args/buffers + 38. :sunhide edit all loaded buffers + 39. :[N]sbmod [N] split + to Nth modified buf + +40. :args list of arguments +41. :buffers list of buffers + +The meaning of [N] depends on the command: + [N] is number of buffers to go forward/backward on ?2, ?3, and ?4 + [N] is an argument number, defaulting to current argument, for 1 and 21 + [N] is a buffer number, defaulting to current buffer, for 11 and 31 + [N] is a count for 19 and 39 + +Note: ":next" is an exception, because it must accept a list of file names +for compatibility with Vi. + + +The argument list and multiple windows +-------------------------------------- + +The current position in the argument list can be different for each window. +Remember that when doing ":e file", the position in the argument list stays +the same, but you are not editing the file at that position. To indicate +this, the file message (and the title, if you have one) shows +"(file (N) of M)", where "(N)" is the current position in the file list, and +"M" the number of files in the file list. + +All the entries in the argument list are added to the buffer list. Thus, you +can also get to them with the buffer list commands, like ":bnext". + +:[N]al[l][!] [N] *:al* *:all* *:sal* *:sall* +:[N]sal[l][!] [N] + Rearrange the screen to open one window for each argument. + All other windows are closed. When a count is given, this is + the maximum number of windows to open. + With the |:tab| modifier open a tab page for each argument. + When there are more arguments than 'tabpagemax' further ones + become split windows in the last tab page. + When the 'hidden' option is set, all buffers in closed windows + become hidden. + When 'hidden' is not set, and the 'autowrite' option is set, + modified buffers are written. Otherwise, windows that have + buffers that are modified are not removed, unless the [!] is + given, then they become hidden. But modified buffers are + never abandoned, so changes cannot get lost. + [N] is the maximum number of windows to open. 'winheight' + also limits the number of windows opened ('winwidth' if + |:vertical| was prepended). + Buf/Win Enter/Leave autocommands are not executed for the new + windows here, that's only done when they are really entered. + +:[N]sa[rgument][!] [++opt] [+cmd] [N] *:sa* *:sargument* + Short for ":split | argument [N]": split window and go to Nth + argument. But when there is no such argument, the window is + not split. Also see |++opt| and |+cmd|. + +:[N]sn[ext][!] [++opt] [+cmd] [file ..] *:sn* *:snext* + Short for ":split | [N]next": split window and go to Nth next + argument. But when there is no next file, the window is not + split. Also see |++opt| and |+cmd|. + +:[N]spr[evious][!] [++opt] [+cmd] [N] *:spr* *:sprevious* +:[N]sN[ext][!] [++opt] [+cmd] [N] *:sN* *:sNext* + Short for ":split | [N]Next": split window and go to Nth + previous argument. But when there is no previous file, the + window is not split. Also see |++opt| and |+cmd|. + + *:sre* *:srewind* +:sre[wind][!] [++opt] [+cmd] + Short for ":split | rewind": split window and go to first + argument. But when there is no argument list, the window is + not split. Also see |++opt| and |+cmd|. + + *:sfir* *:sfirst* +:sfir[st] [++opt] [+cmd] + Same as ":srewind". + + *:sla* *:slast* +:sla[st][!] [++opt] [+cmd] + Short for ":split | last": split window and go to last + argument. But when there is no argument list, the window is + not split. Also see |++opt| and |+cmd|. + + *:dr* *:drop* +:dr[op] [++opt] [+cmd] {file} .. + Edit the first {file} in a window. + - If the file is already open in a window change to that + window. + - If the file is not open in a window edit the file in the + current window. If the current buffer can't be |abandon|ed, + the window is split first. + The |argument-list| is set, like with the |:next| command. + The purpose of this command is that it can be used from a + program that wants Vim to edit another file, e.g., a debugger. + When using the |:tab| modifier each argument is opened in a + tab page. The last window is used if it's empty. + Also see |++opt| and |+cmd|. + {only available when compiled with a GUI} + +============================================================================== +8. Do a command in all buffers or windows *list-repeat* + + *:windo* +:windo {cmd} Execute {cmd} in each window. + It works like doing this: > + CTRL-W t + :{cmd} + CTRL-W w + :{cmd} + etc. +< This only operates in the current tab page. + When an error is detected on one window, further + windows will not be visited. + The last window (or where an error occurred) becomes + the current window. + {cmd} can contain '|' to concatenate several commands. + {cmd} must not open or close windows or reorder them. + {not in Vi} {not available when compiled without the + |+listcmds| feature} + Also see |:tabdo|, |:argdo| and |:bufdo|. + + *:bufdo* +:bufdo[!] {cmd} Execute {cmd} in each buffer in the buffer list. + It works like doing this: > + :bfirst + :{cmd} + :bnext + :{cmd} + etc. +< When the current file can't be |abandon|ed and the [!] + is not present, the command fails. + When an error is detected on one buffer, further + buffers will not be visited. + Unlisted buffers are skipped. + The last buffer (or where an error occurred) becomes + the current buffer. + {cmd} can contain '|' to concatenate several commands. + {cmd} must not delete buffers or add buffers to the + buffer list. + Note: While this command is executing, the Syntax + autocommand event is disabled by adding it to + 'eventignore'. This considerably speeds up editing + each buffer. + {not in Vi} {not available when compiled without the + |+listcmds| feature} + Also see |:tabdo|, |:argdo| and |:windo|. + +Examples: > + + :windo set nolist nofoldcolumn | normal zn + +This resets the 'list' option and disables folding in all windows. > + + :bufdo set fileencoding= | update + +This resets the 'fileencoding' in each buffer and writes it if this changed +the buffer. The result is that all buffers will use the 'encoding' encoding +(if conversion works properly). + +============================================================================== +9. Tag or file name under the cursor *window-tag* + + *:sta* *:stag* +:sta[g][!] [tagname] + Does ":tag[!] [tagname]" and splits the window for the found + tag. See also |:tag|. + +CTRL-W ] *CTRL-W_]* *CTRL-W_CTRL-]* +CTRL-W CTRL-] Split current window in two. Use identifier under cursor as a + tag and jump to it in the new upper window. Make new window N + high. + + *CTRL-W_g]* +CTRL-W g ] Split current window in two. Use identifier under cursor as a + tag and perform ":tselect" on it in the new upper window. + Make new window N high. + + *CTRL-W_g_CTRL-]* +CTRL-W g CTRL-] Split current window in two. Use identifier under cursor as a + tag and perform ":tjump" on it in the new upper window. Make + new window N high. + +CTRL-W f *CTRL-W_f* *CTRL-W_CTRL-F* +CTRL-W CTRL-F Split current window in two. Edit file name under cursor. + Like ":split gf", but window isn't split if the file does not + exist. + Uses the 'path' variable as a list of directory names where to + look for the file. Also the path for current file is + used to search for the file name. + If the name is a hypertext link that looks like + "type://machine/path", only "/path" is used. + If a count is given, the count'th matching file is edited. + {not available when the |+file_in_path| feature was disabled + at compile time} + +CTRL-W F *CTRL-W_F* + Split current window in two. Edit file name under cursor and + jump to the line number following the file name. See |gF| for + details on how the line number is obtained. + {not available when the |+file_in_path| feature was disabled + at compile time} + +CTRL-W gf *CTRL-W_gf* + Open a new tab page and edit the file name under the cursor. + Like "tab split" and "gf", but the new tab page isn't created + if the file does not exist. + {not available when the |+file_in_path| feature was disabled + at compile time} + +CTRL-W gF *CTRL-W_gF* + Open a new tab page and edit the file name under the cursor + and jump to the line number following the file name. Like + "tab split" and "gF", but the new tab page isn't created if + the file does not exist. + {not available when the |+file_in_path| feature was disabled + at compile time} + +Also see |CTRL-W_CTRL-I|: open window for an included file that includes +the keyword under the cursor. + +============================================================================== +10. The preview window *preview-window* + +The preview window is a special window to show (preview) another file. It is +normally a small window used to show an include file or definition of a +function. +{not available when compiled without the |+quickfix| feature} + +There can be only one preview window (per tab page). It is created with one +of the commands below. The 'previewheight' option can be set to specify the +height of the preview window when it's opened. The 'previewwindow' option is +set in the preview window to be able to recognize it. The 'winfixheight' +option is set to have it keep the same height when opening/closing other +windows. + + *:pta* *:ptag* +:pta[g][!] [tagname] + Does ":tag[!] [tagname]" and shows the found tag in a + "Preview" window without changing the current buffer or cursor + position. If a "Preview" window already exists, it is re-used + (like a help window is). If a new one is opened, + 'previewheight' is used for the height of the window. See + also |:tag|. + See below for an example. |CursorHold-example| + Small difference from |:tag|: When [tagname] is equal to the + already displayed tag, the position in the matching tag list + is not reset. This makes the CursorHold example work after a + |:ptnext|. + +CTRL-W z *CTRL-W_z* +CTRL-W CTRL-Z *CTRL-W_CTRL-Z* *:pc* *:pclose* +:pc[lose][!] Close any "Preview" window currently open. When the 'hidden' + option is set, or when the buffer was changed and the [!] is + used, the buffer becomes hidden (unless there is another + window editing it). The command fails if any "Preview" buffer + cannot be closed. See also |:close|. + + *:pp* *:ppop* +:[count]pp[op][!] + Does ":[count]pop[!]" in the preview window. See |:pop| and + |:ptag|. {not in Vi} + +CTRL-W } *CTRL-W_}* + Use identifier under cursor as a tag and perform a :ptag on + it. Make the new Preview window (if required) N high. If N is + not given, 'previewheight' is used. + +CTRL-W g } *CTRL-W_g}* + Use identifier under cursor as a tag and perform a :ptjump on + it. Make the new Preview window (if required) N high. If N is + not given, 'previewheight' is used. + + *:ped* *:pedit* +:ped[it][!] [++opt] [+cmd] {file} + Edit {file} in the preview window. The preview window is + opened like with |:ptag|. The current window and cursor + position isn't changed. Useful example: > + :pedit +/fputc /usr/include/stdio.h +< + *:ps* *:psearch* +:[range]ps[earch][!] [count] [/]pattern[/] + Works like |:ijump| but shows the found match in the preview + window. The preview window is opened like with |:ptag|. The + current window and cursor position isn't changed. Useful + example: > + :psearch popen +< Like with the |:ptag| command, you can use this to + automatically show information about the word under the + cursor. This is less clever than using |:ptag|, but you don't + need a tags file and it will also find matches in system + include files. Example: > + :au! CursorHold *.[ch] nested exe "silent! psearch " . expand("<cword>") +< Warning: This can be slow. + +Example *CursorHold-example* > + + :au! CursorHold *.[ch] nested exe "silent! ptag " . expand("<cword>") + +This will cause a ":ptag" to be executed for the keyword under the cursor, +when the cursor hasn't moved for the time set with 'updatetime'. The "nested" +makes other autocommands be executed, so that syntax highlighting works in the +preview window. The "silent!" avoids an error message when the tag could not +be found. Also see |CursorHold|. To disable this again: > + + :au! CursorHold + +A nice addition is to highlight the found tag, avoid the ":ptag" when there +is no word under the cursor, and a few other things: > + + :au! CursorHold *.[ch] nested call PreviewWord() + :func PreviewWord() + : if &previewwindow " don't do this in the preview window + : return + : endif + : let w = expand("<cword>") " get the word under cursor + : if w =~ '\a' " if the word contains a letter + : + : " Delete any existing highlight before showing another tag + : silent! wincmd P " jump to preview window + : if &previewwindow " if we really get there... + : match none " delete existing highlight + : wincmd p " back to old window + : endif + : + : " Try displaying a matching tag for the word under the cursor + : try + : exe "ptag " . w + : catch + : return + : endtry + : + : silent! wincmd P " jump to preview window + : if &previewwindow " if we really get there... + : if has("folding") + : silent! .foldopen " don't want a closed fold + : endif + : call search("$", "b") " to end of previous line + : let w = substitute(w, '\\', '\\\\', "") + : call search('\<\V' . w . '\>') " position cursor on match + : " Add a match highlight to the word at this position + : hi previewWord term=bold ctermbg=green guibg=green + : exe 'match previewWord "\%' . line(".") . 'l\%' . col(".") . 'c\k*"' + : wincmd p " back to old window + : endif + : endif + :endfun + +============================================================================== +11. Using hidden buffers *buffer-hidden* + +A hidden buffer is not displayed in a window, but is still loaded into memory. +This makes it possible to jump from file to file, without the need to read or +write the file every time you get another buffer in a window. +{not available when compiled without the |+listcmds| feature} + + *:buffer-!* +If the option 'hidden' ('hid') is set, abandoned buffers are kept for all +commands that start editing another file: ":edit", ":next", ":tag", etc. The +commands that move through the buffer list sometimes make the current buffer +hidden although the 'hidden' option is not set. This happens when a buffer is +modified, but is forced (with '!') to be removed from a window, and +'autowrite' is off or the buffer can't be written. + +You can make a hidden buffer not hidden by starting to edit it with any +command. Or by deleting it with the ":bdelete" command. + +The 'hidden' is global, it is used for all buffers. The 'bufhidden' option +can be used to make an exception for a specific buffer. It can take these +values: + <empty> Use the value of 'hidden'. + hide Hide this buffer, also when 'hidden' is not set. + unload Don't hide but unload this buffer, also when 'hidden' + is set. + delete Delete the buffer. + + *hidden-quit* +When you try to quit Vim while there is a hidden, modified buffer, you will +get an error message and Vim will make that buffer the current buffer. You +can then decide to write this buffer (":wq") or quit without writing (":q!"). +Be careful: there may be more hidden, modified buffers! + +A buffer can also be unlisted. This means it exists, but it is not in the +list of buffers. |unlisted-buffer| + + +:files[!] *:files* +:buffers[!] *:buffers* *:ls* +:ls[!] Show all buffers. Example: + + 1 #h "/test/text" line 1 ~ + 2u "asdf" line 0 ~ + 3 %a+ "version.c" line 1 ~ + + When the [!] is included the list will show unlisted buffers + (the term "unlisted" is a bit confusing then...). + + Each buffer has a unique number. That number will not change, + so you can always go to a specific buffer with ":buffer N" or + "N CTRL-^", where N is the buffer number. + + Indicators (chars in the same column are mutually exclusive): + u an unlisted buffer (only displayed when [!] is used) + |unlisted-buffer| + % the buffer in the current window + # the alternate buffer for ":e #" and CTRL-^ + a an active buffer: it is loaded and visible + h a hidden buffer: It is loaded, but currently not + displayed in a window |hidden-buffer| + - a buffer with 'modifiable' off + = a readonly buffer + + a modified buffer + x a buffer with read errors + + *:bad* *:badd* +:bad[d] [+lnum] {fname} + Add file name {fname} to the buffer list, without loading it. + If "lnum" is specified, the cursor will be positioned at that + line when the buffer is first entered. Note that other + commands after the + will be ignored. + +:[N]bd[elete][!] *:bd* *:bdel* *:bdelete* *E516* +:bd[elete][!] [N] + Unload buffer [N] (default: current buffer) and delete it from + the buffer list. If the buffer was changed, this fails, + unless when [!] is specified, in which case changes are lost. + The file remains unaffected. Any windows for this buffer are + closed. If buffer [N] is the current buffer, another buffer + will be displayed instead. This is the most recent entry in + the jump list that points into a loaded buffer. + Actually, the buffer isn't completely deleted, it is removed + from the buffer list |unlisted-buffer| and option values, + variables and mappings/abbreviations for the buffer are + cleared. + +:bdelete[!] {bufname} *E93* *E94* + Like ":bdelete[!] [N]", but buffer given by name. Note that a + buffer whose name is a number cannot be referenced by that + name; use the buffer number instead. Insert a backslash + before a space in a buffer name. + +:bdelete[!] N1 N2 ... + Do ":bdelete[!]" for buffer N1, N2, etc. The arguments can be + buffer numbers or buffer names (but not buffer names that are + a number). Insert a backslash before a space in a buffer + name. + +:N,Mbdelete[!] Do ":bdelete[!]" for all buffers in the range N to M + |inclusive|. + +:[N]bw[ipeout][!] *:bw* *:bwipe* *:bwipeout* *E517* +:bw[ipeout][!] {bufname} +:N,Mbw[ipeout][!] +:bw[ipeout][!] N1 N2 ... + Like |:bdelete|, but really delete the buffer. Everything + related to the buffer is lost. All marks in this buffer + become invalid, option settings are lost, etc. Don't use this + unless you know what you are doing. + +:[N]bun[load][!] *:bun* *:bunload* *E515* +:bun[load][!] [N] + Unload buffer [N] (default: current buffer). The memory + allocated for this buffer will be freed. The buffer remains + in the buffer list. + If the buffer was changed, this fails, unless when [!] is + specified, in which case the changes are lost. + Any windows for this buffer are closed. If buffer [N] is the + current buffer, another buffer will be displayed instead. + This is the most recent entry in the jump list that points + into a loaded buffer. + +:bunload[!] {bufname} + Like ":bunload[!] [N]", but buffer given by name. Note that a + buffer whose name is a number cannot be referenced by that + name; use the buffer number instead. Insert a backslash + before a space in a buffer name. + +:N,Mbunload[!] Do ":bunload[!]" for all buffers in the range N to M + |inclusive|. + +:bunload[!] N1 N2 ... + Do ":bunload[!]" for buffer N1, N2, etc. The arguments can be + buffer numbers or buffer names (but not buffer names that are + a number). Insert a backslash before a space in a buffer + name. + +:[N]b[uffer][!] [N] *:b* *:bu* *:buf* *:buffer* *E86* + Edit buffer [N] from the buffer list. If [N] is not given, + the current buffer remains being edited. See |:buffer-!| for + [!]. This will also edit a buffer that is not in the buffer + list, without setting the 'buflisted' flag. + +:[N]b[uffer][!] {bufname} + Edit buffer for {bufname} from the buffer list. See + |:buffer-!| for [!]. This will also edit a buffer that is not + in the buffer list, without setting the 'buflisted' flag. + +:[N]sb[uffer] [N] *:sb* *:sbuffer* + Split window and edit buffer [N] from the buffer list. If [N] + is not given, the current buffer is edited. Respects the + "useopen" setting of 'switchbuf' when splitting. This will + also edit a buffer that is not in the buffer list, without + setting the 'buflisted' flag. + +:[N]sb[uffer] {bufname} + Split window and edit buffer for {bufname} from the buffer + list. This will also edit a buffer that is not in the buffer + list, without setting the 'buflisted' flag. + Note: If what you want to do is split the buffer, make a copy + under another name, you can do it this way: > + :w foobar | sp # + +:[N]bn[ext][!] [N] *:bn* *:bnext* *E87* + Go to [N]th next buffer in buffer list. [N] defaults to one. + Wraps around the end of the buffer list. + See |:buffer-!| for [!]. + If you are in a help buffer, this takes you to the next help + buffer (if there is one). Similarly, if you are in a normal + (non-help) buffer, this takes you to the next normal buffer. + This is so that if you have invoked help, it doesn't get in + the way when you're browsing code/text buffers. The next three + commands also work like this. + + *:sbn* *:sbnext* +:[N]sbn[ext] [N] + Split window and go to [N]th next buffer in buffer list. + Wraps around the end of the buffer list. Uses 'switchbuf' + +:[N]bN[ext][!] [N] *:bN* *:bNext* *:bp* *:bprevious* *E88* +:[N]bp[revious][!] [N] + Go to [N]th previous buffer in buffer list. [N] defaults to + one. Wraps around the start of the buffer list. + See |:buffer-!| for [!] and 'switchbuf'. + +:[N]sbN[ext] [N] *:sbN* *:sbNext* *:sbp* *:sbprevious* +:[N]sbp[revious] [N] + Split window and go to [N]th previous buffer in buffer list. + Wraps around the start of the buffer list. + Uses 'switchbuf'. + + *:br* *:brewind* +:br[ewind][!] Go to first buffer in buffer list. If the buffer list is + empty, go to the first unlisted buffer. + See |:buffer-!| for [!]. + + *:bf* *:bfirst* +:bf[irst] Same as ":brewind". + + *:sbr* *:sbrewind* +:sbr[ewind] Split window and go to first buffer in buffer list. If the + buffer list is empty, go to the first unlisted buffer. + Respects the 'switchbuf' option. + + *:sbf* *:sbfirst* +:sbf[irst] Same as ":sbrewind". + + *:bl* *:blast* +:bl[ast][!] Go to last buffer in buffer list. If the buffer list is + empty, go to the last unlisted buffer. + See |:buffer-!| for [!]. + + *:sbl* *:sblast* +:sbl[ast] Split window and go to last buffer in buffer list. If the + buffer list is empty, go to the last unlisted buffer. + Respects 'switchbuf' option. + +:[N]bm[odified][!] [N] *:bm* *:bmodified* *E84* + Go to [N]th next modified buffer. Note: this command also + finds unlisted buffers. If there is no modified buffer the + command fails. + +:[N]sbm[odified] [N] *:sbm* *:sbmodified* + Split window and go to [N]th next modified buffer. + Respects 'switchbuf' option. + Note: this command also finds buffers not in the buffer list. + +:[N]unh[ide] [N] *:unh* *:unhide* *:sun* *:sunhide* +:[N]sun[hide] [N] + Rearrange the screen to open one window for each loaded buffer + in the buffer list. When a count is given, this is the + maximum number of windows to open. + +:[N]ba[ll] [N] *:ba* *:ball* *:sba* *:sball* +:[N]sba[ll] [N] Rearrange the screen to open one window for each buffer in + the buffer list. When a count is given, this is the maximum + number of windows to open. 'winheight' also limits the number + of windows opened ('winwidth' if |:vertical| was prepended). + Buf/Win Enter/Leave autocommands are not executed for the new + windows here, that's only done when they are really entered. + When the |:tab| modifier is used new windows are opened in a + new tab, up to 'tabpagemax'. + +Note: All the commands above that start editing another buffer, keep the +'readonly' flag as it was. This differs from the ":edit" command, which sets +the 'readonly' flag each time the file is read. + +============================================================================== +12. Special kinds of buffers *special-buffers* + +Instead of containing the text of a file, buffers can also be used for other +purposes. A few options can be set to change the behavior of a buffer: + 'bufhidden' what happens when the buffer is no longer displayed + in a window. + 'buftype' what kind of a buffer this is + 'swapfile' whether the buffer will have a swap file + 'buflisted' buffer shows up in the buffer list + +A few useful kinds of a buffer: + +quickfix Used to contain the error list or the location list. See + |:cwindow| and |:lwindow|. This command sets the 'buftype' + option to "quickfix". You are not supposed to change this! + 'swapfile' is off. + +help Contains a help file. Will only be created with the |:help| + command. The flag that indicates a help buffer is internal + and can't be changed. The 'buflisted' option will be reset + for a help buffer. + +directory Displays directory contents. Can be used by a file explorer + plugin. The buffer is created with these settings: > + :setlocal buftype=nowrite + :setlocal bufhidden=delete + :setlocal noswapfile +< The buffer name is the name of the directory and is adjusted + when using the |:cd| command. + +scratch Contains text that can be discarded at any time. It is kept + when closing the window, it must be deleted explicitly. + Settings: > + :setlocal buftype=nofile + :setlocal bufhidden=hide + :setlocal noswapfile +< The buffer name can be used to identify the buffer, if you + give it a meaningful name. + + *unlisted-buffer* +unlisted The buffer is not in the buffer list. It is not used for + normal editing, but to show a help file, remember a file name + or marks. The ":bdelete" command will also set this option, + thus it doesn't completely delete the buffer. Settings: > + :setlocal nobuflisted +< + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/workshop.txt b/share/vim/vim73/doc/workshop.txt new file mode 100644 index 0000000000..7fde55bc97 --- /dev/null +++ b/share/vim/vim73/doc/workshop.txt @@ -0,0 +1,98 @@ +*workshop.txt* For Vim version 7.3. Last change: 2010 Jul 20 + + + VIM REFERENCE MANUAL by Gordon Prieur + + +Sun Visual WorkShop Features *workshop* *workshop-support* + +1. Introduction |workshop-intro| +2. Commands |workshop-commands| +3. Compiling vim/gvim for WorkShop |workshop-compiling| +4. Configuring gvim for a WorkShop release tree |workshop-configure| +5. Obtaining the latest version of the XPM library |workshop-xpm| + +{Vi does not have any of these features} +{only available when compiled with the |+sun_workshop| feature} + +============================================================================== +1. Introduction *workshop-intro* + +Sun Visual WorkShop has an "Editor of Choice" feature designed to let users +debug using their favorite editors. For the 6.0 release we have added support +for gvim. A workshop debug session will have a debugging window and an editor +window (possibly others as well). The user can do many debugging operations +from the editor window, minimizing the need to switch from window to window. + +The version of vim shipped with Sun Visual WorkShop 6 (also called Forte +Developer 6) is vim 5.3. The features in this release are much more reliable +than the vim/gvim shipped with Visual WorkShop. VWS users wishing to use vim +as their editor should compile these sources and install them in their +workshop release tree. + +============================================================================== +2. Commands *workshop-commands* + + *:ws* *:wsverb* +:ws[verb] verb Pass the verb to the verb executor + +Pass the verb to a workshop function which gathers some arguments and +sends the verb and data to workshop over an IPC connection. + +============================================================================== +3. Compiling vim/gvim for WorkShop *workshop-compiling* + +Compiling vim with FEAT_SUN_WORKSHOP turns on all compile time flags necessary +for building a vim to work with Visual WorkShop. The features required for VWS +have been built and tested using the Sun compilers from the VWS release. They +have not been built or tested using Gnu compilers. This does not mean the +features won't build and run if compiled with gcc, just that nothing is +guaranteed with gcc! + +============================================================================== +4. Configuring gvim for a WorkShop release tree *workshop-configure* + +There are several assumptions which must be met in order to compile a gvim for +use with Sun Visual WorkShop 6. + + o You should use the compiler in VWS rather than gcc. We have neither + built nor tested with gcc and cannot guarantee it will build properly. + + o You must supply your own XPM library. See |workshop-xpm| below for + details on obtaining the latest version of XPM. + + o Edit the Makefile in the src directory and uncomment the lines for Sun + Visual WorkShop. You can easily find these by searching for the string + FEAT_SUN_WORKSHOP + + o We also suggest you use Motif for your gui. This will provide gvim with + the same look-and-feel as the rest of Sun Visual WorkShop. + +The following configuration line can be used to configure vim to build for use +with Sun Visual WorkShop: + + $ CC=cc configure --enable-workshop --enable-gui=motif \ + -prefix=<VWS-install-dir>/contrib/contrib6/<vim-version> + +The VWS-install-dir should be the base directory where your Sun Visual WorkShop +was installed. By default this is /opt/SUNWspro. It will normally require +root permissions to install the vim release. You will also need to change the +symlink <VWS-install-dir>/bin/gvim to point to the vim in your newly installed +directory. The <vim-version> should be a unique version string. I use "vim" +concatenated with the equivalent of version.h's VIM_VERSION_SHORT. + +============================================================================== +5. Obtaining the latest version of the XPM library *workshop-xpm* + +The XPM library is required to show images within Vim with Motif or Athena. +Without it the toolbar and signs will be disabled. + +The XPM library is provided by Arnaud Le Hors of the French National Institute +for Research in Computer Science and Control. It can be downloaded from +http://cgit.freedesktop.org/xorg/lib/libXpm. The current release, as of this +writing, is xpm-3.4k-solaris.tgz, which is a gzip'ed tar file. If you create +the directory /usr/local/xpm and untar the file there you can use the +uncommented lines in the Makefile without changing them. If you use another +xpm directory you will need to change the XPM_DIR in src/Makefile. + + vim:tw=78:ts=8:ft=help:norl: diff --git a/share/vim/vim73/doc/xxd-fr.1 b/share/vim/vim73/doc/xxd-fr.1 new file mode 100644 index 0000000000..0b25da4376 --- /dev/null +++ b/share/vim/vim73/doc/xxd-fr.1 @@ -0,0 +1,395 @@ +.TH XXD 1 "août 1996" "Page de manuel pour xxd" +.\" +.\" 21st May 1996 +.\" Man page author: +.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.\" Changes by Bram Moolenaar <Bram@vim.org> +.\" French translation by David Blanchet <david.blanchet@free.fr> 2005-03 +.SH NOM +.I xxd +\- convertit en représentation hexadécimale et inversement. +.SH SYNOPSIS +.B xxd +\-h[elp] +.br +.B xxd +[options] [fichier_entree [fichier_sortie]] +.br +.B xxd +\-r[evert] [options] [fichier_entree [fichier_sortie]] +.SH DESCRIPTION +.I xxd +crée un fichier contenant la représentation hexadécimale d'un fichier +binaire ou de l'entrée standard. +Il peut également convertir un fichier de codes hexadécimaux en un fichier +binaire. +Comme +.BR uuencode (1) +et +.BR uudecode (1) +il permet la transmission de données binaires dans une représentation ASCII +compatible avec le courrier électronique, mais a l'avantage de décoder la +sortie standard. +De plus, il peut être utilisé pour appliquer des rustines à des fichiers +binaires. +.SH OPTIONS +Si aucun +.I fichier_entree +n'est spécifié, l'entrée standard est utilisée. +Si +.I fichier_entree +correspond au caractère +.RB '\-' +\, l'entrée standard est employée comme source des données en entrée. +Si aucun +.I fichier_sortie +n'est spécifié (ou qu'un caractère +.RB '\-' +est donné à sa place), le résultat est envoyé sur la sortie standard. +.PP +NOTE : un analyseur paresseux est utilisé. Il ne vérifie pas au-delà de la +première lettre de l'option, à moins que cette dernière ne requiert un +paramètre. +L'espace entre l'option et son paramètre est optionnel. +Les paramètres des options peuvent être spécifiés en notation décimale, +hexadécimale ou octale. +Ainsi +.BR \-c8 , +.BR "\-c 8" , +.B \-c 010 +et +.B \-cols 8 +sont tous équivalents. +.TP +.IR \-a " | " \-autoskip +active la fonctionnalité "autoskip" : le caractère '*' remplace les lignes +d'octets nuls. Désactivée par défaut. +.TP +.IR \-b " | " \-bits +Convertit en binaires plutôt qu'en hexadécimal. +Cette option écrit les octets comme une séquence de "1" et de "0" au lieu +d'une conversion en hexadécimal traditionnel. Chaque ligne est précédée par un +numéro de ligne en hexadécimal et suivie de la représentation ASCII (ou +EBCDIC) correspondante. Les options \-r, \-p, \-i ne fonctionnent pas dans ce +mode. +.TP +.IR "\-c cols " | " \-cols cols" +place +.RI < cols > +octets par ligne. 16 par défaut (\-i : 12, \-ps : 30, \-b : 6). Maximum 256. +.TP +.IR \-E " | " \-EBCDIC +Passe le codage des caractères de la colonne de droite de ASCII à EBCDIC. +Cela ne change pas la représentation hexadécimale. Cette option est sans effet +quand elle est utilisée avec \-r, \-p or \-i. +.TP +.IR "\-g octets " | " \-groupsize octets" +Regroupe les octets (deux chiffres hexadécimaux ou huit chiffres binaires) +par groupe de +.RI < octets > +\, séparés par des espaces blancs. Spécifiez +.I \-g 0 +pour supprimer le regroupement. +.RI < octets > +vaut 2 par défaut dans le mode normal et \fI1\fP en +représentation binaire. Le regroupement ne s'applique pas aux styles +Postscript et Include. +.TP +.IR \-h " | " \-help +Affiche un résumé des commandes disponibles et quitte. Aucune conversion n'est +effectuée. +.TP +.IR \-i " | " \-include +produit une sortie dans le style #include (fichier C à inclure). La définition +complète d'un tableau statique est écrite et est nommée d'après le fichier +d'origine, à moins que xxd lise depuis l'entrée standard. +.TP +.IR "\-l long " | " \-len long" +Arrête après l'écriture de +.RI < long > +octets. +.TP +.IR \-p " | " \-ps " | " \-postscript " | " \-plain +Produit une conversion continue dans le style Postscript (postscript continuous +hexdumd style). +Également connu sous le nom de « conversion brute » (plain hexdump style). +.TP +.IR \-r " | " \-revert +Opération inverse : convertit un fichier hexadécimal en un fichier binaire (ou +applique une rustine à un fichier binaire). +Si l'écriture n'a pas lieu sur la sortie standard, xxd écrit dans le fichier +qu'il produit sans le tronquer. Utilisez la combinaison +.I \-r \-p +pour lire de l'hexadécimal brut sans information sur le numéro des lignes et +sans format de colonnes particulier. Des espaces blancs et coupures de lignes +supplémentaires sont autorisés à n'importe quel endroit. +.TP +.I \-seek décalage +Utilisé après l'option +.IR \-r : +inverse la conversion en ajoutant +.RI < décalage > +aux positions dans le fichier données dans le code hexadécimal. +.TP +.I \-s [+][\-]décalage +Débute au +.RI < décalage > +absolu ou relatif dans fichier_entree. +\fI+ \fRindique que le décalage est relatif à la position courante dans +l'entrée standard (sans effet si la lecture n'a pas lieu sur l'entrée +standard). \fI\- \fRindique un décalage en caractères depuis la fin de +l'entrée (utilisé avec \fI+\fR, désigne la position avant la position +actuelle de l'entrée standard). +Sans l'option \-s, xxd démarre à la position courante du fichier. +.TP +.I \-u +Utilise des chiffres hexadécimaux majuscules. La casse par défaut est +minuscule. +.TP +.IR \-v " | " \-version +Affiche la version de xxd. +.SH MISE EN GARDE +.I xxd \-r +effectue des opérations internes un peu obscures lors de l'évaluation +des informations sur les numéros de lignes. Si le fichier de sortie est +adressable, alors les numéros de lignes au début de chaque ligne d'hexadécimal +peuvent être désordonnées, des lignes peuvent manquer ou se chevaucher. Dans +ces cas, xxd utilisera lseek(2) pour déterminer la prochaine position. Si le +fichier n'est pas adressable, seuls les vides sont autorisés, et ils seront +comblés par des octets nuls. +.PP +.I xxd \-r +ne génère aucune erreur lors de l'analyse. Le problème sont passés +silencieusement. +.PP +Lors de l'édition de la représentation hexadécimale, veuillez noter que +.I xxd \-r +ignore tout ce qui se trouve sur la ligne après avoir lu suffisamment de +données hexadécimales (voir l'option \-c). Cela signifie également que les +modifications dans la colonne ASCII (ou EBCDIC) sont toujours ignorées. La +conversion inverse de données hexadécimales brutes (postscript) avec xxd \-r +\-p ne dépend pas d'un nombre correct de colonnes. Dans ce cas, tout ce qui +ressemble à une paire de chiffres hexadécimaux est interprété. +.PP +Remarquez la différence entre +.br +\fI% xxd \-i fichier\fR +.br +et +.br +\fI% xxd \-i < fichier\fR +.PP +.I xxd \-s \+seek +peut différer de +.IR "xxd \-s seek" , +car lseek(2) est utilisé pour « revenir en arrière ». Le '+' fait une +différence quand la source des données est l'entrée standard et si la position +dans le fichier de l'entrée standard n'est pas au début du fichier lorsque xxd +est démarré et qu'il reçoit ses données. +L'exemple suivant peut vous aider à comprendre (ou bien vous perdre davantage +encore !)... +.PP +Remettre l'entrée standard au départ avant de lire ; nécessaire car 'cat' a +déjà lu jusqu'à la fin de l'entrée standard. +.br +\fI% sh \-c 'cat > donnees_binaires; xxd \-s 0 > donnees_hexa' < fichier\fR +.PP +Convertir à partir de la position 0x480 (= 1024 + 128) du fichier. +Le symbole '+' signifie "relativement à la position actuelle', ainsi 128 est +ajouté aux 1024 octets comptabilisés pour dd. +.br +\fI% sh \-c 'dd of=donnees_binaires bs=1k count=1; xxd \-s +128 > +donnees_hexa' < fichier\fR +.PP +Convertir de fichier depuis la position 0x100 (= 1024 \- 768) du fichier. +.br +\fI% sh \-c 'dd of=donnees_binaires bs=1k count=1; xxd \-s +\-768 > +donnees_hexa' < fichier\fR +.PP +Toutefois, cette situation est peu fréquente et l'utilisation de '+' est +rarement requise. L'auteur préfère surveiller les effets de xxd avec strace(1) +ou truss(1) quand \-s est employé. +.SH EXEMPLES +Afficher la totalité du +.B fichier +sauf les trois premières lignes (0x30 octets en hexadécimal). +.br +\fI% xxd \-s 0x30 fichier\fR +.PP +afficher les trois dernières lignes (0x30 octets en hexadécimal) du +.B fichier +\. +.br +\fI% xxd \-s \-0x30 fichier\fR +.PP +.br +Afficher 120 octets convertis en continu, avec 20 octets par ligne. +.br +\fI% xxd \-l 120 \-ps \-c 20 xxd\-fr.1\fR +.br +2e54482058584420312022616ffb742031393936 +.br +22202250616765206465206d616e75656c20706f +.br +757220787864220a2e5c220a2e5c222032317374 +.br +204d617920313939360a2e5c22204d616e207061 +.br +676520617574686f723a0a2e5c2220202020546f +.br +6e79204e7567656e74203c746f6e79407363746e +.br +204e7567656e74203c746f6e79407363746e7567 +.br +2e54482058584420312022417567757374203139 +.PP +Convertir les 120 premiers octets de cette page de manuel avec 12 octets par +ligne. +.br +\fI% xxd \-l 120 \-c 12 xxd\-fr.1\fR +.br +0000000: 2e54 4820 5858 4420 3120 2261 .TH XXD 1 "a +.br +000000c: 6ffb 7420 3139 3936 2220 2250 o.t 1996" "P +.br +0000018: 6167 6520 6465 206d 616e 7565 age de manue +.br +0000024: 6c20 706f 7572 2078 7864 220a l pour xxd". +.br +0000030: 2e5c 220a 2e5c 2220 3231 7374 .\"..\" 21st +.br +000003c: 204d 6179 2031 3939 360a 2e5c May 1996..\ +.br +0000048: 2220 4d61 6e20 7061 6765 2061 " Man page a +.br +0000054: 7574 686f 723a 0a2e 5c22 2020 uthor:..\" +.br +0000060: 2020 546f 6e79 204e 7567 656e Tony Nugen +.br +000006c: 7420 3c74 6f6e 7940 7363 746e t <tony@sctn +.PP +Afficher la date écrite au début du fichier xxd\-fr.1. +.br +\fI% xxd \-s 0x38 \-l 13 \-c 13 xxd.1\fR +.br +0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 +.PP +Copier +.B fichier_entree +vers +.B fichier_sortie +en ajoutant 100 octets de valeur 0x00 avant. +.br +\fI% xxd fichier_entree | xxd \-r \-s 100 \> fichier_sortie\fR +.PP +Patcher la date dans le fichier xxd.1 +.br +\fI% echo '0000037: 3574 68' | xxd \-r \- xxd\-fr.1\fR +.br +\fI% xxd \-s 0x38 \-l 13 \-c 13 xxd\-fr.1\fR +.br +0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 +.PP +Créer un fichier de 65537 octets tous nuls (0x00), +sauf le dernier qui vaut 'A' (0x41 en hexadécimal). +.br +\fI% echo '010000: 41' | xxd \-r \> fichier\fR +.PP +.br +Convertir le fichier de l'exemple précédent avec la fonctionnalité "autoskip". +.br +\fI% xxd \-a \-c 12 fichier\fR +.br +0000000: 0000 0000 0000 0000 0000 0000 ............ +.br +* +.br +000fffc: 0000 0000 40 ....A +.PP +Créer un fichier d'un octet, contenant seulement le caractère 'A'. +Les nombres après '\-r \-s' s'ajoutent au numéros de lignes trouvées dans le +fichier ; les octets initiaux sont supprimés. +.br +\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> fichier\fR +.PP +Utiliser xxd comme filtre dans un éditeur tel que +.B vim(1) +pour convertir une zone comprise entre les marques 'a' et 'z'. +.br +\fI:'a,'z!xxd\fR +.PP +Utiliser xxd comme filtre dans un éditeur tel que +.B vim(1) +pour récupérer une conversion binaire comprise entre les marques 'a' et 'z'. +.br +\fI:'a,'z!xxd \-r\fR +.PP +Utiliser xxd comme filtre dans un éditeur tel que +.B vim(1) +pour récupérer une ligne convertie. Placez le curseur sur la ligne et tapez : +.br +\fI!!xxd \-r\fR +.PP +Lire des caractères depuis une connexion série : +.br +\fI% xxd \-c1 < /dev/term/b &\fR +.br +\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR +.br +\fI% echo \-n foo > /dev/term/b\fR +.SH VALEURS DE RETOUR +Les erreurs suivantes sont rapportées : +.TP +0 +aucune erreur ne s'est produit. +.TP +\-1 +opération non supportée ( +.I xxd \-r \-i +reste impossible). +.TP +1 +erreur lors de l'analyse des options. +.TP +2 +problème avec le fichier d'entrée. +.TP +3 +problème avec le fichier de sortie. +.TP +4, 5 +la position spécifiée n'est pas atteignable. +.SH VOIR AUSSI +uuencode(1), uudecode(1), patch(1) +.SH AVERTISSEMENTS +L'étrangeté de cet outil reflète celle du cerveau de ses créateurs. +Utilisez cet outil à vos risques et périls. Dupliquez vos fichiers. +Surveillez l'outil. Devenez un gourou. +.SH VERSION +Cette page de manuel documente la version 1.7 de xxd. +.SH AUTEUR +(c) 1990-1997 par Juergen Weigert +.br +<jnweiger@informatik.uni-erlangen.de> +.LP +"Distribute freely and credit me, +.br +make money and share with me, +.br +lose money and don't ask me." +.PP +Distribution libre en citant l'auteur, +.br +gagnez de l'argent, pensez à moi, +.br +perdez de l'argent, oubliez-moi. +.PP +Page de manuel débutée par Tony Nugent +.br +<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.br +Modifications mineures par Bram Moolenaar. +Édité par Juergen Weigert. +.SH TRADUCTION +Cette page de manuel a été traduite par David Blanchet +<david.blanchet@free.fr> 2004-12-24. diff --git a/share/vim/vim73/doc/xxd-fr.UTF-8.1 b/share/vim/vim73/doc/xxd-fr.UTF-8.1 new file mode 100644 index 0000000000..9fc47d3ac7 --- /dev/null +++ b/share/vim/vim73/doc/xxd-fr.UTF-8.1 @@ -0,0 +1,395 @@ +.TH XXD 1 "août 1996" "Page de manuel pour xxd" +.\" +.\" 21st May 1996 +.\" Man page author: +.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.\" Changes by Bram Moolenaar <Bram@vim.org> +.\" French translation by David Blanchet <david.blanchet@free.fr> 2005-03 +.SH NOM +.I xxd +\- convertit en représentation hexadécimale et inversement. +.SH SYNOPSIS +.B xxd +\-h[elp] +.br +.B xxd +[options] [fichier_entree [fichier_sortie]] +.br +.B xxd +\-r[evert] [options] [fichier_entree [fichier_sortie]] +.SH DESCRIPTION +.I xxd +crée un fichier contenant la représentation hexadécimale d'un fichier +binaire ou de l'entrée standard. +Il peut également convertir un fichier de codes hexadécimaux en un fichier +binaire. +Comme +.BR uuencode (1) +et +.BR uudecode (1) +il permet la transmission de données binaires dans une représentation ASCII +compatible avec le courrier électronique, mais a l'avantage de décoder la +sortie standard. +De plus, il peut être utilisé pour appliquer des rustines à des fichiers +binaires. +.SH OPTIONS +Si aucun +.I fichier_entree +n'est spécifié, l'entrée standard est utilisée. +Si +.I fichier_entree +correspond au caractère +.RB '\-' +\, l'entrée standard est employée comme source des données en entrée. +Si aucun +.I fichier_sortie +n'est spécifié (ou qu'un caractère +.RB '\-' +est donné à sa place), le résultat est envoyé sur la sortie standard. +.PP +NOTE : un analyseur paresseux est utilisé. Il ne vérifie pas au-delà de la +première lettre de l'option, à moins que cette dernière ne requiert un +paramètre. +L'espace entre l'option et son paramètre est optionnel. +Les paramètres des options peuvent être spécifiés en notation décimale, +hexadécimale ou octale. +Ainsi +.BR \-c8 , +.BR "\-c 8" , +.B \-c 010 +et +.B \-cols 8 +sont tous équivalents. +.TP +.IR \-a " | " \-autoskip +active la fonctionnalité "autoskip" : le caractère '*' remplace les lignes +d'octets nuls. Désactivée par défaut. +.TP +.IR \-b " | " \-bits +Convertit en binaires plutôt qu'en hexadécimal. +Cette option écrit les octets comme une séquence de "1" et de "0" au lieu +d'une conversion en hexadécimal traditionnel. Chaque ligne est précédée par un +numéro de ligne en hexadécimal et suivie de la représentation ASCII (ou +EBCDIC) correspondante. Les options \-r, \-p, \-i ne fonctionnent pas dans ce +mode. +.TP +.IR "\-c cols " | " \-cols cols" +place +.RI < cols > +octets par ligne. 16 par défaut (\-i : 12, \-ps : 30, \-b : 6). Maximum 256. +.TP +.IR \-E " | " \-EBCDIC +Passe le codage des caractères de la colonne de droite de ASCII à EBCDIC. +Cela ne change pas la représentation hexadécimale. Cette option est sans effet +quand elle est utilisée avec \-r, \-p or \-i. +.TP +.IR "\-g octets " | " \-groupsize octets" +Regroupe les octets (deux chiffres hexadécimaux ou huit chiffres binaires) +par groupe de +.RI < octets > +\, séparés par des espaces blancs. Spécifiez +.I \-g 0 +pour supprimer le regroupement. +.RI < octets > +vaut 2 par défaut dans le mode normal et \fI1\fP en +représentation binaire. Le regroupement ne s'applique pas aux styles +Postscript et Include. +.TP +.IR \-h " | " \-help +Affiche un résumé des commandes disponibles et quitte. Aucune conversion n'est +effectuée. +.TP +.IR \-i " | " \-include +produit une sortie dans le style #include (fichier C à inclure). La définition +complète d'un tableau statique est écrite et est nommée d'après le fichier +d'origine, à moins que xxd lise depuis l'entrée standard. +.TP +.IR "\-l long " | " \-len long" +Arrête après l'écriture de +.RI < long > +octets. +.TP +.IR \-p " | " \-ps " | " \-postscript " | " \-plain +Produit une conversion continue dans le style Postscript (postscript continuous +hexdumd style). +Également connu sous le nom de « conversion brute » (plain hexdump style). +.TP +.IR \-r " | " \-revert +Opération inverse : convertit un fichier hexadécimal en un fichier binaire (ou +applique une rustine à un fichier binaire). +Si l'écriture n'a pas lieu sur la sortie standard, xxd écrit dans le fichier +qu'il produit sans le tronquer. Utilisez la combinaison +.I \-r \-p +pour lire de l'hexadécimal brut sans information sur le numéro des lignes et +sans format de colonnes particulier. Des espaces blancs et coupures de lignes +supplémentaires sont autorisés à n'importe quel endroit. +.TP +.I \-seek décalage +Utilisé après l'option +.IR \-r : +inverse la conversion en ajoutant +.RI < décalage > +aux positions dans le fichier données dans le code hexadécimal. +.TP +.I \-s [+][\-]décalage +Débute au +.RI < décalage > +absolu ou relatif dans fichier_entree. +\fI+ \fRindique que le décalage est relatif à la position courante dans +l'entrée standard (sans effet si la lecture n'a pas lieu sur l'entrée +standard). \fI\- \fRindique un décalage en caractères depuis la fin de +l'entrée (utilisé avec \fI+\fR, désigne la position avant la position +actuelle de l'entrée standard). +Sans l'option \-s, xxd démarre à la position courante du fichier. +.TP +.I \-u +Utilise des chiffres hexadécimaux majuscules. La casse par défaut est +minuscule. +.TP +.IR \-v " | " \-version +Affiche la version de xxd. +.SH MISE EN GARDE +.I xxd \-r +effectue des opérations internes un peu obscures lors de l'évaluation +des informations sur les numéros de lignes. Si le fichier de sortie est +adressable, alors les numéros de lignes au début de chaque ligne d'hexadécimal +peuvent être désordonnées, des lignes peuvent manquer ou se chevaucher. Dans +ces cas, xxd utilisera lseek(2) pour déterminer la prochaine position. Si le +fichier n'est pas adressable, seuls les vides sont autorisés, et ils seront +comblés par des octets nuls. +.PP +.I xxd \-r +ne génère aucune erreur lors de l'analyse. Le problème sont passés +silencieusement. +.PP +Lors de l'édition de la représentation hexadécimale, veuillez noter que +.I xxd \-r +ignore tout ce qui se trouve sur la ligne après avoir lu suffisamment de +données hexadécimales (voir l'option \-c). Cela signifie également que les +modifications dans la colonne ASCII (ou EBCDIC) sont toujours ignorées. La +conversion inverse de données hexadécimales brutes (postscript) avec xxd \-r +\-p ne dépend pas d'un nombre correct de colonnes. Dans ce cas, tout ce qui +ressemble à une paire de chiffres hexadécimaux est interprété. +.PP +Remarquez la différence entre +.br +\fI% xxd \-i fichier\fR +.br +et +.br +\fI% xxd \-i < fichier\fR +.PP +.I xxd \-s \+seek +peut différer de +.IR "xxd \-s seek" , +car lseek(2) est utilisé pour « revenir en arrière ». Le '+' fait une +différence quand la source des données est l'entrée standard et si la position +dans le fichier de l'entrée standard n'est pas au début du fichier lorsque xxd +est démarré et qu'il reçoit ses données. +L'exemple suivant peut vous aider à comprendre (ou bien vous perdre davantage +encore !)... +.PP +Remettre l'entrée standard au départ avant de lire ; nécessaire car 'cat' a +déjà lu jusqu'à la fin de l'entrée standard. +.br +\fI% sh \-c 'cat > donnees_binaires; xxd \-s 0 > donnees_hexa' < fichier\fR +.PP +Convertir à partir de la position 0x480 (= 1024 + 128) du fichier. +Le symbole '+' signifie "relativement à la position actuelle', ainsi 128 est +ajouté aux 1024 octets comptabilisés pour dd. +.br +\fI% sh \-c 'dd of=donnees_binaires bs=1k count=1; xxd \-s +128 > +donnees_hexa' < fichier\fR +.PP +Convertir de fichier depuis la position 0x100 (= 1024 \- 768) du fichier. +.br +\fI% sh \-c 'dd of=donnees_binaires bs=1k count=1; xxd \-s +\-768 > +donnees_hexa' < fichier\fR +.PP +Toutefois, cette situation est peu fréquente et l'utilisation de '+' est +rarement requise. L'auteur préfère surveiller les effets de xxd avec strace(1) +ou truss(1) quand \-s est employé. +.SH EXEMPLES +Afficher la totalité du +.B fichier +sauf les trois premières lignes (0x30 octets en hexadécimal). +.br +\fI% xxd \-s 0x30 fichier\fR +.PP +afficher les trois dernières lignes (0x30 octets en hexadécimal) du +.B fichier +\. +.br +\fI% xxd \-s \-0x30 fichier\fR +.PP +.br +Afficher 120 octets convertis en continu, avec 20 octets par ligne. +.br +\fI% xxd \-l 120 \-ps \-c 20 xxd\-fr.1\fR +.br +2e54482058584420312022616ffb742031393936 +.br +22202250616765206465206d616e75656c20706f +.br +757220787864220a2e5c220a2e5c222032317374 +.br +204d617920313939360a2e5c22204d616e207061 +.br +676520617574686f723a0a2e5c2220202020546f +.br +6e79204e7567656e74203c746f6e79407363746e +.br +204e7567656e74203c746f6e79407363746e7567 +.br +2e54482058584420312022417567757374203139 +.PP +Convertir les 120 premiers octets de cette page de manuel avec 12 octets par +ligne. +.br +\fI% xxd \-l 120 \-c 12 xxd\-fr.1\fR +.br +0000000: 2e54 4820 5858 4420 3120 2261 .TH XXD 1 "a +.br +000000c: 6ffb 7420 3139 3936 2220 2250 o.t 1996" "P +.br +0000018: 6167 6520 6465 206d 616e 7565 age de manue +.br +0000024: 6c20 706f 7572 2078 7864 220a l pour xxd". +.br +0000030: 2e5c 220a 2e5c 2220 3231 7374 .\"..\" 21st +.br +000003c: 204d 6179 2031 3939 360a 2e5c May 1996..\ +.br +0000048: 2220 4d61 6e20 7061 6765 2061 " Man page a +.br +0000054: 7574 686f 723a 0a2e 5c22 2020 uthor:..\" +.br +0000060: 2020 546f 6e79 204e 7567 656e Tony Nugen +.br +000006c: 7420 3c74 6f6e 7940 7363 746e t <tony@sctn +.PP +Afficher la date écrite au début du fichier xxd\-fr.1. +.br +\fI% xxd \-s 0x38 \-l 13 \-c 13 xxd.1\fR +.br +0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 +.PP +Copier +.B fichier_entree +vers +.B fichier_sortie +en ajoutant 100 octets de valeur 0x00 avant. +.br +\fI% xxd fichier_entree | xxd \-r \-s 100 \> fichier_sortie\fR +.PP +Patcher la date dans le fichier xxd.1 +.br +\fI% echo '0000037: 3574 68' | xxd \-r \- xxd\-fr.1\fR +.br +\fI% xxd \-s 0x38 \-l 13 \-c 13 xxd\-fr.1\fR +.br +0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 +.PP +Créer un fichier de 65537 octets tous nuls (0x00), +sauf le dernier qui vaut 'A' (0x41 en hexadécimal). +.br +\fI% echo '010000: 41' | xxd \-r \> fichier\fR +.PP +.br +Convertir le fichier de l'exemple précédent avec la fonctionnalité "autoskip". +.br +\fI% xxd \-a \-c 12 fichier\fR +.br +0000000: 0000 0000 0000 0000 0000 0000 ............ +.br +* +.br +000fffc: 0000 0000 40 ....A +.PP +Créer un fichier d'un octet, contenant seulement le caractère 'A'. +Les nombres après '\-r \-s' s'ajoutent au numéros de lignes trouvées dans le +fichier ; les octets initiaux sont supprimés. +.br +\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> fichier\fR +.PP +Utiliser xxd comme filtre dans un éditeur tel que +.B vim(1) +pour convertir une zone comprise entre les marques 'a' et 'z'. +.br +\fI:'a,'z!xxd\fR +.PP +Utiliser xxd comme filtre dans un éditeur tel que +.B vim(1) +pour récupérer une conversion binaire comprise entre les marques 'a' et 'z'. +.br +\fI:'a,'z!xxd \-r\fR +.PP +Utiliser xxd comme filtre dans un éditeur tel que +.B vim(1) +pour récupérer une ligne convertie. Placez le curseur sur la ligne et tapez : +.br +\fI!!xxd \-r\fR +.PP +Lire des caractères depuis une connexion série : +.br +\fI% xxd \-c1 < /dev/term/b &\fR +.br +\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR +.br +\fI% echo \-n foo > /dev/term/b\fR +.SH VALEURS DE RETOUR +Les erreurs suivantes sont rapportées : +.TP +0 +aucune erreur ne s'est produit. +.TP +\-1 +opération non supportée ( +.I xxd \-r \-i +reste impossible). +.TP +1 +erreur lors de l'analyse des options. +.TP +2 +problème avec le fichier d'entrée. +.TP +3 +problème avec le fichier de sortie. +.TP +4, 5 +la position spécifiée n'est pas atteignable. +.SH VOIR AUSSI +uuencode(1), uudecode(1), patch(1) +.SH AVERTISSEMENTS +L'étrangeté de cet outil reflète celle du cerveau de ses créateurs. +Utilisez cet outil à vos risques et périls. Dupliquez vos fichiers. +Surveillez l'outil. Devenez un gourou. +.SH VERSION +Cette page de manuel documente la version 1.7 de xxd. +.SH AUTEUR +(c) 1990-1997 par Juergen Weigert +.br +<jnweiger@informatik.uni-erlangen.de> +.LP +"Distribute freely and credit me, +.br +make money and share with me, +.br +lose money and don't ask me." +.PP +Distribution libre en citant l'auteur, +.br +gagnez de l'argent, pensez à moi, +.br +perdez de l'argent, oubliez-moi. +.PP +Page de manuel débutée par Tony Nugent +.br +<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.br +Modifications mineures par Bram Moolenaar. +Édité par Juergen Weigert. +.SH TRADUCTION +Cette page de manuel a été traduite par David Blanchet +<david.blanchet@free.fr> 2004-12-24. diff --git a/share/vim/vim73/doc/xxd-it.1 b/share/vim/vim73/doc/xxd-it.1 new file mode 100644 index 0000000000..3d8dabb950 --- /dev/null +++ b/share/vim/vim73/doc/xxd-it.1 @@ -0,0 +1,402 @@ +.TH XXD 1 "Agosto 1996" "Pagina di manuale per xxd" +.\" +.\" 21 Maggio 1996 +.\" Autore della pagina di manuale: +.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.\" Modificato da Bram Moolenaar <Bram@vim.org> +.SH NOME +.I xxd +\- Produce esadecimale da un file binario o viceversa. +.SH SINTASSI +.B xxd +\-h[elp] +.br +.B xxd +[opzioni] [input_file [output_file]] +.br +.B xxd +\-r[evert] [opzioni] [input_file [output_file]] +.SH DESCRIZIONE +.I xxd +crea un'immagine esadecimale di un dato file o dello "standard input". +Può anche ottenere da un'immagine esadecimale il file binario originale. +Come +.BR uuencode (1) +e +.BR uudecode (1) +permette di trasmettere dati binari in una rappresentazione ASCII "a prova +di email", ma ha anche il vantaggio di poter decodificare sullo "standard +output". Inoltre, può essere usato per effettuare delle modifiche (patch) +a file binari. +.SH OPZIONI +Se non si specifica un +.I input_file +il programma legge dallo "standard input". +Se +.I input_file +è specificato come il carattere +.RB \` \- ' +, l'input è letto dallo "standard input". +Se non si specifica un +.I output_file +(o si mette al suo posto il carattere +.RB \` \- ' +), i risultati sono inviati allo "standard output". +.PP +Si noti che la scansione dei caratteri è "pigra", e non controlla oltre +la prima lettera dell'opzione, a meno che l'opzione sia seguita da un +parametro. +Gli spazi fra una singola lettera di opzione e il corrispondente parametro +dopo di essa sono facoltativi. +I parametri delle opzioni possono essere specificati usando la notazione +decimale, esadecimale oppure ottale. +Pertanto +.BR \-c8 , +.BR "\-c 8" , +.B \-c 010 +e +.B \-cols 8 +sono notazioni equivalenti fra loro. +.PP +.TP +.IR \-a " | " \-autoskip +Richiesta di autoskip: Un singolo '*' rimpiazza linee di zeri binari. +Valore di default: off. +.TP +.IR \-b " | " \-bits +Richiesta di una immagine binaria (cifre binarie), invece che esadecimale. +Questa opzione scrive un byte come otto cifre "1" e "0" invece di usare i +numeri esadecimali. Ogni linea è preceduta da un indirizzo in esadecimale e +seguita da una decodifica ascii (o ebcdic). Le opzioni specificabili dalla +linea comando \-r, \-p, \-i non funzionano in questo modo. +.TP +.IR "\-c colonne " | " \-cols colonne" +.IR "\-c colonne " | " \-cols colonne" +In ogni linea sono formattate +.RI < colonne > +colonne. Valore di default 16 (\-i: 12, \-ps: 30, \-b: 6). +Valore massimo 256. +.TP +.IR \-E " | " \-EBCDIC +Cambia la codifica della colonna di destra da ASCII a EBCDIC. +Questo non modifica la rappresentazione esadecimale. Non ha senso +specificare questa opzione in combinazione con \-r, \-p o \-i. +.TP +.IR "\-g numero_byte " | " \-groupsize numero_byte" +Inserisci ogni +.RI < numero_byte > +byte di output (di due caratteri esadecimali o otto numeri binari ognuno) +uno spazio bianco. +Specificando +.I \-g 0 +i byte di output non sono separati da alcuno spazio. +.RI < numero_byte > ha come valore di default " 2 +in modalità normale [esadecimale] e \fI1\fP in modalità binaria. +Il raggruppamento non si applica agli stili "PostScript" e "include". +.TP +.IR \-h " | " \-help +stampa un sommario dei comandi disponibili ed esce. Non viene fatto +null'altro. +.TP +.IR \-i " | " \-include +L'output è nello stile dei file "include" in C. Viene preparata la +definizione completa di un "array" [vettore], dandogli il nome del +file di input), tranne che nel caso in cui xxd legga dallo "standard input". +.TP +.IR "\-l numero " | " \-len numero" +Il programma esce dopo aver scritto +.RI < numero > +byte. +.TP +.IR \-p " | " \-ps " | " \-postscript " | " \-plain +L'output è nello stile di un dump continuo sotto postscript. +Noto anche come stile esadecimale semplice [plain]. +.TP +.IR \-r " | " \-revert +ricostruzione: converte (o mette una patch) a partire dall'immagine +esadecimale, creando [o modificando] il file binario. +Se non diretto allo "standard output", xxd scrive nel suo file di output +in maniera continua, senza interruzioni. Usare la combinazione +.I \-r \-p +per leggere dump in stile esadecimale semplice [plain], senza l'informazione +di numero di linea e senza un particolare tracciato di colonna. Degli spazi +o delle linee vuote possono essere inserite a piacere [e vengono ignorate]. +.TP +.I \-seek distanza +Usato con l'opzione +.IR \-r : +(ricostruzione), +.RI < distanza > +viene aggiunta alla posizione nel file trovata nella immagine +esadecimale. +.TP +.I \-s [+][\-]seek +Inizia a +.RI < seek > +byte assoluti (o relativi) di distanza all'interno di input_file. +\fI+ \fRindica che il "seek" è relativo alla posizione corrente nel file +"standard input" (non significativa quando non si legge da "standard input"). +\fI\- \fRindica che il "seek" dovrebbe posizionarsi ad quel numero di +caratteri dalla fine dell'input (o se in combinazione con +\fI+ \fR: prime della posizione corrente nel file "standard input"). +Se non si specifica una opzione \-s, xxd inizia alla posizione +corrente all'interno del file. +.TP +.I \-u +usa lettere esadecimali maiuscole. Il valore di default è di usare +lettere minuscole. +.TP +.IR \-v " | " \-version +visualizza la stringa contenente la versione del programma. +.SH ATTENZIONE +.PP +.I xxd \-r +è capace di operare "magie" nell'utilizzare l'informazione "numero di linea". +Se sul file di output ci si può posizionare usando la "seek", il numero di +linea all'inizio di ogni riga esadecimale può essere non ordinato, delle +linee possono mancare delle linee, oppure esserci delle sovrapposizioni. +In simili casi xxd userà lseek(2) per raggiungere la posizione d'inizio. +Se il file di output non consente di usare "seek", sono permessi solo dei +"buchi", che saranno riempiti con zeri binari. +.PP +.I xxd \-r +non genera mai errori di specifica parametri. I parametri non riconosciuti +sono silenziosamente ignorati. +.PP +Nel modificare immagini esadecimali, tenete conto che +.I xxd \-r +salta il resto della linea, dopo aver letto abbastanza caratteri contenenti +dati esadecimali (vedere opzione \-c). Ciò implica pure che le modifiche alle +colonne di caratteri stampabili ascii (o ebcdic) sono sempre ignorate. +La ricostruzione da un file immagine esadecimale in stile semplice +(postscript) con xxd \-r \-p non dipende dal numero corretto di colonne. +IN questo caso, qualsiasi cosa assomigli a una coppia di cifre esadecimali +è interpretata [e utilizzata]. +.PP +Notare la differenza fra +.br +\fI% xxd \-i file\fR +.br +e +.br +\fI% xxd \-i \< file\fR +.PP +.I xxd \-s \+seek +può comportarsi in modo diverso da +.IR "xxd \-s seek" +, perché lseek(2) è usata per tornare indietro nel file di input. Il '+' +fa differenza se il file di input è lo "standard input", e se la posizione nel +file di "standard input" non è all'inizio del file quando xxd è eseguito, +con questo input. +I seguenti esempi possono contribuire a chiarire il concetto +(o ad oscurarlo!)... +.PP +Riavvolge lo "standard input" prima di leggere; necessario perché `cat' +ha già letto lo stesso file ["file"] fino alla fine dello "standard input". +.br +\fI% sh \-c 'cat > copia_normale; xxd \-s 0 > copia_esadecimale' < file +.PP +Stampa immagine esadecimale dalla posizione file 0x480 (=1024+128) in poi. +Il segno `+' vuol dire "rispetto alla posizione corrente", quindi il `128' +si aggiunge a 1k (1024) dove `dd' si era fermato. +.br +\fI% sh \-c 'dd of=normale bs=1k count=1; xxd \-s +128 > esadecimale' < file +.PP +Immagine esadecimale dalla posizione 0x100 ( = 1024\-768 ) del file in avanti. +.br +\fI% sh \-c 'dd of=normale bs=1k count=1; xxd \-s +\-768 > esadecimale' < file +.PP +Comunque, questo capita raramente, e l'uso del `+' non serve quasi mai. +L'autore preferisce monitorare il comportamento di xxd con strace(1) o +truss(1), quando si usa l'opzione \-s. +.SH ESEMPI +.PP +.br +Stampa tutto tranne le prime tre linee (0x30 byte esadecimali) di +.B file +\. +.br +\fI% xxd \-s 0x30 file +.PP +.br +Stampa 3 linee (0x30 byte esadecimali) alla fine di +.B file +\. +.br +\fI% xxd \-s \-0x30 file +.PP +.br +Stampa 120 byte come immagine esadecimale continua con 20 byte per linea. +.br +\fI% xxd \-l 120 \-ps \-c 20 xxd.1\fR + +.br +2e54482058584420312022417567757374203139 +.br +39362220224d616e75616c207061676520666f72 +.br +20787864220a2e5c220a2e5c222032317374204d +.br +617920313939360a2e5c22204d616e2070616765 +.br +20617574686f723a0a2e5c2220202020546f6e79 +.br +204e7567656e74203c746f6e79407363746e7567 +.br + +.br +Stampa i primi 120 byte della pagina di manuale vim.1 a 12 byte per linea. +.br +\fI% xxd \-l 120 \-c 12 xxd.1\fR + + +.br +0000000: 2e54 4820 5858 4420 3120 2241 .TH XXD 1 "A +.br +000000c: 7567 7573 7420 3139 3936 2220 ugust 1996" +.br +0000018: 224d 616e 7561 6c20 7061 6765 "Manual page +.br +0000024: 2066 6f72 2078 7864 220a 2e5c for xxd"..\ +.br +0000030: 220a 2e5c 2220 3231 7374 204d "..\" 21st M +.br +000003c: 6179 2031 3939 360a 2e5c 2220 ay 1996..\" +.br +0000048: 4d61 6e20 7061 6765 2061 7574 Man page aut +.br +0000054: 686f 723a 0a2e 5c22 2020 2020 hor:..\" +.br +0000060: 546f 6e79 204e 7567 656e 7420 Tony Nugent +.br +000006c: 3c74 6f6e 7940 7363 746e 7567 <tony@sctnug +.PP +.br +Visualizza la data dal file xxd.1 +.br +\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR +.br +0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 +.PP +.br +Copiare +.B input_file +su +.B output_file +premettendogli 100 byte a 0x00. +.br +\fI% xxd input_file | xxd \-r \-s 100 \> output_file\fR +.br + +.br +Modificare (patch) la data nel file xxd.1 +.br +\fI% echo '0000037: 3574 68' | xxd \-r \- xxd.1\fR +.br +\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR +.br +0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 +.PP +.br +Creare un file di 65537 byte tutto a 0x00, +tranne che l'ultimo carattere che è una 'A' (esadecimale 0x41). +.br +\fI% echo '010000: 41' | xxd \-r \> file\fR +.PP +.br +Stampa una immagine esadecimale del file di cui sopra con opzione autoskip. +.br +\fI% xxd \-a \-c 12 file\fR +.br +0000000: 0000 0000 0000 0000 0000 0000 ............ +.br +* +.br +000fffc: 0000 0000 40 ....A +.PP +Crea un file di 1 byte che contiene il solo carattere 'A'. +Il numero dopo '\-r \-s' viene aggiunto a quello trovato nel file; +in pratica, i byte precedenti non sono stampati. +.br +\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> file\fR +.PP +Usa xxd come filtro all'interno di un editor come +.B vim(1) +per ottenere una immagine esadecimale di una parte di file +delimitata dai marcatori `a' e `z'. +.br +\fI:'a,'z!xxd\fR +.PP +Usare xxd come filtro all'interno di un editor come +.B vim(1) +per ricostruire un pezzo di file binario da una immagine esadecimale +delimitata dai marcatori `a' e `z'. +.br +\fI:'a,'z!xxd \-r\fR +.PP +Usare xxd come filtro all'interno di un editor come +.B vim(1) +per ricostruire una sola linea di file binario da una immagine esadecimale, +Portare il cursore sopra la linea e battere: +.br +\fI!!xxd \-r\fR +.PP +Per leggere singoli caratteri da una linea seriale +.br +\fI% xxd \-c1 < /dev/term/b &\fR +.br +\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR +.br +\fI% echo \-n foo > /dev/term/b\fR +.PP +.SH CODICI DI RITORNO +Il programma può restituire questi codici di errore: +.TP +0 +nessun errore rilevato. +.TP +\-1 +operazione non supportata ( +.I xxd \-r \-i +non ancora possible). +.TP +1 +errore durante la scansione parametri. +.TP +2 +problemi con il file di input. +.TP +3 +problemi con il file di output. +.TP +4,5 +posizione "seek" specificata non raggiungibile all'interno del file. +.SH VEDERE ANCHE +uuencode(1), uudecode(1), patch(1) +.br +.SH AVVERTIMENTI +La stranezza dello strumento rispecchia la mente del suo creatore. +Usate a vostro rischio e pericolo. Copiate i file. Tracciate l'esecuzione. +Diventate un mago. +.br +.SH VERSIONE +Questa pagina di manuale documenta la versione 1.7 di xxd. +.SH AUTORE +.br +(c) 1990-1997 Juergen Weigert +.br +<jnweiger@informatik.uni\-erlangen.de> +.LP +Distribuite liberamente ed attribuitemi il credito, +.br +fate soldi e condivideteli con me +.br +perdete soldi e non venite a chiederli a me. +.PP +Pagina di manuale messa in piedi da Tony Nugent +.br +<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.br +Piccole modifiche di Bram Moolenaar. +Modificato da Juergen Weigert. +.PP diff --git a/share/vim/vim73/doc/xxd-it.UTF-8.1 b/share/vim/vim73/doc/xxd-it.UTF-8.1 new file mode 100644 index 0000000000..b6ccabd2e3 --- /dev/null +++ b/share/vim/vim73/doc/xxd-it.UTF-8.1 @@ -0,0 +1,402 @@ +.TH XXD 1 "Agosto 1996" "Pagina di manuale per xxd" +.\" +.\" 21 Maggio 1996 +.\" Autore della pagina di manuale: +.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.\" Modificato da Bram Moolenaar <Bram@vim.org> +.SH NOME +.I xxd +\- Produce esadecimale da un file binario o viceversa. +.SH SINTASSI +.B xxd +\-h[elp] +.br +.B xxd +[opzioni] [input_file [output_file]] +.br +.B xxd +\-r[evert] [opzioni] [input_file [output_file]] +.SH DESCRIZIONE +.I xxd +crea un'immagine esadecimale di un dato file o dello "standard input". +Può anche ottenere da un'immagine esadecimale il file binario originale. +Come +.BR uuencode (1) +e +.BR uudecode (1) +permette di trasmettere dati binari in una rappresentazione ASCII "a prova +di email", ma ha anche il vantaggio di poter decodificare sullo "standard +output". Inoltre, può essere usato per effettuare delle modifiche (patch) +a file binari. +.SH OPZIONI +Se non si specifica un +.I input_file +il programma legge dallo "standard input". +Se +.I input_file +è specificato come il carattere +.RB \` \- ' +, l'input è letto dallo "standard input". +Se non si specifica un +.I output_file +(o si mette al suo posto il carattere +.RB \` \- ' +), i risultati sono inviati allo "standard output". +.PP +Si noti che la scansione dei caratteri è "pigra", e non controlla oltre +la prima lettera dell'opzione, a meno che l'opzione sia seguita da un +parametro. +Gli spazi fra una singola lettera di opzione e il corrispondente parametro +dopo di essa sono facoltativi. +I parametri delle opzioni possono essere specificati usando la notazione +decimale, esadecimale oppure ottale. +Pertanto +.BR \-c8 , +.BR "\-c 8" , +.B \-c 010 +e +.B \-cols 8 +sono notazioni equivalenti fra loro. +.PP +.TP +.IR \-a " | " \-autoskip +Richiesta di autoskip: Un singolo '*' rimpiazza linee di zeri binari. +Valore di default: off. +.TP +.IR \-b " | " \-bits +Richiesta di una immagine binaria (cifre binarie), invece che esadecimale. +Questa opzione scrive un byte come otto cifre "1" e "0" invece di usare i +numeri esadecimali. Ogni linea è preceduta da un indirizzo in esadecimale e +seguita da una decodifica ascii (o ebcdic). Le opzioni specificabili dalla +linea comando \-r, \-p, \-i non funzionano in questo modo. +.TP +.IR "\-c colonne " | " \-cols colonne" +.IR "\-c colonne " | " \-cols colonne" +In ogni linea sono formattate +.RI < colonne > +colonne. Valore di default 16 (\-i: 12, \-ps: 30, \-b: 6). +Valore massimo 256. +.TP +.IR \-E " | " \-EBCDIC +Cambia la codifica della colonna di destra da ASCII a EBCDIC. +Questo non modifica la rappresentazione esadecimale. Non ha senso +specificare questa opzione in combinazione con \-r, \-p o \-i. +.TP +.IR "\-g numero_byte " | " \-groupsize numero_byte" +Inserisci ogni +.RI < numero_byte > +byte di output (di due caratteri esadecimali o otto numeri binari ognuno) +uno spazio bianco. +Specificando +.I \-g 0 +i byte di output non sono separati da alcuno spazio. +.RI < numero_byte > ha come valore di default " 2 +in modalità normale [esadecimale] e \fI1\fP in modalità binaria. +Il raggruppamento non si applica agli stili "PostScript" e "include". +.TP +.IR \-h " | " \-help +stampa un sommario dei comandi disponibili ed esce. Non viene fatto +null'altro. +.TP +.IR \-i " | " \-include +L'output è nello stile dei file "include" in C. Viene preparata la +definizione completa di un "array" [vettore], dandogli il nome del +file di input), tranne che nel caso in cui xxd legga dallo "standard input". +.TP +.IR "\-l numero " | " \-len numero" +Il programma esce dopo aver scritto +.RI < numero > +byte. +.TP +.IR \-p " | " \-ps " | " \-postscript " | " \-plain +L'output è nello stile di un dump continuo sotto postscript. +Noto anche come stile esadecimale semplice [plain]. +.TP +.IR \-r " | " \-revert +ricostruzione: converte (o mette una patch) a partire dall'immagine +esadecimale, creando [o modificando] il file binario. +Se non diretto allo "standard output", xxd scrive nel suo file di output +in maniera continua, senza interruzioni. Usare la combinazione +.I \-r \-p +per leggere dump in stile esadecimale semplice [plain], senza l'informazione +di numero di linea e senza un particolare tracciato di colonna. Degli spazi +o delle linee vuote possono essere inserite a piacere [e vengono ignorate]. +.TP +.I \-seek distanza +Usato con l'opzione +.IR \-r : +(ricostruzione), +.RI < distanza > +viene aggiunta alla posizione nel file trovata nella immagine +esadecimale. +.TP +.I \-s [+][\-]seek +Inizia a +.RI < seek > +byte assoluti (o relativi) di distanza all'interno di input_file. +\fI+ \fRindica che il "seek" è relativo alla posizione corrente nel file +"standard input" (non significativa quando non si legge da "standard input"). +\fI\- \fRindica che il "seek" dovrebbe posizionarsi ad quel numero di +caratteri dalla fine dell'input (o se in combinazione con +\fI+ \fR: prime della posizione corrente nel file "standard input"). +Se non si specifica una opzione \-s, xxd inizia alla posizione +corrente all'interno del file. +.TP +.I \-u +usa lettere esadecimali maiuscole. Il valore di default è di usare +lettere minuscole. +.TP +.IR \-v " | " \-version +visualizza la stringa contenente la versione del programma. +.SH ATTENZIONE +.PP +.I xxd \-r +è capace di operare "magie" nell'utilizzare l'informazione "numero di linea". +Se sul file di output ci si può posizionare usando la "seek", il numero di +linea all'inizio di ogni riga esadecimale può essere non ordinato, delle +linee possono mancare delle linee, oppure esserci delle sovrapposizioni. +In simili casi xxd userà lseek(2) per raggiungere la posizione d'inizio. +Se il file di output non consente di usare "seek", sono permessi solo dei +"buchi", che saranno riempiti con zeri binari. +.PP +.I xxd \-r +non genera mai errori di specifica parametri. I parametri non riconosciuti +sono silenziosamente ignorati. +.PP +Nel modificare immagini esadecimali, tenete conto che +.I xxd \-r +salta il resto della linea, dopo aver letto abbastanza caratteri contenenti +dati esadecimali (vedere opzione \-c). Ciò implica pure che le modifiche alle +colonne di caratteri stampabili ascii (o ebcdic) sono sempre ignorate. +La ricostruzione da un file immagine esadecimale in stile semplice +(postscript) con xxd \-r \-p non dipende dal numero corretto di colonne. +IN questo caso, qualsiasi cosa assomigli a una coppia di cifre esadecimali +è interpretata [e utilizzata]. +.PP +Notare la differenza fra +.br +\fI% xxd \-i file\fR +.br +e +.br +\fI% xxd \-i \< file\fR +.PP +.I xxd \-s \+seek +può comportarsi in modo diverso da +.IR "xxd \-s seek" +, perché lseek(2) è usata per tornare indietro nel file di input. Il '+' +fa differenza se il file di input è lo "standard input", e se la posizione nel +file di "standard input" non è all'inizio del file quando xxd è eseguito, +con questo input. +I seguenti esempi possono contribuire a chiarire il concetto +(o ad oscurarlo!)... +.PP +Riavvolge lo "standard input" prima di leggere; necessario perché `cat' +ha già letto lo stesso file ["file"] fino alla fine dello "standard input". +.br +\fI% sh \-c 'cat > copia_normale; xxd \-s 0 > copia_esadecimale' < file +.PP +Stampa immagine esadecimale dalla posizione file 0x480 (=1024+128) in poi. +Il segno `+' vuol dire "rispetto alla posizione corrente", quindi il `128' +si aggiunge a 1k (1024) dove `dd' si era fermato. +.br +\fI% sh \-c 'dd of=normale bs=1k count=1; xxd \-s +128 > esadecimale' < file +.PP +Immagine esadecimale dalla posizione 0x100 ( = 1024\-768 ) del file in avanti. +.br +\fI% sh \-c 'dd of=normale bs=1k count=1; xxd \-s +\-768 > esadecimale' < file +.PP +Comunque, questo capita raramente, e l'uso del `+' non serve quasi mai. +L'autore preferisce monitorare il comportamento di xxd con strace(1) o +truss(1), quando si usa l'opzione \-s. +.SH ESEMPI +.PP +.br +Stampa tutto tranne le prime tre linee (0x30 byte esadecimali) di +.B file +\. +.br +\fI% xxd \-s 0x30 file +.PP +.br +Stampa 3 linee (0x30 byte esadecimali) alla fine di +.B file +\. +.br +\fI% xxd \-s \-0x30 file +.PP +.br +Stampa 120 byte come immagine esadecimale continua con 20 byte per linea. +.br +\fI% xxd \-l 120 \-ps \-c 20 xxd.1\fR + +.br +2e54482058584420312022417567757374203139 +.br +39362220224d616e75616c207061676520666f72 +.br +20787864220a2e5c220a2e5c222032317374204d +.br +617920313939360a2e5c22204d616e2070616765 +.br +20617574686f723a0a2e5c2220202020546f6e79 +.br +204e7567656e74203c746f6e79407363746e7567 +.br + +.br +Stampa i primi 120 byte della pagina di manuale vim.1 a 12 byte per linea. +.br +\fI% xxd \-l 120 \-c 12 xxd.1\fR + + +.br +0000000: 2e54 4820 5858 4420 3120 2241 .TH XXD 1 "A +.br +000000c: 7567 7573 7420 3139 3936 2220 ugust 1996" +.br +0000018: 224d 616e 7561 6c20 7061 6765 "Manual page +.br +0000024: 2066 6f72 2078 7864 220a 2e5c for xxd"..\ +.br +0000030: 220a 2e5c 2220 3231 7374 204d "..\" 21st M +.br +000003c: 6179 2031 3939 360a 2e5c 2220 ay 1996..\" +.br +0000048: 4d61 6e20 7061 6765 2061 7574 Man page aut +.br +0000054: 686f 723a 0a2e 5c22 2020 2020 hor:..\" +.br +0000060: 546f 6e79 204e 7567 656e 7420 Tony Nugent +.br +000006c: 3c74 6f6e 7940 7363 746e 7567 <tony@sctnug +.PP +.br +Visualizza la data dal file xxd.1 +.br +\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR +.br +0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 +.PP +.br +Copiare +.B input_file +su +.B output_file +premettendogli 100 byte a 0x00. +.br +\fI% xxd input_file | xxd \-r \-s 100 \> output_file\fR +.br + +.br +Modificare (patch) la data nel file xxd.1 +.br +\fI% echo '0000037: 3574 68' | xxd \-r \- xxd.1\fR +.br +\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR +.br +0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 +.PP +.br +Creare un file di 65537 byte tutto a 0x00, +tranne che l'ultimo carattere che è una 'A' (esadecimale 0x41). +.br +\fI% echo '010000: 41' | xxd \-r \> file\fR +.PP +.br +Stampa una immagine esadecimale del file di cui sopra con opzione autoskip. +.br +\fI% xxd \-a \-c 12 file\fR +.br +0000000: 0000 0000 0000 0000 0000 0000 ............ +.br +* +.br +000fffc: 0000 0000 40 ....A +.PP +Crea un file di 1 byte che contiene il solo carattere 'A'. +Il numero dopo '\-r \-s' viene aggiunto a quello trovato nel file; +in pratica, i byte precedenti non sono stampati. +.br +\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> file\fR +.PP +Usa xxd come filtro all'interno di un editor come +.B vim(1) +per ottenere una immagine esadecimale di una parte di file +delimitata dai marcatori `a' e `z'. +.br +\fI:'a,'z!xxd\fR +.PP +Usare xxd come filtro all'interno di un editor come +.B vim(1) +per ricostruire un pezzo di file binario da una immagine esadecimale +delimitata dai marcatori `a' e `z'. +.br +\fI:'a,'z!xxd \-r\fR +.PP +Usare xxd come filtro all'interno di un editor come +.B vim(1) +per ricostruire una sola linea di file binario da una immagine esadecimale, +Portare il cursore sopra la linea e battere: +.br +\fI!!xxd \-r\fR +.PP +Per leggere singoli caratteri da una linea seriale +.br +\fI% xxd \-c1 < /dev/term/b &\fR +.br +\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR +.br +\fI% echo \-n foo > /dev/term/b\fR +.PP +.SH CODICI DI RITORNO +Il programma può restituire questi codici di errore: +.TP +0 +nessun errore rilevato. +.TP +\-1 +operazione non supportata ( +.I xxd \-r \-i +non ancora possible). +.TP +1 +errore durante la scansione parametri. +.TP +2 +problemi con il file di input. +.TP +3 +problemi con il file di output. +.TP +4,5 +posizione "seek" specificata non raggiungibile all'interno del file. +.SH VEDERE ANCHE +uuencode(1), uudecode(1), patch(1) +.br +.SH AVVERTIMENTI +La stranezza dello strumento rispecchia la mente del suo creatore. +Usate a vostro rischio e pericolo. Copiate i file. Tracciate l'esecuzione. +Diventate un mago. +.br +.SH VERSIONE +Questa pagina di manuale documenta la versione 1.7 di xxd. +.SH AUTORE +.br +(c) 1990-1997 Juergen Weigert +.br +<jnweiger@informatik.uni\-erlangen.de> +.LP +Distribuite liberamente ed attribuitemi il credito, +.br +fate soldi e condivideteli con me +.br +perdete soldi e non venite a chiederli a me. +.PP +Pagina di manuale messa in piedi da Tony Nugent +.br +<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.br +Piccole modifiche di Bram Moolenaar. +Modificato da Juergen Weigert. +.PP diff --git a/share/vim/vim73/doc/xxd-pl.1 b/share/vim/vim73/doc/xxd-pl.1 new file mode 100644 index 0000000000..d9fa9be203 --- /dev/null +++ b/share/vim/vim73/doc/xxd-pl.1 @@ -0,0 +1,389 @@ +.TH XXD 1 "Sierpieñ 1996" "Strona podrêcznika dla xxd" +.\" +.\" 21st May 1996 +.\" Man page author: +.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.\" Changes by Bram Moolenaar <Bram@vim.org> +.SH NAZWA +.I xxd +\- zrzut pliku do hex lub odwrotnie +.SH SYNOPSIS +.B xxd +\-h[elp] +.br +.B xxd +[opcje] [plik_we [plik_wy]] +.br +.B xxd +\-r[evert] [opcje] [plik_we [plik_wy]] +.SH OPIS +.I xxd +tworzy zrzut heksowy podanego pliku lub standardowego wej¶cia. +Mo¿e tak¿e przetworzyæ zrzut heksowy z powrotem do oryginalnej, +binarnej formy. +Podobnie jak +.BR uuencode (1) +i +.BR uudecode (1) +pozwala na przekazanie danych binarnych w bezpiecznej w poczcie formie +ASCII, ale ma zalety dekodowania na standardowe wyj¶cie. +Ponadto mo¿na go u¿yæ do binarnego ³atania plików. +.SH OPCJE +Je¶li nie podano +.I plik_we +xxd czyta ze standardowego wej¶cia. +Je¶li okre¶lono +.I plik_we +jako znak +.RB \` \- ' +wtedy dane wej¶ciowe czytane s± ze standardowego wej¶cia. +Je¶li nie podano +.I plik_wy +(lub podano jako +.RB \` \- ' +), wyniki s± wysy³ane na standardowe wyj¶cie. +.PP +Pamiêtaj, ¿e u¿yty zosta³ "leniwy" parser, który nie sprawdza wiêcej +ni¿ pierwszej litery opcji (o ile ta nie zosta³a obdarzona +parametrem). Spacje miêdzy jedno literowymi opcjami i ich parametrami +s± opcjonalne. Parametry opcji mog± byæ okre¶lone w notacji dziesiêtnej, +heksadecymalej lub oktalnej. +St±d +.BR \-c8 , +.BR "\-c 8" , +.B \-c 010 +i +.B \-cols 8 +s± sobie równowa¿ne. +.PP +.TP +.IR \-a " | " \-autoskip +prze³±cza autoskip: pojedyncza '*' zastêpuje linie nul. Domy¶lnie +wy³±czone. +.TP +.IR \-b " | " \-bits +Prze³±cza do zrzutu bitowego (cyfr binarnych) zamiast heksowego. +Opcja ta zapisuje oktety jako osiem cyfr 1 lub 0 zamiast normalnego +zrzutu heksowego. Ka¿da linia jest poprzedzona przez +heksadecymalny numer linii a po nim jego reprezentacj± w ascii (lub +ebcdic). Opcje linii poleceñ \-r, \-p, \-i nie dzia³aj± w tym +trybie. +.TP +.IR "\-c cols " | " \-cols cols" +formatuje liczbê +.RI < cols > +oktetów na wiersz. Domy¶lnie 16 (\-i: 12, \-ps: 30, \-b: 6). Maks. +256. +.TP +.IR \-E " | "\-EBCDIC +zmienia kodowanie znaków w prawej kolumnie z ASCII na EBCDIC. +Nie zmienia prezentacji heksadecymalej. Opcja nie dzia³a w po³±czeniu +z \-r, \-p lub \-i. +.TP +.IR "\-g bajtów " | " \-groupsize bajtów" +oddziela wyj¶cie ka¿dych +.RI < bajtów > +bajtów (dwa heksowe znaki lub osiem cyfr binarnych ka¿de) przez bia³y +znak. +Okre¶l +.I \-g 0 +by wy³±czyæ grupowanie. +.RI < Bajtów "> domy¶lnie jest " 2 +w trybie normalnym i \fI1\fP w trybie bitów. +Grupowanie nie dzia³a w trybie postscriptu lub w³±czania. +.TP +.IR \-h " | " \-help +wypisuje podsumowanie dostêpnych poleceñ i koñczy dzia³anie. Nie +zostaje przeprowadzony ¿aden zrzut. +.TP +.IR \-i " | " \-include +wyj¶cie w stylu w³±czania pliku w C. Zostaje zapisana kompletna +statyczna tablica definicji (nazwana wed³ug pliku wej¶cia), o ile xxd +nie czyta ze standardowego wej¶cia. +.TP +.IR "\-l len " | "\-len len" +zakoñcz po wypisaniu +.RI < len > +oktetów. +.TP +.IR \-p " | " \-ps " | " \-postscript " | " \-plain +wyj¶cie w postcriptowym ci±g³ym stylu zrzutu heksowego. Znany tak¿e +jako zwyk³y zrzut heksowy. +.TP +.IR \-r " | " \-revert +odwróæ operacjê: przekonwertuj (lub za³ataj) zrzut heksowy w binarkê. +Je¶li nie zapisuje na standardowe wyj¶cie, xxd zapisze plik wyj¶ciowy +bez obcinania go. U¿yj kombinacji +.I \-r \-p +by odczytaæ zwyk³y zrzut heksadecymalny bez numerów linii +i okre¶lonego uk³adu kolumn. Dodatkowe bia³e znaki i ³amanie wierszy +s± wszêdzie dozwolone. +.TP +.I \-seek offset +Kiedy u¿yty po +.IR \-r : +odwraca z +.RI < offset > +dodanym do pozycji w pliku odnalezionym w zrzucie heksowym. +.TP +.I \-s [+][\-]seek +zaczyna na +.RI < seek > +bajtów bezwglêdnego (lub wzglêdnego) offsetu pliku wej¶ciowego. +\fI+ \fRwskazuje, ¿e seek jest wzglêdne do bie¿±cej pozycji pliku (bez +znaczenia je¶li nie wczytuje ze standardowego wej¶cia). \fI\- \fRwskazuje +¿e seek powinno byæ o tyle znaków od koñca wej¶cia (lub je¶li +po³±czone z \fI+\fR: przed bie¿±c± pozycj± pliku na standardowym +wej¶ciu). +Bez opcji \-s xxd zaczyna od bie¿±cej pozycji w pliku. +.TP +.I \-u +u¿yj wielkich liter w znakach heksowych. Domy¶lnie s± ma³e znaki. +.TP +.IR \-v " | " \-version +pokazuje wersjê programu. +.SH OSTRZE¯ENIA +.PP +.I xxd \-r +potrafi okre¶liæ numery linii. Je¶li plik wyj¶cia jest mo¿liwy do +przeszukania wtedy numery linii na pocz±tku wiersza zrzutu heksowego +mog± byæ nie po kolei, mo¿e brakowaæ wierszy lub nak³adaæ siê na +siebie. W takich wypadkach xxd u¿yje lseek(2) by znale¼æ nastêpn± +pozycjê. Je¶li plik wyj¶ciowy nie jest mo¿liwy do przeszukania mo¿liwe +s± tylko przerwy, które zostan± wype³nione bajtami null. +.PP +.I xxd \-r +nigdy nie podaje b³êdów analizy. ¦mieci s± po cichu ignorowane. +.PP +W czasie edycji zrzutów heksowych, proszê zauwa¿yæ ¿e +.I xxd \-r +pomija wszystko w linii wej¶cia po odczytaniu wystarczaj±cej ilo¶ci +kolumn danych heksadecymalnych (zobacz opcjê \-c). Oznacza to tak¿e, +¿e zmiany w drukowanych kolumnach ascii (lub ebcdic) s± zawsze +ignorowane. Odwrócenie zwyk³ego (lub postscriptowego) stylu zrzutu +poprzez xxd \-r \-p nie zale¿y od kolejno¶ci kolumn. Tutaj cokolwiek +co wygl±da jak para znaków heks jest interpretowane. +.PP +Zauwa¿ ró¿nicê miêdzy +.br +\fI% xxd \-i plik\fR +.br +i +.br +\fI% xxd \-i < plik\fR +.PP +.I xxd \-s \+seek +mo¿e byæ ró¿ne od +.IR "xxd \-s seek" , +poniewa¿ lseek(2) jest u¿yty do "przewiniêcie" wej¶cia. '+' stanowi +ró¿nicê je¶li ¼ród³em wej¶cia jest standardowe wej¶cie i je¶li pozycja +w pliku ze standardowego wej¶cia nie jest pocz±tkiem pliku w chwili +uruchomienia xxd. Nastêpuj±ce przyk³ady mog± wyja¶niæ (lub bardziej +zmyliæ!)... +.PP +Przewiñ standardowe wej¶cie przed przeczytaniem; potrzebne poniewa¿ +`cat' ju¿ odczyta³ do koñca standardowego wej¶cia. +.br +\fI% sh \-c 'cat > zwyk³a_kopia; xxd \-s 0 > hex_kopia' < plik\fR +.PP +Zrzut heksowy od pozycji pliku 0x480 (=1024+128) w przód. +Znak `+' oznacza "wzglêdny wobec bie¿±cej pozycji", st±d `128' dodaje +do 1k gdzie zakoñczy³ dd. +.br +\fI% sh \-c 'dd of=plain_snippet bs=1k count=1; xxd \-s +128 > hex_snippet' < file\fR +.PP +Zrzut heksowy od pozycji pliku 0x100 ( = 1024\-768) dalej. +.br +\fI% sh \-c 'dd of=plain_snippet bs=1k count=1; xxd \-s +-768 > hex_snippet' < file\fR +.PP +Jakkolwiek, jest to rzadka sytuacja i u¿ycie `+' jest rzadko +potrzebne. +Autor woli monitorowaæ dzia³anie xxd przy pomocy strace(1) lub truss(1) kiedy \-s jest u¿yte. +.SH PRZYK£ADY +.PP +.br +Wypisz wszystko z wyj±tkiem pierwszych trzech linii (heksowe 0x30 bajtów) +.B pliku +\. +.br +\fI% xxd \-s 0x30 plik\fR +.PP +.br +Wypisz trzy linie (heksowe 0x30 bajtów) z koñca +.B pliku +\. +.br +\fI% xxd \-s \-0x30 plik\fR +.PP +.br +Wypisz 120 bajtów jako ci±g³y zrzut heksowy z 20 oktetami na liniê. +.br +\fI% xxd \-l 120 \-ps \-c 20 xxd.1\fR +.br +2e54482058584420312022417567757374203139 +.br +39362220224d616e75616c207061676520666f72 +.br +20787864220a2e5c220a2e5c222032317374204d +.br +617920313939360a2e5c22204d616e2070616765 +.br +20617574686f723a0a2e5c2220202020546f6e79 +.br +204e7567656e74203c746f6e79407363746e7567 +.br + +.br +Zrzut heksowy z pierwszymi 120 bajtami tej strony podrêcznika z 12 +oktetami na liniê. +.br +\fI% xxd \-l 120 \-c 12 xxd.1\fR +.br +0000000: 2e54 4820 5858 4420 3120 2241 .TH XXD 1 "A +.br +000000c: 7567 7573 7420 3139 3936 2220 ugust 1996" +.br +0000018: 224d 616e 7561 6c20 7061 6765 "Manual page +.br +0000024: 2066 6f72 2078 7864 220a 2e5c for xxd"..\\ +.br +0000030: 220a 2e5c 2220 3231 7374 204d "..\\" 21st M +.br +000003c: 6179 2031 3939 360a 2e5c 2220 ay 1996..\\" +.br +0000048: 4d61 6e20 7061 6765 2061 7574 Man page aut +.br +0000054: 686f 723a 0a2e 5c22 2020 2020 hor:..\\" +.br +0000060: 546f 6e79 204e 7567 656e 7420 Tony Nugent +.br +000006c: 3c74 6f6e 7940 7363 746e 7567 <tony@sctnug +.PP +.br +Poka¿ tylko datê z pliku xxd.1 +.br +\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR +.br +0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 +.PP +.br +Kopiuj +.B plik_we +do +.B plik_wy +i poprzed¼ 100 bajtami o warto¶ci 0x00. +.br +\fI% xxd plik_we | xxd \-r \-s 100 \> plik_wy\fR +.br + +.br +Podmieñ datê w pliku xxd.1 +.br +\fI% echo '0000037: 3574 68' | xxd \-r \- xxd.1\fR +.br +\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR +.br +0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 +.PP +.br +Utwórz plik o 65537 bajtach, wszystkich równych 0x00, +z wyj±tkiem ostatniego, który ma byæ 'A' (hex 0x41). +.br +\fI% echo '010000: 41' | xxd \-r \> plik\fR +.PP +.br +Zrzut heksowy tego pliku z autoskipem. +.br +\fI% xxd \-a \-c 12 plik\fR +.br +0000000: 0000 0000 0000 0000 0000 0000 ............ +.br +* +.br +000fffc: 0000 0000 40 ....A +.PP +Utwórz jedno bajtowy plik zawieraj±cy pojedncz± literê 'A'. +Liczba po '\-r \-s' dodaje numery linii znalezione w pliku; +w efekcie poprzedzaj±ce bajty s± ukryte. +.br +\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> plik\fR +.PP +U¿yj xxd jako filtra wewn±trz edytora takiego jak +.B vim(1) +aby uzyskaæ zrzut heksowy zakresu miêdzy markerami `a' i `z'. +.br +\fI:'a,'z!xxd\fR +.PP +U¿yj xxd jako filtra wewn±trz edytora takiego jak +.B vim(1) +by odzyskaæ binarny zrzut heksowy zakresu pomiêdzy markerami `a' +i `z'. +.br +\fI:'a,'z!xxd \-r\fR +.PP +U¿yj xxd jako filtra wewn±trz edytora takiego jak +.B vim(1) +by odzyskaæ jedn± liniê zrzutu heksowego. Przejd¼ z kursorem na liniê +i wpisz: +.br +\fI!!xxd \-r\fR +.PP +Odczytaj pojednycze znaki z portu szeregowego +.br +\fI% xxd \-c1 < /dev/term/b &\fR +.br +\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR +.br +\fI% echo \-n foo > /dev/term/b\fR +.PP +.SH "ZWRACANE WARTO¦CI" +Zwracane s± nastêpuj±ce warto¶ci b³êdów: +.TP +0 +nie znaleziono b³êdów. +.TP +\-1 +operacja nie jest wspierana ( +.I xxd \-r \-i +ca³y czas niemo¿liwa). +.TP +1 +b³±d w czasie analizowania opcji. +.TP +2 +problemy z plikiem wej¶ciowym. +.TP +3 +problemy z plikiem wyj¶ciowym. +.TP +4,5 +¿±dana pozycja jest nieosi±galna. +.SH "ZOBACZ TAK¯E" +uuencode(1), uudecode(1), patch(1) +.br +.SH OSTRZE¯ENIA +Dziwaczno¶æ narzêdzi dorównuje dziwaczno¶ci mózgu twórcy. +U¿ywaj wy³±cznie na w³asn± odpowiedzialno¶æ. Kopiuj pliki. Analizuj +je. Stañ siê czarodziejem. +.br +.SH WERSJA +Strona podrêcznika opisuje xxd w wersji 1.7 +.SH AUTOR +.br +(c) 1990-1997 by Juergen Weigert +.br +<jnweiger@informatik.uni-erlangen.de> +.LP +Kopiuj do woli i podaj moje dane, +.br +zarabiaj pieni±dze i dziel siê ze mn±, +.br +traæ pieni±dze i nie miej do mnie pretensji. +.PP +Strona podrêcznika zapocz±tkowana przez Tony'ego Nugenta +.br +<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.br +Ma³e zmiany: Bram Moolenaar. +Redakcja: Juergen Weigert. +.PP diff --git a/share/vim/vim73/doc/xxd-pl.UTF-8.1 b/share/vim/vim73/doc/xxd-pl.UTF-8.1 new file mode 100644 index 0000000000..e63ce64b74 --- /dev/null +++ b/share/vim/vim73/doc/xxd-pl.UTF-8.1 @@ -0,0 +1,389 @@ +.TH XXD 1 "Sierpień 1996" "Strona podręcznika dla xxd" +.\" +.\" 21st May 1996 +.\" Man page author: +.\" Tony Nugent <tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.\" Changes by Bram Moolenaar <Bram@vim.org> +.SH NAZWA +.I xxd +\- zrzut pliku do hex lub odwrotnie +.SH SYNOPSIS +.B xxd +\-h[elp] +.br +.B xxd +[opcje] [plik_we [plik_wy]] +.br +.B xxd +\-r[evert] [opcje] [plik_we [plik_wy]] +.SH OPIS +.I xxd +tworzy zrzut heksowy podanego pliku lub standardowego wejścia. +Może także przetworzyć zrzut heksowy z powrotem do oryginalnej, +binarnej formy. +Podobnie jak +.BR uuencode (1) +i +.BR uudecode (1) +pozwala na przekazanie danych binarnych w bezpiecznej w poczcie formie +ASCII, ale ma zalety dekodowania na standardowe wyjście. +Ponadto można go użyć do binarnego łatania plików. +.SH OPCJE +Jeśli nie podano +.I plik_we +xxd czyta ze standardowego wejścia. +Jeśli określono +.I plik_we +jako znak +.RB \` \- ' +wtedy dane wejściowe czytane są ze standardowego wejścia. +Jeśli nie podano +.I plik_wy +(lub podano jako +.RB \` \- ' +), wyniki są wysyłane na standardowe wyjście. +.PP +Pamiętaj, że użyty został "leniwy" parser, który nie sprawdza więcej +niż pierwszej litery opcji (o ile ta nie została obdarzona +parametrem). Spacje między jedno literowymi opcjami i ich parametrami +są opcjonalne. Parametry opcji mogą być określone w notacji dziesiętnej, +heksadecymalej lub oktalnej. +Stąd +.BR \-c8 , +.BR "\-c 8" , +.B \-c 010 +i +.B \-cols 8 +są sobie równoważne. +.PP +.TP +.IR \-a " | " \-autoskip +przełącza autoskip: pojedyncza '*' zastępuje linie nul. Domyślnie +wyłączone. +.TP +.IR \-b " | " \-bits +Przełącza do zrzutu bitowego (cyfr binarnych) zamiast heksowego. +Opcja ta zapisuje oktety jako osiem cyfr 1 lub 0 zamiast normalnego +zrzutu heksowego. Każda linia jest poprzedzona przez +heksadecymalny numer linii a po nim jego reprezentacją w ascii (lub +ebcdic). Opcje linii poleceń \-r, \-p, \-i nie działają w tym +trybie. +.TP +.IR "\-c cols " | " \-cols cols" +formatuje liczbę +.RI < cols > +oktetów na wiersz. Domyślnie 16 (\-i: 12, \-ps: 30, \-b: 6). Maks. +256. +.TP +.IR \-E " | "\-EBCDIC +zmienia kodowanie znaków w prawej kolumnie z ASCII na EBCDIC. +Nie zmienia prezentacji heksadecymalej. Opcja nie działa w połączeniu +z \-r, \-p lub \-i. +.TP +.IR "\-g bajtów " | " \-groupsize bajtów" +oddziela wyjście każdych +.RI < bajtów > +bajtów (dwa heksowe znaki lub osiem cyfr binarnych każde) przez biały +znak. +Określ +.I \-g 0 +by wyłączyć grupowanie. +.RI < Bajtów "> domyślnie jest " 2 +w trybie normalnym i \fI1\fP w trybie bitów. +Grupowanie nie działa w trybie postscriptu lub włączania. +.TP +.IR \-h " | " \-help +wypisuje podsumowanie dostępnych poleceń i kończy działanie. Nie +zostaje przeprowadzony żaden zrzut. +.TP +.IR \-i " | " \-include +wyjście w stylu włączania pliku w C. Zostaje zapisana kompletna +statyczna tablica definicji (nazwana według pliku wejścia), o ile xxd +nie czyta ze standardowego wejścia. +.TP +.IR "\-l len " | "\-len len" +zakończ po wypisaniu +.RI < len > +oktetów. +.TP +.IR \-p " | " \-ps " | " \-postscript " | " \-plain +wyjście w postcriptowym ciągłym stylu zrzutu heksowego. Znany także +jako zwykły zrzut heksowy. +.TP +.IR \-r " | " \-revert +odwróć operację: przekonwertuj (lub załataj) zrzut heksowy w binarkę. +Jeśli nie zapisuje na standardowe wyjście, xxd zapisze plik wyjściowy +bez obcinania go. Użyj kombinacji +.I \-r \-p +by odczytać zwykły zrzut heksadecymalny bez numerów linii +i określonego układu kolumn. Dodatkowe białe znaki i łamanie wierszy +są wszędzie dozwolone. +.TP +.I \-seek offset +Kiedy użyty po +.IR \-r : +odwraca z +.RI < offset > +dodanym do pozycji w pliku odnalezionym w zrzucie heksowym. +.TP +.I \-s [+][\-]seek +zaczyna na +.RI < seek > +bajtów bezwględnego (lub względnego) offsetu pliku wejściowego. +\fI+ \fRwskazuje, że seek jest względne do bieżącej pozycji pliku (bez +znaczenia jeśli nie wczytuje ze standardowego wejścia). \fI\- \fRwskazuje +że seek powinno być o tyle znaków od końca wejścia (lub jeśli +połączone z \fI+\fR: przed bieżącą pozycją pliku na standardowym +wejściu). +Bez opcji \-s xxd zaczyna od bieżącej pozycji w pliku. +.TP +.I \-u +użyj wielkich liter w znakach heksowych. Domyślnie są małe znaki. +.TP +.IR \-v " | " \-version +pokazuje wersję programu. +.SH OSTRZEŻENIA +.PP +.I xxd \-r +potrafi określić numery linii. Jeśli plik wyjścia jest możliwy do +przeszukania wtedy numery linii na początku wiersza zrzutu heksowego +mogą być nie po kolei, może brakować wierszy lub nakładać się na +siebie. W takich wypadkach xxd użyje lseek(2) by znaleźć następną +pozycję. Jeśli plik wyjściowy nie jest możliwy do przeszukania możliwe +są tylko przerwy, które zostaną wypełnione bajtami null. +.PP +.I xxd \-r +nigdy nie podaje błędów analizy. Śmieci są po cichu ignorowane. +.PP +W czasie edycji zrzutów heksowych, proszę zauważyć że +.I xxd \-r +pomija wszystko w linii wejścia po odczytaniu wystarczającej ilości +kolumn danych heksadecymalnych (zobacz opcję \-c). Oznacza to także, +że zmiany w drukowanych kolumnach ascii (lub ebcdic) są zawsze +ignorowane. Odwrócenie zwykłego (lub postscriptowego) stylu zrzutu +poprzez xxd \-r \-p nie zależy od kolejności kolumn. Tutaj cokolwiek +co wygląda jak para znaków heks jest interpretowane. +.PP +Zauważ różnicę między +.br +\fI% xxd \-i plik\fR +.br +i +.br +\fI% xxd \-i < plik\fR +.PP +.I xxd \-s \+seek +może być różne od +.IR "xxd \-s seek" , +ponieważ lseek(2) jest użyty do "przewinięcie" wejścia. '+' stanowi +różnicę jeśli źródłem wejścia jest standardowe wejście i jeśli pozycja +w pliku ze standardowego wejścia nie jest początkiem pliku w chwili +uruchomienia xxd. Następujące przykłady mogą wyjaśnić (lub bardziej +zmylić!)... +.PP +Przewiń standardowe wejście przed przeczytaniem; potrzebne ponieważ +`cat' już odczytał do końca standardowego wejścia. +.br +\fI% sh \-c 'cat > zwykła_kopia; xxd \-s 0 > hex_kopia' < plik\fR +.PP +Zrzut heksowy od pozycji pliku 0x480 (=1024+128) w przód. +Znak `+' oznacza "względny wobec bieżącej pozycji", stąd `128' dodaje +do 1k gdzie zakończył dd. +.br +\fI% sh \-c 'dd of=plain_snippet bs=1k count=1; xxd \-s +128 > hex_snippet' < file\fR +.PP +Zrzut heksowy od pozycji pliku 0x100 ( = 1024\-768) dalej. +.br +\fI% sh \-c 'dd of=plain_snippet bs=1k count=1; xxd \-s +-768 > hex_snippet' < file\fR +.PP +Jakkolwiek, jest to rzadka sytuacja i użycie `+' jest rzadko +potrzebne. +Autor woli monitorować działanie xxd przy pomocy strace(1) lub truss(1) kiedy \-s jest użyte. +.SH PRZYKŁADY +.PP +.br +Wypisz wszystko z wyjątkiem pierwszych trzech linii (heksowe 0x30 bajtów) +.B pliku +\. +.br +\fI% xxd \-s 0x30 plik\fR +.PP +.br +Wypisz trzy linie (heksowe 0x30 bajtów) z końca +.B pliku +\. +.br +\fI% xxd \-s \-0x30 plik\fR +.PP +.br +Wypisz 120 bajtów jako ciągły zrzut heksowy z 20 oktetami na linię. +.br +\fI% xxd \-l 120 \-ps \-c 20 xxd.1\fR +.br +2e54482058584420312022417567757374203139 +.br +39362220224d616e75616c207061676520666f72 +.br +20787864220a2e5c220a2e5c222032317374204d +.br +617920313939360a2e5c22204d616e2070616765 +.br +20617574686f723a0a2e5c2220202020546f6e79 +.br +204e7567656e74203c746f6e79407363746e7567 +.br + +.br +Zrzut heksowy z pierwszymi 120 bajtami tej strony podręcznika z 12 +oktetami na linię. +.br +\fI% xxd \-l 120 \-c 12 xxd.1\fR +.br +0000000: 2e54 4820 5858 4420 3120 2241 .TH XXD 1 "A +.br +000000c: 7567 7573 7420 3139 3936 2220 ugust 1996" +.br +0000018: 224d 616e 7561 6c20 7061 6765 "Manual page +.br +0000024: 2066 6f72 2078 7864 220a 2e5c for xxd"..\\ +.br +0000030: 220a 2e5c 2220 3231 7374 204d "..\\" 21st M +.br +000003c: 6179 2031 3939 360a 2e5c 2220 ay 1996..\\" +.br +0000048: 4d61 6e20 7061 6765 2061 7574 Man page aut +.br +0000054: 686f 723a 0a2e 5c22 2020 2020 hor:..\\" +.br +0000060: 546f 6e79 204e 7567 656e 7420 Tony Nugent +.br +000006c: 3c74 6f6e 7940 7363 746e 7567 <tony@sctnug +.PP +.br +Pokaż tylko datę z pliku xxd.1 +.br +\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR +.br +0000036: 3231 7374 204d 6179 2031 3939 36 21st May 1996 +.PP +.br +Kopiuj +.B plik_we +do +.B plik_wy +i poprzedź 100 bajtami o wartości 0x00. +.br +\fI% xxd plik_we | xxd \-r \-s 100 \> plik_wy\fR +.br + +.br +Podmień datę w pliku xxd.1 +.br +\fI% echo '0000037: 3574 68' | xxd \-r \- xxd.1\fR +.br +\fI% xxd \-s 0x36 \-l 13 \-c 13 xxd.1\fR +.br +0000036: 3235 7468 204d 6179 2031 3939 36 25th May 1996 +.PP +.br +Utwórz plik o 65537 bajtach, wszystkich równych 0x00, +z wyjątkiem ostatniego, który ma być 'A' (hex 0x41). +.br +\fI% echo '010000: 41' | xxd \-r \> plik\fR +.PP +.br +Zrzut heksowy tego pliku z autoskipem. +.br +\fI% xxd \-a \-c 12 plik\fR +.br +0000000: 0000 0000 0000 0000 0000 0000 ............ +.br +* +.br +000fffc: 0000 0000 40 ....A +.PP +Utwórz jedno bajtowy plik zawierający pojednczą literę 'A'. +Liczba po '\-r \-s' dodaje numery linii znalezione w pliku; +w efekcie poprzedzające bajty są ukryte. +.br +\fI% echo '010000: 41' | xxd \-r \-s \-0x10000 \> plik\fR +.PP +Użyj xxd jako filtra wewnątrz edytora takiego jak +.B vim(1) +aby uzyskać zrzut heksowy zakresu między markerami `a' i `z'. +.br +\fI:'a,'z!xxd\fR +.PP +Użyj xxd jako filtra wewnątrz edytora takiego jak +.B vim(1) +by odzyskać binarny zrzut heksowy zakresu pomiędzy markerami `a' +i `z'. +.br +\fI:'a,'z!xxd \-r\fR +.PP +Użyj xxd jako filtra wewnątrz edytora takiego jak +.B vim(1) +by odzyskać jedną linię zrzutu heksowego. Przejdź z kursorem na linię +i wpisz: +.br +\fI!!xxd \-r\fR +.PP +Odczytaj pojednycze znaki z portu szeregowego +.br +\fI% xxd \-c1 < /dev/term/b &\fR +.br +\fI% stty < /dev/term/b \-echo \-opost \-isig \-icanon min 1\fR +.br +\fI% echo \-n foo > /dev/term/b\fR +.PP +.SH "ZWRACANE WARTOŚCI" +Zwracane są następujące wartości błędów: +.TP +0 +nie znaleziono błędów. +.TP +\-1 +operacja nie jest wspierana ( +.I xxd \-r \-i +cały czas niemożliwa). +.TP +1 +błąd w czasie analizowania opcji. +.TP +2 +problemy z plikiem wejściowym. +.TP +3 +problemy z plikiem wyjściowym. +.TP +4,5 +żądana pozycja jest nieosiągalna. +.SH "ZOBACZ TAKŻE" +uuencode(1), uudecode(1), patch(1) +.br +.SH OSTRZEŻENIA +Dziwaczność narzędzi dorównuje dziwaczności mózgu twórcy. +Używaj wyłącznie na własną odpowiedzialność. Kopiuj pliki. Analizuj +je. Stań się czarodziejem. +.br +.SH WERSJA +Strona podręcznika opisuje xxd w wersji 1.7 +.SH AUTOR +.br +(c) 1990-1997 by Juergen Weigert +.br +<jnweiger@informatik.uni-erlangen.de> +.LP +Kopiuj do woli i podaj moje dane, +.br +zarabiaj pieniądze i dziel się ze mną, +.br +trać pieniądze i nie miej do mnie pretensji. +.PP +Strona podręcznika zapoczątkowana przez Tony'ego Nugenta +.br +<tony@sctnugen.ppp.gu.edu.au> <T.Nugent@sct.gu.edu.au> +.br +Małe zmiany: Bram Moolenaar. +Redakcja: Juergen Weigert. +.PP diff --git a/share/vim/vim72/doc/xxd-ru.1 b/share/vim/vim73/doc/xxd-ru.1 similarity index 100% rename from share/vim/vim72/doc/xxd-ru.1 rename to share/vim/vim73/doc/xxd-ru.1 diff --git a/share/vim/vim72/doc/xxd-ru.UTF-8.1 b/share/vim/vim73/doc/xxd-ru.UTF-8.1 similarity index 100% rename from share/vim/vim72/doc/xxd-ru.UTF-8.1 rename to share/vim/vim73/doc/xxd-ru.UTF-8.1 diff --git a/share/vim/vim72/doc/xxd.1 b/share/vim/vim73/doc/xxd.1 similarity index 100% rename from share/vim/vim72/doc/xxd.1 rename to share/vim/vim73/doc/xxd.1 diff --git a/share/vim/vim72/doc/xxd.man b/share/vim/vim73/doc/xxd.man similarity index 100% rename from share/vim/vim72/doc/xxd.man rename to share/vim/vim73/doc/xxd.man diff --git a/share/vim/vim73/evim.vim b/share/vim/vim73/evim.vim new file mode 100644 index 0000000000..650ce428d6 --- /dev/null +++ b/share/vim/vim73/evim.vim @@ -0,0 +1,66 @@ +" Vim script for Evim key bindings +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2006 Mar 29 + +" Don't use Vi-compatible mode. +set nocompatible + +" Use the mswin.vim script for most mappings +source <sfile>:p:h/mswin.vim + +" Vim is in Insert mode by default +set insertmode + +" Make a buffer hidden when editing another one +set hidden + +" Make cursor keys ignore wrapping +inoremap <silent> <Down> <C-R>=pumvisible() ? "\<lt>Down>" : "\<lt>C-O>gj"<CR> +inoremap <silent> <Up> <C-R>=pumvisible() ? "\<lt>Up>" : "\<lt>C-O>gk"<CR> + +" CTRL-F does Find dialog instead of page forward +noremap <silent> <C-F> :promptfind<CR> +vnoremap <silent> <C-F> y:promptfind <C-R>"<CR> +onoremap <silent> <C-F> <C-C>:promptfind<CR> +inoremap <silent> <C-F> <C-O>:promptfind<CR> +cnoremap <silent> <C-F> <C-C>:promptfind<CR> + + +set backspace=2 " allow backspacing over everything in insert mode +set autoindent " always set autoindenting on +if has("vms") + set nobackup " do not keep a backup file, use versions instead +else + set backup " keep a backup file +endif +set history=50 " keep 50 lines of command line history +set ruler " show the cursor position all the time +set incsearch " do incremental searching +set mouse=a " always use the mouse + +" Don't use Ex mode, use Q for formatting +map Q gq + +" Switch syntax highlighting on, when the terminal has colors +" Highlight the last used search pattern on the next search command. +if &t_Co > 2 || has("gui_running") + syntax on + set hlsearch + nohlsearch +endif + +" Only do this part when compiled with support for autocommands. +if has("autocmd") + + " Enable file type detection. + " Use the default filetype settings, so that mail gets 'tw' set to 72, + " 'cindent' is on in C files, etc. + " Also load indent files, to automatically do language-dependent indenting. + filetype plugin indent on + + " For all text files set 'textwidth' to 78 characters. + au FileType text setlocal tw=78 + +endif " has("autocmd") + +" vim: set sw=2 : diff --git a/share/vim/vim73/filetype.vim b/share/vim/vim73/filetype.vim new file mode 100644 index 0000000000..afc0740b1c --- /dev/null +++ b/share/vim/vim73/filetype.vim @@ -0,0 +1,2514 @@ +" Vim support file to detect file types +" +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2010 Jul 30 + +" Listen very carefully, I will say this only once +if exists("did_load_filetypes") + finish +endif +let did_load_filetypes = 1 + +" Line continuation is used here, remove 'C' from 'cpoptions' +let s:cpo_save = &cpo +set cpo&vim + +augroup filetypedetect + +" Ignored extensions +if exists("*fnameescape") +au BufNewFile,BufRead ?\+.orig,?\+.bak,?\+.old,?\+.new,?\+.dpkg-dist,?\+.dpkg-old,?\+.rpmsave,?\+.rpmnew + \ exe "doau filetypedetect BufRead " . fnameescape(expand("<afile>:r")) +au BufNewFile,BufRead *~ + \ let s:name = expand("<afile>") | + \ let s:short = substitute(s:name, '\~$', '', '') | + \ if s:name != s:short && s:short != "" | + \ exe "doau filetypedetect BufRead " . fnameescape(s:short) | + \ endif | + \ unlet! s:name s:short +au BufNewFile,BufRead ?\+.in + \ if expand("<afile>:t") != "configure.in" | + \ exe "doau filetypedetect BufRead " . fnameescape(expand("<afile>:r")) | + \ endif +elseif &verbose > 0 + echomsg "Warning: some filetypes will not be recognized because this version of Vim does not have fnameescape()" +endif + +" Pattern used to match file names which should not be inspected. +" Currently finds compressed files. +if !exists("g:ft_ignore_pat") + let g:ft_ignore_pat = '\.\(Z\|gz\|bz2\|zip\|tgz\)$' +endif + +" Function used for patterns that end in a star: don't set the filetype if the +" file name matches ft_ignore_pat. +func! s:StarSetf(ft) + if expand("<amatch>") !~ g:ft_ignore_pat + exe 'setf ' . a:ft + endif +endfunc + +" Abaqus or Trasys +au BufNewFile,BufRead *.inp call s:Check_inp() + +func! s:Check_inp() + if getline(1) =~ '^\*' + setf abaqus + else + let n = 1 + if line("$") > 500 + let nmax = 500 + else + let nmax = line("$") + endif + while n <= nmax + if getline(n) =~? "^header surface data" + setf trasys + break + endif + let n = n + 1 + endwhile + endif +endfunc + +" A-A-P recipe +au BufNewFile,BufRead *.aap setf aap + +" A2ps printing utility +au BufNewFile,BufRead etc/a2ps.cfg,etc/a2ps/*.cfg,a2psrc,.a2psrc setf a2ps + +" ABAB/4 +au BufNewFile,BufRead *.abap setf abap + +" ABC music notation +au BufNewFile,BufRead *.abc setf abc + +" ABEL +au BufNewFile,BufRead *.abl setf abel + +" AceDB +au BufNewFile,BufRead *.wrm setf acedb + +" Ada (83, 9X, 95) +au BufNewFile,BufRead *.adb,*.ads,*.ada setf ada +if has("vms") + au BufNewFile,BufRead *.gpr,*.ada_m,*.adc setf ada +else + au BufNewFile,BufRead *.gpr setf ada +endif + +" AHDL +au BufNewFile,BufRead *.tdf setf ahdl + +" AMPL +au BufNewFile,BufRead *.run setf ampl + +" Ant +au BufNewFile,BufRead build.xml setf ant + +" Apache style config file +au BufNewFile,BufRead proftpd.conf* call s:StarSetf('apachestyle') + +" Apache config file +au BufNewFile,BufRead .htaccess,/etc/httpd/*.conf setf apache +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') + +" XA65 MOS6510 cross assembler +au BufNewFile,BufRead *.a65 setf a65 + +" Applescript +au BufNewFile,BufRead *.scpt setf applescript + +" Applix ELF +au BufNewFile,BufRead *.am + \ if expand("<afile>") !~? 'Makefile.am\>' | setf elf | endif + +" ALSA configuration +au BufNewFile,BufRead ~/.asoundrc,/usr/share/alsa/alsa.conf,/etc/asound.conf setf alsaconf + +" Arc Macro Language +au BufNewFile,BufRead *.aml setf aml + +" Arch Inventory file +au BufNewFile,BufRead .arch-inventory,=tagging-method setf arch + +" ART*Enterprise (formerly ART-IM) +au BufNewFile,BufRead *.art setf art + +" ASN.1 +au BufNewFile,BufRead *.asn,*.asn1 setf asn + +" Active Server Pages (with Visual Basic Script) +au BufNewFile,BufRead *.asa + \ if exists("g:filetype_asa") | + \ exe "setf " . g:filetype_asa | + \ else | + \ setf aspvbs | + \ endif + +" Active Server Pages (with Perl or Visual Basic Script) +au BufNewFile,BufRead *.asp + \ if exists("g:filetype_asp") | + \ exe "setf " . g:filetype_asp | + \ elseif getline(1) . getline(2) . getline(3) =~? "perlscript" | + \ setf aspperl | + \ else | + \ setf aspvbs | + \ endif + +" Grub (must be before catch *.lst) +au BufNewFile,BufRead /boot/grub/menu.lst,/boot/grub/grub.conf,/etc/grub.conf setf grub + +" Assembly (all kinds) +" *.lst is not pure assembly, it has two extra columns (address, byte codes) +au BufNewFile,BufRead *.asm,*.[sS],*.[aA],*.mac,*.lst call s:FTasm() + +" This function checks for the kind of assembly that is wanted by the user, or +" can be detected from the first five lines of the file. +func! s:FTasm() + " make sure b:asmsyntax exists + if !exists("b:asmsyntax") + let b:asmsyntax = "" + endif + + if b:asmsyntax == "" + call s:FTasmsyntax() + endif + + " if b:asmsyntax still isn't set, default to asmsyntax or GNU + if b:asmsyntax == "" + if exists("g:asmsyntax") + let b:asmsyntax = g:asmsyntax + else + let b:asmsyntax = "asm" + endif + endif + + exe "setf " . fnameescape(b:asmsyntax) +endfunc + +func! s:FTasmsyntax() + " see if file contains any asmsyntax=foo overrides. If so, change + " b:asmsyntax appropriately + let head = " ".getline(1)." ".getline(2)." ".getline(3)." ".getline(4). + \" ".getline(5)." " + let match = matchstr(head, '\sasmsyntax=\zs[a-zA-Z0-9]\+\ze\s') + if match != '' + let b:asmsyntax = match + elseif ((head =~? '\.title') || (head =~? '\.ident') || (head =~? '\.macro') || (head =~? '\.subtitle') || (head =~? '\.library')) + let b:asmsyntax = "vmasm" + endif +endfunc + +" Macro (VAX) +au BufNewFile,BufRead *.mar setf vmasm + +" Atlas +au BufNewFile,BufRead *.atl,*.as setf atlas + +" Autoit v3 +au BufNewFile,BufRead *.au3 setf autoit + +" Autohotkey +au BufNewFile,BufRead *.ahk setf autohotkey + +" Automake +au BufNewFile,BufRead [mM]akefile.am,GNUmakefile.am setf automake + +" Autotest .at files are actually m4 +au BufNewFile,BufRead *.at setf m4 + +" Avenue +au BufNewFile,BufRead *.ave setf ave + +" Awk +au BufNewFile,BufRead *.awk setf awk + +" B +au BufNewFile,BufRead *.mch,*.ref,*.imp setf b + +" BASIC or Visual Basic +au BufNewFile,BufRead *.bas call s:FTVB("basic") + +" Check if one of the first five lines contains "VB_Name". In that case it is +" probably a Visual Basic file. Otherwise it's assumed to be "alt" filetype. +func! s:FTVB(alt) + if getline(1).getline(2).getline(3).getline(4).getline(5) =~? 'VB_Name\|Begin VB\.\(Form\|MDIForm\|UserControl\)' + setf vb + else + exe "setf " . a:alt + endif +endfunc + +" Visual Basic Script (close to Visual Basic) +au BufNewFile,BufRead *.vbs,*.dsm,*.ctl setf vb + +" IBasic file (similar to QBasic) +au BufNewFile,BufRead *.iba,*.ibi setf ibasic + +" FreeBasic file (similar to QBasic) +au BufNewFile,BufRead *.fb,*.bi setf freebasic + +" Batch file for MSDOS. +au BufNewFile,BufRead *.bat,*.sys setf dosbatch +" *.cmd is close to a Batch file, but on OS/2 Rexx files also use *.cmd. +au BufNewFile,BufRead *.cmd + \ if getline(1) =~ '^/\*' | setf rexx | else | setf dosbatch | endif + +" Batch file for 4DOS +au BufNewFile,BufRead *.btm call s:FTbtm() +func! s:FTbtm() + if exists("g:dosbatch_syntax_for_btm") && g:dosbatch_syntax_for_btm + setf dosbatch + else + setf btm + endif +endfunc + +" BC calculator +au BufNewFile,BufRead *.bc setf bc + +" BDF font +au BufNewFile,BufRead *.bdf setf bdf + +" BibTeX bibliography database file +au BufNewFile,BufRead *.bib setf bib + +" BibTeX Bibliography Style +au BufNewFile,BufRead *.bst setf bst + +" BIND configuration +au BufNewFile,BufRead named.conf,rndc.conf setf named + +" BIND zone +au BufNewFile,BufRead named.root setf bindzone +au BufNewFile,BufRead *.db call s:BindzoneCheck('') + +func! s:BindzoneCheck(default) + if getline(1).getline(2).getline(3).getline(4) =~ '^; <<>> DiG [0-9.]\+ <<>>\|BIND.*named\|$ORIGIN\|$TTL\|IN\s\+SOA' + setf bindzone + elseif a:default != '' + exe 'setf ' . a:default + endif +endfunc + +" Blank +au BufNewFile,BufRead *.bl setf blank + +" Blkid cache file +au BufNewFile,BufRead /etc/blkid.tab,/etc/blkid.tab.old setf xml + +" C or lpc +au BufNewFile,BufRead *.c call s:FTlpc() + +func! s:FTlpc() + if exists("g:lpc_syntax_for_c") + let lnum = 1 + while lnum <= 12 + if getline(lnum) =~# '^\(//\|inherit\|private\|protected\|nosave\|string\|object\|mapping\|mixed\)' + setf lpc + return + endif + let lnum = lnum + 1 + endwhile + endif + setf c +endfunc + +" Calendar +au BufNewFile,BufRead calendar setf calendar +au BufNewFile,BufRead */.calendar/*, + \*/share/calendar/*/calendar.*,*/share/calendar/calendar.* + \ call s:StarSetf('calendar') + +" C# +au BufNewFile,BufRead *.cs setf cs + +" Cabal +au BufNewFile,BufRead *.cabal setf cabal + +" Cdrdao TOC +au BufNewFile,BufRead *.toc setf cdrtoc + +" Cdrdao config +au BufNewFile,BufRead etc/cdrdao.conf,etc/defaults/cdrdao,etc/default/cdrdao,~/.cdrdao setf cdrdaoconf + +" Cfengine +au BufNewFile,BufRead cfengine.conf setf cfengine + +" ChaiScript +au BufRead,BufNewFile *.chai setf chaiscript + +" Comshare Dimension Definition Language +au BufNewFile,BufRead *.cdl setf cdl + +" Conary Recipe +au BufNewFile,BufRead *.recipe setf conaryrecipe + +" Controllable Regex Mutilator +au BufNewFile,BufRead *.crm setf crm + +" Cyn++ +au BufNewFile,BufRead *.cyn setf cynpp + +" Cynlib +" .cc and .cpp files can be C++ or Cynlib. +au BufNewFile,BufRead *.cc + \ if exists("cynlib_syntax_for_cc")|setf cynlib|else|setf cpp|endif +au BufNewFile,BufRead *.cpp + \ if exists("cynlib_syntax_for_cpp")|setf cynlib|else|setf cpp|endif + +" C++ +au BufNewFile,BufRead *.cxx,*.c++,*.hh,*.hxx,*.hpp,*.ipp,*.moc,*.tcc,*.inl setf cpp +if has("fname_case") + au BufNewFile,BufRead *.C,*.H setf cpp +endif + +" .h files can be C, Ch C++, ObjC or ObjC++. +" Set c_syntax_for_h if you want C, ch_syntax_for_h if you want Ch. ObjC is +" detected automatically. +au BufNewFile,BufRead *.h call s:FTheader() + +func! s:FTheader() + if match(getline(1, min([line("$"), 200])), '^@\(interface\|end\|class\)') > -1 + setf objc + elseif exists("g:c_syntax_for_h") + setf c + elseif exists("g:ch_syntax_for_h") + setf ch + else + setf cpp + endif +endfunc + +" Ch (CHscript) +au BufNewFile,BufRead *.chf setf ch + +" TLH files are C++ headers generated by Visual C++'s #import from typelibs +au BufNewFile,BufRead *.tlh setf cpp + +" Cascading Style Sheets +au BufNewFile,BufRead *.css setf css + +" Century Term Command Scripts (*.cmd too) +au BufNewFile,BufRead *.con setf cterm + +" Changelog +au BufNewFile,BufRead changelog.Debian,changelog.dch,NEWS.Debian,NEWS.dch + \ setf debchangelog + +au BufNewFile,BufRead [cC]hange[lL]og + \ if getline(1) =~ '; urgency=' + \| setf debchangelog + \| else + \| setf changelog + \| endif + +au BufNewFile,BufRead NEWS + \ if getline(1) =~ '; urgency=' + \| setf debchangelog + \| endif + +" CHILL +au BufNewFile,BufRead *..ch setf chill + +" Changes for WEB and CWEB or CHILL +au BufNewFile,BufRead *.ch call s:FTchange() + +" This function checks if one of the first ten lines start with a '@'. In +" that case it is probably a change file. +" If the first line starts with # or ! it's probably a ch file. +" If a line has "main", "include", "//" ir "/*" it's probably ch. +" Otherwise CHILL is assumed. +func! s:FTchange() + let lnum = 1 + while lnum <= 10 + if getline(lnum)[0] == '@' + setf change + return + endif + if lnum == 1 && (getline(1)[0] == '#' || getline(1)[0] == '!') + setf ch + return + endif + if getline(lnum) =~ "MODULE" + setf chill + return + endif + if getline(lnum) =~ 'main\s*(\|#\s*include\|//' + setf ch + return + endif + let lnum = lnum + 1 + endwhile + setf chill +endfunc + +" ChordPro +au BufNewFile,BufRead *.chopro,*.crd,*.cho,*.crdpro,*.chordpro setf chordpro + +" Clean +au BufNewFile,BufRead *.dcl,*.icl setf clean + +" Clever +au BufNewFile,BufRead *.eni setf cl + +" Clever or dtd +au BufNewFile,BufRead *.ent call s:FTent() + +func! s:FTent() + " This function checks for valid cl syntax in the first five lines. + " Look for either an opening comment, '#', or a block start, '{". + " If not found, assume SGML. + let lnum = 1 + while lnum < 6 + let line = getline(lnum) + if line =~ '^\s*[#{]' + setf cl + return + elseif line !~ '^\s*$' + " Not a blank line, not a comment, and not a block start, + " so doesn't look like valid cl code. + break + endif + let lnum = lnum + 1 + endw + setf dtd +endfunc + +" Clipper (or FoxPro; could also be eviews) +au BufNewFile,BufRead *.prg + \ if exists("g:filetype_prg") | + \ exe "setf " . g:filetype_prg | + \ else | + \ setf clipper | + \ endif + +" Cmake +au BufNewFile,BufRead CMakeLists.txt,*.cmake,*.cmake.in setf cmake + +" Cmusrc +au BufNewFile,BufRead ~/.cmus/{autosave,rc,command-history,*.theme} setf cmusrc +au BufNewFile,BufRead */cmus/{rc,*.theme} setf cmusrc + +" Cobol +au BufNewFile,BufRead *.cbl,*.cob,*.lib setf cobol +" cobol or zope form controller python script? (heuristic) +au BufNewFile,BufRead *.cpy + \ if getline(1) =~ '^##' | + \ setf python | + \ else | + \ setf cobol | + \ endif + +" Coco/R +au BufNewFile,BufRead *.atg setf coco + +" Cold Fusion +au BufNewFile,BufRead *.cfm,*.cfi,*.cfc setf cf + +" Configure scripts +au BufNewFile,BufRead configure.in,configure.ac setf config + +" CUDA Cumpute Unified Device Architecture +au BufNewFile,BufRead *.cu setf cuda + +" WildPackets EtherPeek Decoder +au BufNewFile,BufRead *.dcd setf dcd + +" Enlightenment configuration files +au BufNewFile,BufRead *enlightenment/*.cfg setf c + +" Eterm +au BufNewFile,BufRead *Eterm/*.cfg setf eterm + +" Lynx config files +au BufNewFile,BufRead lynx.cfg setf lynx + +" Quake +au BufNewFile,BufRead *baseq[2-3]/*.cfg,*id1/*.cfg setf quake +au BufNewFile,BufRead *quake[1-3]/*.cfg setf quake + +" Quake C +au BufNewFile,BufRead *.qc setf c + +" Configure files +au BufNewFile,BufRead *.cfg setf cfg + +" Cucumber +au BufNewFile,BufRead *.feature setf cucumber + +" Communicating Sequential Processes +au BufNewFile,BufRead *.csp,*.fdr setf csp + +" CUPL logic description and simulation +au BufNewFile,BufRead *.pld setf cupl +au BufNewFile,BufRead *.si setf cuplsim + +" Debian Control +au BufNewFile,BufRead */debian/control setf debcontrol +au BufNewFile,BufRead control + \ if getline(1) =~ '^Source:' + \| setf debcontrol + \| endif + +" Debian Sources.list +au BufNewFile,BufRead /etc/apt/sources.list setf debsources + +" Deny hosts +au BufNewFile,BufRead denyhosts.conf setf denyhosts + +" ROCKLinux package description +au BufNewFile,BufRead *.desc setf desc + +" the D language or dtrace +au BufNewFile,BufRead *.d call s:DtraceCheck() + +func! s:DtraceCheck() + let lines = getline(1, min([line("$"), 100])) + if match(lines, '^#!\S\+dtrace\|#pragma\s\+D\s\+option\|:\S\{-}:\S\{-}:') > -1 + setf dtrace + else + setf d + endif +endfunc + +" Desktop files +au BufNewFile,BufRead *.desktop,.directory setf desktop + +" Dict config +au BufNewFile,BufRead dict.conf,.dictrc setf dictconf + +" Dictd config +au BufNewFile,BufRead dictd.conf setf dictdconf + +" Diff files +au BufNewFile,BufRead *.diff,*.rej,*.patch setf diff + +" Dircolors +au BufNewFile,BufRead .dir_colors,/etc/DIR_COLORS setf dircolors + +" Diva (with Skill) or InstallShield +au BufNewFile,BufRead *.rul + \ if getline(1).getline(2).getline(3).getline(4).getline(5).getline(6) =~? 'InstallShield' | + \ setf ishd | + \ else | + \ setf diva | + \ endif + +" DCL (Digital Command Language - vms) or DNS zone file +au BufNewFile,BufRead *.com call s:BindzoneCheck('dcl') + +" DOT +au BufNewFile,BufRead *.dot setf dot + +" Dylan - lid files +au BufNewFile,BufRead *.lid setf dylanlid + +" Dylan - intr files (melange) +au BufNewFile,BufRead *.intr setf dylanintr + +" Dylan +au BufNewFile,BufRead *.dylan setf dylan + +" Microsoft Module Definition +au BufNewFile,BufRead *.def setf def + +" Dracula +au BufNewFile,BufRead *.drac,*.drc,*lvs,*lpe setf dracula + +" Datascript +au BufNewFile,BufRead *.ds setf datascript + +" dsl +au BufNewFile,BufRead *.dsl setf dsl + +" DTD (Document Type Definition for XML) +au BufNewFile,BufRead *.dtd setf dtd + +" EDIF (*.edf,*.edif,*.edn,*.edo) +au BufNewFile,BufRead *.ed\(f\|if\|n\|o\) setf edif + +" Embedix Component Description +au BufNewFile,BufRead *.ecd setf ecd + +" Eiffel or Specman +au BufNewFile,BufRead *.e,*.E call s:FTe() + +" Elinks configuration +au BufNewFile,BufRead */etc/elinks.conf,*/.elinks/elinks.conf setf elinks + +func! s:FTe() + let n = 1 + while n < 100 && n < line("$") + if getline(n) =~ "^\\s*\\(<'\\|'>\\)\\s*$" + setf specman + return + endif + let n = n + 1 + endwhile + setf eiffel +endfunc + +" ERicsson LANGuage; Yaws is erlang too +au BufNewFile,BufRead *.erl,*.hrl,*.yaws setf erlang + +" Elm Filter Rules file +au BufNewFile,BufRead filter-rules setf elmfilt + +" ESMTP rc file +au BufNewFile,BufRead *esmtprc setf esmtprc + +" ESQL-C +au BufNewFile,BufRead *.ec,*.EC setf esqlc + +" Esterel +au BufNewFile,BufRead *.strl setf esterel + +" Essbase script +au BufNewFile,BufRead *.csc setf csc + +" Exim +au BufNewFile,BufRead exim.conf setf exim + +" Expect +au BufNewFile,BufRead *.exp setf expect + +" Exports +au BufNewFile,BufRead exports setf exports + +" Fantom +au BufNewFile,BufRead *.fan,*.fwt setf fan + +" Factor +au BufNewFile,BufRead *.factor setf factor + +" Fetchmail RC file +au BufNewFile,BufRead .fetchmailrc setf fetchmail + +" FlexWiki - disabled, because it has side effects when a .wiki file +" is not actually FlexWiki +"au BufNewFile,BufRead *.wiki setf flexwiki + +" Focus Executable +au BufNewFile,BufRead *.fex,*.focexec setf focexec + +" Focus Master file (but not for auto.master) +au BufNewFile,BufRead auto.master setf conf +au BufNewFile,BufRead *.mas,*.master setf master + +" Forth +au BufNewFile,BufRead *.fs,*.ft setf forth + +" Reva Forth +au BufNewFile,BufRead *.frt setf reva + +" Fortran +if has("fname_case") + au BufNewFile,BufRead *.F,*.FOR,*.FPP,*.FTN,*.F77,*.F90,*.F95,*.F03,*.F08 setf fortran +endif +au BufNewFile,BufRead *.f,*.for,*.fortran,*.fpp,*.ftn,*.f77,*.f90,*.f95,*.f03,*.f08 setf fortran + +" Framescript +au BufNewFile,BufRead *.fsl setf framescript + +" FStab +au BufNewFile,BufRead fstab,mtab setf fstab + +" GDB command files +au BufNewFile,BufRead .gdbinit setf gdb + +" GDMO +au BufNewFile,BufRead *.mo,*.gdmo setf gdmo + +" Gedcom +au BufNewFile,BufRead *.ged,lltxxxxx.txt setf gedcom + +" Git +autocmd BufNewFile,BufRead *.git/COMMIT_EDITMSG setf gitcommit +autocmd BufNewFile,BufRead *.git/config,.gitconfig,.gitmodules setf gitconfig +autocmd BufNewFile,BufRead git-rebase-todo setf gitrebase +autocmd BufNewFile,BufRead .msg.[0-9]* + \ if getline(1) =~ '^From.*# This line is ignored.$' | + \ setf gitsendemail | + \ endif +autocmd BufNewFile,BufRead *.git/** + \ if getline(1) =~ '^\x\{40\}\>\|^ref: ' | + \ setf git | + \ endif + +" Gkrellmrc +au BufNewFile,BufRead gkrellmrc,gkrellmrc_? setf gkrellmrc + +" GP scripts (2.0 and onward) +au BufNewFile,BufRead *.gp,.gprc setf gp + +" GPG +au BufNewFile,BufRead */.gnupg/options setf gpg +au BufNewFile,BufRead */.gnupg/gpg.conf setf gpg +au BufNewFile,BufRead /usr/**/gnupg/options.skel setf gpg + +" Gnuplot scripts +au BufNewFile,BufRead *.gpi setf gnuplot + +" GrADS scripts +au BufNewFile,BufRead *.gs setf grads + +" Gretl +au BufNewFile,BufRead *.gretl setf gretl + +" Groovy +au BufNewFile,BufRead *.groovy setf groovy + +" GNU Server Pages +au BufNewFile,BufRead *.gsp setf gsp + +" Group file +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 + +" GTK RC +au BufNewFile,BufRead .gtkrc,gtkrc setf gtkrc + +" Haml +au BufNewFile,BufRead *.haml setf haml + +" Hamster Classic | Playground files +au BufNewFile,BufRead *.hsc,*.hsm setf hamster + +" Haskell +au BufNewFile,BufRead *.hs,*.hs-boot setf haskell +au BufNewFile,BufRead *.lhs setf lhaskell +au BufNewFile,BufRead *.chs setf chaskell + +" Haste +au BufNewFile,BufRead *.ht setf haste +au BufNewFile,BufRead *.htpp setf hastepreproc + +" Hercules +au BufNewFile,BufRead *.vc,*.ev,*.rs,*.sum,*.errsum setf hercules + +" HEX (Intel) +au BufNewFile,BufRead *.hex,*.h32 setf hex + +" Tilde (must be before HTML) +au BufNewFile,BufRead *.t.html setf tilde + +" HTML (.shtml and .stm for server side) +au BufNewFile,BufRead *.html,*.htm,*.shtml,*.stm call s:FThtml() + +" Distinguish between HTML, XHTML and Django +func! s:FThtml() + let n = 1 + while n < 10 && n < line("$") + if getline(n) =~ '\<DTD\s\+XHTML\s' + setf xhtml + return + endif + if getline(n) =~ '{%\s*\(extends\|block\)\>' + setf htmldjango + return + endif + let n = n + 1 + endwhile + setf html +endfunc + +" HTML with Ruby - eRuby +au BufNewFile,BufRead *.erb,*.rhtml setf eruby + +" HTML with M4 +au BufNewFile,BufRead *.html.m4 setf htmlm4 + +" HTML Cheetah template +au BufNewFile,BufRead *.tmpl setf htmlcheetah + +" Host config +au BufNewFile,BufRead /etc/host.conf setf hostconf + +" Hosts access +au BufNewFile,BufRead /etc/hosts.allow,/etc/hosts.deny setf hostsaccess + +" Hyper Builder +au BufNewFile,BufRead *.hb setf hb + +" Icon +au BufNewFile,BufRead *.icn setf icon + +" IDL (Interface Description Language) +au BufNewFile,BufRead *.idl call s:FTidl() + +" Distinguish between standard IDL and MS-IDL +func! s:FTidl() + let n = 1 + while n < 50 && n < line("$") + if getline(n) =~ '^\s*import\s\+"\(unknwn\|objidl\)\.idl"' + setf msidl + return + endif + let n = n + 1 + endwhile + setf idl +endfunc + +" Microsoft IDL (Interface Description Language) Also *.idl +" MOF = WMI (Windows Management Instrumentation) Managed Object Format +au BufNewFile,BufRead *.odl,*.mof setf msidl + +" Icewm menu +au BufNewFile,BufRead */.icewm/menu setf icemenu + +" Indent profile (must come before IDL *.pro!) +au BufNewFile,BufRead .indent.pro setf indent +au BufNewFile,BufRead indent.pro call s:ProtoCheck('indent') + +" IDL (Interactive Data Language) +au BufNewFile,BufRead *.pro call s:ProtoCheck('idlang') + +" Distinguish between "default" and Cproto prototype file. */ +func! s:ProtoCheck(default) + " Cproto files have a comment in the first line and a function prototype in + " the second line, it always ends in ";". Indent files may also have + " comments, thus we can't match comments to see the difference. + if getline(2) =~ ';$' + setf cpp + else + exe 'setf ' . a:default + endif +endfunc + + +" Indent RC +au BufNewFile,BufRead indentrc setf indent + +" Inform +au BufNewFile,BufRead *.inf,*.INF setf inform + +" Initng +au BufNewFile,BufRead /etc/initng/**/*.i,*.ii setf initng + +" Ipfilter +au BufNewFile,BufRead ipf.conf,ipf6.conf,ipf.rules setf ipfilter + +" Informix 4GL (source - canonical, include file, I4GL+M4 preproc.) +au BufNewFile,BufRead *.4gl,*.4gh,*.m4gl setf fgl + +" .INI file for MSDOS +au BufNewFile,BufRead *.ini setf dosini + +" SysV Inittab +au BufNewFile,BufRead inittab setf inittab + +" Inno Setup +au BufNewFile,BufRead *.iss setf iss + +" JAL +au BufNewFile,BufRead *.jal,*.JAL setf jal + +" Jam +au BufNewFile,BufRead *.jpl,*.jpr setf jam + +" Java +au BufNewFile,BufRead *.java,*.jav setf java + +" JavaCC +au BufNewFile,BufRead *.jj,*.jjt setf javacc + +" JavaScript, ECMAScript +au BufNewFile,BufRead *.js,*.javascript,*.es,*.jsx setf javascript + +" Java Server Pages +au BufNewFile,BufRead *.jsp setf jsp + +" Java Properties resource file (note: doesn't catch font.properties.pl) +au BufNewFile,BufRead *.properties,*.properties_??,*.properties_??_?? setf jproperties +au BufNewFile,BufRead *.properties_??_??_* call s:StarSetf('jproperties') + +" Jess +au BufNewFile,BufRead *.clp setf jess + +" Jgraph +au BufNewFile,BufRead *.jgr setf jgraph + +" Kixtart +au BufNewFile,BufRead *.kix setf kix + +" Kimwitu[++] +au BufNewFile,BufRead *.k setf kwt + +" KDE script +au BufNewFile,BufRead *.ks setf kscript + +" Kconfig +au BufNewFile,BufRead Kconfig,Kconfig.debug setf kconfig + +" Lace (ISE) +au BufNewFile,BufRead *.ace,*.ACE setf lace + +" Latte +au BufNewFile,BufRead *.latte,*.lte setf latte + +" Limits +au BufNewFile,BufRead /etc/limits setf limits + +" LambdaProlog (*.mod too, see Modsim) +au BufNewFile,BufRead *.sig setf lprolog + +" LDAP LDIF +au BufNewFile,BufRead *.ldif setf ldif + +" Ld loader +au BufNewFile,BufRead *.ld setf ld + +" Lex +au BufNewFile,BufRead *.lex,*.l setf lex + +" Libao +au BufNewFile,BufRead /etc/libao.conf,*/.libao setf libao + +" Libsensors +au BufNewFile,BufRead /etc/sensors.conf setf sensors + +" LFTP +au BufNewFile,BufRead lftp.conf,.lftprc,*lftp/rc setf lftp + +" Lifelines (or Lex for C++!) +au BufNewFile,BufRead *.ll setf lifelines + +" Lilo: Linux loader +au BufNewFile,BufRead lilo.conf* call s:StarSetf('lilo') + +" Lisp (*.el = ELisp, *.cl = Common Lisp, *.jl = librep Lisp) +if has("fname_case") + au BufNewFile,BufRead *.lsp,*.lisp,*.el,*.cl,*.jl,*.L,.emacs,.sawfishrc setf lisp +else + au BufNewFile,BufRead *.lsp,*.lisp,*.el,*.cl,*.jl,.emacs,.sawfishrc setf lisp +endif + +" SBCL implementation of Common Lisp +au BufNewFile,BufRead sbclrc,.sbclrc setf lisp + +" Liquid +au BufNewFile,BufRead *.liquid setf liquid + +" Lite +au BufNewFile,BufRead *.lite,*.lt setf lite + +" LiteStep RC files +au BufNewFile,BufRead */LiteStep/*/*.rc setf litestep + +" Login access +au BufNewFile,BufRead /etc/login.access setf loginaccess + +" Login defs +au BufNewFile,BufRead /etc/login.defs setf logindefs + +" Logtalk +au BufNewFile,BufRead *.lgt setf logtalk + +" LOTOS +au BufNewFile,BufRead *.lot,*.lotos setf lotos + +" Lout (also: *.lt) +au BufNewFile,BufRead *.lou,*.lout setf lout + +" Lua +au BufNewFile,BufRead *.lua setf lua + +" Linden Scripting Language (Second Life) +au BufNewFile,BufRead *.lsl setf lsl + +" Lynx style file (or LotusScript!) +au BufNewFile,BufRead *.lss setf lss + +" M4 +au BufNewFile,BufRead *.m4 + \ if expand("<afile>") !~? 'html.m4$\|fvwm2rc' | setf m4 | endif + +" MaGic Point +au BufNewFile,BufRead *.mgp setf mgp + +" Mail (for Elm, trn, mutt, muttng, rn, slrn) +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 + +" Mail aliases +au BufNewFile,BufRead /etc/mail/aliases,/etc/aliases setf mailaliases + +" Mailcap configuration file +au BufNewFile,BufRead .mailcap,mailcap setf mailcap + +" Makefile +au BufNewFile,BufRead *[mM]akefile,*.mk,*.mak,*.dsp setf make + +" MakeIndex +au BufNewFile,BufRead *.ist,*.mst setf ist + +" Manpage +au BufNewFile,BufRead *.man setf man + +" Man config +au BufNewFile,BufRead /etc/man.conf,man.config setf manconf + +" Maple V +au BufNewFile,BufRead *.mv,*.mpl,*.mws setf maple + +" Map (UMN mapserver config file) +au BufNewFile,BufRead *.map setf map + +" Markdown +au BufNewFile,BufRead *.markdown,*.mdown,*.mkd,*.mkdn,README.md setf markdown + +" Mason +au BufNewFile,BufRead *.mason,*.mhtml setf mason + +" Matlab or Objective C +au BufNewFile,BufRead *.m call s:FTm() + +func! s:FTm() + let n = 1 + while n < 10 + let line = getline(n) + if line =~ '^\s*\(#\s*\(include\|import\)\>\|/\*\|//\)' + setf objc + return + endif + if line =~ '^\s*%' + setf matlab + return + endif + if line =~ '^\s*(\*' + setf mma + return + endif + let n = n + 1 + endwhile + if exists("g:filetype_m") + exe "setf " . g:filetype_m + else + setf matlab + endif +endfunc + +" Mathematica notebook +au BufNewFile,BufRead *.nb setf mma + +" Maya Extension Language +au BufNewFile,BufRead *.mel setf mel + +" Mercurial config (looks like generic config file) +au BufNewFile,BufRead *.hgrc,*hgrc setf cfg + +" Messages +au BufNewFile,BufRead /var/log/messages,/var/log/messages.*[0-9] setf messages + +" Metafont +au BufNewFile,BufRead *.mf setf mf + +" MetaPost +au BufNewFile,BufRead *.mp setf mp + +" MGL +au BufNewFile,BufRead *.mgl setf mgl + +" MMIX or VMS makefile +au BufNewFile,BufRead *.mms call s:FTmms() + +" Symbian meta-makefile definition (MMP) +au BufNewFile,BufRead *.mmp setf mmp + +func! s:FTmms() + let n = 1 + while n < 10 + let line = getline(n) + if line =~ '^\s*\(%\|//\)' || line =~ '^\*' + setf mmix + return + endif + if line =~ '^\s*#' + setf make + return + endif + let n = n + 1 + endwhile + setf mmix +endfunc + + +" Modsim III (or LambdaProlog) +au BufNewFile,BufRead *.mod + \ if getline(1) =~ '\<module\>' | + \ setf lprolog | + \ else | + \ setf modsim3 | + \ endif + +" Modula 2 +au BufNewFile,BufRead *.m2,*.DEF,*.MOD,*.md,*.mi setf modula2 + +" Modula 3 (.m3, .i3, .mg, .ig) +au BufNewFile,BufRead *.[mi][3g] setf modula3 + +" Monk +au BufNewFile,BufRead *.isc,*.monk,*.ssc,*.tsc setf monk + +" MOO +au BufNewFile,BufRead *.moo setf moo + +" Modconf +au BufNewFile,BufRead /etc/modules.conf,/etc/conf.modules setf modconf +au BufNewFile,BufRead /etc/modutils/* + \ if executable(expand("<afile>")) != 1 + \| call s:StarSetf('modconf') + \|endif + +" Mplayer config +au BufNewFile,BufRead mplayer.conf,*/.mplayer/config setf mplayerconf + +" Moterola S record +au BufNewFile,BufRead *.s19,*.s28,*.s37 setf srec + +" Mrxvtrc +au BufNewFile,BufRead mrxvtrc,.mrxvtrc setf mrxvtrc + +" Msql +au BufNewFile,BufRead *.msql setf msql + +" Mysql +au BufNewFile,BufRead *.mysql setf mysql + +" M$ Resource files +au BufNewFile,BufRead *.rc setf rc + +" MuPAD source +au BufRead,BufNewFile *.mu setf mupad + +" Mush +au BufNewFile,BufRead *.mush setf mush + +" Mutt setup file (also for Muttng) +au BufNewFile,BufRead Mutt{ng,}rc setf muttrc + +" Nano +au BufNewFile,BufRead /etc/nanorc,.nanorc setf nanorc + +" Nastran input/DMAP +"au BufNewFile,BufRead *.dat setf nastran + +" Natural +au BufNewFile,BufRead *.NS[ACGLMNPS] setf natural + +" Netrc +au BufNewFile,BufRead .netrc setf netrc + +" Novell netware batch files +au BufNewFile,BufRead *.ncf setf ncf + +" Nroff/Troff (*.ms and *.t are checked below) +au BufNewFile,BufRead *.me + \ if expand("<afile>") != "read.me" && expand("<afile>") != "click.me" | + \ setf nroff | + \ endif +au BufNewFile,BufRead *.tr,*.nr,*.roff,*.tmac,*.mom setf nroff +au BufNewFile,BufRead *.[1-9] call s:FTnroff() + +" This function checks if one of the first five lines start with a dot. In +" that case it is probably an nroff file: 'filetype' is set and 1 is returned. +func! s:FTnroff() + if getline(1)[0] . getline(2)[0] . getline(3)[0] . getline(4)[0] . getline(5)[0] =~ '\.' + setf nroff + return 1 + endif + return 0 +endfunc + +" Nroff or Objective C++ +au BufNewFile,BufRead *.mm call s:FTmm() + +func! s:FTmm() + let n = 1 + while n < 10 + let line = getline(n) + if line =~ '^\s*\(#\s*\(include\|import\)\>\|/\*\)' + setf objcpp + return + endif + let n = n + 1 + endwhile + setf nroff +endfunc + +" Not Quite C +au BufNewFile,BufRead *.nqc setf nqc + +" NSIS +au BufNewFile,BufRead *.nsi setf nsis + +" OCAML +au BufNewFile,BufRead *.ml,*.mli,*.mll,*.mly setf ocaml + +" Occam +au BufNewFile,BufRead *.occ setf occam + +" Omnimark +au BufNewFile,BufRead *.xom,*.xin setf omnimark + +" OpenROAD +au BufNewFile,BufRead *.or setf openroad + +" OPL +au BufNewFile,BufRead *.[Oo][Pp][Ll] setf opl + +" Oracle config file +au BufNewFile,BufRead *.ora setf ora + +" Packet filter conf +au BufNewFile,BufRead pf.conf setf pf + +" Pam conf +au BufNewFile,BufRead /etc/pam.conf setf pamconf + +" PApp +au BufNewFile,BufRead *.papp,*.pxml,*.pxsl setf papp + +" Password file +au BufNewFile,BufRead /etc/passwd,/etc/passwd-,/etc/passwd.edit,/etc/shadow,/etc/shadow-,/var/backups/passwd.bak,/var/backups/shadow.bak setf passwd + +" Pascal (also *.p) +au BufNewFile,BufRead *.pas setf pascal + +" Delphi project file +au BufNewFile,BufRead *.dpr setf pascal + +" PDF +au BufNewFile,BufRead *.pdf setf pdf + +" Perl +if has("fname_case") + au BufNewFile,BufRead *.pl,*.PL call s:FTpl() +else + au BufNewFile,BufRead *.pl call s:FTpl() +endif +au BufNewFile,BufRead *.plx,*.al setf perl +au BufNewFile,BufRead *.p6,*.pm6 setf perl6 + +func! s:FTpl() + if exists("g:filetype_pl") + exe "setf " . g:filetype_pl + else + " recognize Prolog by specific text in the first non-empty line + " require a blank after the '%' because Perl uses "%list" and "%translate" + let l = getline(nextnonblank(1)) + if l =~ '\<prolog\>' || l =~ '^\s*\(%\+\(\s\|$\)\|/\*\)' || l =~ ':-' + setf prolog + else + setf perl + endif + endif +endfunc + +" Perl, XPM or XPM2 +au BufNewFile,BufRead *.pm + \ if getline(1) =~ "XPM2" | + \ setf xpm2 | + \ elseif getline(1) =~ "XPM" | + \ setf xpm | + \ else | + \ setf perl | + \ endif + +" Perl POD +au BufNewFile,BufRead *.pod setf pod + +" Php, php3, php4, etc. +" Also Phtml (was used for PHP 2 in the past) +" Also .ctp for Cake template file +au BufNewFile,BufRead *.php,*.php\d,*.phtml,*.ctp setf php + +" Pike +au BufNewFile,BufRead *.pike,*.lpc,*.ulpc,*.pmod setf pike + +" Pinfo config +au BufNewFile,BufRead */etc/pinforc,*/.pinforc setf pinfo + +" Palm Resource compiler +au BufNewFile,BufRead *.rcp setf pilrc + +" Pine config +au BufNewFile,BufRead .pinerc,pinerc,.pinercex,pinercex setf pine + +" PL/M (also: *.inp) +au BufNewFile,BufRead *.plm,*.p36,*.pac setf plm + +" PL/SQL +au BufNewFile,BufRead *.pls,*.plsql setf plsql + +" PLP +au BufNewFile,BufRead *.plp setf plp + +" PO and PO template (GNU gettext) +au BufNewFile,BufRead *.po,*.pot setf po + +" Postfix main config +au BufNewFile,BufRead main.cf setf pfmain + +" PostScript (+ font files, encapsulated PostScript, Adobe Illustrator) +au BufNewFile,BufRead *.ps,*.pfa,*.afm,*.eps,*.epsf,*.epsi,*.ai setf postscr + +" PostScript Printer Description +au BufNewFile,BufRead *.ppd setf ppd + +" Povray +au BufNewFile,BufRead *.pov setf pov + +" Povray configuration +au BufNewFile,BufRead .povrayrc setf povini + +" Povray, PHP or assembly +au BufNewFile,BufRead *.inc call s:FTinc() + +func! s:FTinc() + if exists("g:filetype_inc") + exe "setf " . g:filetype_inc + else + let lines = getline(1).getline(2).getline(3) + if lines =~? "perlscript" + setf aspperl + elseif lines =~ "<%" + setf aspvbs + elseif lines =~ "<?" + setf php + else + call s:FTasmsyntax() + if exists("b:asmsyntax") + exe "setf " . fnameescape(b:asmsyntax) + else + setf pov + endif + endif + endif +endfunc + +" Printcap and Termcap +au BufNewFile,BufRead *printcap + \ let b:ptcap_type = "print" | setf ptcap +au BufNewFile,BufRead *termcap + \ let b:ptcap_type = "term" | setf ptcap + +" PCCTS / ANTRL +"au BufNewFile,BufRead *.g setf antrl +au BufNewFile,BufRead *.g setf pccts + +" PPWizard +au BufNewFile,BufRead *.it,*.ih setf ppwiz + +" Obj 3D file format +" TODO: is there a way to avoid MS-Windows Object files? +au BufNewFile,BufRead *.obj setf obj + +" Oracle Pro*C/C++ +au BufNewFile,BufRead *.pc setf proc + +" Privoxy actions file +au BufNewFile,BufRead *.action setf privoxy + +" Procmail +au BufNewFile,BufRead .procmail,.procmailrc setf procmail + +" Progress or CWEB +au BufNewFile,BufRead *.w call s:FTprogress_cweb() + +func! s:FTprogress_cweb() + if exists("g:filetype_w") + exe "setf " . g:filetype_w + return + endif + if getline(1) =~ '&ANALYZE' || getline(3) =~ '&GLOBAL-DEFINE' + setf progress + else + setf cweb + endif +endfunc + +" Progress or assembly +au BufNewFile,BufRead *.i call s:FTprogress_asm() + +func! s:FTprogress_asm() + if exists("g:filetype_i") + exe "setf " . g:filetype_i + return + endif + " This function checks for an assembly comment the first ten lines. + " If not found, assume Progress. + let lnum = 1 + while lnum <= 10 && lnum < line('$') + let line = getline(lnum) + if line =~ '^\s*;' || line =~ '^\*' + call s:FTasm() + return + elseif line !~ '^\s*$' || line =~ '^/\*' + " Not an empty line: Doesn't look like valid assembly code. + " Or it looks like a Progress /* comment + break + endif + let lnum = lnum + 1 + endw + setf progress +endfunc + +" Progress or Pascal +au BufNewFile,BufRead *.p call s:FTprogress_pascal() + +func! s:FTprogress_pascal() + if exists("g:filetype_p") + exe "setf " . g:filetype_p + return + endif + " This function checks for valid Pascal syntax in the first ten lines. + " Look for either an opening comment or a program start. + " If not found, assume Progress. + let lnum = 1 + while lnum <= 10 && lnum < line('$') + let line = getline(lnum) + if line =~ '^\s*\(program\|unit\|procedure\|function\|const\|type\|var\)\>' + \ || line =~ '^\s*{' || line =~ '^\s*(\*' + setf pascal + return + elseif line !~ '^\s*$' || line =~ '^/\*' + " Not an empty line: Doesn't look like valid Pascal code. + " Or it looks like a Progress /* comment + break + endif + let lnum = lnum + 1 + endw + setf progress +endfunc + + +" Software Distributor Product Specification File (POSIX 1387.2-1995) +au BufNewFile,BufRead *.psf setf psf +au BufNewFile,BufRead INDEX,INFO + \ if getline(1) =~ '^\s*\(distribution\|installed_software\|root\|bundle\|product\)\s*$' | + \ setf psf | + \ endif + +" Prolog +au BufNewFile,BufRead *.pdb setf prolog + +" Promela +au BufNewFile,BufRead *.pml setf promela + +" Protocols +au BufNewFile,BufRead /etc/protocols setf protocols + +" Pyrex +au BufNewFile,BufRead *.pyx,*.pxd setf pyrex + +" Python +au BufNewFile,BufRead *.py,*.pyw setf python + +" Quixote (Python-based web framework) +au BufNewFile,BufRead *.ptl setf python + +" Radiance +au BufNewFile,BufRead *.rad,*.mat setf radiance + +" Ratpoison config/command files +au BufNewFile,BufRead .ratpoisonrc,ratpoisonrc setf ratpoison + +" RCS file +au BufNewFile,BufRead *\,v setf rcs + +" Readline +au BufNewFile,BufRead .inputrc,inputrc setf readline + +" Registry for MS-Windows +au BufNewFile,BufRead *.reg + \ if getline(1) =~? '^REGEDIT[0-9]*\s*$\|^Windows Registry Editor Version \d*\.\d*\s*$' | setf registry | endif + +" Renderman Interface Bytestream +au BufNewFile,BufRead *.rib setf rib + +" Rexx +au BufNewFile,BufRead *.rexx,*.rex,*.jrexx,*.rxj,*.orx setf rexx + +" R (Splus) +if has("fname_case") + au BufNewFile,BufRead *.s,*.S setf r +else + au BufNewFile,BufRead *.s setf r +endif + +" R Help file +if has("fname_case") + au BufNewFile,BufRead *.rd,*.Rd setf rhelp +else + au BufNewFile,BufRead *.rd setf rhelp +endif + +" R noweb file +if has("fname_case") + au BufNewFile,BufRead *.Rnw,*.rnw,*.Snw,*.snw setf rnoweb +else + au BufNewFile,BufRead *.rnw,*.snw setf rnoweb +endif + +" Rexx, Rebol or R +au BufNewFile,BufRead *.r,*.R call s:FTr() + +func! s:FTr() + let max = line("$") > 50 ? 50 : line("$") + + for n in range(1, max) + " Rebol is easy to recognize, check for that first + if getline(n) =~? '\<REBOL\>' + setf rebol + return + endif + endfor + + for n in range(1, max) + " R has # comments + if getline(n) =~ '^\s*#' + setf r + return + endif + " Rexx has /* comments */ + if getline(n) =~ '^\s*/\*' + setf rexx + return + endif + endfor + + " Nothing recognized, assume Rexx + setf rexx +endfunc + +" Remind +au BufNewFile,BufRead .reminders* call s:StarSetf('remind') +au BufNewFile,BufRead *.remind,*.rem setf remind + +" Resolv.conf +au BufNewFile,BufRead resolv.conf setf resolv + +" Relax NG Compact +au BufNewFile,BufRead *.rnc setf rnc + +" RPL/2 +au BufNewFile,BufRead *.rpl setf rpl + +" Robots.txt +au BufNewFile,BufRead robots.txt setf robots + +" Rpcgen +au BufNewFile,BufRead *.x setf rpcgen + +" reStructuredText Documentation Format +au BufNewFile,BufRead *.rst setf rst + +" RTF +au BufNewFile,BufRead *.rtf setf rtf + +" Interactive Ruby shell +au BufNewFile,BufRead .irbrc,irbrc setf ruby + +" Ruby +au BufNewFile,BufRead *.rb,*.rbw,*.gem,*.gemspec setf ruby + +" Ruby on Rails +au BufNewFile,BufRead *.builder,*.rxml,*.rjs setf ruby + +" Rantfile and Rakefile is like Ruby +au BufNewFile,BufRead [rR]antfile,*.rant,[rR]akefile,*.rake setf ruby + +" S-lang (or shader language, or SmallLisp) +au BufNewFile,BufRead *.sl setf slang + +" Samba config +au BufNewFile,BufRead smb.conf setf samba + +" SAS script +au BufNewFile,BufRead *.sas setf sas + +" Sass +au BufNewFile,BufRead *.sass setf sass + +" Sather +au BufNewFile,BufRead *.sa setf sather + +" Scilab +au BufNewFile,BufRead *.sci,*.sce setf scilab + +" SCSS +au BufNewFile,BufRead *.scss setf scss + +" SD: Streaming Descriptors +au BufNewFile,BufRead *.sd setf sd + +" SDL +au BufNewFile,BufRead *.sdl,*.pr setf sdl + +" sed +au BufNewFile,BufRead *.sed setf sed + +" Sieve (RFC 3028) +au BufNewFile,BufRead *.siv setf sieve + +" Sendmail +au BufNewFile,BufRead sendmail.cf setf sm + +" Sendmail .mc files are actually m4. Could also be MS Message text file. +au BufNewFile,BufRead *.mc call s:McSetf() + +func! s:McSetf() + " Rely on the file to start with a comment. + " MS message text files use ';', Sendmail files use '#' or 'dnl' + for lnum in range(1, min([line("$"), 20])) + let line = getline(lnum) + if line =~ '^\s*\(#\|dnl\)' + setf m4 " Sendmail .mc file + return + elseif line =~ '^\s*;' + setf msmessages " MS Message text file + return + endif + endfor + setf m4 " Default: Sendmail .mc file +endfunc + +" Services +au BufNewFile,BufRead /etc/services setf services + +" Service Location config +au BufNewFile,BufRead /etc/slp.conf setf slpconf + +" Service Location registration +au BufNewFile,BufRead /etc/slp.reg setf slpreg + +" Service Location SPI +au BufNewFile,BufRead /etc/slp.spi setf slpspi + +" Setserial config +au BufNewFile,BufRead /etc/serial.conf setf setserial + +" SGML +au BufNewFile,BufRead *.sgm,*.sgml + \ if getline(1).getline(2).getline(3).getline(4).getline(5) =~? 'linuxdoc' | + \ setf sgmllnx | + \ elseif getline(1) =~ '<!DOCTYPE.*DocBook' || getline(2) =~ '<!DOCTYPE.*DocBook' | + \ let b:docbk_type="sgml" | + \ setf docbk | + \ else | + \ setf sgml | + \ endif + +" SGMLDECL +au BufNewFile,BufRead *.decl,*.dcl,*.dec + \ if getline(1).getline(2).getline(3) =~? '^<!SGML' | + \ setf sgmldecl | + \ endif + +" SGML catalog file +au BufNewFile,BufRead catalog setf catalog +au BufNewFile,BufRead sgml.catalog* call s:StarSetf('catalog') + +" Shell scripts (sh, ksh, bash, bash2, csh); Allow .profile_foo etc. +" Gentoo ebuilds are actually bash scripts +au BufNewFile,BufRead .bashrc*,bashrc,bash.bashrc,.bash_profile*,.bash_logout*,*.bash,*.ebuild call SetFileTypeSH("bash") +au BufNewFile,BufRead .kshrc*,*.ksh call SetFileTypeSH("ksh") +au BufNewFile,BufRead /etc/profile,.profile*,*.sh,*.env call SetFileTypeSH(getline(1)) + +" Also called from scripts.vim. +func! SetFileTypeSH(name) + if expand("<amatch>") =~ g:ft_ignore_pat + return + endif + if a:name =~ '\<csh\>' + " Some .sh scripts contain #!/bin/csh. + call SetFileTypeShell("csh") + return + elseif a:name =~ '\<tcsh\>' + " Some .sh scripts contain #!/bin/tcsh. + call SetFileTypeShell("tcsh") + return + elseif a:name =~ '\<ksh\>' + let b:is_kornshell = 1 + if exists("b:is_bash") + unlet b:is_bash + endif + if exists("b:is_sh") + unlet b:is_sh + endif + elseif exists("g:bash_is_sh") || a:name =~ '\<bash\>' || a:name =~ '\<bash2\>' + let b:is_bash = 1 + if exists("b:is_kornshell") + unlet b:is_kornshell + endif + if exists("b:is_sh") + unlet b:is_sh + endif + elseif a:name =~ '\<sh\>' + let b:is_sh = 1 + if exists("b:is_kornshell") + unlet b:is_kornshell + endif + if exists("b:is_bash") + unlet b:is_bash + endif + endif + call SetFileTypeShell("sh") +endfunc + +" For shell-like file types, check for an "exec" command hidden in a comment, +" as used for Tcl. +" Also called from scripts.vim, thus can't be local to this script. +func! SetFileTypeShell(name) + if expand("<amatch>") =~ g:ft_ignore_pat + return + endif + let l = 2 + while l < 20 && l < line("$") && getline(l) =~ '^\s*\(#\|$\)' + " Skip empty and comment lines. + let l = l + 1 + endwhile + if l < line("$") && getline(l) =~ '\s*exec\s' && getline(l - 1) =~ '^\s*#.*\\$' + " Found an "exec" line after a comment with continuation + let n = substitute(getline(l),'\s*exec\s\+\([^ ]*/\)\=', '', '') + if n =~ '\<tclsh\|\<wish' + setf tcl + return + endif + endif + exe "setf " . a:name +endfunc + +" tcsh scripts +au BufNewFile,BufRead .tcshrc*,*.tcsh,tcsh.tcshrc,tcsh.login call SetFileTypeShell("tcsh") + +" csh scripts, but might also be tcsh scripts (on some systems csh is tcsh) +au BufNewFile,BufRead .login*,.cshrc*,csh.cshrc,csh.login,csh.logout,*.csh,.alias call s:CSH() + +func! s:CSH() + if exists("g:filetype_csh") + call SetFileTypeShell(g:filetype_csh) + elseif &shell =~ "tcsh" + call SetFileTypeShell("tcsh") + else + call SetFileTypeShell("csh") + endif +endfunc + +" Z-Shell script +au BufNewFile,BufRead .zprofile,/etc/zprofile,.zfbfmarks setf zsh +au BufNewFile,BufRead .zsh*,.zlog*,.zcompdump* call s:StarSetf('zsh') +au BufNewFile,BufRead *.zsh setf zsh + +" Scheme +au BufNewFile,BufRead *.scm,*.ss setf scheme + +" Screen RC +au BufNewFile,BufRead .screenrc,screenrc setf screen + +" Simula +au BufNewFile,BufRead *.sim setf simula + +" SINDA +au BufNewFile,BufRead *.sin,*.s85 setf sinda + +" SiSU +au BufNewFile,BufRead *.sst,*.ssm,*.ssi,*.-sst,*._sst setf sisu +au BufNewFile,BufRead *.sst.meta,*.-sst.meta,*._sst.meta setf sisu + +" SKILL +au BufNewFile,BufRead *.il,*.ils,*.cdf setf skill + +" SLRN +au BufNewFile,BufRead .slrnrc setf slrnrc +au BufNewFile,BufRead *.score setf slrnsc + +" Smalltalk (and TeX) +au BufNewFile,BufRead *.st setf st +au BufNewFile,BufRead *.cls + \ if getline(1) =~ '^%' | + \ setf tex | + \ else | + \ setf st | + \ endif + +" Smarty templates +au BufNewFile,BufRead *.tpl setf smarty + +" SMIL or XML +au BufNewFile,BufRead *.smil + \ if getline(1) =~ '<?\s*xml.*?>' | + \ setf xml | + \ else | + \ setf smil | + \ endif + +" SMIL or SNMP MIB file +au BufNewFile,BufRead *.smi + \ if getline(1) =~ '\<smil\>' | + \ setf smil | + \ else | + \ setf mib | + \ endif + +" SMITH +au BufNewFile,BufRead *.smt,*.smith setf smith + +" Snobol4 and spitbol +au BufNewFile,BufRead *.sno,*.spt setf snobol4 + +" SNMP MIB files +au BufNewFile,BufRead *.mib,*.my setf mib + +" Snort Configuration +au BufNewFile,BufRead *.hog,snort.conf,vision.conf setf hog +au BufNewFile,BufRead *.rules call s:FTRules() + +let s:ft_rules_udev_rules_pattern = '^\s*\cudev_rules\s*=\s*"\([^"]\{-1,}\)/*".*' +func! s:FTRules() + let path = expand('<amatch>:p') + if path =~ '^/etc/udev/\%(rules\.d/\)\=.*\.rules$' + setf udevrules + return + endif + if path =~ '^/etc/ufw/' + setf conf " Better than hog + return + endif + try + let config_lines = readfile('/etc/udev/udev.conf') + catch /^Vim\%((\a\+)\)\=:E484/ + setf hog + return + endtry + let dir = expand('<amatch>:p:h') + for line in config_lines + if line =~ s:ft_rules_udev_rules_pattern + let udev_rules = substitute(line, s:ft_rules_udev_rules_pattern, '\1', "") + if dir == udev_rules + setf udevrules + endif + break + endif + endfor + setf hog +endfunc + + +" Spec (Linux RPM) +au BufNewFile,BufRead *.spec setf spec + +" Speedup (AspenTech plant simulator) +au BufNewFile,BufRead *.speedup,*.spdata,*.spd setf spup + +" Slice +au BufNewFile,BufRead *.ice setf slice + +" Spice +au BufNewFile,BufRead *.sp,*.spice setf spice + +" Spyce +au BufNewFile,BufRead *.spy,*.spi setf spyce + +" Squid +au BufNewFile,BufRead squid.conf setf squid + +" SQL for Oracle Designer +au BufNewFile,BufRead *.tyb,*.typ,*.tyc,*.pkb,*.pks setf sql + +" SQL +au BufNewFile,BufRead *.sql call s:SQL() + +func! s:SQL() + if exists("g:filetype_sql") + exe "setf " . g:filetype_sql + else + setf sql + endif +endfunc + +" SQLJ +au BufNewFile,BufRead *.sqlj setf sqlj + +" SQR +au BufNewFile,BufRead *.sqr,*.sqi setf sqr + +" OpenSSH configuration +au BufNewFile,BufRead ssh_config,*/.ssh/config setf sshconfig + +" OpenSSH server configuration +au BufNewFile,BufRead sshd_config setf sshdconfig + +" Stata +au BufNewFile,BufRead *.ado,*.class,*.do,*.imata,*.mata setf stata + +" SMCL +au BufNewFile,BufRead *.hlp,*.ihlp,*.smcl setf smcl + +" Stored Procedures +au BufNewFile,BufRead *.stp setf stp + +" Standard ML +au BufNewFile,BufRead *.sml setf sml + +" Sratus VOS command macro +au BufNewFile,BufRead *.cm setf voscm + +" Sysctl +au BufNewFile,BufRead /etc/sysctl.conf setf sysctl + +" Synopsys Design Constraints +au BufNewFile,BufRead *.sdc setf sdc + +" Sudoers +au BufNewFile,BufRead /etc/sudoers,sudoers.tmp setf sudoers + +" SVG (Scalable Vector Graphics) +au BufNewFile,BufRead *.svg setf svg + +" If the file has an extension of 't' and is in a directory 't' then it is +" almost certainly a Perl test file. +" If the first line starts with '#' and contains 'perl' it's probably a Perl +" file. +" (Slow test) If a file contains a 'use' statement then it is almost certainly +" a Perl file. +func! s:FTperl() + if expand("%:e") == 't' && expand("%:p:h:t") == 't' + setf perl + return 1 + endif + if getline(1)[0] == '#' && getline(1) =~ 'perl' + setf perl + return 1 + endif + if search('^use\s\s*\k', 'nc', 30) + setf perl + return 1 + endif + return 0 +endfunc + +" Tads (or Nroff or Perl test file) +au BufNewFile,BufRead *.t + \ if !s:FTnroff() && !s:FTperl() | setf tads | endif + +" Tags +au BufNewFile,BufRead tags setf tags + +" TAK +au BufNewFile,BufRead *.tak setf tak + +" Task +au BufRead,BufNewFile {pending,completed,undo}.data setf taskdata +au BufRead,BufNewFile *.task setf taskedit + +" Tcl (JACL too) +au BufNewFile,BufRead *.tcl,*.tk,*.itcl,*.itk,*.jacl setf tcl + +" TealInfo +au BufNewFile,BufRead *.tli setf tli + +" Telix Salt +au BufNewFile,BufRead *.slt setf tsalt + +" Terminfo +au BufNewFile,BufRead *.ti setf terminfo + +" TeX +au BufNewFile,BufRead *.latex,*.sty,*.dtx,*.ltx,*.bbl setf tex +au BufNewFile,BufRead *.tex call s:FTtex() + +" Choose context, plaintex, or tex (LaTeX) based on these rules: +" 1. Check the first line of the file for "%&<format>". +" 2. Check the first 1000 non-comment lines for LaTeX or ConTeXt keywords. +" 3. Default to "latex" or to g:tex_flavor, can be set in user's vimrc. +func! s:FTtex() + let firstline = getline(1) + if firstline =~ '^%&\s*\a\+' + let format = tolower(matchstr(firstline, '\a\+')) + let format = substitute(format, 'pdf', '', '') + if format == 'tex' + let format = 'plain' + endif + else + " Default value, may be changed later: + let format = exists("g:tex_flavor") ? g:tex_flavor : 'plain' + " Save position, go to the top of the file, find first non-comment line. + let save_cursor = getpos('.') + call cursor(1,1) + let firstNC = search('^\s*[^[:space:]%]', 'c', 1000) + if firstNC " Check the next thousand lines for a LaTeX or ConTeXt keyword. + let lpat = 'documentclass\>\|usepackage\>\|begin{\|newcommand\>\|renewcommand\>' + 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\>' + let kwline = search('^\s*\\\%(' . lpat . '\)\|^\s*\\\(' . cpat . '\)', + \ 'cnp', firstNC + 1000) + if kwline == 1 " lpat matched + let format = 'latex' + elseif kwline == 2 " cpat matched + let format = 'context' + endif " If neither matched, keep default set above. + " let lline = search('^\s*\\\%(' . lpat . '\)', 'cn', firstNC + 1000) + " let cline = search('^\s*\\\%(' . cpat . '\)', 'cn', firstNC + 1000) + " if cline > 0 + " let format = 'context' + " endif + " if lline > 0 && (cline == 0 || cline > lline) + " let format = 'tex' + " endif + endif " firstNC + call setpos('.', save_cursor) + endif " firstline =~ '^%&\s*\a\+' + + " Translation from formats to file types. TODO: add AMSTeX, RevTex, others? + if format == 'plain' + setf plaintex + elseif format == 'context' + setf context + else " probably LaTeX + setf tex + endif + return +endfunc + +" ConTeXt +au BufNewFile,BufRead tex/context/*/*.tex,*.mkii,*.mkiv setf context + +" Texinfo +au BufNewFile,BufRead *.texinfo,*.texi,*.txi setf texinfo + +" TeX configuration +au BufNewFile,BufRead texmf.cnf setf texmf + +" Tidy config +au BufNewFile,BufRead .tidyrc,tidyrc setf tidy + +" TF mud client +au BufNewFile,BufRead *.tf,.tfrc,tfrc setf tf + +" TPP - Text Presentation Program +au BufNewFile,BufReadPost *.tpp setf tpp + +" Trustees +au BufNewFile,BufRead trustees.conf setf trustees + +" TSS - Geometry +au BufNewFile,BufReadPost *.tssgm setf tssgm + +" TSS - Optics +au BufNewFile,BufReadPost *.tssop setf tssop + +" TSS - Command Line (temporary) +au BufNewFile,BufReadPost *.tsscl setf tsscl + +" Motif UIT/UIL files +au BufNewFile,BufRead *.uit,*.uil setf uil + +" Udev conf +au BufNewFile,BufRead /etc/udev/udev.conf setf udevconf + +" Udev permissions +au BufNewFile,BufRead /etc/udev/permissions.d/*.permissions setf udevperm +" +" Udev symlinks config +au BufNewFile,BufRead /etc/udev/cdsymlinks.conf setf sh + +" UnrealScript +au BufNewFile,BufRead *.uc setf uc + +" Updatedb +au BufNewFile,BufRead /etc/updatedb.conf setf updatedb + +" Vera +au BufNewFile,BufRead *.vr,*.vri,*.vrh setf vera + +" Verilog HDL +au BufNewFile,BufRead *.v setf verilog + +" Verilog-AMS HDL +au BufNewFile,BufRead *.va,*.vams setf verilogams + +" VHDL +au BufNewFile,BufRead *.hdl,*.vhd,*.vhdl,*.vbe,*.vst setf vhdl +au BufNewFile,BufRead *.vhdl_[0-9]* call s:StarSetf('vhdl') + +" Vim script +au BufNewFile,BufRead *.vim,*.vba,.exrc,_exrc setf vim + +" Viminfo file +au BufNewFile,BufRead .viminfo,_viminfo setf viminfo + +" Virata Config Script File or Drupal module +au BufRead,BufNewFile *.hw,*.module,*.pkg + \ if getline(1) =~ '<?php' | + \ setf php | + \ else | + \ setf virata | + \ endif + +" Visual Basic (also uses *.bas) or FORM +au BufNewFile,BufRead *.frm call s:FTVB("form") + +" SaxBasic is close to Visual Basic +au BufNewFile,BufRead *.sba setf vb + +" Vgrindefs file +au BufNewFile,BufRead vgrindefs setf vgrindefs + +" VRML V1.0c +au BufNewFile,BufRead *.wrl setf vrml + +" Webmacro +au BufNewFile,BufRead *.wm setf webmacro + +" Wget config +au BufNewFile,BufRead .wgetrc,wgetrc setf wget + +" Website MetaLanguage +au BufNewFile,BufRead *.wml setf wml + +" Winbatch +au BufNewFile,BufRead *.wbt setf winbatch + +" WSML +au BufNewFile,BufRead *.wsml setf wsml + +" WvDial +au BufNewFile,BufRead wvdial.conf,.wvdialrc setf wvdial + +" CVS RC file +au BufNewFile,BufRead .cvsrc setf cvsrc + +" CVS commit file +au BufNewFile,BufRead cvs\d\+ setf cvs + +" WEB (*.web is also used for Winbatch: Guess, based on expecting "%" comment +" lines in a WEB file). +au BufNewFile,BufRead *.web + \ if getline(1)[0].getline(2)[0].getline(3)[0].getline(4)[0].getline(5)[0] =~ "%" | + \ setf web | + \ else | + \ setf winbatch | + \ endif + +" Windows Scripting Host and Windows Script Component +au BufNewFile,BufRead *.ws[fc] setf wsh + +" XHTML +au BufNewFile,BufRead *.xhtml,*.xht setf xhtml + +" X Pixmap (dynamically sets colors, use BufEnter to make it work better) +au BufEnter *.xpm + \ if getline(1) =~ "XPM2" | + \ setf xpm2 | + \ else | + \ setf xpm | + \ endif +au BufEnter *.xpm2 setf xpm2 + +" XFree86 config +au BufNewFile,BufRead XF86Config + \ if getline(1) =~ '\<XConfigurator\>' | + \ let b:xf86c_xfree86_version = 3 | + \ endif | + \ setf xf86conf + +" Xorg config +au BufNewFile,BufRead xorg.conf,xorg.conf-4 let b:xf86c_xfree86_version = 4 | setf xf86conf + +" Xinetd conf +au BufNewFile,BufRead /etc/xinetd.conf setf xinetd + +" XS Perl extension interface language +au BufNewFile,BufRead *.xs setf xs + +" X resources file +au BufNewFile,BufRead .Xdefaults,.Xpdefaults,.Xresources,xdm-config,*.ad setf xdefaults + +" Xmath +au BufNewFile,BufRead *.msc,*.msf setf xmath +au BufNewFile,BufRead *.ms + \ if !s:FTnroff() | setf xmath | endif + +" XML specific variants: docbk and xbl +au BufNewFile,BufRead *.xml call s:FTxml() + +func! s:FTxml() + let n = 1 + while n < 100 && n < line("$") + let line = getline(n) + if line =~ '<!DOCTYPE.*DocBook' + let b:docbk_type = "xml" + setf docbk + return + endif + if line =~ 'xmlns:xbl="http://www.mozilla.org/xbl"' + setf xbl + return + endif + let n += 1 + endwhile + setf xml +endfunc + +" XMI (holding UML models) is also XML +au BufNewFile,BufRead *.xmi setf xml + +" CSPROJ files are Visual Studio.NET's XML-based project config files +au BufNewFile,BufRead *.csproj,*.csproj.user setf xml + +" Qt Linguist translation source and Qt User Interface Files are XML +au BufNewFile,BufRead *.ts,*.ui setf xml + +" TPM's are RDF-based descriptions of TeX packages (Nikolai Weibull) +au BufNewFile,BufRead *.tpm setf xml + +" Xdg menus +au BufNewFile,BufRead /etc/xdg/menus/*.menu setf xml + +" ATI graphics driver configuration +au BufNewFile,BufRead fglrxrc setf xml + +" XLIFF (XML Localisation Interchange File Format) is also XML +au BufNewFile,BufRead *.xlf setf xml +au BufNewFile,BufRead *.xliff setf xml + +" X11 xmodmap (also see below) +au BufNewFile,BufRead *Xmodmap setf xmodmap + +" Xquery +au BufNewFile,BufRead *.xq,*.xql,*.xqm,*.xquery,*.xqy setf xquery + +" XSD +au BufNewFile,BufRead *.xsd setf xsd + +" Xslt +au BufNewFile,BufRead *.xsl,*.xslt setf xslt + +" Yacc +au BufNewFile,BufRead *.yy setf yacc + +" Yacc or racc +au BufNewFile,BufRead *.y call s:FTy() + +func! s:FTy() + let n = 1 + while n < 100 && n < line("$") + let line = getline(n) + if line =~ '^\s*%' + setf yacc + return + endif + if getline(n) =~ '^\s*\(#\|class\>\)' && getline(n) !~ '^\s*#\s*include' + setf racc + return + endif + let n = n + 1 + endwhile + setf yacc +endfunc + + +" Yaml +au BufNewFile,BufRead *.yaml,*.yml setf yaml + +" Zope +" dtml (zope dynamic template markup language), pt (zope page template), +" cpt (zope form controller page template) +au BufNewFile,BufRead *.dtml,*.pt,*.cpt call s:FThtml() +" zsql (zope sql method) +au BufNewFile,BufRead *.zsql call s:SQL() + +" Z80 assembler asz80 +au BufNewFile,BufRead *.z8a setf z8a + +augroup END + + +" Source the user-specified filetype file, for backwards compatibility with +" Vim 5.x. +if exists("myfiletypefile") && filereadable(expand(myfiletypefile)) + execute "source " . myfiletypefile +endif + + +" Check for "*" after loading myfiletypefile, so that scripts.vim is only used +" when there are no matching file name extensions. +" Don't do this for compressed files. +augroup filetypedetect +au BufNewFile,BufRead * + \ if !did_filetype() && expand("<amatch>") !~ g:ft_ignore_pat + \ | runtime! scripts.vim | endif +au StdinReadPost * if !did_filetype() | runtime! scripts.vim | endif + + +" Extra checks for when no filetype has been detected now. Mostly used for +" patterns that end in "*". E.g., "zsh*" matches "zsh.vim", but that's a Vim +" script file. +" Most of these should call s:StarSetf() to avoid names ending in .gz and the +" like are used. + +" More Apache files. +au BufNewFile,BufRead /etc/apache2/conf.*/*,/etc/apache2/sites-*/*,/etc/apache2/mods-*/* call s:StarSetf('apache') + +" Asterisk config file +au BufNewFile,BufRead *asterisk/*.conf* call s:StarSetf('asterisk') +au BufNewFile,BufRead *asterisk*/*voicemail.conf* call s:StarSetf('asteriskvm') + +" Bazaar version control +au BufNewFile,BufRead bzr_log.* setf bzr + +" BIND zone +au BufNewFile,BufRead */named/db.*,*/bind/db.* call s:StarSetf('bindzone') + +" Changelog +au BufNewFile,BufRead [cC]hange[lL]og* + \ if getline(1) =~ '; urgency=' + \| call s:StarSetf('debchangelog') + \|else + \| call s:StarSetf('changelog') + \|endif + +" Crontab +au BufNewFile,BufRead crontab,crontab.*,/etc/cron.d/* call s:StarSetf('crontab') + +" Debian Sources.list +au BufNewFile,BufRead /etc/apt/sources.list.d/* call s:StarSetf('debsources') + +" Dracula +au BufNewFile,BufRead drac.* call s:StarSetf('dracula') + +" Fvwm +au BufNewFile,BufRead */.fvwm/* call s:StarSetf('fvwm') +au BufNewFile,BufRead *fvwmrc*,*fvwm95*.hook + \ let b:fvwm_version = 1 | call s:StarSetf('fvwm') +au BufNewFile,BufRead *fvwm2rc* + \ if expand("<afile>:e") == "m4" + \| call s:StarSetf('fvwm2m4') + \|else + \| let b:fvwm_version = 2 | call s:StarSetf('fvwm') + \|endif + +" Gedcom +au BufNewFile,BufRead /tmp/lltmp* call s:StarSetf('gedcom') + +" GTK RC +au BufNewFile,BufRead .gtkrc*,gtkrc* call s:StarSetf('gtkrc') + +" Jam +au BufNewFile,BufRead Prl*.*,JAM*.* call s:StarSetf('jam') + +" Jargon +au! BufNewFile,BufRead *jarg* + \ if getline(1).getline(2).getline(3).getline(4).getline(5) =~? 'THIS IS THE JARGON FILE' + \| call s:StarSetf('jargon') + \|endif + +" Kconfig +au BufNewFile,BufRead Kconfig.* call s:StarSetf('kconfig') + +" Logcheck +au BufNewFile,BufRead /etc/logcheck/*.d*/* call s:StarSetf('logcheck') + +" Makefile +au BufNewFile,BufRead [mM]akefile* call s:StarSetf('make') + +" Ruby Makefile +au BufNewFile,BufRead [rR]akefile* call s:StarSetf('ruby') + +" Mail (also matches muttrc.vim, so this is below the other checks) +au BufNewFile,BufRead mutt[[:alnum:]._-]\{6\} setf mail + +" Modconf +au BufNewFile,BufRead /etc/modprobe.* call s:StarSetf('modconf') + +" Mutt setup file +au BufNewFile,BufRead .mutt{ng,}rc*,*/.mutt{ng,}/mutt{ng,}rc* call s:StarSetf('muttrc') +au BufNewFile,BufRead mutt{ng,}rc*,Mutt{ng,}rc* call s:StarSetf('muttrc') + +" Nroff macros +au BufNewFile,BufRead tmac.* call s:StarSetf('nroff') + +" Pam conf +au BufNewFile,BufRead /etc/pam.d/* call s:StarSetf('pamconf') + +" Printcap and Termcap +au BufNewFile,BufRead *printcap* + \ if !did_filetype() + \| let b:ptcap_type = "print" | call s:StarSetf('ptcap') + \|endif +au BufNewFile,BufRead *termcap* + \ if !did_filetype() + \| let b:ptcap_type = "term" | call s:StarSetf('ptcap') + \|endif + +" Vim script +au BufNewFile,BufRead *vimrc* call s:StarSetf('vim') + +" Subversion commit file +au BufNewFile,BufRead svn-commit*.tmp setf svn + +" X resources file +au BufNewFile,BufRead Xresources*,*/app-defaults/*,*/Xresources/* call s:StarSetf('xdefaults') + +" XFree86 config +au BufNewFile,BufRead XF86Config-4* + \ let b:xf86c_xfree86_version = 4 | call s:StarSetf('xf86conf') +au BufNewFile,BufRead XF86Config* + \ if getline(1) =~ '\<XConfigurator\>' + \| let b:xf86c_xfree86_version = 3 + \|endif + \|call s:StarSetf('xf86conf') + +" X11 xmodmap +au BufNewFile,BufRead *xmodmap* call s:StarSetf('xmodmap') + +" Xinetd conf +au BufNewFile,BufRead /etc/xinetd.d/* call s:StarSetf('xinetd') + +" Z-Shell script +au BufNewFile,BufRead zsh*,zlog* call s:StarSetf('zsh') + + + +" Use the filetype detect plugins. They may overrule any of the previously +" detected filetypes. +runtime! ftdetect/*.vim + + +" Generic configuration file (check this last, it's just guessing!) +au BufNewFile,BufRead,StdinReadPost * + \ if !did_filetype() && expand("<amatch>") !~ g:ft_ignore_pat + \ && (getline(1) =~ '^#' || getline(2) =~ '^#' || getline(3) =~ '^#' + \ || getline(4) =~ '^#' || getline(5) =~ '^#') | + \ setf conf | + \ endif + +augroup END + + +" If the GUI is already running, may still need to install the Syntax menu. +" Don't do it when the 'M' flag is included in 'guioptions'. +if has("menu") && has("gui_running") + \ && !exists("did_install_syntax_menu") && &guioptions !~# "M" + source <sfile>:p:h/menu.vim +endif + +" Function called for testing all functions defined here. These are +" script-local, thus need to be executed here. +" Returns a string with error messages (hopefully empty). +func! TestFiletypeFuncs(testlist) + let output = '' + for f in a:testlist + try + exe f + catch + let output = output . "\n" . f . ": " . v:exception + endtry + endfor + return output +endfunc + +" Restore 'cpoptions' +let &cpo = s:cpo_save +unlet s:cpo_save diff --git a/share/vim/vim72/ftoff.vim b/share/vim/vim73/ftoff.vim similarity index 100% rename from share/vim/vim72/ftoff.vim rename to share/vim/vim73/ftoff.vim diff --git a/share/vim/vim72/ftplugin.vim b/share/vim/vim73/ftplugin.vim similarity index 100% rename from share/vim/vim72/ftplugin.vim rename to share/vim/vim73/ftplugin.vim diff --git a/share/vim/vim72/ftplugin/README.txt b/share/vim/vim73/ftplugin/README.txt similarity index 100% rename from share/vim/vim72/ftplugin/README.txt rename to share/vim/vim73/ftplugin/README.txt diff --git a/share/vim/vim72/ftplugin/a2ps.vim b/share/vim/vim73/ftplugin/a2ps.vim similarity index 100% rename from share/vim/vim72/ftplugin/a2ps.vim rename to share/vim/vim73/ftplugin/a2ps.vim diff --git a/share/vim/vim72/ftplugin/aap.vim b/share/vim/vim73/ftplugin/aap.vim similarity index 100% rename from share/vim/vim72/ftplugin/aap.vim rename to share/vim/vim73/ftplugin/aap.vim diff --git a/share/vim/vim73/ftplugin/abaqus.vim b/share/vim/vim73/ftplugin/abaqus.vim new file mode 100644 index 0000000000..873b9bfaee --- /dev/null +++ b/share/vim/vim73/ftplugin/abaqus.vim @@ -0,0 +1,89 @@ +" Vim filetype plugin file +" Language: Abaqus finite element input file (www.abaqus.com) +" Maintainer: Carl Osterwisch <osterwischc@asme.org> +" Last Change: 2008 Oct 5 + +" Only do this when not done yet for this buffer +if exists("b:did_ftplugin") | finish | endif + +" Don't load another plugin for this buffer +let b:did_ftplugin = 1 + +" Save the compatibility options and temporarily switch to vim defaults +let s:cpo_save = &cpoptions +set cpoptions&vim + +" Set the format of the include file specification for Abaqus +" Used in :check gf ^wf [i and other commands +setlocal include=\\<\\cINPUT\\s*= + +" Remove characters up to the first = when evaluating filenames +setlocal includeexpr=substitute(v:fname,'.\\{-}=','','') + +" Remove comma from valid filename characters since it is used to +" separate keyword parameters +setlocal isfname-=, + +" Define format of comment lines (see 'formatoptions' for uses) +setlocal comments=:** +setlocal commentstring=**%s + +" Definitions start with a * and assign a NAME, NSET, or ELSET +" Used in [d ^wd and other commands +setlocal define=^\\*\\a.*\\c\\(NAME\\\|NSET\\\|ELSET\\)\\s*= + +" Abaqus keywords and identifiers may include a - character +setlocal iskeyword+=- + +let b:undo_ftplugin = "setlocal include< includeexpr< isfname<" + \ . " comments< commentstring< define< iskeyword<" + +if has("folding") + " Fold all lines that do not begin with * + setlocal foldexpr=getline(v:lnum)[0]!=\"\*\" + setlocal foldmethod=expr + let b:undo_ftplugin .= " foldexpr< foldmethod<" +endif + +" Set the file browse filter (currently only supported under Win32 gui) +if has("gui_win32") && !exists("b:browsefilter") + let b:browsefilter = "Abaqus Input Files (*.inp *.inc)\t*.inp;*.inc\n" . + \ "Abaqus Results (*.dat)\t*.dat\n" . + \ "Abaqus Messages (*.pre *.msg *.sta)\t*.pre;*.msg;*.sta\n" . + \ "All Files (*.*)\t*.*\n" + let b:undo_ftplugin .= "|unlet b:browsefilter" +endif + +" Define patterns for the matchit plugin +if exists("loaded_matchit") && !exists("b:match_words") + let b:match_ignorecase = 1 + let b:match_words = + \ '\*part:\*end\s*part,' . + \ '\*assembly:\*end\s*assembly,' . + \ '\*instance:\*end\s*instance,' . + \ '\*step:\*end\s*step' + let b:undo_ftplugin .= "|unlet b:match_ignorecase b:match_words" +endif + +" Define keys used to move [count] keywords backward or forward. +noremap <silent><buffer> [[ ?^\*\a<CR>:nohlsearch<CR> +noremap <silent><buffer> ]] /^\*\a<CR>:nohlsearch<CR> + +" Define key to toggle commenting of the current line or range +noremap <silent><buffer> <LocalLeader><LocalLeader> + \ :call <SID>Abaqus_ToggleComment()<CR>j +function! <SID>Abaqus_ToggleComment() range + if strpart(getline(a:firstline), 0, 2) == "**" + " Un-comment all lines in range + silent execute a:firstline . ',' . a:lastline . 's/^\*\*//' + else + " Comment all lines in range + silent execute a:firstline . ',' . a:lastline . 's/^/**/' + endif +endfunction + +let b:undo_ftplugin .= "|unmap <buffer> [[|unmap <buffer> ]]" + \ . "|unmap <buffer> <LocalLeader><LocalLeader>" + +" Restore saved compatibility options +let &cpoptions = s:cpo_save diff --git a/share/vim/vim72/ftplugin/ada.vim b/share/vim/vim73/ftplugin/ada.vim similarity index 100% rename from share/vim/vim72/ftplugin/ada.vim rename to share/vim/vim73/ftplugin/ada.vim diff --git a/share/vim/vim72/ftplugin/alsaconf.vim b/share/vim/vim73/ftplugin/alsaconf.vim similarity index 100% rename from share/vim/vim72/ftplugin/alsaconf.vim rename to share/vim/vim73/ftplugin/alsaconf.vim diff --git a/share/vim/vim73/ftplugin/ant.vim b/share/vim/vim73/ftplugin/ant.vim new file mode 100644 index 0000000000..648fca1be9 --- /dev/null +++ b/share/vim/vim73/ftplugin/ant.vim @@ -0,0 +1,43 @@ +" Vim filetype plugin file +" Language: ant +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "XML Files (*.xml)\t*.xml\n" . + \ "All Files (*.*)\t*.*\n" + +runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim +let b:did_ftplugin = 1 + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter +endif + +" Change the :browse e filter to primarily show Ant-related files. +if has("gui_win32") + let b:browsefilter = "Build Files (build.xml)\tbuild.xml\n" . + \ "Java Files (*.java)\t*.java\n" . + \ "Properties Files (*.prop*)\t*.prop*\n" . + \ "Manifest Files (*.mf)\t*.mf\n" . + \ s:browsefilter +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "unlet! b:browsefilter | " . s:undo_ftplugin + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/arch.vim b/share/vim/vim73/ftplugin/arch.vim similarity index 100% rename from share/vim/vim72/ftplugin/arch.vim rename to share/vim/vim73/ftplugin/arch.vim diff --git a/share/vim/vim72/ftplugin/art.vim b/share/vim/vim73/ftplugin/art.vim similarity index 100% rename from share/vim/vim72/ftplugin/art.vim rename to share/vim/vim73/ftplugin/art.vim diff --git a/share/vim/vim73/ftplugin/aspvbs.vim b/share/vim/vim73/ftplugin/aspvbs.vim new file mode 100644 index 0000000000..2b841efcff --- /dev/null +++ b/share/vim/vim73/ftplugin/aspvbs.vim @@ -0,0 +1,59 @@ +" Vim filetype plugin file +" Language: aspvbs +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "HTML Files (*.html, *.htm)\t*.htm*\n" . + \ "All Files (*.*)\t*.*\n" +let s:match_words = "" + +runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim +let b:did_ftplugin = 1 + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter +endif +if exists("b:match_words") + let s:match_words = b:match_words +endif + +" ASP: Active Server Pages (with Visual Basic Script) +" thanks to Gontran BAERTS +if exists("loaded_matchit") + let s:notend = '\%(\<end\s\+\)\@<!' + let b:match_ignorecase = 1 + let b:match_words = + \ s:notend . '\<if\>\%(.\{-}then\s\+\w\)\@!:\<elseif\>:^\s*\<else\>:\<end\s\+\<if\>,' . + \ s:notend . '\<select\s\+case\>:\<case\>:\<case\s\+else\>:\<end\s\+select\>,' . + \ '^\s*\<sub\>:\<end\s\+sub\>,' . + \ '^\s*\<function\>:\<end\s\+function\>,' . + \ '\<class\>:\<end\s\+class\>,' . + \ '^\s*\<do\>:\<loop\>,' . + \ '^\s*\<for\>:\<next\>,' . + \ '\<while\>:\<wend\>,' . + \ s:match_words +endif + +" Change the :browse e filter to primarily show ASP-related files. +if has("gui_win32") + let b:browsefilter="ASP Files (*.asp)\t*.asp\n" . s:browsefilter +endif + +let b:undo_ftplugin = "unlet! b:match_words b:match_ignorecase b:browsefilter | " . s:undo_ftplugin + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/automake.vim b/share/vim/vim73/ftplugin/automake.vim similarity index 100% rename from share/vim/vim72/ftplugin/automake.vim rename to share/vim/vim73/ftplugin/automake.vim diff --git a/share/vim/vim72/ftplugin/bdf.vim b/share/vim/vim73/ftplugin/bdf.vim similarity index 100% rename from share/vim/vim72/ftplugin/bdf.vim rename to share/vim/vim73/ftplugin/bdf.vim diff --git a/share/vim/vim72/ftplugin/bst.vim b/share/vim/vim73/ftplugin/bst.vim similarity index 100% rename from share/vim/vim72/ftplugin/bst.vim rename to share/vim/vim73/ftplugin/bst.vim diff --git a/share/vim/vim72/ftplugin/btm.vim b/share/vim/vim73/ftplugin/btm.vim similarity index 100% rename from share/vim/vim72/ftplugin/btm.vim rename to share/vim/vim73/ftplugin/btm.vim diff --git a/share/vim/vim72/ftplugin/c.vim b/share/vim/vim73/ftplugin/c.vim similarity index 100% rename from share/vim/vim72/ftplugin/c.vim rename to share/vim/vim73/ftplugin/c.vim diff --git a/share/vim/vim72/ftplugin/calendar.vim b/share/vim/vim73/ftplugin/calendar.vim similarity index 100% rename from share/vim/vim72/ftplugin/calendar.vim rename to share/vim/vim73/ftplugin/calendar.vim diff --git a/share/vim/vim72/ftplugin/cdrdaoconf.vim b/share/vim/vim73/ftplugin/cdrdaoconf.vim similarity index 100% rename from share/vim/vim72/ftplugin/cdrdaoconf.vim rename to share/vim/vim73/ftplugin/cdrdaoconf.vim diff --git a/share/vim/vim72/ftplugin/ch.vim b/share/vim/vim73/ftplugin/ch.vim similarity index 100% rename from share/vim/vim72/ftplugin/ch.vim rename to share/vim/vim73/ftplugin/ch.vim diff --git a/share/vim/vim73/ftplugin/changelog.vim b/share/vim/vim73/ftplugin/changelog.vim new file mode 100644 index 0000000000..30cd7b5d49 --- /dev/null +++ b/share/vim/vim73/ftplugin/changelog.vim @@ -0,0 +1,301 @@ +" Vim filetype plugin file +" Language: generic Changelog file +" Maintainer: Nikolai Weibull <now@bitwi.se> +" Latest Revision: 2009-05-25 +" Variables: +" g:changelog_timeformat (deprecated: use g:changelog_dateformat instead) - +" description: the timeformat used in ChangeLog entries. +" default: "%Y-%m-%d". +" g:changelog_dateformat - +" description: the format sent to strftime() to generate a date string. +" default: "%Y-%m-%d". +" g:changelog_username - +" description: the username to use in ChangeLog entries +" default: try to deduce it from environment variables and system files. +" Local Mappings: +" <Leader>o - +" adds a new changelog entry for the current user for the current date. +" Global Mappings: +" <Leader>o - +" switches to the ChangeLog buffer opened for the current directory, or +" opens it in a new buffer if it exists in the current directory. Then +" it does the same as the local <Leader>o described above. +" Notes: +" run 'runtime ftplugin/changelog.vim' to enable the global mapping for +" changelog files. +" TODO: +" should we perhaps open the ChangeLog file even if it doesn't exist already? +" Problem is that you might end up with ChangeLog files all over the place. + +" If 'filetype' isn't "changelog", we must have been to add ChangeLog opener +if &filetype == 'changelog' + if exists('b:did_ftplugin') + finish + endif + let b:did_ftplugin = 1 + + let s:cpo_save = &cpo + set cpo&vim + + " Set up the format used for dates. + if !exists('g:changelog_dateformat') + if exists('g:changelog_timeformat') + let g:changelog_dateformat = g:changelog_timeformat + else + let g:changelog_dateformat = "%Y-%m-%d" + endif + endif + + function! s:username() + if exists('g:changelog_username') + return g:changelog_username + elseif $EMAIL != "" + return $EMAIL + elseif $EMAIL_ADDRESS != "" + return $EMAIL_ADDRESS + endif + + let login = s:login() + return printf('%s <%s@%s>', s:name(login), login, s:hostname()) + endfunction + + function! s:login() + return s:trimmed_system_with_default('whoami', 'unknown') + endfunction + + function! s:trimmed_system_with_default(command, default) + return s:first_line(s:system_with_default(a:command, a:default)) + endfunction + + function! s:system_with_default(command, default) + let output = system(a:command) + if v:shell_error + return default + endif + return output + endfunction + + function! s:first_line(string) + return substitute(a:string, '\n.*$', "", "") + endfunction + + function! s:name(login) + for name in [s:gecos_name(a:login), $NAME, s:capitalize(a:login)] + if name != "" + return name + endif + endfor + endfunction + + function! s:gecos_name(login) + for line in s:try_reading_file('/etc/passwd') + if line =~ '^' . a:login . ':' + return substitute(s:passwd_field(line, 5), '&', s:capitalize(a:login), "") + endif + endfor + return "" + endfunction + + function! s:try_reading_file(path) + try + return readfile(a:path) + endtry + return [] + endfunction + + function! s:passwd_field(line, field) + let fields = split(a:line, ':', 1) + if len(fields) < field + return "" + endif + return fields[field - 1] + endfunction + + function! s:capitalize(word) + return toupper(a:word[0]) . strpart(a:word, 1) + endfunction + + function! s:hostname() + return s:trimmed_system_with_default('hostname', 'localhost') + endfunction + + " Format used for new date entries. + if !exists('g:changelog_new_date_format') + let g:changelog_new_date_format = "%d %u\n\n\t* %c\n\n" + endif + + " Format used for new entries to current date entry. + if !exists('g:changelog_new_entry_format') + let g:changelog_new_entry_format = "\t* %c" + endif + + " Regular expression used to find a given date entry. + if !exists('g:changelog_date_entry_search') + let g:changelog_date_entry_search = '^\s*%d\_s*%u' + endif + + " Regular expression used to find the end of a date entry + if !exists('g:changelog_date_end_entry_search') + let g:changelog_date_end_entry_search = '^\s*$' + endif + + + " Substitutes specific items in new date-entry formats and search strings. + " Can be done with substitute of course, but unclean, and need \@! then. + function! s:substitute_items(str, date, user) + let str = a:str + let middles = {'%': '%', 'd': a:date, 'u': a:user, 'c': '{cursor}'} + let i = stridx(str, '%') + while i != -1 + let inc = 0 + if has_key(middles, str[i + 1]) + let mid = middles[str[i + 1]] + let str = strpart(str, 0, i) . mid . strpart(str, i + 2) + let inc = strlen(mid) + endif + let i = stridx(str, '%', i + 1 + inc) + endwhile + return str + endfunction + + " Position the cursor once we've done all the funky substitution. + function! s:position_cursor() + if search('{cursor}') > 0 + let lnum = line('.') + let line = getline(lnum) + let cursor = stridx(line, '{cursor}') + call setline(lnum, substitute(line, '{cursor}', '', '')) + endif + startinsert! + endfunction + + " Internal function to create a new entry in the ChangeLog. + function! s:new_changelog_entry() + " Deal with 'paste' option. + let save_paste = &paste + let &paste = 1 + call cursor(1, 1) + " Look for an entry for today by our user. + let date = strftime(g:changelog_dateformat) + let search = s:substitute_items(g:changelog_date_entry_search, date, + \ g:changelog_username) + if search(search) > 0 + " Ok, now we look for the end of the date entry, and add an entry. + call cursor(nextnonblank(line('.') + 1), 1) + if search(g:changelog_date_end_entry_search, 'W') > 0 + let p = (line('.') == line('$')) ? line('.') : line('.') - 1 + else + let p = line('.') + endif + let ls = split(s:substitute_items(g:changelog_new_entry_format, '', ''), + \ '\n') + call append(p, ls) + call cursor(p + 1, 1) + else + " Flag for removing empty lines at end of new ChangeLogs. + let remove_empty = line('$') == 1 + + " No entry today, so create a date-user header and insert an entry. + let todays_entry = s:substitute_items(g:changelog_new_date_format, + \ date, g:changelog_username) + " Make sure we have a cursor positioning. + if stridx(todays_entry, '{cursor}') == -1 + let todays_entry = todays_entry . '{cursor}' + endif + + " Now do the work. + call append(0, split(todays_entry, '\n')) + + " Remove empty lines at end of file. + if remove_empty + $-/^\s*$/-1,$delete + endif + + " Reposition cursor once we're done. + call cursor(1, 1) + endif + + call s:position_cursor() + + " And reset 'paste' option + let &paste = save_paste + endfunction + + if exists(":NewChangelogEntry") != 2 + noremap <buffer> <silent> <Leader>o <Esc>:call <SID>new_changelog_entry()<CR> + command! -nargs=0 NewChangelogEntry call s:new_changelog_entry() + endif + + let b:undo_ftplugin = "setl com< fo< et< ai<" + + setlocal comments= + setlocal formatoptions+=t + setlocal noexpandtab + setlocal autoindent + + if &textwidth == 0 + setlocal textwidth=78 + let b:undo_ftplugin .= " tw<" + endif + + let &cpo = s:cpo_save + unlet s:cpo_save +else + let s:cpo_save = &cpo + set cpo&vim + + " Add the Changelog opening mapping + nnoremap <silent> <Leader>o :call <SID>open_changelog()<CR> + + function! s:open_changelog() + let path = expand('%:p:h') + if exists('b:changelog_path') + let changelog = b:changelog_path + else + if exists('b:changelog_name') + let name = b:changelog_name + else + let name = 'ChangeLog' + endif + while isdirectory(path) + let changelog = path . '/' . name + if filereadable(changelog) + break + endif + let parent = substitute(path, '/\+[^/]*$', "", "") + if path == parent + break + endif + let path = parent + endwhile + endif + if !filereadable(changelog) + return + endif + + if exists('b:changelog_entry_prefix') + let prefix = call(b:changelog_entry_prefix, []) + else + let prefix = substitute(strpart(expand('%:p'), strlen(path)), '^/\+', "", "") . ':' + endif + if !empty(prefix) + let prefix = ' ' . prefix + endif + + let buf = bufnr(changelog) + if buf != -1 + if bufwinnr(buf) != -1 + execute bufwinnr(buf) . 'wincmd w' + else + execute 'sbuffer' buf + endif + else + execute 'split' fnameescape(changelog) + endif + + call s:new_changelog_entry(prefix) + endfunction + + let &cpo = s:cpo_save + unlet s:cpo_save +endif diff --git a/share/vim/vim72/ftplugin/cobol.vim b/share/vim/vim73/ftplugin/cobol.vim similarity index 100% rename from share/vim/vim72/ftplugin/cobol.vim rename to share/vim/vim73/ftplugin/cobol.vim diff --git a/share/vim/vim72/ftplugin/conf.vim b/share/vim/vim73/ftplugin/conf.vim similarity index 100% rename from share/vim/vim72/ftplugin/conf.vim rename to share/vim/vim73/ftplugin/conf.vim diff --git a/share/vim/vim73/ftplugin/config.vim b/share/vim/vim73/ftplugin/config.vim new file mode 100644 index 0000000000..df607b1b1e --- /dev/null +++ b/share/vim/vim73/ftplugin/config.vim @@ -0,0 +1,41 @@ +" Vim filetype plugin file +" Language: config +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "Bourne Shell Files (*.sh)\t*.sh\n" . + \ "All Files (*.*)\t*.*\n" +let s:match_words = "" + +runtime! ftplugin/sh.vim ftplugin/sh_*.vim ftplugin/sh/*.vim +let b:did_ftplugin = 1 + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter +endif + +" Change the :browse e filter to primarily show configure-related files. +if has("gui_win32") + let b:browsefilter="Configure Scripts (configure.*, config.*)\tconfigure*;config.*\n" . + \ s:browsefilter +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "unlet! b:browsefilter | " . b:undo_ftplugin + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/context.vim b/share/vim/vim73/ftplugin/context.vim similarity index 100% rename from share/vim/vim72/ftplugin/context.vim rename to share/vim/vim73/ftplugin/context.vim diff --git a/share/vim/vim72/ftplugin/cpp.vim b/share/vim/vim73/ftplugin/cpp.vim similarity index 100% rename from share/vim/vim72/ftplugin/cpp.vim rename to share/vim/vim73/ftplugin/cpp.vim diff --git a/share/vim/vim72/ftplugin/crm.vim b/share/vim/vim73/ftplugin/crm.vim similarity index 100% rename from share/vim/vim72/ftplugin/crm.vim rename to share/vim/vim73/ftplugin/crm.vim diff --git a/share/vim/vim72/ftplugin/cs.vim b/share/vim/vim73/ftplugin/cs.vim similarity index 100% rename from share/vim/vim72/ftplugin/cs.vim rename to share/vim/vim73/ftplugin/cs.vim diff --git a/share/vim/vim73/ftplugin/csc.vim b/share/vim/vim73/ftplugin/csc.vim new file mode 100644 index 0000000000..ac02088105 --- /dev/null +++ b/share/vim/vim73/ftplugin/csc.vim @@ -0,0 +1,26 @@ +" Vim filetype plugin file +" Language: csc +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif +let b:did_ftplugin = 1 + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +if exists("loaded_matchit") + let b:match_words= + \ '\<fix\>:\<endfix\>,' . + \ '\<if\>:\<else\%(if\)\=\>:\<endif\>,' . + \ '\<!loopondimensions\>\|\<!looponselected\>:\<!endloop\>' +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "unlet! b:match_words" + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim73/ftplugin/csh.vim b/share/vim/vim73/ftplugin/csh.vim new file mode 100644 index 0000000000..3f89c72c20 --- /dev/null +++ b/share/vim/vim73/ftplugin/csh.vim @@ -0,0 +1,47 @@ +" Vim filetype plugin file +" Language: csh +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif +let b:did_ftplugin = 1 + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +setlocal commentstring=#%s +setlocal formatoptions-=t +setlocal formatoptions+=crql + +" Csh: thanks to Johannes Zellner +" - Both foreach and end must appear alone on separate lines. +" - The words else and endif must appear at the beginning of input lines; +" the if must appear alone on its input line or after an else. +" - Each case label and the default label must appear at the start of a +" line. +" - while and end must appear alone on their input lines. +if exists("loaded_matchit") + let b:match_words = + \ '^\s*\<if\>.*(.*).*\<then\>:'. + \ '^\s*\<else\>\s\+\<if\>.*(.*).*\<then\>:^\s*\<else\>:'. + \ '^\s*\<endif\>,'. + \ '\%(^\s*\<foreach\>\s\+\S\+\|^s*\<while\>\).*(.*):'. + \ '\<break\>:\<continue\>:^\s*\<end\>,'. + \ '^\s*\<switch\>.*(.*):^\s*\<case\>\s\+:^\s*\<default\>:^\s*\<endsw\>' +endif + +" Change the :browse e filter to primarily show csh-related files. +if has("gui_win32") + let b:browsefilter="csh Scripts (*.csh)\t*.csh\n" . + \ "All Files (*.*)\t*.*\n" +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "setlocal commentstring< formatoptions<" . + \ " | unlet! b:match_words b:browsefilter" + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/css.vim b/share/vim/vim73/ftplugin/css.vim similarity index 100% rename from share/vim/vim72/ftplugin/css.vim rename to share/vim/vim73/ftplugin/css.vim diff --git a/share/vim/vim73/ftplugin/cucumber.vim b/share/vim/vim73/ftplugin/cucumber.vim new file mode 100644 index 0000000000..a29d46a039 --- /dev/null +++ b/share/vim/vim73/ftplugin/cucumber.vim @@ -0,0 +1,132 @@ +" Vim filetype plugin +" Language: Cucumber +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 Aug 09 + +" Only do this when not done yet for this buffer +if (exists("b:did_ftplugin")) + finish +endif +let b:did_ftplugin = 1 + +setlocal formatoptions-=t formatoptions+=croql +setlocal comments=:# commentstring=#\ %s +setlocal omnifunc=CucumberComplete + +let b:undo_ftplugin = "setl fo< com< cms< ofu<" + +let b:cucumber_root = expand('%:p:h:s?.*[\/]\%(features\|stories\)\zs[\/].*??') + +if !exists("g:no_plugin_maps") && !exists("g:no_cucumber_maps") + nmap <silent><buffer> <C-]> :<C-U>exe <SID>jump('edit',v:count)<CR> + nmap <silent><buffer> <C-W>] :<C-U>exe <SID>jump('split',v:count)<CR> + nmap <silent><buffer> <C-W><C-]> :<C-U>exe <SID>jump('split',v:count)<CR> + nmap <silent><buffer> <C-W>} :<C-U>exe <SID>jump('pedit',v:count)<CR> + let b:undo_ftplugin .= "| sil! iunmap! <C-]>| sil! iunmap! <C-W>]| sil! iunmap! <C-W><C-]>| sil! iunmap! <C-W>}" +endif + +function! s:jump(command,count) + let steps = s:steps('.') + if len(steps) == 0 || len(steps) < a:count + return 'echoerr "No matching step found"' + elseif len(steps) > 1 && !a:count + return 'echoerr "Multiple matching steps found"' + else + let c = a:count ? a:count-1 : 0 + return a:command.' +'.steps[c][1].' '.escape(steps[c][0],' %#') + endif +endfunction + +function! s:allsteps() + let step_pattern = '\C^\s*\K\k*\>\s*\zs\S.\{-\}\ze\s*\%(do\|{\)\s*\%(|[^|]*|\s*\)\=\%($\|#\)' + let steps = [] + for file in split(glob(b:cucumber_root.'/**/*.rb'),"\n") + let lines = readfile(file) + let num = 0 + for line in lines + let num += 1 + if line =~ step_pattern + let type = matchstr(line,'\w\+') + let steps += [[file,num,type,matchstr(line,step_pattern)]] + endif + endfor + endfor + return steps +endfunction + +function! s:steps(lnum) + let c = indent(a:lnum) + 1 + while synIDattr(synID(a:lnum,c,1),'name') !~# '^$\|Region$' + let c = c + 1 + endwhile + let step = matchstr(getline(a:lnum)[c-1 : -1],'^\s*\zs.\{-\}\ze\s*$') + return filter(s:allsteps(),'s:stepmatch(v:val[3],step)') +endfunction + +function! s:stepmatch(receiver,target) + if a:receiver =~ '^[''"].*[''"]$' + let pattern = '^'.escape(substitute(a:receiver[1:-2],'$\w\+','(.*)','g'),'/').'$' + elseif a:receiver =~ '^/.*/$' + let pattern = a:receiver[1:-2] + elseif a:receiver =~ '^%r..*.$' + let pattern = escape(a:receiver[3:-2],'/') + else + return 0 + endif + try + let vimpattern = substitute(substitute(pattern,'\\\@<!(?:','%(','g'),'\\\@<!\*?','{-}','g') + if a:target =~# '\v'.vimpattern + return 1 + endif + catch + endtry + if has("ruby") && pattern !~ '\\\@<!#{' + ruby VIM.command("return #{if (begin; Kernel.eval('/'+VIM.evaluate('pattern')+'/'); rescue SyntaxError; end) === VIM.evaluate('a:target') then 1 else 0 end}") + else + return 0 + endif +endfunction + +function! s:bsub(target,pattern,replacement) + return substitute(a:target,'\C\\\@<!'.a:pattern,a:replacement,'g') +endfunction + +function! CucumberComplete(findstart,base) abort + let indent = indent('.') + let group = synIDattr(synID(line('.'),indent+1,1),'name') + let type = matchstr(group,'\Ccucumber\zs\%(Given\|When\|Then\)') + let e = matchend(getline('.'),'^\s*\S\+\s') + if type == '' || col('.') < col('$') || e < 0 + return -1 + endif + if a:findstart + return e + endif + let steps = [] + for step in s:allsteps() + if step[2] ==# type + if step[3] =~ '^[''"]' + let steps += [step[3][1:-2]] + elseif step[3] =~ '^/\^.*\$/$' + let pattern = step[3][2:-3] + let pattern = substitute(pattern,'\C^(?:|I )','I ','') + let pattern = s:bsub(pattern,'\\[Sw]','w') + let pattern = s:bsub(pattern,'\\d','1') + let pattern = s:bsub(pattern,'\\[sWD]',' ') + let pattern = s:bsub(pattern,'\[\^\\\="\]','_') + let pattern = s:bsub(pattern,'[[:alnum:]. _-][?*]?\=','') + let pattern = s:bsub(pattern,'\[\([^^]\).\{-\}\]','\1') + let pattern = s:bsub(pattern,'+?\=','') + let pattern = s:bsub(pattern,'(\([[:alnum:]. -]\{-\}\))','\1') + let pattern = s:bsub(pattern,'\\\([[:punct:]]\)','\1') + if pattern !~ '[\\()*?]' + let steps += [pattern] + endif + endif + endif + endfor + call filter(steps,'strpart(v:val,0,strlen(a:base)) ==# a:base') + return sort(steps) +endfunction + +" vim:set sts=2 sw=2: diff --git a/share/vim/vim72/ftplugin/cvsrc.vim b/share/vim/vim73/ftplugin/cvsrc.vim similarity index 100% rename from share/vim/vim72/ftplugin/cvsrc.vim rename to share/vim/vim73/ftplugin/cvsrc.vim diff --git a/share/vim/vim73/ftplugin/debchangelog.vim b/share/vim/vim73/ftplugin/debchangelog.vim new file mode 100644 index 0000000000..80ff8efe42 --- /dev/null +++ b/share/vim/vim73/ftplugin/debchangelog.vim @@ -0,0 +1,383 @@ +" Vim filetype plugin file (GUI menu, folding and completion) +" Language: Debian Changelog +" Maintainer: Debian Vim Maintainers <pkg-vim-maintainers@lists.alioth.debian.org> +" Former Maintainers: Michael Piefel <piefel@informatik.hu-berlin.de> +" Stefano Zacchiroli <zack@debian.org> +" Last Change: 2010-07-11 +" License: GNU GPL, version 2.0 or later +" URL: http://hg.debian.org/hg/pkg-vim/vim/file/unstable/runtime/ftplugin/debchangelog.vim + +" Bug completion requires apt-listbugs installed for Debian packages or +" python-launchpadlib installed for Ubuntu packages + +if exists("b:did_ftplugin") + finish +endif +let b:did_ftplugin=1 + +" {{{1 Local settings (do on every load) +if exists("g:debchangelog_fold_enable") + setlocal foldmethod=expr + setlocal foldexpr=DebGetChangelogFold(v:lnum) + setlocal foldtext=DebChangelogFoldText() +endif + +" Debian changelogs are not supposed to have any other text width, +" so the user cannot override this setting +setlocal tw=78 +setlocal comments=f:* + +" Clean unloading +let b:undo_ftplugin = "setlocal tw< comments< foldmethod< foldexpr< foldtext<" +" }}}1 + +if exists("g:did_changelog_ftplugin") + finish +endif + +" Don't load another plugin (this is global) +let g:did_changelog_ftplugin = 1 + +" {{{1 GUI menu + +" Helper functions returning various data. +" Returns full name, either from $DEBFULLNAME or debianfullname. +" TODO Is there a way to determine name from anywhere else? +function <SID>FullName() + if exists("$DEBFULLNAME") + return $DEBFULLNAME + elseif exists("g:debianfullname") + return g:debianfullname + else + return "Your Name" + endif +endfunction + +" Returns email address, from $DEBEMAIL, $EMAIL or debianemail. +function <SID>Email() + if exists("$DEBEMAIL") + return $DEBEMAIL + elseif exists("$EMAIL") + return $EMAIL + elseif exists("g:debianemail") + return g:debianemail + else + return "your@email.address" + endif +endfunction + +" Returns date in RFC822 format. +function <SID>Date() + let savelang = v:lc_time + execute "language time C" + let dateandtime = strftime("%a, %d %b %Y %X %z") + execute "language time " . savelang + return dateandtime +endfunction + +function <SID>WarnIfNotUnfinalised() + if match(getline("."), " -- [[:alpha:]][[:alnum:].]")!=-1 + echohl WarningMsg + echo "The entry has not been unfinalised before editing." + echohl None + return 1 + endif + return 0 +endfunction + +function <SID>Finalised() + let savelinenum = line(".") + normal 1G + call search("^ -- ") + if match(getline("."), " -- [[:alpha:]][[:alnum:].]")!=-1 + let returnvalue = 1 + else + let returnvalue = 0 + endif + execute savelinenum + return returnvalue +endfunction + +" These functions implement the menus +function NewVersion() + " The new entry is unfinalised and shall be changed + amenu disable Changelog.New\ Version + amenu enable Changelog.Add\ Entry + amenu enable Changelog.Close\ Bug + amenu enable Changelog.Set\ Distribution + amenu enable Changelog.Set\ Urgency + amenu disable Changelog.Unfinalise + amenu enable Changelog.Finalise + call append(0, substitute(getline(1), '-\([[:digit:]]\+\))', '-$$\1)', '')) + call append(1, "") + call append(2, "") + call append(3, " -- ") + call append(4, "") + call Urgency("low") + normal 1G0 + call search(")") + normal h + normal  + call setline(1, substitute(getline(1), '-\$\$', '-', '')) + if exists("g:debchangelog_fold_enable") + foldopen + endif + call AddEntry() +endfunction + +function AddEntry() + normal 1G + call search("^ -- ") + normal kk + call append(".", " * ") + normal jjj + let warn=<SID>WarnIfNotUnfinalised() + normal kk + if warn + echohl MoreMsg + call input("Hit ENTER") + echohl None + endif + startinsert! +endfunction + +function CloseBug() + normal 1G + call search("^ -- ") + let warn=<SID>WarnIfNotUnfinalised() + normal kk + call append(".", " * (closes: #" . input("Bug number to close: ") . ")") + normal j^ll + startinsert +endfunction + +function Distribution(dist) + call setline(1, substitute(getline(1), ") [[:lower:] ]*;", ") " . a:dist . ";", "")) +endfunction + +function Urgency(urg) + call setline(1, substitute(getline(1), "urgency=.*$", "urgency=" . a:urg, "")) +endfunction + +function <SID>UnfinaliseMenu() + " This means the entry shall be changed + amenu disable Changelog.New\ Version + amenu enable Changelog.Add\ Entry + amenu enable Changelog.Close\ Bug + amenu enable Changelog.Set\ Distribution + amenu enable Changelog.Set\ Urgency + amenu disable Changelog.Unfinalise + amenu enable Changelog.Finalise +endfunction + +function Unfinalise() + call <SID>UnfinaliseMenu() + normal 1G + call search("^ -- ") + call setline(".", " -- ") +endfunction + +function <SID>FinaliseMenu() + " This means the entry should not be changed anymore + amenu enable Changelog.New\ Version + amenu disable Changelog.Add\ Entry + amenu disable Changelog.Close\ Bug + amenu disable Changelog.Set\ Distribution + amenu disable Changelog.Set\ Urgency + amenu enable Changelog.Unfinalise + amenu disable Changelog.Finalise +endfunction + +function Finalise() + call <SID>FinaliseMenu() + normal 1G + call search("^ -- ") + call setline(".", " -- " . <SID>FullName() . " <" . <SID>Email() . "> " . <SID>Date()) +endfunction + + +function <SID>MakeMenu() + amenu &Changelog.&New\ Version :call NewVersion()<CR> + amenu Changelog.&Add\ Entry :call AddEntry()<CR> + amenu Changelog.&Close\ Bug :call CloseBug()<CR> + menu Changelog.-sep- <nul> + + amenu Changelog.Set\ &Distribution.&unstable :call Distribution("unstable")<CR> + amenu Changelog.Set\ Distribution.&frozen :call Distribution("frozen")<CR> + amenu Changelog.Set\ Distribution.&stable :call Distribution("stable")<CR> + menu Changelog.Set\ Distribution.-sep- <nul> + amenu Changelog.Set\ Distribution.frozen\ unstable :call Distribution("frozen unstable")<CR> + amenu Changelog.Set\ Distribution.stable\ unstable :call Distribution("stable unstable")<CR> + amenu Changelog.Set\ Distribution.stable\ frozen :call Distribution("stable frozen")<CR> + amenu Changelog.Set\ Distribution.stable\ frozen\ unstable :call Distribution("stable frozen unstable")<CR> + + amenu Changelog.Set\ &Urgency.&low :call Urgency("low")<CR> + amenu Changelog.Set\ Urgency.&medium :call Urgency("medium")<CR> + amenu Changelog.Set\ Urgency.&high :call Urgency("high")<CR> + + menu Changelog.-sep- <nul> + amenu Changelog.U&nfinalise :call Unfinalise()<CR> + amenu Changelog.&Finalise :call Finalise()<CR> + + if <SID>Finalised() + call <SID>FinaliseMenu() + else + call <SID>UnfinaliseMenu() + endif +endfunction + +augroup changelogMenu +au BufEnter * if &filetype == "debchangelog" | call <SID>MakeMenu() | endif +au BufLeave * if &filetype == "debchangelog" | silent! aunmenu Changelog | endif +augroup END + +" }}} +" {{{1 folding + +" look for an author name in the [zonestart zoneend] lines searching backward +function! s:getAuthor(zonestart, zoneend) + let linepos = a:zoneend + while linepos >= a:zonestart + let line = getline(linepos) + if line =~ '^ --' + return substitute(line, '^ --\s*\([^<]\+\)\s*.*', '\1', '') + endif + let linepos -= 1 + endwhile + return '[unknown]' +endfunction + +" Look for a package source name searching backward from the givenline and +" returns it. Return the empty string if the package name can't be found +function! DebGetPkgSrcName(lineno) + let lineidx = a:lineno + let pkgname = '' + while lineidx > 0 + let curline = getline(lineidx) + if curline =~ '^\S' + let pkgname = matchlist(curline, '^\(\S\+\).*$')[1] + break + endif + let lineidx = lineidx - 1 + endwhile + return pkgname +endfunction + +function! DebChangelogFoldText() + if v:folddashes == '-' " changelog entry fold + return foldtext() . ' -- ' . s:getAuthor(v:foldstart, v:foldend) . ' ' + endif + return foldtext() +endfunction + +function! DebGetChangelogFold(lnum) + let line = getline(a:lnum) + if line =~ '^\w\+' + return '>1' " beginning of a changelog entry + endif + if line =~ '^\s\+\[.*\]' + return '>2' " beginning of an author-specific chunk + endif + if line =~ '^ --' + return '1' + endif + return '=' +endfunction + +if exists("g:debchangelog_fold_enable") + silent! foldopen! " unfold the entry the cursor is on (usually the first one) +endif + +" }}} + +" {{{1 omnicompletion for Closes: # + +if !exists('g:debchangelog_listbugs_severities') + let g:debchangelog_listbugs_severities = 'critical,grave,serious,important,normal,minor,wishlist' +endif + +fun! DebCompleteBugs(findstart, base) + if a:findstart + let line = getline('.') + + " try to detect whether this is closes: or lp: + let g:debchangelog_complete_mode = 'debbugs' + let try_colidx = col('.') - 1 + let colidx = -1 " default to no-completion-possible + + while try_colidx > 0 && line[try_colidx - 1] =~ '\s\|\d\|#\|,\|:' + let try_colidx = try_colidx - 1 + if line[try_colidx] == '#' && colidx == -1 + " found hash, where we complete from: + let colidx = try_colidx + elseif line[try_colidx] == ':' + if try_colidx > 1 && strpart(line, try_colidx - 2, 3) =~ '\clp:' + let g:debchangelog_complete_mode = 'lp' + endif + break + endif + endwhile + return colidx + else " return matches: + let bug_lines = [] + if g:debchangelog_complete_mode == 'lp' + if ! has('python') + echoerr 'vim must be built with Python support to use LP bug completion' + return + endif + let pkgsrc = DebGetPkgSrcName(line('.')) + python << EOF +import vim +try: + from launchpadlib.launchpad import Launchpad + from lazr.restfulclient.errors import HTTPError + # login anonymously + lp = Launchpad.login_anonymously('debchangelog.vim', 'production') + ubuntu = lp.distributions['ubuntu'] + try: + sp = ubuntu.getSourcePackage(name=vim.eval('pkgsrc')) + status = ('New', 'Incomplete', 'Confirmed', 'Triaged', + 'In Progress', 'Fix Committed') + tasklist = sp.searchTasks(status=status, order_by='id') + liststr = '[' + for task in tasklist: + bug = task.bug + liststr += "'#%d - %s'," % (bug.id, bug.title.replace('\'', '\'\'')) + liststr += ']' + vim.command('silent let bug_lines = %s' % liststr.encode('utf-8')) + except HTTPError: + pass +except ImportError: + vim.command('echoerr \'python-launchpadlib >= 1.5.4 needs to be installed to use Launchpad bug completion\'') +EOF + else + if ! filereadable('/usr/sbin/apt-listbugs') + echoerr 'apt-listbugs not found, you should install it to use Closes bug completion' + return + endif + let pkgsrc = DebGetPkgSrcName(line('.')) + let listbugs_output = system('/usr/sbin/apt-listbugs -s ' . g:debchangelog_listbugs_severities . ' list ' . pkgsrc . ' | grep "^ #" 2> /dev/null') + let bug_lines = split(listbugs_output, '\n') + endif + let completions = [] + for line in bug_lines + let parts = matchlist(line, '^\s*\(#\S\+\)\s*-\s*\(.*\)$') + " filter only those which match a:base: + if parts[1] !~ "^" . a:base + continue + endif + let completion = {} + let completion['word'] = parts[1] + let completion['menu'] = parts[2] + let completion['info'] = parts[0] + let completions += [completion] + endfor + return completions + endif +endfun + +setlocal omnifunc=DebCompleteBugs + +" }}} + +" vim: set foldmethod=marker: diff --git a/share/vim/vim73/ftplugin/debcontrol.vim b/share/vim/vim73/ftplugin/debcontrol.vim new file mode 100644 index 0000000000..7871d9897f --- /dev/null +++ b/share/vim/vim73/ftplugin/debcontrol.vim @@ -0,0 +1,70 @@ +" Vim filetype plugin file (GUI menu and folding) +" Language: Debian control files +" Maintainer: Debian Vim Maintainers <pkg-vim-maintainers@lists.alioth.debian.org> +" Former Maintainer: Pierre Habouzit <madcoder@debian.org> +" Last Change: 2008-03-08 +" URL: http://hg.debian.org/hg/pkg-vim/vim/raw-file/tip/runtime/ftplugin/debcontrol.vim + +" Do these settings once per buffer +if exists("b:did_ftplugin") + finish +endif +let b:did_ftplugin=1 + +" {{{1 Local settings (do on every load) +if exists("g:debcontrol_fold_enable") + setlocal foldmethod=expr + setlocal foldexpr=DebControlFold(v:lnum) + setlocal foldtext=DebControlFoldText() +endif +setlocal textwidth=0 + +" Clean unloading +let b:undo_ftplugin = "setlocal tw< foldmethod< foldexpr< foldtext<" + +" }}}1 + +" {{{1 folding + +function! s:getField(f, lnum) + let line = getline(a:lnum) + let fwdsteps = 0 + while line !~ '^'.a:f.':' + let fwdsteps += 1 + let line = getline(a:lnum + fwdsteps) + if line == '' + return 'unknown' + endif + endwhile + return substitute(line, '^'.a:f.': *', '', '') +endfunction + +function! DebControlFoldText() + if v:folddashes == '-' " debcontrol entry fold + let type = substitute(getline(v:foldstart), ':.*', '', '') + if type == 'Source' + let ftext = substitute(foldtext(), ' *Source: *', ' ', '') + return ftext . ' -- ' . s:getField('Maintainer', v:foldstart) . ' ' + endif + let arch = s:getField('Architecture', v:foldstart) + let ftext = substitute(foldtext(), ' *Package: *', ' [' . arch . '] ', '') + return ftext . ': ' . s:getField('Description', v:foldstart) . ' ' + endif + return foldtext() +endfunction + +function! DebControlFold(l) + + " This is for not merging blank lines around folds to them + if getline(a:l) =~ '^Source:' + return '>1' + endif + + if getline(a:l) =~ '^Package:' + return '>1' + endif + + return '=' +endfunction + +" }}}1 diff --git a/share/vim/vim72/ftplugin/denyhosts.vim b/share/vim/vim73/ftplugin/denyhosts.vim similarity index 100% rename from share/vim/vim72/ftplugin/denyhosts.vim rename to share/vim/vim73/ftplugin/denyhosts.vim diff --git a/share/vim/vim72/ftplugin/dictconf.vim b/share/vim/vim73/ftplugin/dictconf.vim similarity index 100% rename from share/vim/vim72/ftplugin/dictconf.vim rename to share/vim/vim73/ftplugin/dictconf.vim diff --git a/share/vim/vim72/ftplugin/dictdconf.vim b/share/vim/vim73/ftplugin/dictdconf.vim similarity index 100% rename from share/vim/vim72/ftplugin/dictdconf.vim rename to share/vim/vim73/ftplugin/dictdconf.vim diff --git a/share/vim/vim72/ftplugin/diff.vim b/share/vim/vim73/ftplugin/diff.vim similarity index 100% rename from share/vim/vim72/ftplugin/diff.vim rename to share/vim/vim73/ftplugin/diff.vim diff --git a/share/vim/vim72/ftplugin/dircolors.vim b/share/vim/vim73/ftplugin/dircolors.vim similarity index 100% rename from share/vim/vim72/ftplugin/dircolors.vim rename to share/vim/vim73/ftplugin/dircolors.vim diff --git a/share/vim/vim73/ftplugin/dosbatch.vim b/share/vim/vim73/ftplugin/dosbatch.vim new file mode 100644 index 0000000000..6e581e7e0f --- /dev/null +++ b/share/vim/vim73/ftplugin/dosbatch.vim @@ -0,0 +1,21 @@ +" Vim filetype plugin file +" Language: MS-DOS .bat files +" Maintainer: Mike Williams <mrw@eandem.co.uk> +" Last Change: 27th May 2009 + +" Only do this when not done yet for this buffer +if exists("b:did_ftplugin") + finish +endif + +" Don't load another plugin for this buffer +let b:did_ftplugin = 1 + +" BAT comment formatting +setlocal comments=b:rem,b:@rem,b:REM,b:@REM,::: +setlocal formatoptions-=t formatoptions+=rol + +" Define patterns for the browse file filter +if has("gui_win32") && !exists("b:browsefilter") + let b:browsefilter = "DOS Batch Files (*.bat, *.cmd)\t*.bat;*.cmd\nAll Files (*.*)\t*.*\n" +endif diff --git a/share/vim/vim72/ftplugin/dosini.vim b/share/vim/vim73/ftplugin/dosini.vim similarity index 100% rename from share/vim/vim72/ftplugin/dosini.vim rename to share/vim/vim73/ftplugin/dosini.vim diff --git a/share/vim/vim73/ftplugin/dtd.vim b/share/vim/vim73/ftplugin/dtd.vim new file mode 100644 index 0000000000..eed5ca6ac4 --- /dev/null +++ b/share/vim/vim73/ftplugin/dtd.vim @@ -0,0 +1,39 @@ +" Vim filetype plugin file +" Language: dtd +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif +let b:did_ftplugin = 1 + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +setlocal commentstring=<!--%s--> +setlocal comments=s:<!--,m:\ \ \ \ \ ,e:--> + +setlocal formatoptions-=t +if !exists("g:ft_dtd_autocomment") || (g:ft_dtd_autocomment == 1) + setlocal formatoptions+=croql +endif + +if exists("loaded_matchit") + let b:match_words = '<!--:-->,<!:>' +endif + +" Change the :browse e filter to primarily show Java-related files. +if has("gui_win32") + let b:browsefilter="DTD Files (*.dtd)\t*.dtd\n" . + \ "XML Files (*.xml)\t*.xml\n" . + \ "All Files (*.*)\t*.*\n" +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "setlocal commentstring< comments< formatoptions<" . + \ " | unlet! b:matchwords b:browsefilter" + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/dtrace.vim b/share/vim/vim73/ftplugin/dtrace.vim similarity index 100% rename from share/vim/vim72/ftplugin/dtrace.vim rename to share/vim/vim73/ftplugin/dtrace.vim diff --git a/share/vim/vim72/ftplugin/elinks.vim b/share/vim/vim73/ftplugin/elinks.vim similarity index 100% rename from share/vim/vim72/ftplugin/elinks.vim rename to share/vim/vim73/ftplugin/elinks.vim diff --git a/share/vim/vim73/ftplugin/eruby.vim b/share/vim/vim73/ftplugin/eruby.vim new file mode 100644 index 0000000000..7c19a09aa3 --- /dev/null +++ b/share/vim/vim73/ftplugin/eruby.vim @@ -0,0 +1,104 @@ +" Vim filetype plugin +" Language: eRuby +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 Apr 15 +" URL: http://vim-ruby.rubyforge.org +" Anon CVS: See above site +" Release Coordinator: Doug Kearns <dougkearns@gmail.com> + +" Only do this when not done yet for this buffer +if exists("b:did_ftplugin") + finish +endif + +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "All Files (*.*)\t*.*\n" +let s:match_words = "" + +if !exists("g:eruby_default_subtype") + let g:eruby_default_subtype = "html" +endif + +if !exists("b:eruby_subtype") + let s:lines = getline(1)."\n".getline(2)."\n".getline(3)."\n".getline(4)."\n".getline(5)."\n".getline("$") + let b:eruby_subtype = matchstr(s:lines,'eruby_subtype=\zs\w\+') + if b:eruby_subtype == '' + let b:eruby_subtype = matchstr(&filetype,'^eruby\.\zs\w\+') + endif + if b:eruby_subtype == '' + let b:eruby_subtype = matchstr(substitute(expand("%:t"),'\c\%(\.erb\|\.eruby\|\.erubis\)\+$','',''),'\.\zs\w\+$') + endif + if b:eruby_subtype == 'rhtml' + let b:eruby_subtype = 'html' + elseif b:eruby_subtype == 'rb' + let b:eruby_subtype = 'ruby' + elseif b:eruby_subtype == 'yml' + let b:eruby_subtype = 'yaml' + elseif b:eruby_subtype == 'js' + let b:eruby_subtype = 'javascript' + elseif b:eruby_subtype == 'txt' + " Conventional; not a real file type + let b:eruby_subtype = 'text' + elseif b:eruby_subtype == '' + let b:eruby_subtype = g:eruby_default_subtype + endif +endif + +if exists("b:eruby_subtype") && b:eruby_subtype != '' + exe "runtime! ftplugin/".b:eruby_subtype.".vim ftplugin/".b:eruby_subtype."_*.vim ftplugin/".b:eruby_subtype."/*.vim" +else + runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim +endif +unlet! b:did_ftplugin + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin + unlet b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter + unlet b:browsefilter +endif +if exists("b:match_words") + let s:match_words = b:match_words + unlet b:match_words +endif + +runtime! ftplugin/ruby.vim ftplugin/ruby_*.vim ftplugin/ruby/*.vim +let b:did_ftplugin = 1 + +" Combine the new set of values with those previously included. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin . " | " . s:undo_ftplugin +endif +if exists ("b:browsefilter") + let s:browsefilter = substitute(b:browsefilter,'\cAll Files (\*\.\*)\t\*\.\*\n','','') . s:browsefilter +endif +if exists("b:match_words") + let s:match_words = b:match_words . ',' . s:match_words +endif + +" Change the browse dialog on Win32 to show mainly eRuby-related files +if has("gui_win32") + let b:browsefilter="eRuby Files (*.erb, *.rhtml)\t*.erb;*.rhtml\n" . s:browsefilter +endif + +" Load the combined list of match_words for matchit.vim +if exists("loaded_matchit") + let b:match_words = s:match_words +endif + +" TODO: comments= +setlocal commentstring=<%#%s%> + +let b:undo_ftplugin = "setl cms< " + \ " | unlet! b:browsefilter b:match_words | " . s:undo_ftplugin + +let &cpo = s:save_cpo + +" vim: nowrap sw=2 sts=2 ts=8: diff --git a/share/vim/vim72/ftplugin/eterm.vim b/share/vim/vim73/ftplugin/eterm.vim similarity index 100% rename from share/vim/vim72/ftplugin/eterm.vim rename to share/vim/vim73/ftplugin/eterm.vim diff --git a/share/vim/vim72/ftplugin/fetchmail.vim b/share/vim/vim73/ftplugin/fetchmail.vim similarity index 100% rename from share/vim/vim72/ftplugin/fetchmail.vim rename to share/vim/vim73/ftplugin/fetchmail.vim diff --git a/share/vim/vim72/ftplugin/flexwiki.vim b/share/vim/vim73/ftplugin/flexwiki.vim similarity index 100% rename from share/vim/vim72/ftplugin/flexwiki.vim rename to share/vim/vim73/ftplugin/flexwiki.vim diff --git a/share/vim/vim73/ftplugin/fortran.vim b/share/vim/vim73/ftplugin/fortran.vim new file mode 100644 index 0000000000..741465da18 --- /dev/null +++ b/share/vim/vim73/ftplugin/fortran.vim @@ -0,0 +1,118 @@ +" Vim settings file +" Language: Fortran90 (and Fortran95, Fortran77, F and elf90) +" Version: 0.46 +" Last Change: 2010 July 24 +" Maintainer: Ajit J. Thakkar <ajit@unb.ca>; <http://www.unb.ca/chem/ajit/> +" Usage: Do :help fortran-plugin from Vim +" Credits: +" Useful suggestions were made by Stefano Zacchiroli and Hendrik Merx. + +" Only do these settings when not done yet for this buffer +if exists("b:did_ftplugin") + finish +endif + +" Don't do other file type settings for this buffer +let b:did_ftplugin = 1 + +" Determine whether this is a fixed or free format source file +" if this hasn't been done yet +if !exists("b:fortran_fixed_source") + if exists("fortran_free_source") + " User guarantees free source form + let b:fortran_fixed_source = 0 + elseif exists("fortran_fixed_source") + " User guarantees fixed source form + let b:fortran_fixed_source = 1 + else + " f90 and f95 allow both fixed and free source form + " assume fixed source form unless signs of free source form + " are detected in the first five columns of the first s:lmax lines + " Detection becomes more accurate and time-consuming if more lines + " are checked. Increase the limit below if you keep lots of comments at + " the very top of each file and you have a fast computer + let s:lmax = 500 + if ( s:lmax > line("$") ) + let s:lmax = line("$") + endif + let b:fortran_fixed_source = 1 + let s:ln=1 + while s:ln <= s:lmax + let s:test = strpart(getline(s:ln),0,5) + if s:test !~ '^[Cc*]' && s:test !~ '^ *[!#]' && s:test =~ '[^ 0-9\t]' && s:test !~ '^[ 0-9]*\t' + let b:fortran_fixed_source = 0 + break + endif + let s:ln = s:ln + 1 + endwhile + unlet! s:lmax s:ln s:test + endif +endif + +" Set comments and textwidth according to source type +if (b:fortran_fixed_source == 1) + setlocal comments=:!,:*,:C + " Fixed format requires a textwidth of 72 for code + setlocal tw=72 + " If you need to add "&" on continued lines so that the code is + " compatible with both free and fixed format, then you should do so + " in column 73 and uncomment the next line + " setlocal tw=73 +else + setlocal comments=:! + " Free format allows a textwidth of 132 for code but 80 is more usual + setlocal tw=80 +endif + +" Set commentstring for foldmethod=marker +setlocal cms=!%s + +" Tabs are not a good idea in Fortran so the default is to expand tabs +if !exists("fortran_have_tabs") + setlocal expandtab +endif + +" Set 'formatoptions' to break comment and text lines but allow long lines +setlocal fo+=tcql + +setlocal include=^\\c#\\=\\s*include\\s\\+ +setlocal suffixesadd+=.f95,.f90,.for,.f,.F,.f77,.ftn,.fpp + +let s:cposet=&cpoptions +set cpoptions-=C + +" Define patterns for the matchit plugin +if !exists("b:match_words") + let s:notend = '\%(\<end\s\+\)\@<!' + let s:notselect = '\%(\<select\s\+\)\@<!' + let s:notelse = '\%(\<end\s\+\|\<else\s\+\)\@<!' + let s:notprocedure = '\%(\s\+procedure\>\)\@!' + let b:match_ignorecase = 1 + let b:match_words = + \ '\<select\s*case\>:' . s:notselect. '\<case\>:\<end\s*select\>,' . + \ s:notelse . '\<if\s*(.\+)\s*then\>:' . + \ '\<else\s*\%(if\s*(.\+)\s*then\)\=\>:\<end\s*if\>,'. + \ 'do\s\+\(\d\+\):\%(^\s*\)\@<=\1\s,'. + \ s:notend . '\<do\>:\<end\s*do\>,'. + \ s:notelse . '\<where\>:\<elsewhere\>:\<end\s*where\>,'. + \ s:notend . '\<type\s*[^(]:\<end\s*type\>,'. + \ s:notend . '\<interface\>:\<end\s*interface\>,'. + \ s:notend . '\<subroutine\>:\<end\s*subroutine\>,'. + \ s:notend . '\<function\>:\<end\s*function\>,'. + \ s:notend . '\<module\>' . s:notprocedure . ':\<end\s*module\>,'. + \ s:notend . '\<program\>:\<end\s*program\>' +endif + +" File filters for :browse e +if has("gui_win32") && !exists("b:browsefilter") + let b:browsefilter = "Fortran Files (*.f;*.F;*.for;*.f77;*.f90;*.f95;*.fpp;*.ftn)\t*.f;*.F;*.for;*.f77;*.f90;*.f95;*.fpp;*.ftn\n" . + \ "All Files (*.*)\t*.*\n" +endif + +let b:undo_ftplugin = "setl fo< com< tw< cms< et< inc<" + \ . "| unlet! b:match_ignorecase b:match_words b:browsefilter" + +let &cpoptions=s:cposet +unlet s:cposet + +" vim:sw=2 diff --git a/share/vim/vim72/ftplugin/framescript.vim b/share/vim/vim73/ftplugin/framescript.vim similarity index 100% rename from share/vim/vim72/ftplugin/framescript.vim rename to share/vim/vim73/ftplugin/framescript.vim diff --git a/share/vim/vim72/ftplugin/fvwm.vim b/share/vim/vim73/ftplugin/fvwm.vim similarity index 100% rename from share/vim/vim72/ftplugin/fvwm.vim rename to share/vim/vim73/ftplugin/fvwm.vim diff --git a/share/vim/vim73/ftplugin/git.vim b/share/vim/vim73/ftplugin/git.vim new file mode 100644 index 0000000000..e043c7587e --- /dev/null +++ b/share/vim/vim73/ftplugin/git.vim @@ -0,0 +1,37 @@ +" Vim filetype plugin +" Language: generic git output +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 21 + +" Only do this when not done yet for this buffer +if (exists("b:did_ftplugin")) + finish +endif +let b:did_ftplugin = 1 + +if !exists('b:git_dir') + if expand('%:p') =~# '\.git\>' + let b:git_dir = matchstr(expand('%:p'),'.*\.git\>') + elseif $GIT_DIR != '' + let b:git_dir = $GIT_DIR + endif + if (has('win32') || has('win64')) && exists('b:git_dir') + let b:git_dir = substitute(b:git_dir,'\\','/','g') + endif +endif + +if exists('*shellescape') && exists('b:git_dir') && b:git_dir != '' + if b:git_dir =~# '/\.git$' " Not a bare repository + let &l:path = escape(fnamemodify(b:git_dir,':h'),'\, ').','.&l:path + endif + let &l:path = escape(b:git_dir,'\, ').','.&l:path + let &l:keywordprg = 'git --git-dir='.shellescape(b:git_dir).' show' +else + setlocal keywordprg=git\ show +endif +if has('gui_running') + let &l:keywordprg = substitute(&l:keywordprg,'^git\>','git --no-pager','') +endif + +setlocal includeexpr=substitute(v:fname,'^[^/]\\+/','','') +let b:undo_ftplugin = "setl keywordprg< path< includeexpr<" diff --git a/share/vim/vim73/ftplugin/gitcommit.vim b/share/vim/vim73/ftplugin/gitcommit.vim new file mode 100644 index 0000000000..94d635c5dd --- /dev/null +++ b/share/vim/vim73/ftplugin/gitcommit.vim @@ -0,0 +1,68 @@ +" Vim filetype plugin +" Language: git commit file +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 21 + +" Only do this when not done yet for this buffer +if (exists("b:did_ftplugin")) + finish +endif + +runtime! ftplugin/git.vim +let b:did_ftplugin = 1 + +if &textwidth == 0 + " make sure that log messages play nice with git-log on standard terminals + setlocal textwidth=72 + if !exists("b:undo_ftplugin") + let b:undo_ftplugin = "" + endif + let b:undo_ftplugin = b:undo_ftplugin . "|setl tw<" +endif + +if exists("g:no_gitcommit_commands") || v:version < 700 + finish +endif + +if !exists("b:git_dir") + let b:git_dir = expand("%:p:h") +endif + +" Automatically diffing can be done with: +" autocmd FileType gitcommit DiffGitCached | wincmd p +command! -bang -bar -buffer -complete=custom,s:diffcomplete -nargs=* DiffGitCached :call s:gitdiffcached(<bang>0,b:git_dir,<f-args>) + +function! s:diffcomplete(A,L,P) + let args = "" + if a:P <= match(a:L." -- "," -- ")+3 + let args = args . "-p\n--stat\n--shortstat\n--summary\n--patch-with-stat\n--no-renames\n-B\n-M\n-C\n" + end + if exists("b:git_dir") && a:A !~ '^-' + let tree = fnamemodify(b:git_dir,':h') + if strpart(getcwd(),0,strlen(tree)) == tree + let args = args."\n".system("git diff --cached --name-only") + endif + endif + return args +endfunction + +function! s:gitdiffcached(bang,gitdir,...) + let tree = fnamemodify(a:gitdir,':h') + let name = tempname() + let git = "git" + if strpart(getcwd(),0,strlen(tree)) != tree + let git .= " --git-dir=".(exists("*shellescape") ? shellescape(a:gitdir) : '"'.a:gitdir.'"') + endif + if a:0 + let extra = join(map(copy(a:000),exists("*shellescape") ? 'shellescape(v:val)' : "'\"'.v:val.'\"'")) + else + let extra = "-p --stat=".&columns + endif + call system(git." diff --cached --no-color ".extra." > ".(exists("*shellescape") ? shellescape(name) : name)) + exe "pedit ".(exists("*fnameescape") ? fnameescape(name) : name) + wincmd P + let b:git_dir = a:gitdir + command! -bang -bar -buffer -complete=custom,s:diffcomplete -nargs=* DiffGitCached :call s:gitdiffcached(<bang>0,b:git_dir,<f-args>) + nnoremap <silent> q :q<CR> + setlocal buftype=nowrite nobuflisted noswapfile nomodifiable filetype=git +endfunction diff --git a/share/vim/vim73/ftplugin/gitconfig.vim b/share/vim/vim73/ftplugin/gitconfig.vim new file mode 100644 index 0000000000..833b8b14b2 --- /dev/null +++ b/share/vim/vim73/ftplugin/gitconfig.vim @@ -0,0 +1,15 @@ +" Vim filetype plugin +" Language: git config file +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2009 Dec 24 + +" Only do this when not done yet for this buffer +if (exists("b:did_ftplugin")) + finish +endif +let b:did_ftplugin = 1 + +setlocal formatoptions-=t formatoptions+=croql +setlocal comments=:#,:; commentstring=;\ %s + +let b:undo_ftplugin = "setl fo< com< cms<" diff --git a/share/vim/vim73/ftplugin/gitrebase.vim b/share/vim/vim73/ftplugin/gitrebase.vim new file mode 100644 index 0000000000..0200ba1acc --- /dev/null +++ b/share/vim/vim73/ftplugin/gitrebase.vim @@ -0,0 +1,43 @@ +" Vim filetype plugin +" Language: git rebase --interactive +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 21 + +" Only do this when not done yet for this buffer +if (exists("b:did_ftplugin")) + finish +endif + +runtime! ftplugin/git.vim +let b:did_ftplugin = 1 + +setlocal comments=:# commentstring=#\ %s formatoptions-=t +if !exists("b:undo_ftplugin") + let b:undo_ftplugin = "" +endif +let b:undo_ftplugin = b:undo_ftplugin."|setl com< cms< fo<" + +function! s:choose(word) + s/^\(\w\+\>\)\=\(\s*\)\ze\x\{4,40\}\>/\=(strlen(submatch(1)) == 1 ? a:word[0] : a:word) . substitute(submatch(2),'^$',' ','')/e +endfunction + +function! s:cycle() + call s:choose(get({'s':'edit','p':'squash','e':'reword','r':'fixup'},getline('.')[0],'pick')) +endfunction + +command! -buffer -bar Pick :call s:choose('pick') +command! -buffer -bar Squash :call s:choose('squash') +command! -buffer -bar Edit :call s:choose('edit') +command! -buffer -bar Reword :call s:choose('reword') +command! -buffer -bar Fixup :call s:choose('fixup') +command! -buffer -bar Cycle :call s:cycle() +" The above are more useful when they are mapped; for example: +"nnoremap <buffer> <silent> S :Cycle<CR> + +if exists("g:no_plugin_maps") || exists("g:no_gitrebase_maps") + finish +endif + +nnoremap <buffer> <expr> K col('.') < 7 && expand('<Lt>cword>') =~ '\X' && getline('.') =~ '^\w\+\s\+\x\+\>' ? 'wK' : 'K' + +let b:undo_ftplugin = b:undo_ftplugin . "|nunmap <buffer> K" diff --git a/share/vim/vim73/ftplugin/gitsendemail.vim b/share/vim/vim73/ftplugin/gitsendemail.vim new file mode 100644 index 0000000000..8fb436e181 --- /dev/null +++ b/share/vim/vim73/ftplugin/gitsendemail.vim @@ -0,0 +1,6 @@ +" Vim filetype plugin +" Language: git send-email message +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2009 Dec 24 + +runtime! ftplugin/mail.vim diff --git a/share/vim/vim72/ftplugin/gpg.vim b/share/vim/vim73/ftplugin/gpg.vim similarity index 100% rename from share/vim/vim72/ftplugin/gpg.vim rename to share/vim/vim73/ftplugin/gpg.vim diff --git a/share/vim/vim72/ftplugin/group.vim b/share/vim/vim73/ftplugin/group.vim similarity index 100% rename from share/vim/vim72/ftplugin/group.vim rename to share/vim/vim73/ftplugin/group.vim diff --git a/share/vim/vim72/ftplugin/grub.vim b/share/vim/vim73/ftplugin/grub.vim similarity index 100% rename from share/vim/vim72/ftplugin/grub.vim rename to share/vim/vim73/ftplugin/grub.vim diff --git a/share/vim/vim73/ftplugin/haml.vim b/share/vim/vim73/ftplugin/haml.vim new file mode 100644 index 0000000000..b2c1eca3fc --- /dev/null +++ b/share/vim/vim73/ftplugin/haml.vim @@ -0,0 +1,67 @@ +" Vim filetype plugin +" Language: Haml +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 21 + +" Only do this when not done yet for this buffer +if exists("b:did_ftplugin") + finish +endif + +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "All Files (*.*)\t*.*\n" +let s:match_words = "" + +runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim +unlet! b:did_ftplugin + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin + unlet b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter + unlet b:browsefilter +endif +if exists("b:match_words") + let s:match_words = b:match_words + unlet b:match_words +endif + +runtime! ftplugin/ruby.vim ftplugin/ruby_*.vim ftplugin/ruby/*.vim +let b:did_ftplugin = 1 + +" Combine the new set of values with those previously included. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin . " | " . s:undo_ftplugin +endif +if exists ("b:browsefilter") + let s:browsefilter = substitute(b:browsefilter,'\cAll Files (\*\.\*)\t\*\.\*\n','','') . s:browsefilter +endif +if exists("b:match_words") + let s:match_words = b:match_words . ',' . s:match_words +endif + +" Change the browse dialog on Win32 to show mainly Haml-related files +if has("gui_win32") + let b:browsefilter="Haml Files (*.haml)\t*.haml\nSass Files (*.sass)\t*.sass\n" . s:browsefilter +endif + +" Load the combined list of match_words for matchit.vim +if exists("loaded_matchit") + let b:match_words = s:match_words +endif + +setlocal comments= commentstring=-#\ %s + +let b:undo_ftplugin = "setl cms< com< " + \ " | unlet! b:browsefilter b:match_words | " . s:undo_ftplugin + +let &cpo = s:save_cpo + +" vim:set sw=2: diff --git a/share/vim/vim72/ftplugin/hamster.vim b/share/vim/vim73/ftplugin/hamster.vim similarity index 100% rename from share/vim/vim72/ftplugin/hamster.vim rename to share/vim/vim73/ftplugin/hamster.vim diff --git a/share/vim/vim72/ftplugin/haskell.vim b/share/vim/vim73/ftplugin/haskell.vim similarity index 100% rename from share/vim/vim72/ftplugin/haskell.vim rename to share/vim/vim73/ftplugin/haskell.vim diff --git a/share/vim/vim73/ftplugin/help.vim b/share/vim/vim73/ftplugin/help.vim new file mode 100644 index 0000000000..fdac41064d --- /dev/null +++ b/share/vim/vim73/ftplugin/help.vim @@ -0,0 +1,19 @@ +" Vim filetype plugin file +" Language: Vim help file +" Maintainer: Nikolai Weibull <now@bitwi.se> +" Latest Revision: 2008-07-09 + +if exists("b:did_ftplugin") + finish +endif +let b:did_ftplugin = 1 + +let s:cpo_save = &cpo +set cpo&vim + +let b:undo_ftplugin = "setl fo< tw< cole< cocu<" + +setlocal formatoptions+=tcroql textwidth=78 cole=2 cocu=nc + +let &cpo = s:cpo_save +unlet s:cpo_save diff --git a/share/vim/vim72/ftplugin/hostconf.vim b/share/vim/vim73/ftplugin/hostconf.vim similarity index 100% rename from share/vim/vim72/ftplugin/hostconf.vim rename to share/vim/vim73/ftplugin/hostconf.vim diff --git a/share/vim/vim72/ftplugin/hostsaccess.vim b/share/vim/vim73/ftplugin/hostsaccess.vim similarity index 100% rename from share/vim/vim72/ftplugin/hostsaccess.vim rename to share/vim/vim73/ftplugin/hostsaccess.vim diff --git a/share/vim/vim73/ftplugin/html.vim b/share/vim/vim73/ftplugin/html.vim new file mode 100644 index 0000000000..5f1384b3e4 --- /dev/null +++ b/share/vim/vim73/ftplugin/html.vim @@ -0,0 +1,90 @@ +" Vim filetype plugin file +" Language: html +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif +let b:did_ftplugin = 1 + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +setlocal matchpairs+=<:> +setlocal commentstring=<!--%s--> +setlocal comments=s:<!--,m:\ \ \ \ ,e:--> + +if exists("g:ft_html_autocomment") && (g:ft_html_autocomment == 1) + setlocal formatoptions-=t formatoptions+=croql +endif + + +if exists('&omnifunc') + " Distinguish between HTML versions + " To use with other HTML versions add another + " elseif condition to match proper DOCTYPE + setlocal omnifunc=htmlcomplete#CompleteTags + + if &filetype == 'xhtml' + let b:html_omni_flavor = 'xhtml10s' + else + let b:html_omni_flavor = 'html401t' + endif + let i = 1 + let line = "" + while i < 10 && i < line("$") + let line = getline(i) + if line =~ '<!DOCTYPE.*\<DTD ' + break + endif + let i += 1 + endwhile + if line =~ '<!DOCTYPE.*\<DTD ' " doctype line found above + if line =~ ' HTML 3\.2' + let b:html_omni_flavor = 'html32' + elseif line =~ ' XHTML 1\.1' + let b:html_omni_flavor = 'xhtml11' + else " two-step detection with strict/frameset/transitional + if line =~ ' XHTML 1\.0' + let b:html_omni_flavor = 'xhtml10' + elseif line =~ ' HTML 4\.01' + let b:html_omni_flavor = 'html401' + elseif line =~ ' HTML 4.0\>' + let b:html_omni_flavor = 'html40' + endif + if line =~ '\<Transitional\>' + let b:html_omni_flavor .= 't' + elseif line =~ '\<Frameset\>' + let b:html_omni_flavor .= 'f' + else + let b:html_omni_flavor .= 's' + endif + endif + endif +endif + +" HTML: thanks to Johannes Zellner and Benji Fisher. +if exists("loaded_matchit") + let b:match_ignorecase = 1 + let b:match_words = '<:>,' . + \ '<\@<=[ou]l\>[^>]*\%(>\|$\):<\@<=li\>:<\@<=/[ou]l>,' . + \ '<\@<=dl\>[^>]*\%(>\|$\):<\@<=d[td]\>:<\@<=/dl>,' . + \ '<\@<=\([^/][^ \t>]*\)[^>]*\%(>\|$\):<\@<=/\1>' +endif + +" Change the :browse e filter to primarily show HTML-related files. +if has("gui_win32") + let b:browsefilter="HTML Files (*.html,*.htm)\t*.htm;*.html\n" . + \ "JavaScript Files (*.js)\t*.js\n" . + \ "Cascading StyleSheets (*.css)\t*.css\n" . + \ "All Files (*.*)\t*.*\n" +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "setlocal commentstring< matchpairs< omnifunc< comments< formatoptions<" . + \ " | unlet! b:match_ignorecase b:match_skip b:match_words b:browsefilter" + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/htmldjango.vim b/share/vim/vim73/ftplugin/htmldjango.vim similarity index 100% rename from share/vim/vim72/ftplugin/htmldjango.vim rename to share/vim/vim73/ftplugin/htmldjango.vim diff --git a/share/vim/vim72/ftplugin/indent.vim b/share/vim/vim73/ftplugin/indent.vim similarity index 100% rename from share/vim/vim72/ftplugin/indent.vim rename to share/vim/vim73/ftplugin/indent.vim diff --git a/share/vim/vim72/ftplugin/initex.vim b/share/vim/vim73/ftplugin/initex.vim similarity index 100% rename from share/vim/vim72/ftplugin/initex.vim rename to share/vim/vim73/ftplugin/initex.vim diff --git a/share/vim/vim72/ftplugin/ishd.vim b/share/vim/vim73/ftplugin/ishd.vim similarity index 100% rename from share/vim/vim72/ftplugin/ishd.vim rename to share/vim/vim73/ftplugin/ishd.vim diff --git a/share/vim/vim73/ftplugin/java.vim b/share/vim/vim73/ftplugin/java.vim new file mode 100644 index 0000000000..6c7b3671ce --- /dev/null +++ b/share/vim/vim73/ftplugin/java.vim @@ -0,0 +1,50 @@ +" Vim filetype plugin file +" Language: Java +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Change: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif +let b:did_ftplugin = 1 + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +" For filename completion, prefer the .java extension over the .class +" extension. +set suffixes+=.class + +" Enable gf on import statements. Convert . in the package +" name to / and append .java to the name, then search the path. +setlocal includeexpr=substitute(v:fname,'\\.','/','g') +setlocal suffixesadd=.java +if exists("g:ftplugin_java_source_path") + let &l:path=g:ftplugin_java_source_path . ',' . &l:path +endif + +" Set 'formatoptions' to break comment lines but not other lines, +" and insert the comment leader when hitting <CR> or using "o". +setlocal formatoptions-=t formatoptions+=croql + +" Set 'comments' to format dashed lists in comments. Behaves just like C. +setlocal comments& comments^=sO:*\ -,mO:*\ \ ,exO:*/ + +setlocal commentstring=//%s + +" Change the :browse e filter to primarily show Java-related files. +if has("gui_win32") + let b:browsefilter="Java Files (*.java)\t*.java\n" . + \ "Properties Files (*.prop*)\t*.prop*\n" . + \ "Manifest Files (*.mf)\t*.mf\n" . + \ "All Files (*.*)\t*.*\n" +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "setlocal suffixes< suffixesadd<" . + \ " formatoptions< comments< commentstring< path< includeexpr<" . + \ " | unlet! b:browsefilter" + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/javascript.vim b/share/vim/vim73/ftplugin/javascript.vim similarity index 100% rename from share/vim/vim72/ftplugin/javascript.vim rename to share/vim/vim73/ftplugin/javascript.vim diff --git a/share/vim/vim73/ftplugin/jsp.vim b/share/vim/vim73/ftplugin/jsp.vim new file mode 100644 index 0000000000..9c0eb9687b --- /dev/null +++ b/share/vim/vim73/ftplugin/jsp.vim @@ -0,0 +1,66 @@ +" Vim filetype plugin file +" Language: jsp +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "Java Files (*.java)\t*.java\n" . + \ "HTML Files (*.html, *.htm)\t*.html;*.htm\n" . + \ "All Files (*.*)\t*.*\n" +let s:match_words = "" + +runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim +unlet b:did_ftplugin + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin + unlet b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter + unlet b:browsefilter +endif +if exists("b:match_words") + let s:match_words = b:match_words + unlet b:match_words +endif + +runtime! ftplugin/java.vim ftplugin/java_*.vim ftplugin/java/*.vim +let b:did_ftplugin = 1 + +" Combine the new set of values with those previously included. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin . " | " . s:undo_ftplugin +endif +if exists ("b:browsefilter") + let s:browsefilter = b:browsefilter . s:browsefilter +endif +if exists("b:match_words") + let s:match_words = b:match_words . ',' . s:match_words +endif + +" Load the combined list of match_words for matchit.vim +if exists("loaded_matchit") + let b:match_words = s:match_words +endif + +" Change the :browse e filter to primarily show JSP-related files. +if has("gui_win32") + let b:browsefilter="JSP Files (*.jsp)\t*.jsp\n" . s:browsefilter +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "unlet! b:browsefilter b:match_words | " . s:undo_ftplugin + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/kconfig.vim b/share/vim/vim73/ftplugin/kconfig.vim similarity index 100% rename from share/vim/vim72/ftplugin/kconfig.vim rename to share/vim/vim73/ftplugin/kconfig.vim diff --git a/share/vim/vim72/ftplugin/kwt.vim b/share/vim/vim73/ftplugin/kwt.vim similarity index 100% rename from share/vim/vim72/ftplugin/kwt.vim rename to share/vim/vim73/ftplugin/kwt.vim diff --git a/share/vim/vim72/ftplugin/ld.vim b/share/vim/vim73/ftplugin/ld.vim similarity index 100% rename from share/vim/vim72/ftplugin/ld.vim rename to share/vim/vim73/ftplugin/ld.vim diff --git a/share/vim/vim72/ftplugin/lftp.vim b/share/vim/vim73/ftplugin/lftp.vim similarity index 100% rename from share/vim/vim72/ftplugin/lftp.vim rename to share/vim/vim73/ftplugin/lftp.vim diff --git a/share/vim/vim72/ftplugin/libao.vim b/share/vim/vim73/ftplugin/libao.vim similarity index 100% rename from share/vim/vim72/ftplugin/libao.vim rename to share/vim/vim73/ftplugin/libao.vim diff --git a/share/vim/vim72/ftplugin/limits.vim b/share/vim/vim73/ftplugin/limits.vim similarity index 100% rename from share/vim/vim72/ftplugin/limits.vim rename to share/vim/vim73/ftplugin/limits.vim diff --git a/share/vim/vim73/ftplugin/liquid.vim b/share/vim/vim73/ftplugin/liquid.vim new file mode 100644 index 0000000000..b211a884c6 --- /dev/null +++ b/share/vim/vim73/ftplugin/liquid.vim @@ -0,0 +1,61 @@ +" Vim filetype plugin +" Language: Liquid +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 21 + +if exists('b:did_ftplugin') + finish +endif + +if !exists('g:liquid_default_subtype') + let g:liquid_default_subtype = 'html' +endif + +if !exists('b:liquid_subtype') + let s:lines = getline(1)."\n".getline(2)."\n".getline(3)."\n".getline(4)."\n".getline(5)."\n".getline("$") + let b:liquid_subtype = matchstr(s:lines,'liquid_subtype=\zs\w\+') + if b:liquid_subtype == '' + let b:liquid_subtype = matchstr(&filetype,'^liquid\.\zs\w\+') + endif + if b:liquid_subtype == '' + let b:liquid_subtype = matchstr(substitute(expand('%:t'),'\c\%(\.liquid\)\+$','',''),'\.\zs\w\+$') + endif + if b:liquid_subtype == '' + let b:liquid_subtype = g:liquid_default_subtype + endif +endif + +if exists('b:liquid_subtype') && b:liquid_subtype != '' + exe 'runtime! ftplugin/'.b:liquid_subtype.'.vim ftplugin/'.b:liquid_subtype.'_*.vim ftplugin/'.b:liquid_subtype.'/*.vim' +else + runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim +endif +let b:did_ftplugin = 1 + +if exists('b:undo_ftplugin') + let b:undo_ftplugin .= '|' +else + let b:undo_ftplugin = '' +endif +if exists('b:browsefilter') + let b:browsefilter = "\n".b:browsefilter +else + let b:browsefilter = '' +endif +if exists('b:match_words') + let b:match_words .= ',' +elseif exists('loaded_matchit') + let b:match_words = '' +endif + +if has('gui_win32') + let b:browsefilter="Liquid Files (*.liquid)\t*.liquid" . b:browsefilter +endif + +if exists('loaded_matchit') + let b:match_words .= '\<\%(if\w*\|unless\|case\)\>:\<\%(elsif\|else\|when\)\>:\<end\%(if\w*\|unless\|case\)\>,\<\%(for\|tablerow\)\>:\%({%\s*\)\@<=empty\>:\<end\%(for\|tablerow\)\>,<\(capture\|comment\|highlight\)\>:\<end\1\>' +endif + +setlocal commentstring={%\ comment\ %}%s{%\ endcomment\ %} + +let b:undo_ftplugin .= 'setl cms< | unlet! b:browsefilter b:match_words' diff --git a/share/vim/vim72/ftplugin/lisp.vim b/share/vim/vim73/ftplugin/lisp.vim similarity index 100% rename from share/vim/vim72/ftplugin/lisp.vim rename to share/vim/vim73/ftplugin/lisp.vim diff --git a/share/vim/vim73/ftplugin/logcheck.vim b/share/vim/vim73/ftplugin/logcheck.vim new file mode 100644 index 0000000000..765f6b471e --- /dev/null +++ b/share/vim/vim73/ftplugin/logcheck.vim @@ -0,0 +1,17 @@ +" Vim filetype plugin file +" Language: Logcheck +" Maintainer: Debian Vim Maintainers <pkg-vim-maintainers@lists.alioth.debian.org> +" Last Change: 2010 Jul 29 +" License: GNU GPL, version 2.0 +" URL: http://hg.debian.org/hg/pkg-vim/vim/file/unstable/runtime/ftplugin/logcheck.vim + +if exists("b:did_ftplugin") + finish +endif +let b:did_ftplugin = 1 + +let b:undo_ftplugin = "setl fo<" + +" Do not hard-wrap non-comment lines since each line is a self-contained +" regular expression +setlocal formatoptions-=t diff --git a/share/vim/vim72/ftplugin/loginaccess.vim b/share/vim/vim73/ftplugin/loginaccess.vim similarity index 100% rename from share/vim/vim72/ftplugin/loginaccess.vim rename to share/vim/vim73/ftplugin/loginaccess.vim diff --git a/share/vim/vim72/ftplugin/logindefs.vim b/share/vim/vim73/ftplugin/logindefs.vim similarity index 100% rename from share/vim/vim72/ftplugin/logindefs.vim rename to share/vim/vim73/ftplugin/logindefs.vim diff --git a/share/vim/vim72/ftplugin/logtalk.dict b/share/vim/vim73/ftplugin/logtalk.dict similarity index 100% rename from share/vim/vim72/ftplugin/logtalk.dict rename to share/vim/vim73/ftplugin/logtalk.dict diff --git a/share/vim/vim72/ftplugin/logtalk.vim b/share/vim/vim73/ftplugin/logtalk.vim similarity index 100% rename from share/vim/vim72/ftplugin/logtalk.vim rename to share/vim/vim73/ftplugin/logtalk.vim diff --git a/share/vim/vim72/ftplugin/lprolog.vim b/share/vim/vim73/ftplugin/lprolog.vim similarity index 100% rename from share/vim/vim72/ftplugin/lprolog.vim rename to share/vim/vim73/ftplugin/lprolog.vim diff --git a/share/vim/vim72/ftplugin/lua.vim b/share/vim/vim73/ftplugin/lua.vim similarity index 100% rename from share/vim/vim72/ftplugin/lua.vim rename to share/vim/vim73/ftplugin/lua.vim diff --git a/share/vim/vim72/ftplugin/m4.vim b/share/vim/vim73/ftplugin/m4.vim similarity index 100% rename from share/vim/vim72/ftplugin/m4.vim rename to share/vim/vim73/ftplugin/m4.vim diff --git a/share/vim/vim73/ftplugin/mail.vim b/share/vim/vim73/ftplugin/mail.vim new file mode 100644 index 0000000000..4a4c85195c --- /dev/null +++ b/share/vim/vim73/ftplugin/mail.vim @@ -0,0 +1,35 @@ +" Vim filetype plugin file +" Language: Mail +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2009 Jun 03 + +" Only do this when not done yet for this buffer +if exists("b:did_ftplugin") + finish +endif +let b:did_ftplugin = 1 + +let b:undo_ftplugin = "setl modeline< tw< fo<" + +" Don't use modelines in e-mail messages, avoid trojan horses and nasty +" "jokes" (e.g., setting 'textwidth' to 5). +setlocal nomodeline + +" many people recommend keeping e-mail messages 72 chars wide +if &tw == 0 + setlocal tw=72 +endif + +" Set 'formatoptions' to break text lines and keep the comment leader ">". +setlocal fo+=tcql + +" Add mappings, unless the user doesn't want this. +if !exists("no_plugin_maps") && !exists("no_mail_maps") + " Quote text by inserting "> " + if !hasmapto('<Plug>MailQuote') + vmap <buffer> <LocalLeader>q <Plug>MailQuote + nmap <buffer> <LocalLeader>q <Plug>MailQuote + endif + vnoremap <buffer> <Plug>MailQuote :s/^/> /<CR>:noh<CR>`` + nnoremap <buffer> <Plug>MailQuote :.,$s/^/> /<CR>:noh<CR>`` +endif diff --git a/share/vim/vim72/ftplugin/mailaliases.vim b/share/vim/vim73/ftplugin/mailaliases.vim similarity index 100% rename from share/vim/vim72/ftplugin/mailaliases.vim rename to share/vim/vim73/ftplugin/mailaliases.vim diff --git a/share/vim/vim72/ftplugin/mailcap.vim b/share/vim/vim73/ftplugin/mailcap.vim similarity index 100% rename from share/vim/vim72/ftplugin/mailcap.vim rename to share/vim/vim73/ftplugin/mailcap.vim diff --git a/share/vim/vim72/ftplugin/make.vim b/share/vim/vim73/ftplugin/make.vim similarity index 100% rename from share/vim/vim72/ftplugin/make.vim rename to share/vim/vim73/ftplugin/make.vim diff --git a/share/vim/vim73/ftplugin/man.vim b/share/vim/vim73/ftplugin/man.vim new file mode 100644 index 0000000000..eef0628a04 --- /dev/null +++ b/share/vim/vim73/ftplugin/man.vim @@ -0,0 +1,181 @@ +" Vim filetype plugin file +" Language: man +" Maintainer: SungHyun Nam <goweol@gmail.com> +" Last Change: 2008 Sep 17 + +" To make the ":Man" command available before editing a manual page, source +" this script from your startup vimrc file. + +" If 'filetype' isn't "man", we must have been called to only define ":Man". +if &filetype == "man" + + " Only do this when not done yet for this buffer + if exists("b:did_ftplugin") + finish + endif + let b:did_ftplugin = 1 + + " allow dot and dash in manual page name. + setlocal iskeyword+=\.,- + + " Add mappings, unless the user didn't want this. + if !exists("no_plugin_maps") && !exists("no_man_maps") + if !hasmapto('<Plug>ManBS') + nmap <buffer> <LocalLeader>h <Plug>ManBS + endif + nnoremap <buffer> <Plug>ManBS :%s/.\b//g<CR>:setl nomod<CR>'' + + nnoremap <buffer> <c-]> :call <SID>PreGetPage(v:count)<CR> + nnoremap <buffer> <c-t> :call <SID>PopPage()<CR> + endif + +endif + +if exists(":Man") != 2 + com -nargs=+ Man call s:GetPage(<f-args>) + nmap <Leader>K :call <SID>PreGetPage(0)<CR> +endif + +" Define functions only once. +if !exists("s:man_tag_depth") + +let s:man_tag_depth = 0 + +let s:man_sect_arg = "" +let s:man_find_arg = "-w" +try + if !has("win32") && $OSTYPE !~ 'cygwin\|linux' && system('uname -s') =~ "SunOS" && system('uname -r') =~ "^5" + let s:man_sect_arg = "-s" + let s:man_find_arg = "-l" + endif +catch /E145:/ + " Ignore the error in restricted mode +endtry + +func <SID>PreGetPage(cnt) + if a:cnt == 0 + let old_isk = &iskeyword + setl iskeyword+=(,) + let str = expand("<cword>") + let &l:iskeyword = old_isk + let page = substitute(str, '(*\(\k\+\).*', '\1', '') + let sect = substitute(str, '\(\k\+\)(\([^()]*\)).*', '\2', '') + if match(sect, '^[0-9 ]\+$') == -1 + let sect = "" + endif + if sect == page + let sect = "" + endif + else + let sect = a:cnt + let page = expand("<cword>") + endif + call s:GetPage(sect, page) +endfunc + +func <SID>GetCmdArg(sect, page) + if a:sect == '' + return a:page + endif + return s:man_sect_arg.' '.a:sect.' '.a:page +endfunc + +func <SID>FindPage(sect, page) + let where = system("/usr/bin/man ".s:man_find_arg.' '.s:GetCmdArg(a:sect, a:page)) + if where !~ "^/" + if matchstr(where, " [^ ]*$") !~ "^ /" + return 0 + endif + endif + return 1 +endfunc + +func <SID>GetPage(...) + if a:0 >= 2 + let sect = a:1 + let page = a:2 + elseif a:0 >= 1 + let sect = "" + let page = a:1 + else + return + endif + + " To support: nmap K :Man <cword> + if page == '<cword>' + let page = expand('<cword>') + endif + + if sect != "" && s:FindPage(sect, page) == 0 + let sect = "" + endif + if s:FindPage(sect, page) == 0 + echo "\nCannot find a '".page."'." + return + endif + exec "let s:man_tag_buf_".s:man_tag_depth." = ".bufnr("%") + exec "let s:man_tag_lin_".s:man_tag_depth." = ".line(".") + exec "let s:man_tag_col_".s:man_tag_depth." = ".col(".") + let s:man_tag_depth = s:man_tag_depth + 1 + + " Use an existing "man" window if it exists, otherwise open a new one. + if &filetype != "man" + let thiswin = winnr() + exe "norm! \<C-W>b" + if winnr() > 1 + exe "norm! " . thiswin . "\<C-W>w" + while 1 + if &filetype == "man" + break + endif + exe "norm! \<C-W>w" + if thiswin == winnr() + break + endif + endwhile + endif + if &filetype != "man" + new + setl nonu fdc=0 + endif + endif + silent exec "edit $HOME/".page.".".sect."~" + " Avoid warning for editing the dummy file twice + setl buftype=nofile noswapfile + + setl ma + silent exec "norm 1GdG" + let $MANWIDTH = winwidth(0) + silent exec "r!/usr/bin/man ".s:GetCmdArg(sect, page)." | col -b" + " Remove blank lines from top and bottom. + while getline(1) =~ '^\s*$' + silent norm ggdd + endwhile + while getline('$') =~ '^\s*$' + silent norm Gdd + endwhile + 1 + setl ft=man nomod + setl bufhidden=hide + setl nobuflisted +endfunc + +func <SID>PopPage() + if s:man_tag_depth > 0 + let s:man_tag_depth = s:man_tag_depth - 1 + exec "let s:man_tag_buf=s:man_tag_buf_".s:man_tag_depth + exec "let s:man_tag_lin=s:man_tag_lin_".s:man_tag_depth + exec "let s:man_tag_col=s:man_tag_col_".s:man_tag_depth + exec s:man_tag_buf."b" + exec s:man_tag_lin + exec "norm ".s:man_tag_col."|" + exec "unlet s:man_tag_buf_".s:man_tag_depth + exec "unlet s:man_tag_lin_".s:man_tag_depth + exec "unlet s:man_tag_col_".s:man_tag_depth + unlet s:man_tag_buf s:man_tag_lin s:man_tag_col + endif +endfunc + +endif + +" vim: set sw=2: diff --git a/share/vim/vim72/ftplugin/manconf.vim b/share/vim/vim73/ftplugin/manconf.vim similarity index 100% rename from share/vim/vim72/ftplugin/manconf.vim rename to share/vim/vim73/ftplugin/manconf.vim diff --git a/share/vim/vim73/ftplugin/markdown.vim b/share/vim/vim73/ftplugin/markdown.vim new file mode 100644 index 0000000000..946208203c --- /dev/null +++ b/share/vim/vim73/ftplugin/markdown.vim @@ -0,0 +1,19 @@ +" Vim filetype plugin +" Language: Markdown +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 21 + +if exists("b:did_ftplugin") + finish +endif + +runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim +unlet! b:did_ftplugin + +setlocal comments=fb:*,fb:-,fb:+,n:> commentstring=>\ %s +setlocal formatoptions+=tcqln +setlocal formatlistpat=^\\s*\\d\\+\\.\\s\\+\\\|^[-*+]\\s\\+ + +let b:undo_ftplugin .= "|setl cms< com< fo<" + +" vim:set sw=2: diff --git a/share/vim/vim72/ftplugin/matlab.vim b/share/vim/vim73/ftplugin/matlab.vim similarity index 100% rename from share/vim/vim72/ftplugin/matlab.vim rename to share/vim/vim73/ftplugin/matlab.vim diff --git a/share/vim/vim72/ftplugin/mf.vim b/share/vim/vim73/ftplugin/mf.vim similarity index 100% rename from share/vim/vim72/ftplugin/mf.vim rename to share/vim/vim73/ftplugin/mf.vim diff --git a/share/vim/vim72/ftplugin/modconf.vim b/share/vim/vim73/ftplugin/modconf.vim similarity index 100% rename from share/vim/vim72/ftplugin/modconf.vim rename to share/vim/vim73/ftplugin/modconf.vim diff --git a/share/vim/vim72/ftplugin/mp.vim b/share/vim/vim73/ftplugin/mp.vim similarity index 100% rename from share/vim/vim72/ftplugin/mp.vim rename to share/vim/vim73/ftplugin/mp.vim diff --git a/share/vim/vim72/ftplugin/mplayerconf.vim b/share/vim/vim73/ftplugin/mplayerconf.vim similarity index 100% rename from share/vim/vim72/ftplugin/mplayerconf.vim rename to share/vim/vim73/ftplugin/mplayerconf.vim diff --git a/share/vim/vim72/ftplugin/mrxvtrc.vim b/share/vim/vim73/ftplugin/mrxvtrc.vim similarity index 100% rename from share/vim/vim72/ftplugin/mrxvtrc.vim rename to share/vim/vim73/ftplugin/mrxvtrc.vim diff --git a/share/vim/vim72/ftplugin/msmessages.vim b/share/vim/vim73/ftplugin/msmessages.vim similarity index 100% rename from share/vim/vim72/ftplugin/msmessages.vim rename to share/vim/vim73/ftplugin/msmessages.vim diff --git a/share/vim/vim72/ftplugin/muttrc.vim b/share/vim/vim73/ftplugin/muttrc.vim similarity index 100% rename from share/vim/vim72/ftplugin/muttrc.vim rename to share/vim/vim73/ftplugin/muttrc.vim diff --git a/share/vim/vim72/ftplugin/nanorc.vim b/share/vim/vim73/ftplugin/nanorc.vim similarity index 100% rename from share/vim/vim72/ftplugin/nanorc.vim rename to share/vim/vim73/ftplugin/nanorc.vim diff --git a/share/vim/vim72/ftplugin/netrc.vim b/share/vim/vim73/ftplugin/netrc.vim similarity index 100% rename from share/vim/vim72/ftplugin/netrc.vim rename to share/vim/vim73/ftplugin/netrc.vim diff --git a/share/vim/vim72/ftplugin/nsis.vim b/share/vim/vim73/ftplugin/nsis.vim similarity index 100% rename from share/vim/vim72/ftplugin/nsis.vim rename to share/vim/vim73/ftplugin/nsis.vim diff --git a/share/vim/vim72/ftplugin/objc.vim b/share/vim/vim73/ftplugin/objc.vim similarity index 100% rename from share/vim/vim72/ftplugin/objc.vim rename to share/vim/vim73/ftplugin/objc.vim diff --git a/share/vim/vim73/ftplugin/ocaml.vim b/share/vim/vim73/ftplugin/ocaml.vim new file mode 100644 index 0000000000..a59141182e --- /dev/null +++ b/share/vim/vim73/ftplugin/ocaml.vim @@ -0,0 +1,584 @@ +" Language: OCaml +" Maintainer: David Baelde <firstname.name@ens-lyon.org> +" Mike Leary <leary@nwlink.com> +" Markus Mottl <markus.mottl@gmail.com> +" Stefano Zacchiroli <zack@bononia.it> +" Vincent Aravantinos <firstname.name@imag.fr> +" URL: http://www.ocaml.info/vim/ftplugin/ocaml.vim +" Last Change: 2010 Jul 10 - Bugfix, thanks to Pat Rondon +" 2008 Jul 17 - Bugfix related to fnameescape (VA) +" 2007 Sep 09 - Added .annot support for ocamlbuild, python not +" needed anymore (VA) +" 2006 May 01 - Added .annot support for file.whateverext (SZ) +" 2006 Apr 11 - Fixed an initialization bug; fixed ASS abbrev (MM) +" 2005 Oct 13 - removed GPL; better matchit support (MM, SZ) +" +if exists("b:did_ftplugin") + finish +endif +let b:did_ftplugin=1 + +" some macro +if exists('*fnameescape') + function! s:Fnameescape(s) + return fnameescape(a:s) + endfun +else + function! s:Fnameescape(s) + return escape(a:s," \t\n*?[{`$\\%#'\"|!<") + endfun +endif + +" Error handling -- helps moving where the compiler wants you to go +let s:cposet=&cpoptions +set cpo-=C +setlocal efm= + \%EFile\ \"%f\"\\,\ line\ %l\\,\ characters\ %c-%*\\d:, + \%EFile\ \"%f\"\\,\ line\ %l\\,\ character\ %c:%m, + \%+EReference\ to\ unbound\ regexp\ name\ %m, + \%Eocamlyacc:\ e\ -\ line\ %l\ of\ \"%f\"\\,\ %m, + \%Wocamlyacc:\ w\ -\ %m, + \%-Zmake%.%#, + \%C%m, + \%D%*\\a[%*\\d]:\ Entering\ directory\ `%f', + \%X%*\\a[%*\\d]:\ Leaving\ directory\ `%f', + \%D%*\\a:\ Entering\ directory\ `%f', + \%X%*\\a:\ Leaving\ directory\ `%f', + \%DMaking\ %*\\a\ in\ %f + +" Add mappings, unless the user didn't want this. +if !exists("no_plugin_maps") && !exists("no_ocaml_maps") + " (un)commenting + if !hasmapto('<Plug>Comment') + nmap <buffer> <LocalLeader>c <Plug>LUncomOn + vmap <buffer> <LocalLeader>c <Plug>BUncomOn + nmap <buffer> <LocalLeader>C <Plug>LUncomOff + vmap <buffer> <LocalLeader>C <Plug>BUncomOff + endif + + nnoremap <buffer> <Plug>LUncomOn mz0i(* <ESC>$A *)<ESC>`z + nnoremap <buffer> <Plug>LUncomOff :s/^(\* \(.*\) \*)/\1/<CR>:noh<CR> + vnoremap <buffer> <Plug>BUncomOn <ESC>:'<,'><CR>`<O<ESC>0i(*<ESC>`>o<ESC>0i*)<ESC>`< + vnoremap <buffer> <Plug>BUncomOff <ESC>:'<,'><CR>`<dd`>dd`< + + if !hasmapto('<Plug>Abbrev') + iabbrev <buffer> ASS (assert (0=1) (* XXX *)) + endif +endif + +" Let % jump between structure elements (due to Issac Trotts) +let b:mw = '' +let b:mw = b:mw . ',\<let\>:\<and\>:\(\<in\>\|;;\)' +let b:mw = b:mw . ',\<if\>:\<then\>:\<else\>' +let b:mw = b:mw . ',\<\(for\|while\)\>:\<do\>:\<done\>,' +let b:mw = b:mw . ',\<\(object\|sig\|struct\|begin\)\>:\<end\>' +let b:mw = b:mw . ',\<\(match\|try\)\>:\<with\>' +let b:match_words = b:mw + +let b:match_ignorecase=0 + +" switching between interfaces (.mli) and implementations (.ml) +if !exists("g:did_ocaml_switch") + let g:did_ocaml_switch = 1 + map <LocalLeader>s :call OCaml_switch(0)<CR> + map <LocalLeader>S :call OCaml_switch(1)<CR> + fun OCaml_switch(newwin) + if (match(bufname(""), "\\.mli$") >= 0) + let fname = s:Fnameescape(substitute(bufname(""), "\\.mli$", ".ml", "")) + if (a:newwin == 1) + exec "new " . fname + else + exec "arge " . fname + endif + elseif (match(bufname(""), "\\.ml$") >= 0) + let fname = s:Fnameescape(bufname("")) . "i" + if (a:newwin == 1) + exec "new " . fname + else + exec "arge " . fname + endif + endif + endfun +endif + +" Folding support + +" Get the modeline because folding depends on indentation +let s:s = line2byte(line('.'))+col('.')-1 +if search('^\s*(\*:o\?caml:') + let s:modeline = getline(".") +else + let s:modeline = "" +endif +if s:s > 0 + exe 'goto' s:s +endif + +" Get the indentation params +let s:m = matchstr(s:modeline,'default\s*=\s*\d\+') +if s:m != "" + let s:idef = matchstr(s:m,'\d\+') +elseif exists("g:omlet_indent") + let s:idef = g:omlet_indent +else + let s:idef = 2 +endif +let s:m = matchstr(s:modeline,'struct\s*=\s*\d\+') +if s:m != "" + let s:i = matchstr(s:m,'\d\+') +elseif exists("g:omlet_indent_struct") + let s:i = g:omlet_indent_struct +else + let s:i = s:idef +endif + +" Set the folding method +if exists("g:ocaml_folding") + setlocal foldmethod=expr + setlocal foldexpr=OMLetFoldLevel(v:lnum) +endif + +" - Only definitions below, executed once ------------------------------------- + +if exists("*OMLetFoldLevel") + finish +endif + +function s:topindent(lnum) + let l = a:lnum + while l > 0 + if getline(l) =~ '\s*\%(\<struct\>\|\<sig\>\|\<object\>\)' + return indent(l) + endif + let l = l-1 + endwhile + return -s:i +endfunction + +function OMLetFoldLevel(l) + + " This is for not merging blank lines around folds to them + if getline(a:l) !~ '\S' + return -1 + endif + + " We start folds for modules, classes, and every toplevel definition + if getline(a:l) =~ '^\s*\%(\<val\>\|\<module\>\|\<class\>\|\<type\>\|\<method\>\|\<initializer\>\|\<inherit\>\|\<exception\>\|\<external\>\)' + exe 'return ">' (indent(a:l)/s:i)+1 '"' + endif + + " Toplevel let are detected thanks to the indentation + if getline(a:l) =~ '^\s*let\>' && indent(a:l) == s:i+s:topindent(a:l) + exe 'return ">' (indent(a:l)/s:i)+1 '"' + endif + + " We close fold on end which are associated to struct, sig or object. + " We use syntax information to do that. + if getline(a:l) =~ '^\s*end\>' && synIDattr(synID(a:l, indent(a:l)+1, 0), "name") != "ocamlKeyword" + return (indent(a:l)/s:i)+1 + endif + + " Folds end on ;; + if getline(a:l) =~ '^\s*;;' + exe 'return "<' (indent(a:l)/s:i)+1 '"' + endif + + " Comments around folds aren't merged to them. + if synIDattr(synID(a:l, indent(a:l)+1, 0), "name") == "ocamlComment" + return -1 + endif + + return '=' +endfunction + +" Vim support for OCaml .annot files +" +" Last Change: 2007 Jul 17 +" Maintainer: Vincent Aravantinos <vincent.aravantinos@gmail.com> +" License: public domain +" +" Originally inspired by 'ocaml-dtypes.vim' by Stefano Zacchiroli. +" The source code is quite radically different for we not use python anymore. +" However this plugin should have the exact same behaviour, that's why the +" following lines are the quite exact copy of Stefano's original plugin : +" +" << +" Executing Ocaml_print_type(<mode>) function will display in the Vim bottom +" line(s) the type of an ocaml value getting it from the corresponding .annot +" file (if any). If Vim is in visual mode, <mode> should be "visual" and the +" selected ocaml value correspond to the highlighted text, otherwise (<mode> +" can be anything else) it corresponds to the literal found at the current +" cursor position. +" +" Typing '<LocalLeader>t' (LocalLeader defaults to '\', see :h LocalLeader) +" will cause " Ocaml_print_type function to be invoked with the right +" argument depending on the current mode (visual or not). +" >> +" +" If you find something not matching this behaviour, please signal it. +" +" Differences are: +" - no need for python support +" + plus : more portable +" + minus: no more lazy parsing, it looks very fast however +" +" - ocamlbuild support, ie. +" + the plugin finds the _build directory and looks for the +" corresponding file inside; +" + if the user decides to change the name of the _build directory thanks +" to the '-build-dir' option of ocamlbuild, the plugin will manage in +" most cases to find it out (most cases = if the source file has a unique +" name among your whole project); +" + if ocamlbuild is not used, the usual behaviour holds; ie. the .annot +" file should be in the same directory as the source file; +" + for vim plugin programmers: +" the variable 'b:_build_dir' contains the inferred path to the build +" directory, even if this one is not named '_build'. +" +" Bonus : +" - latin1 accents are handled +" - lists are handled, even on multiple lines, you don't need the visual mode +" (the cursor must be on the first bracket) +" - parenthesized expressions, arrays, and structures (ie. '(...)', '[|...|]', +" and '{...}') are handled the same way + + " Copied from Stefano's original plugin : + " << + " .annot ocaml file representation + " + " File format (copied verbatim from caml-types.el) + " + " file ::= block * + " block ::= position <SP> position <LF> annotation * + " position ::= filename <SP> num <SP> num <SP> num + " annotation ::= keyword open-paren <LF> <SP> <SP> data <LF> close-paren + " + " <SP> is a space character (ASCII 0x20) + " <LF> is a line-feed character (ASCII 0x0A) + " num is a sequence of decimal digits + " filename is a string with the lexical conventions of O'Caml + " open-paren is an open parenthesis (ASCII 0x28) + " close-paren is a closed parenthesis (ASCII 0x29) + " data is any sequence of characters where <LF> is always followed by + " at least two space characters. + " + " - in each block, the two positions are respectively the start and the + " end of the range described by the block. + " - in a position, the filename is the name of the file, the first num + " is the line number, the second num is the offset of the beginning + " of the line, the third num is the offset of the position itself. + " - the char number within the line is the difference between the third + " and second nums. + " + " For the moment, the only possible keyword is \"type\"." + " >> + + +" 1. Finding the annotation file even if we use ocamlbuild + + " In: two strings representing paths + " Out: one string representing the common prefix between the two paths + function! s:Find_common_path (p1,p2) + let temp = a:p2 + while matchstr(a:p1,temp) == '' + let temp = substitute(temp,'/[^/]*$','','') + endwhile + return temp + endfun + + " After call: + " - b:annot_file_path : + " path to the .annot file corresponding to the + " source file (dealing with ocamlbuild stuff) + " - b:_build_path: + " path to the build directory even if this one is + " not named '_build' + function! s:Locate_annotation() + if !b:annotation_file_located + + silent exe 'cd' s:Fnameescape(expand('%:p:h')) + + let annot_file_name = s:Fnameescape(expand('%:r')).'.annot' + + " 1st case : the annot file is in the same directory as the buffer (no ocamlbuild) + let b:annot_file_path = findfile(annot_file_name,'.') + if b:annot_file_path != '' + let b:annot_file_path = getcwd().'/'.b:annot_file_path + let b:_build_path = '' + else + " 2nd case : the buffer and the _build directory are in the same directory + " .. + " / \ + " / \ + " _build .ml + " + let b:_build_path = finddir('_build','.') + if b:_build_path != '' + let b:_build_path = getcwd().'/'.b:_build_path + let b:annot_file_path = findfile(annot_file_name,'_build') + if b:annot_file_path != '' + let b:annot_file_path = getcwd().'/'.b:annot_file_path + endif + else + " 3rd case : the _build directory is in a directory higher in the file hierarchy + " (it can't be deeper by ocamlbuild requirements) + " .. + " / \ + " / \ + " _build ... + " \ + " \ + " .ml + " + let b:_build_path = finddir('_build',';') + if b:_build_path != '' + let project_path = substitute(b:_build_path,'/_build$','','') + let path_relative_to_project = s:Fnameescape(substitute(expand('%:p:h'),project_path.'/','','')) + let b:annot_file_path = findfile(annot_file_name,project_path.'/_build/'.path_relative_to_project) + else + let b:annot_file_path = findfile(annot_file_name,'**') + "4th case : what if the user decided to change the name of the _build directory ? + " -> we relax the constraints, it should work in most cases + if b:annot_file_path != '' + " 4a. we suppose the renamed _build directory is in the current directory + let b:_build_path = matchstr(b:annot_file_path,'^[^/]*') + if b:annot_file_path != '' + let b:annot_file_path = getcwd().'/'.b:annot_file_path + let b:_build_path = getcwd().'/'.b:_build_path + endif + else + " 4b. anarchy : the renamed _build directory may be higher in the hierarchy + " this will work if the file for which we are looking annotations has a unique name in the whole project + " if this is not the case, it may still work, but no warranty here + let b:annot_file_path = findfile(annot_file_name,'**;') + let project_path = s:Find_common_path(b:annot_file_path,expand('%:p:h')) + let b:_build_path = matchstr(b:annot_file_path,project_path.'/[^/]*') + endif + endif + endif + endif + + if b:annot_file_path == '' + throw 'E484: no annotation file found' + endif + + silent exe 'cd' '-' + + let b:annotation_file_located = 1 + endif + endfun + + " This in order to locate the .annot file only once + let b:annotation_file_located = 0 + +" 2. Finding the type information in the annotation file + + " a. The annotation file is opened in vim as a buffer that + " should be (almost) invisible to the user. + + " After call: + " The current buffer is now the one containing the .annot file. + " We manage to keep all this hidden to the user's eye. + function! s:Enter_annotation_buffer() + let s:current_pos = getpos('.') + let s:current_hidden = &l:hidden + set hidden + let s:current_buf = bufname('%') + if bufloaded(b:annot_file_path) + silent exe 'keepj keepalt' 'buffer' s:Fnameescape(b:annot_file_path) + else + silent exe 'keepj keepalt' 'view' s:Fnameescape(b:annot_file_path) + endif + endfun + + " After call: + " The original buffer has been restored in the exact same state as before. + function! s:Exit_annotation_buffer() + silent exe 'keepj keepalt' 'buffer' s:Fnameescape(s:current_buf) + let &l:hidden = s:current_hidden + call setpos('.',s:current_pos) + endfun + + " After call: + " The annot file is loaded and assigned to a buffer. + " This also handles the modification date of the .annot file, eg. after a + " compilation. + function! s:Load_annotation() + if bufloaded(b:annot_file_path) && b:annot_file_last_mod < getftime(b:annot_file_path) + call s:Enter_annotation_buffer() + silent exe "bunload" + call s:Exit_annotation_buffer() + endif + if !bufloaded(b:annot_file_path) + call s:Enter_annotation_buffer() + setlocal nobuflisted + setlocal bufhidden=hide + setlocal noswapfile + setlocal buftype=nowrite + call s:Exit_annotation_buffer() + let b:annot_file_last_mod = getftime(b:annot_file_path) + endif + endfun + + "b. 'search' and 'match' work to find the type information + + "In: - lin1,col1: postion of expression first char + " - lin2,col2: postion of expression last char + "Out: - the pattern to be looked for to find the block + " Must be called in the source buffer (use of line2byte) + function! s:Block_pattern(lin1,lin2,col1,col2) + let start_num1 = a:lin1 + let start_num2 = line2byte(a:lin1) - 1 + let start_num3 = start_num2 + a:col1 + let path = '"\(\\"\|[^"]\)\+"' + let start_pos = path.' '.start_num1.' '.start_num2.' '.start_num3 + let end_num1 = a:lin2 + let end_num2 = line2byte(a:lin2) - 1 + let end_num3 = end_num2 + a:col2 + let end_pos = path.' '.end_num1.' '.end_num2.' '.end_num3 + return '^'.start_pos.' '.end_pos."$" + " rq: the '^' here is not totally correct regarding the annot file "grammar" + " but currently the annotation file respects this, and it's a little bit faster with the '^'; + " can be removed safely. + endfun + + "In: (the cursor position should be at the start of an annotation) + "Out: the type information + " Must be called in the annotation buffer (use of search) + function! s:Match_data() + " rq: idem as previously, in the following, the '^' at start of patterns is not necessary + keepj while search('^type($','ce',line(".")) == 0 + keepj if search('^.\{-}($','e') == 0 + throw "no_annotation" + endif + keepj if searchpair('(','',')') == 0 + throw "malformed_annot_file" + endif + endwhile + let begin = line(".") + 1 + keepj if searchpair('(','',')') == 0 + throw "malformed_annot_file" + endif + let end = line(".") - 1 + return join(getline(begin,end),"\n") + endfun + + "In: the pattern to look for in order to match the block + "Out: the type information (calls s:Match_data) + " Should be called in the annotation buffer + function! s:Extract_type_data(block_pattern) + call s:Enter_annotation_buffer() + try + if search(a:block_pattern,'e') == 0 + throw "no_annotation" + endif + call cursor(line(".") + 1,1) + let annotation = s:Match_data() + finally + call s:Exit_annotation_buffer() + endtry + return annotation + endfun + + "c. link this stuff with what the user wants + " ie. get the expression selected/under the cursor + + let s:ocaml_word_char = '\w|[À-ÿ]|''' + + "In: the current mode (eg. "visual", "normal", etc.) + "Out: the borders of the expression we are looking for the type + function! s:Match_borders(mode) + if a:mode == "visual" + let cur = getpos(".") + normal `< + let col1 = col(".") + let lin1 = line(".") + normal `> + let col2 = col(".") + let lin2 = line(".") + call cursor(cur[1],cur[2]) + return [lin1,lin2,col1-1,col2] + else + let cursor_line = line(".") + let cursor_col = col(".") + let line = getline('.') + if line[cursor_col-1:cursor_col] == '[|' + let [lin2,col2] = searchpairpos('\[|','','|\]','n') + return [cursor_line,lin2,cursor_col-1,col2+1] + elseif line[cursor_col-1] == '[' + let [lin2,col2] = searchpairpos('\[','','\]','n') + return [cursor_line,lin2,cursor_col-1,col2] + elseif line[cursor_col-1] == '(' + let [lin2,col2] = searchpairpos('(','',')','n') + return [cursor_line,lin2,cursor_col-1,col2] + elseif line[cursor_col-1] == '{' + let [lin2,col2] = searchpairpos('{','','}','n') + return [cursor_line,lin2,cursor_col-1,col2] + else + let [lin1,col1] = searchpos('\v%('.s:ocaml_word_char.'|\.)*','ncb') + let [lin2,col2] = searchpos('\v%('.s:ocaml_word_char.'|\.)*','nce') + if col1 == 0 || col2 == 0 + throw "no_expression" + endif + return [cursor_line,cursor_line,col1-1,col2] + endif + endif + endfun + + "In: the current mode (eg. "visual", "normal", etc.) + "Out: the type information (calls s:Extract_type_data) + function! s:Get_type(mode) + let [lin1,lin2,col1,col2] = s:Match_borders(a:mode) + return s:Extract_type_data(s:Block_pattern(lin1,lin2,col1,col2)) + endfun + + "d. main + "In: the current mode (eg. "visual", "normal", etc.) + "After call: the type information is displayed + if !exists("*Ocaml_get_type") + function Ocaml_get_type(mode) + call s:Locate_annotation() + call s:Load_annotation() + return s:Get_type(a:mode) + endfun + endif + + if !exists("*Ocaml_get_type_or_not") + function Ocaml_get_type_or_not(mode) + let t=reltime() + try + return Ocaml_get_type(a:mode) + catch + return "" + endtry + endfun + endif + + if !exists("*Ocaml_print_type") + function Ocaml_print_type(mode) + if expand("%:e") == "mli" + echohl ErrorMsg | echo "No annotations for interface (.mli) files" | echohl None + return + endif + try + echo Ocaml_get_type(a:mode) + catch /E484:/ + echohl ErrorMsg | echo "No type annotations (.annot) file found" | echohl None + catch /no_expression/ + echohl ErrorMsg | echo "No expression found under the cursor" | echohl None + catch /no_annotation/ + echohl ErrorMsg | echo "No type annotation found for the given text" | echohl None + catch /malformed_annot_file/ + echohl ErrorMsg | echo "Malformed .annot file" | echohl None + endtry + endfun + endif + +" Maps + map <silent> <LocalLeader>t :call Ocaml_print_type("normal")<CR> + vmap <silent> <LocalLeader>t :<C-U>call Ocaml_print_type("visual")<CR>`< + +let &cpoptions=s:cposet +unlet s:cposet + +" vim:sw=2 fdm=indent diff --git a/share/vim/vim72/ftplugin/occam.vim b/share/vim/vim73/ftplugin/occam.vim similarity index 100% rename from share/vim/vim72/ftplugin/occam.vim rename to share/vim/vim73/ftplugin/occam.vim diff --git a/share/vim/vim72/ftplugin/pamconf.vim b/share/vim/vim73/ftplugin/pamconf.vim similarity index 100% rename from share/vim/vim72/ftplugin/pamconf.vim rename to share/vim/vim73/ftplugin/pamconf.vim diff --git a/share/vim/vim73/ftplugin/pascal.vim b/share/vim/vim73/ftplugin/pascal.vim new file mode 100644 index 0000000000..3b1db4abdc --- /dev/null +++ b/share/vim/vim73/ftplugin/pascal.vim @@ -0,0 +1,15 @@ +" Vim filetype plugin file +" Language: pascal +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif +let b:did_ftplugin = 1 + +if exists("loaded_matchit") + let b:match_words='\<\%(begin\|case\|try\)\>:\<end\>' +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "unlet! b:match_words" diff --git a/share/vim/vim72/ftplugin/passwd.vim b/share/vim/vim73/ftplugin/passwd.vim similarity index 100% rename from share/vim/vim72/ftplugin/passwd.vim rename to share/vim/vim73/ftplugin/passwd.vim diff --git a/share/vim/vim72/ftplugin/pdf.vim b/share/vim/vim73/ftplugin/pdf.vim similarity index 100% rename from share/vim/vim72/ftplugin/pdf.vim rename to share/vim/vim73/ftplugin/pdf.vim diff --git a/share/vim/vim73/ftplugin/perl.vim b/share/vim/vim73/ftplugin/perl.vim new file mode 100644 index 0000000000..1d948535aa --- /dev/null +++ b/share/vim/vim73/ftplugin/perl.vim @@ -0,0 +1,71 @@ +" Vim filetype plugin file +" Language: Perl +" Maintainer: Andy Lester <andy@petdance.com> +" URL: http://github.com/petdance/vim-perl +" Last Change: 2009-08-14 + +if exists("b:did_ftplugin") | finish | endif +let b:did_ftplugin = 1 + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +setlocal formatoptions+=crq +setlocal keywordprg=perldoc\ -f + +setlocal comments=:# +setlocal commentstring=#%s + +" Change the browse dialog on Win32 to show mainly Perl-related files +if has("gui_win32") + let b:browsefilter = "Perl Source Files (*.pl)\t*.pl\n" . + \ "Perl Modules (*.pm)\t*.pm\n" . + \ "Perl Documentation Files (*.pod)\t*.pod\n" . + \ "All Files (*.*)\t*.*\n" +endif + +" Provided by Ned Konz <ned at bike-nomad dot com> +"--------------------------------------------- +setlocal include=\\<\\(use\\\|require\\)\\> +setlocal includeexpr=substitute(substitute(v:fname,'::','/','g'),'$','.pm','') +setlocal define=[^A-Za-z_] + +" The following line changes a global variable but is necessary to make +" gf and similar commands work. The change to iskeyword was incorrect. +" Thanks to Andrew Pimlott for pointing out the problem. If this causes a +" problem for you, add an after/ftplugin/perl.vim file that contains +" set isfname-=: +set isfname+=: +"setlocal iskeyword=48-57,_,A-Z,a-z,: + +" Set this once, globally. +if !exists("perlpath") + if executable("perl") + try + if &shellxquote != '"' + let perlpath = system('perl -e "print join(q/,/,@INC)"') + else + let perlpath = system("perl -e 'print join(q/,/,@INC)'") + endif + let perlpath = substitute(perlpath,',.$',',,','') + catch /E145:/ + let perlpath = ".,," + endtry + else + " If we can't call perl to get its path, just default to using the + " current directory and the directory of the current file. + let perlpath = ".,," + endif +endif + +let &l:path=perlpath +"--------------------------------------------- + +" Undo the stuff we changed. +let b:undo_ftplugin = "setlocal fo< com< cms< inc< inex< def< isf< kp<" . + \ " | unlet! b:browsefilter" + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim73/ftplugin/perl6.vim b/share/vim/vim73/ftplugin/perl6.vim new file mode 100644 index 0000000000..14ab1e9ca3 --- /dev/null +++ b/share/vim/vim73/ftplugin/perl6.vim @@ -0,0 +1,48 @@ +" Vim filetype plugin file +" Language: Perl 6 +" Maintainer: Andy Lester <andy@petdance.com> +" URL: http://github.com/petdance/vim-perl/tree/master +" Last Change: 2010-08-10 +" Contributors: Hinrik Örn Sigurðsson <hinrik.sig@gmail.com> +" +" Based on ftplugin/perl.vim by Dan Sharp <dwsharp at hotmail dot com> + +if exists("b:did_ftplugin") | finish | endif +let b:did_ftplugin = 1 + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +setlocal formatoptions+=crq +setlocal comments=:# +setlocal commentstring=#%s + +" Change the browse dialog on Win32 to show mainly Perl-related files +if has("gui_win32") + let b:browsefilter = "Perl Source Files (*.pl)\t*.pl\n" . + \ "Perl Modules (*.pm)\t*.pm\n" . + \ "Perl Documentation Files (*.pod)\t*.pod\n" . + \ "All Files (*.*)\t*.*\n" +endif + +" Provided by Ned Konz <ned at bike-nomad dot com> +"--------------------------------------------- +setlocal include=\\<\\(use\\\|require\\)\\> +setlocal includeexpr=substitute(substitute(v:fname,'::','/','g'),'$','.pm','') +setlocal define=[^A-Za-z_] + +" The following line changes a global variable but is necessary to make +" gf and similar commands work. Thanks to Andrew Pimlott for pointing out +" the problem. If this causes a " problem for you, add an +" after/ftplugin/perl6.vim file that contains +" set isfname-=: +set isfname+=: + +" Undo the stuff we changed. +let b:undo_ftplugin = "setlocal fo< com< cms< inc< inex< def< isk<" . + \ " | unlet! b:browsefilter" + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim73/ftplugin/php.vim b/share/vim/vim73/ftplugin/php.vim new file mode 100644 index 0000000000..f59cf122f4 --- /dev/null +++ b/share/vim/vim73/ftplugin/php.vim @@ -0,0 +1,82 @@ +" Vim filetype plugin file +" Language: php +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "HTML Files (*.html, *.htm)\t*.html;*.htm\n" . + \ "All Files (*.*)\t*.*\n" +let s:match_words = "" + +runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim +let b:did_ftplugin = 1 + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter +endif +if exists("b:match_words") + let s:match_words = b:match_words +endif +if exists("b:match_skip") + unlet b:match_skip +endif + +" Change the :browse e filter to primarily show PHP-related files. +if has("gui_win32") + let b:browsefilter="PHP Files (*.php)\t*.php\n" . s:browsefilter +endif + +" ### +" Provided by Mikolaj Machowski <mikmach at wp dot pl> +setlocal include=\\\(require\\\|include\\\)\\\(_once\\\)\\\? +" Disabled changing 'iskeyword', it breaks a command such as "*" +" setlocal iskeyword+=$ + +if exists("loaded_matchit") + let b:match_words = '<?php:?>,\<switch\>:\<endswitch\>,' . + \ '\<if\>:\<elseif\>:\<else\>:\<endif\>,' . + \ '\<while\>:\<endwhile\>,' . + \ '\<do\>:\<while\>,' . + \ '\<for\>:\<endfor\>,' . + \ '\<foreach\>:\<endforeach\>,' . + \ '(:),[:],{:},' . + \ s:match_words +endif +" ### + +if exists('&omnifunc') + setlocal omnifunc=phpcomplete#CompletePHP +endif + +" Section jumping: [[ and ]] provided by Antony Scriven <adscriven at gmail dot com> +let s:function = '\(abstract\s\+\|final\s\+\|private\s\+\|protected\s\+\|public\s\+\|static\s\+\)*function' +let s:class = '\(abstract\s\+\|final\s\+\)*class' +let s:interface = 'interface' +let s:section = '\(.*\%#\)\@!\_^\s*\zs\('.s:function.'\|'.s:class.'\|'.s:interface.'\)' +exe 'nno <buffer> <silent> [[ ?' . escape(s:section, '|') . '?<CR>:nohls<CR>' +exe 'nno <buffer> <silent> ]] /' . escape(s:section, '|') . '/<CR>:nohls<CR>' +exe 'ono <buffer> <silent> [[ ?' . escape(s:section, '|') . '?<CR>:nohls<CR>' +exe 'ono <buffer> <silent> ]] /' . escape(s:section, '|') . '/<CR>:nohls<CR>' + +setlocal commentstring=/*%s*/ + +" Undo the stuff we changed. +let b:undo_ftplugin = "setlocal commentstring< include< omnifunc<" . + \ " | unlet! b:browsefilter b:match_words | " . + \ s:undo_ftplugin + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/pinfo.vim b/share/vim/vim73/ftplugin/pinfo.vim similarity index 100% rename from share/vim/vim72/ftplugin/pinfo.vim rename to share/vim/vim73/ftplugin/pinfo.vim diff --git a/share/vim/vim72/ftplugin/plaintex.vim b/share/vim/vim73/ftplugin/plaintex.vim similarity index 100% rename from share/vim/vim72/ftplugin/plaintex.vim rename to share/vim/vim73/ftplugin/plaintex.vim diff --git a/share/vim/vim72/ftplugin/postscr.vim b/share/vim/vim73/ftplugin/postscr.vim similarity index 100% rename from share/vim/vim72/ftplugin/postscr.vim rename to share/vim/vim73/ftplugin/postscr.vim diff --git a/share/vim/vim72/ftplugin/procmail.vim b/share/vim/vim73/ftplugin/procmail.vim similarity index 100% rename from share/vim/vim72/ftplugin/procmail.vim rename to share/vim/vim73/ftplugin/procmail.vim diff --git a/share/vim/vim72/ftplugin/prolog.vim b/share/vim/vim73/ftplugin/prolog.vim similarity index 100% rename from share/vim/vim72/ftplugin/prolog.vim rename to share/vim/vim73/ftplugin/prolog.vim diff --git a/share/vim/vim72/ftplugin/protocols.vim b/share/vim/vim73/ftplugin/protocols.vim similarity index 100% rename from share/vim/vim72/ftplugin/protocols.vim rename to share/vim/vim73/ftplugin/protocols.vim diff --git a/share/vim/vim72/ftplugin/pyrex.vim b/share/vim/vim73/ftplugin/pyrex.vim similarity index 100% rename from share/vim/vim72/ftplugin/pyrex.vim rename to share/vim/vim73/ftplugin/pyrex.vim diff --git a/share/vim/vim72/ftplugin/python.vim b/share/vim/vim73/ftplugin/python.vim similarity index 100% rename from share/vim/vim72/ftplugin/python.vim rename to share/vim/vim73/ftplugin/python.vim diff --git a/share/vim/vim73/ftplugin/qf.vim b/share/vim/vim73/ftplugin/qf.vim new file mode 100644 index 0000000000..f1d09225f0 --- /dev/null +++ b/share/vim/vim73/ftplugin/qf.vim @@ -0,0 +1,16 @@ +" Vim filetype plugin file +" Language: Vim's quickfix window +" Maintainer: Lech Lorens <Lech.Lorens@gmail.com> +" Last Changed: 22 Jul 2010 + +if exists("b:did_ftplugin") + finish +endif + +" Don't load another plugin for this buffer +let b:did_ftplugin = 1 + +let b:undo_ftplugin = "setl stl<" + +" Display the command that produced the list in the quickfix window: +setlocal stl=%q%{exists('w:quickfix_title')?\ '\ '.w:quickfix_title\ :\ ''} diff --git a/share/vim/vim72/ftplugin/quake.vim b/share/vim/vim73/ftplugin/quake.vim similarity index 100% rename from share/vim/vim72/ftplugin/quake.vim rename to share/vim/vim73/ftplugin/quake.vim diff --git a/share/vim/vim72/ftplugin/racc.vim b/share/vim/vim73/ftplugin/racc.vim similarity index 100% rename from share/vim/vim72/ftplugin/racc.vim rename to share/vim/vim73/ftplugin/racc.vim diff --git a/share/vim/vim72/ftplugin/readline.vim b/share/vim/vim73/ftplugin/readline.vim similarity index 100% rename from share/vim/vim72/ftplugin/readline.vim rename to share/vim/vim73/ftplugin/readline.vim diff --git a/share/vim/vim72/ftplugin/reva.vim b/share/vim/vim73/ftplugin/reva.vim similarity index 100% rename from share/vim/vim72/ftplugin/reva.vim rename to share/vim/vim73/ftplugin/reva.vim diff --git a/share/vim/vim72/ftplugin/rnc.vim b/share/vim/vim73/ftplugin/rnc.vim similarity index 100% rename from share/vim/vim72/ftplugin/rnc.vim rename to share/vim/vim73/ftplugin/rnc.vim diff --git a/share/vim/vim72/ftplugin/rpl.vim b/share/vim/vim73/ftplugin/rpl.vim similarity index 100% rename from share/vim/vim72/ftplugin/rpl.vim rename to share/vim/vim73/ftplugin/rpl.vim diff --git a/share/vim/vim72/ftplugin/rst.vim b/share/vim/vim73/ftplugin/rst.vim similarity index 100% rename from share/vim/vim72/ftplugin/rst.vim rename to share/vim/vim73/ftplugin/rst.vim diff --git a/share/vim/vim73/ftplugin/ruby.vim b/share/vim/vim73/ftplugin/ruby.vim new file mode 100644 index 0000000000..6b9363e480 --- /dev/null +++ b/share/vim/vim73/ftplugin/ruby.vim @@ -0,0 +1,274 @@ +" Vim filetype plugin +" Language: Ruby +" Maintainer: Gavin Sinclair <gsinclair at gmail.com> +" Last Change: 2010 Mar 15 +" URL: http://vim-ruby.rubyforge.org +" Anon CVS: See above site +" Release Coordinator: Doug Kearns <dougkearns@gmail.com> +" ---------------------------------------------------------------------------- +" +" Original matchit support thanks to Ned Konz. See his ftplugin/ruby.vim at +" http://bike-nomad.com/vim/ruby.vim. +" ---------------------------------------------------------------------------- + +" Only do this when not done yet for this buffer +if (exists("b:did_ftplugin")) + finish +endif +let b:did_ftplugin = 1 + +let s:cpo_save = &cpo +set cpo&vim + +if has("gui_running") && !has("gui_win32") + setlocal keywordprg=ri\ -T +else + setlocal keywordprg=ri +endif + +" Matchit support +if exists("loaded_matchit") && !exists("b:match_words") + let b:match_ignorecase = 0 + + let b:match_words = + \ '\<\%(if\|unless\|case\|while\|until\|for\|do\|class\|module\|def\|begin\)\>=\@!' . + \ ':' . + \ '\<\%(else\|elsif\|ensure\|when\|rescue\|break\|redo\|next\|retry\)\>' . + \ ':' . + \ '\<end\>' . + \ ',{:},\[:\],(:)' + + let b:match_skip = + \ "synIDattr(synID(line('.'),col('.'),0),'name') =~ '" . + \ "\\<ruby\\%(String\\|StringDelimiter\\|ASCIICode\\|Escape\\|" . + \ "Interpolation\\|NoInterpolation\\|Comment\\|Documentation\\|" . + \ "ConditionalModifier\\|RepeatModifier\\|OptionalDo\\|" . + \ "Function\\|BlockArgument\\|KeywordAsMethod\\|ClassVariable\\|" . + \ "InstanceVariable\\|GlobalVariable\\|Symbol\\)\\>'" +endif + +setlocal formatoptions-=t formatoptions+=croql + +setlocal include=^\\s*\\<\\(load\\\|\w*require\\)\\> +setlocal includeexpr=substitute(substitute(v:fname,'::','/','g'),'$','.rb','') +setlocal suffixesadd=.rb + +if exists("&ofu") && has("ruby") + setlocal omnifunc=rubycomplete#Complete +endif + +" To activate, :set ballooneval +if has('balloon_eval') && exists('+balloonexpr') + setlocal balloonexpr=RubyBalloonexpr() +endif + + +" TODO: +"setlocal define=^\\s*def + +setlocal comments=:# +setlocal commentstring=#\ %s + +if !exists("s:ruby_path") + if exists("g:ruby_path") + let s:ruby_path = g:ruby_path + elseif has("ruby") && has("win32") + ruby VIM::command( 'let s:ruby_path = "%s"' % ($: + begin; require %q{rubygems}; Gem.all_load_paths.sort.uniq; rescue LoadError; []; end).join(%q{,}) ) + let s:ruby_path = '.,' . substitute(s:ruby_path, '\%(^\|,\)\.\%(,\|$\)', ',,', '') + elseif executable("ruby") + let s:code = "print ($: + begin; require %q{rubygems}; Gem.all_load_paths.sort.uniq; rescue LoadError; []; end).join(%q{,})" + if &shellxquote == "'" + let s:ruby_path = system('ruby -e "' . s:code . '"') + else + let s:ruby_path = system("ruby -e '" . s:code . "'") + endif + let s:ruby_path = '.,' . substitute(s:ruby_path, '\%(^\|,\)\.\%(,\|$\)', ',,', '') + else + " If we can't call ruby to get its path, just default to using the + " current directory and the directory of the current file. + let s:ruby_path = ".,," + endif +endif + +let &l:path = s:ruby_path + +if has("gui_win32") && !exists("b:browsefilter") + let b:browsefilter = "Ruby Source Files (*.rb)\t*.rb\n" . + \ "All Files (*.*)\t*.*\n" +endif + +let b:undo_ftplugin = "setl fo< inc< inex< sua< def< com< cms< path< kp<" + \."| unlet! b:browsefilter b:match_ignorecase b:match_words b:match_skip" + \."| if exists('&ofu') && has('ruby') | setl ofu< | endif" + \."| if has('balloon_eval') && exists('+bexpr') | setl bexpr< | endif" + +if !exists("g:no_plugin_maps") && !exists("g:no_ruby_maps") + + nnoremap <silent> <buffer> [m :<C-U>call <SID>searchsyn('\<def\>','rubyDefine','b','n')<CR> + nnoremap <silent> <buffer> ]m :<C-U>call <SID>searchsyn('\<def\>','rubyDefine','','n')<CR> + nnoremap <silent> <buffer> [M :<C-U>call <SID>searchsyn('\<end\>','rubyDefine','b','n')<CR> + nnoremap <silent> <buffer> ]M :<C-U>call <SID>searchsyn('\<end\>','rubyDefine','','n')<CR> + xnoremap <silent> <buffer> [m :<C-U>call <SID>searchsyn('\<def\>','rubyDefine','b','v')<CR> + xnoremap <silent> <buffer> ]m :<C-U>call <SID>searchsyn('\<def\>','rubyDefine','','v')<CR> + xnoremap <silent> <buffer> [M :<C-U>call <SID>searchsyn('\<end\>','rubyDefine','b','v')<CR> + xnoremap <silent> <buffer> ]M :<C-U>call <SID>searchsyn('\<end\>','rubyDefine','','v')<CR> + + nnoremap <silent> <buffer> [[ :<C-U>call <SID>searchsyn('\<\%(class\<Bar>module\)\>','rubyModule\<Bar>rubyClass','b','n')<CR> + nnoremap <silent> <buffer> ]] :<C-U>call <SID>searchsyn('\<\%(class\<Bar>module\)\>','rubyModule\<Bar>rubyClass','','n')<CR> + nnoremap <silent> <buffer> [] :<C-U>call <SID>searchsyn('\<end\>','rubyModule\<Bar>rubyClass','b','n')<CR> + nnoremap <silent> <buffer> ][ :<C-U>call <SID>searchsyn('\<end\>','rubyModule\<Bar>rubyClass','','n')<CR> + xnoremap <silent> <buffer> [[ :<C-U>call <SID>searchsyn('\<\%(class\<Bar>module\)\>','rubyModule\<Bar>rubyClass','b','v')<CR> + xnoremap <silent> <buffer> ]] :<C-U>call <SID>searchsyn('\<\%(class\<Bar>module\)\>','rubyModule\<Bar>rubyClass','','v')<CR> + xnoremap <silent> <buffer> [] :<C-U>call <SID>searchsyn('\<end\>','rubyModule\<Bar>rubyClass','b','v')<CR> + xnoremap <silent> <buffer> ][ :<C-U>call <SID>searchsyn('\<end\>','rubyModule\<Bar>rubyClass','','v')<CR> + + let b:undo_ftplugin = b:undo_ftplugin + \."| sil! exe 'unmap <buffer> [[' | sil! exe 'unmap <buffer> ]]' | sil! exe 'unmap <buffer> []' | sil! exe 'unmap <buffer> ]['" + \."| sil! exe 'unmap <buffer> [m' | sil! exe 'unmap <buffer> ]m' | sil! exe 'unmap <buffer> [M' | sil! exe 'unmap <buffer> ]M'" + + if maparg("\<C-]>",'n') == '' + nnoremap <silent> <buffer> <C-]> :<C-U>exe v:count1."tag <C-R>=RubyCursorIdentifier()<CR>"<CR> + nnoremap <silent> <buffer> g<C-]> :<C-U>exe "tjump <C-R>=RubyCursorIdentifier()<CR>"<CR> + nnoremap <silent> <buffer> g] :<C-U>exe "tselect <C-R>=RubyCursorIdentifier()<CR>"<CR> + nnoremap <silent> <buffer> <C-W>] :<C-U>exe v:count1."stag <C-R>=RubyCursorIdentifier()<CR>"<CR> + nnoremap <silent> <buffer> <C-W><C-]> :<C-U>exe v:count1."stag <C-R>=RubyCursorIdentifier()<CR>"<CR> + nnoremap <silent> <buffer> <C-W>g<C-]> :<C-U>exe "stjump <C-R>=RubyCursorIdentifier()<CR>"<CR> + nnoremap <silent> <buffer> <C-W>g] :<C-U>exe "stselect <C-R>=RubyCursorIdentifier()<CR>"<CR> + nnoremap <silent> <buffer> <C-W>} :<C-U>exe "ptag <C-R>=RubyCursorIdentifier()<CR>"<CR> + nnoremap <silent> <buffer> <C-W>g} :<C-U>exe "ptjump <C-R>=RubyCursorIdentifier()<CR>"<CR> + let b:undo_ftplugin = b:undo_ftplugin + \."| sil! exe 'nunmap <buffer> <C-]>'| sil! exe 'nunmap <buffer> g<C-]>'| sil! exe 'nunmap <buffer> g]'" + \."| sil! exe 'nunmap <buffer> <C-W>]'| sil! exe 'nunmap <buffer> <C-W><C-]>'" + \."| sil! exe 'nunmap <buffer> <C-W>g<C-]>'| sil! exe 'nunmap <buffer> <C-W>g]'" + \."| sil! exe 'nunmap <buffer> <C-W>}'| sil! exe 'nunmap <buffer> <C-W>g}'" + endif +endif + +let &cpo = s:cpo_save +unlet s:cpo_save + +if exists("g:did_ruby_ftplugin_functions") + finish +endif +let g:did_ruby_ftplugin_functions = 1 + +function! RubyBalloonexpr() + if !exists('s:ri_found') + let s:ri_found = executable('ri') + endif + if s:ri_found + let line = getline(v:beval_lnum) + let b = matchstr(strpart(line,0,v:beval_col),'\%(\w\|[:.]\)*$') + let a = substitute(matchstr(strpart(line,v:beval_col),'^\w*\%([?!]\|\s*=\)\?'),'\s\+','','g') + let str = b.a + let before = strpart(line,0,v:beval_col-strlen(b)) + let after = strpart(line,v:beval_col+strlen(a)) + if str =~ '^\.' + let str = substitute(str,'^\.','#','g') + if before =~ '\]\s*$' + let str = 'Array'.str + elseif before =~ '}\s*$' + " False positives from blocks here + let str = 'Hash'.str + elseif before =~ "[\"'`]\\s*$" || before =~ '\$\d\+\s*$' + let str = 'String'.str + elseif before =~ '\$\d\+\.\d\+\s*$' + let str = 'Float'.str + elseif before =~ '\$\d\+\s*$' + let str = 'Integer'.str + elseif before =~ '/\s*$' + let str = 'Regexp'.str + else + let str = substitute(str,'^#','.','') + endif + endif + let str = substitute(str,'.*\.\s*to_f\s*\.\s*','Float#','') + let str = substitute(str,'.*\.\s*to_i\%(nt\)\=\s*\.\s*','Integer#','') + let str = substitute(str,'.*\.\s*to_s\%(tr\)\=\s*\.\s*','String#','') + let str = substitute(str,'.*\.\s*to_sym\s*\.\s*','Symbol#','') + let str = substitute(str,'.*\.\s*to_a\%(ry\)\=\s*\.\s*','Array#','') + let str = substitute(str,'.*\.\s*to_proc\s*\.\s*','Proc#','') + if str !~ '^\w' + return '' + endif + silent! let res = substitute(system("ri -f simple -T \"".str.'"'),'\n$','','') + if res =~ '^Nothing known about' || res =~ '^Bad argument:' || res =~ '^More than one method' + return '' + endif + return res + else + return "" + endif +endfunction + +function! s:searchsyn(pattern,syn,flags,mode) + norm! m' + if a:mode ==# 'v' + norm! gv + endif + let i = 0 + let cnt = v:count ? v:count : 1 + while i < cnt + let i = i + 1 + let line = line('.') + let col = col('.') + let pos = search(a:pattern,'W'.a:flags) + while pos != 0 && s:synname() !~# a:syn + let pos = search(a:pattern,'W'.a:flags) + endwhile + if pos == 0 + call cursor(line,col) + return + endif + endwhile +endfunction + +function! s:synname() + return synIDattr(synID(line('.'),col('.'),0),'name') +endfunction + +function! RubyCursorIdentifier() + let asciicode = '\%(\w\|[]})\"'."'".']\)\@<!\%(?\%(\\M-\\C-\|\\C-\\M-\|\\M-\\c\|\\c\\M-\|\\c\|\\C-\|\\M-\)\=\%(\\\o\{1,3}\|\\x\x\{1,2}\|\\\=\S\)\)' + let number = '\%(\%(\w\|[]})\"'."'".']\s*\)\@<!-\)\=\%(\<[[:digit:]_]\+\%(\.[[:digit:]_]\+\)\=\%([Ee][[:digit:]_]\+\)\=\>\|\<0[xXbBoOdD][[:xdigit:]_]\+\>\)\|'.asciicode + let operator = '\%(\[\]\|<<\|<=>\|[!<>]=\=\|===\=\|[!=]\~\|>>\|\*\*\|\.\.\.\=\|=>\|[~^&|*/%+-]\)' + let method = '\%(\<[_a-zA-Z]\w*\>\%([?!]\|\s*=>\@!\)\=\)' + let global = '$\%([!$&"'."'".'*+,./:;<=>?@\`~]\|-\=\w\+\>\)' + let symbolizable = '\%(\%(@@\=\)\w\+\>\|'.global.'\|'.method.'\|'.operator.'\)' + let pattern = '\C\s*\%('.number.'\|\%(:\@<!:\)\='.symbolizable.'\)' + let [lnum, col] = searchpos(pattern,'bcn',line('.')) + let raw = matchstr(getline('.')[col-1 : ],pattern) + let stripped = substitute(substitute(raw,'\s\+=$','=',''),'^\s*:\=','','') + return stripped == '' ? expand("<cword>") : stripped +endfunction + +" +" Instructions for enabling "matchit" support: +" +" 1. Look for the latest "matchit" plugin at +" +" http://www.vim.org/scripts/script.php?script_id=39 +" +" It is also packaged with Vim, in the $VIMRUNTIME/macros directory. +" +" 2. Copy "matchit.txt" into a "doc" directory (e.g. $HOME/.vim/doc). +" +" 3. Copy "matchit.vim" into a "plugin" directory (e.g. $HOME/.vim/plugin). +" +" 4. Ensure this file (ftplugin/ruby.vim) is installed. +" +" 5. Ensure you have this line in your $HOME/.vimrc: +" filetype plugin on +" +" 6. Restart Vim and create the matchit documentation: +" +" :helptags ~/.vim/doc +" +" Now you can do ":help matchit", and you should be able to use "%" on Ruby +" keywords. Try ":echo b:match_words" to be sure. +" +" Thanks to Mark J. Reed for the instructions. See ":help vimrc" for the +" locations of plugin directories, etc., as there are several options, and it +" differs on Windows. Email gsinclair@soyabean.com.au if you need help. +" + +" vim: nowrap sw=2 sts=2 ts=8: diff --git a/share/vim/vim73/ftplugin/sass.vim b/share/vim/vim73/ftplugin/sass.vim new file mode 100644 index 0000000000..64232a0894 --- /dev/null +++ b/share/vim/vim73/ftplugin/sass.vim @@ -0,0 +1,22 @@ +" Vim filetype plugin +" Language: Sass +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 Jul 26 + +" Only do this when not done yet for this buffer +if exists("b:did_ftplugin") + finish +endif +let b:did_ftplugin = 1 + +let b:undo_ftplugin = "setl cms< def< inc< inex< ofu< sua<" + +setlocal commentstring=//\ %s +setlocal define=^\\s*\\%(@mixin\\\|=\\) +setlocal includeexpr=substitute(v:fname,'\\%(.*/\\\|^\\)\\zs','_','') +setlocal omnifunc=csscomplete#CompleteCSS +setlocal suffixesadd=.sass,.scss,.css + +let &l:include = '^\s*@import\s\+\%(url(\)\=["'']\=' + +" vim:set sw=2: diff --git a/share/vim/vim72/ftplugin/scheme.vim b/share/vim/vim73/ftplugin/scheme.vim similarity index 100% rename from share/vim/vim72/ftplugin/scheme.vim rename to share/vim/vim73/ftplugin/scheme.vim diff --git a/share/vim/vim72/ftplugin/screen.vim b/share/vim/vim73/ftplugin/screen.vim similarity index 100% rename from share/vim/vim72/ftplugin/screen.vim rename to share/vim/vim73/ftplugin/screen.vim diff --git a/share/vim/vim73/ftplugin/scss.vim b/share/vim/vim73/ftplugin/scss.vim new file mode 100644 index 0000000000..981fb1b881 --- /dev/null +++ b/share/vim/vim73/ftplugin/scss.vim @@ -0,0 +1,12 @@ +" Vim filetype plugin +" Language: SCSS +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 Jul 26 + +if exists("b:did_ftplugin") + finish +endif + +runtime! ftplugin/sass.vim + +" vim:set sw=2: diff --git a/share/vim/vim72/ftplugin/sensors.vim b/share/vim/vim73/ftplugin/sensors.vim similarity index 100% rename from share/vim/vim72/ftplugin/sensors.vim rename to share/vim/vim73/ftplugin/sensors.vim diff --git a/share/vim/vim72/ftplugin/services.vim b/share/vim/vim73/ftplugin/services.vim similarity index 100% rename from share/vim/vim72/ftplugin/services.vim rename to share/vim/vim73/ftplugin/services.vim diff --git a/share/vim/vim72/ftplugin/setserial.vim b/share/vim/vim73/ftplugin/setserial.vim similarity index 100% rename from share/vim/vim72/ftplugin/setserial.vim rename to share/vim/vim73/ftplugin/setserial.vim diff --git a/share/vim/vim73/ftplugin/sgml.vim b/share/vim/vim73/ftplugin/sgml.vim new file mode 100644 index 0000000000..a07d31f085 --- /dev/null +++ b/share/vim/vim73/ftplugin/sgml.vim @@ -0,0 +1,39 @@ +" Vim filetype plugin file +" Language: sgml +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "XML Files (*.xml)\t*.xml\n" . + \ "All Files (*.*)\t*.*\n" + +runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim +let b:did_ftplugin = 1 + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter +endif + +" Change the :browse e filter to primarily show xml-related files. +if has("gui_win32") + let b:browsefilter="SGML Files (*.sgml,*.sgm)\t*.sgm*\n" . s:browsefilter +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "unlet! b:browsefilter | " . s:undo_ftplugin + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim73/ftplugin/sh.vim b/share/vim/vim73/ftplugin/sh.vim new file mode 100644 index 0000000000..076b5efdab --- /dev/null +++ b/share/vim/vim73/ftplugin/sh.vim @@ -0,0 +1,38 @@ +" Vim filetype plugin file +" Language: sh +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif +let b:did_ftplugin = 1 + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +setlocal commentstring=#%s + +" Shell: thanks to Johannes Zellner +if exists("loaded_matchit") + let s:sol = '\%(;\s*\|^\s*\)\@<=' " start of line + let b:match_words = + \ s:sol.'if\>:' . s:sol.'elif\>:' . s:sol.'else\>:' . s:sol. 'fi\>,' . + \ s:sol.'\%(for\|while\)\>:' . s:sol. 'done\>,' . + \ s:sol.'case\>:' . s:sol. 'esac\>' +endif + +" Change the :browse e filter to primarily show shell-related files. +if has("gui_win32") + let b:browsefilter="Bourne Shell Scripts (*.sh)\t*.sh\n" . + \ "Korn Shell Scripts (*.ksh)\t*.ksh\n" . + \ "Bash Shell Scripts (*.bash)\t*.bash\n" . + \ "All Files (*.*)\t*.*\n" +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "setlocal cms< | unlet! b:browsefilter b:match_words" + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/sieve.vim b/share/vim/vim73/ftplugin/sieve.vim similarity index 100% rename from share/vim/vim72/ftplugin/sieve.vim rename to share/vim/vim73/ftplugin/sieve.vim diff --git a/share/vim/vim72/ftplugin/slpconf.vim b/share/vim/vim73/ftplugin/slpconf.vim similarity index 100% rename from share/vim/vim72/ftplugin/slpconf.vim rename to share/vim/vim73/ftplugin/slpconf.vim diff --git a/share/vim/vim72/ftplugin/slpreg.vim b/share/vim/vim73/ftplugin/slpreg.vim similarity index 100% rename from share/vim/vim72/ftplugin/slpreg.vim rename to share/vim/vim73/ftplugin/slpreg.vim diff --git a/share/vim/vim72/ftplugin/slpspi.vim b/share/vim/vim73/ftplugin/slpspi.vim similarity index 100% rename from share/vim/vim72/ftplugin/slpspi.vim rename to share/vim/vim73/ftplugin/slpspi.vim diff --git a/share/vim/vim72/ftplugin/spec.vim b/share/vim/vim73/ftplugin/spec.vim similarity index 100% rename from share/vim/vim72/ftplugin/spec.vim rename to share/vim/vim73/ftplugin/spec.vim diff --git a/share/vim/vim73/ftplugin/sql.vim b/share/vim/vim73/ftplugin/sql.vim new file mode 100644 index 0000000000..cbc8dcc9ad --- /dev/null +++ b/share/vim/vim73/ftplugin/sql.vim @@ -0,0 +1,493 @@ +" SQL filetype plugin file +" Language: SQL (Common for Oracle, Microsoft SQL Server, Sybase) +" Version: 7.0 +" Maintainer: David Fishburn <fishburn at ianywhere dot com> +" Last Change: 2010 Jun 11 +" Download: http://vim.sourceforge.net/script.php?script_id=454 + +" For more details please use: +" :h sql.txt +" +" This file should only contain values that are common to all SQL languages +" Oracle, Microsoft SQL Server, Sybase ASA/ASE, MySQL, and so on +" If additional features are required create: +" vimfiles/after/ftplugin/sql.vim (Windows) +" .vim/after/ftplugin/sql.vim (Unix) +" to override and add any of your own settings. + + +" This file also creates a command, SQLSetType, which allows you to change +" SQL dialects on the fly. For example, if I open an Oracle SQL file, it +" is color highlighted appropriately. If I open an Informix SQL file, it +" will still be highlighted according to Oracles settings. By running: +" :SQLSetType sqlinformix +" +" All files called sqlinformix.vim will be loaded from the indent and syntax +" directories. This allows you to easily flip SQL dialects on a per file +" basis. NOTE: you can also use completion: +" :SQLSetType <tab> +" +" To change the default dialect, add the following to your vimrc: +" let g:sql_type_default = 'sqlanywhere' +" +" This file also creates a command, SQLGetType, which allows you to +" determine what the current dialect is in use. +" :SQLGetType +" +" History +" +" Version 7.0 +" +" NF: Calls the sqlcomplete#ResetCacheSyntax() function when calling +" SQLSetType. +" +" Version 6.0 +" +" NF: Adds the command SQLGetType +" +" Version 5.0 +" +" NF: Adds the ability to choose the keys to control SQL completion, just add +" the following to your .vimrc: +" let g:ftplugin_sql_omni_key = '<C-C>' +" let g:ftplugin_sql_omni_key_right = '<Right>' +" let g:ftplugin_sql_omni_key_left = '<Left>' +" +" BF: format-options - Auto-wrap comments using textwidth was turned off +" by mistake. + + +" Only do this when not done yet for this buffer +if exists("b:did_ftplugin") + finish +endif + +let s:save_cpo = &cpo +set cpo= + +" Disable autowrapping for code, but enable for comments +" t Auto-wrap text using textwidth +" c Auto-wrap comments using textwidth, inserting the current comment +" leader automatically. +setlocal formatoptions-=t +setlocal formatoptions+=c + +" Functions/Commands to allow the user to change SQL syntax dialects +" through the use of :SQLSetType <tab> for completion. +" This works with both Vim 6 and 7. + +if !exists("*SQL_SetType") + " NOTE: You cannot use function! since this file can be + " sourced from within this function. That will result in + " an error reported by Vim. + function SQL_GetList(ArgLead, CmdLine, CursorPos) + + if !exists('s:sql_list') + " Grab a list of files that contain "sql" in their names + let list_indent = globpath(&runtimepath, 'indent/*sql*') + let list_syntax = globpath(&runtimepath, 'syntax/*sql*') + let list_ftplugin = globpath(&runtimepath, 'ftplugin/*sql*') + + let sqls = "\n".list_indent."\n".list_syntax."\n".list_ftplugin."\n" + + " Strip out everything (path info) but the filename + " Regex + " From between two newline characters + " Non-greedily grab all characters + " Followed by a valid filename \w\+\.\w\+ (sql.vim) + " Followed by a newline, but do not include the newline + " + " Replace it with just the filename (get rid of PATH) + " + " Recursively, since there are many filenames that contain + " the word SQL in the indent, syntax and ftplugin directory + let sqls = substitute( sqls, + \ '[\n]\%(.\{-}\)\(\w\+\.\w\+\)\n\@=', + \ '\1\n', + \ 'g' + \ ) + + " Remove duplicates, since sqlanywhere.vim can exist in the + " sytax, indent and ftplugin directory, yet we only want + " to display the option once + let index = match(sqls, '.\{-}\ze\n') + while index > -1 + " Get the first filename + let file = matchstr(sqls, '.\{-}\ze\n', index) + " Recursively replace any *other* occurrence of that + " filename with nothing (ie remove it) + let sqls = substitute(sqls, '\%>'.(index+strlen(file)).'c\<'.file.'\>\n', '', 'g') + " Move on to the next filename + let index = match(sqls, '.\{-}\ze\n', (index+strlen(file)+1)) + endwhile + + " Sort the list if using version 7 + if v:version >= 700 + let mylist = split(sqls, "\n") + let mylist = sort(mylist) + let sqls = join(mylist, "\n") + endif + + let s:sql_list = sqls + endif + + return s:sql_list + + endfunction + + function SQL_SetType(name) + + " User has decided to override default SQL scripts and + " specify a vendor specific version + " (ie Oracle, Informix, SQL Anywhere, ...) + " So check for an remove any settings that prevent the + " scripts from being executed, and then source the + " appropriate Vim scripts. + if exists("b:did_ftplugin") + unlet b:did_ftplugin + endif + if exists("b:current_syntax") + " echomsg 'SQLSetType - clearing syntax' + syntax clear + endif + if exists("b:did_indent") + " echomsg 'SQLSetType - clearing indent' + unlet b:did_indent + " Set these values to their defaults + setlocal indentkeys& + setlocal indentexpr& + endif + + " Ensure the name is in the correct format + let new_sql_type = substitute(a:name, + \ '\s*\([^\.]\+\)\(\.\w\+\)\?', '\L\1', '') + + " Do not specify a buffer local variable if it is + " the default value + if new_sql_type == 'sql' + let new_sql_type = 'sqloracle' + endif + let b:sql_type_override = new_sql_type + + " Remove any cached SQL since a new sytax will have different + " items and groups + if !exists('g:loaded_sql_completion') || 100 == g:loaded_sql_completion + call sqlcomplete#ResetCacheSyntax() + endif + + " Vim will automatically source the correct files if we + " change the filetype. You cannot do this with setfiletype + " since that command will only execute if a filetype has + " not already been set. In this case we want to override + " the existing filetype. + let &filetype = 'sql' + + if b:sql_compl_savefunc != "" + " We are changing the filetype to SQL from some other filetype + " which had OMNI completion defined. We need to activate the + " SQL completion plugin in order to cache some of the syntax items + " while the syntax rules for SQL are active. + call sqlcomplete#PreCacheSyntax() + endif + endfunction + command! -nargs=* -complete=custom,SQL_GetList SQLSetType :call SQL_SetType(<q-args>) + +endif + +" Functions/Commands to allow the user determine current SQL syntax dialect +" This works with both Vim 6 and 7. + +if !exists("*SQL_GetType") + function SQL_GetType() + if exists('b:sql_type_override') + echomsg "Current SQL dialect in use:".b:sql_type_override + else + echomsg "Current SQL dialect in use:".g:sql_type_default + endif + endfunction + command! -nargs=0 SQLGetType :call SQL_GetType() +endif + +if exists("b:sql_type_override") + " echo 'sourcing buffer ftplugin/'.b:sql_type_override.'.vim' + if globpath(&runtimepath, 'ftplugin/'.b:sql_type_override.'.vim') != '' + exec 'runtime ftplugin/'.b:sql_type_override.'.vim' + " else + " echomsg 'ftplugin/'.b:sql_type_override.' not exist, using default' + endif +elseif exists("g:sql_type_default") + " echo 'sourcing global ftplugin/'.g:sql_type_default.'.vim' + if globpath(&runtimepath, 'ftplugin/'.g:sql_type_default.'.vim') != '' + exec 'runtime ftplugin/'.g:sql_type_default.'.vim' + " else + " echomsg 'ftplugin/'.g:sql_type_default.'.vim not exist, using default' + endif +endif + +" If the above runtime command succeeded, do not load the default settings +if exists("b:did_ftplugin") + finish +endif + +let b:undo_ftplugin = "setl comments<" + +" Don't load another plugin for this buffer +let b:did_ftplugin = 1 +let b:current_ftplugin = 'sql' + +" Win32 can filter files in the browse dialog +if has("gui_win32") && !exists("b:browsefilter") + let b:browsefilter = "SQL Files (*.sql)\t*.sql\n" . + \ "All Files (*.*)\t*.*\n" +endif + +" Some standard expressions for use with the matchit strings +let s:notend = '\%(\<end\s\+\)\@<!' +let s:when_no_matched_or_others = '\%(\<when\>\%(\s\+\%(\%(\<not\>\s\+\)\?<matched\>\)\|\<others\>\)\@!\)' +let s:or_replace = '\%(or\s\+replace\s\+\)\?' + +" Define patterns for the matchit macro +if !exists("b:match_words") + " SQL is generally case insensitive + let b:match_ignorecase = 1 + + " Handle the following: + " if + " elseif | elsif + " else [if] + " end if + " + " [while condition] loop + " leave + " break + " continue + " exit + " end loop + " + " for + " leave + " break + " continue + " exit + " end loop + " + " do + " statements + " doend + " + " case + " when + " when + " default + " end case + " + " merge + " when not matched + " when matched + " + " EXCEPTION + " WHEN column_not_found THEN + " WHEN OTHERS THEN + " + " create[ or replace] procedure|function|event + + let b:match_words = + \ '\<begin\>:\<end\>\W*$,'. + \ + \ s:notend . '\<if\>:'. + \ '\<elsif\>\|\<elseif\>\|\<else\>:'. + \ '\<end\s\+if\>,'. + \ + \ '\<do\>\|'. + \ '\<while\>\|'. + \ '\%(' . s:notend . '\<loop\>\)\|'. + \ '\%(' . s:notend . '\<for\>\):'. + \ '\<exit\>\|\<leave\>\|\<break\>\|\<continue\>:'. + \ '\%(\<end\s\+\%(for\|loop\>\)\)\|\<doend\>,'. + \ + \ '\%('. s:notend . '\<case\>\):'. + \ '\%('.s:when_no_matched_or_others.'\):'. + \ '\%(\<when\s\+others\>\|\<end\s\+case\>\),' . + \ + \ '\<merge\>:' . + \ '\<when\s\+not\s\+matched\>:' . + \ '\<when\s\+matched\>,' . + \ + \ '\%(\<create\s\+' . s:or_replace . '\)\?'. + \ '\%(function\|procedure\|event\):'. + \ '\<returns\?\>' + " \ '\<begin\>\|\<returns\?\>:'. + " \ '\<end\>\(;\)\?\s*$' + " \ '\<exception\>:'.s:when_no_matched_or_others. + " \ ':\<when\s\+others\>,'. + " + " \ '\%(\<exception\>\|\%('. s:notend . '\<case\>\)\):'. + " \ '\%(\<default\>\|'.s:when_no_matched_or_others.'\):'. + " \ '\%(\%(\<when\s\+others\>\)\|\<end\s\+case\>\),' . +endif + +" Define how to find the macro definition of a variable using the various +" [d, [D, [_CTRL_D and so on features +" Match these values ignoring case +" ie DECLARE varname INTEGER +let &l:define = '\c\<\(VARIABLE\|DECLARE\|IN\|OUT\|INOUT\)\>' + + +" Mappings to move to the next BEGIN ... END block +" \W - no characters or digits +nmap <buffer> <silent> ]] :call search('\\c^\\s*begin\\>', 'W' )<CR> +nmap <buffer> <silent> [[ :call search('\\c^\\s*begin\\>', 'bW' )<CR> +nmap <buffer> <silent> ][ :call search('\\c^\\s*end\\W*$', 'W' )<CR> +nmap <buffer> <silent> [] :call search('\\c^\\s*end\\W*$', 'bW' )<CR> +vmap <buffer> <silent> ]] :<C-U>exec "normal! gv"<Bar>call search('\\c^\\s*begin\\>', 'W' )<CR> +vmap <buffer> <silent> [[ :<C-U>exec "normal! gv"<Bar>call search('\\c^\\s*begin\\>', 'bW' )<CR> +vmap <buffer> <silent> ][ :<C-U>exec "normal! gv"<Bar>call search('\\c^\\s*end\\W*$', 'W' )<CR> +vmap <buffer> <silent> [] :<C-U>exec "normal! gv"<Bar>call search('\\c^\\s*end\\W*$', 'bW' )<CR> + + +" By default only look for CREATE statements, but allow +" the user to override +if !exists('g:ftplugin_sql_statements') + let g:ftplugin_sql_statements = 'create' +endif + +" Predefined SQL objects what are used by the below mappings using +" the ]} style maps. +" This global variable allows the users to override it's value +" from within their vimrc. +" Note, you cannot use \?, since these patterns can be used to search +" backwards, you must use \{,1} +if !exists('g:ftplugin_sql_objects') + let g:ftplugin_sql_objects = 'function,procedure,event,' . + \ '\\(existing\\\\|global\\s\\+temporary\\s\\+\\)\\\{,1}' . + \ 'table,trigger' . + \ ',schema,service,publication,database,datatype,domain' . + \ ',index,subscription,synchronization,view,variable' +endif + +" Key to trigger SQL completion +if !exists('g:ftplugin_sql_omni_key') + let g:ftplugin_sql_omni_key = '<C-C>' +endif +" Key to trigger drill into column list +if !exists('g:ftplugin_sql_omni_key_right') + let g:ftplugin_sql_omni_key_right = '<Right>' +endif +" Key to trigger drill out of column list +if !exists('g:ftplugin_sql_omni_key_left') + let g:ftplugin_sql_omni_key_left = '<Left>' +endif + +" Replace all ,'s with bars, except ones with numbers after them. +" This will most likely be a \{,1} string. +let s:ftplugin_sql_objects = + \ '\\c^\\s*' . + \ '\\(\\(' . + \ substitute(g:ftplugin_sql_statements, ',\d\@!', '\\\\\\|', 'g') . + \ '\\)\\s\\+\\(or\\s\\+replace\\\s\+\\)\\{,1}\\)\\{,1}' . + \ '\\<\\(' . + \ substitute(g:ftplugin_sql_objects, ',\d\@!', '\\\\\\|', 'g') . + \ '\\)\\>' + +" Mappings to move to the next CREATE ... block +exec "nmap <buffer> <silent> ]} :call search('".s:ftplugin_sql_objects."', 'W')<CR>" +exec "nmap <buffer> <silent> [{ :call search('".s:ftplugin_sql_objects."', 'bW')<CR>" +" Could not figure out how to use a :call search() string in visual mode +" without it ending visual mode +" Unfortunately, this will add a entry to the search history +exec 'vmap <buffer> <silent> ]} /'.s:ftplugin_sql_objects.'<CR>' +exec 'vmap <buffer> <silent> [{ ?'.s:ftplugin_sql_objects.'<CR>' + +" Mappings to move to the next COMMENT +" +" Had to double the \ for the \| separator since this has a special +" meaning on maps +let b:comment_leader = '\\(--\\\|\\/\\/\\\|\\*\\\|\\/\\*\\\|\\*\\/\\)' +" Find the start of the next comment +let b:comment_start = '^\\(\\s*'.b:comment_leader.'.*\\n\\)\\@<!'. + \ '\\(\\s*'.b:comment_leader.'\\)' +" Find the end of the previous comment +let b:comment_end = '\\(^\\s*'.b:comment_leader.'.*\\n\\)'. + \ '\\(^\\s*'.b:comment_leader.'\\)\\@!' +" Skip over the comment +let b:comment_jump_over = "call search('". + \ '^\\(\\s*'.b:comment_leader.'.*\\n\\)\\@<!'. + \ "', 'W')" +let b:comment_skip_back = "call search('". + \ '^\\(\\s*'.b:comment_leader.'.*\\n\\)\\@<!'. + \ "', 'bW')" +" Move to the start and end of comments +exec 'nnoremap <silent><buffer> ]" :call search('."'".b:comment_start."'".', "W" )<CR>' +exec 'nnoremap <silent><buffer> [" :call search('."'".b:comment_end."'".', "W" )<CR>' +exec 'vnoremap <silent><buffer> ]" :<C-U>exec "normal! gv"<Bar>call search('."'".b:comment_start."'".', "W" )<CR>' +exec 'vnoremap <silent><buffer> [" :<C-U>exec "normal! gv"<Bar>call search('."'".b:comment_end."'".', "W" )<CR>' + +" Comments can be of the form: +" /* +" * +" */ +" or +" -- +" or +" // +setlocal comments=s1:/*,mb:*,ex:*/,:--,:// + +" Set completion with CTRL-X CTRL-O to autoloaded function. +if exists('&omnifunc') + " Since the SQL completion plugin can be used in conjunction + " with other completion filetypes it must record the previous + " OMNI function prior to setting up the SQL OMNI function + let b:sql_compl_savefunc = &omnifunc + + " This is used by the sqlcomplete.vim plugin + " Source it for it's global functions + runtime autoload/syntaxcomplete.vim + + setlocal omnifunc=sqlcomplete#Complete + " Prevent the intellisense plugin from loading + let b:sql_vis = 1 + if !exists('g:omni_sql_no_default_maps') + " Static maps which use populate the completion list + " using Vim's syntax highlighting rules + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'a <C-\><C-O>:call sqlcomplete#Map("syntax")<CR><C-X><C-O>' + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'k <C-\><C-O>:call sqlcomplete#Map("sqlKeyword")<CR><C-X><C-O>' + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'f <C-\><C-O>:call sqlcomplete#Map("sqlFunction")<CR><C-X><C-O>' + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'o <C-\><C-O>:call sqlcomplete#Map("sqlOption")<CR><C-X><C-O>' + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'T <C-\><C-O>:call sqlcomplete#Map("sqlType")<CR><C-X><C-O>' + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'s <C-\><C-O>:call sqlcomplete#Map("sqlStatement")<CR><C-X><C-O>' + " Dynamic maps which use populate the completion list + " using the dbext.vim plugin + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'t <C-\><C-O>:call sqlcomplete#Map("table")<CR><C-X><C-O>' + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'p <C-\><C-O>:call sqlcomplete#Map("procedure")<CR><C-X><C-O>' + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'v <C-\><C-O>:call sqlcomplete#Map("view")<CR><C-X><C-O>' + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'c <C-\><C-O>:call sqlcomplete#Map("column")<CR><C-X><C-O>' + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'l <C-\><C-O>:call sqlcomplete#Map("column_csv")<CR><C-X><C-O>' + " The next 3 maps are only to be used while the completion window is + " active due to the <CR> at the beginning of the map + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'L <C-Y><C-\><C-O>:call sqlcomplete#Map("column_csv")<CR><C-X><C-O>' + " <C-Right> is not recognized on most Unix systems, so only create + " these additional maps on the Windows platform. + " If you would like to use these maps, choose a different key and make + " the same map in your vimrc. + " if has('win32') + exec 'imap <buffer> '.g:ftplugin_sql_omni_key_right.' <C-R>=sqlcomplete#DrillIntoTable()<CR>' + exec 'imap <buffer> '.g:ftplugin_sql_omni_key_left.' <C-R>=sqlcomplete#DrillOutOfColumns()<CR>' + " endif + " Remove any cached items useful for schema changes + exec 'imap <buffer> '.g:ftplugin_sql_omni_key.'R <C-\><C-O>:call sqlcomplete#Map("resetCache")<CR><C-X><C-O>' + endif + + if b:sql_compl_savefunc != "" + " We are changing the filetype to SQL from some other filetype + " which had OMNI completion defined. We need to activate the + " SQL completion plugin in order to cache some of the syntax items + " while the syntax rules for SQL are active. + call sqlcomplete#ResetCacheSyntax() + call sqlcomplete#PreCacheSyntax() + endif +endif + +let &cpo = s:save_cpo + +" vim:sw=4: + diff --git a/share/vim/vim72/ftplugin/sshconfig.vim b/share/vim/vim73/ftplugin/sshconfig.vim similarity index 100% rename from share/vim/vim72/ftplugin/sshconfig.vim rename to share/vim/vim73/ftplugin/sshconfig.vim diff --git a/share/vim/vim72/ftplugin/sudoers.vim b/share/vim/vim73/ftplugin/sudoers.vim similarity index 100% rename from share/vim/vim72/ftplugin/sudoers.vim rename to share/vim/vim73/ftplugin/sudoers.vim diff --git a/share/vim/vim73/ftplugin/svg.vim b/share/vim/vim73/ftplugin/svg.vim new file mode 100644 index 0000000000..f8a0d6200a --- /dev/null +++ b/share/vim/vim73/ftplugin/svg.vim @@ -0,0 +1,39 @@ +" Vim filetype plugin file +" Language: svg +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "XML Files (*.xml)\t*.xml\n" . + \ "All Files (*.*)\t*.*\n" + +runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim +let b:did_ftplugin = 1 + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter +endif + +" Change the :browse e filter to primarily show xml-related files. +if has("gui_win32") + let b:browsefilter="SVG Files (*.svg)\t*.svg\n" . s:browsefilter +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "unlet! b:browsefilter | " . s:undo_ftplugin + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/sysctl.vim b/share/vim/vim73/ftplugin/sysctl.vim similarity index 100% rename from share/vim/vim72/ftplugin/sysctl.vim rename to share/vim/vim73/ftplugin/sysctl.vim diff --git a/share/vim/vim73/ftplugin/tcl.vim b/share/vim/vim73/ftplugin/tcl.vim new file mode 100644 index 0000000000..c5bc3033eb --- /dev/null +++ b/share/vim/vim73/ftplugin/tcl.vim @@ -0,0 +1,36 @@ +" Vim filetype plugin file +" Language: Tcl +" Maintainer: Robert L Hicks <sigzero@gmail.com> +" Latest Revision: 2009-05-01 + +if exists("b:did_ftplugin") + finish +endif +let b:did_ftplugin = 1 + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:cpo_save = &cpo +set cpo-=C + +setlocal comments=:# +setlocal commentstring=#%s +setlocal formatoptions+=croql + +" Change the browse dialog on Windows to show mainly Tcl-related files +if has("gui_win32") + let b:browsefilter = "Tcl Source Files (.tcl)\t*.tcl\n" . + \ "Tcl Test Files (.test)\t*.test\n" . + \ "All Files (*.*)\t*.*\n" +endif + +"----------------------------------------------------------------------------- + +" Undo the stuff we changed. +let b:undo_ftplugin = "setlocal fo< com< cms< inc< inex< def< isf< kp<" . + \ " | unlet! b:browsefilter" + +" Restore the saved compatibility options. +let &cpo = s:cpo_save + +" vim: set et ts=4 sw=4 tw=78: diff --git a/share/vim/vim73/ftplugin/tcsh.vim b/share/vim/vim73/ftplugin/tcsh.vim new file mode 100644 index 0000000000..dacb44e719 --- /dev/null +++ b/share/vim/vim73/ftplugin/tcsh.vim @@ -0,0 +1,39 @@ +" Vim filetype plugin file +" Language: tcsh +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "csh Files (*.csh)\t*.csh\n" . + \ "All Files (*.*)\t*.*\n" + +runtime! ftplugin/csh.vim ftplugin/csh_*.vim ftplugin/csh/*.vim +let b:did_ftplugin = 1 + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter +endif + +" Change the :browse e filter to primarily show tcsh-related files. +if has("gui_win32") + let b:browsefilter="tcsh Scripts (*.tcsh)\t*.tcsh\n" . s:browsefilter +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "unlet! b:browsefilter | " . s:undo_ftplugin + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/terminfo.vim b/share/vim/vim73/ftplugin/terminfo.vim similarity index 100% rename from share/vim/vim72/ftplugin/terminfo.vim rename to share/vim/vim73/ftplugin/terminfo.vim diff --git a/share/vim/vim72/ftplugin/tex.vim b/share/vim/vim73/ftplugin/tex.vim similarity index 100% rename from share/vim/vim72/ftplugin/tex.vim rename to share/vim/vim73/ftplugin/tex.vim diff --git a/share/vim/vim72/ftplugin/udevconf.vim b/share/vim/vim73/ftplugin/udevconf.vim similarity index 100% rename from share/vim/vim72/ftplugin/udevconf.vim rename to share/vim/vim73/ftplugin/udevconf.vim diff --git a/share/vim/vim72/ftplugin/udevperm.vim b/share/vim/vim73/ftplugin/udevperm.vim similarity index 100% rename from share/vim/vim72/ftplugin/udevperm.vim rename to share/vim/vim73/ftplugin/udevperm.vim diff --git a/share/vim/vim72/ftplugin/udevrules.vim b/share/vim/vim73/ftplugin/udevrules.vim similarity index 100% rename from share/vim/vim72/ftplugin/udevrules.vim rename to share/vim/vim73/ftplugin/udevrules.vim diff --git a/share/vim/vim72/ftplugin/updatedb.vim b/share/vim/vim73/ftplugin/updatedb.vim similarity index 100% rename from share/vim/vim72/ftplugin/updatedb.vim rename to share/vim/vim73/ftplugin/updatedb.vim diff --git a/share/vim/vim72/ftplugin/vb.vim b/share/vim/vim73/ftplugin/vb.vim similarity index 100% rename from share/vim/vim72/ftplugin/vb.vim rename to share/vim/vim73/ftplugin/vb.vim diff --git a/share/vim/vim73/ftplugin/verilog.vim b/share/vim/vim73/ftplugin/verilog.vim new file mode 100644 index 0000000000..6594f2ea90 --- /dev/null +++ b/share/vim/vim73/ftplugin/verilog.vim @@ -0,0 +1,57 @@ +" Vim filetype plugin file +" Language: Verilog HDL +" Maintainer: Chih-Tsun Huang <cthuang@larc.ee.nthu.edu.tw> +" Last Change: Wed Sep 3 15:24:49 CST 2008 +" URL: http://larc.ee.nthu.edu.tw/~cthuang/vim/ftplugin/verilog.vim + +" Only do this when not done yet for this buffer +if exists("b:did_ftplugin") + finish +endif + +" Don't load another plugin for this buffer +let b:did_ftplugin = 1 + +" Set 'cpoptions' to allow line continuations +let s:cpo_save = &cpo +set cpo&vim + +" Undo the plugin effect +let b:undo_ftplugin = "setlocal fo< com< tw<" + \ . "| unlet! b:browsefilter b:match_ignorecase b:match_words" + +" Set 'formatoptions' to break comment lines but not other lines, +" and insert the comment leader when hitting <CR> or using "o". +setlocal fo-=t fo+=croqlm1 + +" Set 'comments' to format dashed lists in comments. +setlocal comments=sO:*\ -,mO:*\ \ ,exO:*/,s1:/*,mb:*,ex:*/,:// + +" Format comments to be up to 78 characters long +if &textwidth == 0 + setlocal tw=78 +endif + +" Win32 can filter files in the browse dialog +if has("gui_win32") && !exists("b:browsefilter") + let b:browsefilter = "Verilog Source Files (*.v)\t*.v\n" . + \ "All Files (*.*)\t*.*\n" +endif + +" Let the matchit plugin know what items can be matched. +if exists("loaded_matchit") + let b:match_ignorecase=0 + let b:match_words= + \ '\<begin\>:\<end\>,' . + \ '\<case\>\|\<casex\>\|\<casez\>:\<endcase\>,' . + \ '\<module\>:\<endmodule\>,' . + \ '\<if\>:\<else\>,' . + \ '\<function\>:\<endfunction\>,' . + \ '`ifdef\>:`else\>:`endif\>,' . + \ '\<task\>:\<endtask\>,' . + \ '\<specify\>:\<endspecify\>' +endif + +" Reset 'cpoptions' back to the user's setting +let &cpo = s:cpo_save +unlet s:cpo_save diff --git a/share/vim/vim72/ftplugin/vhdl.vim b/share/vim/vim73/ftplugin/vhdl.vim similarity index 100% rename from share/vim/vim72/ftplugin/vhdl.vim rename to share/vim/vim73/ftplugin/vhdl.vim diff --git a/share/vim/vim73/ftplugin/vim.vim b/share/vim/vim73/ftplugin/vim.vim new file mode 100644 index 0000000000..de8a047982 --- /dev/null +++ b/share/vim/vim73/ftplugin/vim.vim @@ -0,0 +1,74 @@ +" Vim filetype plugin +" Language: Vim +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2009 Jan 22 + +" Only do this when not done yet for this buffer +if exists("b:did_ftplugin") + finish +endif + +" Don't load another plugin for this buffer +let b:did_ftplugin = 1 + +let s:cpo_save = &cpo +set cpo-=C + +let b:undo_ftplugin = "setl fo< isk< com< tw< commentstring<" + \ . "| unlet! b:match_ignorecase b:match_words b:match_skip" + +" Set 'formatoptions' to break comment lines but not other lines, +" and insert the comment leader when hitting <CR> or using "o". +setlocal fo-=t fo+=croql + +" To allow tag lookup via CTRL-] for autoload functions, '#' must be a +" keyword character. E.g., for netrw#Nread(). +setlocal isk+=# + +" Set 'comments' to format dashed lists in comments +setlocal com=sO:\"\ -,mO:\"\ \ ,eO:\"\",:\" + +" Format comments to be up to 78 characters long +if &tw == 0 + setlocal tw=78 +endif + +" Comments start with a double quote +setlocal commentstring=\"%s + +" Move around functions. +nnoremap <silent><buffer> [[ m':call search('^\s*fu\%[nction]\>', "bW")<CR> +vnoremap <silent><buffer> [[ m':<C-U>exe "normal! gv"<Bar>call search('^\s*fu\%[nction]\>', "bW")<CR> +nnoremap <silent><buffer> ]] m':call search('^\s*fu\%[nction]\>', "W")<CR> +vnoremap <silent><buffer> ]] m':<C-U>exe "normal! gv"<Bar>call search('^\s*fu\%[nction]\>', "W")<CR> +nnoremap <silent><buffer> [] m':call search('^\s*endf*\%[unction]\>', "bW")<CR> +vnoremap <silent><buffer> [] m':<C-U>exe "normal! gv"<Bar>call search('^\s*endf*\%[unction]\>', "bW")<CR> +nnoremap <silent><buffer> ][ m':call search('^\s*endf*\%[unction]\>', "W")<CR> +vnoremap <silent><buffer> ][ m':<C-U>exe "normal! gv"<Bar>call search('^\s*endf*\%[unction]\>', "W")<CR> + +" Move around comments +nnoremap <silent><buffer> ]" :call search('^\(\s*".*\n\)\@<!\(\s*"\)', "W")<CR> +vnoremap <silent><buffer> ]" :<C-U>exe "normal! gv"<Bar>call search('^\(\s*".*\n\)\@<!\(\s*"\)', "W")<CR> +nnoremap <silent><buffer> [" :call search('\%(^\s*".*\n\)\%(^\s*"\)\@!', "bW")<CR> +vnoremap <silent><buffer> [" :<C-U>exe "normal! gv"<Bar>call search('\%(^\s*".*\n\)\%(^\s*"\)\@!', "bW")<CR> + +" Let the matchit plugin know what items can be matched. +if exists("loaded_matchit") + let b:match_ignorecase = 0 + let b:match_words = + \ '\<fu\%[nction]\>:\<retu\%[rn]\>:\<endf\%[unction]\>,' . + \ '\<\(wh\%[ile]\|for\)\>:\<brea\%[k]\>:\<con\%[tinue]\>:\<end\(w\%[hile]\|fo\%[r]\)\>,' . + \ '\<if\>:\<el\%[seif]\>:\<en\%[dif]\>,' . + \ '\<try\>:\<cat\%[ch]\>:\<fina\%[lly]\>:\<endt\%[ry]\>,' . + \ '\<aug\%[roup]\s\+\%(END\>\)\@!\S:\<aug\%[roup]\s\+END\>,' . + \ '(:)' + " Ignore ":syntax region" commands, the 'end' argument clobbers if-endif + let b:match_skip = 'getline(".") =~ "^\\s*sy\\%[ntax]\\s\\+region" || + \ synIDattr(synID(line("."),col("."),1),"name") =~? "comment\\|string"' +endif + +let &cpo = s:cpo_save +unlet s:cpo_save + +" removed this, because 'cpoptions' is a global option. +" setlocal cpo+=M " makes \%( match \) diff --git a/share/vim/vim72/ftplugin/xdefaults.vim b/share/vim/vim73/ftplugin/xdefaults.vim similarity index 100% rename from share/vim/vim72/ftplugin/xdefaults.vim rename to share/vim/vim73/ftplugin/xdefaults.vim diff --git a/share/vim/vim72/ftplugin/xf86conf.vim b/share/vim/vim73/ftplugin/xf86conf.vim similarity index 100% rename from share/vim/vim72/ftplugin/xf86conf.vim rename to share/vim/vim73/ftplugin/xf86conf.vim diff --git a/share/vim/vim73/ftplugin/xhtml.vim b/share/vim/vim73/ftplugin/xhtml.vim new file mode 100644 index 0000000000..a50ed925b1 --- /dev/null +++ b/share/vim/vim73/ftplugin/xhtml.vim @@ -0,0 +1,66 @@ +" Vim filetype plugin file +" Language: xhtml +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "HTML Files (*.html, *.htm)\t*.html;*.htm\n" . + \ "XML Files (*.xml)\t*.xml\n" . + \ "All Files (*.*)\t*.*\n" +let s:match_words = "" + +runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim +unlet b:did_ftplugin + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin + unlet b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter + unlet b:browsefilter +endif +if exists("b:match_words") + let s:match_words = b:match_words + unlet b:match_words +endif + +runtime! ftplugin/html.vim ftplugin/html_*.vim ftplugin/html/*.vim +let b:did_ftplugin = 1 + +" Combine the new set of values with those previously included. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin . " | " . s:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter . s:browsefilter +endif +if exists("b:match_words") + let s:match_words = b:match_words . "," . s:match_words +endif + +" Load the combined list of match_words for matchit.vim +if exists("loaded_matchit") + let b:match_words = s:match_words +endif + +" Change the :browse e filter to primarily show tcsh-related files. +if has("gui_win32") + let b:browsefilter="XHTML files (*.xhtml, *.xhtm)\t*.xhtml;*.xhtm\n" . s:browsefilter +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "unlet! b:browsefilter b:match_words | " . s:undo_ftplugin + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/xinetd.vim b/share/vim/vim73/ftplugin/xinetd.vim similarity index 100% rename from share/vim/vim72/ftplugin/xinetd.vim rename to share/vim/vim73/ftplugin/xinetd.vim diff --git a/share/vim/vim73/ftplugin/xml.vim b/share/vim/vim73/ftplugin/xml.vim new file mode 100644 index 0000000000..74cd064eed --- /dev/null +++ b/share/vim/vim73/ftplugin/xml.vim @@ -0,0 +1,63 @@ +" Vim filetype plugin file +" Language: xml +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif +let b:did_ftplugin = 1 + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +setlocal commentstring=<!--%s--> +setlocal comments=s:<!--,m:\ \ \ \ \ ,e:--> + +setlocal formatoptions-=t +if !exists("g:ft_xml_autocomment") || (g:ft_xml_autocomment == 1) + setlocal formatoptions+=croql +endif + + +" XML: thanks to Johannes Zellner and Akbar Ibrahim +" - case sensitive +" - don't match empty tags <fred/> +" - match <!--, --> style comments (but not --, --) +" - match <!, > inlined dtd's. This is not perfect, as it +" gets confused for example by +" <!ENTITY gt ">"> +if exists("loaded_matchit") + let b:match_ignorecase=0 + let b:match_words = + \ '<:>,' . + \ '<\@<=!\[CDATA\[:]]>,'. + \ '<\@<=!--:-->,'. + \ '<\@<=?\k\+:?>,'. + \ '<\@<=\([^ \t>/]\+\)\%(\s\+[^>]*\%([^/]>\|$\)\|>\|$\):<\@<=/\1>,'. + \ '<\@<=\%([^ \t>/]\+\)\%(\s\+[^/>]*\|$\):/>' +endif + +" +" For Omni completion, by Mikolaj Machowski. +if exists('&ofu') + setlocal ofu=xmlcomplete#CompleteTags +endif +command! -nargs=+ XMLns call xmlcomplete#CreateConnection(<f-args>) +command! -nargs=? XMLent call xmlcomplete#CreateEntConnection(<f-args>) + + +" Change the :browse e filter to primarily show xml-related files. +if has("gui_win32") + let b:browsefilter="XML Files (*.xml)\t*.xml\n" . + \ "DTD Files (*.dtd)\t*.dtd\n" . + \ "All Files (*.*)\t*.*\n" +endif + +" Undo the stuff we changed. +let b:undo_ftplugin = "setlocal commentstring< comments< formatoptions<" . + \ " | unlet! b:match_ignorecase b:match_words b:browsefilter" + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim72/ftplugin/xmodmap.vim b/share/vim/vim73/ftplugin/xmodmap.vim similarity index 100% rename from share/vim/vim72/ftplugin/xmodmap.vim rename to share/vim/vim73/ftplugin/xmodmap.vim diff --git a/share/vim/vim73/ftplugin/xs.vim b/share/vim/vim73/ftplugin/xs.vim new file mode 100644 index 0000000000..24df05d736 --- /dev/null +++ b/share/vim/vim73/ftplugin/xs.vim @@ -0,0 +1,13 @@ +" Vim filetype plugin file +" Language: XS (Perl extension interface language) +" Maintainer: Andy Lester <andy@petdance.com> +" URL: http://github.com/petdance/vim-perl +" Last Change: 2009-08-14 + +" Only do this when not done yet for this buffer +if exists("b:did_ftplugin") + finish +endif + +" Just use the C plugin for now. +runtime! ftplugin/c.vim ftplugin/c_*.vim ftplugin/c/*.vim diff --git a/share/vim/vim73/ftplugin/xsd.vim b/share/vim/vim73/ftplugin/xsd.vim new file mode 100644 index 0000000000..b0337603c1 --- /dev/null +++ b/share/vim/vim73/ftplugin/xsd.vim @@ -0,0 +1,38 @@ +" Vim filetype plugin file +" Language: xsd +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif + +" Make sure the continuation lines below do not cause problems in +" compatibility mode. +let s:save_cpo = &cpo +set cpo-=C + +" Define some defaults in case the included ftplugins don't set them. +let s:undo_ftplugin = "" +let s:browsefilter = "XML Files (*.xml)\t*.xml\n" . + \ "All Files (*.*)\t*.*\n" + +runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim +let b:did_ftplugin = 1 + +" Override our defaults if these were set by an included ftplugin. +if exists("b:undo_ftplugin") + let s:undo_ftplugin = b:undo_ftplugin +endif +if exists("b:browsefilter") + let s:browsefilter = b:browsefilter +endif + +" Change the :browse e filter to primarily show xsd-related files. +if has("gui_win32") + let b:browsefilter="XSD Files (*.xsd)\t*.xsd\n" . s:browsefilter +endif + +let b:undo_ftplugin = "unlet! b:browsefilter | " . s:undo_ftplugin + +" Restore the saved compatibility options. +let &cpo = s:save_cpo diff --git a/share/vim/vim73/ftplugin/xslt.vim b/share/vim/vim73/ftplugin/xslt.vim new file mode 100644 index 0000000000..1a5ee62865 --- /dev/null +++ b/share/vim/vim73/ftplugin/xslt.vim @@ -0,0 +1,16 @@ +" Vim filetype plugin file +" Language: xslt +" Maintainer: Dan Sharp <dwsharp at users dot sourceforge dot net> +" Last Changed: 20 Jan 2009 +" URL: http://dwsharp.users.sourceforge.net/vim/ftplugin + +if exists("b:did_ftplugin") | finish | endif + +runtime! ftplugin/xml.vim ftplugin/xml_*.vim ftplugin/xml/*.vim + +let b:did_ftplugin = 1 + +" Change the :browse e filter to primarily show xsd-related files. +if has("gui_win32") && exists("b:browsefilter") + let b:browsefilter="XSLT Files (*.xsl,*.xslt)\t*.xsl;*.xslt\n" . b:browsefilter +endif diff --git a/share/vim/vim72/ftplugin/yaml.vim b/share/vim/vim73/ftplugin/yaml.vim similarity index 100% rename from share/vim/vim72/ftplugin/yaml.vim rename to share/vim/vim73/ftplugin/yaml.vim diff --git a/share/vim/vim72/ftplugin/zsh.vim b/share/vim/vim73/ftplugin/zsh.vim similarity index 100% rename from share/vim/vim72/ftplugin/zsh.vim rename to share/vim/vim73/ftplugin/zsh.vim diff --git a/share/vim/vim72/ftplugof.vim b/share/vim/vim73/ftplugof.vim similarity index 100% rename from share/vim/vim72/ftplugof.vim rename to share/vim/vim73/ftplugof.vim diff --git a/share/vim/vim72/gvimrc_example.vim b/share/vim/vim73/gvimrc_example.vim similarity index 100% rename from share/vim/vim72/gvimrc_example.vim rename to share/vim/vim73/gvimrc_example.vim diff --git a/share/vim/vim72/hi16-action-make.png b/share/vim/vim73/hi16-action-make.png similarity index 100% rename from share/vim/vim72/hi16-action-make.png rename to share/vim/vim73/hi16-action-make.png diff --git a/share/vim/vim72/hi22-action-make.png b/share/vim/vim73/hi22-action-make.png similarity index 100% rename from share/vim/vim72/hi22-action-make.png rename to share/vim/vim73/hi22-action-make.png diff --git a/share/vim/vim72/icons.info b/share/vim/vim73/icons.info similarity index 100% rename from share/vim/vim72/icons.info rename to share/vim/vim73/icons.info diff --git a/share/vim/vim72/icons/README.txt b/share/vim/vim73/icons/README.txt similarity index 100% rename from share/vim/vim72/icons/README.txt rename to share/vim/vim73/icons/README.txt diff --git a/share/vim/vim72/icons/README.txt.info b/share/vim/vim73/icons/README.txt.info similarity index 100% rename from share/vim/vim72/icons/README.txt.info rename to share/vim/vim73/icons/README.txt.info diff --git a/share/vim/vim72/icons/Vim_32Colors.info b/share/vim/vim73/icons/Vim_32Colors.info similarity index 100% rename from share/vim/vim72/icons/Vim_32Colors.info rename to share/vim/vim73/icons/Vim_32Colors.info diff --git a/share/vim/vim72/icons/Vim_4ColorsLace.info b/share/vim/vim73/icons/Vim_4ColorsLace.info similarity index 100% rename from share/vim/vim72/icons/Vim_4ColorsLace.info rename to share/vim/vim73/icons/Vim_4ColorsLace.info diff --git a/share/vim/vim72/icons/Vim_8Colors.info b/share/vim/vim73/icons/Vim_8Colors.info similarity index 100% rename from share/vim/vim72/icons/Vim_8Colors.info rename to share/vim/vim73/icons/Vim_8Colors.info diff --git a/share/vim/vim72/icons/Vim_8ColorsLace.info b/share/vim/vim73/icons/Vim_8ColorsLace.info similarity index 100% rename from share/vim/vim72/icons/Vim_8ColorsLace.info rename to share/vim/vim73/icons/Vim_8ColorsLace.info diff --git a/share/vim/vim72/indent.vim b/share/vim/vim73/indent.vim similarity index 100% rename from share/vim/vim72/indent.vim rename to share/vim/vim73/indent.vim diff --git a/share/vim/vim72/indent/README.txt b/share/vim/vim73/indent/README.txt similarity index 100% rename from share/vim/vim72/indent/README.txt rename to share/vim/vim73/indent/README.txt diff --git a/share/vim/vim72/indent/aap.vim b/share/vim/vim73/indent/aap.vim similarity index 100% rename from share/vim/vim72/indent/aap.vim rename to share/vim/vim73/indent/aap.vim diff --git a/share/vim/vim72/indent/ada.vim b/share/vim/vim73/indent/ada.vim similarity index 100% rename from share/vim/vim72/indent/ada.vim rename to share/vim/vim73/indent/ada.vim diff --git a/share/vim/vim72/indent/ant.vim b/share/vim/vim73/indent/ant.vim similarity index 100% rename from share/vim/vim72/indent/ant.vim rename to share/vim/vim73/indent/ant.vim diff --git a/share/vim/vim72/indent/automake.vim b/share/vim/vim73/indent/automake.vim similarity index 100% rename from share/vim/vim72/indent/automake.vim rename to share/vim/vim73/indent/automake.vim diff --git a/share/vim/vim72/indent/awk.vim b/share/vim/vim73/indent/awk.vim similarity index 100% rename from share/vim/vim72/indent/awk.vim rename to share/vim/vim73/indent/awk.vim diff --git a/share/vim/vim72/indent/bib.vim b/share/vim/vim73/indent/bib.vim similarity index 100% rename from share/vim/vim72/indent/bib.vim rename to share/vim/vim73/indent/bib.vim diff --git a/share/vim/vim72/indent/bst.vim b/share/vim/vim73/indent/bst.vim similarity index 100% rename from share/vim/vim72/indent/bst.vim rename to share/vim/vim73/indent/bst.vim diff --git a/share/vim/vim72/indent/c.vim b/share/vim/vim73/indent/c.vim similarity index 100% rename from share/vim/vim72/indent/c.vim rename to share/vim/vim73/indent/c.vim diff --git a/share/vim/vim72/indent/cdl.vim b/share/vim/vim73/indent/cdl.vim similarity index 100% rename from share/vim/vim72/indent/cdl.vim rename to share/vim/vim73/indent/cdl.vim diff --git a/share/vim/vim72/indent/ch.vim b/share/vim/vim73/indent/ch.vim similarity index 100% rename from share/vim/vim72/indent/ch.vim rename to share/vim/vim73/indent/ch.vim diff --git a/share/vim/vim73/indent/chaiscript.vim b/share/vim/vim73/indent/chaiscript.vim new file mode 100644 index 0000000000..247e1a6e4c --- /dev/null +++ b/share/vim/vim73/indent/chaiscript.vim @@ -0,0 +1,50 @@ +" Vim indent file +" Language: ChaiScript +" Maintainer: Jason Turner <lefticus 'at' gmail com> + +" Only load this indent file when no other was loaded. +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +setlocal indentexpr=GetChaiScriptIndent() +setlocal autoindent + +" Only define the function once. +if exists("*GetChaiScriptIndent") + finish +endif + +function! GetChaiScriptIndent() + " Find a non-blank line above the current line. + let lnum = prevnonblank(v:lnum - 1) + + " Hit the start of the file, use zero indent. + if lnum == 0 + return 0 + endif + + " Add a 'shiftwidth' after lines that start a block: + " lines containing a { + let ind = indent(lnum) + let flag = 0 + let prevline = getline(lnum) + if prevline =~ '^.*{.*' + let ind = ind + &shiftwidth + let flag = 1 + endif + + " Subtract a 'shiftwidth' after lines containing a { followed by a } + " to keep it balanced + if flag == 1 && prevline =~ '.*{.*}.*' + let ind = ind - &shiftwidth + endif + + " Subtract a 'shiftwidth' on lines ending with } + if getline(v:lnum) =~ '^\s*\%(}\)' + let ind = ind - &shiftwidth + endif + + return ind +endfunction diff --git a/share/vim/vim72/indent/changelog.vim b/share/vim/vim73/indent/changelog.vim similarity index 100% rename from share/vim/vim72/indent/changelog.vim rename to share/vim/vim73/indent/changelog.vim diff --git a/share/vim/vim73/indent/cmake.vim b/share/vim/vim73/indent/cmake.vim new file mode 100644 index 0000000000..8c408fb1ec --- /dev/null +++ b/share/vim/vim73/indent/cmake.vim @@ -0,0 +1,85 @@ +" Vim indent file +" Program: CMake - Cross-Platform Makefile Generator +" Module: $RCSfile: cmake-indent.vim,v $ +" Language: CMake (ft=cmake) +" Author: Andy Cedilnik <andy.cedilnik@kitware.com> +" Maintainer: Karthik Krishnan <karthik.krishnan@kitware.com> +" Last Change: $Date: 2008-01-16 16:53:53 $ +" Version: $Revision: 1.9 $ +" +" Licence: The CMake license applies to this file. See +" http://www.cmake.org/HTML/Copyright.html +" This implies that distribution with Vim is allowed + +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +setlocal indentexpr=CMakeGetIndent(v:lnum) +setlocal indentkeys+==ENDIF(,ENDFOREACH(,ENDMACRO(,ELSE(,ELSEIF(,ENDWHILE( + +" Only define the function once. +if exists("*CMakeGetIndent") + finish +endif + +fun! CMakeGetIndent(lnum) + let this_line = getline(a:lnum) + + " Find a non-blank line above the current line. + let lnum = a:lnum + let lnum = prevnonblank(lnum - 1) + let previous_line = getline(lnum) + + " Hit the start of the file, use zero indent. + if lnum == 0 + return 0 + endif + + let ind = indent(lnum) + + let or = '\|' + " Regular expressions used by line indentation function. + let cmake_regex_comment = '#.*' + let cmake_regex_identifier = '[A-Za-z][A-Za-z0-9_]*' + let cmake_regex_quoted = '"\([^"\\]\|\\.\)*"' + let cmake_regex_arguments = '\(' . cmake_regex_quoted . + \ or . '\$(' . cmake_regex_identifier . ')' . + \ or . '[^()\\#"]' . or . '\\.' . '\)*' + + let cmake_indent_comment_line = '^\s*' . cmake_regex_comment + let cmake_indent_blank_regex = '^\s*$' + let cmake_indent_open_regex = '^\s*' . cmake_regex_identifier . + \ '\s*(' . cmake_regex_arguments . + \ '\(' . cmake_regex_comment . '\)\?$' + + let cmake_indent_close_regex = '^' . cmake_regex_arguments . + \ ')\s*' . + \ '\(' . cmake_regex_comment . '\)\?$' + + let cmake_indent_begin_regex = '^\s*\(IF\|MACRO\|FOREACH\|ELSE\|ELSEIF\|WHILE\|FUNCTION\)\s*(' + let cmake_indent_end_regex = '^\s*\(ENDIF\|ENDFOREACH\|ENDMACRO\|ELSE\|ELSEIF\|ENDWHILE\|ENDFUNCTION\)\s*(' + + " Add + if previous_line =~? cmake_indent_comment_line " Handle comments + let ind = ind + else + if previous_line =~? cmake_indent_begin_regex + let ind = ind + &sw + endif + if previous_line =~? cmake_indent_open_regex + let ind = ind + &sw + endif + endif + + " Subtract + if this_line =~? cmake_indent_end_regex + let ind = ind - &sw + endif + if previous_line =~? cmake_indent_close_regex + let ind = ind - &sw + endif + + return ind +endfun diff --git a/share/vim/vim72/indent/cobol.vim b/share/vim/vim73/indent/cobol.vim similarity index 100% rename from share/vim/vim72/indent/cobol.vim rename to share/vim/vim73/indent/cobol.vim diff --git a/share/vim/vim72/indent/config.vim b/share/vim/vim73/indent/config.vim similarity index 100% rename from share/vim/vim72/indent/config.vim rename to share/vim/vim73/indent/config.vim diff --git a/share/vim/vim73/indent/cpp.vim b/share/vim/vim73/indent/cpp.vim new file mode 100644 index 0000000000..ffa37d7208 --- /dev/null +++ b/share/vim/vim73/indent/cpp.vim @@ -0,0 +1,15 @@ +" Vim indent file +" Language: C++ +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2008 Nov 29 + +" Only load this indent file when no other was loaded. +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +" C++ indenting is built-in, thus this is very simple +setlocal cindent + +let b:undo_indent = "setl cin<" diff --git a/share/vim/vim72/indent/cs.vim b/share/vim/vim73/indent/cs.vim similarity index 100% rename from share/vim/vim72/indent/cs.vim rename to share/vim/vim73/indent/cs.vim diff --git a/share/vim/vim72/indent/css.vim b/share/vim/vim73/indent/css.vim similarity index 100% rename from share/vim/vim72/indent/css.vim rename to share/vim/vim73/indent/css.vim diff --git a/share/vim/vim73/indent/cucumber.vim b/share/vim/vim73/indent/cucumber.vim new file mode 100644 index 0000000000..a19d123f7e --- /dev/null +++ b/share/vim/vim73/indent/cucumber.vim @@ -0,0 +1,60 @@ +" Vim indent file +" Language: Cucumber +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 21 + +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +setlocal autoindent +setlocal indentexpr=GetCucumberIndent() +setlocal indentkeys=o,O,*<Return>,<:>,0<Bar>,0#,=,!^F + +" Only define the function once. +if exists("*GetCucumberIndent") + finish +endif + +function! s:syn(lnum) + return synIDattr(synID(a:lnum,1+indent(a:lnum),1),'name') +endfunction + +function! GetCucumberIndent() + let line = getline(prevnonblank(v:lnum-1)) + let cline = getline(v:lnum) + let syn = s:syn(prevnonblank(v:lnum-1)) + let csyn = s:syn(v:lnum) + if csyn ==# 'cucumberFeature' || cline =~# '^\s*Feature:' + return 0 + elseif csyn ==# 'cucumberExamples' || cline =~# '^\s*\%(Examples\|Scenarios\):' + return 2 * &sw + elseif csyn =~# '^cucumber\%(Background\|Scenario\|ScenarioOutline\)$' || cline =~# '^\s*\%(Background\|Scenario\|Scenario Outline\):' + return &sw + elseif syn ==# 'cucumberFeature' || line =~# '^\s*Feature:' + return &sw + elseif syn ==# 'cucumberExamples' || line =~# '^\s*\%(Examples\|Scenarios\):' + return 3 * &sw + elseif syn =~# '^cucumber\%(Background\|Scenario\|ScenarioOutline\)$' || line =~# '^\s*\%(Background\|Scenario\|Scenario Outline\):' + return 2 * &sw + elseif cline =~# '^\s*@' && (s:syn(nextnonblank(v:lnum+1)) == 'cucumberFeature' || getline(nextnonblank(v:lnum+1)) =~# '^\s*Feature:' || indent(prevnonblank(v:lnum-1)) <= 0) + return 0 + elseif line =~# '^\s*@' + return &sw + elseif cline =~# '^\s*|' && line =~# '^\s*|' + return indent(prevnonblank(v:lnum-1)) + elseif cline =~# '^\s*|' && line =~# '^\s*[^|#]' + return indent(prevnonblank(v:lnum-1)) + &sw + elseif cline =~# '^\s*[^|# \t]' && line =~# '^\s*|' + return indent(prevnonblank(v:lnum-1)) - &sw + elseif cline =~# '^\s*$' && line =~# '^\s*|' + let in = indent(prevnonblank(v:lnum-1)) + return in == indent(v:lnum) ? in : in - &sw + elseif cline =~# '^\s*#' && getline(v:lnum-1) =~ '^\s*$' && getline(v:lnum+1) =~# '\S' + return indent(getline(v:lnum+1)) + endif + return indent(prevnonblank(v:lnum-1)) +endfunction + +" vim:set sts=2 sw=2: diff --git a/share/vim/vim73/indent/cuda.vim b/share/vim/vim73/indent/cuda.vim new file mode 100644 index 0000000000..68ee9cec0c --- /dev/null +++ b/share/vim/vim73/indent/cuda.vim @@ -0,0 +1,15 @@ +" Vim indent file +" Language: CUDA +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2008 Nov 29 + +" Only load this indent file when no other was loaded. +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +" It's just like C indenting +setlocal cindent + +let b:undo_indent = "setl cin<" diff --git a/share/vim/vim72/indent/d.vim b/share/vim/vim73/indent/d.vim similarity index 100% rename from share/vim/vim72/indent/d.vim rename to share/vim/vim73/indent/d.vim diff --git a/share/vim/vim72/indent/dictconf.vim b/share/vim/vim73/indent/dictconf.vim similarity index 100% rename from share/vim/vim72/indent/dictconf.vim rename to share/vim/vim73/indent/dictconf.vim diff --git a/share/vim/vim72/indent/dictdconf.vim b/share/vim/vim73/indent/dictdconf.vim similarity index 100% rename from share/vim/vim72/indent/dictdconf.vim rename to share/vim/vim73/indent/dictdconf.vim diff --git a/share/vim/vim72/indent/docbk.vim b/share/vim/vim73/indent/docbk.vim similarity index 100% rename from share/vim/vim72/indent/docbk.vim rename to share/vim/vim73/indent/docbk.vim diff --git a/share/vim/vim72/indent/dtd.vim b/share/vim/vim73/indent/dtd.vim similarity index 100% rename from share/vim/vim72/indent/dtd.vim rename to share/vim/vim73/indent/dtd.vim diff --git a/share/vim/vim72/indent/dtrace.vim b/share/vim/vim73/indent/dtrace.vim similarity index 100% rename from share/vim/vim72/indent/dtrace.vim rename to share/vim/vim73/indent/dtrace.vim diff --git a/share/vim/vim72/indent/dylan.vim b/share/vim/vim73/indent/dylan.vim similarity index 100% rename from share/vim/vim72/indent/dylan.vim rename to share/vim/vim73/indent/dylan.vim diff --git a/share/vim/vim72/indent/eiffel.vim b/share/vim/vim73/indent/eiffel.vim similarity index 100% rename from share/vim/vim72/indent/eiffel.vim rename to share/vim/vim73/indent/eiffel.vim diff --git a/share/vim/vim72/indent/erlang.vim b/share/vim/vim73/indent/erlang.vim similarity index 100% rename from share/vim/vim72/indent/erlang.vim rename to share/vim/vim73/indent/erlang.vim diff --git a/share/vim/vim73/indent/eruby.vim b/share/vim/vim73/indent/eruby.vim new file mode 100644 index 0000000000..a4de118ccf --- /dev/null +++ b/share/vim/vim73/indent/eruby.vim @@ -0,0 +1,81 @@ +" Vim indent file +" Language: eRuby +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 28 +" URL: http://vim-ruby.rubyforge.org +" Anon CVS: See above site +" Release Coordinator: Doug Kearns <dougkearns@gmail.com> + +if exists("b:did_indent") + finish +endif + +runtime! indent/ruby.vim +unlet! b:did_indent +setlocal indentexpr= + +if exists("b:eruby_subtype") + exe "runtime! indent/".b:eruby_subtype.".vim" +else + runtime! indent/html.vim +endif +unlet! b:did_indent + +if &l:indentexpr == '' + if &l:cindent + let &l:indentexpr = 'cindent(v:lnum)' + else + let &l:indentexpr = 'indent(prevnonblank(v:lnum-1))' + endif +endif +let b:eruby_subtype_indentexpr = &l:indentexpr + +let b:did_indent = 1 + +setlocal indentexpr=GetErubyIndent() +setlocal indentkeys=o,O,*<Return>,<>>,{,},0),0],o,O,!^F,=end,=else,=elsif,=rescue,=ensure,=when + +" Only define the function once. +if exists("*GetErubyIndent") + finish +endif + +function! GetErubyIndent(...) + if a:0 && a:1 == '.' + let v:lnum = line('.') + elseif a:0 && a:1 =~ '^\d' + let v:lnum = a:1 + endif + let vcol = col('.') + call cursor(v:lnum,1) + let inruby = searchpair('<%','','%>','W') + call cursor(v:lnum,vcol) + if inruby && getline(v:lnum) !~ '^<%\|^\s*-\=%>' + let ind = GetRubyIndent() + else + exe "let ind = ".b:eruby_subtype_indentexpr + endif + let lnum = prevnonblank(v:lnum-1) + let line = getline(lnum) + let cline = getline(v:lnum) + if cline =~# '^\s*<%-\=\s*\%(}\|end\|else\|\%(ensure\|rescue\|elsif\|when\).\{-\}\)\s*\%(-\=%>\|$\)' + let ind = ind - &sw + endif + if line =~# '\S\s*<%-\=\s*\%(}\|end\).\{-\}\s*\%(-\=%>\|$\)' + let ind = ind - &sw + endif + if line =~# '\%({\|\<do\)\%(\s*|[^|]*|\)\=\s*-\=%>' + let ind = ind + &sw + elseif line =~# '<%-\=\s*\%(module\|class\|def\|if\|for\|while\|until\|else\|elsif\|case\|when\|unless\|begin\|ensure\|rescue\)\>.*%>' + let ind = ind + &sw + endif + if line =~# '^\s*<%[=#-]\=\s*$' && cline !~# '^\s*end\>' + let ind = ind + &sw + endif + if cline =~# '^\s*-\=%>\s*$' + let ind = ind - &sw + endif + return ind +endfunction + +" vim:set sw=2 sts=2 ts=8 noet: diff --git a/share/vim/vim72/indent/eterm.vim b/share/vim/vim73/indent/eterm.vim similarity index 100% rename from share/vim/vim72/indent/eterm.vim rename to share/vim/vim73/indent/eterm.vim diff --git a/share/vim/vim73/indent/fortran.vim b/share/vim/vim73/indent/fortran.vim new file mode 100644 index 0000000000..4ff0700fd2 --- /dev/null +++ b/share/vim/vim73/indent/fortran.vim @@ -0,0 +1,166 @@ +" Vim indent file +" Language: Fortran95 (and Fortran90, Fortran77, F and elf90) +" Version: 0.38 +" Last Change: 2010 July 21 +" Maintainer: Ajit J. Thakkar <ajit@unb.ca>; <http://www.unb.ca/chem/ajit/> +" Usage: Do :help fortran-indent from Vim + +" Only load this indent file when no other was loaded. +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +setlocal indentkeys+==~end,=~case,=~if,=~else,=~do,=~where,=~elsewhere,=~select +setlocal indentkeys+==~endif,=~enddo,=~endwhere,=~endselect +setlocal indentkeys+==~type,=~interface + +" Determine whether this is a fixed or free format source file +" if this hasn't been done yet +if !exists("b:fortran_fixed_source") + if exists("fortran_free_source") + " User guarantees free source form + let b:fortran_fixed_source = 0 + elseif exists("fortran_fixed_source") + " User guarantees fixed source form + let b:fortran_fixed_source = 1 + else + " f90 and f95 allow both fixed and free source form + " assume fixed source form unless signs of free source form + " are detected in the first five columns of the first 250 lines + " Detection becomes more accurate and time-consuming if more lines + " are checked. Increase the limit below if you keep lots of comments at + " the very top of each file and you have a fast computer + let s:lmax = 500 + if ( s:lmax > line("$") ) + let s:lmax = line("$") + endif + let b:fortran_fixed_source = 1 + let s:ln=1 + while s:ln <= s:lmax + let s:test = strpart(getline(s:ln),0,5) + if s:test !~ '^[Cc*]' && s:test !~ '^ *[!#]' && s:test =~ '[^ 0-9\t]' && s:test !~ '^[ 0-9]*\t' + let b:fortran_fixed_source = 0 + break + endif + let s:ln = s:ln + 1 + endwhile + endif +endif + +" Define the appropriate indent function but only once +if (b:fortran_fixed_source == 1) + setlocal indentexpr=FortranGetFixedIndent() + if exists("*FortranGetFixedIndent") + finish + endif +else + setlocal indentexpr=FortranGetFreeIndent() + if exists("*FortranGetFreeIndent") + finish + endif +endif + +let s:cposet=&cpoptions +set cpoptions-=C + +function FortranGetIndent(lnum) + let ind = indent(a:lnum) + let prevline=getline(a:lnum) + " Strip tail comment + let prevstat=substitute(prevline, '!.*$', '', '') + + "Indent do loops only if they are all guaranteed to be of do/end do type + if exists("b:fortran_do_enddo") || exists("g:fortran_do_enddo") + if prevstat =~? '^\s*\(\d\+\s\)\=\s*\(\a\w*\s*:\)\=\s*do\>' + let ind = ind + &sw + endif + if getline(v:lnum) =~? '^\s*\(\d\+\s\)\=\s*end\s*do\>' + let ind = ind - &sw + endif + endif + + "Add a shiftwidth to statements following if, else, case, + "where, elsewhere, type and interface statements + if prevstat =~? '^\s*\(\d\+\s\)\=\s*\(else\|case\|where\|elsewhere\)\>' + \ ||prevstat =~? '^\s*\(\d\+\s\)\=\s*\(type\|interface\)\>' + \ || prevstat =~? '^\s*\(\d\+\s\)\=\s*\(\a\w*\s*:\)\=\s*if\>' + let ind = ind + &sw + " Remove unwanted indent after logical and arithmetic ifs + if prevstat =~? '\<if\>' && prevstat !~? '\<then\>' + let ind = ind - &sw + endif + " Remove unwanted indent after type( statements + if prevstat =~? '\<type\s*(' + let ind = ind - &sw + endif + endif + + "Subtract a shiftwidth from else, elsewhere, case, end if, + " end where, end select, end interface and end type statements + if getline(v:lnum) =~? '^\s*\(\d\+\s\)\=\s*' + \. '\(else\|elsewhere\|case\|end\s*\(if\|where\|select\|interface\|type\)\)\>' + let ind = ind - &sw + " Fix indent for case statement immediately after select + if prevstat =~? '\<select\>' + let ind = ind + &sw + endif + endif + + return ind +endfunction + +function FortranGetFreeIndent() + "Find the previous non-blank line + let lnum = prevnonblank(v:lnum - 1) + + "Use zero indent at the top of the file + if lnum == 0 + return 0 + endif + + let ind=FortranGetIndent(lnum) + return ind +endfunction + +function FortranGetFixedIndent() + let currline=getline(v:lnum) + "Don't indent comments, continuation lines and labelled lines + if strpart(currline,0,6) =~ '[^ \t]' + let ind = indent(v:lnum) + return ind + endif + + "Find the previous line which is not blank, not a comment, + "not a continuation line, and does not have a label + let lnum = v:lnum - 1 + while lnum > 0 + let prevline=getline(lnum) + if (prevline =~ "^[C*!]") || (prevline =~ "^\s*$") + \ || (strpart(prevline,5,1) !~ "[ 0]") + " Skip comments, blank lines and continuation lines + let lnum = lnum - 1 + else + let test=strpart(prevline,0,5) + if test =~ "[0-9]" + " Skip lines with statement numbers + let lnum = lnum - 1 + else + break + endif + endif + endwhile + + "First line must begin at column 7 + if lnum == 0 + return 6 + endif + + let ind=FortranGetIndent(lnum) + return ind +endfunction + +let &cpoptions=s:cposet +unlet s:cposet + +" vim:sw=2 tw=130 diff --git a/share/vim/vim72/indent/framescript.vim b/share/vim/vim73/indent/framescript.vim similarity index 100% rename from share/vim/vim72/indent/framescript.vim rename to share/vim/vim73/indent/framescript.vim diff --git a/share/vim/vim73/indent/gitconfig.vim b/share/vim/vim73/indent/gitconfig.vim new file mode 100644 index 0000000000..fa57e56ab6 --- /dev/null +++ b/share/vim/vim73/indent/gitconfig.vim @@ -0,0 +1,35 @@ +" Vim indent file +" Language: git config file +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 21 + +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +setlocal autoindent +setlocal indentexpr=GetGitconfigIndent() +setlocal indentkeys=o,O,*<Return>,0[,],0;,0#,=,!^F + +" Only define the function once. +if exists("*GetGitconfigIndent") + finish +endif + +function! GetGitconfigIndent() + let line = getline(prevnonblank(v:lnum-1)) + let cline = getline(v:lnum) + if line =~ '\\\@<!\%(\\\\\)*\\$' + " odd number of slashes, in a line continuation + return 2 * &sw + elseif cline =~ '^\s*\[' + return 0 + elseif cline =~ '^\s*\a' + return &sw + elseif cline == '' && line =~ '^\[' + return &sw + else + return -1 + endif +endfunction diff --git a/share/vim/vim73/indent/haml.vim b/share/vim/vim73/indent/haml.vim new file mode 100644 index 0000000000..58c0307204 --- /dev/null +++ b/share/vim/vim73/indent/haml.vim @@ -0,0 +1,73 @@ +" Vim indent file +" Language: Haml +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 21 + +if exists("b:did_indent") + finish +endif +runtime! indent/ruby.vim +unlet! b:did_indent +let b:did_indent = 1 + +setlocal autoindent sw=2 et +setlocal indentexpr=GetHamlIndent() +setlocal indentkeys=o,O,*<Return>,},],0),!^F,=end,=else,=elsif,=rescue,=ensure,=when + +" Only define the function once. +if exists("*GetHamlIndent") + finish +endif + +let s:attributes = '\%({.\{-\}}\|\[.\{-\}\]\)' +let s:tag = '\%([%.#][[:alnum:]_-]\+\|'.s:attributes.'\)*[<>]*' + +if !exists('g:haml_self_closing_tags') + let g:haml_self_closing_tags = 'meta|link|img|hr|br' +endif + +function! GetHamlIndent() + let lnum = prevnonblank(v:lnum-1) + if lnum == 0 + return 0 + endif + let line = substitute(getline(lnum),'\s\+$','','') + let cline = substitute(substitute(getline(v:lnum),'\s\+$','',''),'^\s\+','','') + let lastcol = strlen(line) + let line = substitute(line,'^\s\+','','') + let indent = indent(lnum) + let cindent = indent(v:lnum) + if cline =~# '\v^-\s*%(elsif|else|when)>' + let indent = cindent < indent ? cindent : indent - &sw + endif + let increase = indent + &sw + if indent == indent(lnum) + let indent = cindent <= indent ? -1 : increase + endif + + let group = synIDattr(synID(lnum,lastcol,1),'name') + + if line =~ '^!!!' + return indent + elseif line =~ '^/\%(\[[^]]*\]\)\=$' + return increase + elseif group == 'hamlFilter' + return increase + elseif line =~ '^'.s:tag.'[&!]\=[=~-]\s*\%(\%(if\|else\|elsif\|unless\|case\|when\|while\|until\|for\|begin\|module\|class\|def\)\>\%(.*\<end\>\)\@!\|.*do\%(\s*|[^|]*|\)\=\s*$\)' + return increase + elseif line =~ '^'.s:tag.'[&!]\=[=~-].*,\s*$' + return increase + elseif line == '-#' + return increase + elseif group =~? '\v^(hamlSelfCloser)$' || line =~? '^%\v%('.g:haml_self_closing_tags.')>' + return indent + elseif group =~? '\v^%(hamlTag|hamlAttributesDelimiter|hamlObjectDelimiter|hamlClass|hamlId|htmlTagName|htmlSpecialTagName)$' + return increase + elseif synIDattr(synID(v:lnum,1,1),'name') ==? 'hamlRubyFilter' + return GetRubyIndent() + else + return indent + endif +endfunction + +" vim:set sw=2: diff --git a/share/vim/vim72/indent/hamster.vim b/share/vim/vim73/indent/hamster.vim similarity index 100% rename from share/vim/vim72/indent/hamster.vim rename to share/vim/vim73/indent/hamster.vim diff --git a/share/vim/vim72/indent/html.vim b/share/vim/vim73/indent/html.vim similarity index 100% rename from share/vim/vim72/indent/html.vim rename to share/vim/vim73/indent/html.vim diff --git a/share/vim/vim72/indent/htmldjango.vim b/share/vim/vim73/indent/htmldjango.vim similarity index 100% rename from share/vim/vim72/indent/htmldjango.vim rename to share/vim/vim73/indent/htmldjango.vim diff --git a/share/vim/vim72/indent/idlang.vim b/share/vim/vim73/indent/idlang.vim similarity index 100% rename from share/vim/vim72/indent/idlang.vim rename to share/vim/vim73/indent/idlang.vim diff --git a/share/vim/vim72/indent/ishd.vim b/share/vim/vim73/indent/ishd.vim similarity index 100% rename from share/vim/vim72/indent/ishd.vim rename to share/vim/vim73/indent/ishd.vim diff --git a/share/vim/vim72/indent/java.vim b/share/vim/vim73/indent/java.vim similarity index 100% rename from share/vim/vim72/indent/java.vim rename to share/vim/vim73/indent/java.vim diff --git a/share/vim/vim73/indent/javascript.vim b/share/vim/vim73/indent/javascript.vim new file mode 100644 index 0000000000..a83d34b110 --- /dev/null +++ b/share/vim/vim73/indent/javascript.vim @@ -0,0 +1,16 @@ +" Vim indent file +" Language: Javascript +" Maintainer: None! Wanna improve this? +" Last Change: 2007 Jan 22 + +" Only load this indent file when no other was loaded. +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +" C indenting is not too bad. +setlocal cindent +setlocal cinoptions+=j1,J1 + +let b:undo_indent = "setl cin<" diff --git a/share/vim/vim72/indent/jsp.vim b/share/vim/vim73/indent/jsp.vim similarity index 100% rename from share/vim/vim72/indent/jsp.vim rename to share/vim/vim73/indent/jsp.vim diff --git a/share/vim/vim72/indent/ld.vim b/share/vim/vim73/indent/ld.vim similarity index 100% rename from share/vim/vim72/indent/ld.vim rename to share/vim/vim73/indent/ld.vim diff --git a/share/vim/vim73/indent/lifelines.vim b/share/vim/vim73/indent/lifelines.vim new file mode 100644 index 0000000000..0d9b2b46e4 --- /dev/null +++ b/share/vim/vim73/indent/lifelines.vim @@ -0,0 +1,24 @@ +" Vim indent file +" Language: LifeLines +" Maintainer: Patrick Texier <p.texier@orsennes.com> +" Location: <http://patrick.texier.free.fr/vim/indent/lifelines.vim> +" Last Change: 2010 May 7 + +" Only load this indent file when no other was loaded. +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +" LifeLines uses cindent without ; line terminator, C functions +" declarations, C keywords, C++ formating +setlocal cindent +setlocal cinwords="" +setlocal cinoptions+=+0 +setlocal cinoptions+=p0 +setlocal cinoptions+=i0 +setlocal cinoptions+=t0 +setlocal cinoptions+=*500 + +let b:undo_indent = "setl cin< cino< cinw<" +" vim: ts=8 sw=4 diff --git a/share/vim/vim73/indent/liquid.vim b/share/vim/vim73/indent/liquid.vim new file mode 100644 index 0000000000..08341b04f6 --- /dev/null +++ b/share/vim/vim73/indent/liquid.vim @@ -0,0 +1,63 @@ +" Vim indent file +" Language: Liquid +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 21 + +if exists('b:did_indent') + finish +endif + +set indentexpr= +if exists('b:liquid_subtype') + exe 'runtime! indent/'.b:liquid_subtype.'.vim' +else + runtime! indent/html.vim +endif +unlet! b:did_indent + +if &l:indentexpr == '' + if &l:cindent + let &l:indentexpr = 'cindent(v:lnum)' + else + let &l:indentexpr = 'indent(prevnonblank(v:lnum-1))' + endif +endif +let b:liquid_subtype_indentexpr = &l:indentexpr + +let b:did_indent = 1 + +setlocal indentexpr=GetLiquidIndent() +setlocal indentkeys=o,O,*<Return>,<>>,{,},0),0],o,O,!^F,=end,=endif,=endunless,=endifchanged,=endcase,=endfor,=endtablerow,=endcapture,=else,=elsif,=when,=empty + +" Only define the function once. +if exists('*GetLiquidIndent') + finish +endif + +function! s:count(string,pattern) + let string = substitute(a:string,'\C'.a:pattern,"\n",'g') + return strlen(substitute(string,"[^\n]",'','g')) +endfunction + +function! GetLiquidIndent(...) + if a:0 && a:1 == '.' + let v:lnum = line('.') + elseif a:0 && a:1 =~ '^\d' + let v:lnum = a:1 + endif + let vcol = col('.') + call cursor(v:lnum,1) + exe "let ind = ".b:liquid_subtype_indentexpr + let lnum = prevnonblank(v:lnum-1) + let line = getline(lnum) + let cline = getline(v:lnum) + let line = substitute(line,'\C^\%(\s*{%\s*end\w*\s*%}\)\+','','') + let line .= matchstr(cline,'\C^\%(\s*{%\s*end\w*\s*%}\)\+') + let cline = substitute(cline,'\C^\%(\s*{%\s*end\w*\s*%}\)\+','','') + let ind += &sw * s:count(line,'{%\s*\%(if\|elsif\|else\|unless\|ifchanged\|case\|when\|for\|tablerow\|capture\)\>') + let ind -= &sw * s:count(line,'{%\s*end\%(if\|unless\|ifchanged\|case\|for\|tablerow\|capture\)\>') + let ind += &sw * s:count(line,'{%\s*\%(elsif\|else\|when\|empty\)\>') + let ind -= &sw * s:count(cline,'{%\s*\%(elsif\|else\|when\|empty\)\>') + let ind -= &sw * s:count(cline,'{%\s*end\w*$') + return ind +endfunction diff --git a/share/vim/vim72/indent/lisp.vim b/share/vim/vim73/indent/lisp.vim similarity index 100% rename from share/vim/vim72/indent/lisp.vim rename to share/vim/vim73/indent/lisp.vim diff --git a/share/vim/vim72/indent/logtalk.vim b/share/vim/vim73/indent/logtalk.vim similarity index 100% rename from share/vim/vim72/indent/logtalk.vim rename to share/vim/vim73/indent/logtalk.vim diff --git a/share/vim/vim72/indent/lua.vim b/share/vim/vim73/indent/lua.vim similarity index 100% rename from share/vim/vim72/indent/lua.vim rename to share/vim/vim73/indent/lua.vim diff --git a/share/vim/vim73/indent/mail.vim b/share/vim/vim73/indent/mail.vim new file mode 100644 index 0000000000..6246b407e9 --- /dev/null +++ b/share/vim/vim73/indent/mail.vim @@ -0,0 +1,13 @@ +" Vim indent file +" Language: Mail +" Maintainer: Bram Moolenaar +" Last Change: 2009 Jun 03 + +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +" What works best is auto-indenting, disable other indenting. +" For formatting see the ftplugin. +setlocal autoindent nosmartindent nocindent indentexpr= diff --git a/share/vim/vim72/indent/make.vim b/share/vim/vim73/indent/make.vim similarity index 100% rename from share/vim/vim72/indent/make.vim rename to share/vim/vim73/indent/make.vim diff --git a/share/vim/vim72/indent/matlab.vim b/share/vim/vim73/indent/matlab.vim similarity index 100% rename from share/vim/vim72/indent/matlab.vim rename to share/vim/vim73/indent/matlab.vim diff --git a/share/vim/vim72/indent/mma.vim b/share/vim/vim73/indent/mma.vim similarity index 100% rename from share/vim/vim72/indent/mma.vim rename to share/vim/vim73/indent/mma.vim diff --git a/share/vim/vim72/indent/mp.vim b/share/vim/vim73/indent/mp.vim similarity index 100% rename from share/vim/vim72/indent/mp.vim rename to share/vim/vim73/indent/mp.vim diff --git a/share/vim/vim72/indent/objc.vim b/share/vim/vim73/indent/objc.vim similarity index 100% rename from share/vim/vim72/indent/objc.vim rename to share/vim/vim73/indent/objc.vim diff --git a/share/vim/vim72/indent/ocaml.vim b/share/vim/vim73/indent/ocaml.vim similarity index 100% rename from share/vim/vim72/indent/ocaml.vim rename to share/vim/vim73/indent/ocaml.vim diff --git a/share/vim/vim72/indent/occam.vim b/share/vim/vim73/indent/occam.vim similarity index 100% rename from share/vim/vim72/indent/occam.vim rename to share/vim/vim73/indent/occam.vim diff --git a/share/vim/vim72/indent/pascal.vim b/share/vim/vim73/indent/pascal.vim similarity index 100% rename from share/vim/vim72/indent/pascal.vim rename to share/vim/vim73/indent/pascal.vim diff --git a/share/vim/vim73/indent/perl.vim b/share/vim/vim73/indent/perl.vim new file mode 100644 index 0000000000..1fbc4ded9e --- /dev/null +++ b/share/vim/vim73/indent/perl.vim @@ -0,0 +1,180 @@ +" Vim indent file +" Language: Perl 5 +" Author: Andy Lester <andy@petdance.com> +" URL: http://github.com/petdance/vim-perl/tree/master +" Last Change: June 3, 2009 + +" Suggestions and improvements by : +" Aaron J. Sherman (use syntax for hints) +" Artem Chuprina (play nice with folding) + +" TODO things that are not or not properly indented (yet) : +" - Continued statements +" print "foo", +" "bar"; +" print "foo" +" if bar(); +" - Multiline regular expressions (m//x) +" (The following probably needs modifying the perl syntax file) +" - qw() lists +" - Heredocs with terminators that don't match \I\i* + +" Only load this indent file when no other was loaded. +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +" Is syntax highlighting active ? +let b:indent_use_syntax = has("syntax") + +setlocal indentexpr=GetPerlIndent() +setlocal indentkeys+=0=,0),0],0=or,0=and +if !b:indent_use_syntax + setlocal indentkeys+=0=EO +endif + +" Only define the function once. +if exists("*GetPerlIndent") + finish +endif + +let s:cpo_save = &cpo +set cpo-=C + +function GetPerlIndent() + + " Get the line to be indented + let cline = getline(v:lnum) + + " Indent POD markers to column 0 + if cline =~ '^\s*=\L\@!' + return 0 + endif + + " Don't reindent coments on first column + if cline =~ '^#.' + return 0 + endif + + " Get current syntax item at the line's first char + let csynid = '' + if b:indent_use_syntax + let csynid = synIDattr(synID(v:lnum,1,0),"name") + endif + + " Don't reindent POD and heredocs + if csynid == "perlPOD" || csynid == "perlHereDoc" || csynid =~ "^pod" + return indent(v:lnum) + endif + + " Indent end-of-heredocs markers to column 0 + if b:indent_use_syntax + " Assumes that an end-of-heredoc marker matches \I\i* to avoid + " confusion with other types of strings + if csynid == "perlStringStartEnd" && cline =~ '^\I\i*$' + return 0 + endif + else + " Without syntax hints, assume that end-of-heredocs markers begin with EO + if cline =~ '^\s*EO' + return 0 + endif + endif + + " Now get the indent of the previous perl line. + + " Find a non-blank line above the current line. + let lnum = prevnonblank(v:lnum - 1) + " Hit the start of the file, use zero indent. + if lnum == 0 + return 0 + endif + let line = getline(lnum) + let ind = indent(lnum) + " Skip heredocs, POD, and comments on 1st column + if b:indent_use_syntax + let skippin = 2 + while skippin + let synid = synIDattr(synID(lnum,1,0),"name") + if (synid == "perlStringStartEnd" && line =~ '^\I\i*$') + \ || (skippin != 2 && synid == "perlPOD") + \ || (skippin != 2 && synid == "perlHereDoc") + \ || synid == "perlComment" + \ || synid =~ "^pod" + let lnum = prevnonblank(lnum - 1) + if lnum == 0 + return 0 + endif + let line = getline(lnum) + let ind = indent(lnum) + let skippin = 1 + else + let skippin = 0 + endif + endwhile + else + if line =~ "^EO" + let lnum = search("<<[\"']\\=EO", "bW") + let line = getline(lnum) + let ind = indent(lnum) + endif + endif + + " Indent blocks enclosed by {}, (), or [] + if b:indent_use_syntax + " Find a real opening brace + let bracepos = match(line, '[(){}\[\]]', matchend(line, '^\s*[)}\]]')) + while bracepos != -1 + let synid = synIDattr(synID(lnum, bracepos + 1, 0), "name") + " If the brace is highlighted in one of those groups, indent it. + " 'perlHereDoc' is here only to handle the case '&foo(<<EOF)'. + if synid == "" + \ || synid == "perlMatchStartEnd" + \ || synid == "perlHereDoc" + \ || synid =~ "^perlFiledescStatement" + \ || synid =~ '^perl\(Sub\|Block\)Fold' + let brace = strpart(line, bracepos, 1) + if brace == '(' || brace == '{' || brace == '[' + let ind = ind + &sw + else + let ind = ind - &sw + endif + endif + let bracepos = match(line, '[(){}\[\]]', bracepos + 1) + endwhile + let bracepos = matchend(cline, '^\s*[)}\]]') + if bracepos != -1 + let synid = synIDattr(synID(v:lnum, bracepos, 0), "name") + if synid == "" + \ || synid == "perlMatchStartEnd" + \ || synid =~ '^perl\(Sub\|Block\)Fold' + let ind = ind - &sw + endif + endif + else + if line =~ '[{\[(]\s*\(#[^)}\]]*\)\=$' + let ind = ind + &sw + endif + if cline =~ '^\s*[)}\]]' + let ind = ind - &sw + endif + endif + + " Indent lines that begin with 'or' or 'and' + if cline =~ '^\s*\(or\|and\)\>' + if line !~ '^\s*\(or\|and\)\>' + let ind = ind + &sw + endif + elseif line =~ '^\s*\(or\|and\)\>' + let ind = ind - &sw + endif + + return ind + +endfunction + +let &cpo = s:cpo_save +unlet s:cpo_save + +" vim:ts=8:sts=4:sw=4:expandtab:ft=vim diff --git a/share/vim/vim73/indent/perl6.vim b/share/vim/vim73/indent/perl6.vim new file mode 100644 index 0000000000..75159e3a3a --- /dev/null +++ b/share/vim/vim73/indent/perl6.vim @@ -0,0 +1,136 @@ +" Vim indent file +" Language: Perl 6 +" Maintainer: Andy Lester <andy@petdance.com> +" URL: http://github.com/petdance/vim-perl/tree/master +" Last Change: 2009-07-04 +" Contributors: Andy Lester <andy@petdance.com> +" Hinrik Örn Sigurðsson <hinrik.sig@gmail.com> +" +" Adapted from Perl indent file by Rafael Garcia-Suarez <rgarciasuarez@free.fr> + +" Suggestions and improvements by : +" Aaron J. Sherman (use syntax for hints) +" Artem Chuprina (play nice with folding) +" TODO: +" This file still relies on stuff from the Perl 5 syntax file, which Perl 6 +" does not use. +" +" Things that are not or not properly indented (yet) : +" - Continued statements +" print "foo", +" "bar"; +" print "foo" +" if bar(); +" - Multiline regular expressions (m//x) +" (The following probably needs modifying the perl syntax file) +" - qw() lists +" - Heredocs with terminators that don't match \I\i* + +" Only load this indent file when no other was loaded. +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +" Is syntax highlighting active ? +let b:indent_use_syntax = has("syntax") + +setlocal indentexpr=GetPerl6Indent() + +" we reset it first because the Perl 5 indent file might have been loaded due +" to a .pl/pm file extension, and indent files don't clean up afterwards +setlocal indentkeys& + +setlocal indentkeys+=0=,0),0],0>,0»,0=or,0=and +if !b:indent_use_syntax + setlocal indentkeys+=0=EO +endif + +" Only define the function once. +if exists("*GetPerl6Indent") + finish +endif + +let s:cpo_save = &cpo +set cpo-=C + +function GetPerl6Indent() + + " Get the line to be indented + let cline = getline(v:lnum) + + " Indent POD markers to column 0 + if cline =~ '^\s*=\L\@!' + return 0 + endif + + " Don't reindent coments on first column + if cline =~ '^#' + return 0 + endif + + " Get current syntax item at the line's first char + let csynid = '' + if b:indent_use_syntax + let csynid = synIDattr(synID(v:lnum,1,0),"name") + endif + + " Don't reindent POD and heredocs + if csynid =~ "^p6Pod" + return indent(v:lnum) + endif + + + " Now get the indent of the previous perl line. + + " Find a non-blank line above the current line. + let lnum = prevnonblank(v:lnum - 1) + " Hit the start of the file, use zero indent. + if lnum == 0 + return 0 + endif + let line = getline(lnum) + let ind = indent(lnum) + " Skip heredocs, POD, and comments on 1st column + if b:indent_use_syntax + let skippin = 2 + while skippin + let synid = synIDattr(synID(lnum,1,0),"name") + if (synid =~ "^p6Pod" || synid =~ "p6Comment") + let lnum = prevnonblank(lnum - 1) + if lnum == 0 + return 0 + endif + let line = getline(lnum) + let ind = indent(lnum) + let skippin = 1 + else + let skippin = 0 + endif + endwhile + endif + + if line =~ '[<«\[{(]\s*\(#[^)}\]»>]*\)\=$' + let ind = ind + &sw + endif + if cline =~ '^\s*[)}\]»>]' + let ind = ind - &sw + endif + + " Indent lines that begin with 'or' or 'and' + if cline =~ '^\s*\(or\|and\)\>' + if line !~ '^\s*\(or\|and\)\>' + let ind = ind + &sw + endif + elseif line =~ '^\s*\(or\|and\)\>' + let ind = ind - &sw + endif + + return ind + +endfunction + +let &cpo = s:cpo_save +unlet s:cpo_save + +" vim:ts=8:sts=4:sw=4:expandtab:ft=vim diff --git a/share/vim/vim73/indent/php.vim b/share/vim/vim73/indent/php.vim new file mode 100644 index 0000000000..bc196ed3c4 --- /dev/null +++ b/share/vim/vim73/indent/php.vim @@ -0,0 +1,733 @@ +" Vim indent file +" Language: PHP +" Author: John Wellesz <John.wellesz (AT) teaser (DOT) fr> +" URL: http://www.2072productions.com/vim/indent/php.vim +" Last Change: 2010 Jully 26th +" Newsletter: http://www.2072productions.com/?to=php-indent-for-vim-newsletter.php +" Version: 1.33 +" +" +" If you find a bug, please report it on GitHub: +" http://github.com/2072/PHP-Indenting-for-VIm/issues +" with an example of code that breaks the algorithm. +" +" +" Thanks a lot for using this script. +" +" +" NOTE: This script must be used with PHP syntax ON and with the php syntax +" script by Lutz Eymers (http://www.ipdienste.net/data/php.vim ) or with the +" script by Peter Hodge (http://www.vim.org/scripts/script.php?script_id=1571 ) +" the later is bunbdled by default with Vim 7. +" +" +" In the case you have syntax errors in your script such as HereDoc end +" identifiers not at col 1 you'll have to indent your file 2 times (This +" script will automatically put HereDoc end identifiers at col 1 if +" they are followed by a ';'). +" +" +" NOTE: If you are editing files in Unix file format and that (by accident) +" there are '\r' before new lines, this script won't be able to proceed +" correctly and will make many mistakes because it won't be able to match +" '\s*$' correctly. +" So you have to remove those useless characters first with a command like: +" +" :%s /\r$//g +" +" or simply 'let' the option PHP_removeCRwhenUnix to 1 and the script will +" silently remove them when VIM load this script (at each bufread). +" +" Options: See :help php-indent for available options. + + +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + + +let php_sync_method = 0 + + +if exists("PHP_default_indenting") + let b:PHP_default_indenting = PHP_default_indenting * &sw +else + let b:PHP_default_indenting = 0 +endif + +if exists("PHP_BracesAtCodeLevel") + let b:PHP_BracesAtCodeLevel = PHP_BracesAtCodeLevel +else + let b:PHP_BracesAtCodeLevel = 0 +endif + + +if exists("PHP_autoformatcomment") + let b:PHP_autoformatcomment = PHP_autoformatcomment +else + let b:PHP_autoformatcomment = 1 +endif + +if exists("PHP_outdentphpescape") + let b:PHP_outdentphpescape = PHP_outdentphpescape +else + let b:PHP_outdentphpescape = 1 +endif + + +if exists("PHP_vintage_case_default_indent") && PHP_vintage_case_default_indent + let b:PHP_vintage_case_default_indent = 1 +else + let b:PHP_vintage_case_default_indent = 0 +endif + + + +let b:PHP_lastindented = 0 +let b:PHP_indentbeforelast = 0 +let b:PHP_indentinghuge = 0 +let b:PHP_CurrentIndentLevel = b:PHP_default_indenting +let b:PHP_LastIndentedWasComment = 0 +let b:PHP_InsideMultilineComment = 0 +let b:InPHPcode = 0 +let b:InPHPcode_checked = 0 +let b:InPHPcode_and_script = 0 +let b:InPHPcode_tofind = "" +let b:PHP_oldchangetick = b:changedtick +let b:UserIsTypingComment = 0 +let b:optionsset = 0 + +setlocal nosmartindent +setlocal noautoindent +setlocal nocindent +setlocal nolisp + +setlocal indentexpr=GetPhpIndent() +setlocal indentkeys=0{,0},0),:,!^F,o,O,e,*<Return>,=?>,=<?,=*/ + + + +let s:searchpairflags = 'bWr' + +if &fileformat == "unix" && exists("PHP_removeCRwhenUnix") && PHP_removeCRwhenUnix + silent! %s/\r$//g +endif + +if exists("*GetPhpIndent") + call ResetPhpOptions() + finish +endif + +let s:endline= '\s*\%(//.*\|#.*\|/\*.*\*/\s*\)\=$' +let s:PHP_startindenttag = '<?\%(.*?>\)\@!\|<script[^>]*>\%(.*<\/script>\)\@!' + + +function! GetLastRealCodeLNum(startline) " {{{ + + let lnum = a:startline + + if b:GetLastRealCodeLNum_ADD && b:GetLastRealCodeLNum_ADD == lnum + 1 + let lnum = b:GetLastRealCodeLNum_ADD + endif + + let old_lnum = lnum + + while lnum > 1 + let lnum = prevnonblank(lnum) + let lastline = getline(lnum) + + if b:InPHPcode_and_script && lastline =~ '?>\s*$' + let lnum = lnum - 1 + elseif lastline =~ '^\s*?>.*<?\%(php\)\=\s*$' + let lnum = lnum - 1 + elseif lastline =~ '^\s*\%(//\|#\|/\*.*\*/\s*$\)' + let lnum = lnum - 1 + elseif lastline =~ '\*/\s*$' + call cursor(lnum, 1) + if lastline !~ '^\*/' + call search('\*/', 'W') + endif + let lnum = searchpair('/\*', '', '\*/', s:searchpairflags, 'Skippmatch2()') + + let lastline = getline(lnum) + if lastline =~ '^\s*/\*' + let lnum = lnum - 1 + else + break + endif + + + elseif lastline =~? '\%(//\s*\|?>.*\)\@<!<?\%(php\)\=\s*$\|^\s*<script\>' + + while lastline !~ '\(<?.*\)\@<!?>' && lnum > 1 + let lnum = lnum - 1 + let lastline = getline(lnum) + endwhile + if lastline =~ '^\s*?>' + let lnum = lnum - 1 + else + break + endif + + + elseif lastline =~? '^\a\w*;\=$' && lastline !~? s:notPhpHereDoc + let tofind=substitute( lastline, '\(\a\w*\);\=', '<<<''\\=\1''\\=$', '') + while getline(lnum) !~? tofind && lnum > 1 + let lnum = lnum - 1 + endwhile + else + break + endif + endwhile + + if lnum==1 && getline(lnum) !~ '<?' + let lnum=0 + endif + + if b:InPHPcode_and_script && !b:InPHPcode + let b:InPHPcode_and_script = 0 + endif + + + + return lnum +endfunction " }}} + +function! Skippmatch2() + + let line = getline(".") + + if line =~ '\%(".*\)\@<=/\*\%(.*"\)\@=' || line =~ '\%(\%(//\|#\).*\)\@<=/\*' + return 1 + else + return 0 + endif +endfun + +function! Skippmatch() " {{{ + let synname = synIDattr(synID(line("."), col("."), 0), "name") + if synname == "Delimiter" || synname == "phpRegionDelimiter" || synname =~# "^phpParent" || synname == "phpArrayParens" || synname =~# '^php\%(Block\|Brace\)' || synname == "javaScriptBraces" || synname =~# "^phpComment" && b:UserIsTypingComment + return 0 + else + return 1 + endif +endfun " }}} + +function! FindOpenBracket(lnum) " {{{ + call cursor(a:lnum, 1) + return searchpair('{', '', '}', 'bW', 'Skippmatch()') +endfun " }}} + +function! FindTheIfOfAnElse (lnum, StopAfterFirstPrevElse) " {{{ + + if getline(a:lnum) =~# '^\s*}\s*else\%(if\)\=\>' + let beforeelse = a:lnum + else + let beforeelse = GetLastRealCodeLNum(a:lnum - 1) + endif + + if !s:level + let s:iftoskip = 0 + endif + + if getline(beforeelse) =~# '^\s*\%(}\s*\)\=else\%(\s*if\)\@!\>' + let s:iftoskip = s:iftoskip + 1 + endif + + if getline(beforeelse) =~ '^\s*}' + let beforeelse = FindOpenBracket(beforeelse) + + if getline(beforeelse) =~ '^\s*{' + let beforeelse = GetLastRealCodeLNum(beforeelse - 1) + endif + endif + + + if !s:iftoskip && a:StopAfterFirstPrevElse && getline(beforeelse) =~# '^\s*\%([}]\s*\)\=else\%(if\)\=\>' + return beforeelse + endif + + if getline(beforeelse) !~# '^\s*if\>' && beforeelse>1 || s:iftoskip && beforeelse>1 + + if s:iftoskip && getline(beforeelse) =~# '^\s*if\>' + let s:iftoskip = s:iftoskip - 1 + endif + + let s:level = s:level + 1 + let beforeelse = FindTheIfOfAnElse(beforeelse, a:StopAfterFirstPrevElse) + endif + + return beforeelse + +endfunction " }}} + +let s:defaultORcase = '^\s*\%(default\|case\).*:' + +function! FindTheSwitchIndent (lnum) " {{{ + + + let test = GetLastRealCodeLNum(a:lnum - 1) + + if test <= 1 + return indent(1) - &sw * b:PHP_vintage_case_default_indent + end + + if getline(test) =~ '^\s*}' + let test = FindOpenBracket(test) + + if getline(test) =~ '^\s*{' + let test = GetLastRealCodeLNum(GetLastRealCodeLNum(test - 1) - 1) + endif + endif + + if getline(test) =~# '^\s*switch\>' + return indent(test) + elseif getline(test) =~# s:defaultORcase + return indent(test) - &sw * b:PHP_vintage_case_default_indent + else + return FindTheSwitchIndent(test) + endif + +endfunction "}}} + + +function! IslinePHP (lnum, tofind) " {{{ + let cline = getline(a:lnum) + + if a:tofind=="" + let tofind = "^\\s*[\"']*\\s*\\zs\\S" + else + let tofind = a:tofind + endif + + let tofind = tofind . '\c' + + let coltotest = match (cline, tofind) + 1 + + let synname = synIDattr(synID(a:lnum, coltotest, 0), "name") + + if synname =~ '^php' || synname=="Delimiter" || synname =~? '^javaScript' + return synname + else + return "" + endif +endfunction " }}} + +let s:notPhpHereDoc = '\%(break\|return\|continue\|exit\|else\)' +let s:blockstart = '\%(\%(\%(}\s*\)\=else\%(\s\+\)\=\)\=if\>\|else\>\|while\>\|switch\>\|case\>\|default\>\|for\%(each\)\=\>\|declare\>\|class\>\|interface\>\|abstract\>\|try\>\|catch\>\)' + +let s:autoresetoptions = 0 +if ! s:autoresetoptions + let s:autoresetoptions = 1 +endif + +function! ResetPhpOptions() + if ! b:optionsset && &filetype == "php" + if b:PHP_autoformatcomment + + setlocal comments=s1:/*,mb:*,ex:*/,://,:# + + setlocal formatoptions-=t + setlocal formatoptions+=q + setlocal formatoptions+=r + setlocal formatoptions+=o + setlocal formatoptions+=w + setlocal formatoptions+=c + setlocal formatoptions+=b + endif + let b:optionsset = 1 + endif +endfunc + +call ResetPhpOptions() + +function! GetPhpIndent() + + let b:GetLastRealCodeLNum_ADD = 0 + + let UserIsEditing=0 + if b:PHP_oldchangetick != b:changedtick + let b:PHP_oldchangetick = b:changedtick + let UserIsEditing=1 + endif + + if b:PHP_default_indenting + let b:PHP_default_indenting = g:PHP_default_indenting * &sw + endif + + let cline = getline(v:lnum) + + if !b:PHP_indentinghuge && b:PHP_lastindented > b:PHP_indentbeforelast + if b:PHP_indentbeforelast + let b:PHP_indentinghuge = 1 + echom 'Large indenting detected, speed optimizations engaged (v1.33)' + endif + let b:PHP_indentbeforelast = b:PHP_lastindented + endif + + if b:InPHPcode_checked && prevnonblank(v:lnum - 1) != b:PHP_lastindented + if b:PHP_indentinghuge + echom 'Large indenting deactivated' + let b:PHP_indentinghuge = 0 + let b:PHP_CurrentIndentLevel = b:PHP_default_indenting + endif + let b:PHP_lastindented = v:lnum + let b:PHP_LastIndentedWasComment=0 + let b:PHP_InsideMultilineComment=0 + let b:PHP_indentbeforelast = 0 + + let b:InPHPcode = 0 + let b:InPHPcode_checked = 0 + let b:InPHPcode_and_script = 0 + let b:InPHPcode_tofind = "" + + elseif v:lnum > b:PHP_lastindented + let real_PHP_lastindented = b:PHP_lastindented + let b:PHP_lastindented = v:lnum + endif + + + if !b:InPHPcode_checked " {{{ One time check + let b:InPHPcode_checked = 1 + + let synname = "" + if cline !~ '<?.*?>' + let synname = IslinePHP (prevnonblank(v:lnum), "") + endif + + if synname!="" + if synname != "phpHereDoc" && synname != "phpHereDocDelimiter" + let b:InPHPcode = 1 + let b:InPHPcode_tofind = "" + + if synname =~# "^phpComment" + let b:UserIsTypingComment = 1 + else + let b:UserIsTypingComment = 0 + endif + + if synname =~? '^javaScript' + let b:InPHPcode_and_script = 1 + endif + + else + let b:InPHPcode = 0 + let b:UserIsTypingComment = 0 + + let lnum = v:lnum - 1 + while getline(lnum) !~? '<<<''\=\a\w*''\=$' && lnum > 1 + let lnum = lnum - 1 + endwhile + + let b:InPHPcode_tofind = substitute( getline(lnum), '^.*<<<''\=\(\a\w*\)''\=$', '^\\s*\1;\\=$', '') + endif + else + let b:InPHPcode = 0 + let b:UserIsTypingComment = 0 + let b:InPHPcode_tofind = '<?\%(.*?>\)\@!\|<script.*>' + endif + endif "!b:InPHPcode_checked }}} + + + " Test if we are indenting PHP code {{{ + let lnum = prevnonblank(v:lnum - 1) + let last_line = getline(lnum) + + if b:InPHPcode_tofind!="" + if cline =~? b:InPHPcode_tofind + let b:InPHPcode = 1 + let b:InPHPcode_tofind = "" + let b:UserIsTypingComment = 0 + if cline =~ '\*/' + call cursor(v:lnum, 1) + if cline !~ '^\*/' + call search('\*/', 'W') + endif + let lnum = searchpair('/\*', '', '\*/', s:searchpairflags, 'Skippmatch2()') + + let b:PHP_CurrentIndentLevel = b:PHP_default_indenting + + let b:PHP_LastIndentedWasComment = 0 + + if cline =~ '^\s*\*/' + return indent(lnum) + 1 + else + return indent(lnum) + endif + + elseif cline =~? '<script\>' + let b:InPHPcode_and_script = 1 + let b:GetLastRealCodeLNum_ADD = v:lnum + endif + endif + endif + + if b:InPHPcode + + if !b:InPHPcode_and_script && last_line =~ '\%(<?.*\)\@<!?>\%(.*<?\)\@!' && IslinePHP(lnum, '?>')=~"Delimiter" + if cline !~? s:PHP_startindenttag + let b:InPHPcode = 0 + let b:InPHPcode_tofind = s:PHP_startindenttag + elseif cline =~? '<script\>' + let b:InPHPcode_and_script = 1 + endif + + elseif last_line =~? '<<<''\=\a\w*''\=$' + let b:InPHPcode = 0 + let b:InPHPcode_tofind = substitute( last_line, '^.*<<<''\=\(\a\w*\)''\=$', '^\\s*\1;\\=$', '') + + elseif !UserIsEditing && cline =~ '^\s*/\*\%(.*\*/\)\@!' && getline(v:lnum + 1) !~ '^\s*\*' + let b:InPHPcode = 0 + let b:InPHPcode_tofind = '\*/' + + elseif cline =~? '^\s*</script>' + let b:InPHPcode = 0 + let b:InPHPcode_tofind = s:PHP_startindenttag + endif + endif " }}} + + + if !b:InPHPcode && !b:InPHPcode_and_script + return -1 + endif + + " Indent successive // or # comment the same way the first is {{{ + if cline =~ '^\s*\%(//\|#\|/\*.*\*/\s*$\)' + if b:PHP_LastIndentedWasComment == 1 + return indent(real_PHP_lastindented) + endif + let b:PHP_LastIndentedWasComment = 1 + else + let b:PHP_LastIndentedWasComment = 0 + endif " }}} + + " Indent multiline /* comments correctly {{{ + + if b:PHP_InsideMultilineComment || b:UserIsTypingComment + if cline =~ '^\s*\*\%(\/\)\@!' + if last_line =~ '^\s*/\*' + return indent(lnum) + 1 + else + return indent(lnum) + endif + else + let b:PHP_InsideMultilineComment = 0 + endif + endif + + if !b:PHP_InsideMultilineComment && cline =~ '^\s*/\*' && cline !~ '\*/\s*$' + if getline(v:lnum + 1) !~ '^\s*\*' + return -1 + endif + let b:PHP_InsideMultilineComment = 1 + endif " }}} + + + " Things always indented at col 1 (PHP delimiter: <?, ?>, Heredoc end) {{{ + if cline =~# '^\s*<?' && cline !~ '?>' && b:PHP_outdentphpescape + return 0 + endif + + if cline =~ '^\s*?>' && cline !~# '<?' && b:PHP_outdentphpescape + return 0 + endif + + if cline =~? '^\s*\a\w*;$\|^\a\w*$' && cline !~? s:notPhpHereDoc + return 0 + endif " }}} + + let s:level = 0 + + let lnum = GetLastRealCodeLNum(v:lnum - 1) + + let last_line = getline(lnum) + let ind = indent(lnum) + let endline= s:endline + + if ind==0 && b:PHP_default_indenting + let ind = b:PHP_default_indenting + endif + + if lnum == 0 + return b:PHP_default_indenting + endif + + + if cline =~ '^\s*}\%(}}\)\@!' + let ind = indent(FindOpenBracket(v:lnum)) + let b:PHP_CurrentIndentLevel = b:PHP_default_indenting + return ind + endif + + if cline =~ '^\s*\*/' + call cursor(v:lnum, 1) + if cline !~ '^\*/' + call search('\*/', 'W') + endif + let lnum = searchpair('/\*', '', '\*/', s:searchpairflags, 'Skippmatch2()') + + let b:PHP_CurrentIndentLevel = b:PHP_default_indenting + + if cline =~ '^\s*\*/' + return indent(lnum) + 1 + else + return indent(lnum) + endif + endif + + + if last_line =~ '[;}]'.endline && last_line !~ '^)' && last_line !~# s:defaultORcase + if ind==b:PHP_default_indenting + return b:PHP_default_indenting + elseif b:PHP_indentinghuge && ind==b:PHP_CurrentIndentLevel && cline !~# '^\s*\%(else\|\%(case\|default\).*:\|[})];\=\)' && last_line !~# '^\s*\%(\%(}\s*\)\=else\)' && getline(GetLastRealCodeLNum(lnum - 1))=~';'.endline + return b:PHP_CurrentIndentLevel + endif + endif + + let LastLineClosed = 0 + + let terminated = '\%(;\%(\s*?>\)\=\|<<<''\=\a\w*''\=$\|^\s*}\)'.endline + + let unstated = '\%(^\s*'.s:blockstart.'.*)\|\%(//.*\)\@<!\<e'.'lse\>\)'.endline + + if ind != b:PHP_default_indenting && cline =~# '^\s*else\%(if\)\=\>' + let b:PHP_CurrentIndentLevel = b:PHP_default_indenting + return indent(FindTheIfOfAnElse(v:lnum, 1)) + elseif cline =~# s:defaultORcase + return FindTheSwitchIndent(v:lnum) + &sw * b:PHP_vintage_case_default_indent + elseif cline =~ '^\s*)\=\s*{' + let previous_line = last_line + let last_line_num = lnum + + while last_line_num > 1 + + if previous_line =~ '^\s*\%(' . s:blockstart . '\|\%([a-zA-Z]\s*\)*function\)' + + let ind = indent(last_line_num) + + if b:PHP_BracesAtCodeLevel + let ind = ind + &sw + endif + + return ind + endif + + let last_line_num = last_line_num - 1 + let previous_line = getline(last_line_num) + endwhile + + elseif last_line =~# unstated && cline !~ '^\s*);\='.endline + let ind = ind + &sw + return ind + + elseif (ind != b:PHP_default_indenting || last_line =~ '^)' ) && last_line =~ terminated + let previous_line = last_line + let last_line_num = lnum + let LastLineClosed = 1 + + while 1 + if previous_line =~ '^\s*}' + let last_line_num = FindOpenBracket(last_line_num) + + if getline(last_line_num) =~ '^\s*{' + let last_line_num = GetLastRealCodeLNum(last_line_num - 1) + endif + + let previous_line = getline(last_line_num) + + continue + else + + if getline(last_line_num) =~# '^\s*else\%(if\)\=\>' + let last_line_num = FindTheIfOfAnElse(last_line_num, 0) + continue + endif + + + let last_match = last_line_num + + let one_ahead_indent = indent(last_line_num) + let last_line_num = GetLastRealCodeLNum(last_line_num - 1) + let two_ahead_indent = indent(last_line_num) + let after_previous_line = previous_line + let previous_line = getline(last_line_num) + + + if previous_line =~# s:defaultORcase.'\|{'.endline + break + endif + + if after_previous_line=~# '^\s*'.s:blockstart.'.*)'.endline && previous_line =~# '[;}]'.endline + break + endif + + if one_ahead_indent == two_ahead_indent || last_line_num < 1 + if previous_line =~# '\%(;\|^\s*}\)'.endline || last_line_num < 1 + break + endif + endif + endif + endwhile + + if indent(last_match) != ind + let ind = indent(last_match) + let b:PHP_CurrentIndentLevel = b:PHP_default_indenting + + return ind + endif + endif + + let plinnum = GetLastRealCodeLNum(lnum - 1) + let AntepenultimateLine = getline(plinnum) + + let last_line = substitute(last_line,"\\(//\\|#\\)\\(\\(\\([^\"']*\\([\"']\\)[^\"']*\\5\\)\\+[^\"']*$\\)\\|\\([^\"']*$\\)\\)",'','') + + + if ind == b:PHP_default_indenting + if last_line =~ terminated + let LastLineClosed = 1 + endif + endif + + if !LastLineClosed + + + if last_line =~# '[{(]'.endline || last_line =~? '\h\w*\s*(.*,$' && AntepenultimateLine !~ '[,(]'.endline + + if !b:PHP_BracesAtCodeLevel || last_line !~# '^\s*{' + let ind = ind + &sw + endif + + if b:PHP_BracesAtCodeLevel || b:PHP_vintage_case_default_indent == 1 + let b:PHP_CurrentIndentLevel = ind + + return ind + endif + + elseif last_line =~ '\S\+\s*),'.endline + call cursor(lnum, 1) + call search('),'.endline, 'W') + let openedparent = searchpair('(', '', ')', 'bW', 'Skippmatch()') + if openedparent != lnum + let ind = indent(openedparent) + endif + + elseif last_line =~ '^\s*'.s:blockstart + let ind = ind + &sw + + + + elseif AntepenultimateLine =~ '\%(;\%(\s*?>\)\=\|<<<''\=\a\w*''\=$\|^\s*}\|{\)'.endline . '\|' . s:defaultORcase + let ind = ind + &sw + endif + + endif + + if cline =~ '^\s*);\=' + let ind = ind - &sw + endif + + let b:PHP_CurrentIndentLevel = ind + return ind +endfunction diff --git a/share/vim/vim72/indent/postscr.vim b/share/vim/vim73/indent/postscr.vim similarity index 100% rename from share/vim/vim72/indent/postscr.vim rename to share/vim/vim73/indent/postscr.vim diff --git a/share/vim/vim72/indent/pov.vim b/share/vim/vim73/indent/pov.vim similarity index 100% rename from share/vim/vim72/indent/pov.vim rename to share/vim/vim73/indent/pov.vim diff --git a/share/vim/vim72/indent/prolog.vim b/share/vim/vim73/indent/prolog.vim similarity index 100% rename from share/vim/vim72/indent/prolog.vim rename to share/vim/vim73/indent/prolog.vim diff --git a/share/vim/vim72/indent/pyrex.vim b/share/vim/vim73/indent/pyrex.vim similarity index 100% rename from share/vim/vim72/indent/pyrex.vim rename to share/vim/vim73/indent/pyrex.vim diff --git a/share/vim/vim72/indent/python.vim b/share/vim/vim73/indent/python.vim similarity index 100% rename from share/vim/vim72/indent/python.vim rename to share/vim/vim73/indent/python.vim diff --git a/share/vim/vim72/indent/readline.vim b/share/vim/vim73/indent/readline.vim similarity index 100% rename from share/vim/vim72/indent/readline.vim rename to share/vim/vim73/indent/readline.vim diff --git a/share/vim/vim72/indent/rpl.vim b/share/vim/vim73/indent/rpl.vim similarity index 100% rename from share/vim/vim72/indent/rpl.vim rename to share/vim/vim73/indent/rpl.vim diff --git a/share/vim/vim72/indent/rst.vim b/share/vim/vim73/indent/rst.vim similarity index 100% rename from share/vim/vim72/indent/rst.vim rename to share/vim/vim73/indent/rst.vim diff --git a/share/vim/vim73/indent/ruby.vim b/share/vim/vim73/indent/ruby.vim new file mode 100644 index 0000000000..04d130104d --- /dev/null +++ b/share/vim/vim73/indent/ruby.vim @@ -0,0 +1,378 @@ +" Vim indent file +" Language: Ruby +" Maintainer: Nikolai Weibull <now at bitwi.se> +" Last Change: 2009 Dec 17 +" URL: http://vim-ruby.rubyforge.org +" Anon CVS: See above site +" Release Coordinator: Doug Kearns <dougkearns@gmail.com> + +" 0. Initialization {{{1 +" ================= + +" Only load this indent file when no other was loaded. +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +setlocal nosmartindent + +" Now, set up our indentation expression and keys that trigger it. +setlocal indentexpr=GetRubyIndent() +setlocal indentkeys=0{,0},0),0],!^F,o,O,e +setlocal indentkeys+==end,=elsif,=when,=ensure,=rescue,==begin,==end + +" Only define the function once. +if exists("*GetRubyIndent") + finish +endif + +let s:cpo_save = &cpo +set cpo&vim + +" 1. Variables {{{1 +" ============ + +" Regex of syntax group names that are or delimit string or are comments. +let s:syng_strcom = '\<ruby\%(String\|StringEscape\|ASCIICode' . + \ '\|Interpolation\|NoInterpolation\|Comment\|Documentation\)\>' + +" Regex of syntax group names that are strings. +let s:syng_string = + \ '\<ruby\%(String\|Interpolation\|NoInterpolation\|StringEscape\)\>' + +" Regex of syntax group names that are strings or documentation. +let s:syng_stringdoc = + \'\<ruby\%(String\|Interpolation\|NoInterpolation\|StringEscape\|Documentation\)\>' + +" Expression used to check whether we should skip a match with searchpair(). +let s:skip_expr = + \ "synIDattr(synID(line('.'),col('.'),1),'name') =~ '".s:syng_strcom."'" + +" Regex used for words that, at the start of a line, add a level of indent. +let s:ruby_indent_keywords = '^\s*\zs\<\%(module\|class\|def\|if\|for' . + \ '\|while\|until\|else\|elsif\|case\|when\|unless\|begin\|ensure' . + \ '\|rescue\)\>' . + \ '\|\%([*+/,=-]\|<<\|>>\|:\s\)\s*\zs' . + \ '\<\%(if\|for\|while\|until\|case\|unless\|begin\)\>' + +" Regex used for words that, at the start of a line, remove a level of indent. +let s:ruby_deindent_keywords = + \ '^\s*\zs\<\%(ensure\|else\|rescue\|elsif\|when\|end\)\>' + +" Regex that defines the start-match for the 'end' keyword. +"let s:end_start_regex = '\%(^\|[^.]\)\<\%(module\|class\|def\|if\|for\|while\|until\|case\|unless\|begin\|do\)\>' +" TODO: the do here should be restricted somewhat (only at end of line)? +let s:end_start_regex = '^\s*\zs\<\%(module\|class\|def\|if\|for' . + \ '\|while\|until\|case\|unless\|begin\)\>' . + \ '\|\%([*+/,=-]\|<<\|>>\|:\s\)\s*\zs' . + \ '\<\%(if\|for\|while\|until\|case\|unless\|begin\)\>' . + \ '\|\<do\>' + +" Regex that defines the middle-match for the 'end' keyword. +let s:end_middle_regex = '\<\%(ensure\|else\|\%(\%(^\|;\)\s*\)\@<=\<rescue\>\|when\|elsif\)\>' + +" Regex that defines the end-match for the 'end' keyword. +let s:end_end_regex = '\%(^\|[^.:@$]\)\@<=\<end\>' + +" Expression used for searchpair() call for finding match for 'end' keyword. +let s:end_skip_expr = s:skip_expr . + \ ' || (expand("<cword>") == "do"' . + \ ' && getline(".") =~ "^\\s*\\<\\(while\\|until\\|for\\)\\>")' + +" Regex that defines continuation lines, not including (, {, or [. +let s:continuation_regex = '\%([\\*+/.,:]\|\%(<%\)\@<![=-]\|\W[|&?]\|||\|&&\)\s*\%(#.*\)\=$' + +" Regex that defines continuation lines. +" TODO: this needs to deal with if ...: and so on +let s:continuation_regex2 = + \ '\%([\\*+/.,:({[]\|\%(<%\)\@<![=-]\|\W[|&?]\|||\|&&\)\s*\%(#.*\)\=$' + +" Regex that defines blocks. +let s:block_regex = + \ '\%(\<do\>\|{\)\s*\%(|\%([*@]\=\h\w*,\=\s*\)\%(,\s*[*@]\=\h\w*\)*|\)\=\s*\%(#.*\)\=$' + +" 2. Auxiliary Functions {{{1 +" ====================== + +" Check if the character at lnum:col is inside a string, comment, or is ascii. +function s:IsInStringOrComment(lnum, col) + return synIDattr(synID(a:lnum, a:col, 1), 'name') =~ s:syng_strcom +endfunction + +" Check if the character at lnum:col is inside a string. +function s:IsInString(lnum, col) + return synIDattr(synID(a:lnum, a:col, 1), 'name') =~ s:syng_string +endfunction + +" Check if the character at lnum:col is inside a string or documentation. +function s:IsInStringOrDocumentation(lnum, col) + return synIDattr(synID(a:lnum, a:col, 1), 'name') =~ s:syng_stringdoc +endfunction + +" Find line above 'lnum' that isn't empty, in a comment, or in a string. +function s:PrevNonBlankNonString(lnum) + let in_block = 0 + let lnum = prevnonblank(a:lnum) + while lnum > 0 + " Go in and out of blocks comments as necessary. + " If the line isn't empty (with opt. comment) or in a string, end search. + let line = getline(lnum) + if line =~ '^=begin$' + if in_block + let in_block = 0 + else + break + endif + elseif !in_block && line =~ '^=end$' + let in_block = 1 + elseif !in_block && line !~ '^\s*#.*$' && !(s:IsInStringOrComment(lnum, 1) + \ && s:IsInStringOrComment(lnum, strlen(line))) + break + endif + let lnum = prevnonblank(lnum - 1) + endwhile + return lnum +endfunction + +" Find line above 'lnum' that started the continuation 'lnum' may be part of. +function s:GetMSL(lnum) + " Start on the line we're at and use its indent. + let msl = a:lnum + let lnum = s:PrevNonBlankNonString(a:lnum - 1) + while lnum > 0 + " If we have a continuation line, or we're in a string, use line as MSL. + " Otherwise, terminate search as we have found our MSL already. + let line = getline(lnum) + let col = match(line, s:continuation_regex2) + 1 + if (col > 0 && !s:IsInStringOrComment(lnum, col)) + \ || s:IsInString(lnum, strlen(line)) + let msl = lnum + else + break + endif + let lnum = s:PrevNonBlankNonString(lnum - 1) + endwhile + return msl +endfunction + +" Check if line 'lnum' has more opening brackets than closing ones. +function s:LineHasOpeningBrackets(lnum) + let open_0 = 0 + let open_2 = 0 + let open_4 = 0 + let line = getline(a:lnum) + let pos = match(line, '[][(){}]', 0) + while pos != -1 + if !s:IsInStringOrComment(a:lnum, pos + 1) + let idx = stridx('(){}[]', line[pos]) + if idx % 2 == 0 + let open_{idx} = open_{idx} + 1 + else + let open_{idx - 1} = open_{idx - 1} - 1 + endif + endif + let pos = match(line, '[][(){}]', pos + 1) + endwhile + return (open_0 > 0) . (open_2 > 0) . (open_4 > 0) +endfunction + +function s:Match(lnum, regex) + let col = match(getline(a:lnum), '\C'.a:regex) + 1 + return col > 0 && !s:IsInStringOrComment(a:lnum, col) ? col : 0 +endfunction + +function s:MatchLast(lnum, regex) + let line = getline(a:lnum) + let col = match(line, '.*\zs' . a:regex) + while col != -1 && s:IsInStringOrComment(a:lnum, col) + let line = strpart(line, 0, col) + let col = match(line, '.*' . a:regex) + endwhile + return col + 1 +endfunction + +" 3. GetRubyIndent Function {{{1 +" ========================= + +function GetRubyIndent() + " 3.1. Setup {{{2 + " ---------- + + " Set up variables for restoring position in file. Could use v:lnum here. + let vcol = col('.') + + " 3.2. Work on the current line {{{2 + " ----------------------------- + + " Get the current line. + let line = getline(v:lnum) + let ind = -1 + + " If we got a closing bracket on an empty line, find its match and indent + " according to it. For parentheses we indent to its column - 1, for the + " others we indent to the containing line's MSL's level. Return -1 if fail. + let col = matchend(line, '^\s*[]})]') + if col > 0 && !s:IsInStringOrComment(v:lnum, col) + call cursor(v:lnum, col) + let bs = strpart('(){}[]', stridx(')}]', line[col - 1]) * 2, 2) + if searchpair(escape(bs[0], '\['), '', bs[1], 'bW', s:skip_expr) > 0 + if line[col-1]==')' && col('.') != col('$') - 1 + let ind = virtcol('.')-1 + else + let ind = indent(s:GetMSL(line('.'))) + endif + endif + return ind + endif + + " If we have a =begin or =end set indent to first column. + if match(line, '^\s*\%(=begin\|=end\)$') != -1 + return 0 + endif + + " If we have a deindenting keyword, find its match and indent to its level. + " TODO: this is messy + if s:Match(v:lnum, s:ruby_deindent_keywords) + call cursor(v:lnum, 1) + if searchpair(s:end_start_regex, s:end_middle_regex, s:end_end_regex, 'bW', + \ s:end_skip_expr) > 0 + let line = getline('.') + if strpart(line, 0, col('.') - 1) =~ '=\s*$' && + \ strpart(line, col('.') - 1, 2) !~ 'do' + let ind = virtcol('.') - 1 + else + let ind = indent('.') + endif + endif + return ind + endif + + " If we are in a multi-line string or line-comment, don't do anything to it. + if s:IsInStringOrDocumentation(v:lnum, matchend(line, '^\s*') + 1) + return indent('.') + endif + + " 3.3. Work on the previous line. {{{2 + " ------------------------------- + + " Find a non-blank, non-multi-line string line above the current line. + let lnum = s:PrevNonBlankNonString(v:lnum - 1) + + " If the line is empty and inside a string, use the previous line. + if line =~ '^\s*$' && lnum != prevnonblank(v:lnum - 1) + return indent(prevnonblank(v:lnum)) + endif + + " At the start of the file use zero indent. + if lnum == 0 + return 0 + endif + + " Set up variables for current line. + let line = getline(lnum) + let ind = indent(lnum) + + " If the previous line ended with a block opening, add a level of indent. + if s:Match(lnum, s:block_regex) + return indent(s:GetMSL(lnum)) + &sw + endif + + " If the previous line contained an opening bracket, and we are still in it, + " add indent depending on the bracket type. + if line =~ '[[({]' + let counts = s:LineHasOpeningBrackets(lnum) + if counts[0] == '1' && searchpair('(', '', ')', 'bW', s:skip_expr) > 0 + if col('.') + 1 == col('$') + return ind + &sw + else + return virtcol('.') + endif + elseif counts[1] == '1' || counts[2] == '1' + return ind + &sw + else + call cursor(v:lnum, vcol) + end + endif + + " If the previous line ended with an "end", match that "end"s beginning's + " indent. + let col = s:Match(lnum, '\%(^\|[^.:@$]\)\<end\>\s*\%(#.*\)\=$') + if col > 0 + call cursor(lnum, col) + if searchpair(s:end_start_regex, '', s:end_end_regex, 'bW', + \ s:end_skip_expr) > 0 + let n = line('.') + let ind = indent('.') + let msl = s:GetMSL(n) + if msl != n + let ind = indent(msl) + end + return ind + endif + end + + let col = s:Match(lnum, s:ruby_indent_keywords) + if col > 0 + call cursor(lnum, col) + let ind = virtcol('.') - 1 + &sw +" let ind = indent(lnum) + &sw + " TODO: make this better (we need to count them) (or, if a searchpair + " fails, we know that something is lacking an end and thus we indent a + " level + if s:Match(lnum, s:end_end_regex) + let ind = indent('.') + endif + return ind + endif + + " 3.4. Work on the MSL line. {{{2 + " -------------------------- + + " Set up variables to use and search for MSL to the previous line. + let p_lnum = lnum + let lnum = s:GetMSL(lnum) + + " If the previous line wasn't a MSL and is continuation return its indent. + " TODO: the || s:IsInString() thing worries me a bit. + if p_lnum != lnum + if s:Match(p_lnum,s:continuation_regex)||s:IsInString(p_lnum,strlen(line)) + return ind + endif + endif + + " Set up more variables, now that we know we wasn't continuation bound. + let line = getline(lnum) + let msl_ind = indent(lnum) + + " If the MSL line had an indenting keyword in it, add a level of indent. + " TODO: this does not take into account contrived things such as + " module Foo; class Bar; end + if s:Match(lnum, s:ruby_indent_keywords) + let ind = msl_ind + &sw + if s:Match(lnum, s:end_end_regex) + let ind = ind - &sw + endif + return ind + endif + + " If the previous line ended with [*+/.-=], indent one extra level. + if s:Match(lnum, s:continuation_regex) + if lnum == p_lnum + let ind = msl_ind + &sw + else + let ind = msl_ind + endif + endif + + " }}}2 + + return ind +endfunction + +" }}}1 + +let &cpo = s:cpo_save +unlet s:cpo_save + +" vim:set sw=2 sts=2 ts=8 noet: diff --git a/share/vim/vim73/indent/sass.vim b/share/vim/vim73/indent/sass.vim new file mode 100644 index 0000000000..4622f00ff8 --- /dev/null +++ b/share/vim/vim73/indent/sass.vim @@ -0,0 +1,39 @@ +" Vim indent file +" Language: Sass +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 May 21 + +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +setlocal autoindent sw=2 et +setlocal indentexpr=GetSassIndent() +setlocal indentkeys=o,O,*<Return>,<:>,!^F + +" Only define the function once. +if exists("*GetSassIndent") + finish +endif + +let s:property = '^\s*:\|^\s*[[:alnum:]-]\+\%(:\|\s*=\)' + +function! GetSassIndent() + let lnum = prevnonblank(v:lnum-1) + let line = substitute(getline(lnum),'\s\+$','','') + let cline = substitute(substitute(getline(v:lnum),'\s\+$','',''),'^\s\+','','') + let lastcol = strlen(line) + let line = substitute(line,'^\s\+','','') + let indent = indent(lnum) + let cindent = indent(v:lnum) + if line !~ s:property && cline =~ s:property + return indent + &sw + "elseif line =~ s:property && cline !~ s:property + "return indent - &sw + else + return -1 + endif +endfunction + +" vim:set sw=2: diff --git a/share/vim/vim72/indent/scheme.vim b/share/vim/vim73/indent/scheme.vim similarity index 100% rename from share/vim/vim72/indent/scheme.vim rename to share/vim/vim73/indent/scheme.vim diff --git a/share/vim/vim73/indent/scss.vim b/share/vim/vim73/indent/scss.vim new file mode 100644 index 0000000000..82bba4920b --- /dev/null +++ b/share/vim/vim73/indent/scss.vim @@ -0,0 +1,12 @@ +" Vim indent file +" Language: SCSS +" Maintainer: Tim Pope <vimNOSPAM@tpope.org> +" Last Change: 2010 Jul 26 + +if exists("b:did_indent") + finish +endif + +runtime! indent/css.vim + +" vim:set sw=2: diff --git a/share/vim/vim72/indent/sdl.vim b/share/vim/vim73/indent/sdl.vim similarity index 100% rename from share/vim/vim72/indent/sdl.vim rename to share/vim/vim73/indent/sdl.vim diff --git a/share/vim/vim73/indent/sh.vim b/share/vim/vim73/indent/sh.vim new file mode 100644 index 0000000000..49146c7e37 --- /dev/null +++ b/share/vim/vim73/indent/sh.vim @@ -0,0 +1,158 @@ +" Vim indent file +" Language: Shell Script +" Maintainer: Nikolai Weibull <now@bitwi.se> +" Latest Revision: 2010-01-06 + +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +setlocal indentexpr=GetShIndent() +setlocal indentkeys+=0=then,0=do,0=else,0=elif,0=fi,0=esac,0=done,),0=;;,0=;& +setlocal indentkeys+=0=fin,0=fil,0=fip,0=fir,0=fix +setlocal indentkeys-=:,0# +setlocal nosmartindent + +if exists("*GetShIndent") + finish +endif + +let s:cpo_save = &cpo +set cpo&vim + +function s:buffer_shiftwidth() + return &shiftwidth +endfunction + +let s:sh_indent_defaults = { + \ 'default': function('s:buffer_shiftwidth'), + \ 'continuation-line': function('s:buffer_shiftwidth'), + \ 'case-labels': function('s:buffer_shiftwidth'), + \ 'case-statements': function('s:buffer_shiftwidth'), + \ 'case-breaks': 0 } + +function! s:indent_value(option) + let Value = exists('b:sh_indent_options') + \ && has_key(b:sh_indent_options, a:option) ? + \ b:sh_indent_options[a:option] : + \ s:sh_indent_defaults[a:option] + if type(Value) == type(function('type')) + return Value() + endif + return Value +endfunction + +function! GetShIndent() + let lnum = prevnonblank(v:lnum - 1) + if lnum == 0 + return 0 + endif + + let pnum = prevnonblank(lnum - 1) + + let ind = indent(lnum) + let line = getline(lnum) + if line =~ '^\s*\%(if\|then\|do\|else\|elif\|case\|while\|until\|for\|select\)\>' + if line !~ '\<\%(fi\|esac\|done\)\>\s*\%(#.*\)\=$' + let ind += s:indent_value('default') + endif + elseif s:is_case_label(line, pnum) + if !s:is_case_ended(line) + let ind += s:indent_value('case-statements') + endif + elseif line =~ '^\s*\<\k\+\>\s*()\s*{' || line =~ '^\s*{' + if line !~ '}\s*\%(#.*\)\=$' + let ind += s:indent_value('default') + endif + elseif s:is_continuation_line(line) + if pnum == 0 || !s:is_continuation_line(getline(pnum)) + let ind += s:indent_value('continuation-line') + endif + elseif pnum != 0 && s:is_continuation_line(getline(pnum)) + let ind = indent(s:find_continued_lnum(pnum)) + endif + + let pine = line + let line = getline(v:lnum) + if line =~ '^\s*\%(then\|do\|else\|elif\|fi\|done\)\>' || line =~ '^\s*}' + let ind -= s:indent_value('default') + elseif line =~ '^\s*esac\>' + let ind -= (s:is_case_label(pine, lnum) && s:is_case_ended(pine) ? + \ 0 : s:indent_value('case-statements')) + + \ s:indent_value('case-labels') + if s:is_case_break(pine) + let ind += s:indent_value('case-breaks') + endif + elseif s:is_case_label(line, lnum) + if s:is_case(pine) + let ind = indent(lnum) + s:indent_value('case-labels') + else + let ind -= s:indent_value('case-statements') - s:indent_value('case-breaks') + endif + elseif s:is_case_break(line) + let ind -= s:indent_value('case-breaks') + endif + + return ind +endfunction + +function! s:is_continuation_line(line) + return a:line =~ '\%(\%(^\|[^\\]\)\\\|&&\|||\)$' +endfunction + +function! s:find_continued_lnum(lnum) + let i = a:lnum + while i > 1 && s:is_continuation_line(getline(i - 1)) + let i -= 1 + endwhile + return i +endfunction + +function! s:is_case_label(line, pnum) + if a:line !~ '^\s*(\=.*)' + return 0 + endif + + if a:pnum > 0 + let pine = getline(a:pnum) + if !(s:is_case(pine) || s:is_case_ended(pine)) + return 0 + endif + endif + + let suffix = substitute(a:line, '^\s*(\=', "", "") + let nesting = 0 + let i = 0 + let n = strlen(suffix) + while i < n + let c = suffix[i] + let i += 1 + if c == '\\' + let i += 1 + elseif c == '(' + let nesting += 1 + elseif c == ')' + if nesting == 0 + return 1 + endif + let nesting -= 1 + endif + endwhile + return 0 +endfunction + +function! s:is_case(line) + return a:line =~ '^\s*case\>' +endfunction + +function! s:is_case_break(line) + return a:line =~ '^\s*;[;&]' +endfunction + +function! s:is_case_ended(line) + return s:is_case_break(a:line) || a:line =~ ';[;&]\s*\%(#.*\)\=$' +endfunction + +let &cpo = s:cpo_save +unlet s:cpo_save diff --git a/share/vim/vim72/indent/sml.vim b/share/vim/vim73/indent/sml.vim similarity index 100% rename from share/vim/vim72/indent/sml.vim rename to share/vim/vim73/indent/sml.vim diff --git a/share/vim/vim72/indent/sql.vim b/share/vim/vim73/indent/sql.vim similarity index 100% rename from share/vim/vim72/indent/sql.vim rename to share/vim/vim73/indent/sql.vim diff --git a/share/vim/vim72/indent/sqlanywhere.vim b/share/vim/vim73/indent/sqlanywhere.vim similarity index 100% rename from share/vim/vim72/indent/sqlanywhere.vim rename to share/vim/vim73/indent/sqlanywhere.vim diff --git a/share/vim/vim72/indent/tcl.vim b/share/vim/vim73/indent/tcl.vim similarity index 100% rename from share/vim/vim72/indent/tcl.vim rename to share/vim/vim73/indent/tcl.vim diff --git a/share/vim/vim72/indent/tcsh.vim b/share/vim/vim73/indent/tcsh.vim similarity index 100% rename from share/vim/vim72/indent/tcsh.vim rename to share/vim/vim73/indent/tcsh.vim diff --git a/share/vim/vim73/indent/tf.vim b/share/vim/vim73/indent/tf.vim new file mode 100644 index 0000000000..17597734b8 --- /dev/null +++ b/share/vim/vim73/indent/tf.vim @@ -0,0 +1,72 @@ +" Vim indent file +" Language: tf (TinyFugue) +" Maintainer: Christian J. Robinson <heptite@gmail.com> +" URL: http://christianrobinson.name/vim/indent/tf.vim +" Last Change: 2002 May 29 + +" Only load this indent file when no other was loaded. +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +setlocal indentexpr=GetTFIndent() +setlocal indentkeys-=0{,0} indentkeys-=0# indentkeys-=: +setlocal indentkeys+==/endif,=/then,=/else,=/done,0; + +" Only define the function once: +if exists("*GetTFIndent") + finish +endif + +function GetTFIndent() + " Find a non-blank line above the current line: + let lnum = prevnonblank(v:lnum - 1) + + " No indent for the start of the file: + if lnum == 0 + return 0 + endif + + let ind = indent(lnum) + let line = getline(lnum) + + " No indentation if the previous line didn't end with "\": + " (Could be annoying, but it lets you know if you made a mistake.) + if line !~ '\\$' + return 0 + endif + + if line =~ '\(/def.*\\\|/for.*\(%;\s*\)\@\<!\\\)$' + let ind = ind + &sw + elseif line =~ '\(/if\|/else\|/then\)' + if line !~ '/endif' + let ind = ind + &sw + endif + elseif line =~ '/while' + if line !~ '/done' + let ind = ind + &sw + endif + endif + + let line = getline(v:lnum) + + if line =~ '\(/else\|/endif\|/then\)' + if line !~ '/if' + let ind = ind - &sw + endif + elseif line =~ '/done' + if line !~ '/while' + let ind = ind - &sw + endif + endif + + " Comments at the beginning of a line: + if line =~ '^\s*;' + let ind = 0 + endif + + + return ind + +endfunction diff --git a/share/vim/vim72/indent/tilde.vim b/share/vim/vim73/indent/tilde.vim similarity index 100% rename from share/vim/vim72/indent/tilde.vim rename to share/vim/vim73/indent/tilde.vim diff --git a/share/vim/vim73/indent/vb.vim b/share/vim/vim73/indent/vb.vim new file mode 100644 index 0000000000..55a8ea302a --- /dev/null +++ b/share/vim/vim73/indent/vb.vim @@ -0,0 +1,78 @@ +" Vim indent file +" Language: VisualBasic (ft=vb) / Basic (ft=basic) / SaxBasic (ft=vb) +" Author: Johannes Zellner <johannes@zellner.org> +" Last Change: Fri, 18 Jun 2004 07:22:42 CEST +" Small update 2010 Jul 28 by Maxim Kim + +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +setlocal autoindent +setlocal indentexpr=VbGetIndent(v:lnum) +setlocal indentkeys& +setlocal indentkeys+==~else,=~elseif,=~end,=~wend,=~case,=~next,=~select,=~loop,<:> + +let b:undo_indent = "set ai< indentexpr< indentkeys<" + +" Only define the function once. +if exists("*VbGetIndent") + finish +endif + +fun! VbGetIndent(lnum) + " labels and preprocessor get zero indent immediately + let this_line = getline(a:lnum) + let LABELS_OR_PREPROC = '^\s*\(\<\k\+\>:\s*$\|#.*\)' + if this_line =~? LABELS_OR_PREPROC + return 0 + endif + + " Find a non-blank line above the current line. + " Skip over labels and preprocessor directives. + let lnum = a:lnum + while lnum > 0 + let lnum = prevnonblank(lnum - 1) + let previous_line = getline(lnum) + if previous_line !~? LABELS_OR_PREPROC + break + endif + endwhile + + " Hit the start of the file, use zero indent. + if lnum == 0 + return 0 + endif + + let ind = indent(lnum) + + " Add + if previous_line =~? '^\s*\<\(begin\|\%(\%(private\|public\|friend\)\s\+\)\=\%(function\|sub\|property\)\|select\|case\|default\|if\|else\|elseif\|do\|for\|while\|enum\|with\)\>' + let ind = ind + &sw + endif + + " Subtract + if this_line =~? '^\s*\<end\>\s\+\<select\>' + if previous_line !~? '^\s*\<select\>' + let ind = ind - 2 * &sw + else + " this case is for an empty 'select' -- 'end select' + " (w/o any case statements) like: + " + " select case readwrite + " end select + let ind = ind - &sw + endif + elseif this_line =~? '^\s*\<\(end\|else\|elseif\|until\|loop\|next\|wend\)\>' + let ind = ind - &sw + elseif this_line =~? '^\s*\<\(case\|default\)\>' + if previous_line !~? '^\s*\<select\>' + let ind = ind - &sw + endif + endif + + return ind +endfun + +" vim:sw=4 diff --git a/share/vim/vim72/indent/verilog.vim b/share/vim/vim73/indent/verilog.vim similarity index 100% rename from share/vim/vim72/indent/verilog.vim rename to share/vim/vim73/indent/verilog.vim diff --git a/share/vim/vim73/indent/vhdl.vim b/share/vim/vim73/indent/vhdl.vim new file mode 100644 index 0000000000..717857fe3d --- /dev/null +++ b/share/vim/vim73/indent/vhdl.vim @@ -0,0 +1,406 @@ +" VHDL indent ('93 syntax) +" Language: VHDL +" Maintainer: Gerald Lai <laigera+vim?gmail.com> +" Version: 1.56 +" Last Change: 2010 Jun 29 +" URL: http://www.vim.org/scripts/script.php?script_id=1450 + +" only load this indent file when no other was loaded +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +" setup indent options for local VHDL buffer +setlocal indentexpr=GetVHDLindent() +setlocal indentkeys=!^F,o,O,0(,0) +setlocal indentkeys+==~begin,=~end\ ,=~end\ ,=~is,=~select,=~when +setlocal indentkeys+==~if,=~then,=~elsif,=~else +setlocal indentkeys+==~case,=~loop,=~for,=~generate,=~record,=~units,=~process,=~block,=~function,=~component,=~procedure +setlocal indentkeys+==~architecture,=~configuration,=~entity,=~package + +" constants +" not a comment +let s:NC = '\%(--.*\)\@<!' +" end of string +let s:ES = '\s*\%(--.*\)\=$' +" no "end" keyword in front +let s:NE = '\%(\<end\s\+\)\@<!' + +" option to disable alignment of generic/port mappings +if !exists("g:vhdl_indent_genportmap") + let g:vhdl_indent_genportmap = 1 +endif + +" option to disable alignment of right-hand side assignment "<=" statements +if !exists("g:vhdl_indent_rhsassign") + let g:vhdl_indent_rhsassign = 1 +endif + +" only define indent function once +if exists("*GetVHDLindent") + finish +endif + +function GetVHDLindent() + " store current line & string + let curn = v:lnum + let curs = getline(curn) + + " find previous line that is not a comment + let prevn = prevnonblank(curn - 1) + let prevs = getline(prevn) + while prevn > 0 && prevs =~ '^\s*--' + let prevn = prevnonblank(prevn - 1) + let prevs = getline(prevn) + endwhile + let prevs_noi = substitute(prevs, '^\s*', '', '') + + " default indent starts as previous non-comment line's indent + let ind = prevn > 0 ? indent(prevn) : 0 + " backup default + let ind2 = ind + + " indent: special; kill string so it would not affect other filters + " keywords: "report" + string + " where: anywhere in current or previous line + let s0 = s:NC.'\<report\>\s*".*"' + if curs =~? s0 + let curs = "" + endif + if prevs =~? s0 + let prevs = "" + endif + + " indent: previous line's comment position, otherwise follow next non-comment line if possible + " keyword: "--" + " where: start of current line + if curs =~ '^\s*--' + let pn = curn - 1 + let ps = getline(pn) + if curs =~ '^\s*--\s' && ps =~ '--' + return indent(pn) + stridx(substitute(ps, '^\s*', '', ''), '--') + else + " find nextnonblank line that is not a comment + let nn = nextnonblank(curn + 1) + let ns = getline(nn) + while nn > 0 && ns =~ '^\s*--' + let nn = nextnonblank(nn + 1) + let ns = getline(nn) + endwhile + let n = indent(nn) + return n != -1 ? n : ind + endif + endif + + " **************************************************************************************** + " indent: align generic variables & port names + " keywords: "generic", "map", "port" + "(", provided current line is part of mapping + " where: anywhere in previous 2 lines + " find following previous non-comment line + let pn = prevnonblank(prevn - 1) + let ps = getline(pn) + while pn > 0 && ps =~ '^\s*--' + let pn = prevnonblank(pn - 1) + let ps = getline(pn) + endwhile + if (curs =~ '^\s*)' || curs =~? '^\s*\%(\<\%(generic\|map\|port\)\>.*\)\@<!\S\+\s*\%(=>\s*\S\+\|:[^=]\@=\s*\%(\%(in\|out\|inout\|buffer\|linkage\)\>\|\w\+\s\+:=\)\)') && (prevs =~? s:NC.'\<\%(generic\|map\|port\)\s*(\%(\s*\w\)\=' || (ps =~? s:NC.'\<\%(generic\|map\|port\)'.s:ES && prevs =~ '^\s*(')) + " align closing ")" with opening "(" + if curs =~ '^\s*)' + return ind2 + stridx(prevs_noi, '(') + endif + let m = matchend(prevs_noi, '(\s*\ze\w') + if m != -1 + return ind2 + m + else + if g:vhdl_indent_genportmap + return ind2 + stridx(prevs_noi, '(') + &sw + else + return ind2 + &sw + endif + endif + endif + + " indent: align conditional/select statement + " keywords: variable + "<=" without ";" ending + " where: start of previous line + if prevs =~? '^\s*\S\+\s*<=[^;]*'.s:ES + if g:vhdl_indent_rhsassign + return ind2 + matchend(prevs_noi, '<=\s*\ze.') + else + return ind2 + &sw + endif + endif + + " indent: backtrace previous non-comment lines for next smaller or equal size indent + " keywords: "end" + "record", "units" + " where: start of previous line + " keyword: ")" + " where: start of previous line + " keyword: without "<=" + ";" ending + " where: anywhere in previous line + " keyword: "=>" + ")" ending, provided current line does not begin with ")" + " where: anywhere in previous line + " _note_: indent allowed to leave this filter + let m = 0 + if prevs =~? '^\s*end\s\+\%(record\|units\)\>' + let m = 3 + elseif prevs =~ '^\s*)' + let m = 1 + elseif prevs =~ s:NC.'\%(<=.*\)\@<!;'.s:ES || (curs !~ '^\s*)' && prevs =~ s:NC.'=>.*'.s:NC.')'.s:ES) + let m = 2 + endif + + if m > 0 + let pn = prevnonblank(prevn - 1) + let ps = getline(pn) + while pn > 0 + let t = indent(pn) + if ps !~ '^\s*--' && (t < ind || (t == ind && m == 3)) + " make sure one of these is true + " keywords: variable + "<=" without ";" ending + " where: start of previous non-comment line + " keywords: "generic", "map", "port" + " where: anywhere in previous non-comment line + " keyword: "(" + " where: start of previous non-comment line + if m < 3 && ps !~? '^\s*\S\+\s*<=[^;]*'.s:ES + if ps =~? s:NC.'\<\%(generic\|map\|port\)\>' || ps =~ '^\s*(' + let ind = t + endif + break + endif + let ind = t + if m > 1 + " find following previous non-comment line + let ppn = prevnonblank(pn - 1) + let pps = getline(ppn) + while ppn > 0 && pps =~ '^\s*--' + let ppn = prevnonblank(ppn - 1) + let pps = getline(ppn) + endwhile + " indent: follow + " keyword: "select" + " where: end of following previous non-comment line + " keyword: "type" + " where: start of following previous non-comment line + if m == 2 + let s1 = s:NC.'\<select'.s:ES + if ps !~? s1 && pps =~? s1 + let ind = indent(ppn) + endif + elseif m == 3 + let s1 = '^\s*type\>' + if ps !~? s1 && pps =~? s1 + let ind = indent(ppn) + endif + endif + endif + break + endif + let pn = prevnonblank(pn - 1) + let ps = getline(pn) + endwhile + endif + + " indent: follow indent of previous opening statement, otherwise -sw + " keyword: "begin" + " where: anywhere in current line + if curs =~? s:NC.'\<begin\>' + let ind = ind - &sw + " find previous opening statement of + " keywords: "architecture", "block", "entity", "function", "generate", "procedure", "process" + let s2 = s:NC.s:NE.'\<\%(architecture\|block\|entity\|function\|generate\|procedure\|process\)\>' + if (curs !~? s2.'.*'.s:NC.'\<begin\>.*'.s:ES && prevs =~? s2) || m == 1 + let ind = ind + &sw + endif + return ind + endif + + " indent: +sw if previous line is previous opening statement + " keywords: "record", "units" + " where: anywhere in current line + if curs =~? s:NC.s:NE.'\<\%(record\|units\)\>' + " find previous opening statement of + " keyword: "type" + let s3 = s:NC.s:NE.'\<type\>' + if curs !~? s3.'.*'.s:NC.'\<\%(record\|units\)\>.*'.s:ES && prevs =~? s3 + let ind = ind + &sw + endif + return ind + endif + + " **************************************************************************************** + " indent: 0 + " keywords: "architecture", "configuration", "entity", "library", "package" + " where: start of current line + if curs =~? '^\s*\%(architecture\|configuration\|entity\|library\|package\)\>' + return 0 + endif + + " indent: maintain indent of previous opening statement + " keyword: "is" + " where: start of current line + " find previous opening statement of + " keywords: "architecture", "block", "configuration", "entity", "function", "package", "procedure", "process", "type" + if curs =~? '^\s*\<is\>' && prevs =~? s:NC.s:NE.'\<\%(architecture\|block\|configuration\|entity\|function\|package\|procedure\|process\|type\)\>' + return ind2 + endif + + " indent: maintain indent of previous opening statement + " keyword: "then" + " where: start of current line + " find previous opening statement of + " keywords: "elsif", "if" + if curs =~? '^\s*\<then\>' && prevs =~? s:NC.'\%(\<elsif\>\|'.s:NE.'\<if\>\)' + return ind2 + endif + + " indent: maintain indent of previous opening statement + " keyword: "generate" + " where: start of current line + " find previous opening statement of + " keywords: "for", "if" + if curs =~? '^\s*\<generate\>' && prevs =~? s:NC.s:NE.'\%(\%(\<wait\s\+\)\@<!\<for\|\<if\)\>' + return ind2 + endif + + " indent: +sw + " keywords: "block", "process" + " removed: "begin", "case", "elsif", "if", "loop", "record", "units", "while" + " where: anywhere in previous line + if prevs =~? s:NC.s:NE.'\<\%(block\|process\)\>' + return ind + &sw + endif + + " indent: +sw + " keywords: "architecture", "configuration", "entity", "package" + " removed: "component", "for", "when", "with" + " where: start of previous line + if prevs =~? '^\s*\%(architecture\|configuration\|entity\|package\)\>' + return ind + &sw + endif + + " indent: +sw + " keyword: "select" + " removed: "generate", "is", "=>" + " where: end of previous line + if prevs =~? s:NC.'\<select'.s:ES + return ind + &sw + endif + + " indent: +sw + " keyword: "begin", "loop", "record", "units" + " where: anywhere in previous line + " keyword: "component", "else", "for" + " where: start of previous line + " keyword: "generate", "is", "then", "=>" + " where: end of previous line + " _note_: indent allowed to leave this filter + if prevs =~? s:NC.'\%(\<begin\>\|'.s:NE.'\<\%(loop\|record\|units\)\>\)' || prevs =~? '^\s*\%(component\|else\|for\)\>' || prevs =~? s:NC.'\%('.s:NE.'\<generate\|\<\%(is\|then\)\|=>\)'.s:ES + let ind = ind + &sw + endif + + " **************************************************************************************** + " indent: -sw + " keywords: "when", provided previous line does not begin with "when", does not end with "is" + " where: start of current line + let s4 = '^\s*when\>' + if curs =~? s4 + if prevs =~? s:NC.'\<is'.s:ES + return ind + elseif prevs !~? s4 + return ind - &sw + else + return ind2 + endif + endif + + " indent: -sw + " keywords: "else", "elsif", "end" + "block", "for", "function", "generate", "if", "loop", "procedure", "process", "record", "units" + " where: start of current line + if curs =~? '^\s*\%(else\|elsif\|end\s\+\%(block\|for\|function\|generate\|if\|loop\|procedure\|process\|record\|units\)\)\>' + return ind - &sw + endif + + " indent: backtrace previous non-comment lines + " keyword: "end" + "case", "component" + " where: start of current line + let m = 0 + if curs =~? '^\s*end\s\+case\>' + let m = 1 + elseif curs =~? '^\s*end\s\+component\>' + let m = 2 + endif + + if m > 0 + " find following previous non-comment line + let pn = prevn + let ps = getline(pn) + while pn > 0 + if ps !~ '^\s*--' + "indent: -2sw + "keywords: "end" + "case" + "where: start of previous non-comment line + "indent: -sw + "keywords: "when" + "where: start of previous non-comment line + "indent: follow + "keywords: "case" + "where: start of previous non-comment line + if m == 1 + if ps =~? '^\s*end\s\+case\>' + return indent(pn) - 2 * &sw + elseif ps =~? '^\s*when\>' + return indent(pn) - &sw + elseif ps =~? '^\s*case\>' + return indent(pn) + endif + "indent: follow + "keyword: "component" + "where: start of previous non-comment line + elseif m == 2 + if ps =~? '^\s*component\>' + return indent(pn) + endif + endif + endif + let pn = prevnonblank(pn - 1) + let ps = getline(pn) + endwhile + return ind - &sw + endif + + " indent: -sw + " keyword: ")" + " where: start of current line + if curs =~ '^\s*)' + return ind - &sw + endif + + " indent: 0 + " keywords: "end" + "architecture", "configuration", "entity", "package" + " where: start of current line + if curs =~? '^\s*end\s\+\%(architecture\|configuration\|entity\|package\)\>' + return 0 + endif + + " indent: -sw + " keywords: "end" + identifier, ";" + " where: start of current line + "if curs =~? '^\s*end\s\+\w\+\>' + if curs =~? '^\s*end\%(\s\|;'.s:ES.'\)' + return ind - &sw + endif + + " **************************************************************************************** + " indent: maintain indent of previous opening statement + " keywords: without "generic", "map", "port" + ":" but not ":=" + "in", "out", "inout", "buffer", "linkage", variable & ":=" + " where: start of current line + if curs =~? '^\s*\%(\<\%(generic\|map\|port\)\>.*\)\@<!\S\+\s*:[^=]\@=\s*\%(\%(in\|out\|inout\|buffer\|linkage\)\>\|\w\+\s\+:=\)' + return ind2 + endif + + " return leftover filtered indent + return ind +endfunction diff --git a/share/vim/vim72/indent/vim.vim b/share/vim/vim73/indent/vim.vim similarity index 100% rename from share/vim/vim72/indent/vim.vim rename to share/vim/vim73/indent/vim.vim diff --git a/share/vim/vim72/indent/xf86conf.vim b/share/vim/vim73/indent/xf86conf.vim similarity index 100% rename from share/vim/vim72/indent/xf86conf.vim rename to share/vim/vim73/indent/xf86conf.vim diff --git a/share/vim/vim72/indent/xhtml.vim b/share/vim/vim73/indent/xhtml.vim similarity index 100% rename from share/vim/vim72/indent/xhtml.vim rename to share/vim/vim73/indent/xhtml.vim diff --git a/share/vim/vim72/indent/xinetd.vim b/share/vim/vim73/indent/xinetd.vim similarity index 100% rename from share/vim/vim72/indent/xinetd.vim rename to share/vim/vim73/indent/xinetd.vim diff --git a/share/vim/vim73/indent/xml.vim b/share/vim/vim73/indent/xml.vim new file mode 100644 index 0000000000..4ac35b6af1 --- /dev/null +++ b/share/vim/vim73/indent/xml.vim @@ -0,0 +1,96 @@ +" Language: xml +" Maintainer: Johannes Zellner <johannes@zellner.org> +" Last Change: 2009-05-26 00:17:25 +" Notes: 1) does not indent pure non-xml code (e.g. embedded scripts) +" 2) will be confused by unbalanced tags in comments +" or CDATA sections. +" 2009-05-26 patch by Nikolai Weibull +" TODO: implement pre-like tags, see xml_indent_open / xml_indent_close + +" Only load this indent file when no other was loaded. +if exists("b:did_indent") + finish +endif +let b:did_indent = 1 + +" [-- local settings (must come before aborting the script) --] +setlocal indentexpr=XmlIndentGet(v:lnum,1) +setlocal indentkeys=o,O,*<Return>,<>>,<<>,/,{,} + +set cpo-=C + +if !exists('b:xml_indent_open') + let b:xml_indent_open = '.\{-}<\a' + " pre tag, e.g. <address> + " let b:xml_indent_open = '.\{-}<[/]\@!\(address\)\@!' +endif + +if !exists('b:xml_indent_close') + let b:xml_indent_close = '.\{-}</' + " end pre tag, e.g. </address> + " let b:xml_indent_close = '.\{-}</\(address\)\@!' +endif + +" [-- finish, if the function already exists --] +if exists('*XmlIndentGet') | finish | endif + +fun! <SID>XmlIndentWithPattern(line, pat) + let s = substitute('x'.a:line, a:pat, "\1", 'g') + return strlen(substitute(s, "[^\1].*$", '', '')) +endfun + +" [-- check if it's xml --] +fun! <SID>XmlIndentSynCheck(lnum) + if '' != &syntax + let syn1 = synIDattr(synID(a:lnum, 1, 1), 'name') + let syn2 = synIDattr(synID(a:lnum, strlen(getline(a:lnum)) - 1, 1), 'name') + if '' != syn1 && syn1 !~ 'xml' && '' != syn2 && syn2 !~ 'xml' + " don't indent pure non-xml code + return 0 + elseif syn1 =~ '^xmlComment' && syn2 =~ '^xmlComment' + " indent comments specially + return -1 + endif + endif + return 1 +endfun + +" [-- return the sum of indents of a:lnum --] +fun! <SID>XmlIndentSum(lnum, style, add) + let line = getline(a:lnum) + if a:style == match(line, '^\s*</') + return (&sw * + \ (<SID>XmlIndentWithPattern(line, b:xml_indent_open) + \ - <SID>XmlIndentWithPattern(line, b:xml_indent_close) + \ - <SID>XmlIndentWithPattern(line, '.\{-}/>'))) + a:add + else + return a:add + endif +endfun + +fun! XmlIndentGet(lnum, use_syntax_check) + " Find a non-empty line above the current line. + let lnum = prevnonblank(a:lnum - 1) + + " Hit the start of the file, use zero indent. + if lnum == 0 + return 0 + endif + + if a:use_syntax_check + let check_lnum = <SID>XmlIndentSynCheck(lnum) + let check_alnum = <SID>XmlIndentSynCheck(a:lnum) + if 0 == check_lnum || 0 == check_alnum + return indent(a:lnum) + elseif -1 == check_lnum || -1 == check_alnum + return -1 + endif + endif + + let ind = <SID>XmlIndentSum(lnum, -1, indent(lnum)) + let ind = <SID>XmlIndentSum(a:lnum, 0, ind) + + return ind +endfun + +" vim:ts=8 diff --git a/share/vim/vim72/indent/xsd.vim b/share/vim/vim73/indent/xsd.vim similarity index 100% rename from share/vim/vim72/indent/xsd.vim rename to share/vim/vim73/indent/xsd.vim diff --git a/share/vim/vim72/indent/xslt.vim b/share/vim/vim73/indent/xslt.vim similarity index 100% rename from share/vim/vim72/indent/xslt.vim rename to share/vim/vim73/indent/xslt.vim diff --git a/share/vim/vim72/indent/yacc.vim b/share/vim/vim73/indent/yacc.vim similarity index 100% rename from share/vim/vim72/indent/yacc.vim rename to share/vim/vim73/indent/yacc.vim diff --git a/share/vim/vim72/indent/zsh.vim b/share/vim/vim73/indent/zsh.vim similarity index 100% rename from share/vim/vim72/indent/zsh.vim rename to share/vim/vim73/indent/zsh.vim diff --git a/share/vim/vim72/indoff.vim b/share/vim/vim73/indoff.vim similarity index 100% rename from share/vim/vim72/indoff.vim rename to share/vim/vim73/indoff.vim diff --git a/share/vim/vim72/keymap/README.txt b/share/vim/vim73/keymap/README.txt similarity index 100% rename from share/vim/vim72/keymap/README.txt rename to share/vim/vim73/keymap/README.txt diff --git a/share/vim/vim72/keymap/accents.vim b/share/vim/vim73/keymap/accents.vim similarity index 100% rename from share/vim/vim72/keymap/accents.vim rename to share/vim/vim73/keymap/accents.vim diff --git a/share/vim/vim72/keymap/arabic.vim b/share/vim/vim73/keymap/arabic.vim similarity index 100% rename from share/vim/vim72/keymap/arabic.vim rename to share/vim/vim73/keymap/arabic.vim diff --git a/share/vim/vim72/keymap/arabic_utf-8.vim b/share/vim/vim73/keymap/arabic_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/arabic_utf-8.vim rename to share/vim/vim73/keymap/arabic_utf-8.vim diff --git a/share/vim/vim73/keymap/bulgarian-bds.vim b/share/vim/vim73/keymap/bulgarian-bds.vim new file mode 100644 index 0000000000..3377edbbd8 --- /dev/null +++ b/share/vim/vim73/keymap/bulgarian-bds.vim @@ -0,0 +1,155 @@ +" Vim keymap file for Bulgarian and Russian characters, "bds" layout. +" Most of it can be used with both utf-8 and cp1251 file encodings, except +" the accented characters which can only be stored in utf-8. +" This file itself is in utf-8. + +" Maintainer: Boyko Bantchev <boykobb@gmail.com> +" URI: http://www.math.bas.bg/bantchev/vim/bulgarian-bds.vim +" Last Changed: 2010 May 4 + +" This keymap corresponds to what is called Bulgarian standard typewriter +" keyboard layout, or "БДС". +" +" Note that, in addition to the Bulgarian alphabet, the BDS layout prescribes +" the presence of the following characters: +" — The Russian letters ы (small), and Э and э (capital and small). +" — The latin capital letters I and V – used to type Roman numerals +" without having to leave Cyrillic mode. +" +" Some punctuation characters present in ascii are mapped in BDS to keys +" different from the ones they occupy in the QWERTY layout, because the latter +" keys are used to type other characters. +" +" In this keymap, also defined (besides BDS) are: +" — The Russian letters Ё and ё (capital and small), as well as the +" Russian capital letter Ы (see above for the small counterpart). +" This way, using the bulgarian-bds keymap, one can access both +" the Bulgarian and the Russian alphabets. +" — The quotation marks „ “ ” ‘ ’ (used in the Bulgarian and English +" quotation styles), as well as « » (Russian quotation style). +" — The characters §, №, – (en-dash), — (em-dash), …, •, ·, ±, °, ¬, +" ¤, €, ‰, †, ‡, and ¶. +" +" The keymap also defines key combinations for grave and acute accents. +" (Grave accent is used in Bulgarian, acute in Russian, but both accents +" apply to other languages as well.) +" +" For details of what key or key combination maps to what character, please +" see below the map itself. +" +" See also http://www.math.bas.bg/bantchev/vim/kbdbul.html (in Bulgarian). + +scriptencoding utf-8 + +let b:keymap_name = "bds" + +loadkeymap +D А CYRILLIC CAPITAL LETTER A +? Б CYRILLIC CAPITAL LETTER BE +L В CYRILLIC CAPITAL LETTER VE +H Г CYRILLIC CAPITAL LETTER GHE +O Д CYRILLIC CAPITAL LETTER DE +E Е CYRILLIC CAPITAL LETTER IE +E:: Ё CYRILLIC CAPITAL LETTER IO +G Ж CYRILLIC CAPITAL LETTER ZHE +P З CYRILLIC CAPITAL LETTER ZE +R И CYRILLIC CAPITAL LETTER I +X Й CYRILLIC CAPITAL LETTER SHORT I +U К CYRILLIC CAPITAL LETTER KA +> Л CYRILLIC CAPITAL LETTER EL +: М CYRILLIC CAPITAL LETTER EM +K Н CYRILLIC CAPITAL LETTER EN +F О CYRILLIC CAPITAL LETTER O +M П CYRILLIC CAPITAL LETTER PE +< Р CYRILLIC CAPITAL LETTER ER +I С CYRILLIC CAPITAL LETTER ES +J Т CYRILLIC CAPITAL LETTER TE +W У CYRILLIC CAPITAL LETTER U +B Ф CYRILLIC CAPITAL LETTER EF +N Х CYRILLIC CAPITAL LETTER HA +{ Ц CYRILLIC CAPITAL LETTER TSE +\" Ч CYRILLIC CAPITAL LETTER CHE +T Ш CYRILLIC CAPITAL LETTER SHA +Y Щ CYRILLIC CAPITAL LETTER SHCHA +C Ъ CYRILLIC CAPITAL LETTER HARD SIGN +CX Ы CYRILLIC CAPITAL LETTER YERU +A Ь CYRILLIC CAPITAL LETTER SOFT SIGN +V Э CYRILLIC CAPITAL LETTER REVERSED E +Z Ю CYRILLIC CAPITAL LETTER YU +S Я CYRILLIC CAPITAL LETTER YA +d а CYRILLIC SMALL LETTER A +\/ б CYRILLIC SMALL LETTER BE +l в CYRILLIC SMALL LETTER VE +h г CYRILLIC SMALL LETTER GHE +o д CYRILLIC SMALL LETTER DE +e е CYRILLIC SMALL LETTER IE +e:: ё CYRILLIC SMALL LETTER IO +g ж CYRILLIC SMALL LETTER ZHE +p з CYRILLIC SMALL LETTER ZE +r и CYRILLIC SMALL LETTER I +x й CYRILLIC SMALL LETTER SHORT I +u к CYRILLIC SMALL LETTER KA +\. л CYRILLIC SMALL LETTER EL +; м CYRILLIC SMALL LETTER EM +k н CYRILLIC SMALL LETTER EN +f о CYRILLIC SMALL LETTER O +m п CYRILLIC SMALL LETTER PE +, р CYRILLIC SMALL LETTER ER +i с CYRILLIC SMALL LETTER ES +j т CYRILLIC SMALL LETTER TE +w у CYRILLIC SMALL LETTER U +b ф CYRILLIC SMALL LETTER EF +n х CYRILLIC SMALL LETTER HA +[ ц CYRILLIC SMALL LETTER TSE +' ч CYRILLIC SMALL LETTER CHE +t ш CYRILLIC SMALL LETTER SHA +y щ CYRILLIC SMALL LETTER SHCHA +c ъ CYRILLIC SMALL LETTER HARD SIGN +Q ы CYRILLIC SMALL LETTER YERU +a ь CYRILLIC SMALL LETTER SOFT SIGN +v э CYRILLIC SMALL LETTER REVERSED E +z ю CYRILLIC SMALL LETTER YU +s я CYRILLIC SMALL LETTER YA +_ I LATIN CAPITAL LETTER I ++ V LATIN CAPITAL LETTER V +$ " QUOTATION MARK +\\ ( LEFT PARENTHESIS +| ) RIGHT PARENTHESIS +# + PLUS SIGN +q , COMMA +( - HYPHEN-MINUS += . FULL STOP (PERIOD) +* / SOLIDUS (SLASH) +& : COLON +] ; SEMICOLON +^ = EQUALS SIGN +@ ? QUESTION MARK +} § SECTION SIGN (PARAGRAPH SIGN) +) № NUMERO SIGN +-- – EN DASH +--- — EM DASH +.. … HORIZONTAL ELLIPSIS +`` “ LEFT DOUBLE QUOTATION MARK +'' ” RIGHT DOUBLE QUOTATION MARK +,, „ DOUBLE LOW-9 QUOTATION MARK +`. ‘ LEFT SINGLE QUOTATION MARK +'. ’ RIGHT SINGLE QUOTATION MARK +<< « LEFT-POINTING DOUBLE ANGLE QUOTATION MARK +>> » RIGHT-POINTING DOUBLE ANGLE QUOTATION MARK +** • BULLET +,. · MIDDLE DOT ++- ± PLUS-MINUS SIGN +^o ° DEGREE SIGN +~~ ¬ NOT SIGN +@@ ¤ CURRENCY SIGN +$$ € EURO SIGN +%% ‰ PER MILLE SIGN ++| † DAGGER +++ ‡ DOUBLE DAGGER +|| ¶ PILCROW SIGN + +" Accented characters cannot map onto cp1251 – use utf-8 file encoding. +" To apply an accent to a letter, type the corresponding key combination +" to the immediate right of that letter. +^` <char-0x300> COMBINING GRAVE ACCENT +^' <char-0x301> COMBINING ACUTE ACCENT diff --git a/share/vim/vim73/keymap/bulgarian-phonetic.vim b/share/vim/vim73/keymap/bulgarian-phonetic.vim new file mode 100644 index 0000000000..eab2f15e5c --- /dev/null +++ b/share/vim/vim73/keymap/bulgarian-phonetic.vim @@ -0,0 +1,135 @@ +" Vim keymap file for Bulgarian and Russian characters, "phonetic" layout. +" Most of it can be used with both utf-8 and cp1251 file encodings, except +" the accented vowels which can only be stored in utf-8. +" This file itself is in utf-8. + +" Maintainer: Boyko Bantchev <boykobb@gmail.com> +" URI: http://www.math.bas.bg/bantchev/vim/bulgarian-phonetic.vim +" Last Changed: 2010 May 4 + +" This keymap corresponds to what is called "phonetic layout" in Bulgaria: +" Cyrillic letters tend to be mapped to their Latin homophones wherever +" there are ones. Most keys corresponding to punctuation characters are +" left unmapped, so they retain their usual (QWERTY) meanings when typing +" Cyrillic. +" +" In addition to the Bulgarian alphabet, the keymap makes accessible the +" following characters: +" — The letters Ё and ё, Э and э, and Ы and ы (in pairs of capital and +" small). These are the letters in the Russian alphabet that are not +" present in Bulgarian, so using the bulgarian-phonetic keymap one can +" type in Russian, too. +" — The quotation marks „ “ ” ‘ ’ (used in the Bulgarian and English +" quotation styles), as well as « » (Russian quotation style). +" — The characters §, №, – (en-dash), — (em-dash), …, •, ·, ±, °, ¬, +" ¤, €, ‰, †, ‡, and ¶. +" +" The keymap also defines key combinations for grave and acute accents. +" (Grave accent is used in Bulgarian, acute in Russian, but both accents +" apply to other languages as well.) +" +" For details of what key or key combination maps to what character, please +" see below the map itself. +" +" See also http://www.math.bas.bg/bantchev/vim/kbdbul.html (in Bulgarian). + +scriptencoding utf-8 + +let b:keymap_name = "pho" + +loadkeymap +A А CYRILLIC CAPITAL LETTER A +B Б CYRILLIC CAPITAL LETTER BE +W В CYRILLIC CAPITAL LETTER VE +G Г CYRILLIC CAPITAL LETTER GHE +D Д CYRILLIC CAPITAL LETTER DE +E Е CYRILLIC CAPITAL LETTER IE +E:: Ё CYRILLIC CAPITAL LETTER IO +V Ж CYRILLIC CAPITAL LETTER ZHE +Z З CYRILLIC CAPITAL LETTER ZE +I И CYRILLIC CAPITAL LETTER I +J Й CYRILLIC CAPITAL LETTER SHORT I +K К CYRILLIC CAPITAL LETTER KA +L Л CYRILLIC CAPITAL LETTER EL +M М CYRILLIC CAPITAL LETTER EM +N Н CYRILLIC CAPITAL LETTER EN +O О CYRILLIC CAPITAL LETTER O +P П CYRILLIC CAPITAL LETTER PE +R Р CYRILLIC CAPITAL LETTER ER +S С CYRILLIC CAPITAL LETTER ES +T Т CYRILLIC CAPITAL LETTER TE +U У CYRILLIC CAPITAL LETTER U +F Ф CYRILLIC CAPITAL LETTER EF +H Х CYRILLIC CAPITAL LETTER HA +C Ц CYRILLIC CAPITAL LETTER TSE +~ Ч CYRILLIC CAPITAL LETTER CHE +{ Ш CYRILLIC CAPITAL LETTER SHA +} Щ CYRILLIC CAPITAL LETTER SHCHA +Y Ъ CYRILLIC CAPITAL LETTER HARD SIGN +YI Ы CYRILLIC CAPITAL LETTER YERU +X Ь CYRILLIC CAPITAL LETTER SOFT SIGN +YE Э CYRILLIC CAPITAL LETTER REVERSED E +| Ю CYRILLIC CAPITAL LETTER YU +Q Я CYRILLIC CAPITAL LETTER YA +a а CYRILLIC SMALL LETTER A +b б CYRILLIC SMALL LETTER BE +w в CYRILLIC SMALL LETTER VE +g г CYRILLIC SMALL LETTER GHE +d д CYRILLIC SMALL LETTER DE +e е CYRILLIC SMALL LETTER IE +e:: ё CYRILLIC SMALL LETTER IO +v ж CYRILLIC SMALL LETTER ZHE +z з CYRILLIC SMALL LETTER ZE +i и CYRILLIC SMALL LETTER I +j й CYRILLIC SMALL LETTER SHORT I +k к CYRILLIC SMALL LETTER KA +l л CYRILLIC SMALL LETTER EL +m м CYRILLIC SMALL LETTER EM +n н CYRILLIC SMALL LETTER EN +o о CYRILLIC SMALL LETTER O +p п CYRILLIC SMALL LETTER PE +r р CYRILLIC SMALL LETTER ER +s с CYRILLIC SMALL LETTER ES +t т CYRILLIC SMALL LETTER TE +u у CYRILLIC SMALL LETTER U +f ф CYRILLIC SMALL LETTER EF +h х CYRILLIC SMALL LETTER HA +c ц CYRILLIC SMALL LETTER TSE +` ч CYRILLIC SMALL LETTER CHE +[ ш CYRILLIC SMALL LETTER SHA +] щ CYRILLIC SMALL LETTER SHCHA +y ъ CYRILLIC SMALL LETTER HARD SIGN +yi ы CYRILLIC SMALL LETTER YERU +x ь CYRILLIC SMALL LETTER SOFT SIGN +ye э CYRILLIC SMALL LETTER REVERSED E +\\ ю CYRILLIC SMALL LETTER YU +q я CYRILLIC SMALL LETTER YA +!! § SECTION SIGN (PARAGRAPH SIGN) +## № NUMERO SIGN +-- – EN DASH +--- — EM DASH +.. … HORIZONTAL ELLIPSIS +`` “ LEFT DOUBLE QUOTATION MARK +'' ” RIGHT DOUBLE QUOTATION MARK +,, „ DOUBLE LOW-9 QUOTATION MARK +`. ‘ LEFT SINGLE QUOTATION MARK +'. ’ RIGHT SINGLE QUOTATION MARK +<< « LEFT-POINTING DOUBLE ANGLE QUOTATION MARK +>> » RIGHT-POINTING DOUBLE ANGLE QUOTATION MARK +** • BULLET +,. · MIDDLE DOT ++- ± PLUS-MINUS SIGN +^o ° DEGREE SIGN +~~ ¬ NOT SIGN +@@ ¤ CURRENCY SIGN +$$ € EURO SIGN +%% ‰ PER MILLE SIGN ++| † DAGGER +++ ‡ DOUBLE DAGGER +|| ¶ PILCROW SIGN + +" Accented characters cannot map onto cp1251 – use utf-8 file encoding. +" To apply an accent to a letter, type the corresponding key combination +" to the immediate right of that letter. +^` <char-0x300> COMBINING GRAVE ACCENT +^' <char-0x301> COMBINING ACUTE ACCENT diff --git a/share/vim/vim72/keymap/canfr-win.vim b/share/vim/vim73/keymap/canfr-win.vim similarity index 100% rename from share/vim/vim72/keymap/canfr-win.vim rename to share/vim/vim73/keymap/canfr-win.vim diff --git a/share/vim/vim72/keymap/croatian.vim b/share/vim/vim73/keymap/croatian.vim similarity index 100% rename from share/vim/vim72/keymap/croatian.vim rename to share/vim/vim73/keymap/croatian.vim diff --git a/share/vim/vim72/keymap/croatian_cp1250.vim b/share/vim/vim73/keymap/croatian_cp1250.vim similarity index 100% rename from share/vim/vim72/keymap/croatian_cp1250.vim rename to share/vim/vim73/keymap/croatian_cp1250.vim diff --git a/share/vim/vim72/keymap/croatian_iso-8859-2.vim b/share/vim/vim73/keymap/croatian_iso-8859-2.vim similarity index 100% rename from share/vim/vim72/keymap/croatian_iso-8859-2.vim rename to share/vim/vim73/keymap/croatian_iso-8859-2.vim diff --git a/share/vim/vim72/keymap/croatian_utf-8.vim b/share/vim/vim73/keymap/croatian_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/croatian_utf-8.vim rename to share/vim/vim73/keymap/croatian_utf-8.vim diff --git a/share/vim/vim72/keymap/czech.vim b/share/vim/vim73/keymap/czech.vim similarity index 100% rename from share/vim/vim72/keymap/czech.vim rename to share/vim/vim73/keymap/czech.vim diff --git a/share/vim/vim73/keymap/czech_utf-8.vim b/share/vim/vim73/keymap/czech_utf-8.vim new file mode 100644 index 0000000000..0a084742db --- /dev/null +++ b/share/vim/vim73/keymap/czech_utf-8.vim @@ -0,0 +1,86 @@ +" Maintainer: Štěpán Němec <stepnem@gmail.com> +" Last Changed: Fri 25 Jun 2010 22:08:43 CEST + +let b:keymap_name = "czech" + +loadkey +0 é +9 í +8 á +7 ý +6 ž +5 ř +4 č +3 š +2 ě +1 + +` ; +) 0 +( 9 +* 8 +& 7 +^ 6 +% 5 +$ 4 +# 3 +@ 2 +! 1 +] ) +} ( +[ ú +{ / +' § +\" ! +; ů +: " +/ - +? _ +> : +< ? +| ' +~u ů +~U Ů +\\a ä +\\e ë +\\i ï +\\o ö +\\u ü +\\z ÿ +\\A Ä +\\E Ë +\\I Ï +\\O Ö +\\U Ü +\\Z Ÿ +=a á +=e é +=i í +=o ó +=u ú +=z ý +=A Á +=E É +=I Í +=O Ó +=U Ú +=Z Ý ++c č ++d ď ++e ě ++n ň ++r ř ++s š ++t ť ++y ž ++C Č ++D Ď ++E Ě ++N Ň ++R Ř ++S Š ++T Ť ++Y Ž +y z +Y Z +z y +Z Y diff --git a/share/vim/vim73/keymap/dvorak.vim b/share/vim/vim73/keymap/dvorak.vim new file mode 100644 index 0000000000..77dc530b1b --- /dev/null +++ b/share/vim/vim73/keymap/dvorak.vim @@ -0,0 +1,82 @@ +" Maintainer: Ashish SHUKLA <wahjava@members.fsf.org> +" Last Changed: 2009 Jul 04 +" +" All characters are ASCII, conversion to another encoding (e.g., UTF-8) +" should work. + +let b:keymap_name = "en-dv" + +loadkeymap +q ' +w , +e . +r p +t y +y f +u g +i c +o r +p l +[ / +] = +\\ \\ +a a +s o +d e +f u +g i +h d +j h +k t +l n +; s +' - +z ; +x q +c j +v k +b x +n b +m m +, w +. v +/ z +Z : +X Q +C J +V K +B X +N B +M M +< W +> V +? Z +A A +S O +D E +F U +G I +H D +J H +K T +L N +: S +\" _ +Q " +W < +E > +R P +T Y +Y F +U G +I C +O R +P L +{ ? +} + +| | +- [ +_ { += ] ++ } + diff --git a/share/vim/vim72/keymap/esperanto.vim b/share/vim/vim73/keymap/esperanto.vim similarity index 100% rename from share/vim/vim72/keymap/esperanto.vim rename to share/vim/vim73/keymap/esperanto.vim diff --git a/share/vim/vim72/keymap/esperanto_utf-8.vim b/share/vim/vim73/keymap/esperanto_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/esperanto_utf-8.vim rename to share/vim/vim73/keymap/esperanto_utf-8.vim diff --git a/share/vim/vim72/keymap/greek.vim b/share/vim/vim73/keymap/greek.vim similarity index 100% rename from share/vim/vim72/keymap/greek.vim rename to share/vim/vim73/keymap/greek.vim diff --git a/share/vim/vim72/keymap/greek_cp1253.vim b/share/vim/vim73/keymap/greek_cp1253.vim similarity index 100% rename from share/vim/vim72/keymap/greek_cp1253.vim rename to share/vim/vim73/keymap/greek_cp1253.vim diff --git a/share/vim/vim72/keymap/greek_cp737.vim b/share/vim/vim73/keymap/greek_cp737.vim similarity index 100% rename from share/vim/vim72/keymap/greek_cp737.vim rename to share/vim/vim73/keymap/greek_cp737.vim diff --git a/share/vim/vim72/keymap/greek_iso-8859-7.vim b/share/vim/vim73/keymap/greek_iso-8859-7.vim similarity index 100% rename from share/vim/vim72/keymap/greek_iso-8859-7.vim rename to share/vim/vim73/keymap/greek_iso-8859-7.vim diff --git a/share/vim/vim72/keymap/greek_utf-8.vim b/share/vim/vim73/keymap/greek_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/greek_utf-8.vim rename to share/vim/vim73/keymap/greek_utf-8.vim diff --git a/share/vim/vim72/keymap/hebrew.vim b/share/vim/vim73/keymap/hebrew.vim similarity index 100% rename from share/vim/vim72/keymap/hebrew.vim rename to share/vim/vim73/keymap/hebrew.vim diff --git a/share/vim/vim72/keymap/hebrew_cp1255.vim b/share/vim/vim73/keymap/hebrew_cp1255.vim similarity index 100% rename from share/vim/vim72/keymap/hebrew_cp1255.vim rename to share/vim/vim73/keymap/hebrew_cp1255.vim diff --git a/share/vim/vim72/keymap/hebrew_iso-8859-8.vim b/share/vim/vim73/keymap/hebrew_iso-8859-8.vim similarity index 100% rename from share/vim/vim72/keymap/hebrew_iso-8859-8.vim rename to share/vim/vim73/keymap/hebrew_iso-8859-8.vim diff --git a/share/vim/vim72/keymap/hebrew_utf-8.vim b/share/vim/vim73/keymap/hebrew_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/hebrew_utf-8.vim rename to share/vim/vim73/keymap/hebrew_utf-8.vim diff --git a/share/vim/vim72/keymap/hebrewp.vim b/share/vim/vim73/keymap/hebrewp.vim similarity index 100% rename from share/vim/vim72/keymap/hebrewp.vim rename to share/vim/vim73/keymap/hebrewp.vim diff --git a/share/vim/vim72/keymap/hebrewp_cp1255.vim b/share/vim/vim73/keymap/hebrewp_cp1255.vim similarity index 100% rename from share/vim/vim72/keymap/hebrewp_cp1255.vim rename to share/vim/vim73/keymap/hebrewp_cp1255.vim diff --git a/share/vim/vim72/keymap/hebrewp_iso-8859-8.vim b/share/vim/vim73/keymap/hebrewp_iso-8859-8.vim similarity index 100% rename from share/vim/vim72/keymap/hebrewp_iso-8859-8.vim rename to share/vim/vim73/keymap/hebrewp_iso-8859-8.vim diff --git a/share/vim/vim72/keymap/hebrewp_utf-8.vim b/share/vim/vim73/keymap/hebrewp_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/hebrewp_utf-8.vim rename to share/vim/vim73/keymap/hebrewp_utf-8.vim diff --git a/share/vim/vim72/keymap/kana.vim b/share/vim/vim73/keymap/kana.vim similarity index 100% rename from share/vim/vim72/keymap/kana.vim rename to share/vim/vim73/keymap/kana.vim diff --git a/share/vim/vim72/keymap/lithuanian-baltic.vim b/share/vim/vim73/keymap/lithuanian-baltic.vim similarity index 100% rename from share/vim/vim72/keymap/lithuanian-baltic.vim rename to share/vim/vim73/keymap/lithuanian-baltic.vim diff --git a/share/vim/vim72/keymap/magyar_utf-8.vim b/share/vim/vim73/keymap/magyar_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/magyar_utf-8.vim rename to share/vim/vim73/keymap/magyar_utf-8.vim diff --git a/share/vim/vim72/keymap/mongolian_utf-8.vim b/share/vim/vim73/keymap/mongolian_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/mongolian_utf-8.vim rename to share/vim/vim73/keymap/mongolian_utf-8.vim diff --git a/share/vim/vim72/keymap/persian-iranian_utf-8.vim b/share/vim/vim73/keymap/persian-iranian_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/persian-iranian_utf-8.vim rename to share/vim/vim73/keymap/persian-iranian_utf-8.vim diff --git a/share/vim/vim72/keymap/persian.vim b/share/vim/vim73/keymap/persian.vim similarity index 100% rename from share/vim/vim72/keymap/persian.vim rename to share/vim/vim73/keymap/persian.vim diff --git a/share/vim/vim72/keymap/pinyin.vim b/share/vim/vim73/keymap/pinyin.vim similarity index 100% rename from share/vim/vim72/keymap/pinyin.vim rename to share/vim/vim73/keymap/pinyin.vim diff --git a/share/vim/vim72/keymap/polish-slash.vim b/share/vim/vim73/keymap/polish-slash.vim similarity index 100% rename from share/vim/vim72/keymap/polish-slash.vim rename to share/vim/vim73/keymap/polish-slash.vim diff --git a/share/vim/vim72/keymap/polish-slash_cp1250.vim b/share/vim/vim73/keymap/polish-slash_cp1250.vim similarity index 100% rename from share/vim/vim72/keymap/polish-slash_cp1250.vim rename to share/vim/vim73/keymap/polish-slash_cp1250.vim diff --git a/share/vim/vim72/keymap/polish-slash_cp852.vim b/share/vim/vim73/keymap/polish-slash_cp852.vim similarity index 100% rename from share/vim/vim72/keymap/polish-slash_cp852.vim rename to share/vim/vim73/keymap/polish-slash_cp852.vim diff --git a/share/vim/vim72/keymap/polish-slash_iso-8859-2.vim b/share/vim/vim73/keymap/polish-slash_iso-8859-2.vim similarity index 100% rename from share/vim/vim72/keymap/polish-slash_iso-8859-2.vim rename to share/vim/vim73/keymap/polish-slash_iso-8859-2.vim diff --git a/share/vim/vim72/keymap/polish-slash_utf-8.vim b/share/vim/vim73/keymap/polish-slash_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/polish-slash_utf-8.vim rename to share/vim/vim73/keymap/polish-slash_utf-8.vim diff --git a/share/vim/vim72/keymap/russian-dvorak.vim b/share/vim/vim73/keymap/russian-dvorak.vim similarity index 100% rename from share/vim/vim72/keymap/russian-dvorak.vim rename to share/vim/vim73/keymap/russian-dvorak.vim diff --git a/share/vim/vim72/keymap/russian-jcuken.vim b/share/vim/vim73/keymap/russian-jcuken.vim similarity index 100% rename from share/vim/vim72/keymap/russian-jcuken.vim rename to share/vim/vim73/keymap/russian-jcuken.vim diff --git a/share/vim/vim72/keymap/russian-jcukenwin.vim b/share/vim/vim73/keymap/russian-jcukenwin.vim similarity index 100% rename from share/vim/vim72/keymap/russian-jcukenwin.vim rename to share/vim/vim73/keymap/russian-jcukenwin.vim diff --git a/share/vim/vim72/keymap/russian-yawerty.vim b/share/vim/vim73/keymap/russian-yawerty.vim similarity index 100% rename from share/vim/vim72/keymap/russian-yawerty.vim rename to share/vim/vim73/keymap/russian-yawerty.vim diff --git a/share/vim/vim72/keymap/serbian-latin.vim b/share/vim/vim73/keymap/serbian-latin.vim similarity index 100% rename from share/vim/vim72/keymap/serbian-latin.vim rename to share/vim/vim73/keymap/serbian-latin.vim diff --git a/share/vim/vim72/keymap/serbian-latin_utf-8.vim b/share/vim/vim73/keymap/serbian-latin_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/serbian-latin_utf-8.vim rename to share/vim/vim73/keymap/serbian-latin_utf-8.vim diff --git a/share/vim/vim72/keymap/serbian.vim b/share/vim/vim73/keymap/serbian.vim similarity index 100% rename from share/vim/vim72/keymap/serbian.vim rename to share/vim/vim73/keymap/serbian.vim diff --git a/share/vim/vim72/keymap/serbian_cp1250.vim b/share/vim/vim73/keymap/serbian_cp1250.vim similarity index 100% rename from share/vim/vim72/keymap/serbian_cp1250.vim rename to share/vim/vim73/keymap/serbian_cp1250.vim diff --git a/share/vim/vim72/keymap/serbian_cp1251.vim b/share/vim/vim73/keymap/serbian_cp1251.vim similarity index 100% rename from share/vim/vim72/keymap/serbian_cp1251.vim rename to share/vim/vim73/keymap/serbian_cp1251.vim diff --git a/share/vim/vim72/keymap/serbian_iso-8859-2.vim b/share/vim/vim73/keymap/serbian_iso-8859-2.vim similarity index 100% rename from share/vim/vim72/keymap/serbian_iso-8859-2.vim rename to share/vim/vim73/keymap/serbian_iso-8859-2.vim diff --git a/share/vim/vim72/keymap/serbian_iso-8859-5.vim b/share/vim/vim73/keymap/serbian_iso-8859-5.vim similarity index 100% rename from share/vim/vim72/keymap/serbian_iso-8859-5.vim rename to share/vim/vim73/keymap/serbian_iso-8859-5.vim diff --git a/share/vim/vim72/keymap/serbian_utf-8.vim b/share/vim/vim73/keymap/serbian_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/serbian_utf-8.vim rename to share/vim/vim73/keymap/serbian_utf-8.vim diff --git a/share/vim/vim72/keymap/sinhala-phonetic_utf-8.vim b/share/vim/vim73/keymap/sinhala-phonetic_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/sinhala-phonetic_utf-8.vim rename to share/vim/vim73/keymap/sinhala-phonetic_utf-8.vim diff --git a/share/vim/vim72/keymap/sinhala.vim b/share/vim/vim73/keymap/sinhala.vim similarity index 100% rename from share/vim/vim72/keymap/sinhala.vim rename to share/vim/vim73/keymap/sinhala.vim diff --git a/share/vim/vim72/keymap/slovak.vim b/share/vim/vim73/keymap/slovak.vim similarity index 100% rename from share/vim/vim72/keymap/slovak.vim rename to share/vim/vim73/keymap/slovak.vim diff --git a/share/vim/vim72/keymap/slovak_cp1250.vim b/share/vim/vim73/keymap/slovak_cp1250.vim similarity index 100% rename from share/vim/vim72/keymap/slovak_cp1250.vim rename to share/vim/vim73/keymap/slovak_cp1250.vim diff --git a/share/vim/vim72/keymap/slovak_iso-8859-2.vim b/share/vim/vim73/keymap/slovak_iso-8859-2.vim similarity index 100% rename from share/vim/vim72/keymap/slovak_iso-8859-2.vim rename to share/vim/vim73/keymap/slovak_iso-8859-2.vim diff --git a/share/vim/vim72/keymap/slovak_utf-8.vim b/share/vim/vim73/keymap/slovak_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/slovak_utf-8.vim rename to share/vim/vim73/keymap/slovak_utf-8.vim diff --git a/share/vim/vim72/keymap/tamil_tscii.vim b/share/vim/vim73/keymap/tamil_tscii.vim similarity index 100% rename from share/vim/vim72/keymap/tamil_tscii.vim rename to share/vim/vim73/keymap/tamil_tscii.vim diff --git a/share/vim/vim72/keymap/thaana-phonetic_utf-8.vim b/share/vim/vim73/keymap/thaana-phonetic_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/thaana-phonetic_utf-8.vim rename to share/vim/vim73/keymap/thaana-phonetic_utf-8.vim diff --git a/share/vim/vim72/keymap/thaana.vim b/share/vim/vim73/keymap/thaana.vim similarity index 100% rename from share/vim/vim72/keymap/thaana.vim rename to share/vim/vim73/keymap/thaana.vim diff --git a/share/vim/vim72/keymap/ukrainian-dvorak.vim b/share/vim/vim73/keymap/ukrainian-dvorak.vim similarity index 100% rename from share/vim/vim72/keymap/ukrainian-dvorak.vim rename to share/vim/vim73/keymap/ukrainian-dvorak.vim diff --git a/share/vim/vim72/keymap/ukrainian-jcuken.vim b/share/vim/vim73/keymap/ukrainian-jcuken.vim similarity index 100% rename from share/vim/vim72/keymap/ukrainian-jcuken.vim rename to share/vim/vim73/keymap/ukrainian-jcuken.vim diff --git a/share/vim/vim72/keymap/vietnamese-viqr_utf-8.vim b/share/vim/vim73/keymap/vietnamese-viqr_utf-8.vim similarity index 100% rename from share/vim/vim72/keymap/vietnamese-viqr_utf-8.vim rename to share/vim/vim73/keymap/vietnamese-viqr_utf-8.vim diff --git a/share/vim/vim72/lang/README.txt b/share/vim/vim73/lang/README.txt similarity index 100% rename from share/vim/vim72/lang/README.txt rename to share/vim/vim73/lang/README.txt diff --git a/share/vim/vim72/lang/menu_af.latin1.vim b/share/vim/vim73/lang/menu_af.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_af.latin1.vim rename to share/vim/vim73/lang/menu_af.latin1.vim diff --git a/share/vim/vim72/lang/menu_af.utf-8.vim b/share/vim/vim73/lang/menu_af.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_af.utf-8.vim rename to share/vim/vim73/lang/menu_af.utf-8.vim diff --git a/share/vim/vim72/lang/menu_af_af.latin1.vim b/share/vim/vim73/lang/menu_af_af.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_af_af.latin1.vim rename to share/vim/vim73/lang/menu_af_af.latin1.vim diff --git a/share/vim/vim72/lang/menu_af_af.utf-8.vim b/share/vim/vim73/lang/menu_af_af.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_af_af.utf-8.vim rename to share/vim/vim73/lang/menu_af_af.utf-8.vim diff --git a/share/vim/vim72/lang/menu_ca.latin1.vim b/share/vim/vim73/lang/menu_ca.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_ca.latin1.vim rename to share/vim/vim73/lang/menu_ca.latin1.vim diff --git a/share/vim/vim72/lang/menu_ca.utf-8.vim b/share/vim/vim73/lang/menu_ca.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_ca.utf-8.vim rename to share/vim/vim73/lang/menu_ca.utf-8.vim diff --git a/share/vim/vim72/lang/menu_ca_es.latin1.vim b/share/vim/vim73/lang/menu_ca_es.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_ca_es.latin1.vim rename to share/vim/vim73/lang/menu_ca_es.latin1.vim diff --git a/share/vim/vim72/lang/menu_ca_es.utf-8.vim b/share/vim/vim73/lang/menu_ca_es.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_ca_es.utf-8.vim rename to share/vim/vim73/lang/menu_ca_es.utf-8.vim diff --git a/share/vim/vim72/lang/menu_chinese(gb)_gb.936.vim b/share/vim/vim73/lang/menu_chinese(gb)_gb.936.vim similarity index 100% rename from share/vim/vim72/lang/menu_chinese(gb)_gb.936.vim rename to share/vim/vim73/lang/menu_chinese(gb)_gb.936.vim diff --git a/share/vim/vim72/lang/menu_chinese(taiwan)_taiwan.950.vim b/share/vim/vim73/lang/menu_chinese(taiwan)_taiwan.950.vim similarity index 100% rename from share/vim/vim72/lang/menu_chinese(taiwan)_taiwan.950.vim rename to share/vim/vim73/lang/menu_chinese(taiwan)_taiwan.950.vim diff --git a/share/vim/vim72/lang/menu_chinese_gb.936.vim b/share/vim/vim73/lang/menu_chinese_gb.936.vim similarity index 100% rename from share/vim/vim72/lang/menu_chinese_gb.936.vim rename to share/vim/vim73/lang/menu_chinese_gb.936.vim diff --git a/share/vim/vim72/lang/menu_chinese_taiwan.950.vim b/share/vim/vim73/lang/menu_chinese_taiwan.950.vim similarity index 100% rename from share/vim/vim72/lang/menu_chinese_taiwan.950.vim rename to share/vim/vim73/lang/menu_chinese_taiwan.950.vim diff --git a/share/vim/vim72/lang/menu_cs.cp1250.vim b/share/vim/vim73/lang/menu_cs.cp1250.vim similarity index 100% rename from share/vim/vim72/lang/menu_cs.cp1250.vim rename to share/vim/vim73/lang/menu_cs.cp1250.vim diff --git a/share/vim/vim72/lang/menu_cs.latin1.vim b/share/vim/vim73/lang/menu_cs.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_cs.latin1.vim rename to share/vim/vim73/lang/menu_cs.latin1.vim diff --git a/share/vim/vim72/lang/menu_cs_cz.cp1250.vim b/share/vim/vim73/lang/menu_cs_cz.cp1250.vim similarity index 100% rename from share/vim/vim72/lang/menu_cs_cz.cp1250.vim rename to share/vim/vim73/lang/menu_cs_cz.cp1250.vim diff --git a/share/vim/vim72/lang/menu_cs_cz.iso_8859-2.vim b/share/vim/vim73/lang/menu_cs_cz.iso_8859-2.vim similarity index 100% rename from share/vim/vim72/lang/menu_cs_cz.iso_8859-2.vim rename to share/vim/vim73/lang/menu_cs_cz.iso_8859-2.vim diff --git a/share/vim/vim72/lang/menu_cs_cz.latin1.vim b/share/vim/vim73/lang/menu_cs_cz.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_cs_cz.latin1.vim rename to share/vim/vim73/lang/menu_cs_cz.latin1.vim diff --git a/share/vim/vim72/lang/menu_czech_czech_republic.1250.vim b/share/vim/vim73/lang/menu_czech_czech_republic.1250.vim similarity index 100% rename from share/vim/vim72/lang/menu_czech_czech_republic.1250.vim rename to share/vim/vim73/lang/menu_czech_czech_republic.1250.vim diff --git a/share/vim/vim72/lang/menu_czech_czech_republic.1252.vim b/share/vim/vim73/lang/menu_czech_czech_republic.1252.vim similarity index 100% rename from share/vim/vim72/lang/menu_czech_czech_republic.1252.vim rename to share/vim/vim73/lang/menu_czech_czech_republic.1252.vim diff --git a/share/vim/vim72/lang/menu_czech_czech_republic.ascii.vim b/share/vim/vim73/lang/menu_czech_czech_republic.ascii.vim similarity index 100% rename from share/vim/vim72/lang/menu_czech_czech_republic.ascii.vim rename to share/vim/vim73/lang/menu_czech_czech_republic.ascii.vim diff --git a/share/vim/vim72/lang/menu_de.latin1.vim b/share/vim/vim73/lang/menu_de.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_de.latin1.vim rename to share/vim/vim73/lang/menu_de.latin1.vim diff --git a/share/vim/vim72/lang/menu_de.utf-8.vim b/share/vim/vim73/lang/menu_de.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_de.utf-8.vim rename to share/vim/vim73/lang/menu_de.utf-8.vim diff --git a/share/vim/vim73/lang/menu_de_de.latin1.vim b/share/vim/vim73/lang/menu_de_de.latin1.vim new file mode 100644 index 0000000000..6bfc072484 --- /dev/null +++ b/share/vim/vim73/lang/menu_de_de.latin1.vim @@ -0,0 +1,304 @@ +" Menu Translations: German / Deutsch +" Maintainer: Georg Dahn <gorgyd@yahoo.co.uk> +" Originally By: Marcin Dalecki <dalecki@cs.net.pl> +" Johannes Zellner <johannes@zellner.org> +" Last Change: Sat, 11 Mar 2006 22:40:00 CEST +" vim:set foldmethod=marker tabstop=8: + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 + +" The translations below are in latin1, but they work for cp1252 and +" iso-8859-15 without conversion as well. +if &enc != "cp1252" && &enc != "iso-8859-15" + scriptencoding latin1 +endif + +" {{{ FILE / DATEI +menutrans &File &Datei +menutrans &Open\.\.\.<Tab>:e &Öffnen\.\.\.<Tab>:e +menutrans Sp&lit-Open\.\.\.<Tab>:sp In\ geteiltem\ &Fenster\ öffnen\.\.\.<Tab>:sp +menutrans Open\ Tab\.\.\.<Tab>:tabnew In\ neuem\ &Tab\ öffnen\.\.\.<Tab>:tabnew +menutrans &New<Tab>:enew &Neue\ Datei<Tab>:enew +menutrans &Close<Tab>:close S&chließen<Tab>:close +menutrans &Save<Tab>:w &Speichern<Tab>:w +menutrans Save\ &As\.\.\.<Tab>:sav Speichern\ &als\.\.\.<Tab>:sav +menutrans &Print &Drucken +menutrans Sa&ve-Exit<Tab>:wqa Speichern\ und\ Be&enden<Tab>:wqa +menutrans E&xit<Tab>:qa &Beenden<Tab>:qa + +if has("diff") + menutrans Split\ &Diff\ with\.\.\. D&ifferenz\ in\ geteiltem\ Fenster\ mit\.\.\. + menutrans Split\ Patched\ &By\.\.\. &Patch\ in\ geteiltem\ Fenster\ mit\.\.\. +endif +" }}} FILE / DATEI + +" {{{ EDIT / EDITIEREN +menutrans &Edit &Editieren +menutrans &Undo<Tab>u Z&urück<Tab>u +menutrans &Redo<Tab>^R Vo&r<Tab>^R +menutrans Rep&eat<Tab>\. &Wiederholen<Tab>\. +menutrans Cu&t<Tab>"+x &Ausschneiden<Tab>"+x +menutrans &Copy<Tab>"+y &Kopieren<Tab>"+y +menutrans &Paste<Tab>"+gP Ein&fügen<Tab>"+gP +menutrans Put\ &Before<Tab>[p Da&vor\ einfügen<Tab>[p +menutrans Put\ &After<Tab>]p Da&nach\ einfügen<Tab>]p +menutrans &Delete<Tab>x &Löschen<Tab>x +menutrans &Select\ All<Tab>ggVG Alles\ &markieren<Tab>ggVG +menutrans &Find\.\.\. &Suchen\.\.\. +menutrans Find\ and\ Rep&lace\.\.\. Suchen\ und\ &Ersetzen\.\.\. + +" [-- SETTINGS --] +" XXX &E would conflict with 'Suchen\ und\ &Ersetzen', see above +menutrans Settings\ &Window E&instellungen\.\.\. +menutrans &Global\ Settings &Globale\ Einstellungen +menutrans Startup\ &Settings &Starteinstellungen + +menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! &Hervorhebungen\ ein-\ und\ ausschalten<Tab>:set\ hls! +menutrans Toggle\ &Ignore-case<Tab>:set\ ic! Großschreibung\ &ignorieren\ oder\ benutzen<Tab>:set\ ic! +menutrans Toggle\ &Showmatch<Tab>:set\ sm! Anzeige\ des\ passenden\ &Symbols\ ein-\ und\ ausschalten<Tab>:set\ sm! + +menutrans &Context\ lines &Zusammenhang + +menutrans &Virtual\ Edit &Virtueller\ Editier-Modus +menutrans Never Nie +menutrans Block\ Selection Block-Auswahl +menutrans Insert\ mode Einfüge-Modus +menutrans Block\ and\ Insert Block-Auswahl\ und\ Einfüge-Modus +menutrans Always Immer +menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Einfüge-&Modus\ ein-\ und\ ausschalten<Tab>:set\ im! +menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Vi-Kompatibilität\ ein-\ und\ ausschalten<Tab>:set\ cp! + +menutrans Search\ &Path\.\.\. Such-&Pfad\.\.\. +menutrans Ta&g\ Files\.\.\. Ta&g-Dateien\.\.\. + +menutrans Toggle\ &Toolbar Werkzeugleiste\ ein-\ und\ ausschalten +menutrans Toggle\ &Bottom\ Scrollbar Unteren\ Rollbalken\ ein-\ und\ ausschalten +menutrans Toggle\ &Left\ Scrollbar Linken\ Rollbalken\ ein-\ und\ ausschalten +menutrans Toggle\ &Right\ Scrollbar Rechten\ Rollbalken\ ein-\ und\ ausschalten + +" Edit/File Settings +menutrans F&ile\ Settings &Datei-Einstellungen + +" Boolean options +menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! Anzeige\ der\ Zeilen&nummer\ ein-\ und\ ausschalten<Tab>:set\ nu! +menutrans Toggle\ relati&ve\ Line\ Numbering<Tab>:set\ rnu! Anzeige\ der\ relati&ven\ Zeilennummer\ ein-\ und\ ausschalten<Tab>:set\ rnu! +menutrans Toggle\ &List\ Mode<Tab>:set\ list! &List-Modus\ ein-\ und\ ausschalten<Tab>:set\ list! +menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! &Zeilenumbruch\ ein-\ und\ ausschalten<Tab>:set\ wrap! +menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! Umbruch\ an\ &Wortgrenzen\ ein-\ und\ ausschalten<Tab>:set\ lbr! +menutrans Toggle\ &expand-tab<Tab>:set\ et! &Erweiterung\ von\ Tabulatoren\ ein-\ und\ ausschalten<Tab>:set\ et! +menutrans Toggle\ &auto-indent<Tab>:set\ ai! &Automatische\ Einrückung\ ein-\ und\ ausschalten<Tab>:set\ ai! +menutrans Toggle\ &C-indenting<Tab>:set\ cin! &C-Einrückung\ ein-\ und\ ausschalten<Tab>:set\ cin! + +" other options +menutrans &Shiftwidth &Schiebeweite +menutrans Soft\ &Tabstop &Tabulator +menutrans Te&xt\ Width\.\.\. Te&xtbreite\.\.\. +menutrans &File\ Format\.\.\. &Dateiformat\.\.\. +menutrans C&olor\ Scheme F&arbschema\.\.\. +menutrans &Keymap &Tastaturbelegung +" }}} EDIT / EDITIEREN + +" {{{ TOOLS / WERKZEUGE +if has("spell") + menutrans &Spelling &Rechtschreibung + menutrans &Spell\ Check\ On &Rechtschreibprüfung\ an + menutrans Spell\ Check\ &Off Rechtschreibprüfung\ &aus + menutrans To\ &Next\ error<Tab>]s Zum\ &nächsten\ Fehler<Tab>]s + menutrans To\ &Previous\ error<Tab>[s Zum\ &vorherigen\ Fehler<Tab>[s + menutrans Suggest\ &Corrections<Tab>z= &Korrekturvorschläge<Tab>z= + menutrans &Repeat\ correction<Tab>:spellrepall &Wiederhole\ Korrektur<Tab>:spellrepall + menutrans Set\ language\ to\ "en" Verwende\ Wörterbuch\ "en" + menutrans Set\ language\ to\ "en_au" Verwende\ Wörterbuch\ "en_au" + menutrans Set\ language\ to\ "en_ca" Verwende\ Wörterbuch\ "en_ca" + menutrans Set\ language\ to\ "en_gb" Verwende\ Wörterbuch\ "en_gb" + menutrans Set\ language\ to\ "en_nz" Verwende\ Wörterbuch\ "en_nz" + menutrans Set\ language\ to\ "en_us" Verwende\ Wörterbuch\ "en_us" + menutrans Set\ language\ to\ "de" Verwende\ Wörterbuch\ "de" + menutrans &Find\ More\ Languages &Suche\ nach\ Wörterbüchern +endif +if has("folding") + menutrans &Folding Fa<ung + " open close folds + menutrans &Enable/Disable\ folds<Tab>zi &Ein-\ und\ ausschalten<Tab>zi + menutrans &View\ Cursor\ Line<Tab>zv Momentane\ &Position\ anzeigen<Tab>zv + menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx &Ausschließlich\ momentane\ Position\ anzeigen<Tab>zMzx + menutrans C&lose\ more\ folds<Tab>zm Faltungen\ &schließen<Tab>zm + menutrans &Close\ all\ folds<Tab>zM Alle\ Faltungen\ schließen<Tab>zM + menutrans O&pen\ more\ folds<Tab>zr Faltungen\ &öffnen<Tab>zr + menutrans &Open\ all\ folds<Tab>zR Alle\ Faltungen\ öffnen<Tab>zR + " fold method + menutrans Fold\ Met&hod Faltungs-&Methode + menutrans M&anual &Manuell + menutrans I&ndent &Einrückungen + menutrans E&xpression &Ausdruck + menutrans S&yntax &Syntax + menutrans &Diff &Differenz + menutrans Ma&rker Ma&rkierungen + " create and delete folds + " TODO accelerators + menutrans Create\ &Fold<Tab>zf Faltung\ erzeugen<Tab>zf + menutrans &Delete\ Fold<Tab>zd Faltung\ löschen<Tab>zd + menutrans Delete\ &All\ Folds<Tab>zD Alle\ Faltungen\ löschen<Tab>zD + " moving around in folds + menutrans Fold\ column\ &width &Breite\ der\ Faltungsspalte +endif " has folding + +if has("diff") + menutrans &Diff &Differenz + menutrans &Update &Aktualisieren + menutrans &Get\ Block Block\ &einfügen + menutrans &Put\ Block Block\ &übertragen +endif + +menutrans &Tools &Werkzeuge +menutrans &Jump\ to\ this\ tag<Tab>g^] &Springe\ zum\ Tag<Tab>g^] +menutrans Jump\ &back<Tab>^T Springe\ &zurück<Tab>^T +menutrans Build\ &Tags\ File Erstelle\ &Tag-Datei +menutrans &Make<Tab>:make &Erstellen<Tab>:make +menutrans &List\ Errors<Tab>:cl &Fehler\ anzeigen<Tab>:cl +menutrans L&ist\ Messages<Tab>:cl! &Hinweise\ anzeigen<Tab>:cl! +menutrans &Next\ Error<Tab>:cn Zum\ &nächsten\ Fehler<Tab>:cn +menutrans &Previous\ Error<Tab>:cp Zum\ &vorherigen\ Fehler<Tab>:cp +menutrans &Older\ List<Tab>:cold &Ältere\ Liste<Tab>:cold +menutrans N&ewer\ List<Tab>:cnew &Neuere\ Liste<Tab>:cnew + +menutrans Error\ &Window Feh&ler-Fenster +menutrans Se&t\ Compiler &Compiler +menutrans Se&T\ Compiler &Compiler +menutrans &Update<Tab>:cwin &Aktualisieren<Tab>:cwin +menutrans &Open<Tab>:copen &Öffnen<Tab>:copen +menutrans &Close<Tab>:cclose &Schließen<Tab>:cclose + +menutrans &Convert\ to\ HEX<Tab>:%!xxd Nach\ HE&X\ konvertieren<Tab>:%!xxd +menutrans Conve&rt\ back<Tab>:%!xxd\ -r Zurück\ konvertieren<Tab>:%!xxd\ -r +" }}} TOOLS / WERKZEUGE + +" {{{ SYNTAX / SYNTAX +menutrans &Syntax &Syntax +menutrans &Show\ filetypes\ in\ menu Dateitypen\ an&zeigen +menutrans Set\ '&syntax'\ only Nur\ '&syntax'\ setzen +menutrans Set\ '&filetype'\ too Auch\ '&filetype'\ setzen +menutrans &Off &Aus +menutrans &Manual &Manuell +menutrans A&utomatic A&utomatisch +menutrans on/off\ for\ &This\ file An/Aus (diese\ &Datei) +menutrans Co&lor\ test Test\ der\ Farben +menutrans &Highlight\ test Test\ der\ Un&terstreichungen +menutrans &Convert\ to\ HTML Konvertieren\ nach\ &HTML +" }}} SYNTAX / SYNTAX + +" {{{ BUFFERS / PUFFER +menutrans &Buffers &Puffer +menutrans &Refresh\ menu &Aktualisieren +menutrans Delete Löschen +menutrans &Alternate &Wechseln +menutrans &Next &Nächster +menutrans &Previous &Vorheriger +" }}} BUFFERS / PUFFER + +" {{{ WINDOW / ANSICHT +menutrans &Window &Ansicht +menutrans &New<Tab>^Wn &Neu<Tab>^Wn +menutrans S&plit<Tab>^Ws Aufs&palten<Tab>^Ws +menutrans Split\ &Vertically<Tab>^Wv &Vertikal\ aufspalten<Tab>^Wv +menutrans Split\ File\ E&xplorer Ver&zeichnis +menutrans Sp&lit\ To\ #<Tab>^W^^ Aufspa<en\ in\ #<Tab>^W^^ +menutrans &Close<Tab>^Wc &Schließen<Tab>^Wc +menutrans Close\ &Other(s)<Tab>^Wo &Andere\ schließen<Tab>^Wo +menutrans Ne&xt<Tab>^Ww N&ächstes<Tab>^Ww +menutrans P&revious<Tab>^WW Vor&heriges<Tab>^WW +menutrans &Equal\ Size<Tab>^W= &Gleiche\ Höhen<Tab>^W= +menutrans &Max\ Height<Tab>^W_ &Maximale\ Höhe<Tab>^W_ +menutrans M&in\ Height<Tab>^W1_ M&inimale\ Höhe<Tab>^W1_ +menutrans Max\ &Width<Tab>^W\| Maximale\ &Breite<Tab>^W\| +menutrans Min\ Widt&h<Tab>^W1\| Minimale\ Brei&te<Tab>^W1\| +menutrans Move\ &To V&erschiebe\ nach +menutrans &Top<Tab>^WK &Oben<Tab>^WK +menutrans &Bottom<Tab>^WJ &Unten<Tab>^WJ +menutrans &Left\ side<Tab>^WH &Links<Tab>^WH +menutrans &Right\ side<Tab>^WL &Rechts<Tab>^WL +menutrans Rotate\ &Up<Tab>^WR Rotiere\ nach\ &oben<Tab>^WR +menutrans Rotate\ &Down<Tab>^Wr Rotiere\ nach\ &unten<Tab>^Wr +menutrans Select\ Fo&nt\.\.\. Auswahl\ der\ Schriftart\.\.\. +" }}} WINDOW / ANSICHT + +" {{{ HELP / HILFE +menutrans &Help &Hilfe +menutrans &Overview<Tab><F1> &Überblick<Tab><F1> +menutrans &User\ Manual &Handbuch +menutrans &How-to\ links How-to\ &Index +menutrans &GUI &Graphische\ Oberfläche +menutrans &Credits &Autoren +menutrans Co&pying &Urheberrecht +menutrans O&rphans &Waisen +menutrans &Find\.\.\. &Suchen\.\.\. " conflicts with Edit.Find +menutrans &Version &Version +menutrans &About &Titelseite +" }}} HELP / HILFE + +" {{{ POPUP +menutrans &Undo &Zurück +menutrans Cu&t Aus&schneiden +menutrans &Copy &Kopieren +menutrans &Paste &Einfügen +menutrans &Delete &Löschen +menutrans Select\ Blockwise Auswahl\ blockartig +menutrans Select\ &Word Auswahl\ des\ &Wortes +menutrans Select\ &Sentence Auswahl\ des\ Sa&tzes +menutrans Select\ Pa&ragraph Auswahl\ des\ Absatzes +menutrans Select\ &Line Auswahl\ der\ &Zeile +menutrans Select\ &Block Auswahl\ des\ &Blocks +menutrans Select\ &All &Alles\ Auswählen +" }}} POPUP + +" {{{ TOOLBAR +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open Datei öffnen + tmenu ToolBar.Save Datei speichern + tmenu ToolBar.SaveAll Alle Dateien speichern + tmenu ToolBar.Print Drucken + tmenu ToolBar.Undo Zurück + tmenu ToolBar.Redo Wiederholen + tmenu ToolBar.Cut Ausschneiden + tmenu ToolBar.Copy Kopieren + tmenu ToolBar.Paste Einfügen + tmenu ToolBar.Find Suchen... + tmenu ToolBar.FindNext Suche nächsten + tmenu ToolBar.FindPrev Suche vorherigen + tmenu ToolBar.Replace Suchen und Ersetzen... + if 0 " disabled; These are in the Windows menu + tmenu ToolBar.New Neue Ansicht + tmenu ToolBar.WinSplit Ansicht aufspalten + tmenu ToolBar.WinMax Ansicht maximale Höhen + tmenu ToolBar.WinMin Ansicht minimale Höhen + tmenu ToolBar.WinClose Ansicht schließen + endif + tmenu ToolBar.LoadSesn Sitzung laden + tmenu ToolBar.SaveSesn Sitzung speichern + tmenu ToolBar.RunScript Vim-Skript ausführen + tmenu ToolBar.Make Erstellen + tmenu ToolBar.Shell Shell starten + tmenu ToolBar.RunCtags Erstelle Tag-Datei + tmenu ToolBar.TagJump Springe zum Tag + tmenu ToolBar.Help Hilfe! + tmenu ToolBar.FindHelp Hilfe durchsuchen... + endfun +endif +" }}} TOOLBAR + +" {{{ DIALOG TEXTS +let g:menutrans_no_file = "[Keine Datei]" +let g:menutrans_help_dialog = "Geben Sie einen Befehl oder ein Wort ein, für das Sie Hilfe benötigen:\n\nVerwenden Sie i_ für Eingabe ('input') Befehle (z.B.: i_CTRL-X)\nVerwenden Sie c_ für Befehls-Zeilen ('command-line') Befehle (z.B.: c_<Del>)\nVerwenden Sie ' für Options-Namen (z.B.: 'shiftwidth')" +let g:menutrans_path_dialog = "Geben Sie Such-Pfade für Dateien ein.\nTrennen Sie die Verzeichnis-Namen durch Kommata." +let g:menutrans_tags_dialog = "Geben Sie die Namen der 'tag'-Dateien ein.\nTrennen Sie die Namen durch Kommata." +let g:menutrans_textwidth_dialog = "Geben Sie eine neue Text-Breite ein (oder 0, um die Formatierung abzuschalten)" +let g:menutrans_fileformat_dialog = "Wählen Sie ein Datei-Format aus" +" }}} diff --git a/share/vim/vim72/lang/menu_de_de.utf-8.vim b/share/vim/vim73/lang/menu_de_de.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_de_de.utf-8.vim rename to share/vim/vim73/lang/menu_de_de.utf-8.vim diff --git a/share/vim/vim72/lang/menu_en_gb.latin1.vim b/share/vim/vim73/lang/menu_en_gb.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_en_gb.latin1.vim rename to share/vim/vim73/lang/menu_en_gb.latin1.vim diff --git a/share/vim/vim72/lang/menu_en_gb.utf-8.vim b/share/vim/vim73/lang/menu_en_gb.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_en_gb.utf-8.vim rename to share/vim/vim73/lang/menu_en_gb.utf-8.vim diff --git a/share/vim/vim72/lang/menu_english_united_kingdom.1252.vim b/share/vim/vim73/lang/menu_english_united_kingdom.1252.vim similarity index 100% rename from share/vim/vim72/lang/menu_english_united_kingdom.1252.vim rename to share/vim/vim73/lang/menu_english_united_kingdom.1252.vim diff --git a/share/vim/vim72/lang/menu_english_united_kingdom.ascii.vim b/share/vim/vim73/lang/menu_english_united_kingdom.ascii.vim similarity index 100% rename from share/vim/vim72/lang/menu_english_united_kingdom.ascii.vim rename to share/vim/vim73/lang/menu_english_united_kingdom.ascii.vim diff --git a/share/vim/vim72/lang/menu_eo.utf-8.vim b/share/vim/vim73/lang/menu_eo.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_eo.utf-8.vim rename to share/vim/vim73/lang/menu_eo.utf-8.vim diff --git a/share/vim/vim72/lang/menu_eo_eo.utf-8.vim b/share/vim/vim73/lang/menu_eo_eo.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_eo_eo.utf-8.vim rename to share/vim/vim73/lang/menu_eo_eo.utf-8.vim diff --git a/share/vim/vim72/lang/menu_eo_xx.utf-8.vim b/share/vim/vim73/lang/menu_eo_xx.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_eo_xx.utf-8.vim rename to share/vim/vim73/lang/menu_eo_xx.utf-8.vim diff --git a/share/vim/vim72/lang/menu_es.latin1.vim b/share/vim/vim73/lang/menu_es.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_es.latin1.vim rename to share/vim/vim73/lang/menu_es.latin1.vim diff --git a/share/vim/vim72/lang/menu_es.utf-8.vim b/share/vim/vim73/lang/menu_es.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_es.utf-8.vim rename to share/vim/vim73/lang/menu_es.utf-8.vim diff --git a/share/vim/vim73/lang/menu_es_es.latin1.vim b/share/vim/vim73/lang/menu_es_es.latin1.vim new file mode 100644 index 0000000000..b943e230ad --- /dev/null +++ b/share/vim/vim73/lang/menu_es_es.latin1.vim @@ -0,0 +1,318 @@ +" Menu Translations: Español +" Previous translator: Alejandro López-Valencia <dradul@users.sourceforge.net> +" Last translator: Omar Campagne Polaino <ocampagne@gmail.com> +" Version: 7.2.245 +" Last Change: 2009 Sep 03 +" + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 + +" The translations below are in latin1, but they work for cp1252, +" iso-8859-15 without conversion as well. +if &enc != "cp1252" && &enc != "iso-8859-15" + scriptencoding latin1 +endif + + +" Help menu +menutrans &Help Ay&uda +menutrans &Overview<Tab><F1> Tabla\ de\ &contenidos<Tab><F1> +menutrans &User\ Manual &Manual\ del\ usuario +menutrans &How-to\ links &Enlaces\ a\ ¿Cómo\ hago\.\.\.? +menutrans &Find\.\.\. &Buscar\ en\ la\ ayuda +menutrans &Credits &Reconocimientos +menutrans O&rphans Ayude\ a\ los\ niños\ &huérfanos +menutrans Co&pying &Términos\ de\ Licencia +menutrans Sponsor/Register Benefactor/Regístrese +menutrans &Version &Versión\ e\ \información\ de\ configuración +menutrans &About &Acerca\ de\ Vim + +" File menu +menutrans &File &Archivo +menutrans &Open\.\.\.<Tab>:e &Abrir\.\.\.<Tab>:e +menutrans Sp&lit-Open\.\.\.<Tab>:sp A&brir\ en\ otra\ ventana\.\.\.<Tab>:sp +menutrans &New<Tab>:enew &Nuevo<Tab>:enew +menutrans Open\ Tab\.\.\.<Tab>:tabnew Abrir\ pes&taña\.\.\.<Tab>:tabnew +menutrans &Close<Tab>:close &Cerrar<Tab>:close +menutrans &Save<Tab>:w &Guardar<Tab>:w +menutrans Save\ &As\.\.\.<Tab>:sav Guardar\ &como\.\.\.<Tab>:sav +menutrans Split\ &Diff\ with\.\.\. &Mostrar\ diferencias\ con\.\.\. +menutrans Split\ Patched\ &By\.\.\. Mostrar\ &parcheado\ por\.\.\. +menutrans &Print &Imprimir +menutrans Sa&ve-Exit<Tab>:wqa Gua&rdar\ y\ salir<Tab>:wqa +menutrans E&xit<Tab>:qa &Salir<Tab>:qa + +" Edit menu +menutrans &Edit &Editar +menutrans &Undo<Tab>u &Deshacer<Tab>u +menutrans &Redo<Tab>^R &Rehacer<Tab>^R +menutrans Rep&eat<Tab>\. Repe&tir<Tab>\. +menutrans Cu&t<Tab>"+x Cor&tar<Tab>"+x +menutrans &Copy<Tab>"+y &Copiar<Tab>"+y +menutrans &Paste<Tab>"+gP &Pegar<Tab>"+gP +menutrans Put\ &Before<Tab>[p Poner\ &antes<Tab>[p +menutrans Put\ &After<Tab>]p Poner\ &después<Tab>]p +if has("win32") || has("win16") + menutrans &Delete<Tab>x S&uprimir<Tab>x +endif +menutrans &Select\ all<Tab>ggVG &Seleccionar\ todo<Tab>ggVG +menutrans &Find\.\.\. &Buscar\.\.\. +menutrans &Find<Tab>/ &Buscar<Tab>/ +menutrans Find\ and\ Rep&lace\.\.\. Buscar\ y\ R&eemplazar\.\.\. +menutrans Find\ and\ Rep&lace<Tab>:%s Buscar\ y\ R&eemplazar<Tab>:%s +menutrans Find\ and\ Rep&lace Buscar\ y\ R&eemplazar +menutrans Find\ and\ Rep&lace<Tab>:s Buscar\ y\ R&eemplazar<Tab>:s +menutrans Settings\ &Window &Ventana\ de\ opciones +menutrans Startup\ &Settings Opciones\ de\ arranque + +" Edit/Global Settings +menutrans &Global\ Settings Opciones\ &globales + +menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! Activar/Desactivar\ &resaltado\ de\ sintaxis<Tab>:set\ hls! +menutrans Toggle\ &Ignore-case<Tab>:set\ ic! Activar/Desactivar\ &ignorar\ mayúsculas\ y\ minúsculas<Tab>:set\ ic! +menutrans Toggle\ &Showmatch<Tab>:set\ sm! Activar/Desactivar\ &mostrar\ coincidencias<Tab>:set\ sm! + +menutrans &Context\ lines Líneas\ de\ &contexto + +menutrans &Virtual\ Edit Edición\ &virtual +menutrans Never Nunca +menutrans Block\ Selection Selección\ de\ bloque +menutrans Insert\ mode Modo\ de\ inserción +menutrans Block\ and\ Insert Bloque\ e\ inserción +menutrans Always Siempre + +menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Activar/Desactivar\ modo\ de\ in&serción<Tab>:set\ im! +menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Activar/Desactivar\ compatiblidad\ con\ Vi<Tab>:set\ cp! + +menutrans Search\ &Path\.\.\. Ruta\ de\ &búsqueda\.\.\. + +menutrans Ta&g\ Files\.\.\. Ficheros\ de\ &etiquetas\.\.\. + +" GUI options +menutrans Toggle\ &Toolbar Ocultar/Mostrar\ barra\ de\ &herramientas +menutrans Toggle\ &Bottom\ Scrollbar Ocultar/Mostrar\ barra\ de\ desplazamiento\ &inferior +menutrans Toggle\ &Left\ Scrollbar Ocultar/Mostrar\ barra\ de\ desplazamiento\ i&zquierda +menutrans Toggle\ &Right\ Scrollbar Ocultar/Mostrar\ barra\ de\ desplazamiento\ &derecha + +let g:menutrans_path_dialog = "Introduzca la ruta de búsqueda para los archivos.\nSepare los nombres de los directorios con una coma." +let g:menutrans_tags_dialog = "Introduzca los nombres de los archivos de tags.\nSepare los nombres con una coma." + +" Edit/File Settings +menutrans F&ile\ Settings Opciones\ del\ &archivo + +" Boolean options +menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! Activar/Desactivar\ &numeración\ de\ líneas<Tab>:set\ nu! +menutrans Toggle\ &List\ Mode<Tab>:set\ list! Activar/Desactivar\ modo\ de\ lista<Tab>:set\ list! +menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! Activar/Desactivar\ &quiebre\ de\ líneas<Tab>:set\ wrap! +menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! Activar/Desactivar\ quiebre\ entre\ &palabras<Tab>:set\ lbr! +menutrans Toggle\ &expand-tab<Tab>:set\ et! Activar/Desactivar\ &expansión\ de\ marcas\ de\ \tabulado<Tab>:set\ et! +menutrans Toggle\ &auto-indent<Tab>:set\ ai! Activar/Desactivar\ &auto-sangrado<Tab>:set\ ai! +menutrans Toggle\ &C-indenting<Tab>:set\ cin! Activar/Desactivar\ sangrado\ &C<Tab>:set\ cin! + +" other options +menutrans &Shiftwidth Anchura\ del\ &sangrado + +menutrans Soft\ &Tabstop &Tabulado\ «blando» + +menutrans Te&xt\ Width\.\.\. Anchura\ del\ te&xto\.\.\. +let g:menutrans_textwidth_dialog = "Introduzca el nuevo ancho del texto (0 para desactivar el quiebre de línea): " + +menutrans &File\ Format\.\.\. &Formato\ del\ archivo\.\.\. +let g:menutrans_fileformat_dialog = "Seleccione el formato para escribir el archivo" + +menutrans C&olor\ Scheme Esquema\ de\ c&olores +menutrans blue azul +menutrans darkblue azul\ oscuro +menutrans default original +menutrans desert desierto +menutrans evening vespertino +menutrans morning matutino +menutrans peachpuff melocotón +menutrans shine brillante + +menutrans Select\ Fo&nt\.\.\. Seleccionar\ fue&nte\.\.\. + +menutrans &Keymap Asociación\ de\ teclados +menutrans None Ninguna +menutrans accents acentos +menutrans arabic árabe +menutrans czech checo +menutrans greek griego +menutrans hebrew hebreo +menutrans hebrewp hebreo\ fonético +menutrans lithuanian-baltic lituano-báltico +menutrans russian-jcuken ruso-«jcuken» +menutrans russian-jcukenwin ruso-«jcuken»\ Windows +menutrans russian-yawerty ruso-«yawerty» +menutrans serbian-latin serbio-latino +menutrans serbian serbio +menutrans slovak eslovaco + + +" Programming menu +menutrans &Tools &Herramientas +menutrans &Jump\ to\ this\ tag<Tab>g^] &Saltar\ a\ este\ etiqueta<Tab>g^] +menutrans Jump\ &back<Tab>^T Saltar\ &atrás<Tab>^T +menutrans Build\ &Tags\ File Crear\ archivo\ de\ &etiquetas\ +menutrans &Diff Modo\ de\ &diferencias +menutrans &Folding &Plegado +menutrans &Make<Tab>:make Ejecutar\ «&Make»<Tab>:make +menutrans &List\ Errors<Tab>:cl &Lista\ de\ errores<Tab>:cl +menutrans L&ist\ Messages<Tab>:cl! L&ista\ de\ mensajes<Tab>:cl! +menutrans &Next\ Error<Tab>:cn &Error\ siguiente<Tab>:cn +menutrans &Previous\ Error<Tab>:cp Error\ p&revio<Tab>:cp +menutrans &Older\ List<Tab>:cold Lista\ de\ &viejos\ a\ nuevos<Tab>:cold +menutrans N&ewer\ List<Tab>:cnew Lista\ de\ &nuevos\ a\ viejos<Tab>:cnew +menutrans Error\ &Window Ven&tana\ de\ errores +menutrans &Set\ Compiler Esco&ger\ el\ compilador\ a\ usar +menutrans &Convert\ to\ HEX<Tab>:%!xxd Convertir\ a\ formato\ &hexadecimal<Tab>:%!xxd +menutrans Conve&rt\ back<Tab>:%!xxd\ -r &Convertir\ al\ formato\ original<Tab>:%!xxd\ -r + +" Tools.Spelling Menu +menutrans &Spelling Corrección\ ortográfica +menutrans &Spell\ Check\ On &Activar\ corrección\ ortográfica +menutrans Spell\ Check\ &Off &Desactivar\ corrección\ ortográfica +menutrans To\ &Next\ error<Tab>]s &Siguiente\ error<Tab>]s +menutrans To\ &Previous\ error<Tab>[s Error\ &precedente<Tab>[s +menutrans Suggest\ &Corrections<Tab>z= Sugerir\ &corrección<Tab>z= +menutrans &Repeat\ correction<Tab>:spellrepall &Repetir\ corrección<Tab>:spellrepall +an 40.335.205 &Tools.&Spelling.Castellano\ (es) :set spl=es spell<CR> +menutrans Set\ language\ to\ "en" Inglés +menutrans Set\ language\ to\ "en_au" Inglés\ (en_au) +menutrans Set\ language\ to\ "en_ca" Inglés\ (en_ca) +menutrans Set\ language\ to\ "en_gb" Inglés\ (en_gb) +menutrans Set\ language\ to\ "en_nz" Inglés\ (en_nz) +menutrans Set\ language\ to\ "en_us" Inglés\ (en_us) + +menutrans &Find\ More\ Languages &Buscar\ otras\ lenguas + +" Tools.Fold Menu +menutrans &Enable/Disable\ folds<Tab>zi &Activar/Desactivar\ pliegues<Tab>zi +menutrans &View\ Cursor\ Line<Tab>zv &Ver\ línea\ del\ cursor<Tab>zv +menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx Ve&r\ sólo\ la\ línea\ del\ cursor<Tab>zMzx +menutrans C&lose\ more\ folds<Tab>zm C&errar\ más\ pliegues<Tab>zm +menutrans &Close\ all\ folds<Tab>zM &Cerrar\ todos\ los\ pliegues<Tab>zM +menutrans O&pen\ more\ folds<Tab>zr Abrir\ &más\ pliegues<Tab>zr +menutrans &Open\ all\ folds<Tab>zR &Abrir\ todos\ los\ pliegues<Tab>zR +" fold method +menutrans Fold\ Met&hod &Método\ de\ plegado +" create and delete folds +menutrans Create\ &Fold<Tab>zf Crear\ &pliegue<Tab>zf +menutrans &Delete\ Fold<Tab>zd &Suprimir\ pliegue<Tab>zd +menutrans Delete\ &All\ Folds<Tab>zD Suprimir\ &todos\ los\ pliegues<Tab>zD +" moving around in folds +menutrans Fold\ col&umn\ width A&nchura\ de\ columna\ del\ pliegue + +" Tools.Diff Menu +menutrans &Update &Actualizar +menutrans &Get\ Block &Obtener\ bloque +menutrans &Put\ Block &Poner\ bloque + +"Tools.Error Menu +menutrans &Update<Tab>:cwin &Actualizar +menutrans &Open<Tab>:copen A&brir +menutrans &Close<Tab>:cclose &Cerrar + +" Names for buffer menu. +menutrans &Buffers &Buffers +menutrans &Refresh\ menu &Refrescar\ menú +menutrans &Delete &Suprimir +menutrans &Alternate &Alternar +menutrans &Next Si&guiente +menutrans &Previous &Previo +let g:menutrans_no_file = "[Sin archivo]" + +" Window menu +menutrans &Window &Ventana +menutrans &New<Tab>^Wn Ventana\ &nueva<Tab>^Wn +menutrans S&plit<Tab>^Ws &Dividir\ la\ ventana<Tab>^Ws +menutrans Sp&lit\ To\ #<Tab>^W^^ D&ividir\ en\ el\ marcador\ (#)<Tab>^W^^ +menutrans Split\ &Vertically<Tab>^Wv Dividir\ &verticalmente<Tab>^Wv +menutrans Split\ File\ E&xplorer &Abrir\ el\ «Explorador\ de\ archivos» +menutrans &Close<Tab>^Wc &Cerrar\ esta\ ventana<Tab>^Wc +menutrans Close\ &Other(s)<Tab>^Wo Cerrar\ &otra(s)\ ventana(s)<Tab>^Wo +menutrans Move\ &To Mov&er\ a +menutrans &Top<Tab>^WK &Arriba<Tab>^WK +menutrans &Bottom<Tab>^WJ A&bajo<Tab>^WJ +menutrans &Left\ side<Tab>^WH Lado\ &izquierdo<Tab>^WH +menutrans &Right\ side<Tab>^WL Lado\ &derecho<Tab>^WL +menutrans Rotate\ &Up<Tab>^WR &Rotar\ hacia\ arriba<Tab>^WR +menutrans Rotate\ &Down<Tab>^Wr Rotar\ hacia\ a&bajo<Tab>^Wr +menutrans &Equal\ Size<Tab>^W= Mismo\ &tamaño<Tab>^W= +menutrans &Max\ Height<Tab>^W_ Altura\ &máxima<Tab>^W_ +menutrans M&in\ Height<Tab>^W1_ Altura\ mí&nima<Tab>^W1_ +menutrans Max\ &Width<Tab>^W\| Anchura\ má&xima<Tab>^W\| +menutrans Min\ Widt&h<Tab>^W1\| Anc&hura\ mínima<Tab>^W1\| + +" The popup menu +menutrans &Undo &Deshacer +menutrans Cu&t Cor&tar +menutrans &Copy &Copiar +menutrans &Paste &Pegar +menutrans &Delete &Borrar +menutrans Select\ Blockwise Seleccionar\ por\ bloque +menutrans Select\ &Word Seleccionar\ &palabra +menutrans Select\ &Line Seleccionar\ una\ &línea +menutrans Select\ &Block Seleccionar\ un\ &bloque +menutrans Select\ &All Seleccionar\ &todo + +" The GUI toolbar +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open Abrir archivo + tmenu ToolBar.Save Guardar archivo + tmenu ToolBar.SaveAll Guardar todos los archivos + tmenu ToolBar.Print Imprimir + tmenu ToolBar.Undo Deshacer + tmenu ToolBar.Redo Rehacer + tmenu ToolBar.Cut Cortar + tmenu ToolBar.Copy Copiar + tmenu ToolBar.Paste Pegar + tmenu ToolBar.Find Buscar... + tmenu ToolBar.FindNext Buscar siguiente + tmenu ToolBar.FindPrev Buscar precedente + tmenu ToolBar.Replace Buscar y reemplazar + if 0 " disabled; These are in the Windows menu + tmenu ToolBar.New Ventana nueva + tmenu ToolBar.WinSplit Dividir ventana + tmenu ToolBar.WinMax Altura máxima + tmenu ToolBar.WinMin Altura mínima + tmenu ToolBar.WinVSplit Dividir verticalmente + tmenu ToolBar.WinMaxWidth Anchura máxima + tmenu ToolBar.WinMinWidth Anchura mínima + tmenu ToolBar.WinClose Cerrar ventana + endif + tmenu ToolBar.LoadSesn Cargar sesión + tmenu ToolBar.SaveSesn Guardar sesión + tmenu ToolBar.RunScript Ejecutar un archivo de órdenes + tmenu ToolBar.Make Ejecutar «Make» + tmenu ToolBar.Shell Abrir un intérprete de comandos + tmenu ToolBar.RunCtags Generar un archivo de etiquetas + tmenu ToolBar.TagJump Saltar a una etiqueta + tmenu ToolBar.Help Ayuda + tmenu ToolBar.FindHelp Buscar en la ayuda... + endfun +endif + +" Syntax menu +menutrans &Syntax &Sintaxis +menutrans &Show\ filetypes\ in\ menu &Mostrar\ listas\ de\ «tipo\ de\ archivo» +menutrans Set\ '&syntax'\ only Activar\ sólo\ sintaxis +menutrans Set\ '&filetype'\ too Activar\ también\ «tipo\ de\ archivo» +menutrans &Off &Desactivar\ sintaxis +menutrans &Manual Sintaxis\ &manual +menutrans A&utomatic Sintaxis\ a&utomática +menutrans on/off\ for\ &This\ file Activar/Desactivar\ en\ es&te\ archivo +menutrans Co&lor\ test &Prueba\ de\ colores +menutrans &Highlight\ test Prueba\ de\ &resaltado +menutrans &Convert\ to\ HTML &Convertir\ a\ HTML + +" Find Help dialog text +let g:menutrans_help_dialog = "Introduzca un nombre de comando o palabra para obtener ayuda;\n\nAnteponga i_ para comandos de entrada (e.g.: i_CTRL-X)\nAnteponga c_ para comandos de la línea de comandos (e.g.: c_<Del>)\nAnteponga ` para un nombre de opción (e.g.: `shiftwidth`)" diff --git a/share/vim/vim72/lang/menu_es_es.utf-8.vim b/share/vim/vim73/lang/menu_es_es.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_es_es.utf-8.vim rename to share/vim/vim73/lang/menu_es_es.utf-8.vim diff --git a/share/vim/vim72/lang/menu_fi.latin1.vim b/share/vim/vim73/lang/menu_fi.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_fi.latin1.vim rename to share/vim/vim73/lang/menu_fi.latin1.vim diff --git a/share/vim/vim72/lang/menu_fi.utf-8.vim b/share/vim/vim73/lang/menu_fi.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_fi.utf-8.vim rename to share/vim/vim73/lang/menu_fi.utf-8.vim diff --git a/share/vim/vim72/lang/menu_fi_fi.latin1.vim b/share/vim/vim73/lang/menu_fi_fi.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_fi_fi.latin1.vim rename to share/vim/vim73/lang/menu_fi_fi.latin1.vim diff --git a/share/vim/vim72/lang/menu_fi_fi.utf-8.vim b/share/vim/vim73/lang/menu_fi_fi.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_fi_fi.utf-8.vim rename to share/vim/vim73/lang/menu_fi_fi.utf-8.vim diff --git a/share/vim/vim72/lang/menu_finnish_finland.1252.vim b/share/vim/vim73/lang/menu_finnish_finland.1252.vim similarity index 100% rename from share/vim/vim72/lang/menu_finnish_finland.1252.vim rename to share/vim/vim73/lang/menu_finnish_finland.1252.vim diff --git a/share/vim/vim72/lang/menu_fr.latin1.vim b/share/vim/vim73/lang/menu_fr.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_fr.latin1.vim rename to share/vim/vim73/lang/menu_fr.latin1.vim diff --git a/share/vim/vim72/lang/menu_fr.utf-8.vim b/share/vim/vim73/lang/menu_fr.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_fr.utf-8.vim rename to share/vim/vim73/lang/menu_fr.utf-8.vim diff --git a/share/vim/vim72/lang/menu_fr_fr.latin1.vim b/share/vim/vim73/lang/menu_fr_fr.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_fr_fr.latin1.vim rename to share/vim/vim73/lang/menu_fr_fr.latin1.vim diff --git a/share/vim/vim72/lang/menu_fr_fr.utf-8.vim b/share/vim/vim73/lang/menu_fr_fr.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_fr_fr.utf-8.vim rename to share/vim/vim73/lang/menu_fr_fr.utf-8.vim diff --git a/share/vim/vim72/lang/menu_french_france.1252.vim b/share/vim/vim73/lang/menu_french_france.1252.vim similarity index 100% rename from share/vim/vim72/lang/menu_french_france.1252.vim rename to share/vim/vim73/lang/menu_french_france.1252.vim diff --git a/share/vim/vim72/lang/menu_german_germany.1252.vim b/share/vim/vim73/lang/menu_german_germany.1252.vim similarity index 100% rename from share/vim/vim72/lang/menu_german_germany.1252.vim rename to share/vim/vim73/lang/menu_german_germany.1252.vim diff --git a/share/vim/vim72/lang/menu_hu.iso_8859-2.vim b/share/vim/vim73/lang/menu_hu.iso_8859-2.vim similarity index 100% rename from share/vim/vim72/lang/menu_hu.iso_8859-2.vim rename to share/vim/vim73/lang/menu_hu.iso_8859-2.vim diff --git a/share/vim/vim72/lang/menu_hu.utf-8.vim b/share/vim/vim73/lang/menu_hu.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_hu.utf-8.vim rename to share/vim/vim73/lang/menu_hu.utf-8.vim diff --git a/share/vim/vim72/lang/menu_hu_hu.iso_8859-2.vim b/share/vim/vim73/lang/menu_hu_hu.iso_8859-2.vim similarity index 100% rename from share/vim/vim72/lang/menu_hu_hu.iso_8859-2.vim rename to share/vim/vim73/lang/menu_hu_hu.iso_8859-2.vim diff --git a/share/vim/vim72/lang/menu_hu_hu.utf-8.vim b/share/vim/vim73/lang/menu_hu_hu.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_hu_hu.utf-8.vim rename to share/vim/vim73/lang/menu_hu_hu.utf-8.vim diff --git a/share/vim/vim72/lang/menu_it.latin1.vim b/share/vim/vim73/lang/menu_it.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_it.latin1.vim rename to share/vim/vim73/lang/menu_it.latin1.vim diff --git a/share/vim/vim72/lang/menu_it.utf-8.vim b/share/vim/vim73/lang/menu_it.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_it.utf-8.vim rename to share/vim/vim73/lang/menu_it.utf-8.vim diff --git a/share/vim/vim73/lang/menu_it_it.latin1.vim b/share/vim/vim73/lang/menu_it_it.latin1.vim new file mode 100644 index 0000000000..5a87bf00b2 --- /dev/null +++ b/share/vim/vim73/lang/menu_it_it.latin1.vim @@ -0,0 +1,351 @@ +" Menu Translations: Italian / Italiano +" Maintainer: Antonio Colombo <azc100@gmail.com> +" Vlad Sandrini <vlad.gently@gmail.com> +" Luciano Montanaro <mikelima@cirulla.net> +" Last Change: 2010 Ago 13 + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 + +scriptencoding iso-8859-1 + +" Help / Aiuto +menut &Help &Aiuto +menut &Overview<Tab><F1> &Panoramica<Tab><F1> +menut &User\ Manual Manuale\ &Utente +menut &How-to\ links Co&Me\.\.\. +"menut &GUI &GUI +menut &Credits Cr&Editi +menut Co&pying C&Opie +menut &Sponsor/Register &Sponsor/registrazione +menut O&rphans O&Rfani +"menut &Find\.\.\. &Cerca\.\.\. +"NOTA: fa conflitto con 'cerca' nel menu 'modifica' +menut &Version &Versione +menut &About &Intro + +let g:menutrans_help_dialog = "Batti un comando o una parola per cercare aiuto:\n\nPremetti i_ per comandi in modo Input (ad.es.: i_CTRL-X)\nPremetti c_ per comandi che editano la linea-comandi (ad.es.: c_<Del>)\nPremetti ' per un nome di opzione (ad.es.: 'shiftwidth')" + +" File menu +"menut &File &File +" +menut &Open\.\.\.<Tab>:e &Apri\.\.\.<Tab>:e +menut Sp&lit-Open\.\.\.<Tab>:sp A&Pri\ nuova\ finestra\.\.\.<Tab>:sp +menut Open\ Tab\.\.\.<Tab>:tabnew Apri\ nuova\ &Linguetta\.\.\.<Tab>:tabnew +menut &New<Tab>:enew &Nuovo<Tab>:enew +menut &Close<Tab>:close &Chiudi<Tab>:close +menut &Save<Tab>:w &Salva<Tab>:w +menut Save\ &As\.\.\.<Tab>:sav Salva\ &Con\ nome\.\.\.<Tab>:sav + +if has("diff") + menut Split\ &Diff\ with\.\.\. Finestra\ &Differenza\ con\.\.\. + menut Split\ Patched\ &By\.\.\. Finestra\ patc&H\ da\.\.\. +endif + +menut &Print S&tampa +menut Sa&ve-Exit<Tab>:wqa Sa&Lva\ ed\ esci<Tab>:wqa +menut E&xit<Tab>:qa &Esci<Tab>:qa + +" Edit / Modifica + +menut &Edit &Modifica +menut &Undo<Tab>u &Annulla<Tab>u +menut &Redo<Tab>^R &Ripristina<Tab>^R +menut Rep&eat<Tab>\. Ri&Peti<Tab>\. +menut Cu&t<Tab>"+x &Taglia<Tab>"+x +menut &Copy<Tab>"+y &Copia<Tab>"+y +menut &Paste<Tab>"+gP &Incolla<Tab>"+gP +menut Put\ &Before<Tab>[p &Metti\ davanti<Tab>[p +menut Put\ &After<Tab>]p M&Etti\ dietro<Tab>]p +menut &Delete<Tab>x Cance&Lla<Tab>x +menut &Select\ all<Tab>ggVG Seleziona\ &Tutto<Tab>ggVG +menut &Select\ All<Tab>ggVG Seleziona\ &Tutto<Tab>ggVG +menut &Find\.\.\. &Cerca\.\.\. +menut Find\ and\ Rep&lace\.\.\. &Sostituisci\.\.\. +menut Settings\ &Window &Finestra\ impostazioni +menut Startup\ &Settings Impostazioni\ di\ &Avvio +menut &Global\ Settings Impostazioni\ &Globali +menut Question Domanda + +" Edit / Modifica Impostazioni Globali +menut &Global\ Settings Impostazioni\ &Globali +menut Toggle\ Pattern\ &Highlight<Tab>:set\ hls! &Evidenzia\ ricerche\ Sì/No<Tab>:set\ hls! +menut Toggle\ &Ignore-case<Tab>:set\ ic! &Ignora\ maiusc\.-minusc\.\ Sì/No<Tab>:set\ ic! +menut Toggle\ &Showmatch<Tab>:set\ sm! Indica\ &Corrispondente\ Sì/No<Tab>:set\ sm! + +menut &Context\ lines &Linee\ di\ contesto +menut &Virtual\ Edit &Edit\ virtuale + +menut Never Mai +menut Block\ Selection Selezione\ blocco +menut Insert\ mode Modo\ insert +menut Block\ and\ Insert Selezione\ blocco+inserimento +menut Always Sempre + +menut Toggle\ Insert\ &Mode<Tab>:set\ im! &Modo\ insert\ Sì/No<Tab>:set\ im! +menut Toggle\ Vi\ C&ompatible<Tab>:set\ cp! C&Ompatibile\ VI\ Sì/No<Tab>:set\ cp! +menut Search\ &Path\.\.\. &Percorso\ di\ ricerca\.\.\. +menut Ta&g\ Files\.\.\. File\ ta&G\.\.\. +" +" Opzioni GUI +menut Toggle\ &Toolbar Barra\ s&Trumenti\ Sì/No +menut Toggle\ &Bottom\ Scrollbar Barra\ scorrimento\ in\ &Fondo\ Sì/No +menut Toggle\ &Left\ Scrollbar Barra\ scorrimento\ a\ &Sinistra\ Sì/No +menut Toggle\ &Right\ Scrollbar Barra\ scorrimento\ a\ &Destra\ Sì/No + +let g:menutrans_path_dialog = "Batti percorso di ricerca per i file.\nSepara fra loro i nomi di directory con una virgola." +let g:menutrans_tags_dialog = "Batti nome dei file di tag.\nSepara fra loro i nomi di directory con una virgola." + +" Edit / Impostazioni File +menut F&ile\ Settings &Impostazioni\ file + +" Boolean options +menut Toggle\ Line\ &Numbering<Tab>:set\ nu! &Numerazione\ \ Sì/No<Tab>:set\ nu! +menut Toggle\ relati&ve\ Line\ Numbering<Tab>:set\ rnu! Numerazione\ relati&Va\ Sì/No<Tab>:set\ rnu! +menut Toggle\ &List\ Mode<Tab>:set\ list! Modo\ &List\ Sì/No<Tab>:set\ list! +menut Toggle\ Line\ &Wrap<Tab>:set\ wrap! Linee\ &Continuate\ Sì/No<Tab>:set\ wrap! +menut Toggle\ W&rap\ at\ word<Tab>:set\ lbr! A\ capo\ alla\ &Parola\ Sì/No<Tab>:set\ lbr! +menut Toggle\ &expand-tab<Tab>:set\ et! &Espandi\ tabulazione\ Sì/No<Tab>:set\ et! +menut Toggle\ &auto-indent<Tab>:set\ ai! Indentazione\ &Automatica\ Sì/No<Tab>:set ai! +menut Toggle\ &C-indenting<Tab>:set\ cin! Indentazione\ stile\ &C\ Sì/No<Tab>:set cin! + +" altre opzioni +menut &Shiftwidth &Spazi\ rientranza +menut Soft\ &Tabstop &Tabulazione\ software +menut Te&xt\ Width\.\.\. Lunghe&Zza\ riga\.\.\. +menut &File\ Format\.\.\. Formato\ &File\.\.\. + +let g:menutrans_textwidth_dialog = "Batti nuova lunghezza linea (0 per inibire la formattazione): " + +let g:menutrans_fileformat_dialog = "Scegli formato con cui scrivere il file" + +menut C&olor\ Scheme Schema\ c&Olori + +menut default normale +menut DEFAULT NORMALE +menut evening notturno +menut EVENING NOTTURNO +menut morning diurno +menut MORNING DIURNO +menut shine brillante +menut SHINE BRILLANTE +menut peachpuff pesca +menut PEACHPUF PESCA + +menut &Keymap &Mappa\ tastiera + +menut None nessuna +menut accents accenti +menut ACCENTS ACCENTI +menut hebrew ebraico +menut HEBREW EBRAICO +menut hebrew_iso-8859-8 ebraico_iso-8859-8 +menut hebrew_cp1255 ebraico_cp1255 +menut hebrew_utf-8 ebraico_utf-8 +menut hebrewp_iso-8859-8 ebraico_p_iso-8859-8 +menut HEBREW- EBRAICO+ +menut hebrewp EBRAICOP +menut HEBREWP EBRAICOP +menut russian-jcuken cirillico-jcuken +menut russian-jcukenwin cirillico-jcuken-win +menut RUSSIAN CIRILLICO +menut RUSSIAN- CIRILLICO- + +menut Select\ Fo&nt\.\.\. Scegli\ &Font\.\.\. + +" Menu strumenti programmazione +menut &Tools &Strumenti + +menut &Jump\ to\ this\ tag<Tab>g^] &Vai\ a\ questa\ tag<Tab>g^] +menut Jump\ &back<Tab>^T Torna\ &Indietro<Tab>^T +menut Build\ &Tags\ File Costruisci\ file\ &Tags\ + +" Menu ortografia / Spelling +menut &Spelling &Ortografia + +menut &Spell\ Check\ On Attiva\ &Controllo\ ortografico +menut Spell\ Check\ &Off &Disattiva\ controllo\ ortografico +menut To\ &Next\ error<Tab>]s Errore\ &Seguente<tab>]s +menut To\ &Previous\ error<Tab>[s Errore\ &Precedente<tab>[s +menut Suggest\ &Corrections<Tab>z= &Suggerimenti<Tab>z= +menut &Repeat\ correction<Tab>:spellrepall &Ripeti\ correzione<Tab>:spellrepall +menut Set\ language\ to\ "en" Imposta\ lingua\ a\ "en" +menut Set\ language\ to\ "en_au" Imposta\ lingua\ a\ "en_au" +menut Set\ language\ to\ "en_ca" Imposta\ lingua\ a\ "en_ca" +menut Set\ language\ to\ "en_gb" Imposta\ lingua\ a\ "en_gb" +menut Set\ language\ to\ "en_nz" Imposta\ lingua\ a\ "en_nz" +menut Set\ language\ to\ "en_us" Imposta\ lingua\ a\ "en_us" +menut Set\ language\ to\ "it" Imposta\ lingua\ a\ "it" +menut Set\ language\ to\ "it_it" Imposta\ lingua\ a\ "it_it" +menut Set\ language\ to\ "it_ch" Imposta\ lingua\ a\ "it_ch" +menut &Find\ More\ Languages &Trova\ altre\ lingue + +" Menu piegature / Fold +if has("folding") + menut &Folding &Piegature + " apri e chiudi piegature + menut &Enable/Disable\ folds<Tab>zi Pi&egature\ Sì/No<Tab>zi + menut &View\ Cursor\ Line<Tab>zv &Vedi\ linea\ col\ Cursore<Tab>zv + menut Vie&w\ Cursor\ Line\ only<Tab>zMzx Vedi\ &Solo\ linea\ col\ Cursore<Tab>zMzx + menut C&lose\ more\ folds<Tab>zm C&Hiudi\ più\ piegature<Tab>zm + menut &Close\ all\ folds<Tab>zM &Chiudi\ tutte\ le\ piegature<Tab>zM + menut O&pen\ more\ folds<Tab>zr A&Pri\ più\ piegature<Tab>zr + menut &Open\ all\ folds<Tab>zR &Apri\ tutte\ le\ piegature<Tab>zR + " metodo piegatura + menut Fold\ Met&hod Meto&Do\ piegatura + menut M&anual &Manuale + menut I&ndent &Nidificazione + menut E&xpression &Espressione\ Reg\. + menut S&yntax &Sintassi + menut &Diff &Differenza + menut Ma&rker Mar&Catura + " crea e cancella piegature + menut Create\ &Fold<Tab>zf Crea\ &Piegatura<Tab>zf + menut &Delete\ Fold<Tab>zd &Leva\ piegatura<Tab>zd + menut Delete\ &All\ Folds<Tab>zD Leva\ &Tutte\ le\ piegature<Tab>zD + " movimenti all'interno delle piegature + menut Fold\ col&umn\ width Larghezza\ piegat&Ure\ in\ colonne +endif " has folding + +if has("diff") + menut &Diff &Differenza + " + menut &Update &Aggiorna + menut &Get\ Block &Importa\ differenze + menut &Put\ Block &Esporta\ differenze +endif " has diff + +menut &Make<Tab>:make Esegui\ &Make<Tab>:make + +menut &List\ Errors<Tab>:cl Lista\ &Errori<Tab>:cl +menut L&ist\ Messages<Tab>:cl! Lista\ &Messaggi<Tab>:cl! +menut &Next\ Error<Tab>:cn Errore\ s&Uccessivo<Tab>:cn +menut &Previous\ Error<Tab>:cp Errore\ &Precedente<Tab>:cp +menut &Older\ List<Tab>:cold Lista\ men&O\ recente<Tab>:cold +menut N&ewer\ List<Tab>:cnew Lista\ più\ rece&Nte<Tab>:cnew + +menut Error\ &Window &Finestra\ errori + +menut &Update<Tab>:cwin A&Ggiorna<Tab>:cwin +menut &Open<Tab>:copen &Apri<Tab>:copen +menut &Close<Tab>:cclose &Chiudi<Tab>:cclose + +menut &Convert\ to\ HEX<Tab>:%!xxd &Converti\ a\ esadecimale<Tab>:%!xxd +menut Conve&rt\ back<Tab>:%!xxd\ -r Conve&rti\ da\ esadecimale<Tab>:%!xxd\ -r + +menut Se&T\ Compiler Impo&Sta\ Compilatore + +" Buffers / Buffer +menut &Buffers &Buffer + +menut &Refresh\ menu A&ggiorna\ menu +menut &Delete &Elimina +menut &Alternate &Alternato +menut &Next &Successivo +menut &Previous &Precedente +menut [No\ File] [Nessun\ File] +" Syntax / Sintassi +menut &Syntax &Sintassi +menut &Show\ filetypes\ in\ menu Mo&Stra\ tipi\ di\ file\ nel\ menu +menut Set\ '&syntax'\ only &S\ Attiva\ solo\ \ 'syntax' +menut Set\ '&filetype'\ too &F\ Attiva\ anche\ 'filetype' +menut &Off &Disattiva +menut &Manual &Manuale +menut A&utomatic A&Utomatico +menut on/off\ for\ &This\ file Attiva\ Sì/No\ su\ ques&To\ file +menut Co&lor\ test Test\ &Colori +menut &Highlight\ test Test\ &Evidenziamento +menut &Convert\ to\ HTML Converti\ ad\ &HTML + +let g:menutrans_no_file = "[Senza nome]" + +" Window / Finestra +menut &Window &Finestra + +menut &New<Tab>^Wn &Nuova<Tab>^Wn +menut S&plit<Tab>^Ws &Dividi\ lo\ schermo<Tab>^Ws +menut Sp&lit\ To\ #<Tab>^W^^ D&Ividi\ verso\ #<Tab>^W^^ +menut Split\ &Vertically<Tab>^Wv Di&Vidi\ verticalmente<Tab>^Wv +menut Split\ File\ E&xplorer Aggiungi\ finestra\ e&Xplorer + +menut &Close<Tab>^Wc &Chiudi<Tab>^Wc +menut Close\ &Other(s)<Tab>^Wo C&Hiudi\ altra(e)<Tab>^Wo + +menut Move\ &To &Muovi\ verso + +menut &Top<Tab>^WK &Cima<Tab>^WK +menut &Bottom<Tab>^WJ &Fondo<Tab>^WJ +menut &Left\ side<Tab>^WH Lato\ &Sinistro<Tab>^WH +menut &Right\ side<Tab>^WL Lato\ &Destro<Tab>^WL +menut Rotate\ &Up<Tab>^WR Ruota\ verso\ l'&Alto<Tab>^WR +menut Rotate\ &Down<Tab>^Wr Ruota\ verso\ il\ &Basso<Tab>^Wr + +menut &Equal\ Size<Tab>^W= &Uguale\ ampiezza<Tab>^W= +menut &Max\ Height<Tab>^W_ &Altezza\ massima<Tab>^W_ +menut M&in\ Height<Tab>^W1_ A&Ltezza\ minima<Tab>^W1_ +menut Max\ &Width<Tab>^W\| Larghezza\ massima<Tab>^W\| +menut Min\ Widt&h<Tab>^W1\| Larghezza\ minima<Tab>^W1\| + +" The popup menu +menut &Undo &Annulla +menut Cu&t &Taglia +menut &Copy &Copia +menut &Paste &Incolla +menut &Delete &Elimina + +menut Select\ Blockwise Seleziona\ in\ blocco +menut Select\ &Word Seleziona\ &Parola +menut Select\ &Line Seleziona\ &Linea +menut Select\ &Block Seleziona\ &Blocco +menut Select\ &All Seleziona\ t&Utto + +" The GUI Toolbar / Barra Strumenti +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open Apri + tmenu ToolBar.Save Salva + tmenu ToolBar.SaveAll Salva Tutto + tmenu ToolBar.Print Stampa + tmenu ToolBar.Undo Annulla + tmenu ToolBar.Redo Ripristina + tmenu ToolBar.Cut Taglia + tmenu ToolBar.Copy Copia + tmenu ToolBar.Paste Incolla + + if !has("gui_athena") + tmenu ToolBar.Find Cerca + tmenu ToolBar.FindNext Cerca Successivo + tmenu ToolBar.FindPrev Cerca Precedente + tmenu ToolBar.Replace Sostituisci + endif + +if 0 " disabled; These are in the Windows menu + tmenu ToolBar.New Nuova finestra + tmenu ToolBar.WinSplit Dividi finestra + tmenu ToolBar.WinMax Massima ampiezza + tmenu ToolBar.WinMin Minima ampiezza + tmenu ToolBar.WinVSplit Dividi verticalmente + tmenu ToolBar.WinMaxWidth Massima larghezza + tmenu ToolBar.WinMinWidth Minima larghezza + tmenu ToolBar.WinClose Chiudi finestra +endif + + tmenu ToolBar.LoadSesn Carica Sessione + tmenu ToolBar.SaveSesn Salva Sessione + tmenu ToolBar.RunScript Esegui Script + tmenu ToolBar.Make Make + tmenu ToolBar.Shell Shell + tmenu ToolBar.RunCtags Esegui Ctags + tmenu ToolBar.TagJump Vai a Tag + tmenu ToolBar.Help Aiuto + tmenu ToolBar.FindHelp Cerca in Aiuto + endfun +endif + +" vim: set sw=2 : diff --git a/share/vim/vim72/lang/menu_it_it.utf-8.vim b/share/vim/vim73/lang/menu_it_it.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_it_it.utf-8.vim rename to share/vim/vim73/lang/menu_it_it.utf-8.vim diff --git a/share/vim/vim72/lang/menu_italian_italy.1252.vim b/share/vim/vim73/lang/menu_italian_italy.1252.vim similarity index 100% rename from share/vim/vim72/lang/menu_italian_italy.1252.vim rename to share/vim/vim73/lang/menu_italian_italy.1252.vim diff --git a/share/vim/vim72/lang/menu_ja.cp932.vim b/share/vim/vim73/lang/menu_ja.cp932.vim similarity index 100% rename from share/vim/vim72/lang/menu_ja.cp932.vim rename to share/vim/vim73/lang/menu_ja.cp932.vim diff --git a/share/vim/vim72/lang/menu_ja.euc-jp.vim b/share/vim/vim73/lang/menu_ja.euc-jp.vim similarity index 100% rename from share/vim/vim72/lang/menu_ja.euc-jp.vim rename to share/vim/vim73/lang/menu_ja.euc-jp.vim diff --git a/share/vim/vim72/lang/menu_ja.eucjp.vim b/share/vim/vim73/lang/menu_ja.eucjp.vim similarity index 100% rename from share/vim/vim72/lang/menu_ja.eucjp.vim rename to share/vim/vim73/lang/menu_ja.eucjp.vim diff --git a/share/vim/vim72/lang/menu_ja.ujis.vim b/share/vim/vim73/lang/menu_ja.ujis.vim similarity index 100% rename from share/vim/vim72/lang/menu_ja.ujis.vim rename to share/vim/vim73/lang/menu_ja.ujis.vim diff --git a/share/vim/vim72/lang/menu_ja.utf-8.vim b/share/vim/vim73/lang/menu_ja.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_ja.utf-8.vim rename to share/vim/vim73/lang/menu_ja.utf-8.vim diff --git a/share/vim/vim72/lang/menu_ja_jp.cp932.vim b/share/vim/vim73/lang/menu_ja_jp.cp932.vim similarity index 100% rename from share/vim/vim72/lang/menu_ja_jp.cp932.vim rename to share/vim/vim73/lang/menu_ja_jp.cp932.vim diff --git a/share/vim/vim73/lang/menu_ja_jp.euc-jp.vim b/share/vim/vim73/lang/menu_ja_jp.euc-jp.vim new file mode 100644 index 0000000000..f231857996 --- /dev/null +++ b/share/vim/vim73/lang/menu_ja_jp.euc-jp.vim @@ -0,0 +1,338 @@ +" vi:set ts=8 sts=8 sw=8 tw=0: +" +" Menu Translations: Japanese (EUC-JP) +" Translated By: MURAOKA Taro <koron@tka.att.ne.jp> +" Last Change: 18-Apr-2006. + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 + +scriptencoding euc-jp + +" Help menu +menutrans &Help ¥Ø¥ë¥×(&H) +menutrans &Overview<Tab><F1> ³µÎ¬(&O)<Tab><F1> +menutrans &User\ Manual ¥æ¡¼¥¶¥Þ¥Ë¥å¥¢¥ë(&U) +menutrans &How-to\ links &How-to¥ê¥ó¥¯ +menutrans &Credits ¥¯¥ì¥¸¥Ã¥È(&C) +menutrans Co&pying Ãøºî¸¢¾ðÊó(&P) +menutrans &Sponsor/Register ¥¹¥Ý¥ó¥µ¡¼/ÅÐÏ¿(&S) +menutrans O&rphans ¸É»ù(&R) +menutrans &Version ¥Ð¡¼¥¸¥ç¥ó¾ðÊó(&V) +menutrans &About Vim¤Ë¤Ä¤¤¤Æ(&A) + +let g:menutrans_help_dialog = "¥Ø¥ë¥×¤ò¸¡º÷¤·¤¿¤¤¥³¥Þ¥ó¥É¤â¤·¤¯¤Ïñ¸ì¤òÆþÎϤ·¤Æ¤¯¤À¤µ¤¤:\n\nÁÞÆþ¥â¡¼¥É¤Î¥³¥Þ¥ó¥É¤Ë¤Ï i_ ¤òÀèƬ¤ËÉղä·¤Þ¤¹. (Îã: i_CTRL-X)\n¥³¥Þ¥ó¥É¥é¥¤¥óÊÔ½¸¥³¥Þ¥ó¥É¤Ë¤Ï c_ ¤òÀèƬ¤ËÉղä·¤Þ¤¹. (Îã: c_<Del>)\n¥ª¥×¥·¥ç¥ó¤Î̾Á°¤Ë¤Ï ' ¤òÉղä·¤Þ¤¹. (Îã: 'shiftwidth')" + +" File menu +menutrans &File ¥Õ¥¡¥¤¥ë(&F) +menutrans &Open\.\.\.<Tab>:e ³«¤¯(&O)\.\.\.<Tab>:e +menutrans Sp&lit-Open\.\.\.<Tab>:sp ʬ³ä¤·¤Æ³«¤¯(&L)\.\.\.<Tab>:sp +menutrans Open\ Tab\.\.\.<Tab>:tabnew ¥¿¥Ö¥Ú¡¼¥¸¤Ç³«¤¯<Tab>:tabnew +menutrans &New<Tab>:enew ¿·µ¬ºîÀ®(&N)<Tab>:enew +menutrans &Close<Tab>:close ÊĤ¸¤ë(&C)<Tab>:close +menutrans &Save<Tab>:w Êݸ(&S)<Tab>:w +menutrans Save\ &As\.\.\.<Tab>:sav ̾Á°¤òÉÕ¤±¤ÆÊݸ(&A)\.\.\.<Tab>:sav +menutrans Split\ &Diff\ with\.\.\. º¹Ê¬É½¼¨(&D)\.\.\. +menutrans Split\ Patched\ &By\.\.\. ¥Ñ¥Ã¥Á·ë²Ì¤òɽ¼¨(&B)\.\.\. +menutrans &Print °õºþ(&P) +menutrans Sa&ve-Exit<Tab>:wqa Êݸ¤·¤Æ½ªÎ»(&V)<Tab>:wqa +menutrans E&xit<Tab>:qa ½ªÎ»(&X)<Tab>:qa + +" Edit menu +menutrans &Edit ÊÔ½¸(&E) +menutrans &Undo<Tab>u ¼è¤ê¾Ã¤¹(&U)<Tab>u +menutrans &Redo<Tab>^R ¤â¤¦°ìÅÙ¤ä¤ë(&R)<Tab>^R +menutrans Rep&eat<Tab>\. ·«¤êÊÖ¤¹(&E)<Tab>\. +menutrans Cu&t<Tab>"+x ÀÚ¤ê¼è¤ê(&T)<Tab>"+x +menutrans &Copy<Tab>"+y ¥³¥Ô¡¼(&C)<Tab>"+y +menutrans &Paste<Tab>"+gP Ž¤êÉÕ¤±(&P)<Tab>"+gP +menutrans Put\ &Before<Tab>[p Á°¤ËŽ¤ë(&B)<Tab>[p +menutrans Put\ &After<Tab>]p ¸å¤ËŽ¤ë(&A)<Tab>]p +menutrans &Delete<Tab>x ¾Ã¤¹(&D)<Tab>x +menutrans &Select\ All<Tab>ggVG Á´¤ÆÁªÂò(&S)<Tab>ggVG +menutrans &Find\.\.\. ¸¡º÷(&F)\.\.\. +menutrans &Find<Tab>/ ¸¡º÷(&F)<Tab>/ +menutrans Find\ and\ Rep&lace\.\.\. ÃÖ´¹(&L)\.\.\. +menutrans Find\ and\ Rep&lace<Tab>:%s ÃÖ´¹(&L)<Tab>:%s +menutrans Find\ and\ Rep&lace<Tab>:s ÃÖ´¹(&L)<Tab>:s +"menutrans Options\.\.\. ¥ª¥×¥·¥ç¥ó(&O)\.\.\. +menutrans Settings\ &Window ÀßÄꥦ¥£¥ó¥É¥¦(&W) +menutrans Startup\ &Settings µ¯Æ°»þ¤ÎÀßÄê(&S) + +" Edit/Global Settings +menutrans &Global\ Settings Á´ÂÎÀßÄê(&G) +menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! + \ ¥Ñ¥¿¡¼¥ó¶¯Ä´ÀÚÂØ(&H)<Tab>:set\ hls! +menutrans Toggle\ &Ignore-case<Tab>:set\ ic! + \ Â羮ʸ»ú¶èÊÌÀÚÂØ(&I)<Tab>:set\ ic! +menutrans Toggle\ &Showmatch<Tab>:set\ sm! + \ ¥Þ¥Ã¥Áɽ¼¨ÀÚÂØ(&S)<Tab>:set\ sm! +menutrans &Context\ lines ¥«¡¼¥½¥ë¼þÊÕ¹Ô¿ô(&C) +menutrans &Virtual\ Edit ²¾ÁÛÊÔ½¸(&V) +menutrans Never ̵¸ú +menutrans Block\ Selection ¥Ö¥í¥Ã¥¯ÁªÂò»þ +menutrans Insert\ mode ÁÞÆþ¥â¡¼¥É»þ +menutrans Block\ and\ Insert ¥Ö¥í¥Ã¥¯/ÁÞÆþ¥â¡¼¥É»þ +menutrans Always ¾ï»þ +menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! + \ ÁÞÆþ(½é¿´¼Ô)¥â¡¼¥ÉÀÚÂØ(&M)<Tab>:set\ im! +menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! + \ Vi¸ß´¹¥â¡¼¥ÉÀÚÂØ(&O)<Tab>:set\ cp! +menutrans Search\ &Path\.\.\. ¸¡º÷¥Ñ¥¹(&P)\.\.\. +menutrans Ta&g\ Files\.\.\. ¥¿¥°¥Õ¥¡¥¤¥ë(&G)\.\.\. +" +" GUI options +menutrans Toggle\ &Toolbar ¥Ä¡¼¥ë¥Ð¡¼É½¼¨ÀÚÂØ(&T) +menutrans Toggle\ &Bottom\ Scrollbar ¥¹¥¯¥í¡¼¥ë¥Ð¡¼(²¼)ɽ¼¨ÀÚÂØ(&B) +menutrans Toggle\ &Left\ Scrollbar ¥¹¥¯¥í¡¼¥ë¥Ð¡¼(º¸)ɽ¼¨ÀÚÂØ(&L) +menutrans Toggle\ &Right\ Scrollbar ¥¹¥¯¥í¡¼¥ë¥Ð¡¼(±¦)ɽ¼¨ÀÚÂØ(&R) + +let g:menutrans_path_dialog = "¥Õ¥¡¥¤¥ë¤Î¸¡º÷¥Ñ¥¹¤òÆþÎϤ·¤Æ¤¯¤À¤µ¤¤:\n¥Ç¥£¥ì¥¯¥È¥ê̾¤Ï¥«¥ó¥Þ ( , ) ¤Ç¶èÀڤäƤ¯¤À¤µ¤¤." +let g:menutrans_tags_dialog = "¥¿¥°¥Õ¥¡¥¤¥ë¤Î̾Á°¤òÆþÎϤ·¤Æ¤¯¤À¤µ¤¤:\n̾Á°¤Ï¥«¥ó¥Þ ( , ) ¤Ç¶èÀڤäƤ¯¤À¤µ¤¤." + +" Edit/File Settings + +" Boolean options +menutrans F&ile\ Settings ¥Õ¥¡¥¤¥ëÀßÄê(&I) +menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! + \ ¹ÔÈÖ¹æɽ¼¨ÀÚÂØ(&N)<Tab>:set\ nu! +menutrans Toggle\ &List\ Mode<Tab>:set\ list! + \ ¥ê¥¹¥È¥â¡¼¥ÉÀÚÂØ(&L)<Tab>:set\ list! +menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! + \ ¹ÔÀÞÊÖ¤·ÀÚÂØ(&W)<Tab>:set\ wrap! +menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! + \ ñ¸ìÀÞÊÖ¤·ÀÚÂØ(&R)<Tab>:set\ lbr! +menutrans Toggle\ &expand-tab<Tab>:set\ et! + \ ¥¿¥ÖŸ³«ÀÚÂØ(&E)<Tab>:set\ et! +menutrans Toggle\ &auto-indent<Tab>:set\ ai! + \ ¼«Æ°»ú²¼¤²ÀÚÂØ(&A)<Tab>:set\ ai! +menutrans Toggle\ &C-indenting<Tab>:set\ cin! + \ C¸À¸ì»ú²¼¤²ÀÚÂØ(&C)<Tab>:set\ cin! + +" other options +menutrans &Shiftwidth ¥·¥Õ¥ÈÉý(&S) +menutrans Soft\ &Tabstop ¥½¥Õ¥È¥¦¥§¥¢¥¿¥ÖÉý(&T) +menutrans Te&xt\ Width\.\.\. ¥Æ¥­¥¹¥ÈÉý(&X)\.\.\. +menutrans &File\ Format\.\.\. ²þ¹Ôµ­¹æÁªÂò(&F)\.\.\. + +let g:menutrans_textwidth_dialog = "¥Æ¥­¥¹¥È¤ÎÉý('textwidth')¤òÀßÄꤷ¤Æ¤¯¤À¤µ¤¤ (0¤ÇÀ°·Á¤ò̵¸ú²½):" +let g:menutrans_fileformat_dialog = "¥Õ¥¡¥¤¥ë½ÐÎϤκݤβþ¹Ôµ­¹æ¤Î·Á¼°¤òÁª¤ó¤Ç¤¯¤À¤µ¤¤." +let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\n¥­¥ã¥ó¥»¥ë(&C)" + +menutrans C&olor\ Scheme ¿§¥Æ¡¼¥ÞÁªÂò(&O) +menutrans &Keymap ¥­¡¼¥Þ¥Ã¥×(&K) +menutrans None ¤Ê¤· + +" Programming menu +menutrans &Tools ¥Ä¡¼¥ë(&T) +menutrans &Jump\ to\ this\ tag<Tab>g^] ¥¿¥°¥¸¥ã¥ó¥×(&J)<Tab>g^] +menutrans Jump\ &back<Tab>^T Ìá¤ë(&B)<Tab>^T +menutrans Build\ &Tags\ File ¥¿¥°¥Õ¥¡¥¤¥ëºîÀ®(&T) +menutrans &Make<Tab>:make ¥á¥¤¥¯(&M)<Tab>:make +menutrans &List\ Errors<Tab>:cl ¥¨¥é¡¼¥ê¥¹¥È(&L)<Tab>:cl +menutrans L&ist\ Messages<Tab>:cl! ¥á¥Ã¥»¡¼¥¸¥ê¥¹¥È(&I)<Tab>:cl! +menutrans &Next\ Error<Tab>:cn ¼¡¤Î¥¨¥é¡¼¤Ø(&N)<Tab>:cn +menutrans &Previous\ Error<Tab>:cp Á°¤Î¥¨¥é¡¼¤Ø(&P)<Tab>:cp +menutrans &Older\ List<Tab>:cold ¸Å¤¤¥ê¥¹¥È(&O)<Tab>:cold +menutrans N&ewer\ List<Tab>:cnew ¿·¤·¤¤¥ê¥¹¥È(&E)<Tab>:cnew +menutrans Error\ &Window ¥¨¥é¡¼¥¦¥£¥ó¥É¥¦(&W) +menutrans &Update<Tab>:cwin ¹¹¿·(&U)<Tab>:cwin +menutrans &Open<Tab>:copen ³«¤¯(&O)<Tab>:copen +menutrans &Close<Tab>:cclose ÊĤ¸¤ë(&C)<Tab>:cclose +menutrans &Convert\ to\ HEX<Tab>:%!xxd HEX¤ØÊÑ´¹(&C)<Tab>:%!xxd +menutrans Conve&rt\ back<Tab>:%!xxd\ -r HEX¤«¤éµÕÊÑ´¹(&R)<Tab>%!xxd\ -r +menutrans Se&T\ Compiler ¥³¥ó¥Ñ¥¤¥éÀßÄê(&T) + +" Tools.Spelling Menu +menutrans &Spelling ¥¹¥Ú¥ê¥ó¥°(&S) +menutrans &Spell\ Check\ On ¥¹¥Ú¥ë¥Á¥§¥Ã¥¯Í­¸ú(&S) +menutrans Spell\ Check\ &Off ¥¹¥Ú¥ë¥Á¥§¥Ã¥¯Í­¸ú(&O) +menutrans To\ &Next\ error<Tab>]s ¼¡¤Î¥¨¥é¡¼(&N)<Tab>]s +menutrans To\ &Previous\ error<Tab>[s Á°¤Î¥¨¥é¡¼(&P)<Tab>[s +menutrans Suggest\ &Corrections<Tab>z= ½¤Àµ¸õÊä(&C)<Tab>z= +menutrans &Repeat\ correction<Tab>:spellrepall ½¤Àµ¤ò·«¤êÊÖ¤¹(&R)<Tab>:spellrepall +menutrans Set\ language\ to\ "en" ¸À¸ì¤ò\ "en"\ ¤ËÀßÄꤹ¤ë +menutrans Set\ language\ to\ "en_au" ¸À¸ì¤ò\ "en_au"\ ¤ËÀßÄꤹ¤ë +menutrans Set\ language\ to\ "en_ca" ¸À¸ì¤ò\ "en_ca"\ ¤ËÀßÄꤹ¤ë +menutrans Set\ language\ to\ "en_gb" ¸À¸ì¤ò\ "en_gb"\ ¤ËÀßÄꤹ¤ë +menutrans Set\ language\ to\ "en_nz" ¸À¸ì¤ò\ "en_nz"\ ¤ËÀßÄꤹ¤ë +menutrans Set\ language\ to\ "en_us" ¸À¸ì¤ò\ "en_us"\ ¤ËÀßÄꤹ¤ë +menutrans &Find\ More\ Languages ¾¤Î¸À¸ì¤ò¸¡º÷¤¹¤ë(&F) + +" Tools.Fold Menu +menutrans &Folding ÀÞ¾ö¤ß(&F) +" open close folds +menutrans &Enable/Disable\ folds<Tab>zi Í­¸ú/̵¸úÀÚÂØ(&E)<Tab>zi +menutrans &View\ Cursor\ Line<Tab>zv ¥«¡¼¥½¥ë¹Ô¤òɽ¼¨(&V)<Tab>zv +menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx ¥«¡¼¥½¥ë¹Ô¤À¤±¤òɽ¼¨(&W)<Tab>zMzx +menutrans C&lose\ more\ folds<Tab>zm ÀÞ¾ö¤ß¤òÊĤ¸¤ë(&L)<Tab>zm +menutrans &Close\ all\ folds<Tab>zM Á´ÀÞ¾ö¤ß¤òÊĤ¸¤ë(&C)<Tab>zM +menutrans O&pen\ more\ folds<Tab>zr ÀÞ¾ö¤ß¤ò³«¤¯(&P)<Tab>zr +menutrans &Open\ all\ folds<Tab>zR Á´ÀÞ¾ö¤ß¤ò³«¤¯(&O)<Tab>zR +" fold method +menutrans Fold\ Met&hod ÀÞ¾ö¤ßÊýË¡(&H) +menutrans M&anual ¼êÆ°(&A) +menutrans I&ndent ¥¤¥ó¥Ç¥ó¥È(&N) +menutrans E&xpression ¼°É¾²Á(&X) +menutrans S&yntax ¥·¥ó¥¿¥Ã¥¯¥¹(&Y) +menutrans &Diff º¹Ê¬(&D) +menutrans Ma&rker ¥Þ¡¼¥«¡¼(&R) +" create and delete folds +menutrans Create\ &Fold<Tab>zf ÀÞ¾ö¤ßºîÀ®(&F)<Tab>zf +menutrans &Delete\ Fold<Tab>zd ÀÞ¾ö¤ßºï½ü(&D)<Tab>zd +menutrans Delete\ &All\ Folds<Tab>zD Á´ÀÞ¾ö¤ßºï½ü(&A)<Tab>zD +" moving around in folds +menutrans Fold\ col&umn\ width ÀÞ¾ö¤ß¥«¥é¥àÉý(&U) + +menutrans &Update ¹¹¿·(&U) +menutrans &Get\ Block ¥Ö¥í¥Ã¥¯Ãê½Ð(&G) +menutrans &Put\ Block ¥Ö¥í¥Ã¥¯Å¬ÍÑ(&P) + +" Names for buffer menu. +menutrans &Buffers ¥Ð¥Ã¥Õ¥¡(&B) +menutrans &Refresh\ menu ¥á¥Ë¥å¡¼ºÆÆɹþ(&R) +menutrans &Delete ºï½ü(&D) +menutrans &Alternate ΢¤ØÀÚÂØ(&A) +menutrans &Next ¼¡¤Î¥Ð¥Ã¥Õ¥¡(&N) +menutrans &Previous Á°¤Î¥Ð¥Ã¥Õ¥¡(&P) +menutrans [No\ File] [̵Âê] +let g:menutrans_no_file = "[̵Âê]" + +" Window menu +menutrans &Window ¥¦¥£¥ó¥É¥¦(&W) +menutrans &New<Tab>^Wn ¿·µ¬ºîÀ®(&N)<Tab>^Wn +menutrans S&plit<Tab>^Ws ʬ³ä(&P)<Tab>^Ws +menutrans Sp&lit\ To\ #<Tab>^W^^ ΢¥Ð¥Ã¥Õ¥¡¤Øʬ³ä(&L)<Tab>^W^^ +menutrans Split\ &Vertically<Tab>^Wv ¿âľʬ³ä(&V)<Tab>^Wv +menutrans Split\ File\ E&xplorer ¥Õ¥¡¥¤¥ë¥¨¥¯¥¹¥×¥í¡¼¥é(&X) +menutrans &Close<Tab>^Wc ÊĤ¸¤ë(&C)<Tab>^Wc +menutrans Move\ &To °ÜÆ°(&T) +menutrans &Top<Tab>^WK ¾å(&T)<Tab>^WK +menutrans &Bottom<Tab>^WJ ²¼(&B)<Tab>^WJ +menutrans &Left\ side<Tab>^WH º¸(&L)<Tab>^WH +menutrans &Right\ side<Tab>^WL ±¦(&R)<Tab>^WL +menutrans Close\ &Other(s)<Tab>^Wo ¾¤òÊĤ¸¤ë(&O)<Tab>^Wo +menutrans Ne&xt<Tab>^Ww ¼¡¤Ø(&X)<Tab>^Ww +menutrans P&revious<Tab>^WW Á°¤Ø(&R)<Tab>^WW +menutrans &Equal\ Size<Tab>^W= Ʊ¤¸¹â¤µ¤Ë(&E)<Tab>^W= +menutrans &Max\ Height<Tab>^W_ ºÇÂç¹â¤Ë(&M)<Tab>^W_ +menutrans M&in\ Height<Tab>^W1_ ºÇ¾®¹â¤Ë(&i)<Tab>^W1_ +menutrans Max\ &Width<Tab>^W\| ºÇÂçÉý¤Ë(&W)<Tab>^W\| +menutrans Min\ Widt&h<Tab>^W1\| ºÇ¾®Éý¤Ë(&H)<Tab>^W1\| +menutrans Rotate\ &Up<Tab>^WR ¾å¤Ë¥í¡¼¥Æ¡¼¥·¥ç¥ó(&U)<Tab>^WR +menutrans Rotate\ &Down<Tab>^Wr ²¼¤Ë¥í¡¼¥Æ¡¼¥·¥ç¥ó(&D)<Tab>^Wr +menutrans Select\ Fo&nt\.\.\. ¥Õ¥©¥ó¥ÈÀßÄê(&N)\.\.\. + +" The popup menu +menutrans &Undo ¼è¤ê¾Ã¤¹(&U) +menutrans Cu&t ÀÚ¤ê¼è¤ê(&T) +menutrans &Copy ¥³¥Ô¡¼(&C) +menutrans &Paste Ž¤êÉÕ¤±(&P) +menutrans &Delete ºï½ü(&D) +menutrans Select\ Blockwise ¶ë·Á¥Ö¥í¥Ã¥¯ÁªÂò +menutrans Select\ &Word ñ¸ìÁªÂò(&W) +menutrans Select\ &Line ¹ÔÁªÂò(&L) +menutrans Select\ &Block ¥Ö¥í¥Ã¥¯ÁªÂò(&B) +menutrans Select\ &All ¤¹¤Ù¤ÆÁªÂò(&A) + +" The GUI toolbar (for Win32 or GTK) +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open ¥Õ¥¡¥¤¥ë¤ò³«¤¯ + tmenu ToolBar.Save ¸½ºß¤Î¥Õ¥¡¥¤¥ë¤òÊݸ + tmenu ToolBar.SaveAll ¤¹¤Ù¤Æ¤Î¥Õ¥¡¥¤¥ë¤òÊݸ + tmenu ToolBar.Print °õºþ + tmenu ToolBar.Undo ¼è¤ê¾Ã¤· + tmenu ToolBar.Redo ¤â¤¦°ìÅÙ¤ä¤ë + tmenu ToolBar.Cut ¥¯¥ê¥Ã¥×¥Ü¡¼¥É¤ØÀÚ¤ê¼è¤ê + tmenu ToolBar.Copy ¥¯¥ê¥Ã¥×¥Ü¡¼¥É¤Ø¥³¥Ô¡¼ + tmenu ToolBar.Paste ¥¯¥ê¥Ã¥×¥Ü¡¼¥É¤«¤éŽ¤êÉÕ¤± + tmenu ToolBar.Find ¸¡º÷... + tmenu ToolBar.FindNext ¼¡¤ò¸¡º÷ + tmenu ToolBar.FindPrev Á°¤ò¸¡º÷ + tmenu ToolBar.Replace ÃÖ´¹... + if 0 " disabled; These are in the Windows menu + tmenu ToolBar.New ¿·µ¬¥¦¥£¥ó¥É¥¦ºîÀ® + tmenu ToolBar.WinSplit ¥¦¥£¥ó¥É¥¦Ê¬³ä + tmenu ToolBar.WinMax ¥¦¥£¥ó¥É¥¦ºÇÂç²½ + tmenu ToolBar.WinMin ¥¦¥£¥ó¥É¥¦ºÇ¾®²½ + tmenu ToolBar.WinClose ¥¦¥£¥ó¥É¥¦¤òÊĤ¸¤ë + endif + tmenu ToolBar.LoadSesn ¥»¥Ã¥·¥ç¥óÆɹþ + tmenu ToolBar.SaveSesn ¥»¥Ã¥·¥ç¥óÊݸ + tmenu ToolBar.RunScript Vim¥¹¥¯¥ê¥×¥È¼Â¹Ô + tmenu ToolBar.Make ¥×¥í¥¸¥§¥¯¥È¤òMake + tmenu ToolBar.Shell ¥·¥§¥ë¤ò³«¤¯ + tmenu ToolBar.RunCtags tagsºîÀ® + tmenu ToolBar.TagJump ¥¿¥°¥¸¥ã¥ó¥× + tmenu ToolBar.Help Vim¥Ø¥ë¥× + tmenu ToolBar.FindHelp Vim¥Ø¥ë¥×¸¡º÷ + endfun +endif + +" Syntax menu +menutrans &Syntax ¥·¥ó¥¿¥Ã¥¯¥¹(&S) +menutrans &Show\ filetypes\ in\ menu Âбþ·Á¼°¤ò¥á¥Ë¥å¡¼¤Ëɽ¼¨(&S) +menutrans Set\ '&syntax'\ only 'syntax'¤À¤±ÀßÄê(&S) +menutrans Set\ '&filetype'\ too 'filetype'¤âÀßÄê(&F) +menutrans &Off ̵¸ú²½(&O) +menutrans &Manual ¼êÆ°ÀßÄê(&M) +menutrans A&utomatic ¼«Æ°ÀßÄê(&U) +menutrans on/off\ for\ &This\ file + \ ¥ª¥ó/¥ª¥ÕÀÚÂØ(&T) +menutrans Co&lor\ test ¥«¥é¡¼¥Æ¥¹¥È(&L) +menutrans &Highlight\ test ¥Ï¥¤¥é¥¤¥È¥Æ¥¹¥È(&H) +menutrans &Convert\ to\ HTML HTML¤Ø¥³¥ó¥Ð¡¼¥È(&C) + +" Japanese specific menu +" À®ÈݤÏiconv¼¡Â衢ɬ¤º¤·¤â»ØÄꤷ¤¿¥¨¥ó¥³¡¼¥É¤Ë¤Ê¤ë¤ï¤±¤Ç¤Ï¤Ê¤¤¤³¤È¤ËÃí°Õ +if has('iconv') + " iconv¤Î¥Ð¡¼¥¸¥ç¥óȽÄê + let support_jisx0213 = (iconv("\x87\x64\x87\x6a", 'cp932', 'euc-jisx0213') ==# "\xad\xc5\xad\xcb") ? 1 : 0 + " + " Æɤ߹þ¤ß + an 10.395 &File.-SEPICONV- <Nop> + an 10.396.100.100 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..SJIS(&S)<Tab>fenc=cp932 :browse confirm e ++enc=cp932<CR> + if !support_jisx0213 + an 10.396.100.110 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jp :browse confirm e ++enc=euc-jp<CR> + an 10.396.100.120 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :browse confirm e ++enc=iso-2022-jp<CR> + else + an 10.396.100.110 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :browse confirm e ++enc=euc-jisx0213<CR> + an 10.396.100.120 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :browse confirm e ++enc=iso-2022-jp-3<CR> + endif + an 10.396.100.130 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..³«¤¯(&O)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :browse confirm e ++enc=utf-8<CR> + + " ºÆÆɹþ + an 10.396.110.100 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..SJIS(&S)<Tab>fenc=cp932 :e ++enc=cp932<CR> + if !support_jisx0213 + an 10.396.110.110 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jp :e ++enc=euc-jp<CR> + an 10.396.110.120 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :e ++enc=iso-2022-jp<CR> + else + an 10.396.110.110 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :e ++enc=euc-jisx0213<CR> + an 10.396.110.120 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :e ++enc=iso-2022-jp-3<CR> + endif + an 10.396.110.130 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..ºÆÆɹþ(&R)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :e ++enc=utf-8<CR> + + " Êݸ + an 10.396.115 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..-SEP1- <Nop> + an 10.396.120.100 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..SJIS(&S)<Tab>fenc=cp932 :set fenc=cp932 \| w<CR> + if !support_jisx0213 + an 10.396.120.110 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jp :set fenc=euc-jp \| w<CR> + an 10.396.120.120 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :set fenc=iso-2022-jp \| w<CR> + else + an 10.396.120.110 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :set fenc=euc-jisx0213 \| w<CR> + an 10.396.120.120 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :set fenc=iso-2022-jp-3 \| w<CR> + endif + an 10.396.120.130 &File.¥¨¥ó¥³¡¼¥É»ØÄê(&E)\.\.\..Êݸ(&S)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :set fenc=utf-8 \| w<CR> +endif + +" filler to avoid the line above being recognized as a modeline +" filler +" filler +" filler diff --git a/share/vim/vim72/lang/menu_ja_jp.eucjp.vim b/share/vim/vim73/lang/menu_ja_jp.eucjp.vim similarity index 100% rename from share/vim/vim72/lang/menu_ja_jp.eucjp.vim rename to share/vim/vim73/lang/menu_ja_jp.eucjp.vim diff --git a/share/vim/vim72/lang/menu_ja_jp.ujis.vim b/share/vim/vim73/lang/menu_ja_jp.ujis.vim similarity index 100% rename from share/vim/vim72/lang/menu_ja_jp.ujis.vim rename to share/vim/vim73/lang/menu_ja_jp.ujis.vim diff --git a/share/vim/vim73/lang/menu_ja_jp.utf-8.vim b/share/vim/vim73/lang/menu_ja_jp.utf-8.vim new file mode 100644 index 0000000000..b23100596b --- /dev/null +++ b/share/vim/vim73/lang/menu_ja_jp.utf-8.vim @@ -0,0 +1,338 @@ +" vi:set ts=8 sts=8 sw=8 tw=0: +" +" Menu Translations: Japanese (UTF-8) +" Translated By: MURAOKA Taro <koron@tka.att.ne.jp> +" Last Change: 18-Apr-2006. + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 + +scriptencoding utf-8 + +" Help menu +menutrans &Help ヘルプ(&H) +menutrans &Overview<Tab><F1> 概略(&O)<Tab><F1> +menutrans &User\ Manual ユーザマニュアル(&U) +menutrans &How-to\ links &How-toリンク +menutrans &Credits クレジット(&C) +menutrans Co&pying 著作権情報(&P) +menutrans &Sponsor/Register スポンサー/登録(&S) +menutrans O&rphans 孤児(&R) +menutrans &Version バージョン情報(&V) +menutrans &About Vimについて(&A) + +let g:menutrans_help_dialog = "ヘルプを検索したいコマンドもしくは単語を入力してください:\n\n挿入モードのコマンドには i_ を先頭に付加します. (例: i_CTRL-X)\nコマンドライン編集コマンドには c_ を先頭に付加します. (例: c_<Del>)\nオプションの名前には ' を付加します. (例: 'shiftwidth')" + +" File menu +menutrans &File ファイル(&F) +menutrans &Open\.\.\.<Tab>:e 開く(&O)\.\.\.<Tab>:e +menutrans Sp&lit-Open\.\.\.<Tab>:sp 分割して開く(&L)\.\.\.<Tab>:sp +menutrans Open\ Tab\.\.\.<Tab>:tabnew タブページで開く<Tab>:tabnew +menutrans &New<Tab>:enew 新規作成(&N)<Tab>:enew +menutrans &Close<Tab>:close 閉じる(&C)<Tab>:close +menutrans &Save<Tab>:w 保存(&S)<Tab>:w +menutrans Save\ &As\.\.\.<Tab>:sav 名前を付けて保存(&A)\.\.\.<Tab>:sav +menutrans Split\ &Diff\ with\.\.\. 差分表示(&D)\.\.\. +menutrans Split\ Patched\ &By\.\.\. パッチ結果を表示(&B)\.\.\. +menutrans &Print 印刷(&P) +menutrans Sa&ve-Exit<Tab>:wqa 保存して終了(&V)<Tab>:wqa +menutrans E&xit<Tab>:qa 終了(&X)<Tab>:qa + +" Edit menu +menutrans &Edit 編集(&E) +menutrans &Undo<Tab>u 取り消す(&U)<Tab>u +menutrans &Redo<Tab>^R もう一度やる(&R)<Tab>^R +menutrans Rep&eat<Tab>\. 繰り返す(&E)<Tab>\. +menutrans Cu&t<Tab>"+x 切り取り(&T)<Tab>"+x +menutrans &Copy<Tab>"+y コピー(&C)<Tab>"+y +menutrans &Paste<Tab>"+gP 貼り付け(&P)<Tab>"+gP +menutrans Put\ &Before<Tab>[p 前に貼る(&B)<Tab>[p +menutrans Put\ &After<Tab>]p 後に貼る(&A)<Tab>]p +menutrans &Delete<Tab>x 消す(&D)<Tab>x +menutrans &Select\ All<Tab>ggVG 全て選択(&S)<Tab>ggVG +menutrans &Find\.\.\. 検索(&F)\.\.\. +menutrans &Find<Tab>/ 検索(&F)<Tab>/ +menutrans Find\ and\ Rep&lace\.\.\. 置換(&L)\.\.\. +menutrans Find\ and\ Rep&lace<Tab>:%s 置換(&L)<Tab>:%s +menutrans Find\ and\ Rep&lace<Tab>:s 置換(&L)<Tab>:s +"menutrans Options\.\.\. オプション(&O)\.\.\. +menutrans Settings\ &Window 設定ウィンドウ(&W) +menutrans Startup\ &Settings 起動時の設定(&S) + +" Edit/Global Settings +menutrans &Global\ Settings 全体設定(&G) +menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! + \ パターン強調切替(&H)<Tab>:set\ hls! +menutrans Toggle\ &Ignore-case<Tab>:set\ ic! + \ 大小文字区別切替(&I)<Tab>:set\ ic! +menutrans Toggle\ &Showmatch<Tab>:set\ sm! + \ マッチ表示切替(&S)<Tab>:set\ sm! +menutrans &Context\ lines カーソル周辺行数(&C) +menutrans &Virtual\ Edit 仮想編集(&V) +menutrans Never 無効 +menutrans Block\ Selection ブロック選択時 +menutrans Insert\ mode 挿入モード時 +menutrans Block\ and\ Insert ブロック/挿入モード時 +menutrans Always 常時 +menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! + \ 挿入(初心者)モード切替(&M)<Tab>:set\ im! +menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! + \ Vi互換モード切替(&O)<Tab>:set\ cp! +menutrans Search\ &Path\.\.\. 検索パス(&P)\.\.\. +menutrans Ta&g\ Files\.\.\. タグファイル(&G)\.\.\. +" +" GUI options +menutrans Toggle\ &Toolbar ツールバー表示切替(&T) +menutrans Toggle\ &Bottom\ Scrollbar スクロールバー(下)表示切替(&B) +menutrans Toggle\ &Left\ Scrollbar スクロールバー(左)表示切替(&L) +menutrans Toggle\ &Right\ Scrollbar スクロールバー(右)表示切替(&R) + +let g:menutrans_path_dialog = "ファイルの検索パスを入力してください:\nディレクトリ名はカンマ ( , ) で区切ってください." +let g:menutrans_tags_dialog = "タグファイルの名前を入力してください:\n名前はカンマ ( , ) で区切ってください." + +" Edit/File Settings + +" Boolean options +menutrans F&ile\ Settings ファイル設定(&I) +menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! + \ 行番号表示切替(&N)<Tab>:set\ nu! +menutrans Toggle\ &List\ Mode<Tab>:set\ list! + \ リストモード切替(&L)<Tab>:set\ list! +menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! + \ 行折返し切替(&W)<Tab>:set\ wrap! +menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! + \ 単語折返し切替(&R)<Tab>:set\ lbr! +menutrans Toggle\ &expand-tab<Tab>:set\ et! + \ タブ展開切替(&E)<Tab>:set\ et! +menutrans Toggle\ &auto-indent<Tab>:set\ ai! + \ 自動字下げ切替(&A)<Tab>:set\ ai! +menutrans Toggle\ &C-indenting<Tab>:set\ cin! + \ C言語字下げ切替(&C)<Tab>:set\ cin! + +" other options +menutrans &Shiftwidth シフト幅(&S) +menutrans Soft\ &Tabstop ソフトウェアタブ幅(&T) +menutrans Te&xt\ Width\.\.\. テキスト幅(&X)\.\.\. +menutrans &File\ Format\.\.\. 改行記号選択(&F)\.\.\. + +let g:menutrans_textwidth_dialog = "テキストの幅('textwidth')を設定してください (0で整形を無効化):" +let g:menutrans_fileformat_dialog = "ファイル出力の際の改行記号の形式を選んでください." +let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\nキャンセル(&C)" + +menutrans C&olor\ Scheme 色テーマ選択(&O) +menutrans &Keymap キーマップ(&K) +menutrans None なし + +" Programming menu +menutrans &Tools ツール(&T) +menutrans &Jump\ to\ this\ tag<Tab>g^] タグジャンプ(&J)<Tab>g^] +menutrans Jump\ &back<Tab>^T 戻る(&B)<Tab>^T +menutrans Build\ &Tags\ File タグファイル作成(&T) +menutrans &Make<Tab>:make メイク(&M)<Tab>:make +menutrans &List\ Errors<Tab>:cl エラーリスト(&L)<Tab>:cl +menutrans L&ist\ Messages<Tab>:cl! メッセージリスト(&I)<Tab>:cl! +menutrans &Next\ Error<Tab>:cn 次のエラーへ(&N)<Tab>:cn +menutrans &Previous\ Error<Tab>:cp 前のエラーへ(&P)<Tab>:cp +menutrans &Older\ List<Tab>:cold 古いリスト(&O)<Tab>:cold +menutrans N&ewer\ List<Tab>:cnew 新しいリスト(&E)<Tab>:cnew +menutrans Error\ &Window エラーウィンドウ(&W) +menutrans &Update<Tab>:cwin 更新(&U)<Tab>:cwin +menutrans &Open<Tab>:copen 開く(&O)<Tab>:copen +menutrans &Close<Tab>:cclose 閉じる(&C)<Tab>:cclose +menutrans &Convert\ to\ HEX<Tab>:%!xxd HEXへ変換(&C)<Tab>:%!xxd +menutrans Conve&rt\ back<Tab>:%!xxd\ -r HEXから逆変換(&R)<Tab>%!xxd\ -r +menutrans Se&T\ Compiler コンパイラ設定(&T) + +" Tools.Spelling Menu +menutrans &Spelling スペリング(&S) +menutrans &Spell\ Check\ On スペルチェック有効(&S) +menutrans Spell\ Check\ &Off スペルチェック有効(&O) +menutrans To\ &Next\ error<Tab>]s 次のエラー(&N)<Tab>]s +menutrans To\ &Previous\ error<Tab>[s 前のエラー(&P)<Tab>[s +menutrans Suggest\ &Corrections<Tab>z= 修正候補(&C)<Tab>z= +menutrans &Repeat\ correction<Tab>:spellrepall 修正を繰り返す(&R)<Tab>:spellrepall +menutrans Set\ language\ to\ "en" 言語を\ "en"\ に設定する +menutrans Set\ language\ to\ "en_au" 言語を\ "en_au"\ に設定する +menutrans Set\ language\ to\ "en_ca" 言語を\ "en_ca"\ に設定する +menutrans Set\ language\ to\ "en_gb" 言語を\ "en_gb"\ に設定する +menutrans Set\ language\ to\ "en_nz" 言語を\ "en_nz"\ に設定する +menutrans Set\ language\ to\ "en_us" 言語を\ "en_us"\ に設定する +menutrans &Find\ More\ Languages 他の言語を検索する(&F) + +" Tools.Fold Menu +menutrans &Folding 折畳み(&F) +" open close folds +menutrans &Enable/Disable\ folds<Tab>zi 有効/無効切替(&E)<Tab>zi +menutrans &View\ Cursor\ Line<Tab>zv カーソル行を表示(&V)<Tab>zv +menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx カーソル行だけを表示(&W)<Tab>zMzx +menutrans C&lose\ more\ folds<Tab>zm 折畳みを閉じる(&L)<Tab>zm +menutrans &Close\ all\ folds<Tab>zM 全折畳みを閉じる(&C)<Tab>zM +menutrans O&pen\ more\ folds<Tab>zr 折畳みを開く(&P)<Tab>zr +menutrans &Open\ all\ folds<Tab>zR 全折畳みを開く(&O)<Tab>zR +" fold method +menutrans Fold\ Met&hod 折畳み方法(&H) +menutrans M&anual 手動(&A) +menutrans I&ndent インデント(&N) +menutrans E&xpression 式評価(&X) +menutrans S&yntax シンタックス(&Y) +menutrans &Diff 差分(&D) +menutrans Ma&rker マーカー(&R) +" create and delete folds +menutrans Create\ &Fold<Tab>zf 折畳み作成(&F)<Tab>zf +menutrans &Delete\ Fold<Tab>zd 折畳み削除(&D)<Tab>zd +menutrans Delete\ &All\ Folds<Tab>zD 全折畳み削除(&A)<Tab>zD +" moving around in folds +menutrans Fold\ col&umn\ width 折畳みカラム幅(&U) + +menutrans &Update 更新(&U) +menutrans &Get\ Block ブロック抽出(&G) +menutrans &Put\ Block ブロック適用(&P) + +" Names for buffer menu. +menutrans &Buffers バッファ(&B) +menutrans &Refresh\ menu メニュー再読込(&R) +menutrans &Delete 削除(&D) +menutrans &Alternate 裏へ切替(&A) +menutrans &Next 次のバッファ(&N) +menutrans &Previous 前のバッファ(&P) +menutrans [No\ File] [無題] +let g:menutrans_no_file = "[無題]" + +" Window menu +menutrans &Window ウィンドウ(&W) +menutrans &New<Tab>^Wn 新規作成(&N)<Tab>^Wn +menutrans S&plit<Tab>^Ws 分割(&P)<Tab>^Ws +menutrans Sp&lit\ To\ #<Tab>^W^^ 裏バッファへ分割(&L)<Tab>^W^^ +menutrans Split\ &Vertically<Tab>^Wv 垂直分割(&V)<Tab>^Wv +menutrans Split\ File\ E&xplorer ファイルエクスプローラ(&X) +menutrans &Close<Tab>^Wc 閉じる(&C)<Tab>^Wc +menutrans Move\ &To 移動(&T) +menutrans &Top<Tab>^WK 上(&T)<Tab>^WK +menutrans &Bottom<Tab>^WJ 下(&B)<Tab>^WJ +menutrans &Left\ side<Tab>^WH 左(&L)<Tab>^WH +menutrans &Right\ side<Tab>^WL 右(&R)<Tab>^WL +menutrans Close\ &Other(s)<Tab>^Wo 他を閉じる(&O)<Tab>^Wo +menutrans Ne&xt<Tab>^Ww 次へ(&X)<Tab>^Ww +menutrans P&revious<Tab>^WW 前へ(&R)<Tab>^WW +menutrans &Equal\ Size<Tab>^W= 同じ高さに(&E)<Tab>^W= +menutrans &Max\ Height<Tab>^W_ 最大高に(&M)<Tab>^W_ +menutrans M&in\ Height<Tab>^W1_ 最小高に(&i)<Tab>^W1_ +menutrans Max\ &Width<Tab>^W\| 最大幅に(&W)<Tab>^W\| +menutrans Min\ Widt&h<Tab>^W1\| 最小幅に(&H)<Tab>^W1\| +menutrans Rotate\ &Up<Tab>^WR 上にローテーション(&U)<Tab>^WR +menutrans Rotate\ &Down<Tab>^Wr 下にローテーション(&D)<Tab>^Wr +menutrans Select\ Fo&nt\.\.\. フォント設定(&N)\.\.\. + +" The popup menu +menutrans &Undo 取り消す(&U) +menutrans Cu&t 切り取り(&T) +menutrans &Copy コピー(&C) +menutrans &Paste 貼り付け(&P) +menutrans &Delete 削除(&D) +menutrans Select\ Blockwise 矩形ブロック選択 +menutrans Select\ &Word 単語選択(&W) +menutrans Select\ &Line 行選択(&L) +menutrans Select\ &Block ブロック選択(&B) +menutrans Select\ &All すべて選択(&A) + +" The GUI toolbar (for Win32 or GTK) +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open ファイルを開く + tmenu ToolBar.Save 現在のファイルを保存 + tmenu ToolBar.SaveAll すべてのファイルを保存 + tmenu ToolBar.Print 印刷 + tmenu ToolBar.Undo 取り消し + tmenu ToolBar.Redo もう一度やる + tmenu ToolBar.Cut クリップボードへ切り取り + tmenu ToolBar.Copy クリップボードへコピー + tmenu ToolBar.Paste クリップボードから貼り付け + tmenu ToolBar.Find 検索... + tmenu ToolBar.FindNext 次を検索 + tmenu ToolBar.FindPrev 前を検索 + tmenu ToolBar.Replace 置換... + if 0 " disabled; These are in the Windows menu + tmenu ToolBar.New 新規ウィンドウ作成 + tmenu ToolBar.WinSplit ウィンドウ分割 + tmenu ToolBar.WinMax ウィンドウ最大化 + tmenu ToolBar.WinMin ウィンドウ最小化 + tmenu ToolBar.WinClose ウィンドウを閉じる + endif + tmenu ToolBar.LoadSesn セッション読込 + tmenu ToolBar.SaveSesn セッション保存 + tmenu ToolBar.RunScript Vimスクリプト実行 + tmenu ToolBar.Make プロジェクトをMake + tmenu ToolBar.Shell シェルを開く + tmenu ToolBar.RunCtags tags作成 + tmenu ToolBar.TagJump タグジャンプ + tmenu ToolBar.Help Vimヘルプ + tmenu ToolBar.FindHelp Vimヘルプ検索 + endfun +endif + +" Syntax menu +menutrans &Syntax シンタックス(&S) +menutrans &Show\ filetypes\ in\ menu 対応形式をメニューに表示(&S) +menutrans Set\ '&syntax'\ only 'syntax'だけ設定(&S) +menutrans Set\ '&filetype'\ too 'filetype'も設定(&F) +menutrans &Off 無効化(&O) +menutrans &Manual 手動設定(&M) +menutrans A&utomatic 自動設定(&U) +menutrans on/off\ for\ &This\ file + \ オン/オフ切替(&T) +menutrans Co&lor\ test カラーテスト(&L) +menutrans &Highlight\ test ハイライトテスト(&H) +menutrans &Convert\ to\ HTML HTMLへコンバート(&C) + +" Japanese specific menu +" 成否はiconv次第、必ずしも指定したエンコードになるわけではないことに注意 +if has('iconv') + " iconvのバージョン判定 + let support_jisx0213 = (iconv("\x87\x64\x87\x6a", 'cp932', 'euc-jisx0213') ==# "\xad\xc5\xad\xcb") ? 1 : 0 + " + " 読み込み + an 10.395 &File.-SEPICONV- <Nop> + an 10.396.100.100 &File.エンコード指定(&E)\.\.\..開く(&O)\.\.\..SJIS(&S)<Tab>fenc=cp932 :browse confirm e ++enc=cp932<CR> + if !support_jisx0213 + an 10.396.100.110 &File.エンコード指定(&E)\.\.\..開く(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jp :browse confirm e ++enc=euc-jp<CR> + an 10.396.100.120 &File.エンコード指定(&E)\.\.\..開く(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :browse confirm e ++enc=iso-2022-jp<CR> + else + an 10.396.100.110 &File.エンコード指定(&E)\.\.\..開く(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :browse confirm e ++enc=euc-jisx0213<CR> + an 10.396.100.120 &File.エンコード指定(&E)\.\.\..開く(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :browse confirm e ++enc=iso-2022-jp-3<CR> + endif + an 10.396.100.130 &File.エンコード指定(&E)\.\.\..開く(&O)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :browse confirm e ++enc=utf-8<CR> + + " 再読込 + an 10.396.110.100 &File.エンコード指定(&E)\.\.\..再読込(&R)\.\.\..SJIS(&S)<Tab>fenc=cp932 :e ++enc=cp932<CR> + if !support_jisx0213 + an 10.396.110.110 &File.エンコード指定(&E)\.\.\..再読込(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jp :e ++enc=euc-jp<CR> + an 10.396.110.120 &File.エンコード指定(&E)\.\.\..再読込(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :e ++enc=iso-2022-jp<CR> + else + an 10.396.110.110 &File.エンコード指定(&E)\.\.\..再読込(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :e ++enc=euc-jisx0213<CR> + an 10.396.110.120 &File.エンコード指定(&E)\.\.\..再読込(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :e ++enc=iso-2022-jp-3<CR> + endif + an 10.396.110.130 &File.エンコード指定(&E)\.\.\..再読込(&R)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :e ++enc=utf-8<CR> + + " 保存 + an 10.396.115 &File.エンコード指定(&E)\.\.\..-SEP1- <Nop> + an 10.396.120.100 &File.エンコード指定(&E)\.\.\..保存(&S)\.\.\..SJIS(&S)<Tab>fenc=cp932 :set fenc=cp932 \| w<CR> + if !support_jisx0213 + an 10.396.120.110 &File.エンコード指定(&E)\.\.\..保存(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jp :set fenc=euc-jp \| w<CR> + an 10.396.120.120 &File.エンコード指定(&E)\.\.\..保存(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :set fenc=iso-2022-jp \| w<CR> + else + an 10.396.120.110 &File.エンコード指定(&E)\.\.\..保存(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :set fenc=euc-jisx0213 \| w<CR> + an 10.396.120.120 &File.エンコード指定(&E)\.\.\..保存(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :set fenc=iso-2022-jp-3 \| w<CR> + endif + an 10.396.120.130 &File.エンコード指定(&E)\.\.\..保存(&S)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :set fenc=utf-8 \| w<CR> +endif + +" filler to avoid the line above being recognized as a modeline +" filler +" filler +" filler diff --git a/share/vim/vim73/lang/menu_japanese_japan.932.vim b/share/vim/vim73/lang/menu_japanese_japan.932.vim new file mode 100644 index 0000000000..09976a9489 --- /dev/null +++ b/share/vim/vim73/lang/menu_japanese_japan.932.vim @@ -0,0 +1,338 @@ +" vi:set ts=8 sts=8 sw=8 tw=0: +" +" Menu Translations: Japanese (CP932) +" Translated By: MURAOKA Taro <koron@tka.att.ne.jp> +" Last Change: 18-Apr-2006. + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 + +scriptencoding cp932 + +" Help menu +menutrans &Help ƒwƒ‹ƒv(&H) +menutrans &Overview<Tab><F1> ŠT—ª(&O)<Tab><F1> +menutrans &User\ Manual ƒ†�[ƒUƒ}ƒjƒ…ƒAƒ‹(&U) +menutrans &How-to\ links &How-toƒŠƒ“ƒN +menutrans &Credits ƒNƒŒƒWƒbƒg(&C) +menutrans Co&pying ’˜�쌠�î•ñ(&P) +menutrans &Sponsor/Register ƒXƒ|ƒ“ƒT�[/“o˜^(&S) +menutrans O&rphans ŒÇŽ™(&R) +menutrans &Version ƒo�[ƒWƒ‡ƒ“�î•ñ(&V) +menutrans &About Vim‚ɂ‚¢‚Ä(&A) + +let g:menutrans_help_dialog = "ƒwƒ‹ƒv‚ðŒŸ�õ‚µ‚½‚¢ƒRƒ}ƒ“ƒh‚à‚µ‚­‚Í’PŒê‚ð“ü—Í‚µ‚Ä‚­‚¾‚³‚¢:\n\n‘}“üƒ‚�[ƒh‚̃Rƒ}ƒ“ƒh‚É‚Í i_ ‚ð�擪‚É•t‰Á‚µ‚Ü‚·. (—á: i_CTRL-X)\nƒRƒ}ƒ“ƒhƒ‰ƒCƒ“•Ò�WƒRƒ}ƒ“ƒh‚É‚Í c_ ‚ð�擪‚É•t‰Á‚µ‚Ü‚·. (—á: c_<Del>)\nƒIƒvƒVƒ‡ƒ“‚Ì–¼‘O‚É‚Í ' ‚ð•t‰Á‚µ‚Ü‚·. (—á: 'shiftwidth')" + +" File menu +menutrans &File ƒtƒ@ƒCƒ‹(&F) +menutrans &Open\.\.\.<Tab>:e ŠJ‚­(&O)\.\.\.<Tab>:e +menutrans Sp&lit-Open\.\.\.<Tab>:sp •ªŠ„‚µ‚ÄŠJ‚­(&L)\.\.\.<Tab>:sp +menutrans Open\ Tab\.\.\.<Tab>:tabnew ƒ^ƒuƒy�[ƒW‚ÅŠJ‚­<Tab>:tabnew +menutrans &New<Tab>:enew �V‹K�ì�¬(&N)<Tab>:enew +menutrans &Close<Tab>:close •Â‚¶‚é(&C)<Tab>:close +menutrans &Save<Tab>:w •Û‘¶(&S)<Tab>:w +menutrans Save\ &As\.\.\.<Tab>:sav –¼‘O‚ð•t‚¯‚Ä•Û‘¶(&A)\.\.\.<Tab>:sav +menutrans Split\ &Diff\ with\.\.\. �·•ª•\Ž¦(&D)\.\.\. +menutrans Split\ Patched\ &By\.\.\. ƒpƒbƒ`Œ‹‰Ê‚ð•\Ž¦(&B)\.\.\. +menutrans &Print ˆó�ü(&P) +menutrans Sa&ve-Exit<Tab>:wqa •Û‘¶‚µ‚Ä�I—¹(&V)<Tab>:wqa +menutrans E&xit<Tab>:qa �I—¹(&X)<Tab>:qa + +" Edit menu +menutrans &Edit •Ò�W(&E) +menutrans &Undo<Tab>u Žæ‚è�Á‚·(&U)<Tab>u +menutrans &Redo<Tab>^R ‚à‚¤ˆê“x‚â‚é(&R)<Tab>^R +menutrans Rep&eat<Tab>\. ŒJ‚è•Ô‚·(&E)<Tab>\. +menutrans Cu&t<Tab>"+x �Ø‚èŽæ‚è(&T)<Tab>"+x +menutrans &Copy<Tab>"+y ƒRƒs�[(&C)<Tab>"+y +menutrans &Paste<Tab>"+gP “\‚è•t‚¯(&P)<Tab>"+gP +menutrans Put\ &Before<Tab>[p ‘O‚É“\‚é(&B)<Tab>[p +menutrans Put\ &After<Tab>]p Œã‚É“\‚é(&A)<Tab>]p +menutrans &Delete<Tab>x �Á‚·(&D)<Tab>x +menutrans &Select\ All<Tab>ggVG ‘S‚Ä‘I‘ð(&S)<Tab>ggVG +menutrans &Find\.\.\. ŒŸ�õ(&F)\.\.\. +menutrans &Find<Tab>/ ŒŸ�õ(&F)<Tab>/ +menutrans Find\ and\ Rep&lace\.\.\. ’uŠ·(&L)\.\.\. +menutrans Find\ and\ Rep&lace<Tab>:%s ’uŠ·(&L)<Tab>:%s +menutrans Find\ and\ Rep&lace<Tab>:s ’uŠ·(&L)<Tab>:s +"menutrans Options\.\.\. ƒIƒvƒVƒ‡ƒ“(&O)\.\.\. +menutrans Settings\ &Window �Ý’èƒEƒBƒ“ƒhƒE(&W) +menutrans Startup\ &Settings ‹N“®Žž‚Ì�Ý’è(&S) + +" Edit/Global Settings +menutrans &Global\ Settings ‘S‘Ì�Ý’è(&G) +menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! + \ ƒpƒ^�[ƒ“‹­’²�Ø‘Ö(&H)<Tab>:set\ hls! +menutrans Toggle\ &Ignore-case<Tab>:set\ ic! + \ ‘å�¬•¶Žš‹æ•Ê�Ø‘Ö(&I)<Tab>:set\ ic! +menutrans Toggle\ &Showmatch<Tab>:set\ sm! + \ ƒ}ƒbƒ`•\Ž¦�Ø‘Ö(&S)<Tab>:set\ sm! +menutrans &Context\ lines ƒJ�[ƒ\ƒ‹Žü•Ó�s�”(&C) +menutrans &Virtual\ Edit ‰¼‘z•Ò�W(&V) +menutrans Never –³Œø +menutrans Block\ Selection ƒuƒ�ƒbƒN‘I‘ðŽž +menutrans Insert\ mode ‘}“üƒ‚�[ƒhŽž +menutrans Block\ and\ Insert ƒuƒ�ƒbƒN/‘}“üƒ‚�[ƒhŽž +menutrans Always �펞 +menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! + \ ‘}“ü(�‰�SŽÒ)ƒ‚�[ƒh�Ø‘Ö(&M)<Tab>:set\ im! +menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! + \ ViŒÝŠ·ƒ‚�[ƒh�Ø‘Ö(&O)<Tab>:set\ cp! +menutrans Search\ &Path\.\.\. ŒŸ�õƒpƒX(&P)\.\.\. +menutrans Ta&g\ Files\.\.\. ƒ^ƒOƒtƒ@ƒCƒ‹(&G)\.\.\. +" +" GUI options +menutrans Toggle\ &Toolbar ƒc�[ƒ‹ƒo�[•\Ž¦�Ø‘Ö(&T) +menutrans Toggle\ &Bottom\ Scrollbar ƒXƒNƒ��[ƒ‹ƒo�[(‰º)•\Ž¦�Ø‘Ö(&B) +menutrans Toggle\ &Left\ Scrollbar ƒXƒNƒ��[ƒ‹ƒo�[(�¶)•\Ž¦�Ø‘Ö(&L) +menutrans Toggle\ &Right\ Scrollbar ƒXƒNƒ��[ƒ‹ƒo�[(‰E)•\Ž¦�Ø‘Ö(&R) + +let g:menutrans_path_dialog = "ƒtƒ@ƒCƒ‹‚ÌŒŸ�õƒpƒX‚ð“ü—Í‚µ‚Ä‚­‚¾‚³‚¢:\nƒfƒBƒŒƒNƒgƒŠ–¼‚̓Jƒ“ƒ} ( , ) ‚Å‹æ�Ø‚Á‚Ä‚­‚¾‚³‚¢." +let g:menutrans_tags_dialog = "ƒ^ƒOƒtƒ@ƒCƒ‹‚Ì–¼‘O‚ð“ü—Í‚µ‚Ä‚­‚¾‚³‚¢:\n–¼‘O‚̓Jƒ“ƒ} ( , ) ‚Å‹æ�Ø‚Á‚Ä‚­‚¾‚³‚¢." + +" Edit/File Settings + +" Boolean options +menutrans F&ile\ Settings ƒtƒ@ƒCƒ‹�Ý’è(&I) +menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! + \ �s”Ô�†•\Ž¦�Ø‘Ö(&N)<Tab>:set\ nu! +menutrans Toggle\ &List\ Mode<Tab>:set\ list! + \ ƒŠƒXƒgƒ‚�[ƒh�Ø‘Ö(&L)<Tab>:set\ list! +menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! + \ �s�Ü•Ô‚µ�Ø‘Ö(&W)<Tab>:set\ wrap! +menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! + \ ’PŒê�Ü•Ô‚µ�Ø‘Ö(&R)<Tab>:set\ lbr! +menutrans Toggle\ &expand-tab<Tab>:set\ et! + \ ƒ^ƒu“WŠJ�Ø‘Ö(&E)<Tab>:set\ et! +menutrans Toggle\ &auto-indent<Tab>:set\ ai! + \ Ž©“®Žš‰º‚°�Ø‘Ö(&A)<Tab>:set\ ai! +menutrans Toggle\ &C-indenting<Tab>:set\ cin! + \ CŒ¾ŒêŽš‰º‚°�Ø‘Ö(&C)<Tab>:set\ cin! + +" other options +menutrans &Shiftwidth ƒVƒtƒg•�(&S) +menutrans Soft\ &Tabstop ƒ\ƒtƒgƒEƒFƒAƒ^ƒu•�(&T) +menutrans Te&xt\ Width\.\.\. ƒeƒLƒXƒg•�(&X)\.\.\. +menutrans &File\ Format\.\.\. ‰ü�s‹L�†‘I‘ð(&F)\.\.\. + +let g:menutrans_textwidth_dialog = "ƒeƒLƒXƒg‚Ì•�('textwidth')‚ð�ݒ肵‚Ä‚­‚¾‚³‚¢ (0‚Å�®Œ`‚𖳌ø‰»):" +let g:menutrans_fileformat_dialog = "ƒtƒ@ƒCƒ‹�o—Í‚Ì�ۂ̉ü�s‹L�†‚ÌŒ`Ž®‚ð‘I‚ñ‚Å‚­‚¾‚³‚¢." +let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\nƒLƒƒƒ“ƒZƒ‹(&C)" + +menutrans C&olor\ Scheme �Fƒe�[ƒ}‘I‘ð(&O) +menutrans &Keymap ƒL�[ƒ}ƒbƒv(&K) +menutrans None ‚È‚µ + +" Programming menu +menutrans &Tools ƒc�[ƒ‹(&T) +menutrans &Jump\ to\ this\ tag<Tab>g^] ƒ^ƒOƒWƒƒƒ“ƒv(&J)<Tab>g^] +menutrans Jump\ &back<Tab>^T –ß‚é(&B)<Tab>^T +menutrans Build\ &Tags\ File ƒ^ƒOƒtƒ@ƒCƒ‹�ì�¬(&T) +menutrans &Make<Tab>:make ƒ�ƒCƒN(&M)<Tab>:make +menutrans &List\ Errors<Tab>:cl ƒGƒ‰�[ƒŠƒXƒg(&L)<Tab>:cl +menutrans L&ist\ Messages<Tab>:cl! ƒ�ƒbƒZ�[ƒWƒŠƒXƒg(&I)<Tab>:cl! +menutrans &Next\ Error<Tab>:cn ŽŸ‚̃Gƒ‰�[‚Ö(&N)<Tab>:cn +menutrans &Previous\ Error<Tab>:cp ‘O‚̃Gƒ‰�[‚Ö(&P)<Tab>:cp +menutrans &Older\ List<Tab>:cold ŒÃ‚¢ƒŠƒXƒg(&O)<Tab>:cold +menutrans N&ewer\ List<Tab>:cnew �V‚µ‚¢ƒŠƒXƒg(&E)<Tab>:cnew +menutrans Error\ &Window ƒGƒ‰�[ƒEƒBƒ“ƒhƒE(&W) +menutrans &Update<Tab>:cwin �X�V(&U)<Tab>:cwin +menutrans &Open<Tab>:copen ŠJ‚­(&O)<Tab>:copen +menutrans &Close<Tab>:cclose •Â‚¶‚é(&C)<Tab>:cclose +menutrans &Convert\ to\ HEX<Tab>:%!xxd HEX‚Ö•ÏŠ·(&C)<Tab>:%!xxd +menutrans Conve&rt\ back<Tab>:%!xxd\ -r HEX‚©‚ç‹t•ÏŠ·(&R)<Tab>%!xxd\ -r +menutrans Se&T\ Compiler ƒRƒ“ƒpƒCƒ‰�Ý’è(&T) + +" Tools.Spelling Menu +menutrans &Spelling ƒXƒyƒŠƒ“ƒO(&S) +menutrans &Spell\ Check\ On ƒXƒyƒ‹ƒ`ƒFƒbƒN—LŒø(&S) +menutrans Spell\ Check\ &Off ƒXƒyƒ‹ƒ`ƒFƒbƒN—LŒø(&O) +menutrans To\ &Next\ error<Tab>]s ŽŸ‚̃Gƒ‰�[(&N)<Tab>]s +menutrans To\ &Previous\ error<Tab>[s ‘O‚̃Gƒ‰�[(&P)<Tab>[s +menutrans Suggest\ &Corrections<Tab>z= �C�³Œó•â(&C)<Tab>z= +menutrans &Repeat\ correction<Tab>:spellrepall �C�³‚ðŒJ‚è•Ô‚·(&R)<Tab>:spellrepall +menutrans Set\ language\ to\ "en" Œ¾Œê‚ð\ "en"\ ‚É�Ý’è‚·‚é +menutrans Set\ language\ to\ "en_au" Œ¾Œê‚ð\ "en_au"\ ‚É�Ý’è‚·‚é +menutrans Set\ language\ to\ "en_ca" Œ¾Œê‚ð\ "en_ca"\ ‚É�Ý’è‚·‚é +menutrans Set\ language\ to\ "en_gb" Œ¾Œê‚ð\ "en_gb"\ ‚É�Ý’è‚·‚é +menutrans Set\ language\ to\ "en_nz" Œ¾Œê‚ð\ "en_nz"\ ‚É�Ý’è‚·‚é +menutrans Set\ language\ to\ "en_us" Œ¾Œê‚ð\ "en_us"\ ‚É�Ý’è‚·‚é +menutrans &Find\ More\ Languages ‘¼‚ÌŒ¾Œê‚ðŒŸ�õ‚·‚é(&F) + +" Tools.Fold Menu +menutrans &Folding �Ü�ô‚Ý(&F) +" open close folds +menutrans &Enable/Disable\ folds<Tab>zi —LŒø/–³Œø�Ø‘Ö(&E)<Tab>zi +menutrans &View\ Cursor\ Line<Tab>zv ƒJ�[ƒ\ƒ‹�s‚ð•\Ž¦(&V)<Tab>zv +menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx ƒJ�[ƒ\ƒ‹�s‚¾‚¯‚ð•\Ž¦(&W)<Tab>zMzx +menutrans C&lose\ more\ folds<Tab>zm �Ü�ô‚Ý‚ð•Â‚¶‚é(&L)<Tab>zm +menutrans &Close\ all\ folds<Tab>zM ‘S�Ü�ô‚Ý‚ð•Â‚¶‚é(&C)<Tab>zM +menutrans O&pen\ more\ folds<Tab>zr �Ü�ô‚Ý‚ðŠJ‚­(&P)<Tab>zr +menutrans &Open\ all\ folds<Tab>zR ‘S�Ü�ô‚Ý‚ðŠJ‚­(&O)<Tab>zR +" fold method +menutrans Fold\ Met&hod �Ü�ô‚Ý•û–@(&H) +menutrans M&anual Žè“®(&A) +menutrans I&ndent ƒCƒ“ƒfƒ“ƒg(&N) +menutrans E&xpression Ž®•]‰¿(&X) +menutrans S&yntax ƒVƒ“ƒ^ƒbƒNƒX(&Y) +menutrans &Diff �·•ª(&D) +menutrans Ma&rker ƒ}�[ƒJ�[(&R) +" create and delete folds +menutrans Create\ &Fold<Tab>zf �Ü�ô‚Ý�ì�¬(&F)<Tab>zf +menutrans &Delete\ Fold<Tab>zd �Ü�ô‚Ý�í�œ(&D)<Tab>zd +menutrans Delete\ &All\ Folds<Tab>zD ‘S�Ü�ô‚Ý�í�œ(&A)<Tab>zD +" moving around in folds +menutrans Fold\ col&umn\ width �Ü�ô‚݃Jƒ‰ƒ€•�(&U) + +menutrans &Update �X�V(&U) +menutrans &Get\ Block ƒuƒ�ƒbƒN’Š�o(&G) +menutrans &Put\ Block ƒuƒ�ƒbƒN“K—p(&P) + +" Names for buffer menu. +menutrans &Buffers ƒoƒbƒtƒ@(&B) +menutrans &Refresh\ menu ƒ�ƒjƒ…�[�Ä“Ç�ž(&R) +menutrans &Delete �í�œ(&D) +menutrans &Alternate — ‚Ö�Ø‘Ö(&A) +menutrans &Next ŽŸ‚̃oƒbƒtƒ@(&N) +menutrans &Previous ‘O‚̃oƒbƒtƒ@(&P) +menutrans [No\ File] [–³‘è] +let g:menutrans_no_file = "[–³‘è]" + +" Window menu +menutrans &Window ƒEƒBƒ“ƒhƒE(&W) +menutrans &New<Tab>^Wn �V‹K�ì�¬(&N)<Tab>^Wn +menutrans S&plit<Tab>^Ws •ªŠ„(&P)<Tab>^Ws +menutrans Sp&lit\ To\ #<Tab>^W^^ — ƒoƒbƒtƒ@‚Ö•ªŠ„(&L)<Tab>^W^^ +menutrans Split\ &Vertically<Tab>^Wv �‚’¼•ªŠ„(&V)<Tab>^Wv +menutrans Split\ File\ E&xplorer ƒtƒ@ƒCƒ‹ƒGƒNƒXƒvƒ��[ƒ‰(&X) +menutrans &Close<Tab>^Wc •Â‚¶‚é(&C)<Tab>^Wc +menutrans Move\ &To ˆÚ“®(&T) +menutrans &Top<Tab>^WK �ã(&T)<Tab>^WK +menutrans &Bottom<Tab>^WJ ‰º(&B)<Tab>^WJ +menutrans &Left\ side<Tab>^WH �¶(&L)<Tab>^WH +menutrans &Right\ side<Tab>^WL ‰E(&R)<Tab>^WL +menutrans Close\ &Other(s)<Tab>^Wo ‘¼‚ð•Â‚¶‚é(&O)<Tab>^Wo +menutrans Ne&xt<Tab>^Ww ŽŸ‚Ö(&X)<Tab>^Ww +menutrans P&revious<Tab>^WW ‘O‚Ö(&R)<Tab>^WW +menutrans &Equal\ Size<Tab>^W= “¯‚¶�‚‚³‚É(&E)<Tab>^W= +menutrans &Max\ Height<Tab>^W_ �Å‘å�‚‚É(&M)<Tab>^W_ +menutrans M&in\ Height<Tab>^W1_ �Å�¬�‚‚É(&i)<Tab>^W1_ +menutrans Max\ &Width<Tab>^W\| �Å‘å•�‚É(&W)<Tab>^W\| +menutrans Min\ Widt&h<Tab>^W1\| �Å�¬•�‚É(&H)<Tab>^W1\| +menutrans Rotate\ &Up<Tab>^WR �ã‚Ƀ��[ƒe�[ƒVƒ‡ƒ“(&U)<Tab>^WR +menutrans Rotate\ &Down<Tab>^Wr ‰º‚Ƀ��[ƒe�[ƒVƒ‡ƒ“(&D)<Tab>^Wr +menutrans Select\ Fo&nt\.\.\. ƒtƒHƒ“ƒg�Ý’è(&N)\.\.\. + +" The popup menu +menutrans &Undo Žæ‚è�Á‚·(&U) +menutrans Cu&t �Ø‚èŽæ‚è(&T) +menutrans &Copy ƒRƒs�[(&C) +menutrans &Paste “\‚è•t‚¯(&P) +menutrans &Delete �í�œ(&D) +menutrans Select\ Blockwise ‹éŒ`ƒuƒ�ƒbƒN‘I‘ð +menutrans Select\ &Word ’PŒê‘I‘ð(&W) +menutrans Select\ &Line �s‘I‘ð(&L) +menutrans Select\ &Block ƒuƒ�ƒbƒN‘I‘ð(&B) +menutrans Select\ &All ‚·‚ׂđI‘ð(&A) + +" The GUI toolbar (for Win32 or GTK) +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open ƒtƒ@ƒCƒ‹‚ðŠJ‚­ + tmenu ToolBar.Save Œ»�݂̃tƒ@ƒCƒ‹‚ð•Û‘¶ + tmenu ToolBar.SaveAll ‚·‚ׂẴtƒ@ƒCƒ‹‚ð•Û‘¶ + tmenu ToolBar.Print ˆó�ü + tmenu ToolBar.Undo Žæ‚è�Á‚µ + tmenu ToolBar.Redo ‚à‚¤ˆê“x‚â‚é + tmenu ToolBar.Cut ƒNƒŠƒbƒvƒ{�[ƒh‚Ö�Ø‚èŽæ‚è + tmenu ToolBar.Copy ƒNƒŠƒbƒvƒ{�[ƒh‚ÖƒRƒs�[ + tmenu ToolBar.Paste ƒNƒŠƒbƒvƒ{�[ƒh‚©‚ç“\‚è•t‚¯ + tmenu ToolBar.Find ŒŸ�õ... + tmenu ToolBar.FindNext ŽŸ‚ðŒŸ�õ + tmenu ToolBar.FindPrev ‘O‚ðŒŸ�õ + tmenu ToolBar.Replace ’uŠ·... + if 0 " disabled; These are in the Windows menu + tmenu ToolBar.New �V‹KƒEƒBƒ“ƒhƒE�ì�¬ + tmenu ToolBar.WinSplit ƒEƒBƒ“ƒhƒE•ªŠ„ + tmenu ToolBar.WinMax ƒEƒBƒ“ƒhƒE�ő剻 + tmenu ToolBar.WinMin ƒEƒBƒ“ƒhƒE�Å�¬‰» + tmenu ToolBar.WinClose ƒEƒBƒ“ƒhƒE‚ð•Â‚¶‚é + endif + tmenu ToolBar.LoadSesn ƒZƒbƒVƒ‡ƒ““Ç�ž + tmenu ToolBar.SaveSesn ƒZƒbƒVƒ‡ƒ“•Û‘¶ + tmenu ToolBar.RunScript VimƒXƒNƒŠƒvƒgŽÀ�s + tmenu ToolBar.Make ƒvƒ�ƒWƒFƒNƒg‚ðMake + tmenu ToolBar.Shell ƒVƒFƒ‹‚ðŠJ‚­ + tmenu ToolBar.RunCtags tags�ì�¬ + tmenu ToolBar.TagJump ƒ^ƒOƒWƒƒƒ“ƒv + tmenu ToolBar.Help Vimƒwƒ‹ƒv + tmenu ToolBar.FindHelp Vimƒwƒ‹ƒvŒŸ�õ + endfun +endif + +" Syntax menu +menutrans &Syntax ƒVƒ“ƒ^ƒbƒNƒX(&S) +menutrans &Show\ filetypes\ in\ menu ‘ΉžŒ`Ž®‚ðƒ�ƒjƒ…�[‚É•\Ž¦(&S) +menutrans Set\ '&syntax'\ only 'syntax'‚¾‚¯�Ý’è(&S) +menutrans Set\ '&filetype'\ too 'filetype'‚à�Ý’è(&F) +menutrans &Off –³Œø‰»(&O) +menutrans &Manual Žè“®�Ý’è(&M) +menutrans A&utomatic Ž©“®�Ý’è(&U) +menutrans on/off\ for\ &This\ file + \ ƒIƒ“/ƒIƒt�Ø‘Ö(&T) +menutrans Co&lor\ test ƒJƒ‰�[ƒeƒXƒg(&L) +menutrans &Highlight\ test ƒnƒCƒ‰ƒCƒgƒeƒXƒg(&H) +menutrans &Convert\ to\ HTML HTML‚ÖƒRƒ“ƒo�[ƒg(&C) + +" Japanese specific menu +" �¬”Û‚ÍiconvŽŸ‘æ�A•K‚¸‚µ‚àŽw’肵‚½ƒGƒ“ƒR�[ƒh‚É‚È‚é‚킯‚Å‚Í‚È‚¢‚±‚Æ‚É’�ˆÓ +if has('iconv') + " iconv‚̃o�[ƒWƒ‡ƒ“”»’è + let support_jisx0213 = (iconv("\x87\x64\x87\x6a", 'cp932', 'euc-jisx0213') ==# "\xad\xc5\xad\xcb") ? 1 : 0 + " + " “Ç‚Ý�ž‚Ý + an 10.395 &File.-SEPICONV- <Nop> + an 10.396.100.100 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..SJIS(&S)<Tab>fenc=cp932 :browse confirm e ++enc=cp932<CR> + if !support_jisx0213 + an 10.396.100.110 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jp :browse confirm e ++enc=euc-jp<CR> + an 10.396.100.120 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :browse confirm e ++enc=iso-2022-jp<CR> + else + an 10.396.100.110 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :browse confirm e ++enc=euc-jisx0213<CR> + an 10.396.100.120 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :browse confirm e ++enc=iso-2022-jp-3<CR> + endif + an 10.396.100.130 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..ŠJ‚­(&O)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :browse confirm e ++enc=utf-8<CR> + + " �Ä“Ç�ž + an 10.396.110.100 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..SJIS(&S)<Tab>fenc=cp932 :e ++enc=cp932<CR> + if !support_jisx0213 + an 10.396.110.110 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jp :e ++enc=euc-jp<CR> + an 10.396.110.120 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :e ++enc=iso-2022-jp<CR> + else + an 10.396.110.110 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :e ++enc=euc-jisx0213<CR> + an 10.396.110.120 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :e ++enc=iso-2022-jp-3<CR> + endif + an 10.396.110.130 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..�Ä“Ç�ž(&R)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :e ++enc=utf-8<CR> + + " •Û‘¶ + an 10.396.115 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..-SEP1- <Nop> + an 10.396.120.100 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..SJIS(&S)<Tab>fenc=cp932 :set fenc=cp932 \| w<CR> + if !support_jisx0213 + an 10.396.120.110 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jp :set fenc=euc-jp \| w<CR> + an 10.396.120.120 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp :set fenc=iso-2022-jp \| w<CR> + else + an 10.396.120.110 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..EUC(&E)<Tab>fenc=euc-jisx0213 :set fenc=euc-jisx0213 \| w<CR> + an 10.396.120.120 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..JIS(&J)<Tab>fenc=iso-2022-jp-3 :set fenc=iso-2022-jp-3 \| w<CR> + endif + an 10.396.120.130 &File.ƒGƒ“ƒR�[ƒhŽw’è(&E)\.\.\..•Û‘¶(&S)\.\.\..UTF-8(&8)<Tab>fenc=utf-8 :set fenc=utf-8 \| w<CR> +endif + +" filler to avoid the line above being recognized as a modeline +" filler +" filler +" filler diff --git a/share/vim/vim72/lang/menu_ko.utf-8.vim b/share/vim/vim73/lang/menu_ko.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_ko.utf-8.vim rename to share/vim/vim73/lang/menu_ko.utf-8.vim diff --git a/share/vim/vim73/lang/menu_ko_kr.euckr.vim b/share/vim/vim73/lang/menu_ko_kr.euckr.vim new file mode 100644 index 0000000000..11809cf9c5 --- /dev/null +++ b/share/vim/vim73/lang/menu_ko_kr.euckr.vim @@ -0,0 +1,261 @@ +" Menu Translations: Korean +" Maintainer: SungHyun Nam <goweol@gmail.com> +" Last Change: 2010 Feb 18 + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 + +scriptencoding euc-kr + +" Help menu +menutrans &Help µµ¿ò¸»(&H) +menutrans &Overview<Tab><F1> °³°ü(&O)<Tab><F1> +menutrans &User\ Manual »ç¿ëÀÚ\ ¸Å´º¾ó(&U) +menutrans &How-to\ links ÇÏ¿ìÅõ\ ¸ñ·Ï(&H) +menutrans &GUI GUI(&G) +menutrans &Find\.\.\. ã±â(&F)\.\.\. +menutrans &Credits °í¸¶¿î\ ºÐ(&C) +menutrans Co&pying ÀúÀÛ±Ç(&p) +menutrans &Sponsor/Register ÈÄ¿ø/µî·Ï(&S) +menutrans O&rphans °í¾Æ(&r) +menutrans &Version ¹öÁ¯(&V) +menutrans &About ÀÌ\ ÇÁ·Î±×·¥Àº(&A) + +" File menu +menutrans &File ÆÄÀÏ(&F) +menutrans &Open\.\.\.<Tab>:e ¿­±â(&O)\.\.\.<Tab>:e +menutrans Sp&lit-Open\.\.\.<Tab>:sp ³ª´²¼­\ ¿­±â(&l)\.\.\.<Tab>:sp +menutrans Open\ Tab\.\.\.<Tab>:tabnew ÅÇ\ ¿­±â\.\.\.<Tab>:tabnew +menutrans &New<Tab>:enew »õ·Î¿î(&N)<Tab>:enew +menutrans &Close<Tab>:close ´Ý±â(&C)<Tab>:close +menutrans &Save<Tab>:w ÀúÀå(&S)<Tab>:w +menutrans Save\ &As\.\.\.<Tab>:sav ´Ù¸¥\ À̸§À¸·Î\ ÀúÀå(&A)\.\.\.<Tab>:sav +"menutrans Split\ &Diff\ with\.\.\. Split\ &Diff\ with\.\.\. +"menutrans Split\ Patched\ &By\.\.\. Split\ Patched\ &By\.\.\. +menutrans &Print Àμâ(&P) +menutrans Sa&ve-Exit<Tab>:wqa ÀúÀåÇÏ°í\ ³¡³»±â(&v)<Tab>:wqa +menutrans E&xit<Tab>:qa ³¡³»±â(&x)<Tab>:qa + +" Edit menu +menutrans &Edit ÆíÁý(&E) +menutrans &Undo<Tab>u Ãë¼Ò(&U)<Tab>u +menutrans &Redo<Tab>^R ´Ù½Ã ½ÇÇà(&R)<Tab>^R +menutrans Rep&eat<Tab>\. µÇÇ®ÀÌ(&e)<Tab>\. +menutrans Cu&t<Tab>"+x ÀÚ¸£±â(&t)<Tab>"+x +menutrans &Copy<Tab>"+y º¹»ç(&C)<Tab>"+y +menutrans &Paste<Tab>"+gP ºÙÀ̱â(&P)<Tab>"+gP +menutrans Put\ &Before<Tab>[p ¾Õ¿¡\ ºÙÀ̱â(&B)<Tab>[p +menutrans Put\ &After<Tab>]p µÚ¿¡\ ºÙÀ̱â(&A)<Tab>]p +menutrans &Delete<Tab>x Áö¿ì±â(&D)<Tab>x +menutrans &Select\ All<Tab>ggVG ¸ðµÎ\ °í¸£±â(&S)<Tab>ggVG +menutrans &Find\.\.\. ã±â(&F)\.\.\. +menutrans Find\ and\ Rep&lace\.\.\. ã¾Æ¼­\ ¹Ù²Ù±â(&l)\.\.\. +menutrans Settings\ &Window ¼³Á¤\ â(&W) +menutrans Startup\ &Settings ½ÃÀÛ\ ¼³Á¤(&S) + +" Edit/Global Settings +menutrans &Global\ Settings Àü¿ª\ ¼³Á¤(&G) +menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! ÆÐÅÏ\ ÇÏÀ̶óÀÌÆ®\ Åä±Û(&H)<Tab>:set\ hls! +menutrans Toggle\ &Ignore-case<Tab>:set\ ic! ´ë¼Ò¹®ÀÚ\ ±¸ºÐ\ Åä±Û(&I)<Tab>:set\ ic! +menutrans Toggle\ &Showmatch<Tab>:set\ sm! Showmatch\ Åä±Û(&S)<Tab>:set\ sm! +menutrans &Context\ lines ÄÜÅؽºÆ®\ ÁÙ(&C) +menutrans &Virtual\ Edit °¡»ó\ ÆíÁý(&V) +menutrans Never »ç¿ë ¾È ÇÔ +menutrans Block\ Selection ºí·°\ °í¸£±â +menutrans Insert\ mode »ðÀÔ\ ¸ðµå +menutrans Block\ and\ Insert ºí·°°ú\ »ðÀÔ +menutrans Always Ç×»ó\ »ç¿ë +menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! »ðÀÔ\ ¸ðµå\ Åä±Û(&M)<Tab>:set\ im! +menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Vi\ ȣȯ\ Åä±Û(&o)<Tab>:set\ cp! +menutrans Search\ &Path\.\.\. ã±â\ °æ·Î(&P)\.\.\. +menutrans Ta&g\ Files\.\.\. ²¿¸®Ç¥\ ÆÄÀÏ(&g)\.\.\. + +" GUI options +menutrans Toggle\ &Toolbar µµ±¸¸·´ë\ Åä±Û(&T) +menutrans Toggle\ &Bottom\ Scrollbar ¹Ù´Ú\ ½ºÅ©·Ñ¹Ù\ Åä±Û(&B) +menutrans Toggle\ &Left\ Scrollbar ¿ÞÂÊ\ ½ºÅ©·Ñ¹Ù\ Åä±Û(&L) +menutrans Toggle\ &Right\ Scrollbar ¿À¸¥ÂÊ\ ½ºÅ©·Ñ¹Ù\ Åä±Û(&R) + +" Edit/File Settings +menutrans F&ile\ Settings ÆÄÀÏ\ ¼³Á¤(&i) + +" Boolean options +menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! ÁÙ\ ¹øÈ£ºÙÀ̱â\ Åä±Û(&N)<Tab>:set\ nu! +menutrans Toggle\ &List\ Mode<Tab>:set\ list! ¸ñ·Ï\ ¸ðµå\ Åä±Û(&L)<Tab>:set\ list! +menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! ÁÙ\ Wrap\ Åä±Û(&W)<Tab>:set\ wrap! +menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! ³¹¸»¿¡¼­\ Wrap\ Åä±Û(&r)<Tab>:set\ lbr! +menutrans Toggle\ &expand-tab<Tab>:set\ et! ÅÇ\ È®Àå\ Åä±Û(&e)<Tab>:set\ et! +menutrans Toggle\ &auto-indent<Tab>:set\ ai! ÀÚµ¿Àε§Æ®\ Åä±Û(&a)<Tab>:set\ ai! +menutrans Toggle\ &C-indenting<Tab>:set\ cin! C-Àε§ÆÃ\ Åä±Û(&C)<Tab>:set\ cin! + +" other options +menutrans &Shiftwidth ½¬ÇÁÆ® ³Êºñ(&S) +menutrans Soft\ &Tabstop ¼ÒÇÁÆ®\ ÅǽºÅé(&T) +menutrans Te&xt\ Width\.\.\. ÅؽºÆ®\ ³Êºñ(&x)\.\.\. +menutrans &File\ Format\.\.\. ÆÄÀÏ\ Çü½Ä(&F)\.\.\. +menutrans C&olor\ Scheme Ä÷¯\ ½ºÅ´(&o) +menutrans &Keymap Å°¸Ê(&K) + +menutrans Select\ Fo&nt\.\.\. ±Û²Ã\ °í¸£±â(&F)\.\.\. + +" Programming menu +menutrans &Tools µµ±¸(&T) +menutrans &Jump\ to\ this\ tag<Tab>g^] ÀÌ\ ²¿¸®Ç¥·Î\ °¡±â(&J)<Tab>g^] +menutrans Jump\ &back<Tab>^T µÚ·Î\ °¡±â(&b)<Tab>^T +menutrans Build\ &Tags\ File ²¿¸®Ç¥\ ÆÄÀÏ\ ¸¸µé±â(&T) + +menutrans &Spelling ¸ÂÃã¹ý\ °Ë»ç(&S) +menutrans &Spell\ Check\ On ¸ÂÃã¹ý\ °Ë»ç\ ½ÃÀÛ(&S) +menutrans Spell\ Check\ &Off ¸ÂÃã¹ý\ °Ë»ç\ ³¡(&O) +menutrans To\ &Next\ error<Tab>]s ´ÙÀ½\ ¿¡·¯·Î(&N)<Tab>]s +menutrans To\ &Previous\ error<Tab>[s ÀÌÀü\ ¿¡·¯·Î(&P)<Tab>[s +menutrans Suggest\ &Corrections<Tab>z= ¼öÁ¤\ Á¦¾È(&C)<Tab>z= +menutrans &Repeat\ correction<Tab>:spellrepall ¼öÁ¤\ ¹Ýº¹(&R)<Tab>:spellrepall +menutrans Set\ language\ to\ "en" ¾ð¾î¸¦\ "en"À¸·Î\ ¼³Á¤ +menutrans Set\ language\ to\ "en_au" ¾ð¾î¸¦\ "en_au"·Î\ ¼³Á¤ +menutrans Set\ language\ to\ "en_ca" ¾ð¾î¸¦\ "en_ca"·Î\ ¼³Á¤ +menutrans Set\ language\ to\ "en_gb" ¾ð¾î¸¦\ "en_gb"·Î\ ¼³Á¤ +menutrans Set\ language\ to\ "en_nz" ¾ð¾î¸¦\ "en_nz"À¸·Î\ ¼³Á¤ +menutrans Set\ language\ to\ "en_us" ¾ð¾î¸¦\ "en_us"·Î\ ¼³Á¤ +menutrans &Find\ More\ Languages ´Ù¸¥\ ¾ð¾î\ ã±â(&F) + +" Tools.Fold Menu +menutrans &Folding Á¢±â(&F) +" open close folds +menutrans &Enable/Disable\ folds<Tab>zi Á¢´Â\ ±â´É\ »ç¿ë\ Åä±Û(&E)<Tab>zi +menutrans &View\ Cursor\ Line<Tab>zv Ä¿¼­\ ÁÙ\ º¸±â(&V)<Tab>zv +menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx Ä¿¼­\ ÁÙ¸¸\ º¸±â(&w)<Tab>zMzx +menutrans C&lose\ more\ folds<Tab>zm ´õ\ ¸¹Àº\ Á¢±â\ ´Ý±â(&l)<Tab>zm +menutrans &Close\ all\ folds<Tab>zM Á¢Èù\ ºÎºÐ\ ¸ðµÎ\ Á¢±â(&C)<Tab>zM +menutrans O&pen\ more\ folds<Tab>zr ´õ ¸¹Àº\ Á¢±â\ ¿­±â(&p)<Tab>zr +menutrans &Open\ all\ folds<Tab>zR Á¢Èù\ ºÎºÐ\ ¸ðµÎ\ Æì±â(&O)<Tab>zR +" fold method +menutrans Fold\ Met&hod Á¢´Â\ ¹æ¹ý(&h) +menutrans M&anual ¼öµ¿(&a) +menutrans I&ndent µé¿©¾²±â(&n) +menutrans E&xpression Ç¥Çö½Ä(&x) +menutrans S&yntax ½ÅÅýº(&y) +"menutrans &Diff &Diff +menutrans Ma&rker ²¿¸®Ç¥(&r) +" create and delete folds +menutrans Create\ &Fold<Tab>zf »õ·Î Á¢±â(&F)<Tab>zf +menutrans &Delete\ Fold<Tab>zd ¿ÏÀüÈ÷ Æì±â(&D)<Tab>zd +menutrans Delete\ &All\ Folds<Tab>zD ¸ðµÎ\ Æì±â(&A)<Tab>zD +" moving around in folds +menutrans Fold\ column\ &width Á¢À»\ Ä­\ ³Êºñ(&w) + +"menutrans &Diff &Diff +menutrans &Update °»½Å(&U) +menutrans &Get\ Block ºí·°\ °¡Á®¿À±â(&G) +menutrans &Put\ Block ºí·°\ Áý¾î³Ö±â(&P) + +menutrans &Make<Tab>:make ºôµå(&M)<Tab>:make +menutrans &List\ Errors<Tab>:cl ¿¡·¯\ ¸ñ·Ï\ º¸±â(&L)<Tab>:cl +menutrans L&ist\ Messages<Tab>:cl! ¸Þ½ÃÁö\ ¸ñ·Ï\ º¸±â(&i)<Tab>:cl! +menutrans &Next\ Error<Tab>:cn ´ÙÀ½\ ¿¡·¯(&N)<Tab>:cn +menutrans &Previous\ Error<Tab>:cp ÀÌÀü\ ¿¡·¯(&P)<Tab>:cp +menutrans &Older\ List<Tab>:cold ¿À·¡µÈ\ ¸ñ·Ï(&O)<Tab>:cold +menutrans N&ewer\ List<Tab>:cnew »õ·Î¿î\ ¸ñ·Ï(&e)<Tab>:cnew +menutrans Error\ &Window ¿¡·¯\ â(&W) +menutrans &Update<Tab>:cwin °»½Å(&U)<Tab>:cwin +menutrans &Open<Tab>:copen ¿­±â(&O)<Tab>:copen +menutrans &Close<Tab>:cclose ´Ý±â(&C)<Tab>:cclose +menutrans Se&T\ Compiler ÄÄÆÄÀÏ·¯\ ¼³Á¤(&T) +menutrans &Convert\ to\ HEX<Tab>:%!mc\ vim:xxd ½ÊÀ°ÁøÀ¸·Î\ º¯È¯<Tab>:%!mc\ vim:xxd +menutrans &Convert\ to\ HEX<Tab>:%!xxd ½ÊÀ°ÁøÀ¸·Î\ º¯È¯(&C)<Tab>:%!xxd +menutrans Conve&rt\ back<Tab>:%!mc\ vim:xxd\ -r ¿ø·¡´ë·Î\ º¯È¯(&r)<Tab>:%!mc\ vim:xxd\ -r +menutrans Conve&rt\ back<Tab>:%!xxd\ -r ¿ø·¡´ë·Î\ º¯È¯(&r)<Tab>:%!xxd\ -r + +" Names for buffer menu. +menutrans &Buffers ¹öÆÛ(&B) +menutrans &Refresh\ menu Â÷¸²Ç¥\ ´Ù½Ã±×¸®±â(&R) +menutrans &Delete Áö¿ì±â(&D) +menutrans &Alternate ±³Ã¼(&A) +menutrans &Next ´ÙÀ½(&N) +menutrans &Previous ÀÌÀü(&P) + +" Window menu +menutrans &Window â(&W) +menutrans &New<Tab>^Wn »õ\ â(&N)<Tab>^Wn +menutrans S&plit<Tab>^Ws ³ª´©±â(&p)<Tab>^Ws +menutrans Sp&lit\ To\ #<Tab>^W^^ #À¸·Î\ ³ª´©±â(&l)<Tab>^W^^ +menutrans Split\ &Vertically<Tab>^Wv ¼¼·Î·Î\ ³ª´©±â(&V)<Tab>^Wv +menutrans Split\ File\ E&xplorer ÆÄÀÏ\ ÀͽºÇ÷η¯\ ³ª´©±â + +menutrans &Close<Tab>^Wc ´Ý±â(&C)<Tab>^Wc +menutrans Close\ &Other(s)<Tab>^Wo ´Ù¸¥\ â\ ´Ý±â(&O)<Tab>^Wo + +menutrans Move\ &To À̵¿(&T) +menutrans &Top<Tab>^WK ²À´ë±â(&T)<Tab>^WK +menutrans &Bottom<Tab>^WJ ¹Ù´Ú(&B)<Tab>^WJ +menutrans &Left\ side<Tab>^WH ¿ÞÂÊ(&L)<Tab>^WH +menutrans &Right\ side<Tab>^WL ¿À¸¥ÂÊ(&R)<Tab>^WL +menutrans Rotate\ &Up<Tab>^WR À§·Î\ ȸÀü(&U)<Tab>^WR +menutrans Rotate\ &Down<Tab>^Wr ¾Æ·¡·Î\ ȸÀü(&D)<Tab>^Wr + +menutrans &Equal\ Size<Tab>^W= °°Àº\ ³ôÀÌ·Î(&E)<Tab>^W= +menutrans &Max\ Height<Tab>^W_ ÃÖ´ë\ ³ôÀÌ·Î(&M)<Tab>^W_ +menutrans M&in\ Height<Tab>^W1_ ÃÖ¼Ò\ ³ôÀÌ·Î(&i)<Tab>^W1_ +menutrans Max\ &Width<Tab>^W\| ÃÖ´ë\ ³ÐÀÌ·Î(&W)<Tab>^W\| +menutrans Min\ Widt&h<Tab>^W1\| ÃÖ¼Ò\ ³ÐÀÌ·Î(&h)<Tab>^W1\| + +" The popup menu +menutrans &Undo Ãë¼Ò(&U) +menutrans Cu&t ÀÚ¸£±â(&t) +menutrans &Copy º¹»ç(&C) +menutrans &Paste ºÙÀ̱â(&P) +menutrans &Delete Áö¿ì±â(&D) +menutrans Select\ Blockwise »ç°¢Çü\ °í¸£±â +menutrans Select\ &Word ³¹¸»\ °í¸£±â(&W) +menutrans Select\ &Line ÁÙ\ °í¸£±â(&L) +menutrans Select\ &Block ±¸È¹\ °í¸£±â(&B) +menutrans Select\ &All ¸ðµÎ\ °í¸£±â(&A) + +" The GUI toolbar +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open ÆÄÀÏ ¿­±â + tmenu ToolBar.Save ÇöÀç ÆÄÀÏ ÀúÀå + tmenu ToolBar.SaveAll ¸ðµÎ ÀúÀå + tmenu ToolBar.Print Àμâ + tmenu ToolBar.Undo Ãë¼Ò + tmenu ToolBar.Redo ´Ù½Ã ½ÇÇà + tmenu ToolBar.Cut ÀÚ¸£±â + tmenu ToolBar.Copy º¹»ç + tmenu ToolBar.Paste ºÙÀ̱â + tmenu ToolBar.Find ã±â... + tmenu ToolBar.FindNext ´ÙÀ½ ã±â + tmenu ToolBar.FindPrev ÀÌÀü ã±â + tmenu ToolBar.Replace ¹Ù²Ù±â + tmenu ToolBar.LoadSesn ¼¼¼Ç Àоî¿À±â + tmenu ToolBar.SaveSesn ¼¼¼Ç ÀúÀå + tmenu ToolBar.RunScript ½ºÅ©¸³Æ® ½ÇÇà + tmenu ToolBar.Make Make + tmenu ToolBar.Shell ½© + tmenu ToolBar.RunCtags ²¿¸®Ç¥ ¸¸µé±â + tmenu ToolBar.TagJump ²¿¸®Ç¥·Î °¡±â + tmenu ToolBar.Help µµ¿ò¸» + tmenu ToolBar.FindHelp µµ¿ò¸» ã±â... + endfun +endif + +" Syntax menu +menutrans &Syntax ¹®¹ý(&S) +menutrans &Show\ filetypes\ in\ menu ¸ðµç\ ¼±Åð¡´ÉÇÑ\ Ç׸ñ\ º¸±â(&S) +menutrans Set\ '&syntax'\ only 'syntax'¸¸\ ¼³Á¤(&s) +menutrans Set\ '&filetype'\ too 'filetype'µµ\ ¼³Á¤(&f) +menutrans &Off ²ô±â(&O) +menutrans &Manual ¼öµ¿(&M) +menutrans A&utomatic ÀÚµ¿(&u) +menutrans on/off\ for\ &This\ file ÀÌ\ ÆÄÀϸ¸\ Äѱâ/²ô±â(&T) + +menutrans Co&lor\ test »ö\ ½ÃÇè(&l) +menutrans &Highlight\ test Highlight\ ½ÃÇè(&H) +menutrans &Convert\ to\ HTML HTML·Î\ º¯È¯(&C) + diff --git a/share/vim/vim73/lang/menu_ko_kr.utf-8.vim b/share/vim/vim73/lang/menu_ko_kr.utf-8.vim new file mode 100644 index 0000000000..ef461737c0 --- /dev/null +++ b/share/vim/vim73/lang/menu_ko_kr.utf-8.vim @@ -0,0 +1,261 @@ +" Menu Translations: Korean +" Maintainer: SungHyun Nam <goweol@gmail.com> +" Last Change: 2010 Feb 18 + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 + +scriptencoding utf-8 + +" Help menu +menutrans &Help 도움말(&H) +menutrans &Overview<Tab><F1> 개관(&O)<Tab><F1> +menutrans &User\ Manual 사용자\ 매뉴얼(&U) +menutrans &How-to\ links 하우투\ 목록(&H) +menutrans &GUI GUI(&G) +menutrans &Find\.\.\. 찾기(&F)\.\.\. +menutrans &Credits 고마운\ 분(&C) +menutrans Co&pying 저작권(&p) +menutrans &Sponsor/Register 후원/등록(&S) +menutrans O&rphans 고아(&r) +menutrans &Version 버젼(&V) +menutrans &About 이\ 프로그램은(&A) + +" File menu +menutrans &File 파일(&F) +menutrans &Open\.\.\.<Tab>:e 열기(&O)\.\.\.<Tab>:e +menutrans Sp&lit-Open\.\.\.<Tab>:sp 나눠서\ 열기(&l)\.\.\.<Tab>:sp +menutrans Open\ Tab\.\.\.<Tab>:tabnew 탭\ 열기\.\.\.<Tab>:tabnew +menutrans &New<Tab>:enew 새로운(&N)<Tab>:enew +menutrans &Close<Tab>:close 닫기(&C)<Tab>:close +menutrans &Save<Tab>:w 저장(&S)<Tab>:w +menutrans Save\ &As\.\.\.<Tab>:sav 다른\ 이름으로\ 저장(&A)\.\.\.<Tab>:sav +"menutrans Split\ &Diff\ with\.\.\. Split\ &Diff\ with\.\.\. +"menutrans Split\ Patched\ &By\.\.\. Split\ Patched\ &By\.\.\. +menutrans &Print 인쇄(&P) +menutrans Sa&ve-Exit<Tab>:wqa 저장하고\ 끝내기(&v)<Tab>:wqa +menutrans E&xit<Tab>:qa 끝내기(&x)<Tab>:qa + +" Edit menu +menutrans &Edit 편집(&E) +menutrans &Undo<Tab>u 취소(&U)<Tab>u +menutrans &Redo<Tab>^R 다시 실행(&R)<Tab>^R +menutrans Rep&eat<Tab>\. 되풀이(&e)<Tab>\. +menutrans Cu&t<Tab>"+x 자르기(&t)<Tab>"+x +menutrans &Copy<Tab>"+y 복사(&C)<Tab>"+y +menutrans &Paste<Tab>"+gP 붙이기(&P)<Tab>"+gP +menutrans Put\ &Before<Tab>[p 앞에\ 붙이기(&B)<Tab>[p +menutrans Put\ &After<Tab>]p 뒤에\ 붙이기(&A)<Tab>]p +menutrans &Delete<Tab>x 지우기(&D)<Tab>x +menutrans &Select\ All<Tab>ggVG 모두\ 고르기(&S)<Tab>ggVG +menutrans &Find\.\.\. 찾기(&F)\.\.\. +menutrans Find\ and\ Rep&lace\.\.\. 찾아서\ 바꾸기(&l)\.\.\. +menutrans Settings\ &Window 설정\ 창(&W) +menutrans Startup\ &Settings 시작\ 설정(&S) + +" Edit/Global Settings +menutrans &Global\ Settings 전역\ 설정(&G) +menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! 패턴\ 하이라이트\ 토글(&H)<Tab>:set\ hls! +menutrans Toggle\ &Ignore-case<Tab>:set\ ic! 대소문자\ 구분\ 토글(&I)<Tab>:set\ ic! +menutrans Toggle\ &Showmatch<Tab>:set\ sm! Showmatch\ 토글(&S)<Tab>:set\ sm! +menutrans &Context\ lines 콘텍스트\ 줄(&C) +menutrans &Virtual\ Edit 가상\ 편집(&V) +menutrans Never 사용 안 함 +menutrans Block\ Selection 블럭\ 고르기 +menutrans Insert\ mode 삽입\ 모드 +menutrans Block\ and\ Insert 블럭과\ 삽입 +menutrans Always 항상\ 사용 +menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! 삽입\ 모드\ 토글(&M)<Tab>:set\ im! +menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Vi\ 호환\ 토글(&o)<Tab>:set\ cp! +menutrans Search\ &Path\.\.\. 찾기\ 경로(&P)\.\.\. +menutrans Ta&g\ Files\.\.\. 꼬리표\ 파일(&g)\.\.\. + +" GUI options +menutrans Toggle\ &Toolbar 도구막대\ 토글(&T) +menutrans Toggle\ &Bottom\ Scrollbar 바닥\ 스크롤바\ 토글(&B) +menutrans Toggle\ &Left\ Scrollbar 왼쪽\ 스크롤바\ 토글(&L) +menutrans Toggle\ &Right\ Scrollbar 오른쪽\ 스크롤바\ 토글(&R) + +" Edit/File Settings +menutrans F&ile\ Settings 파일\ 설정(&i) + +" Boolean options +menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! 줄\ 번호붙이기\ 토글(&N)<Tab>:set\ nu! +menutrans Toggle\ &List\ Mode<Tab>:set\ list! 목록\ 모드\ 토글(&L)<Tab>:set\ list! +menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! 줄\ Wrap\ 토글(&W)<Tab>:set\ wrap! +menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! 낱말에서\ Wrap\ 토글(&r)<Tab>:set\ lbr! +menutrans Toggle\ &expand-tab<Tab>:set\ et! 탭\ 확장\ 토글(&e)<Tab>:set\ et! +menutrans Toggle\ &auto-indent<Tab>:set\ ai! 자동인덴트\ 토글(&a)<Tab>:set\ ai! +menutrans Toggle\ &C-indenting<Tab>:set\ cin! C-인덴팅\ 토글(&C)<Tab>:set\ cin! + +" other options +menutrans &Shiftwidth 쉬프트 너비(&S) +menutrans Soft\ &Tabstop 소프트\ 탭스톱(&T) +menutrans Te&xt\ Width\.\.\. 텍스트\ 너비(&x)\.\.\. +menutrans &File\ Format\.\.\. 파일\ 형식(&F)\.\.\. +menutrans C&olor\ Scheme 컬러\ 스킴(&o) +menutrans &Keymap 키맵(&K) + +menutrans Select\ Fo&nt\.\.\. 글꼴\ 고르기(&F)\.\.\. + +" Programming menu +menutrans &Tools 도구(&T) +menutrans &Jump\ to\ this\ tag<Tab>g^] 이\ 꼬리표로\ 가기(&J)<Tab>g^] +menutrans Jump\ &back<Tab>^T 뒤로\ 가기(&b)<Tab>^T +menutrans Build\ &Tags\ File 꼬리표\ 파일\ 만들기(&T) + +menutrans &Spelling 맞춤법\ 검사(&S) +menutrans &Spell\ Check\ On 맞춤법\ 검사\ 시작(&S) +menutrans Spell\ Check\ &Off 맞춤법\ 검사\ 끝(&O) +menutrans To\ &Next\ error<Tab>]s 다음\ 에러로(&N)<Tab>]s +menutrans To\ &Previous\ error<Tab>[s 이전\ 에러로(&P)<Tab>[s +menutrans Suggest\ &Corrections<Tab>z= 수정\ 제안(&C)<Tab>z= +menutrans &Repeat\ correction<Tab>:spellrepall 수정\ 반복(&R)<Tab>:spellrepall +menutrans Set\ language\ to\ "en" 언어를\ "en"으로\ 설정 +menutrans Set\ language\ to\ "en_au" 언어를\ "en_au"로\ 설정 +menutrans Set\ language\ to\ "en_ca" 언어를\ "en_ca"로\ 설정 +menutrans Set\ language\ to\ "en_gb" 언어를\ "en_gb"로\ 설정 +menutrans Set\ language\ to\ "en_nz" 언어를\ "en_nz"으로\ 설정 +menutrans Set\ language\ to\ "en_us" 언어를\ "en_us"로\ 설정 +menutrans &Find\ More\ Languages 다른\ 언어\ 찾기(&F) + +" Tools.Fold Menu +menutrans &Folding 접기(&F) +" open close folds +menutrans &Enable/Disable\ folds<Tab>zi 접는\ 기능\ 사용\ 토글(&E)<Tab>zi +menutrans &View\ Cursor\ Line<Tab>zv 커서\ 줄\ 보기(&V)<Tab>zv +menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx 커서\ 줄만\ 보기(&w)<Tab>zMzx +menutrans C&lose\ more\ folds<Tab>zm 더\ 많은\ 접기\ 닫기(&l)<Tab>zm +menutrans &Close\ all\ folds<Tab>zM 접힌\ 부분\ 모두\ 접기(&C)<Tab>zM +menutrans O&pen\ more\ folds<Tab>zr 더 많은\ 접기\ 열기(&p)<Tab>zr +menutrans &Open\ all\ folds<Tab>zR 접힌\ 부분\ 모두\ 펴기(&O)<Tab>zR +" fold method +menutrans Fold\ Met&hod 접는\ 방법(&h) +menutrans M&anual 수동(&a) +menutrans I&ndent 들여쓰기(&n) +menutrans E&xpression 표현식(&x) +menutrans S&yntax 신택스(&y) +"menutrans &Diff &Diff +menutrans Ma&rker 꼬리표(&r) +" create and delete folds +menutrans Create\ &Fold<Tab>zf 새로 접기(&F)<Tab>zf +menutrans &Delete\ Fold<Tab>zd 완전히 펴기(&D)<Tab>zd +menutrans Delete\ &All\ Folds<Tab>zD 모두\ 펴기(&A)<Tab>zD +" moving around in folds +menutrans Fold\ column\ &width 접을\ 칸\ 너비(&w) + +"menutrans &Diff &Diff +menutrans &Update 갱신(&U) +menutrans &Get\ Block 블럭\ 가져오기(&G) +menutrans &Put\ Block 블럭\ 집어넣기(&P) + +menutrans &Make<Tab>:make 빌드(&M)<Tab>:make +menutrans &List\ Errors<Tab>:cl 에러\ 목록\ 보기(&L)<Tab>:cl +menutrans L&ist\ Messages<Tab>:cl! 메시지\ 목록\ 보기(&i)<Tab>:cl! +menutrans &Next\ Error<Tab>:cn 다음\ 에러(&N)<Tab>:cn +menutrans &Previous\ Error<Tab>:cp 이전\ 에러(&P)<Tab>:cp +menutrans &Older\ List<Tab>:cold 오래된\ 목록(&O)<Tab>:cold +menutrans N&ewer\ List<Tab>:cnew 새로운\ 목록(&e)<Tab>:cnew +menutrans Error\ &Window 에러\ 창(&W) +menutrans &Update<Tab>:cwin 갱신(&U)<Tab>:cwin +menutrans &Open<Tab>:copen 열기(&O)<Tab>:copen +menutrans &Close<Tab>:cclose 닫기(&C)<Tab>:cclose +menutrans Se&T\ Compiler 컴파일러\ 설정(&T) +menutrans &Convert\ to\ HEX<Tab>:%!mc\ vim:xxd 십육진으로\ 변환<Tab>:%!mc\ vim:xxd +menutrans &Convert\ to\ HEX<Tab>:%!xxd 십육진으로\ 변환(&C)<Tab>:%!xxd +menutrans Conve&rt\ back<Tab>:%!mc\ vim:xxd\ -r 원래대로\ 변환(&r)<Tab>:%!mc\ vim:xxd\ -r +menutrans Conve&rt\ back<Tab>:%!xxd\ -r 원래대로\ 변환(&r)<Tab>:%!xxd\ -r + +" Names for buffer menu. +menutrans &Buffers 버퍼(&B) +menutrans &Refresh\ menu 차림표\ 다시그리기(&R) +menutrans &Delete 지우기(&D) +menutrans &Alternate 교체(&A) +menutrans &Next 다음(&N) +menutrans &Previous 이전(&P) + +" Window menu +menutrans &Window 창(&W) +menutrans &New<Tab>^Wn 새\ 창(&N)<Tab>^Wn +menutrans S&plit<Tab>^Ws 나누기(&p)<Tab>^Ws +menutrans Sp&lit\ To\ #<Tab>^W^^ #으로\ 나누기(&l)<Tab>^W^^ +menutrans Split\ &Vertically<Tab>^Wv 세로로\ 나누기(&V)<Tab>^Wv +menutrans Split\ File\ E&xplorer 파일\ 익스플로러\ 나누기 + +menutrans &Close<Tab>^Wc 닫기(&C)<Tab>^Wc +menutrans Close\ &Other(s)<Tab>^Wo 다른\ 창\ 닫기(&O)<Tab>^Wo + +menutrans Move\ &To 이동(&T) +menutrans &Top<Tab>^WK 꼭대기(&T)<Tab>^WK +menutrans &Bottom<Tab>^WJ 바닥(&B)<Tab>^WJ +menutrans &Left\ side<Tab>^WH 왼쪽(&L)<Tab>^WH +menutrans &Right\ side<Tab>^WL 오른쪽(&R)<Tab>^WL +menutrans Rotate\ &Up<Tab>^WR 위로\ 회전(&U)<Tab>^WR +menutrans Rotate\ &Down<Tab>^Wr 아래로\ 회전(&D)<Tab>^Wr + +menutrans &Equal\ Size<Tab>^W= 같은\ 높이로(&E)<Tab>^W= +menutrans &Max\ Height<Tab>^W_ 최대\ 높이로(&M)<Tab>^W_ +menutrans M&in\ Height<Tab>^W1_ 최소\ 높이로(&i)<Tab>^W1_ +menutrans Max\ &Width<Tab>^W\| 최대\ 넓이로(&W)<Tab>^W\| +menutrans Min\ Widt&h<Tab>^W1\| 최소\ 넓이로(&h)<Tab>^W1\| + +" The popup menu +menutrans &Undo 취소(&U) +menutrans Cu&t 자르기(&t) +menutrans &Copy 복사(&C) +menutrans &Paste 붙이기(&P) +menutrans &Delete 지우기(&D) +menutrans Select\ Blockwise 사각형\ 고르기 +menutrans Select\ &Word 낱말\ 고르기(&W) +menutrans Select\ &Line 줄\ 고르기(&L) +menutrans Select\ &Block 구획\ 고르기(&B) +menutrans Select\ &All 모두\ 고르기(&A) + +" The GUI toolbar +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open 파일 열기 + tmenu ToolBar.Save 현재 파일 저장 + tmenu ToolBar.SaveAll 모두 저장 + tmenu ToolBar.Print 인쇄 + tmenu ToolBar.Undo 취소 + tmenu ToolBar.Redo 다시 실행 + tmenu ToolBar.Cut 자르기 + tmenu ToolBar.Copy 복사 + tmenu ToolBar.Paste 붙이기 + tmenu ToolBar.Find 찾기... + tmenu ToolBar.FindNext 다음 찾기 + tmenu ToolBar.FindPrev 이전 찾기 + tmenu ToolBar.Replace 바꾸기 + tmenu ToolBar.LoadSesn 세션 읽어오기 + tmenu ToolBar.SaveSesn 세션 저장 + tmenu ToolBar.RunScript 스크립트 실행 + tmenu ToolBar.Make Make + tmenu ToolBar.Shell 쉘 + tmenu ToolBar.RunCtags 꼬리표 만들기 + tmenu ToolBar.TagJump 꼬리표로 가기 + tmenu ToolBar.Help 도움말 + tmenu ToolBar.FindHelp 도움말 찾기... + endfun +endif + +" Syntax menu +menutrans &Syntax 문법(&S) +menutrans &Show\ filetypes\ in\ menu 모든\ 선택가능한\ 항목\ 보기(&S) +menutrans Set\ '&syntax'\ only 'syntax'만\ 설정(&s) +menutrans Set\ '&filetype'\ too 'filetype'도\ 설정(&f) +menutrans &Off 끄기(&O) +menutrans &Manual 수동(&M) +menutrans A&utomatic 자동(&u) +menutrans on/off\ for\ &This\ file 이\ 파일만\ 켜기/끄기(&T) + +menutrans Co&lor\ test 색\ 시험(&l) +menutrans &Highlight\ test Highlight\ 시험(&H) +menutrans &Convert\ to\ HTML HTML로\ 변환(&C) + diff --git a/share/vim/vim73/lang/menu_ko_kr.vim b/share/vim/vim73/lang/menu_ko_kr.vim new file mode 100644 index 0000000000..b67d0cc321 --- /dev/null +++ b/share/vim/vim73/lang/menu_ko_kr.vim @@ -0,0 +1,5 @@ +" Menu Translations: Korean +" Translated By: SungHyun Nam <goweol@gmail.com> +" Last Change: 2008 Sep 17 + +source <sfile>:p:h/menu_ko_kr.euckr.vim diff --git a/share/vim/vim72/lang/menu_nl.latin1.vim b/share/vim/vim73/lang/menu_nl.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_nl.latin1.vim rename to share/vim/vim73/lang/menu_nl.latin1.vim diff --git a/share/vim/vim72/lang/menu_nl.utf-8.vim b/share/vim/vim73/lang/menu_nl.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_nl.utf-8.vim rename to share/vim/vim73/lang/menu_nl.utf-8.vim diff --git a/share/vim/vim72/lang/menu_nl_nl.latin1.vim b/share/vim/vim73/lang/menu_nl_nl.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_nl_nl.latin1.vim rename to share/vim/vim73/lang/menu_nl_nl.latin1.vim diff --git a/share/vim/vim72/lang/menu_nl_nl.utf-8.vim b/share/vim/vim73/lang/menu_nl_nl.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_nl_nl.utf-8.vim rename to share/vim/vim73/lang/menu_nl_nl.utf-8.vim diff --git a/share/vim/vim72/lang/menu_no.latin1.vim b/share/vim/vim73/lang/menu_no.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_no.latin1.vim rename to share/vim/vim73/lang/menu_no.latin1.vim diff --git a/share/vim/vim72/lang/menu_no.utf-8.vim b/share/vim/vim73/lang/menu_no.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_no.utf-8.vim rename to share/vim/vim73/lang/menu_no.utf-8.vim diff --git a/share/vim/vim72/lang/menu_no_no.latin1.vim b/share/vim/vim73/lang/menu_no_no.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_no_no.latin1.vim rename to share/vim/vim73/lang/menu_no_no.latin1.vim diff --git a/share/vim/vim72/lang/menu_no_no.utf-8.vim b/share/vim/vim73/lang/menu_no_no.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_no_no.utf-8.vim rename to share/vim/vim73/lang/menu_no_no.utf-8.vim diff --git a/share/vim/vim72/lang/menu_pl.cp1250.vim b/share/vim/vim73/lang/menu_pl.cp1250.vim similarity index 100% rename from share/vim/vim72/lang/menu_pl.cp1250.vim rename to share/vim/vim73/lang/menu_pl.cp1250.vim diff --git a/share/vim/vim72/lang/menu_pl_pl.cp1250.vim b/share/vim/vim73/lang/menu_pl_pl.cp1250.vim similarity index 100% rename from share/vim/vim72/lang/menu_pl_pl.cp1250.vim rename to share/vim/vim73/lang/menu_pl_pl.cp1250.vim diff --git a/share/vim/vim73/lang/menu_pl_pl.iso_8859-2.vim b/share/vim/vim73/lang/menu_pl_pl.iso_8859-2.vim new file mode 100644 index 0000000000..021e1a7e65 --- /dev/null +++ b/share/vim/vim73/lang/menu_pl_pl.iso_8859-2.vim @@ -0,0 +1,287 @@ +" Menu Translations: Polish +" Maintainer: Mikolaj Machowski ( mikmach AT wp DOT pl ) +" Initial Translation: Marcin Dalecki <martin@dalecki.de> +" Last Change: 17 May 2010 + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 + +scriptencoding iso-8859-2 + +" Help menu +menutrans &Help Po&moc +menutrans &Overview<Tab><F1> &Ogólnie<Tab><F1> +menutrans &User\ Manual Podrêcznik\ &u¿ytkownika +menutrans &How-to\ links &Odno¶niki\ JTZ +menutrans &Find\.\.\. &Szukaj\.\.\. +menutrans &Credits Po&dziêkowania +menutrans Co&pying &Kopiowanie +menutrans &Sponsor/Register &Sponsorowanie/Rejestracja +menutrans O&rphans Sie&roty +menutrans &Version &Wersja +menutrans &About o\ &Programie + +" File menu +menutrans &File &Plik +menutrans &Open\.\.\.<Tab>:e &Otwórz\.\.\.<Tab>:e +menutrans Sp&lit-Open\.\.\.<Tab>:sp Otwórz\ z\ &podzia³em\.\.\.<Tab>:sp +menutrans &New<Tab>:enew &Nowy<Tab>:enew +menutrans &Close<Tab>:close &Zamknij<Tab>:close +menutrans &Save<Tab>:w Za&pisz<Tab>:w +menutrans Save\ &As\.\.\.<Tab>:sav Zapisz\ &jako\.\.\.<Tab>:sav +menutrans Split\ &Diff\ with\.\.\. Podziel\ na\ diff-a\ miêdzy\.\.\. +menutrans Split\ Patched\ &By\.\.\. Podziel\ ³atane\ przez\.\.\. +menutrans &Print &Drukuj +menutrans Sa&ve-Exit<Tab>:wqa W&yj¶cie\ z\ zapisem<Tab>:wqa +menutrans E&xit<Tab>:qa &Wyj¶cie<Tab>:qa +menutrans Open\ Tab\.\.\.<Tab>:tabnew Otwórz\ &kartê\.\.\.<Tab>:tabnew + +" Edit menu +menutrans &Edit &Edycja +menutrans &Undo<Tab>u &Cofnij<Tab>u +menutrans &Redo<Tab>^R &Ponów<Tab>^R +menutrans Rep&eat<Tab>\. P&owtórz<Tab>\. +menutrans Cu&t<Tab>"+x W&ytnij<Tab>"+x +menutrans &Copy<Tab>"+y &Kopiuj<Tab>"+y +menutrans &Paste<Tab>"+gP &Wklej<Tab>"+gP +menutrans Put\ &Before<Tab>[p Wstaw\ p&rzed<Tab>[p +menutrans Put\ &After<Tab>]p Wstaw\ p&o<Tab>]p +menutrans &Select\ All<Tab>ggVG Z&aznacz\ ca³o¶æ<Tab>ggVG +menutrans &Find\.\.\. &Szukaj\.\.\. +menutrans &Find<Tab>/ &Szukaj<Tab>/ +menutrans Find\ and\ Rep&lace\.\.\. &Zamieñ\.\.\. +menutrans Find\ and\ Rep&lace<Tab>:%s &Zamieñ<Tab>:%s +menutrans Find\ and\ Rep&lace &Zamieñ +menutrans Find\ and\ Rep&lace<Tab>:s &Zamieñ<Tab>:s +menutrans Options\.\.\. Opcje\.\.\. +menutrans Settings\ &Window Ustawienia +menutrans &Global\ Settings Ustawienia\ &globalne +menutrans Startup\ &Settings Ustawienia\ &startowe +menutrans F&ile\ Settings Ustawienia\ dla\ pliku +menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! &Numerowanie\ wierszy<Tab>:set\ nu! +menutrans Toggle\ &List\ Mode<Tab>:set\ list! Tryb\ &listowania<Tab>:set\ list! +menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! Za&wijanie\ wierszy<Tab>:set\ wrap! +menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! £amanie\ wie&rsza<Tab>:set\ lbr! +menutrans Toggle\ &expand-tab<Tab>:set\ et! Rozwijani&e\ tabulatorów<Tab>:set\ et! +menutrans Toggle\ &auto-indent<Tab>:set\ ai! &Automatyczne\ wciêcia<Tab>:set\ ai! +menutrans Toggle\ &C-indenting<Tab>:set\ cin! Wciêcia\ &C<Tab>:set\ cin! +menutrans &Shiftwidth &Szeroko¶æ\ wciêcia +menutrans Te&xt\ Width\.\.\. D³ugo¶æ\ linii\.\.\. +menutrans &File\ Format\.\.\. &Format\ pliku\.\.\. +menutrans Soft\ &Tabstop Rozmiar\ &tabulacji +menutrans C&olor\ Scheme Zestawy\ kolorów +menutrans &Keymap Uk³ady\ klawiatury +menutrans None ¿aden +menutrans accents akcenty +menutrans hebrew hebrajski +menutrans hebrewp hebrajski\ p +menutrans russian-jcuken rosyjski-jcuken +menutrans russian-jcukenwin rosyjski-jcukenwin + +menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! Pod¶wietlanie\ &wzorców<Tab>:set\ hls! + +menutrans Toggle\ &Ignore-case<Tab>:set\ ic! &Ignorowanie\ wielko¶ci<Tab>:set\ ic! +menutrans Toggle\ &Showmatch<Tab>:set\ sm! &Pokazywanie\ pasuj±cych<Tab>:set\ sm! + +menutrans &Context\ lines Wiersze\ &kontekstowe +menutrans &Virtual\ Edit Edycja\ &wirtualna + +menutrans Never Nigdy +menutrans Block\ Selection Zaznaczanie\ blokowe +menutrans Insert\ mode Tryb\ wprowadzania +menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Tryb\ zg&odno¶ci\ z\ Vi<Tab>:set\ cp! +menutrans Block\ and\ Insert Blokowe\ i\ wprowadzanie +menutrans Always Zawsze + +menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Tryb\ wprowadzania<Tab>:set\ im! +menutrans Search\ &Path\.\.\. Scie¿ka\ poszukiwania\.\.\. +menutrans Ta&g\ Files\.\.\. Pliki\ tagów\.\.\. + + +" +" GUI options +menutrans Toggle\ &Toolbar Pasek\ narzêdzi +menutrans Toggle\ &Bottom\ Scrollbar Dolny\ przewijacz +menutrans Toggle\ &Left\ Scrollbar &Lewy\ przewijacz +menutrans Toggle\ &Right\ Scrollbar P&rawy\ przewijacz + +" Programming menu +menutrans &Tools &Narzêdzia +menutrans &Jump\ to\ this\ tag<Tab>g^] &Skocz\ do\ taga<Tab>g^] +menutrans Jump\ &back<Tab>^T Skok\ w\ &ty³<Tab>^T +menutrans Build\ &Tags\ File &Twórz\ plik\ tagów +" Spelling +menutrans &Spelling Pi&sownia +menutrans &Spell\ Check\ On W³±cz +menutrans Spell\ Check\ &Off Wy³±cz +menutrans To\ &Next\ error<Tab>]s Do\ &nastêpnego\ b³êdu<Tab>]s +menutrans To\ &Previous\ error<Tab>[s Do\ &poprzedniego\ b³êdu<Tab>[s +menutrans Suggest\ &Corrections<Tab>z= Sugestie\ poprawek<Tab>z= +menutrans &Repeat\ correction<Tab>:spellrepall Powtór&z\ poprawkê<Tab>:spellrepall +menutrans Set\ language\ to\ "en" Ustaw\ jêzyk\ na\ "en" +menutrans Set\ language\ to\ "en_au" Ustaw\ jêzyk\ na\ "en_au" +menutrans Set\ language\ to\ "en_ca" Ustaw\ jêzyk\ na\ "en_ca" +menutrans Set\ language\ to\ "en_gb" Ustaw\ jêzyk\ na\ "en_gb" +menutrans Set\ language\ to\ "en_nz" Ustaw\ jêzyk\ na\ "en_nz" +menutrans Set\ language\ to\ "en_us" Ustaw\ jêzyk\ na\ "en_us" +menutrans Set\ language\ to\ "pl" Ustaw\ jêzyk\ na\ "pl" +menutrans &Find\ More\ Languages &Znajd¼\ wiêcej\ jêzyków + +" Folding +menutrans &Folding &Zwijanie +menutrans &Enable/Disable\ folds<Tab>zi &Zwiñ/rozwiñ<Tab>zi +menutrans &View\ Cursor\ Line<Tab>zv &Linia\ kursora<Tab>zv +menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx &Tylko\ linia\ kursora<Tab>zMzx +menutrans C&lose\ more\ folds<Tab>zm Zwiñ\ wiêcej<Tab>zm +menutrans &Close\ all\ folds<Tab>zM Z&wiñ\ wszystkie<Tab>zM +menutrans &Open\ all\ folds<Tab>zR Rozwiñ\ wszystkie<Tab>zR +menutrans O&pen\ more\ folds<Tab>zr R&ozwiñ\ wiêcej<Tab>zr + +menutrans Create\ &Fold<Tab>zf T&wórz\ zawiniêcie<Tab>zf +menutrans &Delete\ Fold<Tab>zd U&suñ\ zawiniêcie<Tab>zd +menutrans Delete\ &All\ Folds<Tab>zD &Usuñ\ wszystkie\ zawiniêcia<Tab>zD +menutrans Fold\ column\ &width Szeroko¶æ\ kolumny\ za&winiêæ +menutrans Fold\ Met&hod Me&toda\ zawijania +menutrans M&anual &Rêcznie +menutrans I&ndent W&ciêcie +menutrans E&xpression W&yra¿enie +menutrans S&yntax S&k³adnia +menutrans Ma&rker Zn&acznik + +" Diff +menutrans &Update &Od¶wie¿ +menutrans &Get\ Block &Pobierz\ blok +menutrans &Put\ Block &Wstaw\ blok + +" Make and stuff... +menutrans &Make<Tab>:make M&ake<Tab>:make +menutrans &List\ Errors<Tab>:cl &Poka¿\ b³êdy<Tab>:cl +menutrans L&ist\ Messages<Tab>:cl! W&ylicz\ powiadomienia<Tab>:cl! +menutrans &Next\ Error<Tab>:cn &Nastêpny\ b³±d<Tab>:cn +menutrans &Previous\ Error<Tab>:cp &Poprzedni\ b³±d<Tab>:cp +menutrans &Older\ List<Tab>:cold &Starsza\ lista<Tab>:cold +menutrans N&ewer\ List<Tab>:cnew N&owsza\ lista<Tab>:cnew +menutrans Error\ &Window Okno\ b³êdó&w +menutrans &Update<Tab>:cwin Akt&ualizuj<Tab>:cwin +menutrans &Close<Tab>:cclose &Zamknij<Tab>:cclose +menutrans &Open<Tab>:copen &Otwórz<Tab>:copen + +menutrans Se&T\ Compiler U&staw\ kompilator +menutrans &Convert\ to\ HEX<Tab>:%!xxd Kody\ szesnastkowe<Tab>:%!xxd +menutrans Conve&rt\ back<Tab>:%!xxd\ -r Zwyk³y\ tekst<Tab>:%!xxd\ -r + +" Names for buffer menu. +menutrans &Buffers &Bufory +menutrans &Refresh\ menu &Od¶wie¿ +menutrans &Delete &Skasuj +menutrans &Alternate &Zmieñ +menutrans &Next &Nastêpny +menutrans &Previous &Poprzedni +menutrans [No\ File] [Brak\ Pliku] + +" Window menu +menutrans &Window &Widoki +menutrans &New<Tab>^Wn &Nowy<Tab>^Wn +menutrans S&plit<Tab>^Ws Po&dziel<Tab>^Ws +menutrans Sp&lit\ To\ #<Tab>^W^^ P&odziel\ na\ #<Tab>^W^^ +menutrans Split\ &Vertically<Tab>^Wv Podziel\ pionowo<Tab>^Wv +menutrans Split\ File\ E&xplorer Otwórz\ mened¿er\ plików + +menutrans &Close<Tab>^Wc &Zamknij<Tab>^Wc +menutrans Close\ &Other(s)<Tab>^Wo Zamknij\ &inne<Tab>^Wo +menutrans Ne&xt<Tab>^Ww &Nastêpny<Tab>^Ww +menutrans P&revious<Tab>^WW &Poprzedni<Tab>^WW +menutrans &Equal\ Size<Tab>^W= &Wyrównaj\ wysoko¶ci<Tab>^W= +menutrans &Max\ Height<Tab>^W_ Z&maksymalizuj\ wysoko¶æ<Tab>^W_ +menutrans M&in\ Height<Tab>^W1_ Zminim&alizuj\ wysoko¶æ<Tab>^W1_ +menutrans Max\ Width<Tab>^W\| Maksymalna\ szeroko¶æ<Tab>^W\| +menutrans Min\ Width<Tab>^W1\| Minimalna\ szeroko¶æ<Tab>^W1\| +menutrans Max\ &Width<Tab>^W\| Zmaksymalizuj\ szeroko¶æ<Tab>^W\| +menutrans Min\ Widt&h<Tab>^W1\| Zminimalizuj\ szeroko¶æ<Tab>^W1\| +menutrans Move\ &To &Id¼\ do +menutrans &Top<Tab>^WK &Góra<Tab>^WK +menutrans &Bottom<Tab>^WJ &Dó³<Tab>^WJ +menutrans &Left\ side<Tab>^WH &Lewa\ strona<Tab>^WH +menutrans &Right\ side<Tab>^WL &Prawa\ strona<Tab>^WL +menutrans Rotate\ &Up<Tab>^WR Obróæ\ w\ &górê<Tab>^WR +menutrans Rotate\ &Down<Tab>^Wr Obróæ\ w\ &dó³<Tab>^Wr +menutrans Split\ &Vertically<Tab>^Wv &Podziel\ w\ poziomie<Tab>^Wv +menutrans Select\ Fo&nt\.\.\. Wybierz\ &czcionkê\.\.\. + +" The popup menu +menutrans &Undo &Cofnij +menutrans Cu&t W&ytnij +menutrans &Copy &Kopiuj +menutrans &Paste &Wklej +menutrans &Delete &Skasuj +menutrans Select\ Blockwise Zaznacz\ &blok +menutrans Select\ &Sentence Zaznacz\ &zdanie +menutrans Select\ Pa&ragraph Zaznacz\ aka&pit +menutrans Select\ &Word Zaznacz\ &s³owo +menutrans Select\ &Line Zaznacz\ w&iersz +menutrans Select\ &Block Zaznacz\ &blok +menutrans Select\ &All Zaznacz\ c&a³o¶æ +menutrans Input\ &Methods Wprowadza&nie + +" The GUI toolbar +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open Otwórz plik + tmenu ToolBar.Save Zapisz bie¿±cy plik + tmenu ToolBar.SaveAll Zapisz wszystkie pliki + tmenu ToolBar.Print Drukuj + tmenu ToolBar.Undo Cofnij + tmenu ToolBar.Redo Ponów + tmenu ToolBar.Cut Wytnij + tmenu ToolBar.Copy Skopiuj + tmenu ToolBar.Paste Wklej + tmenu ToolBar.Find Szukaj... + tmenu ToolBar.FindNext Szukaj nastêpnego + tmenu ToolBar.FindPrev Szukaj poprzedniego + tmenu ToolBar.Replace Szukaj i zamieniaj... + if 0 " disabled; These are in the Windows menu + tmenu ToolBar.New Nowy widok + tmenu ToolBar.WinSplit Podziel widok + tmenu ToolBar.WinMax Zmaksymalizuj widok + tmenu ToolBar.WinMin Zminimalizuj widok + tmenu ToolBar.WinClose Zamknij widok + endif + tmenu ToolBar.LoadSesn Za³aduj sesjê + tmenu ToolBar.SaveSesn Zachowaj bie¿±c± sesjê + tmenu ToolBar.RunScript Uruchom skrypt Vima + tmenu ToolBar.Make Wykonaj bie¿±cy projekt + tmenu ToolBar.Shell Otwórz pow³okê + tmenu ToolBar.RunCtags Twórz tagi w bie¿±cym katalogu + tmenu ToolBar.TagJump Skok do taga pod kursorem + tmenu ToolBar.Help Pomoc Vima + tmenu ToolBar.FindHelp Przeszukuj pomoc Vim-a + endfun +endif + +" Syntax menu +menutrans &Syntax &Sk³adnia +menutrans &Show\ filetypes\ in\ menu Poka¿\ typy\ &plików\ w\ menu +menutrans Set\ '&syntax'\ only Ustaw\ tylko\ '&syntax' +menutrans Set\ '&filetype'\ too Ustaw\ równie¿\ '&filetype' +menutrans &Off &Wy³±cz +menutrans &Manual &Rêcznie +menutrans A&utomatic A&utomatyczne +menutrans on/off\ for\ &This\ file w³±cz/w&y³±cz\ dla\ pliku +menutrans Co&lor\ test Test\ &kolorów +menutrans &Highlight\ test &Test\ pod¶wietlania +menutrans &Convert\ to\ HTML Przetwórz\ na\ &HTML + +" dialog texts +let menutrans_no_file = "[Brak pliku]" +let menutrans_help_dialog = "Wprowad¼ komendê lub s³owo, aby otrzymaæ pomoc o:\n\nPrzedrostek i_ oznacza komendê trybu Wprowadzania (np. i_CTRL-X)\nPrzedrostek c_ oznacza komendê edycji wiersza komend (np. c_<Del>)\nPrzedrostek ' oznacza nazwê opcji (np. 'shiftwidth')" +let g:menutrans_path_dialog = "Wprowad¼ ¶cie¿kê poszukiwania plików.\nProszê rozdzielaæ nazwy katalogów przecinkiem." +let g:menutrans_tags_dialog = "Podaj nazwy plików tagów.\nProszê rozdzielaæ nazwy przecinkiem." +let g:menutrans_textwidth_dialog = "Wprowad¼ now± szeroko¶æ tekstu (0 wy³±cza przewijanie): " +let g:menutrans_fileformat_dialog = "Wybierz format w którym ten plik ma byæ zapisany" +let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\n&Anuluj" diff --git a/share/vim/vim73/lang/menu_pl_pl.utf-8.vim b/share/vim/vim73/lang/menu_pl_pl.utf-8.vim new file mode 100644 index 0000000000..1d347dcde5 --- /dev/null +++ b/share/vim/vim73/lang/menu_pl_pl.utf-8.vim @@ -0,0 +1,287 @@ +" Menu Translations: Polish +" Maintainer: Mikolaj Machowski ( mikmach AT wp DOT pl ) +" Initial Translation: Marcin Dalecki <martin@dalecki.de> +" Last Change: 17 May 2010 + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 + +scriptencoding utf-8 + +" Help menu +menutrans &Help Po&moc +menutrans &Overview<Tab><F1> &Ogólnie<Tab><F1> +menutrans &User\ Manual Podręcznik\ &użytkownika +menutrans &How-to\ links &Odnośniki\ JTZ +menutrans &Find\.\.\. &Szukaj\.\.\. +menutrans &Credits Po&dziękowania +menutrans Co&pying &Kopiowanie +menutrans &Sponsor/Register &Sponsorowanie/Rejestracja +menutrans O&rphans Sie&roty +menutrans &Version &Wersja +menutrans &About o\ &Programie + +" File menu +menutrans &File &Plik +menutrans &Open\.\.\.<Tab>:e &Otwórz\.\.\.<Tab>:e +menutrans Sp&lit-Open\.\.\.<Tab>:sp Otwórz\ z\ &podziałem\.\.\.<Tab>:sp +menutrans &New<Tab>:enew &Nowy<Tab>:enew +menutrans &Close<Tab>:close &Zamknij<Tab>:close +menutrans &Save<Tab>:w Za&pisz<Tab>:w +menutrans Save\ &As\.\.\.<Tab>:sav Zapisz\ &jako\.\.\.<Tab>:sav +menutrans Split\ &Diff\ with\.\.\. Podziel\ na\ diff-a\ między\.\.\. +menutrans Split\ Patched\ &By\.\.\. Podziel\ łatane\ przez\.\.\. +menutrans &Print &Drukuj +menutrans Sa&ve-Exit<Tab>:wqa W&yjście\ z\ zapisem<Tab>:wqa +menutrans E&xit<Tab>:qa &Wyjście<Tab>:qa +menutrans Open\ Tab\.\.\.<Tab>:tabnew Otwórz\ &kartę\.\.\.<Tab>:tabnew + +" Edit menu +menutrans &Edit &Edycja +menutrans &Undo<Tab>u &Cofnij<Tab>u +menutrans &Redo<Tab>^R &Ponów<Tab>^R +menutrans Rep&eat<Tab>\. P&owtórz<Tab>\. +menutrans Cu&t<Tab>"+x W&ytnij<Tab>"+x +menutrans &Copy<Tab>"+y &Kopiuj<Tab>"+y +menutrans &Paste<Tab>"+gP &Wklej<Tab>"+gP +menutrans Put\ &Before<Tab>[p Wstaw\ p&rzed<Tab>[p +menutrans Put\ &After<Tab>]p Wstaw\ p&o<Tab>]p +menutrans &Select\ All<Tab>ggVG Z&aznacz\ całość<Tab>ggVG +menutrans &Find\.\.\. &Szukaj\.\.\. +menutrans &Find<Tab>/ &Szukaj<Tab>/ +menutrans Find\ and\ Rep&lace\.\.\. &Zamień\.\.\. +menutrans Find\ and\ Rep&lace<Tab>:%s &Zamień<Tab>:%s +menutrans Find\ and\ Rep&lace &Zamień +menutrans Find\ and\ Rep&lace<Tab>:s &Zamień<Tab>:s +menutrans Options\.\.\. Opcje\.\.\. +menutrans Settings\ &Window Ustawienia +menutrans &Global\ Settings Ustawienia\ &globalne +menutrans Startup\ &Settings Ustawienia\ &startowe +menutrans F&ile\ Settings Ustawienia\ dla\ pliku +menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! &Numerowanie\ wierszy<Tab>:set\ nu! +menutrans Toggle\ &List\ Mode<Tab>:set\ list! Tryb\ &listowania<Tab>:set\ list! +menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! Za&wijanie\ wierszy<Tab>:set\ wrap! +menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! Łamanie\ wie&rsza<Tab>:set\ lbr! +menutrans Toggle\ &expand-tab<Tab>:set\ et! Rozwijani&e\ tabulatorów<Tab>:set\ et! +menutrans Toggle\ &auto-indent<Tab>:set\ ai! &Automatyczne\ wcięcia<Tab>:set\ ai! +menutrans Toggle\ &C-indenting<Tab>:set\ cin! Wcięcia\ &C<Tab>:set\ cin! +menutrans &Shiftwidth &Szerokość\ wcięcia +menutrans Te&xt\ Width\.\.\. Długość\ linii\.\.\. +menutrans &File\ Format\.\.\. &Format\ pliku\.\.\. +menutrans Soft\ &Tabstop Rozmiar\ &tabulacji +menutrans C&olor\ Scheme Zestawy\ kolorów +menutrans &Keymap Układy\ klawiatury +menutrans None żaden +menutrans accents akcenty +menutrans hebrew hebrajski +menutrans hebrewp hebrajski\ p +menutrans russian-jcuken rosyjski-jcuken +menutrans russian-jcukenwin rosyjski-jcukenwin + +menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! Podświetlanie\ &wzorców<Tab>:set\ hls! + +menutrans Toggle\ &Ignore-case<Tab>:set\ ic! &Ignorowanie\ wielkości<Tab>:set\ ic! +menutrans Toggle\ &Showmatch<Tab>:set\ sm! &Pokazywanie\ pasujących<Tab>:set\ sm! + +menutrans &Context\ lines Wiersze\ &kontekstowe +menutrans &Virtual\ Edit Edycja\ &wirtualna + +menutrans Never Nigdy +menutrans Block\ Selection Zaznaczanie\ blokowe +menutrans Insert\ mode Tryb\ wprowadzania +menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Tryb\ zg&odności\ z\ Vi<Tab>:set\ cp! +menutrans Block\ and\ Insert Blokowe\ i\ wprowadzanie +menutrans Always Zawsze + +menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Tryb\ wprowadzania<Tab>:set\ im! +menutrans Search\ &Path\.\.\. Scieżka\ poszukiwania\.\.\. +menutrans Ta&g\ Files\.\.\. Pliki\ tagów\.\.\. + + +" +" GUI options +menutrans Toggle\ &Toolbar Pasek\ narzędzi +menutrans Toggle\ &Bottom\ Scrollbar Dolny\ przewijacz +menutrans Toggle\ &Left\ Scrollbar &Lewy\ przewijacz +menutrans Toggle\ &Right\ Scrollbar P&rawy\ przewijacz + +" Programming menu +menutrans &Tools &Narzędzia +menutrans &Jump\ to\ this\ tag<Tab>g^] &Skocz\ do\ taga<Tab>g^] +menutrans Jump\ &back<Tab>^T Skok\ w\ &tył<Tab>^T +menutrans Build\ &Tags\ File &Twórz\ plik\ tagów +" Spelling +menutrans &Spelling Pi&sownia +menutrans &Spell\ Check\ On Włącz +menutrans Spell\ Check\ &Off Wyłącz +menutrans To\ &Next\ error<Tab>]s Do\ &następnego\ błędu<Tab>]s +menutrans To\ &Previous\ error<Tab>[s Do\ &poprzedniego\ błędu<Tab>[s +menutrans Suggest\ &Corrections<Tab>z= Sugestie\ poprawek<Tab>z= +menutrans &Repeat\ correction<Tab>:spellrepall Powtór&z\ poprawkę<Tab>:spellrepall +menutrans Set\ language\ to\ "en" Ustaw\ język\ na\ "en" +menutrans Set\ language\ to\ "en_au" Ustaw\ język\ na\ "en_au" +menutrans Set\ language\ to\ "en_ca" Ustaw\ język\ na\ "en_ca" +menutrans Set\ language\ to\ "en_gb" Ustaw\ język\ na\ "en_gb" +menutrans Set\ language\ to\ "en_nz" Ustaw\ język\ na\ "en_nz" +menutrans Set\ language\ to\ "en_us" Ustaw\ język\ na\ "en_us" +menutrans Set\ language\ to\ "pl" Ustaw\ język\ na\ "pl" +menutrans &Find\ More\ Languages &Znajdź\ więcej\ języków + +" Folding +menutrans &Folding &Zwijanie +menutrans &Enable/Disable\ folds<Tab>zi &Zwiń/rozwiń<Tab>zi +menutrans &View\ Cursor\ Line<Tab>zv &Linia\ kursora<Tab>zv +menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx &Tylko\ linia\ kursora<Tab>zMzx +menutrans C&lose\ more\ folds<Tab>zm Zwiń\ więcej<Tab>zm +menutrans &Close\ all\ folds<Tab>zM Z&wiń\ wszystkie<Tab>zM +menutrans &Open\ all\ folds<Tab>zR Rozwiń\ wszystkie<Tab>zR +menutrans O&pen\ more\ folds<Tab>zr R&ozwiń\ więcej<Tab>zr + +menutrans Create\ &Fold<Tab>zf T&wórz\ zawinięcie<Tab>zf +menutrans &Delete\ Fold<Tab>zd U&suń\ zawinięcie<Tab>zd +menutrans Delete\ &All\ Folds<Tab>zD &Usuń\ wszystkie\ zawinięcia<Tab>zD +menutrans Fold\ column\ &width Szerokość\ kolumny\ za&winięć +menutrans Fold\ Met&hod Me&toda\ zawijania +menutrans M&anual &Ręcznie +menutrans I&ndent W&cięcie +menutrans E&xpression W&yrażenie +menutrans S&yntax S&kładnia +menutrans Ma&rker Zn&acznik + +" Diff +menutrans &Update &Odśwież +menutrans &Get\ Block &Pobierz\ blok +menutrans &Put\ Block &Wstaw\ blok + +" Make and stuff... +menutrans &Make<Tab>:make M&ake<Tab>:make +menutrans &List\ Errors<Tab>:cl &Pokaż\ błędy<Tab>:cl +menutrans L&ist\ Messages<Tab>:cl! W&ylicz\ powiadomienia<Tab>:cl! +menutrans &Next\ Error<Tab>:cn &Następny\ błąd<Tab>:cn +menutrans &Previous\ Error<Tab>:cp &Poprzedni\ błąd<Tab>:cp +menutrans &Older\ List<Tab>:cold &Starsza\ lista<Tab>:cold +menutrans N&ewer\ List<Tab>:cnew N&owsza\ lista<Tab>:cnew +menutrans Error\ &Window Okno\ błędó&w +menutrans &Update<Tab>:cwin Akt&ualizuj<Tab>:cwin +menutrans &Close<Tab>:cclose &Zamknij<Tab>:cclose +menutrans &Open<Tab>:copen &Otwórz<Tab>:copen + +menutrans Se&T\ Compiler U&staw\ kompilator +menutrans &Convert\ to\ HEX<Tab>:%!xxd Kody\ szesnastkowe<Tab>:%!xxd +menutrans Conve&rt\ back<Tab>:%!xxd\ -r Zwykły\ tekst<Tab>:%!xxd\ -r + +" Names for buffer menu. +menutrans &Buffers &Bufory +menutrans &Refresh\ menu &Odśwież +menutrans &Delete &Skasuj +menutrans &Alternate &Zmień +menutrans &Next &Następny +menutrans &Previous &Poprzedni +menutrans [No\ File] [Brak\ Pliku] + +" Window menu +menutrans &Window &Widoki +menutrans &New<Tab>^Wn &Nowy<Tab>^Wn +menutrans S&plit<Tab>^Ws Po&dziel<Tab>^Ws +menutrans Sp&lit\ To\ #<Tab>^W^^ P&odziel\ na\ #<Tab>^W^^ +menutrans Split\ &Vertically<Tab>^Wv Podziel\ pionowo<Tab>^Wv +menutrans Split\ File\ E&xplorer Otwórz\ menedżer\ plików + +menutrans &Close<Tab>^Wc &Zamknij<Tab>^Wc +menutrans Close\ &Other(s)<Tab>^Wo Zamknij\ &inne<Tab>^Wo +menutrans Ne&xt<Tab>^Ww &Następny<Tab>^Ww +menutrans P&revious<Tab>^WW &Poprzedni<Tab>^WW +menutrans &Equal\ Size<Tab>^W= &Wyrównaj\ wysokości<Tab>^W= +menutrans &Max\ Height<Tab>^W_ Z&maksymalizuj\ wysokość<Tab>^W_ +menutrans M&in\ Height<Tab>^W1_ Zminim&alizuj\ wysokość<Tab>^W1_ +menutrans Max\ Width<Tab>^W\| Maksymalna\ szerokość<Tab>^W\| +menutrans Min\ Width<Tab>^W1\| Minimalna\ szerokość<Tab>^W1\| +menutrans Max\ &Width<Tab>^W\| Zmaksymalizuj\ szerokość<Tab>^W\| +menutrans Min\ Widt&h<Tab>^W1\| Zminimalizuj\ szerokość<Tab>^W1\| +menutrans Move\ &To &Idź\ do +menutrans &Top<Tab>^WK &Góra<Tab>^WK +menutrans &Bottom<Tab>^WJ &Dół<Tab>^WJ +menutrans &Left\ side<Tab>^WH &Lewa\ strona<Tab>^WH +menutrans &Right\ side<Tab>^WL &Prawa\ strona<Tab>^WL +menutrans Rotate\ &Up<Tab>^WR Obróć\ w\ &górę<Tab>^WR +menutrans Rotate\ &Down<Tab>^Wr Obróć\ w\ &dół<Tab>^Wr +menutrans Split\ &Vertically<Tab>^Wv &Podziel\ w\ poziomie<Tab>^Wv +menutrans Select\ Fo&nt\.\.\. Wybierz\ &czcionkę\.\.\. + +" The popup menu +menutrans &Undo &Cofnij +menutrans Cu&t W&ytnij +menutrans &Copy &Kopiuj +menutrans &Paste &Wklej +menutrans &Delete &Skasuj +menutrans Select\ Blockwise Zaznacz\ &blok +menutrans Select\ &Sentence Zaznacz\ &zdanie +menutrans Select\ Pa&ragraph Zaznacz\ aka&pit +menutrans Select\ &Word Zaznacz\ &słowo +menutrans Select\ &Line Zaznacz\ w&iersz +menutrans Select\ &Block Zaznacz\ &blok +menutrans Select\ &All Zaznacz\ c&ałość +menutrans Input\ &Methods Wprowadza&nie + +" The GUI toolbar +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open Otwórz plik + tmenu ToolBar.Save Zapisz bieżący plik + tmenu ToolBar.SaveAll Zapisz wszystkie pliki + tmenu ToolBar.Print Drukuj + tmenu ToolBar.Undo Cofnij + tmenu ToolBar.Redo Ponów + tmenu ToolBar.Cut Wytnij + tmenu ToolBar.Copy Skopiuj + tmenu ToolBar.Paste Wklej + tmenu ToolBar.Find Szukaj... + tmenu ToolBar.FindNext Szukaj następnego + tmenu ToolBar.FindPrev Szukaj poprzedniego + tmenu ToolBar.Replace Szukaj i zamieniaj... + if 0 " disabled; These are in the Windows menu + tmenu ToolBar.New Nowy widok + tmenu ToolBar.WinSplit Podziel widok + tmenu ToolBar.WinMax Zmaksymalizuj widok + tmenu ToolBar.WinMin Zminimalizuj widok + tmenu ToolBar.WinClose Zamknij widok + endif + tmenu ToolBar.LoadSesn Załaduj sesję + tmenu ToolBar.SaveSesn Zachowaj bieżącą sesję + tmenu ToolBar.RunScript Uruchom skrypt Vima + tmenu ToolBar.Make Wykonaj bieżący projekt + tmenu ToolBar.Shell Otwórz powłokę + tmenu ToolBar.RunCtags Twórz tagi w bieżącym katalogu + tmenu ToolBar.TagJump Skok do taga pod kursorem + tmenu ToolBar.Help Pomoc Vima + tmenu ToolBar.FindHelp Przeszukuj pomoc Vim-a + endfun +endif + +" Syntax menu +menutrans &Syntax &Składnia +menutrans &Show\ filetypes\ in\ menu Pokaż\ typy\ &plików\ w\ menu +menutrans Set\ '&syntax'\ only Ustaw\ tylko\ '&syntax' +menutrans Set\ '&filetype'\ too Ustaw\ również\ '&filetype' +menutrans &Off &Wyłącz +menutrans &Manual &Ręcznie +menutrans A&utomatic A&utomatyczne +menutrans on/off\ for\ &This\ file włącz/w&yłącz\ dla\ pliku +menutrans Co&lor\ test Test\ &kolorów +menutrans &Highlight\ test &Test\ podświetlania +menutrans &Convert\ to\ HTML Przetwórz\ na\ &HTML + +" dialog texts +let menutrans_no_file = "[Brak pliku]" +let menutrans_help_dialog = "Wprowadź komendę lub słowo, aby otrzymać pomoc o:\n\nPrzedrostek i_ oznacza komendę trybu Wprowadzania (np. i_CTRL-X)\nPrzedrostek c_ oznacza komendę edycji wiersza komend (np. c_<Del>)\nPrzedrostek ' oznacza nazwę opcji (np. 'shiftwidth')" +let g:menutrans_path_dialog = "Wprowadź ścieżkę poszukiwania plików.\nProszę rozdzielać nazwy katalogów przecinkiem." +let g:menutrans_tags_dialog = "Podaj nazwy plików tagów.\nProszę rozdzielać nazwy przecinkiem." +let g:menutrans_textwidth_dialog = "Wprowadź nową szerokość tekstu (0 wyłącza przewijanie): " +let g:menutrans_fileformat_dialog = "Wybierz format w którym ten plik ma być zapisany" +let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\n&Anuluj" diff --git a/share/vim/vim73/lang/menu_polish_poland.1250.vim b/share/vim/vim73/lang/menu_polish_poland.1250.vim new file mode 100644 index 0000000000..398b18daf9 --- /dev/null +++ b/share/vim/vim73/lang/menu_polish_poland.1250.vim @@ -0,0 +1,287 @@ +" Menu Translations: Polish +" Maintainer: Mikolaj Machowski ( mikmach AT wp DOT pl ) +" Initial Translation: Marcin Dalecki <martin@dalecki.de> +" Last Change: 17 May 2010 + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 + +scriptencoding cp1250 + +" Help menu +menutrans &Help Po&moc +menutrans &Overview<Tab><F1> &Ogólnie<Tab><F1> +menutrans &User\ Manual Podrêcznik\ &u¿ytkownika +menutrans &How-to\ links &Odnoœniki\ JTZ +menutrans &Find\.\.\. &Szukaj\.\.\. +menutrans &Credits Po&dziêkowania +menutrans Co&pying &Kopiowanie +menutrans &Sponsor/Register &Sponsorowanie/Rejestracja +menutrans O&rphans Sie&roty +menutrans &Version &Wersja +menutrans &About o\ &Programie + +" File menu +menutrans &File &Plik +menutrans &Open\.\.\.<Tab>:e &Otwórz\.\.\.<Tab>:e +menutrans Sp&lit-Open\.\.\.<Tab>:sp Otwórz\ z\ &podzia³em\.\.\.<Tab>:sp +menutrans &New<Tab>:enew &Nowy<Tab>:enew +menutrans &Close<Tab>:close &Zamknij<Tab>:close +menutrans &Save<Tab>:w Za&pisz<Tab>:w +menutrans Save\ &As\.\.\.<Tab>:sav Zapisz\ &jako\.\.\.<Tab>:sav +menutrans Split\ &Diff\ with\.\.\. Podziel\ na\ diff-a\ miêdzy\.\.\. +menutrans Split\ Patched\ &By\.\.\. Podziel\ ³atane\ przez\.\.\. +menutrans &Print &Drukuj +menutrans Sa&ve-Exit<Tab>:wqa W&yjœcie\ z\ zapisem<Tab>:wqa +menutrans E&xit<Tab>:qa &Wyjœcie<Tab>:qa +menutrans Open\ Tab\.\.\.<Tab>:tabnew Otwórz\ &kartê\.\.\.<Tab>:tabnew + +" Edit menu +menutrans &Edit &Edycja +menutrans &Undo<Tab>u &Cofnij<Tab>u +menutrans &Redo<Tab>^R &Ponów<Tab>^R +menutrans Rep&eat<Tab>\. P&owtórz<Tab>\. +menutrans Cu&t<Tab>"+x W&ytnij<Tab>"+x +menutrans &Copy<Tab>"+y &Kopiuj<Tab>"+y +menutrans &Paste<Tab>"+gP &Wklej<Tab>"+gP +menutrans Put\ &Before<Tab>[p Wstaw\ p&rzed<Tab>[p +menutrans Put\ &After<Tab>]p Wstaw\ p&o<Tab>]p +menutrans &Select\ All<Tab>ggVG Z&aznacz\ ca³oœæ<Tab>ggVG +menutrans &Find\.\.\. &Szukaj\.\.\. +menutrans &Find<Tab>/ &Szukaj<Tab>/ +menutrans Find\ and\ Rep&lace\.\.\. &Zamieñ\.\.\. +menutrans Find\ and\ Rep&lace<Tab>:%s &Zamieñ<Tab>:%s +menutrans Find\ and\ Rep&lace &Zamieñ +menutrans Find\ and\ Rep&lace<Tab>:s &Zamieñ<Tab>:s +menutrans Options\.\.\. Opcje\.\.\. +menutrans Settings\ &Window Ustawienia +menutrans &Global\ Settings Ustawienia\ &globalne +menutrans Startup\ &Settings Ustawienia\ &startowe +menutrans F&ile\ Settings Ustawienia\ dla\ pliku +menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! &Numerowanie\ wierszy<Tab>:set\ nu! +menutrans Toggle\ &List\ Mode<Tab>:set\ list! Tryb\ &listowania<Tab>:set\ list! +menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! Za&wijanie\ wierszy<Tab>:set\ wrap! +menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! £amanie\ wie&rsza<Tab>:set\ lbr! +menutrans Toggle\ &expand-tab<Tab>:set\ et! Rozwijani&e\ tabulatorów<Tab>:set\ et! +menutrans Toggle\ &auto-indent<Tab>:set\ ai! &Automatyczne\ wciêcia<Tab>:set\ ai! +menutrans Toggle\ &C-indenting<Tab>:set\ cin! Wciêcia\ &C<Tab>:set\ cin! +menutrans &Shiftwidth &Szerokoœæ\ wciêcia +menutrans Te&xt\ Width\.\.\. D³ugoœæ\ linii\.\.\. +menutrans &File\ Format\.\.\. &Format\ pliku\.\.\. +menutrans Soft\ &Tabstop Rozmiar\ &tabulacji +menutrans C&olor\ Scheme Zestawy\ kolorów +menutrans &Keymap Uk³ady\ klawiatury +menutrans None ¿aden +menutrans accents akcenty +menutrans hebrew hebrajski +menutrans hebrewp hebrajski\ p +menutrans russian-jcuken rosyjski-jcuken +menutrans russian-jcukenwin rosyjski-jcukenwin + +menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! Podœwietlanie\ &wzorców<Tab>:set\ hls! + +menutrans Toggle\ &Ignore-case<Tab>:set\ ic! &Ignorowanie\ wielkoœci<Tab>:set\ ic! +menutrans Toggle\ &Showmatch<Tab>:set\ sm! &Pokazywanie\ pasuj¹cych<Tab>:set\ sm! + +menutrans &Context\ lines Wiersze\ &kontekstowe +menutrans &Virtual\ Edit Edycja\ &wirtualna + +menutrans Never Nigdy +menutrans Block\ Selection Zaznaczanie\ blokowe +menutrans Insert\ mode Tryb\ wprowadzania +menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! Tryb\ zg&odnoœci\ z\ Vi<Tab>:set\ cp! +menutrans Block\ and\ Insert Blokowe\ i\ wprowadzanie +menutrans Always Zawsze + +menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Tryb\ wprowadzania<Tab>:set\ im! +menutrans Search\ &Path\.\.\. Scie¿ka\ poszukiwania\.\.\. +menutrans Ta&g\ Files\.\.\. Pliki\ tagów\.\.\. + + +" +" GUI options +menutrans Toggle\ &Toolbar Pasek\ narzêdzi +menutrans Toggle\ &Bottom\ Scrollbar Dolny\ przewijacz +menutrans Toggle\ &Left\ Scrollbar &Lewy\ przewijacz +menutrans Toggle\ &Right\ Scrollbar P&rawy\ przewijacz + +" Programming menu +menutrans &Tools &Narzêdzia +menutrans &Jump\ to\ this\ tag<Tab>g^] &Skocz\ do\ taga<Tab>g^] +menutrans Jump\ &back<Tab>^T Skok\ w\ &ty³<Tab>^T +menutrans Build\ &Tags\ File &Twórz\ plik\ tagów +" Spelling +menutrans &Spelling Pi&sownia +menutrans &Spell\ Check\ On W³¹cz +menutrans Spell\ Check\ &Off Wy³¹cz +menutrans To\ &Next\ error<Tab>]s Do\ &nastêpnego\ b³êdu<Tab>]s +menutrans To\ &Previous\ error<Tab>[s Do\ &poprzedniego\ b³êdu<Tab>[s +menutrans Suggest\ &Corrections<Tab>z= Sugestie\ poprawek<Tab>z= +menutrans &Repeat\ correction<Tab>:spellrepall Powtór&z\ poprawkê<Tab>:spellrepall +menutrans Set\ language\ to\ "en" Ustaw\ jêzyk\ na\ "en" +menutrans Set\ language\ to\ "en_au" Ustaw\ jêzyk\ na\ "en_au" +menutrans Set\ language\ to\ "en_ca" Ustaw\ jêzyk\ na\ "en_ca" +menutrans Set\ language\ to\ "en_gb" Ustaw\ jêzyk\ na\ "en_gb" +menutrans Set\ language\ to\ "en_nz" Ustaw\ jêzyk\ na\ "en_nz" +menutrans Set\ language\ to\ "en_us" Ustaw\ jêzyk\ na\ "en_us" +menutrans Set\ language\ to\ "pl" Ustaw\ jêzyk\ na\ "pl" +menutrans &Find\ More\ Languages &ZnajdŸ\ wiêcej\ jêzyków + +" Folding +menutrans &Folding &Zwijanie +menutrans &Enable/Disable\ folds<Tab>zi &Zwiñ/rozwiñ<Tab>zi +menutrans &View\ Cursor\ Line<Tab>zv &Linia\ kursora<Tab>zv +menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx &Tylko\ linia\ kursora<Tab>zMzx +menutrans C&lose\ more\ folds<Tab>zm Zwiñ\ wiêcej<Tab>zm +menutrans &Close\ all\ folds<Tab>zM Z&wiñ\ wszystkie<Tab>zM +menutrans &Open\ all\ folds<Tab>zR Rozwiñ\ wszystkie<Tab>zR +menutrans O&pen\ more\ folds<Tab>zr R&ozwiñ\ wiêcej<Tab>zr + +menutrans Create\ &Fold<Tab>zf T&wórz\ zawiniêcie<Tab>zf +menutrans &Delete\ Fold<Tab>zd U&suñ\ zawiniêcie<Tab>zd +menutrans Delete\ &All\ Folds<Tab>zD &Usuñ\ wszystkie\ zawiniêcia<Tab>zD +menutrans Fold\ column\ &width Szerokoœæ\ kolumny\ za&winiêæ +menutrans Fold\ Met&hod Me&toda\ zawijania +menutrans M&anual &Rêcznie +menutrans I&ndent W&ciêcie +menutrans E&xpression W&yra¿enie +menutrans S&yntax S&k³adnia +menutrans Ma&rker Zn&acznik + +" Diff +menutrans &Update &Odœwie¿ +menutrans &Get\ Block &Pobierz\ blok +menutrans &Put\ Block &Wstaw\ blok + +" Make and stuff... +menutrans &Make<Tab>:make M&ake<Tab>:make +menutrans &List\ Errors<Tab>:cl &Poka¿\ b³êdy<Tab>:cl +menutrans L&ist\ Messages<Tab>:cl! W&ylicz\ powiadomienia<Tab>:cl! +menutrans &Next\ Error<Tab>:cn &Nastêpny\ b³¹d<Tab>:cn +menutrans &Previous\ Error<Tab>:cp &Poprzedni\ b³¹d<Tab>:cp +menutrans &Older\ List<Tab>:cold &Starsza\ lista<Tab>:cold +menutrans N&ewer\ List<Tab>:cnew N&owsza\ lista<Tab>:cnew +menutrans Error\ &Window Okno\ b³êdó&w +menutrans &Update<Tab>:cwin Akt&ualizuj<Tab>:cwin +menutrans &Close<Tab>:cclose &Zamknij<Tab>:cclose +menutrans &Open<Tab>:copen &Otwórz<Tab>:copen + +menutrans Se&T\ Compiler U&staw\ kompilator +menutrans &Convert\ to\ HEX<Tab>:%!xxd Kody\ szesnastkowe<Tab>:%!xxd +menutrans Conve&rt\ back<Tab>:%!xxd\ -r Zwyk³y\ tekst<Tab>:%!xxd\ -r + +" Names for buffer menu. +menutrans &Buffers &Bufory +menutrans &Refresh\ menu &Odœwie¿ +menutrans &Delete &Skasuj +menutrans &Alternate &Zmieñ +menutrans &Next &Nastêpny +menutrans &Previous &Poprzedni +menutrans [No\ File] [Brak\ Pliku] + +" Window menu +menutrans &Window &Widoki +menutrans &New<Tab>^Wn &Nowy<Tab>^Wn +menutrans S&plit<Tab>^Ws Po&dziel<Tab>^Ws +menutrans Sp&lit\ To\ #<Tab>^W^^ P&odziel\ na\ #<Tab>^W^^ +menutrans Split\ &Vertically<Tab>^Wv Podziel\ pionowo<Tab>^Wv +menutrans Split\ File\ E&xplorer Otwórz\ mened¿er\ plików + +menutrans &Close<Tab>^Wc &Zamknij<Tab>^Wc +menutrans Close\ &Other(s)<Tab>^Wo Zamknij\ &inne<Tab>^Wo +menutrans Ne&xt<Tab>^Ww &Nastêpny<Tab>^Ww +menutrans P&revious<Tab>^WW &Poprzedni<Tab>^WW +menutrans &Equal\ Size<Tab>^W= &Wyrównaj\ wysokoœci<Tab>^W= +menutrans &Max\ Height<Tab>^W_ Z&maksymalizuj\ wysokoœæ<Tab>^W_ +menutrans M&in\ Height<Tab>^W1_ Zminim&alizuj\ wysokoœæ<Tab>^W1_ +menutrans Max\ Width<Tab>^W\| Maksymalna\ szerokoœæ<Tab>^W\| +menutrans Min\ Width<Tab>^W1\| Minimalna\ szerokoœæ<Tab>^W1\| +menutrans Max\ &Width<Tab>^W\| Zmaksymalizuj\ szerokoœæ<Tab>^W\| +menutrans Min\ Widt&h<Tab>^W1\| Zminimalizuj\ szerokoœæ<Tab>^W1\| +menutrans Move\ &To &IdŸ\ do +menutrans &Top<Tab>^WK &Góra<Tab>^WK +menutrans &Bottom<Tab>^WJ &Dó³<Tab>^WJ +menutrans &Left\ side<Tab>^WH &Lewa\ strona<Tab>^WH +menutrans &Right\ side<Tab>^WL &Prawa\ strona<Tab>^WL +menutrans Rotate\ &Up<Tab>^WR Obróæ\ w\ &górê<Tab>^WR +menutrans Rotate\ &Down<Tab>^Wr Obróæ\ w\ &dó³<Tab>^Wr +menutrans Split\ &Vertically<Tab>^Wv &Podziel\ w\ poziomie<Tab>^Wv +menutrans Select\ Fo&nt\.\.\. Wybierz\ &czcionkê\.\.\. + +" The popup menu +menutrans &Undo &Cofnij +menutrans Cu&t W&ytnij +menutrans &Copy &Kopiuj +menutrans &Paste &Wklej +menutrans &Delete &Skasuj +menutrans Select\ Blockwise Zaznacz\ &blok +menutrans Select\ &Sentence Zaznacz\ &zdanie +menutrans Select\ Pa&ragraph Zaznacz\ aka&pit +menutrans Select\ &Word Zaznacz\ &s³owo +menutrans Select\ &Line Zaznacz\ w&iersz +menutrans Select\ &Block Zaznacz\ &blok +menutrans Select\ &All Zaznacz\ c&a³oœæ +menutrans Input\ &Methods Wprowadza&nie + +" The GUI toolbar +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open Otwórz plik + tmenu ToolBar.Save Zapisz bie¿¹cy plik + tmenu ToolBar.SaveAll Zapisz wszystkie pliki + tmenu ToolBar.Print Drukuj + tmenu ToolBar.Undo Cofnij + tmenu ToolBar.Redo Ponów + tmenu ToolBar.Cut Wytnij + tmenu ToolBar.Copy Skopiuj + tmenu ToolBar.Paste Wklej + tmenu ToolBar.Find Szukaj... + tmenu ToolBar.FindNext Szukaj nastêpnego + tmenu ToolBar.FindPrev Szukaj poprzedniego + tmenu ToolBar.Replace Szukaj i zamieniaj... + if 0 " disabled; These are in the Windows menu + tmenu ToolBar.New Nowy widok + tmenu ToolBar.WinSplit Podziel widok + tmenu ToolBar.WinMax Zmaksymalizuj widok + tmenu ToolBar.WinMin Zminimalizuj widok + tmenu ToolBar.WinClose Zamknij widok + endif + tmenu ToolBar.LoadSesn Za³aduj sesjê + tmenu ToolBar.SaveSesn Zachowaj bie¿¹c¹ sesjê + tmenu ToolBar.RunScript Uruchom skrypt Vima + tmenu ToolBar.Make Wykonaj bie¿¹cy projekt + tmenu ToolBar.Shell Otwórz pow³okê + tmenu ToolBar.RunCtags Twórz tagi w bie¿¹cym katalogu + tmenu ToolBar.TagJump Skok do taga pod kursorem + tmenu ToolBar.Help Pomoc Vima + tmenu ToolBar.FindHelp Przeszukuj pomoc Vim-a + endfun +endif + +" Syntax menu +menutrans &Syntax &Sk³adnia +menutrans &Show\ filetypes\ in\ menu Poka¿\ typy\ &plików\ w\ menu +menutrans Set\ '&syntax'\ only Ustaw\ tylko\ '&syntax' +menutrans Set\ '&filetype'\ too Ustaw\ równie¿\ '&filetype' +menutrans &Off &Wy³¹cz +menutrans &Manual &Rêcznie +menutrans A&utomatic A&utomatyczne +menutrans on/off\ for\ &This\ file w³¹cz/w&y³¹cz\ dla\ pliku +menutrans Co&lor\ test Test\ &kolorów +menutrans &Highlight\ test &Test\ podœwietlania +menutrans &Convert\ to\ HTML Przetwórz\ na\ &HTML + +" dialog texts +let menutrans_no_file = "[Brak pliku]" +let menutrans_help_dialog = "WprowadŸ komendê lub s³owo, aby otrzymaæ pomoc o:\n\nPrzedrostek i_ oznacza komendê trybu Wprowadzania (np. i_CTRL-X)\nPrzedrostek c_ oznacza komendê edycji wiersza komend (np. c_<Del>)\nPrzedrostek ' oznacza nazwê opcji (np. 'shiftwidth')" +let g:menutrans_path_dialog = "WprowadŸ œcie¿kê poszukiwania plików.\nProszê rozdzielaæ nazwy katalogów przecinkiem." +let g:menutrans_tags_dialog = "Podaj nazwy plików tagów.\nProszê rozdzielaæ nazwy przecinkiem." +let g:menutrans_textwidth_dialog = "WprowadŸ now¹ szerokoœæ tekstu (0 wy³¹cza przewijanie): " +let g:menutrans_fileformat_dialog = "Wybierz format w którym ten plik ma byæ zapisany" +let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\n&Anuluj" diff --git a/share/vim/vim72/lang/menu_pt_br.latin1.vim b/share/vim/vim73/lang/menu_pt_br.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_pt_br.latin1.vim rename to share/vim/vim73/lang/menu_pt_br.latin1.vim diff --git a/share/vim/vim72/lang/menu_pt_br.utf-8.vim b/share/vim/vim73/lang/menu_pt_br.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_pt_br.utf-8.vim rename to share/vim/vim73/lang/menu_pt_br.utf-8.vim diff --git a/share/vim/vim72/lang/menu_pt_br.vim b/share/vim/vim73/lang/menu_pt_br.vim similarity index 100% rename from share/vim/vim72/lang/menu_pt_br.vim rename to share/vim/vim73/lang/menu_pt_br.vim diff --git a/share/vim/vim72/lang/menu_pt_pt.latin1.vim b/share/vim/vim73/lang/menu_pt_pt.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_pt_pt.latin1.vim rename to share/vim/vim73/lang/menu_pt_pt.latin1.vim diff --git a/share/vim/vim72/lang/menu_pt_pt.utf-8.vim b/share/vim/vim73/lang/menu_pt_pt.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_pt_pt.utf-8.vim rename to share/vim/vim73/lang/menu_pt_pt.utf-8.vim diff --git a/share/vim/vim72/lang/menu_pt_pt.vim b/share/vim/vim73/lang/menu_pt_pt.vim similarity index 100% rename from share/vim/vim72/lang/menu_pt_pt.vim rename to share/vim/vim73/lang/menu_pt_pt.vim diff --git a/share/vim/vim72/lang/menu_ru.utf-8.vim b/share/vim/vim73/lang/menu_ru.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_ru.utf-8.vim rename to share/vim/vim73/lang/menu_ru.utf-8.vim diff --git a/share/vim/vim72/lang/menu_ru_ru.koi8-r.vim b/share/vim/vim73/lang/menu_ru_ru.koi8-r.vim similarity index 100% rename from share/vim/vim72/lang/menu_ru_ru.koi8-r.vim rename to share/vim/vim73/lang/menu_ru_ru.koi8-r.vim diff --git a/share/vim/vim72/lang/menu_ru_ru.utf-8.vim b/share/vim/vim73/lang/menu_ru_ru.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_ru_ru.utf-8.vim rename to share/vim/vim73/lang/menu_ru_ru.utf-8.vim diff --git a/share/vim/vim72/lang/menu_ru_ru.vim b/share/vim/vim73/lang/menu_ru_ru.vim similarity index 100% rename from share/vim/vim72/lang/menu_ru_ru.vim rename to share/vim/vim73/lang/menu_ru_ru.vim diff --git a/share/vim/vim72/lang/menu_sk.cp1250.vim b/share/vim/vim73/lang/menu_sk.cp1250.vim similarity index 100% rename from share/vim/vim72/lang/menu_sk.cp1250.vim rename to share/vim/vim73/lang/menu_sk.cp1250.vim diff --git a/share/vim/vim72/lang/menu_sk_sk.1250.vim b/share/vim/vim73/lang/menu_sk_sk.1250.vim similarity index 100% rename from share/vim/vim72/lang/menu_sk_sk.1250.vim rename to share/vim/vim73/lang/menu_sk_sk.1250.vim diff --git a/share/vim/vim72/lang/menu_sk_sk.cp1250.vim b/share/vim/vim73/lang/menu_sk_sk.cp1250.vim similarity index 100% rename from share/vim/vim72/lang/menu_sk_sk.cp1250.vim rename to share/vim/vim73/lang/menu_sk_sk.cp1250.vim diff --git a/share/vim/vim72/lang/menu_sk_sk.iso_8859-2.vim b/share/vim/vim73/lang/menu_sk_sk.iso_8859-2.vim similarity index 100% rename from share/vim/vim72/lang/menu_sk_sk.iso_8859-2.vim rename to share/vim/vim73/lang/menu_sk_sk.iso_8859-2.vim diff --git a/share/vim/vim72/lang/menu_sk_sk.vim b/share/vim/vim73/lang/menu_sk_sk.vim similarity index 100% rename from share/vim/vim72/lang/menu_sk_sk.vim rename to share/vim/vim73/lang/menu_sk_sk.vim diff --git a/share/vim/vim72/lang/menu_sl_si.cp1250.vim b/share/vim/vim73/lang/menu_sl_si.cp1250.vim similarity index 100% rename from share/vim/vim72/lang/menu_sl_si.cp1250.vim rename to share/vim/vim73/lang/menu_sl_si.cp1250.vim diff --git a/share/vim/vim72/lang/menu_sl_si.latin2.vim b/share/vim/vim73/lang/menu_sl_si.latin2.vim similarity index 100% rename from share/vim/vim72/lang/menu_sl_si.latin2.vim rename to share/vim/vim73/lang/menu_sl_si.latin2.vim diff --git a/share/vim/vim72/lang/menu_sl_si.utf-8.vim b/share/vim/vim73/lang/menu_sl_si.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_sl_si.utf-8.vim rename to share/vim/vim73/lang/menu_sl_si.utf-8.vim diff --git a/share/vim/vim72/lang/menu_slovak_slovak_republic.1250.vim b/share/vim/vim73/lang/menu_slovak_slovak_republic.1250.vim similarity index 100% rename from share/vim/vim72/lang/menu_slovak_slovak_republic.1250.vim rename to share/vim/vim73/lang/menu_slovak_slovak_republic.1250.vim diff --git a/share/vim/vim72/lang/menu_spanish_spain.850.vim b/share/vim/vim73/lang/menu_spanish_spain.850.vim similarity index 100% rename from share/vim/vim72/lang/menu_spanish_spain.850.vim rename to share/vim/vim73/lang/menu_spanish_spain.850.vim diff --git a/share/vim/vim73/lang/menu_sr.utf-8.vim b/share/vim/vim73/lang/menu_sr.utf-8.vim new file mode 100644 index 0000000000..4d278f99a9 --- /dev/null +++ b/share/vim/vim73/lang/menu_sr.utf-8.vim @@ -0,0 +1,3 @@ +" Menu Translations: Serbian + +source <sfile>:p:h/menu_sr_rs.utf-8.vim diff --git a/share/vim/vim72/lang/menu_sr_yu.ascii.vim b/share/vim/vim73/lang/menu_sr_rs.ascii.vim similarity index 100% rename from share/vim/vim72/lang/menu_sr_yu.ascii.vim rename to share/vim/vim73/lang/menu_sr_rs.ascii.vim diff --git a/share/vim/vim72/lang/menu_sr_yu.iso_8859-2.vim b/share/vim/vim73/lang/menu_sr_rs.iso_8859-2.vim similarity index 100% rename from share/vim/vim72/lang/menu_sr_yu.iso_8859-2.vim rename to share/vim/vim73/lang/menu_sr_rs.iso_8859-2.vim diff --git a/share/vim/vim72/lang/menu_sr_yu.iso_8859-5.vim b/share/vim/vim73/lang/menu_sr_rs.iso_8859-5.vim similarity index 100% rename from share/vim/vim72/lang/menu_sr_yu.iso_8859-5.vim rename to share/vim/vim73/lang/menu_sr_rs.iso_8859-5.vim diff --git a/share/vim/vim73/lang/menu_sr_rs.utf-8.vim b/share/vim/vim73/lang/menu_sr_rs.utf-8.vim new file mode 100644 index 0000000000..85f1491d5a --- /dev/null +++ b/share/vim/vim73/lang/menu_sr_rs.utf-8.vim @@ -0,0 +1,261 @@ +" Menu Translations: Serbian +" Maintainer: Aleksandar Jelenak <ajelenak AT yahoo.com> +" Last Change: Fri, 30 May 2003 10:17:39 Eastern Daylight Time + +" Quit when menu translations have already been done. +if exists("did_menu_trans") + finish +endif +let did_menu_trans = 1 +scriptencoding utf-8 + +" Help menu +menutrans &Help Помо&ћ +menutrans &Overview<Tab><F1> &Преглед<Tab><F1> +menutrans &User\ Manual &Упутство\ за\ кориснике +menutrans &How-to\ links &Како\ да\.\.\. +menutrans &Find &Нађи +menutrans &Credits &Заслуге +menutrans Co&pying П&реузимање +menutrans O&rphans &Сирочићи +menutrans &Version &Верзија +menutrans &About &О\ програму + +" File menu +menutrans &File &Датотека +menutrans &Open\.\.\.<Tab>:e &Отвори\.\.\.<Tab>:e +menutrans Sp&lit-Open\.\.\.<Tab>:sp &Подели-отвори\.\.\.<Tab>:sp +menutrans &New<Tab>:enew &Нова<Tab>:enew +menutrans &Close<Tab>:close &Затвори<Tab>:close +menutrans &Save<Tab>:w &Сачувај<Tab>:w +menutrans Save\ &As\.\.\.<Tab>:sav Сачувај\ &као\.\.\.<Tab>:sav +menutrans Split\ &Diff\ with\.\.\. Подели\ и\ &упореди\ са\.\.\. +menutrans Split\ Patched\ &By\.\.\. По&дели\ и\ преправи\ са\.\.\. +menutrans &Print Шта&мпај +menutrans Sa&ve-Exit<Tab>:wqa Сачувај\ и\ за&врши<Tab>:wqa +menutrans E&xit<Tab>:qa К&рај<Tab>:qa + +" Edit menu +menutrans &Edit &Уређивање +menutrans &Undo<Tab>u &Врати<Tab>u +menutrans &Redo<Tab>^R &Поврати<Tab>^R +menutrans Rep&eat<Tab>\. П&онови<Tab>\. +menutrans Cu&t<Tab>"+x Исе&ци<Tab>"+x +menutrans &Copy<Tab>"+y &Копирај<Tab>"+y +menutrans &Paste<Tab>"+gP &Убаци<Tab>"+gP +menutrans &Paste<Tab>"+P &Убаци<Tab>"+gP +menutrans Put\ &Before<Tab>[p Стави\ пре&д<Tab>[p +menutrans Put\ &After<Tab>]p Стави\ &иза<Tab>]p +menutrans &Delete<Tab>x Из&бриши<Tab>x +menutrans &Select\ all<Tab>ggVG Изабери\ св&е<Tab>ggVG +menutrans &Find\.\.\. &Нађи\.\.\. +menutrans Find\ and\ Rep&lace\.\.\. Нађи\ и\ &замени\.\.\. +menutrans Settings\ &Window П&розор\ подешавања +menutrans &Global\ Settings Оп&шта\ подешавања +menutrans F&ile\ Settings Подешавања\ за\ да&тотеке +menutrans &Shiftwidth &Померај +menutrans Soft\ &Tabstop &Мека\ табулација +menutrans Te&xt\ Width\.\.\. &Ширина\ текста\.\.\. +menutrans &File\ Format\.\.\. &Врста\ датотеке\.\.\. +menutrans C&olor\ Scheme Бо&је +menutrans &Keymap Прес&ликавање\ тастатуре +menutrans Select\ Fo&nt\.\.\. Избор\ &фонта\.\.\. + +" Edit/Global Settings +menutrans Toggle\ Pattern\ &Highlight<Tab>:set\ hls! Нагласи\ &образце\ (да/не)<Tab>:set\ hls! +menutrans Toggle\ &Ignore-case<Tab>:set\ ic! Занемари\ \величину\ &слова\ (да/не)<Tab>:set\ ic! +menutrans Toggle\ &Showmatch<Tab>:set\ sm! Провери\ пратећу\ &заграду\ (да/не)<Tab>:set\ sm! +menutrans &Context\ lines Видљиви\ &редови +menutrans &Virtual\ Edit Виртуелно\ &уређивање +menutrans Toggle\ Insert\ &Mode<Tab>:set\ im! Режим\ у&носа\ (да/не)<Tab>:set\ im! +menutrans Toggle\ Vi\ C&ompatible<Tab>:set\ cp! '&Vi'\ сагласно\ (да/не)<Tab>:set\ cp! +menutrans Search\ &Path\.\.\. Путања\ &претраге\.\.\. +menutrans Ta&g\ Files\.\.\. &Датотеке\ ознака\.\.\. +menutrans Toggle\ &Toolbar Линија\ са\ &алаткама\ (да/не) +menutrans Toggle\ &Bottom\ Scrollbar Доња\ л&инија\ клизања\ (да/не) +menutrans Toggle\ &Left\ Scrollbar &Лева\ линија\ клизања\ (да/не) +menutrans Toggle\ &Right\ Scrollbar &Десна\ линија\ клизања\ (да/не) + +" Edit/Global Settings/Virtual Edit +menutrans Never Никад +menutrans Block\ Selection Избор\ блока +menutrans Insert\ mode Режим\ уноса +menutrans Block\ and\ Insert Блок\ и\ унос +menutrans Always Увек + +" Edit/File Settings +menutrans Toggle\ Line\ &Numbering<Tab>:set\ nu! Редни\ &бројеви\ (да/не)<Tab>:set\ nu! +menutrans Toggle\ &List\ Mode<Tab>:set\ list! Режим\ &листе\ (да/не)<Tab>:set\ list! +menutrans Toggle\ Line\ &Wrap<Tab>:set\ wrap! Обавијање\ &редова\ (да/не)<Tab>:set\ wrap! +menutrans Toggle\ W&rap\ at\ word<Tab>:set\ lbr! Преломи\ &на\ реч\ (да/не)<Tab>:set\ lbr! +menutrans Toggle\ &expand-tab<Tab>:set\ et! Размаци\ уместо\ &табулације\ (да/не)<Tab>:set\ et! +menutrans Toggle\ &auto-indent<Tab>:set\ ai! Ауто-&увлачење\ (да/не)<Tab>:set\ ai! +menutrans Toggle\ &C-indenting<Tab>:set\ cin! &Це-увлачење\ (да/не)<Tab>:set\ cin! + +" Edit/Keymap +menutrans None Ниједан + +" Tools menu +menutrans &Tools &Алатке +menutrans &Jump\ to\ this\ tag<Tab>g^] Скочи\ на\ &ову\ ознаку<Tab>g^] +menutrans Jump\ &back<Tab>^T Скочи\ &натраг<Tab>^T +menutrans Build\ &Tags\ File Изгради\ &датотеку\ ознака +menutrans &Folding &Подвијање +menutrans Create\ &Fold<Tab>zf С&твори\ подвијутак<Tab>zf +menutrans &Delete\ Fold<Tab>zd О&бриши\ подвијутак<Tab>zd +menutrans Delete\ &All\ Folds<Tab>zD Обриши\ све\ по&двијутке<Tab>zD +menutrans Fold\ column\ &width Ширина\ &реда\ подвијутка +menutrans &Diff &Упоређивање +menutrans &Make<Tab>:make 'mak&е'<Tab>:make +menutrans &List\ Errors<Tab>:cl Списак\ &грешака<Tab>:cl +menutrans L&ist\ Messages<Tab>:cl! Сп&исак\ порука<Tab>:cl! +menutrans &Next\ Error<Tab>:cn С&ледећа\ грешка<Tab>:cn +menutrans &Previous\ Error<Tab>:cp Пре&тходна\ грешка<Tab>:cp +menutrans &Older\ List<Tab>:cold Стари\ списа&к<Tab>:cold +menutrans N&ewer\ List<Tab>:cnew Но&ви\ списак<Tab>:cnew +menutrans Error\ &Window Прозор\ са\ г&решкама +menutrans &Set\ Compiler И&забери\ преводиоца +menutrans &Convert\ to\ HEX<Tab>:%!xxd Претвори\ у\ &ХЕКС<Tab>:%!xxd +menutrans Conve&rt\ back<Tab>:%!xxd\ -r Вр&ати\ у\ првобитан\ облик<Tab>:%!xxd\ -r + +" Tools/Folding +menutrans &Enable/Disable\ folds<Tab>zi &Омогући/прекини\ подвијање<Tab>zi +menutrans &View\ Cursor\ Line<Tab>zv &Покажи\ ред\ са\ курсором<Tab>zv +menutrans Vie&w\ Cursor\ Line\ only<Tab>zMzx Покажи\ &само\ ред\ са\ курсором<Tab>zMzx +menutrans C&lose\ more\ folds<Tab>zm &Затвори\ више\ подвијутака<Tab>zm +menutrans &Close\ all\ folds<Tab>zM Затвори\ с&ве\ подвијутке<Tab>zM +menutrans O&pen\ more\ folds<Tab>zr Отвори\ виш&е\ подвијутака<Tab>zr +menutrans &Open\ all\ folds<Tab>zR О&твори\ све\ подвијутке<Tab>zR +menutrans Fold\ Met&hod &Начин\ подвијања + +" Tools/Folding/Fold Method +menutrans M&anual &Ручно +menutrans I&ndent &Увученост +menutrans E&xpression &Израз +menutrans S&yntax &Синтакса +"menutrans &Diff +menutrans Ma&rker &Ознака + +" Tools/Diff +menutrans &Update &Ажурирај +menutrans &Get\ Block &Прихвати\ измену +menutrans &Put\ Block Пре&баци\ измену + +" Tools/Error Window +menutrans &Update<Tab>:cwin &Ажурирај<Tab>:cwin +menutrans &Open<Tab>:copen &Отвори<Tab>:copen +menutrans &Close<Tab>:cclose &Затвори<Tab>:cclose + +" Bufers menu +menutrans &Buffers &Бафери +menutrans &Refresh\ menu &Ажурирај +menutrans Delete &Обриши +menutrans &Alternate А&лтернативни +menutrans &Next &Следећи +menutrans &Previous &Претходни +menutrans [No\ File] [Нема\ датотеке] + +" Window menu +menutrans &Window &Прозор +menutrans &New<Tab>^Wn &Нови<Tab>^Wn +menutrans S&plit<Tab>^Ws &Подели<Tab>^Ws +menutrans Sp&lit\ To\ #<Tab>^W^^ Подели\ са\ &алтернативним<Tab>^W^^ +menutrans Split\ &Vertically<Tab>^Wv Подели\ &усправно<Tab>^Wv +menutrans Split\ File\ E&xplorer Подели\ за\ преглед\ &датотека +menutrans &Close<Tab>^Wc &Затвори<Tab>^Wc +menutrans Close\ &Other(s)<Tab>^Wo Затвори\ &остале<Tab>^Wo +"menutrans Ne&xt<Tab>^Ww &Следећи<Tab>^Ww +"menutrans P&revious<Tab>^WW П&ретходни<Tab>^WW +menutrans Move\ &To Пре&мести +menutrans Rotate\ &Up<Tab>^WR &Кружно\ нагоре<Tab>^WR +menutrans Rotate\ &Down<Tab>^Wr Кружно\ надол&е<Tab>^Wr +menutrans &Equal\ Size<Tab>^W= &Исте\ величине<Tab>^W= +menutrans &Max\ Height<Tab>^W_ Максимална\ &висина<Tab>^W_ +menutrans M&in\ Height<Tab>^W1_ Минима&лна\ висина<Tab>^W1_ +menutrans Max\ &Width<Tab>^W\| Максимална\ &ширина<Tab>^W\| +menutrans Min\ Widt&h<Tab>^W1\| Минимална\ ши&рина<Tab>^W1\| + +" Window/Move To +menutrans &Top<Tab>^WK &Врх<Tab>^WK +menutrans &Bottom<Tab>^WJ &Подножје<Tab>^WJ +menutrans &Left\ side<Tab>^WH У&лево<Tab>^WH +menutrans &Right\ side<Tab>^WL У&десно<Tab>^WL + +" The popup menu +menutrans &Undo &Врати +menutrans Cu&t &Исеци +menutrans &Copy &Копирај +menutrans &Paste &Убаци +menutrans &Delete И&збриши +menutrans Select\ Blockwise Бирај\ &правоугаоно +menutrans Select\ &Word Изабери\ &реч +menutrans Select\ &Line Изабери\ р&ед +menutrans Select\ &Block Изабери\ &блок +menutrans Select\ &All Изабери\ &све + +" The GUI toolbar +if has("toolbar") + if exists("*Do_toolbar_tmenu") + delfun Do_toolbar_tmenu + endif + fun Do_toolbar_tmenu() + tmenu ToolBar.Open Учитај + tmenu ToolBar.Save Сачувај + tmenu ToolBar.SaveAll Сачувај све + tmenu ToolBar.Print Штампај + tmenu ToolBar.Undo Врати + tmenu ToolBar.Redo Поврати + tmenu ToolBar.Cut Исеци + tmenu ToolBar.Copy Копирај + tmenu ToolBar.Paste Убаци + tmenu ToolBar.Find Нађи + tmenu ToolBar.FindNext Нађи следећи + tmenu ToolBar.FindPrev Нађи претходни + tmenu ToolBar.Replace Замени + tmenu ToolBar.New Нови + tmenu ToolBar.WinSplit Подели прозор + tmenu ToolBar.WinMax Максимална висина + tmenu ToolBar.WinMin Минимална висина + tmenu ToolBar.WinVSplit Подели усправно + tmenu ToolBar.WinMaxWidth Максимална ширина + tmenu ToolBar.WinMinWidth Минимална ширина + tmenu ToolBar.WinClose Затвори прозор + tmenu ToolBar.LoadSesn Учитај сеансу + tmenu ToolBar.SaveSesn Сачувај сеансу + tmenu ToolBar.RunScript Изврши спис + tmenu ToolBar.Make 'make' + tmenu ToolBar.Shell Оперативно окружење + tmenu ToolBar.RunCtags Направи ознаке + tmenu ToolBar.TagJump Иди на ознаку + tmenu ToolBar.Help Помоћ + tmenu ToolBar.FindHelp Нађи објашњење + endfun +endif + +" Syntax menu +menutrans &Syntax &Синтакса +menutrans &Show\ filetypes\ in\ menu Избор\ 'filetype'\ из\ &менија +menutrans Set\ '&syntax'\ only Поде&си\ 'syntax'\ само +menutrans Set\ '&filetype'\ too Подеси\ 'filetype'\ &такође +menutrans &Off &Искључено +menutrans &Manual &Ручно +menutrans A&utomatic &Аутоматски +menutrans on/off\ for\ &This\ file Да/не\ за\ ову\ &датотеку +menutrans Co&lor\ test Провера\ &боја +menutrans &Highlight\ test Провера\ исти&цања +menutrans &Convert\ to\ HTML Претвори\ &у\ HTML + +" dialog texts +let menutrans_help_dialog = "Унесите наредбу или реч чије појашњење тражите:\n\nДодајте i_ за наредбе уноса (нпр. i_CTRL-X)\nДодајте c_ за наредбе командног режима (нпр. с_<Del>)\nДодајте ' за имена опција (нпр. 'shiftwidth')" + +let g:menutrans_path_dialog = "Унесите пут претраге за датотеке\nРаздвојите зарезима имена директоријума." + +let g:menutrans_tags_dialog = "Унесите имена датотека са ознакама\nРаздвојите зарезима имена." + +let g:menutrans_textwidth_dialog = "Унесите нову ширину текста (0 спречава прелом)" + +let g:menutrans_fileformat_dialog = "Изаберите врсту датотеке" + +let menutrans_no_file = "[Нема датотеке]" + +" vim: tw=0 keymap=serbian diff --git a/share/vim/vim73/lang/menu_sr_yu.ascii.vim b/share/vim/vim73/lang/menu_sr_yu.ascii.vim new file mode 100644 index 0000000000..9d908874e7 --- /dev/null +++ b/share/vim/vim73/lang/menu_sr_yu.ascii.vim @@ -0,0 +1,3 @@ +" Menu Translations: Serbian + +source <sfile>:p:h/menu_sr_rs.ascii.vim diff --git a/share/vim/vim73/lang/menu_sr_yu.iso_8859-2.vim b/share/vim/vim73/lang/menu_sr_yu.iso_8859-2.vim new file mode 100644 index 0000000000..98b209e2bf --- /dev/null +++ b/share/vim/vim73/lang/menu_sr_yu.iso_8859-2.vim @@ -0,0 +1,3 @@ +" Menu Translations: Serbian + +source <sfile>:p:h/menu_sr_rs.iso_8859-2.vim diff --git a/share/vim/vim73/lang/menu_sr_yu.iso_8859-5.vim b/share/vim/vim73/lang/menu_sr_yu.iso_8859-5.vim new file mode 100644 index 0000000000..f0aef77317 --- /dev/null +++ b/share/vim/vim73/lang/menu_sr_yu.iso_8859-5.vim @@ -0,0 +1,3 @@ +" Menu Translations: Serbian + +source <sfile>:p:h/menu_sr_rs.iso_8859-5.vim diff --git a/share/vim/vim73/lang/menu_sr_yu.utf-8.vim b/share/vim/vim73/lang/menu_sr_yu.utf-8.vim new file mode 100644 index 0000000000..4d278f99a9 --- /dev/null +++ b/share/vim/vim73/lang/menu_sr_yu.utf-8.vim @@ -0,0 +1,3 @@ +" Menu Translations: Serbian + +source <sfile>:p:h/menu_sr_rs.utf-8.vim diff --git a/share/vim/vim72/lang/menu_sv.latin1.vim b/share/vim/vim73/lang/menu_sv.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_sv.latin1.vim rename to share/vim/vim73/lang/menu_sv.latin1.vim diff --git a/share/vim/vim72/lang/menu_sv.utf-8.vim b/share/vim/vim73/lang/menu_sv.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_sv.utf-8.vim rename to share/vim/vim73/lang/menu_sv.utf-8.vim diff --git a/share/vim/vim72/lang/menu_sv_se.latin1.vim b/share/vim/vim73/lang/menu_sv_se.latin1.vim similarity index 100% rename from share/vim/vim72/lang/menu_sv_se.latin1.vim rename to share/vim/vim73/lang/menu_sv_se.latin1.vim diff --git a/share/vim/vim72/lang/menu_sv_se.utf-8.vim b/share/vim/vim73/lang/menu_sv_se.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_sv_se.utf-8.vim rename to share/vim/vim73/lang/menu_sv_se.utf-8.vim diff --git a/share/vim/vim72/lang/menu_uk_ua.cp1251.vim b/share/vim/vim73/lang/menu_uk_ua.cp1251.vim similarity index 100% rename from share/vim/vim72/lang/menu_uk_ua.cp1251.vim rename to share/vim/vim73/lang/menu_uk_ua.cp1251.vim diff --git a/share/vim/vim72/lang/menu_uk_ua.koi8-u.vim b/share/vim/vim73/lang/menu_uk_ua.koi8-u.vim similarity index 100% rename from share/vim/vim72/lang/menu_uk_ua.koi8-u.vim rename to share/vim/vim73/lang/menu_uk_ua.koi8-u.vim diff --git a/share/vim/vim72/lang/menu_vi_vn.vim b/share/vim/vim73/lang/menu_vi_vn.vim similarity index 100% rename from share/vim/vim72/lang/menu_vi_vn.vim rename to share/vim/vim73/lang/menu_vi_vn.vim diff --git a/share/vim/vim72/lang/menu_zh.big5.vim b/share/vim/vim73/lang/menu_zh.big5.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh.big5.vim rename to share/vim/vim73/lang/menu_zh.big5.vim diff --git a/share/vim/vim72/lang/menu_zh.cp936.vim b/share/vim/vim73/lang/menu_zh.cp936.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh.cp936.vim rename to share/vim/vim73/lang/menu_zh.cp936.vim diff --git a/share/vim/vim72/lang/menu_zh.cp950.vim b/share/vim/vim73/lang/menu_zh.cp950.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh.cp950.vim rename to share/vim/vim73/lang/menu_zh.cp950.vim diff --git a/share/vim/vim72/lang/menu_zh.gb2312.vim b/share/vim/vim73/lang/menu_zh.gb2312.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh.gb2312.vim rename to share/vim/vim73/lang/menu_zh.gb2312.vim diff --git a/share/vim/vim72/lang/menu_zh_cn.18030.vim b/share/vim/vim73/lang/menu_zh_cn.18030.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh_cn.18030.vim rename to share/vim/vim73/lang/menu_zh_cn.18030.vim diff --git a/share/vim/vim72/lang/menu_zh_cn.cp936.vim b/share/vim/vim73/lang/menu_zh_cn.cp936.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh_cn.cp936.vim rename to share/vim/vim73/lang/menu_zh_cn.cp936.vim diff --git a/share/vim/vim72/lang/menu_zh_cn.gb2312.vim b/share/vim/vim73/lang/menu_zh_cn.gb2312.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh_cn.gb2312.vim rename to share/vim/vim73/lang/menu_zh_cn.gb2312.vim diff --git a/share/vim/vim72/lang/menu_zh_cn.gbk.vim b/share/vim/vim73/lang/menu_zh_cn.gbk.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh_cn.gbk.vim rename to share/vim/vim73/lang/menu_zh_cn.gbk.vim diff --git a/share/vim/vim72/lang/menu_zh_cn.utf-8.vim b/share/vim/vim73/lang/menu_zh_cn.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh_cn.utf-8.vim rename to share/vim/vim73/lang/menu_zh_cn.utf-8.vim diff --git a/share/vim/vim72/lang/menu_zh_tw.big5.vim b/share/vim/vim73/lang/menu_zh_tw.big5.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh_tw.big5.vim rename to share/vim/vim73/lang/menu_zh_tw.big5.vim diff --git a/share/vim/vim72/lang/menu_zh_tw.cp950.vim b/share/vim/vim73/lang/menu_zh_tw.cp950.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh_tw.cp950.vim rename to share/vim/vim73/lang/menu_zh_tw.cp950.vim diff --git a/share/vim/vim72/lang/menu_zh_tw.utf-8.vim b/share/vim/vim73/lang/menu_zh_tw.utf-8.vim similarity index 100% rename from share/vim/vim72/lang/menu_zh_tw.utf-8.vim rename to share/vim/vim73/lang/menu_zh_tw.utf-8.vim diff --git a/share/vim/vim72/macmap.vim b/share/vim/vim73/macmap.vim similarity index 100% rename from share/vim/vim72/macmap.vim rename to share/vim/vim73/macmap.vim diff --git a/share/vim/vim72/macros.info b/share/vim/vim73/macros.info similarity index 100% rename from share/vim/vim72/macros.info rename to share/vim/vim73/macros.info diff --git a/share/vim/vim72/macros/README.txt b/share/vim/vim73/macros/README.txt similarity index 100% rename from share/vim/vim72/macros/README.txt rename to share/vim/vim73/macros/README.txt diff --git a/share/vim/vim72/macros/README.txt.info b/share/vim/vim73/macros/README.txt.info similarity index 100% rename from share/vim/vim72/macros/README.txt.info rename to share/vim/vim73/macros/README.txt.info diff --git a/share/vim/vim72/macros/dvorak b/share/vim/vim73/macros/dvorak similarity index 100% rename from share/vim/vim72/macros/dvorak rename to share/vim/vim73/macros/dvorak diff --git a/share/vim/vim72/macros/editexisting.vim b/share/vim/vim73/macros/editexisting.vim similarity index 100% rename from share/vim/vim72/macros/editexisting.vim rename to share/vim/vim73/macros/editexisting.vim diff --git a/share/vim/vim72/macros/hanoi.info b/share/vim/vim73/macros/hanoi.info similarity index 100% rename from share/vim/vim72/macros/hanoi.info rename to share/vim/vim73/macros/hanoi.info diff --git a/share/vim/vim72/macros/hanoi/click.me b/share/vim/vim73/macros/hanoi/click.me similarity index 100% rename from share/vim/vim72/macros/hanoi/click.me rename to share/vim/vim73/macros/hanoi/click.me diff --git a/share/vim/vim72/macros/hanoi/click.me.info b/share/vim/vim73/macros/hanoi/click.me.info similarity index 100% rename from share/vim/vim72/macros/hanoi/click.me.info rename to share/vim/vim73/macros/hanoi/click.me.info diff --git a/share/vim/vim72/macros/hanoi/hanoi.vim b/share/vim/vim73/macros/hanoi/hanoi.vim similarity index 100% rename from share/vim/vim72/macros/hanoi/hanoi.vim rename to share/vim/vim73/macros/hanoi/hanoi.vim diff --git a/share/vim/vim72/macros/hanoi/poster b/share/vim/vim73/macros/hanoi/poster similarity index 100% rename from share/vim/vim72/macros/hanoi/poster rename to share/vim/vim73/macros/hanoi/poster diff --git a/share/vim/vim72/macros/hanoi/poster.info b/share/vim/vim73/macros/hanoi/poster.info similarity index 100% rename from share/vim/vim72/macros/hanoi/poster.info rename to share/vim/vim73/macros/hanoi/poster.info diff --git a/share/vim/vim72/macros/justify.vim b/share/vim/vim73/macros/justify.vim similarity index 100% rename from share/vim/vim72/macros/justify.vim rename to share/vim/vim73/macros/justify.vim diff --git a/share/vim/vim72/macros/less.sh b/share/vim/vim73/macros/less.sh similarity index 100% rename from share/vim/vim72/macros/less.sh rename to share/vim/vim73/macros/less.sh diff --git a/share/vim/vim72/macros/less.vim b/share/vim/vim73/macros/less.vim similarity index 100% rename from share/vim/vim72/macros/less.vim rename to share/vim/vim73/macros/less.vim diff --git a/share/vim/vim72/macros/life/click.me b/share/vim/vim73/macros/life/click.me similarity index 100% rename from share/vim/vim72/macros/life/click.me rename to share/vim/vim73/macros/life/click.me diff --git a/share/vim/vim72/macros/life/click.me.info b/share/vim/vim73/macros/life/click.me.info similarity index 100% rename from share/vim/vim72/macros/life/click.me.info rename to share/vim/vim73/macros/life/click.me.info diff --git a/share/vim/vim72/macros/life/life.vim b/share/vim/vim73/macros/life/life.vim similarity index 100% rename from share/vim/vim72/macros/life/life.vim rename to share/vim/vim73/macros/life/life.vim diff --git a/share/vim/vim72/macros/matchit.txt b/share/vim/vim73/macros/matchit.txt similarity index 100% rename from share/vim/vim72/macros/matchit.txt rename to share/vim/vim73/macros/matchit.txt diff --git a/share/vim/vim73/macros/matchit.vim b/share/vim/vim73/macros/matchit.vim new file mode 100644 index 0000000000..549c26cf31 --- /dev/null +++ b/share/vim/vim73/macros/matchit.vim @@ -0,0 +1,812 @@ +" matchit.vim: (global plugin) Extended "%" matching +" Last Change: Fri Jan 25 10:00 AM 2008 EST +" Maintainer: Benji Fisher PhD <benji@member.AMS.org> +" Version: 1.13.2, for Vim 6.3+ +" URL: http://www.vim.org/script.php?script_id=39 + +" Documentation: +" The documentation is in a separate file, matchit.txt . + +" Credits: +" Vim editor by Bram Moolenaar (Thanks, Bram!) +" Original script and design by Raul Segura Acevedo +" Support for comments by Douglas Potts +" Support for back references and other improvements by Benji Fisher +" Support for many languages by Johannes Zellner +" Suggestions for improvement, bug reports, and support for additional +" languages by Jordi-Albert Batalla, Neil Bird, Servatius Brandt, Mark +" Collett, Stephen Wall, Dany St-Amant, Yuheng Xie, and Johannes Zellner. + +" Debugging: +" If you'd like to try the built-in debugging commands... +" :MatchDebug to activate debugging for the current buffer +" This saves the values of several key script variables as buffer-local +" variables. See the MatchDebug() function, below, for details. + +" TODO: I should think about multi-line patterns for b:match_words. +" This would require an option: how many lines to scan (default 1). +" This would be useful for Python, maybe also for *ML. +" TODO: Maybe I should add a menu so that people will actually use some of +" the features that I have implemented. +" TODO: Eliminate the MultiMatch function. Add yet another argument to +" Match_wrapper() instead. +" TODO: Allow :let b:match_words = '\(\(foo\)\(bar\)\):\3\2:end\1' +" TODO: Make backrefs safer by using '\V' (very no-magic). +" TODO: Add a level of indirection, so that custom % scripts can use my +" work but extend it. + +" allow user to prevent loading +" and prevent duplicate loading +if exists("loaded_matchit") || &cp + finish +endif +let loaded_matchit = 1 +let s:last_mps = "" +let s:last_words = ":" + +let s:save_cpo = &cpo +set cpo&vim + +nnoremap <silent> % :<C-U>call <SID>Match_wrapper('',1,'n') <CR> +nnoremap <silent> g% :<C-U>call <SID>Match_wrapper('',0,'n') <CR> +vnoremap <silent> % :<C-U>call <SID>Match_wrapper('',1,'v') <CR>m'gv`` +vnoremap <silent> g% :<C-U>call <SID>Match_wrapper('',0,'v') <CR>m'gv`` +onoremap <silent> % v:<C-U>call <SID>Match_wrapper('',1,'o') <CR> +onoremap <silent> g% v:<C-U>call <SID>Match_wrapper('',0,'o') <CR> + +" Analogues of [{ and ]} using matching patterns: +nnoremap <silent> [% :<C-U>call <SID>MultiMatch("bW", "n") <CR> +nnoremap <silent> ]% :<C-U>call <SID>MultiMatch("W", "n") <CR> +vmap [% <Esc>[%m'gv`` +vmap ]% <Esc>]%m'gv`` +" vnoremap <silent> [% :<C-U>call <SID>MultiMatch("bW", "v") <CR>m'gv`` +" vnoremap <silent> ]% :<C-U>call <SID>MultiMatch("W", "v") <CR>m'gv`` +onoremap <silent> [% v:<C-U>call <SID>MultiMatch("bW", "o") <CR> +onoremap <silent> ]% v:<C-U>call <SID>MultiMatch("W", "o") <CR> + +" text object: +vmap a% <Esc>[%v]% + +" Auto-complete mappings: (not yet "ready for prime time") +" TODO Read :help write-plugin for the "right" way to let the user +" specify a key binding. +" let g:match_auto = '<C-]>' +" let g:match_autoCR = '<C-CR>' +" if exists("g:match_auto") +" execute "inoremap " . g:match_auto . ' x<Esc>"=<SID>Autocomplete()<CR>Pls' +" endif +" if exists("g:match_autoCR") +" execute "inoremap " . g:match_autoCR . ' <CR><C-R>=<SID>Autocomplete()<CR>' +" endif +" if exists("g:match_gthhoh") +" execute "inoremap " . g:match_gthhoh . ' <C-O>:call <SID>Gthhoh()<CR>' +" endif " gthhoh = "Get the heck out of here!" + +let s:notslash = '\\\@<!\%(\\\\\)*' + +function! s:Match_wrapper(word, forward, mode) range + " In s:CleanUp(), :execute "set" restore_options . + let restore_options = (&ic ? " " : " no") . "ignorecase" + if exists("b:match_ignorecase") + let &ignorecase = b:match_ignorecase + endif + let restore_options = " ve=" . &ve . restore_options + set ve= + " If this function was called from Visual mode, make sure that the cursor + " is at the correct end of the Visual range: + if a:mode == "v" + execute "normal! gv\<Esc>" + endif + " In s:CleanUp(), we may need to check whether the cursor moved forward. + let startline = line(".") + let startcol = col(".") + " Use default behavior if called with a count. + if v:count + exe "normal! " . v:count . "%" + return s:CleanUp(restore_options, a:mode, startline, startcol) + end + + " First step: if not already done, set the script variables + " s:do_BR flag for whether there are backrefs + " s:pat parsed version of b:match_words + " s:all regexp based on s:pat and the default groups + " + if !exists("b:match_words") || b:match_words == "" + let match_words = "" + " Allow b:match_words = "GetVimMatchWords()" . + elseif b:match_words =~ ":" + let match_words = b:match_words + else + execute "let match_words =" b:match_words + endif +" Thanks to Preben "Peppe" Guldberg and Bram Moolenaar for this suggestion! + if (match_words != s:last_words) || (&mps != s:last_mps) || + \ exists("b:match_debug") + let s:last_words = match_words + let s:last_mps = &mps + " The next several lines were here before + " BF started messing with this script. + " quote the special chars in 'matchpairs', replace [,:] with \| and then + " append the builtin pairs (/*, */, #if, #ifdef, #else, #elif, #endif) + " let default = substitute(escape(&mps, '[$^.*~\\/?]'), '[,:]\+', + " \ '\\|', 'g').'\|\/\*\|\*\/\|#if\>\|#ifdef\>\|#else\>\|#elif\>\|#endif\>' + let default = escape(&mps, '[$^.*~\\/?]') . (strlen(&mps) ? "," : "") . + \ '\/\*:\*\/,#if\%(def\)\=:#else\>:#elif\>:#endif\>' + " s:all = pattern with all the keywords + let match_words = match_words . (strlen(match_words) ? "," : "") . default + if match_words !~ s:notslash . '\\\d' + let s:do_BR = 0 + let s:pat = match_words + else + let s:do_BR = 1 + let s:pat = s:ParseWords(match_words) + endif + let s:all = substitute(s:pat, s:notslash . '\zs[,:]\+', '\\|', 'g') + let s:all = '\%(' . s:all . '\)' + " let s:all = '\%(' . substitute(s:all, '\\\ze[,:]', '', 'g') . '\)' + if exists("b:match_debug") + let b:match_pat = s:pat + endif + endif + + " Second step: set the following local variables: + " matchline = line on which the cursor started + " curcol = number of characters before match + " prefix = regexp for start of line to start of match + " suffix = regexp for end of match to end of line + " Require match to end on or after the cursor and prefer it to + " start on or before the cursor. + let matchline = getline(startline) + if a:word != '' + " word given + if a:word !~ s:all + echohl WarningMsg|echo 'Missing rule for word:"'.a:word.'"'|echohl NONE + return s:CleanUp(restore_options, a:mode, startline, startcol) + endif + let matchline = a:word + let curcol = 0 + let prefix = '^\%(' + let suffix = '\)$' + " Now the case when "word" is not given + else " Find the match that ends on or after the cursor and set curcol. + let regexp = s:Wholematch(matchline, s:all, startcol-1) + let curcol = match(matchline, regexp) + " If there is no match, give up. + if curcol == -1 + return s:CleanUp(restore_options, a:mode, startline, startcol) + endif + let endcol = matchend(matchline, regexp) + let suf = strlen(matchline) - endcol + let prefix = (curcol ? '^.*\%' . (curcol + 1) . 'c\%(' : '^\%(') + let suffix = (suf ? '\)\%' . (endcol + 1) . 'c.*$' : '\)$') + endif + if exists("b:match_debug") + let b:match_match = matchstr(matchline, regexp) + let b:match_col = curcol+1 + endif + + " Third step: Find the group and single word that match, and the original + " (backref) versions of these. Then, resolve the backrefs. + " Set the following local variable: + " group = colon-separated list of patterns, one of which matches + " = ini:mid:fin or ini:fin + " + " Reconstruct the version with unresolved backrefs. + let patBR = substitute(match_words.',', + \ s:notslash.'\zs[,:]*,[,:]*', ',', 'g') + let patBR = substitute(patBR, s:notslash.'\zs:\{2,}', ':', 'g') + " Now, set group and groupBR to the matching group: 'if:endif' or + " 'while:endwhile' or whatever. A bit of a kluge: s:Choose() returns + " group . "," . groupBR, and we pick it apart. + let group = s:Choose(s:pat, matchline, ",", ":", prefix, suffix, patBR) + let i = matchend(group, s:notslash . ",") + let groupBR = strpart(group, i) + let group = strpart(group, 0, i-1) + " Now, matchline =~ prefix . substitute(group,':','\|','g') . suffix + if s:do_BR " Do the hard part: resolve those backrefs! + let group = s:InsertRefs(groupBR, prefix, group, suffix, matchline) + endif + if exists("b:match_debug") + let b:match_wholeBR = groupBR + let i = matchend(groupBR, s:notslash . ":") + let b:match_iniBR = strpart(groupBR, 0, i-1) + endif + + " Fourth step: Set the arguments for searchpair(). + let i = matchend(group, s:notslash . ":") + let j = matchend(group, '.*' . s:notslash . ":") + let ini = strpart(group, 0, i-1) + let mid = substitute(strpart(group, i,j-i-1), s:notslash.'\zs:', '\\|', 'g') + let fin = strpart(group, j) + "Un-escape the remaining , and : characters. + let ini = substitute(ini, s:notslash . '\zs\\\(:\|,\)', '\1', 'g') + let mid = substitute(mid, s:notslash . '\zs\\\(:\|,\)', '\1', 'g') + let fin = substitute(fin, s:notslash . '\zs\\\(:\|,\)', '\1', 'g') + " searchpair() requires that these patterns avoid \(\) groups. + let ini = substitute(ini, s:notslash . '\zs\\(', '\\%(', 'g') + let mid = substitute(mid, s:notslash . '\zs\\(', '\\%(', 'g') + let fin = substitute(fin, s:notslash . '\zs\\(', '\\%(', 'g') + " Set mid. This is optimized for readability, not micro-efficiency! + if a:forward && matchline =~ prefix . fin . suffix + \ || !a:forward && matchline =~ prefix . ini . suffix + let mid = "" + endif + " Set flag. This is optimized for readability, not micro-efficiency! + if a:forward && matchline =~ prefix . fin . suffix + \ || !a:forward && matchline !~ prefix . ini . suffix + let flag = "bW" + else + let flag = "W" + endif + " Set skip. + if exists("b:match_skip") + let skip = b:match_skip + elseif exists("b:match_comment") " backwards compatibility and testing! + let skip = "r:" . b:match_comment + else + let skip = 's:comment\|string' + endif + let skip = s:ParseSkip(skip) + if exists("b:match_debug") + let b:match_ini = ini + let b:match_tail = (strlen(mid) ? mid.'\|' : '') . fin + endif + + " Fifth step: actually start moving the cursor and call searchpair(). + " Later, :execute restore_cursor to get to the original screen. + let restore_cursor = virtcol(".") . "|" + normal! g0 + let restore_cursor = line(".") . "G" . virtcol(".") . "|zs" . restore_cursor + normal! H + let restore_cursor = "normal!" . line(".") . "Gzt" . restore_cursor + execute restore_cursor + call cursor(0, curcol + 1) + " normal! 0 + " if curcol + " execute "normal!" . curcol . "l" + " endif + if skip =~ 'synID' && !(has("syntax") && exists("g:syntax_on")) + let skip = "0" + else + execute "if " . skip . "| let skip = '0' | endif" + endif + let sp_return = searchpair(ini, mid, fin, flag, skip) + let final_position = "call cursor(" . line(".") . "," . col(".") . ")" + " Restore cursor position and original screen. + execute restore_cursor + normal! m' + if sp_return > 0 + execute final_position + endif + return s:CleanUp(restore_options, a:mode, startline, startcol, mid.'\|'.fin) +endfun + +" Restore options and do some special handling for Operator-pending mode. +" The optional argument is the tail of the matching group. +fun! s:CleanUp(options, mode, startline, startcol, ...) + execute "set" a:options + " Open folds, if appropriate. + if a:mode != "o" + if &foldopen =~ "percent" + normal! zv + endif + " In Operator-pending mode, we want to include the whole match + " (for example, d%). + " This is only a problem if we end up moving in the forward direction. + elseif (a:startline < line(".")) || + \ (a:startline == line(".") && a:startcol < col(".")) + if a:0 + " Check whether the match is a single character. If not, move to the + " end of the match. + let matchline = getline(".") + let currcol = col(".") + let regexp = s:Wholematch(matchline, a:1, currcol-1) + let endcol = matchend(matchline, regexp) + if endcol > currcol " This is NOT off by one! + execute "normal!" . (endcol - currcol) . "l" + endif + endif " a:0 + endif " a:mode != "o" && etc. + return 0 +endfun + +" Example (simplified HTML patterns): if +" a:groupBR = '<\(\k\+\)>:</\1>' +" a:prefix = '^.\{3}\(' +" a:group = '<\(\k\+\)>:</\(\k\+\)>' +" a:suffix = '\).\{2}$' +" a:matchline = "123<tag>12" or "123</tag>12" +" then extract "tag" from a:matchline and return "<tag>:</tag>" . +fun! s:InsertRefs(groupBR, prefix, group, suffix, matchline) + if a:matchline !~ a:prefix . + \ substitute(a:group, s:notslash . '\zs:', '\\|', 'g') . a:suffix + return a:group + endif + let i = matchend(a:groupBR, s:notslash . ':') + let ini = strpart(a:groupBR, 0, i-1) + let tailBR = strpart(a:groupBR, i) + let word = s:Choose(a:group, a:matchline, ":", "", a:prefix, a:suffix, + \ a:groupBR) + let i = matchend(word, s:notslash . ":") + let wordBR = strpart(word, i) + let word = strpart(word, 0, i-1) + " Now, a:matchline =~ a:prefix . word . a:suffix + if wordBR != ini + let table = s:Resolve(ini, wordBR, "table") + else + " let table = "----------" + let table = "" + let d = 0 + while d < 10 + if tailBR =~ s:notslash . '\\' . d + " let table[d] = d + let table = table . d + else + let table = table . "-" + endif + let d = d + 1 + endwhile + endif + let d = 9 + while d + if table[d] != "-" + let backref = substitute(a:matchline, a:prefix.word.a:suffix, + \ '\'.table[d], "") + " Are there any other characters that should be escaped? + let backref = escape(backref, '*,:') + execute s:Ref(ini, d, "start", "len") + let ini = strpart(ini, 0, start) . backref . strpart(ini, start+len) + let tailBR = substitute(tailBR, s:notslash . '\zs\\' . d, + \ escape(backref, '\\&'), 'g') + endif + let d = d-1 + endwhile + if exists("b:match_debug") + if s:do_BR + let b:match_table = table + let b:match_word = word + else + let b:match_table = "" + let b:match_word = "" + endif + endif + return ini . ":" . tailBR +endfun + +" Input a comma-separated list of groups with backrefs, such as +" a:groups = '\(foo\):end\1,\(bar\):end\1' +" and return a comma-separated list of groups with backrefs replaced: +" return '\(foo\):end\(foo\),\(bar\):end\(bar\)' +fun! s:ParseWords(groups) + let groups = substitute(a:groups.",", s:notslash.'\zs[,:]*,[,:]*', ',', 'g') + let groups = substitute(groups, s:notslash . '\zs:\{2,}', ':', 'g') + let parsed = "" + while groups =~ '[^,:]' + let i = matchend(groups, s:notslash . ':') + let j = matchend(groups, s:notslash . ',') + let ini = strpart(groups, 0, i-1) + let tail = strpart(groups, i, j-i-1) . ":" + let groups = strpart(groups, j) + let parsed = parsed . ini + let i = matchend(tail, s:notslash . ':') + while i != -1 + " In 'if:else:endif', ini='if' and word='else' and then word='endif'. + let word = strpart(tail, 0, i-1) + let tail = strpart(tail, i) + let i = matchend(tail, s:notslash . ':') + let parsed = parsed . ":" . s:Resolve(ini, word, "word") + endwhile " Now, tail has been used up. + let parsed = parsed . "," + endwhile " groups =~ '[^,:]' + let parsed = substitute(parsed, ',$', '', '') + return parsed +endfun + +" TODO I think this can be simplified and/or made more efficient. +" TODO What should I do if a:start is out of range? +" Return a regexp that matches all of a:string, such that +" matchstr(a:string, regexp) represents the match for a:pat that starts +" as close to a:start as possible, before being preferred to after, and +" ends after a:start . +" Usage: +" let regexp = s:Wholematch(getline("."), 'foo\|bar', col(".")-1) +" let i = match(getline("."), regexp) +" let j = matchend(getline("."), regexp) +" let match = matchstr(getline("."), regexp) +fun! s:Wholematch(string, pat, start) + let group = '\%(' . a:pat . '\)' + let prefix = (a:start ? '\(^.*\%<' . (a:start + 2) . 'c\)\zs' : '^') + let len = strlen(a:string) + let suffix = (a:start+1 < len ? '\(\%>'.(a:start+1).'c.*$\)\@=' : '$') + if a:string !~ prefix . group . suffix + let prefix = '' + endif + return prefix . group . suffix +endfun + +" No extra arguments: s:Ref(string, d) will +" find the d'th occurrence of '\(' and return it, along with everything up +" to and including the matching '\)'. +" One argument: s:Ref(string, d, "start") returns the index of the start +" of the d'th '\(' and any other argument returns the length of the group. +" Two arguments: s:Ref(string, d, "foo", "bar") returns a string to be +" executed, having the effect of +" :let foo = s:Ref(string, d, "start") +" :let bar = s:Ref(string, d, "len") +fun! s:Ref(string, d, ...) + let len = strlen(a:string) + if a:d == 0 + let start = 0 + else + let cnt = a:d + let match = a:string + while cnt + let cnt = cnt - 1 + let index = matchend(match, s:notslash . '\\(') + if index == -1 + return "" + endif + let match = strpart(match, index) + endwhile + let start = len - strlen(match) + if a:0 == 1 && a:1 == "start" + return start - 2 + endif + let cnt = 1 + while cnt + let index = matchend(match, s:notslash . '\\(\|\\)') - 1 + if index == -2 + return "" + endif + " Increment if an open, decrement if a ')': + let cnt = cnt + (match[index]=="(" ? 1 : -1) " ')' + " let cnt = stridx('0(', match[index]) + cnt + let match = strpart(match, index+1) + endwhile + let start = start - 2 + let len = len - start - strlen(match) + endif + if a:0 == 1 + return len + elseif a:0 == 2 + return "let " . a:1 . "=" . start . "| let " . a:2 . "=" . len + else + return strpart(a:string, start, len) + endif +endfun + +" Count the number of disjoint copies of pattern in string. +" If the pattern is a literal string and contains no '0' or '1' characters +" then s:Count(string, pattern, '0', '1') should be faster than +" s:Count(string, pattern). +fun! s:Count(string, pattern, ...) + let pat = escape(a:pattern, '\\') + if a:0 > 1 + let foo = substitute(a:string, '[^'.a:pattern.']', "a:1", "g") + let foo = substitute(a:string, pat, a:2, "g") + let foo = substitute(foo, '[^' . a:2 . ']', "", "g") + return strlen(foo) + endif + let result = 0 + let foo = a:string + let index = matchend(foo, pat) + while index != -1 + let result = result + 1 + let foo = strpart(foo, index) + let index = matchend(foo, pat) + endwhile + return result +endfun + +" s:Resolve('\(a\)\(b\)', '\(c\)\2\1\1\2') should return table.word, where +" word = '\(c\)\(b\)\(a\)\3\2' and table = '-32-------'. That is, the first +" '\1' in target is replaced by '\(a\)' in word, table[1] = 3, and this +" indicates that all other instances of '\1' in target are to be replaced +" by '\3'. The hard part is dealing with nesting... +" Note that ":" is an illegal character for source and target, +" unless it is preceded by "\". +fun! s:Resolve(source, target, output) + let word = a:target + let i = matchend(word, s:notslash . '\\\d') - 1 + let table = "----------" + while i != -2 " There are back references to be replaced. + let d = word[i] + let backref = s:Ref(a:source, d) + " The idea is to replace '\d' with backref. Before we do this, + " replace any \(\) groups in backref with :1, :2, ... if they + " correspond to the first, second, ... group already inserted + " into backref. Later, replace :1 with \1 and so on. The group + " number w+b within backref corresponds to the group number + " s within a:source. + " w = number of '\(' in word before the current one + let w = s:Count( + \ substitute(strpart(word, 0, i-1), '\\\\', '', 'g'), '\(', '1') + let b = 1 " number of the current '\(' in backref + let s = d " number of the current '\(' in a:source + while b <= s:Count(substitute(backref, '\\\\', '', 'g'), '\(', '1') + \ && s < 10 + if table[s] == "-" + if w + b < 10 + " let table[s] = w + b + let table = strpart(table, 0, s) . (w+b) . strpart(table, s+1) + endif + let b = b + 1 + let s = s + 1 + else + execute s:Ref(backref, b, "start", "len") + let ref = strpart(backref, start, len) + let backref = strpart(backref, 0, start) . ":". table[s] + \ . strpart(backref, start+len) + let s = s + s:Count(substitute(ref, '\\\\', '', 'g'), '\(', '1') + endif + endwhile + let word = strpart(word, 0, i-1) . backref . strpart(word, i+1) + let i = matchend(word, s:notslash . '\\\d') - 1 + endwhile + let word = substitute(word, s:notslash . '\zs:', '\\', 'g') + if a:output == "table" + return table + elseif a:output == "word" + return word + else + return table . word + endif +endfun + +" Assume a:comma = ",". Then the format for a:patterns and a:1 is +" a:patterns = "<pat1>,<pat2>,..." +" a:1 = "<alt1>,<alt2>,..." +" If <patn> is the first pattern that matches a:string then return <patn> +" if no optional arguments are given; return <patn>,<altn> if a:1 is given. +fun! s:Choose(patterns, string, comma, branch, prefix, suffix, ...) + let tail = (a:patterns =~ a:comma."$" ? a:patterns : a:patterns . a:comma) + let i = matchend(tail, s:notslash . a:comma) + if a:0 + let alttail = (a:1 =~ a:comma."$" ? a:1 : a:1 . a:comma) + let j = matchend(alttail, s:notslash . a:comma) + endif + let current = strpart(tail, 0, i-1) + if a:branch == "" + let currpat = current + else + let currpat = substitute(current, s:notslash . a:branch, '\\|', 'g') + endif + while a:string !~ a:prefix . currpat . a:suffix + let tail = strpart(tail, i) + let i = matchend(tail, s:notslash . a:comma) + if i == -1 + return -1 + endif + let current = strpart(tail, 0, i-1) + if a:branch == "" + let currpat = current + else + let currpat = substitute(current, s:notslash . a:branch, '\\|', 'g') + endif + if a:0 + let alttail = strpart(alttail, j) + let j = matchend(alttail, s:notslash . a:comma) + endif + endwhile + if a:0 + let current = current . a:comma . strpart(alttail, 0, j-1) + endif + return current +endfun + +" Call this function to turn on debugging information. Every time the main +" script is run, buffer variables will be saved. These can be used directly +" or viewed using the menu items below. +if !exists(":MatchDebug") + command! -nargs=0 MatchDebug call s:Match_debug() +endif + +fun! s:Match_debug() + let b:match_debug = 1 " Save debugging information. + " pat = all of b:match_words with backrefs parsed + amenu &Matchit.&pat :echo b:match_pat<CR> + " match = bit of text that is recognized as a match + amenu &Matchit.&match :echo b:match_match<CR> + " curcol = cursor column of the start of the matching text + amenu &Matchit.&curcol :echo b:match_col<CR> + " wholeBR = matching group, original version + amenu &Matchit.wh&oleBR :echo b:match_wholeBR<CR> + " iniBR = 'if' piece, original version + amenu &Matchit.ini&BR :echo b:match_iniBR<CR> + " ini = 'if' piece, with all backrefs resolved from match + amenu &Matchit.&ini :echo b:match_ini<CR> + " tail = 'else\|endif' piece, with all backrefs resolved from match + amenu &Matchit.&tail :echo b:match_tail<CR> + " fin = 'endif' piece, with all backrefs resolved from match + amenu &Matchit.&word :echo b:match_word<CR> + " '\'.d in ini refers to the same thing as '\'.table[d] in word. + amenu &Matchit.t&able :echo '0:' . b:match_table . ':9'<CR> +endfun + +" Jump to the nearest unmatched "(" or "if" or "<tag>" if a:spflag == "bW" +" or the nearest unmatched "</tag>" or "endif" or ")" if a:spflag == "W". +" Return a "mark" for the original position, so that +" let m = MultiMatch("bW", "n") ... execute m +" will return to the original position. If there is a problem, do not +" move the cursor and return "", unless a count is given, in which case +" go up or down as many levels as possible and again return "". +" TODO This relies on the same patterns as % matching. It might be a good +" idea to give it its own matching patterns. +fun! s:MultiMatch(spflag, mode) + if !exists("b:match_words") || b:match_words == "" + return "" + end + let restore_options = (&ic ? "" : "no") . "ignorecase" + if exists("b:match_ignorecase") + let &ignorecase = b:match_ignorecase + endif + let startline = line(".") + let startcol = col(".") + + " First step: if not already done, set the script variables + " s:do_BR flag for whether there are backrefs + " s:pat parsed version of b:match_words + " s:all regexp based on s:pat and the default groups + " This part is copied and slightly modified from s:Match_wrapper(). + let default = escape(&mps, '[$^.*~\\/?]') . (strlen(&mps) ? "," : "") . + \ '\/\*:\*\/,#if\%(def\)\=:#else\>:#elif\>:#endif\>' + " Allow b:match_words = "GetVimMatchWords()" . + if b:match_words =~ ":" + let match_words = b:match_words + else + execute "let match_words =" b:match_words + endif + if (match_words != s:last_words) || (&mps != s:last_mps) || + \ exists("b:match_debug") + let s:last_words = match_words + let s:last_mps = &mps + if match_words !~ s:notslash . '\\\d' + let s:do_BR = 0 + let s:pat = match_words + else + let s:do_BR = 1 + let s:pat = s:ParseWords(match_words) + endif + let s:all = '\%(' . substitute(s:pat . (strlen(s:pat)?",":"") . default, + \ '[,:]\+','\\|','g') . '\)' + if exists("b:match_debug") + let b:match_pat = s:pat + endif + endif + + " Second step: figure out the patterns for searchpair() + " and save the screen, cursor position, and 'ignorecase'. + " - TODO: A lot of this is copied from s:Match_wrapper(). + " - maybe even more functionality should be split off + " - into separate functions! + let cdefault = (s:pat =~ '[^,]$' ? "," : "") . default + let open = substitute(s:pat . cdefault, + \ s:notslash . '\zs:.\{-}' . s:notslash . ',', '\\),\\(', 'g') + let open = '\(' . substitute(open, s:notslash . '\zs:.*$', '\\)', '') + let close = substitute(s:pat . cdefault, + \ s:notslash . '\zs,.\{-}' . s:notslash . ':', '\\),\\(', 'g') + let close = substitute(close, '^.\{-}' . s:notslash . ':', '\\(', '') . '\)' + if exists("b:match_skip") + let skip = b:match_skip + elseif exists("b:match_comment") " backwards compatibility and testing! + let skip = "r:" . b:match_comment + else + let skip = 's:comment\|string' + endif + let skip = s:ParseSkip(skip) + " let restore_cursor = line(".") . "G" . virtcol(".") . "|" + " normal! H + " let restore_cursor = "normal!" . line(".") . "Gzt" . restore_cursor + let restore_cursor = virtcol(".") . "|" + normal! g0 + let restore_cursor = line(".") . "G" . virtcol(".") . "|zs" . restore_cursor + normal! H + let restore_cursor = "normal!" . line(".") . "Gzt" . restore_cursor + execute restore_cursor + + " Third step: call searchpair(). + " Replace '\('--but not '\\('--with '\%(' and ',' with '\|'. + let openpat = substitute(open, '\(\\\@<!\(\\\\\)*\)\@<=\\(', '\\%(', 'g') + let openpat = substitute(openpat, ',', '\\|', 'g') + let closepat = substitute(close, '\(\\\@<!\(\\\\\)*\)\@<=\\(', '\\%(', 'g') + let closepat = substitute(closepat, ',', '\\|', 'g') + if skip =~ 'synID' && !(has("syntax") && exists("g:syntax_on")) + let skip = '0' + else + execute "if " . skip . "| let skip = '0' | endif" + endif + mark ' + let level = v:count1 + while level + if searchpair(openpat, '', closepat, a:spflag, skip) < 1 + call s:CleanUp(restore_options, a:mode, startline, startcol) + return "" + endif + let level = level - 1 + endwhile + + " Restore options and return a string to restore the original position. + call s:CleanUp(restore_options, a:mode, startline, startcol) + return restore_cursor +endfun + +" Search backwards for "if" or "while" or "<tag>" or ... +" and return "endif" or "endwhile" or "</tag>" or ... . +" For now, this uses b:match_words and the same script variables +" as s:Match_wrapper() . Later, it may get its own patterns, +" either from a buffer variable or passed as arguments. +" fun! s:Autocomplete() +" echo "autocomplete not yet implemented :-(" +" if !exists("b:match_words") || b:match_words == "" +" return "" +" end +" let startpos = s:MultiMatch("bW") +" +" if startpos == "" +" return "" +" endif +" " - TODO: figure out whether 'if' or '<tag>' matched, and construct +" " - the appropriate closing. +" let matchline = getline(".") +" let curcol = col(".") - 1 +" " - TODO: Change the s:all argument if there is a new set of match pats. +" let regexp = s:Wholematch(matchline, s:all, curcol) +" let suf = strlen(matchline) - matchend(matchline, regexp) +" let prefix = (curcol ? '^.\{' . curcol . '}\%(' : '^\%(') +" let suffix = (suf ? '\).\{' . suf . '}$' : '\)$') +" " Reconstruct the version with unresolved backrefs. +" let patBR = substitute(b:match_words.',', '[,:]*,[,:]*', ',', 'g') +" let patBR = substitute(patBR, ':\{2,}', ':', "g") +" " Now, set group and groupBR to the matching group: 'if:endif' or +" " 'while:endwhile' or whatever. +" let group = s:Choose(s:pat, matchline, ",", ":", prefix, suffix, patBR) +" let i = matchend(group, s:notslash . ",") +" let groupBR = strpart(group, i) +" let group = strpart(group, 0, i-1) +" " Now, matchline =~ prefix . substitute(group,':','\|','g') . suffix +" if s:do_BR +" let group = s:InsertRefs(groupBR, prefix, group, suffix, matchline) +" endif +" " let g:group = group +" +" " - TODO: Construct the closing from group. +" let fake = "end" . expand("<cword>") +" execute startpos +" return fake +" endfun + +" Close all open structures. "Get the heck out of here!" +" fun! s:Gthhoh() +" let close = s:Autocomplete() +" while strlen(close) +" put=close +" let close = s:Autocomplete() +" endwhile +" endfun + +" Parse special strings as typical skip arguments for searchpair(): +" s:foo becomes (current syntax item) =~ foo +" S:foo becomes (current syntax item) !~ foo +" r:foo becomes (line before cursor) =~ foo +" R:foo becomes (line before cursor) !~ foo +fun! s:ParseSkip(str) + let skip = a:str + if skip[1] == ":" + if skip[0] == "s" + let skip = "synIDattr(synID(line('.'),col('.'),1),'name') =~? '" . + \ strpart(skip,2) . "'" + elseif skip[0] == "S" + let skip = "synIDattr(synID(line('.'),col('.'),1),'name') !~? '" . + \ strpart(skip,2) . "'" + elseif skip[0] == "r" + let skip = "strpart(getline('.'),0,col('.'))=~'" . strpart(skip,2). "'" + elseif skip[0] == "R" + let skip = "strpart(getline('.'),0,col('.'))!~'" . strpart(skip,2). "'" + endif + endif + return skip +endfun + +let &cpo = s:save_cpo + +" vim:sts=2:sw=2: diff --git a/share/vim/vim72/macros/maze.info b/share/vim/vim73/macros/maze.info similarity index 100% rename from share/vim/vim72/macros/maze.info rename to share/vim/vim73/macros/maze.info diff --git a/share/vim/vim72/macros/maze/Makefile b/share/vim/vim73/macros/maze/Makefile similarity index 100% rename from share/vim/vim72/macros/maze/Makefile rename to share/vim/vim73/macros/maze/Makefile diff --git a/share/vim/vim72/macros/maze/README.txt b/share/vim/vim73/macros/maze/README.txt similarity index 100% rename from share/vim/vim72/macros/maze/README.txt rename to share/vim/vim73/macros/maze/README.txt diff --git a/share/vim/vim72/macros/maze/README.txt.info b/share/vim/vim73/macros/maze/README.txt.info similarity index 100% rename from share/vim/vim72/macros/maze/README.txt.info rename to share/vim/vim73/macros/maze/README.txt.info diff --git a/share/vim/vim72/macros/maze/main.aap b/share/vim/vim73/macros/maze/main.aap similarity index 100% rename from share/vim/vim72/macros/maze/main.aap rename to share/vim/vim73/macros/maze/main.aap diff --git a/share/vim/vim72/macros/maze/maze.c b/share/vim/vim73/macros/maze/maze.c similarity index 100% rename from share/vim/vim72/macros/maze/maze.c rename to share/vim/vim73/macros/maze/maze.c diff --git a/share/vim/vim72/macros/maze/maze_5.78 b/share/vim/vim73/macros/maze/maze_5.78 similarity index 100% rename from share/vim/vim72/macros/maze/maze_5.78 rename to share/vim/vim73/macros/maze/maze_5.78 diff --git a/share/vim/vim72/macros/maze/maze_5.78.info b/share/vim/vim73/macros/maze/maze_5.78.info similarity index 100% rename from share/vim/vim72/macros/maze/maze_5.78.info rename to share/vim/vim73/macros/maze/maze_5.78.info diff --git a/share/vim/vim72/macros/maze/maze_mac b/share/vim/vim73/macros/maze/maze_mac similarity index 100% rename from share/vim/vim72/macros/maze/maze_mac rename to share/vim/vim73/macros/maze/maze_mac diff --git a/share/vim/vim72/macros/maze/mazeansi.c b/share/vim/vim73/macros/maze/mazeansi.c similarity index 100% rename from share/vim/vim72/macros/maze/mazeansi.c rename to share/vim/vim73/macros/maze/mazeansi.c diff --git a/share/vim/vim72/macros/maze/mazeclean.c b/share/vim/vim73/macros/maze/mazeclean.c similarity index 100% rename from share/vim/vim72/macros/maze/mazeclean.c rename to share/vim/vim73/macros/maze/mazeclean.c diff --git a/share/vim/vim72/macros/maze/poster b/share/vim/vim73/macros/maze/poster similarity index 100% rename from share/vim/vim72/macros/maze/poster rename to share/vim/vim73/macros/maze/poster diff --git a/share/vim/vim72/macros/maze/poster.info b/share/vim/vim73/macros/maze/poster.info similarity index 100% rename from share/vim/vim72/macros/maze/poster.info rename to share/vim/vim73/macros/maze/poster.info diff --git a/share/vim/vim72/macros/shellmenu.vim b/share/vim/vim73/macros/shellmenu.vim similarity index 100% rename from share/vim/vim72/macros/shellmenu.vim rename to share/vim/vim73/macros/shellmenu.vim diff --git a/share/vim/vim72/macros/swapmous.vim b/share/vim/vim73/macros/swapmous.vim similarity index 100% rename from share/vim/vim72/macros/swapmous.vim rename to share/vim/vim73/macros/swapmous.vim diff --git a/share/vim/vim72/macros/urm.info b/share/vim/vim73/macros/urm.info similarity index 100% rename from share/vim/vim72/macros/urm.info rename to share/vim/vim73/macros/urm.info diff --git a/share/vim/vim72/macros/urm/README.txt b/share/vim/vim73/macros/urm/README.txt similarity index 100% rename from share/vim/vim72/macros/urm/README.txt rename to share/vim/vim73/macros/urm/README.txt diff --git a/share/vim/vim72/macros/urm/README.txt.info b/share/vim/vim73/macros/urm/README.txt.info similarity index 100% rename from share/vim/vim72/macros/urm/README.txt.info rename to share/vim/vim73/macros/urm/README.txt.info diff --git a/share/vim/vim72/macros/urm/examples b/share/vim/vim73/macros/urm/examples similarity index 100% rename from share/vim/vim72/macros/urm/examples rename to share/vim/vim73/macros/urm/examples diff --git a/share/vim/vim72/macros/urm/urm b/share/vim/vim73/macros/urm/urm similarity index 100% rename from share/vim/vim72/macros/urm/urm rename to share/vim/vim73/macros/urm/urm diff --git a/share/vim/vim72/macros/urm/urm.vim b/share/vim/vim73/macros/urm/urm.vim similarity index 100% rename from share/vim/vim72/macros/urm/urm.vim rename to share/vim/vim73/macros/urm/urm.vim diff --git a/share/vim/vim73/makemenu.vim b/share/vim/vim73/makemenu.vim new file mode 100644 index 0000000000..c4d8bc204b --- /dev/null +++ b/share/vim/vim73/makemenu.vim @@ -0,0 +1,600 @@ +" Script to define the syntax menu in synmenu.vim +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2010 Aug 04 + +" This is used by "make menu" in the src directory. +edit <sfile>:p:h/synmenu.vim + +/The Start Of The Syntax Menu/+1,/The End Of The Syntax Menu/-1d +let s:lnum = line(".") - 1 +call append(s:lnum, "") +let s:lnum = s:lnum + 1 + +" Use the SynMenu command and function to define all menu entries +command! -nargs=* SynMenu call <SID>Syn(<q-args>) + +let s:cur_menu_name = "" +let s:cur_menu_nr = 0 +let s:cur_menu_item = 0 +let s:cur_menu_char = "" + +fun! <SID>Syn(arg) + " isolate menu name: until the first dot + let i = match(a:arg, '\.') + let menu_name = strpart(a:arg, 0, i) + let r = strpart(a:arg, i + 1, 999) + " isolate submenu name: until the colon + let i = match(r, ":") + let submenu_name = strpart(r, 0, i) + " after the colon is the syntax name + let syntax_name = strpart(r, i + 1, 999) + + if s:cur_menu_name != menu_name + let s:cur_menu_name = menu_name + let s:cur_menu_nr = s:cur_menu_nr + 10 + let s:cur_menu_item = 100 + let s:cur_menu_char = submenu_name[0] + else + " When starting a new letter, insert a menu separator. + let c = submenu_name[0] + if c != s:cur_menu_char + exe 'an 50.' . s:cur_menu_nr . '.' . s:cur_menu_item . ' &Syntax.' . menu_name . ".-" . c . '- <nul>' + let s:cur_menu_item = s:cur_menu_item + 10 + let s:cur_menu_char = c + endif + endif + call append(s:lnum, 'an 50.' . s:cur_menu_nr . '.' . s:cur_menu_item . ' &Syntax.' . menu_name . "." . submenu_name . ' :cal SetSyn("' . syntax_name . '")<CR>') + let s:cur_menu_item = s:cur_menu_item + 10 + let s:lnum = s:lnum + 1 +endfun + +SynMenu AB.A2ps\ config:a2ps +SynMenu AB.Aap:aap +SynMenu AB.ABAP/4:abap +SynMenu AB.Abaqus:abaqus +SynMenu AB.ABC\ music\ notation:abc +SynMenu AB.ABEL:abel +SynMenu AB.AceDB\ model:acedb +SynMenu AB.Ada:ada +SynMenu AB.AfLex:aflex +SynMenu AB.ALSA\ config:alsaconf +SynMenu AB.Altera\ AHDL:ahdl +SynMenu AB.Amiga\ DOS:amiga +SynMenu AB.AMPL:ampl +SynMenu AB.Ant\ build\ file:ant +SynMenu AB.ANTLR:antlr +SynMenu AB.Apache\ config:apache +SynMenu AB.Apache-style\ config:apachestyle +SynMenu AB.Applix\ ELF:elf +SynMenu AB.Arc\ Macro\ Language:aml +SynMenu AB.Arch\ inventory:arch +SynMenu AB.ART:art +SynMenu AB.ASP\ with\ VBScript:aspvbs +SynMenu AB.ASP\ with\ Perl:aspperl +SynMenu AB.Assembly.680x0:asm68k +SynMenu AB.Assembly.Flat:fasm +SynMenu AB.Assembly.GNU:asm +SynMenu AB.Assembly.GNU\ H-8300:asmh8300 +SynMenu AB.Assembly.Intel\ IA-64:ia64 +SynMenu AB.Assembly.Microsoft:masm +SynMenu AB.Assembly.Netwide:nasm +SynMenu AB.Assembly.PIC:pic +SynMenu AB.Assembly.Turbo:tasm +SynMenu AB.Assembly.VAX\ Macro\ Assembly:vmasm +SynMenu AB.Assembly.Z-80:z8a +SynMenu AB.Assembly.xa\ 6502\ cross\ assember:a65 +SynMenu AB.ASN\.1:asn +SynMenu AB.Asterisk\ config:asterisk +SynMenu AB.Asterisk\ voicemail\ config:asteriskvm +SynMenu AB.Atlas:atlas +SynMenu AB.AutoHotKey:autohotkey +SynMenu AB.AutoIt:autoit +SynMenu AB.Automake:automake +SynMenu AB.Avenue:ave +SynMenu AB.Awk:awk +SynMenu AB.AYacc:ayacc + +SynMenu AB.B:b +SynMenu AB.Baan:baan +SynMenu AB.Basic.FreeBasic:freebasic +SynMenu AB.Basic.IBasic:ibasic +SynMenu AB.Basic.QBasic:basic +SynMenu AB.Basic.Visual\ Basic:vb +SynMenu AB.Bazaar\ commit\ file:bzr +SynMenu AB.BC\ calculator:bc +SynMenu AB.BDF\ font:bdf +SynMenu AB.BibTeX.Bibliography\ database:bib +SynMenu AB.BibTeX.Bibliography\ Style:bst +SynMenu AB.BIND.BIND\ config:named +SynMenu AB.BIND.BIND\ zone:bindzone +SynMenu AB.Blank:blank + +SynMenu C.C:c +SynMenu C.C++:cpp +SynMenu C.C#:cs +SynMenu C.Cabal\ Haskell\ build\ file:cabal +SynMenu C.Calendar:calendar +SynMenu C.Cascading\ Style\ Sheets:css +SynMenu C.CDL:cdl +SynMenu C.Cdrdao\ TOC:cdrtoc +SynMenu C.Cdrdao\ config:cdrdaoconf +SynMenu C.Century\ Term:cterm +SynMenu C.CH\ script:ch +SynMenu C.ChaiScript:chaiscript +SynMenu C.ChangeLog:changelog +SynMenu C.Cheetah\ template:cheetah +SynMenu C.CHILL:chill +SynMenu C.ChordPro:chordpro +SynMenu C.Clean:clean +SynMenu C.Clever:cl +SynMenu C.Clipper:clipper +SynMenu C.Cmake:cmake +SynMenu C.Cmusrc:cmusrc +SynMenu C.Cobol:cobol +SynMenu C.Coco/R:coco +SynMenu C.Cold\ Fusion:cf +SynMenu C.Conary\ Recipe:conaryrecipe +SynMenu C.Config.Cfg\ Config\ file:cfg +SynMenu C.Config.Configure\.in:config +SynMenu C.Config.Generic\ Config\ file:conf +SynMenu C.CRM114:crm +SynMenu C.Crontab:crontab +SynMenu C.CSP:csp +SynMenu C.Ctrl-H:ctrlh +SynMenu C.Cucumber:cucumber +SynMenu C.CUDA:cuda +SynMenu C.CUPL.CUPL:cupl +SynMenu C.CUPL.Simulation:cuplsim +SynMenu C.CVS.commit\ file:cvs +SynMenu C.CVS.cvsrc:cvsrc +SynMenu C.Cyn++:cynpp +SynMenu C.Cynlib:cynlib + +SynMenu DE.D:d +SynMenu DE.Datascript:datascript +SynMenu DE.Debian.Debian\ ChangeLog:debchangelog +SynMenu DE.Debian.Debian\ Control:debcontrol +SynMenu DE.Debian.Debian\ Sources\.list:debsources +SynMenu DE.Denyhosts:denyhosts +SynMenu DE.Desktop:desktop +SynMenu DE.Dict\ config:dictconf +SynMenu DE.Dictd\ config:dictdconf +SynMenu DE.Diff:diff +SynMenu DE.Digital\ Command\ Lang:dcl +SynMenu DE.Dircolors:dircolors +SynMenu DE.Django\ template:django +SynMenu DE.DNS/BIND\ zone:bindzone +SynMenu DE.DocBook.auto-detect:docbk +SynMenu DE.DocBook.SGML:docbksgml +SynMenu DE.DocBook.XML:docbkxml +SynMenu DE.Dot:dot +SynMenu DE.Doxygen.C\ with\ doxygen:c.doxygen +SynMenu DE.Doxygen.C++\ with\ doxygen:cpp.doxygen +SynMenu DE.Doxygen.IDL\ with\ doxygen:idl.doxygen +SynMenu DE.Doxygen.Java\ with\ doxygen:java.doxygen +SynMenu DE.Dracula:dracula +SynMenu DE.DSSSL:dsl +SynMenu DE.DTD:dtd +SynMenu DE.DTML\ (Zope):dtml +SynMenu DE.DTrace:dtrace +SynMenu DE.Dylan.Dylan:dylan +SynMenu DE.Dylan.Dylan\ interface:dylanintr +SynMenu DE.Dylan.Dylan\ lid:dylanlid + +SynMenu DE.EDIF:edif +SynMenu DE.Eiffel:eiffel +SynMenu DE.Elinks\ config:elinks +SynMenu DE.Elm\ filter\ rules:elmfilt +SynMenu DE.Embedix\ Component\ Description:ecd +SynMenu DE.ERicsson\ LANGuage:erlang +SynMenu DE.ESMTP\ rc:esmtprc +SynMenu DE.ESQL-C:esqlc +SynMenu DE.Essbase\ script:csc +SynMenu DE.Esterel:esterel +SynMenu DE.Eterm\ config:eterm +SynMenu DE.Eviews:eviews +SynMenu DE.Exim\ conf:exim +SynMenu DE.Expect:expect +SynMenu DE.Exports:exports + +SynMenu FG.Fantom:fan +SynMenu FG.Fetchmail:fetchmail +SynMenu FG.FlexWiki:flexwiki +SynMenu FG.Focus\ Executable:focexec +SynMenu FG.Focus\ Master:master +SynMenu FG.FORM:form +SynMenu FG.Forth:forth +SynMenu FG.Fortran:fortran +SynMenu FG.FoxPro:foxpro +SynMenu FG.FrameScript:framescript +SynMenu FG.Fstab:fstab +SynMenu FG.Fvwm.Fvwm\ configuration:fvwm1 +SynMenu FG.Fvwm.Fvwm2\ configuration:fvwm2 +SynMenu FG.Fvwm.Fvwm2\ configuration\ with\ M4:fvwm2m4 + +SynMenu FG.GDB\ command\ file:gdb +SynMenu FG.GDMO:gdmo +SynMenu FG.Gedcom:gedcom +SynMenu FG.Git.Output:git +SynMenu FG.Git.Commit:gitcommit +SynMenu FG.Git.Config:gitconfig +SynMenu FG.Git.Rebase:gitrebase +SynMenu FG.Git.Send\ Email:gitsendemail +SynMenu FG.Gkrellmrc:gkrellmrc +SynMenu FG.GP:gp +SynMenu FG.GPG:gpg +SynMenu FG.Group\ file:group +SynMenu FG.Grub:grub +SynMenu FG.GNU\ Server\ Pages:gsp +SynMenu FG.GNUplot:gnuplot +SynMenu FG.GrADS\ scripts:grads +SynMenu FG.Gretl:gretl +SynMenu FG.Groff:groff +SynMenu FG.Groovy:groovy +SynMenu FG.GTKrc:gtkrc + +SynMenu HIJK.Haml:haml +SynMenu HIJK.Hamster:hamster +SynMenu HIJK.Haskell.Haskell:haskell +SynMenu HIJK.Haskell.Haskell-c2hs:chaskell +SynMenu HIJK.Haskell.Haskell-literate:lhaskell +SynMenu HIJK.HASTE:haste +SynMenu HIJK.HASTE\ preproc:hastepreproc +SynMenu HIJK.Hercules:hercules +SynMenu HIJK.Hex\ dump.XXD:xxd +SynMenu HIJK.Hex\ dump.Intel\ MCS51:hex +SynMenu HIJK.HTML.HTML:html +SynMenu HIJK.HTML.HTML\ with\ M4:htmlm4 +SynMenu HIJK.HTML.HTML\ with\ Ruby\ (eRuby):eruby +SynMenu HIJK.HTML.Cheetah\ HTML\ template:htmlcheetah +SynMenu HIJK.HTML.Django\ HTML\ template:htmldjango +SynMenu HIJK.HTML.HTML/OS:htmlos +SynMenu HIJK.HTML.XHTML:xhtml +SynMenu HIJK.Host\.conf:hostconf +SynMenu HIJK.Hyper\ Builder:hb +SynMenu HIJK.Icewm\ menu:icemenu +SynMenu HIJK.Icon:icon +SynMenu HIJK.IDL\Generic\ IDL:idl +SynMenu HIJK.IDL\Microsoft\ IDL:msidl +SynMenu HIJK.Indent\ profile:indent +SynMenu HIJK.Inform:inform +SynMenu HIJK.Informix\ 4GL:fgl +SynMenu HIJK.Initng:initng +SynMenu HIJK.Inittab:inittab +SynMenu HIJK.Inno\ setup:iss +SynMenu HIJK.InstallShield\ script:ishd +SynMenu HIJK.Interactive\ Data\ Lang:idlang +SynMenu HIJK.IPfilter:ipfilter +SynMenu HIJK.JAL:jal +SynMenu HIJK.JAM:jam +SynMenu HIJK.Jargon:jargon +SynMenu HIJK.Java.Java:java +SynMenu HIJK.Java.JavaCC:javacc +SynMenu HIJK.Java.Java\ Server\ Pages:jsp +SynMenu HIJK.Java.Java\ Properties:jproperties +SynMenu HIJK.JavaScript:javascript +SynMenu HIJK.Jess:jess +SynMenu HIJK.Jgraph:jgraph +SynMenu HIJK.Kconfig:kconfig +SynMenu HIJK.KDE\ script:kscript +SynMenu HIJK.Kimwitu++:kwt +SynMenu HIJK.KixTart:kix + +SynMenu L.Lace:lace +SynMenu L.LamdaProlog:lprolog +SynMenu L.Latte:latte +SynMenu L.Ld\ script:ld +SynMenu L.LDAP.LDIF:ldif +SynMenu L.LDAP.Configuration:ldapconf +SynMenu L.Lex:lex +SynMenu L.LFTP\ config:lftp +SynMenu L.Libao:libao +SynMenu L.LifeLines\ script:lifelines +SynMenu L.Lilo:lilo +SynMenu L.Limits\ config:limits +SynMenu L.Linden\ scripting:lsl +SynMenu L.Liquid:liquid +SynMenu L.Lisp:lisp +SynMenu L.Lite:lite +SynMenu L.LiteStep\ RC:litestep +SynMenu L.Locale\ Input:fdcc +SynMenu L.Login\.access:loginaccess +SynMenu L.Login\.defs:logindefs +SynMenu L.Logtalk:logtalk +SynMenu L.LOTOS:lotos +SynMenu L.LotusScript:lscript +SynMenu L.Lout:lout +SynMenu L.LPC:lpc +SynMenu L.Lua:lua +SynMenu L.Lynx\ Style:lss +SynMenu L.Lynx\ config:lynx + +SynMenu M.M4:m4 +SynMenu M.MaGic\ Point:mgp +SynMenu M.Mail:mail +SynMenu M.Mail\ aliases:mailaliases +SynMenu M.Mailcap:mailcap +SynMenu M.Makefile:make +SynMenu M.MakeIndex:ist +SynMenu M.Man\ page:man +SynMenu M.Man\.conf:manconf +SynMenu M.Maple\ V:maple +SynMenu M.Markdown:markdown +SynMenu M.Mason:mason +SynMenu M.Mathematica:mma +SynMenu M.Matlab:matlab +SynMenu M.Maxima:maxima +SynMenu M.MEL\ (for\ Maya):mel +SynMenu M.Messages\ (/var/log):messages +SynMenu M.Metafont:mf +SynMenu M.MetaPost:mp +SynMenu M.MGL:mgl +SynMenu M.MMIX:mmix +SynMenu M.Modconf:modconf +SynMenu M.Model:model +SynMenu M.Modsim\ III:modsim3 +SynMenu M.Modula\ 2:modula2 +SynMenu M.Modula\ 3:modula3 +SynMenu M.Monk:monk +SynMenu M.Mplayer\ config:mplayerconf +SynMenu M.MOO:moo +SynMenu M.Mrxvtrc:mrxvtrc +SynMenu M.MS-DOS/Windows.4DOS\ \.bat\ file:btm +SynMenu M.MS-DOS/Windows.\.bat\/\.cmd\ file:dosbatch +SynMenu M.MS-DOS/Windows.\.ini\ file:dosini +SynMenu M.MS-DOS/Windows.Message\ text:msmessages +SynMenu M.MS-DOS/Windows.Module\ Definition:def +SynMenu M.MS-DOS/Windows.Registry:registry +SynMenu M.MS-DOS/Windows.Resource\ file:rc +SynMenu M.Msql:msql +SynMenu M.MuPAD:mupad +SynMenu M.MUSHcode:mush +SynMenu M.Muttrc:muttrc + +SynMenu NO.Nanorc:nanorc +SynMenu NO.Nastran\ input/DMAP:nastran +SynMenu NO.Natural:natural +SynMenu NO.Netrc:netrc +SynMenu NO.Novell\ NCF\ batch:ncf +SynMenu NO.Not\ Quite\ C\ (LEGO):nqc +SynMenu NO.Nroff:nroff +SynMenu NO.NSIS\ script:nsis +SynMenu NO.Obj\ 3D\ wavefront:obj +SynMenu NO.Objective\ C:objc +SynMenu NO.Objective\ C++:objcpp +SynMenu NO.OCAML:ocaml +SynMenu NO.Occam:occam +SynMenu NO.Omnimark:omnimark +SynMenu NO.OpenROAD:openroad +SynMenu NO.Open\ Psion\ Lang:opl +SynMenu NO.Oracle\ config:ora + +SynMenu PQ.Packet\ filter\ conf:pf +SynMenu PQ.Palm\ resource\ compiler:pilrc +SynMenu PQ.Pam\ config:pamconf +SynMenu PQ.PApp:papp +SynMenu PQ.Pascal:pascal +SynMenu PQ.Password\ file:passwd +SynMenu PQ.PCCTS:pccts +SynMenu PQ.PDF:pdf +SynMenu PQ.Perl.Perl:perl +SynMenu PQ.Perl.Perl\ 6:perl6 +SynMenu PQ.Perl.Perl\ POD:pod +SynMenu PQ.Perl.Perl\ XS:xs +SynMenu PQ.PHP.PHP\ 3-4:php +SynMenu PQ.PHP.Phtml\ (PHP\ 2):phtml +SynMenu PQ.Pike:pike +SynMenu PQ.Pine\ RC:pine +SynMenu PQ.Pinfo\ RC:pinfo +SynMenu PQ.PL/M:plm +SynMenu PQ.PL/SQL:plsql +SynMenu PQ.PLP:plp +SynMenu PQ.PO\ (GNU\ gettext):po +SynMenu PQ.Postfix\ main\ config:pfmain +SynMenu PQ.PostScript.PostScript:postscr +SynMenu PQ.PostScript.PostScript\ Printer\ Description:ppd +SynMenu PQ.Povray.Povray\ scene\ descr:pov +SynMenu PQ.Povray.Povray\ configuration:povini +SynMenu PQ.PPWizard:ppwiz +SynMenu PQ.Prescribe\ (Kyocera):prescribe +SynMenu PQ.Printcap:pcap +SynMenu PQ.Privoxy:privoxy +SynMenu PQ.Procmail:procmail +SynMenu PQ.Product\ Spec\ File:psf +SynMenu PQ.Progress:progress +SynMenu PQ.Prolog:prolog +SynMenu PQ.ProMeLa:promela +SynMenu PQ.Protocols:protocols +SynMenu PQ.Purify\ log:purifylog +SynMenu PQ.Pyrex:pyrex +SynMenu PQ.Python:python +SynMenu PQ.Quake:quake +SynMenu PQ.Quickfix\ window:qf + +SynMenu R.R.R:r +SynMenu R.R.R\ help:rhelp +SynMenu R.R.R\ noweb:rnoweb +SynMenu R.Racc\ input:racc +SynMenu R.Radiance:radiance +SynMenu R.Ratpoison:ratpoison +SynMenu R.RCS.RCS\ log\ output:rcslog +SynMenu R.RCS.RCS\ file:rcs +SynMenu R.Readline\ config:readline +SynMenu R.Rebol:rebol +SynMenu R.Remind:remind +SynMenu R.Relax\ NG\ compact:rnc +SynMenu R.Renderman.Renderman\ Shader\ Lang:sl +SynMenu R.Renderman.Renderman\ Interface\ Bytestream:rib +SynMenu R.Resolv\.conf:resolv +SynMenu R.Reva\ Forth:reva +SynMenu R.Rexx:rexx +SynMenu R.Robots\.txt:robots +SynMenu R.RockLinux\ package\ desc\.:desc +SynMenu R.Rpcgen:rpcgen +SynMenu R.RPL/2:rpl +SynMenu R.ReStructuredText:rst +SynMenu R.RTF:rtf +SynMenu R.Ruby:ruby + +SynMenu S-Sm.S-Lang:slang +SynMenu S-Sm.Samba\ config:samba +SynMenu S-Sm.SAS:sas +SynMenu S-Sm.Sass:sass +SynMenu S-Sm.Sather:sather +SynMenu S-Sm.Scheme:scheme +SynMenu S-Sm.Scilab:scilab +SynMenu S-Sm.Screen\ RC:screen +SynMenu S-Sm.SCSS:scss +SynMenu S-Sm.SDC\ Synopsys\ Design\ Constraints:sdc +SynMenu S-Sm.SDL:sdl +SynMenu S-Sm.Sed:sed +SynMenu S-Sm.Sendmail\.cf:sm +SynMenu S-Sm.Send-pr:sendpr +SynMenu S-Sm.Sensors\.conf:sensors +SynMenu S-Sm.Service\ Location\ config:slpconf +SynMenu S-Sm.Service\ Location\ registration:slpreg +SynMenu S-Sm.Service\ Location\ SPI:slpspi +SynMenu S-Sm.Services:services +SynMenu S-Sm.Setserial\ config:setserial +SynMenu S-Sm.SGML.SGML\ catalog:catalog +SynMenu S-Sm.SGML.SGML\ DTD:sgml +SynMenu S-Sm.SGML.SGML\ Declaration:sgmldecl +SynMenu S-Sm.SGML.SGML-linuxdoc:sgmllnx +SynMenu S-Sm.Shell\ script.sh\ and\ ksh:sh +SynMenu S-Sm.Shell\ script.csh:csh +SynMenu S-Sm.Shell\ script.tcsh:tcsh +SynMenu S-Sm.Shell\ script.zsh:zsh +SynMenu S-Sm.SiCAD:sicad +SynMenu S-Sm.Sieve:sieve +SynMenu S-Sm.Simula:simula +SynMenu S-Sm.Sinda.Sinda\ compare:sindacmp +SynMenu S-Sm.Sinda.Sinda\ input:sinda +SynMenu S-Sm.Sinda.Sinda\ output:sindaout +SynMenu S-Sm.SiSU:sisu +SynMenu S-Sm.SKILL.SKILL:skill +SynMenu S-Sm.SKILL.SKILL\ for\ Diva:diva +SynMenu S-Sm.Slice:slice +SynMenu S-Sm.SLRN.Slrn\ rc:slrnrc +SynMenu S-Sm.SLRN.Slrn\ score:slrnsc +SynMenu S-Sm.SmallTalk:st +SynMenu S-Sm.Smarty\ Templates:smarty +SynMenu S-Sm.SMIL:smil +SynMenu S-Sm.SMITH:smith + +SynMenu Sn-Sy.SNMP\ MIB:mib +SynMenu Sn-Sy.SNNS.SNNS\ network:snnsnet +SynMenu Sn-Sy.SNNS.SNNS\ pattern:snnspat +SynMenu Sn-Sy.SNNS.SNNS\ result:snnsres +SynMenu Sn-Sy.Snobol4:snobol4 +SynMenu Sn-Sy.Snort\ Configuration:hog +SynMenu Sn-Sy.SPEC\ (Linux\ RPM):spec +SynMenu Sn-Sy.Specman:specman +SynMenu Sn-Sy.Spice:spice +SynMenu Sn-Sy.Spyce:spyce +SynMenu Sn-Sy.Speedup:spup +SynMenu Sn-Sy.Splint:splint +SynMenu Sn-Sy.Squid\ config:squid +SynMenu Sn-Sy.SQL.ESQL-C:esqlc +SynMenu Sn-Sy.SQL.MySQL:mysql +SynMenu Sn-Sy.SQL.PL/SQL:plsql +SynMenu Sn-Sy.SQL.SQL\ Anywhere:sqlanywhere +SynMenu Sn-Sy.SQL.SQL\ (automatic):sql +SynMenu Sn-Sy.SQL.SQL\ (Oracle):sqloracle +SynMenu Sn-Sy.SQL.SQL\ Forms:sqlforms +SynMenu Sn-Sy.SQL.SQLJ:sqlj +SynMenu Sn-Sy.SQL.SQL-Informix:sqlinformix +SynMenu Sn-Sy.SQR:sqr +SynMenu Sn-Sy.Ssh.ssh_config:sshconfig +SynMenu Sn-Sy.Ssh.sshd_config:sshdconfig +SynMenu Sn-Sy.Standard\ ML:sml +SynMenu Sn-Sy.Stata.SMCL:smcl +SynMenu Sn-Sy.Stata.Stata:stata +SynMenu Sn-Sy.Stored\ Procedures:stp +SynMenu Sn-Sy.Strace:strace +SynMenu Sn-Sy.Streaming\ descriptor\ file:sd +SynMenu Sn-Sy.Subversion\ commit:svn +SynMenu Sn-Sy.Sudoers:sudoers +SynMenu Sn-Sy.SVG:svg +SynMenu Sn-Sy.Symbian\ meta-makefile:mmp +SynMenu Sn-Sy.Sysctl\.conf:sysctl + +SynMenu T.TADS:tads +SynMenu T.Tags:tags +SynMenu T.TAK.TAK\ compare:takcmp +SynMenu T.TAK.TAK\ input:tak +SynMenu T.TAK.TAK\ output:takout +SynMenu T.Task\ data:taskdata +SynMenu T.Task\ 42\ edit:taskedit +SynMenu T.Tcl/Tk:tcl +SynMenu T.TealInfo:tli +SynMenu T.Telix\ Salt:tsalt +SynMenu T.Termcap/Printcap:ptcap +SynMenu T.Terminfo:terminfo +SynMenu T.TeX.TeX/LaTeX:tex +SynMenu T.TeX.plain\ TeX:plaintex +SynMenu T.TeX.ConTeXt:context +SynMenu T.TeX.TeX\ configuration:texmf +SynMenu T.TeX.Texinfo:texinfo +SynMenu T.TF\ mud\ client:tf +SynMenu T.Tidy\ configuration:tidy +SynMenu T.Tilde:tilde +SynMenu T.TPP:tpp +SynMenu T.Trasys\ input:trasys +SynMenu T.Trustees:trustees +SynMenu T.TSS.Command\ Line:tsscl +SynMenu T.TSS.Geometry:tssgm +SynMenu T.TSS.Optics:tssop + +SynMenu UV.Udev\ config:udevconf +SynMenu UV.Udev\ permissions:udevperm +SynMenu UV.Udev\ rules:udevrules +SynMenu UV.UIT/UIL:uil +SynMenu UV.UnrealScript:uc +SynMenu UV.Updatedb\.conf:updatedb +SynMenu UV.Valgrind:valgrind +SynMenu UV.Vera:vera +SynMenu UV.Verilog-AMS\ HDL:verilogams +SynMenu UV.Verilog\ HDL:verilog +SynMenu UV.Vgrindefs:vgrindefs +SynMenu UV.VHDL:vhdl +SynMenu UV.Vim.Vim\ help\ file:help +SynMenu UV.Vim.Vim\ script:vim +SynMenu UV.Vim.Viminfo\ file:viminfo +SynMenu UV.Virata\ config:virata +SynMenu UV.Visual\ Basic:vb +SynMenu UV.VOS\ CM\ macro:voscm +SynMenu UV.VRML:vrml +SynMenu UV.VSE\ JCL:vsejcl + +SynMenu WXYZ.WEB.CWEB:cweb +SynMenu WXYZ.WEB.WEB:web +SynMenu WXYZ.WEB.WEB\ Changes:change +SynMenu WXYZ.Webmacro:webmacro +SynMenu WXYZ.Website\ MetaLanguage:wml +SynMenu WXYZ.wDiff:wdiff +SynMenu WXYZ.Wget\ config:wget +SynMenu WXYZ.Whitespace\ (add):whitespace +SynMenu WXYZ.WildPackets\ EtherPeek\ Decoder:dcd +SynMenu WXYZ.WinBatch/Webbatch:winbatch +SynMenu WXYZ.Windows\ Scripting\ Host:wsh +SynMenu WXYZ.WSML:wsml +SynMenu WXYZ.WvDial:wvdial +SynMenu WXYZ.X\ Keyboard\ Extension:xkb +SynMenu WXYZ.X\ Pixmap:xpm +SynMenu WXYZ.X\ Pixmap\ (2):xpm2 +SynMenu WXYZ.X\ resources:xdefaults +SynMenu WXYZ.XBL:xbl +SynMenu WXYZ.Xinetd\.conf:xinetd +SynMenu WXYZ.Xmodmap:xmodmap +SynMenu WXYZ.Xmath:xmath +SynMenu WXYZ.XML:xml +SynMenu WXYZ.XML\ Schema\ (XSD):xsd +SynMenu WXYZ.XQuery:xquery +SynMenu WXYZ.Xslt:xslt +SynMenu WXYZ.XFree86\ Config:xf86conf +SynMenu WXYZ.YAML:yaml +SynMenu WXYZ.Yacc:yacc + +call append(s:lnum, "") + +wq diff --git a/share/vim/vim73/menu.vim b/share/vim/vim73/menu.vim new file mode 100644 index 0000000000..2cbd55c4e9 --- /dev/null +++ b/share/vim/vim73/menu.vim @@ -0,0 +1,1106 @@ +" Vim support file to define the default menus +" You can also use this as a start for your own set of menus. +" +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2009 Feb 26 + +" Note that ":an" (short for ":anoremenu") is often used to make a menu work +" in all modes and avoid side effects from mappings defined by the user. + +" Make sure the '<' and 'C' flags are not included in 'cpoptions', otherwise +" <CR> would not be recognized. See ":help 'cpoptions'". +let s:cpo_save = &cpo +set cpo&vim + +" Avoid installing the menus twice +if !exists("did_install_default_menus") +let did_install_default_menus = 1 + + +if exists("v:lang") || &langmenu != "" + " Try to find a menu translation file for the current language. + if &langmenu != "" + if &langmenu =~ "none" + let s:lang = "" + else + let s:lang = &langmenu + endif + else + let s:lang = v:lang + endif + " A language name must be at least two characters, don't accept "C" + if strlen(s:lang) > 1 + " When the language does not include the charset add 'encoding' + if s:lang =~ '^\a\a$\|^\a\a_\a\a$' + let s:lang = s:lang . '.' . &enc + endif + + " We always use a lowercase name. + " Change "iso-8859" to "iso_8859" and "iso8859" to "iso_8859", some + " systems appear to use this. + " Change spaces to underscores. + let s:lang = substitute(tolower(s:lang), '\.iso-', ".iso_", "") + let s:lang = substitute(s:lang, '\.iso8859', ".iso_8859", "") + let s:lang = substitute(s:lang, " ", "_", "g") + " Remove "@euro", otherwise "LC_ALL=de_DE@euro gvim" will show English menus + let s:lang = substitute(s:lang, "@euro", "", "") + " Change "iso_8859-1" and "iso_8859-15" to "latin1", we always use the + " same menu file for them. + let s:lang = substitute(s:lang, 'iso_8859-15\=$', "latin1", "") + menutrans clear + exe "runtime! lang/menu_" . s:lang . ".vim" + + if !exists("did_menu_trans") + " There is no exact match, try matching with a wildcard added + " (e.g. find menu_de_de.iso_8859-1.vim if s:lang == de_DE). + let s:lang = substitute(s:lang, '\.[^.]*', "", "") + exe "runtime! lang/menu_" . s:lang . "[^a-z]*vim" + + if !exists("did_menu_trans") && strlen($LANG) > 1 && s:lang !~ '^en_us' + " On windows locale names are complicated, try using $LANG, it might + " have been set by set_init_1(). But don't do this for "en" or "en_us". + " But don't match "slovak" when $LANG is "sl". + exe "runtime! lang/menu_" . tolower($LANG) . "[^a-z]*vim" + endif + endif + endif +endif + + +" Help menu +an 9999.10 &Help.&Overview<Tab><F1> :help<CR> +an 9999.20 &Help.&User\ Manual :help usr_toc<CR> +an 9999.30 &Help.&How-to\ links :help how-to<CR> +an <silent> 9999.40 &Help.&Find\.\.\. :call <SID>Helpfind()<CR> +an 9999.45 &Help.-sep1- <Nop> +an 9999.50 &Help.&Credits :help credits<CR> +an 9999.60 &Help.Co&pying :help copying<CR> +an 9999.70 &Help.&Sponsor/Register :help sponsor<CR> +an 9999.70 &Help.O&rphans :help kcc<CR> +an 9999.75 &Help.-sep2- <Nop> +an 9999.80 &Help.&Version :version<CR> +an 9999.90 &Help.&About :intro<CR> + +fun! s:Helpfind() + if !exists("g:menutrans_help_dialog") + let g:menutrans_help_dialog = "Enter a command or word to find help on:\n\nPrepend i_ for Input mode commands (e.g.: i_CTRL-X)\nPrepend c_ for command-line editing commands (e.g.: c_<Del>)\nPrepend ' for an option name (e.g.: 'shiftwidth')" + endif + let h = inputdialog(g:menutrans_help_dialog) + if h != "" + let v:errmsg = "" + silent! exe "help " . h + if v:errmsg != "" + echo v:errmsg + endif + endif +endfun + +" File menu +an 10.310 &File.&Open\.\.\.<Tab>:e :browse confirm e<CR> +an 10.320 &File.Sp&lit-Open\.\.\.<Tab>:sp :browse sp<CR> +an 10.320 &File.Open\ Tab\.\.\.<Tab>:tabnew :browse tabnew<CR> +an 10.325 &File.&New<Tab>:enew :confirm enew<CR> +an <silent> 10.330 &File.&Close<Tab>:close + \ :if winheight(2) < 0 <Bar> + \ confirm enew <Bar> + \ else <Bar> + \ confirm close <Bar> + \ endif<CR> +an 10.335 &File.-SEP1- <Nop> +an <silent> 10.340 &File.&Save<Tab>:w :if expand("%") == ""<Bar>browse confirm w<Bar>else<Bar>confirm w<Bar>endif<CR> +an 10.350 &File.Save\ &As\.\.\.<Tab>:sav :browse confirm saveas<CR> + +if has("diff") + an 10.400 &File.-SEP2- <Nop> + an 10.410 &File.Split\ &Diff\ with\.\.\. :browse vert diffsplit<CR> + an 10.420 &File.Split\ Patched\ &By\.\.\. :browse vert diffpatch<CR> +endif + +if has("printer") + an 10.500 &File.-SEP3- <Nop> + an 10.510 &File.&Print :hardcopy<CR> + vunmenu &File.&Print + vnoremenu &File.&Print :hardcopy<CR> +elseif has("unix") + an 10.500 &File.-SEP3- <Nop> + an 10.510 &File.&Print :w !lpr<CR> + vunmenu &File.&Print + vnoremenu &File.&Print :w !lpr<CR> +endif +an 10.600 &File.-SEP4- <Nop> +an 10.610 &File.Sa&ve-Exit<Tab>:wqa :confirm wqa<CR> +an 10.620 &File.E&xit<Tab>:qa :confirm qa<CR> + +func! <SID>SelectAll() + exe "norm gg" . (&slm == "" ? "VG" : "gH\<C-O>G") +endfunc + +func! s:FnameEscape(fname) + if exists('*fnameescape') + return fnameescape(a:fname) + endif + return escape(a:fname, " \t\n*?[{`$\\%#'\"|!<") +endfunc + +" Edit menu +an 20.310 &Edit.&Undo<Tab>u u +an 20.320 &Edit.&Redo<Tab>^R <C-R> +an 20.330 &Edit.Rep&eat<Tab>\. . + +an 20.335 &Edit.-SEP1- <Nop> +vnoremenu 20.340 &Edit.Cu&t<Tab>"+x "+x +vnoremenu 20.350 &Edit.&Copy<Tab>"+y "+y +cnoremenu 20.350 &Edit.&Copy<Tab>"+y <C-Y> +nnoremenu 20.360 &Edit.&Paste<Tab>"+gP "+gP +cnoremenu &Edit.&Paste<Tab>"+gP <C-R>+ +exe 'vnoremenu <script> &Edit.&Paste<Tab>"+gP ' . paste#paste_cmd['v'] +exe 'inoremenu <script> &Edit.&Paste<Tab>"+gP ' . paste#paste_cmd['i'] +nnoremenu 20.370 &Edit.Put\ &Before<Tab>[p [p +inoremenu &Edit.Put\ &Before<Tab>[p <C-O>[p +nnoremenu 20.380 &Edit.Put\ &After<Tab>]p ]p +inoremenu &Edit.Put\ &After<Tab>]p <C-O>]p +if has("win32") || has("win16") + vnoremenu 20.390 &Edit.&Delete<Tab>x x +endif +noremenu <script> <silent> 20.400 &Edit.&Select\ All<Tab>ggVG :<C-U>call <SID>SelectAll()<CR> +inoremenu <script> <silent> 20.400 &Edit.&Select\ All<Tab>ggVG <C-O>:call <SID>SelectAll()<CR> +cnoremenu <script> <silent> 20.400 &Edit.&Select\ All<Tab>ggVG <C-U>call <SID>SelectAll()<CR> + +an 20.405 &Edit.-SEP2- <Nop> +if has("win32") || has("win16") || has("gui_gtk") || has("gui_kde") || has("gui_motif") + an 20.410 &Edit.&Find\.\.\. :promptfind<CR> + vunmenu &Edit.&Find\.\.\. + vnoremenu <silent> &Edit.&Find\.\.\. y:promptfind <C-R>=<SID>FixFText()<CR><CR> + an 20.420 &Edit.Find\ and\ Rep&lace\.\.\. :promptrepl<CR> + vunmenu &Edit.Find\ and\ Rep&lace\.\.\. + vnoremenu <silent> &Edit.Find\ and\ Rep&lace\.\.\. y:promptrepl <C-R>=<SID>FixFText()<CR><CR> +else + an 20.410 &Edit.&Find<Tab>/ / + an 20.420 &Edit.Find\ and\ Rep&lace<Tab>:%s :%s/ + vunmenu &Edit.Find\ and\ Rep&lace<Tab>:%s + vnoremenu &Edit.Find\ and\ Rep&lace<Tab>:s :s/ +endif + +an 20.425 &Edit.-SEP3- <Nop> +an 20.430 &Edit.Settings\ &Window :options<CR> +an 20.435 &Edit.Startup\ &Settings :call <SID>EditVimrc()<CR> + +fun! s:EditVimrc() + if $MYVIMRC != '' + let fname = $MYVIMRC + elseif has("win32") || has("dos32") || has("dos16") || has("os2") + if $HOME != '' + let fname = $HOME . "/_vimrc" + else + let fname = $VIM . "/_vimrc" + endif + elseif has("amiga") + let fname = "s:.vimrc" + else + let fname = $HOME . "/.vimrc" + endif + let fname = s:FnameEscape(fname) + if &mod + exe "split " . fname + else + exe "edit " . fname + endif +endfun + +fun! s:FixFText() + " Fix text in nameless register to be used with :promptfind. + return substitute(@", "[\r\n]", '\\n', 'g') +endfun + +" Edit/Global Settings +an 20.440.100 &Edit.&Global\ Settings.Toggle\ Pattern\ &Highlight<Tab>:set\ hls! :set hls! hls?<CR> +an 20.440.110 &Edit.&Global\ Settings.Toggle\ &Ignore-case<Tab>:set\ ic! :set ic! ic?<CR> +an 20.440.110 &Edit.&Global\ Settings.Toggle\ &Showmatch<Tab>:set\ sm! :set sm! sm?<CR> + +an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 1\ :set so=1<CR> +an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 2\ :set so=2<CR> +an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 3\ :set so=3<CR> +an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 4\ :set so=4<CR> +an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 5\ :set so=5<CR> +an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 7\ :set so=7<CR> +an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 10\ :set so=10<CR> +an 20.440.120 &Edit.&Global\ Settings.&Context\ lines.\ 100\ :set so=100<CR> + +an 20.440.130.40 &Edit.&Global\ Settings.&Virtual\ Edit.Never :set ve=<CR> +an 20.440.130.50 &Edit.&Global\ Settings.&Virtual\ Edit.Block\ Selection :set ve=block<CR> +an 20.440.130.60 &Edit.&Global\ Settings.&Virtual\ Edit.Insert\ mode :set ve=insert<CR> +an 20.440.130.70 &Edit.&Global\ Settings.&Virtual\ Edit.Block\ and\ Insert :set ve=block,insert<CR> +an 20.440.130.80 &Edit.&Global\ Settings.&Virtual\ Edit.Always :set ve=all<CR> +an 20.440.140 &Edit.&Global\ Settings.Toggle\ Insert\ &Mode<Tab>:set\ im! :set im!<CR> +an 20.440.145 &Edit.&Global\ Settings.Toggle\ Vi\ C&ompatible<Tab>:set\ cp! :set cp!<CR> +an <silent> 20.440.150 &Edit.&Global\ Settings.Search\ &Path\.\.\. :call <SID>SearchP()<CR> +an <silent> 20.440.160 &Edit.&Global\ Settings.Ta&g\ Files\.\.\. :call <SID>TagFiles()<CR> +" +" GUI options +an 20.440.300 &Edit.&Global\ Settings.-SEP1- <Nop> +an <silent> 20.440.310 &Edit.&Global\ Settings.Toggle\ &Toolbar :call <SID>ToggleGuiOption("T")<CR> +an <silent> 20.440.320 &Edit.&Global\ Settings.Toggle\ &Bottom\ Scrollbar :call <SID>ToggleGuiOption("b")<CR> +an <silent> 20.440.330 &Edit.&Global\ Settings.Toggle\ &Left\ Scrollbar :call <SID>ToggleGuiOption("l")<CR> +an <silent> 20.440.340 &Edit.&Global\ Settings.Toggle\ &Right\ Scrollbar :call <SID>ToggleGuiOption("r")<CR> + +fun! s:SearchP() + if !exists("g:menutrans_path_dialog") + let g:menutrans_path_dialog = "Enter search path for files.\nSeparate directory names with a comma." + endif + let n = inputdialog(g:menutrans_path_dialog, substitute(&path, '\\ ', ' ', 'g')) + if n != "" + let &path = substitute(n, ' ', '\\ ', 'g') + endif +endfun + +fun! s:TagFiles() + if !exists("g:menutrans_tags_dialog") + let g:menutrans_tags_dialog = "Enter names of tag files.\nSeparate the names with a comma." + endif + let n = inputdialog(g:menutrans_tags_dialog, substitute(&tags, '\\ ', ' ', 'g')) + if n != "" + let &tags = substitute(n, ' ', '\\ ', 'g') + endif +endfun + +fun! s:ToggleGuiOption(option) + " If a:option is already set in guioptions, then we want to remove it + if match(&guioptions, "\\C" . a:option) > -1 + exec "set go-=" . a:option + else + exec "set go+=" . a:option + endif +endfun + +" Edit/File Settings + +" Boolean options +an 20.440.100 &Edit.F&ile\ Settings.Toggle\ Line\ &Numbering<Tab>:set\ nu! :set nu! nu?<CR> +an 20.440.105 &Edit.F&ile\ Settings.Toggle\ relati&ve\ Line\ Numbering<Tab>:set\ rnu! :set rnu! rnu?<CR> +an 20.440.110 &Edit.F&ile\ Settings.Toggle\ &List\ Mode<Tab>:set\ list! :set list! list?<CR> +an 20.440.120 &Edit.F&ile\ Settings.Toggle\ Line\ &Wrap<Tab>:set\ wrap! :set wrap! wrap?<CR> +an 20.440.130 &Edit.F&ile\ Settings.Toggle\ W&rap\ at\ word<Tab>:set\ lbr! :set lbr! lbr?<CR> +an 20.440.160 &Edit.F&ile\ Settings.Toggle\ &expand-tab<Tab>:set\ et! :set et! et?<CR> +an 20.440.170 &Edit.F&ile\ Settings.Toggle\ &auto-indent<Tab>:set\ ai! :set ai! ai?<CR> +an 20.440.180 &Edit.F&ile\ Settings.Toggle\ &C-indenting<Tab>:set\ cin! :set cin! cin?<CR> + +" other options +an 20.440.600 &Edit.F&ile\ Settings.-SEP2- <Nop> +an 20.440.610.20 &Edit.F&ile\ Settings.&Shiftwidth.2 :set sw=2 sw?<CR> +an 20.440.610.30 &Edit.F&ile\ Settings.&Shiftwidth.3 :set sw=3 sw?<CR> +an 20.440.610.40 &Edit.F&ile\ Settings.&Shiftwidth.4 :set sw=4 sw?<CR> +an 20.440.610.50 &Edit.F&ile\ Settings.&Shiftwidth.5 :set sw=5 sw?<CR> +an 20.440.610.60 &Edit.F&ile\ Settings.&Shiftwidth.6 :set sw=6 sw?<CR> +an 20.440.610.80 &Edit.F&ile\ Settings.&Shiftwidth.8 :set sw=8 sw?<CR> + +an 20.440.620.20 &Edit.F&ile\ Settings.Soft\ &Tabstop.2 :set sts=2 sts?<CR> +an 20.440.620.30 &Edit.F&ile\ Settings.Soft\ &Tabstop.3 :set sts=3 sts?<CR> +an 20.440.620.40 &Edit.F&ile\ Settings.Soft\ &Tabstop.4 :set sts=4 sts?<CR> +an 20.440.620.50 &Edit.F&ile\ Settings.Soft\ &Tabstop.5 :set sts=5 sts?<CR> +an 20.440.620.60 &Edit.F&ile\ Settings.Soft\ &Tabstop.6 :set sts=6 sts?<CR> +an 20.440.620.80 &Edit.F&ile\ Settings.Soft\ &Tabstop.8 :set sts=8 sts?<CR> + +an <silent> 20.440.630 &Edit.F&ile\ Settings.Te&xt\ Width\.\.\. :call <SID>TextWidth()<CR> +an <silent> 20.440.640 &Edit.F&ile\ Settings.&File\ Format\.\.\. :call <SID>FileFormat()<CR> +fun! s:TextWidth() + if !exists("g:menutrans_textwidth_dialog") + let g:menutrans_textwidth_dialog = "Enter new text width (0 to disable formatting): " + endif + let n = inputdialog(g:menutrans_textwidth_dialog, &tw) + if n != "" + " remove leading zeros to avoid it being used as an octal number + let &tw = substitute(n, "^0*", "", "") + endif +endfun + +fun! s:FileFormat() + if !exists("g:menutrans_fileformat_dialog") + let g:menutrans_fileformat_dialog = "Select format for writing the file" + endif + if !exists("g:menutrans_fileformat_choices") + let g:menutrans_fileformat_choices = "&Unix\n&Dos\n&Mac\n&Cancel" + endif + if &ff == "dos" + let def = 2 + elseif &ff == "mac" + let def = 3 + else + let def = 1 + endif + let n = confirm(g:menutrans_fileformat_dialog, g:menutrans_fileformat_choices, def, "Question") + if n == 1 + set ff=unix + elseif n == 2 + set ff=dos + elseif n == 3 + set ff=mac + endif +endfun + + +" Setup the Edit.Color Scheme submenu + +" get NL separated string with file names +let s:n = globpath(&runtimepath, "colors/*.vim") + +" split at NL, Ignore case for VMS and windows, sort on name +let s:names = sort(map(split(s:n, "\n"), 'substitute(v:val, "\\c.*[/\\\\:\\]]\\([^/\\\\:]*\\)\\.vim", "\\1", "")'), 1) + +" define all the submenu entries +let s:idx = 100 +for s:name in s:names + exe "an 20.450." . s:idx . ' &Edit.C&olor\ Scheme.' . s:name . " :colors " . s:name . "<CR>" + let s:idx = s:idx + 10 +endfor +unlet s:name s:names s:n s:idx + + +" Setup the Edit.Keymap submenu +if has("keymap") + let s:n = globpath(&runtimepath, "keymap/*.vim") + if s:n != "" + let s:idx = 100 + an 20.460.90 &Edit.&Keymap.None :set keymap=<CR> + while strlen(s:n) > 0 + let s:i = stridx(s:n, "\n") + if s:i < 0 + let s:name = s:n + let s:n = "" + else + let s:name = strpart(s:n, 0, s:i) + let s:n = strpart(s:n, s:i + 1, 19999) + endif + " Ignore case for VMS and windows + let s:name = substitute(s:name, '\c.*[/\\:\]]\([^/\\:_]*\)\(_[0-9a-zA-Z-]*\)\=\.vim', '\1', '') + exe "an 20.460." . s:idx . ' &Edit.&Keymap.' . s:name . " :set keymap=" . s:name . "<CR>" + unlet s:name + unlet s:i + let s:idx = s:idx + 10 + endwhile + unlet s:idx + endif + unlet s:n +endif +if has("win32") || has("win16") || has("gui_motif") || has("gui_gtk") || has("gui_kde") || has("gui_photon") || has("gui_mac") + an 20.470 &Edit.Select\ Fo&nt\.\.\. :set guifont=*<CR> +endif + +" Programming menu +if !exists("g:ctags_command") + if has("vms") + let g:ctags_command = "mc vim:ctags *.*" + else + let g:ctags_command = "ctags -R ." + endif +endif + +an 40.300 &Tools.&Jump\ to\ this\ tag<Tab>g^] g<C-]> +vunmenu &Tools.&Jump\ to\ this\ tag<Tab>g^] +vnoremenu &Tools.&Jump\ to\ this\ tag<Tab>g^] g<C-]> +an 40.310 &Tools.Jump\ &back<Tab>^T <C-T> +an 40.320 &Tools.Build\ &Tags\ File :exe "!" . g:ctags_command<CR> + +if has("folding") || has("spell") + an 40.330 &Tools.-SEP1- <Nop> +endif + +" Tools.Spelling Menu +if has("spell") + an 40.335.110 &Tools.&Spelling.&Spell\ Check\ On :set spell<CR> + an 40.335.120 &Tools.&Spelling.Spell\ Check\ &Off :set nospell<CR> + an 40.335.130 &Tools.&Spelling.To\ &Next\ error<Tab>]s ]s + an 40.335.130 &Tools.&Spelling.To\ &Previous\ error<Tab>[s [s + an 40.335.140 &Tools.&Spelling.Suggest\ &Corrections<Tab>z= z= + an 40.335.150 &Tools.&Spelling.&Repeat\ correction<Tab>:spellrepall :spellrepall<CR> + an 40.335.200 &Tools.&Spelling.-SEP1- <Nop> + an 40.335.210 &Tools.&Spelling.Set\ language\ to\ "en" :set spl=en spell<CR> + an 40.335.220 &Tools.&Spelling.Set\ language\ to\ "en_au" :set spl=en_au spell<CR> + an 40.335.230 &Tools.&Spelling.Set\ language\ to\ "en_ca" :set spl=en_ca spell<CR> + an 40.335.240 &Tools.&Spelling.Set\ language\ to\ "en_gb" :set spl=en_gb spell<CR> + an 40.335.250 &Tools.&Spelling.Set\ language\ to\ "en_nz" :set spl=en_nz spell<CR> + an 40.335.260 &Tools.&Spelling.Set\ language\ to\ "en_us" :set spl=en_us spell<CR> + an <silent> 40.335.270 &Tools.&Spelling.&Find\ More\ Languages :call <SID>SpellLang()<CR> + + let s:undo_spellang = ['aun &Tools.&Spelling.&Find\ More\ Languages'] + func! s:SpellLang() + for cmd in s:undo_spellang + exe "silent! " . cmd + endfor + let s:undo_spellang = [] + + if &enc == "iso-8859-15" + let enc = "latin1" + else + let enc = &enc + endif + + let found = 0 + let s = globpath(&rtp, "spell/*." . enc . ".spl") + if s != "" + let n = 300 + for f in split(s, "\n") + let nm = substitute(f, '.*spell[/\\]\(..\)\.[^/\\]*\.spl', '\1', "") + if nm != "en" && nm !~ '/' + let found += 1 + let menuname = '&Tools.&Spelling.Set\ language\ to\ "' . nm . '"' + exe 'an 40.335.' . n . ' ' . menuname . ' :set spl=' . nm . ' spell<CR>' + let s:undo_spellang += ['aun ' . menuname] + endif + let n += 10 + endfor + endif + if found == 0 + echomsg "Could not find other spell files" + elseif found == 1 + echomsg "Found spell file " . nm + else + echomsg "Found " . found . " more spell files" + endif + " Need to redo this when 'encoding' is changed. + augroup spellmenu + au! EncodingChanged * call <SID>SpellLang() + augroup END + endfun + +endif + +" Tools.Fold Menu +if has("folding") + " open close folds + an 40.340.110 &Tools.&Folding.&Enable/Disable\ folds<Tab>zi zi + an 40.340.120 &Tools.&Folding.&View\ Cursor\ Line<Tab>zv zv + an 40.340.120 &Tools.&Folding.Vie&w\ Cursor\ Line\ only<Tab>zMzx zMzx + an 40.340.130 &Tools.&Folding.C&lose\ more\ folds<Tab>zm zm + an 40.340.140 &Tools.&Folding.&Close\ all\ folds<Tab>zM zM + an 40.340.150 &Tools.&Folding.O&pen\ more\ folds<Tab>zr zr + an 40.340.160 &Tools.&Folding.&Open\ all\ folds<Tab>zR zR + " fold method + an 40.340.200 &Tools.&Folding.-SEP1- <Nop> + an 40.340.210 &Tools.&Folding.Fold\ Met&hod.M&anual :set fdm=manual<CR> + an 40.340.210 &Tools.&Folding.Fold\ Met&hod.I&ndent :set fdm=indent<CR> + an 40.340.210 &Tools.&Folding.Fold\ Met&hod.E&xpression :set fdm=expr<CR> + an 40.340.210 &Tools.&Folding.Fold\ Met&hod.S&yntax :set fdm=syntax<CR> + an 40.340.210 &Tools.&Folding.Fold\ Met&hod.&Diff :set fdm=diff<CR> + an 40.340.210 &Tools.&Folding.Fold\ Met&hod.Ma&rker :set fdm=marker<CR> + " create and delete folds + vnoremenu 40.340.220 &Tools.&Folding.Create\ &Fold<Tab>zf zf + an 40.340.230 &Tools.&Folding.&Delete\ Fold<Tab>zd zd + an 40.340.240 &Tools.&Folding.Delete\ &All\ Folds<Tab>zD zD + " moving around in folds + an 40.340.300 &Tools.&Folding.-SEP2- <Nop> + an 40.340.310.10 &Tools.&Folding.Fold\ col&umn\ width.\ &0\ :set fdc=0<CR> + an 40.340.310.20 &Tools.&Folding.Fold\ col&umn\ width.\ &2\ :set fdc=2<CR> + an 40.340.310.30 &Tools.&Folding.Fold\ col&umn\ width.\ &3\ :set fdc=3<CR> + an 40.340.310.40 &Tools.&Folding.Fold\ col&umn\ width.\ &4\ :set fdc=4<CR> + an 40.340.310.50 &Tools.&Folding.Fold\ col&umn\ width.\ &5\ :set fdc=5<CR> + an 40.340.310.60 &Tools.&Folding.Fold\ col&umn\ width.\ &6\ :set fdc=6<CR> + an 40.340.310.70 &Tools.&Folding.Fold\ col&umn\ width.\ &7\ :set fdc=7<CR> + an 40.340.310.80 &Tools.&Folding.Fold\ col&umn\ width.\ &8\ :set fdc=8<CR> +endif " has folding + +if has("diff") + an 40.350.100 &Tools.&Diff.&Update :diffupdate<CR> + an 40.350.110 &Tools.&Diff.&Get\ Block :diffget<CR> + vunmenu &Tools.&Diff.&Get\ Block + vnoremenu &Tools.&Diff.&Get\ Block :diffget<CR> + an 40.350.120 &Tools.&Diff.&Put\ Block :diffput<CR> + vunmenu &Tools.&Diff.&Put\ Block + vnoremenu &Tools.&Diff.&Put\ Block :diffput<CR> +endif + +an 40.358 &Tools.-SEP2- <Nop> +an 40.360 &Tools.&Make<Tab>:make :make<CR> +an 40.370 &Tools.&List\ Errors<Tab>:cl :cl<CR> +an 40.380 &Tools.L&ist\ Messages<Tab>:cl! :cl!<CR> +an 40.390 &Tools.&Next\ Error<Tab>:cn :cn<CR> +an 40.400 &Tools.&Previous\ Error<Tab>:cp :cp<CR> +an 40.410 &Tools.&Older\ List<Tab>:cold :colder<CR> +an 40.420 &Tools.N&ewer\ List<Tab>:cnew :cnewer<CR> +an 40.430.50 &Tools.Error\ &Window.&Update<Tab>:cwin :cwin<CR> +an 40.430.60 &Tools.Error\ &Window.&Open<Tab>:copen :copen<CR> +an 40.430.70 &Tools.Error\ &Window.&Close<Tab>:cclose :cclose<CR> + +an 40.520 &Tools.-SEP3- <Nop> +an <silent> 40.530 &Tools.&Convert\ to\ HEX<Tab>:%!xxd + \ :call <SID>XxdConv()<CR> +an <silent> 40.540 &Tools.Conve&rt\ back<Tab>:%!xxd\ -r + \ :call <SID>XxdBack()<CR> + +" Use a function to do the conversion, so that it also works with 'insertmode' +" set. +func! s:XxdConv() + let mod = &mod + if has("vms") + %!mc vim:xxd + else + call s:XxdFind() + exe '%!"' . g:xxdprogram . '"' + endif + if getline(1) =~ "^0000000:" " only if it worked + set ft=xxd + endif + let &mod = mod +endfun + +func! s:XxdBack() + let mod = &mod + if has("vms") + %!mc vim:xxd -r + else + call s:XxdFind() + exe '%!"' . g:xxdprogram . '" -r' + endif + set ft= + doautocmd filetypedetect BufReadPost + let &mod = mod +endfun + +func! s:XxdFind() + if !exists("g:xxdprogram") + " On the PC xxd may not be in the path but in the install directory + if (has("win32") || has("dos32")) && !executable("xxd") + let g:xxdprogram = $VIMRUNTIME . (&shellslash ? '/' : '\') . "xxd.exe" + else + let g:xxdprogram = "xxd" + endif + endif +endfun + +" Setup the Tools.Compiler submenu +let s:n = globpath(&runtimepath, "compiler/*.vim") +let s:idx = 100 +while strlen(s:n) > 0 + let s:i = stridx(s:n, "\n") + if s:i < 0 + let s:name = s:n + let s:n = "" + else + let s:name = strpart(s:n, 0, s:i) + let s:n = strpart(s:n, s:i + 1, 19999) + endif + " Ignore case for VMS and windows + let s:name = substitute(s:name, '\c.*[/\\:\]]\([^/\\:]*\)\.vim', '\1', '') + exe "an 30.440." . s:idx . ' &Tools.Se&T\ Compiler.' . s:name . " :compiler " . s:name . "<CR>" + unlet s:name + unlet s:i + let s:idx = s:idx + 10 +endwhile +unlet s:n +unlet s:idx + +if !exists("no_buffers_menu") + +" Buffer list menu -- Setup functions & actions + +" wait with building the menu until after loading 'session' files. Makes +" startup faster. +let s:bmenu_wait = 1 + +if !exists("bmenu_priority") + let bmenu_priority = 60 +endif + +func! s:BMAdd() + if s:bmenu_wait == 0 + " when adding too many buffers, redraw in short format + if s:bmenu_count == &menuitems && s:bmenu_short == 0 + call s:BMShow() + else + call <SID>BMFilename(expand("<afile>"), expand("<abuf>")) + let s:bmenu_count = s:bmenu_count + 1 + endif + endif +endfunc + +func! s:BMRemove() + if s:bmenu_wait == 0 + let name = expand("<afile>") + if isdirectory(name) + return + endif + let munge = <SID>BMMunge(name, expand("<abuf>")) + + if s:bmenu_short == 0 + exe 'silent! aun &Buffers.' . munge + else + exe 'silent! aun &Buffers.' . <SID>BMHash2(munge) . munge + endif + let s:bmenu_count = s:bmenu_count - 1 + endif +endfunc + +" Create the buffer menu (delete an existing one first). +func! s:BMShow(...) + let s:bmenu_wait = 1 + let s:bmenu_short = 1 + let s:bmenu_count = 0 + " + " get new priority, if exists + if a:0 == 1 + let g:bmenu_priority = a:1 + endif + + " remove old menu, if exists; keep one entry to avoid a torn off menu to + " disappear. + silent! unmenu &Buffers + exe 'noremenu ' . g:bmenu_priority . ".1 &Buffers.Dummy l" + silent! unmenu! &Buffers + + " create new menu; set 'cpo' to include the <CR> + let cpo_save = &cpo + set cpo&vim + exe 'an <silent> ' . g:bmenu_priority . ".2 &Buffers.&Refresh\\ menu :call <SID>BMShow()<CR>" + exe 'an ' . g:bmenu_priority . ".4 &Buffers.&Delete :confirm bd<CR>" + exe 'an ' . g:bmenu_priority . ".6 &Buffers.&Alternate :confirm b #<CR>" + exe 'an ' . g:bmenu_priority . ".7 &Buffers.&Next :confirm bnext<CR>" + exe 'an ' . g:bmenu_priority . ".8 &Buffers.&Previous :confirm bprev<CR>" + exe 'an ' . g:bmenu_priority . ".9 &Buffers.-SEP- :" + let &cpo = cpo_save + unmenu &Buffers.Dummy + + " figure out how many buffers there are + let buf = 1 + while buf <= bufnr('$') + if bufexists(buf) && !isdirectory(bufname(buf)) && buflisted(buf) + let s:bmenu_count = s:bmenu_count + 1 + endif + let buf = buf + 1 + endwhile + if s:bmenu_count <= &menuitems + let s:bmenu_short = 0 + endif + + " iterate through buffer list, adding each buffer to the menu: + let buf = 1 + while buf <= bufnr('$') + if bufexists(buf) && !isdirectory(bufname(buf)) && buflisted(buf) + call <SID>BMFilename(bufname(buf), buf) + endif + let buf = buf + 1 + endwhile + let s:bmenu_wait = 0 + aug buffer_list + au! + au BufCreate,BufFilePost * call <SID>BMAdd() + au BufDelete,BufFilePre * call <SID>BMRemove() + aug END +endfunc + +func! s:BMHash(name) + " Make name all upper case, so that chars are between 32 and 96 + let nm = substitute(a:name, ".*", '\U\0', "") + if has("ebcdic") + " HACK: Replace all non alphabetics with 'Z' + " Just to make it work for now. + let nm = substitute(nm, "[^A-Z]", 'Z', "g") + let sp = char2nr('A') - 1 + else + let sp = char2nr(' ') + endif + " convert first six chars into a number for sorting: + return (char2nr(nm[0]) - sp) * 0x800000 + (char2nr(nm[1]) - sp) * 0x20000 + (char2nr(nm[2]) - sp) * 0x1000 + (char2nr(nm[3]) - sp) * 0x80 + (char2nr(nm[4]) - sp) * 0x20 + (char2nr(nm[5]) - sp) +endfunc + +func! s:BMHash2(name) + let nm = substitute(a:name, ".", '\L\0', "") + " Not exactly right for EBCDIC... + if nm[0] < 'a' || nm[0] > 'z' + return '&others.' + elseif nm[0] <= 'd' + return '&abcd.' + elseif nm[0] <= 'h' + return '&efgh.' + elseif nm[0] <= 'l' + return '&ijkl.' + elseif nm[0] <= 'p' + return '&mnop.' + elseif nm[0] <= 't' + return '&qrst.' + else + return '&u-z.' + endif +endfunc + +" insert a buffer name into the buffer menu: +func! s:BMFilename(name, num) + if isdirectory(a:name) + return + endif + let munge = <SID>BMMunge(a:name, a:num) + let hash = <SID>BMHash(munge) + if s:bmenu_short == 0 + let name = 'an ' . g:bmenu_priority . '.' . hash . ' &Buffers.' . munge + else + let name = 'an ' . g:bmenu_priority . '.' . hash . '.' . hash . ' &Buffers.' . <SID>BMHash2(munge) . munge + endif + " set 'cpo' to include the <CR> + let cpo_save = &cpo + set cpo&vim + exe name . ' :confirm b' . a:num . '<CR>' + let &cpo = cpo_save +endfunc + +" Truncate a long path to fit it in a menu item. +if !exists("g:bmenu_max_pathlen") + let g:bmenu_max_pathlen = 35 +endif +func! s:BMTruncName(fname) + let name = a:fname + if g:bmenu_max_pathlen < 5 + let name = "" + else + let len = strlen(name) + if len > g:bmenu_max_pathlen + let amountl = (g:bmenu_max_pathlen / 2) - 2 + let amountr = g:bmenu_max_pathlen - amountl - 3 + let pattern = '^\(.\{,' . amountl . '}\).\{-}\(.\{,' . amountr . '}\)$' + let left = substitute(name, pattern, '\1', '') + let right = substitute(name, pattern, '\2', '') + if strlen(left) + strlen(right) < len + let name = left . '...' . right + endif + endif + endif + return name +endfunc + +func! s:BMMunge(fname, bnum) + let name = a:fname + if name == '' + if !exists("g:menutrans_no_file") + let g:menutrans_no_file = "[No file]" + endif + let name = g:menutrans_no_file + else + let name = fnamemodify(name, ':p:~') + endif + " detach file name and separate it out: + let name2 = fnamemodify(name, ':t') + if a:bnum >= 0 + let name2 = name2 . ' (' . a:bnum . ')' + endif + let name = name2 . "\t" . <SID>BMTruncName(fnamemodify(name,':h')) + let name = escape(name, "\\. \t|") + let name = substitute(name, "&", "&&", "g") + let name = substitute(name, "\n", "^@", "g") + return name +endfunc + +" When just starting Vim, load the buffer menu later +if has("vim_starting") + augroup LoadBufferMenu + au! VimEnter * if !exists("no_buffers_menu") | call <SID>BMShow() | endif + au VimEnter * au! LoadBufferMenu + augroup END +else + call <SID>BMShow() +endif + +endif " !exists("no_buffers_menu") + +" Window menu +an 70.300 &Window.&New<Tab>^Wn <C-W>n +an 70.310 &Window.S&plit<Tab>^Ws <C-W>s +an 70.320 &Window.Sp&lit\ To\ #<Tab>^W^^ <C-W><C-^> +an 70.330 &Window.Split\ &Vertically<Tab>^Wv <C-W>v +if has("vertsplit") + an <silent> 70.332 &Window.Split\ File\ E&xplorer :call MenuExplOpen()<CR> + if !exists("*MenuExplOpen") + fun MenuExplOpen() + if @% == "" + 20vsp . + else + exe "20vsp " . s:FnameEscape(expand("%:p:h")) + endif + endfun + endif +endif +an 70.335 &Window.-SEP1- <Nop> +an 70.340 &Window.&Close<Tab>^Wc :confirm close<CR> +an 70.345 &Window.Close\ &Other(s)<Tab>^Wo :confirm only<CR> +an 70.350 &Window.-SEP2- <Nop> +an 70.355 &Window.Move\ &To.&Top<Tab>^WK <C-W>K +an 70.355 &Window.Move\ &To.&Bottom<Tab>^WJ <C-W>J +an 70.355 &Window.Move\ &To.&Left\ side<Tab>^WH <C-W>H +an 70.355 &Window.Move\ &To.&Right\ side<Tab>^WL <C-W>L +an 70.360 &Window.Rotate\ &Up<Tab>^WR <C-W>R +an 70.362 &Window.Rotate\ &Down<Tab>^Wr <C-W>r +an 70.365 &Window.-SEP3- <Nop> +an 70.370 &Window.&Equal\ Size<Tab>^W= <C-W>= +an 70.380 &Window.&Max\ Height<Tab>^W_ <C-W>_ +an 70.390 &Window.M&in\ Height<Tab>^W1_ <C-W>1_ +an 70.400 &Window.Max\ &Width<Tab>^W\| <C-W>\| +an 70.410 &Window.Min\ Widt&h<Tab>^W1\| <C-W>1\| + +" The popup menu +an 1.10 PopUp.&Undo u +an 1.15 PopUp.-SEP1- <Nop> +vnoremenu 1.20 PopUp.Cu&t "+x +vnoremenu 1.30 PopUp.&Copy "+y +cnoremenu 1.30 PopUp.&Copy <C-Y> +nnoremenu 1.40 PopUp.&Paste "+gP +cnoremenu 1.40 PopUp.&Paste <C-R>+ +exe 'vnoremenu <script> 1.40 PopUp.&Paste ' . paste#paste_cmd['v'] +exe 'inoremenu <script> 1.40 PopUp.&Paste ' . paste#paste_cmd['i'] +vnoremenu 1.50 PopUp.&Delete x +an 1.55 PopUp.-SEP2- <Nop> +vnoremenu 1.60 PopUp.Select\ Blockwise <C-V> + +nnoremenu 1.70 PopUp.Select\ &Word vaw +onoremenu 1.70 PopUp.Select\ &Word aw +vnoremenu 1.70 PopUp.Select\ &Word <C-C>vaw +inoremenu 1.70 PopUp.Select\ &Word <C-O>vaw +cnoremenu 1.70 PopUp.Select\ &Word <C-C>vaw + +nnoremenu 1.73 PopUp.Select\ &Sentence vas +onoremenu 1.73 PopUp.Select\ &Sentence as +vnoremenu 1.73 PopUp.Select\ &Sentence <C-C>vas +inoremenu 1.73 PopUp.Select\ &Sentence <C-O>vas +cnoremenu 1.73 PopUp.Select\ &Sentence <C-C>vas + +nnoremenu 1.77 PopUp.Select\ Pa&ragraph vap +onoremenu 1.77 PopUp.Select\ Pa&ragraph ap +vnoremenu 1.77 PopUp.Select\ Pa&ragraph <C-C>vap +inoremenu 1.77 PopUp.Select\ Pa&ragraph <C-O>vap +cnoremenu 1.77 PopUp.Select\ Pa&ragraph <C-C>vap + +nnoremenu 1.80 PopUp.Select\ &Line V +onoremenu 1.80 PopUp.Select\ &Line <C-C>V +vnoremenu 1.80 PopUp.Select\ &Line <C-C>V +inoremenu 1.80 PopUp.Select\ &Line <C-O>V +cnoremenu 1.80 PopUp.Select\ &Line <C-C>V + +nnoremenu 1.90 PopUp.Select\ &Block <C-V> +onoremenu 1.90 PopUp.Select\ &Block <C-C><C-V> +vnoremenu 1.90 PopUp.Select\ &Block <C-C><C-V> +inoremenu 1.90 PopUp.Select\ &Block <C-O><C-V> +cnoremenu 1.90 PopUp.Select\ &Block <C-C><C-V> + +noremenu <script> <silent> 1.100 PopUp.Select\ &All :<C-U>call <SID>SelectAll()<CR> +inoremenu <script> <silent> 1.100 PopUp.Select\ &All <C-O>:call <SID>SelectAll()<CR> +cnoremenu <script> <silent> 1.100 PopUp.Select\ &All <C-U>call <SID>SelectAll()<CR> + +if has("spell") + " Spell suggestions in the popup menu. Note that this will slow down the + " appearance of the menu! + func! <SID>SpellPopup() + if exists("s:changeitem") && s:changeitem != '' + call <SID>SpellDel() + endif + + " Return quickly if spell checking is not enabled. + if !&spell || &spelllang == '' + return + endif + + let curcol = col('.') + let [w, a] = spellbadword() + if col('.') > curcol " don't use word after the cursor + let w = '' + endif + if w != '' + if a == 'caps' + let s:suglist = [substitute(w, '.*', '\u&', '')] + else + let s:suglist = spellsuggest(w, 10) + endif + if len(s:suglist) > 0 + let s:changeitem = 'change\ "' . escape(w, ' .'). '"\ to' + let s:fromword = w + let pri = 1 + " set 'cpo' to include the <CR> + let cpo_save = &cpo + set cpo&vim + for sug in s:suglist + exe 'anoremenu 1.5.' . pri . ' PopUp.' . s:changeitem . '.' . escape(sug, ' .') + \ . ' :call <SID>SpellReplace(' . pri . ')<CR>' + let pri += 1 + endfor + + let s:additem = 'add\ "' . escape(w, ' .') . '"\ to\ word\ list' + exe 'anoremenu 1.6 PopUp.' . s:additem . ' :spellgood ' . w . '<CR>' + + let s:ignoreitem = 'ignore\ "' . escape(w, ' .') . '"' + exe 'anoremenu 1.7 PopUp.' . s:ignoreitem . ' :spellgood! ' . w . '<CR>' + + anoremenu 1.8 PopUp.-SpellSep- : + let &cpo = cpo_save + endif + endif + call cursor(0, curcol) " put the cursor back where it was + endfunc + + func! <SID>SpellReplace(n) + let l = getline('.') + " Move the cursor to the start of the word. + call spellbadword() + call setline('.', strpart(l, 0, col('.') - 1) . s:suglist[a:n - 1] + \ . strpart(l, col('.') + len(s:fromword) - 1)) + endfunc + + func! <SID>SpellDel() + exe "aunmenu PopUp." . s:changeitem + exe "aunmenu PopUp." . s:additem + exe "aunmenu PopUp." . s:ignoreitem + aunmenu PopUp.-SpellSep- + let s:changeitem = '' + endfun + + augroup SpellPopupMenu + au! MenuPopup * call <SID>SpellPopup() + augroup END +endif + +" The GUI toolbar (for MS-Windows and GTK) +if has("toolbar") + an 1.10 ToolBar.Open :browse confirm e<CR> + an <silent> 1.20 ToolBar.Save :if expand("%") == ""<Bar>browse confirm w<Bar>else<Bar>confirm w<Bar>endif<CR> + an 1.30 ToolBar.SaveAll :browse confirm wa<CR> + + if has("printer") + an 1.40 ToolBar.Print :hardcopy<CR> + vunmenu ToolBar.Print + vnoremenu ToolBar.Print :hardcopy<CR> + elseif has("unix") + an 1.40 ToolBar.Print :w !lpr<CR> + vunmenu ToolBar.Print + vnoremenu ToolBar.Print :w !lpr<CR> + endif + + an 1.45 ToolBar.-sep1- <Nop> + an 1.50 ToolBar.Undo u + an 1.60 ToolBar.Redo <C-R> + + an 1.65 ToolBar.-sep2- <Nop> + vnoremenu 1.70 ToolBar.Cut "+x + vnoremenu 1.80 ToolBar.Copy "+y + cnoremenu 1.80 ToolBar.Copy <C-Y> + nnoremenu 1.90 ToolBar.Paste "+gP + cnoremenu ToolBar.Paste <C-R>+ + exe 'vnoremenu <script> ToolBar.Paste ' . paste#paste_cmd['v'] + exe 'inoremenu <script> ToolBar.Paste ' . paste#paste_cmd['i'] + + if !has("gui_athena") + an 1.95 ToolBar.-sep3- <Nop> + an 1.100 ToolBar.Replace :promptrepl<CR> + vunmenu ToolBar.Replace + vnoremenu ToolBar.Replace y:promptrepl <C-R>=<SID>FixFText()<CR><CR> + an 1.110 ToolBar.FindNext n + an 1.120 ToolBar.FindPrev N + endif + + an 1.215 ToolBar.-sep5- <Nop> + an <silent> 1.220 ToolBar.LoadSesn :call <SID>LoadVimSesn()<CR> + an <silent> 1.230 ToolBar.SaveSesn :call <SID>SaveVimSesn()<CR> + an 1.240 ToolBar.RunScript :browse so<CR> + + an 1.245 ToolBar.-sep6- <Nop> + an 1.250 ToolBar.Make :make<CR> + an 1.270 ToolBar.RunCtags :exe "!" . g:ctags_command<CR> + an 1.280 ToolBar.TagJump g<C-]> + + an 1.295 ToolBar.-sep7- <Nop> + an 1.300 ToolBar.Help :help<CR> + an <silent> 1.310 ToolBar.FindHelp :call <SID>Helpfind()<CR> + +" Only set the tooltips here if not done in a language menu file +if exists("*Do_toolbar_tmenu") + call Do_toolbar_tmenu() +else + let did_toolbar_tmenu = 1 + tmenu ToolBar.Open Open file + tmenu ToolBar.Save Save current file + tmenu ToolBar.SaveAll Save all files + tmenu ToolBar.Print Print + tmenu ToolBar.Undo Undo + tmenu ToolBar.Redo Redo + tmenu ToolBar.Cut Cut to clipboard + tmenu ToolBar.Copy Copy to clipboard + tmenu ToolBar.Paste Paste from Clipboard + if !has("gui_athena") + tmenu ToolBar.Replace Find / Replace... + tmenu ToolBar.FindNext Find Next + tmenu ToolBar.FindPrev Find Previous + endif + tmenu ToolBar.LoadSesn Choose a session to load + tmenu ToolBar.SaveSesn Save current session + tmenu ToolBar.RunScript Choose a Vim Script to run + tmenu ToolBar.Make Make current project (:make) + tmenu ToolBar.RunCtags Build tags in current directory tree (!ctags -R .) + tmenu ToolBar.TagJump Jump to tag under cursor + tmenu ToolBar.Help Vim Help + tmenu ToolBar.FindHelp Search Vim Help +endif + +" Select a session to load; default to current session name if present +fun! s:LoadVimSesn() + if strlen(v:this_session) > 0 + let name = s:FnameEscape(v:this_session) + else + let name = "Session.vim" + endif + execute "browse so " . name +endfun + +" Select a session to save; default to current session name if present +fun! s:SaveVimSesn() + if strlen(v:this_session) == 0 + let v:this_session = "Session.vim" + endif + execute "browse mksession! " . s:FnameEscape(v:this_session) +endfun + +endif + +endif " !exists("did_install_default_menus") + +" Define these items always, so that syntax can be switched on when it wasn't. +" But skip them when the Syntax menu was disabled by the user. +if !exists("did_install_syntax_menu") + an 50.212 &Syntax.&Manual :syn manual<CR> + an 50.214 &Syntax.A&utomatic :syn on<CR> + an <silent> 50.216 &Syntax.on/off\ for\ &This\ file :call <SID>SynOnOff()<CR> + if !exists("*s:SynOnOff") + fun s:SynOnOff() + if has("syntax_items") + syn clear + else + if !exists("g:syntax_on") + syn manual + endif + set syn=ON + endif + endfun + endif +endif + + +" Install the Syntax menu only when filetype.vim has been loaded or when +" manual syntax highlighting is enabled. +" Avoid installing the Syntax menu twice. +if (exists("did_load_filetypes") || exists("syntax_on")) + \ && !exists("did_install_syntax_menu") + let did_install_syntax_menu = 1 + +" Skip setting up the individual syntax selection menus unless +" do_syntax_sel_menu is defined (it takes quite a bit of time). +if exists("do_syntax_sel_menu") + runtime! synmenu.vim +else + an 50.10 &Syntax.&Show\ filetypes\ in\ menu :let do_syntax_sel_menu = 1<Bar>runtime! synmenu.vim<Bar>aunmenu &Syntax.&Show\ filetypes\ in\ menu<CR> + an 50.195 &Syntax.-SEP1- <Nop> +endif + +an 50.210 &Syntax.&Off :syn off<CR> +an 50.700 &Syntax.-SEP3- <Nop> +an 50.710 &Syntax.Co&lor\ test :sp $VIMRUNTIME/syntax/colortest.vim<Bar>so %<CR> +an 50.720 &Syntax.&Highlight\ test :runtime syntax/hitest.vim<CR> +an 50.730 &Syntax.&Convert\ to\ HTML :runtime syntax/2html.vim<CR> + +endif " !exists("did_install_syntax_menu") + +" Restore the previous value of 'cpoptions'. +let &cpo = s:cpo_save +unlet s:cpo_save + +" vim: set sw=2 : diff --git a/share/vim/vim72/mswin.vim b/share/vim/vim73/mswin.vim similarity index 100% rename from share/vim/vim72/mswin.vim rename to share/vim/vim73/mswin.vim diff --git a/share/vim/vim73/optwin.vim b/share/vim/vim73/optwin.vim new file mode 100644 index 0000000000..20f4f923ad --- /dev/null +++ b/share/vim/vim73/optwin.vim @@ -0,0 +1,1342 @@ +" These commands create the option window. +" +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2010 Jul 24 + +" If there already is an option window, jump to that one. +if bufwinnr("option-window") > 0 + let s:thiswin = winnr() + while 1 + if @% == "option-window" + finish + endif + exe "norm! \<C-W>w" + if s:thiswin == winnr() + break + endif + endwhile +endif + +" Make sure the '<' flag is not included in 'cpoptions', otherwise <CR> would +" not be recognized. See ":help 'cpoptions'". +let s:cpo_save = &cpo +set cpo&vim + +" function to be called when <CR> is hit in the option-window +fun! <SID>CR() + + " If on a continued comment line, go back to the first comment line + let lnum = line(".") + let line = getline(lnum) + while line[0] == "\t" + let lnum = lnum - 1 + let line = getline(lnum) + endwhile + + " <CR> on a "set" line executes the option line + if match(line, "^ \tset ") >= 0 + + " For a local option: go to the previous window + " If this is a help window, go to the window below it + let thiswin = winnr() + let local = <SID>Find(lnum) + if local >= 0 + exe line + call <SID>Update(lnum, line, local, thiswin) + endif + + " <CR> on a "option" line shows help for that option + elseif match(line, "^[a-z]") >= 0 + let name = substitute(line, '\([^\t]*\).*', '\1', "") + exe "help '" . name . "'" + + " <CR> on an index line jumps to the group + elseif match(line, '^ \=[0-9]') >= 0 + exe "norm! /" . line . "\<CR>zt" + endif +endfun + +" function to be called when <Space> is hit in the option-window +fun! <SID>Space() + + let lnum = line(".") + let line = getline(lnum) + + " <Space> on a "set" line refreshes the option line + if match(line, "^ \tset ") >= 0 + + " For a local option: go to the previous window + " If this is a help window, go to the window below it + let thiswin = winnr() + let local = <SID>Find(lnum) + if local >= 0 + call <SID>Update(lnum, line, local, thiswin) + endif + + endif +endfun + +" find the window in which the option applies +" returns 0 for global option, 1 for local option, -1 for error +fun! <SID>Find(lnum) + if getline(a:lnum - 1) =~ "(local to" + let local = 1 + let thiswin = winnr() + exe "norm! \<C-W>p" + if exists("b:current_syntax") && b:current_syntax == "help" + exe "norm! \<C-W>j" + if winnr() == thiswin + exe "norm! \<C-W>j" + endif + endif + else + let local = 0 + endif + if local && (winnr() == thiswin || (exists("b:current_syntax") + \ && b:current_syntax == "help")) + echo "Don't know in which window" + let local = -1 + endif + return local +endfun + +" Update a "set" line in the option window +fun! <SID>Update(lnum, line, local, thiswin) + " get the new value of the option and update the option window line + if match(a:line, "=") >= 0 + let name = substitute(a:line, '^ \tset \([^=]*\)=.*', '\1', "") + else + let name = substitute(a:line, '^ \tset \(no\)\=\([a-z]*\).*', '\2', "") + endif + if name == "pt" && &pt =~ "\x80" + let val = <SID>PTvalue() + else + exe "let val = substitute(&" . name . ', "[ \\t\\\\\"|]", "\\\\\\0", "g")' + endif + if a:local + exe "norm! " . a:thiswin . "\<C-W>w" + endif + if match(a:line, "=") >= 0 || (val != "0" && val != "1") + call setline(a:lnum, " \tset " . name . "=" . val) + else + if val + call setline(a:lnum, " \tset " . name . "\tno" . name) + else + call setline(a:lnum, " \tset no" . name . "\t" . name) + endif + endif + set nomodified +endfun + +" Reset 'title' and 'icon' to make it work faster. +let s:old_title = &title +let s:old_icon = &icon +let s:old_sc = &sc +let s:old_ru = &ru +set notitle noicon nosc noru + +" If the current window is a help window, try finding a non-help window. +" Relies on syntax highlighting to be switched on. +let s:thiswin = winnr() +while exists("b:current_syntax") && b:current_syntax == "help" + exe "norm! \<C-W>w" + if s:thiswin == winnr() + break + endif +endwhile + +" Open the window +new option-window +setlocal ts=15 tw=0 noro + +" Insert help and a "set" command for each option. +call append(0, '" Each "set" line shows the current value of an option (on the left).') +call append(1, '" Hit <CR> on a "set" line to execute it.') +call append(2, '" A boolean option will be toggled.') +call append(3, '" For other options you can edit the value.') +call append(4, '" Hit <CR> on a help line to open a help window on this option.') +call append(5, '" Hit <CR> on an index line to jump there.') +call append(6, '" Hit <Space> on a "set" line to refresh it.') + +" These functions are called often below. Keep them fast! + +" Init a local binary option +fun! <SID>BinOptionL(name) + exe "norm! \<C-W>p" + exe "let val = &" . a:name + exe "norm! \<C-W>p" + call append("$", substitute(substitute(" \tset " . val . a:name . "\t" . + \!val . a:name, "0", "no", ""), "1", "", "")) +endfun + +" Init a global binary option +fun! <SID>BinOptionG(name, val) + call append("$", substitute(substitute(" \tset " . a:val . a:name . "\t" . + \!a:val . a:name, "0", "no", ""), "1", "", "")) +endfun + +" Init a local string option +fun! <SID>OptionL(name) + exe "norm! \<C-W>p" + exe "let val = substitute(&" . a:name . ', "[ \\t\\\\\"|]", "\\\\\\0", "g")' + exe "norm! \<C-W>p" + call append("$", " \tset " . a:name . "=" . val) +endfun + +" Init a global string option +fun! <SID>OptionG(name, val) + call append("$", " \tset " . a:name . "=" . substitute(a:val, '[ \t\\"|]', + \ '\\\0', "g")) +endfun + +let s:idx = 1 +let s:lnum = line("$") +call append("$", "") + +fun! <SID>Header(text) + let line = s:idx . " " . a:text + if s:idx < 10 + let line = " " . line + endif + call append("$", "") + call append("$", line) + call append("$", "") + call append(s:lnum, line) + let s:idx = s:idx + 1 + let s:lnum = s:lnum + 1 +endfun + +" Get the value of 'pastetoggle'. It could be a special key. +fun! <SID>PTvalue() + redir @a + silent set pt + redir END + return substitute(@a, '[^=]*=\(.*\)', '\1', "") +endfun + +" Restore the previous value of 'cpoptions' here, it's used below. +let &cpo = s:cpo_save + +" List of all options, organized by function. +" The text should be sufficient to know what the option is used for. + +call <SID>Header("important") +call append("$", "compatible\tbehave very Vi compatible (not advisable)") +call <SID>BinOptionG("cp", &cp) +call append("$", "cpoptions\tlist of flags to specify Vi compatibility") +call <SID>OptionG("cpo", &cpo) +call append("$", "insertmode\tuse Insert mode as the default mode") +call <SID>BinOptionG("im", &im) +call append("$", "paste\tpaste mode, insert typed text literally") +call <SID>BinOptionG("paste", &paste) +call append("$", "pastetoggle\tkey sequence to toggle paste mode") +if &pt =~ "\x80" + call append("$", " \tset pt=" . <SID>PTvalue()) +else + call <SID>OptionG("pt", &pt) +endif +call append("$", "runtimepath\tlist of directories used for runtime files and plugins") +call <SID>OptionG("rtp", &rtp) +call append("$", "helpfile\tname of the main help file") +call <SID>OptionG("hf", &hf) + + +call <SID>Header("moving around, searching and patterns") +call append("$", "whichwrap\tlist of flags specifying which commands wrap to another line") +call append("$", "\t(local to window)") +call <SID>OptionL("ww") +call append("$", "startofline\tmany jump commands move the cursor to the first non-blank") +call append("$", "\tcharacter of a line") +call <SID>BinOptionG("sol", &sol) +call append("$", "paragraphs\tnroff macro names that separate paragraphs") +call <SID>OptionG("para", ¶) +call append("$", "sections\tnroff macro names that separate sections") +call <SID>OptionG("sect", §) +call append("$", "path\tlist of directory names used for file searching") +call append("$", "\t(global or local to buffer)") +call <SID>OptionG("pa", &pa) +call append("$", "cdpath\tlist of directory names used for :cd") +call <SID>OptionG("cd", &cd) +if exists("+autochdir") + call append("$", "autochdir\tchange to directory of file in buffer") + call <SID>BinOptionG("acd", &acd) +endif +call append("$", "wrapscan\tsearch commands wrap around the end of the buffer") +call <SID>BinOptionG("ws", &ws) +call append("$", "incsearch\tshow match for partly typed search command") +call <SID>BinOptionG("is", &is) +call append("$", "magic\tchange the way backslashes are used in search patterns") +call <SID>BinOptionG("magic", &magic) +call append("$", "ignorecase\tignore case when using a search pattern") +call <SID>BinOptionG("ic", &ic) +call append("$", "smartcase\toverride 'ignorecase' when pattern has upper case characters") +call <SID>BinOptionG("scs", &scs) +call append("$", "casemap\twhat method to use for changing case of letters") +call <SID>OptionG("cmp", &cmp) +call append("$", "maxmempattern\tmaximum amount of memory in Kbyte used for pattern matching") +call append("$", " \tset mmp=" . &mmp) +call append("$", "define\tpattern for a macro definition line") +call append("$", "\t(global or local to buffer)") +call <SID>OptionG("def", &def) +if has("find_in_path") + call append("$", "include\tpattern for an include-file line") + call append("$", "\t(local to buffer)") + call <SID>OptionL("inc") + call append("$", "includeexpr\texpression used to transform an include line to a file name") + call append("$", "\t(local to buffer)") + call <SID>OptionL("inex") +endif + + +call <SID>Header("tags") +call append("$", "tagbsearch\tuse binary searching in tags files") +call <SID>BinOptionG("tbs", &tbs) +call append("$", "taglength\tnumber of significant characters in a tag name or zero") +call append("$", " \tset tl=" . &tl) +call append("$", "tags\tlist of file names to search for tags") +call append("$", "\t(global or local to buffer)") +call <SID>OptionG("tag", &tag) +call append("$", "tagrelative\tfile names in a tags file are relative to the tags file") +call <SID>BinOptionG("tr", &tr) +call append("$", "tagstack\ta :tag command will use the tagstack") +call <SID>BinOptionG("tgst", &tgst) +call append("$", "showfulltag\twhen completing tags in Insert mode show more info") +call <SID>BinOptionG("sft", &sft) +if has("cscope") + call append("$", "cscopeprg\tcommand for executing cscope") + call <SID>OptionG("csprg", &csprg) + call append("$", "cscopetag\tuse cscope for tag commands") + call <SID>BinOptionG("cst", &cst) + call append("$", "cscopetagorder\t0 or 1; the order in which \":cstag\" performs a search") + call append("$", " \tset csto=" . &csto) + call append("$", "cscopeverbose\tgive messages when adding a cscope database") + call <SID>BinOptionG("csverb", &csverb) + call append("$", "cscopepathcomp\thow many components of the path to show") + call append("$", " \tset cspc=" . &cspc) + call append("$", "cscopequickfix\twhen to open a quickfix window for cscope") + call <SID>OptionG("csqf", &csqf) +endif + + +call <SID>Header("displaying text") +call append("$", "scroll\tnumber of lines to scroll for CTRL-U and CTRL-D") +call append("$", "\t(local to window)") +call <SID>OptionL("scr") +call append("$", "scrolloff\tnumber of screen lines to show around the cursor") +call append("$", " \tset so=" . &so) +call append("$", "wrap\tlong lines wrap") +call <SID>BinOptionG("wrap", &wrap) +call append("$", "linebreak\twrap long lines at a character in 'breakat'") +call append("$", "\t(local to window)") +call <SID>BinOptionL("lbr") +call append("$", "breakat\twhich characters might cause a line break") +call <SID>OptionG("brk", &brk) +call append("$", "showbreak\tstring to put before wrapped screen lines") +call <SID>OptionG("sbr", &sbr) +call append("$", "sidescroll\tminimal number of columns to scroll horizontally") +call append("$", " \tset ss=" . &ss) +call append("$", "sidescrolloff\tminimal number of columns to keep left and right of the cursor") +call append("$", " \tset siso=" . &siso) +call append("$", "display\tinclude \"lastline\" to show the last line even if it doesn't fit") +call append("$", "\tinclude \"uhex\" to show unprintable characters as a hex number") +call <SID>OptionG("dy", &dy) +call append("$", "fillchars\tcharacters to use for the status line, folds and filler lines") +call <SID>OptionG("fcs", &fcs) +call append("$", "cmdheight\tnumber of lines used for the command-line") +call append("$", " \tset ch=" . &ch) +call append("$", "columns\twidth of the display") +call append("$", " \tset co=" . &co) +call append("$", "lines\tnumber of lines in the display") +call append("$", " \tset lines=" . &lines) +call append("$", "window\tnumber of lines to scroll for CTRL-F and CTRL-B") +call append("$", " \tset window=" . &window) +call append("$", "lazyredraw\tdon't redraw while executing macros") +call <SID>BinOptionG("lz", &lz) +if has("reltime") + call append("$", "redrawtime\ttimeout for 'hlsearch' and :match highlighting in msec") + call append("$", " \tset rdt=" . &rdt) +endif +call append("$", "writedelay\tdelay in msec for each char written to the display") +call append("$", "\t(for debugging)") +call append("$", " \tset wd=" . &wd) +call append("$", "list\tshow <Tab> as ^I and end-of-line as $") +call append("$", "\t(local to window)") +call <SID>BinOptionL("list") +call append("$", "listchars\tlist of strings used for list mode") +call <SID>OptionG("lcs", &lcs) +call append("$", "number\tshow the line number for each line") +call append("$", "\t(local to window)") +call <SID>BinOptionL("nu") +call append("$", "relativenumber\tshow the relative line number for each line") +call append("$", "\t(local to window)") +call <SID>BinOptionL("rnu") +if has("linebreak") + call append("$", "numberwidth\tnumber of columns to use for the line number") + call append("$", "\t(local to window)") + call <SID>OptionL("nuw") +endif +if has("conceal") + call append("$", "conceallevel\tcontrols whether concealable text is hidden") + call append("$", "\t(local to window)") + call <SID>OptionL("cole") + call append("$", "concealcursor\tmodes in which text in the cursor line can be concealed") + call append("$", "\t(local to window)") + call <SID>OptionL("cocu") +endif + + +call <SID>Header("syntax, highlighting and spelling") +call append("$", "background\t\"dark\" or \"light\"; the background color brightness") +call <SID>OptionG("bg", &bg) +if has("autocmd") + call append("$", "filetype\ttype of file; triggers the FileType event when set") + call append("$", "\t(local to buffer)") + call <SID>OptionL("ft") +endif +if has("syntax") + call append("$", "syntax\tname of syntax highlighting used") + call append("$", "\t(local to buffer)") + call <SID>OptionL("syn") + call append("$", "synmaxcol\tmaximum column to look for syntax items") + call append("$", "\t(local to buffer)") + call <SID>OptionL("smc") +endif +call append("$", "highlight\twhich highlighting to use for various occasions") +call <SID>OptionG("hl", &hl) +call append("$", "hlsearch\thighlight all matches for the last used search pattern") +call <SID>BinOptionG("hls", &hls) +if has("syntax") + call append("$", "cursorcolumn\thighlight the screen column of the cursor") + call append("$", "\t(local to window)") + call <SID>BinOptionL("cuc") + call append("$", "cursorline\thighlight the screen line of the cursor") + call append("$", "\t(local to window)") + call <SID>BinOptionL("cul") + call append("$", "colorcolumn\tcolumns to highlight") + call append("$", "\t(local to window)") + call <SID>OptionL("cc") + call append("$", "spell\thighlight spelling mistakes") + call append("$", "\t(local to window)") + call <SID>BinOptionL("spell") + call append("$", "spelllang\tlist of accepted languages") + call append("$", "\t(local to buffer)") + call <SID>OptionL("spl") + call append("$", "spellfile\tfile that \"zg\" adds good words to") + call append("$", "\t(local to buffer)") + call <SID>OptionL("spf") + call append("$", "spellcapcheck\tpattern to locate the end of a sentence") + call append("$", "\t(local to buffer)") + call <SID>OptionL("spc") + call append("$", "spellsuggest\tmethods used to suggest corrections") + call <SID>OptionG("sps", &sps) + call append("$", "mkspellmem\tamount of memory used by :mkspell before compressing") + call <SID>OptionG("msm", &msm) +endif + + +call <SID>Header("multiple windows") +call append("$", "laststatus\t0, 1 or 2; when to use a status line for the last window") +call append("$", " \tset ls=" . &ls) +if has("statusline") + call append("$", "statusline\talternate format to be used for a status line") + call <SID>OptionG("stl", &stl) +endif +call append("$", "equalalways\tmake all windows the same size when adding/removing windows") +call <SID>BinOptionG("ea", &ea) +if has("vertsplit") + call append("$", "eadirection\tin which direction 'equalalways' works: \"ver\", \"hor\" or \"both\"") + call <SID>OptionG("ead", &ead) +endif +call append("$", "winheight\tminimal number of lines used for the current window") +call append("$", " \tset wh=" . &wh) +call append("$", "winminheight\tminimal number of lines used for any window") +call append("$", " \tset wmh=" . &wmh) +call append("$", "winfixheight\tkeep the height of the window") +call append("$", "\t(local to window)") +call <SID>BinOptionL("wfh") +if has("vertsplit") +call append("$", "winfixwidth\tkeep the width of the window") +call append("$", "\t(local to window)") +call <SID>BinOptionL("wfw") + call append("$", "winwidth\tminimal number of columns used for the current window") + call append("$", " \tset wiw=" . &wiw) + call append("$", "winminwidth\tminimal number of columns used for any window") + call append("$", " \tset wmw=" . &wmw) +endif +call append("$", "helpheight\tinitial height of the help window") +call append("$", " \tset hh=" . &hh) +if has("quickfix") + call append("$", "previewheight\tdefault height for the preview window") + call append("$", " \tset pvh=" . &pvh) + call append("$", "previewwindow\tidentifies the preview window") + call append("$", "\t(local to window)") + call <SID>BinOptionL("pvw") +endif +call append("$", "hidden\tdon't unload a buffer when no longer shown in a window") +call <SID>BinOptionG("hid", &hid) +call append("$", "switchbuf\t\"useopen\" and/or \"split\"; which window to use when jumping") +call append("$", "\tto a buffer") +call <SID>OptionG("swb", &swb) +call append("$", "splitbelow\ta new window is put below the current one") +call <SID>BinOptionG("sb", &sb) +if has("vertsplit") + call append("$", "splitright\ta new window is put right of the current one") + call <SID>BinOptionG("spr", &spr) +endif +if has("scrollbind") + call append("$", "scrollbind\tthis window scrolls together with other bound windows") + call append("$", "\t(local to window)") + call <SID>BinOptionL("scb") + call append("$", "scrollopt\t\"ver\", \"hor\" and/or \"jump\"; list of options for 'scrollbind'") + call <SID>OptionG("sbo", &sbo) +endif +if has("cursorbind") + call append("$", "cursorbind\tthis window's cursor moves together with other bound windows") + call append("$", "\t(local to window)") + call <SID>BinOptionL("crb") +endif + + +call <SID>Header("multiple tab pages") +call append("$", "showtabline\t0, 1 or 2; when to use a tab pages line") +call append("$", " \tset stal=" . &stal) +call append("$", "tabpagemax\tmaximum number of tab pages to open for -p and \"tab all\"") +call append("$", " \tset tpm=" . &tpm) +call append("$", "tabline\tcustom tab pages line") +call <SID>OptionG("tal", &tal) +if has("gui") + call append("$", "guitablabel\tcustom tab page label for the GUI") + call <SID>OptionG("gtl", >l) + call append("$", "guitabtooltip\tcustom tab page tooltip for the GUI") + call <SID>OptionG("gtt", >t) +endif + + +call <SID>Header("terminal") +call append("$", "term\tname of the used terminal") +call <SID>OptionG("term", &term) +call append("$", "ttytype\talias for 'term'") +call <SID>OptionG("tty", &tty) +call append("$", "ttybuiltin\tcheck built-in termcaps first") +call <SID>BinOptionG("tbi", &tbi) +call append("$", "ttyfast\tterminal connection is fast") +call <SID>BinOptionG("tf", &tf) +call append("$", "weirdinvert\tterminal that requires extra redrawing") +call <SID>BinOptionG("wiv", &wiv) +call append("$", "esckeys\trecognize keys that start with <Esc> in Insert mode") +call <SID>BinOptionG("ek", &ek) +call append("$", "scrolljump\tminimal number of lines to scroll at a time") +call append("$", " \tset sj=" . &sj) +call append("$", "ttyscroll\tmaximum number of lines to use scrolling instead of redrawing") +call append("$", " \tset tsl=" . &tsl) +if has("gui") || has("msdos") || has("win32") + call append("$", "guicursor\tspecifies what the cursor looks like in different modes") + call <SID>OptionG("gcr", &gcr) +endif +if has("title") + let &title = s:old_title + call append("$", "title\tshow info in the window title") + call <SID>BinOptionG("title", &title) + set notitle + call append("$", "titlelen\tpercentage of 'columns' used for the window title") + call append("$", " \tset titlelen=" . &titlelen) + call append("$", "titlestring\twhen not empty, string to be used for the window title") + call <SID>OptionG("titlestring", &titlestring) + call append("$", "titleold\tstring to restore the title to when exiting Vim") + call <SID>OptionG("titleold", &titleold) + let &icon = s:old_icon + call append("$", "icon\tset the text of the icon for this window") + call <SID>BinOptionG("icon", &icon) + set noicon + call append("$", "iconstring\twhen not empty, text for the icon of this window") + call <SID>OptionG("iconstring", &iconstring) +endif +if has("win32") + call append("$", "restorescreen\trestore the screen contents when exiting Vim") + call <SID>BinOptionG("rs", &rs) +endif + + +call <SID>Header("using the mouse") +call append("$", "mouse\tlist of flags for using the mouse") +call <SID>OptionG("mouse", &mouse) +if has("gui") + call append("$", "mousefocus\tthe window with the mouse pointer becomes the current one") + call <SID>BinOptionG("mousef", &mousef) + call append("$", "mousehide\thide the mouse pointer while typing") + call <SID>BinOptionG("mh", &mh) +endif +call append("$", "mousemodel\t\"extend\", \"popup\" or \"popup_setpos\"; what the right") +call append("$", "\tmouse button is used for") +call <SID>OptionG("mousem", &mousem) +call append("$", "mousetime\tmaximum time in msec to recognize a double-click") +call append("$", " \tset mouset=" . &mouset) +call append("$", "ttymouse\t\"xterm\", \"xterm2\", \"dec\" or \"netterm\"; type of mouse") +call <SID>OptionG("ttym", &ttym) +if has("mouseshape") + call append("$", "mouseshape\twhat the mouse pointer looks like in different modes") + call <SID>OptionG("mouses", &mouses) +endif + + +if has("gui") + call <SID>Header("GUI") + call append("$", "guifont\tlist of font names to be used in the GUI") + call <SID>OptionG("gfn", &gfn) + if has("xfontset") + call append("$", "guifontset\tpair of fonts to be used, for multibyte editing") + call <SID>OptionG("gfs", &gfs) + endif + call append("$", "guifontwide\tlist of font names to be used for double-wide characters") + call <SID>OptionG("gfw", &gfw) + if has("mac") + call append("$", "antialias\tuse smooth, antialiased fonts") + call <SID>BinOptionG("anti", &anti) + endif + call append("$", "guioptions\tlist of flags that specify how the GUI works") + call <SID>OptionG("go", &go) + if has("gui_gtk") + call append("$", "toolbar\t\"icons\", \"text\" and/or \"tooltips\"; how to show the toolbar") + call <SID>OptionG("tb", &tb) + if has("gui_gtk2") + call append("$", "toolbariconsize\tsize of toolbar icons") + call <SID>OptionG("tbis", &tbis) + endif + call append("$", "guiheadroom\troom (in pixels) left above/below the window") + call append("$", " \tset ghr=" . &ghr) + endif + call append("$", "guipty\tuse a pseudo-tty for I/O to external commands") + call <SID>BinOptionG("guipty", &guipty) + if has("browse") + call append("$", "browsedir\t\"last\", \"buffer\" or \"current\": which directory used for the file browser") + call <SID>OptionG("bsdir", &bsdir) + endif + if has("multi_lang") + call append("$", "langmenu\tlanguage to be used for the menus") + call <SID>OptionG("langmenu", &lm) + endif + call append("$", "menuitems\tmaximum number of items in one menu") + call append("$", " \tset mis=" . &mis) + if has("winaltkeys") + call append("$", "winaltkeys\t\"no\", \"yes\" or \"menu\"; how to use the ALT key") + call <SID>OptionG("wak", &wak) + endif + call append("$", "linespace\tnumber of pixel lines to use between characters") + call append("$", " \tset lsp=" . &lsp) + if has("balloon_eval") + call append("$", "balloondelay\tdelay in milliseconds before a balloon may pop up") + call append("$", " \tset bdlay=" . &bdlay) + call append("$", "ballooneval\twhether the balloon evaluation is to be used") + call <SID>BinOptionG("beval", &beval) + if has("eval") + call append("$", "balloonexpr\texpression to show in balloon eval") + call append("$", " \tset bexpr=" . &bexpr) + endif + endif + if exists("+macatsui") + call append("$", "macatsui\tuse ATSUI text drawing; disable to avoid display problems") + call <SID>OptionG("macatsui", &macatsui) + endif +endif + +if has("printer") + call <SID>Header("printing") + call append("$", "printoptions\tlist of items that control the format of :hardcopy output") + call <SID>OptionG("popt", &popt) + call append("$", "printdevice\tname of the printer to be used for :hardcopy") + call <SID>OptionG("pdev", &pdev) + if has("postscript") + call append("$", "printexpr\texpression used to print the PostScript file for :hardcopy") + call <SID>OptionG("pexpr", &pexpr) + endif + call append("$", "printfont\tname of the font to be used for :hardcopy") + call <SID>OptionG("pfn", &pfn) + call append("$", "printheader\tformat of the header used for :hardcopy") + call <SID>OptionG("pheader", &pheader) + if has("postscript") + call append("$", "printencoding\tencoding used to print the PostScript file for :hardcopy") + call <SID>OptionG("penc", &penc) + endif + if has("multi_byte") + call append("$", "printmbcharset\tthe CJK character set to be used for CJK output from :hardcopy") + call <SID>OptionG("pmbcs", &pmbcs) + call append("$", "printmbfont\tlist of font names to be used for CJK output from :hardcopy") + call <SID>OptionG("pmbfn", &pmbfn) + endif +endif + +call <SID>Header("messages and info") +call append("$", "terse\tadd 's' flag in 'shortmess' (don't show search message)") +call <SID>BinOptionG("terse", &terse) +call append("$", "shortmess\tlist of flags to make messages shorter") +call <SID>OptionG("shm", &shm) +call append("$", "showcmd\tshow (partial) command keys in the status line") +let &sc = s:old_sc +call <SID>BinOptionG("sc", &sc) +set nosc +call append("$", "showmode\tdisplay the current mode in the status line") +call <SID>BinOptionG("smd", &smd) +call append("$", "ruler\tshow cursor position below each window") +let &ru = s:old_ru +call <SID>BinOptionG("ru", &ru) +set noru +if has("statusline") + call append("$", "rulerformat\talternate format to be used for the ruler") + call <SID>OptionG("ruf", &ruf) +endif +call append("$", "report\tthreshold for reporting number of changed lines") +call append("$", " \tset report=" . &report) +call append("$", "verbose\tthe higher the more messages are given") +call append("$", " \tset vbs=" . &vbs) +call append("$", "verbosefile\tfile to write messages in") +call <SID>OptionG("vfile", &vfile) +call append("$", "more\tpause listings when the screen is full") +call <SID>BinOptionG("more", &more) +if has("dialog_con") || has("dialog_gui") + call append("$", "confirm\tstart a dialog when a command fails") + call <SID>BinOptionG("cf", &cf) +endif +call append("$", "errorbells\tring the bell for error messages") +call <SID>BinOptionG("eb", &eb) +call append("$", "visualbell\tuse a visual bell instead of beeping") +call <SID>BinOptionG("vb", &vb) +if has("multi_lang") + call append("$", "helplang\tlist of preferred languages for finding help") + call <SID>OptionG("hlg", &hlg) +endif + + +call <SID>Header("selecting text") +call append("$", "selection\t\"old\", \"inclusive\" or \"exclusive\"; how selecting text behaves") +call <SID>OptionG("sel", &sel) +call append("$", "selectmode\t\"mouse\", \"key\" and/or \"cmd\"; when to start Select mode") +call append("$", "\tinstead of Visual mode") +call <SID>OptionG("slm", &slm) +if has("clipboard") + call append("$", "clipboard\t\"unnamed\" to use the * register like unnamed register") + call append("$", "\t\"autoselect\" to always put selected text on the clipboard") + call <SID>OptionG("cb", &cb) +endif +call append("$", "keymodel\t\"startsel\" and/or \"stopsel\"; what special keys can do") +call <SID>OptionG("km", &km) + + +call <SID>Header("editing text") +call append("$", "undolevels\tmaximum number of changes that can be undone") +call append("$", " \tset ul=" . &ul) +call append("$", "undoreload\tmaximum number lines to save for undo on a buffer reload") +call append("$", " \tset ur=" . &ur) +call append("$", "modified\tchanges have been made and not written to a file") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("mod") +call append("$", "readonly\tbuffer is not to be written") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("ro") +call append("$", "modifiable\tchanges to the text are not possible") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("ma") +call append("$", "textwidth\tline length above which to break a line") +call append("$", "\t(local to buffer)") +call <SID>OptionL("tw") +call append("$", "wrapmargin\tmargin from the right in which to break a line") +call append("$", "\t(local to buffer)") +call <SID>OptionL("wm") +call append("$", "backspace\tspecifies what <BS>, CTRL-W, etc. can do in Insert mode") +call append("$", " \tset bs=" . &bs) +call append("$", "comments\tdefinition of what comment lines look like") +call append("$", "\t(local to buffer)") +call <SID>OptionL("com") +call append("$", "formatoptions\tlist of flags that tell how automatic formatting works") +call append("$", "\t(local to buffer)") +call <SID>OptionL("fo") +call append("$", "formatlistpat\tpattern to recognize a numbered list") +call append("$", "\t(local to buffer)") +call <SID>OptionL("flp") +if has("eval") + call append("$", "formatexpr\texpression used for \"gq\" to format lines") + call append("$", "\t(local to buffer)") + call <SID>OptionL("fex") +endif +if has("insert_expand") + call append("$", "complete\tspecifies how Insert mode completion works for CTRL-N and CTRL-P") + call append("$", "\t(local to buffer)") + call <SID>OptionL("cpt") + call append("$", "completeopt\twhether to use a popup menu for Insert mode completion") + call <SID>OptionG("cot", &cot) + call append("$", "pumheight\tmaximum height of the popup menu") + call <SID>OptionG("ph", &ph) + call append("$", "completefunc\tuser defined function for Insert mode completion") + call append("$", "\t(local to buffer)") + call <SID>OptionL("cfu") + call append("$", "omnifunc\tfunction for filetype-specific Insert mode completion") + call append("$", "\t(local to buffer)") + call <SID>OptionL("ofu") + call append("$", "dictionary\tlist of dictionary files for keyword completion") + call append("$", "\t(global or local to buffer)") + call <SID>OptionG("dict", &dict) + call append("$", "thesaurus\tlist of thesaurus files for keyword completion") + call append("$", "\t(global or local to buffer)") + call <SID>OptionG("tsr", &tsr) +endif +call append("$", "infercase\tadjust case of a keyword completion match") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("inf") +if has("digraphs") + call append("$", "digraph\tenable entering digraps with c1 <BS> c2") + call <SID>BinOptionG("dg", &dg) +endif +call append("$", "tildeop\tthe \"~\" command behaves like an operator") +call <SID>BinOptionG("top", &top) +call append("$", "operatorfunc\tfunction called for the\"g@\" operator") +call <SID>OptionG("opfunc", &opfunc) +call append("$", "showmatch\twhen inserting a bracket, briefly jump to its match") +call <SID>BinOptionG("sm", &sm) +call append("$", "matchtime\ttenth of a second to show a match for 'showmatch'") +call append("$", " \tset mat=" . &mat) +call append("$", "matchpairs\tlist of pairs that match for the \"%\" command") +call append("$", "\t(local to buffer)") +call <SID>OptionL("mps") +call append("$", "joinspaces\tuse two spaces after '.' when joining a line") +call <SID>BinOptionG("js", &js) +call append("$", "nrformats\t\"alpha\", \"octal\" and/or \"hex\"; number formats recognized for") +call append("$", "\tCTRL-A and CTRL-X commands") +call append("$", "\t(local to buffer)") +call <SID>OptionL("nf") + + +call <SID>Header("tabs and indenting") +call append("$", "tabstop\tnumber of spaces a <Tab> in the text stands for") +call append("$", "\t(local to buffer)") +call <SID>OptionL("ts") +call append("$", "shiftwidth\tnumber of spaces used for each step of (auto)indent") +call append("$", "\t(local to buffer)") +call <SID>OptionL("sw") +call append("$", "smarttab\ta <Tab> in an indent inserts 'shiftwidth' spaces") +call <SID>BinOptionG("sta", &sta) +call append("$", "softtabstop\tif non-zero, number of spaces to insert for a <Tab>") +call append("$", "\t(local to buffer)") +call <SID>OptionL("sts") +call append("$", "shiftround\tround to 'shiftwidth' for \"<<\" and \">>\"") +call <SID>BinOptionG("sr", &sr) +call append("$", "expandtab\texpand <Tab> to spaces in Insert mode") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("et") +call append("$", "autoindent\tautomatically set the indent of a new line") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("ai") +if has("smartindent") + call append("$", "smartindent\tdo clever autoindenting") + call append("$", "\t(local to buffer)") + call <SID>BinOptionL("si") +endif +if has("cindent") + call append("$", "cindent\tenable specific indenting for C code") + call append("$", "\t(local to buffer)") + call <SID>BinOptionL("cin") + call append("$", "cinoptions\toptions for C-indenting") + call append("$", "\t(local to buffer)") + call <SID>OptionL("cino") + call append("$", "cinkeys\tkeys that trigger C-indenting in Insert mode") + call append("$", "\t(local to buffer)") + call <SID>OptionL("cink") + call append("$", "cinwords\tlist of words that cause more C-indent") + call append("$", "\t(local to buffer)") + call <SID>OptionL("cinw") + call append("$", "indentexpr\texpression used to obtain the indent of a line") + call append("$", "\t(local to buffer)") + call <SID>OptionL("inde") + call append("$", "indentkeys\tkeys that trigger indenting with 'indentexpr' in Insert mode") + call append("$", "\t(local to buffer)") + call <SID>OptionL("indk") +endif +call append("$", "copyindent\tcopy whitespace for indenting from previous line") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("ci") +call append("$", "preserveindent\tpreserve kind of whitespace when changing indent") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("pi") +if has("lispindent") + call append("$", "lisp\tenable lisp mode") + call append("$", "\t(local to buffer)") + call <SID>BinOptionL("lisp") + call append("$", "lispwords\twords that change how lisp indenting works") + call <SID>OptionG("lw", &lw) +endif + + +if has("folding") + call <SID>Header("folding") + call append("$", "foldenable\tset to display all folds open") + call append("$", "\t(local to window)") + call <SID>BinOptionL("fen") + call append("$", "foldlevel\tfolds with a level higher than this number will be closed") + call append("$", "\t(local to window)") + call <SID>OptionL("fdl") + call append("$", "foldlevelstart\tvalue for 'foldlevel' when starting to edit a file") + call append("$", " \tset fdls=" . &fdls) + call append("$", "foldcolumn\twidth of the column used to indicate folds") + call append("$", "\t(local to window)") + call <SID>OptionL("fdc") + call append("$", "foldtext\texpression used to display the text of a closed fold") + call append("$", "\t(local to window)") + call <SID>OptionL("fdt") + call append("$", "foldclose\tset to \"all\" to close a fold when the cursor leaves it") + call <SID>OptionG("fcl", &fcl) + call append("$", "foldopen\tspecifies for which commands a fold will be opened") + call <SID>OptionG("fdo", &fdo) + call append("$", "foldminlines\tminimum number of screen lines for a fold to be closed") + call append("$", "\t(local to window)") + call <SID>OptionL("fml") + call append("$", "commentstring\ttemplate for comments; used to put the marker in") + call <SID>OptionL("cms") + call append("$", "foldmethod\tfolding type: \"manual\", \"indent\", \"expr\", \"marker\" or \"syntax\"") + call append("$", "\t(local to window)") + call <SID>OptionL("fdm") + call append("$", "foldexpr\texpression used when 'foldmethod' is \"expr\"") + call append("$", "\t(local to window)") + call <SID>OptionL("fde") + call append("$", "foldignore\tused to ignore lines when 'foldmethod' is \"indent\"") + call append("$", "\t(local to window)") + call <SID>OptionL("fdi") + call append("$", "foldmarker\tmarkers used when 'foldmethod' is \"marker\"") + call append("$", "\t(local to window)") + call <SID>OptionL("fmr") + call append("$", "foldnestmax\tmaximum fold depth for when 'foldmethod is \"indent\" or \"syntax\"") + call append("$", "\t(local to window)") + call <SID>OptionL("fdn") +endif + + +if has("diff") + call <SID>Header("diff mode") + call append("$", "diff\tuse diff mode for the current window") + call append("$", "\t(local to window)") + call <SID>BinOptionL("diff") + call append("$", "diffopt\toptions for using diff mode") + call <SID>OptionG("dip", &dip) + call append("$", "diffexpr\texpression used to obtain a diff file") + call <SID>OptionG("dex", &dex) + call append("$", "patchexpr\texpression used to patch a file") + call <SID>OptionG("pex", &pex) +endif + + +call <SID>Header("mapping") +call append("$", "maxmapdepth\tmaximum depth of mapping") +call append("$", " \tset mmd=" . &mmd) +call append("$", "remap\trecognize mappings in mapped keys") +call <SID>BinOptionG("remap", &remap) +call append("$", "timeout\tallow timing out halfway into a mapping") +call <SID>BinOptionG("to", &to) +call append("$", "ttimeout\tallow timing out halfway into a key code") +call <SID>BinOptionG("ttimeout", &ttimeout) +call append("$", "timeoutlen\ttime in msec for 'timeout'") +call append("$", " \tset tm=" . &tm) +call append("$", "ttimeoutlen\ttime in msec for 'ttimeout'") +call append("$", " \tset ttm=" . &ttm) + + +call <SID>Header("reading and writing files") +call append("$", "modeline\tenable using settings from modelines when reading a file") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("ml") +call append("$", "modelines\tnumber of lines to check for modelines") +call append("$", " \tset mls=" . &mls) +call append("$", "binary\tbinary file editing") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("bin") +call append("$", "endofline\tlast line in the file has an end-of-line") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("eol") +if has("multi_byte") + call append("$", "bomb\tprepend a Byte Order Mark to the file") + call append("$", "\t(local to buffer)") + call <SID>BinOptionL("bomb") +endif +call append("$", "fileformat\tend-of-line format: \"dos\", \"unix\" or \"mac\"") +call append("$", "\t(local to buffer)") +call <SID>OptionL("ff") +call append("$", "fileformats\tlist of file formats to look for when editing a file") +call <SID>OptionG("ffs", &ffs) +call append("$", "textmode\tobsolete, use 'fileformat'") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("tx") +call append("$", "textauto\tobsolete, use 'fileformats'") +call <SID>BinOptionG("ta", &ta) +call append("$", "write\twriting files is allowed") +call <SID>BinOptionG("write", &write) +call append("$", "writebackup\twrite a backup file before overwriting a file") +call <SID>BinOptionG("wb", &wb) +call append("$", "backup\tkeep a backup after overwriting a file") +call <SID>BinOptionG("bk", &bk) +call append("$", "backupskip\tpatterns that specify for which files a backup is not made") +call append("$", " \tset bsk=" . &bsk) +call append("$", "backupcopy\twhether to make the backup as a copy or rename the existing file") +call append("$", " \tset bkc=" . &bkc) +call append("$", "backupdir\tlist of directories to put backup files in") +call <SID>OptionG("bdir", &bdir) +call append("$", "backupext\tfile name extension for the backup file") +call <SID>OptionG("bex", &bex) +call append("$", "autowrite\tautomatically write a file when leaving a modified buffer") +call <SID>BinOptionG("aw", &aw) +call append("$", "autowriteall\tas 'autowrite', but works with more commands") +call <SID>BinOptionG("awa", &awa) +call append("$", "writeany\talways write without asking for confirmation") +call <SID>BinOptionG("wa", &wa) +call append("$", "autoread\tautomatically read a file when it was modified outside of Vim") +call append("$", "\t(global or local to buffer)") +call <SID>BinOptionG("ar", &ar) +call append("$", "patchmode\tkeep oldest version of a file; specifies file name extension") +call <SID>OptionG("pm", &pm) +call append("$", "fsync\tforcibly sync the file to disk after writing it") +call <SID>BinOptionG("fs", &fs) +if !has("msdos") + call append("$", "shortname\tuse 8.3 file names") + call append("$", "\t(local to buffer)") + call <SID>BinOptionL("sn") +endif +call append("$", "cryptmethod\tencryption method for file writing: zip or blowfish") +call append("$", "\t(local to buffer)") +call <SID>OptionL("cm") + + +call <SID>Header("the swap file") +call append("$", "directory\tlist of directories for the swap file") +call <SID>OptionG("dir", &dir) +call append("$", "swapfile\tuse a swap file for this buffer") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("swf") +call append("$", "swapsync\t\"sync\", \"fsync\" or empty; how to flush a swap file to disk") +call <SID>OptionG("sws", &sws) +call append("$", "updatecount\tnumber of characters typed to cause a swap file update") +call append("$", " \tset uc=" . &uc) +call append("$", "updatetime\ttime in msec after which the swap file will be updated") +call append("$", " \tset ut=" . &ut) +call append("$", "maxmem\tmaximum amount of memory in Kbyte used for one buffer") +call append("$", " \tset mm=" . &mm) +call append("$", "maxmemtot\tmaximum amount of memory in Kbyte used for all buffers") +call append("$", " \tset mmt=" . &mmt) + + +call <SID>Header("command line editing") +call append("$", "history\thow many command lines are remembered ") +call append("$", " \tset hi=" . &hi) +call append("$", "wildchar\tkey that triggers command-line expansion") +call append("$", " \tset wc=" . &wc) +call append("$", "wildcharm\tlike 'wildchar' but can also be used in a mapping") +call append("$", " \tset wcm=" . &wcm) +call append("$", "wildmode\tspecifies how command line completion works") +call <SID>OptionG("wim", &wim) +if has("wildoptions") + call append("$", "wildoptions\tempty or \"tagfile\" to list file name of matching tags") + call <SID>OptionG("wop", &wop) +endif +call append("$", "suffixes\tlist of file name extensions that have a lower priority") +call <SID>OptionG("su", &su) +if has("file_in_path") + call append("$", "suffixesadd\tlist of file name extensions added when searching for a file") + call append("$", "\t(local to buffer)") + call <SID>OptionL("sua") +endif +if has("wildignore") + call append("$", "wildignore\tlist of patterns to ignore files for file name completion") + call <SID>OptionG("wig", &wig) +endif +if has("wildmenu") + call append("$", "wildmenu\tcommand-line completion shows a list of matches") + call <SID>BinOptionG("wmnu", &wmnu) +endif +if has("vertsplit") + call append("$", "cedit\tkey used to open the command-line window") + call <SID>OptionG("cedit", &cedit) + call append("$", "cmdwinheight\theight of the command-line window") + call <SID>OptionG("cwh", &cwh) +endif +call append("$", "undofile\tautomatically save and restore undo history") +call <SID>BinOptionG("udf", &udf) +call append("$", "undodir\tlist of directories for undo files") +call <SID>OptionG("udir", &udir) + + +call <SID>Header("executing external commands") +call append("$", "shell\tname of the shell program used for external commands") +call <SID>OptionG("sh", &sh) +if has("amiga") + call append("$", "shelltype\twhen to use the shell or directly execute a command") + call append("$", " \tset st=" . &st) +endif +call append("$", "shellquote\tcharacter(s) to enclose a shell command in") +call <SID>OptionG("shq", &shq) +call append("$", "shellxquote\tlike 'shellquote' but include the redirection") +call <SID>OptionG("sxq", &sxq) +call append("$", "shellcmdflag\targument for 'shell' to execute a command") +call <SID>OptionG("shcf", &shcf) +call append("$", "shellredir\tused to redirect command output to a file") +call <SID>OptionG("srr", &srr) +call append("$", "shelltemp\tuse a temp file for shell commands instead of using a pipe") +call <SID>BinOptionG("stmp", &stmp) +call append("$", "equalprg\tprogram used for \"=\" command") +call append("$", "\t(global or local to buffer)") +call <SID>OptionG("ep", &ep) +call append("$", "formatprg\tprogram used to format lines with \"gq\" command") +call <SID>OptionG("fp", &fp) +call append("$", "keywordprg\tprogram used for the \"K\" command") +call <SID>OptionG("kp", &kp) +call append("$", "warn\twarn when using a shell command and a buffer has changes") +call <SID>BinOptionG("warn", &warn) + + +if has("quickfix") + call <SID>Header("running make and jumping to errors") + call append("$", "errorfile\tname of the file that contains error messages") + call <SID>OptionG("ef", &ef) + call append("$", "errorformat\tlist of formats for error messages") + call append("$", "\t(global or local to buffer)") + call <SID>OptionG("efm", &efm) + call append("$", "makeprg\tprogram used for the \":make\" command") + call append("$", "\t(global or local to buffer)") + call <SID>OptionG("mp", &mp) + call append("$", "shellpipe\tstring used to put the output of \":make\" in the error file") + call <SID>OptionG("sp", &sp) + call append("$", "makeef\tname of the errorfile for the 'makeprg' command") + call <SID>OptionG("mef", &mef) + call append("$", "grepprg\tprogram used for the \":grep\" command") + call append("$", "\t(global or local to buffer)") + call <SID>OptionG("gp", &gp) + call append("$", "grepformat\tlist of formats for output of 'grepprg'") + call <SID>OptionG("gfm", &gfm) +endif + + +if has("msdos") || has("os2") || has("win16") || has("win32") || has("osfiletype") + call <SID>Header("system specific") + if has("msdos") + call append("$", "bioskey\tcall the BIOS to get a keyoard character") + call <SID>BinOptionG("biosk", &biosk) + call append("$", "conskey\tuse direct console I/O to get a keyboard character") + call <SID>BinOptionG("consk", &consk) + endif + if has("osfiletype") + call append("$", "osfiletype\tOS-specific information about the type of file") + call append("$", "\t(local to buffer)") + call <SID>OptionL("oft") + endif + if has("msdos") || has("os2") || has("win16") || has("win32") + call append("$", "shellslash\tuse forward slashes in file names; for Unix-like shells") + call <SID>BinOptionG("ssl", &ssl) + endif +endif + + +call <SID>Header("language specific") +call append("$", "isfname\tspecifies the characters in a file name") +call <SID>OptionG("isf", &isf) +call append("$", "isident\tspecifies the characters in an identifier") +call <SID>OptionG("isi", &isi) +call append("$", "iskeyword\tspecifies the characters in a keyword") +call append("$", "\t(local to buffer)") +call <SID>OptionL("isk") +call append("$", "isprint\tspecifies printable characters") +call <SID>OptionG("isp", &isp) +if has("textobjects") + call append("$", "quoteescape\tspecifies escape characters in a string") + call append("$", "\t(local to buffer)") + call <SID>OptionL("qe") +endif +if has("rightleft") + call append("$", "rightleft\tdisplay the buffer right-to-left") + call append("$", "\t(local to window)") + call <SID>BinOptionL("rl") + call append("$", "rightleftcmd\twhen to edit the command-line right-to-left") + call append("$", "\t(local to window)") + call <SID>OptionL("rlc") + call append("$", "revins\tinsert characters backwards") + call <SID>BinOptionG("ri", &ri) + call append("$", "allowrevins\tallow CTRL-_ in Insert and Command-line mode to toggle 'revins'") + call <SID>BinOptionG("ari", &ari) + call append("$", "aleph\tthe ASCII code for the first letter of the Hebrew alphabet") + call append("$", " \tset al=" . &al) + call append("$", "hkmap\tuse Hebrew keyboard mapping") + call <SID>BinOptionG("hk", &hk) + call append("$", "hkmapp\tuse phonetic Hebrew keyboard mapping") + call <SID>BinOptionG("hkp", &hkp) +endif +if has("farsi") + call append("$", "altkeymap\tuse Farsi as the second language when 'revins' is set") + call <SID>BinOptionG("akm", &akm) + call append("$", "fkmap\tuse Farsi keyboard mapping") + call <SID>BinOptionG("fk", &fk) +endif +if has("arabic") + call append("$", "arabic\tprepare for editing Arabic text") + call append("$", "\t(local to window)") + call <SID>BinOptionL("arab") + call append("$", "arabicshape\tperform shaping of Arabic characters") + call <SID>BinOptionG("arshape", &arshape) + call append("$", "termbidi\tterminal will perform bidi handling") + call <SID>BinOptionG("tbidi", &tbidi) +endif +if has("keymap") + call append("$", "keymap\tname of a keyboard mappping") + call <SID>OptionL("kmp") +endif +if has("langmap") + call append("$", "langmap\ttranslate characters for Normal mode") + call <SID>OptionG("lmap", &lmap) +endif +if has("xim") + call append("$", "imdisable\twhen set never use IM; overrules following IM options") + call <SID>BinOptionG("imd", &imd) +endif +call append("$", "iminsert\tin Insert mode: 1: use :lmap; 2: use IM; 0: neither") +call append("$", "\t(local to window)") +call <SID>OptionL("imi") +call append("$", "imsearch\tentering a search pattern: 1: use :lmap; 2: use IM; 0: neither") +call append("$", "\t(local to window)") +call <SID>OptionL("ims") +if has("xim") + call append("$", "imcmdline\twhen set always use IM when starting to edit a command line") + call <SID>BinOptionG("imc", &imc) +endif + + +if has("multi_byte") + call <SID>Header("multi-byte characters") + call append("$", "encoding\tcharacter encoding used in Vim: \"latin1\", \"utf-8\"") + call append("$", "\t\"euc-jp\", \"big5\", etc.") + call <SID>OptionG("enc", &enc) + call append("$", "fileencoding\tcharacter encoding for the current file") + call append("$", "\t(local to buffer)") + call <SID>OptionL("fenc") + call append("$", "fileencodings\tautomatically detected character encodings") + call <SID>OptionG("fencs", &fencs) + call append("$", "termencoding\tcharacter encoding used by the terminal") + call <SID>OptionG("tenc", &tenc) + call append("$", "charconvert\texpression used for character encoding conversion") + call <SID>OptionG("ccv", &ccv) + call append("$", "delcombine\tdelete combining (composing) characters on their own") + call <SID>BinOptionG("deco", &deco) + call append("$", "maxcombine\tmaximum number of combining (composing) characters displayed") + call <SID>OptionG("mco", &mco) + if has("xim") && has("gui_gtk") + call append("$", "imactivatekey\tkey that activates the X input method") + call <SID>OptionG("imak", &imak) + endif + call append("$", "ambiwidth\twidth of ambiguous width characters") + call <SID>OptionG("ambw", &ambw) +endif + + +call <SID>Header("various") +if has("virtualedit") + call append("$", "virtualedit\twhen to use virtual editing: \"block\", \"insert\" and/or \"all\"") + call <SID>OptionG("ve", &ve) +endif +if has("autocmd") + call append("$", "eventignore\tlist of autocommand events which are to be ignored") + call <SID>OptionG("ei", &ei) +endif +call append("$", "loadplugins\tload plugin scripts when starting up") +call <SID>BinOptionG("lpl", &lpl) +call append("$", "exrc\tenable reading .vimrc/.exrc/.gvimrc in the current directory") +call <SID>BinOptionG("ex", &ex) +call append("$", "secure\tsafer working with script files in the current directory") +call <SID>BinOptionG("secure", &secure) +call append("$", "gdefault\tuse the 'g' flag for \":substitute\"") +call <SID>BinOptionG("gd", &gd) +call append("$", "edcompatible\t'g' and 'c' flags of \":substitute\" toggle") +call <SID>BinOptionG("ed", &ed) +if exists("+opendevice") + call append("$", "opendevice\tallow reading/writing devices") + call <SID>BinOptionG("odev", &odev) +endif +if exists("+maxfuncdepth") + call append("$", "maxfuncdepth\tmaximum depth of function calls") + call append("$", " \tset mfd=" . &mfd) +endif +if has("mksession") + call append("$", "sessionoptions\tlist of words that specifies what to put in a session file") + call <SID>OptionG("ssop", &ssop) + call append("$", "viewoptions\tlist of words that specifies what to save for :mkview") + call <SID>OptionG("vop", &vop) + call append("$", "viewdir\tdirectory where to store files with :mkview") + call <SID>OptionG("vdir", &vdir) +endif +if has("viminfo") + call append("$", "viminfo\tlist that specifies what to write in the viminfo file") + call <SID>OptionG("vi", &vi) +endif +if has("quickfix") + call append("$", "bufhidden\twhat happens with a buffer when it's no longer in a window") + call append("$", "\t(local to buffer)") + call <SID>OptionL("bh") + call append("$", "buftype\t\"\", \"nofile\", \"nowrite\" or \"quickfix\": type of buffer") + call append("$", "\t(local to buffer)") + call <SID>OptionL("bt") +endif +call append("$", "buflisted\twhether the buffer shows up in the buffer list") +call append("$", "\t(local to buffer)") +call <SID>BinOptionL("bl") +call append("$", "debug\tset to \"msg\" to see all error messages") +call append("$", " \tset debug=" . &debug) +if has("mzscheme") + call append("$", "mzquantum\tinterval in milliseconds between polls for MzScheme threads") + call append("$", " \tset mzq=" . &mzq) +endif + +set cpo&vim + +" go to first line +1 + +" reset 'modified', so that ":q" can be used to close the window +setlocal nomodified + +if has("syntax") + " Use Vim highlighting, with some additional stuff + setlocal ft=vim + syn match optwinHeader "^ \=[0-9].*" + syn match optwinName "^[a-z]*\t" nextgroup=optwinComment + syn match optwinComment ".*" contained + syn match optwinComment "^\t.*" + if !exists("did_optwin_syntax_inits") + let did_optwin_syntax_inits = 1 + hi link optwinHeader Title + hi link optwinName Identifier + hi link optwinComment Comment + endif +endif + +" Install autocommands to enable mappings in option-window +noremap <silent> <buffer> <CR> <C-\><C-N>:call <SID>CR()<CR> +inoremap <silent> <buffer> <CR> <Esc>:call <SID>CR()<CR> +noremap <silent> <buffer> <Space> :call <SID>Space()<CR> + +" Make the buffer be deleted when the window is closed. +setlocal buftype=nofile bufhidden=delete noswapfile + +augroup optwin + au! BufUnload,BufHidden option-window nested + \ call <SID>unload() | delfun <SID>unload +augroup END + +fun! <SID>unload() + delfun <SID>CR + delfun <SID>Space + delfun <SID>Find + delfun <SID>Update + delfun <SID>OptionL + delfun <SID>OptionG + delfun <SID>BinOptionL + delfun <SID>BinOptionG + delfun <SID>Header + au! optwin +endfun + +" Restore the previous value of 'title' and 'icon'. +let &title = s:old_title +let &icon = s:old_icon +let &ru = s:old_ru +let &sc = s:old_sc +let &cpo = s:cpo_save +unlet s:old_title s:old_icon s:old_ru s:old_sc s:cpo_save s:idx s:lnum diff --git a/share/vim/vim72/plugin/README.txt b/share/vim/vim73/plugin/README.txt similarity index 100% rename from share/vim/vim72/plugin/README.txt rename to share/vim/vim73/plugin/README.txt diff --git a/share/vim/vim73/plugin/getscriptPlugin.vim b/share/vim/vim73/plugin/getscriptPlugin.vim new file mode 100644 index 0000000000..7ae35cb41c --- /dev/null +++ b/share/vim/vim73/plugin/getscriptPlugin.vim @@ -0,0 +1,38 @@ +" --------------------------------------------------------------------- +" getscriptPlugin.vim +" Author: Charles E. Campbell, Jr. +" Date: Jan 07, 2008 +" Installing: :help glvs-install +" Usage: :help glvs +" +" GetLatestVimScripts: 642 1 :AutoInstall: getscript.vim +" +" (Rom 15:11 WEB) Again, "Praise the Lord, all you Gentiles! Let +" all the peoples praise Him." +" --------------------------------------------------------------------- +" Initialization: {{{1 +" if you're sourcing this file, surely you can't be +" expecting vim to be in its vi-compatible mode +if &cp || exists("g:loaded_getscriptPlugin") + if &verbose + echo "GetLatestVimScripts is not vi-compatible; not loaded (you need to set nocp)" + endif + finish +endif +let g:loaded_getscriptPlugin = "v32" +let s:keepcpo = &cpo +set cpo&vim + +" --------------------------------------------------------------------- +" Public Interface: {{{1 +com! -nargs=0 GetLatestVimScripts call getscript#GetLatestVimScripts() +com! -nargs=0 GetScripts call getscript#GetLatestVimScripts() +silent! com -nargs=0 GLVS call getscript#GetLatestVimScripts() + +" --------------------------------------------------------------------- +" Restore Options: {{{1 +let &cpo= s:keepcpo +unlet s:keepcpo + +" --------------------------------------------------------------------- +" vim: ts=8 sts=2 fdm=marker nowrap diff --git a/share/vim/vim73/plugin/gzip.vim b/share/vim/vim73/plugin/gzip.vim new file mode 100644 index 0000000000..edef149537 --- /dev/null +++ b/share/vim/vim73/plugin/gzip.vim @@ -0,0 +1,44 @@ +" Vim plugin for editing compressed files. +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2010 Mar 10 + +" Exit quickly when: +" - this plugin was already loaded +" - when 'compatible' is set +" - some autocommands are already taking care of compressed files +if exists("loaded_gzip") || &cp || exists("#BufReadPre#*.gz") + finish +endif +let loaded_gzip = 1 + +augroup gzip + " Remove all gzip autocommands + au! + + " Enable editing of gzipped files. + " The functions are defined in autoload/gzip.vim. + " + " Set binary mode before reading the file. + " Use "gzip -d", gunzip isn't always available. + autocmd BufReadPre,FileReadPre *.gz,*.bz2,*.Z,*.lzma,*.xz setlocal bin + autocmd BufReadPost,FileReadPost *.gz call gzip#read("gzip -dn") + autocmd BufReadPost,FileReadPost *.bz2 call gzip#read("bzip2 -d") + autocmd BufReadPost,FileReadPost *.Z call gzip#read("uncompress") + autocmd BufReadPost,FileReadPost *.lzma call gzip#read("lzma -d") + autocmd BufReadPost,FileReadPost *.xz call gzip#read("xz -d") + autocmd BufWritePost,FileWritePost *.gz call gzip#write("gzip") + autocmd BufWritePost,FileWritePost *.bz2 call gzip#write("bzip2") + autocmd BufWritePost,FileWritePost *.Z call gzip#write("compress -f") + autocmd BufWritePost,FileWritePost *.lzma call gzip#write("lzma -z") + autocmd BufWritePost,FileWritePost *.xz call gzip#write("xz -z") + autocmd FileAppendPre *.gz call gzip#appre("gzip -dn") + autocmd FileAppendPre *.bz2 call gzip#appre("bzip2 -d") + autocmd FileAppendPre *.Z call gzip#appre("uncompress") + autocmd FileAppendPre *.lzma call gzip#appre("lzma -d") + autocmd FileAppendPre *.xz call gzip#appre("xz -d") + autocmd FileAppendPost *.gz call gzip#write("gzip") + autocmd FileAppendPost *.bz2 call gzip#write("bzip2") + autocmd FileAppendPost *.Z call gzip#write("compress -f") + autocmd FileAppendPost *.lzma call gzip#write("lzma -z") + autocmd FileAppendPost *.xz call gzip#write("xz -z") +augroup END diff --git a/share/vim/vim73/plugin/matchparen.vim b/share/vim/vim73/plugin/matchparen.vim new file mode 100644 index 0000000000..d5a0ac5a97 --- /dev/null +++ b/share/vim/vim73/plugin/matchparen.vim @@ -0,0 +1,151 @@ +" Vim plugin for showing matching parens +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2008 Sep 03 + +" Exit quickly when: +" - this plugin was already loaded (or disabled) +" - when 'compatible' is set +" - the "CursorMoved" autocmd event is not availble. +if exists("g:loaded_matchparen") || &cp || !exists("##CursorMoved") + finish +endif +let g:loaded_matchparen = 1 + +augroup matchparen + " Replace all matchparen autocommands + autocmd! CursorMoved,CursorMovedI,WinEnter * call s:Highlight_Matching_Pair() +augroup END + +" Skip the rest if it was already done. +if exists("*s:Highlight_Matching_Pair") + finish +endif + +let s:cpo_save = &cpo +set cpo-=C + +" The function that is invoked (very often) to define a ":match" highlighting +" for any matching paren. +function! s:Highlight_Matching_Pair() + " Remove any previous match. + if exists('w:paren_hl_on') && w:paren_hl_on + 3match none + let w:paren_hl_on = 0 + endif + + " Avoid that we remove the popup menu. + " Return when there are no colors (looks like the cursor jumps). + if pumvisible() || (&t_Co < 8 && !has("gui_running")) + return + endif + + " Get the character under the cursor and check if it's in 'matchpairs'. + let c_lnum = line('.') + let c_col = col('.') + let before = 0 + + let c = getline(c_lnum)[c_col - 1] + let plist = split(&matchpairs, '.\zs[:,]') + let i = index(plist, c) + if i < 0 + " not found, in Insert mode try character before the cursor + if c_col > 1 && (mode() == 'i' || mode() == 'R') + let before = 1 + let c = getline(c_lnum)[c_col - 2] + let i = index(plist, c) + endif + if i < 0 + " not found, nothing to do + return + endif + endif + + " Figure out the arguments for searchpairpos(). + if i % 2 == 0 + let s_flags = 'nW' + let c2 = plist[i + 1] + else + let s_flags = 'nbW' + let c2 = c + let c = plist[i - 1] + endif + if c == '[' + let c = '\[' + let c2 = '\]' + endif + + " Find the match. When it was just before the cursor move it there for a + " moment. + if before > 0 + let save_cursor = winsaveview() + call cursor(c_lnum, c_col - before) + endif + + " When not in a string or comment ignore matches inside them. + let s_skip ='synIDattr(synID(line("."), col("."), 0), "name") ' . + \ '=~? "string\\|character\\|singlequote\\|comment"' + execute 'if' s_skip '| let s_skip = 0 | endif' + + " Limit the search to lines visible in the window. + let stoplinebottom = line('w$') + let stoplinetop = line('w0') + if i % 2 == 0 + let stopline = stoplinebottom + else + let stopline = stoplinetop + endif + + try + " Limit the search time to 300 msec to avoid a hang on very long lines. + " This fails when a timeout is not supported. + let [m_lnum, m_col] = searchpairpos(c, '', c2, s_flags, s_skip, stopline, 300) + catch /E118/ + " Can't use the timeout, restrict the stopline a bit more to avoid taking + " a long time on closed folds and long lines. + " The "viewable" variables give a range in which we can scroll while + " keeping the cursor at the same position. + " adjustedScrolloff accounts for very large numbers of scrolloff. + let adjustedScrolloff = min([&scrolloff, (line('w$') - line('w0')) / 2]) + let bottom_viewable = min([line('$'), c_lnum + &lines - adjustedScrolloff - 2]) + let top_viewable = max([1, c_lnum-&lines+adjustedScrolloff + 2]) + " one of these stoplines will be adjusted below, but the current values are + " minimal boundaries within the current window + if i % 2 == 0 + if has("byte_offset") && has("syntax_items") && &smc > 0 + let stopbyte = min([line2byte("$"), line2byte(".") + col(".") + &smc * 2]) + let stopline = min([bottom_viewable, byte2line(stopbyte)]) + else + let stopline = min([bottom_viewable, c_lnum + 100]) + endif + let stoplinebottom = stopline + else + if has("byte_offset") && has("syntax_items") && &smc > 0 + let stopbyte = max([1, line2byte(".") + col(".") - &smc * 2]) + let stopline = max([top_viewable, byte2line(stopbyte)]) + else + let stopline = max([top_viewable, c_lnum - 100]) + endif + let stoplinetop = stopline + endif + let [m_lnum, m_col] = searchpairpos(c, '', c2, s_flags, s_skip, stopline) + endtry + + if before > 0 + call winrestview(save_cursor) + endif + + " If a match is found setup match highlighting. + if m_lnum > 0 && m_lnum >= stoplinetop && m_lnum <= stoplinebottom + exe '3match MatchParen /\(\%' . c_lnum . 'l\%' . (c_col - before) . + \ 'c\)\|\(\%' . m_lnum . 'l\%' . m_col . 'c\)/' + let w:paren_hl_on = 1 + endif +endfunction + +" Define commands that will disable and enable the plugin. +command! NoMatchParen windo 3match none | unlet! g:loaded_matchparen | + \ au! matchparen +command! DoMatchParen runtime plugin/matchparen.vim | windo doau CursorMoved + +let &cpo = s:cpo_save +unlet s:cpo_save diff --git a/share/vim/vim73/plugin/netrwPlugin.vim b/share/vim/vim73/plugin/netrwPlugin.vim new file mode 100644 index 0000000000..3ce710b0ad --- /dev/null +++ b/share/vim/vim73/plugin/netrwPlugin.vim @@ -0,0 +1,168 @@ +" netrwPlugin.vim: Handles file transfer and remote directory listing across a network +" PLUGIN SECTION +" Date: Jul 27, 2010 +" Maintainer: Charles E Campbell, Jr <NdrOchip@ScampbellPfamily.AbizM-NOSPAM> +" GetLatestVimScripts: 1075 1 :AutoInstall: netrw.vim +" Copyright: Copyright (C) 1999-2008 Charles E. Campbell, Jr. {{{1 +" Permission is hereby granted to use and distribute this code, +" with or without modifications, provided that this copyright +" notice is copied with it. Like anything else that's free, +" netrw.vim, netrwPlugin.vim, and netrwSettings.vim are provided +" *as is* and comes with no warranty of any kind, either +" expressed or implied. By using this plugin, you agree that +" in no event will the copyright holder be liable for any damages +" resulting from the use of this software. +" +" But be doers of the Word, and not only hearers, deluding your own selves {{{1 +" (James 1:22 RSV) +" =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=- +" Load Once: {{{1 +if &cp || exists("g:loaded_netrwPlugin") + finish +endif +let g:loaded_netrwPlugin = "v140" +if v:version < 702 + echohl WarningMsg | echo "***netrw*** you need vim version 7.2 for this version of netrw" | echohl None + finish +endif +let s:keepcpo = &cpo +set cpo&vim + +" --------------------------------------------------------------------- +" Public Interface: {{{1 + +" Local Browsing: {{{2 +augroup FileExplorer + au! + au BufEnter * silent! call s:LocalBrowse(expand("<amatch>")) + au VimEnter * silent! call s:VimEnter(expand("<amatch>")) + if has("win32") || has("win95") || has("win64") || has("win16") + au BufEnter .* silent! call s:LocalBrowse(expand("<amatch>")) + endif +augroup END + +" Network Browsing Reading Writing: {{{2 +augroup Network + au! + if has("win32") || has("win95") || has("win64") || has("win16") + au BufReadCmd file://* exe "silent doau BufReadPre ".fnameescape(netrw#RFC2396(expand("<amatch>")))|exe 'e '.fnameescape(substitute(netrw#RFC2396(expand("<amatch>")),'file://\(.*\)','\1',""))|exe "bwipe ".fnameescape(expand("<amatch>"))|exe "silent doau BufReadPost ".fnameescape(netrw#RFC2396(expand("<amatch>"))) + else + au BufReadCmd file://* exe "silent doau BufReadPre ".fnameescape(netrw#RFC2396(expand("<amatch>")))|exe 'e '.fnameescape(substitute(netrw#RFC2396(expand("<amatch>")),'file://\(.*\)','\1',""))|exe "bwipe ".fnameescape(expand("<amatch>"))|exe "silent doau BufReadPost ".fnameescape(netrw#RFC2396(expand("<amatch>"))) + au BufReadCmd file://localhost/* exe "silent doau BufReadPre ".fnameescape(netrw#RFC2396(expand("<amatch>")))|exe 'e '.fnameescape(substitute(netrw#RFC2396(expand("<amatch>")),'file://localhost/\(.*\)','\1',""))|exe "bwipe ".fnameescape(substitute(expand("<amatch>"),'file://\(\k\+@\)\=','',''))|exe "silent doau BufReadPost ".fnameescape(netrw#RFC2396(expand("<amatch>"))) + endif + au BufReadCmd ftp://*,rcp://*,scp://*,http://*,dav://*,davs://*,rsync://*,sftp://* exe "silent doau BufReadPre ".fnameescape(expand("<amatch>"))|call netrw#Nread(2,expand("<amatch>"))|exe "silent doau BufReadPost ".fnameescape(expand("<amatch>")) + au FileReadCmd ftp://*,rcp://*,scp://*,http://*,dav://*,davs://*,rsync://*,sftp://* exe "silent doau FileReadPre ".fnameescape(expand("<amatch>"))|call netrw#Nread(1,expand("<amatch>"))|exe "silent doau FileReadPost ".fnameescape(expand("<amatch>")) + au BufWriteCmd ftp://*,rcp://*,scp://*,dav://*,davs://*,rsync://*,sftp://* exe "silent doau BufWritePre ".fnameescape(expand("<amatch>"))|exe 'Nwrite '.fnameescape(expand("<amatch>"))|exe "silent doau BufWritePost ".fnameescape(expand("<amatch>")) + au FileWriteCmd ftp://*,rcp://*,scp://*,dav://*,davs://*,rsync://*,sftp://* exe "silent doau FileWritePre ".fnameescape(expand("<amatch>"))|exe "'[,']".'Nwrite '.fnameescape(expand("<amatch>"))|exe "silent doau FileWritePost ".fnameescape(expand("<amatch>")) + try + au SourceCmd ftp://*,rcp://*,scp://*,http://*,dav://*,davs://*,rsync://*,sftp://* exe 'Nsource '.fnameescape(expand("<amatch>")) + catch /^Vim\%((\a\+)\)\=:E216/ + au SourcePre ftp://*,rcp://*,scp://*,http://*,dav://*,davs://*,rsync://*,sftp://* exe 'Nsource '.fnameescape(expand("<amatch>")) + endtry +augroup END + +" Commands: :Nread, :Nwrite, :NetUserPass {{{2 +com! -count=1 -nargs=* Nread call netrw#NetrwSavePosn()<bar>call netrw#NetRead(<count>,<f-args>)<bar>call netrw#NetrwRestorePosn() +com! -range=% -nargs=* Nwrite call netrw#NetrwSavePosn()<bar><line1>,<line2>call netrw#NetWrite(<f-args>)<bar>call netrw#NetrwRestorePosn() +com! -nargs=* NetUserPass call NetUserPass(<f-args>) +com! -nargs=* Nsource call netrw#NetrwSavePosn()<bar>call netrw#NetSource(<f-args>)<bar>call netrw#NetrwRestorePosn() + +" Commands: :Explore, :Sexplore, Hexplore, Vexplore {{{2 +com! -nargs=* -bar -bang -count=0 -complete=dir Explore call netrw#Explore(<count>,0,0+<bang>0,<q-args>) +com! -nargs=* -bar -bang -count=0 -complete=dir Sexplore call netrw#Explore(<count>,1,0+<bang>0,<q-args>) +com! -nargs=* -bar -bang -count=0 -complete=dir Hexplore call netrw#Explore(<count>,1,2+<bang>0,<q-args>) +com! -nargs=* -bar -bang -count=0 -complete=dir Vexplore call netrw#Explore(<count>,1,4+<bang>0,<q-args>) +com! -nargs=* -bar -count=0 -complete=dir Texplore call netrw#Explore(<count>,0,6 ,<q-args>) +com! -nargs=* -bar -bang Nexplore call netrw#Explore(-1,0,0,<q-args>) +com! -nargs=* -bar -bang Pexplore call netrw#Explore(-2,0,0,<q-args>) + +" Commands: NetrwSettings {{{2 +com! -nargs=0 NetrwSettings call netrwSettings#NetrwSettings() +com! -bang NetrwClean call netrw#NetrwClean(<bang>0) + +" Maps: +if !exists("g:netrw_nogx") && maparg('gx','n') == "" + if !hasmapto('<Plug>NetrwBrowseX') + nmap <unique> gx <Plug>NetrwBrowseX + endif + nno <silent> <Plug>NetrwBrowseX :call netrw#NetrwBrowseX(expand("<cWORD>"),0)<cr> +endif + +" --------------------------------------------------------------------- +" LocalBrowse: {{{2 +fun! s:LocalBrowse(dirname) + " unfortunate interaction -- debugging calls can't be used here; + " the BufEnter event causes triggering when attempts to write to + " the DBG buffer are made. +" echomsg "dirname<".a:dirname.">" + if has("amiga") + " The check against '' is made for the Amiga, where the empty + " string is the current directory and not checking would break + " things such as the help command. + if a:dirname != '' && isdirectory(a:dirname) + silent! call netrw#LocalBrowseCheck(a:dirname) + endif + elseif isdirectory(a:dirname) +" echomsg "dirname<".dirname."> isdir" + silent! call netrw#LocalBrowseCheck(a:dirname) + endif + " not a directory, ignore it +endfun + +" --------------------------------------------------------------------- +" s:VimEnter: {{{2 +fun! s:VimEnter(dirname) + let curwin= winnr() + windo if a:dirname != expand("%")|call s:LocalBrowse(expand("%:p"))|endif + exe curwin."wincmd w" +endfun + +" --------------------------------------------------------------------- +" NetrwStatusLine: {{{1 +fun! NetrwStatusLine() +" let g:stlmsg= "Xbufnr=".w:netrw_explore_bufnr." bufnr=".bufnr("%")." Xline#".w:netrw_explore_line." line#".line(".") + if !exists("w:netrw_explore_bufnr") || w:netrw_explore_bufnr != bufnr("%") || !exists("w:netrw_explore_line") || w:netrw_explore_line != line(".") || !exists("w:netrw_explore_list") + let &stl= s:netrw_explore_stl + if exists("w:netrw_explore_bufnr")|unlet w:netrw_explore_bufnr|endif + if exists("w:netrw_explore_line")|unlet w:netrw_explore_line|endif + return "" + else + return "Match ".w:netrw_explore_mtchcnt." of ".w:netrw_explore_listlen + endif +endfun + +" ------------------------------------------------------------------------ +" NetUserPass: set username and password for subsequent ftp transfer {{{1 +" Usage: :call NetUserPass() -- will prompt for userid and password +" :call NetUserPass("uid") -- will prompt for password +" :call NetUserPass("uid","password") -- sets global userid and password +fun! NetUserPass(...) + + " get/set userid + if a:0 == 0 +" call Dfunc("NetUserPass(a:0<".a:0.">)") + if !exists("g:netrw_uid") || g:netrw_uid == "" + " via prompt + let g:netrw_uid= input('Enter username: ') + endif + else " from command line +" call Dfunc("NetUserPass(a:1<".a:1.">) {") + let g:netrw_uid= a:1 + endif + + " get password + if a:0 <= 1 " via prompt +" call Decho("a:0=".a:0." case <=1:") + let g:netrw_passwd= inputsecret("Enter Password: ") + else " from command line +" call Decho("a:0=".a:0." case >1: a:2<".a:2.">") + let g:netrw_passwd=a:2 + endif +" call Dret("NetUserPass") +endfun + +" ------------------------------------------------------------------------ +" Modelines And Restoration: {{{1 +let &cpo= s:keepcpo +unlet s:keepcpo +" vim:ts=8 fdm=marker diff --git a/share/vim/vim73/plugin/rrhelper.vim b/share/vim/vim73/plugin/rrhelper.vim new file mode 100644 index 0000000000..b09cbc10b9 --- /dev/null +++ b/share/vim/vim73/plugin/rrhelper.vim @@ -0,0 +1,48 @@ +" Vim plugin with helper function(s) for --remote-wait +" Maintainer: Flemming Madsen <fma@cci.dk> +" Last Change: 2008 May 29 + +" Has this already been loaded? +if exists("loaded_rrhelper") || !has("clientserver") + finish +endif +let loaded_rrhelper = 1 + +" Setup answers for a --remote-wait client who will assume +" a SetupRemoteReplies() function in the command server + +function SetupRemoteReplies() + let cnt = 0 + let max = argc() + + let id = expand("<client>") + if id == 0 + return + endif + while cnt < max + " Handle same file from more clients and file being more than once + " on the command line by encoding this stuff in the group name + let uniqueGroup = "RemoteReply_".id."_".cnt + + " Path separators are always forward slashes for the autocommand pattern. + " Escape special characters with a backslash. + let f = substitute(argv(cnt), '\\', '/', "g") + if exists('*fnameescape') + let f = fnameescape(f) + else + let f = escape(f, " \t\n*?[{`$\\%#'\"|!<") + endif + execute "augroup ".uniqueGroup + execute "autocmd ".uniqueGroup." BufUnload ". f ." call DoRemoteReply('".id."', '".cnt."', '".uniqueGroup."', '". f ."')" + let cnt = cnt + 1 + endwhile + augroup END +endfunc + +function DoRemoteReply(id, cnt, group, file) + call server2client(a:id, a:cnt) + execute 'autocmd! '.a:group.' BufUnload '.a:file + execute 'augroup! '.a:group +endfunc + +" vim: set sw=2 sts=2 : diff --git a/share/vim/vim72/plugin/spellfile.vim b/share/vim/vim73/plugin/spellfile.vim similarity index 100% rename from share/vim/vim72/plugin/spellfile.vim rename to share/vim/vim73/plugin/spellfile.vim diff --git a/share/vim/vim73/plugin/tarPlugin.vim b/share/vim/vim73/plugin/tarPlugin.vim new file mode 100644 index 0000000000..b0a4d0b239 --- /dev/null +++ b/share/vim/vim73/plugin/tarPlugin.vim @@ -0,0 +1,53 @@ +" tarPlugin.vim -- a Vim plugin for browsing tarfiles +" Original was copyright (c) 2002, Michael C. Toren <mct@toren.net> +" Modified by Charles E. Campbell, Jr. +" Distributed under the GNU General Public License. +" +" Updates are available from <http://michael.toren.net/code/>. If you +" find this script useful, or have suggestions for improvements, please +" let me know. +" Also look there for further comments and documentation. +" +" This part only sets the autocommands. The functions are in autoload/tar.vim. +" --------------------------------------------------------------------- +" Load Once: {{{1 +if &cp || exists("g:loaded_tarPlugin") + finish +endif +let g:loaded_tarPlugin = "v26" +let s:keepcpo = &cpo +set cpo&vim + +" --------------------------------------------------------------------- +" Public Interface: {{{1 +augroup tar + au! + au BufReadCmd tarfile::* call tar#Read(expand("<amatch>"), 1) + au FileReadCmd tarfile::* call tar#Read(expand("<amatch>"), 0) + au BufWriteCmd tarfile::* call tar#Write(expand("<amatch>")) + au FileWriteCmd tarfile::* call tar#Write(expand("<amatch>")) + + if has("unix") + au BufReadCmd tarfile::*/* call tar#Read(expand("<amatch>"), 1) + au FileReadCmd tarfile::*/* call tar#Read(expand("<amatch>"), 0) + au BufWriteCmd tarfile::*/* call tar#Write(expand("<amatch>")) + au FileWriteCmd tarfile::*/* call tar#Write(expand("<amatch>")) + endif + + au BufReadCmd *.tar.gz call tar#Browse(expand("<amatch>")) + au BufReadCmd *.tar call tar#Browse(expand("<amatch>")) + au BufReadCmd *.lrp call tar#Browse(expand("<amatch>")) + au BufReadCmd *.tar.bz2 call tar#Browse(expand("<amatch>")) + au BufReadCmd *.tar.Z call tar#Browse(expand("<amatch>")) + au BufReadCmd *.tgz call tar#Browse(expand("<amatch>")) + au BufReadCmd *.tar.lzma call tar#Browse(expand("<amatch>")) + au BufReadCmd *.tar.xz call tar#Browse(expand("<amatch>")) + au BufReadCmd *.txz call tar#Browse(expand("<amatch>")) +augroup END +com! -nargs=? -complete=file Vimuntar call tar#Vimuntar(<q-args>) + +" --------------------------------------------------------------------- +" Restoration And Modelines: {{{1 +" vim: fdm=marker +let &cpo= s:keepcpo +unlet s:keepcpo diff --git a/share/vim/vim73/plugin/tohtml.vim b/share/vim/vim73/plugin/tohtml.vim new file mode 100644 index 0000000000..36b1f76085 --- /dev/null +++ b/share/vim/vim73/plugin/tohtml.vim @@ -0,0 +1,31 @@ +" Vim plugin for converting a syntax highlighted file to HTML. +" Maintainer: Ben Fritz <fritzophrenic@gmail.com> +" Last Change: 2010 Aug 12 +" +" The core of the code is in $VIMRUNTIME/autoload/tohtml.vim and +" $VIMRUNTIME/syntax/2html.vim +" +" TODO: +" * Restore open/closed folds and cursor position after processing each file +" with option not to restore for speed increase +" * Add extra meta info (generation time, etc.) +" * Tidy up so we can use strict doctype more? +" * Implementation detail: add threshold for writing the lines to the html +" buffer before we're done (5000 or so lines should do it) +" * TODO comments for code cleanup scattered throughout + +if exists('g:loaded_2html_plugin') + finish +endif +let g:loaded_2html_plugin = 'vim7.3_v6' + +" Define the :TOhtml command when: +" - 'compatible' is not set +" - this plugin was not already loaded +" - user commands are available. +if !&cp && !exists(":TOhtml") && has("user_commands") + command -range=% TOhtml :call tohtml#Convert2HTML(<line1>, <line2>) +endif + +" Make sure any patches will probably use consistent indent +" vim: ts=8 sw=2 sts=2 noet diff --git a/share/vim/vim73/plugin/vimballPlugin.vim b/share/vim/vim73/plugin/vimballPlugin.vim new file mode 100644 index 0000000000..c5acc7c4df --- /dev/null +++ b/share/vim/vim73/plugin/vimballPlugin.vim @@ -0,0 +1,36 @@ +" vimballPlugin : construct a file containing both paths and files +" Author: Charles E. Campbell, Jr. +" Copyright: (c) 2004-2010 by Charles E. Campbell, Jr. +" The VIM LICENSE applies to Vimball.vim, and Vimball.txt +" (see |copyright|) except use "Vimball" instead of "Vim". +" No warranty, express or implied. +" *** *** Use At-Your-Own-Risk! *** *** +" +" (Rom 2:1 WEB) Therefore you are without excuse, O man, whoever you are who +" judge. For in that which you judge another, you condemn yourself. For +" you who judge practice the same things. +" GetLatestVimScripts: 1502 1 :AutoInstall: vimball.vim + +" --------------------------------------------------------------------- +" Load Once: {{{1 +if &cp || exists("g:loaded_vimballPlugin") + finish +endif +let g:loaded_vimballPlugin = "v31" +let s:keepcpo = &cpo +set cpo&vim + +" ------------------------------------------------------------------------------ +" Public Interface: {{{1 +com! -ra -complete=file -na=+ -bang MkVimball call vimball#MkVimball(<line1>,<line2>,<bang>0,<f-args>) +com! -na=? -complete=dir UseVimball call vimball#Vimball(1,<f-args>) +com! -na=0 VimballList call vimball#Vimball(0) +com! -na=* -complete=dir RmVimball call vimball#SaveSettings()|call vimball#RmVimball(<f-args>)|call vimball#RestoreSettings() +au SourceCmd *.vba.gz,*.vba.bz2,*.vba.zip call vimball#Decompress(expand("<amatch>"))|call vimball#Vimball(1) +au BufEnter *.vba,*.vba.gz,*.vba.bz2,*.vba.zip setlocal bt=nofile fmr=[[[,]]] fdm=marker|if &ff != 'unix'| setlocal ma ff=unix noma |endif|call vimball#ShowMesg(0,"Source this file to extract it! (:so %)") + +" ===================================================================== +" Restoration And Modelines: {{{1 +" vim: fdm=marker +let &cpo= s:keepcpo +unlet s:keepcpo diff --git a/share/vim/vim73/plugin/zipPlugin.vim b/share/vim/vim73/plugin/zipPlugin.vim new file mode 100644 index 0000000000..ff3825e9ae --- /dev/null +++ b/share/vim/vim73/plugin/zipPlugin.vim @@ -0,0 +1,50 @@ +" zipPlugin.vim: Handles browsing zipfiles +" PLUGIN PORTION +" Date: Oct 05, 2007 +" Maintainer: Charles E Campbell, Jr <NdrOchip@ScampbellPfamily.AbizM-NOSPAM> +" License: Vim License (see vim's :help license) +" Copyright: Copyright (C) 2005,2006 Charles E. Campbell, Jr. {{{1 +" Permission is hereby granted to use and distribute this code, +" with or without modifications, provided that this copyright +" notice is copied with it. Like anything else that's free, +" zipPlugin.vim is provided *as is* and comes with no warranty +" of any kind, either expressed or implied. By using this +" plugin, you agree that in no event will the copyright +" holder be liable for any damages resulting from the use +" of this software. +" +" (James 4:8 WEB) Draw near to God, and he will draw near to you. +" Cleanse your hands, you sinners; and purify your hearts, you double-minded. +" --------------------------------------------------------------------- +" Load Once: {{{1 +if &cp || exists("g:loaded_zipPlugin") + finish +endif +let g:loaded_zipPlugin = "v23" +let s:keepcpo = &cpo +set cpo&vim + +" --------------------------------------------------------------------- +" Public Interface: {{{1 +augroup zip + au! + au BufReadCmd zipfile:* call zip#Read(expand("<amatch>"), 1) + au FileReadCmd zipfile:* call zip#Read(expand("<amatch>"), 0) + au BufWriteCmd zipfile:* call zip#Write(expand("<amatch>")) + au FileWriteCmd zipfile:* call zip#Write(expand("<amatch>")) + + if has("unix") + au BufReadCmd zipfile:*/* call zip#Read(expand("<amatch>"), 1) + au FileReadCmd zipfile:*/* call zip#Read(expand("<amatch>"), 0) + au BufWriteCmd zipfile:*/* call zip#Write(expand("<amatch>")) + au FileWriteCmd zipfile:*/* call zip#Write(expand("<amatch>")) + endif + + au BufReadCmd *.zip,*.jar,*.xpi,*.war,*.ear call zip#Browse(expand("<amatch>")) +augroup END + +" --------------------------------------------------------------------- +" Restoration And Modelines: {{{1 +" vim: fdm=marker +let &cpo= s:keepcpo +unlet s:keepcpo diff --git a/share/vim/vim72/print/ascii.ps b/share/vim/vim73/print/ascii.ps similarity index 100% rename from share/vim/vim72/print/ascii.ps rename to share/vim/vim73/print/ascii.ps diff --git a/share/vim/vim72/print/cidfont.ps b/share/vim/vim73/print/cidfont.ps similarity index 100% rename from share/vim/vim72/print/cidfont.ps rename to share/vim/vim73/print/cidfont.ps diff --git a/share/vim/vim72/print/cns_roman.ps b/share/vim/vim73/print/cns_roman.ps similarity index 100% rename from share/vim/vim72/print/cns_roman.ps rename to share/vim/vim73/print/cns_roman.ps diff --git a/share/vim/vim72/print/cp1250.ps b/share/vim/vim73/print/cp1250.ps similarity index 100% rename from share/vim/vim72/print/cp1250.ps rename to share/vim/vim73/print/cp1250.ps diff --git a/share/vim/vim72/print/cp1251.ps b/share/vim/vim73/print/cp1251.ps similarity index 100% rename from share/vim/vim72/print/cp1251.ps rename to share/vim/vim73/print/cp1251.ps diff --git a/share/vim/vim72/print/cp1252.ps b/share/vim/vim73/print/cp1252.ps similarity index 100% rename from share/vim/vim72/print/cp1252.ps rename to share/vim/vim73/print/cp1252.ps diff --git a/share/vim/vim72/print/cp1253.ps b/share/vim/vim73/print/cp1253.ps similarity index 100% rename from share/vim/vim72/print/cp1253.ps rename to share/vim/vim73/print/cp1253.ps diff --git a/share/vim/vim72/print/cp1254.ps b/share/vim/vim73/print/cp1254.ps similarity index 100% rename from share/vim/vim72/print/cp1254.ps rename to share/vim/vim73/print/cp1254.ps diff --git a/share/vim/vim72/print/cp1255.ps b/share/vim/vim73/print/cp1255.ps similarity index 100% rename from share/vim/vim72/print/cp1255.ps rename to share/vim/vim73/print/cp1255.ps diff --git a/share/vim/vim72/print/cp1257.ps b/share/vim/vim73/print/cp1257.ps similarity index 100% rename from share/vim/vim72/print/cp1257.ps rename to share/vim/vim73/print/cp1257.ps diff --git a/share/vim/vim72/print/dec-mcs.ps b/share/vim/vim73/print/dec-mcs.ps similarity index 100% rename from share/vim/vim72/print/dec-mcs.ps rename to share/vim/vim73/print/dec-mcs.ps diff --git a/share/vim/vim72/print/ebcdic-uk.ps b/share/vim/vim73/print/ebcdic-uk.ps similarity index 100% rename from share/vim/vim72/print/ebcdic-uk.ps rename to share/vim/vim73/print/ebcdic-uk.ps diff --git a/share/vim/vim72/print/gb_roman.ps b/share/vim/vim73/print/gb_roman.ps similarity index 100% rename from share/vim/vim72/print/gb_roman.ps rename to share/vim/vim73/print/gb_roman.ps diff --git a/share/vim/vim72/print/hp-roman8.ps b/share/vim/vim73/print/hp-roman8.ps similarity index 100% rename from share/vim/vim72/print/hp-roman8.ps rename to share/vim/vim73/print/hp-roman8.ps diff --git a/share/vim/vim72/print/iso-8859-10.ps b/share/vim/vim73/print/iso-8859-10.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-10.ps rename to share/vim/vim73/print/iso-8859-10.ps diff --git a/share/vim/vim72/print/iso-8859-11.ps b/share/vim/vim73/print/iso-8859-11.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-11.ps rename to share/vim/vim73/print/iso-8859-11.ps diff --git a/share/vim/vim72/print/iso-8859-13.ps b/share/vim/vim73/print/iso-8859-13.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-13.ps rename to share/vim/vim73/print/iso-8859-13.ps diff --git a/share/vim/vim72/print/iso-8859-14.ps b/share/vim/vim73/print/iso-8859-14.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-14.ps rename to share/vim/vim73/print/iso-8859-14.ps diff --git a/share/vim/vim72/print/iso-8859-15.ps b/share/vim/vim73/print/iso-8859-15.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-15.ps rename to share/vim/vim73/print/iso-8859-15.ps diff --git a/share/vim/vim72/print/iso-8859-2.ps b/share/vim/vim73/print/iso-8859-2.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-2.ps rename to share/vim/vim73/print/iso-8859-2.ps diff --git a/share/vim/vim72/print/iso-8859-3.ps b/share/vim/vim73/print/iso-8859-3.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-3.ps rename to share/vim/vim73/print/iso-8859-3.ps diff --git a/share/vim/vim72/print/iso-8859-4.ps b/share/vim/vim73/print/iso-8859-4.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-4.ps rename to share/vim/vim73/print/iso-8859-4.ps diff --git a/share/vim/vim72/print/iso-8859-5.ps b/share/vim/vim73/print/iso-8859-5.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-5.ps rename to share/vim/vim73/print/iso-8859-5.ps diff --git a/share/vim/vim72/print/iso-8859-7.ps b/share/vim/vim73/print/iso-8859-7.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-7.ps rename to share/vim/vim73/print/iso-8859-7.ps diff --git a/share/vim/vim72/print/iso-8859-8.ps b/share/vim/vim73/print/iso-8859-8.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-8.ps rename to share/vim/vim73/print/iso-8859-8.ps diff --git a/share/vim/vim72/print/iso-8859-9.ps b/share/vim/vim73/print/iso-8859-9.ps similarity index 100% rename from share/vim/vim72/print/iso-8859-9.ps rename to share/vim/vim73/print/iso-8859-9.ps diff --git a/share/vim/vim72/print/jis_roman.ps b/share/vim/vim73/print/jis_roman.ps similarity index 100% rename from share/vim/vim72/print/jis_roman.ps rename to share/vim/vim73/print/jis_roman.ps diff --git a/share/vim/vim72/print/koi8-r.ps b/share/vim/vim73/print/koi8-r.ps similarity index 100% rename from share/vim/vim72/print/koi8-r.ps rename to share/vim/vim73/print/koi8-r.ps diff --git a/share/vim/vim72/print/koi8-u.ps b/share/vim/vim73/print/koi8-u.ps similarity index 100% rename from share/vim/vim72/print/koi8-u.ps rename to share/vim/vim73/print/koi8-u.ps diff --git a/share/vim/vim72/print/ks_roman.ps b/share/vim/vim73/print/ks_roman.ps similarity index 100% rename from share/vim/vim72/print/ks_roman.ps rename to share/vim/vim73/print/ks_roman.ps diff --git a/share/vim/vim72/print/latin1.ps b/share/vim/vim73/print/latin1.ps similarity index 100% rename from share/vim/vim72/print/latin1.ps rename to share/vim/vim73/print/latin1.ps diff --git a/share/vim/vim72/print/mac-roman.ps b/share/vim/vim73/print/mac-roman.ps similarity index 100% rename from share/vim/vim72/print/mac-roman.ps rename to share/vim/vim73/print/mac-roman.ps diff --git a/share/vim/vim72/print/prolog.ps b/share/vim/vim73/print/prolog.ps similarity index 100% rename from share/vim/vim72/print/prolog.ps rename to share/vim/vim73/print/prolog.ps diff --git a/share/vim/vim72/rgb.txt b/share/vim/vim73/rgb.txt similarity index 100% rename from share/vim/vim72/rgb.txt rename to share/vim/vim73/rgb.txt diff --git a/share/vim/vim73/scripts.vim b/share/vim/vim73/scripts.vim new file mode 100644 index 0000000000..e30b5c43fb --- /dev/null +++ b/share/vim/vim73/scripts.vim @@ -0,0 +1,360 @@ +" Vim support file to detect file types in scripts +" +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last change: 2010 Jul 29 + +" This file is called by an autocommand for every file that has just been +" loaded into a buffer. It checks if the type of file can be recognized by +" the file contents. The autocommand is in $VIMRUNTIME/filetype.vim. + + +" Only do the rest when the FileType autocommand has not been triggered yet. +if did_filetype() + finish +endif + +" Load the user defined scripts file first +" Only do this when the FileType autocommand has not been triggered yet +if exists("myscriptsfile") && filereadable(expand(myscriptsfile)) + execute "source " . myscriptsfile + if did_filetype() + finish + endif +endif + +" Line continuation is used here, remove 'C' from 'cpoptions' +let s:cpo_save = &cpo +set cpo&vim + +let s:line1 = getline(1) + +if s:line1 =~ "^#!" + " A script that starts with "#!". + + " Check for a line like "#!/usr/bin/env VAR=val bash". Turn it into + " "#!/usr/bin/bash" to make matching easier. + if s:line1 =~ '^#!\s*\S*\<env\s' + let s:line1 = substitute(s:line1, '\S\+=\S\+', '', 'g') + let s:line1 = substitute(s:line1, '\<env\s\+', '', '') + endif + + " Get the program name. + " Only accept spaces in PC style paths: "#!c:/program files/perl [args]". + " If the word env is used, use the first word after the space: + " "#!/usr/bin/env perl [path/args]" + " If there is no path use the first word: "#!perl [path/args]". + " Otherwise get the last word after a slash: "#!/usr/bin/perl [path/args]". + if s:line1 =~ '^#!\s*\a:[/\\]' + let s:name = substitute(s:line1, '^#!.*[/\\]\(\i\+\).*', '\1', '') + elseif s:line1 =~ '^#!.*\<env\>' + let s:name = substitute(s:line1, '^#!.*\<env\>\s\+\(\i\+\).*', '\1', '') + elseif s:line1 =~ '^#!\s*[^/\\ ]*\>\([^/\\]\|$\)' + let s:name = substitute(s:line1, '^#!\s*\([^/\\ ]*\>\).*', '\1', '') + else + let s:name = substitute(s:line1, '^#!\s*\S*[/\\]\(\i\+\).*', '\1', '') + endif + + " tcl scripts may have #!/bin/sh in the first line and "exec wish" in the + " third line. Suggested by Steven Atkinson. + if getline(3) =~ '^exec wish' + let s:name = 'wish' + endif + + " Bourne-like shell scripts: bash bash2 ksh ksh93 sh + if s:name =~ '^\(bash\d*\|\|ksh\d*\|sh\)\>' + call SetFileTypeSH(s:line1) " defined in filetype.vim + + " csh scripts + elseif s:name =~ '^csh\>' + if exists("g:filetype_csh") + call SetFileTypeShell(g:filetype_csh) + else + call SetFileTypeShell("csh") + endif + + " tcsh scripts + elseif s:name =~ '^tcsh\>' + call SetFileTypeShell("tcsh") + + " Z shell scripts + elseif s:name =~ '^zsh\>' + set ft=zsh + + " TCL scripts + elseif s:name =~ '^\(tclsh\|wish\|expectk\|itclsh\|itkwish\)\>' + set ft=tcl + + " Expect scripts + elseif s:name =~ '^expect\>' + set ft=expect + + " Gnuplot scripts + elseif s:name =~ '^gnuplot\>' + set ft=gnuplot + + " Makefiles + elseif s:name =~ 'make\>' + set ft=make + + " Lua + elseif s:name =~ 'lua' + set ft=lua + + " Perl 6 + elseif s:name =~ 'perl6' + set ft=perl6 + + " Perl + elseif s:name =~ 'perl' + set ft=perl + + " PHP + elseif s:name =~ 'php' + set ft=php + + " Python + elseif s:name =~ 'python' + set ft=python + + " Groovy + elseif s:name =~ '^groovy\>' + set ft=groovy + + " Ruby + elseif s:name =~ 'ruby' + set ft=ruby + + " BC calculator + elseif s:name =~ '^bc\>' + set ft=bc + + " sed + elseif s:name =~ 'sed\>' + set ft=sed + + " OCaml-scripts + elseif s:name =~ 'ocaml' + set ft=ocaml + + " Awk scripts + elseif s:name =~ 'awk\>' + set ft=awk + + " Website MetaLanguage + elseif s:name =~ 'wml' + set ft=wml + + " Scheme scripts + elseif s:name =~ 'scheme' + set ft=scheme + + " CFEngine scripts + elseif s:name =~ 'cfengine' + set ft=cfengine + + endif + unlet s:name + +else + " File does not start with "#!". + + let s:line2 = getline(2) + let s:line3 = getline(3) + let s:line4 = getline(4) + let s:line5 = getline(5) + + " Bourne-like shell scripts: sh ksh bash bash2 + if s:line1 =~ '^:$' + call SetFileTypeSH(s:line1) " defined in filetype.vim + + " Z shell scripts + elseif s:line1 =~ '^#compdef\>' || s:line1 =~ '^#autoload\>' + set ft=zsh + + " ELM Mail files + elseif s:line1 =~ '^From \([a-zA-Z][a-zA-Z_0-9\.=-]*\(@[^ ]*\)\=\|-\) .* \(19\|20\)\d\d$' + set ft=mail + + " Mason + elseif s:line1 =~ '^<[%&].*>' + set ft=mason + + " Vim scripts (must have '" vim' as the first line to trigger this) + elseif s:line1 =~ '^" *[vV]im$' + set ft=vim + + " MOO + elseif s:line1 =~ '^\*\* LambdaMOO Database, Format Version \%([1-3]\>\)\@!\d\+ \*\*$' + set ft=moo + + " Diff file: + " - "diff" in first line (context diff) + " - "Only in " in first line + " - "--- " in first line and "+++ " in second line (unified diff). + " - "*** " in first line and "--- " in second line (context diff). + " - "# It was generated by makepatch " in the second line (makepatch diff). + " - "Index: <filename>" in the first line (CVS file) + " - "=== ", line of "=", "---", "+++ " (SVK diff) + " - "=== ", "--- ", "+++ " (bzr diff, common case) + " - "=== (removed|added|renamed|modified)" (bzr diff, alternative) + elseif s:line1 =~ '^\(diff\>\|Only in \|\d\+\(,\d\+\)\=[cda]\d\+\>\|# It was generated by makepatch \|Index:\s\+\f\+\r\=$\|===== \f\+ \d\+\.\d\+ vs edited\|==== //\f\+#\d\+\)' + \ || (s:line1 =~ '^--- ' && s:line2 =~ '^+++ ') + \ || (s:line1 =~ '^\* looking for ' && s:line2 =~ '^\* comparing to ') + \ || (s:line1 =~ '^\*\*\* ' && s:line2 =~ '^--- ') + \ || (s:line1 =~ '^=== ' && ((s:line2 =~ '^=\{66\}' && s:line3 =~ '^--- ' && s:line4 =~ '^+++') || (s:line2 =~ '^--- ' && s:line3 =~ '^+++ '))) + \ || (s:line1 =~ '^=== \(removed\|added\|renamed\|modified\)') + set ft=diff + + " PostScript Files (must have %!PS as the first line, like a2ps output) + elseif s:line1 =~ '^%![ \t]*PS' + set ft=postscr + + " M4 scripts: Guess there is a line that starts with "dnl". + elseif s:line1 =~ '^\s*dnl\>' + \ || s:line2 =~ '^\s*dnl\>' + \ || s:line3 =~ '^\s*dnl\>' + \ || s:line4 =~ '^\s*dnl\>' + \ || s:line5 =~ '^\s*dnl\>' + set ft=m4 + + " AmigaDos scripts + elseif $TERM == "amiga" + \ && (s:line1 =~ "^;" || s:line1 =~ '^\.[bB][rR][aA]') + set ft=amiga + + " SiCAD scripts (must have procn or procd as the first line to trigger this) + elseif s:line1 =~? '^ *proc[nd] *$' + set ft=sicad + + " Purify log files start with "**** Purify" + elseif s:line1 =~ '^\*\*\*\* Purify' + set ft=purifylog + + " XML + elseif s:line1 =~ '<?\s*xml.*?>' + set ft=xml + + " XHTML (e.g.: PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN") + elseif s:line1 =~ '\<DTD\s\+XHTML\s' + set ft=xhtml + + " HTML (e.g.: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN") + elseif s:line1 =~? '\<DOCTYPE\s\+html\>' + set ft=html + + " PDF + elseif s:line1 =~ '^%PDF-' + set ft=pdf + + " XXD output + elseif s:line1 =~ '^\x\{7}: \x\{2} \=\x\{2} \=\x\{2} \=\x\{2} ' + set ft=xxd + + " RCS/CVS log output + elseif s:line1 =~ '^RCS file:' || s:line2 =~ '^RCS file:' + set ft=rcslog + + " CVS commit + elseif s:line2 =~ '^CVS:' || getline("$") =~ '^CVS: ' + set ft=cvs + + " Prescribe + elseif s:line1 =~ '^!R!' + set ft=prescribe + + " Send-pr + elseif s:line1 =~ '^SEND-PR:' + set ft=sendpr + + " SNNS files + elseif s:line1 =~ '^SNNS network definition file' + set ft=snnsnet + elseif s:line1 =~ '^SNNS pattern definition file' + set ft=snnspat + elseif s:line1 =~ '^SNNS result file' + set ft=snnsres + + " Virata + elseif s:line1 =~ '^%.\{-}[Vv]irata' + \ || s:line2 =~ '^%.\{-}[Vv]irata' + \ || s:line3 =~ '^%.\{-}[Vv]irata' + \ || s:line4 =~ '^%.\{-}[Vv]irata' + \ || s:line5 =~ '^%.\{-}[Vv]irata' + set ft=virata + + " Strace + elseif s:line1 =~ '^\(\[pid \d\+\] \)\=[0-9:.]* *execve(' || s:line1 =~ '^__libc_start_main' + set ft=strace + + " VSE JCL + elseif s:line1 =~ '^\* $$ JOB\>' || s:line1 =~ '^// *JOB\>' + set ft=vsejcl + + " TAK and SINDA + elseif s:line4 =~ 'K & K Associates' || s:line2 =~ 'TAK 2000' + set ft=takout + elseif s:line3 =~ 'S Y S T E M S I M P R O V E D ' + set ft=sindaout + elseif getline(6) =~ 'Run Date: ' + set ft=takcmp + elseif getline(9) =~ 'Node File 1' + set ft=sindacmp + + " DNS zone files + elseif s:line1.s:line2.s:line3.s:line4 =~ '^; <<>> DiG [0-9.]\+ <<>>\|BIND.*named\|$ORIGIN\|$TTL\|IN\s\+SOA' + set ft=bindzone + + " BAAN + elseif s:line1 =~ '|\*\{1,80}' && s:line2 =~ 'VRC ' + \ || s:line2 =~ '|\*\{1,80}' && s:line3 =~ 'VRC ' + set ft=baan + + " Valgrind + elseif s:line1 =~ '^==\d\+== valgrind' || s:line3 =~ '^==\d\+== Using valgrind' + set ft=valgrind + + " Renderman Interface Bytestream + elseif s:line1 =~ '^##RenderMan' + set ft=rib + + " Scheme scripts + elseif s:line1 =~ 'exec\s\+\S*scheme' || s:line2 =~ 'exec\s\+\S*scheme' + set ft=scheme + + " Git output + elseif s:line1 =~ '^\(commit\|tree\|object\) \x\{40\}\>\|^tag \S\+$' + set ft=git + + " CVS diff + else + let s:lnum = 1 + while getline(s:lnum) =~ "^? " && s:lnum < line("$") + let s:lnum += 1 + endwhile + if getline(s:lnum) =~ '^Index:\s\+\f\+$' + set ft=diff + + " locale input files: Formal Definitions of Cultural Conventions + " filename must be like en_US, fr_FR@euro or en_US.UTF-8 + elseif expand("%") =~ '\a\a_\a\a\($\|[.@]\)\|i18n$\|POSIX$\|translit_' + let s:lnum = 1 + while s:lnum < 100 && s:lnum < line("$") + if getline(s:lnum) =~ '^LC_\(IDENTIFICATION\|CTYPE\|COLLATE\|MONETARY\|NUMERIC\|TIME\|MESSAGES\|PAPER\|TELEPHONE\|MEASUREMENT\|NAME\|ADDRESS\)$' + setf fdcc + break + endif + let s:lnum += 1 + endwhile + endif + unlet s:lnum + + endif + + unlet s:line2 s:line3 s:line4 s:line5 + +endif + +" Restore 'cpoptions' +let &cpo = s:cpo_save + +unlet s:cpo_save s:line1 diff --git a/share/vim/vim73/spell/README.txt b/share/vim/vim73/spell/README.txt new file mode 100644 index 0000000000..d427a3c152 --- /dev/null +++ b/share/vim/vim73/spell/README.txt @@ -0,0 +1,112 @@ +The spell files included here are in Vim's special format. You can't edit +them. See ":help spell" for more information. + + +COPYRIGHT + +The files used as input for the spell files come from the OpenOffice.org spell +files. Most of them go under the LGPL or a similar license. + +Copyright notices for specific languages are in README_??.txt. Note that the +files for different regions are merged, both to save space and to make it +possible to highlight words for another region different from bad words. + +Most of the soundslike mappings come from Aspell ??_phonet.dat files: +ftp://ftp.gnu.org/gnu/aspell/dict/. Most go under the GPL or LGPL copyright. + + +GENERATING .SPL FILES + +This involves downloading the files from the OpenOffice.org server, applying a +patch and running Vim to generate the .spl file. To do this all in one go use +the Aap program (www.a-a-p.org). It's simple to install, it only requires +Python. + +Before generating spell files, verify your system has the required locale +support. Source the check_locales.vim script to find out. If something is +missing, see LOCALE below. + + +You can also do it manually: +1. Fetch the right spell file from: + http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries + +2. Unzip the archive: + unzip LL_RR.zip + +3. Apply the patch: + patch < LL_RR.diff + +4. If the language has multiple regions do the above for each region. E.g., + for English there are five regions: US, CA, AU, NZ and GB. + +5. Run Vim and execute ":mkspell". Make sure you do this with the correct + locale, that influences the upper/lower case letters and word characters. + On Unix it's something like: + env LANG=en_US.UTF-8 vim + mkspell! en en_US en_AU en_CA en_GB en_NZ + +6. Repeat step 5 for other locales. For English you could generate a spell + file for latin1, utf-8 and ASCII. ASCII only makes sense for languages + that have very few words with non-ASCII letters. + +Now you understand why I prefer using the Aap recipe :-). + + +MAINTAINING A LANGUAGE + +Every language should have a maintainer. His tasks are to track the changes +in the OpenOffice.org spell files and make updated patches. Words that +haven't been added/removed from the OpenOffice lists can also be handled by +the patches. + +It is important to keep the version of the .dic and .aff files that you +started with. When OpenOffice brings out new versions of these files you can +find out what changed and take over these changes in your patch. When there +are very many changes you can do it the other way around: re-apply the changes +for Vim to the new versions of the .dic and .aff files. + +This procedure should work well: + +1. Obtain the zip archive with the .aff and .dic files. Unpack it as + explained above and copy (don't rename!) the .aff and .dic files to + .orig.aff and .orig.dic. Using the Aap recipe should work, it will make + the copies for you. + +2. Tweak the .aff and .dic files to generate the perfect .spl file. Don't + change too much, the OpenOffice people are not stupid. However, you may + want to remove obvious mistakes. And remove single-letter words that + aren't really words, they mess up the suggestions (English has this + problem). You can use the "fixdup.vim" Vim script to find duplicate words. + +3. Make the diff file. "aap diff" will do this for you. If a diff would be + too big you might consider writing a Vim script to do systematic changes. + Do check that someone else can reproduce building the spell file. Send the + result to Bram for inclusion in the distribution. Bram will generate the + .spl file and upload it to the ftp server (if he can't generate it you will + have to send him the .spl file too). + +4. When OpenOffice makes a new zip file available you need to update the + patch. "aap check" should do most of the work for you: if there are + changes the .new.dic and .new.aff files will appear. You can now figure + out the differences with .orig.dic and .orig.aff, adjust the .dic and .aff + files and finally move the .new.dic to .orig.dic and .new.aff to .orig.aff. + +5. Repeat step 4. regularly. + + +LOCALE + +For proper spell file generation the required locale must be installed. +Otherwise Vim doesn't know what are letters and upper-lower case differences. +Modern systems use UTF-8, but we also generate spell files for 8-bit locales +for users with older systems. + +On Ubuntu the default is to only support locales for your own language. To +add others you need to do this: + sudo vim /var/lib/locales/supported.d/local + Add needed lines from /usr/share/i18n/SUPPORTED + sudo dpkg-reconfigure locales + +When using the check_locales.vim script, you need to exit Vim and restart it +to pickup the newly installed locales. diff --git a/share/vim/vim73/spell/README_en.txt b/share/vim/vim73/spell/README_en.txt new file mode 100644 index 0000000000..52c27440d0 --- /dev/null +++ b/share/vim/vim73/spell/README_en.txt @@ -0,0 +1,913 @@ +en_US +20040623 release. +-- +This dictionary is based on a subset of the original +English wordlist created by Kevin Atkinson for Pspell +and Aspell and thus is covered by his original +LGPL license. The affix file is a heavily modified +version of the original english.aff file which was +released as part of Geoff Kuenning's Ispell and as +such is covered by his BSD license. + +Thanks to both authors for there wonderful work. + + +=================================================== +en_AU: +This dictionary was based on the en_GB Myspell dictionary +which in turn was initially based on a subset of the +original English wordlist created by Kevin Atkinson for +Pspell and Aspell and thus is covered by his original +LGPL licence. + +The credit for this en_AU dictionary goes to: + +Kelvin Eldridge (maintainer) +Jean Hollis Weber +David Wilson + +- Words incorrect in Australian English removed +- a list from the previously removed words with corrected spelling was added +- a list of major rivers was added +- a list of place names was added +- a list of Australian mammals was added +- a list of Aboriginal/Koori words commonly used was added + +A total of 119,267 words are now recognized +by the dictionary. + +Of course, special thanks go to the editors of the +en_GB dictionary (David Bartlett, Brian Kelk and +Andrew Brown) which provided the starting point +for this dictionary. + +The affix file is currently a duplicate of the en_AU.aff +created completely from scratch by David Bartlett and +Andrew Brown, based on the published +rules for MySpell and is also provided under the LGPL. + +If you find omissions or bugs or have new words to +add to the dictionary, please contact the en_AU +maintainer at: + + "Kelvin" <audictionary@onlineconnections.com.au> + + + +=================================================== +en_CA: +The dictionary file was created using the "final" English and Canadian SCOWL (Spell Checker Oriented Word Lists) wordlists available at Kevin's Word Lists Page (http://wordlist.sourceforge.net). Lists with the suffixes 10, 20, 35, 50, 65 and 65 were used. Lists with the suffixes 70, 80 and 95 were excluded. Copyright information for SCOWL and the wordlists used in creating it is reproduced below. + +The affix file is identical to the MySpell English (United States) affix file. It is a heavily modified version of the original english.aff file which was released as part of Geoff Kuenning's Ispell and as such is covered by his BSD license. + +--- + +COPYRIGHT, SOURCES, and CREDITS from SCOWL readme file: + +The collective work is Copyright 2000 by Kevin Atkinson as well as any +of the copyrights mentioned below: + + Copyright 2000 by Kevin Atkinson + + Permission to use, copy, modify, distribute and sell these word + lists, the associated scripts, the output created from the scripts, + and its documentation for any purpose is hereby granted without fee, + provided that the above copyright notice appears in all copies and + that both that copyright notice and this permission notice appear in + supporting documentation. Kevin Atkinson makes no representations + about the suitability of this array for any purpose. It is provided + "as is" without express or implied warranty. + +Alan Beale <biljir@pobox.com> also deserves special credit as he has, +in addition to providing the 12Dicts package and being a major +contributor to the ENABLE word list, given me an incredible amount of +feedback and created a number of special lists (those found in the +Supplement) in order to help improve the overall quality of SCOWL. + +The 10 level includes the 1000 most common English words (according to +the Moby (TM) Words II [MWords] package), a subset of the 1000 most +common words on the Internet (again, according to Moby Words II), and +frequently class 16 from Brian Kelk's "UK English Wordlist +with Frequency Classification". + +The MWords package was explicitly placed in the public domain: + + The Moby lexicon project is complete and has + been place into the public domain. Use, sell, + rework, excerpt and use in any way on any platform. + + Placing this material on internal or public servers is + also encouraged. The compiler is not aware of any + export restrictions so freely distribute world-wide. + + You can verify the public domain status by contacting + + Grady Ward + 3449 Martha Ct. + Arcata, CA 95521-4884 + + grady@netcom.com + grady@northcoast.com + +The "UK English Wordlist With Frequency Classification" is also in the +Public Domain: + + Date: Sat, 08 Jul 2000 20:27:21 +0100 + From: Brian Kelk <Brian.Kelk@cl.cam.ac.uk> + +> I was wondering what the copyright status of your "UK English + > Wordlist With Frequency Classification" word list as it seems to + > be lacking any copyright notice. + + There were many many sources in total, but any text marked + "copyright" was avoided. Locally-written documentation was one + source. An earlier version of the list resided in a filespace called + PUBLIC on the University mainframe, because it was considered public + domain. + + Date: Tue, 11 Jul 2000 19:31:34 +0100 + + > So are you saying your word list is also in the public domain? + + That is the intention. + +The 20 level includes frequency classes 7-15 from Brian's word list. + +The 35 level includes frequency classes 2-6 and words appearing in at +least 11 of 12 dictionaries as indicated in the 12Dicts package. All +words from the 12Dicts package have had likely inflections added via +my inflection database. + +The 12Dicts package and Supplement is in the Public Domain. + +The WordNet database, which was used in the creation of the +Inflections database, is under the following copyright: + + This software and database is being provided to you, the LICENSEE, + by Princeton University under the following license. By obtaining, + using and/or copying this software and database, you agree that you + have read, understood, and will comply with these terms and + conditions.: + + Permission to use, copy, modify and distribute this software and + database and its documentation for any purpose and without fee or + royalty is hereby granted, provided that you agree to comply with + the following copyright notice and statements, including the + disclaimer, and that the same appear on ALL copies of the software, + database and documentation, including modifications that you make + for internal use or for distribution. + + WordNet 1.6 Copyright 1997 by Princeton University. All rights + reserved. + + THIS SOFTWARE AND DATABASE IS PROVIDED "AS IS" AND PRINCETON + UNIVERSITY MAKES NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR + IMPLIED. BY WAY OF EXAMPLE, BUT NOT LIMITATION, PRINCETON + UNIVERSITY MAKES NO REPRESENTATIONS OR WARRANTIES OF MERCHANT- + ABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR THAT THE USE OF THE + LICENSED SOFTWARE, DATABASE OR DOCUMENTATION WILL NOT INFRINGE ANY + THIRD PARTY PATENTS, COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS. + + The name of Princeton University or Princeton may not be used in + advertising or publicity pertaining to distribution of the software + and/or database. Title to copyright in this software, database and + any associated documentation shall at all times remain with + Princeton University and LICENSEE agrees to preserve same. + +The 50 level includes Brian's frequency class 1, words appearing in +at least 5 of 12 of the dictionaries as indicated in the 12Dicts +package, and uppercase words in at least 4 of the previous 12 +dictionaries. A decent number of proper names is also included: The +top 1000 male, female, and Last names from the 1990 Census report; a +list of names sent to me by Alan Beale; and a few names that I added +myself. Finally a small list of abbreviations not commonly found in +other word lists is included. + +The name files form the Census report is a government document which I +don't think can be copyrighted. + +The name list from Alan Beale is also derived from the linux words +list, which is derived from the DEC list. He also added a bunch of +miscellaneous names to the list, which he released to the Public Domain. + +The DEC Word list doesn't have a formal name. It is labeled as "FILE: +english.words; VERSION: DEC-SRC-92-04-05" and was put together by Jorge +Stolfi <stolfi@src.dec.com> DEC Systems Research Center. The DEC Word +list has the following copyright statement: + + (NON-)COPYRIGHT STATUS + + To the best of my knowledge, all the files I used to build these + wordlists were available for public distribution and use, at least + for non-commercial purposes. I have confirmed this assumption with + the authors of the lists, whenever they were known. + + Therefore, it is safe to assume that the wordlists in this package + can also be freely copied, distributed, modified, and used for + personal, educational, and research purposes. (Use of these files in + commercial products may require written permission from DEC and/or + the authors of the original lists.) + + Whenever you distribute any of these wordlists, please distribute + also the accompanying README file. If you distribute a modified + copy of one of these wordlists, please include the original README + file with a note explaining your modifications. Your users will + surely appreciate that. + + (NO-)WARRANTY DISCLAIMER + + These files, like the original wordlists on which they are based, + are still very incomplete, uneven, and inconsistent, and probably + contain many errors. They are offered "as is" without any warranty + of correctness or fitness for any particular purpose. Neither I nor + my employer can be held responsible for any losses or damages that + may result from their use. + +However since this Word List is used in the linux.words package which +the author claims is free of any copyright I assume it is OK to use +for most purposes. If you want to use this in a commercial project +and this concerns you the information from the DEC word list can +easily be removed without much sacrifice in quality as only the name +lists were used. + +The file special-jargon.50 uses common.lst and word.lst from the +"Unofficial Jargon File Word Lists" which is derived from "The Jargon +File". All of which is in the Public Domain. This file also contain +a few extra UNIX terms which are found in the file "unix-terms" in the +special/ directory. + +The 60 level includes Brian's frequency class 0 and all words +appearing in at least 2 of the 12 dictionaries as indicated by the +12Dicts package. A large number of names are also included: The 4,946 +female names and 3,897 male names from the MWords package and the +files "computer.names", "misc.names", and "org.names" from the DEC +package. + +The 65 level includes words found in the Ispell "medium" word list. +The Ispell word lists are under the same copyright of Ispell itself +which is: + + Copyright 1993, Geoff Kuenning, Granada Hills, CA + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + 1. Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + 3. All modifications to the source code must be clearly marked as + such. Binary redistributions based on modified source code + must be clearly marked as modified versions in the documentation + and/or other materials provided with the distribution. + 4. All advertising materials mentioning features or use of this software + must display the following acknowledgment: + This product includes software developed by Geoff Kuenning and + other unpaid contributors. + 5. The name of Geoff Kuenning may not be used to endorse or promote + products derived from this software without specific prior + written permission. + + THIS SOFTWARE IS PROVIDED BY GEOFF KUENNING AND CONTRIBUTORS ``AS + IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS + FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GEOFF + KUENNING OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, + INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, + BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER + CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN + ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. + +The 70 level includes the 74,550 common dictionary words and the 21,986 names +list from the MWords package. The common dictionary words, like those +from the 12Dicts package, have had all likely inflections added. + +The 80 level includes the ENABLE word list, all the lists in the +ENABLE supplement package (except for ABLE), the "UK Advanced Cryptics +Dictionary" (UKACD), the list of signature words in from YAWL package, +and the 10,196 places list from the MWords package. + +The ENABLE package, mainted by M\Cooper <thegrendel@theriver.com>, +is in the Public Domain: + + The ENABLE master word list, WORD.LST, is herewith formally released + into the Public Domain. Anyone is free to use it or distribute it in + any manner they see fit. No fee or registration is required for its + use nor are "contributions" solicited (if you feel you absolutely + must contribute something for your own peace of mind, the authors of + the ENABLE list ask that you make a donation on their behalf to your + favorite charity). This word list is our gift to the Scrabble + community, as an alternate to "official" word lists. Game designers + may feel free to incorporate the WORD.LST into their games. Please + mention the source and credit us as originators of the list. Note + that if you, as a game designer, use the WORD.LST in your product, + you may still copyright and protect your product, but you may *not* + legally copyright or in any way restrict redistribution of the + WORD.LST portion of your product. This *may* under law restrict your + rights to restrict your users' rights, but that is only fair. + +UKACD, by J Ross Beresford <ross@bryson.demon.co.uk>, is under the +following copyright: + + Copyright (c) J Ross Beresford 1993-1999. All Rights Reserved. + + The following restriction is placed on the use of this publication: + if The UK Advanced Cryptics Dictionary is used in a software package + or redistributed in any form, the copyright notice must be + prominently displayed and the text of this document must be included + verbatim. + + There are no other restrictions: I would like to see the list + distributed as widely as possible. + +The 95 level includes the 354,984 single words and 256,772 compound +words from the MWords package, ABLE.LST from the ENABLE Supplement, +and some additional words found in my part-of-speech database that +were not found anywhere else. + +Accent information was taken from UKACD. + +My VARCON package was used to create the American, British, and +Canadian word list. + +Since the original word lists used in the VARCON package came from +the Ispell distribution they are under the Ispell copyright. + +The variant word lists were created from a list of variants found in +the 12dicts supplement package as well as a list of variants I created +myself. + + + + +=================================================== +en_GB: +This dictionary was initially based on a subset of the +original English wordlist created by Kevin Atkinson for +Pspell and Aspell and thus is covered by his original +LGPL licence. + +It has been extensively updated by David Bartlett, Brian Kelk +and Andrew Brown: +- numerous Americanism have been removed +- numerous American spellings have been corrected +- missing words have been added +- many errors have been corrected +- compound hyphenated words have been added where appropriate + +Valuable inputs to this process were received from many other +people - far too numerous to name. Serious thanks to you all +for your greatly appreciated help. + +This word list is intended to be a good representation of +current modern British English and thus it should be a good +basis for Commonwealth English in most countries of the world +outside North America. + +The affix file has been created completely from scratch +by David Bartlett and Andrew Brown, based on the published +rules for MySpell and is also provided under the LGPL. + +In creating the affix rules an attempt has been made to +reproduce the most general rules for English word +formation, rather than merely use it as a means to +compress the size of the dictionary. It is hoped that this +will facilitate future localisation to other variants of +English. + +Please let David Bartlett <dwb@openoffice.org> know of any +errors that you find. + +The current release is R 1.18, 11/04/05 +=================================================== +en_NZ: +I. Copyright +II. Copying (Licence) +---------------------------- + +I. Copyright + +NZ English Dictionary v0.9 beta - Build 06SEP03 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +NB This is an initial version, please check: +http://lingucomponent.openoffice.org/download_dictionary.html +or +http://www.girlza.com/dictionary/download.html +for a final version, after a little while (no hurry). + +This dictionary is based on the en_GB Myspell dictionary +which in turn was initially based on a subset of the +original English wordlist created by Kevin Atkinson for +Pspell and Aspell and thus is covered by his original +LGPL licence. + + +Introduction +~~~~~~~~~~~~ +en_NZ.dic has been altered to include New Zealand places, +including major cities and towns, and major suburbs. It +also contains NZ words, organisations and expressions. + +en_NZ.aff has had a few REPlace strings added, but is +basically unchanged. + + +Acknowledgements +~~~~~~~~~~~~~~~~ +Thanks must go to the original creators of the British +dictionary, David Bartlett, Brian Kelk and Andrew Brown. + +I wouldn't have started this without seeing the Australian +dictionary, thanks Kelvin Eldridge, Jean Hollis Weber and +David Wilson. + +And thank you to all who've contributed to OpenOffice.org. + + +License +~~~~~~~ +This dictionary is covered by the GNU Lesser General Public +License, viewable at http://www.gnu.org/copyleft/lesser.html + + +Issues +~~~~~~ +Many of the proper nouns already in the dictionary do not have +an affix for 's. +All my new words start after the z's of the original dictionary. + + +Contact +~~~~~~~ +Contact Tristan Burtenshaw (hooty@slingshot.co.nz) with any words, +places or other suggestions for the dictionary. + + + +II. Copying + + GNU LESSER GENERAL PUBLIC LICENSE + Version 2.1, February 1999 + + Copyright (C) 1991, 1999 Free Software Foundation, Inc. + 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + +[This is the first released version of the Lesser GPL. It also counts + as the successor of the GNU Library Public License, version 2, hence + the version number 2.1.] + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +Licenses are intended to guarantee your freedom to share and change +free software--to make sure the software is free for all its users. + + This license, the Lesser General Public License, applies to some +specially designated software packages--typically libraries--of the +Free Software Foundation and other authors who decide to use it. You +can use it too, but we suggest you first think carefully about whether +this license or the ordinary General Public License is the better +strategy to use in any particular case, based on the explanations below. + + When we speak of free software, we are referring to freedom of use, +not price. Our General Public Licenses are designed to make sure that +you have the freedom to distribute copies of free software (and charge +for this service if you wish); that you receive source code or can get +it if you want it; that you can change the software and use pieces of +it in new free programs; and that you are informed that you can do +these things. + + To protect your rights, we need to make restrictions that forbid +distributors to deny you these rights or to ask you to surrender these +rights. These restrictions translate to certain responsibilities for +you if you distribute copies of the library or if you modify it. + + For example, if you distribute copies of the library, whether gratis +or for a fee, you must give the recipients all the rights that we gave +you. You must make sure that they, too, receive or can get the source +code. If you link other code with the library, you must provide +complete object files to the recipients, so that they can relink them +with the library after making changes to the library and recompiling +it. And you must show them these terms so they know their rights. + + We protect your rights with a two-step method: (1) we copyright the +library, and (2) we offer you this license, which gives you legal +permission to copy, distribute and/or modify the library. + + To protect each distributor, we want to make it very clear that +there is no warranty for the free library. Also, if the library is +modified by someone else and passed on, the recipients should know +that what they have is not the original version, so that the original +author's reputation will not be affected by problems that might be +introduced by others. + + Finally, software patents pose a constant threat to the existence of +any free program. We wish to make sure that a company cannot +effectively restrict the users of a free program by obtaining a +restrictive license from a patent holder. Therefore, we insist that +any patent license obtained for a version of the library must be +consistent with the full freedom of use specified in this license. + + Most GNU software, including some libraries, is covered by the +ordinary GNU General Public License. This license, the GNU Lesser +General Public License, applies to certain designated libraries, and +is quite different from the ordinary General Public License. We use +this license for certain libraries in order to permit linking those +libraries into non-free programs. + + When a program is linked with a library, whether statically or using +a shared library, the combination of the two is legally speaking a +combined work, a derivative of the original library. The ordinary +General Public License therefore permits such linking only if the +entire combination fits its criteria of freedom. The Lesser General +Public License permits more lax criteria for linking other code with +the library. + + We call this license the "Lesser" General Public License because it +does Less to protect the user's freedom than the ordinary General +Public License. It also provides other free software developers Less +of an advantage over competing non-free programs. These disadvantages +are the reason we use the ordinary General Public License for many +libraries. However, the Lesser license provides advantages in certain +special circumstances. + + For example, on rare occasions, there may be a special need to +encourage the widest possible use of a certain library, so that it becomes +a de-facto standard. To achieve this, non-free programs must be +allowed to use the library. A more frequent case is that a free +library does the same job as widely used non-free libraries. In this +case, there is little to gain by limiting the free library to free +software only, so we use the Lesser General Public License. + + In other cases, permission to use a particular library in non-free +programs enables a greater number of people to use a large body of +free software. For example, permission to use the GNU C Library in +non-free programs enables many more people to use the whole GNU +operating system, as well as its variant, the GNU/Linux operating +system. + + Although the Lesser General Public License is Less protective of the +users' freedom, it does ensure that the user of a program that is +linked with the Library has the freedom and the wherewithal to run +that program using a modified version of the Library. + + The precise terms and conditions for copying, distribution and +modification follow. Pay close attention to the difference between a +"work based on the library" and a "work that uses the library". The +former contains code derived from the library, whereas the latter must +be combined with the library in order to run. + + GNU LESSER GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License Agreement applies to any software library or other +program which contains a notice placed by the copyright holder or +other authorized party saying it may be distributed under the terms of +this Lesser General Public License (also called "this License"). +Each licensee is addressed as "you". + + A "library" means a collection of software functions and/or data +prepared so as to be conveniently linked with application programs +(which use some of those functions and data) to form executables. + + The "Library", below, refers to any such software library or work +which has been distributed under these terms. A "work based on the +Library" means either the Library or any derivative work under +copyright law: that is to say, a work containing the Library or a +portion of it, either verbatim or with modifications and/or translated +straightforwardly into another language. (Hereinafter, translation is +included without limitation in the term "modification".) + + "Source code" for a work means the preferred form of the work for +making modifications to it. For a library, complete source code means +all the source code for all modules it contains, plus any associated +interface definition files, plus the scripts used to control compilation +and installation of the library. + + Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running a program using the Library is not restricted, and output from +such a program is covered only if its contents constitute a work based +on the Library (independent of the use of the Library in a tool for +writing it). Whether that is true depends on what the Library does +and what the program that uses the Library does. + + 1. You may copy and distribute verbatim copies of the Library's +complete source code as you receive it, in any medium, provided that +you conspicuously and appropriately publish on each copy an +appropriate copyright notice and disclaimer of warranty; keep intact +all the notices that refer to this License and to the absence of any +warranty; and distribute a copy of this License along with the +Library. + + You may charge a fee for the physical act of transferring a copy, +and you may at your option offer warranty protection in exchange for a +fee. + + 2. You may modify your copy or copies of the Library or any portion +of it, thus forming a work based on the Library, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) The modified work must itself be a software library. + + b) You must cause the files modified to carry prominent notices + stating that you changed the files and the date of any change. + + c) You must cause the whole of the work to be licensed at no + charge to all third parties under the terms of this License. + + d) If a facility in the modified Library refers to a function or a + table of data to be supplied by an application program that uses + the facility, other than as an argument passed when the facility + is invoked, then you must make a good faith effort to ensure that, + in the event an application does not supply such function or + table, the facility still operates, and performs whatever part of + its purpose remains meaningful. + + (For example, a function in a library to compute square roots has + a purpose that is entirely well-defined independent of the + application. Therefore, Subsection 2d requires that any + application-supplied function or table used by this function must + be optional: if the application does not supply it, the square + root function must still compute square roots.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Library, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Library, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote +it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Library. + +In addition, mere aggregation of another work not based on the Library +with the Library (or with a work based on the Library) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may opt to apply the terms of the ordinary GNU General Public +License instead of this License to a given copy of the Library. To do +this, you must alter all the notices that refer to this License, so +that they refer to the ordinary GNU General Public License, version 2, +instead of to this License. (If a newer version than version 2 of the +ordinary GNU General Public License has appeared, then you can specify +that version instead if you wish.) Do not make any other change in +these notices. + + Once this change is made in a given copy, it is irreversible for +that copy, so the ordinary GNU General Public License applies to all +subsequent copies and derivative works made from that copy. + + This option is useful when you wish to copy part of the code of +the Library into a program that is not a library. + + 4. You may copy and distribute the Library (or a portion or +derivative of it, under Section 2) in object code or executable form +under the terms of Sections 1 and 2 above provided that you accompany +it with the complete corresponding machine-readable source code, which +must be distributed under the terms of Sections 1 and 2 above on a +medium customarily used for software interchange. + + If distribution of object code is made by offering access to copy +from a designated place, then offering equivalent access to copy the +source code from the same place satisfies the requirement to +distribute the source code, even though third parties are not +compelled to copy the source along with the object code. + + 5. A program that contains no derivative of any portion of the +Library, but is designed to work with the Library by being compiled or +linked with it, is called a "work that uses the Library". Such a +work, in isolation, is not a derivative work of the Library, and +therefore falls outside the scope of this License. + + However, linking a "work that uses the Library" with the Library +creates an executable that is a derivative of the Library (because it +contains portions of the Library), rather than a "work that uses the +library". The executable is therefore covered by this License. +Section 6 states terms for distribution of such executables. + + When a "work that uses the Library" uses material from a header file +that is part of the Library, the object code for the work may be a +derivative work of the Library even though the source code is not. +Whether this is true is especially significant if the work can be +linked without the Library, or if the work is itself a library. The +threshold for this to be true is not precisely defined by law. + + If such an object file uses only numerical parameters, data +structure layouts and accessors, and small macros and small inline +functions (ten lines or less in length), then the use of the object +file is unrestricted, regardless of whether it is legally a derivative +work. (Executables containing this object code plus portions of the +Library will still fall under Section 6.) + + Otherwise, if the work is a derivative of the Library, you may +distribute the object code for the work under the terms of Section 6. +Any executables containing that work also fall under Section 6, +whether or not they are linked directly with the Library itself. + + 6. As an exception to the Sections above, you may also combine or +link a "work that uses the Library" with the Library to produce a +work containing portions of the Library, and distribute that work +under terms of your choice, provided that the terms permit +modification of the work for the customer's own use and reverse +engineering for debugging such modifications. + + You must give prominent notice with each copy of the work that the +Library is used in it and that the Library and its use are covered by +this License. You must supply a copy of this License. If the work +during execution displays copyright notices, you must include the +copyright notice for the Library among them, as well as a reference +directing the user to the copy of this License. Also, you must do one +of these things: + + a) Accompany the work with the complete corresponding + machine-readable source code for the Library including whatever + changes were used in the work (which must be distributed under + Sections 1 and 2 above); and, if the work is an executable linked + with the Library, with the complete machine-readable "work that + uses the Library", as object code and/or source code, so that the + user can modify the Library and then relink to produce a modified + executable containing the modified Library. (It is understood + that the user who changes the contents of definitions files in the + Library will not necessarily be able to recompile the application + to use the modified definitions.) + + b) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (1) uses at run time a + copy of the library already present on the user's computer system, + rather than copying library functions into the executable, and (2) + will operate properly with a modified version of the library, if + the user installs one, as long as the modified version is + interface-compatible with the version that the work was made with. + + c) Accompany the work with a written offer, valid for at + least three years, to give the same user the materials + specified in Subsection 6a, above, for a charge no more + than the cost of performing this distribution. + + d) If distribution of the work is made by offering access to copy + from a designated place, offer equivalent access to copy the above + specified materials from the same place. + + e) Verify that the user has already received a copy of these + materials or that you have already sent this user a copy. + + For an executable, the required form of the "work that uses the +Library" must include any data and utility programs needed for +reproducing the executable from it. However, as a special exception, +the materials to be distributed need not include anything that is +normally distributed (in either source or binary form) with the major +components (compiler, kernel, and so on) of the operating system on +which the executable runs, unless that component itself accompanies +the executable. + + It may happen that this requirement contradicts the license +restrictions of other proprietary libraries that do not normally +accompany the operating system. Such a contradiction means you cannot +use both them and the Library together in an executable that you +distribute. + + 7. You may place library facilities that are a work based on the +Library side-by-side in a single library together with other library +facilities not covered by this License, and distribute such a combined +library, provided that the separate distribution of the work based on +the Library and of the other library facilities is otherwise +permitted, and provided that you do these two things: + + a) Accompany the combined library with a copy of the same work + based on the Library, uncombined with any other library + facilities. This must be distributed under the terms of the + Sections above. + + b) Give prominent notice with the combined library of the fact + that part of it is a work based on the Library, and explaining + where to find the accompanying uncombined form of the same work. + + 8. You may not copy, modify, sublicense, link with, or distribute +the Library except as expressly provided under this License. Any +attempt otherwise to copy, modify, sublicense, link with, or +distribute the Library is void, and will automatically terminate your +rights under this License. However, parties who have received copies, +or rights, from you under this License will not have their licenses +terminated so long as such parties remain in full compliance. + + 9. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Library or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Library (or any work based on the +Library), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Library or works based on it. + + 10. Each time you redistribute the Library (or any work based on the +Library), the recipient automatically receives a license from the +original licensor to copy, distribute, link with or modify the Library +subject to these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties with +this License. + + 11. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Library at all. For example, if a patent +license would not permit royalty-free redistribution of the Library by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Library. + +If any portion of this section is held invalid or unenforceable under any +particular circumstance, the balance of the section is intended to apply, +and the section as a whole is intended to apply in other circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 12. If the distribution and/or use of the Library is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Library under this License may add +an explicit geographical distribution limitation excluding those countries, +so that distribution is permitted only in or among countries not thus +excluded. In such case, this License incorporates the limitation as if +written in the body of this License. + + 13. The Free Software Foundation may publish revised and/or new +versions of the Lesser General Public License from time to time. +Such new versions will be similar in spirit to the present version, +but may differ in detail to address new problems or concerns. + +Each version is given a distinguishing version number. If the Library +specifies a version number of this License which applies to it and +"any later version", you have the option of following the terms and +conditions either of that version or of any later version published by +the Free Software Foundation. If the Library does not specify a +license version number, you may choose any version ever published by +the Free Software Foundation. + + 14. If you wish to incorporate parts of the Library into other free +programs whose distribution conditions are incompatible with these, +write to the author to ask for permission. For software which is +copyrighted by the Free Software Foundation, write to the Free +Software Foundation; we sometimes make exceptions for this. Our +decision will be guided by the two goals of preserving the free status +of all derivatives of our free software and of promoting the sharing +and reuse of software generally. + + NO WARRANTY + + 15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO +WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. +EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR +OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY +KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE +LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME +THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN +WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY +AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU +FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR +CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE +LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING +RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A +FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF +SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH +DAMAGES. + + END OF TERMS AND CONDITIONS + diff --git a/share/vim/vim72/spell/af/af_ZA.diff b/share/vim/vim73/spell/af/af_ZA.diff similarity index 100% rename from share/vim/vim72/spell/af/af_ZA.diff rename to share/vim/vim73/spell/af/af_ZA.diff diff --git a/share/vim/vim72/spell/af/main.aap b/share/vim/vim73/spell/af/main.aap similarity index 100% rename from share/vim/vim72/spell/af/main.aap rename to share/vim/vim73/spell/af/main.aap diff --git a/share/vim/vim72/spell/am/am_ET.diff b/share/vim/vim73/spell/am/am_ET.diff similarity index 100% rename from share/vim/vim72/spell/am/am_ET.diff rename to share/vim/vim73/spell/am/am_ET.diff diff --git a/share/vim/vim72/spell/am/main.aap b/share/vim/vim73/spell/am/main.aap similarity index 100% rename from share/vim/vim72/spell/am/main.aap rename to share/vim/vim73/spell/am/main.aap diff --git a/share/vim/vim72/spell/bg/bg_BG.diff b/share/vim/vim73/spell/bg/bg_BG.diff similarity index 100% rename from share/vim/vim72/spell/bg/bg_BG.diff rename to share/vim/vim73/spell/bg/bg_BG.diff diff --git a/share/vim/vim73/spell/bg/main.aap b/share/vim/vim73/spell/bg/main.aap new file mode 100644 index 0000000000..bb34b9a7f0 --- /dev/null +++ b/share/vim/vim73/spell/bg/main.aap @@ -0,0 +1,80 @@ +# Aap recipe for Bulgarian Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = bg_BG.aff bg_BG.dic + +all: $SPELLDIR/bg.cp1251.spl $SPELLDIR/bg.utf-8.spl ../README_bg.txt + +$SPELLDIR/bg.cp1251.spl : $FILES + :sys env LANG=bg_BG.CP1251 $VIM -u NONE -e -c "mkspell! $SPELLDIR/bg bg_BG" -c q + +$SPELLDIR/bg.utf-8.spl : $FILES + :sys env LANG=bg_BG.UTF-8 $VIM -u NONE -e -c "mkspell! $SPELLDIR/bg bg_BG" -c q + +../README_bg.txt: README_bg_BG.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} bg_BG.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +# This is a bit tricky, since the file name includes the date. +bg_BG.aff bg_BG.dic: {buildcheck=} + :assertpkg unzip patch + :fetch bg_BG.zip + :sys $UNZIP bg_BG.zip + :delete bg_BG.zip + :sys $VIM bg_BG.aff -u NONE -e -c "set ff=unix" -c update -c q + :sys $VIM bg_BG.dic -u NONE -e -c "set ff=unix" -c update -c q + :sys $VIM README_bg_BG.txt -u NONE -e -c "set ff=unix" -c update -c q + @if not os.path.exists('bg_BG.orig.aff'): + :copy bg_BG.aff bg_BG.orig.aff + @if not os.path.exists('bg_BG.orig.dic'): + :copy bg_BG.dic bg_BG.orig.dic + @if os.path.exists('bg_BG.diff'): + :sys patch <bg_BG.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 bg_BG.orig.aff bg_BG.aff >bg_BG.diff + :sys {force} diff -a -C 1 bg_BG.orig.dic bg_BG.dic >>bg_BG.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch bg_BG.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../bg_BG.zip + :sys {force} diff ../bg_BG.orig.aff bg_BG.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy bg_BG.aff ../bg_BG.new.aff + :sys {force} diff ../bg_BG.orig.dic bg_BG.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy bg_BG.dic ../bg_BG.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete bg_BG.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim73/spell/br/br_FR.diff b/share/vim/vim73/spell/br/br_FR.diff new file mode 100644 index 0000000000..e2ec71049e --- /dev/null +++ b/share/vim/vim73/spell/br/br_FR.diff @@ -0,0 +1,13 @@ +*** br_FR.orig.aff 2010-04-14 18:44:36.365731271 +0200 +--- br_FR.aff 2010-04-14 18:43:31.069137439 +0200 +*************** +*** 9,14 **** +--- 9,16 ---- + SET UTF-8 + TRY esiaùnñrtolcdugmphbyfvkwzESIAÙNÑRTOLCDUGMPHBYFVKWZ' + ++ MIDWORD ' ++ + PFX m Y 1 + PFX m 0 m' [aehiouy] + diff --git a/share/vim/vim73/spell/br/main.aap b/share/vim/vim73/spell/br/main.aap new file mode 100644 index 0000000000..1ca5935a6f --- /dev/null +++ b/share/vim/vim73/spell/br/main.aap @@ -0,0 +1,86 @@ +# Aap recipe for Breton Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = br_FR.aff br_FR.dic + +all: $SPELLDIR/br.latin1.spl $SPELLDIR/br.utf-8.spl ../README_br.txt + +$SPELLDIR/br.latin1.spl : $FILES + :sys $VIM -u NONE -e -c "set enc=latin1" + -c "mkspell! $SPELLDIR/br br_FR" -c q + +$SPELLDIR/br.utf-8.spl : $FILES + :sys $VIM -u NONE -e -c "set enc=UTF-8" + -c "mkspell! $SPELLDIR/br br_FR" -c q + +../README_br.txt : package-description.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://extensions.services.openoffice.org/e-files/2207/3 +:attr {fetch = $OODIR/%file%} dict-br_0.3.oxt + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +br_FR.aff br_FR.dic: {buildcheck=} + :assertpkg unzip patch + :fetch dict-br_0.3.oxt + :sys $UNZIP dict-br_0.3.oxt + :delete dict-br_0.3.oxt + :copy dictionaries/br_FR.aff br_FR.aff + :copy dictionaries/br_FR.dic br_FR.dic + # The br_FR.aff file contains a BOM, remove it. + :sys $VIM -u NONE -e -c "set enc=utf-8" + -c "e br_FR.aff" + -c "set nobomb ff=unix" + -c "update" -c q + :sys $VIM -u NONE -e -c "set enc=utf-8" + -c "e br_FR.dic" + -c "set nobomb ff=unix" + -c "update" -c q + @if not os.path.exists('br_FR.orig.aff'): + :copy br_FR.aff br_FR.orig.aff + @if os.path.exists('br_FR.diff'): + :sys patch <br_FR.diff + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 dictionaries/br_FR.aff br_FR.aff >br_FR.diff + :sys {force} diff -a -C 1 dictionaries/br_FR.dic br_FR.dic >>br_FR.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch dict-br_0.3.oxt + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../dict-br_0.3.oxt + :sys {force} diff ../dictionaries/br_FR.aff br_FR.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy br_FR.aff ../br_FR.new.aff + :sys {force} diff ../dictionaries/br_FR.dic br_FR.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy br_FR.dic ../br_FR.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete dict-br_0.3.oxt + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/ca/ca_ES.diff b/share/vim/vim73/spell/ca/ca_ES.diff similarity index 100% rename from share/vim/vim72/spell/ca/ca_ES.diff rename to share/vim/vim73/spell/ca/ca_ES.diff diff --git a/share/vim/vim73/spell/ca/main.aap b/share/vim/vim73/spell/ca/main.aap new file mode 100644 index 0000000000..8ba8c1a043 --- /dev/null +++ b/share/vim/vim73/spell/ca/main.aap @@ -0,0 +1,81 @@ +# Aap recipe for Catelan (Spain) Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = ca_ES.aff ca_ES.dic + +all: $SPELLDIR/ca.latin1.spl $SPELLDIR/ca.utf-8.spl ../README_ca.txt + +$SPELLDIR/ca.latin1.spl : $FILES + :sys env LANG=ca_ES.ISO8859-1 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/ca ca_ES" -c q + +$SPELLDIR/ca.utf-8.spl : $FILES + :sys env LANG=ca_ES.UTF-8 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/ca ca_ES" -c q + +../README_ca.txt : README_ca_ES.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} ca_ES.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +# Make sure the files are in Unix fileformat +ca_ES.aff ca_ES.dic: {buildcheck=} + :assertpkg unzip patch + :fetch ca_ES.zip + :sys $UNZIP ca_ES.zip + :delete ca_ES.zip + :sys $VIM ca_ES.aff -u NONE -c "set ff=unix" -c "update" -c q + :sys $VIM ca_ES.dic -u NONE -c "set ff=unix" -c "update" -c q + @if not os.path.exists('ca_ES.orig.aff'): + :copy ca_ES.aff ca_ES.orig.aff + @if not os.path.exists('ca_ES.orig.dic'): + :copy ca_ES.dic ca_ES.orig.dic + @if os.path.exists('ca_ES.diff'): + :sys patch <ca_ES.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 ca_ES.orig.aff ca_ES.aff >ca_ES.diff + :sys {force} diff -a -C 1 ca_ES.orig.dic ca_ES.dic >>ca_ES.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch ca_ES.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../ca_ES.zip + :sys {force} diff ../ca_ES.orig.aff ca_ES.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy ca_ES.aff ../ca_ES.new.aff + :sys {force} diff ../ca_ES.orig.dic ca_ES.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy ca_ES.dic ../ca_ES.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete ca_ES.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim73/spell/check/check_aa.aff b/share/vim/vim73/spell/check/check_aa.aff new file mode 100644 index 0000000000..20e16334fe --- /dev/null +++ b/share/vim/vim73/spell/check/check_aa.aff @@ -0,0 +1,50 @@ +SET ISO8859-1 +TRY esianrtolcdugmphbyfvkwjkqxz-ëéèêïîäàâöüû'ESIANRTOLCDUGMPHBYFVKWJKQXZ + +FOL àáâãäåæçèéêëìíîïðñòóôõöøùúûüýþßÿ +LOW àáâãäåæçèéêëìíîïðñòóôõöøùúûüýþßÿ +UPP ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞßÿ + +SOFOFROM abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþßÿÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞ¿ +SOFOTO ebctefghejklnnepkrstevvkesebctefghejklnnepkrstevvkeseeeeeeeceeeeeeeedneeeeeeeeeeepseeeeeeeeceeeeeeeedneeeeeeeeeeep? + +MIDWORD '- + +PFXPOSTPONE + +COMPOUNDFLAG x +COMPOUNDMIN 5 + +KEEPCASE = +RARE ? +BAD ! + +MAP 9 +MAP aàáâãäå +MAP eèéêë +MAP iìíîï +MAP oòóôõö +MAP uùúûü +MAP nñ +MAP cç +MAP yÿý +MAP sß + +PFX A Y 1 +PFX A 0 aan . + +PFX B N 1 +PFX B 0 be . + +PFX C Y 1 +PFX C a in aa + +SFX J N 1 +SFX J 0 tje [aeiou][aeiou] + +SFX Z N 1 +SFX Z af ven aaf + +REP 2 +REP g ch +REP cht gd diff --git a/share/vim/vim73/spell/check/check_aa.dic b/share/vim/vim73/spell/check/check_aa.dic new file mode 100644 index 0000000000..697a9c9e1b --- /dev/null +++ b/share/vim/vim73/spell/check/check_aa.dic @@ -0,0 +1,12 @@ +1234 +#Some Comment that isn't supposed to matter +/Another Comment that isn't supposed to matter +'s-Graveland +A4 +AagJe +Aalburg/xZBCJZ +Aals'meer/x +Aal-ten/x +Aalburgers/x +Aalsmeer/x +Aalten/x diff --git a/share/vim/vim73/spell/check/check_bb.aff b/share/vim/vim73/spell/check/check_bb.aff new file mode 100644 index 0000000000..20e16334fe --- /dev/null +++ b/share/vim/vim73/spell/check/check_bb.aff @@ -0,0 +1,50 @@ +SET ISO8859-1 +TRY esianrtolcdugmphbyfvkwjkqxz-ëéèêïîäàâöüû'ESIANRTOLCDUGMPHBYFVKWJKQXZ + +FOL àáâãäåæçèéêëìíîïðñòóôõöøùúûüýþßÿ +LOW àáâãäåæçèéêëìíîïðñòóôõöøùúûüýþßÿ +UPP ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞßÿ + +SOFOFROM abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþßÿÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞ¿ +SOFOTO ebctefghejklnnepkrstevvkesebctefghejklnnepkrstevvkeseeeeeeeceeeeeeeedneeeeeeeeeeepseeeeeeeeceeeeeeeedneeeeeeeeeeep? + +MIDWORD '- + +PFXPOSTPONE + +COMPOUNDFLAG x +COMPOUNDMIN 5 + +KEEPCASE = +RARE ? +BAD ! + +MAP 9 +MAP aàáâãäå +MAP eèéêë +MAP iìíîï +MAP oòóôõö +MAP uùúûü +MAP nñ +MAP cç +MAP yÿý +MAP sß + +PFX A Y 1 +PFX A 0 aan . + +PFX B N 1 +PFX B 0 be . + +PFX C Y 1 +PFX C a in aa + +SFX J N 1 +SFX J 0 tje [aeiou][aeiou] + +SFX Z N 1 +SFX Z af ven aaf + +REP 2 +REP g ch +REP cht gd diff --git a/share/vim/vim73/spell/check/check_bb.dic b/share/vim/vim73/spell/check/check_bb.dic new file mode 100644 index 0000000000..c01e7169ae --- /dev/null +++ b/share/vim/vim73/spell/check/check_bb.dic @@ -0,0 +1,12 @@ +1234 +#Some Comment that isn't supposed to matter +/Another Comment that isn't supposed to matter +'s-Graveland +A4 +AagJe +Aalburg/xZBCJZ +Aals'meer/x +Aal-ten/x +foobar/= +rare/? +Emacs/! diff --git a/share/vim/vim73/spell/check/main.aap b/share/vim/vim73/spell/check/main.aap new file mode 100644 index 0000000000..a47351f7ec --- /dev/null +++ b/share/vim/vim73/spell/check/main.aap @@ -0,0 +1,15 @@ +# Aap recipe for a dummy spell file. +# This is used to check if the .spl file format changes. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +all: check.latin1.spl + +check.latin1.spl : $VIM check_aa.aff check_aa.dic check_bb.aff check_bb.dic + :sys $VIM -u NONE -e -c "mkspell! check check_aa check_bb" -c q + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim73/spell/check_locales.vim b/share/vim/vim73/spell/check_locales.vim new file mode 100644 index 0000000000..fe7be93b58 --- /dev/null +++ b/share/vim/vim73/spell/check_locales.vim @@ -0,0 +1,21 @@ +" Script to check if all the locales used in spell files are available. + +grep /sys env LANG/ */main.aap +let not_supported = [] +for item in getqflist() + let lang = substitute(item.text, '.*LANG=\(\S\+\).*', '\1', '') + try + exe 'lang ' . lang + catch /E197/ + call add(not_supported, lang) + endtry +endfor + +if len(not_supported) > 0 + echo "Unsupported languages:" + for l in not_supported + echo l + endfor +else + echo "Everything appears to be OK" +endif diff --git a/share/vim/vim72/spell/cleanadd.vim b/share/vim/vim73/spell/cleanadd.vim similarity index 100% rename from share/vim/vim72/spell/cleanadd.vim rename to share/vim/vim73/spell/cleanadd.vim diff --git a/share/vim/vim72/spell/cs/cs_CZ.diff b/share/vim/vim73/spell/cs/cs_CZ.diff similarity index 100% rename from share/vim/vim72/spell/cs/cs_CZ.diff rename to share/vim/vim73/spell/cs/cs_CZ.diff diff --git a/share/vim/vim72/spell/cs/main.aap b/share/vim/vim73/spell/cs/main.aap similarity index 100% rename from share/vim/vim72/spell/cs/main.aap rename to share/vim/vim73/spell/cs/main.aap diff --git a/share/vim/vim72/spell/cy/cy_GB.diff b/share/vim/vim73/spell/cy/cy_GB.diff similarity index 100% rename from share/vim/vim72/spell/cy/cy_GB.diff rename to share/vim/vim73/spell/cy/cy_GB.diff diff --git a/share/vim/vim73/spell/cy/main.aap b/share/vim/vim73/spell/cy/main.aap new file mode 100644 index 0000000000..1c1d20d9f5 --- /dev/null +++ b/share/vim/vim73/spell/cy/main.aap @@ -0,0 +1,82 @@ +# Aap recipe for Welsh Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = cy_GB.aff cy_GB.dic + +all: $SPELLDIR/cy.iso-8859-14.spl $SPELLDIR/cy.utf-8.spl \ + ../README_cy.txt + +$SPELLDIR/cy.iso-8859-14.spl : $FILES + :sys $VIM -u NONE -e -c "set enc=iso-8859-14" + -c "mkspell! $SPELLDIR/cy cy_GB" -c q + +$SPELLDIR/cy.utf-8.spl : $FILES + :sys $VIM -u NONE -e -c "set enc=utf-8" + -c "mkspell! $SPELLDIR/cy cy_GB" -c q + +../README_cy.txt : README_cy_GB.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} cy_GB.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +cy_GB.aff cy_GB.dic: {buildcheck=} + :assertpkg unzip patch + :fetch cy_GB.zip + :sys $UNZIP cy_GB.zip + :delete cy_GB.zip + :sys $VIM cy_GB.aff -u NONE -e -c "set ff=unix" -c update -c q + :sys $VIM cy_GB.dic -u NONE -e -c "set ff=unix" -c update -c q + :sys $VIM README_cy_GB.txt -u NONE -e -c "set ff=unix" -c update -c q + @if not os.path.exists('cy_GB.orig.aff'): + :copy cy_GB.aff cy_GB.orig.aff + @if not os.path.exists('cy_GB.orig.dic'): + :copy cy_GB.dic cy_GB.orig.dic + @if os.path.exists('cy_GB.diff'): + :sys patch <cy_GB.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 cy_GB.orig.aff cy_GB.aff >cy_GB.diff + :sys {force} diff -a -C 1 cy_GB.orig.dic cy_GB.dic >>cy_GB.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch cy_GB.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../cy_GB.zip + :sys {force} diff ../cy_GB.orig.aff cy_GB.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy cy_GB.aff ../cy_GB.new.aff + :sys {force} diff ../cy_GB.orig.dic cy_GB.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy cy_GB.dic ../cy_GB.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete cy_GB.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/da/da_DK.diff b/share/vim/vim73/spell/da/da_DK.diff similarity index 100% rename from share/vim/vim72/spell/da/da_DK.diff rename to share/vim/vim73/spell/da/da_DK.diff diff --git a/share/vim/vim72/spell/da/main.aap b/share/vim/vim73/spell/da/main.aap similarity index 100% rename from share/vim/vim72/spell/da/main.aap rename to share/vim/vim73/spell/da/main.aap diff --git a/share/vim/vim72/spell/de/de_19.diff b/share/vim/vim73/spell/de/de_19.diff similarity index 100% rename from share/vim/vim72/spell/de/de_19.diff rename to share/vim/vim73/spell/de/de_19.diff diff --git a/share/vim/vim72/spell/de/de_20.diff b/share/vim/vim73/spell/de/de_20.diff similarity index 100% rename from share/vim/vim72/spell/de/de_20.diff rename to share/vim/vim73/spell/de/de_20.diff diff --git a/share/vim/vim72/spell/de/de_AT.diff b/share/vim/vim73/spell/de/de_AT.diff similarity index 100% rename from share/vim/vim72/spell/de/de_AT.diff rename to share/vim/vim73/spell/de/de_AT.diff diff --git a/share/vim/vim72/spell/de/de_CH.diff b/share/vim/vim73/spell/de/de_CH.diff similarity index 100% rename from share/vim/vim72/spell/de/de_CH.diff rename to share/vim/vim73/spell/de/de_CH.diff diff --git a/share/vim/vim72/spell/de/de_DE.diff b/share/vim/vim73/spell/de/de_DE.diff similarity index 100% rename from share/vim/vim72/spell/de/de_DE.diff rename to share/vim/vim73/spell/de/de_DE.diff diff --git a/share/vim/vim73/spell/de/main.aap b/share/vim/vim73/spell/de/main.aap new file mode 100644 index 0000000000..78dfaabd44 --- /dev/null +++ b/share/vim/vim73/spell/de/main.aap @@ -0,0 +1,236 @@ +# Aap recipe for German Vim spell files. +# +# Since there is a big discussion about whether to use the old or the new +# spelling rules, both have been included. +# "de": all possible words allowed +# "de_de": old and new German spelling +# "de_19": old German spelling +# "de_20": new German spelling +# "de_AT": Austrian spelling +# "de_CH": Swiss spelling + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +REGIONS = DE 19 20 AT CH +DE_REGIONS = de_$*REGIONS + +SPELLDIR = .. +FILES = de_$*(REGIONS).aff de_$*(REGIONS).dic + +ZIPFILE_DE = de_DE_comb.zip +ZIPFILE_19 = de_OLDSPELL.zip +ZIPFILE_20 = de_DE_neu.zip +ZIPFILE_AT = de_DE.zip +ZIPFILE_CH = de_CH.zip +ZIPFILES = $ZIPFILE_DE $ZIPFILE_19 $ZIPFILE_20 $ZIPFILE_AT $ZIPFILE_CH + +READMES = README_de_$*(REGIONS).txt + +all: $SPELLDIR/de.latin1.spl $SPELLDIR/de.utf-8.spl ../README_de.txt + +$SPELLDIR/de.latin1.spl : $FILES + :sys env LANG=de_DE.ISO-8859-1 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/de $DE_REGIONS" -c q + +$SPELLDIR/de.utf-8.spl : $FILES + :sys env LANG=de_DE.UTF-8 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/de $DE_REGIONS" -c q + +../README_de.txt: $READMES + :print de_DE (combined) >! $target + :cat README_de_DE.txt >> $target + :print =================================================== >>$target + :print de_19 (old) >> $target + :cat README_de_19.txt >> $target + :print =================================================== >>$target + :print de_20 (new) >> $target + :cat README_de_20.txt >> $target + :print =================================================== >>$target + :print de_AT (Austria) >> $target + :cat README_de_AT.txt >> $target + :print =================================================== >>$target + :print de_CH (Swiss) >> $target + :cat README_de_CH.txt >> $target + +# +# Fetching the files from the OpenOffice.org site. +# The OLDSPELL file comes from elsewhere +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +DEDIR = http://www.j3e.de/myspell +:attr {fetch = $OODIR/%file%} $ZIPFILES +:attr {fetch = $DEDIR/%file%} $ZIPFILE_19 + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +de_DE.aff de_DE.dic: {buildcheck=} + :assertpkg unzip patch + :fetch $ZIPFILE_DE + :sys $UNZIP $ZIPFILE_DE + :delete $ZIPFILE_DE + :move de_DE_comb.aff de_DE.aff + :move de_DE_comb.dic de_DE.dic + :move README_de_DE_comb.txt README_de_DE.txt + @if not os.path.exists('de_DE.orig.aff'): + :copy de_DE.aff de_DE.orig.aff + @if not os.path.exists('de_DE.orig.dic'): + :copy de_DE.dic de_DE.orig.dic + @if os.path.exists('de_DE.diff'): + :sys patch <de_DE.diff + +de_19.aff de_19.dic: {buildcheck=} + :assertpkg unzip patch + :fetch $ZIPFILE_19 + :sys $UNZIP $ZIPFILE_19 + :delete $ZIPFILE_19 + :move de_OLDSPELL.aff de_19.aff + :move de_OLDSPELL.dic de_19.dic + # there is no README file + :print There is no README file for the old spelling >!README_de_19.txt + @if not os.path.exists('de_19.orig.aff'): + :copy de_19.aff de_19.orig.aff + @if not os.path.exists('de_19.orig.dic'): + :copy de_19.dic de_19.orig.dic + @if os.path.exists('de_19.diff'): + :sys patch <de_19.diff + +de_20.aff de_20.dic: {buildcheck=} + :assertpkg unzip patch + :fetch $ZIPFILE_20 + :sys $UNZIP $ZIPFILE_20 + :delete $ZIPFILE_20 + :move de_DE_neu.aff de_20.aff + :move de_DE_neu.dic de_20.dic + :move README_de_DE_neu.txt README_de_20.txt + @if not os.path.exists('de_20.orig.aff'): + :copy de_20.aff de_20.orig.aff + @if not os.path.exists('de_20.orig.dic'): + :copy de_20.dic de_20.orig.dic + @if os.path.exists('de_20.diff'): + :sys patch <de_20.diff + +# The de_AT.dic is included in de_DE.zip. We rename the files and concatenate +# them. Complication is that de_AT.dic is missing a newline at the end. +# And the de_DE.dic file is used for something else. +de_AT.aff de_AT.dic: {buildcheck=} + :assertpkg unzip patch + + # Move de_DE files out of the way. + @if os.path.exists('de_DE.aff'): + :move de_DE.aff de_DE.temp.aff + @if os.path.exists('de_DE.dic'): + :move de_DE.dic de_DE.temp.dic + @if os.path.exists('README_de_DE.txt'): + :move README_de_DE.txt README_de_DE.temp.txt + + :fetch $ZIPFILE_AT + :sys $UNZIP $ZIPFILE_AT + :delete $ZIPFILE_AT + + :print >>de_AT.dic + # delete the first line, the word count + :sys $VIM -u NONE de_DE.dic -e -c 1delete -c wq + :cat de_DE.dic >>de_AT.dic + :delete de_DE.dic + :move de_DE.aff de_AT.aff + :move README_de_DE.txt README_de_AT.txt + + @if os.path.exists('de_DE.temp.aff'): + :move de_DE.temp.aff de_DE.aff + @if os.path.exists('de_DE.temp.dic'): + :move de_DE.temp.dic de_DE.dic + @if os.path.exists('README_de_DE.temp.txt'): + :move README_de_DE.temp.txt README_de_DE.txt + + @if not os.path.exists('de_AT.orig.aff'): + :copy de_AT.aff de_AT.orig.aff + @if not os.path.exists('de_AT.orig.dic'): + :copy de_AT.dic de_AT.orig.dic + @if os.path.exists('de_AT.diff'): + :sys patch <de_AT.diff + +de_CH.aff de_CH.dic: {buildcheck=} + :assertpkg unzip patch + :fetch $ZIPFILE_CH + :sys $UNZIP $ZIPFILE_CH + :delete $ZIPFILE_CH + @if not os.path.exists('de_CH.orig.aff'): + :copy de_CH.aff de_CH.orig.aff + @if not os.path.exists('de_CH.orig.dic'): + :copy de_CH.dic de_CH.orig.dic + @if os.path.exists('de_CH.diff'): + :sys patch <de_CH.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. +diff: + :assertpkg diff + :sys {force} diff -a -C 1 de_DE.orig.aff de_DE.aff >de_DE.diff + :sys {force} diff -a -C 1 de_DE.orig.dic de_DE.dic >>de_DE.diff + :sys {force} diff -a -C 1 de_19.orig.aff de_19.aff >de_19.diff + :sys {force} diff -a -C 1 de_19.orig.dic de_19.dic >>de_19.diff + :sys {force} diff -a -C 1 de_20.orig.aff de_20.aff >de_20.diff + :sys {force} diff -a -C 1 de_20.orig.dic de_20.dic >>de_20.diff + :sys {force} diff -a -C 1 de_AT.orig.aff de_AT.aff >de_AT.diff + :sys {force} diff -a -C 1 de_AT.orig.dic de_AT.dic >>de_AT.diff + :sys {force} diff -a -C 1 de_CH.orig.aff de_CH.aff >de_CH.diff + :sys {force} diff -a -C 1 de_CH.orig.dic de_CH.dic >>de_CH.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip patch + :fetch $ZIPFILES + :mkdir tmp + :cd tmp + @try: + # Do the _AT one first, it overwrites the _DE files. + :sys $UNZIP ../$ZIPFILE_AT + :print >>de_AT.dic + # delete the first line, the word count + :sys ../$VIM -u NONE de_DE.dic -e -c 1delete -c wq + :cat de_DE.dic >>de_AT.dic + :delete de_DE.dic + :move de_DE.aff de_AT.aff + :move README_de_DE.txt README_de_AT.txt + + :sys $UNZIP ../$ZIPFILE_DE + :move de_DE_comb.aff de_DE.aff + :move de_DE_comb.dic de_DE.dic + :move README_de_DE_comb.txt README_de_DE.txt + + :sys $UNZIP ../$ZIPFILE_19 + :move de_OLDSPELL.aff de_19.aff + :move de_OLDSPELL.dic de_19.dic + # there is no README file + :print There is no README file for the old spelling >!README_de_19.txt + :sys $UNZIP ../$ZIPFILE_20 + :move de_DE_neu.aff de_20.aff + :move de_DE_neu.dic de_20.dic + :move README_de_DE_neu.txt README_de_20.txt + + :sys $UNZIP ../$ZIPFILE_CH + + @import stat + @for nm in ['de_DE', 'de_19', 'de_20', 'de_AT', 'de_CH']: + @for ext in ['aff', 'dic']: + :sys {force} diff ../$(nm).orig.$ext $(nm).$ext >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy $(nm).$ext ../$(nm).new.$ext + :sys {force} diff ../README_$(nm).txt README_$(nm).txt >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy README_$(nm).txt ../README_$(nm).new.txt + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete $ZIPFILES + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/el/el_GR.diff b/share/vim/vim73/spell/el/el_GR.diff similarity index 100% rename from share/vim/vim72/spell/el/el_GR.diff rename to share/vim/vim73/spell/el/el_GR.diff diff --git a/share/vim/vim72/spell/el/main.aap b/share/vim/vim73/spell/el/main.aap similarity index 100% rename from share/vim/vim72/spell/el/main.aap rename to share/vim/vim73/spell/el/main.aap diff --git a/share/vim/vim72/spell/en.ascii.spl b/share/vim/vim73/spell/en.ascii.spl similarity index 100% rename from share/vim/vim72/spell/en.ascii.spl rename to share/vim/vim73/spell/en.ascii.spl diff --git a/share/vim/vim72/spell/en.ascii.sug b/share/vim/vim73/spell/en.ascii.sug similarity index 100% rename from share/vim/vim72/spell/en.ascii.sug rename to share/vim/vim73/spell/en.ascii.sug diff --git a/share/vim/vim72/spell/en.latin1.spl b/share/vim/vim73/spell/en.latin1.spl similarity index 100% rename from share/vim/vim72/spell/en.latin1.spl rename to share/vim/vim73/spell/en.latin1.spl diff --git a/share/vim/vim72/spell/en.latin1.sug b/share/vim/vim73/spell/en.latin1.sug similarity index 100% rename from share/vim/vim72/spell/en.latin1.sug rename to share/vim/vim73/spell/en.latin1.sug diff --git a/share/vim/vim72/spell/en.utf-8.spl b/share/vim/vim73/spell/en.utf-8.spl similarity index 100% rename from share/vim/vim72/spell/en.utf-8.spl rename to share/vim/vim73/spell/en.utf-8.spl diff --git a/share/vim/vim72/spell/en.utf-8.sug b/share/vim/vim73/spell/en.utf-8.sug similarity index 100% rename from share/vim/vim72/spell/en.utf-8.sug rename to share/vim/vim73/spell/en.utf-8.sug diff --git a/share/vim/vim72/spell/en/en_AU.diff b/share/vim/vim73/spell/en/en_AU.diff similarity index 100% rename from share/vim/vim72/spell/en/en_AU.diff rename to share/vim/vim73/spell/en/en_AU.diff diff --git a/share/vim/vim72/spell/en/en_CA.diff b/share/vim/vim73/spell/en/en_CA.diff similarity index 100% rename from share/vim/vim72/spell/en/en_CA.diff rename to share/vim/vim73/spell/en/en_CA.diff diff --git a/share/vim/vim72/spell/en/en_GB.diff b/share/vim/vim73/spell/en/en_GB.diff similarity index 100% rename from share/vim/vim72/spell/en/en_GB.diff rename to share/vim/vim73/spell/en/en_GB.diff diff --git a/share/vim/vim72/spell/en/en_NZ.diff b/share/vim/vim73/spell/en/en_NZ.diff similarity index 100% rename from share/vim/vim72/spell/en/en_NZ.diff rename to share/vim/vim73/spell/en/en_NZ.diff diff --git a/share/vim/vim72/spell/en/en_US.diff b/share/vim/vim73/spell/en/en_US.diff similarity index 100% rename from share/vim/vim72/spell/en/en_US.diff rename to share/vim/vim73/spell/en/en_US.diff diff --git a/share/vim/vim72/spell/en/main.aap b/share/vim/vim73/spell/en/main.aap similarity index 100% rename from share/vim/vim72/spell/en/main.aap rename to share/vim/vim73/spell/en/main.aap diff --git a/share/vim/vim72/spell/eo/eo_l3.diff b/share/vim/vim73/spell/eo/eo_l3.diff similarity index 100% rename from share/vim/vim72/spell/eo/eo_l3.diff rename to share/vim/vim73/spell/eo/eo_l3.diff diff --git a/share/vim/vim73/spell/eo/main.aap b/share/vim/vim73/spell/eo/main.aap new file mode 100644 index 0000000000..282b5b73ff --- /dev/null +++ b/share/vim/vim73/spell/eo/main.aap @@ -0,0 +1,80 @@ +# Aap recipe for Esperanto Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = eo_l3.aff eo_l3.dic + +all: $SPELLDIR/eo.iso-8859-3.spl $SPELLDIR/eo.utf-8.spl ../README_eo.txt + +$SPELLDIR/eo.iso-8859-3.spl : $FILES + :sys $VIM -u NONE -e -c "set enc=iso-8859-3" + -c "mkspell! $SPELLDIR/eo eo_l3" -c q + +$SPELLDIR/eo.utf-8.spl : $FILES + :sys $VIM -u NONE -e -c "set enc=utf-8" + -c "mkspell! $SPELLDIR/eo eo_l3" -c q + +../README_eo.txt : README_eo_l3.txt + :copy $source $target + # fix missing newline + :sys $VIM -u NONE -e -c "set ff=unix" -c wq $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} eo.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +eo_l3.aff eo_l3.dic: {buildcheck=} + :assertpkg unzip patch + :fetch eo.zip + :sys $UNZIP eo.zip + :delete eo.zip + @if not os.path.exists('eo_l3.orig.aff'): + :copy eo_l3.aff eo_l3.orig.aff + @if not os.path.exists('eo_l3.orig.dic'): + :copy eo_l3.dic eo_l3.orig.dic + @if os.path.exists('eo_l3.diff'): + :sys patch <eo_l3.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 eo_l3.orig.aff eo_l3.aff >eo_l3.diff + :sys {force} diff -a -C 1 eo_l3.orig.dic eo_l3.dic >>eo_l3.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch eo.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../eo.zip + :sys {force} diff ../eo_l3.orig.aff eo_l3.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy eo_l3.aff ../eo_l3.new.aff + :sys {force} diff ../eo_l3.orig.dic eo_l3.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy eo_l3.dic ../eo_l3.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete eo.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/es/es_ES.diff b/share/vim/vim73/spell/es/es_ES.diff similarity index 100% rename from share/vim/vim72/spell/es/es_ES.diff rename to share/vim/vim73/spell/es/es_ES.diff diff --git a/share/vim/vim73/spell/es/es_MX.diff b/share/vim/vim73/spell/es/es_MX.diff new file mode 100644 index 0000000000..d4c14e7bda --- /dev/null +++ b/share/vim/vim73/spell/es/es_MX.diff @@ -0,0 +1,6975 @@ +*** es_MX.orig.aff Thu Aug 25 19:19:45 2005 +--- es_MX.aff Thu Aug 25 19:19:45 2005 +*************** +*** 1,4 **** +! SET ISO8859-1 +! TRY aroeinltcsdumpbgvfhzóíjqáéñxyúüCkAMIESPGRJBFDVTHUOwLNKZÁY +! + SFX A Y 93 +--- 1,23 ---- +! SET ISO8859-1 +! TRY aroeinltcsdumpbgvfhzóíjqáéñxyúüCkAMIESPGRJBFDVTHUOwLNKZÁY +! +! FOL ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ +! LOW ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ +! UPP ßÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞÿ +! +! SOFOFROM abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþßÿÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞ¿ +! SOFOTO ebctefghejklnnepkrstevvkesebctefghejklnnepkrstevvkeseeeeeeeceeeeeeeedneeeeeeeeeeepseeeeeeeeceeeeeeeedneeeeeeeeeeep? +! +! MAP 9 +! MAP aàáâãäå +! MAP eèéêë +! MAP iìíîï +! MAP oòóôõö +! MAP uùúûü +! MAP nñ +! MAP cç +! MAP yÿý +! MAP sß +! +! + SFX A Y 93 +*************** +*** 7,12 **** + SFX A é ote é +! SFX A é ota é +! SFX A a illa a +! SFX A a illas a +! SFX A a ita a + SFX A a itas a +--- 26,31 ---- + SFX A é ote é +! SFX A é ota é +! SFX A a illa a +! SFX A a illas a +! SFX A a ita a + SFX A a itas a +*************** +*** 21,28 **** + SFX A co quilla co +! SFX A co quillas co +! SFX A co quillo co + SFX A co quillos co + SFX A co quita co +! SFX A co quitas co +! SFX A co quito co + SFX A co quitos co +--- 40,47 ---- + SFX A co quilla co +! SFX A co quillas co +! SFX A co quillo co + SFX A co quillos co + SFX A co quita co +! SFX A co quitas co +! SFX A co quito co + SFX A co quitos co +*************** +*** 36,59 **** + SFX A go guillo go +! SFX A go guillos go +! SFX A go guito go +! SFX A go guitos go +! SFX A io illa io +! SFX A io illas io +! SFX A io ita io +! SFX A io itas io +! SFX A io illo io +! SFX A io illos io +! SFX A io ito io +! SFX A io itos io +! SFX A o ito o +! SFX A o itos o +! SFX A o illo o +! SFX A o illos o +! SFX A o ita o +! SFX A o itas o +! SFX A o illa o +! SFX A o illas o +! SFX A o ota o +! SFX A o otas o +! SFX A o ote o + SFX A o otes o +--- 55,78 ---- + SFX A go guillo go +! SFX A go guillos go +! SFX A go guito go +! SFX A go guitos go +! SFX A io illa io +! SFX A io illas io +! SFX A io ita io +! SFX A io itas io +! SFX A io illo io +! SFX A io illos io +! SFX A io ito io +! SFX A io itos io +! SFX A o ito o +! SFX A o itos o +! SFX A o illo o +! SFX A o illos o +! SFX A o ita o +! SFX A o itas o +! SFX A o illa o +! SFX A o illas o +! SFX A o ota o +! SFX A o otas o +! SFX A o ote o + SFX A o otes o +*************** +*** 70,73 **** + SFX A zo cita zo +! SFX A zo citas zo +! SFX A zo cito zo + SFX A zo citos zo +--- 89,92 ---- + SFX A zo cita zo +! SFX A zo citas zo +! SFX A zo cito zo + SFX A zo citos zo +*************** +*** 76,85 **** + SFX A 0 cillo [er] +! SFX A 0 cillos [er] +! SFX A 0 cito [er] +! SFX A 0 citos [er] +! SFX A 0 cita [er] +! SFX A 0 citas [er] +! SFX A 0 sote [er] +! SFX A 0 sotes [er] +! SFX A 0 sota [er] + SFX A 0 sotas [er] +--- 95,104 ---- + SFX A 0 cillo [er] +! SFX A 0 cillos [er] +! SFX A 0 cito [er] +! SFX A 0 citos [er] +! SFX A 0 cita [er] +! SFX A 0 citas [er] +! SFX A 0 sote [er] +! SFX A 0 sotes [er] +! SFX A 0 sota [er] + SFX A 0 sotas [er] +*************** +*** 88,118 **** + SFX A 0 illo [ls] +! SFX A 0 illos [ls] +! SFX A 0 ita [ls] +! SFX A 0 itas [ls] +! SFX A 0 ito [ls] +! SFX A 0 itos [ls] +! SFX A 0 ota [ls] +! SFX A 0 otas [ls] +! SFX A 0 ote [ls] + SFX A 0 otes [ls] + +! SFX J Y 12 +! SFX J e ísimo e +! SFX J e ísimos e +! SFX J e ísima e +! SFX J e ísimas e +! SFX J o ísimo o +! SFX J o ísima o +! SFX J o ísimos o +! SFX J o ísimas o +! SFX J 0 ísimo l +! SFX J 0 ísima l +! SFX J 0 ísimos l +! SFX J 0 ísimas l +! + SFX M Y 8 + SFX M ble bilidad ble +! SFX M ble bilidades ble + SFX M o idad o +! SFX M o idades o + SFX M o amente o +--- 107,137 ---- + SFX A 0 illo [ls] +! SFX A 0 illos [ls] +! SFX A 0 ita [ls] +! SFX A 0 itas [ls] +! SFX A 0 ito [ls] +! SFX A 0 itos [ls] +! SFX A 0 ota [ls] +! SFX A 0 otas [ls] +! SFX A 0 ote [ls] + SFX A 0 otes [ls] + +! SFX J Y 12 +! SFX J e ísimo e +! SFX J e ísimos e +! SFX J e ísima e +! SFX J e ísimas e +! SFX J o ísimo o +! SFX J o ísima o +! SFX J o ísimos o +! SFX J o ísimas o +! SFX J 0 ísimo l +! SFX J 0 ísima l +! SFX J 0 ísimos l +! SFX J 0 ísimas l +! + SFX M Y 8 + SFX M ble bilidad ble +! SFX M ble bilidades ble + SFX M o idad o +! SFX M o idades o + SFX M o amente o +*************** +*** 120,3490 **** + SFX M 0 idades [elnrsz] +! SFX M 0 mente [elnrsz] +! +! SFX N Y 2 +! SFX N r damente [ai]r +! SFX N er idamente er +! +! SFX P Y 20 +! SFX P e a e +! SFX P o a o +! SFX P 0 s [eo] +! SFX P o as o +! SFX P e as e +! SFX P án ana án +! SFX P án anes án +! SFX P án anas án +! SFX P ín ina ín +! SFX P ín ines ín +! SFX P ín inas ín +! SFX P ón ona ón +! SFX P ón ones ón +! SFX P ón onas ón +! SFX P 0 a [^aons] +! SFX P 0 es [^aons] +! SFX P 0 as [^aons] +! SFX P és esa és +! SFX P és eses és +! SFX P és esas és +! +! SFX H Y 2 +! SFX H r ción [ai]r +! SFX H r ciones [ai]r +! +! SFX I Y 4 +! SFX I r miento [ai]r +! SFX I r mientos [ai]r +! SFX I er imiento er +! SFX I er imientos er +! +! SFX L Y 6 +! SFX L r nte ar +! SFX L r ntes ar +! SFX L er iente er +! SFX L er ientes er +! SFX L r ente ir +! SFX L r entes ir +! +! SFX R Y 20 +! SFX R 0 me [aei]r +! SFX R 0 te [aei]r +! SFX R 0 se [aei]r +! SFX R 0 nos [aei]r +! SFX R 0 os [aei]r +! SFX R ar ándome ar +! SFX R ar ándote ar +! SFX R ar ándose ar +! SFX R ar ándonos ar +! SFX R ar ándoos ar +! SFX R er iéndome er +! SFX R er iéndote er +! SFX R er iéndose er +! SFX R er iéndonos er +! SFX R er iéndoos er +! SFX R r éndome ir +! SFX R r éndote ir +! SFX R r éndose ir +! SFX R r éndonos ir +! SFX R r éndoos ir +! +! SFX S Y 11 +! SFX S 0 s [aeiouáéó] +! SFX S 0 es [úídjlry] +! SFX S z ces z +! SFX S 0 es [^é]s +! SFX S 0 es [^áéíóú]n +! SFX S án anes án +! SFX S én enes én +! SFX S ín ines ín +! SFX S ón ones ón +! SFX S ún unes ún +! SFX S és eses és +! +! SFX T Y 24 +! SFX T 0 lo [aei]r +! SFX T 0 la [aei]r +! SFX T 0 le [aei]r +! SFX T 0 los [aei]r +! SFX T 0 las [aei]r +! SFX T 0 les [aei]r +! SFX T ar ándolo ar +! SFX T ar ándola ar +! SFX T ar ándole ar +! SFX T ar ándolos ar +! SFX T ar ándolas ar +! SFX T ar ándoles ar +! SFX T er iéndolo er +! SFX T er iéndola er +! SFX T er iéndole er +! SFX T er iéndolos er +! SFX T er iéndolas er +! SFX T er iéndoles er +! SFX T r éndolo ir +! SFX T r éndola ir +! SFX T r éndole ir +! SFX T r éndolos ir +! SFX T r éndolas ir +! SFX T r éndoles ir +! +! SFX U Y 120 +! SFX U ar ármelo ar +! SFX U ar ártelo ar +! SFX U ar árselo ar +! SFX U ar árnoslo ar +! SFX U ar ároslo ar +! SFX U ar ármela ar +! SFX U ar ártela ar +! SFX U ar ársela ar +! SFX U ar árnosla ar +! SFX U ar árosla ar +! SFX U ar ármelos ar +! SFX U ar ártelos ar +! SFX U ar árselos ar +! SFX U ar árnoslos ar +! SFX U ar ároslos ar +! SFX U ar ármelas ar +! SFX U ar ártelas ar +! SFX U ar árselas ar +! SFX U ar árnoslas ar +! SFX U ar ároslas ar +! SFX U ar ándomelo ar +! SFX U ar ándotelo ar +! SFX U ar ándoselo ar +! SFX U ar ándonoslo ar +! SFX U ar ándooslo ar +! SFX U ar ándomela ar +! SFX U ar ándotela ar +! SFX U ar ándosela ar +! SFX U ar ándonosla ar +! SFX U ar ándoosla ar +! SFX U ar ándomelos ar +! SFX U ar ándotelos ar +! SFX U ar ándoselos ar +! SFX U ar ándonoslos ar +! SFX U ar ándooslos ar +! SFX U ar ándomelas ar +! SFX U ar ándotelas ar +! SFX U ar ándoselas ar +! SFX U ar ándonoslas ar +! SFX U ar ándooslas ar +! SFX U er érmelo er +! SFX U er értelo er +! SFX U er érselo er +! SFX U er érnoslo er +! SFX U er éroslo er +! SFX U er érmela er +! SFX U er értela er +! SFX U er érsela er +! SFX U er érnosla er +! SFX U er érosla er +! SFX U er érmelos er +! SFX U er értelos er +! SFX U er érselos er +! SFX U er érnoslos er +! SFX U er éroslos er +! SFX U er érmelas er +! SFX U er értelas er +! SFX U er érselas er +! SFX U er érnoslas er +! SFX U er éroslas er +! SFX U er iéndomelo er +! SFX U er iéndotelo er +! SFX U er iéndoselo er +! SFX U er iéndonoslo er +! SFX U er iéndooslo er +! SFX U er iéndomela er +! SFX U er iéndotela er +! SFX U er iéndosela er +! SFX U er iéndonosla er +! SFX U er iéndoosla er +! SFX U er iéndomelos er +! SFX U er iéndotelos er +! SFX U er iéndoselos er +! SFX U er iéndonoslos er +! SFX U er iéndooslos er +! SFX U er iéndomelas er +! SFX U er iéndotelas er +! SFX U er iéndoselas er +! SFX U er iéndonoslas er +! SFX U er iéndooslas er +! SFX U ir írmelo ir +! SFX U ir írtelo ir +! SFX U ir írselo ir +! SFX U ir írnoslo ir +! SFX U ir íroslo ir +! SFX U ir írmela ir +! SFX U ir írtela ir +! SFX U ir írsela ir +! SFX U ir írnosla ir +! SFX U ir írosla ir +! SFX U ir írmelas ir +! SFX U ir írtelas ir +! SFX U ir írselas ir +! SFX U ir írnoslas ir +! SFX U ir íroslas ir +! SFX U ir írmelos ir +! SFX U ir írtelos ir +! SFX U ir írselos ir +! SFX U ir írnoslos ir +! SFX U ir íroslos ir +! SFX U r éndomelo ir +! SFX U r éndotelo ir +! SFX U r éndoselo ir +! SFX U r éndonoslo ir +! SFX U r éndooslo ir +! SFX U r éndomela ir +! SFX U r éndotela ir +! SFX U r éndosela ir +! SFX U r éndonosla ir +! SFX U r éndoosla ir +! SFX U r éndomelos ir +! SFX U r éndotelos ir +! SFX U r éndoselos ir +! SFX U r éndonoslos ir +! SFX U r éndooslos ir +! SFX U r éndomelas ir +! SFX U r éndotelas ir +! SFX U r éndoselas ir +! SFX U r éndonoslas ir +! SFX U r éndooslas ir +! +! SFX V Y 169 +! SFX V ar o ar +! SFX V er o [^cg]er +! SFX V cer zo cer +! SFX V ger jo ger +! SFX V ir o [^cgu]ir +! SFX V cir zo cir +! SFX V gir jo gir +! SFX V uir o guir +! SFX V quir co quir +! SFX V r s [ae]r +! SFX V ir es ir +! SFX V ar a ar +! SFX V er e er +! SFX V ir e ir +! SFX V r mos [aei]r +! SFX V ar áis ar +! SFX V er éis er +! SFX V ir ís ir +! SFX V r n [ae]r +! SFX V ir en ir +! SFX V r ba ar +! SFX V er ía er +! SFX V ir ía ir +! SFX V r bas ar +! SFX V er ías er +! SFX V ir ías ir +! SFX V ar ábamos ar +! SFX V er íamos er +! SFX V ir íamos ir +! SFX V r bais ar +! SFX V er íais er +! SFX V ir íais ir +! SFX V r ban ar +! SFX V er ían er +! SFX V ir ían ir +! SFX V ar é [^czg]ar +! SFX V car qué car +! SFX V ar ué gar +! SFX V zar cé zar +! SFX V er í er +! SFX V ir í ir +! SFX V r ste [ai]r +! SFX V er iste er +! SFX V ar ó ar +! SFX V er ió er +! SFX V r ó ir +! SFX V er imos er +! SFX V r steis [ai]r +! SFX V er isteis er +! SFX V 0 on ar +! SFX V er ieron er +! SFX V r eron ir +! SFX V 0 é [aei]r +! SFX V 0 ás [aei]r +! SFX V 0 á [aei]r +! SFX V 0 emos [aei]r +! SFX V 0 éis [aei]r +! SFX V 0 án [aei]r +! SFX V 0 ía [aei]r +! SFX V 0 ías [aei]r +! SFX V 0 íamos [aei]r +! SFX V 0 íais [aei]r +! SFX V 0 ían [aei]r +! SFX V ar e [^czg]ar +! SFX V car que car +! SFX V ar ue gar +! SFX V zar ce zar +! SFX V er a [^cg]er +! SFX V cer za cer +! SFX V ger ja ger +! SFX V ir a [^cgu]ir +! SFX V cir za cir +! SFX V gir ja gir +! SFX V uir a guir +! SFX V quir ca quir +! SFX V ar es [^czg]ar +! SFX V car ques car +! SFX V ar ues gar +! SFX V zar ces zar +! SFX V er as [^cg]er +! SFX V cer zas cer +! SFX V ger jas ger +! SFX V ir as [^cgu]ir +! SFX V cir zas cir +! SFX V gir jas gir +! SFX V uir as guir +! SFX V quir cas quir +! SFX V ar emos [^czg]ar +! SFX V car quemos car +! SFX V ar uemos gar +! SFX V zar cemos zar +! SFX V er amos [^cg]er +! SFX V cer zamos cer +! SFX V ger jamos ger +! SFX V ir amos [^cgu]ir +! SFX V cir zamos cir +! SFX V gir jamos gir +! SFX V uir amos guir +! SFX V quir camos quir +! SFX V ar éis [^czg]ar +! SFX V car quéis car +! SFX V ar uéis gar +! SFX V zar céis zar +! SFX V er áis [^cg]er +! SFX V cer záis cer +! SFX V ger jáis ger +! SFX V ir áis [^cgu]ir +! SFX V cir záis cir +! SFX V gir jáis gir +! SFX V uir áis guir +! SFX V quir cáis quir +! SFX V ar en [^czg]ar +! SFX V car quen car +! SFX V ar uen gar +! SFX V zar cen zar +! SFX V er an [^cg]er +! SFX V cer zan cer +! SFX V ger jan ger +! SFX V ir an [^cgu]ir +! SFX V cir zan cir +! SFX V gir jan gir +! SFX V uir an guir +! SFX V quir can quir +! SFX V r se ar +! SFX V r ra ar +! SFX V er iese er +! SFX V er iera er +! SFX V r ese ir +! SFX V r era ir +! SFX V r ses ar +! SFX V r ras ar +! SFX V er ieses er +! SFX V er ieras er +! SFX V r eses ir +! SFX V r eras ir +! SFX V ar ásemos ar +! SFX V ar áramos ar +! SFX V er iésemos er +! SFX V er iéramos er +! SFX V r ésemos ir +! SFX V r éramos ir +! SFX V r seis ar +! SFX V r rais ar +! SFX V er ieseis er +! SFX V er ierais er +! SFX V r eseis ir +! SFX V r erais ir +! SFX V r sen ar +! SFX V r ran ar +! SFX V er iesen er +! SFX V er ieran er +! SFX V r esen ir +! SFX V r eran ir +! SFX V r re ar +! SFX V er iere er +! SFX V r ere ir +! SFX V r res ar +! SFX V er ieres er +! SFX V r eres ir +! SFX V ar áremos ar +! SFX V er iéremos er +! SFX V r éremos ir +! SFX V r reis ar +! SFX V er iereis er +! SFX V r ereis ir +! SFX V r ren ar +! SFX V er ieren er +! SFX V r eren ir +! SFX V r d r +! +! SFX X Y 11 +! SFX X r do [ai]r +! SFX X r dos [ai]r +! SFX X r da [ai]r +! SFX X r das [ai]r +! SFX X er ido er +! SFX X er idos er +! SFX X er ida er +! SFX X er idas er +! SFX X r ndo ar +! SFX X er iendo er +! SFX X r endo ir +! +! SFX W Y 197 S +! SFX W ar a andar +! SFX W ar a guar +! SFX W er a [eo]er +! SFX W r ba ar +! SFX W obar ueba obar +! SFX W ebir iba ebir +! SFX W erbar ierba erbar +! SFX W ibir íba ohibir +! SFX W ocar ueca ocar +! SFX W olcar uelca olcar +! SFX W orcar uerca orcar +! SFX W cer zca [^c]ocer +! SFX W cer zca [^fh]acer +! SFX W cer zca ecer +! SFX W cir zca ucir +! SFX W eder ieda eder +! SFX W odar ueda odar +! SFX W oder ueda oder +! SFX W edir ida edir +! SFX W oldar uelda [^g]oldar +! SFX W oldar üelda goldar +! SFX W endar ienda endar +! SFX W ender ienda ender +! SFX W endir inda endir +! SFX W erder ierda erder +! SFX W ordar uerda ordar +! SFX W order uerda order +! SFX W cer ga [fh]acer +! SFX W er ga [eo]ner +! SFX W er ga aler +! SFX W ir ga alir +! SFX W gar ega ugar +! SFX W egar iega egar +! SFX W ogar uega ogar +! SFX W ecir iga ecir +! SFX W eguir iga eguir +! SFX W er iga aer +! SFX W er iga oer +! SFX W ír iga oír +! SFX W olgar uelga olgar +! SFX W enir enga enir +! SFX W engar ienga engar +! SFX W enchir incha enchir +! SFX W egir ija egir +! SFX W ijar íja [ae]hijar +! SFX W oblar uebla oblar +! SFX W emblar iembla emblar +! SFX W elar iela elar +! SFX W olar uela olar +! SFX W oler uela oler +! SFX W ollar uella [^g]ollar +! SFX W ollar üella gollar +! SFX W ilar íla [ae]hilar +! SFX W emir ima emir +! SFX W ormir uerma ormir +! SFX W umar úma [ae]humar +! SFX W onar uena onar +! SFX W ernar ierna ernar +! SFX W erner ierna erner +! SFX W ernir ierna ernir +! SFX W ornar uerna ornar +! SFX W inar ína [aeo]hinar +! SFX W unir úna eunir +! SFX W aber epa saber +! SFX W caber quepa caber +! SFX W r ra [^a]ndar +! SFX W r ra [^d]ar +! SFX W r ra [^n]dar +! SFX W ebrar iebra ebrar +! SFX W embrar iembra embrar +! SFX W edrar iedra edrar +! SFX W endrar iendra endrar +! SFX W r era alir +! SFX W r era ernir +! SFX W r era eunir +! SFX W r era ohibir +! SFX W er iera [^fh]acer +! SFX W er iera aler +! SFX W er iera e[cd]er +! SFX W er iera ender +! SFX W er iera er[dnt]er +! SFX W er iera o[clv]er +! SFX W er iera olver +! SFX W er iera or[cd]er +! SFX W erer iera erer +! SFX W erir iera erir +! SFX W eír iera eír +! SFX W irir iera irir +! SFX W ebir ibiera ebir +! SFX W acer iciera [fh]acer +! SFX W edir idiera edir +! SFX W endir indiera endir +! SFX W oder udiera oder +! SFX W egir igiera egir +! SFX W enchir inchiera enchir +! SFX W emir imiera emir +! SFX W ormir urmiera ormir +! SFX W enir iniera enir +! SFX W aber upiera aber +! SFX W erir iriera erir +! SFX W irir iriera irir +! SFX W orir uriera orir +! SFX W erer isiera erer +! SFX W oner usiera oner +! SFX W etir itiera etir +! SFX W entir intiera entir +! SFX W ertir irtiera ertir +! SFX W estir istiera estir +! SFX W eguir iguiera eguir +! SFX W ervir irviera ervir +! SFX W ar uviera andar +! SFX W ener uviera ener +! SFX W cir jera ucir +! SFX W er jera raer +! SFX W ecir ijera ecir +! SFX W orar uera [^g]orar +! SFX W orir uera orir +! SFX W er yera [eo]er +! SFX W er yera caer +! SFX W ir yera [^g]uir +! SFX W ír yera oír +! SFX W üir uyera güir +! SFX W eñir iñera eñir +! SFX W orar üera gorar +! SFX W errar ierra errar +! SFX W ontrar uentra ontrar +! SFX W ostrar uestra ostrar +! SFX W esar iesa esar +! SFX W osar uesa osar +! SFX W ensar iensa ensar +! SFX W usar úsa [ae]husar +! SFX W etar ieta etar +! SFX W etir ita etir +! SFX W oltar uelta oltar +! SFX W entar ienta entar +! SFX W entir ienta entir +! SFX W ontar uenta ontar +! SFX W ertar ierta ertar +! SFX W erter ierta erter +! SFX W ertir ierta ertir +! SFX W ortar uerta ortar +! SFX W estar iesta estar +! SFX W ostar uesta ostar +! SFX W estir ista estir +! SFX W itar íta [ae]hitar +! SFX W evar ieva evar +! SFX W ovar ueva ovar +! SFX W over ueva over +! SFX W olver uelva olver +! SFX W ervir irva ervir +! SFX W er ya oer +! SFX W ir ya [^g]uir +! SFX W üir uya güir +! SFX W ezar ieza ezar +! SFX W ocer ueza cocer +! SFX W enzar ienza enzar +! SFX W onzar üenza gonzar +! SFX W orcer uerza orcer +! SFX W orzar uerza orzar +! SFX W izar íza [ae]izar +! SFX W 0 ía [^fh]acer +! SFX W 0 ía [aeo]er +! SFX W 0 ía [io]rir +! SFX W 0 ía [üu]ir +! SFX W 0 ía ar +! SFX W 0 ía e[bdgmrtñ]ir +! SFX W 0 ía e[cd]er +! SFX W 0 ía e[ns]tir +! SFX W 0 ía enchir +! SFX W 0 ía ender +! SFX W 0 ía endir +! SFX W 0 ía er[dnt]er +! SFX W 0 ía er[ntv]ir +! SFX W 0 ía eunir +! SFX W 0 ía o[clv]er +! SFX W 0 ía olver +! SFX W 0 ía or[cd]er +! SFX W 0 ía ormir +! SFX W 0 ía ucir +! SFX W er ía er +! SFX W eír ía eír +! SFX W iar ía iar +! SFX W ir ía ir +! SFX W ír ía ír +! SFX W cer ría [fh]acer +! SFX W er ría aber +! SFX W er ría erer +! SFX W er ría oder +! SFX W er dría [eo]ner +! SFX W er dría aler +! SFX W ir dría alir +! SFX W ir dría enir +! SFX W ecir iría ecir +! SFX W ír iría [eo]ír +! SFX W oñar ueña oñar +! SFX W eñir iña eñir +! SFX W uar úa [^g]uar +! +! SFX W Y 264 S +! SFX W ar e andar +! SFX W er e [^c]ocer +! SFX W er e [cr]aer +! SFX W er e [eo]er +! SFX W er e a[bcl]er +! SFX W er e ecer +! SFX W er e oner +! SFX W ir e alir +! SFX W ir e ucir +! SFX W obar uebe obar +! SFX W ebir ibe ebir +! SFX W erbar ierbe erbar +! SFX W ibir íbe ohibir +! SFX W ezar iece ezar +! SFX W ocer uece cocer +! SFX W acer ice [fh]acer +! SFX W ecir ice ecir +! SFX W enzar ience enzar +! SFX W onzar üence gonzar +! SFX W orcer uerce orcer +! SFX W orzar uerce orzar +! SFX W izar íce [ae]izar +! SFX W eder iede eder +! SFX W odar uede odar +! SFX W oder uede oder +! SFX W edir ide edir +! SFX W oldar uelde [^g]oldar +! SFX W oldar üelde goldar +! SFX W endar iende endar +! SFX W ender iende ender +! SFX W endir inde endir +! SFX W erder ierde erder +! SFX W ordar uerde ordar +! SFX W order uerde order +! SFX W oder ude oder +! SFX W egir ige egir +! SFX W enchir inche enchir +! SFX W cir je ucir +! SFX W er je raer +! SFX W ecir ije ecir +! SFX W ijar íje [ae]hijar +! SFX W oblar ueble oblar +! SFX W emblar iemble emblar +! SFX W elar iele elar +! SFX W olar uele olar +! SFX W oler uele oler +! SFX W ollar uelle [^g]ollar +! SFX W ollar üelle gollar +! SFX W ilar íle [ae]hilar +! SFX W emir ime emir +! SFX W ormir uerme ormir +! SFX W umar úme [ae]humar +! SFX W ener iene ener +! SFX W enir iene enir +! SFX W onar uene onar +! SFX W enir ine enir +! SFX W ernar ierne ernar +! SFX W erner ierne erner +! SFX W ernir ierne ernir +! SFX W ornar uerne ornar +! SFX W inar íne [aeo]hinar +! SFX W unir úne eunir +! SFX W aber upe aber +! SFX W r re [^a]ndar +! SFX W r re [^d]ar +! SFX W r re [^n]dar +! SFX W ebrar iebre ebrar +! SFX W embrar iembre embrar +! SFX W edrar iedre edrar +! SFX W endrar iendre endrar +! SFX W r ere alir +! SFX W r ere ernir +! SFX W r ere eunir +! SFX W r ere ohibir +! SFX W er iere [^fh]acer +! SFX W er iere aler +! SFX W er iere e[cd]er +! SFX W er iere ender +! SFX W er iere er[dnt]er +! SFX W er iere o[clv]er +! SFX W er iere olver +! SFX W er iere or[cd]er +! SFX W erer iere erer +! SFX W erir iere erir +! SFX W eír iere eír +! SFX W irir iere irir +! SFX W ebir ibiere ebir +! SFX W acer iciere [fh]acer +! SFX W edir idiere edir +! SFX W endir indiere endir +! SFX W oder udiere oder +! SFX W egir igiere egir +! SFX W enchir inchiere enchir +! SFX W emir imiere emir +! SFX W ormir urmiere ormir +! SFX W enir iniere enir +! SFX W aber upiere aber +! SFX W erir iriere erir +! SFX W irir iriere irir +! SFX W orir uriere orir +! SFX W erer isiere erer +! SFX W oner usiere oner +! SFX W etir itiere etir +! SFX W entir intiere entir +! SFX W ertir irtiere ertir +! SFX W estir istiere estir +! SFX W eguir iguiere eguir +! SFX W ervir irviere ervir +! SFX W ar uviere andar +! SFX W ener uviere ener +! SFX W cir jere ucir +! SFX W er jere raer +! SFX W ecir ijere ecir +! SFX W orar uere [^g]orar +! SFX W orir uere orir +! SFX W er yere [eo]er +! SFX W er yere caer +! SFX W ir yere [^g]uir +! SFX W ír yere oír +! SFX W üir uyere güir +! SFX W eñir iñere eñir +! SFX W orar üere gorar +! SFX W errar ierre errar +! SFX W ontrar uentre ontrar +! SFX W ostrar uestre ostrar +! SFX W r se [^a]ndar +! SFX W r se [^d]ar +! SFX W r se [^n]dar +! SFX W r ese alir +! SFX W r ese ernir +! SFX W r ese eunir +! SFX W r ese ohibir +! SFX W er iese [^fh]acer +! SFX W er iese aler +! SFX W er iese e[cd]er +! SFX W er iese ender +! SFX W er iese er[dnt]er +! SFX W er iese o[clv]er +! SFX W er iese olver +! SFX W er iese or[cd]er +! SFX W esar iese esar +! SFX W eír iese eír +! SFX W ebir ibiese ebir +! SFX W acer iciese [fh]acer +! SFX W edir idiese edir +! SFX W endir indiese endir +! SFX W oder udiese oder +! SFX W egir igiese egir +! SFX W enchir inchiese enchir +! SFX W emir imiese emir +! SFX W ormir urmiese ormir +! SFX W enir iniese enir +! SFX W aber upiese aber +! SFX W erir iriese erir +! SFX W irir iriese irir +! SFX W orir uriese orir +! SFX W erer isiese erer +! SFX W oner usiese oner +! SFX W etir itiese etir +! SFX W entir intiese entir +! SFX W ertir irtiese ertir +! SFX W estir istiese estir +! SFX W eguir iguiese eguir +! SFX W ervir irviese ervir +! SFX W ar uviese andar +! SFX W ener uviese ener +! SFX W cir jese ucir +! SFX W er jese raer +! SFX W ecir ijese ecir +! SFX W osar uese osar +! SFX W er yese [eo]er +! SFX W er yese caer +! SFX W ir yese [^g]uir +! SFX W ír yese oír +! SFX W üir uyese güir +! SFX W eñir iñese eñir +! SFX W erer ise erer +! SFX W ensar iense ensar +! SFX W oner use oner +! SFX W umar úse [ae]husar +! SFX W etar iete etar +! SFX W etir ite etir +! SFX W oltar uelte oltar +! SFX W entar iente entar +! SFX W entir iente entir +! SFX W ontar uente ontar +! SFX W ertar ierte ertar +! SFX W erter ierte erter +! SFX W ertir ierte ertir +! SFX W ortar uerte ortar +! SFX W r ste [^a]ndar +! SFX W r ste [^d]ar +! SFX W r ste [^n]dar +! SFX W r ste [eo]ír +! SFX W r ste [üu]ir +! SFX W r ste alir +! SFX W r ste ebir +! SFX W r ste edir +! SFX W r ste egir +! SFX W r ste emir +! SFX W r ste enchir +! SFX W r ste endir +! SFX W r ste entir +! SFX W r ste erir +! SFX W r ste ernir +! SFX W r ste ertir +! SFX W r ste ervir +! SFX W r ste estir +! SFX W r ste etir +! SFX W r ste eunir +! SFX W r ste eñir +! SFX W r ste irir +! SFX W r ste orir +! SFX W r ste ormir +! SFX W estar ieste estar +! SFX W ostar ueste ostar +! SFX W er iste [^fh]acer +! SFX W er iste aler +! SFX W er iste e[cd]er +! SFX W er iste ender +! SFX W er iste er[dnt]er +! SFX W er iste o[clv]er +! SFX W er iste olver +! SFX W er iste or[cd]er +! SFX W estir iste estir +! SFX W acer iciste [fh]acer +! SFX W oder udiste oder +! SFX W cir jiste ucir +! SFX W er jiste raer +! SFX W ecir ijiste ecir +! SFX W enir iniste enir +! SFX W aber upiste aber +! SFX W erer isiste erer +! SFX W oner usiste oner +! SFX W ar uviste andar +! SFX W ener uviste ener +! SFX W er íste [eo]er +! SFX W er íste caer +! SFX W itar íte [ae]hitar +! SFX W gar egue ugar +! SFX W egar iegue egar +! SFX W ogar uegue ogar +! SFX W eguir igue eguir +! SFX W olgar uelgue olgar +! SFX W engar iengue engar +! SFX W ocar ueque ocar +! SFX W olcar uelque olcar +! SFX W orcar uerque orcar +! SFX W evar ieve evar +! SFX W ovar ueve ovar +! SFX W over ueve over +! SFX W olver uelve olver +! SFX W ervir irve ervir +! SFX W ar uve andar +! SFX W ener uve ener +! SFX W ír ye oír +! SFX W uir uye [^g]uir +! SFX W üir uye güir +! SFX W eír íe eír +! SFX W iar íe iar +! SFX W oñar ueñe oñar +! SFX W eñir iñe eñir +! SFX W uar úe [^g]uar +! SFX W uar üe guar +! +! +! SFX W Y 195 S +! SFX W er an [eo]er +! SFX W r ban ar +! SFX W obar ueban obar +! SFX W ebir iban ebir +! SFX W erbar ierban erbar +! SFX W ibir íban ohibir +! SFX W ocar uecan ocar +! SFX W olcar uelcan olcar +! SFX W orcar uercan orcar +! SFX W cer zcan [^c]ocer +! SFX W cer zcan [^fh]acer +! SFX W cer zcan ecer +! SFX W cir zcan ucir +! SFX W eder iedan eder +! SFX W odar uedan odar +! SFX W oder uedan oder +! SFX W edir idan edir +! SFX W oldar ueldan [^g]oldar +! SFX W oldar üeldan goldar +! SFX W endar iendan endar +! SFX W ender iendan ender +! SFX W endir indan endir +! SFX W erder ierdan erder +! SFX W ordar uerdan ordar +! SFX W order uerdan order +! SFX W cer gan [fh]acer +! SFX W er gan [eo]ner +! SFX W er gan aler +! SFX W ir gan alir +! SFX W gar egan ugar +! SFX W egar iegan egar +! SFX W ogar uegan ogar +! SFX W ecir igan ecir +! SFX W eguir igan eguir +! SFX W er igan aer +! SFX W er igan oer +! SFX W ír igan oír +! SFX W olgar uelgan olgar +! SFX W enir engan enir +! SFX W engar iengan engar +! SFX W enchir inchan enchir +! SFX W egir ijan egir +! SFX W ijar íjan [ae]hijar +! SFX W oblar ueblan oblar +! SFX W emblar iemblan emblar +! SFX W elar ielan elar +! SFX W olar uelan olar +! SFX W oler uelan oler +! SFX W ollar uellan [^g]ollar +! SFX W ollar üellan gollar +! SFX W ilar ílan [ae]hilar +! SFX W emir iman emir +! SFX W ormir uerman ormir +! SFX W umar úman [ae]humar +! SFX W onar uenan onar +! SFX W ernar iernan ernar +! SFX W erner iernan erner +! SFX W ernir iernan ernir +! SFX W ornar uernan ornar +! SFX W inar ínan [aeo]hinar +! SFX W unir únan eunir +! SFX W aber epan saber +! SFX W caber quepan caber +! SFX W r ran [^a]ndar +! SFX W r ran [^d]ar +! SFX W r ran [^n]dar +! SFX W ebrar iebran ebrar +! SFX W embrar iembran embrar +! SFX W edrar iedran edrar +! SFX W endrar iendran endrar +! SFX W r eran alir +! SFX W r eran ernir +! SFX W r eran eunir +! SFX W r eran ohibir +! SFX W er ieran [^fh]acer +! SFX W er ieran aler +! SFX W er ieran e[cd]er +! SFX W er ieran ender +! SFX W er ieran er[dnt]er +! SFX W er ieran o[clv]er +! SFX W er ieran olver +! SFX W er ieran or[cd]er +! SFX W erer ieran erer +! SFX W erir ieran erir +! SFX W eír ieran eír +! SFX W irir ieran irir +! SFX W ebir ibieran ebir +! SFX W acer icieran [fh]acer +! SFX W edir idieran edir +! SFX W endir indieran endir +! SFX W oder udieran oder +! SFX W egir igieran egir +! SFX W enchir inchieran enchir +! SFX W emir imieran emir +! SFX W ormir urmieran ormir +! SFX W enir inieran enir +! SFX W aber upieran aber +! SFX W erir irieran erir +! SFX W irir irieran irir +! SFX W orir urieran orir +! SFX W erer isieran erer +! SFX W oner usieran oner +! SFX W etir itieran etir +! SFX W entir intieran entir +! SFX W ertir irtieran ertir +! SFX W estir istieran estir +! SFX W eguir iguieran eguir +! SFX W ervir irvieran ervir +! SFX W ar uvieran andar +! SFX W ener uvieran ener +! SFX W cir jeran ucir +! SFX W er jeran raer +! SFX W ecir ijeran ecir +! SFX W orar ueran [^g]orar +! SFX W orir ueran orir +! SFX W er yeran [eo]er +! SFX W er yeran caer +! SFX W ir yeran [^g]uir +! SFX W ír yeran oír +! SFX W üir uyeran güir +! SFX W eñir iñeran eñir +! SFX W orar üeran gorar +! SFX W errar ierran errar +! SFX W ontrar uentran ontrar +! SFX W ostrar uestran ostrar +! SFX W esar iesan esar +! SFX W osar uesan osar +! SFX W ensar iensan ensar +! SFX W usar úsan [ae]husar +! SFX W etar ietan etar +! SFX W etir itan etir +! SFX W oltar ueltan oltar +! SFX W entar ientan entar +! SFX W entir ientan entir +! SFX W ontar uentan ontar +! SFX W ertar iertan ertar +! SFX W erter iertan erter +! SFX W ertir iertan ertir +! SFX W ortar uertan ortar +! SFX W estar iestan estar +! SFX W ostar uestan ostar +! SFX W estir istan estir +! SFX W itar ítan [ae]hitar +! SFX W evar ievan evar +! SFX W ovar uevan ovar +! SFX W over uevan over +! SFX W olver uelvan olver +! SFX W ervir irvan ervir +! SFX W er yan oer +! SFX W ir yan [^g]uir +! SFX W üir uyan güir +! SFX W ezar iezan ezar +! SFX W ocer uezan cocer +! SFX W enzar ienzan enzar +! SFX W onzar üenzan gonzar +! SFX W orcer uerzan orcer +! SFX W orzar uerzan orzar +! SFX W izar ízan [ae]izar +! SFX W 0 ían [^fh]acer +! SFX W 0 ían [aeo]er +! SFX W 0 ían [io]rir +! SFX W 0 ían [üu]ir +! SFX W 0 ían ar +! SFX W 0 ían e[bdgmrtñ]ir +! SFX W 0 ían e[cd]er +! SFX W 0 ían e[ns]tir +! SFX W 0 ían enchir +! SFX W 0 ían ender +! SFX W 0 ían endir +! SFX W 0 ían er[dnt]er +! SFX W 0 ían er[ntv]ir +! SFX W 0 ían eunir +! SFX W 0 ían o[clv]er +! SFX W 0 ían olver +! SFX W 0 ían or[cd]er +! SFX W 0 ían ormir +! SFX W 0 ían ucir +! SFX W er ían er +! SFX W eír ían eír +! SFX W iar ían iar +! SFX W ir ían ir +! SFX W ír ían ír +! SFX W cer rían [fh]acer +! SFX W er rían aber +! SFX W er rían erer +! SFX W er rían oder +! SFX W er drían [eo]ner +! SFX W er drían aler +! SFX W ir drían alir +! SFX W ir drían enir +! SFX W ecir irían ecir +! SFX W ír irían [eo]ír +! SFX W oñar ueñan oñar +! SFX W eñir iñan eñir +! SFX W uar úan [^g]uar +! +! +! SFX W Y 202 S +! SFX W ar en andar +! SFX W ir en alir +! SFX W ir en ucir +! SFX W obar ueben obar +! SFX W ebir iben ebir +! SFX W erbar ierben erbar +! SFX W ibir íben ohibir +! SFX W ezar iecen ezar +! SFX W ocer uecen cocer +! SFX W ecir icen ecir +! SFX W enzar iencen enzar +! SFX W onzar üencen gonzar +! SFX W orcer uercen orcer +! SFX W orzar uercen orzar +! SFX W izar ícen [ae]izar +! SFX W eder ieden eder +! SFX W odar ueden odar +! SFX W oder ueden oder +! SFX W edir iden edir +! SFX W oldar uelden [^g]oldar +! SFX W oldar üelden goldar +! SFX W endar ienden endar +! SFX W ender ienden ender +! SFX W endir inden endir +! SFX W erder ierden erder +! SFX W ordar uerden ordar +! SFX W order uerden order +! SFX W egir igen egir +! SFX W enchir inchen enchir +! SFX W ijar íjen [ae]hijar +! SFX W oblar ueblen oblar +! SFX W emblar iemblen emblar +! SFX W elar ielen elar +! SFX W olar uelen olar +! SFX W oler uelen oler +! SFX W ollar uellen [^g]ollar +! SFX W ollar üellen gollar +! SFX W ilar ílen [ae]hilar +! SFX W emir imen emir +! SFX W ormir uermen ormir +! SFX W umar úmen [ae]humar +! SFX W ener ienen ener +! SFX W enir ienen enir +! SFX W onar uenen onar +! SFX W ernar iernen ernar +! SFX W erner iernen erner +! SFX W ernir iernen ernir +! SFX W ornar uernen ornar +! SFX W inar ínen [aeo]hinar +! SFX W unir únen eunir +! SFX W r ren [^a]ndar +! SFX W r ren [^d]ar +! SFX W r ren [^n]dar +! SFX W ebrar iebren ebrar +! SFX W embrar iembren embrar +! SFX W edrar iedren edrar +! SFX W endrar iendren endrar +! SFX W r eren alir +! SFX W r eren ernir +! SFX W r eren eunir +! SFX W r eren ohibir +! SFX W er ieren [^fh]acer +! SFX W er ieren aler +! SFX W er ieren e[cd]er +! SFX W er ieren ender +! SFX W er ieren er[dnt]er +! SFX W er ieren o[clv]er +! SFX W er ieren olver +! SFX W er ieren or[cd]er +! SFX W erer ieren erer +! SFX W erir ieren erir +! SFX W eír ieren eír +! SFX W irir ieren irir +! SFX W ebir ibieren ebir +! SFX W acer icieren [fh]acer +! SFX W edir idieren edir +! SFX W endir indieren endir +! SFX W oder udieren oder +! SFX W egir igieren egir +! SFX W enchir inchieren enchir +! SFX W emir imieren emir +! SFX W ormir urmieren ormir +! SFX W enir inieren enir +! SFX W aber upieren aber +! SFX W erir irieren erir +! SFX W irir irieren irir +! SFX W orir urieren orir +! SFX W erer isieren erer +! SFX W oner usieren oner +! SFX W etir itieren etir +! SFX W entir intieren entir +! SFX W ertir irtieren ertir +! SFX W estir istieren estir +! SFX W eguir iguieren eguir +! SFX W ervir irvieren ervir +! SFX W ar uvieren andar +! SFX W ener uvieren ener +! SFX W cir jeren ucir +! SFX W er jeren raer +! SFX W ecir ijeren ecir +! SFX W orar ueren [^g]orar +! SFX W orir ueren orir +! SFX W er yeren [eo]er +! SFX W er yeren caer +! SFX W ir yeren [^g]uir +! SFX W ír yeren oír +! SFX W üir uyeren güir +! SFX W eñir iñeren eñir +! SFX W orar üeren gorar +! SFX W errar ierren errar +! SFX W ontrar uentren ontrar +! SFX W ostrar uestren ostrar +! SFX W r sen [^a]ndar +! SFX W r sen [^d]ar +! SFX W r sen [^n]dar +! SFX W r esen alir +! SFX W r esen ernir +! SFX W r esen eunir +! SFX W r esen ohibir +! SFX W er iesen [^fh]acer +! SFX W er iesen aler +! SFX W er iesen e[cd]er +! SFX W er iesen ender +! SFX W er iesen er[dnt]er +! SFX W er iesen o[clv]er +! SFX W er iesen olver +! SFX W er iesen or[cd]er +! SFX W esar iesen esar +! SFX W eír iesen eír +! SFX W ebir ibiesen ebir +! SFX W acer iciesen [fh]acer +! SFX W edir idiesen edir +! SFX W endir indiesen endir +! SFX W oder udiesen oder +! SFX W egir igiesen egir +! SFX W enchir inchiesen enchir +! SFX W emir imiesen emir +! SFX W ormir urmiesen ormir +! SFX W enir iniesen enir +! SFX W aber upiesen aber +! SFX W erir iriesen erir +! SFX W irir iriesen irir +! SFX W orir uriesen orir +! SFX W erer isiesen erer +! SFX W oner usiesen oner +! SFX W etir itiesen etir +! SFX W entir intiesen entir +! SFX W ertir irtiesen ertir +! SFX W estir istiesen estir +! SFX W eguir iguiesen eguir +! SFX W ervir irviesen ervir +! SFX W ar uviesen andar +! SFX W ener uviesen ener +! SFX W cir jesen ucir +! SFX W er jesen raer +! SFX W ecir ijesen ecir +! SFX W osar uesen osar +! SFX W er yesen [eo]er +! SFX W er yesen caer +! SFX W ir yesen [^g]uir +! SFX W ír yesen oír +! SFX W üir uyesen güir +! SFX W eñir iñesen eñir +! SFX W ensar iensen ensar +! SFX W usar úsen [ae]husar +! SFX W etar ieten etar +! SFX W etir iten etir +! SFX W oltar uelten oltar +! SFX W entar ienten entar +! SFX W entir ienten entir +! SFX W ontar uenten ontar +! SFX W ertar ierten ertar +! SFX W erter ierten erter +! SFX W ertir ierten ertir +! SFX W ortar uerten ortar +! SFX W estar iesten estar +! SFX W ostar uesten ostar +! SFX W estir isten estir +! SFX W itar íten [ae]hitar +! SFX W gar eguen ugar +! SFX W egar ieguen egar +! SFX W ogar ueguen ogar +! SFX W eguir iguen eguir +! SFX W olgar uelguen olgar +! SFX W engar ienguen engar +! SFX W ocar uequen ocar +! SFX W olcar uelquen olcar +! SFX W orcar uerquen orcar +! SFX W evar ieven evar +! SFX W ovar ueven ovar +! SFX W over ueven over +! SFX W olver uelven olver +! SFX W ervir irven ervir +! SFX W ir yen [^g]uir +! SFX W ír yen oír +! SFX W üir uyen güir +! SFX W eír íen eír +! SFX W iar íen iar +! SFX W oñar ueñen oñar +! SFX W eñir iñen eñir +! SFX W uar úen [^g]uar +! SFX W uar üen guar +! +! +! SFX W Y 49 S +! SFX W 0 on [^a]ndar +! SFX W 0 on [^d]ar +! SFX W 0 on [^n]dar +! SFX W r eron alir +! SFX W r eron ernir +! SFX W r eron eunir +! SFX W r eron irir +! SFX W r eron ohibir +! SFX W er ieron [^fh]acer +! SFX W er ieron aler +! SFX W er ieron e[cd]er +! SFX W er ieron ender +! SFX W er ieron er[dnt]er +! SFX W er ieron o[clv]er +! SFX W er ieron olver +! SFX W er ieron or[cd]er +! SFX W eír ieron eír +! SFX W ebir ibieron ebir +! SFX W acer icieron [fh]acer +! SFX W edir idieron edir +! SFX W endir indieron endir +! SFX W oder udieron oder +! SFX W egir igieron egir +! SFX W enchir inchieron enchir +! SFX W emir imieron emir +! SFX W ormir urmieron ormir +! SFX W enir inieron enir +! SFX W aber upieron aber +! SFX W erir irieron erir +! SFX W orir urieron orir +! SFX W erer isieron erer +! SFX W oner usieron oner +! SFX W etir itieron etir +! SFX W entir intieron entir +! SFX W ertir irtieron ertir +! SFX W estir istieron estir +! SFX W eguir iguieron eguir +! SFX W ervir irvieron ervir +! SFX W ar uvieron andar +! SFX W ener uvieron ener +! SFX W cir jeron ucir +! SFX W er jeron raer +! SFX W ecir ijeron ecir +! SFX W er yeron [eo]er +! SFX W er yeron caer +! SFX W ir yeron [^g]uir +! SFX W ír yeron oír +! SFX W üir uyeron güir +! SFX W eñir iñeron eñir +! +! +! SFX W Y 29 S +! SFX W 0 án [^fh]acer +! SFX W 0 án [aeo]er +! SFX W 0 án [io]rir +! SFX W 0 án [üu]ir +! SFX W 0 án ar +! SFX W 0 án e[bdgmrtñ]ir +! SFX W 0 án e[cd]er +! SFX W 0 án e[ns]tir +! SFX W 0 án enchir +! SFX W 0 án ender +! SFX W 0 án endir +! SFX W 0 án er[dnt]er +! SFX W 0 án er[ntv]ir +! SFX W 0 án eunir +! SFX W 0 án o[clv]er +! SFX W 0 án olver +! SFX W 0 án or[cd]er +! SFX W 0 án ormir +! SFX W 0 án ucir +! SFX W cer rán [fh]acer +! SFX W er rán aber +! SFX W er rán erer +! SFX W er rán oder +! SFX W er drán [eo]ner +! SFX W er drán aler +! SFX W ir drán alir +! SFX W ir drán enir +! SFX W ecir irán ecir +! SFX W ír irán [eo]ír +! +! +! SFX W Y 126 S +! SFX W ar o andar +! SFX W ar o guar +! SFX W er o [eo]er +! SFX W obar uebo obar +! SFX W ebir ibo ebir +! SFX W erbar ierbo erbar +! SFX W ibir íbo ohibir +! SFX W ocar ueco ocar +! SFX W olcar uelco olcar +! SFX W orcar uerco orcar +! SFX W cer zco [^c]ocer +! SFX W cer zco [^fh]acer +! SFX W cer zco ecer +! SFX W ucir uzco ucir +! SFX W eder iedo eder +! SFX W odar uedo odar +! SFX W oder uedo oder +! SFX W edir ido edir +! SFX W oldar ueldo [^g]oldar +! SFX W oldar üeldo goldar +! SFX W endar iendo endar +! SFX W ender iendo ender +! SFX W endir indo endir +! SFX W erder ierdo erder +! SFX W ordar uerdo ordar +! SFX W order uerdo order +! SFX W oder udo oder +! SFX W cer go [fh]acer +! SFX W er go aler +! SFX W er go ener +! SFX W er go oner +! SFX W ir go alir +! SFX W ir go enir +! SFX W gar ego ugar +! SFX W egar iego egar +! SFX W ogar uego ogar +! SFX W ecir igo ecir +! SFX W eguir igo eguir +! SFX W er igo [cr]aer +! SFX W er igo oer +! SFX W ír igo oír +! SFX W olgar uelgo olgar +! SFX W engar iengo engar +! SFX W enchir incho enchir +! SFX W cir jo ucir +! SFX W er jo raer +! SFX W ecir ijo ecir +! SFX W egir ijo egir +! SFX W ijar íjo [ae]hijar +! SFX W oblar ueblo oblar +! SFX W emblar iemblo emblar +! SFX W elar ielo elar +! SFX W olar uelo olar +! SFX W oler uelo oler +! SFX W ollar uello [^g]ollar +! SFX W ollar üello gollar +! SFX W ilar ílo [ae]hilar +! SFX W emir imo emir +! SFX W ormir uermo ormir +! SFX W umar úmo [ae]humar +! SFX W onar ueno onar +! SFX W enir ino enir +! SFX W ernar ierno ernar +! SFX W erner ierno erner +! SFX W ernir ierno ernir +! SFX W ornar uerno ornar +! SFX W inar íno [aeo]hinar +! SFX W unir úno eunir +! SFX W caber quepo caber +! SFX W aber upo aber +! SFX W ebrar iebro ebrar +! SFX W embrar iembro embrar +! SFX W edrar iedro edrar +! SFX W endrar iendro endrar +! SFX W erer iero erer +! SFX W erir iero erir +! SFX W irir iero irir +! SFX W orar uero [^g]orar +! SFX W orir uero orir +! SFX W orar üero gorar +! SFX W errar ierro errar +! SFX W ontrar uentro ontrar +! SFX W ostrar uestro ostrar +! SFX W esar ieso esar +! SFX W osar ueso osar +! SFX W erer iso erer +! SFX W ensar ienso ensar +! SFX W oner uso oner +! SFX W usar úso [ae]husar +! SFX W etar ieto etar +! SFX W etir ito etir +! SFX W oltar uelto oltar +! SFX W entar iento entar +! SFX W entir iento entir +! SFX W ontar uento ontar +! SFX W ertar ierto ertar +! SFX W erter ierto erter +! SFX W ertir ierto ertir +! SFX W ortar uerto ortar +! SFX W estar iesto estar +! SFX W ostar uesto ostar +! SFX W estir isto estir +! SFX W itar íto [ae]hitar +! SFX W evar ievo evar +! SFX W ovar uevo ovar +! SFX W over uevo over +! SFX W olver uelvo olver +! SFX W ervir irvo ervir +! SFX W ar uvo andar +! SFX W ener uvo ener +! SFX W er yo oer +! SFX W uir uyo [^g]uir +! SFX W üir uyo güir +! SFX W ezar iezo ezar +! SFX W ocer uezo cocer +! SFX W acer izo [fh]acer +! SFX W enzar ienzo enzar +! SFX W onzar üenzo gonzar +! SFX W orcer uerzo orcer +! SFX W orzar uerzo orzar +! SFX W izar ízo [ae]izar +! SFX W eír ío eír +! SFX W iar ío iar +! SFX W oñar ueño oñar +! SFX W eñir iño eñir +! SFX W uar úo [^g]uar +! +! +! +! SFX W Y 195 S +! SFX W er as [eo]er +! SFX W r bas ar +! SFX W obar uebas obar +! SFX W ebir ibas ebir +! SFX W erbar ierbas erbar +! SFX W ibir íbas ohibir +! SFX W ocar uecas ocar +! SFX W olcar uelcas olcar +! SFX W orcar uercas orcar +! SFX W cer zcas [^c]ocer +! SFX W cer zcas [^fh]acer +! SFX W cer zcas ecer +! SFX W cir zcas ucir +! SFX W eder iedas eder +! SFX W odar uedas odar +! SFX W oder uedas oder +! SFX W edir idas edir +! SFX W oldar ueldas [^g]oldar +! SFX W oldar üeldas goldar +! SFX W endar iendas endar +! SFX W ender iendas ender +! SFX W endir indas endir +! SFX W erder ierdas erder +! SFX W ordar uerdas ordar +! SFX W order uerdas order +! SFX W cer gas [fh]acer +! SFX W er gas [eo]ner +! SFX W er gas aler +! SFX W ir gas alir +! SFX W gar egas ugar +! SFX W egar iegas egar +! SFX W ogar uegas ogar +! SFX W ecir igas ecir +! SFX W eguir igas eguir +! SFX W er igas aer +! SFX W er igas oer +! SFX W ír igas oír +! SFX W olgar uelgas olgar +! SFX W enir engas enir +! SFX W engar iengas engar +! SFX W enchir inchas enchir +! SFX W egir ijas egir +! SFX W ijar íjas [ae]hijar +! SFX W oblar ueblas oblar +! SFX W emblar iemblas emblar +! SFX W elar ielas elar +! SFX W olar uelas olar +! SFX W oler uelas oler +! SFX W ollar uellas [^g]ollar +! SFX W ollar üellas gollar +! SFX W ilar ílas [ae]hilar +! SFX W emir imas emir +! SFX W ormir uermas ormir +! SFX W umar úmas [ae]humar +! SFX W onar uenas onar +! SFX W ernar iernas ernar +! SFX W erner iernas erner +! SFX W ernir iernas ernir +! SFX W ornar uernas ornar +! SFX W inar ínas [aeo]hinar +! SFX W unir únas eunir +! SFX W aber epas saber +! SFX W caber quepas caber +! SFX W r ras [^a]ndar +! SFX W r ras [^d]ar +! SFX W r ras [^n]dar +! SFX W ebrar iebras ebrar +! SFX W embrar iembras embrar +! SFX W edrar iedras edrar +! SFX W endrar iendras endrar +! SFX W r eras alir +! SFX W r eras ernir +! SFX W r eras eunir +! SFX W r eras ohibir +! SFX W er ieras [^fh]acer +! SFX W er ieras aler +! SFX W er ieras e[cd]er +! SFX W er ieras ender +! SFX W er ieras er[dnt]er +! SFX W er ieras o[clv]er +! SFX W er ieras olver +! SFX W er ieras or[cd]er +! SFX W erer ieras erer +! SFX W erir ieras erir +! SFX W eír ieras eír +! SFX W irir ieras irir +! SFX W ebir ibieras ebir +! SFX W acer icieras [fh]acer +! SFX W edir idieras edir +! SFX W endir indieras endir +! SFX W oder udieras oder +! SFX W egir igieras egir +! SFX W enchir inchieras enchir +! SFX W emir imieras emir +! SFX W ormir urmieras ormir +! SFX W enir inieras enir +! SFX W aber upieras aber +! SFX W erir irieras erir +! SFX W irir irieras irir +! SFX W orir urieras orir +! SFX W erer isieras erer +! SFX W oner usieras oner +! SFX W etir itieras etir +! SFX W entir intieras entir +! SFX W ertir irtieras ertir +! SFX W estir istieras estir +! SFX W eguir iguieras eguir +! SFX W ervir irvieras ervir +! SFX W ar uvieras andar +! SFX W ener uvieras ener +! SFX W cir jeras ucir +! SFX W er jeras raer +! SFX W ecir ijeras ecir +! SFX W orar ueras [^g]orar +! SFX W orir ueras orir +! SFX W er yeras [eo]er +! SFX W er yeras caer +! SFX W ir yeras [^g]uir +! SFX W ír yeras oír +! SFX W üir uyeras güir +! SFX W eñir iñeras eñir +! SFX W orar üeras gorar +! SFX W errar ierras errar +! SFX W ontrar uentras ontrar +! SFX W ostrar uestras ostrar +! SFX W esar iesas esar +! SFX W osar uesas osar +! SFX W ensar iensas ensar +! SFX W usar úsas [ae]husar +! SFX W etar ietas etar +! SFX W etir itas etir +! SFX W oltar ueltas oltar +! SFX W entar ientas entar +! SFX W entir ientas entir +! SFX W ontar uentas ontar +! SFX W ertar iertas ertar +! SFX W erter iertas erter +! SFX W ertir iertas ertir +! SFX W ortar uertas ortar +! SFX W estar iestas estar +! SFX W ostar uestas ostar +! SFX W estir istas estir +! SFX W itar ítas [ae]hitar +! SFX W evar ievas evar +! SFX W ovar uevas ovar +! SFX W over uevas over +! SFX W olver uelvas olver +! SFX W ervir irvas ervir +! SFX W er yas oer +! SFX W ir yas [^g]uir +! SFX W üir uyas güir +! SFX W ezar iezas ezar +! SFX W ocer uezas cocer +! SFX W enzar ienzas enzar +! SFX W onzar üenzas gonzar +! SFX W orcer uerzas orcer +! SFX W orzar uerzas orzar +! SFX W izar ízas [ae]izar +! SFX W 0 ías [^fh]acer +! SFX W 0 ías [aeo]er +! SFX W 0 ías [io]rir +! SFX W 0 ías [üu]ir +! SFX W 0 ías ar +! SFX W 0 ías e[bdgmrtñ]ir +! SFX W 0 ías e[cd]er +! SFX W 0 ías e[ns]tir +! SFX W 0 ías enchir +! SFX W 0 ías ender +! SFX W 0 ías endir +! SFX W 0 ías er[dnt]er +! SFX W 0 ías er[ntv]ir +! SFX W 0 ías eunir +! SFX W 0 ías o[clv]er +! SFX W 0 ías olver +! SFX W 0 ías or[cd]er +! SFX W 0 ías ormir +! SFX W 0 ías ucir +! SFX W er ías er +! SFX W eír ías eír +! SFX W iar ías iar +! SFX W ir ías ir +! SFX W ír ías ír +! SFX W cer rías [fh]acer +! SFX W er rías aber +! SFX W er rías erer +! SFX W er rías oder +! SFX W er drías [eo]ner +! SFX W er drías aler +! SFX W ir drías alir +! SFX W ir drías enir +! SFX W ecir irías ecir +! SFX W ír irías [eo]ír +! SFX W oñar ueñas oñar +! SFX W eñir iñas eñir +! SFX W uar úas [^g]uar +! +! +! +! SFX W Y 202 S +! SFX W ar es andar +! SFX W ir es ucir +! SFX W r es alir +! SFX W obar uebes obar +! SFX W ebir ibes ebir +! SFX W erbar ierbes erbar +! SFX W ibir íbes ohibir +! SFX W ezar ieces ezar +! SFX W ocer ueces cocer +! SFX W ecir ices ecir +! SFX W enzar iences enzar +! SFX W onzar üences gonzar +! SFX W orcer uerces orcer +! SFX W orzar uerces orzar +! SFX W izar íces [ae]izar +! SFX W eder iedes eder +! SFX W odar uedes odar +! SFX W oder uedes oder +! SFX W edir ides edir +! SFX W oldar ueldes [^g]oldar +! SFX W oldar üeldes goldar +! SFX W endar iendes endar +! SFX W ender iendes ender +! SFX W endir indes endir +! SFX W erder ierdes erder +! SFX W ordar uerdes ordar +! SFX W order uerdes order +! SFX W egir iges egir +! SFX W enchir inches enchir +! SFX W ijar íjes [ae]hijar +! SFX W oblar uebles oblar +! SFX W emblar iembles emblar +! SFX W elar ieles elar +! SFX W olar ueles olar +! SFX W oler ueles oler +! SFX W ollar uelles [^g]ollar +! SFX W ollar üelles gollar +! SFX W ilar íles [ae]hilar +! SFX W emir imes emir +! SFX W ormir uermes ormir +! SFX W umar úmes [ae]humar +! SFX W ener ienes ener +! SFX W enir ienes enir +! SFX W onar uenes onar +! SFX W ernar iernes ernar +! SFX W erner iernes erner +! SFX W ernir iernes ernir +! SFX W ornar uernes ornar +! SFX W inar ínes [aeo]hinar +! SFX W unir únes eunir +! SFX W r res [^a]ndar +! SFX W r res [^d]ar +! SFX W r res [^n]dar +! SFX W ebrar iebres ebrar +! SFX W embrar iembres embrar +! SFX W edrar iedres edrar +! SFX W endrar iendres endrar +! SFX W r eres alir +! SFX W r eres ernir +! SFX W r eres eunir +! SFX W r eres ohibir +! SFX W er ieres [^fh]acer +! SFX W er ieres aler +! SFX W er ieres e[cd]er +! SFX W er ieres ender +! SFX W er ieres er[dnt]er +! SFX W er ieres o[clv]er +! SFX W er ieres olver +! SFX W er ieres or[cd]er +! SFX W erer ieres erer +! SFX W erir ieres erir +! SFX W eír ieres eír +! SFX W irir ieres irir +! SFX W ebir ibieres ebir +! SFX W acer icieres [fh]acer +! SFX W edir idieres edir +! SFX W endir indieres endir +! SFX W oder udieres oder +! SFX W egir igieres egir +! SFX W enchir inchieres enchir +! SFX W emir imieres emir +! SFX W ormir urmieres ormir +! SFX W enir inieres enir +! SFX W aber upieres aber +! SFX W erir irieres erir +! SFX W irir irieres irir +! SFX W orir urieres orir +! SFX W erer isieres erer +! SFX W oner usieres oner +! SFX W etir itieres etir +! SFX W entir intieres entir +! SFX W ertir irtieres ertir +! SFX W estir istieres estir +! SFX W eguir iguieres eguir +! SFX W ervir irvieres ervir +! SFX W ar uvieres andar +! SFX W ener uvieres ener +! SFX W cir jeres ucir +! SFX W er jeres raer +! SFX W ecir ijeres ecir +! SFX W orar ueres [^g]orar +! SFX W orir ueres orir +! SFX W er yeres [eo]er +! SFX W er yeres caer +! SFX W ir yeres [^g]uir +! SFX W ír yeres oír +! SFX W üir uyeres güir +! SFX W eñir iñeres eñir +! SFX W orar üeres gorar +! SFX W errar ierres errar +! SFX W ontrar uentres ontrar +! SFX W ostrar uestres ostrar +! SFX W r ses [^a]ndar +! SFX W r ses [^d]ar +! SFX W r ses [^n]dar +! SFX W r eses alir +! SFX W r eses ernir +! SFX W r eses eunir +! SFX W r eses ohibir +! SFX W er ieses [^fh]acer +! SFX W er ieses aler +! SFX W er ieses e[cd]er +! SFX W er ieses ender +! SFX W er ieses er[dnt]er +! SFX W er ieses o[clv]er +! SFX W er ieses olver +! SFX W er ieses or[cd]er +! SFX W esar ieses esar +! SFX W eír ieses eír +! SFX W ebir ibieses ebir +! SFX W acer icieses [fh]acer +! SFX W edir idieses edir +! SFX W endir indieses endir +! SFX W oder udieses oder +! SFX W egir igieses egir +! SFX W enchir inchieses enchir +! SFX W emir imieses emir +! SFX W ormir urmieses ormir +! SFX W enir inieses enir +! SFX W aber upieses aber +! SFX W erir irieses erir +! SFX W irir irieses irir +! SFX W orir urieses orir +! SFX W erer isieses erer +! SFX W oner usieses oner +! SFX W etir itieses etir +! SFX W entir intieses entir +! SFX W ertir irtieses ertir +! SFX W estir istieses estir +! SFX W eguir iguieses eguir +! SFX W ervir irvieses ervir +! SFX W ar uvieses andar +! SFX W ener uvieses ener +! SFX W cir jeses ucir +! SFX W er jeses raer +! SFX W ecir ijeses ecir +! SFX W osar ueses osar +! SFX W er yeses [eo]er +! SFX W er yeses caer +! SFX W ir yeses [^g]uir +! SFX W ír yeses oír +! SFX W üir uyeses güir +! SFX W eñir iñeses eñir +! SFX W ensar ienses ensar +! SFX W usar úses [ae]husar +! SFX W etar ietes etar +! SFX W etir ites etir +! SFX W oltar ueltes oltar +! SFX W entar ientes entar +! SFX W entir ientes entir +! SFX W ontar uentes ontar +! SFX W ertar iertes ertar +! SFX W erter iertes erter +! SFX W ertir iertes ertir +! SFX W ortar uertes ortar +! SFX W estar iestes estar +! SFX W ostar uestes ostar +! SFX W estir istes estir +! SFX W itar ítes [ae]hitar +! SFX W gar egues ugar +! SFX W egar iegues egar +! SFX W ogar uegues ogar +! SFX W eguir igues eguir +! SFX W olgar uelgues olgar +! SFX W engar iengues engar +! SFX W ocar ueques ocar +! SFX W olcar uelques olcar +! SFX W orcar uerques orcar +! SFX W evar ieves evar +! SFX W ovar ueves ovar +! SFX W over ueves over +! SFX W olver uelves olver +! SFX W ervir irves ervir +! SFX W ír yes oír +! SFX W uir uyes [^g]uir +! SFX W üir uyes güir +! SFX W eír íes eír +! SFX W iar íes iar +! SFX W oñar ueñes oñar +! SFX W eñir iñes eñir +! SFX W uar úes [^g]uar +! SFX W uar ües guar +! +! +! SFX W Y 49 S +! SFX W r rais [^a]ndar +! SFX W r rais [^d]ar +! SFX W r rais [^n]dar +! SFX W r erais alir +! SFX W r erais ernir +! SFX W r erais eunir +! SFX W r erais ohibir +! SFX W er ierais [^fh]acer +! SFX W er ierais aler +! SFX W er ierais e[cd]er +! SFX W er ierais ender +! SFX W er ierais er[dnt]er +! SFX W er ierais o[clv]er +! SFX W er ierais olver +! SFX W er ierais or[cd]er +! SFX W eír ierais eír +! SFX W ebir ibierais ebir +! SFX W acer icierais [fh]acer +! SFX W edir idierais edir +! SFX W endir indierais endir +! SFX W oder udierais oder +! SFX W egir igierais egir +! SFX W enchir inchierais enchir +! SFX W emir imierais emir +! SFX W ormir urmierais ormir +! SFX W enir inierais enir +! SFX W aber upierais aber +! SFX W erir irierais erir +! SFX W irir irierais irir +! SFX W orir urierais orir +! SFX W erer isierais erer +! SFX W oner usierais oner +! SFX W etir itierais etir +! SFX W entir intierais entir +! SFX W ertir irtierais ertir +! SFX W estir istierais estir +! SFX W eguir iguierais eguir +! SFX W ervir irvierais ervir +! SFX W ar uvierais andar +! SFX W ener uvierais ener +! SFX W cir jerais ucir +! SFX W er jerais raer +! SFX W ecir ijerais ecir +! SFX W er yerais [eo]er +! SFX W er yerais caer +! SFX W ir yerais [^g]uir +! SFX W ír yerais oír +! SFX W üir uyerais güir +! SFX W eñir iñerais eñir +! +! +! +! SFX W Y 32 S +! SFX W 0 íais [^fh]acer +! SFX W 0 íais [aeo]er +! SFX W 0 íais [io]rir +! SFX W 0 íais [üu]ir +! SFX W 0 íais ar +! SFX W 0 íais e[bdgmrtñ]ir +! SFX W 0 íais e[cd]er +! SFX W 0 íais e[ns]tir +! SFX W 0 íais enchir +! SFX W 0 íais ender +! SFX W 0 íais endir +! SFX W 0 íais er[dnt]er +! SFX W 0 íais er[ntv]ir +! SFX W 0 íais eunir +! SFX W 0 íais o[clv]er +! SFX W 0 íais olver +! SFX W 0 íais or[cd]er +! SFX W 0 íais ormir +! SFX W 0 íais ucir +! SFX W er íais er +! SFX W ir íais ir +! SFX W ír íais ír +! SFX W cer ríais [fh]acer +! SFX W er ríais aber +! SFX W er ríais erer +! SFX W er ríais oder +! SFX W er dríais [eo]ner +! SFX W er dríais aler +! SFX W ir dríais alir +! SFX W ir dríais enir +! SFX W ecir iríais ecir +! SFX W ír iríais [eo]ír +! +! +! +! SFX W Y 48 S +! SFX W r reis [^a]ndar +! SFX W r reis [^d]ar +! SFX W r reis [^n]dar +! SFX W r ereis alir +! SFX W r ereis ernir +! SFX W r ereis ohibir +! SFX W er iereis [^fh]acer +! SFX W er iereis aler +! SFX W er iereis e[cd]er +! SFX W er iereis ender +! SFX W er iereis er[dnt]er +! SFX W er iereis o[clv]er +! SFX W er iereis olver +! SFX W er iereis or[cd]er +! SFX W eír iereis eír +! SFX W ebir ibiereis ebir +! SFX W acer iciereis [fh]acer +! SFX W edir idiereis edir +! SFX W endir indiereis endir +! SFX W oder udiereis oder +! SFX W egir igiereis egir +! SFX W enchir inchiereis enchir +! SFX W emir imiereis emir +! SFX W ormir urmiereis ormir +! SFX W enir iniereis enir +! SFX W aber upiereis aber +! SFX W erir iriereis erir +! SFX W irir iriereis irir +! SFX W orir uriereis orir +! SFX W oner usiereis oner +! SFX W etir itiereis etir +! SFX W entir intiereis entir +! SFX W ertir irtiereis ertir +! SFX W estir istiereis estir +! SFX W eguir iguiereis eguir +! SFX W ervir irviereis ervir +! SFX W ar uviereis andar +! SFX W ener uviereis ener +! SFX W cir jereis ucir +! SFX W er jereis raer +! SFX W ecir ijereis ecir +! SFX W er yereis [eo]er +! SFX W er yereis caer +! SFX W ir yereis [^g]uir +! SFX W ír yereis oír +! SFX W üir uyereis güir +! SFX W eñir iñereis eñir +! SFX W erer isiéreis erer +! +! +! +! SFX W Y 49 S +! SFX W r seis [^a]ndar +! SFX W r seis [^d]ar +! SFX W r seis [^n]dar +! SFX W r eseis alir +! SFX W r eseis ernir +! SFX W r eseis eunir +! SFX W r eseis ohibir +! SFX W er ieseis [^fh]acer +! SFX W er ieseis aler +! SFX W er ieseis e[cd]er +! SFX W er ieseis ender +! SFX W er ieseis er[dnt]er +! SFX W er ieseis o[clv]er +! SFX W er ieseis olver +! SFX W er ieseis or[cd]er +! SFX W eír ieseis eír +! SFX W ebir ibieseis ebir +! SFX W acer icieseis [fh]acer +! SFX W edir idieseis edir +! SFX W endir indieseis endir +! SFX W oder udieseis oder +! SFX W egir igieseis egir +! SFX W enchir inchieseis enchir +! SFX W emir imieseis emir +! SFX W ormir urmieseis ormir +! SFX W enir inieseis enir +! SFX W aber upieseis aber +! SFX W erir irieseis erir +! SFX W irir irieseis irir +! SFX W orir urieseis orir +! SFX W erer isieseis erer +! SFX W oner usieseis oner +! SFX W etir itieseis etir +! SFX W entir intieseis entir +! SFX W ertir irtieseis ertir +! SFX W estir istieseis estir +! SFX W eguir iguieseis eguir +! SFX W ervir irvieseis ervir +! SFX W ar uvieseis andar +! SFX W ener uvieseis ener +! SFX W cir jeseis ucir +! SFX W er jeseis raer +! SFX W ecir ijeseis ecir +! SFX W er yeseis [eo]er +! SFX W er yeseis caer +! SFX W ir yeseis [^g]uir +! SFX W ír yeseis oír +! SFX W üir uyeseis güir +! SFX W eñir iñeseis eñir +! +! +! +! SFX W Y 45 S +! SFX W r steis [^a]ndar +! SFX W r steis [^d]ar +! SFX W r steis [^n]dar +! SFX W r steis [eo]ír +! SFX W r steis [üu]ir +! SFX W r steis alir +! SFX W r steis ebir +! SFX W r steis edir +! SFX W r steis egir +! SFX W r steis emir +! SFX W r steis enchir +! SFX W r steis endir +! SFX W r steis entir +! SFX W r steis erir +! SFX W r steis ernir +! SFX W r steis ertir +! SFX W r steis ervir +! SFX W r steis estir +! SFX W r steis etir +! SFX W r steis eunir +! SFX W r steis eñir +! SFX W r steis irir +! SFX W r steis orir +! SFX W r steis ormir +! SFX W er isteis [^fh]acer +! SFX W er isteis aler +! SFX W er isteis e[cd]er +! SFX W er isteis ender +! SFX W er isteis er[dnt]er +! SFX W er isteis o[clv]er +! SFX W er isteis olver +! SFX W er isteis or[cd]er +! SFX W acer icisteis [fh]acer +! SFX W oder udisteis oder +! SFX W cir jisteis ucir +! SFX W er jisteis raer +! SFX W ecir ijisteis ecir +! SFX W enir inisteis enir +! SFX W aber upisteis aber +! SFX W erer isisteis erer +! SFX W oner usisteis oner +! SFX W ar uvisteis andar +! SFX W ener uvisteis ener +! SFX W er ísteis [eo]er +! SFX W er ísteis caer +! +! +! +! SFX W Y 54 S +! SFX W ar áis ar +! SFX W er áis [eo]er +! SFX W er áis eder +! SFX W er áis ender +! SFX W er áis erder +! SFX W er áis erer +! SFX W er áis erner +! SFX W er áis erter +! SFX W er áis oder +! SFX W er áis oler +! SFX W er áis olver +! SFX W er áis order +! SFX W er áis over +! SFX W ir áis ernir +! SFX W ir áis eunir +! SFX W ir áis irir +! SFX W ir áis ohibir +! SFX W ebir ibáis ebir +! SFX W cer zcáis [^c]ocer +! SFX W cer zcáis [^fh]acer +! SFX W cer zcáis ecer +! SFX W cir zcáis ucir +! SFX W edir idáis edir +! SFX W endir indáis endir +! SFX W cer gáis [fh]acer +! SFX W er gáis [eo]ner +! SFX W er gáis aler +! SFX W ir gáis alir +! SFX W ecir igáis ecir +! SFX W eguir igáis eguir +! SFX W er igáis aer +! SFX W er igáis oer +! SFX W ír igáis oír +! SFX W enir engáis enir +! SFX W enchir incháis enchir +! SFX W eír iáis eír +! SFX W egir ijáis egir +! SFX W emir imáis emir +! SFX W ormir urmáis ormir +! SFX W aber epáis saber +! SFX W caber quepáis caber +! SFX W erir iráis erir +! SFX W orir uráis orir +! SFX W etir itáis etir +! SFX W entir intáis entir +! SFX W ertir irtáis ertir +! SFX W estir istáis estir +! SFX W ervir irváis ervir +! SFX W er yáis oer +! SFX W ir yáis [^g]uir +! SFX W üir uyáis güir +! SFX W cer záis cocer +! SFX W cer záis orcer +! SFX W emir iñáis eñir +! +! +! +! SFX W Y 84 S +! SFX W 0 éis [^fh]acer +! SFX W 0 éis [aeo]er +! SFX W 0 éis [io]rir +! SFX W 0 éis [üu]ir +! SFX W 0 éis ar +! SFX W 0 éis e[bdgmrtñ]ir +! SFX W 0 éis e[cd]er +! SFX W 0 éis e[ns]tir +! SFX W 0 éis enchir +! SFX W 0 éis ender +! SFX W 0 éis endir +! SFX W 0 éis er[dnt]er +! SFX W 0 éis er[ntv]ir +! SFX W 0 éis eunir +! SFX W 0 éis o[clv]er +! SFX W 0 éis olver +! SFX W 0 éis or[cd]er +! SFX W 0 éis ormir +! SFX W 0 éis ucir +! SFX W ar éis [^g]uar +! SFX W ar éis [ae]hu[ms]ar +! SFX W ar éis [ae]ndar +! SFX W ar éis [aeo]hi[jlnt]ar +! SFX W ar éis ebrar +! SFX W ar éis edrar +! SFX W ar éis elar +! SFX W ar éis emblar +! SFX W ar éis embrar +! SFX W ar éis endrar +! SFX W ar éis ensar +! SFX W ar éis entar +! SFX W ar éis erbar +! SFX W ar éis ernar +! SFX W ar éis errar +! SFX W ar éis ertar +! SFX W ar éis esar +! SFX W ar éis estar +! SFX W ar éis etar +! SFX W ar éis evar +! SFX W ar éis iar +! SFX W ar éis obar +! SFX W ar éis oblar +! SFX W ar éis odar +! SFX W ar éis olar +! SFX W ar éis oldar +! SFX W ar éis ollar +! SFX W ar éis oltar +! SFX W ar éis onar +! SFX W ar éis ontar +! SFX W ar éis ontrar +! SFX W ar éis orar +! SFX W ar éis ordar +! SFX W ar éis ornar +! SFX W ar éis ortar +! SFX W ar éis osar +! SFX W ar éis ostar +! SFX W ar éis ostrar +! SFX W ar éis ovar +! SFX W ar éis oñar +! SFX W er éis er +! SFX W zar céis [ae]izar +! SFX W zar céis enzar +! SFX W zar céis ezar +! SFX W zar céis gonzar +! SFX W zar céis orzar +! SFX W cer réis [fh]acer +! SFX W er réis aber +! SFX W er réis erer +! SFX W er réis oder +! SFX W er dréis [eo]ner +! SFX W er dréis aler +! SFX W ir dréis alir +! SFX W ir dréis enir +! SFX W ecir iréis ecir +! SFX W ír iréis [eo]ír +! SFX W ar uéis olgar +! SFX W gar guéis egar +! SFX W gar guéis engar +! SFX W gar guéis ugar +! SFX W ogar guéis ogar +! SFX W car quéis olcar +! SFX W car quéis orcar +! SFX W ocar quéis ocar +! SFX W uar üéis guar +! +! +! SFX W Y 338 S +! SFX W r mos r +! SFX W er amos [eo]er +! SFX W er amos eder +! SFX W er amos ender +! SFX W er amos erder +! SFX W er amos erer +! SFX W er amos erner +! SFX W er amos erter +! SFX W er amos oder +! SFX W er amos oler +! SFX W er amos olver +! SFX W er amos order +! SFX W er amos over +! SFX W ir amos ernir +! SFX W ir amos eunir +! SFX W ir amos irir +! SFX W ir amos ohibir +! SFX W ebir ibamos ebir +! SFX W ar ábamos ar +! SFX W cer zcamos [^c]ocer +! SFX W cer zcamos [^fh]acer +! SFX W cer zcamos ecer +! SFX W cir zcamos ucir +! SFX W edir idamos edir +! SFX W endir indamos endir +! SFX W cer gamos [fh]acer +! SFX W er gamos [eo]ner +! SFX W er gamos aler +! SFX W ir gamos alir +! SFX W ecir igamos ecir +! SFX W eguir igamos eguir +! SFX W er igamos aer +! SFX W er igamos oer +! SFX W ír igamos oír +! SFX W enir engamos enir +! SFX W enchir inchamos enchir +! SFX W eír iamos eír +! SFX W egir ijamos egir +! SFX W emir imamos emir +! SFX W ormir urmamos ormir +! SFX W aber epamos saber +! SFX W caber quepamos caber +! SFX W erir iramos erir +! SFX W orir uramos orir +! SFX W ar áramos [^a]ndar +! SFX W ar áramos [^d]ar +! SFX W ar áramos [^n]dar +! SFX W r éramos alir +! SFX W r éramos ernir +! SFX W r éramos eunir +! SFX W r éramos ohibir +! SFX W er iéramos [^fh]acer +! SFX W er iéramos aler +! SFX W er iéramos e[cd]er +! SFX W er iéramos ender +! SFX W er iéramos er[dnt]er +! SFX W er iéramos o[clv]er +! SFX W er iéramos olver +! SFX W er iéramos or[cd]er +! SFX W eír iéramos eír +! SFX W ebir ibiéramos ebir +! SFX W acer iciéramos [fh]acer +! SFX W edir idiéramos edir +! SFX W endir indiéramos endir +! SFX W oder udiéramos oder +! SFX W egir igiéramos egir +! SFX W enchir inchiéramos enchir +! SFX W emir imiéramos emir +! SFX W ormir urmiéramos ormir +! SFX W enir iniéramos enir +! SFX W aber upiéramos aber +! SFX W erir iriéramos erir +! SFX W irir iriéramos irir +! SFX W orir uriéramos orir +! SFX W erer isiéramos erer +! SFX W oner usiéramos oner +! SFX W etir itiéramos etir +! SFX W entir intiéramos entir +! SFX W ertir irtiéramos ertir +! SFX W estir istiéramos estir +! SFX W eguir iguiéramos eguir +! SFX W ervir irviéramos ervir +! SFX W ar uviéramos andar +! SFX W ener uviéramos ener +! SFX W cir jéramos ucir +! SFX W er jéramos raer +! SFX W ecir ijéramos ecir +! SFX W er yéramos [eo]er +! SFX W er yéramos caer +! SFX W ir yéramos [^g]uir +! SFX W ír yéramos oír +! SFX W üir uyéramos güir +! SFX W eñir iñéramos eñir +! SFX W etir itamos etir +! SFX W entir intamos entir +! SFX W ertir irtamos ertir +! SFX W estir istamos estir +! SFX W ervir irvamos ervir +! SFX W er yamos oer +! SFX W ir yamos [^g]uir +! SFX W üir uyamos güir +! SFX W cer zamos cocer +! SFX W cer zamos orcer +! SFX W 0 íamos [^fh]acer +! SFX W 0 íamos [aeo]er +! SFX W 0 íamos [io]rir +! SFX W 0 íamos [üu]ir +! SFX W 0 íamos ar +! SFX W 0 íamos e[bdgmrtñ]ir +! SFX W 0 íamos e[cd]er +! SFX W 0 íamos e[ns]tir +! SFX W 0 íamos enchir +! SFX W 0 íamos ender +! SFX W 0 íamos endir +! SFX W 0 íamos er[dnt]er +! SFX W 0 íamos er[ntv]ir +! SFX W 0 íamos eunir +! SFX W 0 íamos o[clv]er +! SFX W 0 íamos olver +! SFX W 0 íamos or[cd]er +! SFX W 0 íamos ormir +! SFX W 0 íamos ucir +! SFX W er íamos er +! SFX W ir íamos ir +! SFX W ír íamos ír +! SFX W cer ríamos [fh]acer +! SFX W er ríamos aber +! SFX W er ríamos erer +! SFX W er ríamos oder +! SFX W er dríamos [eo]ner +! SFX W er dríamos aler +! SFX W ir dríamos alir +! SFX W ir dríamos enir +! SFX W ecir iríamos ecir +! SFX W ír iríamos [eo]ír +! SFX W eñir iñamos eñir +! SFX W 0 emos [^fh]acer +! SFX W 0 emos [aeo]er +! SFX W 0 emos [io]rir +! SFX W 0 emos [üu]ir +! SFX W 0 emos ar +! SFX W 0 emos e[bdgmrtñ]ir +! SFX W 0 emos e[cd]er +! SFX W 0 emos e[ns]tir +! SFX W 0 emos enchir +! SFX W 0 emos ender +! SFX W 0 emos endir +! SFX W 0 emos er[dnt]er +! SFX W 0 emos er[ntv]ir +! SFX W 0 emos eunir +! SFX W 0 emos o[clv]er +! SFX W 0 emos olver +! SFX W 0 emos or[cd]er +! SFX W 0 emos ormir +! SFX W 0 emos ucir +! SFX W ar emos [^g]uar +! SFX W ar emos [ae]hu[ms]ar +! SFX W ar emos [ae]ndar +! SFX W ar emos [aeo]hi[jlnt]ar +! SFX W ar emos ebrar +! SFX W ar emos edrar +! SFX W ar emos elar +! SFX W ar emos emblar +! SFX W ar emos embrar +! SFX W ar emos endrar +! SFX W ar emos ensar +! SFX W ar emos entar +! SFX W ar emos erbar +! SFX W ar emos ernar +! SFX W ar emos errar +! SFX W ar emos ertar +! SFX W ar emos esar +! SFX W ar emos estar +! SFX W ar emos etar +! SFX W ar emos evar +! SFX W ar emos obar +! SFX W ar emos oblar +! SFX W ar emos odar +! SFX W ar emos olar +! SFX W ar emos oldar +! SFX W ar emos ollar +! SFX W ar emos oltar +! SFX W ar emos onar +! SFX W ar emos ontar +! SFX W ar emos ontrar +! SFX W ar emos orar +! SFX W ar emos ordar +! SFX W ar emos ornar +! SFX W ar emos ortar +! SFX W ar emos osar +! SFX W ar emos ostar +! SFX W ar emos ostrar +! SFX W ar emos ovar +! SFX W ar emos oñar +! SFX W zar cemos [ae]izar +! SFX W zar cemos enzar +! SFX W zar cemos ezar +! SFX W zar cemos gonzar +! SFX W zar cemos orzar +! SFX W iar iemos iar +! SFX W cer remos [fh]acer +! SFX W er remos aber +! SFX W er remos erer +! SFX W er remos oder +! SFX W er dremos [eo]ner +! SFX W er dremos aler +! SFX W ir dremos alir +! SFX W ir dremos enir +! SFX W ecir iremos ecir +! SFX W ír iremos [eo]ír +! SFX W ar áremos [^a]ndar +! SFX W ar áremos [^d]ar +! SFX W ar áremos [^n]dar +! SFX W r éremos alir +! SFX W r éremos ernir +! SFX W r éremos eunir +! SFX W r éremos ohibir +! SFX W er iéremos [^fh]acer +! SFX W er iéremos aler +! SFX W er iéremos e[cd]er +! SFX W er iéremos ender +! SFX W er iéremos er[dnt]er +! SFX W er iéremos o[clv]er +! SFX W er iéremos olver +! SFX W er iéremos or[cd]er +! SFX W eír iéremos eír +! SFX W ebir ibiéremos ebir +! SFX W acer iciéremos [fh]acer +! SFX W edir idiéremos edir +! SFX W endir indiéremos endir +! SFX W oder udiéremos oder +! SFX W egir igiéremos egir +! SFX W enchir inchiéremos enchir +! SFX W emir imiéremos emir +! SFX W ormir urmiéremos ormir +! SFX W enir iniéremos enir +! SFX W aber upiéremos aber +! SFX W erir iriéremos erir +! SFX W irir iriéremos irir +! SFX W orir uriéremos orir +! SFX W erer isiéremos erer +! SFX W oner usiéremos oner +! SFX W etir itiéremos etir +! SFX W entir intiéremos entir +! SFX W ertir irtiéremos ertir +! SFX W estir istiéremos estir +! SFX W eguir iguiéremos eguir +! SFX W ervir irviéremos ervir +! SFX W ar uviéremos andar +! SFX W ener uviéremos ener +! SFX W cir jéremos ucir +! SFX W er jéremos raer +! SFX W ecir ijéremos ecir +! SFX W er yéremos [eo]er +! SFX W er yéremos caer +! SFX W ir yéremos [^g]uir +! SFX W ír yéremos oír +! SFX W üir uyéremos güir +! SFX W eñir iñéremos eñir +! SFX W ar ásemos [^d]ar +! SFX W ar ásemos [^n]dar +! SFX W r ásemos [^a]ndar +! SFX W r ésemos alir +! SFX W r ésemos ernir +! SFX W r ésemos eunir +! SFX W r ésemos ohibir +! SFX W er iésemos [^fh]acer +! SFX W er iésemos aler +! SFX W er iésemos e[cd]er +! SFX W er iésemos ender +! SFX W er iésemos er[dnt]er +! SFX W er iésemos o[clv]er +! SFX W er iésemos olver +! SFX W er iésemos or[cd]er +! SFX W eír iésemos eír +! SFX W ebir ibiésemos ebir +! SFX W acer iciésemos [fh]acer +! SFX W edir idiésemos edir +! SFX W endir indiésemos endir +! SFX W oder udiésemos oder +! SFX W egir igiésemos egir +! SFX W enchir inchiésemos enchir +! SFX W emir imiésemos emir +! SFX W ormir urmiésemos ormir +! SFX W enir iniésemos enir +! SFX W aber upiésemos aber +! SFX W erir iriésemos erir +! SFX W irir iriésemos irir +! SFX W orir uriésemos orir +! SFX W erer isiésemos erer +! SFX W oner usiésemos oner +! SFX W etir itiésemos etir +! SFX W entir intiésemos entir +! SFX W ertir irtiésemos ertir +! SFX W estir istiésemos estir +! SFX W eguir iguiésemos eguir +! SFX W ervir irviésemos ervir +! SFX W ar uviésemos andar +! SFX W ener uviésemos ener +! SFX W cir jésemos ucir +! SFX W er jésemos raer +! SFX W ecir ijésemos ecir +! SFX W er yésemos [eo]er +! SFX W er yésemos caer +! SFX W ir yésemos [^g]uir +! SFX W ír yésemos oír +! SFX W üir uyésemos güir +! SFX W eñir iñésemos eñir +! SFX W ar uemos olgar +! SFX W gar guemos egar +! SFX W gar guemos engar +! SFX W gar guemos ogar +! SFX W gar guemos ugar +! SFX W car quemos ocar +! SFX W car quemos olcar +! SFX W car quemos orcar +! SFX W uar üemos guar +! SFX W er imos [^fh]acer +! SFX W er imos aler +! SFX W er imos e[cd]er +! SFX W er imos ender +! SFX W er imos er[dnt]er +! SFX W er imos o[clv]er +! SFX W er imos olver +! SFX W er imos or[cd]er +! SFX W acer icimos [fh]acer +! SFX W oder udimos oder +! SFX W cir jimos ucir +! SFX W er jimos raer +! SFX W ecir ijimos ecir +! SFX W enir inimos enir +! SFX W aber upimos aber +! SFX W erer isimos erer +! SFX W oner usimos oner +! SFX W ar uvimos andar +! SFX W ener uvimos ener +! SFX W er ímos [eo]er +! SFX W er ímos caer +! +! +! +! SFX W Y 29 S +! SFX W 0 ás [^fh]acer +! SFX W 0 ás [aeo]er +! SFX W 0 ás [io]rir +! SFX W 0 ás [üu]ir +! SFX W 0 ás ar +! SFX W 0 ás e[bdgmrtñ]ir +! SFX W 0 ás e[cd]er +! SFX W 0 ás e[ns]tir +! SFX W 0 ás enchir +! SFX W 0 ás ender +! SFX W 0 ás endir +! SFX W 0 ás er[dnt]er +! SFX W 0 ás er[ntv]ir +! SFX W 0 ás eunir +! SFX W 0 ás o[clv]er +! SFX W 0 ás olver +! SFX W 0 ás or[cd]er +! SFX W 0 ás ormir +! SFX W 0 ás ucir +! SFX W cer rás [fh]acer +! SFX W er rás aber +! SFX W er rás erer +! SFX W er rás oder +! SFX W er drás [eo]ner +! SFX W er drás aler +! SFX W ir drás alir +! SFX W ir drás enir +! SFX W ecir irás ecir +! SFX W ír irás [eo]ír +! +! +! SFX W Y 29 S +! SFX W 0 á [^fh]acer +! SFX W 0 á [aeo]er +! SFX W 0 á [io]rir +! SFX W 0 á [üu]ir +! SFX W 0 á ar +! SFX W 0 á e[bdgmrtñ]ir +! SFX W 0 á e[cd]er +! SFX W 0 á e[ns]tir +! SFX W 0 á enchir +! SFX W 0 á ender +! SFX W 0 á endir +! SFX W 0 á er[dnt]er +! SFX W 0 á er[ntv]ir +! SFX W 0 á eunir +! SFX W 0 á o[clv]er +! SFX W 0 á olver +! SFX W 0 á or[cd]er +! SFX W 0 á ormir +! SFX W 0 á ucir +! SFX W cer rá [fh]acer +! SFX W er rá aber +! SFX W er rá erer +! SFX W er rá oder +! SFX W er drá [eo]ner +! SFX W er drá aler +! SFX W ir drá alir +! SFX W ir drá enir +! SFX W ecir irá ecir +! SFX W ír irá [eo]ír +! +! +! +! SFX W Y 38 S +! SFX W 0 é [^fh]acer +! SFX W 0 é [aeo]er +! SFX W 0 é [io]rir +! SFX W 0 é [üu]ir +! SFX W 0 é ar +! SFX W 0 é e[bdgmrtñ]ir +! SFX W 0 é e[cd]er +! SFX W 0 é e[ns]tir +! SFX W 0 é enchir +! SFX W 0 é ender +! SFX W 0 é endir +! SFX W 0 é er[dnt]er +! SFX W 0 é er[ntv]ir +! SFX W 0 é eunir +! SFX W 0 é o[clv]er +! SFX W 0 é olver +! SFX W 0 é or[cd]er +! SFX W 0 é ormir +! SFX W 0 é ucir +! SFX W aber é saber +! SFX W ar é [^a]ndar +! SFX W ar é [^cguzd]ar +! SFX W ar é [^g]uar +! SFX W ar é [^n]dar +! SFX W zar cé zar +! SFX W cer ré [fh]acer +! SFX W er ré aber +! SFX W er ré erer +! SFX W er ré oder +! SFX W er dré [eo]ner +! SFX W er dré aler +! SFX W ir dré alir +! SFX W ir dré enir +! SFX W ecir iré ecir +! SFX W ír iré [eo]ír +! SFX W ar ué gar +! SFX W car qué car +! SFX W uar üé guar +! +! +! SFX W Y 31 S +! SFX W er í [^fh]acer +! SFX W er í [eo]er +! SFX W er í aler +! SFX W er í caer +! SFX W er í e[cd]er +! SFX W er í ender +! SFX W er í er[dnt]er +! SFX W er í o[clv]er +! SFX W er í olver +! SFX W er í or[cd]er +! SFX W ir í [üu]ir +! SFX W ir í alir +! SFX W ir í ebir +! SFX W ir í edir +! SFX W ir í egir +! SFX W ir í emir +! SFX W ir í enchir +! SFX W ir í endir +! SFX W ir í entir +! SFX W ir í erir +! SFX W ir í ernir +! SFX W ir í ertir +! SFX W ir í ervir +! SFX W ir í estir +! SFX W ir í etir +! SFX W ir í eunir +! SFX W ir í eñir +! SFX W ir í irir +! SFX W ir í orir +! SFX W ir í ormir +! SFX W ír í [eo]ír +! +! +! +! SFX W Y 39 S +! SFX W ar ó [^a]ndar +! SFX W ar ó [^d]ar +! SFX W ar ó [^n]dar +! SFX W r ó alir +! SFX W r ó ernir +! SFX W r ó eunir +! SFX W r ó irir +! SFX W r ó ohibir +! SFX W er ió [^fh]acer +! SFX W er ió aler +! SFX W er ió e[cd]er +! SFX W er ió ender +! SFX W er ió er[dnt]er +! SFX W er ió o[clv]er +! SFX W er ió olver +! SFX W er ió or[cd]er +! SFX W er ió order +! SFX W eír ió eír +! SFX W ebir ibió ebir +! SFX W edir idió edir +! SFX W endir indió endir +! SFX W egir igió egir +! SFX W enchir inchió enchir +! SFX W emir imió emir +! SFX W ormir urmió ormir +! SFX W erir irió erir +! SFX W orir urió orir +! SFX W etir itió etir +! SFX W entir intió entir +! SFX W ertir irtió ertir +! SFX W estir istió estir +! SFX W eguir iguió eguir +! SFX W ervir irvió ervir +! SFX W er yó [eo]er +! SFX W er yó caer +! SFX W ir yó [^g]uir +! SFX W ír yó oír +! SFX W üir uyó güir +! SFX W eñir iñó eñir +! +! +! +! SFX W Y 21 +! SFX W r d [aeií]r +! SFX W r n [^c]ocer +! SFX W r n [cr]aer +! SFX W r n [eo]er +! SFX W r n a[bcl]er +! SFX W r n andar +! SFX W r n ecer +! SFX W r n guar +! SFX W r n oner +! SFX W r s [^c]ocer +! SFX W r s [cr]aer +! SFX W r s [eo]er +! SFX W r s a[bcl]er +! SFX W r s andar +! SFX W r s ecer +! SFX W r s guar +! SFX W r s oner +! SFX W r bais ar +! SFX W ir ís ir +! SFX W ír ís ír +! SFX W cer z [fh]acer +! +! SFX Y Y 102 +! SFX Y er ído [aeo]er +! SFX Y er ídos [aeo]er +! SFX Y er ída [aeo]er +! SFX Y er ídas [aeo]er +! SFX Y acer echo [fh]acer +! SFX Y acer echos [fh]acer +! SFX Y acer echa [fh]acer +! SFX Y acer echas [fh]acer +! SFX Y er ido oder +! SFX Y er idos oder +! SFX Y er ida oder +! SFX Y er idas oder +! SFX Y olver uelto olver +! SFX Y olver ueltos olver +! SFX Y olver uelta olver +! SFX Y olver ueltas olver +! SFX Y oner uesto oner +! SFX Y oner uestos oner +! SFX Y oner uesta oner +! SFX Y oner uestas oner +! SFX Y rir ierto abrir +! SFX Y rir iertos abrir +! SFX Y rir ierta abrir +! SFX Y rir iertas abrir +! SFX Y r do e[bdgmnrtñ]ir +! SFX Y r dos e[bdgmnrtñ]ir +! SFX Y r da e[bdgmnrtñ]ir +! SFX Y r das e[bdgmnrtñ]ir +! SFX Y ecir icho ecir +! SFX Y ecir ichos ecir +! SFX Y ecir icha ecir +! SFX Y ecir ichas ecir +! SFX Y r do [eo]ír +! SFX Y r dos [eo]ír +! SFX Y r da [eo]ír +! SFX Y r das [eo]ír +! SFX Y r do enchir +! SFX Y r dos enchir +! SFX Y r da enchir +! SFX Y r das enchir +! SFX Y r do en[dt]ir +! SFX Y r dos en[dt]ir +! SFX Y r da en[dt]ir +! SFX Y r das en[dt]ir +! SFX Y r do er[tv]ir +! SFX Y r dos er[tv]ir +! SFX Y r da er[tv]ir +! SFX Y r das er[tv]ir +! SFX Y r do estir +! SFX Y r dos estir +! SFX Y r da estir +! SFX Y r das estir +! SFX Y bir to ibir +! SFX Y bir tos ibir +! SFX Y bir ta ibir +! SFX Y bir tas ibir +! SFX Y orir uerto orir +! SFX Y orir uertos orir +! SFX Y orir uerta orir +! SFX Y orir uertas orir +! SFX Y r do ormir +! SFX Y r dos ormir +! SFX Y r da ormir +! SFX Y r das ormir +! SFX Y rir ierto ubrir +! SFX Y rir iertos ubrir +! SFX Y rir ierta ubrir +! SFX Y rir iertas ubrir +! SFX Y r do [üu]ir +! SFX Y r da [üu]ir +! SFX Y r dos [üu]ir +! SFX Y r das [üu]ir +! SFX Y er iendo [fh]acer +! SFX Y er yendo [aeo]er +! SFX Y oder udiendo oder +! SFX Y er iendo olver +! SFX Y er iendo oner +! SFX Y r endo abrir +! SFX Y ebir ibiendo ebir +! SFX Y ecir iciendo ecir +! SFX Y edir idiendo edir +! SFX Y egir igiendo egir +! SFX Y emir imiendo emir +! SFX Y eír iendo eír +! SFX Y eñir iñendo eñir +! SFX Y enchir inchiendo enchir +! SFX Y endir indiendo endir +! SFX Y enir iniendo enir +! SFX Y entir intiendo entir +! SFX Y ertir irtiendo ertir +! SFX Y ervir irviendo ervir +! SFX Y estir istiendo estir +! SFX Y eguir iguiendo eguir +! SFX Y erir iriendo erir +! SFX Y etir itiendo etir +! SFX Y r endo ibir +! SFX Y ír yendo oír +! SFX Y orir uriendo orir +! SFX Y ormir urmiendo ormir +! SFX Y r endo ubrir +! SFX Y ir yendo [^g]uir +! SFX Y üir uyendo güir +! +! SFX O Y 115 +! SFX O 0 me [eií]r +! SFX O 0 te [eií]r +! SFX O 0 se [eií]r +! SFX O 0 nos [eií]r +! SFX O 0 os [eií]r +! SFX O er yéndome [aeo]er +! SFX O er yéndote [aeo]er +! SFX O er yéndose [aeo]er +! SFX O er yéndonos [aeo]er +! SFX O er yéndoos [aeo]er +! SFX O oder udiéndome oder +! SFX O oder udiéndote oder +! SFX O oder udiéndose oder +! SFX O oder udiéndonos oder +! SFX O oder udiéndoos oder +! SFX O ebir ibiéndome ebir +! SFX O ebir ibiéndote ebir +! SFX O ebir ibiéndose ebir +! SFX O ebir ibiéndonos ebir +! SFX O ebir ibiéndoos ebir +! SFX O ecir iciéndome ecir +! SFX O ecir iciéndote ecir +! SFX O ecir iciéndose ecir +! SFX O ecir iciéndonos ecir +! SFX O ecir iciéndoos ecir +! SFX O edir idiéndome edir +! SFX O edir idiéndote edir +! SFX O edir idiéndose edir +! SFX O edir idiéndonos edir +! SFX O edir idiéndoos edir +! SFX O egir igiéndome egir +! SFX O egir igiéndote egir +! SFX O egir igiéndose egir +! SFX O egir igiéndonos egir +! SFX O egir igiéndoos egir +! SFX O emir imiéndome emir +! SFX O emir imiéndote emir +! SFX O emir imiéndose emir +! SFX O emir imiéndonos emir +! SFX O emir imiéndoos emir +! SFX O eír iéndome eír +! SFX O eír iéndote eír +! SFX O eír iéndose eír +! SFX O eír iéndonos eír +! SFX O eír iéndoos eír +! SFX O eñir iñéndome eñir +! SFX O eñir iñéndote eñir +! SFX O eñir iñéndose eñir +! SFX O eñir iñéndonos eñir +! SFX O eñir iñéndoos eñir +! SFX O endir indiéndome endir +! SFX O endir indiéndote endir +! SFX O endir indiéndose endir +! SFX O endir indiéndonos endir +! SFX O endir indiéndoos endir +! SFX O enir iniéndome enir +! SFX O enir iniéndote enir +! SFX O enir iniéndose enir +! SFX O enir iniéndonos enir +! SFX O enir iniéndoos enir +! SFX O entir intiéndome entir +! SFX O entir intiéndote entir +! SFX O entir intiéndose entir +! SFX O entir intiéndonos entir +! SFX O entir intiéndoos entir +! SFX O ertir irtiéndome ertir +! SFX O ertir irtiéndote ertir +! SFX O ertir irtiéndose ertir +! SFX O ertir irtiéndonos ertir +! SFX O ertir irtiéndoos ertir +! SFX O ervir irviéndome ervir +! SFX O ervir irviéndote ervir +! SFX O ervir irviéndose ervir +! SFX O ervir irviéndonos ervir +! SFX O ervir irviéndoos ervir +! SFX O estir istiéndome estir +! SFX O estir istiéndote estir +! SFX O estir istiéndose estir +! SFX O estir istiéndonos estir +! SFX O estir istiéndoos estir +! SFX O eguir iguiéndome eguir +! SFX O eguir iguiéndote eguir +! SFX O eguir iguiéndose eguir +! SFX O eguir iguiéndonos eguir +! SFX O eguir iguiéndoos eguir +! SFX O erir iriéndome erir +! SFX O erir iriéndote erir +! SFX O erir iriéndose erir +! SFX O erir iriéndonos erir +! SFX O erir iriéndoos erir +! SFX O etir itiéndome etir +! SFX O etir itiéndote etir +! SFX O etir itiéndose etir +! SFX O etir itiéndonos etir +! SFX O etir itiéndoos etir +! SFX O ír yéndome oír +! SFX O ír yéndote oír +! SFX O ír yéndose oír +! SFX O ír yéndonos oír +! SFX O ír yéndoos oír +! SFX O orir uriéndome orir +! SFX O orir uriéndote orir +! SFX O orir uriéndose orir +! SFX O orir uriéndonos orir +! SFX O orir uriéndoos orir +! SFX O ormir urmiéndome ormir +! SFX O ormir urmiéndote ormir +! SFX O ormir urmiéndose ormir +! SFX O ormir urmiéndonos ormir +! SFX O ormir urmiéndoos ormir +! SFX O ir yéndome [^g]uir +! SFX O ir yéndote [^g]uir +! SFX O ir yéndose [^g]uir +! SFX O ir yéndonos [^g]uir +! SFX O ir yéndoos [^g]uir +! +! SFX Q Y 138 +! SFX Q 0 lo [eií]r +! SFX Q 0 la [eií]r +! SFX Q 0 los [eií]r +! SFX Q 0 las [eií]r +! SFX Q 0 le [eií]r +! SFX Q 0 les [eií]r +! SFX Q er yéndolo [aeo]er +! SFX Q er yéndola [aeo]er +! SFX Q er yéndolos [aeo]er +! SFX Q er yéndolas [aeo]er +! SFX Q er yéndole [aeo]er +! SFX Q er yéndoles [aeo]er +! SFX Q oder udiéndolo oder +! SFX Q oder udiéndola oder +! SFX Q oder udiéndolos oder +! SFX Q oder udiéndolas oder +! SFX Q oder udiéndole oder +! SFX Q oder udiéndoles oder +! SFX Q ebir ibiéndolo ebir +! SFX Q ebir ibiéndolos ebir +! SFX Q ebir ibiéndola ebir +! SFX Q ebir ibiéndolas ebir +! SFX Q ebir ibiéndole ebir +! SFX Q ebir ibiéndoles ebir +! SFX Q ecir iciéndolo ecir +! SFX Q ecir iciéndolos ecir +! SFX Q ecir iciéndola ecir +! SFX Q ecir iciéndolas ecir +! SFX Q ecir iciéndole ecir +! SFX Q ecir iciéndoles ecir +! SFX Q edir idiéndolo edir +! SFX Q edir idiéndolos edir +! SFX Q edir idiéndola edir +! SFX Q edir idiéndolas edir +! SFX Q edir idiéndole edir +! SFX Q edir idiéndoles edir +! SFX Q egir igiéndolo egir +! SFX Q egir igiéndolos egir +! SFX Q egir igiéndola egir +! SFX Q egir igiéndolas egir +! SFX Q egir igiéndole egir +! SFX Q egir igiéndoles egir +! SFX Q emir imiéndolo emir +! SFX Q emir imiéndolos emir +! SFX Q emir imiéndola emir +! SFX Q emir imiéndolas emir +! SFX Q emir imiéndole emir +! SFX Q emir imiéndoles emir +! SFX Q eír iéndolo eír +! SFX Q eír iéndolos eír +! SFX Q eír iéndola eír +! SFX Q eír iéndolas eír +! SFX Q eír iéndole eír +! SFX Q eír iéndoles eír +! SFX Q eñir iñéndolo eñir +! SFX Q eñir iñéndolos eñir +! SFX Q eñir iñéndola eñir +! SFX Q eñir iñéndolas eñir +! SFX Q eñir iñéndole eñir +! SFX Q eñir iñéndoles eñir +! SFX Q endir indiéndolo endir +! SFX Q endir indiéndolos endir +! SFX Q endir indiéndola endir +! SFX Q endir indiéndolas endir +! SFX Q endir indiéndole endir +! SFX Q endir indiéndoles endir +! SFX Q enir iniéndolo enir +! SFX Q enir iniéndolos enir +! SFX Q enir iniéndola enir +! SFX Q enir iniéndolas enir +! SFX Q enir iniéndole enir +! SFX Q enir iniéndoles enir +! SFX Q entir intiéndolo entir +! SFX Q entir intiéndolos entir +! SFX Q entir intiéndola entir +! SFX Q entir intiéndolas entir +! SFX Q entir intiéndole entir +! SFX Q entir intiéndoles entir +! SFX Q ertir irtiéndolo ertir +! SFX Q ertir irtiéndolos ertir +! SFX Q ertir irtiéndola ertir +! SFX Q ertir irtiéndolas ertir +! SFX Q ertir irtiéndole ertir +! SFX Q ertir irtiéndoles ertir +! SFX Q ervir irviéndolo ervir +! SFX Q ervir irviéndolos ervir +! SFX Q ervir irviéndola ervir +! SFX Q ervir irviéndolas ervir +! SFX Q ervir irviéndole ervir +! SFX Q ervir irviéndoles ervir +! SFX Q estir istiéndolo estir +! SFX Q estir istiéndolos estir +! SFX Q estir istiéndola estir +! SFX Q estir istiéndolas estir +! SFX Q estir istiéndole estir +! SFX Q estir istiéndoles estir +! SFX Q eguir iguiéndolo eguir +! SFX Q eguir iguiéndolos eguir +! SFX Q eguir iguiéndola eguir +! SFX Q eguir iguiéndolas eguir +! SFX Q eguir iguiéndole eguir +! SFX Q eguir iguiéndoles eguir +! SFX Q erir iriéndolo erir +! SFX Q erir iriéndolos erir +! SFX Q erir iriéndola erir +! SFX Q erir iriéndolas erir +! SFX Q erir iriéndole erir +! SFX Q erir iriéndoles erir +! SFX Q etir itiéndolo etir +! SFX Q etir itiéndolos etir +! SFX Q etir itiéndola etir +! SFX Q etir itiéndolas etir +! SFX Q etir itiéndole etir +! SFX Q etir itiéndoles etir +! SFX Q ír yéndolo oír +! SFX Q ír yéndolos oír +! SFX Q ír yéndola oír +! SFX Q ír yéndolas oír +! SFX Q ír yéndole oír +! SFX Q ír yéndoles oír +! SFX Q orir uriéndolo orir +! SFX Q orir uriéndolos orir +! SFX Q orir uriéndola orir +! SFX Q orir uriéndolas orir +! SFX Q orir uriéndole orir +! SFX Q orir uriéndoles orir +! SFX Q ormir urmiéndolo ormir +! SFX Q ormir urmiéndolos ormir +! SFX Q ormir urmiéndola ormir +! SFX Q ormir urmiéndolas ormir +! SFX Q ormir urmiéndole ormir +! SFX Q ormir urmiéndoles ormir +! SFX Q ir yéndolo [^g]uir +! SFX Q ir yéndolos [^g]uir +! SFX Q ir yéndola [^g]uir +! SFX Q ir yéndolas [^g]uir +! SFX Q ir yéndole [^g]uir +! SFX Q ir yéndoles [^g]uir +! +! SFX Z Y 171 +! SFX Z er érmelo er +! SFX Z er érmela er +! SFX Z er érmelos er +! SFX Z er érmelas er +! SFX Z er értelo er +! SFX Z er értela er +! SFX Z er értelos er +! SFX Z er értelas er +! SFX Z er érselo er +! SFX Z er érsela er +! SFX Z er érselos er +! SFX Z er érselas er +! SFX Z er éroslo er +! SFX Z er érosla er +! SFX Z er éroslos er +! SFX Z er éroslas er +! SFX Z er érnoslo er +! SFX Z er érnosla er +! SFX Z er érnoslos er +! SFX Z er érnoslas er +! SFX Z er érnosles er +! SFX Z ir írmelo ir +! SFX Z ir írmela ir +! SFX Z ir írmele ir +! SFX Z ir írmelos ir +! SFX Z ir írmelas ir +! SFX Z ir írmeles ir +! SFX Z ir írtelo ir +! SFX Z ir írtela ir +! SFX Z ir írtele ir +! SFX Z ir írtelos ir +! SFX Z ir írtelas ir +! SFX Z ir írteles ir +! SFX Z ir írselo ir +! SFX Z ir írsela ir +! SFX Z ir írsele ir +! SFX Z ir írselos ir +! SFX Z ir írselas ir +! SFX Z ir írseles ir +! SFX Z ir íroslo ir +! SFX Z ir írosla ir +! SFX Z ir írosle ir +! SFX Z ir íroslos ir +! SFX Z ir íroslas ir +! SFX Z ir írosles ir +! SFX Z ir írnoslo ir +! SFX Z ir írnosla ir +! SFX Z ir írnosle ir +! SFX Z ir írnoslos ir +! SFX Z ir írnoslas ir +! SFX Z ir írnosles ir +! SFX Z er yéndomelo [aeo]er +! SFX Z er yéndomela [aeo]er +! SFX Z er yéndomele [aeo]er +! SFX Z er yéndomelos [aeo]er +! SFX Z er yéndomelas [aeo]er +! SFX Z er yéndomeles [aeo]er +! SFX Z er yéndotelo [aeo]er +! SFX Z er yéndotela [aeo]er +! SFX Z er yéndotele [aeo]er +! SFX Z er yéndotelos [aeo]er +! SFX Z er yéndotelas [aeo]er +! SFX Z er yéndoteles [aeo]er +! SFX Z er yéndoselo [aeo]er +! SFX Z er yéndosela [aeo]er +! SFX Z er yéndosele [aeo]er +! SFX Z er yéndoselos [aeo]er +! SFX Z er yéndoselas [aeo]er +! SFX Z er yéndoseles [aeo]er +! SFX Z er yéndooslo [aeo]er +! SFX Z er yéndoosla [aeo]er +! SFX Z er yéndoosle [aeo]er +! SFX Z er yéndooslos [aeo]er +! SFX Z er yéndooslas [aeo]er +! SFX Z er yéndoosles [aeo]er +! SFX Z er yéndonoslo [aeo]er +! SFX Z er yéndonosla [aeo]er +! SFX Z er yéndonosle [aeo]er +! SFX Z er yéndonoslos [aeo]er +! SFX Z er yéndonoslas [aeo]er +! SFX Z er yéndonosles [aeo]er +! SFX Z ir yéndomelo [^g]uir +! SFX Z ir yéndomelos [^g]uir +! SFX Z ir yéndomela [^g]uir +! SFX Z ir yéndomelas [^g]uir +! SFX Z ir yéndomele [^g]uir +! SFX Z ir yéndomeles [^g]uir +! SFX Z ir yéndotelo [^g]uir +! SFX Z ir yéndotelos [^g]uir +! SFX Z ir yéndotela [^g]uir +! SFX Z ir yéndotelas [^g]uir +! SFX Z ir yéndotele [^g]uir +! SFX Z ir yéndoteles [^g]uir +! SFX Z ir yéndoselo [^g]uir +! SFX Z ir yéndoselos [^g]uir +! SFX Z ir yéndosela [^g]uir +! SFX Z ir yéndoselas [^g]uir +! SFX Z ir yéndosele [^g]uir +! SFX Z ir yéndoseles [^g]uir +! SFX Z ir yéndooslo [^g]uir +! SFX Z ir yéndooslos [^g]uir +! SFX Z ir yéndoosla [^g]uir +! SFX Z ir yéndooslas [^g]uir +! SFX Z ir yéndoosle [^g]uir +! SFX Z ir yéndoosles [^g]uir +! SFX Z ir yéndonoslo [^g]uir +! SFX Z ir yéndonoslos [^g]uir +! SFX Z ir yéndonosla [^g]uir +! SFX Z ir yéndonoslas [^g]uir +! SFX Z ir yéndonosle [^g]uir +! SFX Z ir yéndonosles [^g]uir +! SFX Z egir igiéndomelo egir +! SFX Z egir igiéndomelos egir +! SFX Z egir igiéndomela egir +! SFX Z egir igiéndomelas egir +! SFX Z egir igiéndomele egir +! SFX Z egir igiéndomeles egir +! SFX Z egir igiéndotelo egir +! SFX Z egir igiéndotelos egir +! SFX Z egir igiéndotela egir +! SFX Z egir igiéndotelas egir +! SFX Z egir igiéndotele egir +! SFX Z egir igiéndoteles egir +! SFX Z egir igiéndoselo egir +! SFX Z egir igiéndoselos egir +! SFX Z egir igiéndosela egir +! SFX Z egir igiéndoselas egir +! SFX Z egir igiéndosele egir +! SFX Z egir igiéndoseles egir +! SFX Z egir igiéndooslo egir +! SFX Z egir igiéndooslos egir +! SFX Z egir igiéndoosla egir +! SFX Z egir igiéndooslas egir +! SFX Z egir igiéndoosle egir +! SFX Z egir igiéndoosles egir +! SFX Z egir igiéndonoslo egir +! SFX Z egir igiéndonoslos egir +! SFX Z egir igiéndonosla egir +! SFX Z egir igiéndonoslas egir +! SFX Z egir igiéndonosle egir +! SFX Z egir igiéndonosles egir +! SFX Z eguir iguiéndomelo eguir +! SFX Z eguir iguiéndomelos eguir +! SFX Z eguir iguiéndomela eguir +! SFX Z eguir iguiéndomelas eguir +! SFX Z eguir iguiéndomele eguir +! SFX Z eguir iguiéndomeles eguir +! SFX Z eguir iguiéndotelo eguir +! SFX Z eguir iguiéndotelos eguir +! SFX Z eguir iguiéndotela eguir +! SFX Z eguir iguiéndotelas eguir +! SFX Z eguir iguiéndotele eguir +! SFX Z eguir iguiéndoteles eguir +! SFX Z eguir iguiéndoselo eguir +! SFX Z eguir iguiéndoselos eguir +! SFX Z eguir iguiéndosela eguir +! SFX Z eguir iguiéndoselas eguir +! SFX Z eguir iguiéndosele eguir +! SFX Z eguir iguiéndoseles eguir +! SFX Z eguir iguiéndooslo eguir +! SFX Z eguir iguiéndooslos eguir +! SFX Z eguir iguiéndoosla eguir +! SFX Z eguir iguiéndooslas eguir +! SFX Z eguir iguiéndoosle eguir +! SFX Z eguir iguiéndoosles eguir +! SFX Z eguir iguiéndonoslo eguir +! SFX Z eguir iguiéndonoslos eguir +! SFX Z eguir iguiéndonosla eguir +! SFX Z eguir iguiéndonoslas eguir +! SFX Z eguir iguiéndonosle eguir +! SFX Z eguir iguiéndonosles eguir +--- 139,3509 ---- + SFX M 0 idades [elnrsz] +! SFX M 0 mente [elnrsz] +! +! SFX N Y 2 +! SFX N r damente [ai]r +! SFX N er idamente er +! +! SFX P Y 20 +! SFX P e a e +! SFX P o a o +! SFX P 0 s [eo] +! SFX P o as o +! SFX P e as e +! SFX P án ana án +! SFX P án anes án +! SFX P án anas án +! SFX P ín ina ín +! SFX P ín ines ín +! SFX P ín inas ín +! SFX P ón ona ón +! SFX P ón ones ón +! SFX P ón onas ón +! SFX P 0 a [^aons] +! SFX P 0 es [^aons] +! SFX P 0 as [^aons] +! SFX P és esa és +! SFX P és eses és +! SFX P és esas és +! +! SFX H Y 2 +! SFX H r ción [ai]r +! SFX H r ciones [ai]r +! +! SFX I Y 4 +! SFX I r miento [ai]r +! SFX I r mientos [ai]r +! SFX I er imiento er +! SFX I er imientos er +! +! SFX L Y 6 +! SFX L r nte ar +! SFX L r ntes ar +! SFX L er iente er +! SFX L er ientes er +! SFX L r ente ir +! SFX L r entes ir +! +! SFX R Y 20 +! SFX R 0 me [aei]r +! SFX R 0 te [aei]r +! SFX R 0 se [aei]r +! SFX R 0 nos [aei]r +! SFX R 0 os [aei]r +! SFX R ar ándome ar +! SFX R ar ándote ar +! SFX R ar ándose ar +! SFX R ar ándonos ar +! SFX R ar ándoos ar +! SFX R er iéndome er +! SFX R er iéndote er +! SFX R er iéndose er +! SFX R er iéndonos er +! SFX R er iéndoos er +! SFX R r éndome ir +! SFX R r éndote ir +! SFX R r éndose ir +! SFX R r éndonos ir +! SFX R r éndoos ir +! +! SFX S Y 11 +! SFX S 0 s [aeiouáéó] +! SFX S 0 es [úídjlry] +! SFX S z ces z +! SFX S 0 es [^é]s +! SFX S 0 es [^áéíóú]n +! SFX S án anes án +! SFX S én enes én +! SFX S ín ines ín +! SFX S ón ones ón +! SFX S ún unes ún +! SFX S és eses és +! +! SFX T Y 24 +! SFX T 0 lo [aei]r +! SFX T 0 la [aei]r +! SFX T 0 le [aei]r +! SFX T 0 los [aei]r +! SFX T 0 las [aei]r +! SFX T 0 les [aei]r +! SFX T ar ándolo ar +! SFX T ar ándola ar +! SFX T ar ándole ar +! SFX T ar ándolos ar +! SFX T ar ándolas ar +! SFX T ar ándoles ar +! SFX T er iéndolo er +! SFX T er iéndola er +! SFX T er iéndole er +! SFX T er iéndolos er +! SFX T er iéndolas er +! SFX T er iéndoles er +! SFX T r éndolo ir +! SFX T r éndola ir +! SFX T r éndole ir +! SFX T r éndolos ir +! SFX T r éndolas ir +! SFX T r éndoles ir +! +! SFX U Y 120 +! SFX U ar ármelo ar +! SFX U ar ártelo ar +! SFX U ar árselo ar +! SFX U ar árnoslo ar +! SFX U ar ároslo ar +! SFX U ar ármela ar +! SFX U ar ártela ar +! SFX U ar ársela ar +! SFX U ar árnosla ar +! SFX U ar árosla ar +! SFX U ar ármelos ar +! SFX U ar ártelos ar +! SFX U ar árselos ar +! SFX U ar árnoslos ar +! SFX U ar ároslos ar +! SFX U ar ármelas ar +! SFX U ar ártelas ar +! SFX U ar árselas ar +! SFX U ar árnoslas ar +! SFX U ar ároslas ar +! SFX U ar ándomelo ar +! SFX U ar ándotelo ar +! SFX U ar ándoselo ar +! SFX U ar ándonoslo ar +! SFX U ar ándooslo ar +! SFX U ar ándomela ar +! SFX U ar ándotela ar +! SFX U ar ándosela ar +! SFX U ar ándonosla ar +! SFX U ar ándoosla ar +! SFX U ar ándomelos ar +! SFX U ar ándotelos ar +! SFX U ar ándoselos ar +! SFX U ar ándonoslos ar +! SFX U ar ándooslos ar +! SFX U ar ándomelas ar +! SFX U ar ándotelas ar +! SFX U ar ándoselas ar +! SFX U ar ándonoslas ar +! SFX U ar ándooslas ar +! SFX U er érmelo er +! SFX U er értelo er +! SFX U er érselo er +! SFX U er érnoslo er +! SFX U er éroslo er +! SFX U er érmela er +! SFX U er értela er +! SFX U er érsela er +! SFX U er érnosla er +! SFX U er érosla er +! SFX U er érmelos er +! SFX U er értelos er +! SFX U er érselos er +! SFX U er érnoslos er +! SFX U er éroslos er +! SFX U er érmelas er +! SFX U er értelas er +! SFX U er érselas er +! SFX U er érnoslas er +! SFX U er éroslas er +! SFX U er iéndomelo er +! SFX U er iéndotelo er +! SFX U er iéndoselo er +! SFX U er iéndonoslo er +! SFX U er iéndooslo er +! SFX U er iéndomela er +! SFX U er iéndotela er +! SFX U er iéndosela er +! SFX U er iéndonosla er +! SFX U er iéndoosla er +! SFX U er iéndomelos er +! SFX U er iéndotelos er +! SFX U er iéndoselos er +! SFX U er iéndonoslos er +! SFX U er iéndooslos er +! SFX U er iéndomelas er +! SFX U er iéndotelas er +! SFX U er iéndoselas er +! SFX U er iéndonoslas er +! SFX U er iéndooslas er +! SFX U ir írmelo ir +! SFX U ir írtelo ir +! SFX U ir írselo ir +! SFX U ir írnoslo ir +! SFX U ir íroslo ir +! SFX U ir írmela ir +! SFX U ir írtela ir +! SFX U ir írsela ir +! SFX U ir írnosla ir +! SFX U ir írosla ir +! SFX U ir írmelas ir +! SFX U ir írtelas ir +! SFX U ir írselas ir +! SFX U ir írnoslas ir +! SFX U ir íroslas ir +! SFX U ir írmelos ir +! SFX U ir írtelos ir +! SFX U ir írselos ir +! SFX U ir írnoslos ir +! SFX U ir íroslos ir +! SFX U r éndomelo ir +! SFX U r éndotelo ir +! SFX U r éndoselo ir +! SFX U r éndonoslo ir +! SFX U r éndooslo ir +! SFX U r éndomela ir +! SFX U r éndotela ir +! SFX U r éndosela ir +! SFX U r éndonosla ir +! SFX U r éndoosla ir +! SFX U r éndomelos ir +! SFX U r éndotelos ir +! SFX U r éndoselos ir +! SFX U r éndonoslos ir +! SFX U r éndooslos ir +! SFX U r éndomelas ir +! SFX U r éndotelas ir +! SFX U r éndoselas ir +! SFX U r éndonoslas ir +! SFX U r éndooslas ir +! +! SFX V Y 169 +! SFX V ar o ar +! SFX V er o [^cg]er +! SFX V cer zo cer +! SFX V ger jo ger +! SFX V ir o [^cgu]ir +! SFX V cir zo cir +! SFX V gir jo gir +! SFX V uir o guir +! SFX V quir co quir +! SFX V r s [ae]r +! SFX V ir es ir +! SFX V ar a ar +! SFX V er e er +! SFX V ir e ir +! SFX V r mos [aei]r +! SFX V ar áis ar +! SFX V er éis er +! SFX V ir ís ir +! SFX V r n [ae]r +! SFX V ir en ir +! SFX V r ba ar +! SFX V er ía er +! SFX V ir ía ir +! SFX V r bas ar +! SFX V er ías er +! SFX V ir ías ir +! SFX V ar ábamos ar +! SFX V er íamos er +! SFX V ir íamos ir +! SFX V r bais ar +! SFX V er íais er +! SFX V ir íais ir +! SFX V r ban ar +! SFX V er ían er +! SFX V ir ían ir +! SFX V ar é [^czg]ar +! SFX V car qué car +! SFX V ar ué gar +! SFX V zar cé zar +! SFX V er í er +! SFX V ir í ir +! SFX V r ste [ai]r +! SFX V er iste er +! SFX V ar ó ar +! SFX V er ió er +! SFX V r ó ir +! SFX V er imos er +! SFX V r steis [ai]r +! SFX V er isteis er +! SFX V 0 on ar +! SFX V er ieron er +! SFX V r eron ir +! SFX V 0 é [aei]r +! SFX V 0 ás [aei]r +! SFX V 0 á [aei]r +! SFX V 0 emos [aei]r +! SFX V 0 éis [aei]r +! SFX V 0 án [aei]r +! SFX V 0 ía [aei]r +! SFX V 0 ías [aei]r +! SFX V 0 íamos [aei]r +! SFX V 0 íais [aei]r +! SFX V 0 ían [aei]r +! SFX V ar e [^czg]ar +! SFX V car que car +! SFX V ar ue gar +! SFX V zar ce zar +! SFX V er a [^cg]er +! SFX V cer za cer +! SFX V ger ja ger +! SFX V ir a [^cgu]ir +! SFX V cir za cir +! SFX V gir ja gir +! SFX V uir a guir +! SFX V quir ca quir +! SFX V ar es [^czg]ar +! SFX V car ques car +! SFX V ar ues gar +! SFX V zar ces zar +! SFX V er as [^cg]er +! SFX V cer zas cer +! SFX V ger jas ger +! SFX V ir as [^cgu]ir +! SFX V cir zas cir +! SFX V gir jas gir +! SFX V uir as guir +! SFX V quir cas quir +! SFX V ar emos [^czg]ar +! SFX V car quemos car +! SFX V ar uemos gar +! SFX V zar cemos zar +! SFX V er amos [^cg]er +! SFX V cer zamos cer +! SFX V ger jamos ger +! SFX V ir amos [^cgu]ir +! SFX V cir zamos cir +! SFX V gir jamos gir +! SFX V uir amos guir +! SFX V quir camos quir +! SFX V ar éis [^czg]ar +! SFX V car quéis car +! SFX V ar uéis gar +! SFX V zar céis zar +! SFX V er áis [^cg]er +! SFX V cer záis cer +! SFX V ger jáis ger +! SFX V ir áis [^cgu]ir +! SFX V cir záis cir +! SFX V gir jáis gir +! SFX V uir áis guir +! SFX V quir cáis quir +! SFX V ar en [^czg]ar +! SFX V car quen car +! SFX V ar uen gar +! SFX V zar cen zar +! SFX V er an [^cg]er +! SFX V cer zan cer +! SFX V ger jan ger +! SFX V ir an [^cgu]ir +! SFX V cir zan cir +! SFX V gir jan gir +! SFX V uir an guir +! SFX V quir can quir +! SFX V r se ar +! SFX V r ra ar +! SFX V er iese er +! SFX V er iera er +! SFX V r ese ir +! SFX V r era ir +! SFX V r ses ar +! SFX V r ras ar +! SFX V er ieses er +! SFX V er ieras er +! SFX V r eses ir +! SFX V r eras ir +! SFX V ar ásemos ar +! SFX V ar áramos ar +! SFX V er iésemos er +! SFX V er iéramos er +! SFX V r ésemos ir +! SFX V r éramos ir +! SFX V r seis ar +! SFX V r rais ar +! SFX V er ieseis er +! SFX V er ierais er +! SFX V r eseis ir +! SFX V r erais ir +! SFX V r sen ar +! SFX V r ran ar +! SFX V er iesen er +! SFX V er ieran er +! SFX V r esen ir +! SFX V r eran ir +! SFX V r re ar +! SFX V er iere er +! SFX V r ere ir +! SFX V r res ar +! SFX V er ieres er +! SFX V r eres ir +! SFX V ar áremos ar +! SFX V er iéremos er +! SFX V r éremos ir +! SFX V r reis ar +! SFX V er iereis er +! SFX V r ereis ir +! SFX V r ren ar +! SFX V er ieren er +! SFX V r eren ir +! SFX V r d r +! +! SFX X Y 11 +! SFX X r do [ai]r +! SFX X r dos [ai]r +! SFX X r da [ai]r +! SFX X r das [ai]r +! SFX X er ido er +! SFX X er idos er +! SFX X er ida er +! SFX X er idas er +! SFX X r ndo ar +! SFX X er iendo er +! SFX X r endo ir +! +! SFX W Y 197 S +! SFX W ar a andar +! SFX W ar a guar +! SFX W er a [eo]er +! SFX W r ba ar +! SFX W obar ueba obar +! SFX W ebir iba ebir +! SFX W erbar ierba erbar +! SFX W ibir íba ohibir +! SFX W ocar ueca ocar +! SFX W olcar uelca olcar +! SFX W orcar uerca orcar +! SFX W cer zca [^c]ocer +! SFX W cer zca [^fh]acer +! SFX W cer zca ecer +! SFX W cir zca ucir +! SFX W eder ieda eder +! SFX W odar ueda odar +! SFX W oder ueda oder +! SFX W edir ida edir +! SFX W oldar uelda [^g]oldar +! SFX W oldar üelda goldar +! SFX W endar ienda endar +! SFX W ender ienda ender +! SFX W endir inda endir +! SFX W erder ierda erder +! SFX W ordar uerda ordar +! SFX W order uerda order +! SFX W cer ga [fh]acer +! SFX W er ga [eo]ner +! SFX W er ga aler +! SFX W ir ga alir +! SFX W gar ega ugar +! SFX W egar iega egar +! SFX W ogar uega ogar +! SFX W ecir iga ecir +! SFX W eguir iga eguir +! SFX W er iga aer +! SFX W er iga oer +! SFX W ír iga oír +! SFX W olgar uelga olgar +! SFX W enir enga enir +! SFX W engar ienga engar +! SFX W enchir incha enchir +! SFX W egir ija egir +! SFX W ijar íja [ae]hijar +! SFX W oblar uebla oblar +! SFX W emblar iembla emblar +! SFX W elar iela elar +! SFX W olar uela olar +! SFX W oler uela oler +! SFX W ollar uella [^g]ollar +! SFX W ollar üella gollar +! SFX W ilar íla [ae]hilar +! SFX W emir ima emir +! SFX W ormir uerma ormir +! SFX W umar úma [ae]humar +! SFX W onar uena onar +! SFX W ernar ierna ernar +! SFX W erner ierna erner +! SFX W ernir ierna ernir +! SFX W ornar uerna ornar +! SFX W inar ína [aeo]hinar +! SFX W unir úna eunir +! SFX W aber epa saber +! SFX W caber quepa caber +! SFX W r ra [^a]ndar +! SFX W r ra [^d]ar +! SFX W r ra [^n]dar +! SFX W ebrar iebra ebrar +! SFX W embrar iembra embrar +! SFX W edrar iedra edrar +! SFX W endrar iendra endrar +! SFX W r era alir +! SFX W r era ernir +! SFX W r era eunir +! SFX W r era ohibir +! SFX W er iera [^fh]acer +! SFX W er iera aler +! SFX W er iera e[cd]er +! SFX W er iera ender +! SFX W er iera er[dnt]er +! SFX W er iera o[clv]er +! SFX W er iera olver +! SFX W er iera or[cd]er +! SFX W erer iera erer +! SFX W erir iera erir +! SFX W eír iera eír +! SFX W irir iera irir +! SFX W ebir ibiera ebir +! SFX W acer iciera [fh]acer +! SFX W edir idiera edir +! SFX W endir indiera endir +! SFX W oder udiera oder +! SFX W egir igiera egir +! SFX W enchir inchiera enchir +! SFX W emir imiera emir +! SFX W ormir urmiera ormir +! SFX W enir iniera enir +! SFX W aber upiera aber +! SFX W erir iriera erir +! SFX W irir iriera irir +! SFX W orir uriera orir +! SFX W erer isiera erer +! SFX W oner usiera oner +! SFX W etir itiera etir +! SFX W entir intiera entir +! SFX W ertir irtiera ertir +! SFX W estir istiera estir +! SFX W eguir iguiera eguir +! SFX W ervir irviera ervir +! SFX W ar uviera andar +! SFX W ener uviera ener +! SFX W cir jera ucir +! SFX W er jera raer +! SFX W ecir ijera ecir +! SFX W orar uera [^g]orar +! SFX W orir uera orir +! SFX W er yera [eo]er +! SFX W er yera caer +! SFX W ir yera [^g]uir +! SFX W ír yera oír +! SFX W üir uyera güir +! SFX W eñir iñera eñir +! SFX W orar üera gorar +! SFX W errar ierra errar +! SFX W ontrar uentra ontrar +! SFX W ostrar uestra ostrar +! SFX W esar iesa esar +! SFX W osar uesa osar +! SFX W ensar iensa ensar +! SFX W usar úsa [ae]husar +! SFX W etar ieta etar +! SFX W etir ita etir +! SFX W oltar uelta oltar +! SFX W entar ienta entar +! SFX W entir ienta entir +! SFX W ontar uenta ontar +! SFX W ertar ierta ertar +! SFX W erter ierta erter +! SFX W ertir ierta ertir +! SFX W ortar uerta ortar +! SFX W estar iesta estar +! SFX W ostar uesta ostar +! SFX W estir ista estir +! SFX W itar íta [ae]hitar +! SFX W evar ieva evar +! SFX W ovar ueva ovar +! SFX W over ueva over +! SFX W olver uelva olver +! SFX W ervir irva ervir +! SFX W er ya oer +! SFX W ir ya [^g]uir +! SFX W üir uya güir +! SFX W ezar ieza ezar +! SFX W ocer ueza cocer +! SFX W enzar ienza enzar +! SFX W onzar üenza gonzar +! SFX W orcer uerza orcer +! SFX W orzar uerza orzar +! SFX W izar íza [ae]izar +! SFX W 0 ía [^fh]acer +! SFX W 0 ía [aeo]er +! SFX W 0 ía [io]rir +! SFX W 0 ía [üu]ir +! SFX W 0 ía ar +! SFX W 0 ía e[bdgmrtñ]ir +! SFX W 0 ía e[cd]er +! SFX W 0 ía e[ns]tir +! SFX W 0 ía enchir +! SFX W 0 ía ender +! SFX W 0 ía endir +! SFX W 0 ía er[dnt]er +! SFX W 0 ía er[ntv]ir +! SFX W 0 ía eunir +! SFX W 0 ía o[clv]er +! SFX W 0 ía olver +! SFX W 0 ía or[cd]er +! SFX W 0 ía ormir +! SFX W 0 ía ucir +! SFX W er ía er +! SFX W eír ía eír +! SFX W iar ía iar +! SFX W ir ía ir +! SFX W ír ía ír +! SFX W cer ría [fh]acer +! SFX W er ría aber +! SFX W er ría erer +! SFX W er ría oder +! SFX W er dría [eo]ner +! SFX W er dría aler +! SFX W ir dría alir +! SFX W ir dría enir +! SFX W ecir iría ecir +! SFX W ír iría [eo]ír +! SFX W oñar ueña oñar +! SFX W eñir iña eñir +! SFX W uar úa [^g]uar +! +! SFX W Y 264 S +! SFX W ar e andar +! SFX W er e [^c]ocer +! SFX W er e [cr]aer +! SFX W er e [eo]er +! SFX W er e a[bcl]er +! SFX W er e ecer +! SFX W er e oner +! SFX W ir e alir +! SFX W ir e ucir +! SFX W obar uebe obar +! SFX W ebir ibe ebir +! SFX W erbar ierbe erbar +! SFX W ibir íbe ohibir +! SFX W ezar iece ezar +! SFX W ocer uece cocer +! SFX W acer ice [fh]acer +! SFX W ecir ice ecir +! SFX W enzar ience enzar +! SFX W onzar üence gonzar +! SFX W orcer uerce orcer +! SFX W orzar uerce orzar +! SFX W izar íce [ae]izar +! SFX W eder iede eder +! SFX W odar uede odar +! SFX W oder uede oder +! SFX W edir ide edir +! SFX W oldar uelde [^g]oldar +! SFX W oldar üelde goldar +! SFX W endar iende endar +! SFX W ender iende ender +! SFX W endir inde endir +! SFX W erder ierde erder +! SFX W ordar uerde ordar +! SFX W order uerde order +! SFX W oder ude oder +! SFX W egir ige egir +! SFX W enchir inche enchir +! SFX W cir je ucir +! SFX W er je raer +! SFX W ecir ije ecir +! SFX W ijar íje [ae]hijar +! SFX W oblar ueble oblar +! SFX W emblar iemble emblar +! SFX W elar iele elar +! SFX W olar uele olar +! SFX W oler uele oler +! SFX W ollar uelle [^g]ollar +! SFX W ollar üelle gollar +! SFX W ilar íle [ae]hilar +! SFX W emir ime emir +! SFX W ormir uerme ormir +! SFX W umar úme [ae]humar +! SFX W ener iene ener +! SFX W enir iene enir +! SFX W onar uene onar +! SFX W enir ine enir +! SFX W ernar ierne ernar +! SFX W erner ierne erner +! SFX W ernir ierne ernir +! SFX W ornar uerne ornar +! SFX W inar íne [aeo]hinar +! SFX W unir úne eunir +! SFX W aber upe aber +! SFX W r re [^a]ndar +! SFX W r re [^d]ar +! SFX W r re [^n]dar +! SFX W ebrar iebre ebrar +! SFX W embrar iembre embrar +! SFX W edrar iedre edrar +! SFX W endrar iendre endrar +! SFX W r ere alir +! SFX W r ere ernir +! SFX W r ere eunir +! SFX W r ere ohibir +! SFX W er iere [^fh]acer +! SFX W er iere aler +! SFX W er iere e[cd]er +! SFX W er iere ender +! SFX W er iere er[dnt]er +! SFX W er iere o[clv]er +! SFX W er iere olver +! SFX W er iere or[cd]er +! SFX W erer iere erer +! SFX W erir iere erir +! SFX W eír iere eír +! SFX W irir iere irir +! SFX W ebir ibiere ebir +! SFX W acer iciere [fh]acer +! SFX W edir idiere edir +! SFX W endir indiere endir +! SFX W oder udiere oder +! SFX W egir igiere egir +! SFX W enchir inchiere enchir +! SFX W emir imiere emir +! SFX W ormir urmiere ormir +! SFX W enir iniere enir +! SFX W aber upiere aber +! SFX W erir iriere erir +! SFX W irir iriere irir +! SFX W orir uriere orir +! SFX W erer isiere erer +! SFX W oner usiere oner +! SFX W etir itiere etir +! SFX W entir intiere entir +! SFX W ertir irtiere ertir +! SFX W estir istiere estir +! SFX W eguir iguiere eguir +! SFX W ervir irviere ervir +! SFX W ar uviere andar +! SFX W ener uviere ener +! SFX W cir jere ucir +! SFX W er jere raer +! SFX W ecir ijere ecir +! SFX W orar uere [^g]orar +! SFX W orir uere orir +! SFX W er yere [eo]er +! SFX W er yere caer +! SFX W ir yere [^g]uir +! SFX W ír yere oír +! SFX W üir uyere güir +! SFX W eñir iñere eñir +! SFX W orar üere gorar +! SFX W errar ierre errar +! SFX W ontrar uentre ontrar +! SFX W ostrar uestre ostrar +! SFX W r se [^a]ndar +! SFX W r se [^d]ar +! SFX W r se [^n]dar +! SFX W r ese alir +! SFX W r ese ernir +! SFX W r ese eunir +! SFX W r ese ohibir +! SFX W er iese [^fh]acer +! SFX W er iese aler +! SFX W er iese e[cd]er +! SFX W er iese ender +! SFX W er iese er[dnt]er +! SFX W er iese o[clv]er +! SFX W er iese olver +! SFX W er iese or[cd]er +! SFX W esar iese esar +! SFX W eír iese eír +! SFX W ebir ibiese ebir +! SFX W acer iciese [fh]acer +! SFX W edir idiese edir +! SFX W endir indiese endir +! SFX W oder udiese oder +! SFX W egir igiese egir +! SFX W enchir inchiese enchir +! SFX W emir imiese emir +! SFX W ormir urmiese ormir +! SFX W enir iniese enir +! SFX W aber upiese aber +! SFX W erir iriese erir +! SFX W irir iriese irir +! SFX W orir uriese orir +! SFX W erer isiese erer +! SFX W oner usiese oner +! SFX W etir itiese etir +! SFX W entir intiese entir +! SFX W ertir irtiese ertir +! SFX W estir istiese estir +! SFX W eguir iguiese eguir +! SFX W ervir irviese ervir +! SFX W ar uviese andar +! SFX W ener uviese ener +! SFX W cir jese ucir +! SFX W er jese raer +! SFX W ecir ijese ecir +! SFX W osar uese osar +! SFX W er yese [eo]er +! SFX W er yese caer +! SFX W ir yese [^g]uir +! SFX W ír yese oír +! SFX W üir uyese güir +! SFX W eñir iñese eñir +! SFX W erer ise erer +! SFX W ensar iense ensar +! SFX W oner use oner +! SFX W umar úse [ae]husar +! SFX W etar iete etar +! SFX W etir ite etir +! SFX W oltar uelte oltar +! SFX W entar iente entar +! SFX W entir iente entir +! SFX W ontar uente ontar +! SFX W ertar ierte ertar +! SFX W erter ierte erter +! SFX W ertir ierte ertir +! SFX W ortar uerte ortar +! SFX W r ste [^a]ndar +! SFX W r ste [^d]ar +! SFX W r ste [^n]dar +! SFX W r ste [eo]ír +! SFX W r ste [üu]ir +! SFX W r ste alir +! SFX W r ste ebir +! SFX W r ste edir +! SFX W r ste egir +! SFX W r ste emir +! SFX W r ste enchir +! SFX W r ste endir +! SFX W r ste entir +! SFX W r ste erir +! SFX W r ste ernir +! SFX W r ste ertir +! SFX W r ste ervir +! SFX W r ste estir +! SFX W r ste etir +! SFX W r ste eunir +! SFX W r ste eñir +! SFX W r ste irir +! SFX W r ste orir +! SFX W r ste ormir +! SFX W estar ieste estar +! SFX W ostar ueste ostar +! SFX W er iste [^fh]acer +! SFX W er iste aler +! SFX W er iste e[cd]er +! SFX W er iste ender +! SFX W er iste er[dnt]er +! SFX W er iste o[clv]er +! SFX W er iste olver +! SFX W er iste or[cd]er +! SFX W estir iste estir +! SFX W acer iciste [fh]acer +! SFX W oder udiste oder +! SFX W cir jiste ucir +! SFX W er jiste raer +! SFX W ecir ijiste ecir +! SFX W enir iniste enir +! SFX W aber upiste aber +! SFX W erer isiste erer +! SFX W oner usiste oner +! SFX W ar uviste andar +! SFX W ener uviste ener +! SFX W er íste [eo]er +! SFX W er íste caer +! SFX W itar íte [ae]hitar +! SFX W gar egue ugar +! SFX W egar iegue egar +! SFX W ogar uegue ogar +! SFX W eguir igue eguir +! SFX W olgar uelgue olgar +! SFX W engar iengue engar +! SFX W ocar ueque ocar +! SFX W olcar uelque olcar +! SFX W orcar uerque orcar +! SFX W evar ieve evar +! SFX W ovar ueve ovar +! SFX W over ueve over +! SFX W olver uelve olver +! SFX W ervir irve ervir +! SFX W ar uve andar +! SFX W ener uve ener +! SFX W ír ye oír +! SFX W uir uye [^g]uir +! SFX W üir uye güir +! SFX W eír íe eír +! SFX W iar íe iar +! SFX W oñar ueñe oñar +! SFX W eñir iñe eñir +! SFX W uar úe [^g]uar +! SFX W uar üe guar +! +! +! SFX W Y 195 S +! SFX W er an [eo]er +! SFX W r ban ar +! SFX W obar ueban obar +! SFX W ebir iban ebir +! SFX W erbar ierban erbar +! SFX W ibir íban ohibir +! SFX W ocar uecan ocar +! SFX W olcar uelcan olcar +! SFX W orcar uercan orcar +! SFX W cer zcan [^c]ocer +! SFX W cer zcan [^fh]acer +! SFX W cer zcan ecer +! SFX W cir zcan ucir +! SFX W eder iedan eder +! SFX W odar uedan odar +! SFX W oder uedan oder +! SFX W edir idan edir +! SFX W oldar ueldan [^g]oldar +! SFX W oldar üeldan goldar +! SFX W endar iendan endar +! SFX W ender iendan ender +! SFX W endir indan endir +! SFX W erder ierdan erder +! SFX W ordar uerdan ordar +! SFX W order uerdan order +! SFX W cer gan [fh]acer +! SFX W er gan [eo]ner +! SFX W er gan aler +! SFX W ir gan alir +! SFX W gar egan ugar +! SFX W egar iegan egar +! SFX W ogar uegan ogar +! SFX W ecir igan ecir +! SFX W eguir igan eguir +! SFX W er igan aer +! SFX W er igan oer +! SFX W ír igan oír +! SFX W olgar uelgan olgar +! SFX W enir engan enir +! SFX W engar iengan engar +! SFX W enchir inchan enchir +! SFX W egir ijan egir +! SFX W ijar íjan [ae]hijar +! SFX W oblar ueblan oblar +! SFX W emblar iemblan emblar +! SFX W elar ielan elar +! SFX W olar uelan olar +! SFX W oler uelan oler +! SFX W ollar uellan [^g]ollar +! SFX W ollar üellan gollar +! SFX W ilar ílan [ae]hilar +! SFX W emir iman emir +! SFX W ormir uerman ormir +! SFX W umar úman [ae]humar +! SFX W onar uenan onar +! SFX W ernar iernan ernar +! SFX W erner iernan erner +! SFX W ernir iernan ernir +! SFX W ornar uernan ornar +! SFX W inar ínan [aeo]hinar +! SFX W unir únan eunir +! SFX W aber epan saber +! SFX W caber quepan caber +! SFX W r ran [^a]ndar +! SFX W r ran [^d]ar +! SFX W r ran [^n]dar +! SFX W ebrar iebran ebrar +! SFX W embrar iembran embrar +! SFX W edrar iedran edrar +! SFX W endrar iendran endrar +! SFX W r eran alir +! SFX W r eran ernir +! SFX W r eran eunir +! SFX W r eran ohibir +! SFX W er ieran [^fh]acer +! SFX W er ieran aler +! SFX W er ieran e[cd]er +! SFX W er ieran ender +! SFX W er ieran er[dnt]er +! SFX W er ieran o[clv]er +! SFX W er ieran olver +! SFX W er ieran or[cd]er +! SFX W erer ieran erer +! SFX W erir ieran erir +! SFX W eír ieran eír +! SFX W irir ieran irir +! SFX W ebir ibieran ebir +! SFX W acer icieran [fh]acer +! SFX W edir idieran edir +! SFX W endir indieran endir +! SFX W oder udieran oder +! SFX W egir igieran egir +! SFX W enchir inchieran enchir +! SFX W emir imieran emir +! SFX W ormir urmieran ormir +! SFX W enir inieran enir +! SFX W aber upieran aber +! SFX W erir irieran erir +! SFX W irir irieran irir +! SFX W orir urieran orir +! SFX W erer isieran erer +! SFX W oner usieran oner +! SFX W etir itieran etir +! SFX W entir intieran entir +! SFX W ertir irtieran ertir +! SFX W estir istieran estir +! SFX W eguir iguieran eguir +! SFX W ervir irvieran ervir +! SFX W ar uvieran andar +! SFX W ener uvieran ener +! SFX W cir jeran ucir +! SFX W er jeran raer +! SFX W ecir ijeran ecir +! SFX W orar ueran [^g]orar +! SFX W orir ueran orir +! SFX W er yeran [eo]er +! SFX W er yeran caer +! SFX W ir yeran [^g]uir +! SFX W ír yeran oír +! SFX W üir uyeran güir +! SFX W eñir iñeran eñir +! SFX W orar üeran gorar +! SFX W errar ierran errar +! SFX W ontrar uentran ontrar +! SFX W ostrar uestran ostrar +! SFX W esar iesan esar +! SFX W osar uesan osar +! SFX W ensar iensan ensar +! SFX W usar úsan [ae]husar +! SFX W etar ietan etar +! SFX W etir itan etir +! SFX W oltar ueltan oltar +! SFX W entar ientan entar +! SFX W entir ientan entir +! SFX W ontar uentan ontar +! SFX W ertar iertan ertar +! SFX W erter iertan erter +! SFX W ertir iertan ertir +! SFX W ortar uertan ortar +! SFX W estar iestan estar +! SFX W ostar uestan ostar +! SFX W estir istan estir +! SFX W itar ítan [ae]hitar +! SFX W evar ievan evar +! SFX W ovar uevan ovar +! SFX W over uevan over +! SFX W olver uelvan olver +! SFX W ervir irvan ervir +! SFX W er yan oer +! SFX W ir yan [^g]uir +! SFX W üir uyan güir +! SFX W ezar iezan ezar +! SFX W ocer uezan cocer +! SFX W enzar ienzan enzar +! SFX W onzar üenzan gonzar +! SFX W orcer uerzan orcer +! SFX W orzar uerzan orzar +! SFX W izar ízan [ae]izar +! SFX W 0 ían [^fh]acer +! SFX W 0 ían [aeo]er +! SFX W 0 ían [io]rir +! SFX W 0 ían [üu]ir +! SFX W 0 ían ar +! SFX W 0 ían e[bdgmrtñ]ir +! SFX W 0 ían e[cd]er +! SFX W 0 ían e[ns]tir +! SFX W 0 ían enchir +! SFX W 0 ían ender +! SFX W 0 ían endir +! SFX W 0 ían er[dnt]er +! SFX W 0 ían er[ntv]ir +! SFX W 0 ían eunir +! SFX W 0 ían o[clv]er +! SFX W 0 ían olver +! SFX W 0 ían or[cd]er +! SFX W 0 ían ormir +! SFX W 0 ían ucir +! SFX W er ían er +! SFX W eír ían eír +! SFX W iar ían iar +! SFX W ir ían ir +! SFX W ír ían ír +! SFX W cer rían [fh]acer +! SFX W er rían aber +! SFX W er rían erer +! SFX W er rían oder +! SFX W er drían [eo]ner +! SFX W er drían aler +! SFX W ir drían alir +! SFX W ir drían enir +! SFX W ecir irían ecir +! SFX W ír irían [eo]ír +! SFX W oñar ueñan oñar +! SFX W eñir iñan eñir +! SFX W uar úan [^g]uar +! +! +! SFX W Y 202 S +! SFX W ar en andar +! SFX W ir en alir +! SFX W ir en ucir +! SFX W obar ueben obar +! SFX W ebir iben ebir +! SFX W erbar ierben erbar +! SFX W ibir íben ohibir +! SFX W ezar iecen ezar +! SFX W ocer uecen cocer +! SFX W ecir icen ecir +! SFX W enzar iencen enzar +! SFX W onzar üencen gonzar +! SFX W orcer uercen orcer +! SFX W orzar uercen orzar +! SFX W izar ícen [ae]izar +! SFX W eder ieden eder +! SFX W odar ueden odar +! SFX W oder ueden oder +! SFX W edir iden edir +! SFX W oldar uelden [^g]oldar +! SFX W oldar üelden goldar +! SFX W endar ienden endar +! SFX W ender ienden ender +! SFX W endir inden endir +! SFX W erder ierden erder +! SFX W ordar uerden ordar +! SFX W order uerden order +! SFX W egir igen egir +! SFX W enchir inchen enchir +! SFX W ijar íjen [ae]hijar +! SFX W oblar ueblen oblar +! SFX W emblar iemblen emblar +! SFX W elar ielen elar +! SFX W olar uelen olar +! SFX W oler uelen oler +! SFX W ollar uellen [^g]ollar +! SFX W ollar üellen gollar +! SFX W ilar ílen [ae]hilar +! SFX W emir imen emir +! SFX W ormir uermen ormir +! SFX W umar úmen [ae]humar +! SFX W ener ienen ener +! SFX W enir ienen enir +! SFX W onar uenen onar +! SFX W ernar iernen ernar +! SFX W erner iernen erner +! SFX W ernir iernen ernir +! SFX W ornar uernen ornar +! SFX W inar ínen [aeo]hinar +! SFX W unir únen eunir +! SFX W r ren [^a]ndar +! SFX W r ren [^d]ar +! SFX W r ren [^n]dar +! SFX W ebrar iebren ebrar +! SFX W embrar iembren embrar +! SFX W edrar iedren edrar +! SFX W endrar iendren endrar +! SFX W r eren alir +! SFX W r eren ernir +! SFX W r eren eunir +! SFX W r eren ohibir +! SFX W er ieren [^fh]acer +! SFX W er ieren aler +! SFX W er ieren e[cd]er +! SFX W er ieren ender +! SFX W er ieren er[dnt]er +! SFX W er ieren o[clv]er +! SFX W er ieren olver +! SFX W er ieren or[cd]er +! SFX W erer ieren erer +! SFX W erir ieren erir +! SFX W eír ieren eír +! SFX W irir ieren irir +! SFX W ebir ibieren ebir +! SFX W acer icieren [fh]acer +! SFX W edir idieren edir +! SFX W endir indieren endir +! SFX W oder udieren oder +! SFX W egir igieren egir +! SFX W enchir inchieren enchir +! SFX W emir imieren emir +! SFX W ormir urmieren ormir +! SFX W enir inieren enir +! SFX W aber upieren aber +! SFX W erir irieren erir +! SFX W irir irieren irir +! SFX W orir urieren orir +! SFX W erer isieren erer +! SFX W oner usieren oner +! SFX W etir itieren etir +! SFX W entir intieren entir +! SFX W ertir irtieren ertir +! SFX W estir istieren estir +! SFX W eguir iguieren eguir +! SFX W ervir irvieren ervir +! SFX W ar uvieren andar +! SFX W ener uvieren ener +! SFX W cir jeren ucir +! SFX W er jeren raer +! SFX W ecir ijeren ecir +! SFX W orar ueren [^g]orar +! SFX W orir ueren orir +! SFX W er yeren [eo]er +! SFX W er yeren caer +! SFX W ir yeren [^g]uir +! SFX W ír yeren oír +! SFX W üir uyeren güir +! SFX W eñir iñeren eñir +! SFX W orar üeren gorar +! SFX W errar ierren errar +! SFX W ontrar uentren ontrar +! SFX W ostrar uestren ostrar +! SFX W r sen [^a]ndar +! SFX W r sen [^d]ar +! SFX W r sen [^n]dar +! SFX W r esen alir +! SFX W r esen ernir +! SFX W r esen eunir +! SFX W r esen ohibir +! SFX W er iesen [^fh]acer +! SFX W er iesen aler +! SFX W er iesen e[cd]er +! SFX W er iesen ender +! SFX W er iesen er[dnt]er +! SFX W er iesen o[clv]er +! SFX W er iesen olver +! SFX W er iesen or[cd]er +! SFX W esar iesen esar +! SFX W eír iesen eír +! SFX W ebir ibiesen ebir +! SFX W acer iciesen [fh]acer +! SFX W edir idiesen edir +! SFX W endir indiesen endir +! SFX W oder udiesen oder +! SFX W egir igiesen egir +! SFX W enchir inchiesen enchir +! SFX W emir imiesen emir +! SFX W ormir urmiesen ormir +! SFX W enir iniesen enir +! SFX W aber upiesen aber +! SFX W erir iriesen erir +! SFX W irir iriesen irir +! SFX W orir uriesen orir +! SFX W erer isiesen erer +! SFX W oner usiesen oner +! SFX W etir itiesen etir +! SFX W entir intiesen entir +! SFX W ertir irtiesen ertir +! SFX W estir istiesen estir +! SFX W eguir iguiesen eguir +! SFX W ervir irviesen ervir +! SFX W ar uviesen andar +! SFX W ener uviesen ener +! SFX W cir jesen ucir +! SFX W er jesen raer +! SFX W ecir ijesen ecir +! SFX W osar uesen osar +! SFX W er yesen [eo]er +! SFX W er yesen caer +! SFX W ir yesen [^g]uir +! SFX W ír yesen oír +! SFX W üir uyesen güir +! SFX W eñir iñesen eñir +! SFX W ensar iensen ensar +! SFX W usar úsen [ae]husar +! SFX W etar ieten etar +! SFX W etir iten etir +! SFX W oltar uelten oltar +! SFX W entar ienten entar +! SFX W entir ienten entir +! SFX W ontar uenten ontar +! SFX W ertar ierten ertar +! SFX W erter ierten erter +! SFX W ertir ierten ertir +! SFX W ortar uerten ortar +! SFX W estar iesten estar +! SFX W ostar uesten ostar +! SFX W estir isten estir +! SFX W itar íten [ae]hitar +! SFX W gar eguen ugar +! SFX W egar ieguen egar +! SFX W ogar ueguen ogar +! SFX W eguir iguen eguir +! SFX W olgar uelguen olgar +! SFX W engar ienguen engar +! SFX W ocar uequen ocar +! SFX W olcar uelquen olcar +! SFX W orcar uerquen orcar +! SFX W evar ieven evar +! SFX W ovar ueven ovar +! SFX W over ueven over +! SFX W olver uelven olver +! SFX W ervir irven ervir +! SFX W ir yen [^g]uir +! SFX W ír yen oír +! SFX W üir uyen güir +! SFX W eír íen eír +! SFX W iar íen iar +! SFX W oñar ueñen oñar +! SFX W eñir iñen eñir +! SFX W uar úen [^g]uar +! SFX W uar üen guar +! +! +! SFX W Y 49 S +! SFX W 0 on [^a]ndar +! SFX W 0 on [^d]ar +! SFX W 0 on [^n]dar +! SFX W r eron alir +! SFX W r eron ernir +! SFX W r eron eunir +! SFX W r eron irir +! SFX W r eron ohibir +! SFX W er ieron [^fh]acer +! SFX W er ieron aler +! SFX W er ieron e[cd]er +! SFX W er ieron ender +! SFX W er ieron er[dnt]er +! SFX W er ieron o[clv]er +! SFX W er ieron olver +! SFX W er ieron or[cd]er +! SFX W eír ieron eír +! SFX W ebir ibieron ebir +! SFX W acer icieron [fh]acer +! SFX W edir idieron edir +! SFX W endir indieron endir +! SFX W oder udieron oder +! SFX W egir igieron egir +! SFX W enchir inchieron enchir +! SFX W emir imieron emir +! SFX W ormir urmieron ormir +! SFX W enir inieron enir +! SFX W aber upieron aber +! SFX W erir irieron erir +! SFX W orir urieron orir +! SFX W erer isieron erer +! SFX W oner usieron oner +! SFX W etir itieron etir +! SFX W entir intieron entir +! SFX W ertir irtieron ertir +! SFX W estir istieron estir +! SFX W eguir iguieron eguir +! SFX W ervir irvieron ervir +! SFX W ar uvieron andar +! SFX W ener uvieron ener +! SFX W cir jeron ucir +! SFX W er jeron raer +! SFX W ecir ijeron ecir +! SFX W er yeron [eo]er +! SFX W er yeron caer +! SFX W ir yeron [^g]uir +! SFX W ír yeron oír +! SFX W üir uyeron güir +! SFX W eñir iñeron eñir +! +! +! SFX W Y 29 S +! SFX W 0 án [^fh]acer +! SFX W 0 án [aeo]er +! SFX W 0 án [io]rir +! SFX W 0 án [üu]ir +! SFX W 0 án ar +! SFX W 0 án e[bdgmrtñ]ir +! SFX W 0 án e[cd]er +! SFX W 0 án e[ns]tir +! SFX W 0 án enchir +! SFX W 0 án ender +! SFX W 0 án endir +! SFX W 0 án er[dnt]er +! SFX W 0 án er[ntv]ir +! SFX W 0 án eunir +! SFX W 0 án o[clv]er +! SFX W 0 án olver +! SFX W 0 án or[cd]er +! SFX W 0 án ormir +! SFX W 0 án ucir +! SFX W cer rán [fh]acer +! SFX W er rán aber +! SFX W er rán erer +! SFX W er rán oder +! SFX W er drán [eo]ner +! SFX W er drán aler +! SFX W ir drán alir +! SFX W ir drán enir +! SFX W ecir irán ecir +! SFX W ír irán [eo]ír +! +! +! SFX W Y 126 S +! SFX W ar o andar +! SFX W ar o guar +! SFX W er o [eo]er +! SFX W obar uebo obar +! SFX W ebir ibo ebir +! SFX W erbar ierbo erbar +! SFX W ibir íbo ohibir +! SFX W ocar ueco ocar +! SFX W olcar uelco olcar +! SFX W orcar uerco orcar +! SFX W cer zco [^c]ocer +! SFX W cer zco [^fh]acer +! SFX W cer zco ecer +! SFX W ucir uzco ucir +! SFX W eder iedo eder +! SFX W odar uedo odar +! SFX W oder uedo oder +! SFX W edir ido edir +! SFX W oldar ueldo [^g]oldar +! SFX W oldar üeldo goldar +! SFX W endar iendo endar +! SFX W ender iendo ender +! SFX W endir indo endir +! SFX W erder ierdo erder +! SFX W ordar uerdo ordar +! SFX W order uerdo order +! SFX W oder udo oder +! SFX W cer go [fh]acer +! SFX W er go aler +! SFX W er go ener +! SFX W er go oner +! SFX W ir go alir +! SFX W ir go enir +! SFX W gar ego ugar +! SFX W egar iego egar +! SFX W ogar uego ogar +! SFX W ecir igo ecir +! SFX W eguir igo eguir +! SFX W er igo [cr]aer +! SFX W er igo oer +! SFX W ír igo oír +! SFX W olgar uelgo olgar +! SFX W engar iengo engar +! SFX W enchir incho enchir +! SFX W cir jo ucir +! SFX W er jo raer +! SFX W ecir ijo ecir +! SFX W egir ijo egir +! SFX W ijar íjo [ae]hijar +! SFX W oblar ueblo oblar +! SFX W emblar iemblo emblar +! SFX W elar ielo elar +! SFX W olar uelo olar +! SFX W oler uelo oler +! SFX W ollar uello [^g]ollar +! SFX W ollar üello gollar +! SFX W ilar ílo [ae]hilar +! SFX W emir imo emir +! SFX W ormir uermo ormir +! SFX W umar úmo [ae]humar +! SFX W onar ueno onar +! SFX W enir ino enir +! SFX W ernar ierno ernar +! SFX W erner ierno erner +! SFX W ernir ierno ernir +! SFX W ornar uerno ornar +! SFX W inar íno [aeo]hinar +! SFX W unir úno eunir +! SFX W caber quepo caber +! SFX W aber upo aber +! SFX W ebrar iebro ebrar +! SFX W embrar iembro embrar +! SFX W edrar iedro edrar +! SFX W endrar iendro endrar +! SFX W erer iero erer +! SFX W erir iero erir +! SFX W irir iero irir +! SFX W orar uero [^g]orar +! SFX W orir uero orir +! SFX W orar üero gorar +! SFX W errar ierro errar +! SFX W ontrar uentro ontrar +! SFX W ostrar uestro ostrar +! SFX W esar ieso esar +! SFX W osar ueso osar +! SFX W erer iso erer +! SFX W ensar ienso ensar +! SFX W oner uso oner +! SFX W usar úso [ae]husar +! SFX W etar ieto etar +! SFX W etir ito etir +! SFX W oltar uelto oltar +! SFX W entar iento entar +! SFX W entir iento entir +! SFX W ontar uento ontar +! SFX W ertar ierto ertar +! SFX W erter ierto erter +! SFX W ertir ierto ertir +! SFX W ortar uerto ortar +! SFX W estar iesto estar +! SFX W ostar uesto ostar +! SFX W estir isto estir +! SFX W itar íto [ae]hitar +! SFX W evar ievo evar +! SFX W ovar uevo ovar +! SFX W over uevo over +! SFX W olver uelvo olver +! SFX W ervir irvo ervir +! SFX W ar uvo andar +! SFX W ener uvo ener +! SFX W er yo oer +! SFX W uir uyo [^g]uir +! SFX W üir uyo güir +! SFX W ezar iezo ezar +! SFX W ocer uezo cocer +! SFX W acer izo [fh]acer +! SFX W enzar ienzo enzar +! SFX W onzar üenzo gonzar +! SFX W orcer uerzo orcer +! SFX W orzar uerzo orzar +! SFX W izar ízo [ae]izar +! SFX W eír ío eír +! SFX W iar ío iar +! SFX W oñar ueño oñar +! SFX W eñir iño eñir +! SFX W uar úo [^g]uar +! +! +! +! SFX W Y 195 S +! SFX W er as [eo]er +! SFX W r bas ar +! SFX W obar uebas obar +! SFX W ebir ibas ebir +! SFX W erbar ierbas erbar +! SFX W ibir íbas ohibir +! SFX W ocar uecas ocar +! SFX W olcar uelcas olcar +! SFX W orcar uercas orcar +! SFX W cer zcas [^c]ocer +! SFX W cer zcas [^fh]acer +! SFX W cer zcas ecer +! SFX W cir zcas ucir +! SFX W eder iedas eder +! SFX W odar uedas odar +! SFX W oder uedas oder +! SFX W edir idas edir +! SFX W oldar ueldas [^g]oldar +! SFX W oldar üeldas goldar +! SFX W endar iendas endar +! SFX W ender iendas ender +! SFX W endir indas endir +! SFX W erder ierdas erder +! SFX W ordar uerdas ordar +! SFX W order uerdas order +! SFX W cer gas [fh]acer +! SFX W er gas [eo]ner +! SFX W er gas aler +! SFX W ir gas alir +! SFX W gar egas ugar +! SFX W egar iegas egar +! SFX W ogar uegas ogar +! SFX W ecir igas ecir +! SFX W eguir igas eguir +! SFX W er igas aer +! SFX W er igas oer +! SFX W ír igas oír +! SFX W olgar uelgas olgar +! SFX W enir engas enir +! SFX W engar iengas engar +! SFX W enchir inchas enchir +! SFX W egir ijas egir +! SFX W ijar íjas [ae]hijar +! SFX W oblar ueblas oblar +! SFX W emblar iemblas emblar +! SFX W elar ielas elar +! SFX W olar uelas olar +! SFX W oler uelas oler +! SFX W ollar uellas [^g]ollar +! SFX W ollar üellas gollar +! SFX W ilar ílas [ae]hilar +! SFX W emir imas emir +! SFX W ormir uermas ormir +! SFX W umar úmas [ae]humar +! SFX W onar uenas onar +! SFX W ernar iernas ernar +! SFX W erner iernas erner +! SFX W ernir iernas ernir +! SFX W ornar uernas ornar +! SFX W inar ínas [aeo]hinar +! SFX W unir únas eunir +! SFX W aber epas saber +! SFX W caber quepas caber +! SFX W r ras [^a]ndar +! SFX W r ras [^d]ar +! SFX W r ras [^n]dar +! SFX W ebrar iebras ebrar +! SFX W embrar iembras embrar +! SFX W edrar iedras edrar +! SFX W endrar iendras endrar +! SFX W r eras alir +! SFX W r eras ernir +! SFX W r eras eunir +! SFX W r eras ohibir +! SFX W er ieras [^fh]acer +! SFX W er ieras aler +! SFX W er ieras e[cd]er +! SFX W er ieras ender +! SFX W er ieras er[dnt]er +! SFX W er ieras o[clv]er +! SFX W er ieras olver +! SFX W er ieras or[cd]er +! SFX W erer ieras erer +! SFX W erir ieras erir +! SFX W eír ieras eír +! SFX W irir ieras irir +! SFX W ebir ibieras ebir +! SFX W acer icieras [fh]acer +! SFX W edir idieras edir +! SFX W endir indieras endir +! SFX W oder udieras oder +! SFX W egir igieras egir +! SFX W enchir inchieras enchir +! SFX W emir imieras emir +! SFX W ormir urmieras ormir +! SFX W enir inieras enir +! SFX W aber upieras aber +! SFX W erir irieras erir +! SFX W irir irieras irir +! SFX W orir urieras orir +! SFX W erer isieras erer +! SFX W oner usieras oner +! SFX W etir itieras etir +! SFX W entir intieras entir +! SFX W ertir irtieras ertir +! SFX W estir istieras estir +! SFX W eguir iguieras eguir +! SFX W ervir irvieras ervir +! SFX W ar uvieras andar +! SFX W ener uvieras ener +! SFX W cir jeras ucir +! SFX W er jeras raer +! SFX W ecir ijeras ecir +! SFX W orar ueras [^g]orar +! SFX W orir ueras orir +! SFX W er yeras [eo]er +! SFX W er yeras caer +! SFX W ir yeras [^g]uir +! SFX W ír yeras oír +! SFX W üir uyeras güir +! SFX W eñir iñeras eñir +! SFX W orar üeras gorar +! SFX W errar ierras errar +! SFX W ontrar uentras ontrar +! SFX W ostrar uestras ostrar +! SFX W esar iesas esar +! SFX W osar uesas osar +! SFX W ensar iensas ensar +! SFX W usar úsas [ae]husar +! SFX W etar ietas etar +! SFX W etir itas etir +! SFX W oltar ueltas oltar +! SFX W entar ientas entar +! SFX W entir ientas entir +! SFX W ontar uentas ontar +! SFX W ertar iertas ertar +! SFX W erter iertas erter +! SFX W ertir iertas ertir +! SFX W ortar uertas ortar +! SFX W estar iestas estar +! SFX W ostar uestas ostar +! SFX W estir istas estir +! SFX W itar ítas [ae]hitar +! SFX W evar ievas evar +! SFX W ovar uevas ovar +! SFX W over uevas over +! SFX W olver uelvas olver +! SFX W ervir irvas ervir +! SFX W er yas oer +! SFX W ir yas [^g]uir +! SFX W üir uyas güir +! SFX W ezar iezas ezar +! SFX W ocer uezas cocer +! SFX W enzar ienzas enzar +! SFX W onzar üenzas gonzar +! SFX W orcer uerzas orcer +! SFX W orzar uerzas orzar +! SFX W izar ízas [ae]izar +! SFX W 0 ías [^fh]acer +! SFX W 0 ías [aeo]er +! SFX W 0 ías [io]rir +! SFX W 0 ías [üu]ir +! SFX W 0 ías ar +! SFX W 0 ías e[bdgmrtñ]ir +! SFX W 0 ías e[cd]er +! SFX W 0 ías e[ns]tir +! SFX W 0 ías enchir +! SFX W 0 ías ender +! SFX W 0 ías endir +! SFX W 0 ías er[dnt]er +! SFX W 0 ías er[ntv]ir +! SFX W 0 ías eunir +! SFX W 0 ías o[clv]er +! SFX W 0 ías olver +! SFX W 0 ías or[cd]er +! SFX W 0 ías ormir +! SFX W 0 ías ucir +! SFX W er ías er +! SFX W eír ías eír +! SFX W iar ías iar +! SFX W ir ías ir +! SFX W ír ías ír +! SFX W cer rías [fh]acer +! SFX W er rías aber +! SFX W er rías erer +! SFX W er rías oder +! SFX W er drías [eo]ner +! SFX W er drías aler +! SFX W ir drías alir +! SFX W ir drías enir +! SFX W ecir irías ecir +! SFX W ír irías [eo]ír +! SFX W oñar ueñas oñar +! SFX W eñir iñas eñir +! SFX W uar úas [^g]uar +! +! +! +! SFX W Y 202 S +! SFX W ar es andar +! SFX W ir es ucir +! SFX W r es alir +! SFX W obar uebes obar +! SFX W ebir ibes ebir +! SFX W erbar ierbes erbar +! SFX W ibir íbes ohibir +! SFX W ezar ieces ezar +! SFX W ocer ueces cocer +! SFX W ecir ices ecir +! SFX W enzar iences enzar +! SFX W onzar üences gonzar +! SFX W orcer uerces orcer +! SFX W orzar uerces orzar +! SFX W izar íces [ae]izar +! SFX W eder iedes eder +! SFX W odar uedes odar +! SFX W oder uedes oder +! SFX W edir ides edir +! SFX W oldar ueldes [^g]oldar +! SFX W oldar üeldes goldar +! SFX W endar iendes endar +! SFX W ender iendes ender +! SFX W endir indes endir +! SFX W erder ierdes erder +! SFX W ordar uerdes ordar +! SFX W order uerdes order +! SFX W egir iges egir +! SFX W enchir inches enchir +! SFX W ijar íjes [ae]hijar +! SFX W oblar uebles oblar +! SFX W emblar iembles emblar +! SFX W elar ieles elar +! SFX W olar ueles olar +! SFX W oler ueles oler +! SFX W ollar uelles [^g]ollar +! SFX W ollar üelles gollar +! SFX W ilar íles [ae]hilar +! SFX W emir imes emir +! SFX W ormir uermes ormir +! SFX W umar úmes [ae]humar +! SFX W ener ienes ener +! SFX W enir ienes enir +! SFX W onar uenes onar +! SFX W ernar iernes ernar +! SFX W erner iernes erner +! SFX W ernir iernes ernir +! SFX W ornar uernes ornar +! SFX W inar ínes [aeo]hinar +! SFX W unir únes eunir +! SFX W r res [^a]ndar +! SFX W r res [^d]ar +! SFX W r res [^n]dar +! SFX W ebrar iebres ebrar +! SFX W embrar iembres embrar +! SFX W edrar iedres edrar +! SFX W endrar iendres endrar +! SFX W r eres alir +! SFX W r eres ernir +! SFX W r eres eunir +! SFX W r eres ohibir +! SFX W er ieres [^fh]acer +! SFX W er ieres aler +! SFX W er ieres e[cd]er +! SFX W er ieres ender +! SFX W er ieres er[dnt]er +! SFX W er ieres o[clv]er +! SFX W er ieres olver +! SFX W er ieres or[cd]er +! SFX W erer ieres erer +! SFX W erir ieres erir +! SFX W eír ieres eír +! SFX W irir ieres irir +! SFX W ebir ibieres ebir +! SFX W acer icieres [fh]acer +! SFX W edir idieres edir +! SFX W endir indieres endir +! SFX W oder udieres oder +! SFX W egir igieres egir +! SFX W enchir inchieres enchir +! SFX W emir imieres emir +! SFX W ormir urmieres ormir +! SFX W enir inieres enir +! SFX W aber upieres aber +! SFX W erir irieres erir +! SFX W irir irieres irir +! SFX W orir urieres orir +! SFX W erer isieres erer +! SFX W oner usieres oner +! SFX W etir itieres etir +! SFX W entir intieres entir +! SFX W ertir irtieres ertir +! SFX W estir istieres estir +! SFX W eguir iguieres eguir +! SFX W ervir irvieres ervir +! SFX W ar uvieres andar +! SFX W ener uvieres ener +! SFX W cir jeres ucir +! SFX W er jeres raer +! SFX W ecir ijeres ecir +! SFX W orar ueres [^g]orar +! SFX W orir ueres orir +! SFX W er yeres [eo]er +! SFX W er yeres caer +! SFX W ir yeres [^g]uir +! SFX W ír yeres oír +! SFX W üir uyeres güir +! SFX W eñir iñeres eñir +! SFX W orar üeres gorar +! SFX W errar ierres errar +! SFX W ontrar uentres ontrar +! SFX W ostrar uestres ostrar +! SFX W r ses [^a]ndar +! SFX W r ses [^d]ar +! SFX W r ses [^n]dar +! SFX W r eses alir +! SFX W r eses ernir +! SFX W r eses eunir +! SFX W r eses ohibir +! SFX W er ieses [^fh]acer +! SFX W er ieses aler +! SFX W er ieses e[cd]er +! SFX W er ieses ender +! SFX W er ieses er[dnt]er +! SFX W er ieses o[clv]er +! SFX W er ieses olver +! SFX W er ieses or[cd]er +! SFX W esar ieses esar +! SFX W eír ieses eír +! SFX W ebir ibieses ebir +! SFX W acer icieses [fh]acer +! SFX W edir idieses edir +! SFX W endir indieses endir +! SFX W oder udieses oder +! SFX W egir igieses egir +! SFX W enchir inchieses enchir +! SFX W emir imieses emir +! SFX W ormir urmieses ormir +! SFX W enir inieses enir +! SFX W aber upieses aber +! SFX W erir irieses erir +! SFX W irir irieses irir +! SFX W orir urieses orir +! SFX W erer isieses erer +! SFX W oner usieses oner +! SFX W etir itieses etir +! SFX W entir intieses entir +! SFX W ertir irtieses ertir +! SFX W estir istieses estir +! SFX W eguir iguieses eguir +! SFX W ervir irvieses ervir +! SFX W ar uvieses andar +! SFX W ener uvieses ener +! SFX W cir jeses ucir +! SFX W er jeses raer +! SFX W ecir ijeses ecir +! SFX W osar ueses osar +! SFX W er yeses [eo]er +! SFX W er yeses caer +! SFX W ir yeses [^g]uir +! SFX W ír yeses oír +! SFX W üir uyeses güir +! SFX W eñir iñeses eñir +! SFX W ensar ienses ensar +! SFX W usar úses [ae]husar +! SFX W etar ietes etar +! SFX W etir ites etir +! SFX W oltar ueltes oltar +! SFX W entar ientes entar +! SFX W entir ientes entir +! SFX W ontar uentes ontar +! SFX W ertar iertes ertar +! SFX W erter iertes erter +! SFX W ertir iertes ertir +! SFX W ortar uertes ortar +! SFX W estar iestes estar +! SFX W ostar uestes ostar +! SFX W estir istes estir +! SFX W itar ítes [ae]hitar +! SFX W gar egues ugar +! SFX W egar iegues egar +! SFX W ogar uegues ogar +! SFX W eguir igues eguir +! SFX W olgar uelgues olgar +! SFX W engar iengues engar +! SFX W ocar ueques ocar +! SFX W olcar uelques olcar +! SFX W orcar uerques orcar +! SFX W evar ieves evar +! SFX W ovar ueves ovar +! SFX W over ueves over +! SFX W olver uelves olver +! SFX W ervir irves ervir +! SFX W ír yes oír +! SFX W uir uyes [^g]uir +! SFX W üir uyes güir +! SFX W eír íes eír +! SFX W iar íes iar +! SFX W oñar ueñes oñar +! SFX W eñir iñes eñir +! SFX W uar úes [^g]uar +! SFX W uar ües guar +! +! +! SFX W Y 49 S +! SFX W r rais [^a]ndar +! SFX W r rais [^d]ar +! SFX W r rais [^n]dar +! SFX W r erais alir +! SFX W r erais ernir +! SFX W r erais eunir +! SFX W r erais ohibir +! SFX W er ierais [^fh]acer +! SFX W er ierais aler +! SFX W er ierais e[cd]er +! SFX W er ierais ender +! SFX W er ierais er[dnt]er +! SFX W er ierais o[clv]er +! SFX W er ierais olver +! SFX W er ierais or[cd]er +! SFX W eír ierais eír +! SFX W ebir ibierais ebir +! SFX W acer icierais [fh]acer +! SFX W edir idierais edir +! SFX W endir indierais endir +! SFX W oder udierais oder +! SFX W egir igierais egir +! SFX W enchir inchierais enchir +! SFX W emir imierais emir +! SFX W ormir urmierais ormir +! SFX W enir inierais enir +! SFX W aber upierais aber +! SFX W erir irierais erir +! SFX W irir irierais irir +! SFX W orir urierais orir +! SFX W erer isierais erer +! SFX W oner usierais oner +! SFX W etir itierais etir +! SFX W entir intierais entir +! SFX W ertir irtierais ertir +! SFX W estir istierais estir +! SFX W eguir iguierais eguir +! SFX W ervir irvierais ervir +! SFX W ar uvierais andar +! SFX W ener uvierais ener +! SFX W cir jerais ucir +! SFX W er jerais raer +! SFX W ecir ijerais ecir +! SFX W er yerais [eo]er +! SFX W er yerais caer +! SFX W ir yerais [^g]uir +! SFX W ír yerais oír +! SFX W üir uyerais güir +! SFX W eñir iñerais eñir +! +! +! +! SFX W Y 32 S +! SFX W 0 íais [^fh]acer +! SFX W 0 íais [aeo]er +! SFX W 0 íais [io]rir +! SFX W 0 íais [üu]ir +! SFX W 0 íais ar +! SFX W 0 íais e[bdgmrtñ]ir +! SFX W 0 íais e[cd]er +! SFX W 0 íais e[ns]tir +! SFX W 0 íais enchir +! SFX W 0 íais ender +! SFX W 0 íais endir +! SFX W 0 íais er[dnt]er +! SFX W 0 íais er[ntv]ir +! SFX W 0 íais eunir +! SFX W 0 íais o[clv]er +! SFX W 0 íais olver +! SFX W 0 íais or[cd]er +! SFX W 0 íais ormir +! SFX W 0 íais ucir +! SFX W er íais er +! SFX W ir íais ir +! SFX W ír íais ír +! SFX W cer ríais [fh]acer +! SFX W er ríais aber +! SFX W er ríais erer +! SFX W er ríais oder +! SFX W er dríais [eo]ner +! SFX W er dríais aler +! SFX W ir dríais alir +! SFX W ir dríais enir +! SFX W ecir iríais ecir +! SFX W ír iríais [eo]ír +! +! +! +! SFX W Y 48 S +! SFX W r reis [^a]ndar +! SFX W r reis [^d]ar +! SFX W r reis [^n]dar +! SFX W r ereis alir +! SFX W r ereis ernir +! SFX W r ereis ohibir +! SFX W er iereis [^fh]acer +! SFX W er iereis aler +! SFX W er iereis e[cd]er +! SFX W er iereis ender +! SFX W er iereis er[dnt]er +! SFX W er iereis o[clv]er +! SFX W er iereis olver +! SFX W er iereis or[cd]er +! SFX W eír iereis eír +! SFX W ebir ibiereis ebir +! SFX W acer iciereis [fh]acer +! SFX W edir idiereis edir +! SFX W endir indiereis endir +! SFX W oder udiereis oder +! SFX W egir igiereis egir +! SFX W enchir inchiereis enchir +! SFX W emir imiereis emir +! SFX W ormir urmiereis ormir +! SFX W enir iniereis enir +! SFX W aber upiereis aber +! SFX W erir iriereis erir +! SFX W irir iriereis irir +! SFX W orir uriereis orir +! SFX W oner usiereis oner +! SFX W etir itiereis etir +! SFX W entir intiereis entir +! SFX W ertir irtiereis ertir +! SFX W estir istiereis estir +! SFX W eguir iguiereis eguir +! SFX W ervir irviereis ervir +! SFX W ar uviereis andar +! SFX W ener uviereis ener +! SFX W cir jereis ucir +! SFX W er jereis raer +! SFX W ecir ijereis ecir +! SFX W er yereis [eo]er +! SFX W er yereis caer +! SFX W ir yereis [^g]uir +! SFX W ír yereis oír +! SFX W üir uyereis güir +! SFX W eñir iñereis eñir +! SFX W erer isiéreis erer +! +! +! +! SFX W Y 49 S +! SFX W r seis [^a]ndar +! SFX W r seis [^d]ar +! SFX W r seis [^n]dar +! SFX W r eseis alir +! SFX W r eseis ernir +! SFX W r eseis eunir +! SFX W r eseis ohibir +! SFX W er ieseis [^fh]acer +! SFX W er ieseis aler +! SFX W er ieseis e[cd]er +! SFX W er ieseis ender +! SFX W er ieseis er[dnt]er +! SFX W er ieseis o[clv]er +! SFX W er ieseis olver +! SFX W er ieseis or[cd]er +! SFX W eír ieseis eír +! SFX W ebir ibieseis ebir +! SFX W acer icieseis [fh]acer +! SFX W edir idieseis edir +! SFX W endir indieseis endir +! SFX W oder udieseis oder +! SFX W egir igieseis egir +! SFX W enchir inchieseis enchir +! SFX W emir imieseis emir +! SFX W ormir urmieseis ormir +! SFX W enir inieseis enir +! SFX W aber upieseis aber +! SFX W erir irieseis erir +! SFX W irir irieseis irir +! SFX W orir urieseis orir +! SFX W erer isieseis erer +! SFX W oner usieseis oner +! SFX W etir itieseis etir +! SFX W entir intieseis entir +! SFX W ertir irtieseis ertir +! SFX W estir istieseis estir +! SFX W eguir iguieseis eguir +! SFX W ervir irvieseis ervir +! SFX W ar uvieseis andar +! SFX W ener uvieseis ener +! SFX W cir jeseis ucir +! SFX W er jeseis raer +! SFX W ecir ijeseis ecir +! SFX W er yeseis [eo]er +! SFX W er yeseis caer +! SFX W ir yeseis [^g]uir +! SFX W ír yeseis oír +! SFX W üir uyeseis güir +! SFX W eñir iñeseis eñir +! +! +! +! SFX W Y 45 S +! SFX W r steis [^a]ndar +! SFX W r steis [^d]ar +! SFX W r steis [^n]dar +! SFX W r steis [eo]ír +! SFX W r steis [üu]ir +! SFX W r steis alir +! SFX W r steis ebir +! SFX W r steis edir +! SFX W r steis egir +! SFX W r steis emir +! SFX W r steis enchir +! SFX W r steis endir +! SFX W r steis entir +! SFX W r steis erir +! SFX W r steis ernir +! SFX W r steis ertir +! SFX W r steis ervir +! SFX W r steis estir +! SFX W r steis etir +! SFX W r steis eunir +! SFX W r steis eñir +! SFX W r steis irir +! SFX W r steis orir +! SFX W r steis ormir +! SFX W er isteis [^fh]acer +! SFX W er isteis aler +! SFX W er isteis e[cd]er +! SFX W er isteis ender +! SFX W er isteis er[dnt]er +! SFX W er isteis o[clv]er +! SFX W er isteis olver +! SFX W er isteis or[cd]er +! SFX W acer icisteis [fh]acer +! SFX W oder udisteis oder +! SFX W cir jisteis ucir +! SFX W er jisteis raer +! SFX W ecir ijisteis ecir +! SFX W enir inisteis enir +! SFX W aber upisteis aber +! SFX W erer isisteis erer +! SFX W oner usisteis oner +! SFX W ar uvisteis andar +! SFX W ener uvisteis ener +! SFX W er ísteis [eo]er +! SFX W er ísteis caer +! +! +! +! SFX W Y 54 S +! SFX W ar áis ar +! SFX W er áis [eo]er +! SFX W er áis eder +! SFX W er áis ender +! SFX W er áis erder +! SFX W er áis erer +! SFX W er áis erner +! SFX W er áis erter +! SFX W er áis oder +! SFX W er áis oler +! SFX W er áis olver +! SFX W er áis order +! SFX W er áis over +! SFX W ir áis ernir +! SFX W ir áis eunir +! SFX W ir áis irir +! SFX W ir áis ohibir +! SFX W ebir ibáis ebir +! SFX W cer zcáis [^c]ocer +! SFX W cer zcáis [^fh]acer +! SFX W cer zcáis ecer +! SFX W cir zcáis ucir +! SFX W edir idáis edir +! SFX W endir indáis endir +! SFX W cer gáis [fh]acer +! SFX W er gáis [eo]ner +! SFX W er gáis aler +! SFX W ir gáis alir +! SFX W ecir igáis ecir +! SFX W eguir igáis eguir +! SFX W er igáis aer +! SFX W er igáis oer +! SFX W ír igáis oír +! SFX W enir engáis enir +! SFX W enchir incháis enchir +! SFX W eír iáis eír +! SFX W egir ijáis egir +! SFX W emir imáis emir +! SFX W ormir urmáis ormir +! SFX W aber epáis saber +! SFX W caber quepáis caber +! SFX W erir iráis erir +! SFX W orir uráis orir +! SFX W etir itáis etir +! SFX W entir intáis entir +! SFX W ertir irtáis ertir +! SFX W estir istáis estir +! SFX W ervir irváis ervir +! SFX W er yáis oer +! SFX W ir yáis [^g]uir +! SFX W üir uyáis güir +! SFX W cer záis cocer +! SFX W cer záis orcer +! SFX W emir iñáis eñir +! +! +! +! SFX W Y 84 S +! SFX W 0 éis [^fh]acer +! SFX W 0 éis [aeo]er +! SFX W 0 éis [io]rir +! SFX W 0 éis [üu]ir +! SFX W 0 éis ar +! SFX W 0 éis e[bdgmrtñ]ir +! SFX W 0 éis e[cd]er +! SFX W 0 éis e[ns]tir +! SFX W 0 éis enchir +! SFX W 0 éis ender +! SFX W 0 éis endir +! SFX W 0 éis er[dnt]er +! SFX W 0 éis er[ntv]ir +! SFX W 0 éis eunir +! SFX W 0 éis o[clv]er +! SFX W 0 éis olver +! SFX W 0 éis or[cd]er +! SFX W 0 éis ormir +! SFX W 0 éis ucir +! SFX W ar éis [^g]uar +! SFX W ar éis [ae]hu[ms]ar +! SFX W ar éis [ae]ndar +! SFX W ar éis [aeo]hi[jlnt]ar +! SFX W ar éis ebrar +! SFX W ar éis edrar +! SFX W ar éis elar +! SFX W ar éis emblar +! SFX W ar éis embrar +! SFX W ar éis endrar +! SFX W ar éis ensar +! SFX W ar éis entar +! SFX W ar éis erbar +! SFX W ar éis ernar +! SFX W ar éis errar +! SFX W ar éis ertar +! SFX W ar éis esar +! SFX W ar éis estar +! SFX W ar éis etar +! SFX W ar éis evar +! SFX W ar éis iar +! SFX W ar éis obar +! SFX W ar éis oblar +! SFX W ar éis odar +! SFX W ar éis olar +! SFX W ar éis oldar +! SFX W ar éis ollar +! SFX W ar éis oltar +! SFX W ar éis onar +! SFX W ar éis ontar +! SFX W ar éis ontrar +! SFX W ar éis orar +! SFX W ar éis ordar +! SFX W ar éis ornar +! SFX W ar éis ortar +! SFX W ar éis osar +! SFX W ar éis ostar +! SFX W ar éis ostrar +! SFX W ar éis ovar +! SFX W ar éis oñar +! SFX W er éis er +! SFX W zar céis [ae]izar +! SFX W zar céis enzar +! SFX W zar céis ezar +! SFX W zar céis gonzar +! SFX W zar céis orzar +! SFX W cer réis [fh]acer +! SFX W er réis aber +! SFX W er réis erer +! SFX W er réis oder +! SFX W er dréis [eo]ner +! SFX W er dréis aler +! SFX W ir dréis alir +! SFX W ir dréis enir +! SFX W ecir iréis ecir +! SFX W ír iréis [eo]ír +! SFX W ar uéis olgar +! SFX W gar guéis egar +! SFX W gar guéis engar +! SFX W gar guéis ugar +! SFX W ogar guéis ogar +! SFX W car quéis olcar +! SFX W car quéis orcar +! SFX W ocar quéis ocar +! SFX W uar üéis guar +! +! +! SFX W Y 338 S +! SFX W r mos r +! SFX W er amos [eo]er +! SFX W er amos eder +! SFX W er amos ender +! SFX W er amos erder +! SFX W er amos erer +! SFX W er amos erner +! SFX W er amos erter +! SFX W er amos oder +! SFX W er amos oler +! SFX W er amos olver +! SFX W er amos order +! SFX W er amos over +! SFX W ir amos ernir +! SFX W ir amos eunir +! SFX W ir amos irir +! SFX W ir amos ohibir +! SFX W ebir ibamos ebir +! SFX W ar ábamos ar +! SFX W cer zcamos [^c]ocer +! SFX W cer zcamos [^fh]acer +! SFX W cer zcamos ecer +! SFX W cir zcamos ucir +! SFX W edir idamos edir +! SFX W endir indamos endir +! SFX W cer gamos [fh]acer +! SFX W er gamos [eo]ner +! SFX W er gamos aler +! SFX W ir gamos alir +! SFX W ecir igamos ecir +! SFX W eguir igamos eguir +! SFX W er igamos aer +! SFX W er igamos oer +! SFX W ír igamos oír +! SFX W enir engamos enir +! SFX W enchir inchamos enchir +! SFX W eír iamos eír +! SFX W egir ijamos egir +! SFX W emir imamos emir +! SFX W ormir urmamos ormir +! SFX W aber epamos saber +! SFX W caber quepamos caber +! SFX W erir iramos erir +! SFX W orir uramos orir +! SFX W ar áramos [^a]ndar +! SFX W ar áramos [^d]ar +! SFX W ar áramos [^n]dar +! SFX W r éramos alir +! SFX W r éramos ernir +! SFX W r éramos eunir +! SFX W r éramos ohibir +! SFX W er iéramos [^fh]acer +! SFX W er iéramos aler +! SFX W er iéramos e[cd]er +! SFX W er iéramos ender +! SFX W er iéramos er[dnt]er +! SFX W er iéramos o[clv]er +! SFX W er iéramos olver +! SFX W er iéramos or[cd]er +! SFX W eír iéramos eír +! SFX W ebir ibiéramos ebir +! SFX W acer iciéramos [fh]acer +! SFX W edir idiéramos edir +! SFX W endir indiéramos endir +! SFX W oder udiéramos oder +! SFX W egir igiéramos egir +! SFX W enchir inchiéramos enchir +! SFX W emir imiéramos emir +! SFX W ormir urmiéramos ormir +! SFX W enir iniéramos enir +! SFX W aber upiéramos aber +! SFX W erir iriéramos erir +! SFX W irir iriéramos irir +! SFX W orir uriéramos orir +! SFX W erer isiéramos erer +! SFX W oner usiéramos oner +! SFX W etir itiéramos etir +! SFX W entir intiéramos entir +! SFX W ertir irtiéramos ertir +! SFX W estir istiéramos estir +! SFX W eguir iguiéramos eguir +! SFX W ervir irviéramos ervir +! SFX W ar uviéramos andar +! SFX W ener uviéramos ener +! SFX W cir jéramos ucir +! SFX W er jéramos raer +! SFX W ecir ijéramos ecir +! SFX W er yéramos [eo]er +! SFX W er yéramos caer +! SFX W ir yéramos [^g]uir +! SFX W ír yéramos oír +! SFX W üir uyéramos güir +! SFX W eñir iñéramos eñir +! SFX W etir itamos etir +! SFX W entir intamos entir +! SFX W ertir irtamos ertir +! SFX W estir istamos estir +! SFX W ervir irvamos ervir +! SFX W er yamos oer +! SFX W ir yamos [^g]uir +! SFX W üir uyamos güir +! SFX W cer zamos cocer +! SFX W cer zamos orcer +! SFX W 0 íamos [^fh]acer +! SFX W 0 íamos [aeo]er +! SFX W 0 íamos [io]rir +! SFX W 0 íamos [üu]ir +! SFX W 0 íamos ar +! SFX W 0 íamos e[bdgmrtñ]ir +! SFX W 0 íamos e[cd]er +! SFX W 0 íamos e[ns]tir +! SFX W 0 íamos enchir +! SFX W 0 íamos ender +! SFX W 0 íamos endir +! SFX W 0 íamos er[dnt]er +! SFX W 0 íamos er[ntv]ir +! SFX W 0 íamos eunir +! SFX W 0 íamos o[clv]er +! SFX W 0 íamos olver +! SFX W 0 íamos or[cd]er +! SFX W 0 íamos ormir +! SFX W 0 íamos ucir +! SFX W er íamos er +! SFX W ir íamos ir +! SFX W ír íamos ír +! SFX W cer ríamos [fh]acer +! SFX W er ríamos aber +! SFX W er ríamos erer +! SFX W er ríamos oder +! SFX W er dríamos [eo]ner +! SFX W er dríamos aler +! SFX W ir dríamos alir +! SFX W ir dríamos enir +! SFX W ecir iríamos ecir +! SFX W ír iríamos [eo]ír +! SFX W eñir iñamos eñir +! SFX W 0 emos [^fh]acer +! SFX W 0 emos [aeo]er +! SFX W 0 emos [io]rir +! SFX W 0 emos [üu]ir +! SFX W 0 emos ar +! SFX W 0 emos e[bdgmrtñ]ir +! SFX W 0 emos e[cd]er +! SFX W 0 emos e[ns]tir +! SFX W 0 emos enchir +! SFX W 0 emos ender +! SFX W 0 emos endir +! SFX W 0 emos er[dnt]er +! SFX W 0 emos er[ntv]ir +! SFX W 0 emos eunir +! SFX W 0 emos o[clv]er +! SFX W 0 emos olver +! SFX W 0 emos or[cd]er +! SFX W 0 emos ormir +! SFX W 0 emos ucir +! SFX W ar emos [^g]uar +! SFX W ar emos [ae]hu[ms]ar +! SFX W ar emos [ae]ndar +! SFX W ar emos [aeo]hi[jlnt]ar +! SFX W ar emos ebrar +! SFX W ar emos edrar +! SFX W ar emos elar +! SFX W ar emos emblar +! SFX W ar emos embrar +! SFX W ar emos endrar +! SFX W ar emos ensar +! SFX W ar emos entar +! SFX W ar emos erbar +! SFX W ar emos ernar +! SFX W ar emos errar +! SFX W ar emos ertar +! SFX W ar emos esar +! SFX W ar emos estar +! SFX W ar emos etar +! SFX W ar emos evar +! SFX W ar emos obar +! SFX W ar emos oblar +! SFX W ar emos odar +! SFX W ar emos olar +! SFX W ar emos oldar +! SFX W ar emos ollar +! SFX W ar emos oltar +! SFX W ar emos onar +! SFX W ar emos ontar +! SFX W ar emos ontrar +! SFX W ar emos orar +! SFX W ar emos ordar +! SFX W ar emos ornar +! SFX W ar emos ortar +! SFX W ar emos osar +! SFX W ar emos ostar +! SFX W ar emos ostrar +! SFX W ar emos ovar +! SFX W ar emos oñar +! SFX W zar cemos [ae]izar +! SFX W zar cemos enzar +! SFX W zar cemos ezar +! SFX W zar cemos gonzar +! SFX W zar cemos orzar +! SFX W iar iemos iar +! SFX W cer remos [fh]acer +! SFX W er remos aber +! SFX W er remos erer +! SFX W er remos oder +! SFX W er dremos [eo]ner +! SFX W er dremos aler +! SFX W ir dremos alir +! SFX W ir dremos enir +! SFX W ecir iremos ecir +! SFX W ír iremos [eo]ír +! SFX W ar áremos [^a]ndar +! SFX W ar áremos [^d]ar +! SFX W ar áremos [^n]dar +! SFX W r éremos alir +! SFX W r éremos ernir +! SFX W r éremos eunir +! SFX W r éremos ohibir +! SFX W er iéremos [^fh]acer +! SFX W er iéremos aler +! SFX W er iéremos e[cd]er +! SFX W er iéremos ender +! SFX W er iéremos er[dnt]er +! SFX W er iéremos o[clv]er +! SFX W er iéremos olver +! SFX W er iéremos or[cd]er +! SFX W eír iéremos eír +! SFX W ebir ibiéremos ebir +! SFX W acer iciéremos [fh]acer +! SFX W edir idiéremos edir +! SFX W endir indiéremos endir +! SFX W oder udiéremos oder +! SFX W egir igiéremos egir +! SFX W enchir inchiéremos enchir +! SFX W emir imiéremos emir +! SFX W ormir urmiéremos ormir +! SFX W enir iniéremos enir +! SFX W aber upiéremos aber +! SFX W erir iriéremos erir +! SFX W irir iriéremos irir +! SFX W orir uriéremos orir +! SFX W erer isiéremos erer +! SFX W oner usiéremos oner +! SFX W etir itiéremos etir +! SFX W entir intiéremos entir +! SFX W ertir irtiéremos ertir +! SFX W estir istiéremos estir +! SFX W eguir iguiéremos eguir +! SFX W ervir irviéremos ervir +! SFX W ar uviéremos andar +! SFX W ener uviéremos ener +! SFX W cir jéremos ucir +! SFX W er jéremos raer +! SFX W ecir ijéremos ecir +! SFX W er yéremos [eo]er +! SFX W er yéremos caer +! SFX W ir yéremos [^g]uir +! SFX W ír yéremos oír +! SFX W üir uyéremos güir +! SFX W eñir iñéremos eñir +! SFX W ar ásemos [^d]ar +! SFX W ar ásemos [^n]dar +! SFX W r ásemos [^a]ndar +! SFX W r ésemos alir +! SFX W r ésemos ernir +! SFX W r ésemos eunir +! SFX W r ésemos ohibir +! SFX W er iésemos [^fh]acer +! SFX W er iésemos aler +! SFX W er iésemos e[cd]er +! SFX W er iésemos ender +! SFX W er iésemos er[dnt]er +! SFX W er iésemos o[clv]er +! SFX W er iésemos olver +! SFX W er iésemos or[cd]er +! SFX W eír iésemos eír +! SFX W ebir ibiésemos ebir +! SFX W acer iciésemos [fh]acer +! SFX W edir idiésemos edir +! SFX W endir indiésemos endir +! SFX W oder udiésemos oder +! SFX W egir igiésemos egir +! SFX W enchir inchiésemos enchir +! SFX W emir imiésemos emir +! SFX W ormir urmiésemos ormir +! SFX W enir iniésemos enir +! SFX W aber upiésemos aber +! SFX W erir iriésemos erir +! SFX W irir iriésemos irir +! SFX W orir uriésemos orir +! SFX W erer isiésemos erer +! SFX W oner usiésemos oner +! SFX W etir itiésemos etir +! SFX W entir intiésemos entir +! SFX W ertir irtiésemos ertir +! SFX W estir istiésemos estir +! SFX W eguir iguiésemos eguir +! SFX W ervir irviésemos ervir +! SFX W ar uviésemos andar +! SFX W ener uviésemos ener +! SFX W cir jésemos ucir +! SFX W er jésemos raer +! SFX W ecir ijésemos ecir +! SFX W er yésemos [eo]er +! SFX W er yésemos caer +! SFX W ir yésemos [^g]uir +! SFX W ír yésemos oír +! SFX W üir uyésemos güir +! SFX W eñir iñésemos eñir +! SFX W ar uemos olgar +! SFX W gar guemos egar +! SFX W gar guemos engar +! SFX W gar guemos ogar +! SFX W gar guemos ugar +! SFX W car quemos ocar +! SFX W car quemos olcar +! SFX W car quemos orcar +! SFX W uar üemos guar +! SFX W er imos [^fh]acer +! SFX W er imos aler +! SFX W er imos e[cd]er +! SFX W er imos ender +! SFX W er imos er[dnt]er +! SFX W er imos o[clv]er +! SFX W er imos olver +! SFX W er imos or[cd]er +! SFX W acer icimos [fh]acer +! SFX W oder udimos oder +! SFX W cir jimos ucir +! SFX W er jimos raer +! SFX W ecir ijimos ecir +! SFX W enir inimos enir +! SFX W aber upimos aber +! SFX W erer isimos erer +! SFX W oner usimos oner +! SFX W ar uvimos andar +! SFX W ener uvimos ener +! SFX W er ímos [eo]er +! SFX W er ímos caer +! +! +! +! SFX W Y 29 S +! SFX W 0 ás [^fh]acer +! SFX W 0 ás [aeo]er +! SFX W 0 ás [io]rir +! SFX W 0 ás [üu]ir +! SFX W 0 ás ar +! SFX W 0 ás e[bdgmrtñ]ir +! SFX W 0 ás e[cd]er +! SFX W 0 ás e[ns]tir +! SFX W 0 ás enchir +! SFX W 0 ás ender +! SFX W 0 ás endir +! SFX W 0 ás er[dnt]er +! SFX W 0 ás er[ntv]ir +! SFX W 0 ás eunir +! SFX W 0 ás o[clv]er +! SFX W 0 ás olver +! SFX W 0 ás or[cd]er +! SFX W 0 ás ormir +! SFX W 0 ás ucir +! SFX W cer rás [fh]acer +! SFX W er rás aber +! SFX W er rás erer +! SFX W er rás oder +! SFX W er drás [eo]ner +! SFX W er drás aler +! SFX W ir drás alir +! SFX W ir drás enir +! SFX W ecir irás ecir +! SFX W ír irás [eo]ír +! +! +! SFX W Y 29 S +! SFX W 0 á [^fh]acer +! SFX W 0 á [aeo]er +! SFX W 0 á [io]rir +! SFX W 0 á [üu]ir +! SFX W 0 á ar +! SFX W 0 á e[bdgmrtñ]ir +! SFX W 0 á e[cd]er +! SFX W 0 á e[ns]tir +! SFX W 0 á enchir +! SFX W 0 á ender +! SFX W 0 á endir +! SFX W 0 á er[dnt]er +! SFX W 0 á er[ntv]ir +! SFX W 0 á eunir +! SFX W 0 á o[clv]er +! SFX W 0 á olver +! SFX W 0 á or[cd]er +! SFX W 0 á ormir +! SFX W 0 á ucir +! SFX W cer rá [fh]acer +! SFX W er rá aber +! SFX W er rá erer +! SFX W er rá oder +! SFX W er drá [eo]ner +! SFX W er drá aler +! SFX W ir drá alir +! SFX W ir drá enir +! SFX W ecir irá ecir +! SFX W ír irá [eo]ír +! +! +! +! SFX W Y 38 S +! SFX W 0 é [^fh]acer +! SFX W 0 é [aeo]er +! SFX W 0 é [io]rir +! SFX W 0 é [üu]ir +! SFX W 0 é ar +! SFX W 0 é e[bdgmrtñ]ir +! SFX W 0 é e[cd]er +! SFX W 0 é e[ns]tir +! SFX W 0 é enchir +! SFX W 0 é ender +! SFX W 0 é endir +! SFX W 0 é er[dnt]er +! SFX W 0 é er[ntv]ir +! SFX W 0 é eunir +! SFX W 0 é o[clv]er +! SFX W 0 é olver +! SFX W 0 é or[cd]er +! SFX W 0 é ormir +! SFX W 0 é ucir +! SFX W aber é saber +! SFX W ar é [^a]ndar +! SFX W ar é [^cguzd]ar +! SFX W ar é [^g]uar +! SFX W ar é [^n]dar +! SFX W zar cé zar +! SFX W cer ré [fh]acer +! SFX W er ré aber +! SFX W er ré erer +! SFX W er ré oder +! SFX W er dré [eo]ner +! SFX W er dré aler +! SFX W ir dré alir +! SFX W ir dré enir +! SFX W ecir iré ecir +! SFX W ír iré [eo]ír +! SFX W ar ué gar +! SFX W car qué car +! SFX W uar üé guar +! +! +! SFX W Y 31 S +! SFX W er í [^fh]acer +! SFX W er í [eo]er +! SFX W er í aler +! SFX W er í caer +! SFX W er í e[cd]er +! SFX W er í ender +! SFX W er í er[dnt]er +! SFX W er í o[clv]er +! SFX W er í olver +! SFX W er í or[cd]er +! SFX W ir í [üu]ir +! SFX W ir í alir +! SFX W ir í ebir +! SFX W ir í edir +! SFX W ir í egir +! SFX W ir í emir +! SFX W ir í enchir +! SFX W ir í endir +! SFX W ir í entir +! SFX W ir í erir +! SFX W ir í ernir +! SFX W ir í ertir +! SFX W ir í ervir +! SFX W ir í estir +! SFX W ir í etir +! SFX W ir í eunir +! SFX W ir í eñir +! SFX W ir í irir +! SFX W ir í orir +! SFX W ir í ormir +! SFX W ír í [eo]ír +! +! +! +! SFX W Y 39 S +! SFX W ar ó [^a]ndar +! SFX W ar ó [^d]ar +! SFX W ar ó [^n]dar +! SFX W r ó alir +! SFX W r ó ernir +! SFX W r ó eunir +! SFX W r ó irir +! SFX W r ó ohibir +! SFX W er ió [^fh]acer +! SFX W er ió aler +! SFX W er ió e[cd]er +! SFX W er ió ender +! SFX W er ió er[dnt]er +! SFX W er ió o[clv]er +! SFX W er ió olver +! SFX W er ió or[cd]er +! SFX W er ió order +! SFX W eír ió eír +! SFX W ebir ibió ebir +! SFX W edir idió edir +! SFX W endir indió endir +! SFX W egir igió egir +! SFX W enchir inchió enchir +! SFX W emir imió emir +! SFX W ormir urmió ormir +! SFX W erir irió erir +! SFX W orir urió orir +! SFX W etir itió etir +! SFX W entir intió entir +! SFX W ertir irtió ertir +! SFX W estir istió estir +! SFX W eguir iguió eguir +! SFX W ervir irvió ervir +! SFX W er yó [eo]er +! SFX W er yó caer +! SFX W ir yó [^g]uir +! SFX W ír yó oír +! SFX W üir uyó güir +! SFX W eñir iñó eñir +! +! +! +! SFX W Y 21 +! SFX W r d [aeií]r +! SFX W r n [^c]ocer +! SFX W r n [cr]aer +! SFX W r n [eo]er +! SFX W r n a[bcl]er +! SFX W r n andar +! SFX W r n ecer +! SFX W r n guar +! SFX W r n oner +! SFX W r s [^c]ocer +! SFX W r s [cr]aer +! SFX W r s [eo]er +! SFX W r s a[bcl]er +! SFX W r s andar +! SFX W r s ecer +! SFX W r s guar +! SFX W r s oner +! SFX W r bais ar +! SFX W ir ís ir +! SFX W ír ís ír +! SFX W cer z [fh]acer +! +! SFX Y Y 102 +! SFX Y er ído [aeo]er +! SFX Y er ídos [aeo]er +! SFX Y er ída [aeo]er +! SFX Y er ídas [aeo]er +! SFX Y acer echo [fh]acer +! SFX Y acer echos [fh]acer +! SFX Y acer echa [fh]acer +! SFX Y acer echas [fh]acer +! SFX Y er ido oder +! SFX Y er idos oder +! SFX Y er ida oder +! SFX Y er idas oder +! SFX Y olver uelto olver +! SFX Y olver ueltos olver +! SFX Y olver uelta olver +! SFX Y olver ueltas olver +! SFX Y oner uesto oner +! SFX Y oner uestos oner +! SFX Y oner uesta oner +! SFX Y oner uestas oner +! SFX Y rir ierto abrir +! SFX Y rir iertos abrir +! SFX Y rir ierta abrir +! SFX Y rir iertas abrir +! SFX Y r do e[bdgmnrtñ]ir +! SFX Y r dos e[bdgmnrtñ]ir +! SFX Y r da e[bdgmnrtñ]ir +! SFX Y r das e[bdgmnrtñ]ir +! SFX Y ecir icho ecir +! SFX Y ecir ichos ecir +! SFX Y ecir icha ecir +! SFX Y ecir ichas ecir +! SFX Y r do [eo]ír +! SFX Y r dos [eo]ír +! SFX Y r da [eo]ír +! SFX Y r das [eo]ír +! SFX Y r do enchir +! SFX Y r dos enchir +! SFX Y r da enchir +! SFX Y r das enchir +! SFX Y r do en[dt]ir +! SFX Y r dos en[dt]ir +! SFX Y r da en[dt]ir +! SFX Y r das en[dt]ir +! SFX Y r do er[tv]ir +! SFX Y r dos er[tv]ir +! SFX Y r da er[tv]ir +! SFX Y r das er[tv]ir +! SFX Y r do estir +! SFX Y r dos estir +! SFX Y r da estir +! SFX Y r das estir +! SFX Y bir to ibir +! SFX Y bir tos ibir +! SFX Y bir ta ibir +! SFX Y bir tas ibir +! SFX Y orir uerto orir +! SFX Y orir uertos orir +! SFX Y orir uerta orir +! SFX Y orir uertas orir +! SFX Y r do ormir +! SFX Y r dos ormir +! SFX Y r da ormir +! SFX Y r das ormir +! SFX Y rir ierto ubrir +! SFX Y rir iertos ubrir +! SFX Y rir ierta ubrir +! SFX Y rir iertas ubrir +! SFX Y r do [üu]ir +! SFX Y r da [üu]ir +! SFX Y r dos [üu]ir +! SFX Y r das [üu]ir +! SFX Y er iendo [fh]acer +! SFX Y er yendo [aeo]er +! SFX Y oder udiendo oder +! SFX Y er iendo olver +! SFX Y er iendo oner +! SFX Y r endo abrir +! SFX Y ebir ibiendo ebir +! SFX Y ecir iciendo ecir +! SFX Y edir idiendo edir +! SFX Y egir igiendo egir +! SFX Y emir imiendo emir +! SFX Y eír iendo eír +! SFX Y eñir iñendo eñir +! SFX Y enchir inchiendo enchir +! SFX Y endir indiendo endir +! SFX Y enir iniendo enir +! SFX Y entir intiendo entir +! SFX Y ertir irtiendo ertir +! SFX Y ervir irviendo ervir +! SFX Y estir istiendo estir +! SFX Y eguir iguiendo eguir +! SFX Y erir iriendo erir +! SFX Y etir itiendo etir +! SFX Y r endo ibir +! SFX Y ír yendo oír +! SFX Y orir uriendo orir +! SFX Y ormir urmiendo ormir +! SFX Y r endo ubrir +! SFX Y ir yendo [^g]uir +! SFX Y üir uyendo güir +! +! SFX O Y 115 +! SFX O 0 me [eií]r +! SFX O 0 te [eií]r +! SFX O 0 se [eií]r +! SFX O 0 nos [eií]r +! SFX O 0 os [eií]r +! SFX O er yéndome [aeo]er +! SFX O er yéndote [aeo]er +! SFX O er yéndose [aeo]er +! SFX O er yéndonos [aeo]er +! SFX O er yéndoos [aeo]er +! SFX O oder udiéndome oder +! SFX O oder udiéndote oder +! SFX O oder udiéndose oder +! SFX O oder udiéndonos oder +! SFX O oder udiéndoos oder +! SFX O ebir ibiéndome ebir +! SFX O ebir ibiéndote ebir +! SFX O ebir ibiéndose ebir +! SFX O ebir ibiéndonos ebir +! SFX O ebir ibiéndoos ebir +! SFX O ecir iciéndome ecir +! SFX O ecir iciéndote ecir +! SFX O ecir iciéndose ecir +! SFX O ecir iciéndonos ecir +! SFX O ecir iciéndoos ecir +! SFX O edir idiéndome edir +! SFX O edir idiéndote edir +! SFX O edir idiéndose edir +! SFX O edir idiéndonos edir +! SFX O edir idiéndoos edir +! SFX O egir igiéndome egir +! SFX O egir igiéndote egir +! SFX O egir igiéndose egir +! SFX O egir igiéndonos egir +! SFX O egir igiéndoos egir +! SFX O emir imiéndome emir +! SFX O emir imiéndote emir +! SFX O emir imiéndose emir +! SFX O emir imiéndonos emir +! SFX O emir imiéndoos emir +! SFX O eír iéndome eír +! SFX O eír iéndote eír +! SFX O eír iéndose eír +! SFX O eír iéndonos eír +! SFX O eír iéndoos eír +! SFX O eñir iñéndome eñir +! SFX O eñir iñéndote eñir +! SFX O eñir iñéndose eñir +! SFX O eñir iñéndonos eñir +! SFX O eñir iñéndoos eñir +! SFX O endir indiéndome endir +! SFX O endir indiéndote endir +! SFX O endir indiéndose endir +! SFX O endir indiéndonos endir +! SFX O endir indiéndoos endir +! SFX O enir iniéndome enir +! SFX O enir iniéndote enir +! SFX O enir iniéndose enir +! SFX O enir iniéndonos enir +! SFX O enir iniéndoos enir +! SFX O entir intiéndome entir +! SFX O entir intiéndote entir +! SFX O entir intiéndose entir +! SFX O entir intiéndonos entir +! SFX O entir intiéndoos entir +! SFX O ertir irtiéndome ertir +! SFX O ertir irtiéndote ertir +! SFX O ertir irtiéndose ertir +! SFX O ertir irtiéndonos ertir +! SFX O ertir irtiéndoos ertir +! SFX O ervir irviéndome ervir +! SFX O ervir irviéndote ervir +! SFX O ervir irviéndose ervir +! SFX O ervir irviéndonos ervir +! SFX O ervir irviéndoos ervir +! SFX O estir istiéndome estir +! SFX O estir istiéndote estir +! SFX O estir istiéndose estir +! SFX O estir istiéndonos estir +! SFX O estir istiéndoos estir +! SFX O eguir iguiéndome eguir +! SFX O eguir iguiéndote eguir +! SFX O eguir iguiéndose eguir +! SFX O eguir iguiéndonos eguir +! SFX O eguir iguiéndoos eguir +! SFX O erir iriéndome erir +! SFX O erir iriéndote erir +! SFX O erir iriéndose erir +! SFX O erir iriéndonos erir +! SFX O erir iriéndoos erir +! SFX O etir itiéndome etir +! SFX O etir itiéndote etir +! SFX O etir itiéndose etir +! SFX O etir itiéndonos etir +! SFX O etir itiéndoos etir +! SFX O ír yéndome oír +! SFX O ír yéndote oír +! SFX O ír yéndose oír +! SFX O ír yéndonos oír +! SFX O ír yéndoos oír +! SFX O orir uriéndome orir +! SFX O orir uriéndote orir +! SFX O orir uriéndose orir +! SFX O orir uriéndonos orir +! SFX O orir uriéndoos orir +! SFX O ormir urmiéndome ormir +! SFX O ormir urmiéndote ormir +! SFX O ormir urmiéndose ormir +! SFX O ormir urmiéndonos ormir +! SFX O ormir urmiéndoos ormir +! SFX O ir yéndome [^g]uir +! SFX O ir yéndote [^g]uir +! SFX O ir yéndose [^g]uir +! SFX O ir yéndonos [^g]uir +! SFX O ir yéndoos [^g]uir +! +! SFX Q Y 138 +! SFX Q 0 lo [eií]r +! SFX Q 0 la [eií]r +! SFX Q 0 los [eií]r +! SFX Q 0 las [eií]r +! SFX Q 0 le [eií]r +! SFX Q 0 les [eií]r +! SFX Q er yéndolo [aeo]er +! SFX Q er yéndola [aeo]er +! SFX Q er yéndolos [aeo]er +! SFX Q er yéndolas [aeo]er +! SFX Q er yéndole [aeo]er +! SFX Q er yéndoles [aeo]er +! SFX Q oder udiéndolo oder +! SFX Q oder udiéndola oder +! SFX Q oder udiéndolos oder +! SFX Q oder udiéndolas oder +! SFX Q oder udiéndole oder +! SFX Q oder udiéndoles oder +! SFX Q ebir ibiéndolo ebir +! SFX Q ebir ibiéndolos ebir +! SFX Q ebir ibiéndola ebir +! SFX Q ebir ibiéndolas ebir +! SFX Q ebir ibiéndole ebir +! SFX Q ebir ibiéndoles ebir +! SFX Q ecir iciéndolo ecir +! SFX Q ecir iciéndolos ecir +! SFX Q ecir iciéndola ecir +! SFX Q ecir iciéndolas ecir +! SFX Q ecir iciéndole ecir +! SFX Q ecir iciéndoles ecir +! SFX Q edir idiéndolo edir +! SFX Q edir idiéndolos edir +! SFX Q edir idiéndola edir +! SFX Q edir idiéndolas edir +! SFX Q edir idiéndole edir +! SFX Q edir idiéndoles edir +! SFX Q egir igiéndolo egir +! SFX Q egir igiéndolos egir +! SFX Q egir igiéndola egir +! SFX Q egir igiéndolas egir +! SFX Q egir igiéndole egir +! SFX Q egir igiéndoles egir +! SFX Q emir imiéndolo emir +! SFX Q emir imiéndolos emir +! SFX Q emir imiéndola emir +! SFX Q emir imiéndolas emir +! SFX Q emir imiéndole emir +! SFX Q emir imiéndoles emir +! SFX Q eír iéndolo eír +! SFX Q eír iéndolos eír +! SFX Q eír iéndola eír +! SFX Q eír iéndolas eír +! SFX Q eír iéndole eír +! SFX Q eír iéndoles eír +! SFX Q eñir iñéndolo eñir +! SFX Q eñir iñéndolos eñir +! SFX Q eñir iñéndola eñir +! SFX Q eñir iñéndolas eñir +! SFX Q eñir iñéndole eñir +! SFX Q eñir iñéndoles eñir +! SFX Q endir indiéndolo endir +! SFX Q endir indiéndolos endir +! SFX Q endir indiéndola endir +! SFX Q endir indiéndolas endir +! SFX Q endir indiéndole endir +! SFX Q endir indiéndoles endir +! SFX Q enir iniéndolo enir +! SFX Q enir iniéndolos enir +! SFX Q enir iniéndola enir +! SFX Q enir iniéndolas enir +! SFX Q enir iniéndole enir +! SFX Q enir iniéndoles enir +! SFX Q entir intiéndolo entir +! SFX Q entir intiéndolos entir +! SFX Q entir intiéndola entir +! SFX Q entir intiéndolas entir +! SFX Q entir intiéndole entir +! SFX Q entir intiéndoles entir +! SFX Q ertir irtiéndolo ertir +! SFX Q ertir irtiéndolos ertir +! SFX Q ertir irtiéndola ertir +! SFX Q ertir irtiéndolas ertir +! SFX Q ertir irtiéndole ertir +! SFX Q ertir irtiéndoles ertir +! SFX Q ervir irviéndolo ervir +! SFX Q ervir irviéndolos ervir +! SFX Q ervir irviéndola ervir +! SFX Q ervir irviéndolas ervir +! SFX Q ervir irviéndole ervir +! SFX Q ervir irviéndoles ervir +! SFX Q estir istiéndolo estir +! SFX Q estir istiéndolos estir +! SFX Q estir istiéndola estir +! SFX Q estir istiéndolas estir +! SFX Q estir istiéndole estir +! SFX Q estir istiéndoles estir +! SFX Q eguir iguiéndolo eguir +! SFX Q eguir iguiéndolos eguir +! SFX Q eguir iguiéndola eguir +! SFX Q eguir iguiéndolas eguir +! SFX Q eguir iguiéndole eguir +! SFX Q eguir iguiéndoles eguir +! SFX Q erir iriéndolo erir +! SFX Q erir iriéndolos erir +! SFX Q erir iriéndola erir +! SFX Q erir iriéndolas erir +! SFX Q erir iriéndole erir +! SFX Q erir iriéndoles erir +! SFX Q etir itiéndolo etir +! SFX Q etir itiéndolos etir +! SFX Q etir itiéndola etir +! SFX Q etir itiéndolas etir +! SFX Q etir itiéndole etir +! SFX Q etir itiéndoles etir +! SFX Q ír yéndolo oír +! SFX Q ír yéndolos oír +! SFX Q ír yéndola oír +! SFX Q ír yéndolas oír +! SFX Q ír yéndole oír +! SFX Q ír yéndoles oír +! SFX Q orir uriéndolo orir +! SFX Q orir uriéndolos orir +! SFX Q orir uriéndola orir +! SFX Q orir uriéndolas orir +! SFX Q orir uriéndole orir +! SFX Q orir uriéndoles orir +! SFX Q ormir urmiéndolo ormir +! SFX Q ormir urmiéndolos ormir +! SFX Q ormir urmiéndola ormir +! SFX Q ormir urmiéndolas ormir +! SFX Q ormir urmiéndole ormir +! SFX Q ormir urmiéndoles ormir +! SFX Q ir yéndolo [^g]uir +! SFX Q ir yéndolos [^g]uir +! SFX Q ir yéndola [^g]uir +! SFX Q ir yéndolas [^g]uir +! SFX Q ir yéndole [^g]uir +! SFX Q ir yéndoles [^g]uir +! +! SFX Z Y 171 +! SFX Z er érmelo er +! SFX Z er érmela er +! SFX Z er érmelos er +! SFX Z er érmelas er +! SFX Z er értelo er +! SFX Z er értela er +! SFX Z er értelos er +! SFX Z er értelas er +! SFX Z er érselo er +! SFX Z er érsela er +! SFX Z er érselos er +! SFX Z er érselas er +! SFX Z er éroslo er +! SFX Z er érosla er +! SFX Z er éroslos er +! SFX Z er éroslas er +! SFX Z er érnoslo er +! SFX Z er érnosla er +! SFX Z er érnoslos er +! SFX Z er érnoslas er +! SFX Z er érnosles er +! SFX Z ir írmelo ir +! SFX Z ir írmela ir +! SFX Z ir írmele ir +! SFX Z ir írmelos ir +! SFX Z ir írmelas ir +! SFX Z ir írmeles ir +! SFX Z ir írtelo ir +! SFX Z ir írtela ir +! SFX Z ir írtele ir +! SFX Z ir írtelos ir +! SFX Z ir írtelas ir +! SFX Z ir írteles ir +! SFX Z ir írselo ir +! SFX Z ir írsela ir +! SFX Z ir írsele ir +! SFX Z ir írselos ir +! SFX Z ir írselas ir +! SFX Z ir írseles ir +! SFX Z ir íroslo ir +! SFX Z ir írosla ir +! SFX Z ir írosle ir +! SFX Z ir íroslos ir +! SFX Z ir íroslas ir +! SFX Z ir írosles ir +! SFX Z ir írnoslo ir +! SFX Z ir írnosla ir +! SFX Z ir írnosle ir +! SFX Z ir írnoslos ir +! SFX Z ir írnoslas ir +! SFX Z ir írnosles ir +! SFX Z er yéndomelo [aeo]er +! SFX Z er yéndomela [aeo]er +! SFX Z er yéndomele [aeo]er +! SFX Z er yéndomelos [aeo]er +! SFX Z er yéndomelas [aeo]er +! SFX Z er yéndomeles [aeo]er +! SFX Z er yéndotelo [aeo]er +! SFX Z er yéndotela [aeo]er +! SFX Z er yéndotele [aeo]er +! SFX Z er yéndotelos [aeo]er +! SFX Z er yéndotelas [aeo]er +! SFX Z er yéndoteles [aeo]er +! SFX Z er yéndoselo [aeo]er +! SFX Z er yéndosela [aeo]er +! SFX Z er yéndosele [aeo]er +! SFX Z er yéndoselos [aeo]er +! SFX Z er yéndoselas [aeo]er +! SFX Z er yéndoseles [aeo]er +! SFX Z er yéndooslo [aeo]er +! SFX Z er yéndoosla [aeo]er +! SFX Z er yéndoosle [aeo]er +! SFX Z er yéndooslos [aeo]er +! SFX Z er yéndooslas [aeo]er +! SFX Z er yéndoosles [aeo]er +! SFX Z er yéndonoslo [aeo]er +! SFX Z er yéndonosla [aeo]er +! SFX Z er yéndonosle [aeo]er +! SFX Z er yéndonoslos [aeo]er +! SFX Z er yéndonoslas [aeo]er +! SFX Z er yéndonosles [aeo]er +! SFX Z ir yéndomelo [^g]uir +! SFX Z ir yéndomelos [^g]uir +! SFX Z ir yéndomela [^g]uir +! SFX Z ir yéndomelas [^g]uir +! SFX Z ir yéndomele [^g]uir +! SFX Z ir yéndomeles [^g]uir +! SFX Z ir yéndotelo [^g]uir +! SFX Z ir yéndotelos [^g]uir +! SFX Z ir yéndotela [^g]uir +! SFX Z ir yéndotelas [^g]uir +! SFX Z ir yéndotele [^g]uir +! SFX Z ir yéndoteles [^g]uir +! SFX Z ir yéndoselo [^g]uir +! SFX Z ir yéndoselos [^g]uir +! SFX Z ir yéndosela [^g]uir +! SFX Z ir yéndoselas [^g]uir +! SFX Z ir yéndosele [^g]uir +! SFX Z ir yéndoseles [^g]uir +! SFX Z ir yéndooslo [^g]uir +! SFX Z ir yéndooslos [^g]uir +! SFX Z ir yéndoosla [^g]uir +! SFX Z ir yéndooslas [^g]uir +! SFX Z ir yéndoosle [^g]uir +! SFX Z ir yéndoosles [^g]uir +! SFX Z ir yéndonoslo [^g]uir +! SFX Z ir yéndonoslos [^g]uir +! SFX Z ir yéndonosla [^g]uir +! SFX Z ir yéndonoslas [^g]uir +! SFX Z ir yéndonosle [^g]uir +! SFX Z ir yéndonosles [^g]uir +! SFX Z egir igiéndomelo egir +! SFX Z egir igiéndomelos egir +! SFX Z egir igiéndomela egir +! SFX Z egir igiéndomelas egir +! SFX Z egir igiéndomele egir +! SFX Z egir igiéndomeles egir +! SFX Z egir igiéndotelo egir +! SFX Z egir igiéndotelos egir +! SFX Z egir igiéndotela egir +! SFX Z egir igiéndotelas egir +! SFX Z egir igiéndotele egir +! SFX Z egir igiéndoteles egir +! SFX Z egir igiéndoselo egir +! SFX Z egir igiéndoselos egir +! SFX Z egir igiéndosela egir +! SFX Z egir igiéndoselas egir +! SFX Z egir igiéndosele egir +! SFX Z egir igiéndoseles egir +! SFX Z egir igiéndooslo egir +! SFX Z egir igiéndooslos egir +! SFX Z egir igiéndoosla egir +! SFX Z egir igiéndooslas egir +! SFX Z egir igiéndoosle egir +! SFX Z egir igiéndoosles egir +! SFX Z egir igiéndonoslo egir +! SFX Z egir igiéndonoslos egir +! SFX Z egir igiéndonosla egir +! SFX Z egir igiéndonoslas egir +! SFX Z egir igiéndonosle egir +! SFX Z egir igiéndonosles egir +! SFX Z eguir iguiéndomelo eguir +! SFX Z eguir iguiéndomelos eguir +! SFX Z eguir iguiéndomela eguir +! SFX Z eguir iguiéndomelas eguir +! SFX Z eguir iguiéndomele eguir +! SFX Z eguir iguiéndomeles eguir +! SFX Z eguir iguiéndotelo eguir +! SFX Z eguir iguiéndotelos eguir +! SFX Z eguir iguiéndotela eguir +! SFX Z eguir iguiéndotelas eguir +! SFX Z eguir iguiéndotele eguir +! SFX Z eguir iguiéndoteles eguir +! SFX Z eguir iguiéndoselo eguir +! SFX Z eguir iguiéndoselos eguir +! SFX Z eguir iguiéndosela eguir +! SFX Z eguir iguiéndoselas eguir +! SFX Z eguir iguiéndosele eguir +! SFX Z eguir iguiéndoseles eguir +! SFX Z eguir iguiéndooslo eguir +! SFX Z eguir iguiéndooslos eguir +! SFX Z eguir iguiéndoosla eguir +! SFX Z eguir iguiéndooslas eguir +! SFX Z eguir iguiéndoosle eguir +! SFX Z eguir iguiéndoosles eguir +! SFX Z eguir iguiéndonoslo eguir +! SFX Z eguir iguiéndonoslos eguir +! SFX Z eguir iguiéndonosla eguir +! SFX Z eguir iguiéndonoslas eguir +! SFX Z eguir iguiéndonosle eguir +! SFX Z eguir iguiéndonosles eguir +*** es_MX.orig.dic Thu Aug 25 19:19:45 2005 +--- es_MX.dic Thu Aug 25 20:15:59 2005 +*************** +*** 1218,1220 **** + Internet +- intraocular + Irapuato +--- 1218,1219 ---- +*************** +*** 33345,33347 **** + nanear/PSVWX +- nanche/S + nanjea/S +--- 33344,33345 ---- diff --git a/share/vim/vim73/spell/es/main.aap b/share/vim/vim73/spell/es/main.aap new file mode 100644 index 0000000000..2421837c74 --- /dev/null +++ b/share/vim/vim73/spell/es/main.aap @@ -0,0 +1,92 @@ +# Aap recipe for Spanish Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +REGIONS = ES MX +ES_REGIONS = es_$*REGIONS + +SPELLDIR = .. +FILES = es_$*(REGIONS).aff es_$*(REGIONS).dic + +ZIPFILE_ES = es_ES.zip +ZIPFILE_MX = es_MX.zip +ZIPFILES = $ZIPFILE_ES $ZIPFILE_MX + +READMES = README_es_$*(REGIONS).txt + +all: $SPELLDIR/es.latin1.spl $SPELLDIR/es.utf-8.spl ../README_es.txt + +$SPELLDIR/es.latin1.spl : $FILES + :sys env LANG=es_ES.ISO8859-1 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/es $ES_REGIONS" -c q + +$SPELLDIR/es.utf-8.spl : $FILES + :sys env LANG=es_ES.UTF-8 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/es $ES_REGIONS" -c q + +../README_es.txt: $READMES + :print es_ES >! $target + :cat README_es_ES.txt >> $target + :print =================================================== >>$target + :print es_MX >> $target + :cat README_es_MX.txt >> $target + +# +# Fetching the files from the OpenOffice.org site. +# The OLDSPELL file comes from elsewhere +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} $ZIPFILES + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +es_ES.aff es_ES.dic: {buildcheck=} + :assertpkg unzip patch + :fetch $ZIPFILE_ES + :sys $UNZIP $ZIPFILE_ES + :delete Changelog_es_ES.txt + :delete $ZIPFILE_ES + @if not os.path.exists('es_ES.orig.aff'): + :copy es_ES.aff es_ES.orig.aff + @if not os.path.exists('es_ES.orig.dic'): + :copy es_ES.dic es_ES.orig.dic + @if os.path.exists('es_ES.diff'): + :sys patch <es_ES.diff + +es_MX.aff es_MX.dic: {buildcheck=} + :assertpkg unzip patch + :fetch $ZIPFILE_MX + :print No copyright information for es_MX wordlist >! README_es_MX.txt + :sys $UNZIP $ZIPFILE_MX + :delete $ZIPFILE_MX + :sys $VIM -u NONE -e -c "set ff=unix | wq" es_MX.dic + @if not os.path.exists('es_MX.orig.aff'): + :copy es_MX.aff es_MX.orig.aff + @if not os.path.exists('es_MX.orig.dic'): + :copy es_MX.dic es_MX.orig.dic + @if os.path.exists('es_MX.diff'): + :sys patch <es_MX.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. +diff: + :assertpkg diff + :sys {force} diff -a -C 1 es_ES.orig.aff es_ES.aff >es_ES.diff + :sys {force} diff -a -C 1 es_ES.orig.dic es_ES.dic >>es_ES.diff + :sys {force} diff -a -C 1 es_MX.orig.aff es_MX.aff >es_MX.diff + :sys {force} diff -a -C 1 es_MX.orig.dic es_MX.dic >>es_MX.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :print TODO!!!! + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/fixdup b/share/vim/vim73/spell/fixdup.vim similarity index 100% rename from share/vim/vim72/spell/fixdup rename to share/vim/vim73/spell/fixdup.vim diff --git a/share/vim/vim72/spell/fo/fo_FO.diff b/share/vim/vim73/spell/fo/fo_FO.diff similarity index 100% rename from share/vim/vim72/spell/fo/fo_FO.diff rename to share/vim/vim73/spell/fo/fo_FO.diff diff --git a/share/vim/vim72/spell/fo/main.aap b/share/vim/vim73/spell/fo/main.aap similarity index 100% rename from share/vim/vim72/spell/fo/main.aap rename to share/vim/vim73/spell/fo/main.aap diff --git a/share/vim/vim72/spell/fr/fr_FR.diff b/share/vim/vim73/spell/fr/fr_FR.diff similarity index 100% rename from share/vim/vim72/spell/fr/fr_FR.diff rename to share/vim/vim73/spell/fr/fr_FR.diff diff --git a/share/vim/vim73/spell/fr/main.aap b/share/vim/vim73/spell/fr/main.aap new file mode 100644 index 0000000000..a0cf374495 --- /dev/null +++ b/share/vim/vim73/spell/fr/main.aap @@ -0,0 +1,126 @@ +# Aap recipe for French Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = fr_FR.aff fr_FR.dic + +all: $SPELLDIR/fr.latin1.spl $SPELLDIR/fr.utf-8.spl ../README_fr.txt + +# The spell file is iso-8859-15, but Vim normally uses "latin1" for this. +# This is OK for the utf-8 files, but for latin1 we need to avoid the "oe" +# character. When unpacking we create four files: +# fr_FR_latin1.aff modified file +# fr_FR_latin1.dic modified file +# fr_FR_iso15.aff original file (after applying diff) +# fr_FR_iso15.dic original file (after applying diff) +# Just before using the dictionary files, the right ones are copied to +# fr_FR.aff +# fr_FR.dic + +$SPELLDIR/fr.latin1.spl : $FILES + :copy {force} fr_FR_latin1.aff fr_FR.aff + :copy {force} fr_FR_latin1.dic fr_FR.dic + :sys env LANG=fr_FR.ISO-8859-15@euro + $VIM -u NONE -e -c "mkspell! $SPELLDIR/fr fr_FR" -c q + +$SPELLDIR/fr.utf-8.spl : $FILES + :copy {force} fr_FR_iso15.aff fr_FR.aff + :copy {force} fr_FR_iso15.dic fr_FR.dic + :sys env LANG=fr_FR.UTF-8 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/fr fr_FR" -c q + +../README_fr.txt : README_fr_FR.txt + :cat $source >!$target + +# +# Used to fetch the files from OpenOffice.org. Those are old. +# Later versions are elsewhere. +# +#OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +ZIPFILE = http://dico.savant.free.fr/_download/fr_FR_1-1-6.zip + +:attr {fetch = $ZIPFILE} fr_FR.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +fr_FR.aff fr_FR.dic: {buildcheck=} + :assertpkg unzip patch + :fetch fr_FR.zip + :sys $UNZIP fr_FR.zip + :delete fr_FR.zip + @if not os.path.exists('fr_FR.orig.aff'): + :copy fr_FR.aff fr_FR.orig.aff + @if not os.path.exists('fr_FR.orig.dic'): + :copy fr_FR.dic fr_FR.orig.dic + @if os.path.exists('fr_FR.diff'): + :sys patch <fr_FR.diff + + # Keep the unmodified files (after diff) for ISO-8859-15. + :copy fr_FR.aff fr_FR_iso15.aff + :copy fr_FR.dic fr_FR_iso15.dic + # For the latin1 .dic file change all the "oe" characters to the two + # characters "oe". + :sys $VIM -u NONE -e -c "set enc=latin1" + -c "e fr_FR.dic" + -c "%s/½/oe/g" + -c "w! fr_FR_latin1.dic" + -c q + # For the latin1 .aff file delete all the "oe" and "OE" characters and + # delete the REP lines with those characters. + :sys $VIM -u NONE -e -c "set enc=latin1" + -c "e fr_FR.aff" + -c "%s/½//g" + -c "%s/¼//g" + -c "%g/REP.*oe/d" + -c "w! fr_FR_latin1.aff" + -c q + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. +# This uses the iso-8859-15 files. +diff: + :assertpkg diff + :copy {force} fr_FR_iso15.aff fr_FR.aff + :copy {force} fr_FR_iso15.dic fr_FR.dic + :sys {force} diff -a -C 1 fr_FR.orig.aff fr_FR.aff >fr_FR.diff + :sys {force} diff -a -C 1 fr_FR.orig.dic fr_FR.dic >>fr_FR.diff + +# Delete all the unpacked and generated files, including the "orig" files. +clean: + :delete {force} fr_FR.zip fr_FR.aff fr_FR.dic + fr_FR.aff.orig fr_FR.dic.orig + fr_FR.orig.aff fr_FR.orig.dic + fr_FR_latin1.aff fr_FR_latin1.dic + fr_FR_iso15.aff fr_FR_iso15.dic + README_fr_FR.txt + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch fr_FR.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../fr_FR.zip + :sys {force} diff ../fr_FR.orig.aff fr_FR.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy fr_FR.aff ../fr_FR.new.aff + :sys {force} diff ../fr_FR.orig.dic fr_FR.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy fr_FR.dic ../fr_FR.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete fr_FR.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/ga/ga_IE.diff b/share/vim/vim73/spell/ga/ga_IE.diff similarity index 100% rename from share/vim/vim72/spell/ga/ga_IE.diff rename to share/vim/vim73/spell/ga/ga_IE.diff diff --git a/share/vim/vim72/spell/ga/main.aap b/share/vim/vim73/spell/ga/main.aap similarity index 100% rename from share/vim/vim72/spell/ga/main.aap rename to share/vim/vim73/spell/ga/main.aap diff --git a/share/vim/vim72/spell/gd/gd_GB.diff b/share/vim/vim73/spell/gd/gd_GB.diff similarity index 100% rename from share/vim/vim72/spell/gd/gd_GB.diff rename to share/vim/vim73/spell/gd/gd_GB.diff diff --git a/share/vim/vim73/spell/gd/main.aap b/share/vim/vim73/spell/gd/main.aap new file mode 100644 index 0000000000..55443aeb09 --- /dev/null +++ b/share/vim/vim73/spell/gd/main.aap @@ -0,0 +1,77 @@ +# Aap recipe for Scottish Gaelic Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = gd_GB.aff gd_GB.dic + +all: $SPELLDIR/gd.latin1.spl $SPELLDIR/gd.utf-8.spl ../README_gd.txt + +$SPELLDIR/gd.latin1.spl : $FILES + :sys env LANG=gd_GB.ISO8859-15 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/gd gd_GB" -c q + +$SPELLDIR/gd.utf-8.spl : $FILES + :sys $VIM -u NONE -e -c "set enc=utf-8" -c "mkspell! $SPELLDIR/gd gd_GB" -c q + +../README_gd.txt : README_gd_GB.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} gd_GB.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +gd_GB.aff gd_GB.dic: {buildcheck=} + :assertpkg unzip patch + :fetch gd_GB.zip + :sys $UNZIP gd_GB.zip + :delete gd_GB.zip + @if not os.path.exists('gd_GB.orig.aff'): + :copy gd_GB.aff gd_GB.orig.aff + @if not os.path.exists('gd_GB.orig.dic'): + :copy gd_GB.dic gd_GB.orig.dic + @if os.path.exists('gd_GB.diff'): + :sys patch <gd_GB.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 gd_GB.orig.aff gd_GB.aff >gd_GB.diff + :sys {force} diff -a -C 1 gd_GB.orig.dic gd_GB.dic >>gd_GB.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch gd_GB.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../gd_GB.zip + :sys {force} diff ../gd_GB.orig.aff gd_GB.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy gd_GB.aff ../gd_GB.new.aff + :sys {force} diff ../gd_GB.orig.dic gd_GB.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy gd_GB.dic ../gd_GB.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete gd_GB.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/gl/gl_ES.diff b/share/vim/vim73/spell/gl/gl_ES.diff similarity index 100% rename from share/vim/vim72/spell/gl/gl_ES.diff rename to share/vim/vim73/spell/gl/gl_ES.diff diff --git a/share/vim/vim72/spell/gl/main.aap b/share/vim/vim73/spell/gl/main.aap similarity index 100% rename from share/vim/vim72/spell/gl/main.aap rename to share/vim/vim73/spell/gl/main.aap diff --git a/share/vim/vim72/spell/he.vim b/share/vim/vim73/spell/he.vim similarity index 100% rename from share/vim/vim72/spell/he.vim rename to share/vim/vim73/spell/he.vim diff --git a/share/vim/vim72/spell/he/he_IL.diff b/share/vim/vim73/spell/he/he_IL.diff similarity index 100% rename from share/vim/vim72/spell/he/he_IL.diff rename to share/vim/vim73/spell/he/he_IL.diff diff --git a/share/vim/vim72/spell/he/main.aap b/share/vim/vim73/spell/he/main.aap similarity index 100% rename from share/vim/vim72/spell/he/main.aap rename to share/vim/vim73/spell/he/main.aap diff --git a/share/vim/vim72/spell/hr/hr_HR.diff b/share/vim/vim73/spell/hr/hr_HR.diff similarity index 100% rename from share/vim/vim72/spell/hr/hr_HR.diff rename to share/vim/vim73/spell/hr/hr_HR.diff diff --git a/share/vim/vim72/spell/hr/main.aap b/share/vim/vim73/spell/hr/main.aap similarity index 100% rename from share/vim/vim72/spell/hr/main.aap rename to share/vim/vim73/spell/hr/main.aap diff --git a/share/vim/vim72/spell/hu/hu_HU.diff b/share/vim/vim73/spell/hu/hu_HU.diff similarity index 100% rename from share/vim/vim72/spell/hu/hu_HU.diff rename to share/vim/vim73/spell/hu/hu_HU.diff diff --git a/share/vim/vim72/spell/hu/main.aap b/share/vim/vim73/spell/hu/main.aap similarity index 100% rename from share/vim/vim72/spell/hu/main.aap rename to share/vim/vim73/spell/hu/main.aap diff --git a/share/vim/vim72/spell/id/id_ID.diff b/share/vim/vim73/spell/id/id_ID.diff similarity index 100% rename from share/vim/vim72/spell/id/id_ID.diff rename to share/vim/vim73/spell/id/id_ID.diff diff --git a/share/vim/vim72/spell/id/main.aap b/share/vim/vim73/spell/id/main.aap similarity index 100% rename from share/vim/vim72/spell/id/main.aap rename to share/vim/vim73/spell/id/main.aap diff --git a/share/vim/vim72/spell/it/it_IT.diff b/share/vim/vim73/spell/it/it_IT.diff similarity index 100% rename from share/vim/vim72/spell/it/it_IT.diff rename to share/vim/vim73/spell/it/it_IT.diff diff --git a/share/vim/vim72/spell/it/main.aap b/share/vim/vim73/spell/it/main.aap similarity index 100% rename from share/vim/vim72/spell/it/main.aap rename to share/vim/vim73/spell/it/main.aap diff --git a/share/vim/vim72/spell/ku/ku_TR.diff b/share/vim/vim73/spell/ku/ku_TR.diff similarity index 100% rename from share/vim/vim72/spell/ku/ku_TR.diff rename to share/vim/vim73/spell/ku/ku_TR.diff diff --git a/share/vim/vim73/spell/ku/main.aap b/share/vim/vim73/spell/ku/main.aap new file mode 100644 index 0000000000..987e6dbea2 --- /dev/null +++ b/share/vim/vim73/spell/ku/main.aap @@ -0,0 +1,82 @@ +# Aap recipe for Kurdish Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = ku_TR.aff ku_TR.dic + +# I don't have a Kurdish locale, us the Turkish one. +all: $SPELLDIR/ku.iso-8859-9.spl $SPELLDIR/ku.utf-8.spl \ + ../README_ku.txt + +$SPELLDIR/ku.iso-8859-9.spl : $FILES + :sys env LANG=tr_TR.ISO8859-9 $VIM -u NONE -e -c "mkspell! $SPELLDIR/ku ku_TR" -c q + +$SPELLDIR/ku.utf-8.spl : $FILES + :sys env LANG=tr_TR.UTF-8 $VIM -u NONE -e -c "mkspell! $SPELLDIR/ku ku_TR" -c q + +../README_ku.txt: README_ku_TR.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} ku_TR.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +# This is a bit tricky, since the file name includes the date. +ku_TR.aff ku_TR.dic: {buildcheck=} + :assertpkg unzip patch + :fetch ku_TR.zip + :sys $UNZIP ku_TR.zip + :delete ku_TR.zip + :sys $VIM ku_TR.aff -u NONE -e -c "set ff=unix" -c update -c q + :sys $VIM ku_TR.dic -u NONE -e -c "set ff=unix" -c update -c q + :sys $VIM README_ku_TR.txt -u NONE -e -c "set ff=unix" -c update -c q + @if not os.path.exists('ku_TR.orig.aff'): + :copy ku_TR.aff ku_TR.orig.aff + @if not os.path.exists('ku_TR.orig.dic'): + :copy ku_TR.dic ku_TR.orig.dic + @if os.path.exists('ku_TR.diff'): + :sys patch <ku_TR.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 ku_TR.orig.aff ku_TR.aff >ku_TR.diff + :sys {force} diff -a -C 1 ku_TR.orig.dic ku_TR.dic >>ku_TR.diff + + +# Check for updated spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch ku_TR.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../ku_TR.zip + :sys {force} diff ../ku_TR.orig.aff ku_TR.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy ku_TR.aff ../ku_TR.new.aff + :sys {force} diff ../ku_TR.orig.dic ku_TR.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy ku_TR.dic ../ku_TR.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete ku_TR.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/la/la.diff b/share/vim/vim73/spell/la/la.diff similarity index 100% rename from share/vim/vim72/spell/la/la.diff rename to share/vim/vim73/spell/la/la.diff diff --git a/share/vim/vim73/spell/la/main.aap b/share/vim/vim73/spell/la/main.aap new file mode 100644 index 0000000000..d9815850bb --- /dev/null +++ b/share/vim/vim73/spell/la/main.aap @@ -0,0 +1,81 @@ +# Aap recipe for Latin Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = la.aff la.dic + +all: $SPELLDIR/la.latin1.spl $SPELLDIR/la.utf-8.spl ../README_la.txt + +# NOTE: the la_LN.ISO-8859-1 locale is not available on Ubuntu. +# Use the English one instead. + +$SPELLDIR/la.latin1.spl : $FILES + :sys env LANG=en_US.ISO-8859-1 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/la la" -c q + +$SPELLDIR/la.utf-8.spl : $FILES + :sys $VIM -u NONE -e -c "set enc=utf-8" + -c "mkspell! $SPELLDIR/la la" -c q + +../README_la.txt : README_la.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} la.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +la.aff la.dic: {buildcheck=} + :assertpkg unzip patch + :fetch la.zip + :sys $UNZIP la.zip + :delete la.zip + @if not os.path.exists('la.orig.aff'): + :copy la.aff la.orig.aff + @if not os.path.exists('la.orig.dic'): + :copy la.dic la.orig.dic + @if os.path.exists('la.diff'): + :sys patch <la.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 la.orig.aff la.aff >la.diff + :sys {force} diff -a -C 1 la.orig.dic la.dic >>la.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch la.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../la.zip + :sys {force} diff ../la.orig.aff la.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy la.aff ../la.new.aff + :sys {force} diff ../la.orig.dic la.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy la.dic ../la.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete la.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/lt/lt_LT.diff b/share/vim/vim73/spell/lt/lt_LT.diff similarity index 100% rename from share/vim/vim72/spell/lt/lt_LT.diff rename to share/vim/vim73/spell/lt/lt_LT.diff diff --git a/share/vim/vim72/spell/lt/main.aap b/share/vim/vim73/spell/lt/main.aap similarity index 100% rename from share/vim/vim72/spell/lt/main.aap rename to share/vim/vim73/spell/lt/main.aap diff --git a/share/vim/vim72/spell/lv/lv_LV.diff b/share/vim/vim73/spell/lv/lv_LV.diff similarity index 100% rename from share/vim/vim72/spell/lv/lv_LV.diff rename to share/vim/vim73/spell/lv/lv_LV.diff diff --git a/share/vim/vim73/spell/lv/main.aap b/share/vim/vim73/spell/lv/main.aap new file mode 100644 index 0000000000..460bd2b1f0 --- /dev/null +++ b/share/vim/vim73/spell/lv/main.aap @@ -0,0 +1,83 @@ +# Aap recipe for Latvian Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = lv_LV.aff lv_LV.dic + +# I don't have a Latvian locale, use Lithuanian instead. +all: $SPELLDIR/lv.iso-8859-13.spl $SPELLDIR/lv.utf-8.spl \ + ../README_lv.txt + +$SPELLDIR/lv.iso-8859-13.spl : $FILES + :sys env LANG=lt_LT.ISO8859-13 $VIM -u NONE -e -c "mkspell! $SPELLDIR/lv lv_LV" -c q + +$SPELLDIR/lv.utf-8.spl : $FILES + :sys env LANG=lt_LT.UTF-8 $VIM -u NONE -e -c "mkspell! $SPELLDIR/lv lv_LV" -c q + +../README_lv.txt: README_lv_LV.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} lv_LV.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +# This is a bit tricky, since the file name includes the date. +lv_LV.aff lv_LV.dic: {buildcheck=} + :assertpkg unzip patch + :fetch lv_LV.zip + :sys $UNZIP lv_LV.zip + :delete lv_LV.zip + :delete changelog.txt gpl.txt lin-lv_LV_add.sh win-lv_LV_add.bat + :sys $VIM lv_LV.aff -u NONE -e -N -c "%s/\r//" -c update -c q + :sys $VIM lv_LV.dic -u NONE -e -N -c "%s/\r//" -c update -c q + :sys $VIM README_lv_LV.txt -u NONE -e -c "set ff=unix" -c update -c q + @if not os.path.exists('lv_LV.orig.aff'): + :copy lv_LV.aff lv_LV.orig.aff + @if not os.path.exists('lv_LV.orig.dic'): + :copy lv_LV.dic lv_LV.orig.dic + @if os.path.exists('lv_LV.diff'): + :sys patch <lv_LV.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 lv_LV.orig.aff lv_LV.aff >lv_LV.diff + :sys {force} diff -a -C 1 lv_LV.orig.dic lv_LV.dic >>lv_LV.diff + + +# Check for updated spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch lv_LV.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../lv_LV.zip + :sys {force} diff ../lv_LV.orig.aff lv_LV.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy lv_LV.aff ../lv_LV.new.aff + :sys {force} diff ../lv_LV.orig.dic lv_LV.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy lv_LV.dic ../lv_LV.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete lv_LV.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim73/spell/main.aap b/share/vim/vim73/spell/main.aap new file mode 100644 index 0000000000..269c710bc3 --- /dev/null +++ b/share/vim/vim73/spell/main.aap @@ -0,0 +1,26 @@ +# Toplevel Aap recipe for Vim spell files +# +# Usage: +# aap generate all the .spl files +# aap diff create all the diff files + +# "hu" is at the end, because it takes a very long time. +LANG = af am bg br ca cs cy da de el en eo es fr fo ga gd gl he hr id it + ku la lt lv mg mi ms nb nl nn ny pl pt ro ru rw sk sl sv sw + tet th tl tn uk yi zu hu + +# TODO: +# Finnish doesn't work, the dictionary fi_FI.zip file contains hyphenation... + +diff: $*LANG/diff + :print Done. + +@for l in string.split(_no.LANG): + :child $l/main.aap + +# The existing .spl files need to be generated when the spell file format +# changes. Depending on the Vim executable does that, but results in doing it +# much too often. Generate a dummy .spl file and let the .spl depend on it, so +# that they are outdated when it changes. +:child check/main.aap +*.spl: check/check.latin1.spl diff --git a/share/vim/vim72/spell/mg/main.aap b/share/vim/vim73/spell/mg/main.aap similarity index 100% rename from share/vim/vim72/spell/mg/main.aap rename to share/vim/vim73/spell/mg/main.aap diff --git a/share/vim/vim72/spell/mg/mg_MG.diff b/share/vim/vim73/spell/mg/mg_MG.diff similarity index 100% rename from share/vim/vim72/spell/mg/mg_MG.diff rename to share/vim/vim73/spell/mg/mg_MG.diff diff --git a/share/vim/vim72/spell/mi/main.aap b/share/vim/vim73/spell/mi/main.aap similarity index 100% rename from share/vim/vim72/spell/mi/main.aap rename to share/vim/vim73/spell/mi/main.aap diff --git a/share/vim/vim72/spell/mi/mi_NZ.diff b/share/vim/vim73/spell/mi/mi_NZ.diff similarity index 100% rename from share/vim/vim72/spell/mi/mi_NZ.diff rename to share/vim/vim73/spell/mi/mi_NZ.diff diff --git a/share/vim/vim73/spell/ms/main.aap b/share/vim/vim73/spell/ms/main.aap new file mode 100644 index 0000000000..09bb3d15c9 --- /dev/null +++ b/share/vim/vim73/spell/ms/main.aap @@ -0,0 +1,81 @@ +# Aap recipe for Malay Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = ms_MY.aff ms_MY.dic + +# I do not have a Malay locale, use the Dutch one instead. +all: $SPELLDIR/ms.latin1.spl $SPELLDIR/ms.utf-8.spl ../README_ms.txt + +$SPELLDIR/ms.latin1.spl : $FILES + :sys env LANG=nl_NL.ISO8859-1 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/ms ms_MY" -c q + +$SPELLDIR/ms.utf-8.spl : $FILES + :sys env LANG=nl_NL.UTF-8 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/ms ms_MY" -c q + +../README_ms.txt : README_ms_MY.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} ms_MY.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +ms_MY.aff ms_MY.dic: {buildcheck=} + :assertpkg unzip patch + :fetch ms_MY.zip + :sys $UNZIP ms_MY.zip + :delete ms_MY.zip + :sys $VIM ms_MY.aff -u NONE -e -c "set ff=unix" -c update -c q + :sys $VIM ms_MY.dic -u NONE -e -c "set ff=unix" -c update -c q + @if not os.path.exists('ms_MY.orig.aff'): + :copy ms_MY.aff ms_MY.orig.aff + @if not os.path.exists('ms_MY.orig.dic'): + :copy ms_MY.dic ms_MY.orig.dic + @if os.path.exists('ms_MY.diff'): + :sys patch <ms_MY.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 ms_MY.orig.aff ms_MY.aff >ms_MY.diff + :sys {force} diff -a -C 1 ms_MY.orig.dic ms_MY.dic >>ms_MY.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch ms_MY.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../ms_MY.zip + :sys {force} diff ../ms_MY.orig.aff ms_MY.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy ms_MY.aff ../ms_MY.new.aff + :sys {force} diff ../ms_MY.orig.dic ms_MY.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy ms_MY.dic ../ms_MY.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete ms_MY.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/ms/ms_MY.diff b/share/vim/vim73/spell/ms/ms_MY.diff similarity index 100% rename from share/vim/vim72/spell/ms/ms_MY.diff rename to share/vim/vim73/spell/ms/ms_MY.diff diff --git a/share/vim/vim73/spell/nb/main.aap b/share/vim/vim73/spell/nb/main.aap new file mode 100644 index 0000000000..4d445c020d --- /dev/null +++ b/share/vim/vim73/spell/nb/main.aap @@ -0,0 +1,78 @@ +# Aap recipe for Dutch Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = nb_NO.aff nb_NO.dic + +all: $SPELLDIR/nb.latin1.spl $SPELLDIR/nb.utf-8.spl ../README_nb.txt + +$SPELLDIR/nb.latin1.spl : $FILES + :sys env LANG=nb_NO.ISO-8859-1 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/nb nb_NO" -c q + +$SPELLDIR/nb.utf-8.spl : $FILES + :sys env LANG=nb_NO.UTF-8 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/nb nb_NO" -c q + +../README_nb.txt : README_nb_NO.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} nb_NO.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +nb_NO.aff nb_NO.dic: {buildcheck=} + :assertpkg unzip patch + :fetch nb_NO.zip + :sys $UNZIP nb_NO.zip + :delete nb_NO.zip + @if not os.path.exists('nb_NO.orig.aff'): + :copy nb_NO.aff nb_NO.orig.aff + @if not os.path.exists('nb_NO.orig.dic'): + :copy nb_NO.dic nb_NO.orig.dic + @if os.path.exists('nb_NO.diff'): + :sys patch <nb_NO.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 nb_NO.orig.aff nb_NO.aff >nb_NO.diff + :sys {force} diff -a -C 1 nb_NO.orig.dic nb_NO.dic >>nb_NO.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch nb_NO.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../nb_NO.zip + :sys {force} diff ../nb_NO.orig.aff nb_NO.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy nb_NO.aff ../nb_NO.new.aff + :sys {force} diff ../nb_NO.orig.dic nb_NO.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy nb_NO.dic ../nb_NO.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete nb_NO.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/nb/nb_NO.diff b/share/vim/vim73/spell/nb/nb_NO.diff similarity index 100% rename from share/vim/vim72/spell/nb/nb_NO.diff rename to share/vim/vim73/spell/nb/nb_NO.diff diff --git a/share/vim/vim73/spell/nl/main.aap b/share/vim/vim73/spell/nl/main.aap new file mode 100644 index 0000000000..c3cae27e9f --- /dev/null +++ b/share/vim/vim73/spell/nl/main.aap @@ -0,0 +1,96 @@ +# Aap recipe for Dutch Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = nl_NL.aff nl_NL.dic + +all: $SPELLDIR/nl.latin1.spl $SPELLDIR/nl.utf-8.spl ../README_nl.txt + +$SPELLDIR/nl.latin1.spl : $FILES + :sys env LANG=nl_NL.ISO8859-1 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/nl nl_NL" -c q + +$SPELLDIR/nl.utf-8.spl : $FILES + :sys env LANG=nl_NL.UTF-8 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/nl nl_NL" -c q + +../README_nl.txt : README_NL.txt README_EN.txt + :cat $source >! $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://extensions.services.openoffice.org/e-files/1456/5 +:attr {fetch = $OODIR/%file%} nl-dict.oxt + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +nl_NL.aff nl_NL.dic: {buildcheck=} + :assertpkg unzip patch + :fetch nl-dict.oxt + :sys $UNZIP nl-dict.oxt + :update cleanunused + @if not os.path.exists('nl_NL.orig.aff'): + :copy nl_NL.aff nl_NL.orig.aff + @if not os.path.exists('nl_NL.orig.dic'): + :copy nl_NL.dic nl_NL.orig.dic + @if os.path.exists('nl_NL.diff'): + :sys patch <nl_NL.diff + +# Delete all the files unpacked from the archive +clean: cleanunused + :delete {f} nl_NL.dic + :delete {f} nl_NL.aff + :delete {f} README_EN.txt + :delete {f} README_NL.txt + +# Delete all the files from the archive that are not used, including the +# archive itself. +cleanunused: + :delete {f} nl-dict.oxt + :delete {f} description.xml + :delete {f} Dictionaries.xcu + :delete {f} hyph_nl_NL.dic + :delete {r}{f} description + :delete {r}{f} images + :delete {r}{f} META-INF + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 nl_NL.orig.aff nl_NL.aff >nl_NL.diff + :sys {force} diff -a -C 1 nl_NL.orig.dic nl_NL.dic >>nl_NL.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. +# Currently doesn't work. + +#check: +# :assertpkg unzip diff +# :fetch nl_NL.zip +# :mkdir tmp +# :cd tmp +# @try: +# @import stat +# :sys $UNZIP ../nl_NL.zip +# :sys {force} diff ../nl_NL.orig.aff nl_NL.aff >d +# @if os.stat('d')[stat.ST_SIZE] > 0: +# :copy nl_NL.aff ../nl_NL.new.aff +# :sys {force} diff ../nl_NL.orig.dic nl_NL.dic >d +# @if os.stat('d')[stat.ST_SIZE] > 0: +# :copy nl_NL.dic ../nl_NL.new.dic +# @finally: +# :cd .. +# :delete {r}{f}{q} tmp +# :delete nl_NL.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim73/spell/nl/nl_NL.diff b/share/vim/vim73/spell/nl/nl_NL.diff new file mode 100644 index 0000000000..4584a7ca67 --- /dev/null +++ b/share/vim/vim73/spell/nl/nl_NL.diff @@ -0,0 +1,228 @@ +*** nl_NL.orig.aff 2010-08-06 22:12:39.000000000 +0200 +--- nl_NL.aff 2010-08-08 16:31:46.000000000 +0200 +*************** +*** 1,9 **** + SET ISO8859-1 + TRY esianrtolcdugmphbyfvkwjkqxz-ëéèêïîäàâöüû'ESIANRTOLCDUGMPHBYFVKWJKQXZ + + # combined layout for BE and NL keyboards NL en BE +! KEY qwertyuiop|asdfghjkl|zxcvbnm|qawsedrftgyhujikolp|azsxdcfvgbhnjmk|aze|qsd|lm|wx|aqz|qws| + + # wordchars is (or is supposed to be) only for command line +! WORDCHARS ' + # . is not useful as wordchar +--- 1,23 ---- + SET ISO8859-1 ++ ++ NAME Nederlands ++ AUTHOR Various, edited by Bram Moolenaar ++ VERSION 1.1.2 ++ + TRY esianrtolcdugmphbyfvkwjkqxz-ëéèêïîäàâöüû'ESIANRTOLCDUGMPHBYFVKWJKQXZ + ++ FOL ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ ++ LOW ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ ++ UPP ßÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞÿ ++ ++ SOFOFROM abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþßÿÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞ¿ ++ SOFOTO ebctefghejklnnepkrstevvkesebctefghejklnnepkrstevvkeseeeeeeeceeeeeeeedneeeeeeeeeeepseeeeeeeeceeeeeeeedneeeeeeeeeeep? ++ ++ MIDWORD '- ++ + # combined layout for BE and NL keyboards NL en BE +! #KEY qwertyuiop|asdfghjkl|zxcvbnm|qawsedrftgyhujikolp|azsxdcfvgbhnjmk|aze|qsd|lm|wx|aqz|qws| + + # wordchars is (or is supposed to be) only for command line +! #WORDCHARS ' + # . is not useful as wordchar +*************** +*** 14,16 **** + # do not offer wplit words (English desease) +! NOSPLITSUGS + +--- 28,30 ---- + # do not offer wplit words (English desease) +! #NOSPLITSUGS + +*************** +*** 20,23 **** + # added to make this dictonary work on planned version 3.2 of OpenOffice.org too. +! BREAK 1 +! BREAK - + +--- 34,37 ---- + # added to make this dictonary work on planned version 3.2 of OpenOffice.org too. +! #BREAK 1 +! #BREAK - + +*************** +*** 186,193 **** + # make calculation of alternatives better for words with accents +! MAP 5 +! MAP eéèëê +! MAP aáà +! MAP iíìïî +! MAP oóòöô +! MAP uüúùû + +--- 200,217 ---- + # make calculation of alternatives better for words with accents +! #MAP 5 +! #MAP eéèëê +! #MAP aáà +! #MAP iíìïî +! #MAP oóòöô +! #MAP uüúùû +! MAP 9 +! MAP aàáâãäå +! MAP eèéêë +! MAP iìíîï +! MAP oòóôõö +! MAP uùúûü +! MAP nñ +! MAP cç +! MAP yÿý +! MAP sß + +*************** +*** 359,479 **** + REP aflassen afgelasten +- REP imho n.m.m. +- REP nmm n.m.m. + REP ff even +- REP AD A.D. +- REP DV D.V. +- REP HKH H.K.H. +- REP HM H.M. +- REP LB L.B. +- REP NB N.B. +- REP NH N.H. +- REP NN N.N. +- REP NO N.O. +- REP NV N.V. +- REP NW N.W. +- REP OLV O.L.V. +- REP RIP R.I.P. +- REP St- St.- +- REP St- St.- +- REP ZH Z.H. +- REP ZKH Z.K.H. +- REP ahw a.h.w. +- REP ajb a.j.b. +- REP am a.m. +- REP as a.s. +- REP aub a.u.b. +- REP bd b.d. +- REP bgg b.g.g. +- REP bvd b.v.d. +- REP cq c.q. +- REP cs c.s. +- REP ca ca. +- REP dd d.d. +- REP di d.i. +- REP dmv d.m.v. +- REP dwz d.w.z. +- REP ea e.a. +- REP ed e.d. +- REP eea e.e.a. +- REP eo e.o. +- REP ev e.v. +- REP eva e.v.a. +- REP ggd g.g.d. +- REP ic i.c. +- REP ie i.e. +- REP iha i.h.a. +- REP ihb i.h.b. +- REP im i.m. +- REP io i.o. +- REP iov i.o.v. +- REP ipv i.p.v. +- REP ism i.s.m. +- REP itt i.t.t. +- REP ivm i.v.m. +- REP izgst i.z.g.st. +- REP kk k.k. +- REP m m. +- REP maw m.a.w. +- REP mbt m.b.t. +- REP mbv m.b.v. +- REP mvg m.v.g. +- REP mi m.i. +- REP miv m.i.v. +- REP mm m.m. +- REP mn m.n. +- REP muv m.u.v. +- REP max max. +- REP mevr mevr. +- REP min min. +- REP mld mld. +- REP mln mln. +- REP mr mr. +- REP mw mw. +- REP nav n.a.v. +- REP notk n.o.t.k. +- REP nvt n.v.t. +- REP nl nl. +- REP nr nr. +- REP oa o.a. +- REP oi o.i. +- REP oid o.i.d. +- REP olv o.l.v. +- REP om o.m. +- REP ott o.t.t. +- REP ovt o.v.t. +- REP ovv o.v.v. +- REP p p. +- REP pm p.m. +- REP pp p.p. +- REP pw p.w. +- REP qed q.e.d. +- REP qq q.q. +- REP r-k r.-k. +- REP sj s.j. +- REP svp s.v.p. +- REP sr sr. +- REP tav t.a.v. +- REP tbv t.b.v. +- REP tgv t.g.v. +- REP tht t.h.t. +- REP tnv t.n.v. +- REP tov t.o.v. +- REP tw t.w. +- REP twv t.w.v. +- REP tzt t.z.t. +- REP vChr v.Chr. +- REP vd v.d. +- REP vh v.h. +- REP vtt v.t.t. +- REP vv v.v. +- REP vvt v.v.t. +- REP wo w.o. +- REP wvttk w.v.t.t.k. +- REP zg z.g. +- REP zgan z.g.a.n. +- REP zi z.i. +- REP zoz z.o.z. +- REP zsm z.s.m. + REP idd inderdaad +- REP etc etc. + REP enzo en_zo +--- 383,386 ---- +*************** +*** 481,486 **** + REP zn zijn +- REP enz enz. + REP ok oké + REP dr haar +- REP dr er + REP ondermeer onder_meer +--- 388,391 ---- +*************** +*** 508,509 **** + REP spercibo sperziebo +! REP voorzover voor_zover +\ No newline at end of file +--- 413,415 ---- + REP spercibo sperziebo +! REP voorzover voor_zover +! REP hopenlijk hopelijk diff --git a/share/vim/vim73/spell/nn/main.aap b/share/vim/vim73/spell/nn/main.aap new file mode 100644 index 0000000000..efb0812a4c --- /dev/null +++ b/share/vim/vim73/spell/nn/main.aap @@ -0,0 +1,78 @@ +# Aap recipe for Dutch Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = nn_NO.aff nn_NO.dic + +all: $SPELLDIR/nn.latin1.spl $SPELLDIR/nn.utf-8.spl ../README_nn.txt + +$SPELLDIR/nn.latin1.spl : $FILES + :sys env LANG=nb_NO.ISO-8859-1 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/nn nn_NO" -c q + +$SPELLDIR/nn.utf-8.spl : $FILES + :sys env LANG=nb_NO.UTF-8 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/nn nn_NO" -c q + +../README_nn.txt : README_nn_NO.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} nn_NO.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +nn_NO.aff nn_NO.dic: {buildcheck=} + :assertpkg unzip patch + :fetch nn_NO.zip + :sys $UNZIP nn_NO.zip + :delete nn_NO.zip + @if not os.path.exists('nn_NO.orig.aff'): + :copy nn_NO.aff nn_NO.orig.aff + @if not os.path.exists('nn_NO.orig.dic'): + :copy nn_NO.dic nn_NO.orig.dic + @if os.path.exists('nn_NO.diff'): + :sys patch <nn_NO.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 nn_NO.orig.aff nn_NO.aff >nn_NO.diff + :sys {force} diff -a -C 1 nn_NO.orig.dic nn_NO.dic >>nn_NO.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch nn_NO.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../nn_NO.zip + :sys {force} diff ../nn_NO.orig.aff nn_NO.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy nn_NO.aff ../nn_NO.new.aff + :sys {force} diff ../nn_NO.orig.dic nn_NO.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy nn_NO.dic ../nn_NO.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete nn_NO.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim72/spell/nn/nn_NO.diff b/share/vim/vim73/spell/nn/nn_NO.diff similarity index 100% rename from share/vim/vim72/spell/nn/nn_NO.diff rename to share/vim/vim73/spell/nn/nn_NO.diff diff --git a/share/vim/vim72/spell/ny/main.aap b/share/vim/vim73/spell/ny/main.aap similarity index 100% rename from share/vim/vim72/spell/ny/main.aap rename to share/vim/vim73/spell/ny/main.aap diff --git a/share/vim/vim72/spell/ny/ny_MW.diff b/share/vim/vim73/spell/ny/ny_MW.diff similarity index 100% rename from share/vim/vim72/spell/ny/ny_MW.diff rename to share/vim/vim73/spell/ny/ny_MW.diff diff --git a/share/vim/vim72/spell/pl/main.aap b/share/vim/vim73/spell/pl/main.aap similarity index 100% rename from share/vim/vim72/spell/pl/main.aap rename to share/vim/vim73/spell/pl/main.aap diff --git a/share/vim/vim72/spell/pl/pl_PL.diff b/share/vim/vim73/spell/pl/pl_PL.diff similarity index 100% rename from share/vim/vim72/spell/pl/pl_PL.diff rename to share/vim/vim73/spell/pl/pl_PL.diff diff --git a/share/vim/vim73/spell/pt/main.aap b/share/vim/vim73/spell/pt/main.aap new file mode 100644 index 0000000000..e54f9d5caf --- /dev/null +++ b/share/vim/vim73/spell/pt/main.aap @@ -0,0 +1,168 @@ +# Aap recipe for Portuguese Vim spell files. +# See ftp://ftp.vim.org/pub/vim/runtime/spell/README.txt + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = pt_PT.aff pt_PT.dic + pt_BR.aff pt_BR.dic + +# +# Fetching the pt_PT files from the Natura project. +# +PT_FNAME = oo3x-pt-PT.oxt +PT_DIR = http://extensions.services.openoffice.org/e-files/1196/5/$(PT_FNAME) +:attr {fetch = $PT_DIR} $PT_FNAME + +# +# Fetching the pt_BR files from BrOffice.org (Brazilian OOo). +# +BR_FNAME = Vero_pt_BR_V207AOC.oxt +BR_DIR = http://www.broffice.org/files/$(BR_FNAME) +:attr {fetch = $BR_DIR} $BR_FNAME + +all: $SPELLDIR/pt.latin1.spl $SPELLDIR/pt.utf-8.spl \ + ../README_pt.txt + +$SPELLDIR/pt.latin1.spl : $FILES + :sys env LANG=pt_PT.ISO-8859-1 LC_ALL=pt_PT.ISO-8859-1 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/pt pt_PT pt_BR" -c q + +$SPELLDIR/pt.utf-8.spl : $FILES + :sys env LANG=pt_PT.UTF-8 LC_ALL=pt_PT.UTF-8 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/pt pt_PT pt_BR" -c q + +../README_pt.txt: README_pt_PT.txt README_pt_BR.txt + :print pt_PT >!$target + :cat README_pt_PT.txt | :eval re.sub('\r', '', stdin) >>$target + :print =================================================== >>$target + :print pt_BR: >>$target + :cat README_pt_BR.txt | :eval re.sub('\r', '', stdin) >>$target + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +pt_PT.aff pt_PT.dic: {buildcheck=} + :assertpkg unzip patch + :fetch $PT_FNAME + :sys $UNZIP $PT_FNAME + :delete $PT_FNAME + :move dictionaries/pt_PT.dic . + :move dictionaries/pt_PT.aff . + :move dictionaries/README_pt_PT.txt . + :move dictionaries/COPYING COPYING_pt_PT.txt + :delete {r}{f} dictionaries + :delete {r}{f} META-INF + :delete {f} description.xml + :delete {f} dictionaries.xcu + :delete {f} LICENSES.txt + # Remove grammer items and the duplicates this causes + :sys $VIM pt_PT.dic -u NONE -e -c "%s/\t.*//" -c "2,$$ sort u" -c update -c q + :sys $VIM pt_PT.aff -u NONE -e -c "%s/\S\+=\S\+$$//" -c update -c q + @if not os.path.exists('pt_PT.orig.aff'): + :copy pt_PT.aff pt_PT.orig.aff + @if not os.path.exists('pt_PT.orig.dic'): + :copy pt_PT.dic pt_PT.orig.dic + @if os.path.exists('pt_PT.diff'): + :sys patch <pt_PT.diff + +pt_BR.aff pt_BR.dic: {buildcheck=} + :assertpkg unzip patch + :fetch $BR_FNAME + :sys $UNZIP $BR_FNAME + :delete $BR_FNAME + :delete {f} description.xml + :delete {f} dictionaries.xcu + :delete {f} hyph_pt_BR.dic + :delete {r}{f} META-INF + :delete {f} README_en.TXT + :delete {f} README_hyph_pt_BR.TXT + :sys $VIM README_pt_BR.TXT -u NONE -N -e -c "set ff=unix" -c update -c q + :move README_pt_BR.TXT README_pt_BR.txt + + :sys $VIM pt_BR.dic -u NONE -N -e -c "set ff=unix" -c update -c q + :sys $VIM pt_BR.aff -u NONE -N -e -c "set ff=unix" -c update -c q + @if not os.path.exists('pt_BR.orig.aff'): + :copy pt_BR.aff pt_BR.orig.aff + @if not os.path.exists('pt_BR.orig.dic'): + :copy pt_BR.dic pt_BR.orig.dic + @if os.path.exists('pt_BR.diff'): + :sys patch <pt_BR.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 pt_PT.orig.aff pt_PT.aff >pt_PT.diff + :sys {force} diff -a -C 1 pt_PT.orig.dic pt_PT.dic >>pt_PT.diff + :sys {force} diff -a -C 1 pt_BR.orig.aff pt_BR.aff >pt_BR.diff + :sys {force} diff -a -C 1 pt_BR.orig.dic pt_BR.dic >>pt_BR.diff + +# Delete all downloaded and generated files. +clean: clean_pt_BR clean_pt_PT + +clean_pt_BR: + :delete {f} pt_BR.aff + :delete {f} pt_BR.dic + :delete {f} pt_BR.orig.aff + :delete {f} pt_BR.orig.dic + :delete {f} README_pt_BR.txt + +clean_pt_PT: + :delete {f} pt_PT.aff + :delete {f} pt_PT.dic + :delete {f} pt_PT.orig.aff + :delete {f} pt_PT.orig.dic + :delete {f} README_pt_PT.txt + :delete {f} COPYING_pt_PT.txt + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. +# TO BE IMPLEMENTED + +check: check-pt check-br + +check-pt: + :assertpkg unzip diff + :fetch $PT_FNAME + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../$PT_FNAME + :sys {force} diff ../pt_PT.orig.aff pt_PT.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy pt_PT.aff ../pt_PT.new.aff + :sys {force} diff ../pt_PT.orig.dic pt_PT.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy pt_PT.dic ../pt_PT.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete $PT_FNAME + +check-br: + :assertpkg unzip diff + :fetch $BR_FNAME + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../$BR_FNAME + :sys {force} diff ../pt_BR.orig.aff pt_BR.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy pt_BR.aff ../pt_BR.new.aff + :sys {force} diff ../pt_BR.orig.dic pt_BR.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy pt_BR.dic ../pt_BR.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete $BR_FNAME + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim73/spell/pt/pt_BR.diff b/share/vim/vim73/spell/pt/pt_BR.diff new file mode 100644 index 0000000000..6ccf3f3d5b --- /dev/null +++ b/share/vim/vim73/spell/pt/pt_BR.diff @@ -0,0 +1,88 @@ +*** pt_BR.orig.aff 2010-08-11 22:50:41.000000000 +0200 +--- pt_BR.aff 2010-08-11 23:01:57.000000000 +0200 +*************** +*** 1,3 **** + SET ISO8859-1 +! TRY áàãâéêíóõôúüçesianrtolcdugmphbyfvkwjqxz + +--- 1,3 ---- + SET ISO8859-1 +! + +*************** +*** 13,14 **** +--- 13,32 ---- + ++ NAME Brazilian Portuguese ++ VERSION 2008-07-07V ++ HOME http://www.broffice.org/verortografico ++ AUTHOR Raimundo Santos Moura ++ EMAIL raimundomoura AT openoffice DOT org ++ AUTHOR Leonardo Ferreira Fontenelle ++ EMAIL leo DOT fontenelle AT gmail DOT org ++ COPYRIGHT LGPL ++ ++ ++ FOL ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ ++ LOW ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ ++ UPP ßÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞÿ ++ ++ ++ MIDWORD '-. ++ ++ + MAP 6 +*************** +*** 21,41 **** + +! BREAK 15 +! BREAK BREAK +! BREAK ^- +! BREAK -$ +! BREAK ^ex- +! BREAK ^Ex- +! BREAK ^EX- +! BREAK ^recém- +! BREAK ^Recém- +! BREAK ^RECÉM- +! BREAK ^pós- +! BREAK ^Pós- +! BREAK ^PÓS- +! BREAK ^pró- +! BREAK ^pró- +! BREAK ^PRÓ- + + # Número máximo de sugestões +! MAXNGRAMSUGS 12 + +--- 39,59 ---- + +! #BREAK 15 +! #BREAK BREAK +! #BREAK ^- +! #BREAK -$ +! #BREAK ^ex- +! #BREAK ^Ex- +! #BREAK ^EX- +! #BREAK ^recém- +! #BREAK ^Recém- +! #BREAK ^RECÉM- +! #BREAK ^pós- +! #BREAK ^Pós- +! #BREAK ^PÓS- +! #BREAK ^pró- +! #BREAK ^pró- +! #BREAK ^PRÓ- + + # Número máximo de sugestões +! #MAXNGRAMSUGS 12 + +*************** +*** 44,46 **** + +! WORDCHARS - + +--- 62,64 ---- + +! #WORDCHARS - + diff --git a/share/vim/vim73/spell/pt/pt_PT.diff b/share/vim/vim73/spell/pt/pt_PT.diff new file mode 100644 index 0000000000..88411a1360 --- /dev/null +++ b/share/vim/vim73/spell/pt/pt_PT.diff @@ -0,0 +1,45 @@ +*** pt_PT.orig.aff 2010-08-11 22:50:30.000000000 +0200 +--- pt_PT.aff 2010-08-11 22:50:30.000000000 +0200 +*************** +*** 1,6 **** + SET UTF-8 +! LANG pt_PT +! TRY aerisontcdmlupvgbfzáhçqjíxãóéêâúõACMPSBTELGRIFVDkHJONôywUKXZWQÁYÍÉàÓèÂÚ +! KEY qwertyuiop|asdfghjkl|zxcvbnm +! WORDCHARS - + +--- 1,10 ---- + SET UTF-8 +! #LANG pt_PT +! #TRY aerisontcdmlupvgbfzáhçqjíxãóéêâúõACMPSBTELGRIFVDkHJONôywUKXZWQÁYÍÉàÓèÂÚ +! #KEY qwertyuiop|asdfghjkl|zxcvbnm +! #WORDCHARS - +! +! FOL ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ +! LOW ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ +! UPP ßÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞÿ + +*************** +*** 1300,1312 **** + +! MAP 11 +! MAP aá +! MAP aã +! MAP aâ +! MAP eé +! MAP eê +! MAP ií + MAP cç +! MAP oó +! MAP oô +! MAP oõ +! MAP uú +--- 1304,1311 ---- + +! MAP 6 +! MAP aáãâAÁà+! MAP eéêEÉÊ +! MAP iíIÍ + MAP cç +! MAP oóõôOÓÕÔ +! MAP uúüUÚÜ diff --git a/share/vim/vim72/spell/ro/main.aap b/share/vim/vim73/spell/ro/main.aap similarity index 100% rename from share/vim/vim72/spell/ro/main.aap rename to share/vim/vim73/spell/ro/main.aap diff --git a/share/vim/vim72/spell/ro/ro_RO.diff b/share/vim/vim73/spell/ro/ro_RO.diff similarity index 100% rename from share/vim/vim72/spell/ro/ro_RO.diff rename to share/vim/vim73/spell/ro/ro_RO.diff diff --git a/share/vim/vim72/spell/ru/main.aap b/share/vim/vim73/spell/ru/main.aap similarity index 100% rename from share/vim/vim72/spell/ru/main.aap rename to share/vim/vim73/spell/ru/main.aap diff --git a/share/vim/vim72/spell/ru/ru_RU.diff b/share/vim/vim73/spell/ru/ru_RU.diff similarity index 100% rename from share/vim/vim72/spell/ru/ru_RU.diff rename to share/vim/vim73/spell/ru/ru_RU.diff diff --git a/share/vim/vim72/spell/ru/ru_YO.diff b/share/vim/vim73/spell/ru/ru_YO.diff similarity index 100% rename from share/vim/vim72/spell/ru/ru_YO.diff rename to share/vim/vim73/spell/ru/ru_YO.diff diff --git a/share/vim/vim72/spell/rw/main.aap b/share/vim/vim73/spell/rw/main.aap similarity index 100% rename from share/vim/vim72/spell/rw/main.aap rename to share/vim/vim73/spell/rw/main.aap diff --git a/share/vim/vim72/spell/rw/rw_RW.diff b/share/vim/vim73/spell/rw/rw_RW.diff similarity index 100% rename from share/vim/vim72/spell/rw/rw_RW.diff rename to share/vim/vim73/spell/rw/rw_RW.diff diff --git a/share/vim/vim72/spell/sk/main.aap b/share/vim/vim73/spell/sk/main.aap similarity index 100% rename from share/vim/vim72/spell/sk/main.aap rename to share/vim/vim73/spell/sk/main.aap diff --git a/share/vim/vim72/spell/sk/sk_SK.diff b/share/vim/vim73/spell/sk/sk_SK.diff similarity index 100% rename from share/vim/vim72/spell/sk/sk_SK.diff rename to share/vim/vim73/spell/sk/sk_SK.diff diff --git a/share/vim/vim72/spell/sl/main.aap b/share/vim/vim73/spell/sl/main.aap similarity index 100% rename from share/vim/vim72/spell/sl/main.aap rename to share/vim/vim73/spell/sl/main.aap diff --git a/share/vim/vim72/spell/sl/sl_SI.diff b/share/vim/vim73/spell/sl/sl_SI.diff similarity index 100% rename from share/vim/vim72/spell/sl/sl_SI.diff rename to share/vim/vim73/spell/sl/sl_SI.diff diff --git a/share/vim/vim73/spell/sv/main.aap b/share/vim/vim73/spell/sv/main.aap new file mode 100644 index 0000000000..536a0452ff --- /dev/null +++ b/share/vim/vim73/spell/sv/main.aap @@ -0,0 +1,93 @@ +# Aap recipe for Swedish Vim spell files. +# +# Maintainer: Mattias Winther <vim@mattias.winthernet.se> + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = sv_SE.aff sv_SE.dic + +all: $SPELLDIR/sv.latin1.spl $SPELLDIR/sv.utf-8.spl ../README_sv.txt + +$SPELLDIR/sv.latin1.spl : $FILES + :sys env LANG=sv_SE.ISO-8859-1 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/sv sv_SE" -c q + +$SPELLDIR/sv.utf-8.spl : $FILES + :sys env LANG=sv_SE.UTF-8 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/sv sv_SE" -c q + +../README_sv.txt : README_sv.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://extensions.services.openoffice.org/e-files/1080/7 +:attr {fetch = $OODIR/%file%} ooo_swedish_dict_1.43.oxt + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +sv_SE.aff sv_SE.dic: {buildcheck=} + :assertpkg unzip patch + :fetch ooo_swedish_dict_1.43.oxt + :sys $UNZIP ooo_swedish_dict_1.43.oxt + :delete ooo_swedish_dict_1.43.oxt + :delete {r} META-INF + :copy dictionaries/sv_SE.aff sv_SE.aff + :copy dictionaries/sv_SE.dic sv_SE.dic + :delete {r} dictionaries dictionaries.xcu description.xml + :delete {f} README_sv.txt + :sys $VIM README_sv.txt -u NONE -N -e -c "0read LICENSE_en_US.txt" -c "read LICENSE_sv_SE.txt" -c "set ff=unix" -c write -c q + :delete LICENSE_en_US.txt LICENSE_sv_SE.txt + @if not os.path.exists('sv_SE.orig.aff'): + :copy sv_SE.aff sv_SE.orig.aff + @if not os.path.exists('sv_SE.orig.dic'): + :copy sv_SE.dic sv_SE.orig.dic + @if os.path.exists('sv_SE.diff'): + :sys patch <sv_SE.diff + +# Delete all the generated files, start from scratch +clean: + :delete {f} sv_SE.aff sv_SE.dic + :delete {f} sv_SE.aff.orig sv_SE.dic.orig + :delete {f} sv_SE.orig.aff sv_SE.orig.dic + :delete {f} README_sv.txt + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 sv_SE.orig.aff sv_SE.aff >sv_SE.diff + :sys {force} diff -a -C 1 sv_SE.orig.dic sv_SE.dic >>sv_SE.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch ooo_swedish_dict_1.43.oxt + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../ooo_swedish_dict_1.43.oxt + :sys {force} diff ../sv_SE.orig.aff sv_SE.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy sv_SE.aff ../sv_SE.new.aff + :sys {force} diff ../sv_SE.orig.dic sv_SE.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy sv_SE.dic ../sv_SE.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete ooo_swedish_dict_1.43.oxt + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim73/spell/sv/sv_SE.diff b/share/vim/vim73/spell/sv/sv_SE.diff new file mode 100644 index 0000000000..3526175f4a --- /dev/null +++ b/share/vim/vim73/spell/sv/sv_SE.diff @@ -0,0 +1,205 @@ +*** sv_SE.orig.aff 2010-07-10 14:45:33.000000000 +0200 +--- sv_SE.aff 2010-07-11 17:42:38.000000000 +0200 +*************** +*** 6,7 **** +--- 6,21 ---- + NOSUGGEST ! ++ FOL ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ ++ LOW ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ ++ UPP ßÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞÿ ++ ++ MAP 9 ++ MAP aàáâãäå ++ MAP eèéêë ++ MAP iìíîï ++ MAP oòóôõö ++ MAP uùúûü ++ MAP nñ ++ MAP cç ++ MAP yÿý ++ MAP sß + +*************** +*** 649 **** +--- 663,763 ---- + SFX t el la/WXZ el ++ ++ # soundslike mapping from Aspell ++ # swedish_phonet.dat - Swedish phonetic transformation rules for aspell ++ # Copyright (C) 2000 Martin Norbäck <d95mback@dtek.chalmers.se> ++ # distributed under GNU GPL ++ # version 0.2 ++ ++ SAL & & ++ SAL @ @ ++ SAL ANG(EIYÄÖ)-^ ANI # förledet an- ska inte bli @-ljud ++ SAL AGNO6 AKNO # agnostiker osv. ++ SAL AG(IE)-6 AK # vokal+g(ie) ger ej j-ljud ++ SAL A A ++ SAL BB-< _ ++ SAL B P ++ SAL CCO- K # broccoli, piccolo ++ SAL CC KS # successiv, access, succé ++ SAL CH & # choklad osv. ++ SAL CK K # ck -> k som vanligt ++ SAL C(EIYÄÖ)-< S # c + mjuk vokal -> s ++ SAL C K # c + annat -> k ++ SAL DJ(UÄÖ)- I # djungel, djävel, adjö ++ SAL DD- _ ++ SAL D T ++ SAL EG(IE)-6 EK # vokal+g(ie) ger ej j-ljud ++ SAL E E ++ SAL É E ++ SAL FF F ++ SAL F F ++ SAL G(EIYÄÖ)-3 I # g+mjuk vokal ger j-ljud ++ SAL GG6 K ++ SAL GN @N # ugn, lugn... ++ SAL G K ++ SAL H(AOUÅEIYÄÖ)-^ H # h i början av ord hörs ++ SAL H(AUOÅEIYÄÖ)- _ # annars stumt framför vokal ++ SAL HJ I # hj->j (hjärta osv.) ++ SAL H H ++ SAL IG(IE)-6 IK # vokal+g(ie) ger ej j-ljud ++ SAL I I ++ SAL J I ++ SAL K(EIYÄÖ)-^ & # k+mjuk vokal ger sje-ljud ++ SAL KJ & # kjol ++ SAL K K ++ SAL LJU- I # ljuga, ljus ++ SAL LL- _ ++ SAL L L ++ SAL MM- _ ++ SAL M M ++ SAL NG6 @ ++ SAL NN- _ ++ SAL N N ++ SAL ORIGI8 ORKI # specialfall ++ SAL OG(IE)-6 OK # vokal+g(ie) ger ej j-ljud ++ SAL O O ++ SAL PROJEKT PRO&EKT # specialfall ++ SAL PSALT< SALT # specialfall ++ SAL PSALM< SALM # specialfall ++ SAL PP- _ ++ SAL P P ++ SAL Q K ++ SAL RGI$6 RGI # inget j i slutet ++ SAL RGA$6 RIA # här är det däremot j (arga,färga) ++ SAL RGE$6 RIE # här också (Norge, överge) ++ SAL RGS$ RIS # rgs i slutet ++ SAL RG$ RI # rg i slutet ++ SAL RD T # "blött" d ++ SAL RN N # "blött" n ++ SAL RT T # "blött" t ++ SAL RLD T # värld ++ SAL RL L # "blött" l ++ SAL RS & # sje-ljud (fars, gärsgård) ++ SAL RR- _ ++ SAL R R ++ SAL SS- _ ++ SAL SCHIZ6 SKITS # specialfall ++ SAL SCH6 & ++ SAL SKJ & # skjorta, skjuta ++ SAL SJ & # sje-ljud ++ SAL S S ++ SAL TION9^ TION # tionde ++ SAL TION6 &ON # station osv. ++ SAL TT- _ ++ SAL T T ++ SAL UG(IE)-6 UK # vokal+g(ie) ger ej j-ljud ++ SAL U U ++ SAL V F ++ SAL W F ++ SAL X9 KS ++ SAL YG(IE)-6 YK # vokal+g(ie) ger ej j-ljud ++ SAL Y I ++ SAL ZZ TS ++ SAL Z S ++ SAL ÅTTIO9 OTIO # specialfall (ej sje-ljud) ++ SAL ÅRTION9 ORTION # specialfall (r hörs) ++ SAL ÅG(IE)-6 OK # vokal+g(ie) ger ej j-ljud ++ SAL Å O ++ SAL ÄG(IE)-6 EK # vokal+g(ie) ger ej j-ljud ++ SAL Ä E ++ SAL ÖG(IE)-6 ÖK # vokal+g(ie) ger ej j-ljud ++ SAL Ö Ö +*** sv_SE.orig.dic 2010-07-10 14:45:33.000000000 +0200 +--- sv_SE.dic 2010-07-10 14:45:33.000000000 +0200 +*************** +*** 11786,11788 **** + DVD +! dvs + dväljas +--- 11786,11788 ---- + DVD +! #dvs Removed by Stefan. + dväljas +*************** +*** 31959,31960 **** +--- 31959,32024 ---- + korsning/ADGvY ++ ++ # Additions by Stefan: ++ SEK ++ adr. ++ anm. ++ art. ++ aug. ++ bl.a. ++ d.v.s. ++ dec. ++ dr ++ dvs. ++ e.Kr. ++ e.d. ++ enl. ++ etc. ++ f.Kr. ++ f.d. ++ f.n. ++ f.ö. ++ febr. ++ fig. ++ fil.kand. ++ fil.lic. ++ forts. ++ fr.o.m. ++ fre. ++ jan. ++ jfr ++ kap. ++ kl. ++ lör. ++ m.fl. ++ m.m. ++ max. ++ min. ++ mån. ++ ngn ++ ngt ++ nov. ++ nr. ++ o.s.v. ++ obs. ++ okt. ++ ons. ++ osv. ++ p.g.a. ++ resp. ++ s.k. ++ sept. ++ sön. ++ t.ex. ++ t.o.m. ++ tab. ++ tis. ++ tors. ++ u.a. ++ uppl. ++ utg. ++ v.g. ++ v.g.v. ++ vard. ++ vd ++ vol. + korsningsfri/OY diff --git a/share/vim/vim72/spell/sw/main.aap b/share/vim/vim73/spell/sw/main.aap similarity index 100% rename from share/vim/vim72/spell/sw/main.aap rename to share/vim/vim73/spell/sw/main.aap diff --git a/share/vim/vim72/spell/sw/sw_KE.diff b/share/vim/vim73/spell/sw/sw_KE.diff similarity index 100% rename from share/vim/vim72/spell/sw/sw_KE.diff rename to share/vim/vim73/spell/sw/sw_KE.diff diff --git a/share/vim/vim73/spell/tet/main.aap b/share/vim/vim73/spell/tet/main.aap new file mode 100644 index 0000000000..617c8a24eb --- /dev/null +++ b/share/vim/vim73/spell/tet/main.aap @@ -0,0 +1,79 @@ +# Aap recipe for Tetum Vim spell files. + +# Use a freshly compiled Vim if it exists. +@if os.path.exists('../../../src/vim'): + VIM = ../../../src/vim +@else: + :progsearch VIM vim + +SPELLDIR = .. +FILES = tet_ID.aff tet_ID.dic + +# I don't hava a Tetum locale, use the Dutch one instead. +all: $SPELLDIR/tet.latin1.spl $SPELLDIR/tet.utf-8.spl ../README_tet.txt + +$SPELLDIR/tet.latin1.spl : $FILES + :sys env LANG=nl_NL.ISO8859-1 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/tet tet_ID" -c q + +$SPELLDIR/tet.utf-8.spl : $FILES + :sys env LANG=nl_NL.UTF-8 + $VIM -u NONE -e -c "mkspell! $SPELLDIR/tet tet_ID" -c q + +../README_tet.txt : README_tet_ID.txt + :copy $source $target + +# +# Fetching the files from OpenOffice.org. +# +OODIR = http://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries +:attr {fetch = $OODIR/%file%} tet_ID.zip + +# The files don't depend on the .zip file so that we can delete it. +# Only download the zip file if the targets don't exist. +tet_ID.aff tet_ID.dic: {buildcheck=} + :assertpkg unzip patch + :fetch tet_ID.zip + :sys $UNZIP tet_ID.zip + :delete tet_ID.zip + @if not os.path.exists('tet_ID.orig.aff'): + :copy tet_ID.aff tet_ID.orig.aff + @if not os.path.exists('tet_ID.orig.dic'): + :copy tet_ID.dic tet_ID.orig.dic + @if os.path.exists('tet_ID.diff'): + :sys patch <tet_ID.diff + + +# Generate diff files, so that others can get the OpenOffice files and apply +# the diffs to get the Vim versions. + +diff: + :assertpkg diff + :sys {force} diff -a -C 1 tet_ID.orig.aff tet_ID.aff >tet_ID.diff + :sys {force} diff -a -C 1 tet_ID.orig.dic tet_ID.dic >>tet_ID.diff + + +# Check for updated OpenOffice spell files. When there are changes the +# ".new.aff" and ".new.dic" files are left behind for manual inspection. + +check: + :assertpkg unzip diff + :fetch tet_ID.zip + :mkdir tmp + :cd tmp + @try: + @import stat + :sys $UNZIP ../tet_ID.zip + :sys {force} diff ../tet_ID.orig.aff tet_ID.aff >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy tet_ID.aff ../tet_ID.new.aff + :sys {force} diff ../tet_ID.orig.dic tet_ID.dic >d + @if os.stat('d')[stat.ST_SIZE] > 0: + :copy tet_ID.dic ../tet_ID.new.dic + @finally: + :cd .. + :delete {r}{f}{q} tmp + :delete tet_ID.zip + + +# vim: set sts=4 sw=4 : diff --git a/share/vim/vim73/spell/tet/tet_ID.diff b/share/vim/vim73/spell/tet/tet_ID.diff new file mode 100644 index 0000000000..941121c883 --- /dev/null +++ b/share/vim/vim73/spell/tet/tet_ID.diff @@ -0,0 +1,26 @@ +*** tet_ID.orig.aff Wed Aug 31 21:14:37 2005 +--- tet_ID.aff Wed Aug 31 21:15:15 2005 +*************** +*** 19 **** +--- 19,39 ---- + TRY aineousrthlkmdbp'fTvgzLAINjSPEMéD-KHáóFRUBGJúOcíwxCWXVñãÁqêçZÓQyâÍ ++ ++ FOL ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ ++ LOW ßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ ++ UPP ßÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞÿ ++ ++ SOFOFROM abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþßÿÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞ¿ ++ SOFOTO ebctefghejklnnepkrstevvkesebctefghejklnnepkrstevvkeseeeeeeeceeeeeeeedneeeeeeeeeeepseeeeeeeeceeeeeeeedneeeeeeeeeeep? ++ ++ MIDWORD '- ++ ++ MAP 9 ++ MAP aàáâãäå ++ MAP eèéêë ++ MAP iìíîï ++ MAP oòóôõö ++ MAP uùúûü ++ MAP nñ ++ MAP cç ++ MAP yÿý ++ MAP sß diff --git a/share/vim/vim72/spell/th/main.aap b/share/vim/vim73/spell/th/main.aap similarity index 100% rename from share/vim/vim72/spell/th/main.aap rename to share/vim/vim73/spell/th/main.aap diff --git a/share/vim/vim72/spell/th/th.diff b/share/vim/vim73/spell/th/th.diff similarity index 100% rename from share/vim/vim72/spell/th/th.diff rename to share/vim/vim73/spell/th/th.diff diff --git a/share/vim/vim72/spell/tl/main.aap b/share/vim/vim73/spell/tl/main.aap similarity index 100% rename from share/vim/vim72/spell/tl/main.aap rename to share/vim/vim73/spell/tl/main.aap diff --git a/share/vim/vim72/spell/tl/tl_PH.diff b/share/vim/vim73/spell/tl/tl_PH.diff similarity index 100% rename from share/vim/vim72/spell/tl/tl_PH.diff rename to share/vim/vim73/spell/tl/tl_PH.diff diff --git a/share/vim/vim72/spell/tn/main.aap b/share/vim/vim73/spell/tn/main.aap similarity index 100% rename from share/vim/vim72/spell/tn/main.aap rename to share/vim/vim73/spell/tn/main.aap diff --git a/share/vim/vim72/spell/tn/tn_ZA.diff b/share/vim/vim73/spell/tn/tn_ZA.diff similarity index 100% rename from share/vim/vim72/spell/tn/tn_ZA.diff rename to share/vim/vim73/spell/tn/tn_ZA.diff diff --git a/share/vim/vim72/spell/uk/main.aap b/share/vim/vim73/spell/uk/main.aap similarity index 100% rename from share/vim/vim72/spell/uk/main.aap rename to share/vim/vim73/spell/uk/main.aap diff --git a/share/vim/vim72/spell/uk/uk_UA.diff b/share/vim/vim73/spell/uk/uk_UA.diff similarity index 100% rename from share/vim/vim72/spell/uk/uk_UA.diff rename to share/vim/vim73/spell/uk/uk_UA.diff diff --git a/share/vim/vim72/spell/yi.vim b/share/vim/vim73/spell/yi.vim similarity index 100% rename from share/vim/vim72/spell/yi.vim rename to share/vim/vim73/spell/yi.vim diff --git a/share/vim/vim72/spell/yi/README.txt b/share/vim/vim73/spell/yi/README.txt similarity index 100% rename from share/vim/vim72/spell/yi/README.txt rename to share/vim/vim73/spell/yi/README.txt diff --git a/share/vim/vim72/spell/yi/main.aap b/share/vim/vim73/spell/yi/main.aap similarity index 100% rename from share/vim/vim72/spell/yi/main.aap rename to share/vim/vim73/spell/yi/main.aap diff --git a/share/vim/vim72/spell/yi/yi.diff b/share/vim/vim73/spell/yi/yi.diff similarity index 100% rename from share/vim/vim72/spell/yi/yi.diff rename to share/vim/vim73/spell/yi/yi.diff diff --git a/share/vim/vim72/spell/yi/yi_tr.diff b/share/vim/vim73/spell/yi/yi_tr.diff similarity index 100% rename from share/vim/vim72/spell/yi/yi_tr.diff rename to share/vim/vim73/spell/yi/yi_tr.diff diff --git a/share/vim/vim72/spell/zu/main.aap b/share/vim/vim73/spell/zu/main.aap similarity index 100% rename from share/vim/vim72/spell/zu/main.aap rename to share/vim/vim73/spell/zu/main.aap diff --git a/share/vim/vim72/spell/zu/zu_ZA.diff b/share/vim/vim73/spell/zu/zu_ZA.diff similarity index 100% rename from share/vim/vim72/spell/zu/zu_ZA.diff rename to share/vim/vim73/spell/zu/zu_ZA.diff diff --git a/share/vim/vim73/synmenu.vim b/share/vim/vim73/synmenu.vim new file mode 100644 index 0000000000..92678d149c --- /dev/null +++ b/share/vim/vim73/synmenu.vim @@ -0,0 +1,586 @@ +" Vim support file to define the syntax selection menu +" This file is normally sourced from menu.vim. +" +" Maintainer: Bram Moolenaar <Bram@vim.org> +" Last Change: 2010 Jul 26 + +" Define the SetSyn function, used for the Syntax menu entries. +" Set 'filetype' and also 'syntax' if it is manually selected. +fun! SetSyn(name) + if a:name == "fvwm1" + let use_fvwm_1 = 1 + let use_fvwm_2 = 0 + let name = "fvwm" + elseif a:name == "fvwm2" + let use_fvwm_2 = 1 + let use_fvwm_1 = 0 + let name = "fvwm" + else + let name = a:name + endif + if !exists("s:syntax_menu_synonly") + exe "set ft=" . name + if exists("g:syntax_manual") + exe "set syn=" . name + endif + else + exe "set syn=" . name + endif +endfun + +" <> notation is used here, remove '<' from 'cpoptions' +let s:cpo_save = &cpo +set cpo&vim + +" The following menu items are generated by makemenu.vim. +" The Start Of The Syntax Menu + +an 50.10.100 &Syntax.AB.A2ps\ config :cal SetSyn("a2ps")<CR> +an 50.10.110 &Syntax.AB.Aap :cal SetSyn("aap")<CR> +an 50.10.120 &Syntax.AB.ABAP/4 :cal SetSyn("abap")<CR> +an 50.10.130 &Syntax.AB.Abaqus :cal SetSyn("abaqus")<CR> +an 50.10.140 &Syntax.AB.ABC\ music\ notation :cal SetSyn("abc")<CR> +an 50.10.150 &Syntax.AB.ABEL :cal SetSyn("abel")<CR> +an 50.10.160 &Syntax.AB.AceDB\ model :cal SetSyn("acedb")<CR> +an 50.10.170 &Syntax.AB.Ada :cal SetSyn("ada")<CR> +an 50.10.180 &Syntax.AB.AfLex :cal SetSyn("aflex")<CR> +an 50.10.190 &Syntax.AB.ALSA\ config :cal SetSyn("alsaconf")<CR> +an 50.10.200 &Syntax.AB.Altera\ AHDL :cal SetSyn("ahdl")<CR> +an 50.10.210 &Syntax.AB.Amiga\ DOS :cal SetSyn("amiga")<CR> +an 50.10.220 &Syntax.AB.AMPL :cal SetSyn("ampl")<CR> +an 50.10.230 &Syntax.AB.Ant\ build\ file :cal SetSyn("ant")<CR> +an 50.10.240 &Syntax.AB.ANTLR :cal SetSyn("antlr")<CR> +an 50.10.250 &Syntax.AB.Apache\ config :cal SetSyn("apache")<CR> +an 50.10.260 &Syntax.AB.Apache-style\ config :cal SetSyn("apachestyle")<CR> +an 50.10.270 &Syntax.AB.Applix\ ELF :cal SetSyn("elf")<CR> +an 50.10.280 &Syntax.AB.Arc\ Macro\ Language :cal SetSyn("aml")<CR> +an 50.10.290 &Syntax.AB.Arch\ inventory :cal SetSyn("arch")<CR> +an 50.10.300 &Syntax.AB.ART :cal SetSyn("art")<CR> +an 50.10.310 &Syntax.AB.ASP\ with\ VBScript :cal SetSyn("aspvbs")<CR> +an 50.10.320 &Syntax.AB.ASP\ with\ Perl :cal SetSyn("aspperl")<CR> +an 50.10.330 &Syntax.AB.Assembly.680x0 :cal SetSyn("asm68k")<CR> +an 50.10.340 &Syntax.AB.Assembly.Flat :cal SetSyn("fasm")<CR> +an 50.10.350 &Syntax.AB.Assembly.GNU :cal SetSyn("asm")<CR> +an 50.10.360 &Syntax.AB.Assembly.GNU\ H-8300 :cal SetSyn("asmh8300")<CR> +an 50.10.370 &Syntax.AB.Assembly.Intel\ IA-64 :cal SetSyn("ia64")<CR> +an 50.10.380 &Syntax.AB.Assembly.Microsoft :cal SetSyn("masm")<CR> +an 50.10.390 &Syntax.AB.Assembly.Netwide :cal SetSyn("nasm")<CR> +an 50.10.400 &Syntax.AB.Assembly.PIC :cal SetSyn("pic")<CR> +an 50.10.410 &Syntax.AB.Assembly.Turbo :cal SetSyn("tasm")<CR> +an 50.10.420 &Syntax.AB.Assembly.VAX\ Macro\ Assembly :cal SetSyn("vmasm")<CR> +an 50.10.430 &Syntax.AB.Assembly.Z-80 :cal SetSyn("z8a")<CR> +an 50.10.440 &Syntax.AB.Assembly.xa\ 6502\ cross\ assember :cal SetSyn("a65")<CR> +an 50.10.450 &Syntax.AB.ASN\.1 :cal SetSyn("asn")<CR> +an 50.10.460 &Syntax.AB.Asterisk\ config :cal SetSyn("asterisk")<CR> +an 50.10.470 &Syntax.AB.Asterisk\ voicemail\ config :cal SetSyn("asteriskvm")<CR> +an 50.10.480 &Syntax.AB.Atlas :cal SetSyn("atlas")<CR> +an 50.10.490 &Syntax.AB.AutoHotKey :cal SetSyn("autohotkey")<CR> +an 50.10.500 &Syntax.AB.AutoIt :cal SetSyn("autoit")<CR> +an 50.10.510 &Syntax.AB.Automake :cal SetSyn("automake")<CR> +an 50.10.520 &Syntax.AB.Avenue :cal SetSyn("ave")<CR> +an 50.10.530 &Syntax.AB.Awk :cal SetSyn("awk")<CR> +an 50.10.540 &Syntax.AB.AYacc :cal SetSyn("ayacc")<CR> +an 50.10.560 &Syntax.AB.B :cal SetSyn("b")<CR> +an 50.10.570 &Syntax.AB.Baan :cal SetSyn("baan")<CR> +an 50.10.580 &Syntax.AB.Basic.FreeBasic :cal SetSyn("freebasic")<CR> +an 50.10.590 &Syntax.AB.Basic.IBasic :cal SetSyn("ibasic")<CR> +an 50.10.600 &Syntax.AB.Basic.QBasic :cal SetSyn("basic")<CR> +an 50.10.610 &Syntax.AB.Basic.Visual\ Basic :cal SetSyn("vb")<CR> +an 50.10.620 &Syntax.AB.Bazaar\ commit\ file :cal SetSyn("bzr")<CR> +an 50.10.630 &Syntax.AB.BC\ calculator :cal SetSyn("bc")<CR> +an 50.10.640 &Syntax.AB.BDF\ font :cal SetSyn("bdf")<CR> +an 50.10.650 &Syntax.AB.BibTeX.Bibliography\ database :cal SetSyn("bib")<CR> +an 50.10.660 &Syntax.AB.BibTeX.Bibliography\ Style :cal SetSyn("bst")<CR> +an 50.10.670 &Syntax.AB.BIND.BIND\ config :cal SetSyn("named")<CR> +an 50.10.680 &Syntax.AB.BIND.BIND\ zone :cal SetSyn("bindzone")<CR> +an 50.10.690 &Syntax.AB.Blank :cal SetSyn("blank")<CR> +an 50.20.100 &Syntax.C.C :cal SetSyn("c")<CR> +an 50.20.110 &Syntax.C.C++ :cal SetSyn("cpp")<CR> +an 50.20.120 &Syntax.C.C# :cal SetSyn("cs")<CR> +an 50.20.130 &Syntax.C.Cabal\ Haskell\ build\ file :cal SetSyn("cabal")<CR> +an 50.20.140 &Syntax.C.Calendar :cal SetSyn("calendar")<CR> +an 50.20.150 &Syntax.C.Cascading\ Style\ Sheets :cal SetSyn("css")<CR> +an 50.20.160 &Syntax.C.CDL :cal SetSyn("cdl")<CR> +an 50.20.170 &Syntax.C.Cdrdao\ TOC :cal SetSyn("cdrtoc")<CR> +an 50.20.180 &Syntax.C.Cdrdao\ config :cal SetSyn("cdrdaoconf")<CR> +an 50.20.190 &Syntax.C.Century\ Term :cal SetSyn("cterm")<CR> +an 50.20.200 &Syntax.C.CH\ script :cal SetSyn("ch")<CR> +an 50.20.210 &Syntax.C.ChaiScript :cal SetSyn("chaiscript")<CR> +an 50.20.220 &Syntax.C.ChangeLog :cal SetSyn("changelog")<CR> +an 50.20.230 &Syntax.C.Cheetah\ template :cal SetSyn("cheetah")<CR> +an 50.20.240 &Syntax.C.CHILL :cal SetSyn("chill")<CR> +an 50.20.250 &Syntax.C.ChordPro :cal SetSyn("chordpro")<CR> +an 50.20.260 &Syntax.C.Clean :cal SetSyn("clean")<CR> +an 50.20.270 &Syntax.C.Clever :cal SetSyn("cl")<CR> +an 50.20.280 &Syntax.C.Clipper :cal SetSyn("clipper")<CR> +an 50.20.290 &Syntax.C.Cmake :cal SetSyn("cmake")<CR> +an 50.20.300 &Syntax.C.Cmusrc :cal SetSyn("cmusrc")<CR> +an 50.20.310 &Syntax.C.Cobol :cal SetSyn("cobol")<CR> +an 50.20.320 &Syntax.C.Coco/R :cal SetSyn("coco")<CR> +an 50.20.330 &Syntax.C.Cold\ Fusion :cal SetSyn("cf")<CR> +an 50.20.340 &Syntax.C.Conary\ Recipe :cal SetSyn("conaryrecipe")<CR> +an 50.20.350 &Syntax.C.Config.Cfg\ Config\ file :cal SetSyn("cfg")<CR> +an 50.20.360 &Syntax.C.Config.Configure\.in :cal SetSyn("config")<CR> +an 50.20.370 &Syntax.C.Config.Generic\ Config\ file :cal SetSyn("conf")<CR> +an 50.20.380 &Syntax.C.CRM114 :cal SetSyn("crm")<CR> +an 50.20.390 &Syntax.C.Crontab :cal SetSyn("crontab")<CR> +an 50.20.400 &Syntax.C.CSP :cal SetSyn("csp")<CR> +an 50.20.410 &Syntax.C.Ctrl-H :cal SetSyn("ctrlh")<CR> +an 50.20.420 &Syntax.C.Cucumber :cal SetSyn("cucumber")<CR> +an 50.20.430 &Syntax.C.CUDA :cal SetSyn("cuda")<CR> +an 50.20.440 &Syntax.C.CUPL.CUPL :cal SetSyn("cupl")<CR> +an 50.20.450 &Syntax.C.CUPL.Simulation :cal SetSyn("cuplsim")<CR> +an 50.20.460 &Syntax.C.CVS.commit\ file :cal SetSyn("cvs")<CR> +an 50.20.470 &Syntax.C.CVS.cvsrc :cal SetSyn("cvsrc")<CR> +an 50.20.480 &Syntax.C.Cyn++ :cal SetSyn("cynpp")<CR> +an 50.20.490 &Syntax.C.Cynlib :cal SetSyn("cynlib")<CR> +an 50.30.100 &Syntax.DE.D :cal SetSyn("d")<CR> +an 50.30.110 &Syntax.DE.Datascript :cal SetSyn("datascript")<CR> +an 50.30.120 &Syntax.DE.Debian.Debian\ ChangeLog :cal SetSyn("debchangelog")<CR> +an 50.30.130 &Syntax.DE.Debian.Debian\ Control :cal SetSyn("debcontrol")<CR> +an 50.30.140 &Syntax.DE.Debian.Debian\ Sources\.list :cal SetSyn("debsources")<CR> +an 50.30.150 &Syntax.DE.Denyhosts :cal SetSyn("denyhosts")<CR> +an 50.30.160 &Syntax.DE.Desktop :cal SetSyn("desktop")<CR> +an 50.30.170 &Syntax.DE.Dict\ config :cal SetSyn("dictconf")<CR> +an 50.30.180 &Syntax.DE.Dictd\ config :cal SetSyn("dictdconf")<CR> +an 50.30.190 &Syntax.DE.Diff :cal SetSyn("diff")<CR> +an 50.30.200 &Syntax.DE.Digital\ Command\ Lang :cal SetSyn("dcl")<CR> +an 50.30.210 &Syntax.DE.Dircolors :cal SetSyn("dircolors")<CR> +an 50.30.220 &Syntax.DE.Django\ template :cal SetSyn("django")<CR> +an 50.30.230 &Syntax.DE.DNS/BIND\ zone :cal SetSyn("bindzone")<CR> +an 50.30.240 &Syntax.DE.DocBook.auto-detect :cal SetSyn("docbk")<CR> +an 50.30.250 &Syntax.DE.DocBook.SGML :cal SetSyn("docbksgml")<CR> +an 50.30.260 &Syntax.DE.DocBook.XML :cal SetSyn("docbkxml")<CR> +an 50.30.270 &Syntax.DE.Dot :cal SetSyn("dot")<CR> +an 50.30.280 &Syntax.DE.Doxygen.C\ with\ doxygen :cal SetSyn("c.doxygen")<CR> +an 50.30.290 &Syntax.DE.Doxygen.C++\ with\ doxygen :cal SetSyn("cpp.doxygen")<CR> +an 50.30.300 &Syntax.DE.Doxygen.IDL\ with\ doxygen :cal SetSyn("idl.doxygen")<CR> +an 50.30.310 &Syntax.DE.Doxygen.Java\ with\ doxygen :cal SetSyn("java.doxygen")<CR> +an 50.30.320 &Syntax.DE.Dracula :cal SetSyn("dracula")<CR> +an 50.30.330 &Syntax.DE.DSSSL :cal SetSyn("dsl")<CR> +an 50.30.340 &Syntax.DE.DTD :cal SetSyn("dtd")<CR> +an 50.30.350 &Syntax.DE.DTML\ (Zope) :cal SetSyn("dtml")<CR> +an 50.30.360 &Syntax.DE.DTrace :cal SetSyn("dtrace")<CR> +an 50.30.370 &Syntax.DE.Dylan.Dylan :cal SetSyn("dylan")<CR> +an 50.30.380 &Syntax.DE.Dylan.Dylan\ interface :cal SetSyn("dylanintr")<CR> +an 50.30.390 &Syntax.DE.Dylan.Dylan\ lid :cal SetSyn("dylanlid")<CR> +an 50.30.410 &Syntax.DE.EDIF :cal SetSyn("edif")<CR> +an 50.30.420 &Syntax.DE.Eiffel :cal SetSyn("eiffel")<CR> +an 50.30.430 &Syntax.DE.Elinks\ config :cal SetSyn("elinks")<CR> +an 50.30.440 &Syntax.DE.Elm\ filter\ rules :cal SetSyn("elmfilt")<CR> +an 50.30.450 &Syntax.DE.Embedix\ Component\ Description :cal SetSyn("ecd")<CR> +an 50.30.460 &Syntax.DE.ERicsson\ LANGuage :cal SetSyn("erlang")<CR> +an 50.30.470 &Syntax.DE.ESMTP\ rc :cal SetSyn("esmtprc")<CR> +an 50.30.480 &Syntax.DE.ESQL-C :cal SetSyn("esqlc")<CR> +an 50.30.490 &Syntax.DE.Essbase\ script :cal SetSyn("csc")<CR> +an 50.30.500 &Syntax.DE.Esterel :cal SetSyn("esterel")<CR> +an 50.30.510 &Syntax.DE.Eterm\ config :cal SetSyn("eterm")<CR> +an 50.30.520 &Syntax.DE.Eviews :cal SetSyn("eviews")<CR> +an 50.30.530 &Syntax.DE.Exim\ conf :cal SetSyn("exim")<CR> +an 50.30.540 &Syntax.DE.Expect :cal SetSyn("expect")<CR> +an 50.30.550 &Syntax.DE.Exports :cal SetSyn("exports")<CR> +an 50.40.100 &Syntax.FG.Fantom :cal SetSyn("fan")<CR> +an 50.40.110 &Syntax.FG.Fetchmail :cal SetSyn("fetchmail")<CR> +an 50.40.120 &Syntax.FG.FlexWiki :cal SetSyn("flexwiki")<CR> +an 50.40.130 &Syntax.FG.Focus\ Executable :cal SetSyn("focexec")<CR> +an 50.40.140 &Syntax.FG.Focus\ Master :cal SetSyn("master")<CR> +an 50.40.150 &Syntax.FG.FORM :cal SetSyn("form")<CR> +an 50.40.160 &Syntax.FG.Forth :cal SetSyn("forth")<CR> +an 50.40.170 &Syntax.FG.Fortran :cal SetSyn("fortran")<CR> +an 50.40.180 &Syntax.FG.FoxPro :cal SetSyn("foxpro")<CR> +an 50.40.190 &Syntax.FG.FrameScript :cal SetSyn("framescript")<CR> +an 50.40.200 &Syntax.FG.Fstab :cal SetSyn("fstab")<CR> +an 50.40.210 &Syntax.FG.Fvwm.Fvwm\ configuration :cal SetSyn("fvwm1")<CR> +an 50.40.220 &Syntax.FG.Fvwm.Fvwm2\ configuration :cal SetSyn("fvwm2")<CR> +an 50.40.230 &Syntax.FG.Fvwm.Fvwm2\ configuration\ with\ M4 :cal SetSyn("fvwm2m4")<CR> +an 50.40.250 &Syntax.FG.GDB\ command\ file :cal SetSyn("gdb")<CR> +an 50.40.260 &Syntax.FG.GDMO :cal SetSyn("gdmo")<CR> +an 50.40.270 &Syntax.FG.Gedcom :cal SetSyn("gedcom")<CR> +an 50.40.280 &Syntax.FG.Git.Output :cal SetSyn("git")<CR> +an 50.40.290 &Syntax.FG.Git.Commit :cal SetSyn("gitcommit")<CR> +an 50.40.300 &Syntax.FG.Git.Config :cal SetSyn("gitconfig")<CR> +an 50.40.310 &Syntax.FG.Git.Rebase :cal SetSyn("gitrebase")<CR> +an 50.40.320 &Syntax.FG.Git.Send\ Email :cal SetSyn("gitsendemail")<CR> +an 50.40.330 &Syntax.FG.Gkrellmrc :cal SetSyn("gkrellmrc")<CR> +an 50.40.340 &Syntax.FG.GP :cal SetSyn("gp")<CR> +an 50.40.350 &Syntax.FG.GPG :cal SetSyn("gpg")<CR> +an 50.40.360 &Syntax.FG.Group\ file :cal SetSyn("group")<CR> +an 50.40.370 &Syntax.FG.Grub :cal SetSyn("grub")<CR> +an 50.40.380 &Syntax.FG.GNU\ Server\ Pages :cal SetSyn("gsp")<CR> +an 50.40.390 &Syntax.FG.GNUplot :cal SetSyn("gnuplot")<CR> +an 50.40.400 &Syntax.FG.GrADS\ scripts :cal SetSyn("grads")<CR> +an 50.40.410 &Syntax.FG.Gretl :cal SetSyn("gretl")<CR> +an 50.40.420 &Syntax.FG.Groff :cal SetSyn("groff")<CR> +an 50.40.430 &Syntax.FG.Groovy :cal SetSyn("groovy")<CR> +an 50.40.440 &Syntax.FG.GTKrc :cal SetSyn("gtkrc")<CR> +an 50.50.100 &Syntax.HIJK.Haml :cal SetSyn("haml")<CR> +an 50.50.110 &Syntax.HIJK.Hamster :cal SetSyn("hamster")<CR> +an 50.50.120 &Syntax.HIJK.Haskell.Haskell :cal SetSyn("haskell")<CR> +an 50.50.130 &Syntax.HIJK.Haskell.Haskell-c2hs :cal SetSyn("chaskell")<CR> +an 50.50.140 &Syntax.HIJK.Haskell.Haskell-literate :cal SetSyn("lhaskell")<CR> +an 50.50.150 &Syntax.HIJK.HASTE :cal SetSyn("haste")<CR> +an 50.50.160 &Syntax.HIJK.HASTE\ preproc :cal SetSyn("hastepreproc")<CR> +an 50.50.170 &Syntax.HIJK.Hercules :cal SetSyn("hercules")<CR> +an 50.50.180 &Syntax.HIJK.Hex\ dump.XXD :cal SetSyn("xxd")<CR> +an 50.50.190 &Syntax.HIJK.Hex\ dump.Intel\ MCS51 :cal SetSyn("hex")<CR> +an 50.50.200 &Syntax.HIJK.HTML.HTML :cal SetSyn("html")<CR> +an 50.50.210 &Syntax.HIJK.HTML.HTML\ with\ M4 :cal SetSyn("htmlm4")<CR> +an 50.50.220 &Syntax.HIJK.HTML.HTML\ with\ Ruby\ (eRuby) :cal SetSyn("eruby")<CR> +an 50.50.230 &Syntax.HIJK.HTML.Cheetah\ HTML\ template :cal SetSyn("htmlcheetah")<CR> +an 50.50.240 &Syntax.HIJK.HTML.Django\ HTML\ template :cal SetSyn("htmldjango")<CR> +an 50.50.250 &Syntax.HIJK.HTML.HTML/OS :cal SetSyn("htmlos")<CR> +an 50.50.260 &Syntax.HIJK.HTML.XHTML :cal SetSyn("xhtml")<CR> +an 50.50.270 &Syntax.HIJK.Host\.conf :cal SetSyn("hostconf")<CR> +an 50.50.280 &Syntax.HIJK.Hyper\ Builder :cal SetSyn("hb")<CR> +an 50.50.300 &Syntax.HIJK.Icewm\ menu :cal SetSyn("icemenu")<CR> +an 50.50.310 &Syntax.HIJK.Icon :cal SetSyn("icon")<CR> +an 50.50.320 &Syntax.HIJK.IDL\Generic\ IDL :cal SetSyn("idl")<CR> +an 50.50.330 &Syntax.HIJK.IDL\Microsoft\ IDL :cal SetSyn("msidl")<CR> +an 50.50.340 &Syntax.HIJK.Indent\ profile :cal SetSyn("indent")<CR> +an 50.50.350 &Syntax.HIJK.Inform :cal SetSyn("inform")<CR> +an 50.50.360 &Syntax.HIJK.Informix\ 4GL :cal SetSyn("fgl")<CR> +an 50.50.370 &Syntax.HIJK.Initng :cal SetSyn("initng")<CR> +an 50.50.380 &Syntax.HIJK.Inittab :cal SetSyn("inittab")<CR> +an 50.50.390 &Syntax.HIJK.Inno\ setup :cal SetSyn("iss")<CR> +an 50.50.400 &Syntax.HIJK.InstallShield\ script :cal SetSyn("ishd")<CR> +an 50.50.410 &Syntax.HIJK.Interactive\ Data\ Lang :cal SetSyn("idlang")<CR> +an 50.50.420 &Syntax.HIJK.IPfilter :cal SetSyn("ipfilter")<CR> +an 50.50.440 &Syntax.HIJK.JAL :cal SetSyn("jal")<CR> +an 50.50.450 &Syntax.HIJK.JAM :cal SetSyn("jam")<CR> +an 50.50.460 &Syntax.HIJK.Jargon :cal SetSyn("jargon")<CR> +an 50.50.470 &Syntax.HIJK.Java.Java :cal SetSyn("java")<CR> +an 50.50.480 &Syntax.HIJK.Java.JavaCC :cal SetSyn("javacc")<CR> +an 50.50.490 &Syntax.HIJK.Java.Java\ Server\ Pages :cal SetSyn("jsp")<CR> +an 50.50.500 &Syntax.HIJK.Java.Java\ Properties :cal SetSyn("jproperties")<CR> +an 50.50.510 &Syntax.HIJK.JavaScript :cal SetSyn("javascript")<CR> +an 50.50.520 &Syntax.HIJK.Jess :cal SetSyn("jess")<CR> +an 50.50.530 &Syntax.HIJK.Jgraph :cal SetSyn("jgraph")<CR> +an 50.50.550 &Syntax.HIJK.Kconfig :cal SetSyn("kconfig")<CR> +an 50.50.560 &Syntax.HIJK.KDE\ script :cal SetSyn("kscript")<CR> +an 50.50.570 &Syntax.HIJK.Kimwitu++ :cal SetSyn("kwt")<CR> +an 50.50.580 &Syntax.HIJK.KixTart :cal SetSyn("kix")<CR> +an 50.60.100 &Syntax.L.Lace :cal SetSyn("lace")<CR> +an 50.60.110 &Syntax.L.LamdaProlog :cal SetSyn("lprolog")<CR> +an 50.60.120 &Syntax.L.Latte :cal SetSyn("latte")<CR> +an 50.60.130 &Syntax.L.Ld\ script :cal SetSyn("ld")<CR> +an 50.60.140 &Syntax.L.LDAP.LDIF :cal SetSyn("ldif")<CR> +an 50.60.150 &Syntax.L.LDAP.Configuration :cal SetSyn("ldapconf")<CR> +an 50.60.160 &Syntax.L.Lex :cal SetSyn("lex")<CR> +an 50.60.170 &Syntax.L.LFTP\ config :cal SetSyn("lftp")<CR> +an 50.60.180 &Syntax.L.Libao :cal SetSyn("libao")<CR> +an 50.60.190 &Syntax.L.LifeLines\ script :cal SetSyn("lifelines")<CR> +an 50.60.200 &Syntax.L.Lilo :cal SetSyn("lilo")<CR> +an 50.60.210 &Syntax.L.Limits\ config :cal SetSyn("limits")<CR> +an 50.60.220 &Syntax.L.Linden\ scripting :cal SetSyn("lsl")<CR> +an 50.60.230 &Syntax.L.Liquid :cal SetSyn("liquid")<CR> +an 50.60.240 &Syntax.L.Lisp :cal SetSyn("lisp")<CR> +an 50.60.250 &Syntax.L.Lite :cal SetSyn("lite")<CR> +an 50.60.260 &Syntax.L.LiteStep\ RC :cal SetSyn("litestep")<CR> +an 50.60.270 &Syntax.L.Locale\ Input :cal SetSyn("fdcc")<CR> +an 50.60.280 &Syntax.L.Login\.access :cal SetSyn("loginaccess")<CR> +an 50.60.290 &Syntax.L.Login\.defs :cal SetSyn("logindefs")<CR> +an 50.60.300 &Syntax.L.Logtalk :cal SetSyn("logtalk")<CR> +an 50.60.310 &Syntax.L.LOTOS :cal SetSyn("lotos")<CR> +an 50.60.320 &Syntax.L.LotusScript :cal SetSyn("lscript")<CR> +an 50.60.330 &Syntax.L.Lout :cal SetSyn("lout")<CR> +an 50.60.340 &Syntax.L.LPC :cal SetSyn("lpc")<CR> +an 50.60.350 &Syntax.L.Lua :cal SetSyn("lua")<CR> +an 50.60.360 &Syntax.L.Lynx\ Style :cal SetSyn("lss")<CR> +an 50.60.370 &Syntax.L.Lynx\ config :cal SetSyn("lynx")<CR> +an 50.70.100 &Syntax.M.M4 :cal SetSyn("m4")<CR> +an 50.70.110 &Syntax.M.MaGic\ Point :cal SetSyn("mgp")<CR> +an 50.70.120 &Syntax.M.Mail :cal SetSyn("mail")<CR> +an 50.70.130 &Syntax.M.Mail\ aliases :cal SetSyn("mailaliases")<CR> +an 50.70.140 &Syntax.M.Mailcap :cal SetSyn("mailcap")<CR> +an 50.70.150 &Syntax.M.Makefile :cal SetSyn("make")<CR> +an 50.70.160 &Syntax.M.MakeIndex :cal SetSyn("ist")<CR> +an 50.70.170 &Syntax.M.Man\ page :cal SetSyn("man")<CR> +an 50.70.180 &Syntax.M.Man\.conf :cal SetSyn("manconf")<CR> +an 50.70.190 &Syntax.M.Maple\ V :cal SetSyn("maple")<CR> +an 50.70.200 &Syntax.M.Markdown :cal SetSyn("markdown")<CR> +an 50.70.210 &Syntax.M.Mason :cal SetSyn("mason")<CR> +an 50.70.220 &Syntax.M.Mathematica :cal SetSyn("mma")<CR> +an 50.70.230 &Syntax.M.Matlab :cal SetSyn("matlab")<CR> +an 50.70.240 &Syntax.M.Maxima :cal SetSyn("maxima")<CR> +an 50.70.250 &Syntax.M.MEL\ (for\ Maya) :cal SetSyn("mel")<CR> +an 50.70.260 &Syntax.M.Messages\ (/var/log) :cal SetSyn("messages")<CR> +an 50.70.270 &Syntax.M.Metafont :cal SetSyn("mf")<CR> +an 50.70.280 &Syntax.M.MetaPost :cal SetSyn("mp")<CR> +an 50.70.290 &Syntax.M.MGL :cal SetSyn("mgl")<CR> +an 50.70.300 &Syntax.M.MMIX :cal SetSyn("mmix")<CR> +an 50.70.310 &Syntax.M.Modconf :cal SetSyn("modconf")<CR> +an 50.70.320 &Syntax.M.Model :cal SetSyn("model")<CR> +an 50.70.330 &Syntax.M.Modsim\ III :cal SetSyn("modsim3")<CR> +an 50.70.340 &Syntax.M.Modula\ 2 :cal SetSyn("modula2")<CR> +an 50.70.350 &Syntax.M.Modula\ 3 :cal SetSyn("modula3")<CR> +an 50.70.360 &Syntax.M.Monk :cal SetSyn("monk")<CR> +an 50.70.370 &Syntax.M.Mplayer\ config :cal SetSyn("mplayerconf")<CR> +an 50.70.380 &Syntax.M.MOO :cal SetSyn("moo")<CR> +an 50.70.390 &Syntax.M.Mrxvtrc :cal SetSyn("mrxvtrc")<CR> +an 50.70.400 &Syntax.M.MS-DOS/Windows.4DOS\ \.bat\ file :cal SetSyn("btm")<CR> +an 50.70.410 &Syntax.M.MS-DOS/Windows.\.bat\/\.cmd\ file :cal SetSyn("dosbatch")<CR> +an 50.70.420 &Syntax.M.MS-DOS/Windows.\.ini\ file :cal SetSyn("dosini")<CR> +an 50.70.430 &Syntax.M.MS-DOS/Windows.Message\ text :cal SetSyn("msmessages")<CR> +an 50.70.440 &Syntax.M.MS-DOS/Windows.Module\ Definition :cal SetSyn("def")<CR> +an 50.70.450 &Syntax.M.MS-DOS/Windows.Registry :cal SetSyn("registry")<CR> +an 50.70.460 &Syntax.M.MS-DOS/Windows.Resource\ file :cal SetSyn("rc")<CR> +an 50.70.470 &Syntax.M.Msql :cal SetSyn("msql")<CR> +an 50.70.480 &Syntax.M.MuPAD :cal SetSyn("mupad")<CR> +an 50.70.490 &Syntax.M.MUSHcode :cal SetSyn("mush")<CR> +an 50.70.500 &Syntax.M.Muttrc :cal SetSyn("muttrc")<CR> +an 50.80.100 &Syntax.NO.Nanorc :cal SetSyn("nanorc")<CR> +an 50.80.110 &Syntax.NO.Nastran\ input/DMAP :cal SetSyn("nastran")<CR> +an 50.80.120 &Syntax.NO.Natural :cal SetSyn("natural")<CR> +an 50.80.130 &Syntax.NO.Netrc :cal SetSyn("netrc")<CR> +an 50.80.140 &Syntax.NO.Novell\ NCF\ batch :cal SetSyn("ncf")<CR> +an 50.80.150 &Syntax.NO.Not\ Quite\ C\ (LEGO) :cal SetSyn("nqc")<CR> +an 50.80.160 &Syntax.NO.Nroff :cal SetSyn("nroff")<CR> +an 50.80.170 &Syntax.NO.NSIS\ script :cal SetSyn("nsis")<CR> +an 50.80.190 &Syntax.NO.Obj\ 3D\ wavefront :cal SetSyn("obj")<CR> +an 50.80.200 &Syntax.NO.Objective\ C :cal SetSyn("objc")<CR> +an 50.80.210 &Syntax.NO.Objective\ C++ :cal SetSyn("objcpp")<CR> +an 50.80.220 &Syntax.NO.OCAML :cal SetSyn("ocaml")<CR> +an 50.80.230 &Syntax.NO.Occam :cal SetSyn("occam")<CR> +an 50.80.240 &Syntax.NO.Omnimark :cal SetSyn("omnimark")<CR> +an 50.80.250 &Syntax.NO.OpenROAD :cal SetSyn("openroad")<CR> +an 50.80.260 &Syntax.NO.Open\ Psion\ Lang :cal SetSyn("opl")<CR> +an 50.80.270 &Syntax.NO.Oracle\ config :cal SetSyn("ora")<CR> +an 50.90.100 &Syntax.PQ.Packet\ filter\ conf :cal SetSyn("pf")<CR> +an 50.90.110 &Syntax.PQ.Palm\ resource\ compiler :cal SetSyn("pilrc")<CR> +an 50.90.120 &Syntax.PQ.Pam\ config :cal SetSyn("pamconf")<CR> +an 50.90.130 &Syntax.PQ.PApp :cal SetSyn("papp")<CR> +an 50.90.140 &Syntax.PQ.Pascal :cal SetSyn("pascal")<CR> +an 50.90.150 &Syntax.PQ.Password\ file :cal SetSyn("passwd")<CR> +an 50.90.160 &Syntax.PQ.PCCTS :cal SetSyn("pccts")<CR> +an 50.90.170 &Syntax.PQ.PDF :cal SetSyn("pdf")<CR> +an 50.90.180 &Syntax.PQ.Perl.Perl :cal SetSyn("perl")<CR> +an 50.90.190 &Syntax.PQ.Perl.Perl\ 6 :cal SetSyn("perl6")<CR> +an 50.90.200 &Syntax.PQ.Perl.Perl\ POD :cal SetSyn("pod")<CR> +an 50.90.210 &Syntax.PQ.Perl.Perl\ XS :cal SetSyn("xs")<CR> +an 50.90.220 &Syntax.PQ.PHP.PHP\ 3-4 :cal SetSyn("php")<CR> +an 50.90.230 &Syntax.PQ.PHP.Phtml\ (PHP\ 2) :cal SetSyn("phtml")<CR> +an 50.90.240 &Syntax.PQ.Pike :cal SetSyn("pike")<CR> +an 50.90.250 &Syntax.PQ.Pine\ RC :cal SetSyn("pine")<CR> +an 50.90.260 &Syntax.PQ.Pinfo\ RC :cal SetSyn("pinfo")<CR> +an 50.90.270 &Syntax.PQ.PL/M :cal SetSyn("plm")<CR> +an 50.90.280 &Syntax.PQ.PL/SQL :cal SetSyn("plsql")<CR> +an 50.90.290 &Syntax.PQ.PLP :cal SetSyn("plp")<CR> +an 50.90.300 &Syntax.PQ.PO\ (GNU\ gettext) :cal SetSyn("po")<CR> +an 50.90.310 &Syntax.PQ.Postfix\ main\ config :cal SetSyn("pfmain")<CR> +an 50.90.320 &Syntax.PQ.PostScript.PostScript :cal SetSyn("postscr")<CR> +an 50.90.330 &Syntax.PQ.PostScript.PostScript\ Printer\ Description :cal SetSyn("ppd")<CR> +an 50.90.340 &Syntax.PQ.Povray.Povray\ scene\ descr :cal SetSyn("pov")<CR> +an 50.90.350 &Syntax.PQ.Povray.Povray\ configuration :cal SetSyn("povini")<CR> +an 50.90.360 &Syntax.PQ.PPWizard :cal SetSyn("ppwiz")<CR> +an 50.90.370 &Syntax.PQ.Prescribe\ (Kyocera) :cal SetSyn("prescribe")<CR> +an 50.90.380 &Syntax.PQ.Printcap :cal SetSyn("pcap")<CR> +an 50.90.390 &Syntax.PQ.Privoxy :cal SetSyn("privoxy")<CR> +an 50.90.400 &Syntax.PQ.Procmail :cal SetSyn("procmail")<CR> +an 50.90.410 &Syntax.PQ.Product\ Spec\ File :cal SetSyn("psf")<CR> +an 50.90.420 &Syntax.PQ.Progress :cal SetSyn("progress")<CR> +an 50.90.430 &Syntax.PQ.Prolog :cal SetSyn("prolog")<CR> +an 50.90.440 &Syntax.PQ.ProMeLa :cal SetSyn("promela")<CR> +an 50.90.450 &Syntax.PQ.Protocols :cal SetSyn("protocols")<CR> +an 50.90.460 &Syntax.PQ.Purify\ log :cal SetSyn("purifylog")<CR> +an 50.90.470 &Syntax.PQ.Pyrex :cal SetSyn("pyrex")<CR> +an 50.90.480 &Syntax.PQ.Python :cal SetSyn("python")<CR> +an 50.90.500 &Syntax.PQ.Quake :cal SetSyn("quake")<CR> +an 50.90.510 &Syntax.PQ.Quickfix\ window :cal SetSyn("qf")<CR> +an 50.100.100 &Syntax.R.R.R :cal SetSyn("r")<CR> +an 50.100.110 &Syntax.R.R.R\ help :cal SetSyn("rhelp")<CR> +an 50.100.120 &Syntax.R.R.R\ noweb :cal SetSyn("rnoweb")<CR> +an 50.100.130 &Syntax.R.Racc\ input :cal SetSyn("racc")<CR> +an 50.100.140 &Syntax.R.Radiance :cal SetSyn("radiance")<CR> +an 50.100.150 &Syntax.R.Ratpoison :cal SetSyn("ratpoison")<CR> +an 50.100.160 &Syntax.R.RCS.RCS\ log\ output :cal SetSyn("rcslog")<CR> +an 50.100.170 &Syntax.R.RCS.RCS\ file :cal SetSyn("rcs")<CR> +an 50.100.180 &Syntax.R.Readline\ config :cal SetSyn("readline")<CR> +an 50.100.190 &Syntax.R.Rebol :cal SetSyn("rebol")<CR> +an 50.100.200 &Syntax.R.Remind :cal SetSyn("remind")<CR> +an 50.100.210 &Syntax.R.Relax\ NG\ compact :cal SetSyn("rnc")<CR> +an 50.100.220 &Syntax.R.Renderman.Renderman\ Shader\ Lang :cal SetSyn("sl")<CR> +an 50.100.230 &Syntax.R.Renderman.Renderman\ Interface\ Bytestream :cal SetSyn("rib")<CR> +an 50.100.240 &Syntax.R.Resolv\.conf :cal SetSyn("resolv")<CR> +an 50.100.250 &Syntax.R.Reva\ Forth :cal SetSyn("reva")<CR> +an 50.100.260 &Syntax.R.Rexx :cal SetSyn("rexx")<CR> +an 50.100.270 &Syntax.R.Robots\.txt :cal SetSyn("robots")<CR> +an 50.100.280 &Syntax.R.RockLinux\ package\ desc\. :cal SetSyn("desc")<CR> +an 50.100.290 &Syntax.R.Rpcgen :cal SetSyn("rpcgen")<CR> +an 50.100.300 &Syntax.R.RPL/2 :cal SetSyn("rpl")<CR> +an 50.100.310 &Syntax.R.ReStructuredText :cal SetSyn("rst")<CR> +an 50.100.320 &Syntax.R.RTF :cal SetSyn("rtf")<CR> +an 50.100.330 &Syntax.R.Ruby :cal SetSyn("ruby")<CR> +an 50.110.100 &Syntax.S-Sm.S-Lang :cal SetSyn("slang")<CR> +an 50.110.110 &Syntax.S-Sm.Samba\ config :cal SetSyn("samba")<CR> +an 50.110.120 &Syntax.S-Sm.SAS :cal SetSyn("sas")<CR> +an 50.110.130 &Syntax.S-Sm.Sass :cal SetSyn("sass")<CR> +an 50.110.140 &Syntax.S-Sm.Sather :cal SetSyn("sather")<CR> +an 50.110.150 &Syntax.S-Sm.Scheme :cal SetSyn("scheme")<CR> +an 50.110.160 &Syntax.S-Sm.Scilab :cal SetSyn("scilab")<CR> +an 50.110.170 &Syntax.S-Sm.Screen\ RC :cal SetSyn("screen")<CR> +an 50.110.180 &Syntax.S-Sm.SCSS :cal SetSyn("scss")<CR> +an 50.110.190 &Syntax.S-Sm.SDC\ Synopsys\ Design\ Constraints :cal SetSyn("sdc")<CR> +an 50.110.200 &Syntax.S-Sm.SDL :cal SetSyn("sdl")<CR> +an 50.110.210 &Syntax.S-Sm.Sed :cal SetSyn("sed")<CR> +an 50.110.220 &Syntax.S-Sm.Sendmail\.cf :cal SetSyn("sm")<CR> +an 50.110.230 &Syntax.S-Sm.Send-pr :cal SetSyn("sendpr")<CR> +an 50.110.240 &Syntax.S-Sm.Sensors\.conf :cal SetSyn("sensors")<CR> +an 50.110.250 &Syntax.S-Sm.Service\ Location\ config :cal SetSyn("slpconf")<CR> +an 50.110.260 &Syntax.S-Sm.Service\ Location\ registration :cal SetSyn("slpreg")<CR> +an 50.110.270 &Syntax.S-Sm.Service\ Location\ SPI :cal SetSyn("slpspi")<CR> +an 50.110.280 &Syntax.S-Sm.Services :cal SetSyn("services")<CR> +an 50.110.290 &Syntax.S-Sm.Setserial\ config :cal SetSyn("setserial")<CR> +an 50.110.300 &Syntax.S-Sm.SGML.SGML\ catalog :cal SetSyn("catalog")<CR> +an 50.110.310 &Syntax.S-Sm.SGML.SGML\ DTD :cal SetSyn("sgml")<CR> +an 50.110.320 &Syntax.S-Sm.SGML.SGML\ Declaration :cal SetSyn("sgmldecl")<CR> +an 50.110.330 &Syntax.S-Sm.SGML.SGML-linuxdoc :cal SetSyn("sgmllnx")<CR> +an 50.110.340 &Syntax.S-Sm.Shell\ script.sh\ and\ ksh :cal SetSyn("sh")<CR> +an 50.110.350 &Syntax.S-Sm.Shell\ script.csh :cal SetSyn("csh")<CR> +an 50.110.360 &Syntax.S-Sm.Shell\ script.tcsh :cal SetSyn("tcsh")<CR> +an 50.110.370 &Syntax.S-Sm.Shell\ script.zsh :cal SetSyn("zsh")<CR> +an 50.110.380 &Syntax.S-Sm.SiCAD :cal SetSyn("sicad")<CR> +an 50.110.390 &Syntax.S-Sm.Sieve :cal SetSyn("sieve")<CR> +an 50.110.400 &Syntax.S-Sm.Simula :cal SetSyn("simula")<CR> +an 50.110.410 &Syntax.S-Sm.Sinda.Sinda\ compare :cal SetSyn("sindacmp")<CR> +an 50.110.420 &Syntax.S-Sm.Sinda.Sinda\ input :cal SetSyn("sinda")<CR> +an 50.110.430 &Syntax.S-Sm.Sinda.Sinda\ output :cal SetSyn("sindaout")<CR> +an 50.110.440 &Syntax.S-Sm.SiSU :cal SetSyn("sisu")<CR> +an 50.110.450 &Syntax.S-Sm.SKILL.SKILL :cal SetSyn("skill")<CR> +an 50.110.460 &Syntax.S-Sm.SKILL.SKILL\ for\ Diva :cal SetSyn("diva")<CR> +an 50.110.470 &Syntax.S-Sm.Slice :cal SetSyn("slice")<CR> +an 50.110.480 &Syntax.S-Sm.SLRN.Slrn\ rc :cal SetSyn("slrnrc")<CR> +an 50.110.490 &Syntax.S-Sm.SLRN.Slrn\ score :cal SetSyn("slrnsc")<CR> +an 50.110.500 &Syntax.S-Sm.SmallTalk :cal SetSyn("st")<CR> +an 50.110.510 &Syntax.S-Sm.Smarty\ Templates :cal SetSyn("smarty")<CR> +an 50.110.520 &Syntax.S-Sm.SMIL :cal SetSyn("smil")<CR> +an 50.110.530 &Syntax.S-Sm.SMITH :cal SetSyn("smith")<CR> +an 50.120.100 &Syntax.Sn-Sy.SNMP\ MIB :cal SetSyn("mib")<CR> +an 50.120.110 &Syntax.Sn-Sy.SNNS.SNNS\ network :cal SetSyn("snnsnet")<CR> +an 50.120.120 &Syntax.Sn-Sy.SNNS.SNNS\ pattern :cal SetSyn("snnspat")<CR> +an 50.120.130 &Syntax.Sn-Sy.SNNS.SNNS\ result :cal SetSyn("snnsres")<CR> +an 50.120.140 &Syntax.Sn-Sy.Snobol4 :cal SetSyn("snobol4")<CR> +an 50.120.150 &Syntax.Sn-Sy.Snort\ Configuration :cal SetSyn("hog")<CR> +an 50.120.160 &Syntax.Sn-Sy.SPEC\ (Linux\ RPM) :cal SetSyn("spec")<CR> +an 50.120.170 &Syntax.Sn-Sy.Specman :cal SetSyn("specman")<CR> +an 50.120.180 &Syntax.Sn-Sy.Spice :cal SetSyn("spice")<CR> +an 50.120.190 &Syntax.Sn-Sy.Spyce :cal SetSyn("spyce")<CR> +an 50.120.200 &Syntax.Sn-Sy.Speedup :cal SetSyn("spup")<CR> +an 50.120.210 &Syntax.Sn-Sy.Splint :cal SetSyn("splint")<CR> +an 50.120.220 &Syntax.Sn-Sy.Squid\ config :cal SetSyn("squid")<CR> +an 50.120.230 &Syntax.Sn-Sy.SQL.ESQL-C :cal SetSyn("esqlc")<CR> +an 50.120.240 &Syntax.Sn-Sy.SQL.MySQL :cal SetSyn("mysql")<CR> +an 50.120.250 &Syntax.Sn-Sy.SQL.PL/SQL :cal SetSyn("plsql")<CR> +an 50.120.260 &Syntax.Sn-Sy.SQL.SQL\ Anywhere :cal SetSyn("sqlanywhere")<CR> +an 50.120.270 &Syntax.Sn-Sy.SQL.SQL\ (automatic) :cal SetSyn("sql")<CR> +an 50.120.280 &Syntax.Sn-Sy.SQL.SQL\ (Oracle) :cal SetSyn("sqloracle")<CR> +an 50.120.290 &Syntax.Sn-Sy.SQL.SQL\ Forms :cal SetSyn("sqlforms")<CR> +an 50.120.300 &Syntax.Sn-Sy.SQL.SQLJ :cal SetSyn("sqlj")<CR> +an 50.120.310 &Syntax.Sn-Sy.SQL.SQL-Informix :cal SetSyn("sqlinformix")<CR> +an 50.120.320 &Syntax.Sn-Sy.SQR :cal SetSyn("sqr")<CR> +an 50.120.330 &Syntax.Sn-Sy.Ssh.ssh_config :cal SetSyn("sshconfig")<CR> +an 50.120.340 &Syntax.Sn-Sy.Ssh.sshd_config :cal SetSyn("sshdconfig")<CR> +an 50.120.350 &Syntax.Sn-Sy.Standard\ ML :cal SetSyn("sml")<CR> +an 50.120.360 &Syntax.Sn-Sy.Stata.SMCL :cal SetSyn("smcl")<CR> +an 50.120.370 &Syntax.Sn-Sy.Stata.Stata :cal SetSyn("stata")<CR> +an 50.120.380 &Syntax.Sn-Sy.Stored\ Procedures :cal SetSyn("stp")<CR> +an 50.120.390 &Syntax.Sn-Sy.Strace :cal SetSyn("strace")<CR> +an 50.120.400 &Syntax.Sn-Sy.Streaming\ descriptor\ file :cal SetSyn("sd")<CR> +an 50.120.410 &Syntax.Sn-Sy.Subversion\ commit :cal SetSyn("svn")<CR> +an 50.120.420 &Syntax.Sn-Sy.Sudoers :cal SetSyn("sudoers")<CR> +an 50.120.430 &Syntax.Sn-Sy.SVG :cal SetSyn("svg")<CR> +an 50.120.440 &Syntax.Sn-Sy.Symbian\ meta-makefile :cal SetSyn("mmp")<CR> +an 50.120.450 &Syntax.Sn-Sy.Sysctl\.conf :cal SetSyn("sysctl")<CR> +an 50.130.100 &Syntax.T.TADS :cal SetSyn("tads")<CR> +an 50.130.110 &Syntax.T.Tags :cal SetSyn("tags")<CR> +an 50.130.120 &Syntax.T.TAK.TAK\ compare :cal SetSyn("takcmp")<CR> +an 50.130.130 &Syntax.T.TAK.TAK\ input :cal SetSyn("tak")<CR> +an 50.130.140 &Syntax.T.TAK.TAK\ output :cal SetSyn("takout")<CR> +an 50.130.150 &Syntax.T.Task\ data :cal SetSyn("taskdata")<CR> +an 50.130.160 &Syntax.T.Task\ 42\ edit :cal SetSyn("taskedit")<CR> +an 50.130.170 &Syntax.T.Tcl/Tk :cal SetSyn("tcl")<CR> +an 50.130.180 &Syntax.T.TealInfo :cal SetSyn("tli")<CR> +an 50.130.190 &Syntax.T.Telix\ Salt :cal SetSyn("tsalt")<CR> +an 50.130.200 &Syntax.T.Termcap/Printcap :cal SetSyn("ptcap")<CR> +an 50.130.210 &Syntax.T.Terminfo :cal SetSyn("terminfo")<CR> +an 50.130.220 &Syntax.T.TeX.TeX/LaTeX :cal SetSyn("tex")<CR> +an 50.130.230 &Syntax.T.TeX.plain\ TeX :cal SetSyn("plaintex")<CR> +an 50.130.240 &Syntax.T.TeX.ConTeXt :cal SetSyn("context")<CR> +an 50.130.250 &Syntax.T.TeX.TeX\ configuration :cal SetSyn("texmf")<CR> +an 50.130.260 &Syntax.T.TeX.Texinfo :cal SetSyn("texinfo")<CR> +an 50.130.270 &Syntax.T.TF\ mud\ client :cal SetSyn("tf")<CR> +an 50.130.280 &Syntax.T.Tidy\ configuration :cal SetSyn("tidy")<CR> +an 50.130.290 &Syntax.T.Tilde :cal SetSyn("tilde")<CR> +an 50.130.300 &Syntax.T.TPP :cal SetSyn("tpp")<CR> +an 50.130.310 &Syntax.T.Trasys\ input :cal SetSyn("trasys")<CR> +an 50.130.320 &Syntax.T.Trustees :cal SetSyn("trustees")<CR> +an 50.130.330 &Syntax.T.TSS.Command\ Line :cal SetSyn("tsscl")<CR> +an 50.130.340 &Syntax.T.TSS.Geometry :cal SetSyn("tssgm")<CR> +an 50.130.350 &Syntax.T.TSS.Optics :cal SetSyn("tssop")<CR> +an 50.140.100 &Syntax.UV.Udev\ config :cal SetSyn("udevconf")<CR> +an 50.140.110 &Syntax.UV.Udev\ permissions :cal SetSyn("udevperm")<CR> +an 50.140.120 &Syntax.UV.Udev\ rules :cal SetSyn("udevrules")<CR> +an 50.140.130 &Syntax.UV.UIT/UIL :cal SetSyn("uil")<CR> +an 50.140.140 &Syntax.UV.UnrealScript :cal SetSyn("uc")<CR> +an 50.140.150 &Syntax.UV.Updatedb\.conf :cal SetSyn("updatedb")<CR> +an 50.140.170 &Syntax.UV.Valgrind :cal SetSyn("valgrind")<CR> +an 50.140.180 &Syntax.UV.Vera :cal SetSyn("vera")<CR> +an 50.140.190 &Syntax.UV.Verilog-AMS\ HDL :cal SetSyn("verilogams")<CR> +an 50.140.200 &Syntax.UV.Verilog\ HDL :cal SetSyn("verilog")<CR> +an 50.140.210 &Syntax.UV.Vgrindefs :cal SetSyn("vgrindefs")<CR> +an 50.140.220 &Syntax.UV.VHDL :cal SetSyn("vhdl")<CR> +an 50.140.230 &Syntax.UV.Vim.Vim\ help\ file :cal SetSyn("help")<CR> +an 50.140.240 &Syntax.UV.Vim.Vim\ script :cal SetSyn("vim")<CR> +an 50.140.250 &Syntax.UV.Vim.Viminfo\ file :cal SetSyn("viminfo")<CR> +an 50.140.260 &Syntax.UV.Virata\ config :cal SetSyn("virata")<CR> +an 50.140.270 &Syntax.UV.Visual\ Basic :cal SetSyn("vb")<CR> +an 50.140.280 &Syntax.UV.VOS\ CM\ macro :cal SetSyn("voscm")<CR> +an 50.140.290 &Syntax.UV.VRML :cal SetSyn("vrml")<CR> +an 50.140.300 &Syntax.UV.VSE\ JCL :cal SetSyn("vsejcl")<CR> +an 50.150.100 &Syntax.WXYZ.WEB.CWEB :cal SetSyn("cweb")<CR> +an 50.150.110 &Syntax.WXYZ.WEB.WEB :cal SetSyn("web")<CR> +an 50.150.120 &Syntax.WXYZ.WEB.WEB\ Changes :cal SetSyn("change")<CR> +an 50.150.130 &Syntax.WXYZ.Webmacro :cal SetSyn("webmacro")<CR> +an 50.150.140 &Syntax.WXYZ.Website\ MetaLanguage :cal SetSyn("wml")<CR> +an 50.150.160 &Syntax.WXYZ.wDiff :cal SetSyn("wdiff")<CR> +an 50.150.180 &Syntax.WXYZ.Wget\ config :cal SetSyn("wget")<CR> +an 50.150.190 &Syntax.WXYZ.Whitespace\ (add) :cal SetSyn("whitespace")<CR> +an 50.150.200 &Syntax.WXYZ.WildPackets\ EtherPeek\ Decoder :cal SetSyn("dcd")<CR> +an 50.150.210 &Syntax.WXYZ.WinBatch/Webbatch :cal SetSyn("winbatch")<CR> +an 50.150.220 &Syntax.WXYZ.Windows\ Scripting\ Host :cal SetSyn("wsh")<CR> +an 50.150.230 &Syntax.WXYZ.WSML :cal SetSyn("wsml")<CR> +an 50.150.240 &Syntax.WXYZ.WvDial :cal SetSyn("wvdial")<CR> +an 50.150.260 &Syntax.WXYZ.X\ Keyboard\ Extension :cal SetSyn("xkb")<CR> +an 50.150.270 &Syntax.WXYZ.X\ Pixmap :cal SetSyn("xpm")<CR> +an 50.150.280 &Syntax.WXYZ.X\ Pixmap\ (2) :cal SetSyn("xpm2")<CR> +an 50.150.290 &Syntax.WXYZ.X\ resources :cal SetSyn("xdefaults")<CR> +an 50.150.300 &Syntax.WXYZ.XBL :cal SetSyn("xbl")<CR> +an 50.150.310 &Syntax.WXYZ.Xinetd\.conf :cal SetSyn("xinetd")<CR> +an 50.150.320 &Syntax.WXYZ.Xmodmap :cal SetSyn("xmodmap")<CR> +an 50.150.330 &Syntax.WXYZ.Xmath :cal SetSyn("xmath")<CR> +an 50.150.340 &Syntax.WXYZ.XML :cal SetSyn("xml")<CR> +an 50.150.350 &Syntax.WXYZ.XML\ Schema\ (XSD) :cal SetSyn("xsd")<CR> +an 50.150.360 &Syntax.WXYZ.XQuery :cal SetSyn("xquery")<CR> +an 50.150.370 &Syntax.WXYZ.Xslt :cal SetSyn("xslt")<CR> +an 50.150.380 &Syntax.WXYZ.XFree86\ Config :cal SetSyn("xf86conf")<CR> +an 50.150.400 &Syntax.WXYZ.YAML :cal SetSyn("yaml")<CR> +an 50.150.410 &Syntax.WXYZ.Yacc :cal SetSyn("yacc")<CR> + +" The End Of The Syntax Menu + + +an 50.195 &Syntax.-SEP1- <Nop> + +an <silent> 50.200 &Syntax.Set\ '&syntax'\ only :call <SID>Setsynonly()<CR> +fun! s:Setsynonly() + let s:syntax_menu_synonly = 1 +endfun +an <silent> 50.202 &Syntax.Set\ '&filetype'\ too :call <SID>Nosynonly()<CR> +fun! s:Nosynonly() + if exists("s:syntax_menu_synonly") + unlet s:syntax_menu_synonly + endif +endfun + +" Restore 'cpoptions' +let &cpo = s:cpo_save +unlet s:cpo_save diff --git a/share/vim/vim73/syntax/2html.vim b/share/vim/vim73/syntax/2html.vim new file mode 100644 index 0000000000..ad58112d29 --- /dev/null +++ b/share/vim/vim73/syntax/2html.vim @@ -0,0 +1,1120 @@ +" Vim syntax support file +" Maintainer: Ben Fritz <fritzophrenic@gmail.com> +" Last Change: 2010 Aug 12 +" +" Additional contributors: +" +" Original by Bram Moolenaar <Bram@vim.org> +" Modified by David Ne\v{c}as (Yeti) <yeti@physics.muni.cz> +" XHTML support by Panagiotis Issaris <takis@lumumba.luc.ac.be> +" Made w3 compliant by Edd Barrett <vext01@gmail.com> +" Added html_font. Edd Barrett <vext01@gmail.com> +" Progress bar based off code from "progressbar widget" plugin by +" Andreas Politz, heavily modified: +" http://www.vim.org/scripts/script.php?script_id=2006 +" +" See Mercurial change logs for more! + +" Transform a file into HTML, using the current syntax highlighting. + +" this file uses line continuations +let s:cpo_sav = &cpo +let s:ls = &ls +set cpo-=C + +let s:end=line('$') + +" Font +if exists("g:html_font") + let s:htmlfont = "'". g:html_font . "', monospace" +else + let s:htmlfont = "monospace" +endif + +let s:settings = tohtml#GetUserSettings() + +" When not in gui we can only guess the colors. +if has("gui_running") + let s:whatterm = "gui" +else + let s:whatterm = "cterm" + if &t_Co == 8 + let s:cterm_color = {0: "#808080", 1: "#ff6060", 2: "#00ff00", 3: "#ffff00", 4: "#8080ff", 5: "#ff40ff", 6: "#00ffff", 7: "#ffffff"} + else + let s:cterm_color = {0: "#000000", 1: "#c00000", 2: "#008000", 3: "#804000", 4: "#0000c0", 5: "#c000c0", 6: "#008080", 7: "#c0c0c0", 8: "#808080", 9: "#ff6060", 10: "#00ff00", 11: "#ffff00", 12: "#8080ff", 13: "#ff40ff", 14: "#00ffff", 15: "#ffffff"} + + " Colors for 88 and 256 come from xterm. + if &t_Co == 88 + call extend(s:cterm_color, {16: "#000000", 17: "#00008b", 18: "#0000cd", 19: "#0000ff", 20: "#008b00", 21: "#008b8b", 22: "#008bcd", 23: "#008bff", 24: "#00cd00", 25: "#00cd8b", 26: "#00cdcd", 27: "#00cdff", 28: "#00ff00", 29: "#00ff8b", 30: "#00ffcd", 31: "#00ffff", 32: "#8b0000", 33: "#8b008b", 34: "#8b00cd", 35: "#8b00ff", 36: "#8b8b00", 37: "#8b8b8b", 38: "#8b8bcd", 39: "#8b8bff", 40: "#8bcd00", 41: "#8bcd8b", 42: "#8bcdcd", 43: "#8bcdff", 44: "#8bff00", 45: "#8bff8b", 46: "#8bffcd", 47: "#8bffff", 48: "#cd0000", 49: "#cd008b", 50: "#cd00cd", 51: "#cd00ff", 52: "#cd8b00", 53: "#cd8b8b", 54: "#cd8bcd", 55: "#cd8bff", 56: "#cdcd00", 57: "#cdcd8b", 58: "#cdcdcd", 59: "#cdcdff", 60: "#cdff00", 61: "#cdff8b", 62: "#cdffcd", 63: "#cdffff", 64: "#ff0000"}) + call extend(s:cterm_color, {65: "#ff008b", 66: "#ff00cd", 67: "#ff00ff", 68: "#ff8b00", 69: "#ff8b8b", 70: "#ff8bcd", 71: "#ff8bff", 72: "#ffcd00", 73: "#ffcd8b", 74: "#ffcdcd", 75: "#ffcdff", 76: "#ffff00", 77: "#ffff8b", 78: "#ffffcd", 79: "#ffffff", 80: "#2e2e2e", 81: "#5c5c5c", 82: "#737373", 83: "#8b8b8b", 84: "#a2a2a2", 85: "#b9b9b9", 86: "#d0d0d0", 87: "#e7e7e7"}) + elseif &t_Co == 256 + call extend(s:cterm_color, {16: "#000000", 17: "#00005f", 18: "#000087", 19: "#0000af", 20: "#0000d7", 21: "#0000ff", 22: "#005f00", 23: "#005f5f", 24: "#005f87", 25: "#005faf", 26: "#005fd7", 27: "#005fff", 28: "#008700", 29: "#00875f", 30: "#008787", 31: "#0087af", 32: "#0087d7", 33: "#0087ff", 34: "#00af00", 35: "#00af5f", 36: "#00af87", 37: "#00afaf", 38: "#00afd7", 39: "#00afff", 40: "#00d700", 41: "#00d75f", 42: "#00d787", 43: "#00d7af", 44: "#00d7d7", 45: "#00d7ff", 46: "#00ff00", 47: "#00ff5f", 48: "#00ff87", 49: "#00ffaf", 50: "#00ffd7", 51: "#00ffff", 52: "#5f0000", 53: "#5f005f", 54: "#5f0087", 55: "#5f00af", 56: "#5f00d7", 57: "#5f00ff", 58: "#5f5f00", 59: "#5f5f5f", 60: "#5f5f87", 61: "#5f5faf", 62: "#5f5fd7", 63: "#5f5fff", 64: "#5f8700"}) + call extend(s:cterm_color, {65: "#5f875f", 66: "#5f8787", 67: "#5f87af", 68: "#5f87d7", 69: "#5f87ff", 70: "#5faf00", 71: "#5faf5f", 72: "#5faf87", 73: "#5fafaf", 74: "#5fafd7", 75: "#5fafff", 76: "#5fd700", 77: "#5fd75f", 78: "#5fd787", 79: "#5fd7af", 80: "#5fd7d7", 81: "#5fd7ff", 82: "#5fff00", 83: "#5fff5f", 84: "#5fff87", 85: "#5fffaf", 86: "#5fffd7", 87: "#5fffff", 88: "#870000", 89: "#87005f", 90: "#870087", 91: "#8700af", 92: "#8700d7", 93: "#8700ff", 94: "#875f00", 95: "#875f5f", 96: "#875f87", 97: "#875faf", 98: "#875fd7", 99: "#875fff", 100: "#878700", 101: "#87875f", 102: "#878787", 103: "#8787af", 104: "#8787d7", 105: "#8787ff", 106: "#87af00", 107: "#87af5f", 108: "#87af87", 109: "#87afaf", 110: "#87afd7", 111: "#87afff", 112: "#87d700"}) + call extend(s:cterm_color, {113: "#87d75f", 114: "#87d787", 115: "#87d7af", 116: "#87d7d7", 117: "#87d7ff", 118: "#87ff00", 119: "#87ff5f", 120: "#87ff87", 121: "#87ffaf", 122: "#87ffd7", 123: "#87ffff", 124: "#af0000", 125: "#af005f", 126: "#af0087", 127: "#af00af", 128: "#af00d7", 129: "#af00ff", 130: "#af5f00", 131: "#af5f5f", 132: "#af5f87", 133: "#af5faf", 134: "#af5fd7", 135: "#af5fff", 136: "#af8700", 137: "#af875f", 138: "#af8787", 139: "#af87af", 140: "#af87d7", 141: "#af87ff", 142: "#afaf00", 143: "#afaf5f", 144: "#afaf87", 145: "#afafaf", 146: "#afafd7", 147: "#afafff", 148: "#afd700", 149: "#afd75f", 150: "#afd787", 151: "#afd7af", 152: "#afd7d7", 153: "#afd7ff", 154: "#afff00", 155: "#afff5f", 156: "#afff87", 157: "#afffaf", 158: "#afffd7"}) + call extend(s:cterm_color, {159: "#afffff", 160: "#d70000", 161: "#d7005f", 162: "#d70087", 163: "#d700af", 164: "#d700d7", 165: "#d700ff", 166: "#d75f00", 167: "#d75f5f", 168: "#d75f87", 169: "#d75faf", 170: "#d75fd7", 171: "#d75fff", 172: "#d78700", 173: "#d7875f", 174: "#d78787", 175: "#d787af", 176: "#d787d7", 177: "#d787ff", 178: "#d7af00", 179: "#d7af5f", 180: "#d7af87", 181: "#d7afaf", 182: "#d7afd7", 183: "#d7afff", 184: "#d7d700", 185: "#d7d75f", 186: "#d7d787", 187: "#d7d7af", 188: "#d7d7d7", 189: "#d7d7ff", 190: "#d7ff00", 191: "#d7ff5f", 192: "#d7ff87", 193: "#d7ffaf", 194: "#d7ffd7", 195: "#d7ffff", 196: "#ff0000", 197: "#ff005f", 198: "#ff0087", 199: "#ff00af", 200: "#ff00d7", 201: "#ff00ff", 202: "#ff5f00", 203: "#ff5f5f", 204: "#ff5f87"}) + call extend(s:cterm_color, {205: "#ff5faf", 206: "#ff5fd7", 207: "#ff5fff", 208: "#ff8700", 209: "#ff875f", 210: "#ff8787", 211: "#ff87af", 212: "#ff87d7", 213: "#ff87ff", 214: "#ffaf00", 215: "#ffaf5f", 216: "#ffaf87", 217: "#ffafaf", 218: "#ffafd7", 219: "#ffafff", 220: "#ffd700", 221: "#ffd75f", 222: "#ffd787", 223: "#ffd7af", 224: "#ffd7d7", 225: "#ffd7ff", 226: "#ffff00", 227: "#ffff5f", 228: "#ffff87", 229: "#ffffaf", 230: "#ffffd7", 231: "#ffffff", 232: "#080808", 233: "#121212", 234: "#1c1c1c", 235: "#262626", 236: "#303030", 237: "#3a3a3a", 238: "#444444", 239: "#4e4e4e", 240: "#585858", 241: "#626262", 242: "#6c6c6c", 243: "#767676", 244: "#808080", 245: "#8a8a8a", 246: "#949494", 247: "#9e9e9e", 248: "#a8a8a8", 249: "#b2b2b2", 250: "#bcbcbc", 251: "#c6c6c6", 252: "#d0d0d0", 253: "#dadada", 254: "#e4e4e4", 255: "#eeeeee"}) + endif + endif +endif + +" Return good color specification: in GUI no transformation is done, in +" terminal return RGB values of known colors and empty string for unknown +if s:whatterm == "gui" + function! s:HtmlColor(color) + return a:color + endfun +else + function! s:HtmlColor(color) + if has_key(s:cterm_color, a:color) + return s:cterm_color[a:color] + else + return "" + endif + endfun +endif + +if !s:settings.use_css + " Return opening HTML tag for given highlight id + function! s:HtmlOpening(id) + let a = "" + if synIDattr(a:id, "inverse") + " For inverse, we always must set both colors (and exchange them) + let x = s:HtmlColor(synIDattr(a:id, "fg#", s:whatterm)) + let a = a . '<span style="background-color: ' . ( x != "" ? x : s:fgc ) . '">' + let x = s:HtmlColor(synIDattr(a:id, "bg#", s:whatterm)) + let a = a . '<font color="' . ( x != "" ? x : s:bgc ) . '">' + else + let x = s:HtmlColor(synIDattr(a:id, "bg#", s:whatterm)) + if x != "" | let a = a . '<span style="background-color: ' . x . '">' | endif + let x = s:HtmlColor(synIDattr(a:id, "fg#", s:whatterm)) + if x != "" | let a = a . '<font color="' . x . '">' | endif + endif + if synIDattr(a:id, "bold") | let a = a . "<b>" | endif + if synIDattr(a:id, "italic") | let a = a . "<i>" | endif + if synIDattr(a:id, "underline") | let a = a . "<u>" | endif + return a + endfun + + " Return closing HTML tag for given highlight id + function! s:HtmlClosing(id) + let a = "" + if synIDattr(a:id, "underline") | let a = a . "</u>" | endif + if synIDattr(a:id, "italic") | let a = a . "</i>" | endif + if synIDattr(a:id, "bold") | let a = a . "</b>" | endif + if synIDattr(a:id, "inverse") + let a = a . '</font></span>' + else + let x = s:HtmlColor(synIDattr(a:id, "fg#", s:whatterm)) + if x != "" | let a = a . '</font>' | endif + let x = s:HtmlColor(synIDattr(a:id, "bg#", s:whatterm)) + if x != "" | let a = a . '</span>' | endif + endif + return a + endfun +endif + +" Return HTML valid characters enclosed in a span of class style_name with +" unprintable characters expanded and double spaces replaced as necessary. +function! s:HtmlFormat(text, style_name, diff_style_name) + " Replace unprintable characters + let formatted = strtrans(a:text) + + " separate the two classes by a space to apply them both if there is a diff + " style name + let l:style_name = a:style_name . (a:diff_style_name == '' ? '' : ' ') . a:diff_style_name + + " Replace the reserved html characters + let formatted = substitute(substitute(substitute(substitute(substitute(formatted, '&', '\&', 'g'), '<', '\<', 'g'), '>', '\>', 'g'), '"', '\"', 'g'), "\x0c", '<hr class="PAGE-BREAK">', 'g') + + " Replace double spaces, leading spaces, and trailing spaces if needed + if ' ' != s:HtmlSpace + let formatted = substitute(formatted, ' ', s:HtmlSpace . s:HtmlSpace, 'g') + let formatted = substitute(formatted, '^ ', s:HtmlSpace, 'g') + let formatted = substitute(formatted, ' \+$', s:HtmlSpace, 'g') + endif + + " Enclose in a span of class style_name + let formatted = '<span class="' . l:style_name . '">' . formatted . '</span>' + + " Add the class to class list if it's not there yet. + " Add normal groups to the beginning so diff groups can override them. + let s:id = hlID(a:style_name) + if index(s:idlist, s:id ) == -1 + if a:style_name =~ 'Diff\%(Add\|Change\|Delete\|Text\)' + call add(s:idlist, s:id) + else + call insert(s:idlist, s:id) + endif + endif + + " Add the diff highlight class to class list if used and it's not there yet. + " Add diff groups to the end so they override the other highlighting. + if a:diff_style_name != "" + let s:diff_id = hlID(a:diff_style_name) + if index(s:idlist, s:diff_id) == -1 + call add(s:idlist, s:diff_id) + endif + endif + + return formatted +endfun + +" Return CSS style describing given highlight id (can be empty) +function! s:CSS1(id) + let a = "" + if synIDattr(a:id, "inverse") + " For inverse, we always must set both colors (and exchange them) + let x = s:HtmlColor(synIDattr(a:id, "bg#", s:whatterm)) + let a = a . "color: " . ( x != "" ? x : s:bgc ) . "; " + let x = s:HtmlColor(synIDattr(a:id, "fg#", s:whatterm)) + let a = a . "background-color: " . ( x != "" ? x : s:fgc ) . "; " + else + let x = s:HtmlColor(synIDattr(a:id, "fg#", s:whatterm)) + if x != "" | let a = a . "color: " . x . "; " | endif + let x = s:HtmlColor(synIDattr(a:id, "bg#", s:whatterm)) + if x != "" | let a = a . "background-color: " . x . "; " | endif + endif + if synIDattr(a:id, "bold") | let a = a . "font-weight: bold; " | endif + if synIDattr(a:id, "italic") | let a = a . "font-style: italic; " | endif + if synIDattr(a:id, "underline") | let a = a . "text-decoration: underline; " | endif + return a +endfun + +if s:settings.dynamic_folds + " compares two folds as stored in our list of folds + " A fold is "less" than another if it starts at an earlier line number, + " or ends at a later line number, ties broken by fold level + function! s:FoldCompare(f1, f2) + if a:f1.firstline != a:f2.firstline + " put it before if it starts earlier + return a:f1.firstline - a:f2.firstline + elseif a:f1.lastline != a:f2.lastline + " put it before if it ends later + return a:f2.lastline - a:f1.lastline + else + " if folds begin and end on the same lines, put lowest fold level first + return a:f1.level - a:f2.level + endif + endfunction + +endif + + +" Set some options to make it work faster. +" Don't report changes for :substitute, there will be many of them. +" Don't change other windows; turn off scroll bind temporarily +let s:old_title = &title +let s:old_icon = &icon +let s:old_et = &l:et +let s:old_bind = &l:scrollbind +let s:old_report = &report +let s:old_search = @/ +let s:old_more = &more +set notitle noicon +setlocal et +set nomore +set report=1000000 +setlocal noscrollbind + +if exists(':ownsyntax') && exists('w:current_syntax') + let s:current_syntax = w:current_syntax +elseif exists('b:current_syntax') + let s:current_syntax = b:current_syntax +else + let s:current_syntax = 'none' +endif + +if s:current_syntax == '' + let s:current_syntax = 'none' +endif + +" Split window to create a buffer with the HTML file. +let s:orgbufnr = winbufnr(0) +let s:origwin_stl = &l:stl +if expand("%") == "" + exec 'new Untitled.'.(s:settings.use_xhtml ? 'x' : '').'html' +else + exec 'new %.'.(s:settings.use_xhtml ? 'x' : '').'html' +endif + +" Resize the new window to very small in order to make it draw faster +let s:old_winheight = winheight(0) +let s:old_winfixheight = &l:winfixheight +if s:old_winheight > 2 + resize 1 " leave enough room to view one line at a time + norm! G + norm! zt +endif +setlocal winfixheight + +let s:newwin_stl = &l:stl + +" on the new window, set the least time-consuming fold method +let s:old_fdm = &foldmethod +let s:old_fen = &foldenable +setlocal foldmethod=manual +setlocal nofoldenable + +let s:newwin = winnr() +let s:orgwin = bufwinnr(s:orgbufnr) + +setlocal modifiable +%d +let s:old_paste = &paste +set paste +let s:old_magic = &magic +set magic + +let s:lines = [] + +if s:settings.use_xhtml + if s:settings.encoding != "" + call add(s:lines, "<?xml version=\"1.0\" encoding=\"" . s:settings.encoding . "\"?>") + else + call add(s:lines, "<?xml version=\"1.0\"?>") + endif + let s:tag_close = ' />' +else + let s:tag_close = '>' +endif + +let s:HtmlSpace = ' ' +let s:LeadingSpace = ' ' +let s:HtmlEndline = '' +if s:settings.no_pre + let s:HtmlEndline = '<br' . s:tag_close + let s:LeadingSpace = ' ' + let s:HtmlSpace = '\' . s:LeadingSpace +endif + +" HTML header, with the title and generator ;-). Left free space for the CSS, +" to be filled at the end. +call extend(s:lines, [ + \ "<html>", + \ "<head>"]) +" include encoding as close to the top as possible, but only if not already +" contained in XML information (to avoid haggling over content type) +if s:settings.encoding != "" && !s:settings.use_xhtml + call add(s:lines, "<meta http-equiv=\"content-type\" content=\"text/html; charset=" . s:settings.encoding . '"' . s:tag_close) +endif +call extend(s:lines, [ + \ ("<title>".expand("%:p:~").""), + \ ("", + \ s:settings.use_xhtml ? "" : "', + \ '']) + " TODO: IE7 doesn't *actually* support XHTML, maybe we should remove this. + " But if it's served up as tag soup, maybe the following will work, so + " leave it in for now. + call extend(s:lines, [ + \ "", + \]) + else + " if we aren't doing hover_unfold, use CSS 1 only + call extend(s:lines, [ + \ "' + \]) + endif + else + " if we aren't doing any dynamic folding, no need for any special rules + call extend(s:lines, [ + \ "", + \]) + endif +endif + +" insert javascript to toggle folds open and closed +if s:settings.dynamic_folds + call extend(s:lines, [ + \ "", + \ "" + \]) +endif + +if s:settings.no_pre + call extend(s:lines, ["", ""]) +else + call extend(s:lines, ["", "", "
"])
+endif
+
+exe s:orgwin . "wincmd w"
+
+" List of all id's
+let s:idlist = []
+
+" set up progress bar in the status line
+if !s:settings.no_progress
+  " ProgressBar Indicator
+  let s:progressbar={}
+
+  " Progessbar specific functions
+  func! s:ProgressBar(title, max_value, winnr)
+    let pgb=copy(s:progressbar)
+    let pgb.title = a:title.' '
+    let pgb.max_value = a:max_value
+    let pgb.winnr = a:winnr
+    let pgb.cur_value = 0
+    let pgb.items = { 'title'   : { 'color' : 'Statusline' },
+	  \'bar'     : { 'color' : 'Statusline' , 'fillcolor' : 'DiffDelete' , 'bg' : 'Statusline' } ,
+	  \'counter' : { 'color' : 'Statusline' } }
+    let pgb.last_value = 0
+    let pgb.needs_redraw = 0
+    " Note that you must use len(split) instead of len() if you want to use 
+    " unicode in title.
+    "
+    " Subtract 3 for spacing around the title.
+    " Subtract 4 for the percentage display.
+    " Subtract 2 for spacing before this.
+    " Subtract 2 more for the '|' on either side of the progress bar
+    let pgb.subtractedlen=len(split(pgb.title, '\zs'))+3+4+2+2
+    let pgb.max_len = 0
+    set laststatus=2
+    return pgb
+  endfun
+
+  " Function: progressbar.calculate_ticks() {{{1
+  func! s:progressbar.calculate_ticks(pb_len)
+    if a:pb_len<=0
+      let pb_len = 100
+    else
+      let pb_len = a:pb_len
+    endif
+    let self.progress_ticks = map(range(pb_len+1), "v:val * self.max_value / pb_len")
+  endfun
+
+  "Function: progressbar.paint()
+  func! s:progressbar.paint()
+    " Recalculate widths.
+    let max_len = winwidth(self.winnr)
+    let pb_len = 0
+    " always true on first call because of initial value of self.max_len
+    if max_len != self.max_len
+      let self.max_len = max_len
+
+      " Progressbar length
+      let pb_len = max_len - self.subtractedlen
+
+      call self.calculate_ticks(pb_len)
+
+      let self.needs_redraw = 1
+      let cur_value = 0
+      let self.pb_len = pb_len
+    else
+      " start searching at the last found index to make the search for the
+      " appropriate tick value normally take 0 or 1 comparisons
+      let cur_value = self.last_value
+      let pb_len = self.pb_len
+    endif
+
+    let cur_val_max = pb_len > 0 ? pb_len : 100
+
+    " find the current progress bar position based on precalculated thresholds
+    while cur_value < cur_val_max && self.cur_value > self.progress_ticks[cur_value]
+      let cur_value += 1
+    endwhile
+
+    " update progress bar
+    if self.last_value != cur_value || self.needs_redraw || self.cur_value == self.max_value
+      let self.needs_redraw = 1
+      let self.last_value = cur_value
+
+      let t_color  = self.items.title.color
+      let b_fcolor = self.items.bar.fillcolor
+      let b_color  = self.items.bar.color
+      let c_color  = self.items.counter.color
+
+      let stl =  "%#".t_color."#%-( ".self.title." %)".
+	    \"%#".b_color."#".
+	    \(pb_len>0 ?
+	    \	('|%#'.b_fcolor."#%-(".repeat(" ",cur_value)."%)".
+	    \	 '%#'.b_color."#".repeat(" ",pb_len-cur_value)."|"):
+	    \	('')).
+	    \"%=%#".c_color."#%( ".printf("%3.d ",100*self.cur_value/self.max_value)."%% %)"
+      call setwinvar(self.winnr, '&stl', stl)
+    endif
+  endfun
+
+  func! s:progressbar.incr( ... )
+    let self.cur_value += (a:0 ? a:1 : 1)
+    " if we were making a general-purpose progress bar, we'd need to limit to a
+    " lower limit as well, but since we always increment with a positive value
+    " in this script, we only need limit the upper value
+    let self.cur_value = (self.cur_value > self.max_value ? self.max_value : self.cur_value)
+    call self.paint()
+  endfun
+  " }}}
+  if s:settings.dynamic_folds
+    " to process folds we make two passes through each line
+    let s:pgb = s:ProgressBar("Processing folds:", line('$')*2, s:orgwin)
+  endif
+endif
+
+" First do some preprocessing for dynamic folding. Do this for the entire file
+" so we don't accidentally start within a closed fold or something.
+let s:allfolds = []
+
+if s:settings.dynamic_folds
+  let s:lnum = 1
+  let s:end = line('$')
+  " save the fold text and set it to the default so we can find fold levels
+  let s:foldtext_save = &foldtext
+  setlocal foldtext&
+
+  " we will set the foldcolumn in the html to the greater of the maximum fold
+  " level and the current foldcolumn setting
+  let s:foldcolumn = &foldcolumn
+
+  " get all info needed to describe currently closed folds
+  while s:lnum <= s:end
+    if foldclosed(s:lnum) == s:lnum
+      " default fold text has '+-' and then a number of dashes equal to fold
+      " level, so subtract 2 from index of first non-dash after the dashes
+      " in order to get the fold level of the current fold
+      let s:level = match(foldtextresult(s:lnum), '+-*\zs[^-]') - 2
+      if s:level+1 > s:foldcolumn
+	let s:foldcolumn = s:level+1
+      endif
+      " store fold info for later use
+      let s:newfold = {'firstline': s:lnum, 'lastline': foldclosedend(s:lnum), 'level': s:level,'type': "closed-fold"}
+      call add(s:allfolds, s:newfold)
+      " open the fold so we can find any contained folds
+      execute s:lnum."foldopen"
+    else
+      if !s:settings.no_progress
+	call s:pgb.incr()
+	if s:pgb.needs_redraw
+	  redrawstatus
+	  let s:pgb.needs_redraw = 0
+	endif
+      endif
+      let s:lnum = s:lnum + 1
+    endif
+  endwhile
+
+  " close all folds to get info for originally open folds
+  silent! %foldclose!
+  let s:lnum = 1
+
+  " the originally open folds will be all folds we encounter that aren't
+  " already in the list of closed folds
+  while s:lnum <= s:end
+    if foldclosed(s:lnum) == s:lnum
+      " default fold text has '+-' and then a number of dashes equal to fold
+      " level, so subtract 2 from index of first non-dash after the dashes
+      " in order to get the fold level of the current fold
+      let s:level = match(foldtextresult(s:lnum), '+-*\zs[^-]') - 2
+      if s:level+1 > s:foldcolumn
+	let s:foldcolumn = s:level+1
+      endif
+      let s:newfold = {'firstline': s:lnum, 'lastline': foldclosedend(s:lnum), 'level': s:level,'type': "closed-fold"}
+      " only add the fold if we don't already have it
+      if empty(s:allfolds) || index(s:allfolds, s:newfold) == -1
+	let s:newfold.type = "open-fold"
+	call add(s:allfolds, s:newfold)
+      endif
+      " open the fold so we can find any contained folds
+      execute s:lnum."foldopen"
+    else
+      if !s:settings.no_progress
+	call s:pgb.incr()
+	if s:pgb.needs_redraw
+	  redrawstatus
+	  let s:pgb.needs_redraw = 0
+	endif
+      endif
+      let s:lnum = s:lnum + 1
+    endif
+  endwhile
+
+  " sort the folds so that we only ever need to look at the first item in the
+  " list of folds
+  call sort(s:allfolds, "s:FoldCompare")
+
+  let &l:foldtext = s:foldtext_save
+  unlet s:foldtext_save
+
+  " close all folds again so we can get the fold text as we go
+  silent! %foldclose!
+endif
+
+" Now loop over all lines in the original text to convert to html.
+" Use html_start_line and html_end_line if they are set.
+if exists("g:html_start_line")
+  let s:lnum = html_start_line
+  if s:lnum < 1 || s:lnum > line("$")
+    let s:lnum = 1
+  endif
+else
+  let s:lnum = 1
+endif
+if exists("g:html_end_line")
+  let s:end = html_end_line
+  if s:end < s:lnum || s:end > line("$")
+    let s:end = line("$")
+  endif
+else
+  let s:end = line("$")
+endif
+
+" stack to keep track of all the folds containing the current line
+let s:foldstack = []
+
+if !s:settings.no_progress
+  let s:pgb = s:ProgressBar("Processing lines:", s:end - s:lnum + 1, s:orgwin)
+endif
+
+if s:settings.number_lines
+  let s:margin = strlen(s:end) + 1
+else
+  let s:margin = 0
+endif
+
+if has('folding') && !s:settings.ignore_folding
+  let s:foldfillchar = &fillchars[matchend(&fillchars, 'fold:')]
+  if s:foldfillchar == ''
+    let s:foldfillchar = '-'
+  endif
+endif
+let s:difffillchar = &fillchars[matchend(&fillchars, 'diff:')]
+if s:difffillchar == ''
+  let s:difffillchar = '-'
+endif
+
+let s:foldId = 0
+
+while s:lnum <= s:end
+
+  " If there are filler lines for diff mode, show these above the line.
+  let s:filler = diff_filler(s:lnum)
+  if s:filler > 0
+    let s:n = s:filler
+    while s:n > 0
+      let s:new = repeat(s:difffillchar, 3)
+
+      if s:n > 2 && s:n < s:filler && !s:settings.whole_filler
+	let s:new = s:new . " " . s:filler . " inserted lines "
+	let s:n = 2
+      endif
+
+      if !s:settings.no_pre
+	" HTML line wrapping is off--go ahead and fill to the margin
+	let s:new = s:new . repeat(s:difffillchar, &columns - strlen(s:new) - s:margin)
+      else
+	let s:new = s:new . repeat(s:difffillchar, 3)
+      endif
+
+      let s:new = s:HtmlFormat(s:new, "DiffDelete", "")
+      if s:settings.number_lines
+	" Indent if line numbering is on; must be after escaping.
+	let s:new = repeat(s:LeadingSpace, s:margin) . s:new
+      endif
+      call add(s:lines, s:new.s:HtmlEndline)
+
+      let s:n = s:n - 1
+    endwhile
+    unlet s:n
+  endif
+  unlet s:filler
+
+  " Start the line with the line number.
+  if s:settings.number_lines
+    let s:numcol = repeat(' ', s:margin - 1 - strlen(s:lnum)) . s:lnum . ' '
+  else
+    let s:numcol = ""
+  endif
+
+  let s:new = ""
+
+  if has('folding') && !s:settings.ignore_folding && foldclosed(s:lnum) > -1 && !s:settings.dynamic_folds
+    "
+    " This is the beginning of a folded block (with no dynamic folding)
+    "
+    let s:new = s:numcol . foldtextresult(s:lnum)
+    if !s:settings.no_pre
+      " HTML line wrapping is off--go ahead and fill to the margin
+      let s:new = s:new . repeat(s:foldfillchar, &columns - strlen(s:new))
+    endif
+
+    let s:new = s:HtmlFormat(s:new, "Folded", "")
+
+    " Skip to the end of the fold
+    let s:new_lnum = foldclosedend(s:lnum)
+
+    if !s:settings.no_progress
+      call s:pgb.incr(s:new_lnum - s:lnum)
+    endif
+
+    let s:lnum = s:new_lnum
+
+  else
+    "
+    " A line that is not folded, or doing dynamic folding.
+    "
+    let s:line = getline(s:lnum)
+    let s:len = strlen(s:line)
+
+    if s:settings.dynamic_folds
+      " First insert a closing for any open folds that end on this line
+      while !empty(s:foldstack) && get(s:foldstack,0).lastline == s:lnum-1
+	let s:new = s:new.""
+	call remove(s:foldstack, 0)
+      endwhile
+
+      " Now insert an opening any new folds that start on this line
+      let s:firstfold = 1
+      while !empty(s:allfolds) && get(s:allfolds,0).firstline == s:lnum
+	let s:foldId = s:foldId + 1
+	let s:new .= ""
+
+
+	" Unless disabled, add a fold column for the opening line of a fold.
+	"
+	" Note that dynamic folds require using css so we just use css to take
+	" care of the leading spaces rather than using   in the case of
+	" html_no_pre to make it easier
+	if !s:settings.no_foldcolumn
+	  " add fold column that can open the new fold
+	  if s:allfolds[0].level > 1 && s:firstfold
+	    let s:new = s:new . ""
+	    let s:new = s:new . repeat('|', s:allfolds[0].level - 1) . ""
+	  endif
+	  let s:new = s:new . "+"
+	  let s:new = s:new . ""
+
+	  " add fold column that can close the new fold
+	  let s:new = s:new . ""
+	  if s:firstfold
+	    let s:new = s:new . repeat('|', s:allfolds[0].level - 1)
+	  endif
+	  let s:new = s:new . "-"
+	  " only add spaces if we aren't opening another fold on the same line
+	  if get(s:allfolds, 1, {'firstline': 0}).firstline != s:lnum
+	    let s:new = s:new . repeat(" ", s:foldcolumn - s:allfolds[0].level)
+	  endif
+	  let s:new = s:new . ""
+	  let s:firstfold = 0
+	endif
+
+	" add fold text, moving the span ending to the next line so collapsing
+	" of folds works correctly
+	let s:new = s:new . substitute(s:HtmlFormat(s:numcol . foldtextresult(s:lnum), "Folded", ""), '', s:HtmlEndline.'\n\0', '')
+	let s:new = s:new . ""
+
+	" open the fold now that we have the fold text to allow retrieval of
+	" fold text for subsequent folds
+	execute s:lnum."foldopen"
+	call insert(s:foldstack, remove(s:allfolds,0))
+	let s:foldstack[0].id = s:foldId
+      endwhile
+
+      " Unless disabled, add a fold column for other lines.
+      "
+      " Note that dynamic folds require using css so we just use css to take
+      " care of the leading spaces rather than using   in the case of
+      " html_no_pre to make it easier
+      if !s:settings.no_foldcolumn
+	if empty(s:foldstack)
+	  " add the empty foldcolumn for unfolded lines if there is a fold
+	  " column at all
+	  if s:foldcolumn > 0
+	    let s:new = s:new . s:HtmlFormat(repeat(' ', s:foldcolumn), "FoldColumn", "")
+	  endif
+	else
+	  " add the fold column for folds not on the opening line
+	  if get(s:foldstack, 0).firstline < s:lnum
+	    let s:new = s:new . ""
+	    let s:new = s:new . repeat('|', s:foldstack[0].level)
+	    let s:new = s:new . repeat(' ', s:foldcolumn - s:foldstack[0].level) . ""
+	  endif
+	endif
+      endif
+    endif
+
+    " Now continue with the unfolded line text
+    if s:settings.number_lines
+      " TODO: why not use the real highlight name here?
+      let s:new = s:new . s:HtmlFormat(s:numcol, "lnr", "")
+    endif
+
+    " Get the diff attribute, if any.
+    let s:diffattr = diff_hlID(s:lnum, 1)
+
+    " initialize conceal info to act like not concealed, just in case
+    let s:concealinfo = [0, '']
+
+    " Loop over each character in the line
+    let s:col = 1
+
+    " most of the time we won't use the diff_id, initialize to zero
+    let s:diff_id = 0
+    let s:diff_id_name = ""
+
+    while s:col <= s:len || (s:col == 1 && s:diffattr)
+      let s:startcol = s:col " The start column for processing text
+      if !s:settings.ignore_conceal && has('conceal')
+	let s:concealinfo = synconcealed(s:lnum, s:col)
+      endif
+      if !s:settings.ignore_conceal && s:concealinfo[0]
+	let s:col = s:col + 1
+	" Speed loop (it's small - that's the trick)
+	" Go along till we find a change in the match sequence number (ending
+	" the specific concealed region) or until there are no more concealed
+	" characters.
+	while s:col <= s:len && s:concealinfo == synconcealed(s:lnum, s:col) | let s:col = s:col + 1 | endwhile
+      elseif s:diffattr
+	let s:diff_id = diff_hlID(s:lnum, s:col)
+	let s:id = synID(s:lnum, s:col, 1)
+	let s:col = s:col + 1
+	" Speed loop (it's small - that's the trick)
+	" Go along till we find a change in hlID
+	while s:col <= s:len && s:id == synID(s:lnum, s:col, 1)
+	      \   && s:diff_id == diff_hlID(s:lnum, s:col) |
+	      \     let s:col = s:col + 1 |
+	      \ endwhile
+	if s:len < &columns && !s:settings.no_pre
+	  " Add spaces at the end of the raw text line to extend the changed
+	  " line to the full width.
+	  let s:line = s:line . repeat(' ', &columns - virtcol([s:lnum, s:len]) - s:margin)
+	  let s:len = &columns
+	endif
+      else
+	let s:id = synID(s:lnum, s:col, 1)
+	let s:col = s:col + 1
+	" Speed loop (it's small - that's the trick)
+	" Go along till we find a change in synID
+	while s:col <= s:len && s:id == synID(s:lnum, s:col, 1) | let s:col = s:col + 1 | endwhile
+      endif
+
+      if s:settings.ignore_conceal || !s:concealinfo[0]
+	" Expand tabs
+	let s:expandedtab = strpart(s:line, s:startcol - 1, s:col - s:startcol)
+	let s:offset = 0
+	let s:idx = stridx(s:expandedtab, "\t")
+	while s:idx >= 0
+	  if has("multi_byte_encoding")
+	    if s:startcol + s:idx == 1
+	      let s:i = &ts
+	    else
+	      if s:idx == 0
+		let s:prevc = matchstr(s:line, '.\%' . (s:startcol + s:idx + s:offset) . 'c')
+	      else
+		let s:prevc = matchstr(s:expandedtab, '.\%' . (s:idx + 1) . 'c')
+	      endif
+	      let s:vcol = virtcol([s:lnum, s:startcol + s:idx + s:offset - len(s:prevc)])
+	      let s:i = &ts - (s:vcol % &ts)
+	    endif
+	    let s:offset -= s:i - 1
+	  else
+	    let s:i = &ts - ((s:idx + s:startcol - 1) % &ts)
+	  endif
+	  let s:expandedtab = substitute(s:expandedtab, '\t', repeat(' ', s:i), '')
+	  let s:idx = stridx(s:expandedtab, "\t")
+	endwhile
+
+	" get the highlight group name to use
+	let s:id = synIDtrans(s:id)
+	let s:id_name = synIDattr(s:id, "name", s:whatterm)
+	if s:diff_id
+	  let s:diff_id_name = synIDattr(s:diff_id, "name", s:whatterm)
+	endif
+      else
+	" use Conceal highlighting for concealed text
+	let s:id_name = 'Conceal'
+	let s:expandedtab = s:concealinfo[1]
+      endif
+
+      " Output the text with the same synID, with class set to {s:id_name},
+      " unless it has been concealed completely.
+      if strlen(s:expandedtab) > 0
+	let s:new = s:new . s:HtmlFormat(s:expandedtab,  s:id_name, s:diff_id_name)
+      endif
+    endwhile
+  endif
+
+  call extend(s:lines, split(s:new.s:HtmlEndline, '\n', 1))
+  if !s:settings.no_progress && s:pgb.needs_redraw
+    redrawstatus
+    let s:pgb.needs_redraw = 0
+  endif
+  let s:lnum = s:lnum + 1
+
+  if !s:settings.no_progress
+    call s:pgb.incr()
+  endif
+endwhile
+
+if s:settings.dynamic_folds
+  " finish off any open folds
+  while !empty(s:foldstack)
+    let s:lines[-1].=""
+    call remove(s:foldstack, 0)
+  endwhile
+
+  " add fold column to the style list if not already there
+  let s:id = hlID('FoldColumn')
+  if index(s:idlist, s:id) == -1
+    call insert(s:idlist, s:id)
+  endif
+endif
+
+if s:settings.no_pre
+  if !s:settings.use_css
+    " Close off the font tag that encapsulates the whole 
+    call extend(s:lines, ["", "", ""])
+  else
+    call extend(s:lines, ["", ""])
+  endif
+else
+  call extend(s:lines, ["
", "", ""]) +endif + +exe s:newwin . "wincmd w" +call setline(1, s:lines) +unlet s:lines + +" Now, when we finally know which, we define the colors and styles +if s:settings.use_css + 1;/